From 3f64ffa110e82fbefef3e1d5964e9c9988360d20 Mon Sep 17 00:00:00 2001 From: Joshua Seigler Date: Tue, 30 Nov 2021 10:46:56 -0500 Subject: [PATCH] publish: fix: bugs generated from commit c853faf3ca575d0ce34555e7f4bcabd574ce0b03 --- index.ed2f3c79.js => index.6b10736e.js | 6 +++--- index.ed2f3c79.js.map => index.6b10736e.js.map | 2 +- index.html | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) rename index.ed2f3c79.js => index.6b10736e.js (77%) rename index.ed2f3c79.js.map => index.6b10736e.js.map (50%) diff --git a/index.ed2f3c79.js b/index.6b10736e.js similarity index 77% rename from index.ed2f3c79.js rename to index.6b10736e.js index 5ddc635..28f9953 100644 --- a/index.ed2f3c79.js +++ b/index.6b10736e.js @@ -1,4 +1,4 @@ -!function(e,t,r,i,n){var s="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"!=typeof window?window:"undefined"!=typeof global?global:{},o="function"==typeof s.parcelRequire6d65&&s.parcelRequire6d65,a=o.cache||{},c="undefined"!=typeof module&&"function"==typeof module.require&&module.require.bind(module);function u(t,r){if(!a[t]){if(!e[t]){var i="function"==typeof s.parcelRequire6d65&&s.parcelRequire6d65;if(!r&&i)return i(t,!0);if(o)return o(t,!0);if(c&&"string"==typeof t)return c(t);var n=new Error("Cannot find module '"+t+"'");throw n.code="MODULE_NOT_FOUND",n}d.resolve=function(r){return e[t][1][r]||r},d.cache={};var l=a[t]=new u.Module(t);e[t][0].call(l.exports,d,l,l.exports,this)}return a[t].exports;function d(e){return u(d.resolve(e))}}u.isParcelRequire=!0,u.Module=function(e){this.id=e,this.bundle=u,this.exports={}},u.modules=e,u.cache=a,u.parent=o,u.register=function(t,r){e[t]=[function(e,t){t.exports=r},{}]},Object.defineProperty(u,"root",{get:function(){return s.parcelRequire6d65}}),s.parcelRequire6d65=u;for(var l=0;l{const e=u("hash"),t=u("source"),r=u("title"),i=u("time");if(function(){const i=document.getElementById("video"),n=document.getElementById("contextBackground"),s=document.getElementById("contextMenu");i.oncontextmenu=e=>{n.classList.toggle("is-hidden"),s.style.left=e.pageX+"px",s.style.top=e.pageY+"px",e.preventDefault()},n.onclick=e=>{e.stopPropagation(),n.classList.toggle("is-hidden")};const o=`http://ipfsvideo.cc?hash=${e}${r&&"&title="+encodeURIComponent(r)||""}${t&&"&source="+encodeURIComponent(t)||""}`;document.getElementById("contextMenu-url").onclick=e=>{navigator.clipboard.writeText(o)},document.getElementById("contextMenu-urlWithTime").onclick=e=>{navigator.clipboard.writeText(`${o}&time=${Math.round(i.currentTime)}`)}}(),r&&(document.title=r),e){document.getElementById("help").style.display="none";const r=document.getElementById("video");r.style.display="block";const s="ipfs-"+Math.random();l("Connecting to IPFS");const a=await n.create({repo:s});if(l("Connected"),o.default.DefaultConfig.loader=c.default,o.default.DefaultConfig.debug=!1,o.default.isSupported()){const n=new o.default;n.config.ipfs=a,n.config.ipfsHash=e,l("Video loading"),n.loadSource(t||"master.m3u8"),n.attachMedia(r),n.on(o.default.Events.MANIFEST_PARSED,(()=>{l("Video loaded",!0),i&&(r.currentTime=i),r.play()}))}}d(),window.addEventListener("resize",d)}))},{"ipfs-core":"iJfvU","hls.js":"juo1D","hlsjs-ipfs-loader":"1xTo6","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],iJfvU:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./components/index.js"),n=e("libp2p-crypto"),s=e("is-ipfs"),o=e("multiformats/cid"),a=e("multiaddr"),c=e("peer-id"),u=e("ipfs-utils/src/files/glob-source.js"),l=e("ipfs-utils/src/files/url-source.js");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var f=d(n),h=d(s),p=d(c),g=d(u),y=d(l);const m=i.create,b=f.default,v=h.default,w=o.CID,_=a.Multiaddr,E=p.default,S=g.default,T=y.default;r.CID=w,r.PeerId=E,r.create=m,r.crypto=b,r.globSource=S,r.isIPFS=v,r.multiaddr=_,r.urlSource=T},{"./components/index.js":"RQOpu","libp2p-crypto":"bb1cb","is-ipfs":"40iuV","multiformats/cid":"9ooAY",multiaddr:"8Mu1u","peer-id":"8Bdb3","ipfs-utils/src/files/glob-source.js":"lHksA","ipfs-utils/src/files/url-source.js":"jQSIS"}],RQOpu:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("merge-options"),n=e("ipfs-utils/src/env.js"),s=e("debug"),o=e("err-code"),a=e("ipfs-unixfs"),c=e("@ipld/dag-pb"),u=e("@ipld/dag-cbor"),l=e("multiformats/hashes/identity"),d=e("multiformats/basics"),f=e("ipfs-core-config/init-assets"),h=e("../errors.js"),p=e("uint8arrays/from-string"),g=e("./start.js"),y=e("./stop.js"),m=e("./dns.js"),b=e("./is-online.js"),v=e("./resolve.js"),w=e("./pin/index.js"),_=e("./ipns.js"),E=e("./name/index.js"),S=e("./refs/index.js"),T=e("./refs/local.js"),A=e("./bitswap/index.js"),k=e("./bootstrap/index.js"),I=e("./block/index.js"),R=e("./root.js"),P=e("./version.js"),O=e("./id.js"),C=e("./config/index.js"),j=e("./dag/index.js"),D=e("../preload.js"),M=e("../mfs-preload.js"),x=e("./files/index.js"),B=e("./key/index.js"),L=e("./object/index.js"),N=e("./repo/index.js"),U=e("./stats/index.js"),F=e("./storage.js"),K=e("./network.js"),z=e("../utils/service.js"),V=e("./swarm/index.js"),q=e("./ping.js"),G=e("./dht.js"),H=e("./pubsub.js"),$=e("ipfs-core-utils/multicodecs"),W=e("ipfs-core-utils/multihashes"),Y=e("ipfs-core-utils/multibases");function X(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function Z(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var Q=X(i),J=X(s),ee=X(o),te=Z(c),re=Z(u);const ie=Q.default.bind({ignoreUndefined:!0}),ne=J.default("ipfs");class se{constructor({print:e,storage:t,codecs:r,options:i}){const{peerId:n,repo:s,keychain:o}=t,a=z.Service.create(K.Network),c=D.createPreloader(i.preload),u=m.createDns(),l=b.createIsOnline({network:a}),f=new _.IPNSAPI(i),h=Object.values(d.hashes);(i.ipld&&i.ipld.hashers?i.ipld.hashers:[]).forEach((e=>h.push(e))),this.hashers=new W.Multihashes({hashers:h,loadHasher:i.ipld&&i.ipld.loadHasher});const p=Object.values(d.bases);(i.ipld&&i.ipld.bases?i.ipld.bases:[]).forEach((e=>p.push(e))),this.bases=new Y.Multibases({bases:p,loadBase:i.ipld&&i.ipld.loadBase});const F=new w.PinAPI({repo:s,codecs:r}),$=new I.BlockAPI({codecs:r,hashers:this.hashers,preload:c,repo:s}),X=new E.NameAPI({dns:u,ipns:f,repo:s,codecs:r,peerId:n,isOnline:l,keychain:o,options:i}),Z=v.createResolve({repo:s,codecs:r,bases:this.bases,name:X}),Q=new j.DagAPI({repo:s,codecs:r,hashers:this.hashers,preload:c}),J=Object.assign(S.createRefs({repo:s,codecs:r,resolve:Z,preload:c}),{local:T.createLocal({repo:t.repo})}),{add:te,addAll:re,cat:ie,get:ne,ls:se}=new R.RootAPI({preload:c,repo:s,options:i.EXPERIMENTAL}),oe=x.createFiles({repo:s,preload:c,hashers:this.hashers,options:i}),ae=M.createMfsPreloader({files:oe,preload:c,options:i.preload});this.preload=c,this.name=X,this.ipns=f,this.pin=F,this.resolve=Z,this.block=$,this.refs=J,this.start=g.createStart({network:a,peerId:n,repo:s,preload:c,ipns:f,mfsPreload:ae,print:e,keychain:o,options:i}),this.stop=y.createStop({network:a,preload:c,mfsPreload:ae,ipns:f,repo:s}),this.dht=G.createDht({network:a,repo:s}),this.pubsub=H.createPubsub({network:a,config:i.config}),this.dns=u,this.isOnline=l,this.id=O.createId({network:a,peerId:n}),this.version=P.createVersion({repo:s}),this.bitswap=new A.BitswapAPI({network:a}),this.bootstrap=new k.BootstrapAPI({repo:s}),this.config=C.createConfig({repo:s}),this.ping=q.createPing({network:a}),this.add=te,this.addAll=re,this.cat=ie,this.get=ne,this.ls=se,this.dag=Q,this.files=oe,this.key=new B.KeyAPI({keychain:o}),this.object=new L.ObjectAPI({preload:c,codecs:r,repo:s}),this.repo=new N.RepoAPI({repo:s,hashers:this.hashers}),this.stats=new U.StatsAPI({repo:s,network:a}),this.swarm=new V.SwarmAPI({network:a}),Object.defineProperty(this,"libp2p",{get(){const e=a.try();return e?e.libp2p:void 0}});const ce=()=>Promise.reject(ee.default(new Error("Not implemented"),"ERR_NOT_IMPLEMENTED"));this.commands=ce,this.diag={cmds:ce,net:ce,sys:ce},this.log={level:ce,ls:ce,tail:async function*(){throw ee.default(new Error("Not implemented"),"ERR_NOT_IMPLEMENTED")}},this.mount=ce,this.codecs=r}async init(){throw new h.AlreadyInitializedError}}r.create=async function(e={}){const t=(e=ie({start:!0,EXPERIMENTAL:{},preload:{enabled:!n.isTest,addresses:["/dns4/node0.preload.ipfs.io/https","/dns4/node1.preload.ipfs.io/https","/dns4/node2.preload.ipfs.io/https","/dns4/node3.preload.ipfs.io/https"]}},e)).init||{},r={name:l.identity.name,code:l.identity.code,encode:e=>e,decode:e=>e},i=Object.values(d.codecs);[te,re,r].concat(e.ipld&&e.ipld.codecs||[]).forEach((e=>i.push(e)));const s=new $.Multicodecs({codecs:i,loadCodec:e.ipld&&e.ipld.loadCodec}),o=e.silent?ne:console.log,c=await F.Storage.start(o,s,e),u=await c.repo.config.getAll(),h=new se({storage:c,print:o,codecs:s,options:{...e,config:u}});if(await h.preload.start(),h.ipns.startOffline(c),c.isNew&&!t.emptyRepo){const e=await(async e=>{const t=te.encode({Data:new a.UnixFS({type:"directory"}).marshal(),Links:[]}),r=await e.block.put(t,{mhtype:"sha2-256",format:"dag-pb"});return await e.pin.add(r),r})(h);ne("adding default assets"),await f.initAssets({addAll:h.addAll,print:o}),ne("initializing IPNS keyspace"),await h.ipns.initializeKeyspace(c.peerId.privKey,p.fromString(`/ipfs/${e}`))}return!1!==e.start&&await h.start(),h}},{"merge-options":"fupyv","ipfs-utils/src/env.js":"flyHr",debug:"bO5wM","err-code":"chZjB","ipfs-unixfs":"dF9VO","@ipld/dag-pb":"i2cdx","@ipld/dag-cbor":"3498i","multiformats/hashes/identity":"eYCZn","multiformats/basics":"lPcQG","ipfs-core-config/init-assets":"d1lP3","../errors.js":"j69o8","uint8arrays/from-string":"dF7Y4","./start.js":"93XEg","./stop.js":"kkxN3","./dns.js":"4N8JT","./is-online.js":"2KSm7","./resolve.js":"faFUb","./pin/index.js":"hDUM1","./ipns.js":"fTgTV","./name/index.js":"u6g6o","./refs/index.js":"9Y9Id","./refs/local.js":"lEaxs","./bitswap/index.js":"lGDjO","./bootstrap/index.js":"dh9oy","./block/index.js":"jcbA3","./root.js":"3wOOx","./version.js":"8mBfq","./id.js":"bQa6q","./config/index.js":"3uMSz","./dag/index.js":"9rLzF","../preload.js":"kBOEV","../mfs-preload.js":"7arhH","./files/index.js":"1yxa2","./key/index.js":"aJXOU","./object/index.js":"kwMxL","./repo/index.js":"1qDVo","./stats/index.js":"1NkyG","./storage.js":"bI63q","./network.js":"1MCQb","../utils/service.js":"ethcf","./swarm/index.js":"cGDFf","./ping.js":"dHQEh","./dht.js":"kOgiu","./pubsub.js":"7IJgU","ipfs-core-utils/multicodecs":"4I7TQ","ipfs-core-utils/multihashes":"febSG","ipfs-core-utils/multibases":"lr7wI"}],fupyv:[function(e,t,r){"use strict";const i=e("is-plain-obj"),{hasOwnProperty:n}=Object.prototype,{propertyIsEnumerable:s}=Object,o=(e,t,r)=>Object.defineProperty(e,t,{value:r,writable:!0,enumerable:!0,configurable:!0}),a=this,c={concatArrays:!1,ignoreUndefined:!1},u=e=>{const t=[];for(const r in e)n.call(e,r)&&t.push(r);if(Object.getOwnPropertySymbols){const r=Object.getOwnPropertySymbols(e);for(const i of r)s.call(e,i)&&t.push(i)}return t};function l(e){return Array.isArray(e)?function(e){const t=e.slice(0,0);return u(e).forEach((r=>{o(t,r,l(e[r]))})),t}(e):i(e)?function(e){const t=null===Object.getPrototypeOf(e)?Object.create(null):{};return u(e).forEach((r=>{o(t,r,l(e[r]))})),t}(e):e}const d=(e,t,r,i)=>(r.forEach((r=>{void 0===t[r]&&i.ignoreUndefined||(r in e&&e[r]!==Object.getPrototypeOf(e)?o(e,r,f(e[r],t[r],i)):o(e,r,l(t[r])))})),e);function f(e,t,r){return r.concatArrays&&Array.isArray(e)&&Array.isArray(t)?((e,t,r)=>{let i=e.slice(0,0),s=0;return[e,t].forEach((t=>{const a=[];for(let r=0;r!a.includes(e))),r)})),i})(e,t,r):i(t)&&i(e)?d(e,t,u(t),r):l(t)}t.exports=function(...e){const t=f(l(c),this!==a&&this||{},c);let r={_:{}};for(const n of e)if(void 0!==n){if(!i(n))throw new TypeError("`"+n+"` is not an Option Object");r=f(r,{_:n},t)}return r._}},{"is-plain-obj":"jGt65"}],jGt65:[function(e,t,r){"use strict";t.exports=e=>{if("[object Object]"!==Object.prototype.toString.call(e))return!1;const t=Object.getPrototypeOf(e);return null===t||t===Object.prototype}},{}],flyHr:[function(e,t,r){var i=e("process");const n=e("is-electron"),s="object"==typeof window&&"object"==typeof document&&9===document.nodeType,o=n(),a=s&&!o,c=o&&!s,u=o&&s,l="function"==typeof e&&void 0!==i&&void 0!==i.release&&"node"===i.release.name&&!o,d="function"==typeof importScripts&&"undefined"!=typeof self&&"undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope,f=void 0!==i&&void 0!==i.env&&!1,h="undefined"!=typeof navigator&&"ReactNative"===navigator.product;t.exports={isTest:f,isElectron:o,isElectronMain:c,isElectronRenderer:u,isNode:l,isBrowser:a,isWebWorker:d,isEnvWithDom:s,isReactNative:h}},{process:"bjUAi","is-electron":"e6ybt"}],bjUAi:[function(e,t,r){var i,n,s=t.exports={};function o(){throw new Error("setTimeout has not been defined")}function a(){throw new Error("clearTimeout has not been defined")}function c(e){if(i===setTimeout)return setTimeout(e,0);if((i===o||!i)&&setTimeout)return i=setTimeout,setTimeout(e,0);try{return i(e,0)}catch(t){try{return i.call(null,e,0)}catch(t){return i.call(this,e,0)}}}!function(){try{i="function"==typeof setTimeout?setTimeout:o}catch(e){i=o}try{n="function"==typeof clearTimeout?clearTimeout:a}catch(e){n=a}}();var u,l=[],d=!1,f=-1;function h(){d&&u&&(d=!1,u.length?l=u.concat(l):f=-1,l.length&&p())}function p(){if(!d){var e=c(h);d=!0;for(var t=l.length;t;){for(u=l,l=[];++f1)for(var r=1;r=0)}},{process:"bjUAi"}],bO5wM:[function(e,t,r){var i=e("process");r.formatArgs=function(e){if(e[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+e[0]+(this.useColors?"%c ":" ")+"+"+t.exports.humanize(this.diff),!this.useColors)return;const r="color: "+this.color;e.splice(1,0,r,"color: inherit");let i=0,n=0;e[0].replace(/%[a-zA-Z%]/g,(e=>{"%%"!==e&&(i++,"%c"===e&&(n=i))})),e.splice(n,0,r)},r.save=function(e){try{e?r.storage.setItem("debug",e):r.storage.removeItem("debug")}catch(e){}},r.load=function(){let e;try{e=r.storage.getItem("debug")}catch(e){}!e&&void 0!==i&&"env"in i&&(e=void 0);return e},r.useColors=function(){return!("undefined"==typeof window||!window.process||"renderer"!==window.process.type&&!window.process.__nwjs)||("undefined"==typeof navigator||!navigator.userAgent||!navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))&&("undefined"!=typeof document&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||"undefined"!=typeof window&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/))},r.storage=function(){try{return localStorage}catch(e){}}(),r.destroy=(()=>{let e=!1;return()=>{e||(e=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),r.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"],r.log=console.debug||console.log||(()=>{}),t.exports=e("./common")(r);const{formatters:n}=t.exports;n.j=function(e){try{return JSON.stringify(e)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}},{process:"bjUAi","./common":"5mxUS"}],"5mxUS":[function(e,t,r){t.exports=function(t){function r(e){let t,n,s,o=null;function a(...e){if(!a.enabled)return;const i=a,n=Number(new Date),s=n-(t||n);i.diff=s,i.prev=t,i.curr=n,t=n,e[0]=r.coerce(e[0]),"string"!=typeof e[0]&&e.unshift("%O");let o=0;e[0]=e[0].replace(/%([a-zA-Z%])/g,((t,n)=>{if("%%"===t)return"%";o++;const s=r.formatters[n];if("function"==typeof s){const r=e[o];t=s.call(i,r),e.splice(o,1),o--}return t})),r.formatArgs.call(i,e);(i.log||r.log).apply(i,e)}return a.namespace=e,a.useColors=r.useColors(),a.color=r.selectColor(e),a.extend=i,a.destroy=r.destroy,Object.defineProperty(a,"enabled",{enumerable:!0,configurable:!1,get:()=>null!==o?o:(n!==r.namespaces&&(n=r.namespaces,s=r.enabled(e)),s),set:e=>{o=e}}),"function"==typeof r.init&&r.init(a),a}function i(e,t){const i=r(this.namespace+(void 0===t?":":t)+e);return i.log=this.log,i}function n(e){return e.toString().substring(2,e.toString().length-2).replace(/\.\*\?$/,"*")}return r.debug=r,r.default=r,r.coerce=function(e){return e instanceof Error?e.stack||e.message:e},r.disable=function(){const e=[...r.names.map(n),...r.skips.map(n).map((e=>"-"+e))].join(",");return r.enable(""),e},r.enable=function(e){let t;r.save(e),r.namespaces=e,r.names=[],r.skips=[];const i=("string"==typeof e?e:"").split(/[\s,]+/),n=i.length;for(t=0;t{r[e]=t[e]})),r.names=[],r.skips=[],r.formatters={},r.selectColor=function(e){let t=0;for(let r=0;r=1.5*r;return Math.round(e/r)+" "+i+(n?"s":"")}t.exports=function(e,t){t=t||{};var r,l,d=typeof e;if("string"===d&&e.length>0)return function(e){if((e=String(e)).length>100)return;var t=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(e);if(!t)return;var r=parseFloat(t[1]);switch((t[2]||"ms").toLowerCase()){case"years":case"year":case"yrs":case"yr":case"y":return r*c;case"weeks":case"week":case"w":return r*a;case"days":case"day":case"d":return r*o;case"hours":case"hour":case"hrs":case"hr":case"h":return r*s;case"minutes":case"minute":case"mins":case"min":case"m":return r*n;case"seconds":case"second":case"secs":case"sec":case"s":return r*i;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return r;default:return}}(e);if("number"===d&&isFinite(e))return t.long?(r=e,(l=Math.abs(r))>=o?u(r,l,o,"day"):l>=s?u(r,l,s,"hour"):l>=n?u(r,l,n,"minute"):l>=i?u(r,l,i,"second"):r+" ms"):function(e){var t=Math.abs(e);return t>=o?Math.round(e/o)+"d":t>=s?Math.round(e/s)+"h":t>=n?Math.round(e/n)+"m":t>=i?Math.round(e/i)+"s":e+"ms"}(e);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(e))}},{}],chZjB:[function(e,t,r){"use strict";function i(e,t){for(const r in t)Object.defineProperty(e,r,{value:t[r],enumerable:!0,configurable:!0});return e}t.exports=function(e,t,r){if(!e||"string"==typeof e)throw new TypeError("Please pass an Error to err-code");r||(r={}),"object"==typeof t&&(r=t,t=""),t&&(r.code=t);try{return i(e,r)}catch(t){r.message=e.message,r.stack=e.stack;const n=function(){};n.prototype=Object.create(Object.getPrototypeOf(e));return i(new n,r)}}},{}],dF9VO:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("err-code"),n=e("./unixfs.js");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=s(i);const a=n.Data,c=["raw","directory","file","metadata","symlink","hamt-sharded-directory"],u=["directory","hamt-sharded-directory"],l=parseInt("0644",8),d=parseInt("0755",8);function f(e){if(null!=e)return"number"==typeof e?4095&e:"0"===(e=e.toString()).substring(0,1)?4095&parseInt(e,8):4095&parseInt(e,10)}function h(e){if(null==e)return;let t;if(null!=e.secs&&(t={secs:e.secs,nsecs:e.nsecs}),null!=e.Seconds&&(t={secs:e.Seconds,nsecs:e.FractionalNanoseconds}),Array.isArray(e)&&(t={secs:e[0],nsecs:e[1]}),e instanceof Date){const r=e.getTime(),i=Math.floor(r/1e3);t={secs:i,nsecs:1e3*(r-1e3*i)}}if(Object.prototype.hasOwnProperty.call(t,"secs")){if(null!=t&&null!=t.nsecs&&(t.nsecs<0||t.nsecs>999999999))throw o.default(new Error("mtime-nsecs must be within the range [0,999999999]"),"ERR_INVALID_MTIME_NSECS");return t}}class p{static unmarshal(e){const t=a.decode(e),r=a.toObject(t,{defaults:!1,arrays:!0,longs:Number,objects:!1}),i=new p({type:c[r.Type],data:r.Data,blockSizes:r.blocksizes,mode:r.mode,mtime:r.mtime?{secs:r.mtime.Seconds,nsecs:r.mtime.FractionalNanoseconds}:void 0});return i._originalMode=r.mode||0,i}constructor(e={type:"file"}){const{type:t,data:r,blockSizes:i,hashType:n,fanout:s,mtime:a,mode:u}=e;if(t&&!c.includes(t))throw o.default(new Error("Type: "+t+" is not valid"),"ERR_INVALID_TYPE");this.type=t||"file",this.data=r,this.hashType=n,this.fanout=s,this.blockSizes=i||[],this._originalMode=0,this.mode=f(u),a&&(this.mtime=h(a),this.mtime&&!this.mtime.nsecs&&(this.mtime.nsecs=0))}set mode(e){this._mode=this.isDirectory()?d:l;const t=f(e);void 0!==t&&(this._mode=t)}get mode(){return this._mode}isDirectory(){return Boolean(this.type&&u.includes(this.type))}addBlockSize(e){this.blockSizes.push(e)}removeBlockSize(e){this.blockSizes.splice(e,1)}fileSize(){if(this.isDirectory())return 0;let e=0;return this.blockSizes.forEach((t=>{e+=t})),this.data&&(e+=this.data.length),e}marshal(){let e;switch(this.type){case"raw":e=a.DataType.Raw;break;case"directory":e=a.DataType.Directory;break;case"file":e=a.DataType.File;break;case"metadata":e=a.DataType.Metadata;break;case"symlink":e=a.DataType.Symlink;break;case"hamt-sharded-directory":e=a.DataType.HAMTShard;break;default:throw o.default(new Error("Type: "+e+" is not valid"),"ERR_INVALID_TYPE")}let t,r,i=this.data;if(this.data&&this.data.length||(i=void 0),null!=this.mode&&(t=4294963200&this._originalMode|(f(this.mode)||0),t!==l||this.isDirectory()||(t=void 0),t===d&&this.isDirectory()&&(t=void 0)),null!=this.mtime){const e=h(this.mtime);e&&(r={Seconds:e.secs,FractionalNanoseconds:e.nsecs},0===r.FractionalNanoseconds&&delete r.FractionalNanoseconds)}const n={Type:e,Data:i,filesize:this.isDirectory()?void 0:this.fileSize(),blocksizes:this.blockSizes,hashType:this.hashType,fanout:this.fanout,mode:t,mtime:r};return a.encode(n).finish()}}r.UnixFS=p,r.parseMode=f,r.parseMtime=h},{"err-code":"chZjB","./unixfs.js":"l2F50"}],l2F50:[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("protobufjs/minimal.js"));const s=n.default.Reader,o=n.default.Writer,a=n.default.util,c=n.default.roots["ipfs-unixfs"]||(n.default.roots["ipfs-unixfs"]={}),u=c.Data=(()=>{function e(e){if(this.blocksizes=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.Type=e.int32();break;case 2:i.Data=e.bytes();break;case 3:i.filesize=e.uint64();break;case 4:if(i.blocksizes&&i.blocksizes.length||(i.blocksizes=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>0,e.filesize.high>>>0).toNumber(!0))),e.blocksizes){if(!Array.isArray(e.blocksizes))throw TypeError(".Data.blocksizes: array expected");t.blocksizes=[];for(var r=0;r>>0,e.blocksizes[r].high>>>0).toNumber(!0))}if(null!=e.hashType&&(a.Long?(t.hashType=a.Long.fromValue(e.hashType)).unsigned=!0:"string"==typeof e.hashType?t.hashType=parseInt(e.hashType,10):"number"==typeof e.hashType?t.hashType=e.hashType:"object"==typeof e.hashType&&(t.hashType=new a.LongBits(e.hashType.low>>>0,e.hashType.high>>>0).toNumber(!0))),null!=e.fanout&&(a.Long?(t.fanout=a.Long.fromValue(e.fanout)).unsigned=!0:"string"==typeof e.fanout?t.fanout=parseInt(e.fanout,10):"number"==typeof e.fanout?t.fanout=e.fanout:"object"==typeof e.fanout&&(t.fanout=new a.LongBits(e.fanout.low>>>0,e.fanout.high>>>0).toNumber(!0))),null!=e.mode&&(t.mode=e.mode>>>0),null!=e.mtime){if("object"!=typeof e.mtime)throw TypeError(".Data.mtime: object expected");t.mtime=c.UnixTime.fromObject(e.mtime)}return t},e.toObject=function(e,t){t||(t={});var r={};if((t.arrays||t.defaults)&&(r.blocksizes=[]),t.defaults){if(r.Type=t.enums===String?"Raw":0,t.bytes===String?r.Data="":(r.Data=[],t.bytes!==Array&&(r.Data=a.newBuffer(r.Data))),a.Long){var i=new a.Long(0,0,!0);r.filesize=t.longs===String?i.toString():t.longs===Number?i.toNumber():i}else r.filesize=t.longs===String?"0":0;if(a.Long){i=new a.Long(0,0,!0);r.hashType=t.longs===String?i.toString():t.longs===Number?i.toNumber():i}else r.hashType=t.longs===String?"0":0;if(a.Long){i=new a.Long(0,0,!0);r.fanout=t.longs===String?i.toString():t.longs===Number?i.toNumber():i}else r.fanout=t.longs===String?"0":0;r.mode=0,r.mtime=null}if(null!=e.Type&&e.hasOwnProperty("Type")&&(r.Type=t.enums===String?c.Data.DataType[e.Type]:e.Type),null!=e.Data&&e.hasOwnProperty("Data")&&(r.Data=t.bytes===String?a.base64.encode(e.Data,0,e.Data.length):t.bytes===Array?Array.prototype.slice.call(e.Data):e.Data),null!=e.filesize&&e.hasOwnProperty("filesize")&&("number"==typeof e.filesize?r.filesize=t.longs===String?String(e.filesize):e.filesize:r.filesize=t.longs===String?a.Long.prototype.toString.call(e.filesize):t.longs===Number?new a.LongBits(e.filesize.low>>>0,e.filesize.high>>>0).toNumber(!0):e.filesize),e.blocksizes&&e.blocksizes.length){r.blocksizes=[];for(var n=0;n>>0,e.blocksizes[n].high>>>0).toNumber(!0):e.blocksizes[n]}return null!=e.hashType&&e.hasOwnProperty("hashType")&&("number"==typeof e.hashType?r.hashType=t.longs===String?String(e.hashType):e.hashType:r.hashType=t.longs===String?a.Long.prototype.toString.call(e.hashType):t.longs===Number?new a.LongBits(e.hashType.low>>>0,e.hashType.high>>>0).toNumber(!0):e.hashType),null!=e.fanout&&e.hasOwnProperty("fanout")&&("number"==typeof e.fanout?r.fanout=t.longs===String?String(e.fanout):e.fanout:r.fanout=t.longs===String?a.Long.prototype.toString.call(e.fanout):t.longs===Number?new a.LongBits(e.fanout.low>>>0,e.fanout.high>>>0).toNumber(!0):e.fanout),null!=e.mode&&e.hasOwnProperty("mode")&&(r.mode=e.mode),null!=e.mtime&&e.hasOwnProperty("mtime")&&(r.mtime=c.UnixTime.toObject(e.mtime,t)),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,n.default.util.toJSONOptions)},e.DataType=function(){const e={},t=Object.create(e);return t[e[0]="Raw"]=0,t[e[1]="Directory"]=1,t[e[2]="File"]=2,t[e[3]="Metadata"]=3,t[e[4]="Symlink"]=4,t[e[5]="HAMTShard"]=5,t}(),e})(),l=c.UnixTime=(()=>{function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.Seconds=e.int64();break;case 2:i.FractionalNanoseconds=e.fixed32();break;default:e.skipType(7&n)}}if(!i.hasOwnProperty("Seconds"))throw a.ProtocolError("missing required 'Seconds'",{instance:i});return i},e.fromObject=function(e){if(e instanceof c.UnixTime)return e;var t=new c.UnixTime;return null!=e.Seconds&&(a.Long?(t.Seconds=a.Long.fromValue(e.Seconds)).unsigned=!1:"string"==typeof e.Seconds?t.Seconds=parseInt(e.Seconds,10):"number"==typeof e.Seconds?t.Seconds=e.Seconds:"object"==typeof e.Seconds&&(t.Seconds=new a.LongBits(e.Seconds.low>>>0,e.Seconds.high>>>0).toNumber())),null!=e.FractionalNanoseconds&&(t.FractionalNanoseconds=e.FractionalNanoseconds>>>0),t},e.toObject=function(e,t){t||(t={});var r={};if(t.defaults){if(a.Long){var i=new a.Long(0,0,!1);r.Seconds=t.longs===String?i.toString():t.longs===Number?i.toNumber():i}else r.Seconds=t.longs===String?"0":0;r.FractionalNanoseconds=0}return null!=e.Seconds&&e.hasOwnProperty("Seconds")&&("number"==typeof e.Seconds?r.Seconds=t.longs===String?String(e.Seconds):e.Seconds:r.Seconds=t.longs===String?a.Long.prototype.toString.call(e.Seconds):t.longs===Number?new a.LongBits(e.Seconds.low>>>0,e.Seconds.high>>>0).toNumber():e.Seconds),null!=e.FractionalNanoseconds&&e.hasOwnProperty("FractionalNanoseconds")&&(r.FractionalNanoseconds=e.FractionalNanoseconds),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,n.default.util.toJSONOptions)},e})(),d=c.Metadata=(()=>{function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3==1)i.MimeType=e.string();else e.skipType(7&n)}return i},e.fromObject=function(e){if(e instanceof c.Metadata)return e;var t=new c.Metadata;return null!=e.MimeType&&(t.MimeType=String(e.MimeType)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(r.MimeType=""),null!=e.MimeType&&e.hasOwnProperty("MimeType")&&(r.MimeType=e.MimeType),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,n.default.util.toJSONOptions)},e})();r.Data=u,r.Metadata=d,r.UnixTime=l,r.default=c},{"protobufjs/minimal.js":"grAXL"}],grAXL:[function(e,t,r){"use strict";t.exports=e("./src/index-minimal")},{"./src/index-minimal":"3OMTL"}],"3OMTL":[function(e,t,r){"use strict";var i=r;function n(){i.util._configure(),i.Writer._configure(i.BufferWriter),i.Reader._configure(i.BufferReader)}i.build="minimal",i.Writer=e("./writer"),i.BufferWriter=e("./writer_buffer"),i.Reader=e("./reader"),i.BufferReader=e("./reader_buffer"),i.util=e("./util/minimal"),i.rpc=e("./rpc"),i.roots=e("./roots"),i.configure=n,n()},{"./writer":"eDEax","./writer_buffer":"a3zLo","./reader":"hwSZz","./reader_buffer":"51B7L","./util/minimal":"kCaEH","./rpc":"flYC1","./roots":"aq70a"}],eDEax:[function(e,t,r){"use strict";t.exports=d;var i,n=e("./util/minimal"),s=n.LongBits,o=n.base64,a=n.utf8;function c(e,t,r){this.fn=e,this.len=t,this.next=void 0,this.val=r}function u(){}function l(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}function d(){this.len=0,this.head=new c(u,0,0),this.tail=this.head,this.states=null}var f=function(){return n.Buffer?function(){return(d.create=function(){return new i})()}:function(){return new d}};function h(e,t,r){t[r]=255&e}function p(e,t){this.len=e,this.next=void 0,this.val=t}function g(e,t,r){for(;e.hi;)t[r++]=127&e.lo|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[r++]=127&e.lo|128,e.lo=e.lo>>>7;t[r++]=e.lo}function y(e,t,r){t[r]=255&e,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}d.create=f(),d.alloc=function(e){return new n.Array(e)},n.Array!==Array&&(d.alloc=n.pool(d.alloc,n.Array.prototype.subarray)),d.prototype._push=function(e,t,r){return this.tail=this.tail.next=new c(e,t,r),this.len+=t,this},p.prototype=Object.create(c.prototype),p.prototype.fn=function(e,t,r){for(;e>127;)t[r++]=127&e|128,e>>>=7;t[r]=e},d.prototype.uint32=function(e){return this.len+=(this.tail=this.tail.next=new p((e>>>=0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this},d.prototype.int32=function(e){return e<0?this._push(g,10,s.fromNumber(e)):this.uint32(e)},d.prototype.sint32=function(e){return this.uint32((e<<1^e>>31)>>>0)},d.prototype.uint64=function(e){var t=s.from(e);return this._push(g,t.length(),t)},d.prototype.int64=d.prototype.uint64,d.prototype.sint64=function(e){var t=s.from(e).zzEncode();return this._push(g,t.length(),t)},d.prototype.bool=function(e){return this._push(h,1,e?1:0)},d.prototype.fixed32=function(e){return this._push(y,4,e>>>0)},d.prototype.sfixed32=d.prototype.fixed32,d.prototype.fixed64=function(e){var t=s.from(e);return this._push(y,4,t.lo)._push(y,4,t.hi)},d.prototype.sfixed64=d.prototype.fixed64,d.prototype.float=function(e){return this._push(n.float.writeFloatLE,4,e)},d.prototype.double=function(e){return this._push(n.float.writeDoubleLE,8,e)};var m=n.Array.prototype.set?function(e,t,r){t.set(e,r)}:function(e,t,r){for(var i=0;i>>0;if(!t)return this._push(h,1,0);if(n.isString(e)){var r=d.alloc(t=o.length(e));o.decode(e,r,0),e=r}return this.uint32(t)._push(m,t,e)},d.prototype.string=function(e){var t=a.length(e);return t?this.uint32(t)._push(a.write,t,e):this._push(h,1,0)},d.prototype.fork=function(){return this.states=new l(this),this.head=this.tail=new c(u,0,0),this.len=0,this},d.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new c(u,0,0),this.len=0),this},d.prototype.ldelim=function(){var e=this.head,t=this.tail,r=this.len;return this.reset().uint32(r),r&&(this.tail.next=e.next,this.tail=t,this.len+=r),this},d.prototype.finish=function(){for(var e=this.head.next,t=this.constructor.alloc(this.len),r=0;e;)e.fn(e.val,t,r),r+=e.len,e=e.next;return t},d._configure=function(e){i=e,d.create=f(),i._configure()}},{"./util/minimal":"kCaEH"}],kCaEH:[function(e,t,r){var i=arguments[3],n=r;function s(e,t,r){for(var i=Object.keys(t),n=0;n0)},n.Buffer=function(){try{var e=n.inquire("buffer").Buffer;return e.prototype.utf8Write?e:null}catch(e){return null}}(),n._Buffer_from=null,n._Buffer_allocUnsafe=null,n.newBuffer=function(e){return"number"==typeof e?n.Buffer?n._Buffer_allocUnsafe(e):new n.Array(e):n.Buffer?n._Buffer_from(e):"undefined"==typeof Uint8Array?e:new Uint8Array(e)},n.Array="undefined"!=typeof Uint8Array?Uint8Array:Array,n.Long=n.global.dcodeIO&&n.global.dcodeIO.Long||n.global.Long||n.inquire("long"),n.key2Re=/^true|false|0|1$/,n.key32Re=/^-?(?:0|[1-9][0-9]*)$/,n.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,n.longToHash=function(e){return e?n.LongBits.from(e).toHash():n.LongBits.zeroHash},n.longFromHash=function(e,t){var r=n.LongBits.fromHash(e);return n.Long?n.Long.fromBits(r.lo,r.hi,t):r.toNumber(Boolean(t))},n.merge=s,n.lcFirst=function(e){return e.charAt(0).toLowerCase()+e.substring(1)},n.newError=o,n.ProtocolError=o("ProtocolError"),n.oneOfGetter=function(e){for(var t={},r=0;r-1;--r)if(1===t[e[r]]&&void 0!==this[e[r]]&&null!==this[e[r]])return e[r]}},n.oneOfSetter=function(e){return function(t){for(var r=0;r1&&"="===e.charAt(t);)++r;return Math.ceil(3*e.length)/4-r};for(var n=new Array(64),s=new Array(123),o=0;o<64;)s[n[o]=o<26?o+65:o<52?o+71:o<62?o-4:o-59|43]=o++;i.encode=function(e,t,r){for(var i,s=null,o=[],a=0,c=0;t>2],i=(3&u)<<4,c=1;break;case 1:o[a++]=n[i|u>>4],i=(15&u)<<2,c=2;break;case 2:o[a++]=n[i|u>>6],o[a++]=n[63&u],c=0}a>8191&&((s||(s=[])).push(String.fromCharCode.apply(String,o)),a=0)}return c&&(o[a++]=n[i],o[a++]=61,1===c&&(o[a++]=61)),s?(a&&s.push(String.fromCharCode.apply(String,o.slice(0,a))),s.join("")):String.fromCharCode.apply(String,o.slice(0,a))};var a="invalid encoding";i.decode=function(e,t,r){for(var i,n=r,o=0,c=0;c1)break;if(void 0===(u=s[u]))throw Error(a);switch(o){case 0:i=u,o=1;break;case 1:t[r++]=i<<2|(48&u)>>4,i=u,o=2;break;case 2:t[r++]=(15&i)<<4|(60&u)>>2,i=u,o=3;break;case 3:t[r++]=(3&i)<<6|u,o=0}}if(1===o)throw Error(a);return r-n},i.test=function(e){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(e)}},{}],"8QYdM":[function(e,t,r){"use strict";function i(){this._listeners={}}t.exports=i,i.prototype.on=function(e,t,r){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:t,ctx:r||this}),this},i.prototype.off=function(e,t){if(void 0===e)this._listeners={};else if(void 0===t)this._listeners[e]=[];else for(var r=this._listeners[e],i=0;i0?0:2147483648,r,i);else if(isNaN(t))e(2143289344,r,i);else if(t>34028234663852886e22)e((n<<31|2139095040)>>>0,r,i);else if(t<11754943508222875e-54)e((n<<31|Math.round(t/1401298464324817e-60))>>>0,r,i);else{var s=Math.floor(Math.log(t)/Math.LN2);e((n<<31|s+127<<23|8388607&Math.round(t*Math.pow(2,-s)*8388608))>>>0,r,i)}}function r(e,t,r){var i=e(t,r),n=2*(i>>31)+1,s=i>>>23&255,o=8388607&i;return 255===s?o?NaN:n*(1/0):0===s?1401298464324817e-60*n*o:n*Math.pow(2,s-150)*(o+8388608)}e.writeFloatLE=t.bind(null,n),e.writeFloatBE=t.bind(null,s),e.readFloatLE=r.bind(null,o),e.readFloatBE=r.bind(null,a)}(),"undefined"!=typeof Float64Array?function(){var t=new Float64Array([-0]),r=new Uint8Array(t.buffer),i=128===r[7];function n(e,i,n){t[0]=e,i[n]=r[0],i[n+1]=r[1],i[n+2]=r[2],i[n+3]=r[3],i[n+4]=r[4],i[n+5]=r[5],i[n+6]=r[6],i[n+7]=r[7]}function s(e,i,n){t[0]=e,i[n]=r[7],i[n+1]=r[6],i[n+2]=r[5],i[n+3]=r[4],i[n+4]=r[3],i[n+5]=r[2],i[n+6]=r[1],i[n+7]=r[0]}function o(e,i){return r[0]=e[i],r[1]=e[i+1],r[2]=e[i+2],r[3]=e[i+3],r[4]=e[i+4],r[5]=e[i+5],r[6]=e[i+6],r[7]=e[i+7],t[0]}function a(e,i){return r[7]=e[i],r[6]=e[i+1],r[5]=e[i+2],r[4]=e[i+3],r[3]=e[i+4],r[2]=e[i+5],r[1]=e[i+6],r[0]=e[i+7],t[0]}e.writeDoubleLE=i?n:s,e.writeDoubleBE=i?s:n,e.readDoubleLE=i?o:a,e.readDoubleBE=i?a:o}():function(){function t(e,t,r,i,n,s){var o=i<0?1:0;if(o&&(i=-i),0===i)e(0,n,s+t),e(1/i>0?0:2147483648,n,s+r);else if(isNaN(i))e(0,n,s+t),e(2146959360,n,s+r);else if(i>17976931348623157e292)e(0,n,s+t),e((o<<31|2146435072)>>>0,n,s+r);else{var a;if(i<22250738585072014e-324)e((a=i/5e-324)>>>0,n,s+t),e((o<<31|a/4294967296)>>>0,n,s+r);else{var c=Math.floor(Math.log(i)/Math.LN2);1024===c&&(c=1023),e(4503599627370496*(a=i*Math.pow(2,-c))>>>0,n,s+t),e((o<<31|c+1023<<20|1048576*a&1048575)>>>0,n,s+r)}}}function r(e,t,r,i,n){var s=e(i,n+t),o=e(i,n+r),a=2*(o>>31)+1,c=o>>>20&2047,u=4294967296*(1048575&o)+s;return 2047===c?u?NaN:a*(1/0):0===c?5e-324*a*u:a*Math.pow(2,c-1075)*(u+4503599627370496)}e.writeDoubleLE=t.bind(null,n,0,4),e.writeDoubleBE=t.bind(null,s,4,0),e.readDoubleLE=r.bind(null,o,0,4),e.readDoubleBE=r.bind(null,a,4,0)}(),e}function n(e,t,r){t[r]=255&e,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}function s(e,t,r){t[r]=e>>>24,t[r+1]=e>>>16&255,t[r+2]=e>>>8&255,t[r+3]=255&e}function o(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0}function a(e,t){return(e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3])>>>0}t.exports=i(i)},{}],"3GHL4":[function(require,module,exports){"use strict";function inquire(moduleName){try{var mod=eval("quire".replace(/^/,"re"))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(e){}return null}module.exports=inquire},{}],ergn2:[function(e,t,r){"use strict";var i=r;i.length=function(e){for(var t=0,r=0,i=0;i191&&i<224?s[o++]=(31&i)<<6|63&e[t++]:i>239&&i<365?(i=((7&i)<<18|(63&e[t++])<<12|(63&e[t++])<<6|63&e[t++])-65536,s[o++]=55296+(i>>10),s[o++]=56320+(1023&i)):s[o++]=(15&i)<<12|(63&e[t++])<<6|63&e[t++],o>8191&&((n||(n=[])).push(String.fromCharCode.apply(String,s)),o=0);return n?(o&&n.push(String.fromCharCode.apply(String,s.slice(0,o))),n.join("")):String.fromCharCode.apply(String,s.slice(0,o))},i.write=function(e,t,r){for(var i,n,s=r,o=0;o>6|192,t[r++]=63&i|128):55296==(64512&i)&&56320==(64512&(n=e.charCodeAt(o+1)))?(i=65536+((1023&i)<<10)+(1023&n),++o,t[r++]=i>>18|240,t[r++]=i>>12&63|128,t[r++]=i>>6&63|128,t[r++]=63&i|128):(t[r++]=i>>12|224,t[r++]=i>>6&63|128,t[r++]=63&i|128);return r-s}},{}],lRkSe:[function(e,t,r){"use strict";t.exports=function(e,t,r){var i=r||8192,n=i>>>1,s=null,o=i;return function(r){if(r<1||r>n)return e(r);o+r>i&&(s=e(i),o=0);var a=t.call(s,o,o+=r);return 7&o&&(o=1+(7|o)),a}}},{}],kTtk9:[function(e,t,r){"use strict";t.exports=n;var i=e("../util/minimal");function n(e,t){this.lo=e>>>0,this.hi=t>>>0}var s=n.zero=new n(0,0);s.toNumber=function(){return 0},s.zzEncode=s.zzDecode=function(){return this},s.length=function(){return 1};var o=n.zeroHash="\0\0\0\0\0\0\0\0";n.fromNumber=function(e){if(0===e)return s;var t=e<0;t&&(e=-e);var r=e>>>0,i=(e-r)/4294967296>>>0;return t&&(i=~i>>>0,r=~r>>>0,++r>4294967295&&(r=0,++i>4294967295&&(i=0))),new n(r,i)},n.from=function(e){if("number"==typeof e)return n.fromNumber(e);if(i.isString(e)){if(!i.Long)return n.fromNumber(parseInt(e,10));e=i.Long.fromString(e)}return e.low||e.high?new n(e.low>>>0,e.high>>>0):s},n.prototype.toNumber=function(e){if(!e&&this.hi>>>31){var t=1+~this.lo>>>0,r=~this.hi>>>0;return t||(r=r+1>>>0),-(t+4294967296*r)}return this.lo+4294967296*this.hi},n.prototype.toLong=function(e){return i.Long?new i.Long(0|this.lo,0|this.hi,Boolean(e)):{low:0|this.lo,high:0|this.hi,unsigned:Boolean(e)}};var a=String.prototype.charCodeAt;n.fromHash=function(e){return e===o?s:new n((a.call(e,0)|a.call(e,1)<<8|a.call(e,2)<<16|a.call(e,3)<<24)>>>0,(a.call(e,4)|a.call(e,5)<<8|a.call(e,6)<<16|a.call(e,7)<<24)>>>0)},n.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},n.prototype.zzEncode=function(){var e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this},n.prototype.zzDecode=function(){var e=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this},n.prototype.length=function(){var e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,r=this.hi>>>24;return 0===r?0===t?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:r<128?9:10}},{"../util/minimal":"kCaEH"}],a3zLo:[function(e,t,r){"use strict";t.exports=s;var i=e("./writer");(s.prototype=Object.create(i.prototype)).constructor=s;var n=e("./util/minimal");function s(){i.call(this)}function o(e,t,r){e.length<40?n.utf8.write(e,t,r):t.utf8Write?t.utf8Write(e,r):t.write(e,r)}s._configure=function(){s.alloc=n._Buffer_allocUnsafe,s.writeBytesBuffer=n.Buffer&&n.Buffer.prototype instanceof Uint8Array&&"set"===n.Buffer.prototype.set.name?function(e,t,r){t.set(e,r)}:function(e,t,r){if(e.copy)e.copy(t,r,0,e.length);else for(var i=0;i>>0;return this.uint32(t),t&&this._push(s.writeBytesBuffer,t,e),this},s.prototype.string=function(e){var t=n.Buffer.byteLength(e);return this.uint32(t),t&&this._push(o,t,e),this},s._configure()},{"./writer":"eDEax","./util/minimal":"kCaEH"}],hwSZz:[function(e,t,r){"use strict";t.exports=c;var i,n=e("./util/minimal"),s=n.LongBits,o=n.utf8;function a(e,t){return RangeError("index out of range: "+e.pos+" + "+(t||1)+" > "+e.len)}function c(e){this.buf=e,this.pos=0,this.len=e.length}var u,l="undefined"!=typeof Uint8Array?function(e){if(e instanceof Uint8Array||Array.isArray(e))return new c(e);throw Error("illegal buffer")}:function(e){if(Array.isArray(e))return new c(e);throw Error("illegal buffer")},d=function(){return n.Buffer?function(e){return(c.create=function(e){return n.Buffer.isBuffer(e)?new i(e):l(e)})(e)}:l};function f(){var e=new s(0,0),t=0;if(!(this.len-this.pos>4)){for(;t<3;++t){if(this.pos>=this.len)throw a(this);if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(127&this.buf[this.pos++])<<7*t)>>>0,e}for(;t<4;++t)if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(127&this.buf[this.pos])<<28)>>>0,e.hi=(e.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return e;if(t=0,this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw a(this);if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}function h(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}function p(){if(this.pos+8>this.len)throw a(this,8);return new s(h(this.buf,this.pos+=4),h(this.buf,this.pos+=4))}c.create=d(),c.prototype._slice=n.Array.prototype.subarray||n.Array.prototype.slice,c.prototype.uint32=(u=4294967295,function(){if(u=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return u;if(u=(u|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return u;if(u=(u|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return u;if(u=(u|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return u;if(u=(u|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return u;if((this.pos+=5)>this.len)throw this.pos=this.len,a(this,10);return u}),c.prototype.int32=function(){return 0|this.uint32()},c.prototype.sint32=function(){var e=this.uint32();return e>>>1^-(1&e)|0},c.prototype.bool=function(){return 0!==this.uint32()},c.prototype.fixed32=function(){if(this.pos+4>this.len)throw a(this,4);return h(this.buf,this.pos+=4)},c.prototype.sfixed32=function(){if(this.pos+4>this.len)throw a(this,4);return 0|h(this.buf,this.pos+=4)},c.prototype.float=function(){if(this.pos+4>this.len)throw a(this,4);var e=n.float.readFloatLE(this.buf,this.pos);return this.pos+=4,e},c.prototype.double=function(){if(this.pos+8>this.len)throw a(this,4);var e=n.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,e},c.prototype.bytes=function(){var e=this.uint32(),t=this.pos,r=this.pos+e;if(r>this.len)throw a(this,e);return this.pos+=e,Array.isArray(this.buf)?this.buf.slice(t,r):t===r?new this.buf.constructor(0):this._slice.call(this.buf,t,r)},c.prototype.string=function(){var e=this.bytes();return o.read(e,0,e.length)},c.prototype.skip=function(e){if("number"==typeof e){if(this.pos+e>this.len)throw a(this,e);this.pos+=e}else do{if(this.pos>=this.len)throw a(this)}while(128&this.buf[this.pos++]);return this},c.prototype.skipType=function(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;4!=(e=7&this.uint32());)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+e+" at offset "+this.pos)}return this},c._configure=function(e){i=e,c.create=d(),i._configure();var t=n.Long?"toLong":"toNumber";n.merge(c.prototype,{int64:function(){return f.call(this)[t](!1)},uint64:function(){return f.call(this)[t](!0)},sint64:function(){return f.call(this).zzDecode()[t](!1)},fixed64:function(){return p.call(this)[t](!0)},sfixed64:function(){return p.call(this)[t](!1)}})}},{"./util/minimal":"kCaEH"}],"51B7L":[function(e,t,r){"use strict";t.exports=s;var i=e("./reader");(s.prototype=Object.create(i.prototype)).constructor=s;var n=e("./util/minimal");function s(e){i.call(this,e)}s._configure=function(){n.Buffer&&(s.prototype._slice=n.Buffer.prototype.slice)},s.prototype.string=function(){var e=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+e,this.len)):this.buf.toString("utf-8",this.pos,this.pos=Math.min(this.pos+e,this.len))},s._configure()},{"./reader":"hwSZz","./util/minimal":"kCaEH"}],flYC1:[function(e,t,r){"use strict";r.Service=e("./rpc/service")},{"./rpc/service":"cl9qf"}],cl9qf:[function(e,t,r){"use strict";t.exports=n;var i=e("../util/minimal");function n(e,t,r){if("function"!=typeof e)throw TypeError("rpcImpl must be a function");i.EventEmitter.call(this),this.rpcImpl=e,this.requestDelimited=Boolean(t),this.responseDelimited=Boolean(r)}(n.prototype=Object.create(i.EventEmitter.prototype)).constructor=n,n.prototype.rpcCall=function e(t,r,n,s,o){if(!s)throw TypeError("request must be specified");var a=this;if(!o)return i.asPromise(e,a,t,r,n,s);if(a.rpcImpl)try{return a.rpcImpl(t,r[a.requestDelimited?"encodeDelimited":"encode"](s).finish(),(function(e,r){if(e)return a.emit("error",e,t),o(e);if(null!==r){if(!(r instanceof n))try{r=n[a.responseDelimited?"decodeDelimited":"decode"](r)}catch(e){return a.emit("error",e,t),o(e)}return a.emit("data",r,t),o(null,r)}a.end(!0)}))}catch(e){return a.emit("error",e,t),void setTimeout((function(){o(e)}),0)}else setTimeout((function(){o(Error("already ended"))}),0)},n.prototype.end=function(e){return this.rpcImpl&&(e||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this}},{"../util/minimal":"kCaEH"}],aq70a:[function(e,t,r){"use strict";t.exports={}},{}],i2cdx:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("./pb-decode.js"),s=e("./pb-encode.js"),o=e("./util.js");r.createLink=o.createLink,r.createNode=o.createNode,r.prepare=o.prepare,r.validate=o.validate,r.code=112,r.decode=function(e){const t=n.decodeNode(e),r={};return t.Data&&(r.Data=t.Data),t.Links&&(r.Links=t.Links.map((e=>{const t={};try{t.Hash=i.CID.decode(e.Hash)}catch(e){}if(!t.Hash)throw new Error("Invalid Hash field found in link, expected CID");return void 0!==e.Name&&(t.Name=e.Name),void 0!==e.Tsize&&(t.Tsize=e.Tsize),t}))),r},r.encode=function(e){o.validate(e);const t={};return e.Links&&(t.Links=e.Links.map((e=>{const t={};return e.Hash&&(t.Hash=e.Hash.bytes),void 0!==e.Name&&(t.Name=e.Name),void 0!==e.Tsize&&(t.Tsize=e.Tsize),t}))),e.Data&&(t.Data=e.Data),s.encodeNode(t)},r.name="dag-pb"},{"multiformats/cid":"9ooAY","./pb-decode.js":"ld3PU","./pb-encode.js":"5nPbE","./util.js":"1YHGP"}],"9ooAY":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./varint.js"),n=e("./hashes/digest.js"),s=e("./bases/base58.js"),o=e("./bases/base32.js"),a=e("./bytes.js");class c{constructor(e,t,r,i){this.code=t,this.version=e,this.multihash=r,this.bytes=i,this.byteOffset=i.byteOffset,this.byteLength=i.byteLength,this.asCID=this,this._baseCache=new Map,Object.defineProperties(this,{byteOffset:m,byteLength:m,code:y,version:y,multihash:y,bytes:y,_baseCache:m,asCID:m})}toV0(){if(0===this.version)return this;{const{code:e,multihash:t}=this;if(e!==f)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==h)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return c.createV0(t)}}toV1(){switch(this.version){case 0:{const{code:e,digest:t}=this.multihash,r=n.create(e,t);return c.createV1(this.code,r)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}equals(e){return e&&this.code===e.code&&this.version===e.version&&n.equals(this.multihash,e.multihash)}toString(e){const{bytes:t,version:r,_baseCache:i}=this;return 0===r?l(t,i,e||s.base58btc.encoder):d(t,i,e||o.base32.encoder)}toJSON(){return{code:this.code,version:this.version,hash:this.multihash.bytes}}get[Symbol.toStringTag](){return"CID"}[Symbol.for("nodejs.util.inspect.custom")](){return"CID("+this.toString()+")"}static isCID(e){return b(/^0\.0/,v),!(!e||!e[g]&&e.asCID!==e)}get toBaseEncodedString(){throw new Error("Deprecated, use .toString()")}get codec(){throw new Error('"codec" property is deprecated, use integer "code" property instead')}get buffer(){throw new Error("Deprecated .buffer property, use .bytes to get Uint8Array instead")}get multibaseName(){throw new Error('"multibaseName" property is deprecated')}get prefix(){throw new Error('"prefix" property is deprecated')}static asCID(e){if(e instanceof c)return e;if(null!=e&&e.asCID===e){const{version:t,code:r,multihash:i,bytes:n}=e;return new c(t,r,i,n||p(t,r,i.bytes))}if(null!=e&&!0===e[g]){const{version:t,multihash:r,code:i}=e,s=n.decode(r);return c.create(t,i,s)}return null}static create(e,t,r){if("number"!=typeof t)throw new Error("String codecs are no longer supported");switch(e){case 0:if(t!==f)throw new Error(`Version 0 CID must use dag-pb (code: ${f}) block encoding`);return new c(e,t,r,r.bytes);case 1:{const i=p(e,t,r.bytes);return new c(e,t,r,i)}default:throw new Error("Invalid version")}}static createV0(e){return c.create(0,f,e)}static createV1(e,t){return c.create(1,e,t)}static decode(e){const[t,r]=c.decodeFirst(e);if(r.length)throw new Error("Incorrect length");return t}static decodeFirst(e){const t=c.inspectBytes(e),r=t.size-t.multihashSize,i=a.coerce(e.subarray(r,r+t.multihashSize));if(i.byteLength!==t.multihashSize)throw new Error("Incorrect length");const s=i.subarray(t.multihashSize-t.digestSize),o=new n.Digest(t.multihashCode,t.digestSize,s,i);return[0===t.version?c.createV0(o):c.createV1(t.codec,o),e.subarray(t.size)]}static inspectBytes(e){let t=0;const r=()=>{const[r,n]=i.decode(e.subarray(t));return t+=n,r};let n=r(),s=f;if(18===n?(n=0,t=0):1===n&&(s=r()),0!==n&&1!==n)throw new RangeError(`Invalid CID version ${n}`);const o=t,a=r(),c=r(),u=t+c;return{version:n,codec:s,multihashCode:a,digestSize:c,multihashSize:u-o,size:u}}static parse(e,t){const[r,i]=u(e,t),n=c.decode(i);return n._baseCache.set(r,e),n}}const u=(e,t)=>{switch(e[0]){case"Q":{const r=t||s.base58btc;return[s.base58btc.prefix,r.decode(`${s.base58btc.prefix}${e}`)]}case s.base58btc.prefix:{const r=t||s.base58btc;return[s.base58btc.prefix,r.decode(e)]}case o.base32.prefix:{const r=t||o.base32;return[o.base32.prefix,r.decode(e)]}default:if(null==t)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[e[0],t.decode(e)]}},l=(e,t,r)=>{const{prefix:i}=r;if(i!==s.base58btc.prefix)throw Error(`Cannot string encode V0 in ${r.name} encoding`);const n=t.get(i);if(null==n){const n=r.encode(e).slice(1);return t.set(i,n),n}return n},d=(e,t,r)=>{const{prefix:i}=r,n=t.get(i);if(null==n){const n=r.encode(e);return t.set(i,n),n}return n},f=112,h=18,p=(e,t,r)=>{const n=i.encodingLength(e),s=n+i.encodingLength(t),o=new Uint8Array(s+r.byteLength);return i.encodeTo(e,o,0),i.encodeTo(t,o,n),o.set(r,s),o},g=Symbol.for("@ipld/js-cid/CID"),y={writable:!1,configurable:!1,enumerable:!0},m={writable:!1,enumerable:!1,configurable:!1},b=(e,t)=>{if(!e.test("0.0.0-dev"))throw new Error(t);console.warn(t)},v="CID.isCID(v) is deprecated and will be removed in the next major release.\nFollowing code pattern:\n\nif (CID.isCID(value)) {\n doSomethingWithCID(value)\n}\n\nIs replaced with:\n\nconst cid = CID.asCID(value)\nif (cid) {\n // Make sure to use cid instead of value\n doSomethingWithCID(cid)\n}\n";r.CID=c},{"./varint.js":"ivDPm","./hashes/digest.js":"kpRBg","./bases/base58.js":"4n7mA","./bases/base32.js":"5k9Tu","./bytes.js":"6I0Ku"}],ivDPm:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../vendor/varint.js");r.decode=e=>[i.decode(e),i.decode.bytes],r.encodeTo=(e,t,r=0)=>(i.encode(e,t,r),t),r.encodingLength=e=>i.encodingLength(e)},{"../vendor/varint.js":"h72ss"}],h72ss:[function(e,t,r){"use strict";var i=function e(t,r,i){r=r||[];var s=i=i||0;for(;t>=n;)r[i++]=255&t|128,t/=128;for(;-128&t;)r[i++]=255&t|128,t>>>=7;return r[i]=0|t,e.bytes=i-s+1,r},n=Math.pow(2,31);var s=function e(t,r){var i,n=0,s=0,o=r=r||0,a=t.length;do{if(o>=a)throw e.bytes=0,new RangeError("Could not decode varint");i=t[o++],n+=s<28?(127&i)<=128);return e.bytes=o-r,n};var o=Math.pow(2,7),a=Math.pow(2,14),c=Math.pow(2,21),u=Math.pow(2,28),l=Math.pow(2,35),d=Math.pow(2,42),f=Math.pow(2,49),h=Math.pow(2,56),p=Math.pow(2,63),g={encode:i,decode:s,encodingLength:function(e){return e{const r=t.byteLength,i=n.encodingLength(e),o=i+n.encodingLength(r),a=new Uint8Array(o+r);return n.encodeTo(e,a,0),n.encodeTo(r,a,i),a.set(t,o),new s(e,r,t,a)},r.decode=e=>{const t=i.coerce(e),[r,o]=n.decode(t),[a,c]=n.decode(t.subarray(o)),u=t.subarray(o+c);if(u.byteLength!==a)throw new Error("Incorrect length");return new s(r,a,u,t)},r.equals=(e,t)=>e===t||e.code===t.code&&e.size===t.size&&i.equals(e.bytes,t.bytes)},{"../bytes.js":"6I0Ku","../varint.js":"ivDPm"}],"6I0Ku":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=new Uint8Array(0);r.coerce=e=>{if(e instanceof Uint8Array&&"Uint8Array"===e.constructor.name)return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw new Error("Unknown type, must be binary type")},r.empty=i,r.equals=(e,t)=>{if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r{const t=e.match(/../g);return t?new Uint8Array(t.map((e=>parseInt(e,16)))):i},r.fromString=e=>(new TextEncoder).encode(e),r.isBinary=e=>e instanceof ArrayBuffer||ArrayBuffer.isView(e),r.toHex=e=>e.reduce(((e,t)=>e+t.toString(16).padStart(2,"0")),""),r.toString=e=>(new TextDecoder).decode(e)},{}],"4n7mA":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js");const n=i.baseX({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),s=i.baseX({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});r.base58btc=n,r.base58flickr=s},{"./base.js":"6uTk1"}],"6uTk1":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../vendor/base-x.js"),n=e("../bytes.js");class s{constructor(e,t,r){this.name=e,this.prefix=t,this.baseEncode=r}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}}class o{constructor(e,t,r){this.name=e,this.prefix=t,this.baseDecode=r}decode(e){if("string"==typeof e){if(e[0]===this.prefix)return this.baseDecode(e.slice(1));throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`)}throw Error("Can only multibase decode strings")}or(e){return c(this,e)}}class a{constructor(e){this.decoders=e}or(e){return c(this,e)}decode(e){const t=e[0],r=this.decoders[t];if(r)return r.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}}const c=(e,t)=>new a({...e.decoders||{[e.prefix]:e},...t.decoders||{[t.prefix]:t}});class u{constructor(e,t,r,i){this.name=e,this.prefix=t,this.baseEncode=r,this.baseDecode=i,this.encoder=new s(e,t,r),this.decoder=new o(e,t,i)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}}const l=({name:e,prefix:t,encode:r,decode:i})=>new u(e,t,r,i);r.Codec=u,r.baseX=({prefix:e,name:t,alphabet:r})=>{const{encode:s,decode:o}=i(r,t);return l({prefix:e,name:t,encode:s,decode:e=>n.coerce(o(e))})},r.from=l,r.or=c,r.rfc4648=({name:e,prefix:t,bitsPerChar:r,alphabet:i})=>l({prefix:t,name:e,encode:e=>((e,t,r)=>{const i="="===t[t.length-1],n=(1<r;)o-=r,s+=t[n&a>>o];if(o&&(s+=t[n&a<((e,t,r,i)=>{const n={};for(let e=0;e=8&&(a-=8,o[u++]=255&c>>a)}if(a>=r||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o})(t,i,r,e)})},{"../../vendor/base-x.js":"bImXU","../bytes.js":"6I0Ku"}],bImXU:[function(e,t,r){"use strict";var i=function(e,t){if(e.length>=255)throw new TypeError("Alphabet too long");for(var r=new Uint8Array(256),i=0;i>>0,o=new Uint8Array(s);e[t];){var l=r[e.charCodeAt(t)];if(255===l)return;for(var d=0,f=s-1;(0!==l||d>>0,o[f]=l%256>>>0,l=l/256>>>0;if(0!==l)throw new Error("Non-zero carry");n=d,t++}if(" "!==e[t]){for(var h=s-n;h!==s&&0===o[h];)h++;for(var p=new Uint8Array(i+(s-h)),g=i;h!==s;)p[g++]=o[h++];return p}}}return{encode:function(t){if(t instanceof Uint8Array||(ArrayBuffer.isView(t)?t=new Uint8Array(t.buffer,t.byteOffset,t.byteLength):Array.isArray(t)&&(t=Uint8Array.from(t))),!(t instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(0===t.length)return"";for(var r=0,i=0,n=0,s=t.length;n!==s&&0===t[n];)n++,r++;for(var o=(s-n)*l+1>>>0,u=new Uint8Array(o);n!==s;){for(var d=t[n],f=0,h=o-1;(0!==d||f>>0,u[h]=d%a>>>0,d=d/a>>>0;if(0!==d)throw new Error("Non-zero carry");i=f,n++}for(var p=o-i;p!==o&&0===u[p];)p++;for(var g=c.repeat(r);p=64)throw new Error("protobuf: varint overflow");if(t>=e.length)throw new Error("protobuf: unexpected end of data");const n=e[t++];if(r+=i<28?(127&n)<e.length)throw new Error("protobuf: unexpected end of data");return[e.subarray(t,i),i]}function o(e,t){let r;return[r,t]=n(e,t),[7&r,r>>3,t]}function a(e){const t={},r=e.length;let a=0;for(;ar)throw new Error("protobuf: (PBLink) unexpected end of data");return t}r.decodeNode=function(e){const t=e.length;let r,i,n=0,c=!1;for(;nt)throw new Error("protobuf: (PBNode) unexpected end of data");const u={};return i&&(u.Data=i),u.Links=r||[],u}},{}],"5nPbE":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=new TextEncoder,n=2**32;function s(e,t){let r=t.length;if("number"==typeof e.Tsize){if(e.Tsize<0)throw new Error("Tsize cannot be negative");if(!Number.isSafeInteger(e.Tsize))throw new Error("Tsize too large for encoding");r=a(t,r,e.Tsize)-1,t[r]=24}if("string"==typeof e.Name){const n=i.encode(e.Name);r-=n.length,t.set(n,r),r=a(t,r,n.length)-1,t[r]=18}return e.Hash&&(r-=e.Hash.length,t.set(e.Hash,r),r=a(t,r,e.Hash.length)-1,t[r]=10),t.length-r}function o(e){let t=0;if(e.Hash){const r=e.Hash.length;t+=1+r+c(r)}if("string"==typeof e.Name){const r=i.encode(e.Name).length;t+=1+r+c(r)}return"number"==typeof e.Tsize&&(t+=1+c(e.Tsize)),t}function a(e,t,r){const i=t-=c(r);for(;r>=2147483648;)e[t++]=127&r|128,r/=128;for(;r>=128;)e[t++]=127&r|128,r>>>=7;return e[t]=r,i}function c(e){return e%2==0&&e++,Math.floor((function(e){let t=0;e>=n&&(e=Math.floor(e/n),t=32);e>=65536&&(e>>>=16,t+=16);e>=256&&(e>>>=8,t+=8);return t+u[e]}(e)+6)/7)}const u=[0,1,2,2,3,3,3,3,4,4,4,4,4,4,4,4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8];r.encodeNode=function(e){const t=function(e){let t=0;if(e.Data){const r=e.Data.length;t+=1+r+c(r)}if(e.Links)for(const r of e.Links){const e=o(r);t+=1+e+c(e)}return t}(e),r=new Uint8Array(t);let i=t;if(e.Data&&(i-=e.Data.length,r.set(e.Data,i),i=a(r,i,e.Data.length)-1,r[i]=10),e.Links)for(let t=e.Links.length-1;t>=0;t--){const n=s(e.Links[t],r.subarray(0,i));i-=n,i=a(r,i,n)-1,r[i]=18}return r}},{}],"1YHGP":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid");const n=["Data","Links"],s=["Hash","Name","Tsize"],o=new TextEncoder;function a(e,t){if(e===t)return 0;const r=e.Name?o.encode(e.Name):[],i=t.Name?o.encode(t.Name):[];let n=r.length,s=i.length;for(let e=0,t=Math.min(n,s);e!t.includes(e)))}function u(e){if("object"==typeof e.asCID){const t=i.CID.asCID(e);if(!t)throw new TypeError("Invalid DAG-PB form");return{Hash:t}}if("object"!=typeof e||Array.isArray(e))throw new TypeError("Invalid DAG-PB form");const t={};if(e.Hash){let r=i.CID.asCID(e.Hash);try{r||("string"==typeof e.Hash?r=i.CID.parse(e.Hash):e.Hash instanceof Uint8Array&&(r=i.CID.decode(e.Hash)))}catch(e){throw new TypeError(`Invalid DAG-PB form: ${e.message}`)}r&&(t.Hash=r)}if(!t.Hash)throw new TypeError("Invalid DAG-PB form");return"string"==typeof e.Name&&(t.Name=e.Name),"number"==typeof e.Tsize&&(t.Tsize=e.Tsize),t}function l(e){if((e instanceof Uint8Array||"string"==typeof e)&&(e={Data:e}),"object"!=typeof e||Array.isArray(e))throw new TypeError("Invalid DAG-PB form");const t={};if(void 0!==e.Data)if("string"==typeof e.Data)t.Data=o.encode(e.Data);else{if(!(e.Data instanceof Uint8Array))throw new TypeError("Invalid DAG-PB form");t.Data=e.Data}if(void 0!==e.Links){if(!Array.isArray(e.Links))throw new TypeError("Invalid DAG-PB form");t.Links=e.Links.map(u),t.Links.sort(a)}else t.Links=[];return t}r.createLink=function(e,t,r){return u({Hash:r,Name:e,Tsize:t})},r.createNode=function(e,t=[]){return l({Data:e,Links:t})},r.prepare=l,r.validate=function(e){if(!e||"object"!=typeof e||Array.isArray(e))throw new TypeError("Invalid DAG-PB form");if(!c(e,n))throw new TypeError("Invalid DAG-PB form (extraneous properties)");if(void 0!==e.Data&&!(e.Data instanceof Uint8Array))throw new TypeError("Invalid DAG-PB form (Data must be a Uint8Array)");if(!Array.isArray(e.Links))throw new TypeError("Invalid DAG-PB form (Links must be an array)");for(let t=0;t0&&-1===a(r,e.Links[t-1]))throw new TypeError("Invalid DAG-PB form (links must be sorted by Name bytes)")}}},{"multiformats/cid":"9ooAY"}],"3498i":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("cborg"),n=e("multiformats/cid");function s(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var o=s(i);const a={float64:!0,typeEncoders:{Object:function(e){if(e.asCID!==e)return null;const t=n.CID.asCID(e);if(!t)return null;const r=new Uint8Array(t.bytes.byteLength+1);return r.set(t.bytes,1),[new o.Token(o.Type.tag,42),new o.Token(o.Type.bytes,r)]},undefined:function(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")},number:function(e){if(Number.isNaN(e))throw new Error("`NaN` is not supported by the IPLD Data Model and cannot be encoded");if(e===1/0||e===-1/0)throw new Error("`Infinity` and `-Infinity` is not supported by the IPLD Data Model and cannot be encoded");return null}}};const c={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,tags:[]};c.tags[42]=function(e){if(0!==e[0])throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return n.CID.decode(e.subarray(1))};r.code=113,r.decode=e=>o.decode(e,c),r.encode=e=>o.encode(e,a),r.name="dag-cbor"},{cborg:"iZrkE","multiformats/cid":"9ooAY"}],iZrkE:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/encode.js"),n=e("./lib/decode.js"),s=e("./lib/token.js");r.encode=i.encode,r.decode=n.decode,r.Token=s.Token,r.Type=s.Type},{"./lib/encode.js":"72LuQ","./lib/decode.js":"dbDwZ","./lib/token.js":"jVUGz"}],"72LuQ":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./is.js"),n=e("./token.js"),s=e("./bl.js"),o=e("./common.js"),a=e("./jump.js"),c=e("./byte-utils.js"),u=e("./0uint.js"),l=e("./1negint.js"),d=e("./2bytes.js"),f=e("./3string.js"),h=e("./4array.js"),p=e("./5map.js"),g=e("./6tag.js"),y=e("./7float.js");const m={float64:!1,mapSorter:function(e,t){const r=Array.isArray(e[0])?e[0][0]:e[0],i=Array.isArray(t[0])?t[0][0]:t[0];if(r.type!==i.type)return r.type.compare(i.type);const n=r.type.major,s=b[n].compareTokens(r,i);0===s&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone");return s},quickEncodeToken:a.quickEncodeToken},b=[];b[n.Type.uint.major]=u.encodeUint,b[n.Type.negint.major]=l.encodeNegint,b[n.Type.bytes.major]=d.encodeBytes,b[n.Type.string.major]=f.encodeString,b[n.Type.array.major]=h.encodeArray,b[n.Type.map.major]=p.encodeMap,b[n.Type.tag.major]=g.encodeTag,b[n.Type.float.major]=y.encodeFloat;const v=new s.Bl;class w{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do{if(t.obj===e)return!0}while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${o.encodeErrPrefix} object contains circular references`);return new w(t,e)}}const _={null:new n.Token(n.Type.null,null),undefined:new n.Token(n.Type.undefined,void 0),true:new n.Token(n.Type.true,!0),false:new n.Token(n.Type.false,!1),emptyArray:new n.Token(n.Type.array,0),emptyMap:new n.Token(n.Type.map,0)},E={number:(e,t,r,i)=>Number.isInteger(e)&&Number.isSafeInteger(e)?e>=0?new n.Token(n.Type.uint,e):new n.Token(n.Type.negint,e):new n.Token(n.Type.float,e),bigint:(e,t,r,i)=>e>=BigInt(0)?new n.Token(n.Type.uint,e):new n.Token(n.Type.negint,e),Uint8Array:(e,t,r,i)=>new n.Token(n.Type.bytes,e),string:(e,t,r,i)=>new n.Token(n.Type.string,e),boolean:(e,t,r,i)=>e?_.true:_.false,null:(e,t,r,i)=>_.null,undefined:(e,t,r,i)=>_.undefined,ArrayBuffer:(e,t,r,i)=>new n.Token(n.Type.bytes,new Uint8Array(e)),DataView:(e,t,r,i)=>new n.Token(n.Type.bytes,new Uint8Array(e.buffer,e.byteOffset,e.byteLength)),Array(e,t,r,i){if(!e.length)return!0===r.addBreakTokens?[_.emptyArray,new n.Token(n.Type.break)]:_.emptyArray;i=w.createCheck(i,e);const s=[];let o=0;for(const t of e)s[o++]=S(t,r,i);return r.addBreakTokens?[new n.Token(n.Type.array,e.length),s,new n.Token(n.Type.break)]:[new n.Token(n.Type.array,e.length),s]},Object(e,t,r,i){const s="Object"!==t,o=s?e.keys():Object.keys(e),a=s?e.size:o.length;if(!a)return!0===r.addBreakTokens?[_.emptyMap,new n.Token(n.Type.break)]:_.emptyMap;i=w.createCheck(i,e);const c=[];let u=0;for(const t of o)c[u++]=[S(t,r,i),S(s?e.get(t):e[t],r,i)];return function(e,t){t.mapSorter&&e.sort(t.mapSorter)}(c,r),r.addBreakTokens?[new n.Token(n.Type.map,a),c,new n.Token(n.Type.break)]:[new n.Token(n.Type.map,a),c]}};E.Map=E.Object,E.Buffer=E.Uint8Array;for(const e of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))E[`${e}Array`]=E.DataView;function S(e,t={},r){const n=i.is(e),s=t&&t.typeEncoders&&t.typeEncoders[n]||E[n];if("function"==typeof s){const i=s(e,n,t,r);if(null!=i)return i}const a=E[n];if(!a)throw new Error(`${o.encodeErrPrefix} unsupported type: ${n}`);return a(e,n,t,r)}function T(e,t,r,i){if(Array.isArray(t))for(const n of t)T(e,n,r,i);else r[t.type.major](e,t,i)}function A(e,t,r){const i=S(e,r);if(!Array.isArray(i)&&r.quickEncodeToken){const e=r.quickEncodeToken(i);if(e)return e;const n=t[i.type.major];if(n.encodedSize){const e=n.encodedSize(i,r),t=new s.Bl(e);if(n(t,i,r),1!==t.chunks.length)throw new Error(`Unexpected error: pre-calculated length for ${i} was wrong`);return c.asU8A(t.chunks[0])}}return T(v,i,t,r),v.toBytes(!0)}r.Ref=w,r.encode=function(e,t){return t=Object.assign({},m,t),A(e,b,t)},r.encodeCustom=A,r.objectToTokens=S},{"./is.js":"bPQoh","./token.js":"jVUGz","./bl.js":"25Ozo","./common.js":"aoxj4","./jump.js":"FaFBb","./byte-utils.js":"9dmLv","./0uint.js":"9zilL","./1negint.js":"2sjxL","./2bytes.js":"8Tv7U","./3string.js":"56Ua8","./4array.js":"4ePxQ","./5map.js":"28THk","./6tag.js":"5TCWp","./7float.js":"5T30n"}],bPQoh:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=["string","number","bigint","symbol"],n=["Function","Generator","AsyncGenerator","GeneratorFunction","AsyncGeneratorFunction","AsyncFunction","Observable","Array","Buffer","Object","RegExp","Date","Error","Map","Set","WeakMap","WeakSet","ArrayBuffer","SharedArrayBuffer","DataView","Promise","URL","HTMLElement","Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array"];r.is=function(e){if(null===e)return"null";if(void 0===e)return"undefined";if(!0===e||!1===e)return"boolean";const t=typeof e;if(i.includes(t))return t;if("function"===t)return"Function";if(Array.isArray(e))return"Array";if(function(e){return e&&e.constructor&&e.constructor.isBuffer&&e.constructor.isBuffer.call(null,e)}(e))return"Buffer";const r=function(e){const t=Object.prototype.toString.call(e).slice(8,-1);return n.includes(t)?t:void 0}(e);return r||"Object"}},{}],jVUGz:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});class i{constructor(e,t,r){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=r}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.majore.major?1:0}}i.uint=new i(0,"uint",!0),i.negint=new i(1,"negint",!0),i.bytes=new i(2,"bytes",!0),i.string=new i(3,"string",!0),i.array=new i(4,"array",!1),i.map=new i(5,"map",!1),i.tag=new i(6,"tag",!1),i.float=new i(7,"float",!0),i.false=new i(7,"false",!0),i.true=new i(7,"true",!0),i.null=new i(7,"null",!0),i.undefined=new i(7,"undefined",!0),i.break=new i(7,"break",!0);r.Token=class{constructor(e,t,r){this.type=e,this.value=t,this.encodedLength=r,this.encodedBytes=void 0}toString(){return`Token[${this.type}].${this.value}`}},r.Type=i},{}],"25Ozo":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./byte-utils.js");r.Bl=class{constructor(e=256){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.chunks=[],this.cursor=0,this.maxCursor=-1,null!==this._initReuseChunk&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){const r=t.length-(this.maxCursor-this.cursor)-1;t.set(e,r)}else{if(t){const e=t.length-(this.maxCursor-this.cursor)-1;er.length/2?(t=this.cursor===r.length?r:r.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=i.slice(r,0,this.cursor)}else t=i.concat(this.chunks,this.cursor);return e&&this.reset(),t}}},{"./byte-utils.js":"9dmLv"}],"9dmLv":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&"function"==typeof globalThis.Buffer.isBuffer,n=new TextDecoder,s=new TextEncoder;function o(e){return i&&globalThis.Buffer.isBuffer(e)}function a(e){return e instanceof Uint8Array?o(e)?new Uint8Array(e.buffer,e.byteOffset,e.byteLength):e:Uint8Array.from(e)}const c=i?(e,t,r)=>r-t>64?globalThis.Buffer.from(e.subarray(t,r)).toString("utf8"):m(e,t,r):(e,t,r)=>r-t>64?n.decode(e.subarray(t,r)):m(e,t,r),u=i?e=>e.length>64?globalThis.Buffer.from(e):y(e):e=>e.length>64?s.encode(e):y(e),l=i?(e,t,r)=>o(e)?new Uint8Array(e.subarray(t,r)):e.slice(t,r):(e,t,r)=>e.slice(t,r),d=i?(e,t)=>(e=e.map((e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e))),a(globalThis.Buffer.concat(e,t))):(e,t)=>{const r=new Uint8Array(t);let i=0;for(let t of e)i+t.length>r.length&&(t=t.subarray(0,r.length-i)),r.set(t,i),i+=t.length;return r},f=i?e=>globalThis.Buffer.allocUnsafe(e):e=>new Uint8Array(e),h=i?e=>"string"==typeof e?e:globalThis.Buffer.from(g(e)).toString("hex"):e=>"string"==typeof e?e:Array.prototype.reduce.call(g(e),((e,t)=>`${e}${t.toString(16).padStart(2,"0")}`),""),p=i?e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e,"hex"):e=>e instanceof Uint8Array?e:e.length?new Uint8Array(e.split("").map(((e,t,r)=>t%2==0?`0x${e}${r[t+1]}`:"")).filter(Boolean).map((e=>parseInt(e,16)))):new Uint8Array(0);function g(e){if(e instanceof Uint8Array&&"Uint8Array"===e.constructor.name)return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw new Error("Unknown type, must be binary type")}function y(e,t=1/0){let r;const i=e.length;let n=null;const s=[];for(let o=0;o55295&&r<57344){if(!n){if(r>56319){(t-=3)>-1&&s.push(239,191,189);continue}if(o+1===i){(t-=3)>-1&&s.push(239,191,189);continue}n=r;continue}if(r<56320){(t-=3)>-1&&s.push(239,191,189),n=r;continue}r=65536+(n-55296<<10|r-56320)}else n&&(t-=3)>-1&&s.push(239,191,189);if(n=null,r<128){if((t-=1)<0)break;s.push(r)}else if(r<2048){if((t-=2)<0)break;s.push(r>>6|192,63&r|128)}else if(r<65536){if((t-=3)<0)break;s.push(r>>12|224,r>>6&63|128,63&r|128)}else{if(!(r<1114112))throw new Error("Invalid code point");if((t-=4)<0)break;s.push(r>>18|240,r>>12&63|128,r>>6&63|128,63&r|128)}}return s}function m(e,t,r){const i=[];for(;t239?4:n>223?3:n>191?2:1;if(t+o<=r){let r,i,a,c;switch(o){case 1:n<128&&(s=n);break;case 2:r=e[t+1],128==(192&r)&&(c=(31&n)<<6|63&r,c>127&&(s=c));break;case 3:r=e[t+1],i=e[t+2],128==(192&r)&&128==(192&i)&&(c=(15&n)<<12|(63&r)<<6|63&i,c>2047&&(c<55296||c>57343)&&(s=c));break;case 4:r=e[t+1],i=e[t+2],a=e[t+3],128==(192&r)&&128==(192&i)&&128==(192&a)&&(c=(15&n)<<18|(63&r)<<12|(63&i)<<6|63&a,c>65535&&c<1114112&&(s=c))}}null===s?(s=65533,o=1):s>65535&&(s-=65536,i.push(s>>>10&1023|55296),s=56320|1023&s),i.push(s),t+=o}return b(i)}function b(e){const t=e.length;if(t<=4096)return String.fromCharCode.apply(String,e);let r="",i=0;for(;iUint8Array.from(e),r.fromHex=p,r.fromString=u,r.slice=l,r.toHex=h,r.toString=c,r.useBuffer=i},{}],aoxj4:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i="CBOR decode error:",n=[];n[23]=1,n[24]=2,n[25]=3,n[26]=5,n[27]=9,r.assertEnoughData=function(e,t,r){if(e.length-t>>5}`)}function g(e){return()=>{throw new Error(`${f.decodeErrPrefix} ${e}`)}}const y=[];for(let e=0;e<=23;e++)y[e]=p;y[24]=n.decodeUint8,y[25]=n.decodeUint16,y[26]=n.decodeUint32,y[27]=n.decodeUint64,y[28]=p,y[29]=p,y[30]=p,y[31]=p;for(let e=32;e<=55;e++)y[e]=p;y[56]=s.decodeNegint8,y[57]=s.decodeNegint16,y[58]=s.decodeNegint32,y[59]=s.decodeNegint64,y[60]=p,y[61]=p,y[62]=p,y[63]=p;for(let e=64;e<=87;e++)y[e]=o.decodeBytesCompact;y[88]=o.decodeBytes8,y[89]=o.decodeBytes16,y[90]=o.decodeBytes32,y[91]=o.decodeBytes64,y[92]=p,y[93]=p,y[94]=p,y[95]=g("indefinite length bytes/strings are not supported");for(let e=96;e<=119;e++)y[e]=a.decodeStringCompact;y[120]=a.decodeString8,y[121]=a.decodeString16,y[122]=a.decodeString32,y[123]=a.decodeString64,y[124]=p,y[125]=p,y[126]=p,y[127]=g("indefinite length bytes/strings are not supported");for(let e=128;e<=151;e++)y[e]=c.decodeArrayCompact;y[152]=c.decodeArray8,y[153]=c.decodeArray16,y[154]=c.decodeArray32,y[155]=c.decodeArray64,y[156]=p,y[157]=p,y[158]=p,y[159]=c.decodeArrayIndefinite;for(let e=160;e<=183;e++)y[e]=u.decodeMapCompact;y[184]=u.decodeMap8,y[185]=u.decodeMap16,y[186]=u.decodeMap32,y[187]=u.decodeMap64,y[188]=p,y[189]=p,y[190]=p,y[191]=u.decodeMapIndefinite;for(let e=192;e<=215;e++)y[e]=l.decodeTagCompact;y[216]=l.decodeTag8,y[217]=l.decodeTag16,y[218]=l.decodeTag32,y[219]=l.decodeTag64,y[220]=p,y[221]=p,y[222]=p,y[223]=p;for(let e=224;e<=243;e++)y[e]=g("simple values are not supported");y[244]=p,y[245]=p,y[246]=p,y[247]=d.decodeUndefined,y[248]=g("simple values are not supported"),y[249]=d.decodeFloat16,y[250]=d.decodeFloat32,y[251]=d.decodeFloat64,y[252]=p,y[253]=p,y[254]=p,y[255]=d.decodeBreak;const m=[];for(let e=0;e<24;e++)m[e]=new i.Token(i.Type.uint,e,1);for(let e=-1;e>=-24;e--)m[31-e]=new i.Token(i.Type.negint,e,1);m[64]=new i.Token(i.Type.bytes,new Uint8Array(0),1),m[96]=new i.Token(i.Type.string,"",1),m[128]=new i.Token(i.Type.array,0,1),m[160]=new i.Token(i.Type.map,0,1),m[244]=new i.Token(i.Type.false,!1,1),m[245]=new i.Token(i.Type.true,!0,1),m[246]=new i.Token(i.Type.null,null,1),r.jump=y,r.quick=m,r.quickEncodeToken=function(e){switch(e.type){case i.Type.false:return h.fromArray([244]);case i.Type.true:return h.fromArray([245]);case i.Type.null:return h.fromArray([246]);case i.Type.bytes:return e.value.length?void 0:h.fromArray([64]);case i.Type.string:return""===e.value?h.fromArray([96]):void 0;case i.Type.array:return 0===e.value?h.fromArray([128]):void 0;case i.Type.map:return 0===e.value?h.fromArray([160]):void 0;case i.Type.uint:return e.value<24?h.fromArray([Number(e.value)]):void 0;case i.Type.negint:if(e.value>=-24)return h.fromArray([31-Number(e.value)])}}},{"./token.js":"jVUGz","./0uint.js":"9zilL","./1negint.js":"2sjxL","./2bytes.js":"8Tv7U","./3string.js":"56Ua8","./4array.js":"4ePxQ","./5map.js":"28THk","./6tag.js":"5TCWp","./7float.js":"5T30n","./common.js":"aoxj4","./byte-utils.js":"9dmLv"}],"9zilL":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./common.js");const s=[24,256,65536,4294967296,BigInt("18446744073709551616")];function o(e,t,r){n.assertEnoughData(e,t,1);const i=e[t];if(!0===r.strict&&i>>8,255&i])}else if(r>>24&255,i>>>16&255,i>>>8&255,255&i])}else{const i=BigInt(r);if(!(i>BigInt(32)&BigInt(4294967295));r[8]=255&n,n>>=8,r[7]=255&n,n>>=8,r[6]=255&n,n>>=8,r[5]=255&n,r[4]=255&s,s>>=8,r[3]=255&s,s>>=8,r[2]=255&s,s>>=8,r[1]=255&s,e.push(r)}}}l.encodedSize=function(e){return d.encodedSize(e.value)},d.encodedSize=function(e){return et.value?1:0},r.decodeUint16=function(e,t,r,n){return new i.Token(i.Type.uint,a(e,t+1,n),3)},r.decodeUint32=function(e,t,r,n){return new i.Token(i.Type.uint,c(e,t+1,n),5)},r.decodeUint64=function(e,t,r,n){return new i.Token(i.Type.uint,u(e,t+1,n),9)},r.decodeUint8=function(e,t,r,n){return new i.Token(i.Type.uint,o(e,t+1,n),2)},r.encodeUint=l,r.encodeUintValue=d,r.readUint16=a,r.readUint32=c,r.readUint64=u,r.readUint8=o,r.uintBoundaries=s},{"./token.js":"jVUGz","./common.js":"aoxj4"}],"2sjxL":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./0uint.js"),s=e("./common.js");const o=BigInt(-1),a=BigInt(1);function c(e,t){const r=t.value,i="bigint"==typeof r?r*o-a:-1*r-1;n.encodeUintValue(e,t.type.majorEncoded,i)}c.encodedSize=function(e){const t=e.value,r="bigint"==typeof t?t*o-a:-1*t-1;return rt.value?-1:0},r.decodeNegint16=function(e,t,r,s){return new i.Token(i.Type.negint,-1-n.readUint16(e,t+1,s),3)},r.decodeNegint32=function(e,t,r,s){return new i.Token(i.Type.negint,-1-n.readUint32(e,t+1,s),5)},r.decodeNegint64=function(e,t,r,a){const c=n.readUint64(e,t+1,a);if("bigint"!=typeof c){const e=-1-c;if(e>=Number.MIN_SAFE_INTEGER)return new i.Token(i.Type.negint,e,9)}if(!0!==a.allowBigInt)throw new Error(`${s.decodeErrPrefix} integers outside of the safe integer range are not supported`);return new i.Token(i.Type.negint,o-BigInt(c),9)},r.decodeNegint8=function(e,t,r,s){return new i.Token(i.Type.negint,-1-n.readUint8(e,t+1,s),2)},r.encodeNegint=c},{"./token.js":"jVUGz","./0uint.js":"9zilL","./common.js":"aoxj4"}],"8Tv7U":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./common.js"),s=e("./0uint.js"),o=e("./byte-utils.js");function a(e,t,r,s){n.assertEnoughData(e,t,r+s);const a=o.slice(e,t+r,t+r+s);return new i.Token(i.Type.bytes,a,r+s)}function c(e){return void 0===e.encodedBytes&&(e.encodedBytes=e.type===i.Type.string?o.fromString(e.value):e.value),e.encodedBytes}function u(e,t){const r=c(t);s.encodeUintValue(e,t.type.majorEncoded,r.length),e.push(r)}function l(e,t){return e.lengtht.length?1:o.compare(e,t)}u.encodedSize=function(e){const t=c(e);return s.encodeUintValue.encodedSize(t.length)+t.length},u.compareTokens=function(e,t){return l(c(e),c(t))},r.compareBytes=l,r.decodeBytes16=function(e,t,r,i){return a(e,t,3,s.readUint16(e,t+1,i))},r.decodeBytes32=function(e,t,r,i){return a(e,t,5,s.readUint32(e,t+1,i))},r.decodeBytes64=function(e,t,r,i){const o=s.readUint64(e,t+1,i);if("bigint"==typeof o)throw new Error(`${n.decodeErrPrefix} 64-bit integer bytes lengths not supported`);return a(e,t,9,o)},r.decodeBytes8=function(e,t,r,i){return a(e,t,2,s.readUint8(e,t+1,i))},r.decodeBytesCompact=function(e,t,r,i){return a(e,t,1,r)},r.encodeBytes=u},{"./token.js":"jVUGz","./common.js":"aoxj4","./0uint.js":"9zilL","./byte-utils.js":"9dmLv"}],"56Ua8":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./common.js"),s=e("./0uint.js"),o=e("./2bytes.js"),a=e("./byte-utils.js");function c(e,t,r,s){const o=r+s;return n.assertEnoughData(e,t,o),new i.Token(i.Type.string,a.toString(e,t+r,t+o),o)}const u=o.encodeBytes;r.decodeString16=function(e,t,r,i){return c(e,t,3,s.readUint16(e,t+1,i))},r.decodeString32=function(e,t,r,i){return c(e,t,5,s.readUint32(e,t+1,i))},r.decodeString64=function(e,t,r,i){const o=s.readUint64(e,t+1,i);if("bigint"==typeof o)throw new Error(`${n.decodeErrPrefix} 64-bit integer string lengths not supported`);return c(e,t,9,o)},r.decodeString8=function(e,t,r,i){return c(e,t,2,s.readUint8(e,t+1,i))},r.decodeStringCompact=function(e,t,r,i){return c(e,t,1,r)},r.encodeString=u},{"./token.js":"jVUGz","./common.js":"aoxj4","./0uint.js":"9zilL","./2bytes.js":"8Tv7U","./byte-utils.js":"9dmLv"}],"4ePxQ":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./0uint.js"),s=e("./common.js");function o(e,t,r,n){return new i.Token(i.Type.array,n,r)}function a(e,t){n.encodeUintValue(e,i.Type.array.majorEncoded,t.value)}a.compareTokens=n.encodeUint.compareTokens,r.decodeArray16=function(e,t,r,i){return o(0,0,3,n.readUint16(e,t+1,i))},r.decodeArray32=function(e,t,r,i){return o(0,0,5,n.readUint32(e,t+1,i))},r.decodeArray64=function(e,t,r,i){const a=n.readUint64(e,t+1,i);if("bigint"==typeof a)throw new Error(`${s.decodeErrPrefix} 64-bit integer array lengths not supported`);return o(0,0,9,a)},r.decodeArray8=function(e,t,r,i){return o(0,0,2,n.readUint8(e,t+1,i))},r.decodeArrayCompact=function(e,t,r,i){return o(0,0,1,r)},r.decodeArrayIndefinite=function(e,t,r,i){if(!1===i.allowIndefinite)throw new Error(`${s.decodeErrPrefix} indefinite length items not allowed`);return o(0,0,1,1/0)},r.encodeArray=a},{"./token.js":"jVUGz","./0uint.js":"9zilL","./common.js":"aoxj4"}],"28THk":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./0uint.js"),s=e("./common.js");function o(e,t,r,n){return new i.Token(i.Type.map,n,r)}function a(e,t){n.encodeUintValue(e,i.Type.map.majorEncoded,t.value)}a.compareTokens=n.encodeUint.compareTokens,r.decodeMap16=function(e,t,r,i){return o(0,0,3,n.readUint16(e,t+1,i))},r.decodeMap32=function(e,t,r,i){return o(0,0,5,n.readUint32(e,t+1,i))},r.decodeMap64=function(e,t,r,i){const a=n.readUint64(e,t+1,i);if("bigint"==typeof a)throw new Error(`${s.decodeErrPrefix} 64-bit integer map lengths not supported`);return o(0,0,9,a)},r.decodeMap8=function(e,t,r,i){return o(0,0,2,n.readUint8(e,t+1,i))},r.decodeMapCompact=function(e,t,r,i){return o(0,0,1,r)},r.decodeMapIndefinite=function(e,t,r,i){if(!1===i.allowIndefinite)throw new Error(`${s.decodeErrPrefix} indefinite length items not allowed`);return o(0,0,1,1/0)},r.encodeMap=a},{"./token.js":"jVUGz","./0uint.js":"9zilL","./common.js":"aoxj4"}],"5TCWp":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./0uint.js");function s(e,t){n.encodeUintValue(e,i.Type.tag.majorEncoded,t.value)}s.compareTokens=n.encodeUint.compareTokens,r.decodeTag16=function(e,t,r,s){return new i.Token(i.Type.tag,n.readUint16(e,t+1,s),3)},r.decodeTag32=function(e,t,r,s){return new i.Token(i.Type.tag,n.readUint32(e,t+1,s),5)},r.decodeTag64=function(e,t,r,s){return new i.Token(i.Type.tag,n.readUint64(e,t+1,s),9)},r.decodeTag8=function(e,t,r,s){return new i.Token(i.Type.tag,n.readUint8(e,t+1,s),2)},r.decodeTagCompact=function(e,t,r,n){return new i.Token(i.Type.tag,r,1)},r.encodeTag=s},{"./token.js":"jVUGz","./0uint.js":"9zilL"}],"5T30n":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./common.js"),s=e("./0uint.js");function o(e,t,r){if(r){if(!1===r.allowNaN&&Number.isNaN(e))throw new Error(`${n.decodeErrPrefix} NaN values are not supported`);if(!1===r.allowInfinity&&(e===1/0||e===-1/0))throw new Error(`${n.decodeErrPrefix} Infinity values are not supported`)}return new i.Token(i.Type.float,e,t)}function a(e,t,r){const n=t.value;if(!1===n)e.push([20|i.Type.float.majorEncoded]);else if(!0===n)e.push([21|i.Type.float.majorEncoded]);else if(null===n)e.push([22|i.Type.float.majorEncoded]);else if(void 0===n)e.push([23|i.Type.float.majorEncoded]);else{let t,i=!1;r&&!0===r.float64||(d(n),t=f(l,1),n===t||Number.isNaN(n)?(l[0]=249,e.push(l.slice(0,3)),i=!0):(h(n),t=p(l,1),n===t&&(l[0]=250,e.push(l.slice(0,5)),i=!0))),i||(s=n,u.setFloat64(0,s,!1),t=g(l,1),l[0]=251,e.push(l.slice(0,9)))}var s}a.encodedSize=function(e,t){const r=e.value;if(!1===r||!0===r||null==r)return 1;let i;if(!t||!0!==t.float64){if(d(r),i=f(l,1),r===i||Number.isNaN(r))return 3;if(h(r),i=p(l,1),r===i)return 5}return 9};const c=new ArrayBuffer(9),u=new DataView(c,1),l=new Uint8Array(c,0);function d(e){if(e===1/0)u.setUint16(0,31744,!1);else if(e===-1/0)u.setUint16(0,64512,!1);else if(Number.isNaN(e))u.setUint16(0,32256,!1);else{u.setFloat32(0,e);const t=u.getUint32(0),r=(2139095040&t)>>23,i=8388607&t;if(255===r)u.setUint16(0,31744,!1);else if(0===r)u.setUint16(0,(2147483648&e)>>16|i>>13,!1);else{const e=r-127;e<-24?u.setUint16(0,0):e<-14?u.setUint16(0,(2147483648&t)>>16|1<<24+e,!1):u.setUint16(0,(2147483648&t)>>16|e+15<<10|i>>13,!1)}}}function f(e,t){if(e.length-t<2)throw new Error(`${n.decodeErrPrefix} not enough data for float16`);const r=(e[t]<<8)+e[t+1];if(31744===r)return 1/0;if(64512===r)return-1/0;if(32256===r)return NaN;const i=r>>10&31,s=1023&r;let o;return o=0===i?s*2**-24:31!==i?(s+1024)*2**(i-25):0===s?1/0:NaN,32768&r?-o:o}function h(e){u.setFloat32(0,e,!1)}function p(e,t){if(e.length-t<4)throw new Error(`${n.decodeErrPrefix} not enough data for float32`);const r=(e.byteOffset||0)+t;return new DataView(e.buffer,r,4).getFloat32(0,!1)}function g(e,t){if(e.length-t<8)throw new Error(`${n.decodeErrPrefix} not enough data for float64`);const r=(e.byteOffset||0)+t;return new DataView(e.buffer,r,8).getFloat64(0,!1)}a.compareTokens=s.encodeUint.compareTokens,r.decodeBreak=function(e,t,r,s){if(!1===s.allowIndefinite)throw new Error(`${n.decodeErrPrefix} indefinite length items not allowed`);return new i.Token(i.Type.break,void 0,1)},r.decodeFloat16=function(e,t,r,i){return o(f(e,t+1),3,i)},r.decodeFloat32=function(e,t,r,i){return o(p(e,t+1),5,i)},r.decodeFloat64=function(e,t,r,i){return o(g(e,t+1),9,i)},r.decodeUndefined=function(e,t,r,s){if(!1===s.allowUndefined)throw new Error(`${n.decodeErrPrefix} undefined values are not supported`);return new i.Token(i.Type.undefined,void 0,1)},r.encodeFloat=a},{"./token.js":"jVUGz","./common.js":"aoxj4","./0uint.js":"9zilL"}],dbDwZ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./common.js"),n=e("./token.js"),s=e("./jump.js");const o={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0};class a{constructor(e,t={}){this.pos=0,this.data=e,this.options=t}done(){return this.pos>=this.data.length}next(){const e=this.data[this.pos];let t=s.quick[e];if(void 0===t){const r=s.jump[e];if(!r)throw new Error(`${i.decodeErrPrefix} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);const n=31&e;t=r(this.data,this.pos,n,this.options)}return this.pos+=t.encodedLength,t}}const c=Symbol.for("DONE"),u=Symbol.for("BREAK");function l(e,t){if(e.done())return c;const r=e.next();if(r.type===n.Type.break)return u;if(r.type.terminal)return r.value;if(r.type===n.Type.array)return function(e,t,r){const n=[];for(let s=0;sn.coerce(e)});r.identity=s},{"./hasher.js":"5z3Qi","../bytes.js":"6I0Ku"}],"5z3Qi":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./digest.js");class n{constructor(e,t,r){this.name=e,this.code=t,this.encode=r}async digest(e){if(e instanceof Uint8Array){const t=await this.encode(e);return i.create(this.code,t)}throw Error("Unknown type, must be binary type")}}r.Hasher=n,r.from=({name:e,code:t,encode:r})=>new n(e,t,r)},{"./digest.js":"kpRBg"}],lPcQG:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./bases/identity.js"),n=e("./bases/base2.js"),s=e("./bases/base8.js"),o=e("./bases/base10.js"),a=e("./bases/base16.js"),c=e("./bases/base32.js"),u=e("./bases/base36.js"),l=e("./bases/base58.js"),d=e("./bases/base64.js"),f=e("./hashes/sha2.js"),h=e("./hashes/identity.js"),p=e("./codecs/raw.js"),g=e("./codecs/json.js");e("./index.js");var y=e("./cid.js"),m=e("./hashes/hasher.js"),b=e("./hashes/digest.js"),v=e("./varint.js"),w=e("./bytes.js");const _={...i,...n,...s,...o,...a,...c,...u,...l,...d},E={...f,...h},S={raw:p,json:g};r.CID=y.CID,r.hasher=m,r.digest=b,r.varint=v,r.bytes=w,r.bases=_,r.codecs=S,r.hashes=E},{"./bases/identity.js":"4EVux","./bases/base2.js":"5EiC2","./bases/base8.js":"bGEV7","./bases/base10.js":"esjPe","./bases/base16.js":"iQzgO","./bases/base32.js":"5k9Tu","./bases/base36.js":"7VmDr","./bases/base58.js":"4n7mA","./bases/base64.js":"gaFBW","./hashes/sha2.js":"7i9MT","./hashes/identity.js":"eYCZn","./codecs/raw.js":"fdfgp","./codecs/json.js":"cRmep","./index.js":"3ANyW","./cid.js":"9ooAY","./hashes/hasher.js":"5z3Qi","./hashes/digest.js":"kpRBg","./varint.js":"ivDPm","./bytes.js":"6I0Ku"}],"4EVux":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js"),n=e("../bytes.js");const s=i.from({prefix:"\0",name:"identity",encode:e=>n.toString(e),decode:e=>n.fromString(e)});r.identity=s},{"./base.js":"6uTk1","../bytes.js":"6I0Ku"}],"5EiC2":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./base.js").rfc4648({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});r.base2=i},{"./base.js":"6uTk1"}],bGEV7:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./base.js").rfc4648({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});r.base8=i},{"./base.js":"6uTk1"}],esjPe:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./base.js").baseX({prefix:"9",name:"base10",alphabet:"0123456789"});r.base10=i},{"./base.js":"6uTk1"}],iQzgO:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js");const n=i.rfc4648({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),s=i.rfc4648({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});r.base16=n,r.base16upper=s},{"./base.js":"6uTk1"}],"7VmDr":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js");const n=i.baseX({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),s=i.baseX({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});r.base36=n,r.base36upper=s},{"./base.js":"6uTk1"}],gaFBW:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js");const n=i.rfc4648({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),s=i.rfc4648({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),o=i.rfc4648({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),a=i.rfc4648({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});r.base64=n,r.base64pad=s,r.base64url=o,r.base64urlpad=a},{"./base.js":"6uTk1"}],"7i9MT":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./hasher.js");const n=e=>async t=>new Uint8Array(await crypto.subtle.digest(e,t)),s=i.from({name:"sha2-256",code:18,encode:n("SHA-256")}),o=i.from({name:"sha2-512",code:19,encode:n("SHA-512")});r.sha256=s,r.sha512=o},{"./hasher.js":"5z3Qi"}],fdfgp:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../bytes.js");r.code=85,r.decode=e=>i.coerce(e),r.encode=e=>i.coerce(e),r.name="raw"},{"../bytes.js":"6I0Ku"}],cRmep:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=new TextEncoder,n=new TextDecoder;r.code=512,r.decode=e=>JSON.parse(n.decode(e)),r.encode=e=>i.encode(JSON.stringify(e)),r.name="json"},{}],"3ANyW":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./cid.js"),n=e("./varint.js"),s=e("./bytes.js"),o=e("./hashes/hasher.js"),a=e("./hashes/digest.js");r.CID=i.CID,r.varint=n,r.bytes=s,r.hasher=o,r.digest=a},{"./cid.js":"9ooAY","./varint.js":"ivDPm","./bytes.js":"6I0Ku","./hashes/hasher.js":"5z3Qi","./hashes/digest.js":"kpRBg"}],d1lP3:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.initAssets=function(){}},{}],j69o8:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});class i extends Error{constructor(e="not initialized"){super(e),this.name="NotInitializedError",this.code=i.code}}i.code="ERR_NOT_INITIALIZED";class n extends Error{constructor(e="cannot initialize an initializing node"){super(e),this.name="AlreadyInitializingError",this.code=s.code}}n.code="ERR_ALREADY_INITIALIZING";class s extends Error{constructor(e="cannot re-initialize an initialized node"){super(e),this.name="AlreadyInitializedError",this.code=s.code}}s.code="ERR_ALREADY_INITIALIZED";class o extends Error{constructor(e="not started"){super(e),this.name="NotStartedError",this.code=o.code}}o.code="ERR_NOT_STARTED";class a extends Error{constructor(e="cannot start, already startin"){super(e),this.name="AlreadyStartingError",this.code=a.code}}a.code="ERR_ALREADY_STARTING";class c extends Error{constructor(e="cannot start, already started"){super(e),this.name="AlreadyStartedError",this.code=c.code}}c.code="ERR_ALREADY_STARTED";class u extends Error{constructor(e="not enabled"){super(e),this.name="NotEnabledError",this.code=u.code}}u.code="ERR_NOT_ENABLED",r.AlreadyInitializedError=s,r.AlreadyInitializingError=n,r.AlreadyStartedError=c,r.AlreadyStartingError=a,r.NotEnabledError=u,r.NotInitializedError=i,r.NotStartedError=o},{}],dF7Y4:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./util/bases.js");r.fromString=function(e,t="utf8"){const r=i[t];if(!r)throw new Error(`Unsupported encoding "${t}"`);return r.decoder.decode(`${r.prefix}${e}`)}},{"./util/bases.js":"6UNPX"}],"6UNPX":[function(e,t,r){"use strict";var i=e("multiformats/basics");function n(e,t,r,i){return{name:e,prefix:t,encoder:{name:e,prefix:t,encode:r},decoder:{decode:i}}}const s=n("utf8","u",(e=>"u"+new TextDecoder("utf8").decode(e)),(e=>(new TextEncoder).encode(e.substring(1)))),o=n("ascii","a",(e=>{let t="a";for(let r=0;r{e=e.substring(1);const t=new Uint8Array(e.length);for(let r=0;r{const{libp2p:l}=await i.Service.start(e,{peerId:r,repo:s,print:c,options:u});await Promise.all([o.startOnline({keychain:n,libp2p:l,peerId:r,repo:s}),t.start(),a.start()])}}},{"../utils/service.js":"ethcf"}],ethcf:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../errors.js"),n=e("../utils.js");class s{static create({start:e,stop:t}){return new s(e,t)}static async start(e,t){const{state:r,activate:n}=e;switch(r.status){case"stopped":try{const r=n(t);e.state={status:"starting",ready:r};const i=await r;return e.state={status:"started",value:i},i}catch(t){throw e.state={status:"stopped"},t}case"starting":throw new i.AlreadyStartingError;case"started":throw new i.AlreadyStartedError;case"stopping":return await r.ready,await s.start(e,t);default:return s.panic(e)}}static async stop(e){const{state:t,deactivate:r}=e;switch(t.status){case"stopped":break;case"starting":try{await t.ready}catch(e){}return await s.stop(e);case"stopping":return await t.ready;case"started":r&&await r(t.value),e.state={status:"stopped"};break;default:s.panic(t)}}static try({state:e}){return"started"===e.status?e.value:null}static async use({state:e},t){switch(e.status){case"started":return e.value;case"starting":return await n.withTimeout(e.ready,t);default:throw new i.NotStartedError}}static panic({state:e}){const t=JSON.stringify({status:e.status});throw RangeError(`Service in invalid state ${t}, should never happen if you see this please report a bug`)}constructor(e,t){this.activate=e,this.deactivate=t,this.state={status:"stopped"}}async use(e){return await s.use(this,e)}try(){return s.try(this)}}r.Service=s},{"../errors.js":"j69o8","../utils.js":"cT4uN"}],cT4uN:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("is-ipfs"),n=e("multiformats/cid"),s=e("interface-datastore/key"),o=e("err-code"),a=e("ipfs-core-utils/with-timeout-option"),c=e("ipfs-core-utils/to-cid-and-path"),u=e("@ipld/dag-pb");function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function d(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var f=l(i),h=l(o),p=d(u);const g=new s.Key("/local/filesroot"),y=a.withTimeoutOption((async(e,t)=>await e)),m=async function*(e,t,r,i,s){const o=async e=>{const t=await r.getCodec(e.code),n=await i.blocks.get(e,s);return t.decode(n)},a=t.split("/").filter(Boolean);let c=await o(e),u=e;for(a.length||(yield{value:c,remainderPath:""});a.length;){const r=a.shift();if(!r)throw h.default(new Error(`Could not resolve path "${t}"`),"ERR_INVALID_PATH");if(e.code===p.code&&Array.isArray(c.Links)){const e=c.Links.find((e=>e.Name===r));if(e){yield{value:e.Hash,remainderPath:a.join("/")},c=await o(e.Hash),u=e.Hash;continue}}if(!Object.prototype.hasOwnProperty.call(c,r))throw h.default(new Error(`no link named "${r}" under ${u}`),"ERR_NO_LINK");c=c[r],yield{value:c,remainderPath:a.join("/")},n.CID.asCID(c)&&(u=c,c=await o(c))}};r.MFS_MAX_CHUNK_SIZE=262144,r.MFS_MAX_LINKS=174,r.MFS_ROOT_KEY=g,r.OFFLINE_ERROR="This command must be run in online mode. Try running 'ipfs daemon' first.",r.mapFile=e=>{if("file"!==e.type&&"directory"!==e.type&&"raw"!==e.type)throw new Error(`Unknown node type '${e.type}'`);const t={cid:e.cid,path:e.path,name:e.name,size:e.size,type:"file"};return"directory"===e.type&&(t.type="dir"),"file"===e.type&&(t.size=e.unixfs.fileSize()),"file"!==e.type&&"directory"!==e.type||(t.mode=e.unixfs.mode,void 0!==e.unixfs.mtime&&(t.mtime=e.unixfs.mtime)),t},r.normalizeCidPath=e=>e instanceof Uint8Array?n.CID.decode(e).toString():(0===(e=e.toString()).indexOf("/ipfs/")&&(e=e.substring(6)),"/"===e.charAt(e.length-1)&&(e=e.substring(0,e.length-1)),e),r.normalizePath=e=>{if(n.CID.asCID(e))return`/ipfs/${e}`;const t=e.toString();try{return`/ipfs/${n.CID.parse(t)}`}catch{}if(f.default.path(t))return t;throw h.default(new Error(`invalid path: ${e}`),"ERR_BAD_PATH")},r.resolve=m,r.resolvePath=async function(e,t,r,i={}){const{cid:s,path:o}=c.toCidAndPath(r);o&&(i.path=o);let a=s,u=i.path||"";if(u.startsWith("/")&&(u=u.substring(1)),i.path)try{for await(const{value:r,remainderPath:o}of m(s,i.path,t,e,{signal:i.signal})){if(!n.CID.asCID(r))break;u=o,a=r}}catch(e){throw e.message.startsWith("Object has no property")&&(e.message=`no link named "${u.split("/")[0]}" under ${a}`,e.code="ERR_NO_LINK"),e}return{cid:a,remainderPath:u||""}},r.withTimeout=y},{"is-ipfs":"40iuV","multiformats/cid":"9ooAY","interface-datastore/key":"9hGOz","err-code":"chZjB","ipfs-core-utils/with-timeout-option":"j29MK","ipfs-core-utils/to-cid-and-path":"jN5CZ","@ipld/dag-pb":"i2cdx"}],"40iuV":[function(e,t,r){"use strict";const{base58btc:i}=e("multiformats/bases/base58"),{base32:n}=e("multiformats/bases/base32"),s=e("multiformats/hashes/digest"),{Multiaddr:o}=e("multiaddr"),a=e("mafmt"),{CID:c}=e("multiformats/cid"),{URL:u}=e("iso-url"),{toString:l}=e("uint8arrays/to-string"),d=/^https?:\/\/[^/]+\/(ip[fn]s)\/([^/?#]+)/,f=/^\/(ip[fn]s)\/([^/?#]+)/,h=/^https?:\/\/([^/]+)\.(ip[fn]s)\.[^/?]+/,p=/^(([a-z0-9]|[a-z0-9][a-z0-9-]*[a-z0-9])\.)+([a-z0-9]|[a-z0-9][a-z0-9-]*[a-z0-9])$/;function g(e){try{return"string"==typeof e?Boolean(c.parse(e)):e instanceof Uint8Array?Boolean(c.decode(e)):Boolean(c.asCID(e))}catch(e){return!1}}function y(e){if(!e)return!1;if(o.isMultiaddr(e))return!0;try{return new o(e),!0}catch(e){return!1}}function m(e,t,r=1,i=2){const n=w(e);if(!n)return!1;const s=n.match(t);if(!s)return!1;if("ipfs"!==s[r])return!1;let o=s[i];return o&&t===h&&(o=o.toLowerCase()),g(o)}function b(e,t,r=1,i=2){const n=w(e);if(!n)return!1;const s=n.match(t);if(!s)return!1;if("ipns"!==s[r])return!1;let o=s[i];if(o&&t===h){if(o=o.toLowerCase(),g(o))return!0;try{!o.includes(".")&&o.includes("-")&&(o=o.replace(/--/g,"@").replace(/-/g,".").replace(/@/g,"-"));const{hostname:e}=new u(`http://${o}`);return p.test(e)}catch(e){return!1}}return!0}function v(e){return"string"==typeof e}function w(e){return e instanceof Uint8Array?l(e,"base58btc"):!!v(e)&&e}const _=e=>m(e,h,2,1),E=e=>b(e,h,2,1),S=e=>_(e)||E(e),T=e=>m(e,d)||_(e),A=e=>b(e,d)||E(e),k=e=>T(e)||A(e)||S(e),I=e=>m(e,f)||b(e,f);t.exports={multihash:function(e){const t=w(e);try{s.decode(i.decode("z"+t))}catch{return!1}return!0},multiaddr:y,peerMultiaddr:function(e){return y(e)&&a.P2P.matches(e)},cid:g,base32cid:e=>function(e){try{n.decode(e)}catch{return!1}return!0}(e)&&g(e),ipfsSubdomain:_,ipnsSubdomain:E,subdomain:S,subdomainGatewayPattern:h,ipfsUrl:T,ipnsUrl:A,url:k,pathGatewayPattern:d,ipfsPath:e=>m(e,f),ipnsPath:e=>b(e,f),path:I,pathPattern:f,urlOrPath:e=>k(e)||I(e),cidPath:e=>v(e)&&!g(e)&&m(`/ipfs/${e}`,f)}},{"multiformats/bases/base58":"4n7mA","multiformats/bases/base32":"5k9Tu","multiformats/hashes/digest":"kpRBg",multiaddr:"8Mu1u",mafmt:"l1lok","multiformats/cid":"9ooAY","iso-url":"86VPZ","uint8arrays/to-string":"hC8JB"}],"8Mu1u":[function(e,t,r){"use strict";const i=e("./codec"),n=e("./protocols-table"),s=e("varint"),{CID:o}=e("multiformats/cid"),{base58btc:a}=e("multiformats/bases/base58"),c=e("err-code"),u=Symbol.for("nodejs.util.inspect.custom"),{toString:l}=e("uint8arrays/to-string"),{equals:d}=e("uint8arrays/equals"),f=new Map,h=Symbol.for("@multiformats/js-multiaddr/multiaddr");class p{constructor(e){if(null==e&&(e=""),Object.defineProperty(this,h,{value:!0}),e instanceof Uint8Array)this.bytes=i.fromBytes(e);else if("string"==typeof e){if(e.length>0&&"/"!==e.charAt(0))throw new Error(`multiaddr "${e}" must start with a "/"`);this.bytes=i.fromString(e)}else{if(!p.isMultiaddr(e))throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=i.fromBytes(e.bytes)}}toString(){return i.bytesToString(this.bytes)}toJSON(){return this.toString()}toOptions(){const e={},t=this.toString().split("/");return e.family="ip4"===t[1]?4:6,e.host=t[2],e.transport=t[3],e.port=parseInt(t[4]),e}protos(){return this.protoCodes().map((e=>Object.assign({},n(e))))}protoCodes(){const e=[],t=this.bytes;let r=0;for(;re.name))}tuples(){return i.bytesToTuples(this.bytes)}stringTuples(){const e=i.bytesToTuples(this.bytes);return i.tuplesToStringTuples(e)}encapsulate(e){return e=new p(e),new p(this.toString()+e.toString())}decapsulate(e){const t=e.toString(),r=this.toString(),i=r.lastIndexOf(t);if(i<0)throw new Error("Address "+this+" does not contain subaddress: "+e);return new p(r.slice(0,i))}decapsulateCode(e){const t=this.tuples();for(let r=t.length-1;r>=0;r--)if(t[r][0]===e)return new p(i.tuplesToBytes(t.slice(0,r)));return this}getPeerId(){try{const e=this.stringTuples().filter((e=>e[0]===n.names.ipfs.code)).pop();if(e&&e[1]){const t=e[1];return"Q"===t[0]||"1"===t[0]?l(a.decode(`z${t}`),"base58btc"):l(o.parse(t).multihash.bytes,"base58btc")}return null}catch(e){return null}}getPath(){let e=null;try{e=this.stringTuples().filter((e=>!!n(e[0]).path))[0][1],e||(e=null)}catch(t){e=null}return e}equals(e){return d(this.bytes,e.bytes)}async resolve(){const e=this.protos().find((e=>e.resolvable));if(!e)return[this];const t=f.get(e.name);if(!t)throw c(new Error(`no available resolver for ${e.name}`),"ERR_NO_AVAILABLE_RESOLVER");return(await t(this)).map((e=>new p(e)))}nodeAddress(){const e=this.protoCodes(),t=this.protoNames(),r=this.toString().split("/").slice(1);if(r.length<4)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6}/{address}/{tcp, udp}/{port}".');if(4!==e[0]&&41!==e[0]&&54!==e[0]&&55!==e[0])throw new Error(`no protocol with name: "'${t[0]}'". Must have a valid family name: "{ip4, ip6, dns4, dns6}".`);if("tcp"!==r[2]&&"udp"!==r[2])throw new Error(`no protocol with name: "'${t[1]}'". Must have a valid transport protocol: "{tcp, udp}".`);return{family:41===e[0]||55===e[0]?6:4,address:r[1],port:parseInt(r[3])}}isThinWaistAddress(e){const t=(e||this).protos();return 2===t.length&&((4===t[0].code||41===t[0].code)&&(6===t[1].code||273===t[1].code))}static fromNodeAddress(e,t){if(!e)throw new Error("requires node address object");if(!t)throw new Error("requires transport protocol");let r;switch(e.family){case 4:r="ip4";break;case 6:r="ip6";break;default:throw Error(`Invalid addr family. Got '${e.family}' instead of 4 or 6`)}return new p("/"+[r,e.address,t,e.port].join("/"))}static isName(e){return!!p.isMultiaddr(e)&&e.protos().some((e=>e.resolvable))}static isMultiaddr(e){return e instanceof p||Boolean(e&&e[h])}[u](){return""}inspect(){return""}}p.protocols=n,p.resolvers=f,t.exports={Multiaddr:p,multiaddr:function(e){return new p(e)},protocols:n,resolvers:f}},{"./codec":"heFUu","./protocols-table":"5Z4cQ",varint:"aN1CO","multiformats/cid":"9ooAY","multiformats/bases/base58":"4n7mA","err-code":"chZjB","uint8arrays/to-string":"hC8JB","uint8arrays/equals":"eY3cX"}],heFUu:[function(e,t,r){"use strict";const i=e("./convert"),n=e("./protocols-table"),s=e("varint"),{concat:o}=e("uint8arrays/concat"),{toString:a}=e("uint8arrays/to-string");function c(e){const t=[],r=e.split("/").slice(1);if(1===r.length&&""===r[0])return[];for(let i=0;i=r.length)throw v("invalid address: "+e);if(o.path){t.push([s,b(r.slice(i).join("/"))]);break}t.push([s,r[i]])}else t.push([s])}return t}function u(e){const t=[];return e.map((e=>{const r=w(e);return t.push(r.name),e.length>1&&t.push(e[1]),null})),b(t.join("/"))}function l(e){return e.map((e=>{Array.isArray(e)||(e=[e]);const t=w(e);return e.length>1?[t.code,i.toBytes(t.code,e[1])]:[t.code]}))}function d(e){return e.map((e=>{const t=w(e);return e[1]?[t.code,i.toString(t.code,e[1])]:[t.code]}))}function f(e){return y(o(e.map((e=>{const t=w(e);let r=Uint8Array.from(s.encode(t.code));return e.length>1&&(r=o([r,e[1]])),r}))))}function h(e,t){if(e.size>0)return e.size/8;if(0===e.size)return 0;return s.decode(t)+s.decode.bytes}function p(e){const t=[];let r=0;for(;re.length)throw v("Invalid address Uint8Array: "+a(e,"base16"));t.push([i,u])}return t}function g(e){return f(l(c(e=b(e))))}function y(e){const t=m(e);if(t)throw t;return Uint8Array.from(e)}function m(e){try{p(e)}catch(e){return e}}function b(e){return"/"+e.trim().split("/").filter((e=>e)).join("/")}function v(e){return new Error("Error parsing address: "+e)}function w(e){return n(e[0])}t.exports={stringToStringTuples:c,stringTuplesToString:u,tuplesToStringTuples:d,stringTuplesToTuples:l,bytesToTuples:p,tuplesToBytes:f,bytesToString:function(e){const t=p(e);return u(d(t))},stringToBytes:g,fromString:function(e){return g(e)},fromBytes:y,validateBytes:m,isValidBytes:function(e){return void 0===m(e)},cleanPath:b,ParseError:v,protoFromTuple:w,sizeForAddr:h}},{"./convert":"gfu3m","./protocols-table":"5Z4cQ",varint:"aN1CO","uint8arrays/concat":"4EBjG","uint8arrays/to-string":"hC8JB"}],gfu3m:[function(e,t,r){"use strict";const i=e("./ip"),n=e("./protocols-table"),{CID:s}=e("multiformats/cid"),{base32:o}=e("multiformats/bases/base32"),{base58btc:a}=e("multiformats/bases/base58"),c=e("multiformats/hashes/digest"),u=e("varint"),{toString:l}=e("uint8arrays/to-string"),{fromString:d}=e("uint8arrays/from-string"),{concat:f}=e("uint8arrays/concat");function h(e,t){return t instanceof Uint8Array?h.toString(e,t):h.toBytes(e,t)}function p(e){if(!i.isIP(e))throw new Error("invalid ip address");return i.toBytes(e)}function g(e){const t=new ArrayBuffer(2);return new DataView(t).setUint16(0,e),new Uint8Array(t)}function y(e){return new DataView(e.buffer).getUint16(e.byteOffset)}function m(e){const t=e.slice(0,e.length-2),r=e.slice(e.length-2);return l(t,"base32")+":"+y(r)}t.exports=h,h.toString=function(e,t){switch(n(e).code){case 4:case 41:return function(e){const t=i.toString(e);if(!t||!i.isIP(t))throw new Error("invalid ip address");return t}(t);case 6:case 273:case 33:case 132:return y(t).toString();case 53:case 54:case 55:case 56:case 400:case 777:return function(e){const t=u.decode(e);if((e=e.slice(u.decode.bytes)).length!==t)throw new Error("inconsistent lengths");return l(e)}(t);case 421:return function(e){const t=u.decode(e),r=e.slice(u.decode.bytes);if(r.length!==t)throw new Error("inconsistent lengths");return l(r,"base58btc")}(t);case 444:case 445:return m(t);default:return l(t,"base16")}},h.toBytes=function(e,t){switch(n(e).code){case 4:case 41:return p(t);case 6:case 273:case 33:case 132:return g(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 777:return function(e){const t=d(e),r=Uint8Array.from(u.encode(t.length));return f([r,t],r.length+t.length)}(t);case 421:return function(e){let t;t="Q"===e[0]||"1"===e[0]?c.decode(a.decode(`z${e}`)).bytes:s.parse(e).multihash.bytes;const r=Uint8Array.from(u.encode(t.length));return f([r,t],r.length+t.length)}(t);case 444:return function(e){const t=e.split(":");if(2!==t.length)throw new Error("failed to parse onion addr: "+t+" does not contain a port number");if(16!==t[0].length)throw new Error("failed to parse onion addr: "+t[0]+" not a Tor onion address.");const r=o.decode("b"+t[0]),i=parseInt(t[1],10);if(i<1||i>65536)throw new Error("Port number is not in range(1, 65536)");const n=g(i);return f([r,n],r.length+n.length)}(t);case 445:return function(e){const t=e.split(":");if(2!==t.length)throw new Error("failed to parse onion addr: "+t+" does not contain a port number");if(56!==t[0].length)throw new Error("failed to parse onion addr: "+t[0]+" not a Tor onion3 address.");const r=o.decode("b"+t[0]),i=parseInt(t[1],10);if(i<1||i>65536)throw new Error("Port number is not in range(1, 65536)");const n=g(i);return f([r,n],r.length+n.length)}(t);default:return d(t,"base16")}}},{"./ip":"dqiuc","./protocols-table":"5Z4cQ","multiformats/cid":"9ooAY","multiformats/bases/base32":"5k9Tu","multiformats/bases/base58":"4n7mA","multiformats/hashes/digest":"kpRBg",varint:"aN1CO","uint8arrays/to-string":"hC8JB","uint8arrays/from-string":"dF7Y4","uint8arrays/concat":"4EBjG"}],dqiuc:[function(e,t,r){"use strict";const i=e("is-ip"),{toString:n}=e("uint8arrays/to-string"),s=i,o=i.v4,a=i.v6,c=function(e,t,r){let i;if(r=~~r,o(e))i=t||new Uint8Array(r+4),e.split(/\./g).map((function(e){i[r++]=255&parseInt(e,10)}));else if(a(e)){const s=e.split(":",8);let a;for(a=0;a0;a--)e.push("0");s.splice.apply(s,e)}for(i=t||new Uint8Array(r+16),a=0;a>8&255,i[r++]=255&e}}if(!i)throw Error("Invalid ip address: "+e);return i};t.exports={isIP:s,isV4:o,isV6:a,toBytes:c,toString:function(e,t,r){t=~~t,r=r||e.length-t;const i=[];let n;const s=new DataView(e.buffer);if(4===r){for(let n=0;ni({exact:!0}).test(e);n.v4=e=>i.v4({exact:!0}).test(e),n.v6=e=>i.v6({exact:!0}).test(e),n.version=e=>n(e)?n.v4(e)?4:6:void 0,t.exports=n},{"ip-regex":"foGrp"}],foGrp:[function(e,t,r){"use strict";const i="[a-fA-F\\d:]",n=e=>e&&e.includeBoundaries?`(?:(?<=\\s|^)(?=${i})|(?<=${i})(?=\\s|$))`:"",s="(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}",o="[a-fA-F\\d]{1,4}",a=`\n(?:\n(?:${o}:){7}(?:${o}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8\n(?:${o}:){6}(?:${s}|:${o}|:)| // 1:2:3:4:5:6:: 1:2:3:4:5:6::8 1:2:3:4:5:6::8 1:2:3:4:5:6::1.2.3.4\n(?:${o}:){5}(?::${s}|(?::${o}){1,2}|:)| // 1:2:3:4:5:: 1:2:3:4:5::7:8 1:2:3:4:5::8 1:2:3:4:5::7:1.2.3.4\n(?:${o}:){4}(?:(?::${o}){0,1}:${s}|(?::${o}){1,3}|:)| // 1:2:3:4:: 1:2:3:4::6:7:8 1:2:3:4::8 1:2:3:4::6:7:1.2.3.4\n(?:${o}:){3}(?:(?::${o}){0,2}:${s}|(?::${o}){1,4}|:)| // 1:2:3:: 1:2:3::5:6:7:8 1:2:3::8 1:2:3::5:6:7:1.2.3.4\n(?:${o}:){2}(?:(?::${o}){0,3}:${s}|(?::${o}){1,5}|:)| // 1:2:: 1:2::4:5:6:7:8 1:2::8 1:2::4:5:6:7:1.2.3.4\n(?:${o}:){1}(?:(?::${o}){0,4}:${s}|(?::${o}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4\n(?::(?:(?::${o}){0,5}:${s}|(?::${o}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4\n)(?:%[0-9a-zA-Z]{1,})? // %eth0 %1\n`.replace(/\s*\/\/.*$/gm,"").replace(/\n/g,"").trim(),c=new RegExp(`(?:^${s}$)|(?:^${a}$)`),u=new RegExp(`^${s}$`),l=new RegExp(`^${a}$`),d=e=>e&&e.exact?c:new RegExp(`(?:${n(e)}${s}${n(e)})|(?:${n(e)}${a}${n(e)})`,"g");d.v4=e=>e&&e.exact?u:new RegExp(`${n(e)}${s}${n(e)}`,"g"),d.v6=e=>e&&e.exact?l:new RegExp(`${n(e)}${a}${n(e)}`,"g"),t.exports=d},{}],hC8JB:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./util/bases.js");r.toString=function(e,t="utf8"){const r=i[t];if(!r)throw new Error(`Unsupported encoding "${t}"`);return r.encoder.encode(e).substring(1)}},{"./util/bases.js":"6UNPX"}],"5Z4cQ":[function(e,t,r){"use strict";function i(e){if("number"==typeof e){if(i.codes[e])return i.codes[e];throw new Error("no protocol with code: "+e)}if("string"==typeof e){if(i.names[e])return i.names[e];throw new Error("no protocol with name: "+e)}throw new Error("invalid protocol id type: "+e)}const n=-1;function s(e,t,r,i,n){return{code:e,size:t,name:r,resolvable:Boolean(i),path:Boolean(n)}}i.lengthPrefixedVarSize=n,i.V=n,i.table=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,n,"ip6zone"],[53,n,"dns","resolvable"],[54,n,"dns4","resolvable"],[55,n,"dns6","resolvable"],[56,n,"dnsaddr","resolvable"],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,n,"unix",!1,"path"],[421,n,"ipfs"],[421,n,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,n,"garlic64"],[460,0,"quic"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,n,"memory"]],i.names={},i.codes={},i.table.map((e=>{const t=s.apply(null,e);return i.codes[t.code]=t,i.names[t.name]=t,null})),i.object=s,t.exports=i},{}],aN1CO:[function(e,t,r){t.exports={encode:e("./encode.js"),decode:e("./decode.js"),encodingLength:e("./length.js")}},{"./encode.js":"j1gSN","./decode.js":"9agvx","./length.js":"3Fbt5"}],j1gSN:[function(e,t,r){t.exports=function e(t,r,n){if(Number.MAX_SAFE_INTEGER&&t>Number.MAX_SAFE_INTEGER)throw e.bytes=0,new RangeError("Could not encode varint");r=r||[];var s=n=n||0;for(;t>=i;)r[n++]=255&t|128,t/=128;for(;-128&t;)r[n++]=255&t|128,t>>>=7;return r[n]=0|t,e.bytes=n-s+1,r};var i=Math.pow(2,31)},{}],"9agvx":[function(e,t,r){t.exports=function e(t,r){var i,n=0,s=0,o=r=r||0,a=t.length;do{if(o>=a||s>49)throw e.bytes=0,new RangeError("Could not decode varint");i=t[o++],n+=s<28?(127&i)<=128);return e.bytes=o-r,n}},{}],"3Fbt5":[function(e,t,r){var i=Math.pow(2,7),n=Math.pow(2,14),s=Math.pow(2,21),o=Math.pow(2,28),a=Math.pow(2,35),c=Math.pow(2,42),u=Math.pow(2,49),l=Math.pow(2,56),d=Math.pow(2,63);t.exports=function(e){return ee+t.length),0));const r=new Uint8Array(t);let i=0;for(const t of e)r.set(t,i),i+=t.length;return r}},{}],eY3cX:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.equals=function(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;rP(R(S,T),S),A=T(),k=P(R(A,E,A),R(E,A),R(A,E),A,E);function I(e){return function(t){if(!i.isMultiaddr(t))try{t=new i(t)}catch(e){return!1}const r=e(t.protoNames());return null!==r&&(!0===r||!1===r?r:0===r.length)}}function R(...e){function t(t){if(t.length(r="function"==typeof e?e().partialMatch(t):e.partialMatch(t),Array.isArray(r)&&(t=r),null===r))),r}return{toString:function(){return"{ "+e.join(" ")+" }"},input:e,matches:I(t),partialMatch:t}}function P(...e){function t(t){let r=null;return e.some((e=>{const i="function"==typeof e?e().partialMatch(t):e.partialMatch(t);return!!i&&(r=i,!0)})),r}return{toString:function(){return"{ "+e.join(" ")+" }"},input:e,matches:I(t),partialMatch:t}}function O(e){const t=e;return{toString:function(){return t},matches:function(e){let r;if("string"==typeof e||e instanceof Uint8Array)try{r=new i(e)}catch(e){return!1}else r=e;const n=r.protoNames();return 1===n.length&&n[0]===t},partialMatch:function(e){return 0===e.length?null:e[0]===t?e.slice(1):null}}}t.exports={DNS:a,DNS4:n,DNS6:s,DNSADDR:o,IP:c,TCP:u,UDP:l,QUIC:f,UTP:d,HTTP:g,HTTPS:y,WebSockets:h,WebSocketsSecure:p,WebSocketStar:b,WebRTCStar:m,WebRTCDirect:v,Reliable:w,Stardust:_,Circuit:A,P2P:k,IPFS:k}},{multiaddr:"8Mu1u"}],"86VPZ":[function(e,t,r){"use strict";const{URLWithLegacySupport:i,format:n,URLSearchParams:s,defaultBase:o}=e("./src/url"),a=e("./src/relative");t.exports={URL:i,URLSearchParams:s,format:n,relative:a,defaultBase:o}},{"./src/url":"86S6m","./src/relative":"ki4KM"}],"86S6m":[function(e,t,r){"use strict";const i="undefined"!=typeof navigator&&"ReactNative"===navigator.product;const n=self.URL,s=i?"http://localhost":self.location?self.location.protocol+"//"+self.location.host:"";t.exports={URLWithLegacySupport:class{constructor(e="",t=s){this.super=new n(e,t),this.path=this.pathname+this.search,this.auth=this.username&&this.password?this.username+":"+this.password:null,this.query=this.search&&this.search.startsWith("?")?this.search.slice(1):null}get hash(){return this.super.hash}get host(){return this.super.host}get hostname(){return this.super.hostname}get href(){return this.super.href}get origin(){return this.super.origin}get password(){return this.super.password}get pathname(){return this.super.pathname}get port(){return this.super.port}get protocol(){return this.super.protocol}get search(){return this.super.search}get searchParams(){return this.super.searchParams}get username(){return this.super.username}set hash(e){this.super.hash=e}set host(e){this.super.host=e}set hostname(e){this.super.hostname=e}set href(e){this.super.href=e}set password(e){this.super.password=e}set pathname(e){this.super.pathname=e}set port(e){this.super.port=e}set protocol(e){this.super.protocol=e}set search(e){this.super.search=e}set username(e){this.super.username=e}static createObjectURL(e){return n.createObjectURL(e)}static revokeObjectURL(e){n.revokeObjectURL(e)}toJSON(){return this.super.toJSON()}toString(){return this.super.toString()}format(){return this.toString()}},URLSearchParams:self.URLSearchParams,defaultBase:s,format:function(e){if("string"==typeof e){return new n(e).toString()}if(!(e instanceof n)){const t=e.username&&e.password?`${e.username}:${e.password}@`:"",r=e.auth?e.auth+"@":"",i=e.port?":"+e.port:"",n=e.protocol?e.protocol+"//":"",s=e.host||"",o=e.hostname||"",a=e.search||(e.query?"?"+e.query:""),c=e.hash||"",u=e.pathname||"";return`${n}${t||r}${s||o+i}${e.path||u+a}${c}`}}}},{}],ki4KM:[function(e,t,r){"use strict";const{URLWithLegacySupport:i,format:n}=e("./url");t.exports=(e,t={},r={},s)=>{let o,a=t.protocol?t.protocol.replace(":",""):"http";a=(r[a]||s||a)+":";try{o=new i(e)}catch(e){o={}}const c=Object.assign({},t,{protocol:a||o.protocol,host:t.host||o.host});return new i(e,n(c)).toString()}},{"./url":"86S6m"}],"9hGOz":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("nanoid"),n=e("uint8arrays/to-string"),s=e("uint8arrays/from-string");const o="/",a=(new TextEncoder).encode(o),c=a[0];class u{constructor(e,t){if("string"==typeof e)this._buf=s.fromString(e);else{if(!(e instanceof Uint8Array))throw new Error("Invalid key, should be String of Uint8Array");this._buf=e}if(null==t&&(t=!0),t&&this.clean(),0===this._buf.byteLength||this._buf[0]!==c)throw new Error("Invalid key")}toString(e="utf8"){return n.toString(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new u(e.join(o))}static random(){return new u(i.nanoid().replace(/-/g,""))}static asKey(e){return e instanceof Uint8Array||"string"==typeof e?new u(e):e.uint8Array?new u(e.uint8Array()):null}clean(){if(this._buf&&0!==this._buf.byteLength||(this._buf=a),this._buf[0]!==c){const e=new Uint8Array(this._buf.byteLength+1);e.fill(c,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===c;)this._buf=this._buf.subarray(0,-1)}less(e){const t=this.list(),r=e.list();for(let e=0;en)return!1}return t.lengthe.namespaces())),[].concat(...t))]);var t}}r.Key=u},{nanoid:"dmVhu","uint8arrays/to-string":"hC8JB","uint8arrays/from-string":"dF7Y4"}],dmVhu:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"nanoid",(()=>c)),i.export(r,"customAlphabet",(()=>a)),i.export(r,"customRandom",(()=>o)),i.export(r,"urlAlphabet",(()=>n.urlAlphabet)),i.export(r,"random",(()=>s));var n=e("./url-alphabet/index.js");let s=e=>crypto.getRandomValues(new Uint8Array(e)),o=(e,t,r)=>{let i=(2<{let s="";for(;;){let o=r(n),a=n;for(;a--;)if(s+=e[o[a]&i]||"",s.length===t)return s}}},a=(e,t)=>o(e,t,s),c=(e=21)=>{let t="",r=crypto.getRandomValues(new Uint8Array(e));for(;e--;){let i=63&r[e];t+=i<36?i.toString(36):i<62?(i-26).toString(36).toUpperCase():i<63?"_":"-"}return t}},{"./url-alphabet/index.js":"lbsD0","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],lbsD0:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"urlAlphabet",(()=>n));let n="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],h08wk:[function(e,t,r){r.interopDefault=function(e){return e&&e.__esModule?e:{default:e}},r.defineInteropFlag=function(e){Object.defineProperty(e,"__esModule",{value:!0})},r.exportAll=function(e,t){return Object.keys(e).forEach((function(r){"default"===r||"__esModule"===r||t.hasOwnProperty(r)||Object.defineProperty(t,r,{enumerable:!0,get:function(){return e[r]}})})),t},r.export=function(e,t,r){Object.defineProperty(e,t,{enumerable:!0,get:r})}},{}],j29MK:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("timeout-abort-controller"),n=e("any-signal"),s=e("parse-duration"),o=e("./errors.js");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var c=a(i),u=a(s);r.withTimeoutOption=function(e,t){return(...r)=>{const i=r[null==t?r.length-1:t];if(!i||!i.timeout)return e(...r);const s="string"==typeof i.timeout?u.default(i.timeout):i.timeout,a=new c.default(s);i.signal=n.anySignal([i.signal,a.signal]);const l=e(...r),d=new Promise(((e,t)=>{a.signal.addEventListener("abort",(()=>{t(new o.TimeoutError)}))})),f=Date.now(),h=()=>{if(a.signal.aborted)throw new o.TimeoutError;if(Date.now()-f>s)throw a.abort(),new o.TimeoutError};return l[Symbol.asyncIterator]?async function*(){const e=l[Symbol.asyncIterator]();try{for(;;){const{value:t,done:r}=await Promise.race([e.next(),d]);if(r)break;h(),yield t}}catch(e){throw h(),e}finally{a.clear(),e.return&&e.return()}}():(async()=>{try{const e=await Promise.race([l,d]);return h(),e}catch(e){throw h(),e}finally{a.clear()}})()}}},{"timeout-abort-controller":"hzClg","any-signal":"kXgRR","parse-duration":"fGYtw","./errors.js":"2ffCq"}],hzClg:[function(e,t,r){"use strict";const{AbortController:i}="undefined"!=typeof self?self:"undefined"!=typeof window?window:e("abort-controller"),n=e("retimer");class s extends i{constructor(e){super(),this._ms=e,this._timer=n((()=>this.abort()),e),Object.setPrototypeOf(this,s.prototype)}abort(){return this._timer.clear(),super.abort()}clear(){this._timer.clear()}reset(){this._timer.clear(),this._timer=n((()=>this.abort()),this._ms)}}t.exports=s,t.exports.TimeoutController=s},{"abort-controller":"lNJ7z",retimer:"gJ6S6"}],lNJ7z:[function(e,t,r){"use strict";const{AbortController:i,AbortSignal:n}="undefined"!=typeof self?self:"undefined"!=typeof window?window:void 0;t.exports=i,t.exports.AbortSignal=n,t.exports.default=i},{}],gJ6S6:[function(e,t,r){"use strict";var i=e("./time");function n(e,t,r){var n=this;this._started=i(),this._rescheduled=0,this._scheduled=t,this._args=r,this._timer=setTimeout((function t(){n._rescheduled>0?(n._scheduled=n._rescheduled-(i()-n._started),n._timer=setTimeout(t,n._scheduled),n._rescheduled=0):e.apply(null,n._args)}),t)}n.prototype.reschedule=function(e){var t=i();return!(t+e-(this._started+this._scheduled)<0)&&(this._started=t,this._rescheduled=e,!0)},n.prototype.clear=function(){clearTimeout(this._timer)},t.exports=function(){if("function"!=typeof arguments[0])throw new Error("callback needed");if("number"!=typeof arguments[1])throw new Error("timeout needed");var e;if(arguments.length>0){e=new Array(arguments.length-2);for(var t=0;t{await Promise.all([t.stop(),r.stop(),s.stop(),i.Service.stop(e),n.close()])}}},{"../utils/service.js":"ethcf"}],"4N8JT":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-config/dns"),n=e("ipfs-core-utils/with-timeout-option");r.createDns=function(){return n.withTimeoutOption((async(e,t={recursive:!0})=>{if("string"!=typeof e)throw new Error("Invalid arguments, domain must be a string");return e=function(e){return e.endsWith(".eth")&&(e=e.replace(/.eth$/,".eth.link")),e}(e),i.resolveDnslink(e,t)}))}},{"ipfs-core-config/dns":"HOLZZ","ipfs-core-utils/with-timeout-option":"j29MK"}],HOLZZ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./utils/tlru.js"),n=e("p-queue"),s=e("ipfs-utils/src/http.js");function o(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=o(n),c=o(s);const u=new i.TLRU(1e3),l=new(a.default.default?a.default.default:a.default)({concurrency:4}),d=e=>{if(e.Path)return e.Path;throw new Error(e.Message)};r.resolveDnslink=async function(e,t){return(async(e,t={})=>{const r=new URLSearchParams(t);r.set("arg",e);const i=r.toString();if(!t.nocache&&u.has(i)){const e=u.get(i);return d(e)}const n=await l.add((async()=>{const e=await c.default.get("https://ipfs.io/api/v0/dns",{searchParams:r}),t=new URL(e.url).search.slice(1),i=await e.json();return u.set(t,i,6e4),i}));return d(n)})(e,t)}},{"./utils/tlru.js":"2qTdj","p-queue":"biPlv","ipfs-utils/src/http.js":"ifXXn"}],"2qTdj":[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("hashlru"));r.TLRU=class{constructor(e){this.lru=n.default(e)}get(e){const t=this.lru.get(e);if(t)return t.expire&&t.expire=e&&(t=0,i=r,r=Object.create(null))}return{has:function(e){return void 0!==r[e]||void 0!==i[e]},remove:function(e){void 0!==r[e]&&(r[e]=void 0),void 0!==i[e]&&(i[e]=void 0)},get:function(e){var t=r[e];return void 0!==t?t:void 0!==(t=i[e])?(n(e,t),t):void 0},set:function(e,t){void 0!==r[e]?r[e]=t:n(e,t)},clear:function(){r=Object.create(null),i=Object.create(null)}}}},{}],biPlv:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("eventemitter3"),n=e("p-timeout"),s=e("./priority-queue"),o=()=>{},a=new n.TimeoutError;r.default=class extends i{constructor(e){var t,r,i,n;if(super(),this._intervalCount=0,this._intervalEnd=0,this._pendingCount=0,this._resolveEmpty=o,this._resolveIdle=o,!("number"==typeof(e=Object.assign({carryoverConcurrencyCount:!1,intervalCap:1/0,interval:0,concurrency:1/0,autoStart:!0,queueClass:s.default},e)).intervalCap&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${null!==(r=null===(t=e.intervalCap)||void 0===t?void 0:t.toString())&&void 0!==r?r:""}\` (${typeof e.intervalCap})`);if(void 0===e.interval||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${null!==(n=null===(i=e.interval)||void 0===i?void 0:i.toString())&&void 0!==n?n:""}\` (${typeof e.interval})`);this._carryoverConcurrencyCount=e.carryoverConcurrencyCount,this._isIntervalIgnored=e.intervalCap===1/0||0===e.interval,this._intervalCap=e.intervalCap,this._interval=e.interval,this._queue=new e.queueClass,this._queueClass=e.queueClass,this.concurrency=e.concurrency,this._timeout=e.timeout,this._throwOnTimeout=!0===e.throwOnTimeout,this._isPaused=!1===e.autoStart}get _doesIntervalAllowAnother(){return this._isIntervalIgnored||this._intervalCount{this._onResumeInterval()}),t)),!0;this._intervalCount=this._carryoverConcurrencyCount?this._pendingCount:0}return!1}_tryToStartAnother(){if(0===this._queue.size)return this._intervalId&&clearInterval(this._intervalId),this._intervalId=void 0,this._resolvePromises(),!1;if(!this._isPaused){const e=!this._isIntervalPaused();if(this._doesIntervalAllowAnother&&this._doesConcurrentAllowAnother){const t=this._queue.dequeue();return!!t&&(this.emit("active"),t(),e&&this._initializeIntervalIfNeeded(),!0)}}return!1}_initializeIntervalIfNeeded(){this._isIntervalIgnored||void 0!==this._intervalId||(this._intervalId=setInterval((()=>{this._onInterval()}),this._interval),this._intervalEnd=Date.now()+this._interval)}_onInterval(){0===this._intervalCount&&0===this._pendingCount&&this._intervalId&&(clearInterval(this._intervalId),this._intervalId=void 0),this._intervalCount=this._carryoverConcurrencyCount?this._pendingCount:0,this._processQueue()}_processQueue(){for(;this._tryToStartAnother(););}get concurrency(){return this._concurrency}set concurrency(e){if(!("number"==typeof e&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this._concurrency=e,this._processQueue()}async add(e,t={}){return new Promise(((r,i)=>{this._queue.enqueue((async()=>{this._pendingCount++,this._intervalCount++;try{const s=void 0===this._timeout&&void 0===t.timeout?e():n.default(Promise.resolve(e()),void 0===t.timeout?this._timeout:t.timeout,(()=>{(void 0===t.throwOnTimeout?this._throwOnTimeout:t.throwOnTimeout)&&i(a)}));r(await s)}catch(e){i(e)}this._next()}),t),this._tryToStartAnother(),this.emit("add")}))}async addAll(e,t){return Promise.all(e.map((async e=>this.add(e,t))))}start(){return this._isPaused?(this._isPaused=!1,this._processQueue(),this):this}pause(){this._isPaused=!0}clear(){this._queue=new this._queueClass}async onEmpty(){if(0!==this._queue.size)return new Promise((e=>{const t=this._resolveEmpty;this._resolveEmpty=()=>{t(),e()}}))}async onIdle(){if(0!==this._pendingCount||0!==this._queue.size)return new Promise((e=>{const t=this._resolveIdle;this._resolveIdle=()=>{t(),e()}}))}get size(){return this._queue.size}sizeBy(e){return this._queue.filter(e).length}get pending(){return this._pendingCount}get isPaused(){return this._isPaused}get timeout(){return this._timeout}set timeout(e){this._timeout=e}}},{eventemitter3:"btRgg","p-timeout":"2SalH","./priority-queue":"hkJNA"}],btRgg:[function(e,t,r){"use strict";var i=Object.prototype.hasOwnProperty,n="~";function s(){}function o(e,t,r){this.fn=e,this.context=t,this.once=r||!1}function a(e,t,r,i,s){if("function"!=typeof r)throw new TypeError("The listener must be a function");var a=new o(r,i||e,s),c=n?n+t:t;return e._events[c]?e._events[c].fn?e._events[c]=[e._events[c],a]:e._events[c].push(a):(e._events[c]=a,e._eventsCount++),e}function c(e,t){0==--e._eventsCount?e._events=new s:delete e._events[t]}function u(){this._events=new s,this._eventsCount=0}Object.create&&(s.prototype=Object.create(null),(new s).__proto__||(n=!1)),u.prototype.eventNames=function(){var e,t,r=[];if(0===this._eventsCount)return r;for(t in e=this._events)i.call(e,t)&&r.push(n?t.slice(1):t);return Object.getOwnPropertySymbols?r.concat(Object.getOwnPropertySymbols(e)):r},u.prototype.listeners=function(e){var t=n?n+e:e,r=this._events[t];if(!r)return[];if(r.fn)return[r.fn];for(var i=0,s=r.length,o=new Array(s);inew Promise(((s,o)=>{if("number"!=typeof t||t<0)throw new TypeError("Expected `milliseconds` to be a positive number");if(t===1/0)return void s(e);const a=setTimeout((()=>{if("function"==typeof r){try{s(r())}catch(e){o(e)}return}const i=r instanceof Error?r:new n("string"==typeof r?r:`Promise timed out after ${t} milliseconds`);"function"==typeof e.cancel&&e.cancel(),o(i)}),t);i(e.then(s,o),(()=>{clearTimeout(a)}))}));t.exports=s,t.exports.default=s,t.exports.TimeoutError=n},{"p-finally":"4tkVQ"}],"4tkVQ":[function(e,t,r){"use strict";t.exports=(e,t)=>(t=t||(()=>{}),e.then((e=>new Promise((e=>{e(t())})).then((()=>e))),(e=>new Promise((e=>{e(t())})).then((()=>{throw e})))))},{}],hkJNA:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./lower-bound");r.default=class{constructor(){this._queue=[]}enqueue(e,t){const r={priority:(t=Object.assign({priority:0},t)).priority,run:e};if(this.size&&this._queue[this.size-1].priority>=t.priority)return void this._queue.push(r);const n=i.default(this._queue,r,((e,t)=>t.priority-e.priority));this._queue.splice(n,0,r)}dequeue(){const e=this._queue.shift();return null==e?void 0:e.run}filter(e){return this._queue.filter((t=>t.priority===e.priority)).map((e=>e.run))}get size(){return this._queue.length}}},{"./lower-bound":"9Swn9"}],"9Swn9":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.default=function(e,t,r){let i=0,n=e.length;for(;n>0;){const s=n/2|0;let o=i+s;r(e[o],t)<=0?(i=++o,n-=s+1):n=s}return i}},{}],ifXXn:[function(e,t,r){"use strict";const{fetch:i,Request:n,Headers:s}=e("./http/fetch"),{TimeoutError:o,HTTPError:a}=e("./http/error"),c=e("merge-options").bind({ignoreUndefined:!0}),{URL:u,URLSearchParams:l}=e("iso-url"),{AbortController:d}=e("native-abort-controller"),f=e("any-signal"),h={throwHttpErrors:!0,credentials:"same-origin"};class p{constructor(e={}){this.opts=c(h,e)}async fetch(e,t={}){const r=c(this.opts,t),h=new s(r.headers);if("string"!=typeof e&&!(e instanceof u||e instanceof n))throw new TypeError("`resource` must be a string, URL, or Request");const p=new u(e.toString(),r.base),{searchParams:m,transformSearchParams:b,json:v}=r;m&&(p.search="function"==typeof b?b(new l(r.searchParams)):new l(r.searchParams)),v&&(r.body=JSON.stringify(r.json),h.set("content-type","application/json"));const w=new d,_=f([w.signal,r.signal]),E=await((e,t,r)=>{if(void 0===t)return e;const i=Date.now(),n=()=>Date.now()-i>=t;return new Promise(((i,s)=>{const a=setTimeout((()=>{n()&&(s(new o),r.abort())}),t),c=e=>t=>{clearTimeout(a),n()?s(new o):e(t)};e.then(c(i),c(s))}))})(i(p.toString(),{...r,signal:_,timeout:void 0,headers:h}),r.timeout,w);if(!E.ok&&r.throwHttpErrors)throw r.handleError&&await r.handleError(E),new a(E);return E.iterator=function(){return y(E.body)},E.ndjson=async function*(){for await(const e of g(E.iterator()))t.transform?yield t.transform(e):yield e},E}post(e,t={}){return this.fetch(e,{...t,method:"POST"})}get(e,t={}){return this.fetch(e,{...t,method:"GET"})}put(e,t={}){return this.fetch(e,{...t,method:"PUT"})}delete(e,t={}){return this.fetch(e,{...t,method:"DELETE"})}options(e,t={}){return this.fetch(e,{...t,method:"OPTIONS"})}}const g=async function*(e){const t=new TextDecoder;let r="";for await(const i of e){r+=t.decode(i,{stream:!0});const e=r.split(/\r?\n/);for(let t=0;t0&&(yield JSON.parse(r))}r=e[e.length-1]}r+=t.decode(),r=r.trim(),0!==r.length&&(yield JSON.parse(r))},y=e=>{if(v(e)){const t=e[Symbol.asyncIterator]();return{[Symbol.asyncIterator]:()=>({next:t.next.bind(t),return:r=>(e.destroy(),"function"==typeof t.return?t.return():Promise.resolve({done:!0,value:r}))})}}if(b(e)){const t=e.getReader();return async function*(){try{for(;;){const{done:e,value:r}=await t.read();if(e)return;r&&(yield r)}}finally{t.releaseLock()}}()}if(m(e))return e;throw new TypeError("Body can't be converted to AsyncIterable")},m=e=>"object"==typeof e&&null!==e&&"function"==typeof e[Symbol.asyncIterator],b=e=>e&&"function"==typeof e.getReader,v=e=>Object.prototype.hasOwnProperty.call(e,"readable")&&Object.prototype.hasOwnProperty.call(e,"writable");p.HTTPError=a,p.TimeoutError=o,p.streamToAsyncIterator=y,p.post=(e,t)=>new p(t).post(e,t),p.get=(e,t)=>new p(t).get(e,t),p.put=(e,t)=>new p(t).put(e,t),p.delete=(e,t)=>new p(t).delete(e,t),p.options=(e,t)=>new p(t).options(e,t),t.exports=p},{"./http/fetch":"8A13C","./http/error":"7OuWB","merge-options":"fupyv","iso-url":"86VPZ","native-abort-controller":"6zwoZ","any-signal":"kXgRR"}],"8A13C":[function(e,t,r){"use strict";const{TimeoutError:i,AbortError:n}=e("./error"),{Response:s,Request:o,Headers:a,default:c}=e("../fetch"),u=c,l=e=>{const t=new a;for(const r of e.trim().split(/[\r\n]+/)){const e=r.indexOf(": ");e>0&&t.set(r.slice(0,e),r.slice(e+1))}return t};class d extends s{constructor(e,t,r){super(t,r),Object.defineProperty(this,"url",{value:e})}}t.exports={fetch:(e,t={})=>null!=t.onUploadProgress?((e,t={})=>{const r=new XMLHttpRequest;r.open(t.method||"GET",e.toString(),!0);const{timeout:o,headers:c}=t;if(o&&o>0&&o<1/0&&(r.timeout=o),null!=t.overrideMimeType&&r.overrideMimeType(t.overrideMimeType),c)for(const[e,t]of new a(c))r.setRequestHeader(e,t);return t.signal&&(t.signal.onabort=()=>r.abort()),t.onUploadProgress&&(r.upload.onprogress=t.onUploadProgress),r.responseType="arraybuffer",new Promise(((e,o)=>{const a=t=>{switch(t.type){case"error":e(s.error());break;case"load":e(new d(r.responseURL,r.response,{status:r.status,statusText:r.statusText,headers:l(r.getAllResponseHeaders())}));break;case"timeout":o(new i);break;case"abort":o(new n)}};r.onerror=a,r.onload=a,r.ontimeout=a,r.onabort=a,r.send(t.body)}))})(e,t):u(e,t),Request:o,Headers:a}},{"./error":"7OuWB","../fetch":"6Y5cD"}],"7OuWB":[function(e,t,r){"use strict";class i extends Error{constructor(e="Request timed out"){super(e),this.name="TimeoutError"}}r.TimeoutError=i;class n extends Error{constructor(e="The operation was aborted."){super(e),this.name="AbortError"}}r.AbortError=n;class s extends Error{constructor(e){super(e.statusText),this.name="HTTPError",this.response=e}}r.HTTPError=s},{}],"6Y5cD":[function(e,t,r){"use strict";const{isElectronMain:i}=e("./env");t.exports=e(i?"electron-fetch":"native-fetch")},{"./env":"flyHr","electron-fetch":"lHksA","native-fetch":"kdks4"}],lHksA:[function(e,t,r){},{}],kdks4:[function(e,t,r){"use strict";globalThis.fetch&&globalThis.Headers&&globalThis.Request&&globalThis.Response?t.exports={default:globalThis.fetch,Headers:globalThis.Headers,Request:globalThis.Request,Response:globalThis.Response}:t.exports={default:e("node-fetch").default,Headers:e("node-fetch").Headers,Request:e("node-fetch").Request,Response:e("node-fetch").Response}},{"node-fetch":"1F7gr"}],"1F7gr":[function(e,t,r){"use strict";var i=function(){if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==i)return i;throw new Error("unable to locate global object")}();t.exports=r=i.fetch,i.fetch&&(r.default=i.fetch.bind(i)),r.Headers=i.Headers,r.Request=i.Request,r.Response=i.Response},{}],"2KSm7":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.createIsOnline=function({network:e}){return()=>{const t=e.try();return null!=t&&Boolean(t.libp2p.isStarted())}}},{}],faFUb:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("is-ipfs"),n=e("multiformats/cid"),s=e("peer-id"),o=e("ipfs-core-utils/with-timeout-option"),a=e("../utils.js");function c(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var u=c(i),l=c(s);r.createResolve=function({repo:e,codecs:t,bases:r,name:i}){return o.withTimeoutOption((async function(s,o={}){if(!u.default.path(s))throw new Error("invalid argument "+s);if(u.default.ipnsPath(s))for await(const e of i.resolve(s,o))s=e;const[,c,d,...f]=s.split("/"),h=o.cidBase?await r.getBase(o.cidBase):void 0,p=function(e){try{return l.default.parse(e).toBytes()}catch{return n.CID.parse(e).bytes}}(d);if(0===f.length){return`/${c}/${h?h.encoder.encode(p):d}`}const g=n.CID.decode(p);s=f.join("/");const y=a.resolve(g,s,t,e,o);let m=g,b=s;for await(const e of y)n.CID.asCID(e.value)&&(m=e.value,b=e.remainderPath);return`/ipfs/${m.toString(h&&h.encoder)}${b?"/"+b:""}`}))}},{"is-ipfs":"40iuV","multiformats/cid":"9ooAY","peer-id":"8Bdb3","ipfs-core-utils/with-timeout-option":"j29MK","../utils.js":"cT4uN"}],"8Bdb3":[function(e,t,r){"use strict";const{CID:i}=e("multiformats/cid"),n=e("multiformats/bases/base32"),s=e("multiformats/bases/base36"),o=e("multiformats/bases/base58"),a=e("multiformats/bases/base64"),{base58btc:c}=e("multiformats/bases/base58"),{base32:u}=e("multiformats/bases/base32"),{base16:l}=e("multiformats/bases/base16"),d=e("multiformats/hashes/digest"),f=e("libp2p-crypto/src/keys"),h=e("class-is"),{PeerIdProto:p}=e("./proto"),{equals:g}=e("uint8arrays/equals"),{fromString:y}=e("uint8arrays/from-string"),{toString:m}=e("uint8arrays/to-string"),{identity:b}=e("multiformats/hashes/identity"),v={...n,...s,...o,...a},w=Object.keys(v).reduce(((e,t)=>e.or(v[t])),u.decoder);const _=h(class{constructor(e,t,r){if(!(e instanceof Uint8Array))throw new Error("invalid id provided");if(t&&r&&!g(t.public.bytes,r.bytes))throw new Error("inconsistent arguments");this._id=e,this._idB58String=c.encode(this.id).substring(1),this._privKey=t,this._pubKey=r}get id(){return this._id}set id(e){throw new Error("Id is immutable")}get privKey(){return this._privKey}set privKey(e){this._privKey=e}get pubKey(){if(this._pubKey)return this._pubKey;if(this._privKey)return this._privKey.public;try{const e=d.decode(this.id);e.code===b.code&&(this._pubKey=f.unmarshalPublicKey(e.digest))}catch(e){}return this._pubKey}set pubKey(e){this._pubKey=e}marshalPubKey(){if(this.pubKey)return f.marshalPublicKey(this.pubKey)}marshalPrivKey(){if(this.privKey)return f.marshalPrivateKey(this.privKey)}marshal(e){return p.encode({id:this.toBytes(),pubKey:this.marshalPubKey(),privKey:e?null:this.marshalPrivKey()}).finish()}toPrint(){let e=this.toB58String();e.startsWith("Qm")&&(e=e.slice(2));let t=6;return e.length"}toJSON(){return{id:this.toB58String(),privKey:A(this.marshalPrivKey()),pubKey:A(this.marshalPubKey())}}toHexString(){return l.encode(this.id).substring(1)}toBytes(){return this.id}toB58String(){return this._idB58String}toString(){if(!this._idCIDString){const e=i.createV1(114,d.decode(this.id));Object.defineProperty(this,"_idCIDString",{value:e.toString(),enumerable:!1})}return this._idCIDString}equals(e){if(e instanceof Uint8Array)return g(this.id,e);if(e.id)return g(this.id,e.id);throw new Error("not valid Id")}isEqual(e){return this.equals(e)}isValid(){return Boolean(this.privKey&&this.privKey.public&&this.privKey.public.bytes&&this.pubKey.bytes instanceof Uint8Array&&g(this.privKey.public.bytes,this.pubKey.bytes))}hasInlinePublicKey(){try{if(d.decode(this.id).code===b.code)return!0}catch(e){}return!1}},{className:"PeerId",symbolName:"@libp2p/js-peer-id/PeerId"});r=t.exports=_;const E=e=>e.bytes.length<=42?d.create(b.code,e.bytes).bytes:e.hash(),S=async(e,t)=>{const r=await E(t);return new _(r,e,t)};r.create=async e=>{(e=e||{}).bits=e.bits||2048,e.keyType=e.keyType||"RSA";const t=await f.generateKeyPair(e.keyType,e.bits);return S(t,t.public)},r.createFromHexString=e=>new _(l.decode("f"+e)),r.createFromBytes=e=>{try{const t=i.decode(e);if(!T(t))throw new Error("Supplied PeerID CID is invalid");return r.createFromCID(t)}catch{if(d.decode(e).code!==b.code)throw new Error("Supplied PeerID CID is invalid");return new _(e)}},r.createFromB58String=e=>r.createFromBytes(c.decode("z"+e));const T=e=>114===e.code||112===e.code;function A(e){if(e)return m(e,"base64pad")}r.createFromCID=e=>{if(!(e=i.asCID(e))||!T(e))throw new Error("Supplied PeerID CID is invalid");return new _(e.multihash.bytes)},r.createFromPubKey=async e=>{let t=e;if("string"==typeof t&&(t=y(e,"base64pad")),!(t instanceof Uint8Array))throw new Error("Supplied key is neither a base64 string nor a Uint8Array");const r=await f.unmarshalPublicKey(t);return S(void 0,r)},r.createFromPrivKey=async e=>{if("string"==typeof e&&(e=y(e,"base64pad")),!(e instanceof Uint8Array))throw new Error("Supplied key is neither a base64 string nor a Uint8Array");const t=await f.unmarshalPrivateKey(e);return S(t,t.public)},r.createFromJSON=async e=>{const t=c.decode("z"+e.id),r=e.privKey&&y(e.privKey,"base64pad"),i=e.pubKey&&y(e.pubKey,"base64pad"),n=i&&await f.unmarshalPublicKey(i);if(!r)return new _(t,void 0,n);const s=await f.unmarshalPrivateKey(r),o=await E(s.public);let a;if(n&&(a=await E(n)),n&&!g(o,a))throw new Error("Public and private key do not match");if(t&&!g(o,t))throw new Error("Id and private key do not match");return new _(t,s,n)},r.createFromProtobuf=async e=>{"string"==typeof e&&(e=y(e,"base16"));let t,r,{id:i,privKey:n,pubKey:s}=p.decode(e);if(n=!!n&&await f.unmarshalPrivateKey(n),s=!!s&&await f.unmarshalPublicKey(s),n&&(r=await E(n.public)),s&&(t=await E(s)),n){if(s&&!g(r,t))throw new Error("Public and private key do not match");return new _(r,n,n.public)}if(s)return new _(t,void 0,s);if(i)return new _(i);throw new Error("Protobuf did not contain any usable key material")},r.parse=e=>("1"!==e.charAt(0)&&"Q"!==e.charAt(0)||(e=`z${e}`),r.createFromBytes(w.decode(e))),r.isPeerId=e=>Boolean("object"==typeof e&&e._id&&e._idB58String)},{"multiformats/cid":"9ooAY","multiformats/bases/base32":"5k9Tu","multiformats/bases/base36":"7VmDr","multiformats/bases/base58":"4n7mA","multiformats/bases/base64":"gaFBW","multiformats/bases/base16":"iQzgO","multiformats/hashes/digest":"kpRBg","libp2p-crypto/src/keys":"kWJWg","class-is":"gx31A","./proto":"c0IJt","uint8arrays/equals":"eY3cX","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB","multiformats/hashes/identity":"eYCZn"}],kWJWg:[function(e,t,r){"use strict";const i=e("./keys");e("node-forge/lib/asn1"),e("node-forge/lib/pbe");const n=e("node-forge/lib/forge"),s=e("err-code"),{fromString:o}=e("uint8arrays/from-string"),a=e("./importer"),c={rsa:e("./rsa-class"),ed25519:e("./ed25519-class"),secp256k1:e("./secp256k1-class")(i,e("../random-bytes"))},u="secp256k1 support requires libp2p-crypto-secp256k1 package",l="ERR_MISSING_PACKAGE";function d(e){const t=c[e.toLowerCase()];if(!t){const t=Object.keys(c).join(" / ");throw s(new Error(`invalid or unsupported key type ${e}. Must be ${t}`),"ERR_UNSUPPORTED_KEY_TYPE")}return t}const f=async e=>{const t=i.PrivateKey.decode(e),r=t.Data;switch(t.Type){case i.KeyType.RSA:return c.rsa.unmarshalRsaPrivateKey(r);case i.KeyType.Ed25519:return c.ed25519.unmarshalEd25519PrivateKey(r);case i.KeyType.Secp256k1:if(c.secp256k1)return c.secp256k1.unmarshalSecp256k1PrivateKey(r);throw s(new Error(u),l);default:d(t.Type)}};t.exports={supportedKeys:c,keysPBM:i,keyStretcher:e("./key-stretcher"),generateEphemeralKeyPair:e("./ephemeral-keys"),generateKeyPair:async(e,t)=>d(e).generateKeyPair(t),generateKeyPairFromSeed:async(e,t,r)=>{const i=d(e);if("ed25519"!==e.toLowerCase())throw s(new Error("Seed key derivation is unimplemented for RSA or secp256k1"),"ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return i.generateKeyPairFromSeed(t,r)},unmarshalPublicKey:e=>{const t=i.PublicKey.decode(e),r=t.Data;switch(t.Type){case i.KeyType.RSA:return c.rsa.unmarshalRsaPublicKey(r);case i.KeyType.Ed25519:return c.ed25519.unmarshalEd25519PublicKey(r);case i.KeyType.Secp256k1:if(c.secp256k1)return c.secp256k1.unmarshalSecp256k1PublicKey(r);throw s(new Error(u),l);default:d(t.Type)}},marshalPublicKey:(e,t)=>(d(t=(t||"rsa").toLowerCase()),e.bytes),unmarshalPrivateKey:f,marshalPrivateKey:(e,t)=>(d(t=(t||"rsa").toLowerCase()),e.bytes),import:async(e,t)=>{try{const r=await a.import(e,t);return f(r)}catch(e){}const r=n.pki.decryptRsaPrivateKey(e,t);if(null===r)throw s(new Error("Cannot read the key, most likely the password is wrong or not a RSA key"),"ERR_CANNOT_DECRYPT_PEM");let i=n.asn1.toDer(n.pki.privateKeyToAsn1(r));return i=o(i.getBytes(),"ascii"),c.rsa.unmarshalRsaPrivateKey(i)}}},{"./keys":"jWSTZ","node-forge/lib/asn1":"bcsXQ","node-forge/lib/pbe":"gUP8s","node-forge/lib/forge":"4OuPD","err-code":"chZjB","uint8arrays/from-string":"dF7Y4","./importer":"jyqjk","./rsa-class":"1sbpX","./ed25519-class":"dh3ng","./secp256k1-class":"jXCAP","../random-bytes":"gsnuW","./key-stretcher":"kdBuU","./ephemeral-keys":"ds3K5"}],jWSTZ:[function(e,t,r){"use strict";var i,n,s=e("protobufjs/minimal"),o=s.Reader,a=s.Writer,c=s.util,u=s.roots["libp2p-crypto-keys"]||(s.roots["libp2p-crypto-keys"]={});u.KeyType=(i={},(n=Object.create(i))[i[0]="RSA"]=0,n[i[1]="Ed25519"]=1,n[i[2]="Secp256k1"]=2,n),u.PublicKey=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.Type=e.int32();break;case 2:i.Data=e.bytes();break;default:e.skipType(7&n)}}if(!i.hasOwnProperty("Type"))throw c.ProtocolError("missing required 'Type'",{instance:i});if(!i.hasOwnProperty("Data"))throw c.ProtocolError("missing required 'Data'",{instance:i});return i},e.fromObject=function(e){if(e instanceof u.PublicKey)return e;var t=new u.PublicKey;switch(e.Type){case"RSA":case 0:t.Type=0;break;case"Ed25519":case 1:t.Type=1;break;case"Secp256k1":case 2:t.Type=2}return null!=e.Data&&("string"==typeof e.Data?c.base64.decode(e.Data,t.Data=c.newBuffer(c.base64.length(e.Data)),0):e.Data.length&&(t.Data=e.Data)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(r.Type=t.enums===String?"RSA":0,t.bytes===String?r.Data="":(r.Data=[],t.bytes!==Array&&(r.Data=c.newBuffer(r.Data)))),null!=e.Type&&e.hasOwnProperty("Type")&&(r.Type=t.enums===String?u.KeyType[e.Type]:e.Type),null!=e.Data&&e.hasOwnProperty("Data")&&(r.Data=t.bytes===String?c.base64.encode(e.Data,0,e.Data.length):t.bytes===Array?Array.prototype.slice.call(e.Data):e.Data),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,s.util.toJSONOptions)},e}(),u.PrivateKey=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.Type=e.int32();break;case 2:i.Data=e.bytes();break;default:e.skipType(7&n)}}if(!i.hasOwnProperty("Type"))throw c.ProtocolError("missing required 'Type'",{instance:i});if(!i.hasOwnProperty("Data"))throw c.ProtocolError("missing required 'Data'",{instance:i});return i},e.fromObject=function(e){if(e instanceof u.PrivateKey)return e;var t=new u.PrivateKey;switch(e.Type){case"RSA":case 0:t.Type=0;break;case"Ed25519":case 1:t.Type=1;break;case"Secp256k1":case 2:t.Type=2}return null!=e.Data&&("string"==typeof e.Data?c.base64.decode(e.Data,t.Data=c.newBuffer(c.base64.length(e.Data)),0):e.Data.length&&(t.Data=e.Data)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(r.Type=t.enums===String?"RSA":0,t.bytes===String?r.Data="":(r.Data=[],t.bytes!==Array&&(r.Data=c.newBuffer(r.Data)))),null!=e.Type&&e.hasOwnProperty("Type")&&(r.Type=t.enums===String?u.KeyType[e.Type]:e.Type),null!=e.Data&&e.hasOwnProperty("Data")&&(r.Data=t.bytes===String?c.base64.encode(e.Data,0,e.Data.length):t.bytes===Array?Array.prototype.slice.call(e.Data):e.Data),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,s.util.toJSONOptions)},e}(),t.exports=u},{"protobufjs/minimal":"grAXL"}],bcsXQ:[function(e,t,r){var i=e("./forge");e("./util"),e("./oids");var n=t.exports=i.asn1=i.asn1||{};function s(e,t,r){if(r>t){var i=new Error("Too few bytes to parse DER.");throw i.available=e.length(),i.remaining=t,i.requested=r,i}}n.Class={UNIVERSAL:0,APPLICATION:64,CONTEXT_SPECIFIC:128,PRIVATE:192},n.Type={NONE:0,BOOLEAN:1,INTEGER:2,BITSTRING:3,OCTETSTRING:4,NULL:5,OID:6,ODESC:7,EXTERNAL:8,REAL:9,ENUMERATED:10,EMBEDDED:11,UTF8:12,ROID:13,SEQUENCE:16,SET:17,PRINTABLESTRING:19,IA5STRING:22,UTCTIME:23,GENERALIZEDTIME:24,BMPSTRING:30},n.create=function(e,t,r,s,o){if(i.util.isArray(s)){for(var a=[],c=0;ct){if(i.strict){var p=new Error("Too few bytes to read ASN.1 value.");throw p.available=e.length(),p.remaining=t,p.requested=h,p}h=t}var g=32==(32&c);if(g)if(d=[],void 0===h)for(;;){if(s(e,t,2),e.bytes(2)===String.fromCharCode(0,0)){e.getBytes(2),t-=2;break}a=e.length(),d.push(o(e,t,r+1,i)),t-=a-e.length()}else for(;h>0;)a=e.length(),d.push(o(e,h,r+1,i)),t-=a-e.length(),h-=a-e.length();if(void 0===d&&u===n.Class.UNIVERSAL&&l===n.Type.BITSTRING&&(f=e.bytes(h)),void 0===d&&i.decodeBitStrings&&u===n.Class.UNIVERSAL&&l===n.Type.BITSTRING&&h>1){var y=e.read,m=t,b=0;if(l===n.Type.BITSTRING&&(s(e,t,1),b=e.getByte(),t--),0===b)try{a=e.length();var v=o(e,t,r+1,{verbose:i.verbose,strict:!0,decodeBitStrings:!0}),w=a-e.length();t-=w,l==n.Type.BITSTRING&&w++;var _=v.tagClass;w!==h||_!==n.Class.UNIVERSAL&&_!==n.Class.CONTEXT_SPECIFIC||(d=[v])}catch(e){}void 0===d&&(e.read=y,t=m)}if(void 0===d){if(void 0===h){if(i.strict)throw new Error("Non-constructed ASN.1 object of indefinite length.");h=t}if(l===n.Type.BMPSTRING)for(d="";h>0;h-=2)s(e,t,2),d+=String.fromCharCode(e.getInt16()),t-=2;else d=e.getBytes(h)}var E=void 0===f?null:{bitStringContents:f};return n.create(u,l,g,d,E)}n.fromDer=function(e,t){return void 0===t&&(t={strict:!0,decodeBitStrings:!0}),"boolean"==typeof t&&(t={strict:t,decodeBitStrings:!0}),"strict"in t||(t.strict=!0),"decodeBitStrings"in t||(t.decodeBitStrings=!0),"string"==typeof e&&(e=i.util.createBuffer(e)),o(e,e.length(),0,t)},n.toDer=function(e){var t=i.util.createBuffer(),r=e.tagClass|e.type,s=i.util.createBuffer(),o=!1;if("bitStringContents"in e&&(o=!0,e.original&&(o=n.equals(e,e.original))),o)s.putBytes(e.bitStringContents);else if(e.composed){e.constructed?r|=32:s.putByte(0);for(var a=0;a1&&(0===e.value.charCodeAt(0)&&0==(128&e.value.charCodeAt(1))||255===e.value.charCodeAt(0)&&128==(128&e.value.charCodeAt(1)))?s.putBytes(e.value.substr(1)):s.putBytes(e.value);if(t.putByte(r),s.length()<=127)t.putByte(127&s.length());else{var c=s.length(),u="";do{u+=String.fromCharCode(255&c),c>>>=8}while(c>0);t.putByte(128|u.length);for(a=u.length-1;a>=0;--a)t.putByte(u.charCodeAt(a))}return t.putBuffer(s),t},n.oidToDer=function(e){var t,r,n,s,o=e.split("."),a=i.util.createBuffer();a.putByte(40*parseInt(o[0],10)+parseInt(o[1],10));for(var c=2;c>>=7,t||(s|=128),r.push(s),t=!1}while(n>0);for(var u=r.length-1;u>=0;--u)a.putByte(r[u])}return a},n.derToOid=function(e){var t;"string"==typeof e&&(e=i.util.createBuffer(e));var r=e.getByte();t=Math.floor(r/40)+"."+r%40;for(var n=0;e.length()>0;)n<<=7,128&(r=e.getByte())?n+=127&r:(t+="."+(n+r),n=0);return t},n.utcTimeToDate=function(e){var t=new Date,r=parseInt(e.substr(0,2),10);r=r>=50?1900+r:2e3+r;var i=parseInt(e.substr(2,2),10)-1,n=parseInt(e.substr(4,2),10),s=parseInt(e.substr(6,2),10),o=parseInt(e.substr(8,2),10),a=0;if(e.length>11){var c=e.charAt(10),u=10;"+"!==c&&"-"!==c&&(a=parseInt(e.substr(10,2),10),u+=2)}if(t.setUTCFullYear(r,i,n),t.setUTCHours(s,o,a,0),u&&("+"===(c=e.charAt(u))||"-"===c)){var l=60*parseInt(e.substr(u+1,2),10)+parseInt(e.substr(u+4,2),10);l*=6e4,"+"===c?t.setTime(+t-l):t.setTime(+t+l)}return t},n.generalizedTimeToDate=function(e){var t=new Date,r=parseInt(e.substr(0,4),10),i=parseInt(e.substr(4,2),10)-1,n=parseInt(e.substr(6,2),10),s=parseInt(e.substr(8,2),10),o=parseInt(e.substr(10,2),10),a=parseInt(e.substr(12,2),10),c=0,u=0,l=!1;"Z"===e.charAt(e.length-1)&&(l=!0);var d=e.length-5,f=e.charAt(d);"+"!==f&&"-"!==f||(u=60*parseInt(e.substr(d+1,2),10)+parseInt(e.substr(d+4,2),10),u*=6e4,"+"===f&&(u*=-1),l=!0);return"."===e.charAt(14)&&(c=1e3*parseFloat(e.substr(14),10)),l?(t.setUTCFullYear(r,i,n),t.setUTCHours(s,o,a,c),t.setTime(+t+u)):(t.setFullYear(r,i,n),t.setHours(s,o,a,c)),t},n.dateToUtcTime=function(e){if("string"==typeof e)return e;var t="",r=[];r.push((""+e.getUTCFullYear()).substr(2)),r.push(""+(e.getUTCMonth()+1)),r.push(""+e.getUTCDate()),r.push(""+e.getUTCHours()),r.push(""+e.getUTCMinutes()),r.push(""+e.getUTCSeconds());for(var i=0;i=-128&&e<128)return t.putSignedInt(e,8);if(e>=-32768&&e<32768)return t.putSignedInt(e,16);if(e>=-8388608&&e<8388608)return t.putSignedInt(e,24);if(e>=-2147483648&&e<2147483648)return t.putSignedInt(e,32);var r=new Error("Integer too large; max is 32-bits.");throw r.integer=e,r},n.derToInteger=function(e){"string"==typeof e&&(e=i.util.createBuffer(e));var t=8*e.length();if(t>32)throw new Error("Integer too large; max is 32-bits.");return e.getSignedInt(t)},n.validate=function(e,t,r,s){var o=!1;if(e.tagClass!==t.tagClass&&void 0!==t.tagClass||e.type!==t.type&&void 0!==t.type)s&&(e.tagClass!==t.tagClass&&s.push("["+t.name+'] Expected tag class "'+t.tagClass+'", got "'+e.tagClass+'"'),e.type!==t.type&&s.push("["+t.name+'] Expected type "'+t.type+'", got "'+e.type+'"'));else if(e.constructed===t.constructed||void 0===t.constructed){if(o=!0,t.value&&i.util.isArray(t.value))for(var a=0,c=0;o&&c0&&(s+="\n");for(var o="",c=0;c1?s+="0x"+i.util.bytesToHex(e.value.slice(1)):s+="(none)",e.value.length>0){var f=e.value.charCodeAt(0);1==f?s+=" (1 unused bit shown)":f>1&&(s+=" ("+f+" unused bits shown)")}}else e.type===n.Type.OCTETSTRING?(a.test(e.value)||(s+="("+e.value+") "),s+="0x"+i.util.bytesToHex(e.value)):e.type===n.Type.UTF8?s+=i.util.decodeUtf8(e.value):e.type===n.Type.PRINTABLESTRING||e.type===n.Type.IA5String?s+=e.value:a.test(e.value)?s+="0x"+i.util.bytesToHex(e.value):0===e.value.length?s+="[null]":s+=e.value}return s}},{"./forge":"4OuPD","./util":"df43p","./oids":"7VPL4"}],"4OuPD":[function(e,t,r){t.exports={options:{usePureJavaScript:!1}}},{}],df43p:[function(e,t,r){var i=arguments[3],n=e("process"),s=e("buffer").Buffer,o=e("./forge"),a=e("./baseN"),c=t.exports=o.util=o.util||{};function u(e){if(8!==e&&16!==e&&24!==e&&32!==e)throw new Error("Only 8, 16, 24, or 32 bits supported: "+e)}function l(e){if(this.data="",this.read=0,"string"==typeof e)this.data=e;else if(c.isArrayBuffer(e)||c.isArrayBufferView(e))if(void 0!==s&&e instanceof s)this.data=e.toString("binary");else{var t=new Uint8Array(e);try{this.data=String.fromCharCode.apply(null,t)}catch(e){for(var r=0;r15?(r=Date.now(),o(e)):(t.push(e),1===t.length&&s.setAttribute("a",i=!i))}}c.nextTick=c.setImmediate}(),c.isNodejs=void 0!==n&&n.versions&&n.versions.node,c.globalScope=c.isNodejs?i:"undefined"==typeof self?window:self,c.isArray=Array.isArray||function(e){return"[object Array]"===Object.prototype.toString.call(e)},c.isArrayBuffer=function(e){return"undefined"!=typeof ArrayBuffer&&e instanceof ArrayBuffer},c.isArrayBufferView=function(e){return e&&c.isArrayBuffer(e.buffer)&&void 0!==e.byteLength},c.ByteBuffer=l,c.ByteStringBuffer=l;var d=4096;function f(e,t){t=t||{},this.read=t.readOffset||0,this.growSize=t.growSize||1024;var r=c.isArrayBuffer(e),i=c.isArrayBufferView(e);if(r||i)return this.data=r?new DataView(e):new DataView(e.buffer,e.byteOffset,e.byteLength),void(this.write="writeOffset"in t?t.writeOffset:this.data.byteLength);this.data=new DataView(new ArrayBuffer(0)),this.write=0,null!=e&&this.putBytes(e),"writeOffset"in t&&(this.write=t.writeOffset)}c.ByteStringBuffer.prototype._optimizeConstructedString=function(e){this._constructedStringLength+=e,this._constructedStringLength>d&&(this.data.substr(0,1),this._constructedStringLength=0)},c.ByteStringBuffer.prototype.length=function(){return this.data.length-this.read},c.ByteStringBuffer.prototype.isEmpty=function(){return this.length()<=0},c.ByteStringBuffer.prototype.putByte=function(e){return this.putBytes(String.fromCharCode(e))},c.ByteStringBuffer.prototype.fillWithByte=function(e,t){e=String.fromCharCode(e);for(var r=this.data;t>0;)1&t&&(r+=e),(t>>>=1)>0&&(e+=e);return this.data=r,this._optimizeConstructedString(t),this},c.ByteStringBuffer.prototype.putBytes=function(e){return this.data+=e,this._optimizeConstructedString(e.length),this},c.ByteStringBuffer.prototype.putString=function(e){return this.putBytes(c.encodeUtf8(e))},c.ByteStringBuffer.prototype.putInt16=function(e){return this.putBytes(String.fromCharCode(e>>8&255)+String.fromCharCode(255&e))},c.ByteStringBuffer.prototype.putInt24=function(e){return this.putBytes(String.fromCharCode(e>>16&255)+String.fromCharCode(e>>8&255)+String.fromCharCode(255&e))},c.ByteStringBuffer.prototype.putInt32=function(e){return this.putBytes(String.fromCharCode(e>>24&255)+String.fromCharCode(e>>16&255)+String.fromCharCode(e>>8&255)+String.fromCharCode(255&e))},c.ByteStringBuffer.prototype.putInt16Le=function(e){return this.putBytes(String.fromCharCode(255&e)+String.fromCharCode(e>>8&255))},c.ByteStringBuffer.prototype.putInt24Le=function(e){return this.putBytes(String.fromCharCode(255&e)+String.fromCharCode(e>>8&255)+String.fromCharCode(e>>16&255))},c.ByteStringBuffer.prototype.putInt32Le=function(e){return this.putBytes(String.fromCharCode(255&e)+String.fromCharCode(e>>8&255)+String.fromCharCode(e>>16&255)+String.fromCharCode(e>>24&255))},c.ByteStringBuffer.prototype.putInt=function(e,t){u(t);var r="";do{t-=8,r+=String.fromCharCode(e>>t&255)}while(t>0);return this.putBytes(r)},c.ByteStringBuffer.prototype.putSignedInt=function(e,t){return e<0&&(e+=2<0);return t},c.ByteStringBuffer.prototype.getSignedInt=function(e){var t=this.getInt(e),r=2<=r&&(t-=r<<1),t},c.ByteStringBuffer.prototype.getBytes=function(e){var t;return e?(e=Math.min(this.length(),e),t=this.data.slice(this.read,this.read+e),this.read+=e):0===e?t="":(t=0===this.read?this.data:this.data.slice(this.read),this.clear()),t},c.ByteStringBuffer.prototype.bytes=function(e){return void 0===e?this.data.slice(this.read):this.data.slice(this.read,this.read+e)},c.ByteStringBuffer.prototype.at=function(e){return this.data.charCodeAt(this.read+e)},c.ByteStringBuffer.prototype.setAt=function(e,t){return this.data=this.data.substr(0,this.read+e)+String.fromCharCode(t)+this.data.substr(this.read+e+1),this},c.ByteStringBuffer.prototype.last=function(){return this.data.charCodeAt(this.data.length-1)},c.ByteStringBuffer.prototype.copy=function(){var e=c.createBuffer(this.data);return e.read=this.read,e},c.ByteStringBuffer.prototype.compact=function(){return this.read>0&&(this.data=this.data.slice(this.read),this.read=0),this},c.ByteStringBuffer.prototype.clear=function(){return this.data="",this.read=0,this},c.ByteStringBuffer.prototype.truncate=function(e){var t=Math.max(0,this.length()-e);return this.data=this.data.substr(this.read,t),this.read=0,this},c.ByteStringBuffer.prototype.toHex=function(){for(var e="",t=this.read;t=e)return this;t=Math.max(t||this.growSize,e);var r=new Uint8Array(this.data.buffer,this.data.byteOffset,this.data.byteLength),i=new Uint8Array(this.length()+t);return i.set(r),this.data=new DataView(i.buffer),this},c.DataBuffer.prototype.putByte=function(e){return this.accommodate(1),this.data.setUint8(this.write++,e),this},c.DataBuffer.prototype.fillWithByte=function(e,t){this.accommodate(t);for(var r=0;r>8&65535),this.data.setInt8(this.write,e>>16&255),this.write+=3,this},c.DataBuffer.prototype.putInt32=function(e){return this.accommodate(4),this.data.setInt32(this.write,e),this.write+=4,this},c.DataBuffer.prototype.putInt16Le=function(e){return this.accommodate(2),this.data.setInt16(this.write,e,!0),this.write+=2,this},c.DataBuffer.prototype.putInt24Le=function(e){return this.accommodate(3),this.data.setInt8(this.write,e>>16&255),this.data.setInt16(this.write,e>>8&65535,!0),this.write+=3,this},c.DataBuffer.prototype.putInt32Le=function(e){return this.accommodate(4),this.data.setInt32(this.write,e,!0),this.write+=4,this},c.DataBuffer.prototype.putInt=function(e,t){u(t),this.accommodate(t/8);do{t-=8,this.data.setInt8(this.write++,e>>t&255)}while(t>0);return this},c.DataBuffer.prototype.putSignedInt=function(e,t){return u(t),this.accommodate(t/8),e<0&&(e+=2<0);return t},c.DataBuffer.prototype.getSignedInt=function(e){var t=this.getInt(e),r=2<=r&&(t-=r<<1),t},c.DataBuffer.prototype.getBytes=function(e){var t;return e?(e=Math.min(this.length(),e),t=this.data.slice(this.read,this.read+e),this.read+=e):0===e?t="":(t=0===this.read?this.data:this.data.slice(this.read),this.clear()),t},c.DataBuffer.prototype.bytes=function(e){return void 0===e?this.data.slice(this.read):this.data.slice(this.read,this.read+e)},c.DataBuffer.prototype.at=function(e){return this.data.getUint8(this.read+e)},c.DataBuffer.prototype.setAt=function(e,t){return this.data.setUint8(e,t),this},c.DataBuffer.prototype.last=function(){return this.data.getUint8(this.write-1)},c.DataBuffer.prototype.copy=function(){return new c.DataBuffer(this)},c.DataBuffer.prototype.compact=function(){if(this.read>0){var e=new Uint8Array(this.data.buffer,this.read),t=new Uint8Array(e.byteLength);t.set(e),this.data=new DataView(t),this.write-=this.read,this.read=0}return this},c.DataBuffer.prototype.clear=function(){return this.data=new DataView(new ArrayBuffer(0)),this.read=this.write=0,this},c.DataBuffer.prototype.truncate=function(e){return this.write=Math.max(0,this.length()-e),this.read=Math.min(this.read,this.write),this},c.DataBuffer.prototype.toHex=function(){for(var e="",t=this.read;t0;)1&t&&(r+=e),(t>>>=1)>0&&(e+=e);return r},c.xorBytes=function(e,t,r){for(var i="",n="",s="",o=0,a=0;r>0;--r,++o)n=e.charCodeAt(o)^t.charCodeAt(o),a>=10&&(i+=s,s="",a=0),s+=String.fromCharCode(n),++a;return i+=s},c.hexToBytes=function(e){var t="",r=0;for(!0&e.length&&(r=1,t+=String.fromCharCode(parseInt(e[0],16)));r>24&255)+String.fromCharCode(e>>16&255)+String.fromCharCode(e>>8&255)+String.fromCharCode(255&e)};var h="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",p=[62,-1,-1,-1,63,52,53,54,55,56,57,58,59,60,61,-1,-1,-1,64,-1,-1,-1,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,-1,-1,-1,-1,-1,-1,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51],g="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz";c.encode64=function(e,t){for(var r,i,n,s="",o="",a=0;a>2),s+=h.charAt((3&r)<<4|i>>4),isNaN(i)?s+="==":(s+=h.charAt((15&i)<<2|n>>6),s+=isNaN(n)?"=":h.charAt(63&n)),t&&s.length>t&&(o+=s.substr(0,t)+"\r\n",s=s.substr(t));return o+=s},c.decode64=function(e){e=e.replace(/[^A-Za-z0-9\+\/\=]/g,"");for(var t,r,i,n,s="",o=0;o>4),64!==i&&(s+=String.fromCharCode((15&r)<<4|i>>2),64!==n&&(s+=String.fromCharCode((3&i)<<6|n)));return s},c.encodeUtf8=function(e){return unescape(encodeURIComponent(e))},c.decodeUtf8=function(e){return decodeURIComponent(escape(e))},c.binary={raw:{},hex:{},base64:{},base58:{},baseN:{encode:a.encode,decode:a.decode}},c.binary.raw.encode=function(e){return String.fromCharCode.apply(null,e)},c.binary.raw.decode=function(e,t,r){var i=t;i||(i=new Uint8Array(e.length));for(var n=r=r||0,s=0;s>2),s+=h.charAt((3&r)<<4|i>>4),isNaN(i)?s+="==":(s+=h.charAt((15&i)<<2|n>>6),s+=isNaN(n)?"=":h.charAt(63&n)),t&&s.length>t&&(o+=s.substr(0,t)+"\r\n",s=s.substr(t));return o+=s},c.binary.base64.decode=function(e,t,r){var i,n,s,o,a=t;a||(a=new Uint8Array(3*Math.ceil(e.length/4))),e=e.replace(/[^A-Za-z0-9\+\/\=]/g,"");for(var c=0,u=r=r||0;c>4,64!==s&&(a[u++]=(15&n)<<4|s>>2,64!==o&&(a[u++]=(3&s)<<6|o));return t?u-r:a.subarray(0,u)},c.binary.base58.encode=function(e,t){return c.binary.baseN.encode(e,g,t)},c.binary.base58.decode=function(e,t){return c.binary.baseN.decode(e,g,t)},c.text={utf8:{},utf16:{}},c.text.utf8.encode=function(e,t,r){e=c.encodeUtf8(e);var i=t;i||(i=new Uint8Array(e.length));for(var n=r=r||0,s=0;s0?(n=r[i].substring(0,o),s=r[i].substring(o+1)):(n=r[i],s=null),n in t||(t[n]=[]),n in Object.prototype||null===s||t[n].push(unescape(s))}return t};return void 0===e?(null===S&&(S="undefined"!=typeof window&&window.location&&window.location.search?r(window.location.search.substring(1)):{}),t=S):t=r(e),t},c.parseFragment=function(e){var t=e,r="",i=e.indexOf("?");i>0&&(t=e.substring(0,i),r=e.substring(i+1));var n=t.split("/");return n.length>0&&""===n[0]&&n.shift(),{pathString:t,queryString:r,path:n,query:""===r?{}:c.getQueryVariables(r)}},c.makeRequest=function(e){var t=c.parseFragment(e),r={path:t.pathString,query:t.queryString,getPath:function(e){return void 0===e?t.path:t.path[e]},getQuery:function(e,r){var i;return void 0===e?i=t.query:(i=t.query[e])&&void 0!==r&&(i=i[r]),i},getQueryLast:function(e,t){var i=r.getQuery(e);return i?i[i.length-1]:t}};return r},c.makeLink=function(e,t,r){e=jQuery.isArray(e)?e.join("/"):e;var i=jQuery.param(t||{});return r=r||"",e+(i.length>0?"?"+i:"")+(r.length>0?"#"+r:"")},c.isEmpty=function(e){for(var t in e)if(e.hasOwnProperty(t))return!1;return!0},c.format=function(e){for(var t,r,i=/%./g,n=0,s=[],o=0;t=i.exec(e);){(r=e.substring(o,i.lastIndex-2)).length>0&&s.push(r),o=i.lastIndex;var a=t[0][1];switch(a){case"s":case"o":n");break;case"%":s.push("%");break;default:s.push("<%"+a+"?>")}}return s.push(e.substring(o)),s.join("")},c.formatNumber=function(e,t,r,i){var n=e,s=isNaN(t=Math.abs(t))?2:t,o=void 0===r?",":r,a=void 0===i?".":i,c=n<0?"-":"",u=parseInt(n=Math.abs(+n||0).toFixed(s),10)+"",l=u.length>3?u.length%3:0;return c+(l?u.substr(0,l)+a:"")+u.substr(l).replace(/(\d{3})(?=\d)/g,"$1"+a)+(s?o+Math.abs(n-u).toFixed(s).slice(2):"")},c.formatSize=function(e){return e=e>=1073741824?c.formatNumber(e/1073741824,2,".","")+" GiB":e>=1048576?c.formatNumber(e/1048576,2,".","")+" MiB":e>=1024?c.formatNumber(e/1024,0)+" KiB":c.formatNumber(e,0)+" bytes"},c.bytesFromIP=function(e){return-1!==e.indexOf(".")?c.bytesFromIPv4(e):-1!==e.indexOf(":")?c.bytesFromIPv6(e):null},c.bytesFromIPv4=function(e){if(4!==(e=e.split(".")).length)return null;for(var t=c.createBuffer(),r=0;rr[i].end-r[i].start&&(i=r.length-1)):r.push({start:a,end:a})}t.push(s)}if(r.length>0){var u=r[i];u.end-u.start>0&&(t.splice(u.start,u.end-u.start+1,""),0===u.start&&t.unshift(""),7===u.end&&t.push(""))}return t.join(":")},c.estimateCores=function(e,t){if("function"==typeof e&&(t=e,e={}),e=e||{},"cores"in c&&!e.update)return t(null,c.cores);if("undefined"!=typeof navigator&&"hardwareConcurrency"in navigator&&navigator.hardwareConcurrency>0)return c.cores=navigator.hardwareConcurrency,t(null,c.cores);if("undefined"==typeof Worker)return c.cores=1,t(null,c.cores);if("undefined"==typeof Blob)return c.cores=2,t(null,c.cores);var r=URL.createObjectURL(new Blob(["(",function(){self.addEventListener("message",(function(e){for(var t=Date.now(),r=t+4;Date.now()a.st&&n.stn.st&&a.st0;)a.push(u%s),u=u/s|0}for(n=0;0===e[n]&&n=0;--n)i+=t[a[n]]}else i=function(e,t){var r=0,i=t.length,n=t.charAt(0),s=[0];for(r=0;r0;)s.push(a%i),a=a/i|0}var c="";for(r=0;0===e.at(r)&&r=0;--r)c+=t[s[r]];return c}(e,t);if(r){var l=new RegExp(".{1,"+r+"}","g");i=i.match(l).join("\r\n")}return i},n.decode=function(e,t){if("string"!=typeof e)throw new TypeError('"input" must be a string.');if("string"!=typeof t)throw new TypeError('"alphabet" must be a string.');var r=s[t];if(!r){r=s[t]=[];for(var n=0;n>=8;for(;d>0;)c.push(255&d),d>>=8}for(var f=0;e[f]===a&&f=0;c--)P>>=8,P+=A.at(c)+R.at(c),R.setAt(c,255&P);I.putBuffer(R)}w=I,d.putBuffer(S)}return d.truncate(d.length()-s),d},o.pbe.getCipher=function(e,t,r){switch(e){case o.oids.pkcs5PBES2:return o.pbe.getCipherForPBES2(e,t,r);case o.oids["pbeWithSHAAnd3-KeyTripleDES-CBC"]:case o.oids["pbewithSHAAnd40BitRC2-CBC"]:return o.pbe.getCipherForPKCS12PBE(e,t,r);default:var i=new Error("Cannot read encrypted PBE data block. Unsupported OID.");throw i.oid=e,i.supportedOids=["pkcs5PBES2","pbeWithSHAAnd3-KeyTripleDES-CBC","pbewithSHAAnd40BitRC2-CBC"],i}},o.pbe.getCipherForPBES2=function(e,t,r){var n,a={},c=[];if(!s.validate(t,u,a,c))throw(n=new Error("Cannot read password-based-encryption algorithm parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.")).errors=c,n;if((e=s.derToOid(a.kdfOid))!==o.oids.pkcs5PBKDF2)throw(n=new Error("Cannot read encrypted private key. Unsupported key derivation function OID.")).oid=e,n.supportedOids=["pkcs5PBKDF2"],n;if((e=s.derToOid(a.encOid))!==o.oids["aes128-CBC"]&&e!==o.oids["aes192-CBC"]&&e!==o.oids["aes256-CBC"]&&e!==o.oids["des-EDE3-CBC"]&&e!==o.oids.desCBC)throw(n=new Error("Cannot read encrypted private key. Unsupported encryption scheme OID.")).oid=e,n.supportedOids=["aes128-CBC","aes192-CBC","aes256-CBC","des-EDE3-CBC","desCBC"],n;var l,d,h=a.kdfSalt,p=i.util.createBuffer(a.kdfIterationCount);switch(p=p.getInt(p.length()<<3),o.oids[e]){case"aes128-CBC":l=16,d=i.aes.createDecryptionCipher;break;case"aes192-CBC":l=24,d=i.aes.createDecryptionCipher;break;case"aes256-CBC":l=32,d=i.aes.createDecryptionCipher;break;case"des-EDE3-CBC":l=24,d=i.des.createDecryptionCipher;break;case"desCBC":l=8,d=i.des.createDecryptionCipher}var g=f(a.prfOid),y=i.pkcs5.pbkdf2(r,h,p,l,g),m=a.encIv,b=d(y);return b.start(m),b},o.pbe.getCipherForPKCS12PBE=function(e,t,r){var n={},a=[];if(!s.validate(t,l,n,a))throw(g=new Error("Cannot read password-based-encryption algorithm parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.")).errors=a,g;var c,u,d,h=i.util.createBuffer(n.salt),p=i.util.createBuffer(n.iterations);switch(p=p.getInt(p.length()<<3),e){case o.oids["pbeWithSHAAnd3-KeyTripleDES-CBC"]:c=24,u=8,d=i.des.startDecrypting;break;case o.oids["pbewithSHAAnd40BitRC2-CBC"]:c=5,u=8,d=function(e,t){var r=i.rc2.createDecryptionCipher(e,40);return r.start(t,null),r};break;default:var g;throw(g=new Error("Cannot read PKCS #12 PBE data block. Unsupported OID.")).oid=e,g}var y=f(n.prfOid),m=o.pbe.generatePkcs12Key(r,h,1,p,c,y);return y.start(),d(m,o.pbe.generatePkcs12Key(r,h,2,p,u,y))},o.pbe.opensslDeriveBytes=function(e,t,r,n){if(null==n){if(!("md5"in i.md))throw new Error('"md5" hash algorithm unavailable.');n=i.md.md5.create()}null===t&&(t="");for(var s=[d(n,e+t)],o=16,a=1;o>>=2;for(n=0;n>8^255&d^99,s[g]=d,o[d]=g,h=(f=e[d])<<24^d<<16^d<<8^d^f,p=((r=e[g])^(i=e[r])^(n=e[i]))<<24^(g^n)<<16^(g^i^n)<<8^g^r^n;for(var m=0;m<4;++m)c[m][g]=h,u[m][d]=p,h=h<<24|h>>>8,p=p<<24|p>>>8;0===g?g=y=1:(g=r^e[e[e[r^n]]],y^=e[e[y]])}}function f(e,t){for(var r,i=e.slice(0),n=1,o=i.length,c=4*(o+6+1),l=o;l>>16&255]<<24^s[r>>>8&255]<<16^s[255&r]<<8^s[r>>>24]^a[n]<<24,n++):o>6&&l%o==4&&(r=s[r>>>24]<<24^s[r>>>16&255]<<16^s[r>>>8&255]<<8^s[255&r]),i[l]=i[l-o]^r;if(t){for(var d,f=u[0],h=u[1],p=u[2],g=u[3],y=i.slice(0),m=(l=0,(c=i.length)-4);l>>24]]^h[s[d>>>16&255]]^p[s[d>>>8&255]]^g[s[255&d]];i=y}return i}function h(e,t,r,i){var n,a,l,d,f,h,p,g,y,m,b,v,w=e.length/4-1;i?(n=u[0],a=u[1],l=u[2],d=u[3],f=o):(n=c[0],a=c[1],l=c[2],d=c[3],f=s),h=t[0]^e[0],p=t[i?3:1]^e[1],g=t[2]^e[2],y=t[i?1:3]^e[3];for(var _=3,E=1;E>>24]^a[p>>>16&255]^l[g>>>8&255]^d[255&y]^e[++_],b=n[p>>>24]^a[g>>>16&255]^l[y>>>8&255]^d[255&h]^e[++_],v=n[g>>>24]^a[y>>>16&255]^l[h>>>8&255]^d[255&p]^e[++_],y=n[y>>>24]^a[h>>>16&255]^l[p>>>8&255]^d[255&g]^e[++_],h=m,p=b,g=v;r[0]=f[h>>>24]<<24^f[p>>>16&255]<<16^f[g>>>8&255]<<8^f[255&y]^e[++_],r[i?3:1]=f[p>>>24]<<24^f[g>>>16&255]<<16^f[y>>>8&255]<<8^f[255&h]^e[++_],r[2]=f[g>>>24]<<24^f[y>>>16&255]<<16^f[h>>>8&255]<<8^f[255&p]^e[++_],r[i?1:3]=f[y>>>24]<<24^f[h>>>16&255]<<16^f[p>>>8&255]<<8^f[255&g]^e[++_]}function p(e){var t,r="AES-"+((e=e||{}).mode||"CBC").toUpperCase(),n=(t=e.decrypt?i.cipher.createDecipher(r,e.key):i.cipher.createCipher(r,e.key)).start;return t.start=function(e,r){var s=null;r instanceof i.util.ByteBuffer&&(s=r,r={}),(r=r||{}).output=s,r.iv=e,n.call(t,r)},t}},{"./forge":"4OuPD","./cipher":"jMIHu","./cipherModes":"9MNR1","./util":"df43p"}],jMIHu:[function(e,t,r){var i=e("./forge");e("./util"),t.exports=i.cipher=i.cipher||{},i.cipher.algorithms=i.cipher.algorithms||{},i.cipher.createCipher=function(e,t){var r=e;if("string"==typeof r&&(r=i.cipher.getAlgorithm(r))&&(r=r()),!r)throw new Error("Unsupported algorithm: "+e);return new i.cipher.BlockCipher({algorithm:r,key:t,decrypt:!1})},i.cipher.createDecipher=function(e,t){var r=e;if("string"==typeof r&&(r=i.cipher.getAlgorithm(r))&&(r=r()),!r)throw new Error("Unsupported algorithm: "+e);return new i.cipher.BlockCipher({algorithm:r,key:t,decrypt:!0})},i.cipher.registerAlgorithm=function(e,t){e=e.toUpperCase(),i.cipher.algorithms[e]=t},i.cipher.getAlgorithm=function(e){return(e=e.toUpperCase())in i.cipher.algorithms?i.cipher.algorithms[e]:null};var n=i.cipher.BlockCipher=function(e){this.algorithm=e.algorithm,this.mode=this.algorithm.mode,this.blockSize=this.mode.blockSize,this._finish=!1,this._input=null,this.output=null,this._op=e.decrypt?this.mode.decrypt:this.mode.encrypt,this._decrypt=e.decrypt,this.algorithm.initialize(e)};n.prototype.start=function(e){e=e||{};var t={};for(var r in e)t[r]=e[r];t.decrypt=this._decrypt,this._finish=!1,this._input=i.util.createBuffer(),this.output=e.output||i.util.createBuffer(),this.mode.start(t)},n.prototype.update=function(e){for(e&&this._input.putBuffer(e);!this._op.call(this.mode,this._input,this.output,this._finish)&&!this._finish;);this._input.compact()},n.prototype.finish=function(e){!e||"ECB"!==this.mode.name&&"CBC"!==this.mode.name||(this.mode.pad=function(t){return e(this.blockSize,t,!1)},this.mode.unpad=function(t){return e(this.blockSize,t,!0)});var t={};return t.decrypt=this._decrypt,t.overflow=this._input.length()%this.blockSize,!(!this._decrypt&&this.mode.pad&&!this.mode.pad(this._input,t))&&(this._finish=!0,this.update(),!(this._decrypt&&this.mode.unpad&&!this.mode.unpad(this.output,t))&&!(this.mode.afterFinish&&!this.mode.afterFinish(this.output,t)))}},{"./forge":"4OuPD","./util":"df43p"}],"9MNR1":[function(e,t,r){var i=e("./forge");e("./util"),i.cipher=i.cipher||{};var n=t.exports=i.cipher.modes=i.cipher.modes||{};function s(e,t){if("string"==typeof e&&(e=i.util.createBuffer(e)),i.util.isArray(e)&&e.length>4){var r=e;e=i.util.createBuffer();for(var n=0;n0))return!0;for(var i=0;i0))return!0;for(var i=0;i0)return!1;var r=e.length(),i=e.at(r-1);return!(i>this.blockSize<<2)&&(e.truncate(i),!0)},n.cbc=function(e){e=e||{},this.name="CBC",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=new Array(this._ints),this._outBlock=new Array(this._ints)},n.cbc.prototype.start=function(e){if(null===e.iv){if(!this._prev)throw new Error("Invalid IV parameter.");this._iv=this._prev.slice(0)}else{if(!("iv"in e))throw new Error("Invalid IV parameter.");this._iv=s(e.iv,this.blockSize),this._prev=this._iv.slice(0)}},n.cbc.prototype.encrypt=function(e,t,r){if(e.length()0))return!0;for(var i=0;i0))return!0;for(var i=0;i0)return!1;var r=e.length(),i=e.at(r-1);return!(i>this.blockSize<<2)&&(e.truncate(i),!0)},n.cfb=function(e){e=e||{},this.name="CFB",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=null,this._outBlock=new Array(this._ints),this._partialBlock=new Array(this._ints),this._partialOutput=i.util.createBuffer(),this._partialBytes=0},n.cfb.prototype.start=function(e){if(!("iv"in e))throw new Error("Invalid IV parameter.");this._iv=s(e.iv,this.blockSize),this._inBlock=this._iv.slice(0),this._partialBytes=0},n.cfb.prototype.encrypt=function(e,t,r){var i=e.length();if(0===i)return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize)for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0)e.read-=this.blockSize;else for(n=0;n0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}},n.cfb.prototype.decrypt=function(e,t,r){var i=e.length();if(0===i)return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize)for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0)e.read-=this.blockSize;else for(n=0;n0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}},n.ofb=function(e){e=e||{},this.name="OFB",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=null,this._outBlock=new Array(this._ints),this._partialOutput=i.util.createBuffer(),this._partialBytes=0},n.ofb.prototype.start=function(e){if(!("iv"in e))throw new Error("Invalid IV parameter.");this._iv=s(e.iv,this.blockSize),this._inBlock=this._iv.slice(0),this._partialBytes=0},n.ofb.prototype.encrypt=function(e,t,r){var i=e.length();if(0===e.length())return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize)for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0)e.read-=this.blockSize;else for(n=0;n0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}},n.ofb.prototype.decrypt=n.ofb.prototype.encrypt,n.ctr=function(e){e=e||{},this.name="CTR",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=null,this._outBlock=new Array(this._ints),this._partialOutput=i.util.createBuffer(),this._partialBytes=0},n.ctr.prototype.start=function(e){if(!("iv"in e))throw new Error("Invalid IV parameter.");this._iv=s(e.iv,this.blockSize),this._inBlock=this._iv.slice(0),this._partialBytes=0},n.ctr.prototype.encrypt=function(e,t,r){var i=e.length();if(0===i)return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize)for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0&&(e.read-=this.blockSize),this._partialBytes>0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}o(this._inBlock)},n.ctr.prototype.decrypt=n.ctr.prototype.encrypt,n.gcm=function(e){e=e||{},this.name="GCM",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=new Array(this._ints),this._outBlock=new Array(this._ints),this._partialOutput=i.util.createBuffer(),this._partialBytes=0,this._R=3774873600},n.gcm.prototype.start=function(e){if(!("iv"in e))throw new Error("Invalid IV parameter.");var t,r=i.util.createBuffer(e.iv);if(this._cipherLength=0,t="additionalData"in e?i.util.createBuffer(e.additionalData):i.util.createBuffer(),this._tagLength="tagLength"in e?e.tagLength:128,this._tag=null,e.decrypt&&(this._tag=i.util.createBuffer(e.tag).getBytes(),this._tag.length!==this._tagLength/8))throw new Error("Authentication tag does not match tag length.");this._hashBlock=new Array(this._ints),this.tag=null,this._hashSubkey=new Array(this._ints),this.cipher.encrypt([0,0,0,0],this._hashSubkey),this.componentBits=4,this._m=this.generateHashTable(this._hashSubkey,this.componentBits);var n=r.length();if(12===n)this._j0=[r.getInt32(),r.getInt32(),r.getInt32(),1];else{for(this._j0=[0,0,0,0];r.length()>0;)this._j0=this.ghash(this._hashSubkey,this._j0,[r.getInt32(),r.getInt32(),r.getInt32(),r.getInt32()]);this._j0=this.ghash(this._hashSubkey,this._j0,[0,0].concat(a(8*n)))}this._inBlock=this._j0.slice(0),o(this._inBlock),this._partialBytes=0,t=i.util.createBuffer(t),this._aDataLength=a(8*t.length());var s=t.length()%this.blockSize;for(s&&t.fillWithByte(0,this.blockSize-s),this._s=[0,0,0,0];t.length()>0;)this._s=this.ghash(this._hashSubkey,this._s,[t.getInt32(),t.getInt32(),t.getInt32(),t.getInt32()])},n.gcm.prototype.encrypt=function(e,t,r){var i=e.length();if(0===i)return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize){for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return e.read-=this.blockSize,t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}this._s=this.ghash(this._hashSubkey,this._s,this._outBlock),o(this._inBlock)},n.gcm.prototype.decrypt=function(e,t,r){var i=e.length();if(i0))return!0;this.cipher.encrypt(this._inBlock,this._outBlock),o(this._inBlock),this._hashBlock[0]=e.getInt32(),this._hashBlock[1]=e.getInt32(),this._hashBlock[2]=e.getInt32(),this._hashBlock[3]=e.getInt32(),this._s=this.ghash(this._hashSubkey,this._s,this._hashBlock);for(var n=0;n0;--i)t[i]=e[i]>>>1|(1&e[i-1])<<31;t[0]=e[0]>>>1,r&&(t[0]^=this._R)},n.gcm.prototype.tableMultiply=function(e){for(var t=[0,0,0,0],r=0;r<32;++r){var i=e[r/8|0]>>>4*(7-r%8)&15,n=this._m[r][i];t[0]^=n[0],t[1]^=n[1],t[2]^=n[2],t[3]^=n[3]}return t},n.gcm.prototype.ghash=function(e,t,r){return t[0]^=r[0],t[1]^=r[1],t[2]^=r[2],t[3]^=r[3],this.tableMultiply(t)},n.gcm.prototype.generateHashTable=function(e,t){for(var r=8/t,i=4*r,n=16*r,s=new Array(n),o=0;o>>1,n=new Array(r);n[i]=e.slice(0);for(var s=i>>>1;s>0;)this.pow(n[2*s],n[s]=[]),s>>=1;for(s=2;s8?3:1,m=[],b=[0,0,1,1,1,1,1,1,0,1,1,1,1,1,1,0],v=0,w=0;w>>4^E))<<4,_^=t=65535&((E^=t)>>>-16^_),_^=(t=858993459&(_>>>2^(E^=t<<-16)))<<2,_^=t=65535&((E^=t)>>>-16^_),_^=(t=1431655765&(_>>>1^(E^=t<<-16)))<<1,_^=t=16711935&((E^=t)>>>8^_),t=(_^=(t=1431655765&(_>>>1^(E^=t<<8)))<<1)<<8|(E^=t)>>>20&240,_=E<<24|E<<8&16711680|E>>>8&65280|E>>>24&240,E=t;for(var S=0;S>>26,E=E<<2|E>>>26):(_=_<<1|_>>>27,E=E<<1|E>>>27),E&=-15;var T=r[(_&=-15)>>>28]|i[_>>>24&15]|n[_>>>20&15]|s[_>>>16&15]|o[_>>>12&15]|a[_>>>8&15]|c[_>>>4&15],A=u[E>>>28]|l[E>>>24&15]|d[E>>>20&15]|f[E>>>16&15]|h[E>>>12&15]|p[E>>>8&15]|g[E>>>4&15];t=65535&(A>>>16^T),m[v++]=T^t,m[v++]=A^t<<16}}return m}(t),this._init=!0}},n("DES-ECB",i.cipher.modes.ecb),n("DES-CBC",i.cipher.modes.cbc),n("DES-CFB",i.cipher.modes.cfb),n("DES-OFB",i.cipher.modes.ofb),n("DES-CTR",i.cipher.modes.ctr),n("3DES-ECB",i.cipher.modes.ecb),n("3DES-CBC",i.cipher.modes.cbc),n("3DES-CFB",i.cipher.modes.cfb),n("3DES-OFB",i.cipher.modes.ofb),n("3DES-CTR",i.cipher.modes.ctr);var s=[16843776,0,65536,16843780,16842756,66564,4,65536,1024,16843776,16843780,1024,16778244,16842756,16777216,4,1028,16778240,16778240,66560,66560,16842752,16842752,16778244,65540,16777220,16777220,65540,0,1028,66564,16777216,65536,16843780,4,16842752,16843776,16777216,16777216,1024,16842756,65536,66560,16777220,1024,4,16778244,66564,16843780,65540,16842752,16778244,16777220,1028,66564,16843776,1028,16778240,16778240,0,65540,66560,0,16842756],o=[-2146402272,-2147450880,32768,1081376,1048576,32,-2146435040,-2147450848,-2147483616,-2146402272,-2146402304,-2147483648,-2147450880,1048576,32,-2146435040,1081344,1048608,-2147450848,0,-2147483648,32768,1081376,-2146435072,1048608,-2147483616,0,1081344,32800,-2146402304,-2146435072,32800,0,1081376,-2146435040,1048576,-2147450848,-2146435072,-2146402304,32768,-2146435072,-2147450880,32,-2146402272,1081376,32,32768,-2147483648,32800,-2146402304,1048576,-2147483616,1048608,-2147450848,-2147483616,1048608,1081344,0,-2147450880,32800,-2147483648,-2146435040,-2146402272,1081344],a=[520,134349312,0,134348808,134218240,0,131592,134218240,131080,134217736,134217736,131072,134349320,131080,134348800,520,134217728,8,134349312,512,131584,134348800,134348808,131592,134218248,131584,131072,134218248,8,134349320,512,134217728,134349312,134217728,131080,520,131072,134349312,134218240,0,512,131080,134349320,134218240,134217736,512,0,134348808,134218248,131072,134217728,134349320,8,131592,131584,134217736,134348800,134218248,520,134348800,131592,8,134348808,131584],c=[8396801,8321,8321,128,8396928,8388737,8388609,8193,0,8396800,8396800,8396929,129,0,8388736,8388609,1,8192,8388608,8396801,128,8388608,8193,8320,8388737,1,8320,8388736,8192,8396928,8396929,129,8388736,8388609,8396800,8396929,129,0,0,8396800,8320,8388736,8388737,1,8396801,8321,8321,128,8396929,129,1,8192,8388609,8193,8396928,8388737,8193,8320,8388608,8396801,128,8388608,8192,8396928],u=[256,34078976,34078720,1107296512,524288,256,1073741824,34078720,1074266368,524288,33554688,1074266368,1107296512,1107820544,524544,1073741824,33554432,1074266112,1074266112,0,1073742080,1107820800,1107820800,33554688,1107820544,1073742080,0,1107296256,34078976,33554432,1107296256,524544,524288,1107296512,256,33554432,1073741824,34078720,1107296512,1074266368,33554688,1073741824,1107820544,34078976,1074266368,256,33554432,1107820544,1107820800,524544,1107296256,1107820800,34078720,0,1074266112,1107296256,524544,33554688,1073742080,524288,0,1074266112,34078976,1073742080],l=[536870928,541065216,16384,541081616,541065216,16,541081616,4194304,536887296,4210704,4194304,536870928,4194320,536887296,536870912,16400,0,4194320,536887312,16384,4210688,536887312,16,541065232,541065232,0,4210704,541081600,16400,4210688,541081600,536870912,536887296,16,541065232,4210688,541081616,4194304,16400,536870928,4194304,536887296,536870912,16400,536870928,541081616,4210688,541065216,4210704,541081600,0,541065232,16,16384,541065216,4210704,16384,4194320,536887312,0,541081600,536870912,4194320,536887312],d=[2097152,69206018,67110914,0,2048,67110914,2099202,69208064,69208066,2097152,0,67108866,2,67108864,69206018,2050,67110912,2099202,2097154,67110912,67108866,69206016,69208064,2097154,69206016,2048,2050,69208066,2099200,2,67108864,2099200,67108864,2099200,2097152,67110914,67110914,69206018,69206018,2,2097154,67108864,67110912,2097152,69208064,2050,2099202,69208064,2050,67108866,69208066,69206016,2099200,0,2,69208066,0,2099202,69206016,2048,67108866,67110912,2048,2097154],f=[268439616,4096,262144,268701760,268435456,268439616,64,268435456,262208,268697600,268701760,266240,268701696,266304,4096,64,268697600,268435520,268439552,4160,266240,262208,268697664,268701696,4160,0,0,268697664,268435520,268439552,266304,262144,266304,262144,268701696,4096,64,268697664,4096,266304,268439552,64,268435520,268697600,268697664,268435456,262144,268439616,0,268701760,262208,268435520,268697600,268439552,268439616,0,268701760,266240,266240,4160,4160,262208,268435456,268701696];function h(e,t,r,i){var n,h,p=32===e.length?3:9;n=3===p?i?[30,-2,-2]:[0,32,2]:i?[94,62,-2,32,64,2,30,-2,-2]:[0,32,2,62,30,-2,64,96,2];var g=t[0],y=t[1];g^=(h=252645135&(g>>>4^y))<<4,g^=(h=65535&(g>>>16^(y^=h)))<<16,g^=h=858993459&((y^=h)>>>2^g),g^=h=16711935&((y^=h<<2)>>>8^g),g=(g^=(h=1431655765&(g>>>1^(y^=h<<8)))<<1)<<1|g>>>31,y=(y^=h)<<1|y>>>31;for(var m=0;m>>4|y<<28)^e[w+1];h=g,g=y,y=h^(o[_>>>24&63]|c[_>>>16&63]|l[_>>>8&63]|f[63&_]|s[E>>>24&63]|a[E>>>16&63]|u[E>>>8&63]|d[63&E])}h=g,g=y,y=h}y=y>>>1|y<<31,y^=h=1431655765&((g=g>>>1|g<<31)>>>1^y),y^=(h=16711935&(y>>>8^(g^=h<<1)))<<8,y^=(h=858993459&(y>>>2^(g^=h)))<<2,y^=h=65535&((g^=h)>>>16^y),y^=h=252645135&((g^=h<<16)>>>4^y),g^=h<<4,r[0]=g,r[1]=y}function p(e){var t,r="DES-"+((e=e||{}).mode||"CBC").toUpperCase(),n=(t=e.decrypt?i.cipher.createDecipher(r,e.key):i.cipher.createCipher(r,e.key)).start;return t.start=function(e,r){var s=null;r instanceof i.util.ByteBuffer&&(s=r,r={}),(r=r||{}).output=s,r.iv=e,n.call(t,r)},t}},{"./forge":"4OuPD","./cipher":"jMIHu","./cipherModes":"9MNR1","./util":"df43p"}],fYbz5:[function(e,t,r){var i=e("./forge");t.exports=i.md=i.md||{},i.md.algorithms=i.md.algorithms||{}},{"./forge":"4OuPD"}],j1TyX:[function(e,t,r){var i=e("buffer").Buffer,n=e("./forge");e("./hmac"),e("./md"),e("./util");var s,o=n.pkcs5=n.pkcs5||{};n.util.isNodejs&&!n.options.usePureJavaScript&&(s=e("crypto")),t.exports=n.pbkdf2=o.pbkdf2=function(e,t,r,o,a,c){if("function"==typeof a&&(c=a,a=null),n.util.isNodejs&&!n.options.usePureJavaScript&&s.pbkdf2&&(null===a||"object"!=typeof a)&&(s.pbkdf2Sync.length>4||!a||"sha1"===a))return"string"!=typeof a&&(a="sha1"),e=i.from(e,"binary"),t=i.from(t,"binary"),c?4===s.pbkdf2Sync.length?s.pbkdf2(e,t,r,o,(function(e,t){if(e)return c(e);c(null,t.toString("binary"))})):s.pbkdf2(e,t,r,o,a,(function(e,t){if(e)return c(e);c(null,t.toString("binary"))})):4===s.pbkdf2Sync.length?s.pbkdf2Sync(e,t,r,o).toString("binary"):s.pbkdf2Sync(e,t,r,o,a).toString("binary");if(null==a&&(a="sha1"),"string"==typeof a){if(!(a in n.md.algorithms))throw new Error("Unknown hash algorithm: "+a);a=n.md[a].create()}var u=a.digestLength;if(o>4294967295*u){var l=new Error("Derived key is too long.");if(c)return c(l);throw l}var d=Math.ceil(o/u),f=o-(d-1)*u,h=n.hmac.create();h.start(a,e);var p,g,y,m="";if(!c){for(var b=1;b<=d;++b){h.start(null,null),h.update(t),h.update(n.util.int32ToBytes(b)),p=y=h.digest().getBytes();for(var v=2;v<=r;++v)h.start(null,null),h.update(y),g=h.digest().getBytes(),p=n.util.xorBytes(p,g,u),y=g;m+=bd)return c(null,m);h.start(null,null),h.update(t),h.update(n.util.int32ToBytes(b)),p=y=h.digest().getBytes(),v=2,_()}function _(){if(v<=r)return h.start(null,null),h.update(y),g=h.digest().getBytes(),p=n.util.xorBytes(p,g,u),y=g,++v,n.util.setImmediate(_);m+=bt.blockLength&&(t.start(),t.update(o.bytes()),o=t.digest()),r=i.util.createBuffer(),n=i.util.createBuffer(),u=o.length();for(c=0;c65&&-1!==o){var a=t[o];","===a?(++o,t=t.substr(0,o)+"\r\n "+t.substr(o)):t=t.substr(0,o)+"\r\n"+a+t.substr(o+1),s=n-o-1,o=-1,++n}else" "!==t[n]&&"\t"!==t[n]&&","!==t[n]||(o=n);return t}function o(e){return e.replace(/^\s+/,"")}n.encode=function(e,t){t=t||{};var r,n="-----BEGIN "+e.type+"-----\r\n";if(e.procType&&(n+=s(r={name:"Proc-Type",values:[String(e.procType.version),e.procType.type]})),e.contentDomain&&(n+=s(r={name:"Content-Domain",values:[e.contentDomain]})),e.dekInfo&&(r={name:"DEK-Info",values:[e.dekInfo.algorithm]},e.dekInfo.parameters&&r.values.push(e.dekInfo.parameters),n+=s(r)),e.headers)for(var o=0;o>>0,a>>>0];for(var u=n.fullMessageLength.length-1;u>=0;--u)n.fullMessageLength[u]+=a[1],a[1]=a[0]+(n.fullMessageLength[u]/4294967296>>>0),n.fullMessageLength[u]=n.fullMessageLength[u]>>>0,a[0]=a[1]/4294967296>>>0;return t.putBytes(s),c(e,r,t),(t.read>2048||0===t.length())&&t.compact(),n},n.digest=function(){var o=i.util.createBuffer();o.putBytes(t.bytes());var a,u=n.fullMessageLength[n.fullMessageLength.length-1]+n.messageLengthSize&n.blockLength-1;o.putBytes(s.substr(0,n.blockLength-u));for(var l=8*n.fullMessageLength[0],d=0;d>>0,o.putInt32(l>>>0),l=a>>>0;o.putInt32(l);var f={h0:e.h0,h1:e.h1,h2:e.h2,h3:e.h3,h4:e.h4,h5:e.h5,h6:e.h6,h7:e.h7};c(f,r,o);var h=i.util.createBuffer();return h.putInt32(f.h0),h.putInt32(f.h1),h.putInt32(f.h2),h.putInt32(f.h3),h.putInt32(f.h4),h.putInt32(f.h5),h.putInt32(f.h6),h.putInt32(f.h7),h},n};var s=null,o=!1,a=null;function c(e,t,r){for(var i,n,s,o,c,u,l,d,f,h,p,g,y,m=r.length();m>=64;){for(c=0;c<16;++c)t[c]=r.getInt32();for(;c<64;++c)i=((i=t[c-2])>>>17|i<<15)^(i>>>19|i<<13)^i>>>10,n=((n=t[c-15])>>>7|n<<25)^(n>>>18|n<<14)^n>>>3,t[c]=i+t[c-7]+n+t[c-16]|0;for(u=e.h0,l=e.h1,d=e.h2,f=e.h3,h=e.h4,p=e.h5,g=e.h6,y=e.h7,c=0;c<64;++c)s=(u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10),o=u&l|d&(u^l),i=y+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+(g^h&(p^g))+a[c]+t[c],y=g,g=p,p=h,h=f+i>>>0,f=d,d=l,l=u,u=i+(n=s+o)>>>0;e.h0=e.h0+u|0,e.h1=e.h1+l|0,e.h2=e.h2+d|0,e.h3=e.h3+f|0,e.h4=e.h4+h|0,e.h5=e.h5+p|0,e.h6=e.h6+g|0,e.h7=e.h7+y|0,m-=64}}},{"./forge":"4OuPD","./md":"fYbz5","./util":"df43p"}],"5YtEX":[function(e,t,r){var i=e("process"),n=e("./forge");e("./util");var s=null;!n.util.isNodejs||n.options.usePureJavaScript||i.versions["node-webkit"]||(s=e("crypto")),(t.exports=n.prng=n.prng||{}).create=function(e){for(var t={plugin:e,key:null,seed:null,time:null,reseeds:0,generated:0,keyBytes:""},r=e.md,i=new Array(32),o=0;o<32;++o)i[o]=r.create();function a(){if(t.pools[0].messageLength>=32)return c();var e=32-t.pools[0].messageLength<<5;t.collect(t.seedFileSync(e)),c()}function c(){t.reseeds=4294967295===t.reseeds?0:t.reseeds+1;var e=t.plugin.md.create();e.update(t.keyBytes);for(var r=1,i=0;i<32;++i)t.reseeds%r==0&&(e.update(t.pools[i].digest().getBytes()),t.pools[i].start()),r<<=1;t.keyBytes=e.digest().getBytes(),e.start(),e.update(t.keyBytes);var n=e.digest().getBytes();t.key=t.plugin.formatKey(t.keyBytes),t.seed=t.plugin.formatSeed(n),t.generated=0}function u(e){var t=null,r=n.util.globalScope,i=r.crypto||r.msCrypto;i&&i.getRandomValues&&(t=function(e){return i.getRandomValues(e)});var s=n.util.createBuffer();if(t)for(;s.length()>16)))<<16,f=4294967295&(l=(2147483647&(l+=u>>15))+(l>>31));for(c=0;c<3;++c)d=f>>>(c<<3),d^=Math.floor(256*Math.random()),s.putByte(String.fromCharCode(255&d))}return s.getBytes(e)}return t.pools=i,t.pool=0,t.generate=function(e,r){if(!r)return t.generateSync(e);var i=t.plugin.cipher,s=t.plugin.increment,o=t.plugin.formatKey,a=t.plugin.formatSeed,u=n.util.createBuffer();t.key=null,function l(d){if(d)return r(d);if(u.length()>=e)return r(null,u.getBytes(e));t.generated>1048575&&(t.key=null);if(null===t.key)return n.util.nextTick((function(){!function(e){if(t.pools[0].messageLength>=32)return c(),e();var r=32-t.pools[0].messageLength<<5;t.seedFile(r,(function(r,i){if(r)return e(r);t.collect(i),c(),e()}))}(l)}));var f=i(t.key,t.seed);t.generated+=f.length,u.putBytes(f),t.key=o(i(t.key,s(t.seed))),t.seed=a(i(t.key,t.seed)),n.util.setImmediate(l)}()},t.generateSync=function(e){var r=t.plugin.cipher,i=t.plugin.increment,s=t.plugin.formatKey,o=t.plugin.formatSeed;t.key=null;for(var c=n.util.createBuffer();c.length()1048575&&(t.key=null),null===t.key&&a();var u=r(t.key,t.seed);t.generated+=u.length,c.putBytes(u),t.key=s(r(t.key,i(t.seed))),t.seed=o(r(t.key,t.seed))}return c.getBytes(e)},s?(t.seedFile=function(e,t){s.randomBytes(e,(function(e,r){if(e)return t(e);t(null,r.toString())}))},t.seedFileSync=function(e){return s.randomBytes(e).toString()}):(t.seedFile=function(e,t){try{t(null,u(e))}catch(e){t(e)}},t.seedFileSync=u),t.collect=function(e){for(var r=e.length,i=0;i>n&255);t.collect(i)},t.registerWorker=function(e){if(e===self)t.seedFile=function(e,t){self.addEventListener("message",(function e(r){var i=r.data;i.forge&&i.forge.prng&&(self.removeEventListener("message",e),t(i.forge.prng.err,i.forge.prng.bytes))})),self.postMessage({forge:{prng:{needed:e}}})};else{e.addEventListener("message",(function(r){var i=r.data;i.forge&&i.forge.prng&&t.seedFile(i.forge.prng.needed,(function(t,r){e.postMessage({forge:{prng:{err:t,bytes:r}}})}))}))}},t}},{process:"lHksA","./forge":"4OuPD","./util":"df43p",crypto:"lHksA"}],k5bWr:[function(e,t,r){var i=e("./forge");e("./util");var n=[217,120,249,196,25,221,181,237,40,233,253,121,74,160,216,157,198,126,55,131,43,118,83,142,98,76,100,136,68,139,251,162,23,154,89,245,135,179,79,19,97,69,109,141,9,129,125,50,189,143,64,235,134,183,123,11,240,149,33,34,92,107,78,130,84,214,101,147,206,96,178,28,115,86,192,20,167,140,241,220,18,117,202,31,59,190,228,209,66,61,212,48,163,60,182,38,111,191,14,218,70,105,7,87,39,242,29,155,188,148,67,3,248,17,199,246,144,239,62,231,6,195,213,47,200,102,30,215,8,232,234,222,128,82,238,247,132,170,114,172,53,77,106,42,150,26,210,113,90,21,73,116,75,159,208,94,4,24,164,236,194,224,65,110,15,81,203,204,36,145,175,80,161,244,112,57,153,124,58,133,35,184,180,122,252,2,54,91,37,85,151,49,45,93,250,152,227,138,146,174,5,223,41,16,103,108,186,201,211,0,230,207,225,158,168,44,99,22,1,63,88,226,137,169,13,56,52,27,171,51,255,176,187,72,12,95,185,177,205,46,197,243,219,71,229,165,156,119,10,166,32,104,254,127,193,173],s=[1,2,3,5],o=function(e,t){return e<>16-t},a=function(e,t){return(65535&e)>>t|e<<16-t&65535};t.exports=i.rc2=i.rc2||{},i.rc2.expandKey=function(e,t){"string"==typeof e&&(e=i.util.createBuffer(e)),t=t||128;var r,s=e,o=e.length(),a=t,c=Math.ceil(a/8),u=255>>(7&a);for(r=o;r<128;r++)s.putByte(n[s.at(r-1)+s.at(r-o)&255]);for(s.setAt(128-c,n[s.at(128-c)&u]),r=127-c;r>=0;r--)s.setAt(r,n[s.at(r+1)^s.at(r+c)]);return s};var c=function(e,t,r){var n,c,u,l,d=!1,f=null,h=null,p=null,g=[];for(e=i.rc2.expandKey(e,t),u=0;u<64;u++)g.push(e.getInt16Le());r?(n=function(e){for(u=0;u<4;u++)e[u]+=g[l]+(e[(u+3)%4]&e[(u+2)%4])+(~e[(u+3)%4]&e[(u+1)%4]),e[u]=o(e[u],s[u]),l++},c=function(e){for(u=0;u<4;u++)e[u]+=g[63&e[(u+3)%4]]}):(n=function(e){for(u=3;u>=0;u--)e[u]=a(e[u],s[u]),e[u]-=g[l]+(e[(u+3)%4]&e[(u+2)%4])+(~e[(u+3)%4]&e[(u+1)%4]),l--},c=function(e){for(u=3;u>=0;u--)e[u]-=g[63&e[(u+3)%4]]});var y=function(e){var t=[];for(u=0;u<4;u++){var i=f.getInt16Le();null!==p&&(r?i^=p.getInt16Le():p.putInt16Le(i)),t.push(65535&i)}l=r?0:63;for(var n=0;n=8;)y([[5,n],[1,c],[6,n],[1,c],[5,n]])},finish:function(e){var t=!0;if(r)if(e)t=e(8,f,!r);else{var i=8===f.length()?8:8-f.length();f.fillWithByte(i,i)}if(t&&(d=!0,m.update()),!r&&(t=0===f.length()))if(e)t=e(8,h,!r);else{var n=h.length(),s=h.at(n-1);s>n?t=!1:h.truncate(s)}return t}}};i.rc2.startEncrypting=function(e,t,r){var n=i.rc2.createEncryptionCipher(e,128);return n.start(t,r),n},i.rc2.createEncryptionCipher=function(e,t){return c(e,t,!0)},i.rc2.startDecrypting=function(e,t,r){var n=i.rc2.createDecryptionCipher(e,128);return n.start(t,r),n},i.rc2.createDecryptionCipher=function(e,t){return c(e,t,!1)}},{"./forge":"4OuPD","./util":"df43p"}],"9ROH2":[function(e,t,r){var i=e("./forge");if(e("./asn1"),e("./jsbn"),e("./oids"),e("./pkcs1"),e("./prime"),e("./random"),e("./util"),void 0===n)var n=i.jsbn.BigInteger;var s=i.util.isNodejs?e("crypto"):null,o=i.asn1,a=i.util;i.pki=i.pki||{},t.exports=i.pki.rsa=i.rsa=i.rsa||{};var c=i.pki,u=[6,4,2,4,2,4,6,2],l={name:"PrivateKeyInfo",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"PrivateKeyInfo.version",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyVersion"},{name:"PrivateKeyInfo.privateKeyAlgorithm",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:o.Class.UNIVERSAL,type:o.Type.OID,constructed:!1,capture:"privateKeyOid"}]},{name:"PrivateKeyInfo",tagClass:o.Class.UNIVERSAL,type:o.Type.OCTETSTRING,constructed:!1,capture:"privateKey"}]},d={name:"RSAPrivateKey",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"RSAPrivateKey.version",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyVersion"},{name:"RSAPrivateKey.modulus",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyModulus"},{name:"RSAPrivateKey.publicExponent",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyPublicExponent"},{name:"RSAPrivateKey.privateExponent",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyPrivateExponent"},{name:"RSAPrivateKey.prime1",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyPrime1"},{name:"RSAPrivateKey.prime2",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyPrime2"},{name:"RSAPrivateKey.exponent1",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyExponent1"},{name:"RSAPrivateKey.exponent2",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyExponent2"},{name:"RSAPrivateKey.coefficient",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyCoefficient"}]},f={name:"RSAPublicKey",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"RSAPublicKey.modulus",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"publicKeyModulus"},{name:"RSAPublicKey.exponent",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"publicKeyExponent"}]},h=i.pki.rsa.publicKeyValidator={name:"SubjectPublicKeyInfo",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,captureAsn1:"subjectPublicKeyInfo",value:[{name:"SubjectPublicKeyInfo.AlgorithmIdentifier",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:o.Class.UNIVERSAL,type:o.Type.OID,constructed:!1,capture:"publicKeyOid"}]},{name:"SubjectPublicKeyInfo.subjectPublicKey",tagClass:o.Class.UNIVERSAL,type:o.Type.BITSTRING,constructed:!1,value:[{name:"SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,optional:!0,captureAsn1:"rsaPublicKey"}]}]},p=function(e){var t;if(!(e.algorithm in c.oids)){var r=new Error("Unknown message digest algorithm.");throw r.algorithm=e.algorithm,r}t=c.oids[e.algorithm];var i=o.oidToDer(t).getBytes(),n=o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[]),s=o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[]);s.value.push(o.create(o.Class.UNIVERSAL,o.Type.OID,!1,i)),s.value.push(o.create(o.Class.UNIVERSAL,o.Type.NULL,!1,""));var a=o.create(o.Class.UNIVERSAL,o.Type.OCTETSTRING,!1,e.digest().getBytes());return n.value.push(s),n.value.push(a),o.toDer(n).getBytes()},g=function(e,t,r){if(r)return e.modPow(t.e,t.n);if(!t.p||!t.q)return e.modPow(t.d,t.n);var s;t.dP||(t.dP=t.d.mod(t.p.subtract(n.ONE))),t.dQ||(t.dQ=t.d.mod(t.q.subtract(n.ONE))),t.qInv||(t.qInv=t.q.modInverse(t.p));do{s=new n(i.util.bytesToHex(i.random.getBytes(t.n.bitLength()/8)),16)}while(s.compareTo(t.n)>=0||!s.gcd(t.n).equals(n.ONE));for(var o=(e=e.multiply(s.modPow(t.e,t.n)).mod(t.n)).mod(t.p).modPow(t.dP,t.p),a=e.mod(t.q).modPow(t.dQ,t.q);o.compareTo(a)<0;)o=o.add(t.p);var c=o.subtract(a).multiply(t.qInv).mod(t.p).multiply(t.q).add(a);return c=c.multiply(s.modInverse(t.n)).mod(t.n)};function y(e,t,r){var n=i.util.createBuffer(),s=Math.ceil(t.n.bitLength()/8);if(e.length>s-11){var o=new Error("Message is too long for PKCS#1 v1.5 padding.");throw o.length=e.length,o.max=s-11,o}n.putByte(0),n.putByte(r);var a,c=s-3-e.length;if(0===r||1===r){a=0===r?0:255;for(var u=0;u0;){var l=0,d=i.random.getBytes(c);for(u=0;u1;){if(255!==o.getByte()){--o.read;break}++u}else if(2===c)for(u=0;o.length()>1;){if(0===o.getByte()){--o.read;break}++u}if(0!==o.getByte()||u!==s-3-o.length())throw new Error("Encryption block is invalid.");return o.getBytes()}function b(e,t,r){"function"==typeof t&&(r=t,t={});var s={algorithm:{name:(t=t||{}).algorithm||"PRIMEINC",options:{workers:t.workers||2,workLoad:t.workLoad||100,workerScript:t.workerScript}}};function o(){a(e.pBits,(function(t,i){return t?r(t):(e.p=i,null!==e.q?u(t,e.q):void a(e.qBits,u))}))}function a(e,t){i.prime.generateProbablePrime(e,s,t)}function u(t,i){if(t)return r(t);if(e.q=i,e.p.compareTo(e.q)<0){var s=e.p;e.p=e.q,e.q=s}if(0!==e.p.subtract(n.ONE).gcd(e.e).compareTo(n.ONE))return e.p=null,void o();if(0!==e.q.subtract(n.ONE).gcd(e.e).compareTo(n.ONE))return e.q=null,void a(e.qBits,u);if(e.p1=e.p.subtract(n.ONE),e.q1=e.q.subtract(n.ONE),e.phi=e.p1.multiply(e.q1),0!==e.phi.gcd(e.e).compareTo(n.ONE))return e.p=e.q=null,void o();if(e.n=e.p.multiply(e.q),e.n.bitLength()!==e.bits)return e.q=null,void a(e.qBits,u);var l=e.e.modInverse(e.phi);e.keys={privateKey:c.rsa.setPrivateKey(e.n,e.e,l,e.p,e.q,l.mod(e.p1),l.mod(e.q1),e.q.modInverse(e.p)),publicKey:c.rsa.setPublicKey(e.n,e.e)},r(null,e.keys)}"prng"in t&&(s.prng=t.prng),o()}function v(e){var t=e.toString(16);t[0]>="8"&&(t="00"+t);var r=i.util.hexToBytes(t);return r.length>1&&(0===r.charCodeAt(0)&&0==(128&r.charCodeAt(1))||255===r.charCodeAt(0)&&128==(128&r.charCodeAt(1)))?r.substr(1):r}function w(e){return e<=100?27:e<=150?18:e<=200?15:e<=250?12:e<=300?9:e<=350?8:e<=400?7:e<=500?6:e<=600?5:e<=800?4:e<=1250?3:2}function _(e){return i.util.isNodejs&&"function"==typeof s[e]}function E(e){return void 0!==a.globalScope&&"object"==typeof a.globalScope.crypto&&"object"==typeof a.globalScope.crypto.subtle&&"function"==typeof a.globalScope.crypto.subtle[e]}function S(e){return void 0!==a.globalScope&&"object"==typeof a.globalScope.msCrypto&&"object"==typeof a.globalScope.msCrypto.subtle&&"function"==typeof a.globalScope.msCrypto.subtle[e]}function T(e){for(var t=i.util.hexToBytes(e.toString(16)),r=new Uint8Array(t.length),n=0;n0;)l.putByte(0),--d;return l.putBytes(i.util.hexToBytes(u)),l.getBytes()},c.rsa.decrypt=function(e,t,r,s){var o=Math.ceil(t.n.bitLength()/8);if(e.length!==o){var a=new Error("Encrypted message length is invalid.");throw a.length=e.length,a.expected=o,a}var c=new n(i.util.createBuffer(e).toHex(),16);if(c.compareTo(t.n)>=0)throw new Error("Encrypted message is invalid.");for(var u=g(c,t,r).toString(16),l=i.util.createBuffer(),d=o-Math.ceil(u.length/2);d>0;)l.putByte(0),--d;return l.putBytes(i.util.hexToBytes(u)),!1!==s?m(l.getBytes(),t,r):l.getBytes()},c.rsa.createKeyPairGenerationState=function(e,t,r){"string"==typeof e&&(e=parseInt(e,10)),e=e||2048;var s,o=(r=r||{}).prng||i.random,a={nextBytes:function(e){for(var t=o.getBytesSync(e.length),r=0;r>1,pBits:e-(e>>1),pqState:0,num:null,keys:null}).e.fromInt(s.eInt),s},c.rsa.stepKeyPairGenerationState=function(e,t){"algorithm"in e||(e.algorithm="PRIMEINC");var r=new n(null);r.fromInt(30);for(var i,s=0,o=function(e,t){return e|t},a=+new Date,l=0;null===e.keys&&(t<=0||ld?e.pqState=0:e.num.isProbablePrime(w(e.num.bitLength()))?++e.pqState:e.num.dAddOffset(u[s++%8],0):2===e.pqState?e.pqState=0===e.num.subtract(n.ONE).gcd(e.e).compareTo(n.ONE)?3:0:3===e.pqState&&(e.pqState=0,null===e.p?e.p=e.num:e.q=e.num,null!==e.p&&null!==e.q&&++e.state,e.num=null)}else if(1===e.state)e.p.compareTo(e.q)<0&&(e.num=e.p,e.p=e.q,e.q=e.num),++e.state;else if(2===e.state)e.p1=e.p.subtract(n.ONE),e.q1=e.q.subtract(n.ONE),e.phi=e.p1.multiply(e.q1),++e.state;else if(3===e.state)0===e.phi.gcd(e.e).compareTo(n.ONE)?++e.state:(e.p=null,e.q=null,e.state=0);else if(4===e.state)e.n=e.p.multiply(e.q),e.n.bitLength()===e.bits?++e.state:(e.q=null,e.state=0);else if(5===e.state){var h=e.e.modInverse(e.phi);e.keys={privateKey:c.rsa.setPrivateKey(e.n,e.e,h,e.p,e.q,h.mod(e.p1),h.mod(e.q1),e.q.modInverse(e.p)),publicKey:c.rsa.setPublicKey(e.n,e.e)}}l+=(i=+new Date)-a,a=i}return null!==e.keys},c.rsa.generateKeyPair=function(e,t,r,n){if(1===arguments.length?"object"==typeof e?(r=e,e=void 0):"function"==typeof e&&(n=e,e=void 0):2===arguments.length?"number"==typeof e?"function"==typeof t?(n=t,t=void 0):"number"!=typeof t&&(r=t,t=void 0):(r=e,n=t,e=void 0,t=void 0):3===arguments.length&&("number"==typeof t?"function"==typeof r&&(n=r,r=void 0):(n=r,r=t,t=void 0)),r=r||{},void 0===e&&(e=r.bits||2048),void 0===t&&(t=r.e||65537),!i.options.usePureJavaScript&&!r.prng&&e>=256&&e<=16384&&(65537===t||3===t))if(n){if(_("generateKeyPair"))return s.generateKeyPair("rsa",{modulusLength:e,publicExponent:t,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}},(function(e,t,r){if(e)return n(e);n(null,{privateKey:c.privateKeyFromPem(r),publicKey:c.publicKeyFromPem(t)})}));if(E("generateKey")&&E("exportKey"))return a.globalScope.crypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:T(t),hash:{name:"SHA-256"}},!0,["sign","verify"]).then((function(e){return a.globalScope.crypto.subtle.exportKey("pkcs8",e.privateKey)})).then(void 0,(function(e){n(e)})).then((function(e){if(e){var t=c.privateKeyFromAsn1(o.fromDer(i.util.createBuffer(e)));n(null,{privateKey:t,publicKey:c.setRsaPublicKey(t.n,t.e)})}}));if(S("generateKey")&&S("exportKey")){var u=a.globalScope.msCrypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:T(t),hash:{name:"SHA-256"}},!0,["sign","verify"]);return u.oncomplete=function(e){var t=e.target.result,r=a.globalScope.msCrypto.subtle.exportKey("pkcs8",t.privateKey);r.oncomplete=function(e){var t=e.target.result,r=c.privateKeyFromAsn1(o.fromDer(i.util.createBuffer(t)));n(null,{privateKey:r,publicKey:c.setRsaPublicKey(r.n,r.e)})},r.onerror=function(e){n(e)}},void(u.onerror=function(e){n(e)})}}else if(_("generateKeyPairSync")){var l=s.generateKeyPairSync("rsa",{modulusLength:e,publicExponent:t,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{privateKey:c.privateKeyFromPem(l.privateKey),publicKey:c.publicKeyFromPem(l.publicKey)}}var d=c.rsa.createKeyPairGenerationState(e,t,r);if(!n)return c.rsa.stepKeyPairGenerationState(d,0),d.keys;b(d,r,n)},c.setRsaPublicKey=c.rsa.setPublicKey=function(e,t){var r={n:e,e:t,encrypt:function(e,t,n){if("string"==typeof t?t=t.toUpperCase():void 0===t&&(t="RSAES-PKCS1-V1_5"),"RSAES-PKCS1-V1_5"===t)t={encode:function(e,t,r){return y(e,t,2).getBytes()}};else if("RSA-OAEP"===t||"RSAES-OAEP"===t)t={encode:function(e,t){return i.pkcs1.encode_rsa_oaep(t,e,n)}};else if(-1!==["RAW","NONE","NULL",null].indexOf(t))t={encode:function(e){return e}};else if("string"==typeof t)throw new Error('Unsupported encryption scheme: "'+t+'".');var s=t.encode(e,r,!0);return c.rsa.encrypt(s,r,!0)},verify:function(e,t,i){"string"==typeof i?i=i.toUpperCase():void 0===i&&(i="RSASSA-PKCS1-V1_5"),"RSASSA-PKCS1-V1_5"===i?i={verify:function(e,t){return t=m(t,r,!0),e===o.fromDer(t).value[1].value}}:"NONE"!==i&&"NULL"!==i&&null!==i||(i={verify:function(e,t){return e===(t=m(t,r,!0))}});var n=c.rsa.decrypt(t,r,!0,!1);return i.verify(e,n,r.n.bitLength())}};return r},c.setRsaPrivateKey=c.rsa.setPrivateKey=function(e,t,r,n,s,o,a,u){var l={n:e,e:t,d:r,p:n,q:s,dP:o,dQ:a,qInv:u,decrypt:function(e,t,r){"string"==typeof t?t=t.toUpperCase():void 0===t&&(t="RSAES-PKCS1-V1_5");var n=c.rsa.decrypt(e,l,!1,!1);if("RSAES-PKCS1-V1_5"===t)t={decode:m};else if("RSA-OAEP"===t||"RSAES-OAEP"===t)t={decode:function(e,t){return i.pkcs1.decode_rsa_oaep(t,e,r)}};else{if(-1===["RAW","NONE","NULL",null].indexOf(t))throw new Error('Unsupported encryption scheme: "'+t+'".');t={decode:function(e){return e}}}return t.decode(n,l,!1)},sign:function(e,t){var r=!1;"string"==typeof t&&(t=t.toUpperCase()),void 0===t||"RSASSA-PKCS1-V1_5"===t?(t={encode:p},r=1):"NONE"!==t&&"NULL"!==t&&null!==t||(t={encode:function(){return e}},r=1);var i=t.encode(e,l.n.bitLength());return c.rsa.encrypt(i,l,r)}};return l},c.wrapRsaPrivateKey=function(e){return o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,o.integerToDer(0).getBytes()),o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.OID,!1,o.oidToDer(c.oids.rsaEncryption).getBytes()),o.create(o.Class.UNIVERSAL,o.Type.NULL,!1,"")]),o.create(o.Class.UNIVERSAL,o.Type.OCTETSTRING,!1,o.toDer(e).getBytes())])},c.privateKeyFromAsn1=function(e){var t,r,s,a,u,f,h,p,g={},y=[];if(o.validate(e,l,g,y)&&(e=o.fromDer(i.util.createBuffer(g.privateKey))),g={},y=[],!o.validate(e,d,g,y)){var m=new Error("Cannot read private key. ASN.1 object does not contain an RSAPrivateKey.");throw m.errors=y,m}return t=i.util.createBuffer(g.privateKeyModulus).toHex(),r=i.util.createBuffer(g.privateKeyPublicExponent).toHex(),s=i.util.createBuffer(g.privateKeyPrivateExponent).toHex(),a=i.util.createBuffer(g.privateKeyPrime1).toHex(),u=i.util.createBuffer(g.privateKeyPrime2).toHex(),f=i.util.createBuffer(g.privateKeyExponent1).toHex(),h=i.util.createBuffer(g.privateKeyExponent2).toHex(),p=i.util.createBuffer(g.privateKeyCoefficient).toHex(),c.setRsaPrivateKey(new n(t,16),new n(r,16),new n(s,16),new n(a,16),new n(u,16),new n(f,16),new n(h,16),new n(p,16))},c.privateKeyToAsn1=c.privateKeyToRSAPrivateKey=function(e){return o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,o.integerToDer(0).getBytes()),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.n)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.e)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.d)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.p)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.q)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.dP)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.dQ)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.qInv))])},c.publicKeyFromAsn1=function(e){var t={},r=[];if(o.validate(e,h,t,r)){var s,a=o.derToOid(t.publicKeyOid);if(a!==c.oids.rsaEncryption)throw(s=new Error("Cannot read public key. Unknown OID.")).oid=a,s;e=t.rsaPublicKey}if(r=[],!o.validate(e,f,t,r))throw(s=new Error("Cannot read public key. ASN.1 object does not contain an RSAPublicKey.")).errors=r,s;var u=i.util.createBuffer(t.publicKeyModulus).toHex(),l=i.util.createBuffer(t.publicKeyExponent).toHex();return c.setRsaPublicKey(new n(u,16),new n(l,16))},c.publicKeyToAsn1=c.publicKeyToSubjectPublicKeyInfo=function(e){return o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.OID,!1,o.oidToDer(c.oids.rsaEncryption).getBytes()),o.create(o.Class.UNIVERSAL,o.Type.NULL,!1,"")]),o.create(o.Class.UNIVERSAL,o.Type.BITSTRING,!1,[c.publicKeyToRSAPublicKey(e)])])},c.publicKeyToRSAPublicKey=function(e){return o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.n)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.e))])}},{"./forge":"4OuPD","./asn1":"bcsXQ","./jsbn":"eeS3U","./oids":"7VPL4","./pkcs1":"2vXck","./prime":"ZaXlg","./random":"3tULm","./util":"df43p",crypto:"lHksA"}],eeS3U:[function(e,t,r){var i,n=e("./forge");t.exports=n.jsbn=n.jsbn||{};function s(e,t,r){this.data=[],null!=e&&("number"==typeof e?this.fromNumber(e,t,r):null==t&&"string"!=typeof e?this.fromString(e,256):this.fromString(e,t))}function o(){return new s(null)}function a(e,t,r,i,n,s){for(var o=16383&t,a=t>>14;--s>=0;){var c=16383&this.data[e],u=this.data[e++]>>14,l=a*c+u*o;n=((c=o*c+((16383&l)<<14)+r.data[i]+n)>>28)+(l>>14)+a*u,r.data[i++]=268435455&c}return n}n.jsbn.BigInteger=s,"undefined"==typeof navigator?(s.prototype.am=a,i=28):"Microsoft Internet Explorer"==navigator.appName?(s.prototype.am=function(e,t,r,i,n,s){for(var o=32767&t,a=t>>15;--s>=0;){var c=32767&this.data[e],u=this.data[e++]>>15,l=a*c+u*o;n=((c=o*c+((32767&l)<<15)+r.data[i]+(1073741823&n))>>>30)+(l>>>15)+a*u+(n>>>30),r.data[i++]=1073741823&c}return n},i=30):"Netscape"!=navigator.appName?(s.prototype.am=function(e,t,r,i,n,s){for(;--s>=0;){var o=t*this.data[e++]+r.data[i]+n;n=Math.floor(o/67108864),r.data[i++]=67108863&o}return n},i=26):(s.prototype.am=a,i=28),s.prototype.DB=i,s.prototype.DM=(1<>>16)&&(e=t,r+=16),0!=(t=e>>8)&&(e=t,r+=8),0!=(t=e>>4)&&(e=t,r+=4),0!=(t=e>>2)&&(e=t,r+=2),0!=(t=e>>1)&&(e=t,r+=1),r}function g(e){this.m=e}function y(e){this.m=e,this.mp=e.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,t+=16),0==(255&e)&&(e>>=8,t+=8),0==(15&e)&&(e>>=4,t+=4),0==(3&e)&&(e>>=2,t+=2),0==(1&e)&&++t,t}function E(e){for(var t=0;0!=e;)e&=e-1,++t;return t}function S(){}function T(e){return e}function A(e){this.r2=o(),this.q3=o(),s.ONE.dlShiftTo(2*e.t,this.r2),this.mu=this.r2.divide(e),this.m=e}g.prototype.convert=function(e){return e.s<0||e.compareTo(this.m)>=0?e.mod(this.m):e},g.prototype.revert=function(e){return e},g.prototype.reduce=function(e){e.divRemTo(this.m,null,e)},g.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r),this.reduce(r)},g.prototype.sqrTo=function(e,t){e.squareTo(t),this.reduce(t)},y.prototype.convert=function(e){var t=o();return e.abs().dlShiftTo(this.m.t,t),t.divRemTo(this.m,null,t),e.s<0&&t.compareTo(s.ZERO)>0&&this.m.subTo(t,t),t},y.prototype.revert=function(e){var t=o();return e.copyTo(t),this.reduce(t),t},y.prototype.reduce=function(e){for(;e.t<=this.mt2;)e.data[e.t++]=0;for(var t=0;t>15)*this.mpl&this.um)<<15)&e.DM;for(r=t+this.m.t,e.data[r]+=this.m.am(0,i,e,t,0,this.m.t);e.data[r]>=e.DV;)e.data[r]-=e.DV,e.data[++r]++}e.clamp(),e.drShiftTo(this.m.t,e),e.compareTo(this.m)>=0&&e.subTo(this.m,e)},y.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r),this.reduce(r)},y.prototype.sqrTo=function(e,t){e.squareTo(t),this.reduce(t)},s.prototype.copyTo=function(e){for(var t=this.t-1;t>=0;--t)e.data[t]=this.data[t];e.t=this.t,e.s=this.s},s.prototype.fromInt=function(e){this.t=1,this.s=e<0?-1:0,e>0?this.data[0]=e:e<-1?this.data[0]=e+this.DV:this.t=0},s.prototype.fromString=function(e,t){var r;if(16==t)r=4;else if(8==t)r=3;else if(256==t)r=8;else if(2==t)r=1;else if(32==t)r=5;else{if(4!=t)return void this.fromRadix(e,t);r=2}this.t=0,this.s=0;for(var i=e.length,n=!1,o=0;--i>=0;){var a=8==r?255&e[i]:f(e,i);a<0?"-"==e.charAt(i)&&(n=!0):(n=!1,0==o?this.data[this.t++]=a:o+r>this.DB?(this.data[this.t-1]|=(a&(1<>this.DB-o):this.data[this.t-1]|=a<=this.DB&&(o-=this.DB))}8==r&&0!=(128&e[0])&&(this.s=-1,o>0&&(this.data[this.t-1]|=(1<0&&this.data[this.t-1]==e;)--this.t},s.prototype.dlShiftTo=function(e,t){var r;for(r=this.t-1;r>=0;--r)t.data[r+e]=this.data[r];for(r=e-1;r>=0;--r)t.data[r]=0;t.t=this.t+e,t.s=this.s},s.prototype.drShiftTo=function(e,t){for(var r=e;r=0;--r)t.data[r+o+1]=this.data[r]>>n|a,a=(this.data[r]&s)<=0;--r)t.data[r]=0;t.data[o]=a,t.t=this.t+o+1,t.s=this.s,t.clamp()},s.prototype.rShiftTo=function(e,t){t.s=this.s;var r=Math.floor(e/this.DB);if(r>=this.t)t.t=0;else{var i=e%this.DB,n=this.DB-i,s=(1<>i;for(var o=r+1;o>i;i>0&&(t.data[this.t-r-1]|=(this.s&s)<>=this.DB;if(e.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=e.s}t.s=i<0?-1:0,i<-1?t.data[r++]=this.DV+i:i>0&&(t.data[r++]=i),t.t=r,t.clamp()},s.prototype.multiplyTo=function(e,t){var r=this.abs(),i=e.abs(),n=r.t;for(t.t=n+i.t;--n>=0;)t.data[n]=0;for(n=0;n=0;)e.data[r]=0;for(r=0;r=t.DV&&(e.data[r+t.t]-=t.DV,e.data[r+t.t+1]=1)}e.t>0&&(e.data[e.t-1]+=t.am(r,t.data[r],e,2*r,0,1)),e.s=0,e.clamp()},s.prototype.divRemTo=function(e,t,r){var i=e.abs();if(!(i.t<=0)){var n=this.abs();if(n.t0?(i.lShiftTo(l,a),n.lShiftTo(l,r)):(i.copyTo(a),n.copyTo(r));var d=a.t,f=a.data[d-1];if(0!=f){var h=f*(1<1?a.data[d-2]>>this.F2:0),g=this.FV/h,y=(1<=0&&(r.data[r.t++]=1,r.subTo(w,r)),s.ONE.dlShiftTo(d,w),w.subTo(a,a);a.t=0;){var _=r.data[--b]==f?this.DM:Math.floor(r.data[b]*g+(r.data[b-1]+m)*y);if((r.data[b]+=a.am(0,_,r,v,0,d))<_)for(a.dlShiftTo(v,w),r.subTo(w,r);r.data[b]<--_;)r.subTo(w,r)}null!=t&&(r.drShiftTo(d,t),c!=u&&s.ZERO.subTo(t,t)),r.t=d,r.clamp(),l>0&&r.rShiftTo(l,r),c<0&&s.ZERO.subTo(r,r)}}},s.prototype.invDigit=function(){if(this.t<1)return 0;var e=this.data[0];if(0==(1&e))return 0;var t=3&e;return(t=(t=(t=(t=t*(2-(15&e)*t)&15)*(2-(255&e)*t)&255)*(2-((65535&e)*t&65535))&65535)*(2-e*t%this.DV)%this.DV)>0?this.DV-t:-t},s.prototype.isEven=function(){return 0==(this.t>0?1&this.data[0]:this.s)},s.prototype.exp=function(e,t){if(e>4294967295||e<1)return s.ONE;var r=o(),i=o(),n=t.convert(this),a=p(e)-1;for(n.copyTo(r);--a>=0;)if(t.sqrTo(r,i),(e&1<0)t.mulTo(i,n,r);else{var c=r;r=i,i=c}return t.revert(r)},s.prototype.toString=function(e){if(this.s<0)return"-"+this.negate().toString(e);var t;if(16==e)t=4;else if(8==e)t=3;else if(2==e)t=1;else if(32==e)t=5;else{if(4!=e)return this.toRadix(e);t=2}var r,i=(1<0)for(a>a)>0&&(n=!0,s=d(r));o>=0;)a>(a+=this.DB-t)):(r=this.data[o]>>(a-=t)&i,a<=0&&(a+=this.DB,--o)),r>0&&(n=!0),n&&(s+=d(r));return n?s:"0"},s.prototype.negate=function(){var e=o();return s.ZERO.subTo(this,e),e},s.prototype.abs=function(){return this.s<0?this.negate():this},s.prototype.compareTo=function(e){var t=this.s-e.s;if(0!=t)return t;var r=this.t;if(0!=(t=r-e.t))return this.s<0?-t:t;for(;--r>=0;)if(0!=(t=this.data[r]-e.data[r]))return t;return 0},s.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+p(this.data[this.t-1]^this.s&this.DM)},s.prototype.mod=function(e){var t=o();return this.abs().divRemTo(e,null,t),this.s<0&&t.compareTo(s.ZERO)>0&&e.subTo(t,t),t},s.prototype.modPowInt=function(e,t){var r;return r=e<256||t.isEven()?new g(t):new y(t),this.exp(e,r)},s.ZERO=h(0),s.ONE=h(1),S.prototype.convert=T,S.prototype.revert=T,S.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r)},S.prototype.sqrTo=function(e,t){e.squareTo(t)},A.prototype.convert=function(e){if(e.s<0||e.t>2*this.m.t)return e.mod(this.m);if(e.compareTo(this.m)<0)return e;var t=o();return e.copyTo(t),this.reduce(t),t},A.prototype.revert=function(e){return e},A.prototype.reduce=function(e){for(e.drShiftTo(this.m.t-1,this.r2),e.t>this.m.t+1&&(e.t=this.m.t+1,e.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);e.compareTo(this.r2)<0;)e.dAddOffset(1,this.m.t+1);for(e.subTo(this.r2,e);e.compareTo(this.m)>=0;)e.subTo(this.m,e)},A.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r),this.reduce(r)},A.prototype.sqrTo=function(e,t){e.squareTo(t),this.reduce(t)};var k=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509],I=67108864/k[k.length-1];s.prototype.chunkSize=function(e){return Math.floor(Math.LN2*this.DB/Math.log(e))},s.prototype.toRadix=function(e){if(null==e&&(e=10),0==this.signum()||e<2||e>36)return"0";var t=this.chunkSize(e),r=Math.pow(e,t),i=h(r),n=o(),s=o(),a="";for(this.divRemTo(i,n,s);n.signum()>0;)a=(r+s.intValue()).toString(e).substr(1)+a,n.divRemTo(i,n,s);return s.intValue().toString(e)+a},s.prototype.fromRadix=function(e,t){this.fromInt(0),null==t&&(t=10);for(var r=this.chunkSize(t),i=Math.pow(t,r),n=!1,o=0,a=0,c=0;c=r&&(this.dMultiply(i),this.dAddOffset(a,0),o=0,a=0))}o>0&&(this.dMultiply(Math.pow(t,o)),this.dAddOffset(a,0)),n&&s.ZERO.subTo(this,this)},s.prototype.fromNumber=function(e,t,r){if("number"==typeof t)if(e<2)this.fromInt(1);else for(this.fromNumber(e,r),this.testBit(e-1)||this.bitwiseTo(s.ONE.shiftLeft(e-1),b,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(t);)this.dAddOffset(2,0),this.bitLength()>e&&this.subTo(s.ONE.shiftLeft(e-1),this);else{var i=new Array,n=7&e;i.length=1+(e>>3),t.nextBytes(i),n>0?i[0]&=(1<>=this.DB;if(e.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=e.s}t.s=i<0?-1:0,i>0?t.data[r++]=i:i<-1&&(t.data[r++]=this.DV+i),t.t=r,t.clamp()},s.prototype.dMultiply=function(e){this.data[this.t]=this.am(0,e-1,this,0,0,this.t),++this.t,this.clamp()},s.prototype.dAddOffset=function(e,t){if(0!=e){for(;this.t<=t;)this.data[this.t++]=0;for(this.data[t]+=e;this.data[t]>=this.DV;)this.data[t]-=this.DV,++t>=this.t&&(this.data[this.t++]=0),++this.data[t]}},s.prototype.multiplyLowerTo=function(e,t,r){var i,n=Math.min(this.t+e.t,t);for(r.s=0,r.t=n;n>0;)r.data[--n]=0;for(i=r.t-this.t;n=0;)r.data[i]=0;for(i=Math.max(t-this.t,0);i0)if(0==t)r=this.data[0]%e;else for(var i=this.t-1;i>=0;--i)r=(t*r+this.data[i])%e;return r},s.prototype.millerRabin=function(e){var t=this.subtract(s.ONE),r=t.getLowestSetBit();if(r<=0)return!1;for(var i,n=t.shiftRight(r),o={nextBytes:function(e){for(var t=0;t=0);var c=i.modPow(n,this);if(0!=c.compareTo(s.ONE)&&0!=c.compareTo(t)){for(var u=1;u++>24},s.prototype.shortValue=function(){return 0==this.t?this.s:this.data[0]<<16>>16},s.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this.data[0]<=0?0:1},s.prototype.toByteArray=function(){var e=this.t,t=new Array;t[0]=this.s;var r,i=this.DB-e*this.DB%8,n=0;if(e-- >0)for(i>i)!=(this.s&this.DM)>>i&&(t[n++]=r|this.s<=0;)i<8?(r=(this.data[e]&(1<>(i+=this.DB-8)):(r=this.data[e]>>(i-=8)&255,i<=0&&(i+=this.DB,--e)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(t[n++]=r);return t},s.prototype.equals=function(e){return 0==this.compareTo(e)},s.prototype.min=function(e){return this.compareTo(e)<0?this:e},s.prototype.max=function(e){return this.compareTo(e)>0?this:e},s.prototype.and=function(e){var t=o();return this.bitwiseTo(e,m,t),t},s.prototype.or=function(e){var t=o();return this.bitwiseTo(e,b,t),t},s.prototype.xor=function(e){var t=o();return this.bitwiseTo(e,v,t),t},s.prototype.andNot=function(e){var t=o();return this.bitwiseTo(e,w,t),t},s.prototype.not=function(){for(var e=o(),t=0;t=this.t?0!=this.s:0!=(this.data[t]&1<1){var d=o();for(i.sqrTo(a[1],d);c<=l;)a[c]=o(),i.mulTo(d,a[c-2],a[c]),c+=2}var f,m,b=e.t-1,v=!0,w=o();for(n=p(e.data[b])-1;b>=0;){for(n>=u?f=e.data[b]>>n-u&l:(f=(e.data[b]&(1<0&&(f|=e.data[b-1]>>this.DB+n-u)),c=r;0==(1&f);)f>>=1,--c;if((n-=c)<0&&(n+=this.DB,--b),v)a[f].copyTo(s),v=!1;else{for(;c>1;)i.sqrTo(s,w),i.sqrTo(w,s),c-=2;c>0?i.sqrTo(s,w):(m=s,s=w,w=m),i.mulTo(w,a[f],s)}for(;b>=0&&0==(e.data[b]&1<=0?(r.subTo(i,r),t&&n.subTo(a,n),o.subTo(c,o)):(i.subTo(r,i),t&&a.subTo(n,a),c.subTo(o,c))}return 0!=i.compareTo(s.ONE)?s.ZERO:c.compareTo(e)>=0?c.subtract(e):c.signum()<0?(c.addTo(e,c),c.signum()<0?c.add(e):c):c},s.prototype.pow=function(e){return this.exp(e,new S)},s.prototype.gcd=function(e){var t=this.s<0?this.negate():this.clone(),r=e.s<0?e.negate():e.clone();if(t.compareTo(r)<0){var i=t;t=r,r=i}var n=t.getLowestSetBit(),s=r.getLowestSetBit();if(s<0)return t;for(n0&&(t.rShiftTo(s,t),r.rShiftTo(s,r));t.signum()>0;)(n=t.getLowestSetBit())>0&&t.rShiftTo(n,t),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),t.compareTo(r)>=0?(t.subTo(r,t),t.rShiftTo(1,t)):(r.subTo(t,r),r.rShiftTo(1,r));return s>0&&r.lShiftTo(s,r),r},s.prototype.isProbablePrime=function(e){var t,r=this.abs();if(1==r.t&&r.data[0]<=k[k.length-1]){for(t=0;t>24&255,o>>16&255,o>>8&255,255&o);r.start(),r.update(e+a),n+=r.digest().getBytes()}return n.substring(0,t)}n.encode_rsa_oaep=function(e,t,r){var n,o,a,c;"string"==typeof r?(n=r,o=arguments[3]||void 0,a=arguments[4]||void 0):r&&(n=r.label||void 0,o=r.seed||void 0,a=r.md||void 0,r.mgf1&&r.mgf1.md&&(c=r.mgf1.md)),a?a.start():a=i.md.sha1.create(),c||(c=a);var u=Math.ceil(e.n.bitLength()/8),l=u-2*a.digestLength-2;if(t.length>l)throw(y=new Error("RSAES-OAEP input message length is too long.")).length=t.length,y.maxLength=l,y;n||(n=""),a.update(n,"raw");for(var d=a.digest(),f="",h=l-t.length,p=0;p>>0,c>>>0];for(var u=n.fullMessageLength.length-1;u>=0;--u)n.fullMessageLength[u]+=c[1],c[1]=c[0]+(n.fullMessageLength[u]/4294967296>>>0),n.fullMessageLength[u]=n.fullMessageLength[u]>>>0,c[0]=c[1]/4294967296>>>0;return t.putBytes(s),a(e,r,t),(t.read>2048||0===t.length())&&t.compact(),n},n.digest=function(){var o=i.util.createBuffer();o.putBytes(t.bytes());var c,u=n.fullMessageLength[n.fullMessageLength.length-1]+n.messageLengthSize&n.blockLength-1;o.putBytes(s.substr(0,n.blockLength-u));for(var l=8*n.fullMessageLength[0],d=0;d>>0,o.putInt32(l>>>0),l=c>>>0;o.putInt32(l);var f={h0:e.h0,h1:e.h1,h2:e.h2,h3:e.h3,h4:e.h4};a(f,r,o);var h=i.util.createBuffer();return h.putInt32(f.h0),h.putInt32(f.h1),h.putInt32(f.h2),h.putInt32(f.h3),h.putInt32(f.h4),h},n};var s=null,o=!1;function a(e,t,r){for(var i,n,s,o,a,c,u,l=r.length();l>=64;){for(n=e.h0,s=e.h1,o=e.h2,a=e.h3,c=e.h4,u=0;u<16;++u)i=r.getInt32(),t[u]=i,i=(n<<5|n>>>27)+(a^s&(o^a))+c+1518500249+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<20;++u)i=(i=t[u-3]^t[u-8]^t[u-14]^t[u-16])<<1|i>>>31,t[u]=i,i=(n<<5|n>>>27)+(a^s&(o^a))+c+1518500249+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<32;++u)i=(i=t[u-3]^t[u-8]^t[u-14]^t[u-16])<<1|i>>>31,t[u]=i,i=(n<<5|n>>>27)+(s^o^a)+c+1859775393+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<40;++u)i=(i=t[u-6]^t[u-16]^t[u-28]^t[u-32])<<2|i>>>30,t[u]=i,i=(n<<5|n>>>27)+(s^o^a)+c+1859775393+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<60;++u)i=(i=t[u-6]^t[u-16]^t[u-28]^t[u-32])<<2|i>>>30,t[u]=i,i=(n<<5|n>>>27)+(s&o|a&(s^o))+c+2400959708+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<80;++u)i=(i=t[u-6]^t[u-16]^t[u-28]^t[u-32])<<2|i>>>30,t[u]=i,i=(n<<5|n>>>27)+(s^o^a)+c+3395469782+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;e.h0=e.h0+n|0,e.h1=e.h1+s|0,e.h2=e.h2+o|0,e.h3=e.h3+a|0,e.h4=e.h4+c|0,l-=64}}},{"./forge":"4OuPD","./md":"fYbz5","./util":"df43p"}],ZaXlg:[function(e,t,r){var i=e("./forge");e("./util"),e("./jsbn"),e("./random"),function(){if(i.prime)t.exports=i.prime;else{var e=t.exports=i.prime=i.prime||{},r=i.jsbn.BigInteger,n=[6,4,2,4,2,4,6,2],s=new r(null);s.fromInt(30);var o=function(e,t){return e|t};e.generateProbablePrime=function(e,t,n){"function"==typeof t&&(n=t,t={});var s=(t=t||{}).algorithm||"PRIMEINC";"string"==typeof s&&(s={name:s}),s.options=s.options||{};var o=t.prng||i.random,c={nextBytes:function(e){for(var t=o.getBytesSync(e.length),r=0;re&&(o=u(e,t));var h=o.toString(16);n.target.postMessage({hex:h,workLoad:l}),o.dAddOffset(d,0)}}}h()}(e,t,n,s):a(e,t,n,s)}(e,c,s.options,n);throw new Error("Invalid prime generation algorithm: "+s.name)}}function a(e,t,r,i){var n=u(e,t),s=function(e){return e<=100?27:e<=150?18:e<=200?15:e<=250?12:e<=300?9:e<=350?8:e<=400?7:e<=500?6:e<=600?5:e<=800?4:e<=1250?3:2}(n.bitLength());"millerRabinTests"in r&&(s=r.millerRabinTests);var o=10;"maxBlockTime"in r&&(o=r.maxBlockTime),c(n,e,t,0,s,o,i)}function c(e,t,r,s,o,a,l){var d=+new Date;do{if(e.bitLength()>t&&(e=u(t,r)),e.isProbablePrime(o))return l(null,e);e.dAddOffset(n[s++%8],0)}while(a<0||+new Date-d{const t=e.crypto||e.msCrypto;if(!t||!t.subtle)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p-crypto/blob/master/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}},{}],"1sbpX":[function(e,t,r){"use strict";const{sha256:i}=e("multiformats/hashes/sha2"),n=e("err-code"),{equals:s}=e("uint8arrays/equals"),{toString:o}=e("uint8arrays/to-string");e("node-forge/lib/sha512"),e("node-forge/lib/ed25519");const a=e("node-forge/lib/forge"),c=e("./rsa"),u=e("./keys"),l=e("./exporter");class d{constructor(e){this._key=e}async verify(e,t){return c.hashAndVerify(this._key,t,e)}marshal(){return c.utils.jwkToPkix(this._key)}get bytes(){return u.PublicKey.encode({Type:u.KeyType.RSA,Data:this.marshal()}).finish()}encrypt(e){return c.encrypt(this._key,e)}equals(e){return s(this.bytes,e.bytes)}async hash(){const{bytes:e}=await i.digest(this.bytes);return e}}class f{constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return c.getRandomValues(16)}async sign(e){return c.hashAndSign(this._key,e)}get public(){if(!this._publicKey)throw n(new Error("public key not provided"),"ERR_PUBKEY_NOT_PROVIDED");return new d(this._publicKey)}decrypt(e){return c.decrypt(this._key,e)}marshal(){return c.utils.jwkToPkcs1(this._key)}get bytes(){return u.PrivateKey.encode({Type:u.KeyType.RSA,Data:this.marshal()}).finish()}equals(e){return s(this.bytes,e.bytes)}async hash(){const{bytes:e}=await i.digest(this.bytes);return e}async id(){const e=await this.public.hash();return o(e,"base58btc")}async export(e,t="pkcs-8"){if("pkcs-8"===t){const t=new a.util.ByteBuffer(this.marshal()),r=a.asn1.fromDer(t),i=a.pki.privateKeyFromAsn1(r),n={algorithm:"aes256",count:1e4,saltSize:16,prfAlgorithm:"sha512"};return a.pki.encryptRsaPrivateKey(i,e,n)}if("libp2p-key"===t)return l.export(this.bytes,e);throw n(new Error(`export format '${t}' is not supported`),"ERR_INVALID_EXPORT_FORMAT")}}t.exports={RsaPublicKey:d,RsaPrivateKey:f,unmarshalRsaPublicKey:function(e){const t=c.utils.pkixToJwk(e);return new d(t)},unmarshalRsaPrivateKey:async function(e){const t=c.utils.pkcs1ToJwk(e),r=await c.unmarshalPrivateKey(t);return new f(r.privateKey,r.publicKey)},generateKeyPair:async function(e){const t=await c.generateKey(e);return new f(t.privateKey,t.publicKey)},fromJwk:async function(e){const t=await c.unmarshalPrivateKey(e);return new f(t.privateKey,t.publicKey)}}},{"multiformats/hashes/sha2":"7i9MT","err-code":"chZjB","uint8arrays/equals":"eY3cX","uint8arrays/to-string":"hC8JB","node-forge/lib/sha512":"9XKJ9","node-forge/lib/ed25519":"9HAE7","node-forge/lib/forge":"4OuPD","./rsa":"5a3He","./keys":"jWSTZ","./exporter":"8qVel"}],"9XKJ9":[function(e,t,r){var i=e("./forge");e("./md"),e("./util");var n=t.exports=i.sha512=i.sha512||{};i.md.sha512=i.md.algorithms.sha512=n;var s=i.sha384=i.sha512.sha384=i.sha512.sha384||{};s.create=function(){return n.create("SHA-384")},i.md.sha384=i.md.algorithms.sha384=s,i.sha512.sha256=i.sha512.sha256||{create:function(){return n.create("SHA-512/256")}},i.md["sha512/256"]=i.md.algorithms["sha512/256"]=i.sha512.sha256,i.sha512.sha224=i.sha512.sha224||{create:function(){return n.create("SHA-512/224")}},i.md["sha512/224"]=i.md.algorithms["sha512/224"]=i.sha512.sha224,n.create=function(e){if(a||(o=String.fromCharCode(128),o+=i.util.fillString(String.fromCharCode(0),128),c=[[1116352408,3609767458],[1899447441,602891725],[3049323471,3964484399],[3921009573,2173295548],[961987163,4081628472],[1508970993,3053834265],[2453635748,2937671579],[2870763221,3664609560],[3624381080,2734883394],[310598401,1164996542],[607225278,1323610764],[1426881987,3590304994],[1925078388,4068182383],[2162078206,991336113],[2614888103,633803317],[3248222580,3479774868],[3835390401,2666613458],[4022224774,944711139],[264347078,2341262773],[604807628,2007800933],[770255983,1495990901],[1249150122,1856431235],[1555081692,3175218132],[1996064986,2198950837],[2554220882,3999719339],[2821834349,766784016],[2952996808,2566594879],[3210313671,3203337956],[3336571891,1034457026],[3584528711,2466948901],[113926993,3758326383],[338241895,168717936],[666307205,1188179964],[773529912,1546045734],[1294757372,1522805485],[1396182291,2643833823],[1695183700,2343527390],[1986661051,1014477480],[2177026350,1206759142],[2456956037,344077627],[2730485921,1290863460],[2820302411,3158454273],[3259730800,3505952657],[3345764771,106217008],[3516065817,3606008344],[3600352804,1432725776],[4094571909,1467031594],[275423344,851169720],[430227734,3100823752],[506948616,1363258195],[659060556,3750685593],[883997877,3785050280],[958139571,3318307427],[1322822218,3812723403],[1537002063,2003034995],[1747873779,3602036899],[1955562222,1575990012],[2024104815,1125592928],[2227730452,2716904306],[2361852424,442776044],[2428436474,593698344],[2756734187,3733110249],[3204031479,2999351573],[3329325298,3815920427],[3391569614,3928383900],[3515267271,566280711],[3940187606,3454069534],[4118630271,4000239992],[116418474,1914138554],[174292421,2731055270],[289380356,3203993006],[460393269,320620315],[685471733,587496836],[852142971,1086792851],[1017036298,365543100],[1126000580,2618297676],[1288033470,3409855158],[1501505948,4234509866],[1607167915,987167468],[1816402316,1246189591]],(u={})["SHA-512"]=[[1779033703,4089235720],[3144134277,2227873595],[1013904242,4271175723],[2773480762,1595750129],[1359893119,2917565137],[2600822924,725511199],[528734635,4215389547],[1541459225,327033209]],u["SHA-384"]=[[3418070365,3238371032],[1654270250,914150663],[2438529370,812702999],[355462360,4144912697],[1731405415,4290775857],[2394180231,1750603025],[3675008525,1694076839],[1203062813,3204075428]],u["SHA-512/256"]=[[573645204,4230739756],[2673172387,3360449730],[596883563,1867755857],[2520282905,1497426621],[2519219938,2827943907],[3193839141,1401305490],[721525244,746961066],[246885852,2177182882]],u["SHA-512/224"]=[[2352822216,424955298],[1944164710,2312950998],[502970286,855612546],[1738396948,1479516111],[258812777,2077511080],[2011393907,79989058],[1067287976,1780299464],[286451373,2446758561]],a=!0),void 0===e&&(e="SHA-512"),!(e in u))throw new Error("Invalid SHA-512 algorithm: "+e);for(var t=u[e],r=null,n=i.util.createBuffer(),s=new Array(80),d=0;d<80;++d)s[d]=new Array(2);var f=64;switch(e){case"SHA-384":f=48;break;case"SHA-512/256":f=32;break;case"SHA-512/224":f=28}var h={algorithm:e.replace("-","").toLowerCase(),blockLength:128,digestLength:f,messageLength:0,fullMessageLength:null,messageLengthSize:16,start:function(){h.messageLength=0,h.fullMessageLength=h.messageLength128=[];for(var e=h.messageLengthSize/4,s=0;s>>0,o>>>0];for(var a=h.fullMessageLength.length-1;a>=0;--a)h.fullMessageLength[a]+=o[1],o[1]=o[0]+(h.fullMessageLength[a]/4294967296>>>0),h.fullMessageLength[a]=h.fullMessageLength[a]>>>0,o[0]=o[1]/4294967296>>>0;return n.putBytes(e),l(r,s,n),(n.read>2048||0===n.length())&&n.compact(),h},h.digest=function(){var t=i.util.createBuffer();t.putBytes(n.bytes());var a,c=h.fullMessageLength[h.fullMessageLength.length-1]+h.messageLengthSize&h.blockLength-1;t.putBytes(o.substr(0,h.blockLength-c));for(var u=8*h.fullMessageLength[0],d=0;d>>0,t.putInt32(u>>>0),u=a>>>0;t.putInt32(u);var f=new Array(r.length);for(d=0;d=128;){for(O=0;O<16;++O)t[O][0]=r.getInt32()>>>0,t[O][1]=r.getInt32()>>>0;for(;O<80;++O)i=(((C=(D=t[O-2])[0])>>>19|(j=D[1])<<13)^(j>>>29|C<<3)^C>>>6)>>>0,n=((C<<13|j>>>19)^(j<<3|C>>>29)^(C<<26|j>>>6))>>>0,s=(((C=(x=t[O-15])[0])>>>1|(j=x[1])<<31)^(C>>>8|j<<24)^C>>>7)>>>0,o=((C<<31|j>>>1)^(C<<24|j>>>8)^(C<<25|j>>>7))>>>0,M=t[O-7],B=t[O-16],j=n+M[1]+o+B[1],t[O][0]=i+M[0]+s+B[0]+(j/4294967296>>>0)>>>0,t[O][1]=j>>>0;for(p=e[0][0],g=e[0][1],y=e[1][0],m=e[1][1],b=e[2][0],v=e[2][1],w=e[3][0],_=e[3][1],E=e[4][0],S=e[4][1],T=e[5][0],A=e[5][1],k=e[6][0],I=e[6][1],R=e[7][0],P=e[7][1],O=0;O<80;++O)l=((E>>>14|S<<18)^(E>>>18|S<<14)^(S>>>9|E<<23))>>>0,d=(k^E&(T^k))>>>0,a=((p>>>28|g<<4)^(g>>>2|p<<30)^(g>>>7|p<<25))>>>0,u=((p<<4|g>>>28)^(g<<30|p>>>2)^(g<<25|p>>>7))>>>0,f=(p&y|b&(p^y))>>>0,h=(g&m|v&(g^m))>>>0,j=P+(((E<<18|S>>>14)^(E<<14|S>>>18)^(S<<23|E>>>9))>>>0)+((I^S&(A^I))>>>0)+c[O][1]+t[O][1],i=R+l+d+c[O][0]+t[O][0]+(j/4294967296>>>0)>>>0,n=j>>>0,s=a+f+((j=u+h)/4294967296>>>0)>>>0,o=j>>>0,R=k,P=I,k=T,I=A,T=E,A=S,E=w+i+((j=_+n)/4294967296>>>0)>>>0,S=j>>>0,w=b,_=v,b=y,v=m,y=p,m=g,p=i+s+((j=n+o)/4294967296>>>0)>>>0,g=j>>>0;j=e[0][1]+g,e[0][0]=e[0][0]+p+(j/4294967296>>>0)>>>0,e[0][1]=j>>>0,j=e[1][1]+m,e[1][0]=e[1][0]+y+(j/4294967296>>>0)>>>0,e[1][1]=j>>>0,j=e[2][1]+v,e[2][0]=e[2][0]+b+(j/4294967296>>>0)>>>0,e[2][1]=j>>>0,j=e[3][1]+_,e[3][0]=e[3][0]+w+(j/4294967296>>>0)>>>0,e[3][1]=j>>>0,j=e[4][1]+S,e[4][0]=e[4][0]+E+(j/4294967296>>>0)>>>0,e[4][1]=j>>>0,j=e[5][1]+A,e[5][0]=e[5][0]+T+(j/4294967296>>>0)>>>0,e[5][1]=j>>>0,j=e[6][1]+I,e[6][0]=e[6][0]+k+(j/4294967296>>>0)>>>0,e[6][1]=j>>>0,j=e[7][1]+P,e[7][0]=e[7][0]+R+(j/4294967296>>>0)>>>0,e[7][1]=j>>>0,L-=128}}},{"./forge":"4OuPD","./md":"fYbz5","./util":"df43p"}],"9HAE7":[function(e,t,r){var i=e("buffer").Buffer,n=e("./forge");e("./jsbn"),e("./random"),e("./sha512"),e("./util");var s=e("./asn1-validator"),o=s.publicKeyValidator,a=s.privateKeyValidator;if(void 0===c)var c=n.jsbn.BigInteger;var u=n.util.ByteBuffer,l=void 0===i?Uint8Array:i;n.pki=n.pki||{},t.exports=n.pki.ed25519=n.ed25519=n.ed25519||{};var d=n.ed25519;function f(e){var t=e.message;if(t instanceof Uint8Array||t instanceof l)return t;var r=e.encoding;if(void 0===t){if(!e.md)throw new TypeError('"options.message" or "options.md" not specified.');t=e.md.digest().getBytes(),r="binary"}if("string"==typeof t&&!r)throw new TypeError('"options.encoding" must be "binary" or "utf8".');if("string"==typeof t){if(void 0!==i)return i.from(t,r);t=new u(t,r)}else if(!(t instanceof u))throw new TypeError('"options.message" must be a node.js Buffer, a Uint8Array, a forge ByteBuffer, or a string with "options.encoding" specifying its encoding.');for(var n=new l(t.length()),s=0;s=0;--r)U(i,i),1!==r&&F(i,i,t);for(r=0;r<16;++r)e[r]=i[r]}(r,r),F(r,r,n),F(r,r,s),F(r,r,s),F(e[0],r,s),U(i,e[0]),F(i,i,s),R(i,n)&&F(e[0],e[0],w);if(U(i,e[0]),F(i,i,s),R(i,n))return-1;O(e[0])===t[31]>>7&&N(e[0],h,e[0]);return F(e[3],e[0],e[1]),0}(a,i))return-1;for(n=0;n=0};var h=B(),p=B([1]),g=B([30883,4953,19914,30187,55467,16705,2637,112,59544,30585,16505,36039,65139,11119,27886,20995]),y=B([61785,9906,39828,60374,45398,33411,5274,224,53552,61171,33010,6542,64743,22239,55772,9222]),m=B([54554,36645,11616,51542,42930,38181,51040,26924,56412,64982,57905,49316,21502,52590,14035,8553]),b=B([26200,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214]),v=new Float64Array([237,211,245,92,26,99,18,88,214,156,247,162,222,249,222,20,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,16]),w=B([41136,18958,6951,50414,58488,44335,6150,12099,55207,15867,153,11085,57099,20417,9344,11139]);function _(e,t){var r=n.md.sha512.create(),s=new u(e);r.update(s.getBytes(t),"binary");var o=r.digest().getBytes();if(void 0!==i)return i.from(o,"binary");for(var a=new l(d.constants.HASH_BYTE_LENGTH),c=0;c<64;++c)a[c]=o.charCodeAt(c);return a}function E(e,t){var r,i,n,s;for(i=63;i>=32;--i){for(r=0,n=i-32,s=i-12;n>8,t[n]-=256*r;t[n]+=r,t[i]=0}for(r=0,n=0;n<32;++n)t[n]+=r-(t[31]>>4)*v[n],r=t[n]>>8,t[n]&=255;for(n=0;n<32;++n)t[n]-=r*v[n];for(i=0;i<32;++i)t[i+1]+=t[i]>>8,e[i]=255&t[i]}function S(e){for(var t=new Float64Array(64),r=0;r<64;++r)t[r]=e[r],e[r]=0;E(e,t)}function T(e,t){var r=B(),i=B(),n=B(),s=B(),o=B(),a=B(),c=B(),u=B(),l=B();N(r,e[1],e[0]),N(l,t[1],t[0]),F(r,r,l),L(i,e[0],e[1]),L(l,t[0],t[1]),F(i,i,l),F(n,e[3],t[3]),F(n,n,y),F(s,e[2],t[2]),L(s,s,s),N(o,i,r),N(a,s,n),L(c,s,n),L(u,i,r),F(e[0],o,a),F(e[1],u,c),F(e[2],c,a),F(e[3],o,u)}function A(e,t,r){for(var i=0;i<4;++i)x(e[i],t[i],r)}function k(e,t){var r=B(),i=B(),n=B();!function(e,t){var r,i=B();for(r=0;r<16;++r)i[r]=t[r];for(r=253;r>=0;--r)U(i,i),2!==r&&4!==r&&F(i,i,t);for(r=0;r<16;++r)e[r]=i[r]}(n,t[2]),F(r,t[0],n),F(i,t[1],n),I(e,i),e[31]^=O(r)<<7}function I(e,t){var r,i,n,s=B(),o=B();for(r=0;r<16;++r)o[r]=t[r];for(M(o),M(o),M(o),i=0;i<2;++i){for(s[0]=o[0]-65517,r=1;r<15;++r)s[r]=o[r]-65535-(s[r-1]>>16&1),s[r-1]&=65535;s[15]=o[15]-32767-(s[14]>>16&1),n=s[15]>>16&1,s[14]&=65535,x(o,s,1-n)}for(r=0;r<16;r++)e[2*r]=255&o[r],e[2*r+1]=o[r]>>8}function R(e,t){var r=new l(32),i=new l(32);return I(r,e),I(i,t),P(r,0,i,0)}function P(e,t,r,i){return function(e,t,r,i,n){var s,o=0;for(s=0;s>>8)-1}(e,t,r,i,32)}function O(e){var t=new l(32);return I(t,e),1&t[0]}function C(e,t,r){var i,n;for(D(e[0],h),D(e[1],p),D(e[2],p),D(e[3],h),n=255;n>=0;--n)A(e,t,i=r[n/8|0]>>(7&n)&1),T(t,e),T(e,e),A(e,t,i)}function j(e,t){var r=[B(),B(),B(),B()];D(r[0],m),D(r[1],b),D(r[2],p),F(r[3],m,b),C(e,r,t)}function D(e,t){var r;for(r=0;r<16;r++)e[r]=0|t[r]}function M(e){var t,r,i=1;for(t=0;t<16;++t)r=e[t]+i+65535,i=Math.floor(r/65536),e[t]=r-65536*i;e[0]+=i-1+37*(i-1)}function x(e,t,r){for(var i,n=~(r-1),s=0;s<16;++s)i=n&(e[s]^t[s]),e[s]^=i,t[s]^=i}function B(e){var t,r=new Float64Array(16);if(e)for(t=0;tt.encrypt(e)))},r.decrypt=function(e,t){return l(e,!1,t,((e,t)=>t.decrypt(e)))}},{"../webcrypto":"i99ng","../random-bytes":"gsnuW","uint8arrays/to-string":"hC8JB","uint8arrays/from-string":"dF7Y4","./rsa-utils":"3gF4s","./jwk2pem":"4kPkh"}],gsnuW:[function(e,t,r){"use strict";const i=e("iso-random-stream/src/random"),n=e("err-code");t.exports=function(e){if(isNaN(e)||e<=0)throw n(new Error("random bytes length must be a Number bigger than 0"),"ERR_INVALID_LENGTH");return i(e)}},{"iso-random-stream/src/random":"bIbEo","err-code":"chZjB"}],bIbEo:[function(e,t,r){"use strict";const i=65536;t.exports=function(e){const t=new Uint8Array(e);let r=0;if(e>0)if(e>i)for(;re?(crypto.getRandomValues(t.subarray(r,r+(e-r))),r+=e-r):(crypto.getRandomValues(t.subarray(r,r+i)),r+=i);else crypto.getRandomValues(t);return t}},{}],"3gF4s":[function(e,t,r){"use strict";e("node-forge/lib/asn1"),e("node-forge/lib/rsa");const i=e("node-forge/lib/forge"),{bigIntegerToUintBase64url:n,base64urlToBigInteger:s}=e("./../util"),{fromString:o}=e("uint8arrays/from-string"),{toString:a}=e("uint8arrays/to-string");r.pkcs1ToJwk=function(e){const t=i.asn1.fromDer(a(e,"ascii")),r=i.pki.privateKeyFromAsn1(t);return{kty:"RSA",n:n(r.n),e:n(r.e),d:n(r.d),p:n(r.p),q:n(r.q),dp:n(r.dP),dq:n(r.dQ),qi:n(r.qInv),alg:"RS256",kid:"2011-04-29"}},r.jwkToPkcs1=function(e){const t=i.pki.privateKeyToAsn1({n:s(e.n),e:s(e.e),d:s(e.d),p:s(e.p),q:s(e.q),dP:s(e.dp),dQ:s(e.dq),qInv:s(e.qi)});return o(i.asn1.toDer(t).getBytes(),"ascii")},r.pkixToJwk=function(e){const t=i.asn1.fromDer(a(e,"ascii")),r=i.pki.publicKeyFromAsn1(t);return{kty:"RSA",n:n(r.n),e:n(r.e),alg:"RS256",kid:"2011-04-29"}},r.jwkToPkix=function(e){const t=i.pki.publicKeyToAsn1({n:s(e.n),e:s(e.e)});return o(i.asn1.toDer(t).getBytes(),"ascii")}},{"node-forge/lib/asn1":"bcsXQ","node-forge/lib/rsa":"9ROH2","node-forge/lib/forge":"4OuPD","./../util":"ffmp6","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB"}],ffmp6:[function(e,t,r){"use strict";e("node-forge/lib/util"),e("node-forge/lib/jsbn");const i=e("node-forge/lib/forge"),{fromString:n}=e("uint8arrays/from-string"),{toString:s}=e("uint8arrays/to-string"),{concat:o}=e("uint8arrays/concat");r.bigIntegerToUintBase64url=(e,t)=>{let r=Uint8Array.from(e.abs().toByteArray());if(r=0===r[0]?r.slice(1):r,null!=t){if(r.length>t)throw new Error("byte array longer than desired length");r=o([new Uint8Array(t-r.length),r])}return s(r,"base64url")},r.base64urlToBigInteger=e=>{const t=r.base64urlToBuffer(e);return new i.jsbn.BigInteger(s(t,"base16"),16)},r.base64urlToBuffer=(e,t)=>{let r=n(e,"base64urlpad");if(null!=t){if(r.length>t)throw new Error("byte array longer than desired length");r=o([new Uint8Array(t-r.length),r])}return r}},{"node-forge/lib/util":"df43p","node-forge/lib/jsbn":"eeS3U","node-forge/lib/forge":"4OuPD","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB","uint8arrays/concat":"4EBjG"}],"4kPkh":[function(e,t,r){"use strict";e("node-forge/lib/rsa");const i=e("node-forge/lib/forge"),{base64urlToBigInteger:n}=e("../util");function s(e,t){return t.map((t=>n(e[t])))}t.exports={jwk2pub:function(e){return i.pki.setRsaPublicKey(...s(e,["n","e"]))},jwk2priv:function(e){return i.pki.setRsaPrivateKey(...s(e,["n","e","d","p","q","dp","dq","qi"]))}}},{"node-forge/lib/rsa":"9ROH2","node-forge/lib/forge":"4OuPD","../util":"ffmp6"}],"8qVel":[function(e,t,r){"use strict";const{base64:i}=e("multiformats/bases/base64"),n=e("../ciphers/aes-gcm");t.exports={export:async function(e,t){const r=n.create(),s=await r.encrypt(e,t);return i.encode(s)}}},{"multiformats/bases/base64":"gaFBW","../ciphers/aes-gcm":"92UH6"}],dh3ng:[function(e,t,r){"use strict";const i=e("err-code"),{equals:n}=e("uint8arrays/equals"),{sha256:s}=e("multiformats/hashes/sha2"),{base58btc:o}=e("multiformats/bases/base58"),{identity:a}=e("multiformats/hashes/identity"),c=e("./ed25519"),u=e("./keys"),l=e("./exporter");class d{constructor(e){this._key=h(e,c.publicKeyLength)}async verify(e,t){return c.hashAndVerify(this._key,t,e)}marshal(){return this._key}get bytes(){return u.PublicKey.encode({Type:u.KeyType.Ed25519,Data:this.marshal()}).finish()}equals(e){return n(this.bytes,e.bytes)}async hash(){const{bytes:e}=await s.digest(this.bytes);return e}}class f{constructor(e,t){this._key=h(e,c.privateKeyLength),this._publicKey=h(t,c.publicKeyLength)}async sign(e){return c.hashAndSign(this._key,e)}get public(){return new d(this._publicKey)}marshal(){return this._key}get bytes(){return u.PrivateKey.encode({Type:u.KeyType.Ed25519,Data:this.marshal()}).finish()}equals(e){return n(this.bytes,e.bytes)}async hash(){const{bytes:e}=await s.digest(this.bytes);return e}async id(){const e=await a.digest(this.public.bytes);return o.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if("libp2p-key"===t)return l.export(this.bytes,e);throw i(new Error(`export format '${t}' is not supported`),"ERR_INVALID_EXPORT_FORMAT")}}function h(e,t){if((e=Uint8Array.from(e||[])).length!==t)throw i(new Error(`Key must be a Uint8Array of length ${t}, got ${e.length}`),"ERR_INVALID_KEY_TYPE");return e}t.exports={Ed25519PublicKey:d,Ed25519PrivateKey:f,unmarshalEd25519PrivateKey:function(e){if(e.length>c.privateKeyLength){const t=(e=h(e,c.privateKeyLength+c.publicKeyLength)).slice(0,c.privateKeyLength),r=e.slice(c.privateKeyLength,e.length);return new f(t,r)}const t=(e=h(e,c.privateKeyLength)).slice(0,c.privateKeyLength),r=e.slice(c.publicKeyLength);return new f(t,r)},unmarshalEd25519PublicKey:function(e){return e=h(e,c.publicKeyLength),new d(e)},generateKeyPair:async function(){const{privateKey:e,publicKey:t}=await c.generateKey();return new f(e,t)},generateKeyPairFromSeed:async function(e){const{privateKey:t,publicKey:r}=await c.generateKeyFromSeed(e);return new f(t,r)}}},{"err-code":"chZjB","uint8arrays/equals":"eY3cX","multiformats/hashes/sha2":"7i9MT","multiformats/bases/base58":"4n7mA","multiformats/hashes/identity":"eYCZn","./ed25519":"8jlvB","./keys":"jWSTZ","./exporter":"8qVel"}],"8jlvB":[function(e,t,r){"use strict";e("node-forge/lib/ed25519");const i=e("node-forge/lib/forge");r.publicKeyLength=i.pki.ed25519.constants.PUBLIC_KEY_BYTE_LENGTH,r.privateKeyLength=i.pki.ed25519.constants.PRIVATE_KEY_BYTE_LENGTH,r.generateKey=async function(){return i.pki.ed25519.generateKeyPair()},r.generateKeyFromSeed=async function(e){return i.pki.ed25519.generateKeyPair({seed:e})},r.hashAndSign=async function(e,t){return i.pki.ed25519.sign({message:t,privateKey:e})},r.hashAndVerify=async function(e,t,r){return i.pki.ed25519.verify({signature:t,message:r,publicKey:e})}},{"node-forge/lib/ed25519":"9HAE7","node-forge/lib/forge":"4OuPD"}],jXCAP:[function(e,t,r){"use strict";const{sha256:i}=e("multiformats/hashes/sha2"),n=e("err-code"),{equals:s}=e("uint8arrays/equals"),{toString:o}=e("uint8arrays/to-string"),a=e("./exporter");t.exports=(t,r,c)=>{c=c||e("./secp256k1")(r);class u{constructor(e){c.validatePublicKey(e),this._key=e}verify(e,t){return c.hashAndVerify(this._key,t,e)}marshal(){return c.compressPublicKey(this._key)}get bytes(){return t.PublicKey.encode({Type:t.KeyType.Secp256k1,Data:this.marshal()}).finish()}equals(e){return s(this.bytes,e.bytes)}async hash(){const{bytes:e}=await i.digest(this.bytes);return e}}class l{constructor(e,t){this._key=e,this._publicKey=t||c.computePublicKey(e),c.validatePrivateKey(this._key),c.validatePublicKey(this._publicKey)}sign(e){return c.hashAndSign(this._key,e)}get public(){return new u(this._publicKey)}marshal(){return this._key}get bytes(){return t.PrivateKey.encode({Type:t.KeyType.Secp256k1,Data:this.marshal()}).finish()}equals(e){return s(this.bytes,e.bytes)}async hash(){const{bytes:e}=await i.digest(this.bytes);return e}async id(){const e=await this.public.hash();return o(e,"base58btc")}async export(e,t="libp2p-key"){if("libp2p-key"===t)return a.export(this.bytes,e);throw n(new Error(`export format '${t}' is not supported`),"ERR_INVALID_EXPORT_FORMAT")}}return{Secp256k1PublicKey:u,Secp256k1PrivateKey:l,unmarshalSecp256k1PrivateKey:function(e){return new l(e)},unmarshalSecp256k1PublicKey:function(e){return new u(e)},generateKeyPair:async function(){const e=await c.generateKey();return new l(e)}}}},{"multiformats/hashes/sha2":"7i9MT","err-code":"chZjB","uint8arrays/equals":"eY3cX","uint8arrays/to-string":"hC8JB","./exporter":"8qVel","./secp256k1":"e9sAH"}],e9sAH:[function(e,t,r){"use strict";const i=e("secp256k1"),{sha256:n}=e("multiformats/hashes/sha2");t.exports=e=>{function t(e){if(!i.privateKeyVerify(e))throw new Error("Invalid private key")}return{generateKey:function(){let t;do{t=e(32)}while(!i.privateKeyVerify(t));return t},privateKeyLength:32,hashAndSign:async function(e,t){const{digest:r}=await n.digest(t),s=i.ecdsaSign(r,e);return i.signatureExport(s.signature)},hashAndVerify:async function(e,t,r){const{digest:s}=await n.digest(r);return t=i.signatureImport(t),i.ecdsaVerify(t,s,e)},compressPublicKey:function(e){if(!i.publicKeyVerify(e))throw new Error("Invalid public key");return i.publicKeyConvert(e,!0)},decompressPublicKey:function(e){return i.publicKeyConvert(e,!1)},validatePrivateKey:t,validatePublicKey:function(e){if(!i.publicKeyVerify(e))throw new Error("Invalid public key")},computePublicKey:function(e){return t(e),i.publicKeyCreate(e)}}}},{secp256k1:"5e78P","multiformats/hashes/sha2":"7i9MT"}],"5e78P":[function(e,t,r){t.exports=e("./lib")(e("./lib/elliptic"))},{"./lib":"f9Aan","./lib/elliptic":"7HHQM"}],f9Aan:[function(e,t,r){const i="Impossible case. Please create issue.",n="The tweak was out of range or the resulted private key is invalid",s="The tweak was out of range or equal to zero",o="Unknow error on context randomization",a="Private Key is invalid",c="Public Key could not be parsed",u="Public Key serialization error",l="The sum of the public keys is not valid",d="Signature could not be parsed",f="The nonce generation function failed, or the private key was invalid",h="Public key could not be recover",p="Scalar was invalid (zero or overflow)";function g(e,t){if(!e)throw new Error(t)}function y(e,t,r){if(g(t instanceof Uint8Array,`Expected ${e} to be an Uint8Array`),void 0!==r)if(Array.isArray(r)){const i=`Expected ${e} to be an Uint8Array with length [${r.join(", ")}]`;g(r.includes(t.length),i)}else{const i=`Expected ${e} to be an Uint8Array with length ${r}`;g(t.length===r,i)}}function m(e){g("Boolean"===v(e),"Expected compressed to be a Boolean")}function b(e=(e=>new Uint8Array(e)),t){return"function"==typeof e&&(e=e(t)),y("output",e,t),e}function v(e){return Object.prototype.toString.call(e).slice(8,-1)}t.exports=e=>({contextRandomize(t){if(g(null===t||t instanceof Uint8Array,"Expected seed to be an Uint8Array or null"),null!==t&&y("seed",t,32),1===e.contextRandomize(t))throw new Error(o)},privateKeyVerify:t=>(y("private key",t,32),0===e.privateKeyVerify(t)),privateKeyNegate(t){switch(y("private key",t,32),e.privateKeyNegate(t)){case 0:return t;case 1:throw new Error(i)}},privateKeyTweakAdd(t,r){switch(y("private key",t,32),y("tweak",r,32),e.privateKeyTweakAdd(t,r)){case 0:return t;case 1:throw new Error(n)}},privateKeyTweakMul(t,r){switch(y("private key",t,32),y("tweak",r,32),e.privateKeyTweakMul(t,r)){case 0:return t;case 1:throw new Error(s)}},publicKeyVerify:t=>(y("public key",t,[33,65]),0===e.publicKeyVerify(t)),publicKeyCreate(t,r=!0,i){switch(y("private key",t,32),m(r),i=b(i,r?33:65),e.publicKeyCreate(i,t)){case 0:return i;case 1:throw new Error(a);case 2:throw new Error(u)}},publicKeyConvert(t,r=!0,i){switch(y("public key",t,[33,65]),m(r),i=b(i,r?33:65),e.publicKeyConvert(i,t)){case 0:return i;case 1:throw new Error(c);case 2:throw new Error(u)}},publicKeyNegate(t,r=!0,n){switch(y("public key",t,[33,65]),m(r),n=b(n,r?33:65),e.publicKeyNegate(n,t)){case 0:return n;case 1:throw new Error(c);case 2:throw new Error(i);case 3:throw new Error(u)}},publicKeyCombine(t,r=!0,i){g(Array.isArray(t),"Expected public keys to be an Array"),g(t.length>0,"Expected public keys array will have more than zero items");for(const e of t)y("public key",e,[33,65]);switch(m(r),i=b(i,r?33:65),e.publicKeyCombine(i,t)){case 0:return i;case 1:throw new Error(c);case 2:throw new Error(l);case 3:throw new Error(u)}},publicKeyTweakAdd(t,r,i=!0,s){switch(y("public key",t,[33,65]),y("tweak",r,32),m(i),s=b(s,i?33:65),e.publicKeyTweakAdd(s,t,r)){case 0:return s;case 1:throw new Error(c);case 2:throw new Error(n)}},publicKeyTweakMul(t,r,i=!0,n){switch(y("public key",t,[33,65]),y("tweak",r,32),m(i),n=b(n,i?33:65),e.publicKeyTweakMul(n,t,r)){case 0:return n;case 1:throw new Error(c);case 2:throw new Error(s)}},signatureNormalize(t){switch(y("signature",t,64),e.signatureNormalize(t)){case 0:return t;case 1:throw new Error(d)}},signatureExport(t,r){y("signature",t,64);const n={output:r=b(r,72),outputlen:72};switch(e.signatureExport(n,t)){case 0:return r.slice(0,n.outputlen);case 1:throw new Error(d);case 2:throw new Error(i)}},signatureImport(t,r){switch(y("signature",t),r=b(r,64),e.signatureImport(r,t)){case 0:return r;case 1:throw new Error(d);case 2:throw new Error(i)}},ecdsaSign(t,r,n={},s){y("message",t,32),y("private key",r,32),g("Object"===v(n),"Expected options to be an Object"),void 0!==n.data&&y("options.data",n.data),void 0!==n.noncefn&&g("Function"===v(n.noncefn),"Expected options.noncefn to be a Function");const o={signature:s=b(s,64),recid:null};switch(e.ecdsaSign(o,t,r,n.data,n.noncefn)){case 0:return o;case 1:throw new Error(f);case 2:throw new Error(i)}},ecdsaVerify(t,r,i){switch(y("signature",t,64),y("message",r,32),y("public key",i,[33,65]),e.ecdsaVerify(t,r,i)){case 0:return!0;case 3:return!1;case 1:throw new Error(d);case 2:throw new Error(c)}},ecdsaRecover(t,r,n,s=!0,o){switch(y("signature",t,64),g("Number"===v(r)&&r>=0&&r<=3,"Expected recovery id to be a Number within interval [0, 3]"),y("message",n,32),m(s),o=b(o,s?33:65),e.ecdsaRecover(o,t,r,n)){case 0:return o;case 1:throw new Error(d);case 2:throw new Error(h);case 3:throw new Error(i)}},ecdh(t,r,i={},n){switch(y("public key",t,[33,65]),y("private key",r,32),g("Object"===v(i),"Expected options to be an Object"),void 0!==i.data&&y("options.data",i.data),void 0!==i.hashfn?(g("Function"===v(i.hashfn),"Expected options.hashfn to be a Function"),void 0!==i.xbuf&&y("options.xbuf",i.xbuf,32),void 0!==i.ybuf&&y("options.ybuf",i.ybuf,32),y("output",n)):n=b(n,32),e.ecdh(n,t,r,i.data,i.hashfn,i.xbuf,i.ybuf)){case 0:return n;case 1:throw new Error(c);case 2:throw new Error(p)}}})},{}],"7HHQM":[function(e,t,r){const i=new(0,e("elliptic").ec)("secp256k1"),n=i.curve,s=n.n.constructor;function o(e){const t=e[0];switch(t){case 2:case 3:return 33!==e.length?null:function(e,t){let r=new s(t);if(r.cmp(n.p)>=0)return null;r=r.toRed(n.red);let o=r.redSqr().redIMul(r).redIAdd(n.b).redSqrt();return 3===e!==o.isOdd()&&(o=o.redNeg()),i.keyPair({pub:{x:r,y:o}})}(t,e.subarray(1,33));case 4:case 6:case 7:return 65!==e.length?null:function(e,t,r){let o=new s(t),a=new s(r);if(o.cmp(n.p)>=0||a.cmp(n.p)>=0)return null;if(o=o.toRed(n.red),a=a.toRed(n.red),(6===e||7===e)&&a.isOdd()!==(7===e))return null;const c=o.redSqr().redIMul(o);return a.redSqr().redISub(c.redIAdd(n.b)).isZero()?i.keyPair({pub:{x:o,y:a}}):null}(t,e.subarray(1,33),e.subarray(33,65));default:return null}}function a(e,t){const r=t.encode(null,33===e.length);for(let t=0;t0,privateKeyVerify(e){const t=new s(e);return t.cmp(n.n)<0&&!t.isZero()?0:1},privateKeyNegate(e){const t=new s(e),r=n.n.sub(t).umod(n.n).toArrayLike(Uint8Array,"be",32);return e.set(r),0},privateKeyTweakAdd(e,t){const r=new s(t);if(r.cmp(n.n)>=0)return 1;if(r.iadd(new s(e)),r.cmp(n.n)>=0&&r.isub(n.n),r.isZero())return 1;const i=r.toArrayLike(Uint8Array,"be",32);return e.set(i),0},privateKeyTweakMul(e,t){let r=new s(t);if(r.cmp(n.n)>=0||r.isZero())return 1;r.imul(new s(e)),r.cmp(n.n)>=0&&(r=r.umod(n.n));const i=r.toArrayLike(Uint8Array,"be",32);return e.set(i),0},publicKeyVerify:e=>null===o(e)?1:0,publicKeyCreate(e,t){const r=new s(t);if(r.cmp(n.n)>=0||r.isZero())return 1;return a(e,i.keyFromPrivate(t).getPublic()),0},publicKeyConvert(e,t){const r=o(t);if(null===r)return 1;return a(e,r.getPublic()),0},publicKeyNegate(e,t){const r=o(t);if(null===r)return 1;const i=r.getPublic();return i.y=i.y.redNeg(),a(e,i),0},publicKeyCombine(e,t){const r=new Array(t.length);for(let e=0;e=0)return 2;const c=i.getPublic().add(n.g.mul(r));return c.isInfinity()?2:(a(e,c),0)},publicKeyTweakMul(e,t,r){const i=o(t);if(null===i)return 1;if((r=new s(r)).cmp(n.n)>=0||r.isZero())return 2;return a(e,i.getPublic().mul(r)),0},signatureNormalize(e){const t=new s(e.subarray(0,32)),r=new s(e.subarray(32,64));return t.cmp(n.n)>=0||r.cmp(n.n)>=0?1:(1===r.cmp(i.nh)&&e.set(n.n.sub(r).toArrayLike(Uint8Array,"be",32),32),0)},signatureExport(e,t){const r=t.subarray(0,32),i=t.subarray(32,64);if(new s(r).cmp(n.n)>=0)return 1;if(new s(i).cmp(n.n)>=0)return 1;const{output:o}=e;let a=o.subarray(4,37);a[0]=0,a.set(r,1);let c=33,u=0;for(;c>1&&0===a[u]&&!(128&a[u+1]);--c,++u);if(a=a.subarray(u),128&a[0])return 1;if(c>1&&0===a[0]&&!(128&a[1]))return 1;let l=o.subarray(39,72);l[0]=0,l.set(i,1);let d=33,f=0;for(;d>1&&0===l[f]&&!(128&l[f+1]);--d,++f);return l=l.subarray(f),128&l[0]||d>1&&0===l[0]&&!(128&l[1])?1:(e.outputlen=6+c+d,o[0]=48,o[1]=e.outputlen-2,o[2]=2,o[3]=a.length,o.set(a,4),o[4+c]=2,o[5+c]=l.length,o.set(l,6+c),0)},signatureImport(e,t){if(t.length<8)return 1;if(t.length>72)return 1;if(48!==t[0])return 1;if(t[1]!==t.length-2)return 1;if(2!==t[2])return 1;const r=t[3];if(0===r)return 1;if(5+r>=t.length)return 1;if(2!==t[4+r])return 1;const i=t[5+r];if(0===i)return 1;if(6+r+i!==t.length)return 1;if(128&t[4])return 1;if(r>1&&0===t[4]&&!(128&t[5]))return 1;if(128&t[r+6])return 1;if(i>1&&0===t[r+6]&&!(128&t[r+7]))return 1;let o=t.subarray(4,4+r);if(33===o.length&&0===o[0]&&(o=o.subarray(1)),o.length>32)return 1;let a=t.subarray(6+r);if(33===a.length&&0===a[0]&&(a=a.slice(1)),a.length>32)throw new Error("S length is too long");let c=new s(o);c.cmp(n.n)>=0&&(c=new s(0));let u=new s(t.subarray(6+r));return u.cmp(n.n)>=0&&(u=new s(0)),e.set(c.toArrayLike(Uint8Array,"be",32),0),e.set(u.toArrayLike(Uint8Array,"be",32),32),0},ecdsaSign(e,t,r,o,a){if(a){const e=a;a=i=>{const n=e(t,r,null,o,i);if(!(n instanceof Uint8Array&&32===n.length))throw new Error("This is the way");return new s(n)}}const c=new s(r);if(c.cmp(n.n)>=0||c.isZero())return 1;let u;try{u=i.sign(t,r,{canonical:!0,k:a,pers:o})}catch(e){return 1}return e.signature.set(u.r.toArrayLike(Uint8Array,"be",32),0),e.signature.set(u.s.toArrayLike(Uint8Array,"be",32),32),e.recid=u.recoveryParam,0},ecdsaVerify(e,t,r){const a={r:e.subarray(0,32),s:e.subarray(32,64)},c=new s(a.r),u=new s(a.s);if(c.cmp(n.n)>=0||u.cmp(n.n)>=0)return 1;if(1===u.cmp(i.nh)||c.isZero()||u.isZero())return 3;const l=o(r);if(null===l)return 2;const d=l.getPublic();return i.verify(t,a,d)?0:3},ecdsaRecover(e,t,r,o){const c={r:t.slice(0,32),s:t.slice(32,64)},u=new s(c.r),l=new s(c.s);if(u.cmp(n.n)>=0||l.cmp(n.n)>=0)return 1;if(u.isZero()||l.isZero())return 2;let d;try{d=i.recoverPubKey(o,c,r)}catch(e){return 2}return a(e,d),0},ecdh(e,t,r,a,c,u,l){const d=o(t);if(null===d)return 1;const f=new s(r);if(f.cmp(n.n)>=0||f.isZero())return 2;const h=d.getPublic().mul(f);if(void 0===c){const t=h.encode(null,!0),r=i.hash().update(t).digest();for(let t=0;t<32;++t)e[t]=r[t]}else{u||(u=new Uint8Array(32));const t=h.getX().toArray("be",32);for(let e=0;e<32;++e)u[e]=t[e];l||(l=new Uint8Array(32));const r=h.getY().toArray("be",32);for(let e=0;e<32;++e)l[e]=r[e];const i=c(u,l,a);if(!(i instanceof Uint8Array&&i.length===e.length))return 2;e.set(i)}return 0}}},{elliptic:"g2Vtb"}],g2Vtb:[function(e,t,r){"use strict";var i=r;i.version=e("../package.json").version,i.utils=e("./elliptic/utils"),i.rand=e("brorand"),i.curve=e("./elliptic/curve"),i.curves=e("./elliptic/curves"),i.ec=e("./elliptic/ec"),i.eddsa=e("./elliptic/eddsa")},{"../package.json":"ejBaf","./elliptic/utils":"959xT",brorand:"P54o1","./elliptic/curve":"byDyH","./elliptic/curves":"4unkA","./elliptic/ec":"5AnhI","./elliptic/eddsa":"j2H5w"}],ejBaf:[function(e,t,r){t.exports=JSON.parse('{"name":"elliptic","version":"6.5.4","description":"EC cryptography","main":"lib/elliptic.js","files":["lib"],"scripts":{"lint":"eslint lib test","lint:fix":"npm run lint -- --fix","unit":"istanbul test _mocha --reporter=spec test/index.js","test":"npm run lint && npm run unit","version":"grunt dist && git add dist/"},"repository":{"type":"git","url":"git@github.com:indutny/elliptic"},"keywords":["EC","Elliptic","curve","Cryptography"],"author":"Fedor Indutny ","license":"MIT","bugs":{"url":"https://github.com/indutny/elliptic/issues"},"homepage":"https://github.com/indutny/elliptic","devDependencies":{"brfs":"^2.0.2","coveralls":"^3.1.0","eslint":"^7.6.0","grunt":"^1.2.1","grunt-browserify":"^5.3.0","grunt-cli":"^1.3.2","grunt-contrib-connect":"^3.0.0","grunt-contrib-copy":"^1.0.0","grunt-contrib-uglify":"^5.0.0","grunt-mocha-istanbul":"^5.0.2","grunt-saucelabs":"^9.0.1","istanbul":"^0.4.5","mocha":"^8.0.1"},"dependencies":{"bn.js":"^4.11.9","brorand":"^1.1.0","hash.js":"^1.0.0","hmac-drbg":"^1.0.1","inherits":"^2.0.4","minimalistic-assert":"^1.0.1","minimalistic-crypto-utils":"^1.0.1"}}')},{}],"959xT":[function(e,t,r){"use strict";var i=r,n=e("bn.js"),s=e("minimalistic-assert"),o=e("minimalistic-crypto-utils");i.assert=s,i.toArray=o.toArray,i.zero2=o.zero2,i.toHex=o.toHex,i.encode=o.encode,i.getNAF=function(e,t,r){var i=new Array(Math.max(e.bitLength(),r)+1);i.fill(0);for(var n=1<(n>>1)-1?(n>>1)-c:c,s.isubn(a)):a=0,i[o]=a,s.iushrn(1)}return i},i.getJSF=function(e,t){var r=[[],[]];e=e.clone(),t=t.clone();for(var i,n=0,s=0;e.cmpn(-n)>0||t.cmpn(-s)>0;){var o,a,c=e.andln(3)+n&3,u=t.andln(3)+s&3;3===c&&(c=-1),3===u&&(u=-1),o=0==(1&c)?0:3!==(i=e.andln(7)+n&7)&&5!==i||2!==u?c:-c,r[0].push(o),a=0==(1&u)?0:3!==(i=t.andln(7)+s&7)&&5!==i||2!==c?u:-u,r[1].push(a),2*n===o+1&&(n=1-n),2*s===a+1&&(s=1-s),e.iushrn(1),t.iushrn(1)}return r},i.cachedProperty=function(e,t,r){var i="_"+t;e.prototype[t]=function(){return void 0!==this[i]?this[i]:this[i]=r.call(this)}},i.parseBytes=function(e){return"string"==typeof e?i.toArray(e,"hex"):e},i.intFromLE=function(e){return new n(e,"hex","le")}},{"bn.js":"c8Lvi","minimalistic-assert":"1GrVu","minimalistic-crypto-utils":"3MGAl"}],c8Lvi:[function(e,t,r){!function(t,r){function i(e,t){if(!e)throw new Error(t||"Assertion failed")}function n(e,t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}function s(e,t,r){if(s.isBN(e))return e;this.negative=0,this.words=null,this.length=0,this.red=null,null!==e&&("le"!==t&&"be"!==t||(r=t,t=10),this._init(e||0,t||10,r||"be"))}var o;"object"==typeof t?t.exports=s:r.BN=s,s.BN=s,s.wordSize=26;try{o="undefined"!=typeof window&&void 0!==window.Buffer?window.Buffer:e("buffer").Buffer}catch(e){}function a(e,t){var r=e.charCodeAt(t);return r>=65&&r<=70?r-55:r>=97&&r<=102?r-87:r-48&15}function c(e,t,r){var i=a(e,r);return r-1>=t&&(i|=a(e,r-1)<<4),i}function u(e,t,r,i){for(var n=0,s=Math.min(e.length,r),o=t;o=49?a-49+10:a>=17?a-17+10:a}return n}s.isBN=function(e){return e instanceof s||null!==e&&"object"==typeof e&&e.constructor.wordSize===s.wordSize&&Array.isArray(e.words)},s.max=function(e,t){return e.cmp(t)>0?e:t},s.min=function(e,t){return e.cmp(t)<0?e:t},s.prototype._init=function(e,t,r){if("number"==typeof e)return this._initNumber(e,t,r);if("object"==typeof e)return this._initArray(e,t,r);"hex"===t&&(t=16),i(t===(0|t)&&t>=2&&t<=36);var n=0;"-"===(e=e.toString().replace(/\s+/g,""))[0]&&(n++,this.negative=1),n=0;n-=3)o=e[n]|e[n-1]<<8|e[n-2]<<16,this.words[s]|=o<>>26-a&67108863,(a+=24)>=26&&(a-=26,s++);else if("le"===r)for(n=0,s=0;n>>26-a&67108863,(a+=24)>=26&&(a-=26,s++);return this.strip()},s.prototype._parseHex=function(e,t,r){this.length=Math.ceil((e.length-t)/6),this.words=new Array(this.length);for(var i=0;i=t;i-=2)n=c(e,t,i)<=18?(s-=18,o+=1,this.words[o]|=n>>>26):s+=8;else for(i=(e.length-t)%2==0?t+1:t;i=18?(s-=18,o+=1,this.words[o]|=n>>>26):s+=8;this.strip()},s.prototype._parseBase=function(e,t,r){this.words=[0],this.length=1;for(var i=0,n=1;n<=67108863;n*=t)i++;i--,n=n/t|0;for(var s=e.length-r,o=s%i,a=Math.min(s,s-o)+r,c=0,l=r;l1&&0===this.words[this.length-1];)this.length--;return this._normSign()},s.prototype._normSign=function(){return 1===this.length&&0===this.words[0]&&(this.negative=0),this},s.prototype.inspect=function(){return(this.red?""};var l=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],d=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],f=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64e6,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,243e5,28629151,33554432,39135393,45435424,52521875,60466176];function h(e,t,r){r.negative=t.negative^e.negative;var i=e.length+t.length|0;r.length=i,i=i-1|0;var n=0|e.words[0],s=0|t.words[0],o=n*s,a=67108863&o,c=o/67108864|0;r.words[0]=a;for(var u=1;u>>26,d=67108863&c,f=Math.min(u,t.length-1),h=Math.max(0,u-e.length+1);h<=f;h++){var p=u-h|0;l+=(o=(n=0|e.words[p])*(s=0|t.words[h])+d)/67108864|0,d=67108863&o}r.words[u]=0|d,c=0|l}return 0!==c?r.words[u]=0|c:r.length--,r.strip()}s.prototype.toString=function(e,t){var r;if(t=0|t||1,16===(e=e||10)||"hex"===e){r="";for(var n=0,s=0,o=0;o>>24-n&16777215)||o!==this.length-1?l[6-c.length]+c+r:c+r,(n+=2)>=26&&(n-=26,o--)}for(0!==s&&(r=s.toString(16)+r);r.length%t!=0;)r="0"+r;return 0!==this.negative&&(r="-"+r),r}if(e===(0|e)&&e>=2&&e<=36){var u=d[e],h=f[e];r="";var p=this.clone();for(p.negative=0;!p.isZero();){var g=p.modn(h).toString(e);r=(p=p.idivn(h)).isZero()?g+r:l[u-g.length]+g+r}for(this.isZero()&&(r="0"+r);r.length%t!=0;)r="0"+r;return 0!==this.negative&&(r="-"+r),r}i(!1,"Base should be between 2 and 36")},s.prototype.toNumber=function(){var e=this.words[0];return 2===this.length?e+=67108864*this.words[1]:3===this.length&&1===this.words[2]?e+=4503599627370496+67108864*this.words[1]:this.length>2&&i(!1,"Number can only safely store up to 53 bits"),0!==this.negative?-e:e},s.prototype.toJSON=function(){return this.toString(16)},s.prototype.toBuffer=function(e,t){return i(void 0!==o),this.toArrayLike(o,e,t)},s.prototype.toArray=function(e,t){return this.toArrayLike(Array,e,t)},s.prototype.toArrayLike=function(e,t,r){var n=this.byteLength(),s=r||Math.max(1,n);i(n<=s,"byte array longer than desired length"),i(s>0,"Requested array length <= 0"),this.strip();var o,a,c="le"===t,u=new e(s),l=this.clone();if(c){for(a=0;!l.isZero();a++)o=l.andln(255),l.iushrn(8),u[a]=o;for(;a=4096&&(r+=13,t>>>=13),t>=64&&(r+=7,t>>>=7),t>=8&&(r+=4,t>>>=4),t>=2&&(r+=2,t>>>=2),r+t},s.prototype._zeroBits=function(e){if(0===e)return 26;var t=e,r=0;return 0==(8191&t)&&(r+=13,t>>>=13),0==(127&t)&&(r+=7,t>>>=7),0==(15&t)&&(r+=4,t>>>=4),0==(3&t)&&(r+=2,t>>>=2),0==(1&t)&&r++,r},s.prototype.bitLength=function(){var e=this.words[this.length-1],t=this._countBits(e);return 26*(this.length-1)+t},s.prototype.zeroBits=function(){if(this.isZero())return 0;for(var e=0,t=0;te.length?this.clone().ior(e):e.clone().ior(this)},s.prototype.uor=function(e){return this.length>e.length?this.clone().iuor(e):e.clone().iuor(this)},s.prototype.iuand=function(e){var t;t=this.length>e.length?e:this;for(var r=0;re.length?this.clone().iand(e):e.clone().iand(this)},s.prototype.uand=function(e){return this.length>e.length?this.clone().iuand(e):e.clone().iuand(this)},s.prototype.iuxor=function(e){var t,r;this.length>e.length?(t=this,r=e):(t=e,r=this);for(var i=0;ie.length?this.clone().ixor(e):e.clone().ixor(this)},s.prototype.uxor=function(e){return this.length>e.length?this.clone().iuxor(e):e.clone().iuxor(this)},s.prototype.inotn=function(e){i("number"==typeof e&&e>=0);var t=0|Math.ceil(e/26),r=e%26;this._expand(t),r>0&&t--;for(var n=0;n0&&(this.words[n]=~this.words[n]&67108863>>26-r),this.strip()},s.prototype.notn=function(e){return this.clone().inotn(e)},s.prototype.setn=function(e,t){i("number"==typeof e&&e>=0);var r=e/26|0,n=e%26;return this._expand(r+1),this.words[r]=t?this.words[r]|1<e.length?(r=this,i=e):(r=e,i=this);for(var n=0,s=0;s>>26;for(;0!==n&&s>>26;if(this.length=r.length,0!==n)this.words[this.length]=n,this.length++;else if(r!==this)for(;se.length?this.clone().iadd(e):e.clone().iadd(this)},s.prototype.isub=function(e){if(0!==e.negative){e.negative=0;var t=this.iadd(e);return e.negative=1,t._normSign()}if(0!==this.negative)return this.negative=0,this.iadd(e),this.negative=1,this._normSign();var r,i,n=this.cmp(e);if(0===n)return this.negative=0,this.length=1,this.words[0]=0,this;n>0?(r=this,i=e):(r=e,i=this);for(var s=0,o=0;o>26,this.words[o]=67108863&t;for(;0!==s&&o>26,this.words[o]=67108863&t;if(0===s&&o>>13,h=0|o[1],p=8191&h,g=h>>>13,y=0|o[2],m=8191&y,b=y>>>13,v=0|o[3],w=8191&v,_=v>>>13,E=0|o[4],S=8191&E,T=E>>>13,A=0|o[5],k=8191&A,I=A>>>13,R=0|o[6],P=8191&R,O=R>>>13,C=0|o[7],j=8191&C,D=C>>>13,M=0|o[8],x=8191&M,B=M>>>13,L=0|o[9],N=8191&L,U=L>>>13,F=0|a[0],K=8191&F,z=F>>>13,V=0|a[1],q=8191&V,G=V>>>13,H=0|a[2],$=8191&H,W=H>>>13,Y=0|a[3],X=8191&Y,Z=Y>>>13,Q=0|a[4],J=8191&Q,ee=Q>>>13,te=0|a[5],re=8191&te,ie=te>>>13,ne=0|a[6],se=8191&ne,oe=ne>>>13,ae=0|a[7],ce=8191&ae,ue=ae>>>13,le=0|a[8],de=8191&le,fe=le>>>13,he=0|a[9],pe=8191&he,ge=he>>>13;r.negative=e.negative^t.negative,r.length=19;var ye=(u+(i=Math.imul(d,K))|0)+((8191&(n=(n=Math.imul(d,z))+Math.imul(f,K)|0))<<13)|0;u=((s=Math.imul(f,z))+(n>>>13)|0)+(ye>>>26)|0,ye&=67108863,i=Math.imul(p,K),n=(n=Math.imul(p,z))+Math.imul(g,K)|0,s=Math.imul(g,z);var me=(u+(i=i+Math.imul(d,q)|0)|0)+((8191&(n=(n=n+Math.imul(d,G)|0)+Math.imul(f,q)|0))<<13)|0;u=((s=s+Math.imul(f,G)|0)+(n>>>13)|0)+(me>>>26)|0,me&=67108863,i=Math.imul(m,K),n=(n=Math.imul(m,z))+Math.imul(b,K)|0,s=Math.imul(b,z),i=i+Math.imul(p,q)|0,n=(n=n+Math.imul(p,G)|0)+Math.imul(g,q)|0,s=s+Math.imul(g,G)|0;var be=(u+(i=i+Math.imul(d,$)|0)|0)+((8191&(n=(n=n+Math.imul(d,W)|0)+Math.imul(f,$)|0))<<13)|0;u=((s=s+Math.imul(f,W)|0)+(n>>>13)|0)+(be>>>26)|0,be&=67108863,i=Math.imul(w,K),n=(n=Math.imul(w,z))+Math.imul(_,K)|0,s=Math.imul(_,z),i=i+Math.imul(m,q)|0,n=(n=n+Math.imul(m,G)|0)+Math.imul(b,q)|0,s=s+Math.imul(b,G)|0,i=i+Math.imul(p,$)|0,n=(n=n+Math.imul(p,W)|0)+Math.imul(g,$)|0,s=s+Math.imul(g,W)|0;var ve=(u+(i=i+Math.imul(d,X)|0)|0)+((8191&(n=(n=n+Math.imul(d,Z)|0)+Math.imul(f,X)|0))<<13)|0;u=((s=s+Math.imul(f,Z)|0)+(n>>>13)|0)+(ve>>>26)|0,ve&=67108863,i=Math.imul(S,K),n=(n=Math.imul(S,z))+Math.imul(T,K)|0,s=Math.imul(T,z),i=i+Math.imul(w,q)|0,n=(n=n+Math.imul(w,G)|0)+Math.imul(_,q)|0,s=s+Math.imul(_,G)|0,i=i+Math.imul(m,$)|0,n=(n=n+Math.imul(m,W)|0)+Math.imul(b,$)|0,s=s+Math.imul(b,W)|0,i=i+Math.imul(p,X)|0,n=(n=n+Math.imul(p,Z)|0)+Math.imul(g,X)|0,s=s+Math.imul(g,Z)|0;var we=(u+(i=i+Math.imul(d,J)|0)|0)+((8191&(n=(n=n+Math.imul(d,ee)|0)+Math.imul(f,J)|0))<<13)|0;u=((s=s+Math.imul(f,ee)|0)+(n>>>13)|0)+(we>>>26)|0,we&=67108863,i=Math.imul(k,K),n=(n=Math.imul(k,z))+Math.imul(I,K)|0,s=Math.imul(I,z),i=i+Math.imul(S,q)|0,n=(n=n+Math.imul(S,G)|0)+Math.imul(T,q)|0,s=s+Math.imul(T,G)|0,i=i+Math.imul(w,$)|0,n=(n=n+Math.imul(w,W)|0)+Math.imul(_,$)|0,s=s+Math.imul(_,W)|0,i=i+Math.imul(m,X)|0,n=(n=n+Math.imul(m,Z)|0)+Math.imul(b,X)|0,s=s+Math.imul(b,Z)|0,i=i+Math.imul(p,J)|0,n=(n=n+Math.imul(p,ee)|0)+Math.imul(g,J)|0,s=s+Math.imul(g,ee)|0;var _e=(u+(i=i+Math.imul(d,re)|0)|0)+((8191&(n=(n=n+Math.imul(d,ie)|0)+Math.imul(f,re)|0))<<13)|0;u=((s=s+Math.imul(f,ie)|0)+(n>>>13)|0)+(_e>>>26)|0,_e&=67108863,i=Math.imul(P,K),n=(n=Math.imul(P,z))+Math.imul(O,K)|0,s=Math.imul(O,z),i=i+Math.imul(k,q)|0,n=(n=n+Math.imul(k,G)|0)+Math.imul(I,q)|0,s=s+Math.imul(I,G)|0,i=i+Math.imul(S,$)|0,n=(n=n+Math.imul(S,W)|0)+Math.imul(T,$)|0,s=s+Math.imul(T,W)|0,i=i+Math.imul(w,X)|0,n=(n=n+Math.imul(w,Z)|0)+Math.imul(_,X)|0,s=s+Math.imul(_,Z)|0,i=i+Math.imul(m,J)|0,n=(n=n+Math.imul(m,ee)|0)+Math.imul(b,J)|0,s=s+Math.imul(b,ee)|0,i=i+Math.imul(p,re)|0,n=(n=n+Math.imul(p,ie)|0)+Math.imul(g,re)|0,s=s+Math.imul(g,ie)|0;var Ee=(u+(i=i+Math.imul(d,se)|0)|0)+((8191&(n=(n=n+Math.imul(d,oe)|0)+Math.imul(f,se)|0))<<13)|0;u=((s=s+Math.imul(f,oe)|0)+(n>>>13)|0)+(Ee>>>26)|0,Ee&=67108863,i=Math.imul(j,K),n=(n=Math.imul(j,z))+Math.imul(D,K)|0,s=Math.imul(D,z),i=i+Math.imul(P,q)|0,n=(n=n+Math.imul(P,G)|0)+Math.imul(O,q)|0,s=s+Math.imul(O,G)|0,i=i+Math.imul(k,$)|0,n=(n=n+Math.imul(k,W)|0)+Math.imul(I,$)|0,s=s+Math.imul(I,W)|0,i=i+Math.imul(S,X)|0,n=(n=n+Math.imul(S,Z)|0)+Math.imul(T,X)|0,s=s+Math.imul(T,Z)|0,i=i+Math.imul(w,J)|0,n=(n=n+Math.imul(w,ee)|0)+Math.imul(_,J)|0,s=s+Math.imul(_,ee)|0,i=i+Math.imul(m,re)|0,n=(n=n+Math.imul(m,ie)|0)+Math.imul(b,re)|0,s=s+Math.imul(b,ie)|0,i=i+Math.imul(p,se)|0,n=(n=n+Math.imul(p,oe)|0)+Math.imul(g,se)|0,s=s+Math.imul(g,oe)|0;var Se=(u+(i=i+Math.imul(d,ce)|0)|0)+((8191&(n=(n=n+Math.imul(d,ue)|0)+Math.imul(f,ce)|0))<<13)|0;u=((s=s+Math.imul(f,ue)|0)+(n>>>13)|0)+(Se>>>26)|0,Se&=67108863,i=Math.imul(x,K),n=(n=Math.imul(x,z))+Math.imul(B,K)|0,s=Math.imul(B,z),i=i+Math.imul(j,q)|0,n=(n=n+Math.imul(j,G)|0)+Math.imul(D,q)|0,s=s+Math.imul(D,G)|0,i=i+Math.imul(P,$)|0,n=(n=n+Math.imul(P,W)|0)+Math.imul(O,$)|0,s=s+Math.imul(O,W)|0,i=i+Math.imul(k,X)|0,n=(n=n+Math.imul(k,Z)|0)+Math.imul(I,X)|0,s=s+Math.imul(I,Z)|0,i=i+Math.imul(S,J)|0,n=(n=n+Math.imul(S,ee)|0)+Math.imul(T,J)|0,s=s+Math.imul(T,ee)|0,i=i+Math.imul(w,re)|0,n=(n=n+Math.imul(w,ie)|0)+Math.imul(_,re)|0,s=s+Math.imul(_,ie)|0,i=i+Math.imul(m,se)|0,n=(n=n+Math.imul(m,oe)|0)+Math.imul(b,se)|0,s=s+Math.imul(b,oe)|0,i=i+Math.imul(p,ce)|0,n=(n=n+Math.imul(p,ue)|0)+Math.imul(g,ce)|0,s=s+Math.imul(g,ue)|0;var Te=(u+(i=i+Math.imul(d,de)|0)|0)+((8191&(n=(n=n+Math.imul(d,fe)|0)+Math.imul(f,de)|0))<<13)|0;u=((s=s+Math.imul(f,fe)|0)+(n>>>13)|0)+(Te>>>26)|0,Te&=67108863,i=Math.imul(N,K),n=(n=Math.imul(N,z))+Math.imul(U,K)|0,s=Math.imul(U,z),i=i+Math.imul(x,q)|0,n=(n=n+Math.imul(x,G)|0)+Math.imul(B,q)|0,s=s+Math.imul(B,G)|0,i=i+Math.imul(j,$)|0,n=(n=n+Math.imul(j,W)|0)+Math.imul(D,$)|0,s=s+Math.imul(D,W)|0,i=i+Math.imul(P,X)|0,n=(n=n+Math.imul(P,Z)|0)+Math.imul(O,X)|0,s=s+Math.imul(O,Z)|0,i=i+Math.imul(k,J)|0,n=(n=n+Math.imul(k,ee)|0)+Math.imul(I,J)|0,s=s+Math.imul(I,ee)|0,i=i+Math.imul(S,re)|0,n=(n=n+Math.imul(S,ie)|0)+Math.imul(T,re)|0,s=s+Math.imul(T,ie)|0,i=i+Math.imul(w,se)|0,n=(n=n+Math.imul(w,oe)|0)+Math.imul(_,se)|0,s=s+Math.imul(_,oe)|0,i=i+Math.imul(m,ce)|0,n=(n=n+Math.imul(m,ue)|0)+Math.imul(b,ce)|0,s=s+Math.imul(b,ue)|0,i=i+Math.imul(p,de)|0,n=(n=n+Math.imul(p,fe)|0)+Math.imul(g,de)|0,s=s+Math.imul(g,fe)|0;var Ae=(u+(i=i+Math.imul(d,pe)|0)|0)+((8191&(n=(n=n+Math.imul(d,ge)|0)+Math.imul(f,pe)|0))<<13)|0;u=((s=s+Math.imul(f,ge)|0)+(n>>>13)|0)+(Ae>>>26)|0,Ae&=67108863,i=Math.imul(N,q),n=(n=Math.imul(N,G))+Math.imul(U,q)|0,s=Math.imul(U,G),i=i+Math.imul(x,$)|0,n=(n=n+Math.imul(x,W)|0)+Math.imul(B,$)|0,s=s+Math.imul(B,W)|0,i=i+Math.imul(j,X)|0,n=(n=n+Math.imul(j,Z)|0)+Math.imul(D,X)|0,s=s+Math.imul(D,Z)|0,i=i+Math.imul(P,J)|0,n=(n=n+Math.imul(P,ee)|0)+Math.imul(O,J)|0,s=s+Math.imul(O,ee)|0,i=i+Math.imul(k,re)|0,n=(n=n+Math.imul(k,ie)|0)+Math.imul(I,re)|0,s=s+Math.imul(I,ie)|0,i=i+Math.imul(S,se)|0,n=(n=n+Math.imul(S,oe)|0)+Math.imul(T,se)|0,s=s+Math.imul(T,oe)|0,i=i+Math.imul(w,ce)|0,n=(n=n+Math.imul(w,ue)|0)+Math.imul(_,ce)|0,s=s+Math.imul(_,ue)|0,i=i+Math.imul(m,de)|0,n=(n=n+Math.imul(m,fe)|0)+Math.imul(b,de)|0,s=s+Math.imul(b,fe)|0;var ke=(u+(i=i+Math.imul(p,pe)|0)|0)+((8191&(n=(n=n+Math.imul(p,ge)|0)+Math.imul(g,pe)|0))<<13)|0;u=((s=s+Math.imul(g,ge)|0)+(n>>>13)|0)+(ke>>>26)|0,ke&=67108863,i=Math.imul(N,$),n=(n=Math.imul(N,W))+Math.imul(U,$)|0,s=Math.imul(U,W),i=i+Math.imul(x,X)|0,n=(n=n+Math.imul(x,Z)|0)+Math.imul(B,X)|0,s=s+Math.imul(B,Z)|0,i=i+Math.imul(j,J)|0,n=(n=n+Math.imul(j,ee)|0)+Math.imul(D,J)|0,s=s+Math.imul(D,ee)|0,i=i+Math.imul(P,re)|0,n=(n=n+Math.imul(P,ie)|0)+Math.imul(O,re)|0,s=s+Math.imul(O,ie)|0,i=i+Math.imul(k,se)|0,n=(n=n+Math.imul(k,oe)|0)+Math.imul(I,se)|0,s=s+Math.imul(I,oe)|0,i=i+Math.imul(S,ce)|0,n=(n=n+Math.imul(S,ue)|0)+Math.imul(T,ce)|0,s=s+Math.imul(T,ue)|0,i=i+Math.imul(w,de)|0,n=(n=n+Math.imul(w,fe)|0)+Math.imul(_,de)|0,s=s+Math.imul(_,fe)|0;var Ie=(u+(i=i+Math.imul(m,pe)|0)|0)+((8191&(n=(n=n+Math.imul(m,ge)|0)+Math.imul(b,pe)|0))<<13)|0;u=((s=s+Math.imul(b,ge)|0)+(n>>>13)|0)+(Ie>>>26)|0,Ie&=67108863,i=Math.imul(N,X),n=(n=Math.imul(N,Z))+Math.imul(U,X)|0,s=Math.imul(U,Z),i=i+Math.imul(x,J)|0,n=(n=n+Math.imul(x,ee)|0)+Math.imul(B,J)|0,s=s+Math.imul(B,ee)|0,i=i+Math.imul(j,re)|0,n=(n=n+Math.imul(j,ie)|0)+Math.imul(D,re)|0,s=s+Math.imul(D,ie)|0,i=i+Math.imul(P,se)|0,n=(n=n+Math.imul(P,oe)|0)+Math.imul(O,se)|0,s=s+Math.imul(O,oe)|0,i=i+Math.imul(k,ce)|0,n=(n=n+Math.imul(k,ue)|0)+Math.imul(I,ce)|0,s=s+Math.imul(I,ue)|0,i=i+Math.imul(S,de)|0,n=(n=n+Math.imul(S,fe)|0)+Math.imul(T,de)|0,s=s+Math.imul(T,fe)|0;var Re=(u+(i=i+Math.imul(w,pe)|0)|0)+((8191&(n=(n=n+Math.imul(w,ge)|0)+Math.imul(_,pe)|0))<<13)|0;u=((s=s+Math.imul(_,ge)|0)+(n>>>13)|0)+(Re>>>26)|0,Re&=67108863,i=Math.imul(N,J),n=(n=Math.imul(N,ee))+Math.imul(U,J)|0,s=Math.imul(U,ee),i=i+Math.imul(x,re)|0,n=(n=n+Math.imul(x,ie)|0)+Math.imul(B,re)|0,s=s+Math.imul(B,ie)|0,i=i+Math.imul(j,se)|0,n=(n=n+Math.imul(j,oe)|0)+Math.imul(D,se)|0,s=s+Math.imul(D,oe)|0,i=i+Math.imul(P,ce)|0,n=(n=n+Math.imul(P,ue)|0)+Math.imul(O,ce)|0,s=s+Math.imul(O,ue)|0,i=i+Math.imul(k,de)|0,n=(n=n+Math.imul(k,fe)|0)+Math.imul(I,de)|0,s=s+Math.imul(I,fe)|0;var Pe=(u+(i=i+Math.imul(S,pe)|0)|0)+((8191&(n=(n=n+Math.imul(S,ge)|0)+Math.imul(T,pe)|0))<<13)|0;u=((s=s+Math.imul(T,ge)|0)+(n>>>13)|0)+(Pe>>>26)|0,Pe&=67108863,i=Math.imul(N,re),n=(n=Math.imul(N,ie))+Math.imul(U,re)|0,s=Math.imul(U,ie),i=i+Math.imul(x,se)|0,n=(n=n+Math.imul(x,oe)|0)+Math.imul(B,se)|0,s=s+Math.imul(B,oe)|0,i=i+Math.imul(j,ce)|0,n=(n=n+Math.imul(j,ue)|0)+Math.imul(D,ce)|0,s=s+Math.imul(D,ue)|0,i=i+Math.imul(P,de)|0,n=(n=n+Math.imul(P,fe)|0)+Math.imul(O,de)|0,s=s+Math.imul(O,fe)|0;var Oe=(u+(i=i+Math.imul(k,pe)|0)|0)+((8191&(n=(n=n+Math.imul(k,ge)|0)+Math.imul(I,pe)|0))<<13)|0;u=((s=s+Math.imul(I,ge)|0)+(n>>>13)|0)+(Oe>>>26)|0,Oe&=67108863,i=Math.imul(N,se),n=(n=Math.imul(N,oe))+Math.imul(U,se)|0,s=Math.imul(U,oe),i=i+Math.imul(x,ce)|0,n=(n=n+Math.imul(x,ue)|0)+Math.imul(B,ce)|0,s=s+Math.imul(B,ue)|0,i=i+Math.imul(j,de)|0,n=(n=n+Math.imul(j,fe)|0)+Math.imul(D,de)|0,s=s+Math.imul(D,fe)|0;var Ce=(u+(i=i+Math.imul(P,pe)|0)|0)+((8191&(n=(n=n+Math.imul(P,ge)|0)+Math.imul(O,pe)|0))<<13)|0;u=((s=s+Math.imul(O,ge)|0)+(n>>>13)|0)+(Ce>>>26)|0,Ce&=67108863,i=Math.imul(N,ce),n=(n=Math.imul(N,ue))+Math.imul(U,ce)|0,s=Math.imul(U,ue),i=i+Math.imul(x,de)|0,n=(n=n+Math.imul(x,fe)|0)+Math.imul(B,de)|0,s=s+Math.imul(B,fe)|0;var je=(u+(i=i+Math.imul(j,pe)|0)|0)+((8191&(n=(n=n+Math.imul(j,ge)|0)+Math.imul(D,pe)|0))<<13)|0;u=((s=s+Math.imul(D,ge)|0)+(n>>>13)|0)+(je>>>26)|0,je&=67108863,i=Math.imul(N,de),n=(n=Math.imul(N,fe))+Math.imul(U,de)|0,s=Math.imul(U,fe);var De=(u+(i=i+Math.imul(x,pe)|0)|0)+((8191&(n=(n=n+Math.imul(x,ge)|0)+Math.imul(B,pe)|0))<<13)|0;u=((s=s+Math.imul(B,ge)|0)+(n>>>13)|0)+(De>>>26)|0,De&=67108863;var Me=(u+(i=Math.imul(N,pe))|0)+((8191&(n=(n=Math.imul(N,ge))+Math.imul(U,pe)|0))<<13)|0;return u=((s=Math.imul(U,ge))+(n>>>13)|0)+(Me>>>26)|0,Me&=67108863,c[0]=ye,c[1]=me,c[2]=be,c[3]=ve,c[4]=we,c[5]=_e,c[6]=Ee,c[7]=Se,c[8]=Te,c[9]=Ae,c[10]=ke,c[11]=Ie,c[12]=Re,c[13]=Pe,c[14]=Oe,c[15]=Ce,c[16]=je,c[17]=De,c[18]=Me,0!==u&&(c[19]=u,r.length++),r};function g(e,t,r){return(new y).mulp(e,t,r)}function y(e,t){this.x=e,this.y=t}Math.imul||(p=h),s.prototype.mulTo=function(e,t){var r,i=this.length+e.length;return r=10===this.length&&10===e.length?p(this,e,t):i<63?h(this,e,t):i<1024?function(e,t,r){r.negative=t.negative^e.negative,r.length=e.length+t.length;for(var i=0,n=0,s=0;s>>26)|0)>>>26,o&=67108863}r.words[s]=a,i=o,o=n}return 0!==i?r.words[s]=i:r.length--,r.strip()}(this,e,t):g(this,e,t),r},y.prototype.makeRBT=function(e){for(var t=new Array(e),r=s.prototype._countBits(e)-1,i=0;i>=1;return i},y.prototype.permute=function(e,t,r,i,n,s){for(var o=0;o>>=1)n++;return 1<>>=13,r[2*o+1]=8191&s,s>>>=13;for(o=2*t;o>=26,t+=n/67108864|0,t+=s>>>26,this.words[r]=67108863&s}return 0!==t&&(this.words[r]=t,this.length++),this},s.prototype.muln=function(e){return this.clone().imuln(e)},s.prototype.sqr=function(){return this.mul(this)},s.prototype.isqr=function(){return this.imul(this.clone())},s.prototype.pow=function(e){var t=function(e){for(var t=new Array(e.bitLength()),r=0;r>>n}return t}(e);if(0===t.length)return new s(1);for(var r=this,i=0;i=0);var t,r=e%26,n=(e-r)/26,s=67108863>>>26-r<<26-r;if(0!==r){var o=0;for(t=0;t>>26-r}o&&(this.words[t]=o,this.length++)}if(0!==n){for(t=this.length-1;t>=0;t--)this.words[t+n]=this.words[t];for(t=0;t=0),n=t?(t-t%26)/26:0;var s=e%26,o=Math.min((e-s)/26,this.length),a=67108863^67108863>>>s<o)for(this.length-=o,u=0;u=0&&(0!==l||u>=n);u--){var d=0|this.words[u];this.words[u]=l<<26-s|d>>>s,l=d&a}return c&&0!==l&&(c.words[c.length++]=l),0===this.length&&(this.words[0]=0,this.length=1),this.strip()},s.prototype.ishrn=function(e,t,r){return i(0===this.negative),this.iushrn(e,t,r)},s.prototype.shln=function(e){return this.clone().ishln(e)},s.prototype.ushln=function(e){return this.clone().iushln(e)},s.prototype.shrn=function(e){return this.clone().ishrn(e)},s.prototype.ushrn=function(e){return this.clone().iushrn(e)},s.prototype.testn=function(e){i("number"==typeof e&&e>=0);var t=e%26,r=(e-t)/26,n=1<=0);var t=e%26,r=(e-t)/26;if(i(0===this.negative,"imaskn works only with positive numbers"),this.length<=r)return this;if(0!==t&&r++,this.length=Math.min(r,this.length),0!==t){var n=67108863^67108863>>>t<=67108864;t++)this.words[t]-=67108864,t===this.length-1?this.words[t+1]=1:this.words[t+1]++;return this.length=Math.max(this.length,t+1),this},s.prototype.isubn=function(e){if(i("number"==typeof e),i(e<67108864),e<0)return this.iaddn(-e);if(0!==this.negative)return this.negative=0,this.iaddn(e),this.negative=1,this;if(this.words[0]-=e,1===this.length&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var t=0;t>26)-(c/67108864|0),this.words[n+r]=67108863&s}for(;n>26,this.words[n+r]=67108863&s;if(0===a)return this.strip();for(i(-1===a),a=0,n=0;n>26,this.words[n]=67108863&s;return this.negative=1,this.strip()},s.prototype._wordDiv=function(e,t){var r=(this.length,e.length),i=this.clone(),n=e,o=0|n.words[n.length-1];0!==(r=26-this._countBits(o))&&(n=n.ushln(r),i.iushln(r),o=0|n.words[n.length-1]);var a,c=i.length-n.length;if("mod"!==t){(a=new s(null)).length=c+1,a.words=new Array(a.length);for(var u=0;u=0;d--){var f=67108864*(0|i.words[n.length+d])+(0|i.words[n.length+d-1]);for(f=Math.min(f/o|0,67108863),i._ishlnsubmul(n,f,d);0!==i.negative;)f--,i.negative=0,i._ishlnsubmul(n,1,d),i.isZero()||(i.negative^=1);a&&(a.words[d]=f)}return a&&a.strip(),i.strip(),"div"!==t&&0!==r&&i.iushrn(r),{div:a||null,mod:i}},s.prototype.divmod=function(e,t,r){return i(!e.isZero()),this.isZero()?{div:new s(0),mod:new s(0)}:0!==this.negative&&0===e.negative?(a=this.neg().divmod(e,t),"mod"!==t&&(n=a.div.neg()),"div"!==t&&(o=a.mod.neg(),r&&0!==o.negative&&o.iadd(e)),{div:n,mod:o}):0===this.negative&&0!==e.negative?(a=this.divmod(e.neg(),t),"mod"!==t&&(n=a.div.neg()),{div:n,mod:a.mod}):0!=(this.negative&e.negative)?(a=this.neg().divmod(e.neg(),t),"div"!==t&&(o=a.mod.neg(),r&&0!==o.negative&&o.isub(e)),{div:a.div,mod:o}):e.length>this.length||this.cmp(e)<0?{div:new s(0),mod:this}:1===e.length?"div"===t?{div:this.divn(e.words[0]),mod:null}:"mod"===t?{div:null,mod:new s(this.modn(e.words[0]))}:{div:this.divn(e.words[0]),mod:new s(this.modn(e.words[0]))}:this._wordDiv(e,t);var n,o,a},s.prototype.div=function(e){return this.divmod(e,"div",!1).div},s.prototype.mod=function(e){return this.divmod(e,"mod",!1).mod},s.prototype.umod=function(e){return this.divmod(e,"mod",!0).mod},s.prototype.divRound=function(e){var t=this.divmod(e);if(t.mod.isZero())return t.div;var r=0!==t.div.negative?t.mod.isub(e):t.mod,i=e.ushrn(1),n=e.andln(1),s=r.cmp(i);return s<0||1===n&&0===s?t.div:0!==t.div.negative?t.div.isubn(1):t.div.iaddn(1)},s.prototype.modn=function(e){i(e<=67108863);for(var t=67108864%e,r=0,n=this.length-1;n>=0;n--)r=(t*r+(0|this.words[n]))%e;return r},s.prototype.idivn=function(e){i(e<=67108863);for(var t=0,r=this.length-1;r>=0;r--){var n=(0|this.words[r])+67108864*t;this.words[r]=n/e|0,t=n%e}return this.strip()},s.prototype.divn=function(e){return this.clone().idivn(e)},s.prototype.egcd=function(e){i(0===e.negative),i(!e.isZero());var t=this,r=e.clone();t=0!==t.negative?t.umod(e):t.clone();for(var n=new s(1),o=new s(0),a=new s(0),c=new s(1),u=0;t.isEven()&&r.isEven();)t.iushrn(1),r.iushrn(1),++u;for(var l=r.clone(),d=t.clone();!t.isZero();){for(var f=0,h=1;0==(t.words[0]&h)&&f<26;++f,h<<=1);if(f>0)for(t.iushrn(f);f-- >0;)(n.isOdd()||o.isOdd())&&(n.iadd(l),o.isub(d)),n.iushrn(1),o.iushrn(1);for(var p=0,g=1;0==(r.words[0]&g)&&p<26;++p,g<<=1);if(p>0)for(r.iushrn(p);p-- >0;)(a.isOdd()||c.isOdd())&&(a.iadd(l),c.isub(d)),a.iushrn(1),c.iushrn(1);t.cmp(r)>=0?(t.isub(r),n.isub(a),o.isub(c)):(r.isub(t),a.isub(n),c.isub(o))}return{a:a,b:c,gcd:r.iushln(u)}},s.prototype._invmp=function(e){i(0===e.negative),i(!e.isZero());var t=this,r=e.clone();t=0!==t.negative?t.umod(e):t.clone();for(var n,o=new s(1),a=new s(0),c=r.clone();t.cmpn(1)>0&&r.cmpn(1)>0;){for(var u=0,l=1;0==(t.words[0]&l)&&u<26;++u,l<<=1);if(u>0)for(t.iushrn(u);u-- >0;)o.isOdd()&&o.iadd(c),o.iushrn(1);for(var d=0,f=1;0==(r.words[0]&f)&&d<26;++d,f<<=1);if(d>0)for(r.iushrn(d);d-- >0;)a.isOdd()&&a.iadd(c),a.iushrn(1);t.cmp(r)>=0?(t.isub(r),o.isub(a)):(r.isub(t),a.isub(o))}return(n=0===t.cmpn(1)?o:a).cmpn(0)<0&&n.iadd(e),n},s.prototype.gcd=function(e){if(this.isZero())return e.abs();if(e.isZero())return this.abs();var t=this.clone(),r=e.clone();t.negative=0,r.negative=0;for(var i=0;t.isEven()&&r.isEven();i++)t.iushrn(1),r.iushrn(1);for(;;){for(;t.isEven();)t.iushrn(1);for(;r.isEven();)r.iushrn(1);var n=t.cmp(r);if(n<0){var s=t;t=r,r=s}else if(0===n||0===r.cmpn(1))break;t.isub(r)}return r.iushln(i)},s.prototype.invm=function(e){return this.egcd(e).a.umod(e)},s.prototype.isEven=function(){return 0==(1&this.words[0])},s.prototype.isOdd=function(){return 1==(1&this.words[0])},s.prototype.andln=function(e){return this.words[0]&e},s.prototype.bincn=function(e){i("number"==typeof e);var t=e%26,r=(e-t)/26,n=1<>>26,a&=67108863,this.words[o]=a}return 0!==s&&(this.words[o]=s,this.length++),this},s.prototype.isZero=function(){return 1===this.length&&0===this.words[0]},s.prototype.cmpn=function(e){var t,r=e<0;if(0!==this.negative&&!r)return-1;if(0===this.negative&&r)return 1;if(this.strip(),this.length>1)t=1;else{r&&(e=-e),i(e<=67108863,"Number is too big");var n=0|this.words[0];t=n===e?0:ne.length)return 1;if(this.length=0;r--){var i=0|this.words[r],n=0|e.words[r];if(i!==n){in&&(t=1);break}}return t},s.prototype.gtn=function(e){return 1===this.cmpn(e)},s.prototype.gt=function(e){return 1===this.cmp(e)},s.prototype.gten=function(e){return this.cmpn(e)>=0},s.prototype.gte=function(e){return this.cmp(e)>=0},s.prototype.ltn=function(e){return-1===this.cmpn(e)},s.prototype.lt=function(e){return-1===this.cmp(e)},s.prototype.lten=function(e){return this.cmpn(e)<=0},s.prototype.lte=function(e){return this.cmp(e)<=0},s.prototype.eqn=function(e){return 0===this.cmpn(e)},s.prototype.eq=function(e){return 0===this.cmp(e)},s.red=function(e){return new S(e)},s.prototype.toRed=function(e){return i(!this.red,"Already a number in reduction context"),i(0===this.negative,"red works only with positives"),e.convertTo(this)._forceRed(e)},s.prototype.fromRed=function(){return i(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},s.prototype._forceRed=function(e){return this.red=e,this},s.prototype.forceRed=function(e){return i(!this.red,"Already a number in reduction context"),this._forceRed(e)},s.prototype.redAdd=function(e){return i(this.red,"redAdd works only with red numbers"),this.red.add(this,e)},s.prototype.redIAdd=function(e){return i(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,e)},s.prototype.redSub=function(e){return i(this.red,"redSub works only with red numbers"),this.red.sub(this,e)},s.prototype.redISub=function(e){return i(this.red,"redISub works only with red numbers"),this.red.isub(this,e)},s.prototype.redShl=function(e){return i(this.red,"redShl works only with red numbers"),this.red.shl(this,e)},s.prototype.redMul=function(e){return i(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.mul(this,e)},s.prototype.redIMul=function(e){return i(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.imul(this,e)},s.prototype.redSqr=function(){return i(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},s.prototype.redISqr=function(){return i(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},s.prototype.redSqrt=function(){return i(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},s.prototype.redInvm=function(){return i(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},s.prototype.redNeg=function(){return i(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},s.prototype.redPow=function(e){return i(this.red&&!e.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,e)};var m={k256:null,p224:null,p192:null,p25519:null};function b(e,t){this.name=e,this.p=new s(t,16),this.n=this.p.bitLength(),this.k=new s(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}function v(){b.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}function w(){b.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}function _(){b.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}function E(){b.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}function S(e){if("string"==typeof e){var t=s._prime(e);this.m=t.p,this.prime=t}else i(e.gtn(1),"modulus must be greater than 1"),this.m=e,this.prime=null}function T(e){S.call(this,e),this.shift=this.m.bitLength(),this.shift%26!=0&&(this.shift+=26-this.shift%26),this.r=new s(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}b.prototype._tmp=function(){var e=new s(null);return e.words=new Array(Math.ceil(this.n/13)),e},b.prototype.ireduce=function(e){var t,r=e;do{this.split(r,this.tmp),t=(r=(r=this.imulK(r)).iadd(this.tmp)).bitLength()}while(t>this.n);var i=t0?r.isub(this.p):void 0!==r.strip?r.strip():r._strip(),r},b.prototype.split=function(e,t){e.iushrn(this.n,0,t)},b.prototype.imulK=function(e){return e.imul(this.k)},n(v,b),v.prototype.split=function(e,t){for(var r=4194303,i=Math.min(e.length,9),n=0;n>>22,s=o}s>>>=22,e.words[n-10]=s,0===s&&e.length>10?e.length-=10:e.length-=9},v.prototype.imulK=function(e){e.words[e.length]=0,e.words[e.length+1]=0,e.length+=2;for(var t=0,r=0;r>>=26,e.words[r]=n,t=i}return 0!==t&&(e.words[e.length++]=t),e},s._prime=function(e){if(m[e])return m[e];var t;if("k256"===e)t=new v;else if("p224"===e)t=new w;else if("p192"===e)t=new _;else{if("p25519"!==e)throw new Error("Unknown prime "+e);t=new E}return m[e]=t,t},S.prototype._verify1=function(e){i(0===e.negative,"red works only with positives"),i(e.red,"red works only with red numbers")},S.prototype._verify2=function(e,t){i(0==(e.negative|t.negative),"red works only with positives"),i(e.red&&e.red===t.red,"red works only with red numbers")},S.prototype.imod=function(e){return this.prime?this.prime.ireduce(e)._forceRed(this):e.umod(this.m)._forceRed(this)},S.prototype.neg=function(e){return e.isZero()?e.clone():this.m.sub(e)._forceRed(this)},S.prototype.add=function(e,t){this._verify2(e,t);var r=e.add(t);return r.cmp(this.m)>=0&&r.isub(this.m),r._forceRed(this)},S.prototype.iadd=function(e,t){this._verify2(e,t);var r=e.iadd(t);return r.cmp(this.m)>=0&&r.isub(this.m),r},S.prototype.sub=function(e,t){this._verify2(e,t);var r=e.sub(t);return r.cmpn(0)<0&&r.iadd(this.m),r._forceRed(this)},S.prototype.isub=function(e,t){this._verify2(e,t);var r=e.isub(t);return r.cmpn(0)<0&&r.iadd(this.m),r},S.prototype.shl=function(e,t){return this._verify1(e),this.imod(e.ushln(t))},S.prototype.imul=function(e,t){return this._verify2(e,t),this.imod(e.imul(t))},S.prototype.mul=function(e,t){return this._verify2(e,t),this.imod(e.mul(t))},S.prototype.isqr=function(e){return this.imul(e,e.clone())},S.prototype.sqr=function(e){return this.mul(e,e)},S.prototype.sqrt=function(e){if(e.isZero())return e.clone();var t=this.m.andln(3);if(i(t%2==1),3===t){var r=this.m.add(new s(1)).iushrn(2);return this.pow(e,r)}for(var n=this.m.subn(1),o=0;!n.isZero()&&0===n.andln(1);)o++,n.iushrn(1);i(!n.isZero());var a=new s(1).toRed(this),c=a.redNeg(),u=this.m.subn(1).iushrn(1),l=this.m.bitLength();for(l=new s(2*l*l).toRed(this);0!==this.pow(l,u).cmp(c);)l.redIAdd(c);for(var d=this.pow(l,n),f=this.pow(e,n.addn(1).iushrn(1)),h=this.pow(e,n),p=o;0!==h.cmp(a);){for(var g=h,y=0;0!==g.cmp(a);y++)g=g.redSqr();i(y=0;i--){for(var u=t.words[i],l=c-1;l>=0;l--){var d=u>>l&1;n!==r[0]&&(n=this.sqr(n)),0!==d||0!==o?(o<<=1,o|=d,(4===++a||0===i&&0===l)&&(n=this.mul(n,r[o]),a=0,o=0)):a=0}c=26}return n},S.prototype.convertTo=function(e){var t=e.umod(this.m);return t===e?t.clone():t},S.prototype.convertFrom=function(e){var t=e.clone();return t.red=null,t},s.mont=function(e){return new T(e)},n(T,S),T.prototype.convertTo=function(e){return this.imod(e.ushln(this.shift))},T.prototype.convertFrom=function(e){var t=this.imod(e.mul(this.rinv));return t.red=null,t},T.prototype.imul=function(e,t){if(e.isZero()||t.isZero())return e.words[0]=0,e.length=1,e;var r=e.imul(t),i=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),n=r.isub(i).iushrn(this.shift),s=n;return n.cmp(this.m)>=0?s=n.isub(this.m):n.cmpn(0)<0&&(s=n.iadd(this.m)),s._forceRed(this)},T.prototype.mul=function(e,t){if(e.isZero()||t.isZero())return new s(0)._forceRed(this);var r=e.mul(t),i=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),n=r.isub(i).iushrn(this.shift),o=n;return n.cmp(this.m)>=0?o=n.isub(this.m):n.cmpn(0)<0&&(o=n.iadd(this.m)),o._forceRed(this)},T.prototype.invm=function(e){return this.imod(e._invmp(this.m).mul(this.r2))._forceRed(this)}}(void 0===t||t,this)},{buffer:"lHksA"}],"1GrVu":[function(e,t,r){function i(e,t){if(!e)throw new Error(t||"Assertion failed")}t.exports=i,i.equal=function(e,t,r){if(e!=t)throw new Error(r||"Assertion failed: "+e+" != "+t)}},{}],"3MGAl":[function(e,t,r){"use strict";var i=r;function n(e){return 1===e.length?"0"+e:e}function s(e){for(var t="",r=0;r>8,o=255&n;s?r.push(s,o):r.push(o)}return r},i.zero2=n,i.toHex=s,i.encode=function(e,t){return"hex"===t?s(e):e}},{}],P54o1:[function(e,t,r){var i;function n(e){this.rand=e}if(t.exports=function(e){return i||(i=new n(null)),i.generate(e)},t.exports.Rand=n,n.prototype.generate=function(e){return this._rand(e)},n.prototype._rand=function(e){if(this.rand.getBytes)return this.rand.getBytes(e);for(var t=new Uint8Array(e),r=0;r0?this.redN=null:(this._maxwellTrick=!0,this.redN=this.n.toRed(this.red))}function u(e,t){this.curve=e,this.type=t,this.precomputed=null}t.exports=c,c.prototype.point=function(){throw new Error("Not implemented")},c.prototype.validate=function(){throw new Error("Not implemented")},c.prototype._fixedNafMul=function(e,t){a(e.precomputed);var r=e._getDoubles(),i=s(t,1,this._bitLength),n=(1<=o;l--)c=(c<<1)+i[l];u.push(c)}for(var d=this.jpoint(null,null,null),f=this.jpoint(null,null,null),h=n;h>0;h--){for(o=0;o=0;u--){for(var l=0;u>=0&&0===o[u];u--)l++;if(u>=0&&l++,c=c.dblp(l),u<0)break;var d=o[u];a(0!==d),c="affine"===e.type?d>0?c.mixedAdd(n[d-1>>1]):c.mixedAdd(n[-d-1>>1].neg()):d>0?c.add(n[d-1>>1]):c.add(n[-d-1>>1].neg())}return"affine"===e.type?c.toP():c},c.prototype._wnafMulAdd=function(e,t,r,i,n){var a,c,u,l=this._wnafT1,d=this._wnafT2,f=this._wnafT3,h=0;for(a=0;a=1;a-=2){var g=a-1,y=a;if(1===l[g]&&1===l[y]){var m=[t[g],null,null,t[y]];0===t[g].y.cmp(t[y].y)?(m[1]=t[g].add(t[y]),m[2]=t[g].toJ().mixedAdd(t[y].neg())):0===t[g].y.cmp(t[y].y.redNeg())?(m[1]=t[g].toJ().mixedAdd(t[y]),m[2]=t[g].add(t[y].neg())):(m[1]=t[g].toJ().mixedAdd(t[y]),m[2]=t[g].toJ().mixedAdd(t[y].neg()));var b=[-3,-1,-5,-7,0,7,5,1,3],v=o(r[g],r[y]);for(h=Math.max(v[0].length,h),f[g]=new Array(h),f[y]=new Array(h),c=0;c=0;a--){for(var T=0;a>=0;){var A=!0;for(c=0;c=0&&T++,E=E.dblp(T),a<0)break;for(c=0;c0?u=d[c][k-1>>1]:k<0&&(u=d[c][-k-1>>1].neg()),E="affine"===u.type?E.mixedAdd(u):E.add(u))}}for(a=0;a=Math.ceil((e.bitLength()+1)/t.step)},u.prototype._getDoubles=function(e,t){if(this.precomputed&&this.precomputed.doubles)return this.precomputed.doubles;for(var r=[this],i=this,n=0;n=0&&(o=t,a=r),i.negative&&(i=i.neg(),s=s.neg()),o.negative&&(o=o.neg(),a=a.neg()),[{a:i,b:s},{a:o,b:a}]},c.prototype._endoSplit=function(e){var t=this.endo.basis,r=t[0],i=t[1],n=i.b.mul(e).divRound(this.n),s=r.b.neg().mul(e).divRound(this.n),o=n.mul(r.a),a=s.mul(i.a),c=n.mul(r.b),u=s.mul(i.b);return{k1:e.sub(o).sub(a),k2:c.add(u).neg()}},c.prototype.pointFromX=function(e,t){(e=new n(e,16)).red||(e=e.toRed(this.red));var r=e.redSqr().redMul(e).redIAdd(e.redMul(this.a)).redIAdd(this.b),i=r.redSqrt();if(0!==i.redSqr().redSub(r).cmp(this.zero))throw new Error("invalid point");var s=i.fromRed().isOdd();return(t&&!s||!t&&s)&&(i=i.redNeg()),this.point(e,i)},c.prototype.validate=function(e){if(e.inf)return!0;var t=e.x,r=e.y,i=this.a.redMul(t),n=t.redSqr().redMul(t).redIAdd(i).redIAdd(this.b);return 0===r.redSqr().redISub(n).cmpn(0)},c.prototype._endoWnafMulAdd=function(e,t,r){for(var i=this._endoWnafT1,n=this._endoWnafT2,s=0;s":""},u.prototype.isInfinity=function(){return this.inf},u.prototype.add=function(e){if(this.inf)return e;if(e.inf)return this;if(this.eq(e))return this.dbl();if(this.neg().eq(e))return this.curve.point(null,null);if(0===this.x.cmp(e.x))return this.curve.point(null,null);var t=this.y.redSub(e.y);0!==t.cmpn(0)&&(t=t.redMul(this.x.redSub(e.x).redInvm()));var r=t.redSqr().redISub(this.x).redISub(e.x),i=t.redMul(this.x.redSub(r)).redISub(this.y);return this.curve.point(r,i)},u.prototype.dbl=function(){if(this.inf)return this;var e=this.y.redAdd(this.y);if(0===e.cmpn(0))return this.curve.point(null,null);var t=this.curve.a,r=this.x.redSqr(),i=e.redInvm(),n=r.redAdd(r).redIAdd(r).redIAdd(t).redMul(i),s=n.redSqr().redISub(this.x.redAdd(this.x)),o=n.redMul(this.x.redSub(s)).redISub(this.y);return this.curve.point(s,o)},u.prototype.getX=function(){return this.x.fromRed()},u.prototype.getY=function(){return this.y.fromRed()},u.prototype.mul=function(e){return e=new n(e,16),this.isInfinity()?this:this._hasDoubles(e)?this.curve._fixedNafMul(this,e):this.curve.endo?this.curve._endoWnafMulAdd([this],[e]):this.curve._wnafMul(this,e)},u.prototype.mulAdd=function(e,t,r){var i=[this,t],n=[e,r];return this.curve.endo?this.curve._endoWnafMulAdd(i,n):this.curve._wnafMulAdd(1,i,n,2)},u.prototype.jmulAdd=function(e,t,r){var i=[this,t],n=[e,r];return this.curve.endo?this.curve._endoWnafMulAdd(i,n,!0):this.curve._wnafMulAdd(1,i,n,2,!0)},u.prototype.eq=function(e){return this===e||this.inf===e.inf&&(this.inf||0===this.x.cmp(e.x)&&0===this.y.cmp(e.y))},u.prototype.neg=function(e){if(this.inf)return this;var t=this.curve.point(this.x,this.y.redNeg());if(e&&this.precomputed){var r=this.precomputed,i=function(e){return e.neg()};t.precomputed={naf:r.naf&&{wnd:r.naf.wnd,points:r.naf.points.map(i)},doubles:r.doubles&&{step:r.doubles.step,points:r.doubles.points.map(i)}}}return t},u.prototype.toJ=function(){return this.inf?this.curve.jpoint(null,null,null):this.curve.jpoint(this.x,this.y,this.curve.one)},s(l,o.BasePoint),c.prototype.jpoint=function(e,t,r){return new l(this,e,t,r)},l.prototype.toP=function(){if(this.isInfinity())return this.curve.point(null,null);var e=this.z.redInvm(),t=e.redSqr(),r=this.x.redMul(t),i=this.y.redMul(t).redMul(e);return this.curve.point(r,i)},l.prototype.neg=function(){return this.curve.jpoint(this.x,this.y.redNeg(),this.z)},l.prototype.add=function(e){if(this.isInfinity())return e;if(e.isInfinity())return this;var t=e.z.redSqr(),r=this.z.redSqr(),i=this.x.redMul(t),n=e.x.redMul(r),s=this.y.redMul(t.redMul(e.z)),o=e.y.redMul(r.redMul(this.z)),a=i.redSub(n),c=s.redSub(o);if(0===a.cmpn(0))return 0!==c.cmpn(0)?this.curve.jpoint(null,null,null):this.dbl();var u=a.redSqr(),l=u.redMul(a),d=i.redMul(u),f=c.redSqr().redIAdd(l).redISub(d).redISub(d),h=c.redMul(d.redISub(f)).redISub(s.redMul(l)),p=this.z.redMul(e.z).redMul(a);return this.curve.jpoint(f,h,p)},l.prototype.mixedAdd=function(e){if(this.isInfinity())return e.toJ();if(e.isInfinity())return this;var t=this.z.redSqr(),r=this.x,i=e.x.redMul(t),n=this.y,s=e.y.redMul(t).redMul(this.z),o=r.redSub(i),a=n.redSub(s);if(0===o.cmpn(0))return 0!==a.cmpn(0)?this.curve.jpoint(null,null,null):this.dbl();var c=o.redSqr(),u=c.redMul(o),l=r.redMul(c),d=a.redSqr().redIAdd(u).redISub(l).redISub(l),f=a.redMul(l.redISub(d)).redISub(n.redMul(u)),h=this.z.redMul(o);return this.curve.jpoint(d,f,h)},l.prototype.dblp=function(e){if(0===e)return this;if(this.isInfinity())return this;if(!e)return this.dbl();var t;if(this.curve.zeroA||this.curve.threeA){var r=this;for(t=0;t=0)return!1;if(r.redIAdd(n),0===this.x.cmp(r))return!0}},l.prototype.inspect=function(){return this.isInfinity()?"":""},l.prototype.isInfinity=function(){return 0===this.z.cmpn(0)}},{"../utils":"959xT","bn.js":"c8Lvi",inherits:"j5plK","./base":"joYZE"}],j5plK:[function(e,t,r){"function"==typeof Object.create?t.exports=function(e,t){t&&(e.super_=t,e.prototype=Object.create(t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}))}:t.exports=function(e,t){if(t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}}},{}],exiKb:[function(e,t,r){"use strict";var i=e("bn.js"),n=e("inherits"),s=e("./base"),o=e("../utils");function a(e){s.call(this,"mont",e),this.a=new i(e.a,16).toRed(this.red),this.b=new i(e.b,16).toRed(this.red),this.i4=new i(4).toRed(this.red).redInvm(),this.two=new i(2).toRed(this.red),this.a24=this.i4.redMul(this.a.redAdd(this.two))}function c(e,t,r){s.BasePoint.call(this,e,"projective"),null===t&&null===r?(this.x=this.curve.one,this.z=this.curve.zero):(this.x=new i(t,16),this.z=new i(r,16),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)))}n(a,s),t.exports=a,a.prototype.validate=function(e){var t=e.normalize().x,r=t.redSqr(),i=r.redMul(t).redAdd(r.redMul(this.a)).redAdd(t);return 0===i.redSqrt().redSqr().cmp(i)},n(c,s.BasePoint),a.prototype.decodePoint=function(e,t){return this.point(o.toArray(e,t),1)},a.prototype.point=function(e,t){return new c(this,e,t)},a.prototype.pointFromJSON=function(e){return c.fromJSON(this,e)},c.prototype.precompute=function(){},c.prototype._encode=function(){return this.getX().toArray("be",this.curve.p.byteLength())},c.fromJSON=function(e,t){return new c(e,t[0],t[1]||e.one)},c.prototype.inspect=function(){return this.isInfinity()?"":""},c.prototype.isInfinity=function(){return 0===this.z.cmpn(0)},c.prototype.dbl=function(){var e=this.x.redAdd(this.z).redSqr(),t=this.x.redSub(this.z).redSqr(),r=e.redSub(t),i=e.redMul(t),n=r.redMul(t.redAdd(this.curve.a24.redMul(r)));return this.curve.point(i,n)},c.prototype.add=function(){throw new Error("Not supported on Montgomery curve")},c.prototype.diffAdd=function(e,t){var r=this.x.redAdd(this.z),i=this.x.redSub(this.z),n=e.x.redAdd(e.z),s=e.x.redSub(e.z).redMul(r),o=n.redMul(i),a=t.z.redMul(s.redAdd(o).redSqr()),c=t.x.redMul(s.redISub(o).redSqr());return this.curve.point(a,c)},c.prototype.mul=function(e){for(var t=e.clone(),r=this,i=this.curve.point(null,null),n=[];0!==t.cmpn(0);t.iushrn(1))n.push(t.andln(1));for(var s=n.length-1;s>=0;s--)0===n[s]?(r=r.diffAdd(i,this),i=i.dbl()):(i=r.diffAdd(i,this),r=r.dbl());return i},c.prototype.mulAdd=function(){throw new Error("Not supported on Montgomery curve")},c.prototype.jumlAdd=function(){throw new Error("Not supported on Montgomery curve")},c.prototype.eq=function(e){return 0===this.getX().cmp(e.getX())},c.prototype.normalize=function(){return this.x=this.x.redMul(this.z.redInvm()),this.z=this.curve.one,this},c.prototype.getX=function(){return this.normalize(),this.x.fromRed()}},{"bn.js":"c8Lvi",inherits:"j5plK","./base":"joYZE","../utils":"959xT"}],d2B4t:[function(e,t,r){"use strict";var i=e("../utils"),n=e("bn.js"),s=e("inherits"),o=e("./base"),a=i.assert;function c(e){this.twisted=1!=(0|e.a),this.mOneA=this.twisted&&-1==(0|e.a),this.extended=this.mOneA,o.call(this,"edwards",e),this.a=new n(e.a,16).umod(this.red.m),this.a=this.a.toRed(this.red),this.c=new n(e.c,16).toRed(this.red),this.c2=this.c.redSqr(),this.d=new n(e.d,16).toRed(this.red),this.dd=this.d.redAdd(this.d),a(!this.twisted||0===this.c.fromRed().cmpn(1)),this.oneC=1==(0|e.c)}function u(e,t,r,i,s){o.BasePoint.call(this,e,"projective"),null===t&&null===r&&null===i?(this.x=this.curve.zero,this.y=this.curve.one,this.z=this.curve.one,this.t=this.curve.zero,this.zOne=!0):(this.x=new n(t,16),this.y=new n(r,16),this.z=i?new n(i,16):this.curve.one,this.t=s&&new n(s,16),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.y.red||(this.y=this.y.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)),this.t&&!this.t.red&&(this.t=this.t.toRed(this.curve.red)),this.zOne=this.z===this.curve.one,this.curve.extended&&!this.t&&(this.t=this.x.redMul(this.y),this.zOne||(this.t=this.t.redMul(this.z.redInvm()))))}s(c,o),t.exports=c,c.prototype._mulA=function(e){return this.mOneA?e.redNeg():this.a.redMul(e)},c.prototype._mulC=function(e){return this.oneC?e:this.c.redMul(e)},c.prototype.jpoint=function(e,t,r,i){return this.point(e,t,r,i)},c.prototype.pointFromX=function(e,t){(e=new n(e,16)).red||(e=e.toRed(this.red));var r=e.redSqr(),i=this.c2.redSub(this.a.redMul(r)),s=this.one.redSub(this.c2.redMul(this.d).redMul(r)),o=i.redMul(s.redInvm()),a=o.redSqrt();if(0!==a.redSqr().redSub(o).cmp(this.zero))throw new Error("invalid point");var c=a.fromRed().isOdd();return(t&&!c||!t&&c)&&(a=a.redNeg()),this.point(e,a)},c.prototype.pointFromY=function(e,t){(e=new n(e,16)).red||(e=e.toRed(this.red));var r=e.redSqr(),i=r.redSub(this.c2),s=r.redMul(this.d).redMul(this.c2).redSub(this.a),o=i.redMul(s.redInvm());if(0===o.cmp(this.zero)){if(t)throw new Error("invalid point");return this.point(this.zero,e)}var a=o.redSqrt();if(0!==a.redSqr().redSub(o).cmp(this.zero))throw new Error("invalid point");return a.fromRed().isOdd()!==t&&(a=a.redNeg()),this.point(a,e)},c.prototype.validate=function(e){if(e.isInfinity())return!0;e.normalize();var t=e.x.redSqr(),r=e.y.redSqr(),i=t.redMul(this.a).redAdd(r),n=this.c2.redMul(this.one.redAdd(this.d.redMul(t).redMul(r)));return 0===i.cmp(n)},s(u,o.BasePoint),c.prototype.pointFromJSON=function(e){return u.fromJSON(this,e)},c.prototype.point=function(e,t,r,i){return new u(this,e,t,r,i)},u.fromJSON=function(e,t){return new u(e,t[0],t[1],t[2])},u.prototype.inspect=function(){return this.isInfinity()?"":""},u.prototype.isInfinity=function(){return 0===this.x.cmpn(0)&&(0===this.y.cmp(this.z)||this.zOne&&0===this.y.cmp(this.curve.c))},u.prototype._extDbl=function(){var e=this.x.redSqr(),t=this.y.redSqr(),r=this.z.redSqr();r=r.redIAdd(r);var i=this.curve._mulA(e),n=this.x.redAdd(this.y).redSqr().redISub(e).redISub(t),s=i.redAdd(t),o=s.redSub(r),a=i.redSub(t),c=n.redMul(o),u=s.redMul(a),l=n.redMul(a),d=o.redMul(s);return this.curve.point(c,u,d,l)},u.prototype._projDbl=function(){var e,t,r,i,n,s,o=this.x.redAdd(this.y).redSqr(),a=this.x.redSqr(),c=this.y.redSqr();if(this.curve.twisted){var u=(i=this.curve._mulA(a)).redAdd(c);this.zOne?(e=o.redSub(a).redSub(c).redMul(u.redSub(this.curve.two)),t=u.redMul(i.redSub(c)),r=u.redSqr().redSub(u).redSub(u)):(n=this.z.redSqr(),s=u.redSub(n).redISub(n),e=o.redSub(a).redISub(c).redMul(s),t=u.redMul(i.redSub(c)),r=u.redMul(s))}else i=a.redAdd(c),n=this.curve._mulC(this.z).redSqr(),s=i.redSub(n).redSub(n),e=this.curve._mulC(o.redISub(i)).redMul(s),t=this.curve._mulC(i).redMul(a.redISub(c)),r=i.redMul(s);return this.curve.point(e,t,r)},u.prototype.dbl=function(){return this.isInfinity()?this:this.curve.extended?this._extDbl():this._projDbl()},u.prototype._extAdd=function(e){var t=this.y.redSub(this.x).redMul(e.y.redSub(e.x)),r=this.y.redAdd(this.x).redMul(e.y.redAdd(e.x)),i=this.t.redMul(this.curve.dd).redMul(e.t),n=this.z.redMul(e.z.redAdd(e.z)),s=r.redSub(t),o=n.redSub(i),a=n.redAdd(i),c=r.redAdd(t),u=s.redMul(o),l=a.redMul(c),d=s.redMul(c),f=o.redMul(a);return this.curve.point(u,l,f,d)},u.prototype._projAdd=function(e){var t,r,i=this.z.redMul(e.z),n=i.redSqr(),s=this.x.redMul(e.x),o=this.y.redMul(e.y),a=this.curve.d.redMul(s).redMul(o),c=n.redSub(a),u=n.redAdd(a),l=this.x.redAdd(this.y).redMul(e.x.redAdd(e.y)).redISub(s).redISub(o),d=i.redMul(c).redMul(l);return this.curve.twisted?(t=i.redMul(u).redMul(o.redSub(this.curve._mulA(s))),r=c.redMul(u)):(t=i.redMul(u).redMul(o.redSub(s)),r=this.curve._mulC(c).redMul(u)),this.curve.point(d,t,r)},u.prototype.add=function(e){return this.isInfinity()?e:e.isInfinity()?this:this.curve.extended?this._extAdd(e):this._projAdd(e)},u.prototype.mul=function(e){return this._hasDoubles(e)?this.curve._fixedNafMul(this,e):this.curve._wnafMul(this,e)},u.prototype.mulAdd=function(e,t,r){return this.curve._wnafMulAdd(1,[this,t],[e,r],2,!1)},u.prototype.jmulAdd=function(e,t,r){return this.curve._wnafMulAdd(1,[this,t],[e,r],2,!0)},u.prototype.normalize=function(){if(this.zOne)return this;var e=this.z.redInvm();return this.x=this.x.redMul(e),this.y=this.y.redMul(e),this.t&&(this.t=this.t.redMul(e)),this.z=this.curve.one,this.zOne=!0,this},u.prototype.neg=function(){return this.curve.point(this.x.redNeg(),this.y,this.z,this.t&&this.t.redNeg())},u.prototype.getX=function(){return this.normalize(),this.x.fromRed()},u.prototype.getY=function(){return this.normalize(),this.y.fromRed()},u.prototype.eq=function(e){return this===e||0===this.getX().cmp(e.getX())&&0===this.getY().cmp(e.getY())},u.prototype.eqXToP=function(e){var t=e.toRed(this.curve.red).redMul(this.z);if(0===this.x.cmp(t))return!0;for(var r=e.clone(),i=this.curve.redN.redMul(this.z);;){if(r.iadd(this.curve.n),r.cmp(this.curve.p)>=0)return!1;if(t.redIAdd(i),0===this.x.cmp(t))return!0}},u.prototype.toP=u.prototype.normalize,u.prototype.mixedAdd=u.prototype.add},{"../utils":"959xT","bn.js":"c8Lvi",inherits:"j5plK","./base":"joYZE"}],"4unkA":[function(e,t,r){"use strict";var i,n=r,s=e("hash.js"),o=e("./curve"),a=e("./utils").assert;function c(e){"short"===e.type?this.curve=new o.short(e):"edwards"===e.type?this.curve=new o.edwards(e):this.curve=new o.mont(e),this.g=this.curve.g,this.n=this.curve.n,this.hash=e.hash,a(this.g.validate(),"Invalid curve"),a(this.g.mul(this.n).isInfinity(),"Invalid curve, G*N != O")}function u(e,t){Object.defineProperty(n,e,{configurable:!0,enumerable:!0,get:function(){var r=new c(t);return Object.defineProperty(n,e,{configurable:!0,enumerable:!0,value:r}),r}})}n.PresetCurve=c,u("p192",{type:"short",prime:"p192",p:"ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff",a:"ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc",b:"64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1",n:"ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831",hash:s.sha256,gRed:!1,g:["188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012","07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811"]}),u("p224",{type:"short",prime:"p224",p:"ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001",a:"ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe",b:"b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4",n:"ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d",hash:s.sha256,gRed:!1,g:["b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21","bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34"]}),u("p256",{type:"short",prime:null,p:"ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff",a:"ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc",b:"5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b",n:"ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551",hash:s.sha256,gRed:!1,g:["6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296","4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5"]}),u("p384",{type:"short",prime:null,p:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 ffffffff",a:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 fffffffc",b:"b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f 5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef",n:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 f4372ddf 581a0db2 48b0a77a ecec196a ccc52973",hash:s.sha384,gRed:!1,g:["aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 5502f25d bf55296c 3a545e38 72760ab7","3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 0a60b1ce 1d7e819d 7a431d7c 90ea0e5f"]}),u("p521",{type:"short",prime:null,p:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff",a:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffc",b:"00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b 99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd 3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00",n:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409",hash:s.sha512,gRed:!1,g:["000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66","00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 3fad0761 353c7086 a272c240 88be9476 9fd16650"]}),u("curve25519",{type:"mont",prime:"p25519",p:"7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed",a:"76d06",b:"1",n:"1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed",hash:s.sha256,gRed:!1,g:["9"]}),u("ed25519",{type:"edwards",prime:"p25519",p:"7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed",a:"-1",c:"1",d:"52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3",n:"1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed",hash:s.sha256,gRed:!1,g:["216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a","6666666666666666666666666666666666666666666666666666666666666658"]});try{i=e("./precomputed/secp256k1")}catch(e){i=void 0}u("secp256k1",{type:"short",prime:"k256",p:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f",a:"0",b:"7",n:"ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141",h:"1",hash:s.sha256,beta:"7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee",lambda:"5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72",basis:[{a:"3086d221a7d46bcde86c90e49284eb15",b:"-e4437ed6010e88286f547fa90abfe4c3"},{a:"114ca50f7a8e2f3f657c1108d9d44cfd8",b:"3086d221a7d46bcde86c90e49284eb15"}],gRed:!1,g:["79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798","483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8",i]})},{"hash.js":"8UgFw","./curve":"byDyH","./utils":"959xT","./precomputed/secp256k1":"0oQdV"}],"8UgFw":[function(e,t,r){var i=r;i.utils=e("./hash/utils"),i.common=e("./hash/common"),i.sha=e("./hash/sha"),i.ripemd=e("./hash/ripemd"),i.hmac=e("./hash/hmac"),i.sha1=i.sha.sha1,i.sha256=i.sha.sha256,i.sha224=i.sha.sha224,i.sha384=i.sha.sha384,i.sha512=i.sha.sha512,i.ripemd160=i.ripemd.ripemd160},{"./hash/utils":"fs59i","./hash/common":"bUDg4","./hash/sha":"allnM","./hash/ripemd":"11wsf","./hash/hmac":"7ZuTN"}],fs59i:[function(e,t,r){"use strict";var i=e("minimalistic-assert"),n=e("inherits");function s(e,t){return 55296==(64512&e.charCodeAt(t))&&(!(t<0||t+1>=e.length)&&56320==(64512&e.charCodeAt(t+1)))}function o(e){return(e>>>24|e>>>8&65280|e<<8&16711680|(255&e)<<24)>>>0}function a(e){return 1===e.length?"0"+e:e}function c(e){return 7===e.length?"0"+e:6===e.length?"00"+e:5===e.length?"000"+e:4===e.length?"0000"+e:3===e.length?"00000"+e:2===e.length?"000000"+e:1===e.length?"0000000"+e:e}r.inherits=n,r.toArray=function(e,t){if(Array.isArray(e))return e.slice();if(!e)return[];var r=[];if("string"==typeof e)if(t){if("hex"===t)for((e=e.replace(/[^a-z0-9]+/gi,"")).length%2!=0&&(e="0"+e),n=0;n>6|192,r[i++]=63&o|128):s(e,n)?(o=65536+((1023&o)<<10)+(1023&e.charCodeAt(++n)),r[i++]=o>>18|240,r[i++]=o>>12&63|128,r[i++]=o>>6&63|128,r[i++]=63&o|128):(r[i++]=o>>12|224,r[i++]=o>>6&63|128,r[i++]=63&o|128)}else for(n=0;n>>0}return o},r.split32=function(e,t){for(var r=new Array(4*e.length),i=0,n=0;i>>24,r[n+1]=s>>>16&255,r[n+2]=s>>>8&255,r[n+3]=255&s):(r[n+3]=s>>>24,r[n+2]=s>>>16&255,r[n+1]=s>>>8&255,r[n]=255&s)}return r},r.rotr32=function(e,t){return e>>>t|e<<32-t},r.rotl32=function(e,t){return e<>>32-t},r.sum32=function(e,t){return e+t>>>0},r.sum32_3=function(e,t,r){return e+t+r>>>0},r.sum32_4=function(e,t,r,i){return e+t+r+i>>>0},r.sum32_5=function(e,t,r,i,n){return e+t+r+i+n>>>0},r.sum64=function(e,t,r,i){var n=e[t],s=i+e[t+1]>>>0,o=(s>>0,e[t+1]=s},r.sum64_hi=function(e,t,r,i){return(t+i>>>0>>0},r.sum64_lo=function(e,t,r,i){return t+i>>>0},r.sum64_4_hi=function(e,t,r,i,n,s,o,a){var c=0,u=t;return c+=(u=u+i>>>0)>>0)>>0)>>0},r.sum64_4_lo=function(e,t,r,i,n,s,o,a){return t+i+s+a>>>0},r.sum64_5_hi=function(e,t,r,i,n,s,o,a,c,u){var l=0,d=t;return l+=(d=d+i>>>0)>>0)>>0)>>0)>>0},r.sum64_5_lo=function(e,t,r,i,n,s,o,a,c,u){return t+i+s+a+u>>>0},r.rotr64_hi=function(e,t,r){return(t<<32-r|e>>>r)>>>0},r.rotr64_lo=function(e,t,r){return(e<<32-r|t>>>r)>>>0},r.shr64_hi=function(e,t,r){return e>>>r},r.shr64_lo=function(e,t,r){return(e<<32-r|t>>>r)>>>0}},{"minimalistic-assert":"1GrVu",inherits:"j5plK"}],bUDg4:[function(e,t,r){"use strict";var i=e("./utils"),n=e("minimalistic-assert");function s(){this.pending=null,this.pendingTotal=0,this.blockSize=this.constructor.blockSize,this.outSize=this.constructor.outSize,this.hmacStrength=this.constructor.hmacStrength,this.padLength=this.constructor.padLength/8,this.endian="big",this._delta8=this.blockSize/8,this._delta32=this.blockSize/32}r.BlockHash=s,s.prototype.update=function(e,t){if(e=i.toArray(e,t),this.pending?this.pending=this.pending.concat(e):this.pending=e,this.pendingTotal+=e.length,this.pending.length>=this._delta8){var r=(e=this.pending).length%this._delta8;this.pending=e.slice(e.length-r,e.length),0===this.pending.length&&(this.pending=null),e=i.join32(e,0,e.length-r,this.endian);for(var n=0;n>>24&255,i[n++]=e>>>16&255,i[n++]=e>>>8&255,i[n++]=255&e}else for(i[n++]=255&e,i[n++]=e>>>8&255,i[n++]=e>>>16&255,i[n++]=e>>>24&255,i[n++]=0,i[n++]=0,i[n++]=0,i[n++]=0,s=8;s>>3},r.g1_256=function(e){return i(e,17)^i(e,19)^e>>>10}},{"../utils":"fs59i"}],"5p3po":[function(e,t,r){"use strict";var i=e("../utils"),n=e("./256");function s(){if(!(this instanceof s))return new s;n.call(this),this.h=[3238371032,914150663,812702999,4144912697,4290775857,1750603025,1694076839,3204075428]}i.inherits(s,n),t.exports=s,s.blockSize=512,s.outSize=224,s.hmacStrength=192,s.padLength=64,s.prototype._digest=function(e){return"hex"===e?i.toHex32(this.h.slice(0,7),"big"):i.split32(this.h.slice(0,7),"big")}},{"../utils":"fs59i","./256":"kwXkv"}],kwXkv:[function(e,t,r){"use strict";var i=e("../utils"),n=e("../common"),s=e("./common"),o=e("minimalistic-assert"),a=i.sum32,c=i.sum32_4,u=i.sum32_5,l=s.ch32,d=s.maj32,f=s.s0_256,h=s.s1_256,p=s.g0_256,g=s.g1_256,y=n.BlockHash,m=[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];function b(){if(!(this instanceof b))return new b;y.call(this),this.h=[1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225],this.k=m,this.W=new Array(64)}i.inherits(b,y),t.exports=b,b.blockSize=512,b.outSize=256,b.hmacStrength=192,b.padLength=64,b.prototype._update=function(e,t){for(var r=this.W,i=0;i<16;i++)r[i]=e[t+i];for(;ithis.blockSize&&(e=(new this.Hash).update(e).digest()),n(e.length<=this.blockSize);for(var t=e.length;t0))return o.iaddn(1),this.keyFromPrivate(o)}},d.prototype._truncateToN=function(e,t){var r=8*e.byteLength()-this.n.bitLength();return r>0&&(e=e.ushrn(r)),!t&&e.cmp(this.n)>=0?e.sub(this.n):e},d.prototype.sign=function(e,t,r,s){"object"==typeof r&&(s=r,r=null),s||(s={}),t=this.keyFromPrivate(t,r),e=this._truncateToN(new i(e,16));for(var o=this.n.byteLength(),a=t.getPrivate().toArray("be",o),c=e.toArray("be",o),u=new n({hash:this.hash,entropy:a,nonce:c,pers:s.pers,persEnc:s.persEnc||"utf8"}),d=this.n.sub(new i(1)),f=0;;f++){var h=s.k?s.k(f):new i(u.generate(this.n.byteLength()));if(!((h=this._truncateToN(h,!0)).cmpn(1)<=0||h.cmp(d)>=0)){var p=this.g.mul(h);if(!p.isInfinity()){var g=p.getX(),y=g.umod(this.n);if(0!==y.cmpn(0)){var m=h.invm(this.n).mul(y.mul(t.getPrivate()).iadd(e));if(0!==(m=m.umod(this.n)).cmpn(0)){var b=(p.getY().isOdd()?1:0)|(0!==g.cmp(y)?2:0);return s.canonical&&m.cmp(this.nh)>0&&(m=this.n.sub(m),b^=1),new l({r:y,s:m,recoveryParam:b})}}}}}},d.prototype.verify=function(e,t,r,n){e=this._truncateToN(new i(e,16)),r=this.keyFromPublic(r,n);var s=(t=new l(t,"hex")).r,o=t.s;if(s.cmpn(1)<0||s.cmp(this.n)>=0)return!1;if(o.cmpn(1)<0||o.cmp(this.n)>=0)return!1;var a,c=o.invm(this.n),u=c.mul(e).umod(this.n),d=c.mul(s).umod(this.n);return this.curve._maxwellTrick?!(a=this.g.jmulAdd(u,r.getPublic(),d)).isInfinity()&&a.eqXToP(s):!(a=this.g.mulAdd(u,r.getPublic(),d)).isInfinity()&&0===a.getX().umod(this.n).cmp(s)},d.prototype.recoverPubKey=function(e,t,r,n){c((3&r)===r,"The recovery param is more than two bits"),t=new l(t,n);var s=this.n,o=new i(e),a=t.r,u=t.s,d=1&r,f=r>>1;if(a.cmp(this.curve.p.umod(this.curve.n))>=0&&f)throw new Error("Unable to find sencond key candinate");a=f?this.curve.pointFromX(a.add(this.curve.n),d):this.curve.pointFromX(a,d);var h=t.r.invm(s),p=s.sub(o).mul(h).umod(s),g=u.mul(h).umod(s);return this.g.mulAdd(p,a,g)},d.prototype.getKeyRecoveryParam=function(e,t,r,i){if(null!==(t=new l(t,i)).recoveryParam)return t.recoveryParam;for(var n=0;n<4;n++){var s;try{s=this.recoverPubKey(e,t,n)}catch(e){continue}if(s.eq(r))return n}throw new Error("Unable to find valid recovery factor")}},{"bn.js":"c8Lvi","hmac-drbg":"iPkoP","../utils":"959xT","../curves":"4unkA",brorand:"P54o1","./key":"9sGQ9","./signature":"hmVaw"}],iPkoP:[function(e,t,r){"use strict";var i=e("hash.js"),n=e("minimalistic-crypto-utils"),s=e("minimalistic-assert");function o(e){if(!(this instanceof o))return new o(e);this.hash=e.hash,this.predResist=!!e.predResist,this.outLen=this.hash.outSize,this.minEntropy=e.minEntropy||this.hash.hmacStrength,this._reseed=null,this.reseedInterval=null,this.K=null,this.V=null;var t=n.toArray(e.entropy,e.entropyEnc||"hex"),r=n.toArray(e.nonce,e.nonceEnc||"hex"),i=n.toArray(e.pers,e.persEnc||"hex");s(t.length>=this.minEntropy/8,"Not enough entropy. Minimum is: "+this.minEntropy+" bits"),this._init(t,r,i)}t.exports=o,o.prototype._init=function(e,t,r){var i=e.concat(t).concat(r);this.K=new Array(this.outLen/8),this.V=new Array(this.outLen/8);for(var n=0;n=this.minEntropy/8,"Not enough entropy. Minimum is: "+this.minEntropy+" bits"),this._update(e.concat(r||[])),this._reseed=1},o.prototype.generate=function(e,t,r,i){if(this._reseed>this.reseedInterval)throw new Error("Reseed is required");"string"!=typeof t&&(i=r,r=t,t=null),r&&(r=n.toArray(r,i||"hex"),this._update(r));for(var s=[];s.length"}},{"bn.js":"c8Lvi","../utils":"959xT"}],hmVaw:[function(e,t,r){"use strict";var i=e("bn.js"),n=e("../utils"),s=n.assert;function o(e,t){if(e instanceof o)return e;this._importDER(e,t)||(s(e.r&&e.s,"Signature without r or s"),this.r=new i(e.r,16),this.s=new i(e.s,16),void 0===e.recoveryParam?this.recoveryParam=null:this.recoveryParam=e.recoveryParam)}function a(){this.place=0}function c(e,t){var r=e[t.place++];if(!(128&r))return r;var i=15&r;if(0===i||i>4)return!1;for(var n=0,s=0,o=t.place;s>>=0;return!(n<=127)&&(t.place=o,n)}function u(e){for(var t=0,r=e.length-1;!e[t]&&!(128&e[t+1])&&t>>3);for(e.push(128|r);--r;)e.push(t>>>(r<<3)&255);e.push(t)}}t.exports=o,o.prototype._importDER=function(e,t){e=n.toArray(e,t);var r=new a;if(48!==e[r.place++])return!1;var s=c(e,r);if(!1===s)return!1;if(s+r.place!==e.length)return!1;if(2!==e[r.place++])return!1;var o=c(e,r);if(!1===o)return!1;var u=e.slice(r.place,o+r.place);if(r.place+=o,2!==e[r.place++])return!1;var l=c(e,r);if(!1===l)return!1;if(e.length!==l+r.place)return!1;var d=e.slice(r.place,l+r.place);if(0===u[0]){if(!(128&u[1]))return!1;u=u.slice(1)}if(0===d[0]){if(!(128&d[1]))return!1;d=d.slice(1)}return this.r=new i(u),this.s=new i(d),this.recoveryParam=null,!0},o.prototype.toDER=function(e){var t=this.r.toArray(),r=this.s.toArray();for(128&t[0]&&(t=[0].concat(t)),128&r[0]&&(r=[0].concat(r)),t=u(t),r=u(r);!(r[0]||128&r[1]);)r=r.slice(1);var i=[2];l(i,t.length),(i=i.concat(t)).push(2),l(i,r.length);var s=i.concat(r),o=[48];return l(o,s.length),o=o.concat(s),n.encode(o,e)}},{"bn.js":"c8Lvi","../utils":"959xT"}],j2H5w:[function(e,t,r){"use strict";var i=e("hash.js"),n=e("../curves"),s=e("../utils"),o=s.assert,a=s.parseBytes,c=e("./key"),u=e("./signature");function l(e){if(o("ed25519"===e,"only tested with ed25519 so far"),!(this instanceof l))return new l(e);e=n[e].curve,this.curve=e,this.g=e.g,this.g.precompute(e.n.bitLength()+1),this.pointClass=e.point().constructor,this.encodingLength=Math.ceil(e.n.bitLength()/8),this.hash=i.sha512}t.exports=l,l.prototype.sign=function(e,t){e=a(e);var r=this.keyFromSecret(t),i=this.hashInt(r.messagePrefix(),e),n=this.g.mul(i),s=this.encodePoint(n),o=this.hashInt(s,r.pubBytes(),e).mul(r.priv()),c=i.add(o).umod(this.curve.n);return this.makeSignature({R:n,S:c,Rencoded:s})},l.prototype.verify=function(e,t,r){e=a(e),t=this.makeSignature(t);var i=this.keyFromPublic(r),n=this.hashInt(t.Rencoded(),i.pubBytes(),e),s=this.g.mul(t.S());return t.R().add(i.pub().mul(n)).eq(s)},l.prototype.hashInt=function(){for(var e=this.hash(),t=0;t{const c=a[e];if(!c){const t=Object.keys(a).join(" / ");throw i(new Error(`unknown cipher type '${e}'. Must be ${t}`),"ERR_INVALID_CIPHER_TYPE")}if(!t)throw i(new Error("missing hash type"),"ERR_MISSING_HASH_TYPE");const u=c.keySize,l=c.ivSize,d=s("key expansion"),f=2*(l+u+20),h=await o.create(t,r);let p=await h.digest(d);const g=[];let y=0;for(;yf&&(t=f-y),g.push(e),y+=t,p=await h.digest(p)}const m=f/2,b=n(g),v=b.slice(0,m),w=b.slice(m,f),_=e=>({iv:e.slice(0,l),cipherKey:e.slice(l,l+u),macKey:e.slice(l+u)});return{k1:_(v),k2:_(w)}}},{"err-code":"chZjB","uint8arrays/concat":"4EBjG","uint8arrays/from-string":"dF7Y4","../hmac":"JUsR3"}],JUsR3:[function(e,t,r){"use strict";const i=e("../webcrypto"),n=e("./lengths"),s={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"};r.create=async function(e,t){const r=s[e],o=await i.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:r}},!1,["sign"]);return{digest:async e=>(async(e,t)=>{const r=await i.get().subtle.sign({name:"HMAC"},e,t);return new Uint8Array(r,r.byteOffset,r.byteLength)})(o,e),length:n[e]}}},{"../webcrypto":"i99ng","./lengths":"8g8ed"}],"8g8ed":[function(e,t,r){"use strict";t.exports={SHA1:20,SHA256:32,SHA512:64}},{}],ds3K5:[function(e,t,r){"use strict";const i=e("./ecdh");t.exports=async e=>i.generateEphmeralKeyPair(e)},{"./ecdh":"bSsHl"}],bSsHl:[function(e,t,r){"use strict";const i=e("err-code"),n=e("../webcrypto"),{base64urlToBuffer:s}=e("../util"),o=e("./validate-curve-type"),{toString:a}=e("uint8arrays/to-string"),{concat:c}=e("uint8arrays/concat"),{equals:u}=e("uint8arrays/equals"),l={"P-256":256,"P-384":384,"P-521":521};r.generateEphmeralKeyPair=async function(e){o(Object.keys(l),e);const t=await n.get().subtle.generateKey({name:"ECDH",namedCurve:e},!0,["deriveBits"]);return{key:f(await n.get().subtle.exportKey("jwk",t.publicKey)),genSharedKey:async(r,i)=>{let s;s=i?await n.get().subtle.importKey("jwk",p(e,i),{name:"ECDH",namedCurve:e},!1,["deriveBits"]):t.privateKey;const o=[await n.get().subtle.importKey("jwk",h(e,r),{name:"ECDH",namedCurve:e},!1,[]),s],a=await n.get().subtle.deriveBits({name:"ECDH",namedCurve:e,public:o[0]},o[1],l[e]);return new Uint8Array(a,a.byteOffset,a.byteLength)}}};const d={"P-256":32,"P-384":48,"P-521":66};function f(e){const t=d[e.crv];return c([Uint8Array.from([4]),s(e.x,t),s(e.y,t)],1+2*t)}function h(e,t){const r=d[e];if(u(!t.slice(0,1),Uint8Array.from([4])))throw i(new Error("Cannot unmarshal public key - invalid key format"),"ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:e,x:a(t.slice(1,r+1),"base64url"),y:a(t.slice(1+r),"base64url"),ext:!0}}const p=(e,t)=>({...h(e,t.public),d:a(t.private,"base64url")})},{"err-code":"chZjB","../webcrypto":"i99ng","../util":"ffmp6","./validate-curve-type":"8CFUR","uint8arrays/to-string":"hC8JB","uint8arrays/concat":"4EBjG","uint8arrays/equals":"eY3cX"}],"8CFUR":[function(e,t,r){"use strict";const i=e("err-code");t.exports=function(e,t){if(!e.includes(t)){const r=e.join(" / ");throw i(new Error(`Unknown curve: ${t}. Must be ${r}`),"ERR_INVALID_CURVE")}}},{"err-code":"chZjB"}],gx31A:[function(e,t,r){"use strict";t.exports=function(e,{className:t,symbolName:r}){const i=Symbol.for(r),n={[t]:class extends e{constructor(...e){super(...e),Object.defineProperty(this,i,{value:!0})}get[Symbol.toStringTag](){return t}}}[t];return n[`is${t}`]=e=>!(!e||!e[i]),n},t.exports.proto=function(e,{className:t,symbolName:r,withoutNew:i}){const n=Symbol.for(r),s={[t]:function(...t){if(i&&!(this instanceof s))return new s(...t);const r=e.call(this,...t)||this;return r&&!r[n]&&Object.defineProperty(r,n,{value:!0}),r}}[t];return s.prototype=Object.create(e.prototype),s.prototype.constructor=s,Object.defineProperty(s.prototype,Symbol.toStringTag,{get:()=>t}),s[`is${t}`]=e=>!(!e||!e[n]),s}},{}],c0IJt:[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-peer-id"]||(i.roots["libp2p-peer-id"]={});a.PeerIdProto=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.id=e.bytes();break;case 2:i.pubKey=e.bytes();break;case 3:i.privKey=e.bytes();break;default:e.skipType(7&s)}}if(!i.hasOwnProperty("id"))throw o.ProtocolError("missing required 'id'",{instance:i});return i},e.fromObject=function(e){if(e instanceof a.PeerIdProto)return e;var t=new a.PeerIdProto;return null!=e.id&&("string"==typeof e.id?o.base64.decode(e.id,t.id=o.newBuffer(o.base64.length(e.id)),0):e.id.length&&(t.id=e.id)),null!=e.pubKey&&("string"==typeof e.pubKey?o.base64.decode(e.pubKey,t.pubKey=o.newBuffer(o.base64.length(e.pubKey)),0):e.pubKey.length&&(t.pubKey=e.pubKey)),null!=e.privKey&&("string"==typeof e.privKey?o.base64.decode(e.privKey,t.privKey=o.newBuffer(o.base64.length(e.privKey)),0):e.privKey.length&&(t.privKey=e.privKey)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(t.bytes===String?r.id="":(r.id=[],t.bytes!==Array&&(r.id=o.newBuffer(r.id))),t.bytes===String?r.pubKey="":(r.pubKey=[],t.bytes!==Array&&(r.pubKey=o.newBuffer(r.pubKey))),t.bytes===String?r.privKey="":(r.privKey=[],t.bytes!==Array&&(r.privKey=o.newBuffer(r.privKey)))),null!=e.id&&e.hasOwnProperty("id")&&(r.id=t.bytes===String?o.base64.encode(e.id,0,e.id.length):t.bytes===Array?Array.prototype.slice.call(e.id):e.id),null!=e.pubKey&&e.hasOwnProperty("pubKey")&&(r.pubKey=t.bytes===String?o.base64.encode(e.pubKey,0,e.pubKey.length):t.bytes===Array?Array.prototype.slice.call(e.pubKey):e.pubKey),null!=e.privKey&&e.hasOwnProperty("privKey")&&(r.privKey=t.bytes===String?o.base64.encode(e.privKey,0,e.privKey.length):t.bytes===Array?Array.prototype.slice.call(e.privKey):e.privKey),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,i.util.toJSONOptions)},e}(),t.exports=a},{"protobufjs/minimal":"grAXL"}],hDUM1:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./add.js"),n=e("./add-all.js"),s=e("./ls.js"),o=e("./rm.js"),a=e("./rm-all.js");r.PinAPI=class{constructor({codecs:e,repo:t}){const r=n.createAddAll({codecs:e,repo:t});this.addAll=r,this.add=i.createAdd({addAll:r});const c=a.createRmAll({codecs:e,repo:t});this.rmAll=c,this.rm=o.createRm({rmAll:c}),this.ls=s.createLs({codecs:e,repo:t}),this.remote={add:(e,t={})=>Promise.reject(new Error("Not implemented")),ls:async function*(e,t={}){return Promise.reject(new Error("Not implemented"))},rm:(e,t={})=>Promise.reject(new Error("Not implemented")),rmAll:(e,t={})=>Promise.reject(new Error("Not implemented")),service:{add:(e,t)=>Promise.reject(new Error("Not implemented")),rm:(e,t={})=>Promise.reject(new Error("Not implemented")),ls:(e={})=>Promise.reject(new Error("Not implemented"))}}}}},{"./add.js":"lM2k0","./add-all.js":"5qgaX","./ls.js":"hVzUN","./rm.js":"khHqn","./rm-all.js":"5GWqa"}],lM2k0:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("it-last"),n=e("multiformats/cid");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=s(i);r.createAdd=function({addAll:e}){return(t,r={})=>{let i;const s=n.CID.asCID(t);return i=e(s?[{cid:s,...r}]:[{path:t.toString(),...r}],r),o.default(i)}}},{"it-last":"cSXX9","multiformats/cid":"9ooAY"}],cSXX9:[function(e,t,r){"use strict";t.exports=async e=>{let t;for await(const r of e)t=r;return t}},{}],"5qgaX":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../utils.js"),n=e("ipfs-core-utils/with-timeout-option"),s=e("ipfs-core-utils/pins/normalise-input"),o=e("ipfs-repo/pin-types");r.createAddAll=function({repo:e,codecs:t}){return n.withTimeoutOption((async function*(r,n={}){const a=async function*(){for await(const{path:n,recursive:a,metadata:c}of s.normaliseInput(r)){const{cid:r}=await i.resolvePath(e,t,n),{reason:s}=await e.pins.isPinnedWithType(r,[o.PinTypes.recursive,o.PinTypes.direct]);if("recursive"===s&&!a)throw new Error(`${r} already pinned recursively`);a?await e.pins.pinRecursively(r,{metadata:c}):await e.pins.pinDirectly(r,{metadata:c}),yield r}};if(!Boolean(n.lock))return void(yield*a());const c=await e.gcLock.readLock();try{yield*a()}finally{c()}}))}},{"../../utils.js":"cT4uN","ipfs-core-utils/with-timeout-option":"j29MK","ipfs-core-utils/pins/normalise-input":"4NDJq","ipfs-repo/pin-types":"uek22"}],"4NDJq":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("err-code"),n=e("multiformats/cid");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=s(i);function a(e){const t=e.cid||`${e.path}`;if(!t)throw o.default(new Error("Unexpected input: Please path either a CID or an IPFS path"),"ERR_UNEXPECTED_INPUT");const r={path:t,recursive:!1!==e.recursive};return null!=e.metadata&&(r.metadata=e.metadata),r}r.normaliseInput=async function*(e){if(null==e)throw o.default(new Error(`Unexpected input: ${e}`),"ERR_UNEXPECTED_INPUT");const t=n.CID.asCID(e);if(t)yield a({cid:t});else{if(!(e instanceof String||"string"==typeof e)){if(null!=e.cid||null!=e.path)return yield a(e);if(Symbol.iterator in e){const t=e[Symbol.iterator](),r=t.next();if(r.done)return t;if(n.CID.asCID(r.value)||r.value instanceof String||"string"==typeof r.value){yield a({cid:r.value});for(const e of t)yield a({cid:e});return}if(null!=r.value.cid||null!=r.value.path){yield a(r.value);for(const e of t)yield a(e);return}throw o.default(new Error("Unexpected input: "+typeof e),"ERR_UNEXPECTED_INPUT")}if(Symbol.asyncIterator in e){const t=e[Symbol.asyncIterator](),r=await t.next();if(r.done)return t;if(n.CID.asCID(r.value)||r.value instanceof String||"string"==typeof r.value){yield a({cid:r.value});for await(const e of t)yield a({cid:e});return}if(null!=r.value.cid||null!=r.value.path){yield a(r.value);for await(const e of t)yield a(e);return}throw o.default(new Error("Unexpected input: "+typeof e),"ERR_UNEXPECTED_INPUT")}throw o.default(new Error("Unexpected input: "+typeof e),"ERR_UNEXPECTED_INPUT")}yield a({path:e})}}},{"err-code":"chZjB","multiformats/cid":"9ooAY"}],uek22:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});r.PinTypes={direct:"direct",recursive:"recursive",indirect:"indirect",all:"all"}},{}],hVzUN:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/pins/normalise-input"),n=e("../../utils.js"),s=e("ipfs-core-utils/with-timeout-option"),o=e("err-code"),a=e("ipfs-repo/pin-types");function c(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var u=c(o);function l(e,t,r){const i={type:e,cid:t};return r&&(i.metadata=r),i}r.createLs=function({repo:e,codecs:t}){return s.withTimeoutOption((async function*(r={}){let s=a.PinTypes.all;if(r.type&&(s=r.type,!Object.keys(a.PinTypes).includes(s)))throw u.default(new Error("Invalid pin type"),"ERR_INVALID_PIN_TYPE");if(r.paths){let o=!1;for await(const{path:c}of i.normaliseInput(r.paths)){const{cid:r}=await n.resolvePath(e,t,c),{reason:i,pinned:d,parent:f,metadata:h}=await e.pins.isPinnedWithType(r,s);if(!d)throw u.default(new Error(`path '${c}' is not pinned`),"ERR_NOT_PINNED");switch(i){case a.PinTypes.direct:case a.PinTypes.recursive:o=!0,yield l(i,r,h);break;default:o=!0,yield l(`${a.PinTypes.indirect} through ${f}`,r,h)}}if(!o)throw new Error("No match found")}else{if(s===a.PinTypes.recursive||s===a.PinTypes.all)for await(const{cid:t,metadata:r}of e.pins.recursiveKeys())yield l(a.PinTypes.recursive,t,r);if(s===a.PinTypes.indirect||s===a.PinTypes.all)for await(const t of e.pins.indirectKeys(r))yield l(a.PinTypes.indirect,t);if(s===a.PinTypes.direct||s===a.PinTypes.all)for await(const{cid:t,metadata:r}of e.pins.directKeys())yield l(a.PinTypes.direct,t,r)}}))}},{"ipfs-core-utils/pins/normalise-input":"4NDJq","../../utils.js":"cT4uN","ipfs-core-utils/with-timeout-option":"j29MK","err-code":"chZjB","ipfs-repo/pin-types":"uek22"}],khHqn:[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("it-last"));r.createRm=function({rmAll:e}){return async function(t,r={}){const i=await n.default(e([{path:t,...r}],r));if(!i)throw new Error("CID expected");return i}}},{"it-last":"cSXX9"}],"5GWqa":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/pins/normalise-input"),n=e("../../utils.js"),s=e("ipfs-core-utils/with-timeout-option"),o=e("ipfs-repo/pin-types");r.createRmAll=function({repo:e,codecs:t}){return s.withTimeoutOption((async function*(r,s={}){const a=await e.gcLock.readLock();try{for await(const{path:s,recursive:a}of i.normaliseInput(r)){const{cid:r}=await n.resolvePath(e,t,s),{pinned:i,reason:c}=await e.pins.isPinnedWithType(r,o.PinTypes.all);if(!i)throw new Error(`${r} is not pinned`);switch(c){case o.PinTypes.recursive:if(!a)throw new Error(`${r} is pinned recursively`);await e.pins.unpin(r),yield r;break;case o.PinTypes.direct:await e.pins.unpin(r),yield r;break;default:throw new Error(`${r} is pinned indirectly under ${c}`)}}}finally{a()}}))}},{"ipfs-core-utils/pins/normalise-input":"4NDJq","../../utils.js":"cT4uN","ipfs-core-utils/with-timeout-option":"j29MK","ipfs-repo/pin-types":"uek22"}],fTgTV:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../ipns/index.js"),n=e("../ipns/routing/config.js"),s=e("../ipns/routing/offline-datastore.js"),o=e("../errors.js");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}const c=a(e("debug")).default("ipfs:components:ipns");r.IPNSAPI=class{constructor(e={pass:""}){this.options=e,this.offline=null,this.online=null}getIPNS(){const e=this.online||this.offline;if(e)return e;throw new o.NotInitializedError}get routing(){return this.getIPNS().routing}startOffline({repo:e,peerId:t,keychain:r}){if(null!=this.offline)throw new o.AlreadyInitializedError;c("initializing IPNS keyspace");const n=new s.OfflineDatastore(e),a=new i.IPNS(n,e.datastore,t,r,this.options);this.offline=a}async startOnline({libp2p:e,repo:t,peerId:r,keychain:s}){if(null!=this.online)throw new o.AlreadyInitializedError;const a=n.createRouting({libp2p:e,repo:t,peerId:r,options:this.options}),c=new i.IPNS(a,t.datastore,r,s,this.options);await c.republisher.start(),this.online=c}async stop(){const e=this.online;e&&(await e.republisher.stop(),this.online=null)}publish(e,t,r){return this.getIPNS().publish(e,t,r)}resolve(e,t){return this.getIPNS().resolve(e,t)}initializeKeyspace(e,t){return this.getIPNS().initializeKeyspace(e,t)}}},{"../ipns/index.js":"KNAGK","../ipns/routing/config.js":"bU4x4","../ipns/routing/offline-datastore.js":"a4pYc","../errors.js":"j69o8",debug:"bO5wM"}],KNAGK:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("peer-id"),n=e("err-code"),s=e("debug"),o=e("./publisher.js"),a=e("./republisher.js"),c=e("./resolver.js"),u=e("../utils/tlru.js"),l=e("uint8arrays/to-string");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var f=d(n),h=d(s);const p=Object.assign(h.default("ipfs:ipns"),{error:h.default("ipfs:ipns:error")});r.IPNS=class{constructor(e,t,r,i,n){this.publisher=new o.IpnsPublisher(e,t),this.republisher=new a.IpnsRepublisher(this.publisher,t,r,i,n),this.resolver=new c.IpnsResolver(e),this.cache=new u.TLRU(1e3),this.routing=e}async publish(e,t,r=o.IpnsPublisher.defaultRecordLifetime){try{const n=await i.createFromPrivKey(e.bytes);await this.publisher.publishWithEOL(e,t,r),p(`IPNS value ${l.toString(t,"base32")} was published correctly`);const s=n.toB58String(),o=parseFloat(r),a=o<6e4?o:6e4;return this.cache.set(s,t,a),p(`IPNS value ${l.toString(t,"base32")} was cached correctly`),{name:s,value:t}}catch(e){throw p.error(e),e}}async resolve(e,t={}){if("string"!=typeof e)throw f.default(new Error("name received is not valid"),"ERR_INVALID_NAME");if(!t.nocache&&!t.recursive){const t=e.split("/")[2],r=this.cache.get(t);if(r)return r}try{const r=await this.resolver.resolve(e,t);return p(`IPNS record from ${e} was resolved correctly`),r}catch(e){throw p.error(e),e}}async initializeKeyspace(e,t){return this.publish(e,t,o.IpnsPublisher.defaultRecordLifetime)}}},{"peer-id":"8Bdb3","err-code":"chZjB",debug:"bO5wM","./publisher.js":"5jkXx","./republisher.js":"hoedq","./resolver.js":"gifOE","../utils/tlru.js":"lQE1u","uint8arrays/to-string":"hC8JB"}],"5jkXx":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("peer-id"),n=e("interface-datastore/key"),s=e("datastore-core/errors"),o=e("err-code"),a=e("debug"),c=e("uint8arrays/to-string"),u=e("uint8arrays/equals"),l=e("ipns");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function f(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var h=d(i),p=d(o),g=d(a),y=f(l);const m=Object.assign(g.default("ipfs:ipns:publisher"),{error:g.default("ipfs:ipns:publisher:error")}),b=s.notFoundError().code,v=36e5;class w{constructor(e,t){this._routing=e,this._datastore=t}async publishWithEOL(e,t,r){if(!e||!e.bytes)throw p.default(new Error("invalid private key"),"ERR_INVALID_PRIVATE_KEY");const i=await h.default.createFromPrivKey(e.bytes),n=await this._updateOrCreateRecord(e,t,r,i);return this._putRecordToRouting(n,i)}publish(e,t){return this.publishWithEOL(e,t,v)}async _putRecordToRouting(e,t){if(!h.default.isPeerId(t)){const e="peerId received is not valid";throw m.error(e),p.default(new Error(e),"ERR_INVALID_PEER_ID")}const r=t._pubKey,i=await y.embedPublicKey(r,e),n=y.getIdKeys(t.toBytes());return await this._publishEntry(n.routingKey,i||e),await this._publishPublicKey(n.routingPubKey,r),i||e}async _publishEntry(e,t){const r=n.Key.asKey(e);if(!r){const e="datastore key does not have a valid format";throw m.error(e),p.default(new Error(e),"ERR_INVALID_DATASTORE_KEY")}let i;try{i=y.marshal(t)}catch(e){throw m.error(e),e}try{const e=await this._routing.put(r.uint8Array(),i);return m(`ipns record for ${c.toString(r.uint8Array(),"base64")} was stored in the routing`),e}catch(e){const t=`ipns record for ${c.toString(r.uint8Array(),"base64")} could not be stored in the routing`;throw m.error(t),m.error(e),p.default(new Error(t),"ERR_PUTTING_TO_ROUTING")}}async _publishPublicKey(e,t){const r=n.Key.asKey(e);if(!r){const e="datastore key does not have a valid format";throw m.error(e),p.default(new Error(e),"ERR_INVALID_DATASTORE_KEY")}if(!t||!t.bytes){const e="one or more of the provided parameters are not defined";throw m.error(e),p.default(new Error(e),"ERR_UNDEFINED_PARAMETER")}try{const e=await this._routing.put(r.uint8Array(),t.bytes);return m(`public key for ${c.toString(r.uint8Array(),"base64")} was stored in the routing`),e}catch(e){const t=`public key for ${c.toString(r.uint8Array(),"base64")} could not be stored in the routing`;throw m.error(t),m.error(e),p.default(new Error(t),"ERR_PUTTING_TO_ROUTING")}}async _getPublished(e,t={}){if(!h.default.isPeerId(e)){const e="peerId received is not valid";throw m.error(e),p.default(new Error(e),"ERR_INVALID_PEER_ID")}const r=!1!==t.checkRouting;try{const t=await this._datastore.get(y.getLocalKey(e.id));return this._unmarshalData(t)}catch(t){if(t.code!==b){const t=`unexpected error getting the ipns record ${e.id} from datastore`;throw m.error(t),p.default(new Error(t),"ERR_UNEXPECTED_DATASTORE_RESPONSE")}if(!r)throw p.default(t,"ERR_NOT_FOUND_AND_CHECK_ROUTING_NOT_ENABLED");try{const t=y.getIdKeys(e.toBytes()),r=await this._routing.get(t.routingKey.uint8Array());return this._unmarshalData(r)}catch(e){throw m.error(e),e}}}_unmarshalData(e){try{return y.unmarshal(e)}catch(e){throw p.default(e,"ERR_INVALID_RECORD_DATA")}}async _updateOrCreateRecord(e,t,r,i){if(!h.default.isPeerId(i)){const e="peerId received is not valid";throw m.error(e),p.default(new Error(e),"ERR_INVALID_PEER_ID")}const n={checkRouting:!0};let s;try{s=await this._getPublished(i,n)}catch(e){if(e.code!==b){const t=`unexpected error when determining the last published IPNS record for ${i.id} ${e.stack}`;throw m.error(t),p.default(new Error(t),"ERR_DETERMINING_PUBLISHED_RECORD")}}let o,a=0;s&&void 0!==s.sequence&&(a=u.equals(s.value,t)?BigInt(s.sequence):BigInt(s.sequence)+BigInt(1));try{o=await y.create(e,t,a,r)}catch(e){const r=`ipns record for ${t} could not be created`;throw m.error(e),p.default(new Error(r),"ERR_CREATING_IPNS_RECORD")}try{const e=y.marshal(o);return await this._datastore.put(y.getLocalKey(i.id),e),m(`ipns record for ${c.toString(t,"base32")} was stored in the datastore`),o}catch(e){const r=`ipns record for ${t} could not be stored in the datastore`;throw m.error(r),p.default(new Error(r),"ERR_STORING_IN_DATASTORE")}}}w.defaultRecordLifetime=v,r.IpnsPublisher=w},{"peer-id":"8Bdb3","interface-datastore/key":"9hGOz","datastore-core/errors":"65M4b","err-code":"chZjB",debug:"bO5wM","uint8arrays/to-string":"hC8JB","uint8arrays/equals":"eY3cX",ipns:"7rNAT"}],"65M4b":[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("err-code"));r.abortedError=function(e){return e=e||new Error("Aborted"),n.default(e,"ERR_ABORTED")},r.dbDeleteFailedError=function(e){return e=e||new Error("Delete failed"),n.default(e,"ERR_DB_DELETE_FAILED")},r.dbOpenFailedError=function(e){return e=e||new Error("Cannot open database"),n.default(e,"ERR_DB_OPEN_FAILED")},r.dbWriteFailedError=function(e){return e=e||new Error("Write failed"),n.default(e,"ERR_DB_WRITE_FAILED")},r.notFoundError=function(e){return e=e||new Error("Not Found"),n.default(e,"ERR_NOT_FOUND")}},{"err-code":"chZjB"}],"7rNAT":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("timestamp-nano"),n=e("interface-datastore/key"),s=e("libp2p-crypto"),o=e("peer-id"),a=e("multiformats/hashes/digest"),c=e("multiformats/hashes/identity"),u=e("err-code"),l=e("multiformats/bases/base32"),d=e("uint8arrays/from-string"),f=e("uint8arrays/to-string"),h=e("uint8arrays/concat"),p=e("uint8arrays/equals"),g=e("cborg"),y=e("long"),m=e("debug"),b=e("./pb/ipns.js"),v=e("./utils.js"),w=e("./errors.js");function _(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function E(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var S=_(i),T=_(s),A=_(o),k=E(a),I=_(u),R=E(g),P=_(y),O=_(m);const C=Object.assign(O.default("jsipns"),{error:O.default("jsipns:error")}),j=c.identity.code,D=d.fromString("/ipns/"),M="/ipns/",x=M.length,B=async(e,t,r,i,n,s)=>{r=BigInt(r);const o=d.fromString(n.toString()),a=await z(e,t,i,o),c=L(t,o,i,r,s),u=q(c),l={value:t,signature:a,validityType:i,validity:o,sequence:r,ttl:s,signatureV2:await e.sign(u),data:c};return C(`ipns entry for ${t} created`),l},L=(e,t,r,i,n)=>{const s={Value:e,Validity:t,ValidityType:r,Sequence:i,TTL:n};return R.encode(s)},N=async(e,t)=>{const{value:r,validityType:i,validity:n}=t;let s,o,a;t.signatureV2&&t.data?(o=t.signatureV2,s=q(t.data),U(t)):(o=t.signature,s=V(r,i,n));try{a=await e.verify(s,o)}catch(e){a=!1}if(!a)throw C.error("record signature verification failed"),I.default(new Error("record signature verification failed"),w.ERR_SIGNATURE_VERIFICATION);if(i===b.IpnsEntry.ValidityType.EOL){let e;try{e=v.parseRFC3339(f.toString(n))}catch(e){throw C.error("unrecognized validity format (not an rfc3339 format)"),I.default(new Error("unrecognized validity format (not an rfc3339 format)"),w.ERR_UNRECOGNIZED_FORMAT)}if(e.getTime(){if(!e.data)throw I.default(new Error("Record data is missing"),w.ERR_INVALID_RECORD_DATA);const t=R.decode(e.data);if(Number.isInteger(t.Sequence)&&(t.Sequence=BigInt(t.Sequence)),Number.isInteger(t.TTL)&&(t.TTL=BigInt(t.TTL)),!p.equals(t.Value,e.value))throw I.default(new Error('Field "value" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION);if(!p.equals(t.Validity,e.validity))throw I.default(new Error('Field "validity" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION);if(t.ValidityType!==e.validityType)throw I.default(new Error('Field "validityType" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION);if(t.Sequence!==e.sequence)throw I.default(new Error('Field "sequence" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION);if(t.TTL!==e.ttl)throw I.default(new Error('Field "ttl" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION)},F=async(e,t)=>{if(!t||!e){const e=new Error("one or more of the provided parameters are not defined");throw C.error(e),I.default(e,w.ERR_UNDEFINED_PARAMETER)}let r;if(t.pubKey){try{r=T.default.keys.unmarshalPublicKey(t.pubKey)}catch(e){throw C.error(e),e}if(!(await A.default.createFromPubKey(t.pubKey)).equals(e))throw I.default(new Error("Embedded public key did not match PeerID"),w.ERR_INVALID_EMBEDDED_KEY)}else e.pubKey&&(r=e.pubKey);if(r)return r;throw I.default(new Error("no public key is available"),w.ERR_UNDEFINED_PARAMETER)},K=e=>l.base32upper.encode(e).slice(1),z=(e,t,r,i)=>{try{const n=V(t,r,i);return e.sign(n)}catch(e){throw C.error("record signature creation failed"),I.default(new Error("record signature creation failed: "+e.message),w.ERR_SIGNATURE_CREATION)}},V=(e,t,r)=>{const i=d.fromString((e=>{if("0"===e.toString())return"EOL";const t=new Error(`unrecognized validity type ${e.toString()}`);throw C.error(t),I.default(t,w.ERR_UNRECOGNIZED_VALIDITY)})(t));return h.concat([e,r,i])},q=e=>{const t=d.fromString("ipns-signature:");return h.concat([t,e])},G=e=>{const t=k.decode(e.id);return t.code!==j?null:T.default.keys.unmarshalPublicKey(t.digest)},H=e=>{const t=b.IpnsEntry.decode(e),r=b.IpnsEntry.toObject(t,{defaults:!1,arrays:!0,objects:!1});return{value:r.value,signature:r.signature,validityType:r.validityType,validity:r.validity,sequence:Object.hasOwnProperty.call(r,"sequence")?BigInt(`${r.sequence}`):0,pubKey:r.pubKey,ttl:Object.hasOwnProperty.call(r,"ttl")?BigInt(`${r.ttl}`):void 0,signatureV2:r.signatureV2,data:r.data}},$={validate:async(e,t)=>{const r=H(e),i=t.slice(D.length),n=A.default.createFromBytes(i),s=await F(n,r);await N(s,r)},select:(e,t)=>{const r=H(e),i=H(t);if(r.signatureV2&&!i.signatureV2)return 0;if(i.signatureV2&&!r.signatureV2)return 1;if(r.sequence>i.sequence)return 0;if(r.sequencen.getTime()?1:0}};r.create=(e,t,r,i)=>{const n=new S.default(Date.now()+Number(i)),s=b.IpnsEntry.ValidityType.EOL,[o,a]=i.toString().split("."),c=BigInt(o)*BigInt(1e5)+BigInt(a||0);return B(e,t,r,s,n,c)},r.createWithExpiration=(e,t,r,i)=>{const n=S.default.fromString(i),s=b.IpnsEntry.ValidityType.EOL,o=n.toDate().getTime()-Date.now(),a=BigInt(o)*BigInt(1e5)+BigInt(n.getNano());return B(e,t,r,s,n,a)},r.embedPublicKey=async(e,t)=>{if(!e||!e.bytes||!t){const e=new Error("one or more of the provided parameters are not defined");throw C.error(e),I.default(e,w.ERR_UNDEFINED_PARAMETER)}let r,i;try{r=await A.default.createFromPubKey(e.bytes)}catch(e){throw I.default(e,w.ERR_PEER_ID_FROM_PUBLIC_KEY)}try{i=G(r)}catch(e){throw C.error(e),I.default(e,w.ERR_PUBLIC_KEY_FROM_ID)}if(i)return null;try{t.pubKey=T.default.keys.marshalPublicKey(e)}catch(e){throw C.error(e),e}return t},r.extractPublicKey=F,r.getIdKeys=e=>{const t=d.fromString("/pk/"),r=d.fromString("/ipns/");return{routingPubKey:new n.Key(h.concat([t,e]),!1),pkKey:new n.Key(K(h.concat([t,e]))),routingKey:new n.Key(h.concat([r,e]),!1),ipnsKey:new n.Key(K(h.concat([r,e])))}},r.getLocalKey=e=>new n.Key(`/ipns/${K(e)}`),r.marshal=e=>b.IpnsEntry.encode({...e,sequence:P.default.fromString(e.sequence.toString()),ttl:null==e.ttl?void 0:P.default.fromString(e.ttl.toString())}).finish(),r.namespace=M,r.namespaceLength=x,r.unmarshal=H,r.validate=N,r.validator=$},{"timestamp-nano":"7gA2O","interface-datastore/key":"9hGOz","libp2p-crypto":"bb1cb","peer-id":"8Bdb3","multiformats/hashes/digest":"kpRBg","multiformats/hashes/identity":"eYCZn","err-code":"chZjB","multiformats/bases/base32":"5k9Tu","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB","uint8arrays/concat":"4EBjG","uint8arrays/equals":"eY3cX",cborg:"iZrkE",long:"lyrB6",debug:"bO5wM","./pb/ipns.js":"ayx1q","./utils.js":"kYcWW","./errors.js":"jtlhd"}],"7gA2O":[function(e,t,r){ +!function(e,t,r,i,n){var s="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"!=typeof window?window:"undefined"!=typeof global?global:{},o="function"==typeof s.parcelRequire6d65&&s.parcelRequire6d65,a=o.cache||{},c="undefined"!=typeof module&&"function"==typeof module.require&&module.require.bind(module);function u(t,r){if(!a[t]){if(!e[t]){var i="function"==typeof s.parcelRequire6d65&&s.parcelRequire6d65;if(!r&&i)return i(t,!0);if(o)return o(t,!0);if(c&&"string"==typeof t)return c(t);var n=new Error("Cannot find module '"+t+"'");throw n.code="MODULE_NOT_FOUND",n}d.resolve=function(r){return e[t][1][r]||r},d.cache={};var l=a[t]=new u.Module(t);e[t][0].call(l.exports,d,l,l.exports,this)}return a[t].exports;function d(e){return u(d.resolve(e))}}u.isParcelRequire=!0,u.Module=function(e){this.id=e,this.bundle=u,this.exports={}},u.modules=e,u.cache=a,u.parent=o,u.register=function(t,r){e[t]=[function(e,t){t.exports=r},{}]},Object.defineProperty(u,"root",{get:function(){return s.parcelRequire6d65}}),s.parcelRequire6d65=u;for(var l=0;l{const e=u("hash"),t=u("source"),r=u("title"),i=u("time");if(function(){const i=document.getElementById("video"),n=document.getElementById("contextBackground"),s=document.getElementById("contextMenu");i.oncontextmenu=e=>{n.classList.toggle("is-hidden"),s.style.left=e.pageX+"px",s.style.top=e.pageY+"px",e.preventDefault()},n.onclick=e=>{e.stopPropagation(),n.classList.toggle("is-hidden")};const o=`http://ipfsvideo.cc?hash=${e}${r&&"&title="+encodeURIComponent(r)||""}${t&&"&source="+encodeURIComponent(t)||""}`;document.getElementById("contextMenu-url").onclick=e=>{navigator.clipboard.writeText(o)},document.getElementById("contextMenu-urlWithTime").onclick=e=>{navigator.clipboard.writeText(`${o}&time=${Math.round(i.currentTime)}`)}}(),r&&(document.title=r),e){document.getElementById("help").style.display="none",d(),window.addEventListener("resize",d);const r=document.getElementById("video");r.style.display="block";const s="ipfs-"+Math.random();l("Connecting to IPFS");const a=await n.create({repo:s});if(l("Connected"),o.default.DefaultConfig.loader=c.default,o.default.DefaultConfig.debug=!1,o.default.isSupported()){const n=new o.default;n.config.ipfs=a,n.config.ipfsHash=e,l("Video loading"),n.loadSource(t||"master.m3u8"),n.attachMedia(r),n.on(o.default.Events.MANIFEST_PARSED,(()=>{l("Video loaded",!0),i&&(r.currentTime=i),r.play()}))}}}))},{"ipfs-core":"iJfvU","hls.js":"juo1D","hlsjs-ipfs-loader":"1xTo6","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],iJfvU:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./components/index.js"),n=e("libp2p-crypto"),s=e("is-ipfs"),o=e("multiformats/cid"),a=e("multiaddr"),c=e("peer-id"),u=e("ipfs-utils/src/files/glob-source.js"),l=e("ipfs-utils/src/files/url-source.js");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var f=d(n),h=d(s),p=d(c),g=d(u),y=d(l);const m=i.create,b=f.default,v=h.default,w=o.CID,_=a.Multiaddr,E=p.default,S=g.default,T=y.default;r.CID=w,r.PeerId=E,r.create=m,r.crypto=b,r.globSource=S,r.isIPFS=v,r.multiaddr=_,r.urlSource=T},{"./components/index.js":"RQOpu","libp2p-crypto":"bb1cb","is-ipfs":"40iuV","multiformats/cid":"9ooAY",multiaddr:"8Mu1u","peer-id":"8Bdb3","ipfs-utils/src/files/glob-source.js":"lHksA","ipfs-utils/src/files/url-source.js":"jQSIS"}],RQOpu:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("merge-options"),n=e("ipfs-utils/src/env.js"),s=e("debug"),o=e("err-code"),a=e("ipfs-unixfs"),c=e("@ipld/dag-pb"),u=e("@ipld/dag-cbor"),l=e("multiformats/hashes/identity"),d=e("multiformats/basics"),f=e("ipfs-core-config/init-assets"),h=e("../errors.js"),p=e("uint8arrays/from-string"),g=e("./start.js"),y=e("./stop.js"),m=e("./dns.js"),b=e("./is-online.js"),v=e("./resolve.js"),w=e("./pin/index.js"),_=e("./ipns.js"),E=e("./name/index.js"),S=e("./refs/index.js"),T=e("./refs/local.js"),A=e("./bitswap/index.js"),k=e("./bootstrap/index.js"),I=e("./block/index.js"),R=e("./root.js"),P=e("./version.js"),O=e("./id.js"),C=e("./config/index.js"),j=e("./dag/index.js"),D=e("../preload.js"),M=e("../mfs-preload.js"),x=e("./files/index.js"),B=e("./key/index.js"),L=e("./object/index.js"),N=e("./repo/index.js"),U=e("./stats/index.js"),F=e("./storage.js"),K=e("./network.js"),z=e("../utils/service.js"),V=e("./swarm/index.js"),q=e("./ping.js"),G=e("./dht.js"),H=e("./pubsub.js"),$=e("ipfs-core-utils/multicodecs"),W=e("ipfs-core-utils/multihashes"),Y=e("ipfs-core-utils/multibases");function X(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function Z(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var Q=X(i),J=X(s),ee=X(o),te=Z(c),re=Z(u);const ie=Q.default.bind({ignoreUndefined:!0}),ne=J.default("ipfs");class se{constructor({print:e,storage:t,codecs:r,options:i}){const{peerId:n,repo:s,keychain:o}=t,a=z.Service.create(K.Network),c=D.createPreloader(i.preload),u=m.createDns(),l=b.createIsOnline({network:a}),f=new _.IPNSAPI(i),h=Object.values(d.hashes);(i.ipld&&i.ipld.hashers?i.ipld.hashers:[]).forEach((e=>h.push(e))),this.hashers=new W.Multihashes({hashers:h,loadHasher:i.ipld&&i.ipld.loadHasher});const p=Object.values(d.bases);(i.ipld&&i.ipld.bases?i.ipld.bases:[]).forEach((e=>p.push(e))),this.bases=new Y.Multibases({bases:p,loadBase:i.ipld&&i.ipld.loadBase});const F=new w.PinAPI({repo:s,codecs:r}),$=new I.BlockAPI({codecs:r,hashers:this.hashers,preload:c,repo:s}),X=new E.NameAPI({dns:u,ipns:f,repo:s,codecs:r,peerId:n,isOnline:l,keychain:o,options:i}),Z=v.createResolve({repo:s,codecs:r,bases:this.bases,name:X}),Q=new j.DagAPI({repo:s,codecs:r,hashers:this.hashers,preload:c}),J=Object.assign(S.createRefs({repo:s,codecs:r,resolve:Z,preload:c}),{local:T.createLocal({repo:t.repo})}),{add:te,addAll:re,cat:ie,get:ne,ls:se}=new R.RootAPI({preload:c,repo:s,options:i.EXPERIMENTAL}),oe=x.createFiles({repo:s,preload:c,hashers:this.hashers,options:i}),ae=M.createMfsPreloader({files:oe,preload:c,options:i.preload});this.preload=c,this.name=X,this.ipns=f,this.pin=F,this.resolve=Z,this.block=$,this.refs=J,this.start=g.createStart({network:a,peerId:n,repo:s,preload:c,ipns:f,mfsPreload:ae,print:e,keychain:o,options:i}),this.stop=y.createStop({network:a,preload:c,mfsPreload:ae,ipns:f,repo:s}),this.dht=G.createDht({network:a,repo:s}),this.pubsub=H.createPubsub({network:a,config:i.config}),this.dns=u,this.isOnline=l,this.id=O.createId({network:a,peerId:n}),this.version=P.createVersion({repo:s}),this.bitswap=new A.BitswapAPI({network:a}),this.bootstrap=new k.BootstrapAPI({repo:s}),this.config=C.createConfig({repo:s}),this.ping=q.createPing({network:a}),this.add=te,this.addAll=re,this.cat=ie,this.get=ne,this.ls=se,this.dag=Q,this.files=oe,this.key=new B.KeyAPI({keychain:o}),this.object=new L.ObjectAPI({preload:c,codecs:r,repo:s}),this.repo=new N.RepoAPI({repo:s,hashers:this.hashers}),this.stats=new U.StatsAPI({repo:s,network:a}),this.swarm=new V.SwarmAPI({network:a}),Object.defineProperty(this,"libp2p",{get(){const e=a.try();return e?e.libp2p:void 0}});const ce=()=>Promise.reject(ee.default(new Error("Not implemented"),"ERR_NOT_IMPLEMENTED"));this.commands=ce,this.diag={cmds:ce,net:ce,sys:ce},this.log={level:ce,ls:ce,tail:async function*(){throw ee.default(new Error("Not implemented"),"ERR_NOT_IMPLEMENTED")}},this.mount=ce,this.codecs=r}async init(){throw new h.AlreadyInitializedError}}r.create=async function(e={}){const t=(e=ie({start:!0,EXPERIMENTAL:{},preload:{enabled:!n.isTest,addresses:["/dns4/node0.preload.ipfs.io/https","/dns4/node1.preload.ipfs.io/https","/dns4/node2.preload.ipfs.io/https","/dns4/node3.preload.ipfs.io/https"]}},e)).init||{},r={name:l.identity.name,code:l.identity.code,encode:e=>e,decode:e=>e},i=Object.values(d.codecs);[te,re,r].concat(e.ipld&&e.ipld.codecs||[]).forEach((e=>i.push(e)));const s=new $.Multicodecs({codecs:i,loadCodec:e.ipld&&e.ipld.loadCodec}),o=e.silent?ne:console.log,c=await F.Storage.start(o,s,e),u=await c.repo.config.getAll(),h=new se({storage:c,print:o,codecs:s,options:{...e,config:u}});if(await h.preload.start(),h.ipns.startOffline(c),c.isNew&&!t.emptyRepo){const e=await(async e=>{const t=te.encode({Data:new a.UnixFS({type:"directory"}).marshal(),Links:[]}),r=await e.block.put(t,{mhtype:"sha2-256",format:"dag-pb"});return await e.pin.add(r),r})(h);ne("adding default assets"),await f.initAssets({addAll:h.addAll,print:o}),ne("initializing IPNS keyspace"),await h.ipns.initializeKeyspace(c.peerId.privKey,p.fromString(`/ipfs/${e}`))}return!1!==e.start&&await h.start(),h}},{"merge-options":"fupyv","ipfs-utils/src/env.js":"flyHr",debug:"bO5wM","err-code":"chZjB","ipfs-unixfs":"dF9VO","@ipld/dag-pb":"i2cdx","@ipld/dag-cbor":"3498i","multiformats/hashes/identity":"eYCZn","multiformats/basics":"lPcQG","ipfs-core-config/init-assets":"d1lP3","../errors.js":"j69o8","uint8arrays/from-string":"dF7Y4","./start.js":"93XEg","./stop.js":"kkxN3","./dns.js":"4N8JT","./is-online.js":"2KSm7","./resolve.js":"faFUb","./pin/index.js":"hDUM1","./ipns.js":"fTgTV","./name/index.js":"u6g6o","./refs/index.js":"9Y9Id","./refs/local.js":"lEaxs","./bitswap/index.js":"lGDjO","./bootstrap/index.js":"dh9oy","./block/index.js":"jcbA3","./root.js":"3wOOx","./version.js":"8mBfq","./id.js":"bQa6q","./config/index.js":"3uMSz","./dag/index.js":"9rLzF","../preload.js":"kBOEV","../mfs-preload.js":"7arhH","./files/index.js":"1yxa2","./key/index.js":"aJXOU","./object/index.js":"kwMxL","./repo/index.js":"1qDVo","./stats/index.js":"1NkyG","./storage.js":"bI63q","./network.js":"1MCQb","../utils/service.js":"ethcf","./swarm/index.js":"cGDFf","./ping.js":"dHQEh","./dht.js":"kOgiu","./pubsub.js":"7IJgU","ipfs-core-utils/multicodecs":"4I7TQ","ipfs-core-utils/multihashes":"febSG","ipfs-core-utils/multibases":"lr7wI"}],fupyv:[function(e,t,r){"use strict";const i=e("is-plain-obj"),{hasOwnProperty:n}=Object.prototype,{propertyIsEnumerable:s}=Object,o=(e,t,r)=>Object.defineProperty(e,t,{value:r,writable:!0,enumerable:!0,configurable:!0}),a=this,c={concatArrays:!1,ignoreUndefined:!1},u=e=>{const t=[];for(const r in e)n.call(e,r)&&t.push(r);if(Object.getOwnPropertySymbols){const r=Object.getOwnPropertySymbols(e);for(const i of r)s.call(e,i)&&t.push(i)}return t};function l(e){return Array.isArray(e)?function(e){const t=e.slice(0,0);return u(e).forEach((r=>{o(t,r,l(e[r]))})),t}(e):i(e)?function(e){const t=null===Object.getPrototypeOf(e)?Object.create(null):{};return u(e).forEach((r=>{o(t,r,l(e[r]))})),t}(e):e}const d=(e,t,r,i)=>(r.forEach((r=>{void 0===t[r]&&i.ignoreUndefined||(r in e&&e[r]!==Object.getPrototypeOf(e)?o(e,r,f(e[r],t[r],i)):o(e,r,l(t[r])))})),e);function f(e,t,r){return r.concatArrays&&Array.isArray(e)&&Array.isArray(t)?((e,t,r)=>{let i=e.slice(0,0),s=0;return[e,t].forEach((t=>{const a=[];for(let r=0;r!a.includes(e))),r)})),i})(e,t,r):i(t)&&i(e)?d(e,t,u(t),r):l(t)}t.exports=function(...e){const t=f(l(c),this!==a&&this||{},c);let r={_:{}};for(const n of e)if(void 0!==n){if(!i(n))throw new TypeError("`"+n+"` is not an Option Object");r=f(r,{_:n},t)}return r._}},{"is-plain-obj":"jGt65"}],jGt65:[function(e,t,r){"use strict";t.exports=e=>{if("[object Object]"!==Object.prototype.toString.call(e))return!1;const t=Object.getPrototypeOf(e);return null===t||t===Object.prototype}},{}],flyHr:[function(e,t,r){var i=e("process");const n=e("is-electron"),s="object"==typeof window&&"object"==typeof document&&9===document.nodeType,o=n(),a=s&&!o,c=o&&!s,u=o&&s,l="function"==typeof e&&void 0!==i&&void 0!==i.release&&"node"===i.release.name&&!o,d="function"==typeof importScripts&&"undefined"!=typeof self&&"undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope,f=void 0!==i&&void 0!==i.env&&!1,h="undefined"!=typeof navigator&&"ReactNative"===navigator.product;t.exports={isTest:f,isElectron:o,isElectronMain:c,isElectronRenderer:u,isNode:l,isBrowser:a,isWebWorker:d,isEnvWithDom:s,isReactNative:h}},{process:"bjUAi","is-electron":"e6ybt"}],bjUAi:[function(e,t,r){var i,n,s=t.exports={};function o(){throw new Error("setTimeout has not been defined")}function a(){throw new Error("clearTimeout has not been defined")}function c(e){if(i===setTimeout)return setTimeout(e,0);if((i===o||!i)&&setTimeout)return i=setTimeout,setTimeout(e,0);try{return i(e,0)}catch(t){try{return i.call(null,e,0)}catch(t){return i.call(this,e,0)}}}!function(){try{i="function"==typeof setTimeout?setTimeout:o}catch(e){i=o}try{n="function"==typeof clearTimeout?clearTimeout:a}catch(e){n=a}}();var u,l=[],d=!1,f=-1;function h(){d&&u&&(d=!1,u.length?l=u.concat(l):f=-1,l.length&&p())}function p(){if(!d){var e=c(h);d=!0;for(var t=l.length;t;){for(u=l,l=[];++f1)for(var r=1;r=0)}},{process:"bjUAi"}],bO5wM:[function(e,t,r){var i=e("process");r.formatArgs=function(e){if(e[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+e[0]+(this.useColors?"%c ":" ")+"+"+t.exports.humanize(this.diff),!this.useColors)return;const r="color: "+this.color;e.splice(1,0,r,"color: inherit");let i=0,n=0;e[0].replace(/%[a-zA-Z%]/g,(e=>{"%%"!==e&&(i++,"%c"===e&&(n=i))})),e.splice(n,0,r)},r.save=function(e){try{e?r.storage.setItem("debug",e):r.storage.removeItem("debug")}catch(e){}},r.load=function(){let e;try{e=r.storage.getItem("debug")}catch(e){}!e&&void 0!==i&&"env"in i&&(e=void 0);return e},r.useColors=function(){return!("undefined"==typeof window||!window.process||"renderer"!==window.process.type&&!window.process.__nwjs)||("undefined"==typeof navigator||!navigator.userAgent||!navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))&&("undefined"!=typeof document&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||"undefined"!=typeof window&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/))},r.storage=function(){try{return localStorage}catch(e){}}(),r.destroy=(()=>{let e=!1;return()=>{e||(e=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),r.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"],r.log=console.debug||console.log||(()=>{}),t.exports=e("./common")(r);const{formatters:n}=t.exports;n.j=function(e){try{return JSON.stringify(e)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}},{process:"bjUAi","./common":"5mxUS"}],"5mxUS":[function(e,t,r){t.exports=function(t){function r(e){let t,n,s,o=null;function a(...e){if(!a.enabled)return;const i=a,n=Number(new Date),s=n-(t||n);i.diff=s,i.prev=t,i.curr=n,t=n,e[0]=r.coerce(e[0]),"string"!=typeof e[0]&&e.unshift("%O");let o=0;e[0]=e[0].replace(/%([a-zA-Z%])/g,((t,n)=>{if("%%"===t)return"%";o++;const s=r.formatters[n];if("function"==typeof s){const r=e[o];t=s.call(i,r),e.splice(o,1),o--}return t})),r.formatArgs.call(i,e);(i.log||r.log).apply(i,e)}return a.namespace=e,a.useColors=r.useColors(),a.color=r.selectColor(e),a.extend=i,a.destroy=r.destroy,Object.defineProperty(a,"enabled",{enumerable:!0,configurable:!1,get:()=>null!==o?o:(n!==r.namespaces&&(n=r.namespaces,s=r.enabled(e)),s),set:e=>{o=e}}),"function"==typeof r.init&&r.init(a),a}function i(e,t){const i=r(this.namespace+(void 0===t?":":t)+e);return i.log=this.log,i}function n(e){return e.toString().substring(2,e.toString().length-2).replace(/\.\*\?$/,"*")}return r.debug=r,r.default=r,r.coerce=function(e){return e instanceof Error?e.stack||e.message:e},r.disable=function(){const e=[...r.names.map(n),...r.skips.map(n).map((e=>"-"+e))].join(",");return r.enable(""),e},r.enable=function(e){let t;r.save(e),r.namespaces=e,r.names=[],r.skips=[];const i=("string"==typeof e?e:"").split(/[\s,]+/),n=i.length;for(t=0;t{r[e]=t[e]})),r.names=[],r.skips=[],r.formatters={},r.selectColor=function(e){let t=0;for(let r=0;r=1.5*r;return Math.round(e/r)+" "+i+(n?"s":"")}t.exports=function(e,t){t=t||{};var r,l,d=typeof e;if("string"===d&&e.length>0)return function(e){if((e=String(e)).length>100)return;var t=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(e);if(!t)return;var r=parseFloat(t[1]);switch((t[2]||"ms").toLowerCase()){case"years":case"year":case"yrs":case"yr":case"y":return r*c;case"weeks":case"week":case"w":return r*a;case"days":case"day":case"d":return r*o;case"hours":case"hour":case"hrs":case"hr":case"h":return r*s;case"minutes":case"minute":case"mins":case"min":case"m":return r*n;case"seconds":case"second":case"secs":case"sec":case"s":return r*i;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return r;default:return}}(e);if("number"===d&&isFinite(e))return t.long?(r=e,(l=Math.abs(r))>=o?u(r,l,o,"day"):l>=s?u(r,l,s,"hour"):l>=n?u(r,l,n,"minute"):l>=i?u(r,l,i,"second"):r+" ms"):function(e){var t=Math.abs(e);return t>=o?Math.round(e/o)+"d":t>=s?Math.round(e/s)+"h":t>=n?Math.round(e/n)+"m":t>=i?Math.round(e/i)+"s":e+"ms"}(e);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(e))}},{}],chZjB:[function(e,t,r){"use strict";function i(e,t){for(const r in t)Object.defineProperty(e,r,{value:t[r],enumerable:!0,configurable:!0});return e}t.exports=function(e,t,r){if(!e||"string"==typeof e)throw new TypeError("Please pass an Error to err-code");r||(r={}),"object"==typeof t&&(r=t,t=""),t&&(r.code=t);try{return i(e,r)}catch(t){r.message=e.message,r.stack=e.stack;const n=function(){};n.prototype=Object.create(Object.getPrototypeOf(e));return i(new n,r)}}},{}],dF9VO:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("err-code"),n=e("./unixfs.js");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=s(i);const a=n.Data,c=["raw","directory","file","metadata","symlink","hamt-sharded-directory"],u=["directory","hamt-sharded-directory"],l=parseInt("0644",8),d=parseInt("0755",8);function f(e){if(null!=e)return"number"==typeof e?4095&e:"0"===(e=e.toString()).substring(0,1)?4095&parseInt(e,8):4095&parseInt(e,10)}function h(e){if(null==e)return;let t;if(null!=e.secs&&(t={secs:e.secs,nsecs:e.nsecs}),null!=e.Seconds&&(t={secs:e.Seconds,nsecs:e.FractionalNanoseconds}),Array.isArray(e)&&(t={secs:e[0],nsecs:e[1]}),e instanceof Date){const r=e.getTime(),i=Math.floor(r/1e3);t={secs:i,nsecs:1e3*(r-1e3*i)}}if(Object.prototype.hasOwnProperty.call(t,"secs")){if(null!=t&&null!=t.nsecs&&(t.nsecs<0||t.nsecs>999999999))throw o.default(new Error("mtime-nsecs must be within the range [0,999999999]"),"ERR_INVALID_MTIME_NSECS");return t}}class p{static unmarshal(e){const t=a.decode(e),r=a.toObject(t,{defaults:!1,arrays:!0,longs:Number,objects:!1}),i=new p({type:c[r.Type],data:r.Data,blockSizes:r.blocksizes,mode:r.mode,mtime:r.mtime?{secs:r.mtime.Seconds,nsecs:r.mtime.FractionalNanoseconds}:void 0});return i._originalMode=r.mode||0,i}constructor(e={type:"file"}){const{type:t,data:r,blockSizes:i,hashType:n,fanout:s,mtime:a,mode:u}=e;if(t&&!c.includes(t))throw o.default(new Error("Type: "+t+" is not valid"),"ERR_INVALID_TYPE");this.type=t||"file",this.data=r,this.hashType=n,this.fanout=s,this.blockSizes=i||[],this._originalMode=0,this.mode=f(u),a&&(this.mtime=h(a),this.mtime&&!this.mtime.nsecs&&(this.mtime.nsecs=0))}set mode(e){this._mode=this.isDirectory()?d:l;const t=f(e);void 0!==t&&(this._mode=t)}get mode(){return this._mode}isDirectory(){return Boolean(this.type&&u.includes(this.type))}addBlockSize(e){this.blockSizes.push(e)}removeBlockSize(e){this.blockSizes.splice(e,1)}fileSize(){if(this.isDirectory())return 0;let e=0;return this.blockSizes.forEach((t=>{e+=t})),this.data&&(e+=this.data.length),e}marshal(){let e;switch(this.type){case"raw":e=a.DataType.Raw;break;case"directory":e=a.DataType.Directory;break;case"file":e=a.DataType.File;break;case"metadata":e=a.DataType.Metadata;break;case"symlink":e=a.DataType.Symlink;break;case"hamt-sharded-directory":e=a.DataType.HAMTShard;break;default:throw o.default(new Error("Type: "+e+" is not valid"),"ERR_INVALID_TYPE")}let t,r,i=this.data;if(this.data&&this.data.length||(i=void 0),null!=this.mode&&(t=4294963200&this._originalMode|(f(this.mode)||0),t!==l||this.isDirectory()||(t=void 0),t===d&&this.isDirectory()&&(t=void 0)),null!=this.mtime){const e=h(this.mtime);e&&(r={Seconds:e.secs,FractionalNanoseconds:e.nsecs},0===r.FractionalNanoseconds&&delete r.FractionalNanoseconds)}const n={Type:e,Data:i,filesize:this.isDirectory()?void 0:this.fileSize(),blocksizes:this.blockSizes,hashType:this.hashType,fanout:this.fanout,mode:t,mtime:r};return a.encode(n).finish()}}r.UnixFS=p,r.parseMode=f,r.parseMtime=h},{"err-code":"chZjB","./unixfs.js":"l2F50"}],l2F50:[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("protobufjs/minimal.js"));const s=n.default.Reader,o=n.default.Writer,a=n.default.util,c=n.default.roots["ipfs-unixfs"]||(n.default.roots["ipfs-unixfs"]={}),u=c.Data=(()=>{function e(e){if(this.blocksizes=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.Type=e.int32();break;case 2:i.Data=e.bytes();break;case 3:i.filesize=e.uint64();break;case 4:if(i.blocksizes&&i.blocksizes.length||(i.blocksizes=[]),2==(7&n))for(var o=e.uint32()+e.pos;e.pos>>0,e.filesize.high>>>0).toNumber(!0))),e.blocksizes){if(!Array.isArray(e.blocksizes))throw TypeError(".Data.blocksizes: array expected");t.blocksizes=[];for(var r=0;r>>0,e.blocksizes[r].high>>>0).toNumber(!0))}if(null!=e.hashType&&(a.Long?(t.hashType=a.Long.fromValue(e.hashType)).unsigned=!0:"string"==typeof e.hashType?t.hashType=parseInt(e.hashType,10):"number"==typeof e.hashType?t.hashType=e.hashType:"object"==typeof e.hashType&&(t.hashType=new a.LongBits(e.hashType.low>>>0,e.hashType.high>>>0).toNumber(!0))),null!=e.fanout&&(a.Long?(t.fanout=a.Long.fromValue(e.fanout)).unsigned=!0:"string"==typeof e.fanout?t.fanout=parseInt(e.fanout,10):"number"==typeof e.fanout?t.fanout=e.fanout:"object"==typeof e.fanout&&(t.fanout=new a.LongBits(e.fanout.low>>>0,e.fanout.high>>>0).toNumber(!0))),null!=e.mode&&(t.mode=e.mode>>>0),null!=e.mtime){if("object"!=typeof e.mtime)throw TypeError(".Data.mtime: object expected");t.mtime=c.UnixTime.fromObject(e.mtime)}return t},e.toObject=function(e,t){t||(t={});var r={};if((t.arrays||t.defaults)&&(r.blocksizes=[]),t.defaults){if(r.Type=t.enums===String?"Raw":0,t.bytes===String?r.Data="":(r.Data=[],t.bytes!==Array&&(r.Data=a.newBuffer(r.Data))),a.Long){var i=new a.Long(0,0,!0);r.filesize=t.longs===String?i.toString():t.longs===Number?i.toNumber():i}else r.filesize=t.longs===String?"0":0;if(a.Long){i=new a.Long(0,0,!0);r.hashType=t.longs===String?i.toString():t.longs===Number?i.toNumber():i}else r.hashType=t.longs===String?"0":0;if(a.Long){i=new a.Long(0,0,!0);r.fanout=t.longs===String?i.toString():t.longs===Number?i.toNumber():i}else r.fanout=t.longs===String?"0":0;r.mode=0,r.mtime=null}if(null!=e.Type&&e.hasOwnProperty("Type")&&(r.Type=t.enums===String?c.Data.DataType[e.Type]:e.Type),null!=e.Data&&e.hasOwnProperty("Data")&&(r.Data=t.bytes===String?a.base64.encode(e.Data,0,e.Data.length):t.bytes===Array?Array.prototype.slice.call(e.Data):e.Data),null!=e.filesize&&e.hasOwnProperty("filesize")&&("number"==typeof e.filesize?r.filesize=t.longs===String?String(e.filesize):e.filesize:r.filesize=t.longs===String?a.Long.prototype.toString.call(e.filesize):t.longs===Number?new a.LongBits(e.filesize.low>>>0,e.filesize.high>>>0).toNumber(!0):e.filesize),e.blocksizes&&e.blocksizes.length){r.blocksizes=[];for(var n=0;n>>0,e.blocksizes[n].high>>>0).toNumber(!0):e.blocksizes[n]}return null!=e.hashType&&e.hasOwnProperty("hashType")&&("number"==typeof e.hashType?r.hashType=t.longs===String?String(e.hashType):e.hashType:r.hashType=t.longs===String?a.Long.prototype.toString.call(e.hashType):t.longs===Number?new a.LongBits(e.hashType.low>>>0,e.hashType.high>>>0).toNumber(!0):e.hashType),null!=e.fanout&&e.hasOwnProperty("fanout")&&("number"==typeof e.fanout?r.fanout=t.longs===String?String(e.fanout):e.fanout:r.fanout=t.longs===String?a.Long.prototype.toString.call(e.fanout):t.longs===Number?new a.LongBits(e.fanout.low>>>0,e.fanout.high>>>0).toNumber(!0):e.fanout),null!=e.mode&&e.hasOwnProperty("mode")&&(r.mode=e.mode),null!=e.mtime&&e.hasOwnProperty("mtime")&&(r.mtime=c.UnixTime.toObject(e.mtime,t)),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,n.default.util.toJSONOptions)},e.DataType=function(){const e={},t=Object.create(e);return t[e[0]="Raw"]=0,t[e[1]="Directory"]=1,t[e[2]="File"]=2,t[e[3]="Metadata"]=3,t[e[4]="Symlink"]=4,t[e[5]="HAMTShard"]=5,t}(),e})(),l=c.UnixTime=(()=>{function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.Seconds=e.int64();break;case 2:i.FractionalNanoseconds=e.fixed32();break;default:e.skipType(7&n)}}if(!i.hasOwnProperty("Seconds"))throw a.ProtocolError("missing required 'Seconds'",{instance:i});return i},e.fromObject=function(e){if(e instanceof c.UnixTime)return e;var t=new c.UnixTime;return null!=e.Seconds&&(a.Long?(t.Seconds=a.Long.fromValue(e.Seconds)).unsigned=!1:"string"==typeof e.Seconds?t.Seconds=parseInt(e.Seconds,10):"number"==typeof e.Seconds?t.Seconds=e.Seconds:"object"==typeof e.Seconds&&(t.Seconds=new a.LongBits(e.Seconds.low>>>0,e.Seconds.high>>>0).toNumber())),null!=e.FractionalNanoseconds&&(t.FractionalNanoseconds=e.FractionalNanoseconds>>>0),t},e.toObject=function(e,t){t||(t={});var r={};if(t.defaults){if(a.Long){var i=new a.Long(0,0,!1);r.Seconds=t.longs===String?i.toString():t.longs===Number?i.toNumber():i}else r.Seconds=t.longs===String?"0":0;r.FractionalNanoseconds=0}return null!=e.Seconds&&e.hasOwnProperty("Seconds")&&("number"==typeof e.Seconds?r.Seconds=t.longs===String?String(e.Seconds):e.Seconds:r.Seconds=t.longs===String?a.Long.prototype.toString.call(e.Seconds):t.longs===Number?new a.LongBits(e.Seconds.low>>>0,e.Seconds.high>>>0).toNumber():e.Seconds),null!=e.FractionalNanoseconds&&e.hasOwnProperty("FractionalNanoseconds")&&(r.FractionalNanoseconds=e.FractionalNanoseconds),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,n.default.util.toJSONOptions)},e})(),d=c.Metadata=(()=>{function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3==1)i.MimeType=e.string();else e.skipType(7&n)}return i},e.fromObject=function(e){if(e instanceof c.Metadata)return e;var t=new c.Metadata;return null!=e.MimeType&&(t.MimeType=String(e.MimeType)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(r.MimeType=""),null!=e.MimeType&&e.hasOwnProperty("MimeType")&&(r.MimeType=e.MimeType),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,n.default.util.toJSONOptions)},e})();r.Data=u,r.Metadata=d,r.UnixTime=l,r.default=c},{"protobufjs/minimal.js":"grAXL"}],grAXL:[function(e,t,r){"use strict";t.exports=e("./src/index-minimal")},{"./src/index-minimal":"3OMTL"}],"3OMTL":[function(e,t,r){"use strict";var i=r;function n(){i.util._configure(),i.Writer._configure(i.BufferWriter),i.Reader._configure(i.BufferReader)}i.build="minimal",i.Writer=e("./writer"),i.BufferWriter=e("./writer_buffer"),i.Reader=e("./reader"),i.BufferReader=e("./reader_buffer"),i.util=e("./util/minimal"),i.rpc=e("./rpc"),i.roots=e("./roots"),i.configure=n,n()},{"./writer":"eDEax","./writer_buffer":"a3zLo","./reader":"hwSZz","./reader_buffer":"51B7L","./util/minimal":"kCaEH","./rpc":"flYC1","./roots":"aq70a"}],eDEax:[function(e,t,r){"use strict";t.exports=d;var i,n=e("./util/minimal"),s=n.LongBits,o=n.base64,a=n.utf8;function c(e,t,r){this.fn=e,this.len=t,this.next=void 0,this.val=r}function u(){}function l(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}function d(){this.len=0,this.head=new c(u,0,0),this.tail=this.head,this.states=null}var f=function(){return n.Buffer?function(){return(d.create=function(){return new i})()}:function(){return new d}};function h(e,t,r){t[r]=255&e}function p(e,t){this.len=e,this.next=void 0,this.val=t}function g(e,t,r){for(;e.hi;)t[r++]=127&e.lo|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[r++]=127&e.lo|128,e.lo=e.lo>>>7;t[r++]=e.lo}function y(e,t,r){t[r]=255&e,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}d.create=f(),d.alloc=function(e){return new n.Array(e)},n.Array!==Array&&(d.alloc=n.pool(d.alloc,n.Array.prototype.subarray)),d.prototype._push=function(e,t,r){return this.tail=this.tail.next=new c(e,t,r),this.len+=t,this},p.prototype=Object.create(c.prototype),p.prototype.fn=function(e,t,r){for(;e>127;)t[r++]=127&e|128,e>>>=7;t[r]=e},d.prototype.uint32=function(e){return this.len+=(this.tail=this.tail.next=new p((e>>>=0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this},d.prototype.int32=function(e){return e<0?this._push(g,10,s.fromNumber(e)):this.uint32(e)},d.prototype.sint32=function(e){return this.uint32((e<<1^e>>31)>>>0)},d.prototype.uint64=function(e){var t=s.from(e);return this._push(g,t.length(),t)},d.prototype.int64=d.prototype.uint64,d.prototype.sint64=function(e){var t=s.from(e).zzEncode();return this._push(g,t.length(),t)},d.prototype.bool=function(e){return this._push(h,1,e?1:0)},d.prototype.fixed32=function(e){return this._push(y,4,e>>>0)},d.prototype.sfixed32=d.prototype.fixed32,d.prototype.fixed64=function(e){var t=s.from(e);return this._push(y,4,t.lo)._push(y,4,t.hi)},d.prototype.sfixed64=d.prototype.fixed64,d.prototype.float=function(e){return this._push(n.float.writeFloatLE,4,e)},d.prototype.double=function(e){return this._push(n.float.writeDoubleLE,8,e)};var m=n.Array.prototype.set?function(e,t,r){t.set(e,r)}:function(e,t,r){for(var i=0;i>>0;if(!t)return this._push(h,1,0);if(n.isString(e)){var r=d.alloc(t=o.length(e));o.decode(e,r,0),e=r}return this.uint32(t)._push(m,t,e)},d.prototype.string=function(e){var t=a.length(e);return t?this.uint32(t)._push(a.write,t,e):this._push(h,1,0)},d.prototype.fork=function(){return this.states=new l(this),this.head=this.tail=new c(u,0,0),this.len=0,this},d.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new c(u,0,0),this.len=0),this},d.prototype.ldelim=function(){var e=this.head,t=this.tail,r=this.len;return this.reset().uint32(r),r&&(this.tail.next=e.next,this.tail=t,this.len+=r),this},d.prototype.finish=function(){for(var e=this.head.next,t=this.constructor.alloc(this.len),r=0;e;)e.fn(e.val,t,r),r+=e.len,e=e.next;return t},d._configure=function(e){i=e,d.create=f(),i._configure()}},{"./util/minimal":"kCaEH"}],kCaEH:[function(e,t,r){var i=arguments[3],n=r;function s(e,t,r){for(var i=Object.keys(t),n=0;n0)},n.Buffer=function(){try{var e=n.inquire("buffer").Buffer;return e.prototype.utf8Write?e:null}catch(e){return null}}(),n._Buffer_from=null,n._Buffer_allocUnsafe=null,n.newBuffer=function(e){return"number"==typeof e?n.Buffer?n._Buffer_allocUnsafe(e):new n.Array(e):n.Buffer?n._Buffer_from(e):"undefined"==typeof Uint8Array?e:new Uint8Array(e)},n.Array="undefined"!=typeof Uint8Array?Uint8Array:Array,n.Long=n.global.dcodeIO&&n.global.dcodeIO.Long||n.global.Long||n.inquire("long"),n.key2Re=/^true|false|0|1$/,n.key32Re=/^-?(?:0|[1-9][0-9]*)$/,n.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,n.longToHash=function(e){return e?n.LongBits.from(e).toHash():n.LongBits.zeroHash},n.longFromHash=function(e,t){var r=n.LongBits.fromHash(e);return n.Long?n.Long.fromBits(r.lo,r.hi,t):r.toNumber(Boolean(t))},n.merge=s,n.lcFirst=function(e){return e.charAt(0).toLowerCase()+e.substring(1)},n.newError=o,n.ProtocolError=o("ProtocolError"),n.oneOfGetter=function(e){for(var t={},r=0;r-1;--r)if(1===t[e[r]]&&void 0!==this[e[r]]&&null!==this[e[r]])return e[r]}},n.oneOfSetter=function(e){return function(t){for(var r=0;r1&&"="===e.charAt(t);)++r;return Math.ceil(3*e.length)/4-r};for(var n=new Array(64),s=new Array(123),o=0;o<64;)s[n[o]=o<26?o+65:o<52?o+71:o<62?o-4:o-59|43]=o++;i.encode=function(e,t,r){for(var i,s=null,o=[],a=0,c=0;t>2],i=(3&u)<<4,c=1;break;case 1:o[a++]=n[i|u>>4],i=(15&u)<<2,c=2;break;case 2:o[a++]=n[i|u>>6],o[a++]=n[63&u],c=0}a>8191&&((s||(s=[])).push(String.fromCharCode.apply(String,o)),a=0)}return c&&(o[a++]=n[i],o[a++]=61,1===c&&(o[a++]=61)),s?(a&&s.push(String.fromCharCode.apply(String,o.slice(0,a))),s.join("")):String.fromCharCode.apply(String,o.slice(0,a))};var a="invalid encoding";i.decode=function(e,t,r){for(var i,n=r,o=0,c=0;c1)break;if(void 0===(u=s[u]))throw Error(a);switch(o){case 0:i=u,o=1;break;case 1:t[r++]=i<<2|(48&u)>>4,i=u,o=2;break;case 2:t[r++]=(15&i)<<4|(60&u)>>2,i=u,o=3;break;case 3:t[r++]=(3&i)<<6|u,o=0}}if(1===o)throw Error(a);return r-n},i.test=function(e){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(e)}},{}],"8QYdM":[function(e,t,r){"use strict";function i(){this._listeners={}}t.exports=i,i.prototype.on=function(e,t,r){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:t,ctx:r||this}),this},i.prototype.off=function(e,t){if(void 0===e)this._listeners={};else if(void 0===t)this._listeners[e]=[];else for(var r=this._listeners[e],i=0;i0?0:2147483648,r,i);else if(isNaN(t))e(2143289344,r,i);else if(t>34028234663852886e22)e((n<<31|2139095040)>>>0,r,i);else if(t<11754943508222875e-54)e((n<<31|Math.round(t/1401298464324817e-60))>>>0,r,i);else{var s=Math.floor(Math.log(t)/Math.LN2);e((n<<31|s+127<<23|8388607&Math.round(t*Math.pow(2,-s)*8388608))>>>0,r,i)}}function r(e,t,r){var i=e(t,r),n=2*(i>>31)+1,s=i>>>23&255,o=8388607&i;return 255===s?o?NaN:n*(1/0):0===s?1401298464324817e-60*n*o:n*Math.pow(2,s-150)*(o+8388608)}e.writeFloatLE=t.bind(null,n),e.writeFloatBE=t.bind(null,s),e.readFloatLE=r.bind(null,o),e.readFloatBE=r.bind(null,a)}(),"undefined"!=typeof Float64Array?function(){var t=new Float64Array([-0]),r=new Uint8Array(t.buffer),i=128===r[7];function n(e,i,n){t[0]=e,i[n]=r[0],i[n+1]=r[1],i[n+2]=r[2],i[n+3]=r[3],i[n+4]=r[4],i[n+5]=r[5],i[n+6]=r[6],i[n+7]=r[7]}function s(e,i,n){t[0]=e,i[n]=r[7],i[n+1]=r[6],i[n+2]=r[5],i[n+3]=r[4],i[n+4]=r[3],i[n+5]=r[2],i[n+6]=r[1],i[n+7]=r[0]}function o(e,i){return r[0]=e[i],r[1]=e[i+1],r[2]=e[i+2],r[3]=e[i+3],r[4]=e[i+4],r[5]=e[i+5],r[6]=e[i+6],r[7]=e[i+7],t[0]}function a(e,i){return r[7]=e[i],r[6]=e[i+1],r[5]=e[i+2],r[4]=e[i+3],r[3]=e[i+4],r[2]=e[i+5],r[1]=e[i+6],r[0]=e[i+7],t[0]}e.writeDoubleLE=i?n:s,e.writeDoubleBE=i?s:n,e.readDoubleLE=i?o:a,e.readDoubleBE=i?a:o}():function(){function t(e,t,r,i,n,s){var o=i<0?1:0;if(o&&(i=-i),0===i)e(0,n,s+t),e(1/i>0?0:2147483648,n,s+r);else if(isNaN(i))e(0,n,s+t),e(2146959360,n,s+r);else if(i>17976931348623157e292)e(0,n,s+t),e((o<<31|2146435072)>>>0,n,s+r);else{var a;if(i<22250738585072014e-324)e((a=i/5e-324)>>>0,n,s+t),e((o<<31|a/4294967296)>>>0,n,s+r);else{var c=Math.floor(Math.log(i)/Math.LN2);1024===c&&(c=1023),e(4503599627370496*(a=i*Math.pow(2,-c))>>>0,n,s+t),e((o<<31|c+1023<<20|1048576*a&1048575)>>>0,n,s+r)}}}function r(e,t,r,i,n){var s=e(i,n+t),o=e(i,n+r),a=2*(o>>31)+1,c=o>>>20&2047,u=4294967296*(1048575&o)+s;return 2047===c?u?NaN:a*(1/0):0===c?5e-324*a*u:a*Math.pow(2,c-1075)*(u+4503599627370496)}e.writeDoubleLE=t.bind(null,n,0,4),e.writeDoubleBE=t.bind(null,s,4,0),e.readDoubleLE=r.bind(null,o,0,4),e.readDoubleBE=r.bind(null,a,4,0)}(),e}function n(e,t,r){t[r]=255&e,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}function s(e,t,r){t[r]=e>>>24,t[r+1]=e>>>16&255,t[r+2]=e>>>8&255,t[r+3]=255&e}function o(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0}function a(e,t){return(e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3])>>>0}t.exports=i(i)},{}],"3GHL4":[function(require,module,exports){"use strict";function inquire(moduleName){try{var mod=eval("quire".replace(/^/,"re"))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(e){}return null}module.exports=inquire},{}],ergn2:[function(e,t,r){"use strict";var i=r;i.length=function(e){for(var t=0,r=0,i=0;i191&&i<224?s[o++]=(31&i)<<6|63&e[t++]:i>239&&i<365?(i=((7&i)<<18|(63&e[t++])<<12|(63&e[t++])<<6|63&e[t++])-65536,s[o++]=55296+(i>>10),s[o++]=56320+(1023&i)):s[o++]=(15&i)<<12|(63&e[t++])<<6|63&e[t++],o>8191&&((n||(n=[])).push(String.fromCharCode.apply(String,s)),o=0);return n?(o&&n.push(String.fromCharCode.apply(String,s.slice(0,o))),n.join("")):String.fromCharCode.apply(String,s.slice(0,o))},i.write=function(e,t,r){for(var i,n,s=r,o=0;o>6|192,t[r++]=63&i|128):55296==(64512&i)&&56320==(64512&(n=e.charCodeAt(o+1)))?(i=65536+((1023&i)<<10)+(1023&n),++o,t[r++]=i>>18|240,t[r++]=i>>12&63|128,t[r++]=i>>6&63|128,t[r++]=63&i|128):(t[r++]=i>>12|224,t[r++]=i>>6&63|128,t[r++]=63&i|128);return r-s}},{}],lRkSe:[function(e,t,r){"use strict";t.exports=function(e,t,r){var i=r||8192,n=i>>>1,s=null,o=i;return function(r){if(r<1||r>n)return e(r);o+r>i&&(s=e(i),o=0);var a=t.call(s,o,o+=r);return 7&o&&(o=1+(7|o)),a}}},{}],kTtk9:[function(e,t,r){"use strict";t.exports=n;var i=e("../util/minimal");function n(e,t){this.lo=e>>>0,this.hi=t>>>0}var s=n.zero=new n(0,0);s.toNumber=function(){return 0},s.zzEncode=s.zzDecode=function(){return this},s.length=function(){return 1};var o=n.zeroHash="\0\0\0\0\0\0\0\0";n.fromNumber=function(e){if(0===e)return s;var t=e<0;t&&(e=-e);var r=e>>>0,i=(e-r)/4294967296>>>0;return t&&(i=~i>>>0,r=~r>>>0,++r>4294967295&&(r=0,++i>4294967295&&(i=0))),new n(r,i)},n.from=function(e){if("number"==typeof e)return n.fromNumber(e);if(i.isString(e)){if(!i.Long)return n.fromNumber(parseInt(e,10));e=i.Long.fromString(e)}return e.low||e.high?new n(e.low>>>0,e.high>>>0):s},n.prototype.toNumber=function(e){if(!e&&this.hi>>>31){var t=1+~this.lo>>>0,r=~this.hi>>>0;return t||(r=r+1>>>0),-(t+4294967296*r)}return this.lo+4294967296*this.hi},n.prototype.toLong=function(e){return i.Long?new i.Long(0|this.lo,0|this.hi,Boolean(e)):{low:0|this.lo,high:0|this.hi,unsigned:Boolean(e)}};var a=String.prototype.charCodeAt;n.fromHash=function(e){return e===o?s:new n((a.call(e,0)|a.call(e,1)<<8|a.call(e,2)<<16|a.call(e,3)<<24)>>>0,(a.call(e,4)|a.call(e,5)<<8|a.call(e,6)<<16|a.call(e,7)<<24)>>>0)},n.prototype.toHash=function(){return String.fromCharCode(255&this.lo,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,255&this.hi,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},n.prototype.zzEncode=function(){var e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this},n.prototype.zzDecode=function(){var e=-(1&this.lo);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this},n.prototype.length=function(){var e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,r=this.hi>>>24;return 0===r?0===t?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:r<128?9:10}},{"../util/minimal":"kCaEH"}],a3zLo:[function(e,t,r){"use strict";t.exports=s;var i=e("./writer");(s.prototype=Object.create(i.prototype)).constructor=s;var n=e("./util/minimal");function s(){i.call(this)}function o(e,t,r){e.length<40?n.utf8.write(e,t,r):t.utf8Write?t.utf8Write(e,r):t.write(e,r)}s._configure=function(){s.alloc=n._Buffer_allocUnsafe,s.writeBytesBuffer=n.Buffer&&n.Buffer.prototype instanceof Uint8Array&&"set"===n.Buffer.prototype.set.name?function(e,t,r){t.set(e,r)}:function(e,t,r){if(e.copy)e.copy(t,r,0,e.length);else for(var i=0;i>>0;return this.uint32(t),t&&this._push(s.writeBytesBuffer,t,e),this},s.prototype.string=function(e){var t=n.Buffer.byteLength(e);return this.uint32(t),t&&this._push(o,t,e),this},s._configure()},{"./writer":"eDEax","./util/minimal":"kCaEH"}],hwSZz:[function(e,t,r){"use strict";t.exports=c;var i,n=e("./util/minimal"),s=n.LongBits,o=n.utf8;function a(e,t){return RangeError("index out of range: "+e.pos+" + "+(t||1)+" > "+e.len)}function c(e){this.buf=e,this.pos=0,this.len=e.length}var u,l="undefined"!=typeof Uint8Array?function(e){if(e instanceof Uint8Array||Array.isArray(e))return new c(e);throw Error("illegal buffer")}:function(e){if(Array.isArray(e))return new c(e);throw Error("illegal buffer")},d=function(){return n.Buffer?function(e){return(c.create=function(e){return n.Buffer.isBuffer(e)?new i(e):l(e)})(e)}:l};function f(){var e=new s(0,0),t=0;if(!(this.len-this.pos>4)){for(;t<3;++t){if(this.pos>=this.len)throw a(this);if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(127&this.buf[this.pos++])<<7*t)>>>0,e}for(;t<4;++t)if(e.lo=(e.lo|(127&this.buf[this.pos])<<7*t)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(127&this.buf[this.pos])<<28)>>>0,e.hi=(e.hi|(127&this.buf[this.pos])>>4)>>>0,this.buf[this.pos++]<128)return e;if(t=0,this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw a(this);if(e.hi=(e.hi|(127&this.buf[this.pos])<<7*t+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}function h(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}function p(){if(this.pos+8>this.len)throw a(this,8);return new s(h(this.buf,this.pos+=4),h(this.buf,this.pos+=4))}c.create=d(),c.prototype._slice=n.Array.prototype.subarray||n.Array.prototype.slice,c.prototype.uint32=(u=4294967295,function(){if(u=(127&this.buf[this.pos])>>>0,this.buf[this.pos++]<128)return u;if(u=(u|(127&this.buf[this.pos])<<7)>>>0,this.buf[this.pos++]<128)return u;if(u=(u|(127&this.buf[this.pos])<<14)>>>0,this.buf[this.pos++]<128)return u;if(u=(u|(127&this.buf[this.pos])<<21)>>>0,this.buf[this.pos++]<128)return u;if(u=(u|(15&this.buf[this.pos])<<28)>>>0,this.buf[this.pos++]<128)return u;if((this.pos+=5)>this.len)throw this.pos=this.len,a(this,10);return u}),c.prototype.int32=function(){return 0|this.uint32()},c.prototype.sint32=function(){var e=this.uint32();return e>>>1^-(1&e)|0},c.prototype.bool=function(){return 0!==this.uint32()},c.prototype.fixed32=function(){if(this.pos+4>this.len)throw a(this,4);return h(this.buf,this.pos+=4)},c.prototype.sfixed32=function(){if(this.pos+4>this.len)throw a(this,4);return 0|h(this.buf,this.pos+=4)},c.prototype.float=function(){if(this.pos+4>this.len)throw a(this,4);var e=n.float.readFloatLE(this.buf,this.pos);return this.pos+=4,e},c.prototype.double=function(){if(this.pos+8>this.len)throw a(this,4);var e=n.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,e},c.prototype.bytes=function(){var e=this.uint32(),t=this.pos,r=this.pos+e;if(r>this.len)throw a(this,e);return this.pos+=e,Array.isArray(this.buf)?this.buf.slice(t,r):t===r?new this.buf.constructor(0):this._slice.call(this.buf,t,r)},c.prototype.string=function(){var e=this.bytes();return o.read(e,0,e.length)},c.prototype.skip=function(e){if("number"==typeof e){if(this.pos+e>this.len)throw a(this,e);this.pos+=e}else do{if(this.pos>=this.len)throw a(this)}while(128&this.buf[this.pos++]);return this},c.prototype.skipType=function(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;4!=(e=7&this.uint32());)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+e+" at offset "+this.pos)}return this},c._configure=function(e){i=e,c.create=d(),i._configure();var t=n.Long?"toLong":"toNumber";n.merge(c.prototype,{int64:function(){return f.call(this)[t](!1)},uint64:function(){return f.call(this)[t](!0)},sint64:function(){return f.call(this).zzDecode()[t](!1)},fixed64:function(){return p.call(this)[t](!0)},sfixed64:function(){return p.call(this)[t](!1)}})}},{"./util/minimal":"kCaEH"}],"51B7L":[function(e,t,r){"use strict";t.exports=s;var i=e("./reader");(s.prototype=Object.create(i.prototype)).constructor=s;var n=e("./util/minimal");function s(e){i.call(this,e)}s._configure=function(){n.Buffer&&(s.prototype._slice=n.Buffer.prototype.slice)},s.prototype.string=function(){var e=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+e,this.len)):this.buf.toString("utf-8",this.pos,this.pos=Math.min(this.pos+e,this.len))},s._configure()},{"./reader":"hwSZz","./util/minimal":"kCaEH"}],flYC1:[function(e,t,r){"use strict";r.Service=e("./rpc/service")},{"./rpc/service":"cl9qf"}],cl9qf:[function(e,t,r){"use strict";t.exports=n;var i=e("../util/minimal");function n(e,t,r){if("function"!=typeof e)throw TypeError("rpcImpl must be a function");i.EventEmitter.call(this),this.rpcImpl=e,this.requestDelimited=Boolean(t),this.responseDelimited=Boolean(r)}(n.prototype=Object.create(i.EventEmitter.prototype)).constructor=n,n.prototype.rpcCall=function e(t,r,n,s,o){if(!s)throw TypeError("request must be specified");var a=this;if(!o)return i.asPromise(e,a,t,r,n,s);if(a.rpcImpl)try{return a.rpcImpl(t,r[a.requestDelimited?"encodeDelimited":"encode"](s).finish(),(function(e,r){if(e)return a.emit("error",e,t),o(e);if(null!==r){if(!(r instanceof n))try{r=n[a.responseDelimited?"decodeDelimited":"decode"](r)}catch(e){return a.emit("error",e,t),o(e)}return a.emit("data",r,t),o(null,r)}a.end(!0)}))}catch(e){return a.emit("error",e,t),void setTimeout((function(){o(e)}),0)}else setTimeout((function(){o(Error("already ended"))}),0)},n.prototype.end=function(e){return this.rpcImpl&&(e||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this}},{"../util/minimal":"kCaEH"}],aq70a:[function(e,t,r){"use strict";t.exports={}},{}],i2cdx:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("./pb-decode.js"),s=e("./pb-encode.js"),o=e("./util.js");r.createLink=o.createLink,r.createNode=o.createNode,r.prepare=o.prepare,r.validate=o.validate,r.code=112,r.decode=function(e){const t=n.decodeNode(e),r={};return t.Data&&(r.Data=t.Data),t.Links&&(r.Links=t.Links.map((e=>{const t={};try{t.Hash=i.CID.decode(e.Hash)}catch(e){}if(!t.Hash)throw new Error("Invalid Hash field found in link, expected CID");return void 0!==e.Name&&(t.Name=e.Name),void 0!==e.Tsize&&(t.Tsize=e.Tsize),t}))),r},r.encode=function(e){o.validate(e);const t={};return e.Links&&(t.Links=e.Links.map((e=>{const t={};return e.Hash&&(t.Hash=e.Hash.bytes),void 0!==e.Name&&(t.Name=e.Name),void 0!==e.Tsize&&(t.Tsize=e.Tsize),t}))),e.Data&&(t.Data=e.Data),s.encodeNode(t)},r.name="dag-pb"},{"multiformats/cid":"9ooAY","./pb-decode.js":"ld3PU","./pb-encode.js":"5nPbE","./util.js":"1YHGP"}],"9ooAY":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./varint.js"),n=e("./hashes/digest.js"),s=e("./bases/base58.js"),o=e("./bases/base32.js"),a=e("./bytes.js");class c{constructor(e,t,r,i){this.code=t,this.version=e,this.multihash=r,this.bytes=i,this.byteOffset=i.byteOffset,this.byteLength=i.byteLength,this.asCID=this,this._baseCache=new Map,Object.defineProperties(this,{byteOffset:m,byteLength:m,code:y,version:y,multihash:y,bytes:y,_baseCache:m,asCID:m})}toV0(){if(0===this.version)return this;{const{code:e,multihash:t}=this;if(e!==f)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==h)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return c.createV0(t)}}toV1(){switch(this.version){case 0:{const{code:e,digest:t}=this.multihash,r=n.create(e,t);return c.createV1(this.code,r)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}equals(e){return e&&this.code===e.code&&this.version===e.version&&n.equals(this.multihash,e.multihash)}toString(e){const{bytes:t,version:r,_baseCache:i}=this;return 0===r?l(t,i,e||s.base58btc.encoder):d(t,i,e||o.base32.encoder)}toJSON(){return{code:this.code,version:this.version,hash:this.multihash.bytes}}get[Symbol.toStringTag](){return"CID"}[Symbol.for("nodejs.util.inspect.custom")](){return"CID("+this.toString()+")"}static isCID(e){return b(/^0\.0/,v),!(!e||!e[g]&&e.asCID!==e)}get toBaseEncodedString(){throw new Error("Deprecated, use .toString()")}get codec(){throw new Error('"codec" property is deprecated, use integer "code" property instead')}get buffer(){throw new Error("Deprecated .buffer property, use .bytes to get Uint8Array instead")}get multibaseName(){throw new Error('"multibaseName" property is deprecated')}get prefix(){throw new Error('"prefix" property is deprecated')}static asCID(e){if(e instanceof c)return e;if(null!=e&&e.asCID===e){const{version:t,code:r,multihash:i,bytes:n}=e;return new c(t,r,i,n||p(t,r,i.bytes))}if(null!=e&&!0===e[g]){const{version:t,multihash:r,code:i}=e,s=n.decode(r);return c.create(t,i,s)}return null}static create(e,t,r){if("number"!=typeof t)throw new Error("String codecs are no longer supported");switch(e){case 0:if(t!==f)throw new Error(`Version 0 CID must use dag-pb (code: ${f}) block encoding`);return new c(e,t,r,r.bytes);case 1:{const i=p(e,t,r.bytes);return new c(e,t,r,i)}default:throw new Error("Invalid version")}}static createV0(e){return c.create(0,f,e)}static createV1(e,t){return c.create(1,e,t)}static decode(e){const[t,r]=c.decodeFirst(e);if(r.length)throw new Error("Incorrect length");return t}static decodeFirst(e){const t=c.inspectBytes(e),r=t.size-t.multihashSize,i=a.coerce(e.subarray(r,r+t.multihashSize));if(i.byteLength!==t.multihashSize)throw new Error("Incorrect length");const s=i.subarray(t.multihashSize-t.digestSize),o=new n.Digest(t.multihashCode,t.digestSize,s,i);return[0===t.version?c.createV0(o):c.createV1(t.codec,o),e.subarray(t.size)]}static inspectBytes(e){let t=0;const r=()=>{const[r,n]=i.decode(e.subarray(t));return t+=n,r};let n=r(),s=f;if(18===n?(n=0,t=0):1===n&&(s=r()),0!==n&&1!==n)throw new RangeError(`Invalid CID version ${n}`);const o=t,a=r(),c=r(),u=t+c;return{version:n,codec:s,multihashCode:a,digestSize:c,multihashSize:u-o,size:u}}static parse(e,t){const[r,i]=u(e,t),n=c.decode(i);return n._baseCache.set(r,e),n}}const u=(e,t)=>{switch(e[0]){case"Q":{const r=t||s.base58btc;return[s.base58btc.prefix,r.decode(`${s.base58btc.prefix}${e}`)]}case s.base58btc.prefix:{const r=t||s.base58btc;return[s.base58btc.prefix,r.decode(e)]}case o.base32.prefix:{const r=t||o.base32;return[o.base32.prefix,r.decode(e)]}default:if(null==t)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[e[0],t.decode(e)]}},l=(e,t,r)=>{const{prefix:i}=r;if(i!==s.base58btc.prefix)throw Error(`Cannot string encode V0 in ${r.name} encoding`);const n=t.get(i);if(null==n){const n=r.encode(e).slice(1);return t.set(i,n),n}return n},d=(e,t,r)=>{const{prefix:i}=r,n=t.get(i);if(null==n){const n=r.encode(e);return t.set(i,n),n}return n},f=112,h=18,p=(e,t,r)=>{const n=i.encodingLength(e),s=n+i.encodingLength(t),o=new Uint8Array(s+r.byteLength);return i.encodeTo(e,o,0),i.encodeTo(t,o,n),o.set(r,s),o},g=Symbol.for("@ipld/js-cid/CID"),y={writable:!1,configurable:!1,enumerable:!0},m={writable:!1,enumerable:!1,configurable:!1},b=(e,t)=>{if(!e.test("0.0.0-dev"))throw new Error(t);console.warn(t)},v="CID.isCID(v) is deprecated and will be removed in the next major release.\nFollowing code pattern:\n\nif (CID.isCID(value)) {\n doSomethingWithCID(value)\n}\n\nIs replaced with:\n\nconst cid = CID.asCID(value)\nif (cid) {\n // Make sure to use cid instead of value\n doSomethingWithCID(cid)\n}\n";r.CID=c},{"./varint.js":"ivDPm","./hashes/digest.js":"kpRBg","./bases/base58.js":"4n7mA","./bases/base32.js":"5k9Tu","./bytes.js":"6I0Ku"}],ivDPm:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../vendor/varint.js");r.decode=e=>[i.decode(e),i.decode.bytes],r.encodeTo=(e,t,r=0)=>(i.encode(e,t,r),t),r.encodingLength=e=>i.encodingLength(e)},{"../vendor/varint.js":"h72ss"}],h72ss:[function(e,t,r){"use strict";var i=function e(t,r,i){r=r||[];var s=i=i||0;for(;t>=n;)r[i++]=255&t|128,t/=128;for(;-128&t;)r[i++]=255&t|128,t>>>=7;return r[i]=0|t,e.bytes=i-s+1,r},n=Math.pow(2,31);var s=function e(t,r){var i,n=0,s=0,o=r=r||0,a=t.length;do{if(o>=a)throw e.bytes=0,new RangeError("Could not decode varint");i=t[o++],n+=s<28?(127&i)<=128);return e.bytes=o-r,n};var o=Math.pow(2,7),a=Math.pow(2,14),c=Math.pow(2,21),u=Math.pow(2,28),l=Math.pow(2,35),d=Math.pow(2,42),f=Math.pow(2,49),h=Math.pow(2,56),p=Math.pow(2,63),g={encode:i,decode:s,encodingLength:function(e){return e{const r=t.byteLength,i=n.encodingLength(e),o=i+n.encodingLength(r),a=new Uint8Array(o+r);return n.encodeTo(e,a,0),n.encodeTo(r,a,i),a.set(t,o),new s(e,r,t,a)},r.decode=e=>{const t=i.coerce(e),[r,o]=n.decode(t),[a,c]=n.decode(t.subarray(o)),u=t.subarray(o+c);if(u.byteLength!==a)throw new Error("Incorrect length");return new s(r,a,u,t)},r.equals=(e,t)=>e===t||e.code===t.code&&e.size===t.size&&i.equals(e.bytes,t.bytes)},{"../bytes.js":"6I0Ku","../varint.js":"ivDPm"}],"6I0Ku":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=new Uint8Array(0);r.coerce=e=>{if(e instanceof Uint8Array&&"Uint8Array"===e.constructor.name)return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw new Error("Unknown type, must be binary type")},r.empty=i,r.equals=(e,t)=>{if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r{const t=e.match(/../g);return t?new Uint8Array(t.map((e=>parseInt(e,16)))):i},r.fromString=e=>(new TextEncoder).encode(e),r.isBinary=e=>e instanceof ArrayBuffer||ArrayBuffer.isView(e),r.toHex=e=>e.reduce(((e,t)=>e+t.toString(16).padStart(2,"0")),""),r.toString=e=>(new TextDecoder).decode(e)},{}],"4n7mA":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js");const n=i.baseX({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),s=i.baseX({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});r.base58btc=n,r.base58flickr=s},{"./base.js":"6uTk1"}],"6uTk1":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../vendor/base-x.js"),n=e("../bytes.js");class s{constructor(e,t,r){this.name=e,this.prefix=t,this.baseEncode=r}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}}class o{constructor(e,t,r){this.name=e,this.prefix=t,this.baseDecode=r}decode(e){if("string"==typeof e){if(e[0]===this.prefix)return this.baseDecode(e.slice(1));throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`)}throw Error("Can only multibase decode strings")}or(e){return c(this,e)}}class a{constructor(e){this.decoders=e}or(e){return c(this,e)}decode(e){const t=e[0],r=this.decoders[t];if(r)return r.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}}const c=(e,t)=>new a({...e.decoders||{[e.prefix]:e},...t.decoders||{[t.prefix]:t}});class u{constructor(e,t,r,i){this.name=e,this.prefix=t,this.baseEncode=r,this.baseDecode=i,this.encoder=new s(e,t,r),this.decoder=new o(e,t,i)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}}const l=({name:e,prefix:t,encode:r,decode:i})=>new u(e,t,r,i);r.Codec=u,r.baseX=({prefix:e,name:t,alphabet:r})=>{const{encode:s,decode:o}=i(r,t);return l({prefix:e,name:t,encode:s,decode:e=>n.coerce(o(e))})},r.from=l,r.or=c,r.rfc4648=({name:e,prefix:t,bitsPerChar:r,alphabet:i})=>l({prefix:t,name:e,encode:e=>((e,t,r)=>{const i="="===t[t.length-1],n=(1<r;)o-=r,s+=t[n&a>>o];if(o&&(s+=t[n&a<((e,t,r,i)=>{const n={};for(let e=0;e=8&&(a-=8,o[u++]=255&c>>a)}if(a>=r||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o})(t,i,r,e)})},{"../../vendor/base-x.js":"bImXU","../bytes.js":"6I0Ku"}],bImXU:[function(e,t,r){"use strict";var i=function(e,t){if(e.length>=255)throw new TypeError("Alphabet too long");for(var r=new Uint8Array(256),i=0;i>>0,o=new Uint8Array(s);e[t];){var l=r[e.charCodeAt(t)];if(255===l)return;for(var d=0,f=s-1;(0!==l||d>>0,o[f]=l%256>>>0,l=l/256>>>0;if(0!==l)throw new Error("Non-zero carry");n=d,t++}if(" "!==e[t]){for(var h=s-n;h!==s&&0===o[h];)h++;for(var p=new Uint8Array(i+(s-h)),g=i;h!==s;)p[g++]=o[h++];return p}}}return{encode:function(t){if(t instanceof Uint8Array||(ArrayBuffer.isView(t)?t=new Uint8Array(t.buffer,t.byteOffset,t.byteLength):Array.isArray(t)&&(t=Uint8Array.from(t))),!(t instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(0===t.length)return"";for(var r=0,i=0,n=0,s=t.length;n!==s&&0===t[n];)n++,r++;for(var o=(s-n)*l+1>>>0,u=new Uint8Array(o);n!==s;){for(var d=t[n],f=0,h=o-1;(0!==d||f>>0,u[h]=d%a>>>0,d=d/a>>>0;if(0!==d)throw new Error("Non-zero carry");i=f,n++}for(var p=o-i;p!==o&&0===u[p];)p++;for(var g=c.repeat(r);p=64)throw new Error("protobuf: varint overflow");if(t>=e.length)throw new Error("protobuf: unexpected end of data");const n=e[t++];if(r+=i<28?(127&n)<e.length)throw new Error("protobuf: unexpected end of data");return[e.subarray(t,i),i]}function o(e,t){let r;return[r,t]=n(e,t),[7&r,r>>3,t]}function a(e){const t={},r=e.length;let a=0;for(;ar)throw new Error("protobuf: (PBLink) unexpected end of data");return t}r.decodeNode=function(e){const t=e.length;let r,i,n=0,c=!1;for(;nt)throw new Error("protobuf: (PBNode) unexpected end of data");const u={};return i&&(u.Data=i),u.Links=r||[],u}},{}],"5nPbE":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=new TextEncoder,n=2**32;function s(e,t){let r=t.length;if("number"==typeof e.Tsize){if(e.Tsize<0)throw new Error("Tsize cannot be negative");if(!Number.isSafeInteger(e.Tsize))throw new Error("Tsize too large for encoding");r=a(t,r,e.Tsize)-1,t[r]=24}if("string"==typeof e.Name){const n=i.encode(e.Name);r-=n.length,t.set(n,r),r=a(t,r,n.length)-1,t[r]=18}return e.Hash&&(r-=e.Hash.length,t.set(e.Hash,r),r=a(t,r,e.Hash.length)-1,t[r]=10),t.length-r}function o(e){let t=0;if(e.Hash){const r=e.Hash.length;t+=1+r+c(r)}if("string"==typeof e.Name){const r=i.encode(e.Name).length;t+=1+r+c(r)}return"number"==typeof e.Tsize&&(t+=1+c(e.Tsize)),t}function a(e,t,r){const i=t-=c(r);for(;r>=2147483648;)e[t++]=127&r|128,r/=128;for(;r>=128;)e[t++]=127&r|128,r>>>=7;return e[t]=r,i}function c(e){return e%2==0&&e++,Math.floor((function(e){let t=0;e>=n&&(e=Math.floor(e/n),t=32);e>=65536&&(e>>>=16,t+=16);e>=256&&(e>>>=8,t+=8);return t+u[e]}(e)+6)/7)}const u=[0,1,2,2,3,3,3,3,4,4,4,4,4,4,4,4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8];r.encodeNode=function(e){const t=function(e){let t=0;if(e.Data){const r=e.Data.length;t+=1+r+c(r)}if(e.Links)for(const r of e.Links){const e=o(r);t+=1+e+c(e)}return t}(e),r=new Uint8Array(t);let i=t;if(e.Data&&(i-=e.Data.length,r.set(e.Data,i),i=a(r,i,e.Data.length)-1,r[i]=10),e.Links)for(let t=e.Links.length-1;t>=0;t--){const n=s(e.Links[t],r.subarray(0,i));i-=n,i=a(r,i,n)-1,r[i]=18}return r}},{}],"1YHGP":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid");const n=["Data","Links"],s=["Hash","Name","Tsize"],o=new TextEncoder;function a(e,t){if(e===t)return 0;const r=e.Name?o.encode(e.Name):[],i=t.Name?o.encode(t.Name):[];let n=r.length,s=i.length;for(let e=0,t=Math.min(n,s);e!t.includes(e)))}function u(e){if("object"==typeof e.asCID){const t=i.CID.asCID(e);if(!t)throw new TypeError("Invalid DAG-PB form");return{Hash:t}}if("object"!=typeof e||Array.isArray(e))throw new TypeError("Invalid DAG-PB form");const t={};if(e.Hash){let r=i.CID.asCID(e.Hash);try{r||("string"==typeof e.Hash?r=i.CID.parse(e.Hash):e.Hash instanceof Uint8Array&&(r=i.CID.decode(e.Hash)))}catch(e){throw new TypeError(`Invalid DAG-PB form: ${e.message}`)}r&&(t.Hash=r)}if(!t.Hash)throw new TypeError("Invalid DAG-PB form");return"string"==typeof e.Name&&(t.Name=e.Name),"number"==typeof e.Tsize&&(t.Tsize=e.Tsize),t}function l(e){if((e instanceof Uint8Array||"string"==typeof e)&&(e={Data:e}),"object"!=typeof e||Array.isArray(e))throw new TypeError("Invalid DAG-PB form");const t={};if(void 0!==e.Data)if("string"==typeof e.Data)t.Data=o.encode(e.Data);else{if(!(e.Data instanceof Uint8Array))throw new TypeError("Invalid DAG-PB form");t.Data=e.Data}if(void 0!==e.Links){if(!Array.isArray(e.Links))throw new TypeError("Invalid DAG-PB form");t.Links=e.Links.map(u),t.Links.sort(a)}else t.Links=[];return t}r.createLink=function(e,t,r){return u({Hash:r,Name:e,Tsize:t})},r.createNode=function(e,t=[]){return l({Data:e,Links:t})},r.prepare=l,r.validate=function(e){if(!e||"object"!=typeof e||Array.isArray(e))throw new TypeError("Invalid DAG-PB form");if(!c(e,n))throw new TypeError("Invalid DAG-PB form (extraneous properties)");if(void 0!==e.Data&&!(e.Data instanceof Uint8Array))throw new TypeError("Invalid DAG-PB form (Data must be a Uint8Array)");if(!Array.isArray(e.Links))throw new TypeError("Invalid DAG-PB form (Links must be an array)");for(let t=0;t0&&-1===a(r,e.Links[t-1]))throw new TypeError("Invalid DAG-PB form (links must be sorted by Name bytes)")}}},{"multiformats/cid":"9ooAY"}],"3498i":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("cborg"),n=e("multiformats/cid");function s(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var o=s(i);const a={float64:!0,typeEncoders:{Object:function(e){if(e.asCID!==e)return null;const t=n.CID.asCID(e);if(!t)return null;const r=new Uint8Array(t.bytes.byteLength+1);return r.set(t.bytes,1),[new o.Token(o.Type.tag,42),new o.Token(o.Type.bytes,r)]},undefined:function(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")},number:function(e){if(Number.isNaN(e))throw new Error("`NaN` is not supported by the IPLD Data Model and cannot be encoded");if(e===1/0||e===-1/0)throw new Error("`Infinity` and `-Infinity` is not supported by the IPLD Data Model and cannot be encoded");return null}}};const c={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,tags:[]};c.tags[42]=function(e){if(0!==e[0])throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return n.CID.decode(e.subarray(1))};r.code=113,r.decode=e=>o.decode(e,c),r.encode=e=>o.encode(e,a),r.name="dag-cbor"},{cborg:"iZrkE","multiformats/cid":"9ooAY"}],iZrkE:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/encode.js"),n=e("./lib/decode.js"),s=e("./lib/token.js");r.encode=i.encode,r.decode=n.decode,r.Token=s.Token,r.Type=s.Type},{"./lib/encode.js":"72LuQ","./lib/decode.js":"dbDwZ","./lib/token.js":"jVUGz"}],"72LuQ":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./is.js"),n=e("./token.js"),s=e("./bl.js"),o=e("./common.js"),a=e("./jump.js"),c=e("./byte-utils.js"),u=e("./0uint.js"),l=e("./1negint.js"),d=e("./2bytes.js"),f=e("./3string.js"),h=e("./4array.js"),p=e("./5map.js"),g=e("./6tag.js"),y=e("./7float.js");const m={float64:!1,mapSorter:function(e,t){const r=Array.isArray(e[0])?e[0][0]:e[0],i=Array.isArray(t[0])?t[0][0]:t[0];if(r.type!==i.type)return r.type.compare(i.type);const n=r.type.major,s=b[n].compareTokens(r,i);0===s&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone");return s},quickEncodeToken:a.quickEncodeToken},b=[];b[n.Type.uint.major]=u.encodeUint,b[n.Type.negint.major]=l.encodeNegint,b[n.Type.bytes.major]=d.encodeBytes,b[n.Type.string.major]=f.encodeString,b[n.Type.array.major]=h.encodeArray,b[n.Type.map.major]=p.encodeMap,b[n.Type.tag.major]=g.encodeTag,b[n.Type.float.major]=y.encodeFloat;const v=new s.Bl;class w{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do{if(t.obj===e)return!0}while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${o.encodeErrPrefix} object contains circular references`);return new w(t,e)}}const _={null:new n.Token(n.Type.null,null),undefined:new n.Token(n.Type.undefined,void 0),true:new n.Token(n.Type.true,!0),false:new n.Token(n.Type.false,!1),emptyArray:new n.Token(n.Type.array,0),emptyMap:new n.Token(n.Type.map,0)},E={number:(e,t,r,i)=>Number.isInteger(e)&&Number.isSafeInteger(e)?e>=0?new n.Token(n.Type.uint,e):new n.Token(n.Type.negint,e):new n.Token(n.Type.float,e),bigint:(e,t,r,i)=>e>=BigInt(0)?new n.Token(n.Type.uint,e):new n.Token(n.Type.negint,e),Uint8Array:(e,t,r,i)=>new n.Token(n.Type.bytes,e),string:(e,t,r,i)=>new n.Token(n.Type.string,e),boolean:(e,t,r,i)=>e?_.true:_.false,null:(e,t,r,i)=>_.null,undefined:(e,t,r,i)=>_.undefined,ArrayBuffer:(e,t,r,i)=>new n.Token(n.Type.bytes,new Uint8Array(e)),DataView:(e,t,r,i)=>new n.Token(n.Type.bytes,new Uint8Array(e.buffer,e.byteOffset,e.byteLength)),Array(e,t,r,i){if(!e.length)return!0===r.addBreakTokens?[_.emptyArray,new n.Token(n.Type.break)]:_.emptyArray;i=w.createCheck(i,e);const s=[];let o=0;for(const t of e)s[o++]=S(t,r,i);return r.addBreakTokens?[new n.Token(n.Type.array,e.length),s,new n.Token(n.Type.break)]:[new n.Token(n.Type.array,e.length),s]},Object(e,t,r,i){const s="Object"!==t,o=s?e.keys():Object.keys(e),a=s?e.size:o.length;if(!a)return!0===r.addBreakTokens?[_.emptyMap,new n.Token(n.Type.break)]:_.emptyMap;i=w.createCheck(i,e);const c=[];let u=0;for(const t of o)c[u++]=[S(t,r,i),S(s?e.get(t):e[t],r,i)];return function(e,t){t.mapSorter&&e.sort(t.mapSorter)}(c,r),r.addBreakTokens?[new n.Token(n.Type.map,a),c,new n.Token(n.Type.break)]:[new n.Token(n.Type.map,a),c]}};E.Map=E.Object,E.Buffer=E.Uint8Array;for(const e of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))E[`${e}Array`]=E.DataView;function S(e,t={},r){const n=i.is(e),s=t&&t.typeEncoders&&t.typeEncoders[n]||E[n];if("function"==typeof s){const i=s(e,n,t,r);if(null!=i)return i}const a=E[n];if(!a)throw new Error(`${o.encodeErrPrefix} unsupported type: ${n}`);return a(e,n,t,r)}function T(e,t,r,i){if(Array.isArray(t))for(const n of t)T(e,n,r,i);else r[t.type.major](e,t,i)}function A(e,t,r){const i=S(e,r);if(!Array.isArray(i)&&r.quickEncodeToken){const e=r.quickEncodeToken(i);if(e)return e;const n=t[i.type.major];if(n.encodedSize){const e=n.encodedSize(i,r),t=new s.Bl(e);if(n(t,i,r),1!==t.chunks.length)throw new Error(`Unexpected error: pre-calculated length for ${i} was wrong`);return c.asU8A(t.chunks[0])}}return T(v,i,t,r),v.toBytes(!0)}r.Ref=w,r.encode=function(e,t){return t=Object.assign({},m,t),A(e,b,t)},r.encodeCustom=A,r.objectToTokens=S},{"./is.js":"bPQoh","./token.js":"jVUGz","./bl.js":"25Ozo","./common.js":"aoxj4","./jump.js":"FaFBb","./byte-utils.js":"9dmLv","./0uint.js":"9zilL","./1negint.js":"2sjxL","./2bytes.js":"8Tv7U","./3string.js":"56Ua8","./4array.js":"4ePxQ","./5map.js":"28THk","./6tag.js":"5TCWp","./7float.js":"5T30n"}],bPQoh:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=["string","number","bigint","symbol"],n=["Function","Generator","AsyncGenerator","GeneratorFunction","AsyncGeneratorFunction","AsyncFunction","Observable","Array","Buffer","Object","RegExp","Date","Error","Map","Set","WeakMap","WeakSet","ArrayBuffer","SharedArrayBuffer","DataView","Promise","URL","HTMLElement","Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array"];r.is=function(e){if(null===e)return"null";if(void 0===e)return"undefined";if(!0===e||!1===e)return"boolean";const t=typeof e;if(i.includes(t))return t;if("function"===t)return"Function";if(Array.isArray(e))return"Array";if(function(e){return e&&e.constructor&&e.constructor.isBuffer&&e.constructor.isBuffer.call(null,e)}(e))return"Buffer";const r=function(e){const t=Object.prototype.toString.call(e).slice(8,-1);return n.includes(t)?t:void 0}(e);return r||"Object"}},{}],jVUGz:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});class i{constructor(e,t,r){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=r}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.majore.major?1:0}}i.uint=new i(0,"uint",!0),i.negint=new i(1,"negint",!0),i.bytes=new i(2,"bytes",!0),i.string=new i(3,"string",!0),i.array=new i(4,"array",!1),i.map=new i(5,"map",!1),i.tag=new i(6,"tag",!1),i.float=new i(7,"float",!0),i.false=new i(7,"false",!0),i.true=new i(7,"true",!0),i.null=new i(7,"null",!0),i.undefined=new i(7,"undefined",!0),i.break=new i(7,"break",!0);r.Token=class{constructor(e,t,r){this.type=e,this.value=t,this.encodedLength=r,this.encodedBytes=void 0}toString(){return`Token[${this.type}].${this.value}`}},r.Type=i},{}],"25Ozo":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./byte-utils.js");r.Bl=class{constructor(e=256){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.chunks=[],this.cursor=0,this.maxCursor=-1,null!==this._initReuseChunk&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){const r=t.length-(this.maxCursor-this.cursor)-1;t.set(e,r)}else{if(t){const e=t.length-(this.maxCursor-this.cursor)-1;er.length/2?(t=this.cursor===r.length?r:r.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=i.slice(r,0,this.cursor)}else t=i.concat(this.chunks,this.cursor);return e&&this.reset(),t}}},{"./byte-utils.js":"9dmLv"}],"9dmLv":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&"function"==typeof globalThis.Buffer.isBuffer,n=new TextDecoder,s=new TextEncoder;function o(e){return i&&globalThis.Buffer.isBuffer(e)}function a(e){return e instanceof Uint8Array?o(e)?new Uint8Array(e.buffer,e.byteOffset,e.byteLength):e:Uint8Array.from(e)}const c=i?(e,t,r)=>r-t>64?globalThis.Buffer.from(e.subarray(t,r)).toString("utf8"):m(e,t,r):(e,t,r)=>r-t>64?n.decode(e.subarray(t,r)):m(e,t,r),u=i?e=>e.length>64?globalThis.Buffer.from(e):y(e):e=>e.length>64?s.encode(e):y(e),l=i?(e,t,r)=>o(e)?new Uint8Array(e.subarray(t,r)):e.slice(t,r):(e,t,r)=>e.slice(t,r),d=i?(e,t)=>(e=e.map((e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e))),a(globalThis.Buffer.concat(e,t))):(e,t)=>{const r=new Uint8Array(t);let i=0;for(let t of e)i+t.length>r.length&&(t=t.subarray(0,r.length-i)),r.set(t,i),i+=t.length;return r},f=i?e=>globalThis.Buffer.allocUnsafe(e):e=>new Uint8Array(e),h=i?e=>"string"==typeof e?e:globalThis.Buffer.from(g(e)).toString("hex"):e=>"string"==typeof e?e:Array.prototype.reduce.call(g(e),((e,t)=>`${e}${t.toString(16).padStart(2,"0")}`),""),p=i?e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e,"hex"):e=>e instanceof Uint8Array?e:e.length?new Uint8Array(e.split("").map(((e,t,r)=>t%2==0?`0x${e}${r[t+1]}`:"")).filter(Boolean).map((e=>parseInt(e,16)))):new Uint8Array(0);function g(e){if(e instanceof Uint8Array&&"Uint8Array"===e.constructor.name)return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw new Error("Unknown type, must be binary type")}function y(e,t=1/0){let r;const i=e.length;let n=null;const s=[];for(let o=0;o55295&&r<57344){if(!n){if(r>56319){(t-=3)>-1&&s.push(239,191,189);continue}if(o+1===i){(t-=3)>-1&&s.push(239,191,189);continue}n=r;continue}if(r<56320){(t-=3)>-1&&s.push(239,191,189),n=r;continue}r=65536+(n-55296<<10|r-56320)}else n&&(t-=3)>-1&&s.push(239,191,189);if(n=null,r<128){if((t-=1)<0)break;s.push(r)}else if(r<2048){if((t-=2)<0)break;s.push(r>>6|192,63&r|128)}else if(r<65536){if((t-=3)<0)break;s.push(r>>12|224,r>>6&63|128,63&r|128)}else{if(!(r<1114112))throw new Error("Invalid code point");if((t-=4)<0)break;s.push(r>>18|240,r>>12&63|128,r>>6&63|128,63&r|128)}}return s}function m(e,t,r){const i=[];for(;t239?4:n>223?3:n>191?2:1;if(t+o<=r){let r,i,a,c;switch(o){case 1:n<128&&(s=n);break;case 2:r=e[t+1],128==(192&r)&&(c=(31&n)<<6|63&r,c>127&&(s=c));break;case 3:r=e[t+1],i=e[t+2],128==(192&r)&&128==(192&i)&&(c=(15&n)<<12|(63&r)<<6|63&i,c>2047&&(c<55296||c>57343)&&(s=c));break;case 4:r=e[t+1],i=e[t+2],a=e[t+3],128==(192&r)&&128==(192&i)&&128==(192&a)&&(c=(15&n)<<18|(63&r)<<12|(63&i)<<6|63&a,c>65535&&c<1114112&&(s=c))}}null===s?(s=65533,o=1):s>65535&&(s-=65536,i.push(s>>>10&1023|55296),s=56320|1023&s),i.push(s),t+=o}return b(i)}function b(e){const t=e.length;if(t<=4096)return String.fromCharCode.apply(String,e);let r="",i=0;for(;iUint8Array.from(e),r.fromHex=p,r.fromString=u,r.slice=l,r.toHex=h,r.toString=c,r.useBuffer=i},{}],aoxj4:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i="CBOR decode error:",n=[];n[23]=1,n[24]=2,n[25]=3,n[26]=5,n[27]=9,r.assertEnoughData=function(e,t,r){if(e.length-t>>5}`)}function g(e){return()=>{throw new Error(`${f.decodeErrPrefix} ${e}`)}}const y=[];for(let e=0;e<=23;e++)y[e]=p;y[24]=n.decodeUint8,y[25]=n.decodeUint16,y[26]=n.decodeUint32,y[27]=n.decodeUint64,y[28]=p,y[29]=p,y[30]=p,y[31]=p;for(let e=32;e<=55;e++)y[e]=p;y[56]=s.decodeNegint8,y[57]=s.decodeNegint16,y[58]=s.decodeNegint32,y[59]=s.decodeNegint64,y[60]=p,y[61]=p,y[62]=p,y[63]=p;for(let e=64;e<=87;e++)y[e]=o.decodeBytesCompact;y[88]=o.decodeBytes8,y[89]=o.decodeBytes16,y[90]=o.decodeBytes32,y[91]=o.decodeBytes64,y[92]=p,y[93]=p,y[94]=p,y[95]=g("indefinite length bytes/strings are not supported");for(let e=96;e<=119;e++)y[e]=a.decodeStringCompact;y[120]=a.decodeString8,y[121]=a.decodeString16,y[122]=a.decodeString32,y[123]=a.decodeString64,y[124]=p,y[125]=p,y[126]=p,y[127]=g("indefinite length bytes/strings are not supported");for(let e=128;e<=151;e++)y[e]=c.decodeArrayCompact;y[152]=c.decodeArray8,y[153]=c.decodeArray16,y[154]=c.decodeArray32,y[155]=c.decodeArray64,y[156]=p,y[157]=p,y[158]=p,y[159]=c.decodeArrayIndefinite;for(let e=160;e<=183;e++)y[e]=u.decodeMapCompact;y[184]=u.decodeMap8,y[185]=u.decodeMap16,y[186]=u.decodeMap32,y[187]=u.decodeMap64,y[188]=p,y[189]=p,y[190]=p,y[191]=u.decodeMapIndefinite;for(let e=192;e<=215;e++)y[e]=l.decodeTagCompact;y[216]=l.decodeTag8,y[217]=l.decodeTag16,y[218]=l.decodeTag32,y[219]=l.decodeTag64,y[220]=p,y[221]=p,y[222]=p,y[223]=p;for(let e=224;e<=243;e++)y[e]=g("simple values are not supported");y[244]=p,y[245]=p,y[246]=p,y[247]=d.decodeUndefined,y[248]=g("simple values are not supported"),y[249]=d.decodeFloat16,y[250]=d.decodeFloat32,y[251]=d.decodeFloat64,y[252]=p,y[253]=p,y[254]=p,y[255]=d.decodeBreak;const m=[];for(let e=0;e<24;e++)m[e]=new i.Token(i.Type.uint,e,1);for(let e=-1;e>=-24;e--)m[31-e]=new i.Token(i.Type.negint,e,1);m[64]=new i.Token(i.Type.bytes,new Uint8Array(0),1),m[96]=new i.Token(i.Type.string,"",1),m[128]=new i.Token(i.Type.array,0,1),m[160]=new i.Token(i.Type.map,0,1),m[244]=new i.Token(i.Type.false,!1,1),m[245]=new i.Token(i.Type.true,!0,1),m[246]=new i.Token(i.Type.null,null,1),r.jump=y,r.quick=m,r.quickEncodeToken=function(e){switch(e.type){case i.Type.false:return h.fromArray([244]);case i.Type.true:return h.fromArray([245]);case i.Type.null:return h.fromArray([246]);case i.Type.bytes:return e.value.length?void 0:h.fromArray([64]);case i.Type.string:return""===e.value?h.fromArray([96]):void 0;case i.Type.array:return 0===e.value?h.fromArray([128]):void 0;case i.Type.map:return 0===e.value?h.fromArray([160]):void 0;case i.Type.uint:return e.value<24?h.fromArray([Number(e.value)]):void 0;case i.Type.negint:if(e.value>=-24)return h.fromArray([31-Number(e.value)])}}},{"./token.js":"jVUGz","./0uint.js":"9zilL","./1negint.js":"2sjxL","./2bytes.js":"8Tv7U","./3string.js":"56Ua8","./4array.js":"4ePxQ","./5map.js":"28THk","./6tag.js":"5TCWp","./7float.js":"5T30n","./common.js":"aoxj4","./byte-utils.js":"9dmLv"}],"9zilL":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./common.js");const s=[24,256,65536,4294967296,BigInt("18446744073709551616")];function o(e,t,r){n.assertEnoughData(e,t,1);const i=e[t];if(!0===r.strict&&i>>8,255&i])}else if(r>>24&255,i>>>16&255,i>>>8&255,255&i])}else{const i=BigInt(r);if(!(i>BigInt(32)&BigInt(4294967295));r[8]=255&n,n>>=8,r[7]=255&n,n>>=8,r[6]=255&n,n>>=8,r[5]=255&n,r[4]=255&s,s>>=8,r[3]=255&s,s>>=8,r[2]=255&s,s>>=8,r[1]=255&s,e.push(r)}}}l.encodedSize=function(e){return d.encodedSize(e.value)},d.encodedSize=function(e){return et.value?1:0},r.decodeUint16=function(e,t,r,n){return new i.Token(i.Type.uint,a(e,t+1,n),3)},r.decodeUint32=function(e,t,r,n){return new i.Token(i.Type.uint,c(e,t+1,n),5)},r.decodeUint64=function(e,t,r,n){return new i.Token(i.Type.uint,u(e,t+1,n),9)},r.decodeUint8=function(e,t,r,n){return new i.Token(i.Type.uint,o(e,t+1,n),2)},r.encodeUint=l,r.encodeUintValue=d,r.readUint16=a,r.readUint32=c,r.readUint64=u,r.readUint8=o,r.uintBoundaries=s},{"./token.js":"jVUGz","./common.js":"aoxj4"}],"2sjxL":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./0uint.js"),s=e("./common.js");const o=BigInt(-1),a=BigInt(1);function c(e,t){const r=t.value,i="bigint"==typeof r?r*o-a:-1*r-1;n.encodeUintValue(e,t.type.majorEncoded,i)}c.encodedSize=function(e){const t=e.value,r="bigint"==typeof t?t*o-a:-1*t-1;return rt.value?-1:0},r.decodeNegint16=function(e,t,r,s){return new i.Token(i.Type.negint,-1-n.readUint16(e,t+1,s),3)},r.decodeNegint32=function(e,t,r,s){return new i.Token(i.Type.negint,-1-n.readUint32(e,t+1,s),5)},r.decodeNegint64=function(e,t,r,a){const c=n.readUint64(e,t+1,a);if("bigint"!=typeof c){const e=-1-c;if(e>=Number.MIN_SAFE_INTEGER)return new i.Token(i.Type.negint,e,9)}if(!0!==a.allowBigInt)throw new Error(`${s.decodeErrPrefix} integers outside of the safe integer range are not supported`);return new i.Token(i.Type.negint,o-BigInt(c),9)},r.decodeNegint8=function(e,t,r,s){return new i.Token(i.Type.negint,-1-n.readUint8(e,t+1,s),2)},r.encodeNegint=c},{"./token.js":"jVUGz","./0uint.js":"9zilL","./common.js":"aoxj4"}],"8Tv7U":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./common.js"),s=e("./0uint.js"),o=e("./byte-utils.js");function a(e,t,r,s){n.assertEnoughData(e,t,r+s);const a=o.slice(e,t+r,t+r+s);return new i.Token(i.Type.bytes,a,r+s)}function c(e){return void 0===e.encodedBytes&&(e.encodedBytes=e.type===i.Type.string?o.fromString(e.value):e.value),e.encodedBytes}function u(e,t){const r=c(t);s.encodeUintValue(e,t.type.majorEncoded,r.length),e.push(r)}function l(e,t){return e.lengtht.length?1:o.compare(e,t)}u.encodedSize=function(e){const t=c(e);return s.encodeUintValue.encodedSize(t.length)+t.length},u.compareTokens=function(e,t){return l(c(e),c(t))},r.compareBytes=l,r.decodeBytes16=function(e,t,r,i){return a(e,t,3,s.readUint16(e,t+1,i))},r.decodeBytes32=function(e,t,r,i){return a(e,t,5,s.readUint32(e,t+1,i))},r.decodeBytes64=function(e,t,r,i){const o=s.readUint64(e,t+1,i);if("bigint"==typeof o)throw new Error(`${n.decodeErrPrefix} 64-bit integer bytes lengths not supported`);return a(e,t,9,o)},r.decodeBytes8=function(e,t,r,i){return a(e,t,2,s.readUint8(e,t+1,i))},r.decodeBytesCompact=function(e,t,r,i){return a(e,t,1,r)},r.encodeBytes=u},{"./token.js":"jVUGz","./common.js":"aoxj4","./0uint.js":"9zilL","./byte-utils.js":"9dmLv"}],"56Ua8":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./common.js"),s=e("./0uint.js"),o=e("./2bytes.js"),a=e("./byte-utils.js");function c(e,t,r,s){const o=r+s;return n.assertEnoughData(e,t,o),new i.Token(i.Type.string,a.toString(e,t+r,t+o),o)}const u=o.encodeBytes;r.decodeString16=function(e,t,r,i){return c(e,t,3,s.readUint16(e,t+1,i))},r.decodeString32=function(e,t,r,i){return c(e,t,5,s.readUint32(e,t+1,i))},r.decodeString64=function(e,t,r,i){const o=s.readUint64(e,t+1,i);if("bigint"==typeof o)throw new Error(`${n.decodeErrPrefix} 64-bit integer string lengths not supported`);return c(e,t,9,o)},r.decodeString8=function(e,t,r,i){return c(e,t,2,s.readUint8(e,t+1,i))},r.decodeStringCompact=function(e,t,r,i){return c(e,t,1,r)},r.encodeString=u},{"./token.js":"jVUGz","./common.js":"aoxj4","./0uint.js":"9zilL","./2bytes.js":"8Tv7U","./byte-utils.js":"9dmLv"}],"4ePxQ":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./0uint.js"),s=e("./common.js");function o(e,t,r,n){return new i.Token(i.Type.array,n,r)}function a(e,t){n.encodeUintValue(e,i.Type.array.majorEncoded,t.value)}a.compareTokens=n.encodeUint.compareTokens,r.decodeArray16=function(e,t,r,i){return o(0,0,3,n.readUint16(e,t+1,i))},r.decodeArray32=function(e,t,r,i){return o(0,0,5,n.readUint32(e,t+1,i))},r.decodeArray64=function(e,t,r,i){const a=n.readUint64(e,t+1,i);if("bigint"==typeof a)throw new Error(`${s.decodeErrPrefix} 64-bit integer array lengths not supported`);return o(0,0,9,a)},r.decodeArray8=function(e,t,r,i){return o(0,0,2,n.readUint8(e,t+1,i))},r.decodeArrayCompact=function(e,t,r,i){return o(0,0,1,r)},r.decodeArrayIndefinite=function(e,t,r,i){if(!1===i.allowIndefinite)throw new Error(`${s.decodeErrPrefix} indefinite length items not allowed`);return o(0,0,1,1/0)},r.encodeArray=a},{"./token.js":"jVUGz","./0uint.js":"9zilL","./common.js":"aoxj4"}],"28THk":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./0uint.js"),s=e("./common.js");function o(e,t,r,n){return new i.Token(i.Type.map,n,r)}function a(e,t){n.encodeUintValue(e,i.Type.map.majorEncoded,t.value)}a.compareTokens=n.encodeUint.compareTokens,r.decodeMap16=function(e,t,r,i){return o(0,0,3,n.readUint16(e,t+1,i))},r.decodeMap32=function(e,t,r,i){return o(0,0,5,n.readUint32(e,t+1,i))},r.decodeMap64=function(e,t,r,i){const a=n.readUint64(e,t+1,i);if("bigint"==typeof a)throw new Error(`${s.decodeErrPrefix} 64-bit integer map lengths not supported`);return o(0,0,9,a)},r.decodeMap8=function(e,t,r,i){return o(0,0,2,n.readUint8(e,t+1,i))},r.decodeMapCompact=function(e,t,r,i){return o(0,0,1,r)},r.decodeMapIndefinite=function(e,t,r,i){if(!1===i.allowIndefinite)throw new Error(`${s.decodeErrPrefix} indefinite length items not allowed`);return o(0,0,1,1/0)},r.encodeMap=a},{"./token.js":"jVUGz","./0uint.js":"9zilL","./common.js":"aoxj4"}],"5TCWp":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./0uint.js");function s(e,t){n.encodeUintValue(e,i.Type.tag.majorEncoded,t.value)}s.compareTokens=n.encodeUint.compareTokens,r.decodeTag16=function(e,t,r,s){return new i.Token(i.Type.tag,n.readUint16(e,t+1,s),3)},r.decodeTag32=function(e,t,r,s){return new i.Token(i.Type.tag,n.readUint32(e,t+1,s),5)},r.decodeTag64=function(e,t,r,s){return new i.Token(i.Type.tag,n.readUint64(e,t+1,s),9)},r.decodeTag8=function(e,t,r,s){return new i.Token(i.Type.tag,n.readUint8(e,t+1,s),2)},r.decodeTagCompact=function(e,t,r,n){return new i.Token(i.Type.tag,r,1)},r.encodeTag=s},{"./token.js":"jVUGz","./0uint.js":"9zilL"}],"5T30n":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./token.js"),n=e("./common.js"),s=e("./0uint.js");function o(e,t,r){if(r){if(!1===r.allowNaN&&Number.isNaN(e))throw new Error(`${n.decodeErrPrefix} NaN values are not supported`);if(!1===r.allowInfinity&&(e===1/0||e===-1/0))throw new Error(`${n.decodeErrPrefix} Infinity values are not supported`)}return new i.Token(i.Type.float,e,t)}function a(e,t,r){const n=t.value;if(!1===n)e.push([20|i.Type.float.majorEncoded]);else if(!0===n)e.push([21|i.Type.float.majorEncoded]);else if(null===n)e.push([22|i.Type.float.majorEncoded]);else if(void 0===n)e.push([23|i.Type.float.majorEncoded]);else{let t,i=!1;r&&!0===r.float64||(d(n),t=f(l,1),n===t||Number.isNaN(n)?(l[0]=249,e.push(l.slice(0,3)),i=!0):(h(n),t=p(l,1),n===t&&(l[0]=250,e.push(l.slice(0,5)),i=!0))),i||(s=n,u.setFloat64(0,s,!1),t=g(l,1),l[0]=251,e.push(l.slice(0,9)))}var s}a.encodedSize=function(e,t){const r=e.value;if(!1===r||!0===r||null==r)return 1;let i;if(!t||!0!==t.float64){if(d(r),i=f(l,1),r===i||Number.isNaN(r))return 3;if(h(r),i=p(l,1),r===i)return 5}return 9};const c=new ArrayBuffer(9),u=new DataView(c,1),l=new Uint8Array(c,0);function d(e){if(e===1/0)u.setUint16(0,31744,!1);else if(e===-1/0)u.setUint16(0,64512,!1);else if(Number.isNaN(e))u.setUint16(0,32256,!1);else{u.setFloat32(0,e);const t=u.getUint32(0),r=(2139095040&t)>>23,i=8388607&t;if(255===r)u.setUint16(0,31744,!1);else if(0===r)u.setUint16(0,(2147483648&e)>>16|i>>13,!1);else{const e=r-127;e<-24?u.setUint16(0,0):e<-14?u.setUint16(0,(2147483648&t)>>16|1<<24+e,!1):u.setUint16(0,(2147483648&t)>>16|e+15<<10|i>>13,!1)}}}function f(e,t){if(e.length-t<2)throw new Error(`${n.decodeErrPrefix} not enough data for float16`);const r=(e[t]<<8)+e[t+1];if(31744===r)return 1/0;if(64512===r)return-1/0;if(32256===r)return NaN;const i=r>>10&31,s=1023&r;let o;return o=0===i?s*2**-24:31!==i?(s+1024)*2**(i-25):0===s?1/0:NaN,32768&r?-o:o}function h(e){u.setFloat32(0,e,!1)}function p(e,t){if(e.length-t<4)throw new Error(`${n.decodeErrPrefix} not enough data for float32`);const r=(e.byteOffset||0)+t;return new DataView(e.buffer,r,4).getFloat32(0,!1)}function g(e,t){if(e.length-t<8)throw new Error(`${n.decodeErrPrefix} not enough data for float64`);const r=(e.byteOffset||0)+t;return new DataView(e.buffer,r,8).getFloat64(0,!1)}a.compareTokens=s.encodeUint.compareTokens,r.decodeBreak=function(e,t,r,s){if(!1===s.allowIndefinite)throw new Error(`${n.decodeErrPrefix} indefinite length items not allowed`);return new i.Token(i.Type.break,void 0,1)},r.decodeFloat16=function(e,t,r,i){return o(f(e,t+1),3,i)},r.decodeFloat32=function(e,t,r,i){return o(p(e,t+1),5,i)},r.decodeFloat64=function(e,t,r,i){return o(g(e,t+1),9,i)},r.decodeUndefined=function(e,t,r,s){if(!1===s.allowUndefined)throw new Error(`${n.decodeErrPrefix} undefined values are not supported`);return new i.Token(i.Type.undefined,void 0,1)},r.encodeFloat=a},{"./token.js":"jVUGz","./common.js":"aoxj4","./0uint.js":"9zilL"}],dbDwZ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./common.js"),n=e("./token.js"),s=e("./jump.js");const o={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0};class a{constructor(e,t={}){this.pos=0,this.data=e,this.options=t}done(){return this.pos>=this.data.length}next(){const e=this.data[this.pos];let t=s.quick[e];if(void 0===t){const r=s.jump[e];if(!r)throw new Error(`${i.decodeErrPrefix} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);const n=31&e;t=r(this.data,this.pos,n,this.options)}return this.pos+=t.encodedLength,t}}const c=Symbol.for("DONE"),u=Symbol.for("BREAK");function l(e,t){if(e.done())return c;const r=e.next();if(r.type===n.Type.break)return u;if(r.type.terminal)return r.value;if(r.type===n.Type.array)return function(e,t,r){const n=[];for(let s=0;sn.coerce(e)});r.identity=s},{"./hasher.js":"5z3Qi","../bytes.js":"6I0Ku"}],"5z3Qi":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./digest.js");class n{constructor(e,t,r){this.name=e,this.code=t,this.encode=r}async digest(e){if(e instanceof Uint8Array){const t=await this.encode(e);return i.create(this.code,t)}throw Error("Unknown type, must be binary type")}}r.Hasher=n,r.from=({name:e,code:t,encode:r})=>new n(e,t,r)},{"./digest.js":"kpRBg"}],lPcQG:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./bases/identity.js"),n=e("./bases/base2.js"),s=e("./bases/base8.js"),o=e("./bases/base10.js"),a=e("./bases/base16.js"),c=e("./bases/base32.js"),u=e("./bases/base36.js"),l=e("./bases/base58.js"),d=e("./bases/base64.js"),f=e("./hashes/sha2.js"),h=e("./hashes/identity.js"),p=e("./codecs/raw.js"),g=e("./codecs/json.js");e("./index.js");var y=e("./cid.js"),m=e("./hashes/hasher.js"),b=e("./hashes/digest.js"),v=e("./varint.js"),w=e("./bytes.js");const _={...i,...n,...s,...o,...a,...c,...u,...l,...d},E={...f,...h},S={raw:p,json:g};r.CID=y.CID,r.hasher=m,r.digest=b,r.varint=v,r.bytes=w,r.bases=_,r.codecs=S,r.hashes=E},{"./bases/identity.js":"4EVux","./bases/base2.js":"5EiC2","./bases/base8.js":"bGEV7","./bases/base10.js":"esjPe","./bases/base16.js":"iQzgO","./bases/base32.js":"5k9Tu","./bases/base36.js":"7VmDr","./bases/base58.js":"4n7mA","./bases/base64.js":"gaFBW","./hashes/sha2.js":"7i9MT","./hashes/identity.js":"eYCZn","./codecs/raw.js":"fdfgp","./codecs/json.js":"cRmep","./index.js":"3ANyW","./cid.js":"9ooAY","./hashes/hasher.js":"5z3Qi","./hashes/digest.js":"kpRBg","./varint.js":"ivDPm","./bytes.js":"6I0Ku"}],"4EVux":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js"),n=e("../bytes.js");const s=i.from({prefix:"\0",name:"identity",encode:e=>n.toString(e),decode:e=>n.fromString(e)});r.identity=s},{"./base.js":"6uTk1","../bytes.js":"6I0Ku"}],"5EiC2":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./base.js").rfc4648({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});r.base2=i},{"./base.js":"6uTk1"}],bGEV7:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./base.js").rfc4648({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});r.base8=i},{"./base.js":"6uTk1"}],esjPe:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./base.js").baseX({prefix:"9",name:"base10",alphabet:"0123456789"});r.base10=i},{"./base.js":"6uTk1"}],iQzgO:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js");const n=i.rfc4648({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),s=i.rfc4648({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});r.base16=n,r.base16upper=s},{"./base.js":"6uTk1"}],"7VmDr":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js");const n=i.baseX({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),s=i.baseX({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});r.base36=n,r.base36upper=s},{"./base.js":"6uTk1"}],gaFBW:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js");const n=i.rfc4648({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),s=i.rfc4648({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),o=i.rfc4648({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),a=i.rfc4648({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});r.base64=n,r.base64pad=s,r.base64url=o,r.base64urlpad=a},{"./base.js":"6uTk1"}],"7i9MT":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./hasher.js");const n=e=>async t=>new Uint8Array(await crypto.subtle.digest(e,t)),s=i.from({name:"sha2-256",code:18,encode:n("SHA-256")}),o=i.from({name:"sha2-512",code:19,encode:n("SHA-512")});r.sha256=s,r.sha512=o},{"./hasher.js":"5z3Qi"}],fdfgp:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../bytes.js");r.code=85,r.decode=e=>i.coerce(e),r.encode=e=>i.coerce(e),r.name="raw"},{"../bytes.js":"6I0Ku"}],cRmep:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=new TextEncoder,n=new TextDecoder;r.code=512,r.decode=e=>JSON.parse(n.decode(e)),r.encode=e=>i.encode(JSON.stringify(e)),r.name="json"},{}],"3ANyW":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./cid.js"),n=e("./varint.js"),s=e("./bytes.js"),o=e("./hashes/hasher.js"),a=e("./hashes/digest.js");r.CID=i.CID,r.varint=n,r.bytes=s,r.hasher=o,r.digest=a},{"./cid.js":"9ooAY","./varint.js":"ivDPm","./bytes.js":"6I0Ku","./hashes/hasher.js":"5z3Qi","./hashes/digest.js":"kpRBg"}],d1lP3:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.initAssets=function(){}},{}],j69o8:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});class i extends Error{constructor(e="not initialized"){super(e),this.name="NotInitializedError",this.code=i.code}}i.code="ERR_NOT_INITIALIZED";class n extends Error{constructor(e="cannot initialize an initializing node"){super(e),this.name="AlreadyInitializingError",this.code=s.code}}n.code="ERR_ALREADY_INITIALIZING";class s extends Error{constructor(e="cannot re-initialize an initialized node"){super(e),this.name="AlreadyInitializedError",this.code=s.code}}s.code="ERR_ALREADY_INITIALIZED";class o extends Error{constructor(e="not started"){super(e),this.name="NotStartedError",this.code=o.code}}o.code="ERR_NOT_STARTED";class a extends Error{constructor(e="cannot start, already startin"){super(e),this.name="AlreadyStartingError",this.code=a.code}}a.code="ERR_ALREADY_STARTING";class c extends Error{constructor(e="cannot start, already started"){super(e),this.name="AlreadyStartedError",this.code=c.code}}c.code="ERR_ALREADY_STARTED";class u extends Error{constructor(e="not enabled"){super(e),this.name="NotEnabledError",this.code=u.code}}u.code="ERR_NOT_ENABLED",r.AlreadyInitializedError=s,r.AlreadyInitializingError=n,r.AlreadyStartedError=c,r.AlreadyStartingError=a,r.NotEnabledError=u,r.NotInitializedError=i,r.NotStartedError=o},{}],dF7Y4:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./util/bases.js");r.fromString=function(e,t="utf8"){const r=i[t];if(!r)throw new Error(`Unsupported encoding "${t}"`);return r.decoder.decode(`${r.prefix}${e}`)}},{"./util/bases.js":"6UNPX"}],"6UNPX":[function(e,t,r){"use strict";var i=e("multiformats/basics");function n(e,t,r,i){return{name:e,prefix:t,encoder:{name:e,prefix:t,encode:r},decoder:{decode:i}}}const s=n("utf8","u",(e=>"u"+new TextDecoder("utf8").decode(e)),(e=>(new TextEncoder).encode(e.substring(1)))),o=n("ascii","a",(e=>{let t="a";for(let r=0;r{e=e.substring(1);const t=new Uint8Array(e.length);for(let r=0;r{const{libp2p:l}=await i.Service.start(e,{peerId:r,repo:s,print:c,options:u});await Promise.all([o.startOnline({keychain:n,libp2p:l,peerId:r,repo:s}),t.start(),a.start()])}}},{"../utils/service.js":"ethcf"}],ethcf:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../errors.js"),n=e("../utils.js");class s{static create({start:e,stop:t}){return new s(e,t)}static async start(e,t){const{state:r,activate:n}=e;switch(r.status){case"stopped":try{const r=n(t);e.state={status:"starting",ready:r};const i=await r;return e.state={status:"started",value:i},i}catch(t){throw e.state={status:"stopped"},t}case"starting":throw new i.AlreadyStartingError;case"started":throw new i.AlreadyStartedError;case"stopping":return await r.ready,await s.start(e,t);default:return s.panic(e)}}static async stop(e){const{state:t,deactivate:r}=e;switch(t.status){case"stopped":break;case"starting":try{await t.ready}catch(e){}return await s.stop(e);case"stopping":return await t.ready;case"started":r&&await r(t.value),e.state={status:"stopped"};break;default:s.panic(t)}}static try({state:e}){return"started"===e.status?e.value:null}static async use({state:e},t){switch(e.status){case"started":return e.value;case"starting":return await n.withTimeout(e.ready,t);default:throw new i.NotStartedError}}static panic({state:e}){const t=JSON.stringify({status:e.status});throw RangeError(`Service in invalid state ${t}, should never happen if you see this please report a bug`)}constructor(e,t){this.activate=e,this.deactivate=t,this.state={status:"stopped"}}async use(e){return await s.use(this,e)}try(){return s.try(this)}}r.Service=s},{"../errors.js":"j69o8","../utils.js":"cT4uN"}],cT4uN:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("is-ipfs"),n=e("multiformats/cid"),s=e("interface-datastore/key"),o=e("err-code"),a=e("ipfs-core-utils/with-timeout-option"),c=e("ipfs-core-utils/to-cid-and-path"),u=e("@ipld/dag-pb");function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function d(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var f=l(i),h=l(o),p=d(u);const g=new s.Key("/local/filesroot"),y=a.withTimeoutOption((async(e,t)=>await e)),m=async function*(e,t,r,i,s){const o=async e=>{const t=await r.getCodec(e.code),n=await i.blocks.get(e,s);return t.decode(n)},a=t.split("/").filter(Boolean);let c=await o(e),u=e;for(a.length||(yield{value:c,remainderPath:""});a.length;){const r=a.shift();if(!r)throw h.default(new Error(`Could not resolve path "${t}"`),"ERR_INVALID_PATH");if(e.code===p.code&&Array.isArray(c.Links)){const e=c.Links.find((e=>e.Name===r));if(e){yield{value:e.Hash,remainderPath:a.join("/")},c=await o(e.Hash),u=e.Hash;continue}}if(!Object.prototype.hasOwnProperty.call(c,r))throw h.default(new Error(`no link named "${r}" under ${u}`),"ERR_NO_LINK");c=c[r],yield{value:c,remainderPath:a.join("/")},n.CID.asCID(c)&&(u=c,c=await o(c))}};r.MFS_MAX_CHUNK_SIZE=262144,r.MFS_MAX_LINKS=174,r.MFS_ROOT_KEY=g,r.OFFLINE_ERROR="This command must be run in online mode. Try running 'ipfs daemon' first.",r.mapFile=e=>{if("file"!==e.type&&"directory"!==e.type&&"raw"!==e.type)throw new Error(`Unknown node type '${e.type}'`);const t={cid:e.cid,path:e.path,name:e.name,size:e.size,type:"file"};return"directory"===e.type&&(t.type="dir"),"file"===e.type&&(t.size=e.unixfs.fileSize()),"file"!==e.type&&"directory"!==e.type||(t.mode=e.unixfs.mode,void 0!==e.unixfs.mtime&&(t.mtime=e.unixfs.mtime)),t},r.normalizeCidPath=e=>e instanceof Uint8Array?n.CID.decode(e).toString():(0===(e=e.toString()).indexOf("/ipfs/")&&(e=e.substring(6)),"/"===e.charAt(e.length-1)&&(e=e.substring(0,e.length-1)),e),r.normalizePath=e=>{if(n.CID.asCID(e))return`/ipfs/${e}`;const t=e.toString();try{return`/ipfs/${n.CID.parse(t)}`}catch{}if(f.default.path(t))return t;throw h.default(new Error(`invalid path: ${e}`),"ERR_BAD_PATH")},r.resolve=m,r.resolvePath=async function(e,t,r,i={}){const{cid:s,path:o}=c.toCidAndPath(r);o&&(i.path=o);let a=s,u=i.path||"";if(u.startsWith("/")&&(u=u.substring(1)),i.path)try{for await(const{value:r,remainderPath:o}of m(s,i.path,t,e,{signal:i.signal})){if(!n.CID.asCID(r))break;u=o,a=r}}catch(e){throw e.message.startsWith("Object has no property")&&(e.message=`no link named "${u.split("/")[0]}" under ${a}`,e.code="ERR_NO_LINK"),e}return{cid:a,remainderPath:u||""}},r.withTimeout=y},{"is-ipfs":"40iuV","multiformats/cid":"9ooAY","interface-datastore/key":"9hGOz","err-code":"chZjB","ipfs-core-utils/with-timeout-option":"j29MK","ipfs-core-utils/to-cid-and-path":"jN5CZ","@ipld/dag-pb":"i2cdx"}],"40iuV":[function(e,t,r){"use strict";const{base58btc:i}=e("multiformats/bases/base58"),{base32:n}=e("multiformats/bases/base32"),s=e("multiformats/hashes/digest"),{Multiaddr:o}=e("multiaddr"),a=e("mafmt"),{CID:c}=e("multiformats/cid"),{URL:u}=e("iso-url"),{toString:l}=e("uint8arrays/to-string"),d=/^https?:\/\/[^/]+\/(ip[fn]s)\/([^/?#]+)/,f=/^\/(ip[fn]s)\/([^/?#]+)/,h=/^https?:\/\/([^/]+)\.(ip[fn]s)\.[^/?]+/,p=/^(([a-z0-9]|[a-z0-9][a-z0-9-]*[a-z0-9])\.)+([a-z0-9]|[a-z0-9][a-z0-9-]*[a-z0-9])$/;function g(e){try{return"string"==typeof e?Boolean(c.parse(e)):e instanceof Uint8Array?Boolean(c.decode(e)):Boolean(c.asCID(e))}catch(e){return!1}}function y(e){if(!e)return!1;if(o.isMultiaddr(e))return!0;try{return new o(e),!0}catch(e){return!1}}function m(e,t,r=1,i=2){const n=w(e);if(!n)return!1;const s=n.match(t);if(!s)return!1;if("ipfs"!==s[r])return!1;let o=s[i];return o&&t===h&&(o=o.toLowerCase()),g(o)}function b(e,t,r=1,i=2){const n=w(e);if(!n)return!1;const s=n.match(t);if(!s)return!1;if("ipns"!==s[r])return!1;let o=s[i];if(o&&t===h){if(o=o.toLowerCase(),g(o))return!0;try{!o.includes(".")&&o.includes("-")&&(o=o.replace(/--/g,"@").replace(/-/g,".").replace(/@/g,"-"));const{hostname:e}=new u(`http://${o}`);return p.test(e)}catch(e){return!1}}return!0}function v(e){return"string"==typeof e}function w(e){return e instanceof Uint8Array?l(e,"base58btc"):!!v(e)&&e}const _=e=>m(e,h,2,1),E=e=>b(e,h,2,1),S=e=>_(e)||E(e),T=e=>m(e,d)||_(e),A=e=>b(e,d)||E(e),k=e=>T(e)||A(e)||S(e),I=e=>m(e,f)||b(e,f);t.exports={multihash:function(e){const t=w(e);try{s.decode(i.decode("z"+t))}catch{return!1}return!0},multiaddr:y,peerMultiaddr:function(e){return y(e)&&a.P2P.matches(e)},cid:g,base32cid:e=>function(e){try{n.decode(e)}catch{return!1}return!0}(e)&&g(e),ipfsSubdomain:_,ipnsSubdomain:E,subdomain:S,subdomainGatewayPattern:h,ipfsUrl:T,ipnsUrl:A,url:k,pathGatewayPattern:d,ipfsPath:e=>m(e,f),ipnsPath:e=>b(e,f),path:I,pathPattern:f,urlOrPath:e=>k(e)||I(e),cidPath:e=>v(e)&&!g(e)&&m(`/ipfs/${e}`,f)}},{"multiformats/bases/base58":"4n7mA","multiformats/bases/base32":"5k9Tu","multiformats/hashes/digest":"kpRBg",multiaddr:"8Mu1u",mafmt:"l1lok","multiformats/cid":"9ooAY","iso-url":"86VPZ","uint8arrays/to-string":"hC8JB"}],"8Mu1u":[function(e,t,r){"use strict";const i=e("./codec"),n=e("./protocols-table"),s=e("varint"),{CID:o}=e("multiformats/cid"),{base58btc:a}=e("multiformats/bases/base58"),c=e("err-code"),u=Symbol.for("nodejs.util.inspect.custom"),{toString:l}=e("uint8arrays/to-string"),{equals:d}=e("uint8arrays/equals"),f=new Map,h=Symbol.for("@multiformats/js-multiaddr/multiaddr");class p{constructor(e){if(null==e&&(e=""),Object.defineProperty(this,h,{value:!0}),e instanceof Uint8Array)this.bytes=i.fromBytes(e);else if("string"==typeof e){if(e.length>0&&"/"!==e.charAt(0))throw new Error(`multiaddr "${e}" must start with a "/"`);this.bytes=i.fromString(e)}else{if(!p.isMultiaddr(e))throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=i.fromBytes(e.bytes)}}toString(){return i.bytesToString(this.bytes)}toJSON(){return this.toString()}toOptions(){const e={},t=this.toString().split("/");return e.family="ip4"===t[1]?4:6,e.host=t[2],e.transport=t[3],e.port=parseInt(t[4]),e}protos(){return this.protoCodes().map((e=>Object.assign({},n(e))))}protoCodes(){const e=[],t=this.bytes;let r=0;for(;re.name))}tuples(){return i.bytesToTuples(this.bytes)}stringTuples(){const e=i.bytesToTuples(this.bytes);return i.tuplesToStringTuples(e)}encapsulate(e){return e=new p(e),new p(this.toString()+e.toString())}decapsulate(e){const t=e.toString(),r=this.toString(),i=r.lastIndexOf(t);if(i<0)throw new Error("Address "+this+" does not contain subaddress: "+e);return new p(r.slice(0,i))}decapsulateCode(e){const t=this.tuples();for(let r=t.length-1;r>=0;r--)if(t[r][0]===e)return new p(i.tuplesToBytes(t.slice(0,r)));return this}getPeerId(){try{const e=this.stringTuples().filter((e=>e[0]===n.names.ipfs.code)).pop();if(e&&e[1]){const t=e[1];return"Q"===t[0]||"1"===t[0]?l(a.decode(`z${t}`),"base58btc"):l(o.parse(t).multihash.bytes,"base58btc")}return null}catch(e){return null}}getPath(){let e=null;try{e=this.stringTuples().filter((e=>!!n(e[0]).path))[0][1],e||(e=null)}catch(t){e=null}return e}equals(e){return d(this.bytes,e.bytes)}async resolve(){const e=this.protos().find((e=>e.resolvable));if(!e)return[this];const t=f.get(e.name);if(!t)throw c(new Error(`no available resolver for ${e.name}`),"ERR_NO_AVAILABLE_RESOLVER");return(await t(this)).map((e=>new p(e)))}nodeAddress(){const e=this.protoCodes(),t=this.protoNames(),r=this.toString().split("/").slice(1);if(r.length<4)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6}/{address}/{tcp, udp}/{port}".');if(4!==e[0]&&41!==e[0]&&54!==e[0]&&55!==e[0])throw new Error(`no protocol with name: "'${t[0]}'". Must have a valid family name: "{ip4, ip6, dns4, dns6}".`);if("tcp"!==r[2]&&"udp"!==r[2])throw new Error(`no protocol with name: "'${t[1]}'". Must have a valid transport protocol: "{tcp, udp}".`);return{family:41===e[0]||55===e[0]?6:4,address:r[1],port:parseInt(r[3])}}isThinWaistAddress(e){const t=(e||this).protos();return 2===t.length&&((4===t[0].code||41===t[0].code)&&(6===t[1].code||273===t[1].code))}static fromNodeAddress(e,t){if(!e)throw new Error("requires node address object");if(!t)throw new Error("requires transport protocol");let r;switch(e.family){case 4:r="ip4";break;case 6:r="ip6";break;default:throw Error(`Invalid addr family. Got '${e.family}' instead of 4 or 6`)}return new p("/"+[r,e.address,t,e.port].join("/"))}static isName(e){return!!p.isMultiaddr(e)&&e.protos().some((e=>e.resolvable))}static isMultiaddr(e){return e instanceof p||Boolean(e&&e[h])}[u](){return""}inspect(){return""}}p.protocols=n,p.resolvers=f,t.exports={Multiaddr:p,multiaddr:function(e){return new p(e)},protocols:n,resolvers:f}},{"./codec":"heFUu","./protocols-table":"5Z4cQ",varint:"aN1CO","multiformats/cid":"9ooAY","multiformats/bases/base58":"4n7mA","err-code":"chZjB","uint8arrays/to-string":"hC8JB","uint8arrays/equals":"eY3cX"}],heFUu:[function(e,t,r){"use strict";const i=e("./convert"),n=e("./protocols-table"),s=e("varint"),{concat:o}=e("uint8arrays/concat"),{toString:a}=e("uint8arrays/to-string");function c(e){const t=[],r=e.split("/").slice(1);if(1===r.length&&""===r[0])return[];for(let i=0;i=r.length)throw v("invalid address: "+e);if(o.path){t.push([s,b(r.slice(i).join("/"))]);break}t.push([s,r[i]])}else t.push([s])}return t}function u(e){const t=[];return e.map((e=>{const r=w(e);return t.push(r.name),e.length>1&&t.push(e[1]),null})),b(t.join("/"))}function l(e){return e.map((e=>{Array.isArray(e)||(e=[e]);const t=w(e);return e.length>1?[t.code,i.toBytes(t.code,e[1])]:[t.code]}))}function d(e){return e.map((e=>{const t=w(e);return e[1]?[t.code,i.toString(t.code,e[1])]:[t.code]}))}function f(e){return y(o(e.map((e=>{const t=w(e);let r=Uint8Array.from(s.encode(t.code));return e.length>1&&(r=o([r,e[1]])),r}))))}function h(e,t){if(e.size>0)return e.size/8;if(0===e.size)return 0;return s.decode(t)+s.decode.bytes}function p(e){const t=[];let r=0;for(;re.length)throw v("Invalid address Uint8Array: "+a(e,"base16"));t.push([i,u])}return t}function g(e){return f(l(c(e=b(e))))}function y(e){const t=m(e);if(t)throw t;return Uint8Array.from(e)}function m(e){try{p(e)}catch(e){return e}}function b(e){return"/"+e.trim().split("/").filter((e=>e)).join("/")}function v(e){return new Error("Error parsing address: "+e)}function w(e){return n(e[0])}t.exports={stringToStringTuples:c,stringTuplesToString:u,tuplesToStringTuples:d,stringTuplesToTuples:l,bytesToTuples:p,tuplesToBytes:f,bytesToString:function(e){const t=p(e);return u(d(t))},stringToBytes:g,fromString:function(e){return g(e)},fromBytes:y,validateBytes:m,isValidBytes:function(e){return void 0===m(e)},cleanPath:b,ParseError:v,protoFromTuple:w,sizeForAddr:h}},{"./convert":"gfu3m","./protocols-table":"5Z4cQ",varint:"aN1CO","uint8arrays/concat":"4EBjG","uint8arrays/to-string":"hC8JB"}],gfu3m:[function(e,t,r){"use strict";const i=e("./ip"),n=e("./protocols-table"),{CID:s}=e("multiformats/cid"),{base32:o}=e("multiformats/bases/base32"),{base58btc:a}=e("multiformats/bases/base58"),c=e("multiformats/hashes/digest"),u=e("varint"),{toString:l}=e("uint8arrays/to-string"),{fromString:d}=e("uint8arrays/from-string"),{concat:f}=e("uint8arrays/concat");function h(e,t){return t instanceof Uint8Array?h.toString(e,t):h.toBytes(e,t)}function p(e){if(!i.isIP(e))throw new Error("invalid ip address");return i.toBytes(e)}function g(e){const t=new ArrayBuffer(2);return new DataView(t).setUint16(0,e),new Uint8Array(t)}function y(e){return new DataView(e.buffer).getUint16(e.byteOffset)}function m(e){const t=e.slice(0,e.length-2),r=e.slice(e.length-2);return l(t,"base32")+":"+y(r)}t.exports=h,h.toString=function(e,t){switch(n(e).code){case 4:case 41:return function(e){const t=i.toString(e);if(!t||!i.isIP(t))throw new Error("invalid ip address");return t}(t);case 6:case 273:case 33:case 132:return y(t).toString();case 53:case 54:case 55:case 56:case 400:case 777:return function(e){const t=u.decode(e);if((e=e.slice(u.decode.bytes)).length!==t)throw new Error("inconsistent lengths");return l(e)}(t);case 421:return function(e){const t=u.decode(e),r=e.slice(u.decode.bytes);if(r.length!==t)throw new Error("inconsistent lengths");return l(r,"base58btc")}(t);case 444:case 445:return m(t);default:return l(t,"base16")}},h.toBytes=function(e,t){switch(n(e).code){case 4:case 41:return p(t);case 6:case 273:case 33:case 132:return g(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 777:return function(e){const t=d(e),r=Uint8Array.from(u.encode(t.length));return f([r,t],r.length+t.length)}(t);case 421:return function(e){let t;t="Q"===e[0]||"1"===e[0]?c.decode(a.decode(`z${e}`)).bytes:s.parse(e).multihash.bytes;const r=Uint8Array.from(u.encode(t.length));return f([r,t],r.length+t.length)}(t);case 444:return function(e){const t=e.split(":");if(2!==t.length)throw new Error("failed to parse onion addr: "+t+" does not contain a port number");if(16!==t[0].length)throw new Error("failed to parse onion addr: "+t[0]+" not a Tor onion address.");const r=o.decode("b"+t[0]),i=parseInt(t[1],10);if(i<1||i>65536)throw new Error("Port number is not in range(1, 65536)");const n=g(i);return f([r,n],r.length+n.length)}(t);case 445:return function(e){const t=e.split(":");if(2!==t.length)throw new Error("failed to parse onion addr: "+t+" does not contain a port number");if(56!==t[0].length)throw new Error("failed to parse onion addr: "+t[0]+" not a Tor onion3 address.");const r=o.decode("b"+t[0]),i=parseInt(t[1],10);if(i<1||i>65536)throw new Error("Port number is not in range(1, 65536)");const n=g(i);return f([r,n],r.length+n.length)}(t);default:return d(t,"base16")}}},{"./ip":"dqiuc","./protocols-table":"5Z4cQ","multiformats/cid":"9ooAY","multiformats/bases/base32":"5k9Tu","multiformats/bases/base58":"4n7mA","multiformats/hashes/digest":"kpRBg",varint:"aN1CO","uint8arrays/to-string":"hC8JB","uint8arrays/from-string":"dF7Y4","uint8arrays/concat":"4EBjG"}],dqiuc:[function(e,t,r){"use strict";const i=e("is-ip"),{toString:n}=e("uint8arrays/to-string"),s=i,o=i.v4,a=i.v6,c=function(e,t,r){let i;if(r=~~r,o(e))i=t||new Uint8Array(r+4),e.split(/\./g).map((function(e){i[r++]=255&parseInt(e,10)}));else if(a(e)){const s=e.split(":",8);let a;for(a=0;a0;a--)e.push("0");s.splice.apply(s,e)}for(i=t||new Uint8Array(r+16),a=0;a>8&255,i[r++]=255&e}}if(!i)throw Error("Invalid ip address: "+e);return i};t.exports={isIP:s,isV4:o,isV6:a,toBytes:c,toString:function(e,t,r){t=~~t,r=r||e.length-t;const i=[];let n;const s=new DataView(e.buffer);if(4===r){for(let n=0;ni({exact:!0}).test(e);n.v4=e=>i.v4({exact:!0}).test(e),n.v6=e=>i.v6({exact:!0}).test(e),n.version=e=>n(e)?n.v4(e)?4:6:void 0,t.exports=n},{"ip-regex":"foGrp"}],foGrp:[function(e,t,r){"use strict";const i="[a-fA-F\\d:]",n=e=>e&&e.includeBoundaries?`(?:(?<=\\s|^)(?=${i})|(?<=${i})(?=\\s|$))`:"",s="(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}",o="[a-fA-F\\d]{1,4}",a=`\n(?:\n(?:${o}:){7}(?:${o}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8\n(?:${o}:){6}(?:${s}|:${o}|:)| // 1:2:3:4:5:6:: 1:2:3:4:5:6::8 1:2:3:4:5:6::8 1:2:3:4:5:6::1.2.3.4\n(?:${o}:){5}(?::${s}|(?::${o}){1,2}|:)| // 1:2:3:4:5:: 1:2:3:4:5::7:8 1:2:3:4:5::8 1:2:3:4:5::7:1.2.3.4\n(?:${o}:){4}(?:(?::${o}){0,1}:${s}|(?::${o}){1,3}|:)| // 1:2:3:4:: 1:2:3:4::6:7:8 1:2:3:4::8 1:2:3:4::6:7:1.2.3.4\n(?:${o}:){3}(?:(?::${o}){0,2}:${s}|(?::${o}){1,4}|:)| // 1:2:3:: 1:2:3::5:6:7:8 1:2:3::8 1:2:3::5:6:7:1.2.3.4\n(?:${o}:){2}(?:(?::${o}){0,3}:${s}|(?::${o}){1,5}|:)| // 1:2:: 1:2::4:5:6:7:8 1:2::8 1:2::4:5:6:7:1.2.3.4\n(?:${o}:){1}(?:(?::${o}){0,4}:${s}|(?::${o}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4\n(?::(?:(?::${o}){0,5}:${s}|(?::${o}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4\n)(?:%[0-9a-zA-Z]{1,})? // %eth0 %1\n`.replace(/\s*\/\/.*$/gm,"").replace(/\n/g,"").trim(),c=new RegExp(`(?:^${s}$)|(?:^${a}$)`),u=new RegExp(`^${s}$`),l=new RegExp(`^${a}$`),d=e=>e&&e.exact?c:new RegExp(`(?:${n(e)}${s}${n(e)})|(?:${n(e)}${a}${n(e)})`,"g");d.v4=e=>e&&e.exact?u:new RegExp(`${n(e)}${s}${n(e)}`,"g"),d.v6=e=>e&&e.exact?l:new RegExp(`${n(e)}${a}${n(e)}`,"g"),t.exports=d},{}],hC8JB:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./util/bases.js");r.toString=function(e,t="utf8"){const r=i[t];if(!r)throw new Error(`Unsupported encoding "${t}"`);return r.encoder.encode(e).substring(1)}},{"./util/bases.js":"6UNPX"}],"5Z4cQ":[function(e,t,r){"use strict";function i(e){if("number"==typeof e){if(i.codes[e])return i.codes[e];throw new Error("no protocol with code: "+e)}if("string"==typeof e){if(i.names[e])return i.names[e];throw new Error("no protocol with name: "+e)}throw new Error("invalid protocol id type: "+e)}const n=-1;function s(e,t,r,i,n){return{code:e,size:t,name:r,resolvable:Boolean(i),path:Boolean(n)}}i.lengthPrefixedVarSize=n,i.V=n,i.table=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,n,"ip6zone"],[53,n,"dns","resolvable"],[54,n,"dns4","resolvable"],[55,n,"dns6","resolvable"],[56,n,"dnsaddr","resolvable"],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,n,"unix",!1,"path"],[421,n,"ipfs"],[421,n,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,n,"garlic64"],[460,0,"quic"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,n,"memory"]],i.names={},i.codes={},i.table.map((e=>{const t=s.apply(null,e);return i.codes[t.code]=t,i.names[t.name]=t,null})),i.object=s,t.exports=i},{}],aN1CO:[function(e,t,r){t.exports={encode:e("./encode.js"),decode:e("./decode.js"),encodingLength:e("./length.js")}},{"./encode.js":"j1gSN","./decode.js":"9agvx","./length.js":"3Fbt5"}],j1gSN:[function(e,t,r){t.exports=function e(t,r,n){if(Number.MAX_SAFE_INTEGER&&t>Number.MAX_SAFE_INTEGER)throw e.bytes=0,new RangeError("Could not encode varint");r=r||[];var s=n=n||0;for(;t>=i;)r[n++]=255&t|128,t/=128;for(;-128&t;)r[n++]=255&t|128,t>>>=7;return r[n]=0|t,e.bytes=n-s+1,r};var i=Math.pow(2,31)},{}],"9agvx":[function(e,t,r){t.exports=function e(t,r){var i,n=0,s=0,o=r=r||0,a=t.length;do{if(o>=a||s>49)throw e.bytes=0,new RangeError("Could not decode varint");i=t[o++],n+=s<28?(127&i)<=128);return e.bytes=o-r,n}},{}],"3Fbt5":[function(e,t,r){var i=Math.pow(2,7),n=Math.pow(2,14),s=Math.pow(2,21),o=Math.pow(2,28),a=Math.pow(2,35),c=Math.pow(2,42),u=Math.pow(2,49),l=Math.pow(2,56),d=Math.pow(2,63);t.exports=function(e){return ee+t.length),0));const r=new Uint8Array(t);let i=0;for(const t of e)r.set(t,i),i+=t.length;return r}},{}],eY3cX:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.equals=function(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;rP(R(S,T),S),A=T(),k=P(R(A,E,A),R(E,A),R(A,E),A,E);function I(e){return function(t){if(!i.isMultiaddr(t))try{t=new i(t)}catch(e){return!1}const r=e(t.protoNames());return null!==r&&(!0===r||!1===r?r:0===r.length)}}function R(...e){function t(t){if(t.length(r="function"==typeof e?e().partialMatch(t):e.partialMatch(t),Array.isArray(r)&&(t=r),null===r))),r}return{toString:function(){return"{ "+e.join(" ")+" }"},input:e,matches:I(t),partialMatch:t}}function P(...e){function t(t){let r=null;return e.some((e=>{const i="function"==typeof e?e().partialMatch(t):e.partialMatch(t);return!!i&&(r=i,!0)})),r}return{toString:function(){return"{ "+e.join(" ")+" }"},input:e,matches:I(t),partialMatch:t}}function O(e){const t=e;return{toString:function(){return t},matches:function(e){let r;if("string"==typeof e||e instanceof Uint8Array)try{r=new i(e)}catch(e){return!1}else r=e;const n=r.protoNames();return 1===n.length&&n[0]===t},partialMatch:function(e){return 0===e.length?null:e[0]===t?e.slice(1):null}}}t.exports={DNS:a,DNS4:n,DNS6:s,DNSADDR:o,IP:c,TCP:u,UDP:l,QUIC:f,UTP:d,HTTP:g,HTTPS:y,WebSockets:h,WebSocketsSecure:p,WebSocketStar:b,WebRTCStar:m,WebRTCDirect:v,Reliable:w,Stardust:_,Circuit:A,P2P:k,IPFS:k}},{multiaddr:"8Mu1u"}],"86VPZ":[function(e,t,r){"use strict";const{URLWithLegacySupport:i,format:n,URLSearchParams:s,defaultBase:o}=e("./src/url"),a=e("./src/relative");t.exports={URL:i,URLSearchParams:s,format:n,relative:a,defaultBase:o}},{"./src/url":"86S6m","./src/relative":"ki4KM"}],"86S6m":[function(e,t,r){"use strict";const i="undefined"!=typeof navigator&&"ReactNative"===navigator.product;const n=self.URL,s=i?"http://localhost":self.location?self.location.protocol+"//"+self.location.host:"";t.exports={URLWithLegacySupport:class{constructor(e="",t=s){this.super=new n(e,t),this.path=this.pathname+this.search,this.auth=this.username&&this.password?this.username+":"+this.password:null,this.query=this.search&&this.search.startsWith("?")?this.search.slice(1):null}get hash(){return this.super.hash}get host(){return this.super.host}get hostname(){return this.super.hostname}get href(){return this.super.href}get origin(){return this.super.origin}get password(){return this.super.password}get pathname(){return this.super.pathname}get port(){return this.super.port}get protocol(){return this.super.protocol}get search(){return this.super.search}get searchParams(){return this.super.searchParams}get username(){return this.super.username}set hash(e){this.super.hash=e}set host(e){this.super.host=e}set hostname(e){this.super.hostname=e}set href(e){this.super.href=e}set password(e){this.super.password=e}set pathname(e){this.super.pathname=e}set port(e){this.super.port=e}set protocol(e){this.super.protocol=e}set search(e){this.super.search=e}set username(e){this.super.username=e}static createObjectURL(e){return n.createObjectURL(e)}static revokeObjectURL(e){n.revokeObjectURL(e)}toJSON(){return this.super.toJSON()}toString(){return this.super.toString()}format(){return this.toString()}},URLSearchParams:self.URLSearchParams,defaultBase:s,format:function(e){if("string"==typeof e){return new n(e).toString()}if(!(e instanceof n)){const t=e.username&&e.password?`${e.username}:${e.password}@`:"",r=e.auth?e.auth+"@":"",i=e.port?":"+e.port:"",n=e.protocol?e.protocol+"//":"",s=e.host||"",o=e.hostname||"",a=e.search||(e.query?"?"+e.query:""),c=e.hash||"",u=e.pathname||"";return`${n}${t||r}${s||o+i}${e.path||u+a}${c}`}}}},{}],ki4KM:[function(e,t,r){"use strict";const{URLWithLegacySupport:i,format:n}=e("./url");t.exports=(e,t={},r={},s)=>{let o,a=t.protocol?t.protocol.replace(":",""):"http";a=(r[a]||s||a)+":";try{o=new i(e)}catch(e){o={}}const c=Object.assign({},t,{protocol:a||o.protocol,host:t.host||o.host});return new i(e,n(c)).toString()}},{"./url":"86S6m"}],"9hGOz":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("nanoid"),n=e("uint8arrays/to-string"),s=e("uint8arrays/from-string");const o="/",a=(new TextEncoder).encode(o),c=a[0];class u{constructor(e,t){if("string"==typeof e)this._buf=s.fromString(e);else{if(!(e instanceof Uint8Array))throw new Error("Invalid key, should be String of Uint8Array");this._buf=e}if(null==t&&(t=!0),t&&this.clean(),0===this._buf.byteLength||this._buf[0]!==c)throw new Error("Invalid key")}toString(e="utf8"){return n.toString(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new u(e.join(o))}static random(){return new u(i.nanoid().replace(/-/g,""))}static asKey(e){return e instanceof Uint8Array||"string"==typeof e?new u(e):e.uint8Array?new u(e.uint8Array()):null}clean(){if(this._buf&&0!==this._buf.byteLength||(this._buf=a),this._buf[0]!==c){const e=new Uint8Array(this._buf.byteLength+1);e.fill(c,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===c;)this._buf=this._buf.subarray(0,-1)}less(e){const t=this.list(),r=e.list();for(let e=0;en)return!1}return t.lengthe.namespaces())),[].concat(...t))]);var t}}r.Key=u},{nanoid:"dmVhu","uint8arrays/to-string":"hC8JB","uint8arrays/from-string":"dF7Y4"}],dmVhu:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"nanoid",(()=>c)),i.export(r,"customAlphabet",(()=>a)),i.export(r,"customRandom",(()=>o)),i.export(r,"urlAlphabet",(()=>n.urlAlphabet)),i.export(r,"random",(()=>s));var n=e("./url-alphabet/index.js");let s=e=>crypto.getRandomValues(new Uint8Array(e)),o=(e,t,r)=>{let i=(2<{let s="";for(;;){let o=r(n),a=n;for(;a--;)if(s+=e[o[a]&i]||"",s.length===t)return s}}},a=(e,t)=>o(e,t,s),c=(e=21)=>{let t="",r=crypto.getRandomValues(new Uint8Array(e));for(;e--;){let i=63&r[e];t+=i<36?i.toString(36):i<62?(i-26).toString(36).toUpperCase():i<63?"_":"-"}return t}},{"./url-alphabet/index.js":"lbsD0","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],lbsD0:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"urlAlphabet",(()=>n));let n="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],h08wk:[function(e,t,r){r.interopDefault=function(e){return e&&e.__esModule?e:{default:e}},r.defineInteropFlag=function(e){Object.defineProperty(e,"__esModule",{value:!0})},r.exportAll=function(e,t){return Object.keys(e).forEach((function(r){"default"===r||"__esModule"===r||t.hasOwnProperty(r)||Object.defineProperty(t,r,{enumerable:!0,get:function(){return e[r]}})})),t},r.export=function(e,t,r){Object.defineProperty(e,t,{enumerable:!0,get:r})}},{}],j29MK:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("timeout-abort-controller"),n=e("any-signal"),s=e("parse-duration"),o=e("./errors.js");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var c=a(i),u=a(s);r.withTimeoutOption=function(e,t){return(...r)=>{const i=r[null==t?r.length-1:t];if(!i||!i.timeout)return e(...r);const s="string"==typeof i.timeout?u.default(i.timeout):i.timeout,a=new c.default(s);i.signal=n.anySignal([i.signal,a.signal]);const l=e(...r),d=new Promise(((e,t)=>{a.signal.addEventListener("abort",(()=>{t(new o.TimeoutError)}))})),f=Date.now(),h=()=>{if(a.signal.aborted)throw new o.TimeoutError;if(Date.now()-f>s)throw a.abort(),new o.TimeoutError};return l[Symbol.asyncIterator]?async function*(){const e=l[Symbol.asyncIterator]();try{for(;;){const{value:t,done:r}=await Promise.race([e.next(),d]);if(r)break;h(),yield t}}catch(e){throw h(),e}finally{a.clear(),e.return&&e.return()}}():(async()=>{try{const e=await Promise.race([l,d]);return h(),e}catch(e){throw h(),e}finally{a.clear()}})()}}},{"timeout-abort-controller":"hzClg","any-signal":"kXgRR","parse-duration":"fGYtw","./errors.js":"2ffCq"}],hzClg:[function(e,t,r){"use strict";const{AbortController:i}="undefined"!=typeof self?self:"undefined"!=typeof window?window:e("abort-controller"),n=e("retimer");class s extends i{constructor(e){super(),this._ms=e,this._timer=n((()=>this.abort()),e),Object.setPrototypeOf(this,s.prototype)}abort(){return this._timer.clear(),super.abort()}clear(){this._timer.clear()}reset(){this._timer.clear(),this._timer=n((()=>this.abort()),this._ms)}}t.exports=s,t.exports.TimeoutController=s},{"abort-controller":"lNJ7z",retimer:"gJ6S6"}],lNJ7z:[function(e,t,r){"use strict";const{AbortController:i,AbortSignal:n}="undefined"!=typeof self?self:"undefined"!=typeof window?window:void 0;t.exports=i,t.exports.AbortSignal=n,t.exports.default=i},{}],gJ6S6:[function(e,t,r){"use strict";var i=e("./time");function n(e,t,r){var n=this;this._started=i(),this._rescheduled=0,this._scheduled=t,this._args=r,this._timer=setTimeout((function t(){n._rescheduled>0?(n._scheduled=n._rescheduled-(i()-n._started),n._timer=setTimeout(t,n._scheduled),n._rescheduled=0):e.apply(null,n._args)}),t)}n.prototype.reschedule=function(e){var t=i();return!(t+e-(this._started+this._scheduled)<0)&&(this._started=t,this._rescheduled=e,!0)},n.prototype.clear=function(){clearTimeout(this._timer)},t.exports=function(){if("function"!=typeof arguments[0])throw new Error("callback needed");if("number"!=typeof arguments[1])throw new Error("timeout needed");var e;if(arguments.length>0){e=new Array(arguments.length-2);for(var t=0;t{await Promise.all([t.stop(),r.stop(),s.stop(),i.Service.stop(e),n.close()])}}},{"../utils/service.js":"ethcf"}],"4N8JT":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-config/dns"),n=e("ipfs-core-utils/with-timeout-option");r.createDns=function(){return n.withTimeoutOption((async(e,t={recursive:!0})=>{if("string"!=typeof e)throw new Error("Invalid arguments, domain must be a string");return e=function(e){return e.endsWith(".eth")&&(e=e.replace(/.eth$/,".eth.link")),e}(e),i.resolveDnslink(e,t)}))}},{"ipfs-core-config/dns":"HOLZZ","ipfs-core-utils/with-timeout-option":"j29MK"}],HOLZZ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./utils/tlru.js"),n=e("p-queue"),s=e("ipfs-utils/src/http.js");function o(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=o(n),c=o(s);const u=new i.TLRU(1e3),l=new(a.default.default?a.default.default:a.default)({concurrency:4}),d=e=>{if(e.Path)return e.Path;throw new Error(e.Message)};r.resolveDnslink=async function(e,t){return(async(e,t={})=>{const r=new URLSearchParams(t);r.set("arg",e);const i=r.toString();if(!t.nocache&&u.has(i)){const e=u.get(i);return d(e)}const n=await l.add((async()=>{const e=await c.default.get("https://ipfs.io/api/v0/dns",{searchParams:r}),t=new URL(e.url).search.slice(1),i=await e.json();return u.set(t,i,6e4),i}));return d(n)})(e,t)}},{"./utils/tlru.js":"2qTdj","p-queue":"biPlv","ipfs-utils/src/http.js":"ifXXn"}],"2qTdj":[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("hashlru"));r.TLRU=class{constructor(e){this.lru=n.default(e)}get(e){const t=this.lru.get(e);if(t)return t.expire&&t.expire=e&&(t=0,i=r,r=Object.create(null))}return{has:function(e){return void 0!==r[e]||void 0!==i[e]},remove:function(e){void 0!==r[e]&&(r[e]=void 0),void 0!==i[e]&&(i[e]=void 0)},get:function(e){var t=r[e];return void 0!==t?t:void 0!==(t=i[e])?(n(e,t),t):void 0},set:function(e,t){void 0!==r[e]?r[e]=t:n(e,t)},clear:function(){r=Object.create(null),i=Object.create(null)}}}},{}],biPlv:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("eventemitter3"),n=e("p-timeout"),s=e("./priority-queue"),o=()=>{},a=new n.TimeoutError;r.default=class extends i{constructor(e){var t,r,i,n;if(super(),this._intervalCount=0,this._intervalEnd=0,this._pendingCount=0,this._resolveEmpty=o,this._resolveIdle=o,!("number"==typeof(e=Object.assign({carryoverConcurrencyCount:!1,intervalCap:1/0,interval:0,concurrency:1/0,autoStart:!0,queueClass:s.default},e)).intervalCap&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${null!==(r=null===(t=e.intervalCap)||void 0===t?void 0:t.toString())&&void 0!==r?r:""}\` (${typeof e.intervalCap})`);if(void 0===e.interval||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${null!==(n=null===(i=e.interval)||void 0===i?void 0:i.toString())&&void 0!==n?n:""}\` (${typeof e.interval})`);this._carryoverConcurrencyCount=e.carryoverConcurrencyCount,this._isIntervalIgnored=e.intervalCap===1/0||0===e.interval,this._intervalCap=e.intervalCap,this._interval=e.interval,this._queue=new e.queueClass,this._queueClass=e.queueClass,this.concurrency=e.concurrency,this._timeout=e.timeout,this._throwOnTimeout=!0===e.throwOnTimeout,this._isPaused=!1===e.autoStart}get _doesIntervalAllowAnother(){return this._isIntervalIgnored||this._intervalCount{this._onResumeInterval()}),t)),!0;this._intervalCount=this._carryoverConcurrencyCount?this._pendingCount:0}return!1}_tryToStartAnother(){if(0===this._queue.size)return this._intervalId&&clearInterval(this._intervalId),this._intervalId=void 0,this._resolvePromises(),!1;if(!this._isPaused){const e=!this._isIntervalPaused();if(this._doesIntervalAllowAnother&&this._doesConcurrentAllowAnother){const t=this._queue.dequeue();return!!t&&(this.emit("active"),t(),e&&this._initializeIntervalIfNeeded(),!0)}}return!1}_initializeIntervalIfNeeded(){this._isIntervalIgnored||void 0!==this._intervalId||(this._intervalId=setInterval((()=>{this._onInterval()}),this._interval),this._intervalEnd=Date.now()+this._interval)}_onInterval(){0===this._intervalCount&&0===this._pendingCount&&this._intervalId&&(clearInterval(this._intervalId),this._intervalId=void 0),this._intervalCount=this._carryoverConcurrencyCount?this._pendingCount:0,this._processQueue()}_processQueue(){for(;this._tryToStartAnother(););}get concurrency(){return this._concurrency}set concurrency(e){if(!("number"==typeof e&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this._concurrency=e,this._processQueue()}async add(e,t={}){return new Promise(((r,i)=>{this._queue.enqueue((async()=>{this._pendingCount++,this._intervalCount++;try{const s=void 0===this._timeout&&void 0===t.timeout?e():n.default(Promise.resolve(e()),void 0===t.timeout?this._timeout:t.timeout,(()=>{(void 0===t.throwOnTimeout?this._throwOnTimeout:t.throwOnTimeout)&&i(a)}));r(await s)}catch(e){i(e)}this._next()}),t),this._tryToStartAnother(),this.emit("add")}))}async addAll(e,t){return Promise.all(e.map((async e=>this.add(e,t))))}start(){return this._isPaused?(this._isPaused=!1,this._processQueue(),this):this}pause(){this._isPaused=!0}clear(){this._queue=new this._queueClass}async onEmpty(){if(0!==this._queue.size)return new Promise((e=>{const t=this._resolveEmpty;this._resolveEmpty=()=>{t(),e()}}))}async onIdle(){if(0!==this._pendingCount||0!==this._queue.size)return new Promise((e=>{const t=this._resolveIdle;this._resolveIdle=()=>{t(),e()}}))}get size(){return this._queue.size}sizeBy(e){return this._queue.filter(e).length}get pending(){return this._pendingCount}get isPaused(){return this._isPaused}get timeout(){return this._timeout}set timeout(e){this._timeout=e}}},{eventemitter3:"btRgg","p-timeout":"2SalH","./priority-queue":"hkJNA"}],btRgg:[function(e,t,r){"use strict";var i=Object.prototype.hasOwnProperty,n="~";function s(){}function o(e,t,r){this.fn=e,this.context=t,this.once=r||!1}function a(e,t,r,i,s){if("function"!=typeof r)throw new TypeError("The listener must be a function");var a=new o(r,i||e,s),c=n?n+t:t;return e._events[c]?e._events[c].fn?e._events[c]=[e._events[c],a]:e._events[c].push(a):(e._events[c]=a,e._eventsCount++),e}function c(e,t){0==--e._eventsCount?e._events=new s:delete e._events[t]}function u(){this._events=new s,this._eventsCount=0}Object.create&&(s.prototype=Object.create(null),(new s).__proto__||(n=!1)),u.prototype.eventNames=function(){var e,t,r=[];if(0===this._eventsCount)return r;for(t in e=this._events)i.call(e,t)&&r.push(n?t.slice(1):t);return Object.getOwnPropertySymbols?r.concat(Object.getOwnPropertySymbols(e)):r},u.prototype.listeners=function(e){var t=n?n+e:e,r=this._events[t];if(!r)return[];if(r.fn)return[r.fn];for(var i=0,s=r.length,o=new Array(s);inew Promise(((s,o)=>{if("number"!=typeof t||t<0)throw new TypeError("Expected `milliseconds` to be a positive number");if(t===1/0)return void s(e);const a=setTimeout((()=>{if("function"==typeof r){try{s(r())}catch(e){o(e)}return}const i=r instanceof Error?r:new n("string"==typeof r?r:`Promise timed out after ${t} milliseconds`);"function"==typeof e.cancel&&e.cancel(),o(i)}),t);i(e.then(s,o),(()=>{clearTimeout(a)}))}));t.exports=s,t.exports.default=s,t.exports.TimeoutError=n},{"p-finally":"4tkVQ"}],"4tkVQ":[function(e,t,r){"use strict";t.exports=(e,t)=>(t=t||(()=>{}),e.then((e=>new Promise((e=>{e(t())})).then((()=>e))),(e=>new Promise((e=>{e(t())})).then((()=>{throw e})))))},{}],hkJNA:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./lower-bound");r.default=class{constructor(){this._queue=[]}enqueue(e,t){const r={priority:(t=Object.assign({priority:0},t)).priority,run:e};if(this.size&&this._queue[this.size-1].priority>=t.priority)return void this._queue.push(r);const n=i.default(this._queue,r,((e,t)=>t.priority-e.priority));this._queue.splice(n,0,r)}dequeue(){const e=this._queue.shift();return null==e?void 0:e.run}filter(e){return this._queue.filter((t=>t.priority===e.priority)).map((e=>e.run))}get size(){return this._queue.length}}},{"./lower-bound":"9Swn9"}],"9Swn9":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.default=function(e,t,r){let i=0,n=e.length;for(;n>0;){const s=n/2|0;let o=i+s;r(e[o],t)<=0?(i=++o,n-=s+1):n=s}return i}},{}],ifXXn:[function(e,t,r){"use strict";const{fetch:i,Request:n,Headers:s}=e("./http/fetch"),{TimeoutError:o,HTTPError:a}=e("./http/error"),c=e("merge-options").bind({ignoreUndefined:!0}),{URL:u,URLSearchParams:l}=e("iso-url"),{AbortController:d}=e("native-abort-controller"),f=e("any-signal"),h={throwHttpErrors:!0,credentials:"same-origin"};class p{constructor(e={}){this.opts=c(h,e)}async fetch(e,t={}){const r=c(this.opts,t),h=new s(r.headers);if("string"!=typeof e&&!(e instanceof u||e instanceof n))throw new TypeError("`resource` must be a string, URL, or Request");const p=new u(e.toString(),r.base),{searchParams:m,transformSearchParams:b,json:v}=r;m&&(p.search="function"==typeof b?b(new l(r.searchParams)):new l(r.searchParams)),v&&(r.body=JSON.stringify(r.json),h.set("content-type","application/json"));const w=new d,_=f([w.signal,r.signal]),E=await((e,t,r)=>{if(void 0===t)return e;const i=Date.now(),n=()=>Date.now()-i>=t;return new Promise(((i,s)=>{const a=setTimeout((()=>{n()&&(s(new o),r.abort())}),t),c=e=>t=>{clearTimeout(a),n()?s(new o):e(t)};e.then(c(i),c(s))}))})(i(p.toString(),{...r,signal:_,timeout:void 0,headers:h}),r.timeout,w);if(!E.ok&&r.throwHttpErrors)throw r.handleError&&await r.handleError(E),new a(E);return E.iterator=function(){return y(E.body)},E.ndjson=async function*(){for await(const e of g(E.iterator()))t.transform?yield t.transform(e):yield e},E}post(e,t={}){return this.fetch(e,{...t,method:"POST"})}get(e,t={}){return this.fetch(e,{...t,method:"GET"})}put(e,t={}){return this.fetch(e,{...t,method:"PUT"})}delete(e,t={}){return this.fetch(e,{...t,method:"DELETE"})}options(e,t={}){return this.fetch(e,{...t,method:"OPTIONS"})}}const g=async function*(e){const t=new TextDecoder;let r="";for await(const i of e){r+=t.decode(i,{stream:!0});const e=r.split(/\r?\n/);for(let t=0;t0&&(yield JSON.parse(r))}r=e[e.length-1]}r+=t.decode(),r=r.trim(),0!==r.length&&(yield JSON.parse(r))},y=e=>{if(v(e)){const t=e[Symbol.asyncIterator]();return{[Symbol.asyncIterator]:()=>({next:t.next.bind(t),return:r=>(e.destroy(),"function"==typeof t.return?t.return():Promise.resolve({done:!0,value:r}))})}}if(b(e)){const t=e.getReader();return async function*(){try{for(;;){const{done:e,value:r}=await t.read();if(e)return;r&&(yield r)}}finally{t.releaseLock()}}()}if(m(e))return e;throw new TypeError("Body can't be converted to AsyncIterable")},m=e=>"object"==typeof e&&null!==e&&"function"==typeof e[Symbol.asyncIterator],b=e=>e&&"function"==typeof e.getReader,v=e=>Object.prototype.hasOwnProperty.call(e,"readable")&&Object.prototype.hasOwnProperty.call(e,"writable");p.HTTPError=a,p.TimeoutError=o,p.streamToAsyncIterator=y,p.post=(e,t)=>new p(t).post(e,t),p.get=(e,t)=>new p(t).get(e,t),p.put=(e,t)=>new p(t).put(e,t),p.delete=(e,t)=>new p(t).delete(e,t),p.options=(e,t)=>new p(t).options(e,t),t.exports=p},{"./http/fetch":"8A13C","./http/error":"7OuWB","merge-options":"fupyv","iso-url":"86VPZ","native-abort-controller":"6zwoZ","any-signal":"kXgRR"}],"8A13C":[function(e,t,r){"use strict";const{TimeoutError:i,AbortError:n}=e("./error"),{Response:s,Request:o,Headers:a,default:c}=e("../fetch"),u=c,l=e=>{const t=new a;for(const r of e.trim().split(/[\r\n]+/)){const e=r.indexOf(": ");e>0&&t.set(r.slice(0,e),r.slice(e+1))}return t};class d extends s{constructor(e,t,r){super(t,r),Object.defineProperty(this,"url",{value:e})}}t.exports={fetch:(e,t={})=>null!=t.onUploadProgress?((e,t={})=>{const r=new XMLHttpRequest;r.open(t.method||"GET",e.toString(),!0);const{timeout:o,headers:c}=t;if(o&&o>0&&o<1/0&&(r.timeout=o),null!=t.overrideMimeType&&r.overrideMimeType(t.overrideMimeType),c)for(const[e,t]of new a(c))r.setRequestHeader(e,t);return t.signal&&(t.signal.onabort=()=>r.abort()),t.onUploadProgress&&(r.upload.onprogress=t.onUploadProgress),r.responseType="arraybuffer",new Promise(((e,o)=>{const a=t=>{switch(t.type){case"error":e(s.error());break;case"load":e(new d(r.responseURL,r.response,{status:r.status,statusText:r.statusText,headers:l(r.getAllResponseHeaders())}));break;case"timeout":o(new i);break;case"abort":o(new n)}};r.onerror=a,r.onload=a,r.ontimeout=a,r.onabort=a,r.send(t.body)}))})(e,t):u(e,t),Request:o,Headers:a}},{"./error":"7OuWB","../fetch":"6Y5cD"}],"7OuWB":[function(e,t,r){"use strict";class i extends Error{constructor(e="Request timed out"){super(e),this.name="TimeoutError"}}r.TimeoutError=i;class n extends Error{constructor(e="The operation was aborted."){super(e),this.name="AbortError"}}r.AbortError=n;class s extends Error{constructor(e){super(e.statusText),this.name="HTTPError",this.response=e}}r.HTTPError=s},{}],"6Y5cD":[function(e,t,r){"use strict";const{isElectronMain:i}=e("./env");t.exports=e(i?"electron-fetch":"native-fetch")},{"./env":"flyHr","electron-fetch":"lHksA","native-fetch":"kdks4"}],lHksA:[function(e,t,r){},{}],kdks4:[function(e,t,r){"use strict";globalThis.fetch&&globalThis.Headers&&globalThis.Request&&globalThis.Response?t.exports={default:globalThis.fetch,Headers:globalThis.Headers,Request:globalThis.Request,Response:globalThis.Response}:t.exports={default:e("node-fetch").default,Headers:e("node-fetch").Headers,Request:e("node-fetch").Request,Response:e("node-fetch").Response}},{"node-fetch":"1F7gr"}],"1F7gr":[function(e,t,r){"use strict";var i=function(){if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==i)return i;throw new Error("unable to locate global object")}();t.exports=r=i.fetch,i.fetch&&(r.default=i.fetch.bind(i)),r.Headers=i.Headers,r.Request=i.Request,r.Response=i.Response},{}],"2KSm7":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.createIsOnline=function({network:e}){return()=>{const t=e.try();return null!=t&&Boolean(t.libp2p.isStarted())}}},{}],faFUb:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("is-ipfs"),n=e("multiformats/cid"),s=e("peer-id"),o=e("ipfs-core-utils/with-timeout-option"),a=e("../utils.js");function c(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var u=c(i),l=c(s);r.createResolve=function({repo:e,codecs:t,bases:r,name:i}){return o.withTimeoutOption((async function(s,o={}){if(!u.default.path(s))throw new Error("invalid argument "+s);if(u.default.ipnsPath(s))for await(const e of i.resolve(s,o))s=e;const[,c,d,...f]=s.split("/"),h=o.cidBase?await r.getBase(o.cidBase):void 0,p=function(e){try{return l.default.parse(e).toBytes()}catch{return n.CID.parse(e).bytes}}(d);if(0===f.length){return`/${c}/${h?h.encoder.encode(p):d}`}const g=n.CID.decode(p);s=f.join("/");const y=a.resolve(g,s,t,e,o);let m=g,b=s;for await(const e of y)n.CID.asCID(e.value)&&(m=e.value,b=e.remainderPath);return`/ipfs/${m.toString(h&&h.encoder)}${b?"/"+b:""}`}))}},{"is-ipfs":"40iuV","multiformats/cid":"9ooAY","peer-id":"8Bdb3","ipfs-core-utils/with-timeout-option":"j29MK","../utils.js":"cT4uN"}],"8Bdb3":[function(e,t,r){"use strict";const{CID:i}=e("multiformats/cid"),n=e("multiformats/bases/base32"),s=e("multiformats/bases/base36"),o=e("multiformats/bases/base58"),a=e("multiformats/bases/base64"),{base58btc:c}=e("multiformats/bases/base58"),{base32:u}=e("multiformats/bases/base32"),{base16:l}=e("multiformats/bases/base16"),d=e("multiformats/hashes/digest"),f=e("libp2p-crypto/src/keys"),h=e("class-is"),{PeerIdProto:p}=e("./proto"),{equals:g}=e("uint8arrays/equals"),{fromString:y}=e("uint8arrays/from-string"),{toString:m}=e("uint8arrays/to-string"),{identity:b}=e("multiformats/hashes/identity"),v={...n,...s,...o,...a},w=Object.keys(v).reduce(((e,t)=>e.or(v[t])),u.decoder);const _=h(class{constructor(e,t,r){if(!(e instanceof Uint8Array))throw new Error("invalid id provided");if(t&&r&&!g(t.public.bytes,r.bytes))throw new Error("inconsistent arguments");this._id=e,this._idB58String=c.encode(this.id).substring(1),this._privKey=t,this._pubKey=r}get id(){return this._id}set id(e){throw new Error("Id is immutable")}get privKey(){return this._privKey}set privKey(e){this._privKey=e}get pubKey(){if(this._pubKey)return this._pubKey;if(this._privKey)return this._privKey.public;try{const e=d.decode(this.id);e.code===b.code&&(this._pubKey=f.unmarshalPublicKey(e.digest))}catch(e){}return this._pubKey}set pubKey(e){this._pubKey=e}marshalPubKey(){if(this.pubKey)return f.marshalPublicKey(this.pubKey)}marshalPrivKey(){if(this.privKey)return f.marshalPrivateKey(this.privKey)}marshal(e){return p.encode({id:this.toBytes(),pubKey:this.marshalPubKey(),privKey:e?null:this.marshalPrivKey()}).finish()}toPrint(){let e=this.toB58String();e.startsWith("Qm")&&(e=e.slice(2));let t=6;return e.length"}toJSON(){return{id:this.toB58String(),privKey:A(this.marshalPrivKey()),pubKey:A(this.marshalPubKey())}}toHexString(){return l.encode(this.id).substring(1)}toBytes(){return this.id}toB58String(){return this._idB58String}toString(){if(!this._idCIDString){const e=i.createV1(114,d.decode(this.id));Object.defineProperty(this,"_idCIDString",{value:e.toString(),enumerable:!1})}return this._idCIDString}equals(e){if(e instanceof Uint8Array)return g(this.id,e);if(e.id)return g(this.id,e.id);throw new Error("not valid Id")}isEqual(e){return this.equals(e)}isValid(){return Boolean(this.privKey&&this.privKey.public&&this.privKey.public.bytes&&this.pubKey.bytes instanceof Uint8Array&&g(this.privKey.public.bytes,this.pubKey.bytes))}hasInlinePublicKey(){try{if(d.decode(this.id).code===b.code)return!0}catch(e){}return!1}},{className:"PeerId",symbolName:"@libp2p/js-peer-id/PeerId"});r=t.exports=_;const E=e=>e.bytes.length<=42?d.create(b.code,e.bytes).bytes:e.hash(),S=async(e,t)=>{const r=await E(t);return new _(r,e,t)};r.create=async e=>{(e=e||{}).bits=e.bits||2048,e.keyType=e.keyType||"RSA";const t=await f.generateKeyPair(e.keyType,e.bits);return S(t,t.public)},r.createFromHexString=e=>new _(l.decode("f"+e)),r.createFromBytes=e=>{try{const t=i.decode(e);if(!T(t))throw new Error("Supplied PeerID CID is invalid");return r.createFromCID(t)}catch{if(d.decode(e).code!==b.code)throw new Error("Supplied PeerID CID is invalid");return new _(e)}},r.createFromB58String=e=>r.createFromBytes(c.decode("z"+e));const T=e=>114===e.code||112===e.code;function A(e){if(e)return m(e,"base64pad")}r.createFromCID=e=>{if(!(e=i.asCID(e))||!T(e))throw new Error("Supplied PeerID CID is invalid");return new _(e.multihash.bytes)},r.createFromPubKey=async e=>{let t=e;if("string"==typeof t&&(t=y(e,"base64pad")),!(t instanceof Uint8Array))throw new Error("Supplied key is neither a base64 string nor a Uint8Array");const r=await f.unmarshalPublicKey(t);return S(void 0,r)},r.createFromPrivKey=async e=>{if("string"==typeof e&&(e=y(e,"base64pad")),!(e instanceof Uint8Array))throw new Error("Supplied key is neither a base64 string nor a Uint8Array");const t=await f.unmarshalPrivateKey(e);return S(t,t.public)},r.createFromJSON=async e=>{const t=c.decode("z"+e.id),r=e.privKey&&y(e.privKey,"base64pad"),i=e.pubKey&&y(e.pubKey,"base64pad"),n=i&&await f.unmarshalPublicKey(i);if(!r)return new _(t,void 0,n);const s=await f.unmarshalPrivateKey(r),o=await E(s.public);let a;if(n&&(a=await E(n)),n&&!g(o,a))throw new Error("Public and private key do not match");if(t&&!g(o,t))throw new Error("Id and private key do not match");return new _(t,s,n)},r.createFromProtobuf=async e=>{"string"==typeof e&&(e=y(e,"base16"));let t,r,{id:i,privKey:n,pubKey:s}=p.decode(e);if(n=!!n&&await f.unmarshalPrivateKey(n),s=!!s&&await f.unmarshalPublicKey(s),n&&(r=await E(n.public)),s&&(t=await E(s)),n){if(s&&!g(r,t))throw new Error("Public and private key do not match");return new _(r,n,n.public)}if(s)return new _(t,void 0,s);if(i)return new _(i);throw new Error("Protobuf did not contain any usable key material")},r.parse=e=>("1"!==e.charAt(0)&&"Q"!==e.charAt(0)||(e=`z${e}`),r.createFromBytes(w.decode(e))),r.isPeerId=e=>Boolean("object"==typeof e&&e._id&&e._idB58String)},{"multiformats/cid":"9ooAY","multiformats/bases/base32":"5k9Tu","multiformats/bases/base36":"7VmDr","multiformats/bases/base58":"4n7mA","multiformats/bases/base64":"gaFBW","multiformats/bases/base16":"iQzgO","multiformats/hashes/digest":"kpRBg","libp2p-crypto/src/keys":"kWJWg","class-is":"gx31A","./proto":"c0IJt","uint8arrays/equals":"eY3cX","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB","multiformats/hashes/identity":"eYCZn"}],kWJWg:[function(e,t,r){"use strict";const i=e("./keys");e("node-forge/lib/asn1"),e("node-forge/lib/pbe");const n=e("node-forge/lib/forge"),s=e("err-code"),{fromString:o}=e("uint8arrays/from-string"),a=e("./importer"),c={rsa:e("./rsa-class"),ed25519:e("./ed25519-class"),secp256k1:e("./secp256k1-class")(i,e("../random-bytes"))},u="secp256k1 support requires libp2p-crypto-secp256k1 package",l="ERR_MISSING_PACKAGE";function d(e){const t=c[e.toLowerCase()];if(!t){const t=Object.keys(c).join(" / ");throw s(new Error(`invalid or unsupported key type ${e}. Must be ${t}`),"ERR_UNSUPPORTED_KEY_TYPE")}return t}const f=async e=>{const t=i.PrivateKey.decode(e),r=t.Data;switch(t.Type){case i.KeyType.RSA:return c.rsa.unmarshalRsaPrivateKey(r);case i.KeyType.Ed25519:return c.ed25519.unmarshalEd25519PrivateKey(r);case i.KeyType.Secp256k1:if(c.secp256k1)return c.secp256k1.unmarshalSecp256k1PrivateKey(r);throw s(new Error(u),l);default:d(t.Type)}};t.exports={supportedKeys:c,keysPBM:i,keyStretcher:e("./key-stretcher"),generateEphemeralKeyPair:e("./ephemeral-keys"),generateKeyPair:async(e,t)=>d(e).generateKeyPair(t),generateKeyPairFromSeed:async(e,t,r)=>{const i=d(e);if("ed25519"!==e.toLowerCase())throw s(new Error("Seed key derivation is unimplemented for RSA or secp256k1"),"ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return i.generateKeyPairFromSeed(t,r)},unmarshalPublicKey:e=>{const t=i.PublicKey.decode(e),r=t.Data;switch(t.Type){case i.KeyType.RSA:return c.rsa.unmarshalRsaPublicKey(r);case i.KeyType.Ed25519:return c.ed25519.unmarshalEd25519PublicKey(r);case i.KeyType.Secp256k1:if(c.secp256k1)return c.secp256k1.unmarshalSecp256k1PublicKey(r);throw s(new Error(u),l);default:d(t.Type)}},marshalPublicKey:(e,t)=>(d(t=(t||"rsa").toLowerCase()),e.bytes),unmarshalPrivateKey:f,marshalPrivateKey:(e,t)=>(d(t=(t||"rsa").toLowerCase()),e.bytes),import:async(e,t)=>{try{const r=await a.import(e,t);return f(r)}catch(e){}const r=n.pki.decryptRsaPrivateKey(e,t);if(null===r)throw s(new Error("Cannot read the key, most likely the password is wrong or not a RSA key"),"ERR_CANNOT_DECRYPT_PEM");let i=n.asn1.toDer(n.pki.privateKeyToAsn1(r));return i=o(i.getBytes(),"ascii"),c.rsa.unmarshalRsaPrivateKey(i)}}},{"./keys":"jWSTZ","node-forge/lib/asn1":"bcsXQ","node-forge/lib/pbe":"gUP8s","node-forge/lib/forge":"4OuPD","err-code":"chZjB","uint8arrays/from-string":"dF7Y4","./importer":"jyqjk","./rsa-class":"1sbpX","./ed25519-class":"dh3ng","./secp256k1-class":"jXCAP","../random-bytes":"gsnuW","./key-stretcher":"kdBuU","./ephemeral-keys":"ds3K5"}],jWSTZ:[function(e,t,r){"use strict";var i,n,s=e("protobufjs/minimal"),o=s.Reader,a=s.Writer,c=s.util,u=s.roots["libp2p-crypto-keys"]||(s.roots["libp2p-crypto-keys"]={});u.KeyType=(i={},(n=Object.create(i))[i[0]="RSA"]=0,n[i[1]="Ed25519"]=1,n[i[2]="Secp256k1"]=2,n),u.PublicKey=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.Type=e.int32();break;case 2:i.Data=e.bytes();break;default:e.skipType(7&n)}}if(!i.hasOwnProperty("Type"))throw c.ProtocolError("missing required 'Type'",{instance:i});if(!i.hasOwnProperty("Data"))throw c.ProtocolError("missing required 'Data'",{instance:i});return i},e.fromObject=function(e){if(e instanceof u.PublicKey)return e;var t=new u.PublicKey;switch(e.Type){case"RSA":case 0:t.Type=0;break;case"Ed25519":case 1:t.Type=1;break;case"Secp256k1":case 2:t.Type=2}return null!=e.Data&&("string"==typeof e.Data?c.base64.decode(e.Data,t.Data=c.newBuffer(c.base64.length(e.Data)),0):e.Data.length&&(t.Data=e.Data)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(r.Type=t.enums===String?"RSA":0,t.bytes===String?r.Data="":(r.Data=[],t.bytes!==Array&&(r.Data=c.newBuffer(r.Data)))),null!=e.Type&&e.hasOwnProperty("Type")&&(r.Type=t.enums===String?u.KeyType[e.Type]:e.Type),null!=e.Data&&e.hasOwnProperty("Data")&&(r.Data=t.bytes===String?c.base64.encode(e.Data,0,e.Data.length):t.bytes===Array?Array.prototype.slice.call(e.Data):e.Data),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,s.util.toJSONOptions)},e}(),u.PrivateKey=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.Type=e.int32();break;case 2:i.Data=e.bytes();break;default:e.skipType(7&n)}}if(!i.hasOwnProperty("Type"))throw c.ProtocolError("missing required 'Type'",{instance:i});if(!i.hasOwnProperty("Data"))throw c.ProtocolError("missing required 'Data'",{instance:i});return i},e.fromObject=function(e){if(e instanceof u.PrivateKey)return e;var t=new u.PrivateKey;switch(e.Type){case"RSA":case 0:t.Type=0;break;case"Ed25519":case 1:t.Type=1;break;case"Secp256k1":case 2:t.Type=2}return null!=e.Data&&("string"==typeof e.Data?c.base64.decode(e.Data,t.Data=c.newBuffer(c.base64.length(e.Data)),0):e.Data.length&&(t.Data=e.Data)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(r.Type=t.enums===String?"RSA":0,t.bytes===String?r.Data="":(r.Data=[],t.bytes!==Array&&(r.Data=c.newBuffer(r.Data)))),null!=e.Type&&e.hasOwnProperty("Type")&&(r.Type=t.enums===String?u.KeyType[e.Type]:e.Type),null!=e.Data&&e.hasOwnProperty("Data")&&(r.Data=t.bytes===String?c.base64.encode(e.Data,0,e.Data.length):t.bytes===Array?Array.prototype.slice.call(e.Data):e.Data),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,s.util.toJSONOptions)},e}(),t.exports=u},{"protobufjs/minimal":"grAXL"}],bcsXQ:[function(e,t,r){var i=e("./forge");e("./util"),e("./oids");var n=t.exports=i.asn1=i.asn1||{};function s(e,t,r){if(r>t){var i=new Error("Too few bytes to parse DER.");throw i.available=e.length(),i.remaining=t,i.requested=r,i}}n.Class={UNIVERSAL:0,APPLICATION:64,CONTEXT_SPECIFIC:128,PRIVATE:192},n.Type={NONE:0,BOOLEAN:1,INTEGER:2,BITSTRING:3,OCTETSTRING:4,NULL:5,OID:6,ODESC:7,EXTERNAL:8,REAL:9,ENUMERATED:10,EMBEDDED:11,UTF8:12,ROID:13,SEQUENCE:16,SET:17,PRINTABLESTRING:19,IA5STRING:22,UTCTIME:23,GENERALIZEDTIME:24,BMPSTRING:30},n.create=function(e,t,r,s,o){if(i.util.isArray(s)){for(var a=[],c=0;ct){if(i.strict){var p=new Error("Too few bytes to read ASN.1 value.");throw p.available=e.length(),p.remaining=t,p.requested=h,p}h=t}var g=32==(32&c);if(g)if(d=[],void 0===h)for(;;){if(s(e,t,2),e.bytes(2)===String.fromCharCode(0,0)){e.getBytes(2),t-=2;break}a=e.length(),d.push(o(e,t,r+1,i)),t-=a-e.length()}else for(;h>0;)a=e.length(),d.push(o(e,h,r+1,i)),t-=a-e.length(),h-=a-e.length();if(void 0===d&&u===n.Class.UNIVERSAL&&l===n.Type.BITSTRING&&(f=e.bytes(h)),void 0===d&&i.decodeBitStrings&&u===n.Class.UNIVERSAL&&l===n.Type.BITSTRING&&h>1){var y=e.read,m=t,b=0;if(l===n.Type.BITSTRING&&(s(e,t,1),b=e.getByte(),t--),0===b)try{a=e.length();var v=o(e,t,r+1,{verbose:i.verbose,strict:!0,decodeBitStrings:!0}),w=a-e.length();t-=w,l==n.Type.BITSTRING&&w++;var _=v.tagClass;w!==h||_!==n.Class.UNIVERSAL&&_!==n.Class.CONTEXT_SPECIFIC||(d=[v])}catch(e){}void 0===d&&(e.read=y,t=m)}if(void 0===d){if(void 0===h){if(i.strict)throw new Error("Non-constructed ASN.1 object of indefinite length.");h=t}if(l===n.Type.BMPSTRING)for(d="";h>0;h-=2)s(e,t,2),d+=String.fromCharCode(e.getInt16()),t-=2;else d=e.getBytes(h)}var E=void 0===f?null:{bitStringContents:f};return n.create(u,l,g,d,E)}n.fromDer=function(e,t){return void 0===t&&(t={strict:!0,decodeBitStrings:!0}),"boolean"==typeof t&&(t={strict:t,decodeBitStrings:!0}),"strict"in t||(t.strict=!0),"decodeBitStrings"in t||(t.decodeBitStrings=!0),"string"==typeof e&&(e=i.util.createBuffer(e)),o(e,e.length(),0,t)},n.toDer=function(e){var t=i.util.createBuffer(),r=e.tagClass|e.type,s=i.util.createBuffer(),o=!1;if("bitStringContents"in e&&(o=!0,e.original&&(o=n.equals(e,e.original))),o)s.putBytes(e.bitStringContents);else if(e.composed){e.constructed?r|=32:s.putByte(0);for(var a=0;a1&&(0===e.value.charCodeAt(0)&&0==(128&e.value.charCodeAt(1))||255===e.value.charCodeAt(0)&&128==(128&e.value.charCodeAt(1)))?s.putBytes(e.value.substr(1)):s.putBytes(e.value);if(t.putByte(r),s.length()<=127)t.putByte(127&s.length());else{var c=s.length(),u="";do{u+=String.fromCharCode(255&c),c>>>=8}while(c>0);t.putByte(128|u.length);for(a=u.length-1;a>=0;--a)t.putByte(u.charCodeAt(a))}return t.putBuffer(s),t},n.oidToDer=function(e){var t,r,n,s,o=e.split("."),a=i.util.createBuffer();a.putByte(40*parseInt(o[0],10)+parseInt(o[1],10));for(var c=2;c>>=7,t||(s|=128),r.push(s),t=!1}while(n>0);for(var u=r.length-1;u>=0;--u)a.putByte(r[u])}return a},n.derToOid=function(e){var t;"string"==typeof e&&(e=i.util.createBuffer(e));var r=e.getByte();t=Math.floor(r/40)+"."+r%40;for(var n=0;e.length()>0;)n<<=7,128&(r=e.getByte())?n+=127&r:(t+="."+(n+r),n=0);return t},n.utcTimeToDate=function(e){var t=new Date,r=parseInt(e.substr(0,2),10);r=r>=50?1900+r:2e3+r;var i=parseInt(e.substr(2,2),10)-1,n=parseInt(e.substr(4,2),10),s=parseInt(e.substr(6,2),10),o=parseInt(e.substr(8,2),10),a=0;if(e.length>11){var c=e.charAt(10),u=10;"+"!==c&&"-"!==c&&(a=parseInt(e.substr(10,2),10),u+=2)}if(t.setUTCFullYear(r,i,n),t.setUTCHours(s,o,a,0),u&&("+"===(c=e.charAt(u))||"-"===c)){var l=60*parseInt(e.substr(u+1,2),10)+parseInt(e.substr(u+4,2),10);l*=6e4,"+"===c?t.setTime(+t-l):t.setTime(+t+l)}return t},n.generalizedTimeToDate=function(e){var t=new Date,r=parseInt(e.substr(0,4),10),i=parseInt(e.substr(4,2),10)-1,n=parseInt(e.substr(6,2),10),s=parseInt(e.substr(8,2),10),o=parseInt(e.substr(10,2),10),a=parseInt(e.substr(12,2),10),c=0,u=0,l=!1;"Z"===e.charAt(e.length-1)&&(l=!0);var d=e.length-5,f=e.charAt(d);"+"!==f&&"-"!==f||(u=60*parseInt(e.substr(d+1,2),10)+parseInt(e.substr(d+4,2),10),u*=6e4,"+"===f&&(u*=-1),l=!0);return"."===e.charAt(14)&&(c=1e3*parseFloat(e.substr(14),10)),l?(t.setUTCFullYear(r,i,n),t.setUTCHours(s,o,a,c),t.setTime(+t+u)):(t.setFullYear(r,i,n),t.setHours(s,o,a,c)),t},n.dateToUtcTime=function(e){if("string"==typeof e)return e;var t="",r=[];r.push((""+e.getUTCFullYear()).substr(2)),r.push(""+(e.getUTCMonth()+1)),r.push(""+e.getUTCDate()),r.push(""+e.getUTCHours()),r.push(""+e.getUTCMinutes()),r.push(""+e.getUTCSeconds());for(var i=0;i=-128&&e<128)return t.putSignedInt(e,8);if(e>=-32768&&e<32768)return t.putSignedInt(e,16);if(e>=-8388608&&e<8388608)return t.putSignedInt(e,24);if(e>=-2147483648&&e<2147483648)return t.putSignedInt(e,32);var r=new Error("Integer too large; max is 32-bits.");throw r.integer=e,r},n.derToInteger=function(e){"string"==typeof e&&(e=i.util.createBuffer(e));var t=8*e.length();if(t>32)throw new Error("Integer too large; max is 32-bits.");return e.getSignedInt(t)},n.validate=function(e,t,r,s){var o=!1;if(e.tagClass!==t.tagClass&&void 0!==t.tagClass||e.type!==t.type&&void 0!==t.type)s&&(e.tagClass!==t.tagClass&&s.push("["+t.name+'] Expected tag class "'+t.tagClass+'", got "'+e.tagClass+'"'),e.type!==t.type&&s.push("["+t.name+'] Expected type "'+t.type+'", got "'+e.type+'"'));else if(e.constructed===t.constructed||void 0===t.constructed){if(o=!0,t.value&&i.util.isArray(t.value))for(var a=0,c=0;o&&c0&&(s+="\n");for(var o="",c=0;c1?s+="0x"+i.util.bytesToHex(e.value.slice(1)):s+="(none)",e.value.length>0){var f=e.value.charCodeAt(0);1==f?s+=" (1 unused bit shown)":f>1&&(s+=" ("+f+" unused bits shown)")}}else e.type===n.Type.OCTETSTRING?(a.test(e.value)||(s+="("+e.value+") "),s+="0x"+i.util.bytesToHex(e.value)):e.type===n.Type.UTF8?s+=i.util.decodeUtf8(e.value):e.type===n.Type.PRINTABLESTRING||e.type===n.Type.IA5String?s+=e.value:a.test(e.value)?s+="0x"+i.util.bytesToHex(e.value):0===e.value.length?s+="[null]":s+=e.value}return s}},{"./forge":"4OuPD","./util":"df43p","./oids":"7VPL4"}],"4OuPD":[function(e,t,r){t.exports={options:{usePureJavaScript:!1}}},{}],df43p:[function(e,t,r){var i=e("process"),n=arguments[3],s=e("buffer").Buffer,o=e("./forge"),a=e("./baseN"),c=t.exports=o.util=o.util||{};function u(e){if(8!==e&&16!==e&&24!==e&&32!==e)throw new Error("Only 8, 16, 24, or 32 bits supported: "+e)}function l(e){if(this.data="",this.read=0,"string"==typeof e)this.data=e;else if(c.isArrayBuffer(e)||c.isArrayBufferView(e))if(void 0!==s&&e instanceof s)this.data=e.toString("binary");else{var t=new Uint8Array(e);try{this.data=String.fromCharCode.apply(null,t)}catch(e){for(var r=0;r15?(r=Date.now(),o(e)):(t.push(e),1===t.length&&s.setAttribute("a",n=!n))}}c.nextTick=c.setImmediate}(),c.isNodejs=void 0!==i&&i.versions&&i.versions.node,c.globalScope=c.isNodejs?n:"undefined"==typeof self?window:self,c.isArray=Array.isArray||function(e){return"[object Array]"===Object.prototype.toString.call(e)},c.isArrayBuffer=function(e){return"undefined"!=typeof ArrayBuffer&&e instanceof ArrayBuffer},c.isArrayBufferView=function(e){return e&&c.isArrayBuffer(e.buffer)&&void 0!==e.byteLength},c.ByteBuffer=l,c.ByteStringBuffer=l;var d=4096;function f(e,t){t=t||{},this.read=t.readOffset||0,this.growSize=t.growSize||1024;var r=c.isArrayBuffer(e),i=c.isArrayBufferView(e);if(r||i)return this.data=r?new DataView(e):new DataView(e.buffer,e.byteOffset,e.byteLength),void(this.write="writeOffset"in t?t.writeOffset:this.data.byteLength);this.data=new DataView(new ArrayBuffer(0)),this.write=0,null!=e&&this.putBytes(e),"writeOffset"in t&&(this.write=t.writeOffset)}c.ByteStringBuffer.prototype._optimizeConstructedString=function(e){this._constructedStringLength+=e,this._constructedStringLength>d&&(this.data.substr(0,1),this._constructedStringLength=0)},c.ByteStringBuffer.prototype.length=function(){return this.data.length-this.read},c.ByteStringBuffer.prototype.isEmpty=function(){return this.length()<=0},c.ByteStringBuffer.prototype.putByte=function(e){return this.putBytes(String.fromCharCode(e))},c.ByteStringBuffer.prototype.fillWithByte=function(e,t){e=String.fromCharCode(e);for(var r=this.data;t>0;)1&t&&(r+=e),(t>>>=1)>0&&(e+=e);return this.data=r,this._optimizeConstructedString(t),this},c.ByteStringBuffer.prototype.putBytes=function(e){return this.data+=e,this._optimizeConstructedString(e.length),this},c.ByteStringBuffer.prototype.putString=function(e){return this.putBytes(c.encodeUtf8(e))},c.ByteStringBuffer.prototype.putInt16=function(e){return this.putBytes(String.fromCharCode(e>>8&255)+String.fromCharCode(255&e))},c.ByteStringBuffer.prototype.putInt24=function(e){return this.putBytes(String.fromCharCode(e>>16&255)+String.fromCharCode(e>>8&255)+String.fromCharCode(255&e))},c.ByteStringBuffer.prototype.putInt32=function(e){return this.putBytes(String.fromCharCode(e>>24&255)+String.fromCharCode(e>>16&255)+String.fromCharCode(e>>8&255)+String.fromCharCode(255&e))},c.ByteStringBuffer.prototype.putInt16Le=function(e){return this.putBytes(String.fromCharCode(255&e)+String.fromCharCode(e>>8&255))},c.ByteStringBuffer.prototype.putInt24Le=function(e){return this.putBytes(String.fromCharCode(255&e)+String.fromCharCode(e>>8&255)+String.fromCharCode(e>>16&255))},c.ByteStringBuffer.prototype.putInt32Le=function(e){return this.putBytes(String.fromCharCode(255&e)+String.fromCharCode(e>>8&255)+String.fromCharCode(e>>16&255)+String.fromCharCode(e>>24&255))},c.ByteStringBuffer.prototype.putInt=function(e,t){u(t);var r="";do{t-=8,r+=String.fromCharCode(e>>t&255)}while(t>0);return this.putBytes(r)},c.ByteStringBuffer.prototype.putSignedInt=function(e,t){return e<0&&(e+=2<0);return t},c.ByteStringBuffer.prototype.getSignedInt=function(e){var t=this.getInt(e),r=2<=r&&(t-=r<<1),t},c.ByteStringBuffer.prototype.getBytes=function(e){var t;return e?(e=Math.min(this.length(),e),t=this.data.slice(this.read,this.read+e),this.read+=e):0===e?t="":(t=0===this.read?this.data:this.data.slice(this.read),this.clear()),t},c.ByteStringBuffer.prototype.bytes=function(e){return void 0===e?this.data.slice(this.read):this.data.slice(this.read,this.read+e)},c.ByteStringBuffer.prototype.at=function(e){return this.data.charCodeAt(this.read+e)},c.ByteStringBuffer.prototype.setAt=function(e,t){return this.data=this.data.substr(0,this.read+e)+String.fromCharCode(t)+this.data.substr(this.read+e+1),this},c.ByteStringBuffer.prototype.last=function(){return this.data.charCodeAt(this.data.length-1)},c.ByteStringBuffer.prototype.copy=function(){var e=c.createBuffer(this.data);return e.read=this.read,e},c.ByteStringBuffer.prototype.compact=function(){return this.read>0&&(this.data=this.data.slice(this.read),this.read=0),this},c.ByteStringBuffer.prototype.clear=function(){return this.data="",this.read=0,this},c.ByteStringBuffer.prototype.truncate=function(e){var t=Math.max(0,this.length()-e);return this.data=this.data.substr(this.read,t),this.read=0,this},c.ByteStringBuffer.prototype.toHex=function(){for(var e="",t=this.read;t=e)return this;t=Math.max(t||this.growSize,e);var r=new Uint8Array(this.data.buffer,this.data.byteOffset,this.data.byteLength),i=new Uint8Array(this.length()+t);return i.set(r),this.data=new DataView(i.buffer),this},c.DataBuffer.prototype.putByte=function(e){return this.accommodate(1),this.data.setUint8(this.write++,e),this},c.DataBuffer.prototype.fillWithByte=function(e,t){this.accommodate(t);for(var r=0;r>8&65535),this.data.setInt8(this.write,e>>16&255),this.write+=3,this},c.DataBuffer.prototype.putInt32=function(e){return this.accommodate(4),this.data.setInt32(this.write,e),this.write+=4,this},c.DataBuffer.prototype.putInt16Le=function(e){return this.accommodate(2),this.data.setInt16(this.write,e,!0),this.write+=2,this},c.DataBuffer.prototype.putInt24Le=function(e){return this.accommodate(3),this.data.setInt8(this.write,e>>16&255),this.data.setInt16(this.write,e>>8&65535,!0),this.write+=3,this},c.DataBuffer.prototype.putInt32Le=function(e){return this.accommodate(4),this.data.setInt32(this.write,e,!0),this.write+=4,this},c.DataBuffer.prototype.putInt=function(e,t){u(t),this.accommodate(t/8);do{t-=8,this.data.setInt8(this.write++,e>>t&255)}while(t>0);return this},c.DataBuffer.prototype.putSignedInt=function(e,t){return u(t),this.accommodate(t/8),e<0&&(e+=2<0);return t},c.DataBuffer.prototype.getSignedInt=function(e){var t=this.getInt(e),r=2<=r&&(t-=r<<1),t},c.DataBuffer.prototype.getBytes=function(e){var t;return e?(e=Math.min(this.length(),e),t=this.data.slice(this.read,this.read+e),this.read+=e):0===e?t="":(t=0===this.read?this.data:this.data.slice(this.read),this.clear()),t},c.DataBuffer.prototype.bytes=function(e){return void 0===e?this.data.slice(this.read):this.data.slice(this.read,this.read+e)},c.DataBuffer.prototype.at=function(e){return this.data.getUint8(this.read+e)},c.DataBuffer.prototype.setAt=function(e,t){return this.data.setUint8(e,t),this},c.DataBuffer.prototype.last=function(){return this.data.getUint8(this.write-1)},c.DataBuffer.prototype.copy=function(){return new c.DataBuffer(this)},c.DataBuffer.prototype.compact=function(){if(this.read>0){var e=new Uint8Array(this.data.buffer,this.read),t=new Uint8Array(e.byteLength);t.set(e),this.data=new DataView(t),this.write-=this.read,this.read=0}return this},c.DataBuffer.prototype.clear=function(){return this.data=new DataView(new ArrayBuffer(0)),this.read=this.write=0,this},c.DataBuffer.prototype.truncate=function(e){return this.write=Math.max(0,this.length()-e),this.read=Math.min(this.read,this.write),this},c.DataBuffer.prototype.toHex=function(){for(var e="",t=this.read;t0;)1&t&&(r+=e),(t>>>=1)>0&&(e+=e);return r},c.xorBytes=function(e,t,r){for(var i="",n="",s="",o=0,a=0;r>0;--r,++o)n=e.charCodeAt(o)^t.charCodeAt(o),a>=10&&(i+=s,s="",a=0),s+=String.fromCharCode(n),++a;return i+=s},c.hexToBytes=function(e){var t="",r=0;for(!0&e.length&&(r=1,t+=String.fromCharCode(parseInt(e[0],16)));r>24&255)+String.fromCharCode(e>>16&255)+String.fromCharCode(e>>8&255)+String.fromCharCode(255&e)};var h="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",p=[62,-1,-1,-1,63,52,53,54,55,56,57,58,59,60,61,-1,-1,-1,64,-1,-1,-1,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,-1,-1,-1,-1,-1,-1,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51],g="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz";c.encode64=function(e,t){for(var r,i,n,s="",o="",a=0;a>2),s+=h.charAt((3&r)<<4|i>>4),isNaN(i)?s+="==":(s+=h.charAt((15&i)<<2|n>>6),s+=isNaN(n)?"=":h.charAt(63&n)),t&&s.length>t&&(o+=s.substr(0,t)+"\r\n",s=s.substr(t));return o+=s},c.decode64=function(e){e=e.replace(/[^A-Za-z0-9\+\/\=]/g,"");for(var t,r,i,n,s="",o=0;o>4),64!==i&&(s+=String.fromCharCode((15&r)<<4|i>>2),64!==n&&(s+=String.fromCharCode((3&i)<<6|n)));return s},c.encodeUtf8=function(e){return unescape(encodeURIComponent(e))},c.decodeUtf8=function(e){return decodeURIComponent(escape(e))},c.binary={raw:{},hex:{},base64:{},base58:{},baseN:{encode:a.encode,decode:a.decode}},c.binary.raw.encode=function(e){return String.fromCharCode.apply(null,e)},c.binary.raw.decode=function(e,t,r){var i=t;i||(i=new Uint8Array(e.length));for(var n=r=r||0,s=0;s>2),s+=h.charAt((3&r)<<4|i>>4),isNaN(i)?s+="==":(s+=h.charAt((15&i)<<2|n>>6),s+=isNaN(n)?"=":h.charAt(63&n)),t&&s.length>t&&(o+=s.substr(0,t)+"\r\n",s=s.substr(t));return o+=s},c.binary.base64.decode=function(e,t,r){var i,n,s,o,a=t;a||(a=new Uint8Array(3*Math.ceil(e.length/4))),e=e.replace(/[^A-Za-z0-9\+\/\=]/g,"");for(var c=0,u=r=r||0;c>4,64!==s&&(a[u++]=(15&n)<<4|s>>2,64!==o&&(a[u++]=(3&s)<<6|o));return t?u-r:a.subarray(0,u)},c.binary.base58.encode=function(e,t){return c.binary.baseN.encode(e,g,t)},c.binary.base58.decode=function(e,t){return c.binary.baseN.decode(e,g,t)},c.text={utf8:{},utf16:{}},c.text.utf8.encode=function(e,t,r){e=c.encodeUtf8(e);var i=t;i||(i=new Uint8Array(e.length));for(var n=r=r||0,s=0;s0?(n=r[i].substring(0,o),s=r[i].substring(o+1)):(n=r[i],s=null),n in t||(t[n]=[]),n in Object.prototype||null===s||t[n].push(unescape(s))}return t};return void 0===e?(null===S&&(S="undefined"!=typeof window&&window.location&&window.location.search?r(window.location.search.substring(1)):{}),t=S):t=r(e),t},c.parseFragment=function(e){var t=e,r="",i=e.indexOf("?");i>0&&(t=e.substring(0,i),r=e.substring(i+1));var n=t.split("/");return n.length>0&&""===n[0]&&n.shift(),{pathString:t,queryString:r,path:n,query:""===r?{}:c.getQueryVariables(r)}},c.makeRequest=function(e){var t=c.parseFragment(e),r={path:t.pathString,query:t.queryString,getPath:function(e){return void 0===e?t.path:t.path[e]},getQuery:function(e,r){var i;return void 0===e?i=t.query:(i=t.query[e])&&void 0!==r&&(i=i[r]),i},getQueryLast:function(e,t){var i=r.getQuery(e);return i?i[i.length-1]:t}};return r},c.makeLink=function(e,t,r){e=jQuery.isArray(e)?e.join("/"):e;var i=jQuery.param(t||{});return r=r||"",e+(i.length>0?"?"+i:"")+(r.length>0?"#"+r:"")},c.isEmpty=function(e){for(var t in e)if(e.hasOwnProperty(t))return!1;return!0},c.format=function(e){for(var t,r,i=/%./g,n=0,s=[],o=0;t=i.exec(e);){(r=e.substring(o,i.lastIndex-2)).length>0&&s.push(r),o=i.lastIndex;var a=t[0][1];switch(a){case"s":case"o":n");break;case"%":s.push("%");break;default:s.push("<%"+a+"?>")}}return s.push(e.substring(o)),s.join("")},c.formatNumber=function(e,t,r,i){var n=e,s=isNaN(t=Math.abs(t))?2:t,o=void 0===r?",":r,a=void 0===i?".":i,c=n<0?"-":"",u=parseInt(n=Math.abs(+n||0).toFixed(s),10)+"",l=u.length>3?u.length%3:0;return c+(l?u.substr(0,l)+a:"")+u.substr(l).replace(/(\d{3})(?=\d)/g,"$1"+a)+(s?o+Math.abs(n-u).toFixed(s).slice(2):"")},c.formatSize=function(e){return e=e>=1073741824?c.formatNumber(e/1073741824,2,".","")+" GiB":e>=1048576?c.formatNumber(e/1048576,2,".","")+" MiB":e>=1024?c.formatNumber(e/1024,0)+" KiB":c.formatNumber(e,0)+" bytes"},c.bytesFromIP=function(e){return-1!==e.indexOf(".")?c.bytesFromIPv4(e):-1!==e.indexOf(":")?c.bytesFromIPv6(e):null},c.bytesFromIPv4=function(e){if(4!==(e=e.split(".")).length)return null;for(var t=c.createBuffer(),r=0;rr[i].end-r[i].start&&(i=r.length-1)):r.push({start:a,end:a})}t.push(s)}if(r.length>0){var u=r[i];u.end-u.start>0&&(t.splice(u.start,u.end-u.start+1,""),0===u.start&&t.unshift(""),7===u.end&&t.push(""))}return t.join(":")},c.estimateCores=function(e,t){if("function"==typeof e&&(t=e,e={}),e=e||{},"cores"in c&&!e.update)return t(null,c.cores);if("undefined"!=typeof navigator&&"hardwareConcurrency"in navigator&&navigator.hardwareConcurrency>0)return c.cores=navigator.hardwareConcurrency,t(null,c.cores);if("undefined"==typeof Worker)return c.cores=1,t(null,c.cores);if("undefined"==typeof Blob)return c.cores=2,t(null,c.cores);var r=URL.createObjectURL(new Blob(["(",function(){self.addEventListener("message",(function(e){for(var t=Date.now(),r=t+4;Date.now()a.st&&n.stn.st&&a.st0;)a.push(u%s),u=u/s|0}for(n=0;0===e[n]&&n=0;--n)i+=t[a[n]]}else i=function(e,t){var r=0,i=t.length,n=t.charAt(0),s=[0];for(r=0;r0;)s.push(a%i),a=a/i|0}var c="";for(r=0;0===e.at(r)&&r=0;--r)c+=t[s[r]];return c}(e,t);if(r){var l=new RegExp(".{1,"+r+"}","g");i=i.match(l).join("\r\n")}return i},n.decode=function(e,t){if("string"!=typeof e)throw new TypeError('"input" must be a string.');if("string"!=typeof t)throw new TypeError('"alphabet" must be a string.');var r=s[t];if(!r){r=s[t]=[];for(var n=0;n>=8;for(;d>0;)c.push(255&d),d>>=8}for(var f=0;e[f]===a&&f=0;c--)P>>=8,P+=A.at(c)+R.at(c),R.setAt(c,255&P);I.putBuffer(R)}w=I,d.putBuffer(S)}return d.truncate(d.length()-s),d},o.pbe.getCipher=function(e,t,r){switch(e){case o.oids.pkcs5PBES2:return o.pbe.getCipherForPBES2(e,t,r);case o.oids["pbeWithSHAAnd3-KeyTripleDES-CBC"]:case o.oids["pbewithSHAAnd40BitRC2-CBC"]:return o.pbe.getCipherForPKCS12PBE(e,t,r);default:var i=new Error("Cannot read encrypted PBE data block. Unsupported OID.");throw i.oid=e,i.supportedOids=["pkcs5PBES2","pbeWithSHAAnd3-KeyTripleDES-CBC","pbewithSHAAnd40BitRC2-CBC"],i}},o.pbe.getCipherForPBES2=function(e,t,r){var n,a={},c=[];if(!s.validate(t,u,a,c))throw(n=new Error("Cannot read password-based-encryption algorithm parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.")).errors=c,n;if((e=s.derToOid(a.kdfOid))!==o.oids.pkcs5PBKDF2)throw(n=new Error("Cannot read encrypted private key. Unsupported key derivation function OID.")).oid=e,n.supportedOids=["pkcs5PBKDF2"],n;if((e=s.derToOid(a.encOid))!==o.oids["aes128-CBC"]&&e!==o.oids["aes192-CBC"]&&e!==o.oids["aes256-CBC"]&&e!==o.oids["des-EDE3-CBC"]&&e!==o.oids.desCBC)throw(n=new Error("Cannot read encrypted private key. Unsupported encryption scheme OID.")).oid=e,n.supportedOids=["aes128-CBC","aes192-CBC","aes256-CBC","des-EDE3-CBC","desCBC"],n;var l,d,h=a.kdfSalt,p=i.util.createBuffer(a.kdfIterationCount);switch(p=p.getInt(p.length()<<3),o.oids[e]){case"aes128-CBC":l=16,d=i.aes.createDecryptionCipher;break;case"aes192-CBC":l=24,d=i.aes.createDecryptionCipher;break;case"aes256-CBC":l=32,d=i.aes.createDecryptionCipher;break;case"des-EDE3-CBC":l=24,d=i.des.createDecryptionCipher;break;case"desCBC":l=8,d=i.des.createDecryptionCipher}var g=f(a.prfOid),y=i.pkcs5.pbkdf2(r,h,p,l,g),m=a.encIv,b=d(y);return b.start(m),b},o.pbe.getCipherForPKCS12PBE=function(e,t,r){var n={},a=[];if(!s.validate(t,l,n,a))throw(g=new Error("Cannot read password-based-encryption algorithm parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.")).errors=a,g;var c,u,d,h=i.util.createBuffer(n.salt),p=i.util.createBuffer(n.iterations);switch(p=p.getInt(p.length()<<3),e){case o.oids["pbeWithSHAAnd3-KeyTripleDES-CBC"]:c=24,u=8,d=i.des.startDecrypting;break;case o.oids["pbewithSHAAnd40BitRC2-CBC"]:c=5,u=8,d=function(e,t){var r=i.rc2.createDecryptionCipher(e,40);return r.start(t,null),r};break;default:var g;throw(g=new Error("Cannot read PKCS #12 PBE data block. Unsupported OID.")).oid=e,g}var y=f(n.prfOid),m=o.pbe.generatePkcs12Key(r,h,1,p,c,y);return y.start(),d(m,o.pbe.generatePkcs12Key(r,h,2,p,u,y))},o.pbe.opensslDeriveBytes=function(e,t,r,n){if(null==n){if(!("md5"in i.md))throw new Error('"md5" hash algorithm unavailable.');n=i.md.md5.create()}null===t&&(t="");for(var s=[d(n,e+t)],o=16,a=1;o>>=2;for(n=0;n>8^255&d^99,s[g]=d,o[d]=g,h=(f=e[d])<<24^d<<16^d<<8^d^f,p=((r=e[g])^(i=e[r])^(n=e[i]))<<24^(g^n)<<16^(g^i^n)<<8^g^r^n;for(var m=0;m<4;++m)c[m][g]=h,u[m][d]=p,h=h<<24|h>>>8,p=p<<24|p>>>8;0===g?g=y=1:(g=r^e[e[e[r^n]]],y^=e[e[y]])}}function f(e,t){for(var r,i=e.slice(0),n=1,o=i.length,c=4*(o+6+1),l=o;l>>16&255]<<24^s[r>>>8&255]<<16^s[255&r]<<8^s[r>>>24]^a[n]<<24,n++):o>6&&l%o==4&&(r=s[r>>>24]<<24^s[r>>>16&255]<<16^s[r>>>8&255]<<8^s[255&r]),i[l]=i[l-o]^r;if(t){for(var d,f=u[0],h=u[1],p=u[2],g=u[3],y=i.slice(0),m=(l=0,(c=i.length)-4);l>>24]]^h[s[d>>>16&255]]^p[s[d>>>8&255]]^g[s[255&d]];i=y}return i}function h(e,t,r,i){var n,a,l,d,f,h,p,g,y,m,b,v,w=e.length/4-1;i?(n=u[0],a=u[1],l=u[2],d=u[3],f=o):(n=c[0],a=c[1],l=c[2],d=c[3],f=s),h=t[0]^e[0],p=t[i?3:1]^e[1],g=t[2]^e[2],y=t[i?1:3]^e[3];for(var _=3,E=1;E>>24]^a[p>>>16&255]^l[g>>>8&255]^d[255&y]^e[++_],b=n[p>>>24]^a[g>>>16&255]^l[y>>>8&255]^d[255&h]^e[++_],v=n[g>>>24]^a[y>>>16&255]^l[h>>>8&255]^d[255&p]^e[++_],y=n[y>>>24]^a[h>>>16&255]^l[p>>>8&255]^d[255&g]^e[++_],h=m,p=b,g=v;r[0]=f[h>>>24]<<24^f[p>>>16&255]<<16^f[g>>>8&255]<<8^f[255&y]^e[++_],r[i?3:1]=f[p>>>24]<<24^f[g>>>16&255]<<16^f[y>>>8&255]<<8^f[255&h]^e[++_],r[2]=f[g>>>24]<<24^f[y>>>16&255]<<16^f[h>>>8&255]<<8^f[255&p]^e[++_],r[i?1:3]=f[y>>>24]<<24^f[h>>>16&255]<<16^f[p>>>8&255]<<8^f[255&g]^e[++_]}function p(e){var t,r="AES-"+((e=e||{}).mode||"CBC").toUpperCase(),n=(t=e.decrypt?i.cipher.createDecipher(r,e.key):i.cipher.createCipher(r,e.key)).start;return t.start=function(e,r){var s=null;r instanceof i.util.ByteBuffer&&(s=r,r={}),(r=r||{}).output=s,r.iv=e,n.call(t,r)},t}},{"./forge":"4OuPD","./cipher":"jMIHu","./cipherModes":"9MNR1","./util":"df43p"}],jMIHu:[function(e,t,r){var i=e("./forge");e("./util"),t.exports=i.cipher=i.cipher||{},i.cipher.algorithms=i.cipher.algorithms||{},i.cipher.createCipher=function(e,t){var r=e;if("string"==typeof r&&(r=i.cipher.getAlgorithm(r))&&(r=r()),!r)throw new Error("Unsupported algorithm: "+e);return new i.cipher.BlockCipher({algorithm:r,key:t,decrypt:!1})},i.cipher.createDecipher=function(e,t){var r=e;if("string"==typeof r&&(r=i.cipher.getAlgorithm(r))&&(r=r()),!r)throw new Error("Unsupported algorithm: "+e);return new i.cipher.BlockCipher({algorithm:r,key:t,decrypt:!0})},i.cipher.registerAlgorithm=function(e,t){e=e.toUpperCase(),i.cipher.algorithms[e]=t},i.cipher.getAlgorithm=function(e){return(e=e.toUpperCase())in i.cipher.algorithms?i.cipher.algorithms[e]:null};var n=i.cipher.BlockCipher=function(e){this.algorithm=e.algorithm,this.mode=this.algorithm.mode,this.blockSize=this.mode.blockSize,this._finish=!1,this._input=null,this.output=null,this._op=e.decrypt?this.mode.decrypt:this.mode.encrypt,this._decrypt=e.decrypt,this.algorithm.initialize(e)};n.prototype.start=function(e){e=e||{};var t={};for(var r in e)t[r]=e[r];t.decrypt=this._decrypt,this._finish=!1,this._input=i.util.createBuffer(),this.output=e.output||i.util.createBuffer(),this.mode.start(t)},n.prototype.update=function(e){for(e&&this._input.putBuffer(e);!this._op.call(this.mode,this._input,this.output,this._finish)&&!this._finish;);this._input.compact()},n.prototype.finish=function(e){!e||"ECB"!==this.mode.name&&"CBC"!==this.mode.name||(this.mode.pad=function(t){return e(this.blockSize,t,!1)},this.mode.unpad=function(t){return e(this.blockSize,t,!0)});var t={};return t.decrypt=this._decrypt,t.overflow=this._input.length()%this.blockSize,!(!this._decrypt&&this.mode.pad&&!this.mode.pad(this._input,t))&&(this._finish=!0,this.update(),!(this._decrypt&&this.mode.unpad&&!this.mode.unpad(this.output,t))&&!(this.mode.afterFinish&&!this.mode.afterFinish(this.output,t)))}},{"./forge":"4OuPD","./util":"df43p"}],"9MNR1":[function(e,t,r){var i=e("./forge");e("./util"),i.cipher=i.cipher||{};var n=t.exports=i.cipher.modes=i.cipher.modes||{};function s(e,t){if("string"==typeof e&&(e=i.util.createBuffer(e)),i.util.isArray(e)&&e.length>4){var r=e;e=i.util.createBuffer();for(var n=0;n0))return!0;for(var i=0;i0))return!0;for(var i=0;i0)return!1;var r=e.length(),i=e.at(r-1);return!(i>this.blockSize<<2)&&(e.truncate(i),!0)},n.cbc=function(e){e=e||{},this.name="CBC",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=new Array(this._ints),this._outBlock=new Array(this._ints)},n.cbc.prototype.start=function(e){if(null===e.iv){if(!this._prev)throw new Error("Invalid IV parameter.");this._iv=this._prev.slice(0)}else{if(!("iv"in e))throw new Error("Invalid IV parameter.");this._iv=s(e.iv,this.blockSize),this._prev=this._iv.slice(0)}},n.cbc.prototype.encrypt=function(e,t,r){if(e.length()0))return!0;for(var i=0;i0))return!0;for(var i=0;i0)return!1;var r=e.length(),i=e.at(r-1);return!(i>this.blockSize<<2)&&(e.truncate(i),!0)},n.cfb=function(e){e=e||{},this.name="CFB",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=null,this._outBlock=new Array(this._ints),this._partialBlock=new Array(this._ints),this._partialOutput=i.util.createBuffer(),this._partialBytes=0},n.cfb.prototype.start=function(e){if(!("iv"in e))throw new Error("Invalid IV parameter.");this._iv=s(e.iv,this.blockSize),this._inBlock=this._iv.slice(0),this._partialBytes=0},n.cfb.prototype.encrypt=function(e,t,r){var i=e.length();if(0===i)return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize)for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0)e.read-=this.blockSize;else for(n=0;n0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}},n.cfb.prototype.decrypt=function(e,t,r){var i=e.length();if(0===i)return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize)for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0)e.read-=this.blockSize;else for(n=0;n0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}},n.ofb=function(e){e=e||{},this.name="OFB",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=null,this._outBlock=new Array(this._ints),this._partialOutput=i.util.createBuffer(),this._partialBytes=0},n.ofb.prototype.start=function(e){if(!("iv"in e))throw new Error("Invalid IV parameter.");this._iv=s(e.iv,this.blockSize),this._inBlock=this._iv.slice(0),this._partialBytes=0},n.ofb.prototype.encrypt=function(e,t,r){var i=e.length();if(0===e.length())return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize)for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0)e.read-=this.blockSize;else for(n=0;n0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}},n.ofb.prototype.decrypt=n.ofb.prototype.encrypt,n.ctr=function(e){e=e||{},this.name="CTR",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=null,this._outBlock=new Array(this._ints),this._partialOutput=i.util.createBuffer(),this._partialBytes=0},n.ctr.prototype.start=function(e){if(!("iv"in e))throw new Error("Invalid IV parameter.");this._iv=s(e.iv,this.blockSize),this._inBlock=this._iv.slice(0),this._partialBytes=0},n.ctr.prototype.encrypt=function(e,t,r){var i=e.length();if(0===i)return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize)for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0&&(e.read-=this.blockSize),this._partialBytes>0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}o(this._inBlock)},n.ctr.prototype.decrypt=n.ctr.prototype.encrypt,n.gcm=function(e){e=e||{},this.name="GCM",this.cipher=e.cipher,this.blockSize=e.blockSize||16,this._ints=this.blockSize/4,this._inBlock=new Array(this._ints),this._outBlock=new Array(this._ints),this._partialOutput=i.util.createBuffer(),this._partialBytes=0,this._R=3774873600},n.gcm.prototype.start=function(e){if(!("iv"in e))throw new Error("Invalid IV parameter.");var t,r=i.util.createBuffer(e.iv);if(this._cipherLength=0,t="additionalData"in e?i.util.createBuffer(e.additionalData):i.util.createBuffer(),this._tagLength="tagLength"in e?e.tagLength:128,this._tag=null,e.decrypt&&(this._tag=i.util.createBuffer(e.tag).getBytes(),this._tag.length!==this._tagLength/8))throw new Error("Authentication tag does not match tag length.");this._hashBlock=new Array(this._ints),this.tag=null,this._hashSubkey=new Array(this._ints),this.cipher.encrypt([0,0,0,0],this._hashSubkey),this.componentBits=4,this._m=this.generateHashTable(this._hashSubkey,this.componentBits);var n=r.length();if(12===n)this._j0=[r.getInt32(),r.getInt32(),r.getInt32(),1];else{for(this._j0=[0,0,0,0];r.length()>0;)this._j0=this.ghash(this._hashSubkey,this._j0,[r.getInt32(),r.getInt32(),r.getInt32(),r.getInt32()]);this._j0=this.ghash(this._hashSubkey,this._j0,[0,0].concat(a(8*n)))}this._inBlock=this._j0.slice(0),o(this._inBlock),this._partialBytes=0,t=i.util.createBuffer(t),this._aDataLength=a(8*t.length());var s=t.length()%this.blockSize;for(s&&t.fillWithByte(0,this.blockSize-s),this._s=[0,0,0,0];t.length()>0;)this._s=this.ghash(this._hashSubkey,this._s,[t.getInt32(),t.getInt32(),t.getInt32(),t.getInt32()])},n.gcm.prototype.encrypt=function(e,t,r){var i=e.length();if(0===i)return!0;if(this.cipher.encrypt(this._inBlock,this._outBlock),0===this._partialBytes&&i>=this.blockSize){for(var n=0;n0&&(s=this.blockSize-s),this._partialOutput.clear();for(n=0;n0&&this._partialOutput.getBytes(this._partialBytes),s>0&&!r)return e.read-=this.blockSize,t.putBytes(this._partialOutput.getBytes(s-this._partialBytes)),this._partialBytes=s,!0;t.putBytes(this._partialOutput.getBytes(i-this._partialBytes)),this._partialBytes=0}this._s=this.ghash(this._hashSubkey,this._s,this._outBlock),o(this._inBlock)},n.gcm.prototype.decrypt=function(e,t,r){var i=e.length();if(i0))return!0;this.cipher.encrypt(this._inBlock,this._outBlock),o(this._inBlock),this._hashBlock[0]=e.getInt32(),this._hashBlock[1]=e.getInt32(),this._hashBlock[2]=e.getInt32(),this._hashBlock[3]=e.getInt32(),this._s=this.ghash(this._hashSubkey,this._s,this._hashBlock);for(var n=0;n0;--i)t[i]=e[i]>>>1|(1&e[i-1])<<31;t[0]=e[0]>>>1,r&&(t[0]^=this._R)},n.gcm.prototype.tableMultiply=function(e){for(var t=[0,0,0,0],r=0;r<32;++r){var i=e[r/8|0]>>>4*(7-r%8)&15,n=this._m[r][i];t[0]^=n[0],t[1]^=n[1],t[2]^=n[2],t[3]^=n[3]}return t},n.gcm.prototype.ghash=function(e,t,r){return t[0]^=r[0],t[1]^=r[1],t[2]^=r[2],t[3]^=r[3],this.tableMultiply(t)},n.gcm.prototype.generateHashTable=function(e,t){for(var r=8/t,i=4*r,n=16*r,s=new Array(n),o=0;o>>1,n=new Array(r);n[i]=e.slice(0);for(var s=i>>>1;s>0;)this.pow(n[2*s],n[s]=[]),s>>=1;for(s=2;s8?3:1,m=[],b=[0,0,1,1,1,1,1,1,0,1,1,1,1,1,1,0],v=0,w=0;w>>4^E))<<4,_^=t=65535&((E^=t)>>>-16^_),_^=(t=858993459&(_>>>2^(E^=t<<-16)))<<2,_^=t=65535&((E^=t)>>>-16^_),_^=(t=1431655765&(_>>>1^(E^=t<<-16)))<<1,_^=t=16711935&((E^=t)>>>8^_),t=(_^=(t=1431655765&(_>>>1^(E^=t<<8)))<<1)<<8|(E^=t)>>>20&240,_=E<<24|E<<8&16711680|E>>>8&65280|E>>>24&240,E=t;for(var S=0;S>>26,E=E<<2|E>>>26):(_=_<<1|_>>>27,E=E<<1|E>>>27),E&=-15;var T=r[(_&=-15)>>>28]|i[_>>>24&15]|n[_>>>20&15]|s[_>>>16&15]|o[_>>>12&15]|a[_>>>8&15]|c[_>>>4&15],A=u[E>>>28]|l[E>>>24&15]|d[E>>>20&15]|f[E>>>16&15]|h[E>>>12&15]|p[E>>>8&15]|g[E>>>4&15];t=65535&(A>>>16^T),m[v++]=T^t,m[v++]=A^t<<16}}return m}(t),this._init=!0}},n("DES-ECB",i.cipher.modes.ecb),n("DES-CBC",i.cipher.modes.cbc),n("DES-CFB",i.cipher.modes.cfb),n("DES-OFB",i.cipher.modes.ofb),n("DES-CTR",i.cipher.modes.ctr),n("3DES-ECB",i.cipher.modes.ecb),n("3DES-CBC",i.cipher.modes.cbc),n("3DES-CFB",i.cipher.modes.cfb),n("3DES-OFB",i.cipher.modes.ofb),n("3DES-CTR",i.cipher.modes.ctr);var s=[16843776,0,65536,16843780,16842756,66564,4,65536,1024,16843776,16843780,1024,16778244,16842756,16777216,4,1028,16778240,16778240,66560,66560,16842752,16842752,16778244,65540,16777220,16777220,65540,0,1028,66564,16777216,65536,16843780,4,16842752,16843776,16777216,16777216,1024,16842756,65536,66560,16777220,1024,4,16778244,66564,16843780,65540,16842752,16778244,16777220,1028,66564,16843776,1028,16778240,16778240,0,65540,66560,0,16842756],o=[-2146402272,-2147450880,32768,1081376,1048576,32,-2146435040,-2147450848,-2147483616,-2146402272,-2146402304,-2147483648,-2147450880,1048576,32,-2146435040,1081344,1048608,-2147450848,0,-2147483648,32768,1081376,-2146435072,1048608,-2147483616,0,1081344,32800,-2146402304,-2146435072,32800,0,1081376,-2146435040,1048576,-2147450848,-2146435072,-2146402304,32768,-2146435072,-2147450880,32,-2146402272,1081376,32,32768,-2147483648,32800,-2146402304,1048576,-2147483616,1048608,-2147450848,-2147483616,1048608,1081344,0,-2147450880,32800,-2147483648,-2146435040,-2146402272,1081344],a=[520,134349312,0,134348808,134218240,0,131592,134218240,131080,134217736,134217736,131072,134349320,131080,134348800,520,134217728,8,134349312,512,131584,134348800,134348808,131592,134218248,131584,131072,134218248,8,134349320,512,134217728,134349312,134217728,131080,520,131072,134349312,134218240,0,512,131080,134349320,134218240,134217736,512,0,134348808,134218248,131072,134217728,134349320,8,131592,131584,134217736,134348800,134218248,520,134348800,131592,8,134348808,131584],c=[8396801,8321,8321,128,8396928,8388737,8388609,8193,0,8396800,8396800,8396929,129,0,8388736,8388609,1,8192,8388608,8396801,128,8388608,8193,8320,8388737,1,8320,8388736,8192,8396928,8396929,129,8388736,8388609,8396800,8396929,129,0,0,8396800,8320,8388736,8388737,1,8396801,8321,8321,128,8396929,129,1,8192,8388609,8193,8396928,8388737,8193,8320,8388608,8396801,128,8388608,8192,8396928],u=[256,34078976,34078720,1107296512,524288,256,1073741824,34078720,1074266368,524288,33554688,1074266368,1107296512,1107820544,524544,1073741824,33554432,1074266112,1074266112,0,1073742080,1107820800,1107820800,33554688,1107820544,1073742080,0,1107296256,34078976,33554432,1107296256,524544,524288,1107296512,256,33554432,1073741824,34078720,1107296512,1074266368,33554688,1073741824,1107820544,34078976,1074266368,256,33554432,1107820544,1107820800,524544,1107296256,1107820800,34078720,0,1074266112,1107296256,524544,33554688,1073742080,524288,0,1074266112,34078976,1073742080],l=[536870928,541065216,16384,541081616,541065216,16,541081616,4194304,536887296,4210704,4194304,536870928,4194320,536887296,536870912,16400,0,4194320,536887312,16384,4210688,536887312,16,541065232,541065232,0,4210704,541081600,16400,4210688,541081600,536870912,536887296,16,541065232,4210688,541081616,4194304,16400,536870928,4194304,536887296,536870912,16400,536870928,541081616,4210688,541065216,4210704,541081600,0,541065232,16,16384,541065216,4210704,16384,4194320,536887312,0,541081600,536870912,4194320,536887312],d=[2097152,69206018,67110914,0,2048,67110914,2099202,69208064,69208066,2097152,0,67108866,2,67108864,69206018,2050,67110912,2099202,2097154,67110912,67108866,69206016,69208064,2097154,69206016,2048,2050,69208066,2099200,2,67108864,2099200,67108864,2099200,2097152,67110914,67110914,69206018,69206018,2,2097154,67108864,67110912,2097152,69208064,2050,2099202,69208064,2050,67108866,69208066,69206016,2099200,0,2,69208066,0,2099202,69206016,2048,67108866,67110912,2048,2097154],f=[268439616,4096,262144,268701760,268435456,268439616,64,268435456,262208,268697600,268701760,266240,268701696,266304,4096,64,268697600,268435520,268439552,4160,266240,262208,268697664,268701696,4160,0,0,268697664,268435520,268439552,266304,262144,266304,262144,268701696,4096,64,268697664,4096,266304,268439552,64,268435520,268697600,268697664,268435456,262144,268439616,0,268701760,262208,268435520,268697600,268439552,268439616,0,268701760,266240,266240,4160,4160,262208,268435456,268701696];function h(e,t,r,i){var n,h,p=32===e.length?3:9;n=3===p?i?[30,-2,-2]:[0,32,2]:i?[94,62,-2,32,64,2,30,-2,-2]:[0,32,2,62,30,-2,64,96,2];var g=t[0],y=t[1];g^=(h=252645135&(g>>>4^y))<<4,g^=(h=65535&(g>>>16^(y^=h)))<<16,g^=h=858993459&((y^=h)>>>2^g),g^=h=16711935&((y^=h<<2)>>>8^g),g=(g^=(h=1431655765&(g>>>1^(y^=h<<8)))<<1)<<1|g>>>31,y=(y^=h)<<1|y>>>31;for(var m=0;m>>4|y<<28)^e[w+1];h=g,g=y,y=h^(o[_>>>24&63]|c[_>>>16&63]|l[_>>>8&63]|f[63&_]|s[E>>>24&63]|a[E>>>16&63]|u[E>>>8&63]|d[63&E])}h=g,g=y,y=h}y=y>>>1|y<<31,y^=h=1431655765&((g=g>>>1|g<<31)>>>1^y),y^=(h=16711935&(y>>>8^(g^=h<<1)))<<8,y^=(h=858993459&(y>>>2^(g^=h)))<<2,y^=h=65535&((g^=h)>>>16^y),y^=h=252645135&((g^=h<<16)>>>4^y),g^=h<<4,r[0]=g,r[1]=y}function p(e){var t,r="DES-"+((e=e||{}).mode||"CBC").toUpperCase(),n=(t=e.decrypt?i.cipher.createDecipher(r,e.key):i.cipher.createCipher(r,e.key)).start;return t.start=function(e,r){var s=null;r instanceof i.util.ByteBuffer&&(s=r,r={}),(r=r||{}).output=s,r.iv=e,n.call(t,r)},t}},{"./forge":"4OuPD","./cipher":"jMIHu","./cipherModes":"9MNR1","./util":"df43p"}],fYbz5:[function(e,t,r){var i=e("./forge");t.exports=i.md=i.md||{},i.md.algorithms=i.md.algorithms||{}},{"./forge":"4OuPD"}],j1TyX:[function(e,t,r){var i=e("buffer").Buffer,n=e("./forge");e("./hmac"),e("./md"),e("./util");var s,o=n.pkcs5=n.pkcs5||{};n.util.isNodejs&&!n.options.usePureJavaScript&&(s=e("crypto")),t.exports=n.pbkdf2=o.pbkdf2=function(e,t,r,o,a,c){if("function"==typeof a&&(c=a,a=null),n.util.isNodejs&&!n.options.usePureJavaScript&&s.pbkdf2&&(null===a||"object"!=typeof a)&&(s.pbkdf2Sync.length>4||!a||"sha1"===a))return"string"!=typeof a&&(a="sha1"),e=i.from(e,"binary"),t=i.from(t,"binary"),c?4===s.pbkdf2Sync.length?s.pbkdf2(e,t,r,o,(function(e,t){if(e)return c(e);c(null,t.toString("binary"))})):s.pbkdf2(e,t,r,o,a,(function(e,t){if(e)return c(e);c(null,t.toString("binary"))})):4===s.pbkdf2Sync.length?s.pbkdf2Sync(e,t,r,o).toString("binary"):s.pbkdf2Sync(e,t,r,o,a).toString("binary");if(null==a&&(a="sha1"),"string"==typeof a){if(!(a in n.md.algorithms))throw new Error("Unknown hash algorithm: "+a);a=n.md[a].create()}var u=a.digestLength;if(o>4294967295*u){var l=new Error("Derived key is too long.");if(c)return c(l);throw l}var d=Math.ceil(o/u),f=o-(d-1)*u,h=n.hmac.create();h.start(a,e);var p,g,y,m="";if(!c){for(var b=1;b<=d;++b){h.start(null,null),h.update(t),h.update(n.util.int32ToBytes(b)),p=y=h.digest().getBytes();for(var v=2;v<=r;++v)h.start(null,null),h.update(y),g=h.digest().getBytes(),p=n.util.xorBytes(p,g,u),y=g;m+=bd)return c(null,m);h.start(null,null),h.update(t),h.update(n.util.int32ToBytes(b)),p=y=h.digest().getBytes(),v=2,_()}function _(){if(v<=r)return h.start(null,null),h.update(y),g=h.digest().getBytes(),p=n.util.xorBytes(p,g,u),y=g,++v,n.util.setImmediate(_);m+=bt.blockLength&&(t.start(),t.update(o.bytes()),o=t.digest()),r=i.util.createBuffer(),n=i.util.createBuffer(),u=o.length();for(c=0;c65&&-1!==o){var a=t[o];","===a?(++o,t=t.substr(0,o)+"\r\n "+t.substr(o)):t=t.substr(0,o)+"\r\n"+a+t.substr(o+1),s=n-o-1,o=-1,++n}else" "!==t[n]&&"\t"!==t[n]&&","!==t[n]||(o=n);return t}function o(e){return e.replace(/^\s+/,"")}n.encode=function(e,t){t=t||{};var r,n="-----BEGIN "+e.type+"-----\r\n";if(e.procType&&(n+=s(r={name:"Proc-Type",values:[String(e.procType.version),e.procType.type]})),e.contentDomain&&(n+=s(r={name:"Content-Domain",values:[e.contentDomain]})),e.dekInfo&&(r={name:"DEK-Info",values:[e.dekInfo.algorithm]},e.dekInfo.parameters&&r.values.push(e.dekInfo.parameters),n+=s(r)),e.headers)for(var o=0;o>>0,a>>>0];for(var u=n.fullMessageLength.length-1;u>=0;--u)n.fullMessageLength[u]+=a[1],a[1]=a[0]+(n.fullMessageLength[u]/4294967296>>>0),n.fullMessageLength[u]=n.fullMessageLength[u]>>>0,a[0]=a[1]/4294967296>>>0;return t.putBytes(s),c(e,r,t),(t.read>2048||0===t.length())&&t.compact(),n},n.digest=function(){var o=i.util.createBuffer();o.putBytes(t.bytes());var a,u=n.fullMessageLength[n.fullMessageLength.length-1]+n.messageLengthSize&n.blockLength-1;o.putBytes(s.substr(0,n.blockLength-u));for(var l=8*n.fullMessageLength[0],d=0;d>>0,o.putInt32(l>>>0),l=a>>>0;o.putInt32(l);var f={h0:e.h0,h1:e.h1,h2:e.h2,h3:e.h3,h4:e.h4,h5:e.h5,h6:e.h6,h7:e.h7};c(f,r,o);var h=i.util.createBuffer();return h.putInt32(f.h0),h.putInt32(f.h1),h.putInt32(f.h2),h.putInt32(f.h3),h.putInt32(f.h4),h.putInt32(f.h5),h.putInt32(f.h6),h.putInt32(f.h7),h},n};var s=null,o=!1,a=null;function c(e,t,r){for(var i,n,s,o,c,u,l,d,f,h,p,g,y,m=r.length();m>=64;){for(c=0;c<16;++c)t[c]=r.getInt32();for(;c<64;++c)i=((i=t[c-2])>>>17|i<<15)^(i>>>19|i<<13)^i>>>10,n=((n=t[c-15])>>>7|n<<25)^(n>>>18|n<<14)^n>>>3,t[c]=i+t[c-7]+n+t[c-16]|0;for(u=e.h0,l=e.h1,d=e.h2,f=e.h3,h=e.h4,p=e.h5,g=e.h6,y=e.h7,c=0;c<64;++c)s=(u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10),o=u&l|d&(u^l),i=y+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+(g^h&(p^g))+a[c]+t[c],y=g,g=p,p=h,h=f+i>>>0,f=d,d=l,l=u,u=i+(n=s+o)>>>0;e.h0=e.h0+u|0,e.h1=e.h1+l|0,e.h2=e.h2+d|0,e.h3=e.h3+f|0,e.h4=e.h4+h|0,e.h5=e.h5+p|0,e.h6=e.h6+g|0,e.h7=e.h7+y|0,m-=64}}},{"./forge":"4OuPD","./md":"fYbz5","./util":"df43p"}],"5YtEX":[function(e,t,r){var i=e("process"),n=e("./forge");e("./util");var s=null;!n.util.isNodejs||n.options.usePureJavaScript||i.versions["node-webkit"]||(s=e("crypto")),(t.exports=n.prng=n.prng||{}).create=function(e){for(var t={plugin:e,key:null,seed:null,time:null,reseeds:0,generated:0,keyBytes:""},r=e.md,i=new Array(32),o=0;o<32;++o)i[o]=r.create();function a(){if(t.pools[0].messageLength>=32)return c();var e=32-t.pools[0].messageLength<<5;t.collect(t.seedFileSync(e)),c()}function c(){t.reseeds=4294967295===t.reseeds?0:t.reseeds+1;var e=t.plugin.md.create();e.update(t.keyBytes);for(var r=1,i=0;i<32;++i)t.reseeds%r==0&&(e.update(t.pools[i].digest().getBytes()),t.pools[i].start()),r<<=1;t.keyBytes=e.digest().getBytes(),e.start(),e.update(t.keyBytes);var n=e.digest().getBytes();t.key=t.plugin.formatKey(t.keyBytes),t.seed=t.plugin.formatSeed(n),t.generated=0}function u(e){var t=null,r=n.util.globalScope,i=r.crypto||r.msCrypto;i&&i.getRandomValues&&(t=function(e){return i.getRandomValues(e)});var s=n.util.createBuffer();if(t)for(;s.length()>16)))<<16,f=4294967295&(l=(2147483647&(l+=u>>15))+(l>>31));for(c=0;c<3;++c)d=f>>>(c<<3),d^=Math.floor(256*Math.random()),s.putByte(String.fromCharCode(255&d))}return s.getBytes(e)}return t.pools=i,t.pool=0,t.generate=function(e,r){if(!r)return t.generateSync(e);var i=t.plugin.cipher,s=t.plugin.increment,o=t.plugin.formatKey,a=t.plugin.formatSeed,u=n.util.createBuffer();t.key=null,function l(d){if(d)return r(d);if(u.length()>=e)return r(null,u.getBytes(e));t.generated>1048575&&(t.key=null);if(null===t.key)return n.util.nextTick((function(){!function(e){if(t.pools[0].messageLength>=32)return c(),e();var r=32-t.pools[0].messageLength<<5;t.seedFile(r,(function(r,i){if(r)return e(r);t.collect(i),c(),e()}))}(l)}));var f=i(t.key,t.seed);t.generated+=f.length,u.putBytes(f),t.key=o(i(t.key,s(t.seed))),t.seed=a(i(t.key,t.seed)),n.util.setImmediate(l)}()},t.generateSync=function(e){var r=t.plugin.cipher,i=t.plugin.increment,s=t.plugin.formatKey,o=t.plugin.formatSeed;t.key=null;for(var c=n.util.createBuffer();c.length()1048575&&(t.key=null),null===t.key&&a();var u=r(t.key,t.seed);t.generated+=u.length,c.putBytes(u),t.key=s(r(t.key,i(t.seed))),t.seed=o(r(t.key,t.seed))}return c.getBytes(e)},s?(t.seedFile=function(e,t){s.randomBytes(e,(function(e,r){if(e)return t(e);t(null,r.toString())}))},t.seedFileSync=function(e){return s.randomBytes(e).toString()}):(t.seedFile=function(e,t){try{t(null,u(e))}catch(e){t(e)}},t.seedFileSync=u),t.collect=function(e){for(var r=e.length,i=0;i>n&255);t.collect(i)},t.registerWorker=function(e){if(e===self)t.seedFile=function(e,t){self.addEventListener("message",(function e(r){var i=r.data;i.forge&&i.forge.prng&&(self.removeEventListener("message",e),t(i.forge.prng.err,i.forge.prng.bytes))})),self.postMessage({forge:{prng:{needed:e}}})};else{e.addEventListener("message",(function(r){var i=r.data;i.forge&&i.forge.prng&&t.seedFile(i.forge.prng.needed,(function(t,r){e.postMessage({forge:{prng:{err:t,bytes:r}}})}))}))}},t}},{process:"lHksA","./forge":"4OuPD","./util":"df43p",crypto:"lHksA"}],k5bWr:[function(e,t,r){var i=e("./forge");e("./util");var n=[217,120,249,196,25,221,181,237,40,233,253,121,74,160,216,157,198,126,55,131,43,118,83,142,98,76,100,136,68,139,251,162,23,154,89,245,135,179,79,19,97,69,109,141,9,129,125,50,189,143,64,235,134,183,123,11,240,149,33,34,92,107,78,130,84,214,101,147,206,96,178,28,115,86,192,20,167,140,241,220,18,117,202,31,59,190,228,209,66,61,212,48,163,60,182,38,111,191,14,218,70,105,7,87,39,242,29,155,188,148,67,3,248,17,199,246,144,239,62,231,6,195,213,47,200,102,30,215,8,232,234,222,128,82,238,247,132,170,114,172,53,77,106,42,150,26,210,113,90,21,73,116,75,159,208,94,4,24,164,236,194,224,65,110,15,81,203,204,36,145,175,80,161,244,112,57,153,124,58,133,35,184,180,122,252,2,54,91,37,85,151,49,45,93,250,152,227,138,146,174,5,223,41,16,103,108,186,201,211,0,230,207,225,158,168,44,99,22,1,63,88,226,137,169,13,56,52,27,171,51,255,176,187,72,12,95,185,177,205,46,197,243,219,71,229,165,156,119,10,166,32,104,254,127,193,173],s=[1,2,3,5],o=function(e,t){return e<>16-t},a=function(e,t){return(65535&e)>>t|e<<16-t&65535};t.exports=i.rc2=i.rc2||{},i.rc2.expandKey=function(e,t){"string"==typeof e&&(e=i.util.createBuffer(e)),t=t||128;var r,s=e,o=e.length(),a=t,c=Math.ceil(a/8),u=255>>(7&a);for(r=o;r<128;r++)s.putByte(n[s.at(r-1)+s.at(r-o)&255]);for(s.setAt(128-c,n[s.at(128-c)&u]),r=127-c;r>=0;r--)s.setAt(r,n[s.at(r+1)^s.at(r+c)]);return s};var c=function(e,t,r){var n,c,u,l,d=!1,f=null,h=null,p=null,g=[];for(e=i.rc2.expandKey(e,t),u=0;u<64;u++)g.push(e.getInt16Le());r?(n=function(e){for(u=0;u<4;u++)e[u]+=g[l]+(e[(u+3)%4]&e[(u+2)%4])+(~e[(u+3)%4]&e[(u+1)%4]),e[u]=o(e[u],s[u]),l++},c=function(e){for(u=0;u<4;u++)e[u]+=g[63&e[(u+3)%4]]}):(n=function(e){for(u=3;u>=0;u--)e[u]=a(e[u],s[u]),e[u]-=g[l]+(e[(u+3)%4]&e[(u+2)%4])+(~e[(u+3)%4]&e[(u+1)%4]),l--},c=function(e){for(u=3;u>=0;u--)e[u]-=g[63&e[(u+3)%4]]});var y=function(e){var t=[];for(u=0;u<4;u++){var i=f.getInt16Le();null!==p&&(r?i^=p.getInt16Le():p.putInt16Le(i)),t.push(65535&i)}l=r?0:63;for(var n=0;n=8;)y([[5,n],[1,c],[6,n],[1,c],[5,n]])},finish:function(e){var t=!0;if(r)if(e)t=e(8,f,!r);else{var i=8===f.length()?8:8-f.length();f.fillWithByte(i,i)}if(t&&(d=!0,m.update()),!r&&(t=0===f.length()))if(e)t=e(8,h,!r);else{var n=h.length(),s=h.at(n-1);s>n?t=!1:h.truncate(s)}return t}}};i.rc2.startEncrypting=function(e,t,r){var n=i.rc2.createEncryptionCipher(e,128);return n.start(t,r),n},i.rc2.createEncryptionCipher=function(e,t){return c(e,t,!0)},i.rc2.startDecrypting=function(e,t,r){var n=i.rc2.createDecryptionCipher(e,128);return n.start(t,r),n},i.rc2.createDecryptionCipher=function(e,t){return c(e,t,!1)}},{"./forge":"4OuPD","./util":"df43p"}],"9ROH2":[function(e,t,r){var i=e("./forge");if(e("./asn1"),e("./jsbn"),e("./oids"),e("./pkcs1"),e("./prime"),e("./random"),e("./util"),void 0===n)var n=i.jsbn.BigInteger;var s=i.util.isNodejs?e("crypto"):null,o=i.asn1,a=i.util;i.pki=i.pki||{},t.exports=i.pki.rsa=i.rsa=i.rsa||{};var c=i.pki,u=[6,4,2,4,2,4,6,2],l={name:"PrivateKeyInfo",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"PrivateKeyInfo.version",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyVersion"},{name:"PrivateKeyInfo.privateKeyAlgorithm",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:o.Class.UNIVERSAL,type:o.Type.OID,constructed:!1,capture:"privateKeyOid"}]},{name:"PrivateKeyInfo",tagClass:o.Class.UNIVERSAL,type:o.Type.OCTETSTRING,constructed:!1,capture:"privateKey"}]},d={name:"RSAPrivateKey",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"RSAPrivateKey.version",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyVersion"},{name:"RSAPrivateKey.modulus",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyModulus"},{name:"RSAPrivateKey.publicExponent",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyPublicExponent"},{name:"RSAPrivateKey.privateExponent",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyPrivateExponent"},{name:"RSAPrivateKey.prime1",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyPrime1"},{name:"RSAPrivateKey.prime2",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyPrime2"},{name:"RSAPrivateKey.exponent1",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyExponent1"},{name:"RSAPrivateKey.exponent2",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyExponent2"},{name:"RSAPrivateKey.coefficient",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"privateKeyCoefficient"}]},f={name:"RSAPublicKey",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"RSAPublicKey.modulus",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"publicKeyModulus"},{name:"RSAPublicKey.exponent",tagClass:o.Class.UNIVERSAL,type:o.Type.INTEGER,constructed:!1,capture:"publicKeyExponent"}]},h=i.pki.rsa.publicKeyValidator={name:"SubjectPublicKeyInfo",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,captureAsn1:"subjectPublicKeyInfo",value:[{name:"SubjectPublicKeyInfo.AlgorithmIdentifier",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:o.Class.UNIVERSAL,type:o.Type.OID,constructed:!1,capture:"publicKeyOid"}]},{name:"SubjectPublicKeyInfo.subjectPublicKey",tagClass:o.Class.UNIVERSAL,type:o.Type.BITSTRING,constructed:!1,value:[{name:"SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey",tagClass:o.Class.UNIVERSAL,type:o.Type.SEQUENCE,constructed:!0,optional:!0,captureAsn1:"rsaPublicKey"}]}]},p=function(e){var t;if(!(e.algorithm in c.oids)){var r=new Error("Unknown message digest algorithm.");throw r.algorithm=e.algorithm,r}t=c.oids[e.algorithm];var i=o.oidToDer(t).getBytes(),n=o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[]),s=o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[]);s.value.push(o.create(o.Class.UNIVERSAL,o.Type.OID,!1,i)),s.value.push(o.create(o.Class.UNIVERSAL,o.Type.NULL,!1,""));var a=o.create(o.Class.UNIVERSAL,o.Type.OCTETSTRING,!1,e.digest().getBytes());return n.value.push(s),n.value.push(a),o.toDer(n).getBytes()},g=function(e,t,r){if(r)return e.modPow(t.e,t.n);if(!t.p||!t.q)return e.modPow(t.d,t.n);var s;t.dP||(t.dP=t.d.mod(t.p.subtract(n.ONE))),t.dQ||(t.dQ=t.d.mod(t.q.subtract(n.ONE))),t.qInv||(t.qInv=t.q.modInverse(t.p));do{s=new n(i.util.bytesToHex(i.random.getBytes(t.n.bitLength()/8)),16)}while(s.compareTo(t.n)>=0||!s.gcd(t.n).equals(n.ONE));for(var o=(e=e.multiply(s.modPow(t.e,t.n)).mod(t.n)).mod(t.p).modPow(t.dP,t.p),a=e.mod(t.q).modPow(t.dQ,t.q);o.compareTo(a)<0;)o=o.add(t.p);var c=o.subtract(a).multiply(t.qInv).mod(t.p).multiply(t.q).add(a);return c=c.multiply(s.modInverse(t.n)).mod(t.n)};function y(e,t,r){var n=i.util.createBuffer(),s=Math.ceil(t.n.bitLength()/8);if(e.length>s-11){var o=new Error("Message is too long for PKCS#1 v1.5 padding.");throw o.length=e.length,o.max=s-11,o}n.putByte(0),n.putByte(r);var a,c=s-3-e.length;if(0===r||1===r){a=0===r?0:255;for(var u=0;u0;){var l=0,d=i.random.getBytes(c);for(u=0;u1;){if(255!==o.getByte()){--o.read;break}++u}else if(2===c)for(u=0;o.length()>1;){if(0===o.getByte()){--o.read;break}++u}if(0!==o.getByte()||u!==s-3-o.length())throw new Error("Encryption block is invalid.");return o.getBytes()}function b(e,t,r){"function"==typeof t&&(r=t,t={});var s={algorithm:{name:(t=t||{}).algorithm||"PRIMEINC",options:{workers:t.workers||2,workLoad:t.workLoad||100,workerScript:t.workerScript}}};function o(){a(e.pBits,(function(t,i){return t?r(t):(e.p=i,null!==e.q?u(t,e.q):void a(e.qBits,u))}))}function a(e,t){i.prime.generateProbablePrime(e,s,t)}function u(t,i){if(t)return r(t);if(e.q=i,e.p.compareTo(e.q)<0){var s=e.p;e.p=e.q,e.q=s}if(0!==e.p.subtract(n.ONE).gcd(e.e).compareTo(n.ONE))return e.p=null,void o();if(0!==e.q.subtract(n.ONE).gcd(e.e).compareTo(n.ONE))return e.q=null,void a(e.qBits,u);if(e.p1=e.p.subtract(n.ONE),e.q1=e.q.subtract(n.ONE),e.phi=e.p1.multiply(e.q1),0!==e.phi.gcd(e.e).compareTo(n.ONE))return e.p=e.q=null,void o();if(e.n=e.p.multiply(e.q),e.n.bitLength()!==e.bits)return e.q=null,void a(e.qBits,u);var l=e.e.modInverse(e.phi);e.keys={privateKey:c.rsa.setPrivateKey(e.n,e.e,l,e.p,e.q,l.mod(e.p1),l.mod(e.q1),e.q.modInverse(e.p)),publicKey:c.rsa.setPublicKey(e.n,e.e)},r(null,e.keys)}"prng"in t&&(s.prng=t.prng),o()}function v(e){var t=e.toString(16);t[0]>="8"&&(t="00"+t);var r=i.util.hexToBytes(t);return r.length>1&&(0===r.charCodeAt(0)&&0==(128&r.charCodeAt(1))||255===r.charCodeAt(0)&&128==(128&r.charCodeAt(1)))?r.substr(1):r}function w(e){return e<=100?27:e<=150?18:e<=200?15:e<=250?12:e<=300?9:e<=350?8:e<=400?7:e<=500?6:e<=600?5:e<=800?4:e<=1250?3:2}function _(e){return i.util.isNodejs&&"function"==typeof s[e]}function E(e){return void 0!==a.globalScope&&"object"==typeof a.globalScope.crypto&&"object"==typeof a.globalScope.crypto.subtle&&"function"==typeof a.globalScope.crypto.subtle[e]}function S(e){return void 0!==a.globalScope&&"object"==typeof a.globalScope.msCrypto&&"object"==typeof a.globalScope.msCrypto.subtle&&"function"==typeof a.globalScope.msCrypto.subtle[e]}function T(e){for(var t=i.util.hexToBytes(e.toString(16)),r=new Uint8Array(t.length),n=0;n0;)l.putByte(0),--d;return l.putBytes(i.util.hexToBytes(u)),l.getBytes()},c.rsa.decrypt=function(e,t,r,s){var o=Math.ceil(t.n.bitLength()/8);if(e.length!==o){var a=new Error("Encrypted message length is invalid.");throw a.length=e.length,a.expected=o,a}var c=new n(i.util.createBuffer(e).toHex(),16);if(c.compareTo(t.n)>=0)throw new Error("Encrypted message is invalid.");for(var u=g(c,t,r).toString(16),l=i.util.createBuffer(),d=o-Math.ceil(u.length/2);d>0;)l.putByte(0),--d;return l.putBytes(i.util.hexToBytes(u)),!1!==s?m(l.getBytes(),t,r):l.getBytes()},c.rsa.createKeyPairGenerationState=function(e,t,r){"string"==typeof e&&(e=parseInt(e,10)),e=e||2048;var s,o=(r=r||{}).prng||i.random,a={nextBytes:function(e){for(var t=o.getBytesSync(e.length),r=0;r>1,pBits:e-(e>>1),pqState:0,num:null,keys:null}).e.fromInt(s.eInt),s},c.rsa.stepKeyPairGenerationState=function(e,t){"algorithm"in e||(e.algorithm="PRIMEINC");var r=new n(null);r.fromInt(30);for(var i,s=0,o=function(e,t){return e|t},a=+new Date,l=0;null===e.keys&&(t<=0||ld?e.pqState=0:e.num.isProbablePrime(w(e.num.bitLength()))?++e.pqState:e.num.dAddOffset(u[s++%8],0):2===e.pqState?e.pqState=0===e.num.subtract(n.ONE).gcd(e.e).compareTo(n.ONE)?3:0:3===e.pqState&&(e.pqState=0,null===e.p?e.p=e.num:e.q=e.num,null!==e.p&&null!==e.q&&++e.state,e.num=null)}else if(1===e.state)e.p.compareTo(e.q)<0&&(e.num=e.p,e.p=e.q,e.q=e.num),++e.state;else if(2===e.state)e.p1=e.p.subtract(n.ONE),e.q1=e.q.subtract(n.ONE),e.phi=e.p1.multiply(e.q1),++e.state;else if(3===e.state)0===e.phi.gcd(e.e).compareTo(n.ONE)?++e.state:(e.p=null,e.q=null,e.state=0);else if(4===e.state)e.n=e.p.multiply(e.q),e.n.bitLength()===e.bits?++e.state:(e.q=null,e.state=0);else if(5===e.state){var h=e.e.modInverse(e.phi);e.keys={privateKey:c.rsa.setPrivateKey(e.n,e.e,h,e.p,e.q,h.mod(e.p1),h.mod(e.q1),e.q.modInverse(e.p)),publicKey:c.rsa.setPublicKey(e.n,e.e)}}l+=(i=+new Date)-a,a=i}return null!==e.keys},c.rsa.generateKeyPair=function(e,t,r,n){if(1===arguments.length?"object"==typeof e?(r=e,e=void 0):"function"==typeof e&&(n=e,e=void 0):2===arguments.length?"number"==typeof e?"function"==typeof t?(n=t,t=void 0):"number"!=typeof t&&(r=t,t=void 0):(r=e,n=t,e=void 0,t=void 0):3===arguments.length&&("number"==typeof t?"function"==typeof r&&(n=r,r=void 0):(n=r,r=t,t=void 0)),r=r||{},void 0===e&&(e=r.bits||2048),void 0===t&&(t=r.e||65537),!i.options.usePureJavaScript&&!r.prng&&e>=256&&e<=16384&&(65537===t||3===t))if(n){if(_("generateKeyPair"))return s.generateKeyPair("rsa",{modulusLength:e,publicExponent:t,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}},(function(e,t,r){if(e)return n(e);n(null,{privateKey:c.privateKeyFromPem(r),publicKey:c.publicKeyFromPem(t)})}));if(E("generateKey")&&E("exportKey"))return a.globalScope.crypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:T(t),hash:{name:"SHA-256"}},!0,["sign","verify"]).then((function(e){return a.globalScope.crypto.subtle.exportKey("pkcs8",e.privateKey)})).then(void 0,(function(e){n(e)})).then((function(e){if(e){var t=c.privateKeyFromAsn1(o.fromDer(i.util.createBuffer(e)));n(null,{privateKey:t,publicKey:c.setRsaPublicKey(t.n,t.e)})}}));if(S("generateKey")&&S("exportKey")){var u=a.globalScope.msCrypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:T(t),hash:{name:"SHA-256"}},!0,["sign","verify"]);return u.oncomplete=function(e){var t=e.target.result,r=a.globalScope.msCrypto.subtle.exportKey("pkcs8",t.privateKey);r.oncomplete=function(e){var t=e.target.result,r=c.privateKeyFromAsn1(o.fromDer(i.util.createBuffer(t)));n(null,{privateKey:r,publicKey:c.setRsaPublicKey(r.n,r.e)})},r.onerror=function(e){n(e)}},void(u.onerror=function(e){n(e)})}}else if(_("generateKeyPairSync")){var l=s.generateKeyPairSync("rsa",{modulusLength:e,publicExponent:t,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{privateKey:c.privateKeyFromPem(l.privateKey),publicKey:c.publicKeyFromPem(l.publicKey)}}var d=c.rsa.createKeyPairGenerationState(e,t,r);if(!n)return c.rsa.stepKeyPairGenerationState(d,0),d.keys;b(d,r,n)},c.setRsaPublicKey=c.rsa.setPublicKey=function(e,t){var r={n:e,e:t,encrypt:function(e,t,n){if("string"==typeof t?t=t.toUpperCase():void 0===t&&(t="RSAES-PKCS1-V1_5"),"RSAES-PKCS1-V1_5"===t)t={encode:function(e,t,r){return y(e,t,2).getBytes()}};else if("RSA-OAEP"===t||"RSAES-OAEP"===t)t={encode:function(e,t){return i.pkcs1.encode_rsa_oaep(t,e,n)}};else if(-1!==["RAW","NONE","NULL",null].indexOf(t))t={encode:function(e){return e}};else if("string"==typeof t)throw new Error('Unsupported encryption scheme: "'+t+'".');var s=t.encode(e,r,!0);return c.rsa.encrypt(s,r,!0)},verify:function(e,t,i){"string"==typeof i?i=i.toUpperCase():void 0===i&&(i="RSASSA-PKCS1-V1_5"),"RSASSA-PKCS1-V1_5"===i?i={verify:function(e,t){return t=m(t,r,!0),e===o.fromDer(t).value[1].value}}:"NONE"!==i&&"NULL"!==i&&null!==i||(i={verify:function(e,t){return e===(t=m(t,r,!0))}});var n=c.rsa.decrypt(t,r,!0,!1);return i.verify(e,n,r.n.bitLength())}};return r},c.setRsaPrivateKey=c.rsa.setPrivateKey=function(e,t,r,n,s,o,a,u){var l={n:e,e:t,d:r,p:n,q:s,dP:o,dQ:a,qInv:u,decrypt:function(e,t,r){"string"==typeof t?t=t.toUpperCase():void 0===t&&(t="RSAES-PKCS1-V1_5");var n=c.rsa.decrypt(e,l,!1,!1);if("RSAES-PKCS1-V1_5"===t)t={decode:m};else if("RSA-OAEP"===t||"RSAES-OAEP"===t)t={decode:function(e,t){return i.pkcs1.decode_rsa_oaep(t,e,r)}};else{if(-1===["RAW","NONE","NULL",null].indexOf(t))throw new Error('Unsupported encryption scheme: "'+t+'".');t={decode:function(e){return e}}}return t.decode(n,l,!1)},sign:function(e,t){var r=!1;"string"==typeof t&&(t=t.toUpperCase()),void 0===t||"RSASSA-PKCS1-V1_5"===t?(t={encode:p},r=1):"NONE"!==t&&"NULL"!==t&&null!==t||(t={encode:function(){return e}},r=1);var i=t.encode(e,l.n.bitLength());return c.rsa.encrypt(i,l,r)}};return l},c.wrapRsaPrivateKey=function(e){return o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,o.integerToDer(0).getBytes()),o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.OID,!1,o.oidToDer(c.oids.rsaEncryption).getBytes()),o.create(o.Class.UNIVERSAL,o.Type.NULL,!1,"")]),o.create(o.Class.UNIVERSAL,o.Type.OCTETSTRING,!1,o.toDer(e).getBytes())])},c.privateKeyFromAsn1=function(e){var t,r,s,a,u,f,h,p,g={},y=[];if(o.validate(e,l,g,y)&&(e=o.fromDer(i.util.createBuffer(g.privateKey))),g={},y=[],!o.validate(e,d,g,y)){var m=new Error("Cannot read private key. ASN.1 object does not contain an RSAPrivateKey.");throw m.errors=y,m}return t=i.util.createBuffer(g.privateKeyModulus).toHex(),r=i.util.createBuffer(g.privateKeyPublicExponent).toHex(),s=i.util.createBuffer(g.privateKeyPrivateExponent).toHex(),a=i.util.createBuffer(g.privateKeyPrime1).toHex(),u=i.util.createBuffer(g.privateKeyPrime2).toHex(),f=i.util.createBuffer(g.privateKeyExponent1).toHex(),h=i.util.createBuffer(g.privateKeyExponent2).toHex(),p=i.util.createBuffer(g.privateKeyCoefficient).toHex(),c.setRsaPrivateKey(new n(t,16),new n(r,16),new n(s,16),new n(a,16),new n(u,16),new n(f,16),new n(h,16),new n(p,16))},c.privateKeyToAsn1=c.privateKeyToRSAPrivateKey=function(e){return o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,o.integerToDer(0).getBytes()),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.n)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.e)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.d)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.p)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.q)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.dP)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.dQ)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.qInv))])},c.publicKeyFromAsn1=function(e){var t={},r=[];if(o.validate(e,h,t,r)){var s,a=o.derToOid(t.publicKeyOid);if(a!==c.oids.rsaEncryption)throw(s=new Error("Cannot read public key. Unknown OID.")).oid=a,s;e=t.rsaPublicKey}if(r=[],!o.validate(e,f,t,r))throw(s=new Error("Cannot read public key. ASN.1 object does not contain an RSAPublicKey.")).errors=r,s;var u=i.util.createBuffer(t.publicKeyModulus).toHex(),l=i.util.createBuffer(t.publicKeyExponent).toHex();return c.setRsaPublicKey(new n(u,16),new n(l,16))},c.publicKeyToAsn1=c.publicKeyToSubjectPublicKeyInfo=function(e){return o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.OID,!1,o.oidToDer(c.oids.rsaEncryption).getBytes()),o.create(o.Class.UNIVERSAL,o.Type.NULL,!1,"")]),o.create(o.Class.UNIVERSAL,o.Type.BITSTRING,!1,[c.publicKeyToRSAPublicKey(e)])])},c.publicKeyToRSAPublicKey=function(e){return o.create(o.Class.UNIVERSAL,o.Type.SEQUENCE,!0,[o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.n)),o.create(o.Class.UNIVERSAL,o.Type.INTEGER,!1,v(e.e))])}},{"./forge":"4OuPD","./asn1":"bcsXQ","./jsbn":"eeS3U","./oids":"7VPL4","./pkcs1":"2vXck","./prime":"ZaXlg","./random":"3tULm","./util":"df43p",crypto:"lHksA"}],eeS3U:[function(e,t,r){var i,n=e("./forge");t.exports=n.jsbn=n.jsbn||{};function s(e,t,r){this.data=[],null!=e&&("number"==typeof e?this.fromNumber(e,t,r):null==t&&"string"!=typeof e?this.fromString(e,256):this.fromString(e,t))}function o(){return new s(null)}function a(e,t,r,i,n,s){for(var o=16383&t,a=t>>14;--s>=0;){var c=16383&this.data[e],u=this.data[e++]>>14,l=a*c+u*o;n=((c=o*c+((16383&l)<<14)+r.data[i]+n)>>28)+(l>>14)+a*u,r.data[i++]=268435455&c}return n}n.jsbn.BigInteger=s,"undefined"==typeof navigator?(s.prototype.am=a,i=28):"Microsoft Internet Explorer"==navigator.appName?(s.prototype.am=function(e,t,r,i,n,s){for(var o=32767&t,a=t>>15;--s>=0;){var c=32767&this.data[e],u=this.data[e++]>>15,l=a*c+u*o;n=((c=o*c+((32767&l)<<15)+r.data[i]+(1073741823&n))>>>30)+(l>>>15)+a*u+(n>>>30),r.data[i++]=1073741823&c}return n},i=30):"Netscape"!=navigator.appName?(s.prototype.am=function(e,t,r,i,n,s){for(;--s>=0;){var o=t*this.data[e++]+r.data[i]+n;n=Math.floor(o/67108864),r.data[i++]=67108863&o}return n},i=26):(s.prototype.am=a,i=28),s.prototype.DB=i,s.prototype.DM=(1<>>16)&&(e=t,r+=16),0!=(t=e>>8)&&(e=t,r+=8),0!=(t=e>>4)&&(e=t,r+=4),0!=(t=e>>2)&&(e=t,r+=2),0!=(t=e>>1)&&(e=t,r+=1),r}function g(e){this.m=e}function y(e){this.m=e,this.mp=e.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,t+=16),0==(255&e)&&(e>>=8,t+=8),0==(15&e)&&(e>>=4,t+=4),0==(3&e)&&(e>>=2,t+=2),0==(1&e)&&++t,t}function E(e){for(var t=0;0!=e;)e&=e-1,++t;return t}function S(){}function T(e){return e}function A(e){this.r2=o(),this.q3=o(),s.ONE.dlShiftTo(2*e.t,this.r2),this.mu=this.r2.divide(e),this.m=e}g.prototype.convert=function(e){return e.s<0||e.compareTo(this.m)>=0?e.mod(this.m):e},g.prototype.revert=function(e){return e},g.prototype.reduce=function(e){e.divRemTo(this.m,null,e)},g.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r),this.reduce(r)},g.prototype.sqrTo=function(e,t){e.squareTo(t),this.reduce(t)},y.prototype.convert=function(e){var t=o();return e.abs().dlShiftTo(this.m.t,t),t.divRemTo(this.m,null,t),e.s<0&&t.compareTo(s.ZERO)>0&&this.m.subTo(t,t),t},y.prototype.revert=function(e){var t=o();return e.copyTo(t),this.reduce(t),t},y.prototype.reduce=function(e){for(;e.t<=this.mt2;)e.data[e.t++]=0;for(var t=0;t>15)*this.mpl&this.um)<<15)&e.DM;for(r=t+this.m.t,e.data[r]+=this.m.am(0,i,e,t,0,this.m.t);e.data[r]>=e.DV;)e.data[r]-=e.DV,e.data[++r]++}e.clamp(),e.drShiftTo(this.m.t,e),e.compareTo(this.m)>=0&&e.subTo(this.m,e)},y.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r),this.reduce(r)},y.prototype.sqrTo=function(e,t){e.squareTo(t),this.reduce(t)},s.prototype.copyTo=function(e){for(var t=this.t-1;t>=0;--t)e.data[t]=this.data[t];e.t=this.t,e.s=this.s},s.prototype.fromInt=function(e){this.t=1,this.s=e<0?-1:0,e>0?this.data[0]=e:e<-1?this.data[0]=e+this.DV:this.t=0},s.prototype.fromString=function(e,t){var r;if(16==t)r=4;else if(8==t)r=3;else if(256==t)r=8;else if(2==t)r=1;else if(32==t)r=5;else{if(4!=t)return void this.fromRadix(e,t);r=2}this.t=0,this.s=0;for(var i=e.length,n=!1,o=0;--i>=0;){var a=8==r?255&e[i]:f(e,i);a<0?"-"==e.charAt(i)&&(n=!0):(n=!1,0==o?this.data[this.t++]=a:o+r>this.DB?(this.data[this.t-1]|=(a&(1<>this.DB-o):this.data[this.t-1]|=a<=this.DB&&(o-=this.DB))}8==r&&0!=(128&e[0])&&(this.s=-1,o>0&&(this.data[this.t-1]|=(1<0&&this.data[this.t-1]==e;)--this.t},s.prototype.dlShiftTo=function(e,t){var r;for(r=this.t-1;r>=0;--r)t.data[r+e]=this.data[r];for(r=e-1;r>=0;--r)t.data[r]=0;t.t=this.t+e,t.s=this.s},s.prototype.drShiftTo=function(e,t){for(var r=e;r=0;--r)t.data[r+o+1]=this.data[r]>>n|a,a=(this.data[r]&s)<=0;--r)t.data[r]=0;t.data[o]=a,t.t=this.t+o+1,t.s=this.s,t.clamp()},s.prototype.rShiftTo=function(e,t){t.s=this.s;var r=Math.floor(e/this.DB);if(r>=this.t)t.t=0;else{var i=e%this.DB,n=this.DB-i,s=(1<>i;for(var o=r+1;o>i;i>0&&(t.data[this.t-r-1]|=(this.s&s)<>=this.DB;if(e.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=e.s}t.s=i<0?-1:0,i<-1?t.data[r++]=this.DV+i:i>0&&(t.data[r++]=i),t.t=r,t.clamp()},s.prototype.multiplyTo=function(e,t){var r=this.abs(),i=e.abs(),n=r.t;for(t.t=n+i.t;--n>=0;)t.data[n]=0;for(n=0;n=0;)e.data[r]=0;for(r=0;r=t.DV&&(e.data[r+t.t]-=t.DV,e.data[r+t.t+1]=1)}e.t>0&&(e.data[e.t-1]+=t.am(r,t.data[r],e,2*r,0,1)),e.s=0,e.clamp()},s.prototype.divRemTo=function(e,t,r){var i=e.abs();if(!(i.t<=0)){var n=this.abs();if(n.t0?(i.lShiftTo(l,a),n.lShiftTo(l,r)):(i.copyTo(a),n.copyTo(r));var d=a.t,f=a.data[d-1];if(0!=f){var h=f*(1<1?a.data[d-2]>>this.F2:0),g=this.FV/h,y=(1<=0&&(r.data[r.t++]=1,r.subTo(w,r)),s.ONE.dlShiftTo(d,w),w.subTo(a,a);a.t=0;){var _=r.data[--b]==f?this.DM:Math.floor(r.data[b]*g+(r.data[b-1]+m)*y);if((r.data[b]+=a.am(0,_,r,v,0,d))<_)for(a.dlShiftTo(v,w),r.subTo(w,r);r.data[b]<--_;)r.subTo(w,r)}null!=t&&(r.drShiftTo(d,t),c!=u&&s.ZERO.subTo(t,t)),r.t=d,r.clamp(),l>0&&r.rShiftTo(l,r),c<0&&s.ZERO.subTo(r,r)}}},s.prototype.invDigit=function(){if(this.t<1)return 0;var e=this.data[0];if(0==(1&e))return 0;var t=3&e;return(t=(t=(t=(t=t*(2-(15&e)*t)&15)*(2-(255&e)*t)&255)*(2-((65535&e)*t&65535))&65535)*(2-e*t%this.DV)%this.DV)>0?this.DV-t:-t},s.prototype.isEven=function(){return 0==(this.t>0?1&this.data[0]:this.s)},s.prototype.exp=function(e,t){if(e>4294967295||e<1)return s.ONE;var r=o(),i=o(),n=t.convert(this),a=p(e)-1;for(n.copyTo(r);--a>=0;)if(t.sqrTo(r,i),(e&1<0)t.mulTo(i,n,r);else{var c=r;r=i,i=c}return t.revert(r)},s.prototype.toString=function(e){if(this.s<0)return"-"+this.negate().toString(e);var t;if(16==e)t=4;else if(8==e)t=3;else if(2==e)t=1;else if(32==e)t=5;else{if(4!=e)return this.toRadix(e);t=2}var r,i=(1<0)for(a>a)>0&&(n=!0,s=d(r));o>=0;)a>(a+=this.DB-t)):(r=this.data[o]>>(a-=t)&i,a<=0&&(a+=this.DB,--o)),r>0&&(n=!0),n&&(s+=d(r));return n?s:"0"},s.prototype.negate=function(){var e=o();return s.ZERO.subTo(this,e),e},s.prototype.abs=function(){return this.s<0?this.negate():this},s.prototype.compareTo=function(e){var t=this.s-e.s;if(0!=t)return t;var r=this.t;if(0!=(t=r-e.t))return this.s<0?-t:t;for(;--r>=0;)if(0!=(t=this.data[r]-e.data[r]))return t;return 0},s.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+p(this.data[this.t-1]^this.s&this.DM)},s.prototype.mod=function(e){var t=o();return this.abs().divRemTo(e,null,t),this.s<0&&t.compareTo(s.ZERO)>0&&e.subTo(t,t),t},s.prototype.modPowInt=function(e,t){var r;return r=e<256||t.isEven()?new g(t):new y(t),this.exp(e,r)},s.ZERO=h(0),s.ONE=h(1),S.prototype.convert=T,S.prototype.revert=T,S.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r)},S.prototype.sqrTo=function(e,t){e.squareTo(t)},A.prototype.convert=function(e){if(e.s<0||e.t>2*this.m.t)return e.mod(this.m);if(e.compareTo(this.m)<0)return e;var t=o();return e.copyTo(t),this.reduce(t),t},A.prototype.revert=function(e){return e},A.prototype.reduce=function(e){for(e.drShiftTo(this.m.t-1,this.r2),e.t>this.m.t+1&&(e.t=this.m.t+1,e.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);e.compareTo(this.r2)<0;)e.dAddOffset(1,this.m.t+1);for(e.subTo(this.r2,e);e.compareTo(this.m)>=0;)e.subTo(this.m,e)},A.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r),this.reduce(r)},A.prototype.sqrTo=function(e,t){e.squareTo(t),this.reduce(t)};var k=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509],I=67108864/k[k.length-1];s.prototype.chunkSize=function(e){return Math.floor(Math.LN2*this.DB/Math.log(e))},s.prototype.toRadix=function(e){if(null==e&&(e=10),0==this.signum()||e<2||e>36)return"0";var t=this.chunkSize(e),r=Math.pow(e,t),i=h(r),n=o(),s=o(),a="";for(this.divRemTo(i,n,s);n.signum()>0;)a=(r+s.intValue()).toString(e).substr(1)+a,n.divRemTo(i,n,s);return s.intValue().toString(e)+a},s.prototype.fromRadix=function(e,t){this.fromInt(0),null==t&&(t=10);for(var r=this.chunkSize(t),i=Math.pow(t,r),n=!1,o=0,a=0,c=0;c=r&&(this.dMultiply(i),this.dAddOffset(a,0),o=0,a=0))}o>0&&(this.dMultiply(Math.pow(t,o)),this.dAddOffset(a,0)),n&&s.ZERO.subTo(this,this)},s.prototype.fromNumber=function(e,t,r){if("number"==typeof t)if(e<2)this.fromInt(1);else for(this.fromNumber(e,r),this.testBit(e-1)||this.bitwiseTo(s.ONE.shiftLeft(e-1),b,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(t);)this.dAddOffset(2,0),this.bitLength()>e&&this.subTo(s.ONE.shiftLeft(e-1),this);else{var i=new Array,n=7&e;i.length=1+(e>>3),t.nextBytes(i),n>0?i[0]&=(1<>=this.DB;if(e.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=e.s}t.s=i<0?-1:0,i>0?t.data[r++]=i:i<-1&&(t.data[r++]=this.DV+i),t.t=r,t.clamp()},s.prototype.dMultiply=function(e){this.data[this.t]=this.am(0,e-1,this,0,0,this.t),++this.t,this.clamp()},s.prototype.dAddOffset=function(e,t){if(0!=e){for(;this.t<=t;)this.data[this.t++]=0;for(this.data[t]+=e;this.data[t]>=this.DV;)this.data[t]-=this.DV,++t>=this.t&&(this.data[this.t++]=0),++this.data[t]}},s.prototype.multiplyLowerTo=function(e,t,r){var i,n=Math.min(this.t+e.t,t);for(r.s=0,r.t=n;n>0;)r.data[--n]=0;for(i=r.t-this.t;n=0;)r.data[i]=0;for(i=Math.max(t-this.t,0);i0)if(0==t)r=this.data[0]%e;else for(var i=this.t-1;i>=0;--i)r=(t*r+this.data[i])%e;return r},s.prototype.millerRabin=function(e){var t=this.subtract(s.ONE),r=t.getLowestSetBit();if(r<=0)return!1;for(var i,n=t.shiftRight(r),o={nextBytes:function(e){for(var t=0;t=0);var c=i.modPow(n,this);if(0!=c.compareTo(s.ONE)&&0!=c.compareTo(t)){for(var u=1;u++>24},s.prototype.shortValue=function(){return 0==this.t?this.s:this.data[0]<<16>>16},s.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this.data[0]<=0?0:1},s.prototype.toByteArray=function(){var e=this.t,t=new Array;t[0]=this.s;var r,i=this.DB-e*this.DB%8,n=0;if(e-- >0)for(i>i)!=(this.s&this.DM)>>i&&(t[n++]=r|this.s<=0;)i<8?(r=(this.data[e]&(1<>(i+=this.DB-8)):(r=this.data[e]>>(i-=8)&255,i<=0&&(i+=this.DB,--e)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(t[n++]=r);return t},s.prototype.equals=function(e){return 0==this.compareTo(e)},s.prototype.min=function(e){return this.compareTo(e)<0?this:e},s.prototype.max=function(e){return this.compareTo(e)>0?this:e},s.prototype.and=function(e){var t=o();return this.bitwiseTo(e,m,t),t},s.prototype.or=function(e){var t=o();return this.bitwiseTo(e,b,t),t},s.prototype.xor=function(e){var t=o();return this.bitwiseTo(e,v,t),t},s.prototype.andNot=function(e){var t=o();return this.bitwiseTo(e,w,t),t},s.prototype.not=function(){for(var e=o(),t=0;t=this.t?0!=this.s:0!=(this.data[t]&1<1){var d=o();for(i.sqrTo(a[1],d);c<=l;)a[c]=o(),i.mulTo(d,a[c-2],a[c]),c+=2}var f,m,b=e.t-1,v=!0,w=o();for(n=p(e.data[b])-1;b>=0;){for(n>=u?f=e.data[b]>>n-u&l:(f=(e.data[b]&(1<0&&(f|=e.data[b-1]>>this.DB+n-u)),c=r;0==(1&f);)f>>=1,--c;if((n-=c)<0&&(n+=this.DB,--b),v)a[f].copyTo(s),v=!1;else{for(;c>1;)i.sqrTo(s,w),i.sqrTo(w,s),c-=2;c>0?i.sqrTo(s,w):(m=s,s=w,w=m),i.mulTo(w,a[f],s)}for(;b>=0&&0==(e.data[b]&1<=0?(r.subTo(i,r),t&&n.subTo(a,n),o.subTo(c,o)):(i.subTo(r,i),t&&a.subTo(n,a),c.subTo(o,c))}return 0!=i.compareTo(s.ONE)?s.ZERO:c.compareTo(e)>=0?c.subtract(e):c.signum()<0?(c.addTo(e,c),c.signum()<0?c.add(e):c):c},s.prototype.pow=function(e){return this.exp(e,new S)},s.prototype.gcd=function(e){var t=this.s<0?this.negate():this.clone(),r=e.s<0?e.negate():e.clone();if(t.compareTo(r)<0){var i=t;t=r,r=i}var n=t.getLowestSetBit(),s=r.getLowestSetBit();if(s<0)return t;for(n0&&(t.rShiftTo(s,t),r.rShiftTo(s,r));t.signum()>0;)(n=t.getLowestSetBit())>0&&t.rShiftTo(n,t),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),t.compareTo(r)>=0?(t.subTo(r,t),t.rShiftTo(1,t)):(r.subTo(t,r),r.rShiftTo(1,r));return s>0&&r.lShiftTo(s,r),r},s.prototype.isProbablePrime=function(e){var t,r=this.abs();if(1==r.t&&r.data[0]<=k[k.length-1]){for(t=0;t>24&255,o>>16&255,o>>8&255,255&o);r.start(),r.update(e+a),n+=r.digest().getBytes()}return n.substring(0,t)}n.encode_rsa_oaep=function(e,t,r){var n,o,a,c;"string"==typeof r?(n=r,o=arguments[3]||void 0,a=arguments[4]||void 0):r&&(n=r.label||void 0,o=r.seed||void 0,a=r.md||void 0,r.mgf1&&r.mgf1.md&&(c=r.mgf1.md)),a?a.start():a=i.md.sha1.create(),c||(c=a);var u=Math.ceil(e.n.bitLength()/8),l=u-2*a.digestLength-2;if(t.length>l)throw(y=new Error("RSAES-OAEP input message length is too long.")).length=t.length,y.maxLength=l,y;n||(n=""),a.update(n,"raw");for(var d=a.digest(),f="",h=l-t.length,p=0;p>>0,c>>>0];for(var u=n.fullMessageLength.length-1;u>=0;--u)n.fullMessageLength[u]+=c[1],c[1]=c[0]+(n.fullMessageLength[u]/4294967296>>>0),n.fullMessageLength[u]=n.fullMessageLength[u]>>>0,c[0]=c[1]/4294967296>>>0;return t.putBytes(s),a(e,r,t),(t.read>2048||0===t.length())&&t.compact(),n},n.digest=function(){var o=i.util.createBuffer();o.putBytes(t.bytes());var c,u=n.fullMessageLength[n.fullMessageLength.length-1]+n.messageLengthSize&n.blockLength-1;o.putBytes(s.substr(0,n.blockLength-u));for(var l=8*n.fullMessageLength[0],d=0;d>>0,o.putInt32(l>>>0),l=c>>>0;o.putInt32(l);var f={h0:e.h0,h1:e.h1,h2:e.h2,h3:e.h3,h4:e.h4};a(f,r,o);var h=i.util.createBuffer();return h.putInt32(f.h0),h.putInt32(f.h1),h.putInt32(f.h2),h.putInt32(f.h3),h.putInt32(f.h4),h},n};var s=null,o=!1;function a(e,t,r){for(var i,n,s,o,a,c,u,l=r.length();l>=64;){for(n=e.h0,s=e.h1,o=e.h2,a=e.h3,c=e.h4,u=0;u<16;++u)i=r.getInt32(),t[u]=i,i=(n<<5|n>>>27)+(a^s&(o^a))+c+1518500249+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<20;++u)i=(i=t[u-3]^t[u-8]^t[u-14]^t[u-16])<<1|i>>>31,t[u]=i,i=(n<<5|n>>>27)+(a^s&(o^a))+c+1518500249+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<32;++u)i=(i=t[u-3]^t[u-8]^t[u-14]^t[u-16])<<1|i>>>31,t[u]=i,i=(n<<5|n>>>27)+(s^o^a)+c+1859775393+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<40;++u)i=(i=t[u-6]^t[u-16]^t[u-28]^t[u-32])<<2|i>>>30,t[u]=i,i=(n<<5|n>>>27)+(s^o^a)+c+1859775393+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<60;++u)i=(i=t[u-6]^t[u-16]^t[u-28]^t[u-32])<<2|i>>>30,t[u]=i,i=(n<<5|n>>>27)+(s&o|a&(s^o))+c+2400959708+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;for(;u<80;++u)i=(i=t[u-6]^t[u-16]^t[u-28]^t[u-32])<<2|i>>>30,t[u]=i,i=(n<<5|n>>>27)+(s^o^a)+c+3395469782+i,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=n,n=i;e.h0=e.h0+n|0,e.h1=e.h1+s|0,e.h2=e.h2+o|0,e.h3=e.h3+a|0,e.h4=e.h4+c|0,l-=64}}},{"./forge":"4OuPD","./md":"fYbz5","./util":"df43p"}],ZaXlg:[function(e,t,r){var i=e("./forge");e("./util"),e("./jsbn"),e("./random"),function(){if(i.prime)t.exports=i.prime;else{var e=t.exports=i.prime=i.prime||{},r=i.jsbn.BigInteger,n=[6,4,2,4,2,4,6,2],s=new r(null);s.fromInt(30);var o=function(e,t){return e|t};e.generateProbablePrime=function(e,t,n){"function"==typeof t&&(n=t,t={});var s=(t=t||{}).algorithm||"PRIMEINC";"string"==typeof s&&(s={name:s}),s.options=s.options||{};var o=t.prng||i.random,c={nextBytes:function(e){for(var t=o.getBytesSync(e.length),r=0;re&&(o=u(e,t));var h=o.toString(16);n.target.postMessage({hex:h,workLoad:l}),o.dAddOffset(d,0)}}}h()}(e,t,n,s):a(e,t,n,s)}(e,c,s.options,n);throw new Error("Invalid prime generation algorithm: "+s.name)}}function a(e,t,r,i){var n=u(e,t),s=function(e){return e<=100?27:e<=150?18:e<=200?15:e<=250?12:e<=300?9:e<=350?8:e<=400?7:e<=500?6:e<=600?5:e<=800?4:e<=1250?3:2}(n.bitLength());"millerRabinTests"in r&&(s=r.millerRabinTests);var o=10;"maxBlockTime"in r&&(o=r.maxBlockTime),c(n,e,t,0,s,o,i)}function c(e,t,r,s,o,a,l){var d=+new Date;do{if(e.bitLength()>t&&(e=u(t,r)),e.isProbablePrime(o))return l(null,e);e.dAddOffset(n[s++%8],0)}while(a<0||+new Date-d{const t=e.crypto||e.msCrypto;if(!t||!t.subtle)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p-crypto/blob/master/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}},{}],"1sbpX":[function(e,t,r){"use strict";const{sha256:i}=e("multiformats/hashes/sha2"),n=e("err-code"),{equals:s}=e("uint8arrays/equals"),{toString:o}=e("uint8arrays/to-string");e("node-forge/lib/sha512"),e("node-forge/lib/ed25519");const a=e("node-forge/lib/forge"),c=e("./rsa"),u=e("./keys"),l=e("./exporter");class d{constructor(e){this._key=e}async verify(e,t){return c.hashAndVerify(this._key,t,e)}marshal(){return c.utils.jwkToPkix(this._key)}get bytes(){return u.PublicKey.encode({Type:u.KeyType.RSA,Data:this.marshal()}).finish()}encrypt(e){return c.encrypt(this._key,e)}equals(e){return s(this.bytes,e.bytes)}async hash(){const{bytes:e}=await i.digest(this.bytes);return e}}class f{constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return c.getRandomValues(16)}async sign(e){return c.hashAndSign(this._key,e)}get public(){if(!this._publicKey)throw n(new Error("public key not provided"),"ERR_PUBKEY_NOT_PROVIDED");return new d(this._publicKey)}decrypt(e){return c.decrypt(this._key,e)}marshal(){return c.utils.jwkToPkcs1(this._key)}get bytes(){return u.PrivateKey.encode({Type:u.KeyType.RSA,Data:this.marshal()}).finish()}equals(e){return s(this.bytes,e.bytes)}async hash(){const{bytes:e}=await i.digest(this.bytes);return e}async id(){const e=await this.public.hash();return o(e,"base58btc")}async export(e,t="pkcs-8"){if("pkcs-8"===t){const t=new a.util.ByteBuffer(this.marshal()),r=a.asn1.fromDer(t),i=a.pki.privateKeyFromAsn1(r),n={algorithm:"aes256",count:1e4,saltSize:16,prfAlgorithm:"sha512"};return a.pki.encryptRsaPrivateKey(i,e,n)}if("libp2p-key"===t)return l.export(this.bytes,e);throw n(new Error(`export format '${t}' is not supported`),"ERR_INVALID_EXPORT_FORMAT")}}t.exports={RsaPublicKey:d,RsaPrivateKey:f,unmarshalRsaPublicKey:function(e){const t=c.utils.pkixToJwk(e);return new d(t)},unmarshalRsaPrivateKey:async function(e){const t=c.utils.pkcs1ToJwk(e),r=await c.unmarshalPrivateKey(t);return new f(r.privateKey,r.publicKey)},generateKeyPair:async function(e){const t=await c.generateKey(e);return new f(t.privateKey,t.publicKey)},fromJwk:async function(e){const t=await c.unmarshalPrivateKey(e);return new f(t.privateKey,t.publicKey)}}},{"multiformats/hashes/sha2":"7i9MT","err-code":"chZjB","uint8arrays/equals":"eY3cX","uint8arrays/to-string":"hC8JB","node-forge/lib/sha512":"9XKJ9","node-forge/lib/ed25519":"9HAE7","node-forge/lib/forge":"4OuPD","./rsa":"5a3He","./keys":"jWSTZ","./exporter":"8qVel"}],"9XKJ9":[function(e,t,r){var i=e("./forge");e("./md"),e("./util");var n=t.exports=i.sha512=i.sha512||{};i.md.sha512=i.md.algorithms.sha512=n;var s=i.sha384=i.sha512.sha384=i.sha512.sha384||{};s.create=function(){return n.create("SHA-384")},i.md.sha384=i.md.algorithms.sha384=s,i.sha512.sha256=i.sha512.sha256||{create:function(){return n.create("SHA-512/256")}},i.md["sha512/256"]=i.md.algorithms["sha512/256"]=i.sha512.sha256,i.sha512.sha224=i.sha512.sha224||{create:function(){return n.create("SHA-512/224")}},i.md["sha512/224"]=i.md.algorithms["sha512/224"]=i.sha512.sha224,n.create=function(e){if(a||(o=String.fromCharCode(128),o+=i.util.fillString(String.fromCharCode(0),128),c=[[1116352408,3609767458],[1899447441,602891725],[3049323471,3964484399],[3921009573,2173295548],[961987163,4081628472],[1508970993,3053834265],[2453635748,2937671579],[2870763221,3664609560],[3624381080,2734883394],[310598401,1164996542],[607225278,1323610764],[1426881987,3590304994],[1925078388,4068182383],[2162078206,991336113],[2614888103,633803317],[3248222580,3479774868],[3835390401,2666613458],[4022224774,944711139],[264347078,2341262773],[604807628,2007800933],[770255983,1495990901],[1249150122,1856431235],[1555081692,3175218132],[1996064986,2198950837],[2554220882,3999719339],[2821834349,766784016],[2952996808,2566594879],[3210313671,3203337956],[3336571891,1034457026],[3584528711,2466948901],[113926993,3758326383],[338241895,168717936],[666307205,1188179964],[773529912,1546045734],[1294757372,1522805485],[1396182291,2643833823],[1695183700,2343527390],[1986661051,1014477480],[2177026350,1206759142],[2456956037,344077627],[2730485921,1290863460],[2820302411,3158454273],[3259730800,3505952657],[3345764771,106217008],[3516065817,3606008344],[3600352804,1432725776],[4094571909,1467031594],[275423344,851169720],[430227734,3100823752],[506948616,1363258195],[659060556,3750685593],[883997877,3785050280],[958139571,3318307427],[1322822218,3812723403],[1537002063,2003034995],[1747873779,3602036899],[1955562222,1575990012],[2024104815,1125592928],[2227730452,2716904306],[2361852424,442776044],[2428436474,593698344],[2756734187,3733110249],[3204031479,2999351573],[3329325298,3815920427],[3391569614,3928383900],[3515267271,566280711],[3940187606,3454069534],[4118630271,4000239992],[116418474,1914138554],[174292421,2731055270],[289380356,3203993006],[460393269,320620315],[685471733,587496836],[852142971,1086792851],[1017036298,365543100],[1126000580,2618297676],[1288033470,3409855158],[1501505948,4234509866],[1607167915,987167468],[1816402316,1246189591]],(u={})["SHA-512"]=[[1779033703,4089235720],[3144134277,2227873595],[1013904242,4271175723],[2773480762,1595750129],[1359893119,2917565137],[2600822924,725511199],[528734635,4215389547],[1541459225,327033209]],u["SHA-384"]=[[3418070365,3238371032],[1654270250,914150663],[2438529370,812702999],[355462360,4144912697],[1731405415,4290775857],[2394180231,1750603025],[3675008525,1694076839],[1203062813,3204075428]],u["SHA-512/256"]=[[573645204,4230739756],[2673172387,3360449730],[596883563,1867755857],[2520282905,1497426621],[2519219938,2827943907],[3193839141,1401305490],[721525244,746961066],[246885852,2177182882]],u["SHA-512/224"]=[[2352822216,424955298],[1944164710,2312950998],[502970286,855612546],[1738396948,1479516111],[258812777,2077511080],[2011393907,79989058],[1067287976,1780299464],[286451373,2446758561]],a=!0),void 0===e&&(e="SHA-512"),!(e in u))throw new Error("Invalid SHA-512 algorithm: "+e);for(var t=u[e],r=null,n=i.util.createBuffer(),s=new Array(80),d=0;d<80;++d)s[d]=new Array(2);var f=64;switch(e){case"SHA-384":f=48;break;case"SHA-512/256":f=32;break;case"SHA-512/224":f=28}var h={algorithm:e.replace("-","").toLowerCase(),blockLength:128,digestLength:f,messageLength:0,fullMessageLength:null,messageLengthSize:16,start:function(){h.messageLength=0,h.fullMessageLength=h.messageLength128=[];for(var e=h.messageLengthSize/4,s=0;s>>0,o>>>0];for(var a=h.fullMessageLength.length-1;a>=0;--a)h.fullMessageLength[a]+=o[1],o[1]=o[0]+(h.fullMessageLength[a]/4294967296>>>0),h.fullMessageLength[a]=h.fullMessageLength[a]>>>0,o[0]=o[1]/4294967296>>>0;return n.putBytes(e),l(r,s,n),(n.read>2048||0===n.length())&&n.compact(),h},h.digest=function(){var t=i.util.createBuffer();t.putBytes(n.bytes());var a,c=h.fullMessageLength[h.fullMessageLength.length-1]+h.messageLengthSize&h.blockLength-1;t.putBytes(o.substr(0,h.blockLength-c));for(var u=8*h.fullMessageLength[0],d=0;d>>0,t.putInt32(u>>>0),u=a>>>0;t.putInt32(u);var f=new Array(r.length);for(d=0;d=128;){for(O=0;O<16;++O)t[O][0]=r.getInt32()>>>0,t[O][1]=r.getInt32()>>>0;for(;O<80;++O)i=(((C=(D=t[O-2])[0])>>>19|(j=D[1])<<13)^(j>>>29|C<<3)^C>>>6)>>>0,n=((C<<13|j>>>19)^(j<<3|C>>>29)^(C<<26|j>>>6))>>>0,s=(((C=(x=t[O-15])[0])>>>1|(j=x[1])<<31)^(C>>>8|j<<24)^C>>>7)>>>0,o=((C<<31|j>>>1)^(C<<24|j>>>8)^(C<<25|j>>>7))>>>0,M=t[O-7],B=t[O-16],j=n+M[1]+o+B[1],t[O][0]=i+M[0]+s+B[0]+(j/4294967296>>>0)>>>0,t[O][1]=j>>>0;for(p=e[0][0],g=e[0][1],y=e[1][0],m=e[1][1],b=e[2][0],v=e[2][1],w=e[3][0],_=e[3][1],E=e[4][0],S=e[4][1],T=e[5][0],A=e[5][1],k=e[6][0],I=e[6][1],R=e[7][0],P=e[7][1],O=0;O<80;++O)l=((E>>>14|S<<18)^(E>>>18|S<<14)^(S>>>9|E<<23))>>>0,d=(k^E&(T^k))>>>0,a=((p>>>28|g<<4)^(g>>>2|p<<30)^(g>>>7|p<<25))>>>0,u=((p<<4|g>>>28)^(g<<30|p>>>2)^(g<<25|p>>>7))>>>0,f=(p&y|b&(p^y))>>>0,h=(g&m|v&(g^m))>>>0,j=P+(((E<<18|S>>>14)^(E<<14|S>>>18)^(S<<23|E>>>9))>>>0)+((I^S&(A^I))>>>0)+c[O][1]+t[O][1],i=R+l+d+c[O][0]+t[O][0]+(j/4294967296>>>0)>>>0,n=j>>>0,s=a+f+((j=u+h)/4294967296>>>0)>>>0,o=j>>>0,R=k,P=I,k=T,I=A,T=E,A=S,E=w+i+((j=_+n)/4294967296>>>0)>>>0,S=j>>>0,w=b,_=v,b=y,v=m,y=p,m=g,p=i+s+((j=n+o)/4294967296>>>0)>>>0,g=j>>>0;j=e[0][1]+g,e[0][0]=e[0][0]+p+(j/4294967296>>>0)>>>0,e[0][1]=j>>>0,j=e[1][1]+m,e[1][0]=e[1][0]+y+(j/4294967296>>>0)>>>0,e[1][1]=j>>>0,j=e[2][1]+v,e[2][0]=e[2][0]+b+(j/4294967296>>>0)>>>0,e[2][1]=j>>>0,j=e[3][1]+_,e[3][0]=e[3][0]+w+(j/4294967296>>>0)>>>0,e[3][1]=j>>>0,j=e[4][1]+S,e[4][0]=e[4][0]+E+(j/4294967296>>>0)>>>0,e[4][1]=j>>>0,j=e[5][1]+A,e[5][0]=e[5][0]+T+(j/4294967296>>>0)>>>0,e[5][1]=j>>>0,j=e[6][1]+I,e[6][0]=e[6][0]+k+(j/4294967296>>>0)>>>0,e[6][1]=j>>>0,j=e[7][1]+P,e[7][0]=e[7][0]+R+(j/4294967296>>>0)>>>0,e[7][1]=j>>>0,L-=128}}},{"./forge":"4OuPD","./md":"fYbz5","./util":"df43p"}],"9HAE7":[function(e,t,r){var i=e("buffer").Buffer,n=e("./forge");e("./jsbn"),e("./random"),e("./sha512"),e("./util");var s=e("./asn1-validator"),o=s.publicKeyValidator,a=s.privateKeyValidator;if(void 0===c)var c=n.jsbn.BigInteger;var u=n.util.ByteBuffer,l=void 0===i?Uint8Array:i;n.pki=n.pki||{},t.exports=n.pki.ed25519=n.ed25519=n.ed25519||{};var d=n.ed25519;function f(e){var t=e.message;if(t instanceof Uint8Array||t instanceof l)return t;var r=e.encoding;if(void 0===t){if(!e.md)throw new TypeError('"options.message" or "options.md" not specified.');t=e.md.digest().getBytes(),r="binary"}if("string"==typeof t&&!r)throw new TypeError('"options.encoding" must be "binary" or "utf8".');if("string"==typeof t){if(void 0!==i)return i.from(t,r);t=new u(t,r)}else if(!(t instanceof u))throw new TypeError('"options.message" must be a node.js Buffer, a Uint8Array, a forge ByteBuffer, or a string with "options.encoding" specifying its encoding.');for(var n=new l(t.length()),s=0;s=0;--r)U(i,i),1!==r&&F(i,i,t);for(r=0;r<16;++r)e[r]=i[r]}(r,r),F(r,r,n),F(r,r,s),F(r,r,s),F(e[0],r,s),U(i,e[0]),F(i,i,s),R(i,n)&&F(e[0],e[0],w);if(U(i,e[0]),F(i,i,s),R(i,n))return-1;O(e[0])===t[31]>>7&&N(e[0],h,e[0]);return F(e[3],e[0],e[1]),0}(a,i))return-1;for(n=0;n=0};var h=B(),p=B([1]),g=B([30883,4953,19914,30187,55467,16705,2637,112,59544,30585,16505,36039,65139,11119,27886,20995]),y=B([61785,9906,39828,60374,45398,33411,5274,224,53552,61171,33010,6542,64743,22239,55772,9222]),m=B([54554,36645,11616,51542,42930,38181,51040,26924,56412,64982,57905,49316,21502,52590,14035,8553]),b=B([26200,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214,26214]),v=new Float64Array([237,211,245,92,26,99,18,88,214,156,247,162,222,249,222,20,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,16]),w=B([41136,18958,6951,50414,58488,44335,6150,12099,55207,15867,153,11085,57099,20417,9344,11139]);function _(e,t){var r=n.md.sha512.create(),s=new u(e);r.update(s.getBytes(t),"binary");var o=r.digest().getBytes();if(void 0!==i)return i.from(o,"binary");for(var a=new l(d.constants.HASH_BYTE_LENGTH),c=0;c<64;++c)a[c]=o.charCodeAt(c);return a}function E(e,t){var r,i,n,s;for(i=63;i>=32;--i){for(r=0,n=i-32,s=i-12;n>8,t[n]-=256*r;t[n]+=r,t[i]=0}for(r=0,n=0;n<32;++n)t[n]+=r-(t[31]>>4)*v[n],r=t[n]>>8,t[n]&=255;for(n=0;n<32;++n)t[n]-=r*v[n];for(i=0;i<32;++i)t[i+1]+=t[i]>>8,e[i]=255&t[i]}function S(e){for(var t=new Float64Array(64),r=0;r<64;++r)t[r]=e[r],e[r]=0;E(e,t)}function T(e,t){var r=B(),i=B(),n=B(),s=B(),o=B(),a=B(),c=B(),u=B(),l=B();N(r,e[1],e[0]),N(l,t[1],t[0]),F(r,r,l),L(i,e[0],e[1]),L(l,t[0],t[1]),F(i,i,l),F(n,e[3],t[3]),F(n,n,y),F(s,e[2],t[2]),L(s,s,s),N(o,i,r),N(a,s,n),L(c,s,n),L(u,i,r),F(e[0],o,a),F(e[1],u,c),F(e[2],c,a),F(e[3],o,u)}function A(e,t,r){for(var i=0;i<4;++i)x(e[i],t[i],r)}function k(e,t){var r=B(),i=B(),n=B();!function(e,t){var r,i=B();for(r=0;r<16;++r)i[r]=t[r];for(r=253;r>=0;--r)U(i,i),2!==r&&4!==r&&F(i,i,t);for(r=0;r<16;++r)e[r]=i[r]}(n,t[2]),F(r,t[0],n),F(i,t[1],n),I(e,i),e[31]^=O(r)<<7}function I(e,t){var r,i,n,s=B(),o=B();for(r=0;r<16;++r)o[r]=t[r];for(M(o),M(o),M(o),i=0;i<2;++i){for(s[0]=o[0]-65517,r=1;r<15;++r)s[r]=o[r]-65535-(s[r-1]>>16&1),s[r-1]&=65535;s[15]=o[15]-32767-(s[14]>>16&1),n=s[15]>>16&1,s[14]&=65535,x(o,s,1-n)}for(r=0;r<16;r++)e[2*r]=255&o[r],e[2*r+1]=o[r]>>8}function R(e,t){var r=new l(32),i=new l(32);return I(r,e),I(i,t),P(r,0,i,0)}function P(e,t,r,i){return function(e,t,r,i,n){var s,o=0;for(s=0;s>>8)-1}(e,t,r,i,32)}function O(e){var t=new l(32);return I(t,e),1&t[0]}function C(e,t,r){var i,n;for(D(e[0],h),D(e[1],p),D(e[2],p),D(e[3],h),n=255;n>=0;--n)A(e,t,i=r[n/8|0]>>(7&n)&1),T(t,e),T(e,e),A(e,t,i)}function j(e,t){var r=[B(),B(),B(),B()];D(r[0],m),D(r[1],b),D(r[2],p),F(r[3],m,b),C(e,r,t)}function D(e,t){var r;for(r=0;r<16;r++)e[r]=0|t[r]}function M(e){var t,r,i=1;for(t=0;t<16;++t)r=e[t]+i+65535,i=Math.floor(r/65536),e[t]=r-65536*i;e[0]+=i-1+37*(i-1)}function x(e,t,r){for(var i,n=~(r-1),s=0;s<16;++s)i=n&(e[s]^t[s]),e[s]^=i,t[s]^=i}function B(e){var t,r=new Float64Array(16);if(e)for(t=0;tt.encrypt(e)))},r.decrypt=function(e,t){return l(e,!1,t,((e,t)=>t.decrypt(e)))}},{"../webcrypto":"i99ng","../random-bytes":"gsnuW","uint8arrays/to-string":"hC8JB","uint8arrays/from-string":"dF7Y4","./rsa-utils":"3gF4s","./jwk2pem":"4kPkh"}],gsnuW:[function(e,t,r){"use strict";const i=e("iso-random-stream/src/random"),n=e("err-code");t.exports=function(e){if(isNaN(e)||e<=0)throw n(new Error("random bytes length must be a Number bigger than 0"),"ERR_INVALID_LENGTH");return i(e)}},{"iso-random-stream/src/random":"bIbEo","err-code":"chZjB"}],bIbEo:[function(e,t,r){"use strict";const i=65536;t.exports=function(e){const t=new Uint8Array(e);let r=0;if(e>0)if(e>i)for(;re?(crypto.getRandomValues(t.subarray(r,r+(e-r))),r+=e-r):(crypto.getRandomValues(t.subarray(r,r+i)),r+=i);else crypto.getRandomValues(t);return t}},{}],"3gF4s":[function(e,t,r){"use strict";e("node-forge/lib/asn1"),e("node-forge/lib/rsa");const i=e("node-forge/lib/forge"),{bigIntegerToUintBase64url:n,base64urlToBigInteger:s}=e("./../util"),{fromString:o}=e("uint8arrays/from-string"),{toString:a}=e("uint8arrays/to-string");r.pkcs1ToJwk=function(e){const t=i.asn1.fromDer(a(e,"ascii")),r=i.pki.privateKeyFromAsn1(t);return{kty:"RSA",n:n(r.n),e:n(r.e),d:n(r.d),p:n(r.p),q:n(r.q),dp:n(r.dP),dq:n(r.dQ),qi:n(r.qInv),alg:"RS256",kid:"2011-04-29"}},r.jwkToPkcs1=function(e){const t=i.pki.privateKeyToAsn1({n:s(e.n),e:s(e.e),d:s(e.d),p:s(e.p),q:s(e.q),dP:s(e.dp),dQ:s(e.dq),qInv:s(e.qi)});return o(i.asn1.toDer(t).getBytes(),"ascii")},r.pkixToJwk=function(e){const t=i.asn1.fromDer(a(e,"ascii")),r=i.pki.publicKeyFromAsn1(t);return{kty:"RSA",n:n(r.n),e:n(r.e),alg:"RS256",kid:"2011-04-29"}},r.jwkToPkix=function(e){const t=i.pki.publicKeyToAsn1({n:s(e.n),e:s(e.e)});return o(i.asn1.toDer(t).getBytes(),"ascii")}},{"node-forge/lib/asn1":"bcsXQ","node-forge/lib/rsa":"9ROH2","node-forge/lib/forge":"4OuPD","./../util":"ffmp6","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB"}],ffmp6:[function(e,t,r){"use strict";e("node-forge/lib/util"),e("node-forge/lib/jsbn");const i=e("node-forge/lib/forge"),{fromString:n}=e("uint8arrays/from-string"),{toString:s}=e("uint8arrays/to-string"),{concat:o}=e("uint8arrays/concat");r.bigIntegerToUintBase64url=(e,t)=>{let r=Uint8Array.from(e.abs().toByteArray());if(r=0===r[0]?r.slice(1):r,null!=t){if(r.length>t)throw new Error("byte array longer than desired length");r=o([new Uint8Array(t-r.length),r])}return s(r,"base64url")},r.base64urlToBigInteger=e=>{const t=r.base64urlToBuffer(e);return new i.jsbn.BigInteger(s(t,"base16"),16)},r.base64urlToBuffer=(e,t)=>{let r=n(e,"base64urlpad");if(null!=t){if(r.length>t)throw new Error("byte array longer than desired length");r=o([new Uint8Array(t-r.length),r])}return r}},{"node-forge/lib/util":"df43p","node-forge/lib/jsbn":"eeS3U","node-forge/lib/forge":"4OuPD","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB","uint8arrays/concat":"4EBjG"}],"4kPkh":[function(e,t,r){"use strict";e("node-forge/lib/rsa");const i=e("node-forge/lib/forge"),{base64urlToBigInteger:n}=e("../util");function s(e,t){return t.map((t=>n(e[t])))}t.exports={jwk2pub:function(e){return i.pki.setRsaPublicKey(...s(e,["n","e"]))},jwk2priv:function(e){return i.pki.setRsaPrivateKey(...s(e,["n","e","d","p","q","dp","dq","qi"]))}}},{"node-forge/lib/rsa":"9ROH2","node-forge/lib/forge":"4OuPD","../util":"ffmp6"}],"8qVel":[function(e,t,r){"use strict";const{base64:i}=e("multiformats/bases/base64"),n=e("../ciphers/aes-gcm");t.exports={export:async function(e,t){const r=n.create(),s=await r.encrypt(e,t);return i.encode(s)}}},{"multiformats/bases/base64":"gaFBW","../ciphers/aes-gcm":"92UH6"}],dh3ng:[function(e,t,r){"use strict";const i=e("err-code"),{equals:n}=e("uint8arrays/equals"),{sha256:s}=e("multiformats/hashes/sha2"),{base58btc:o}=e("multiformats/bases/base58"),{identity:a}=e("multiformats/hashes/identity"),c=e("./ed25519"),u=e("./keys"),l=e("./exporter");class d{constructor(e){this._key=h(e,c.publicKeyLength)}async verify(e,t){return c.hashAndVerify(this._key,t,e)}marshal(){return this._key}get bytes(){return u.PublicKey.encode({Type:u.KeyType.Ed25519,Data:this.marshal()}).finish()}equals(e){return n(this.bytes,e.bytes)}async hash(){const{bytes:e}=await s.digest(this.bytes);return e}}class f{constructor(e,t){this._key=h(e,c.privateKeyLength),this._publicKey=h(t,c.publicKeyLength)}async sign(e){return c.hashAndSign(this._key,e)}get public(){return new d(this._publicKey)}marshal(){return this._key}get bytes(){return u.PrivateKey.encode({Type:u.KeyType.Ed25519,Data:this.marshal()}).finish()}equals(e){return n(this.bytes,e.bytes)}async hash(){const{bytes:e}=await s.digest(this.bytes);return e}async id(){const e=await a.digest(this.public.bytes);return o.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if("libp2p-key"===t)return l.export(this.bytes,e);throw i(new Error(`export format '${t}' is not supported`),"ERR_INVALID_EXPORT_FORMAT")}}function h(e,t){if((e=Uint8Array.from(e||[])).length!==t)throw i(new Error(`Key must be a Uint8Array of length ${t}, got ${e.length}`),"ERR_INVALID_KEY_TYPE");return e}t.exports={Ed25519PublicKey:d,Ed25519PrivateKey:f,unmarshalEd25519PrivateKey:function(e){if(e.length>c.privateKeyLength){const t=(e=h(e,c.privateKeyLength+c.publicKeyLength)).slice(0,c.privateKeyLength),r=e.slice(c.privateKeyLength,e.length);return new f(t,r)}const t=(e=h(e,c.privateKeyLength)).slice(0,c.privateKeyLength),r=e.slice(c.publicKeyLength);return new f(t,r)},unmarshalEd25519PublicKey:function(e){return e=h(e,c.publicKeyLength),new d(e)},generateKeyPair:async function(){const{privateKey:e,publicKey:t}=await c.generateKey();return new f(e,t)},generateKeyPairFromSeed:async function(e){const{privateKey:t,publicKey:r}=await c.generateKeyFromSeed(e);return new f(t,r)}}},{"err-code":"chZjB","uint8arrays/equals":"eY3cX","multiformats/hashes/sha2":"7i9MT","multiformats/bases/base58":"4n7mA","multiformats/hashes/identity":"eYCZn","./ed25519":"8jlvB","./keys":"jWSTZ","./exporter":"8qVel"}],"8jlvB":[function(e,t,r){"use strict";e("node-forge/lib/ed25519");const i=e("node-forge/lib/forge");r.publicKeyLength=i.pki.ed25519.constants.PUBLIC_KEY_BYTE_LENGTH,r.privateKeyLength=i.pki.ed25519.constants.PRIVATE_KEY_BYTE_LENGTH,r.generateKey=async function(){return i.pki.ed25519.generateKeyPair()},r.generateKeyFromSeed=async function(e){return i.pki.ed25519.generateKeyPair({seed:e})},r.hashAndSign=async function(e,t){return i.pki.ed25519.sign({message:t,privateKey:e})},r.hashAndVerify=async function(e,t,r){return i.pki.ed25519.verify({signature:t,message:r,publicKey:e})}},{"node-forge/lib/ed25519":"9HAE7","node-forge/lib/forge":"4OuPD"}],jXCAP:[function(e,t,r){"use strict";const{sha256:i}=e("multiformats/hashes/sha2"),n=e("err-code"),{equals:s}=e("uint8arrays/equals"),{toString:o}=e("uint8arrays/to-string"),a=e("./exporter");t.exports=(t,r,c)=>{c=c||e("./secp256k1")(r);class u{constructor(e){c.validatePublicKey(e),this._key=e}verify(e,t){return c.hashAndVerify(this._key,t,e)}marshal(){return c.compressPublicKey(this._key)}get bytes(){return t.PublicKey.encode({Type:t.KeyType.Secp256k1,Data:this.marshal()}).finish()}equals(e){return s(this.bytes,e.bytes)}async hash(){const{bytes:e}=await i.digest(this.bytes);return e}}class l{constructor(e,t){this._key=e,this._publicKey=t||c.computePublicKey(e),c.validatePrivateKey(this._key),c.validatePublicKey(this._publicKey)}sign(e){return c.hashAndSign(this._key,e)}get public(){return new u(this._publicKey)}marshal(){return this._key}get bytes(){return t.PrivateKey.encode({Type:t.KeyType.Secp256k1,Data:this.marshal()}).finish()}equals(e){return s(this.bytes,e.bytes)}async hash(){const{bytes:e}=await i.digest(this.bytes);return e}async id(){const e=await this.public.hash();return o(e,"base58btc")}async export(e,t="libp2p-key"){if("libp2p-key"===t)return a.export(this.bytes,e);throw n(new Error(`export format '${t}' is not supported`),"ERR_INVALID_EXPORT_FORMAT")}}return{Secp256k1PublicKey:u,Secp256k1PrivateKey:l,unmarshalSecp256k1PrivateKey:function(e){return new l(e)},unmarshalSecp256k1PublicKey:function(e){return new u(e)},generateKeyPair:async function(){const e=await c.generateKey();return new l(e)}}}},{"multiformats/hashes/sha2":"7i9MT","err-code":"chZjB","uint8arrays/equals":"eY3cX","uint8arrays/to-string":"hC8JB","./exporter":"8qVel","./secp256k1":"e9sAH"}],e9sAH:[function(e,t,r){"use strict";const i=e("secp256k1"),{sha256:n}=e("multiformats/hashes/sha2");t.exports=e=>{function t(e){if(!i.privateKeyVerify(e))throw new Error("Invalid private key")}return{generateKey:function(){let t;do{t=e(32)}while(!i.privateKeyVerify(t));return t},privateKeyLength:32,hashAndSign:async function(e,t){const{digest:r}=await n.digest(t),s=i.ecdsaSign(r,e);return i.signatureExport(s.signature)},hashAndVerify:async function(e,t,r){const{digest:s}=await n.digest(r);return t=i.signatureImport(t),i.ecdsaVerify(t,s,e)},compressPublicKey:function(e){if(!i.publicKeyVerify(e))throw new Error("Invalid public key");return i.publicKeyConvert(e,!0)},decompressPublicKey:function(e){return i.publicKeyConvert(e,!1)},validatePrivateKey:t,validatePublicKey:function(e){if(!i.publicKeyVerify(e))throw new Error("Invalid public key")},computePublicKey:function(e){return t(e),i.publicKeyCreate(e)}}}},{secp256k1:"5e78P","multiformats/hashes/sha2":"7i9MT"}],"5e78P":[function(e,t,r){t.exports=e("./lib")(e("./lib/elliptic"))},{"./lib":"f9Aan","./lib/elliptic":"7HHQM"}],f9Aan:[function(e,t,r){const i="Impossible case. Please create issue.",n="The tweak was out of range or the resulted private key is invalid",s="The tweak was out of range or equal to zero",o="Unknow error on context randomization",a="Private Key is invalid",c="Public Key could not be parsed",u="Public Key serialization error",l="The sum of the public keys is not valid",d="Signature could not be parsed",f="The nonce generation function failed, or the private key was invalid",h="Public key could not be recover",p="Scalar was invalid (zero or overflow)";function g(e,t){if(!e)throw new Error(t)}function y(e,t,r){if(g(t instanceof Uint8Array,`Expected ${e} to be an Uint8Array`),void 0!==r)if(Array.isArray(r)){const i=`Expected ${e} to be an Uint8Array with length [${r.join(", ")}]`;g(r.includes(t.length),i)}else{const i=`Expected ${e} to be an Uint8Array with length ${r}`;g(t.length===r,i)}}function m(e){g("Boolean"===v(e),"Expected compressed to be a Boolean")}function b(e=(e=>new Uint8Array(e)),t){return"function"==typeof e&&(e=e(t)),y("output",e,t),e}function v(e){return Object.prototype.toString.call(e).slice(8,-1)}t.exports=e=>({contextRandomize(t){if(g(null===t||t instanceof Uint8Array,"Expected seed to be an Uint8Array or null"),null!==t&&y("seed",t,32),1===e.contextRandomize(t))throw new Error(o)},privateKeyVerify:t=>(y("private key",t,32),0===e.privateKeyVerify(t)),privateKeyNegate(t){switch(y("private key",t,32),e.privateKeyNegate(t)){case 0:return t;case 1:throw new Error(i)}},privateKeyTweakAdd(t,r){switch(y("private key",t,32),y("tweak",r,32),e.privateKeyTweakAdd(t,r)){case 0:return t;case 1:throw new Error(n)}},privateKeyTweakMul(t,r){switch(y("private key",t,32),y("tweak",r,32),e.privateKeyTweakMul(t,r)){case 0:return t;case 1:throw new Error(s)}},publicKeyVerify:t=>(y("public key",t,[33,65]),0===e.publicKeyVerify(t)),publicKeyCreate(t,r=!0,i){switch(y("private key",t,32),m(r),i=b(i,r?33:65),e.publicKeyCreate(i,t)){case 0:return i;case 1:throw new Error(a);case 2:throw new Error(u)}},publicKeyConvert(t,r=!0,i){switch(y("public key",t,[33,65]),m(r),i=b(i,r?33:65),e.publicKeyConvert(i,t)){case 0:return i;case 1:throw new Error(c);case 2:throw new Error(u)}},publicKeyNegate(t,r=!0,n){switch(y("public key",t,[33,65]),m(r),n=b(n,r?33:65),e.publicKeyNegate(n,t)){case 0:return n;case 1:throw new Error(c);case 2:throw new Error(i);case 3:throw new Error(u)}},publicKeyCombine(t,r=!0,i){g(Array.isArray(t),"Expected public keys to be an Array"),g(t.length>0,"Expected public keys array will have more than zero items");for(const e of t)y("public key",e,[33,65]);switch(m(r),i=b(i,r?33:65),e.publicKeyCombine(i,t)){case 0:return i;case 1:throw new Error(c);case 2:throw new Error(l);case 3:throw new Error(u)}},publicKeyTweakAdd(t,r,i=!0,s){switch(y("public key",t,[33,65]),y("tweak",r,32),m(i),s=b(s,i?33:65),e.publicKeyTweakAdd(s,t,r)){case 0:return s;case 1:throw new Error(c);case 2:throw new Error(n)}},publicKeyTweakMul(t,r,i=!0,n){switch(y("public key",t,[33,65]),y("tweak",r,32),m(i),n=b(n,i?33:65),e.publicKeyTweakMul(n,t,r)){case 0:return n;case 1:throw new Error(c);case 2:throw new Error(s)}},signatureNormalize(t){switch(y("signature",t,64),e.signatureNormalize(t)){case 0:return t;case 1:throw new Error(d)}},signatureExport(t,r){y("signature",t,64);const n={output:r=b(r,72),outputlen:72};switch(e.signatureExport(n,t)){case 0:return r.slice(0,n.outputlen);case 1:throw new Error(d);case 2:throw new Error(i)}},signatureImport(t,r){switch(y("signature",t),r=b(r,64),e.signatureImport(r,t)){case 0:return r;case 1:throw new Error(d);case 2:throw new Error(i)}},ecdsaSign(t,r,n={},s){y("message",t,32),y("private key",r,32),g("Object"===v(n),"Expected options to be an Object"),void 0!==n.data&&y("options.data",n.data),void 0!==n.noncefn&&g("Function"===v(n.noncefn),"Expected options.noncefn to be a Function");const o={signature:s=b(s,64),recid:null};switch(e.ecdsaSign(o,t,r,n.data,n.noncefn)){case 0:return o;case 1:throw new Error(f);case 2:throw new Error(i)}},ecdsaVerify(t,r,i){switch(y("signature",t,64),y("message",r,32),y("public key",i,[33,65]),e.ecdsaVerify(t,r,i)){case 0:return!0;case 3:return!1;case 1:throw new Error(d);case 2:throw new Error(c)}},ecdsaRecover(t,r,n,s=!0,o){switch(y("signature",t,64),g("Number"===v(r)&&r>=0&&r<=3,"Expected recovery id to be a Number within interval [0, 3]"),y("message",n,32),m(s),o=b(o,s?33:65),e.ecdsaRecover(o,t,r,n)){case 0:return o;case 1:throw new Error(d);case 2:throw new Error(h);case 3:throw new Error(i)}},ecdh(t,r,i={},n){switch(y("public key",t,[33,65]),y("private key",r,32),g("Object"===v(i),"Expected options to be an Object"),void 0!==i.data&&y("options.data",i.data),void 0!==i.hashfn?(g("Function"===v(i.hashfn),"Expected options.hashfn to be a Function"),void 0!==i.xbuf&&y("options.xbuf",i.xbuf,32),void 0!==i.ybuf&&y("options.ybuf",i.ybuf,32),y("output",n)):n=b(n,32),e.ecdh(n,t,r,i.data,i.hashfn,i.xbuf,i.ybuf)){case 0:return n;case 1:throw new Error(c);case 2:throw new Error(p)}}})},{}],"7HHQM":[function(e,t,r){const i=new(0,e("elliptic").ec)("secp256k1"),n=i.curve,s=n.n.constructor;function o(e){const t=e[0];switch(t){case 2:case 3:return 33!==e.length?null:function(e,t){let r=new s(t);if(r.cmp(n.p)>=0)return null;r=r.toRed(n.red);let o=r.redSqr().redIMul(r).redIAdd(n.b).redSqrt();return 3===e!==o.isOdd()&&(o=o.redNeg()),i.keyPair({pub:{x:r,y:o}})}(t,e.subarray(1,33));case 4:case 6:case 7:return 65!==e.length?null:function(e,t,r){let o=new s(t),a=new s(r);if(o.cmp(n.p)>=0||a.cmp(n.p)>=0)return null;if(o=o.toRed(n.red),a=a.toRed(n.red),(6===e||7===e)&&a.isOdd()!==(7===e))return null;const c=o.redSqr().redIMul(o);return a.redSqr().redISub(c.redIAdd(n.b)).isZero()?i.keyPair({pub:{x:o,y:a}}):null}(t,e.subarray(1,33),e.subarray(33,65));default:return null}}function a(e,t){const r=t.encode(null,33===e.length);for(let t=0;t0,privateKeyVerify(e){const t=new s(e);return t.cmp(n.n)<0&&!t.isZero()?0:1},privateKeyNegate(e){const t=new s(e),r=n.n.sub(t).umod(n.n).toArrayLike(Uint8Array,"be",32);return e.set(r),0},privateKeyTweakAdd(e,t){const r=new s(t);if(r.cmp(n.n)>=0)return 1;if(r.iadd(new s(e)),r.cmp(n.n)>=0&&r.isub(n.n),r.isZero())return 1;const i=r.toArrayLike(Uint8Array,"be",32);return e.set(i),0},privateKeyTweakMul(e,t){let r=new s(t);if(r.cmp(n.n)>=0||r.isZero())return 1;r.imul(new s(e)),r.cmp(n.n)>=0&&(r=r.umod(n.n));const i=r.toArrayLike(Uint8Array,"be",32);return e.set(i),0},publicKeyVerify:e=>null===o(e)?1:0,publicKeyCreate(e,t){const r=new s(t);if(r.cmp(n.n)>=0||r.isZero())return 1;return a(e,i.keyFromPrivate(t).getPublic()),0},publicKeyConvert(e,t){const r=o(t);if(null===r)return 1;return a(e,r.getPublic()),0},publicKeyNegate(e,t){const r=o(t);if(null===r)return 1;const i=r.getPublic();return i.y=i.y.redNeg(),a(e,i),0},publicKeyCombine(e,t){const r=new Array(t.length);for(let e=0;e=0)return 2;const c=i.getPublic().add(n.g.mul(r));return c.isInfinity()?2:(a(e,c),0)},publicKeyTweakMul(e,t,r){const i=o(t);if(null===i)return 1;if((r=new s(r)).cmp(n.n)>=0||r.isZero())return 2;return a(e,i.getPublic().mul(r)),0},signatureNormalize(e){const t=new s(e.subarray(0,32)),r=new s(e.subarray(32,64));return t.cmp(n.n)>=0||r.cmp(n.n)>=0?1:(1===r.cmp(i.nh)&&e.set(n.n.sub(r).toArrayLike(Uint8Array,"be",32),32),0)},signatureExport(e,t){const r=t.subarray(0,32),i=t.subarray(32,64);if(new s(r).cmp(n.n)>=0)return 1;if(new s(i).cmp(n.n)>=0)return 1;const{output:o}=e;let a=o.subarray(4,37);a[0]=0,a.set(r,1);let c=33,u=0;for(;c>1&&0===a[u]&&!(128&a[u+1]);--c,++u);if(a=a.subarray(u),128&a[0])return 1;if(c>1&&0===a[0]&&!(128&a[1]))return 1;let l=o.subarray(39,72);l[0]=0,l.set(i,1);let d=33,f=0;for(;d>1&&0===l[f]&&!(128&l[f+1]);--d,++f);return l=l.subarray(f),128&l[0]||d>1&&0===l[0]&&!(128&l[1])?1:(e.outputlen=6+c+d,o[0]=48,o[1]=e.outputlen-2,o[2]=2,o[3]=a.length,o.set(a,4),o[4+c]=2,o[5+c]=l.length,o.set(l,6+c),0)},signatureImport(e,t){if(t.length<8)return 1;if(t.length>72)return 1;if(48!==t[0])return 1;if(t[1]!==t.length-2)return 1;if(2!==t[2])return 1;const r=t[3];if(0===r)return 1;if(5+r>=t.length)return 1;if(2!==t[4+r])return 1;const i=t[5+r];if(0===i)return 1;if(6+r+i!==t.length)return 1;if(128&t[4])return 1;if(r>1&&0===t[4]&&!(128&t[5]))return 1;if(128&t[r+6])return 1;if(i>1&&0===t[r+6]&&!(128&t[r+7]))return 1;let o=t.subarray(4,4+r);if(33===o.length&&0===o[0]&&(o=o.subarray(1)),o.length>32)return 1;let a=t.subarray(6+r);if(33===a.length&&0===a[0]&&(a=a.slice(1)),a.length>32)throw new Error("S length is too long");let c=new s(o);c.cmp(n.n)>=0&&(c=new s(0));let u=new s(t.subarray(6+r));return u.cmp(n.n)>=0&&(u=new s(0)),e.set(c.toArrayLike(Uint8Array,"be",32),0),e.set(u.toArrayLike(Uint8Array,"be",32),32),0},ecdsaSign(e,t,r,o,a){if(a){const e=a;a=i=>{const n=e(t,r,null,o,i);if(!(n instanceof Uint8Array&&32===n.length))throw new Error("This is the way");return new s(n)}}const c=new s(r);if(c.cmp(n.n)>=0||c.isZero())return 1;let u;try{u=i.sign(t,r,{canonical:!0,k:a,pers:o})}catch(e){return 1}return e.signature.set(u.r.toArrayLike(Uint8Array,"be",32),0),e.signature.set(u.s.toArrayLike(Uint8Array,"be",32),32),e.recid=u.recoveryParam,0},ecdsaVerify(e,t,r){const a={r:e.subarray(0,32),s:e.subarray(32,64)},c=new s(a.r),u=new s(a.s);if(c.cmp(n.n)>=0||u.cmp(n.n)>=0)return 1;if(1===u.cmp(i.nh)||c.isZero()||u.isZero())return 3;const l=o(r);if(null===l)return 2;const d=l.getPublic();return i.verify(t,a,d)?0:3},ecdsaRecover(e,t,r,o){const c={r:t.slice(0,32),s:t.slice(32,64)},u=new s(c.r),l=new s(c.s);if(u.cmp(n.n)>=0||l.cmp(n.n)>=0)return 1;if(u.isZero()||l.isZero())return 2;let d;try{d=i.recoverPubKey(o,c,r)}catch(e){return 2}return a(e,d),0},ecdh(e,t,r,a,c,u,l){const d=o(t);if(null===d)return 1;const f=new s(r);if(f.cmp(n.n)>=0||f.isZero())return 2;const h=d.getPublic().mul(f);if(void 0===c){const t=h.encode(null,!0),r=i.hash().update(t).digest();for(let t=0;t<32;++t)e[t]=r[t]}else{u||(u=new Uint8Array(32));const t=h.getX().toArray("be",32);for(let e=0;e<32;++e)u[e]=t[e];l||(l=new Uint8Array(32));const r=h.getY().toArray("be",32);for(let e=0;e<32;++e)l[e]=r[e];const i=c(u,l,a);if(!(i instanceof Uint8Array&&i.length===e.length))return 2;e.set(i)}return 0}}},{elliptic:"g2Vtb"}],g2Vtb:[function(e,t,r){"use strict";var i=r;i.version=e("../package.json").version,i.utils=e("./elliptic/utils"),i.rand=e("brorand"),i.curve=e("./elliptic/curve"),i.curves=e("./elliptic/curves"),i.ec=e("./elliptic/ec"),i.eddsa=e("./elliptic/eddsa")},{"../package.json":"ejBaf","./elliptic/utils":"959xT",brorand:"P54o1","./elliptic/curve":"byDyH","./elliptic/curves":"4unkA","./elliptic/ec":"5AnhI","./elliptic/eddsa":"j2H5w"}],ejBaf:[function(e,t,r){t.exports=JSON.parse('{"name":"elliptic","version":"6.5.4","description":"EC cryptography","main":"lib/elliptic.js","files":["lib"],"scripts":{"lint":"eslint lib test","lint:fix":"npm run lint -- --fix","unit":"istanbul test _mocha --reporter=spec test/index.js","test":"npm run lint && npm run unit","version":"grunt dist && git add dist/"},"repository":{"type":"git","url":"git@github.com:indutny/elliptic"},"keywords":["EC","Elliptic","curve","Cryptography"],"author":"Fedor Indutny ","license":"MIT","bugs":{"url":"https://github.com/indutny/elliptic/issues"},"homepage":"https://github.com/indutny/elliptic","devDependencies":{"brfs":"^2.0.2","coveralls":"^3.1.0","eslint":"^7.6.0","grunt":"^1.2.1","grunt-browserify":"^5.3.0","grunt-cli":"^1.3.2","grunt-contrib-connect":"^3.0.0","grunt-contrib-copy":"^1.0.0","grunt-contrib-uglify":"^5.0.0","grunt-mocha-istanbul":"^5.0.2","grunt-saucelabs":"^9.0.1","istanbul":"^0.4.5","mocha":"^8.0.1"},"dependencies":{"bn.js":"^4.11.9","brorand":"^1.1.0","hash.js":"^1.0.0","hmac-drbg":"^1.0.1","inherits":"^2.0.4","minimalistic-assert":"^1.0.1","minimalistic-crypto-utils":"^1.0.1"}}')},{}],"959xT":[function(e,t,r){"use strict";var i=r,n=e("bn.js"),s=e("minimalistic-assert"),o=e("minimalistic-crypto-utils");i.assert=s,i.toArray=o.toArray,i.zero2=o.zero2,i.toHex=o.toHex,i.encode=o.encode,i.getNAF=function(e,t,r){var i=new Array(Math.max(e.bitLength(),r)+1);i.fill(0);for(var n=1<(n>>1)-1?(n>>1)-c:c,s.isubn(a)):a=0,i[o]=a,s.iushrn(1)}return i},i.getJSF=function(e,t){var r=[[],[]];e=e.clone(),t=t.clone();for(var i,n=0,s=0;e.cmpn(-n)>0||t.cmpn(-s)>0;){var o,a,c=e.andln(3)+n&3,u=t.andln(3)+s&3;3===c&&(c=-1),3===u&&(u=-1),o=0==(1&c)?0:3!==(i=e.andln(7)+n&7)&&5!==i||2!==u?c:-c,r[0].push(o),a=0==(1&u)?0:3!==(i=t.andln(7)+s&7)&&5!==i||2!==c?u:-u,r[1].push(a),2*n===o+1&&(n=1-n),2*s===a+1&&(s=1-s),e.iushrn(1),t.iushrn(1)}return r},i.cachedProperty=function(e,t,r){var i="_"+t;e.prototype[t]=function(){return void 0!==this[i]?this[i]:this[i]=r.call(this)}},i.parseBytes=function(e){return"string"==typeof e?i.toArray(e,"hex"):e},i.intFromLE=function(e){return new n(e,"hex","le")}},{"bn.js":"c8Lvi","minimalistic-assert":"1GrVu","minimalistic-crypto-utils":"3MGAl"}],c8Lvi:[function(e,t,r){!function(t,r){function i(e,t){if(!e)throw new Error(t||"Assertion failed")}function n(e,t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}function s(e,t,r){if(s.isBN(e))return e;this.negative=0,this.words=null,this.length=0,this.red=null,null!==e&&("le"!==t&&"be"!==t||(r=t,t=10),this._init(e||0,t||10,r||"be"))}var o;"object"==typeof t?t.exports=s:r.BN=s,s.BN=s,s.wordSize=26;try{o="undefined"!=typeof window&&void 0!==window.Buffer?window.Buffer:e("buffer").Buffer}catch(e){}function a(e,t){var r=e.charCodeAt(t);return r>=65&&r<=70?r-55:r>=97&&r<=102?r-87:r-48&15}function c(e,t,r){var i=a(e,r);return r-1>=t&&(i|=a(e,r-1)<<4),i}function u(e,t,r,i){for(var n=0,s=Math.min(e.length,r),o=t;o=49?a-49+10:a>=17?a-17+10:a}return n}s.isBN=function(e){return e instanceof s||null!==e&&"object"==typeof e&&e.constructor.wordSize===s.wordSize&&Array.isArray(e.words)},s.max=function(e,t){return e.cmp(t)>0?e:t},s.min=function(e,t){return e.cmp(t)<0?e:t},s.prototype._init=function(e,t,r){if("number"==typeof e)return this._initNumber(e,t,r);if("object"==typeof e)return this._initArray(e,t,r);"hex"===t&&(t=16),i(t===(0|t)&&t>=2&&t<=36);var n=0;"-"===(e=e.toString().replace(/\s+/g,""))[0]&&(n++,this.negative=1),n=0;n-=3)o=e[n]|e[n-1]<<8|e[n-2]<<16,this.words[s]|=o<>>26-a&67108863,(a+=24)>=26&&(a-=26,s++);else if("le"===r)for(n=0,s=0;n>>26-a&67108863,(a+=24)>=26&&(a-=26,s++);return this.strip()},s.prototype._parseHex=function(e,t,r){this.length=Math.ceil((e.length-t)/6),this.words=new Array(this.length);for(var i=0;i=t;i-=2)n=c(e,t,i)<=18?(s-=18,o+=1,this.words[o]|=n>>>26):s+=8;else for(i=(e.length-t)%2==0?t+1:t;i=18?(s-=18,o+=1,this.words[o]|=n>>>26):s+=8;this.strip()},s.prototype._parseBase=function(e,t,r){this.words=[0],this.length=1;for(var i=0,n=1;n<=67108863;n*=t)i++;i--,n=n/t|0;for(var s=e.length-r,o=s%i,a=Math.min(s,s-o)+r,c=0,l=r;l1&&0===this.words[this.length-1];)this.length--;return this._normSign()},s.prototype._normSign=function(){return 1===this.length&&0===this.words[0]&&(this.negative=0),this},s.prototype.inspect=function(){return(this.red?""};var l=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],d=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],f=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64e6,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,243e5,28629151,33554432,39135393,45435424,52521875,60466176];function h(e,t,r){r.negative=t.negative^e.negative;var i=e.length+t.length|0;r.length=i,i=i-1|0;var n=0|e.words[0],s=0|t.words[0],o=n*s,a=67108863&o,c=o/67108864|0;r.words[0]=a;for(var u=1;u>>26,d=67108863&c,f=Math.min(u,t.length-1),h=Math.max(0,u-e.length+1);h<=f;h++){var p=u-h|0;l+=(o=(n=0|e.words[p])*(s=0|t.words[h])+d)/67108864|0,d=67108863&o}r.words[u]=0|d,c=0|l}return 0!==c?r.words[u]=0|c:r.length--,r.strip()}s.prototype.toString=function(e,t){var r;if(t=0|t||1,16===(e=e||10)||"hex"===e){r="";for(var n=0,s=0,o=0;o>>24-n&16777215)||o!==this.length-1?l[6-c.length]+c+r:c+r,(n+=2)>=26&&(n-=26,o--)}for(0!==s&&(r=s.toString(16)+r);r.length%t!=0;)r="0"+r;return 0!==this.negative&&(r="-"+r),r}if(e===(0|e)&&e>=2&&e<=36){var u=d[e],h=f[e];r="";var p=this.clone();for(p.negative=0;!p.isZero();){var g=p.modn(h).toString(e);r=(p=p.idivn(h)).isZero()?g+r:l[u-g.length]+g+r}for(this.isZero()&&(r="0"+r);r.length%t!=0;)r="0"+r;return 0!==this.negative&&(r="-"+r),r}i(!1,"Base should be between 2 and 36")},s.prototype.toNumber=function(){var e=this.words[0];return 2===this.length?e+=67108864*this.words[1]:3===this.length&&1===this.words[2]?e+=4503599627370496+67108864*this.words[1]:this.length>2&&i(!1,"Number can only safely store up to 53 bits"),0!==this.negative?-e:e},s.prototype.toJSON=function(){return this.toString(16)},s.prototype.toBuffer=function(e,t){return i(void 0!==o),this.toArrayLike(o,e,t)},s.prototype.toArray=function(e,t){return this.toArrayLike(Array,e,t)},s.prototype.toArrayLike=function(e,t,r){var n=this.byteLength(),s=r||Math.max(1,n);i(n<=s,"byte array longer than desired length"),i(s>0,"Requested array length <= 0"),this.strip();var o,a,c="le"===t,u=new e(s),l=this.clone();if(c){for(a=0;!l.isZero();a++)o=l.andln(255),l.iushrn(8),u[a]=o;for(;a=4096&&(r+=13,t>>>=13),t>=64&&(r+=7,t>>>=7),t>=8&&(r+=4,t>>>=4),t>=2&&(r+=2,t>>>=2),r+t},s.prototype._zeroBits=function(e){if(0===e)return 26;var t=e,r=0;return 0==(8191&t)&&(r+=13,t>>>=13),0==(127&t)&&(r+=7,t>>>=7),0==(15&t)&&(r+=4,t>>>=4),0==(3&t)&&(r+=2,t>>>=2),0==(1&t)&&r++,r},s.prototype.bitLength=function(){var e=this.words[this.length-1],t=this._countBits(e);return 26*(this.length-1)+t},s.prototype.zeroBits=function(){if(this.isZero())return 0;for(var e=0,t=0;te.length?this.clone().ior(e):e.clone().ior(this)},s.prototype.uor=function(e){return this.length>e.length?this.clone().iuor(e):e.clone().iuor(this)},s.prototype.iuand=function(e){var t;t=this.length>e.length?e:this;for(var r=0;re.length?this.clone().iand(e):e.clone().iand(this)},s.prototype.uand=function(e){return this.length>e.length?this.clone().iuand(e):e.clone().iuand(this)},s.prototype.iuxor=function(e){var t,r;this.length>e.length?(t=this,r=e):(t=e,r=this);for(var i=0;ie.length?this.clone().ixor(e):e.clone().ixor(this)},s.prototype.uxor=function(e){return this.length>e.length?this.clone().iuxor(e):e.clone().iuxor(this)},s.prototype.inotn=function(e){i("number"==typeof e&&e>=0);var t=0|Math.ceil(e/26),r=e%26;this._expand(t),r>0&&t--;for(var n=0;n0&&(this.words[n]=~this.words[n]&67108863>>26-r),this.strip()},s.prototype.notn=function(e){return this.clone().inotn(e)},s.prototype.setn=function(e,t){i("number"==typeof e&&e>=0);var r=e/26|0,n=e%26;return this._expand(r+1),this.words[r]=t?this.words[r]|1<e.length?(r=this,i=e):(r=e,i=this);for(var n=0,s=0;s>>26;for(;0!==n&&s>>26;if(this.length=r.length,0!==n)this.words[this.length]=n,this.length++;else if(r!==this)for(;se.length?this.clone().iadd(e):e.clone().iadd(this)},s.prototype.isub=function(e){if(0!==e.negative){e.negative=0;var t=this.iadd(e);return e.negative=1,t._normSign()}if(0!==this.negative)return this.negative=0,this.iadd(e),this.negative=1,this._normSign();var r,i,n=this.cmp(e);if(0===n)return this.negative=0,this.length=1,this.words[0]=0,this;n>0?(r=this,i=e):(r=e,i=this);for(var s=0,o=0;o>26,this.words[o]=67108863&t;for(;0!==s&&o>26,this.words[o]=67108863&t;if(0===s&&o>>13,h=0|o[1],p=8191&h,g=h>>>13,y=0|o[2],m=8191&y,b=y>>>13,v=0|o[3],w=8191&v,_=v>>>13,E=0|o[4],S=8191&E,T=E>>>13,A=0|o[5],k=8191&A,I=A>>>13,R=0|o[6],P=8191&R,O=R>>>13,C=0|o[7],j=8191&C,D=C>>>13,M=0|o[8],x=8191&M,B=M>>>13,L=0|o[9],N=8191&L,U=L>>>13,F=0|a[0],K=8191&F,z=F>>>13,V=0|a[1],q=8191&V,G=V>>>13,H=0|a[2],$=8191&H,W=H>>>13,Y=0|a[3],X=8191&Y,Z=Y>>>13,Q=0|a[4],J=8191&Q,ee=Q>>>13,te=0|a[5],re=8191&te,ie=te>>>13,ne=0|a[6],se=8191&ne,oe=ne>>>13,ae=0|a[7],ce=8191&ae,ue=ae>>>13,le=0|a[8],de=8191&le,fe=le>>>13,he=0|a[9],pe=8191&he,ge=he>>>13;r.negative=e.negative^t.negative,r.length=19;var ye=(u+(i=Math.imul(d,K))|0)+((8191&(n=(n=Math.imul(d,z))+Math.imul(f,K)|0))<<13)|0;u=((s=Math.imul(f,z))+(n>>>13)|0)+(ye>>>26)|0,ye&=67108863,i=Math.imul(p,K),n=(n=Math.imul(p,z))+Math.imul(g,K)|0,s=Math.imul(g,z);var me=(u+(i=i+Math.imul(d,q)|0)|0)+((8191&(n=(n=n+Math.imul(d,G)|0)+Math.imul(f,q)|0))<<13)|0;u=((s=s+Math.imul(f,G)|0)+(n>>>13)|0)+(me>>>26)|0,me&=67108863,i=Math.imul(m,K),n=(n=Math.imul(m,z))+Math.imul(b,K)|0,s=Math.imul(b,z),i=i+Math.imul(p,q)|0,n=(n=n+Math.imul(p,G)|0)+Math.imul(g,q)|0,s=s+Math.imul(g,G)|0;var be=(u+(i=i+Math.imul(d,$)|0)|0)+((8191&(n=(n=n+Math.imul(d,W)|0)+Math.imul(f,$)|0))<<13)|0;u=((s=s+Math.imul(f,W)|0)+(n>>>13)|0)+(be>>>26)|0,be&=67108863,i=Math.imul(w,K),n=(n=Math.imul(w,z))+Math.imul(_,K)|0,s=Math.imul(_,z),i=i+Math.imul(m,q)|0,n=(n=n+Math.imul(m,G)|0)+Math.imul(b,q)|0,s=s+Math.imul(b,G)|0,i=i+Math.imul(p,$)|0,n=(n=n+Math.imul(p,W)|0)+Math.imul(g,$)|0,s=s+Math.imul(g,W)|0;var ve=(u+(i=i+Math.imul(d,X)|0)|0)+((8191&(n=(n=n+Math.imul(d,Z)|0)+Math.imul(f,X)|0))<<13)|0;u=((s=s+Math.imul(f,Z)|0)+(n>>>13)|0)+(ve>>>26)|0,ve&=67108863,i=Math.imul(S,K),n=(n=Math.imul(S,z))+Math.imul(T,K)|0,s=Math.imul(T,z),i=i+Math.imul(w,q)|0,n=(n=n+Math.imul(w,G)|0)+Math.imul(_,q)|0,s=s+Math.imul(_,G)|0,i=i+Math.imul(m,$)|0,n=(n=n+Math.imul(m,W)|0)+Math.imul(b,$)|0,s=s+Math.imul(b,W)|0,i=i+Math.imul(p,X)|0,n=(n=n+Math.imul(p,Z)|0)+Math.imul(g,X)|0,s=s+Math.imul(g,Z)|0;var we=(u+(i=i+Math.imul(d,J)|0)|0)+((8191&(n=(n=n+Math.imul(d,ee)|0)+Math.imul(f,J)|0))<<13)|0;u=((s=s+Math.imul(f,ee)|0)+(n>>>13)|0)+(we>>>26)|0,we&=67108863,i=Math.imul(k,K),n=(n=Math.imul(k,z))+Math.imul(I,K)|0,s=Math.imul(I,z),i=i+Math.imul(S,q)|0,n=(n=n+Math.imul(S,G)|0)+Math.imul(T,q)|0,s=s+Math.imul(T,G)|0,i=i+Math.imul(w,$)|0,n=(n=n+Math.imul(w,W)|0)+Math.imul(_,$)|0,s=s+Math.imul(_,W)|0,i=i+Math.imul(m,X)|0,n=(n=n+Math.imul(m,Z)|0)+Math.imul(b,X)|0,s=s+Math.imul(b,Z)|0,i=i+Math.imul(p,J)|0,n=(n=n+Math.imul(p,ee)|0)+Math.imul(g,J)|0,s=s+Math.imul(g,ee)|0;var _e=(u+(i=i+Math.imul(d,re)|0)|0)+((8191&(n=(n=n+Math.imul(d,ie)|0)+Math.imul(f,re)|0))<<13)|0;u=((s=s+Math.imul(f,ie)|0)+(n>>>13)|0)+(_e>>>26)|0,_e&=67108863,i=Math.imul(P,K),n=(n=Math.imul(P,z))+Math.imul(O,K)|0,s=Math.imul(O,z),i=i+Math.imul(k,q)|0,n=(n=n+Math.imul(k,G)|0)+Math.imul(I,q)|0,s=s+Math.imul(I,G)|0,i=i+Math.imul(S,$)|0,n=(n=n+Math.imul(S,W)|0)+Math.imul(T,$)|0,s=s+Math.imul(T,W)|0,i=i+Math.imul(w,X)|0,n=(n=n+Math.imul(w,Z)|0)+Math.imul(_,X)|0,s=s+Math.imul(_,Z)|0,i=i+Math.imul(m,J)|0,n=(n=n+Math.imul(m,ee)|0)+Math.imul(b,J)|0,s=s+Math.imul(b,ee)|0,i=i+Math.imul(p,re)|0,n=(n=n+Math.imul(p,ie)|0)+Math.imul(g,re)|0,s=s+Math.imul(g,ie)|0;var Ee=(u+(i=i+Math.imul(d,se)|0)|0)+((8191&(n=(n=n+Math.imul(d,oe)|0)+Math.imul(f,se)|0))<<13)|0;u=((s=s+Math.imul(f,oe)|0)+(n>>>13)|0)+(Ee>>>26)|0,Ee&=67108863,i=Math.imul(j,K),n=(n=Math.imul(j,z))+Math.imul(D,K)|0,s=Math.imul(D,z),i=i+Math.imul(P,q)|0,n=(n=n+Math.imul(P,G)|0)+Math.imul(O,q)|0,s=s+Math.imul(O,G)|0,i=i+Math.imul(k,$)|0,n=(n=n+Math.imul(k,W)|0)+Math.imul(I,$)|0,s=s+Math.imul(I,W)|0,i=i+Math.imul(S,X)|0,n=(n=n+Math.imul(S,Z)|0)+Math.imul(T,X)|0,s=s+Math.imul(T,Z)|0,i=i+Math.imul(w,J)|0,n=(n=n+Math.imul(w,ee)|0)+Math.imul(_,J)|0,s=s+Math.imul(_,ee)|0,i=i+Math.imul(m,re)|0,n=(n=n+Math.imul(m,ie)|0)+Math.imul(b,re)|0,s=s+Math.imul(b,ie)|0,i=i+Math.imul(p,se)|0,n=(n=n+Math.imul(p,oe)|0)+Math.imul(g,se)|0,s=s+Math.imul(g,oe)|0;var Se=(u+(i=i+Math.imul(d,ce)|0)|0)+((8191&(n=(n=n+Math.imul(d,ue)|0)+Math.imul(f,ce)|0))<<13)|0;u=((s=s+Math.imul(f,ue)|0)+(n>>>13)|0)+(Se>>>26)|0,Se&=67108863,i=Math.imul(x,K),n=(n=Math.imul(x,z))+Math.imul(B,K)|0,s=Math.imul(B,z),i=i+Math.imul(j,q)|0,n=(n=n+Math.imul(j,G)|0)+Math.imul(D,q)|0,s=s+Math.imul(D,G)|0,i=i+Math.imul(P,$)|0,n=(n=n+Math.imul(P,W)|0)+Math.imul(O,$)|0,s=s+Math.imul(O,W)|0,i=i+Math.imul(k,X)|0,n=(n=n+Math.imul(k,Z)|0)+Math.imul(I,X)|0,s=s+Math.imul(I,Z)|0,i=i+Math.imul(S,J)|0,n=(n=n+Math.imul(S,ee)|0)+Math.imul(T,J)|0,s=s+Math.imul(T,ee)|0,i=i+Math.imul(w,re)|0,n=(n=n+Math.imul(w,ie)|0)+Math.imul(_,re)|0,s=s+Math.imul(_,ie)|0,i=i+Math.imul(m,se)|0,n=(n=n+Math.imul(m,oe)|0)+Math.imul(b,se)|0,s=s+Math.imul(b,oe)|0,i=i+Math.imul(p,ce)|0,n=(n=n+Math.imul(p,ue)|0)+Math.imul(g,ce)|0,s=s+Math.imul(g,ue)|0;var Te=(u+(i=i+Math.imul(d,de)|0)|0)+((8191&(n=(n=n+Math.imul(d,fe)|0)+Math.imul(f,de)|0))<<13)|0;u=((s=s+Math.imul(f,fe)|0)+(n>>>13)|0)+(Te>>>26)|0,Te&=67108863,i=Math.imul(N,K),n=(n=Math.imul(N,z))+Math.imul(U,K)|0,s=Math.imul(U,z),i=i+Math.imul(x,q)|0,n=(n=n+Math.imul(x,G)|0)+Math.imul(B,q)|0,s=s+Math.imul(B,G)|0,i=i+Math.imul(j,$)|0,n=(n=n+Math.imul(j,W)|0)+Math.imul(D,$)|0,s=s+Math.imul(D,W)|0,i=i+Math.imul(P,X)|0,n=(n=n+Math.imul(P,Z)|0)+Math.imul(O,X)|0,s=s+Math.imul(O,Z)|0,i=i+Math.imul(k,J)|0,n=(n=n+Math.imul(k,ee)|0)+Math.imul(I,J)|0,s=s+Math.imul(I,ee)|0,i=i+Math.imul(S,re)|0,n=(n=n+Math.imul(S,ie)|0)+Math.imul(T,re)|0,s=s+Math.imul(T,ie)|0,i=i+Math.imul(w,se)|0,n=(n=n+Math.imul(w,oe)|0)+Math.imul(_,se)|0,s=s+Math.imul(_,oe)|0,i=i+Math.imul(m,ce)|0,n=(n=n+Math.imul(m,ue)|0)+Math.imul(b,ce)|0,s=s+Math.imul(b,ue)|0,i=i+Math.imul(p,de)|0,n=(n=n+Math.imul(p,fe)|0)+Math.imul(g,de)|0,s=s+Math.imul(g,fe)|0;var Ae=(u+(i=i+Math.imul(d,pe)|0)|0)+((8191&(n=(n=n+Math.imul(d,ge)|0)+Math.imul(f,pe)|0))<<13)|0;u=((s=s+Math.imul(f,ge)|0)+(n>>>13)|0)+(Ae>>>26)|0,Ae&=67108863,i=Math.imul(N,q),n=(n=Math.imul(N,G))+Math.imul(U,q)|0,s=Math.imul(U,G),i=i+Math.imul(x,$)|0,n=(n=n+Math.imul(x,W)|0)+Math.imul(B,$)|0,s=s+Math.imul(B,W)|0,i=i+Math.imul(j,X)|0,n=(n=n+Math.imul(j,Z)|0)+Math.imul(D,X)|0,s=s+Math.imul(D,Z)|0,i=i+Math.imul(P,J)|0,n=(n=n+Math.imul(P,ee)|0)+Math.imul(O,J)|0,s=s+Math.imul(O,ee)|0,i=i+Math.imul(k,re)|0,n=(n=n+Math.imul(k,ie)|0)+Math.imul(I,re)|0,s=s+Math.imul(I,ie)|0,i=i+Math.imul(S,se)|0,n=(n=n+Math.imul(S,oe)|0)+Math.imul(T,se)|0,s=s+Math.imul(T,oe)|0,i=i+Math.imul(w,ce)|0,n=(n=n+Math.imul(w,ue)|0)+Math.imul(_,ce)|0,s=s+Math.imul(_,ue)|0,i=i+Math.imul(m,de)|0,n=(n=n+Math.imul(m,fe)|0)+Math.imul(b,de)|0,s=s+Math.imul(b,fe)|0;var ke=(u+(i=i+Math.imul(p,pe)|0)|0)+((8191&(n=(n=n+Math.imul(p,ge)|0)+Math.imul(g,pe)|0))<<13)|0;u=((s=s+Math.imul(g,ge)|0)+(n>>>13)|0)+(ke>>>26)|0,ke&=67108863,i=Math.imul(N,$),n=(n=Math.imul(N,W))+Math.imul(U,$)|0,s=Math.imul(U,W),i=i+Math.imul(x,X)|0,n=(n=n+Math.imul(x,Z)|0)+Math.imul(B,X)|0,s=s+Math.imul(B,Z)|0,i=i+Math.imul(j,J)|0,n=(n=n+Math.imul(j,ee)|0)+Math.imul(D,J)|0,s=s+Math.imul(D,ee)|0,i=i+Math.imul(P,re)|0,n=(n=n+Math.imul(P,ie)|0)+Math.imul(O,re)|0,s=s+Math.imul(O,ie)|0,i=i+Math.imul(k,se)|0,n=(n=n+Math.imul(k,oe)|0)+Math.imul(I,se)|0,s=s+Math.imul(I,oe)|0,i=i+Math.imul(S,ce)|0,n=(n=n+Math.imul(S,ue)|0)+Math.imul(T,ce)|0,s=s+Math.imul(T,ue)|0,i=i+Math.imul(w,de)|0,n=(n=n+Math.imul(w,fe)|0)+Math.imul(_,de)|0,s=s+Math.imul(_,fe)|0;var Ie=(u+(i=i+Math.imul(m,pe)|0)|0)+((8191&(n=(n=n+Math.imul(m,ge)|0)+Math.imul(b,pe)|0))<<13)|0;u=((s=s+Math.imul(b,ge)|0)+(n>>>13)|0)+(Ie>>>26)|0,Ie&=67108863,i=Math.imul(N,X),n=(n=Math.imul(N,Z))+Math.imul(U,X)|0,s=Math.imul(U,Z),i=i+Math.imul(x,J)|0,n=(n=n+Math.imul(x,ee)|0)+Math.imul(B,J)|0,s=s+Math.imul(B,ee)|0,i=i+Math.imul(j,re)|0,n=(n=n+Math.imul(j,ie)|0)+Math.imul(D,re)|0,s=s+Math.imul(D,ie)|0,i=i+Math.imul(P,se)|0,n=(n=n+Math.imul(P,oe)|0)+Math.imul(O,se)|0,s=s+Math.imul(O,oe)|0,i=i+Math.imul(k,ce)|0,n=(n=n+Math.imul(k,ue)|0)+Math.imul(I,ce)|0,s=s+Math.imul(I,ue)|0,i=i+Math.imul(S,de)|0,n=(n=n+Math.imul(S,fe)|0)+Math.imul(T,de)|0,s=s+Math.imul(T,fe)|0;var Re=(u+(i=i+Math.imul(w,pe)|0)|0)+((8191&(n=(n=n+Math.imul(w,ge)|0)+Math.imul(_,pe)|0))<<13)|0;u=((s=s+Math.imul(_,ge)|0)+(n>>>13)|0)+(Re>>>26)|0,Re&=67108863,i=Math.imul(N,J),n=(n=Math.imul(N,ee))+Math.imul(U,J)|0,s=Math.imul(U,ee),i=i+Math.imul(x,re)|0,n=(n=n+Math.imul(x,ie)|0)+Math.imul(B,re)|0,s=s+Math.imul(B,ie)|0,i=i+Math.imul(j,se)|0,n=(n=n+Math.imul(j,oe)|0)+Math.imul(D,se)|0,s=s+Math.imul(D,oe)|0,i=i+Math.imul(P,ce)|0,n=(n=n+Math.imul(P,ue)|0)+Math.imul(O,ce)|0,s=s+Math.imul(O,ue)|0,i=i+Math.imul(k,de)|0,n=(n=n+Math.imul(k,fe)|0)+Math.imul(I,de)|0,s=s+Math.imul(I,fe)|0;var Pe=(u+(i=i+Math.imul(S,pe)|0)|0)+((8191&(n=(n=n+Math.imul(S,ge)|0)+Math.imul(T,pe)|0))<<13)|0;u=((s=s+Math.imul(T,ge)|0)+(n>>>13)|0)+(Pe>>>26)|0,Pe&=67108863,i=Math.imul(N,re),n=(n=Math.imul(N,ie))+Math.imul(U,re)|0,s=Math.imul(U,ie),i=i+Math.imul(x,se)|0,n=(n=n+Math.imul(x,oe)|0)+Math.imul(B,se)|0,s=s+Math.imul(B,oe)|0,i=i+Math.imul(j,ce)|0,n=(n=n+Math.imul(j,ue)|0)+Math.imul(D,ce)|0,s=s+Math.imul(D,ue)|0,i=i+Math.imul(P,de)|0,n=(n=n+Math.imul(P,fe)|0)+Math.imul(O,de)|0,s=s+Math.imul(O,fe)|0;var Oe=(u+(i=i+Math.imul(k,pe)|0)|0)+((8191&(n=(n=n+Math.imul(k,ge)|0)+Math.imul(I,pe)|0))<<13)|0;u=((s=s+Math.imul(I,ge)|0)+(n>>>13)|0)+(Oe>>>26)|0,Oe&=67108863,i=Math.imul(N,se),n=(n=Math.imul(N,oe))+Math.imul(U,se)|0,s=Math.imul(U,oe),i=i+Math.imul(x,ce)|0,n=(n=n+Math.imul(x,ue)|0)+Math.imul(B,ce)|0,s=s+Math.imul(B,ue)|0,i=i+Math.imul(j,de)|0,n=(n=n+Math.imul(j,fe)|0)+Math.imul(D,de)|0,s=s+Math.imul(D,fe)|0;var Ce=(u+(i=i+Math.imul(P,pe)|0)|0)+((8191&(n=(n=n+Math.imul(P,ge)|0)+Math.imul(O,pe)|0))<<13)|0;u=((s=s+Math.imul(O,ge)|0)+(n>>>13)|0)+(Ce>>>26)|0,Ce&=67108863,i=Math.imul(N,ce),n=(n=Math.imul(N,ue))+Math.imul(U,ce)|0,s=Math.imul(U,ue),i=i+Math.imul(x,de)|0,n=(n=n+Math.imul(x,fe)|0)+Math.imul(B,de)|0,s=s+Math.imul(B,fe)|0;var je=(u+(i=i+Math.imul(j,pe)|0)|0)+((8191&(n=(n=n+Math.imul(j,ge)|0)+Math.imul(D,pe)|0))<<13)|0;u=((s=s+Math.imul(D,ge)|0)+(n>>>13)|0)+(je>>>26)|0,je&=67108863,i=Math.imul(N,de),n=(n=Math.imul(N,fe))+Math.imul(U,de)|0,s=Math.imul(U,fe);var De=(u+(i=i+Math.imul(x,pe)|0)|0)+((8191&(n=(n=n+Math.imul(x,ge)|0)+Math.imul(B,pe)|0))<<13)|0;u=((s=s+Math.imul(B,ge)|0)+(n>>>13)|0)+(De>>>26)|0,De&=67108863;var Me=(u+(i=Math.imul(N,pe))|0)+((8191&(n=(n=Math.imul(N,ge))+Math.imul(U,pe)|0))<<13)|0;return u=((s=Math.imul(U,ge))+(n>>>13)|0)+(Me>>>26)|0,Me&=67108863,c[0]=ye,c[1]=me,c[2]=be,c[3]=ve,c[4]=we,c[5]=_e,c[6]=Ee,c[7]=Se,c[8]=Te,c[9]=Ae,c[10]=ke,c[11]=Ie,c[12]=Re,c[13]=Pe,c[14]=Oe,c[15]=Ce,c[16]=je,c[17]=De,c[18]=Me,0!==u&&(c[19]=u,r.length++),r};function g(e,t,r){return(new y).mulp(e,t,r)}function y(e,t){this.x=e,this.y=t}Math.imul||(p=h),s.prototype.mulTo=function(e,t){var r,i=this.length+e.length;return r=10===this.length&&10===e.length?p(this,e,t):i<63?h(this,e,t):i<1024?function(e,t,r){r.negative=t.negative^e.negative,r.length=e.length+t.length;for(var i=0,n=0,s=0;s>>26)|0)>>>26,o&=67108863}r.words[s]=a,i=o,o=n}return 0!==i?r.words[s]=i:r.length--,r.strip()}(this,e,t):g(this,e,t),r},y.prototype.makeRBT=function(e){for(var t=new Array(e),r=s.prototype._countBits(e)-1,i=0;i>=1;return i},y.prototype.permute=function(e,t,r,i,n,s){for(var o=0;o>>=1)n++;return 1<>>=13,r[2*o+1]=8191&s,s>>>=13;for(o=2*t;o>=26,t+=n/67108864|0,t+=s>>>26,this.words[r]=67108863&s}return 0!==t&&(this.words[r]=t,this.length++),this},s.prototype.muln=function(e){return this.clone().imuln(e)},s.prototype.sqr=function(){return this.mul(this)},s.prototype.isqr=function(){return this.imul(this.clone())},s.prototype.pow=function(e){var t=function(e){for(var t=new Array(e.bitLength()),r=0;r>>n}return t}(e);if(0===t.length)return new s(1);for(var r=this,i=0;i=0);var t,r=e%26,n=(e-r)/26,s=67108863>>>26-r<<26-r;if(0!==r){var o=0;for(t=0;t>>26-r}o&&(this.words[t]=o,this.length++)}if(0!==n){for(t=this.length-1;t>=0;t--)this.words[t+n]=this.words[t];for(t=0;t=0),n=t?(t-t%26)/26:0;var s=e%26,o=Math.min((e-s)/26,this.length),a=67108863^67108863>>>s<o)for(this.length-=o,u=0;u=0&&(0!==l||u>=n);u--){var d=0|this.words[u];this.words[u]=l<<26-s|d>>>s,l=d&a}return c&&0!==l&&(c.words[c.length++]=l),0===this.length&&(this.words[0]=0,this.length=1),this.strip()},s.prototype.ishrn=function(e,t,r){return i(0===this.negative),this.iushrn(e,t,r)},s.prototype.shln=function(e){return this.clone().ishln(e)},s.prototype.ushln=function(e){return this.clone().iushln(e)},s.prototype.shrn=function(e){return this.clone().ishrn(e)},s.prototype.ushrn=function(e){return this.clone().iushrn(e)},s.prototype.testn=function(e){i("number"==typeof e&&e>=0);var t=e%26,r=(e-t)/26,n=1<=0);var t=e%26,r=(e-t)/26;if(i(0===this.negative,"imaskn works only with positive numbers"),this.length<=r)return this;if(0!==t&&r++,this.length=Math.min(r,this.length),0!==t){var n=67108863^67108863>>>t<=67108864;t++)this.words[t]-=67108864,t===this.length-1?this.words[t+1]=1:this.words[t+1]++;return this.length=Math.max(this.length,t+1),this},s.prototype.isubn=function(e){if(i("number"==typeof e),i(e<67108864),e<0)return this.iaddn(-e);if(0!==this.negative)return this.negative=0,this.iaddn(e),this.negative=1,this;if(this.words[0]-=e,1===this.length&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var t=0;t>26)-(c/67108864|0),this.words[n+r]=67108863&s}for(;n>26,this.words[n+r]=67108863&s;if(0===a)return this.strip();for(i(-1===a),a=0,n=0;n>26,this.words[n]=67108863&s;return this.negative=1,this.strip()},s.prototype._wordDiv=function(e,t){var r=(this.length,e.length),i=this.clone(),n=e,o=0|n.words[n.length-1];0!==(r=26-this._countBits(o))&&(n=n.ushln(r),i.iushln(r),o=0|n.words[n.length-1]);var a,c=i.length-n.length;if("mod"!==t){(a=new s(null)).length=c+1,a.words=new Array(a.length);for(var u=0;u=0;d--){var f=67108864*(0|i.words[n.length+d])+(0|i.words[n.length+d-1]);for(f=Math.min(f/o|0,67108863),i._ishlnsubmul(n,f,d);0!==i.negative;)f--,i.negative=0,i._ishlnsubmul(n,1,d),i.isZero()||(i.negative^=1);a&&(a.words[d]=f)}return a&&a.strip(),i.strip(),"div"!==t&&0!==r&&i.iushrn(r),{div:a||null,mod:i}},s.prototype.divmod=function(e,t,r){return i(!e.isZero()),this.isZero()?{div:new s(0),mod:new s(0)}:0!==this.negative&&0===e.negative?(a=this.neg().divmod(e,t),"mod"!==t&&(n=a.div.neg()),"div"!==t&&(o=a.mod.neg(),r&&0!==o.negative&&o.iadd(e)),{div:n,mod:o}):0===this.negative&&0!==e.negative?(a=this.divmod(e.neg(),t),"mod"!==t&&(n=a.div.neg()),{div:n,mod:a.mod}):0!=(this.negative&e.negative)?(a=this.neg().divmod(e.neg(),t),"div"!==t&&(o=a.mod.neg(),r&&0!==o.negative&&o.isub(e)),{div:a.div,mod:o}):e.length>this.length||this.cmp(e)<0?{div:new s(0),mod:this}:1===e.length?"div"===t?{div:this.divn(e.words[0]),mod:null}:"mod"===t?{div:null,mod:new s(this.modn(e.words[0]))}:{div:this.divn(e.words[0]),mod:new s(this.modn(e.words[0]))}:this._wordDiv(e,t);var n,o,a},s.prototype.div=function(e){return this.divmod(e,"div",!1).div},s.prototype.mod=function(e){return this.divmod(e,"mod",!1).mod},s.prototype.umod=function(e){return this.divmod(e,"mod",!0).mod},s.prototype.divRound=function(e){var t=this.divmod(e);if(t.mod.isZero())return t.div;var r=0!==t.div.negative?t.mod.isub(e):t.mod,i=e.ushrn(1),n=e.andln(1),s=r.cmp(i);return s<0||1===n&&0===s?t.div:0!==t.div.negative?t.div.isubn(1):t.div.iaddn(1)},s.prototype.modn=function(e){i(e<=67108863);for(var t=67108864%e,r=0,n=this.length-1;n>=0;n--)r=(t*r+(0|this.words[n]))%e;return r},s.prototype.idivn=function(e){i(e<=67108863);for(var t=0,r=this.length-1;r>=0;r--){var n=(0|this.words[r])+67108864*t;this.words[r]=n/e|0,t=n%e}return this.strip()},s.prototype.divn=function(e){return this.clone().idivn(e)},s.prototype.egcd=function(e){i(0===e.negative),i(!e.isZero());var t=this,r=e.clone();t=0!==t.negative?t.umod(e):t.clone();for(var n=new s(1),o=new s(0),a=new s(0),c=new s(1),u=0;t.isEven()&&r.isEven();)t.iushrn(1),r.iushrn(1),++u;for(var l=r.clone(),d=t.clone();!t.isZero();){for(var f=0,h=1;0==(t.words[0]&h)&&f<26;++f,h<<=1);if(f>0)for(t.iushrn(f);f-- >0;)(n.isOdd()||o.isOdd())&&(n.iadd(l),o.isub(d)),n.iushrn(1),o.iushrn(1);for(var p=0,g=1;0==(r.words[0]&g)&&p<26;++p,g<<=1);if(p>0)for(r.iushrn(p);p-- >0;)(a.isOdd()||c.isOdd())&&(a.iadd(l),c.isub(d)),a.iushrn(1),c.iushrn(1);t.cmp(r)>=0?(t.isub(r),n.isub(a),o.isub(c)):(r.isub(t),a.isub(n),c.isub(o))}return{a:a,b:c,gcd:r.iushln(u)}},s.prototype._invmp=function(e){i(0===e.negative),i(!e.isZero());var t=this,r=e.clone();t=0!==t.negative?t.umod(e):t.clone();for(var n,o=new s(1),a=new s(0),c=r.clone();t.cmpn(1)>0&&r.cmpn(1)>0;){for(var u=0,l=1;0==(t.words[0]&l)&&u<26;++u,l<<=1);if(u>0)for(t.iushrn(u);u-- >0;)o.isOdd()&&o.iadd(c),o.iushrn(1);for(var d=0,f=1;0==(r.words[0]&f)&&d<26;++d,f<<=1);if(d>0)for(r.iushrn(d);d-- >0;)a.isOdd()&&a.iadd(c),a.iushrn(1);t.cmp(r)>=0?(t.isub(r),o.isub(a)):(r.isub(t),a.isub(o))}return(n=0===t.cmpn(1)?o:a).cmpn(0)<0&&n.iadd(e),n},s.prototype.gcd=function(e){if(this.isZero())return e.abs();if(e.isZero())return this.abs();var t=this.clone(),r=e.clone();t.negative=0,r.negative=0;for(var i=0;t.isEven()&&r.isEven();i++)t.iushrn(1),r.iushrn(1);for(;;){for(;t.isEven();)t.iushrn(1);for(;r.isEven();)r.iushrn(1);var n=t.cmp(r);if(n<0){var s=t;t=r,r=s}else if(0===n||0===r.cmpn(1))break;t.isub(r)}return r.iushln(i)},s.prototype.invm=function(e){return this.egcd(e).a.umod(e)},s.prototype.isEven=function(){return 0==(1&this.words[0])},s.prototype.isOdd=function(){return 1==(1&this.words[0])},s.prototype.andln=function(e){return this.words[0]&e},s.prototype.bincn=function(e){i("number"==typeof e);var t=e%26,r=(e-t)/26,n=1<>>26,a&=67108863,this.words[o]=a}return 0!==s&&(this.words[o]=s,this.length++),this},s.prototype.isZero=function(){return 1===this.length&&0===this.words[0]},s.prototype.cmpn=function(e){var t,r=e<0;if(0!==this.negative&&!r)return-1;if(0===this.negative&&r)return 1;if(this.strip(),this.length>1)t=1;else{r&&(e=-e),i(e<=67108863,"Number is too big");var n=0|this.words[0];t=n===e?0:ne.length)return 1;if(this.length=0;r--){var i=0|this.words[r],n=0|e.words[r];if(i!==n){in&&(t=1);break}}return t},s.prototype.gtn=function(e){return 1===this.cmpn(e)},s.prototype.gt=function(e){return 1===this.cmp(e)},s.prototype.gten=function(e){return this.cmpn(e)>=0},s.prototype.gte=function(e){return this.cmp(e)>=0},s.prototype.ltn=function(e){return-1===this.cmpn(e)},s.prototype.lt=function(e){return-1===this.cmp(e)},s.prototype.lten=function(e){return this.cmpn(e)<=0},s.prototype.lte=function(e){return this.cmp(e)<=0},s.prototype.eqn=function(e){return 0===this.cmpn(e)},s.prototype.eq=function(e){return 0===this.cmp(e)},s.red=function(e){return new S(e)},s.prototype.toRed=function(e){return i(!this.red,"Already a number in reduction context"),i(0===this.negative,"red works only with positives"),e.convertTo(this)._forceRed(e)},s.prototype.fromRed=function(){return i(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},s.prototype._forceRed=function(e){return this.red=e,this},s.prototype.forceRed=function(e){return i(!this.red,"Already a number in reduction context"),this._forceRed(e)},s.prototype.redAdd=function(e){return i(this.red,"redAdd works only with red numbers"),this.red.add(this,e)},s.prototype.redIAdd=function(e){return i(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,e)},s.prototype.redSub=function(e){return i(this.red,"redSub works only with red numbers"),this.red.sub(this,e)},s.prototype.redISub=function(e){return i(this.red,"redISub works only with red numbers"),this.red.isub(this,e)},s.prototype.redShl=function(e){return i(this.red,"redShl works only with red numbers"),this.red.shl(this,e)},s.prototype.redMul=function(e){return i(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.mul(this,e)},s.prototype.redIMul=function(e){return i(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.imul(this,e)},s.prototype.redSqr=function(){return i(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},s.prototype.redISqr=function(){return i(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},s.prototype.redSqrt=function(){return i(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},s.prototype.redInvm=function(){return i(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},s.prototype.redNeg=function(){return i(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},s.prototype.redPow=function(e){return i(this.red&&!e.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,e)};var m={k256:null,p224:null,p192:null,p25519:null};function b(e,t){this.name=e,this.p=new s(t,16),this.n=this.p.bitLength(),this.k=new s(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}function v(){b.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}function w(){b.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}function _(){b.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}function E(){b.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}function S(e){if("string"==typeof e){var t=s._prime(e);this.m=t.p,this.prime=t}else i(e.gtn(1),"modulus must be greater than 1"),this.m=e,this.prime=null}function T(e){S.call(this,e),this.shift=this.m.bitLength(),this.shift%26!=0&&(this.shift+=26-this.shift%26),this.r=new s(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}b.prototype._tmp=function(){var e=new s(null);return e.words=new Array(Math.ceil(this.n/13)),e},b.prototype.ireduce=function(e){var t,r=e;do{this.split(r,this.tmp),t=(r=(r=this.imulK(r)).iadd(this.tmp)).bitLength()}while(t>this.n);var i=t0?r.isub(this.p):void 0!==r.strip?r.strip():r._strip(),r},b.prototype.split=function(e,t){e.iushrn(this.n,0,t)},b.prototype.imulK=function(e){return e.imul(this.k)},n(v,b),v.prototype.split=function(e,t){for(var r=4194303,i=Math.min(e.length,9),n=0;n>>22,s=o}s>>>=22,e.words[n-10]=s,0===s&&e.length>10?e.length-=10:e.length-=9},v.prototype.imulK=function(e){e.words[e.length]=0,e.words[e.length+1]=0,e.length+=2;for(var t=0,r=0;r>>=26,e.words[r]=n,t=i}return 0!==t&&(e.words[e.length++]=t),e},s._prime=function(e){if(m[e])return m[e];var t;if("k256"===e)t=new v;else if("p224"===e)t=new w;else if("p192"===e)t=new _;else{if("p25519"!==e)throw new Error("Unknown prime "+e);t=new E}return m[e]=t,t},S.prototype._verify1=function(e){i(0===e.negative,"red works only with positives"),i(e.red,"red works only with red numbers")},S.prototype._verify2=function(e,t){i(0==(e.negative|t.negative),"red works only with positives"),i(e.red&&e.red===t.red,"red works only with red numbers")},S.prototype.imod=function(e){return this.prime?this.prime.ireduce(e)._forceRed(this):e.umod(this.m)._forceRed(this)},S.prototype.neg=function(e){return e.isZero()?e.clone():this.m.sub(e)._forceRed(this)},S.prototype.add=function(e,t){this._verify2(e,t);var r=e.add(t);return r.cmp(this.m)>=0&&r.isub(this.m),r._forceRed(this)},S.prototype.iadd=function(e,t){this._verify2(e,t);var r=e.iadd(t);return r.cmp(this.m)>=0&&r.isub(this.m),r},S.prototype.sub=function(e,t){this._verify2(e,t);var r=e.sub(t);return r.cmpn(0)<0&&r.iadd(this.m),r._forceRed(this)},S.prototype.isub=function(e,t){this._verify2(e,t);var r=e.isub(t);return r.cmpn(0)<0&&r.iadd(this.m),r},S.prototype.shl=function(e,t){return this._verify1(e),this.imod(e.ushln(t))},S.prototype.imul=function(e,t){return this._verify2(e,t),this.imod(e.imul(t))},S.prototype.mul=function(e,t){return this._verify2(e,t),this.imod(e.mul(t))},S.prototype.isqr=function(e){return this.imul(e,e.clone())},S.prototype.sqr=function(e){return this.mul(e,e)},S.prototype.sqrt=function(e){if(e.isZero())return e.clone();var t=this.m.andln(3);if(i(t%2==1),3===t){var r=this.m.add(new s(1)).iushrn(2);return this.pow(e,r)}for(var n=this.m.subn(1),o=0;!n.isZero()&&0===n.andln(1);)o++,n.iushrn(1);i(!n.isZero());var a=new s(1).toRed(this),c=a.redNeg(),u=this.m.subn(1).iushrn(1),l=this.m.bitLength();for(l=new s(2*l*l).toRed(this);0!==this.pow(l,u).cmp(c);)l.redIAdd(c);for(var d=this.pow(l,n),f=this.pow(e,n.addn(1).iushrn(1)),h=this.pow(e,n),p=o;0!==h.cmp(a);){for(var g=h,y=0;0!==g.cmp(a);y++)g=g.redSqr();i(y=0;i--){for(var u=t.words[i],l=c-1;l>=0;l--){var d=u>>l&1;n!==r[0]&&(n=this.sqr(n)),0!==d||0!==o?(o<<=1,o|=d,(4===++a||0===i&&0===l)&&(n=this.mul(n,r[o]),a=0,o=0)):a=0}c=26}return n},S.prototype.convertTo=function(e){var t=e.umod(this.m);return t===e?t.clone():t},S.prototype.convertFrom=function(e){var t=e.clone();return t.red=null,t},s.mont=function(e){return new T(e)},n(T,S),T.prototype.convertTo=function(e){return this.imod(e.ushln(this.shift))},T.prototype.convertFrom=function(e){var t=this.imod(e.mul(this.rinv));return t.red=null,t},T.prototype.imul=function(e,t){if(e.isZero()||t.isZero())return e.words[0]=0,e.length=1,e;var r=e.imul(t),i=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),n=r.isub(i).iushrn(this.shift),s=n;return n.cmp(this.m)>=0?s=n.isub(this.m):n.cmpn(0)<0&&(s=n.iadd(this.m)),s._forceRed(this)},T.prototype.mul=function(e,t){if(e.isZero()||t.isZero())return new s(0)._forceRed(this);var r=e.mul(t),i=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),n=r.isub(i).iushrn(this.shift),o=n;return n.cmp(this.m)>=0?o=n.isub(this.m):n.cmpn(0)<0&&(o=n.iadd(this.m)),o._forceRed(this)},T.prototype.invm=function(e){return this.imod(e._invmp(this.m).mul(this.r2))._forceRed(this)}}(void 0===t||t,this)},{buffer:"lHksA"}],"1GrVu":[function(e,t,r){function i(e,t){if(!e)throw new Error(t||"Assertion failed")}t.exports=i,i.equal=function(e,t,r){if(e!=t)throw new Error(r||"Assertion failed: "+e+" != "+t)}},{}],"3MGAl":[function(e,t,r){"use strict";var i=r;function n(e){return 1===e.length?"0"+e:e}function s(e){for(var t="",r=0;r>8,o=255&n;s?r.push(s,o):r.push(o)}return r},i.zero2=n,i.toHex=s,i.encode=function(e,t){return"hex"===t?s(e):e}},{}],P54o1:[function(e,t,r){var i;function n(e){this.rand=e}if(t.exports=function(e){return i||(i=new n(null)),i.generate(e)},t.exports.Rand=n,n.prototype.generate=function(e){return this._rand(e)},n.prototype._rand=function(e){if(this.rand.getBytes)return this.rand.getBytes(e);for(var t=new Uint8Array(e),r=0;r0?this.redN=null:(this._maxwellTrick=!0,this.redN=this.n.toRed(this.red))}function u(e,t){this.curve=e,this.type=t,this.precomputed=null}t.exports=c,c.prototype.point=function(){throw new Error("Not implemented")},c.prototype.validate=function(){throw new Error("Not implemented")},c.prototype._fixedNafMul=function(e,t){a(e.precomputed);var r=e._getDoubles(),i=s(t,1,this._bitLength),n=(1<=o;l--)c=(c<<1)+i[l];u.push(c)}for(var d=this.jpoint(null,null,null),f=this.jpoint(null,null,null),h=n;h>0;h--){for(o=0;o=0;u--){for(var l=0;u>=0&&0===o[u];u--)l++;if(u>=0&&l++,c=c.dblp(l),u<0)break;var d=o[u];a(0!==d),c="affine"===e.type?d>0?c.mixedAdd(n[d-1>>1]):c.mixedAdd(n[-d-1>>1].neg()):d>0?c.add(n[d-1>>1]):c.add(n[-d-1>>1].neg())}return"affine"===e.type?c.toP():c},c.prototype._wnafMulAdd=function(e,t,r,i,n){var a,c,u,l=this._wnafT1,d=this._wnafT2,f=this._wnafT3,h=0;for(a=0;a=1;a-=2){var g=a-1,y=a;if(1===l[g]&&1===l[y]){var m=[t[g],null,null,t[y]];0===t[g].y.cmp(t[y].y)?(m[1]=t[g].add(t[y]),m[2]=t[g].toJ().mixedAdd(t[y].neg())):0===t[g].y.cmp(t[y].y.redNeg())?(m[1]=t[g].toJ().mixedAdd(t[y]),m[2]=t[g].add(t[y].neg())):(m[1]=t[g].toJ().mixedAdd(t[y]),m[2]=t[g].toJ().mixedAdd(t[y].neg()));var b=[-3,-1,-5,-7,0,7,5,1,3],v=o(r[g],r[y]);for(h=Math.max(v[0].length,h),f[g]=new Array(h),f[y]=new Array(h),c=0;c=0;a--){for(var T=0;a>=0;){var A=!0;for(c=0;c=0&&T++,E=E.dblp(T),a<0)break;for(c=0;c0?u=d[c][k-1>>1]:k<0&&(u=d[c][-k-1>>1].neg()),E="affine"===u.type?E.mixedAdd(u):E.add(u))}}for(a=0;a=Math.ceil((e.bitLength()+1)/t.step)},u.prototype._getDoubles=function(e,t){if(this.precomputed&&this.precomputed.doubles)return this.precomputed.doubles;for(var r=[this],i=this,n=0;n=0&&(o=t,a=r),i.negative&&(i=i.neg(),s=s.neg()),o.negative&&(o=o.neg(),a=a.neg()),[{a:i,b:s},{a:o,b:a}]},c.prototype._endoSplit=function(e){var t=this.endo.basis,r=t[0],i=t[1],n=i.b.mul(e).divRound(this.n),s=r.b.neg().mul(e).divRound(this.n),o=n.mul(r.a),a=s.mul(i.a),c=n.mul(r.b),u=s.mul(i.b);return{k1:e.sub(o).sub(a),k2:c.add(u).neg()}},c.prototype.pointFromX=function(e,t){(e=new n(e,16)).red||(e=e.toRed(this.red));var r=e.redSqr().redMul(e).redIAdd(e.redMul(this.a)).redIAdd(this.b),i=r.redSqrt();if(0!==i.redSqr().redSub(r).cmp(this.zero))throw new Error("invalid point");var s=i.fromRed().isOdd();return(t&&!s||!t&&s)&&(i=i.redNeg()),this.point(e,i)},c.prototype.validate=function(e){if(e.inf)return!0;var t=e.x,r=e.y,i=this.a.redMul(t),n=t.redSqr().redMul(t).redIAdd(i).redIAdd(this.b);return 0===r.redSqr().redISub(n).cmpn(0)},c.prototype._endoWnafMulAdd=function(e,t,r){for(var i=this._endoWnafT1,n=this._endoWnafT2,s=0;s":""},u.prototype.isInfinity=function(){return this.inf},u.prototype.add=function(e){if(this.inf)return e;if(e.inf)return this;if(this.eq(e))return this.dbl();if(this.neg().eq(e))return this.curve.point(null,null);if(0===this.x.cmp(e.x))return this.curve.point(null,null);var t=this.y.redSub(e.y);0!==t.cmpn(0)&&(t=t.redMul(this.x.redSub(e.x).redInvm()));var r=t.redSqr().redISub(this.x).redISub(e.x),i=t.redMul(this.x.redSub(r)).redISub(this.y);return this.curve.point(r,i)},u.prototype.dbl=function(){if(this.inf)return this;var e=this.y.redAdd(this.y);if(0===e.cmpn(0))return this.curve.point(null,null);var t=this.curve.a,r=this.x.redSqr(),i=e.redInvm(),n=r.redAdd(r).redIAdd(r).redIAdd(t).redMul(i),s=n.redSqr().redISub(this.x.redAdd(this.x)),o=n.redMul(this.x.redSub(s)).redISub(this.y);return this.curve.point(s,o)},u.prototype.getX=function(){return this.x.fromRed()},u.prototype.getY=function(){return this.y.fromRed()},u.prototype.mul=function(e){return e=new n(e,16),this.isInfinity()?this:this._hasDoubles(e)?this.curve._fixedNafMul(this,e):this.curve.endo?this.curve._endoWnafMulAdd([this],[e]):this.curve._wnafMul(this,e)},u.prototype.mulAdd=function(e,t,r){var i=[this,t],n=[e,r];return this.curve.endo?this.curve._endoWnafMulAdd(i,n):this.curve._wnafMulAdd(1,i,n,2)},u.prototype.jmulAdd=function(e,t,r){var i=[this,t],n=[e,r];return this.curve.endo?this.curve._endoWnafMulAdd(i,n,!0):this.curve._wnafMulAdd(1,i,n,2,!0)},u.prototype.eq=function(e){return this===e||this.inf===e.inf&&(this.inf||0===this.x.cmp(e.x)&&0===this.y.cmp(e.y))},u.prototype.neg=function(e){if(this.inf)return this;var t=this.curve.point(this.x,this.y.redNeg());if(e&&this.precomputed){var r=this.precomputed,i=function(e){return e.neg()};t.precomputed={naf:r.naf&&{wnd:r.naf.wnd,points:r.naf.points.map(i)},doubles:r.doubles&&{step:r.doubles.step,points:r.doubles.points.map(i)}}}return t},u.prototype.toJ=function(){return this.inf?this.curve.jpoint(null,null,null):this.curve.jpoint(this.x,this.y,this.curve.one)},s(l,o.BasePoint),c.prototype.jpoint=function(e,t,r){return new l(this,e,t,r)},l.prototype.toP=function(){if(this.isInfinity())return this.curve.point(null,null);var e=this.z.redInvm(),t=e.redSqr(),r=this.x.redMul(t),i=this.y.redMul(t).redMul(e);return this.curve.point(r,i)},l.prototype.neg=function(){return this.curve.jpoint(this.x,this.y.redNeg(),this.z)},l.prototype.add=function(e){if(this.isInfinity())return e;if(e.isInfinity())return this;var t=e.z.redSqr(),r=this.z.redSqr(),i=this.x.redMul(t),n=e.x.redMul(r),s=this.y.redMul(t.redMul(e.z)),o=e.y.redMul(r.redMul(this.z)),a=i.redSub(n),c=s.redSub(o);if(0===a.cmpn(0))return 0!==c.cmpn(0)?this.curve.jpoint(null,null,null):this.dbl();var u=a.redSqr(),l=u.redMul(a),d=i.redMul(u),f=c.redSqr().redIAdd(l).redISub(d).redISub(d),h=c.redMul(d.redISub(f)).redISub(s.redMul(l)),p=this.z.redMul(e.z).redMul(a);return this.curve.jpoint(f,h,p)},l.prototype.mixedAdd=function(e){if(this.isInfinity())return e.toJ();if(e.isInfinity())return this;var t=this.z.redSqr(),r=this.x,i=e.x.redMul(t),n=this.y,s=e.y.redMul(t).redMul(this.z),o=r.redSub(i),a=n.redSub(s);if(0===o.cmpn(0))return 0!==a.cmpn(0)?this.curve.jpoint(null,null,null):this.dbl();var c=o.redSqr(),u=c.redMul(o),l=r.redMul(c),d=a.redSqr().redIAdd(u).redISub(l).redISub(l),f=a.redMul(l.redISub(d)).redISub(n.redMul(u)),h=this.z.redMul(o);return this.curve.jpoint(d,f,h)},l.prototype.dblp=function(e){if(0===e)return this;if(this.isInfinity())return this;if(!e)return this.dbl();var t;if(this.curve.zeroA||this.curve.threeA){var r=this;for(t=0;t=0)return!1;if(r.redIAdd(n),0===this.x.cmp(r))return!0}},l.prototype.inspect=function(){return this.isInfinity()?"":""},l.prototype.isInfinity=function(){return 0===this.z.cmpn(0)}},{"../utils":"959xT","bn.js":"c8Lvi",inherits:"j5plK","./base":"joYZE"}],j5plK:[function(e,t,r){"function"==typeof Object.create?t.exports=function(e,t){t&&(e.super_=t,e.prototype=Object.create(t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}))}:t.exports=function(e,t){if(t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}}},{}],exiKb:[function(e,t,r){"use strict";var i=e("bn.js"),n=e("inherits"),s=e("./base"),o=e("../utils");function a(e){s.call(this,"mont",e),this.a=new i(e.a,16).toRed(this.red),this.b=new i(e.b,16).toRed(this.red),this.i4=new i(4).toRed(this.red).redInvm(),this.two=new i(2).toRed(this.red),this.a24=this.i4.redMul(this.a.redAdd(this.two))}function c(e,t,r){s.BasePoint.call(this,e,"projective"),null===t&&null===r?(this.x=this.curve.one,this.z=this.curve.zero):(this.x=new i(t,16),this.z=new i(r,16),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)))}n(a,s),t.exports=a,a.prototype.validate=function(e){var t=e.normalize().x,r=t.redSqr(),i=r.redMul(t).redAdd(r.redMul(this.a)).redAdd(t);return 0===i.redSqrt().redSqr().cmp(i)},n(c,s.BasePoint),a.prototype.decodePoint=function(e,t){return this.point(o.toArray(e,t),1)},a.prototype.point=function(e,t){return new c(this,e,t)},a.prototype.pointFromJSON=function(e){return c.fromJSON(this,e)},c.prototype.precompute=function(){},c.prototype._encode=function(){return this.getX().toArray("be",this.curve.p.byteLength())},c.fromJSON=function(e,t){return new c(e,t[0],t[1]||e.one)},c.prototype.inspect=function(){return this.isInfinity()?"":""},c.prototype.isInfinity=function(){return 0===this.z.cmpn(0)},c.prototype.dbl=function(){var e=this.x.redAdd(this.z).redSqr(),t=this.x.redSub(this.z).redSqr(),r=e.redSub(t),i=e.redMul(t),n=r.redMul(t.redAdd(this.curve.a24.redMul(r)));return this.curve.point(i,n)},c.prototype.add=function(){throw new Error("Not supported on Montgomery curve")},c.prototype.diffAdd=function(e,t){var r=this.x.redAdd(this.z),i=this.x.redSub(this.z),n=e.x.redAdd(e.z),s=e.x.redSub(e.z).redMul(r),o=n.redMul(i),a=t.z.redMul(s.redAdd(o).redSqr()),c=t.x.redMul(s.redISub(o).redSqr());return this.curve.point(a,c)},c.prototype.mul=function(e){for(var t=e.clone(),r=this,i=this.curve.point(null,null),n=[];0!==t.cmpn(0);t.iushrn(1))n.push(t.andln(1));for(var s=n.length-1;s>=0;s--)0===n[s]?(r=r.diffAdd(i,this),i=i.dbl()):(i=r.diffAdd(i,this),r=r.dbl());return i},c.prototype.mulAdd=function(){throw new Error("Not supported on Montgomery curve")},c.prototype.jumlAdd=function(){throw new Error("Not supported on Montgomery curve")},c.prototype.eq=function(e){return 0===this.getX().cmp(e.getX())},c.prototype.normalize=function(){return this.x=this.x.redMul(this.z.redInvm()),this.z=this.curve.one,this},c.prototype.getX=function(){return this.normalize(),this.x.fromRed()}},{"bn.js":"c8Lvi",inherits:"j5plK","./base":"joYZE","../utils":"959xT"}],d2B4t:[function(e,t,r){"use strict";var i=e("../utils"),n=e("bn.js"),s=e("inherits"),o=e("./base"),a=i.assert;function c(e){this.twisted=1!=(0|e.a),this.mOneA=this.twisted&&-1==(0|e.a),this.extended=this.mOneA,o.call(this,"edwards",e),this.a=new n(e.a,16).umod(this.red.m),this.a=this.a.toRed(this.red),this.c=new n(e.c,16).toRed(this.red),this.c2=this.c.redSqr(),this.d=new n(e.d,16).toRed(this.red),this.dd=this.d.redAdd(this.d),a(!this.twisted||0===this.c.fromRed().cmpn(1)),this.oneC=1==(0|e.c)}function u(e,t,r,i,s){o.BasePoint.call(this,e,"projective"),null===t&&null===r&&null===i?(this.x=this.curve.zero,this.y=this.curve.one,this.z=this.curve.one,this.t=this.curve.zero,this.zOne=!0):(this.x=new n(t,16),this.y=new n(r,16),this.z=i?new n(i,16):this.curve.one,this.t=s&&new n(s,16),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.y.red||(this.y=this.y.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)),this.t&&!this.t.red&&(this.t=this.t.toRed(this.curve.red)),this.zOne=this.z===this.curve.one,this.curve.extended&&!this.t&&(this.t=this.x.redMul(this.y),this.zOne||(this.t=this.t.redMul(this.z.redInvm()))))}s(c,o),t.exports=c,c.prototype._mulA=function(e){return this.mOneA?e.redNeg():this.a.redMul(e)},c.prototype._mulC=function(e){return this.oneC?e:this.c.redMul(e)},c.prototype.jpoint=function(e,t,r,i){return this.point(e,t,r,i)},c.prototype.pointFromX=function(e,t){(e=new n(e,16)).red||(e=e.toRed(this.red));var r=e.redSqr(),i=this.c2.redSub(this.a.redMul(r)),s=this.one.redSub(this.c2.redMul(this.d).redMul(r)),o=i.redMul(s.redInvm()),a=o.redSqrt();if(0!==a.redSqr().redSub(o).cmp(this.zero))throw new Error("invalid point");var c=a.fromRed().isOdd();return(t&&!c||!t&&c)&&(a=a.redNeg()),this.point(e,a)},c.prototype.pointFromY=function(e,t){(e=new n(e,16)).red||(e=e.toRed(this.red));var r=e.redSqr(),i=r.redSub(this.c2),s=r.redMul(this.d).redMul(this.c2).redSub(this.a),o=i.redMul(s.redInvm());if(0===o.cmp(this.zero)){if(t)throw new Error("invalid point");return this.point(this.zero,e)}var a=o.redSqrt();if(0!==a.redSqr().redSub(o).cmp(this.zero))throw new Error("invalid point");return a.fromRed().isOdd()!==t&&(a=a.redNeg()),this.point(a,e)},c.prototype.validate=function(e){if(e.isInfinity())return!0;e.normalize();var t=e.x.redSqr(),r=e.y.redSqr(),i=t.redMul(this.a).redAdd(r),n=this.c2.redMul(this.one.redAdd(this.d.redMul(t).redMul(r)));return 0===i.cmp(n)},s(u,o.BasePoint),c.prototype.pointFromJSON=function(e){return u.fromJSON(this,e)},c.prototype.point=function(e,t,r,i){return new u(this,e,t,r,i)},u.fromJSON=function(e,t){return new u(e,t[0],t[1],t[2])},u.prototype.inspect=function(){return this.isInfinity()?"":""},u.prototype.isInfinity=function(){return 0===this.x.cmpn(0)&&(0===this.y.cmp(this.z)||this.zOne&&0===this.y.cmp(this.curve.c))},u.prototype._extDbl=function(){var e=this.x.redSqr(),t=this.y.redSqr(),r=this.z.redSqr();r=r.redIAdd(r);var i=this.curve._mulA(e),n=this.x.redAdd(this.y).redSqr().redISub(e).redISub(t),s=i.redAdd(t),o=s.redSub(r),a=i.redSub(t),c=n.redMul(o),u=s.redMul(a),l=n.redMul(a),d=o.redMul(s);return this.curve.point(c,u,d,l)},u.prototype._projDbl=function(){var e,t,r,i,n,s,o=this.x.redAdd(this.y).redSqr(),a=this.x.redSqr(),c=this.y.redSqr();if(this.curve.twisted){var u=(i=this.curve._mulA(a)).redAdd(c);this.zOne?(e=o.redSub(a).redSub(c).redMul(u.redSub(this.curve.two)),t=u.redMul(i.redSub(c)),r=u.redSqr().redSub(u).redSub(u)):(n=this.z.redSqr(),s=u.redSub(n).redISub(n),e=o.redSub(a).redISub(c).redMul(s),t=u.redMul(i.redSub(c)),r=u.redMul(s))}else i=a.redAdd(c),n=this.curve._mulC(this.z).redSqr(),s=i.redSub(n).redSub(n),e=this.curve._mulC(o.redISub(i)).redMul(s),t=this.curve._mulC(i).redMul(a.redISub(c)),r=i.redMul(s);return this.curve.point(e,t,r)},u.prototype.dbl=function(){return this.isInfinity()?this:this.curve.extended?this._extDbl():this._projDbl()},u.prototype._extAdd=function(e){var t=this.y.redSub(this.x).redMul(e.y.redSub(e.x)),r=this.y.redAdd(this.x).redMul(e.y.redAdd(e.x)),i=this.t.redMul(this.curve.dd).redMul(e.t),n=this.z.redMul(e.z.redAdd(e.z)),s=r.redSub(t),o=n.redSub(i),a=n.redAdd(i),c=r.redAdd(t),u=s.redMul(o),l=a.redMul(c),d=s.redMul(c),f=o.redMul(a);return this.curve.point(u,l,f,d)},u.prototype._projAdd=function(e){var t,r,i=this.z.redMul(e.z),n=i.redSqr(),s=this.x.redMul(e.x),o=this.y.redMul(e.y),a=this.curve.d.redMul(s).redMul(o),c=n.redSub(a),u=n.redAdd(a),l=this.x.redAdd(this.y).redMul(e.x.redAdd(e.y)).redISub(s).redISub(o),d=i.redMul(c).redMul(l);return this.curve.twisted?(t=i.redMul(u).redMul(o.redSub(this.curve._mulA(s))),r=c.redMul(u)):(t=i.redMul(u).redMul(o.redSub(s)),r=this.curve._mulC(c).redMul(u)),this.curve.point(d,t,r)},u.prototype.add=function(e){return this.isInfinity()?e:e.isInfinity()?this:this.curve.extended?this._extAdd(e):this._projAdd(e)},u.prototype.mul=function(e){return this._hasDoubles(e)?this.curve._fixedNafMul(this,e):this.curve._wnafMul(this,e)},u.prototype.mulAdd=function(e,t,r){return this.curve._wnafMulAdd(1,[this,t],[e,r],2,!1)},u.prototype.jmulAdd=function(e,t,r){return this.curve._wnafMulAdd(1,[this,t],[e,r],2,!0)},u.prototype.normalize=function(){if(this.zOne)return this;var e=this.z.redInvm();return this.x=this.x.redMul(e),this.y=this.y.redMul(e),this.t&&(this.t=this.t.redMul(e)),this.z=this.curve.one,this.zOne=!0,this},u.prototype.neg=function(){return this.curve.point(this.x.redNeg(),this.y,this.z,this.t&&this.t.redNeg())},u.prototype.getX=function(){return this.normalize(),this.x.fromRed()},u.prototype.getY=function(){return this.normalize(),this.y.fromRed()},u.prototype.eq=function(e){return this===e||0===this.getX().cmp(e.getX())&&0===this.getY().cmp(e.getY())},u.prototype.eqXToP=function(e){var t=e.toRed(this.curve.red).redMul(this.z);if(0===this.x.cmp(t))return!0;for(var r=e.clone(),i=this.curve.redN.redMul(this.z);;){if(r.iadd(this.curve.n),r.cmp(this.curve.p)>=0)return!1;if(t.redIAdd(i),0===this.x.cmp(t))return!0}},u.prototype.toP=u.prototype.normalize,u.prototype.mixedAdd=u.prototype.add},{"../utils":"959xT","bn.js":"c8Lvi",inherits:"j5plK","./base":"joYZE"}],"4unkA":[function(e,t,r){"use strict";var i,n=r,s=e("hash.js"),o=e("./curve"),a=e("./utils").assert;function c(e){"short"===e.type?this.curve=new o.short(e):"edwards"===e.type?this.curve=new o.edwards(e):this.curve=new o.mont(e),this.g=this.curve.g,this.n=this.curve.n,this.hash=e.hash,a(this.g.validate(),"Invalid curve"),a(this.g.mul(this.n).isInfinity(),"Invalid curve, G*N != O")}function u(e,t){Object.defineProperty(n,e,{configurable:!0,enumerable:!0,get:function(){var r=new c(t);return Object.defineProperty(n,e,{configurable:!0,enumerable:!0,value:r}),r}})}n.PresetCurve=c,u("p192",{type:"short",prime:"p192",p:"ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff",a:"ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc",b:"64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1",n:"ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831",hash:s.sha256,gRed:!1,g:["188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012","07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811"]}),u("p224",{type:"short",prime:"p224",p:"ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001",a:"ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe",b:"b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4",n:"ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d",hash:s.sha256,gRed:!1,g:["b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21","bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34"]}),u("p256",{type:"short",prime:null,p:"ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff",a:"ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc",b:"5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b",n:"ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551",hash:s.sha256,gRed:!1,g:["6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296","4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5"]}),u("p384",{type:"short",prime:null,p:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 ffffffff",a:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 fffffffc",b:"b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f 5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef",n:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 f4372ddf 581a0db2 48b0a77a ecec196a ccc52973",hash:s.sha384,gRed:!1,g:["aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 5502f25d bf55296c 3a545e38 72760ab7","3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 0a60b1ce 1d7e819d 7a431d7c 90ea0e5f"]}),u("p521",{type:"short",prime:null,p:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff",a:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffc",b:"00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b 99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd 3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00",n:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409",hash:s.sha512,gRed:!1,g:["000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66","00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 3fad0761 353c7086 a272c240 88be9476 9fd16650"]}),u("curve25519",{type:"mont",prime:"p25519",p:"7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed",a:"76d06",b:"1",n:"1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed",hash:s.sha256,gRed:!1,g:["9"]}),u("ed25519",{type:"edwards",prime:"p25519",p:"7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed",a:"-1",c:"1",d:"52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3",n:"1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed",hash:s.sha256,gRed:!1,g:["216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a","6666666666666666666666666666666666666666666666666666666666666658"]});try{i=e("./precomputed/secp256k1")}catch(e){i=void 0}u("secp256k1",{type:"short",prime:"k256",p:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f",a:"0",b:"7",n:"ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141",h:"1",hash:s.sha256,beta:"7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee",lambda:"5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72",basis:[{a:"3086d221a7d46bcde86c90e49284eb15",b:"-e4437ed6010e88286f547fa90abfe4c3"},{a:"114ca50f7a8e2f3f657c1108d9d44cfd8",b:"3086d221a7d46bcde86c90e49284eb15"}],gRed:!1,g:["79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798","483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8",i]})},{"hash.js":"8UgFw","./curve":"byDyH","./utils":"959xT","./precomputed/secp256k1":"0oQdV"}],"8UgFw":[function(e,t,r){var i=r;i.utils=e("./hash/utils"),i.common=e("./hash/common"),i.sha=e("./hash/sha"),i.ripemd=e("./hash/ripemd"),i.hmac=e("./hash/hmac"),i.sha1=i.sha.sha1,i.sha256=i.sha.sha256,i.sha224=i.sha.sha224,i.sha384=i.sha.sha384,i.sha512=i.sha.sha512,i.ripemd160=i.ripemd.ripemd160},{"./hash/utils":"fs59i","./hash/common":"bUDg4","./hash/sha":"allnM","./hash/ripemd":"11wsf","./hash/hmac":"7ZuTN"}],fs59i:[function(e,t,r){"use strict";var i=e("minimalistic-assert"),n=e("inherits");function s(e,t){return 55296==(64512&e.charCodeAt(t))&&(!(t<0||t+1>=e.length)&&56320==(64512&e.charCodeAt(t+1)))}function o(e){return(e>>>24|e>>>8&65280|e<<8&16711680|(255&e)<<24)>>>0}function a(e){return 1===e.length?"0"+e:e}function c(e){return 7===e.length?"0"+e:6===e.length?"00"+e:5===e.length?"000"+e:4===e.length?"0000"+e:3===e.length?"00000"+e:2===e.length?"000000"+e:1===e.length?"0000000"+e:e}r.inherits=n,r.toArray=function(e,t){if(Array.isArray(e))return e.slice();if(!e)return[];var r=[];if("string"==typeof e)if(t){if("hex"===t)for((e=e.replace(/[^a-z0-9]+/gi,"")).length%2!=0&&(e="0"+e),n=0;n>6|192,r[i++]=63&o|128):s(e,n)?(o=65536+((1023&o)<<10)+(1023&e.charCodeAt(++n)),r[i++]=o>>18|240,r[i++]=o>>12&63|128,r[i++]=o>>6&63|128,r[i++]=63&o|128):(r[i++]=o>>12|224,r[i++]=o>>6&63|128,r[i++]=63&o|128)}else for(n=0;n>>0}return o},r.split32=function(e,t){for(var r=new Array(4*e.length),i=0,n=0;i>>24,r[n+1]=s>>>16&255,r[n+2]=s>>>8&255,r[n+3]=255&s):(r[n+3]=s>>>24,r[n+2]=s>>>16&255,r[n+1]=s>>>8&255,r[n]=255&s)}return r},r.rotr32=function(e,t){return e>>>t|e<<32-t},r.rotl32=function(e,t){return e<>>32-t},r.sum32=function(e,t){return e+t>>>0},r.sum32_3=function(e,t,r){return e+t+r>>>0},r.sum32_4=function(e,t,r,i){return e+t+r+i>>>0},r.sum32_5=function(e,t,r,i,n){return e+t+r+i+n>>>0},r.sum64=function(e,t,r,i){var n=e[t],s=i+e[t+1]>>>0,o=(s>>0,e[t+1]=s},r.sum64_hi=function(e,t,r,i){return(t+i>>>0>>0},r.sum64_lo=function(e,t,r,i){return t+i>>>0},r.sum64_4_hi=function(e,t,r,i,n,s,o,a){var c=0,u=t;return c+=(u=u+i>>>0)>>0)>>0)>>0},r.sum64_4_lo=function(e,t,r,i,n,s,o,a){return t+i+s+a>>>0},r.sum64_5_hi=function(e,t,r,i,n,s,o,a,c,u){var l=0,d=t;return l+=(d=d+i>>>0)>>0)>>0)>>0)>>0},r.sum64_5_lo=function(e,t,r,i,n,s,o,a,c,u){return t+i+s+a+u>>>0},r.rotr64_hi=function(e,t,r){return(t<<32-r|e>>>r)>>>0},r.rotr64_lo=function(e,t,r){return(e<<32-r|t>>>r)>>>0},r.shr64_hi=function(e,t,r){return e>>>r},r.shr64_lo=function(e,t,r){return(e<<32-r|t>>>r)>>>0}},{"minimalistic-assert":"1GrVu",inherits:"j5plK"}],bUDg4:[function(e,t,r){"use strict";var i=e("./utils"),n=e("minimalistic-assert");function s(){this.pending=null,this.pendingTotal=0,this.blockSize=this.constructor.blockSize,this.outSize=this.constructor.outSize,this.hmacStrength=this.constructor.hmacStrength,this.padLength=this.constructor.padLength/8,this.endian="big",this._delta8=this.blockSize/8,this._delta32=this.blockSize/32}r.BlockHash=s,s.prototype.update=function(e,t){if(e=i.toArray(e,t),this.pending?this.pending=this.pending.concat(e):this.pending=e,this.pendingTotal+=e.length,this.pending.length>=this._delta8){var r=(e=this.pending).length%this._delta8;this.pending=e.slice(e.length-r,e.length),0===this.pending.length&&(this.pending=null),e=i.join32(e,0,e.length-r,this.endian);for(var n=0;n>>24&255,i[n++]=e>>>16&255,i[n++]=e>>>8&255,i[n++]=255&e}else for(i[n++]=255&e,i[n++]=e>>>8&255,i[n++]=e>>>16&255,i[n++]=e>>>24&255,i[n++]=0,i[n++]=0,i[n++]=0,i[n++]=0,s=8;s>>3},r.g1_256=function(e){return i(e,17)^i(e,19)^e>>>10}},{"../utils":"fs59i"}],"5p3po":[function(e,t,r){"use strict";var i=e("../utils"),n=e("./256");function s(){if(!(this instanceof s))return new s;n.call(this),this.h=[3238371032,914150663,812702999,4144912697,4290775857,1750603025,1694076839,3204075428]}i.inherits(s,n),t.exports=s,s.blockSize=512,s.outSize=224,s.hmacStrength=192,s.padLength=64,s.prototype._digest=function(e){return"hex"===e?i.toHex32(this.h.slice(0,7),"big"):i.split32(this.h.slice(0,7),"big")}},{"../utils":"fs59i","./256":"kwXkv"}],kwXkv:[function(e,t,r){"use strict";var i=e("../utils"),n=e("../common"),s=e("./common"),o=e("minimalistic-assert"),a=i.sum32,c=i.sum32_4,u=i.sum32_5,l=s.ch32,d=s.maj32,f=s.s0_256,h=s.s1_256,p=s.g0_256,g=s.g1_256,y=n.BlockHash,m=[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];function b(){if(!(this instanceof b))return new b;y.call(this),this.h=[1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225],this.k=m,this.W=new Array(64)}i.inherits(b,y),t.exports=b,b.blockSize=512,b.outSize=256,b.hmacStrength=192,b.padLength=64,b.prototype._update=function(e,t){for(var r=this.W,i=0;i<16;i++)r[i]=e[t+i];for(;ithis.blockSize&&(e=(new this.Hash).update(e).digest()),n(e.length<=this.blockSize);for(var t=e.length;t0))return o.iaddn(1),this.keyFromPrivate(o)}},d.prototype._truncateToN=function(e,t){var r=8*e.byteLength()-this.n.bitLength();return r>0&&(e=e.ushrn(r)),!t&&e.cmp(this.n)>=0?e.sub(this.n):e},d.prototype.sign=function(e,t,r,s){"object"==typeof r&&(s=r,r=null),s||(s={}),t=this.keyFromPrivate(t,r),e=this._truncateToN(new i(e,16));for(var o=this.n.byteLength(),a=t.getPrivate().toArray("be",o),c=e.toArray("be",o),u=new n({hash:this.hash,entropy:a,nonce:c,pers:s.pers,persEnc:s.persEnc||"utf8"}),d=this.n.sub(new i(1)),f=0;;f++){var h=s.k?s.k(f):new i(u.generate(this.n.byteLength()));if(!((h=this._truncateToN(h,!0)).cmpn(1)<=0||h.cmp(d)>=0)){var p=this.g.mul(h);if(!p.isInfinity()){var g=p.getX(),y=g.umod(this.n);if(0!==y.cmpn(0)){var m=h.invm(this.n).mul(y.mul(t.getPrivate()).iadd(e));if(0!==(m=m.umod(this.n)).cmpn(0)){var b=(p.getY().isOdd()?1:0)|(0!==g.cmp(y)?2:0);return s.canonical&&m.cmp(this.nh)>0&&(m=this.n.sub(m),b^=1),new l({r:y,s:m,recoveryParam:b})}}}}}},d.prototype.verify=function(e,t,r,n){e=this._truncateToN(new i(e,16)),r=this.keyFromPublic(r,n);var s=(t=new l(t,"hex")).r,o=t.s;if(s.cmpn(1)<0||s.cmp(this.n)>=0)return!1;if(o.cmpn(1)<0||o.cmp(this.n)>=0)return!1;var a,c=o.invm(this.n),u=c.mul(e).umod(this.n),d=c.mul(s).umod(this.n);return this.curve._maxwellTrick?!(a=this.g.jmulAdd(u,r.getPublic(),d)).isInfinity()&&a.eqXToP(s):!(a=this.g.mulAdd(u,r.getPublic(),d)).isInfinity()&&0===a.getX().umod(this.n).cmp(s)},d.prototype.recoverPubKey=function(e,t,r,n){c((3&r)===r,"The recovery param is more than two bits"),t=new l(t,n);var s=this.n,o=new i(e),a=t.r,u=t.s,d=1&r,f=r>>1;if(a.cmp(this.curve.p.umod(this.curve.n))>=0&&f)throw new Error("Unable to find sencond key candinate");a=f?this.curve.pointFromX(a.add(this.curve.n),d):this.curve.pointFromX(a,d);var h=t.r.invm(s),p=s.sub(o).mul(h).umod(s),g=u.mul(h).umod(s);return this.g.mulAdd(p,a,g)},d.prototype.getKeyRecoveryParam=function(e,t,r,i){if(null!==(t=new l(t,i)).recoveryParam)return t.recoveryParam;for(var n=0;n<4;n++){var s;try{s=this.recoverPubKey(e,t,n)}catch(e){continue}if(s.eq(r))return n}throw new Error("Unable to find valid recovery factor")}},{"bn.js":"c8Lvi","hmac-drbg":"iPkoP","../utils":"959xT","../curves":"4unkA",brorand:"P54o1","./key":"9sGQ9","./signature":"hmVaw"}],iPkoP:[function(e,t,r){"use strict";var i=e("hash.js"),n=e("minimalistic-crypto-utils"),s=e("minimalistic-assert");function o(e){if(!(this instanceof o))return new o(e);this.hash=e.hash,this.predResist=!!e.predResist,this.outLen=this.hash.outSize,this.minEntropy=e.minEntropy||this.hash.hmacStrength,this._reseed=null,this.reseedInterval=null,this.K=null,this.V=null;var t=n.toArray(e.entropy,e.entropyEnc||"hex"),r=n.toArray(e.nonce,e.nonceEnc||"hex"),i=n.toArray(e.pers,e.persEnc||"hex");s(t.length>=this.minEntropy/8,"Not enough entropy. Minimum is: "+this.minEntropy+" bits"),this._init(t,r,i)}t.exports=o,o.prototype._init=function(e,t,r){var i=e.concat(t).concat(r);this.K=new Array(this.outLen/8),this.V=new Array(this.outLen/8);for(var n=0;n=this.minEntropy/8,"Not enough entropy. Minimum is: "+this.minEntropy+" bits"),this._update(e.concat(r||[])),this._reseed=1},o.prototype.generate=function(e,t,r,i){if(this._reseed>this.reseedInterval)throw new Error("Reseed is required");"string"!=typeof t&&(i=r,r=t,t=null),r&&(r=n.toArray(r,i||"hex"),this._update(r));for(var s=[];s.length"}},{"bn.js":"c8Lvi","../utils":"959xT"}],hmVaw:[function(e,t,r){"use strict";var i=e("bn.js"),n=e("../utils"),s=n.assert;function o(e,t){if(e instanceof o)return e;this._importDER(e,t)||(s(e.r&&e.s,"Signature without r or s"),this.r=new i(e.r,16),this.s=new i(e.s,16),void 0===e.recoveryParam?this.recoveryParam=null:this.recoveryParam=e.recoveryParam)}function a(){this.place=0}function c(e,t){var r=e[t.place++];if(!(128&r))return r;var i=15&r;if(0===i||i>4)return!1;for(var n=0,s=0,o=t.place;s>>=0;return!(n<=127)&&(t.place=o,n)}function u(e){for(var t=0,r=e.length-1;!e[t]&&!(128&e[t+1])&&t>>3);for(e.push(128|r);--r;)e.push(t>>>(r<<3)&255);e.push(t)}}t.exports=o,o.prototype._importDER=function(e,t){e=n.toArray(e,t);var r=new a;if(48!==e[r.place++])return!1;var s=c(e,r);if(!1===s)return!1;if(s+r.place!==e.length)return!1;if(2!==e[r.place++])return!1;var o=c(e,r);if(!1===o)return!1;var u=e.slice(r.place,o+r.place);if(r.place+=o,2!==e[r.place++])return!1;var l=c(e,r);if(!1===l)return!1;if(e.length!==l+r.place)return!1;var d=e.slice(r.place,l+r.place);if(0===u[0]){if(!(128&u[1]))return!1;u=u.slice(1)}if(0===d[0]){if(!(128&d[1]))return!1;d=d.slice(1)}return this.r=new i(u),this.s=new i(d),this.recoveryParam=null,!0},o.prototype.toDER=function(e){var t=this.r.toArray(),r=this.s.toArray();for(128&t[0]&&(t=[0].concat(t)),128&r[0]&&(r=[0].concat(r)),t=u(t),r=u(r);!(r[0]||128&r[1]);)r=r.slice(1);var i=[2];l(i,t.length),(i=i.concat(t)).push(2),l(i,r.length);var s=i.concat(r),o=[48];return l(o,s.length),o=o.concat(s),n.encode(o,e)}},{"bn.js":"c8Lvi","../utils":"959xT"}],j2H5w:[function(e,t,r){"use strict";var i=e("hash.js"),n=e("../curves"),s=e("../utils"),o=s.assert,a=s.parseBytes,c=e("./key"),u=e("./signature");function l(e){if(o("ed25519"===e,"only tested with ed25519 so far"),!(this instanceof l))return new l(e);e=n[e].curve,this.curve=e,this.g=e.g,this.g.precompute(e.n.bitLength()+1),this.pointClass=e.point().constructor,this.encodingLength=Math.ceil(e.n.bitLength()/8),this.hash=i.sha512}t.exports=l,l.prototype.sign=function(e,t){e=a(e);var r=this.keyFromSecret(t),i=this.hashInt(r.messagePrefix(),e),n=this.g.mul(i),s=this.encodePoint(n),o=this.hashInt(s,r.pubBytes(),e).mul(r.priv()),c=i.add(o).umod(this.curve.n);return this.makeSignature({R:n,S:c,Rencoded:s})},l.prototype.verify=function(e,t,r){e=a(e),t=this.makeSignature(t);var i=this.keyFromPublic(r),n=this.hashInt(t.Rencoded(),i.pubBytes(),e),s=this.g.mul(t.S());return t.R().add(i.pub().mul(n)).eq(s)},l.prototype.hashInt=function(){for(var e=this.hash(),t=0;t{const c=a[e];if(!c){const t=Object.keys(a).join(" / ");throw i(new Error(`unknown cipher type '${e}'. Must be ${t}`),"ERR_INVALID_CIPHER_TYPE")}if(!t)throw i(new Error("missing hash type"),"ERR_MISSING_HASH_TYPE");const u=c.keySize,l=c.ivSize,d=s("key expansion"),f=2*(l+u+20),h=await o.create(t,r);let p=await h.digest(d);const g=[];let y=0;for(;yf&&(t=f-y),g.push(e),y+=t,p=await h.digest(p)}const m=f/2,b=n(g),v=b.slice(0,m),w=b.slice(m,f),_=e=>({iv:e.slice(0,l),cipherKey:e.slice(l,l+u),macKey:e.slice(l+u)});return{k1:_(v),k2:_(w)}}},{"err-code":"chZjB","uint8arrays/concat":"4EBjG","uint8arrays/from-string":"dF7Y4","../hmac":"JUsR3"}],JUsR3:[function(e,t,r){"use strict";const i=e("../webcrypto"),n=e("./lengths"),s={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"};r.create=async function(e,t){const r=s[e],o=await i.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:r}},!1,["sign"]);return{digest:async e=>(async(e,t)=>{const r=await i.get().subtle.sign({name:"HMAC"},e,t);return new Uint8Array(r,r.byteOffset,r.byteLength)})(o,e),length:n[e]}}},{"../webcrypto":"i99ng","./lengths":"8g8ed"}],"8g8ed":[function(e,t,r){"use strict";t.exports={SHA1:20,SHA256:32,SHA512:64}},{}],ds3K5:[function(e,t,r){"use strict";const i=e("./ecdh");t.exports=async e=>i.generateEphmeralKeyPair(e)},{"./ecdh":"bSsHl"}],bSsHl:[function(e,t,r){"use strict";const i=e("err-code"),n=e("../webcrypto"),{base64urlToBuffer:s}=e("../util"),o=e("./validate-curve-type"),{toString:a}=e("uint8arrays/to-string"),{concat:c}=e("uint8arrays/concat"),{equals:u}=e("uint8arrays/equals"),l={"P-256":256,"P-384":384,"P-521":521};r.generateEphmeralKeyPair=async function(e){o(Object.keys(l),e);const t=await n.get().subtle.generateKey({name:"ECDH",namedCurve:e},!0,["deriveBits"]);return{key:f(await n.get().subtle.exportKey("jwk",t.publicKey)),genSharedKey:async(r,i)=>{let s;s=i?await n.get().subtle.importKey("jwk",p(e,i),{name:"ECDH",namedCurve:e},!1,["deriveBits"]):t.privateKey;const o=[await n.get().subtle.importKey("jwk",h(e,r),{name:"ECDH",namedCurve:e},!1,[]),s],a=await n.get().subtle.deriveBits({name:"ECDH",namedCurve:e,public:o[0]},o[1],l[e]);return new Uint8Array(a,a.byteOffset,a.byteLength)}}};const d={"P-256":32,"P-384":48,"P-521":66};function f(e){const t=d[e.crv];return c([Uint8Array.from([4]),s(e.x,t),s(e.y,t)],1+2*t)}function h(e,t){const r=d[e];if(u(!t.slice(0,1),Uint8Array.from([4])))throw i(new Error("Cannot unmarshal public key - invalid key format"),"ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:e,x:a(t.slice(1,r+1),"base64url"),y:a(t.slice(1+r),"base64url"),ext:!0}}const p=(e,t)=>({...h(e,t.public),d:a(t.private,"base64url")})},{"err-code":"chZjB","../webcrypto":"i99ng","../util":"ffmp6","./validate-curve-type":"8CFUR","uint8arrays/to-string":"hC8JB","uint8arrays/concat":"4EBjG","uint8arrays/equals":"eY3cX"}],"8CFUR":[function(e,t,r){"use strict";const i=e("err-code");t.exports=function(e,t){if(!e.includes(t)){const r=e.join(" / ");throw i(new Error(`Unknown curve: ${t}. Must be ${r}`),"ERR_INVALID_CURVE")}}},{"err-code":"chZjB"}],gx31A:[function(e,t,r){"use strict";t.exports=function(e,{className:t,symbolName:r}){const i=Symbol.for(r),n={[t]:class extends e{constructor(...e){super(...e),Object.defineProperty(this,i,{value:!0})}get[Symbol.toStringTag](){return t}}}[t];return n[`is${t}`]=e=>!(!e||!e[i]),n},t.exports.proto=function(e,{className:t,symbolName:r,withoutNew:i}){const n=Symbol.for(r),s={[t]:function(...t){if(i&&!(this instanceof s))return new s(...t);const r=e.call(this,...t)||this;return r&&!r[n]&&Object.defineProperty(r,n,{value:!0}),r}}[t];return s.prototype=Object.create(e.prototype),s.prototype.constructor=s,Object.defineProperty(s.prototype,Symbol.toStringTag,{get:()=>t}),s[`is${t}`]=e=>!(!e||!e[n]),s}},{}],c0IJt:[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-peer-id"]||(i.roots["libp2p-peer-id"]={});a.PeerIdProto=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.id=e.bytes();break;case 2:i.pubKey=e.bytes();break;case 3:i.privKey=e.bytes();break;default:e.skipType(7&s)}}if(!i.hasOwnProperty("id"))throw o.ProtocolError("missing required 'id'",{instance:i});return i},e.fromObject=function(e){if(e instanceof a.PeerIdProto)return e;var t=new a.PeerIdProto;return null!=e.id&&("string"==typeof e.id?o.base64.decode(e.id,t.id=o.newBuffer(o.base64.length(e.id)),0):e.id.length&&(t.id=e.id)),null!=e.pubKey&&("string"==typeof e.pubKey?o.base64.decode(e.pubKey,t.pubKey=o.newBuffer(o.base64.length(e.pubKey)),0):e.pubKey.length&&(t.pubKey=e.pubKey)),null!=e.privKey&&("string"==typeof e.privKey?o.base64.decode(e.privKey,t.privKey=o.newBuffer(o.base64.length(e.privKey)),0):e.privKey.length&&(t.privKey=e.privKey)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(t.bytes===String?r.id="":(r.id=[],t.bytes!==Array&&(r.id=o.newBuffer(r.id))),t.bytes===String?r.pubKey="":(r.pubKey=[],t.bytes!==Array&&(r.pubKey=o.newBuffer(r.pubKey))),t.bytes===String?r.privKey="":(r.privKey=[],t.bytes!==Array&&(r.privKey=o.newBuffer(r.privKey)))),null!=e.id&&e.hasOwnProperty("id")&&(r.id=t.bytes===String?o.base64.encode(e.id,0,e.id.length):t.bytes===Array?Array.prototype.slice.call(e.id):e.id),null!=e.pubKey&&e.hasOwnProperty("pubKey")&&(r.pubKey=t.bytes===String?o.base64.encode(e.pubKey,0,e.pubKey.length):t.bytes===Array?Array.prototype.slice.call(e.pubKey):e.pubKey),null!=e.privKey&&e.hasOwnProperty("privKey")&&(r.privKey=t.bytes===String?o.base64.encode(e.privKey,0,e.privKey.length):t.bytes===Array?Array.prototype.slice.call(e.privKey):e.privKey),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,i.util.toJSONOptions)},e}(),t.exports=a},{"protobufjs/minimal":"grAXL"}],hDUM1:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./add.js"),n=e("./add-all.js"),s=e("./ls.js"),o=e("./rm.js"),a=e("./rm-all.js");r.PinAPI=class{constructor({codecs:e,repo:t}){const r=n.createAddAll({codecs:e,repo:t});this.addAll=r,this.add=i.createAdd({addAll:r});const c=a.createRmAll({codecs:e,repo:t});this.rmAll=c,this.rm=o.createRm({rmAll:c}),this.ls=s.createLs({codecs:e,repo:t}),this.remote={add:(e,t={})=>Promise.reject(new Error("Not implemented")),ls:async function*(e,t={}){return Promise.reject(new Error("Not implemented"))},rm:(e,t={})=>Promise.reject(new Error("Not implemented")),rmAll:(e,t={})=>Promise.reject(new Error("Not implemented")),service:{add:(e,t)=>Promise.reject(new Error("Not implemented")),rm:(e,t={})=>Promise.reject(new Error("Not implemented")),ls:(e={})=>Promise.reject(new Error("Not implemented"))}}}}},{"./add.js":"lM2k0","./add-all.js":"5qgaX","./ls.js":"hVzUN","./rm.js":"khHqn","./rm-all.js":"5GWqa"}],lM2k0:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("it-last"),n=e("multiformats/cid");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=s(i);r.createAdd=function({addAll:e}){return(t,r={})=>{let i;const s=n.CID.asCID(t);return i=e(s?[{cid:s,...r}]:[{path:t.toString(),...r}],r),o.default(i)}}},{"it-last":"cSXX9","multiformats/cid":"9ooAY"}],cSXX9:[function(e,t,r){"use strict";t.exports=async e=>{let t;for await(const r of e)t=r;return t}},{}],"5qgaX":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../utils.js"),n=e("ipfs-core-utils/with-timeout-option"),s=e("ipfs-core-utils/pins/normalise-input"),o=e("ipfs-repo/pin-types");r.createAddAll=function({repo:e,codecs:t}){return n.withTimeoutOption((async function*(r,n={}){const a=async function*(){for await(const{path:n,recursive:a,metadata:c}of s.normaliseInput(r)){const{cid:r}=await i.resolvePath(e,t,n),{reason:s}=await e.pins.isPinnedWithType(r,[o.PinTypes.recursive,o.PinTypes.direct]);if("recursive"===s&&!a)throw new Error(`${r} already pinned recursively`);a?await e.pins.pinRecursively(r,{metadata:c}):await e.pins.pinDirectly(r,{metadata:c}),yield r}};if(!Boolean(n.lock))return void(yield*a());const c=await e.gcLock.readLock();try{yield*a()}finally{c()}}))}},{"../../utils.js":"cT4uN","ipfs-core-utils/with-timeout-option":"j29MK","ipfs-core-utils/pins/normalise-input":"4NDJq","ipfs-repo/pin-types":"uek22"}],"4NDJq":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("err-code"),n=e("multiformats/cid");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=s(i);function a(e){const t=e.cid||`${e.path}`;if(!t)throw o.default(new Error("Unexpected input: Please path either a CID or an IPFS path"),"ERR_UNEXPECTED_INPUT");const r={path:t,recursive:!1!==e.recursive};return null!=e.metadata&&(r.metadata=e.metadata),r}r.normaliseInput=async function*(e){if(null==e)throw o.default(new Error(`Unexpected input: ${e}`),"ERR_UNEXPECTED_INPUT");const t=n.CID.asCID(e);if(t)yield a({cid:t});else{if(!(e instanceof String||"string"==typeof e)){if(null!=e.cid||null!=e.path)return yield a(e);if(Symbol.iterator in e){const t=e[Symbol.iterator](),r=t.next();if(r.done)return t;if(n.CID.asCID(r.value)||r.value instanceof String||"string"==typeof r.value){yield a({cid:r.value});for(const e of t)yield a({cid:e});return}if(null!=r.value.cid||null!=r.value.path){yield a(r.value);for(const e of t)yield a(e);return}throw o.default(new Error("Unexpected input: "+typeof e),"ERR_UNEXPECTED_INPUT")}if(Symbol.asyncIterator in e){const t=e[Symbol.asyncIterator](),r=await t.next();if(r.done)return t;if(n.CID.asCID(r.value)||r.value instanceof String||"string"==typeof r.value){yield a({cid:r.value});for await(const e of t)yield a({cid:e});return}if(null!=r.value.cid||null!=r.value.path){yield a(r.value);for await(const e of t)yield a(e);return}throw o.default(new Error("Unexpected input: "+typeof e),"ERR_UNEXPECTED_INPUT")}throw o.default(new Error("Unexpected input: "+typeof e),"ERR_UNEXPECTED_INPUT")}yield a({path:e})}}},{"err-code":"chZjB","multiformats/cid":"9ooAY"}],uek22:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});r.PinTypes={direct:"direct",recursive:"recursive",indirect:"indirect",all:"all"}},{}],hVzUN:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/pins/normalise-input"),n=e("../../utils.js"),s=e("ipfs-core-utils/with-timeout-option"),o=e("err-code"),a=e("ipfs-repo/pin-types");function c(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var u=c(o);function l(e,t,r){const i={type:e,cid:t};return r&&(i.metadata=r),i}r.createLs=function({repo:e,codecs:t}){return s.withTimeoutOption((async function*(r={}){let s=a.PinTypes.all;if(r.type&&(s=r.type,!Object.keys(a.PinTypes).includes(s)))throw u.default(new Error("Invalid pin type"),"ERR_INVALID_PIN_TYPE");if(r.paths){let o=!1;for await(const{path:c}of i.normaliseInput(r.paths)){const{cid:r}=await n.resolvePath(e,t,c),{reason:i,pinned:d,parent:f,metadata:h}=await e.pins.isPinnedWithType(r,s);if(!d)throw u.default(new Error(`path '${c}' is not pinned`),"ERR_NOT_PINNED");switch(i){case a.PinTypes.direct:case a.PinTypes.recursive:o=!0,yield l(i,r,h);break;default:o=!0,yield l(`${a.PinTypes.indirect} through ${f}`,r,h)}}if(!o)throw new Error("No match found")}else{if(s===a.PinTypes.recursive||s===a.PinTypes.all)for await(const{cid:t,metadata:r}of e.pins.recursiveKeys())yield l(a.PinTypes.recursive,t,r);if(s===a.PinTypes.indirect||s===a.PinTypes.all)for await(const t of e.pins.indirectKeys(r))yield l(a.PinTypes.indirect,t);if(s===a.PinTypes.direct||s===a.PinTypes.all)for await(const{cid:t,metadata:r}of e.pins.directKeys())yield l(a.PinTypes.direct,t,r)}}))}},{"ipfs-core-utils/pins/normalise-input":"4NDJq","../../utils.js":"cT4uN","ipfs-core-utils/with-timeout-option":"j29MK","err-code":"chZjB","ipfs-repo/pin-types":"uek22"}],khHqn:[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("it-last"));r.createRm=function({rmAll:e}){return async function(t,r={}){const i=await n.default(e([{path:t,...r}],r));if(!i)throw new Error("CID expected");return i}}},{"it-last":"cSXX9"}],"5GWqa":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/pins/normalise-input"),n=e("../../utils.js"),s=e("ipfs-core-utils/with-timeout-option"),o=e("ipfs-repo/pin-types");r.createRmAll=function({repo:e,codecs:t}){return s.withTimeoutOption((async function*(r,s={}){const a=await e.gcLock.readLock();try{for await(const{path:s,recursive:a}of i.normaliseInput(r)){const{cid:r}=await n.resolvePath(e,t,s),{pinned:i,reason:c}=await e.pins.isPinnedWithType(r,o.PinTypes.all);if(!i)throw new Error(`${r} is not pinned`);switch(c){case o.PinTypes.recursive:if(!a)throw new Error(`${r} is pinned recursively`);await e.pins.unpin(r),yield r;break;case o.PinTypes.direct:await e.pins.unpin(r),yield r;break;default:throw new Error(`${r} is pinned indirectly under ${c}`)}}}finally{a()}}))}},{"ipfs-core-utils/pins/normalise-input":"4NDJq","../../utils.js":"cT4uN","ipfs-core-utils/with-timeout-option":"j29MK","ipfs-repo/pin-types":"uek22"}],fTgTV:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../ipns/index.js"),n=e("../ipns/routing/config.js"),s=e("../ipns/routing/offline-datastore.js"),o=e("../errors.js");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}const c=a(e("debug")).default("ipfs:components:ipns");r.IPNSAPI=class{constructor(e={pass:""}){this.options=e,this.offline=null,this.online=null}getIPNS(){const e=this.online||this.offline;if(e)return e;throw new o.NotInitializedError}get routing(){return this.getIPNS().routing}startOffline({repo:e,peerId:t,keychain:r}){if(null!=this.offline)throw new o.AlreadyInitializedError;c("initializing IPNS keyspace");const n=new s.OfflineDatastore(e),a=new i.IPNS(n,e.datastore,t,r,this.options);this.offline=a}async startOnline({libp2p:e,repo:t,peerId:r,keychain:s}){if(null!=this.online)throw new o.AlreadyInitializedError;const a=n.createRouting({libp2p:e,repo:t,peerId:r,options:this.options}),c=new i.IPNS(a,t.datastore,r,s,this.options);await c.republisher.start(),this.online=c}async stop(){const e=this.online;e&&(await e.republisher.stop(),this.online=null)}publish(e,t,r){return this.getIPNS().publish(e,t,r)}resolve(e,t){return this.getIPNS().resolve(e,t)}initializeKeyspace(e,t){return this.getIPNS().initializeKeyspace(e,t)}}},{"../ipns/index.js":"KNAGK","../ipns/routing/config.js":"bU4x4","../ipns/routing/offline-datastore.js":"a4pYc","../errors.js":"j69o8",debug:"bO5wM"}],KNAGK:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("peer-id"),n=e("err-code"),s=e("debug"),o=e("./publisher.js"),a=e("./republisher.js"),c=e("./resolver.js"),u=e("../utils/tlru.js"),l=e("uint8arrays/to-string");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var f=d(n),h=d(s);const p=Object.assign(h.default("ipfs:ipns"),{error:h.default("ipfs:ipns:error")});r.IPNS=class{constructor(e,t,r,i,n){this.publisher=new o.IpnsPublisher(e,t),this.republisher=new a.IpnsRepublisher(this.publisher,t,r,i,n),this.resolver=new c.IpnsResolver(e),this.cache=new u.TLRU(1e3),this.routing=e}async publish(e,t,r=o.IpnsPublisher.defaultRecordLifetime){try{const n=await i.createFromPrivKey(e.bytes);await this.publisher.publishWithEOL(e,t,r),p(`IPNS value ${l.toString(t,"base32")} was published correctly`);const s=n.toB58String(),o=parseFloat(r),a=o<6e4?o:6e4;return this.cache.set(s,t,a),p(`IPNS value ${l.toString(t,"base32")} was cached correctly`),{name:s,value:t}}catch(e){throw p.error(e),e}}async resolve(e,t={}){if("string"!=typeof e)throw f.default(new Error("name received is not valid"),"ERR_INVALID_NAME");if(!t.nocache&&!t.recursive){const t=e.split("/")[2],r=this.cache.get(t);if(r)return r}try{const r=await this.resolver.resolve(e,t);return p(`IPNS record from ${e} was resolved correctly`),r}catch(e){throw p.error(e),e}}async initializeKeyspace(e,t){return this.publish(e,t,o.IpnsPublisher.defaultRecordLifetime)}}},{"peer-id":"8Bdb3","err-code":"chZjB",debug:"bO5wM","./publisher.js":"5jkXx","./republisher.js":"hoedq","./resolver.js":"gifOE","../utils/tlru.js":"lQE1u","uint8arrays/to-string":"hC8JB"}],"5jkXx":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("peer-id"),n=e("interface-datastore/key"),s=e("datastore-core/errors"),o=e("err-code"),a=e("debug"),c=e("uint8arrays/to-string"),u=e("uint8arrays/equals"),l=e("ipns");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function f(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var h=d(i),p=d(o),g=d(a),y=f(l);const m=Object.assign(g.default("ipfs:ipns:publisher"),{error:g.default("ipfs:ipns:publisher:error")}),b=s.notFoundError().code,v=36e5;class w{constructor(e,t){this._routing=e,this._datastore=t}async publishWithEOL(e,t,r){if(!e||!e.bytes)throw p.default(new Error("invalid private key"),"ERR_INVALID_PRIVATE_KEY");const i=await h.default.createFromPrivKey(e.bytes),n=await this._updateOrCreateRecord(e,t,r,i);return this._putRecordToRouting(n,i)}publish(e,t){return this.publishWithEOL(e,t,v)}async _putRecordToRouting(e,t){if(!h.default.isPeerId(t)){const e="peerId received is not valid";throw m.error(e),p.default(new Error(e),"ERR_INVALID_PEER_ID")}const r=t._pubKey,i=await y.embedPublicKey(r,e),n=y.getIdKeys(t.toBytes());return await this._publishEntry(n.routingKey,i||e),await this._publishPublicKey(n.routingPubKey,r),i||e}async _publishEntry(e,t){const r=n.Key.asKey(e);if(!r){const e="datastore key does not have a valid format";throw m.error(e),p.default(new Error(e),"ERR_INVALID_DATASTORE_KEY")}let i;try{i=y.marshal(t)}catch(e){throw m.error(e),e}try{const e=await this._routing.put(r.uint8Array(),i);return m(`ipns record for ${c.toString(r.uint8Array(),"base64")} was stored in the routing`),e}catch(e){const t=`ipns record for ${c.toString(r.uint8Array(),"base64")} could not be stored in the routing`;throw m.error(t),m.error(e),p.default(new Error(t),"ERR_PUTTING_TO_ROUTING")}}async _publishPublicKey(e,t){const r=n.Key.asKey(e);if(!r){const e="datastore key does not have a valid format";throw m.error(e),p.default(new Error(e),"ERR_INVALID_DATASTORE_KEY")}if(!t||!t.bytes){const e="one or more of the provided parameters are not defined";throw m.error(e),p.default(new Error(e),"ERR_UNDEFINED_PARAMETER")}try{const e=await this._routing.put(r.uint8Array(),t.bytes);return m(`public key for ${c.toString(r.uint8Array(),"base64")} was stored in the routing`),e}catch(e){const t=`public key for ${c.toString(r.uint8Array(),"base64")} could not be stored in the routing`;throw m.error(t),m.error(e),p.default(new Error(t),"ERR_PUTTING_TO_ROUTING")}}async _getPublished(e,t={}){if(!h.default.isPeerId(e)){const e="peerId received is not valid";throw m.error(e),p.default(new Error(e),"ERR_INVALID_PEER_ID")}const r=!1!==t.checkRouting;try{const t=await this._datastore.get(y.getLocalKey(e.id));return this._unmarshalData(t)}catch(t){if(t.code!==b){const t=`unexpected error getting the ipns record ${e.id} from datastore`;throw m.error(t),p.default(new Error(t),"ERR_UNEXPECTED_DATASTORE_RESPONSE")}if(!r)throw p.default(t,"ERR_NOT_FOUND_AND_CHECK_ROUTING_NOT_ENABLED");try{const t=y.getIdKeys(e.toBytes()),r=await this._routing.get(t.routingKey.uint8Array());return this._unmarshalData(r)}catch(e){throw m.error(e),e}}}_unmarshalData(e){try{return y.unmarshal(e)}catch(e){throw p.default(e,"ERR_INVALID_RECORD_DATA")}}async _updateOrCreateRecord(e,t,r,i){if(!h.default.isPeerId(i)){const e="peerId received is not valid";throw m.error(e),p.default(new Error(e),"ERR_INVALID_PEER_ID")}const n={checkRouting:!0};let s;try{s=await this._getPublished(i,n)}catch(e){if(e.code!==b){const t=`unexpected error when determining the last published IPNS record for ${i.id} ${e.stack}`;throw m.error(t),p.default(new Error(t),"ERR_DETERMINING_PUBLISHED_RECORD")}}let o,a=0;s&&void 0!==s.sequence&&(a=u.equals(s.value,t)?BigInt(s.sequence):BigInt(s.sequence)+BigInt(1));try{o=await y.create(e,t,a,r)}catch(e){const r=`ipns record for ${t} could not be created`;throw m.error(e),p.default(new Error(r),"ERR_CREATING_IPNS_RECORD")}try{const e=y.marshal(o);return await this._datastore.put(y.getLocalKey(i.id),e),m(`ipns record for ${c.toString(t,"base32")} was stored in the datastore`),o}catch(e){const r=`ipns record for ${t} could not be stored in the datastore`;throw m.error(r),p.default(new Error(r),"ERR_STORING_IN_DATASTORE")}}}w.defaultRecordLifetime=v,r.IpnsPublisher=w},{"peer-id":"8Bdb3","interface-datastore/key":"9hGOz","datastore-core/errors":"65M4b","err-code":"chZjB",debug:"bO5wM","uint8arrays/to-string":"hC8JB","uint8arrays/equals":"eY3cX",ipns:"7rNAT"}],"65M4b":[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("err-code"));r.abortedError=function(e){return e=e||new Error("Aborted"),n.default(e,"ERR_ABORTED")},r.dbDeleteFailedError=function(e){return e=e||new Error("Delete failed"),n.default(e,"ERR_DB_DELETE_FAILED")},r.dbOpenFailedError=function(e){return e=e||new Error("Cannot open database"),n.default(e,"ERR_DB_OPEN_FAILED")},r.dbWriteFailedError=function(e){return e=e||new Error("Write failed"),n.default(e,"ERR_DB_WRITE_FAILED")},r.notFoundError=function(e){return e=e||new Error("Not Found"),n.default(e,"ERR_NOT_FOUND")}},{"err-code":"chZjB"}],"7rNAT":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("timestamp-nano"),n=e("interface-datastore/key"),s=e("libp2p-crypto"),o=e("peer-id"),a=e("multiformats/hashes/digest"),c=e("multiformats/hashes/identity"),u=e("err-code"),l=e("multiformats/bases/base32"),d=e("uint8arrays/from-string"),f=e("uint8arrays/to-string"),h=e("uint8arrays/concat"),p=e("uint8arrays/equals"),g=e("cborg"),y=e("long"),m=e("debug"),b=e("./pb/ipns.js"),v=e("./utils.js"),w=e("./errors.js");function _(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function E(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var S=_(i),T=_(s),A=_(o),k=E(a),I=_(u),R=E(g),P=_(y),O=_(m);const C=Object.assign(O.default("jsipns"),{error:O.default("jsipns:error")}),j=c.identity.code,D=d.fromString("/ipns/"),M="/ipns/",x=M.length,B=async(e,t,r,i,n,s)=>{r=BigInt(r);const o=d.fromString(n.toString()),a=await z(e,t,i,o),c=L(t,o,i,r,s),u=q(c),l={value:t,signature:a,validityType:i,validity:o,sequence:r,ttl:s,signatureV2:await e.sign(u),data:c};return C(`ipns entry for ${t} created`),l},L=(e,t,r,i,n)=>{const s={Value:e,Validity:t,ValidityType:r,Sequence:i,TTL:n};return R.encode(s)},N=async(e,t)=>{const{value:r,validityType:i,validity:n}=t;let s,o,a;t.signatureV2&&t.data?(o=t.signatureV2,s=q(t.data),U(t)):(o=t.signature,s=V(r,i,n));try{a=await e.verify(s,o)}catch(e){a=!1}if(!a)throw C.error("record signature verification failed"),I.default(new Error("record signature verification failed"),w.ERR_SIGNATURE_VERIFICATION);if(i===b.IpnsEntry.ValidityType.EOL){let e;try{e=v.parseRFC3339(f.toString(n))}catch(e){throw C.error("unrecognized validity format (not an rfc3339 format)"),I.default(new Error("unrecognized validity format (not an rfc3339 format)"),w.ERR_UNRECOGNIZED_FORMAT)}if(e.getTime(){if(!e.data)throw I.default(new Error("Record data is missing"),w.ERR_INVALID_RECORD_DATA);const t=R.decode(e.data);if(Number.isInteger(t.Sequence)&&(t.Sequence=BigInt(t.Sequence)),Number.isInteger(t.TTL)&&(t.TTL=BigInt(t.TTL)),!p.equals(t.Value,e.value))throw I.default(new Error('Field "value" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION);if(!p.equals(t.Validity,e.validity))throw I.default(new Error('Field "validity" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION);if(t.ValidityType!==e.validityType)throw I.default(new Error('Field "validityType" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION);if(t.Sequence!==e.sequence)throw I.default(new Error('Field "sequence" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION);if(t.TTL!==e.ttl)throw I.default(new Error('Field "ttl" did not match between protobuf and CBOR'),w.ERR_SIGNATURE_VERIFICATION)},F=async(e,t)=>{if(!t||!e){const e=new Error("one or more of the provided parameters are not defined");throw C.error(e),I.default(e,w.ERR_UNDEFINED_PARAMETER)}let r;if(t.pubKey){try{r=T.default.keys.unmarshalPublicKey(t.pubKey)}catch(e){throw C.error(e),e}if(!(await A.default.createFromPubKey(t.pubKey)).equals(e))throw I.default(new Error("Embedded public key did not match PeerID"),w.ERR_INVALID_EMBEDDED_KEY)}else e.pubKey&&(r=e.pubKey);if(r)return r;throw I.default(new Error("no public key is available"),w.ERR_UNDEFINED_PARAMETER)},K=e=>l.base32upper.encode(e).slice(1),z=(e,t,r,i)=>{try{const n=V(t,r,i);return e.sign(n)}catch(e){throw C.error("record signature creation failed"),I.default(new Error("record signature creation failed: "+e.message),w.ERR_SIGNATURE_CREATION)}},V=(e,t,r)=>{const i=d.fromString((e=>{if("0"===e.toString())return"EOL";const t=new Error(`unrecognized validity type ${e.toString()}`);throw C.error(t),I.default(t,w.ERR_UNRECOGNIZED_VALIDITY)})(t));return h.concat([e,r,i])},q=e=>{const t=d.fromString("ipns-signature:");return h.concat([t,e])},G=e=>{const t=k.decode(e.id);return t.code!==j?null:T.default.keys.unmarshalPublicKey(t.digest)},H=e=>{const t=b.IpnsEntry.decode(e),r=b.IpnsEntry.toObject(t,{defaults:!1,arrays:!0,objects:!1});return{value:r.value,signature:r.signature,validityType:r.validityType,validity:r.validity,sequence:Object.hasOwnProperty.call(r,"sequence")?BigInt(`${r.sequence}`):0,pubKey:r.pubKey,ttl:Object.hasOwnProperty.call(r,"ttl")?BigInt(`${r.ttl}`):void 0,signatureV2:r.signatureV2,data:r.data}},$={validate:async(e,t)=>{const r=H(e),i=t.slice(D.length),n=A.default.createFromBytes(i),s=await F(n,r);await N(s,r)},select:(e,t)=>{const r=H(e),i=H(t);if(r.signatureV2&&!i.signatureV2)return 0;if(i.signatureV2&&!r.signatureV2)return 1;if(r.sequence>i.sequence)return 0;if(r.sequencen.getTime()?1:0}};r.create=(e,t,r,i)=>{const n=new S.default(Date.now()+Number(i)),s=b.IpnsEntry.ValidityType.EOL,[o,a]=i.toString().split("."),c=BigInt(o)*BigInt(1e5)+BigInt(a||0);return B(e,t,r,s,n,c)},r.createWithExpiration=(e,t,r,i)=>{const n=S.default.fromString(i),s=b.IpnsEntry.ValidityType.EOL,o=n.toDate().getTime()-Date.now(),a=BigInt(o)*BigInt(1e5)+BigInt(n.getNano());return B(e,t,r,s,n,a)},r.embedPublicKey=async(e,t)=>{if(!e||!e.bytes||!t){const e=new Error("one or more of the provided parameters are not defined");throw C.error(e),I.default(e,w.ERR_UNDEFINED_PARAMETER)}let r,i;try{r=await A.default.createFromPubKey(e.bytes)}catch(e){throw I.default(e,w.ERR_PEER_ID_FROM_PUBLIC_KEY)}try{i=G(r)}catch(e){throw C.error(e),I.default(e,w.ERR_PUBLIC_KEY_FROM_ID)}if(i)return null;try{t.pubKey=T.default.keys.marshalPublicKey(e)}catch(e){throw C.error(e),e}return t},r.extractPublicKey=F,r.getIdKeys=e=>{const t=d.fromString("/pk/"),r=d.fromString("/ipns/");return{routingPubKey:new n.Key(h.concat([t,e]),!1),pkKey:new n.Key(K(h.concat([t,e]))),routingKey:new n.Key(h.concat([r,e]),!1),ipnsKey:new n.Key(K(h.concat([r,e])))}},r.getLocalKey=e=>new n.Key(`/ipns/${K(e)}`),r.marshal=e=>b.IpnsEntry.encode({...e,sequence:P.default.fromString(e.sequence.toString()),ttl:null==e.ttl?void 0:P.default.fromString(e.ttl.toString())}).finish(),r.namespace=M,r.namespaceLength=x,r.unmarshal=H,r.validate=N,r.validator=$},{"timestamp-nano":"7gA2O","interface-datastore/key":"9hGOz","libp2p-crypto":"bb1cb","peer-id":"8Bdb3","multiformats/hashes/digest":"kpRBg","multiformats/hashes/identity":"eYCZn","err-code":"chZjB","multiformats/bases/base32":"5k9Tu","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB","uint8arrays/concat":"4EBjG","uint8arrays/equals":"eY3cX",cborg:"iZrkE",long:"lyrB6",debug:"bO5wM","./pb/ipns.js":"ayx1q","./utils.js":"kYcWW","./errors.js":"jtlhd"}],"7gA2O":[function(e,t,r){ /** * Timestamp for 64-bit time_t, nanosecond precision and strftime * @@ -28,8 +28,8 @@ * @license MIT */ t.exports=function(e){return null!=e&&null!=e.constructor&&"function"==typeof e.constructor.isBuffer&&e.constructor.isBuffer(e)}},{}],"3yKZX":[function(e,t,r){"use strict";var i=e("queue-tick");r.fromCallback=function(e,t){if(void 0===e){var r=new Promise((function(t,r){e=function(e,i){e?r(e):t(i)}}));e[void 0!==t?t:"promise"]=r}else if("function"!=typeof e)throw new TypeError("Callback must be a function");return e},r.fromPromise=function(e,t){if(void 0===t)return e;e.then((function(e){i((()=>t(null,e)))})).catch((function(e){i((()=>t(e)))}))}},{"queue-tick":"gJSe0"}],gJSe0:[function(e,t,r){t.exports="function"==typeof queueMicrotask?queueMicrotask:e=>Promise.resolve().then(e)},{}],lYFsd:[function(e,t,r){"use strict";function i(e){if("object"!=typeof e||null===e)throw new TypeError("First argument must be an abstract-leveldown compliant store");this.db=e,this._ended=!1,this._nexting=!1}i.prototype.next=function(e){let t=this;if(void 0===e)t=new Promise((function(t,r){e=function(e,i,n){e?r(e):void 0===i&&void 0===n?t():t([i,n])}}));else if("function"!=typeof e)throw new Error("next() requires a callback argument");return this._ended?(this._nextTick(e,new Error("cannot call next() after end()")),t):this._nexting?(this._nextTick(e,new Error("cannot call next() before previous next() has completed")),t):(this._nexting=!0,this._next(((t,...r)=>{this._nexting=!1,e(t,...r)})),t)},i.prototype._next=function(e){this._nextTick(e)},i.prototype.seek=function(e){if(this._ended)throw new Error("cannot call seek() after end()");if(this._nexting)throw new Error("cannot call seek() before next() has completed");e=this.db._serializeKey(e),this._seek(e)},i.prototype._seek=function(e){},i.prototype.end=function(e){let t;if(void 0===e)t=new Promise((function(t,r){e=function(e){e?r(e):t()}}));else if("function"!=typeof e)throw new Error("end() requires a callback argument");return this._ended?(this._nextTick(e,new Error("end() already called on iterator")),t):(this._ended=!0,this._end(e),t)},i.prototype._end=function(e){this._nextTick(e)},i.prototype[Symbol.asyncIterator]=async function*(){try{let e;for(;void 0!==(e=await this.next());)yield e}finally{this._ended||await this.end()}},i.prototype._nextTick=e("./next-tick"),t.exports=i},{"./next-tick":"clHeC"}],clHeC:[function(e,t,r){"use strict";const i=e("queue-microtask");t.exports=function(e,...t){0===t.length?i(e):i((()=>e(...t)))}},{"queue-microtask":"3aIgO"}],"3aIgO":[function(e,t,r){var i=arguments[3]; -/*! queue-microtask. MIT License. Feross Aboukhadijeh */let n;t.exports="function"==typeof queueMicrotask?queueMicrotask.bind("undefined"!=typeof window?window:i):e=>(n||(n=Promise.resolve())).then(e).catch((e=>setTimeout((()=>{throw e}),0)))},{}],hpfv2:[function(e,t,r){"use strict";const i=Object.freeze({});function n(e){if("object"!=typeof e||null===e)throw new TypeError("First argument must be an abstract-leveldown compliant store");this.db=e,this._operations=[],this._written=!1}n.prototype._checkWritten=function(){if(this._written)throw new Error("write() already called on this batch")},n.prototype.put=function(e,t,r){this._checkWritten();const n=this.db._checkKey(e)||this.db._checkValue(t);if(n)throw n;return e=this.db._serializeKey(e),t=this.db._serializeValue(t),this._put(e,t,null!=r?r:i),this},n.prototype._put=function(e,t,r){this._operations.push({...r,type:"put",key:e,value:t})},n.prototype.del=function(e,t){this._checkWritten();const r=this.db._checkKey(e);if(r)throw r;return e=this.db._serializeKey(e),this._del(e,null!=t?t:i),this},n.prototype._del=function(e,t){this._operations.push({...t,type:"del",key:e})},n.prototype.clear=function(){return this._checkWritten(),this._clear(),this},n.prototype._clear=function(){this._operations=[]},n.prototype.write=function(e,t){if(this._checkWritten(),"function"==typeof e&&(t=e),"function"!=typeof t)throw new Error("write() requires a callback argument");"object"==typeof e&&null!==e||(e={}),this._written=!0,this._write(e,t)},n.prototype._write=function(e,t){this.db._batch(this._operations,e,t)},n.prototype._nextTick=e("./next-tick"),t.exports=n},{"./next-tick":"clHeC"}],aaqLC:[function(e,t,r){"use strict";r.getCallback=function(e,t){return"function"==typeof e?e:t},r.getOptions=function(e){return"object"==typeof e&&null!==e?e:{}}},{}],"35pXB":[function(e,t,r){"use strict";const{AbstractIterator:i}=e("abstract-leveldown"),n=e("inherits"),s=e("./util").getCallback,o=Symbol("options"),a=Symbol("iterator"),c=Symbol("operations"),u=Symbol("promise");function l(e,t){i.call(this,e),this[o]=t,this[a]=null,this[c]=[]}n(l,i),l.prototype.setDb=function(e){this[a]=e.iterator(this[o]);for(const e of this[c].splice(0,this[c].length))this[a][e.method](...e.args)},l.prototype.next=function(...e){if("open"===this.db.status)return this[a].next(...e);const t=s(e,u,(function(e,t){return void 0===e&&void 0===t?void 0:[e,t]}));return"opening"===this.db.status?this[c].push({method:"next",args:e}):this._nextTick(t,new Error("Database is not open")),t[u]||this},l.prototype.seek=function(...e){if("open"===this.db.status)this[a].seek(...e);else{if("opening"!==this.db.status)throw new Error("Database is not open");this[c].push({method:"seek",args:e})}},l.prototype.end=function(...e){if("open"===this.db.status)return this[a].end(...e);const t=s(e,u);return"opening"===this.db.status?this[c].push({method:"end",args:e}):this._nextTick(t,new Error("Database is not open")),t[u]||this};for(const e of["next","seek","end"])l.prototype["_"+e]=function(){throw new Error("Did not expect private method to be called: "+e)};t.exports=l},{"abstract-leveldown":"f3ZXE",inherits:"j5plK","./util":"hJkDA"}],hJkDA:[function(e,t,r){"use strict";r.getCallback=function(e,t,r){let i=e[e.length-1];if("function"!=typeof i){const n=new Promise(((t,n)=>{e.push(i=function(e,...i){e?n(e):t(r?r(...i):i[0])})}));i[t]=n}return i}},{}],fHwIS:[function(e,t,r){"use strict";const{AbstractChainedBatch:i}=e("abstract-leveldown"),n=Symbol("operations");t.exports=class extends i{constructor(e){super(e),this[n]=[]}_put(e,t,r){this[n].push({...r,type:"put",key:e,value:t})}_del(e,t){this[n].push({...t,type:"del",key:e})}_clear(){this[n]=[]}_write(e,t){this.db.batch(this[n],e,t)}}},{"abstract-leveldown":"f3ZXE"}],"284tK":[function(e,t,r){"use strict";const i=e("inherits"),{Readable:n}=e("readable-stream");function s(e,t){if(!(this instanceof s))return new s(e,t);t=t||{},n.call(this,Object.assign({},t,{objectMode:!0})),this._iterator=e,this._options=t,this.on("end",this.destroy.bind(this,null,null))}t.exports=s,i(s,n),s.prototype._read=function(){this.destroyed||this._iterator.next(((e,t,r)=>{if(!this.destroyed)return e?this.destroy(e):void(void 0===t&&void 0===r?this.push(null):!1!==this._options.keys&&!1===this._options.values?this.push(t):!1===this._options.keys&&!1!==this._options.values?this.push(r):this.push({key:t,value:r}))}))},s.prototype._destroy=function(e,t){this._iterator.end((function(r){t(e||r)}))}},{inherits:"j5plK","readable-stream":"w0M38"}],w0M38:[function(e,t,r){(r=t.exports=e("./lib/_stream_readable.js")).Stream=r,r.Readable=r,r.Writable=e("./lib/_stream_writable.js"),r.Duplex=e("./lib/_stream_duplex.js"),r.Transform=e("./lib/_stream_transform.js"),r.PassThrough=e("./lib/_stream_passthrough.js"),r.finished=e("./lib/internal/streams/end-of-stream.js"),r.pipeline=e("./lib/internal/streams/pipeline.js")},{"./lib/_stream_readable.js":"hUJUV","./lib/_stream_writable.js":"5EyvX","./lib/_stream_duplex.js":"bbfLz","./lib/_stream_transform.js":"9ioV2","./lib/_stream_passthrough.js":"8DY2M","./lib/internal/streams/end-of-stream.js":"6WyPU","./lib/internal/streams/pipeline.js":"7zSdy"}],hUJUV:[function(e,t,r){var i,n=e("process"),s=arguments[3];t.exports=O,O.ReadableState=P;e("events").EventEmitter;var o=function(e,t){return e.listeners(t).length},a=e("./internal/streams/stream"),c=e("buffer").Buffer,u=s.Uint8Array||function(){};function l(e){return c.from(e)}function d(e){return c.isBuffer(e)||e instanceof u}var f,h=e("util");f=h&&h.debuglog?h.debuglog("stream"):function(){};var p,g,y,m=e("./internal/streams/buffer_list"),b=e("./internal/streams/destroy"),v=e("./internal/streams/state"),w=v.getHighWaterMark,_=e("../errors").codes,E=_.ERR_INVALID_ARG_TYPE,S=_.ERR_STREAM_PUSH_AFTER_EOF,T=_.ERR_METHOD_NOT_IMPLEMENTED,A=_.ERR_STREAM_UNSHIFT_AFTER_END_EVENT;e("inherits")(O,a);var k=b.errorOrDestroy,I=["error","close","destroy","pause","resume"];function R(e,t,r){if("function"==typeof e.prependListener)return e.prependListener(t,r);e._events&&e._events[t]?Array.isArray(e._events[t])?e._events[t].unshift(r):e._events[t]=[r,e._events[t]]:e.on(t,r)}function P(t,r,n){i=i||e("./_stream_duplex"),t=t||{},"boolean"!=typeof n&&(n=r instanceof i),this.objectMode=!!t.objectMode,n&&(this.objectMode=this.objectMode||!!t.readableObjectMode),this.highWaterMark=w(this,t,"readableHighWaterMark",n),this.buffer=new m,this.length=0,this.pipes=null,this.pipesCount=0,this.flowing=null,this.ended=!1,this.endEmitted=!1,this.reading=!1,this.sync=!0,this.needReadable=!1,this.emittedReadable=!1,this.readableListening=!1,this.resumeScheduled=!1,this.paused=!0,this.emitClose=!1!==t.emitClose,this.autoDestroy=!!t.autoDestroy,this.destroyed=!1,this.defaultEncoding=t.defaultEncoding||"utf8",this.awaitDrain=0,this.readingMore=!1,this.decoder=null,this.encoding=null,t.encoding&&(p||(p=e("string_decoder/").StringDecoder),this.decoder=new p(t.encoding),this.encoding=t.encoding)}function O(t){if(i=i||e("./_stream_duplex"),!(this instanceof O))return new O(t);var r=this instanceof i;this._readableState=new P(t,this,r),this.readable=!0,t&&("function"==typeof t.read&&(this._read=t.read),"function"==typeof t.destroy&&(this._destroy=t.destroy)),a.call(this)}function C(e,t,r,i,n){f("readableAddChunk",t);var s,o=e._readableState;if(null===t)o.reading=!1,L(e,o);else if(n||(s=D(o,t)),s)k(e,s);else if(o.objectMode||t&&t.length>0)if("string"==typeof t||o.objectMode||Object.getPrototypeOf(t)===c.prototype||(t=l(t)),i)o.endEmitted?k(e,new A):j(e,o,t,!0);else if(o.ended)k(e,new S);else{if(o.destroyed)return!1;o.reading=!1,o.decoder&&!r?(t=o.decoder.write(t),o.objectMode||0!==t.length?j(e,o,t,!1):F(e,o)):j(e,o,t,!1)}else i||(o.reading=!1,F(e,o));return!o.ended&&(o.length=M?e=M:(e--,e|=e>>>1,e|=e>>>2,e|=e>>>4,e|=e>>>8,e|=e>>>16,e++),e}function B(e,t){return e<=0||0===t.length&&t.ended?0:t.objectMode?1:e!=e?t.flowing&&t.length?t.buffer.head.data.length:t.length:(e>t.highWaterMark&&(t.highWaterMark=x(e)),e<=t.length?e:t.ended?t.length:(t.needReadable=!0,0))}function L(e,t){if(f("onEofChunk"),!t.ended){if(t.decoder){var r=t.decoder.end();r&&r.length&&(t.buffer.push(r),t.length+=t.objectMode?1:r.length)}t.ended=!0,t.sync?N(e):(t.needReadable=!1,t.emittedReadable||(t.emittedReadable=!0,U(e)))}}function N(e){var t=e._readableState;f("emitReadable",t.needReadable,t.emittedReadable),t.needReadable=!1,t.emittedReadable||(f("emitReadable",t.flowing),t.emittedReadable=!0,n.nextTick(U,e))}function U(e){var t=e._readableState;f("emitReadable_",t.destroyed,t.length,t.ended),t.destroyed||!t.length&&!t.ended||(e.emit("readable"),t.emittedReadable=!1),t.needReadable=!t.flowing&&!t.ended&&t.length<=t.highWaterMark,$(e)}function F(e,t){t.readingMore||(t.readingMore=!0,n.nextTick(K,e,t))}function K(e,t){for(;!t.reading&&!t.ended&&(t.length0,t.resumeScheduled&&!t.paused?t.flowing=!0:e.listenerCount("data")>0&&e.resume()}function q(e){f("readable nexttick read 0"),e.read(0)}function G(e,t){t.resumeScheduled||(t.resumeScheduled=!0,n.nextTick(H,e,t))}function H(e,t){f("resume",t.reading),t.reading||e.read(0),t.resumeScheduled=!1,e.emit("resume"),$(e),t.flowing&&!t.reading&&e.read(0)}function $(e){var t=e._readableState;for(f("flow",t.flowing);t.flowing&&null!==e.read(););}function W(e,t){return 0===t.length?null:(t.objectMode?r=t.buffer.shift():!e||e>=t.length?(r=t.decoder?t.buffer.join(""):1===t.buffer.length?t.buffer.first():t.buffer.concat(t.length),t.buffer.clear()):r=t.buffer.consume(e,t.decoder),r);var r}function Y(e){var t=e._readableState;f("endReadable",t.endEmitted),t.endEmitted||(t.ended=!0,n.nextTick(X,t,e))}function X(e,t){if(f("endReadableNT",e.endEmitted,e.length),!e.endEmitted&&0===e.length&&(e.endEmitted=!0,t.readable=!1,t.emit("end"),e.autoDestroy)){var r=t._writableState;(!r||r.autoDestroy&&r.finished)&&t.destroy()}}function Z(e,t){for(var r=0,i=e.length;r=t.highWaterMark:t.length>0)||t.ended))return f("read: emitReadable",t.length,t.ended),0===t.length&&t.ended?Y(this):N(this),null;if(0===(e=B(e,t))&&t.ended)return 0===t.length&&Y(this),null;var i,n=t.needReadable;return f("need readable",n),(0===t.length||t.length-e0?W(e,t):null)?(t.needReadable=t.length<=t.highWaterMark,e=0):(t.length-=e,t.awaitDrain=0),0===t.length&&(t.ended||(t.needReadable=!0),r!==e&&t.ended&&Y(this)),null!==i&&this.emit("data",i),i},O.prototype._read=function(e){k(this,new T("_read()"))},O.prototype.pipe=function(e,t){var r=this,i=this._readableState;switch(i.pipesCount){case 0:i.pipes=e;break;case 1:i.pipes=[i.pipes,e];break;default:i.pipes.push(e)}i.pipesCount+=1,f("pipe count=%d opts=%j",i.pipesCount,t);var s=(!t||!1!==t.end)&&e!==n.stdout&&e!==n.stderr?c:y;function a(t,n){f("onunpipe"),t===r&&n&&!1===n.hasUnpiped&&(n.hasUnpiped=!0,f("cleanup"),e.removeListener("close",p),e.removeListener("finish",g),e.removeListener("drain",u),e.removeListener("error",h),e.removeListener("unpipe",a),r.removeListener("end",c),r.removeListener("end",y),r.removeListener("data",d),l=!0,!i.awaitDrain||e._writableState&&!e._writableState.needDrain||u())}function c(){f("onend"),e.end()}i.endEmitted?n.nextTick(s):r.once("end",s),e.on("unpipe",a);var u=z(r);e.on("drain",u);var l=!1;function d(t){f("ondata");var n=e.write(t);f("dest.write",n),!1===n&&((1===i.pipesCount&&i.pipes===e||i.pipesCount>1&&-1!==Z(i.pipes,e))&&!l&&(f("false write response, pause",i.awaitDrain),i.awaitDrain++),r.pause())}function h(t){f("onerror",t),y(),e.removeListener("error",h),0===o(e,"error")&&k(e,t)}function p(){e.removeListener("finish",g),y()}function g(){f("onfinish"),e.removeListener("close",p),y()}function y(){f("unpipe"),r.unpipe(e)}return r.on("data",d),R(e,"error",h),e.once("close",p),e.once("finish",g),e.emit("pipe",r),i.flowing||(f("pipe resume"),r.resume()),e},O.prototype.unpipe=function(e){var t=this._readableState,r={hasUnpiped:!1};if(0===t.pipesCount)return this;if(1===t.pipesCount)return e&&e!==t.pipes||(e||(e=t.pipes),t.pipes=null,t.pipesCount=0,t.flowing=!1,e&&e.emit("unpipe",this,r)),this;if(!e){var i=t.pipes,n=t.pipesCount;t.pipes=null,t.pipesCount=0,t.flowing=!1;for(var s=0;s0,!1!==i.flowing&&this.resume()):"readable"===e&&(i.endEmitted||i.readableListening||(i.readableListening=i.needReadable=!0,i.flowing=!1,i.emittedReadable=!1,f("on readable",i.length,i.reading),i.length?N(this):i.reading||n.nextTick(q,this))),r},O.prototype.addListener=O.prototype.on,O.prototype.removeListener=function(e,t){var r=a.prototype.removeListener.call(this,e,t);return"readable"===e&&n.nextTick(V,this),r},O.prototype.removeAllListeners=function(e){var t=a.prototype.removeAllListeners.apply(this,arguments);return"readable"!==e&&void 0!==e||n.nextTick(V,this),t},O.prototype.resume=function(){var e=this._readableState;return e.flowing||(f("resume"),e.flowing=!e.readableListening,G(this,e)),e.paused=!1,this},O.prototype.pause=function(){return f("call pause flowing=%j",this._readableState.flowing),!1!==this._readableState.flowing&&(f("pause"),this._readableState.flowing=!1,this.emit("pause")),this._readableState.paused=!0,this},O.prototype.wrap=function(e){var t=this,r=this._readableState,i=!1;for(var n in e.on("end",(function(){if(f("wrapped end"),r.decoder&&!r.ended){var e=r.decoder.end();e&&e.length&&t.push(e)}t.push(null)})),e.on("data",(function(n){(f("wrapped data"),r.decoder&&(n=r.decoder.write(n)),r.objectMode&&null==n)||(r.objectMode||n&&n.length)&&(t.push(n)||(i=!0,e.pause()))})),e)void 0===this[n]&&"function"==typeof e[n]&&(this[n]=function(t){return function(){return e[t].apply(e,arguments)}}(n));for(var s=0;s0?this.tail.next=t:this.head=t,this.tail=t,++this.length}},{key:"unshift",value:function(e){var t={data:e,next:this.head};0===this.length&&(this.tail=t),this.head=t,++this.length}},{key:"shift",value:function(){if(0!==this.length){var e=this.head.data;return 1===this.length?this.head=this.tail=null:this.head=this.head.next,--this.length,e}}},{key:"clear",value:function(){this.head=this.tail=null,this.length=0}},{key:"join",value:function(e){if(0===this.length)return"";for(var t=this.head,r=""+t.data;t=t.next;)r+=e+t.data;return r}},{key:"concat",value:function(e){if(0===this.length)return o.alloc(0);for(var t,r,i,n=o.allocUnsafe(e>>>0),s=this.head,a=0;s;)t=s.data,r=n,i=a,o.prototype.copy.call(t,r,i),a+=s.data.length,s=s.next;return n}},{key:"consume",value:function(e,t){var r;return en.length?n.length:e;if(s===n.length?i+=n:i+=n.slice(0,e),0==(e-=s)){s===n.length?(++r,t.next?this.head=t.next:this.head=this.tail=null):(this.head=t,t.data=n.slice(s));break}++r}return this.length-=r,i}},{key:"_getBuffer",value:function(e){var t=o.allocUnsafe(e),r=this.head,i=1;for(r.data.copy(t),e-=r.data.length;r=r.next;){var n=r.data,s=e>n.length?n.length:e;if(n.copy(t,t.length-e,0,s),0==(e-=s)){s===n.length?(++i,r.next?this.head=r.next:this.head=this.tail=null):(this.head=r,r.data=n.slice(s));break}++i}return this.length-=i,t}},{key:c,value:function(e,t){return a(this,function(e){for(var t=1;t2?"one of ".concat(t," ").concat(e.slice(0,r-1).join(", "),", or ")+e[r-1]:2===r?"one of ".concat(t," ").concat(e[0]," or ").concat(e[1]):"of ".concat(t," ").concat(e[0])}return"of ".concat(t," ").concat(String(e))}n("ERR_INVALID_OPT_VALUE",(function(e,t){return'The value "'+t+'" is invalid for option "'+e+'"'}),TypeError),n("ERR_INVALID_ARG_TYPE",(function(e,t,r){var i,n,o,a;if("string"==typeof t&&(n="not ",t.substr(!o||o<0?0:+o,n.length)===n)?(i="must not be",t=t.replace(/^not /,"")):i="must be",function(e,t,r){return(void 0===r||r>e.length)&&(r=e.length),e.substring(r-t.length,r)===t}(e," argument"))a="The ".concat(e," ").concat(i," ").concat(s(t,"type"));else{var c=function(e,t,r){return"number"!=typeof r&&(r=0),!(r+t.length>e.length)&&-1!==e.indexOf(t,r)}(e,".")?"property":"argument";a='The "'.concat(e,'" ').concat(c," ").concat(i," ").concat(s(t,"type"))}return a+=". Received type ".concat(typeof r)}),TypeError),n("ERR_STREAM_PUSH_AFTER_EOF","stream.push() after EOF"),n("ERR_METHOD_NOT_IMPLEMENTED",(function(e){return"The "+e+" method is not implemented"})),n("ERR_STREAM_PREMATURE_CLOSE","Premature close"),n("ERR_STREAM_DESTROYED",(function(e){return"Cannot call "+e+" after a stream was destroyed"})),n("ERR_MULTIPLE_CALLBACK","Callback called multiple times"),n("ERR_STREAM_CANNOT_PIPE","Cannot pipe, not readable"),n("ERR_STREAM_WRITE_AFTER_END","write after end"),n("ERR_STREAM_NULL_VALUES","May not write null values to stream",TypeError),n("ERR_UNKNOWN_ENCODING",(function(e){return"Unknown encoding: "+e}),TypeError),n("ERR_STREAM_UNSHIFT_AFTER_END_EVENT","stream.unshift() after end event"),t.exports.codes=i},{}],bbfLz:[function(e,t,r){var i=e("process"),n=Object.keys||function(e){var t=[];for(var r in e)t.push(r);return t};t.exports=l;var s=e("./_stream_readable"),o=e("./_stream_writable");e("inherits")(l,s);for(var a=n(o.prototype),c=0;c-1))throw new A(e);return this._writableState.defaultEncoding=e,this},Object.defineProperty(P.prototype,"writableBuffer",{enumerable:!1,get:function(){return this._writableState&&this._writableState.getBuffer()}}),Object.defineProperty(P.prototype,"writableHighWaterMark",{enumerable:!1,get:function(){return this._writableState.highWaterMark}}),P.prototype._write=function(e,t,r){r(new v("_write()"))},P.prototype._writev=null,P.prototype.end=function(e,t,r){var i=this._writableState;return"function"==typeof e?(r=e,e=null,t=null):"function"==typeof t&&(r=t,t=null),null!=e&&this.write(e,t),i.corked&&(i.corked=1,this.uncork()),i.ending||G(this,i,r),this},Object.defineProperty(P.prototype,"writableLength",{enumerable:!1,get:function(){return this._writableState.length}}),Object.defineProperty(P.prototype,"destroyed",{enumerable:!1,get:function(){return void 0!==this._writableState&&this._writableState.destroyed},set:function(e){this._writableState&&(this._writableState.destroyed=e)}}),P.prototype.destroy=p.destroy,P.prototype._undestroy=p.undestroy,P.prototype._destroy=function(e,t){t(e)}},{process:"bjUAi","util-deprecate":"3zH8r","./internal/streams/stream":"WXKP8",buffer:"etowf","./internal/streams/destroy":"hWarO","./internal/streams/state":"kof1d","../errors":"7Ny4a",inherits:"j5plK","./_stream_duplex":"bbfLz"}],"3zH8r":[function(e,t,r){var i=arguments[3];function n(e,t){if(s("noDeprecation"))return e;var r=!1;return function(){if(!r){if(s("throwDeprecation"))throw new Error(t);s("traceDeprecation")?console.trace(t):console.warn(t),r=!0}return e.apply(this,arguments)}}function s(e){try{if(!i.localStorage)return!1}catch(e){return!1}var t=i.localStorage[e];return null!=t&&"true"===String(t).toLowerCase()}t.exports=n},{}],cHJFU:[function(e,t,r){"use strict";var i=e("safe-buffer").Buffer,n=i.isEncoding||function(e){switch((e=""+e)&&e.toLowerCase()){case"hex":case"utf8":case"utf-8":case"ascii":case"binary":case"base64":case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":case"raw":return!0;default:return!1}};function s(e){var t;switch(this.encoding=function(e){var t=function(e){if(!e)return"utf8";for(var t;;)switch(e){case"utf8":case"utf-8":return"utf8";case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return"utf16le";case"latin1":case"binary":return"latin1";case"base64":case"ascii":case"hex":return e;default:if(t)return;e=(""+e).toLowerCase(),t=!0}}(e);if("string"!=typeof t&&(i.isEncoding===n||!n(e)))throw new Error("Unknown encoding: "+e);return t||e}(e),this.encoding){case"utf16le":this.text=c,this.end=u,t=4;break;case"utf8":this.fillLast=a,t=4;break;case"base64":this.text=l,this.end=d,t=3;break;default:return this.write=f,void(this.end=h)}this.lastNeed=0,this.lastTotal=0,this.lastChar=i.allocUnsafe(t)}function o(e){return e<=127?0:e>>5==6?2:e>>4==14?3:e>>3==30?4:e>>6==2?-1:-2}function a(e){var t=this.lastTotal-this.lastNeed,r=function(e,t,r){if(128!=(192&t[0]))return e.lastNeed=0,"�";if(e.lastNeed>1&&t.length>1){if(128!=(192&t[1]))return e.lastNeed=1,"�";if(e.lastNeed>2&&t.length>2&&128!=(192&t[2]))return e.lastNeed=2,"�"}}(this,e);return void 0!==r?r:this.lastNeed<=e.length?(e.copy(this.lastChar,t,0,this.lastNeed),this.lastChar.toString(this.encoding,0,this.lastTotal)):(e.copy(this.lastChar,t,0,e.length),void(this.lastNeed-=e.length))}function c(e,t){if((e.length-t)%2==0){var r=e.toString("utf16le",t);if(r){var i=r.charCodeAt(r.length-1);if(i>=55296&&i<=56319)return this.lastNeed=2,this.lastTotal=4,this.lastChar[0]=e[e.length-2],this.lastChar[1]=e[e.length-1],r.slice(0,-1)}return r}return this.lastNeed=1,this.lastTotal=2,this.lastChar[0]=e[e.length-1],e.toString("utf16le",t,e.length-1)}function u(e){var t=e&&e.length?this.write(e):"";if(this.lastNeed){var r=this.lastTotal-this.lastNeed;return t+this.lastChar.toString("utf16le",0,r)}return t}function l(e,t){var r=(e.length-t)%3;return 0===r?e.toString("base64",t):(this.lastNeed=3-r,this.lastTotal=3,1===r?this.lastChar[0]=e[e.length-1]:(this.lastChar[0]=e[e.length-2],this.lastChar[1]=e[e.length-1]),e.toString("base64",t,e.length-r))}function d(e){var t=e&&e.length?this.write(e):"";return this.lastNeed?t+this.lastChar.toString("base64",0,3-this.lastNeed):t}function f(e){return e.toString(this.encoding)}function h(e){return e&&e.length?this.write(e):""}r.StringDecoder=s,s.prototype.write=function(e){if(0===e.length)return"";var t,r;if(this.lastNeed){if(void 0===(t=this.fillLast(e)))return"";r=this.lastNeed,this.lastNeed=0}else r=0;return r=0)return n>0&&(e.lastNeed=n-1),n;if(--i=0)return n>0&&(e.lastNeed=n-2),n;if(--i=0)return n>0&&(2===n?n=0:e.lastNeed=n-3),n;return 0}(this,e,t);if(!this.lastNeed)return e.toString("utf8",t);this.lastTotal=r;var i=e.length-(r-this.lastNeed);return e.copy(this.lastChar,0,i),e.toString("utf8",t,i)},s.prototype.fillLast=function(e){if(this.lastNeed<=e.length)return e.copy(this.lastChar,this.lastTotal-this.lastNeed,0,this.lastNeed),this.lastChar.toString(this.encoding,0,this.lastTotal);e.copy(this.lastChar,this.lastTotal-this.lastNeed,0,e.length),this.lastNeed-=e.length}},{"safe-buffer":"2ZY92"}],"2ZY92":[function(e,t,r){ +/*! queue-microtask. MIT License. Feross Aboukhadijeh */let n;t.exports="function"==typeof queueMicrotask?queueMicrotask.bind("undefined"!=typeof window?window:i):e=>(n||(n=Promise.resolve())).then(e).catch((e=>setTimeout((()=>{throw e}),0)))},{}],hpfv2:[function(e,t,r){"use strict";const i=Object.freeze({});function n(e){if("object"!=typeof e||null===e)throw new TypeError("First argument must be an abstract-leveldown compliant store");this.db=e,this._operations=[],this._written=!1}n.prototype._checkWritten=function(){if(this._written)throw new Error("write() already called on this batch")},n.prototype.put=function(e,t,r){this._checkWritten();const n=this.db._checkKey(e)||this.db._checkValue(t);if(n)throw n;return e=this.db._serializeKey(e),t=this.db._serializeValue(t),this._put(e,t,null!=r?r:i),this},n.prototype._put=function(e,t,r){this._operations.push({...r,type:"put",key:e,value:t})},n.prototype.del=function(e,t){this._checkWritten();const r=this.db._checkKey(e);if(r)throw r;return e=this.db._serializeKey(e),this._del(e,null!=t?t:i),this},n.prototype._del=function(e,t){this._operations.push({...t,type:"del",key:e})},n.prototype.clear=function(){return this._checkWritten(),this._clear(),this},n.prototype._clear=function(){this._operations=[]},n.prototype.write=function(e,t){if(this._checkWritten(),"function"==typeof e&&(t=e),"function"!=typeof t)throw new Error("write() requires a callback argument");"object"==typeof e&&null!==e||(e={}),this._written=!0,this._write(e,t)},n.prototype._write=function(e,t){this.db._batch(this._operations,e,t)},n.prototype._nextTick=e("./next-tick"),t.exports=n},{"./next-tick":"clHeC"}],aaqLC:[function(e,t,r){"use strict";r.getCallback=function(e,t){return"function"==typeof e?e:t},r.getOptions=function(e){return"object"==typeof e&&null!==e?e:{}}},{}],"35pXB":[function(e,t,r){"use strict";const{AbstractIterator:i}=e("abstract-leveldown"),n=e("inherits"),s=e("./util").getCallback,o=Symbol("options"),a=Symbol("iterator"),c=Symbol("operations"),u=Symbol("promise");function l(e,t){i.call(this,e),this[o]=t,this[a]=null,this[c]=[]}n(l,i),l.prototype.setDb=function(e){this[a]=e.iterator(this[o]);for(const e of this[c].splice(0,this[c].length))this[a][e.method](...e.args)},l.prototype.next=function(...e){if("open"===this.db.status)return this[a].next(...e);const t=s(e,u,(function(e,t){return void 0===e&&void 0===t?void 0:[e,t]}));return"opening"===this.db.status?this[c].push({method:"next",args:e}):this._nextTick(t,new Error("Database is not open")),t[u]||this},l.prototype.seek=function(...e){if("open"===this.db.status)this[a].seek(...e);else{if("opening"!==this.db.status)throw new Error("Database is not open");this[c].push({method:"seek",args:e})}},l.prototype.end=function(...e){if("open"===this.db.status)return this[a].end(...e);const t=s(e,u);return"opening"===this.db.status?this[c].push({method:"end",args:e}):this._nextTick(t,new Error("Database is not open")),t[u]||this};for(const e of["next","seek","end"])l.prototype["_"+e]=function(){throw new Error("Did not expect private method to be called: "+e)};t.exports=l},{"abstract-leveldown":"f3ZXE",inherits:"j5plK","./util":"hJkDA"}],hJkDA:[function(e,t,r){"use strict";r.getCallback=function(e,t,r){let i=e[e.length-1];if("function"!=typeof i){const n=new Promise(((t,n)=>{e.push(i=function(e,...i){e?n(e):t(r?r(...i):i[0])})}));i[t]=n}return i}},{}],fHwIS:[function(e,t,r){"use strict";const{AbstractChainedBatch:i}=e("abstract-leveldown"),n=Symbol("operations");t.exports=class extends i{constructor(e){super(e),this[n]=[]}_put(e,t,r){this[n].push({...r,type:"put",key:e,value:t})}_del(e,t){this[n].push({...t,type:"del",key:e})}_clear(){this[n]=[]}_write(e,t){this.db.batch(this[n],e,t)}}},{"abstract-leveldown":"f3ZXE"}],"284tK":[function(e,t,r){"use strict";const i=e("inherits"),{Readable:n}=e("readable-stream");function s(e,t){if(!(this instanceof s))return new s(e,t);t=t||{},n.call(this,Object.assign({},t,{objectMode:!0})),this._iterator=e,this._options=t,this.on("end",this.destroy.bind(this,null,null))}t.exports=s,i(s,n),s.prototype._read=function(){this.destroyed||this._iterator.next(((e,t,r)=>{if(!this.destroyed)return e?this.destroy(e):void(void 0===t&&void 0===r?this.push(null):!1!==this._options.keys&&!1===this._options.values?this.push(t):!1===this._options.keys&&!1!==this._options.values?this.push(r):this.push({key:t,value:r}))}))},s.prototype._destroy=function(e,t){this._iterator.end((function(r){t(e||r)}))}},{inherits:"j5plK","readable-stream":"w0M38"}],w0M38:[function(e,t,r){(r=t.exports=e("./lib/_stream_readable.js")).Stream=r,r.Readable=r,r.Writable=e("./lib/_stream_writable.js"),r.Duplex=e("./lib/_stream_duplex.js"),r.Transform=e("./lib/_stream_transform.js"),r.PassThrough=e("./lib/_stream_passthrough.js"),r.finished=e("./lib/internal/streams/end-of-stream.js"),r.pipeline=e("./lib/internal/streams/pipeline.js")},{"./lib/_stream_readable.js":"hUJUV","./lib/_stream_writable.js":"5EyvX","./lib/_stream_duplex.js":"bbfLz","./lib/_stream_transform.js":"9ioV2","./lib/_stream_passthrough.js":"8DY2M","./lib/internal/streams/end-of-stream.js":"6WyPU","./lib/internal/streams/pipeline.js":"7zSdy"}],hUJUV:[function(e,t,r){var i,n=e("process"),s=arguments[3];t.exports=O,O.ReadableState=P;e("events").EventEmitter;var o=function(e,t){return e.listeners(t).length},a=e("./internal/streams/stream"),c=e("buffer").Buffer,u=s.Uint8Array||function(){};function l(e){return c.from(e)}function d(e){return c.isBuffer(e)||e instanceof u}var f,h=e("util");f=h&&h.debuglog?h.debuglog("stream"):function(){};var p,g,y,m=e("./internal/streams/buffer_list"),b=e("./internal/streams/destroy"),v=e("./internal/streams/state"),w=v.getHighWaterMark,_=e("../errors").codes,E=_.ERR_INVALID_ARG_TYPE,S=_.ERR_STREAM_PUSH_AFTER_EOF,T=_.ERR_METHOD_NOT_IMPLEMENTED,A=_.ERR_STREAM_UNSHIFT_AFTER_END_EVENT;e("inherits")(O,a);var k=b.errorOrDestroy,I=["error","close","destroy","pause","resume"];function R(e,t,r){if("function"==typeof e.prependListener)return e.prependListener(t,r);e._events&&e._events[t]?Array.isArray(e._events[t])?e._events[t].unshift(r):e._events[t]=[r,e._events[t]]:e.on(t,r)}function P(t,r,n){i=i||e("./_stream_duplex"),t=t||{},"boolean"!=typeof n&&(n=r instanceof i),this.objectMode=!!t.objectMode,n&&(this.objectMode=this.objectMode||!!t.readableObjectMode),this.highWaterMark=w(this,t,"readableHighWaterMark",n),this.buffer=new m,this.length=0,this.pipes=null,this.pipesCount=0,this.flowing=null,this.ended=!1,this.endEmitted=!1,this.reading=!1,this.sync=!0,this.needReadable=!1,this.emittedReadable=!1,this.readableListening=!1,this.resumeScheduled=!1,this.paused=!0,this.emitClose=!1!==t.emitClose,this.autoDestroy=!!t.autoDestroy,this.destroyed=!1,this.defaultEncoding=t.defaultEncoding||"utf8",this.awaitDrain=0,this.readingMore=!1,this.decoder=null,this.encoding=null,t.encoding&&(p||(p=e("string_decoder/").StringDecoder),this.decoder=new p(t.encoding),this.encoding=t.encoding)}function O(t){if(i=i||e("./_stream_duplex"),!(this instanceof O))return new O(t);var r=this instanceof i;this._readableState=new P(t,this,r),this.readable=!0,t&&("function"==typeof t.read&&(this._read=t.read),"function"==typeof t.destroy&&(this._destroy=t.destroy)),a.call(this)}function C(e,t,r,i,n){f("readableAddChunk",t);var s,o=e._readableState;if(null===t)o.reading=!1,L(e,o);else if(n||(s=D(o,t)),s)k(e,s);else if(o.objectMode||t&&t.length>0)if("string"==typeof t||o.objectMode||Object.getPrototypeOf(t)===c.prototype||(t=l(t)),i)o.endEmitted?k(e,new A):j(e,o,t,!0);else if(o.ended)k(e,new S);else{if(o.destroyed)return!1;o.reading=!1,o.decoder&&!r?(t=o.decoder.write(t),o.objectMode||0!==t.length?j(e,o,t,!1):F(e,o)):j(e,o,t,!1)}else i||(o.reading=!1,F(e,o));return!o.ended&&(o.length=M?e=M:(e--,e|=e>>>1,e|=e>>>2,e|=e>>>4,e|=e>>>8,e|=e>>>16,e++),e}function B(e,t){return e<=0||0===t.length&&t.ended?0:t.objectMode?1:e!=e?t.flowing&&t.length?t.buffer.head.data.length:t.length:(e>t.highWaterMark&&(t.highWaterMark=x(e)),e<=t.length?e:t.ended?t.length:(t.needReadable=!0,0))}function L(e,t){if(f("onEofChunk"),!t.ended){if(t.decoder){var r=t.decoder.end();r&&r.length&&(t.buffer.push(r),t.length+=t.objectMode?1:r.length)}t.ended=!0,t.sync?N(e):(t.needReadable=!1,t.emittedReadable||(t.emittedReadable=!0,U(e)))}}function N(e){var t=e._readableState;f("emitReadable",t.needReadable,t.emittedReadable),t.needReadable=!1,t.emittedReadable||(f("emitReadable",t.flowing),t.emittedReadable=!0,n.nextTick(U,e))}function U(e){var t=e._readableState;f("emitReadable_",t.destroyed,t.length,t.ended),t.destroyed||!t.length&&!t.ended||(e.emit("readable"),t.emittedReadable=!1),t.needReadable=!t.flowing&&!t.ended&&t.length<=t.highWaterMark,$(e)}function F(e,t){t.readingMore||(t.readingMore=!0,n.nextTick(K,e,t))}function K(e,t){for(;!t.reading&&!t.ended&&(t.length0,t.resumeScheduled&&!t.paused?t.flowing=!0:e.listenerCount("data")>0&&e.resume()}function q(e){f("readable nexttick read 0"),e.read(0)}function G(e,t){t.resumeScheduled||(t.resumeScheduled=!0,n.nextTick(H,e,t))}function H(e,t){f("resume",t.reading),t.reading||e.read(0),t.resumeScheduled=!1,e.emit("resume"),$(e),t.flowing&&!t.reading&&e.read(0)}function $(e){var t=e._readableState;for(f("flow",t.flowing);t.flowing&&null!==e.read(););}function W(e,t){return 0===t.length?null:(t.objectMode?r=t.buffer.shift():!e||e>=t.length?(r=t.decoder?t.buffer.join(""):1===t.buffer.length?t.buffer.first():t.buffer.concat(t.length),t.buffer.clear()):r=t.buffer.consume(e,t.decoder),r);var r}function Y(e){var t=e._readableState;f("endReadable",t.endEmitted),t.endEmitted||(t.ended=!0,n.nextTick(X,t,e))}function X(e,t){if(f("endReadableNT",e.endEmitted,e.length),!e.endEmitted&&0===e.length&&(e.endEmitted=!0,t.readable=!1,t.emit("end"),e.autoDestroy)){var r=t._writableState;(!r||r.autoDestroy&&r.finished)&&t.destroy()}}function Z(e,t){for(var r=0,i=e.length;r=t.highWaterMark:t.length>0)||t.ended))return f("read: emitReadable",t.length,t.ended),0===t.length&&t.ended?Y(this):N(this),null;if(0===(e=B(e,t))&&t.ended)return 0===t.length&&Y(this),null;var i,n=t.needReadable;return f("need readable",n),(0===t.length||t.length-e0?W(e,t):null)?(t.needReadable=t.length<=t.highWaterMark,e=0):(t.length-=e,t.awaitDrain=0),0===t.length&&(t.ended||(t.needReadable=!0),r!==e&&t.ended&&Y(this)),null!==i&&this.emit("data",i),i},O.prototype._read=function(e){k(this,new T("_read()"))},O.prototype.pipe=function(e,t){var r=this,i=this._readableState;switch(i.pipesCount){case 0:i.pipes=e;break;case 1:i.pipes=[i.pipes,e];break;default:i.pipes.push(e)}i.pipesCount+=1,f("pipe count=%d opts=%j",i.pipesCount,t);var s=(!t||!1!==t.end)&&e!==n.stdout&&e!==n.stderr?c:y;function a(t,n){f("onunpipe"),t===r&&n&&!1===n.hasUnpiped&&(n.hasUnpiped=!0,f("cleanup"),e.removeListener("close",p),e.removeListener("finish",g),e.removeListener("drain",u),e.removeListener("error",h),e.removeListener("unpipe",a),r.removeListener("end",c),r.removeListener("end",y),r.removeListener("data",d),l=!0,!i.awaitDrain||e._writableState&&!e._writableState.needDrain||u())}function c(){f("onend"),e.end()}i.endEmitted?n.nextTick(s):r.once("end",s),e.on("unpipe",a);var u=z(r);e.on("drain",u);var l=!1;function d(t){f("ondata");var n=e.write(t);f("dest.write",n),!1===n&&((1===i.pipesCount&&i.pipes===e||i.pipesCount>1&&-1!==Z(i.pipes,e))&&!l&&(f("false write response, pause",i.awaitDrain),i.awaitDrain++),r.pause())}function h(t){f("onerror",t),y(),e.removeListener("error",h),0===o(e,"error")&&k(e,t)}function p(){e.removeListener("finish",g),y()}function g(){f("onfinish"),e.removeListener("close",p),y()}function y(){f("unpipe"),r.unpipe(e)}return r.on("data",d),R(e,"error",h),e.once("close",p),e.once("finish",g),e.emit("pipe",r),i.flowing||(f("pipe resume"),r.resume()),e},O.prototype.unpipe=function(e){var t=this._readableState,r={hasUnpiped:!1};if(0===t.pipesCount)return this;if(1===t.pipesCount)return e&&e!==t.pipes||(e||(e=t.pipes),t.pipes=null,t.pipesCount=0,t.flowing=!1,e&&e.emit("unpipe",this,r)),this;if(!e){var i=t.pipes,n=t.pipesCount;t.pipes=null,t.pipesCount=0,t.flowing=!1;for(var s=0;s0,!1!==i.flowing&&this.resume()):"readable"===e&&(i.endEmitted||i.readableListening||(i.readableListening=i.needReadable=!0,i.flowing=!1,i.emittedReadable=!1,f("on readable",i.length,i.reading),i.length?N(this):i.reading||n.nextTick(q,this))),r},O.prototype.addListener=O.prototype.on,O.prototype.removeListener=function(e,t){var r=a.prototype.removeListener.call(this,e,t);return"readable"===e&&n.nextTick(V,this),r},O.prototype.removeAllListeners=function(e){var t=a.prototype.removeAllListeners.apply(this,arguments);return"readable"!==e&&void 0!==e||n.nextTick(V,this),t},O.prototype.resume=function(){var e=this._readableState;return e.flowing||(f("resume"),e.flowing=!e.readableListening,G(this,e)),e.paused=!1,this},O.prototype.pause=function(){return f("call pause flowing=%j",this._readableState.flowing),!1!==this._readableState.flowing&&(f("pause"),this._readableState.flowing=!1,this.emit("pause")),this._readableState.paused=!0,this},O.prototype.wrap=function(e){var t=this,r=this._readableState,i=!1;for(var n in e.on("end",(function(){if(f("wrapped end"),r.decoder&&!r.ended){var e=r.decoder.end();e&&e.length&&t.push(e)}t.push(null)})),e.on("data",(function(n){(f("wrapped data"),r.decoder&&(n=r.decoder.write(n)),r.objectMode&&null==n)||(r.objectMode||n&&n.length)&&(t.push(n)||(i=!0,e.pause()))})),e)void 0===this[n]&&"function"==typeof e[n]&&(this[n]=function(t){return function(){return e[t].apply(e,arguments)}}(n));for(var s=0;s0?this.tail.next=t:this.head=t,this.tail=t,++this.length}},{key:"unshift",value:function(e){var t={data:e,next:this.head};0===this.length&&(this.tail=t),this.head=t,++this.length}},{key:"shift",value:function(){if(0!==this.length){var e=this.head.data;return 1===this.length?this.head=this.tail=null:this.head=this.head.next,--this.length,e}}},{key:"clear",value:function(){this.head=this.tail=null,this.length=0}},{key:"join",value:function(e){if(0===this.length)return"";for(var t=this.head,r=""+t.data;t=t.next;)r+=e+t.data;return r}},{key:"concat",value:function(e){if(0===this.length)return o.alloc(0);for(var t,r,i,n=o.allocUnsafe(e>>>0),s=this.head,a=0;s;)t=s.data,r=n,i=a,o.prototype.copy.call(t,r,i),a+=s.data.length,s=s.next;return n}},{key:"consume",value:function(e,t){var r;return en.length?n.length:e;if(s===n.length?i+=n:i+=n.slice(0,e),0==(e-=s)){s===n.length?(++r,t.next?this.head=t.next:this.head=this.tail=null):(this.head=t,t.data=n.slice(s));break}++r}return this.length-=r,i}},{key:"_getBuffer",value:function(e){var t=o.allocUnsafe(e),r=this.head,i=1;for(r.data.copy(t),e-=r.data.length;r=r.next;){var n=r.data,s=e>n.length?n.length:e;if(n.copy(t,t.length-e,0,s),0==(e-=s)){s===n.length?(++i,r.next?this.head=r.next:this.head=this.tail=null):(this.head=r,r.data=n.slice(s));break}++i}return this.length-=i,t}},{key:c,value:function(e,t){return a(this,function(e){for(var t=1;t2?"one of ".concat(t," ").concat(e.slice(0,r-1).join(", "),", or ")+e[r-1]:2===r?"one of ".concat(t," ").concat(e[0]," or ").concat(e[1]):"of ".concat(t," ").concat(e[0])}return"of ".concat(t," ").concat(String(e))}n("ERR_INVALID_OPT_VALUE",(function(e,t){return'The value "'+t+'" is invalid for option "'+e+'"'}),TypeError),n("ERR_INVALID_ARG_TYPE",(function(e,t,r){var i,n,o,a;if("string"==typeof t&&(n="not ",t.substr(!o||o<0?0:+o,n.length)===n)?(i="must not be",t=t.replace(/^not /,"")):i="must be",function(e,t,r){return(void 0===r||r>e.length)&&(r=e.length),e.substring(r-t.length,r)===t}(e," argument"))a="The ".concat(e," ").concat(i," ").concat(s(t,"type"));else{var c=function(e,t,r){return"number"!=typeof r&&(r=0),!(r+t.length>e.length)&&-1!==e.indexOf(t,r)}(e,".")?"property":"argument";a='The "'.concat(e,'" ').concat(c," ").concat(i," ").concat(s(t,"type"))}return a+=". Received type ".concat(typeof r)}),TypeError),n("ERR_STREAM_PUSH_AFTER_EOF","stream.push() after EOF"),n("ERR_METHOD_NOT_IMPLEMENTED",(function(e){return"The "+e+" method is not implemented"})),n("ERR_STREAM_PREMATURE_CLOSE","Premature close"),n("ERR_STREAM_DESTROYED",(function(e){return"Cannot call "+e+" after a stream was destroyed"})),n("ERR_MULTIPLE_CALLBACK","Callback called multiple times"),n("ERR_STREAM_CANNOT_PIPE","Cannot pipe, not readable"),n("ERR_STREAM_WRITE_AFTER_END","write after end"),n("ERR_STREAM_NULL_VALUES","May not write null values to stream",TypeError),n("ERR_UNKNOWN_ENCODING",(function(e){return"Unknown encoding: "+e}),TypeError),n("ERR_STREAM_UNSHIFT_AFTER_END_EVENT","stream.unshift() after end event"),t.exports.codes=i},{}],bbfLz:[function(e,t,r){var i=e("process"),n=Object.keys||function(e){var t=[];for(var r in e)t.push(r);return t};t.exports=l;var s=e("./_stream_readable"),o=e("./_stream_writable");e("inherits")(l,s);for(var a=n(o.prototype),c=0;c-1))throw new A(e);return this._writableState.defaultEncoding=e,this},Object.defineProperty(P.prototype,"writableBuffer",{enumerable:!1,get:function(){return this._writableState&&this._writableState.getBuffer()}}),Object.defineProperty(P.prototype,"writableHighWaterMark",{enumerable:!1,get:function(){return this._writableState.highWaterMark}}),P.prototype._write=function(e,t,r){r(new v("_write()"))},P.prototype._writev=null,P.prototype.end=function(e,t,r){var i=this._writableState;return"function"==typeof e?(r=e,e=null,t=null):"function"==typeof t&&(r=t,t=null),null!=e&&this.write(e,t),i.corked&&(i.corked=1,this.uncork()),i.ending||G(this,i,r),this},Object.defineProperty(P.prototype,"writableLength",{enumerable:!1,get:function(){return this._writableState.length}}),Object.defineProperty(P.prototype,"destroyed",{enumerable:!1,get:function(){return void 0!==this._writableState&&this._writableState.destroyed},set:function(e){this._writableState&&(this._writableState.destroyed=e)}}),P.prototype.destroy=p.destroy,P.prototype._undestroy=p.undestroy,P.prototype._destroy=function(e,t){t(e)}},{process:"bjUAi","util-deprecate":"3zH8r","./internal/streams/stream":"WXKP8",buffer:"etowf","./internal/streams/destroy":"hWarO","./internal/streams/state":"kof1d","../errors":"7Ny4a",inherits:"j5plK","./_stream_duplex":"bbfLz"}],"3zH8r":[function(e,t,r){var i=arguments[3];function n(e,t){if(s("noDeprecation"))return e;var r=!1;return function(){if(!r){if(s("throwDeprecation"))throw new Error(t);s("traceDeprecation")?console.trace(t):console.warn(t),r=!0}return e.apply(this,arguments)}}function s(e){try{if(!i.localStorage)return!1}catch(e){return!1}var t=i.localStorage[e];return null!=t&&"true"===String(t).toLowerCase()}t.exports=n},{}],cHJFU:[function(e,t,r){"use strict";var i=e("safe-buffer").Buffer,n=i.isEncoding||function(e){switch((e=""+e)&&e.toLowerCase()){case"hex":case"utf8":case"utf-8":case"ascii":case"binary":case"base64":case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":case"raw":return!0;default:return!1}};function s(e){var t;switch(this.encoding=function(e){var t=function(e){if(!e)return"utf8";for(var t;;)switch(e){case"utf8":case"utf-8":return"utf8";case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return"utf16le";case"latin1":case"binary":return"latin1";case"base64":case"ascii":case"hex":return e;default:if(t)return;e=(""+e).toLowerCase(),t=!0}}(e);if("string"!=typeof t&&(i.isEncoding===n||!n(e)))throw new Error("Unknown encoding: "+e);return t||e}(e),this.encoding){case"utf16le":this.text=c,this.end=u,t=4;break;case"utf8":this.fillLast=a,t=4;break;case"base64":this.text=l,this.end=d,t=3;break;default:return this.write=f,void(this.end=h)}this.lastNeed=0,this.lastTotal=0,this.lastChar=i.allocUnsafe(t)}function o(e){return e<=127?0:e>>5==6?2:e>>4==14?3:e>>3==30?4:e>>6==2?-1:-2}function a(e){var t=this.lastTotal-this.lastNeed,r=function(e,t,r){if(128!=(192&t[0]))return e.lastNeed=0,"�";if(e.lastNeed>1&&t.length>1){if(128!=(192&t[1]))return e.lastNeed=1,"�";if(e.lastNeed>2&&t.length>2&&128!=(192&t[2]))return e.lastNeed=2,"�"}}(this,e);return void 0!==r?r:this.lastNeed<=e.length?(e.copy(this.lastChar,t,0,this.lastNeed),this.lastChar.toString(this.encoding,0,this.lastTotal)):(e.copy(this.lastChar,t,0,e.length),void(this.lastNeed-=e.length))}function c(e,t){if((e.length-t)%2==0){var r=e.toString("utf16le",t);if(r){var i=r.charCodeAt(r.length-1);if(i>=55296&&i<=56319)return this.lastNeed=2,this.lastTotal=4,this.lastChar[0]=e[e.length-2],this.lastChar[1]=e[e.length-1],r.slice(0,-1)}return r}return this.lastNeed=1,this.lastTotal=2,this.lastChar[0]=e[e.length-1],e.toString("utf16le",t,e.length-1)}function u(e){var t=e&&e.length?this.write(e):"";if(this.lastNeed){var r=this.lastTotal-this.lastNeed;return t+this.lastChar.toString("utf16le",0,r)}return t}function l(e,t){var r=(e.length-t)%3;return 0===r?e.toString("base64",t):(this.lastNeed=3-r,this.lastTotal=3,1===r?this.lastChar[0]=e[e.length-1]:(this.lastChar[0]=e[e.length-2],this.lastChar[1]=e[e.length-1]),e.toString("base64",t,e.length-r))}function d(e){var t=e&&e.length?this.write(e):"";return this.lastNeed?t+this.lastChar.toString("base64",0,3-this.lastNeed):t}function f(e){return e.toString(this.encoding)}function h(e){return e&&e.length?this.write(e):""}r.StringDecoder=s,s.prototype.write=function(e){if(0===e.length)return"";var t,r;if(this.lastNeed){if(void 0===(t=this.fillLast(e)))return"";r=this.lastNeed,this.lastNeed=0}else r=0;return r=0)return n>0&&(e.lastNeed=n-1),n;if(--i=0)return n>0&&(e.lastNeed=n-2),n;if(--i=0)return n>0&&(2===n?n=0:e.lastNeed=n-3),n;return 0}(this,e,t);if(!this.lastNeed)return e.toString("utf8",t);this.lastTotal=r;var i=e.length-(r-this.lastNeed);return e.copy(this.lastChar,0,i),e.toString("utf8",t,i)},s.prototype.fillLast=function(e){if(this.lastNeed<=e.length)return e.copy(this.lastChar,this.lastTotal-this.lastNeed,0,this.lastNeed),this.lastChar.toString(this.encoding,0,this.lastTotal);e.copy(this.lastChar,this.lastTotal-this.lastNeed,0,e.length),this.lastNeed-=e.length}},{"safe-buffer":"2ZY92"}],"2ZY92":[function(e,t,r){ /*! safe-buffer. MIT License. Feross Aboukhadijeh */var i=e("buffer"),n=i.Buffer;function s(e,t){for(var r in e)t[r]=e[r]}function o(e,t,r){return n(e,t,r)}n.from&&n.alloc&&n.allocUnsafe&&n.allocUnsafeSlow?t.exports=i:(s(i,r),r.Buffer=o),o.prototype=Object.create(n.prototype),s(n,o),o.from=function(e,t,r){if("number"==typeof e)throw new TypeError("Argument must not be a number");return n(e,t,r)},o.alloc=function(e,t,r){if("number"!=typeof e)throw new TypeError("Argument must be a number");var i=n(e);return void 0!==t?"string"==typeof r?i.fill(t,r):i.fill(t):i.fill(0),i},o.allocUnsafe=function(e){if("number"!=typeof e)throw new TypeError("Argument must be a number");return n(e)},o.allocUnsafeSlow=function(e){if("number"!=typeof e)throw new TypeError("Argument must be a number");return i.SlowBuffer(e)}},{buffer:"etowf"}],deb8T:[function(e,t,r){var i,n=e("process");function s(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}var o=e("./end-of-stream"),a=Symbol("lastResolve"),c=Symbol("lastReject"),u=Symbol("error"),l=Symbol("ended"),d=Symbol("lastPromise"),f=Symbol("handlePromise"),h=Symbol("stream");function p(e,t){return{value:e,done:t}}function g(e){var t=e[a];if(null!==t){var r=e[h].read();null!==r&&(e[d]=null,e[a]=null,e[c]=null,t(p(r,!1)))}}function y(e){n.nextTick(g,e)}var m=Object.getPrototypeOf((function(){})),b=Object.setPrototypeOf((s(i={get stream(){return this[h]},next:function(){var e=this,t=this[u];if(null!==t)return Promise.reject(t);if(this[l])return Promise.resolve(p(void 0,!0));if(this[h].destroyed)return new Promise((function(t,r){n.nextTick((function(){e[u]?r(e[u]):t(p(void 0,!0))}))}));var r,i=this[d];if(i)r=new Promise(function(e,t){return function(r,i){e.then((function(){t[l]?r(p(void 0,!0)):t[f](r,i)}),i)}}(i,this));else{var s=this[h].read();if(null!==s)return Promise.resolve(p(s,!1));r=new Promise(this[f])}return this[d]=r,r}},Symbol.asyncIterator,(function(){return this})),s(i,"return",(function(){var e=this;return new Promise((function(t,r){e[h].destroy(null,(function(e){e?r(e):t(p(void 0,!0))}))}))})),i),m);t.exports=function(e){var t,r=Object.create(b,(s(t={},h,{value:e,writable:!0}),s(t,a,{value:null,writable:!0}),s(t,c,{value:null,writable:!0}),s(t,u,{value:null,writable:!0}),s(t,l,{value:e._readableState.endEmitted,writable:!0}),s(t,f,{value:function(e,t){var i=r[h].read();i?(r[d]=null,r[a]=null,r[c]=null,e(p(i,!1))):(r[a]=e,r[c]=t)},writable:!0}),t));return r[d]=null,o(e,(function(e){if(e&&"ERR_STREAM_PREMATURE_CLOSE"!==e.code){var t=r[c];return null!==t&&(r[d]=null,r[a]=null,r[c]=null,t(e)),void(r[u]=e)}var i=r[a];null!==i&&(r[d]=null,r[a]=null,r[c]=null,i(p(void 0,!0))),r[l]=!0})),e.on("readable",y.bind(null,r)),r}},{process:"bjUAi","./end-of-stream":"6WyPU"}],"6WyPU":[function(e,t,r){"use strict";var i=e("../../../errors").codes.ERR_STREAM_PREMATURE_CLOSE;function n(){}t.exports=function e(t,r,s){if("function"==typeof r)return e(t,null,r);r||(r={}),s=function(e){var t=!1;return function(){if(!t){t=!0;for(var r=arguments.length,i=new Array(r),n=0;n0,(function(e){i||(i=e),e&&o.forEach(u),s||(o.forEach(u),n(i))}))}));return t.reduce(l)}},{"../../../errors":"7Ny4a","./end-of-stream":"6WyPU"}],"8aV2Q":[function(e,t,r){"use strict";const i=e("level-errors").WriteError,n=e("catering"),s=e("./common").getCallback,o=e("./common").getOptions;function a(e){this.db=e,this.batch=e.db.batch(),this.ops=[],this.length=0}a.prototype.put=function(e,t,r){try{this.batch.put(e,t,r)}catch(e){throw new i(e)}return this.ops.push({...r,type:"put",key:e,value:t}),this.length++,this},a.prototype.del=function(e,t){try{this.batch.del(e,t)}catch(e){throw new i(e)}return this.ops.push({...t,type:"del",key:e}),this.length++,this},a.prototype.clear=function(){try{this.batch.clear()}catch(e){throw new i(e)}return this.ops=[],this.length=0,this},a.prototype.write=function(e,t){const r=this.db,a=this.ops;t=s(e,t),t=n.fromCallback(t),e=o(e);try{this.batch.write(e,(function(e){if(e)return t(new i(e));r.emit("batch",a),t()}))}catch(e){throw new i(e)}return t.promise},t.exports=a},{"level-errors":"iLFVA",catering:"3yKZX","./common":"4WQgu"}],iLFVA:[function(e,t,r){"use strict";function i(e,t){const r=function(t,i){if("object"==typeof t&&null!==t&&(i=i||t,t=t.message||t.name),t=t||"","object"==typeof(i=i||void 0)&&i.type===e&&i.message===t)return i;Object.defineProperty(this,"type",{value:e,enumerable:!1,writable:!0,configurable:!0}),Object.defineProperty(this,"name",{value:e,enumerable:!1,writable:!0,configurable:!0}),Object.defineProperty(this,"cause",{value:i,enumerable:!1,writable:!0,configurable:!0}),Object.defineProperty(this,"message",{value:t,enumerable:!1,writable:!0,configurable:!0}),Error.call(this),"function"==typeof Error.captureStackTrace&&Error.captureStackTrace(this,r)};return r.prototype=new t,r}const n=i("LevelUPError",Error);t.exports={LevelUPError:n,InitializationError:i("InitializationError",n),OpenError:i("OpenError",n),ReadError:i("ReadError",n),WriteError:i("WriteError",n),NotFoundError:i("NotFoundError",n),EncodingError:i("EncodingError",n)},t.exports.NotFoundError.prototype.notFound=!0,t.exports.NotFoundError.prototype.status=404},{}],"4WQgu":[function(e,t,r){"use strict";r.getCallback=function(e,t){return"function"==typeof e?e:t},r.getOptions=function(e){return"object"==typeof e&&null!==e?e:{}}},{}],"8xl4Y":[function(e,t,r){"use strict";const i=e("queue-microtask");t.exports=function(e,...t){0===t.length?i(e):i((()=>e(...t)))}},{"queue-microtask":"3aIgO"}],eMHkk:[function(e,t,r){"use strict";const i=e("abstract-leveldown").AbstractLevelDOWN,n=e("abstract-leveldown").AbstractChainedBatch,s=e("abstract-leveldown").AbstractIterator,o=e("inherits"),a=e("level-codec"),c=e("level-errors").EncodingError,u=["approximateSize","compactRange"];function l(e,t){if(!(this instanceof l))return new l(e,t);const r=e.supports||{},n=r.additionalMethods||{};i.call(this,r),this.supports.encodings=!0,this.supports.additionalMethods={},u.forEach((function(t){const r="function"==typeof e[t];(n[t]||r)&&(this.supports.additionalMethods[t]=!0,this[t]=function(e,r,i,n){return e=this.codec.encodeKey(e,i),r=this.codec.encodeKey(r,i),this.db[t](e,r,i,n)})}),this),void 0===(t=t||{}).keyEncoding&&(t.keyEncoding="utf8"),void 0===t.valueEncoding&&(t.valueEncoding="utf8"),this.db=e,this.codec=new a(t)}function d(e,t){s.call(this,e),this.codec=e.codec,this.keys=t.keys,this.values=t.values,this.opts=this.codec.encodeLtgt(t),this.it=e.db.iterator(this.opts)}function f(e,t){n.call(this,e),this.codec=e.codec,this.batch=e.db.batch()}t.exports=l,o(l,i),l.prototype.type="encoding-down",l.prototype._serializeKey=l.prototype._serializeValue=function(e){return e},l.prototype._open=function(e,t){this.db.open(e,t)},l.prototype._close=function(e){this.db.close(e)},l.prototype._put=function(e,t,r,i){e=this.codec.encodeKey(e,r),t=this.codec.encodeValue(t,r),this.db.put(e,t,r,i)},l.prototype._get=function(e,t,r){e=this.codec.encodeKey(e,t),t.asBuffer=this.codec.valueAsBuffer(t),this.db.get(e,t,((e,i)=>{if(e)return r(e);try{i=this.codec.decodeValue(i,t)}catch(e){return r(new c(e))}r(null,i)}))},l.prototype._getMany=function(e,t,r){e=e.map((e=>this.codec.encodeKey(e,t))),t.asBuffer=this.codec.valueAsBuffer(t),this.db.getMany(e,t,((e,i)=>{if(e)return r(e);const n=new Array(i.length);for(let s=0;s{if(t)return e(t);try{r=this.keys&&void 0!==r?this.codec.decodeKey(r,this.opts):void 0,i=this.values&&void 0!==i?this.codec.decodeValue(i,this.opts):void 0}catch(t){return e(new c(t))}e(null,r,i)}))},d.prototype._seek=function(e){e=this.codec.encodeKey(e,this.opts),this.it.seek(e)},d.prototype._end=function(e){this.it.end(e)},o(f,n),f.prototype._put=function(e,t,r){e=this.codec.encodeKey(e,r),t=this.codec.encodeValue(t,r),this.batch.put(e,t)},f.prototype._del=function(e,t){e=this.codec.encodeKey(e,t),this.batch.del(e)},f.prototype._clear=function(){this.batch.clear()},f.prototype._write=function(e,t){this.batch.write(e,t)}},{"abstract-leveldown":"f3ZXE",inherits:"j5plK","level-codec":"avh2o","level-errors":"iLFVA"}],avh2o:[function(e,t,r){"use strict";const i=e("./lib/encodings"),n=new Set(["lt","gt","lte","gte"]);function s(e){if(!(this instanceof s))return new s(e);this.opts=e||{},this.encodings=i}t.exports=s,s.prototype._encoding=function(e){return"string"==typeof e&&(e=i[e]),e||(e=i.id),e},s.prototype._keyEncoding=function(e,t){return this._encoding(t&&t.keyEncoding||e&&e.keyEncoding||this.opts.keyEncoding)},s.prototype._valueEncoding=function(e,t){return this._encoding(t&&(t.valueEncoding||t.encoding)||e&&(e.valueEncoding||e.encoding)||this.opts.valueEncoding||this.opts.encoding)},s.prototype.encodeKey=function(e,t,r){return this._keyEncoding(t,r).encode(e)},s.prototype.encodeValue=function(e,t,r){return this._valueEncoding(t,r).encode(e)},s.prototype.decodeKey=function(e,t){return this._keyEncoding(t).decode(e)},s.prototype.decodeValue=function(e,t){return this._valueEncoding(t).decode(e)},s.prototype.encodeBatch=function(e,t){return e.map((e=>{const r={type:e.type,key:this.encodeKey(e.key,t,e)};return this.keyAsBuffer(t,e)&&(r.keyEncoding="binary"),e.prefix&&(r.prefix=e.prefix),"value"in e&&(r.value=this.encodeValue(e.value,t,e),this.valueAsBuffer(t,e)&&(r.valueEncoding="binary")),r}))},s.prototype.encodeLtgt=function(e){const t={};for(const r of Object.keys(e)){if("start"===r||"end"===r)throw new Error('Legacy range options ("start" and "end") have been removed');t[r]=n.has(r)?this.encodeKey(e[r],e):e[r]}return t},s.prototype.createStreamDecoder=function(e){return e.keys&&e.values?(t,r)=>({key:this.decodeKey(t,e),value:this.decodeValue(r,e)}):e.keys?t=>this.decodeKey(t,e):e.values?(t,r)=>this.decodeValue(r,e):function(){}},s.prototype.keyAsBuffer=function(e){return this._keyEncoding(e).buffer},s.prototype.valueAsBuffer=function(e){return this._valueEncoding(e).buffer}},{"./lib/encodings":"yLou2"}],yLou2:[function(e,t,r){"use strict";const{Buffer:i}=e("buffer");r.utf8=r["utf-8"]={encode:function(e){return o(e)?e:String(e)},decode:s,buffer:!1,type:"utf8"},r.json={encode:JSON.stringify,decode:JSON.parse,buffer:!1,type:"json"},r.binary={encode:function(e){return o(e)?e:i.from(e)},decode:s,buffer:!0,type:"binary"},r.none={encode:s,decode:s,buffer:!1,type:"id"},r.id=r.none;const n=["hex","ascii","base64","ucs2","ucs-2","utf16le","utf-16le"];for(const e of n)r[e]={encode:function(t){return o(t)?t:i.from(t,e)},decode:function(t){return t.toString(e)},buffer:!0,type:e};function s(e){return e}function o(e){return null==e||i.isBuffer(e)}},{buffer:"etowf"}],lRPoL:[function(e,t,r){"use strict";t.exports=h;const i=e("abstract-leveldown").AbstractLevelDOWN,n=e("inherits"),s=e("run-parallel-limit"),o=e("./iterator"),a=e("./util/serialize"),c=e("./util/deserialize"),u=e("./util/support"),l=e("./util/clear"),d=e("./util/key-range"),f="level-js-";function h(e,t){if(!(this instanceof h))return new h(e,t);if(i.call(this,{bufferKeys:u.bufferKeys(indexedDB),snapshots:!0,permanence:!0,clear:!0,getMany:!0}),t=t||{},"string"!=typeof e)throw new Error("constructor requires a location string argument");this.location=e,this.prefix=null==t.prefix?f:t.prefix,this.version=parseInt(t.version||1,10)}n(h,i),h.prototype.type="level-js",h.prototype._open=function(e,t){const r=indexedDB.open(this.prefix+this.location,this.version);r.onerror=function(){t(r.error||new Error("unknown error"))},r.onsuccess=()=>{this.db=r.result,t()},r.onupgradeneeded=e=>{const t=e.target.result;t.objectStoreNames.contains(this.location)||t.createObjectStore(this.location)}},h.prototype.store=function(e){return this.db.transaction([this.location],e).objectStore(this.location)},h.prototype.await=function(e,t){const r=e.transaction;r.onabort=function(){t(r.error||new Error("aborted by user"))},r.oncomplete=function(){t(null,e.result)}},h.prototype._get=function(e,t,r){const i=this.store("readonly");let n;try{n=i.get(e)}catch(e){return this._nextTick(r,e)}this.await(n,(function(e,i){return e?r(e):void 0===i?r(new Error("NotFound")):void r(null,c(i,t.asBuffer))}))},h.prototype._getMany=function(e,t,r){const i=t.asBuffer,n=this.store("readonly"),o=e.map((e=>t=>{let r;try{r=n.get(e)}catch(e){return t(e)}r.onsuccess=()=>{const e=r.result;t(null,void 0===e?e:c(e,i))},r.onerror=e=>{e.stopPropagation(),t(r.error)}}));s(o,16,r)},h.prototype._del=function(e,t,r){const i=this.store("readwrite");let n;try{n=i.delete(e)}catch(e){return this._nextTick(r,e)}this.await(n,r)},h.prototype._put=function(e,t,r,i){const n=this.store("readwrite");let s;try{s=n.put(t,e)}catch(e){return this._nextTick(i,e)}this.await(s,i)},h.prototype._serializeKey=function(e){return a(e,this.supports.bufferKeys)},h.prototype._serializeValue=function(e){return a(e,!0)},h.prototype._iterator=function(e){return new o(this,this.location,e)},h.prototype._batch=function(e,t,r){if(0===e.length)return this._nextTick(r);const i=this.store("readwrite"),n=i.transaction;let s,o=0;n.onabort=function(){r(s||n.error||new Error("aborted by user"))},n.oncomplete=function(){r()},function t(){const r=e[o++],a=r.key;let c;try{c="del"===r.type?i.delete(a):i.put(r.value,a)}catch(e){return s=e,void n.abort()}o=0)return l(this,this.location,r,e,t);try{const e=this.store("readwrite");i=r?e.delete(r):e.clear()}catch(e){return this._nextTick(t,e)}this.await(i,t)},h.prototype._close=function(e){this.db.close(),this._nextTick(e)},h.prototype.upgrade=function(e){if("open"!==this.status)return this._nextTick(e,new Error("cannot upgrade() before open()"));const t=this.iterator(),r={},i=this;function n(e){if(e)return o(e);t.next(s)}function s(e,t,s){if(e||void 0===t)return o(e);const a=i._serializeKey(c(t,!0)),u=i._serializeValue(c(s,!0));i._batch([{type:"del",key:t},{type:"put",key:a,value:u}],r,n)}function o(r){t.end((function(t){e(r||t)}))}t._deserializeKey=t._deserializeValue=function(e){return e},n()},h.destroy=function(e,t,r){"function"==typeof t&&(r=t,t=f);const i=indexedDB.deleteDatabase(t+e);i.onsuccess=function(){r()},i.onerror=function(e){r(e)}}},{"abstract-leveldown":"f3ZXE",inherits:"j5plK","run-parallel-limit":"i7UCm","./iterator":"K8EMC","./util/serialize":"hGPws","./util/deserialize":"kV0qO","./util/support":"8xE1u","./util/clear":"6sCF8","./util/key-range":"iJjZ3"}],i7UCm:[function(e,t,r){ /*! run-parallel-limit. MIT License. Feross Aboukhadijeh */t.exports=function(e,t,r){if("number"!=typeof t)throw new Error("second argument must be a Number");let n,s,o,a,c,u,l=!0;Array.isArray(e)?(n=[],o=s=e.length):(a=Object.keys(e),n={},o=s=a.length);function d(e){function t(){r&&r(e,n),r=null}l?i(t):t()}function f(t,r,i){if(n[t]=i,r&&(c=!0),0==--o||r)d(r);else if(!c&&u{const t=e.target.result;t&&this.onItem(t)},this._transaction=i,i.onabort=()=>{this.onAbort(this._transaction.error||new Error("aborted by user"))},i.oncomplete=()=>{this.onComplete()}},c.prototype.onItem=function(e){this._cache.push(e.key,e.value),(this._limit<=0||++this._count0){let t=this._cache.shift(),r=this._cache.shift();t=this._keys&&void 0!==t?this._deserializeKey(t,this._keyAsBuffer):void 0,r=this._values&&void 0!==r?this._deserializeValue(r,this._valueAsBuffer):void 0,this._nextTick(e,null,t,r)}else this._completed?this._nextTick(e):this._callback=e},c.prototype._deserializeKey=o,c.prototype._deserializeValue=o,c.prototype._end=function(e){if(this._aborted||this._completed)return this._nextTick(e,this._error);this.onItem=a,this.onAbort=e,this.onComplete=e}},{inherits:"j5plK","abstract-leveldown":"f3ZXE","./util/key-range":"iJjZ3","./util/deserialize":"kV0qO"}],iJjZ3:[function(e,t,r){"use strict";const i=e("ltgt"),n=Symbol("none");t.exports=function(e){const t=i.lowerBound(e,n),r=i.upperBound(e,n),s=i.lowerBoundExclusive(e,n),o=i.upperBoundExclusive(e,n);return t!==n&&r!==n?IDBKeyRange.bound(t,r,s,o):t!==n?IDBKeyRange.lowerBound(t,s):r!==n?IDBKeyRange.upperBound(r,o):null}},{ltgt:"fRjrc"}],fRjrc:[function(e,t,r){var i=e("buffer").Buffer;function n(e){return void 0!==e&&""!==e}function s(e,t){return Object.hasOwnProperty.call(e,t)}function o(e,t){return Object.hasOwnProperty.call(e,t)&&t}r.compare=function(e,t){if(i.isBuffer(e)){for(var r=Math.min(e.length,t.length),n=0;nt?1:0};var a=r.lowerBoundKey=function(e){return o(e,"gt")||o(e,"gte")||o(e,"min")||(e.reverse?o(e,"end"):o(e,"start"))||void 0},c=r.lowerBound=function(e,t){var r=a(e);return r?e[r]:t},u=r.lowerBoundInclusive=function(e){return!s(e,"gt")},l=r.upperBoundInclusive=function(e){return!s(e,"lt")},d=r.lowerBoundExclusive=function(e){return!u(e)},f=r.upperBoundExclusive=function(e){return!l(e)},h=r.upperBoundKey=function(e){return o(e,"lt")||o(e,"lte")||o(e,"max")||(e.reverse?o(e,"start"):o(e,"end"))||void 0},p=r.upperBound=function(e,t){var r=h(e);return r?e[r]:t};function g(e){return e}r.start=function(e,t){return e.reverse?p(e,t):c(e,t)},r.end=function(e,t){return e.reverse?c(e,t):p(e,t)},r.startInclusive=function(e){return e.reverse?l(e):u(e)},r.endInclusive=function(e){return e.reverse?u(e):l(e)},r.toLtgt=function(e,t,i,n,o){t=t||{},i=i||g;var a=arguments.length>3,c=r.lowerBoundKey(e),u=r.upperBoundKey(e);return c?"gt"===c?t.gt=i(e.gt,!1):t.gte=i(e[c],!1):a&&(t.gte=i(n,!1)),u?"lt"===u?t.lt=i(e.lt,!0):t.lte=i(e[u],!0):a&&(t.lte=i(o,!0)),null!=e.reverse&&(t.reverse=!!e.reverse),s(t,"max")&&delete t.max,s(t,"min")&&delete t.min,s(t,"start")&&delete t.start,s(t,"end")&&delete t.end,t},r.contains=function(e,t,i){i=i||r.compare;var s=c(e);if(n(s)&&((o=i(t,s))<0||0===o&&d(e)))return!1;var o,a=p(e);if(n(a)&&((o=i(t,a))>0||0===o&&f(e)))return!1;return!0},r.filter=function(e,t){return function(i){return r.contains(e,i,t)}}},{buffer:"etowf"}],kV0qO:[function(e,t,r){var i=arguments[3];const n=e("buffer").Buffer,s=function(){if(i.TextDecoder){const e=new TextDecoder("utf-8");return e.decode.bind(e)}return function(e){return a(e).toString()}}(),o=function(){if(i.TextDecoder){const e=new TextDecoder("utf-8");return e.decode.bind(e)}return function(e){return n.from(e).toString()}}();function a(e){const t=n.from(e.buffer);return e.byteLength===e.buffer.byteLength?t:t.slice(e.byteOffset,e.byteOffset+e.byteLength)}t.exports=function(e,t){return e instanceof Uint8Array?t?a(e):s(e):e instanceof ArrayBuffer?t?n.from(e):o(e):t?n.from(String(e)):String(e)}},{buffer:"etowf"}],hGPws:[function(e,t,r){var i=arguments[3];const n=e("buffer").Buffer,s=function(){if(i.TextEncoder){const e=new TextEncoder("utf-8");return e.encode.bind(e)}return n.from}();t.exports=function(e,t){return t?n.isBuffer(e)?e:s(String(e)):String(e)}},{buffer:"etowf"}],"8xE1u":[function(e,t,r){"use strict";const i=e("buffer").Buffer;r.test=function(e){return function(t){try{return t.cmp(e,0),!0}catch(e){return!1}}},r.bufferKeys=r.test(i.alloc(0))},{buffer:"etowf"}],"6sCF8":[function(e,t,r){"use strict";t.exports=function(e,t,r,i,n){if(0===i.limit)return e._nextTick(n);const s=e.db.transaction([t],"readwrite"),o=s.objectStore(t);let a=0;s.oncomplete=function(){n()},s.onabort=function(){n(s.error||new Error("aborted by user"))};const c=o.openKeyCursor?"openKeyCursor":"openCursor",u=i.reverse?"prev":"next";o[c](r,u).onsuccess=function(e){const t=e.target.result;t&&(o.delete(t.key).onsuccess=function(){(i.limit<=0||++au.base32.decode(e.toLowerCase()).subarray(2):"c"===t.toLowerCase()?e=>u.base32pad.decode(e.toLowerCase()).subarray(2):"z"===t?e=>l.base58btc.decode(e).subarray(2):"Q"===t?e=>l.base58btc.decode("z"+e):e=>u.base32.decode("b"+e.toLowerCase()).subarray(2);for(let t=1;tt=>e({key:_(t.key),value:t.value}))):void 0,orders:e.orders?e.orders.map((e=>(t,r)=>e({key:_(t.key),value:t.value},{key:_(r.key),value:r.value}))):void 0}}(e),t))yield{key:_(r),value:i}}async*queryKeys(e,t){for await(const i of this.child.queryKeys((r=e,{...r,prefix:r.prefix?E(r.prefix):void 0,filters:r.filters?r.filters.map((e=>t=>e(_(t)))):void 0,orders:r.orders?r.orders.map((e=>(t,r)=>e(_(t),_(r)))):void 0}),t))yield _(i);var r}async get(e,t){return this.child.get(w(e),t)}async*getMany(e,t){for await(const r of e)yield this.get(r,t)}async put(e,t,r){await this.child.put(w(e),t,r)}async*putMany(e,t){const r=y.default();(globalThis.process&&globalThis.process.nextTick?globalThis.process.nextTick:globalThis.setImmediate||globalThis.setTimeout)((async()=>{try{const i=this.child;await g.default(this.child.putMany(async function*(){for await(const n of e){const e=w(n.key);await i.has(e,t)||(yield{key:e,value:n.value}),r.push(n)}}())),r.end()}catch(e){r.end(e)}})),yield*r}has(e,t){return this.child.has(w(e),t)}delete(e,t){return this.child.delete(w(e),t)}deleteMany(e,t){const r=y.default();return g.default(this.child.deleteMany(async function*(){for await(const t of e)yield w(t),r.push(t);r.end()}(),t)).catch((e=>{r.end(e)})),r}}r.BlockstoreDatastoreAdapter=S},{"it-drain":"dKYhO","it-pushable":"bnpei","interface-datastore/key":"9hGOz","multiformats/cid":"9ooAY","multiformats/codecs/raw":"fdfgp","multiformats/hashes/digest":"kpRBg","multiformats/bases/base32":"5k9Tu","multiformats/bases/base58":"4n7mA","err-code":"chZjB","blockstore-core/base":"l2CNM"}],l2CNM:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("it-drain"),n=e("it-filter"),s=e("it-take"),o=e("it-all");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var c=a(i),u=a(n),l=a(s),d=a(o);const f=(e,t)=>async function*(){const r=await d.default(e);yield*r.sort(t)}();r.BaseBlockstore=class{open(){return Promise.reject(new Error(".open is not implemented"))}close(){return Promise.reject(new Error(".close is not implemented"))}put(e,t,r){return Promise.reject(new Error(".put is not implemented"))}get(e,t){return Promise.reject(new Error(".get is not implemented"))}has(e,t){return Promise.reject(new Error(".has is not implemented"))}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*putMany(e,t={}){for await(const{key:r,value:i}of e)await this.put(r,i,t),yield{key:r,value:i}}async*getMany(e,t={}){for await(const r of e)yield this.get(r,t)}async*deleteMany(e,t={}){for await(const r of e)await this.delete(r,t),yield r}batch(){let e=[],t=[];return{put(t,r){e.push({key:t,value:r})},delete(e){t.push(e)},commit:async r=>{await c.default(this.putMany(e,r)),e=[],await c.default(this.deleteMany(t,r)),t=[]}}}async*_all(e,t){throw new Error("._all is not implemented")}async*_allKeys(e,t){throw new Error("._allKeys is not implemented")}query(e,t){let r=this._all(e,t);if(null!=e.prefix&&(r=u.default(r,(t=>t.key.toString().startsWith(e.prefix||"")))),Array.isArray(e.filters)&&(r=e.filters.reduce(((e,t)=>u.default(e,t)),r)),Array.isArray(e.orders)&&(r=e.orders.reduce(((e,t)=>f(e,t)),r)),null!=e.offset){let t=0;r=u.default(r,(()=>t++>=(e.offset||0)))}return null!=e.limit&&(r=l.default(r,e.limit)),r}queryKeys(e,t){let r=this._allKeys(e,t);if(null!=e.prefix&&(r=u.default(r,(t=>t.toString().startsWith(e.prefix||"")))),Array.isArray(e.filters)&&(r=e.filters.reduce(((e,t)=>u.default(e,t)),r)),Array.isArray(e.orders)&&(r=e.orders.reduce(((e,t)=>f(e,t)),r)),null!=e.offset){let t=0;r=u.default(r,(()=>t++>=e.offset))}return null!=e.limit&&(r=l.default(r,e.limit)),r}}},{"it-drain":"dKYhO","it-filter":"5LCTL","it-take":"gxr1t","it-all":"iCXBu"}],jcB2q:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("dlv"),n=e("merge-options"),s=e("err-code"),o=e("ipfs-core-config/libp2p-pubsub-routers"),a=e("libp2p-delegated-peer-routing"),c=e("libp2p-delegated-content-routing"),u=e("ipfs-http-client"),l=e("multiaddr"),d=e("../version.js"),f=e("ipfs-core-config/libp2p"),h=e("libp2p-bootstrap"),p=e("libp2p");function g(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var y=g(i),m=g(n),b=g(s),v=g(a),w=g(c),_=g(h),E=g(p);const S=m.default.bind({ignoreUndefined:!0});r.createLibp2p=function({options:e={},peerId:t,multiaddrs:r=[],repo:i,keychainConfig:n={},config:s={}}){const{datastore:a,keys:c}=i,h=function({options:e,config:t,datastore:r,keys:i,keychainConfig:n,peerId:s,multiaddrs:a}){const c={datastore:r,peerId:s,modules:{}},h={modules:{pubsub:(()=>{const e=y.default(t,"Pubsub.Router")||"gossipsub";if(!o.routers[e])throw b.default(new Error(`Router unavailable. Configure libp2p.modules.pubsub to use the ${e} router.`),"ERR_NOT_SUPPORTED");return o.routers[e]})(),contentRouting:[],peerRouting:[]},config:{peerDiscovery:{mdns:{enabled:y.default(e,"config.Discovery.MDNS.Enabled",y.default(t,"Discovery.MDNS.Enabled",!0))},webRTCStar:{enabled:y.default(e,"config.Discovery.webRTCStar.Enabled",y.default(t,"Discovery.webRTCStar.Enabled",!0))},bootstrap:{list:y.default(e,"config.Bootstrap",y.default(t,"Bootstrap",[]))}},relay:{enabled:y.default(e,"relay.enabled",y.default(t,"relay.enabled",!0)),hop:{enabled:y.default(e,"relay.hop.enabled",y.default(t,"relay.hop.enabled",!1)),active:y.default(e,"relay.hop.active",y.default(t,"relay.hop.active",!1))}},dht:{enabled:"none"!==y.default(t,"Routing.Type","none"),clientMode:"dhtserver"!==y.default(t,"Routing.Type","dht"),kBucketSize:y.default(e,"dht.kBucketSize",20)},pubsub:{enabled:y.default(e,"config.Pubsub.Enabled",y.default(t,"Pubsub.Enabled",!0))},nat:{enabled:!y.default(t,"Swarm.DisableNatPortMap",!1)}},addresses:{listen:a.map((e=>e.toString())),announce:y.default(e,"addresses.announce",y.default(t,"Addresses.Announce",[])),noAnnounce:y.default(e,"addresses.noAnnounce",y.default(t,"Addresses.NoAnnounce",[]))},connectionManager:y.default(e,"connectionManager",{maxConnections:y.default(e,"config.Swarm.ConnMgr.HighWater",y.default(t,"Swarm.ConnMgr.HighWater")),minConnections:y.default(e,"config.Swarm.ConnMgr.LowWater",y.default(t,"Swarm.ConnMgr.LowWater"))}),keychain:{datastore:i,...n},host:{agentVersion:`js-ipfs/${d.ipfsCore}`}};let p=y.default(e,"libp2p",void 0);"function"==typeof p&&(p=void 0);const g=S(c,f.libp2pConfig(),h,p);y.default(g,"config.peerDiscovery.bootstrap.list",[]).length>0&&g.modules.peerDiscovery.push(_.default);const m=y.default(e,"config.Addresses.Delegates",y.default(t,"Addresses.Delegates",[]));if(m.length>0){const e=m[Math.floor(Math.random()*m.length)],t=new l.Multiaddr(e).toOptions(),r={host:t.host,protocol:443===parseInt(t.port)?"https":"http",port:t.port},i=u.create(r);h.modules.contentRouting=h.modules.contentRouting||[],h.modules.contentRouting.push(new w.default(s,i)),h.modules.peerRouting=h.modules.peerRouting||[],h.modules.peerRouting.push(new v.default(i))}return g}({options:e,config:s,datastore:a,keys:c,keychainConfig:n,peerId:t,multiaddrs:r});return"function"==typeof e.libp2p?e.libp2p({libp2pOptions:h,options:e,config:s,datastore:a,peerId:t}):E.default.create(h)}},{dlv:"hp0pQ","merge-options":"fupyv","err-code":"chZjB","ipfs-core-config/libp2p-pubsub-routers":"3XeOM","libp2p-delegated-peer-routing":"jgA5e","libp2p-delegated-content-routing":"gg6SI","ipfs-http-client":"h5Uk6",multiaddr:"8Mu1u","../version.js":"cyFMr","ipfs-core-config/libp2p":"eStoI","libp2p-bootstrap":"hla2J",libp2p:"757Qe"}],"3XeOM":[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});const n={gossipsub:i(e("libp2p-gossipsub")).default};r.routers=n},{"libp2p-gossipsub":"eSowE"}],eSowE:[function(e,t,r){"use strict";var i=this&&this.__createBinding||(Object.create?function(e,t,r,i){void 0===i&&(i=r),Object.defineProperty(e,i,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,i){void 0===i&&(i=r),e[i]=t[r]}),n=this&&this.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),s=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var r in e)"default"!==r&&Object.prototype.hasOwnProperty.call(e,r)&&i(t,e,r);return n(t,e),t},o=this&&this.__awaiter||function(e,t,r,i){return new(r||(r=Promise))((function(n,s){function o(e){try{c(i.next(e))}catch(e){s(e)}}function a(e){try{c(i.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?n(e.value):(t=e.value,t instanceof r?t:new r((function(e){e(t)}))).then(o,a)}c((i=i.apply(e,t||[])).next())}))};const a=s(e("libp2p-interfaces/src/pubsub")),c=e("./message-cache"),u=e("./message/rpc"),l=s(e("./constants")),d=e("./heartbeat"),f=e("./get-gossip-peers"),h=e("./utils"),p=e("./score"),g=e("./tracer"),y=e("time-cache"),m=e("peer-id"),b=e("libp2p/src/record/envelope");class v extends a.default{constructor(e,t={}){const r=[l.GossipsubIDv11,l.GossipsubIDv10],i=Object.assign(Object.assign({gossipIncoming:!0,fallbackToFloodsub:!0,floodPublish:!0,doPX:!1,directPeers:[],D:l.GossipsubD,Dlo:l.GossipsubDlo,Dhi:l.GossipsubDhi,Dscore:l.GossipsubDscore,Dout:l.GossipsubDout,Dlazy:l.GossipsubDlazy,heartbeatInterval:l.GossipsubHeartbeatInterval,fanoutTTL:l.GossipsubFanoutTTL,mcacheLength:l.GossipsubHistoryLength,mcacheGossip:l.GossipsubHistoryGossip,seenTTL:l.GossipsubSeenTTL},t),{scoreParams:p.createPeerScoreParams(t.scoreParams),scoreThresholds:p.createPeerScoreThresholds(t.scoreThresholds)});i.fallbackToFloodsub&&r.push(l.FloodsubID),super(Object.assign({debugName:"libp2p:gossipsub",multicodecs:r,libp2p:e},i)),this._options=i,this.direct=new Set(i.directPeers.map((e=>e.id.toB58String()))),i.directPeers.forEach((t=>{e.peerStore.addressBook.add(t.id,t.addrs)})),this.seenCache=new y({validity:i.seenTTL/1e3}),this.mesh=new Map,this.fanout=new Map,this.lastpub=new Map,this.gossip=new Map,this.control=new Map,this.peerhave=new Map,this.iasked=new Map,this.backoff=new Map,this.outbound=new Map,this.messageCache=t.messageCache||new c.MessageCache(i.mcacheGossip,i.mcacheLength,this.getMsgId.bind(this)),this.heartbeat=new d.Heartbeat(this),this.heartbeatTicks=0,this.gossipTracer=new g.IWantTracer(this.getMsgId.bind(this)),this._libp2p=e,this.score=new p.PeerScore(this._options.scoreParams,e.connectionManager,this.getMsgId.bind(this))}_decodeRpc(e){return u.RPC.decode(e)}_encodeRpc(e){return u.RPC.encode(e).finish()}_addPeer(e,t){const r=super._addPeer(e,t);this.score.addPeer(e.toB58String());let i=!1;for(const r of this._libp2p.connectionManager.getAll(e))if("outbound"===r.stat.direction&&Array.from(r.registry.values()).some((e=>t===e.protocol))){i=!0;break}return this.outbound.set(r.id.toB58String(),i),r}_removePeer(e){const t=super._removePeer(e),r=e.toB58String();for(const e of this.mesh.values())e.delete(r);for(const e of this.fanout.values())e.delete(r);return this.gossip.delete(r),this.control.delete(r),this.outbound.delete(r),this.score.removePeer(r),t}_processRpc(e,t,r){const i=Object.create(null,{_processRpc:{get:()=>super._processRpc}});return o(this,void 0,void 0,(function*(){return!!(yield i._processRpc.call(this,e,t,r))&&(r.control&&this._processRpcControlMessage(e,r.control),!0)}))}_processRpcControlMessage(e,t){if(!t)return;const r=t.ihave?this._handleIHave(e,t.ihave):[],i=t.iwant?this._handleIWant(e,t.iwant):[],n=t.graft?this._handleGraft(e,t.graft):[];if(t.prune&&this._handlePrune(e,t.prune),!r.length&&!i.length&&!n.length)return;const s=h.createGossipRpc(i,{iwant:r,prune:n});this._sendRpc(e,s)}_processRpcMessage(e){const t=Object.create(null,{_processRpcMessage:{get:()=>super._processRpcMessage}});return o(this,void 0,void 0,(function*(){const r=yield this.getMsgId(e),i=h.messageIdToString(r);this.seenCache.has(i)?this.score.duplicateMessage(e):(this.seenCache.put(i),yield this.score.validateMessage(e),yield t._processRpcMessage.call(this,e))}))}_acceptFrom(e){return this.direct.has(e)||this.score.score(e)>=this._options.scoreThresholds.graylistThreshold}validate(e){const t=Object.create(null,{validate:{get:()=>super.validate}});return o(this,void 0,void 0,(function*(){try{yield t.validate.call(this,e)}catch(t){throw this.score.rejectMessage(e,t.code),this.gossipTracer.rejectMessage(e,t.code),t}}))}_handleIHave(e,t){if(!t.length)return[];const r=this.score.score(e);if(rl.GossipsubMaxIHaveMessages)return this.log("IHAVE: peer %s has advertised too many times (%d) within this heartbeat interval; ignoring",e,i),[];const n=this.iasked.get(e)||0;if(n>=l.GossipsubMaxIHaveLength)return this.log("IHAVE: peer %s has already advertised too many messages (%d); ignoring",e,n),[];const s=new Map;if(t.forEach((({topicID:e,messageIDs:t})=>{e&&t&&this.mesh.has(e)&&t.forEach((e=>{const t=h.messageIdToString(e);this.seenCache.has(t)||s.set(t,e)}))})),!s.size)return[];let o=s.size;o+n>l.GossipsubMaxIHaveLength&&(o=l.GossipsubMaxIHaveLength-n),this.log("IHAVE: Asking for %d out of %d messages from %s",o,s.size,e);let a=Array.from(s.values());return h.shuffle(a),a=a.slice(0,o),this.iasked.set(e,n+o),this.gossipTracer.addPromise(e,a),[{messageIDs:a}]}_handleIWant(e,t){if(!t.length)return[];const r=this.score.score(e);if(r{t&&t.forEach((t=>{const[r,n]=this.messageCache.getForPeer(t,e);r&&(n>l.GossipsubGossipRetransmission?this.log("IWANT: Peer %s has asked for message %s too many times: ignoring request",e,t):i.set(h.messageIdToString(t),r))}))})),i.size?(this.log("IWANT: Sending %d messages to %s",i.size,e),Array.from(i.values()).map(a.utils.normalizeOutRpcMessage)):[]}_handleGraft(e,t){const r=[],i=this.score.score(e),n=this._now();let s=this._options.doPX;return t.forEach((({topicID:t})=>{var o;if(!t)return;const a=this.mesh.get(t);if(!a)return void(s=!1);if(a.has(e))return;if(this.direct.has(e))return this.log("GRAFT: ignoring request from direct peer %s",e),r.push(t),void(s=!1);const c=null===(o=this.backoff.get(t))||void 0===o?void 0:o.get(e);if("number"==typeof c&&n=this._options.Dhi&&!this.outbound.get(e)?(r.push(t),void this._addBackoff(e,t)):(this.log("GRAFT: Add mesh link from %s in %s",e,t),this.score.graft(e,t),void a.add(e))})),r.length?r.map((t=>this._makePrune(e,t,s))):[]}_handlePrune(e,t){const r=this.score.score(e);t.forEach((({topicID:t,backoff:i,peers:n})=>{if(!t)return;const s=this.mesh.get(t);if(s&&(this.log("PRUNE: Remove mesh link to %s in %s",e,t),this.score.prune(e,t),s.delete(e),"number"==typeof i&&i>0?this._doAddBackoff(e,t,1e3*i):this._addBackoff(e,t),n&&n.length)){if(r{this.log("peer %s didn't follow up in %d IWANT requests; adding penalty",t,e),this.score.addPenalty(t,e)}))}_clearBackoff(){if(this.heartbeatTicks%l.GossipsubPruneBackoffTicks!=0)return;const e=this._now();this.backoff.forEach(((t,r)=>{t.forEach(((r,i)=>{r{const r=this.peers.get(t);r&&r.isWritable||e.push(t)})),e.length&&e.forEach((e=>{this._connect(e)}))}_pxConnect(e){return o(this,void 0,void 0,(function*(){e.length>l.GossipsubPrunePeers&&(h.shuffle(e),e=e.slice(0,l.GossipsubPrunePeers));const t=[];yield Promise.all(e.map((e=>o(this,void 0,void 0,(function*(){if(!e.peerID)return;const r=m.createFromBytes(e.peerID).toB58String();if(!this.peers.has(r))if(e.signedPeerRecord)try{const i=yield b.openAndCertify(e.signedPeerRecord,"libp2p-peer-record"),n=i.peerId.toB58String();if(r!==n)return void this.log("bogus peer record obtained through px: peer ID %s doesn't match expected peer %s",n,r);if(!this._libp2p.peerStore.addressBook.consumePeerRecord(i))return void this.log("bogus peer record obtained through px: could not add peer record to address book");t.push(r)}catch(e){this.log("bogus peer record obtained through px: invalid signature or not a peer record")}else t.push(r)}))))),t.length&&t.forEach((e=>this._connect(e)))}))}start(){super.start(),this.heartbeat.start(),this.score.start(),this._directPeerInitial=setTimeout((()=>{this.direct.forEach((e=>{this._connect(e)}))}),l.GossipsubDirectConnectInitialDelay)}stop(){super.stop(),this.heartbeat.stop(),this.score.stop(),this.mesh=new Map,this.fanout=new Map,this.lastpub=new Map,this.gossip=new Map,this.control=new Map,this.peerhave=new Map,this.iasked=new Map,this.backoff=new Map,this.outbound=new Map,this.gossipTracer.clear(),clearTimeout(this._directPeerInitial)}_connect(e){this.log("Initiating connection with %s",e),this._libp2p.dialProtocol(m.createFromB58String(e),this.multicodecs)}subscribe(e){super.subscribe(e),this.join(e)}unsubscribe(e){super.unsubscribe(e),this.leave(e)}join(e){if(!this.started)throw new Error("Gossipsub has not started");this.log("JOIN %s",e);const t=this.fanout.get(e);if(t)t.forEach((e=>{this.score.score(e)<0&&t.delete(e)})),t.size!t.has(e)&&!this.direct.has(e)&&this.score.score(e)>=0)).forEach((e=>t.add(e))),this.mesh.set(e,t),this.fanout.delete(e),this.lastpub.delete(e);else{const t=f.getGossipPeers(this,e,this._options.D,(e=>!this.direct.has(e)&&this.score.score(e)>=0));this.mesh.set(e,t)}this.mesh.get(e).forEach((t=>{this.log("JOIN: Add mesh link to %s in %s",t,e),this._sendGraft(t,e)}))}leave(e){if(!this.started)throw new Error("Gossipsub has not started");this.log("LEAVE %s",e);const t=this.mesh.get(e);t&&(t.forEach((t=>{this.log("LEAVE: Remove mesh link to %s in %s",t,e),this._sendPrune(t,e)})),this.mesh.delete(e))}_publish(e){return o(this,void 0,void 0,(function*(){e.receivedFrom!==this.peerId.toB58String()&&(this.score.deliverMessage(e),this.gossipTracer.deliverMessage(e));const t=yield this.getMsgId(e),r=h.messageIdToString(t);this.seenCache.put(r),this.messageCache.put(e);const i=new Set;e.topicIDs.forEach((t=>{const r=this.topics.get(t);if(r)if(this._options.floodPublish&&e.from===this.peerId.toB58String())r.forEach((e=>{(this.direct.has(e)||this.score.score(e)>=this._options.scoreThresholds.publishThreshold)&&i.add(e)}));else{this.direct.forEach((e=>{i.add(e)})),r.forEach((e=>{const t=this.score.score(e),r=this.peers.get(e);r&&r.protocol===l.FloodsubID&&t>=this._options.scoreThresholds.publishThreshold&&i.add(e)}));let e=this.mesh.get(t);if(!e||!e.size){if(e=this.fanout.get(t),!e){const r=f.getGossipPeers(this,t,this._options.D,(e=>this.score.score(e)>=this._options.scoreThresholds.publishThreshold));r.size>0?(e=r,this.fanout.set(t,r)):e=new Set}this.lastpub.set(t,this._now())}e.forEach((e=>{i.add(e)}))}}));const n=h.createGossipRpc([a.utils.normalizeOutRpcMessage(e)]);i.forEach((t=>{t!==e.from&&this._sendRpc(t,n)}))}))}_sendGraft(e,t){const r=[{topicID:t}],i=h.createGossipRpc([],{graft:r});this._sendRpc(e,i)}_sendPrune(e,t){const r=[this._makePrune(e,t,this._options.doPX)],i=h.createGossipRpc([],{prune:r});this._sendRpc(e,i)}_sendRpc(e,t){const r=this.peers.get(e);if(!r||!r.isWritable)return;const i=this.control.get(e);i&&(this._piggybackControl(e,t,i),this.control.delete(e));const n=this.gossip.get(e);n&&(this._piggybackGossip(e,t,n),this.gossip.delete(e)),r.write(u.RPC.encode(t).finish())}_piggybackControl(e,t,r){const i=(r.graft||[]).filter((({topicID:t})=>(t&&this.mesh.get(t)||new Set).has(e))),n=(r.prune||[]).filter((({topicID:t})=>!(t&&this.mesh.get(t)||new Set).has(e)));(i.length||n.length)&&(t.control?(t.control.graft=t.control.graft&&t.control.graft.concat(i),t.control.prune=t.control.prune&&t.control.prune.concat(n)):t.control={ihave:[],iwant:[],graft:i,prune:n})}_piggybackGossip(e,t,r){t.control||(t.control={ihave:[],iwant:[],graft:[],prune:[]}),t.control.ihave=r}_sendGraftPrune(e,t,r){const i=this._options.doPX;for(const[n,s]of e){const e=s.map((e=>({topicID:e})));let o=[];const a=t.get(n);a&&(o=a.map((e=>this._makePrune(n,e,i&&!r.get(n)))),t.delete(n));const c=h.createGossipRpc([],{graft:e,prune:o});this._sendRpc(n,c)}for(const[e,n]of t){const t=n.map((t=>this._makePrune(e,t,i&&!r.get(e)))),s=h.createGossipRpc([],{prune:t});this._sendRpc(e,s)}}_emitGossip(e,t){const r=this.messageCache.getGossipIDs(e);if(!r.length)return;h.shuffle(r),r.length>l.GossipsubMaxIHaveLength&&this.log("too many messages for gossip; will truncate IHAVE list (%d messages)",r.length);const i=[],n=this.topics.get(e);if(!n)return;n.forEach((e=>{const r=this.peers.get(e);r&&!t.has(e)&&!this.direct.has(e)&&h.hasGossipProtocol(r.protocol)&&this.score.score(e)>=this._options.scoreThresholds.gossipThreshold&&i.push(e)}));let s=this._options.Dlazy;const o=l.GossipsubGossipFactor*i.length;o>s&&(s=o),s>i.length?s=i.length:h.shuffle(i),i.slice(0,s).forEach((t=>{let i=r;r.length>l.GossipsubMaxIHaveLength&&(i=h.shuffle(i.slice()).slice(0,l.GossipsubMaxIHaveLength)),this._pushGossip(t,{topicID:e,messageIDs:i})}))}_flush(){for(const[e,t]of this.gossip.entries()){this.gossip.delete(e);const r=h.createGossipRpc([],{ihave:t});this._sendRpc(e,r)}for(const[e,t]of this.control.entries()){this.control.delete(e);const r=h.createGossipRpc([],{graft:t.graft,prune:t.prune});this._sendRpc(e,r)}}_pushGossip(e,t){this.log("Add gossip to %s",e);const r=this.gossip.get(e)||[];this.gossip.set(e,r.concat(t))}_now(){return Date.now()}_makePrune(e,t,r){if(this.peers.get(e).protocol===l.GossipsubIDv10)return{topicID:t,peers:[]};const i=l.GossipsubPruneBackoff/1e3,n=[];if(r){f.getGossipPeers(this,t,l.GossipsubPrunePeers,(t=>t!==e&&this.score.score(t)>=0)).forEach((e=>{const t=m.createFromB58String(e);n.push({peerID:t.toBytes(),signedPeerRecord:this._libp2p.peerStore.addressBook.getRawEnvelope(t)})}))}return{topicID:t,peers:n,backoff:i}}}v.multicodec=l.GossipsubIDv11,t.exports=v},{"libp2p-interfaces/src/pubsub":"6JRpn","./message-cache":"gJumF","./message/rpc":"8UPPx","./constants":"kx67k","./heartbeat":"l9R1d","./get-gossip-peers":"jYUGm","./utils":"8kUZs","./score":"8Uy6q","./tracer":"8V5x8","time-cache":"gpqKk","peer-id":"8Bdb3","libp2p/src/record/envelope":"27rHX"}],"6JRpn":[function(e,t,r){"use strict";const i=e("debug"),{EventEmitter:n}=e("events"),s=e("err-code"),{pipe:o}=e("it-pipe"),{default:a}=e("p-queue"),c=e("../topology/multicodec-topology"),{codes:u}=e("./errors"),{RPC:l}=e("./message/rpc"),d=e("./peer-streams"),{SignaturePolicy:f}=e("./signature-policy"),h=e("./utils"),{signMessage:p,verifySignature:g}=e("./message/sign");class y extends n{constructor({debugName:e,multicodecs:t,libp2p:r,globalSignaturePolicy:n=f.StrictSign,canRelayMessage:o=!1,emitSelf:c=!1,messageProcessingConcurrency:l=10}){if("string"!=typeof e)throw new Error("a debugname `string` is required");if(!t)throw new Error("multicodecs are required");if(!r)throw new Error("libp2p is required");if(super(),this.log=Object.assign(i(e),{err:i(`${e}:error`)}),this.multicodecs=h.ensureArray(t),this._libp2p=r,this.registrar=r.registrar,this.peerId=r.peerId,this.started=!1,this.topics=new Map,this.subscriptions=new Set,this.peers=new Map,!f[n])throw s(new Error("Invalid global signature policy"),u.ERR_INVALID_SIGNATURE_POLICY);this.globalSignaturePolicy=n,this.canRelayMessage=o,this.emitSelf=c,this.topicValidators=new Map,this.queue=new a({concurrency:l}),this._registrarId=void 0,this._onIncomingStream=this._onIncomingStream.bind(this),this._onPeerConnected=this._onPeerConnected.bind(this),this._onPeerDisconnected=this._onPeerDisconnected.bind(this)}start(){if(this.started)return;this.log("starting"),this.registrar.handle(this.multicodecs,this._onIncomingStream);const e=new c({multicodecs:this.multicodecs,handlers:{onConnect:this._onPeerConnected,onDisconnect:this._onPeerDisconnected}});this._registrarId=this.registrar.register(e),this.log("started"),this.started=!0}stop(){this.started&&(this.registrar.unregister(this._registrarId),this.log("stopping"),this.peers.forEach((e=>e.close())),this.peers=new Map,this.subscriptions=new Set,this.started=!1,this.log("stopped"))}_onIncomingStream({protocol:e,stream:t,connection:r}){const i=r.remotePeer,n=i.toB58String(),s=this._addPeer(i,e),o=s.attachInboundStream(t);this._processMessages(n,o,s)}async _onPeerConnected(e,t){const r=e.toB58String();this.log("connected",r);try{const{stream:r,protocol:i}=await t.newStream(this.multicodecs),n=this._addPeer(e,i);await n.attachOutboundStream(r)}catch(e){this.log.err(e)}this._sendSubscriptions(r,Array.from(this.subscriptions),!0)}_onPeerDisconnected(e,t){const r=e.toB58String();this.log("connection ended",r,t?t.message:""),this._removePeer(e)}_addPeer(e,t){const r=e.toB58String(),i=this.peers.get(r);if(i)return i;this.log("new peer",r);const n=new d({id:e,protocol:t});return this.peers.set(r,n),n.once("close",(()=>this._removePeer(e))),n}_removePeer(e){if(!e)return;const t=e.toB58String(),r=this.peers.get(t);if(r){r.removeAllListeners(),r.close(),this.log("delete peer",t),this.peers.delete(t);for(const e of this.topics.values())e.delete(t);return r}}async _processMessages(e,t,r){try{await o(t,(async t=>{for await(const i of t){const t=i instanceof Uint8Array?i:i.slice(),n=this._decodeRpc(t);(async()=>{try{await this._processRpc(e,r,n)}catch(e){this.log.err(e)}})()}}))}catch(e){this._onPeerDisconnected(r.id,e)}}async _processRpc(e,t,r){this.log("rpc from",e);const i=r.subscriptions,n=r.msgs;return i.length&&(i.forEach((t=>{this._processRpcSubOpt(e,t)})),this.emit("pubsub:subscription-change",t.id,i)),this._acceptFrom(e)?(n.length&&this.queue.addAll(n.map((t=>async()=>{if(this.canRelayMessage||t.topicIDs&&t.topicIDs.some((e=>this.subscriptions.has(e))))try{const r=h.normalizeInRpcMessage(t,e);await this._processRpcMessage(r)}catch(e){this.log.err(e)}else this.log("received message we didn't subscribe to. Dropping.")}))),!0):(this.log("received message from unacceptable peer %s",e),!1)}_processRpcSubOpt(e,t){const r=t.topicID;if(!r)return;let i=this.topics.get(r);i||(i=new Set,this.topics.set(r,i)),t.subscribe?i.add(e):i.delete(e)}async _processRpcMessage(e){if(this.peerId.toB58String()!==e.from||this.emitSelf){try{await this.validate(e)}catch(e){return void this.log("Message is invalid, dropping it. %O",e)}return this._emitMessage(e),this._publish(h.normalizeOutRpcMessage(e))}}_emitMessage(e){e.topicIDs.forEach((t=>{this.subscriptions.has(t)&&this.emit(t,e)}))}getMsgId(e){const t=this.globalSignaturePolicy;switch(t){case f.StrictSign:return h.msgId(e.from,e.seqno);case f.StrictNoSign:return h.noSignMsgId(e.data);default:throw s(new Error("Cannot get message id: unhandled signature policy: "+t),u.ERR_UNHANDLED_SIGNATURE_POLICY)}}_acceptFrom(e){return!0}_decodeRpc(e){return l.decode(e)}_encodeRpc(e){return l.encode(e).finish()}_sendRpc(e,t){const r=this.peers.get(e);if(r&&r.isWritable)r.write(this._encodeRpc(t));else{const t=`Cannot send RPC to ${e} as there is no open stream to it available`;this.log.err(t)}}_sendSubscriptions(e,t,r){return this._sendRpc(e,{subscriptions:t.map((e=>({topicID:e,subscribe:r})))})}async validate(e){const t=this.globalSignaturePolicy;switch(t){case f.StrictNoSign:if(e.from)throw s(new Error("StrictNoSigning: from should not be present"),u.ERR_UNEXPECTED_FROM);if(e.signature)throw s(new Error("StrictNoSigning: signature should not be present"),u.ERR_UNEXPECTED_SIGNATURE);if(e.key)throw s(new Error("StrictNoSigning: key should not be present"),u.ERR_UNEXPECTED_KEY);if(e.seqno)throw s(new Error("StrictNoSigning: seqno should not be present"),u.ERR_UNEXPECTED_SEQNO);break;case f.StrictSign:if(!e.signature)throw s(new Error("StrictSigning: Signing required and no signature was present"),u.ERR_MISSING_SIGNATURE);if(!e.seqno)throw s(new Error("StrictSigning: Signing required and no seqno was present"),u.ERR_MISSING_SEQNO);if(!await g(e))throw s(new Error("StrictSigning: Invalid message signature"),u.ERR_INVALID_SIGNATURE);break;default:throw s(new Error("Cannot validate message: unhandled signature policy: "+t),u.ERR_UNHANDLED_SIGNATURE_POLICY)}for(const t of e.topicIDs){const r=this.topicValidators.get(t);r&&await r(t,e)}}_buildMessage(e){const t=this.globalSignaturePolicy;switch(t){case f.StrictSign:return e.from=this.peerId.toB58String(),e.seqno=h.randomSeqno(),p(this.peerId,e);case f.StrictNoSign:return Promise.resolve(e);default:throw s(new Error("Cannot build message: unhandled signature policy: "+t),u.ERR_UNHANDLED_SIGNATURE_POLICY)}}getSubscribers(e){if(!this.started)throw s(new Error("not started yet"),"ERR_NOT_STARTED_YET");if(!e||"string"!=typeof e)throw s(new Error("a string topic must be provided"),"ERR_NOT_VALID_TOPIC");const t=this.topics.get(e);return t?Array.from(t):[]}async publish(e,t){if(!this.started)throw new Error("Pubsub has not started");this.log("publish",e,t);const r={receivedFrom:this.peerId.toB58String(),data:t,topicIDs:[e]},i=await this._buildMessage(r),n=h.normalizeInRpcMessage(i);this.emitSelf&&this._emitMessage(n),await this._publish(n)}_publish(e){throw s(new Error("publish must be implemented by the subclass"),"ERR_NOT_IMPLEMENTED")}subscribe(e){if(!this.started)throw new Error("Pubsub has not started");this.subscriptions.has(e)||(this.subscriptions.add(e),this.peers.forEach(((t,r)=>this._sendSubscriptions(r,[e],!0))))}unsubscribe(e){if(!this.started)throw new Error("Pubsub is not started");this.subscriptions.has(e)&&0===this.listenerCount(e)&&(this.subscriptions.delete(e),this.peers.forEach(((t,r)=>this._sendSubscriptions(r,[e],!1))))}getTopics(){if(!this.started)throw new Error("Pubsub is not started");return Array.from(this.subscriptions)}}y.utils=h,y.SignaturePolicy=f,t.exports=y},{debug:"bO5wM",events:"g82pp","err-code":"chZjB","it-pipe":"giKBQ","p-queue":"biPlv","../topology/multicodec-topology":"52SML","./errors":"i7hyG","./message/rpc":"27BcS","./peer-streams":"l6fHJ","./signature-policy":"dUKk2","./utils":"3CEYj","./message/sign":"2dsDd"}],"52SML":[function(e,t,r){"use strict";const i=e("./index"),n=Symbol.for("@libp2p/js-interfaces/topology/multicodec-topology");class s extends i{constructor({min:e,max:t,multicodecs:r,handlers:i}){if(super({min:e,max:t,handlers:i}),!r)throw new Error("one or more multicodec should be provided");if(!i)throw new Error("the handlers should be provided");if("function"!=typeof i.onConnect)throw new Error("the 'onConnect' handler must be provided");if("function"!=typeof i.onDisconnect)throw new Error("the 'onDisconnect' handler must be provided");this.multicodecs=Array.isArray(r)?r:[r],this._registrar=void 0,this._onProtocolChange=this._onProtocolChange.bind(this),this._onPeerConnect=this._onPeerConnect.bind(this)}get[Symbol.toStringTag](){return"Topology"}get[n](){return!0}static isMulticodecTopology(e){return Boolean(e&&e[n])}set registrar(e){this._registrar=e,this._registrar.peerStore.on("change:protocols",this._onProtocolChange),this._registrar.connectionManager.on("peer:connect",this._onPeerConnect),this._updatePeers(this._registrar.peerStore.peers.values())}_updatePeers(e){for(const{id:t,protocols:r}of e)if(this.multicodecs.filter((e=>r.includes(e))).length){this.peers.add(t.toB58String());const e=this._registrar.getConnection(t);e&&this._onConnect(t,e)}else this.peers.delete(t.toB58String())}_onProtocolChange({peerId:e,protocols:t}){const r=this.peers.has(e.toB58String()),i=t.filter((e=>this.multicodecs.includes(e)));r&&0===i.length&&this._onDisconnect(e);for(const r of t)if(this.multicodecs.includes(r)){const t=this._registrar.peerStore.get(e);return void this._updatePeers([t])}}_onPeerConnect(e){const t=e.remotePeer,r=this._registrar.peerStore.protoBook.get(t);r&&this.multicodecs.find((e=>r.includes(e)))&&(this.peers.add(t.toB58String()),this._onConnect(t,e))}}t.exports=s},{"./index":"6HbOL"}],"6HbOL":[function(e,t,r){"use strict";const i=()=>{},n=Symbol.for("@libp2p/js-interfaces/topology");class s{constructor({min:e=0,max:t=1/0,handlers:r={}}){this.min=e,this.max=t,this._onConnect=r.onConnect||i,this._onDisconnect=r.onDisconnect||i,this.peers=new Set}get[Symbol.toStringTag](){return"Topology"}get[n](){return!0}static isTopology(e){return Boolean(e&&e[n])}set registrar(e){this._registrar=e}disconnect(e){this._onDisconnect(e)}}t.exports=s},{}],i7hyG:[function(e,t,r){"use strict";r.codes={ERR_INVALID_SIGNATURE_POLICY:"ERR_INVALID_SIGNATURE_POLICY",ERR_UNHANDLED_SIGNATURE_POLICY:"ERR_UNHANDLED_SIGNATURE_POLICY",ERR_MISSING_SIGNATURE:"ERR_MISSING_SIGNATURE",ERR_MISSING_SEQNO:"ERR_MISSING_SEQNO",ERR_INVALID_SIGNATURE:"ERR_INVALID_SIGNATURE",ERR_UNEXPECTED_FROM:"ERR_UNEXPECTED_FROM",ERR_UNEXPECTED_SIGNATURE:"ERR_UNEXPECTED_SIGNATURE",ERR_UNEXPECTED_KEY:"ERR_UNEXPECTED_KEY",ERR_UNEXPECTED_SEQNO:"ERR_UNEXPECTED_SEQNO"}},{}],"27BcS":[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-pubsub-rpc"]||(i.roots["libp2p-pubsub-rpc"]={});a.RPC=function(){function e(e){if(this.subscriptions=[],this.msgs=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.subscriptions&&i.subscriptions.length||(i.subscriptions=[]),i.subscriptions.push(a.RPC.SubOpts.decode(e,e.uint32()));break;case 2:i.msgs&&i.msgs.length||(i.msgs=[]),i.msgs.push(a.RPC.Message.decode(e,e.uint32()));break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.RPC)return e;var t=new a.RPC;if(e.subscriptions){if(!Array.isArray(e.subscriptions))throw TypeError(".RPC.subscriptions: array expected");t.subscriptions=[];for(var r=0;r>>3){case 1:i.subscribe=e.bool();break;case 2:i.topicID=e.string();break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.RPC.SubOpts)return e;var t=new a.RPC.SubOpts;return null!=e.subscribe&&(t.subscribe=Boolean(e.subscribe)),null!=e.topicID&&(t.topicID=String(e.topicID)),t},e.toObject=function(e,t){t||(t={});var r={};return null!=e.subscribe&&e.hasOwnProperty("subscribe")&&(r.subscribe=e.subscribe,t.oneofs&&(r._subscribe="subscribe")),null!=e.topicID&&e.hasOwnProperty("topicID")&&(r.topicID=e.topicID,t.oneofs&&(r._topicID="topicID")),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,i.util.toJSONOptions)},e}(),e.Message=function(){function e(e){if(this.topicIDs=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.from=e.bytes();break;case 2:i.data=e.bytes();break;case 3:i.seqno=e.bytes();break;case 4:i.topicIDs&&i.topicIDs.length||(i.topicIDs=[]),i.topicIDs.push(e.string());break;case 5:i.signature=e.bytes();break;case 6:i.key=e.bytes();break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.RPC.Message)return e;var t=new a.RPC.Message;if(null!=e.from&&("string"==typeof e.from?o.base64.decode(e.from,t.from=o.newBuffer(o.base64.length(e.from)),0):e.from.length&&(t.from=e.from)),null!=e.data&&("string"==typeof e.data?o.base64.decode(e.data,t.data=o.newBuffer(o.base64.length(e.data)),0):e.data.length&&(t.data=e.data)),null!=e.seqno&&("string"==typeof e.seqno?o.base64.decode(e.seqno,t.seqno=o.newBuffer(o.base64.length(e.seqno)),0):e.seqno.length&&(t.seqno=e.seqno)),e.topicIDs){if(!Array.isArray(e.topicIDs))throw TypeError(".RPC.Message.topicIDs: array expected");t.topicIDs=[];for(var r=0;r{this._rawOutboundStream&&this._rawOutboundStream.reset&&this._rawOutboundStream.reset(),this._rawOutboundStream=null,this.outboundStream=null,e&&this.emit("close")}}),c(this.outboundStream,o.encode(),this._rawOutboundStream).catch((e=>{n.error(e)})),t||this.emit("stream:outbound")}close(){this.outboundStream&&this.outboundStream.end(),this.inboundStream&&this._inboundAbortController.abort(),this._rawOutboundStream=null,this.outboundStream=null,this._rawInboundStream=null,this.inboundStream=null,this.emit("close")}}},{debug:"bO5wM",events:"g82pp","it-length-prefixed":"3yxIE","it-pushable":"bnpei","it-pipe":"giKBQ","abortable-iterator":"awlU8","abort-controller":"lNJ7z"}],"3yxIE":[function(e,t,r){"use strict";r.encode=e("./encode"),r.decode=e("./decode"),r.varintEncode=e("./varint-encode"),r.varintDecode=e("./varint-decode"),r.int32BEEncode=e("./int32BE-encode"),r.int32BEDecode=e("./int32BE-decode")},{"./encode":"d162i","./decode":"gBAfD","./varint-encode":"c11wj","./varint-decode":"eMugP","./int32BE-encode":"lRnoQ","./int32BE-decode":"aDo5s"}],d162i:[function(e,t,r){"use strict";const{Buffer:i}=e("buffer"),n=e("bl/BufferList"),s=e("./varint-encode");function o(e){e=e||{};const t=Math.max(e.poolSize||10240,e.minPoolSize||8),r=e.lengthEncoder||s;return async function*(e){let s=i.alloc(t),o=0;for await(const a of e){r(a.length,s,o);const e=s.slice(o,o+r.bytes);o+=r.bytes,s.length-o<8&&(s=i.alloc(t),o=0),yield(new n).append(e).append(a)}}}o.single=(e,t)=>{const r=(t=t||{}).lengthEncoder||s;return new n([r(e.length),e.slice()])},t.exports=o,t.exports.MIN_POOL_SIZE=8,t.exports.DEFAULT_POOL_SIZE=10240},{buffer:"etowf","bl/BufferList":"im7j6","./varint-encode":"c11wj"}],c11wj:[function(e,t,r){"use strict";const i=e("varint"),{Buffer:n}=e("buffer"),s=(e,t,r)=>{const o=i.encode(e,t,r);return s.bytes=i.encode.bytes,t||n.from(o)};t.exports=s},{varint:"aN1CO",buffer:"etowf"}],gBAfD:[function(e,t,r){"use strict";const{Buffer:i}=e("buffer"),n=e("bl/BufferList"),s=e("./varint-decode"),o=4194304,a=i.alloc(0),c="readLength",u="readData",l={[c]:(e,t,r,i)=>{let s;t=t.append(e);try{s=i.lengthDecoder(t)}catch(e){if(t.length>i.maxLengthLength)throw Object.assign(e,{message:"message length too long",code:"ERR_MSG_LENGTH_TOO_LONG"});if(e instanceof RangeError)return{mode:c,buffer:t,chunk:void 0,state:void 0,data:void 0};throw e}if(s>i.maxDataLength)throw Object.assign(new Error("message data too long"),{code:"ERR_MSG_DATA_TOO_LONG"});return e=t.shallowSlice(i.lengthDecoder.bytes),t=new n,i.onLength&&i.onLength(s),s<=0?(i.onData&&i.onData(a),{mode:c,chunk:e,buffer:t,data:a}):{mode:u,chunk:e,buffer:t,state:{dataLength:s},data:void 0}},[u]:(e,t,r,i)=>{if(t=t.append(e),!r)throw new Error("state is required");if(t.lengths?t.shallowSlice(s):void 0;return t=new n,i.onData&&i.onData(o),{mode:c,chunk:a,buffer:t,state:void 0,data:o}}};function d(e){const t={lengthDecoder:(e=e||{}).lengthDecoder||s,maxLengthLength:e.maxLengthLength||8,maxDataLength:e.maxDataLength||o,onLength:e.onLength,onData:e.onData};return async function*(e){let r,i=new n,s=c;for await(const n of e){let e=n;for(;e;){const n=l[s](e,i,r,t);s=n.mode,e=n.chunk,i=n.buffer,r=n.state,n.data&&(yield n.data)}}if(i.length)throw Object.assign(new Error("unexpected end of input"),{code:"ERR_UNEXPECTED_EOF"})}}d.fromReader=(e,t)=>{let r=1;const i={[Symbol.asyncIterator](){return this},next:async()=>{try{return await e.next(r)}catch(e){if("ERR_UNDER_READ"===e.code)return{done:!0,value:null};throw e}finally{r=1}}};return d({...t||{},onLength:e=>{r=e}})(i)},t.exports=d,t.exports.MAX_LENGTH_LENGTH=8,t.exports.MAX_DATA_LENGTH=o},{buffer:"etowf","bl/BufferList":"im7j6","./varint-decode":"eMugP"}],eMugP:[function(e,t,r){"use strict";const i=e("varint"),{Buffer:n}=e("buffer"),s=e=>{const t=i.decode(n.isBuffer(e)?e:(r=e,new Proxy({},{get:(e,t)=>"l"===t[0]?r[t]:r.get(parseInt(t))})));var r;return s.bytes=i.decode.bytes,t};t.exports=s},{varint:"aN1CO",buffer:"etowf"}],lRnoQ:[function(e,t,r){"use strict";const{Buffer:i}=e("buffer"),n=(e,t,r)=>((t=t||i.allocUnsafe(4)).writeInt32BE(e,r),t);n.bytes=4,t.exports=n},{buffer:"etowf"}],aDo5s:[function(e,t,r){"use strict";const i=e=>{if(e.length<4)throw RangeError("Could not decode int32BE");return e.readInt32BE(0)};i.bytes=4,t.exports=i},{}],awlU8:[function(e,t,r){const i=e("get-iterator"),n=e("./AbortError"),s=(e,t,r)=>o(e,Array.isArray(t)?t:[{signal:t,options:r}]),o=(e,t)=>(e=i(e),t=t.map((({signal:e,options:t})=>({signal:e,options:t||{}}))),async function*(){let r;const i=()=>{r&&r()};for(const{signal:e}of t)e.addEventListener("abort",i);for(;;){let s;try{for(const{signal:e,options:r}of t)if(e.aborted){const{abortMessage:e,abortCode:t}=r;throw new n(e,t)}const i=new Promise(((e,i)=>{r=()=>{const{options:e}=t.find((({signal:e})=>e.aborted)),{abortMessage:r,abortCode:s}=e;i(new n(r,s))}}));s=await Promise.race([i,e.next()]),r=null}catch(r){for(const{signal:e}of t)e.removeEventListener("abort",i);const n=t.find((({signal:e})=>e.aborted)),s="aborted"===r.type&&n;if(s&&n.options.onAbort&&await n.options.onAbort(e),"function"==typeof e.return&&await e.return(),s&&n.options.returnOnAbort)return;throw r}if(s.done)break;yield s.value}for(const{signal:e}of t)e.removeEventListener("abort",i)}()),a=(e,t,r)=>c(e,Array.isArray(t)?t:[{signal:t,options:r}]),c=(e,t)=>r=>e(o(r,t)),u=(e,t)=>({sink:c(e.sink,t),source:o(e.source,t)});t.exports=s,t.exports.AbortError=n,t.exports.source=s,t.exports.sink=a,t.exports.transform=a,t.exports.duplex=(e,t,r)=>u(e,Array.isArray(t)?t:[{signal:t,options:r}])},{"get-iterator":"li8y1","./AbortError":"daAph"}],li8y1:[function(e,t,r){t.exports=function(e){if(e){if("function"==typeof e[Symbol.iterator])return e[Symbol.iterator]();if("function"==typeof e[Symbol.asyncIterator])return e[Symbol.asyncIterator]();if("function"==typeof e.next)return e}throw new Error("argument is not an iterator or iterable")}},{}],daAph:[function(e,t,r){t.exports=class extends Error{constructor(e,t){super(e||"The operation was aborted"),this.type="aborted",this.code=t||"ABORT_ERR"}}},{}],dUKk2:[function(e,t,r){"use strict";r.SignaturePolicy={StrictSign:"StrictSign",StrictNoSign:"StrictNoSign"}},{}],"3CEYj":[function(e,t,r){"use strict";const i=e("libp2p-crypto/src/random-bytes"),{toString:n}=e("uint8arrays/to-string"),{fromString:s}=e("uint8arrays/from-string"),o=e("peer-id"),{sha256:a}=e("multiformats/hashes/sha2");t.exports={randomSeqno:()=>i(8),msgId:(e,t)=>{let r;r=e instanceof Uint8Array?o.createFromBytes(e).id:o.parse(e).id;const i=new Uint8Array(r.length+t.length);return i.set(r,0),i.set(t,r.length),i},noSignMsgId:e=>a.encode(e),anyMatch:(e,t)=>{let r;r=Array.isArray(t)?e=>t.indexOf(e)>-1:e=>t.has(e);for(const t of e)if(r(t))return!0;return!1},ensureArray:e=>Array.isArray(e)?e:[e],normalizeInRpcMessage:(e,t)=>{const r=Object.assign({},e);return e.from instanceof Uint8Array&&(r.from=n(e.from,"base58btc")),t&&(r.receivedFrom=t),r},normalizeOutRpcMessage:e=>{const t=Object.assign({},e);return"string"==typeof e.from&&(t.from=s(e.from,"base58btc")),"string"==typeof e.data&&(t.data=s(e.data)),t}}},{"libp2p-crypto/src/random-bytes":"gsnuW","uint8arrays/to-string":"hC8JB","uint8arrays/from-string":"dF7Y4","peer-id":"8Bdb3","multiformats/hashes/sha2":"7i9MT"}],"2dsDd":[function(e,t,r){"use strict";const i=e("peer-id"),{RPC:n}=e("./rpc"),{concat:s}=e("uint8arrays/concat"),{fromString:o}=e("uint8arrays/from-string"),a=o("libp2p-pubsub:"),{normalizeOutRpcMessage:c}=e("../utils");async function u(e){if(!e.from)throw new Error("Could not get the public key from the originator id");const t=i.createFromB58String(e.from);if(e.key){const r=await i.createFromPubKey(e.key);if(r.equals(t))return r.pubKey;throw new Error("Public Key does not match the originator")}if(t.pubKey)return t.pubKey;throw new Error("Could not get the public key from the originator id")}t.exports={messagePublicKey:u,signMessage:async function(e,t){const r=s([a,n.Message.encode(c(t)).finish()]),i=await e.privKey.sign(r);return{...t,signature:i,key:e.pubKey.bytes}},SignPrefix:a,verifySignature:async function(e){if(!e.signature)throw new Error("Message must contain a signature to be verified");if(!e.from)throw new Error("Message must contain a from property to be verified");const t=s([a,n.Message.encode({...e,from:i.createFromB58String(e.from).toBytes(),signature:void 0,key:void 0}).finish()]);return(await u(e)).verify(t,e.signature)}}},{"peer-id":"8Bdb3","./rpc":"27BcS","uint8arrays/concat":"4EBjG","uint8arrays/from-string":"dF7Y4","../utils":"3CEYj"}],gJumF:[function(e,t,r){"use strict";var i=this&&this.__awaiter||function(e,t,r,i){return new(r||(r=Promise))((function(n,s){function o(e){try{c(i.next(e))}catch(e){s(e)}}function a(e){try{c(i.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?n(e.value):(t=e.value,t instanceof r?t:new r((function(e){e(t)}))).then(o,a)}c((i=i.apply(e,t||[])).next())}))};Object.defineProperty(r,"__esModule",{value:!0}),r.MessageCache=void 0;const n=e("./utils");r.MessageCache=class{constructor(e,t,r){this.msgs=new Map,this.peertx=new Map,this.history=[];for(let e=0;e{for(const i of r.topics)if(i===e){t.push(r.msgID);break}}));return t}shift(){this.history[this.history.length-1].forEach((e=>{const t=n.messageIdToString(e.msgID);this.msgs.delete(t),this.peertx.delete(t)})),this.history.pop(),this.history.unshift([])}}},{"./utils":"8kUZs"}],"8kUZs":[function(e,t,r){"use strict";var i=this&&this.__createBinding||(Object.create?function(e,t,r,i){void 0===i&&(i=r),Object.defineProperty(e,i,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,i){void 0===i&&(i=r),e[i]=t[r]}),n=this&&this.__exportStar||function(e,t){for(var r in e)"default"===r||Object.prototype.hasOwnProperty.call(t,r)||i(t,e,r)};Object.defineProperty(r,"__esModule",{value:!0}),n(e("./create-gossip-rpc"),r),n(e("./shuffle"),r),n(e("./has-gossip-protocol"),r),n(e("./messageIdToString"),r)},{"./create-gossip-rpc":"8OYkT","./shuffle":"e1hER","./has-gossip-protocol":"l4KwQ","./messageIdToString":"8V5xp"}],"8OYkT":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.createGossipRpc=void 0,r.createGossipRpc=function(e=[],t={}){return{subscriptions:[],msgs:e,control:Object.assign({ihave:[],iwant:[],graft:[],prune:[]},t)}}},{}],e1hER:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.shuffle=void 0,r.shuffle=function(e){if(e.length<=1)return e;for(let t=0;t>>3){case 1:s.subscriptions&&s.subscriptions.length||(s.subscriptions=[]),s.subscriptions.push(n.RPC.SubOpts.decode(e,e.uint32()));break;case 2:s.msgs&&s.msgs.length||(s.msgs=[]),s.msgs.push(n.RPC.Message.decode(e,e.uint32()));break;case 3:s.control=n.RPC.ControlMessage.decode(e,e.uint32());break;default:e.skipType(7&o)}}return s},s.fromObject=function(e){if(e instanceof n.RPC)return e;var t=new n.RPC;if(e.subscriptions){if(!Array.isArray(e.subscriptions))throw TypeError(".RPC.subscriptions: array expected");t.subscriptions=[];for(var r=0;r>>3){case 1:s.subscribe=e.bool();break;case 2:s.topicID=e.string();break;default:e.skipType(7&o)}}return s},s.fromObject=function(e){if(e instanceof n.RPC.SubOpts)return e;var t=new n.RPC.SubOpts;return null!=e.subscribe&&(t.subscribe=Boolean(e.subscribe)),null!=e.topicID&&(t.topicID=String(e.topicID)),t},s.toObject=function(e,t){t||(t={});var r={};return null!=e.subscribe&&e.hasOwnProperty("subscribe")&&(r.subscribe=e.subscribe,t.oneofs&&(r._subscribe="subscribe")),null!=e.topicID&&e.hasOwnProperty("topicID")&&(r.topicID=e.topicID,t.oneofs&&(r._topicID="topicID")),r},s.prototype.toJSON=function(){return this.constructor.toObject(this,e.util.toJSONOptions)},s}(),s.Message=function(){function s(e){if(this.topicIDs=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:s.from=e.bytes();break;case 2:s.data=e.bytes();break;case 3:s.seqno=e.bytes();break;case 4:s.topicIDs&&s.topicIDs.length||(s.topicIDs=[]),s.topicIDs.push(e.string());break;case 5:s.signature=e.bytes();break;case 6:s.key=e.bytes();break;default:e.skipType(7&o)}}return s},s.fromObject=function(e){if(e instanceof n.RPC.Message)return e;var t=new n.RPC.Message;if(null!=e.from&&("string"==typeof e.from?i.base64.decode(e.from,t.from=i.newBuffer(i.base64.length(e.from)),0):e.from.length&&(t.from=e.from)),null!=e.data&&("string"==typeof e.data?i.base64.decode(e.data,t.data=i.newBuffer(i.base64.length(e.data)),0):e.data.length&&(t.data=e.data)),null!=e.seqno&&("string"==typeof e.seqno?i.base64.decode(e.seqno,t.seqno=i.newBuffer(i.base64.length(e.seqno)),0):e.seqno.length&&(t.seqno=e.seqno)),e.topicIDs){if(!Array.isArray(e.topicIDs))throw TypeError(".RPC.Message.topicIDs: array expected");t.topicIDs=[];for(var r=0;r>>3){case 1:s.ihave&&s.ihave.length||(s.ihave=[]),s.ihave.push(n.RPC.ControlIHave.decode(e,e.uint32()));break;case 2:s.iwant&&s.iwant.length||(s.iwant=[]),s.iwant.push(n.RPC.ControlIWant.decode(e,e.uint32()));break;case 3:s.graft&&s.graft.length||(s.graft=[]),s.graft.push(n.RPC.ControlGraft.decode(e,e.uint32()));break;case 4:s.prune&&s.prune.length||(s.prune=[]),s.prune.push(n.RPC.ControlPrune.decode(e,e.uint32()));break;default:e.skipType(7&o)}}return s},s.fromObject=function(e){if(e instanceof n.RPC.ControlMessage)return e;var t=new n.RPC.ControlMessage;if(e.ihave){if(!Array.isArray(e.ihave))throw TypeError(".RPC.ControlMessage.ihave: array expected");t.ihave=[];for(var r=0;r>>3){case 1:s.topicID=e.string();break;case 2:s.messageIDs&&s.messageIDs.length||(s.messageIDs=[]),s.messageIDs.push(e.bytes());break;default:e.skipType(7&o)}}return s},s.fromObject=function(e){if(e instanceof n.RPC.ControlIHave)return e;var t=new n.RPC.ControlIHave;if(null!=e.topicID&&(t.topicID=String(e.topicID)),e.messageIDs){if(!Array.isArray(e.messageIDs))throw TypeError(".RPC.ControlIHave.messageIDs: array expected");t.messageIDs=[];for(var r=0;r>>3==1?(s.messageIDs&&s.messageIDs.length||(s.messageIDs=[]),s.messageIDs.push(e.bytes())):e.skipType(7&o)}return s},s.fromObject=function(e){if(e instanceof n.RPC.ControlIWant)return e;var t=new n.RPC.ControlIWant;if(e.messageIDs){if(!Array.isArray(e.messageIDs))throw TypeError(".RPC.ControlIWant.messageIDs: array expected");t.messageIDs=[];for(var r=0;r>>3==1?s.topicID=e.string():e.skipType(7&o)}return s},s.fromObject=function(e){if(e instanceof n.RPC.ControlGraft)return e;var t=new n.RPC.ControlGraft;return null!=e.topicID&&(t.topicID=String(e.topicID)),t},s.toObject=function(e,t){t||(t={});var r={};return null!=e.topicID&&e.hasOwnProperty("topicID")&&(r.topicID=e.topicID,t.oneofs&&(r._topicID="topicID")),r},s.prototype.toJSON=function(){return this.constructor.toObject(this,e.util.toJSONOptions)},s}(),s.ControlPrune=function(){function s(e){if(this.peers=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:s.topicID=e.string();break;case 2:s.peers&&s.peers.length||(s.peers=[]),s.peers.push(n.RPC.PeerInfo.decode(e,e.uint32()));break;case 3:s.backoff=e.uint64();break;default:e.skipType(7&o)}}return s},s.fromObject=function(e){if(e instanceof n.RPC.ControlPrune)return e;var t=new n.RPC.ControlPrune;if(null!=e.topicID&&(t.topicID=String(e.topicID)),e.peers){if(!Array.isArray(e.peers))throw TypeError(".RPC.ControlPrune.peers: array expected");t.peers=[];for(var r=0;r>>0,e.backoff.high>>>0).toNumber(!0))),t},s.toObject=function(e,t){t||(t={});var r={};if((t.arrays||t.defaults)&&(r.peers=[]),null!=e.topicID&&e.hasOwnProperty("topicID")&&(r.topicID=e.topicID,t.oneofs&&(r._topicID="topicID")),e.peers&&e.peers.length){r.peers=[];for(var s=0;s>>0,e.backoff.high>>>0).toNumber(!0):e.backoff,t.oneofs&&(r._backoff="backoff")),r},s.prototype.toJSON=function(){return this.constructor.toObject(this,e.util.toJSONOptions)},s}(),s.PeerInfo=function(){function s(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:s.peerID=e.bytes();break;case 2:s.signedPeerRecord=e.bytes();break;default:e.skipType(7&o)}}return s},s.fromObject=function(e){if(e instanceof n.RPC.PeerInfo)return e;var t=new n.RPC.PeerInfo;return null!=e.peerID&&("string"==typeof e.peerID?i.base64.decode(e.peerID,t.peerID=i.newBuffer(i.base64.length(e.peerID)),0):e.peerID.length&&(t.peerID=e.peerID)),null!=e.signedPeerRecord&&("string"==typeof e.signedPeerRecord?i.base64.decode(e.signedPeerRecord,t.signedPeerRecord=i.newBuffer(i.base64.length(e.signedPeerRecord)),0):e.signedPeerRecord.length&&(t.signedPeerRecord=e.signedPeerRecord)),t},s.toObject=function(e,t){t||(t={});var r={};return null!=e.peerID&&e.hasOwnProperty("peerID")&&(r.peerID=t.bytes===String?i.base64.encode(e.peerID,0,e.peerID.length):t.bytes===Array?Array.prototype.slice.call(e.peerID):e.peerID,t.oneofs&&(r._peerID="peerID")),null!=e.signedPeerRecord&&e.hasOwnProperty("signedPeerRecord")&&(r.signedPeerRecord=t.bytes===String?i.base64.encode(e.signedPeerRecord,0,e.signedPeerRecord.length):t.bytes===Array?Array.prototype.slice.call(e.signedPeerRecord):e.signedPeerRecord,t.oneofs&&(r._signedPeerRecord="signedPeerRecord")),r},s.prototype.toJSON=function(){return this.constructor.toObject(this,e.util.toJSONOptions)},s}(),s}(),n},"function"==typeof define&&define.amd?define(["protobufjs/minimal"],i):"function"==typeof e&&"object"==typeof t&&t&&t.exports&&(t.exports=i(e("protobufjs/minimal")))},{"protobufjs/minimal":"grAXL"}],l9R1d:[function(e,t,r){"use strict";var i=this&&this.__createBinding||(Object.create?function(e,t,r,i){void 0===i&&(i=r),Object.defineProperty(e,i,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,i){void 0===i&&(i=r),e[i]=t[r]}),n=this&&this.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),s=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var r in e)"default"!==r&&Object.prototype.hasOwnProperty.call(e,r)&&i(t,e,r);return n(t,e),t};Object.defineProperty(r,"__esModule",{value:!0}),r.Heartbeat=void 0;const o=s(e("./constants")),a=e("./get-gossip-peers"),c=e("./utils");r.Heartbeat=class{constructor(e){this.gossipsub=e}start(){if(this._heartbeatTimer)return;const e=this._heartbeat.bind(this),t=setTimeout((()=>{e(),this._heartbeatTimer.runPeriodically(e,this.gossipsub._options.heartbeatInterval)}),o.GossipsubHeartbeatInitialDelay);this._heartbeatTimer={_intervalId:void 0,runPeriodically:(e,t)=>{this._heartbeatTimer._intervalId=setInterval(e,t)},cancel:()=>{clearTimeout(t),clearInterval(this._heartbeatTimer._intervalId)}}}stop(){this._heartbeatTimer&&(this._heartbeatTimer.cancel(),this._heartbeatTimer=null)}_heartbeat(){const{D:e,Dlo:t,Dhi:r,Dscore:i,Dout:n,fanoutTTL:s}=this.gossipsub._options;this.gossipsub.heartbeatTicks++;const u=new Map,l=e=>{let t=u.get(e);return void 0===t&&(t=this.gossipsub.score.score(e),u.set(e,t)),t},d=new Map,f=new Map,h=new Map;this.gossipsub._clearBackoff(),this.gossipsub.peerhave.clear(),this.gossipsub.iasked.clear(),this.gossipsub._applyIwantPenalties(),this.gossipsub._directConnect(),this.gossipsub.mesh.forEach(((s,u)=>{const p=e=>{this.gossipsub.log("HEARTBEAT: Remove mesh link to %s in %s",e,u),this.gossipsub.score.prune(e,u),this.gossipsub._addBackoff(e,u),s.delete(e);const t=f.get(e);t?t.push(u):f.set(e,[u])},g=e=>{this.gossipsub.log("HEARTBEAT: Add mesh link to %s in %s",e,u),this.gossipsub.score.graft(e,u),s.add(e);const t=d.get(e);t?t.push(u):d.set(e,[u])};if(s.forEach((e=>{const t=l(e);t<0&&(this.gossipsub.log("HEARTBEAT: Prune peer %s with negative score: score=%d, topic=%s",e,t,u),p(e),h.set(e,!0))})),s.size!s.has(e)&&!this.gossipsub.direct.has(e)&&(!t||!t.has(e))&&l(e)>=0)).forEach(g)}if(s.size>r){let t=Array.from(s);t.sort(((e,t)=>l(t)-l(e))),t=t.slice(0,i).concat(c.shuffle(t.slice(i)));let r=0;if(t.slice(0,e).forEach((e=>{this.gossipsub.outbound.get(e)&&r++})),r{const r=t[e];for(let r=e;r>0;r--)t[r]=t[r-1];t[0]=r};if(r>0){let n=r;for(let r=1;r0;r++)this.gossipsub.outbound.get(t[r])&&(i(r),n--)}let n=e-r;for(let r=e;r0;r++)this.gossipsub.outbound.get(t[r])&&(i(r),n--)}t.slice(e).forEach(p)}if(s.size>=t){let e=0;if(s.forEach((t=>{this.gossipsub.outbound.get(t)&&e++})),e!s.has(e)&&!this.gossipsub.direct.has(e)&&(!r||!r.has(e))&&l(e)>=0)).forEach(g)}}if(this.gossipsub.heartbeatTicks%o.GossipsubOpportunisticGraftTicks==0&&s.size>1){const e=Array.from(s).sort(((e,t)=>l(e)-l(t))),t=Math.floor(s.size/2),r=l(e[t]);if(rs.has(t)&&!this.gossipsub.direct.has(t)&&(!e||!e.has(t))&&l(t)>r)).forEach((e=>{this.gossipsub.log("HEARTBEAT: Opportunistically graft peer %s on topic %s",e,u),g(e)}))}}this.gossipsub._emitGossip(u,s)}));const p=this.gossipsub._now();this.gossipsub.lastpub.forEach(((e,t)=>{e+s{const i=this.gossipsub.topics.get(r);if(t.forEach((e=>{(!i.has(e)||l(e)!t.has(e)&&!this.gossipsub.direct.has(e)&&l(e)>=this.gossipsub._options.scoreThresholds.publishThreshold)).forEach((e=>{t.add(e)}))}this.gossipsub._emitGossip(r,t)})),this.gossipsub._sendGraftPrune(d,f,h),this.gossipsub._flush(),this.gossipsub.messageCache.shift(),this.gossipsub.emit("gossipsub:heartbeat")}}},{"./constants":"kx67k","./get-gossip-peers":"jYUGm","./utils":"8kUZs"}],jYUGm:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.getGossipPeers=void 0;const i=e("./utils");r.getGossipPeers=function(e,t,r,n=(()=>!0)){const s=e.topics.get(t);if(!s)return new Set;let o=[];return s.forEach((t=>{const r=e.peers.get(t);r&&i.hasGossipProtocol(r.protocol)&&n(t)&&o.push(t)})),o=i.shuffle(o),r>0&&o.length>r&&(o=o.slice(0,r)),new Set(o)}},{"./utils":"8kUZs"}],"8Uy6q":[function(e,t,r){"use strict";var i=this&&this.__createBinding||(Object.create?function(e,t,r,i){void 0===i&&(i=r),Object.defineProperty(e,i,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,i){void 0===i&&(i=r),e[i]=t[r]}),n=this&&this.__exportStar||function(e,t){for(var r in e)"default"===r||Object.prototype.hasOwnProperty.call(t,r)||i(t,e,r)};Object.defineProperty(r,"__esModule",{value:!0}),n(e("./peer-score-params"),r),n(e("./peer-score-thresholds"),r),n(e("./peer-score"),r)},{"./peer-score-params":"lHcoR","./peer-score-thresholds":"kpAfK","./peer-score":"2EtC2"}],lHcoR:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.validateTopicScoreParams=r.validatePeerScoreParams=r.createTopicScoreParams=r.createPeerScoreParams=r.defaultTopicScoreParams=r.defaultPeerScoreParams=void 0;const i=e("./constants"),n=e("err-code");function s(e={}){return Object.assign(Object.assign({},r.defaultTopicScoreParams),e)}function o(e){if(e.topicWeight<0)throw n(new Error("invalid topic weight; must be >= 0"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0===e.timeInMeshQuantum)throw n(new Error("invalid TimeInMeshQuantum; must be non zero"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.timeInMeshWeight<0)throw n(new Error("invalid TimeInMeshWeight; must be positive (or 0 to disable)"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.timeInMeshWeight&&e.timeInMeshQuantum<=0)throw n(new Error("invalid TimeInMeshQuantum; must be positive"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.timeInMeshWeight&&e.timeInMeshCap<=0)throw n(new Error("invalid TimeInMeshCap; must be positive"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.firstMessageDeliveriesWeight<0)throw n(new Error("invallid FirstMessageDeliveriesWeight; must be positive (or 0 to disable)"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.firstMessageDeliveriesWeight&&(e.firstMessageDeliveriesDecay<=0||e.firstMessageDeliveriesDecay>=1))throw n(new Error("invalid FirstMessageDeliveriesDecay; must be between 0 and 1"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.firstMessageDeliveriesWeight&&e.firstMessageDeliveriesCap<=0)throw n(new Error("invalid FirstMessageDeliveriesCap; must be positive"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.meshMessageDeliveriesWeight>0)throw n(new Error("invalid MeshMessageDeliveriesWeight; must be negative (or 0 to disable)"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.meshMessageDeliveriesWeight&&(e.meshMessageDeliveriesDecay<=0||e.meshMessageDeliveriesDecay>=1))throw n(new Error("invalid MeshMessageDeliveriesDecay; must be between 0 and 1"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.meshMessageDeliveriesWeight&&e.meshMessageDeliveriesCap<=0)throw n(new Error("invalid MeshMessageDeliveriesCap; must be positive"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.meshMessageDeliveriesWeight&&e.meshMessageDeliveriesThreshold<=0)throw n(new Error("invalid MeshMessageDeliveriesThreshold; must be positive"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.meshMessageDeliveriesWindow<0)throw n(new Error("invalid MeshMessageDeliveriesWindow; must be non-negative"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.meshMessageDeliveriesWeight&&e.meshMessageDeliveriesActivation<1e3)throw n(new Error("invalid MeshMessageDeliveriesActivation; must be at least 1s"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.meshFailurePenaltyWeight>0)throw n(new Error("invalid MeshFailurePenaltyWeight; must be negative (or 0 to disable)"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.meshFailurePenaltyWeight&&(e.meshFailurePenaltyDecay<=0||e.meshFailurePenaltyDecay>=1))throw n(new Error("invalid MeshFailurePenaltyDecay; must be between 0 and 1"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.invalidMessageDeliveriesWeight>0)throw n(new Error("invalid InvalidMessageDeliveriesWeight; must be negative (or 0 to disable)"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.invalidMessageDeliveriesDecay<=0||e.invalidMessageDeliveriesDecay>=1)throw n(new Error("invalid InvalidMessageDeliveriesDecay; must be between 0 and 1"),i.ERR_INVALID_PEER_SCORE_PARAMS)}r.defaultPeerScoreParams={topics:{},topicScoreCap:10,appSpecificScore:()=>0,appSpecificWeight:10,IPColocationFactorWeight:-5,IPColocationFactorThreshold:10,IPColocationFactorWhitelist:new Set,behaviourPenaltyWeight:-10,behaviourPenaltyDecay:.2,decayInterval:1e3,decayToZero:.1,retainScore:36e5},r.defaultTopicScoreParams={topicWeight:.5,timeInMeshWeight:1,timeInMeshQuantum:1,timeInMeshCap:3600,firstMessageDeliveriesWeight:1,firstMessageDeliveriesDecay:.5,firstMessageDeliveriesCap:2e3,meshMessageDeliveriesWeight:-1,meshMessageDeliveriesDecay:.5,meshMessageDeliveriesCap:100,meshMessageDeliveriesThreshold:20,meshMessageDeliveriesWindow:10,meshMessageDeliveriesActivation:5e3,meshFailurePenaltyWeight:-1,meshFailurePenaltyDecay:.5,invalidMessageDeliveriesWeight:-1,invalidMessageDeliveriesDecay:.3},r.createPeerScoreParams=function(e={}){return Object.assign(Object.assign(Object.assign({},r.defaultPeerScoreParams),e),{topics:e.topics?Object.entries(e.topics).reduce(((e,[t,r])=>(e[t]=s(r),e)),{}):{}})},r.createTopicScoreParams=s,r.validatePeerScoreParams=function(e){for(const[t,r]of Object.entries(e.topics))try{o(r)}catch(e){throw n(new Error(`invalid score parameters for topic ${t}: ${e.message}`),i.ERR_INVALID_PEER_SCORE_PARAMS)}if(e.topicScoreCap<0)throw n(new Error("invalid topic score cap; must be positive (or 0 for no cap)"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(null===e.appSpecificScore||void 0===e.appSpecificScore)throw n(new Error("missing application specific score function"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.IPColocationFactorWeight>0)throw n(new Error("invalid IPColocationFactorWeight; must be negative (or 0 to disable)"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.IPColocationFactorWeight&&e.IPColocationFactorThreshold<1)throw n(new Error("invalid IPColocationFactorThreshold; must be at least 1"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.behaviourPenaltyWeight>0)throw n(new Error("invalid BehaviourPenaltyWeight; must be negative (or 0 to disable)"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(0!==e.behaviourPenaltyWeight&&(e.behaviourPenaltyDecay<=0||e.behaviourPenaltyDecay>=1))throw n(new Error("invalid BehaviourPenaltyDecay; must be between 0 and 1"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.decayInterval<1e3)throw n(new Error("invalid DecayInterval; must be at least 1s"),i.ERR_INVALID_PEER_SCORE_PARAMS);if(e.decayToZero<=0||e.decayToZero>=1)throw n(new Error("invalid DecayToZero; must be between 0 and 1"),i.ERR_INVALID_PEER_SCORE_PARAMS)},r.validateTopicScoreParams=o},{"./constants":"eJAl3","err-code":"chZjB"}],eJAl3:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.ERR_INVALID_PEER_SCORE_THRESHOLDS=r.ERR_INVALID_PEER_SCORE_PARAMS=void 0,r.ERR_INVALID_PEER_SCORE_PARAMS="ERR_INVALID_PEER_SCORE_PARAMS",r.ERR_INVALID_PEER_SCORE_THRESHOLDS="ERR_INVALID_PEER_SCORE_THRESHOLDS"},{}],kpAfK:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.validatePeerScoreThresholds=r.createPeerScoreThresholds=r.defaultPeerScoreThresholds=void 0;const i=e("./constants"),n=e("err-code");r.defaultPeerScoreThresholds={gossipThreshold:-10,publishThreshold:-50,graylistThreshold:-80,acceptPXThreshold:10,opportunisticGraftThreshold:20},r.createPeerScoreThresholds=function(e={}){return Object.assign(Object.assign({},r.defaultPeerScoreThresholds),e)},r.validatePeerScoreThresholds=function(e){if(e.gossipThreshold>0)throw n(new Error("invalid gossip threshold; it must be <= 0"),i.ERR_INVALID_PEER_SCORE_THRESHOLDS);if(e.publishThreshold>0||e.publishThreshold>e.gossipThreshold)throw n(new Error("invalid publish threshold; it must be <= 0 and <= gossip threshold"),i.ERR_INVALID_PEER_SCORE_THRESHOLDS);if(e.graylistThreshold>0||e.graylistThreshold>e.publishThreshold)throw n(new Error("invalid graylist threshold; it must be <= 0 and <= publish threshold"),i.ERR_INVALID_PEER_SCORE_THRESHOLDS);if(e.acceptPXThreshold<0)throw n(new Error("invalid accept PX threshold; it must be >= 0"),i.ERR_INVALID_PEER_SCORE_THRESHOLDS);if(e.opportunisticGraftThreshold<0)throw n(new Error("invalid opportunistic grafting threshold; it must be >= 0"),i.ERR_INVALID_PEER_SCORE_THRESHOLDS)}},{"./constants":"eJAl3","err-code":"chZjB"}],"2EtC2":[function(e,t,r){"use strict";var i=this&&this.__awaiter||function(e,t,r,i){return new(r||(r=Promise))((function(n,s){function o(e){try{c(i.next(e))}catch(e){s(e)}}function a(e){try{c(i.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?n(e.value):(t=e.value,t instanceof r?t:new r((function(e){e(t)}))).then(o,a)}c((i=i.apply(e,t||[])).next())}))},n=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(r,"__esModule",{value:!0}),r.PeerScore=void 0;const s=e("./peer-score-params"),o=e("./peer-stats"),a=e("./compute-score"),c=e("./message-deliveries"),u=e("../constants"),l=n(e("peer-id")),d=e("debug"),f=e("libp2p-interfaces/src/pubsub/errors"),{ERR_INVALID_SIGNATURE:h,ERR_MISSING_SIGNATURE:p}=f.codes,g=d("libp2p:gossipsub:score");r.PeerScore=class{constructor(e,t,r){s.validatePeerScoreParams(e),this.params=e,this._connectionManager=t,this.peerStats=new Map,this.peerIPs=new Map,this.deliveryRecords=new c.MessageDeliveries,this.msgId=r}start(){this._backgroundInterval?g("Peer score already running"):(this._backgroundInterval=setInterval((()=>this.background()),this.params.decayInterval),g("started"))}stop(){this._backgroundInterval?(clearInterval(this._backgroundInterval),delete this._backgroundInterval,this.peerIPs.clear(),this.peerStats.clear(),this.deliveryRecords.clear(),g("stopped")):g("Peer score already stopped")}background(){this._refreshScores(),this._updateIPs(),this.deliveryRecords.gc()}_refreshScores(){const e=Date.now(),t=this.params.decayToZero;this.peerStats.forEach(((r,i)=>{r.connected?(Object.entries(r.topics).forEach((([r,i])=>{const n=this.params.topics[r];n&&(i.firstMessageDeliveries*=n.firstMessageDeliveriesDecay,i.firstMessageDeliveriesn.meshMessageDeliveriesActivation&&(i.meshMessageDeliveriesActive=!0)))})),r.behaviourPenalty*=this.params.behaviourPenaltyDecay,r.behaviourPenaltyr.expire&&(this._removeIPs(i,r.ips),this.peerStats.delete(i))}))}score(e){const t=this.peerStats.get(e);return t?a.computeScore(e,t,this.params,this.peerIPs):0}addPenalty(e,t){const r=this.peerStats.get(e);r&&(r.behaviourPenalty+=t)}addPeer(e){const t=o.createPeerStats({connected:!0});this.peerStats.set(e,t);const r=this._getIPs(e);this._setIPs(e,r,t.ips),t.ips=r}removePeer(e){const t=this.peerStats.get(e);if(t){if(this.score(e)>0)return this._removeIPs(e,t.ips),void this.peerStats.delete(e);Object.entries(t.topics).forEach((([e,t])=>{t.firstMessageDeliveries=0;const r=this.params.topics[e].meshMessageDeliveriesThreshold;if(t.inMesh&&t.meshMessageDeliveriesActive&&t.meshMessageDeliveries{r!==t&&this._markDuplicateMessageDelivery(r,e)}))):g("unexpected delivery: message from %s was first seen %s ago and has delivery status %d",t,i-r.firstSeen,c.DeliveryRecordStatus[r.status])}))}rejectMessage(e,t){return i(this,void 0,void 0,(function*(){const r=e.receivedFrom;switch(t){case p:case h:return void this._markInvalidMessageDelivery(r,e)}const i=this.deliveryRecords.ensureRecord(yield this.msgId(e));i.status===c.DeliveryRecordStatus.unknown?t!==u.ERR_TOPIC_VALIDATOR_IGNORE?(i.status=c.DeliveryRecordStatus.invalid,this._markInvalidMessageDelivery(r,e),i.peers.forEach((t=>{this._markInvalidMessageDelivery(t,e)}))):i.status=c.DeliveryRecordStatus.ignored:g("unexpected rejection: message from %s was first seen %s ago and has delivery status %d",r,Date.now()-i.firstSeen,c.DeliveryRecordStatus[i.status])}))}duplicateMessage(e){return i(this,void 0,void 0,(function*(){const t=e.receivedFrom,r=this.deliveryRecords.ensureRecord(yield this.msgId(e));if(!r.peers.has(t))switch(r.status){case c.DeliveryRecordStatus.unknown:r.peers.add(t);break;case c.DeliveryRecordStatus.valid:r.peers.add(t),this._markDuplicateMessageDelivery(t,e,r.validated);break;case c.DeliveryRecordStatus.invalid:this._markInvalidMessageDelivery(t,e)}}))}_markInvalidMessageDelivery(e,t){const r=this.peerStats.get(e);r&&t.topicIDs.forEach((e=>{const t=o.ensureTopicStats(e,r,this.params);t&&(t.invalidMessageDeliveries+=1)}))}_markFirstMessageDelivery(e,t){const r=this.peerStats.get(e);r&&t.topicIDs.forEach((e=>{const t=o.ensureTopicStats(e,r,this.params);if(!t)return;let i=this.params.topics[e].firstMessageDeliveriesCap;t.firstMessageDeliveries+=1,t.firstMessageDeliveries>i&&(t.firstMessageDeliveries=i),t.inMesh&&(i=this.params.topics[e].meshMessageDeliveriesCap,t.meshMessageDeliveries+=1,t.meshMessageDeliveries>i&&(t.meshMessageDeliveries=i))}))}_markDuplicateMessageDelivery(e,t,r=0){const i=this.peerStats.get(e);if(!i)return;const n=r?Date.now():0;t.topicIDs.forEach((e=>{const t=o.ensureTopicStats(e,i,this.params);if(!t)return;if(!t.inMesh)return;const s=this.params.topics[e];if(r&&n>r+s.meshMessageDeliveriesWindow)return;const a=s.meshMessageDeliveriesCap;t.meshMessageDeliveries+=1,t.meshMessageDeliveries>a&&(t.meshMessageDeliveries=a)}))}_getIPs(e){return this._connectionManager.getAll(l.default.createFromB58String(e)).map((e=>e.remoteAddr.toOptions().host))}_setIPs(e,t,r){e:for(const i of t){for(const e of r)if(i===e)continue e;let t=this.peerIPs.get(i);t||(t=new Set,this.peerIPs.set(i,t)),t.add(e)}e:for(const i of r){for(const e of t)if(i===e)continue e;const r=this.peerIPs.get(i);r&&(r.delete(e),r.size||this.peerIPs.delete(i))}}_removeIPs(e,t){t.forEach((t=>{const r=this.peerIPs.get(t);r&&(r.delete(e),r.size||this.peerIPs.delete(t))}))}_updateIPs(){this.peerStats.forEach(((e,t)=>{const r=this._getIPs(t);this._setIPs(t,r,e.ips),e.ips=r}))}}},{"./peer-score-params":"lHcoR","./peer-stats":"ghpOC","./compute-score":"b22gU","./message-deliveries":"pijyj","../constants":"kx67k","peer-id":"8Bdb3",debug:"bO5wM","libp2p-interfaces/src/pubsub/errors":"i7hyG"}],ghpOC:[function(e,t,r){"use strict";function i(e={}){return Object.assign({inMesh:!1,graftTime:0,meshTime:0,firstMessageDeliveries:0,meshMessageDeliveries:0,meshMessageDeliveriesActive:!1,meshFailurePenalty:0,invalidMessageDeliveries:0},e)}Object.defineProperty(r,"__esModule",{value:!0}),r.ensureTopicStats=r.createTopicStats=r.createPeerStats=void 0,r.createPeerStats=function(e={}){return Object.assign(Object.assign({connected:!1,expire:0,ips:[],behaviourPenalty:0},e),{topics:e.topics?Object.entries(e.topics).reduce(((e,[t,r])=>(e[t]=i(r),e)),{}):{}})},r.createTopicStats=i,r.ensureTopicStats=function(e,t,r){let n=t.topics[e];return n||(r.topics[e]?(t.topics[e]=n=i(),n):void 0)}},{}],b22gU:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.computeScore=void 0,r.computeScore=function(e,t,r,i){let n=0;Object.entries(t.topics).forEach((([e,t])=>{const i=r.topics[e];if(!i)return;let s=0;if(t.inMesh){let e=t.meshTime/i.timeInMeshQuantum;e>i.timeInMeshCap&&(e=i.timeInMeshCap),s+=e*i.timeInMeshWeight}if(s+=t.firstMessageDeliveries*i.firstMessageDeliveriesWeight,t.meshMessageDeliveriesActive&&t.meshMessageDeliveries0&&n>r.topicScoreCap&&(n=r.topicScoreCap);const s=r.appSpecificScore(e);n+=s*r.appSpecificWeight,t.ips.forEach((e=>{if(r.IPColocationFactorWhitelist.has(e))return;const t=i.get(e),s=t?t.size:0;if(s>r.IPColocationFactorThreshold){const e=s-r.IPColocationFactorThreshold;n+=e*e*r.IPColocationFactorWeight}}));const o=t.behaviourPenalty*t.behaviourPenalty;return n+=o*r.behaviourPenaltyWeight,n}},{}],pijyj:[function(e,t,r){"use strict";var i=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(r,"__esModule",{value:!0}),r.MessageDeliveries=r.DeliveryRecordStatus=void 0;const n=e("../constants"),s=i(e("denque")),o=e("../utils");var a,c;(c=a=r.DeliveryRecordStatus||(r.DeliveryRecordStatus={}))[c.unknown=0]="unknown",c[c.valid=1]="valid",c[c.invalid=2]="invalid",c[c.ignored=3]="ignored";r.MessageDeliveries=class{constructor(){this.records=new Map,this.queue=new s.default}ensureRecord(e){const t=o.messageIdToString(e);let r=this.records.get(t);if(r)return r;r={status:a.unknown,firstSeen:Date.now(),validated:0,peers:new Set},this.records.set(t,r);const i={msgId:t,expire:Date.now()+n.TimeCacheDuration};return this.queue.push(i),r}gc(){const e=Date.now();let t=this.queue.peekFront();for(;t&&t.expire=r||t<-r))return t<0&&(t+=r),t=this._head+t&this._capacityMask,this._list[t]}},i.prototype.get=function(e){return this.peekAt(e)},i.prototype.peek=function(){if(this._head!==this._tail)return this._list[this._head]},i.prototype.peekFront=function(){return this.peek()},i.prototype.peekBack=function(){return this.peekAt(-1)},Object.defineProperty(i.prototype,"length",{get:function(){return this.size()}}),i.prototype.size=function(){return this._head===this._tail?0:this._headthis._capacity&&this.pop(),this._head1e4&&this._tail<=this._list.length>>>2&&this._shrinkArray(),t}},i.prototype.push=function(e){if(void 0===e)return this.size();var t=this._tail;return this._list[t]=e,this._tail=t+1&this._capacityMask,this._tail===this._head&&this._growArray(),this._capacity&&this.size()>this._capacity&&this.shift(),this._head1e4&&e<=t>>>2&&this._shrinkArray(),r}},i.prototype.removeOne=function(e){var t=e;if(t===(0|t)&&this._head!==this._tail){var r=this.size(),i=this._list.length;if(!(t>=r||t<-r)){t<0&&(t+=r),t=this._head+t&this._capacityMask;var n,s=this._list[t];if(e0;n--)this._list[t]=this._list[t=t-1+i&this._capacityMask];this._list[t]=void 0,this._head=this._head+1+i&this._capacityMask}else{for(n=r-1-e;n>0;n--)this._list[t]=this._list[t=t+1+i&this._capacityMask];this._list[t]=void 0,this._tail=this._tail-1+i&this._capacityMask}return s}}},i.prototype.remove=function(e,t){var r,i=e,n=t;if(i===(0|i)&&this._head!==this._tail){var s=this.size(),o=this._list.length;if(!(i>=s||i<-s||t<1)){if(i<0&&(i+=s),1===t||!t)return(r=new Array(1))[0]=this.removeOne(i),r;if(0===i&&i+t>=s)return r=this.toArray(),this.clear(),r;var a;for(i+t>s&&(t=s-i),r=new Array(t),a=0;a0;a--)this._list[i=i+1+o&this._capacityMask]=void 0;return r}if(0===e){for(this._head=this._head+t+o&this._capacityMask,a=t-1;a>0;a--)this._list[i=i+1+o&this._capacityMask]=void 0;return r}if(i0;a--)this.unshift(this._list[i=i-1+o&this._capacityMask]);for(i=this._head-1+o&this._capacityMask;n>0;)this._list[i=i-1+o&this._capacityMask]=void 0,n--;e<0&&(this._tail=i)}else{for(this._tail=i,i=i+t+o&this._capacityMask,a=s-(t+e);a>0;a--)this.push(this._list[i++]);for(i=this._tail;n>0;)this._list[i=i+1+o&this._capacityMask]=void 0,n--}return this._head<2&&this._tail>1e4&&this._tail<=o>>>2&&this._shrinkArray(),r}}},i.prototype.splice=function(e,t){var r=e;if(r===(0|r)){var i=this.size();if(r<0&&(r+=i),!(r>i)){if(arguments.length>2){var n,s,o,a=arguments.length,c=this._list.length,u=2;if(!i||r0&&(this._head=this._head+r+c&this._capacityMask)):(o=this.remove(r,t),this._head=this._head+r+c&this._capacityMask);a>u;)this.unshift(arguments[--a]);for(n=r;n>0;n--)this.unshift(s[n-1])}else{var l=(s=new Array(i-(r+t))).length;for(n=0;nthis._tail){for(t=this._head;t>>=1,this._capacityMask>>>=1},t.exports=i},{}],"8V5x8":[function(e,t,r){"use strict";var i=this&&this.__awaiter||function(e,t,r,i){return new(r||(r=Promise))((function(n,s){function o(e){try{c(i.next(e))}catch(e){s(e)}}function a(e){try{c(i.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?n(e.value):(t=e.value,t instanceof r?t:new r((function(e){e(t)}))).then(o,a)}c((i=i.apply(e,t||[])).next())}))};Object.defineProperty(r,"__esModule",{value:!0}),r.IWantTracer=void 0;const n=e("./constants"),s=e("./utils"),o=e("libp2p-interfaces/src/pubsub/errors"),{ERR_INVALID_SIGNATURE:a,ERR_MISSING_SIGNATURE:c}=o.codes;r.IWantTracer=class{constructor(e){this.getMsgId=e,this.promises=new Map}addPromise(e,t){const r=t[Math.floor(Math.random()*t.length)],i=s.messageIdToString(r);let o=this.promises.get(i);o||(o=new Map,this.promises.set(i,o)),o.has(e)||o.set(e,Date.now()+n.GossipsubIWantFollowupTime)}getBrokenPromises(){const e=Date.now(),t=new Map;return this.promises.forEach(((r,i)=>{r.forEach(((i,n)=>{i{n.forEach(((e,t)=>{const i=e.validity||r;(function(e){const t=(new Date).getTime()-e.getTime();return Math.floor(t/1e3)})(e.timestamp)>i&&n.delete(t)}))}),200);this.put=(e,t,r)=>{this.has(e)||n.set(e,{value:t,timestamp:new Date,validity:r}),s()},this.get=e=>{if(n.has(e))return n.get(e).value;throw new Error("key does not exist")},this.has=e=>n.has(e)}},{"lodash.throttle":"3gPBz"}],"3gPBz":[function(e,t,r){var i=arguments[3],n="Expected a function",s=NaN,o="[object Symbol]",a=/^\s+|\s+$/g,c=/^[-+]0x[0-9a-f]+$/i,u=/^0b[01]+$/i,l=/^0o[0-7]+$/i,d=parseInt,f="object"==typeof i&&i&&i.Object===Object&&i,h="object"==typeof self&&self&&self.Object===Object&&self,p=f||h||Function("return this")(),g=Object.prototype,y=g.toString,m=Math.max,b=Math.min,v=function(){return p.Date.now()};function w(e,t,r){var i,s,o,a,c,u,l=0,d=!1,f=!1,h=!0;if("function"!=typeof e)throw new TypeError(n);function p(t){var r=i,n=s;return i=s=void 0,l=t,a=e.apply(n,r)}function g(e){return l=e,c=setTimeout(w,t),d?p(e):a}function y(e){var r=e-u;return void 0===u||r>=t||r<0||f&&e-l>=o}function w(){var e=v();if(y(e))return _(e);c=setTimeout(w,function(e){var r=t-(e-u);return f?b(r,o-(e-l)):r}(e))}function _(e){return c=void 0,h&&i?p(e):(i=s=void 0,a)}function S(){var e=v(),r=y(e);if(i=arguments,s=this,u=e,r){if(void 0===c)return g(u);if(f)return c=setTimeout(w,t),p(u)}return void 0===c&&(c=setTimeout(w,t)),a}return t=A(t)||0,E(r)&&(d=!!r.leading,o=(f="maxWait"in r)?m(A(r.maxWait)||0,t):o,h="trailing"in r?!!r.trailing:h),S.cancel=function(){void 0!==c&&clearTimeout(c),l=0,i=u=s=c=void 0},S.flush=function(){return void 0===c?a:_(v())},S}function _(e,t,r){var i=!0,s=!0;if("function"!=typeof e)throw new TypeError(n);return E(r)&&(i="leading"in r?!!r.leading:i,s="trailing"in r?!!r.trailing:s),w(e,t,{leading:i,maxWait:t,trailing:s})}function E(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}function S(e){return!!e&&"object"==typeof e}function T(e){return"symbol"==typeof e||S(e)&&y.call(e)==o}function A(e){if("number"==typeof e)return e;if(T(e))return s;if(E(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=E(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=e.replace(a,"");var r=u.test(e);return r||l.test(e)?d(e.slice(2),r?2:8):c.test(e)?s:+e}t.exports=_},{}],"27rHX":[function(e,t,r){"use strict";const i=e("err-code"),{concat:n}=e("uint8arrays/concat"),{fromString:s}=e("uint8arrays/from-string"),o=e("libp2p-crypto/src/keys"),a=e("peer-id"),c=e("varint"),{equals:u}=e("uint8arrays/equals"),{codes:l}=e("../../errors"),{Envelope:d}=e("./envelope");class f{constructor({peerId:e,payloadType:t,payload:r,signature:i}){this.peerId=e,this.payloadType=t,this.payload=r,this.signature=i,this._marshal=void 0}marshal(){if(this._marshal)return this._marshal;const e=o.marshalPublicKey(this.peerId.pubKey);return this._marshal=d.encode({publicKey:e,payloadType:this.payloadType,payload:this.payload,signature:this.signature}).finish(),this._marshal}equals(e){return u(this.peerId.pubKey.bytes,e.peerId.pubKey.bytes)&&u(this.payloadType,e.payloadType)&&u(this.payload,e.payload)&&u(this.signature,e.signature)}validate(e){const t=h(e,this.payloadType,this.payload);return this.peerId.pubKey.verify(t,this.signature)}}const h=(e,t,r)=>{const i=s(e),o=c.encode(i.byteLength),a=c.encode(t.length),u=c.encode(r.length);return n([new Uint8Array(o),i,new Uint8Array(a),t,new Uint8Array(u),r])};f.createFromProtobuf=async e=>{const t=d.decode(e),r=await a.createFromPubKey(t.publicKey);return new f({peerId:r,payloadType:t.payloadType,payload:t.payload,signature:t.signature})},f.seal=async(e,t)=>{const r=e.domain,i=e.codec,n=e.marshal(),s=h(r,i,n),o=await t.privKey.sign(s);return new f({peerId:t,payloadType:i,payload:n,signature:o})},f.openAndCertify=async(e,t)=>{const r=await f.createFromProtobuf(e);if(!await r.validate(t))throw i(new Error("envelope signature is not valid for the given domain"),l.ERR_SIGNATURE_NOT_VALID);return r},t.exports=f},{"err-code":"chZjB","uint8arrays/concat":"4EBjG","uint8arrays/from-string":"dF7Y4","libp2p-crypto/src/keys":"kWJWg","peer-id":"8Bdb3",varint:"aN1CO","uint8arrays/equals":"eY3cX","../../errors":"3rNo5","./envelope":"1obky"}],"3rNo5":[function(e,t,r){"use strict";r.messages={NOT_STARTED_YET:"The libp2p node is not started yet",DHT_DISABLED:"DHT is not available",CONN_ENCRYPTION_REQUIRED:"At least one connection encryption module is required"},r.codes={DHT_DISABLED:"ERR_DHT_DISABLED",PUBSUB_NOT_STARTED:"ERR_PUBSUB_NOT_STARTED",DHT_NOT_STARTED:"ERR_DHT_NOT_STARTED",CONN_ENCRYPTION_REQUIRED:"ERR_CONN_ENCRYPTION_REQUIRED",ERR_INVALID_PROTOCOLS_FOR_STREAM:"ERR_INVALID_PROTOCOLS_FOR_STREAM",ERR_CONNECTION_ENDED:"ERR_CONNECTION_ENDED",ERR_CONNECTION_FAILED:"ERR_CONNECTION_FAILED",ERR_NODE_NOT_STARTED:"ERR_NODE_NOT_STARTED",ERR_ALREADY_ABORTED:"ERR_ALREADY_ABORTED",ERR_TOO_MANY_ADDRESSES:"ERR_TOO_MANY_ADDRESSES",ERR_NO_VALID_ADDRESSES:"ERR_NO_VALID_ADDRESSES",ERR_RELAYED_DIAL:"ERR_RELAYED_DIAL",ERR_DIALED_SELF:"ERR_DIALED_SELF",ERR_DISCOVERED_SELF:"ERR_DISCOVERED_SELF",ERR_DUPLICATE_TRANSPORT:"ERR_DUPLICATE_TRANSPORT",ERR_ENCRYPTION_FAILED:"ERR_ENCRYPTION_FAILED",ERR_HOP_REQUEST_FAILED:"ERR_HOP_REQUEST_FAILED",ERR_INVALID_KEY:"ERR_INVALID_KEY",ERR_INVALID_MESSAGE:"ERR_INVALID_MESSAGE",ERR_INVALID_PARAMETERS:"ERR_INVALID_PARAMETERS",ERR_INVALID_PEER:"ERR_INVALID_PEER",ERR_MUXER_UNAVAILABLE:"ERR_MUXER_UNAVAILABLE",ERR_TIMEOUT:"ERR_TIMEOUT",ERR_TRANSPORT_UNAVAILABLE:"ERR_TRANSPORT_UNAVAILABLE",ERR_TRANSPORT_DIAL_FAILED:"ERR_TRANSPORT_DIAL_FAILED",ERR_UNSUPPORTED_PROTOCOL:"ERR_UNSUPPORTED_PROTOCOL",ERR_INVALID_MULTIADDR:"ERR_INVALID_MULTIADDR",ERR_SIGNATURE_NOT_VALID:"ERR_SIGNATURE_NOT_VALID"}},{}],"1obky":[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-envelope"]||(i.roots["libp2p-envelope"]={});a.Envelope=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.publicKey=e.bytes();break;case 2:i.payloadType=e.bytes();break;case 3:i.payload=e.bytes();break;case 5:i.signature=e.bytes();break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.Envelope)return e;var t=new a.Envelope;return null!=e.publicKey&&("string"==typeof e.publicKey?o.base64.decode(e.publicKey,t.publicKey=o.newBuffer(o.base64.length(e.publicKey)),0):e.publicKey.length&&(t.publicKey=e.publicKey)),null!=e.payloadType&&("string"==typeof e.payloadType?o.base64.decode(e.payloadType,t.payloadType=o.newBuffer(o.base64.length(e.payloadType)),0):e.payloadType.length&&(t.payloadType=e.payloadType)),null!=e.payload&&("string"==typeof e.payload?o.base64.decode(e.payload,t.payload=o.newBuffer(o.base64.length(e.payload)),0):e.payload.length&&(t.payload=e.payload)),null!=e.signature&&("string"==typeof e.signature?o.base64.decode(e.signature,t.signature=o.newBuffer(o.base64.length(e.signature)),0):e.signature.length&&(t.signature=e.signature)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(t.bytes===String?r.publicKey="":(r.publicKey=[],t.bytes!==Array&&(r.publicKey=o.newBuffer(r.publicKey))),t.bytes===String?r.payloadType="":(r.payloadType=[],t.bytes!==Array&&(r.payloadType=o.newBuffer(r.payloadType))),t.bytes===String?r.payload="":(r.payload=[],t.bytes!==Array&&(r.payload=o.newBuffer(r.payload))),t.bytes===String?r.signature="":(r.signature=[],t.bytes!==Array&&(r.signature=o.newBuffer(r.signature)))),null!=e.publicKey&&e.hasOwnProperty("publicKey")&&(r.publicKey=t.bytes===String?o.base64.encode(e.publicKey,0,e.publicKey.length):t.bytes===Array?Array.prototype.slice.call(e.publicKey):e.publicKey),null!=e.payloadType&&e.hasOwnProperty("payloadType")&&(r.payloadType=t.bytes===String?o.base64.encode(e.payloadType,0,e.payloadType.length):t.bytes===Array?Array.prototype.slice.call(e.payloadType):e.payloadType),null!=e.payload&&e.hasOwnProperty("payload")&&(r.payload=t.bytes===String?o.base64.encode(e.payload,0,e.payload.length):t.bytes===Array?Array.prototype.slice.call(e.payload):e.payload),null!=e.signature&&e.hasOwnProperty("signature")&&(r.signature=t.bytes===String?o.base64.encode(e.signature,0,e.signature.length):t.bytes===Array?Array.prototype.slice.call(e.signature):e.signature),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,i.util.toJSONOptions)},e}(),t.exports=a},{"protobufjs/minimal":"grAXL"}],jgA5e:[function(e,t,r){"use strict";const i=e("peer-id"),{base58btc:n}=e("multiformats/bases/base58"),{default:s}=e("p-queue"),o=e("p-defer"),a=e("debug"),c=a("libp2p-delegated-peer-routing");c.error=a("libp2p-delegated-peer-routing:error");t.exports=class{constructor(e){if(null==e)throw new Error("missing ipfs http client");this._client=e,this._httpQueue=new s({concurrency:4});const{protocol:t,host:r,port:i}=e.getEndpointConfig();c(`enabled DelegatedPeerRouting via ${t}://${r}:${i}`)}async findPeer(e,t={}){let r=e;i.isPeerId(r)&&(r=e.toB58String()),c("findPeer starts: "+e),t.timeout=t.timeout||3e4;try{return await this._httpQueue.add((async()=>{const{addrs:i}=await this._client.dht.findPeer(r,{timeout:t.timeout});return{id:e,multiaddrs:i}}))}catch(e){if(e.message.includes("not found"))return;throw e}finally{c("findPeer finished: "+e)}}async*getClosestPeers(e,t={}){const r=n.encode(e).substring(1);c("getClosestPeers starts:",r),t.timeout=t.timeout||3e4;const s=o(),a=o();this._httpQueue.add((()=>(s.resolve(),a.promise)));try{await s.promise;const e=new Map;for await(const n of this._client.dht.query(r,{timeout:t.timeout}))switch(n.type){case 1:n.responses.forEach((t=>{e.set(t.id,{id:i.parse(t.id),multiaddrs:t.addrs})}));break;case 2:yield e.get(n.id.string)||{id:i.createFromCID(n.id),multiaddrs:[]};break;default:c("getClosestPeers unhandled response",n)}}catch(e){throw c.error("getClosestPeers errored:",e),e}finally{a.resolve(),c("getClosestPeers finished:",r)}}}},{"peer-id":"8Bdb3","multiformats/bases/base58":"4n7mA","p-queue":"biPlv","p-defer":"5rKSv",debug:"bO5wM"}],gg6SI:[function(e,t,r){"use strict";const i=e("debug"),n=e("peer-id"),s=e("it-drain"),{default:o}=e("p-queue"),a=e("p-defer"),c=i("libp2p-delegated-content-routing");c.error=i("libp2p-delegated-content-routing:error");t.exports=class{constructor(e,t){if(null==e)throw new Error("missing self peerId");if(null==t)throw new Error("missing ipfs http client");this._client=t,this.peerId=e;const r={concurrency:4};this._httpQueue=new o(r),this._httpQueueRefs=new o(Object.assign({},r,{concurrency:2}));const{protocol:i,host:n,port:s}=t.getEndpointConfig();c(`enabled DelegatedContentRouting via ${i}://${n}:${s}`)}async*findProviders(e,t={}){c(`findProviders starts: ${e}`),t.timeout=t.timeout||3e4;let r=0;const i=a(),s=a();this._httpQueue.add((()=>(i.resolve(),s.promise)));try{await i.promise;for await(const{id:i,addrs:s}of this._client.dht.findProvs(e,{numProviders:t.numProviders,timeout:t.timeout}))yield{id:n.parse(i),multiaddrs:s},r++}catch(e){throw c.error("findProviders errored:",e),e}finally{s.resolve(),c(`findProviders finished: ${e} found ${r} providers`)}}async provide(e){c(`provide starts: ${e}`),await this._httpQueueRefs.add((async()=>{await this._client.block.stat(e),await s(this._client.dht.provide(e))})),c(`provide finished: ${e}`)}}},{debug:"bO5wM","peer-id":"8Bdb3","it-drain":"dKYhO","p-queue":"biPlv","p-defer":"5rKSv"}],h5Uk6:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/multibases"),n=e("ipfs-core-utils/multicodecs"),s=e("ipfs-core-utils/multihashes"),o=e("@ipld/dag-pb"),a=e("@ipld/dag-cbor"),c=e("multiformats/hashes/identity"),u=e("multiformats/basics"),l=e("./bitswap/index.js"),d=e("./block/index.js"),f=e("./bootstrap/index.js"),h=e("./config/index.js"),p=e("./dag/index.js"),g=e("./dht/index.js"),y=e("./diag/index.js"),m=e("./files/index.js"),b=e("./key/index.js"),v=e("./log/index.js"),w=e("./name/index.js"),_=e("./object/index.js"),E=e("./pin/index.js"),S=e("./pubsub/index.js"),T=e("./refs/index.js"),A=e("./repo/index.js"),k=e("./stats/index.js"),I=e("./swarm/index.js"),R=e("./add.js"),P=e("./add-all.js"),O=e("./cat.js"),C=e("./commands.js"),j=e("./dns.js"),D=e("./get-endpoint-config.js"),M=e("./get.js"),x=e("./id.js"),B=e("./is-online.js"),L=e("./ls.js"),N=e("./mount.js"),U=e("./ping.js"),F=e("./resolve.js"),K=e("./start.js"),z=e("./stop.js"),V=e("./version.js"),q=e("ipfs-utils/src/files/glob-source.js"),G=e("multiformats/cid"),H=e("multiaddr"),$=e("ipfs-utils/src/files/url-source.js");function W(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function Y(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var X=Y(o),Z=Y(a),Q=W(q),J=W($);const ee=Q.default;Object.defineProperty(r,"CID",{enumerable:!0,get:function(){return G.CID}}),Object.defineProperty(r,"multiaddr",{enumerable:!0,get:function(){return H.Multiaddr}}),Object.defineProperty(r,"urlSource",{enumerable:!0,get:function(){return J.default}}),r.create=function(e={}){const t={name:c.identity.name,code:c.identity.code,encode:e=>e,decode:e=>e},r=Object.values(u.bases);(e.ipld&&e.ipld.bases?e.ipld.bases:[]).forEach((e=>r.push(e)));const o=new i.Multibases({bases:r,loadBase:e.ipld&&e.ipld.loadBase}),a=Object.values(u.codecs);[X,Z,t].concat(e.ipld&&e.ipld.codecs||[]).forEach((e=>a.push(e)));const q=new n.Multicodecs({codecs:a,loadCodec:e.ipld&&e.ipld.loadCodec}),G=Object.values(u.hashes);(e.ipld&&e.ipld.hashers?e.ipld.hashers:[]).forEach((e=>G.push(e)));const H=new s.Multihashes({hashers:G,loadHasher:e.ipld&&e.ipld.loadHasher});return{add:R.createAdd(e),addAll:P.createAddAll(e),bitswap:l.createBitswap(e),block:d.createBlock(e),bootstrap:f.createBootstrap(e),cat:O.createCat(e),commands:C.createCommands(e),config:h.createConfig(e),dag:p.createDag(q,e),dht:g.createDht(e),diag:y.createDiag(e),dns:j.createDns(e),files:m.createFiles(e),get:M.createGet(e),getEndpointConfig:D.createGetEndpointConfig(e),id:x.createId(e),isOnline:B.createIsOnline(e),key:b.createKey(e),log:v.createLog(e),ls:L.createLs(e),mount:N.createMount(e),name:w.createName(e),object:_.createObject(q,e),pin:E.createPin(e),ping:U.createPing(e),pubsub:S.createPubsub(e),refs:T.createRefs(e),repo:A.createRepo(e),resolve:F.createResolve(e),start:K.createStart(e),stats:k.createStats(e),stop:z.createStop(e),swarm:I.createSwarm(e),version:V.createVersion(e),bases:o,codecs:q,hashers:H}},r.globSource=ee},{"ipfs-core-utils/multibases":"lr7wI","ipfs-core-utils/multicodecs":"4I7TQ","ipfs-core-utils/multihashes":"febSG","@ipld/dag-pb":"i2cdx","@ipld/dag-cbor":"3498i","multiformats/hashes/identity":"eYCZn","multiformats/basics":"lPcQG","./bitswap/index.js":"e1wIm","./block/index.js":"jb9Ty","./bootstrap/index.js":"94xQz","./config/index.js":"jQsLT","./dag/index.js":"alcVs","./dht/index.js":"l4zXl","./diag/index.js":"lYFrh","./files/index.js":"5SjY6","./key/index.js":"d23S0","./log/index.js":"dax7W","./name/index.js":"hAUWJ","./object/index.js":"lIWb3","./pin/index.js":"2EyML","./pubsub/index.js":"9yoEA","./refs/index.js":"6sM7A","./repo/index.js":"lf1uS","./stats/index.js":"8ekdG","./swarm/index.js":"9n7fV","./add.js":"bh9eV","./add-all.js":"dygjF","./cat.js":"37ULc","./commands.js":"d7oos","./dns.js":"6WsTM","./get-endpoint-config.js":"e09lW","./get.js":"9dl4d","./id.js":"iMd7i","./is-online.js":"1Ujko","./ls.js":"jIkVK","./mount.js":"5Ghx1","./ping.js":"fIZQw","./resolve.js":"fqXrw","./start.js":"4YTOj","./stop.js":"j2dHM","./version.js":"k3Foi","ipfs-utils/src/files/glob-source.js":"lHksA","multiformats/cid":"9ooAY",multiaddr:"8Mu1u","ipfs-utils/src/files/url-source.js":"jQSIS"}],lr7wI:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e=>Promise.reject(new Error(`No base found for "${e}"`));r.Multibases=class{constructor(e){this._basesByName={},this._basesByPrefix={},this._loadBase=e.loadBase||i;for(const t of e.bases)this.addBase(t)}addBase(e){if(this._basesByName[e.name]||this._basesByPrefix[e.prefix])throw new Error(`Codec already exists for codec "${e.name}"`);this._basesByName[e.name]=e,this._basesByPrefix[e.prefix]=e}removeBase(e){delete this._basesByName[e.name],delete this._basesByPrefix[e.prefix]}async getBase(e){if(this._basesByName[e])return this._basesByName[e];if(this._basesByPrefix[e])return this._basesByPrefix[e];const t=await this._loadBase(e);return null==this._basesByName[t.name]&&null==this._basesByPrefix[t.prefix]&&this.addBase(t),t}listBases(){return Object.values(this._basesByName)}}},{}],"4I7TQ":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e=>Promise.reject(new Error(`No codec found for "${e}"`));r.Multicodecs=class{constructor(e){this._codecsByName={},this._codecsByCode={},this._loadCodec=e.loadCodec||i;for(const t of e.codecs)this.addCodec(t)}addCodec(e){if(this._codecsByName[e.name]||this._codecsByCode[e.code])throw new Error(`Resolver already exists for codec "${e.name}"`);this._codecsByName[e.name]=e,this._codecsByCode[e.code]=e}removeCodec(e){delete this._codecsByName[e.name],delete this._codecsByCode[e.code]}async getCodec(e){const t="string"==typeof e?this._codecsByName:this._codecsByCode;if(t[e])return t[e];const r=await this._loadCodec(e);return null==t[e]&&this.addCodec(r),r}listCodecs(){return Object.values(this._codecsByName)}}},{}],febSG:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e=>Promise.reject(new Error(`No hasher found for "${e}"`));r.Multihashes=class{constructor(e){this._hashersByName={},this._hashersByCode={},this._loadHasher=e.loadHasher||i;for(const t of e.hashers)this.addHasher(t)}addHasher(e){if(this._hashersByName[e.name]||this._hashersByCode[e.code])throw new Error(`Resolver already exists for codec "${e.name}"`);this._hashersByName[e.name]=e,this._hashersByCode[e.code]=e}removeHasher(e){delete this._hashersByName[e.name],delete this._hashersByCode[e.code]}async getHasher(e){const t="string"==typeof e?this._hashersByName:this._hashersByCode;if(t[e])return t[e];const r=await this._loadHasher(e);return null==t[e]&&this.addHasher(r),r}listHashers(){return Object.values(this._hashersByName)}}},{}],e1wIm:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./wantlist.js"),n=e("./wantlist-for-peer.js"),s=e("./stat.js"),o=e("./unwant.js");r.createBitswap=function(e){return{wantlist:i.createWantlist(e),wantlistForPeer:n.createWantlistForPeer(e),unwant:o.createUnwant(e),stat:s.createStat(e)}}},{"./wantlist.js":"hU5XK","./wantlist-for-peer.js":"9fQsQ","./stat.js":"3Q0KE","./unwant.js":"azoPb"}],hU5XK:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){return((await(await e.post("bitswap/wantlist",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers})).json()).Keys||[]).map((e=>i.CID.parse(e["/"])))}));r.createWantlist=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],hR8g6:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./core.js");r.configure=e=>t=>e(new i.Client(t),t)},{"./core.js":"3XXp5"}],"3XXp5":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr"),n=e("ipfs-utils/src/env.js"),s=e("parse-duration"),o=e("debug"),a=e("ipfs-utils/src/http.js"),c=e("merge-options"),u=e("ipfs-core-utils/to-url-string"),l=e("ipfs-core-utils/agent");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var f=d(s),h=d(o),p=d(a),g=d(c),y=d(l);const m=h.default("ipfs-http-client:lib:error-handler"),b=g.default.bind({ignoreUndefined:!0}),v=n.isBrowser||n.isWebWorker?location.protocol:"http",w=n.isBrowser||n.isWebWorker?location.hostname:"localhost",_=n.isBrowser||n.isWebWorker?location.port:"5001",E=async e=>{let t;try{if((e.headers.get("Content-Type")||"").startsWith("application/json")){const r=await e.json();m(r),t=r.Message||r.message}else t=await e.text()}catch(e){m("Failed to parse error response",e),t=e.message}let r=new p.default.HTTPError(e);throw t&&(t.includes("deadline has elapsed")&&(r=new p.default.TimeoutError),t&&t.includes("context deadline exceeded")&&(r=new p.default.TimeoutError)),t&&t.includes("request timed out")&&(r=new p.default.TimeoutError),t&&(r.message=t),r},S=/[A-Z\u00C0-\u00D6\u00D8-\u00DE]/g,T=e=>e.replace(S,(function(e){return"-"+e.toLowerCase()}));class A extends p.default{constructor(e={}){const t=((e={})=>{let t,r,s={};if("string"==typeof e||i.Multiaddr.isMultiaddr(e))t=new URL(u.toUrlString(e));else if(e instanceof URL)t=e;else if("string"==typeof e.url||i.Multiaddr.isMultiaddr(e.url))t=new URL(u.toUrlString(e.url)),s=e;else if(e.url instanceof URL)t=e.url,s=e;else{s=e||{};const r=(s.protocol||v).replace(":",""),i=(s.host||w).split(":")[0],n=s.port||_;t=new URL(`${r}://${i}:${n}`)}if(s.apiPath?t.pathname=s.apiPath:"/"!==t.pathname&&void 0!==t.pathname||(t.pathname="api/v0"),n.isNode){const e=y.default(t);r=s.agent||new e({keepAlive:!0,maxSockets:6})}return{...s,host:t.host,protocol:t.protocol.replace(":",""),port:Number(t.port),apiPath:t.pathname,url:t,agent:r}})(e);var r;super({timeout:(r=t.timeout||0,("string"==typeof r?f.default(r):r)||void 0),headers:t.headers,base:`${t.url}`,handleError:E,transformSearchParams:e=>{const t=new URLSearchParams;for(const[r,i]of e)"undefined"!==i&&"null"!==i&&"signal"!==r&&t.append(T(r),i),"timeout"!==r||isNaN(i)||t.append(T(r),i);return t},agent:t.agent}),delete this.get,delete this.put,delete this.delete,delete this.options;const s=this.fetch;this.fetch=(e,r={})=>("string"!=typeof e||e.startsWith("/")||(e=`${t.url}/${e}`),s.call(this,e,b(r,{method:"POST"})))}}const k=p.default.HTTPError;r.Client=A,r.HTTPError=k,r.errorHandler=E},{multiaddr:"8Mu1u","ipfs-utils/src/env.js":"flyHr","parse-duration":"fGYtw",debug:"bO5wM","ipfs-utils/src/http.js":"ifXXn","merge-options":"fupyv","ipfs-core-utils/to-url-string":"aPEcT","ipfs-core-utils/agent":"lcuEJ"}],aPEcT:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var s=n(e("multiaddr-to-uri"));r.toUrlString=function(e){try{e=s.default(new i.Multiaddr(e))}catch(e){}return e=e.toString()}},{multiaddr:"8Mu1u","multiaddr-to-uri":"4PPH7"}],lcuEJ:[function(e,t,r){"use strict";t.exports=()=>{}},{}],fT4zz:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./mode-to-string.js"),n=e("./parse-mtime.js");r.toUrlSearchParams=function({arg:e,searchParams:t,hashAlg:r,mtime:s,mode:o,...a}={}){t&&(a={...a,...t}),r&&(a.hash=r),null!=s&&(s=n.parseMtime(s),a.mtime=s.secs,a.mtimeNsecs=s.nsecs),null!=o&&(a.mode=i.modeToString(o)),a.timeout&&!isNaN(a.timeout)&&(a.timeout=`${a.timeout}ms`),null==e?e=[]:Array.isArray(e)||(e=[e]);const c=new URLSearchParams(a);return e.forEach((e=>c.append("arg",e))),c}},{"./mode-to-string.js":"bbWaj","./parse-mtime.js":"aLNRF"}],bbWaj:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.modeToString=function(e){if(null!=e)return"string"==typeof e?e:e.toString(8).padStart(4,"0")}},{}],aLNRF:[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("err-code"));r.parseMtime=function(e){if(null==e)return;let t;if(null!=e.secs&&(t={secs:e.secs,nsecs:e.nsecs}),null!=e.Seconds&&(t={secs:e.Seconds,nsecs:e.FractionalNanoseconds}),Array.isArray(e)&&(t={secs:e[0],nsecs:e[1]}),e instanceof Date){const r=e.getTime(),i=Math.floor(r/1e3);t={secs:i,nsecs:1e3*(r-1e3*i)}}if(Object.prototype.hasOwnProperty.call(t,"secs")){if(null!=t&&null!=t.nsecs&&(t.nsecs<0||t.nsecs>999999999))throw n.default(new Error("mtime-nsecs must be within the range [0,999999999]"),"ERR_INVALID_MTIME_NSECS");return t}}},{"err-code":"chZjB"}],"9fQsQ":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={}){return((await(await e.post("bitswap/wantlist",{signal:r.signal,searchParams:s.toUrlSearchParams({...r,peer:t.toString()}),headers:r.headers})).json()).Keys||[]).map((e=>i.CID.parse(e["/"])))}));r.createWantlistForPeer=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"3Q0KE":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("bitswap/stat",{searchParams:s.toUrlSearchParams(t),signal:t.signal,headers:t.headers});return function(e){return{provideBufLen:e.ProvideBufLen,wantlist:(e.Wantlist||[]).map((e=>i.CID.parse(e["/"]))),peers:e.Peers||[],blocksReceived:BigInt(e.BlocksReceived),dataReceived:BigInt(e.DataReceived),blocksSent:BigInt(e.BlocksSent),dataSent:BigInt(e.DataSent),dupBlksReceived:BigInt(e.DupBlksReceived),dupDataReceived:BigInt(e.DupDataReceived)}}(await r.json())}));r.createStat=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],azoPb:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){return(await e.post("bitswap/unwant",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t.toString(),...r}),headers:r.headers})).json()}));r.createUnwant=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],jb9Ty:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./get.js"),n=e("./put.js"),s=e("./rm.js"),o=e("./stat.js");r.createBlock=function(e){return{get:i.createGet(e),put:n.createPut(e),rm:s.createRm(e),stat:o.createStat(e)}}},{"./get.js":"818EH","./put.js":"aXuxp","./rm.js":"7gdfk","./stat.js":"h9r67"}],"818EH":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){const i=await e.post("block/get",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t.toString(),...r}),headers:r.headers});return new Uint8Array(await i.arrayBuffer())}));r.createGet=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],aXuxp:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("ipfs-core-utils/multipart-request"),s=e("../lib/configure.js"),o=e("../lib/to-url-search-params.js"),a=e("../lib/abort-signal.js"),c=e("native-abort-controller");const u=s.configure((e=>async function t(r,s={}){const u=new c.AbortController,l=a.abortSignal(u.signal,s.signal);let d;try{const t=await e.post("block/put",{signal:l,searchParams:o.toUrlSearchParams(s),...await n.multipartRequest(r,u,s.headers)});d=await t.json()}catch(e){if("dag-pb"===s.format)return t(r,{...s,format:"protobuf"});if("dag-cbor"===s.format)return t(r,{...s,format:"cbor"});throw e}return i.CID.parse(d.Key)}));r.createPut=u},{"multiformats/cid":"9ooAY","ipfs-core-utils/multipart-request":"7TICD","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","../lib/abort-signal.js":"hzxSr","native-abort-controller":"6zwoZ"}],"7TICD":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./files/normalise-input.browser.js"),n=e("./mode-to-string.js");r.multipartRequest=async function(e,t,r={}){const s=[],o=new FormData;let a=0,c=0;for await(const{content:t,path:r,mode:u,mtime:l}of i.normaliseInput(e)){let e="";a>0&&(e=`-${a}`);let i=(t?"file":"dir")+e;const d=[];if(null!=u&&d.push(`mode=${n.modeToString(u)}`),null!=l){const{secs:e,nsecs:t}=l;d.push(`mtime=${e}`),null!=t&&d.push(`mtime-nsecs=${t}`)}if(d.length&&(i=`${i}?${d.join("&")}`),t){o.set(i,t,null!=r?encodeURIComponent(r):void 0);const e=c+t.size;s.push({name:r,start:c,end:e}),c=e}else{if(null==r)throw new Error("path or content or both must be set");o.set(i,new File([""],encodeURIComponent(r),{type:"application/x-directory"}))}a++}return{total:c,parts:s,headers:r,body:o}}},{"./files/normalise-input.browser.js":"67MIR","./mode-to-string.js":"laXQo"}],"67MIR":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./normalise-content.browser.js"),n=e("./normalise.js");r.normaliseInput=function(e){return n.normalise(e,i.normaliseContent)}},{"./normalise-content.browser.js":"fbARE","./normalise.js":"7hUEG"}],fbARE:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("err-code"),n=e("it-peekable"),s=e("browser-readablestream-to-it"),o=e("it-all"),a=e("./utils.js");function c(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var u=c(i),l=c(n),d=c(s),f=c(o);async function h(e){const t=[];for await(const r of e)t.push(r);return new Blob(t)}r.normaliseContent=async function(e){if(a.isBytes(e))return new Blob([e]);if("string"==typeof e||e instanceof String)return new Blob([e.toString()]);if(a.isBlob(e))return e;if(a.isReadableStream(e)&&(e=d.default(e)),Symbol.iterator in e||Symbol.asyncIterator in e){const t=l.default(e),{value:r,done:i}=await t.peek();if(i)return h(t);if(t.push(r),Number.isInteger(r))return new Blob([Uint8Array.from(await f.default(t))]);if(a.isBytes(r)||"string"==typeof r||r instanceof String)return h(t)}throw u.default(new Error(`Unexpected input: ${e}`),"ERR_UNEXPECTED_INPUT")}},{"err-code":"chZjB","it-peekable":"bi9X1","browser-readablestream-to-it":"aUa4D","it-all":"iCXBu","./utils.js":"ded5K"}],laXQo:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.modeToString=function(e){if(null!=e)return"string"==typeof e?e:e.toString(8).padStart(4,"0")}},{}],hzxSr:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("any-signal");r.abortSignal=function(...e){return i.anySignal(function(e){return e.filter(Boolean)}(e))}},{"any-signal":"kXgRR"}],"7gdfk":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function*(t,r={}){Array.isArray(t)||(t=[t]);const i=await e.post("block/rm",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:t.map((e=>e.toString())),"stream-channels":!0,...r}),headers:r.headers});for await(const e of i.ndjson())yield a(e)}));function a(e){const t={cid:i.CID.parse(e.Hash)};return e.Error&&(t.error=new Error(e.Error)),t}r.createRm=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],h9r67:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={}){const n=await e.post("block/stat",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:t.toString(),...r}),headers:r.headers}),o=await n.json();return{cid:i.CID.parse(o.Key),size:o.Size}}));r.createStat=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"94xQz":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./add.js"),n=e("./clear.js"),s=e("./list.js"),o=e("./reset.js"),a=e("./rm.js");r.createBootstrap=function(e){return{add:i.createAdd(e),clear:n.createClear(e),list:s.createList(e),reset:o.createReset(e),rm:a.createRm(e)}}},{"./add.js":"i6XDR","./clear.js":"89Gdv","./list.js":"4mZUF","./reset.js":"ldIgy","./rm.js":"5vusI"}],i6XDR:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js"),s=e("multiaddr");const o=i.configure((e=>async function(t,r={}){const i=await e.post("bootstrap/add",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers}),{Peers:o}=await i.json();return{Peers:o.map((e=>new s.Multiaddr(e)))}}));r.createAdd=o},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz",multiaddr:"8Mu1u"}],"89Gdv":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js"),s=e("multiaddr");const o=i.configure((e=>async function(t={}){const r=await e.post("bootstrap/rm",{signal:t.signal,searchParams:n.toUrlSearchParams({...t,all:!0}),headers:t.headers}),{Peers:i}=await r.json();return{Peers:i.map((e=>new s.Multiaddr(e)))}}));r.createClear=o},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz",multiaddr:"8Mu1u"}],"4mZUF":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js"),s=e("multiaddr");const o=i.configure((e=>async function(t={}){const r=await e.post("bootstrap/list",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers}),{Peers:i}=await r.json();return{Peers:i.map((e=>new s.Multiaddr(e)))}}));r.createList=o},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz",multiaddr:"8Mu1u"}],ldIgy:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js"),s=e("multiaddr");const o=i.configure((e=>async function(t={}){const r=await e.post("bootstrap/add",{signal:t.signal,searchParams:n.toUrlSearchParams({...t,default:!0}),headers:t.headers}),{Peers:i}=await r.json();return{Peers:i.map((e=>new s.Multiaddr(e)))}}));r.createReset=o},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz",multiaddr:"8Mu1u"}],"5vusI":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js"),s=e("multiaddr");const o=i.configure((e=>async function(t,r={}){const i=await e.post("bootstrap/rm",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers}),{Peers:o}=await i.json();return{Peers:o.map((e=>new s.Multiaddr(e)))}}));r.createRm=o},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz",multiaddr:"8Mu1u"}],jQsLT:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./profiles/index.js"),n=e("./get.js"),s=e("./get-all.js"),o=e("./replace.js"),a=e("./set.js");r.createConfig=function(e){return{getAll:s.createGetAll(e),get:n.createGet(e),set:a.createSet(e),replace:o.createReplace(e),profiles:i.createProfiles(e)}}},{"./profiles/index.js":"h2X0u","./get.js":"7SQ8n","./get-all.js":"6OKA2","./replace.js":"2ISib","./set.js":"eroO0"}],h2X0u:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./apply.js"),n=e("./list.js");r.createProfiles=function(e){return{apply:i.createApply(e),list:n.createList(e)}}},{"./apply.js":"brNlE","./list.js":"bZlc4"}],brNlE:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../lib/configure.js"),n=e("../../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){const i=await e.post("config/profile/apply",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers}),s=await i.json();return{original:s.OldCfg,updated:s.NewCfg}}));r.createApply=s},{"../../lib/configure.js":"hR8g6","../../lib/to-url-search-params.js":"fT4zz"}],bZlc4:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../lib/object-to-camel.js"),n=e("../../lib/configure.js"),s=e("../../lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("config/profile/list",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers});return(await r.json()).map((e=>i.objectToCamel(e)))}));r.createList=o},{"../../lib/object-to-camel.js":"hdPx4","../../lib/configure.js":"hR8g6","../../lib/to-url-search-params.js":"fT4zz"}],hdPx4:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.objectToCamel=function(e){if(null==e)return e;const t=/^[A-Z]+$/;return Object.keys(e).reduce(((r,i)=>(t.test(i)?r[i.toLowerCase()]=e[i]:t.test(i[0])?r[i[0].toLowerCase()+i.slice(1)]=e[i]:r[i]=e[i],r)),{})}},{}],"7SQ8n":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async(t,r={})=>{if(!t)throw new Error("key argument is required");const i=await e.post("config",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers});return(await i.json()).Value}));r.createGet=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"6OKA2":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async(t={})=>{const r=await e.post("config/show",{signal:t.signal,searchParams:n.toUrlSearchParams({...t}),headers:t.headers});return await r.json()}));r.createGetAll=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"2ISib":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("uint8arrays/from-string"),n=e("ipfs-core-utils/multipart-request"),s=e("../lib/configure.js"),o=e("../lib/to-url-search-params.js"),a=e("../lib/abort-signal.js"),c=e("native-abort-controller");const u=s.configure((e=>async(t,r={})=>{const s=new c.AbortController,u=a.abortSignal(s.signal,r.signal),l=await e.post("config/replace",{signal:u,searchParams:o.toUrlSearchParams(r),...await n.multipartRequest(i.fromString(JSON.stringify(t)),s,r.headers)});await l.text()}));r.createReplace=u},{"uint8arrays/from-string":"dF7Y4","ipfs-core-utils/multipart-request":"7TICD","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","../lib/abort-signal.js":"hzxSr","native-abort-controller":"6zwoZ"}],eroO0:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async(t,r,i={})=>{if("string"!=typeof t)throw new Error("Invalid key type");const s={...i,...o(t,r)},a=await e.post("config",{signal:i.signal,searchParams:n.toUrlSearchParams(s),headers:i.headers});await a.text()})),o=(e,t)=>{switch(typeof t){case"boolean":return{arg:[e,t.toString()],bool:!0};case"string":return{arg:[e,t]};default:return{arg:[e,JSON.stringify(t)],json:!0}}};r.createSet=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],alcVs:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./export.js"),n=e("./get.js"),s=e("./import.js"),o=e("./put.js"),a=e("./resolve.js");r.createDag=function(e,t){return{export:i.createExport(t),get:n.createGet(e,t),import:s.createImport(t),put:o.createPut(e,t),resolve:a.createResolve(t)}}},{"./export.js":"42FYP","./get.js":"1DVHz","./import.js":"91D00","./put.js":"e3DVQ","./resolve.js":"fYLE3"}],"42FYP":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function*(t,r={}){const i=await e.post("dag/export",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t.toString()}),headers:r.headers});yield*i.iterator()}));r.createExport=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"1DVHz":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/resolve.js"),s=e("it-first"),o=e("it-last"),a=e("err-code"),c=e("../block/get.js");function u(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var l=u(s),d=u(o),f=u(a);r.createGet=(e,t)=>i.configure(((t,r)=>{const i=c.createGet(r);return async(t,r={})=>{if(r.path){const s=r.localResolve?await l.default(n.resolve(t,r.path,e,i,r)):await d.default(n.resolve(t,r.path,e,i,r));if(!s)throw f.default(new Error("Not found"),"ERR_NOT_FOUND");return s}const s=await e.getCodec(t.code),o=await i(t,r);return{value:s.decode(o),remainderPath:""}}}))(t)},{"../lib/configure.js":"hR8g6","../lib/resolve.js":"7MeIb","it-first":"hBrkP","it-last":"cSXX9","err-code":"chZjB","../block/get.js":"818EH"}],"7MeIb":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var s=n(e("err-code"));r.resolve=async function*(e,t,r,n,o){const a=async e=>{const t=await r.getCodec(e.code),i=await n(e,o);return t.decode(i)},c=t.split("/").filter(Boolean);let u=await a(e),l=e;for(c.length||(yield{value:u,remainderPath:""});c.length;){const e=c.shift();if(!e)throw s.default(new Error(`Could not resolve path "${t}"`),"ERR_INVALID_PATH");if(!Object.prototype.hasOwnProperty.call(u,e))throw s.default(new Error(`no link named "${e}" under ${l}`),"ERR_NO_LINK");u=u[e],yield{value:u,remainderPath:c.join("/")};const r=i.CID.asCID(u);r&&(l=r,u=await a(u))}}},{"multiformats/cid":"9ooAY","err-code":"chZjB"}],"91D00":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js"),s=e("../lib/abort-signal.js"),o=e("ipfs-core-utils/multipart-request"),a=e("native-abort-controller"),c=e("multiformats/cid");const u=i.configure((e=>async function*(t,r={}){const i=new a.AbortController,u=s.abortSignal(i.signal,r.signal),{headers:l,body:d}=await o.multipartRequest(t,i,r.headers),f=await e.post("dag/import",{signal:u,headers:l,body:d,searchParams:n.toUrlSearchParams({"pin-roots":r.pinRoots})});for await(const{Root:e}of f.ndjson())if(void 0!==e){const{Cid:{"/":t},PinErrorMsg:r}=e;yield{root:{cid:c.CID.parse(t),pinErrorMsg:r}}}}));r.createImport=u},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","../lib/abort-signal.js":"hzxSr","ipfs-core-utils/multipart-request":"7TICD","native-abort-controller":"6zwoZ","multiformats/cid":"9ooAY"}],e3DVQ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("ipfs-core-utils/multipart-request"),o=e("../lib/to-url-search-params.js"),a=e("../lib/abort-signal.js"),c=e("native-abort-controller");r.createPut=(e,t)=>n.configure((t=>async(r,n={})=>{const u={format:"dag-cbor",hashAlg:"sha2-256",inputEnc:"raw",...n},l=(await e.getCodec(u.format)).encode(r),d=new c.AbortController,f=a.abortSignal(d.signal,u.signal),h=await t.post("dag/put",{timeout:u.timeout,signal:f,searchParams:o.toUrlSearchParams(u),...await s.multipartRequest(l,d,u.headers)}),p=await h.json();return i.CID.parse(p.Cid["/"])}))(t)},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","ipfs-core-utils/multipart-request":"7TICD","../lib/to-url-search-params.js":"fT4zz","../lib/abort-signal.js":"hzxSr","native-abort-controller":"6zwoZ"}],fYLE3:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async(t,r={})=>{const n=await e.post("dag/resolve",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:`${t}${r.path?`/${r.path}`.replace(/\/[/]+/g,"/"):""}`,...r}),headers:r.headers}),o=await n.json();return{cid:i.CID.parse(o.Cid["/"]),remainderPath:o.RemPath}}));r.createResolve=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],l4zXl:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./find-peer.js"),n=e("./find-provs.js"),s=e("./get.js"),o=e("./provide.js"),a=e("./put.js"),c=e("./query.js");r.createDht=function(e){return{findPeer:i.createFindPeer(e),findProvs:n.createFindProvs(e),get:s.createGet(e),provide:o.createProvide(e),put:a.createPut(e),query:c.createQuery(e)}}},{"./find-peer.js":"c2Je3","./find-provs.js":"Cn9mt","./get.js":"8ckSi","./provide.js":"i1las","./put.js":"fVqLD","./query.js":"aEVP8"}],c2Je3:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js"),o=e("./response-types.js");const a=n.configure((e=>async function(t,r={}){const n=await e.post("dht/findpeer",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:t,...r}),headers:r.headers});for await(const e of n.ndjson())if(e.Type===o.FinalPeer&&e.Responses){const{ID:t,Addrs:r}=e.Responses[0];return{id:t,addrs:(r||[]).map((e=>new i.Multiaddr(e)))}}throw new Error("not found")}));r.createFindPeer=a},{multiaddr:"8Mu1u","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","./response-types.js":"lyzlA"}],lyzlA:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});r.AddingPeer=6,r.DialingPeer=7,r.FinalPeer=2,r.PeerResponse=1,r.Provider=4,r.QueryError=3,r.SendingQuery=0,r.Value=5},{}],Cn9mt:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js"),o=e("./response-types.js");const a=n.configure((e=>async function*(t,r={}){const n=await e.post("dht/findprovs",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:t.toString(),...r}),headers:r.headers});for await(const e of n.ndjson())if(e.Type===o.Provider&&e.Responses)for(const{ID:t,Addrs:r}of e.Responses)yield{id:t,addrs:(r||[]).map((e=>new i.Multiaddr(e)))}}));r.createFindProvs=a},{multiaddr:"8Mu1u","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","./response-types.js":"lyzlA"}],"8ckSi":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js"),s=e("./response-types.js"),o=e("uint8arrays/from-string"),a=e("uint8arrays/to-string");const c=i.configure((e=>async function(t,r={}){const i=await e.post("dht/get",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t instanceof Uint8Array?a.toString(t):t,...r}),headers:r.headers});for await(const e of i.ndjson())if(e.Type===s.Value)return o.fromString(e.Extra,"base64pad");throw new Error("not found")}));r.createGet=c},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","./response-types.js":"lyzlA","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB"}],i1las:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr"),n=e("../lib/object-to-camel.js"),s=e("../lib/configure.js"),o=e("../lib/to-url-search-params.js");const a=s.configure((e=>async function*(t,r={recursive:!1}){const s=Array.isArray(t)?t:[t],a=await e.post("dht/provide",{signal:r.signal,searchParams:o.toUrlSearchParams({arg:s.map((e=>e.toString())),...r}),headers:r.headers});for await(let e of a.ndjson())e=n.objectToCamel(e),e.responses?e.responses=e.responses.map((({ID:e,Addrs:t})=>({id:e,addrs:(t||[]).map((e=>new i.Multiaddr(e)))}))):e.responses=[],yield e}));r.createProvide=a},{multiaddr:"8Mu1u","../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],fVqLD:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr"),n=e("../lib/object-to-camel.js"),s=e("../lib/configure.js"),o=e("../lib/to-url-search-params.js"),a=e("ipfs-core-utils/multipart-request"),c=e("../lib/abort-signal.js"),u=e("native-abort-controller"),l=e("uint8arrays/to-string");const d=s.configure((e=>async function*(t,r,s={}){const d=new u.AbortController,f=c.abortSignal(d.signal,s.signal),h=await e.post("dht/put",{signal:f,searchParams:o.toUrlSearchParams({arg:l.toString(t),...s}),...await a.multipartRequest(r,d,s.headers)});for await(let e of h.ndjson())e=n.objectToCamel(e),e.responses&&(e.responses=e.responses.map((({ID:e,Addrs:t})=>({id:e,addrs:(t||[]).map((e=>new i.Multiaddr(e)))})))),yield e}));r.createPut=d},{multiaddr:"8Mu1u","../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","ipfs-core-utils/multipart-request":"7TICD","../lib/abort-signal.js":"hzxSr","native-abort-controller":"6zwoZ","uint8arrays/to-string":"hC8JB"}],aEVP8:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr"),n=e("../lib/object-to-camel.js"),s=e("../lib/configure.js"),o=e("../lib/to-url-search-params.js");const a=s.configure((e=>async function*(t,r={}){const s=await e.post("dht/query",{signal:r.signal,searchParams:o.toUrlSearchParams({arg:t.toString(),...r}),headers:r.headers});for await(let e of s.ndjson())e=n.objectToCamel(e),e.responses=(e.responses||[]).map((({ID:e,Addrs:t})=>({id:e,addrs:(t||[]).map((e=>new i.Multiaddr(e)))}))),yield e}));r.createQuery=a},{multiaddr:"8Mu1u","../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],lYFrh:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./cmds.js"),n=e("./net.js"),s=e("./sys.js");r.createDiag=function(e){return{cmds:i.createCmds(e),net:n.createNet(e),sys:s.createSys(e)}}},{"./cmds.js":"l9zdD","./net.js":"6Ce1z","./sys.js":"ySsKi"}],l9zdD:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t={}){return(await e.post("diag/cmds",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers})).json()}));r.createCmds=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"6Ce1z":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t={}){return(await e.post("diag/net",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers})).json()}));r.createNet=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],ySsKi:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t={}){return(await e.post("diag/sys",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers})).json()}));r.createSys=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"5SjY6":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./chmod.js"),n=e("./cp.js"),s=e("./flush.js"),o=e("./ls.js"),a=e("./mkdir.js"),c=e("./mv.js"),u=e("./read.js"),l=e("./rm.js"),d=e("./stat.js"),f=e("./touch.js"),h=e("./write.js");r.createFiles=function(e){return{chmod:i.createChmod(e),cp:n.createCp(e),flush:s.createFlush(e),ls:o.createLs(e),mkdir:a.createMkdir(e),mv:c.createMv(e),read:u.createRead(e),rm:l.createRm(e),stat:d.createStat(e),touch:f.createTouch(e),write:h.createWrite(e)}}},{"./chmod.js":"i7Fmt","./cp.js":"5v5u2","./flush.js":"deUwB","./ls.js":"1dhdH","./mkdir.js":"iocNx","./mv.js":"jgv4R","./read.js":"2jkwj","./rm.js":"60cHB","./stat.js":"2InTg","./touch.js":"aa8jv","./write.js":"aw4qs"}],i7Fmt:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r,i={}){const s=await e.post("files/chmod",{signal:i.signal,searchParams:n.toUrlSearchParams({arg:t,mode:r,...i}),headers:i.headers});await s.text()}));r.createChmod=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"5v5u2":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r,n={}){const o=Array.isArray(t)?t:[t],a=await e.post("files/cp",{signal:n.signal,searchParams:s.toUrlSearchParams({arg:o.concat(r).map((e=>i.CID.asCID(e)?`/ipfs/${e}`:e)),...n}),headers:n.headers});await a.text()}));r.createCp=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],deUwB:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={}){if(!t||"string"!=typeof t)throw new Error("ipfs.files.flush requires a path");const n=await e.post("files/flush",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:t,...r}),headers:r.headers}),o=await n.json();return i.CID.parse(o.Cid)}));r.createFlush=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"1dhdH":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/object-to-camel-with-metadata.js"),s=e("../lib/configure.js"),o=e("../lib/to-url-search-params.js");const a=s.configure((e=>async function*(t,r={}){if(!t)throw new Error("ipfs.files.ls requires a path");const s=await e.post("files/ls",{signal:r.signal,searchParams:o.toUrlSearchParams({arg:i.CID.asCID(t)?`/ipfs/${t}`:t,long:!0,...r,stream:!0}),headers:r.headers});for await(const e of s.ndjson())if("Entries"in e)for(const t of e.Entries||[])yield c(n.objectToCamelWithMetadata(t));else yield c(n.objectToCamelWithMetadata(e))}));function c(e){return e.hash&&(e.cid=i.CID.parse(e.hash)),delete e.hash,e.type=1===e.type?"directory":"file",e}r.createLs=a},{"multiformats/cid":"9ooAY","../lib/object-to-camel-with-metadata.js":"1iQWC","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"1iQWC":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./object-to-camel.js");r.objectToCamelWithMetadata=function(e){const t=i.objectToCamel(e);return Object.prototype.hasOwnProperty.call(t,"mode")&&(t.mode=parseInt(t.mode,8)),Object.prototype.hasOwnProperty.call(t,"mtime")&&(t.mtime={secs:t.mtime,nsecs:t.mtimeNsecs||0},delete t.mtimeNsecs),t}},{"./object-to-camel.js":"hdPx4"}],iocNx:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){const i=await e.post("files/mkdir",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers});await i.text()}));r.createMkdir=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],jgv4R:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r,i={}){Array.isArray(t)||(t=[t]);const s=await e.post("files/mv",{signal:i.signal,searchParams:n.toUrlSearchParams({arg:t.concat(r),...i}),headers:i.headers});await s.text()}));r.createMv=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"2jkwj":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=s(e("stream-to-it/source.js"));const a=i.configure((e=>async function*(t,r={}){const i=await e.post("files/read",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,count:r.length,...r}),headers:r.headers});yield*o.default(i.body)}));r.createRead=a},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","stream-to-it/source.js":"7664L"}],"7664L":[function(e,t,r){t.exports=e=>{if(e[Symbol.asyncIterator])return e;if(e.getReader)return async function*(){const t=e.getReader();try{for(;;){const{done:e,value:r}=await t.read();if(e)return;yield r}}finally{t.releaseLock()}}();throw new Error("unknown stream")}},{}],"60cHB":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){const i=await e.post("files/rm",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers});await i.text()}));r.createRm=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"2InTg":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/object-to-camel-with-metadata.js"),s=e("../lib/configure.js"),o=e("../lib/to-url-search-params.js");const a=s.configure((e=>async function(t,r={}){const s=await e.post("files/stat",{signal:r.signal,searchParams:o.toUrlSearchParams({arg:t,...r}),headers:r.headers}),a=await s.json();return a.WithLocality=a.WithLocality||!1,(c=n.objectToCamelWithMetadata(a)).cid=i.CID.parse(c.hash),delete c.hash,c;var c}));r.createStat=a},{"multiformats/cid":"9ooAY","../lib/object-to-camel-with-metadata.js":"1iQWC","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],aa8jv:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){const i=await e.post("files/touch",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers});await i.text()}));r.createTouch=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],aw4qs:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/mode-to-string.js"),n=e("../lib/parse-mtime.js"),s=e("../lib/configure.js"),o=e("ipfs-core-utils/multipart-request"),a=e("../lib/to-url-search-params.js"),c=e("../lib/abort-signal.js"),u=e("native-abort-controller");const l=s.configure((e=>async function(t,r,s={}){const l=new u.AbortController,d=c.abortSignal(l.signal,s.signal),f=await e.post("files/write",{signal:d,searchParams:a.toUrlSearchParams({arg:t,streamChannels:!0,count:s.length,...s}),...await o.multipartRequest({content:r,path:"arg",mode:i.modeToString(s.mode),mtime:n.parseMtime(s.mtime)},l,s.headers)});await f.text()}));r.createWrite=l},{"../lib/mode-to-string.js":"bbWaj","../lib/parse-mtime.js":"aLNRF","../lib/configure.js":"hR8g6","ipfs-core-utils/multipart-request":"7TICD","../lib/to-url-search-params.js":"fT4zz","../lib/abort-signal.js":"hzxSr","native-abort-controller":"6zwoZ"}],d23S0:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./export.js"),n=e("./gen.js"),s=e("./import.js"),o=e("./info.js"),a=e("./list.js"),c=e("./rename.js"),u=e("./rm.js");r.createKey=function(e){return{export:i.createExport(e),gen:n.createGen(e),import:s.createImport(e),info:o.createInfo(e),list:a.createList(e),rename:c.createRename(e),rm:u.createRm(e)}}},{"./export.js":"kC3hv","./gen.js":"ezvwT","./import.js":"liRPy","./info.js":"4TCmX","./list.js":"91GPg","./rename.js":"etz52","./rm.js":"lHlAl"}],kC3hv:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var s=n(e("err-code"));const o=i.configure((e=>async(e,t,r={})=>{throw s.default(new Error("Not implemented"),"ERR_NOT_IMPLEMENTED")}));r.createExport=o},{"../lib/configure.js":"hR8g6","err-code":"chZjB"}],ezvwT:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/object-to-camel.js"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={type:"rsa",size:2048}){const n=await e.post("key/gen",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:t,...r}),headers:r.headers}),o=await n.json();return i.objectToCamel(o)}));r.createGen=o},{"../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],liRPy:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/object-to-camel.js"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r,n,o={}){const a=await e.post("key/import",{signal:o.signal,searchParams:s.toUrlSearchParams({arg:t,pem:r,password:n,...o}),headers:o.headers}),c=await a.json();return i.objectToCamel(c)}));r.createImport=o},{"../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"4TCmX":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var s=n(e("err-code"));const o=i.configure((e=>async(e,t={})=>{throw s.default(new Error("Not implemented"),"ERR_NOT_IMPLEMENTED")}));r.createInfo=o},{"../lib/configure.js":"hR8g6","err-code":"chZjB"}],"91GPg":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/object-to-camel.js"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("key/list",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers});return((await r.json()).Keys||[]).map((e=>i.objectToCamel(e)))}));r.createList=o},{"../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],etz52:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/object-to-camel.js"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r,n={}){const o=await e.post("key/rename",{signal:n.signal,searchParams:s.toUrlSearchParams({arg:[t,r],...n}),headers:n.headers});return i.objectToCamel(await o.json())}));r.createRename=o},{"../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],lHlAl:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/object-to-camel.js"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={}){const n=await e.post("key/rm",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:t,...r}),headers:r.headers}),o=await n.json();return i.objectToCamel(o.Keys[0])}));r.createRm=o},{"../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],dax7W:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./level.js"),n=e("./ls.js"),s=e("./tail.js");r.createLog=function(e){return{level:i.createLevel(e),ls:n.createLs(e),tail:s.createTail(e)}}},{"./level.js":"1Z9n5","./ls.js":"7ctbp","./tail.js":"3faFf"}],"1Z9n5":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/object-to-camel.js"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r,n={}){const o=await e.post("log/level",{signal:n.signal,searchParams:s.toUrlSearchParams({arg:[t,r],...n}),headers:n.headers});return i.objectToCamel(await o.json())}));r.createLevel=o},{"../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"7ctbp":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t={}){const r=await e.post("log/ls",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers});return(await r.json()).Strings}));r.createLs=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"3faFf":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function*(t={}){const r=await e.post("log/tail",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers});yield*r.ndjson()}));r.createTail=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],hAUWJ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./publish.js"),n=e("./resolve.js"),s=e("./pubsub/index.js");r.createName=function(e){return{publish:i.createPublish(e),resolve:n.createResolve(e),pubsub:s.createPubsub(e)}}},{"./publish.js":"kB8Vy","./resolve.js":"jDw6l","./pubsub/index.js":"1TMtb"}],kB8Vy:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/object-to-camel.js"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={}){const n=await e.post("name/publish",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:`${t}`,...r}),headers:r.headers});return i.objectToCamel(await n.json())}));r.createPublish=o},{"../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],jDw6l:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function*(t,r={}){const i=await e.post("name/resolve",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,stream:!0,...r}),headers:r.headers});for await(const e of i.ndjson())yield e.Path}));r.createResolve=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"1TMtb":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./cancel.js"),n=e("./state.js"),s=e("./subs.js");r.createPubsub=function(e){return{cancel:i.createCancel(e),state:n.createState(e),subs:s.createSubs(e)}}},{"./cancel.js":"0ogCj","./state.js":"9oBIl","./subs.js":"eKxDJ"}],"0ogCj":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../lib/object-to-camel.js"),n=e("../../lib/configure.js"),s=e("../../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={}){const n=await e.post("name/pubsub/cancel",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:t,...r}),headers:r.headers});return i.objectToCamel(await n.json())}));r.createCancel=o},{"../../lib/object-to-camel.js":"hdPx4","../../lib/configure.js":"hR8g6","../../lib/to-url-search-params.js":"fT4zz"}],"9oBIl":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../lib/object-to-camel.js"),n=e("../../lib/configure.js"),s=e("../../lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("name/pubsub/state",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers});return i.objectToCamel(await r.json())}));r.createState=o},{"../../lib/object-to-camel.js":"hdPx4","../../lib/configure.js":"hR8g6","../../lib/to-url-search-params.js":"fT4zz"}],eKxDJ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../lib/configure.js"),n=e("../../lib/to-url-search-params.js");const s=i.configure((e=>async function(t={}){const r=await e.post("name/pubsub/subs",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers});return(await r.json()).Strings||[]}));r.createSubs=s},{"../../lib/configure.js":"hR8g6","../../lib/to-url-search-params.js":"fT4zz"}],lIWb3:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./data.js"),n=e("./get.js"),s=e("./links.js"),o=e("./new.js"),a=e("./put.js"),c=e("./stat.js"),u=e("./patch/index.js");r.createObject=function(e,t){return{data:i.createData(t),get:n.createGet(t),links:s.createLinks(t),new:o.createNew(t),put:a.createPut(e,t),stat:c.createStat(t),patch:u.createPatch(t)}}},{"./data.js":"ef4Az","./get.js":"2uTHZ","./links.js":"10Mon","./new.js":"4VILN","./put.js":"3vtk9","./stat.js":"4TYop","./patch/index.js":"kOUgR"}],ef4Az:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={}){const n=await e.post("object/data",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:`${t instanceof Uint8Array?i.CID.decode(t):t}`,...r}),headers:r.headers}),o=await n.arrayBuffer();return new Uint8Array(o,0,o.byteLength)}));r.createData=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"2uTHZ":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js"),o=e("uint8arrays/from-string");const a=n.configure((e=>async function(t,r={}){const n=await e.post("object/get",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:`${t instanceof Uint8Array?i.CID.decode(t):t}`,dataEncoding:"base64",...r}),headers:r.headers}),a=await n.json();return{Data:o.fromString(a.Data,"base64pad"),Links:(a.Links||[]).map((e=>({Name:e.Name,Hash:i.CID.parse(e.Hash),Tsize:e.Size})))}}));r.createGet=a},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","uint8arrays/from-string":"dF7Y4"}],"10Mon":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={}){const n=await e.post("object/links",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:`${t instanceof Uint8Array?i.CID.decode(t):t}`,...r}),headers:r.headers});return((await n.json()).Links||[]).map((e=>({Name:e.Name,Tsize:e.Size,Hash:i.CID.parse(e.Hash)})))}));r.createLinks=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"4VILN":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("object/new",{signal:t.signal,searchParams:s.toUrlSearchParams({arg:t.template,...t}),headers:t.headers}),{Hash:n}=await r.json();return i.CID.parse(n)}));r.createNew=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"3vtk9":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../dag/put.js");r.createPut=(e,t)=>i.configure((r=>{const i=n.createPut(e,t);return async function(e,t={}){return i(e,{...t,format:"dag-pb",hashAlg:"sha2-256",version:0})}}))(t)},{"../lib/configure.js":"hR8g6","../dag/put.js":"e3DVQ"}],"4TYop":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r={}){const n=await e.post("object/stat",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:`${t}`,...r}),headers:r.headers}),o=await n.json();return{...o,Hash:i.CID.parse(o.Hash)}}));r.createStat=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],kOUgR:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./add-link.js"),n=e("./append-data.js"),s=e("./rm-link.js"),o=e("./set-data.js");r.createPatch=function(e){return{addLink:i.createAddLink(e),appendData:n.createAppendData(e),rmLink:s.createRmLink(e),setData:o.createSetData(e)}}},{"./add-link.js":"9EUqN","./append-data.js":"2uXuE","./rm-link.js":"6Y2ZK","./set-data.js":"SCMuD"}],"9EUqN":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../../lib/configure.js"),s=e("../../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r,n={}){const o=await e.post("object/patch/add-link",{signal:n.signal,searchParams:s.toUrlSearchParams({arg:[`${t}`,r.Name||r.name||"",(r.Hash||r.cid||"").toString()||null],...n}),headers:n.headers}),{Hash:a}=await o.json();return i.CID.parse(a)}));r.createAddLink=o},{"multiformats/cid":"9ooAY","../../lib/configure.js":"hR8g6","../../lib/to-url-search-params.js":"fT4zz"}],"2uXuE":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("ipfs-core-utils/multipart-request"),s=e("../../lib/configure.js"),o=e("../../lib/to-url-search-params.js"),a=e("../../lib/abort-signal.js"),c=e("native-abort-controller");const u=s.configure((e=>async function(t,r,s={}){const u=new c.AbortController,l=a.abortSignal(u.signal,s.signal),d=await e.post("object/patch/append-data",{signal:l,searchParams:o.toUrlSearchParams({arg:`${t}`,...s}),...await n.multipartRequest(r,u,s.headers)}),{Hash:f}=await d.json();return i.CID.parse(f)}));r.createAppendData=u},{"multiformats/cid":"9ooAY","ipfs-core-utils/multipart-request":"7TICD","../../lib/configure.js":"hR8g6","../../lib/to-url-search-params.js":"fT4zz","../../lib/abort-signal.js":"hzxSr","native-abort-controller":"6zwoZ"}],"6Y2ZK":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../../lib/configure.js"),s=e("../../lib/to-url-search-params.js");const o=n.configure((e=>async function(t,r,n={}){const o=await e.post("object/patch/rm-link",{signal:n.signal,searchParams:s.toUrlSearchParams({arg:[`${t}`,r.Name||r.name||null],...n}),headers:n.headers}),{Hash:a}=await o.json();return i.CID.parse(a)}));r.createRmLink=o},{"multiformats/cid":"9ooAY","../../lib/configure.js":"hR8g6","../../lib/to-url-search-params.js":"fT4zz"}],SCMuD:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("ipfs-core-utils/multipart-request"),s=e("../../lib/configure.js"),o=e("../../lib/to-url-search-params.js"),a=e("../../lib/abort-signal.js"),c=e("native-abort-controller");const u=s.configure((e=>async function(t,r,s={}){const u=new c.AbortController,l=a.abortSignal(u.signal,s.signal),d=await e.post("object/patch/set-data",{signal:l,searchParams:o.toUrlSearchParams({arg:[`${t}`],...s}),...await n.multipartRequest(r,u,s.headers)}),{Hash:f}=await d.json();return i.CID.parse(f)}));r.createSetData=u},{"multiformats/cid":"9ooAY","ipfs-core-utils/multipart-request":"7TICD","../../lib/configure.js":"hR8g6","../../lib/to-url-search-params.js":"fT4zz","../../lib/abort-signal.js":"hzxSr","native-abort-controller":"6zwoZ"}],"2EyML":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./add-all.js"),n=e("./add.js"),s=e("./ls.js"),o=e("./rm-all.js"),a=e("./rm.js"),c=e("./remote/index.js");r.createPin=function(e){return{addAll:i.createAddAll(e),add:n.createAdd(e),ls:s.createLs(e),rmAll:o.createRmAll(e),rm:a.createRm(e),remote:c.createRemote(e)}}},{"./add-all.js":"6SsJV","./add.js":"gNAmm","./ls.js":"4xLZT","./rm-all.js":"1RTay","./rm.js":"iRwZg","./remote/index.js":"5Qqlr"}],"6SsJV":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("ipfs-core-utils/pins/normalise-input"),o=e("../lib/to-url-search-params.js");const a=n.configure((e=>async function*(t,r={}){for await(const{path:n,recursive:a,metadata:c}of s.normaliseInput(t)){const t=await e.post("pin/add",{signal:r.signal,searchParams:o.toUrlSearchParams({...r,arg:n,recursive:a,metadata:c?JSON.stringify(c):void 0,stream:!0}),headers:r.headers});for await(const e of t.ndjson())if(e.Pins)for(const t of e.Pins)yield i.CID.parse(t);else yield i.CID.parse(e)}}));r.createAddAll=a},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","ipfs-core-utils/pins/normalise-input":"4NDJq","../lib/to-url-search-params.js":"fT4zz"}],gNAmm:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./add-all.js"),n=e("it-last"),s=e("../lib/configure.js");function o(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=o(n);r.createAdd=function(e){const t=i.createAddAll(e);return s.configure((()=>async function(e,r={}){return a.default(t([{path:e,...r}],r))}))(e)}},{"./add-all.js":"6SsJV","it-last":"cSXX9","../lib/configure.js":"hR8g6"}],"4xLZT":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");function o(e,t,r){const n={type:e,cid:i.CID.parse(t)};return r&&(n.metadata=r),n}const a=n.configure((e=>async function*(t={}){let r=[];t.paths&&(r=Array.isArray(t.paths)?t.paths:[t.paths]);const i=await e.post("pin/ls",{signal:t.signal,searchParams:s.toUrlSearchParams({...t,arg:r.map((e=>`${e}`)),stream:!0}),headers:t.headers});for await(const e of i.ndjson()){if(e.Keys){for(const t of Object.keys(e.Keys))yield o(e.Keys[t].Type,t,e.Keys[t].Metadata);return}yield o(e.Type,e.Cid,e.Metadata)}}));r.createLs=a},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"1RTay":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("ipfs-core-utils/pins/normalise-input"),o=e("../lib/to-url-search-params.js");const a=n.configure((e=>async function*(t,r={}){for await(const{path:n,recursive:a}of s.normaliseInput(t)){const t=new URLSearchParams(r.searchParams);t.append("arg",`${n}`),null!=a&&t.set("recursive",String(a));const s=await e.post("pin/rm",{signal:r.signal,headers:r.headers,searchParams:o.toUrlSearchParams({...r,arg:`${n}`,recursive:a})});for await(const e of s.ndjson())e.Pins?yield*e.Pins.map((e=>i.CID.parse(e))):yield i.CID.parse(e)}}));r.createRmAll=a},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","ipfs-core-utils/pins/normalise-input":"4NDJq","../lib/to-url-search-params.js":"fT4zz"}],iRwZg:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./rm-all.js"),n=e("it-last"),s=e("../lib/configure.js");function o(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=o(n);r.createRm=e=>{const t=i.createRmAll(e);return s.configure((()=>async function(e,r={}){return a.default(t([{path:e,...r}],r))}))(e)}},{"./rm-all.js":"1RTay","it-last":"cSXX9","../lib/configure.js":"hR8g6"}],"5Qqlr":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../lib/core.js"),n=e("./add.js"),s=e("./ls.js"),o=e("./rm.js"),a=e("./rm-all.js"),c=e("./service/index.js");r.createRemote=function(e){const t=new i.Client(e);return{add:n.createAdd(t),ls:s.createLs(t),rm:o.createRm(t),rmAll:a.createRmAll(t),service:c.createService(e)}}},{"../../lib/core.js":"3XXp5","./add.js":"6QlyE","./ls.js":"jHl8Y","./rm.js":"1hrlp","./rm-all.js":"fIlTt","./service/index.js":"78IT1"}],"6QlyE":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./utils.js");r.createAdd=function(e){return async function(t,{timeout:r,signal:n,headers:s,...o}){const a=await e.post("pin/remote/add",{timeout:r,signal:n,headers:s,searchParams:i.encodeAddParams({cid:t,...o})});return i.decodePin(await a.json())}}},{"./utils.js":"bQgDT"}],bQgDT:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../../lib/to-url-search-params.js");const s=e=>{if("string"==typeof e&&""!==e)return e;throw new TypeError("service name must be passed")},o=e=>{if(i.CID.asCID(e))return e.toString();throw new TypeError("CID instance expected instead of "+typeof e)};r.decodePin=({Name:e,Status:t,Cid:r})=>({cid:i.CID.parse(r),name:e,status:t}),r.encodeAddParams=({cid:e,service:t,background:r,name:i,origins:a})=>{const c=n.toUrlSearchParams({arg:o(e),service:s(t),name:i,background:!!r||void 0});if(a)for(const e of a)c.append("origin",e.toString());return c},r.encodeCID=o,r.encodeQuery=({service:e,cid:t,name:r,status:i,all:a})=>{const c=n.toUrlSearchParams({service:s(e),name:r,force:!!a||void 0});if(t)for(const e of t)c.append("cid",o(e));if(i)for(const e of i)c.append("status",e);return c},r.encodeService=s},{"multiformats/cid":"9ooAY","../../lib/to-url-search-params.js":"fT4zz"}],jHl8Y:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./utils.js");r.createLs=function(e){return async function*({timeout:t,signal:r,headers:n,...s}){const o=await e.post("pin/remote/ls",{timeout:t,signal:r,headers:n,searchParams:i.encodeQuery(s)});for await(const e of o.ndjson())yield i.decodePin(e)}}},{"./utils.js":"bQgDT"}],"1hrlp":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./utils.js");r.createRm=function(e){return async function({timeout:t,signal:r,headers:n,...s}){await e.post("pin/remote/rm",{timeout:t,signal:r,headers:n,searchParams:i.encodeQuery({...s,all:!1})})}}},{"./utils.js":"bQgDT"}],fIlTt:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./utils.js");r.createRmAll=function(e){return async function({timeout:t,signal:r,headers:n,...s}){await e.post("pin/remote/rm",{timeout:t,signal:r,headers:n,searchParams:i.encodeQuery({...s,all:!0})})}}},{"./utils.js":"bQgDT"}],"78IT1":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../../lib/core.js"),n=e("./add.js"),s=e("./ls.js"),o=e("./rm.js");r.createService=function(e){const t=new i.Client(e);return{add:n.createAdd(t),ls:s.createLs(t),rm:o.createRm(t)}}},{"../../../lib/core.js":"3XXp5","./add.js":"jw6p7","./ls.js":"d55dc","./rm.js":"5AjIT"}],jw6p7:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../../lib/to-url-search-params.js"),n=e("./utils.js");r.createAdd=function(e){return async function(t,r){const{endpoint:s,key:o,headers:a,timeout:c,signal:u}=r;await e.post("pin/remote/service/add",{timeout:c,signal:u,searchParams:i.toUrlSearchParams({arg:[t,n.encodeEndpoint(s),o]}),headers:a})}}},{"../../../lib/to-url-search-params.js":"fT4zz","./utils.js":"6pYda"}],"6pYda":[function(e,t,r){"use strict";function i(e){switch(e.Status){case"valid":{const{Pinning:t,Pinned:r,Queued:i,Failed:n}=e.PinCount;return{status:"valid",pinCount:{queued:i,pinning:t,pinned:r,failed:n}}}case"invalid":return{status:"invalid"};default:return{status:e.Status}}}Object.defineProperty(r,"__esModule",{value:!0}),r.decodeRemoteService=function(e){return{service:e.Service,endpoint:new URL(e.ApiEndpoint),...e.Stat&&{stat:i(e.Stat)}}},r.decodeStat=i,r.encodeEndpoint=function(e){const t=String(e);if("undefined"===t)throw Error("endpoint is required");return"/"===t[t.length-1]?t.slice(0,-1):t}},{}],d55dc:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../../lib/to-url-search-params.js"),n=e("./utils.js");r.createLs=function(e){return async function(t={}){const{stat:r,headers:s,timeout:o,signal:a}=t,c=await e.post("pin/remote/service/ls",{timeout:o,signal:a,headers:s,searchParams:!0===r?i.toUrlSearchParams({stat:r}):void 0}),{RemoteServices:u}=await c.json();return u.map(n.decodeRemoteService)}}},{"../../../lib/to-url-search-params.js":"fT4zz","./utils.js":"6pYda"}],"5AjIT":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../../../lib/to-url-search-params.js");r.createRm=function(e){return async function(t,r={}){await e.post("pin/remote/service/rm",{signal:r.signal,headers:r.headers,searchParams:i.toUrlSearchParams({arg:t})})}}},{"../../../lib/to-url-search-params.js":"fT4zz"}],"9yoEA":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./ls.js"),n=e("./peers.js"),s=e("./publish.js"),o=e("./subscribe.js"),a=e("./unsubscribe.js"),c=e("./subscription-tracker.js");r.createPubsub=function(e){const t=new c.SubscriptionTracker;return{ls:i.createLs(e),peers:n.createPeers(e),publish:s.createPublish(e),subscribe:o.createSubscribe(e,t),unsubscribe:a.createUnsubscribe(e,t)}}},{"./ls.js":"2yozO","./peers.js":"5ZIFR","./publish.js":"3DcXt","./subscribe.js":"02Av6","./unsubscribe.js":"97bmo","./subscription-tracker.js":"eg0Db"}],"2yozO":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t={}){const{Strings:r}=await(await e.post("pubsub/ls",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers})).json();return r||[]}));r.createLs=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"5ZIFR":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){const i=await e.post("pubsub/peers",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers}),{Strings:s}=await i.json();return s||[]}));r.createPeers=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"3DcXt":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js"),s=e("ipfs-core-utils/multipart-request"),o=e("../lib/abort-signal.js"),a=e("native-abort-controller");const c=i.configure((e=>async function(t,r,i={}){const c=n.toUrlSearchParams({arg:t,...i}),u=new a.AbortController,l=o.abortSignal(u.signal,i.signal),d=await e.post("pubsub/pub",{signal:l,searchParams:c,...await s.multipartRequest(r,u,i.headers)});await d.text()}));r.createPublish=c},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","ipfs-core-utils/multipart-request":"7TICD","../lib/abort-signal.js":"hzxSr","native-abort-controller":"6zwoZ"}],"02Av6":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("uint8arrays/from-string"),n=e("uint8arrays/to-string"),s=e("debug"),o=e("../lib/configure.js"),a=e("../lib/to-url-search-params.js");function c(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}const u=c(s).default("ipfs-http-client:pubsub:subscribe");const l=e=>{switch(e.type){case"aborted":case"abort":return!0;default:return"AbortError"===e.name}};r.createSubscribe=(e,t)=>o.configure((e=>async function(r,s,o={}){let c,d;o.signal=t.subscribe(r,s,o.signal);const f=new Promise(((e,t)=>{c=e,d=t})),h=setTimeout((()=>c()),1e3);return e.post("pubsub/sub",{signal:o.signal,searchParams:a.toUrlSearchParams({arg:r,...o}),headers:o.headers}).catch((e=>{t.unsubscribe(r,s),d(e)})).then((e=>{clearTimeout(h),e&&(!async function(e,{onMessage:t,onEnd:r,onError:s}){s=s||u;try{for await(const r of e.ndjson())try{if(!r.from)continue;t({from:n.toString(i.fromString(r.from,"base64pad"),"base58btc"),data:i.fromString(r.data,"base64pad"),seqno:i.fromString(r.seqno,"base64pad"),topicIDs:r.topicIDs})}catch(e){e.message=`Failed to parse pubsub message: ${e.message}`,s(e,!1,r)}}catch(e){l(e)||s(e,!0)}finally{r()}}(e,{onMessage:s,onEnd:()=>t.unsubscribe(r,s),onError:o.onError}),c())})),f}))(e)},{"uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB",debug:"bO5wM","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"97bmo":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});r.createUnsubscribe=(e,t)=>async function(e,r){t.unsubscribe(e,r)}},{}],eg0Db:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("native-abort-controller");r.SubscriptionTracker=class{constructor(){this._subs=new Map}subscribe(e,t,r){const n=this._subs.get(e)||[];if(n.find((e=>e.handler===t)))throw new Error(`Already subscribed to ${e} with this handler`);const s=new i.AbortController;return this._subs.set(e,[{handler:t,controller:s}].concat(n)),r&&r.addEventListener("abort",(()=>this.unsubscribe(e,t))),s.signal}unsubscribe(e,t){const r=this._subs.get(e)||[];let i;t?(this._subs.set(e,r.filter((e=>e.handler!==t))),i=r.filter((e=>e.handler===t))):(this._subs.set(e,[]),i=r),(this._subs.get(e)||[]).length||this._subs.delete(e),i.forEach((e=>e.controller.abort()))}}},{"native-abort-controller":"6zwoZ"}],"6sM7A":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/object-to-camel.js"),s=e("../lib/configure.js"),o=e("../lib/to-url-search-params.js"),a=e("./local.js");const c=s.configure(((e,t)=>Object.assign((async function*(t,r={}){const s=Array.isArray(t)?t:[t],a=await e.post("refs",{signal:r.signal,searchParams:o.toUrlSearchParams({arg:s.map((e=>`${e instanceof Uint8Array?i.CID.decode(e):e}`)),...r}),headers:r.headers,transform:n.objectToCamel});yield*a.ndjson()}),{local:a.createLocal(t)})));r.createRefs=c},{"multiformats/cid":"9ooAY","../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz","./local.js":"hVVLK"}],hVVLK:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/object-to-camel.js"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function*(t={}){const r=await e.post("refs/local",{signal:t.signal,transform:i.objectToCamel,searchParams:s.toUrlSearchParams(t),headers:t.headers});yield*r.ndjson()}));r.createLocal=o},{"../lib/object-to-camel.js":"hdPx4","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],lf1uS:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./gc.js"),n=e("./stat.js"),s=e("./version.js");r.createRepo=function(e){return{gc:i.createGc(e),stat:n.createStat(e),version:s.createVersion(e)}}},{"./gc.js":"5kVJA","./stat.js":"kW3mJ","./version.js":"bU0xW"}],"5kVJA":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function*(t={}){const r=await e.post("repo/gc",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers,transform:e=>({err:e.Error?new Error(e.Error):null,cid:(e.Key||{})["/"]?i.CID.parse(e.Key["/"]):null})});yield*r.ndjson()}));r.createGc=o},{"multiformats/cid":"9ooAY","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],kW3mJ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t={}){const r=await e.post("repo/stat",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers}),i=await r.json();return{numObjects:BigInt(i.NumObjects),repoSize:BigInt(i.RepoSize),repoPath:i.RepoPath,version:i.Version,storageMax:BigInt(i.StorageMax)}}));r.createStat=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],bU0xW:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t={}){return(await(await e.post("repo/version",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers})).json()).Version}));r.createVersion=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"8ekdG":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../bitswap/stat.js"),n=e("../repo/stat.js"),s=e("./bw.js");r.createStats=function(e){return{bitswap:i.createStat(e),repo:n.createStat(e),bw:s.createBw(e)}}},{"../bitswap/stat.js":"3Q0KE","../repo/stat.js":"kW3mJ","./bw.js":"cvdwA"}],cvdwA:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function*(t={}){const r=await e.post("stats/bw",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers,transform:e=>({totalIn:BigInt(e.TotalIn),totalOut:BigInt(e.TotalOut),rateIn:parseFloat(e.RateIn),rateOut:parseFloat(e.RateOut)})});yield*r.ndjson()}));r.createBw=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"9n7fV":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./addrs.js"),n=e("./connect.js"),s=e("./disconnect.js"),o=e("./local-addrs.js"),a=e("./peers.js");r.createSwarm=function(e){return{addrs:i.createAddrs(e),connect:n.createConnect(e),disconnect:s.createDisconnect(e),localAddrs:o.createLocalAddrs(e),peers:a.createPeers(e)}}},{"./addrs.js":"fxhEW","./connect.js":"cuaL2","./disconnect.js":"820vp","./local-addrs.js":"dEgBz","./peers.js":"jZx0P"}],fxhEW:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("swarm/addrs",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers}),{Addrs:n}=await r.json();return Object.keys(n).map((e=>({id:e,addrs:(n[e]||[]).map((e=>new i.Multiaddr(e)))})))}));r.createAddrs=o},{multiaddr:"8Mu1u","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],cuaL2:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){const i=await e.post("swarm/connect",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers}),{Strings:s}=await i.json();return s||[]}));r.createConnect=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],"820vp":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../lib/configure.js"),n=e("../lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){const i=await e.post("swarm/disconnect",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers}),{Strings:s}=await i.json();return s||[]}));r.createDisconnect=s},{"../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],dEgBz:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("swarm/addrs/local",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers}),{Strings:n}=await r.json();return(n||[]).map((e=>new i.Multiaddr(e)))}));r.createLocalAddrs=o},{multiaddr:"8Mu1u","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],jZx0P:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiaddr"),n=e("../lib/configure.js"),s=e("../lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("swarm/peers",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers}),{Peers:n}=await r.json();return(n||[]).map((e=>({addr:new i.Multiaddr(e.Addr),peer:e.Peer,muxer:e.Muxer,latency:e.Latency,streams:e.Streams,direction:null==e.Direction?void 0:0===e.Direction?"inbound":"outbound"})))}));r.createPeers=o},{multiaddr:"8Mu1u","../lib/configure.js":"hR8g6","../lib/to-url-search-params.js":"fT4zz"}],bh9eV:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./add-all.js"),n=e("it-last"),s=e("./lib/configure.js");function o(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=o(n);r.createAdd=function(e){const t=i.createAddAll(e);return s.configure((()=>async function(e,r={}){return await a.default(t(e,r))}))(e)}},{"./add-all.js":"dygjF","it-last":"cSXX9","./lib/configure.js":"hR8g6"}],dygjF:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("./lib/object-to-camel.js"),s=e("./lib/configure.js"),o=e("ipfs-core-utils/multipart-request"),a=e("./lib/to-url-search-params.js"),c=e("./lib/abort-signal.js"),u=e("native-abort-controller");const l=s.configure((e=>async function*(t,r={}){const i=new u.AbortController,s=c.abortSignal(i.signal,r.signal),{headers:l,body:f,total:p,parts:g}=await o.multipartRequest(t,i,r.headers),[y,m]="function"==typeof r.progress?d(p,g,r.progress):[void 0,void 0],b=await e.post("add",{searchParams:a.toUrlSearchParams({"stream-channels":!0,...r,progress:Boolean(y)}),onUploadProgress:m,signal:s,headers:l,body:f});for await(let e of b.ndjson())e=n.objectToCamel(e),void 0!==e.hash?yield h(e):y&&y(e.bytes||0,e.name)})),d=(e,t,r)=>t?[void 0,f(e,t,r)]:[r,void 0],f=(e,t,r)=>{let i=0;const n=t.length;return({loaded:s,total:o})=>{const a=Math.floor(s/o*e);for(;iasync function*(t,r={}){const i=await e.post("cat",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t.toString(),...r}),headers:r.headers});yield*i.iterator()}));r.createCat=s},{"./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],d7oos:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/configure.js"),n=e("./lib/to-url-search-params.js");const s=i.configure((e=>async(t={})=>(await e.post("commands",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers})).json()));r.createCommands=s},{"./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],"6WsTM":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/configure.js"),n=e("./lib/to-url-search-params.js");const s=i.configure((e=>async(t,r={})=>{const i=await e.post("dns",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers});return(await i.json()).Path}));r.createDns=s},{"./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],e09lW:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./lib/configure.js").configure((e=>()=>{const t=new URL(e.opts.base||"");return{host:t.hostname,port:t.port,protocol:t.protocol,pathname:t.pathname,"api-path":t.pathname}}));r.createGetEndpointConfig=i},{"./lib/configure.js":"hR8g6"}],"9dl4d":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("./lib/configure.js"),s=e("./lib/to-url-search-params.js");const o=n.configure((e=>async function*(t,r={}){const n={arg:`${t instanceof Uint8Array?i.CID.decode(t):t}`,...r};n.compressionLevel&&(n["compression-level"]=n.compressionLevel,delete n.compressionLevel);const o=await e.post("get",{signal:r.signal,searchParams:s.toUrlSearchParams(n),headers:r.headers});yield*o.iterator()}));r.createGet=o},{"multiformats/cid":"9ooAY","./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],iMd7i:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/object-to-camel.js"),n=e("multiaddr"),s=e("./lib/configure.js"),o=e("./lib/to-url-search-params.js");const a=s.configure((e=>async function(t={}){const r=await e.post("id",{signal:t.signal,searchParams:o.toUrlSearchParams({arg:t.peerId?t.peerId.toString():void 0,...t}),headers:t.headers}),s=await r.json(),a={...i.objectToCamel(s)};return a.addresses&&(a.addresses=a.addresses.map((e=>new n.Multiaddr(e)))),a}));r.createId=a},{"./lib/object-to-camel.js":"hdPx4",multiaddr:"8Mu1u","./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],"1Ujko":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./id.js");r.createIsOnline=e=>{const t=i.createId(e);return async function(e={}){const r=await t(e);return Boolean(r&&r.addresses&&r.addresses.length)}}},{"./id.js":"iMd7i"}],jIkVK:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("./lib/configure.js"),s=e("./lib/to-url-search-params.js"),o=e("./files/stat.js");const a=n.configure(((e,t)=>async function*(r,n={}){const a=`${r instanceof Uint8Array?i.CID.decode(r):r}`;async function u(e){let r=e.Hash;if(r.includes("/")){const e=r.startsWith("/ipfs/")?r:`/ipfs/${r}`;r=(await o.createStat(t)(e)).cid}else r=i.CID.parse(r);const n={name:e.Name,path:a+(e.Name?`/${e.Name}`:""),size:e.Size,cid:r,type:c(e)};return e.Mode&&(n.mode=parseInt(e.Mode,8)),void 0!==e.Mtime&&null!==e.Mtime&&(n.mtime={secs:e.Mtime},void 0!==e.MtimeNsecs&&null!==e.MtimeNsecs&&(n.mtime.nsecs=e.MtimeNsecs)),n}const l=await e.post("ls",{signal:n.signal,searchParams:s.toUrlSearchParams({arg:a,...n}),headers:n.headers});for await(let e of l.ndjson()){if(e=e.Objects,!e)throw new Error("expected .Objects in results");if(e=e[0],!e)throw new Error("expected one array in results.Objects");const t=e.Links;if(!Array.isArray(t))throw new Error("expected one array in results.Objects[0].Links");if(!t.length)return void(yield u(e));yield*t.map(u)}}));function c(e){switch(e.Type){case 1:case 5:return"dir";default:return"file"}}r.createLs=a},{"multiformats/cid":"9ooAY","./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz","./files/stat.js":"2InTg"}],"5Ghx1":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/object-to-camel.js"),n=e("./lib/configure.js"),s=e("./lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("dns",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers});return i.objectToCamel(await r.json())}));r.createMount=o},{"./lib/object-to-camel.js":"hdPx4","./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],fIZQw:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/object-to-camel.js"),n=e("./lib/configure.js"),s=e("./lib/to-url-search-params.js");const o=n.configure((e=>async function*(t,r={}){const n=await e.post("ping",{signal:r.signal,searchParams:s.toUrlSearchParams({arg:`${t}`,...r}),headers:r.headers,transform:i.objectToCamel});yield*n.ndjson()}));r.createPing=o},{"./lib/object-to-camel.js":"hdPx4","./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],fqXrw:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/configure.js"),n=e("./lib/to-url-search-params.js");const s=i.configure((e=>async function(t,r={}){const i=await e.post("resolve",{signal:r.signal,searchParams:n.toUrlSearchParams({arg:t,...r}),headers:r.headers}),{Path:s}=await i.json();return s}));r.createResolve=s},{"./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],"4YTOj":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/configure.js");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var s=n(e("err-code"));const o=i.configure((e=>async(e={})=>{throw s.default(new Error("Not implemented"),"ERR_NOT_IMPLEMENTED")}));r.createStart=o},{"./lib/configure.js":"hR8g6","err-code":"chZjB"}],j2dHM:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/configure.js"),n=e("./lib/to-url-search-params.js");const s=i.configure((e=>async function(t={}){const r=await e.post("shutdown",{signal:t.signal,searchParams:n.toUrlSearchParams(t),headers:t.headers});await r.text()}));r.createStop=s},{"./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],k3Foi:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./lib/object-to-camel.js"),n=e("./lib/configure.js"),s=e("./lib/to-url-search-params.js");const o=n.configure((e=>async function(t={}){const r=await e.post("version",{signal:t.signal,searchParams:s.toUrlSearchParams(t),headers:t.headers});return{...i.objectToCamel(await r.json()),"ipfs-http-client":"1.0.0"}}));r.createVersion=o},{"./lib/object-to-camel.js":"hdPx4","./lib/configure.js":"hR8g6","./lib/to-url-search-params.js":"fT4zz"}],jQSIS:[function(e,t,r){"use strict";const i=e("../http");async function*n(e,t){const r=new i,n=await r.get(e,t);yield*n.iterator()}t.exports=(e,t)=>({path:decodeURIComponent(new URL(e).pathname.split("/").pop()||""),content:n(e,t)})},{"../http":"ifXXn"}],eStoI:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("libp2p-websockets"),n=e("libp2p-webrtc-star"),s=e("libp2p-mplex"),o=e("@chainsafe/libp2p-noise"),a=e("libp2p-kad-dht"),c=e("libp2p-gossipsub"),u=e("./utils/ipns.js");function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var d=l(i),f=l(n),h=l(s),p=l(a),g=l(c);r.libp2pConfig=function(){return{dialer:{maxParallelDials:150,maxDialsPerPeer:4,dialTimeout:1e4},modules:{transport:[d.default,f.default],streamMuxer:[h.default],connEncryption:[o.NOISE],peerDiscovery:[],dht:p.default,pubsub:g.default},config:{peerDiscovery:{autoDial:!0,bootstrap:{enabled:!0},webRTCStar:{enabled:!0}},dht:{kBucketSize:20,enabled:!1,clientMode:!0,randomWalk:{enabled:!1},validators:{ipns:u.validator},selectors:{ipns:u.selector}},pubsub:{enabled:!0,emitSelf:!0},nat:{enabled:!1}},metrics:{enabled:!0},peerStore:{persistence:!0,threshold:1}}}},{"libp2p-websockets":"e2AFa","libp2p-webrtc-star":"jtxJ4","libp2p-mplex":"6n2fc","@chainsafe/libp2p-noise":"5JB8e","libp2p-kad-dht":"lEgzz","libp2p-gossipsub":"eSowE","./utils/ipns.js":"2X3ZY"}],e2AFa:[function(e,t,r){"use strict";const i=e("it-ws/client"),n=e("class-is"),s=e("multiaddr-to-uri"),{AbortError:o}=e("abortable-iterator"),a=e("p-defer"),c=e("debug"),u=c("libp2p:websockets");u.error=c("libp2p:websockets:error");const l=e("ipfs-utils/src/env"),d=e("./listener"),f=e("./socket-to-conn"),h=e("./filters");t.exports=n(class{constructor({upgrader:e,filter:t}){if(!e)throw new Error("An upgrader must be provided. See https://github.com/libp2p/interface-transport#upgrader.");this._upgrader=e,this._filter=t}async dial(e,t={}){u("dialing %s",e);const r=await this._connect(e,t),i=f(r,{remoteAddr:e,signal:t.signal});u("new outbound connection %s",i.remoteAddr);const n=await this._upgrader.upgradeOutbound(i);return u("outbound connection %s upgraded",i.remoteAddr),n}async _connect(e,t={}){if(t.signal&&t.signal.aborted)throw new o;const r=e.toOptions();u("dialing %s:%s",r.host,r.port);const n=a(),c=e=>{const t=`connection error: ${e.message}`;u.error(t),n.reject(e)},l=i(s(e),Object.assign({binary:!0},t));if(l.socket.on?l.socket.on("error",c):l.socket.onerror=c,!t.signal)return await Promise.race([l.connected(),n.promise]),u("connected %s",e),l;let d;const f=new Promise(((e,r)=>{if(d=()=>{r(new o),setTimeout((()=>{l.close()}))},t.signal.aborted)return d();t.signal.addEventListener("abort",d)}));try{await Promise.race([f,n.promise,l.connected()])}finally{t.signal.removeEventListener("abort",d)}return u("connected %s",e),l}createListener(e={},t){return"function"==typeof e&&(t=e,e={}),d({handler:t,upgrader:this._upgrader},e)}filter(e){return e=Array.isArray(e)?e:[e],this._filter?this._filter(e):l.isBrowser||l.isWebWorker?h.dnsWss(e):h.all(e)}},{className:"WebSockets",symbolName:"@libp2p/js-libp2p-websockets/websockets"})},{"it-ws/client":"3ilsV","class-is":"gx31A","multiaddr-to-uri":"4PPH7","abortable-iterator":"awlU8","p-defer":"5rKSv",debug:"bO5wM","ipfs-utils/src/env":"flyHr","./listener":"8AR2t","./socket-to-conn":"9P0w8","./filters":"f6X4K"}],"3ilsV":[function(e,t,r){"use strict";var i=e("./web-socket"),n=e("./duplex"),s=e("./ws-url");t.exports=function(e,t={}){const r="undefined"==typeof window?{}:window.location,o=s(e,r),a=new i(o,t.websocket),c=n(a,t);return c.remoteAddress=o,c.close=()=>new Promise(((e,t)=>{a.addEventListener("close",e),a.close()})),c.destroy=()=>{a.terminate?a.terminate():a.close()},c.socket=a,c},t.exports.connect=t.exports},{"./web-socket":"S1OKn","./duplex":"l5069","./ws-url":"kgph9"}],S1OKn:[function(e,t,r){t.exports="undefined"==typeof WebSocket?e("ws"):WebSocket},{ws:"lHksA"}],l5069:[function(e,t,r){const i=e("./source"),n=e("./sink");t.exports=(e,t)=>{(t=t||{}).binaryType?e.binaryType=t.binaryType:t.binary&&(e.binaryType="arraybuffer");const r={sink:n(e,t),source:i(e,t),connected:()=>r.source.connected()};return r}},{"./source":"2FpyK","./sink":"6GqBJ"}],"2FpyK":[function(e,t,r){const{Buffer:i}=e("buffer"),{EventIterator:n}=e("event-iterator");t.exports=e=>{const t=e.removeEventListener||e.removeListener,r=async function*(){const r=new n((({push:r,stop:i,fail:n})=>(e.addEventListener("message",r),e.addEventListener("error",n),e.addEventListener("close",i),()=>{t.call(e,"message",r),t.call(e,"error",n),t.call(e,"close",i)})),{highWaterMark:1/0});for await(const{data:e}of r)yield(s=e,s instanceof ArrayBuffer||null!=s&&null!=s.constructor&&"ArrayBuffer"===s.constructor.name&&"number"==typeof s.byteLength?i.from(e):e);var s}();let s,o=1===e.readyState;return e.addEventListener("open",(()=>{o=!0,s=null})),e.addEventListener("close",(()=>{o=!1,s=null})),e.addEventListener("error",(e=>{o||(s=e)})),r.connected=()=>new Promise(((r,i)=>{if(o)return r();if(s)return i(s);const n=r=>{t.call(e,"open",a),t.call(e,"error",c),r()},a=()=>n(r),c=e=>n((()=>i(e)));e.addEventListener("open",a),e.addEventListener("error",c)})),r}},{buffer:"etowf","event-iterator":"atALZ"}],atALZ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=e("./event-iterator");r.EventIterator=i.EventIterator,r.subscribe=function(e,t,r){return new i.EventIterator((({push:r})=>(this.addEventListener(e,r,t),()=>this.removeEventListener(e,r,t))),r)},r.default=i.EventIterator},{"./event-iterator":"eQdTI"}],eQdTI:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});class i{constructor(){this.pullQueue=[],this.pushQueue=[],this.eventHandlers={},this.isPaused=!1,this.isStopped=!1}push(e){if(this.isStopped)return;const t={value:e,done:!1};if(this.pullQueue.length){const e=this.pullQueue.shift();e&&e.resolve(t)}else this.pushQueue.push(Promise.resolve(t)),void 0!==this.highWaterMark&&this.pushQueue.length>=this.highWaterMark&&!this.isPaused&&(this.isPaused=!0,this.eventHandlers.highWater?this.eventHandlers.highWater():console&&console.warn(`EventIterator queue reached ${this.pushQueue.length} items`))}stop(){if(!this.isStopped){this.isStopped=!0,this.remove();for(const e of this.pullQueue)e.resolve({value:void 0,done:!0});this.pullQueue.length=0}}fail(e){if(!this.isStopped)if(this.isStopped=!0,this.remove(),this.pullQueue.length){for(const t of this.pullQueue)t.reject(e);this.pullQueue.length=0}else{const t=Promise.reject(e);t.catch((()=>{})),this.pushQueue.push(t)}}remove(){Promise.resolve().then((()=>{this.removeCallback&&this.removeCallback()}))}[Symbol.asyncIterator](){return{next:e=>{const t=this.pushQueue.shift();return t?(void 0!==this.lowWaterMark&&this.pushQueue.length<=this.lowWaterMark&&this.isPaused&&(this.isPaused=!1,this.eventHandlers.lowWater&&this.eventHandlers.lowWater()),t):this.isStopped?Promise.resolve({value:void 0,done:!0}):new Promise(((e,t)=>{this.pullQueue.push({resolve:e,reject:t})}))},return:()=>(this.isStopped=!0,this.pushQueue.length=0,this.remove(),Promise.resolve({value:void 0,done:!0}))}}}class n{constructor(e,{highWaterMark:t=100,lowWaterMark:r=1}={}){const n=new i;n.highWaterMark=t,n.lowWaterMark=r,n.removeCallback=e({push:e=>n.push(e),stop:()=>n.stop(),fail:e=>n.fail(e),on:(e,t)=>{n.eventHandlers[e]=t}})||(()=>{}),this[Symbol.asyncIterator]=()=>n[Symbol.asyncIterator](),Object.freeze(this)}}r.EventIterator=n,r.default=n},{}],"6GqBJ":[function(e,t,r){const i=e("./ready");t.exports=(e,t)=>((t=t||{}).closeOnEnd=!1!==t.closeOnEnd,async r=>{for await(const t of r){try{await i(e)}catch(e){if("socket closed"===e.message)break;throw e}e.send(t)}if(t.closeOnEnd&&e.readyState<=1)return new Promise(((t,r)=>{e.addEventListener("close",(e=>{if(e.wasClean||1006===e.code)t();else{const t=Object.assign(new Error("ws error"),{event:e});r(t)}})),setTimeout((()=>e.close()))}))})},{"./ready":"3cCUJ"}],"3cCUJ":[function(e,t,r){t.exports=async e=>{if(e.readyState>=2)throw new Error("socket closed");if(1!==e.readyState)return new Promise(((t,r)=>{const i=e&&(e.removeEventListener||e.removeListener);function n(){"function"==typeof i&&(i.call(e,"open",s),i.call(e,"error",o))}function s(){n(),t()}function o(e){n(),r(e)}e.addEventListener("open",s),e.addEventListener("error",o)}))}},{}],kgph9:[function(e,t,r){const{relative:i}=e("iso-url"),n={http:"ws",https:"wss"};t.exports=(e,t)=>i(e,t,n,"ws")},{"iso-url":"86VPZ"}],"8AR2t":[function(e,t,r){"use strict";t.exports=function(){throw new Error("WebSocket Servers can not be created in the browser!")}},{}],"9P0w8":[function(e,t,r){"use strict";const i=e("abortable-iterator"),{CLOSE_TIMEOUT:n}=e("./constants"),s=e("libp2p-utils/src/ip-port-to-multiaddr"),o=e("p-timeout"),a=e("debug"),c=a("libp2p:websockets:socket");c.error=a("libp2p:websockets:socket:error"),t.exports=(e,t={})=>{const r={async sink(r){t.signal&&(r=i(r,t.signal));try{await e.sink(async function*(){for await(const e of r)yield e instanceof Uint8Array?e:e.slice()}())}catch(e){"aborted"!==e.type&&c.error(e)}},source:t.signal?i(e.source,t.signal):e.source,conn:e,localAddr:t.localAddr||(e.localAddress&&e.localPort?s(e.localAddress,e.localPort):void 0),remoteAddr:t.remoteAddr||s(e.remoteAddress,e.remotePort),timeline:{open:Date.now()},async close(){const t=Date.now();try{await o(e.close(),n)}catch(i){const{host:n,port:s}=r.remoteAddr.toOptions();c("timeout closing stream to %s:%s after %dms, destroying it manually",n,s,Date.now()-t),e.destroy()}finally{r.timeline.close=Date.now()}}};return e.socket.once&&e.socket.once("close",(()=>{r.timeline.close||(r.timeline.close=Date.now())})),r}},{"abortable-iterator":"awlU8","./constants":"7O7y1","libp2p-utils/src/ip-port-to-multiaddr":"WM46A","p-timeout":"hP9Ay",debug:"bO5wM"}],"7O7y1":[function(e,t,r){"use strict";r.CODE_P2P=421,r.CODE_CIRCUIT=290,r.CODE_TCP=6,r.CODE_WS=477,r.CODE_WSS=478,r.CLOSE_TIMEOUT=2e3},{}],WM46A:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:ip-port-to-multiaddr"),{error:i("libp2p:ip-port-to-multiaddr:err")}),{Multiaddr:s}=e("multiaddr"),o=e("err-code"),{Address4:a,Address6:c}=e("ip-address"),u={ERR_INVALID_IP_PARAMETER:"ERR_INVALID_IP_PARAMETER",ERR_INVALID_PORT_PARAMETER:"ERR_INVALID_PORT_PARAMETER",ERR_INVALID_IP:"ERR_INVALID_IP"};t.exports=function(e,t){if("string"!=typeof e)throw o(new Error(`invalid ip provided: ${e}`),u.ERR_INVALID_IP_PARAMETER);if("string"==typeof t&&(t=parseInt(t)),isNaN(t))throw o(new Error(`invalid port provided: ${t}`),u.ERR_INVALID_PORT_PARAMETER);try{return new a(e),new s(`/ip4/${e}/tcp/${t}`)}catch{}try{const r=new c(e);return r.is4()?new s(`/ip4/${r.to4().correctForm()}/tcp/${t}`):new s(`/ip6/${e}/tcp/${t}`)}catch(r){const i=`invalid ip:port for creating a multiaddr: ${e}:${t}`;throw n.error(i),o(new Error(i),u.ERR_INVALID_IP)}},t.exports.Errors=u},{debug:"bO5wM",multiaddr:"8Mu1u","err-code":"chZjB","ip-address":"14vMS"}],"14vMS":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"Address4",(()=>n.Address4)),i.export(r,"Address6",(()=>s.Address6)),i.export(r,"AddressError",(()=>o.AddressError)),i.export(r,"v6",(()=>a));var n=e("./lib/ipv4"),s=e("./lib/ipv6"),o=e("./lib/address-error");const a={helpers:e("./lib/v6/helpers")}},{"./lib/ipv4":"blUQX","./lib/ipv6":"a8cEK","./lib/address-error":"fmci6","./lib/v6/helpers":"hT0Uq","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],blUQX:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"Address4",(()=>u));var n=e("./common"),s=e("./v4/constants"),o=e("./address-error"),a=e("jsbn"),c=e("sprintf-js");class u{constructor(e){this.groups=s.GROUPS,this.parsedAddress=[],this.parsedSubnet="",this.subnet="/32",this.subnetMask=32,this.v4=!0,this.isCorrect=n.isCorrect(s.BITS),this.isInSubnet=n.isInSubnet,this.address=e;const t=s.RE_SUBNET_STRING.exec(e);if(t){if(this.parsedSubnet=t[0].replace("/",""),this.subnetMask=parseInt(this.parsedSubnet,10),this.subnet=`/${this.subnetMask}`,this.subnetMask<0||this.subnetMask>s.BITS)throw new o.AddressError("Invalid subnet mask.");e=e.replace(s.RE_SUBNET_STRING,"")}this.addressMinusSuffix=e,this.parsedAddress=this.parse(e)}static isValid(e){try{return new u(e),!0}catch(e){return!1}}parse(e){const t=e.split(".");if(!e.match(s.RE_ADDRESS))throw new o.AddressError("Invalid IPv4 address.");return t}correctForm(){return this.parsedAddress.map((e=>parseInt(e,10))).join(".")}static fromHex(e){const t=e.replace(/:/g,"").padStart(8,"0"),r=[];let i;for(i=0;i<8;i+=2){const e=t.slice(i,i+2);r.push(parseInt(e,16))}return new u(r.join("."))}static fromInteger(e){return u.fromHex(e.toString(16))}static fromArpa(e){const t=e.replace(/(\.in-addr\.arpa)?\.$/,"").split(".").reverse().join(".");return new u(t)}toHex(){return this.parsedAddress.map((e=>c.sprintf("%02x",parseInt(e,10)))).join(":")}toArray(){return this.parsedAddress.map((e=>parseInt(e,10)))}toGroup6(){const e=[];let t;for(t=0;tc.sprintf("%02x",parseInt(e,10)))).join(""),16)}_startAddress(){return new a.BigInteger(this.mask()+"0".repeat(s.BITS-this.subnetMask),2)}startAddress(){return u.fromBigInteger(this._startAddress())}startAddressExclusive(){const e=new a.BigInteger("1");return u.fromBigInteger(this._startAddress().add(e))}_endAddress(){return new a.BigInteger(this.mask()+"1".repeat(s.BITS-this.subnetMask),2)}endAddress(){return u.fromBigInteger(this._endAddress())}endAddressExclusive(){const e=new a.BigInteger("1");return u.fromBigInteger(this._endAddress().subtract(e))}static fromBigInteger(e){return u.fromInteger(parseInt(e.toString(),10))}mask(e){return void 0===e&&(e=this.subnetMask),this.getBitsBase2(0,e)}getBitsBase2(e,t){return this.binaryZeroPad().slice(e,t)}reverseForm(e){e||(e={});const t=this.correctForm().split(".").reverse().join(".");return e.omitSuffix?t:c.sprintf("%s.in-addr.arpa.",t)}isMulticast(){return this.isInSubnet(new u("224.0.0.0/4"))}binaryZeroPad(){return this.bigInteger().toString(2).padStart(s.BITS,"0")}groupForV6(){const e=this.parsedAddress;return this.address.replace(s.RE_ADDRESS,c.sprintf('%s.%s',e.slice(0,2).join("."),e.slice(2,4).join(".")))}}},{"./common":"6mE8e","./v4/constants":"7d2VV","./address-error":"fmci6",jsbn:"cmpQN","sprintf-js":"5O475","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],"6mE8e":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");function n(e){return!(this.subnetMaskn)),i.export(r,"isCorrect",(()=>s))},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],"7d2VV":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"BITS",(()=>n)),i.export(r,"GROUPS",(()=>s)),i.export(r,"RE_ADDRESS",(()=>o)),i.export(r,"RE_SUBNET_STRING",(()=>a));const n=32,s=4,o=/^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/g,a=/\/\d{1,2}$/},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],fmci6:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"AddressError",(()=>n));class n extends Error{constructor(e,t){super(e),this.name="AddressError",null!==t&&(this.parseMessage=t)}}},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],cmpQN:[function(e,t,r){(function(){var e;function i(e,t,r){null!=e&&("number"==typeof e?this.fromNumber(e,t,r):null==t&&"string"!=typeof e?this.fromString(e,256):this.fromString(e,t))}function n(){return new i(null)}var s="undefined"!=typeof navigator;s&&"Microsoft Internet Explorer"==navigator.appName?(i.prototype.am=function(e,t,r,i,n,s){for(var o=32767&t,a=t>>15;--s>=0;){var c=32767&this[e],u=this[e++]>>15,l=a*c+u*o;n=((c=o*c+((32767&l)<<15)+r[i]+(1073741823&n))>>>30)+(l>>>15)+a*u+(n>>>30),r[i++]=1073741823&c}return n},e=30):s&&"Netscape"!=navigator.appName?(i.prototype.am=function(e,t,r,i,n,s){for(;--s>=0;){var o=t*this[e++]+r[i]+n;n=Math.floor(o/67108864),r[i++]=67108863&o}return n},e=26):(i.prototype.am=function(e,t,r,i,n,s){for(var o=16383&t,a=t>>14;--s>=0;){var c=16383&this[e],u=this[e++]>>14,l=a*c+u*o;n=((c=o*c+((16383&l)<<14)+r[i]+n)>>28)+(l>>14)+a*u,r[i++]=268435455&c}return n},e=28),i.prototype.DB=e,i.prototype.DM=(1<>>16)&&(e=t,r+=16),0!=(t=e>>8)&&(e=t,r+=8),0!=(t=e>>4)&&(e=t,r+=4),0!=(t=e>>2)&&(e=t,r+=2),0!=(t=e>>1)&&(e=t,r+=1),r}function h(e){this.m=e}function p(e){this.m=e,this.mp=e.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<>=16,t+=16),0==(255&e)&&(e>>=8,t+=8),0==(15&e)&&(e>>=4,t+=4),0==(3&e)&&(e>>=2,t+=2),0==(1&e)&&++t,t}function w(e){for(var t=0;0!=e;)e&=e-1,++t;return t}function _(){}function E(e){return e}function S(e){this.r2=n(),this.q3=n(),i.ONE.dlShiftTo(2*e.t,this.r2),this.mu=this.r2.divide(e),this.m=e}h.prototype.convert=function(e){return e.s<0||e.compareTo(this.m)>=0?e.mod(this.m):e},h.prototype.revert=function(e){return e},h.prototype.reduce=function(e){e.divRemTo(this.m,null,e)},h.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r),this.reduce(r)},h.prototype.sqrTo=function(e,t){e.squareTo(t),this.reduce(t)},p.prototype.convert=function(e){var t=n();return e.abs().dlShiftTo(this.m.t,t),t.divRemTo(this.m,null,t),e.s<0&&t.compareTo(i.ZERO)>0&&this.m.subTo(t,t),t},p.prototype.revert=function(e){var t=n();return e.copyTo(t),this.reduce(t),t},p.prototype.reduce=function(e){for(;e.t<=this.mt2;)e[e.t++]=0;for(var t=0;t>15)*this.mpl&this.um)<<15)&e.DM;for(e[r=t+this.m.t]+=this.m.am(0,i,e,t,0,this.m.t);e[r]>=e.DV;)e[r]-=e.DV,e[++r]++}e.clamp(),e.drShiftTo(this.m.t,e),e.compareTo(this.m)>=0&&e.subTo(this.m,e)},p.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r),this.reduce(r)},p.prototype.sqrTo=function(e,t){e.squareTo(t),this.reduce(t)},i.prototype.copyTo=function(e){for(var t=this.t-1;t>=0;--t)e[t]=this[t];e.t=this.t,e.s=this.s},i.prototype.fromInt=function(e){this.t=1,this.s=e<0?-1:0,e>0?this[0]=e:e<-1?this[0]=e+this.DV:this.t=0},i.prototype.fromString=function(e,t){var r;if(16==t)r=4;else if(8==t)r=3;else if(256==t)r=8;else if(2==t)r=1;else if(32==t)r=5;else{if(4!=t)return void this.fromRadix(e,t);r=2}this.t=0,this.s=0;for(var n=e.length,s=!1,o=0;--n>=0;){var a=8==r?255&e[n]:l(e,n);a<0?"-"==e.charAt(n)&&(s=!0):(s=!1,0==o?this[this.t++]=a:o+r>this.DB?(this[this.t-1]|=(a&(1<>this.DB-o):this[this.t-1]|=a<=this.DB&&(o-=this.DB))}8==r&&0!=(128&e[0])&&(this.s=-1,o>0&&(this[this.t-1]|=(1<0&&this[this.t-1]==e;)--this.t},i.prototype.dlShiftTo=function(e,t){var r;for(r=this.t-1;r>=0;--r)t[r+e]=this[r];for(r=e-1;r>=0;--r)t[r]=0;t.t=this.t+e,t.s=this.s},i.prototype.drShiftTo=function(e,t){for(var r=e;r=0;--r)t[r+o+1]=this[r]>>n|a,a=(this[r]&s)<=0;--r)t[r]=0;t[o]=a,t.t=this.t+o+1,t.s=this.s,t.clamp()},i.prototype.rShiftTo=function(e,t){t.s=this.s;var r=Math.floor(e/this.DB);if(r>=this.t)t.t=0;else{var i=e%this.DB,n=this.DB-i,s=(1<>i;for(var o=r+1;o>i;i>0&&(t[this.t-r-1]|=(this.s&s)<>=this.DB;if(e.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i-=e.s}t.s=i<0?-1:0,i<-1?t[r++]=this.DV+i:i>0&&(t[r++]=i),t.t=r,t.clamp()},i.prototype.multiplyTo=function(e,t){var r=this.abs(),n=e.abs(),s=r.t;for(t.t=s+n.t;--s>=0;)t[s]=0;for(s=0;s=0;)e[r]=0;for(r=0;r=t.DV&&(e[r+t.t]-=t.DV,e[r+t.t+1]=1)}e.t>0&&(e[e.t-1]+=t.am(r,t[r],e,2*r,0,1)),e.s=0,e.clamp()},i.prototype.divRemTo=function(e,t,r){var s=e.abs();if(!(s.t<=0)){var o=this.abs();if(o.t0?(s.lShiftTo(l,a),o.lShiftTo(l,r)):(s.copyTo(a),o.copyTo(r));var d=a.t,h=a[d-1];if(0!=h){var p=h*(1<1?a[d-2]>>this.F2:0),g=this.FV/p,y=(1<=0&&(r[r.t++]=1,r.subTo(w,r)),i.ONE.dlShiftTo(d,w),w.subTo(a,a);a.t=0;){var _=r[--b]==h?this.DM:Math.floor(r[b]*g+(r[b-1]+m)*y);if((r[b]+=a.am(0,_,r,v,0,d))<_)for(a.dlShiftTo(v,w),r.subTo(w,r);r[b]<--_;)r.subTo(w,r)}null!=t&&(r.drShiftTo(d,t),c!=u&&i.ZERO.subTo(t,t)),r.t=d,r.clamp(),l>0&&r.rShiftTo(l,r),c<0&&i.ZERO.subTo(r,r)}}},i.prototype.invDigit=function(){if(this.t<1)return 0;var e=this[0];if(0==(1&e))return 0;var t=3&e;return(t=(t=(t=(t=t*(2-(15&e)*t)&15)*(2-(255&e)*t)&255)*(2-((65535&e)*t&65535))&65535)*(2-e*t%this.DV)%this.DV)>0?this.DV-t:-t},i.prototype.isEven=function(){return 0==(this.t>0?1&this[0]:this.s)},i.prototype.exp=function(e,t){if(e>4294967295||e<1)return i.ONE;var r=n(),s=n(),o=t.convert(this),a=f(e)-1;for(o.copyTo(r);--a>=0;)if(t.sqrTo(r,s),(e&1<0)t.mulTo(s,o,r);else{var c=r;r=s,s=c}return t.revert(r)},i.prototype.toString=function(e){if(this.s<0)return"-"+this.negate().toString(e);var t;if(16==e)t=4;else if(8==e)t=3;else if(2==e)t=1;else if(32==e)t=5;else{if(4!=e)return this.toRadix(e);t=2}var r,i=(1<0)for(a>a)>0&&(n=!0,s=u(r));o>=0;)a>(a+=this.DB-t)):(r=this[o]>>(a-=t)&i,a<=0&&(a+=this.DB,--o)),r>0&&(n=!0),n&&(s+=u(r));return n?s:"0"},i.prototype.negate=function(){var e=n();return i.ZERO.subTo(this,e),e},i.prototype.abs=function(){return this.s<0?this.negate():this},i.prototype.compareTo=function(e){var t=this.s-e.s;if(0!=t)return t;var r=this.t;if(0!=(t=r-e.t))return this.s<0?-t:t;for(;--r>=0;)if(0!=(t=this[r]-e[r]))return t;return 0},i.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+f(this[this.t-1]^this.s&this.DM)},i.prototype.mod=function(e){var t=n();return this.abs().divRemTo(e,null,t),this.s<0&&t.compareTo(i.ZERO)>0&&e.subTo(t,t),t},i.prototype.modPowInt=function(e,t){var r;return r=e<256||t.isEven()?new h(t):new p(t),this.exp(e,r)},i.ZERO=d(0),i.ONE=d(1),_.prototype.convert=E,_.prototype.revert=E,_.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r)},_.prototype.sqrTo=function(e,t){e.squareTo(t)},S.prototype.convert=function(e){if(e.s<0||e.t>2*this.m.t)return e.mod(this.m);if(e.compareTo(this.m)<0)return e;var t=n();return e.copyTo(t),this.reduce(t),t},S.prototype.revert=function(e){return e},S.prototype.reduce=function(e){for(e.drShiftTo(this.m.t-1,this.r2),e.t>this.m.t+1&&(e.t=this.m.t+1,e.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);e.compareTo(this.r2)<0;)e.dAddOffset(1,this.m.t+1);for(e.subTo(this.r2,e);e.compareTo(this.m)>=0;)e.subTo(this.m,e)},S.prototype.mulTo=function(e,t,r){e.multiplyTo(t,r),this.reduce(r)},S.prototype.sqrTo=function(e,t){e.squareTo(t),this.reduce(t)};var T,A,k,I=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],R=67108864/I[I.length-1];function P(){var e;e=(new Date).getTime(),A[k++]^=255&e,A[k++]^=e>>8&255,A[k++]^=e>>16&255,A[k++]^=e>>24&255,k>=B&&(k-=B)}if(i.prototype.chunkSize=function(e){return Math.floor(Math.LN2*this.DB/Math.log(e))},i.prototype.toRadix=function(e){if(null==e&&(e=10),0==this.signum()||e<2||e>36)return"0";var t=this.chunkSize(e),r=Math.pow(e,t),i=d(r),s=n(),o=n(),a="";for(this.divRemTo(i,s,o);s.signum()>0;)a=(r+o.intValue()).toString(e).substr(1)+a,s.divRemTo(i,s,o);return o.intValue().toString(e)+a},i.prototype.fromRadix=function(e,t){this.fromInt(0),null==t&&(t=10);for(var r=this.chunkSize(t),n=Math.pow(t,r),s=!1,o=0,a=0,c=0;c=r&&(this.dMultiply(n),this.dAddOffset(a,0),o=0,a=0))}o>0&&(this.dMultiply(Math.pow(t,o)),this.dAddOffset(a,0)),s&&i.ZERO.subTo(this,this)},i.prototype.fromNumber=function(e,t,r){if("number"==typeof t)if(e<2)this.fromInt(1);else for(this.fromNumber(e,r),this.testBit(e-1)||this.bitwiseTo(i.ONE.shiftLeft(e-1),y,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(t);)this.dAddOffset(2,0),this.bitLength()>e&&this.subTo(i.ONE.shiftLeft(e-1),this);else{var n=new Array,s=7&e;n.length=1+(e>>3),t.nextBytes(n),s>0?n[0]&=(1<>=this.DB;if(e.t>=this.DB;i+=this.s}else{for(i+=this.s;r>=this.DB;i+=e.s}t.s=i<0?-1:0,i>0?t[r++]=i:i<-1&&(t[r++]=this.DV+i),t.t=r,t.clamp()},i.prototype.dMultiply=function(e){this[this.t]=this.am(0,e-1,this,0,0,this.t),++this.t,this.clamp()},i.prototype.dAddOffset=function(e,t){if(0!=e){for(;this.t<=t;)this[this.t++]=0;for(this[t]+=e;this[t]>=this.DV;)this[t]-=this.DV,++t>=this.t&&(this[this.t++]=0),++this[t]}},i.prototype.multiplyLowerTo=function(e,t,r){var i,n=Math.min(this.t+e.t,t);for(r.s=0,r.t=n;n>0;)r[--n]=0;for(i=r.t-this.t;n=0;)r[i]=0;for(i=Math.max(t-this.t,0);i0)if(0==t)r=this[0]%e;else for(var i=this.t-1;i>=0;--i)r=(t*r+this[i])%e;return r},i.prototype.millerRabin=function(e){var t=this.subtract(i.ONE),r=t.getLowestSetBit();if(r<=0)return!1;var s=t.shiftRight(r);(e=e+1>>1)>I.length&&(e=I.length);for(var o=n(),a=0;a>24},i.prototype.shortValue=function(){return 0==this.t?this.s:this[0]<<16>>16},i.prototype.signum=function(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1},i.prototype.toByteArray=function(){var e=this.t,t=new Array;t[0]=this.s;var r,i=this.DB-e*this.DB%8,n=0;if(e-- >0)for(i>i)!=(this.s&this.DM)>>i&&(t[n++]=r|this.s<=0;)i<8?(r=(this[e]&(1<>(i+=this.DB-8)):(r=this[e]>>(i-=8)&255,i<=0&&(i+=this.DB,--e)),0!=(128&r)&&(r|=-256),0==n&&(128&this.s)!=(128&r)&&++n,(n>0||r!=this.s)&&(t[n++]=r);return t},i.prototype.equals=function(e){return 0==this.compareTo(e)},i.prototype.min=function(e){return this.compareTo(e)<0?this:e},i.prototype.max=function(e){return this.compareTo(e)>0?this:e},i.prototype.and=function(e){var t=n();return this.bitwiseTo(e,g,t),t},i.prototype.or=function(e){var t=n();return this.bitwiseTo(e,y,t),t},i.prototype.xor=function(e){var t=n();return this.bitwiseTo(e,m,t),t},i.prototype.andNot=function(e){var t=n();return this.bitwiseTo(e,b,t),t},i.prototype.not=function(){for(var e=n(),t=0;t=this.t?0!=this.s:0!=(this[t]&1<1){var g=n();for(i.sqrTo(a[1],g);c<=l;)a[c]=n(),i.mulTo(g,a[c-2],a[c]),c+=2}var y,m,b=e.t-1,v=!0,w=n();for(s=f(e[b])-1;b>=0;){for(s>=u?y=e[b]>>s-u&l:(y=(e[b]&(1<0&&(y|=e[b-1]>>this.DB+s-u)),c=r;0==(1&y);)y>>=1,--c;if((s-=c)<0&&(s+=this.DB,--b),v)a[y].copyTo(o),v=!1;else{for(;c>1;)i.sqrTo(o,w),i.sqrTo(w,o),c-=2;c>0?i.sqrTo(o,w):(m=o,o=w,w=m),i.mulTo(w,a[y],o)}for(;b>=0&&0==(e[b]&1<=0?(r.subTo(n,r),t&&s.subTo(a,s),o.subTo(c,o)):(n.subTo(r,n),t&&a.subTo(s,a),c.subTo(o,c))}return 0!=n.compareTo(i.ONE)?i.ZERO:c.compareTo(e)>=0?c.subtract(e):c.signum()<0?(c.addTo(e,c),c.signum()<0?c.add(e):c):c},i.prototype.pow=function(e){return this.exp(e,new _)},i.prototype.gcd=function(e){var t=this.s<0?this.negate():this.clone(),r=e.s<0?e.negate():e.clone();if(t.compareTo(r)<0){var i=t;t=r,r=i}var n=t.getLowestSetBit(),s=r.getLowestSetBit();if(s<0)return t;for(n0&&(t.rShiftTo(s,t),r.rShiftTo(s,r));t.signum()>0;)(n=t.getLowestSetBit())>0&&t.rShiftTo(n,t),(n=r.getLowestSetBit())>0&&r.rShiftTo(n,r),t.compareTo(r)>=0?(t.subTo(r,t),t.rShiftTo(1,t)):(r.subTo(t,r),r.rShiftTo(1,r));return s>0&&r.lShiftTo(s,r),r},i.prototype.isProbablePrime=function(e){var t,r=this.abs();if(1==r.t&&r[0]<=I[I.length-1]){for(t=0;t>>8,A[k++]=255&O;k=0,P()}function D(){if(null==T){for(P(),(T=new x).init(A),k=0;k=0),a.type){case"b":n=parseInt(n,10).toString(2);break;case"c":n=String.fromCharCode(parseInt(n,10));break;case"d":case"i":n=parseInt(n,10);break;case"j":n=JSON.stringify(n,null,a.width?parseInt(a.width):0);break;case"e":n=a.precision?parseFloat(n).toExponential(a.precision):parseFloat(n).toExponential();break;case"f":n=a.precision?parseFloat(n).toFixed(a.precision):parseFloat(n);break;case"g":n=a.precision?String(Number(n.toPrecision(a.precision))):parseFloat(n);break;case"o":n=(parseInt(n,10)>>>0).toString(8);break;case"s":n=String(n),n=a.precision?n.substring(0,a.precision):n;break;case"t":n=String(!!n),n=a.precision?n.substring(0,a.precision):n;break;case"T":n=Object.prototype.toString.call(n).slice(8,-1).toLowerCase(),n=a.precision?n.substring(0,a.precision):n;break;case"u":n=parseInt(n,10)>>>0;break;case"v":n=n.valueOf(),n=a.precision?n.substring(0,a.precision):n;break;case"x":n=(parseInt(n,10)>>>0).toString(16);break;case"X":n=(parseInt(n,10)>>>0).toString(16).toUpperCase()}e.json.test(a.type)?g+=n:(!e.number.test(a.type)||d&&!a.sign?f="":(f=d?"+":"-",n=n.toString().replace(e.sign,"")),u=a.pad_char?"0"===a.pad_char?"0":a.pad_char.charAt(1):" ",l=a.width-(f+n).length,c=a.width&&l>0?u.repeat(l):"",g+=a.align?f+n+c:"0"===u?f+c+n:c+f+n)}return g}var s=Object.create(null);function o(t){if(s[t])return s[t];for(var r,i=t,n=[],o=0;i;){if(null!==(r=e.text.exec(i)))n.push(r[0]);else if(null!==(r=e.modulo.exec(i)))n.push("%");else{if(null===(r=e.placeholder.exec(i)))throw new SyntaxError("[sprintf] unexpected placeholder");if(r[2]){o|=1;var a=[],c=r[2],u=[];if(null===(u=e.key.exec(c)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(u[1]);""!==(c=c.substring(u[0].length));)if(null!==(u=e.key_access.exec(c)))a.push(u[1]);else{if(null===(u=e.index_access.exec(c)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(u[1])}r[2]=a}else o|=2;if(3===o)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");n.push({placeholder:r[0],param_no:r[1],keys:r[2],sign:r[3],pad_char:r[4],align:r[5],width:r[6],precision:r[7],type:r[8]})}i=i.substring(r[0].length)}return s[t]=n}void 0!==r&&(r.sprintf=t,r.vsprintf=i),"undefined"!=typeof window&&(window.sprintf=t,window.vsprintf=i,"function"==typeof define&&define.amd&&define((function(){return{sprintf:t,vsprintf:i}})))}()},{}],a8cEK:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"Address6",(()=>m));var n=e("./common"),s=e("./v4/constants"),o=e("./v6/constants"),a=e("./v6/helpers"),c=e("./ipv4"),u=e("./v6/regular-expressions"),l=e("./address-error"),d=e("jsbn"),f=e("sprintf-js");function h(e){if(!e)throw new Error("Assertion failed.")}function p(e){return e=(e=e.replace(/^(0{1,})([1-9]+)$/,'$1$2')).replace(/^(0{1,})(0)$/,'$1$2')}function g(e){return f.sprintf("%04x",parseInt(e,16))}function y(e){return 255&e}class m{constructor(e,t){this.addressMinusSuffix="",this.parsedSubnet="",this.subnet="/128",this.subnetMask=128,this.v4=!1,this.zone="",this.isInSubnet=n.isInSubnet,this.isCorrect=n.isCorrect(o.BITS),this.groups=void 0===t?o.GROUPS:t,this.address=e;const r=o.RE_SUBNET_STRING.exec(e);if(r){if(this.parsedSubnet=r[0].replace("/",""),this.subnetMask=parseInt(this.parsedSubnet,10),this.subnet=`/${this.subnetMask}`,Number.isNaN(this.subnetMask)||this.subnetMask<0||this.subnetMask>o.BITS)throw new l.AddressError("Invalid subnet mask.");e=e.replace(o.RE_SUBNET_STRING,"")}else if(/\//.test(e))throw new l.AddressError("Invalid subnet mask.");const i=o.RE_ZONE_STRING.exec(e);i&&(this.zone=i[0],e=e.replace(o.RE_ZONE_STRING,"")),this.addressMinusSuffix=e,this.parsedAddress=this.parse(this.addressMinusSuffix)}static isValid(e){try{return new m(e),!0}catch(e){return!1}}static fromBigInteger(e){const t=e.toString(16).padStart(32,"0"),r=[];let i;for(i=0;i65536)&&(i=null)):i=null,{address:new m(t),port:i}}static fromAddress4(e){const t=new c.Address4(e),r=o.BITS-(s.BITS-t.subnetMask);return new m(`::ffff:${t.correctForm()}/${r}`)}static fromArpa(e){let t=e.replace(/(\.ip6\.arpa)?\.$/,"");if(63!==t.length)throw new l.AddressError("Invalid 'ip6.arpa' form.");const r=t.split(".").reverse();for(let e=7;e>0;e--){const t=4*e;r.splice(t,0,":")}return t=r.join(""),new m(t)}microsoftTranscription(){return f.sprintf("%s.ipv6-literal.net",this.correctForm().replace(/:/g,"-"))}mask(e=this.subnetMask){return this.getBitsBase2(0,e)}possibleSubnets(e=128){const t=o.BITS-this.subnetMask-Math.abs(e-o.BITS);return t<0?"0":function(e){const t=/(\d+)(\d{3})/;for(;t.test(e);)e=e.replace(t,"$1,$2");return e}(new d.BigInteger("2",10).pow(t).toString(10))}_startAddress(){return new d.BigInteger(this.mask()+"0".repeat(o.BITS-this.subnetMask),2)}startAddress(){return m.fromBigInteger(this._startAddress())}startAddressExclusive(){const e=new d.BigInteger("1");return m.fromBigInteger(this._startAddress().add(e))}_endAddress(){return new d.BigInteger(this.mask()+"1".repeat(o.BITS-this.subnetMask),2)}endAddress(){return m.fromBigInteger(this._endAddress())}endAddressExclusive(){const e=new d.BigInteger("1");return m.fromBigInteger(this._endAddress().subtract(e))}getScope(){let e=o.SCOPES[this.getBits(12,16).intValue()];return"Global unicast"===this.getType()&&"Link local"!==e&&(e="Global"),e||"Unknown"}getType(){for(const e of Object.keys(o.TYPES))if(this.isInSubnet(new m(e)))return o.TYPES[e];return"Global unicast"}getBits(e,t){return new d.BigInteger(this.getBitsBase2(e,t),2)}getBitsBase2(e,t){return this.binaryZeroPad().slice(e,t)}getBitsBase16(e,t){const r=t-e;if(r%4!=0)throw new Error("Length of bits to retrieve must be divisible by four");return this.getBits(e,t).toString(16).padStart(r/4,"0")}getBitsPastSubnet(){return this.getBitsBase2(this.subnetMask,o.BITS)}reverseForm(e){e||(e={});const t=Math.floor(this.subnetMask/4),r=this.canonicalForm().replace(/:/g,"").split("").slice(0,t).reverse().join(".");return t>0?e.omitSuffix?r:f.sprintf("%s.ip6.arpa.",r):e.omitSuffix?"":"ip6.arpa."}correctForm(){let e,t=[],r=0;const i=[];for(e=0;e0&&(r>1&&i.push([e-r,e-1]),r=0)}r>1&&i.push([this.parsedAddress.length-r,this.parsedAddress.length-1]);const n=i.map((e=>e[1]-e[0]+1));if(i.length>0){const e=n.indexOf(Math.max(...n));t=function(e,t){const r=[],i=[];let n;for(n=0;nt[1]&&i.push(e[n]);return r.concat(["compact"]).concat(i)}(this.parsedAddress,i[e])}else t=this.parsedAddress;for(e=0;e1?"s":"",t.join("")),e.replace(o.RE_BAD_CHARACTERS,'$1'));const r=e.match(o.RE_BAD_ADDRESS);if(r)throw new l.AddressError(f.sprintf("Address failed regex: %s",r.join("")),e.replace(o.RE_BAD_ADDRESS,'$1'));let i=[];const n=e.split("::");if(2===n.length){let e=n[0].split(":"),t=n[1].split(":");1===e.length&&""===e[0]&&(e=[]),1===t.length&&""===t[0]&&(t=[]);const r=this.groups-(e.length+t.length);if(!r)throw new l.AddressError("Error parsing groups");this.elidedGroups=r,this.elisionBegin=e.length,this.elisionEnd=e.length+this.elidedGroups,i=i.concat(e);for(let e=0;ef.sprintf("%x",parseInt(e,16)))),i.length!==this.groups)throw new l.AddressError("Incorrect number of groups found");return i}canonicalForm(){return this.parsedAddress.map(g).join(":")}decimal(){return this.parsedAddress.map((e=>f.sprintf("%05d",parseInt(e,16)))).join(":")}bigInteger(){return new d.BigInteger(this.parsedAddress.map(g).join(""),16)}to4(){const e=this.binaryZeroPad().split("");return c.Address4.fromHex(new d.BigInteger(e.slice(96,128).join(""),2).toString(16))}to4in6(){const e=this.to4(),t=new m(this.parsedAddress.slice(0,6).join(":"),6).correctForm();let r="";return/:$/.test(t)||(r=":"),t+r+e.address}inspectTeredo(){const e=this.getBitsBase16(0,32),t=this.getBits(80,96).xor(new d.BigInteger("ffff",16)).toString(),r=c.Address4.fromHex(this.getBitsBase16(32,64)),i=c.Address4.fromHex(this.getBits(96,128).xor(new d.BigInteger("ffffffff",16)).toString(16)),n=this.getBits(64,80),s=this.getBitsBase2(64,80),o=n.testBit(15),a=n.testBit(14),u=n.testBit(8),l=n.testBit(9),h=new d.BigInteger(s.slice(2,6)+s.slice(8,16),2).toString(10);return{prefix:f.sprintf("%s:%s",e.slice(0,4),e.slice(4,8)),server4:r.address,client4:i.address,flags:s,coneNat:o,microsoft:{reserved:a,universalLocal:l,groupIndividual:u,nonce:h},udpPort:t}}inspect6to4(){const e=this.getBitsBase16(0,16),t=c.Address4.fromHex(this.getBitsBase16(16,48));return{prefix:f.sprintf("%s",e.slice(0,4)),gateway:t.address}}to6to4(){if(!this.is4())return null;const e=["2002",this.getBitsBase16(96,112),this.getBitsBase16(112,128),"","/16"].join(":");return new m(e)}toByteArray(){const e=this.bigInteger().toByteArray();return 17===e.length&&0===e[0]?e.slice(1):e}toUnsignedByteArray(){return this.toByteArray().map(y)}static fromByteArray(e){return this.fromUnsignedByteArray(e.map(y))}static fromUnsignedByteArray(e){const t=new d.BigInteger("256",10);let r=new d.BigInteger("0",10),i=new d.BigInteger("1",10);for(let n=e.length-1;n>=0;n--)r=r.add(i.multiply(new d.BigInteger(e[n].toString(10),10))),i=i.multiply(t);return m.fromBigInteger(r)}isCanonical(){return this.addressMinusSuffix===this.canonicalForm()}isLinkLocal(){return"1111111010000000000000000000000000000000000000000000000000000000"===this.getBitsBase2(0,64)}isMulticast(){return"Multicast"===this.getType()}is4(){return this.v4}isTeredo(){return this.isInSubnet(new m("2001::/32"))}is6to4(){return this.isInSubnet(new m("2002::/16"))}isLoopback(){return"Loopback"===this.getType()}href(e){return e=void 0===e?"":f.sprintf(":%s",e),f.sprintf("http://[%s]%s/",this.correctForm(),e)}link(e){e||(e={}),void 0===e.className&&(e.className=""),void 0===e.prefix&&(e.prefix="/#address="),void 0===e.v4&&(e.v4=!1);let t=this.correctForm;return e.v4&&(t=this.to4in6),e.className?f.sprintf('%2$s',e.prefix,t.call(this),e.className):f.sprintf('%2$s',e.prefix,t.call(this))}group(){if(0===this.elidedGroups)return a.simpleGroup(this.address).join(":");h("number"==typeof this.elidedGroups),h("number"==typeof this.elisionBegin);const e=[],[t,r]=this.address.split("::");t.length?e.push(...a.simpleGroup(t)):e.push("");const i=["hover-group"];for(let e=this.elisionBegin;e',i.join(" "))),r.length?e.push(...a.simpleGroup(r,this.elisionEnd)):e.push(""),this.is4()&&(h(this.address4 instanceof c.Address4),e.pop(),e.push(this.address4.groupForV6())),e.join(":")}regularExpressionString(e=!1){let t=[];const r=new m(this.correctForm());if(0===r.elidedGroups)t.push(u.simpleRegularExpression(r.parsedAddress));else if(r.elidedGroups===o.GROUPS)t.push(u.possibleElisions(o.GROUPS));else{const e=r.address.split("::");e[0].length&&t.push(u.simpleRegularExpression(e[0].split(":"))),h("number"==typeof r.elidedGroups),t.push(u.possibleElisions(r.elidedGroups,0!==e[0].length,0!==e[1].length)),e[1].length&&t.push(u.simpleRegularExpression(e[1].split(":"))),t=[t.join(":")]}return e||(t=["(?=^|",u.ADDRESS_BOUNDARY,"|[^\\w\\:])(",...t,")(?=[^\\w\\:]|",u.ADDRESS_BOUNDARY,"|$)"]),t.join("")}regularExpression(e=!1){return new RegExp(this.regularExpressionString(e),"i")}}},{"./common":"6mE8e","./v4/constants":"7d2VV","./v6/constants":"5lfrn","./v6/helpers":"hT0Uq","./ipv4":"blUQX","./v6/regular-expressions":"cbb6J","./address-error":"fmci6",jsbn:"cmpQN","sprintf-js":"5O475","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],"5lfrn":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"BITS",(()=>n)),i.export(r,"GROUPS",(()=>s)),i.export(r,"SCOPES",(()=>o)),i.export(r,"TYPES",(()=>a)),i.export(r,"RE_BAD_CHARACTERS",(()=>c)),i.export(r,"RE_BAD_ADDRESS",(()=>u)),i.export(r,"RE_SUBNET_STRING",(()=>l)),i.export(r,"RE_ZONE_STRING",(()=>d)),i.export(r,"RE_URL",(()=>f)),i.export(r,"RE_URL_WITH_PORT",(()=>h));const n=128,s=8,o={0:"Reserved",1:"Interface local",2:"Link local",4:"Admin local",5:"Site local",8:"Organization local",14:"Global",15:"Reserved"},a={"ff01::1/128":"Multicast (All nodes on this interface)","ff01::2/128":"Multicast (All routers on this interface)","ff02::1/128":"Multicast (All nodes on this link)","ff02::2/128":"Multicast (All routers on this link)","ff05::2/128":"Multicast (All routers in this site)","ff02::5/128":"Multicast (OSPFv3 AllSPF routers)","ff02::6/128":"Multicast (OSPFv3 AllDR routers)","ff02::9/128":"Multicast (RIP routers)","ff02::a/128":"Multicast (EIGRP routers)","ff02::d/128":"Multicast (PIM routers)","ff02::16/128":"Multicast (MLDv2 reports)","ff01::fb/128":"Multicast (mDNSv6)","ff02::fb/128":"Multicast (mDNSv6)","ff05::fb/128":"Multicast (mDNSv6)","ff02::1:2/128":"Multicast (All DHCP servers and relay agents on this link)","ff05::1:2/128":"Multicast (All DHCP servers and relay agents in this site)","ff02::1:3/128":"Multicast (All DHCP servers on this link)","ff05::1:3/128":"Multicast (All DHCP servers in this site)","::/128":"Unspecified","::1/128":"Loopback","ff00::/8":"Multicast","fe80::/10":"Link-local unicast"},c=/([^0-9a-f:/%])/gi,u=/([0-9a-f]{5,}|:{3,}|[^:]:$|^:[^:]|\/$)/gi,l=/\/\d{1,3}(?=%|$)/,d=/%.*$/,f=new RegExp(/^\[{0,1}([0-9a-f:]+)\]{0,1}/),h=new RegExp(/\[([0-9a-f:]+)\]:([0-9]{1,5})/)},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],hT0Uq:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"spanAllZeroes",(()=>s)),i.export(r,"spanAll",(()=>o)),i.export(r,"spanLeadingZeroes",(()=>c)),i.export(r,"simpleGroup",(()=>u));var n=e("sprintf-js");function s(e){return e.replace(/(0+)/g,'$1')}function o(e,t=0){return e.split("").map(((e,r)=>n.sprintf('%s',e,r+t,s(e)))).join("")}function a(e){return e.replace(/^(0+)/,'$1')}function c(e){return e.split(":").map((e=>a(e))).join(":")}function u(e,t=0){return e.split(":").map(((e,r)=>/group-v4/.test(e)?e:n.sprintf('%s',r+t,a(e))))}},{"sprintf-js":"5O475","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],cbb6J:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"groupPossibilities",(()=>o)),i.export(r,"padGroup",(()=>a)),i.export(r,"ADDRESS_BOUNDARY",(()=>c)),i.export(r,"simpleRegularExpression",(()=>u)),i.export(r,"possibleElisions",(()=>l));var n=e("./constants"),s=e("sprintf-js");function o(e){return s.sprintf("(%s)",e.join("|"))}function a(e){return e.length<4?s.sprintf("0{0,%d}%s",4-e.length,e):e}const c="[^A-Fa-f0-9:]";function u(e){const t=[];e.forEach(((e,r)=>{0===parseInt(e,16)&&t.push(r)}));const r=t.map((t=>e.map(((e,r)=>{if(r===t){const t=0===r||r===n.GROUPS-1?":":"";return o([a(e),t])}return a(e)})).join(":")));return r.push(e.map(a).join(":")),o(r)}function l(e,t,r){const i=t?"":":",n=r?"":":",a=[];t||r||a.push("::"),t&&r&&a.push(""),(r&&!t||!r&&t)&&a.push(":"),a.push(s.sprintf("%s(:0{1,4}){1,%d}",i,e-1)),a.push(s.sprintf("(0{1,4}:){1,%d}%s",e-1,n)),a.push(s.sprintf("(0{1,4}:){%d}0{1,4}",e-1));for(let t=1;t{let s;const o=new Promise(((o,a)=>{if("number"!=typeof t||t<0)throw new TypeError("Expected `milliseconds` to be a positive number");t!==1/0?(n={customTimers:{setTimeout:setTimeout,clearTimeout:clearTimeout},...n},s=n.customTimers.setTimeout.call(void 0,(()=>{if("function"==typeof r){try{o(r())}catch(e){a(e)}return}const n=r instanceof Error?r:new i("string"==typeof r?r:`Promise timed out after ${t} milliseconds`);"function"==typeof e.cancel&&e.cancel(),a(n)}),t),(async()=>{try{o(await e)}catch(e){a(e)}finally{n.customTimers.clearTimeout.call(void 0,s)}})()):o(e)}));return o.clear=()=>{clearTimeout(s),s=void 0},o};t.exports=n,t.exports.default=n,t.exports.TimeoutError=i},{}],f6X4K:[function(e,t,r){"use strict";const i=e("mafmt"),{CODE_CIRCUIT:n,CODE_P2P:s,CODE_TCP:o,CODE_WS:a,CODE_WSS:c}=e("./constants");t.exports={all:e=>e.filter((e=>{if(e.protoCodes().includes(n))return!1;const t=e.decapsulateCode(s);return i.WebSockets.matches(t)||i.WebSocketsSecure.matches(t)})),dnsWss:e=>e.filter((e=>{if(e.protoCodes().includes(n))return!1;const t=e.decapsulateCode(s);return i.WebSocketsSecure.matches(t)&&i.DNS.matches(t.decapsulateCode(o).decapsulateCode(c))})),dnsWsOrWss:e=>e.filter((e=>{if(e.protoCodes().includes(n))return!1;const t=e.decapsulateCode(s);return i.WebSockets.matches(t)?i.DNS.matches(t.decapsulateCode(o).decapsulateCode(a)):i.WebSocketsSecure.matches(t)&&i.DNS.matches(t.decapsulateCode(o).decapsulateCode(c))}))}},{mafmt:"l1lok","./constants":"7O7y1"}],jtxJ4:[function(e,t,r){"use strict";const i=e("debug"),n=i("libp2p:webrtc-star");n.error=i("libp2p:webrtc-star:error");const{EventEmitter:s}=e("events"),o=e("err-code"),a=e("class-is"),{AbortError:c}=e("abortable-iterator"),u=e("libp2p-webrtc-peer"),{supportsWebRTCDataChannels:l}=e("ipfs-utils/src/supports"),{Multiaddr:d}=e("multiaddr"),f=e("mafmt"),h=e("peer-id"),{CODE_CIRCUIT:p}=e("./constants"),g=e("./listener"),y=e("./socket-to-conn"),{cleanMultiaddr:m,cleanUrlSIO:b}=e("./utils");function v(){}t.exports=a(class{constructor(e={}){if(!e.upgrader)throw new Error("An upgrader must be provided. See https://github.com/libp2p/interface-transport#upgrader.");this._upgrader=e.upgrader,this.sioOptions={transports:["websocket"],"force new connection":!0},e.wrtc&&(this.wrtc=e.wrtc),this.sigReferences=new Map,this.discovery=new s,this.discovery.tag="webRTCStar",this.discovery._isStarted=!1,this.discovery.start=()=>{this.discovery._isStarted=!0},this.discovery.stop=()=>{this.discovery._isStarted=!1},this._peerDiscovered=this._peerDiscovered.bind(this)}async dial(e,t={}){const r=await this._connect(e,t),i=y(r,{remoteAddr:e,signal:t.signal});n("new outbound connection %s",i.remoteAddr);const s=await this._upgrader.upgradeOutbound(i);return n("outbound connection %s upgraded",i.remoteAddr),s}_connect(e,t={}){if(t.signal&&t.signal.aborted)throw new c;const r={initiator:!0,trickle:!1,...t.spOptions||{}};this.wrtc&&(r.wrtc=this.wrtc);const i=e.toOptions(),s=(~~(1e9*Math.random())).toString(36)+Date.now();return new Promise(((a,l)=>{const d=this.sigReferences.get(b(e));if(!d||!d.listener)return l(o(new Error("unknown signal server to use"),"ERR_UNKNOWN_SIGNAL_SERVER"));const f=d.listener.io,h=Date.now();let p;n("dialing %s:%s",i.host,i.port);const g=new u(r),y=e=>{if(!p){const t=`connection error ${i.host}:${i.port}: ${e.message}`;n.error(t),_(e)}},m=()=>{n("connnection timeout %s:%s",i.host,i.port);const e=o(new Error(`connection timeout after ${Date.now()-h}ms`),"ERR_CONNECT_TIMEOUT");g.emit("error",e)},v=()=>{p=!0,n("connection opened %s:%s",i.host,i.port),_(null)},w=()=>{n.error("connection aborted %s:%s",i.host,i.port),g.destroy(),_(new c)},_=e=>{g.removeListener("timeout",m),g.removeListener("connect",v),t.signal&&t.signal.removeEventListener("abort",w),e?l(e):a(g)};g.on("error",y),g.once("timeout",m),g.once("connect",v),g.on("close",(()=>{g.removeListener("error",y)})),t.signal&&t.signal.addEventListener("abort",w),g.on("signal",(t=>{f.emit("ss-handshake",{intentId:s,srcMultiaddr:d.signallingAddr.toString(),dstMultiaddr:e.toString(),signal:t})})),f.on("ws-handshake",(e=>{e.intentId===s&&e.err&&(g.destroy(),l(o(e.err instanceof Error?e.err:new Error(e.err),"ERR_SIGNALLING_FAILED"))),e.intentId===s&&e.answer&&!g.destroyed&&g.signal(e.signal)}))}))}createListener(e={},t){if(!l&&!this.wrtc)throw o(new Error("no WebRTC support"),"ERR_NO_WEBRTC_SUPPORT");return"function"==typeof e&&(t=e,e={}),g({handler:t=t||v,upgrader:this._upgrader},this,e)}filter(e){return(e=Array.isArray(e)?e:[e]).filter((e=>!e.protoCodes().includes(p)&&f.WebRTCStar.matches(e)))}_peerDiscovered(e){if(!this.discovery._isStarted)return;n("Peer Discovered:",e),e=m(e);const t=new d(e),r=h.createFromB58String(t.getPeerId());this.discovery.emit("peer",{id:r,multiaddrs:[t]})}},{className:"WebRTCStar",symbolName:"@libp2p/js-libp2p-webrtc-star/webrtcstar"})},{debug:"bO5wM",events:"g82pp","err-code":"chZjB","class-is":"gx31A","abortable-iterator":"awlU8","libp2p-webrtc-peer":"kt3eh","ipfs-utils/src/supports":"3yyjP",multiaddr:"8Mu1u",mafmt:"l1lok","peer-id":"8Bdb3","./constants":"1IQXV","./listener":"bN3Nc","./socket-to-conn":"heHOu","./utils":"kfyaq"}],kt3eh:[function(e,t,r){ /*! simple-peer. MIT License. Feross Aboukhadijeh */var i=e("debug")("simple-peer"),n=e("get-browser-rtc"),s=e("randombytes"),o=e("readable-stream"),a=e("queue-microtask"),c=e("err-code"),u=65536;function l(e){return e.replace(/a=ice-options:trickle\s\n/g,"")}class d extends o.Duplex{constructor(e){if(super(e=Object.assign({allowHalfOpen:!1},e)),this._id=s(4).toString("hex").slice(0,7),this._debug("new peer %o",e),this.channelName=e.initiator?e.channelName||s(20).toString("hex"):null,this.initiator=e.initiator||!1,this.channelConfig=e.channelConfig||d.channelConfig,this.negotiated=this.channelConfig.negotiated,this.config=Object.assign({},d.config,e.config),this.offerOptions=e.offerOptions||{},this.answerOptions=e.answerOptions||{},this.sdpTransform=e.sdpTransform||(e=>e),this.streams=e.streams||(e.stream?[e.stream]:[]),this.trickle=void 0===e.trickle||e.trickle,this.allowHalfTrickle=void 0!==e.allowHalfTrickle&&e.allowHalfTrickle,this.iceCompleteTimeout=e.iceCompleteTimeout||5e3,this._connected=!1,this.remoteAddress=void 0,this.remoteFamily=void 0,this.remotePort=void 0,this.localAddress=void 0,this.localFamily=void 0,this.localPort=void 0,this._wrtc=e.wrtc&&"object"==typeof e.wrtc?e.wrtc:n(),!this._wrtc)throw"undefined"==typeof window?c(new Error("No WebRTC support: Specify `opts.wrtc` option in this environment"),"ERR_WEBRTC_SUPPORT"):c(new Error("No WebRTC support: Not a supported browser"),"ERR_WEBRTC_SUPPORT");this._pcReady=!1,this._channelReady=!1,this._iceComplete=!1,this._iceCompleteTimer=null,this._channel=null,this._pendingCandidates=[],this._isNegotiating=!this.negotiated&&!this.initiator,this._batchedNegotiation=!1,this._queuedNegotiation=!1,this._sendersAwaitingStable=[],this._senderMap=new Map,this._firstStable=!0,this._closingInterval=null,this._remoteTracks=[],this._remoteStreams=[],this._chunk=null,this._cb=null,this._interval=null;try{this._pc=new this._wrtc.RTCPeerConnection(this.config)}catch(e){return void a((()=>this.destroy(c(e,"ERR_PC_CONSTRUCTOR"))))}this._isReactNativeWebrtc="number"==typeof this._pc._peerConnectionId,this._pc.oniceconnectionstatechange=()=>{this._onIceStateChange()},this._pc.onicegatheringstatechange=()=>{this._onIceStateChange()},this._pc.onconnectionstatechange=()=>{this._onConnectionStateChange()},this._pc.onsignalingstatechange=()=>{this._onSignalingStateChange()},this._pc.onicecandidate=e=>{this._onIceCandidate(e)},this.initiator||this.negotiated?this._setupData({channel:this._pc.createDataChannel(this.channelName,this.channelConfig)}):this._pc.ondatachannel=e=>{this._setupData(e)},this.streams&&this.streams.forEach((e=>{this.addStream(e)})),this._pc.ontrack=e=>{this._onTrack(e)},this.initiator&&this._needsNegotiation(),this._onFinishBound=()=>{this._onFinish()},this.once("finish",this._onFinishBound)}get bufferSize(){return this._channel&&this._channel.bufferedAmount||0}get connected(){return this._connected&&"open"===this._channel.readyState}address(){return{port:this.localPort,family:this.localFamily,address:this.localAddress}}signal(e){if(this.destroyed)throw c(new Error("cannot signal after peer is destroyed"),"ERR_SIGNALING");if("string"==typeof e)try{e=JSON.parse(e)}catch(t){e={}}this._debug("signal()"),e.renegotiate&&this.initiator&&(this._debug("got request to renegotiate"),this._needsNegotiation()),e.transceiverRequest&&this.initiator&&(this._debug("got request for transceiver"),this.addTransceiver(e.transceiverRequest.kind,e.transceiverRequest.init)),e.candidate&&(this._pc.remoteDescription&&this._pc.remoteDescription.type?this._addIceCandidate(e.candidate):this._pendingCandidates.push(e.candidate)),e.sdp&&this._pc.setRemoteDescription(new this._wrtc.RTCSessionDescription(e)).then((()=>{this.destroyed||(this._pendingCandidates.forEach((e=>{this._addIceCandidate(e)})),this._pendingCandidates=[],"offer"===this._pc.remoteDescription.type&&this._createAnswer())})).catch((e=>{this.destroy(c(e,"ERR_SET_REMOTE_DESCRIPTION"))})),e.sdp||e.candidate||e.renegotiate||e.transceiverRequest||this.destroy(c(new Error("signal() called with invalid signal data"),"ERR_SIGNALING"))}_addIceCandidate(e){var t=new this._wrtc.RTCIceCandidate(e);this._pc.addIceCandidate(t).catch((e=>{var r;!t.address||t.address.endsWith(".local")?(r="Ignoring unsupported ICE candidate.",console.warn(r)):this.destroy(c(e,"ERR_ADD_ICE_CANDIDATE"))}))}send(e){this._channel.send(e)}addTransceiver(e,t){if(this._debug("addTransceiver()"),this.initiator)try{this._pc.addTransceiver(e,t),this._needsNegotiation()}catch(e){this.destroy(c(e,"ERR_ADD_TRANSCEIVER"))}else this.emit("signal",{transceiverRequest:{kind:e,init:t}})}addStream(e){this._debug("addStream()"),e.getTracks().forEach((t=>{this.addTrack(t,e)}))}addTrack(e,t){this._debug("addTrack()");var r=this._senderMap.get(e)||new Map,i=r.get(t);if(i)throw i.removed?c(new Error("Track has been removed. You should enable/disable tracks that you want to re-add."),"ERR_SENDER_REMOVED"):c(new Error("Track has already been added to that stream."),"ERR_SENDER_ALREADY_ADDED");i=this._pc.addTrack(e,t),r.set(t,i),this._senderMap.set(e,r),this._needsNegotiation()}replaceTrack(e,t,r){this._debug("replaceTrack()");var i=this._senderMap.get(e),n=i?i.get(r):null;if(!n)throw c(new Error("Cannot replace track that was never added."),"ERR_TRACK_NOT_ADDED");t&&this._senderMap.set(t,i),null!=n.replaceTrack?n.replaceTrack(t):this.destroy(c(new Error("replaceTrack is not supported in this browser"),"ERR_UNSUPPORTED_REPLACETRACK"))}removeTrack(e,t){this._debug("removeSender()");var r=this._senderMap.get(e),i=r?r.get(t):null;if(!i)throw c(new Error("Cannot remove track that was never added."),"ERR_TRACK_NOT_ADDED");try{i.removed=!0,this._pc.removeTrack(i)}catch(e){"NS_ERROR_UNEXPECTED"===e.name?this._sendersAwaitingStable.push(i):this.destroy(c(e,"ERR_REMOVE_TRACK"))}this._needsNegotiation()}removeStream(e){this._debug("removeSenders()"),e.getTracks().forEach((t=>{this.removeTrack(t,e)}))}_needsNegotiation(){this._debug("_needsNegotiation"),this._batchedNegotiation||(this._batchedNegotiation=!0,a((()=>{this._batchedNegotiation=!1,this._debug("starting batched negotiation"),this.negotiate()})))}negotiate(){this.initiator?this._isNegotiating?(this._queuedNegotiation=!0,this._debug("already negotiating, queueing")):(this._debug("start negotiation"),setTimeout((()=>{this._createOffer()}),0)):this._isNegotiating?(this._queuedNegotiation=!0,this._debug("already negotiating, queueing")):(this._debug("requesting negotiation from initiator"),this.emit("signal",{renegotiate:!0})),this._isNegotiating=!0}_destroy(e,t){if(this._debug("destroy (error: %s)",e&&(e.message||e)),this.readable=this.writable=!1,this._readableState.ended||this.push(null),this._writableState.finished||this.end(),this._connected=!1,this._pcReady=!1,this._channelReady=!1,this._remoteTracks=null,this._remoteStreams=null,this._senderMap=null,clearInterval(this._closingInterval),this._closingInterval=null,clearInterval(this._interval),this._interval=null,this._chunk=null,this._cb=null,this._onFinishBound&&this.removeListener("finish",this._onFinishBound),this._onFinishBound=null,this._channel){try{this._channel.close()}catch(e){}this._channel.onmessage=null,this._channel.onopen=null,this._channel.onclose=null,this._channel.onerror=null}if(this._pc){try{this._pc.close()}catch(e){}this._pc.oniceconnectionstatechange=null,this._pc.onicegatheringstatechange=null,this._pc.onsignalingstatechange=null,this._pc.onicecandidate=null,this._pc.ontrack=null,this._pc.ondatachannel=null}this._pc=null,this._channel=null,t(e)}_setupData(e){if(!e.channel)return this.destroy(c(new Error("Data channel event is missing `channel` property"),"ERR_DATA_CHANNEL"));this._channel=e.channel,this._channel.binaryType="arraybuffer","number"==typeof this._channel.bufferedAmountLowThreshold&&(this._channel.bufferedAmountLowThreshold=u),this.channelName=this._channel.label,this._channel.onmessage=e=>{this._onChannelMessage(e)},this._channel.onbufferedamountlow=()=>{this._onChannelBufferedAmountLow()},this._channel.onopen=()=>{this._onChannelOpen()},this._channel.onclose=()=>{this._onChannelClose()},this._channel.onerror=e=>{this.destroy(c(e,"ERR_DATA_CHANNEL"))};var t=!1;this._closingInterval=setInterval((()=>{this._channel&&"closing"===this._channel.readyState?(t&&this._onChannelClose(),t=!0):t=!1}),5e3)}_read(){}_write(e,t,r){if(this.destroyed)return r(c(new Error("cannot write after peer is destroyed"),"ERR_DATA_CHANNEL"));if(this._connected){try{this.send(e)}catch(e){return this.destroy(c(e,"ERR_DATA_CHANNEL"))}this._channel.bufferedAmount>u?(this._debug("start backpressure: bufferedAmount %d",this._channel.bufferedAmount),this._cb=r):r(null)}else this._debug("write before connect"),this._chunk=e,this._cb=r}_onFinish(){if(this.destroyed)return;const e=()=>{setTimeout((()=>this.destroy()),1e3)};this._connected?e():this.once("connect",e)}_startIceCompleteTimeout(){this.destroyed||this._iceCompleteTimer||(this._debug("started iceComplete timeout"),this._iceCompleteTimer=setTimeout((()=>{this._iceComplete||(this._iceComplete=!0,this._debug("iceComplete timeout completed"),this.emit("iceTimeout"),this.emit("_iceComplete"))}),this.iceCompleteTimeout))}_createOffer(){this.destroyed||this._pc.createOffer(this.offerOptions).then((e=>{if(this.destroyed)return;this.trickle||this.allowHalfTrickle||(e.sdp=l(e.sdp)),e.sdp=this.sdpTransform(e.sdp);const t=()=>{if(!this.destroyed){var t=this._pc.localDescription||e;this._debug("signal"),this.emit("signal",{type:t.type,sdp:t.sdp})}};this._pc.setLocalDescription(e).then((()=>{this._debug("createOffer success"),this.destroyed||(this.trickle||this._iceComplete?t():this.once("_iceComplete",t))})).catch((e=>{this.destroy(c(e,"ERR_SET_LOCAL_DESCRIPTION"))}))})).catch((e=>{this.destroy(c(e,"ERR_CREATE_OFFER"))}))}_requestMissingTransceivers(){this._pc.getTransceivers&&this._pc.getTransceivers().forEach((e=>{e.mid||!e.sender.track||e.requested||(e.requested=!0,this.addTransceiver(e.sender.track.kind))}))}_createAnswer(){this.destroyed||this._pc.createAnswer(this.answerOptions).then((e=>{if(this.destroyed)return;this.trickle||this.allowHalfTrickle||(e.sdp=l(e.sdp)),e.sdp=this.sdpTransform(e.sdp);const t=()=>{if(!this.destroyed){var t=this._pc.localDescription||e;this._debug("signal"),this.emit("signal",{type:t.type,sdp:t.sdp}),this.initiator||this._requestMissingTransceivers()}};this._pc.setLocalDescription(e).then((()=>{this.destroyed||(this.trickle||this._iceComplete?t():this.once("_iceComplete",t))})).catch((e=>{this.destroy(c(e,"ERR_SET_LOCAL_DESCRIPTION"))}))})).catch((e=>{this.destroy(c(e,"ERR_CREATE_ANSWER"))}))}_onConnectionStateChange(){this.destroyed||"failed"===this._pc.connectionState&&this.destroy(c(new Error("Connection failed."),"ERR_CONNECTION_FAILURE"))}_onIceStateChange(){if(!this.destroyed){var e=this._pc.iceConnectionState,t=this._pc.iceGatheringState;this._debug("iceStateChange (connection: %s) (gathering: %s)",e,t),this.emit("iceStateChange",e,t),"connected"!==e&&"completed"!==e||(this._pcReady=!0,this._maybeReady()),"failed"===e&&this.destroy(c(new Error("Ice connection failed."),"ERR_ICE_CONNECTION_FAILURE")),"closed"===e&&this.destroy(c(new Error("Ice connection closed."),"ERR_ICE_CONNECTION_CLOSED"))}}getStats(e){const t=e=>("[object Array]"===Object.prototype.toString.call(e.values)&&e.values.forEach((t=>{Object.assign(e,t)})),e);0===this._pc.getStats.length||this._isReactNativeWebrtc?this._pc.getStats().then((r=>{var i=[];r.forEach((e=>{i.push(t(e))})),e(null,i)}),(t=>e(t))):this._pc.getStats.length>0?this._pc.getStats((r=>{if(!this.destroyed){var i=[];r.result().forEach((e=>{var r={};e.names().forEach((t=>{r[t]=e.stat(t)})),r.id=e.id,r.type=e.type,r.timestamp=e.timestamp,i.push(t(r))})),e(null,i)}}),(t=>e(t))):e(null,[])}_maybeReady(){if(this._debug("maybeReady pc %s channel %s",this._pcReady,this._channelReady),this._connected||this._connecting||!this._pcReady||!this._channelReady)return;this._connecting=!0;const e=()=>{this.destroyed||this.getStats(((t,r)=>{if(this.destroyed)return;t&&(r=[]);var i={},n={},s={},o=!1;r.forEach((e=>{"remotecandidate"!==e.type&&"remote-candidate"!==e.type||(i[e.id]=e),"localcandidate"!==e.type&&"local-candidate"!==e.type||(n[e.id]=e),"candidatepair"!==e.type&&"candidate-pair"!==e.type||(s[e.id]=e)}));const a=e=>{o=!0;var t=n[e.localCandidateId];t&&(t.ip||t.address)?(this.localAddress=t.ip||t.address,this.localPort=Number(t.port)):t&&t.ipAddress?(this.localAddress=t.ipAddress,this.localPort=Number(t.portNumber)):"string"==typeof e.googLocalAddress&&(t=e.googLocalAddress.split(":"),this.localAddress=t[0],this.localPort=Number(t[1])),this.localAddress&&(this.localFamily=this.localAddress.includes(":")?"IPv6":"IPv4");var r=i[e.remoteCandidateId];r&&(r.ip||r.address)?(this.remoteAddress=r.ip||r.address,this.remotePort=Number(r.port)):r&&r.ipAddress?(this.remoteAddress=r.ipAddress,this.remotePort=Number(r.portNumber)):"string"==typeof e.googRemoteAddress&&(r=e.googRemoteAddress.split(":"),this.remoteAddress=r[0],this.remotePort=Number(r[1])),this.remoteAddress&&(this.remoteFamily=this.remoteAddress.includes(":")?"IPv6":"IPv4"),this._debug("connect local: %s:%s remote: %s:%s",this.localAddress,this.localPort,this.remoteAddress,this.remotePort)};if(r.forEach((e=>{"transport"===e.type&&e.selectedCandidatePairId&&a(s[e.selectedCandidatePairId]),("googCandidatePair"===e.type&&"true"===e.googActiveConnection||("candidatepair"===e.type||"candidate-pair"===e.type)&&e.selected)&&a(e)})),o||Object.keys(s).length&&!Object.keys(n).length){if(this._connecting=!1,this._connected=!0,this._chunk){try{this.send(this._chunk)}catch(t){return this.destroy(c(t,"ERR_DATA_CHANNEL"))}this._chunk=null,this._debug('sent chunk from "write before connect"');var u=this._cb;this._cb=null,u(null)}"number"!=typeof this._channel.bufferedAmountLowThreshold&&(this._interval=setInterval((()=>this._onInterval()),150),this._interval.unref&&this._interval.unref()),this._debug("connect"),this.emit("connect")}else setTimeout(e,100)}))};e()}_onInterval(){!this._cb||!this._channel||this._channel.bufferedAmount>u||this._onChannelBufferedAmountLow()}_onSignalingStateChange(){this.destroyed||("stable"!==this._pc.signalingState||this._firstStable||(this._isNegotiating=!1,this._debug("flushing sender queue",this._sendersAwaitingStable),this._sendersAwaitingStable.forEach((e=>{this._pc.removeTrack(e),this._queuedNegotiation=!0})),this._sendersAwaitingStable=[],this._queuedNegotiation&&(this._debug("flushing negotiation queue"),this._queuedNegotiation=!1,this._needsNegotiation()),this._debug("negotiate"),this.emit("negotiate")),this._firstStable=!1,this._debug("signalingStateChange %s",this._pc.signalingState),this.emit("signalingStateChange",this._pc.signalingState))}_onIceCandidate(e){this.destroyed||(e.candidate&&this.trickle?this.emit("signal",{candidate:{candidate:e.candidate.candidate,sdpMLineIndex:e.candidate.sdpMLineIndex,sdpMid:e.candidate.sdpMid}}):e.candidate||this._iceComplete||(this._iceComplete=!0,this.emit("_iceComplete")),e.candidate&&this._startIceCompleteTimeout())}_onChannelMessage(e){if(!this.destroyed){var t=e.data;t instanceof ArrayBuffer&&(t=new Uint8Array(t)),this.push(t)}}_onChannelBufferedAmountLow(){if(!this.destroyed&&this._cb){this._debug("ending backpressure: bufferedAmount %d",this._channel.bufferedAmount);var e=this._cb;this._cb=null,e(null)}}_onChannelOpen(){this._connected||this.destroyed||(this._debug("on channel open"),this._channelReady=!0,this._maybeReady())}_onChannelClose(){this.destroyed||(this._debug("on channel close"),this.destroy())}_onTrack(e){this.destroyed||e.streams.forEach((t=>{this._debug("on track"),this.emit("track",e.track,t),this._remoteTracks.push({track:e.track,stream:t}),this._remoteStreams.some((e=>e.id===t.id))||(this._remoteStreams.push(t),a((()=>{this.emit("stream",t)})))}))}_debug(){var e=[].slice.call(arguments);e[0]="["+this._id+"] "+e[0],i.apply(null,e)}}d.WEBRTC_SUPPORT=!!n(),d.config={iceServers:[{urls:["stun:stun.l.google.com:19302","stun:global.stun.twilio.com:3478"]}],sdpSemantics:"unified-plan"},d.channelConfig={},t.exports=d},{debug:"bO5wM","get-browser-rtc":"k3B3j",randombytes:"jH1v5","readable-stream":"w0M38","queue-microtask":"3aIgO","err-code":"l0zxT"}],k3B3j:[function(e,t,r){t.exports=function(){if("undefined"==typeof globalThis)return null;var e={RTCPeerConnection:globalThis.RTCPeerConnection||globalThis.mozRTCPeerConnection||globalThis.webkitRTCPeerConnection,RTCSessionDescription:globalThis.RTCSessionDescription||globalThis.mozRTCSessionDescription||globalThis.webkitRTCSessionDescription,RTCIceCandidate:globalThis.RTCIceCandidate||globalThis.mozRTCIceCandidate||globalThis.webkitRTCIceCandidate};return e.RTCPeerConnection?e:null}},{}],jH1v5:[function(e,t,r){var i=arguments[3],n=e("process"),s=65536,o=4294967295;function a(){throw new Error("Secure random number generation is not supported by this browser.\nUse Chrome, Firefox or Internet Explorer 11")}var c=e("safe-buffer").Buffer,u=i.crypto||i.msCrypto;function l(e,t){if(e>o)throw new RangeError("requested too many random bytes");var r=c.allocUnsafe(e);if(e>0)if(e>s)for(var i=0;i{const p=new i;let g,y;return p.__connections=[],p.__spChannels=new Map,p.__pendingIntents=new Map,p.listen=i=>{if(g)throw o(new Error("listener already in use"),"ERR_ALREADY_LISTENING");const m=u();let b;g=i,b=!i.protoCodes().includes(f)&&t.localPeer?i.encapsulate(`/p2p/${t.localPeer.toB58String()}`):i,p.on("error",(()=>m.reject())),y=d(i),s("Dialing to Signalling Server on: "+y),p.io=a.connect(y,h);return p.io.once("connect_error",(e=>m.reject(e))),p.io.once("error",(e=>{p.emit("error",e),p.emit("close")})),p.io.on("ws-handshake",(o=>{if(o.answer||o.err||!o.intentId)return;const a=o.intentId;let u=p.__pendingIntents.get(a);u||(u=[],p.__pendingIntents.set(a,u));let d=p.__spChannels.get(a);if(d)return void d.signal(o.signal);if("offer"!==o.signal.type)return void u.push(o);const h={trickle:!1,...n};r.wrtc&&(h.wrtc=r.wrtc),d=new c(h);const g=e=>{s.error("incoming connection errored",e)};d.on("error",g),d.once("close",((...e)=>{d.removeListener("error",g)})),d.on("signal",(e=>{o.signal=e,o.answer=!0,p.io.emit("ss-handshake",o)})),d.signal(o.signal);for(const e of u)d.signal(e.signal);p.__pendingIntents.set(a,[]),d.once("connect",(async()=>{const r=l(d);let n;s("new inbound connection %s",r.remoteAddr);try{n=await t.upgradeInbound(r)}catch(e){return s.error("inbound connection failed to upgrade",e),r.close()}if(!n.remoteAddr)try{n.remoteAddr=i.decapsulateCode(f).encapsulate(`/p2p/${n.remotePeer.toB58String()}`)}catch(e){s.error("could not determine remote address",e)}s("inbound connection %s upgraded",r.remoteAddr),function(e,t,r){e.__connections.push(t);const i=()=>{e.__connections=e.__connections.filter((e=>e!==t)),e.__spChannels.delete(r),e.__pendingIntents.delete(r)};t.conn.once("close",i)}(p,r,a),p.emit("connection",n),e(n)})),p.__spChannels.set(a,d)})),p.io.on("ws-peer",r._peerDiscovered),p.io.on("connect",(()=>{p.io.emit("ss-join",b.toString())})),p.io.once("connect",(()=>{p.emit("listening"),m.resolve()})),r.sigReferences.set(y,{listener:p,signallingAddr:b}),m.promise},p.close=async()=>{const e=r.sigReferences.get(y);e&&e.listener.io&&(e.listener.io.emit("ss-leave"),e.listener.io.close()),await Promise.all(p.__connections.map((e=>e.close()))),p.emit("close"),p.removeAllListeners(),g=void 0,r.sigReferences.delete(y)},p.getAddrs=()=>[g],p}},{events:"g82pp",debug:"bO5wM","err-code":"chZjB","socket.io-client":"iolK3","libp2p-webrtc-peer":"kt3eh","p-defer":"5rKSv","./socket-to-conn":"heHOu","./utils":"kfyaq","./constants":"1IQXV"}],iolK3:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"protocol",(()=>a.protocol)),i.export(r,"Manager",(()=>s.Manager)),i.export(r,"Socket",(()=>o.Socket)),i.export(r,"io",(()=>u)),i.export(r,"connect",(()=>u)),i.export(r,"default",(()=>u));var n=e("./url.js"),s=e("./manager.js"),o=e("./socket.js"),a=e("socket.io-parser");const c={};function u(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};const r=n.url(e,t.path||"/socket.io"),i=r.source,o=r.id,a=r.path,u=c[o]&&a in c[o].nsps;let l;return t.forceNew||t["force new connection"]||!1===t.multiplex||u?l=new s.Manager(i,t):(c[o]||(c[o]=new s.Manager(i,t)),l=c[o]),r.query&&!t.query&&(t.query=r.queryKey),l.socket(r.path,t)}Object.assign(u,{Manager:s.Manager,Socket:o.Socket,io:u,connect:u})},{"./url.js":"hHJao","./manager.js":"2S1kn","./socket.js":"6OhON","socket.io-parser":"5avRb","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],hHJao:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"url",(()=>o));var n=e("parseuri"),s=i.interopDefault(n);function o(e,t="",r){let i=e;r=r||"undefined"!=typeof location&&location,null==e&&(e=r.protocol+"//"+r.host),"string"==typeof e&&("/"===e.charAt(0)&&(e="/"===e.charAt(1)?r.protocol+e:r.host+e),/^(https?|wss?):\/\//.test(e)||(e=void 0!==r?r.protocol+"//"+e:"https://"+e),i=s.default(e)),i.port||(/^(http|ws)$/.test(i.protocol)?i.port="80":/^(http|ws)s$/.test(i.protocol)&&(i.port="443")),i.path=i.path||"/";const n=-1!==i.host.indexOf(":")?"["+i.host+"]":i.host;return i.id=i.protocol+"://"+n+":"+i.port+t,i.href=i.protocol+"://"+n+(r&&r.port===i.port?"":":"+i.port),i}},{parseuri:"iXBlw","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],iXBlw:[function(e,t,r){var i=/^(?:(?![^:@]+:[^:@\/]*@)(http|https|ws|wss):\/\/)?((?:(([^:@]*)(?::([^:@]*))?)?@)?((?:[a-f0-9]{0,4}:){2,7}[a-f0-9]{0,4}|[^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/,n=["source","protocol","authority","userInfo","user","password","host","port","relative","path","directory","file","query","anchor"];t.exports=function(e){var t=e,r=e.indexOf("["),s=e.indexOf("]");-1!=r&&-1!=s&&(e=e.substring(0,r)+e.substring(r,s).replace(/:/g,";")+e.substring(s,e.length));for(var o,a,c=i.exec(e||""),u={},l=14;l--;)u[n[l]]=c[l]||"";return-1!=r&&-1!=s&&(u.source=t,u.host=u.host.substring(1,u.host.length-1).replace(/;/g,":"),u.authority=u.authority.replace("[","").replace("]","").replace(/;/g,":"),u.ipv6uri=!0),u.pathNames=function(e,t){var r=/\/{2,9}/g,i=t.replace(r,"/").split("/");"/"!=t.substr(0,1)&&0!==t.length||i.splice(0,1);"/"==t.substr(t.length-1,1)&&i.splice(i.length-1,1);return i}(0,u.path),u.queryKey=(o=u.query,a={},o.replace(/(?:^|&)([^&=]*)=?([^&]*)/g,(function(e,t,r){t&&(a[t]=r)})),a),u}},{}],"2S1kn":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"Manager",(()=>d));var n=e("engine.io-client"),s=e("./socket.js"),o=e("socket.io-parser"),a=e("./on.js"),c=e("backo2"),u=i.interopDefault(c),l=e("@socket.io/component-emitter");class d extends l.Emitter{constructor(e,t){var r;super(),this.nsps={},this.subs=[],e&&"object"==typeof e&&(t=e,e=void 0),(t=t||{}).path=t.path||"/socket.io",this.opts=t,n.installTimerFunctions(this,t),this.reconnection(!1!==t.reconnection),this.reconnectionAttempts(t.reconnectionAttempts||1/0),this.reconnectionDelay(t.reconnectionDelay||1e3),this.reconnectionDelayMax(t.reconnectionDelayMax||5e3),this.randomizationFactor(null!==(r=t.randomizationFactor)&&void 0!==r?r:.5),this.backoff=new u.default({min:this.reconnectionDelay(),max:this.reconnectionDelayMax(),jitter:this.randomizationFactor()}),this.timeout(null==t.timeout?2e4:t.timeout),this._readyState="closed",this.uri=e;const i=t.parser||o;this.encoder=new i.Encoder,this.decoder=new i.Decoder,this._autoConnect=!1!==t.autoConnect,this._autoConnect&&this.open()}reconnection(e){return arguments.length?(this._reconnection=!!e,this):this._reconnection}reconnectionAttempts(e){return void 0===e?this._reconnectionAttempts:(this._reconnectionAttempts=e,this)}reconnectionDelay(e){var t;return void 0===e?this._reconnectionDelay:(this._reconnectionDelay=e,null===(t=this.backoff)||void 0===t||t.setMin(e),this)}randomizationFactor(e){var t;return void 0===e?this._randomizationFactor:(this._randomizationFactor=e,null===(t=this.backoff)||void 0===t||t.setJitter(e),this)}reconnectionDelayMax(e){var t;return void 0===e?this._reconnectionDelayMax:(this._reconnectionDelayMax=e,null===(t=this.backoff)||void 0===t||t.setMax(e),this)}timeout(e){return arguments.length?(this._timeout=e,this):this._timeout}maybeReconnectOnOpen(){!this._reconnecting&&this._reconnection&&0===this.backoff.attempts&&this.reconnect()}open(e){if(~this._readyState.indexOf("open"))return this;this.engine=new n.Socket(this.uri,this.opts);const t=this.engine,r=this;this._readyState="opening",this.skipReconnect=!1;const i=a.on(t,"open",(function(){r.onopen(),e&&e()})),s=a.on(t,"error",(t=>{r.cleanup(),r._readyState="closed",this.emitReserved("error",t),e?e(t):r.maybeReconnectOnOpen()}));if(!1!==this._timeout){const e=this._timeout;0===e&&i();const r=this.setTimeoutFn((()=>{i(),t.close(),t.emit("error",new Error("timeout"))}),e);this.opts.autoUnref&&r.unref(),this.subs.push((function(){clearTimeout(r)}))}return this.subs.push(i),this.subs.push(s),this}connect(e){return this.open(e)}onopen(){this.cleanup(),this._readyState="open",this.emitReserved("open");const e=this.engine;this.subs.push(a.on(e,"ping",this.onping.bind(this)),a.on(e,"data",this.ondata.bind(this)),a.on(e,"error",this.onerror.bind(this)),a.on(e,"close",this.onclose.bind(this)),a.on(this.decoder,"decoded",this.ondecoded.bind(this)))}onping(){this.emitReserved("ping")}ondata(e){this.decoder.add(e)}ondecoded(e){this.emitReserved("packet",e)}onerror(e){this.emitReserved("error",e)}socket(e,t){let r=this.nsps[e];return r||(r=new s.Socket(this,e,t),this.nsps[e]=r),r}_destroy(e){const t=Object.keys(this.nsps);for(const e of t){if(this.nsps[e].active)return}this._close()}_packet(e){const t=this.encoder.encode(e);for(let r=0;re())),this.subs.length=0,this.decoder.destroy()}_close(){this.skipReconnect=!0,this._reconnecting=!1,this.onclose("forced close"),this.engine&&this.engine.close()}disconnect(){return this._close()}onclose(e){this.cleanup(),this.backoff.reset(),this._readyState="closed",this.emitReserved("close",e),this._reconnection&&!this.skipReconnect&&this.reconnect()}reconnect(){if(this._reconnecting||this.skipReconnect)return this;const e=this;if(this.backoff.attempts>=this._reconnectionAttempts)this.backoff.reset(),this.emitReserved("reconnect_failed"),this._reconnecting=!1;else{const t=this.backoff.duration();this._reconnecting=!0;const r=this.setTimeoutFn((()=>{e.skipReconnect||(this.emitReserved("reconnect_attempt",e.backoff.attempts),e.skipReconnect||e.open((t=>{t?(e._reconnecting=!1,e.reconnect(),this.emitReserved("reconnect_error",t)):e.onreconnect()})))}),t);this.opts.autoUnref&&r.unref(),this.subs.push((function(){clearTimeout(r)}))}}onreconnect(){const e=this.backoff.attempts;this._reconnecting=!1,this.backoff.reset(),this.emitReserved("reconnect",e)}}},{"engine.io-client":"3bSox","./socket.js":"6OhON","socket.io-parser":"5avRb","./on.js":"8c8jd",backo2:"jE9JM","@socket.io/component-emitter":"kYHC2","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],"3bSox":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"Socket",(()=>n.Socket)),i.export(r,"protocol",(()=>c)),i.export(r,"Transport",(()=>s.Transport)),i.export(r,"transports",(()=>o.transports)),i.export(r,"installTimerFunctions",(()=>a.installTimerFunctions));var n=e("./socket.js"),s=e("./transport.js"),o=e("./transports/index.js"),a=e("./util.js");const c=n.Socket.protocol},{"./socket.js":"7OyJL","./transport.js":"jdgVA","./transports/index.js":"ae41u","./util.js":"hj4iM","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],"7OyJL":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"Socket",(()=>f));var n=e("./transports/index.js"),s=e("./util.js"),o=e("parseqs"),a=i.interopDefault(o),c=e("parseuri"),u=i.interopDefault(c),l=e("@socket.io/component-emitter"),d=e("engine.io-parser");class f extends l.Emitter{constructor(e,t={}){super(),e&&"object"==typeof e&&(t=e,e=null),e?(e=u.default(e),t.hostname=e.host,t.secure="https"===e.protocol||"wss"===e.protocol,t.port=e.port,e.query&&(t.query=e.query)):t.host&&(t.hostname=u.default(t.host).host),s.installTimerFunctions(this,t),this.secure=null!=t.secure?t.secure:"undefined"!=typeof location&&"https:"===location.protocol,t.hostname&&!t.port&&(t.port=this.secure?"443":"80"),this.hostname=t.hostname||("undefined"!=typeof location?location.hostname:"localhost"),this.port=t.port||("undefined"!=typeof location&&location.port?location.port:this.secure?"443":"80"),this.transports=t.transports||["polling","websocket"],this.readyState="",this.writeBuffer=[],this.prevBufferLen=0,this.opts=Object.assign({path:"/engine.io",agent:!1,withCredentials:!1,upgrade:!0,timestampParam:"t",rememberUpgrade:!1,rejectUnauthorized:!0,perMessageDeflate:{threshold:1024},transportOptions:{},closeOnBeforeunload:!0},t),this.opts.path=this.opts.path.replace(/\/$/,"")+"/","string"==typeof this.opts.query&&(this.opts.query=a.default.decode(this.opts.query)),this.id=null,this.upgrades=null,this.pingInterval=null,this.pingTimeout=null,this.pingTimeoutTimer=null,"function"==typeof addEventListener&&(this.opts.closeOnBeforeunload&&addEventListener("beforeunload",(()=>{this.transport&&(this.transport.removeAllListeners(),this.transport.close())}),!1),"localhost"!==this.hostname&&(this.offlineEventListener=()=>{this.onClose("transport close")},addEventListener("offline",this.offlineEventListener,!1))),this.open()}createTransport(e){const t=function(e){const t={};for(let r in e)e.hasOwnProperty(r)&&(t[r]=e[r]);return t}(this.opts.query);t.EIO=d.protocol,t.transport=e,this.id&&(t.sid=this.id);const r=Object.assign({},this.opts.transportOptions[e],this.opts,{query:t,socket:this,hostname:this.hostname,secure:this.secure,port:this.port});return new n.transports[e](r)}open(){let e;if(this.opts.rememberUpgrade&&f.priorWebsocketSuccess&&-1!==this.transports.indexOf("websocket"))e="websocket";else{if(0===this.transports.length)return void this.setTimeoutFn((()=>{this.emitReserved("error","No transports available")}),0);e=this.transports[0]}this.readyState="opening";try{e=this.createTransport(e)}catch(e){return this.transports.shift(),void this.open()}e.open(),this.setTransport(e)}setTransport(e){this.transport&&this.transport.removeAllListeners(),this.transport=e,e.on("drain",this.onDrain.bind(this)).on("packet",this.onPacket.bind(this)).on("error",this.onError.bind(this)).on("close",(()=>{this.onClose("transport close")}))}probe(e){let t=this.createTransport(e),r=!1;f.priorWebsocketSuccess=!1;const i=()=>{r||(t.send([{type:"ping",data:"probe"}]),t.once("packet",(e=>{if(!r)if("pong"===e.type&&"probe"===e.data){if(this.upgrading=!0,this.emitReserved("upgrading",t),!t)return;f.priorWebsocketSuccess="websocket"===t.name,this.transport.pause((()=>{r||"closed"!==this.readyState&&(u(),this.setTransport(t),t.send([{type:"upgrade"}]),this.emitReserved("upgrade",t),t=null,this.upgrading=!1,this.flush())}))}else{const e=new Error("probe error");e.transport=t.name,this.emitReserved("upgradeError",e)}})))};function n(){r||(r=!0,u(),t.close(),t=null)}const s=e=>{const r=new Error("probe error: "+e);r.transport=t.name,n(),this.emitReserved("upgradeError",r)};function o(){s("transport closed")}function a(){s("socket closed")}function c(e){t&&e.name!==t.name&&n()}const u=()=>{t.removeListener("open",i),t.removeListener("error",s),t.removeListener("close",o),this.off("close",a),this.off("upgrading",c)};t.once("open",i),t.once("error",s),t.once("close",o),this.once("close",a),this.once("upgrading",c),t.open()}onOpen(){if(this.readyState="open",f.priorWebsocketSuccess="websocket"===this.transport.name,this.emitReserved("open"),this.flush(),"open"===this.readyState&&this.opts.upgrade&&this.transport.pause){let e=0;const t=this.upgrades.length;for(;e{this.onClose("ping timeout")}),this.pingInterval+this.pingTimeout),this.opts.autoUnref&&this.pingTimeoutTimer.unref()}onDrain(){this.writeBuffer.splice(0,this.prevBufferLen),this.prevBufferLen=0,0===this.writeBuffer.length?this.emitReserved("drain"):this.flush()}flush(){"closed"!==this.readyState&&this.transport.writable&&!this.upgrading&&this.writeBuffer.length&&(this.transport.send(this.writeBuffer),this.prevBufferLen=this.writeBuffer.length,this.emitReserved("flush"))}write(e,t,r){return this.sendPacket("message",e,t,r),this}send(e,t,r){return this.sendPacket("message",e,t,r),this}sendPacket(e,t,r,i){if("function"==typeof t&&(i=t,t=void 0),"function"==typeof r&&(i=r,r=null),"closing"===this.readyState||"closed"===this.readyState)return;(r=r||{}).compress=!1!==r.compress;const n={type:e,data:t,options:r};this.emitReserved("packetCreate",n),this.writeBuffer.push(n),i&&this.once("flush",i),this.flush()}close(){const e=()=>{this.onClose("forced close"),this.transport.close()},t=()=>{this.off("upgrade",t),this.off("upgradeError",t),e()},r=()=>{this.once("upgrade",t),this.once("upgradeError",t)};return"opening"!==this.readyState&&"open"!==this.readyState||(this.readyState="closing",this.writeBuffer.length?this.once("drain",(()=>{this.upgrading?r():e()})):this.upgrading?r():e()),this}onError(e){f.priorWebsocketSuccess=!1,this.emitReserved("error",e),this.onClose("transport error",e)}onClose(e,t){"opening"!==this.readyState&&"open"!==this.readyState&&"closing"!==this.readyState||(this.clearTimeoutFn(this.pingTimeoutTimer),this.transport.removeAllListeners("close"),this.transport.close(),this.transport.removeAllListeners(),"function"==typeof removeEventListener&&removeEventListener("offline",this.offlineEventListener,!1),this.readyState="closed",this.id=null,this.emitReserved("close",e,t),this.writeBuffer=[],this.prevBufferLen=0)}filterUpgrades(e){const t=[];let r=0;const i=e.length;for(;rs));var n=e("./polling-xhr.js");const s={websocket:e("./websocket.js").WS,polling:n.XHR}},{"./polling-xhr.js":"amf1l","./websocket.js":"iYHZM","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],amf1l:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"XHR",(()=>h)),i.export(r,"Request",(()=>p));var n=e("./xmlhttprequest.js"),s=i.interopDefault(n),o=e("../globalThis.js"),a=i.interopDefault(o),c=e("../util.js"),u=e("@socket.io/component-emitter"),l=e("./polling.js");function d(){}const f=null!=new s.default({xdomain:!1}).responseType;class h extends l.Polling{constructor(e){if(super(e),"undefined"!=typeof location){const t="https:"===location.protocol;let r=location.port;r||(r=t?"443":"80"),this.xd="undefined"!=typeof location&&e.hostname!==location.hostname||r!==e.port,this.xs=e.secure!==t}const t=e&&e.forceBase64;this.supportsBinary=f&&!t}request(e={}){return Object.assign(e,{xd:this.xd,xs:this.xs},this.opts),new p(this.uri(),e)}doWrite(e,t){const r=this.request({method:"POST",data:e});r.on("success",t),r.on("error",(e=>{this.onError("xhr post error",e)}))}doPoll(){const e=this.request();e.on("data",this.onData.bind(this)),e.on("error",(e=>{this.onError("xhr poll error",e)})),this.pollXhr=e}}class p extends u.Emitter{constructor(e,t){super(),c.installTimerFunctions(this,t),this.opts=t,this.method=t.method||"GET",this.uri=e,this.async=!1!==t.async,this.data=void 0!==t.data?t.data:null,this.create()}create(){const e=c.pick(this.opts,"agent","pfx","key","passphrase","cert","ca","ciphers","rejectUnauthorized","autoUnref");e.xdomain=!!this.opts.xd,e.xscheme=!!this.opts.xs;const t=this.xhr=new s.default(e);try{t.open(this.method,this.uri,this.async);try{if(this.opts.extraHeaders){t.setDisableHeaderCheck&&t.setDisableHeaderCheck(!0);for(let e in this.opts.extraHeaders)this.opts.extraHeaders.hasOwnProperty(e)&&t.setRequestHeader(e,this.opts.extraHeaders[e])}}catch(e){}if("POST"===this.method)try{t.setRequestHeader("Content-type","text/plain;charset=UTF-8")}catch(e){}try{t.setRequestHeader("Accept","*/*")}catch(e){}"withCredentials"in t&&(t.withCredentials=this.opts.withCredentials),this.opts.requestTimeout&&(t.timeout=this.opts.requestTimeout),t.onreadystatechange=()=>{4===t.readyState&&(200===t.status||1223===t.status?this.onLoad():this.setTimeoutFn((()=>{this.onError("number"==typeof t.status?t.status:0)}),0))},t.send(this.data)}catch(e){return void this.setTimeoutFn((()=>{this.onError(e)}),0)}"undefined"!=typeof document&&(this.index=p.requestsCount++,p.requests[this.index]=this)}onSuccess(){this.emit("success"),this.cleanup()}onData(e){this.emit("data",e),this.onSuccess()}onError(e){this.emit("error",e),this.cleanup(!0)}cleanup(e){if(void 0!==this.xhr&&null!==this.xhr){if(this.xhr.onreadystatechange=d,e)try{this.xhr.abort()}catch(e){}"undefined"!=typeof document&&delete p.requests[this.index],this.xhr=null}}onLoad(){const e=this.xhr.responseText;null!==e&&this.onData(e)}abort(){this.cleanup()}}if(p.requestsCount=0,p.requests={},"undefined"!=typeof document)if("function"==typeof attachEvent)attachEvent("onunload",g);else if("function"==typeof addEventListener){const e="onpagehide"in a.default?"pagehide":"unload";addEventListener(e,g,!1)}function g(){for(let e in p.requests)p.requests.hasOwnProperty(e)&&p.requests[e].abort()}},{"./xmlhttprequest.js":"fZPB9","../globalThis.js":"fLI8m","../util.js":"hj4iM","@socket.io/component-emitter":"kYHC2","./polling.js":"kT6ee","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],fZPB9:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r);var n=e("has-cors"),s=i.interopDefault(n),o=e("../globalThis.js"),a=i.interopDefault(o);r.default=function(e){const t=e.xdomain;try{if("undefined"!=typeof XMLHttpRequest&&(!t||s.default))return new XMLHttpRequest}catch(e){}if(!t)try{return new(a.default[["Active"].concat("Object").join("X")])("Microsoft.XMLHTTP")}catch(e){}}},{"has-cors":"f7en3","../globalThis.js":"fLI8m","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],f7en3:[function(e,t,r){try{t.exports="undefined"!=typeof XMLHttpRequest&&"withCredentials"in new XMLHttpRequest}catch(e){t.exports=!1}},{}],fLI8m:[function(e,t,r){e("@parcel/transformer-js/src/esmodule-helpers.js").defineInteropFlag(r),r.default="undefined"!=typeof self?self:"undefined"!=typeof window?window:Function("return this")()},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],hj4iM:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"pick",(()=>o)),i.export(r,"installTimerFunctions",(()=>u));var n=e("./globalThis.js"),s=i.interopDefault(n);function o(e,...t){return t.reduce(((t,r)=>(e.hasOwnProperty(r)&&(t[r]=e[r]),t)),{})}const a=setTimeout,c=clearTimeout;function u(e,t){t.useNativeTimers?(e.setTimeoutFn=a.bind(s.default),e.clearTimeoutFn=c.bind(s.default)):(e.setTimeoutFn=setTimeout.bind(s.default),e.clearTimeoutFn=clearTimeout.bind(s.default))}},{"./globalThis.js":"fLI8m","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],kYHC2:[function(e,t,r){function i(e){if(e)return function(e){for(var t in i.prototype)e[t]=i.prototype[t];return e}(e)}r.Emitter=i,i.prototype.on=i.prototype.addEventListener=function(e,t){return this._callbacks=this._callbacks||{},(this._callbacks["$"+e]=this._callbacks["$"+e]||[]).push(t),this},i.prototype.once=function(e,t){function r(){this.off(e,r),t.apply(this,arguments)}return r.fn=t,this.on(e,r),this},i.prototype.off=i.prototype.removeListener=i.prototype.removeAllListeners=i.prototype.removeEventListener=function(e,t){if(this._callbacks=this._callbacks||{},0==arguments.length)return this._callbacks={},this;var r,i=this._callbacks["$"+e];if(!i)return this;if(1==arguments.length)return delete this._callbacks["$"+e],this;for(var n=0;nl));var n=e("../transport.js"),s=e("yeast"),o=i.interopDefault(s),a=e("parseqs"),c=i.interopDefault(a),u=e("engine.io-parser");class l extends n.Transport{constructor(){super(...arguments),this.polling=!1}get name(){return"polling"}doOpen(){this.poll()}pause(e){this.readyState="pausing";const t=()=>{this.readyState="paused",e()};if(this.polling||!this.writable){let e=0;this.polling&&(e++,this.once("pollComplete",(function(){--e||t()}))),this.writable||(e++,this.once("drain",(function(){--e||t()})))}else t()}poll(){this.polling=!0,this.doPoll(),this.emit("poll")}onData(e){u.decodePayload(e,this.socket.binaryType).forEach((e=>{if("opening"===this.readyState&&"open"===e.type&&this.onOpen(),"close"===e.type)return this.onClose(),!1;this.onPacket(e)})),"closed"!==this.readyState&&(this.polling=!1,this.emit("pollComplete"),"open"===this.readyState&&this.poll())}doClose(){const e=()=>{this.write([{type:"close"}])};"open"===this.readyState?e():this.once("open",e)}write(e){this.writable=!1,u.encodePayload(e,(e=>{this.doWrite(e,(()=>{this.writable=!0,this.emit("drain")}))}))}uri(){let e=this.query||{};const t=this.opts.secure?"https":"http";let r="";!1!==this.opts.timestampRequests&&(e[this.opts.timestampParam]=o.default()),this.supportsBinary||e.sid||(e.b64=1),this.opts.port&&("https"===t&&443!==Number(this.opts.port)||"http"===t&&80!==Number(this.opts.port))&&(r=":"+this.opts.port);const i=c.default.encode(e);return t+"://"+(-1!==this.opts.hostname.indexOf(":")?"["+this.opts.hostname+"]":this.opts.hostname)+r+this.opts.path+(i.length?"?"+i:"")}}},{"../transport.js":"jdgVA",yeast:"da0sk",parseqs:"kg931","engine.io-parser":"mMYXv","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],jdgVA:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"Transport",(()=>a));var n=e("engine.io-parser"),s=e("@socket.io/component-emitter"),o=e("./util.js");class a extends s.Emitter{constructor(e){super(),this.writable=!1,o.installTimerFunctions(this,e),this.opts=e,this.query=e.query,this.readyState="",this.socket=e.socket}onError(e,t){const r=new Error(e);return r.type="TransportError",r.description=t,super.emit("error",r),this}open(){return"closed"!==this.readyState&&""!==this.readyState||(this.readyState="opening",this.doOpen()),this}close(){return"opening"!==this.readyState&&"open"!==this.readyState||(this.doClose(),this.onClose()),this}send(e){"open"===this.readyState&&this.write(e)}onOpen(){this.readyState="open",this.writable=!0,super.emit("open")}onData(e){const t=n.decodePacket(e,this.socket.binaryType);this.onPacket(t)}onPacket(e){super.emit("packet",e)}onClose(){this.readyState="closed",super.emit("close")}}},{"engine.io-parser":"mMYXv","@socket.io/component-emitter":"kYHC2","./util.js":"hj4iM","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],mMYXv:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"protocol",(()=>d)),i.export(r,"encodePacket",(()=>s.default)),i.export(r,"encodePayload",(()=>u)),i.export(r,"decodePacket",(()=>a.default)),i.export(r,"decodePayload",(()=>l));var n=e("./encodePacket.js"),s=i.interopDefault(n),o=e("./decodePacket.js"),a=i.interopDefault(o);const c=String.fromCharCode(30),u=(e,t)=>{const r=e.length,i=new Array(r);let n=0;e.forEach(((e,o)=>{s.default(e,!1,(e=>{i[o]=e,++n===r&&t(i.join(c))}))}))},l=(e,t)=>{const r=e.split(c),i=[];for(let e=0;e{const r=new FileReader;return r.onload=function(){const e=r.result.split(",")[1];t("b"+e)},r.readAsDataURL(e)};r.default=({type:e,data:t},r,a)=>{return n&&t instanceof Blob?r?a(t):o(t,a):s&&(t instanceof ArrayBuffer||(c=t,"function"==typeof ArrayBuffer.isView?ArrayBuffer.isView(c):c&&c.buffer instanceof ArrayBuffer))?r?a(t):o(new Blob([t]),a):a(i.PACKET_TYPES[e]+(t||""));var c}},{"./commons.js":"2D0Nf","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],"2D0Nf":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"PACKET_TYPES",(()=>n)),i.export(r,"PACKET_TYPES_REVERSE",(()=>s)),i.export(r,"ERROR_PACKET",(()=>o));const n=Object.create(null);n.open="0",n.close="1",n.ping="2",n.pong="3",n.message="4",n.upgrade="5",n.noop="6";const s=Object.create(null);Object.keys(n).forEach((e=>{s[n[e]]=e}));const o={type:"error",data:"parser error"}},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],dGiro:[function(e,t,r){e("@parcel/transformer-js/src/esmodule-helpers.js").defineInteropFlag(r);var i=e("./commons.js"),n=e("base64-arraybuffer");const s="function"==typeof ArrayBuffer,o=(e,t)=>{if(s){const r=n.decode(e);return a(r,t)}return{base64:!0,data:e}},a=(e,t)=>"blob"===t&&e instanceof ArrayBuffer?new Blob([e]):e;r.default=(e,t)=>{if("string"!=typeof e)return{type:"message",data:a(e,t)};const r=e.charAt(0);if("b"===r)return{type:"message",data:o(e.substring(1),t)};return i.PACKET_TYPES_REVERSE[r]?e.length>1?{type:i.PACKET_TYPES_REVERSE[r],data:e.substring(1)}:{type:i.PACKET_TYPES_REVERSE[r]}:i.ERROR_PACKET}},{"./commons.js":"2D0Nf","base64-arraybuffer":"h2Zgn","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],h2Zgn:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"decode",(()=>c)),i.export(r,"encode",(()=>a));for(var n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",s="undefined"==typeof Uint8Array?[]:new Uint8Array(256),o=0;o>2],s+=n[(3&r[t])<<4|r[t+1]>>4],s+=n[(15&r[t+1])<<2|r[t+2]>>6],s+=n[63&r[t+2]];return i%3==2?s=s.substring(0,s.length-1)+"=":i%3==1&&(s=s.substring(0,s.length-2)+"=="),s},c=function(e){var t,r,i,n,o,a=.75*e.length,c=e.length,u=0;"="===e[e.length-1]&&(a--,"="===e[e.length-2]&&a--);var l=new ArrayBuffer(a),d=new Uint8Array(l);for(t=0;t>4,d[u++]=(15&i)<<4|n>>2,d[u++]=(3&n)<<6|63&o;return l}},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],da0sk:[function(e,t,r){"use strict";var i,n="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz-_".split(""),s={},o=0,a=0;function c(e){var t="";do{t=n[e%64]+t,e=Math.floor(e/64)}while(e>0);return t}function u(){var e=c(+new Date);return e!==i?(o=0,i=e):e+"."+c(o++)}for(;a<64;a++)s[n[a]]=a;u.encode=c,u.decode=function(e){var t=0;for(a=0;ap));var n=e("../transport.js"),s=e("parseqs"),o=i.interopDefault(s),a=e("yeast"),c=i.interopDefault(a),u=e("../util.js"),l=e("./websocket-constructor.js"),d=e("engine.io-parser"),f=e("buffer").Buffer;const h="undefined"!=typeof navigator&&"string"==typeof navigator.product&&"reactnative"===navigator.product.toLowerCase();class p extends n.Transport{constructor(e){super(e),this.supportsBinary=!e.forceBase64}get name(){return"websocket"}doOpen(){if(!this.check())return;const e=this.uri(),t=this.opts.protocols,r=h?{}:u.pick(this.opts,"agent","perMessageDeflate","pfx","key","passphrase","cert","ca","ciphers","rejectUnauthorized","localAddress","protocolVersion","origin","maxPayload","family","checkServerIdentity");this.opts.extraHeaders&&(r.headers=this.opts.extraHeaders);try{this.ws=l.usingBrowserWebSocket&&!h?t?new l.WebSocket(e,t):new l.WebSocket(e):new l.WebSocket(e,t,r)}catch(e){return this.emit("error",e)}this.ws.binaryType=this.socket.binaryType||l.defaultBinaryType,this.addEventListeners()}addEventListeners(){this.ws.onopen=()=>{this.opts.autoUnref&&this.ws._socket.unref(),this.onOpen()},this.ws.onclose=this.onClose.bind(this),this.ws.onmessage=e=>this.onData(e.data),this.ws.onerror=e=>this.onError("websocket error",e)}write(e){this.writable=!1;for(let t=0;t{const t={};if(!l.usingBrowserWebSocket&&(r.options&&(t.compress=r.options.compress),this.opts.perMessageDeflate)){("string"==typeof e?f.byteLength(e):e.length){this.writable=!0,this.emit("drain")}),this.setTimeoutFn)}))}}doClose(){void 0!==this.ws&&(this.ws.close(),this.ws=null)}uri(){let e=this.query||{};const t=this.opts.secure?"wss":"ws";let r="";this.opts.port&&("wss"===t&&443!==Number(this.opts.port)||"ws"===t&&80!==Number(this.opts.port))&&(r=":"+this.opts.port),this.opts.timestampRequests&&(e[this.opts.timestampParam]=c.default()),this.supportsBinary||(e.b64=1);const i=o.default.encode(e);return t+"://"+(-1!==this.opts.hostname.indexOf(":")?"["+this.opts.hostname+"]":this.opts.hostname)+r+this.opts.path+(i.length?"?"+i:"")}check(){return!(!l.WebSocket||"__initialize"in l.WebSocket&&this.name===p.prototype.name)}}},{buffer:"etowf","../transport.js":"jdgVA",parseqs:"kg931",yeast:"da0sk","../util.js":"hj4iM","./websocket-constructor.js":"eTlGe","engine.io-parser":"mMYXv","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],eTlGe:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"nextTick",(()=>o)),i.export(r,"WebSocket",(()=>a)),i.export(r,"usingBrowserWebSocket",(()=>c)),i.export(r,"defaultBinaryType",(()=>u));var n=e("../globalThis.js"),s=i.interopDefault(n);const o="function"==typeof Promise&&"function"==typeof Promise.resolve?e=>Promise.resolve().then(e):(e,t)=>t(e,0),a=s.default.WebSocket||s.default.MozWebSocket,c=!0,u="arraybuffer"},{"../globalThis.js":"fLI8m","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],"6OhON":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"Socket",(()=>c));var n=e("socket.io-parser"),s=e("./on.js"),o=e("@socket.io/component-emitter");const a=Object.freeze({connect:1,connect_error:1,disconnect:1,disconnecting:1,newListener:1,removeListener:1});class c extends o.Emitter{constructor(e,t,r){super(),this.connected=!1,this.disconnected=!0,this.receiveBuffer=[],this.sendBuffer=[],this.ids=0,this.acks={},this.flags={},this.io=e,this.nsp=t,r&&r.auth&&(this.auth=r.auth),this.io._autoConnect&&this.open()}subEvents(){if(this.subs)return;const e=this.io;this.subs=[s.on(e,"open",this.onopen.bind(this)),s.on(e,"packet",this.onpacket.bind(this)),s.on(e,"error",this.onerror.bind(this)),s.on(e,"close",this.onclose.bind(this))]}get active(){return!!this.subs}connect(){return this.connected||(this.subEvents(),this.io._reconnecting||this.io.open(),"open"===this.io._readyState&&this.onopen()),this}open(){return this.connect()}send(...e){return e.unshift("message"),this.emit.apply(this,e),this}emit(e,...t){if(a.hasOwnProperty(e))throw new Error('"'+e+'" is a reserved event name');t.unshift(e);const r={type:n.PacketType.EVENT,data:t,options:{}};if(r.options.compress=!1!==this.flags.compress,"function"==typeof t[t.length-1]){const e=this.ids++,i=t.pop();this._registerAckCallback(e,i),r.id=e}const i=this.io.engine&&this.io.engine.transport&&this.io.engine.transport.writable;return this.flags.volatile&&(!i||!this.connected)||(this.connected?this.packet(r):this.sendBuffer.push(r)),this.flags={},this}_registerAckCallback(e,t){const r=this.flags.timeout;if(void 0===r)return void(this.acks[e]=t);const i=this.io.setTimeoutFn((()=>{delete this.acks[e];for(let t=0;t{this.io.clearTimeoutFn(i),t.apply(this,[null,...e])}}packet(e){e.nsp=this.nsp,this.io._packet(e)}onopen(){"function"==typeof this.auth?this.auth((e=>{this.packet({type:n.PacketType.CONNECT,data:e})})):this.packet({type:n.PacketType.CONNECT,data:this.auth})}onerror(e){this.connected||this.emitReserved("connect_error",e)}onclose(e){this.connected=!1,this.disconnected=!0,delete this.id,this.emitReserved("disconnect",e)}onpacket(e){if(e.nsp===this.nsp)switch(e.type){case n.PacketType.CONNECT:if(e.data&&e.data.sid){const t=e.data.sid;this.onconnect(t)}else this.emitReserved("connect_error",new Error("It seems you are trying to reach a Socket.IO server in v2.x with a v3.x client, but they are not compatible (more information here: https://socket.io/docs/v3/migrating-from-2-x-to-3-0/)"));break;case n.PacketType.EVENT:case n.PacketType.BINARY_EVENT:this.onevent(e);break;case n.PacketType.ACK:case n.PacketType.BINARY_ACK:this.onack(e);break;case n.PacketType.DISCONNECT:this.ondisconnect();break;case n.PacketType.CONNECT_ERROR:this.destroy();const t=new Error(e.data.message);t.data=e.data.data,this.emitReserved("connect_error",t)}}onevent(e){const t=e.data||[];null!=e.id&&t.push(this.ack(e.id)),this.connected?this.emitEvent(t):this.receiveBuffer.push(Object.freeze(t))}emitEvent(e){if(this._anyListeners&&this._anyListeners.length){const t=this._anyListeners.slice();for(const r of t)r.apply(this,e)}super.emit.apply(this,e)}ack(e){const t=this;let r=!1;return function(...i){r||(r=!0,t.packet({type:n.PacketType.ACK,id:e,data:i}))}}onack(e){const t=this.acks[e.id];"function"==typeof t&&(t.apply(this,e.data),delete this.acks[e.id])}onconnect(e){this.id=e,this.connected=!0,this.disconnected=!1,this.emitBuffered(),this.emitReserved("connect")}emitBuffered(){this.receiveBuffer.forEach((e=>this.emitEvent(e))),this.receiveBuffer=[],this.sendBuffer.forEach((e=>this.packet(e))),this.sendBuffer=[]}ondisconnect(){this.destroy(),this.onclose("io server disconnect")}destroy(){this.subs&&(this.subs.forEach((e=>e())),this.subs=void 0),this.io._destroy(this)}disconnect(){return this.connected&&this.packet({type:n.PacketType.DISCONNECT}),this.destroy(),this.connected&&this.onclose("io client disconnect"),this}close(){return this.disconnect()}compress(e){return this.flags.compress=e,this}get volatile(){return this.flags.volatile=!0,this}timeout(e){return this.flags.timeout=e,this}onAny(e){return this._anyListeners=this._anyListeners||[],this._anyListeners.push(e),this}prependAny(e){return this._anyListeners=this._anyListeners||[],this._anyListeners.unshift(e),this}offAny(e){if(!this._anyListeners)return this;if(e){const t=this._anyListeners;for(let r=0;ra)),i.export(r,"PacketType",(()=>c)),i.export(r,"Encoder",(()=>l)),i.export(r,"Decoder",(()=>d));var n=e("@socket.io/component-emitter"),s=e("./binary.js"),o=e("./is-binary.js");const a=5;var c,u;(u=c||(c={}))[u.CONNECT=0]="CONNECT",u[u.DISCONNECT=1]="DISCONNECT",u[u.EVENT=2]="EVENT",u[u.ACK=3]="ACK",u[u.CONNECT_ERROR=4]="CONNECT_ERROR",u[u.BINARY_EVENT=5]="BINARY_EVENT",u[u.BINARY_ACK=6]="BINARY_ACK";class l{encode(e){return e.type!==c.EVENT&&e.type!==c.ACK||!o.hasBinary(e)?[this.encodeAsString(e)]:(e.type=e.type===c.EVENT?c.BINARY_EVENT:c.BINARY_ACK,this.encodeAsBinary(e))}encodeAsString(e){let t=""+e.type;return e.type!==c.BINARY_EVENT&&e.type!==c.BINARY_ACK||(t+=e.attachments+"-"),e.nsp&&"/"!==e.nsp&&(t+=e.nsp+","),null!=e.id&&(t+=e.id),null!=e.data&&(t+=JSON.stringify(e.data)),t}encodeAsBinary(e){const t=s.deconstructPacket(e),r=this.encodeAsString(t.packet),i=t.buffers;return i.unshift(r),i}}class d extends n.Emitter{constructor(){super()}add(e){let t;if("string"==typeof e)t=this.decodeString(e),t.type===c.BINARY_EVENT||t.type===c.BINARY_ACK?(this.reconstructor=new f(t),0===t.attachments&&super.emitReserved("decoded",t)):super.emitReserved("decoded",t);else{if(!o.isBinary(e)&&!e.base64)throw new Error("Unknown type: "+e);if(!this.reconstructor)throw new Error("got binary data when not reconstructing a packet");t=this.reconstructor.takeBinaryData(e),t&&(this.reconstructor=null,super.emitReserved("decoded",t))}}decodeString(e){let t=0;const r={type:Number(e.charAt(0))};if(void 0===c[r.type])throw new Error("unknown packet type "+r.type);if(r.type===c.BINARY_EVENT||r.type===c.BINARY_ACK){const i=t+1;for(;"-"!==e.charAt(++t)&&t!=e.length;);const n=e.substring(i,t);if(n!=Number(n)||"-"!==e.charAt(t))throw new Error("Illegal attachments");r.attachments=Number(n)}if("/"===e.charAt(t+1)){const i=t+1;for(;++t;){if(","===e.charAt(t))break;if(t===e.length)break}r.nsp=e.substring(i,t)}else r.nsp="/";const i=e.charAt(t+1);if(""!==i&&Number(i)==i){const i=t+1;for(;++t;){const r=e.charAt(t);if(null==r||Number(r)!=r){--t;break}if(t===e.length)break}r.id=Number(e.substring(i,t+1))}if(e.charAt(++t)){const i=function(e){try{return JSON.parse(e)}catch(e){return!1}}(e.substr(t));if(!d.isPayloadValid(r.type,i))throw new Error("invalid payload");r.data=i}return r}static isPayloadValid(e,t){switch(e){case c.CONNECT:return"object"==typeof t;case c.DISCONNECT:return void 0===t;case c.CONNECT_ERROR:return"string"==typeof t||"object"==typeof t;case c.EVENT:case c.BINARY_EVENT:return Array.isArray(t)&&t.length>0;case c.ACK:case c.BINARY_ACK:return Array.isArray(t)}}destroy(){this.reconstructor&&this.reconstructor.finishedReconstruction()}}class f{constructor(e){this.packet=e,this.buffers=[],this.reconPack=e}takeBinaryData(e){if(this.buffers.push(e),this.buffers.length===this.reconPack.attachments){const e=s.reconstructPacket(this.reconPack,this.buffers);return this.finishedReconstruction(),e}return null}finishedReconstruction(){this.reconPack=null,this.buffers=[]}}},{"@socket.io/component-emitter":"kYHC2","./binary.js":"c0isJ","./is-binary.js":"2y0fk","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],c0isJ:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"deconstructPacket",(()=>s)),i.export(r,"reconstructPacket",(()=>a));var n=e("./is-binary.js");function s(e){const t=[],r=e.data,i=e;return i.data=o(r,t),i.attachments=t.length,{packet:i,buffers:t}}function o(e,t){if(!e)return e;if(n.isBinary(e)){const r={_placeholder:!0,num:t.length};return t.push(e),r}if(Array.isArray(e)){const r=new Array(e.length);for(let i=0;ic)),i.export(r,"hasBinary",(()=>u));const n="function"==typeof ArrayBuffer,s=Object.prototype.toString,o="function"==typeof Blob||"undefined"!=typeof Blob&&"[object BlobConstructor]"===s.call(Blob),a="function"==typeof File||"undefined"!=typeof File&&"[object FileConstructor]"===s.call(File);function c(e){return n&&(e instanceof ArrayBuffer||(e=>"function"==typeof ArrayBuffer.isView?ArrayBuffer.isView(e):e.buffer instanceof ArrayBuffer)(e))||o&&e instanceof Blob||a&&e instanceof File}function u(e,t){if(!e||"object"!=typeof e)return!1;if(Array.isArray(e)){for(let t=0,r=e.length;tn))},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],jE9JM:[function(e,t,r){function i(e){e=e||{},this.ms=e.min||100,this.max=e.max||1e4,this.factor=e.factor||2,this.jitter=e.jitter>0&&e.jitter<=1?e.jitter:0,this.attempts=0}t.exports=i,i.prototype.duration=function(){var e=this.ms*Math.pow(this.factor,this.attempts++);if(this.jitter){var t=Math.random(),r=Math.floor(t*this.jitter*e);e=0==(1&Math.floor(10*t))?e-r:e+r}return 0|Math.min(e,this.max)},i.prototype.reset=function(){this.attempts=0},i.prototype.setMin=function(e){this.ms=e},i.prototype.setMax=function(e){this.max=e},i.prototype.setJitter=function(e){this.jitter=e}},{}],heHOu:[function(e,t,r){"use strict";const i=e("abortable-iterator"),n=e("stream-to-it"),{CLOSE_TIMEOUT:s}=e("./constants"),o=e("libp2p-utils/src/ip-port-to-multiaddr"),a=e("debug"),c=a("libp2p:webrtc-star:socket");c.error=a("libp2p:webrtc-star:socket:error");const u=(e,t)=>{if(e&&t)try{return o(e,t)}catch(e){return c.error(e),o("0.0.0.0",t)}};t.exports=(e,t={})=>{const{sink:r,source:o}=n.duplex(e),a=t.remoteAddr||u(e.remoteAddress,e.remotePort),l=u(e.localAddress,e.localPort),d={async sink(e){t.signal&&(e=i(e,t.signal));try{await r(async function*(){for await(const t of e)yield t instanceof Uint8Array?t:t.slice()}())}catch(e){"aborted"!==e.type&&c.error(e)}},source:t.signal?i(o,t.signal):o,conn:e,localAddr:l,remoteAddr:a,timeline:{open:Date.now()},close(){if(!e.destroyed)return new Promise(((t,r)=>{const i=Date.now(),n=setTimeout((()=>{if(d.remoteAddr){const{host:e,port:t}=d.remoteAddr.toOptions();c("timeout closing socket to %s:%s after %dms, destroying it manually",e,t,Date.now()-i)}e.destroyed||e.destroy()}),s);e.once("close",(()=>{t()})),e.end((e=>{if(clearTimeout(n),d.timeline.close=Date.now(),e)return r(e)}))}))}};return e.once("close",(()=>{d.timeline.close||(d.timeline.close=Date.now())})),d}},{"abortable-iterator":"awlU8","stream-to-it":"8tF2x","./constants":"1IQXV","libp2p-utils/src/ip-port-to-multiaddr":"WM46A",debug:"bO5wM"}],"8tF2x":[function(e,t,r){t.exports=e("./source"),t.exports.source=e("./source"),t.exports.sink=e("./sink"),t.exports.transform=e("./transform"),t.exports.duplex=e("./duplex")},{"./source":"7664L","./sink":"5VmJ6","./transform":"9Vbep","./duplex":"dkoqM"}],"5VmJ6":[function(e,t,r){const i=e("get-iterator");t.exports=e=>async t=>{t=i(t);const r=e=>{"function"==typeof e.return&&e.return()};let n=null,s=null;const o=e=>{n=e,s&&s(e),r(t)};let a=null,c=!1;const u=()=>{c=!0,a&&a()};let l=null,d=!1;const f=()=>{d=!0,l&&l()};let h=null;const p=()=>{h&&h()};e.once("error",o),e.once("close",u),e.once("finish",f);try{for await(const r of t){if(!e.writable||e.destroyed||n)break;!1===e.write(r)&&await new Promise(((t,r)=>{a=h=t,s=r,e.once("drain",p)}))}}catch(t){n||e.destroy(),n=t}try{if(e.writable&&e.end(),await(r(t),new Promise(((e,t)=>{if(c||d||n)return e();l=a=e,s=t}))),n)throw n}finally{e.removeListener("error",o),e.removeListener("close",u),e.removeListener("finish",f),e.removeListener("drain",p)}}},{"get-iterator":"li8y1"}],"9Vbep":[function(e,t,r){const i=e("./duplex");t.exports=e=>async function*(t){const r=i(e);let n;if(r.sink(t).catch((e=>{n=e})),yield*r.source,n)throw n}},{"./duplex":"dkoqM"}],dkoqM:[function(e,t,r){const i=e("./sink"),n=e("./source");t.exports=e=>({sink:i(e),source:n(e)})},{"./sink":"5VmJ6","./source":"7664L"}],kfyaq:[function(e,t,r){"use strict";const{Multiaddr:i}=e("multiaddr");t.exports={cleanUrlSIO:function(e){const t=e.toString().split("/"),r=e.protos()[1].name,n=e.protos()[2].name,s=e.stringTuples()[1][1];if("tcp"!==r||"ws"!==n&&"wss"!==n)throw new Error("invalid multiaddr: "+e.toString());return i.isName(e)?"ws"===n?"http://"+t[2]+("80"===s?"":":"+s):"wss"===n?"https://"+t[2]+("443"===s?"":":"+s):void 0:"http://"+t[2]+":"+t[4]},cleanMultiaddr:function(e){const t="/libp2p-webrtc-star";if(-1!==e.indexOf(t)){e=e.substring(t.length,e.length);let r=new i(e);const n=r.stringTuples().filter((e=>421===e[0]))[0];r=r.decapsulate("p2p"),r=r.encapsulate("/p2p-webrtc-star"),r=r.encapsulate(`/p2p/${n[1]}`),e=r.toString()}return e}}},{multiaddr:"8Mu1u"}],"6n2fc":[function(e,t,r){"use strict";t.exports=e("./mplex")},{"./mplex":"bdx0L"}],bdx0L:[function(e,t,r){"use strict";const i=e("it-pipe"),n=e("it-pushable"),s=e("debug")("libp2p:mplex"),o=e("abortable-iterator"),a=e("./coder"),c=e("./restrict-size"),{MessageTypes:u,MessageTypeNames:l}=e("./message-types"),d=e("./stream");class f{constructor(e){e="function"==typeof(e=e||{})?{onStream:e}:e,this._streamId=0,this._streams={initiators:new Map,receivers:new Map},this._options=e,this.sink=this._createSink(),this.source=this._createSource(),this.onStream=e.onStream,this.onStreamEnd=e.onStreamEnd}get streams(){const e=[];return this._streams.initiators.forEach((t=>{e.push(t)})),this._streams.receivers.forEach((t=>{e.push(t)})),e}newStream(e){const t=this._streamId++;e=null==e?t.toString():String(e);const r=this._streams.initiators;return this._newStream({id:t,name:e,type:"initiator",registry:r})}_newReceiverStream({id:e,name:t}){const r=this._streams.receivers;return this._newStream({id:e,name:t,type:"receiver",registry:r})}_newStream({id:e,name:t,type:r,registry:i}){if(i.has(e))throw new Error(`${r} stream ${e} already exists!`);s("new %s stream %s %s",r,e,t);const n=d({id:e,name:t,send:i=>(s.enabled&&s("%s stream %s %s send",r,e,t,{...i,type:l[i.type],data:i.data&&i.data.slice()}),this.source.push(i)),type:r,onEnd:()=>{s("%s stream %s %s ended",r,e,t),i.delete(e),this.onStreamEnd&&this.onStreamEnd(n)},maxMsgSize:this._options.maxMsgSize});return i.set(e,n),n}_createSink(){return async e=>{this._options.signal&&(e=o(e,this._options.signal));try{await i(e,a.decode,c(this._options.maxMsgSize),(async e=>{for await(const t of e)for(const e of t)this._handleIncoming(e)}))}catch(e){return s("error in sink",e),this.source.end(e)}this.source.end()}}_createSource(){const e=n({onEnd:e=>{const{initiators:t,receivers:r}=this._streams;for(const r of t.values())r.abort(e);for(const t of r.values())t.abort(e)},writev:!0});return Object.assign(a.encode(e),{push:e.push,end:e.end,return:e.return})}_handleIncoming({id:e,type:t,data:r}){if(s.enabled&&s("incoming message",{id:e,type:l[t],data:r.slice()}),t===u.NEW_STREAM&&this.onStream){const t=this._newReceiverStream({id:e,name:r.toString()});return this.onStream(t)}const i=(1&t?this._streams.initiators:this._streams.receivers).get(e);if(!i)return s("missing stream %s",e);switch(t){case u.MESSAGE_INITIATOR:case u.MESSAGE_RECEIVER:i.source.push(r);break;case u.CLOSE_INITIATOR:case u.CLOSE_RECEIVER:i.close();break;case u.RESET_INITIATOR:case u.RESET_RECEIVER:i.reset();break;default:s("unknown message type %s",t)}}}f.multicodec="/mplex/6.7.0",t.exports=f},{"it-pipe":"giKBQ","it-pushable":"bnpei",debug:"bO5wM","abortable-iterator":"awlU8","./coder":"7KKkK","./restrict-size":"aHge1","./message-types":"guJdt","./stream":"eKb79"}],"7KKkK":[function(e,t,r){"use strict";r.encode=e("./encode"),r.decode=e("./decode")},{"./encode":"7SPKN","./decode":"5DYd5"}],"7SPKN":[function(e,t,r){"use strict";const i=e("varint"),n=e("bl/BufferList"),s=10240;const o=new class{constructor(){this._pool=new Uint8Array(s),this._poolOffset=0}write(e){const t=this._pool;let r=this._poolOffset;i.encode(e.id<<3|e.type,t,r),r+=i.encode.bytes,i.encode(e.data?e.data.length:0,t,r),r+=i.encode.bytes;const n=t.subarray(this._poolOffset,r);return s-r<100?(this._pool=new Uint8Array(s),this._poolOffset=0):this._poolOffset=r,e.data?[n,e.data]:n}};t.exports=e=>async function*(){for await(const t of e)Array.isArray(t)?yield new n(t.map((e=>o.write(e)))):yield new n(o.write(t))}()},{varint:"aN1CO","bl/BufferList":"im7j6"}],"5DYd5":[function(e,t,r){"use strict";const i=e("varint"),n=e("bl/BufferList");t.exports=e=>async function*(){const t=new s;for await(const r of e){const e=t.write(r);e.length&&(yield e)}}();class s{constructor(){this._buffer=new n,this._bufferProxy=new Proxy({},{get:(e,t)=>"l"===t[0]?this._buffer[t]:this._buffer.get(parseInt(t))}),this._headerInfo=null}write(e){if(!e||!e.length)return[];this._buffer.append(e);const t=[];for(;;){if(!this._headerInfo)try{this._headerInfo=this._decodeHeader(this._bufferProxy)}catch(e){break}const{id:e,type:r,length:i,offset:n}=this._headerInfo;if(this._buffer.length-n>3,type:7&t,offset:r,length:n}}}},{varint:"aN1CO","bl/BufferList":"im7j6"}],aHge1:[function(e,t,r){"use strict";const i=1048576;t.exports=e=>{e=e||i;const t=t=>{if(t.data&&t.data.length>e)throw Object.assign(new Error("message size too large!"),{code:"ERR_MSG_TOO_BIG"})};return e=>async function*(){for await(const r of e)Array.isArray(r)?r.forEach(t):t(r),yield r}()},t.exports.MAX_MSG_SIZE=i},{}],guJdt:[function(e,t,r){"use strict";const i=Object.freeze({NEW_STREAM:0,MESSAGE_RECEIVER:1,MESSAGE_INITIATOR:2,CLOSE_RECEIVER:3,CLOSE_INITIATOR:4,RESET_RECEIVER:5,RESET_INITIATOR:6});r.MessageTypes=i,r.InitiatorMessageTypes=Object.freeze({NEW_STREAM:i.NEW_STREAM,MESSAGE:i.MESSAGE_INITIATOR,CLOSE:i.CLOSE_INITIATOR,RESET:i.RESET_INITIATOR}),r.ReceiverMessageTypes=Object.freeze({MESSAGE:i.MESSAGE_RECEIVER,CLOSE:i.CLOSE_RECEIVER,RESET:i.RESET_RECEIVER}),r.MessageTypeNames=Object.freeze(Object.entries(i).reduce(((e,t)=>(e[t[1]]=t[0],e)),{}))},{}],eKb79:[function(e,t,r){"use strict";const i=e("abortable-iterator"),n=e("abort-controller"),s=e("debug")("libp2p:mplex:stream"),o=e("it-pushable"),a=e("bl/BufferList"),c=e("err-code"),{MAX_MSG_SIZE:u}=e("./restrict-size"),{InitiatorMessageTypes:l,ReceiverMessageTypes:d}=e("./message-types"),f="ERR_MPLEX_STREAM_RESET";t.exports=({id:e,name:t,send:r,onEnd:h=(()=>{}),type:p="initiator",maxMsgSize:g=u})=>{const y=new n,m=new n,b="initiator"===p?l:d,v="initiator"===p?`i${e}`:`r${e}`;t=String(null==t?e:t);let w,_=!1,E=!1;const S=e=>{E||(E=!0,s("%s stream %s sink end",p,t,e),e&&!w&&(w=e),_&&(T.timeline.close=Date.now(),h(w)))},T={close:()=>T.source.end(),abort:e=>{s("%s stream %s abort",p,t,e),T.source.end(e),y.abort(),S(e)},reset:()=>{const e=c(new Error("stream reset"),f);m.abort(),T.source.end(e),S(e)},sink:async n=>{n=i(n,[{signal:y.signal,options:{abortMessage:"stream aborted",abortCode:"ERR_MPLEX_STREAM_ABORT"}},{signal:m.signal,options:{abortMessage:"stream reset",abortCode:f}}]),"initiator"===p&&r({id:e,type:b.NEW_STREAM,data:t});try{for await(let t of n)for(;t.length;){if(t.length<=g){r({id:e,type:b.MESSAGE,data:t});break}t=a.isBufferList(t)?t:new a(t),r({id:e,type:b.MESSAGE,data:t.shallowSlice(0,g)}),t.consume(g)}}catch(i){return i.code===f?s("%s stream %s reset",p,t):(s("%s stream %s error",p,t,i),r({id:e,type:b.RESET})),T.source.end(i),S(i)}r({id:e,type:b.CLOSE}),S()},source:o((e=>{_||(_=!0,s("%s stream %s source end",p,t,e),e&&!w&&(w=e),E&&(T.timeline.close=Date.now(),h(w)))})),timeline:{open:Date.now(),close:null},id:v};return T}},{"abortable-iterator":"awlU8","abort-controller":"lNJ7z",debug:"bO5wM","it-pushable":"bnpei","bl/BufferList":"im7j6","err-code":"chZjB","./restrict-size":"aHge1","./message-types":"guJdt"}],"5JB8e":[function(e,t,r){"use strict";var i=this&&this.__createBinding||(Object.create?function(e,t,r,i){void 0===i&&(i=r),Object.defineProperty(e,i,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,i){void 0===i&&(i=r),e[i]=t[r]}),n=this&&this.__exportStar||function(e,t){for(var r in e)"default"===r||Object.prototype.hasOwnProperty.call(t,r)||i(t,e,r)};Object.defineProperty(r,"__esModule",{value:!0}),r.NOISE=void 0;const s=e("./noise");n(e("./noise"),r),r.NOISE=new s.Noise},{"./noise":"j7J44"}],j7J44:[function(e,t,r){"use strict";var i=this&&this.__createBinding||(Object.create?function(e,t,r,i){void 0===i&&(i=r),Object.defineProperty(e,i,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,i){void 0===i&&(i=r),e[i]=t[r]}),n=this&&this.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),s=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var r in e)"default"!==r&&Object.prototype.hasOwnProperty.call(e,r)&&i(t,e,r);return n(t,e),t},o=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(r,"__esModule",{value:!0}),r.Noise=void 0;const a=s(e("@stablelib/x25519")),c=e("buffer"),u=o(e("it-pb-rpc")),l=o(e("it-pair/duplex")),d=o(e("it-buffer")),f=o(e("it-pipe")),h=e("it-length-prefixed"),p=e("./handshake-xx"),g=e("./handshake-ik"),y=e("./handshake-xx-fallback"),m=e("./utils"),b=e("./encoder"),v=e("./crypto"),w=e("./keycache"),_=e("./logger"),E=e("./constants");r.Noise=class{constructor(e,t){if(this.protocol="/noise",this.prologue=c.Buffer.alloc(0),this.earlyData=null!=t?t:c.Buffer.alloc(0),this.useNoisePipes=!1,e){const t=a.generateKeyPairFromSeed(e);this.staticKeys={privateKey:c.Buffer.from(t.secretKey.buffer,t.secretKey.byteOffset,t.secretKey.length),publicKey:c.Buffer.from(t.publicKey.buffer,t.publicKey.byteOffset,t.publicKey.length)}}else this.staticKeys=m.generateKeypair()}async secureOutbound(e,t,r){const i=u.default(t,{lengthEncoder:b.uint16BEEncode,lengthDecoder:b.uint16BEDecode,maxDataLength:E.NOISE_MSG_MAX_LENGTH_BYTES}),n=await this.performHandshake({connection:i,isInitiator:!0,localPeer:e,remotePeer:r});return{conn:await this.createSecureConnection(i,n),remoteEarlyData:n.remoteEarlyData,remotePeer:n.remotePeer}}async secureInbound(e,t,r){const i=u.default(t,{lengthEncoder:b.uint16BEEncode,lengthDecoder:b.uint16BEDecode,maxDataLength:E.NOISE_MSG_MAX_LENGTH_BYTES}),n=await this.performHandshake({connection:i,isInitiator:!1,localPeer:e,remotePeer:r});return{conn:await this.createSecureConnection(i,n),remoteEarlyData:n.remoteEarlyData,remotePeer:n.remotePeer}}async performHandshake(e){var t;const r=await m.getPayload(e.localPeer,this.staticKeys.publicKey,this.earlyData);let i=this.useNoisePipes;if(e.isInitiator&&null===w.KeyCache.load(e.remotePeer)&&(i=!1),!i)return await this.performXXHandshake(e,r);{const{remotePeer:i,connection:n,isInitiator:s}=e,o=new g.IKHandshake(s,r,this.prologue,this.staticKeys,n,null!==(t=w.KeyCache.load(e.remotePeer))&&void 0!==t?t:c.Buffer.alloc(32),i);try{return await this.performIKHandshake(o)}catch(t){let i;return e.isInitiator&&(i=o.getLocalEphemeralKeys()),await this.performXXFallbackHandshake(e,r,t.initialMsg,i)}}}async performXXFallbackHandshake(e,t,r,i){const{isInitiator:n,remotePeer:s,connection:o}=e,a=new y.XXFallbackHandshake(n,t,this.prologue,this.staticKeys,o,r,s,i);try{await a.propose(),await a.exchange(),await a.finish()}catch(e){_.logger(e);throw new Error(`Error occurred during XX Fallback handshake: ${e.message}`)}return a}async performXXHandshake(e,t){const{isInitiator:r,remotePeer:i,connection:n}=e,s=new p.XXHandshake(r,t,this.prologue,this.staticKeys,n,i);try{await s.propose(),await s.exchange(),await s.finish(),this.useNoisePipes&&s.remotePeer&&w.KeyCache.store(s.remotePeer,s.getRemoteStaticKey())}catch(e){throw new Error(`Error occurred during XX handshake: ${e.message}`)}return s}async performIKHandshake(e){return await e.stage0(),await e.stage1(),e}async createSecureConnection(e,t){const[r,i]=l.default(),n=e.unwrap();return await f.default(r,d.default,v.encryptStream(t),h.encode({lengthEncoder:b.uint16BEEncode}),n,h.decode({lengthDecoder:b.uint16BEDecode}),d.default,v.decryptStream(t),r),i}}},{"@stablelib/x25519":"5PJXv",buffer:"etowf","it-pb-rpc":"1VNxb","it-pair/duplex":"i2hGG","it-buffer":"jQv22","it-pipe":"giKBQ","it-length-prefixed":"3yxIE","./handshake-xx":"aO5Kw","./handshake-ik":"6aLUa","./handshake-xx-fallback":"3Y81f","./utils":"hkQyI","./encoder":"fJwxo","./crypto":"fylsy","./keycache":"8Z0xy","./logger":"iHFBc","./constants":"dt6rC"}],"5PJXv":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("@stablelib/random"),n=e("@stablelib/wipe");function s(e){var t=new Float64Array(16);if(e)for(var r=0;r=0;--b){var v=r[b>>>3]>>>(7&b)&1;u(n,o,v),u(p,g,v),l(y,n,p),d(n,n,p),l(p,o,g),d(o,o,g),h(g,y),h(m,n),f(n,p,n),f(p,o,y),l(y,n,p),d(n,n,p),h(o,n),d(p,g,m),f(n,p,a),l(n,n,g),f(p,p,n),f(n,g,m),f(g,o,i),h(o,y),u(n,o,v),u(p,g,v)}for(b=0;b<16;b++)i[b+16]=n[b],i[b+32]=p[b],i[b+48]=o[b],i[b+64]=g[b];var w=i.subarray(32),_=i.subarray(16);!function(e,t){for(var r=s(),i=0;i<16;i++)r[i]=t[i];for(i=253;i>=0;i--)h(r,r),2!==i&&4!==i&&f(r,r,t);for(i=0;i<16;i++)e[i]=r[i]}(w,w),f(_,_,w);var E=new Uint8Array(32);return function(e,t){for(var r=s(),i=s(),n=0;n<16;n++)i[n]=t[n];c(i),c(i),c(i);for(var o=0;o<2;o++){for(r[0]=i[0]-65517,n=1;n<15;n++)r[n]=i[n]-65535-(r[n-1]>>16&1),r[n-1]&=65535;r[15]=i[15]-32767-(r[14]>>16&1);var a=r[15]>>16&1;r[14]&=65535,u(i,r,1-a)}for(n=0;n<16;n++)e[2*n]=255&i[n],e[2*n+1]=i[n]>>8}(E,_),E}function g(e){return p(e,o)}function y(e){if(e.length!==r.SECRET_KEY_LENGTH)throw new Error("x25519: seed must be "+r.SECRET_KEY_LENGTH+" bytes");var t=new Uint8Array(e);return{publicKey:g(t),secretKey:t}}r.scalarMult=p,r.scalarMultBase=g,r.generateKeyPairFromSeed=y,r.generateKeyPair=function(e){var t=i.randomBytes(32,e),r=y(t);return n.wipe(t),r},r.sharedKey=function(e,t,i){if(void 0===i&&(i=!1),e.length!==r.PUBLIC_KEY_LENGTH)throw new Error("X25519: incorrect secret key length");if(t.length!==r.PUBLIC_KEY_LENGTH)throw new Error("X25519: incorrect public key length");var n=p(e,t);if(i){for(var s=0,o=0;o256)throw new Error("randomString charset is too long");for(var n="",c=t.length,u=256-256%c;e>0;){for(var l=o(Math.ceil(256*e/u),i),d=0;d0;d++){var f=l[d];f>>8,t[r+1]=e>>>0,t}function s(e,t,r){return void 0===t&&(t=new Uint8Array(2)),void 0===r&&(r=0),t[r+0]=e>>>0,t[r+1]=e>>>8,t}function o(e,t){return void 0===t&&(t=0),e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3]}function a(e,t){return void 0===t&&(t=0),(e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3])>>>0}function c(e,t){return void 0===t&&(t=0),e[t+3]<<24|e[t+2]<<16|e[t+1]<<8|e[t]}function u(e,t){return void 0===t&&(t=0),(e[t+3]<<24|e[t+2]<<16|e[t+1]<<8|e[t])>>>0}function l(e,t,r){return void 0===t&&(t=new Uint8Array(4)),void 0===r&&(r=0),t[r+0]=e>>>24,t[r+1]=e>>>16,t[r+2]=e>>>8,t[r+3]=e>>>0,t}function d(e,t,r){return void 0===t&&(t=new Uint8Array(4)),void 0===r&&(r=0),t[r+0]=e>>>0,t[r+1]=e>>>8,t[r+2]=e>>>16,t[r+3]=e>>>24,t}function f(e,t,r){return void 0===t&&(t=new Uint8Array(8)),void 0===r&&(r=0),l(e/4294967296>>>0,t,r),l(e>>>0,t,r+4),t}function h(e,t,r){return void 0===t&&(t=new Uint8Array(8)),void 0===r&&(r=0),d(e>>>0,t,r),d(e/4294967296>>>0,t,r+4),t}r.readInt16BE=function(e,t){return void 0===t&&(t=0),(e[t+0]<<8|e[t+1])<<16>>16},r.readUint16BE=function(e,t){return void 0===t&&(t=0),(e[t+0]<<8|e[t+1])>>>0},r.readInt16LE=function(e,t){return void 0===t&&(t=0),(e[t+1]<<8|e[t])<<16>>16},r.readUint16LE=function(e,t){return void 0===t&&(t=0),(e[t+1]<<8|e[t])>>>0},r.writeUint16BE=n,r.writeInt16BE=n,r.writeUint16LE=s,r.writeInt16LE=s,r.readInt32BE=o,r.readUint32BE=a,r.readInt32LE=c,r.readUint32LE=u,r.writeUint32BE=l,r.writeInt32BE=l,r.writeUint32LE=d,r.writeInt32LE=d,r.readInt64BE=function(e,t){void 0===t&&(t=0);var r=o(e,t),i=o(e,t+4);return 4294967296*r+i-4294967296*(i>>31)},r.readUint64BE=function(e,t){return void 0===t&&(t=0),4294967296*a(e,t)+a(e,t+4)},r.readInt64LE=function(e,t){void 0===t&&(t=0);var r=c(e,t);return 4294967296*c(e,t+4)+r-4294967296*(r>>31)},r.readUint64LE=function(e,t){void 0===t&&(t=0);var r=u(e,t);return 4294967296*u(e,t+4)+r},r.writeUint64BE=f,r.writeInt64BE=f,r.writeUint64LE=h,r.writeInt64LE=h,r.readUintBE=function(e,t,r){if(void 0===r&&(r=0),e%8!=0)throw new Error("readUintBE supports only bitLengths divisible by 8");if(e/8>t.length-r)throw new Error("readUintBE: array is too short for the given bitLength");for(var i=0,n=1,s=e/8+r-1;s>=r;s--)i+=t[s]*n,n*=256;return i},r.readUintLE=function(e,t,r){if(void 0===r&&(r=0),e%8!=0)throw new Error("readUintLE supports only bitLengths divisible by 8");if(e/8>t.length-r)throw new Error("readUintLE: array is too short for the given bitLength");for(var i=0,n=1,s=r;s=n;o--)r[o]=t/s&255,s*=256;return r},r.writeUintLE=function(e,t,r,n){if(void 0===r&&(r=new Uint8Array(e/8)),void 0===n&&(n=0),e%8!=0)throw new Error("writeUintLE supports only bitLengths divisible by 8");if(!i.isSafeInteger(t))throw new Error("writeUintLE value must be an integer");for(var s=1,o=n;o>>16&65535)*i+r*(t>>>16&65535)<<16>>>0)|0},r.add=function(e,t){return e+t|0},r.sub=function(e,t){return e-t|0},r.rotl=function(e,t){return e<>>32-t},r.rotr=function(e,t){return e<<32-t|e>>>t},r.isInteger=Number.isInteger||function(e){return"number"==typeof e&&isFinite(e)&&Math.floor(e)===e},r.MAX_SAFE_INTEGER=9007199254740991,r.isSafeInteger=function(e){return r.isInteger(e)&&e>=-r.MAX_SAFE_INTEGER&&e<=r.MAX_SAFE_INTEGER}},{}],"1VNxb":[function(e,t,r){"use strict";const i=e("is-buffer"),n=e("it-handshake"),s=e("it-length-prefixed");t.exports=(e,t={})=>{const r=n(e),o=s.decode.fromReader(r.reader,t);let a=!1;const c={read:async e=>{const{value:t,done:i}=await r.reader.next(e);if(i&&t.length{const{value:e,done:t}=await o.next();if(a=t,!e)throw new Error("Value is null");return e},readPB:async e=>{const t=await c.readLP();if(!t)throw new Error("Value is null");const r=i(t)?t:t.slice();return e.decode(r)},write:e=>{r.writer.push(e)},writeLP:e=>{c.write(s.encode.single(e,t))},writePB:(e,t)=>{c.writeLP(t.encode(e))},pb:e=>({read:()=>c.readPB(e),write:t=>c.writePB(t,e)}),unwrap:()=>(r.rest(),r.stream)};return c}},{"is-buffer":"5yoKf","it-handshake":"5ZBDe","it-length-prefixed":"3yxIE"}],"5ZBDe":[function(e,t,r){"use strict";const i=e("it-reader"),n=e("it-pushable"),s=e("p-defer");t.exports=e=>{const t=n(),r=i(e.source),o=s();let a;const c=e.sink(async function*(){yield*t;const e=await o.promise;yield*e}());c.catch((e=>{a=e}));return{reader:r,writer:t,stream:{sink:e=>a?Promise.reject(a):(o.resolve(e),c),source:r},rest:()=>t.end(),write:t.push,read:async()=>(await r.next()).value}}},{"it-reader":"btxDo","it-pushable":"bnpei","p-defer":"5rKSv"}],i2hGG:[function(e,t,r){var i=e("./");t.exports=function(){var e=i(),t=i();return[{source:e.source,sink:t.sink},{source:t.source,sink:e.sink}]}},{"./":"hvKe2"}],hvKe2:[function(e,t,r){"use strict";const i=e("get-iterator");t.exports=function(){let e,t;return{sink:async r=>{if(e)throw new Error("already piped");e=i(r),t&&t(e)},source:{[Symbol.asyncIterator](){return this},next:()=>e?e.next():new Promise((e=>{t=r=>{t=null,e(r.next())}}))}}}},{"get-iterator":"li8y1"}],jQv22:[function(e,t,r){"use strict";const{Buffer:i}=e("buffer"),n=e("bl/BufferList");t.exports=async function*(e){for await(const t of e)i.isBuffer(t)?yield t:n.isBufferList(t)?yield t.slice():yield i.from(t)},t.exports.toBuffer=t.exports,t.exports.toList=async function*(e){for await(const t of e)i.isBuffer(t)?yield(new n).append(t):n.isBufferList(t)?yield t:yield(new n).append(i.from(t))}},{buffer:"etowf","bl/BufferList":"im7j6"}],aO5Kw:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.XXHandshake=void 0;const i=e("buffer"),n=e("./handshakes/xx"),s=e("./utils"),o=e("./logger"),a=e("./encoder");r.XXHandshake=class{constructor(e,t,r,s,o,a,c){this.isInitiator=e,this.payload=t,this.prologue=r,this.staticKeypair=s,this.connection=o,a&&(this.remotePeer=a),this.xx=null!=c?c:new n.XX,this.session=this.xx.initSession(this.isInitiator,this.prologue,this.staticKeypair),this.remoteEarlyData=i.Buffer.alloc(0)}async propose(){if(o.logLocalStaticKeys(this.session.hs.s),this.isInitiator){o.logger("Stage 0 - Initiator starting to send first message.");const e=this.xx.sendMessage(this.session,i.Buffer.alloc(0));this.connection.writeLP(a.encode0(e)),o.logger("Stage 0 - Initiator finished sending first message."),o.logLocalEphemeralKeys(this.session.hs.e)}else{o.logger("Stage 0 - Responder waiting to receive first message...");const e=a.decode0((await this.connection.readLP()).slice()),{valid:t}=this.xx.recvMessage(this.session,e);if(!t)throw new Error("xx handshake stage 0 validation fail");o.logger("Stage 0 - Responder received first message."),o.logRemoteEphemeralKey(this.session.hs.re)}}async exchange(){if(this.isInitiator){o.logger("Stage 1 - Initiator waiting to receive first message from responder...");const e=a.decode1((await this.connection.readLP()).slice()),{plaintext:t,valid:r}=this.xx.recvMessage(this.session,e);if(!r)throw new Error("xx handshake stage 1 validation fail");o.logger("Stage 1 - Initiator received the message."),o.logRemoteEphemeralKey(this.session.hs.re),o.logRemoteStaticKey(this.session.hs.rs),o.logger("Initiator going to check remote's signature...");try{const r=await s.decodePayload(t);this.remotePeer=this.remotePeer||await s.getPeerIdFromPayload(r),this.remotePeer=await s.verifySignedPayload(e.ns,r,this.remotePeer),this.setRemoteEarlyData(r.data)}catch(e){throw new Error(`Error occurred while verifying signed payload: ${e.message}`)}o.logger("All good with the signature!")}else{o.logger("Stage 1 - Responder sending out first message with signed payload and static key.");const e=this.xx.sendMessage(this.session,this.payload);this.connection.writeLP(a.encode1(e)),o.logger("Stage 1 - Responder sent the second handshake message with signed payload."),o.logLocalEphemeralKeys(this.session.hs.e)}}async finish(){if(this.isInitiator){o.logger("Stage 2 - Initiator sending third handshake message.");const e=this.xx.sendMessage(this.session,this.payload);this.connection.writeLP(a.encode2(e)),o.logger("Stage 2 - Initiator sent message with signed payload.")}else{o.logger("Stage 2 - Responder waiting for third handshake message...");const e=a.decode2((await this.connection.readLP()).slice()),{plaintext:t,valid:r}=this.xx.recvMessage(this.session,e);if(!r)throw new Error("xx handshake stage 2 validation fail");o.logger("Stage 2 - Responder received the message, finished handshake.");try{const e=await s.decodePayload(t);this.remotePeer=this.remotePeer||await s.getPeerIdFromPayload(e),await s.verifySignedPayload(this.session.hs.rs,e,this.remotePeer),this.setRemoteEarlyData(e.data)}catch(e){throw new Error(`Error occurred while verifying signed payload: ${e.message}`)}}o.logCipherState(this.session)}encrypt(e,t){const r=this.getCS(t);return this.xx.encryptWithAd(r,i.Buffer.alloc(0),e)}decrypt(e,t){const r=this.getCS(t,!1);return this.xx.decryptWithAd(r,i.Buffer.alloc(0),e)}getRemoteStaticKey(){return this.session.hs.rs}getCS(e,t=!0){if(!e.cs1||!e.cs2)throw new Error("Handshake not completed properly, cipher state does not exist.");return this.isInitiator?t?e.cs1:e.cs2:t?e.cs2:e.cs1}setRemoteEarlyData(e){e&&(this.remoteEarlyData=i.Buffer.from(e.buffer,e.byteOffset,e.length))}}},{buffer:"etowf","./handshakes/xx":"9a2BV","./utils":"hkQyI","./logger":"iHFBc","./encoder":"fJwxo"}],"9a2BV":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.XX=void 0;const i=e("buffer"),n=e("../utils"),s=e("./abstract-handshake");class o extends s.AbstractHandshake{initializeInitiator(e,t,r,n){const s=this.initializeSymmetric("Noise_XX_25519_ChaChaPoly_SHA256");this.mixHash(s,e);return{ss:s,s:t,rs:r,psk:n,re:i.Buffer.alloc(32)}}initializeResponder(e,t,r,n){const s=this.initializeSymmetric("Noise_XX_25519_ChaChaPoly_SHA256");this.mixHash(s,e);return{ss:s,s:t,rs:r,psk:n,re:i.Buffer.alloc(32)}}writeMessageA(e,t,r){const s=i.Buffer.alloc(0);e.e=void 0!==r?r:n.generateKeypair();const o=e.e.publicKey;this.mixHash(e.ss,o);return{ne:o,ns:s,ciphertext:this.encryptAndHash(e.ss,t)}}writeMessageB(e,t){e.e=n.generateKeypair();const r=e.e.publicKey;this.mixHash(e.ss,r),this.mixKey(e.ss,this.dh(e.e.privateKey,e.re));const s=i.Buffer.from(e.s.publicKey),o=this.encryptAndHash(e.ss,s);this.mixKey(e.ss,this.dh(e.s.privateKey,e.re));return{ne:r,ns:o,ciphertext:this.encryptAndHash(e.ss,t)}}writeMessageC(e,t){const r=i.Buffer.from(e.s.publicKey),n=this.encryptAndHash(e.ss,r);this.mixKey(e.ss,this.dh(e.s.privateKey,e.re));const s=this.encryptAndHash(e.ss,t),o={ne:this.createEmptyKey(),ns:n,ciphertext:s},{cs1:a,cs2:c}=this.split(e.ss);return{h:e.ss.h,messageBuffer:o,cs1:a,cs2:c}}readMessageA(e,t){return n.isValidPublicKey(t.ne)&&(e.re=t.ne),this.mixHash(e.ss,e.re),this.decryptAndHash(e.ss,t.ciphertext)}readMessageB(e,t){if(n.isValidPublicKey(t.ne)&&(e.re=t.ne),this.mixHash(e.ss,e.re),!e.e)throw new Error("Handshake state `e` param is missing.");this.mixKey(e.ss,this.dh(e.e.privateKey,e.re));const{plaintext:r,valid:i}=this.decryptAndHash(e.ss,t.ns);i&&32===r.length&&n.isValidPublicKey(r)&&(e.rs=r),this.mixKey(e.ss,this.dh(e.e.privateKey,e.rs));const{plaintext:s,valid:o}=this.decryptAndHash(e.ss,t.ciphertext);return{plaintext:s,valid:i&&o}}readMessageC(e,t){const{plaintext:r,valid:i}=this.decryptAndHash(e.ss,t.ns);if(i&&32===r.length&&n.isValidPublicKey(r)&&(e.rs=r),!e.e)throw new Error("Handshake state `e` param is missing.");this.mixKey(e.ss,this.dh(e.e.privateKey,e.rs));const{plaintext:s,valid:o}=this.decryptAndHash(e.ss,t.ciphertext),{cs1:a,cs2:c}=this.split(e.ss);return{h:e.ss.h,plaintext:s,valid:i&&o,cs1:a,cs2:c}}initSession(e,t,r){const n=this.createEmptyKey(),s=i.Buffer.alloc(32);let o;return o=e?this.initializeInitiator(t,r,s,n):this.initializeResponder(t,r,s,n),{hs:o,i:e,mc:0}}sendMessage(e,t,r){let i;if(0===e.mc)i=this.writeMessageA(e.hs,t,r);else if(1===e.mc)i=this.writeMessageB(e.hs,t);else if(2===e.mc){const{h:r,messageBuffer:n,cs1:s,cs2:o}=this.writeMessageC(e.hs,t);i=n,e.h=r,e.cs1=s,e.cs2=o}else{if(!(e.mc>2))throw new Error("Session invalid.");if(e.i){if(!e.cs1)throw new Error("CS1 (cipher state) is not defined");i=this.writeMessageRegular(e.cs1,t)}else{if(!e.cs2)throw new Error("CS2 (cipher state) is not defined");i=this.writeMessageRegular(e.cs2,t)}}return e.mc++,i}recvMessage(e,t){let r=i.Buffer.alloc(0),n=!1;if(0===e.mc)({plaintext:r,valid:n}=this.readMessageA(e.hs,t));else if(1===e.mc)({plaintext:r,valid:n}=this.readMessageB(e.hs,t));else if(2===e.mc){const{h:i,plaintext:s,valid:o,cs1:a,cs2:c}=this.readMessageC(e.hs,t);r=s,n=o,e.h=i,e.cs1=a,e.cs2=c}return e.mc++,{plaintext:r,valid:n}}}r.XX=o},{buffer:"etowf","../utils":"hkQyI","./abstract-handshake":"8oSG2"}],hkQyI:[function(e,t,r){"use strict";var i=this&&this.__createBinding||(Object.create?function(e,t,r,i){void 0===i&&(i=r),Object.defineProperty(e,i,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,i){void 0===i&&(i=r),e[i]=t[r]}),n=this&&this.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),s=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var r in e)"default"!==r&&Object.prototype.hasOwnProperty.call(e,r)&&i(t,e,r);return n(t,e),t},o=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(r,"__esModule",{value:!0}),r.isValidPublicKey=r.getHkdf=r.verifySignedPayload=r.getHandshakePayload=r.decodePayload=r.getPeerIdFromPayload=r.signPayload=r.createHandshakePayload=r.getPayload=r.generateKeypair=void 0;const a=e("@stablelib/hkdf"),c=e("@stablelib/sha256"),u=s(e("@stablelib/x25519")),l=e("buffer"),d=o(e("peer-id")),f=e("libp2p-crypto"),h=e("./proto/payload"),p=e("uint8arrays/equals"),g=h.pb.NoiseHandshakePayload;function y(e,t,r){const i=g.create({identityKey:l.Buffer.from(e),identitySig:t,data:null!=r?r:null});return l.Buffer.from(g.encode(i).finish())}async function m(e,t){return l.Buffer.from(await e.privKey.sign(t))}function b(e){return l.Buffer.concat([l.Buffer.from("noise-libp2p-static-key:"),e])}r.generateKeypair=function(){const e=u.generateKeyPair();return{publicKey:l.Buffer.from(e.publicKey.buffer,e.publicKey.byteOffset,e.publicKey.length),privateKey:l.Buffer.from(e.secretKey.buffer,e.secretKey.byteOffset,e.secretKey.length)}},r.getPayload=async function(e,t,r){const i=await m(e,b(t)),n=null!=r?r:l.Buffer.alloc(0);return y(e.marshalPubKey(),i,n)},r.createHandshakePayload=y,r.signPayload=m,r.getPeerIdFromPayload=async function(e){return await d.default.createFromPubKey(l.Buffer.from(e.identityKey))},r.decodePayload=function(e){return g.toObject(g.decode(l.Buffer.from(e)))},r.getHandshakePayload=b,r.verifySignedPayload=async function(e,t,r){const i=l.Buffer.from(t.identityKey);if(!await async function(e,t){const r=await d.default.createFromPubKey(t);return p.equals(r.id,e)}(r.id,i))throw new Error("Peer ID doesn't match libp2p public key.");const n=b(e),s=f.keys.unmarshalPublicKey(i);if(!t.identitySig||!s.verify(n,l.Buffer.from(t.identitySig)))throw new Error("Static key doesn't match to peer that signed payload!");return await d.default.createFromPubKey(i)},r.getHkdf=function(e,t){const r=new a.HKDF(c.SHA256,t,e).expand(96),i=l.Buffer.from(r.buffer,r.byteOffset,r.length);return[i.slice(0,32),i.slice(32,64),i.slice(64,96)]},r.isValidPublicKey=function(e){return!!l.Buffer.isBuffer(e)&&32===e.length}},{"@stablelib/hkdf":"2qV77","@stablelib/sha256":"9CBdD","@stablelib/x25519":"5PJXv",buffer:"etowf","peer-id":"8Bdb3","libp2p-crypto":"bb1cb","./proto/payload":"cBkC4","uint8arrays/equals":"eY3cX"}],"2qV77":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("@stablelib/hmac"),n=e("@stablelib/wipe"),s=function(){function e(e,t,r,n){void 0===r&&(r=new Uint8Array(0)),this._counter=new Uint8Array(1),this._hash=e,this._info=n;var s=i.hmac(this._hash,r,t);this._hmac=new i.HMAC(e,s),this._buffer=new Uint8Array(this._hmac.digestLength),this._bufpos=this._buffer.length}return e.prototype._fillBuffer=function(){this._counter[0]++;var e=this._counter[0];if(0===e)throw new Error("hkdf: cannot expand more");this._hmac.reset(),e>1&&this._hmac.update(this._buffer),this._info&&this._hmac.update(this._info),this._hmac.update(this._counter),this._hmac.finish(this._buffer),this._bufpos=0},e.prototype.expand=function(e){for(var t=new Uint8Array(e),r=0;rthis.blockSize?this._inner.update(t).finish(r).clean():r.set(t);for(var n=0;n>>8}Object.defineProperty(r,"__esModule",{value:!0}),r.select=function(e,t,r){return~(e-1)&t|e-1&r},r.lessOrEqual=function(e,t){return(0|e)-(0|t)-1>>>31&1},r.compare=i,r.equal=function(e,t){return 0!==e.length&&0!==t.length&&0!==i(e,t)}},{}],"9CBdD":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("@stablelib/binary"),n=e("@stablelib/wipe");r.DIGEST_LENGTH=32,r.BLOCK_SIZE=64;var s=function(){function e(){this.digestLength=r.DIGEST_LENGTH,this.blockSize=r.BLOCK_SIZE,this._state=new Int32Array(8),this._temp=new Int32Array(64),this._buffer=new Uint8Array(128),this._bufferLength=0,this._bytesHashed=0,this._finished=!1,this.reset()}return e.prototype._initState=function(){this._state[0]=1779033703,this._state[1]=3144134277,this._state[2]=1013904242,this._state[3]=2773480762,this._state[4]=1359893119,this._state[5]=2600822924,this._state[6]=528734635,this._state[7]=1541459225},e.prototype.reset=function(){return this._initState(),this._bufferLength=0,this._bytesHashed=0,this._finished=!1,this},e.prototype.clean=function(){n.wipe(this._buffer),n.wipe(this._temp),this.reset()},e.prototype.update=function(e,t){if(void 0===t&&(t=e.length),this._finished)throw new Error("SHA256: can't update because hash was finished.");var r=0;if(this._bytesHashed+=t,this._bufferLength>0){for(;this._bufferLength0;)this._buffer[this._bufferLength++]=e[r++],t--;this._bufferLength===this.blockSize&&(a(this._temp,this._state,this._buffer,0,this.blockSize),this._bufferLength=0)}for(t>=this.blockSize&&(r=a(this._temp,this._state,e,r,t),t%=this.blockSize);t>0;)this._buffer[this._bufferLength++]=e[r++],t--;return this},e.prototype.finish=function(e){if(!this._finished){var t=this._bytesHashed,r=this._bufferLength,n=t/536870912|0,s=t<<3,o=t%64<56?64:128;this._buffer[r]=128;for(var c=r+1;c0?new Uint8Array(this._buffer):void 0,bufferLength:this._bufferLength,bytesHashed:this._bytesHashed}},e.prototype.restoreState=function(e){return this._state.set(e.state),this._bufferLength=e.bufferLength,e.buffer&&this._buffer.set(e.buffer),this._bytesHashed=e.bytesHashed,this._finished=!1,this},e.prototype.cleanSavedState=function(e){n.wipe(e.state),e.buffer&&n.wipe(e.buffer),e.bufferLength=0,e.bytesHashed=0},e}();r.SHA256=s;var o=new Int32Array([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]);function a(e,t,r,n,s){for(;s>=64;){for(var a=t[0],c=t[1],u=t[2],l=t[3],d=t[4],f=t[5],h=t[6],p=t[7],g=0;g<16;g++){var y=n+4*g;e[g]=i.readUint32BE(r,y)}for(g=16;g<64;g++){var m=e[g-2],b=(m>>>17|m<<15)^(m>>>19|m<<13)^m>>>10,v=((m=e[g-15])>>>7|m<<25)^(m>>>18|m<<14)^m>>>3;e[g]=(b+e[g-7]|0)+(v+e[g-16]|0)}for(g=0;g<64;g++){b=(((d>>>6|d<<26)^(d>>>11|d<<21)^(d>>>25|d<<7))+(d&f^~d&h)|0)+(p+(o[g]+e[g]|0)|0)|0,v=((a>>>2|a<<30)^(a>>>13|a<<19)^(a>>>22|a<<10))+(a&c^a&u^c&u)|0;p=h,h=f,f=d,d=l+b|0,l=u,u=c,c=a,a=b+v|0}t[0]+=a,t[1]+=c,t[2]+=u,t[3]+=l,t[4]+=d,t[5]+=f,t[6]+=h,t[7]+=p,n+=64,s-=64}return n}r.hash=function(e){var t=new s;t.update(e);var r=t.digest();return t.clean(),r}},{"@stablelib/binary":"h0oFL","@stablelib/wipe":"4bsjy"}],cBkC4:[function(e,t,r){"use strict";var i;i=function(e){var t,r=e.Reader,i=e.Writer,n=e.util,s=e.roots["libp2p-noise"]||(e.roots["libp2p-noise"]={});return s.pb=((t={}).NoiseHandshakePayload=function(){function t(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:n.identityKey=e.bytes();break;case 2:n.identitySig=e.bytes();break;case 3:n.data=e.bytes();break;default:e.skipType(7&o)}}return n},t.decodeDelimited=function(e){return e instanceof r||(e=new r(e)),this.decode(e,e.uint32())},t.verify=function(e){return"object"!=typeof e||null===e?"object expected":null!=e.identityKey&&e.hasOwnProperty("identityKey")&&!(e.identityKey&&"number"==typeof e.identityKey.length||n.isString(e.identityKey))?"identityKey: buffer expected":null!=e.identitySig&&e.hasOwnProperty("identitySig")&&!(e.identitySig&&"number"==typeof e.identitySig.length||n.isString(e.identitySig))?"identitySig: buffer expected":null!=e.data&&e.hasOwnProperty("data")&&!(e.data&&"number"==typeof e.data.length||n.isString(e.data))?"data: buffer expected":null},t.fromObject=function(e){if(e instanceof s.pb.NoiseHandshakePayload)return e;var t=new s.pb.NoiseHandshakePayload;return null!=e.identityKey&&("string"==typeof e.identityKey?n.base64.decode(e.identityKey,t.identityKey=n.newBuffer(n.base64.length(e.identityKey)),0):e.identityKey.length&&(t.identityKey=e.identityKey)),null!=e.identitySig&&("string"==typeof e.identitySig?n.base64.decode(e.identitySig,t.identitySig=n.newBuffer(n.base64.length(e.identitySig)),0):e.identitySig.length&&(t.identitySig=e.identitySig)),null!=e.data&&("string"==typeof e.data?n.base64.decode(e.data,t.data=n.newBuffer(n.base64.length(e.data)),0):e.data.length&&(t.data=e.data)),t},t.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(t.bytes===String?r.identityKey="":(r.identityKey=[],t.bytes!==Array&&(r.identityKey=n.newBuffer(r.identityKey))),t.bytes===String?r.identitySig="":(r.identitySig=[],t.bytes!==Array&&(r.identitySig=n.newBuffer(r.identitySig))),t.bytes===String?r.data="":(r.data=[],t.bytes!==Array&&(r.data=n.newBuffer(r.data)))),null!=e.identityKey&&e.hasOwnProperty("identityKey")&&(r.identityKey=t.bytes===String?n.base64.encode(e.identityKey,0,e.identityKey.length):t.bytes===Array?Array.prototype.slice.call(e.identityKey):e.identityKey),null!=e.identitySig&&e.hasOwnProperty("identitySig")&&(r.identitySig=t.bytes===String?n.base64.encode(e.identitySig,0,e.identitySig.length):t.bytes===Array?Array.prototype.slice.call(e.identitySig):e.identitySig),null!=e.data&&e.hasOwnProperty("data")&&(r.data=t.bytes===String?n.base64.encode(e.data,0,e.data.length):t.bytes===Array?Array.prototype.slice.call(e.data):e.data),r},t.prototype.toJSON=function(){return this.constructor.toObject(this,e.util.toJSONOptions)},t}(),t),s},"function"==typeof define&&define.amd?define(["protobufjs/minimal"],i):"function"==typeof e&&"object"==typeof t&&t&&t.exports&&(t.exports=i(e("protobufjs/minimal")))},{"protobufjs/minimal":"grAXL"}],"8oSG2":[function(e,t,r){"use strict";var i=this&&this.__createBinding||(Object.create?function(e,t,r,i){void 0===i&&(i=r),Object.defineProperty(e,i,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,i){void 0===i&&(i=r),e[i]=t[r]}),n=this&&this.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),s=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var r in e)"default"!==r&&Object.prototype.hasOwnProperty.call(e,r)&&i(t,e,r);return n(t,e),t};Object.defineProperty(r,"__esModule",{value:!0}),r.AbstractHandshake=r.MIN_NONCE=void 0;const o=e("buffer"),a=s(e("@stablelib/x25519")),c=s(e("@stablelib/sha256")),u=e("@stablelib/chacha20poly1305"),l=e("../utils"),d=e("../logger");r.MIN_NONCE=0;r.AbstractHandshake=class{encryptWithAd(e,t,r){const i=this.encrypt(e.k,e.n,t,r);return this.setNonce(e,this.incrementNonce(e.n)),i}decryptWithAd(e,t,r){const{plaintext:i,valid:n}=this.decrypt(e.k,e.n,t,r);return this.setNonce(e,this.incrementNonce(e.n)),{plaintext:i,valid:n}}hasKey(e){return!this.isEmptyKey(e.k)}setNonce(e,t){e.n=t}createEmptyKey(){return o.Buffer.alloc(32)}isEmptyKey(e){return this.createEmptyKey().equals(e)}incrementNonce(e){return e+1}nonceToBytes(e){const t=o.Buffer.alloc(12);return t.writeUInt32LE(e,4),t}encrypt(e,t,r,i){const n=this.nonceToBytes(t),s=new u.ChaCha20Poly1305(e).seal(n,i,r);return o.Buffer.from(s.buffer,s.byteOffset,s.length)}encryptAndHash(e,t){let r;return r=this.hasKey(e.cs)?this.encryptWithAd(e.cs,e.h,t):t,this.mixHash(e,r),r}decrypt(e,t,r,i){const n=this.nonceToBytes(t),s=new u.ChaCha20Poly1305(e).open(n,i,r);return s?{plaintext:o.Buffer.from(s.buffer,s.byteOffset,s.length),valid:!0}:{plaintext:o.Buffer.from(""),valid:!1}}decryptAndHash(e,t){let r,i=!0;return this.hasKey(e.cs)?({plaintext:r,valid:i}=this.decryptWithAd(e.cs,e.h,t)):r=t,this.mixHash(e,t),{plaintext:r,valid:i}}dh(e,t){try{const r=a.sharedKey(e,t),i=o.Buffer.from(r.buffer,r.byteOffset,r.length),n=o.Buffer.alloc(32);return i.copy(n),n}catch(e){return d.logger(e.message),o.Buffer.alloc(32)}}mixHash(e,t){e.h=this.getHash(e.h,t)}getHash(e,t){const r=c.hash(o.Buffer.from([...e,...t]));return o.Buffer.from(r.buffer,r.byteOffset,r.length)}mixKey(e,t){const[r,i]=l.getHkdf(e.ck,t);e.cs=this.initializeKey(i),e.ck=r}initializeKey(e){return{k:e,n:r.MIN_NONCE}}initializeSymmetric(e){const t=o.Buffer.from(e,"utf-8"),r=this.hashProtocolName(t),i=r,n=this.createEmptyKey();return{cs:this.initializeKey(n),ck:i,h:r}}hashProtocolName(e){if(e.length<=32){const t=o.Buffer.alloc(32);return e.copy(t),t}return this.getHash(e,o.Buffer.alloc(0))}split(e){const[t,r]=l.getHkdf(e.ck,o.Buffer.alloc(0));return{cs1:this.initializeKey(t),cs2:this.initializeKey(r)}}writeMessageRegular(e,t){const r=this.encryptWithAd(e,o.Buffer.alloc(0),t);return{ne:this.createEmptyKey(),ns:o.Buffer.alloc(0),ciphertext:r}}readMessageRegular(e,t){return this.decryptWithAd(e,o.Buffer.alloc(0),t.ciphertext)}}},{buffer:"etowf","@stablelib/x25519":"5PJXv","@stablelib/sha256":"9CBdD","@stablelib/chacha20poly1305":"buhYd","../utils":"hkQyI","../logger":"iHFBc"}],buhYd:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("@stablelib/chacha"),n=e("@stablelib/poly1305"),s=e("@stablelib/wipe"),o=e("@stablelib/binary"),a=e("@stablelib/constant-time");r.KEY_LENGTH=32,r.NONCE_LENGTH=12,r.TAG_LENGTH=16;var c=new Uint8Array(16),u=function(){function e(e){if(this.nonceLength=r.NONCE_LENGTH,this.tagLength=r.TAG_LENGTH,e.length!==r.KEY_LENGTH)throw new Error("ChaCha20Poly1305 needs 32-byte key");this._key=new Uint8Array(e)}return e.prototype.seal=function(e,t,r,n){if(e.length>16)throw new Error("ChaCha20Poly1305: incorrect nonce length");var o=new Uint8Array(16);o.set(e,o.length-e.length);var a=new Uint8Array(32);i.stream(this._key,o,a,4);var c,u=t.length+this.tagLength;if(n){if(n.length!==u)throw new Error("ChaCha20Poly1305: incorrect destination length");c=n}else c=new Uint8Array(u);return i.streamXOR(this._key,o,t,c,4),this._authenticate(c.subarray(c.length-this.tagLength,c.length),a,c.subarray(0,c.length-this.tagLength),r),s.wipe(o),c},e.prototype.open=function(e,t,r,n){if(e.length>16)throw new Error("ChaCha20Poly1305: incorrect nonce length");if(t.length0&&a.update(c.subarray(i.length%16))),a.update(r),r.length%16>0&&a.update(c.subarray(r.length%16));var u=new Uint8Array(8);i&&o.writeUint64LE(i.length,u),a.update(u),o.writeUint64LE(r.length,u),a.update(u);for(var l=a.digest(),d=0;d>>16|j<<16)|0)>>>20|T<<12,A=(A^=P=P+(D=(D^=_=_+A|0)>>>16|D<<16)|0)>>>20|A<<12,k=(k^=O=O+(M=(M^=E=E+k|0)>>>16|M<<16)|0)>>>20|k<<12,I=(I^=C=C+(x=(x^=S=S+I|0)>>>16|x<<16)|0)>>>20|I<<12,k=(k^=O=O+(M=(M^=E=E+k|0)>>>24|M<<8)|0)>>>25|k<<7,I=(I^=C=C+(x=(x^=S=S+I|0)>>>24|x<<8)|0)>>>25|I<<7,A=(A^=P=P+(D=(D^=_=_+A|0)>>>24|D<<8)|0)>>>25|A<<7,T=(T^=R=R+(j=(j^=w=w+T|0)>>>24|j<<8)|0)>>>25|T<<7,A=(A^=O=O+(x=(x^=w=w+A|0)>>>16|x<<16)|0)>>>20|A<<12,k=(k^=C=C+(j=(j^=_=_+k|0)>>>16|j<<16)|0)>>>20|k<<12,I=(I^=R=R+(D=(D^=E=E+I|0)>>>16|D<<16)|0)>>>20|I<<12,T=(T^=P=P+(M=(M^=S=S+T|0)>>>16|M<<16)|0)>>>20|T<<12,I=(I^=R=R+(D=(D^=E=E+I|0)>>>24|D<<8)|0)>>>25|I<<7,T=(T^=P=P+(M=(M^=S=S+T|0)>>>24|M<<8)|0)>>>25|T<<7,k=(k^=C=C+(j=(j^=_=_+k|0)>>>24|j<<8)|0)>>>25|k<<7,A=(A^=O=O+(x=(x^=w=w+A|0)>>>24|x<<8)|0)>>>25|A<<7;i.writeUint32LE(w+n|0,e,0),i.writeUint32LE(_+s|0,e,4),i.writeUint32LE(E+o|0,e,8),i.writeUint32LE(S+a|0,e,12),i.writeUint32LE(T+c|0,e,16),i.writeUint32LE(A+u|0,e,20),i.writeUint32LE(k+l|0,e,24),i.writeUint32LE(I+d|0,e,28),i.writeUint32LE(R+f|0,e,32),i.writeUint32LE(P+h|0,e,36),i.writeUint32LE(O+p|0,e,40),i.writeUint32LE(C+g|0,e,44),i.writeUint32LE(j+y|0,e,48),i.writeUint32LE(D+m|0,e,52),i.writeUint32LE(M+b|0,e,56),i.writeUint32LE(x+v|0,e,60)}function o(e,t,r,i,o){if(void 0===o&&(o=0),32!==e.length)throw new Error("ChaCha: key size must be 32 bytes");if(i.length>>=8,t++;if(i>0)throw new Error("ChaCha: counter overflow")}r.streamXOR=o,r.stream=function(e,t,r,i){return void 0===i&&(i=0),n.wipe(r),o(e,t,r,r,i)}},{"@stablelib/binary":"h0oFL","@stablelib/wipe":"4bsjy"}],"8r9OD":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("@stablelib/constant-time"),n=e("@stablelib/wipe");r.DIGEST_LENGTH=16;var s=function(){function e(e){this.digestLength=r.DIGEST_LENGTH,this._buffer=new Uint8Array(16),this._r=new Uint16Array(10),this._h=new Uint16Array(10),this._pad=new Uint16Array(8),this._leftover=0,this._fin=0,this._finished=!1;var t=e[0]|e[1]<<8;this._r[0]=8191&t;var i=e[2]|e[3]<<8;this._r[1]=8191&(t>>>13|i<<3);var n=e[4]|e[5]<<8;this._r[2]=7939&(i>>>10|n<<6);var s=e[6]|e[7]<<8;this._r[3]=8191&(n>>>7|s<<9);var o=e[8]|e[9]<<8;this._r[4]=255&(s>>>4|o<<12),this._r[5]=o>>>1&8190;var a=e[10]|e[11]<<8;this._r[6]=8191&(o>>>14|a<<2);var c=e[12]|e[13]<<8;this._r[7]=8065&(a>>>11|c<<5);var u=e[14]|e[15]<<8;this._r[8]=8191&(c>>>8|u<<8),this._r[9]=u>>>5&127,this._pad[0]=e[16]|e[17]<<8,this._pad[1]=e[18]|e[19]<<8,this._pad[2]=e[20]|e[21]<<8,this._pad[3]=e[22]|e[23]<<8,this._pad[4]=e[24]|e[25]<<8,this._pad[5]=e[26]|e[27]<<8,this._pad[6]=e[28]|e[29]<<8,this._pad[7]=e[30]|e[31]<<8}return e.prototype._blocks=function(e,t,r){for(var i=this._fin?0:2048,n=this._h[0],s=this._h[1],o=this._h[2],a=this._h[3],c=this._h[4],u=this._h[5],l=this._h[6],d=this._h[7],f=this._h[8],h=this._h[9],p=this._r[0],g=this._r[1],y=this._r[2],m=this._r[3],b=this._r[4],v=this._r[5],w=this._r[6],_=this._r[7],E=this._r[8],S=this._r[9];r>=16;){var T=e[t+0]|e[t+1]<<8;n+=8191&T;var A=e[t+2]|e[t+3]<<8;s+=8191&(T>>>13|A<<3);var k=e[t+4]|e[t+5]<<8;o+=8191&(A>>>10|k<<6);var I=e[t+6]|e[t+7]<<8;a+=8191&(k>>>7|I<<9);var R=e[t+8]|e[t+9]<<8;c+=8191&(I>>>4|R<<12),u+=R>>>1&8191;var P=e[t+10]|e[t+11]<<8;l+=8191&(R>>>14|P<<2);var O=e[t+12]|e[t+13]<<8;d+=8191&(P>>>11|O<<5);var C=e[t+14]|e[t+15]<<8,j=0,D=j;D+=n*p,D+=s*(5*S),D+=o*(5*E),D+=a*(5*_),j=(D+=c*(5*w))>>>13,D&=8191,D+=u*(5*v),D+=l*(5*b),D+=d*(5*m),D+=(f+=8191&(O>>>8|C<<8))*(5*y);var M=j+=(D+=(h+=C>>>5|i)*(5*g))>>>13;M+=n*g,M+=s*p,M+=o*(5*S),M+=a*(5*E),j=(M+=c*(5*_))>>>13,M&=8191,M+=u*(5*w),M+=l*(5*v),M+=d*(5*b),M+=f*(5*m),j+=(M+=h*(5*y))>>>13,M&=8191;var x=j;x+=n*y,x+=s*g,x+=o*p,x+=a*(5*S),j=(x+=c*(5*E))>>>13,x&=8191,x+=u*(5*_),x+=l*(5*w),x+=d*(5*v),x+=f*(5*b);var B=j+=(x+=h*(5*m))>>>13;B+=n*m,B+=s*y,B+=o*g,B+=a*p,j=(B+=c*(5*S))>>>13,B&=8191,B+=u*(5*E),B+=l*(5*_),B+=d*(5*w),B+=f*(5*v);var L=j+=(B+=h*(5*b))>>>13;L+=n*b,L+=s*m,L+=o*y,L+=a*g,j=(L+=c*p)>>>13,L&=8191,L+=u*(5*S),L+=l*(5*E),L+=d*(5*_),L+=f*(5*w);var N=j+=(L+=h*(5*v))>>>13;N+=n*v,N+=s*b,N+=o*m,N+=a*y,j=(N+=c*g)>>>13,N&=8191,N+=u*p,N+=l*(5*S),N+=d*(5*E),N+=f*(5*_);var U=j+=(N+=h*(5*w))>>>13;U+=n*w,U+=s*v,U+=o*b,U+=a*m,j=(U+=c*y)>>>13,U&=8191,U+=u*g,U+=l*p,U+=d*(5*S),U+=f*(5*E);var F=j+=(U+=h*(5*_))>>>13;F+=n*_,F+=s*w,F+=o*v,F+=a*b,j=(F+=c*m)>>>13,F&=8191,F+=u*y,F+=l*g,F+=d*p,F+=f*(5*S);var K=j+=(F+=h*(5*E))>>>13;K+=n*E,K+=s*_,K+=o*w,K+=a*v,j=(K+=c*b)>>>13,K&=8191,K+=u*m,K+=l*y,K+=d*g,K+=f*p;var z=j+=(K+=h*(5*S))>>>13;z+=n*S,z+=s*E,z+=o*_,z+=a*w,j=(z+=c*v)>>>13,z&=8191,z+=u*b,z+=l*m,z+=d*y,z+=f*g,n=D=8191&(j=(j=((j+=(z+=h*p)>>>13)<<2)+j|0)+(D&=8191)|0),s=M+=j>>>=13,o=x&=8191,a=B&=8191,c=L&=8191,u=N&=8191,l=U&=8191,d=F&=8191,f=K&=8191,h=z&=8191,t+=16,r-=16}this._h[0]=n,this._h[1]=s,this._h[2]=o,this._h[3]=a,this._h[4]=c,this._h[5]=u,this._h[6]=l,this._h[7]=d,this._h[8]=f,this._h[9]=h},e.prototype.finish=function(e,t){void 0===t&&(t=0);var r,i,n,s,o=new Uint16Array(10);if(this._leftover){for(s=this._leftover,this._buffer[s++]=1;s<16;s++)this._buffer[s]=0;this._fin=1,this._blocks(this._buffer,0,16)}for(r=this._h[1]>>>13,this._h[1]&=8191,s=2;s<10;s++)this._h[s]+=r,r=this._h[s]>>>13,this._h[s]&=8191;for(this._h[0]+=5*r,r=this._h[0]>>>13,this._h[0]&=8191,this._h[1]+=r,r=this._h[1]>>>13,this._h[1]&=8191,this._h[2]+=r,o[0]=this._h[0]+5,r=o[0]>>>13,o[0]&=8191,s=1;s<10;s++)o[s]=this._h[s]+r,r=o[s]>>>13,o[s]&=8191;for(o[9]-=8192,i=(1^r)-1,s=0;s<10;s++)o[s]&=i;for(i=~i,s=0;s<10;s++)this._h[s]=this._h[s]&i|o[s];for(this._h[0]=65535&(this._h[0]|this._h[1]<<13),this._h[1]=65535&(this._h[1]>>>3|this._h[2]<<10),this._h[2]=65535&(this._h[2]>>>6|this._h[3]<<7),this._h[3]=65535&(this._h[3]>>>9|this._h[4]<<4),this._h[4]=65535&(this._h[4]>>>12|this._h[5]<<1|this._h[6]<<14),this._h[5]=65535&(this._h[6]>>>2|this._h[7]<<11),this._h[6]=65535&(this._h[7]>>>5|this._h[8]<<8),this._h[7]=65535&(this._h[8]>>>8|this._h[9]<<5),n=this._h[0]+this._pad[0],this._h[0]=65535&n,s=1;s<8;s++)n=(this._h[s]+this._pad[s]|0)+(n>>>16)|0,this._h[s]=65535&n;return e[t+0]=this._h[0]>>>0,e[t+1]=this._h[0]>>>8,e[t+2]=this._h[1]>>>0,e[t+3]=this._h[1]>>>8,e[t+4]=this._h[2]>>>0,e[t+5]=this._h[2]>>>8,e[t+6]=this._h[3]>>>0,e[t+7]=this._h[3]>>>8,e[t+8]=this._h[4]>>>0,e[t+9]=this._h[4]>>>8,e[t+10]=this._h[5]>>>0,e[t+11]=this._h[5]>>>8,e[t+12]=this._h[6]>>>0,e[t+13]=this._h[6]>>>8,e[t+14]=this._h[7]>>>0,e[t+15]=this._h[7]>>>8,this._finished=!0,this},e.prototype.update=function(e){var t,r=0,i=e.length;if(this._leftover){(t=16-this._leftover)>i&&(t=i);for(var n=0;n=16&&(t=i-i%16,this._blocks(e,r,t),r+=t,i-=t),i){for(n=0;n{},r.logLocalStaticKeys=function(e){o(`LOCAL_STATIC_PUBLIC_KEY ${e.publicKey.toString("hex")}`),o(`LOCAL_STATIC_PRIVATE_KEY ${e.privateKey.toString("hex")}`)},r.logLocalEphemeralKeys=function(e){e?(o(`LOCAL_PUBLIC_EPHEMERAL_KEY ${e.publicKey.toString("hex")}`),o(`LOCAL_PRIVATE_EPHEMERAL_KEY ${e.privateKey.toString("hex")}`)):o("Missing local ephemeral keys.")},r.logRemoteStaticKey=function(e){o(`REMOTE_STATIC_PUBLIC_KEY ${e.toString("hex")}`)},r.logRemoteEphemeralKey=function(e){o(`REMOTE_EPHEMERAL_PUBLIC_KEY ${e.toString("hex")}`)},r.logCipherState=function(e){e.cs1&&e.cs2?(o(`CIPHER_STATE_1 ${e.cs1.n} ${e.cs1.k.toString("hex")}`),o(`CIPHER_STATE_2 ${e.cs2.n} ${e.cs2.k.toString("hex")}`)):o("Missing cipher state.")}},{debug:"bO5wM","./constants":"dt6rC"}],dt6rC:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.DUMP_SESSION_KEYS=r.NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG=r.NOISE_MSG_MAX_LENGTH_BYTES=void 0,r.NOISE_MSG_MAX_LENGTH_BYTES=65535,r.NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG=r.NOISE_MSG_MAX_LENGTH_BYTES-16,r.DUMP_SESSION_KEYS=void 0},{}],fJwxo:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.decode2=r.decode1=r.decode0=r.encode2=r.encode1=r.encode0=r.uint16BEDecode=r.uint16BEEncode=void 0;const i=e("buffer");r.uint16BEEncode=(e,t,r)=>((t=t||i.Buffer.allocUnsafe(2)).writeUInt16BE(e,r),t),r.uint16BEEncode.bytes=2;r.uint16BEDecode=e=>{if(e.length<2)throw RangeError("Could not decode int16BE");return e.readUInt16BE(0)},r.uint16BEDecode.bytes=2,r.encode0=function(e){return i.Buffer.concat([e.ne,e.ciphertext])},r.encode1=function(e){return i.Buffer.concat([e.ne,e.ns,e.ciphertext])},r.encode2=function(e){return i.Buffer.concat([e.ns,e.ciphertext])},r.decode0=function(e){if(e.length<32)throw new Error("Cannot decode stage 0 MessageBuffer: length less than 32 bytes.");return{ne:e.slice(0,32),ciphertext:e.slice(32,e.length),ns:i.Buffer.alloc(0)}},r.decode1=function(e){if(e.length<80)throw new Error("Cannot decode stage 1 MessageBuffer: length less than 80 bytes.");return{ne:e.slice(0,32),ns:e.slice(32,80),ciphertext:e.slice(80,e.length)}},r.decode2=function(e){if(e.length<48)throw new Error("Cannot decode stage 2 MessageBuffer: length less than 48 bytes.");return{ne:i.Buffer.alloc(0),ns:e.slice(0,48),ciphertext:e.slice(48,e.length)}}},{buffer:"etowf"}],"6aLUa":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.IKHandshake=void 0;const i=e("./handshakes/ik"),n=e("buffer"),s=e("./encoder"),o=e("./utils"),a=e("./errors"),c=e("./logger");r.IKHandshake=class{constructor(e,t,r,s,o,a,c,u){this.isInitiator=e,this.payload=n.Buffer.from(t),this.prologue=r,this.staticKeypair=s,this.connection=o,c&&(this.remotePeer=c),this.ik=null!=u?u:new i.IK,this.session=this.ik.initSession(this.isInitiator,this.prologue,this.staticKeypair,a),this.remoteEarlyData=n.Buffer.alloc(0)}async stage0(){if(c.logLocalStaticKeys(this.session.hs.s),c.logRemoteStaticKey(this.session.hs.rs),this.isInitiator){c.logger("IK Stage 0 - Initiator sending message...");const e=this.ik.sendMessage(this.session,this.payload);this.connection.writeLP(s.encode1(e)),c.logger("IK Stage 0 - Initiator sent message."),c.logLocalEphemeralKeys(this.session.hs.e)}else{c.logger("IK Stage 0 - Responder receiving message...");const e=await this.connection.readLP();try{const t=s.decode1(e.slice()),{plaintext:r,valid:i}=this.ik.recvMessage(this.session,t);if(!i)throw new Error("ik handshake stage 0 decryption validation fail");c.logger("IK Stage 0 - Responder got message, going to verify payload.");const n=await o.decodePayload(r);this.remotePeer=this.remotePeer||await o.getPeerIdFromPayload(n),await o.verifySignedPayload(this.session.hs.rs,n,this.remotePeer),this.setRemoteEarlyData(n.data),c.logger("IK Stage 0 - Responder successfully verified payload!"),c.logRemoteEphemeralKey(this.session.hs.re)}catch(t){const r=t;throw c.logger("Responder breaking up with IK handshake in stage 0."),new a.FailedIKError(e,`Error occurred while verifying initiator's signed payload: ${r.message}`)}}}async stage1(){if(this.isInitiator){c.logger("IK Stage 1 - Initiator receiving message...");const e=(await this.connection.readLP()).slice(),t=s.decode0(n.Buffer.from(e)),{plaintext:r,valid:i}=this.ik.recvMessage(this.session,t);c.logger("IK Stage 1 - Initiator got message, going to verify payload.");try{if(!i)throw new Error("ik stage 1 decryption validation fail");const e=await o.decodePayload(r);this.remotePeer=this.remotePeer||await o.getPeerIdFromPayload(e),await o.verifySignedPayload(t.ns.slice(0,32),e,this.remotePeer),this.setRemoteEarlyData(e.data),c.logger("IK Stage 1 - Initiator successfully verified payload!"),c.logRemoteEphemeralKey(this.session.hs.re)}catch(t){const r=t;throw c.logger("Initiator breaking up with IK handshake in stage 1."),new a.FailedIKError(e,`Error occurred while verifying responder's signed payload: ${r.message}`)}}else{c.logger("IK Stage 1 - Responder sending message...");const e=this.ik.sendMessage(this.session,this.payload);this.connection.writeLP(s.encode0(e)),c.logger("IK Stage 1 - Responder sent message..."),c.logLocalEphemeralKeys(this.session.hs.e)}c.logCipherState(this.session)}decrypt(e,t){const r=this.getCS(t,!1);return this.ik.decryptWithAd(r,n.Buffer.alloc(0),e)}encrypt(e,t){const r=this.getCS(t);return this.ik.encryptWithAd(r,n.Buffer.alloc(0),e)}getLocalEphemeralKeys(){if(!this.session.hs.e)throw new Error("Ephemeral keys do not exist.");return this.session.hs.e}getCS(e,t=!0){if(!e.cs1||!e.cs2)throw new Error("Handshake not completed properly, cipher state does not exist.");return this.isInitiator?t?e.cs1:e.cs2:t?e.cs2:e.cs1}setRemoteEarlyData(e){e&&(this.remoteEarlyData=n.Buffer.from(e.buffer,e.byteOffset,e.length))}}},{"./handshakes/ik":"hBdbp",buffer:"etowf","./encoder":"fJwxo","./utils":"hkQyI","./errors":"7MQBJ","./logger":"iHFBc"}],hBdbp:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.IK=void 0;const i=e("buffer"),n=e("../utils"),s=e("./abstract-handshake");class o extends s.AbstractHandshake{initSession(e,t,r,i){const n=this.createEmptyKey();let s;return s=e?this.initializeInitiator(t,r,i,n):this.initializeResponder(t,r,i,n),{hs:s,i:e,mc:0}}sendMessage(e,t){let r;if(0===e.mc)r=this.writeMessageA(e.hs,t);else if(1===e.mc){const{messageBuffer:i,h:n,cs1:s,cs2:o}=this.writeMessageB(e.hs,t);r=i,e.h=n,e.cs1=s,e.cs2=o}else{if(!(e.mc>1))throw new Error("Session invalid.");if(e.i){if(!e.cs1)throw new Error("CS1 (cipher state) is not defined");r=this.writeMessageRegular(e.cs1,t)}else{if(!e.cs2)throw new Error("CS2 (cipher state) is not defined");r=this.writeMessageRegular(e.cs2,t)}}return e.mc++,r}recvMessage(e,t){let r=i.Buffer.alloc(0),n=!1;if(0===e.mc&&({plaintext:r,valid:n}=this.readMessageA(e.hs,t)),1===e.mc){const{plaintext:i,valid:s,h:o,cs1:a,cs2:c}=this.readMessageB(e.hs,t);r=i,n=s,e.h=o,e.cs1=a,e.cs2=c}return e.mc++,{plaintext:r,valid:n}}writeMessageA(e,t){e.e=n.generateKeypair();const r=e.e.publicKey;this.mixHash(e.ss,r),this.mixKey(e.ss,this.dh(e.e.privateKey,e.rs));const s=i.Buffer.from(e.s.publicKey),o=this.encryptAndHash(e.ss,s);this.mixKey(e.ss,this.dh(e.s.privateKey,e.rs));return{ne:r,ns:o,ciphertext:this.encryptAndHash(e.ss,t)}}writeMessageB(e,t){e.e=n.generateKeypair();const r=e.e.publicKey;this.mixHash(e.ss,r),this.mixKey(e.ss,this.dh(e.e.privateKey,e.re)),this.mixKey(e.ss,this.dh(e.e.privateKey,e.rs));const i=this.encryptAndHash(e.ss,t),s={ne:r,ns:this.createEmptyKey(),ciphertext:i},{cs1:o,cs2:a}=this.split(e.ss);return{messageBuffer:s,cs1:o,cs2:a,h:e.ss.h}}readMessageA(e,t){n.isValidPublicKey(t.ne)&&(e.re=t.ne),this.mixHash(e.ss,e.re),this.mixKey(e.ss,this.dh(e.s.privateKey,e.re));const{plaintext:r,valid:i}=this.decryptAndHash(e.ss,t.ns);i&&32===r.length&&n.isValidPublicKey(r)&&(e.rs=r),this.mixKey(e.ss,this.dh(e.s.privateKey,e.rs));const{plaintext:s,valid:o}=this.decryptAndHash(e.ss,t.ciphertext);return{plaintext:s,valid:i&&o}}readMessageB(e,t){if(n.isValidPublicKey(t.ne)&&(e.re=t.ne),this.mixHash(e.ss,e.re),!e.e)throw new Error("Handshake state should contain ephemeral key by now.");this.mixKey(e.ss,this.dh(e.e.privateKey,e.re)),this.mixKey(e.ss,this.dh(e.s.privateKey,e.re));const{plaintext:r,valid:i}=this.decryptAndHash(e.ss,t.ciphertext),{cs1:s,cs2:o}=this.split(e.ss);return{h:e.ss.h,valid:i,plaintext:r,cs1:s,cs2:o}}initializeInitiator(e,t,r,n){const s=this.initializeSymmetric("Noise_IK_25519_ChaChaPoly_SHA256");this.mixHash(s,e),this.mixHash(s,r);return{ss:s,s:t,rs:r,re:i.Buffer.alloc(32),psk:n}}initializeResponder(e,t,r,n){const s=this.initializeSymmetric("Noise_IK_25519_ChaChaPoly_SHA256");this.mixHash(s,e),this.mixHash(s,t.publicKey);return{ss:s,s:t,rs:r,re:i.Buffer.alloc(32),psk:n}}}r.IK=o},{buffer:"etowf","../utils":"hkQyI","./abstract-handshake":"8oSG2"}],"7MQBJ":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.FailedIKError=void 0;class i extends Error{constructor(e,t){super(t),this.initialMsg=e,this.name="FailedIKhandshake"}}r.FailedIKError=i},{}],"3Y81f":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.XXFallbackHandshake=void 0;const i=e("buffer"),n=e("./handshake-xx"),s=e("./utils"),o=e("./logger"),a=e("./encoder");class c extends n.XXHandshake{constructor(e,t,r,i,n,s,o,a,c){super(e,t,r,i,n,o,c),a&&(this.ephemeralKeys=a),this.initialMsg=s}async propose(){if(this.isInitiator)this.xx.sendMessage(this.session,i.Buffer.alloc(0),this.ephemeralKeys),o.logger("XX Fallback Stage 0 - Initialized state as the first message was sent by initiator."),o.logLocalEphemeralKeys(this.session.hs.e);else{o.logger("XX Fallback Stage 0 - Responder decoding initial msg from IK.");const e=a.decode0(this.initialMsg),{valid:t}=this.xx.recvMessage(this.session,{ne:e.ne,ns:i.Buffer.alloc(0),ciphertext:i.Buffer.alloc(0)});if(!t)throw new Error("xx fallback stage 0 decryption validation fail");o.logger("XX Fallback Stage 0 - Responder used received message from IK."),o.logRemoteEphemeralKey(this.session.hs.re)}}async exchange(){if(this.isInitiator){const e=a.decode1(this.initialMsg),{plaintext:t,valid:r}=this.xx.recvMessage(this.session,e);if(!r)throw new Error("xx fallback stage 1 decryption validation fail");o.logger("XX Fallback Stage 1 - Initiator used received message from IK."),o.logRemoteEphemeralKey(this.session.hs.re),o.logRemoteStaticKey(this.session.hs.rs),o.logger("Initiator going to check remote's signature...");try{const e=await s.decodePayload(t);this.remotePeer=this.remotePeer||await s.getPeerIdFromPayload(e),await s.verifySignedPayload(this.session.hs.rs,e,this.remotePeer),this.setRemoteEarlyData(e.data)}catch(e){throw new Error(`Error occurred while verifying signed payload from responder: ${e.message}`)}o.logger("All good with the signature!")}else o.logger("XX Fallback Stage 1 - Responder start"),await super.exchange(),o.logger("XX Fallback Stage 1 - Responder end")}}r.XXFallbackHandshake=c},{buffer:"etowf","./handshake-xx":"aO5Kw","./utils":"hkQyI","./logger":"iHFBc","./encoder":"fJwxo"}],fylsy:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.decryptStream=r.encryptStream=void 0;const i=e("buffer"),n=e("./constants");r.encryptStream=function(e){return async function*(t){for await(const r of t){const t=i.Buffer.from(r.buffer,r.byteOffset,r.length);for(let r=0;rt.length&&(i=t.length);const s=e.encrypt(t.slice(r,i),e.session);yield s}}}},r.decryptStream=function(e){return async function*(t){for await(const r of t){const t=i.Buffer.from(r.buffer,r.byteOffset,r.length);for(let r=0;rt.length&&(i=t.length);const s=t.slice(r,i),{plaintext:o,valid:a}=await e.decrypt(s,e.session);if(!a)throw new Error("Failed to validate decrypted chunk");yield o}}}}},{buffer:"etowf","./constants":"dt6rC"}],"8Z0xy":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.KeyCache=void 0;const i=new class{constructor(){this.storage=new Map}store(e,t){this.storage.set(e.id,t)}load(e){var t;return e&&null!==(t=this.storage.get(e.id))&&void 0!==t?t:null}resetStorage(){this.storage.clear()}};r.KeyCache=i},{}],lEgzz:[function(e,t,r){"use strict";const{EventEmitter:i}=e("events"),n=e("err-code"),s=e("libp2p-record"),{MemoryDatastore:o}=e("datastore-core/memory"),{equals:a}=e("uint8arrays/equals"),{toString:c}=e("uint8arrays/to-string"),u=e("./routing-table"),l=e("./utils"),d=e("./constants"),f=e("./network"),h=e("./content-fetching"),p=e("./content-routing"),g=e("./peer-routing"),y=e("./message"),m=e("./providers"),b=e("./query-manager"),v=s.Record;t.exports=class extends i{constructor({libp2p:e,dialer:t,peerId:r,peerStore:i,registrar:n,protocolPrefix:a="/ipfs",forceProtocolLegacy:c=!1,datastore:y=new o,kBucketSize:v=d.K,clientMode:w=!1,concurrency:_=d.ALPHA,validators:E={},selectors:S={},onPut:T=(()=>{}),onRemove:A=(()=>{})}){if(super(),!t)throw new Error("libp2p-kad-dht requires an instance of Dialer");this.libp2p=e,this.dialer=t,this.peerId=r,this.peerStore=i,this.registrar=n,this.protocol=a+(c?"":d.PROTOCOL_DHT),this.kBucketSize=v,this._clientMode=w,this.concurrency=_,this.disjointPaths=Math.ceil(this.kBucketSize/2),this.routingTable=new u(this,{kBucketSize:this.kBucketSize}),this.datastore=y,this.providers=new m(this.datastore,this.peerId),this.validators={pk:s.validator.validators.pk,...E},this.selectors={pk:s.selection.selectors.pk,...S},this.network=new f(this),this._log=l.logger(this.peerId),this._queryManager=new b,this._running=!1,this.contentFetching=h(this),this.contentRouting=p(this),this.peerRouting=g(this),this.onPut=T,this.onRemove=A}get isStarted(){return this._running}start(){return this._running=!0,Promise.all([this.providers.start(),this._queryManager.start(),this.network.start(),this.routingTable.start()])}stop(){return this._running=!1,Promise.all([this.providers.stop(),this._queryManager.stop(),this.network.stop(),this.routingTable.stop()])}async put(e,t,r={}){return this.contentFetching.put(e,t,r)}async get(e,t={}){return this.contentFetching.get(e,t)}async getMany(e,t,r={}){return this.contentFetching.getMany(e,t,r)}async removeLocal(e){this._log(`removeLocal: ${c(e,"base32")}`);const t=l.bufferToKey(e);try{await this.datastore.delete(t)}catch(e){if("ERR_NOT_FOUND"===e.code)return;throw e}}async _putLocal(e,t){this._log(`_putLocal: ${c(e,"base32")}`);const r=l.bufferToKey(e);await this.datastore.put(r,t)}async provide(e){return this.contentRouting.provide(e)}async*findProviders(e,t={timeout:6e3,maxNumProviders:5}){for await(const r of this.contentRouting.findProviders(e,t))yield r}async findPeer(e,t={timeout:6e4}){return this.peerRouting.findPeer(e,t)}async*getClosestPeers(e,t={shallow:!1}){yield*this.peerRouting.getClosestPeers(e,t)}getPublicKey(e){return this.peerRouting.getPublicKey(e)}_peerDiscovered(e,t){this.emit("peer",{id:e,multiaddrs:t})}async _nearestPeersToQuery(e){const t=await l.convertBuffer(e.key);return this.routingTable.closestPeers(t,this.kBucketSize).map((e=>{const t=this.peerStore.get(e);return{id:e,multiaddrs:t?t.addresses.map((e=>e.multiaddr)):[]}}))}async _betterPeersToQuery(e,t){this._log("betterPeersToQuery");return(await this._nearestPeersToQuery(e)).filter((e=>this._isSelf(e.id)?(this._log.error("trying to return self as closer"),!1):!e.id.isEqual(t)))}async _checkLocalDatastore(e){this._log(`checkLocalDatastore: ${c(e)} %b`,e);const t=l.bufferToKey(e);let r;try{r=await this.datastore.get(t)}catch(e){if("ERR_NOT_FOUND"===e.code)return;throw e}const i=v.deserialize(r);if(!i)throw n(new Error("Invalid record"),"ERR_INVALID_RECORD");return null==i.timeReceived||l.now()-i.timeReceived.getTime()>d.MAX_RECORD_AGE?(await this.datastore.delete(t),void this.onRemove(i)):i}async _add(e){await this.routingTable.add(e)}async _verifyRecordLocally(e){this._log("verifyRecordLocally"),await s.validator.verifyRecord(this.validators,e)}_isSelf(e){return e&&a(this.peerId.id,e.id)}async _putValueToPeer(e,t,r){const i=new y(y.TYPES.PUT_VALUE,e,0);i.record=v.deserialize(t);const s=await this.network.sendRequest(r,i);if(s.record&&!a(s.record.value,v.deserialize(t).value))throw n(new Error("value not put correctly"),"ERR_PUT_VALUE_INVALID")}async _getValueOrPeers(e,t){const r=await this._getValueSingle(e,t),i=r.closerPeers,s=r.record;if(s){try{await this._verifyRecordOnline(s)}catch(e){const t="invalid record received, discarded";throw this._log(t),n(new Error(t),"ERR_INVALID_RECORD")}return{record:s,peers:i}}if(i.length>0)return{peers:i};throw n(new Error("Not found"),"ERR_NOT_FOUND")}async _getValueSingle(e,t){const r=new y(y.TYPES.GET_VALUE,t,0);return this.network.sendRequest(e,r)}async _verifyRecordOnline(e){await s.validator.verifyRecord(this.validators,e)}},t.exports.multicodec="/ipfs"+d.PROTOCOL_DHT},{events:"g82pp","err-code":"chZjB","libp2p-record":"h5gPS","datastore-core/memory":"farQr","uint8arrays/equals":"eY3cX","uint8arrays/to-string":"hC8JB","./routing-table":"6K2UO","./utils":"eTk1n","./constants":"4YMVW","./network":"4PJUJ","./content-fetching":"7ohZp","./content-routing":"bDSmy","./peer-routing":"nezkB","./message":"dWtGc","./providers":"lunE9","./query-manager":"9th0A"}],"6K2UO":[function(e,t,r){"use strict";const i=e("k-bucket"),{xor:n}=e("uint8arrays/xor"),s=e("./generated-prefix-list.json"),{sha256:o}=e("multiformats/hashes/sha2"),a=e("libp2p-crypto"),c=e("peer-id"),u=e("../utils"),l=e("debug"),d=Object.assign(l("libp2p:dht:routing-table"),{error:l("libp2p:dht:routing-table:error")}),f=e("it-length");t.exports=class{constructor(e,{kBucketSize:t,refreshInterval:r}={}){this.peerId=e.peerId,this.dht=e,this._kBucketSize=t||20,this._refreshInterval=r||3e4,this.kb=new i({numberOfNodesPerKBucket:this._kBucketSize,numberOfNodesToPing:1}),this.commonPrefixLengthRefreshedAt=[],this._refreshTable=this._refreshTable.bind(this),this._onPing=this._onPing.bind(this)}async start(){this.kb.localNodeId=await u.convertPeerId(this.peerId),this.kb.on("ping",this._onPing),await this._refreshTable(!0)}async stop(){this._refreshTimeoutId&&clearTimeout(this._refreshTimeoutId)}async _refreshTable(e){d("refreshing routing table");const t=this._maxCommonPrefix(),r=this._getTrackedCommonPrefixLengthsForRefresh(t);d(`max common prefix length ${t}`),d(`tracked CPLs [ ${r.map((e=>`${e.getFullYear()}-${(e.getMonth()+1).toString().padStart(2,"0")}-${e.getDate().toString().padStart(2,"0")} ${e.getHours().toString().padStart(2,"0")}:${e.getMinutes().toString().padStart(2,"0")}:${e.getSeconds().toString().padStart(2,"0")}`)).join(", ")} ]`),await Promise.all(r.map((async(i,n)=>{try{if(await this._refreshCommonPrefixLength(n,i,!0===e),0===this._numPeersForCpl(t)){const t=Math.min(2*(n+1),r.length-1);for(let r=n+1;rDate.now()-this._refreshInterval)return void d(`not running refresh for cpl ${e} as time since last refresh not above interval`);const i=await this._generateRandomPeerId(e);d(`starting refreshing cpl ${e} with key ${i.toB58String()} (routing table size was ${this.kb.count()})`);const n=await f(this.dht.getClosestPeers(i.toBytes(),{}));d(`found ${n} peers that were close to imaginary peer ${i.toB58String()}`),d(`finished refreshing cpl ${e} with key ${i.toB58String()} (routing table size was ${this.kb.count()})`)}_getTrackedCommonPrefixLengthsForRefresh(e){e>15&&(e=15);const t=[];for(let r=0;r<=e;r++)t[r]=this.commonPrefixLengthRefreshedAt[r]||new Date;return t}async _generateRandomPeerId(e){const t=a.randomBytes(2),r=(t[1]<<8)+t[0],i=await this._makePeerId(this.kb.localNodeId,r,e);return c.createFromBytes(i)}async _makePeerId(e,t,r){if(r>15)throw new Error("Cannot generate peer ID for common prefix length greater than 15");const i=new DataView(e.buffer,e.byteOffset,e.byteLength).getUint16(0,!1),n=65535<<16-(r+1),a=s[(i^32768>>r)&n|t&~n],c=new ArrayBuffer(34),u=new DataView(c,0,c.byteLength);return u.setUint8(0,o.code),u.setUint8(1,32),u.setUint32(2,a,!1),new Uint8Array(u.buffer,u.byteOffset,u.byteLength)}_maxCommonPrefix(){if(!this.kb.localNodeId)return 0;let e=0;for(const t of this._prefixLengths())t>e&&(e=t);return e}_numPeersForCpl(e){let t=0;for(const r of this._prefixLengths())r===e&&t++;return t}*_prefixLengths(){for(const{id:e}of this.kb.toIterable()){const t=n(this.kb.localNodeId,e);let r=0;for(const e of t){if(0!==e)break;r++}yield r}}_onPing(e,t){const r=e[0];r&&this.kb.remove(r.id),this.kb.add(t)}get size(){return this.kb.count()}async find(e){const t=await u.convertPeerId(e),r=this.closestPeer(t);if(r&&e.equals(r))return r}closestPeer(e){const t=this.closestPeers(e,1);if(t.length>0)return t[0]}closestPeers(e,t){return this.kb.closest(e,t).map((e=>e.peer))}async add(e){const t=await u.convertPeerId(e);this.kb.add({id:t,peer:e})}async remove(e){const t=await u.convertPeerId(e);this.kb.remove(t)}}},{"k-bucket":"6o2Us","uint8arrays/xor":"6wTd5","./generated-prefix-list.json":"15vmo","multiformats/hashes/sha2":"7i9MT","libp2p-crypto":"bb1cb","peer-id":"8Bdb3","../utils":"eTk1n",debug:"bO5wM","it-length":"6ksGI"}],"6o2Us":[function(e,t,r){"use strict";const i=e("randombytes"),{EventEmitter:n}=e("events");function s(e,t){if(e===t)return!0;if(e.length!==t.length)return!1;for(let r=0,i=e.length;rt.vectorClock?e:t}static distance(e,t){let r=0,i=0;const n=Math.min(e.length,t.length),s=Math.max(e.length,t.length);for(;i=0?(this._update(r,i,e),this):r.contacts.length0&&r.length[this.distance(t.id,e),t])).sort(((e,t)=>e[0]-t[0])).slice(0,t).map((e=>e[1]))}count(){let e=0;for(const t=[this.root];t.length>0;){const r=t.pop();null===r.contacts?t.push(r.right,r.left):e+=r.contacts.length}return e}_determineNode(e,t,r){const i=r>>3,n=r%8;if(t.length<=i&&0!==n)return e.left;return t[i]&1<<7-n?e.right:e.left}get(e){o("id",e);let t=0,r=this.root;for(;null===r.contacts;)r=this._determineNode(r,e,t++);const i=this._indexOf(r,e);return i>=0?r.contacts[i]:null}_indexOf(e,t){for(let r=0;r=0){const e=r.contacts.splice(i,1)[0];this.emit("removed",e)}return this}_split(e,t){e.left={contacts:[],dontSplit:!1,left:null,right:null},e.right={contacts:[],dontSplit:!1,left:null,right:null};for(const r of e.contacts)this._determineNode(e,r.id,t).contacts.push(r);e.contacts=null;const r=this._determineNode(e,this.localNodeId,t);(e.left===r?e.right:e.left).dontSplit=!0}toArray(){let e=[];for(const t=[this.root];t.length>0;){const r=t.pop();null===r.contacts?t.push(r.right,r.left):e=e.concat(r.contacts)}return e}*toIterable(){for(const e=[this.root];e.length>0;){const t=e.pop();null===t.contacts?e.push(t.right,t.left):yield*t.contacts}}_update(e,t,r){if(!s(e.contacts[t].id,r.id))throw new Error("wrong index for _update");const i=e.contacts[t],n=this.arbiter(i,r);n===i&&i!==r||(e.contacts.splice(t,1),e.contacts.push(n),this.emit("updated",i,n))}}t.exports=a},{randombytes:"jH1v5",events:"g82pp"}],"6wTd5":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.xor=function(e,t){if(e.length!==t.length)throw new Error("Inputs should have the same length");const r=new Uint8Array(e.length);for(let i=0;i(await n.digest(e)).digest,r.convertPeerId=async e=>(await n.digest(e.id)).digest,r.bufferToKey=e=>new o("/"+r.encodeBase32(e),!1),r.keyForPublicKey=e=>g([h("/pk/"),e.id]),r.isPublicKeyKey=e=>"/pk/"===p(e.slice(0,4)),r.fromPublicKeyKey=e=>new d(e.slice(4)),r.now=()=>Date.now(),r.encodeBase32=e=>p(e,"base32"),r.decodeBase32=e=>h(e,"base32"),r.sortClosestPeers=async(e,t)=>(await u(e,(async e=>{const i=await r.convertPeerId(e);return{peer:e,distance:a(i,t)}}))).sort(r.xorCompare).map((e=>e.peer)),r.xorCompare=(e,t)=>c(e.distance,t.distance),r.pathSize=(e,t)=>Math.ceil(e/t),r.createPutRecord=(e,t)=>{const r=new Date;return new l(e,t,r).serialize()},r.logger=(e,t)=>{const r=["libp2p","dht"];t&&r.push(t),e&&r.push(`${e.toB58String().slice(0,8)}`),i.formatters.b=e=>s.baseEncode(e);return Object.assign(i(r.join(":")),{error:i(r.concat(["error"]).join(":"))})},r.TimeoutError=class extends Error{get code(){return"ETIMEDOUT"}},r.withTimeout=(e,t)=>async function(...r){if(!t)return e(...r);let i;try{i=await y(e(...r),t)}catch(e){if(e instanceof y.TimeoutError)throw f(e,"ETIMEDOUT");throw e}return i},r.mapParallel=async function(e,t){const r=[];for await(const i of e)r.push(t(i));return Promise.all(r)}},{debug:"bO5wM","multiformats/hashes/sha2":"7i9MT","multiformats/bases/base58":"4n7mA","interface-datastore/key":"9hGOz","uint8arrays/xor":"6wTd5","uint8arrays/compare":"2xv9i","p-map":"ccWP1","libp2p-record":"h5gPS","peer-id":"8Bdb3","err-code":"chZjB","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB","uint8arrays/concat":"4EBjG","p-timeout":"hP9Ay"}],ccWP1:[function(e,t,r){"use strict";const i=e("aggregate-error");t.exports=async(e,t,{concurrency:r=1/0,stopOnError:n=!0}={})=>new Promise(((s,o)=>{if("function"!=typeof t)throw new TypeError("Mapper function is required");if(!Number.isSafeInteger(r)&&r!==1/0||!(r>=1))throw new TypeError(`Expected \`concurrency\` to be an integer from 1 and up or \`Infinity\`, got \`${r}\` (${typeof r})`);const a=[],c=[],u=e[Symbol.iterator]();let l=!1,d=!1,f=0,h=0;const p=()=>{if(l)return;const e=u.next(),r=h;if(h++,e.done)return d=!0,void(0===f&&(n||0===c.length?s(a):o(new i(c))));f++,(async()=>{try{const i=await e.value;a[r]=await t(i,r),f--,p()}catch(e){n?(l=!0,o(e)):(c.push(e),f--,p())}})()};for(let e=0;ee instanceof Error?e:null!==e&&"object"==typeof e?Object.assign(new Error(e.message),e):new Error(e)))).map((e=>"string"==typeof e.stack?n(e.stack).replace(/\s+at .*aggregate-error\/index.js:\d+:\d+\)?/g,""):String(e))).join("\n");t="\n"+i(t,4),super(t),this.name="AggregateError",Object.defineProperty(this,"_errors",{value:e})}*[Symbol.iterator](){for(const e of this._errors)yield e}}t.exports=s},{"indent-string":"hRid0","clean-stack":"eUSPW"}],hRid0:[function(e,t,r){"use strict";t.exports=(e,t=1,r)=>{if(r={indent:" ",includeEmptyLines:!1,...r},"string"!=typeof e)throw new TypeError(`Expected \`input\` to be a \`string\`, got \`${typeof e}\``);if("number"!=typeof t)throw new TypeError(`Expected \`count\` to be a \`number\`, got \`${typeof t}\``);if("string"!=typeof r.indent)throw new TypeError(`Expected \`options.indent\` to be a \`string\`, got \`${typeof r.indent}\``);if(0===t)return e;const i=r.includeEmptyLines?/^/gm:/^(?!\s*$)/gm;return e.replace(i,r.indent.repeat(t))}},{}],eUSPW:[function(e,t,r){"use strict";const i=e("os"),n=/\s+at.*(?:\(|\s)(.*)\)?/,s=/^(?:(?:(?:node|(?:internal\/[\w/]*|.*node_modules\/(?:babel-polyfill|pirates)\/.*)?\w+)\.js:\d+:\d+)|native)/,o=void 0===i.homedir?"":i.homedir();t.exports=(e,t)=>(t=Object.assign({pretty:!1},t),e.replace(/\\/g,"/").split("\n").filter((e=>{const t=e.match(n);if(null===t||!t[1])return!0;const r=t[1];return!r.includes(".app/Contents/Resources/electron.asar")&&!r.includes(".app/Contents/Resources/default_app.asar")&&!s.test(r)})).filter((e=>""!==e.trim())).map((e=>t.pretty?e.replace(n,((e,t)=>e.replace(t,t.replace(o,"~")))):e)).join("\n"))},{os:"lHksA"}],"4YMVW":[function(e,t,r){"use strict";const i=r.second=1e3,n=r.minute=60*i,s=r.hour=60*n;r.MAX_RECORD_AGE=36*s,r.PROTOCOL_DHT="/kad/1.0.0",r.PROVIDERS_KEY_PREFIX="/providers/",r.PROVIDERS_LRU_CACHE_SIZE=256,r.PROVIDERS_VALIDITY=24*s,r.PROVIDERS_CLEANUP_INTERVAL=s,r.READ_MESSAGE_TIMEOUT=10*i,r.GET_MANY_RECORD_COUNT=16,r.K=20,r.ALPHA=3},{}],"4PJUJ":[function(e,t,r){"use strict";const i=e("err-code"),{pipe:n}=e("it-pipe"),s=e("it-length-prefixed"),o=e("p-timeout"),{consume:a}=e("streaming-iterables"),c=e("it-first"),u=e("libp2p-interfaces/src/topology/multicodec-topology"),l=e("./rpc"),d=e("./constants"),f=e("./message"),h=e("./utils");t.exports=class{constructor(e){this.dht=e,this.readMessageTimeout=d.READ_MESSAGE_TIMEOUT,this._log=h.logger(this.dht.peerId,"net"),this._rpc=l(this.dht),this._onPeerConnected=this._onPeerConnected.bind(this),this._running=!1}start(){if(this._running)return;if(!this.dht.isStarted)throw i(new Error("Can not start network"),"ERR_CANNOT_START_NETWORK");this._running=!0,!1===this.dht._clientMode&&this.dht.registrar.handle(this.dht.protocol,this._rpc);const e=new u({multicodecs:[this.dht.protocol],handlers:{onConnect:this._onPeerConnected,onDisconnect:()=>{}}});this._registrarId=this.dht.registrar.register(e)}stop(){(this.dht.isStarted||this.isStarted)&&(this._running=!1,this._registrarId&&this.dht.registrar.unregister(this._registrarId))}get isStarted(){return this._running}get isConnected(){return this.dht.isStarted&&this.isStarted}async _onPeerConnected(e){await this.dht._add(e),this._log("added to the routing table: %s",e.toB58String())}async sendRequest(e,t){if(!this.isConnected)throw i(new Error("Network is offline"),"ERR_NETWORK_OFFLINE");const r=e.toB58String();this._log("sending to: %s",r);let n=this.dht.registrar.connectionManager.get(e);n||(n=await this.dht.dialer.connectToPeer(e));const{stream:s}=await n.newStream(this.dht.protocol);return this._writeReadMessage(s,t.serialize())}async sendMessage(e,t){if(!this.isConnected)throw i(new Error("Network is offline"),"ERR_NETWORK_OFFLINE");const r=e.toB58String();this._log("sending to: %s",r);let n=this.dht.registrar.connectionManager.get(e);n||(n=await this.dht.dialer.connectToPeer(e));const{stream:s}=await n.newStream(this.dht.protocol);return this._writeMessage(s,t.serialize())}async _writeReadMessage(e,t){return o(async function(e,t){const r=await n([t],s.encode(),e,s.decode(),(async e=>{const t=await c(e);if(t)return t.slice()}));if(0===r.length)throw i(new Error("No message received"),"ERR_NO_MESSAGE_RECEIVED");return f.deserialize(r)}(e,t),this.readMessageTimeout)}_writeMessage(e,t){return n([t],s.encode(),e,a)}}},{"err-code":"chZjB","it-pipe":"giKBQ","it-length-prefixed":"3yxIE","p-timeout":"hP9Ay","streaming-iterables":"jrrai","it-first":"hBrkP","libp2p-interfaces/src/topology/multicodec-topology":"52SML","./rpc":"8GalW","./constants":"4YMVW","./message":"dWtGc","./utils":"eTk1n"}],jrrai:[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"batch",(()=>s)),i.export(r,"buffer",(()=>u)),i.export(r,"collect",(()=>l)),i.export(r,"concat",(()=>d)),i.export(r,"consume",(()=>f)),i.export(r,"filter",(()=>p)),i.export(r,"flatMap",(()=>b)),i.export(r,"flatTransform",(()=>w)),i.export(r,"flatten",(()=>g)),i.export(r,"fromStream",(()=>E)),i.export(r,"getIterator",(()=>o)),i.export(r,"map",(()=>m)),i.export(r,"merge",(()=>S)),i.export(r,"parallelFlatMap",(()=>k)),i.export(r,"parallelMap",(()=>A)),i.export(r,"parallelMerge",(()=>I)),i.export(r,"pipeline",(()=>T)),i.export(r,"reduce",(()=>P)),i.export(r,"take",(()=>O)),i.export(r,"tap",(()=>j)),i.export(r,"time",(()=>M)),i.export(r,"transform",(()=>B)),i.export(r,"writeToStream",(()=>N));var n=e("process");function s(e,t){return void 0===t?t=>s(e,t):t[Symbol.asyncIterator]?async function*(e,t){let r=[];for await(const i of t)r.push(i),r.length===e&&(yield r,r=[]);r.length>0&&(yield r)}(e,t):function*(e,t){let r=[];for(const i of t)r.push(i),r.length===e&&(yield r,r=[]);r.length>0&&(yield r)}(e,t)}function o(e){if("function"==typeof e.next)return e;if("function"==typeof e[Symbol.iterator])return e[Symbol.iterator]();if("function"==typeof e[Symbol.asyncIterator])return e[Symbol.asyncIterator]();throw new TypeError('"values" does not to conform to any of the iterator or iterable protocols')}function a(){let e,t;return{promise:new Promise(((r,i)=>{t=r,e=i})),reject:e,resolve:t}}function c(e,t){const r=o(t),i=[],n=[];let s=!1,c=!1;async function u(){if(!c&&!(s||i.length>=e)){s=!0;try{const{done:e,value:t}=await r.next();e?c=!0:i.push({value:t})}catch(e){c=!0,i.push({error:e})}!function(){for(;n.length>0&&i.length>0;){const e=n.shift(),{error:t,value:r}=i.shift();t?e.reject(t):e.resolve({done:!1,value:r})}for(;n.length>0&&c;){const{resolve:e}=n.shift();e({done:!0,value:void 0})}}(),s=!1,u()}}const l={next:async function(){if(i.length>0){const{error:e,value:t}=i.shift();if(e)throw e;return u(),{done:!1,value:t}}if(c)return{done:!0,value:void 0};const e=a();return n.push(e),u(),e.promise},[Symbol.asyncIterator]:()=>l};return l}function u(e,t){return void 0===t?t=>u(e,t):0===e?t:t[Symbol.asyncIterator]?c(e,t):function*(e,t){const r=[];let i;try{for(const i of t)r.push(i),r.length<=e||(yield r.shift())}catch(e){i=e}for(const e of r)yield e;if(i)throw i}(e,t)}function l(e){return e[Symbol.asyncIterator]?async function(e){const t=[];for await(const r of e)t.push(r);return t}(e):Array.from(e)}function d(...e){return e.find((e=>void 0!==e[Symbol.asyncIterator]))?async function*(e){for await(const t of e)yield*t}(e):function*(e){for(const t of e)yield*t}(e)}function f(e){if(e[Symbol.asyncIterator])return async function(e){for await(const t of e);}(e);for(const t of e);}async function*h(e,t){for await(const r of t)await e(r)&&(yield r)}function p(e,t){return void 0===t?t=>h(e,t):h(e,t)}async function*g(e){for await(const t of e)t&&"string"!=typeof t&&(t[Symbol.iterator]||t[Symbol.asyncIterator])?yield*g(t):yield t}async function*y(e,t){for await(const r of t)yield await e(r)}function m(e,t){return void 0===t?t=>y(e,t):y(e,t)}function b(e,t){return void 0===t?t=>b(e,t):p((e=>null!=e),g(m(e,t)))}function v(e,t,r){const i=o(r),n=[],s=[];let c=!1,u=!1,l=0,d=null;function f(){for(;s.length>0&&n.length>0;){const{resolve:e}=s.shift();e({done:!1,value:n.shift()})}for(;s.length>0&&0===l&&c;){const{resolve:e,reject:t}=s.shift();d?(t(d),d=null):e({done:!0,value:void 0})}}async function h(){if(c)f();else if(!(u||l+n.length>=e)){u=!0,l++;try{const{done:e,value:r}=await i.next();e?(c=!0,l--,f()):async function(e){try{const r=await t(e);if(r&&r[Symbol.asyncIterator])for await(const e of r)n.push(e);else n.push(r)}catch(e){c=!0,d=e}l--,f(),h()}(r)}catch(e){c=!0,l--,d=e,f()}u=!1,h()}}const p={next:async function(){if(0===n.length){const e=a();return s.push(e),h(),e.promise}const e=n.shift();return h(),{done:!1,value:e}},[Symbol.asyncIterator]:()=>p};return p}function w(e,t,r){return void 0===t?(t,r)=>r?w(e,t,r):w(e,t):void 0===r?r=>w(e,t,r):p((e=>null!=e),g(v(e,t,r)))}async function _(e){return new Promise((t=>{e.once("readable",(()=>{t()}))}))}function E(e){return"function"==typeof e[Symbol.asyncIterator]?e:async function*(e){for(;;){const t=e.read();if(null===t){if(e._readableState.ended)break;await _(e)}else yield t}}(e)}async function*S(...e){const t=new Set(e.map(o));for(;t.size>0;)for(const e of t){const r=await e.next();r.done?t.delete(e):yield r.value}}function T(e,...t){let r=e();for(const e of t)r=e(r);return r}function A(e,t,r){return void 0===t?(t,r)=>A(e,t,r):void 0===r?r=>A(e,t,r):1===e?m(t,r):async function*(e,t,r){let i=null;const n=o(T((()=>r),u(1),(async function*(e){for await(const t of e){if(i)return;yield t}}),m((e=>({value:t(e)}))),u(e-1)));for(;;){const{value:e,done:t}=await n.next();if(t)break;try{const t=await e.value;i||(yield t)}catch(e){i=e}}if(i)throw i}(e,t,r)}function k(e,t,r){return void 0===t?(t,r)=>r?k(e,t,r):k(e,t):void 0===r?r=>k(e,t,r):p((e=>null!=e),g(A(e,t,r)))}async function*I(...e){const t=e.map(o),r=new Set,i=new Map;let n=null,s=null,a=null;const c=e=>{n=e,s&&s(e)},u=e=>{a&&a(e)},l=e=>{const t=Promise.resolve(e.next()).then((async({done:n,value:s})=>{n||i.set(e,s),r.delete(t)}));r.add(t),t.then(u,c)};for(const e of t)l(e);for(;;){if(0===r.size&&0===i.size)return;await new Promise(((e,t)=>{if(n&&t(n),i.size>0)return e();a=e,s=t}));for(const[e,t]of i)i.delete(e),yield t,l(e)}}async function R(e,t,r){let i=t;for await(const t of r)i=await e(i,t);return i}function P(e,t,r){return void 0===t?(t,r)=>r?R(e,t,r):P(e,t):void 0===r?r=>P(e,t,r):R(e,t,r)}function O(e,t){return void 0===t?t=>O(e,t):t[Symbol.asyncIterator]?async function*(e,t){let r=0;for await(const i of t)if(yield await i,r++,r>=e)break}(e,t):function*(e,t){let r=0;for(const i of t)if(yield i,r++,r>=e)break}(e,t)}async function*C(e,t){for await(const r of t)await e(r),yield r}function j(e,t){return void 0===t?t=>C(e,t):C(e,t)}function D(e,t){let r=e[0]+t[0],i=e[1]+t[1];if(i>=1e9){const e=i%1e9;r+=(i-e)/1e9,i=e}return[r,i]}function M(e={},t){return void 0===t?t=>M(e,t):void 0!==t[Symbol.asyncIterator]?async function*(e,t){const r=t[Symbol.asyncIterator]();let i=[0,0];for(;;){const t=n.hrtime(),{value:s,done:o}=await r.next(),a=n.hrtime(t);if(i=D(i,a),e.progress&&e.progress(a,i),o)return e.total&&e.total(i),s;yield s}}(e,t):function*(e,t){const r=t[Symbol.iterator]();let i=[0,0];for(;;){const t=n.hrtime(),{value:s,done:o}=r.next(),a=n.hrtime(t);if(i=D(i,a),e.progress&&e.progress(a,i),o)return e.total&&e.total(i),s;yield s}}(e,t)}function x(e,t,r){const i=o(r),n=[],s=[];let c=!1,u=!1,l=0,d=null;function f(){for(;s.length>0&&n.length>0;){const{resolve:e}=s.shift();e({done:!1,value:n.shift()})}for(;s.length>0&&0===l&&c;){const{resolve:e,reject:t}=s.shift();d?(t(d),d=null):e({done:!0,value:void 0})}}async function h(){if(c)f();else if(!(u||l+n.length>=e)){u=!0,l++;try{const{done:e,value:r}=await i.next();e?(c=!0,l--,f()):async function(e){try{const r=await t(e);n.push(r)}catch(e){c=!0,d=e}l--,f(),h()}(r)}catch(e){c=!0,l--,d=e,f()}u=!1,h()}}const p={next:async function(){if(0===n.length){const e=a();return s.push(e),h(),e.promise}const e=n.shift();return h(),{done:!1,value:e}},[Symbol.asyncIterator]:()=>p};return p}function B(e,t,r){return void 0===t?(t,r)=>r?B(e,t,r):B(e,t):void 0===r?r=>B(e,t,r):x(e,t,r)}async function L(e,t){let r=null,i=null,n=null;const s=e=>{r=e,i&&i(e)},o=()=>{n&&n()};e.once("error",s);for await(const s of t)if(!1===e.write(s)&&await new Promise(((t,s)=>{if(r)return s(r);e.once("drain",o),n=t,i=s})),r)break;if(e.removeListener("error",s),e.removeListener("drain",o),r)throw r}function N(e,t){return void 0===t?t=>L(e,t):L(e,t)}},{process:"bjUAi","@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],"8GalW":[function(e,t,r){"use strict";const{pipe:i}=e("it-pipe"),n=e("it-length-prefixed"),s=e("../message"),o=e("./handlers"),a=e("../utils");t.exports=e=>{const t=a.logger(e.peerId,"rpc"),r=o(e);async function c(i,n){const s=r(n.type);try{await e._add(i)}catch(e){t.error("Failed to update the kbucket store",e)}if(s)return s(i,n);t.error(`no handler found for message type: ${n.type}`)}return async function({stream:r,connection:o}){const a=o.remotePeer;try{await e._add(a)}catch(e){t.error(e)}const u=a.toB58String();t("from: %s",u),await i(r.source,n.decode(),(e=>async function*(){for await(const t of e){const e=s.deserialize(t.slice()),r=await c(a,e);r&&(yield r.serialize())}}()),n.encode(),r.sink)}}},{"it-pipe":"giKBQ","it-length-prefixed":"3yxIE","../message":"dWtGc","./handlers":"jYQNr","../utils":"eTk1n"}],dWtGc:[function(e,t,r){"use strict";const i=e("peer-id"),{Multiaddr:n}=e("multiaddr"),{Record:s}=e("libp2p-record"),o=e("./dht"),a=o.Message.MessageType,c=o.Message.ConnectionType;class u{constructor(e,t,r){if(t&&!(t instanceof Uint8Array))throw new Error("Key must be a Uint8Array");this.type=e,this.key=t,this._clusterLevelRaw=r,this.closerPeers=[],this.providerPeers=[],this.record=void 0}get clusterLevel(){const e=this._clusterLevelRaw-1;return e<0?0:e}set clusterLevel(e){this._clusterLevelRaw=e}serialize(){const e={key:this.key,type:this.type,clusterLevelRaw:this._clusterLevelRaw,closerPeers:this.closerPeers.map(l),providerPeers:this.providerPeers.map(l),record:void 0};return this.record&&(this.record instanceof Uint8Array?e.record=this.record:e.record=this.record.serialize()),o.Message.encode(e).finish()}static deserialize(e){const t=o.Message.decode(e),r=new u(t.type||0,t.key||Uint8Array.from([]),t.clusterLevelRaw||0);return r.closerPeers=t.closerPeers.map(d),r.providerPeers=t.providerPeers.map(d),t.record&&t.record.length&&(r.record=s.deserialize(t.record)),r}}function l(e){return{id:e.id.id,addrs:(e.multiaddrs||[]).map((e=>e.bytes)),connection:c.CONNECTED}}function d(e){return{id:new i(e.id),multiaddrs:(e.addrs||[]).map((e=>new n(e)))}}u.TYPES=a,u.CONNECTION_TYPES=c,t.exports=u},{"peer-id":"8Bdb3",multiaddr:"8Mu1u","libp2p-record":"h5gPS","./dht":"xqrwr"}],xqrwr:[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-dht-message"]||(i.roots["libp2p-dht-message"]={});a.Record=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.key=e.bytes();break;case 2:i.value=e.bytes();break;case 3:i.author=e.bytes();break;case 4:i.signature=e.bytes();break;case 5:i.timeReceived=e.string();break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.Record)return e;var t=new a.Record;return null!=e.key&&("string"==typeof e.key?o.base64.decode(e.key,t.key=o.newBuffer(o.base64.length(e.key)),0):e.key.length&&(t.key=e.key)),null!=e.value&&("string"==typeof e.value?o.base64.decode(e.value,t.value=o.newBuffer(o.base64.length(e.value)),0):e.value.length&&(t.value=e.value)),null!=e.author&&("string"==typeof e.author?o.base64.decode(e.author,t.author=o.newBuffer(o.base64.length(e.author)),0):e.author.length&&(t.author=e.author)),null!=e.signature&&("string"==typeof e.signature?o.base64.decode(e.signature,t.signature=o.newBuffer(o.base64.length(e.signature)),0):e.signature.length&&(t.signature=e.signature)),null!=e.timeReceived&&(t.timeReceived=String(e.timeReceived)),t},e.toObject=function(e,t){t||(t={});var r={};return null!=e.key&&e.hasOwnProperty("key")&&(r.key=t.bytes===String?o.base64.encode(e.key,0,e.key.length):t.bytes===Array?Array.prototype.slice.call(e.key):e.key,t.oneofs&&(r._key="key")),null!=e.value&&e.hasOwnProperty("value")&&(r.value=t.bytes===String?o.base64.encode(e.value,0,e.value.length):t.bytes===Array?Array.prototype.slice.call(e.value):e.value,t.oneofs&&(r._value="value")),null!=e.author&&e.hasOwnProperty("author")&&(r.author=t.bytes===String?o.base64.encode(e.author,0,e.author.length):t.bytes===Array?Array.prototype.slice.call(e.author):e.author,t.oneofs&&(r._author="author")),null!=e.signature&&e.hasOwnProperty("signature")&&(r.signature=t.bytes===String?o.base64.encode(e.signature,0,e.signature.length):t.bytes===Array?Array.prototype.slice.call(e.signature):e.signature,t.oneofs&&(r._signature="signature")),null!=e.timeReceived&&e.hasOwnProperty("timeReceived")&&(r.timeReceived=e.timeReceived,t.oneofs&&(r._timeReceived="timeReceived")),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,i.util.toJSONOptions)},e}(),a.Message=function(){function e(e){if(this.closerPeers=[],this.providerPeers=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.type=e.int32();break;case 10:i.clusterLevelRaw=e.int32();break;case 2:i.key=e.bytes();break;case 3:i.record=e.bytes();break;case 8:i.closerPeers&&i.closerPeers.length||(i.closerPeers=[]),i.closerPeers.push(a.Message.Peer.decode(e,e.uint32()));break;case 9:i.providerPeers&&i.providerPeers.length||(i.providerPeers=[]),i.providerPeers.push(a.Message.Peer.decode(e,e.uint32()));break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.Message)return e;var t=new a.Message;switch(e.type){case"PUT_VALUE":case 0:t.type=0;break;case"GET_VALUE":case 1:t.type=1;break;case"ADD_PROVIDER":case 2:t.type=2;break;case"GET_PROVIDERS":case 3:t.type=3;break;case"FIND_NODE":case 4:t.type=4;break;case"PING":case 5:t.type=5}if(null!=e.clusterLevelRaw&&(t.clusterLevelRaw=0|e.clusterLevelRaw),null!=e.key&&("string"==typeof e.key?o.base64.decode(e.key,t.key=o.newBuffer(o.base64.length(e.key)),0):e.key.length&&(t.key=e.key)),null!=e.record&&("string"==typeof e.record?o.base64.decode(e.record,t.record=o.newBuffer(o.base64.length(e.record)),0):e.record.length&&(t.record=e.record)),e.closerPeers){if(!Array.isArray(e.closerPeers))throw TypeError(".Message.closerPeers: array expected");t.closerPeers=[];for(var r=0;r>>3){case 1:i.id=e.bytes();break;case 2:i.addrs&&i.addrs.length||(i.addrs=[]),i.addrs.push(e.bytes());break;case 3:i.connection=e.int32();break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.Message.Peer)return e;var t=new a.Message.Peer;if(null!=e.id&&("string"==typeof e.id?o.base64.decode(e.id,t.id=o.newBuffer(o.base64.length(e.id)),0):e.id.length&&(t.id=e.id)),e.addrs){if(!Array.isArray(e.addrs))throw TypeError(".Message.Peer.addrs: array expected");t.addrs=[];for(var r=0;r{const r={[i.GET_VALUE]:e("./get-value")(t),[i.PUT_VALUE]:e("./put-value")(t),[i.FIND_NODE]:e("./find-node")(t),[i.ADD_PROVIDER]:e("./add-provider")(t),[i.GET_PROVIDERS]:e("./get-providers")(t),[i.PING]:e("./ping")(t)};return function(e){return r[e]}}},{"../../message":"dWtGc","./get-value":"fhqbS","./put-value":"7V6R3","./find-node":"i6Wjq","./add-provider":"7ShND","./get-providers":"1f7P5","./ping":"2BfBU"}],fhqbS:[function(e,t,r){"use strict";const{Record:i}=e("libp2p-record"),n=e("err-code"),s=e("../../message"),o=e("../../utils");t.exports=e=>{const t=o.logger(e.peerId,"rpc:get-value");return async function(r,a){const c=a.key;if(t("key: %b",c),!c||0===c.length)throw n(new Error("Invalid key"),"ERR_INVALID_KEY");const u=new s(s.TYPES.GET_VALUE,c,a.clusterLevel);if(o.isPublicKeyKey(c)){t("is public key");const r=o.fromPublicKeyKey(c);let n;if(e._isSelf(r))n=e.peerId;else{const t=e.peerStore.get(r);n=t&&t.id}if(n&&n.pubKey)return t("returning found public key"),u.record=new i(c,n.pubKey.bytes),u}const[l,d]=await Promise.all([e._checkLocalDatastore(c),e._betterPeersToQuery(a,r)]);return l&&(t("got record"),u.record=l),d.length>0&&(t("got closer %s",d.length),u.closerPeers=d),u}}},{"libp2p-record":"h5gPS","err-code":"chZjB","../../message":"dWtGc","../../utils":"eTk1n"}],"7V6R3":[function(e,t,r){"use strict";const i=e("../../utils"),n=e("err-code");t.exports=e=>{const t=i.logger(e.peerId,"rpc:put-value");return async function(r,s){const o=s.key;t("key: %b",o);const a=s.record;if(!a){const e=`Empty record from: ${r.toB58String()}`;throw t.error(e),n(new Error(e),"ERR_EMPTY_RECORD")}await e._verifyRecordLocally(a),a.timeReceived=new Date;const c=i.bufferToKey(a.key);return await e.datastore.put(c,a.serialize()),e.onPut(a,r),s}}},{"../../utils":"eTk1n","err-code":"chZjB"}],i6Wjq:[function(e,t,r){"use strict";const{equals:i}=e("uint8arrays/equals"),n=e("../../message"),s=e("../../utils");t.exports=e=>{const t=s.logger(e.peerId,"rpc:find-node");return async function(r,s){let o;t("start"),o=i(s.key,e.peerId.id)?[{id:e.peerId,multiaddrs:e.libp2p.multiaddrs}]:await e._betterPeersToQuery(s,r);const a=new n(s.type,new Uint8Array(0),s.clusterLevel);return o.length>0?a.closerPeers=o:t("handle FindNode %s: could not find anything",r.toB58String()),a}}},{"uint8arrays/equals":"eY3cX","../../message":"dWtGc","../../utils":"eTk1n"}],"7ShND":[function(e,t,r){"use strict";const{CID:i}=e("multiformats/cid"),n=e("err-code"),s=e("../../utils");t.exports=e=>{const t=s.logger(e.peerId,"rpc:add-provider");return async function(r,s){if(t("start"),!s.key||0===s.key.length)throw n(new Error("Missing key"),"ERR_MISSING_KEY");let o;try{o=i.decode(s.key)}catch(e){const t=`Invalid CID: ${e.message}`;throw n(new Error(t),"ERR_INVALID_CID")}return s.providerPeers.forEach((i=>{if(i.id.isEqual(r)){if(!(i.multiaddrs.length<1))return t("received provider %s for %s (addrs %s)",r.toB58String(),o.toString(),i.multiaddrs.map((e=>e.toString()))),e._isSelf(i.id)?void 0:(e.peerStore.addressBook.add(i.id,i.multiaddrs),e.providers.addProvider(o,i.id));t("no valid addresses for provider %s. Ignore",r.toB58String())}else t("invalid provider peer %s from %s",i.id.toB58String(),r.toB58String())})),e.providers.addProvider(o,r)}}},{"multiformats/cid":"9ooAY","err-code":"chZjB","../../utils":"eTk1n"}],"1f7P5":[function(e,t,r){"use strict";const{CID:i}=e("multiformats/cid"),n=e("err-code"),s=e("../../message"),o=e("../../utils");t.exports=e=>{const t=o.logger(e.peerId,"rpc:get-providers");return async function(r,a){let c;try{c=i.decode(a.key)}catch(e){throw n(new Error(`Invalid CID: ${e.message}`),"ERR_INVALID_CID")}t("%s",c.toString());const u=o.bufferToKey(c.bytes),[l,d,f]=await Promise.all([e.datastore.has(u),e.providers.getProviders(c),e._betterPeersToQuery(a,r)]),h=d.map((e=>({id:e,multiaddrs:[]}))),p=f.map((e=>({id:e.id,multiaddrs:[]})));l&&h.push({id:e.peerId,multiaddrs:[]});const g=new s(a.type,a.key,a.clusterLevel);return h.length>0&&(g.providerPeers=h),p.length>0&&(g.closerPeers=p),t("got %s providers %s closerPeers",h.length,p.length),g}}},{"multiformats/cid":"9ooAY","err-code":"chZjB","../../message":"dWtGc","../../utils":"eTk1n"}],"2BfBU":[function(e,t,r){"use strict";const i=e("../../utils");t.exports=e=>{const t=i.logger(e.peerId,"rpc:ping");return function(e,r){return t("from %s",e.toB58String()),r}}},{"../../utils":"eTk1n"}],"7ohZp":[function(e,t,r){"use strict";const i=e("err-code"),n=e("p-timeout"),{equals:s}=e("uint8arrays/equals"),{toString:o}=e("uint8arrays/to-string"),a=e("libp2p-record"),c=e("../constants"),u=e("../query"),l=e("../utils"),d=a.Record;t.exports=e=>{const t=async(t,r)=>e.datastore.put(l.bufferToKey(t),r);return{_putLocal:async(e,r)=>t(e,r),async put(r,n,s={}){e._log("PutValue %b",r);const o=await l.createPutRecord(r,n);await t(r,o);let a=0,c=0;await l.mapParallel(e.getClosestPeers(r,{shallow:!0}),(async t=>{try{a+=1,await e._putValueToPeer(r,o,t),c+=1}catch(r){e._log.error("Failed to put to peer (%b): %s",t.id,r)}}));const u=s.minPeers||a;if(u>c){const t=i(new Error(`Failed to put value to enough peers: ${c}/${u}`),"ERR_NOT_ENOUGH_PUT_PEERS");throw e._log.error(t),t}},async get(t,r={}){r.timeout=r.timeout||c.minute,e._log("_get %b",t);const n=await e.getMany(t,c.GET_MANY_RECORD_COUNT,r),o=n.map((e=>e.val));let u=0;try{u=a.selection.bestRecord(e.selectors,t,o)}catch(e){if("ERR_NO_SELECTOR_FUNCTION_FOR_RECORD_KEY"!==e.code)throw e}const d=o[u];if(e._log("GetValue %b %s",t,d),!d)throw i(new Error("best value was not found"),"ERR_NOT_FOUND");return await(async(t,r,i)=>{const n=await l.createPutRecord(t,i);return Promise.all(r.map((async r=>{if(!s(r.val,i))if(e._isSelf(r.from))try{await e._putLocal(t,n)}catch(t){e._log.error("Failed error correcting self",t)}else try{await e._putValueToPeer(t,n,r.from)}catch(t){e._log.error("Failed error correcting entry",t)}})))})(t,n,d),d},async getMany(t,r,s={}){s.timeout=s.timeout||c.minute,e._log("getMany %b (%s)",t,r);const a=[];let f;try{f=await(async t=>{e._log(`getLocal ${o(t,"base32")}`);const r=await e.datastore.get(l.bufferToKey(t));e._log(`found ${o(t,"base32")} in local datastore`);const i=d.deserialize(r);return await e._verifyRecordLocally(i),i})(t)}catch(e){if(0===r)throw e}if(f&&a.push({val:f.value,from:e.peerId}),a.length>=r)return a;const h=await l.convertBuffer(t),p=e.routingTable.closestPeers(h,e.kBucketSize);if(e._log("peers in rt: %d",p.length),0===p.length){const t="Failed to lookup key! No peers from routing table!";if(e._log.error(t),0===a.length)throw i(new Error(t),"ERR_NO_PEERS_IN_ROUTING_TABLE");return a}const g=a.length;const y=new u(e,t,(function(i,n){const s=l.pathSize(r-g,n);let o=0;return async function(r){let i,n,c;try{const s=await e._getValueOrPeers(r,t);i=s.record,n=s.peers}catch(e){if("ERR_INVALID_RECORD"!==e.code)throw e;c=e}const u={closerPeers:n};return i&&i.value?(a.push({val:i.value,from:r}),o++):c&&(a.push({err:c,from:r}),o++),o>=s&&(u.pathComplete=!0),u}}));try{await n(y.run(p),s.timeout)}catch(e){if(0===a.length)throw e}finally{y.stop()}return a}}}},{"err-code":"chZjB","p-timeout":"hP9Ay","uint8arrays/equals":"eY3cX","uint8arrays/to-string":"hC8JB","libp2p-record":"h5gPS","../constants":"4YMVW","../query":"jOM9h","../utils":"eTk1n"}],jOM9h:[function(e,t,r){"use strict";const{base58btc:i}=e("multiformats/bases/base58"),n=e("../utils"),s=e("./run");t.exports=class{constructor(e,t,r){this.dht=e,this.key=t,this.makePath=r,this._log=n.logger(this.dht.peerId,"query:"+i.baseEncode(t)),this.running=!1,this._onStart=this._onStart.bind(this),this._onComplete=this._onComplete.bind(this)}async run(e){return this.dht._queryManager.running?0===e.length?(this._log.error("Running query with no peers"),{finalSet:new Set,paths:[]}):(this._run=new s(this),this._log(`query running with K=${this.dht.kBucketSize}, A=${this.dht.concurrency}, D=${Math.min(this.dht.disjointPaths,e.length)}`),this._run.once("start",this._onStart),this._run.once("complete",this._onComplete),this._run.execute(e)):(this._log.error("Attempt to run query after shutdown"),{finalSet:new Set,paths:[]})}_onStart(){this.running=!0,this._startTime=Date.now(),this._log("query:start"),this.dht._queryManager.queryStarted(this)}_onComplete(){this.stop()}stop(){this._log(`query:done in ${Date.now()-(this._startTime||0)}ms`),this._run&&this._log(`${this._run.errors.length} of ${this._run.peersSeen.size} peers errored (${this._run.errors.length/this._run.peersSeen.size*100}% fail rate)`),this.running&&(this.running=!1,this._run&&(this._run.removeListener("start",this._onStart),this._run.removeListener("complete",this._onComplete),this._run.stop()),this.dht._queryManager.queryCompleted(this))}}},{"multiformats/bases/base58":"4n7mA","../utils":"eTk1n","./run":"gHPwC"}],gHPwC:[function(e,t,r){"use strict";const i=e("../peer-list/peer-distance-list"),n=e("events"),s=e("./path"),o=e("./worker-queue"),a=e("../utils");t.exports=class extends n{constructor(e){super(),this.query=e,this.running=!1,this.workers=[],this.peersSeen=new Set,this.errors=[],this.peersQueried=null}stop(){if(this.running){this.running=!1;for(const e of this.workers)e.stop()}}async execute(e){const t=[],r=Math.min(this.query.dht.disjointPaths,e.length);for(let e=0;e{t[i%r].addInitialPeer(e)})),await this.executePaths(t);const i={finalSet:new Set(this.peersQueried&&this.peersQueried.peers),paths:[]};for(const e of t)e.res&&(e.res.pathComplete||e.res.queryComplete)&&(e.res.success=!0,i.paths.push(e.res));return i}async executePaths(e){this.running=!0,this.emit("start");try{await Promise.all(e.map((e=>e.execute())))}finally{this.stop(),this.emit("complete")}if(this.errors.length===this.peersSeen.size)throw this.errors[0]}async workerQueue(e){await this.init(),await this.startWorker(e)}async startWorker(e){const t=new o(this.query.dht,this,e,this.query._log);this.workers.push(t),await t.execute()}async init(){this.peersQueried||(this.peersQueriedPromise?await this.peersQueriedPromise:(this.peersQueriedPromise=(async()=>{const e=await a.convertBuffer(this.query.key);this.peersQueried=new i(e,this.query.dht.kBucketSize)})(),await this.peersQueriedPromise,delete this.peersQueriedPromise))}async continueQuerying(e){if(this.peersQueried&&this.peersQueried.lengthe.peerId))}async add(e){if(this.peerDistances.find((t=>s(t.peerId.id,e.id))))return;const t=await i.convertPeerId(e),r={peerId:e,distance:a(this.originDhtKey,t)};this.peerDistances.push(r),this.peerDistances.sort(((e,t)=>o(e.distance,t.distance))),this.peerDistances=this.peerDistances.slice(0,this.capacity)}async anyCloser(e){if(!e.length)return!1;if(!this.length)return!0;const t=await n(e,(e=>i.convertPeerId(e))),r=this.peerDistances[this.peerDistances.length-1].distance;for(const e of t){const t=a(this.originDhtKey,e);if(o(t,r)<0)return!0}return!1}}},{"../utils":"eTk1n","p-map":"ccWP1","uint8arrays/equals":"eY3cX","uint8arrays/compare":"2xv9i","uint8arrays/xor":"6wTd5"}],jyTZo:[function(e,t,r){"use strict";const i=e("../peer-list/peer-queue"),n=e("../utils");t.exports=class{constructor(e,t){if(this.run=e,this.queryFunc=n.withTimeout(t,3e4),!this.queryFunc)throw new Error("Path requires a `queryFn` to be specified");if("function"!=typeof this.queryFunc)throw new Error("Path expected `queryFn` to be a function. Got "+typeof this.queryFunc);this.initialPeers=[],this.peersToQuery=null,this.res=null}addInitialPeer(e){this.initialPeers.push(e)}async execute(){const e=await i.fromKey(this.run.query.key);this.peersToQuery=e,await Promise.all(this.initialPeers.map((e=>this.addPeerToQuery(e)))),await this.run.workerQueue(this)}async addPeerToQuery(e){this.run.query.dht._isSelf(e)||this.run.peersSeen.has(e.toB58String())||this.peersToQuery&&await this.peersToQuery.enqueue(e)}}},{"../peer-list/peer-queue":"2hgn1","../utils":"eTk1n"}],"2hgn1":[function(e,t,r){"use strict";const i=e("heap"),{xor:n}=e("uint8arrays/xor"),s=e("debug"),o=e("../utils"),a=s("libp2p:dht:peer-queue");class c{static async fromPeerId(e){const t=await o.convertPeerId(e);return new c(t)}static async fromKey(e){const t=await o.convertBuffer(e);return new c(t)}constructor(e){a("create: %b",e),this.from=e,this.heap=new i(o.xorCompare)}async enqueue(e){a("enqueue %s",e.toB58String());const t=await o.convertPeerId(e),r={id:e,distance:n(this.from,t)};this.heap.push(r)}dequeue(){const e=this.heap.pop();return a("dequeue %s",e.id.toB58String()),e.id}get length(){return this.heap.size()}}t.exports=c},{heap:"lhu6N","uint8arrays/xor":"6wTd5",debug:"bO5wM","../utils":"eTk1n"}],lhu6N:[function(e,t,r){t.exports=e("./lib/heap")},{"./lib/heap":"bAELV"}],bAELV:[function(e,t,r){(function(){var e,i,n,s,o,a,c,u,l,d,f,h,p,g,y,m,b;n=Math.floor,d=Math.min,i=function(e,t){return et?1:0},l=function(e,t,r,s,o){var a;if(null==r&&(r=0),null==o&&(o=i),r<0)throw new Error("lo must be non-negative");for(null==s&&(s=e.length);rr;0<=r?t++:t--)u.push(t);return u}.apply(this).reverse()).length;sg;0<=g?++f:--f)y.push(o(e,r));return y},g=function(e,t,r,n){var s,o,a;for(null==n&&(n=i),s=e[r];r>t&&n(s,o=e[a=r-1>>1])<0;)e[r]=o,r=a;return e[r]=s},y=function(e,t,r){var n,s,o,a,c;for(null==r&&(r=i),s=e.length,c=t,o=e[t],n=2*t+1;n{this.path.peersToQuery&&!this.path.peersToQuery.length&&(this.log("queue:drain"),this.stop())})),e.on("next",(()=>{this.running&&e.pendinge.running)).length),this.execution&&(e?this.execution.reject(e):this.execution.resolve()))}async execute(){this.running=!0,this.execution=null;const e=new Promise(((e,t)=>{this.execution={resolve:e,reject:t}}));this.fill(),await e}fill(){if(this.path.peersToQuery)for(;this.queue.pending+this.queue.size0;){const e=this.path.peersToQuery.dequeue();this.queuedPeerIds.add(e),this.queue.add((()=>this.processNext(e).catch((e=>{this.log.error("queue",e),this.stop(e)})).finally((()=>{this.queuedPeerIds.delete(e)}))))}}async processNext(e){if(!this.running)return;if(this.run.peersSeen.has(e.toB58String()))return;let t,r,i,n;try{t=await this.run.continueQuerying(this)}catch(e){r=e}if(this.running){if(r)throw r;if(t){if(!this.run.peersSeen.has(e.toB58String())){this.run.peersSeen.add(e.toB58String()),this.log("queue:work");try{i=await this.execQuery(e)}catch(e){n=e}if(this.running){if(this.log("queue:work:done",n,i),n)throw n;if(i&&i.queryComplete)return this.log("query:complete"),void this.run.stop();i&&i.pathComplete&&this.stop()}}}else this.stop()}}async execQuery(e){let t,r;try{t=await this.path.queryFunc(e)}catch(e){r=e}if(this.running)if(r)this.run.errors.push(r);else if(this.run.peersQueried&&await this.run.peersQueried.add(e),t){if(t.pathComplete||t.queryComplete)return this.path.res=t,{pathComplete:t.pathComplete,queryComplete:t.queryComplete};if(t.closerPeers&&t.closerPeers.length>0){const e=async e=>{this.dht._isSelf(e.id)||(this.dht._peerDiscovered(e.id,e.multiaddrs),await this.path.addPeerToQuery(e.id))};await Promise.all(t.closerPeers.map(e))}}}}},{"p-queue":"biPlv"}],bDSmy:[function(e,t,r){"use strict";const i=e("err-code"),n=e("p-timeout"),s=e("../constants"),o=e("../peer-list/limited-peer-list"),a=e("../message"),c=e("../query"),u=e("../utils");t.exports=e=>({async provide(t){e._log(`provide: ${t}`);const r=[];await e.providers.addProvider(t,e.peerId);const n=e.libp2p?e.libp2p.multiaddrs:[],s=new a(a.TYPES.ADD_PROVIDER,t.bytes,0);if(s.providerPeers=[{id:e.peerId,multiaddrs:n}],await u.mapParallel(e.getClosestPeers(t.bytes),(async function(i){e._log(`putProvider ${t} to ${i.toB58String()}`);try{await e.network.sendMessage(i,s)}catch(e){r.push(e)}})),r.length)throw i(new Error(`Failed to provide to ${r.length} of ${e.kBucketSize} peers`),"ERR_SOME_PROVIDES_FAILED",{errors:r})},async*findProviders(t,r={timeout:6e4,maxNumProviders:5}){const i=r.timeout||s.minute,l=r.maxNumProviders||s.K;e._log(`findProviders ${t}`);const d=new o(l);if((await e.providers.getProviders(t)).forEach((t=>{const r=e.peerStore.get(t);r?d.push({id:r.id,multiaddrs:r.addresses.map((e=>e.multiaddr))}):d.push({id:t,multiaddrs:[]})})),d.length>=l){for(const e of d.toArray())yield e;return}const f=[];const h=new c(e,t.bytes,(function(r,i){const n=u.pathSize(l-d.length,i),s=new o(n);return f.push(s),async function(r){const i=await(async(t,r)=>{const i=new a(a.TYPES.GET_PROVIDERS,r.bytes,0);return e.network.sendRequest(t,i)})(r,t),o=i.providerPeers;return e._log(`Found ${o.length} provider entries for ${t}`),o.forEach((e=>{s.push({...e})})),s.length>=n?{pathComplete:!0}:{closerPeers:i.closerPeers}}})),p=e.routingTable.closestPeers(t.bytes,e.kBucketSize);try{await n(h.run(p),i)}catch(e){if(e.name!==n.TimeoutError.name)throw e}finally{h.stop()}f.forEach((e=>{e.toArray().forEach((e=>{d.push(e)}))}));for(const e of d.toArray())yield e}})},{"err-code":"chZjB","p-timeout":"hP9Ay","../constants":"4YMVW","../peer-list/limited-peer-list":"lGgEB","../message":"dWtGc","../query":"jOM9h","../utils":"eTk1n"}],lGgEB:[function(e,t,r){"use strict";const i=e(".");t.exports=class extends i{constructor(e){super(),this.limit=e}push(e){return this.lengtht.id.equals(e)));return Boolean(t)}toArray(){return this.list.slice()}pop(){return this.list.pop()}get length(){return this.list.length}}},{}],nezkB:[function(e,t,r){"use strict";const i=e("err-code"),n=e("p-timeout"),s=e("peer-id"),o=e("libp2p-crypto"),{toString:a}=e("uint8arrays/to-string"),c=e("../constants"),u=e("../message"),l=e("../query"),d=e("../utils");t.exports=e=>{const t=async t=>{const r=d.keyForPublicKey(t),n=await(async(t,r)=>{const i=new u(u.TYPES.GET_VALUE,r,0);return e.network.sendRequest(t,i)})(t,r);if(!n.record||!n.record.value)throw i(new Error(`Node not responding with its public key: ${t.toB58String()}`),"ERR_INVALID_RECORD");const o=await s.createFromPubKey(n.record.value);if(!o.equals(t))throw i(new Error("public key does not match id"),"ERR_PUBLIC_KEY_DOES_NOT_MATCH_ID");return o.pubKey};return{async _findPeerSingle(t,r){e._log("findPeerSingle %s",t.toB58String());const i=new u(u.TYPES.FIND_NODE,r.id,0);return e.network.sendRequest(t,i)},async findPeer(t,r={timeout:6e4}){r.timeout=r.timeout||c.minute,e._log("findPeer %s",t.toB58String());const s=await(async t=>{e._log(`findPeerLocal ${t.toB58String()}`);const r=await e.routingTable.find(t),i=r&&e.peerStore.get(r);if(i)return{id:i.id,multiaddrs:i.addresses.map((e=>e.multiaddr))}})(t);if(null!=s)return e._log("found local"),s;const o=await d.convertPeerId(t),a=e.routingTable.closestPeers(o,e.kBucketSize);if(0===a.length)throw i(new Error("Peer lookup failed"),"ERR_LOOKUP_FAILED");if(a.find((e=>e.isEqual(t)))){const r=e.peerStore.get(t);if(r)return e._log("found in peerStore"),{id:r.id,multiaddrs:r.addresses.map((e=>e.multiaddr))}}const u=new l(e,t.id,(()=>async e=>{const r=await this._findPeerSingle(e,t),i=r.closerPeers.find((e=>e.id.isEqual(t)));return i?{peer:i,queryComplete:!0}:{closerPeers:r.closerPeers}}));let f;try{f=await n(u.run(a),r.timeout)}finally{u.stop()}let h=!1;if(f.paths.forEach((t=>{t.success&&t.peer&&(h=!0,e.peerStore.addressBook.add(t.peer.id,t.peer.multiaddrs))})),e._log("findPeer %s: %s",t.toB58String(),h),!h)throw i(new Error("No peer found"),"ERR_NOT_FOUND");const p=e.peerStore.get(t);if(!p)throw i(new Error("No peer found in peer store"),"ERR_NOT_FOUND");return{id:p.id,multiaddrs:p.addresses.map((e=>e.multiaddr))}},async*getClosestPeers(t,r={shallow:!1}){e._log("getClosestPeers to %b",t);const i=await d.convertBuffer(t),n=e.routingTable.closestPeers(i,e.kBucketSize),o=new l(e,t,(()=>async i=>{const n=await(async(t,r)=>(e._log(`closerPeersSingle ${a(t,"base32")} from ${r.toB58String()}`),(await e.peerRouting._findPeerSingle(r,new s(t))).closerPeers.filter((t=>!e._isSelf(t.id))).map((t=>(e.peerStore.addressBook.add(t.id,t.multiaddrs),t)))))(t,i);return{closerPeers:n,pathComplete:!!r.shallow||void 0}})),c=await o.run(n);if(!c||!c.finalSet)return[];const u=await d.sortClosestPeers(Array.from(c.finalSet),i);for(const t of u.slice(0,e.kBucketSize))yield t},async getPublicKey(r){e._log("getPublicKey %s",r.toB58String());const i=e.peerStore.get(r);if(i&&i.id.pubKey)return e._log("getPublicKey: found local copy"),i.id.pubKey;let n;try{n=await t(r)}catch(t){const i=d.keyForPublicKey(r),s=await e.get(i);n=o.keys.unmarshalPublicKey(s)}const a=new s(r.id,void 0,n),c=(i&&i.addresses||[]).map((e=>e.multiaddr));return e.peerStore.addressBook.add(a,c),e.peerStore.keyBook.set(a,n),n}}}},{"err-code":"chZjB","p-timeout":"hP9Ay","peer-id":"8Bdb3","libp2p-crypto":"bb1cb","uint8arrays/to-string":"hC8JB","../constants":"4YMVW","../message":"dWtGc","../query":"jOM9h","../utils":"eTk1n"}],lunE9:[function(e,t,r){"use strict";const i=e("hashlru"),n=e("varint"),s=e("peer-id"),{Key:o}=e("interface-datastore/key"),{default:a}=e("p-queue"),c=e("./constants"),u=e("./utils");function l(e){return e="string"==typeof e?e:u.encodeBase32(e.bytes),c.PROVIDERS_KEY_PREFIX+e}function d(e){const t=e.toString().split("/");if(4!==t.length)throw new Error("incorrectly formatted provider entry key in datastore: "+e);return{cid:t[2],peerId:t[3]}}function f(e){return n.decode(e)}t.exports=class{constructor(e,t,r){this.datastore=e,this._log=u.logger(t,"providers"),this.cleanupInterval=c.PROVIDERS_CLEANUP_INTERVAL,this.provideValidity=c.PROVIDERS_VALIDITY,this.lruCacheSize=r||c.PROVIDERS_LRU_CACHE_SIZE,this.providers=i(this.lruCacheSize),this.syncQueue=new a({concurrency:1})}start(){this._started||(this._started=!0,this._cleaner=setInterval((()=>this._cleanup()),this.cleanupInterval))}stop(){this._started=!1,this._cleaner&&(clearInterval(this._cleaner),this._cleaner=null)}_cleanup(){return this.syncQueue.add((async()=>{this._log("start cleanup");const e=Date.now();let t=0,r=0;const i=new Map,n=this.datastore.batch(),s=this.datastore.query({prefix:c.PROVIDERS_KEY_PREFIX});for await(const e of s)try{const{cid:s,peerId:o}=d(e.key),a=f(e.value),c=Date.now(),u=c-a,l=u>this.provideValidity;if(this._log("comparing: %d - %d = %d > %d %s",c,a,u,this.provideValidity,l?"(expired)":""),l){r++,n.delete(e.key);const t=i.get(s)||new Set;t.add(o),i.set(s,t)}t++}catch(e){this._log.error(e.message)}this._log("deleting %d / %d entries",r,t),i.size&&await n.commit();for(const[e,t]of i){const r=l(e),i=this.providers.get(r);if(i){for(const e of t)i.delete(e);0===i.size?this.providers.remove(r):this.providers.set(r,i)}}this._log("Cleanup successful (%dms)",Date.now()-e)}))}async _getProvidersMap(e){const t=l(e);let r=this.providers.get(t);return r||(r=await async function(e,t){const r=new Map,i=e.query({prefix:l(t)});for await(const e of i){const{peerId:t}=d(e.key);r.set(t,f(e.value))}return r}(this.datastore,e),this.providers.set(t,r)),r}async addProvider(e,t){return this.syncQueue.add((async()=>{this._log("addProvider %s",e.toString());const r=await this._getProvidersMap(e);this._log("loaded %s provs",r.size);const i=new Date;r.set(u.encodeBase32(t.id),i);const s=l(e);return this.providers.set(s,r),async function(e,t,r,i){const s=[l(t),"/",u.encodeBase32(r.id)].join(""),a=new o(s),c=Uint8Array.from(n.encode(i.getTime()));return e.put(a,c)}(this.datastore,e,t,i)}))}async getProviders(e){return this.syncQueue.add((async()=>{this._log("getProviders %s",e.toString());return[...(await this._getProvidersMap(e)).keys()].map((e=>new s(u.decodeBase32(e))))}))}}},{hashlru:"kBj5c",varint:"aN1CO","peer-id":"8Bdb3","interface-datastore/key":"9hGOz","p-queue":"biPlv","./constants":"4YMVW","./utils":"eTk1n"}],"9th0A":[function(e,t,r){"use strict";t.exports=class{constructor(){this.queries=new Set,this.running=!1}queryStarted(e){this.queries.add(e)}queryCompleted(e){this.queries.delete(e)}start(){this.running=!0}stop(){this.running=!1;for(const e of this.queries)e.stop();this.queries.clear()}}},{}],"2X3ZY":[function(e,t,r){"use strict";function i(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("ipns"));const s={func:(e,t)=>n.validator.validate(t,e)};r.selector=function(e,t){return n.validator.select(t[0],t[1])},r.validator=s},{ipns:"7rNAT"}],hla2J:[function(e,t,r){"use strict";const i=e("peer-id"),{Multiaddr:n}=e("multiaddr"),s=e("mafmt"),{EventEmitter:o}=e("events"),a=e("debug"),c=Object.assign(a("libp2p:bootstrap"),{error:a("libp2p:bootstrap:error")});(t.exports=class extends o{constructor(e={list:[]}){if(!e.list||!e.list.length)throw new Error("Bootstrap requires a list of peer addresses");super(),this._list=e.list,this._interval=e.interval||1e4,this._timer=null}start(){this._timer||(this._timer=setInterval((()=>this._discoverBootstrapPeers()),this._interval),c("Starting bootstrap node discovery"),this._discoverBootstrapPeers())}_discoverBootstrapPeers(){this._timer&&this._list.forEach((e=>{if(!s.P2P.matches(e))return c.error("Invalid multiaddr");const t=new n(e),r=t.getPeerId();if(!r)return void c.error("Invalid bootstrap multiaddr without peer id");const o=i.createFromB58String(r);try{this.emit("peer",{id:o,multiaddrs:[t]})}catch(e){c.error("Invalid bootstrap peer id",e)}}))}stop(){this._timer&&clearInterval(this._timer),this._timer=null}}).tag="bootstrap"},{"peer-id":"8Bdb3",multiaddr:"8Mu1u",mafmt:"l1lok",events:"g82pp",debug:"bO5wM"}],"757Qe":[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p"),{error:i("libp2p:err")}),{EventEmitter:s}=e("events"),o=e("err-code"),a=e("peer-id"),{Multiaddr:c}=e("multiaddr"),u=e("./peer-routing"),l=e("./content-routing"),d=e("./get-peer"),{validate:f}=e("./config"),{codes:h,messages:p}=e("./errors"),g=e("./address-manager"),y=e("./connection-manager"),m=e("./circuit/transport"),b=e("./circuit"),v=e("./dialer"),w=e("./keychain"),_=e("./metrics"),E=e("./transport-manager"),S=e("./upgrader"),T=e("./peer-store"),A=e("./pubsub-adapter"),k=e("./peer-store/persistent"),I=e("./registrar"),R=e("./ping"),P=e("./identify"),O=e("./nat-manager"),{updateSelfPeerRecord:C}=e("./record/utils");class j extends s{static async create(e){if(e.peerId)return new j(e);const t=await a.create();return e.peerId=t,new j(e)}constructor(e){if(super(),this._options=f(e),this.peerId=this._options.peerId,this.datastore=this._options.datastore,this.peerStore=this.datastore&&this._options.peerStore.persistence?new k({peerId:this.peerId,datastore:this.datastore,...this._options.peerStore}):new T({peerId:this.peerId}),this.addresses=this._options.addresses,this.addressManager=new g(this.peerId,this._options.addresses),this.addressManager.on("change:addresses",(()=>{C(this).catch((e=>{n.error("Error updating self peer record",e)}))})),this._modules=this._options.modules,this._config=this._options.config,this._transport=[],this._discovery=new Map,this.connectionManager=new y(this,{autoDial:this._config.peerDiscovery.autoDial,...this._options.connectionManager}),this._options.metrics.enabled&&(this.metrics=new _({...this._options.metrics,connectionManager:this.connectionManager})),this._options.keychain&&this._options.keychain.datastore){n("creating keychain");const e=w.generateOptions();this.keychain=new w(this._options.keychain.datastore,{...e,...this._options.keychain}),n("keychain constructed")}if(this.upgrader=new S({localPeer:this.peerId,metrics:this.metrics,onConnection:e=>this.connectionManager.onConnect(e),onConnectionEnd:e=>this.connectionManager.onDisconnect(e)}),this.transportManager=new E({libp2p:this,upgrader:this.upgrader,faultTolerance:this._options.transportManager.faultTolerance}),this.natManager=new O({peerId:this.peerId,addressManager:this.addressManager,transportManager:this.transportManager,...this._options.config.nat}),this.registrar=new I({peerStore:this.peerStore,connectionManager:this.connectionManager}),this.handle=this.handle.bind(this),this.registrar.handle=this.handle,!this._modules.connEncryption||!this._modules.connEncryption.length)throw o(new Error(p.CONN_ENCRYPTION_REQUIRED),h.CONN_ENCRYPTION_REQUIRED);if(this._modules.connEncryption.forEach((e=>{this.upgrader.cryptos.set(e.protocol,e)})),this.dialer=new v({transportManager:this.transportManager,peerStore:this.peerStore,...this._options.dialer}),this._modules.transport.forEach((e=>{const t=e.prototype[Symbol.toStringTag],r=this._config.transport[t];this.transportManager.add(t,e,r)})),this._config.relay.enabled&&(this.transportManager.add(m.prototype[Symbol.toStringTag],m),this.relay=new b(this)),this._modules.streamMuxer){this._modules.streamMuxer.forEach((e=>{this.upgrader.muxers.set(e.multicodec,e)})),this.identifyService=new P({libp2p:this}),this.handle(Object.values(P.getProtocolStr(this)),this.identifyService.handleMessage)}if(this._modules.connProtector)this.upgrader.protector=this._modules.connProtector;else if(void 0!==globalThis.process&&globalThis.process.env&&globalThis.process.env.LIBP2P_FORCE_PNET)throw new Error("Private network is enforced, but no protector was provided");if(this._modules.dht){const e=this._modules.dht;this._dht=new e({libp2p:this,dialer:this.dialer,peerId:this.peerId,peerStore:this.peerStore,registrar:this.registrar,datastore:this.datastore,...this._config.dht})}if(this._modules.pubsub){const e=this._modules.pubsub;this.pubsub=A(e,this,this._config.pubsub)}this.peerRouting=new u(this),this.contentRouting=new l(this),R.mount(this),this._onDiscoveryPeer=this._onDiscoveryPeer.bind(this)}emit(e,...t){return"error"!==e||this._events.error?super.emit(e,...t):(n.error(t),!1)}async start(){n("libp2p is starting");try{await this._onStarting(),await this._onDidStart(),n("libp2p has started")}catch(e){throw this.emit("error",e),n.error("An error occurred starting libp2p",e),await this.stop(),e}}async stop(){n("libp2p is stopping");try{this._isStarted=!1,this.relay&&this.relay.stop(),this.peerRouting.stop();for(const e of this._discovery.values())e.removeListener("peer",this._onDiscoveryPeer);await Promise.all(Array.from(this._discovery.values(),(e=>e.stop()))),this._discovery=new Map,await this.peerStore.stop(),await this.connectionManager.stop(),await Promise.all([this.pubsub&&this.pubsub.stop(),this._dht&&this._dht.stop(),this.metrics&&this.metrics.stop()]),await this.natManager.stop(),await this.transportManager.close(),R.unmount(this),this.dialer.destroy()}catch(e){e&&(n.error(e),this.emit("error",e))}n("libp2p has stopped")}async loadKeychain(){if(this.keychain)try{await this.keychain.findKeyByName("self")}catch(e){await this.keychain.importPeer("self",this.peerId)}}isStarted(){return this._isStarted}get connections(){return this.connectionManager.connections}dial(e,t){return this._dial(e,t)}async dialProtocol(e,t,r){if(!t||!t.length)throw o(new Error("no protocols were provided to open a stream"),h.ERR_INVALID_PROTOCOLS_FOR_STREAM);return(await this._dial(e,r)).newStream(t)}async _dial(e,t){const{id:r,multiaddrs:i}=d(e);if(r.equals(this.peerId))throw o(new Error("Cannot dial self"),h.ERR_DIALED_SELF);let n=this.connectionManager.get(r);return n?i&&this.peerStore.addressBook.add(r,i):n=await this.dialer.connectToPeer(e,t),n}get multiaddrs(){let e=this.addressManager.getAnnounceAddrs().map((e=>e.toString()));e.length||(e=this.transportManager.getAddrs().map((e=>e.toString()))),e=e.concat(this.addressManager.getObservedAddrs().map((e=>e.toString())));const t=this._options.addresses.announceFilter,r=new Set(e);return t(Array.from(r).map((e=>new c(e))))}async hangUp(e){const{id:t}=d(e),r=this.connectionManager.connections.get(t.toB58String());r&&await Promise.all(r.map((e=>e.close())))}ping(e){const{id:t,multiaddrs:r}=d(e);return R(this,r?r[0]:t)}handle(e,t){(e=Array.isArray(e)?e:[e]).forEach((e=>{this.upgrader.protocols.set(e,t)})),this.peerStore.protoBook.add(this.peerId,e)}unhandle(e){(e=Array.isArray(e)?e:[e]).forEach((e=>{this.upgrader.protocols.delete(e)})),this.peerStore.protoBook.remove(this.peerId,e)}async _onStarting(){const e=this.addressManager.getListenAddrs();await this.transportManager.listen(e),this.natManager.start(),await this.peerStore.start(),this._config.pubsub.enabled&&this.pubsub&&this.pubsub.start(),this._config.dht.enabled&&(this._dht&&this._dht.start(),this._dht.on("peer",this._onDiscoveryPeer)),this.metrics&&this.metrics.start()}async _onDidStart(){this._isStarted=!0,this.peerStore.on("peer",(e=>{this.emit("peer:discovery",e),this._maybeConnect(e)}));for(const e of this.peerStore.peers.values())this.emit("peer:discovery",e.id);this.connectionManager.start(),await this._setupPeerDiscovery(),this.relay&&this.relay.start(),this.peerRouting.start()}_onDiscoveryPeer(e){e.id.toB58String()!==this.peerId.toB58String()?(e.multiaddrs&&this.peerStore.addressBook.add(e.id,e.multiaddrs),e.protocols&&this.peerStore.protoBook.set(e.id,e.protocols)):n.error(new Error(h.ERR_DISCOVERED_SELF))}async _maybeConnect(e){if(!0===this._config.peerDiscovery.autoDial&&!this.connectionManager.get(e)){if((this._options.connectionManager.minConnections||0)>this.connectionManager.size){n("connecting to discovered peer %s",e.toB58String());try{await this.dialer.connectToPeer(e)}catch(t){n.error(`could not connect to discovered peer ${e.toB58String()} with ${t}`)}}}}async _setupPeerDiscovery(){const e=e=>{let t={enabled:!0};if(e.tag&&this._config.peerDiscovery&&this._config.peerDiscovery[e.tag]&&(t={...t,...this._config.peerDiscovery[e.tag]}),t.enabled&&!this._discovery.has(e.tag)){let r;r="function"==typeof e?new e(Object.assign({},t,{peerId:this.peerId,libp2p:this})):e,r.on("peer",this._onDiscoveryPeer),this._discovery.set(e.tag,r)}};for(const t of this._modules.peerDiscovery||[])e(t);for(const t of this.transportManager.getTransports())t.discovery&&e(t.discovery);await Promise.all(Array.from(this._discovery.values(),(e=>e.start())))}}t.exports=j},{debug:"bO5wM",events:"g82pp","err-code":"chZjB","peer-id":"8Bdb3",multiaddr:"8Mu1u","./peer-routing":"6b8mM","./content-routing":"hrRcA","./get-peer":"39nOe","./config":"aC5Bt","./errors":"3rNo5","./address-manager":"8bdzg","./connection-manager":"bZLZf","./circuit/transport":"2UjYE","./circuit":"hBCQx","./dialer":"kwWEi","./keychain":"f4Pg5","./metrics":"jy74B","./transport-manager":"7AeM0","./upgrader":"fdRaE","./peer-store":"hDFM8","./pubsub-adapter":"4AHRd","./peer-store/persistent":"kcKey","./registrar":"bUUbk","./ping":"azCOK","./identify":"jPbT6","./nat-manager":"1LCyC","./record/utils":"7dy3Z"}],"6b8mM":[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:peer-routing"),{error:i("libp2p:peer-routing:err")}),s=e("err-code"),{storeAddresses:o,uniquePeers:a,requirePeers:c}=e("./content-routing/utils"),u=e("it-merge"),{pipe:l}=e("it-pipe"),d=e("it-first"),f=e("it-drain"),h=e("it-filter"),{setDelayedInterval:p,clearDelayedInterval:g}=e("set-delayed-interval");t.exports=class{constructor(e){this._peerId=e.peerId,this._peerStore=e.peerStore,this._routers=e._modules.peerRouting||[],e._dht&&e._config.dht.enabled&&this._routers.push(e._dht),this._refreshManagerOptions=e._options.peerRouting.refreshManager,this._findClosestPeersTask=this._findClosestPeersTask.bind(this)}start(){this._routers.length&&!this._timeoutId&&this._refreshManagerOptions.enabled&&(this._timeoutId=p(this._findClosestPeersTask,this._refreshManagerOptions.interval,this._refreshManagerOptions.bootDelay))}async _findClosestPeersTask(){try{await f(this.getClosestPeers(this._peerId.id))}catch(e){n.error(e)}}stop(){g(this._timeoutId)}async findPeer(e,t){if(!this._routers.length)throw s(new Error("No peer routers available"),"NO_ROUTERS_AVAILABLE");if(e.toB58String()===this._peerId.toB58String())throw s(new Error("Should not try to find self"),"ERR_FIND_SELF");const r=await l(u(...this._routers.map((r=>[r.findPeer(e,t)]))),(e=>h(e,Boolean)),(e=>o(e,this._peerStore)),(e=>d(e)));if(r)return r;throw s(new Error("not found"),"NOT_FOUND")}async*getClosestPeers(e,t={timeout:3e4}){if(!this._routers.length)throw s(new Error("No peer routers available"),"NO_ROUTERS_AVAILABLE");yield*l(u(...this._routers.map((r=>r.getClosestPeers(e,t)))),(e=>o(e,this._peerStore)),(e=>a(e)),(e=>c(e)))}}},{debug:"bO5wM","err-code":"chZjB","./content-routing/utils":"5SdWt","it-merge":"cPFu3","it-pipe":"giKBQ","it-first":"hBrkP","it-drain":"dKYhO","it-filter":"5LCTL","set-delayed-interval":"4OF34"}],"5SdWt":[function(e,t,r){"use strict";const i=e("err-code"),n=e("it-filter"),s=e("it-map"),o=e("it-take");t.exports={storeAddresses:function(e,t){return s(e,(e=>(t.addressBook.add(e.id,e.multiaddrs),e)))},uniquePeers:function(e){const t=new Set;return n(e,(e=>!t.has(e.id.toString())&&(t.add(e.id.toString()),!0)))},requirePeers:async function*(e,t=1){let r=0;for await(const t of e)r++,yield t;if(r{!async function(e,t,r){for(;i.get(r);){try{await e()}catch(e){setTimeout((()=>{throw e}),1);break}if(!i.get(r))break;await new Promise((e=>{const n=setTimeout(e,t);i.set(r,n)}))}}(e,t,n)}),r);return i.set(n,s),n},clearDelayedInterval:function(e){const t=i.get(e);t&&(clearTimeout(t),i.delete(e))}}},{}],hrRcA:[function(e,t,r){"use strict";const i=e("err-code"),{messages:n,codes:s}=e("../errors"),{storeAddresses:o,uniquePeers:a,requirePeers:c,maybeLimitSource:u}=e("./utils"),l=e("it-merge"),{pipe:d}=e("it-pipe");t.exports=class{constructor(e){this.libp2p=e,this.routers=e._modules.contentRouting||[],this.dht=e._dht,this.dht&&e._config.dht.enabled&&this.routers.push(this.dht)}async*findProviders(e,t={}){if(!this.routers.length)throw i(new Error("No content this.routers available"),"NO_ROUTERS_AVAILABLE");yield*d(l(...this.routers.map((r=>r.findProviders(e,t)))),(e=>o(e,this.libp2p.peerStore)),(e=>a(e)),(e=>u(e,t.maxNumProviders)),(e=>c(e)))}async provide(e){if(!this.routers.length)throw i(new Error("No content routers available"),"NO_ROUTERS_AVAILABLE");await Promise.all(this.routers.map((t=>t.provide(e))))}put(e,t,r){if(!this.libp2p.isStarted()||!this.dht.isStarted)throw i(new Error(n.NOT_STARTED_YET),s.DHT_NOT_STARTED);return this.dht.put(e,t,r)}get(e,t){if(!this.libp2p.isStarted()||!this.dht.isStarted)throw i(new Error(n.NOT_STARTED_YET),s.DHT_NOT_STARTED);return this.dht.get(e,t)}async getMany(e,t,r){if(!this.libp2p.isStarted()||!this.dht.isStarted)throw i(new Error(n.NOT_STARTED_YET),s.DHT_NOT_STARTED);return this.dht.getMany(e,t,r)}}},{"err-code":"chZjB","../errors":"3rNo5","./utils":"5SdWt","it-merge":"cPFu3","it-pipe":"giKBQ"}],"39nOe":[function(e,t,r){"use strict";const i=e("peer-id"),{Multiaddr:n}=e("multiaddr"),s=e("err-code"),{codes:o}=e("./errors");t.exports=function(e){let t;if("string"==typeof e&&(e=new n(e)),n.isMultiaddr(e)){t=e;const r=e.getPeerId();if(!r)throw s(new Error(`${e} does not have a valid peer type`),o.ERR_INVALID_MULTIADDR);try{e=i.createFromB58String(r)}catch(t){throw s(new Error(`${e} is not a valid peer type`),o.ERR_INVALID_MULTIADDR)}}return{id:e,multiaddrs:t?[t]:void 0}}},{"peer-id":"8Bdb3",multiaddr:"8Mu1u","err-code":"chZjB","./errors":"3rNo5"}],aC5Bt:[function(e,t,r){"use strict";const i=e("merge-options"),{dnsaddrResolver:n}=e("multiaddr/src/resolvers"),s=e("./constants"),{AGENT_VERSION:o}=e("./identify/consts"),a=e("./circuit/constants"),{publicAddressesFirst:c}=e("libp2p-utils/src/address-sort"),{FaultTolerance:u}=e("./transport-manager"),l={addresses:{listen:[],announce:[],noAnnounce:[],announceFilter:e=>e},connectionManager:{minConnections:25},transportManager:{faultTolerance:u.FATAL_ALL},dialer:{maxParallelDials:s.MAX_PARALLEL_DIALS,maxDialsPerPeer:s.MAX_PER_PEER_DIALS,dialTimeout:s.DIAL_TIMEOUT,resolvers:{dnsaddr:n},addressSorter:c},host:{agentVersion:o},metrics:{enabled:!1},peerStore:{persistence:!1,threshold:5},peerRouting:{refreshManager:{enabled:!0,interval:6e5,bootDelay:1e4}},config:{protocolPrefix:"ipfs",dht:{enabled:!1,kBucketSize:20,randomWalk:{enabled:!1,queriesPerPeriod:1,interval:3e5,timeout:1e4}},nat:{enabled:!0,ttl:7200,keepAlive:!0,gateway:null,externalIp:null,pmp:{enabled:!1}},peerDiscovery:{autoDial:!0},pubsub:{enabled:!0},relay:{enabled:!0,advertise:{bootDelay:a.ADVERTISE_BOOT_DELAY,enabled:!1,ttl:a.ADVERTISE_TTL},hop:{enabled:!1,active:!1},autoRelay:{enabled:!1,maxListeners:2}},transport:{}}};t.exports.validate=e=>{const t=i(l,e);if(t.modules.transport.length<1)throw new Error("'options.modules.transport' must contain at least 1 transport");return t}},{"merge-options":"fupyv","multiaddr/src/resolvers":"gzxe3","./constants":"92Vak","./identify/consts":"62PhM","./circuit/constants":"eXVcE","libp2p-utils/src/address-sort":"5uTJL","./transport-manager":"7AeM0"}],gzxe3:[function(e,t,r){"use strict";const i=e("../protocols-table"),{code:n}=i("dnsaddr");t.exports={dnsaddrResolver:async function(t){const r=new(e("./dns")),i=t.getPeerId(),[,s]=t.stringTuples().find((([e])=>e===n))||[];let o=(await r.resolveTxt(`_dnsaddr.${s}`)).flat().map((e=>e.split("=")[1]));return i&&(o=o.filter((e=>e.includes(i)))),o}}},{"../protocols-table":"5Z4cQ","./dns":"6yz41"}],"6yz41":[function(e,t,r){"use strict";const i=e("dns-over-http-resolver");t.exports=i},{"dns-over-http-resolver":"9Glvu"}],"9Glvu":[function(e,t,r){"use strict";const i=e("debug"),n=i("dns-over-http-resolver");n.error=i("dns-over-http-resolver:error");const s=e("receptacle"),o=e("./utils");class a{constructor({maxCache:e=100}={}){this._cache=new s({max:e}),this._servers=["https://cloudflare-dns.com/dns-query","https://dns.google/resolve"]}getServers(){return this._servers}_getShuffledServers(){const e=[].concat(this._servers);for(let t=e.length-1;t>0;t--){const r=Math.floor(Math.random()*t),i=e[t];e[t]=e[r],e[r]=i}return e}setServers(e){this._servers=e}resolve(e,t="A"){switch(t){case"A":return this.resolve4(e);case"AAAA":return this.resolve6(e);case"TXT":return this.resolveTxt(e);default:throw new Error(`${t} is not supported`)}}async resolve4(e){const t="A",r=this._cache.get(o.getCacheKey(e,t));if(r)return r;for(const r of this._getShuffledServers())try{const i=await o.fetch(o.buildResource({serverResolver:r,hostname:e,recordType:t})),n=await i.json(),s=n.Answer.map((e=>e.data)),a=Math.min(n.Answer.map((e=>e.TTL)));return this._cache.set(o.getCacheKey(e,t),s,{ttl:a}),s}catch(t){n.error(`${r} could not resolve ${e} record A`)}throw new Error(`Could not resolve ${e} record A`)}async resolve6(e){const t="AAAA",r=this._cache.get(o.getCacheKey(e,t));if(r)return r;for(const r of this._getShuffledServers())try{const i=await o.fetch(o.buildResource({serverResolver:r,hostname:e,recordType:t})),n=await i.json(),s=n.Answer.map((e=>e.data)),a=Math.min(n.Answer.map((e=>e.TTL)));return this._cache.set(o.getCacheKey(e,t),s,{ttl:a}),s}catch(t){n.error(`${r} could not resolve ${e} record AAAA`)}throw new Error(`Could not resolve ${e} record AAAA`)}async resolveTxt(e){const t="TXT",r=this._cache.get(o.getCacheKey(e,t));if(r)return r;for(const r of this._getShuffledServers())try{const i=await o.fetch(o.buildResource({serverResolver:r,hostname:e,recordType:t})),n=await i.json(),s=n.Answer.map((e=>[e.data.replace(/['"]+/g,"")])),a=Math.min(n.Answer.map((e=>e.TTL)));return this._cache.set(o.getCacheKey(e,t),s,{ttl:a}),s}catch(t){n.error(`${r} could not resolve ${e} record TXT`)}throw new Error(`Could not resolve ${e} record TXT`)}}a.Resolver=a,t.exports=a},{debug:"bO5wM",receptacle:"6A2bX","./utils":"jAL77"}],"6A2bX":[function(e,t,r){"use strict";t.exports=o;var i=e("ms"),n=o.prototype,s=new Date%1e9;function o(e){e=e||{},this.id=e.id||(1e9*Math.random()>>>0)+s++,this.max=e.max||1/0,this.items=e.items||[],this._lookup={},this.size=this.items.length,this.lastModified=new Date(e.lastModified||new Date);for(var t,r,i=this.items.length;i--;)t=this.items[i],r=new Date(t.expires)-new Date,this._lookup[t.key]=t,r>0?this.expire(t.key,r):r<=0&&this.delete(t.key)}n.has=function(e){return e in this._lookup},n.get=function(e){if(!this.has(e))return null;var t=this._lookup[e];return t.refresh&&this.expire(e,t.refresh),this.items.splice(this.items.indexOf(t),1),this.items.push(t),t.value},n.meta=function(e){if(!this.has(e))return null;var t=this._lookup[e];return"meta"in t?t.meta:null},n.set=function(e,t,r){var i=this._lookup[e],n=this._lookup[e]={key:e,value:t};return this.lastModified=new Date,i?(clearTimeout(i.timeout),this.items.splice(this.items.indexOf(i),1,n)):(this.size>=this.max&&this.delete(this.items[0].key),this.items.push(n),this.size++),r&&("ttl"in r&&this.expire(e,r.ttl),"meta"in r&&(n.meta=r.meta),r.refresh&&(n.refresh=r.ttl)),this},n.delete=function(e){var t=this._lookup[e];return!!t&&(this.lastModified=new Date,this.items.splice(this.items.indexOf(t),1),clearTimeout(t.timeout),delete this._lookup[e],this.size--,this)},n.expire=function(e,t){var r=t||0,n=this._lookup[e];if(!n)return this;if("string"==typeof r&&(r=i(t)),"number"!=typeof r)throw new TypeError("Expiration time must be a string or number.");return clearTimeout(n.timeout),n.timeout=setTimeout(this.delete.bind(this,n.key),r),n.expires=Number(new Date)+r,this},n.clear=function(){for(var e=this.items.length;e--;)this.delete(this.items[e].key);return this},n.toJSON=function(){for(var e,t=new Array(this.items.length),r=t.length;r--;)e=this.items[r],t[r]={key:e.key,meta:e.meta,value:e.value,expires:e.expires,refresh:e.refresh};return{id:this.id,max:isFinite(this.max)?this.max:void 0,lastModified:this.lastModified,items:t}}},{ms:"kjKOC"}],kjKOC:[function(e,t,r){var i=1e3,n=60*i,s=60*n,o=24*s,a=7*o,c=365.25*o;function u(e,t,r,i){var n=t>=1.5*r;return Math.round(e/r)+" "+i+(n?"s":"")}t.exports=function(e,t){t=t||{};var r,l,d=typeof e;if("string"===d&&e.length>0)return function(e){if((e=String(e)).length>100)return;var t=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(e);if(!t)return;var r=parseFloat(t[1]);switch((t[2]||"ms").toLowerCase()){case"years":case"year":case"yrs":case"yr":case"y":return r*c;case"weeks":case"week":case"w":return r*a;case"days":case"day":case"d":return r*o;case"hours":case"hour":case"hrs":case"hr":case"h":return r*s;case"minutes":case"minute":case"mins":case"min":case"m":return r*n;case"seconds":case"second":case"secs":case"sec":case"s":return r*i;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return r;default:return}}(e);if("number"===d&&isFinite(e))return t.long?(r=e,(l=Math.abs(r))>=o?u(r,l,o,"day"):l>=s?u(r,l,s,"hour"):l>=n?u(r,l,n,"minute"):l>=i?u(r,l,i,"second"):r+" ms"):function(e){var t=Math.abs(e);return t>=o?Math.round(e/o)+"d":t>=s?Math.round(e/s)+"h":t>=n?Math.round(e/n)+"m":t>=i?Math.round(e/i)+"s":e+"ms"}(e);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(e))}},{}],jAL77:[function(e,t,r){"use strict";const{default:i,Headers:n}=e("native-fetch");t.exports={buildResource:function({serverResolver:e,hostname:t,recordType:r}){return`${e}?name=${t}&type=${r}`},fetch:function(e){return i(e,{headers:new n({accept:"application/dns-json"})})},getCacheKey:function(e,t){return`${t}_${e}`}}},{"native-fetch":"kdks4"}],"92Vak":[function(e,t,r){"use strict";t.exports={DIAL_TIMEOUT:3e4,MAX_PARALLEL_DIALS:100,MAX_PER_PEER_DIALS:4,MAX_ADDRS_TO_DIAL:25,METRICS:{computeThrottleMaxQueueSize:1e3,computeThrottleTimeout:2e3,movingAverageIntervals:[6e4,3e5,9e5],maxOldPeersRetention:50}}},{}],"62PhM":[function(e,t,r){"use strict";const i=e("../../package.json").version;t.exports.PROTOCOL_VERSION="ipfs/0.1.0",t.exports.AGENT_VERSION=`js-libp2p/${i}`,t.exports.MULTICODEC_IDENTIFY="/ipfs/id/1.0.0",t.exports.MULTICODEC_IDENTIFY_PUSH="/ipfs/id/push/1.0.0",t.exports.IDENTIFY_PROTOCOL_VERSION="0.1.0",t.exports.MULTICODEC_IDENTIFY_PROTOCOL_NAME="id",t.exports.MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME="id/push",t.exports.MULTICODEC_IDENTIFY_PROTOCOL_VERSION="1.0.0",t.exports.MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION="1.0.0"},{"../../package.json":"cq0b4"}],cq0b4:[function(e,t,r){t.exports=JSON.parse('{"name":"libp2p","version":"0.33.0","description":"JavaScript implementation of libp2p, a modular peer to peer network stack","leadMaintainer":"Jacob Heun ","main":"src/index.js","types":"dist/src/index.d.ts","typesVersions":{"*":{"src/*":["dist/src/*","dist/src/*/index"]}},"files":["dist","src"],"scripts":{"lint":"aegir lint","build":"aegir build","build:proto":"npm run build:proto:circuit && npm run build:proto:identify && npm run build:proto:plaintext && npm run build:proto:address-book && npm run build:proto:proto-book && npm run build:proto:peer-record && npm run build:proto:envelope","build:proto:circuit":"pbjs -t static-module -w commonjs -r libp2p-circuit --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/circuit/protocol/index.js ./src/circuit/protocol/index.proto","build:proto:identify":"pbjs -t static-module -w commonjs -r libp2p-identify --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/identify/message.js ./src/identify/message.proto","build:proto:plaintext":"pbjs -t static-module -w commonjs -r libp2p-plaintext --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/insecure/proto.js ./src/insecure/proto.proto","build:proto:address-book":"pbjs -t static-module -w commonjs -r libp2p-address-book --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/peer-store/persistent/pb/address-book.js ./src/peer-store/persistent/pb/address-book.proto","build:proto:proto-book":"pbjs -t static-module -w commonjs -r libp2p-proto-book --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/peer-store/persistent/pb/proto-book.js ./src/peer-store/persistent/pb/proto-book.proto","build:proto:peer-record":"pbjs -t static-module -w commonjs -r libp2p-peer-record --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/record/peer-record/peer-record.js ./src/record/peer-record/peer-record.proto","build:proto:envelope":"pbjs -t static-module -w commonjs -r libp2p-envelope --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/record/envelope/envelope.js ./src/record/envelope/envelope.proto","build:proto-types":"npm run build:proto-types:circuit && npm run build:proto-types:identify && npm run build:proto-types:plaintext && npm run build:proto-types:address-book && npm run build:proto-types:proto-book && npm run build:proto-types:peer-record && npm run build:proto-types:envelope","build:proto-types:circuit":"pbts -o src/circuit/protocol/index.d.ts src/circuit/protocol/index.js","build:proto-types:identify":"pbts -o src/identify/message.d.ts src/identify/message.js","build:proto-types:plaintext":"pbts -o src/insecure/proto.d.ts src/insecure/proto.js","build:proto-types:address-book":"pbts -o src/peer-store/persistent/pb/address-book.d.ts src/peer-store/persistent/pb/address-book.js","build:proto-types:proto-book":"pbts -o src/peer-store/persistent/pb/proto-book.d.ts src/peer-store/persistent/pb/proto-book.js","build:proto-types:peer-record":"pbts -o src/record/peer-record/peer-record.d.ts src/record/peer-record/peer-record.js","build:proto-types:envelope":"pbts -o src/record/envelope/envelope.d.ts src/record/envelope/envelope.js","test":"aegir test","test:ts":"aegir build --no-bundle && npm run test --prefix test/ts-use","test:node":"aegir test -t node -f \\"./test/**/*.{node,spec}.js\\"","test:browser":"aegir test -t browser","test:examples":"cd examples && npm run test:all","prepare":"aegir build --no-bundle","release":"aegir release -t node -t browser","release-minor":"aegir release --type minor -t node -t browser","release-major":"aegir release --type major -t node -t browser","coverage":"nyc --reporter=text --reporter=lcov npm run test:node"},"repository":{"type":"git","url":"https://github.com/libp2p/js-libp2p.git"},"keywords":["libp2p","network","p2p","peer","peer-to-peer","IPFS"],"bugs":{"url":"https://github.com/libp2p/js-libp2p/issues"},"homepage":"https://libp2p.io","license":"MIT","engines":{"node":">=14.0.0"},"browser":{"@motrix/nat-api":false},"eslintConfig":{"extends":"ipfs","ignorePatterns":["!.aegir.js","test/ts-use"]},"dependencies":{"abortable-iterator":"^3.0.0","@motrix/nat-api":"^0.3.1","@vascosantos/moving-average":"^1.1.0","abort-controller":"^3.0.0","aggregate-error":"^3.1.0","any-signal":"^2.1.1","bignumber.js":"^9.0.1","class-is":"^1.1.0","debug":"^4.3.1","err-code":"^3.0.0","es6-promisify":"^7.0.0","events":"^3.3.0","hashlru":"^2.3.0","interface-datastore":"^6.0.2","it-all":"^1.0.4","it-buffer":"^0.1.2","it-drain":"^1.0.3","it-filter":"^1.0.1","it-first":"^1.0.4","it-handshake":"^2.0.0","it-length-prefixed":"^5.0.2","it-map":"^1.0.4","it-merge":"^1.0.0","it-pipe":"^1.1.0","it-take":"^1.0.0","libp2p-crypto":"^0.19.4","libp2p-interfaces":"^1.0.0","libp2p-utils":"^0.4.0","mafmt":"^10.0.0","merge-options":"^3.0.4","multiaddr":"^10.0.0","multiformats":"^9.0.0","multistream-select":"^2.0.0","mutable-proxy":"^1.0.0","node-forge":"^0.10.0","p-any":"^3.0.0","p-fifo":"^1.0.0","p-retry":"^4.4.0","p-settle":"^4.1.1","peer-id":"^0.15.0","private-ip":"^2.1.0","protobufjs":"^6.10.2","retimer":"^3.0.0","sanitize-filename":"^1.6.3","set-delayed-interval":"^1.0.0","streaming-iterables":"^6.0.0","timeout-abort-controller":"^1.1.1","uint8arrays":"^3.0.0","varint":"^6.0.0","wherearewe":"^1.0.0","xsalsa20":"^1.1.0"},"devDependencies":{"@chainsafe/libp2p-noise":"^4.0.0","@nodeutils/defaults-deep":"^1.1.0","@types/es6-promisify":"^6.0.0","@types/node":"^16.0.1","@types/node-forge":"^0.10.1","@types/varint":"^6.0.0","aegir":"^33.1.1","buffer":"^6.0.3","datastore-core":"^6.0.7","delay":"^5.0.0","interop-libp2p":"^0.4.0","into-stream":"^7.0.0","ipfs-http-client":"^52.0.2","it-concat":"^2.0.0","it-pair":"^1.0.0","it-pushable":"^1.4.0","libp2p":".","libp2p-bootstrap":"^0.13.0","libp2p-delegated-content-routing":"^0.11.0","libp2p-delegated-peer-routing":"^0.10.0","libp2p-floodsub":"^0.27.0","libp2p-gossipsub":"^0.11.0","libp2p-interfaces-compliance-tests":"^1.0.0","libp2p-kad-dht":"^0.24.2","libp2p-mdns":"^0.17.0","libp2p-mplex":"^0.10.1","libp2p-tcp":"^0.17.0","libp2p-webrtc-star":"^0.23.0","libp2p-websockets":"^0.16.0","nock":"^13.0.3","p-defer":"^3.0.0","p-times":"^3.0.0","p-wait-for":"^3.2.0","rimraf":"^3.0.2","sinon":"^11.1.1","util":"^0.12.3"},"contributors":["Vasco Santos ","David Dias ","Jacob Heun ","Alex Potsides ","Alan Shaw ","Cayman ","Pedro Teixeira ","Friedel Ziegelmayer ","Maciej Krüger ","Hugo Dias ","Chris Dostert ","dirkmc ","Volker Mische ","zeim839 <50573884+zeim839@users.noreply.github.com>","Richard Littauer ","a1300 ","Ryan Bell ","ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ ","Franck Royer ","Thomas Eizinger ","Giovanni T. Parra ","acolytec3 <17355484+acolytec3@users.noreply.github.com>","Elven ","Andrew Nesbitt ","Samlior ","Didrik Nordström ","RasmusErik Voel Jensen ","Robert Kiel ","Smite Chow ","Soeren ","Sönke Hahn ","TJKoury ","Tiago Alves ","XiaoZhang ","Yusef Napora ","Zane Starr ","ebinks ","Aditya Bose <13054902+adbose@users.noreply.github.com>","isan_rivkin ","mayerwin ","mcclure ","phillmac ","robertkiel ","shresthagrawal <34920931+shresthagrawal@users.noreply.github.com>","swedneck <40505480+swedneck@users.noreply.github.com>","greenSnot ","Aleksei ","Bernd Strehl ","Chris Bratlien ","Cindy Wu ","Daijiro Wachi ","Diogo Silva ","Dmitriy Ryajov ","Ethan Lam ","Fei Liu ","Felipe Martins ","Florian-Merle ","Francis Gulotta ","Guy Sviry <32539816+guysv@users.noreply.github.com>","Henrique Dias ","Irakli Gozalishvili ","Joel Gustafson ","John Rees ","João Santos ","Julien Bouquillon ","Kevin Kwok ","Kevin Lacker ","Lars Gierth ","Leask Wong ","Marcin Tojek ","Michael Burns <5170+mburns@users.noreply.github.com>","Miguel Mota ","Nuno Nogueira ","Philipp Muens "]}')},{}],eXVcE:[function(e,t,r){"use strict";t.exports={ADVERTISE_BOOT_DELAY:9e5,ADVERTISE_TTL:18e5,CIRCUIT_PROTO_CODE:290,HOP_METADATA_KEY:"hop_relay",HOP_METADATA_VALUE:"true",RELAY_RENDEZVOUS_NS:"/libp2p/relay"}},{}],"5uTJL":[function(e,t,r){"use strict";const i=e("./multiaddr/is-private");function n(e,t){const r=i(e.multiaddr),n=i(t.multiaddr);return r&&!n?1:!r&&n||e.isCertified&&!t.isCertified?-1:!e.isCertified&&t.isCertified?1:0}t.exports.publicAddressesFirst=function(e){return[...e].sort(n)}},{"./multiaddr/is-private":"gME6b"}],gME6b:[function(e,t,r){"use strict";const i=e("private-ip");t.exports=function(e){const{address:t}=e.nodeAddress();return i(t)}},{"private-ip":"kXRph"}],kXRph:[function(e,t,r){"use strict";t.exports=e("./lib").default},{"./lib":"hAqtf"}],hAqtf:[function(e,t,r){"use strict";var i=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(r,"__esModule",{value:!0});const n=e("netmask"),s=i(e("ip-regex")),o=i(e("is-ip")),a=e("ipaddr.js"),c=["0.0.0.0/8","10.0.0.0/8","100.64.0.0/10","127.0.0.0/8","169.254.0.0/16","172.16.0.0/12","192.0.0.0/24","192.0.0.0/29","192.0.0.8/32","192.0.0.9/32","192.0.0.10/32","192.0.0.170/32","192.0.0.171/32","192.0.2.0/24","192.31.196.0/24","192.52.193.0/24","192.88.99.0/24","192.168.0.0/16","192.175.48.0/24","198.18.0.0/15","198.51.100.0/24","203.0.113.0/24","240.0.0.0/4","255.255.255.255/32"].map((e=>new n.Netmask(e)));function u(e){return/^::$/.test(e)||/^::1$/.test(e)||/^::f{4}:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(e)||/^::f{4}:0.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(e)||/^64:ff9b::([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(e)||/^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(e)||/^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(e)||/^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(e)||/^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(e)||/^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(e)||/^f[c-d]([0-9a-fA-F]{2,2}):/i.test(e)||/^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(e)||/^ff([0-9a-fA-F]{2,2}):/i.test(e)}r.default=e=>{if(a.isValid(e)){const t=a.parse(e);if("ipv4"===t.kind())return function(e){for(let t of c)if(t.contains(e))return!0;return!1}(t.toNormalizedString());if("ipv6"===t.kind())return u(e)}else if(o.default(e)&&s.default.v6().test(e))return u(e)}},{netmask:"2iaUq","ip-regex":"foGrp","is-ip":"arQx3","ipaddr.js":"8jiec"}],"2iaUq":[function(e,t,r){(function(){var e,t,i,n,s,o,a,c;c=function(e){return[(-16777216&e)>>>24,(16711680&e)>>>16,(65280&e)>>>8,255&e].join(".")},a=function(e){var r,i,n,s,o,a;for(r=[],n=s=0;s<=3&&0!==e.length;n=++s){if(n>0){if("."!==e[0])throw new Error("Invalid IP");e=e.substring(1)}o=(a=t(e))[0],i=a[1],e=e.substring(i),r.push(o)}if(0!==e.length)throw new Error("Invalid IP");switch(r.length){case 1:if(r[0]>4294967295)throw new Error("Invalid IP");return r[0]>>>0;case 2:if(r[0]>255||r[1]>16777215)throw new Error("Invalid IP");return(r[0]<<24|r[1])>>>0;case 3:if(r[0]>255||r[1]>255||r[2]>65535)throw new Error("Invalid IP");return(r[0]<<24|r[1]<<16|r[2])>>>0;case 4:if(r[0]>255||r[1]>255||r[2]>255||r[3]>255)throw new Error("Invalid IP");return(r[0]<<24|r[1]<<16|r[2]<<8|r[3])>>>0;default:throw new Error("Invalid IP")}},n=(i=function(e){return e.charCodeAt(0)})("0"),o=i("a"),s=i("A"),t=function(e){var t,r,a,c,u;for(c=0,t=10,r="9",a=0,e.length>1&&"0"===e[a]&&("x"===e[a+1]||"X"===e[a+1]?(a+=2,t=16):"0"<=e[a+1]&&e[a+1]<="9"&&(a++,t=8,r="7")),u=a;a>>0;else{if(16!==t)break;if("a"<=e[a]&&e[a]<="f")c=c*t+(10+i(e[a])-o)>>>0;else{if(!("A"<=e[a]&&e[a]<="F"))break;c=c*t+(10+i(e[a])-s)>>>0}}if(c>4294967295)throw new Error("too large");a++}if(a===u)throw new Error("empty octet");return[c,a]},e=function(){function e(e,t){var r,i,n;if("string"!=typeof e)throw new Error("Missing `net' parameter");if(t||(n=e.split("/",2),e=n[0],t=n[1]),t||(t=32),"string"==typeof t&&t.indexOf(".")>-1){try{this.maskLong=a(t)}catch(e){throw e,new Error("Invalid mask: "+t)}for(r=i=32;i>=0;r=--i)if(this.maskLong===4294967295<<32-r>>>0){this.bitmask=r;break}}else{if(!t&&0!==t)throw new Error("Invalid mask: empty");this.bitmask=parseInt(t,10),this.maskLong=0,this.bitmask>0&&(this.maskLong=4294967295<<32-this.bitmask>>>0)}try{this.netLong=(a(e)&this.maskLong)>>>0}catch(t){throw t,new Error("Invalid net address: "+e)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+t);this.size=Math.pow(2,32-this.bitmask),this.base=c(this.netLong),this.mask=c(this.maskLong),this.hostmask=c(~this.maskLong),this.first=this.bitmask<=30?c(this.netLong+1):this.base,this.last=this.bitmask<=30?c(this.netLong+this.size-2):c(this.netLong+this.size-1),this.broadcast=this.bitmask<=30?c(this.netLong+this.size-1):void 0}return e.prototype.contains=function(t){return"string"==typeof t&&(t.indexOf("/")>0||4!==t.split(".").length)&&(t=new e(t)),t instanceof e?this.contains(t.base)&&this.contains(t.broadcast||t.last):(a(t)&this.maskLong)>>>0==(this.netLong&this.maskLong)>>>0},e.prototype.next=function(t){return null==t&&(t=1),new e(c(this.netLong+this.size*t),this.mask)},e.prototype.forEach=function(e){var t,r,i;for(i=a(this.first),r=a(this.last),t=0;i<=r;)e(c(i),i,t),t++,i++},e.prototype.toString=function(){return this.base+"/"+this.bitmask},e}(),r.ip2long=a,r.long2ip=c,r.Netmask=e}).call(this)},{}],"8jiec":[function(e,t,r){!function(e){const r="(0?\\d+|0x[a-f0-9]+)",i={fourOctet:new RegExp(`^${r}\\.${r}\\.${r}\\.${r}$`,"i"),threeOctet:new RegExp(`^${r}\\.${r}\\.${r}$`,"i"),twoOctet:new RegExp(`^${r}\\.${r}$`,"i"),longValue:new RegExp(`^${r}$`,"i")},n=new RegExp("^0[0-7]+$","i"),s=new RegExp("^0x[a-f0-9]+$","i"),o="%[0-9a-z]{1,}",a="(?:[0-9a-f]+::?)+",c={zoneIndex:new RegExp(o,"i"),native:new RegExp(`^(::)?(${a})?([0-9a-f]+)?(::)?(${o})?$`,"i"),deprecatedTransitional:new RegExp(`^(?:::)(${r}\\.${r}\\.${r}\\.${r}(${o})?)$`,"i"),transitional:new RegExp(`^((?:${a})|(?:::)(?:${a})?)${r}\\.${r}\\.${r}\\.${r}(${o})?$`,"i")};function u(e,t){if(e.indexOf("::")!==e.lastIndexOf("::"))return null;let r,i,n=0,s=-1,o=(e.match(c.zoneIndex)||[])[0];for(o&&(o=o.substring(1),e=e.replace(/%.+$/,""));(s=e.indexOf(":",s+1))>=0;)n++;if("::"===e.substr(0,2)&&n--,"::"===e.substr(-2,2)&&n--,n>t)return null;for(i=t-n,r=":";i--;)r+="0:";return":"===(e=e.replace("::",r))[0]&&(e=e.slice(1)),":"===e[e.length-1]&&(e=e.slice(0,-1)),{parts:t=function(){const t=e.split(":"),r=[];for(let e=0;e0;){if(n=r-i,n<0&&(n=0),e[s]>>n!=t[s]>>n)return!1;i-=r,s+=1}return!0}function d(e){if(s.test(e))return parseInt(e,16);if("0"===e[0]&&!isNaN(parseInt(e[1],10))){if(n.test(e))return parseInt(e,8);throw new Error(`ipaddr: cannot parse ${e} as octal`)}return parseInt(e,10)}function f(e,t){for(;e.length=0;i-=1){if(n=this.octets[i],!(n in r))return null;if(s=r[n],t&&0!==s)return null;8!==s&&(t=!0),e+=s}return 32-e},e.prototype.range=function(){return h.subnetMatch(this,this.SpecialRanges)},e.prototype.toByteArray=function(){return this.octets.slice(0)},e.prototype.toIPv4MappedAddress=function(){return h.IPv6.parse(`::ffff:${this.toString()}`)},e.prototype.toNormalizedString=function(){return this.toString()},e.prototype.toString=function(){return this.octets.join(".")},e}(),h.IPv4.broadcastAddressFromCIDR=function(e){try{const t=this.parseCIDR(e),r=t[0].toByteArray(),i=this.subnetMaskFromPrefixLength(t[1]).toByteArray(),n=[];let s=0;for(;s<4;)n.push(parseInt(r[s],10)|255^parseInt(i[s],10)),s++;return new this(n)}catch(e){throw new Error("ipaddr: the address does not have IPv4 CIDR format")}},h.IPv4.isIPv4=function(e){return null!==this.parser(e)},h.IPv4.isValid=function(e){try{return new this(this.parser(e)),!0}catch(e){return!1}},h.IPv4.isValidFourPartDecimal=function(e){return!(!h.IPv4.isValid(e)||!e.match(/^(0|[1-9]\d*)(\.(0|[1-9]\d*)){3}$/))},h.IPv4.networkAddressFromCIDR=function(e){let t,r,i,n,s;try{for(t=this.parseCIDR(e),i=t[0].toByteArray(),s=this.subnetMaskFromPrefixLength(t[1]).toByteArray(),n=[],r=0;r<4;)n.push(parseInt(i[r],10)&parseInt(s[r],10)),r++;return new this(n)}catch(e){throw new Error("ipaddr: the address does not have IPv4 CIDR format")}},h.IPv4.parse=function(e){const t=this.parser(e);if(null===t)throw new Error("ipaddr: string is not formatted like an IPv4 Address");return new this(t)},h.IPv4.parseCIDR=function(e){let t;if(t=e.match(/^(.+)\/(\d+)$/)){const e=parseInt(t[2]);if(e>=0&&e<=32){const r=[this.parse(t[1]),e];return Object.defineProperty(r,"toString",{value:function(){return this.join("/")}}),r}}throw new Error("ipaddr: string is not formatted like an IPv4 CIDR range")},h.IPv4.parser=function(e){let t,r,n;if(t=e.match(i.fourOctet))return function(){const e=t.slice(1,6),i=[];for(let t=0;t4294967295||n<0)throw new Error("ipaddr: address outside defined range");return function(){const e=[];let t;for(t=0;t<=24;t+=8)e.push(n>>t&255);return e}().reverse()}return(t=e.match(i.twoOctet))?function(){const e=t.slice(1,4),r=[];if(n=d(e[1]),n>16777215||n<0)throw new Error("ipaddr: address outside defined range");return r.push(d(e[0])),r.push(n>>16&255),r.push(n>>8&255),r.push(255&n),r}():(t=e.match(i.threeOctet))?function(){const e=t.slice(1,5),r=[];if(n=d(e[2]),n>65535||n<0)throw new Error("ipaddr: address outside defined range");return r.push(d(e[0])),r.push(d(e[1])),r.push(n>>8&255),r.push(255&n),r}():null},h.IPv4.subnetMaskFromPrefixLength=function(e){if((e=parseInt(e))<0||e>32)throw new Error("ipaddr: invalid IPv4 prefix length");const t=[0,0,0,0];let r=0;const i=Math.floor(e/8);for(;r=0;s-=1){if(i=this.parts[s],!(i in r))return null;if(n=r[i],t&&0!==n)return null;16!==n&&(t=!0),e+=n}return 128-e},e.prototype.range=function(){return h.subnetMatch(this,this.SpecialRanges)},e.prototype.toByteArray=function(){let e;const t=[],r=this.parts;for(let i=0;i>8),t.push(255&e);return t},e.prototype.toFixedLengthString=function(){const e=function(){const e=[];for(let t=0;t>8,255&t,r>>8,255&r])},e.prototype.toNormalizedString=function(){const e=function(){const e=[];for(let t=0;tn&&(i=r.index,n=r[0].length);return n<0?t:`${t.substring(0,i)}::${t.substring(i+n)}`},e.prototype.toString=function(){return this.toNormalizedString().replace(/((^|:)(0(:|$))+)/,"::")},e}(),h.IPv6.broadcastAddressFromCIDR=function(e){try{const t=this.parseCIDR(e),r=t[0].toByteArray(),i=this.subnetMaskFromPrefixLength(t[1]).toByteArray(),n=[];let s=0;for(;s<16;)n.push(parseInt(r[s],10)|255^parseInt(i[s],10)),s++;return new this(n)}catch(e){throw new Error(`ipaddr: the address does not have IPv6 CIDR format (${e})`)}},h.IPv6.isIPv6=function(e){return null!==this.parser(e)},h.IPv6.isValid=function(e){if("string"==typeof e&&-1===e.indexOf(":"))return!1;try{const t=this.parser(e);return new this(t.parts,t.zoneId),!0}catch(e){return!1}},h.IPv6.networkAddressFromCIDR=function(e){let t,r,i,n,s;try{for(t=this.parseCIDR(e),i=t[0].toByteArray(),s=this.subnetMaskFromPrefixLength(t[1]).toByteArray(),n=[],r=0;r<16;)n.push(parseInt(i[r],10)&parseInt(s[r],10)),r++;return new this(n)}catch(e){throw new Error(`ipaddr: the address does not have IPv6 CIDR format (${e})`)}},h.IPv6.parse=function(e){const t=this.parser(e);if(null===t.parts)throw new Error("ipaddr: string is not formatted like an IPv6 Address");return new this(t.parts,t.zoneId)},h.IPv6.parseCIDR=function(e){let t,r,i;if((r=e.match(/^(.+)\/(\d+)$/))&&(t=parseInt(r[2]),t>=0&&t<=128))return i=[this.parse(r[1]),t],Object.defineProperty(i,"toString",{value:function(){return this.join("/")}}),i;throw new Error("ipaddr: string is not formatted like an IPv6 CIDR range")},h.IPv6.parser=function(e){let t,r,i,n,s,o;if(i=e.match(c.deprecatedTransitional))return this.parser(`::ffff:${i[1]}`);if(c.native.test(e))return u(e,8);if((i=e.match(c.transitional))&&(o=i[6]||"",t=u(i[1].slice(0,-1)+o,6),t.parts)){for(s=[parseInt(i[2]),parseInt(i[3]),parseInt(i[4]),parseInt(i[5])],r=0;r128)throw new Error("ipaddr: invalid IPv6 prefix length");const t=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];let r=0;const i=Math.floor(e/8);for(;rc(this.libp2p))),t.on("close",(()=>c(this.libp2p))),d.push(t.listen(e))}if(0===d.length){t.push(r);continue}if(!(await s(d)).find((e=>!0===e.isFulfilled))&&this.faultTolerance!==l.NO_FATAL)throw a(new Error(`Transport (${r}) could not listen on any available address`),o.ERR_NO_VALID_ADDRESSES)}if(t.length===this._transports.size){const e=`no valid addresses were provided for transports [${t}]`;if(this.faultTolerance===l.FATAL_ALL)throw a(new Error(e),o.ERR_NO_VALID_ADDRESSES);n(`libp2p in dial mode only: ${e}`)}}async remove(e){if(n("removing %s",e),this._listeners.has(e))for(const t of this._listeners.get(e))t.removeAllListeners("listening"),t.removeAllListeners("close"),await t.close();this._transports.delete(e),this._listeners.delete(e)}async removeAll(){const e=[];for(const t of this._transports.keys())e.push(this.remove(t));await Promise.all(e)}}const l={FATAL_ALL:0,NO_FATAL:1};u.FaultTolerance=l,t.exports=u},{debug:"bO5wM","p-settle":"hczkz","./errors":"3rNo5","err-code":"chZjB","./record/utils":"7dy3Z"}],hczkz:[function(e,t,r){"use strict";const i=e("p-reflect"),n=e("p-limit");t.exports=async(e,t={})=>{const{concurrency:r=1/0}=t,s=n(r);return Promise.all(e.map((e=>e&&"function"==typeof e.then?i(e):i("function"==typeof e?s((()=>e())):Promise.resolve(e)))))}},{"p-reflect":"3v3gm","p-limit":"k9NpZ"}],"3v3gm":[function(e,t,r){"use strict";const i=async e=>{try{return{isFulfilled:!0,isRejected:!1,value:await e}}catch(e){return{isFulfilled:!1,isRejected:!0,reason:e}}};t.exports=i,t.exports.default=i},{}],k9NpZ:[function(e,t,r){"use strict";const i=e("p-try"),n=e=>{if(!Number.isInteger(e)&&e!==1/0||!(e>0))return Promise.reject(new TypeError("Expected `concurrency` to be a number from 1 and up"));const t=[];let r=0;const n=()=>{r--,t.length>0&&t.shift()()},s=(e,t,...s)=>{r++;const o=i(e,...s);t(o),o.then(n,n)},o=(i,...n)=>new Promise((o=>((i,n,...o)=>{rr},pendingCount:{get:()=>t.length},clearQueue:{value:()=>{t.length=0}}}),o};t.exports=n,t.exports.default=n},{"p-try":"RBpbF"}],RBpbF:[function(e,t,r){"use strict";const i=(e,...t)=>new Promise((r=>{r(e(...t))}));t.exports=i,t.exports.default=i},{}],"7dy3Z":[function(e,t,r){"use strict";const i=e("./envelope"),n=e("./peer-record");t.exports.updateSelfPeerRecord=async function(e){const t=new n({peerId:e.peerId,multiaddrs:e.multiaddrs}),r=await i.seal(t,e.peerId);e.peerStore.addressBook.consumePeerRecord(r)}},{"./envelope":"27rHX","./peer-record":"ewlv9"}],ewlv9:[function(e,t,r){"use strict";const{Multiaddr:i}=e("multiaddr"),n=e("peer-id"),s=e("libp2p-utils/src/array-equals"),{PeerRecord:o}=e("./peer-record"),{ENVELOPE_DOMAIN_PEER_RECORD:a,ENVELOPE_PAYLOAD_TYPE_PEER_RECORD:c}=e("./consts");class u{constructor({peerId:e,multiaddrs:t=[],seqNumber:r=Date.now()}){this.domain=a,this.codec=c,this.peerId=e,this.multiaddrs=t,this.seqNumber=r,this._marshal=void 0}marshal(){return this._marshal||(this._marshal=o.encode({peerId:this.peerId.toBytes(),seq:this.seqNumber,addresses:this.multiaddrs.map((e=>({multiaddr:e.bytes})))}).finish()),this._marshal}equals(e){return e instanceof u&&(!!this.peerId.equals(e.peerId)&&(this.seqNumber===e.seqNumber&&!!s(this.multiaddrs,e.multiaddrs)))}}u.createFromProtobuf=e=>{const t=o.decode(e),r=n.createFromBytes(t.peerId),s=(t.addresses||[]).map((e=>new i(e.multiaddr))),a=Number(t.seq);return new u({peerId:r,multiaddrs:s,seqNumber:a})},u.DOMAIN=a,t.exports=u},{multiaddr:"8Mu1u","peer-id":"8Bdb3","libp2p-utils/src/array-equals":"8n4Vn","./peer-record":"48CV1","./consts":"5QB9f"}],"8n4Vn":[function(e,t,r){"use strict";t.exports=function(e,t){return e.length===t.length&&t.sort()&&e.sort().every(((e,r)=>t[r].equals(e)))}},{}],"48CV1":[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-peer-record"]||(i.roots["libp2p-peer-record"]={});a.PeerRecord=function(){function e(e){if(this.addresses=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.peerId=e.bytes();break;case 2:i.seq=e.uint64();break;case 3:i.addresses&&i.addresses.length||(i.addresses=[]),i.addresses.push(a.PeerRecord.AddressInfo.decode(e,e.uint32()));break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.PeerRecord)return e;var t=new a.PeerRecord;if(null!=e.peerId&&("string"==typeof e.peerId?o.base64.decode(e.peerId,t.peerId=o.newBuffer(o.base64.length(e.peerId)),0):e.peerId.length&&(t.peerId=e.peerId)),null!=e.seq&&(o.Long?(t.seq=o.Long.fromValue(e.seq)).unsigned=!0:"string"==typeof e.seq?t.seq=parseInt(e.seq,10):"number"==typeof e.seq?t.seq=e.seq:"object"==typeof e.seq&&(t.seq=new o.LongBits(e.seq.low>>>0,e.seq.high>>>0).toNumber(!0))),e.addresses){if(!Array.isArray(e.addresses))throw TypeError(".PeerRecord.addresses: array expected");t.addresses=[];for(var r=0;r>>0,e.seq.high>>>0).toNumber(!0):e.seq),e.addresses&&e.addresses.length){r.addresses=[];for(var n=0;n>>3==1)i.multiaddr=e.bytes();else e.skipType(7&s)}return i},e.fromObject=function(e){if(e instanceof a.PeerRecord.AddressInfo)return e;var t=new a.PeerRecord.AddressInfo;return null!=e.multiaddr&&("string"==typeof e.multiaddr?o.base64.decode(e.multiaddr,t.multiaddr=o.newBuffer(o.base64.length(e.multiaddr)),0):e.multiaddr.length&&(t.multiaddr=e.multiaddr)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(t.bytes===String?r.multiaddr="":(r.multiaddr=[],t.bytes!==Array&&(r.multiaddr=o.newBuffer(r.multiaddr)))),null!=e.multiaddr&&e.hasOwnProperty("multiaddr")&&(r.multiaddr=t.bytes===String?o.base64.encode(e.multiaddr,0,e.multiaddr.length):t.bytes===Array?Array.prototype.slice.call(e.multiaddr):e.multiaddr),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,i.util.toJSONOptions)},e}(),e}(),t.exports=a},{"protobufjs/minimal":"grAXL"}],"5QB9f":[function(e,t,r){"use strict";const i=Uint8Array.from([3,1]);t.exports={ENVELOPE_DOMAIN_PEER_RECORD:"libp2p-peer-record",ENVELOPE_PAYLOAD_TYPE_PEER_RECORD:i}},{}],"8bdzg":[function(e,t,r){"use strict";const{EventEmitter:i}=e("events"),{Multiaddr:n}=e("multiaddr"),s=e("peer-id");t.exports=class extends i{constructor(e,{listen:t=[],announce:r=[]}={}){super(),this.peerId=e,this.listen=new Set(t.map((e=>e.toString()))),this.announce=new Set(r.map((e=>e.toString()))),this.observed=new Set}getListenAddrs(){return Array.from(this.listen).map((e=>new n(e)))}getAnnounceAddrs(){return Array.from(this.announce).map((e=>new n(e)))}getObservedAddrs(){return Array.from(this.observed).map((e=>new n(e)))}addObservedAddr(e){let t=new n(e);const r=t.getPeerId();if(r){s.createFromB58String(r).equals(this.peerId)&&(t=t.decapsulate(new n(`/p2p/${this.peerId}`)))}const i=t.toString();this.observed.has(i)||(this.observed.add(i),this.emit("change:addresses"))}}},{events:"g82pp",multiaddr:"8Mu1u","peer-id":"8Bdb3"}],bZLZf:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:connection-manager"),{error:i("libp2p:connection-manager:err")}),s=e("err-code"),o=e("merge-options"),a=e("./latency-monitor"),c=e("retimer"),{EventEmitter:u}=e("events"),l=e("peer-id"),{codes:{ERR_INVALID_PARAMETERS:d}}=e("../errors"),f={maxConnections:1/0,minConnections:0,maxData:1/0,maxSentData:1/0,maxReceivedData:1/0,maxEventLoopDelay:1/0,pollInterval:2e3,autoDialInterval:1e4,movingAverageInterval:6e4,defaultPeerValue:1};t.exports=class extends u{constructor(e,t={}){if(super(),this._libp2p=e,this._peerId=e.peerId.toB58String(),this._options=o.call({ignoreUndefined:!0},f,t),this._options.maxConnectionse+t.length),0)}start(){this._libp2p.metrics&&(this._timer=this._timer||c(this._checkMetrics,this._options.pollInterval)),this._latencyMonitor.start(),this._onLatencyMeasure=this._onLatencyMeasure.bind(this),this._latencyMonitor.on("data",this._onLatencyMeasure),this._started=!0,n("started"),this._options.autoDial&&this._autoDial()}async stop(){this._autoDialTimeout&&this._autoDialTimeout.clear(),this._timer&&this._timer.clear(),this._latencyMonitor.removeListener("data",this._onLatencyMeasure),this._latencyMonitor.stop(),this._started=!1,await this._close(),n("stopped")}async _close(){const e=[];for(const t of this.connections.values())for(const r of t)e.push(r.close());await Promise.all(e),this.connections.clear()}setPeerValue(e,t){if(t<0||t>1)throw new Error("value should be a number between 0 and 1");this._peerValues.set(e.toB58String(),t)}_checkMetrics(){if(this._libp2p.metrics){const e=this._libp2p.metrics.global.movingAverages,t=e.dataReceived[this._options.movingAverageInterval].movingAverage();this._checkMaxLimit("maxReceivedData",t);const r=e.dataSent[this._options.movingAverageInterval].movingAverage();this._checkMaxLimit("maxSentData",r);const i=t+r;this._checkMaxLimit("maxData",i),n("metrics update",i),this._timer=c(this._checkMetrics,this._options.pollInterval)}}onConnect(e){const t=e.remotePeer,r=t.toB58String(),i=this.connections.get(r);this.emit("peer:connect",e),i?i.push(e):this.connections.set(r,[e]),this._libp2p.peerStore.keyBook.set(t,t.pubKey),this._peerValues.has(r)||this._peerValues.set(r,this._options.defaultPeerValue),this._checkMaxLimit("maxConnections",this.size)}onDisconnect(e){const t=e.remotePeer.toB58String();let r=this.connections.get(t);r&&r.length>1?(r=r.filter((t=>t.id!==e.id)),this.connections.set(t,r)):r&&(this.connections.delete(t),this._peerValues.delete(e.remotePeer.toB58String()),this.emit("peer:disconnect",e))}get(e){const t=this.getAll(e);return t.length?t[0]:null}getAll(e){if(!l.isPeerId(e))throw s(new Error("peerId must be an instance of peer-id"),d);const t=e.toB58String(),r=this.connections.get(t);return r?r.filter((e=>"open"===e.stat.status)):[]}_onLatencyMeasure(e){this._checkMaxLimit("maxEventLoopDelay",e.avgMs)}_checkMaxLimit(e,t){const r=this._options[e];n("checking limit of %s. current value: %d of %d",e,t,r),t>r&&(n("%s: limit exceeded: %s, %d",this._peerId,e,t),this._maybeDisconnectOne())}async _autoDial(){const e=this._options.minConnections;if(this.size>=e)return void(this._autoDialTimeout=c(this._autoDial,this._options.autoDialInterval));const t=Array.from(this._libp2p.peerStore.peers.values()).sort(((e,t)=>!t.protocols||!t.protocols.length||e.protocols&&e.protocols.length?t.id.pubKey&&!e.id.pubKey?1:-1:1));for(let r=0;re[1]-t[1]))));n("%s: sorted peer values: %j",this._peerId,e);const t=e[0];if(t){const e=t[0];n("%s: lowest value peer is %s",this._peerId,e),n("%s: closing a connection to %j",this._peerId,e);for(const t of this.connections.values())if(t[0].remotePeer.toB58String()===e){t[0].close();break}}}}}},{debug:"bO5wM","err-code":"chZjB","merge-options":"fupyv","./latency-monitor":"cAPgo",retimer:"8W3r3",events:"g82pp","peer-id":"8Bdb3","../errors":"3rNo5"}],cAPgo:[function(e,t,r){"use strict";const{EventEmitter:i}=e("events"),n=e("./visibility-change-emitter"),s=e("debug")("latency-monitor:LatencyMonitor");t.exports=class extends i{constructor({latencyCheckIntervalMs:e,dataEmitIntervalMs:t,asyncTestFn:r,latencyRandomPercentage:i}={}){super();const n=this;n.latencyCheckIntervalMs=e||500,n.latencyRandomPercentage=i||10,n._latecyCheckMultiply=n.latencyRandomPercentage/100*2*n.latencyCheckIntervalMs,n._latecyCheckSubtract=n._latecyCheckMultiply/2,n.dataEmitIntervalMs=null===t||0===t?void 0:t||5e3,s("latencyCheckIntervalMs: %s dataEmitIntervalMs: %s",n.latencyCheckIntervalMs,n.dataEmitIntervalMs),n.dataEmitIntervalMs?s("Expecting ~%s events per summary",n.latencyCheckIntervalMs/n.dataEmitIntervalMs):s("Not emitting summaries"),n.asyncTestFn=r}start(){globalThis.process&&globalThis.process.hrtime?(s("Using process.hrtime for timing"),this.now=globalThis.process.hrtime,this.getDeltaMS=e=>{const t=this.now(e);return 1e3*t[0]+t[1]/1e6}):"undefined"!=typeof window&&window.performance&&window.performance.now?(s("Using performance.now for timing"),this.now=window.performance.now.bind(window.performance),this.getDeltaMS=e=>Math.round(this.now()-e)):(s("Using Date.now for timing"),this.now=Date.now,this.getDeltaMS=e=>this.now()-e),this._latencyData=this._initLatencyData(),"undefined"!=typeof window&&(this._visibilityChangeEmitter=new n,this._visibilityChangeEmitter.on("visibilityChange",(e=>{e?this._startTimers():(this._emitSummary(),this._stopTimers())}))),this._visibilityChangeEmitter&&!this._visibilityChangeEmitter.isVisible()||this._startTimers()}stop(){this._stopTimers()}_startTimers(){this._checkLatencyID||(this._checkLatency(),this.dataEmitIntervalMs&&(this._emitIntervalID=setInterval((()=>this._emitSummary()),this.dataEmitIntervalMs),"function"==typeof this._emitIntervalID.unref&&this._emitIntervalID.unref()))}_stopTimers(){this._checkLatencyID&&(clearTimeout(this._checkLatencyID),this._checkLatencyID=void 0),this._emitIntervalID&&(clearInterval(this._emitIntervalID),this._emitIntervalID=void 0)}_emitSummary(){const e=this.getSummary();e.events>0&&this.emit("data",e)}getSummary(){const e={events:this._latencyData.events,minMs:this._latencyData.minMs,maxMs:this._latencyData.maxMs,avgMs:this._latencyData.events?this._latencyData.totalMs/this._latencyData.events:Number.POSITIVE_INFINITY,lengthMs:this.getDeltaMS(this._latencyData.startTime)};return this._latencyData=this._initLatencyData(),s("Summary: %O",e),e}_checkLatency(){const e=this,t=Math.random()*e._latecyCheckMultiply-e._latecyCheckSubtract,r={deltaOffset:Math.ceil(e.latencyCheckIntervalMs+t),startTime:e.now()},i=()=>{if(!this._checkLatencyID)return;const t=e.getDeltaMS(r.startTime)-r.deltaOffset;e._checkLatency(),e._latencyData.events++,e._latencyData.minMs=Math.min(e._latencyData.minMs,t),e._latencyData.maxMs=Math.max(e._latencyData.maxMs,t),e._latencyData.totalMs+=t,s("MS: %s Data: %O",t,e._latencyData)};s("localData: %O",r),this._checkLatencyID=setTimeout((()=>{e.asyncTestFn?(r.deltaOffset=0,r.startTime=e.now(),e.asyncTestFn(i)):(r.deltaOffset-=1,i())}),r.deltaOffset),"function"==typeof this._checkLatencyID.unref&&this._checkLatencyID.unref()}_initLatencyData(){return{startTime:this.now(),minMs:Number.POSITIVE_INFINITY,maxMs:Number.NEGATIVE_INFINITY,events:0,totalMs:0}}}},{events:"g82pp","./visibility-change-emitter":"dTe03",debug:"bO5wM"}],dTe03:[function(e,t,r){"use strict";const{EventEmitter:i}=e("events"),n=e("debug")("latency-monitor:VisibilityChangeEmitter");t.exports=class extends i{constructor(){super(),"undefined"!=typeof document?(this._initializeVisibilityVarNames(),this._addVisibilityChangeListener()):n('This is not a browser, no "document" found. Stopping.')}_initializeVisibilityVarNames(){let e,t;void 0!==document.hidden?(e="hidden",t="visibilitychange"):void 0!==document.mozHidden?(e="mozHidden",t="mozvisibilitychange"):void 0!==document.msHidden?(e="msHidden",t="msvisibilitychange"):void 0!==document.webkitHidden&&(e="webkitHidden",t="webkitvisibilitychange"),this._hidden=e,this._visibilityChange=t}_addVisibilityChangeListener(){void 0===document.addEventListener||void 0===document[this._hidden]?n("Checking page visibility requires a browser that supports the Page Visibility API."):document.addEventListener(this._visibilityChange,this._handleVisibilityChange.bind(this),!1)}isVisible(){if(void 0!==this._hidden&&void 0!==document[this._hidden])return!document[this._hidden]}_handleVisibilityChange(){const e=!document[this._hidden];n(e?"Page Visible":"Page Hidden"),this.emit("visibilityChange",e)}}},{events:"g82pp",debug:"bO5wM"}],"8W3r3":[function(e,t,r){"use strict";const i=e("./time");class n{constructor(e,t,r){const n=this;this._started=i(),this._rescheduled=0,this._scheduled=t,this._args=r,this._triggered=!1,this._timerWrapper=()=>{n._rescheduled>0?(n._scheduled=n._rescheduled-(i()-n._started),n._schedule(n._scheduled)):(n._triggered=!0,e.apply(null,n._args))},this._timer=setTimeout(this._timerWrapper,t)}reschedule(e){e||(e=this._scheduled);const t=i();t+e-(this._started+this._scheduled)<0?(clearTimeout(this._timer),this._schedule(e)):this._triggered?this._schedule(e):(this._started=t,this._rescheduled=e)}_schedule(e){this._triggered=!1,this._started=i(),this._rescheduled=0,this._scheduled=e,this._timer=setTimeout(this._timerWrapper,e)}clear(){clearTimeout(this._timer)}}t.exports=function(){if("function"!=typeof arguments[0])throw new Error("callback needed");if("number"!=typeof arguments[1])throw new Error("timeout needed");let e;if(arguments.length>0){e=new Array(arguments.length-2);for(var t=0;te.bytes))},dstPeer:{id:g.toBytes(),addrs:[new a(o).bytes]}}}),r=i.encapsulate(`/p2p-circuit/p2p/${this.peerId.toB58String()}`),s=d({stream:t,remoteAddr:e,localAddr:r});return n("new outbound connection %s",s.remoteAddr),this._upgrader.upgradeOutbound(s)}catch(e){throw n.error("Circuit relay dial failed",e),m&&await b.close(),e}}createListener(e,t){return"function"==typeof e&&(t=e,e={}),this.handler=t,h(this._libp2p)}filter(e){return(e=Array.isArray(e)?e:[e]).filter((e=>o.Circuit.matches(e)))}get[Symbol.toStringTag](){return"Circuit"}static isTransport(e){return Boolean(e&&e[v])}}t.exports=w},{debug:"bO5wM","err-code":"chZjB",mafmt:"l1lok",multiaddr:"8Mu1u","peer-id":"8Bdb3","./protocol":"fLprH","../errors":"3rNo5","libp2p-utils/src/stream-to-ma-conn":"9Ldtq","./multicodec":"cvoxe","./listener":"3rDyV","./circuit/hop":"8wHM9","./circuit/stop":"9XOcP","./circuit/stream-handler":"4ZlbH"}],fLprH:[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-circuit"]||(i.roots["libp2p-circuit"]={});a.CircuitRelay=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.type=e.int32();break;case 2:i.srcPeer=a.CircuitRelay.Peer.decode(e,e.uint32());break;case 3:i.dstPeer=a.CircuitRelay.Peer.decode(e,e.uint32());break;case 4:i.code=e.int32();break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.CircuitRelay)return e;var t=new a.CircuitRelay;switch(e.type){case"HOP":case 1:t.type=1;break;case"STOP":case 2:t.type=2;break;case"STATUS":case 3:t.type=3;break;case"CAN_HOP":case 4:t.type=4}if(null!=e.srcPeer){if("object"!=typeof e.srcPeer)throw TypeError(".CircuitRelay.srcPeer: object expected");t.srcPeer=a.CircuitRelay.Peer.fromObject(e.srcPeer)}if(null!=e.dstPeer){if("object"!=typeof e.dstPeer)throw TypeError(".CircuitRelay.dstPeer: object expected");t.dstPeer=a.CircuitRelay.Peer.fromObject(e.dstPeer)}switch(e.code){case"SUCCESS":case 100:t.code=100;break;case"HOP_SRC_ADDR_TOO_LONG":case 220:t.code=220;break;case"HOP_DST_ADDR_TOO_LONG":case 221:t.code=221;break;case"HOP_SRC_MULTIADDR_INVALID":case 250:t.code=250;break;case"HOP_DST_MULTIADDR_INVALID":case 251:t.code=251;break;case"HOP_NO_CONN_TO_DST":case 260:t.code=260;break;case"HOP_CANT_DIAL_DST":case 261:t.code=261;break;case"HOP_CANT_OPEN_DST_STREAM":case 262:t.code=262;break;case"HOP_CANT_SPEAK_RELAY":case 270:t.code=270;break;case"HOP_CANT_RELAY_TO_SELF":case 280:t.code=280;break;case"STOP_SRC_ADDR_TOO_LONG":case 320:t.code=320;break;case"STOP_DST_ADDR_TOO_LONG":case 321:t.code=321;break;case"STOP_SRC_MULTIADDR_INVALID":case 350:t.code=350;break;case"STOP_DST_MULTIADDR_INVALID":case 351:t.code=351;break;case"STOP_RELAY_REFUSED":case 390:t.code=390;break;case"MALFORMED_MESSAGE":case 400:t.code=400}return t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(r.type=t.enums===String?"HOP":1,r.srcPeer=null,r.dstPeer=null,r.code=t.enums===String?"SUCCESS":100),null!=e.type&&e.hasOwnProperty("type")&&(r.type=t.enums===String?a.CircuitRelay.Type[e.type]:e.type),null!=e.srcPeer&&e.hasOwnProperty("srcPeer")&&(r.srcPeer=a.CircuitRelay.Peer.toObject(e.srcPeer,t)),null!=e.dstPeer&&e.hasOwnProperty("dstPeer")&&(r.dstPeer=a.CircuitRelay.Peer.toObject(e.dstPeer,t)),null!=e.code&&e.hasOwnProperty("code")&&(r.code=t.enums===String?a.CircuitRelay.Status[e.code]:e.code),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,i.util.toJSONOptions)},e.Status=(t={},(r=Object.create(t))[t[100]="SUCCESS"]=100,r[t[220]="HOP_SRC_ADDR_TOO_LONG"]=220,r[t[221]="HOP_DST_ADDR_TOO_LONG"]=221,r[t[250]="HOP_SRC_MULTIADDR_INVALID"]=250,r[t[251]="HOP_DST_MULTIADDR_INVALID"]=251,r[t[260]="HOP_NO_CONN_TO_DST"]=260,r[t[261]="HOP_CANT_DIAL_DST"]=261,r[t[262]="HOP_CANT_OPEN_DST_STREAM"]=262,r[t[270]="HOP_CANT_SPEAK_RELAY"]=270,r[t[280]="HOP_CANT_RELAY_TO_SELF"]=280,r[t[320]="STOP_SRC_ADDR_TOO_LONG"]=320,r[t[321]="STOP_DST_ADDR_TOO_LONG"]=321,r[t[350]="STOP_SRC_MULTIADDR_INVALID"]=350,r[t[351]="STOP_DST_MULTIADDR_INVALID"]=351,r[t[390]="STOP_RELAY_REFUSED"]=390,r[t[400]="MALFORMED_MESSAGE"]=400,r),e.Type=function(){var e={},t=Object.create(e);return t[e[1]="HOP"]=1,t[e[2]="STOP"]=2,t[e[3]="STATUS"]=3,t[e[4]="CAN_HOP"]=4,t}(),e.Peer=function(){function e(e){if(this.addrs=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.id=e.bytes();break;case 2:i.addrs&&i.addrs.length||(i.addrs=[]),i.addrs.push(e.bytes());break;default:e.skipType(7&s)}}if(!i.hasOwnProperty("id"))throw o.ProtocolError("missing required 'id'",{instance:i});return i},e.fromObject=function(e){if(e instanceof a.CircuitRelay.Peer)return e;var t=new a.CircuitRelay.Peer;if(null!=e.id&&("string"==typeof e.id?o.base64.decode(e.id,t.id=o.newBuffer(o.base64.length(e.id)),0):e.id.length&&(t.id=e.id)),e.addrs){if(!Array.isArray(e.addrs))throw TypeError(".CircuitRelay.Peer.addrs: array expected");t.addrs=[];for(var r=0;r(o(new Uint8Array(0)),u())};function u(){return c.timeline.close||(c.timeline.close=Date.now()),Promise.resolve()}return c}},{"abortable-iterator":"awlU8",debug:"bO5wM"}],cvoxe:[function(e,t,r){"use strict";t.exports={relay:"/libp2p/circuit/relay/0.1.0"}},{}],"3rDyV":[function(e,t,r){"use strict";const{EventEmitter:i}=e("events"),{Multiaddr:n}=e("multiaddr");t.exports=e=>{const t=new Map;const r=Object.assign(new i,{close:()=>Promise.resolve(),listen:async function(i){const s=String(i).split("/p2p-circuit").find((e=>""!==e)),o=await e.dial(new n(s)),a=o.remoteAddr.encapsulate("/p2p-circuit");t.set(o.remotePeer.toB58String(),a),r.emit("listening")},getAddrs:function(){const e=[];for(const r of t.values())e.push(r);return e}});return e.connectionManager.on("peer:disconnect",(e=>{t.delete(e.remotePeer.toB58String())&&r.emit("close")})),r}},{events:"g82pp",multiaddr:"8Mu1u"}],"8wHM9":[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:circuit:hop"),{error:i("libp2p:circuit:hop:err")}),s=e("err-code"),o=e("peer-id"),{validateAddrs:a}=e("./utils"),c=e("./stream-handler"),{CircuitRelay:u}=e("../protocol"),{pipe:l}=e("it-pipe"),{codes:d}=e("../../errors"),{stop:f}=e("./stop"),h=e("./../multicodec");t.exports={handleHop:async function({connection:e,request:t,streamHandler:r,circuit:i}){if(!i._options.hop.enabled)return n("HOP request received but we are not acting as a relay"),r.end({type:u.Type.STATUS,code:u.Status.HOP_CANT_SPEAK_RELAY});try{a(t,r)}catch(t){return n.error("invalid hop request via peer %s",e.remotePeer.toB58String(),t)}if(!t.dstPeer)return void n("HOP request received but we do not receive a dstPeer");const s=new o(t.dstPeer.id),c=i._connectionManager.get(s);if(!c&&!i._options.hop.active)return n("HOP request received but we are not connected to the destination peer"),r.end({type:u.Type.STATUS,code:u.Status.HOP_NO_CONN_TO_DST});if(!c)return;const d={type:u.Type.STOP,dstPeer:t.dstPeer,srcPeer:t.srcPeer};let h;try{h=await f({connection:c,request:d})}catch(e){return n.error(e)}n("hop request from %s is valid",e.remotePeer.toB58String()),r.write({type:u.Type.STATUS,code:u.Status.SUCCESS});const p=r.rest();return l(p,h,p)},hop:async function({connection:e,request:t}){const{stream:r}=await e.newStream([h.relay]),i=new c({stream:r});i.write(t);const o=await i.read();if(!o)throw s(new Error("HOP request had no response"),d.ERR_HOP_REQUEST_FAILED);if(o.code===u.Status.SUCCESS)return n("hop request was successful"),i.rest();throw n("hop request failed with code %d, closing stream",o.code),i.close(),s(new Error(`HOP request failed with code ${o.code}`),d.ERR_HOP_REQUEST_FAILED)},canHop:async function({connection:e}){const{stream:t}=await e.newStream([h.relay]),r=new c({stream:t});r.write({type:u.Type.CAN_HOP});const i=await r.read();return await r.close(),!(!i||i.code!==u.Status.SUCCESS)},handleCanHop:function({connection:e,streamHandler:t,circuit:r}){const i=r._options.hop.enabled;n("can hop (%s) request from %s",i,e.remotePeer.toB58String()),t.end({type:u.Type.STATUS,code:i?u.Status.SUCCESS:u.Status.HOP_CANT_SPEAK_RELAY})}}},{debug:"bO5wM","err-code":"chZjB","peer-id":"8Bdb3","./utils":"daC1e","./stream-handler":"4ZlbH","../protocol":"fLprH","it-pipe":"giKBQ","../../errors":"3rNo5","./stop":"9XOcP","./../multicodec":"cvoxe"}],daC1e:[function(e,t,r){"use strict";const{Multiaddr:i}=e("multiaddr"),{CircuitRelay:n}=e("../protocol");function s(e,t){e.write({type:n.Type.STATUS,code:t})}t.exports={validateAddrs:function(e,t){try{e.dstPeer&&e.dstPeer.addrs&&e.dstPeer.addrs.forEach((e=>new i(e)))}catch(r){throw s(t,e.type===n.Type.HOP?n.Status.HOP_DST_MULTIADDR_INVALID:n.Status.STOP_DST_MULTIADDR_INVALID),r}try{e.srcPeer&&e.srcPeer.addrs&&e.srcPeer.addrs.forEach((e=>new i(e)))}catch(r){throw s(t,e.type===n.Type.HOP?n.Status.HOP_SRC_MULTIADDR_INVALID:n.Status.STOP_SRC_MULTIADDR_INVALID),r}}}},{multiaddr:"8Mu1u","../protocol":"fLprH"}],"4ZlbH":[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:circuit:stream-handler"),{error:i("libp2p:circuit:stream-handler:err")}),s=e("it-length-prefixed"),o=e("it-handshake"),{CircuitRelay:a}=e("../protocol");t.exports=class{constructor({stream:e,maxLength:t=4096}){this.stream=e,this.shake=o(this.stream),this.decoder=s.decode.fromReader(this.shake.reader,{maxDataLength:t})}async read(){const e=await this.decoder.next();if(e.value){const t=a.decode(e.value.slice());return n("read message type",t.type),t}n("read received no value, closing stream"),this.close()}write(e){n("write message type %s",e.type),this.shake.write(s.encode.single(a.encode(e).finish()))}rest(){return this.shake.rest(),this.shake.stream}end(e){this.write(e),this.close()}close(){n("closing the stream"),this.rest().sink([])}}},{debug:"bO5wM","it-length-prefixed":"3yxIE","it-handshake":"5ZBDe","../protocol":"fLprH"}],"9XOcP":[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:circuit:stop"),{error:i("libp2p:circuit:stop:err")}),{CircuitRelay:s}=e("../protocol"),o=e("../multicodec"),a=e("./stream-handler"),{validateAddrs:c}=e("./utils");t.exports.handleStop=function({connection:e,request:t,streamHandler:r}){try{c(t,r)}catch(t){return n.error("invalid stop request via peer %s",e.remotePeer.toB58String(),t)}return n("stop request is valid"),r.write({type:s.Type.STATUS,code:s.Status.SUCCESS}),r.rest()},t.exports.stop=async function({connection:e,request:t}){const{stream:r}=await e.newStream([o.relay]);n("starting stop request to %s",e.remotePeer.toB58String());const i=new a({stream:r});i.write(t);const c=await i.read();return c?c.code===s.Status.SUCCESS?(n("stop request to %s was successful",e.remotePeer.toB58String()),i.rest()):(n("stop request failed with code %d",c.code),void i.close()):i.close()}},{debug:"bO5wM","../protocol":"fLprH","../multicodec":"cvoxe","./stream-handler":"4ZlbH","./utils":"daC1e"}],hBCQx:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:relay"),{error:i("libp2p:relay:err")}),{setDelayedInterval:s,clearDelayedInterval:o}=e("set-delayed-interval"),a=e("./auto-relay"),{namespaceToCid:c}=e("./utils"),{RELAY_RENDEZVOUS_NS:u}=e("./constants");t.exports=class{constructor(e){this._libp2p=e,this._options={...e._config.relay},this._autoRelay=this._options.autoRelay.enabled&&new a({libp2p:e,...this._options.autoRelay}),this._advertiseService=this._advertiseService.bind(this)}start(){this._options.hop.enabled&&this._options.advertise.enabled&&(this._timeout=s(this._advertiseService,this._options.advertise.ttl,this._options.advertise.bootDelay))}stop(){o(this._timeout)}async _advertiseService(){try{const e=await c(u);await this._libp2p.contentRouting.provide(e)}catch(e){"NO_ROUTERS_AVAILABLE"===e.code?(n.error("a content router, such as a DHT, must be provided in order to advertise the relay service",e),this.stop()):n.error(e)}}}},{debug:"bO5wM","set-delayed-interval":"4OF34","./auto-relay":"84VTV","./utils":"l4Fw3","./constants":"eXVcE"}],"84VTV":[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:auto-relay"),{error:i("libp2p:auto-relay:err")}),{fromString:s}=e("uint8arrays/from-string"),{toString:o}=e("uint8arrays/to-string"),{Multiaddr:a}=e("multiaddr"),c=e("peer-id"),{relay:u}=e("./multicodec"),{canHop:l}=e("./circuit/hop"),{namespaceToCid:d}=e("./utils"),{CIRCUIT_PROTO_CODE:f,HOP_METADATA_KEY:h,HOP_METADATA_VALUE:p,RELAY_RENDEZVOUS_NS:g}=e("./constants");t.exports=class{constructor({libp2p:e,maxListeners:t=1,onError:r}){this._libp2p=e,this._peerId=e.peerId,this._peerStore=e.peerStore,this._connectionManager=e.connectionManager,this._transportManager=e.transportManager,this._addressSorter=e.dialer.addressSorter,this.maxListeners=t,this._listenRelays=new Set,this._onProtocolChange=this._onProtocolChange.bind(this),this._onPeerDisconnected=this._onPeerDisconnected.bind(this),this._peerStore.on("change:protocols",this._onProtocolChange),this._connectionManager.on("peer:disconnect",this._onPeerDisconnected),this._onError=(e,t)=>{n.error(t||e),r&&r(e,t)}}async _onProtocolChange({peerId:e,protocols:t}){const r=e.toB58String(),i=t.find((e=>e===u));if(i||!this._listenRelays.has(r)){if(i&&!this._listenRelays.has(r))try{const t=this._connectionManager.get(e);if(!t)return;if(t.remoteAddr.protoCodes().includes(f))return void n(`relayed connection to ${r} will not be used to hop on`);await l({connection:t})&&(this._peerStore.metadataBook.set(e,h,s(p)),await this._addListenRelay(t,r))}catch(e){this._onError(e)}}else this._removeListenRelay(r)}_onPeerDisconnected(e){const t=e.remotePeer.toB58String();this._listenRelays.has(t)&&this._removeListenRelay(t)}async _addListenRelay(e,t){if(this._listenRelays.size>=this.maxListeners)return;const r=this._peerStore.addressBook.getMultiaddrsForPeer(e.remotePeer,this._addressSorter);if(!r||!r.length)return;const i=`${r[0].toString()}/p2p-circuit`;this._listenRelays.add(t);try{await this._transportManager.listen([new a(i)])}catch(e){this._onError(e),this._listenRelays.delete(t)}}_removeListenRelay(e){this._listenRelays.delete(e)&&this._listenOnAvailableHopRelays([e])}async _listenOnAvailableHopRelays(e=[]){if(this._listenRelays.size>=this.maxListeners)return;const t=[];for(const[r,i]of this._peerStore.metadataBook.data.entries()){if(this._listenRelays.has(r)||e.includes(r))continue;const n=i.get(h);if(!n||o(n)!==p)continue;const s=c.createFromB58String(r),a=this._connectionManager.get(s);if(a){if(await this._addListenRelay(a,r),this._listenRelays.size>=this.maxListeners)return}else t.push(s)}for(const e of t)if(await this._tryToListenOnRelay(e),this._listenRelays.size>=this.maxListeners)return;try{const e=await d(g);for await(const t of this._libp2p.contentRouting.findProviders(e)){if(!t.multiaddrs.length)continue;const e=t.id;if(this._peerStore.addressBook.add(e,t.multiaddrs),await this._tryToListenOnRelay(e),this._listenRelays.size>=this.maxListeners)return}}catch(e){this._onError(e)}}async _tryToListenOnRelay(e){try{const t=await this._libp2p.dial(e);await this._addListenRelay(t,e.toB58String())}catch(t){this._onError(t,`could not connect and listen on known hop relay ${e.toB58String()}`)}}}},{debug:"bO5wM","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB",multiaddr:"8Mu1u","peer-id":"8Bdb3","./multicodec":"cvoxe","./circuit/hop":"8wHM9","./utils":"l4Fw3","./constants":"eXVcE"}],l4Fw3:[function(e,t,r){"use strict";const{CID:i}=e("multiformats/cid"),{sha256:n}=e("multiformats/hashes/sha2");t.exports.namespaceToCid=async e=>{const t=(new TextEncoder).encode(e),r=await n.digest(t);return i.createV0(r)}},{"multiformats/cid":"9ooAY","multiformats/hashes/sha2":"7i9MT"}],kwWEi:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:dialer"),{error:i("libp2p:dialer:err")}),s=e("err-code"),{Multiaddr:o}=e("multiaddr"),a=e("timeout-abort-controller"),{AbortError:c}=e("abortable-iterator"),{anySignal:u}=e("any-signal"),l=e("./dial-request"),{publicAddressesFirst:d}=e("libp2p-utils/src/address-sort"),f=e("../get-peer"),{codes:h}=e("../errors"),{DIAL_TIMEOUT:p,MAX_PARALLEL_DIALS:g,MAX_PER_PEER_DIALS:y,MAX_ADDRS_TO_DIAL:m}=e("../constants");t.exports=class{constructor({transportManager:e,peerStore:t,addressSorter:r=d,maxParallelDials:i=g,maxAddrsToDial:n=m,dialTimeout:s=p,maxDialsPerPeer:a=y,resolvers:c={}}){this.transportManager=e,this.peerStore=t,this.addressSorter=r,this.maxParallelDials=i,this.maxAddrsToDial=n,this.timeout=s,this.maxDialsPerPeer=a,this.tokens=[...new Array(i)].map(((e,t)=>t)),this._pendingDials=new Map,this._pendingDialTargets=new Map;for(const[e,t]of Object.entries(c))o.resolvers.set(e,t)}destroy(){for(const e of this._pendingDials.values())try{e.controller.abort()}catch(e){n.error(e)}this._pendingDials.clear();for(const e of this._pendingDialTargets.values())e.reject(new c("Dialer was destroyed"));this._pendingDialTargets.clear()}async connectToPeer(e,t={}){const r=await this._createCancellableDialTarget(e);if(!r.addrs.length)throw s(new Error("The dial request has no valid addresses"),h.ERR_NO_VALID_ADDRESSES);const i=this._pendingDials.get(r.id)||this._createPendingDial(r,t);try{const e=await i.promise;return n("dial succeeded to %s",r.id),e}catch(e){throw i.controller.signal.aborted&&(e.code=h.ERR_TIMEOUT),n.error(e),e}finally{i.destroy()}}async _createCancellableDialTarget(e){const t=`${parseInt(String(1e9*Math.random()),10).toString()+Date.now()}`,r=new Promise(((e,r)=>{this._pendingDialTargets.set(t,{resolve:e,reject:r})})),i=await Promise.race([this._createDialTarget(e),r]);return this._pendingDialTargets.delete(t),i}async _createDialTarget(e){const{id:t,multiaddrs:r}=f(e);r&&this.peerStore.addressBook.add(t,r);let i=this.peerStore.addressBook.getMultiaddrsForPeer(t,this.addressSorter)||[];o.isMultiaddr(e)&&(i=i.filter((t=>!e.equals(t))),i.unshift(e));const n=[];for(const e of i){(await this._resolve(e)).forEach((e=>n.push(e)))}const a=n.filter((e=>this.transportManager.transportForMultiaddr(e)));if(a.length>this.maxAddrsToDial)throw this.peerStore.delete(t),s(new Error("dial with more addresses than allowed"),h.ERR_TOO_MANY_ADDRESSES);return{id:t.toB58String(),addrs:a}}_createPendingDial(e,t={}){const r=new l({addrs:e.addrs,dialAction:(e,t)=>{if(t.signal.aborted)throw s(new Error("already aborted"),h.ERR_ALREADY_ABORTED);return this.transportManager.dial(e,t)},dialer:this}),i=new a(this.timeout),n=[i.signal];t.signal&&n.push(t.signal);const o=u(n),c={dialRequest:r,controller:i,promise:r.run({...t,signal:o}),destroy:()=>{i.clear(),this._pendingDials.delete(e.id)}};return this._pendingDials.set(e.id,c),c}getTokens(e){const t=Math.min(e,this.maxDialsPerPeer,this.tokens.length),r=this.tokens.splice(0,t);return n("%d tokens request, returning %d, %d remaining",e,t,this.tokens.length),r}releaseToken(e){this.tokens.indexOf(e)>-1||(n("token %d released",e),this.tokens.push(e))}async _resolve(e){if(!e.protoNames().includes("dnsaddr"))return[e];const t=await this._resolveRecord(e);return(await Promise.all(t.map((e=>this._resolve(e))))).flat().reduce(((e,t)=>(e.find((e=>e.equals(t)))||e.push(t),e)),[])}async _resolveRecord(e){try{e=new o(e.toString());return await e.resolve()}catch(t){return n.error(`multiaddr ${e} could not be resolved`),[]}}}},{debug:"bO5wM","err-code":"chZjB",multiaddr:"8Mu1u","timeout-abort-controller":"hzClg","abortable-iterator":"awlU8","any-signal":"kXgRR","./dial-request":"bCRVF","libp2p-utils/src/address-sort":"5uTJL","../get-peer":"39nOe","../errors":"3rNo5","../constants":"92Vak"}],bCRVF:[function(e,t,r){"use strict";const i=e("err-code"),n=e("abort-controller").default,{anySignal:s}=e("any-signal"),o=e("p-fifo"),a=e("p-any");t.exports=class{constructor({addrs:e,dialAction:t,dialer:r}){this.addrs=e,this.dialer=r,this.dialAction=t}async run(e={}){const t=this.dialer.getTokens(this.addrs.length);if(t.length<1)throw i(new Error("No dial tokens available"),"ERR_NO_DIAL_TOKENS");const r=new o;t.forEach((e=>r.push(e)));const c=this.addrs.map((()=>new n));let u=0;try{return await a(this.addrs.map((async(i,n)=>{const o=await r.shift();let a;try{const l=c[n].signal;a=await this.dialAction(i,{...e,signal:e.signal?s([l,e.signal]):l}),c.splice(n,1)}finally{u++,this.addrs.length-u>=t.length?r.push(o):this.dialer.releaseToken(t.splice(t.indexOf(o),1)[0])}return a})))}finally{c.map((e=>e.abort())),t.forEach((e=>this.dialer.releaseToken(e)))}}}},{"err-code":"chZjB","abort-controller":"lNJ7z","any-signal":"kXgRR","p-fifo":"9S0qu","p-any":"24Yiw"}],"9S0qu":[function(e,t,r){const i=e("fast-fifo"),n=e("p-defer");t.exports=class{constructor(){this._buffer=new i,this._waitingConsumers=new i}push(e){const{promise:t,resolve:r}=n();return this._buffer.push({chunk:e,resolve:r}),this._consume(),t}_consume(){for(;!this._waitingConsumers.isEmpty()&&!this._buffer.isEmpty();){const e=this._waitingConsumers.shift(),t=this._buffer.shift();e.resolve(t.chunk),t.resolve()}}shift(){const{promise:e,resolve:t}=n();return this._waitingConsumers.push({resolve:t}),this._consume(),e}isEmpty(){return this._buffer.isEmpty()}}},{"fast-fifo":"8Ws5O","p-defer":"5rKSv"}],"24Yiw":[function(e,t,r){"use strict";const i=e("p-some"),n=e("p-cancelable");t.exports=(e,t)=>{const r=i(e,{...t,count:1});return n.fn((async e=>{e((()=>{r.cancel()}));const[t]=await r;return t}))()},t.exports.AggregateError=i.AggregateError},{"p-some":"gmdP0","p-cancelable":"fDp4B"}],gmdP0:[function(e,t,r){"use strict";const i=e("aggregate-error"),n=e("p-cancelable");class s extends Error{}t.exports=(e,t)=>new n(((r,n,o)=>{const{count:a,filter:c=(()=>!0)}=t;if(!Number.isFinite(a))return void n(new TypeError("Expected a finite number, got "+typeof t.count));const u=[],l=[];let d=0,f=!1;const h=new Set,p=()=>{for(const t of e)h.has(t)||"function"!=typeof t.cancel||t.cancel()};o(p);for(const t of e)d++,(async()=>{try{const e=await t;if(f)return;if(!c(e))throw new s("Value does not satisfy filter");u.push(e)}catch(e){l.push(e)}finally{h.add(t),!f&&(u.length===a&&(r(u),f=!0),d-l.lengthd&&(n(new RangeError(`Expected input to contain at least ${t.count} items, but contains ${d} items`)),p())})),t.exports.AggregateError=i,t.exports.FilterError=s},{"aggregate-error":"45emq","p-cancelable":"fDp4B"}],fDp4B:[function(e,t,r){"use strict";class i extends Error{constructor(e){super(e||"Promise was canceled"),this.name="CancelError"}get isCanceled(){return!0}}class n{static fn(e){return(...t)=>new n(((r,i,n)=>{t.push(n),e(...t).then(r,i)}))}constructor(e){this._cancelHandlers=[],this._isPending=!0,this._isCanceled=!1,this._rejectOnCancel=!0,this._promise=new Promise(((t,r)=>{this._reject=r;const i=e=>{if(!this._isPending)throw new Error("The `onCancel` handler was attached after the promise settled.");this._cancelHandlers.push(e)};return Object.defineProperties(i,{shouldReject:{get:()=>this._rejectOnCancel,set:e=>{this._rejectOnCancel=e}}}),e((e=>{this._isCanceled&&i.shouldReject||(this._isPending=!1,t(e))}),(e=>{this._isPending=!1,r(e)}),i)}))}then(e,t){return this._promise.then(e,t)}catch(e){return this._promise.catch(e)}finally(e){return this._promise.finally(e)}cancel(e){if(this._isPending&&!this._isCanceled){if(this._isCanceled=!0,this._cancelHandlers.length>0)try{for(const e of this._cancelHandlers)e()}catch(e){return void this._reject(e)}this._rejectOnCancel&&this._reject(new i(e))}}get isCanceled(){return this._isCanceled}}Object.setPrototypeOf(n.prototype,Promise.prototype),t.exports=n,t.exports.CancelError=i},{}],f4Pg5:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:keychain"),{error:i("libp2p:keychain:err")}),s=e("sanitize-filename"),o=e("merge-options"),a=e("libp2p-crypto"),{Key:c}=e("interface-datastore/key"),u=e("./cms"),l=e("err-code"),{toString:d}=e("uint8arrays/to-string"),{fromString:f}=e("uint8arrays/from-string");e("node-forge/lib/sha512");const h="/info/",p=new WeakMap,g=14,y=16,m=1e3,b={dek:{keyLength:64,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function v(e){return!!e&&("string"==typeof e&&e===s(e.trim()))}async function w(e){const t=800*Math.random()+200;throw await new Promise((e=>setTimeout(e,t))),e}function _(e){return new c("/pkcs8/"+e)}function E(e){return new c(h+e)}t.exports=class{constructor(e,t){if(!e)throw new Error("store is required");if(this.store=e,this.opts=o(b,t),this.opts.pass&&this.opts.pass.length<20)throw new Error("pass must be least 20 characters");if(this.opts.dek.keyLengtht.id===e))}catch(e){return w(e)}}async findKeyByName(e){if(!v(e))return w(l(new Error(`Invalid key name '${e}'`),"ERR_INVALID_KEY_NAME"));const t=E(e);try{const e=await this.store.get(t);return JSON.parse(d(e))}catch(t){return w(l(new Error(`Key '${e}' does not exist. ${t.message}`),"ERR_KEY_NOT_FOUND"))}}async removeKey(e){if(!v(e)||"self"===e)return w(l(new Error(`Invalid key name '${e}'`),"ERR_INVALID_KEY_NAME"));const t=_(e),r=await this.findKeyByName(e),i=this.store.batch();return i.delete(t),i.delete(E(e)),await i.commit(),r}async renameKey(e,t){const r=this;if(!v(e)||"self"===e)return w(l(new Error(`Invalid old key name '${e}'`),"ERR_OLD_KEY_NAME_INVALID"));if(!v(t)||"self"===t)return w(l(new Error(`Invalid new key name '${t}'`),"ERR_NEW_KEY_NAME_INVALID"));const i=_(e),n=_(t),s=E(e),o=E(t);if(await r.store.has(n))return w(l(new Error(`Key '${t}' already exists`),"ERR_KEY_ALREADY_EXISTS"));try{const e=await r.store.get(i),a=await r.store.get(s),c=JSON.parse(d(a));c.name=t;const u=r.store.batch();return u.put(n,e),u.put(o,f(JSON.stringify(c))),u.delete(i),u.delete(s),await u.commit(),c}catch(e){return w(e)}}async exportKey(e,t){if(!v(e))return w(l(new Error(`Invalid key name '${e}'`),"ERR_INVALID_KEY_NAME"));if(!t)return w(l(new Error("Password is required"),"ERR_PASSWORD_REQUIRED"));const r=_(e);try{const e=await this.store.get(r),i=d(e),n=p.get(this).dek;return(await a.keys.import(i,n)).export(t)}catch(e){return w(e)}}async importKey(e,t,r){if(!v(e)||"self"===e)return w(l(new Error(`Invalid key name '${e}'`),"ERR_INVALID_KEY_NAME"));if(!t)return w(l(new Error("PEM encoded key is required"),"ERR_PEM_REQUIRED"));const i=_(e);if(await this.store.has(i))return w(l(new Error(`Key '${e}' already exists`),"ERR_KEY_ALREADY_EXISTS"));let n,s;try{n=await a.keys.import(t,r)}catch(e){return w(l(new Error("Cannot read the key, most likely the password is wrong"),"ERR_CANNOT_READ_KEY"))}try{s=await n.id();const e=p.get(this).dek;t=await n.export(e)}catch(e){return w(e)}const o={name:e,id:s},c=this.store.batch();return c.put(i,f(t)),c.put(E(e),f(JSON.stringify(o))),await c.commit(),o}async importPeer(e,t){const r=this;if(!v(e))return w(l(new Error(`Invalid key name '${e}'`),"ERR_INVALID_KEY_NAME"));if(!t||!t.privKey)return w(l(new Error("Peer.privKey is required"),"ERR_MISSING_PRIVATE_KEY"));const i=t.privKey,n=_(e);if(await r.store.has(n))return w(l(new Error(`Key '${e}' already exists`),"ERR_KEY_ALREADY_EXISTS"));try{const t=await i.id(),s=p.get(this).dek,o=await i.export(s),a={name:e,id:t},c=r.store.batch();return c.put(n,f(o)),c.put(E(e),f(JSON.stringify(a))),await c.commit(),a}catch(e){return w(e)}}async _getPrivateKey(e){if(!v(e))return w(l(new Error(`Invalid key name '${e}'`),"ERR_INVALID_KEY_NAME"));try{const t=_(e),r=await this.store.get(t);return d(r)}catch(t){return w(l(new Error(`Key '${e}' does not exist. ${t.message}`),"ERR_KEY_NOT_FOUND"))}}async rotateKeychainPass(e,t){if("string"!=typeof e)return w(l(new Error(`Invalid old pass type '${typeof e}'`),"ERR_INVALID_OLD_PASS_TYPE"));if("string"!=typeof t)return w(l(new Error(`Invalid new pass type '${typeof t}'`),"ERR_INVALID_NEW_PASS_TYPE"));if(t.length<20)return w(l(new Error(`Invalid pass length ${t.length}`),"ERR_INVALID_PASS_LENGTH"));n("recreating keychain");const r=p.get(this).dek;this.opts.pass=t;const i=t?a.pbkdf2(t,this.opts.dek.salt,this.opts.dek.iterationCount,this.opts.dek.keyLength,this.opts.dek.hash):"";p.set(this,{dek:i});const s=await this.listKeys();for(const e of s){const t=await this.store.get(_(e.name)),n=d(t),s=await a.keys.import(n,r),o=i.toString(),c=await s.export(o),u=this.store.batch(),l={name:e.name,id:e.id};u.put(_(e.name),f(c)),u.put(E(e.name),f(JSON.stringify(l))),await u.commit()}n("keychain reconstructed")}}},{debug:"bO5wM","sanitize-filename":"gfrhY","merge-options":"fupyv","libp2p-crypto":"bb1cb","interface-datastore/key":"9hGOz","./cms":"2CEx0","err-code":"chZjB","uint8arrays/to-string":"hC8JB","uint8arrays/from-string":"dF7Y4","node-forge/lib/sha512":"9XKJ9"}],gfrhY:[function(e,t,r){"use strict";var i=e("truncate-utf8-bytes"),n=/[\/\?<>\\:\*\|"]/g,s=/[\x00-\x1f\x80-\x9f]/g,o=/^\.+$/,a=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,c=/[\. ]+$/;function u(e,t){if("string"!=typeof e)throw new Error("Input must be string");var r=e.replace(n,t).replace(s,t).replace(o,t).replace(a,t).replace(c,t);return i(r,255)}t.exports=function(e,t){var r=t&&t.replacement||"",i=u(e,r);return""===r?i:u(i,"")}},{"truncate-utf8-bytes":"jMN74"}],jMN74:[function(e,t,r){"use strict";var i=e("./lib/truncate"),n=e("utf8-byte-length/browser");t.exports=i.bind(null,n)},{"./lib/truncate":"16NPs","utf8-byte-length/browser":"3kc7b"}],"16NPs":[function(e,t,r){"use strict";function i(e){return e>=55296&&e<=56319}function n(e){return e>=56320&&e<=57343}t.exports=function(e,t,r){if("string"!=typeof t)throw new Error("Input must be string");for(var s,o,a=t.length,c=0,u=0;ur)return t.slice(0,u-o.length+1)}return t}},{}],"3kc7b":[function(e,t,r){"use strict";function i(e){return e>=55296&&e<=56319}function n(e){return e>=56320&&e<=57343}t.exports=function(e){if("string"!=typeof e)throw new Error("Input must be string");for(var t=e.length,r=0,s=null,o=null,a=0;a=128&&s<=2047?r+=2:s>=2048&&s<=65535&&(r+=3),o=s;return r}},{}],"2CEx0":[function(e,t,r){"use strict";e("node-forge/lib/pkcs7"),e("node-forge/lib/pbe");const i=e("node-forge/lib/forge"),{certificateForKey:n,findAsync:s}=e("./util"),o=e("err-code"),{fromString:a}=e("uint8arrays/from-string"),{toString:c}=e("uint8arrays/to-string"),u=new WeakMap;t.exports=class{constructor(e,t){if(!e)throw o(new Error("keychain is required"),"ERR_KEYCHAIN_REQUIRED");this.keychain=e,u.set(this,{dek:t})}async encrypt(e,t){if(!(t instanceof Uint8Array))throw o(new Error("Plain data must be a Uint8Array"),"ERR_INVALID_PARAMS");const r=await this.keychain.findKeyByName(e),s=await this.keychain._getPrivateKey(e),c=u.get(this).dek,l=i.pki.decryptRsaPrivateKey(s,c),d=await n(r,l),f=i.pkcs7.createEnvelopedData();f.addRecipient(d),f.content=i.util.createBuffer(t),f.encrypt();const h=i.asn1.toDer(f.toAsn1()).getBytes();return a(h,"ascii")}async decrypt(e){if(!(e instanceof Uint8Array))throw o(new Error("CMS data is required"),"ERR_INVALID_PARAMS");let t;try{const r=i.util.createBuffer(c(e,"ascii")),n=i.asn1.fromDer(r);t=i.pkcs7.messageFromAsn1(n)}catch(e){throw o(new Error("Invalid CMS: "+e.message),"ERR_INVALID_CMS")}const r=t.recipients.filter((e=>e.issuer.find((e=>"O"===e.shortName&&"ipfs"===e.value)))).filter((e=>e.issuer.find((e=>"CN"===e.shortName)))).map((e=>({recipient:e,keyId:e.issuer.find((e=>"CN"===e.shortName)).value}))),n=await s(r,(async e=>{try{if(await this.keychain.findKeyById(e.keyId))return!0}catch(e){return!1}return!1}));if(!n){const e=r.map((e=>e.keyId));throw o(new Error("Decryption needs one of the key(s): "+e.join(", ")),"ERR_MISSING_KEYS",{missingKeys:e})}const l=await this.keychain.findKeyById(n.keyId);if(!l)throw o(new Error("No key available to decrypto"),"ERR_NO_KEY");const d=await this.keychain._getPrivateKey(l.name),f=u.get(this).dek,h=i.pki.decryptRsaPrivateKey(d,f);return t.decrypt(n.recipient,h),a(t.content.getBytes(),"ascii")}}},{"node-forge/lib/pkcs7":"2u5SG","node-forge/lib/pbe":"gUP8s","node-forge/lib/forge":"4OuPD","./util":"hlA8C","err-code":"chZjB","uint8arrays/from-string":"dF7Y4","uint8arrays/to-string":"hC8JB"}],"2u5SG":[function(e,t,r){var i=e("./forge");e("./aes"),e("./asn1"),e("./des"),e("./oids"),e("./pem"),e("./pkcs7asn1"),e("./random"),e("./util"),e("./x509");var n=i.asn1,s=t.exports=i.pkcs7=i.pkcs7||{};function o(e){var t={},r=[];if(!n.validate(e,s.asn1.recipientInfoValidator,t,r)){var o=new Error("Cannot read PKCS#7 RecipientInfo. ASN.1 object is not an PKCS#7 RecipientInfo.");throw o.errors=r,o}return{version:t.version.charCodeAt(0),issuer:i.pki.RDNAttributesAsArray(t.issuer),serialNumber:i.util.createBuffer(t.serial).toHex(),encryptedContent:{algorithm:n.derToOid(t.encAlgorithm),parameter:t.encParameter.value,content:t.encKey}}}function a(e){for(var t,r=[],s=0;s0){for(var r=n.create(n.Class.CONTEXT_SPECIFIC,1,!0,[]),s=0;s=r&&o0&&o.value[0].value.push(n.create(n.Class.CONTEXT_SPECIFIC,0,!0,t)),s.length>0&&o.value[0].value.push(n.create(n.Class.CONTEXT_SPECIFIC,1,!0,s)),o.value[0].value.push(n.create(n.Class.UNIVERSAL,n.Type.SET,!0,e.signerInfos)),n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[n.create(n.Class.UNIVERSAL,n.Type.OID,!1,n.oidToDer(e.type).getBytes()),o])},addSigner:function(t){var r=t.issuer,n=t.serialNumber;if(t.certificate){var s=t.certificate;"string"==typeof s&&(s=i.pki.certificateFromPem(s)),r=s.issuer.attributes,n=s.serialNumber}var o=t.key;if(!o)throw new Error("Could not add PKCS#7 signer; no private key specified.");"string"==typeof o&&(o=i.pki.privateKeyFromPem(o));var a=t.digestAlgorithm||i.pki.oids.sha1;switch(a){case i.pki.oids.sha1:case i.pki.oids.sha256:case i.pki.oids.sha384:case i.pki.oids.sha512:case i.pki.oids.md5:break;default:throw new Error("Could not add PKCS#7 signer; unknown message digest algorithm: "+a)}var c=t.authenticatedAttributes||[];if(c.length>0){for(var u=!1,l=!1,d=0;d128)throw new Error('Invalid "nsComment" content.');e.value=n.create(n.Class.UNIVERSAL,n.Type.IA5STRING,!1,e.comment)}else if("subjectKeyIdentifier"===e.name&&t.cert){var h=t.cert.generateSubjectKeyIdentifier();e.subjectKeyIdentifier=h.toHex(),e.value=n.create(n.Class.UNIVERSAL,n.Type.OCTETSTRING,!1,h.getBytes())}else if("authorityKeyIdentifier"===e.name&&t.cert){e.value=n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[]);l=e.value.value;if(e.keyIdentifier){var p=!0===e.keyIdentifier?t.cert.generateSubjectKeyIdentifier().getBytes():e.keyIdentifier;l.push(n.create(n.Class.CONTEXT_SPECIFIC,0,!1,p))}if(e.authorityCertIssuer){var y=[n.create(n.Class.CONTEXT_SPECIFIC,4,!0,[g(!0===e.authorityCertIssuer?t.cert.issuer:e.authorityCertIssuer)])];l.push(n.create(n.Class.CONTEXT_SPECIFIC,1,!0,y))}if(e.serialNumber){var m=i.util.hexToBytes(!0===e.serialNumber?t.cert.serialNumber:e.serialNumber);l.push(n.create(n.Class.CONTEXT_SPECIFIC,2,!1,m))}}else if("cRLDistributionPoints"===e.name){e.value=n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[]);l=e.value.value;var b,v=n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[]),w=n.create(n.Class.CONTEXT_SPECIFIC,0,!0,[]);for(f=0;f2)throw new Error("Cannot read notBefore/notAfter validity times; more than two times were provided in the certificate.");if(d.length<2)throw new Error("Cannot read notBefore/notAfter validity times; they were not provided as either UTCTime or GeneralizedTime.");if(c.validity.notBefore=d[0],c.validity.notAfter=d[1],c.tbsCertificate=r.tbsCertificate,t){var f;if(c.md=null,c.signatureOid in o)switch(o[c.signatureOid]){case"sha1WithRSAEncryption":c.md=i.md.sha1.create();break;case"md5WithRSAEncryption":c.md=i.md.md5.create();break;case"sha256WithRSAEncryption":case"RSASSA-PSS":c.md=i.md.sha256.create();break;case"sha384WithRSAEncryption":c.md=i.md.sha384.create();break;case"sha512WithRSAEncryption":c.md=i.md.sha512.create()}if(null===c.md)throw(f=new Error("Could not compute certificate digest. Unknown signature OID.")).signatureOid=c.signatureOid,f;var g=n.toDer(c.tbsCertificate);c.md.update(g.getBytes())}var m=i.md.sha1.create();c.issuer.getField=function(e){return h(c.issuer,e)},c.issuer.addField=function(e){y([e]),c.issuer.attributes.push(e)},c.issuer.attributes=s.RDNAttributesAsArray(r.certIssuer,m),r.certIssuerUniqueId&&(c.issuer.uniqueId=r.certIssuerUniqueId),c.issuer.hash=m.digest().toHex();var b=i.md.sha1.create();return c.subject.getField=function(e){return h(c.subject,e)},c.subject.addField=function(e){y([e]),c.subject.attributes.push(e)},c.subject.attributes=s.RDNAttributesAsArray(r.certSubject,b),r.certSubjectUniqueId&&(c.subject.uniqueId=r.certSubjectUniqueId),c.subject.hash=b.digest().toHex(),r.certExtensions?c.extensions=s.certificateExtensionsFromAsn1(r.certExtensions):c.extensions=[],c.publicKey=s.publicKeyFromAsn1(r.subjectPublicKeyInfo),c},s.certificateExtensionsFromAsn1=function(e){for(var t=[],r=0;r1&&(r=c.value.charCodeAt(1),s=c.value.length>2?c.value.charCodeAt(2):0),t.digitalSignature=128==(128&r),t.nonRepudiation=64==(64&r),t.keyEncipherment=32==(32&r),t.dataEncipherment=16==(16&r),t.keyAgreement=8==(8&r),t.keyCertSign=4==(4&r),t.cRLSign=2==(2&r),t.encipherOnly=1==(1&r),t.decipherOnly=128==(128&s)}else if("basicConstraints"===t.name){(c=n.fromDer(t.value)).value.length>0&&c.value[0].type===n.Type.BOOLEAN?t.cA=0!==c.value[0].value.charCodeAt(0):t.cA=!1;var a=null;c.value.length>0&&c.value[0].type===n.Type.INTEGER?a=c.value[0].value:c.value.length>1&&(a=c.value[1].value),null!==a&&(t.pathLenConstraint=n.derToInteger(a))}else if("extKeyUsage"===t.name)for(var c=n.fromDer(t.value),u=0;u1&&(r=c.value.charCodeAt(1)),t.client=128==(128&r),t.server=64==(64&r),t.email=32==(32&r),t.objsign=16==(16&r),t.reserved=8==(8&r),t.sslCA=4==(4&r),t.emailCA=2==(2&r),t.objCA=1==(1&r)}else if("subjectAltName"===t.name||"issuerAltName"===t.name){var d;t.altNames=[];c=n.fromDer(t.value);for(var f=0;f=w&&e<_?n.create(n.Class.UNIVERSAL,n.Type.UTCTIME,!1,n.dateToUtcTime(e)):n.create(n.Class.UNIVERSAL,n.Type.GENERALIZEDTIME,!1,n.dateToGeneralizedTime(e))}s.getTBSCertificate=function(e){var t=E(e.validity.notBefore),r=E(e.validity.notAfter),o=n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[n.create(n.Class.CONTEXT_SPECIFIC,0,!0,[n.create(n.Class.UNIVERSAL,n.Type.INTEGER,!1,n.integerToDer(e.version).getBytes())]),n.create(n.Class.UNIVERSAL,n.Type.INTEGER,!1,i.util.hexToBytes(e.serialNumber)),n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[n.create(n.Class.UNIVERSAL,n.Type.OID,!1,n.oidToDer(e.siginfo.algorithmOid).getBytes()),b(e.siginfo.algorithmOid,e.siginfo.parameters)]),g(e.issuer),n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[t,r]),g(e.subject),s.publicKeyToAsn1(e.publicKey)]);return e.issuer.uniqueId&&o.value.push(n.create(n.Class.CONTEXT_SPECIFIC,1,!0,[n.create(n.Class.UNIVERSAL,n.Type.BITSTRING,!1,String.fromCharCode(0)+e.issuer.uniqueId)])),e.subject.uniqueId&&o.value.push(n.create(n.Class.CONTEXT_SPECIFIC,2,!0,[n.create(n.Class.UNIVERSAL,n.Type.BITSTRING,!1,String.fromCharCode(0)+e.subject.uniqueId)])),e.extensions.length>0&&o.value.push(s.certificateExtensionsToAsn1(e.extensions)),o},s.getCertificationRequestInfo=function(e){return n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[n.create(n.Class.UNIVERSAL,n.Type.INTEGER,!1,n.integerToDer(e.version).getBytes()),g(e.subject),s.publicKeyToAsn1(e.publicKey),v(e)])},s.distinguishedNameToAsn1=function(e){return g(e)},s.certificateToAsn1=function(e){var t=e.tbsCertificate||s.getTBSCertificate(e);return n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[t,n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[n.create(n.Class.UNIVERSAL,n.Type.OID,!1,n.oidToDer(e.signatureOid).getBytes()),b(e.signatureOid,e.signatureParameters)]),n.create(n.Class.UNIVERSAL,n.Type.BITSTRING,!1,String.fromCharCode(0)+e.signature)])},s.certificateExtensionsToAsn1=function(e){var t=n.create(n.Class.CONTEXT_SPECIFIC,3,!0,[]),r=n.create(n.Class.UNIVERSAL,n.Type.SEQUENCE,!0,[]);t.value.push(r);for(var i=0;il.validity.notAfter)&&(c={message:"Certificate is not valid yet or has expired.",error:s.certificateError.certificate_expired,notBefore:l.validity.notBefore,notAfter:l.validity.notAfter,now:o}),null===c){if(null===(d=t[0]||e.getIssuer(l))&&l.isIssuer(l)&&(f=!0,d=l),d){var h=d;i.util.isArray(h)||(h=[h]);for(var p=!1;!p&&h.length>0;){d=h.shift();try{p=d.verify(l)}catch(e){}}p||(c={message:"Certificate signature is invalid.",error:s.certificateError.bad_certificate})}null!==c||d&&!f||e.hasCertificate(l)||(c={message:"Certificate is not trusted.",error:s.certificateError.unknown_ca})}if(null===c&&d&&!l.isIssuer(d)&&(c={message:"Certificate issuer is invalid.",error:s.certificateError.bad_certificate}),null===c)for(var g={keyUsage:!0,basicConstraints:!0},y=0;null===c&&yb.pathLenConstraint&&(c={message:"Certificate basicConstraints pathLenConstraint violated.",error:s.certificateError.bad_certificate})}var w=null===c||c.error,_=r.verify?r.verify(w,u,n):w;if(!0!==_)throw!0===w&&(c={message:"The application rejected the certificate.",error:s.certificateError.bad_certificate}),(_||0===_)&&("object"!=typeof _||i.util.isArray(_)?"string"==typeof _&&(c.error=_):(_.message&&(c.message=_.message),_.error&&(c.error=_.error))),c;c=null,a=!1,++u}while(t.length>0);return!0}},{"./forge":"4OuPD","./aes":"1SAd7","./asn1":"bcsXQ","./des":"6e2qD","./md":"fYbz5","./mgf":"igoKv","./oids":"7VPL4","./pem":"9qqi9","./pss":"fYf6X","./rsa":"9ROH2","./util":"df43p"}],igoKv:[function(e,t,r){var i=e("./forge");e("./mgf1"),t.exports=i.mgf=i.mgf||{},i.mgf.mgf1=i.mgf1},{"./forge":"4OuPD","./mgf1":"d3pVa"}],d3pVa:[function(e,t,r){var i=e("./forge");e("./util"),i.mgf=i.mgf||{},(t.exports=i.mgf.mgf1=i.mgf1=i.mgf1||{}).create=function(e){return{generate:function(t,r){for(var n=new i.util.ByteBuffer,s=Math.ceil(r/e.digestLength),o=0;o>8*f-d&255;return(w=String.fromCharCode(w.charCodeAt(0)&~_)+w.substr(1))+g+String.fromCharCode(188)},verify:function(e,o,a){var c,u=a-1,l=Math.ceil(u/8);if(o=o.substr(-l),l>8*l-u&255;if(0!=(f.charCodeAt(0)&p))throw new Error("Bits beyond keysize not zero as expected.");var g=n.generate(h,d),y="";for(c=0;c{const r=i.setRsaPublicKey(t.n,t.e),n=i.createCertificate();n.publicKey=r,n.serialNumber="01",n.validity.notBefore=new Date,n.validity.notAfter=new Date,n.validity.notAfter.setFullYear(n.validity.notBefore.getFullYear()+10);const s=[{name:"organizationName",value:"ipfs"},{shortName:"OU",value:"keystore"},{name:"commonName",value:e.id}];return n.setSubject(s),n.setIssuer(s),n.setExtensions([{name:"basicConstraints",cA:!0},{name:"keyUsage",keyCertSign:!0,digitalSignature:!0,nonRepudiation:!0,keyEncipherment:!0,dataEncipherment:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0,codeSigning:!0,emailProtection:!0,timeStamping:!0},{name:"nsCertType",client:!0,server:!0,email:!0,objsign:!0,sslCA:!0,emailCA:!0,objCA:!0}]),n.sign(t),n},findAsync:async function(e,t){const r=e.map(t);return e[(await Promise.all(r)).findIndex((e=>e))]}}},{"node-forge/lib/x509":"f2ToB","node-forge/lib/forge":"4OuPD"}],jy74B:[function(e,t,r){"use strict";const i=e("merge-options"),{pipe:n}=e("it-pipe"),{tap:s}=e("streaming-iterables"),o=e("./old-peers"),{METRICS:a}=e("../constants"),c=e("./stats"),u=["dataReceived","dataSent"],l={in:"dataReceived",out:"dataSent"};class d{constructor(e){this._options=i(a,e),this._globalStats=new c(u,this._options),this._peerStats=new Map,this._protocolStats=new Map,this._oldPeers=o(this._options.maxOldPeersRetention),this._running=!1,this._onMessage=this._onMessage.bind(this),this._connectionManager=e.connectionManager,this._connectionManager.on("peer:disconnect",(e=>{this.onPeerDisconnected(e.remotePeer)}))}start(){this._running=!0}stop(){this._running=!1,this._globalStats.stop();for(const e of this._peerStats.values())e.stop();for(const e of this._protocolStats.values())e.stop()}get global(){return this._globalStats}get peers(){return Array.from(this._peerStats.keys())}forPeer(e){const t=e.toB58String();return this._peerStats.get(t)||this._oldPeers.get(t)}get protocols(){return Array.from(this._protocolStats.keys())}forProtocol(e){return this._protocolStats.get(e)}onPeerDisconnected(e){const t=e.toB58String(),r=this._peerStats.get(t);r&&(r.stop(),this._peerStats.delete(t),this._oldPeers.set(t,r))}_onMessage({remotePeer:e,protocol:t,direction:r,dataLength:i}){if(!this._running)return;const n=l[r];let s=this.forPeer(e);if(s||(s=new c(u,this._options),this._peerStats.set(e.toB58String(),s)),s.push(n,i),this._globalStats.push(n,i),t){let e=this.forProtocol(t);e||(e=new c(u,this._options),this._protocolStats.set(t,e)),e.push(n,i)}}updatePlaceholder(e,t){if(!this._running)return;const r=this.forPeer(e),i=t.toB58String(),n=this.forPeer(t);let s=r;n&&(s=d.mergeStats(n,s),this._oldPeers.delete(i)),this._peerStats.delete(e.toB58String()),this._peerStats.set(i,s),s.start()}trackStream({stream:e,remotePeer:t,protocol:r}){const i=this,o=e.source;e.source=s((e=>i._onMessage({remotePeer:t,protocol:r,direction:"in",dataLength:e.length})))(o);const a=e.sink;return e.sink=e=>n(e,s((e=>i._onMessage({remotePeer:t,protocol:r,direction:"out",dataLength:e.length}))),a),e}static mergeStats(e,t){return e.stop(),t.stop(),e._queue=[...e._queue,...t._queue],e}}t.exports=d},{"merge-options":"fupyv","it-pipe":"giKBQ","streaming-iterables":"jrrai","./old-peers":"98TJE","../constants":"92Vak","./stats":"e6AW2"}],"98TJE":[function(e,t,r){"use strict";const i=e("hashlru");t.exports=e=>{const t=i(e);return t.delete=t.remove,t}},{hashlru:"kBj5c"}],e6AW2:[function(e,t,r){"use strict";const{EventEmitter:i}=e("events"),{BigNumber:n}=e("bignumber.js"),s=e("@vascosantos/moving-average"),o=e("retimer");t.exports=class extends i{constructor(e,t){super(),this._options=t,this._queue=[],this._stats={dataReceived:n(0),dataSent:n(0)},this._frequencyLastTime=Date.now(),this._frequencyAccumulators={},this._movingAverages={},this._update=this._update.bind(this);const r=this._options.movingAverageIntervals;for(let t=0;t{this._updateFrequencyFor(r,t,e)})),this._frequencyLastTime=e}_updateFrequencyFor(e,t,r){const i=this._frequencyAccumulators[e]||0;this._frequencyAccumulators[e]=0;const n=i/(t||1)*1e3;let o=this._movingAverages[e];o||(o=this._movingAverages[e]={});const a=this._options.movingAverageIntervals;for(let e=0;e0||e===t?t:t-1}function g(e){for(var t,r,i=1,n=e.length,s=e[0]+"";iu^r?1:-1;for(a=(c=n.length)<(u=s.length)?c:u,o=0;os[o]^r?1:-1;return c==u?0:c>u^r?1:-1}function m(e,t,r,i){if(er||e!==s(e))throw Error(o+(i||"Argument")+("number"==typeof e?er?" out of range: ":" not an integer: ":" not a primitive number: ")+String(e))}function b(e){var t=e.c.length-1;return p(e.e/u)==t&&e.c[t]%2!=0}function v(e,t){return(e.length>1?e.charAt(0)+"."+e.slice(1):e)+(t<0?"e":"e+")+t}function w(e,t,r){var i,n;if(t<0){for(n=r+".";++t;n+=r);e=n+e}else if(++t>(i=e.length)){for(n=r,t-=i;--t;n+=r);e+=n}else tL?g.c=g.e=null:e.e=10;d/=10,c++);return void(c>L?g.c=g.e=null:(g.e=c,g.c=[e]))}p=String(e)}else{if(!i.test(p=String(e)))return E(g,p,f);g.s=45==p.charCodeAt(0)?(p=p.slice(1),-1):1}(c=p.indexOf("."))>-1&&(p=p.replace(".","")),(d=p.search(/e/i))>0?(c<0&&(c=d),c+=+p.slice(d+1),p=p.substring(0,d)):c<0&&(c=p.length)}else{if(m(t,2,z.length,"Base"),10==t)return $(g=new V(e),j+g.e+1,D);if(p=String(e),f="number"==typeof e){if(0*e!=0)return E(g,p,f,t);if(g.s=1/e<0?(p=p.slice(1),-1):1,V.DEBUG&&p.replace(/^0\.0*|\./,"").length>15)throw Error(a+e)}else g.s=45===p.charCodeAt(0)?(p=p.slice(1),-1):1;for(r=z.slice(0,t),c=d=0,h=p.length;dc){c=h;continue}}else if(!o&&(p==p.toUpperCase()&&(p=p.toLowerCase())||p==p.toLowerCase()&&(p=p.toUpperCase()))){o=!0,d=-1,c=0;continue}return E(g,String(e),f,t)}f=!1,(c=(p=_(p,t,10,g.s)).indexOf("."))>-1?p=p.replace(".",""):c=p.length}for(d=0;48===p.charCodeAt(d);d++);for(h=p.length;48===p.charCodeAt(--h););if(p=p.slice(d,++h)){if(h-=d,f&&V.DEBUG&&h>15&&(e>l||e!==s(e)))throw Error(a+g.s*e);if((c=c-d-1)>L)g.c=g.e=null;else if(c=x)?v(c,o):w(c,o,"0");else if(s=(e=$(new V(e),t,r)).e,a=(c=g(e.c)).length,1==i||2==i&&(t<=s||s<=M)){for(;aa){if(--t>0)for(c+=".";t--;c+="0");}else if((t+=s-a)>0)for(s+1==a&&(c+=".");t--;c+="0");return e.s<0&&n?"-"+c:c}function G(e,t){for(var r,i=1,n=new V(e[0]);i=10;n/=10,i++);return(r=i+r*u-1)>L?e.c=e.e=null:r=10;f/=10,o++);if((a=t-o)<0)a+=u,l=t,g=(h=y[p=0])/m[o-l-1]%10|0;else if((p=n((a+1)/u))>=y.length){if(!i)break e;for(;y.length<=p;y.push(0));h=g=0,o=1,l=(a%=u)-u+1}else{for(h=f=y[p],o=1;f>=10;f/=10,o++);g=(l=(a%=u)-u+o)<0?0:h/m[o-l-1]%10|0}if(i=i||t<0||null!=y[p+1]||(l<0?h:h%m[o-l-1]),i=r<4?(g||i)&&(0==r||r==(e.s<0?3:2)):g>5||5==g&&(4==r||i||6==r&&(a>0?l>0?h/m[o-l]:0:y[p-1])%10&1||r==(e.s<0?8:7)),t<1||!y[0])return y.length=0,i?(t-=e.e+1,y[0]=m[(u-t%u)%u],e.e=-t||0):y[0]=e.e=0,e;if(0==a?(y.length=p,f=1,p--):(y.length=p+1,f=m[u-a],y[p]=l>0?s(h/m[o-l]%m[l])*f:0),i)for(;;){if(0==p){for(a=1,l=y[0];l>=10;l/=10,a++);for(l=y[0]+=f,f=1;l>=10;l/=10,f++);a!=f&&(e.e++,y[0]==c&&(y[0]=1));break}if(y[p]+=f,y[p]!=c)break;y[p--]=0,f=1}for(a=y.length;0===y[--a];y.pop());}e.e>L?e.c=e.e=null:e.e=x?v(t,r):w(t,r,"0"),e.s<0?"-"+t:t)}return V.clone=e,V.ROUND_UP=0,V.ROUND_DOWN=1,V.ROUND_CEIL=2,V.ROUND_FLOOR=3,V.ROUND_HALF_UP=4,V.ROUND_HALF_DOWN=5,V.ROUND_HALF_EVEN=6,V.ROUND_HALF_CEIL=7,V.ROUND_HALF_FLOOR=8,V.EUCLID=9,V.config=V.set=function(e){var t,r;if(null!=e){if("object"!=typeof e)throw Error(o+"Object expected: "+e);if(e.hasOwnProperty(t="DECIMAL_PLACES")&&(m(r=e[t],0,h,t),j=r),e.hasOwnProperty(t="ROUNDING_MODE")&&(m(r=e[t],0,8,t),D=r),e.hasOwnProperty(t="EXPONENTIAL_AT")&&((r=e[t])&&r.pop?(m(r[0],-h,0,t),m(r[1],0,h,t),M=r[0],x=r[1]):(m(r,-h,h,t),M=-(x=r<0?-r:r))),e.hasOwnProperty(t="RANGE"))if((r=e[t])&&r.pop)m(r[0],-h,-1,t),m(r[1],1,h,t),B=r[0],L=r[1];else{if(m(r,-h,h,t),!r)throw Error(o+t+" cannot be zero: "+r);B=-(L=r<0?-r:r)}if(e.hasOwnProperty(t="CRYPTO")){if((r=e[t])!==!!r)throw Error(o+t+" not true or false: "+r);if(r){if("undefined"==typeof crypto||!crypto||!crypto.getRandomValues&&!crypto.randomBytes)throw N=!r,Error(o+"crypto unavailable");N=r}else N=r}if(e.hasOwnProperty(t="MODULO_MODE")&&(m(r=e[t],0,9,t),U=r),e.hasOwnProperty(t="POW_PRECISION")&&(m(r=e[t],0,h,t),F=r),e.hasOwnProperty(t="FORMAT")){if("object"!=typeof(r=e[t]))throw Error(o+t+" not an object: "+r);K=r}if(e.hasOwnProperty(t="ALPHABET")){if("string"!=typeof(r=e[t])||/^.?$|[+\-.\s]|(.).*\1/.test(r))throw Error(o+t+" invalid: "+r);z=r}}return{DECIMAL_PLACES:j,ROUNDING_MODE:D,EXPONENTIAL_AT:[M,x],RANGE:[B,L],CRYPTO:N,MODULO_MODE:U,POW_PRECISION:F,FORMAT:K,ALPHABET:z}},V.isBigNumber=function(e){if(!e||!0!==e._isBigNumber)return!1;if(!V.DEBUG)return!0;var t,r,i=e.c,n=e.e,a=e.s;e:if("[object Array]"=={}.toString.call(i)){if((1===a||-1===a)&&n>=-h&&n<=h&&n===s(n)){if(0===i[0]){if(0===n&&1===i.length)return!0;break e}if((t=(n+1)%u)<1&&(t+=u),String(i[0]).length==t){for(t=0;t=c||r!==s(r))break e;if(0!==r)return!0}}}else if(null===i&&null===n&&(null===a||1===a||-1===a))return!0;throw Error(o+"Invalid BigNumber: "+e)},V.maximum=V.max=function(){return G(arguments,O.lt)},V.minimum=V.min=function(){return G(arguments,O.gt)},V.random=(S=9007199254740992,T=Math.random()*S&2097151?function(){return s(Math.random()*S)}:function(){return 8388608*(1073741824*Math.random()|0)+(8388608*Math.random()|0)},function(e){var t,r,i,a,c,l=0,f=[],p=new V(C);if(null==e?e=j:m(e,0,h),a=n(e/u),N)if(crypto.getRandomValues){for(t=crypto.getRandomValues(new Uint32Array(a*=2));l>>11))>=9e15?(r=crypto.getRandomValues(new Uint32Array(2)),t[l]=r[0],t[l+1]=r[1]):(f.push(c%1e14),l+=2);l=a/2}else{if(!crypto.randomBytes)throw N=!1,Error(o+"crypto unavailable");for(t=crypto.randomBytes(a*=7);l=9e15?crypto.randomBytes(7).copy(t,l):(f.push(c%1e14),l+=7);l=a/7}if(!N)for(;l=10;c/=10,l++);lr-1&&(null==o[n+1]&&(o[n+1]=0),o[n+1]+=o[n]/r|0,o[n]%=r)}return o.reverse()}return function(i,n,s,o,a){var c,u,l,d,f,h,p,y,m=i.indexOf("."),b=j,v=D;for(m>=0&&(d=F,F=0,i=i.replace(".",""),h=(y=new V(n)).pow(i.length-m),F=d,y.c=t(w(g(h.c),h.e,"0"),10,s,e),y.e=y.c.length),l=d=(p=t(i,n,s,a?(c=z,e):(c=e,z))).length;0==p[--d];p.pop());if(!p[0])return c.charAt(0);if(m<0?--l:(h.c=p,h.e=l,h.s=o,p=(h=r(h,y,b,v,s)).c,f=h.r,l=h.e),m=p[u=l+b+1],d=s/2,f=f||u<0||null!=p[u+1],f=v<4?(null!=m||f)&&(0==v||v==(h.s<0?3:2)):m>d||m==d&&(4==v||f||6==v&&1&p[u-1]||v==(h.s<0?8:7)),u<1||!p[0])i=f?w(c.charAt(1),-b,c.charAt(0)):c.charAt(0);else{if(p.length=u,f)for(--s;++p[--u]>s;)p[u]=0,u||(++l,p=[1].concat(p));for(d=p.length;!p[--d];);for(m=0,i="";m<=d;i+=c.charAt(p[m++]));i=w(i,l,c.charAt(0))}return i}}(),r=function(){function e(e,t,r){var i,n,s,o,a=0,c=e.length,u=t%f,l=t/f|0;for(e=e.slice();c--;)a=((n=u*(s=e[c]%f)+(i=l*s+(o=e[c]/f|0)*u)%f*f+a)/r|0)+(i/f|0)+l*o,e[c]=n%r;return a&&(e=[a].concat(e)),e}function t(e,t,r,i){var n,s;if(r!=i)s=r>i?1:-1;else for(n=s=0;nt[n]?1:-1;break}return s}function r(e,t,r,i){for(var n=0;r--;)e[r]-=n,n=e[r]1;e.splice(0,1));}return function(i,n,o,a,l){var d,f,h,g,y,m,b,v,w,_,E,S,T,A,k,I,R,P=i.s==n.s?1:-1,O=i.c,C=n.c;if(!(O&&O[0]&&C&&C[0]))return new V(i.s&&n.s&&(O?!C||O[0]!=C[0]:C)?O&&0==O[0]||!C?0*P:P/0:NaN);for(w=(v=new V(P)).c=[],P=o+(f=i.e-n.e)+1,l||(l=c,f=p(i.e/u)-p(n.e/u),P=P/u|0),h=0;C[h]==(O[h]||0);h++);if(C[h]>(O[h]||0)&&f--,P<0)w.push(1),g=!0;else{for(A=O.length,I=C.length,h=0,P+=2,(y=s(l/(C[0]+1)))>1&&(C=e(C,y,l),O=e(O,y,l),I=C.length,A=O.length),T=I,E=(_=O.slice(0,I)).length;E=l/2&&k++;do{if(y=0,(d=t(C,_,I,E))<0){if(S=_[0],I!=E&&(S=S*l+(_[1]||0)),(y=s(S/k))>1)for(y>=l&&(y=l-1),b=(m=e(C,y,l)).length,E=_.length;1==t(m,_,b,E);)y--,r(m,I=10;P/=10,h++);$(v,o+(v.e=h+f*u-1)+1,a,g)}else v.e=f,v.r=+g;return v}}(),A=/^(-?)0([xbo])(?=\w[\w.]*$)/i,k=/^([^.]+)\.$/,I=/^\.([^.]+)$/,R=/^-?(Infinity|NaN)$/,P=/^\s*\+(?=[\w.])|^\s+|\s+$/g,E=function(e,t,r,i){var n,s=r?t:t.replace(P,"");if(R.test(s))e.s=isNaN(s)?null:s<0?-1:1;else{if(!r&&(s=s.replace(A,(function(e,t,r){return n="x"==(r=r.toLowerCase())?16:"b"==r?2:8,i&&i!=n?e:t})),i&&(n=i,s=s.replace(k,"$1").replace(I,"0.$1")),t!=s))return new V(s,n);if(V.DEBUG)throw Error(o+"Not a"+(i?" base "+i:"")+" number: "+t);e.s=null}e.c=e.e=null},O.absoluteValue=O.abs=function(){var e=new V(this);return e.s<0&&(e.s=1),e},O.comparedTo=function(e,t){return y(this,new V(e,t))},O.decimalPlaces=O.dp=function(e,t){var r,i,n,s=this;if(null!=e)return m(e,0,h),null==t?t=D:m(t,0,8),$(new V(s),e+s.e+1,t);if(!(r=s.c))return null;if(i=((n=r.length-1)-p(this.e/u))*u,n=r[n])for(;n%10==0;n/=10,i--);return i<0&&(i=0),i},O.dividedBy=O.div=function(e,t){return r(this,new V(e,t),j,D)},O.dividedToIntegerBy=O.idiv=function(e,t){return r(this,new V(e,t),0,1)},O.exponentiatedBy=O.pow=function(e,t){var r,i,a,c,l,d,f,h,p=this;if((e=new V(e)).c&&!e.isInteger())throw Error(o+"Exponent not an integer: "+W(e));if(null!=t&&(t=new V(t)),l=e.e>14,!p.c||!p.c[0]||1==p.c[0]&&!p.e&&1==p.c.length||!e.c||!e.c[0])return h=new V(Math.pow(+W(p),l?2-b(e):+W(e))),t?h.mod(t):h;if(d=e.s<0,t){if(t.c?!t.c[0]:!t.s)return new V(NaN);(i=!d&&p.isInteger()&&t.isInteger())&&(p=p.mod(t))}else{if(e.e>9&&(p.e>0||p.e<-1||(0==p.e?p.c[0]>1||l&&p.c[1]>=24e7:p.c[0]<8e13||l&&p.c[0]<=9999975e7)))return c=p.s<0&&b(e)?-0:0,p.e>-1&&(c=1/c),new V(d?1/c:c);F&&(c=n(F/u+2))}for(l?(r=new V(.5),d&&(e.s=1),f=b(e)):f=(a=Math.abs(+W(e)))%2,h=new V(C);;){if(f){if(!(h=h.times(p)).c)break;c?h.c.length>c&&(h.c.length=c):i&&(h=h.mod(t))}if(a){if(0===(a=s(a/2)))break;f=a%2}else if($(e=e.times(r),e.e+1,1),e.e>14)f=b(e);else{if(0===(a=+W(e)))break;f=a%2}p=p.times(p),c?p.c&&p.c.length>c&&(p.c.length=c):i&&(p=p.mod(t))}return i?h:(d&&(h=C.div(h)),t?h.mod(t):c?$(h,F,D,undefined):h)},O.integerValue=function(e){var t=new V(this);return null==e?e=D:m(e,0,8),$(t,t.e+1,e)},O.isEqualTo=O.eq=function(e,t){return 0===y(this,new V(e,t))},O.isFinite=function(){return!!this.c},O.isGreaterThan=O.gt=function(e,t){return y(this,new V(e,t))>0},O.isGreaterThanOrEqualTo=O.gte=function(e,t){return 1===(t=y(this,new V(e,t)))||0===t},O.isInteger=function(){return!!this.c&&p(this.e/u)>this.c.length-2},O.isLessThan=O.lt=function(e,t){return y(this,new V(e,t))<0},O.isLessThanOrEqualTo=O.lte=function(e,t){return-1===(t=y(this,new V(e,t)))||0===t},O.isNaN=function(){return!this.s},O.isNegative=function(){return this.s<0},O.isPositive=function(){return this.s>0},O.isZero=function(){return!!this.c&&0==this.c[0]},O.minus=function(e,t){var r,i,n,s,o=this,a=o.s;if(t=(e=new V(e,t)).s,!a||!t)return new V(NaN);if(a!=t)return e.s=-t,o.plus(e);var l=o.e/u,d=e.e/u,f=o.c,h=e.c;if(!l||!d){if(!f||!h)return f?(e.s=-t,e):new V(h?o:NaN);if(!f[0]||!h[0])return h[0]?(e.s=-t,e):new V(f[0]?o:3==D?-0:0)}if(l=p(l),d=p(d),f=f.slice(),a=l-d){for((s=a<0)?(a=-a,n=f):(d=l,n=h),n.reverse(),t=a;t--;n.push(0));n.reverse()}else for(i=(s=(a=f.length)<(t=h.length))?a:t,a=t=0;t0)for(;t--;f[r++]=0);for(t=c-1;i>a;){if(f[--i]=0;){for(r=0,y=S[n]%w,m=S[n]/w|0,s=n+(o=l);s>n;)r=((d=y*(d=E[--o]%w)+(a=m*d+(h=E[o]/w|0)*y)%w*w+b[s]+r)/v|0)+(a/w|0)+m*h,b[s--]=d%v;b[s]=r}return r?++i:b.splice(0,1),H(e,b,i)},O.negated=function(){var e=new V(this);return e.s=-e.s||null,e},O.plus=function(e,t){var r,i=this,n=i.s;if(t=(e=new V(e,t)).s,!n||!t)return new V(NaN);if(n!=t)return e.s=-t,i.minus(e);var s=i.e/u,o=e.e/u,a=i.c,l=e.c;if(!s||!o){if(!a||!l)return new V(n/0);if(!a[0]||!l[0])return l[0]?e:new V(a[0]?i:0*n)}if(s=p(s),o=p(o),a=a.slice(),n=s-o){for(n>0?(o=s,r=l):(n=-n,r=a),r.reverse();n--;r.push(0));r.reverse()}for((n=a.length)-(t=l.length)<0&&(r=l,l=a,a=r,t=n),n=0;t;)n=(a[--t]=a[t]+l[t]+n)/c|0,a[t]=c===a[t]?0:a[t]%c;return n&&(a=[n].concat(a),++o),H(e,a,o)},O.precision=O.sd=function(e,t){var r,i,n,s=this;if(null!=e&&e!==!!e)return m(e,1,h),null==t?t=D:m(t,0,8),$(new V(s),e,t);if(!(r=s.c))return null;if(i=(n=r.length-1)*u+1,n=r[n]){for(;n%10==0;n/=10,i--);for(n=r[0];n>=10;n/=10,i++);}return e&&s.e+1>i&&(i=s.e+1),i},O.shiftedBy=function(e){return m(e,-9007199254740991,l),this.times("1e"+e)},O.squareRoot=O.sqrt=function(){var e,t,i,n,s,o=this,a=o.c,c=o.s,u=o.e,l=j+4,d=new V("0.5");if(1!==c||!a||!a[0])return new V(!c||c<0&&(!a||a[0])?NaN:a?o:1/0);if(0==(c=Math.sqrt(+W(o)))||c==1/0?(((t=g(a)).length+u)%2==0&&(t+="0"),c=Math.sqrt(+t),u=p((u+1)/2)-(u<0||u%2),i=new V(t=c==1/0?"5e"+u:(t=c.toExponential()).slice(0,t.indexOf("e")+1)+u)):i=new V(c+""),i.c[0])for((c=(u=i.e)+l)<3&&(c=0);;)if(s=i,i=d.times(s.plus(r(o,s,l,1))),g(s.c).slice(0,c)===(t=g(i.c)).slice(0,c)){if(i.e0&&g>0){for(s=g%c||c,d=p.substr(0,s);s0&&(d+=l+p.slice(s)),h&&(d="-"+d)}i=f?d+(r.decimalSeparator||"")+((u=+r.fractionGroupSize)?f.replace(new RegExp("\\d{"+u+"}\\B","g"),"$&"+(r.fractionGroupSeparator||"")):f):d}return(r.prefix||"")+i+(r.suffix||"")},O.toFraction=function(e){var t,i,n,s,a,c,l,f,h,p,y,m,b=this,v=b.c;if(null!=e&&(!(l=new V(e)).isInteger()&&(l.c||1!==l.s)||l.lt(C)))throw Error(o+"Argument "+(l.isInteger()?"out of range: ":"not an integer: ")+W(l));if(!v)return new V(b);for(t=new V(C),h=i=new V(C),n=f=new V(C),m=g(v),a=t.e=m.length-b.e-1,t.c[0]=d[(c=a%u)<0?u+c:c],e=!e||l.comparedTo(t)>0?a>0?t:h:l,c=L,L=1/0,l=new V(m),f.c[0]=0;p=r(l,t,0,1),1!=(s=i.plus(p.times(n))).comparedTo(e);)i=n,n=s,h=f.plus(p.times(s=h)),f=s,t=l.minus(p.times(s=t)),l=s;return s=r(e.minus(i),n,0,1),f=f.plus(s.times(h)),i=i.plus(s.times(n)),f.s=h.s=b.s,y=r(h,n,a*=2,D).minus(b).abs().comparedTo(r(f,i,a,D).minus(b).abs())<1?[h,n]:[f,i],L=c,y},O.toNumber=function(){return+W(this)},O.toPrecision=function(e,t){return null!=e&&m(e,1,h),q(this,e,t,2)},O.toString=function(e){var t,r=this,i=r.s,n=r.e;return null===n?i?(t="Infinity",i<0&&(t="-"+t)):t="NaN":(null==e?t=n<=M||n>=x?v(g(r.c),n):w(g(r.c),n,"0"):10===e?t=w(g((r=$(new V(r),j+n+1,D)).c),r.e,"0"):(m(e,2,z.length,"Base"),t=_(w(g(r.c),n,"0"),10,e,i,!0)),i<0&&r.c[0]&&(t="-"+t)),t},O.valueOf=O.toJSON=function(){return W(this)},O._isBigNumber=!0,null!=t&&V.set(t),V}(),r.default=r.BigNumber=r,"function"==typeof define&&define.amd?define((function(){return r})):void 0!==t&&t.exports?t.exports=r:(e||(e="undefined"!=typeof self&&self?self:window),e.BigNumber=r)}(this)},{}],"2F3Pq":[function(e,t,r){"use strict";const i=Math.exp;t.exports=function(e){if("number"!=typeof e)throw new Error("must provide a timespan to the moving average constructor");if(e<=0)throw new Error("must provide a timespan > 0 to the moving average constructor");let t,r,n=0,s=0,o=0,a={};return a.push=function(a,c){if(r){const u=1-i(-(a-r)/e),l=c-t;t=u*c+(1-u)*t,n=(1-u)*(n+l*(u*l)),s=Math.sqrt(n),o=t+u*l}else t=c;r=a},a.movingAverage=function(){return t},a.variance=function(){return n},a.deviation=function(){return s},a.forecast=function(){return o},a}},{}],fdRaE:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:upgrader"),{error:i("libp2p:upgrader:err")}),s=e("err-code"),o=e("multistream-select"),{Connection:a}=e("libp2p-interfaces/src/connection"),c=e("peer-id"),{pipe:u}=e("it-pipe"),l=e("mutable-proxy"),{codes:d}=e("./errors");t.exports=class{constructor({localPeer:e,metrics:t,cryptos:r=new Map,muxers:i=new Map,onConnectionEnd:n=(()=>{}),onConnection:s=(()=>{})}){this.localPeer=e,this.metrics=t,this.cryptos=r,this.muxers=i,this.protector=null,this.protocols=new Map,this.onConnection=s,this.onConnectionEnd=n}async upgradeInbound(e){let t,r,i,s,o,a,c;if(this.metrics){({setTarget:a,proxy:c}=l());const t=(1e9*Math.random()).toString(36)+Date.now();a({toB58String:()=>t}),e=this.metrics.trackStream({stream:e,remotePeer:c})}n("Starting the inbound connection upgrade");let u=e;this.protector&&(u=await this.protector.protect(e));try{({conn:t,remotePeer:r,protocol:o}=await this._encryptInbound(this.localPeer,u,this.cryptos)),this.muxers.size?({stream:i,Muxer:s}=await this._multiplexInbound(t,this.muxers)):i=t}catch(t){throw n.error("Failed to upgrade inbound connection",t),await e.close(t),t}return this.metrics&&(this.metrics.updatePlaceholder(c,r),a(r)),n("Successfully upgraded inbound connection"),this._createConnection({cryptoProtocol:o,direction:"inbound",maConn:e,upgradedConn:i,Muxer:s,remotePeer:r})}async upgradeOutbound(e){const t=e.remoteAddr.getPeerId();if(!t)throw s(new Error("outbound connection must have a peer id"),d.ERR_INVALID_MULTIADDR);const r=c.createFromB58String(t);let i,o,a,u,f,h,p;if(this.metrics){({setTarget:h,proxy:p}=l());const t=(1e9*Math.random()).toString(36)+Date.now();h({toB58String:()=>t}),e=this.metrics.trackStream({stream:e,remotePeer:p})}n("Starting the outbound connection upgrade");let g=e;this.protector&&(g=await this.protector.protect(e));try{({conn:i,remotePeer:o,protocol:u}=await this._encryptOutbound(this.localPeer,g,r,this.cryptos)),this.muxers.size?({stream:a,Muxer:f}=await this._multiplexOutbound(i,this.muxers)):a=i}catch(t){throw n.error("Failed to upgrade outbound connection",t),await e.close(t),t}return this.metrics&&(this.metrics.updatePlaceholder(p,o),h(o)),n("Successfully upgraded outbound connection"),this._createConnection({cryptoProtocol:u,direction:"outbound",maConn:e,upgradedConn:a,Muxer:f,remotePeer:o})}_createConnection({cryptoProtocol:e,direction:t,maConn:r,upgradedConn:i,Muxer:c,remotePeer:l}){let f,h,p;c&&(f=new c({onStream:async e=>{if(!p)return;const r=new o.Listener(e);try{const{stream:i,protocol:s}=await r.handle(Array.from(this.protocols.keys()));n("%s: incoming stream opened on %s",t,s),this.metrics&&this.metrics.trackStream({stream:i,remotePeer:l,protocol:s}),p.addStream(e,{protocol:s}),this._onStream({connection:p,stream:{...e,...i},protocol:s})}catch(e){n.error(e)}},onStreamEnd:e=>{p.removeStream(e.id)}}),h=async e=>{n("%s: starting new stream on %s",t,e);const r=f.newStream(),i=new o.Dialer(r);try{const{stream:t,protocol:n}=await i.select(e);return this.metrics&&this.metrics.trackStream({stream:t,remotePeer:l,protocol:n}),{stream:{...r,...t},protocol:n}}catch(e){throw n.error("could not create new stream",e),s(e,d.ERR_UNSUPPORTED_PROTOCOL)}},u(i,f,i).catch(n.error));const g=r.timeline;r.timeline=new Proxy(g,{set:(...e)=>(p&&"close"===e[1]&&e[2]&&!g.close&&(async()=>{try{"open"===p.stat.status&&await p.close()}catch(e){n.error(e)}finally{this.onConnectionEnd(p)}})(),Reflect.set(...e))}),r.timeline.upgraded=Date.now();const y=()=>{throw s(new Error("connection is not multiplexed"),"ERR_CONNECTION_NOT_MULTIPLEXED")};return p=new a({localAddr:r.localAddr,remoteAddr:r.remoteAddr,localPeer:this.localPeer,remotePeer:l,stat:{direction:t,timeline:r.timeline,multiplexer:c&&c.multicodec,encryption:e},newStream:h||y,getStreams:()=>f?f.streams:y(),close:async()=>{await r.close(),f&&f.streams.map((e=>e.abort()))}}),this.onConnection(p),p}_onStream({connection:e,stream:t,protocol:r}){this.protocols.get(r)({connection:e,stream:t,protocol:r})}async _encryptInbound(e,t,r){const i=new o.Listener(t),a=Array.from(r.keys());n("handling inbound crypto protocol selection",a);try{const{stream:t,protocol:s}=await i.handle(a),o=r.get(s);if(n("encrypting inbound connection..."),!o)throw new Error(`no crypto module found for ${s}`);return{...await o.secureInbound(e,t),protocol:s}}catch(e){throw s(e,d.ERR_ENCRYPTION_FAILED)}}async _encryptOutbound(e,t,r,i){const a=new o.Dialer(t),c=Array.from(i.keys());n("selecting outbound crypto protocol",c);try{const{stream:t,protocol:s}=await a.select(c),o=i.get(s);if(n("encrypting outbound connection to %j",r),!o)throw new Error(`no crypto module found for ${s}`);return{...await o.secureOutbound(e,t,r),protocol:s}}catch(e){throw s(e,d.ERR_ENCRYPTION_FAILED)}}async _multiplexOutbound(e,t){const r=new o.Dialer(e),i=Array.from(t.keys());n("outbound selecting muxer %s",i);try{const{stream:e,protocol:s}=await r.select(i);n("%s selected as muxer protocol",s);return{stream:e,Muxer:t.get(s)}}catch(e){throw s(e,d.ERR_MUXER_UNAVAILABLE)}}async _multiplexInbound(e,t){const r=new o.Listener(e),i=Array.from(t.keys());n("inbound handling muxers %s",i);try{const{stream:e,protocol:n}=await r.handle(i);return{stream:e,Muxer:t.get(n)}}catch(e){throw s(e,d.ERR_MUXER_UNAVAILABLE)}}}},{debug:"bO5wM","err-code":"chZjB","multistream-select":"jMWmZ","libp2p-interfaces/src/connection":"GaTue","peer-id":"8Bdb3","it-pipe":"giKBQ","mutable-proxy":"iviy0","./errors":"3rNo5"}],jMWmZ:[function(e,t,r){"use strict";const i=e("./select"),n=e("./handle"),s=e("./ls"),{PROTOCOL_ID:o}=e("./constants");r.PROTOCOL_ID=o;class a{constructor(e){this._stream=e,this._shaken=!1}async _handshake(){if(this._shaken)return;const{stream:e}=await i(this._stream,o);this._stream=e,this._shaken=!0}}r.Dialer=class extends a{select(e){return i(this._stream,e,this._shaken?null:o)}async ls(){await this._handshake();const{stream:e,protocols:t}=await s(this._stream);return this._stream=e,t}};r.Listener=class extends a{handle(e){return n(this._stream,e)}}},{"./select":"69bj3","./handle":"dCEW4","./ls":"kJyHp","./constants":"78iMV"}],"69bj3":[function(e,t,r){"use strict";const i=e("debug")("mss:select"),n=e("err-code"),s=e("./multistream"),o=e("it-handshake");t.exports=async(e,t,r)=>{t=Array.isArray(t)?[...t]:[t];const{reader:a,writer:c,rest:u,stream:l}=o(e),d=t.shift();r?(i('select: write ["%s", "%s"]',r,d),s.writeAll(c,[r,d])):(i('select: write "%s"',d),s.write(c,d));let f=(await s.read(a)).toString();if(i('select: read "%s"',f),f===r&&(f=(await s.read(a)).toString(),i('select: read "%s"',f)),f===d)return u(),{stream:l,protocol:d};for(const e of t){i('select: write "%s"',e),s.write(c,e);const t=(await s.read(a)).toString();if(i('select: read "%s" for "%s"',t,e),t===e)return u(),{stream:l,protocol:e}}throw u(),n(new Error("protocol selection failed"),"ERR_UNSUPPORTED_PROTOCOL")}},{debug:"bO5wM","err-code":"chZjB","./multistream":"l6zhU","it-handshake":"5ZBDe"}],l6zhU:[function(e,t,r){"use strict";const i=e("bl/BufferList"),n=e("it-length-prefixed"),s=e("it-pipe"),o=e("err-code"),{fromString:a}=e("uint8arrays/from-string"),c=e("it-first"),u=a("\n");r.encode=e=>n.encode.single(new i([e,u])),r.write=(e,t)=>e.push(r.encode(t)),r.writeAll=(e,t)=>{e.push(t.reduce(((e,t)=>e.append(r.encode(t))),new i))},r.read=async e=>{let t=1;const r={[Symbol.asyncIterator](){return this},next:()=>e.next(t)},i=await s(r,n.decode({onLength:e=>{t=e}}),c);if(i.get(i.length-1)!==u[0])throw o(new Error("missing newline"),"ERR_INVALID_MULTISTREAM_SELECT_MESSAGE");return i.shallowSlice(0,-1)}},{"bl/BufferList":"im7j6","it-length-prefixed":"3yxIE","it-pipe":"giKBQ","err-code":"chZjB","uint8arrays/from-string":"dF7Y4","it-first":"hBrkP"}],dCEW4:[function(e,t,r){"use strict";const i=e("debug")("mss:handle"),n=e("bl/BufferList"),s=e("./multistream"),o=e("it-handshake"),{PROTOCOL_ID:a}=e("./constants");t.exports=async(e,t)=>{t=Array.isArray(t)?t:[t];const{writer:r,reader:c,rest:u,stream:l}=o(e);for(;;){const e=(await s.read(c)).toString();if(i('read "%s"',e),e!==a){if(t.includes(e))return s.write(r,e),i('respond with "%s" for "%s"',e,e),u(),{stream:l,protocol:e};"ls"!==e?(s.write(r,"na"),i('respond with "na" for "%s"',e)):(s.write(r,new n(t.map((e=>s.encode(e))))),i('respond with "%s" for %s',t,e))}else i('respond with "%s" for "%s"',a,e),s.write(r,a)}}},{debug:"bO5wM","bl/BufferList":"im7j6","./multistream":"l6zhU","it-handshake":"5ZBDe","./constants":"78iMV"}],"78iMV":[function(e,t,r){"use strict";r.PROTOCOL_ID="/multistream/1.0.0"},{}],kJyHp:[function(e,t,r){"use strict";const i=e("it-reader"),n=e("debug")("it-multistream-select:ls"),s=e("./multistream"),o=e("it-handshake"),a=e("it-length-prefixed"),c=e("it-pipe");t.exports=async e=>{const{reader:t,writer:r,rest:u,stream:l}=o(e);n('write "ls"'),s.write(r,"ls"),u();const d=await s.read(t),f=i([d]),h=[];return await c(f,a.decode(),(async e=>{for await(const t of e)h.push(t.shallowSlice(0,-1).toString())})),{stream:l,protocols:h}}},{"it-reader":"btxDo",debug:"bO5wM","./multistream":"l6zhU","it-handshake":"5ZBDe","it-length-prefixed":"3yxIE","it-pipe":"giKBQ"}],GaTue:[function(e,t,r){"use strict";r.Connection=e("./connection")},{"./connection":"kwiyC"}],kwiyC:[function(e,t,r){"use strict";const i=e("peer-id"),{Multiaddr:n}=e("multiaddr"),s=e("err-code"),{OPEN:o,CLOSING:a,CLOSED:c}=e("./status"),u=Symbol.for("@libp2p/interface-connection/connection");class l{constructor({localAddr:e,remoteAddr:t,localPeer:r,remotePeer:a,newStream:c,close:u,getStreams:l,stat:d}){!function(e,t,r,o,a,c,u){if(e&&!n.isMultiaddr(e))throw s(new Error("localAddr must be an instance of multiaddr"),"ERR_INVALID_PARAMETERS");if(!i.isPeerId(t))throw s(new Error("localPeer must be an instance of peer-id"),"ERR_INVALID_PARAMETERS");if(!i.isPeerId(r))throw s(new Error("remotePeer must be an instance of peer-id"),"ERR_INVALID_PARAMETERS");if("function"!=typeof o)throw s(new Error("new stream must be a function"),"ERR_INVALID_PARAMETERS");if("function"!=typeof a)throw s(new Error("close must be a function"),"ERR_INVALID_PARAMETERS");if("function"!=typeof c)throw s(new Error("getStreams must be a function"),"ERR_INVALID_PARAMETERS");if(!u)throw s(new Error("connection metadata object must be provided"),"ERR_INVALID_PARAMETERS");if("inbound"!==u.direction&&"outbound"!==u.direction)throw s(new Error('direction must be "inbound" or "outbound"'),"ERR_INVALID_PARAMETERS");if(!u.timeline)throw s(new Error("connection timeline object must be provided in the stat object"),"ERR_INVALID_PARAMETERS");if(!u.timeline.open)throw s(new Error("connection open timestamp must be provided"),"ERR_INVALID_PARAMETERS");if(!u.timeline.upgraded)throw s(new Error("connection upgraded timestamp must be provided"),"ERR_INVALID_PARAMETERS")}(e,r,a,c,u,l,d),this.id=parseInt(String(1e9*Math.random())).toString(36)+Date.now(),this.localAddr=e,this.remoteAddr=t,this.localPeer=r,this.remotePeer=a,this._stat={...d,status:o},this._newStream=c,this._close=u,this._getStreams=l,this.registry=new Map,this.tags=[]}get[Symbol.toStringTag](){return"Connection"}get[u](){return!0}static isConnection(e){return Boolean(e&&e[u])}get stat(){return this._stat}get streams(){return this._getStreams()}async newStream(e){if(this.stat.status===a)throw s(new Error("the connection is being closed"),"ERR_CONNECTION_BEING_CLOSED");if(this.stat.status===c)throw s(new Error("the connection is closed"),"ERR_CONNECTION_CLOSED");Array.isArray(e)||(e=[e]);const{stream:t,protocol:r}=await this._newStream(e);return this.addStream(t,{protocol:r}),{stream:t,protocol:r}}addStream(e,{protocol:t,metadata:r={}}){this.registry.set(e.id,{protocol:t,...r})}removeStream(e){this.registry.delete(e)}async close(){if(this.stat.status!==c){if(this._closing)return this._closing;this.stat.status=a,this._closing=await this._close(),this._stat.timeline.close=Date.now(),this.stat.status=c}}}t.exports=l},{"peer-id":"8Bdb3",multiaddr:"8Mu1u","err-code":"chZjB","./status":"hXsny"}],hXsny:[function(e,t,r){"use strict";t.exports={OPEN:"open",CLOSING:"closing",CLOSED:"closed"}},{}],iviy0:[function(e,t,r){"use strict";function i(e){if(Array.isArray(e)){for(var t=0,r=Array(e.length);t{t.set(e,this.get(s.createFromB58String(e)))})),t}delete(e){const t=this.addressBook.delete(e),r=this.keyBook.delete(e),i=this.protoBook.delete(e),n=this.metadataBook.delete(e);return t||r||i||n}get(e){if(!s.isPeerId(e))throw i(new Error("peerId must be an instance of peer-id"),l);const t=this.keyBook.data.get(e.toB58String()),r=this.addressBook.get(e),n=this.metadataBook.get(e),o=this.protoBook.get(e);if(t||r||n||o)return{id:t||e,addresses:r||[],protocols:o||[],metadata:n}}}},{"err-code":"chZjB",events:"g82pp","peer-id":"8Bdb3","./address-book":"lgtGk","./key-book":"5ggTp","./metadata-book":"emm3H","./proto-book":"98zRc","../errors":"3rNo5"}],lgtGk:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:peer-store:address-book"),{error:i("libp2p:peer-store:address-book:err")}),s=e("err-code"),{Multiaddr:o}=e("multiaddr"),a=e("peer-id"),c=e("./book"),u=e("../record/peer-record"),{codes:{ERR_INVALID_PARAMETERS:l}}=e("../errors"),d=e("../record/envelope");t.exports=class extends c{constructor(e){super({peerStore:e,eventName:"change:multiaddrs",eventProperty:"multiaddrs",eventTransformer:e=>e.addresses?e.addresses.map((e=>e.multiaddr)):[]}),this.data=new Map}consumePeerRecord(e){let t;try{t=u.createFromProtobuf(e.payload)}catch(e){return n.error("invalid peer record received"),!1}if(!t.peerId.equals(e.peerId))return n("signing key does not match PeerId in the PeerRecord"),!1;if(!t.multiaddrs||!t.multiaddrs.length)return!1;const r=t.peerId,i=r.toB58String(),s=(this.data.get(i)||{record:void 0}).record;if(s&&s.seqNumber>=t.seqNumber)return!1;const o=this._toAddresses(t.multiaddrs,!0);return this._setData(r,{addresses:o,record:{raw:e.marshal(),seqNumber:t.seqNumber}}),n(`stored provided peer record for ${i}`),!0}getRawEnvelope(e){const t=this.data.get(e.toB58String());if(t&&t.record&&t.record.raw)return t.record.raw}getPeerRecord(e){const t=this.getRawEnvelope(e);if(t)return d.createFromProtobuf(t)}set(e,t){if(!a.isPeerId(e))throw n.error("peerId must be an instance of peer-id to store data"),s(new Error("peerId must be an instance of peer-id"),l);const r=this._toAddresses(t);if(!r.length)return this;const i=e.toB58String(),o=this.data.get(i);if(o&&o.addresses&&o.addresses.length===r.length){if(o.addresses.filter((e=>r.some((t=>e.multiaddr.equals(t.multiaddr))))).length===o.addresses.length)return n(`the addresses provided to store are equal to the already stored for ${i}`),this}return this._setData(e,{addresses:r,record:o&&o.record}),n(`stored provided multiaddrs for ${i}`),o||this._ps.emit("peer",e),this}add(e,t){if(!a.isPeerId(e))throw n.error("peerId must be an instance of peer-id to store data"),s(new Error("peerId must be an instance of peer-id"),l);const r=this._toAddresses(t),i=e.toB58String();if(!r.length)return this;const o=this.data.get(i);return o&&o.addresses&&(o.addresses.forEach((e=>{r.find((t=>t.multiaddr.equals(e.multiaddr)))||r.push(e)})),o.addresses.length===r.length)?(n(`the addresses provided to store are already stored for ${i}`),this):(this._setData(e,{addresses:r,record:o&&o.record}),n(`added provided multiaddrs for ${i}`),o&&o.addresses||this._ps.emit("peer",e),this)}get(e){if(!a.isPeerId(e))throw s(new Error("peerId must be an instance of peer-id"),l);const t=this.data.get(e.toB58String());return t&&t.addresses?[...t.addresses]:void 0}_toAddresses(e,t=!1){if(!e)throw n.error("multiaddrs must be provided to store data"),s(new Error("multiaddrs must be provided"),l);const r=[];return e.forEach((e=>{if(!o.isMultiaddr(e))throw n.error(`multiaddr ${e} must be an instance of multiaddr`),s(new Error(`multiaddr ${e} must be an instance of multiaddr`),l);r.find((t=>t.multiaddr.equals(e)))||r.push({multiaddr:e,isCertified:t})})),r}getMultiaddrsForPeer(e,t=(e=>e)){if(!a.isPeerId(e))throw s(new Error("peerId must be an instance of peer-id"),l);const r=this.data.get(e.toB58String());if(r&&r.addresses)return t(r.addresses||[]).map((t=>{const r=t.multiaddr,i=r.getPeerId();return i&&i===e.toB58String()?r:r.encapsulate(`/p2p/${e.toB58String()}`)}))}}},{debug:"bO5wM","err-code":"chZjB",multiaddr:"8Mu1u","peer-id":"8Bdb3","./book":"aXIpl","../record/peer-record":"ewlv9","../errors":"3rNo5","../record/envelope":"27rHX"}],aXIpl:[function(e,t,r){"use strict";const i=e("err-code"),n=e("peer-id"),{codes:{ERR_INVALID_PARAMETERS:s}}=e("../errors"),o=e=>e;t.exports=class{constructor({peerStore:e,eventName:t,eventProperty:r,eventTransformer:i=o}){this._ps=e,this.eventName=t,this.eventProperty=r,this.eventTransformer=i,this.data=new Map}set(e,t){throw i(new Error("set must be implemented by the subclass"),"ERR_NOT_IMPLEMENTED")}_setData(e,t,{emit:r=!0}={}){const i=e.toB58String();this.data.set(i,t),r&&this._emit(e,t)}_emit(e,t){this._ps.emit(this.eventName,{peerId:e,[this.eventProperty]:this.eventTransformer(t)})}get(e){if(!n.isPeerId(e))throw i(new Error("peerId must be an instance of peer-id"),s);const t=this.data.get(e.toB58String());return t?[...t]:void 0}delete(e){if(!n.isPeerId(e))throw i(new Error("peerId must be an instance of peer-id"),s);return!!this.data.delete(e.toB58String())&&(this._emit(e,[]),!0)}}},{"err-code":"chZjB","peer-id":"8Bdb3","../errors":"3rNo5"}],"5ggTp":[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:peer-store:key-book"),{error:i("libp2p:peer-store:key-book:err")}),s=e("err-code"),o=e("peer-id"),a=e("./book"),{codes:{ERR_INVALID_PARAMETERS:c}}=e("../errors");t.exports=class extends a{constructor(e){super({peerStore:e,eventName:"change:pubkey",eventProperty:"pubkey",eventTransformer:e=>e.pubKey}),this.data=new Map}set(e,t){if(!o.isPeerId(e))throw n.error("peerId must be an instance of peer-id to store data"),s(new Error("peerId must be an instance of peer-id"),c);const r=e.toB58String();return!this.data.get(r)&&t&&(e.pubKey=t,this._setData(e,e),n(`stored provided public key for ${r}`)),this}get(e){if(!o.isPeerId(e))throw s(new Error("peerId must be an instance of peer-id"),c);const t=this.data.get(e.toB58String());return t?t.pubKey:void 0}}},{debug:"bO5wM","err-code":"chZjB","peer-id":"8Bdb3","./book":"aXIpl","../errors":"3rNo5"}],emm3H:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:peer-store:proto-book"),{error:i("libp2p:peer-store:proto-book:err")}),s=e("err-code"),{equals:o}=e("uint8arrays/equals"),a=e("peer-id"),c=e("./book"),{codes:{ERR_INVALID_PARAMETERS:u}}=e("../errors");t.exports=class extends c{constructor(e){super({peerStore:e,eventName:"change:metadata",eventProperty:"metadata"}),this.data=new Map}set(e,t,r){if(!a.isPeerId(e))throw n.error("peerId must be an instance of peer-id to store data"),s(new Error("peerId must be an instance of peer-id"),u);if("string"!=typeof t||!(r instanceof Uint8Array))throw n.error("valid key and value must be provided to store data"),s(new Error("valid key and value must be provided"),u);return this._setValue(e,t,r),this}_setValue(e,t,r,{emit:i=!0}={}){const s=e.toB58String(),a=this.data.get(s)||new Map,c=a.get(t);c&&o(r,c)?n(`the metadata provided to store is equal to the already stored for ${s} on ${t}`):(a.set(t,r),this.data.set(s,a),i&&this._emit(e,t))}get(e){if(!a.isPeerId(e))throw s(new Error("peerId must be an instance of peer-id"),u);return this.data.get(e.toB58String())}getValue(e,t){if(!a.isPeerId(e))throw s(new Error("peerId must be an instance of peer-id"),u);const r=this.data.get(e.toB58String());return r&&r.get(t)}delete(e){if(!a.isPeerId(e))throw s(new Error("peerId must be an instance of peer-id"),u);return!!this.data.delete(e.toB58String())&&(this._emit(e),!0)}deleteValue(e,t){if(!a.isPeerId(e))throw s(new Error("peerId must be an instance of peer-id"),u);const r=this.data.get(e.toB58String());return!(!r||!r.delete(t))&&(this._emit(e,t),!0)}}},{debug:"bO5wM","err-code":"chZjB","uint8arrays/equals":"eY3cX","peer-id":"8Bdb3","./book":"aXIpl","../errors":"3rNo5"}],"98zRc":[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:peer-store:proto-book"),{error:i("libp2p:peer-store:proto-book:err")}),s=e("err-code"),o=e("peer-id"),a=e("./book"),{codes:{ERR_INVALID_PARAMETERS:c}}=e("../errors");t.exports=class extends a{constructor(e){super({peerStore:e,eventName:"change:protocols",eventProperty:"protocols",eventTransformer:e=>Array.from(e)}),this.data=new Map}set(e,t){if(!o.isPeerId(e))throw n.error("peerId must be an instance of peer-id to store data"),s(new Error("peerId must be an instance of peer-id"),c);if(!t)throw n.error("protocols must be provided to store data"),s(new Error("protocols must be provided"),c);const r=e.toB58String(),i=this.data.get(r),a=new Set(t);return i&&(l=a,(u=i).size===l.size&&[...u].every((e=>l.has(e))))?(n(`the protocols provided to store are equal to the already stored for ${r}`),this):(this._setData(e,a),n(`stored provided protocols for ${r}`),this);var u,l}add(e,t){if(!o.isPeerId(e))throw n.error("peerId must be an instance of peer-id to store data"),s(new Error("peerId must be an instance of peer-id"),c);if(!t)throw n.error("protocols must be provided to store data"),s(new Error("protocols must be provided"),c);const r=e.toB58String(),i=this.data.get(r)||new Set,a=new Set([...i,...t]);return i.size===a.size?(n(`the protocols provided to store are already stored for ${r}`),this):(this._setData(e,a),n(`added provided protocols for ${r}`),this)}remove(e,t){if(!o.isPeerId(e))throw n.error("peerId must be an instance of peer-id to store data"),s(new Error("peerId must be an instance of peer-id"),c);if(!t)throw n.error("protocols must be provided to store data"),s(new Error("protocols must be provided"),c);const r=e.toB58String(),i=this.data.get(r);if(i){const s=new Set([...i].filter((e=>!t.includes(e))));if(i.size===s.size)return this;this._setData(e,s),n(`removed provided protocols for ${r}`)}return this}}},{debug:"bO5wM","err-code":"chZjB","peer-id":"8Bdb3","./book":"aXIpl","../errors":"3rNo5"}],"4AHRd":[function(e,t,r){"use strict";t.exports=function(e,t,r){const i=new e(t,r);return i._subscribeAdapter=i.subscribe,i._unsubscribeAdapter=i.unsubscribe,i.subscribe=function(e,t){t&&i.on(e,t),i._subscribeAdapter(e)},i.unsubscribe=function(e,t){t?i.removeListener(e,t):i.removeAllListeners(e),0===i.listenerCount(e)&&i._unsubscribeAdapter(e)},i}},{}],kcKey:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:persistent-peer-store"),{error:i("libp2p:persistent-peer-store:err")}),{Key:s}=e("interface-datastore/key"),{Multiaddr:o}=e("multiaddr"),a=e("peer-id"),{base32:c}=e("multiformats/bases/base32"),u=e(".."),{NAMESPACE_ADDRESS:l,NAMESPACE_COMMON:d,NAMESPACE_KEYS:f,NAMESPACE_METADATA:h,NAMESPACE_PROTOCOL:p}=e("./consts"),{Addresses:g}=e("./pb/address-book"),{Protocols:y}=e("./pb/proto-book");t.exports=class extends u{constructor({peerId:e,datastore:t,threshold:r=5}){super({peerId:e}),this._datastore=t,this._dirtyPeers=new Set,this._dirtyMetadata=new Map,this.threshold=r,this._addDirtyPeer=this._addDirtyPeer.bind(this)}async start(){n("PeerStore is starting"),this.on("change:protocols",this._addDirtyPeer),this.on("change:multiaddrs",this._addDirtyPeer),this.on("change:pubkey",this._addDirtyPeerKey),this.on("change:metadata",this._addDirtyPeerMetadata);for await(const e of this._datastore.query({prefix:d}))await this._processDatastoreEntry(e);n("PeerStore started")}async stop(){n("PeerStore is stopping"),this.removeAllListeners(),await this._commitData(),n("PeerStore stopped")}_addDirtyPeer({peerId:e}){const t=e.toB58String();n("add dirty peer",t),this._dirtyPeers.add(t),this._dirtyPeers.size>=this.threshold&&this._commitData().catch((e=>{n.error("error committing data",e)}))}_addDirtyPeerKey({peerId:e}){if(e.hasInlinePublicKey())return;const t=e.toB58String();n("add dirty peer key",t),this._dirtyPeers.add(t),this._dirtyPeers.size>=this.threshold&&this._commitData().catch((e=>{n.error("error committing data",e)}))}_addDirtyPeerMetadata({peerId:e,metadata:t}){const r=e.toB58String();n("add dirty metadata peer",r),this._dirtyPeers.add(r);const i=this._dirtyMetadata.get(r)||new Set;i.add(t),this._dirtyMetadata.set(r,i),this._dirtyPeers.size>=this.threshold&&this._commitData().catch((e=>{n.error("error committing data",e)}))}async _commitData(){const e=Array.from(this._dirtyPeers);if(!e.length)return;this._dirtyPeers.clear(),n("create batch commit");const t=this._datastore.batch();for(const r of e){const e=this.keyBook.data.get(r)||a.createFromB58String(r);this._batchAddressBook(e,t),!e.hasInlinePublicKey()&&this._batchKeyBook(e,t),this._batchMetadataBook(e,t),this._batchProtoBook(e,t)}await t.commit(),n("batch committed")}_batchAddressBook(e,t){const r=e.toString(),i=new s(`${l}${r}`),o=this.addressBook.data.get(e.toB58String());try{if(!o)return void t.delete(i);const e=g.encode({addrs:o.addresses.map((e=>({multiaddr:e.multiaddr.bytes,isCertified:e.isCertified}))),certifiedRecord:o.record?{seq:o.record.seqNumber,raw:o.record.raw}:void 0}).finish();t.put(i,e)}catch(e){n.error(e)}}_batchKeyBook(e,t){const r=e.toString(),i=new s(`${f}${r}`);try{if(!e.pubKey)return void t.delete(i);const r=e.marshalPubKey();t.put(i,r)}catch(e){n.error(e)}}_batchMetadataBook(e,t){const r=e.toString(),i=this._dirtyMetadata.get(e.toB58String())||[];try{i.forEach((i=>{const n=new s(`${h}${r}/${i}`),o=this.metadataBook.getValue(e,i);o?t.put(n,o):t.delete(n)}))}catch(e){n.error(e)}}_batchProtoBook(e,t){const r=e.toString(),i=new s(`${p}${r}`),o=this.protoBook.get(e);try{if(!o)return void t.delete(i);const e=y.encode({protocols:o}).finish();t.put(i,e)}catch(e){n.error(e)}}async _processDatastoreEntry({key:e,value:t}){try{const r=e.toString().split("/"),i=a.createFromBytes(c.decode(r[3]));let s;switch(r[2]){case"addrs":s=g.decode(t),this.addressBook._setData(i,{addresses:s.addrs.map((e=>({multiaddr:new o(e.multiaddr),isCertified:Boolean(e.isCertified)}))),record:s.certifiedRecord?{raw:s.certifiedRecord.raw,seqNumber:s.certifiedRecord.seq}:void 0},{emit:!1});break;case"keys":s=await a.createFromPubKey(t),this.keyBook._setData(s,s,{emit:!1});break;case"metadata":this.metadataBook._setValue(i,r[4],t,{emit:!1});break;case"protos":s=y.decode(t),this.protoBook._setData(i,new Set(s.protocols),{emit:!1});break;default:n("invalid data persisted for: ",e.toString())}}catch(e){n.error(e)}}}},{debug:"bO5wM","interface-datastore/key":"9hGOz",multiaddr:"8Mu1u","peer-id":"8Bdb3","multiformats/bases/base32":"5k9Tu","..":"hDFM8","./consts":"2EBy4","./pb/address-book":"jj9hF","./pb/proto-book":"j2d2m"}],"2EBy4":[function(e,t,r){"use strict";t.exports.NAMESPACE_COMMON="/peers/",t.exports.NAMESPACE_ADDRESS="/peers/addrs/",t.exports.NAMESPACE_KEYS="/peers/keys/",t.exports.NAMESPACE_METADATA="/peers/metadata/",t.exports.NAMESPACE_PROTOCOL="/peers/protos/"},{}],jj9hF:[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-address-book"]||(i.roots["libp2p-address-book"]={});a.Addresses=function(){function e(e){if(this.addrs=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.addrs&&i.addrs.length||(i.addrs=[]),i.addrs.push(a.Addresses.Address.decode(e,e.uint32()));break;case 2:i.certifiedRecord=a.Addresses.CertifiedRecord.decode(e,e.uint32());break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.Addresses)return e;var t=new a.Addresses;if(e.addrs){if(!Array.isArray(e.addrs))throw TypeError(".Addresses.addrs: array expected");t.addrs=[];for(var r=0;r>>3){case 1:i.multiaddr=e.bytes();break;case 2:i.isCertified=e.bool();break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.Addresses.Address)return e;var t=new a.Addresses.Address;return null!=e.multiaddr&&("string"==typeof e.multiaddr?o.base64.decode(e.multiaddr,t.multiaddr=o.newBuffer(o.base64.length(e.multiaddr)),0):e.multiaddr.length&&(t.multiaddr=e.multiaddr)),null!=e.isCertified&&(t.isCertified=Boolean(e.isCertified)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(t.bytes===String?r.multiaddr="":(r.multiaddr=[],t.bytes!==Array&&(r.multiaddr=o.newBuffer(r.multiaddr))),r.isCertified=!1),null!=e.multiaddr&&e.hasOwnProperty("multiaddr")&&(r.multiaddr=t.bytes===String?o.base64.encode(e.multiaddr,0,e.multiaddr.length):t.bytes===Array?Array.prototype.slice.call(e.multiaddr):e.multiaddr),null!=e.isCertified&&e.hasOwnProperty("isCertified")&&(r.isCertified=e.isCertified),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,i.util.toJSONOptions)},e}(),e.CertifiedRecord=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.seq=e.uint64();break;case 2:i.raw=e.bytes();break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.Addresses.CertifiedRecord)return e;var t=new a.Addresses.CertifiedRecord;return null!=e.seq&&(o.Long?(t.seq=o.Long.fromValue(e.seq)).unsigned=!0:"string"==typeof e.seq?t.seq=parseInt(e.seq,10):"number"==typeof e.seq?t.seq=e.seq:"object"==typeof e.seq&&(t.seq=new o.LongBits(e.seq.low>>>0,e.seq.high>>>0).toNumber(!0))),null!=e.raw&&("string"==typeof e.raw?o.base64.decode(e.raw,t.raw=o.newBuffer(o.base64.length(e.raw)),0):e.raw.length&&(t.raw=e.raw)),t},e.toObject=function(e,t){t||(t={});var r={};if(t.defaults){if(o.Long){var i=new o.Long(0,0,!0);r.seq=t.longs===String?i.toString():t.longs===Number?i.toNumber():i}else r.seq=t.longs===String?"0":0;t.bytes===String?r.raw="":(r.raw=[],t.bytes!==Array&&(r.raw=o.newBuffer(r.raw)))}return null!=e.seq&&e.hasOwnProperty("seq")&&("number"==typeof e.seq?r.seq=t.longs===String?String(e.seq):e.seq:r.seq=t.longs===String?o.Long.prototype.toString.call(e.seq):t.longs===Number?new o.LongBits(e.seq.low>>>0,e.seq.high>>>0).toNumber(!0):e.seq),null!=e.raw&&e.hasOwnProperty("raw")&&(r.raw=t.bytes===String?o.base64.encode(e.raw,0,e.raw.length):t.bytes===Array?Array.prototype.slice.call(e.raw):e.raw),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,i.util.toJSONOptions)},e}(),e}(),t.exports=a},{"protobufjs/minimal":"grAXL"}],j2d2m:[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-proto-book"]||(i.roots["libp2p-proto-book"]={});a.Protocols=function(){function e(e){if(this.protocols=[],e)for(var t=Object.keys(e),r=0;r>>3==1)i.protocols&&i.protocols.length||(i.protocols=[]),i.protocols.push(e.string());else e.skipType(7&s)}return i},e.fromObject=function(e){if(e instanceof a.Protocols)return e;var t=new a.Protocols;if(e.protocols){if(!Array.isArray(e.protocols))throw TypeError(".Protocols.protocols: array expected");t.protocols=[];for(var r=0;rl(1,e)),c,u),v=Date.now();if(!d(m,b))throw s(new Error("Received wrong ping ack"),"ERR_WRONG_PING_ACK");return v-y}).mount=function(e){e.handle(`/${e._config.protocolPrefix}/${f}/${p}`,(({stream:e})=>a(e,e)))},r.unmount=function(e){e.unhandle(`/${e._config.protocolPrefix}/${f}/${p}`)}},{debug:"bO5wM","err-code":"chZjB","libp2p-crypto":"bb1cb","it-pipe":"giKBQ","it-buffer":"jQv22","streaming-iterables":"jrrai","uint8arrays/equals":"eY3cX","./constants":"g9JxC"}],g9JxC:[function(e,t,r){"use strict";t.exports={PROTOCOL:"/ipfs/ping/1.0.0",PING_LENGTH:32,PROTOCOL_VERSION:"1.0.0",PROTOCOL_NAME:"ping"}},{}],jPbT6:[function(e,t,r){"use strict";const i=e("debug"),n=Object.assign(i("libp2p:identify"),{error:i("libp2p:identify:err")}),s=e("err-code"),o=e("it-length-prefixed"),{pipe:a}=e("it-pipe"),{collect:c,take:u,consume:l}=e("streaming-iterables"),{fromString:d}=e("uint8arrays/from-string"),f=e("peer-id"),{Multiaddr:h}=e("multiaddr"),{toBuffer:p}=e("it-buffer"),g=e("./message"),y=e("../record/envelope"),m=e("../record/peer-record"),{MULTICODEC_IDENTIFY:b,MULTICODEC_IDENTIFY_PUSH:v,IDENTIFY_PROTOCOL_VERSION:w,MULTICODEC_IDENTIFY_PROTOCOL_NAME:_,MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME:E,MULTICODEC_IDENTIFY_PROTOCOL_VERSION:S,MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION:T}=e("./consts"),{codes:A}=e("../errors");class k{static getProtocolStr(e){return{identifyProtocolStr:`/${e._config.protocolPrefix}/${_}/${S}`,identifyPushProtocolStr:`/${e._config.protocolPrefix}/${E}/${T}`}}constructor({libp2p:e}){this._libp2p=e,this.peerStore=e.peerStore,this.addressManager=e.addressManager,this.connectionManager=e.connectionManager,this.peerId=e.peerId,this.handleMessage=this.handleMessage.bind(this);const t=k.getProtocolStr(e);this.identifyProtocolStr=t.identifyProtocolStr,this.identifyPushProtocolStr=t.identifyPushProtocolStr,this._host={protocolVersion:`${e._config.protocolPrefix}/${w}`,...e._options.host},this.peerStore.metadataBook.set(this.peerId,"AgentVersion",d(this._host.agentVersion)),this.peerStore.metadataBook.set(this.peerId,"ProtocolVersion",d(this._host.protocolVersion)),this.connectionManager.on("peer:connect",(e=>{this.identify(e).catch(n.error)})),this.peerStore.on("change:multiaddrs",(({peerId:e})=>{e.toString()===this.peerId.toString()&&this.pushToPeerStore()})),this.peerStore.on("change:protocols",(({peerId:e})=>{e.toString()===this.peerId.toString()&&this.pushToPeerStore()}))}async push(e){const t=await this.peerStore.addressBook.getRawEnvelope(this.peerId),r=this._libp2p.multiaddrs.map((e=>e.bytes)),i=this.peerStore.protoBook.get(this.peerId)||[],s=e.map((async e=>{try{const{stream:n}=await e.newStream(this.identifyPushProtocolStr);await a([g.Identify.encode({listenAddrs:r,signedPeerRecord:t,protocols:i}).finish()],o.encode(),n,l)}catch(e){n.error("could not push identify update to peer",e)}}));return Promise.all(s)}pushToPeerStore(){if(!this._libp2p.isStarted())return;const e=[];let t;for(const r of this.peerStore.peers.values())r.protocols.includes(this.identifyPushProtocolStr)&&(t=this.connectionManager.get(r.id))&&e.push(t);this.push(e)}async identify(e){const{stream:t}=await e.newStream(this.identifyProtocolStr),[r]=await a([],t,o.decode(),u(1),p,c);if(!r)throw s(new Error("No data could be retrieved"),A.ERR_CONNECTION_ENDED);let i;try{i=g.Identify.decode(r)}catch(e){throw s(e,A.ERR_INVALID_MESSAGE)}const{publicKey:l,listenAddrs:b,protocols:v,observedAddr:w,signedPeerRecord:_}=i,E=await f.createFromPubKey(l);if(e.remotePeer.toB58String()!==E.toB58String())throw s(new Error("identified peer does not match the expected peer"),A.ERR_INVALID_PEER);const S=k.getCleanMultiaddr(w);try{const e=await y.openAndCertify(_,m.DOMAIN);if(this.peerStore.addressBook.consumePeerRecord(e))return this.peerStore.protoBook.set(E,v),this.peerStore.metadataBook.set(E,"AgentVersion",d(i.agentVersion)),void this.peerStore.metadataBook.set(E,"ProtocolVersion",d(i.protocolVersion))}catch(e){n("received invalid envelope, discard it and fallback to listenAddrs is available",e)}try{this.peerStore.addressBook.set(E,b.map((e=>new h(e))))}catch(e){n.error("received invalid addrs",e)}this.peerStore.protoBook.set(E,v),this.peerStore.metadataBook.set(E,"AgentVersion",d(i.agentVersion)),this.peerStore.metadataBook.set(E,"ProtocolVersion",d(i.protocolVersion)),n("received observed address of %s",S)}handleMessage({connection:e,stream:t,protocol:r}){switch(r){case this.identifyProtocolStr:return this._handleIdentify({connection:e,stream:t});case this.identifyPushProtocolStr:return this._handlePush({connection:e,stream:t});default:n.error("cannot handle unknown protocol %s",r)}}async _handleIdentify({connection:e,stream:t}){let r=new Uint8Array(0);this.peerId.pubKey&&(r=this.peerId.pubKey.bytes);const i=await this.peerStore.addressBook.getRawEnvelope(this.peerId),s=this.peerStore.protoBook.get(this.peerId)||[],c=g.Identify.encode({protocolVersion:this._host.protocolVersion,agentVersion:this._host.agentVersion,publicKey:r,listenAddrs:this._libp2p.multiaddrs.map((e=>e.bytes)),signedPeerRecord:i,observedAddr:e.remoteAddr.bytes,protocols:s}).finish();try{await a([c],o.encode(),t,l)}catch(e){n.error("could not respond to identify request",e)}}async _handlePush({connection:e,stream:t}){let r;try{const[e]=await a([],t,o.decode(),u(1),p,c);r=g.Identify.decode(e)}catch(e){return n.error("received invalid message",e)}const i=e.remotePeer;try{const e=await y.openAndCertify(r.signedPeerRecord,m.DOMAIN);if(this.peerStore.addressBook.consumePeerRecord(e))return void this.peerStore.protoBook.set(i,r.protocols)}catch(e){n("received invalid envelope, discard it and fallback to listenAddrs is available",e)}try{this.peerStore.addressBook.set(i,r.listenAddrs.map((e=>new h(e))))}catch(e){n.error("received invalid addrs",e)}this.peerStore.protoBook.set(i,r.protocols)}static getCleanMultiaddr(e){if(e&&e.length>0)try{return new h(e)}catch(e){return null}return null}}const I={IDENTIFY:b,IDENTIFY_PUSH:v};k.multicodecs=I,k.Messsage=g,t.exports=k},{debug:"bO5wM","err-code":"chZjB","it-length-prefixed":"3yxIE","it-pipe":"giKBQ","streaming-iterables":"jrrai","uint8arrays/from-string":"dF7Y4","peer-id":"8Bdb3",multiaddr:"8Mu1u","it-buffer":"jQv22","./message":"cIqCO","../record/envelope":"27rHX","../record/peer-record":"ewlv9","./consts":"62PhM","../errors":"3rNo5"}],cIqCO:[function(e,t,r){"use strict";var i=e("protobufjs/minimal"),n=i.Reader,s=i.Writer,o=i.util,a=i.roots["libp2p-identify"]||(i.roots["libp2p-identify"]={});a.Identify=function(){function e(e){if(this.listenAddrs=[],this.protocols=[],e)for(var t=Object.keys(e),r=0;r>>3){case 5:i.protocolVersion=e.string();break;case 6:i.agentVersion=e.string();break;case 1:i.publicKey=e.bytes();break;case 2:i.listenAddrs&&i.listenAddrs.length||(i.listenAddrs=[]),i.listenAddrs.push(e.bytes());break;case 4:i.observedAddr=e.bytes();break;case 3:i.protocols&&i.protocols.length||(i.protocols=[]),i.protocols.push(e.string());break;case 8:i.signedPeerRecord=e.bytes();break;default:e.skipType(7&s)}}return i},e.fromObject=function(e){if(e instanceof a.Identify)return e;var t=new a.Identify;if(null!=e.protocolVersion&&(t.protocolVersion=String(e.protocolVersion)),null!=e.agentVersion&&(t.agentVersion=String(e.agentVersion)),null!=e.publicKey&&("string"==typeof e.publicKey?o.base64.decode(e.publicKey,t.publicKey=o.newBuffer(o.base64.length(e.publicKey)),0):e.publicKey.length&&(t.publicKey=e.publicKey)),e.listenAddrs){if(!Array.isArray(e.listenAddrs))throw TypeError(".Identify.listenAddrs: array expected");t.listenAddrs=[];for(var r=0;r{a.error(e)}))}async _start(){const e=this._transportManager.getAddrs();for(const t of e){const{family:e,host:r,port:i,transport:n}=t.toOptions();if(!t.isThinWaistAddress()||"tcp"!==n)continue;if(p(t))continue;if(4!==e)continue;const s=this._getClient(),c=this._externalIp||await s.externalIp();if(l(c))throw new Error(`${c} is private - please set config.nat.externalIp to an externally routable IP or ensure you are not behind a double NAT`);const u=y();a(`opening uPnP connection from ${c}:${u} to ${r}:${i}`),await s.map({publicPort:u,privatePort:i,protocol:n.toUpperCase()}),this._addressManager.addObservedAddr(o.fromNodeAddress({family:4,address:c,port:u},n))}}_getClient(){if(this._client)return this._client;const e=new i(this._options),t=s(e.map.bind(e)),r=s(e.destroy.bind(e)),n=s(e.externalIp.bind(e));return this._client={map:(...e)=>u((()=>t(...e)),{onFailedAttempt:a.error,unref:!0}),destroy:(...e)=>u((()=>r(...e)),{onFailedAttempt:a.error,unref:!0}),externalIp:(...e)=>u((()=>n(...e)),{onFailedAttempt:a.error,unref:!0})},this._client}async stop(){if(!c&&this._client)try{await this._client.destroy(),this._client=null}catch(e){a.error(e)}}}},{"@motrix/nat-api":"lHksA",debug:"bO5wM","es6-promisify":"4jb5N",multiaddr:"8Mu1u",wherearewe:"lr9au","p-retry":"3fyh8","private-ip":"kXRph","../package.json":"cq0b4","err-code":"chZjB","./errors":"3rNo5","libp2p-utils/src/multiaddr/is-loopback":"55HY1"}],"4jb5N":[function(e,t,r){var i=e("@parcel/transformer-js/src/esmodule-helpers.js");i.defineInteropFlag(r),i.export(r,"promisify",(()=>n));function n(e){if("function"!=typeof e)throw new TypeError("Argument to promisify must be a function");var t=e["__ES6-PROMISIFY--CUSTOM-ARGUMENTS__"],r=n.Promise||Promise;if("function"!=typeof r)throw new Error("No Promise implementation found; do you need a polyfill?");return function(){for(var i=arguments.length,n=Array(i),s=0;s{n.push((function(e){if(e)return i(e);for(var n=arguments.length,s=Array(1{var i=t[r];i&&(a[i]=e)})),r(a)})),e.apply(this,n)}))}}n.argumentNames="__ES6-PROMISIFY--CUSTOM-ARGUMENTS__",n.Promise=void 0},{"@parcel/transformer-js/src/esmodule-helpers.js":"h08wk"}],lr9au:[function(e,t,r){var i=e("process");const n=e("is-electron"),s="object"==typeof window&&"object"==typeof document&&9===document.nodeType,o=n(),a=s&&!o,c=o&&!s,u=o&&s,l="function"==typeof e&&void 0!==i&&void 0!==i.release&&"node"===i.release.name&&!o,d="function"==typeof importScripts&&"undefined"!=typeof self&&"undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope,f=void 0!==i&&void 0!==i.env&&!1;t.exports={isTest:f,isElectron:o,isElectronMain:c,isElectronRenderer:u,isNode:l,isBrowser:a,isWebWorker:d,isEnvWithDom:s}},{process:"bjUAi","is-electron":"e6ybt"}],"3fyh8":[function(e,t,r){"use strict";const i=e("retry"),n=["Failed to fetch","NetworkError when attempting to fetch resource.","The Internet connection appears to be offline.","Network request failed"];class s extends Error{constructor(e){super(),e instanceof Error?(this.originalError=e,({message:e}=e)):(this.originalError=new Error(e),this.originalError.stack=this.stack),this.name="AbortError",this.message=e}}const o=(e,t)=>new Promise(((r,o)=>{t={onFailedAttempt:()=>{},retries:10,...t};const a=i.operation(t);a.attempt((async i=>{try{r(await e(i))}catch(e){if(!(e instanceof Error))return void o(new TypeError(`Non-error was thrown: "${e}". You should only throw errors.`));if(e instanceof s)a.stop(),o(e.originalError);else if(e instanceof TypeError&&(c=e.message,!n.includes(c)))a.stop(),o(e);else{((e,t,r)=>{const i=r.retries-(t-1);e.attemptNumber=t,e.retriesLeft=i})(e,i,t);try{await t.onFailedAttempt(e)}catch(e){return void o(e)}a.retry(e)||o(a.mainError())}}var c}))}));t.exports=o,t.exports.default=o,t.exports.AbortError=s},{retry:"l316T"}],l316T:[function(e,t,r){t.exports=e("./lib/retry")},{"./lib/retry":"e5bUs"}],e5bUs:[function(e,t,r){var i=e("./retry_operation");r.operation=function(e){var t=r.timeouts(e);return new i(t,{forever:e&&(e.forever||e.retries===1/0),unref:e&&e.unref,maxRetryTime:e&&e.maxRetryTime})},r.timeouts=function(e){if(e instanceof Array)return[].concat(e);var t={retries:10,factor:2,minTimeout:1e3,maxTimeout:1/0,randomize:!1};for(var r in e)t[r]=e[r];if(t.minTimeout>t.maxTimeout)throw new Error("minTimeout is greater than maxTimeout");for(var i=[],n=0;n=this._maxRetryTime)return this._errors.push(e),this._errors.unshift(new Error("RetryOperation timeout occurred")),!1;this._errors.push(e);var r=this._timeouts.shift();if(void 0===r){if(!this._cachedTimeouts)return!1;this._errors.splice(0,this._errors.length-1),r=this._cachedTimeouts.slice(-1)}var i=this;return this._timer=setTimeout((function(){i._attempts++,i._operationTimeoutCb&&(i._timeout=setTimeout((function(){i._operationTimeoutCb(i._attempts)}),i._operationTimeout),i._options.unref&&i._timeout.unref()),i._fn(i._attempts)}),r),this._options.unref&&this._timer.unref(),!0},i.prototype.attempt=function(e,t){this._fn=e,t&&(t.timeout&&(this._operationTimeout=t.timeout),t.cb&&(this._operationTimeoutCb=t.cb));var r=this;this._operationTimeoutCb&&(this._timeout=setTimeout((function(){r._operationTimeoutCb()}),r._operationTimeout)),this._operationStart=(new Date).getTime(),this._fn(this._attempts)},i.prototype.try=function(e){console.log("Using RetryOperation.try() is deprecated"),this.attempt(e)},i.prototype.start=function(e){console.log("Using RetryOperation.start() is deprecated"),this.attempt(e)},i.prototype.start=i.prototype.try,i.prototype.errors=function(){return this._errors},i.prototype.attempts=function(){return this._attempts},i.prototype.mainError=function(){if(0===this._errors.length)return null;for(var e={},t=null,r=0,i=0;i=r&&(t=n,r=o)}return t}},{}],"55HY1":[function(e,t,r){"use strict";const i=e("is-loopback-addr");t.exports=function(e){const{address:t}=e.nodeAddress();return i(t)}},{"is-loopback-addr":"8SMxm"}],"8SMxm":[function(e,t,r){"use strict";t.exports=function(e){return/^127\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/i.test(e)||/^::1$/.test(e)}},{}],"1MCQb":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-bitswap"),n=e("./libp2p.js"),s=e("multiaddr"),o=e("err-code"),a=e("../block-storage.js");function c(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var u=c(o);class l{constructor(e,t,r,i,n){this.peerId=e,this.libp2p=t,this.bitswap=r,this.repo=i,this.blockstore=n}static async start({peerId:e,repo:t,print:r,options:s}){t.closed&&await t.open();const o=await t.config.getAll(),c=await n.createLibp2p({options:s,repo:t,peerId:e,multiaddrs:d(e,o),config:o,keychainConfig:void 0});c.keychain&&await c.loadKeychain(),await c.start();for(const t of c.multiaddrs)r(`Swarm listening on ${t}/p2p/${e.toB58String()}`);const u=i.createBitswap(c,t.blocks,{statsEnabled:!0});await u.start();const f=new a.BlockStorage(t.blocks,u);return t.blocks=f,t.pins.blockstore=f,new l(e,c,u,t,f)}static async stop(e){e.repo.blocks=e.blockstore.unwrap(),e.repo.pins.blockstore=e.blockstore.unwrap(),await Promise.all([e.bitswap.stop(),e.libp2p.stop()])}}const d=(e,t)=>{const r=e.toB58String(),i=[],n=t.Addresses&&t.Addresses.Swarm||[];for(const e of n){let t=new s.Multiaddr(e);if(t.protoCodes().includes(f))throw u.default(new Error("websocket-star swarm addresses are not supported. See https://github.com/ipfs/js-ipfs/issues/2779"),"ERR_WEBSOCKET_STAR_SWARM_ADDR_NOT_SUPPORTED");const n=t.getPeerId();n&&n!==r&&(t=t.encapsulate(`/p2p/${r}`)),i.push(t)}return i},f=479;r.Network=l},{"ipfs-bitswap":"flwND","./libp2p.js":"jcB2q",multiaddr:"8Mu1u","err-code":"chZjB","../block-storage.js":"55a3I"}],flwND:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./bitswap.js");r.createBitswap=(e,t,r={})=>new i.Bitswap(e,t,r)},{"./bitswap.js":"dAIea"}],dAIea:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./want-manager/index.js"),n=e("./network.js"),s=e("./decision-engine/index.js"),o=e("./notifications.js"),a=e("./utils/index.js"),c=e("./stats/index.js"),u=e("native-abort-controller"),l=e("any-signal"),d=e("blockstore-core/base"),f=e("multiformats/cid");const h={statsEnabled:!1,statsComputeThrottleTimeout:1e3,statsComputeThrottleMaxQueueSize:1e3},p=["blocksReceived","dataReceived","dupBlksReceived","dupDataReceived","blocksSent","dataSent","providesBufferLength","wantListLength","peerCount"];class g extends d.BaseBlockstore{constructor(e,t,r={}){super(),this._libp2p=e,this._log=a.logger(this.peerId),this._options=Object.assign({},h,r),this._stats=new c.Stats(p,{enabled:this._options.statsEnabled,computeThrottleTimeout:this._options.statsComputeThrottleTimeout,computeThrottleMaxQueueSize:this._options.statsComputeThrottleMaxQueueSize}),this.network=new n.Network(e,this,this._stats,{hashLoader:r.hashLoader}),this.blockstore=t,this.engine=new s.DecisionEngine(this.peerId,t,this.network,this._stats),this.wm=new i.WantManager(this.peerId,this.network,this._stats),this.notifications=new o.Notifications(this.peerId),this.started=!1}isStarted(){return this.started}get peerId(){return this._libp2p.peerId}async _receiveMessage(e,t){try{await this.engine.messageReceived(e,t)}catch(e){this._log("failed to receive message",t)}if(0===t.blocks.size)return;const r=[];for(const[e,i]of t.blocks.entries()){const t=f.CID.parse(e);r.push({wasWanted:this.wm.wantlist.contains(t),cid:t,data:i})}this.wm.cancelWants(r.filter((({wasWanted:e})=>e)).map((({cid:e})=>e))),await Promise.all(r.map((({cid:t,wasWanted:r,data:i})=>this._handleReceivedBlock(e,t,i,r))))}async _handleReceivedBlock(e,t,r,i){this._log("received block");const n=await this.blockstore.has(t);this._updateReceiveCounters(e.toB58String(),t,r,n),i&&await this.put(t,r)}_updateReceiveCounters(e,t,r,i){this._stats.push(e,"blocksReceived",1),this._stats.push(e,"dataReceived",r.length),i&&(this._stats.push(e,"dupBlksReceived",1),this._stats.push(e,"dupDataReceived",r.length))}_receiveError(e){this._log.error("ReceiveError: %s",e.message)}_onPeerConnected(e){this.wm.connected(e)}_onPeerDisconnected(e){this.wm.disconnected(e),this.engine.peerDisconnected(e),this._stats.disconnected(e)}enableStats(){this._stats.enable()}disableStats(){this._stats.disable()}wantlistForPeer(e,t){return this.engine.wantlistForPeer(e)}ledgerForPeer(e){return this.engine.ledgerForPeer(e)}async get(e,t={}){const r=(e,t)=>(this.wm.wantBlocks([e],t),this.notifications.wantBlock(e,t));let i=!1;const n=new u.AbortController,s=t.signal?l.anySignal([t.signal,n.signal]):n.signal,o=await Promise.race([this.notifications.wantBlock(e,{signal:s}),(async(e,t)=>{try{return await this.blockstore.get(e,t)}catch(n){if("ERR_NOT_FOUND"!==n.code)throw n;return i||(i=!0,this.network.findAndConnect(e).catch((e=>this._log.error(e)))),r(e,t)}})(e,{signal:s})]);return n.abort(),o}async*getMany(e,t={}){for await(const r of e)yield this.get(r,t)}unwant(e){const t=Array.isArray(e)?e:[e];this.wm.unwantBlocks(t),t.forEach((e=>this.notifications.unwantBlock(e)))}cancelWants(e){this.wm.cancelWants(Array.isArray(e)?e:[e])}async put(e,t,r){await this.blockstore.put(e,t),this._sendHaveBlockNotifications(e,t)}async*putMany(e,t){for await(const{key:r,value:i}of this.blockstore.putMany(e,t))this._sendHaveBlockNotifications(r,i),yield{key:r,value:i}}_sendHaveBlockNotifications(e,t){this.notifications.hasBlock(e,t),this.engine.receivedBlocks([{cid:e,data:t}]),this.network.provide(e).catch((e=>{this._log.error("Failed to provide: %s",e.message)}))}getWantlist(){return this.wm.wantlist.entries()}peers(){return this.engine.peers()}stat(){return this._stats}start(){this.wm.start(),this.network.start(),this.engine.start(),this.started=!0}stop(){this._stats.stop(),this.wm.stop(),this.network.stop(),this.engine.stop(),this.started=!1}unwrap(){return this.blockstore}}r.Bitswap=g},{"./want-manager/index.js":"i19lk","./network.js":"5d3og","./decision-engine/index.js":"drDE5","./notifications.js":"jCbDy","./utils/index.js":"9omCc","./stats/index.js":"da28N","native-abort-controller":"6zwoZ","any-signal":"kXgRR","blockstore-core/base":"l2CNM","multiformats/cid":"9ooAY"}],i19lk:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../message/index.js"),n=e("../wantlist/index.js"),s=e("../constants.js"),o=e("./msg-queue.js"),a=e("../utils/index.js"),c=e("multiformats/bases/base58");r.WantManager=class{constructor(e,t,r){this.peers=new Map,this.wantlist=new n.Wantlist(r),this.network=t,this._stats=r,this._peerId=e,this._log=a.logger(e,"want")}_addEntries(e,t,r){const n=e.map(((e,r)=>new i.BitswapMessage.Entry(e,s.kMaxPriority-r,i.BitswapMessage.WantType.Block,t)));n.forEach((e=>{e.cancel?r?this.wantlist.removeForce(e.cid.toString(c.base58btc)):this.wantlist.remove(e.cid):(this._log("adding to wl"),this.wantlist.add(e.cid,e.priority))}));for(const e of this.peers.values())e.addEntries(n)}_startPeerHandler(e){let t=this.peers.get(e.toB58String());if(t)return void t.refcnt++;t=new o.MsgQueue(this._peerId,e,this.network);const r=new i.BitswapMessage(!0);for(const e of this.wantlist.entries())r.addEntry(e[1].cid,e[1].priority);return t.addMessage(r),this.peers.set(e.toB58String(),t),t}_stopPeerHandler(e){const t=this.peers.get(e.toB58String());t&&(t.refcnt--,t.refcnt>0||this.peers.delete(e.toB58String()))}wantBlocks(e,t={}){this._addEntries(e,!1),t&&t.signal&&t.signal.addEventListener("abort",(()=>{this.cancelWants(e)}))}unwantBlocks(e){this._log("unwant blocks: %s",e.length),this._addEntries(e,!0,!0)}cancelWants(e){this._log("cancel wants: %s",e.length),this._addEntries(e,!0)}connectedPeers(){return Array.from(this.peers.keys())}connected(e){this._startPeerHandler(e)}disconnected(e){this._stopPeerHandler(e)}start(){}stop(){this.peers.forEach((e=>this.disconnected(e.peerId)))}}},{"../message/index.js":"3KDsa","../wantlist/index.js":"hFdtZ","../constants.js":"jvLuC","./msg-queue.js":"bgetp","../utils/index.js":"9omCc","multiformats/bases/base58":"4n7mA"}],"3KDsa":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("multiformats/hashes/sha2"),s=e("multiformats/bases/base58"),o=e("varint-decoder"),a=e("../utils/varint-encoder.js"),c=e("../utils/index.js"),u=e("./message.js"),l=e("./entry.js"),d=e("err-code");function f(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var h=f(o),p=f(d);class g{constructor(e){this.full=e,this.wantlist=new Map,this.blocks=new Map,this.blockPresences=new Map,this.pendingBytes=0}get empty(){return 0===this.blocks.size&&0===this.wantlist.size&&0===this.blockPresences.size}addEntry(e,t,r,i,n){null==r&&(r=g.WantType.Block);const o=e.toString(s.base58btc),a=this.wantlist.get(o);a?(a.wantType===r&&(a.priority=t),i&&(a.cancel=Boolean(i)),n&&(a.sendDontHave=Boolean(n)),r===g.WantType.Block&&a.wantType===g.WantType.Have&&(a.wantType=r)):this.wantlist.set(o,new l.BitswapMessageEntry(e,t,r,i,n))}addBlock(e,t){const r=e.toString(s.base58btc);this.blocks.set(r,t)}addHave(e){const t=e.toString(s.base58btc);this.blockPresences.has(t)||this.blockPresences.set(t,g.BlockPresenceType.Have)}addDontHave(e){const t=e.toString(s.base58btc);this.blockPresences.has(t)||this.blockPresences.set(t,g.BlockPresenceType.DontHave)}cancel(e){const t=e.toString(s.base58btc);this.wantlist.delete(t),this.addEntry(e,0,g.WantType.Block,!0,!1)}setPendingBytes(e){this.pendingBytes=e}serializeToBitswap100(){const e={wantlist:{entries:Array.from(this.wantlist.values()).map((e=>({block:e.cid.bytes,priority:Number(e.priority),cancel:Boolean(e.cancel)}))),full:!!this.full||void 0},blocks:Array.from(this.blocks.values())};return u.Message.encode(e).finish()}serializeToBitswap110(){const e={wantlist:{entries:Array.from(this.wantlist.values()).map((e=>({block:e.cid.bytes,priority:Number(e.priority),wantType:e.wantType,cancel:Boolean(e.cancel),sendDontHave:Boolean(e.sendDontHave)}))),full:!!this.full||void 0},blockPresences:[],payload:[],pendingBytes:this.pendingBytes};for(const[t,r]of this.blocks.entries()){const n=i.CID.parse(t),s=n.version,o=n.code,c=n.multihash.code,l=n.multihash.digest.length,d=a([s,o,c,l]);e.payload.push(new u.Message.Block({prefix:d,data:r}))}for(const[t,r]of this.blockPresences)e.blockPresences.push(new u.Message.BlockPresence({cid:i.CID.parse(t).bytes,type:r}));return this.pendingBytes>0&&(e.pendingBytes=this.pendingBytes),u.Message.encode(e).finish()}equals(e){return!!(this.full===e.full&&this.pendingBytes===e.pendingBytes&&c.isMapEqual(this.wantlist,e.wantlist)&&c.isMapEqual(this.blocks,e.blocks)&&c.isMapEqual(this.blockPresences,e.blockPresences))}get[Symbol.toStringTag](){const e=Array.from(this.wantlist.keys()),t=Array.from(this.blocks.keys());return`BitswapMessage `}}g.deserialize=async(e,t)=>{const r=u.Message.decode(e),s=r.wantlist&&r.wantlist.full||!1,o=new g(s);return r.wantlist&&r.wantlist.entries&&r.wantlist.entries.forEach((e=>{if(!e.block)return;const t=i.CID.decode(e.block);o.addEntry(t,e.priority||0,e.wantType,Boolean(e.cancel),Boolean(e.sendDontHave))})),r.blockPresences&&r.blockPresences.forEach((e=>{if(!e.cid)return;const t=i.CID.decode(e.cid);e.type===g.BlockPresenceType.Have?o.addHave(t):o.addDontHave(t)})),r.blocks.length>0?(await Promise.all(r.blocks.map((async e=>{const t=await n.sha256.digest(e),r=i.CID.createV0(t);o.addBlock(r,e)}))),o):r.payload.length>0?(await Promise.all(r.payload.map((async e=>{if(!e.prefix||!e.data)return;const r=h.default(e.prefix),s=r[0],a=r[1],c=r[2],u=c===n.sha256.code?n.sha256:t&&await t.getHasher(c);if(!u)throw p.default(new Error("Unknown hash algorithm"),"ERR_UNKNOWN_HASH_ALG");const l=await u.digest(e.data),d=i.CID.create(s,a,l);o.addBlock(d,e.data)}))),o.setPendingBytes(r.pendingBytes),o):o},g.blockPresenceSize=e=>e.bytes.length+1,g.Entry=l.BitswapMessageEntry,g.WantType={Block:u.Message.Wantlist.WantType.Block,Have:u.Message.Wantlist.WantType.Have},g.BlockPresenceType={Have:u.Message.BlockPresenceType.Have,DontHave:u.Message.BlockPresenceType.DontHave},r.BitswapMessage=g},{"multiformats/cid":"9ooAY","multiformats/hashes/sha2":"7i9MT","multiformats/bases/base58":"4n7mA","varint-decoder":"4XERa","../utils/varint-encoder.js":"4kcuH","../utils/index.js":"9omCc","./message.js":"2JgzA","./entry.js":"7Jb33","err-code":"chZjB"}],"4XERa":[function(e,t,r){"use strict";const i=e("varint");t.exports=e=>{if(!(e instanceof Uint8Array))throw new Error("arg needs to be a Uint8Array");const t=[];for(;e.length>0;){const r=i.decode(e);t.push(r),e=e.slice(i.decode.bytes)}return t}},{varint:"lqmon"}],lqmon:[function(e,t,r){t.exports={encode:e("./encode.js"),decode:e("./decode.js"),encodingLength:e("./length.js")}},{"./encode.js":"2HIPs","./decode.js":"5Jcva","./length.js":"cD3BZ"}],"2HIPs":[function(e,t,r){t.exports=function e(t,r,n){r=r||[];var s=n=n||0;for(;t>=i;)r[n++]=255&t|128,t/=128;for(;-128&t;)r[n++]=255&t|128,t>>>=7;return r[n]=0|t,e.bytes=n-s+1,r};var i=Math.pow(2,31)},{}],"5Jcva":[function(e,t,r){t.exports=function e(t,r){var i,n=0,s=0,o=r=r||0,a=t.length;do{if(o>=a)throw e.bytes=0,new RangeError("Could not decode varint");i=t[o++],n+=s<28?(127&i)<=128);return e.bytes=o-r,n}},{}],cD3BZ:[function(e,t,r){var i=Math.pow(2,7),n=Math.pow(2,14),s=Math.pow(2,21),o=Math.pow(2,28),a=Math.pow(2,35),c=Math.pow(2,42),u=Math.pow(2,49),l=Math.pow(2,56),d=Math.pow(2,63);t.exports=function(e){return ee+n.default.encodingLength(t)),0)),r=0;for(const i of e)t=n.encode(i,t,r),r+=n.default.encodingLength(i);return t}},{varint:"aN1CO"}],"9omCc":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("debug"),n=e("uint8arrays/equals"),s=e("../message/entry.js");function o(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=o(i);const c=(e,t,r)=>{let i=0;const n=r.length;for(;it.reduce(((t,r)=>{const i=e(r);return t[i]?t[i].push(r):t[i]=[r],t}),{}),r.includesWith=c,r.isMapEqual=(e,t)=>{if(e.size!==t.size)return!1;for(const[r,i]of e){const e=t.get(r);if(void 0===e)return!1;if(i instanceof Uint8Array&&e instanceof Uint8Array&&!n.equals(i,e))return!1;if(i instanceof s.BitswapMessageEntry&&e instanceof s.BitswapMessageEntry&&!i.equals(e))return!1}return!0},r.logger=(e,t)=>{const r=["bitswap"];return t&&r.push(t),e&&r.push(`${e.toB58String().slice(0,8)}`),Object.assign(a.default(r.join(":")),{error:a.default(r.concat(["error"]).join(":"))})},r.pullAllWith=(e,t,r)=>t.filter((t=>!c(e,t,r))),r.sortBy=(e,t)=>Array.prototype.slice.call(t,0).sort(((t,r)=>{const i=e(t),n=e(r);return in?1:0})),r.uniqWith=(e,t)=>{let r=0;const i=t.length,n=[];let s;for(;r`}equals(e){return this.cancel===e.cancel&&this.sendDontHave===e.sendDontHave&&this.wantType===e.wantType&&this.entry.equals(e.entry)}}r.BitswapMessageEntry=o},{"../wantlist/index.js":"hFdtZ","multiformats/bases/base58":"4n7mA"}],hFdtZ:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./entry.js"),n=e("multiformats/bases/base58"),s=e("../message/message.js");const o=s.Message.Wantlist.WantType.Block,a=s.Message.Wantlist.WantType.Have;class c{constructor(e){this.set=new Map,this._stats=e}get length(){return this.set.size}add(e,t,r){const s=e.toString(n.base58btc),c=this.set.get(s);c?(c.inc(),c.priority=t,c.wantType===a&&r===o&&(c.wantType=r)):(this.set.set(s,new i.WantListEntry(e,t,r)),this._stats&&this._stats.push(null,"wantListSize",1))}remove(e){const t=e.toString(n.base58btc),r=this.set.get(t);r&&(r.dec(),r.hasRefs()||(this.set.delete(t),this._stats&&this._stats.push(null,"wantListSize",-1)))}removeForce(e){this.set.has(e)&&this.set.delete(e)}forEach(e){return this.set.forEach(e)}entries(){return this.set.entries()}sortedEntries(){return new Map((e=e=>e[1].key,t=Array.from(this.set.entries()),Array.prototype.slice.call(t,0).sort(((t,r)=>{const i=e(t),n=e(r);return in?1:0}))));var e,t}contains(e){const t=e.toString(n.base58btc);return this.set.has(t)}get(e){const t=e.toString(n.base58btc);return this.set.get(t)}}c.Entry=i.WantListEntry,r.Wantlist=c},{"./entry.js":"9pqLF","multiformats/bases/base58":"4n7mA","../message/message.js":"2JgzA"}],"9pqLF":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/bases/base58");class n{constructor(e,t,r){this._refCounter=1,this.cid=e,this.priority=t||1,this.wantType=r}inc(){this._refCounter+=1}dec(){this._refCounter=Math.max(0,this._refCounter-1)}hasRefs(){return this._refCounter>0}get[Symbol.toStringTag](){return`WantlistEntry `}equals(e){return this._refCounter===e._refCounter&&this.cid.equals(e.cid)&&this.priority===e.priority&&this.wantType===e.wantType}}r.WantListEntry=n},{"multiformats/bases/base58":"4n7mA"}],"2JgzA":[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("protobufjs/minimal.js"));const s=n.default.Reader,o=n.default.Writer,a=n.default.util,c=n.default.roots["ipfs-bitswap"]||(n.default.roots["ipfs-bitswap"]={}),u=c.Message=(()=>{function e(e){if(this.blocks=[],this.payload=[],this.blockPresences=[],e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.wantlist=c.Message.Wantlist.decode(e,e.uint32());break;case 2:i.blocks&&i.blocks.length||(i.blocks=[]),i.blocks.push(e.bytes());break;case 3:i.payload&&i.payload.length||(i.payload=[]),i.payload.push(c.Message.Block.decode(e,e.uint32()));break;case 4:i.blockPresences&&i.blockPresences.length||(i.blockPresences=[]),i.blockPresences.push(c.Message.BlockPresence.decode(e,e.uint32()));break;case 5:i.pendingBytes=e.int32();break;default:e.skipType(7&n)}}return i},e.fromObject=function(e){if(e instanceof c.Message)return e;var t=new c.Message;if(null!=e.wantlist){if("object"!=typeof e.wantlist)throw TypeError(".Message.wantlist: object expected");t.wantlist=c.Message.Wantlist.fromObject(e.wantlist)}if(e.blocks){if(!Array.isArray(e.blocks))throw TypeError(".Message.blocks: array expected");t.blocks=[];for(var r=0;r>>3){case 1:i.entries&&i.entries.length||(i.entries=[]),i.entries.push(c.Message.Wantlist.Entry.decode(e,e.uint32()));break;case 2:i.full=e.bool();break;default:e.skipType(7&n)}}return i},e.fromObject=function(e){if(e instanceof c.Message.Wantlist)return e;var t=new c.Message.Wantlist;if(e.entries){if(!Array.isArray(e.entries))throw TypeError(".Message.Wantlist.entries: array expected");t.entries=[];for(var r=0;r>>3){case 1:i.block=e.bytes();break;case 2:i.priority=e.int32();break;case 3:i.cancel=e.bool();break;case 4:i.wantType=e.int32();break;case 5:i.sendDontHave=e.bool();break;default:e.skipType(7&n)}}return i},e.fromObject=function(e){if(e instanceof c.Message.Wantlist.Entry)return e;var t=new c.Message.Wantlist.Entry;switch(null!=e.block&&("string"==typeof e.block?a.base64.decode(e.block,t.block=a.newBuffer(a.base64.length(e.block)),0):e.block.length&&(t.block=e.block)),null!=e.priority&&(t.priority=0|e.priority),null!=e.cancel&&(t.cancel=Boolean(e.cancel)),e.wantType){case"Block":case 0:t.wantType=0;break;case"Have":case 1:t.wantType=1}return null!=e.sendDontHave&&(t.sendDontHave=Boolean(e.sendDontHave)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(t.bytes===String?r.block="":(r.block=[],t.bytes!==Array&&(r.block=a.newBuffer(r.block))),r.priority=0,r.cancel=!1,r.wantType=t.enums===String?"Block":0,r.sendDontHave=!1),null!=e.block&&e.hasOwnProperty("block")&&(r.block=t.bytes===String?a.base64.encode(e.block,0,e.block.length):t.bytes===Array?Array.prototype.slice.call(e.block):e.block),null!=e.priority&&e.hasOwnProperty("priority")&&(r.priority=e.priority),null!=e.cancel&&e.hasOwnProperty("cancel")&&(r.cancel=e.cancel),null!=e.wantType&&e.hasOwnProperty("wantType")&&(r.wantType=t.enums===String?c.Message.Wantlist.WantType[e.wantType]:e.wantType),null!=e.sendDontHave&&e.hasOwnProperty("sendDontHave")&&(r.sendDontHave=e.sendDontHave),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,n.default.util.toJSONOptions)},e}(),e}(),e.Block=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.prefix=e.bytes();break;case 2:i.data=e.bytes();break;default:e.skipType(7&n)}}return i},e.fromObject=function(e){if(e instanceof c.Message.Block)return e;var t=new c.Message.Block;return null!=e.prefix&&("string"==typeof e.prefix?a.base64.decode(e.prefix,t.prefix=a.newBuffer(a.base64.length(e.prefix)),0):e.prefix.length&&(t.prefix=e.prefix)),null!=e.data&&("string"==typeof e.data?a.base64.decode(e.data,t.data=a.newBuffer(a.base64.length(e.data)),0):e.data.length&&(t.data=e.data)),t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(t.bytes===String?r.prefix="":(r.prefix=[],t.bytes!==Array&&(r.prefix=a.newBuffer(r.prefix))),t.bytes===String?r.data="":(r.data=[],t.bytes!==Array&&(r.data=a.newBuffer(r.data)))),null!=e.prefix&&e.hasOwnProperty("prefix")&&(r.prefix=t.bytes===String?a.base64.encode(e.prefix,0,e.prefix.length):t.bytes===Array?Array.prototype.slice.call(e.prefix):e.prefix),null!=e.data&&e.hasOwnProperty("data")&&(r.data=t.bytes===String?a.base64.encode(e.data,0,e.data.length):t.bytes===Array?Array.prototype.slice.call(e.data):e.data),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,n.default.util.toJSONOptions)},e}(),e.BlockPresenceType=function(){const e={},t=Object.create(e);return t[e[0]="Have"]=0,t[e[1]="DontHave"]=1,t}(),e.BlockPresence=function(){function e(e){if(e)for(var t=Object.keys(e),r=0;r>>3){case 1:i.cid=e.bytes();break;case 2:i.type=e.int32();break;default:e.skipType(7&n)}}return i},e.fromObject=function(e){if(e instanceof c.Message.BlockPresence)return e;var t=new c.Message.BlockPresence;switch(null!=e.cid&&("string"==typeof e.cid?a.base64.decode(e.cid,t.cid=a.newBuffer(a.base64.length(e.cid)),0):e.cid.length&&(t.cid=e.cid)),e.type){case"Have":case 0:t.type=0;break;case"DontHave":case 1:t.type=1}return t},e.toObject=function(e,t){t||(t={});var r={};return t.defaults&&(t.bytes===String?r.cid="":(r.cid=[],t.bytes!==Array&&(r.cid=a.newBuffer(r.cid))),r.type=t.enums===String?"Have":0),null!=e.cid&&e.hasOwnProperty("cid")&&(r.cid=t.bytes===String?a.base64.encode(e.cid,0,e.cid.length):t.bytes===Array?Array.prototype.slice.call(e.cid):e.cid),null!=e.type&&e.hasOwnProperty("type")&&(r.type=t.enums===String?c.Message.BlockPresenceType[e.type]:e.type),r},e.prototype.toJSON=function(){return this.constructor.toObject(this,n.default.util.toJSONOptions)},e}(),e})();r.Message=u,r.default=c},{"protobufjs/minimal.js":"grAXL"}],jvLuC:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});const i=Math.pow(2,31)-1;r.hasBlockTimeout=15e3,r.kMaxPriority=i,r.maxListeners=1e3,r.maxProvidersPerRequest=3,r.provideTimeout=15e3,r.providerRequestTimeout=1e4,r.wantlistSendDebounceMs=1},{}],bgetp:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("just-debounce-it"),n=e("../message/index.js"),s=e("../utils/index.js"),o=e("../constants.js");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var c=a(i);r.MsgQueue=class{constructor(e,t,r){this.peerId=t,this.network=r,this.refcnt=1,this._entries=[],this._log=s.logger(e,"msgqueue"),this.sendEntries=c.default(this._sendEntries.bind(this),o.wantlistSendDebounceMs)}addMessage(e){e.empty||this.send(e)}addEntries(e){this._entries=this._entries.concat(e),this.sendEntries()}_sendEntries(){if(!this._entries.length)return;const e=new n.BitswapMessage(!1);this._entries.forEach((t=>{t.cancel?e.cancel(t.cid):e.addEntry(t.cid,t.priority)})),this._entries=[],this.addMessage(e)}async send(e){try{await this.network.connectTo(this.peerId)}catch(e){return void this._log.error("cant connect to peer %s: %s",this.peerId.toB58String(),e.message)}this._log("sending message to peer %s",this.peerId.toB58String()),this.network.sendMessage(this.peerId,e).catch((e=>{this._log.error("send error: %s",e.message)}))}}},{"just-debounce-it":"ci2L4","../message/index.js":"3KDsa","../utils/index.js":"9omCc","../constants.js":"jvLuC"}],ci2L4:[function(e,t,r){t.exports=function(e,t,r){var i=null,n=null,s=function(){i&&(clearTimeout(i),n=null,i=null)},o=function(){if(!t)return e.apply(this,arguments);var o=this,a=arguments,c=r&&!i;return s(),n=function(){e.apply(o,a)},i=setTimeout((function(){if(i=null,!c){var e=n;return n=null,e()}}),t),c?n():void 0};return o.cancel=s,o.flush=function(){var e=n;s(),e&&e()},o}},{}],"5d3og":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("it-length-prefixed"),n=e("it-pipe"),s=e("libp2p-interfaces/src/topology/multicodec-topology.js"),o=e("./message/index.js"),a=e("./constants.js"),c=e("./utils/index.js");function u(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var l=u(i),d=u(s);const f="/ipfs/bitswap/1.0.0",h="/ipfs/bitswap/1.1.0",p="/ipfs/bitswap/1.2.0";r.Network=class{constructor(e,t,r,i={}){this._log=c.logger(e.peerId,"network"),this._libp2p=e,this._bitswap=t,this._protocols=[f],i.b100Only||(this._protocols.unshift(h),this._protocols.unshift(p)),this._stats=r,this._running=!1,this._onPeerConnect=this._onPeerConnect.bind(this),this._onPeerDisconnect=this._onPeerDisconnect.bind(this),this._onConnection=this._onConnection.bind(this),this._hashLoader=i.hashLoader}start(){this._running=!0,this._libp2p.handle(this._protocols,this._onConnection);const e=new d.default({multicodecs:this._protocols,handlers:{onConnect:this._onPeerConnect,onDisconnect:this._onPeerDisconnect}});this._registrarId=this._libp2p.registrar.register(e);for(const e of this._libp2p.peerStore.peers.values()){const t=this._libp2p.connectionManager.get(e.id);t&&this._onPeerConnect(t.remotePeer)}}stop(){this._running=!1,this._libp2p.unhandle(this._protocols),null!=this._registrarId&&this._libp2p.registrar.unregister(this._registrarId)}async _onConnection({protocol:e,stream:t,connection:r}){if(this._running){this._log("incoming new bitswap %s connection from %s",e,r.remotePeer.toB58String());try{await n.pipe(t,l.default.decode(),(async e=>{for await(const t of e)try{const e=await o.BitswapMessage.deserialize(t.slice(),this._hashLoader);await this._bitswap._receiveMessage(r.remotePeer,e)}catch(e){this._bitswap._receiveError(e);break}}))}catch(e){this._log(e)}}}_onPeerConnect(e){this._bitswap._onPeerConnected(e)}_onPeerDisconnect(e){this._bitswap._onPeerDisconnected(e)}findProviders(e,t,r={}){return this._libp2p.contentRouting.findProviders(e,{timeout:a.providerRequestTimeout,maxNumProviders:t})}async findAndConnect(e,t){const r=[];for await(const i of this.findProviders(e,a.maxProvidersPerRequest,t))this._log(`connecting to provider ${i.id}`),r.push(this.connectTo(i.id,t).catch((e=>{this._log.error(e)})));await Promise.all(r)}async provide(e,t){await this._libp2p.contentRouting.provide(e,t)}async sendMessage(e,t){if(!this._running)throw new Error("network isn't running");const r=e.toB58String();this._log("sendMessage to %s",r,t);const i=await this._libp2p.dial(e),{stream:s,protocol:o}=await i.newStream([p,h,f]);let a;switch(o){case f:a=t.serializeToBitswap100();break;case h:case p:a=t.serializeToBitswap110();break;default:throw new Error("Unknown protocol: "+o)}!async function(e,t,r){try{await n.pipe([t],l.default.encode(),e)}catch(e){r(e)}}(s,a,this._log),this._updateSentStats(e,t.blocks)}async connectTo(e,t){if(!this._running)throw new Error("network isn't running");return this._libp2p.dial(e,t)}_updateSentStats(e,t){const r=e.toB58String();if(this._stats){for(const e of t.values())this._stats.push(r,"dataSent",e.length);this._stats.push(r,"blocksSent",t.size)}}}},{"it-length-prefixed":"3yxIE","it-pipe":"giKBQ","libp2p-interfaces/src/topology/multicodec-topology.js":"52SML","./message/index.js":"3KDsa","./constants.js":"jvLuC","./utils/index.js":"9omCc"}],drDE5:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("multiformats/cid"),n=e("multiformats/bases/base58"),s=e("../message/index.js"),o=e("../wantlist/index.js"),a=e("./ledger.js"),c=e("./req-queue.js"),u=e("./task-merger.js"),l=e("../utils/index.js");const d=s.BitswapMessage.WantType;r.DecisionEngine=class{constructor(e,t,r,i,n={}){this._log=l.logger(e,"engine"),this.blockstore=t,this.network=r,this._stats=i,this._opts=this._processOpts(n),this.ledgerMap=new Map,this._running=!1,this._requestQueue=new c.RequestQueue(u.TaskMerger)}_processOpts(e){return{maxSizeReplaceHasWithBlock:1024,targetMessageSize:16384,...e}}_scheduleProcessTasks(){setTimeout((()=>{this._processTasks()}))}async _processTasks(){if(!this._running)return;const{peerId:e,tasks:t,pendingSize:r}=this._requestQueue.popTasks(this._opts.targetMessageSize);if(0===t.length)return;const n=new s.BitswapMessage(!1);n.setPendingBytes(r);const o=[],a=new Map;for(const e of t){const t=i.CID.parse(e.topic);e.data.haveBlock?e.data.isWantBlock?(o.push(t),a.set(e.topic,e.data)):n.addHave(t):n.addDontHave(t)}const c=await this._getBlocks(o);for(const[e,t]of a){const r=i.CID.parse(e),s=c.get(e);s?n.addBlock(r,s):t.sendDontHave&&n.addDontHave(r)}if(n.empty)return e&&this._requestQueue.tasksDone(e,t),void this._scheduleProcessTasks();try{e&&await this.network.sendMessage(e,n);for(const[t,r]of c.entries())e&&this.messageSent(e,i.CID.parse(t),r)}catch(e){this._log.error(e)}e&&this._requestQueue.tasksDone(e,t),this._scheduleProcessTasks()}wantlistForPeer(e){const t=e.toB58String(),r=this.ledgerMap.get(t);return r?r.wantlist.sortedEntries():new Map}ledgerForPeer(e){const t=e.toB58String(),r=this.ledgerMap.get(t);return r?{peer:r.partner,value:r.debtRatio(),sent:r.accounting.bytesSent,recv:r.accounting.bytesRecv,exchanged:r.exchangeCount}:null}peers(){return Array.from(this.ledgerMap.values()).map((e=>e.partner))}receivedBlocks(e){if(e.length){for(const t of this.ledgerMap.values())for(const r of e){const e=t.wantlistContains(r.cid);if(!e)continue;const i=r.data.length,o=this._sendAsBlock(e.wantType,i);let a=i;o||(a=s.BitswapMessage.blockPresenceSize(e.cid)),this._requestQueue.pushTasks(t.partner,[{topic:e.cid.toString(n.base58btc),priority:e.priority,size:a,data:{blockSize:i,isWantBlock:o,haveBlock:!0,sendDontHave:!1}}])}this._scheduleProcessTasks()}}async messageReceived(e,t){const r=this._findOrCreate(e);if(t.empty)return;if(t.full&&(r.wantlist=new o.Wantlist),this._updateBlockAccounting(t.blocks,r),0===t.wantlist.size)return void this._scheduleProcessTasks();const i=[],n=[];t.wantlist.forEach((e=>{e.cancel?(r.cancelWant(e.cid),i.push(e.cid)):(r.wants(e.cid,e.priority,e.wantType),n.push(e))})),this._cancelWants(e,i),await this._addWants(e,n),this._scheduleProcessTasks()}_cancelWants(e,t){for(const r of t)this._requestQueue.remove(r.toString(n.base58btc),e)}async _addWants(e,t){const r=await this._getBlockSizes(t.map((e=>e.cid))),i=[];for(const o of t){const t=o.cid.toString(n.base58btc),a=r.get(t);if(null==a)o.sendDontHave&&i.push({topic:t,priority:o.priority,size:s.BitswapMessage.blockPresenceSize(o.cid),data:{isWantBlock:o.wantType===d.Block,blockSize:0,haveBlock:!1,sendDontHave:o.sendDontHave}});else{const e=this._sendAsBlock(o.wantType,a);let r=a;e||(r=s.BitswapMessage.blockPresenceSize(o.cid)),i.push({topic:t,priority:o.priority,size:r,data:{isWantBlock:e,blockSize:a,haveBlock:!0,sendDontHave:o.sendDontHave}})}this._requestQueue.pushTasks(e,i)}}_sendAsBlock(e,t){return e===d.Block||t<=this._opts.maxSizeReplaceHasWithBlock}async _getBlockSizes(e){const t=await this._getBlocks(e);return new Map([...t].map((([e,t])=>[e,t.length])))}async _getBlocks(e){const t=new Map;return await Promise.all(e.map((async e=>{try{const r=await this.blockstore.get(e);t.set(e.toString(n.base58btc),r)}catch(t){"ERR_NOT_FOUND"!==t.code&&this._log.error("failed to query blockstore for %s: %s",e,t)}}))),t}_updateBlockAccounting(e,t){for(const r of e.values())this._log("got block (%s bytes)",r.length),t.receivedBytes(r.length)}messageSent(e,t,r){const i=this._findOrCreate(e);i.sentBytes(r.length),i.wantlist.remove(t)}numBytesSentTo(e){return this._findOrCreate(e).accounting.bytesSent}numBytesReceivedFrom(e){return this._findOrCreate(e).accounting.bytesRecv}peerDisconnected(e){}_findOrCreate(e){const t=e.toB58String(),r=this.ledgerMap.get(t);if(r)return r;const i=new a.Ledger(e);return this.ledgerMap.set(t,i),this._stats&&this._stats.push(t,"peerCount",1),i}start(){this._running=!0}stop(){this._running=!1}}},{"multiformats/cid":"9ooAY","multiformats/bases/base58":"4n7mA","../message/index.js":"3KDsa","../wantlist/index.js":"hFdtZ","./ledger.js":"9MSJX","./req-queue.js":"2w6WU","./task-merger.js":"hlwar","../utils/index.js":"9omCc"}],"9MSJX":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../wantlist/index.js");r.Ledger=class{constructor(e){this.partner=e,this.wantlist=new i.Wantlist,this.exchangeCount=0,this.sentToPeer=new Map,this.accounting={bytesSent:0,bytesRecv:0}}sentBytes(e){this.exchangeCount++,this.lastExchange=(new Date).getTime(),this.accounting.bytesSent+=e}receivedBytes(e){this.exchangeCount++,this.lastExchange=(new Date).getTime(),this.accounting.bytesRecv+=e}wants(e,t,r){this.wantlist.add(e,t,r)}cancelWant(e){this.wantlist.remove(e)}wantlistContains(e){return this.wantlist.get(e)}debtRatio(){return this.accounting.bytesSent/(this.accounting.bytesRecv+1)}}},{"../wantlist/index.js":"hFdtZ"}],"2w6WU":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("../utils/sorted-map.js");const n={hasNewInfo:()=>!1,merge(){}};class s{constructor(e,t){this.peerId=e,this._taskMerger=t,this._activeTotalSize=0,this._pending=new o,this._active=new Set}pushTasks(e){for(const t of e)this._pushTask(t)}_pushTask(e){if(!this._taskHasMoreInfoThanActiveTasks(e))return;const t=this._pending.get(e.topic);if(t)return e.priority>t.priority&&this._pending.updatePriority(e.topic,e.priority),void this._taskMerger.merge(e,t);this._pending.add(e)}_taskHasMoreInfoThanActiveTasks(e){const t=[];for(const r of this._active)r.topic===e.topic&&t.push(r);return 0===t.length||this._taskMerger.hasNewInfo(e,t)}popTasks(e){let t=0;const r=[],i=this._pending.tasks();for(let n=0;ne+t.task.size),0)}get(e){return(this._tasks.get(e)||{}).task}add(e){this._tasks.set(e.topic,{created:Date.now(),task:e})}delete(e){this._tasks.delete(e)}tasks(){return[...this._tasks.values()].map((e=>e.task))}updatePriority(e,t){const r=this._tasks.get(e);if(!r)return;const i=this._tasks.indexOf(e);r.task.priority=t,this._tasks.update(i)}_compare(e,t){return e[1].task.priority===t[1].task.priority?e[1].created-t[1].created:t[1].task.priority-e[1].task.priority}}r.RequestQueue=class{constructor(e=n){this._taskMerger=e,this._byPeer=new i.SortedMap([],s.compare)}pushTasks(e,t){let r=this._byPeer.get(e.toB58String());r||(r=new s(e,this._taskMerger)),r.pushTasks(t),this._byPeer.set(e.toB58String(),r)}popTasks(e){const t=this._head();if(void 0===t)return{tasks:[],pendingSize:0};const{tasks:r,pendingSize:i}=t.popTasks(e);if(0===r.length)return{tasks:r,pendingSize:i};const n=t.peerId;return t.isIdle()?this._byPeer.delete(n.toB58String()):this._byPeer.update(0),{peerId:n,tasks:r,pendingSize:i}}_head(){if(0!==this._byPeer.size)for(const[,e]of this._byPeer)return e}remove(e,t){const r=this._byPeer.get(t.toB58String());r&&r.remove(e)}tasksDone(e,t){const r=this._byPeer.get(e.toB58String());if(!r)return;const i=this._byPeer.indexOf(e.toB58String());for(const e of t)r.taskDone(e);this._byPeer.update(i)}}},{"../utils/sorted-map.js":"h0gYa"}],h0gYa:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});class i extends Map{constructor(e,t){super(),this._cmp=t||this._defaultSort,this._keys=[];for(const[t,r]of e||[])this.set(t,r)}update(e){if(e<0||e>=this._keys.length)return;const t=this._keys[e];this._keys.splice(e,1);const r=this._find(t);this._keys.splice(r,0,t)}set(e,t){if(this.has(e)){const t=this.indexOf(e);this._keys.splice(t,1)}super.set(e,t);const r=this._find(e);return this._keys.splice(r,0,e),this}clear(){super.clear(),this._keys=[]}delete(e){if(!this.has(e))return!1;const t=this.indexOf(e);return this._keys.splice(t,1),super.delete(e)}indexOf(e){if(!this.has(e))return-1;const t=this._find(e);if(this._keys[t]===e)return t;for(let r=1;r>>1,n=this._kCmp(this._keys[i],e);if(n<0)t=i+1;else{if(!(n>0))return i;r=i}}return t}*keys(){for(const e of this._keys)yield e}*values(){for(const e of this._keys)yield this.get(e)}*entries(){for(const e of this._keys)yield[e,this.get(e)]}*[Symbol.iterator](){yield*this.entries()}forEach(e,t){if(e)for(const r of this._keys)e.apply(t,[[r,this.get(r)]])}_defaultSort(e,t){return e[0]`unwant:${n.toString(e.multihash.bytes,"base64")}`,c=e=>`block:${n.toString(e.multihash.bytes,"base64")}`;class u extends i.EventEmitter{constructor(e){super(),this.setMaxListeners(s.maxListeners),this._log=o.logger(e,"notif")}hasBlock(e,t){const r=c(e);this._log(r),this.emit(r,t)}wantBlock(e,t={}){if(!e)throw new Error("Not a valid cid");const r=c(e),i=a(e);return this._log(`wantBlock:${e}`),new Promise(((n,s)=>{const o=()=>{this.removeListener(r,a),s(new Error(`Block for ${e} unwanted`))},a=e=>{this.removeListener(i,o),n(e)};this.once(i,o),this.once(r,a),t&&t.signal&&t.signal.addEventListener("abort",(()=>{this.removeListener(r,a),this.removeListener(i,o),s(new Error(`Want for ${e} aborted`))}))}))}unwantBlock(e){const t=a(e);this._log(t),this.emit(t)}}r.Notifications=u},{events:"g82pp","uint8arrays/to-string":"hC8JB","./constants.js":"jvLuC","./utils/index.js":"9omCc"}],da28N:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("events"),n=e("./stat.js");const s={enabled:!1,computeThrottleTimeout:1e3,computeThrottleMaxQueueSize:1e3,movingAverageIntervals:[6e4,3e5,9e5]};class o extends i.EventEmitter{constructor(e=[],t=s){super();const r=Object.assign({},s,t);if("number"!=typeof r.computeThrottleTimeout)throw new Error("need computeThrottleTimeout");if("number"!=typeof r.computeThrottleMaxQueueSize)throw new Error("need computeThrottleMaxQueueSize");this._initialCounters=e,this._options=r,this._enabled=this._options.enabled,this._global=new n.Stat(e,r),this._global.on("update",(e=>this.emit("update",e))),this._peers=new Map}enable(){this._enabled=!0,this._options.enabled=!0,this._global.enable()}disable(){this._enabled=!1,this._options.enabled=!1,this._global.disable()}stop(){this._enabled=!1,this._global.stop();for(const e of this._peers)e[1].stop()}get snapshot(){return this._global.snapshot}get movingAverages(){return this._global.movingAverages}forPeer(e){const t="string"!=typeof e&&e.toB58String?e.toB58String():`${e}`;return this._peers.get(t)}push(e,t,r){if(this._enabled&&(this._global.push(t,r),e)){let i=this._peers.get(e);i||(i=new n.Stat(this._initialCounters,this._options),this._peers.set(e,i)),i.push(t,r)}}disconnected(e){const t=e.toB58String(),r=this._peers.get(t);r&&(r.stop(),this._peers.delete(t))}}r.Stats=o},{events:"g82pp","./stat.js":"bywlH"}],bywlH:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("events");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var s=n(e("@vascosantos/moving-average"));class o extends i.EventEmitter{constructor(e,t){super(),this._options=t,this._queue=[],this._stats={},this._frequencyLastTime=Date.now(),this._frequencyAccumulators={},this._movingAverages={},this._update=this._update.bind(this),e.forEach((e=>{this._stats[e]=BigInt(0),this._movingAverages[e]={},this._options.movingAverageIntervals.forEach((t=>{(this._movingAverages[e][t]=s.default(t)).push(this._frequencyLastTime,0)}))})),this._enabled=this._options.enabled}enable(){this._enabled=!0}disable(){this._disabled=!0}stop(){this._timeout&&clearTimeout(this._timeout)}get snapshot(){return Object.assign({},this._stats)}get movingAverages(){return Object.assign({},this._movingAverages)}push(e,t){this._enabled&&(this._queue.push([e,t,Date.now()]),this._resetComputeTimeout())}_resetComputeTimeout(){this._timeout&&clearTimeout(this._timeout),this._timeout=setTimeout(this._update,this._nextTimeout())}_nextTimeout(){const e=this._queue.length/this._options.computeThrottleMaxQueueSize;return Math.max(this._options.computeThrottleTimeout*(1-e),0)}_update(){if(this._timeout=null,this._queue.length){let e;for(;this._queue.length;){const t=e=this._queue.shift();t&&this._applyOp(t)}e&&this._updateFrequency(e[2]),this.emit("update",this._stats)}}_updateFrequency(e){const t=e-this._frequencyLastTime;t&&Object.keys(this._stats).forEach((r=>{this._updateFrequencyFor(r,t,e)})),this._frequencyLastTime=e}_updateFrequencyFor(e,t,r){const i=this._frequencyAccumulators[e]||0;this._frequencyAccumulators[e]=0;const n=i/t*1e3;let o=this._movingAverages[e];o||(o=this._movingAverages[e]={}),this._options.movingAverageIntervals.forEach((e=>{let t=o[e];t||(t=o[e]=s.default(e)),t.push(r,n)}))}_applyOp(e){const t=e[0],r=e[1];if("number"!=typeof r)throw new Error(`invalid increment number: ${r}`);Object.prototype.hasOwnProperty.call(this._stats,t)||(this._stats[t]=BigInt(0)),this._stats[t]=BigInt(this._stats[t])+BigInt(r),this._frequencyAccumulators[t]||(this._frequencyAccumulators[t]=0),this._frequencyAccumulators[t]+=r}}r.Stat=o},{events:"g82pp","@vascosantos/moving-average":"2F3Pq"}],"55a3I":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("blockstore-core"),n=e("it-merge"),s=e("it-pushable"),o=e("it-filter");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var c=a(n),u=a(s),l=a(o);class d extends i.BaseBlockstore{constructor(e,t){super(),this.child=e,this.bitswap=t}open(){return this.child.open()}close(){return this.child.close()}unwrap(){return this.child}async put(e,t,r={}){await this.has(e)||(this.bitswap.isStarted()?await this.bitswap.put(e,t,r):await this.child.put(e,t,r))}async*putMany(e,t={}){const r=l.default(e,(async({key:e})=>!await this.has(e)));this.bitswap.isStarted()?yield*this.bitswap.putMany(r,t):yield*this.child.putMany(r,t)}async get(e,t={}){return!await this.has(e)&&this.bitswap.isStarted()?this.bitswap.get(e,t):this.child.get(e,t)}async*getMany(e,t={}){const r=u.default(),i=u.default();Promise.resolve().then((async()=>{for await(const t of e)!await this.has(t)&&this.bitswap.isStarted()?r.push(t):i.push(t);r.end(),i.end()})),yield*c.default(this.bitswap.getMany(r,t),this.child.getMany(i,t))}async delete(e,t){await this.child.delete(e,t)}async*deleteMany(e,t){yield*this.child.deleteMany(e,t)}async has(e,t={}){return this.child.has(e,t)}async*query(e,t={}){yield*this.child.query(e,t)}async*queryKeys(e,t={}){yield*this.child.queryKeys(e,t)}}r.BlockStorage=d},{"blockstore-core":"alw2u","it-merge":"cPFu3","it-pushable":"bnpei","it-filter":"5LCTL"}],alw2u:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./errors.js"),n=e("./base.js"),s=e("./memory.js");const o={...i};r.BaseBlockstore=n.BaseBlockstore,r.MemoryBlockstore=s.MemoryBlockstore,r.Errors=o},{"./errors.js":"eBPsS","./base.js":"l2CNM","./memory.js":"ahARU"}],eBPsS:[function(e,t,r){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}Object.defineProperty(r,"__esModule",{value:!0});var n=i(e("err-code"));r.abortedError=function(e){return e=e||new Error("Aborted"),n.default(e,"ERR_ABORTED")},r.notFoundError=function(e){return e=e||new Error("Not Found"),n.default(e,"ERR_NOT_FOUND")}},{"err-code":"chZjB"}],ahARU:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./base.js"),n=e("multiformats/bases/base32"),s=e("multiformats/codecs/raw"),o=e("multiformats/cid"),a=e("multiformats/hashes/digest"),c=e("./errors.js");function u(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var i=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,i.get?i:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var l=u(s),d=u(a);class f extends i.BaseBlockstore{constructor(){super(),this.data={}}open(){return Promise.resolve()}close(){return Promise.resolve()}async put(e,t){this.data[n.base32.encode(e.multihash.bytes)]=t}async get(e){if(!await this.has(e))throw c.notFoundError();return this.data[n.base32.encode(e.multihash.bytes)]}async has(e){return void 0!==this.data[n.base32.encode(e.multihash.bytes)]}async delete(e){delete this.data[n.base32.encode(e.multihash.bytes)]}async*_all(){yield*Object.entries(this.data).map((([e,t])=>({key:o.CID.createV1(l.code,d.decode(n.base32.decode(e))),value:t})))}async*_allKeys(){yield*Object.entries(this.data).map((([e])=>o.CID.createV1(l.code,d.decode(n.base32.decode(e)))))}}r.MemoryBlockstore=f},{"./base.js":"l2CNM","multiformats/bases/base32":"5k9Tu","multiformats/codecs/raw":"fdfgp","multiformats/cid":"9ooAY","multiformats/hashes/digest":"kpRBg","./errors.js":"eBPsS"}],cGDFf:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("./addrs.js"),n=e("./connect.js"),s=e("./disconnect.js"),o=e("./local-addrs.js"),a=e("./peers.js");r.SwarmAPI=class{constructor({network:e}){this.addrs=i.createAddrs({network:e}),this.connect=n.createConnect({network:e}),this.disconnect=s.createDisconnect({network:e}),this.localAddrs=o.createLocalAddrs({network:e}),this.peers=a.createPeers({network:e})}}},{"./addrs.js":"4nmdM","./connect.js":"1cg0c","./disconnect.js":"kER7G","./local-addrs.js":"vjKoo","./peers.js":"gf7YS"}],"4nmdM":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/with-timeout-option");r.createAddrs=function({network:e}){return i.withTimeoutOption((async function(t={}){const r=[],{libp2p:i}=await e.use(t);for(const[e,t]of i.peerStore.peers.entries())r.push({id:e,addrs:t.addresses.map((e=>e.multiaddr))});return r}))}},{"ipfs-core-utils/with-timeout-option":"j29MK"}],"1cg0c":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/with-timeout-option");r.createConnect=function({network:e}){return i.withTimeoutOption((async function(t,r={}){const{libp2p:i}=await e.use(r);await i.dial(t,r)}))}},{"ipfs-core-utils/with-timeout-option":"j29MK"}],kER7G:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/with-timeout-option");r.createDisconnect=function({network:e}){return i.withTimeoutOption((async function(t,r={}){const{libp2p:i}=await e.use(r);await i.hangUp(t)}))}},{"ipfs-core-utils/with-timeout-option":"j29MK"}],vjKoo:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/with-timeout-option");r.createLocalAddrs=function({network:e}){return i.withTimeoutOption((async function(t={}){const{libp2p:r}=await e.use(t);return r.multiaddrs}))}},{"ipfs-core-utils/with-timeout-option":"j29MK"}],gf7YS:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/with-timeout-option");r.createPeers=function({network:e}){return i.withTimeoutOption((async function(t={}){const{libp2p:r}=await e.use(t),i=[];for(const[e,n]of r.connections)for(const r of n){const n={addr:r.remoteAddr,peer:e};(t.verbose||t.direction)&&(n.direction=r.stat.direction),t.verbose&&(n.muxer=r.stat.multiplexer,n.latency="n/a",n.streams=[]),i.push(n)}return i}))}},{"ipfs-core-utils/with-timeout-option":"j29MK"}],dHQEh:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("peer-id"),n=e("ipfs-core-utils/with-timeout-option");function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=s(i);const a={success:!0,time:0,text:""};r.createPing=function({network:e}){return n.withTimeoutOption((async function*(t,r={}){const{libp2p:i}=await e.use();r.count=r.count||10;const n=o.default.createFromB58String(t),s=i.peerStore.get(n);let c=s&&s.id;if(!c){yield{...a,text:`Looking up peer ${t}`};const e=await i.peerRouting.findPeer(n);c=e&&e.id}if(!c)throw new Error("Peer was not found");yield{...a,text:`PING ${c.toB58String()}`};let u=0,l=0;for(let e=0;e{const r=await e.use(t);if(d.default(r.libp2p,"_config.dht.enabled",!1))return r;throw new s.NotEnabledError("dht not enabled")};r.createDht=function({network:e,repo:t}){const{get:r,put:i,findProvs:n,findPeer:s,provide:o,query:c}={async get(t,r={}){const{libp2p:i}=await f(e,r);return i._dht.get(t,r)},async*put(t,r,i){const{libp2p:n}=await f(e,i);yield*n._dht.put(t,r)},async*findProvs(t,r={numProviders:20}){const{libp2p:i}=await f(e,r);for await(const e of i._dht.findProviders(t,{maxNumProviders:r.numProviders,signal:r.signal}))yield{id:e.id.toB58String(),addrs:e.addrs}},async findPeer(t,r){const{libp2p:i}=await f(e,r),n=await i._dht.findPeer(u.default.parse(t));return{id:n.id.toB58String(),addrs:n.multiaddrs}},async*provide(r,i={recursive:!1}){const{libp2p:n}=await f(e,i),s=Array.isArray(r)?r:[r];if(!(await Promise.all(s.map((e=>t.blocks.has(e))))).every((e=>e)))throw l.default(new Error("block(s) not found locally, cannot provide"),"ERR_BLOCK_NOT_FOUND");if(i.recursive)throw l.default(new Error("not implemented yet"),"ERR_NOT_IMPLEMENTED_YET");for(const e of s)yield n._dht.provide(e)},async*query(t,r){const{libp2p:i}=await f(e,r);for await(const e of i._dht.getClosestPeers(u.default.parse(t).toBytes()))yield{id:e.toB58String(),addrs:[]}}};return{get:a.withTimeoutOption(r),put:a.withTimeoutOption(i),findProvs:a.withTimeoutOption(n),findPeer:a.withTimeoutOption(s),provide:a.withTimeoutOption(o),query:a.withTimeoutOption(c)}}},{"peer-id":"8Bdb3","err-code":"chZjB","../errors.js":"j69o8",dlv:"hp0pQ","ipfs-core-utils/with-timeout-option":"j29MK"}],"7IJgU":[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var i=e("ipfs-core-utils/with-timeout-option"),n=e("err-code"),s=e("../errors.js"),o=e("dlv");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var c=a(n),u=a(o);const l=async()=>{throw new s.NotEnabledError("pubsub not enabled")};r.createPubsub=function({network:e,config:t}){const r=u.default(t||{},"Pubsub.Enabled",!0);return{subscribe:r?i.withTimeoutOption((async function(t,r,i={}){const{libp2p:n}=await e.use(i);return n.pubsub.subscribe(t,r,i)})):l,unsubscribe:r?i.withTimeoutOption((async function(t,r,i={}){const{libp2p:n}=await e.use(i);n.pubsub.unsubscribe(t,r,i)})):l,publish:r?i.withTimeoutOption((async function(t,r,i={}){const{libp2p:n}=await e.use(i);if(!r)throw c.default(new Error('argument "data" is required'),"ERR_ARG_REQUIRED");await n.pubsub.publish(t,r)})):l,ls:r?i.withTimeoutOption((async function(t={}){const{libp2p:r}=await e.use(t);return r.pubsub.getTopics()})):l,peers:r?i.withTimeoutOption((async function(t,r={}){const{libp2p:i}=await e.use(r);return i.pubsub.getSubscribers(t)})):l}}},{"ipfs-core-utils/with-timeout-option":"j29MK","err-code":"chZjB","../errors.js":"j69o8",dlv:"hp0pQ"}],juo1D:[function(e,t,r){var i,n;"undefined"!=typeof window&&(i=this,n=function(){return function(e){var t={};function r(i){if(t[i])return t[i].exports;var n=t[i]={i:i,l:!1,exports:{}};return e[i].call(n.exports,n,n.exports,r),n.l=!0,n.exports}return r.m=e,r.c=t,r.d=function(e,t,i){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:i})},r.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var i=Object.create(null);if(r.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)r.d(i,n,function(t){return e[t]}.bind(null,n));return i},r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,"a",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p="/dist/",r(r.s="./src/hls.ts")}({"./node_modules/eventemitter3/index.js":function(e,t,r){"use strict";var i=Object.prototype.hasOwnProperty,n="~";function s(){}function o(e,t,r){this.fn=e,this.context=t,this.once=r||!1}function a(e,t,r,i,s){if("function"!=typeof r)throw new TypeError("The listener must be a function");var a=new o(r,i||e,s),c=n?n+t:t;return e._events[c]?e._events[c].fn?e._events[c]=[e._events[c],a]:e._events[c].push(a):(e._events[c]=a,e._eventsCount++),e}function c(e,t){0==--e._eventsCount?e._events=new s:delete e._events[t]}function u(){this._events=new s,this._eventsCount=0}Object.create&&(s.prototype=Object.create(null),(new s).__proto__||(n=!1)),u.prototype.eventNames=function(){var e,t,r=[];if(0===this._eventsCount)return r;for(t in e=this._events)i.call(e,t)&&r.push(n?t.slice(1):t);return Object.getOwnPropertySymbols?r.concat(Object.getOwnPropertySymbols(e)):r},u.prototype.listeners=function(e){var t=n?n+e:e,r=this._events[t];if(!r)return[];if(r.fn)return[r.fn];for(var i=0,s=r.length,o=new Array(s);i0}),!1)}e.exports=function(e,t){t=t||{};var n={main:r.m},s=t.all?{main:Object.keys(n.main)}:function(e,t){for(var r={main:[t]},i={main:[]},n={main:{}};c(r);)for(var s=Object.keys(r),o=0;o>>8^255&y^99,e[h]=y,t[y]=h;var m=f[h],b=f[m],v=f[b],w=257*f[y]^16843008*y;i[h]=w<<24|w>>>8,n[h]=w<<16|w>>>16,s[h]=w<<8|w>>>24,o[h]=w,w=16843009*v^65537*b^257*m^16843008*h,c[y]=w<<24|w>>>8,u[y]=w<<16|w>>>16,l[y]=w<<8|w>>>24,d[y]=w,h?(h=m^f[f[f[v^m]]],p^=f[f[p]]):h=p=1}},t.expandKey=function(e){for(var t=this.uint8ArrayToUint32Array_(e),r=!0,i=0;i>>5}function f(e,t){return!!(t+1=e.length)return!1;var i=d(e,t);if(i<=r)return!1;var n=t+i;if(n===e.length||n+1>>6),!((c=(60&t[r+2])>>>2)>p.length-1))return l=(1&t[r+2])<<2,l|=(192&t[r+3])>>>6,a.logger.log("manifest codec:"+s+",ADTS data:type:"+o+",sampleingIndex:"+c+"["+p[c]+"Hz],channelConfig:"+l),/firefox/i.test(f)?c>=6?(o=5,d=new Array(4),u=c-3):(o=2,d=new Array(2),u=c):-1!==f.indexOf("android")?(o=2,d=new Array(2),u=c):(o=5,d=new Array(4),s&&(-1!==s.indexOf("mp4a.40.29")||-1!==s.indexOf("mp4a.40.5"))||!s&&c>=6?u=c-3:((s&&-1!==s.indexOf("mp4a.40.2")&&(c>=6&&1===l||/vivaldi/i.test(f))||!s&&1===l)&&(o=2,d=new Array(2)),u=c)),d[0]=o<<3,d[0]|=(14&c)>>1,d[1]|=(1&c)<<7,d[1]|=l<<3,5===o&&(d[1]|=(14&u)>>1,d[2]=(1&u)<<7,d[2]|=8,d[3]=0),{config:d,samplerate:p[c],channelCount:l,codec:"mp4a.40."+o,manifestCodec:h};e.trigger(i.default.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.FRAG_PARSING_ERROR,fatal:!0,reason:"invalid ADTS sampling index:"+c})}(t,r,s,o);e.config=c.config,e.samplerate=c.samplerate,e.channelCount=c.channelCount,e.codec=c.codec,e.manifestCodec=c.manifestCodec,a.logger.log("parsed codec:"+e.codec+",rate:"+c.samplerate+",nb channel:"+c.channelCount)}}function g(e){return 9216e4/e}function y(e,t,r,i,n){var s=function(e,t,r,i,n){var s,o,a=e.length;if(s=l(e,t),o=d(e,t),(o-=s)>0&&t+s+o<=a)return{headerLength:s,frameLength:o,stamp:r+i*n}}(t,r,i,n,g(e.samplerate));if(s){var o=s.stamp,a=s.headerLength,c=s.frameLength,u={unit:t.subarray(r+a,r+a+c),pts:o,dts:o};return e.samples.push(u),{sample:u,length:c+a}}}var m=r("./src/demux/id3.js"),b=function(){function e(e,t,r){this.observer=e,this.config=r,this.remuxer=t}var t=e.prototype;return t.resetInitSegment=function(e,t,r,i){this._audioTrack={container:"audio/adts",type:"audio",id:0,sequenceNumber:0,isAAC:!0,samples:[],len:0,manifestCodec:t,duration:i,inputTimeScale:9e4}},t.resetTimeStamp=function(){},e.probe=function(e){if(!e)return!1;for(var t=(m.default.getID3Data(e,0)||[]).length,r=e.length;tt.length)){var s=this.parseHeader(t,r);if(s&&r+s.frameLength<=t.length){var o=i+n*(9e4*s.samplesPerFrame/s.sampleRate),a={unit:t.subarray(r,r+s.frameLength),pts:o,dts:o};return e.config=[],e.channelCount=s.channelCount,e.samplerate=s.sampleRate,e.samples.push(a),{sample:a,length:s.frameLength}}}},parseHeader:function(e,t){var r=e[t+1]>>3&3,i=e[t+1]>>1&3,n=e[t+2]>>4&15,s=e[t+2]>>2&3,o=e[t+2]>>1&1;if(1!==r&&0!==n&&15!==n&&3!==s){var a=3===r?3-i:3===i?3:4,c=1e3*w.BitratesMap[14*a+n-1],u=3===r?0:2===r?1:2,l=w.SamplingRateMap[3*u+s],d=e[t+3]>>6==3?1:2,f=w.SamplesCoefficients[r][i],h=w.BytesInSlot[i],p=8*f*h;return{sampleRate:l,channelCount:d,frameLength:parseInt(f*c/l+o,10)*h,samplesPerFrame:p}}},isHeaderPattern:function(e,t){return 255===e[t]&&224==(224&e[t+1])&&0!=(6&e[t+1])},isHeader:function(e,t){return!!(t+1e?(this.word<<=e,this.bitsAvailable-=e):(e-=this.bitsAvailable,e-=(t=e>>3)>>3,this.bytesAvailable-=t,this.loadWord(),this.word<<=e,this.bitsAvailable-=e)},t.readBits=function(e){var t=Math.min(this.bitsAvailable,e),r=this.word>>>32-t;return e>32&&a.logger.error("Cannot read more than 32 bits at a time"),this.bitsAvailable-=t,this.bitsAvailable>0?this.word<<=t:this.bytesAvailable>0&&this.loadWord(),(t=e-t)>0&&this.bitsAvailable?r<>>e))return this.word<<=e,this.bitsAvailable-=e,e;return this.loadWord(),e+this.skipLZ()},t.skipUEG=function(){this.skipBits(1+this.skipLZ())},t.skipEG=function(){this.skipBits(1+this.skipLZ())},t.readUEG=function(){var e=this.skipLZ();return this.readBits(e+1)-1},t.readEG=function(){var e=this.readUEG();return 1&e?1+e>>>1:-1*(e>>>1)},t.readBoolean=function(){return 1===this.readBits(1)},t.readUByte=function(){return this.readBits(8)},t.readUShort=function(){return this.readBits(16)},t.readUInt=function(){return this.readBits(32)},t.skipScalingList=function(e){var t,r=8,i=8;for(t=0;t=e.length)return void r();if(!(e[t].unit.length<32)){var i=this.decrypter.isSync();if(this.decryptAacSample(e,t,r,i),!i)return}}},t.getAvcEncryptedData=function(e){for(var t=16*Math.floor((e.length-48)/160)+16,r=new Int8Array(t),i=0,n=32;n<=e.length-16;n+=160,i+=16)r.set(e.subarray(n,n+16),i);return r},t.getAvcDecryptedUnit=function(e,t){t=new Uint8Array(t);for(var r=0,i=32;i<=e.length-16;i+=160,r+=16)e.set(t.subarray(r,r+16),i);return e},t.decryptAvcSample=function(e,t,r,i,n,s){var o=this.discardEPB(n.data),a=this.getAvcEncryptedData(o),c=this;this.decryptBuffer(a.buffer,(function(a){n.data=c.getAvcDecryptedUnit(o,a),s||c.decryptAvcSamples(e,t,r+1,i)}))},t.decryptAvcSamples=function(e,t,r,i){for(;;t++,r=0){if(t>=e.length)return void i();for(var n=e[t].units;!(r>=n.length);r++){var s=n[r];if(!(s.data.length<=48||1!==s.type&&5!==s.type)){var o=this.decrypter.isSync();if(this.decryptAvcSample(e,t,r,i,s,o),!o)return}}}},e}(),T={video:1,audio:2,id3:3,text:4},A=function(){function e(e,t,r,i){this.observer=e,this.config=r,this.typeSupported=i,this.remuxer=t,this.sampleAes=null,this.pmtUnknownTypes={}}var t=e.prototype;return t.setDecryptData=function(e){null!=e&&null!=e.key&&"SAMPLE-AES"===e.method?this.sampleAes=new S(this.observer,this.config,e,this.discardEPB):this.sampleAes=null},e.probe=function(t){var r=e._syncOffset(t);return!(r<0||(r&&a.logger.warn("MPEG2-TS detected but first sync word found @ offset "+r+", junk ahead ?"),0))},e._syncOffset=function(e){for(var t=Math.min(1e3,e.length-564),r=0;r>4>1){if((d=c+5+t[c+4])===c+188)continue}else d=c+4;switch(l){case v:u&&(S&&(f=R(S))&&P(f,!1),S={data:[],size:0}),S&&(S.data.push(t.subarray(d,c+188)),S.size+=c+188-d);break;case w:u&&(T&&(f=R(T))&&(m.isAAC?O(f):C(f)),T={data:[],size:0}),T&&(T.data.push(t.subarray(d,c+188)),T.size+=c+188-d);break;case _:u&&(A&&(f=R(A))&&j(f),A={data:[],size:0}),A&&(A.data.push(t.subarray(d,c+188)),A.size+=c+188-d);break;case 0:u&&(d+=t[d]+1),E=this._pmtId=k(t,d);break;case E:u&&(d+=t[d]+1);var M=I(t,d,!0===this.typeSupported.mpeg||!0===this.typeSupported.mp3,null!=this.sampleAes);(v=M.avc)>0&&(y.pid=v),(w=M.audio)>0&&(m.pid=w,m.isAAC=M.isAAC),(_=M.id3)>0&&(b.pid=_),p&&!g&&(a.logger.log("reparse from beginning"),p=!1,c=D-188),g=this.pmtParsed=!0;break;case 17:case 8191:break;default:p=!0}}else this.observer.trigger(i.default.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.FRAG_PARSING_ERROR,fatal:!1,reason:"TS packet did not start with 0x47"});S&&(f=R(S))?(P(f,!0),y.pesData=null):y.pesData=S,T&&(f=R(T))?(m.isAAC?O(f):C(f),m.pesData=null):(T&&T.size&&a.logger.log("last AAC PES packet truncated,might overlap between fragments"),m.pesData=T),A&&(f=R(A))?(j(f),b.pesData=null):b.pesData=A,null==this.sampleAes?this.remuxer.remux(m,y,b,this._txtTrack,r,s,o):this.decryptAndRemux(m,y,b,this._txtTrack,r,s,o)},t.decryptAndRemux=function(e,t,r,i,n,s,o){if(e.samples&&e.isAAC){var a=this;this.sampleAes.decryptAacSamples(e.samples,0,(function(){a.decryptAndRemuxAvc(e,t,r,i,n,s,o)}))}else this.decryptAndRemuxAvc(e,t,r,i,n,s,o)},t.decryptAndRemuxAvc=function(e,t,r,i,n,s,o){if(t.samples){var a=this;this.sampleAes.decryptAvcSamples(t.samples,0,0,(function(){a.remuxer.remux(e,t,r,i,n,s,o)}))}else this.remuxer.remux(e,t,r,i,n,s,o)},t.destroy=function(){this._initPTS=this._initDTS=void 0,this._duration=0},t._parsePAT=function(e,t){return(31&e[t+10])<<8|e[t+11]},t._trackUnknownPmt=function(e,t,r){var i=this.pmtUnknownTypes[e]||0;return 0===i&&(this.pmtUnknownTypes[e]=0,t.call(a.logger,r)),this.pmtUnknownTypes[e]++,i},t._parsePMT=function(e,t,r,i){var n,s,o={audio:-1,avc:-1,id3:-1,isAAC:!0};for(n=t+3+((15&e[t+1])<<8|e[t+2])-4,t+=12+((15&e[t+10])<<8|e[t+11]);t1;){var f=new Uint8Array(d[0].length+d[1].length);f.set(d[0]),f.set(d[1],d[0].length),d[0]=f,d.splice(1,1)}if(1===((t=d[0])[0]<<16)+(t[1]<<8)+t[2]){if((i=(t[4]<<8)+t[5])&&i>e.size-6)return null;if(192&(r=t[7])&&(o=536870912*(14&t[9])+4194304*(255&t[10])+16384*(254&t[11])+128*(255&t[12])+(254&t[13])/2,64&r?o-(c=536870912*(14&t[14])+4194304*(255&t[15])+16384*(254&t[16])+128*(255&t[17])+(254&t[18])/2)>54e5&&(a.logger.warn(Math.round((o-c)/9e4)+"s delta between PTS and DTS, align them"),o=c):c=o),u=(n=t[8])+9,e.size<=u)return null;e.size-=u,s=new Uint8Array(e.size);for(var h=0,p=d.length;hg){u-=g;continue}t=t.subarray(u),g-=u,u=0}s.set(t,l),l+=g}return i&&(i-=n+3),{data:s,pts:o,dts:c,len:i}}return null},t.pushAccesUnit=function(e,t){if(e.units.length&&e.frame){var r=t.samples,i=r.length;if(isNaN(e.pts)){if(!i)return void t.dropped++;var n=r[i-1];e.pts=n.pts,e.dts=n.dts}!this.config.forceKeyFrameOnDiscontinuity||!0===e.key||t.sps&&(i||this.contiguous)?(e.id=i,r.push(e)):t.dropped++}e.debug.length&&a.logger.log(e.pts+"/"+e.dts+":"+e.debug)},t._parseAVCPES=function(e,t){var r,i,n,s=this,o=this._avcTrack,a=this._parseAVCNALu(e.data),c=this.avcSample,u=!1,l=this.pushAccesUnit.bind(this),d=function(e,t,r,i){return{key:e,pts:t,dts:r,units:[],debug:i}};e.data=null,c&&a.length&&!o.audFound&&(l(c,o),c=this.avcSample=d(!1,e.pts,e.dts,"")),a.forEach((function(t){switch(t.type){case 1:i=!0,c||(c=s.avcSample=d(!0,e.pts,e.dts,"")),c.frame=!0;var a=t.data;if(u&&a.length>4){var f=new E(a).readSliceType();2!==f&&4!==f&&7!==f&&9!==f||(c.key=!0)}break;case 5:i=!0,c||(c=s.avcSample=d(!0,e.pts,e.dts,"")),c.key=!0,c.frame=!0;break;case 6:i=!0,(r=new E(s.discardEPB(t.data))).readUByte();for(var h=0,p=0,g=!1,y=0;!g&&r.bytesAvailable>1;){h=0;do{h+=y=r.readUByte()}while(255===y);p=0;do{p+=y=r.readUByte()}while(255===y);if(4===h&&0!==r.bytesAvailable){if(g=!0,181===r.readUByte()&&49===r.readUShort()&&1195456820===r.readUInt()&&3===r.readUByte()){var b=r.readUByte(),v=31&b,w=[b,r.readUByte()];for(n=0;n16){var _=[];for(n=0;n<16;n++)_.push(r.readUByte().toString(16)),3!==n&&5!==n&&7!==n&&9!==n||_.push("-");var S=p-16,T=new Uint8Array(S);for(n=0;n0){if(t.pts>=e[r-1].pts)e.push(t);else for(var i=r-1;i>=0;i--)if(t.pts=0)i={data:e.subarray(d,s-c-1),type:n},l.push(i);else{var f=this._getLastNalUnit();if(f&&(u&&s<=4-u&&f.state&&(f.data=f.data.subarray(0,f.data.byteLength-u)),(r=s-c-1)>0)){var h=new Uint8Array(f.data.byteLength+r);h.set(f.data,0),h.set(e.subarray(0,r),f.data.byteLength),f.data=h}}s=0&&c>=0&&(i={data:e.subarray(d,o),type:n,state:c},l.push(i)),0===l.length){var p=this._getLastNalUnit();if(p){var g=new Uint8Array(p.data.byteLength+e.byteLength);g.set(p.data,0),g.set(e,p.data.byteLength),p.data=g}}return a.naluState=c,l},t.discardEPB=function(e){for(var t,r,i=e.byteLength,n=[],s=1;s1&&(a.logger.log("AAC: align PTS for overlapping frames by "+Math.round((_-m)/90)),m=_)}for(;s>24&255,t[1]=i>>16&255,t[2]=i>>8&255,t[3]=255&i,t.set(e,4),n=0,i=8;n>24&255,t>>16&255,t>>8&255,255&t,i>>24,i>>16&255,i>>8&255,255&i,n>>24,n>>16&255,n>>8&255,255&n,85,196,0,0]))},e.mdia=function(t){return e.box(e.types.mdia,e.mdhd(t.timescale,t.duration),e.hdlr(t.type),e.minf(t))},e.mfhd=function(t){return e.box(e.types.mfhd,new Uint8Array([0,0,0,0,t>>24,t>>16&255,t>>8&255,255&t]))},e.minf=function(t){return"audio"===t.type?e.box(e.types.minf,e.box(e.types.smhd,e.SMHD),e.DINF,e.stbl(t)):e.box(e.types.minf,e.box(e.types.vmhd,e.VMHD),e.DINF,e.stbl(t))},e.moof=function(t,r,i){return e.box(e.types.moof,e.mfhd(t),e.traf(i,r))},e.moov=function(t){for(var r=t.length,i=[];r--;)i[r]=e.trak(t[r]);return e.box.apply(null,[e.types.moov,e.mvhd(t[0].timescale,t[0].duration)].concat(i).concat(e.mvex(t)))},e.mvex=function(t){for(var r=t.length,i=[];r--;)i[r]=e.trex(t[r]);return e.box.apply(null,[e.types.mvex].concat(i))},e.mvhd=function(t,r){r*=t;var i=Math.floor(r/(R+1)),n=Math.floor(r%(R+1)),s=new Uint8Array([1,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,3,t>>24&255,t>>16&255,t>>8&255,255&t,i>>24,i>>16&255,i>>8&255,255&i,n>>24,n>>16&255,n>>8&255,255&n,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255]);return e.box(e.types.mvhd,s)},e.sdtp=function(t){var r,i,n=t.samples||[],s=new Uint8Array(4+n.length);for(i=0;i>>8&255),s.push(255&n),s=s.concat(Array.prototype.slice.call(i));for(r=0;r>>8&255),o.push(255&n),o=o.concat(Array.prototype.slice.call(i));var a=e.box(e.types.avcC,new Uint8Array([1,s[3],s[4],s[5],255,224|t.sps.length].concat(s).concat([t.pps.length]).concat(o))),c=t.width,u=t.height,l=t.pixelRatio[0],d=t.pixelRatio[1];return e.box(e.types.avc1,new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,c>>8&255,255&c,u>>8&255,255&u,0,72,0,0,0,72,0,0,0,0,0,0,0,1,18,100,97,105,108,121,109,111,116,105,111,110,47,104,108,115,46,106,115,0,0,0,0,0,0,0,0,0,0,0,0,0,0,24,17,17]),a,e.box(e.types.btrt,new Uint8Array([0,28,156,128,0,45,198,192,0,45,198,192])),e.box(e.types.pasp,new Uint8Array([l>>24,l>>16&255,l>>8&255,255&l,d>>24,d>>16&255,d>>8&255,255&d])))},e.esds=function(e){var t=e.config.length;return new Uint8Array([0,0,0,0,3,23+t,0,1,0,4,15+t,64,21,0,0,0,0,0,0,0,0,0,0,0,5].concat([t]).concat(e.config).concat([6,1,2]))},e.mp4a=function(t){var r=t.samplerate;return e.box(e.types.mp4a,new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,t.channelCount,0,16,0,0,0,0,r>>8&255,255&r,0,0]),e.box(e.types.esds,e.esds(t)))},e.mp3=function(t){var r=t.samplerate;return e.box(e.types[".mp3"],new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,t.channelCount,0,16,0,0,0,0,r>>8&255,255&r,0,0]))},e.stsd=function(t){return"audio"===t.type?t.isAAC||"mp3"!==t.codec?e.box(e.types.stsd,e.STSD,e.mp4a(t)):e.box(e.types.stsd,e.STSD,e.mp3(t)):e.box(e.types.stsd,e.STSD,e.avc1(t))},e.tkhd=function(t){var r=t.id,i=t.duration*t.timescale,n=t.width,s=t.height,o=Math.floor(i/(R+1)),a=Math.floor(i%(R+1));return e.box(e.types.tkhd,new Uint8Array([1,0,0,7,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,3,r>>24&255,r>>16&255,r>>8&255,255&r,0,0,0,0,o>>24,o>>16&255,o>>8&255,255&o,a>>24,a>>16&255,a>>8&255,255&a,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,0,0,0,n>>8&255,255&n,0,0,s>>8&255,255&s,0,0]))},e.traf=function(t,r){var i=e.sdtp(t),n=t.id,s=Math.floor(r/(R+1)),o=Math.floor(r%(R+1));return e.box(e.types.traf,e.box(e.types.tfhd,new Uint8Array([0,0,0,0,n>>24,n>>16&255,n>>8&255,255&n])),e.box(e.types.tfdt,new Uint8Array([1,0,0,0,s>>24,s>>16&255,s>>8&255,255&s,o>>24,o>>16&255,o>>8&255,255&o])),e.trun(t,i.length+16+20+8+16+8+8),i)},e.trak=function(t){return t.duration=t.duration||4294967295,e.box(e.types.trak,e.tkhd(t),e.mdia(t))},e.trex=function(t){var r=t.id;return e.box(e.types.trex,new Uint8Array([0,0,0,0,r>>24,r>>16&255,r>>8&255,255&r,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,1]))},e.trun=function(t,r){var i,n,s,o,a,c,u=t.samples||[],l=u.length,d=12+16*l,f=new Uint8Array(d);for(r+=8+d,f.set([0,0,15,1,l>>>24&255,l>>>16&255,l>>>8&255,255&l,r>>>24&255,r>>>16&255,r>>>8&255,255&r],0),i=0;i>>24&255,s>>>16&255,s>>>8&255,255&s,o>>>24&255,o>>>16&255,o>>>8&255,255&o,a.isLeading<<2|a.dependsOn,a.isDependedOn<<6|a.hasRedundancy<<4|a.paddingValue<<1|a.isNonSync,61440&a.degradPrio,15&a.degradPrio,c>>>24&255,c>>>16&255,c>>>8&255,255&c],12+16*i);return e.box(e.types.trun,f)},e.initSegment=function(t){e.types||e.init();var r,i=e.moov(t);return(r=new Uint8Array(e.FTYP.byteLength+i.byteLength)).set(e.FTYP),r.set(i,e.FTYP.byteLength),r},e}(),O=P;function C(e,t,r,i){void 0===r&&(r=1),void 0===i&&(i=!1);var n=e*t*r;return i?Math.round(n):n}function j(e,t){return void 0===t&&(t=!1),C(e,1e3,1/9e4,t)}function D(e,t){return void 0===t&&(t=1),C(e,9e4,1/t)}var M=D(10),x=D(.2),B=null;function L(e,t){var r;if(void 0===t)return e;for(r=t4294967296;)e+=r;return e}var N,U=function(){function e(e,t,r,i){if(this.observer=e,this.config=t,this.typeSupported=r,this.ISGenerated=!1,null===B){var n=navigator.userAgent.match(/Chrome\/(\d+)/i);B=n?parseInt(n[1]):0}}var t=e.prototype;return t.destroy=function(){},t.resetTimeStamp=function(e){this._initPTS=this._initDTS=e},t.resetInitSegment=function(){this.ISGenerated=!1},t.getVideoStartPts=function(e){var t=!1,r=e.reduce((function(e,r){var i=r.pts-e;return i<-4294967296?(t=!0,L(e,r.pts)):i>0?e:r.pts}),e[0].pts);return t&&a.logger.debug("PTS rollover detected"),r},t.remux=function(e,t,r,n,s,o,c){if(this.ISGenerated||this.generateIS(e,t,s),this.ISGenerated){var u=e.samples.length,l=t.samples.length,d=s,f=s;if(u&&l){var h=this.getVideoStartPts(t.samples),p=(L(e.samples[0].pts,h)-h)/t.inputTimeScale;d+=Math.max(0,p),f+=Math.max(0,-p)}if(u){e.timescale||(a.logger.warn("regenerate InitSegment as audio detected"),this.generateIS(e,t,s));var g,y=this.remuxAudio(e,d,o,c);l&&(y&&(g=y.endPTS-y.startPTS),t.timescale||(a.logger.warn("regenerate InitSegment as video detected"),this.generateIS(e,t,s)),this.remuxVideo(t,f,o,g))}else if(l){var m=this.remuxVideo(t,f,o,0,c);m&&e.codec&&this.remuxEmptyAudio(e,d,o,m)}}r.samples.length&&this.remuxID3(r,s),n.samples.length&&this.remuxText(n,s),this.observer.trigger(i.default.FRAG_PARSED)},t.generateIS=function(e,t,r){var s,o,c=this.observer,u=e.samples,l=t.samples,d=this.typeSupported,f="audio/mp4",h={},p={tracks:h},g=void 0===this._initPTS;if(g&&(s=o=1/0),e.config&&u.length&&(e.timescale=e.samplerate,a.logger.log("audio sampling rate : "+e.samplerate),e.isAAC||(d.mpeg?(f="audio/mpeg",e.codec=""):d.mp3&&(e.codec="mp3")),h.audio={container:f,codec:e.codec,initSegment:!e.isAAC&&d.mpeg?new Uint8Array:O.initSegment([e]),metadata:{channelCount:e.channelCount}},g&&(s=o=u[0].pts-Math.round(e.inputTimeScale*r))),t.sps&&t.pps&&l.length){var y=t.inputTimeScale;if(t.timescale=y,h.video={container:"video/mp4",codec:t.codec,initSegment:O.initSegment([t]),metadata:{width:t.width,height:t.height}},g){var m=this.getVideoStartPts(l),b=Math.round(y*r);o=Math.min(o,L(l[0].dts,m)-b),s=Math.min(s,m-b),this.observer.trigger(i.default.INIT_PTS_FOUND,{initPTS:s})}}else g&&h.audio&&this.observer.trigger(i.default.INIT_PTS_FOUND,{initPTS:s});Object.keys(h).length?(c.trigger(i.default.FRAG_PARSING_INIT_SEGMENT,p),this.ISGenerated=!0,g&&(this._initPTS=s,this._initDTS=o)):c.trigger(i.default.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.FRAG_PARSING_ERROR,fatal:!1,reason:"no audio/video samples found"})},t.remuxVideo=function(e,t,r,s){var o,c,u,l,d,f=e.timescale,h=e.samples,p=[],g=h.length,y=this._initPTS,m=8,b=Number.POSITIVE_INFINITY,v=Number.NEGATIVE_INFINITY,w=0,_=!1,E=this.nextAvcDts;if(0!==g){r||(E=t*f-(h[0].pts-L(h[0].dts,h[0].pts)));for(var S=0;ST.pts&&(w=Math.max(Math.min(w,T.pts-T.dts),-1*x)),T.dts0?S-1:S].dts&&(_=!0)}_&&h.sort((function(e,t){var r=e.dts-t.dts,i=e.pts-t.pts;return r||i||e.id-t.id})),l=h[0].dts,d=h[g-1].dts;var A=Math.round((d-l)/(g-1));if(w<0){if(w<-2*A){a.logger.warn("PTS < DTS detected in video samples, offsetting DTS from PTS by "+j(-A,!0)+" ms");for(var k=w,I=0;IA;if(C||P<-1){C?a.logger.warn("AVC: "+j(P,!0)+" ms ("+P+"dts) hole between fragments detected, filling it"):a.logger.warn("AVC: "+j(-P,!0)+" ms ("+P+"dts) overlapping between fragments detected"),l=E;var D=h[0].pts-P;h[0].dts=l,h[0].pts=D,a.logger.log("Video: First PTS/DTS adjusted: "+j(D,!0)+"/"+j(l,!0)+", delta: "+j(P,!0)+" ms")}}B&&B<75&&(l=Math.max(0,l));for(var M=0,N=0,U=0;U0?$-1:$].dts;if(ie.stretchShortVideoTrack){var se=ie.maxBufferHole,oe=Math.floor(se*f),ae=(s?b+s*f:this.nextAudioPts)-Y.pts;ae>oe?((o=ae-ne)<0&&(o=ne),a.logger.log("It is approximately "+j(ae,!1)+" ms to the next segment; using duration "+j(o,!1)+" ms for the last video frame.")):o=ne}else o=ne}W=Math.round(Y.pts-Y.dts),p.push({size:Z,duration:o,cts:W,flags:{isLeading:0,isDependedOn:0,hasRedundancy:0,degradPrio:0,dependsOn:Y.key?2:1,isNonSync:Y.key?0:1}})}this.nextAvcDts=d+o;var ce=e.dropped;if(e.nbNalu=0,e.dropped=0,p.length&&navigator.userAgent.toLowerCase().indexOf("chrome")>-1){var ue=p[0].flags;ue.dependsOn=2,ue.isNonSync=0}e.samples=p,u=O.moof(e.sequenceNumber++,l,e),e.samples=[];var le={data1:u,data2:c,startPTS:b/f,endPTS:(v+o)/f,startDTS:l/f,endDTS:this.nextAvcDts/f,type:"video",hasAudio:!1,hasVideo:!0,nb:p.length,dropped:ce};return this.observer.trigger(i.default.FRAG_PARSING_DATA,le),le}},t.remuxAudio=function(e,t,r,s){var o,c,u,l,d,f,h=e.inputTimeScale,p=e.timescale,g=h/p,y=(e.isAAC?1024:1152)*g,m=this._initPTS,b=!e.isAAC&&this.typeSupported.mpeg,v=b?0:8,w=e.samples,_=[],E=this.nextAudioPts;if(r|=w.length&&E&&(s&&Math.abs(t-E/h)<.1||Math.abs(w[0].pts-E-m)<20*y),w.forEach((function(e){e.pts=e.dts=L(e.pts-m,t*h)})),0!==(w=w.filter((function(e){return e.pts>=0}))).length){if(r||(E=s?Math.max(0,t*h):w[0].pts),e.isAAC)for(var S=this.config.maxAudioFramesDrift,T=0,A=E;T0?(a.logger.warn("Dropping 1 audio frame @ "+j(A,!0)/1e3+"s due to "+j(P,!0)+" ms overlap."),w.splice(T,1)):(a.logger.warn("Audio frame @ "+j(R,!0)/1e3+"s overlaps nextAudioPts by "+j(P,!0)+" ms."),A=R+y,T++);else if(P>=S*y&&P0&&q0&&((c=I.getSilentFrame(e.manifestCodec||e.codec,e.channelCount))||(c=z.subarray()),N+=G*c.length);else if(q<-12){a.logger.log("drop overlapping AAC sample, expected/parsed/delta: "+j(E,!0)+" ms / "+j(V,!0)+" ms / "+j(-q,!0)+" ms"),N-=z.byteLength;continue}V=E}if(d=V,!(N>0))return;N+=v;try{u=new Uint8Array(N)}catch(e){return void this.observer.trigger(i.default.ERROR,{type:n.ErrorTypes.MUX_ERROR,details:n.ErrorDetails.REMUX_ALLOC_ERROR,fatal:!1,bytes:N,reason:"fail allocating audio mdat "+N})}b||(new DataView(u.buffer).setUint32(0,N),u.set(O.types.mdat,4));for(var H=0;H=2&&(W=_[B-2].duration,o.duration=W),B){this.nextAudioPts=E=f+g*W,e.samples=_,l=b?new Uint8Array:O.moof(e.sequenceNumber++,d/g,e),e.samples=[];var Y=d/h,X=E/h,Z={data1:l,data2:u,startPTS:Y,endPTS:X,startDTS:Y,endDTS:X,type:"audio",hasAudio:!0,hasVideo:!1,nb:B};return this.observer.trigger(i.default.FRAG_PARSING_DATA,Z),Z}return null}},t.remuxEmptyAudio=function(e,t,r,i){var n=e.inputTimeScale,s=n/(e.samplerate?e.samplerate:n),o=this.nextAudioPts,c=(void 0!==o?o:i.startDTS*n)+this._initDTS,u=i.endDTS*n+this._initDTS,l=1024*s,d=Math.ceil((u-c)/l),f=I.getSilentFrame(e.manifestCodec||e.codec,e.channelCount);if(a.logger.warn("remux empty Audio"),f){for(var h=[],p=0;p0&&null!=t&&null!=t.key&&"AES-128"===t.method){var g=this.decrypter;null==g&&(g=this.decrypter=new s.default(this.observer,this.config));var y=N();g.decrypt(e,t.key.buffer,t.iv.buffer,(function(e){var s=N();p.observer.trigger(i.default.FRAG_DECRYPTED,{stats:{tstart:y,tdecrypt:s}}),p.pushDecrypted(new Uint8Array(e),t,new Uint8Array(r),n,o,a,c,u,l,d,f,h)}))}else this.pushDecrypted(new Uint8Array(e),t,new Uint8Array(r),n,o,a,c,u,l,d,f,h)},t.pushDecrypted=function(e,t,r,s,o,a,c,u,l,d,f,h){var p=this.demuxer,g=this.remuxer;if(!p||c||u){for(var y,m=this.observer,w=this.typeSupported,_=this.config,E=[{demux:A,remux:U},{demux:v.default,remux:F},{demux:b,remux:U},{demux:k,remux:U}],S=0,T=E.length;S1?r-1:0),n=1;n1?r-1:0),n=1;n0)return t.subarray(i,i+n)},e._readSize=function(e,t){var r=0;return r=(127&e[t])<<21,r|=(127&e[t+1])<<14,r|=(127&e[t+2])<<7,r|=127&e[t+3]},e.getTimeStamp=function(t){for(var r=e.getID3Frames(t),i=0;i>4){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:d+=String.fromCharCode(a);break;case 12:case 13:c=e[f++],d+=String.fromCharCode((31&a)<<6|63&c);break;case 14:c=e[f++],u=e[f++],d+=String.fromCharCode((15&a)<<12|(63&c)<<6|(63&u)<<0)}}return d},e}(),o=s._utf8ArrayToStr;t.default=s},"./src/demux/mp4demuxer.js":function(e,t,r){"use strict";r.r(t);var i=r(/*! ../utils/logger */"./src/utils/logger.js"),n=r(/*! ../events */"./src/events.js"),s=Math.pow(2,32)-1,o=function(){function e(e,t){this.observer=e,this.remuxer=t}var t=e.prototype;return t.resetTimeStamp=function(e){this.initPTS=e},t.resetInitSegment=function(t,r,i,s){if(t&&t.byteLength){var o=this.initData=e.parseInitSegment(t);null==r&&(r="mp4a.40.5"),null==i&&(i="avc1.42e01e");var a={};o.audio&&o.video?a.audiovideo={container:"video/mp4",codec:r+","+i,initSegment:s?t:null}:(o.audio&&(a.audio={container:"audio/mp4",codec:r,initSegment:s?t:null}),o.video&&(a.video={container:"video/mp4",codec:i,initSegment:s?t:null})),this.observer.trigger(n.default.FRAG_PARSING_INIT_SEGMENT,{tracks:a})}else r&&(this.audioCodec=r),i&&(this.videoCodec=i)},e.probe=function(t){return e.findBox({data:t,start:0,end:Math.min(t.length,16384)},["moof"]).length>0},e.bin2str=function(e){return String.fromCharCode.apply(null,e)},e.readUint16=function(e,t){e.data&&(t+=e.start,e=e.data);var r=e[t]<<8|e[t+1];return r<0?65536+r:r},e.readUint32=function(e,t){e.data&&(t+=e.start,e=e.data);var r=e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3];return r<0?4294967296+r:r},e.writeUint32=function(e,t,r){e.data&&(t+=e.start,e=e.data),e[t]=r>>24,e[t+1]=r>>16&255,e[t+2]=r>>8&255,e[t+3]=255&r},e.findBox=function(t,r){var i,n,s,o,a,c,u=[];if(t.data?(a=t.start,s=t.end,t=t.data):(a=0,s=t.byteLength),!r.length)return null;for(i=a;i1?i+n:s,e.bin2str(t.subarray(i+4,i+8))===r[0]&&(1===r.length?u.push({data:t,start:i+8,end:c}):(o=e.findBox({data:t,start:i+8,end:c},r.slice(1))).length&&(u=u.concat(o))),i=c;return u},e.parseSegmentIndex=function(t){var r,i=e.findBox(t,["moov"])[0],n=i?i.end:null,s=0,o=e.findBox(t,["sidx"]);if(!o||!o[0])return null;r=[];var a=(o=o[0]).data[0];s=0===a?8:16;var c=e.readUint32(o,s);s+=4,s+=0===a?8:16,s+=2;var u=o.end+0,l=e.readUint16(o,s);s+=2;for(var d=0;d>>31)return void console.warn("SIDX has hierarchical references (not supported)");var g=e.readUint32(o,f);f+=4,r.push({referenceSize:p,subsegmentDuration:g,info:{duration:g/c,start:u,end:u+p-1}}),u+=p,s=f+=4}return{earliestPresentationTime:0,timescale:c,version:a,referencesCount:l,references:r,moovEndOffset:n}},e.parseInitSegment=function(t){var r=[];return e.findBox(t,["moov","trak"]).forEach((function(t){var n=e.findBox(t,["tkhd"])[0];if(n){var s=n.data[n.start],o=0===s?12:20,a=e.readUint32(n,o),c=e.findBox(t,["mdia","mdhd"])[0];if(c){o=0===(s=c.data[c.start])?12:20;var u=e.readUint32(c,o),l=e.findBox(t,["mdia","hdlr"])[0];if(l){var d={soun:"audio",vide:"video"}[e.bin2str(l.data.subarray(l.start+8,l.start+12))];if(d){var f=e.findBox(t,["mdia","minf","stbl","stsd"]);if(f.length){f=f[0];var h=e.bin2str(f.data.subarray(f.start+12,f.start+16));i.logger.log("MP4Demuxer:"+d+":"+h+" found")}r[a]={timescale:u,type:d},r[d]={timescale:u,id:a}}}}}})),r},e.getStartDTS=function(t,r){var i,n,s;return i=e.findBox(r,["moof","traf"]),n=[].concat.apply([],i.map((function(r){return e.findBox(r,["tfhd"]).map((function(i){var n,s;return n=e.readUint32(i,4),s=t[n].timescale||9e4,e.findBox(r,["tfdt"]).map((function(t){var r,i;return r=t.data[t.start],i=e.readUint32(t,4),1===r&&(i*=Math.pow(2,32),i+=e.readUint32(t,8)),i}))[0]/s}))}))),s=Math.min.apply(null,n),isFinite(s)?s:0},e.offsetStartDTS=function(t,r,i){e.findBox(r,["moof","traf"]).map((function(r){return e.findBox(r,["tfhd"]).map((function(n){var o=e.readUint32(n,4),a=t[o].timescale||9e4;e.findBox(r,["tfdt"]).map((function(t){var r=t.data[t.start],n=e.readUint32(t,4);if(0===r)e.writeUint32(t,4,n-i*a);else{n*=Math.pow(2,32),n+=e.readUint32(t,8),n-=i*a,n=Math.max(n,0);var o=Math.floor(n/(s+1)),c=Math.floor(n%(s+1));e.writeUint32(t,4,o),e.writeUint32(t,8,c)}}))}))}))},t.append=function(t,r,i,s){var o=this.initData;o||(this.resetInitSegment(t,this.audioCodec,this.videoCodec,!1),o=this.initData);var a,c=this.initPTS;if(void 0===c){var u=e.getStartDTS(o,t);this.initPTS=c=u-r,this.observer.trigger(n.default.INIT_PTS_FOUND,{initPTS:c})}e.offsetStartDTS(o,t,c),a=e.getStartDTS(o,t),this.remuxer.remux(o.audio,o.video,null,null,a,i,s,t)},t.destroy=function(){},e}();t.default=o},"./src/errors.ts":function(e,t,r){"use strict";var i,n,s,o;r.r(t),r.d(t,"ErrorTypes",(function(){return i})),r.d(t,"ErrorDetails",(function(){return s})),(n=i||(i={})).NETWORK_ERROR="networkError",n.MEDIA_ERROR="mediaError",n.KEY_SYSTEM_ERROR="keySystemError",n.MUX_ERROR="muxError",n.OTHER_ERROR="otherError",(o=s||(s={})).KEY_SYSTEM_NO_KEYS="keySystemNoKeys",o.KEY_SYSTEM_NO_ACCESS="keySystemNoAccess",o.KEY_SYSTEM_NO_SESSION="keySystemNoSession",o.KEY_SYSTEM_LICENSE_REQUEST_FAILED="keySystemLicenseRequestFailed",o.KEY_SYSTEM_NO_INIT_DATA="keySystemNoInitData",o.MANIFEST_LOAD_ERROR="manifestLoadError",o.MANIFEST_LOAD_TIMEOUT="manifestLoadTimeOut",o.MANIFEST_PARSING_ERROR="manifestParsingError",o.MANIFEST_INCOMPATIBLE_CODECS_ERROR="manifestIncompatibleCodecsError",o.LEVEL_EMPTY_ERROR="levelEmptyError",o.LEVEL_LOAD_ERROR="levelLoadError",o.LEVEL_LOAD_TIMEOUT="levelLoadTimeOut",o.LEVEL_SWITCH_ERROR="levelSwitchError",o.AUDIO_TRACK_LOAD_ERROR="audioTrackLoadError",o.AUDIO_TRACK_LOAD_TIMEOUT="audioTrackLoadTimeOut",o.FRAG_LOAD_ERROR="fragLoadError",o.FRAG_LOAD_TIMEOUT="fragLoadTimeOut",o.FRAG_DECRYPT_ERROR="fragDecryptError",o.FRAG_PARSING_ERROR="fragParsingError",o.REMUX_ALLOC_ERROR="remuxAllocError",o.KEY_LOAD_ERROR="keyLoadError",o.KEY_LOAD_TIMEOUT="keyLoadTimeOut",o.BUFFER_ADD_CODEC_ERROR="bufferAddCodecError",o.BUFFER_APPEND_ERROR="bufferAppendError",o.BUFFER_APPENDING_ERROR="bufferAppendingError",o.BUFFER_STALLED_ERROR="bufferStalledError",o.BUFFER_FULL_ERROR="bufferFullError",o.BUFFER_SEEK_OVER_HOLE="bufferSeekOverHole",o.BUFFER_NUDGE_ON_STALL="bufferNudgeOnStall",o.INTERNAL_EXCEPTION="internalException"},"./src/events.js":function(e,t,r){"use strict";r.r(t),t.default={MEDIA_ATTACHING:"hlsMediaAttaching",MEDIA_ATTACHED:"hlsMediaAttached",MEDIA_DETACHING:"hlsMediaDetaching",MEDIA_DETACHED:"hlsMediaDetached",BUFFER_RESET:"hlsBufferReset",BUFFER_CODECS:"hlsBufferCodecs",BUFFER_CREATED:"hlsBufferCreated",BUFFER_APPENDING:"hlsBufferAppending",BUFFER_APPENDED:"hlsBufferAppended",BUFFER_EOS:"hlsBufferEos",BUFFER_FLUSHING:"hlsBufferFlushing",BUFFER_FLUSHED:"hlsBufferFlushed",MANIFEST_LOADING:"hlsManifestLoading",MANIFEST_LOADED:"hlsManifestLoaded",MANIFEST_PARSED:"hlsManifestParsed",LEVEL_SWITCHING:"hlsLevelSwitching",LEVEL_SWITCHED:"hlsLevelSwitched",LEVEL_LOADING:"hlsLevelLoading",LEVEL_LOADED:"hlsLevelLoaded",LEVEL_UPDATED:"hlsLevelUpdated",LEVEL_PTS_UPDATED:"hlsLevelPtsUpdated",LEVELS_UPDATED:"hlsLevelsUpdated",AUDIO_TRACKS_UPDATED:"hlsAudioTracksUpdated",AUDIO_TRACK_SWITCHING:"hlsAudioTrackSwitching",AUDIO_TRACK_SWITCHED:"hlsAudioTrackSwitched",AUDIO_TRACK_LOADING:"hlsAudioTrackLoading",AUDIO_TRACK_LOADED:"hlsAudioTrackLoaded",SUBTITLE_TRACKS_UPDATED:"hlsSubtitleTracksUpdated",SUBTITLE_TRACK_SWITCH:"hlsSubtitleTrackSwitch",SUBTITLE_TRACK_LOADING:"hlsSubtitleTrackLoading",SUBTITLE_TRACK_LOADED:"hlsSubtitleTrackLoaded",SUBTITLE_FRAG_PROCESSED:"hlsSubtitleFragProcessed",CUES_PARSED:"hlsCuesParsed",NON_NATIVE_TEXT_TRACKS_FOUND:"hlsNonNativeTextTracksFound",INIT_PTS_FOUND:"hlsInitPtsFound",FRAG_LOADING:"hlsFragLoading",FRAG_LOAD_PROGRESS:"hlsFragLoadProgress",FRAG_LOAD_EMERGENCY_ABORTED:"hlsFragLoadEmergencyAborted",FRAG_LOADED:"hlsFragLoaded",FRAG_DECRYPTED:"hlsFragDecrypted",FRAG_PARSING_INIT_SEGMENT:"hlsFragParsingInitSegment",FRAG_PARSING_USERDATA:"hlsFragParsingUserdata",FRAG_PARSING_METADATA:"hlsFragParsingMetadata",FRAG_PARSING_DATA:"hlsFragParsingData",FRAG_PARSED:"hlsFragParsed",FRAG_BUFFERED:"hlsFragBuffered",FRAG_CHANGED:"hlsFragChanged",FPS_DROP:"hlsFpsDrop",FPS_DROP_LEVEL_CAPPING:"hlsFpsDropLevelCapping",ERROR:"hlsError",DESTROYING:"hlsDestroying",KEY_LOADING:"hlsKeyLoading",KEY_LOADED:"hlsKeyLoaded",STREAM_STATE_TRANSITION:"hlsStreamStateTransition",LIVE_BACK_BUFFER_REACHED:"hlsLiveBackBufferReached"}},"./src/hls.ts":function(e,t,r){"use strict";r.r(t),r.d(t,"default",(function(){return hr}));var i={};r.r(i),r.d(i,"newCue",(function(){return mt}));var n,s,o,a,c=r("./node_modules/url-toolkit/src/url-toolkit.js"),u=r("./src/errors.ts"),l=r("./src/polyfills/number.js"),d=r("./src/events.js"),f=r("./src/utils/logger.js"),h={hlsEventGeneric:!0,hlsHandlerDestroying:!0,hlsHandlerDestroyed:!0},p=function(){function e(e){this.hls=void 0,this.handledEvents=void 0,this.useGenericHandler=void 0,this.hls=e,this.onEvent=this.onEvent.bind(this);for(var t=arguments.length,r=new Array(t>1?t-1:0),i=1;i>8*(15-r)&255;return t},n.setDecryptDataFromLevelKey=function(e,t){var r=e;return(null==e?void 0:e.method)&&e.uri&&!e.iv&&((r=new w(e.baseuri,e.reluri)).method=e.method,r.iv=this.createInitializationVector(t)),r},t=e,(r=[{key:"url",get:function(){return!this._url&&this.relurl&&(this._url=Object(c.buildAbsoluteURL)(this.baseurl,this.relurl,{alwaysNormalize:!0})),this._url},set:function(e){this._url=e}},{key:"byteRange",get:function(){return this._byteRange?this._byteRange:[]}},{key:"byteRangeStartOffset",get:function(){return this.byteRange[0]}},{key:"byteRangeEndOffset",get:function(){return this.byteRange[1]}},{key:"decryptdata",get:function(){if(!this.levelkey&&!this._decryptdata)return null;if(!this._decryptdata&&this.levelkey){var e=this.sn;"number"!=typeof e&&(this.levelkey&&"AES-128"===this.levelkey.method&&!this.levelkey.iv&&f.logger.warn('missing IV for initialization segment with method="'+this.levelkey.method+'" - compliance issue'),e=0),this._decryptdata=this.setDecryptDataFromLevelKey(this.levelkey,e)}return this._decryptdata}},{key:"endProgramDateTime",get:function(){if(null===this.programDateTime)return null;if(!Object(l.isFiniteNumber)(this.programDateTime))return null;var e=Object(l.isFiniteNumber)(this.duration)?this.duration:0;return this.programDateTime+1e3*e}},{key:"encrypted",get:function(){return!(!this.decryptdata||null===this.decryptdata.uri||null!==this.decryptdata.key)}}])&&_(t.prototype,r),i&&_(t,i),e}();function S(e,t){for(var r=0;rNumber.MAX_SAFE_INTEGER?1/0:t},t.hexadecimalInteger=function(e){if(this[e]){var t=(this[e]||"0x").slice(2);t=(1&t.length?"0":"")+t;for(var r=new Uint8Array(t.length/2),i=0;iNumber.MAX_SAFE_INTEGER?1/0:t},t.decimalFloatingPoint=function(e){return parseFloat(this[e])},t.enumeratedString=function(e){return this[e]},t.decimalResolution=function(e){var t=A.exec(this[e]);if(null!==t)return{width:parseInt(t[1],10),height:parseInt(t[2],10)}},e.parseAttrList=function(e){var t,r={};for(k.lastIndex=0;null!==(t=k.exec(e));){var i=t[2];0===i.indexOf('"')&&i.lastIndexOf('"')===i.length-1&&(i=i.slice(1,-1)),r[t[1]]=i}return r},e}(),R={audio:{a3ds:!0,"ac-3":!0,"ac-4":!0,alac:!0,alaw:!0,dra1:!0,"dts+":!0,"dts-":!0,dtsc:!0,dtse:!0,dtsh:!0,"ec-3":!0,enca:!0,g719:!0,g726:!0,m4ae:!0,mha1:!0,mha2:!0,mhm1:!0,mhm2:!0,mlpa:!0,mp4a:!0,"raw ":!0,Opus:!0,samr:!0,sawb:!0,sawp:!0,sevc:!0,sqcp:!0,ssmv:!0,twos:!0,ulaw:!0},video:{avc1:!0,avc2:!0,avc3:!0,avc4:!0,avcp:!0,drac:!0,dvav:!0,dvhe:!0,encv:!0,hev1:!0,hvc1:!0,mjp2:!0,mp4v:!0,mvc1:!0,mvc2:!0,mvc3:!0,mvc4:!0,resv:!0,rv60:!0,s263:!0,svc1:!0,svc2:!0,"vc-1":!0,vp08:!0,vp09:!0}};function P(e,t){return MediaSource.isTypeSupported((t||"video")+'/mp4;codecs="'+e+'"')}var O=/(?:#EXT-X-STREAM-INF:([^\n\r]*)[\r\n]+([^\r\n]+)|#EXT-X-SESSION-DATA:([^\n\r]*)[\r\n]+)/g,C=/#EXT-X-MEDIA:(.*)/g,j=new RegExp([/#EXTINF:\s*(\d*(?:\.\d+)?)(?:,(.*)\s+)?/.source,/|(?!#)([\S+ ?]+)/.source,/|#EXT-X-BYTERANGE:*(.+)/.source,/|#EXT-X-PROGRAM-DATE-TIME:(.+)/.source,/|#.*/.source].join(""),"g"),D=/(?:(?:#(EXTM3U))|(?:#EXT-X-(PLAYLIST-TYPE):(.+))|(?:#EXT-X-(MEDIA-SEQUENCE): *(\d+))|(?:#EXT-X-(TARGETDURATION): *(\d+))|(?:#EXT-X-(KEY):(.+))|(?:#EXT-X-(START):(.+))|(?:#EXT-X-(ENDLIST))|(?:#EXT-X-(DISCONTINUITY-SEQ)UENCE:(\d+))|(?:#EXT-X-(DIS)CONTINUITY))|(?:#EXT-X-(VERSION):(\d+))|(?:#EXT-X-(MAP):(.+))|(?:(#)([^:]*):(.*))|(?:(#)(.*))(?:.*)\r?\n?/,M=/\.(mp4|m4s|m4v|m4a)$/i,x=function(){function e(){}return e.findGroup=function(e,t){for(var r=0;r2?(t=r.shift()+".",t+=parseInt(r.shift()).toString(16),t+=("000"+parseInt(r.shift()).toString(16)).substr(-4)):t=e,t},e.resolve=function(e,t){return c.buildAbsoluteURL(t,e,{alwaysNormalize:!0})},e.parseMasterPlaylist=function(t,r){var i,n=[],s={},o=!1;function a(e,t){["video","audio"].forEach((function(r){var i=e.filter((function(e){return function(e,t){var r=R[t];return!!r&&!0===r[e.slice(0,4)]}(e,r)}));if(i.length){var n=i.filter((function(e){return 0===e.lastIndexOf("avc1",0)||0===e.lastIndexOf("mp4a",0)}));t[r+"Codec"]=n.length>0?n[0]:i[0],e=e.filter((function(e){return-1===i.indexOf(e)}))}})),t.unknownCodecs=e}for(O.lastIndex=0;null!=(i=O.exec(t));)if(i[1]){var c={},u=c.attrs=new I(i[1]);c.url=e.resolve(i[2],r);var l=u.decimalResolution("RESOLUTION");l&&(c.width=l.width,c.height=l.height),c.bitrate=u.decimalInteger("AVERAGE-BANDWIDTH")||u.decimalInteger("BANDWIDTH"),c.name=u.NAME,a([].concat((u.CODECS||"").split(/[ ,]+/)),c),c.videoCodec&&-1!==c.videoCodec.indexOf("avc1")&&(c.videoCodec=e.convertAVC1ToAVCOTI(c.videoCodec)),n.push(c)}else if(i[3]){var d=new I(i[3]);d["DATA-ID"]&&(o=!0,s[d["DATA-ID"]]=d)}return{levels:n,sessionData:o?s:null}},e.parseMasterPlaylistMedia=function(t,r,i,n){var s;void 0===n&&(n=[]);var o=[],a=0;for(C.lastIndex=0;null!==(s=C.exec(t));){var c=new I(s[1]);if(c.TYPE===i){var u={attrs:c,id:a++,groupId:c["GROUP-ID"],instreamId:c["INSTREAM-ID"],name:c.NAME||c.LANGUAGE,type:i,default:"YES"===c.DEFAULT,autoselect:"YES"===c.AUTOSELECT,forced:"YES"===c.FORCED,lang:c.LANGUAGE};if(c.URI&&(u.url=e.resolve(c.URI,r)),n.length){var l=e.findGroup(n,u.groupId);u.audioCodec=l?l.codec:n[0].codec}o.push(u)}}return o},e.parseLevelPlaylist=function(e,t,r,i,n){var s,o,a,c=0,u=0,d=new T(t),h=0,p=null,g=new E,y=null;for(j.lastIndex=0;null!==(s=j.exec(e));){var m=s[1];if(m){g.duration=parseFloat(m);var b=(" "+s[2]).slice(1);g.title=b||null,g.tagList.push(b?["INF",m,b]:["INF",m])}else if(s[3]){if(Object(l.isFiniteNumber)(g.duration)){var v=c++;g.type=i,g.start=u,a&&(g.levelkey=a),g.sn=v,g.level=r,g.cc=h,g.urlId=n,g.baseurl=t,g.relurl=(" "+s[3]).slice(1),B(g,p),d.fragments.push(g),p=g,u+=g.duration,g=new E}}else if(s[4]){var _=(" "+s[4]).slice(1);p?g.setByteRange(_,p):g.setByteRange(_)}else if(s[5])g.rawProgramDateTime=(" "+s[5]).slice(1),g.tagList.push(["PROGRAM-DATE-TIME",g.rawProgramDateTime]),null===y&&(y=d.fragments.length);else{if(!(s=s[0].match(D))){f.logger.warn("No matches on slow regex match for level playlist!");continue}for(o=1;o=0&&(a.method=R,a.key=null,a.iv=O));break;case"START":var C=new I(S).decimalFloatingPoint("TIME-OFFSET");Object(l.isFiniteNumber)(C)&&(d.startTimeOffset=C);break;case"MAP":var x=new I(S);g.relurl=x.URI,x.BYTERANGE&&g.setByteRange(x.BYTERANGE),g.baseurl=t,g.level=r,g.type=i,g.sn="initSegment",d.initSegment=g,(g=new E).rawProgramDateTime=d.initSegment.rawProgramDateTime;break;default:f.logger.warn("line parsed but not handled: "+s)}}}return(g=p)&&!g.relurl&&(d.fragments.pop(),u-=g.duration),d.totalduration=u,d.averagetargetduration=u/d.fragments.length,d.endSN=c-1,d.startCC=d.fragments[0]?d.fragments[0].cc:0,d.endCC=h,!d.initSegment&&d.fragments.length&&d.fragments.every((function(e){return M.test(e.relurl)}))&&(f.logger.warn("MP4 fragments found but no init segment (probably no MAP, incomplete M3U8), trying to fetch SIDX"),(g=new E).relurl=d.fragments[0].relurl,g.baseurl=t,g.level=r,g.type=i,g.sn="initSegment",d.initSegment=g,d.needSidxRanges=!0),y&&function(e,t){for(var r=e[t],i=t-1;i>=0;i--){var n=e[i];n.programDateTime=r.programDateTime-1e3*n.duration,r=n}}(d.fragments,y),d},e}();function B(e,t){e.rawProgramDateTime?e.programDateTime=Date.parse(e.rawProgramDateTime):(null==t?void 0:t.programDateTime)&&(e.programDateTime=t.endProgramDateTime),Object(l.isFiniteNumber)(e.programDateTime)||(e.programDateTime=null,e.rawProgramDateTime=null)}var L=window.performance,N=function(e){var t,r;function i(t){var r;return(r=e.call(this,t,d.default.MANIFEST_LOADING,d.default.LEVEL_LOADING,d.default.AUDIO_TRACK_LOADING,d.default.SUBTITLE_TRACK_LOADING)||this).loaders={},r}r=e,(t=i).prototype=Object.create(r.prototype),t.prototype.constructor=t,t.__proto__=r,i.canHaveQualityLevels=function(e){return e!==n.AUDIO_TRACK&&e!==n.SUBTITLE_TRACK},i.mapContextToLevelType=function(e){switch(e.type){case n.AUDIO_TRACK:return o.AUDIO;case n.SUBTITLE_TRACK:return o.SUBTITLE;default:return o.MAIN}},i.getResponseUrl=function(e,t){var r=e.url;return void 0!==r&&0!==r.indexOf("data:")||(r=t.url),r};var s=i.prototype;return s.createInternalLoader=function(e){var t=this.hls.config,r=t.pLoader,i=t.loader,n=new(r||i)(t);return e.loader=n,this.loaders[e.type]=n,n},s.getInternalLoader=function(e){return this.loaders[e.type]},s.resetInternalLoader=function(e){this.loaders[e]&&delete this.loaders[e]},s.destroyInternalLoaders=function(){for(var e in this.loaders){var t=this.loaders[e];t&&t.destroy(),this.resetInternalLoader(e)}},s.destroy=function(){this.destroyInternalLoaders(),e.prototype.destroy.call(this)},s.onManifestLoading=function(e){this.load({url:e.url,type:n.MANIFEST,level:0,id:null,responseType:"text"})},s.onLevelLoading=function(e){this.load({url:e.url,type:n.LEVEL,level:e.level,id:e.id,responseType:"text"})},s.onAudioTrackLoading=function(e){this.load({url:e.url,type:n.AUDIO_TRACK,level:null,id:e.id,responseType:"text"})},s.onSubtitleTrackLoading=function(e){this.load({url:e.url,type:n.SUBTITLE_TRACK,level:null,id:e.id,responseType:"text"})},s.load=function(e){var t=this.hls.config;f.logger.debug("Loading playlist of type "+e.type+", level: "+e.level+", id: "+e.id);var r,i,s,o,a=this.getInternalLoader(e);if(a){var c=a.context;if(c&&c.url===e.url)return f.logger.trace("playlist request ongoing"),!1;f.logger.warn("aborting previous loader for type: "+e.type),a.abort()}switch(e.type){case n.MANIFEST:r=t.manifestLoadingMaxRetry,i=t.manifestLoadingTimeOut,s=t.manifestLoadingRetryDelay,o=t.manifestLoadingMaxRetryTimeout;break;case n.LEVEL:r=0,o=0,s=0,i=t.levelLoadingTimeOut;break;default:r=t.levelLoadingMaxRetry,i=t.levelLoadingTimeOut,s=t.levelLoadingRetryDelay,o=t.levelLoadingMaxRetryTimeout}a=this.createInternalLoader(e);var u={timeout:i,maxRetry:r,retryDelay:s,maxRetryDelay:o},l={onSuccess:this.loadsuccess.bind(this),onError:this.loaderror.bind(this),onTimeout:this.loadtimeout.bind(this)};return f.logger.debug("Calling internal loader delegate for URL: "+e.url),a.load(e,u,l),!0},s.loadsuccess=function(e,t,r,i){if(void 0===i&&(i=null),r.isSidxRequest)return this._handleSidxRequest(e,r),void this._handlePlaylistLoaded(e,t,r,i);if(this.resetInternalLoader(r.type),"string"!=typeof e.data)throw new Error('expected responseType of "text" for PlaylistLoader');var n=e.data;t.tload=L.now(),0===n.indexOf("#EXTM3U")?n.indexOf("#EXTINF:")>0||n.indexOf("#EXT-X-TARGETDURATION:")>0?this._handleTrackOrLevelPlaylist(e,t,r,i):this._handleMasterPlaylist(e,t,r,i):this._handleManifestParsingError(e,r,"no EXTM3U delimiter",i)},s.loaderror=function(e,t,r){void 0===r&&(r=null),this._handleNetworkError(t,r,!1,e)},s.loadtimeout=function(e,t,r){void 0===r&&(r=null),this._handleNetworkError(t,r,!0)},s._handleMasterPlaylist=function(e,t,r,n){var s=this.hls,o=e.data,a=i.getResponseUrl(e,r),c=x.parseMasterPlaylist(o,a),u=c.levels,l=c.sessionData;if(u.length){var h=u.map((function(e){return{id:e.attrs.AUDIO,codec:e.audioCodec}})),p=x.parseMasterPlaylistMedia(o,a,"AUDIO",h),g=x.parseMasterPlaylistMedia(o,a,"SUBTITLES"),y=x.parseMasterPlaylistMedia(o,a,"CLOSED-CAPTIONS");if(p.length){var m=!1;p.forEach((function(e){e.url||(m=!0)})),!1===m&&u[0].audioCodec&&!u[0].attrs.AUDIO&&(f.logger.log("audio codec signaled in quality level, but no embedded audio track signaled, create one"),p.unshift({type:"main",name:"main",default:!1,autoselect:!1,forced:!1,id:-1,attrs:{},url:""}))}s.trigger(d.default.MANIFEST_LOADED,{levels:u,audioTracks:p,subtitles:g,captions:y,url:a,stats:t,networkDetails:n,sessionData:l})}else this._handleManifestParsingError(e,r,"no level found in manifest",n)},s._handleTrackOrLevelPlaylist=function(e,t,r,s){var o=this.hls,a=r.id,c=r.level,f=r.type,h=i.getResponseUrl(e,r),p=Object(l.isFiniteNumber)(a)?a:0,g=Object(l.isFiniteNumber)(c)?c:p,y=i.mapContextToLevelType(r),m=x.parseLevelPlaylist(e.data,h,g,y,p);if(m.tload=t.tload,m.fragments.length){if(f===n.MANIFEST){var b={url:h,details:m};o.trigger(d.default.MANIFEST_LOADED,{levels:[b],audioTracks:[],url:h,stats:t,networkDetails:s,sessionData:null})}if(t.tparsed=L.now(),m.needSidxRanges){var v=m.initSegment.url;this.load({url:v,isSidxRequest:!0,type:f,level:c,levelDetails:m,id:a,rangeStart:0,rangeEnd:2048,responseType:"arraybuffer"})}else r.levelDetails=m,this._handlePlaylistLoaded(e,t,r,s)}else o.trigger(d.default.ERROR,{type:u.ErrorTypes.NETWORK_ERROR,details:u.ErrorDetails.LEVEL_EMPTY_ERROR,fatal:!1,url:h,reason:"no fragments found in level",level:"number"==typeof r.level?r.level:void 0})},s._handleSidxRequest=function(e,t){if("string"==typeof e.data)throw new Error("sidx request must be made with responseType of array buffer");var r=y.default.parseSegmentIndex(new Uint8Array(e.data));if(r){var i=r.references,n=t.levelDetails;i.forEach((function(e,t){var r=e.info;if(n){var i=n.fragments[t];0===i.byteRange.length&&i.setByteRange(String(1+r.end-r.start)+"@"+String(r.start))}})),n&&n.initSegment.setByteRange(String(r.moovEndOffset)+"@0")}},s._handleManifestParsingError=function(e,t,r,i){this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.NETWORK_ERROR,details:u.ErrorDetails.MANIFEST_PARSING_ERROR,fatal:!0,url:e.url,reason:r,networkDetails:i})},s._handleNetworkError=function(e,t,r,i){var s,o;void 0===r&&(r=!1),void 0===i&&(i=null),f.logger.info("A network error occured while loading a "+e.type+"-type playlist");var a=this.getInternalLoader(e);switch(e.type){case n.MANIFEST:s=r?u.ErrorDetails.MANIFEST_LOAD_TIMEOUT:u.ErrorDetails.MANIFEST_LOAD_ERROR,o=!0;break;case n.LEVEL:s=r?u.ErrorDetails.LEVEL_LOAD_TIMEOUT:u.ErrorDetails.LEVEL_LOAD_ERROR,o=!1;break;case n.AUDIO_TRACK:s=r?u.ErrorDetails.AUDIO_TRACK_LOAD_TIMEOUT:u.ErrorDetails.AUDIO_TRACK_LOAD_ERROR,o=!1;break;default:o=!1}a&&(a.abort(),this.resetInternalLoader(e.type));var c={type:u.ErrorTypes.NETWORK_ERROR,details:s,fatal:o,url:e.url,loader:a,context:e,networkDetails:t};i&&(c.response=i),this.hls.trigger(d.default.ERROR,c)},s._handlePlaylistLoaded=function(e,t,r,s){var o=r.type,a=r.level,c=r.id,u=r.levelDetails;if(u&&u.targetduration)if(i.canHaveQualityLevels(r.type))this.hls.trigger(d.default.LEVEL_LOADED,{details:u,level:a||0,id:c||0,stats:t,networkDetails:s});else switch(o){case n.AUDIO_TRACK:this.hls.trigger(d.default.AUDIO_TRACK_LOADED,{details:u,id:c,stats:t,networkDetails:s});break;case n.SUBTITLE_TRACK:this.hls.trigger(d.default.SUBTITLE_TRACK_LOADED,{details:u,id:c,stats:t,networkDetails:s})}else this._handleManifestParsingError(e,r,"invalid target duration",s)},i}(g),U=function(e){var t,r;function i(t){var r;return(r=e.call(this,t,d.default.FRAG_LOADING)||this).loaders={},r}r=e,(t=i).prototype=Object.create(r.prototype),t.prototype.constructor=t,t.__proto__=r;var n=i.prototype;return n.destroy=function(){var t=this.loaders;for(var r in t){var i=t[r];i&&i.destroy()}this.loaders={},e.prototype.destroy.call(this)},n.onFragLoading=function(e){var t=e.frag,r=t.type,i=this.loaders,n=this.hls.config,s=n.fLoader,o=n.loader;t.loaded=0;var a,c,u,d=i[r];d&&(f.logger.warn("abort previous fragment loader for type: "+r),d.abort()),d=i[r]=t.loader=n.fLoader?new s(n):new o(n),a={url:t.url,frag:t,responseType:"arraybuffer",progressData:!1};var h=t.byteRangeStartOffset,p=t.byteRangeEndOffset;Object(l.isFiniteNumber)(h)&&Object(l.isFiniteNumber)(p)&&(a.rangeStart=h,a.rangeEnd=p),c={timeout:n.fragLoadingTimeOut,maxRetry:0,retryDelay:0,maxRetryDelay:n.fragLoadingMaxRetryTimeout},u={onSuccess:this.loadsuccess.bind(this),onError:this.loaderror.bind(this),onTimeout:this.loadtimeout.bind(this),onProgress:this.loadprogress.bind(this)},d.load(a,c,u)},n.loadsuccess=function(e,t,r,i){void 0===i&&(i=null);var n=e.data,s=r.frag;s.loader=void 0,this.loaders[s.type]=void 0,this.hls.trigger(d.default.FRAG_LOADED,{payload:n,frag:s,stats:t,networkDetails:i})},n.loaderror=function(e,t,r){void 0===r&&(r=null);var i=t.frag,n=i.loader;n&&n.abort(),this.loaders[i.type]=void 0,this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.NETWORK_ERROR,details:u.ErrorDetails.FRAG_LOAD_ERROR,fatal:!1,frag:t.frag,response:e,networkDetails:r})},n.loadtimeout=function(e,t,r){void 0===r&&(r=null);var i=t.frag,n=i.loader;n&&n.abort(),this.loaders[i.type]=void 0,this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.NETWORK_ERROR,details:u.ErrorDetails.FRAG_LOAD_TIMEOUT,fatal:!1,frag:t.frag,networkDetails:r})},n.loadprogress=function(e,t,r,i){void 0===i&&(i=null);var n=t.frag;n.loaded=e.loaded,this.hls.trigger(d.default.FRAG_LOAD_PROGRESS,{frag:n,stats:e,networkDetails:i})},i}(g),F=function(e){var t,r;function i(t){var r;return(r=e.call(this,t,d.default.KEY_LOADING)||this).loaders={},r.decryptkey=null,r.decrypturl=null,r}r=e,(t=i).prototype=Object.create(r.prototype),t.prototype.constructor=t,t.__proto__=r;var n=i.prototype;return n.destroy=function(){for(var t in this.loaders){var r=this.loaders[t];r&&r.destroy()}this.loaders={},e.prototype.destroy.call(this)},n.onKeyLoading=function(e){var t=e.frag,r=t.type,i=this.loaders[r];if(t.decryptdata){var n=t.decryptdata.uri;if(n!==this.decrypturl||null===this.decryptkey){var s=this.hls.config;if(i&&(f.logger.warn("abort previous key loader for type:"+r),i.abort()),!n)return void f.logger.warn("key uri is falsy");t.loader=this.loaders[r]=new s.loader(s),this.decrypturl=n,this.decryptkey=null;var o={url:n,frag:t,responseType:"arraybuffer"},a={timeout:s.fragLoadingTimeOut,maxRetry:0,retryDelay:s.fragLoadingRetryDelay,maxRetryDelay:s.fragLoadingMaxRetryTimeout},c={onSuccess:this.loadsuccess.bind(this),onError:this.loaderror.bind(this),onTimeout:this.loadtimeout.bind(this)};t.loader.load(o,a,c)}else this.decryptkey&&(t.decryptdata.key=this.decryptkey,this.hls.trigger(d.default.KEY_LOADED,{frag:t}))}else f.logger.warn("Missing decryption data on fragment in onKeyLoading")},n.loadsuccess=function(e,t,r){var i=r.frag;i.decryptdata?(this.decryptkey=i.decryptdata.key=new Uint8Array(e.data),i.loader=void 0,delete this.loaders[i.type],this.hls.trigger(d.default.KEY_LOADED,{frag:i})):f.logger.error("after key load, decryptdata unset")},n.loaderror=function(e,t){var r=t.frag,i=r.loader;i&&i.abort(),delete this.loaders[r.type],this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.NETWORK_ERROR,details:u.ErrorDetails.KEY_LOAD_ERROR,fatal:!1,frag:r,response:e})},n.loadtimeout=function(e,t){var r=t.frag,i=r.loader;i&&i.abort(),delete this.loaders[r.type],this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.NETWORK_ERROR,details:u.ErrorDetails.KEY_LOAD_TIMEOUT,fatal:!1,frag:r})},i}(g),K="NOT_LOADED",z="APPENDING",V="PARTIAL",q="OK",G=function(e){var t,r;function i(t){var r;return(r=e.call(this,t,d.default.BUFFER_APPENDED,d.default.FRAG_BUFFERED,d.default.FRAG_LOADED)||this).bufferPadding=.2,r.fragments=Object.create(null),r.timeRanges=Object.create(null),r.config=t.config,r}r=e,(t=i).prototype=Object.create(r.prototype),t.prototype.constructor=t,t.__proto__=r;var n=i.prototype;return n.destroy=function(){this.fragments=Object.create(null),this.timeRanges=Object.create(null),this.config=null,g.prototype.destroy.call(this),e.prototype.destroy.call(this)},n.getBufferedFrag=function(e,t){var r=this.fragments,i=Object.keys(r).filter((function(i){var n=r[i];if(n.body.type!==t)return!1;if(!n.buffered)return!1;var s=n.body;return s.startPTS<=e&&e<=s.endPTS}));if(0===i.length)return null;var n=i.pop();return r[n].body},n.detectEvictedFragments=function(e,t){var r=this;Object.keys(this.fragments).forEach((function(i){var n=r.fragments[i];if(n&&n.buffered){var s=n.range[e];if(s)for(var o=s.time,a=0;a=i&&t<=n){s.push({startPTS:Math.max(e,r.start(a)),endPTS:Math.min(t,r.end(a))});break}if(ei)s.push({startPTS:Math.max(e,r.start(a)),endPTS:Math.min(t,r.end(a))}),o=!0;else if(t<=i)break}return{time:s,partial:o}},n.getFragmentKey=function(e){return e.type+"_"+e.level+"_"+e.urlId+"_"+e.sn},n.getPartialFragment=function(e){var t,r,i,n=this,s=null,o=0;return Object.keys(this.fragments).forEach((function(a){var c=n.fragments[a];n.isPartial(c)&&(r=c.body.startPTS-n.bufferPadding,i=c.body.endPTS+n.bufferPadding,e>=r&&e<=i&&(t=Math.min(e-r,i-e),o<=t&&(s=c.body,o=t)))})),s},n.getState=function(e){var t=this.getFragmentKey(e),r=this.fragments[t],i=K;return void 0!==r&&(i=r.buffered?!0===this.isPartial(r)?V:q:z),i},n.isPartial=function(e){return!0===e.buffered&&(void 0!==e.range.video&&!0===e.range.video.partial||void 0!==e.range.audio&&!0===e.range.audio.partial)},n.isTimeBuffered=function(e,t,r){for(var i,n,s=0;s=i&&t<=n)return!0;if(t<=i)return!1}return!1},n.onFragLoaded=function(e){var t=e.frag;Object(l.isFiniteNumber)(t.sn)&&!t.bitrateTest&&(this.fragments[this.getFragmentKey(t)]={body:t,range:Object.create(null),buffered:!1})},n.onBufferAppended=function(e){var t=this;this.timeRanges=e.timeRanges,Object.keys(this.timeRanges).forEach((function(e){var r=t.timeRanges[e];t.detectEvictedFragments(e,r)}))},n.onFragBuffered=function(e){this.detectPartialFragments(e.frag)},n.hasFragment=function(e){var t=this.getFragmentKey(e);return void 0!==this.fragments[t]},n.removeFragment=function(e){var t=this.getFragmentKey(e);delete this.fragments[t]},n.removeAllFragments=function(){this.fragments=Object.create(null)},i}(g),H={search:function(e,t){for(var r=0,i=e.length-1,n=null,s=null;r<=i;){var o=t(s=e[n=(r+i)/2|0]);if(o>0)r=n+1;else{if(!(o<0))return s;i=n-1}}return null}},$=function(){function e(){}return e.isBuffered=function(e,t){try{if(e)for(var r=e.buffered,i=0;i=r.start(i)&&t<=r.end(i))return!0}catch(e){}return!1},e.bufferInfo=function(e,t,r){try{if(e){var i,n=e.buffered,s=[];for(i=0;io&&(i[s-1].end=e[n].end):i.push(e[n])}else i.push(e[n])}else i=e;for(var a,c=0,u=t,l=t,d=0;d=f&&t1?t-1:0),i=1;it?(i.duration=s-i.start,i.duration<0&&f.logger.warn("negative duration computed for frag "+i.sn+",level "+i.level+", there should be some duration drift between playlist and fragment!")):(n.duration=i.start-s,n.duration<0&&f.logger.warn("negative duration computed for frag "+n.sn+",level "+n.level+", there should be some duration drift between playlist and fragment!"));else if(r>t){var o=i.cc===n.cc;n.start=i.start+(o&&i.minEndPTS?i.minEndPTS-i.start:i.duration)}else n.start=Math.max(i.start-n.duration,0)}function se(e,t,r,i,n,s){var o=r,a=i;if(Object(l.isFiniteNumber)(t.startPTS)){var c=Math.abs(t.startPTS-r);Object(l.isFiniteNumber)(t.deltaPTS)?t.deltaPTS=Math.max(c,t.deltaPTS):t.deltaPTS=c,o=Math.max(r,t.startPTS),r=Math.min(r,t.startPTS),a=Math.min(i,t.endPTS),i=Math.max(i,t.endPTS),n=Math.min(n,t.startDTS),s=Math.max(s,t.endDTS)}var u=r-t.start;t.start=t.startPTS=r,t.maxStartPTS=o,t.endPTS=i,t.minEndPTS=a,t.startDTS=n,t.endDTS=s,t.duration=i-r;var d,f,h,p=t.sn;if(!e||pe.endSN)return 0;for(d=p-e.startSN,(f=e.fragments)[d]=t,h=d;h>0;h--)ne(f,h,h-1);for(h=d;hi.length))for(var s=0;sr.startCC||e&&e.cc=(e[e.length-1].endProgramDateTime||0))return null;r=r||0;for(var i=0;ie&&r.start?-1:0}function ge(e,t,r){var i=1e3*Math.min(t,r.duration+(r.deltaPTS?r.deltaPTS:0));return(r.endProgramDateTime||0)-i>e}var ye=function(){function e(e,t,r,i){this.config=e,this.media=t,this.fragmentTracker=r,this.hls=i,this.nudgeRetry=0,this.stallReported=!1,this.stalled=null,this.moved=!1,this.seeking=!1}var t=e.prototype;return t.poll=function(e){var t=this.config,r=this.media,i=this.stalled,n=r.currentTime,s=r.seeking,o=this.seeking&&!s,a=!this.seeking&&s;if(this.seeking=s,n===e){if((a||o)&&(this.stalled=null),!r.paused&&!r.ended&&0!==r.playbackRate&&r.buffered.length){var c=$.bufferInfo(r,n,0),u=c.len>0,l=c.nextStart||0;if(u||l){if(s){var d=c.len>2,h=!l||l-n>2&&!this.fragmentTracker.getPartialFragment(n);if(d||h)return;this.moved=!1}if(!this.moved&&this.stalled){var p=Math.max(l,c.start||0)-n;if(p>0&&p<=2)return void this._trySkipBufferHole(null)}var g=self.performance.now();if(null!==i){var y=g-i;!s&&y>=250&&this._reportStall(c.len);var m=$.bufferInfo(r,n,t.maxBufferHole);this._tryFixBufferStall(m,y)}else this.stalled=g}}}else if(this.moved=!0,null!==i){if(this.stallReported){var b=self.performance.now()-i;f.logger.warn("playback not stuck anymore @"+n+", after "+Math.round(b)+"ms"),this.stallReported=!1}this.stalled=null,this.nudgeRetry=0}},t._tryFixBufferStall=function(e,t){var r=this.config,i=this.fragmentTracker,n=this.media.currentTime,s=i.getPartialFragment(n);s&&this._trySkipBufferHole(s)||e.len>r.maxBufferHole&&t>1e3*r.highBufferWatchdogPeriod&&(f.logger.warn("Trying to nudge playhead over buffer-hole"),this.stalled=null,this._tryNudgeBuffer())},t._reportStall=function(e){var t=this.hls,r=this.media;this.stallReported||(this.stallReported=!0,f.logger.warn("Playback stalling at @"+r.currentTime+" due to low buffer (buffer="+e+")"),t.trigger(d.default.ERROR,{type:u.ErrorTypes.MEDIA_ERROR,details:u.ErrorDetails.BUFFER_STALLED_ERROR,fatal:!1,buffer:e}))},t._trySkipBufferHole=function(e){for(var t=this.config,r=this.hls,i=this.media,n=i.currentTime,s=0,o=0;o=s&&n1?i-1:0),s=1;s1&&(this.clearNextTick(),this._tickTimer=self.setTimeout(this._boundTick,0)),this._tickCallCount=0)},n.doTick=function(){},i}(g),ve="STOPPED",we="STARTING",_e="IDLE",Ee="PAUSED",Se="KEY_LOADING",Te="FRAG_LOADING",Ae="FRAG_LOADING_WAITING_RETRY",ke="WAITING_TRACK",Ie="PARSING",Re="PARSED",Pe="BUFFER_FLUSHING",Oe="ENDED",Ce="ERROR",je="WAITING_INIT_PTS",De="WAITING_LEVEL",Me=function(e){var t,r;function i(){return e.apply(this,arguments)||this}r=e,(t=i).prototype=Object.create(r.prototype),t.prototype.constructor=t,t.__proto__=r;var n=i.prototype;return n.doTick=function(){},n.startLoad=function(){},n.stopLoad=function(){var e=this.fragCurrent;e&&(e.loader&&e.loader.abort(),this.fragmentTracker.removeFragment(e)),this.demuxer&&(this.demuxer.destroy(),this.demuxer=null),this.fragCurrent=null,this.fragPrevious=null,this.clearInterval(),this.clearNextTick(),this.state=ve},n._streamEnded=function(e,t){var r=this.fragCurrent,i=this.fragmentTracker;if(!t.live&&r&&!r.backtracked&&r.sn===t.endSN&&!e.nextStart){var n=i.getState(r);return n===V||n===q}return!1},n.onMediaSeeking=function(){var e=this.config,t=this.media,r=this.mediaBuffer,i=this.state,n=t?t.currentTime:null,s=$.bufferInfo(r||t,n,this.config.maxBufferHole);if(f.logger.log("media seeking to "+(Object(l.isFiniteNumber)(n)?n.toFixed(3):n)),i===Te){var o=this.fragCurrent;if(0===s.len&&o){var a=e.maxFragLookUpTolerance,c=o.start-a,u=o.start+o.duration+a;nu?(o.loader&&(f.logger.log("seeking outside of buffer while fragment load in progress, cancel fragment load"),o.loader.abort()),this.fragCurrent=null,this.fragPrevious=null,this.state=_e):f.logger.log("seeking outside of buffer but within currently loaded fragment range")}}else i===Oe&&(0===s.len&&(this.fragPrevious=null,this.fragCurrent=null),this.state=_e);t&&(this.lastCurrentTime=n),this.loadedmetadata||(this.nextLoadPosition=this.startPosition=n),this.tick()},n.onMediaEnded=function(){this.startPosition=this.lastCurrentTime=0},n.onHandlerDestroying=function(){this.stopLoad(),e.prototype.onHandlerDestroying.call(this)},n.onHandlerDestroyed=function(){this.state=ve,this.fragmentTracker=null},n.computeLivePosition=function(e,t){var r=void 0!==this.config.liveSyncDuration?this.config.liveSyncDuration:this.config.liveSyncDurationCount*t.targetduration;return e+Math.max(0,t.totalduration-r)},i}(be);function xe(e,t){for(var r=0;r0&&-1===e&&(f.logger.log("override startPosition with lastCurrentTime @"+t.toFixed(3)),e=t),this.state=_e,this.nextLoadPosition=this.startPosition=this.lastCurrentTime=e,this.tick()}else this.forceStartLoad=!0,this.state=ve},c.stopLoad=function(){this.forceStartLoad=!1,e.prototype.stopLoad.call(this)},c.doTick=function(){switch(this.state){case Pe:this.fragLoadError=0;break;case _e:this._doTickIdle();break;case De:var e=this.levels[this.level];e&&e.details&&(this.state=_e);break;case Ae:var t=window.performance.now(),r=this.retryDate;(!r||t>=r||this.media&&this.media.seeking)&&(f.logger.log("mediaController: retryDate reached, switch back to IDLE state"),this.state=_e)}this._checkBuffer(),this._checkFragmentChanged()},c._doTickIdle=function(){var e=this.hls,t=e.config,r=this.media;if(void 0!==this.levelLastLoaded&&(r||!this.startFragRequested&&t.startFragPrefetch))if(this.altAudio&&this.audioOnly)this.demuxer.frag=null;else{var i;i=this.loadedmetadata?r.currentTime:this.nextLoadPosition;var n=e.nextLoadLevel,s=this.levels[n];if(s){var o,a=s.bitrate;o=a?Math.max(8*t.maxBufferSize/a,t.maxBufferLength):t.maxBufferLength,o=Math.min(o,t.maxMaxBufferLength);var c=i=o)){f.logger.trace("buffer length of "+l.toFixed(3)+" is below max of "+o.toFixed(3)+". checking for more payload ..."),this.level=e.nextLoadLevel=n;var h=s.details;if(!h||h.live&&this.levelLastLoaded!==n)this.state=De;else{if(this._streamEnded(u,h)){var p={};return this.altAudio&&(p.type="video"),this.hls.trigger(d.default.BUFFER_EOS,p),void(this.state=Oe)}this._fetchPayloadOrEos(i,u,h)}}}}},c._fetchPayloadOrEos=function(e,t,r){var i=this.fragPrevious,n=(this.level,r.fragments),s=n.length;if(0!==s){var o,a=n[0].start,c=n[s-1].start+n[s-1].duration,u=t.end;if(r.initSegment&&!r.initSegment.data)o=r.initSegment;else if(r.live){var l=this.config.initialLiveManifestSize;if(sd&&d>c.currentTime&&(f.logger.log("buffer end: "+t.toFixed(3)+" is located too far from the end of live sliding playlist, reset currentTime to : "+d.toFixed(3)),c.currentTime=d),this.nextLoadPosition=d}if(e.PTSKnown&&t>i&&c&&c.readyState)return null;if(this.startFragRequested&&!e.PTSKnown&&n)if(e.hasProgramDateTime)f.logger.log("live playlist, switching playlist, load frag with same PDT: "+n.programDateTime),o=fe(s,n.endProgramDateTime,a.maxFragLookUpTolerance);else{var h=n.sn+1;if(h>=e.startSN&&h<=e.endSN){var p=s[h-e.startSN];n.cc===p.cc&&(o=p,f.logger.log("live playlist, switching playlist, load frag with next SN: "+o.sn))}o||(o=H.search(s,(function(e){return n.cc-e.cc})))&&f.logger.log("live playlist, switching playlist, load frag with same CC: "+o.sn)}return o},c._findFragment=function(e,t,r,i,n,s,o){var a,c=this.hls.config;if(a=ns-c.maxFragLookUpTolerance?0:c.maxFragLookUpTolerance):i[r-1]){var u=a.sn-o.startSN,l=t&&a.level===t.level,d=i[u-1],h=i[u+1];if(t&&a.sn===t.sn)if(l&&!a.backtracked)if(a.snc.maxBufferHole&&t.dropped&&u?(a=d,f.logger.warn("Previous fragment was dropped with large PTS gap between audio and video. Maybe fragment is not starting with a keyframe? Loading previous one to try to overcome this")):(a=h,this.fragmentTracker.getState(a)!==q&&f.logger.log("Re-loading fragment with SN: "+a.sn))}else a=null;else a.backtracked&&(h&&h.backtracked?(f.logger.warn("Already backtracked from fragment "+h.sn+", will not backtrack to fragment "+a.sn+". Loading fragment "+h.sn),a=h):(f.logger.warn("Loaded fragment with dropped frames, backtracking 1 segment to find a keyframe"),a.dropped=0,d?(a=d).backtracked=!0:u&&(a=null)))}return a},c._loadKey=function(e,t){f.logger.log("Loading key for "+e.sn+" of ["+t.startSN+"-"+t.endSN+"], level "+this.level),this.state=Se,this.hls.trigger(d.default.KEY_LOADING,{frag:e})},c._loadFragment=function(e,t,r,i){var n=this.fragmentTracker.getState(e);this.fragCurrent=e,"initSegment"!==e.sn&&(this.startFragRequested=!0),Object(l.isFiniteNumber)(e.sn)&&!e.bitrateTest&&(this.nextLoadPosition=e.start+e.duration),e.backtracked||n===K||n===V?(e.autoLevel=this.hls.autoLevelEnabled,e.bitrateTest=this.bitrateTest,f.logger.log("Loading "+e.sn+" of ["+t.startSN+"-"+t.endSN+"], level "+this.level+", "+(this.loadedmetadata?"currentTime":"nextLoadPosition")+": "+parseFloat(r.toFixed(3))+", bufferEnd: "+parseFloat(i.toFixed(3))),this.hls.trigger(d.default.FRAG_LOADING,{frag:e}),this.demuxer||(this.demuxer=new re(this.hls,"main")),this.state=Te):n===z&&this._reduceMaxBufferLength(e.duration)&&this.fragmentTracker.removeFragment(e)},c.getBufferedFrag=function(e){return this.fragmentTracker.getBufferedFrag(e,o.MAIN)},c.followingBufferedFrag=function(e){return e?this.getBufferedFrag(e.endPTS+.5):null},c._checkFragmentChanged=function(){var e,t,r=this.media;if(r&&r.readyState&&!1===r.seeking&&((t=r.currentTime)>this.lastCurrentTime&&(this.lastCurrentTime=t),$.isBuffered(r,t)?e=this.getBufferedFrag(t):$.isBuffered(r,t+.1)&&(e=this.getBufferedFrag(t+.1)),e)){var i=e;if(i!==this.fragPlaying){this.hls.trigger(d.default.FRAG_CHANGED,{frag:i});var n=i.level;this.fragPlaying&&this.fragPlaying.level===n||this.hls.trigger(d.default.LEVEL_SWITCHED,{level:n}),this.fragPlaying=i}}},c.immediateLevelSwitch=function(){if(f.logger.log("immediateLevelSwitch"),!this.immediateSwitch){this.immediateSwitch=!0;var e,t=this.media;t?(e=t.paused)||t.pause():e=!0,this.previouslyPaused=e}var r=this.fragCurrent;r&&r.loader&&r.loader.abort(),this.fragCurrent=null,this.flushMainBuffer(0,Number.POSITIVE_INFINITY)},c.immediateLevelSwitchEnd=function(){var e=this.media;e&&e.buffered.length&&(this.immediateSwitch=!1,e.currentTime>0&&$.isBuffered(e,e.currentTime)&&(e.currentTime-=1e-4),this.previouslyPaused||e.play())},c.nextLevelSwitch=function(){var e=this.media;if(e&&e.readyState){var t,r=this.getBufferedFrag(e.currentTime);if(r&&r.startPTS>1&&this.flushMainBuffer(0,r.startPTS-1),e.paused)t=0;else{var i=this.hls.nextLoadLevel,n=this.levels[i],s=this.fragLastKbps;t=s&&this.fragCurrent?this.fragCurrent.duration*n.bitrate/(1e3*s)+1:0}var o=this.getBufferedFrag(e.currentTime+t);if(o){var a=this.followingBufferedFrag(o);if(a){var c=this.fragCurrent;c&&c.loader&&c.loader.abort(),this.fragCurrent=null;var u=Math.max(o.endPTS,a.maxStartPTS+Math.min(this.config.maxFragLookUpTolerance,a.duration));this.flushMainBuffer(u,Number.POSITIVE_INFINITY)}}}},c.flushMainBuffer=function(e,t){this.state=Pe;var r={startOffset:e,endOffset:t};this.altAudio&&(r.type="video"),this.hls.trigger(d.default.BUFFER_FLUSHING,r)},c.onMediaAttached=function(e){var t=this.media=this.mediaBuffer=e.media;this.onvseeking=this.onMediaSeeking.bind(this),this.onvseeked=this.onMediaSeeked.bind(this),this.onvended=this.onMediaEnded.bind(this),t.addEventListener("seeking",this.onvseeking),t.addEventListener("seeked",this.onvseeked),t.addEventListener("ended",this.onvended);var r=this.config;this.levels&&r.autoStartLoad&&this.hls.startLoad(r.startPosition),this.gapController=new ye(r,t,this.fragmentTracker,this.hls)},c.onMediaDetaching=function(){var e=this.media;e&&e.ended&&(f.logger.log("MSE detaching and video ended, reset startPosition"),this.startPosition=this.lastCurrentTime=0);var t=this.levels;t&&t.forEach((function(e){e.details&&e.details.fragments.forEach((function(e){e.backtracked=void 0}))})),e&&(e.removeEventListener("seeking",this.onvseeking),e.removeEventListener("seeked",this.onvseeked),e.removeEventListener("ended",this.onvended),this.onvseeking=this.onvseeked=this.onvended=null),this.fragmentTracker.removeAllFragments(),this.media=this.mediaBuffer=null,this.loadedmetadata=!1,this.stopLoad()},c.onMediaSeeked=function(){var e=this.media,t=e?e.currentTime:void 0;Object(l.isFiniteNumber)(t)&&f.logger.log("media seeked to "+t.toFixed(3)),this.tick()},c.onManifestLoading=function(){f.logger.log("trigger BUFFER_RESET"),this.hls.trigger(d.default.BUFFER_RESET),this.fragmentTracker.removeAllFragments(),this.stalled=!1,this.startPosition=this.lastCurrentTime=0},c.onManifestParsed=function(e){var t,r=!1,i=!1;e.levels.forEach((function(e){(t=e.audioCodec)&&(-1!==t.indexOf("mp4a.40.2")&&(r=!0),-1!==t.indexOf("mp4a.40.5")&&(i=!0))})),this.audioCodecSwitch=r&&i,this.audioCodecSwitch&&f.logger.log("both AAC/HE-AAC audio found in levels; declaring level codec as HE-AAC"),this.altAudio=e.altAudio,this.levels=e.levels,this.startFragRequested=!1;var n=this.config;(n.autoStartLoad||this.forceStartLoad)&&this.hls.startLoad(n.startPosition)},c.onLevelLoaded=function(e){var t=e.details,r=e.level,i=this.levels[this.levelLastLoaded],n=this.levels[r],s=t.totalduration,o=0;if(f.logger.log("level "+r+" loaded ["+t.startSN+","+t.endSN+"],duration:"+s),t.live||n.details&&n.details.live){var a=n.details;a&&t.fragments.length>0?(oe(a,t),o=t.fragments[0].start,this.liveSyncPosition=this.computeLivePosition(o,a),t.PTSKnown&&Object(l.isFiniteNumber)(o)?f.logger.log("live playlist sliding:"+o.toFixed(3)):(f.logger.log("live playlist - outdated PTS, unknown sliding"),de(this.fragPrevious,i,t))):(f.logger.log("live playlist - first load, unknown sliding"),t.PTSKnown=!1,de(this.fragPrevious,i,t))}else t.PTSKnown=!1;if(n.details=t,this.levelLastLoaded=r,this.hls.trigger(d.default.LEVEL_UPDATED,{details:t,level:r}),!1===this.startFragRequested){if(-1===this.startPosition||-1===this.lastCurrentTime){var c=t.startTimeOffset;Object(l.isFiniteNumber)(c)?(c<0&&(f.logger.log("negative start time offset "+c+", count from end of last fragment"),c=o+s+c),f.logger.log("start time offset found in playlist, adjust startPosition to "+c),this.startPosition=c):t.live?(this.startPosition=this.computeLivePosition(o,t),f.logger.log("configure startPosition to "+this.startPosition)):this.startPosition=0,this.lastCurrentTime=this.startPosition}this.nextLoadPosition=this.startPosition}this.state===De&&(this.state=_e),this.tick()},c.onKeyLoaded=function(){this.state===Se&&(this.state=_e,this.tick())},c.onFragLoaded=function(e){var t=this.fragCurrent,r=this.hls,i=this.levels,n=this.media,s=e.frag;if(this.state===Te&&t&&"main"===s.type&&s.level===t.level&&s.sn===t.sn){var o=e.stats,a=i[t.level],c=a.details;if(this.bitrateTest=!1,this.stats=o,f.logger.log("Loaded "+t.sn+" of ["+c.startSN+" ,"+c.endSN+"],level "+t.level),s.bitrateTest&&r.nextLoadLevel)this.state=_e,this.startFragRequested=!1,o.tparsed=o.tbuffered=window.performance.now(),r.trigger(d.default.FRAG_BUFFERED,{stats:o,frag:t,id:"main"}),this.tick();else if("initSegment"===s.sn)this.state=_e,o.tparsed=o.tbuffered=window.performance.now(),c.initSegment.data=e.payload,r.trigger(d.default.FRAG_BUFFERED,{stats:o,frag:t,id:"main"}),this.tick();else{f.logger.log("Parsing "+t.sn+" of ["+c.startSN+" ,"+c.endSN+"],level "+t.level+", cc "+t.cc),this.state=Ie,this.pendingBuffering=!0,this.appended=!1,s.bitrateTest&&(s.bitrateTest=!1,this.fragmentTracker.onFragLoaded({frag:s}));var u=!(n&&n.seeking)&&(c.PTSKnown||!c.live),l=c.initSegment?c.initSegment.data:[],h=this._getAudioCodec(a);(this.demuxer=this.demuxer||new re(this.hls,"main")).push(e.payload,l,h,a.videoCodec,t,c.totalduration,u)}}this.fragLoadError=0},c.onFragParsingInitSegment=function(e){var t=this.fragCurrent,r=e.frag;if(t&&"main"===e.id&&r.sn===t.sn&&r.level===t.level&&this.state===Ie){var i,n,s=e.tracks;if(this.audioOnly=s.audio&&!s.video,this.altAudio&&!this.audioOnly&&delete s.audio,n=s.audio){var o=this.levels[this.level].audioCodec,a=navigator.userAgent.toLowerCase();o&&this.audioCodecSwap&&(f.logger.log("swapping playlist audio codec"),o=-1!==o.indexOf("mp4a.40.5")?"mp4a.40.2":"mp4a.40.5"),this.audioCodecSwitch&&1!==n.metadata.channelCount&&-1===a.indexOf("firefox")&&(o="mp4a.40.5"),-1!==a.indexOf("android")&&"audio/mpeg"!==n.container&&(o="mp4a.40.2",f.logger.log("Android: force audio codec to "+o)),n.levelCodec=o,n.id=e.id}for(i in(n=s.video)&&(n.levelCodec=this.levels[this.level].videoCodec,n.id=e.id),this.hls.trigger(d.default.BUFFER_CODECS,s),s){n=s[i],f.logger.log("main track:"+i+",container:"+n.container+",codecs[level/parsed]=["+n.levelCodec+"/"+n.codec+"]");var c=n.initSegment;c&&(this.appended=!0,this.pendingBuffering=!0,this.hls.trigger(d.default.BUFFER_APPENDING,{type:i,data:c,parent:"main",content:"initSegment"}))}this.tick()}},c.onFragParsingData=function(e){var t=this,r=this.fragCurrent,i=e.frag;if(r&&"main"===e.id&&i.sn===r.sn&&i.level===r.level&&("audio"!==e.type||!this.altAudio)&&this.state===Ie){var n=this.levels[this.level],s=r;if(Object(l.isFiniteNumber)(e.endPTS)||(e.endPTS=e.startPTS+r.duration,e.endDTS=e.startDTS+r.duration),!0===e.hasAudio&&s.addElementaryStream(b.AUDIO),!0===e.hasVideo&&s.addElementaryStream(b.VIDEO),f.logger.log("Parsed "+e.type+",PTS:["+e.startPTS.toFixed(3)+","+e.endPTS.toFixed(3)+"],DTS:["+e.startDTS.toFixed(3)+"/"+e.endDTS.toFixed(3)+"],nb:"+e.nb+",dropped:"+(e.dropped||0)),"video"===e.type)if(s.dropped=e.dropped,s.dropped)if(s.backtracked)f.logger.warn("Already backtracked on this fragment, appending with the gap",s.sn);else{var o=n.details;if(!o||s.sn!==o.startSN)return f.logger.warn("missing video frame(s), backtracking fragment",s.sn),this.fragmentTracker.removeFragment(s),s.backtracked=!0,this.nextLoadPosition=e.startPTS,this.state=_e,this.fragPrevious=s,this.demuxer&&(this.demuxer.destroy(),this.demuxer=null),void this.tick();f.logger.warn("missing video frame(s) on first frag, appending with gap",s.sn)}else s.backtracked=!1;var a=se(n.details,s,e.startPTS,e.endPTS,e.startDTS,e.endDTS),c=this.hls;c.trigger(d.default.LEVEL_PTS_UPDATED,{details:n.details,level:this.level,drift:a,type:e.type,start:e.startPTS,end:e.endPTS}),[e.data1,e.data2].forEach((function(r){r&&r.length&&t.state===Ie&&(t.appended=!0,t.pendingBuffering=!0,c.trigger(d.default.BUFFER_APPENDING,{type:e.type,data:r,parent:"main",content:"data"}))})),this.tick()}},c.onFragParsed=function(e){var t=this.fragCurrent,r=e.frag;t&&"main"===e.id&&r.sn===t.sn&&r.level===t.level&&this.state===Ie&&(this.stats.tparsed=window.performance.now(),this.state=Re,this._checkAppendedParsed())},c.onAudioTrackSwitching=function(e){var t=this.altAudio,r=!!e.url,i=e.id;if(!r){if(this.mediaBuffer!==this.media){f.logger.log("switching on main audio, use media.buffered to schedule main fragment loading"),this.mediaBuffer=this.media;var n=this.fragCurrent;n.loader&&(f.logger.log("switching to main audio track, cancel main fragment load"),n.loader.abort()),this.fragCurrent=null,this.fragPrevious=null,this.demuxer&&(this.demuxer.destroy(),this.demuxer=null),this.state=_e}var s=this.hls;t&&s.trigger(d.default.BUFFER_FLUSHING,{startOffset:0,endOffset:Number.POSITIVE_INFINITY,type:"audio"}),s.trigger(d.default.AUDIO_TRACK_SWITCHED,{id:i})}},c.onAudioTrackSwitched=function(e){var t=e.id,r=!!this.hls.audioTracks[t].url;if(r){var i=this.videoBuffer;i&&this.mediaBuffer!==i&&(f.logger.log("switching on alternate audio, use video.buffered to schedule main fragment loading"),this.mediaBuffer=i)}this.altAudio=r,this.tick()},c.onBufferCreated=function(e){var t,r,i=e.tracks,n=!1;for(var s in i){var o=i[s];"main"===o.id?(r=s,t=o,"video"===s&&(this.videoBuffer=i[s].buffer)):n=!0}n&&t?(f.logger.log("alternate track found, use "+r+".buffered to schedule main fragment loading"),this.mediaBuffer=t.buffer):this.mediaBuffer=this.media},c.onBufferAppended=function(e){if("main"===e.parent){var t=this.state;t!==Ie&&t!==Re||(this.pendingBuffering=e.pending>0,this._checkAppendedParsed())}},c._checkAppendedParsed=function(){if(!(this.state!==Re||this.appended&&this.pendingBuffering)){var e=this.fragCurrent;if(e){var t=this.mediaBuffer?this.mediaBuffer:this.media;f.logger.log("main buffered : "+ue.toString(t.buffered)),this.fragPrevious=e;var r=this.stats;r.tbuffered=window.performance.now(),this.fragLastKbps=Math.round(8*r.total/(r.tbuffered-r.tfirst)),this.hls.trigger(d.default.FRAG_BUFFERED,{stats:r,frag:e,id:"main"}),this.state=_e}(this.loadedmetadata||this.startPosition<=0)&&this.tick()}},c.onError=function(e){var t=e.frag||this.fragCurrent;if(!t||"main"===t.type){var r=!!this.media&&$.isBuffered(this.media,this.media.currentTime)&&$.isBuffered(this.media,this.media.currentTime+.5);switch(e.details){case u.ErrorDetails.FRAG_LOAD_ERROR:case u.ErrorDetails.FRAG_LOAD_TIMEOUT:case u.ErrorDetails.KEY_LOAD_ERROR:case u.ErrorDetails.KEY_LOAD_TIMEOUT:if(!e.fatal)if(this.fragLoadError+1<=this.config.fragLoadingMaxRetry){var i=Math.min(Math.pow(2,this.fragLoadError)*this.config.fragLoadingRetryDelay,this.config.fragLoadingMaxRetryTimeout);f.logger.warn("mediaController: frag loading failed, retry in "+i+" ms"),this.retryDate=window.performance.now()+i,this.loadedmetadata||(this.startFragRequested=!1,this.nextLoadPosition=this.startPosition),this.fragLoadError++,this.state=Ae}else f.logger.error("mediaController: "+e.details+" reaches max retry, redispatch as fatal ..."),e.fatal=!0,this.state=Ce;break;case u.ErrorDetails.LEVEL_LOAD_ERROR:case u.ErrorDetails.LEVEL_LOAD_TIMEOUT:this.state!==Ce&&(e.fatal?(this.state=Ce,f.logger.warn("streamController: "+e.details+",switch to "+this.state+" state ...")):e.levelRetry||this.state!==De||(this.state=_e));break;case u.ErrorDetails.BUFFER_FULL_ERROR:"main"!==e.parent||this.state!==Ie&&this.state!==Re||(r?(this._reduceMaxBufferLength(this.config.maxBufferLength),this.state=_e):(f.logger.warn("buffer full error also media.currentTime is not buffered, flush everything"),this.fragCurrent=null,this.flushMainBuffer(0,Number.POSITIVE_INFINITY)))}}},c._reduceMaxBufferLength=function(e){var t=this.config;return t.maxMaxBufferLength>=e&&(t.maxMaxBufferLength/=2,f.logger.warn("main:reduce max buffer length to "+t.maxMaxBufferLength+"s"),!0)},c._checkBuffer=function(){var e=this.media;if(e&&0!==e.readyState){var t=(this.mediaBuffer?this.mediaBuffer:e).buffered;!this.loadedmetadata&&t.length?(this.loadedmetadata=!0,this._seekToStartPos()):this.immediateSwitch?this.immediateLevelSwitchEnd():this.gapController.poll(this.lastCurrentTime,t)}},c.onFragLoadEmergencyAborted=function(){this.state=_e,this.loadedmetadata||(this.startFragRequested=!1,this.nextLoadPosition=this.startPosition),this.tick()},c.onBufferFlushed=function(){var e=this.mediaBuffer?this.mediaBuffer:this.media;if(e){var t=this.audioOnly?b.AUDIO:b.VIDEO;this.fragmentTracker.detectEvictedFragments(t,e.buffered)}this.state=_e,this.fragPrevious=null},c.onLevelsUpdated=function(e){this.levels=e.levels},c.swapAudioCodec=function(){this.audioCodecSwap=!this.audioCodecSwap},c._seekToStartPos=function(){var e=this.media,t=e.currentTime,r=this.startPosition;if(t!==r&&r>=0){if(e.seeking)return void f.logger.log("could not seek to "+r+", already seeking at "+t);var i=(e.buffered.length?e.buffered.start(0):0)-r;i>0&&i"+e),this.hls.trigger(d.default.STREAM_STATE_TRANSITION,{previousState:t,nextState:e})}},get:function(){return this._state}},{key:"currentLevel",get:function(){var e=this.media;if(e){var t=this.getBufferedFrag(e.currentTime);if(t)return t.level}return-1}},{key:"nextBufferedFrag",get:function(){var e=this.media;return e?this.followingBufferedFrag(this.getBufferedFrag(e.currentTime)):null}},{key:"nextLevel",get:function(){var e=this.nextBufferedFrag;return e?e.level:-1}},{key:"liveSyncPosition",get:function(){return this._liveSyncPosition},set:function(e){this._liveSyncPosition=e}}])&&xe(n.prototype,s),a&&xe(n,a),i}(Me);function Ne(e,t){for(var r=0;r0){t=r[0].bitrate,r.sort((function(e,t){return e.bitrate-t.bitrate})),this._levels=r;for(var c=0;c=0&&e1&&l.loadError0){var t=this.currentLevelIndex,r=e.urlId,i=e.url[r];f.logger.log("Attempt loading level index "+t+" with URL-id "+r),this.hls.trigger(d.default.LEVEL_LOADING,{url:i,level:t,id:r})}}},a.removeLevel=function(e,t){var r=this.levels.filter((function(r,i){return i!==e||r.url.length>1&&void 0!==t&&(r.url=r.url.filter((function(e,r){return r!==t})),r.urlId=0,!0)})).map((function(e,t){var r=e.details;return r&&r.fragments&&r.fragments.forEach((function(e){e.level=t})),e}));this._levels=r,this.hls.trigger(d.default.LEVELS_UPDATED,{levels:r})},n=i,(s=[{key:"levels",get:function(){return this._levels}},{key:"level",get:function(){return this.currentLevelIndex},set:function(e){var t=this._levels;t&&(e=Math.min(e,t.length-1),this.currentLevelIndex===e&&t[e].details||this.setLevelInternal(e))}},{key:"manualLevel",get:function(){return this.manualLevelIndex},set:function(e){this.manualLevelIndex=e,void 0===this._startLevel&&(this._startLevel=e),-1!==e&&(this.level=e)}},{key:"firstLevel",get:function(){return this._firstLevel},set:function(e){this._firstLevel=e}},{key:"startLevel",get:function(){if(void 0===this._startLevel){var e=this.hls.config.startLevel;return void 0!==e?e:this._firstLevel}return this._startLevel},set:function(e){this._startLevel=e}},{key:"nextLoadLevel",get:function(){return-1!==this.manualLevelIndex?this.manualLevelIndex:this.hls.nextAutoLevel},set:function(e){this.level=e,-1===this.manualLevelIndex&&(this.hls.nextAutoLevel=e)}}])&&Ne(n.prototype,s),o&&Ne(n,o),i}(g),Fe=r("./src/demux/id3.js");function Ke(e,t){var r;try{r=new Event("addtrack")}catch(e){(r=document.createEvent("Event")).initEvent("addtrack",!1,!1)}r.track=e,t.dispatchEvent(r)}function ze(e){if(null==e?void 0:e.cues)for(;e.cues.length>0;)e.removeCue(e.cues[0])}var Ve=function(e){var t,r;function i(t){var r;return(r=e.call(this,t,d.default.MEDIA_ATTACHED,d.default.MEDIA_DETACHING,d.default.FRAG_PARSING_METADATA,d.default.LIVE_BACK_BUFFER_REACHED)||this).id3Track=void 0,r.media=void 0,r}r=e,(t=i).prototype=Object.create(r.prototype),t.prototype.constructor=t,t.__proto__=r;var n=i.prototype;return n.destroy=function(){g.prototype.destroy.call(this)},n.onMediaAttached=function(e){this.media=e.media,this.media},n.onMediaDetaching=function(){ze(this.id3Track),this.id3Track=void 0,this.media=void 0},n.getID3Track=function(e){for(var t=0;te[e.length-1].endTime)return e[e.length-1];for(var r=0,i=e.length-1;r<=i;){var n=Math.floor((i+r)/2);if(te[n].endTime))return e[n];r=n+1}}return e[r].endTime-t=this.minWeight_},t.getEstimate=function(){return this.canEstimate()?Math.min(this.fast_.getEstimate(),this.slow_.getEstimate()):this.defaultEstimate_},t.destroy=function(){},e}();function He(e,t){for(var r=0;r500*r.duration/o){var a=e.levels,c=Math.max(1,n.bw?n.bw/8:1e3*n.loaded/s),u=a[r.level];if(!u)return;var l=u.realBitrate?Math.max(u.realBitrate,u.bitrate):u.bitrate,h=n.total?n.total:Math.max(n.loaded,Math.round(r.duration*l/8)),p=t.currentTime,g=(h-n.loaded)/c,y=($.bufferInfo(t,p,e.config.maxBufferHole).end-p)/o;if(y<2*r.duration/o&&g>y){var m,b,v=e.minAutoLevel;for(b=r.level-1;b>v;b--){var w=a[b].realBitrate?Math.max(a[b].realBitrate,a[b].bitrate):a[b].bitrate;if(r.duration*w/(6.4*c)=i;u--){var l=c[u];if(l){var d=l.details,h=d?d.totalduration/d.fragments.length:t,p=!!d&&d.live,g=void 0;g=u<=e?o*r:a*r;var y=c[u].realBitrate?Math.max(c[u].realBitrate,c[u].bitrate):c[u].bitrate,m=y*h/g;if(f.logger.trace("level/adjustedbw/bitrate/avgDuration/maxFetchDuration/fetchDuration: "+u+"/"+Math.round(g)+"/"+y+"/"+h+"/"+s+"/"+m),g>y&&(!m||p&&!this.bitrateTestDelay||m=0)return h;f.logger.trace("rebuffering expected to happen, lets try to find a quality level minimizing the rebuffering");var p=a?Math.min(a,i.maxStarvationDelay):i.maxStarvationDelay,g=i.abrBandWidthFactor,y=i.abrBandWidthUpFactor;if(0===d){var m=this.bitrateTestDelay;m&&(p=(a?Math.min(a,i.maxLoadingDelay):i.maxLoadingDelay)-m,f.logger.trace("bitrate test took "+Math.round(1e3*m)+"ms, set first fragment max fetchDuration to "+Math.round(1e3*p)+" ms"),g=y=1)}return h=this._findBestLevel(o,a,l,n,t,d+p,g,y,r),Math.max(h,0)}}])&&He(n.prototype,s),o&&He(n,o),i}(g),Ye=Z(),Xe=function(e){var t,r;function i(t){var r;return(r=e.call(this,t,d.default.MEDIA_ATTACHING,d.default.MEDIA_DETACHING,d.default.MANIFEST_PARSED,d.default.BUFFER_RESET,d.default.BUFFER_APPENDING,d.default.BUFFER_CODECS,d.default.BUFFER_EOS,d.default.BUFFER_FLUSHING,d.default.LEVEL_PTS_UPDATED,d.default.LEVEL_UPDATED)||this)._msDuration=null,r._levelDuration=null,r._levelTargetDuration=10,r._live=null,r._objectUrl=null,r._needsFlush=!1,r._needsEos=!1,r.config=void 0,r.audioTimestampOffset=void 0,r.bufferCodecEventsExpected=0,r._bufferCodecEventsTotal=0,r.media=null,r.mediaSource=null,r.segments=[],r.parent=void 0,r.appending=!1,r.appended=0,r.appendError=0,r.flushBufferCounter=0,r.tracks={},r.pendingTracks={},r.sourceBuffer={},r.flushRange=[],r._onMediaSourceOpen=function(){f.logger.log("media source opened"),r.hls.trigger(d.default.MEDIA_ATTACHED,{media:r.media});var e=r.mediaSource;e&&e.removeEventListener("sourceopen",r._onMediaSourceOpen),r.checkPendingTracks()},r._onMediaSourceClose=function(){f.logger.log("media source closed")},r._onMediaSourceEnded=function(){f.logger.log("media source ended")},r._onSBUpdateEnd=function(){if(r.audioTimestampOffset&&r.sourceBuffer.audio){var e=r.sourceBuffer.audio;f.logger.warn("change mpeg audio timestamp offset from "+e.timestampOffset+" to "+r.audioTimestampOffset),e.timestampOffset=r.audioTimestampOffset,delete r.audioTimestampOffset}r._needsFlush&&r.doFlush(),r._needsEos&&r.checkEos(),r.appending=!1;var t=r.parent,i=r.segments.reduce((function(e,r){return r.parent===t?e+1:e}),0),n={},s=r.sourceBuffer;for(var o in s){var a=s[o];if(!a)throw Error("handling source buffer update end error: source buffer for "+o+" uninitilized and unable to update buffered TimeRanges.");n[o]=a.buffered}r.hls.trigger(d.default.BUFFER_APPENDED,{parent:t,pending:i,timeRanges:n}),r._needsFlush||r.doAppending(),r.updateMediaElementDuration(),0===i&&r.flushLiveBackBuffer()},r._onSBUpdateError=function(e){f.logger.error("sourceBuffer error:",e),r.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.MEDIA_ERROR,details:u.ErrorDetails.BUFFER_APPENDING_ERROR,fatal:!1})},r.config=t.config,r}r=e,(t=i).prototype=Object.create(r.prototype),t.prototype.constructor=t,t.__proto__=r;var n=i.prototype;return n.destroy=function(){g.prototype.destroy.call(this)},n.onLevelPtsUpdated=function(e){var t=e.type,r=this.tracks.audio;if("audio"===t&&r&&"audio/mpeg"===r.container){var i=this.sourceBuffer.audio;if(!i)throw Error("Level PTS Updated and source buffer for audio uninitalized");if(Math.abs(i.timestampOffset-e.start)>.1){var n=i.updating;try{i.abort()}catch(e){f.logger.warn("can not abort audio buffer: "+e)}n?this.audioTimestampOffset=e.start:(f.logger.warn("change mpeg audio timestamp offset from "+i.timestampOffset+" to "+e.start),i.timestampOffset=e.start)}}},n.onManifestParsed=function(e){var t=2;(e.audio&&!e.video||!e.altAudio)&&(t=1),this.bufferCodecEventsExpected=this._bufferCodecEventsTotal=t,f.logger.log(this.bufferCodecEventsExpected+" bufferCodec event(s) expected")},n.onMediaAttaching=function(e){var t=this.media=e.media;if(t&&Ye){var r=this.mediaSource=new Ye;r.addEventListener("sourceopen",this._onMediaSourceOpen),r.addEventListener("sourceended",this._onMediaSourceEnded),r.addEventListener("sourceclose",this._onMediaSourceClose),t.src=window.URL.createObjectURL(r),this._objectUrl=t.src}},n.onMediaDetaching=function(){f.logger.log("media source detaching");var e=this.mediaSource;if(e){if("open"===e.readyState)try{e.endOfStream()}catch(e){f.logger.warn("onMediaDetaching:"+e.message+" while calling endOfStream")}e.removeEventListener("sourceopen",this._onMediaSourceOpen),e.removeEventListener("sourceended",this._onMediaSourceEnded),e.removeEventListener("sourceclose",this._onMediaSourceClose),this.media&&(this._objectUrl&&window.URL.revokeObjectURL(this._objectUrl),this.media.src===this._objectUrl?(this.media.removeAttribute("src"),this.media.load()):f.logger.warn("media.src was changed by a third party - skip cleanup")),this.mediaSource=null,this.media=null,this._objectUrl=null,this.bufferCodecEventsExpected=this._bufferCodecEventsTotal,this.pendingTracks={},this.tracks={},this.sourceBuffer={},this.flushRange=[],this.segments=[],this.appended=0}this.hls.trigger(d.default.MEDIA_DETACHED)},n.checkPendingTracks=function(){var e=this.bufferCodecEventsExpected,t=this.pendingTracks,r=Object.keys(t).length;(r&&!e||2===r)&&(this.createSourceBuffers(t),this.pendingTracks={},this.doAppending())},n.onBufferReset=function(){var e=this.sourceBuffer;for(var t in e){var r=e[t];try{r&&(this.mediaSource&&this.mediaSource.removeSourceBuffer(r),r.removeEventListener("updateend",this._onSBUpdateEnd),r.removeEventListener("error",this._onSBUpdateError))}catch(e){}}this.sourceBuffer={},this.flushRange=[],this.segments=[],this.appended=0},n.onBufferCodecs=function(e){var t=this;Object.keys(this.sourceBuffer).length||(Object.keys(e).forEach((function(r){t.pendingTracks[r]=e[r]})),this.bufferCodecEventsExpected=Math.max(this.bufferCodecEventsExpected-1,0),this.mediaSource&&"open"===this.mediaSource.readyState&&this.checkPendingTracks())},n.createSourceBuffers=function(e){var t=this.sourceBuffer,r=this.mediaSource;if(!r)throw Error("createSourceBuffers called when mediaSource was null");for(var i in e)if(!t[i]){var n=e[i];if(!n)throw Error("source buffer exists for track "+i+", however track does not");var s=n.levelCodec||n.codec,o=n.container+";codecs="+s;f.logger.log("creating sourceBuffer("+o+")");try{var a=t[i]=r.addSourceBuffer(o);a.addEventListener("updateend",this._onSBUpdateEnd),a.addEventListener("error",this._onSBUpdateError),this.tracks[i]={buffer:a,codec:s,id:n.id,container:n.container,levelCodec:n.levelCodec}}catch(e){f.logger.error("error while trying to add sourceBuffer:"+e.message),this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.MEDIA_ERROR,details:u.ErrorDetails.BUFFER_ADD_CODEC_ERROR,fatal:!1,err:e,mimeType:o})}}this.hls.trigger(d.default.BUFFER_CREATED,{tracks:this.tracks})},n.onBufferAppending=function(e){this._needsFlush||(this.segments?this.segments.push(e):this.segments=[e],this.doAppending())},n.onBufferEos=function(e){for(var t in this.sourceBuffer)if(!e.type||e.type===t){var r=this.sourceBuffer[t];r&&!r.ended&&(r.ended=!0,f.logger.log(t+" sourceBuffer now EOS"))}this.checkEos()},n.checkEos=function(){var e=this.sourceBuffer,t=this.mediaSource;if(t&&"open"===t.readyState){for(var r in e){var i=e[r];if(i){if(!i.ended)return;if(i.updating)return void(this._needsEos=!0)}}f.logger.log("all media data are available, signal endOfStream() to MediaSource and stop loading fragment");try{t.endOfStream()}catch(e){f.logger.warn("exception while calling mediaSource.endOfStream()")}this._needsEos=!1}else this._needsEos=!1},n.onBufferFlushing=function(e){e.type?this.flushRange.push({start:e.startOffset,end:e.endOffset,type:e.type}):(this.flushRange.push({start:e.startOffset,end:e.endOffset,type:"video"}),this.flushRange.push({start:e.startOffset,end:e.endOffset,type:"audio"})),this.flushBufferCounter=0,this.doFlush()},n.flushLiveBackBuffer=function(){if(this._live){var e=this.config.liveBackBufferLength;if(isFinite(e)&&!(e<0))if(this.media)for(var t=this.media.currentTime,r=this.sourceBuffer,i=Object.keys(r),n=t-Math.max(e,this._levelTargetDuration),s=i.length-1;s>=0;s--){var o=i[s],a=r[o];if(a){var c=a.buffered;c.length>0&&n>c.start(0)&&this.removeBufferRange(o,a,0,n)&&this.hls.trigger(d.default.LIVE_BACK_BUFFER_REACHED,{bufferEnd:n})}}else f.logger.error("flushLiveBackBuffer called without attaching media")}},n.onLevelUpdated=function(e){var t=e.details;t.fragments.length>0&&(this._levelDuration=t.totalduration+t.fragments[0].start,this._levelTargetDuration=t.averagetargetduration||t.targetduration||10,this._live=t.live,this.updateMediaElementDuration())},n.updateMediaElementDuration=function(){var e,t=this.config;if(null!==this._levelDuration&&this.media&&this.mediaSource&&this.sourceBuffer&&0!==this.media.readyState&&"open"===this.mediaSource.readyState){for(var r in this.sourceBuffer){var i=this.sourceBuffer[r];if(i&&!0===i.updating)return}e=this.media.duration,null===this._msDuration&&(this._msDuration=this.mediaSource.duration),!0===this._live&&!0===t.liveDurationInfinity?(f.logger.log("Media Source duration is set to Infinity"),this._msDuration=this.mediaSource.duration=1/0):(this._levelDuration>this._msDuration&&this._levelDuration>e||!Object(l.isFiniteNumber)(e))&&(f.logger.log("Updating Media Source duration to "+this._levelDuration.toFixed(3)),this._msDuration=this.mediaSource.duration=this._levelDuration)}},n.doFlush=function(){for(;this.flushRange.length;){var e=this.flushRange[0];if(!this.flushBuffer(e.start,e.end,e.type))return void(this._needsFlush=!0);this.flushRange.shift(),this.flushBufferCounter=0}if(0===this.flushRange.length){this._needsFlush=!1;var t=0,r=this.sourceBuffer;try{for(var i in r){var n=r[i];n&&(t+=n.buffered.length)}}catch(e){f.logger.error("error while accessing sourceBuffer.buffered")}this.appended=t,this.hls.trigger(d.default.BUFFER_FLUSHED)}},n.doAppending=function(){var e=this.config,t=this.hls,r=this.segments,i=this.sourceBuffer;if(Object.keys(i).length){if(!this.media||this.media.error)return this.segments=[],void f.logger.error("trying to append although a media error occured, flush segment and abort");if(!this.appending){var n=r.shift();if(n)try{var s=i[n.type];if(!s)return void this._onSBUpdateEnd();if(s.updating)return void r.unshift(n);s.ended=!1,this.parent=n.parent,s.appendBuffer(n.data),this.appendError=0,this.appended++,this.appending=!0}catch(i){f.logger.error("error while trying to append buffer:"+i.message),r.unshift(n);var o={type:u.ErrorTypes.MEDIA_ERROR,parent:n.parent,details:"",fatal:!1};22===i.code?(this.segments=[],o.details=u.ErrorDetails.BUFFER_FULL_ERROR):(this.appendError++,o.details=u.ErrorDetails.BUFFER_APPEND_ERROR,this.appendError>e.appendErrorMaxRetry&&(f.logger.log("fail "+e.appendErrorMaxRetry+" times to append segment in sourceBuffer"),this.segments=[],o.fatal=!0)),t.trigger(d.default.ERROR,o)}}}},n.flushBuffer=function(e,t,r){var i=this.sourceBuffer;if(!Object.keys(i).length)return!0;var n="null";if(this.media&&(n=this.media.currentTime.toFixed(3)),f.logger.log("flushBuffer,pos/start/end: "+n+"/"+e+"/"+t),this.flushBufferCounter>=this.appended)return f.logger.warn("abort flushing too many retries"),!0;var s=i[r];if(s){if(s.ended=!1,s.updating)return f.logger.warn("cannot flush, sb updating in progress"),!1;if(this.removeBufferRange(r,s,e,t))return this.flushBufferCounter++,!1}return f.logger.log("buffer flushed"),!0},n.removeBufferRange=function(e,t,r,i){try{for(var n=0;n.5){var u="null";return this.media&&(u=this.media.currentTime.toString()),f.logger.log("sb remove "+e+" ["+a+","+c+"], of ["+s+","+o+"], pos:"+u),t.remove(a,c),!0}}}catch(e){f.logger.warn("removeBufferRange failed",e)}return!1},i}(g);function Ze(e,t){for(var r=0;rthis.autoLevelCapping&&t.streamController.nextLevelSwitch(),this.autoLevelCapping=t.autoLevelCapping}}},a.getMaxLevel=function(e){var t=this;if(!this.levels)return-1;var r=this.levels.filter((function(r,n){return i.isLevelAllowed(n,t.restrictedLevels)&&n<=e}));return this.clientRect=null,i.getMaxLevelByMediaSize(r,this.mediaWidth,this.mediaHeight)},a.startCapping=function(){this.timer||(this.autoLevelCapping=Number.POSITIVE_INFINITY,this.hls.firstLevel=this.getMaxLevel(this.firstLevel),clearInterval(this.timer),this.timer=setInterval(this.detectPlayerSize.bind(this),1e3),this.detectPlayerSize())},a.stopCapping=function(){this.restrictedLevels=[],this.firstLevel=null,this.autoLevelCapping=Number.POSITIVE_INFINITY,this.timer&&(this.timer=clearInterval(this.timer),this.timer=null)},a.getDimensions=function(){if(this.clientRect)return this.clientRect;var e=this.media,t={width:0,height:0};if(e){var r=e.getBoundingClientRect();t.width=r.width,t.height=r.height,t.width||t.height||(t.width=r.right-r.left||e.width||0,t.height=r.bottom-r.top||e.height||0)}return this.clientRect=t,t},i.isLevelAllowed=function(e,t){return void 0===t&&(t=[]),-1===t.indexOf(e)},i.getMaxLevelByMediaSize=function(e,t,r){if(!e||e&&!e.length)return-1;for(var i,n,s=e.length-1,o=0;o=t||a.height>=r)&&(i=a,!(n=e[o+1])||i.width!==n.width||i.height!==n.height)){s=o;break}}return s},n=i,o=[{key:"contentScaleFactor",get:function(){var e=1;try{e=window.devicePixelRatio}catch(e){}return e}}],(s=[{key:"mediaWidth",get:function(){return this.getDimensions().width*i.contentScaleFactor}},{key:"mediaHeight",get:function(){return this.getDimensions().height*i.contentScaleFactor}}])&&Ze(n.prototype,s),o&&Ze(n,o),i}(g),Je=window.performance,et=function(e){var t,r;function i(t){return e.call(this,t,d.default.MEDIA_ATTACHING)||this}r=e,(t=i).prototype=Object.create(r.prototype),t.prototype.constructor=t,t.__proto__=r;var n=i.prototype;return n.destroy=function(){this.timer&&clearInterval(this.timer),this.isVideoPlaybackQualityAvailable=!1},n.onMediaAttaching=function(e){var t=this.hls.config;t.capLevelOnFPSDrop&&("function"==typeof(this.video=e.media instanceof window.HTMLVideoElement?e.media:null).getVideoPlaybackQuality&&(this.isVideoPlaybackQualityAvailable=!0),clearInterval(this.timer),this.timer=setInterval(this.checkFPSInterval.bind(this),t.fpsDroppedMonitoringPeriod))},n.checkFPS=function(e,t,r){var i=Je.now();if(t){if(this.lastTime){var n=i-this.lastTime,s=r-this.lastDroppedFrames,o=t-this.lastDecodedFrames,a=1e3*s/n,c=this.hls;if(c.trigger(d.default.FPS_DROP,{currentDropped:s,currentDecoded:o,totalDroppedFrames:r}),a>0&&s>c.config.fpsDroppedMonitoringThreshold*o){var u=c.currentLevel;f.logger.warn("drop FPS ratio greater than max allowed value for currentLevel: "+u),u>0&&(-1===c.autoLevelCapping||c.autoLevelCapping>=u)&&(u-=1,c.trigger(d.default.FPS_DROP_LEVEL_CAPPING,{level:u,droppedLevel:c.currentLevel}),c.autoLevelCapping=u,c.streamController.nextLevelSwitch())}}this.lastTime=i,this.lastDroppedFrames=r,this.lastDecodedFrames=t}},n.checkFPSInterval=function(){var e=this.video;if(e)if(this.isVideoPlaybackQualityAvailable){var t=e.getVideoPlaybackQuality();this.checkFPS(e,t.totalVideoFrames,t.droppedVideoFrames)}else this.checkFPS(e,e.webkitDecodedFrameCount,e.webkitDroppedFrameCount)},i}(g),tt=function(){function e(e){e&&e.xhrSetup&&(this.xhrSetup=e.xhrSetup)}var t=e.prototype;return t.destroy=function(){this.abort(),this.loader=null},t.abort=function(){var e=this.loader;e&&4!==e.readyState&&(this.stats.aborted=!0,e.abort()),window.clearTimeout(this.requestTimeout),this.requestTimeout=null,window.clearTimeout(this.retryTimeout),this.retryTimeout=null},t.load=function(e,t,r){this.context=e,this.config=t,this.callbacks=r,this.stats={trequest:window.performance.now(),retry:0},this.retryDelay=t.retryDelay,this.loadInternal()},t.loadInternal=function(){var e,t=this.context;e=this.loader=new window.XMLHttpRequest;var r=this.stats;r.tfirst=0,r.loaded=0;var i=this.xhrSetup;try{if(i)try{i(e,t.url)}catch(r){e.open("GET",t.url,!0),i(e,t.url)}e.readyState||e.open("GET",t.url,!0)}catch(r){return void this.callbacks.onError({code:e.status,text:r.message},t,e)}t.rangeEnd&&e.setRequestHeader("Range","bytes="+t.rangeStart+"-"+(t.rangeEnd-1)),e.onreadystatechange=this.readystatechange.bind(this),e.onprogress=this.loadprogress.bind(this),e.responseType=t.responseType,this.requestTimeout=window.setTimeout(this.loadtimeout.bind(this),this.config.timeout),e.send()},t.readystatechange=function(e){var t=e.currentTarget,r=t.readyState,i=this.stats,n=this.context,s=this.config;if(!i.aborted&&r>=2)if(window.clearTimeout(this.requestTimeout),0===i.tfirst&&(i.tfirst=Math.max(window.performance.now(),i.trequest)),4===r){var o=t.status;if(o>=200&&o<300){var a,c;i.tload=Math.max(i.tfirst,window.performance.now()),c="arraybuffer"===n.responseType?(a=t.response).byteLength:(a=t.responseText).length,i.loaded=i.total=c;var u={url:t.responseURL,data:a};this.callbacks.onSuccess(u,i,n,t)}else i.retry>=s.maxRetry||o>=400&&o<499?(f.logger.error(o+" while loading "+n.url),this.callbacks.onError({code:o,text:t.statusText},n,t)):(f.logger.warn(o+" while loading "+n.url+", retrying in "+this.retryDelay+"..."),this.destroy(),this.retryTimeout=window.setTimeout(this.loadInternal.bind(this),this.retryDelay),this.retryDelay=Math.min(2*this.retryDelay,s.maxRetryDelay),i.retry++)}else this.requestTimeout=window.setTimeout(this.loadtimeout.bind(this),s.timeout)},t.loadtimeout=function(){f.logger.warn("timeout while loading "+this.context.url),this.callbacks.onTimeout(this.stats,this.context,null)},t.loadprogress=function(e){var t=e.currentTarget,r=this.stats;r.loaded=e.loaded,e.lengthComputable&&(r.total=e.total);var i=this.callbacks.onProgress;i&&i(r,this.context,null,t)},e}();function rt(e,t){for(var r=0;r=this.tracks.length)f.logger.warn("Invalid audio track id:",e.id);else{if(f.logger.log("audioTrack "+e.id+" loaded"),this.tracks[e.id].details=e.details,e.details.live&&!this.hasInterval()){var t=1e3*e.details.targetduration;this.setInterval(t)}!e.details.live&&this.hasInterval()&&this.clearInterval()}},a.onAudioTrackSwitched=function(e){var t=this.tracks[e.id].groupId;t&&this.audioGroupId!==t&&(this.audioGroupId=t)},a.onLevelLoaded=function(e){this._selectAudioGroup(e.level)},a.onError=function(e){e.type===u.ErrorTypes.NETWORK_ERROR&&(e.fatal&&this.clearInterval(),e.details===u.ErrorDetails.AUDIO_TRACK_LOAD_ERROR&&(f.logger.warn("Network failure on audio-track id:",e.context.id),this._handleLoadError()))},a._setAudioTrack=function(e){if(this._trackId===e&&this.tracks[this._trackId].details)f.logger.debug("Same id as current audio-track passed, and track details available -> no-op");else if(e<0||e>=this.tracks.length)f.logger.warn("Invalid id passed to audio-track controller");else{var t=this.tracks[e];f.logger.log("Now switching to audio-track index "+e),this.clearInterval(),this._trackId=e;var r=t.url,i=t.type,n=t.id;this.hls.trigger(d.default.AUDIO_TRACK_SWITCHING,{id:n,type:i,url:r}),this._loadTrackDetailsIfNeeded(t)}},a.doTick=function(){this._updateTrack(this._trackId)},a._selectAudioGroup=function(e){var t=this.hls.levels[e];if(t&&t.audioGroupIds){var r=t.audioGroupIds[t.urlId];this.audioGroupId!==r&&(this.audioGroupId=r,this._selectInitialAudioTrack())}},a._selectInitialAudioTrack=function(){var e=this,t=this.tracks;if(t.length){var r=this.tracks[this._trackId],i=null;if(r&&(i=r.name),this._selectDefaultTrack){var n=t.filter((function(e){return e.default}));n.length?t=n:f.logger.warn("No default audio tracks defined")}var s=!1,o=function(){t.forEach((function(t){s||e.audioGroupId&&t.groupId!==e.audioGroupId||i&&i!==t.name||(e._setAudioTrack(t.id),s=!0)}))};o(),s||(i=null,o()),s||(f.logger.error("No track found for running audio group-ID: "+this.audioGroupId),this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.MEDIA_ERROR,details:u.ErrorDetails.AUDIO_TRACK_LOAD_ERROR,fatal:!0}))}},a._needsTrackLoading=function(e){var t=e.details,r=e.url;return!(t&&!t.live||!r)},a._loadTrackDetailsIfNeeded=function(e){if(this._needsTrackLoading(e)){var t=e.url,r=e.id;f.logger.log("loading audio-track playlist for id: "+r),this.hls.trigger(d.default.AUDIO_TRACK_LOADING,{url:t,id:r})}},a._updateTrack=function(e){if(!(e<0||e>=this.tracks.length)){this.clearInterval(),this._trackId=e,f.logger.log("trying to update audio-track "+e);var t=this.tracks[e];this._loadTrackDetailsIfNeeded(t)}},a._handleLoadError=function(){this.trackIdBlacklist[this._trackId]=!0;var e=this._trackId,t=this.tracks[e],r=t.name,i=t.language,n=t.groupId;f.logger.warn("Loading failed on audio track id: "+e+", group-id: "+n+', name/language: "'+r+'" / "'+i+'"');for(var s=e,o=0;o0&&-1===e?(f.logger.log("audio:override startPosition with lastCurrentTime @"+t.toFixed(3)),this.state=_e):(this.lastCurrentTime=this.startPosition?this.startPosition:e,this.state=we),this.nextLoadPosition=this.startPosition=this.lastCurrentTime,this.tick()}else this.startPosition=e,this.state=ve},a.doTick=function(){var e,t,r,i=this.hls,n=i.config;switch(this.state){case Ce:case Ee:case Pe:break;case we:this.state=ke,this.loadedmetadata=!1;break;case _e:var s=this.tracks;if(!s)break;if(!this.media&&(this.startFragRequested||!n.startFragPrefetch))break;if(this.loadedmetadata)e=this.media.currentTime;else if(void 0===(e=this.nextLoadPosition))break;var o=this.mediaBuffer?this.mediaBuffer:this.media,a=this.videoBuffer?this.videoBuffer:this.media,c=eT||u.nextStart))return;f.logger.log("alt audio track ahead of main track, seek to start of alt audio track"),this.media.currentTime=T+.05}if(r.initSegment&&!r.initSegment.data)_=r.initSegment;else if(g<=T){if(_=E[0],null!==this.videoTrackCC&&_.cc!==this.videoTrackCC&&(_=function(e,t){return H.search(e,(function(e){return e.cct?-1:0}))}(E,this.videoTrackCC)),r.live&&_.loadIdx&&_.loadIdx===this.fragLoadIdx){var k=u.nextStart?u.nextStart:T;return f.logger.log("no alt audio available @currentTime:"+this.media.currentTime+", seeking @"+(k+.05)),void(this.media.currentTime=k+.05)}}else{var I,R=n.maxFragLookUpTolerance,P=y?E[y.sn-E[0].sn+1]:void 0;gA-R&&(R=0),I=P&&!pe(g,R,P)?P:H.search(E,(function(e){return pe(g,R,e)}))):I=E[S-1],I&&(_=I,T=I.start,y&&_.level===y.level&&_.sn===y.sn&&(_.sn=C||j)&&(f.logger.log("audioStreamController: retryDate reached, switch back to IDLE state"),this.state=_e);break;case je:var D=this.waitingFragment;if(D){var M=D.frag.cc;if(void 0!==this.initPTS[M])this.waitingFragment=null,this.state=Te,this.onFragLoaded(D);else if(this.videoTrackCC!==this.waitingVideoCC)f.logger.log("Waiting fragment cc ("+M+") cancelled because video is at cc "+this.videoTrackCC),this.clearWaitingFragment();else{var x=$.bufferInfo(this.mediaBuffer,this.media.currentTime,n.maxBufferHole);pe(x.end,n.maxFragLookUpTolerance,D.frag)<0&&(f.logger.log("Waiting fragment cc ("+M+") @ "+D.frag.start+" cancelled because another fragment at "+x.end+" is needed"),this.clearWaitingFragment())}}else this.state=_e}},a.clearWaitingFragment=function(){var e=this.waitingFragment;e&&(this.fragmentTracker.removeFragment(e.frag),this.waitingFragment=null,this.waitingVideoCC=null,this.state=_e)},a.onMediaAttached=function(e){var t=this.media=this.mediaBuffer=e.media;this.onvseeking=this.onMediaSeeking.bind(this),this.onvended=this.onMediaEnded.bind(this),t.addEventListener("seeking",this.onvseeking),t.addEventListener("ended",this.onvended);var r=this.config;this.tracks&&r.autoStartLoad&&this.startLoad(r.startPosition)},a.onMediaDetaching=function(){var e=this.media;e&&e.ended&&(f.logger.log("MSE detaching and video ended, reset startPosition"),this.startPosition=this.lastCurrentTime=0),e&&(e.removeEventListener("seeking",this.onvseeking),e.removeEventListener("ended",this.onvended),this.onvseeking=this.onvseeked=this.onvended=null),this.media=this.mediaBuffer=this.videoBuffer=null,this.loadedmetadata=!1,this.fragmentTracker.removeAllFragments(),this.stopLoad()},a.onAudioTracksUpdated=function(e){f.logger.log("audio tracks updated"),this.tracks=e.audioTracks},a.onAudioTrackSwitching=function(e){var t=!!e.url;this.trackId=e.id,this.fragCurrent=null,this.clearWaitingFragment(),this.state=Ee,t?this.setInterval(100):this.demuxer&&(this.demuxer.destroy(),this.demuxer=null),t&&(this.audioSwitch=!0,this.state=_e),this.tick()},a.onAudioTrackLoaded=function(e){var t=e.details,r=e.id,i=this.tracks[r],n=i.details,s=t.totalduration,o=0;if(f.logger.log("track "+r+" loaded ["+t.startSN+","+t.endSN+"],duration:"+s),t.live||n&&n.live?n&&t.fragments.length>0?(oe(n,t),o=t.fragments[0].start,t.PTSKnown?f.logger.log("live audio playlist sliding:"+o.toFixed(3)):f.logger.log("live audio playlist - outdated PTS, unknown sliding")):(t.PTSKnown=!1,f.logger.log("live audio playlist - first load, unknown sliding")):t.PTSKnown=!1,i.details=t,!this.startFragRequested){if(-1===this.startPosition){var a=t.startTimeOffset;Object(l.isFiniteNumber)(a)?(f.logger.log("start time offset found in playlist, adjust startPosition to "+a),this.startPosition=a):t.live?(this.startPosition=this.computeLivePosition(o,t),f.logger.log("compute startPosition for audio-track to "+this.startPosition)):this.startPosition=0}this.nextLoadPosition=this.startPosition}this.state===ke&&(this.state=_e),this.tick()},a.onKeyLoaded=function(){this.state===Se&&(this.state=_e,this.tick())},a.onFragLoaded=function(e){var t=this.fragCurrent,r=e.frag;if(this.state===Te&&t&&"audio"===r.type&&r.level===t.level&&r.sn===t.sn){var i=this.tracks[this.trackId],n=i.details,s=n.totalduration,o=t.level,a=t.sn,c=t.cc,u=this.config.defaultAudioCodec||i.audioCodec||"mp4a.40.2",l=this.stats=e.stats;if("initSegment"===a)this.state=_e,l.tparsed=l.tbuffered=st.now(),n.initSegment.data=e.payload,this.hls.trigger(d.default.FRAG_BUFFERED,{stats:l,frag:t,id:"audio"}),this.tick();else{this.state=Ie,this.appended=!1,this.demuxer||(this.demuxer=new re(this.hls,"audio"));var h=this.initPTS[c],p=n.initSegment?n.initSegment.data:[];void 0!==h?(this.pendingBuffering=!0,f.logger.log("Demuxing "+a+" of ["+n.startSN+" ,"+n.endSN+"],track "+o),this.demuxer.push(e.payload,p,u,null,t,s,!1,h)):(f.logger.log("Unknown video PTS for cc "+c+", waiting for video PTS before demuxing audio frag "+a+" of ["+n.startSN+" ,"+n.endSN+"],track "+o),this.waitingFragment=e,this.waitingVideoCC=this.videoTrackCC,this.state=je)}}this.fragLoadError=0},a.onFragParsingInitSegment=function(e){var t=this.fragCurrent,r=e.frag;if(t&&"audio"===e.id&&r.sn===t.sn&&r.level===t.level&&this.state===Ie){var i,n=e.tracks;if(n.video&&delete n.video,i=n.audio){i.levelCodec=i.codec,i.id=e.id,this.hls.trigger(d.default.BUFFER_CODECS,n),f.logger.log("audio track:audio,container:"+i.container+",codecs[level/parsed]=["+i.levelCodec+"/"+i.codec+"]");var s=i.initSegment;if(s){var o={type:"audio",data:s,parent:"audio",content:"initSegment"};this.audioSwitch?this.pendingData=[o]:(this.appended=!0,this.pendingBuffering=!0,this.hls.trigger(d.default.BUFFER_APPENDING,o))}this.tick()}}},a.onFragParsingData=function(e){var t=this,r=this.fragCurrent,i=e.frag;if(r&&"audio"===e.id&&"audio"===e.type&&i.sn===r.sn&&i.level===r.level&&this.state===Ie){var n=this.trackId,s=this.tracks[n],o=this.hls;Object(l.isFiniteNumber)(e.endPTS)||(e.endPTS=e.startPTS+r.duration,e.endDTS=e.startDTS+r.duration),r.addElementaryStream(b.AUDIO),f.logger.log("parsed "+e.type+",PTS:["+e.startPTS.toFixed(3)+","+e.endPTS.toFixed(3)+"],DTS:["+e.startDTS.toFixed(3)+"/"+e.endDTS.toFixed(3)+"],nb:"+e.nb),se(s.details,r,e.startPTS,e.endPTS);var a=this.media,c=!1;if(this.audioSwitch)if(a&&a.readyState){var h=a.currentTime;f.logger.log("switching audio track : currentTime:"+h),h>=e.startPTS&&(f.logger.log("switching audio track : flushing all audio"),this.state=Pe,o.trigger(d.default.BUFFER_FLUSHING,{startOffset:0,endOffset:Number.POSITIVE_INFINITY,type:"audio"}),c=!0,this.audioSwitch=!1,o.trigger(d.default.AUDIO_TRACK_SWITCHED,{id:n}))}else this.audioSwitch=!1,o.trigger(d.default.AUDIO_TRACK_SWITCHED,{id:n});var p=this.pendingData;if(!p)return f.logger.warn("Apparently attempt to enqueue media payload without codec initialization data upfront"),void o.trigger(d.default.ERROR,{type:u.ErrorTypes.MEDIA_ERROR,details:null,fatal:!0});this.audioSwitch||([e.data1,e.data2].forEach((function(t){t&&t.length&&p.push({type:e.type,data:t,parent:"audio",content:"data"})})),!c&&p.length&&(p.forEach((function(e){t.state===Ie&&(t.pendingBuffering=!0,t.hls.trigger(d.default.BUFFER_APPENDING,e))})),this.pendingData=[],this.appended=!0)),this.tick()}},a.onFragParsed=function(e){var t=this.fragCurrent,r=e.frag;t&&"audio"===e.id&&r.sn===t.sn&&r.level===t.level&&this.state===Ie&&(this.stats.tparsed=st.now(),this.state=Re,this._checkAppendedParsed())},a.onBufferReset=function(){this.mediaBuffer=this.videoBuffer=null,this.loadedmetadata=!1},a.onBufferCreated=function(e){var t=e.tracks.audio;t&&(this.mediaBuffer=t.buffer,this.loadedmetadata=!0),e.tracks.video&&(this.videoBuffer=e.tracks.video.buffer)},a.onBufferAppended=function(e){if("audio"===e.parent){var t=this.state;t!==Ie&&t!==Re||(this.pendingBuffering=e.pending>0,this._checkAppendedParsed())}},a._checkAppendedParsed=function(){if(!(this.state!==Re||this.appended&&this.pendingBuffering)){var e=this.fragCurrent,t=this.stats,r=this.hls;if(e){this.fragPrevious=e,t.tbuffered=st.now(),r.trigger(d.default.FRAG_BUFFERED,{stats:t,frag:e,id:"audio"});var i=this.mediaBuffer?this.mediaBuffer:this.media;i&&f.logger.log("audio buffered : "+ue.toString(i.buffered)),this.audioSwitch&&this.appended&&(this.audioSwitch=!1,r.trigger(d.default.AUDIO_TRACK_SWITCHED,{id:this.trackId})),this.state=_e}this.tick()}},a.onError=function(e){var t=e.frag;if(!t||"audio"===t.type)switch(e.details){case u.ErrorDetails.FRAG_LOAD_ERROR:case u.ErrorDetails.FRAG_LOAD_TIMEOUT:var r=e.frag;if(r&&"audio"!==r.type)break;if(!e.fatal){var i=this.fragLoadError;i?i++:i=1;var n=this.config;if(i<=n.fragLoadingMaxRetry){this.fragLoadError=i;var s=Math.min(Math.pow(2,i-1)*n.fragLoadingRetryDelay,n.fragLoadingMaxRetryTimeout);f.logger.warn("AudioStreamController: frag loading failed, retry in "+s+" ms"),this.retryDate=st.now()+s,this.state=Ae}else f.logger.error("AudioStreamController: "+e.details+" reaches max retry, redispatch as fatal ..."),e.fatal=!0,this.state=Ce}break;case u.ErrorDetails.AUDIO_TRACK_LOAD_ERROR:case u.ErrorDetails.AUDIO_TRACK_LOAD_TIMEOUT:case u.ErrorDetails.KEY_LOAD_ERROR:case u.ErrorDetails.KEY_LOAD_TIMEOUT:this.state!==Ce&&(this.state=e.fatal?Ce:_e,f.logger.warn("AudioStreamController: "+e.details+" while loading frag, now switching to "+this.state+" state ..."));break;case u.ErrorDetails.BUFFER_FULL_ERROR:if("audio"===e.parent&&(this.state===Ie||this.state===Re)){var o=this.mediaBuffer,a=this.media.currentTime;if(o&&$.isBuffered(o,a)&&$.isBuffered(o,a+.5)){var c=this.config;c.maxMaxBufferLength>=c.maxBufferLength&&(c.maxMaxBufferLength/=2,f.logger.warn("AudioStreamController: reduce max buffer length to "+c.maxMaxBufferLength+"s")),this.state=_e}else f.logger.warn("AudioStreamController: buffer full error also media.currentTime is not buffered, flush audio buffer"),this.fragCurrent=null,this.state=Pe,this.hls.trigger(d.default.BUFFER_FLUSHING,{startOffset:0,endOffset:Number.POSITIVE_INFINITY,type:"audio"})}}},a.onBufferFlushed=function(){var e=this,t=this.pendingData;t&&t.length?(f.logger.log("AudioStreamController: appending pending audio data after buffer flushed"),t.forEach((function(t){e.hls.trigger(d.default.BUFFER_APPENDING,t)})),this.appended=!0,this.pendingData=[],this.state=Re):(this.state=_e,this.fragPrevious=null,this.tick())},n=i,(s=[{key:"state",set:function(e){if(this.state!==e){var t=this.state;this._state=e,f.logger.log("audio stream:"+t+"->"+e)}},get:function(){return this._state}}])&&nt(n.prototype,s),o&&nt(n,o),i}(Me),at=function(){if("undefined"!=typeof window&&window.VTTCue)return window.VTTCue;var e={"":!0,lr:!0,rl:!0},t={start:!0,middle:!0,end:!0,left:!0,right:!0};function r(e){return"string"==typeof e&&!!t[e.toLowerCase()]&&e.toLowerCase()}function i(e){for(var t=1;t100)throw new Error("Position must be between 0 and 100.");b=e,this.hasBeenReset=!0}})),Object.defineProperty(o,"positionAlign",i({},a,{get:function(){return v},set:function(e){var t=r(e);if(!t)throw new SyntaxError("An invalid or illegal string was specified.");v=t,this.hasBeenReset=!0}})),Object.defineProperty(o,"size",i({},a,{get:function(){return w},set:function(e){if(e<0||e>100)throw new Error("Size must be between 0 and 100.");w=e,this.hasBeenReset=!0}})),Object.defineProperty(o,"align",i({},a,{get:function(){return _},set:function(e){var t=r(e);if(!t)throw new SyntaxError("An invalid or illegal string was specified.");_=t,this.hasBeenReset=!0}})),o.displayState=void 0}return n.prototype.getCueAsHTML=function(){return window.WebVTT.convertCueToDOMTree(window,this.text)},n}(),ct=function(){return{decode:function(e){if(!e)return"";if("string"!=typeof e)throw new Error("Error - expected string data.");return decodeURIComponent(encodeURIComponent(e))}}};function ut(){this.window=window,this.state="INITIAL",this.buffer="",this.decoder=new ct,this.regionList=[]}function lt(){this.values=Object.create(null)}function dt(e,t,r,i){var n=i?e.split(i):[e];for(var s in n)if("string"==typeof n[s]){var o=n[s].split(r);2===o.length&&t(o[0],o[1])}}lt.prototype={set:function(e,t){this.get(e)||""===t||(this.values[e]=t)},get:function(e,t,r){return r?this.has(e)?this.values[e]:t[r]:this.has(e)?this.values[e]:t},has:function(e){return e in this.values},alt:function(e,t,r){for(var i=0;i=0&&t<=100)&&(this.set(e,t),!0)}};var ft=new at(0,0,0),ht="middle"===ft.align?"middle":"center";function pt(e,t,r){var i=e;function n(){var t=function(e){function t(e,t,r,i){return 3600*(0|e)+60*(0|t)+(0|r)+(0|i)/1e3}var r=e.match(/^(\d+):(\d{2})(:\d{2})?\.(\d{3})/);return r?r[3]?t(r[1],r[2],r[3].replace(":",""),r[4]):r[1]>59?t(r[1],r[2],0,r[4]):t(0,r[1],r[2],r[4]):null}(e);if(null===t)throw new Error("Malformed timestamp: "+i);return e=e.replace(/^[^\sa-zA-Z-]+/,""),t}function s(){e=e.replace(/^\s+/,"")}if(s(),t.startTime=n(),s(),"--\x3e"!==e.substr(0,3))throw new Error("Malformed time stamp (time stamps must be separated by '--\x3e'): "+i);e=e.substr(3),s(),t.endTime=n(),s(),function(e,t){var i=new lt;dt(e,(function(e,t){switch(e){case"region":for(var n=r.length-1;n>=0;n--)if(r[n].id===t){i.set(e,r[n].region);break}break;case"vertical":i.alt(e,t,["rl","lr"]);break;case"line":var s=t.split(","),o=s[0];i.integer(e,o),i.percent(e,o)&&i.set("snapToLines",!1),i.alt(e,o,["auto"]),2===s.length&&i.alt("lineAlign",s[1],["start",ht,"end"]);break;case"position":s=t.split(","),i.percent(e,s[0]),2===s.length&&i.alt("positionAlign",s[1],["start",ht,"end","line-left","line-right","auto"]);break;case"size":i.percent(e,t);break;case"align":i.alt(e,t,["start",ht,"end","left","right"])}}),/:/,/\s/),t.region=i.get("region",null),t.vertical=i.get("vertical","");var n=i.get("line","auto");"auto"===n&&-1===ft.line&&(n=-1),t.line=n,t.lineAlign=i.get("lineAlign","start"),t.snapToLines=i.get("snapToLines",!0),t.size=i.get("size",100),t.align=i.get("align",ht);var s=i.get("position","auto");"auto"===s&&50===ft.position&&(s="start"===t.align||"left"===t.align?0:"end"===t.align||"right"===t.align?100:50),t.position=s}(e,t)}function gt(e){return e.replace(//gi,"\n")}ut.prototype={parse:function(e){var t=this;function r(){var e=t.buffer,r=0;for(e=gt(e);r=16?a--:a++,navigator.userAgent.match(/Firefox\//)?s.line=d+1:s.line=d>7?d-2:d+1,s.align="left",s.position=Math.max(0,Math.min(100,a/32*100)),u.push(s),e&&e.addCue(s)}return u}var bt,vt,wt={42:225,92:233,94:237,95:243,96:250,123:231,124:247,125:209,126:241,127:9608,128:174,129:176,130:189,131:191,132:8482,133:162,134:163,135:9834,136:224,137:32,138:232,139:226,140:234,141:238,142:244,143:251,144:193,145:201,146:211,147:218,148:220,149:252,150:8216,151:161,152:42,153:8217,154:9473,155:169,156:8480,157:8226,158:8220,159:8221,160:192,161:194,162:199,163:200,164:202,165:203,166:235,167:206,168:207,169:239,170:212,171:217,172:249,173:219,174:171,175:187,176:195,177:227,178:205,179:204,180:236,181:210,182:242,183:213,184:245,185:123,186:125,187:92,188:94,189:95,190:124,191:8764,192:196,193:228,194:214,195:246,196:223,197:165,198:164,199:9475,200:197,201:229,202:216,203:248,204:9487,205:9491,206:9495,207:9499},_t=function(e){var t=e;return wt.hasOwnProperty(e)&&(t=wt[e]),String.fromCharCode(t)},Et=15,St=100,Tt={17:1,18:3,21:5,22:7,23:9,16:11,19:12,20:14},At={17:2,18:4,21:6,22:8,23:10,19:13,20:15},kt={25:1,26:3,29:5,30:7,31:9,24:11,27:12,28:14},It={25:2,26:4,29:6,30:8,31:10,27:13,28:15},Rt=["white","green","blue","cyan","red","yellow","magenta","black","transparent"];(vt=bt||(bt={}))[vt.ERROR=0]="ERROR",vt[vt.TEXT=1]="TEXT",vt[vt.WARNING=2]="WARNING",vt[vt.INFO=2]="INFO",vt[vt.DEBUG=3]="DEBUG",vt[vt.DATA=3]="DATA";var Pt=function(){function e(){this.time=null,this.verboseLevel=bt.ERROR}return e.prototype.log=function(e,t){this.verboseLevel>=e&&f.logger.log(this.time+" ["+e+"] "+t)},e}(),Ot=function(e){for(var t=[],r=0;rSt&&(this.logger.log(bt.DEBUG,"Too large cursor position "+this.pos),this.pos=St)},t.moveCursor=function(e){var t=this.pos+e;if(e>1)for(var r=this.pos+1;r=144&&this.backSpace();var t=_t(e);this.pos>=St?this.logger.log(bt.ERROR,"Cannot insert "+e.toString(16)+" ("+t+") at position "+this.pos+". Skipping it!"):(this.chars[this.pos].setChar(t,this.currPenState),this.moveCursor(1))},t.clearFromPos=function(e){var t;for(t=e;t0&&(r=e?"["+t.join(" | ")+"]":t.join("\n")),r},t.getTextAndFormat=function(){return this.rows},e}(),xt=function(){function e(e,t,r){this.chNr=void 0,this.outputFilter=void 0,this.mode=void 0,this.verbose=void 0,this.displayedMemory=void 0,this.nonDisplayedMemory=void 0,this.lastOutputScreen=void 0,this.currRollUpRow=void 0,this.writeScreen=void 0,this.cueStartTime=void 0,this.logger=void 0,this.chNr=e,this.outputFilter=t,this.mode=null,this.verbose=0,this.displayedMemory=new Mt(r),this.nonDisplayedMemory=new Mt(r),this.lastOutputScreen=new Mt(r),this.currRollUpRow=this.displayedMemory.rows[14],this.writeScreen=this.displayedMemory,this.mode=null,this.cueStartTime=null,this.logger=r}var t=e.prototype;return t.reset=function(){this.mode=null,this.displayedMemory.reset(),this.nonDisplayedMemory.reset(),this.lastOutputScreen.reset(),this.outputFilter.reset(),this.currRollUpRow=this.displayedMemory.rows[14],this.writeScreen=this.displayedMemory,this.mode=null,this.cueStartTime=null},t.getHandler=function(){return this.outputFilter},t.setHandler=function(e){this.outputFilter=e},t.setPAC=function(e){this.writeScreen.setPAC(e)},t.setBkgData=function(e){this.writeScreen.setBkgData(e)},t.setMode=function(e){e!==this.mode&&(this.mode=e,this.logger.log(bt.INFO,"MODE="+e),"MODE_POP-ON"===this.mode?this.writeScreen=this.nonDisplayedMemory:(this.writeScreen=this.displayedMemory,this.writeScreen.reset()),"MODE_ROLL-UP"!==this.mode&&(this.displayedMemory.nrRollUpRows=null,this.nonDisplayedMemory.nrRollUpRows=null),this.mode=e)},t.insertChars=function(e){for(var t=0;t=46,t.italics)t.foreground="white";else{var r=Math.floor(e/2)-16;t.foreground=["white","green","blue","cyan","red","yellow","magenta"][r]}this.logger.log(bt.INFO,"MIDROW: "+JSON.stringify(t)),this.writeScreen.setPen(t)},t.outputDataUpdate=function(e){void 0===e&&(e=!1);var t=this.logger.time;null!==t&&this.outputFilter&&(null!==this.cueStartTime||this.displayedMemory.isEmpty()?this.displayedMemory.equals(this.lastOutputScreen)||(this.outputFilter.newCue(this.cueStartTime,t,this.lastOutputScreen),e&&this.outputFilter.dispatchCue&&this.outputFilter.dispatchCue(),this.cueStartTime=this.displayedMemory.isEmpty()?null:t):this.cueStartTime=t,this.lastOutputScreen.copy(this.displayedMemory))},t.cueSplitAtTime=function(e){this.outputFilter&&(this.displayedMemory.isEmpty()||(this.outputFilter.newCue&&this.outputFilter.newCue(this.cueStartTime,e,this.displayedMemory),this.cueStartTime=e))},e}();function Bt(e,t,r){r.a=e,r.b=t}function Lt(e,t,r){return r.a===e&&r.b===t}var Nt=function(){function e(e,t,r){this.channels=void 0,this.currentChannel=0,this.cmdHistory=void 0,this.logger=void 0;var i=new Pt;this.channels=[null,new xt(e,t,i),new xt(e+1,r,i)],this.cmdHistory={a:null,b:null},this.logger=i}var t=e.prototype;return t.getHandler=function(e){return this.channels[e].getHandler()},t.setHandler=function(e,t){this.channels[e].setHandler(t)},t.addData=function(e,t){var r,i,n,s=!1;this.logger.time=e;for(var o=0;o ("+Ot([i,n])+")"),(r=this.parseCmd(i,n))||(r=this.parseMidrow(i,n)),r||(r=this.parsePAC(i,n)),r||(r=this.parseBackgroundAttributes(i,n)),!r&&(s=this.parseChars(i,n))){var a=this.currentChannel;a&&a>0?this.channels[a].insertChars(s):this.logger.log(bt.WARNING,"No channel found yet. TEXT-MODE?")}r||s||this.logger.log(bt.WARNING,"Couldn't parse cleaned data "+Ot([i,n])+" orig: "+Ot([t[o],t[o+1]]))}},t.parseCmd=function(e,t){var r=this.cmdHistory;if(!((20===e||28===e||21===e||29===e)&&t>=32&&t<=47||(23===e||31===e)&&t>=33&&t<=35))return!1;if(Lt(e,t,r))return Bt(null,null,r),this.logger.log(bt.DEBUG,"Repeated command ("+Ot([e,t])+") is dropped"),!0;var i=20===e||21===e||23===e?1:2,n=this.channels[i];return 20===e||21===e||28===e||29===e?32===t?n.ccRCL():33===t?n.ccBS():34===t?n.ccAOF():35===t?n.ccAON():36===t?n.ccDER():37===t?n.ccRU(2):38===t?n.ccRU(3):39===t?n.ccRU(4):40===t?n.ccFON():41===t?n.ccRDC():42===t?n.ccTR():43===t?n.ccRTD():44===t?n.ccEDM():45===t?n.ccCR():46===t?n.ccENM():47===t&&n.ccEOC():n.ccTO(t-32),Bt(e,t,r),this.currentChannel=i,!0},t.parseMidrow=function(e,t){var r=0;if((17===e||25===e)&&t>=32&&t<=47){if((r=17===e?1:2)!==this.currentChannel)return this.logger.log(bt.ERROR,"Mismatch channel in midrow parsing"),!1;var i=this.channels[r];return!!i&&(i.ccMIDROW(t),this.logger.log(bt.DEBUG,"MIDROW ("+Ot([e,t])+")"),!0)}return!1},t.parsePAC=function(e,t){var r,i=this.cmdHistory;if(!((e>=17&&e<=23||e>=25&&e<=31)&&t>=64&&t<=127||(16===e||24===e)&&t>=64&&t<=95))return!1;if(Lt(e,t,i))return Bt(null,null,i),!0;var n=e<=23?1:2;r=t>=64&&t<=95?1===n?Tt[e]:kt[e]:1===n?At[e]:It[e];var s=this.channels[n];return!!s&&(s.setPAC(this.interpretPAC(r,t)),Bt(e,t,i),this.currentChannel=n,!0)},t.interpretPAC=function(e,t){var r=t,i={color:null,italics:!1,indent:null,underline:!1,row:e};return r=t>95?t-96:t-64,i.underline=1==(1&r),r<=13?i.color=["white","green","blue","cyan","red","yellow","magenta","white"][Math.floor(r/2)]:r<=15?(i.italics=!0,i.color="white"):i.indent=4*Math.floor((r-16)/2),i},t.parseChars=function(e,t){var r,i=null,n=null;if(e>=25?(r=2,n=e-8):(r=1,n=e),n>=17&&n<=19){var s=t;s=17===n?t+80:18===n?t+112:t+144,this.logger.log(bt.INFO,"Special char '"+_t(s)+"' in channel "+r),i=[s]}else e>=32&&e<=127&&(i=0===t?[e]:[e,t]);if(i){var o=Ot(i);this.logger.log(bt.DEBUG,"Char codes = "+o.join(",")),Bt(e,t,this.cmdHistory)}return i},t.parseBackgroundAttributes=function(e,t){var r;if(!((16===e||24===e)&&t>=32&&t<=47||(23===e||31===e)&&t>=45&&t<=47))return!1;var i={};16===e||24===e?(r=Math.floor((t-32)/2),i.background=Rt[r],t%2==1&&(i.background=i.background+"_semi")):45===t?i.background="transparent":(i.foreground="black",47===t&&(i.underline=!0));var n=e<=23?1:2;return this.channels[n].setBkgData(i),Bt(e,t,this.cmdHistory),!0},t.reset=function(){for(var e=0;ee)&&(this.startTime=e),this.endTime=t,this.screen=r,this.timelineController.createCaptionsTrack(this.trackName)},t.reset=function(){this.cueRanges=[]},e}(),Ft=function(e,t,r){return e.substr(r||0,t.length)===t},Kt=function(e){for(var t=5381,r=e.length;r;)t=33*t^e.charCodeAt(--r);return(t>>>0).toString()},zt={parse:function(e,t,r,i,n,s){var o,a=Object(Fe.utf8ArrayToStr)(new Uint8Array(e)).trim().replace(/\r\n|\n\r|\n|\r/g,"\n").split("\n"),c="00:00.000",u=0,d=0,f=0,h=[],p=!0,g=!1,y=new yt;y.oncue=function(e){var t=r[i],n=r.ccOffset;t&&t.new&&(void 0!==d?n=r.ccOffset=t.start:function(e,t,r){var i=e[t],n=e[i.prevCC];if(!n||!n.new&&i.new)return e.ccOffset=e.presentationOffset=i.start,void(i.new=!1);for(;n&&n.new;)e.ccOffset+=i.start-n.start,i.new=!1,n=e[(i=n).prevCC];e.presentationOffset=r}(r,i,f)),f&&(n=f-r.presentationOffset),g&&(e.startTime+=n-d,e.endTime+=n-d),e.id=Kt(e.startTime.toString())+Kt(e.endTime.toString())+Kt(e.text),e.text=decodeURIComponent(encodeURIComponent(e.text)),e.endTime>0&&h.push(e)},y.onparsingerror=function(e){o=e},y.onflush=function(){o&&s?s(o):n(h)},a.forEach((function(e){if(p){if(Ft(e,"X-TIMESTAMP-MAP=")){p=!1,g=!0,e.substr(16).split(",").forEach((function(e){Ft(e,"LOCAL:")?c=e.substr(6):Ft(e,"MPEGTS:")&&(u=parseInt(e.substr(7)))}));try{t+(9e4*r[i].start||0)<0&&(t+=8589934592),u-=t,d=function(e){var t=parseInt(e.substr(-3)),r=parseInt(e.substr(-6,2)),i=parseInt(e.substr(-9,2)),n=e.length>9?parseInt(e.substr(0,e.indexOf(":"))):0;if(!(Object(l.isFiniteNumber)(t)&&Object(l.isFiniteNumber)(r)&&Object(l.isFiniteNumber)(i)&&Object(l.isFiniteNumber)(n)))throw Error("Malformed X-TIMESTAMP-MAP: Local:"+e);return t+=1e3*r,(t+=6e4*i)+36e5*n}(c)/1e3,f=u/9e4}catch(e){g=!1,o=e}return}""===e&&(p=!1)}y.parse(e+"\n")})),y.flush()}};function Vt(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}function qt(e,t){return e&&e.label===t.name&&!(e.textTrack1||e.textTrack2)}var Gt=function(e){var t,r;function i(t){var r;if((r=e.call(this,t,d.default.MEDIA_ATTACHING,d.default.MEDIA_DETACHING,d.default.FRAG_PARSING_USERDATA,d.default.FRAG_DECRYPTED,d.default.MANIFEST_LOADING,d.default.MANIFEST_LOADED,d.default.FRAG_LOADED,d.default.INIT_PTS_FOUND)||this).media=null,r.config=void 0,r.enabled=!0,r.Cues=void 0,r.textTracks=[],r.tracks=[],r.initPTS=[],r.unparsedVttFrags=[],r.captionsTracks={},r.nonNativeCaptionsTracks={},r.captionsProperties=void 0,r.cea608Parser1=void 0,r.cea608Parser2=void 0,r.lastSn=-1,r.prevCC=-1,r.vttCCs={ccOffset:0,presentationOffset:0,0:{start:0,prevCC:-1,new:!1}},r.hls=t,r.config=t.config,r.Cues=t.config.cueHandler,r.captionsProperties={textTrack1:{label:r.config.captionsTextTrack1Label,languageCode:r.config.captionsTextTrack1LanguageCode},textTrack2:{label:r.config.captionsTextTrack2Label,languageCode:r.config.captionsTextTrack2LanguageCode},textTrack3:{label:r.config.captionsTextTrack3Label,languageCode:r.config.captionsTextTrack3LanguageCode},textTrack4:{label:r.config.captionsTextTrack4Label,languageCode:r.config.captionsTextTrack4LanguageCode}},r.config.enableCEA708Captions){var i=new Ut(Vt(r),"textTrack1"),n=new Ut(Vt(r),"textTrack2"),s=new Ut(Vt(r),"textTrack3"),o=new Ut(Vt(r),"textTrack4");r.cea608Parser1=new Nt(1,i,n),r.cea608Parser2=new Nt(3,s,o)}return r}r=e,(t=i).prototype=Object.create(r.prototype),t.prototype.constructor=t,t.__proto__=r;var n=i.prototype;return n.addCues=function(e,t,r,i,n){for(var s,o,a,c,u=!1,l=n.length;l--;){var f=n[l],h=(s=f[0],o=f[1],a=t,c=r,Math.min(o,c)-Math.max(s,a));if(h>=0&&(f[0]=Math.min(f[0],t),f[1]=Math.max(f[1],r),u=!0,h/(r-t)>.5))return}if(u||n.push([t,r]),this.config.renderTextTracksNatively)this.Cues.newCue(this.captionsTracks[e],t,r,i);else{var p=this.Cues.newCue(null,t,r,i);this.hls.trigger(d.default.CUES_PARSED,{type:"captions",cues:p,track:e})}},n.onInitPtsFound=function(e){var t=this,r=e.frag,i=e.id,n=e.initPTS,s=this.unparsedVttFrags;"main"===i&&(this.initPTS[r.cc]=n),s.length&&(this.unparsedVttFrags=[],s.forEach((function(e){t.onFragLoaded(e)})))},n.getExistingTrack=function(e){var t=this.media;if(t)for(var r=0;r=s.length||r!==n||!o||this.stopped)this._clearReloadTimer();else if(f.logger.log("subtitle track "+r+" loaded"),i.live){var a=ce(o.details,i,e.stats.trequest);f.logger.log("Reloading live subtitle playlist in "+a+"ms"),this.timer=setTimeout((function(){t._loadCurrentTrack()}),a)}else this._clearReloadTimer()},a.startLoad=function(){this.stopped=!1,this._loadCurrentTrack()},a.stopLoad=function(){this.stopped=!0,this._clearReloadTimer()},a._clearReloadTimer=function(){this.timer&&(clearTimeout(this.timer),this.timer=null)},a._loadCurrentTrack=function(){var e=this.trackId,t=this.tracks,r=this.hls,i=t[e];e<0||!i||i.details&&!i.details.live||(f.logger.log("Loading subtitle track "+e),r.trigger(d.default.SUBTITLE_TRACK_LOADING,{url:i.url,id:e}))},a._toggleTrackModes=function(e){var t=this.media,r=this.subtitleDisplay,i=this.trackId;if(t){var n=$t(t.textTracks);if(-1===e)[].slice.call(n).forEach((function(e){e.mode="disabled"}));else{var s=n[i];s&&(s.mode="disabled")}var o=n[e];o&&(o.mode=r?"showing":"hidden")}},a._setSubtitleTrackInternal=function(e){var t=this.hls,r=this.tracks;!Object(l.isFiniteNumber)(e)||e<-1||e>=r.length||(this.trackId=e,f.logger.log("Switching to subtitle track "+e),t.trigger(d.default.SUBTITLE_TRACK_SWITCH,{id:e}),this._loadCurrentTrack())},a._onTextTracksChanged=function(){if(this.media&&this.hls.config.renderTextTracksNatively){for(var e=-1,t=$t(this.media.textTracks),r=0;r=i[o].start&&s<=i[o].end){n=i[o];break}var a=t.start+t.duration;n?n.end=a:(n={start:s,end:a},i.push(n))}}},n.onMediaAttached=function(e){var t=e.media;this.media=t,t.addEventListener("seeking",this._onMediaSeeking),this.state=_e},n.onMediaDetaching=function(){var e=this;this.media&&(this.media.removeEventListener("seeking",this._onMediaSeeking),this.fragmentTracker.removeAllFragments(),this.currentTrackId=-1,this.tracks.forEach((function(t){e.tracksBuffered[t.id]=[]})),this.media=null,this.state=ve)},n.onError=function(e){var t=e.frag;t&&"subtitle"===t.type&&(this.fragCurrent&&this.fragCurrent.loader&&this.fragCurrent.loader.abort(),this.state=_e)},n.onSubtitleTracksUpdated=function(e){var t=this;f.logger.log("subtitle tracks updated"),this.tracksBuffered=[],this.tracks=e.subtitleTracks,this.tracks.forEach((function(e){t.tracksBuffered[e.id]=[]}))},n.onSubtitleTrackSwitch=function(e){if(this.currentTrackId=e.id,this.tracks&&this.tracks.length&&-1!==this.currentTrackId){var t=this.tracks[this.currentTrackId];t&&t.details&&this.setInterval(500)}else this.clearInterval()},n.onSubtitleTrackLoaded=function(e){var t=e.id,r=e.details,i=this.currentTrackId,n=this.tracks,s=n[i];t>=n.length||t!==i||!s||(r.live&&function(e,t,r){void 0===r&&(r=0);var i=-1;ae(e,t,(function(e,t,r){t.start=e.start,i=r}));var n=t.fragments;if(i<0)n.forEach((function(e){e.start+=r}));else for(var s=i+1;s0&&r&&r.key&&"AES-128"===r.method){var s=Qt.now();this.decrypter.decrypt(e.payload,r.key.buffer,r.iv.buffer,(function(e){var t=Qt.now();n.trigger(d.default.FRAG_DECRYPTED,{frag:i,payload:e,stats:{tstart:s,tdecrypt:t}})}))}},n.onLevelUpdated=function(e){var t=e.details.fragments;this.lastAVStart=t.length?t[0].start:0},n.doTick=function(){if(this.media)switch(this.state){case _e:var e=this.config,t=this.currentTrackId,r=this.fragmentTracker,i=this.media,n=this.tracks;if(!n||!n[t]||!n[t].details)break;var s,o=e.maxBufferHole,a=e.maxFragLookUpTolerance,c=Math.min(e.maxBufferLength,e.maxMaxBufferLength),u=$.bufferedInfo(this._getBuffered(),i.currentTime,o),l=u.end,h=u.len,p=n[t].details,g=p.fragments,y=g.length,m=g[y-1].start+g[y-1].duration;if(h>c)return;var b=this.fragPrevious;li)&&(this.fragCurrent.loader&&this.fragCurrent.loader.abort(),this.fragmentTracker.removeFragment(this.fragCurrent),this.fragCurrent=null,this.fragPrevious=null,this.state=_e,this.tick())}},i}(Me);(Yt=Wt||(Wt={})).WIDEVINE="com.widevine.alpha",Yt.PLAYREADY="com.microsoft.playready";var er="undefined"!=typeof window&&window.navigator&&window.navigator.requestMediaKeySystemAccess?window.navigator.requestMediaKeySystemAccess.bind(window.navigator):null;function tr(e,t){for(var r=0;r3)return void this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.KEY_SYSTEM_ERROR,details:u.ErrorDetails.KEY_SYSTEM_LICENSE_REQUEST_FAILED,fatal:!0});var n=3-this._requestLicenseFailureCount+1;f.logger.warn("Retrying license request, "+n+" attempts left"),this._requestLicense(r,i)}},a._generateLicenseRequestChallenge=function(e,t){if(e.mediaKeySystemDomain===Wt.WIDEVINE)return t;throw new Error("unsupported key-system: "+e.mediaKeySystemDomain)},a._requestLicense=function(e,t){f.logger.log("Requesting content license for key-system");var r=this._mediaKeysList[0];if(!r)return f.logger.error("Fatal error: Media is encrypted but no key-system access has been obtained yet"),void this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.KEY_SYSTEM_ERROR,details:u.ErrorDetails.KEY_SYSTEM_NO_ACCESS,fatal:!0});try{var i=this.getLicenseServerUrl(r.mediaKeySystemDomain),n=this._createLicenseXhr(i,e,t);f.logger.log("Sending license request to URL: "+i);var s=this._generateLicenseRequestChallenge(r,e);n.send(s)}catch(e){f.logger.error("Failure requesting DRM license: "+e),this.hls.trigger(d.default.ERROR,{type:u.ErrorTypes.KEY_SYSTEM_ERROR,details:u.ErrorDetails.KEY_SYSTEM_LICENSE_REQUEST_FAILED,fatal:!0})}},a.onMediaAttached=function(e){if(this._emeEnabled){var t=e.media;this._media=t,t.addEventListener("encrypted",this._onMediaEncrypted)}},a.onMediaDetached=function(){var e=this._media,t=this._mediaKeysList;e&&(e.removeEventListener("encrypted",this._onMediaEncrypted),this._media=null,this._mediaKeysList=[],Promise.all(t.map((function(e){if(e.mediaKeysSession)return e.mediaKeysSession.close().catch((function(){}))}))).then((function(){return e.setMediaKeys(null)})).catch((function(){})))},a.onManifestParsed=function(e){if(this._emeEnabled){var t=e.levels.map((function(e){return e.audioCodec})),r=e.levels.map((function(e){return e.videoCodec}));this._attemptKeySystemAccess(Wt.WIDEVINE,t,r)}},n=i,(s=[{key:"requestMediaKeySystemAccess",get:function(){if(!this._requestMediaKeySystemAccess)throw new Error("No requestMediaKeySystemAccess function configured");return this._requestMediaKeySystemAccess}}])&&tr(n.prototype,s),o&&tr(n,o),i}(g);function ir(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,i)}return r}function nr(e){for(var t=1;tt)return i;return 0}},{key:"maxAutoLevel",get:function(){var e=this.levels,t=this.autoLevelCapping;return-1===t&&e&&e.length?e.length-1:t}},{key:"nextAutoLevel",get:function(){return Math.min(Math.max(this.abrController.nextAutoLevel,this.minAutoLevel),this.maxAutoLevel)},set:function(e){this.abrController.nextAutoLevel=Math.max(this.minAutoLevel,e)}},{key:"audioTracks",get:function(){var e=this.audioTrackController;return e?e.audioTracks:[]}},{key:"audioTrack",get:function(){var e=this.audioTrackController;return e?e.audioTrack:-1},set:function(e){var t=this.audioTrackController;t&&(t.audioTrack=e)}},{key:"liveSyncPosition",get:function(){return this.streamController.liveSyncPosition}},{key:"subtitleTracks",get:function(){var e=this.subtitleTrackController;return e?e.subtitleTracks:[]}},{key:"subtitleTrack",get:function(){var e=this.subtitleTrackController;return e?e.subtitleTrack:-1},set:function(e){var t=this.subtitleTrackController;t&&(t.subtitleTrack=e)}},{key:"subtitleDisplay",get:function(){var e=this.subtitleTrackController;return!!e&&e.subtitleDisplay},set:function(e){var t=this.subtitleTrackController;t&&(t.subtitleDisplay=e)}}]),i}(J);hr.defaultConfig=void 0},"./src/polyfills/number.js":function(e,t,r){"use strict";r.r(t),r.d(t,"isFiniteNumber",(function(){return i})),r.d(t,"MAX_SAFE_INTEGER",(function(){return n}));var i=Number.isFinite||function(e){return"number"==typeof e&&isFinite(e)},n=Number.MAX_SAFE_INTEGER||9007199254740991},"./src/utils/get-self-scope.js":function(e,t,r){"use strict";function i(){return"undefined"==typeof window?self:window}r.r(t),r.d(t,"getSelfScope",(function(){return i}))},"./src/utils/logger.js":function(e,t,r){"use strict";r.r(t),r.d(t,"enableLogs",(function(){return l})),r.d(t,"logger",(function(){return d}));var i=r(/*! ./get-self-scope */"./src/utils/get-self-scope.js");function n(){}var s={trace:n,debug:n,log:n,warn:n,info:n,error:n},o=s;function a(e,t){return t="["+e+"] > "+t}var c=Object(i.getSelfScope)();function u(e){var t=c.console[e];return t?function(){for(var r=arguments.length,i=new Array(r),n=0;n1?t-1:0),i=1;i{const s="arraybuffer"===t.responseType?i:n(i);e.loaded=e.total=s.length,e.tload=Math.max(e.tfirst,performance.now());const o={url:t.url,data:s};r.onSuccess(o,e,t)}),console.error);else{var c=this.tsListProvider()[o];c&&this.cat(c).then((s=>{let o;o=i.isBuffer(s)?n(s):s,e.loaded=e.total=o.length,e.tload=Math.max(e.tfirst,performance.now());const a={url:t.url,data:o};r.onSuccess(a,e,t)}))}else{const s=this.m3u8provider();let o;o=i.isBuffer(s)?n(s):s;const a={url:t.url,data:o};r.onSuccess(a,e,t)}}}},{buffer:"etowf"}]},["fsddd"],"fsddd"); -//# sourceMappingURL=index.ed2f3c79.js.map +//# sourceMappingURL=index.6b10736e.js.map diff --git a/index.ed2f3c79.js.map b/index.6b10736e.js.map similarity index 50% rename from index.ed2f3c79.js.map rename to index.6b10736e.js.map index 3ca6087..336da81 100644 --- a/index.ed2f3c79.js.map +++ b/index.6b10736e.js.map @@ -1 +1 @@ -{"mappings":"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AgBA20B,EAAava,EAAO2H,EAAQ1P,GAEnC,MAAMnP,EADN6e,GAAU+S,EAAIziB,QAEPA,GAhFS,YAiFd+H,EAAM2H,KAAgB,IAAJ1P,EAAU,IAC5BA,GAAK,SAEAA,GAAK,KACV+H,EAAM2H,KAAgB,IAAJ1P,EAAU,IAC5BA,KAAO,EAGT,OADA+H,EAAM2H,GAAU1P,EACTnP,WAEA4xB,EAAI/C,GAIX,OAHIA,EAAI,GAAM,GACZA,IAEKn4B,KAAKkd,gBAECib,GACb,IAAI/xB,EAAI,EACJ+xB,GAAKyC,IACPzC,EAAIn4B,KAAKkd,MAAMib,EAAIyC,GACnBx0B,EAAI,IAEF+xB,GAAK,QACPA,KAAO,GACP/xB,GAAK,IAEH+xB,GAAK,MACPA,KAAO,EACP/xB,GAAK,GAEP,OAAOA,EAAI+0B,EAAQhD,GAhBAiD,CAAMjD,GAAK,GAAK,GAkBrC,MAAMgD,EAAU,CACd,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,GAGFt5B,EAAQgtB,oBAxVYtuB,GAClB,MAAMme,WAkCUne,GAChB,IAAI6F,EAAI,EACR,GAAI7F,EAAKuO,KAAM,CACb,MAAM+R,EAAItgB,EAAKuO,KAAKuC,OACpBjL,GAAK,EAAIya,EAAIqa,EAAIra,GAEnB,GAAItgB,EAAK2O,MACP,IAAK,MAAMuf,KAAQluB,EAAK2O,MAAO,CAC7B,MAAM2R,EAAIoa,EAASxM,GACnBroB,GAAK,EAAIya,EAAIqa,EAAIra,GAGrB,OAAOza,EA9CMi1B,CAAS96B,GAChBigB,EAAQ,IAAIkG,WAAWhI,GAC7B,IAAI1J,EAAI0J,EAOR,GANIne,EAAKuO,OACPkG,GAAKzU,EAAKuO,KAAKuC,OACfmP,EAAM5G,IAAIrZ,EAAKuO,KAAMkG,GACrBA,EAAI+lB,EAAava,EAAOxL,EAAGzU,EAAKuO,KAAKuC,QAAU,EAC/CmP,EAAMxL,GAAK,IAETzU,EAAK2O,MACP,IAAK,IAAInN,EAAQxB,EAAK2O,MAAMmC,OAAS,EAAGtP,GAAS,EAAGA,IAAS,CAC3D,MAAM2c,EAAOmc,EAAWt6B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F,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,kEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,sEAINxT,IAAK,CACHyR,IAAK,EACL+B,OAAQ,CACN,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,iEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,mEAEF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AAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,EAAE,EAAE,GAAG,GAAG,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,GAAG,IAAI,IAAI,EAAE,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,IAAI,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,E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","sources":["src/index.js","node_modules/ipfs-core/cjs/src/index.js","node_modules/ipfs-core/cjs/src/components/index.js","node_modules/merge-options/index.js","node_modules/is-plain-obj/index.js","node_modules/ipfs-utils/src/env.js","node_modules/process/browser.js","node_modules/is-electron/index.js","node_modules/debug/src/browser.js","node_modules/debug/src/common.js","node_modules/debug/node_modules/ms/index.js","node_modules/err-code/index.js","node_modules/ipfs-unixfs/cjs/src/index.js","node_modules/ipfs-unixfs/cjs/src/unixfs.js","node_modules/protobufjs/minimal.js","node_modules/protobufjs/src/index-minimal.js","node_modules/protobufjs/src/writer.js","node_modules/protobufjs/src/util/minimal.js","node_modules/@protobufjs/aspromise/index.js","node_modules/@protobufjs/base64/index.js","node_modules/@protobufjs/eventemitter/index.js","node_modules/@protobufjs/float/index.js","node_modules/@protobufjs/inquire/index.js","node_modules/@protobufjs/utf8/index.js","node_modules/@protobufjs/pool/index.js","node_modules/protobufjs/src/util/longbits.js","node_modules/protobufjs/src/writer_buffer.js","node_modules/protobufjs/src/reader.js","node_modules/protobufjs/src/reader_buffer.js","node_modules/protobufjs/src/rpc.js","node_modules/protobufjs/src/rpc/service.js","node_modules/protobufjs/src/roots.js","node_modules/@ipld/dag-pb/cjs/src/index.js","node_modules/multiformats/cjs/src/cid.js","node_modules/multiformats/cjs/src/varint.js","node_modules/multiformats/cjs/vendor/varint.js","node_modules/multiformats/cjs/src/hashes/digest.js","node_modules/multiformats/cjs/src/bytes.js","node_modules/multiformats/cjs/src/bases/base58.js","node_modules/multiformats/cjs/src/bases/base.js","node_modules/multiformats/cjs/vendor/base-x.js","node_modules/multiformats/cjs/src/bases/base32.js","node_modules/@ipld/dag-pb/cjs/src/pb-decode.js","node_modules/@ipld/dag-pb/cjs/src/pb-encode.js","node_modules/@ipld/dag-pb/cjs/src/util.js","node_modules/@ipld/dag-cbor/cjs/index.js","node_modules/cborg/cjs/cborg.js","node_modules/cborg/cjs/lib/encode.js","node_modules/cborg/cjs/lib/is.js","node_modules/cborg/cjs/lib/token.js","node_modules/cborg/cjs/lib/bl.js","node_modules/cborg/cjs/lib/byte-utils.js","node_modules/cborg/cjs/lib/common.js","node_modules/cborg/cjs/lib/jump.js","node_modules/cborg/cjs/lib/0uint.js","node_modules/cborg/cjs/lib/1negint.js","node_modules/cborg/cjs/lib/2bytes.js","node_modules/cborg/cjs/lib/3string.js","node_modules/cborg/cjs/lib/4array.js","node_modules/cborg/cjs/lib/5map.js","node_modules/cborg/cjs/lib/6tag.js","node_modules/cborg/cjs/lib/7float.js","node_modules/cborg/cjs/lib/decode.js","node_modules/multiformats/cjs/src/hashes/identity.js","node_modules/multiformats/cjs/src/hashes/hasher.js","node_modules/multiformats/cjs/src/basics.js","node_modules/multiformats/cjs/src/bases/identity.js","node_modules/multiformats/cjs/src/bases/base2.js","node_modules/multiformats/cjs/src/bases/base8.js","node_modules/multiformats/cjs/src/bases/base10.js","node_modules/multiformats/cjs/src/bases/base16.js","node_modules/multiformats/cjs/src/bases/base36.js","node_modules/multiformats/cjs/src/bases/base64.js","node_modules/multiformats/cjs/src/hashes/sha2-browser.js","node_modules/multiformats/cjs/src/codecs/raw.js","node_modules/multiformats/cjs/src/codecs/json.js","node_modules/multiformats/cjs/src/index.js","node_modules/ipfs-core-config/cjs/src/init-assets.browser.js","node_modules/ipfs-core/cjs/src/errors.js","node_modules/uint8arrays/cjs/src/from-string.js","node_modules/uint8arrays/cjs/src/util/bases.js","node_modules/ipfs-core/cjs/src/components/start.js","node_modules/ipfs-core/cjs/src/utils/service.js","node_modules/ipfs-core/cjs/src/utils.js","node_modules/is-ipfs/src/index.js","node_modules/multiaddr/src/index.js","node_modules/multiaddr/src/codec.js","node_modules/multiaddr/src/convert.js","node_modules/multiaddr/src/ip.js","node_modules/is-ip/index.js","node_modules/ip-regex/index.js","node_modules/uint8arrays/cjs/src/to-string.js","node_modules/multiaddr/src/protocols-table.js","node_modules/varint/index.js","node_modules/varint/encode.js","node_modules/varint/decode.js","node_modules/varint/length.js","node_modules/uint8arrays/cjs/src/concat.js","node_modules/uint8arrays/cjs/src/equals.js","node_modules/mafmt/src/index.js","node_modules/iso-url/index.js","node_modules/iso-url/src/url-browser.js","node_modules/iso-url/src/relative.js","node_modules/interface-datastore/cjs/src/key.js","node_modules/nanoid/index.browser.js","node_modules/nanoid/url-alphabet/index.js","node_modules/@parcel/transformer-js/src/esmodule-helpers.js","node_modules/ipfs-core-utils/cjs/src/with-timeout-option.js","node_modules/timeout-abort-controller/index.js","node_modules/abort-controller/browser.js","node_modules/timeout-abort-controller/node_modules/retimer/retimer.js","node_modules/timeout-abort-controller/node_modules/retimer/time-browser.js","node_modules/any-signal/index.js","node_modules/native-abort-controller/src/index.js","node_modules/parse-duration/index.mjs","node_modules/ipfs-core-utils/cjs/src/errors.js","node_modules/ipfs-core-utils/cjs/src/to-cid-and-path.js","node_modules/ipfs-core/cjs/src/components/stop.js","node_modules/ipfs-core/cjs/src/components/dns.js","node_modules/ipfs-core-config/cjs/src/dns.browser.js","node_modules/ipfs-core-config/cjs/src/utils/tlru.js","node_modules/hashlru/index.js","node_modules/p-queue/dist/index.js","node_modules/eventemitter3/index.js","node_modules/p-queue/node_modules/p-timeout/index.js","node_modules/p-finally/index.js","node_modules/p-queue/dist/priority-queue.js","node_modules/p-queue/dist/lower-bound.js","node_modules/ipfs-utils/src/http.js","node_modules/ipfs-utils/src/http/fetch.browser.js","node_modules/ipfs-utils/src/http/error.js","node_modules/ipfs-utils/src/fetch.js","node_modules/native-fetch/src/index.js","node_modules/node-fetch/browser.js","node_modules/ipfs-core/cjs/src/components/is-online.js","node_modules/ipfs-core/cjs/src/components/resolve.js","node_modules/peer-id/src/index.js","node_modules/libp2p-crypto/src/keys/index.js","node_modules/libp2p-crypto/src/keys/keys.js","node_modules/node-forge/lib/asn1.js","node_modules/node-forge/lib/forge.js","node_modules/node-forge/lib/util.js","node_modules/node-forge/lib/baseN.js","node_modules/node-forge/lib/oids.js","node_modules/node-forge/lib/pbe.js","node_modules/node-forge/lib/aes.js","node_modules/node-forge/lib/cipher.js","node_modules/node-forge/lib/cipherModes.js","node_modules/node-forge/lib/des.js","node_modules/node-forge/lib/md.js","node_modules/node-forge/lib/pbkdf2.js","node_modules/node-forge/lib/hmac.js","node_modules/node-forge/lib/pem.js","node_modules/node-forge/lib/random.js","node_modules/node-forge/lib/sha256.js","node_modules/node-forge/lib/prng.js","node_modules/node-forge/lib/rc2.js","node_modules/node-forge/lib/rsa.js","node_modules/node-forge/lib/jsbn.js","node_modules/node-forge/lib/pkcs1.js","node_modules/node-forge/lib/sha1.js","node_modules/node-forge/lib/prime.js","node_modules/libp2p-crypto/src/keys/importer.js","node_modules/libp2p-crypto/src/ciphers/aes-gcm.browser.js","node_modules/libp2p-crypto/src/webcrypto.js","node_modules/libp2p-crypto/src/keys/rsa-class.js","node_modules/node-forge/lib/sha512.js","node_modules/node-forge/lib/ed25519.js","node_modules/node-forge/lib/asn1-validator.js","node_modules/libp2p-crypto/src/keys/rsa-browser.js","node_modules/libp2p-crypto/src/random-bytes.js","node_modules/iso-random-stream/src/random.browser.js","node_modules/libp2p-crypto/src/keys/rsa-utils.js","node_modules/libp2p-crypto/src/util.js","node_modules/libp2p-crypto/src/keys/jwk2pem.js","node_modules/libp2p-crypto/src/keys/exporter.js","node_modules/libp2p-crypto/src/keys/ed25519-class.js","node_modules/libp2p-crypto/src/keys/ed25519.js","node_modules/libp2p-crypto/src/keys/secp256k1-class.js","node_modules/libp2p-crypto/src/keys/secp256k1.js","node_modules/secp256k1/elliptic.js","node_modules/secp256k1/lib/index.js","node_modules/secp256k1/lib/elliptic.js","node_modules/elliptic/lib/elliptic.js","node_modules/elliptic/package.json","node_modules/elliptic/lib/elliptic/utils.js","node_modules/elliptic/node_modules/bn.js/lib/bn.js","node_modules/minimalistic-assert/index.js","node_modules/minimalistic-crypto-utils/lib/utils.js","node_modules/brorand/index.js","node_modules/elliptic/lib/elliptic/curve/index.js","node_modules/elliptic/lib/elliptic/curve/base.js","node_modules/elliptic/lib/elliptic/curve/short.js","node_modules/inherits/inherits_browser.js","node_modules/elliptic/lib/elliptic/curve/mont.js","node_modules/elliptic/lib/elliptic/curve/edwards.js","node_modules/elliptic/lib/elliptic/curves.js","node_modules/hash.js/lib/hash.js","node_modules/hash.js/lib/hash/utils.js","node_modules/hash.js/lib/hash/common.js","node_modules/hash.js/lib/hash/sha.js","node_modules/hash.js/lib/hash/sha/1.js","node_modules/hash.js/lib/hash/sha/common.js","node_modules/hash.js/lib/hash/sha/224.js","node_modules/hash.js/lib/hash/sha/256.js","node_modules/hash.js/lib/hash/sha/384.js","node_modules/hash.js/lib/hash/sha/512.js","node_modules/hash.js/lib/hash/ripemd.js","node_modules/hash.js/lib/hash/hmac.js","node_modules/elliptic/lib/elliptic/precomputed/secp256k1.js","node_modules/elliptic/lib/elliptic/ec/index.js","node_modules/hmac-drbg/lib/hmac-drbg.js","node_modules/elliptic/lib/elliptic/ec/key.js","node_modules/elliptic/lib/elliptic/ec/signature.js","node_modules/elliptic/lib/elliptic/eddsa/index.js","node_modules/elliptic/lib/elliptic/eddsa/key.js","node_modules/elliptic/lib/elliptic/eddsa/signature.js","node_modules/libp2p-crypto/src/keys/key-stretcher.js","node_modules/libp2p-crypto/src/hmac/index-browser.js","node_modules/libp2p-crypto/src/hmac/lengths.js","node_modules/libp2p-crypto/src/keys/ephemeral-keys.js","node_modules/libp2p-crypto/src/keys/ecdh-browser.js","node_modules/libp2p-crypto/src/keys/validate-curve-type.js","node_modules/class-is/index.js","node_modules/peer-id/src/proto.js","node_modules/ipfs-core/cjs/src/components/pin/index.js","node_modules/ipfs-core/cjs/src/components/pin/add.js","node_modules/it-last/index.js","node_modules/ipfs-core/cjs/src/components/pin/add-all.js","node_modules/ipfs-core-utils/cjs/src/pins/normalise-input.js","node_modules/ipfs-repo/cjs/src/pin-types.js","node_modules/ipfs-core/cjs/src/components/pin/ls.js","node_modules/ipfs-core/cjs/src/components/pin/rm.js","node_modules/ipfs-core/cjs/src/components/pin/rm-all.js","node_modules/ipfs-core/cjs/src/components/ipns.js","node_modules/ipfs-core/cjs/src/ipns/index.js","node_modules/ipfs-core/cjs/src/ipns/publisher.js","node_modules/datastore-core/cjs/src/errors.js","node_modules/ipns/cjs/src/index.js","node_modules/timestamp-nano/timestamp.js","node_modules/libp2p-crypto/src/index.js","node_modules/libp2p-crypto/src/aes/index.js","node_modules/libp2p-crypto/src/aes/ciphers-browser.js","node_modules/libp2p-crypto/src/aes/cipher-mode.js","node_modules/libp2p-crypto/src/pbkdf2.js","node_modules/long/src/long.js","node_modules/ipns/cjs/src/pb/ipns.js","node_modules/ipns/cjs/src/utils.js","node_modules/ipns/cjs/src/errors.js","node_modules/ipfs-core/cjs/src/ipns/republisher.js","node_modules/ipfs-core/cjs/src/ipns/resolver.js","node_modules/ipfs-core/cjs/src/utils/tlru.js","node_modules/ipfs-core/cjs/src/ipns/routing/config.js","node_modules/datastore-core/cjs/src/tiered.js","node_modules/datastore-core/cjs/src/base.js","node_modules/datastore-core/cjs/src/utils.js","node_modules/it-all/index.js","node_modules/it-drain/index.js","node_modules/it-filter/index.js","node_modules/it-take/index.js","node_modules/it-pushable/index.js","node_modules/fast-fifo/index.js","node_modules/fast-fifo/fixed-size.js","node_modules/dlv/index.js","node_modules/ipfs-core/cjs/src/ipns/routing/pubsub-datastore.js","node_modules/datastore-pubsub/cjs/src/index.js","node_modules/interface-datastore/index.js","node_modules/interface-datastore/cjs/src/index.js","node_modules/datastore-core/cjs/src/index.js","node_modules/datastore-core/cjs/src/shard.js","node_modules/datastore-core/cjs/src/shard-readme.js","node_modules/datastore-core/cjs/src/memory.js","node_modules/datastore-core/cjs/src/keytransform.js","node_modules/it-map/index.js","node_modules/it-pipe/index.js","node_modules/datastore-core/cjs/src/sharding.js","node_modules/datastore-core/cjs/src/mount.js","node_modules/it-merge/index.js","node_modules/datastore-core/cjs/src/namespace.js","node_modules/datastore-pubsub/cjs/src/utils.js","node_modules/ipfs-core/cjs/src/ipns/routing/offline-datastore.js","node_modules/libp2p-record/src/index.js","node_modules/libp2p-record/src/record/index.js","node_modules/libp2p-record/src/record/record.js","node_modules/libp2p-record/src/utils.js","node_modules/libp2p-record/src/validator.js","node_modules/libp2p-record/src/validators/index.js","node_modules/libp2p-record/src/validators/public-key.js","node_modules/libp2p-record/src/selection.js","node_modules/libp2p-record/src/selectors/index.js","node_modules/libp2p-record/src/selectors/public-key.js","node_modules/ipfs-core/cjs/src/components/name/index.js","node_modules/ipfs-core/cjs/src/components/name/publish.js","node_modules/ipfs-core/cjs/src/components/name/utils.js","node_modules/ipfs-core/cjs/src/components/name/resolve.js","node_modules/is-domain-name/index.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/index.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/cancel.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/utils.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/state.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/subs.js","node_modules/ipfs-core/cjs/src/components/refs/index.js","node_modules/ipfs-core/cjs/src/components/refs/local.js","node_modules/ipfs-core/cjs/src/components/bitswap/index.js","node_modules/ipfs-core/cjs/src/components/bitswap/wantlist.js","node_modules/ipfs-core/cjs/src/components/bitswap/wantlist-for-peer.js","node_modules/ipfs-core/cjs/src/components/bitswap/unwant.js","node_modules/ipfs-core/cjs/src/components/bitswap/stat.js","node_modules/ipfs-core/cjs/src/components/bootstrap/index.js","node_modules/ipfs-core/cjs/src/components/bootstrap/add.js","node_modules/ipfs-core/cjs/src/components/bootstrap/utils.js","node_modules/ipfs-core/cjs/src/components/bootstrap/clear.js","node_modules/ipfs-core/cjs/src/components/bootstrap/list.js","node_modules/ipfs-core/cjs/src/components/bootstrap/reset.js","node_modules/ipfs-core-config/cjs/src/config.browser.js","node_modules/ipfs-core/cjs/src/components/bootstrap/rm.js","node_modules/ipfs-core/cjs/src/components/block/index.js","node_modules/ipfs-core/cjs/src/components/block/get.js","node_modules/ipfs-core/cjs/src/components/block/put.js","node_modules/ipfs-core/cjs/src/components/block/rm.js","node_modules/it-parallel/index.js","node_modules/p-defer/index.js","node_modules/events/events.js","node_modules/ipfs-core/cjs/src/components/block/utils.js","node_modules/ipfs-core/cjs/src/components/block/stat.js","node_modules/ipfs-core/cjs/src/components/root.js","node_modules/ipfs-core/cjs/src/components/add.js","node_modules/ipfs-core/cjs/src/components/add-all/index.js","node_modules/ipfs-unixfs-importer/cjs/src/index.js","node_modules/it-parallel-batch/index.js","node_modules/it-batch/index.js","node_modules/ipfs-unixfs-importer/cjs/src/options.js","node_modules/@multiformats/murmur3/cjs/index.js","node_modules/murmurhash3js-revisited/index.js","node_modules/murmurhash3js-revisited/lib/murmurHash3js.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/index.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/dir.js","node_modules/ipfs-unixfs-importer/cjs/src/utils/persist.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/index.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/flat.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/balanced.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/trickle.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/buffer-importer.js","node_modules/ipfs-unixfs-importer/cjs/src/chunker/rabin.js","node_modules/bl/BufferList.js","node_modules/@parcel/node-libs-browser/node_modules/buffer/index.js","node_modules/base64-js/index.js","node_modules/ieee754/index.js","node_modules/rabin-wasm/src/index.js","node_modules/rabin-wasm/src/rabin.js","node_modules/rabin-wasm/dist/rabin-wasm.js","node_modules/@assemblyscript/loader/index.js","node_modules/ipfs-unixfs-importer/cjs/src/chunker/fixed-size.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/validate-chunks.js","node_modules/ipfs-unixfs-importer/cjs/src/tree-builder.js","node_modules/ipfs-unixfs-importer/cjs/src/dir-flat.js","node_modules/ipfs-unixfs-importer/cjs/src/dir.js","node_modules/ipfs-unixfs-importer/cjs/src/flat-to-shard.js","node_modules/ipfs-unixfs-importer/cjs/src/dir-sharded.js","node_modules/hamt-sharding/src/index.js","node_modules/hamt-sharding/src/bucket.js","node_modules/sparse-array/index.js","node_modules/hamt-sharding/src/consumable-hash.js","node_modules/hamt-sharding/src/consumable-buffer.js","node_modules/ipfs-unixfs-importer/cjs/src/utils/to-path-components.js","node_modules/ipfs-core-utils/cjs/src/files/normalise-input.js","node_modules/ipfs-core-utils/cjs/src/files/normalise-content.js","node_modules/browser-readablestream-to-it/index.js","node_modules/blob-to-it/index.js","node_modules/it-peekable/index.js","node_modules/ipfs-core-utils/cjs/src/files/utils.js","node_modules/ipfs-core-utils/cjs/src/files/normalise.js","node_modules/ipfs-core/cjs/src/components/add-all/utils.js","node_modules/ipfs-core/cjs/src/components/cat.js","node_modules/ipfs-unixfs-exporter/cjs/src/index.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/index.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/unixfs-v1/index.js","node_modules/ipfs-unixfs-exporter/cjs/src/utils/find-cid-in-shard.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/unixfs-v1/content/file.js","node_modules/ipfs-unixfs-exporter/cjs/src/utils/extract-data-from-block.js","node_modules/ipfs-unixfs-exporter/cjs/src/utils/validate-offset-and-length.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/unixfs-v1/content/directory.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/unixfs-v1/content/hamt-sharded-directory.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/raw.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/dag-cbor.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/identity.js","node_modules/ipfs-core/cjs/src/components/get.js","node_modules/it-tar/index.js","node_modules/it-tar/extract.js","node_modules/it-tar/extract-headers.js","node_modules/it-tar/lte-reader.js","node_modules/it-reader/index.js","node_modules/it-tar/pack.js","node_modules/iso-constants/index.browser.js","node_modules/it-concat/index.js","node_modules/it-tar/pack-headers.js","node_modules/pako/index.js","node_modules/pako/lib/utils/common.js","node_modules/pako/lib/deflate.js","node_modules/pako/lib/zlib/deflate.js","node_modules/pako/lib/zlib/trees.js","node_modules/pako/lib/zlib/adler32.js","node_modules/pako/lib/zlib/crc32.js","node_modules/pako/lib/zlib/messages.js","node_modules/pako/lib/utils/strings.js","node_modules/pako/lib/zlib/zstream.js","node_modules/pako/lib/inflate.js","node_modules/pako/lib/zlib/inflate.js","node_modules/pako/lib/zlib/inffast.js","node_modules/pako/lib/zlib/inftrees.js","node_modules/pako/lib/zlib/constants.js","node_modules/pako/lib/zlib/gzheader.js","node_modules/it-to-buffer/index.js","node_modules/ipfs-core/cjs/src/components/ls.js","node_modules/ipfs-core/cjs/src/components/version.js","node_modules/ipfs-core/cjs/src/version.js","node_modules/ipfs-core/cjs/src/components/id.js","node_modules/ipfs-core/cjs/src/components/config/index.js","node_modules/ipfs-core/cjs/src/components/config/profiles.js","node_modules/just-safe-set/index.js","node_modules/ipfs-core/cjs/src/components/dag/index.js","node_modules/ipfs-core/cjs/src/components/dag/export.js","node_modules/multiformats/cjs/src/block.js","node_modules/@ipld/car/cjs/lib/writer-browser.js","node_modules/@ipld/car/cjs/lib/encoder.js","node_modules/@ipld/car/cjs/lib/iterator-channel.js","node_modules/@ipld/car/cjs/lib/decoder.js","node_modules/ipfs-core/cjs/src/components/dag/get.js","node_modules/it-first/index.js","node_modules/ipfs-core/cjs/src/components/dag/import.js","node_modules/@ipld/car/cjs/lib/iterator.js","node_modules/ipfs-core/cjs/src/components/dag/put.js","node_modules/ipfs-core/cjs/src/components/dag/resolve.js","node_modules/ipfs-core/cjs/src/preload.js","node_modules/multiaddr-to-uri/index.js","node_modules/array-shuffle/index.js","node_modules/ipfs-core-config/cjs/src/preload.browser.js","node_modules/ipfs-core/cjs/src/mfs-preload.js","node_modules/ipfs-core/cjs/src/components/files/index.js","node_modules/ipfs-core/cjs/src/components/files/utils/create-lock.js","node_modules/mortice/lib/index.js","node_modules/mortice/lib/node.js","node_modules/mortice/lib/constants.js","node_modules/mortice/lib/browser.js","node_modules/observable-webworkers/lib/index.js","node_modules/promise-timeout/index.js","node_modules/ipfs-core/cjs/src/components/files/stat.js","node_modules/ipfs-core/cjs/src/components/files/utils/to-mfs-path.js","node_modules/ipfs-core/cjs/src/components/files/utils/with-mfs-root.js","node_modules/ipfs-core/cjs/src/components/files/utils/to-path-components.js","node_modules/ipfs-core/cjs/src/components/files/chmod.js","node_modules/ipfs-core/cjs/src/components/files/utils/to-trail.js","node_modules/ipfs-core/cjs/src/components/files/utils/add-link.js","node_modules/ipfs-core/cjs/src/components/files/utils/dir-sharded.js","node_modules/ipfs-core/cjs/src/components/files/utils/persist.js","node_modules/ipfs-core/cjs/src/components/files/utils/hamt-constants.js","node_modules/ipfs-core/cjs/src/components/files/utils/hamt-utils.js","node_modules/ipfs-core/cjs/src/components/files/utils/update-tree.js","node_modules/ipfs-core/cjs/src/components/files/utils/update-mfs-root.js","node_modules/ipfs-core/cjs/src/components/files/cp.js","node_modules/ipfs-core/cjs/src/components/files/mkdir.js","node_modules/ipfs-core/cjs/src/components/files/utils/create-node.js","node_modules/ipfs-core/cjs/src/components/files/rm.js","node_modules/ipfs-core/cjs/src/components/files/utils/remove-link.js","node_modules/ipfs-core/cjs/src/components/files/flush.js","node_modules/ipfs-core/cjs/src/components/files/mv.js","node_modules/ipfs-core/cjs/src/components/files/touch.js","node_modules/ipfs-core/cjs/src/components/files/read.js","node_modules/ipfs-core/cjs/src/components/files/write.js","node_modules/ipfs-core/cjs/src/components/files/utils/to-async-iterator.js","node_modules/ipfs-core/cjs/src/components/files/ls.js","node_modules/ipfs-core/cjs/src/components/key/index.js","node_modules/ipfs-core/cjs/src/components/key/export.js","node_modules/ipfs-core/cjs/src/components/key/gen.js","node_modules/ipfs-core/cjs/src/components/key/import.js","node_modules/ipfs-core/cjs/src/components/key/info.js","node_modules/ipfs-core/cjs/src/components/key/list.js","node_modules/ipfs-core/cjs/src/components/key/rename.js","node_modules/ipfs-core/cjs/src/components/key/rm.js","node_modules/ipfs-core/cjs/src/components/object/index.js","node_modules/ipfs-core/cjs/src/components/object/data.js","node_modules/ipfs-core/cjs/src/components/object/get.js","node_modules/ipfs-core/cjs/src/components/object/links.js","node_modules/ipfs-core/cjs/src/components/object/new.js","node_modules/ipfs-core/cjs/src/components/object/put.js","node_modules/ipfs-core/cjs/src/components/object/stat.js","node_modules/ipfs-core/cjs/src/components/object/patch/index.js","node_modules/ipfs-core/cjs/src/components/object/patch/add-link.js","node_modules/ipfs-core/cjs/src/components/object/patch/append-data.js","node_modules/ipfs-core/cjs/src/components/object/patch/rm-link.js","node_modules/ipfs-core/cjs/src/components/object/patch/set-data.js","node_modules/ipfs-core/cjs/src/components/repo/index.js","node_modules/ipfs-core/cjs/src/components/repo/gc.js","node_modules/ipfs-core/cjs/src/components/repo/stat.js","node_modules/ipfs-core/cjs/src/components/repo/version.js","node_modules/ipfs-repo/cjs/src/constants.js","node_modules/ipfs-core/cjs/src/components/stats/index.js","node_modules/ipfs-core/cjs/src/components/stats/bw.js","node_modules/ipfs-core/cjs/src/components/storage.js","node_modules/ipfs-core-config/cjs/src/repo.browser.js","node_modules/ipfs-repo/cjs/src/index.js","node_modules/just-safe-get/index.js","node_modules/ipfs-repo-migrations/cjs/src/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-8/index.js","node_modules/it-length/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-9/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-9/pin-set.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-9/pin.js","node_modules/fnv1a/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-9/utils.js","node_modules/uint8arrays/cjs/src/compare.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-10/index.js","node_modules/ipfs-repo-migrations/cjs/src/utils.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-11/index.js","node_modules/ipfs-repo-migrations/cjs/src/repo/version.js","node_modules/ipfs-repo-migrations/cjs/src/repo/init.js","node_modules/ipfs-repo-migrations/cjs/src/errors.js","node_modules/bytes/index.js","node_modules/ipfs-repo/cjs/src/version.js","node_modules/ipfs-repo/cjs/src/utils/level.js","node_modules/ipfs-repo/cjs/src/errors.js","node_modules/ipfs-repo/cjs/src/config.js","node_modules/ipfs-repo/cjs/src/spec.js","node_modules/sort-keys/index.js","node_modules/ipfs-repo/cjs/src/api-addr.js","node_modules/ipfs-repo/cjs/src/idstore.js","node_modules/ipfs-repo/cjs/src/default-options.js","node_modules/ipfs-repo/cjs/src/locks/memory.js","node_modules/ipfs-repo/cjs/src/default-datastore.js","node_modules/ipfs-repo/cjs/src/pin-manager.js","node_modules/ipfs-repo/cjs/src/utils/blockstore.js","node_modules/ipfs-repo/cjs/src/utils/walk-dag.js","node_modules/ipfs-repo/cjs/src/pinned-blockstore.js","node_modules/ipfs-repo/cjs/src/gc.js","node_modules/datastore-level/cjs/src/index.js","node_modules/it-sort/index.js","node_modules/level/browser.js","node_modules/level-packager/level-packager.js","node_modules/levelup/lib/levelup.js","node_modules/util/util.js","node_modules/util/support/types.js","node_modules/is-arguments/index.js","node_modules/has-tostringtag/shams.js","node_modules/has-symbols/shams.js","node_modules/call-bind/callBound.js","node_modules/get-intrinsic/index.js","node_modules/has-symbols/index.js","node_modules/function-bind/index.js","node_modules/function-bind/implementation.js","node_modules/has/src/index.js","node_modules/call-bind/index.js","node_modules/is-generator-function/index.js","node_modules/which-typed-array/index.js","node_modules/foreach/index.js","node_modules/available-typed-arrays/index.js","node_modules/es-abstract/helpers/getOwnPropertyDescriptor.js","node_modules/is-typed-array/index.js","node_modules/util/support/isBufferBrowser.js","node_modules/deferred-leveldown/deferred-leveldown.js","node_modules/abstract-leveldown/index.js","node_modules/abstract-leveldown/abstract-leveldown.js","node_modules/level-supports/index.js","node_modules/is-buffer/index.js","node_modules/catering/index.js","node_modules/queue-tick/queue-microtask.js","node_modules/abstract-leveldown/abstract-iterator.js","node_modules/abstract-leveldown/next-tick-browser.js","node_modules/queue-microtask/index.js","node_modules/abstract-leveldown/abstract-chained-batch.js","node_modules/abstract-leveldown/lib/common.js","node_modules/deferred-leveldown/deferred-iterator.js","node_modules/deferred-leveldown/util.js","node_modules/deferred-leveldown/deferred-chained-batch.js","node_modules/level-iterator-stream/index.js","node_modules/readable-stream/readable-browser.js","node_modules/readable-stream/lib/_stream_readable.js","node_modules/readable-stream/lib/internal/streams/stream-browser.js","node_modules/readable-stream/lib/internal/streams/buffer_list.js","node_modules/readable-stream/lib/internal/streams/destroy.js","node_modules/readable-stream/lib/internal/streams/state.js","node_modules/readable-stream/errors-browser.js","node_modules/readable-stream/lib/_stream_duplex.js","node_modules/readable-stream/lib/_stream_writable.js","node_modules/util-deprecate/browser.js","node_modules/string_decoder/lib/string_decoder.js","node_modules/string_decoder/node_modules/safe-buffer/index.js","node_modules/readable-stream/lib/internal/streams/async_iterator.js","node_modules/readable-stream/lib/internal/streams/end-of-stream.js","node_modules/readable-stream/lib/internal/streams/from-browser.js","node_modules/readable-stream/lib/_stream_transform.js","node_modules/readable-stream/lib/_stream_passthrough.js","node_modules/readable-stream/lib/internal/streams/pipeline.js","node_modules/levelup/lib/batch.js","node_modules/level-errors/errors.js","node_modules/levelup/lib/common.js","node_modules/levelup/lib/next-tick-browser.js","node_modules/encoding-down/index.js","node_modules/level-codec/index.js","node_modules/level-codec/lib/encodings.js","node_modules/level-js/index.js","node_modules/run-parallel-limit/index.js","node_modules/level-js/iterator.js","node_modules/level-js/util/key-range.js","node_modules/ltgt/index.js","node_modules/level-js/util/deserialize.js","node_modules/level-js/util/serialize.js","node_modules/level-js/util/support.js","node_modules/level-js/util/clear.js","node_modules/blockstore-datastore-adapter/cjs/src/index.js","node_modules/blockstore-core/cjs/src/base.js","node_modules/ipfs-core/cjs/src/components/libp2p.js","node_modules/ipfs-core-config/cjs/src/libp2p-pubsub-routers.browser.js","node_modules/libp2p-gossipsub/src/index.js","node_modules/libp2p-interfaces/src/pubsub/index.js","node_modules/libp2p-interfaces/src/topology/multicodec-topology.js","node_modules/libp2p-interfaces/src/topology/index.js","node_modules/libp2p-interfaces/src/pubsub/errors.js","node_modules/libp2p-interfaces/src/pubsub/message/rpc.js","node_modules/libp2p-interfaces/src/pubsub/peer-streams.js","node_modules/it-length-prefixed/src/index.js","node_modules/it-length-prefixed/src/encode.js","node_modules/it-length-prefixed/src/varint-encode.js","node_modules/it-length-prefixed/src/decode.js","node_modules/it-length-prefixed/src/varint-decode.js","node_modules/it-length-prefixed/src/int32BE-encode.js","node_modules/it-length-prefixed/src/int32BE-decode.js","node_modules/abortable-iterator/index.js","node_modules/get-iterator/index.js","node_modules/abortable-iterator/AbortError.js","node_modules/libp2p-interfaces/src/pubsub/signature-policy.js","node_modules/libp2p-interfaces/src/pubsub/utils.js","node_modules/libp2p-interfaces/src/pubsub/message/sign.js","node_modules/libp2p-gossipsub/src/message-cache.js","node_modules/libp2p-gossipsub/src/utils/index.js","node_modules/libp2p-gossipsub/src/utils/create-gossip-rpc.js","node_modules/libp2p-gossipsub/src/utils/shuffle.js","node_modules/libp2p-gossipsub/src/utils/has-gossip-protocol.js","node_modules/libp2p-gossipsub/src/constants.js","node_modules/libp2p-gossipsub/src/utils/messageIdToString.js","node_modules/libp2p-gossipsub/src/message/rpc.js","node_modules/libp2p-gossipsub/src/heartbeat.js","node_modules/libp2p-gossipsub/src/get-gossip-peers.js","node_modules/libp2p-gossipsub/src/score/index.js","node_modules/libp2p-gossipsub/src/score/peer-score-params.js","node_modules/libp2p-gossipsub/src/score/constants.js","node_modules/libp2p-gossipsub/src/score/peer-score-thresholds.js","node_modules/libp2p-gossipsub/src/score/peer-score.js","node_modules/libp2p-gossipsub/src/score/peer-stats.js","node_modules/libp2p-gossipsub/src/score/compute-score.js","node_modules/libp2p-gossipsub/src/score/message-deliveries.js","node_modules/denque/index.js","node_modules/libp2p-gossipsub/src/tracer.js","node_modules/time-cache/src/index.js","node_modules/lodash.throttle/index.js","node_modules/libp2p/src/record/envelope/index.js","node_modules/libp2p/src/errors.js","node_modules/libp2p/src/record/envelope/envelope.js","node_modules/libp2p-delegated-peer-routing/src/index.js","node_modules/libp2p-delegated-content-routing/src/index.js","node_modules/ipfs-http-client/cjs/src/index.js","node_modules/ipfs-core-utils/cjs/src/multibases.js","node_modules/ipfs-core-utils/cjs/src/multicodecs.js","node_modules/ipfs-core-utils/cjs/src/multihashes.js","node_modules/ipfs-http-client/cjs/src/bitswap/index.js","node_modules/ipfs-http-client/cjs/src/bitswap/wantlist.js","node_modules/ipfs-http-client/cjs/src/lib/configure.js","node_modules/ipfs-http-client/cjs/src/lib/core.js","node_modules/ipfs-core-utils/cjs/src/to-url-string.js","node_modules/ipfs-core-utils/cjs/src/agent.browser.js","node_modules/ipfs-http-client/cjs/src/lib/to-url-search-params.js","node_modules/ipfs-http-client/cjs/src/lib/mode-to-string.js","node_modules/ipfs-http-client/cjs/src/lib/parse-mtime.js","node_modules/ipfs-http-client/cjs/src/bitswap/wantlist-for-peer.js","node_modules/ipfs-http-client/cjs/src/bitswap/stat.js","node_modules/ipfs-http-client/cjs/src/bitswap/unwant.js","node_modules/ipfs-http-client/cjs/src/block/index.js","node_modules/ipfs-http-client/cjs/src/block/get.js","node_modules/ipfs-http-client/cjs/src/block/put.js","node_modules/ipfs-core-utils/cjs/src/multipart-request.browser.js","node_modules/ipfs-core-utils/cjs/src/files/normalise-input.browser.js","node_modules/ipfs-core-utils/cjs/src/files/normalise-content.browser.js","node_modules/ipfs-core-utils/cjs/src/mode-to-string.js","node_modules/ipfs-http-client/cjs/src/lib/abort-signal.js","node_modules/ipfs-http-client/cjs/src/block/rm.js","node_modules/ipfs-http-client/cjs/src/block/stat.js","node_modules/ipfs-http-client/cjs/src/bootstrap/index.js","node_modules/ipfs-http-client/cjs/src/bootstrap/add.js","node_modules/ipfs-http-client/cjs/src/bootstrap/clear.js","node_modules/ipfs-http-client/cjs/src/bootstrap/list.js","node_modules/ipfs-http-client/cjs/src/bootstrap/reset.js","node_modules/ipfs-http-client/cjs/src/bootstrap/rm.js","node_modules/ipfs-http-client/cjs/src/config/index.js","node_modules/ipfs-http-client/cjs/src/config/profiles/index.js","node_modules/ipfs-http-client/cjs/src/config/profiles/apply.js","node_modules/ipfs-http-client/cjs/src/config/profiles/list.js","node_modules/ipfs-http-client/cjs/src/lib/object-to-camel.js","node_modules/ipfs-http-client/cjs/src/config/get.js","node_modules/ipfs-http-client/cjs/src/config/get-all.js","node_modules/ipfs-http-client/cjs/src/config/replace.js","node_modules/ipfs-http-client/cjs/src/config/set.js","node_modules/ipfs-http-client/cjs/src/dag/index.js","node_modules/ipfs-http-client/cjs/src/dag/export.js","node_modules/ipfs-http-client/cjs/src/dag/get.js","node_modules/ipfs-http-client/cjs/src/lib/resolve.js","node_modules/ipfs-http-client/cjs/src/dag/import.js","node_modules/ipfs-http-client/cjs/src/dag/put.js","node_modules/ipfs-http-client/cjs/src/dag/resolve.js","node_modules/ipfs-http-client/cjs/src/dht/index.js","node_modules/ipfs-http-client/cjs/src/dht/find-peer.js","node_modules/ipfs-http-client/cjs/src/dht/response-types.js","node_modules/ipfs-http-client/cjs/src/dht/find-provs.js","node_modules/ipfs-http-client/cjs/src/dht/get.js","node_modules/ipfs-http-client/cjs/src/dht/provide.js","node_modules/ipfs-http-client/cjs/src/dht/put.js","node_modules/ipfs-http-client/cjs/src/dht/query.js","node_modules/ipfs-http-client/cjs/src/diag/index.js","node_modules/ipfs-http-client/cjs/src/diag/cmds.js","node_modules/ipfs-http-client/cjs/src/diag/net.js","node_modules/ipfs-http-client/cjs/src/diag/sys.js","node_modules/ipfs-http-client/cjs/src/files/index.js","node_modules/ipfs-http-client/cjs/src/files/chmod.js","node_modules/ipfs-http-client/cjs/src/files/cp.js","node_modules/ipfs-http-client/cjs/src/files/flush.js","node_modules/ipfs-http-client/cjs/src/files/ls.js","node_modules/ipfs-http-client/cjs/src/lib/object-to-camel-with-metadata.js","node_modules/ipfs-http-client/cjs/src/files/mkdir.js","node_modules/ipfs-http-client/cjs/src/files/mv.js","node_modules/ipfs-http-client/cjs/src/files/read.js","node_modules/stream-to-it/source.js","node_modules/ipfs-http-client/cjs/src/files/rm.js","node_modules/ipfs-http-client/cjs/src/files/stat.js","node_modules/ipfs-http-client/cjs/src/files/touch.js","node_modules/ipfs-http-client/cjs/src/files/write.js","node_modules/ipfs-http-client/cjs/src/key/index.js","node_modules/ipfs-http-client/cjs/src/key/export.js","node_modules/ipfs-http-client/cjs/src/key/gen.js","node_modules/ipfs-http-client/cjs/src/key/import.js","node_modules/ipfs-http-client/cjs/src/key/info.js","node_modules/ipfs-http-client/cjs/src/key/list.js","node_modules/ipfs-http-client/cjs/src/key/rename.js","node_modules/ipfs-http-client/cjs/src/key/rm.js","node_modules/ipfs-http-client/cjs/src/log/index.js","node_modules/ipfs-http-client/cjs/src/log/level.js","node_modules/ipfs-http-client/cjs/src/log/ls.js","node_modules/ipfs-http-client/cjs/src/log/tail.js","node_modules/ipfs-http-client/cjs/src/name/index.js","node_modules/ipfs-http-client/cjs/src/name/publish.js","node_modules/ipfs-http-client/cjs/src/name/resolve.js","node_modules/ipfs-http-client/cjs/src/name/pubsub/index.js","node_modules/ipfs-http-client/cjs/src/name/pubsub/cancel.js","node_modules/ipfs-http-client/cjs/src/name/pubsub/state.js","node_modules/ipfs-http-client/cjs/src/name/pubsub/subs.js","node_modules/ipfs-http-client/cjs/src/object/index.js","node_modules/ipfs-http-client/cjs/src/object/data.js","node_modules/ipfs-http-client/cjs/src/object/get.js","node_modules/ipfs-http-client/cjs/src/object/links.js","node_modules/ipfs-http-client/cjs/src/object/new.js","node_modules/ipfs-http-client/cjs/src/object/put.js","node_modules/ipfs-http-client/cjs/src/object/stat.js","node_modules/ipfs-http-client/cjs/src/object/patch/index.js","node_modules/ipfs-http-client/cjs/src/object/patch/add-link.js","node_modules/ipfs-http-client/cjs/src/object/patch/append-data.js","node_modules/ipfs-http-client/cjs/src/object/patch/rm-link.js","node_modules/ipfs-http-client/cjs/src/object/patch/set-data.js","node_modules/ipfs-http-client/cjs/src/pin/index.js","node_modules/ipfs-http-client/cjs/src/pin/add-all.js","node_modules/ipfs-http-client/cjs/src/pin/add.js","node_modules/ipfs-http-client/cjs/src/pin/ls.js","node_modules/ipfs-http-client/cjs/src/pin/rm-all.js","node_modules/ipfs-http-client/cjs/src/pin/rm.js","node_modules/ipfs-http-client/cjs/src/pin/remote/index.js","node_modules/ipfs-http-client/cjs/src/pin/remote/add.js","node_modules/ipfs-http-client/cjs/src/pin/remote/utils.js","node_modules/ipfs-http-client/cjs/src/pin/remote/ls.js","node_modules/ipfs-http-client/cjs/src/pin/remote/rm.js","node_modules/ipfs-http-client/cjs/src/pin/remote/rm-all.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/index.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/add.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/utils.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/ls.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/rm.js","node_modules/ipfs-http-client/cjs/src/pubsub/index.js","node_modules/ipfs-http-client/cjs/src/pubsub/ls.js","node_modules/ipfs-http-client/cjs/src/pubsub/peers.js","node_modules/ipfs-http-client/cjs/src/pubsub/publish.js","node_modules/ipfs-http-client/cjs/src/pubsub/subscribe.js","node_modules/ipfs-http-client/cjs/src/pubsub/unsubscribe.js","node_modules/ipfs-http-client/cjs/src/pubsub/subscription-tracker.js","node_modules/ipfs-http-client/cjs/src/refs/index.js","node_modules/ipfs-http-client/cjs/src/refs/local.js","node_modules/ipfs-http-client/cjs/src/repo/index.js","node_modules/ipfs-http-client/cjs/src/repo/gc.js","node_modules/ipfs-http-client/cjs/src/repo/stat.js","node_modules/ipfs-http-client/cjs/src/repo/version.js","node_modules/ipfs-http-client/cjs/src/stats/index.js","node_modules/ipfs-http-client/cjs/src/stats/bw.js","node_modules/ipfs-http-client/cjs/src/swarm/index.js","node_modules/ipfs-http-client/cjs/src/swarm/addrs.js","node_modules/ipfs-http-client/cjs/src/swarm/connect.js","node_modules/ipfs-http-client/cjs/src/swarm/disconnect.js","node_modules/ipfs-http-client/cjs/src/swarm/local-addrs.js","node_modules/ipfs-http-client/cjs/src/swarm/peers.js","node_modules/ipfs-http-client/cjs/src/add.js","node_modules/ipfs-http-client/cjs/src/add-all.js","node_modules/ipfs-http-client/cjs/src/cat.js","node_modules/ipfs-http-client/cjs/src/commands.js","node_modules/ipfs-http-client/cjs/src/dns.js","node_modules/ipfs-http-client/cjs/src/get-endpoint-config.js","node_modules/ipfs-http-client/cjs/src/get.js","node_modules/ipfs-http-client/cjs/src/id.js","node_modules/ipfs-http-client/cjs/src/is-online.js","node_modules/ipfs-http-client/cjs/src/ls.js","node_modules/ipfs-http-client/cjs/src/mount.js","node_modules/ipfs-http-client/cjs/src/ping.js","node_modules/ipfs-http-client/cjs/src/resolve.js","node_modules/ipfs-http-client/cjs/src/start.js","node_modules/ipfs-http-client/cjs/src/stop.js","node_modules/ipfs-http-client/cjs/src/version.js","node_modules/ipfs-utils/src/files/url-source.js","node_modules/ipfs-core-config/cjs/src/libp2p.browser.js","node_modules/libp2p-websockets/src/index.js","node_modules/it-ws/client.js","node_modules/it-ws/web-socket.js","node_modules/it-ws/duplex.js","node_modules/it-ws/source.js","node_modules/event-iterator/lib/dom.js","node_modules/event-iterator/lib/event-iterator.js","node_modules/it-ws/sink.js","node_modules/it-ws/ready.js","node_modules/it-ws/ws-url.js","node_modules/libp2p-websockets/src/listener.browser.js","node_modules/libp2p-websockets/src/socket-to-conn.js","node_modules/libp2p-websockets/src/constants.js","node_modules/libp2p-utils/src/ip-port-to-multiaddr.js","node_modules/ip-address/ip-address.ts","node_modules/ip-address/lib/ipv4.ts","node_modules/ip-address/lib/common.ts","node_modules/ip-address/lib/v4/constants.ts","node_modules/ip-address/lib/address-error.ts","node_modules/jsbn/index.js","node_modules/sprintf-js/src/sprintf.js","node_modules/ip-address/lib/ipv6.ts","node_modules/ip-address/lib/v6/constants.ts","node_modules/ip-address/lib/v6/helpers.ts","node_modules/ip-address/lib/v6/regular-expressions.ts","node_modules/p-timeout/index.js","node_modules/libp2p-websockets/src/filters.js","node_modules/libp2p-webrtc-star/src/index.js","node_modules/libp2p-webrtc-peer/index.js","node_modules/get-browser-rtc/index.js","node_modules/randombytes/browser.js","node_modules/safe-buffer/index.js","node_modules/libp2p-webrtc-peer/node_modules/err-code/index.js","node_modules/ipfs-utils/src/supports.js","node_modules/libp2p-webrtc-star/src/constants.js","node_modules/libp2p-webrtc-star/src/listener.js","node_modules/socket.io-client/build/esm/index.js","node_modules/socket.io-client/build/esm/url.js","node_modules/parseuri/index.js","node_modules/socket.io-client/build/esm/manager.js","node_modules/engine.io-client/build/esm/index.js","node_modules/engine.io-client/build/esm/socket.js","node_modules/engine.io-client/build/esm/transports/index.js","node_modules/engine.io-client/build/esm/transports/polling-xhr.js","node_modules/engine.io-client/build/esm/transports/xmlhttprequest.browser.js","node_modules/has-cors/index.js","node_modules/engine.io-client/build/esm/globalThis.browser.js","node_modules/engine.io-client/build/esm/util.js","node_modules/@socket.io/component-emitter/index.js","node_modules/engine.io-client/build/esm/transports/polling.js","node_modules/engine.io-client/build/esm/transport.js","node_modules/engine.io-parser/build/esm/index.js","node_modules/engine.io-parser/build/esm/encodePacket.browser.js","node_modules/engine.io-parser/build/esm/commons.js","node_modules/engine.io-parser/build/esm/decodePacket.browser.js","node_modules/src/index.ts","node_modules/yeast/index.js","node_modules/parseqs/index.js","node_modules/engine.io-client/build/esm/transports/websocket.js","node_modules/engine.io-client/build/esm/transports/websocket-constructor.browser.js","node_modules/socket.io-client/build/esm/socket.js","node_modules/socket.io-parser/build/esm/index.js","node_modules/socket.io-parser/build/esm/binary.js","node_modules/socket.io-parser/build/esm/is-binary.js","node_modules/socket.io-client/build/esm/on.js","node_modules/backo2/index.js","node_modules/libp2p-webrtc-star/src/socket-to-conn.js","node_modules/stream-to-it/index.js","node_modules/stream-to-it/sink.js","node_modules/stream-to-it/transform.js","node_modules/stream-to-it/duplex.js","node_modules/libp2p-webrtc-star/src/utils.js","node_modules/libp2p-mplex/src/index.js","node_modules/libp2p-mplex/src/mplex.js","node_modules/libp2p-mplex/src/coder/index.js","node_modules/libp2p-mplex/src/coder/encode.browser.js","node_modules/libp2p-mplex/src/coder/decode.js","node_modules/libp2p-mplex/src/restrict-size.js","node_modules/libp2p-mplex/src/message-types.js","node_modules/libp2p-mplex/src/stream.js","node_modules/@chainsafe/libp2p-noise/src/index.ts","node_modules/@chainsafe/libp2p-noise/src/noise.ts","node_modules/@stablelib/x25519/x25519.ts","node_modules/@stablelib/random/random.ts","node_modules/@stablelib/random/source/system.ts","node_modules/@stablelib/random/source/browser.ts","node_modules/@stablelib/random/source/node.ts","node_modules/@stablelib/wipe/wipe.ts","node_modules/@stablelib/binary/binary.ts","node_modules/@stablelib/int/int.ts","node_modules/it-pb-rpc/src/index.js","node_modules/it-handshake/src/index.js","node_modules/it-pair/duplex.js","node_modules/it-pair/index.js","node_modules/it-buffer/index.js","node_modules/@chainsafe/libp2p-noise/src/handshake-xx.ts","node_modules/@chainsafe/libp2p-noise/src/handshakes/xx.ts","node_modules/@chainsafe/libp2p-noise/src/utils.ts","node_modules/@stablelib/hkdf/hkdf.ts","node_modules/@stablelib/hmac/hmac.ts","node_modules/@stablelib/hash/hash.ts","node_modules/@stablelib/constant-time/constant-time.ts","node_modules/@stablelib/sha256/sha256.ts","node_modules/@chainsafe/libp2p-noise/src/proto/payload.js","node_modules/@chainsafe/libp2p-noise/src/handshakes/abstract-handshake.ts","node_modules/@stablelib/chacha20poly1305/chacha20poly1305.ts","node_modules/@stablelib/chacha/chacha.ts","node_modules/@stablelib/poly1305/poly1305.ts","node_modules/@chainsafe/libp2p-noise/src/logger.ts","node_modules/@chainsafe/libp2p-noise/src/constants.ts","node_modules/@chainsafe/libp2p-noise/src/encoder.ts","node_modules/@chainsafe/libp2p-noise/src/handshake-ik.ts","node_modules/@chainsafe/libp2p-noise/src/handshakes/ik.ts","node_modules/@chainsafe/libp2p-noise/src/errors.ts","node_modules/@chainsafe/libp2p-noise/src/handshake-xx-fallback.ts","node_modules/@chainsafe/libp2p-noise/src/crypto.ts","node_modules/@chainsafe/libp2p-noise/src/keycache.ts","node_modules/libp2p-kad-dht/src/index.js","node_modules/libp2p-kad-dht/src/routing-table/index.js","node_modules/k-bucket/index.js","node_modules/uint8arrays/cjs/src/xor.js","node_modules/libp2p-kad-dht/src/routing-table/generated-prefix-list-browser.json","node_modules/libp2p-kad-dht/src/utils.js","node_modules/p-map/index.js","node_modules/aggregate-error/index.js","node_modules/indent-string/index.js","node_modules/clean-stack/index.js","node_modules/libp2p-kad-dht/src/constants.js","node_modules/libp2p-kad-dht/src/network.js","node_modules/streaming-iterables/dist/index.mjs","node_modules/libp2p-kad-dht/src/rpc/index.js","node_modules/libp2p-kad-dht/src/message/index.js","node_modules/libp2p-kad-dht/src/message/dht.js","node_modules/libp2p-kad-dht/src/rpc/handlers/index.js","node_modules/libp2p-kad-dht/src/rpc/handlers/get-value.js","node_modules/libp2p-kad-dht/src/rpc/handlers/put-value.js","node_modules/libp2p-kad-dht/src/rpc/handlers/find-node.js","node_modules/libp2p-kad-dht/src/rpc/handlers/add-provider.js","node_modules/libp2p-kad-dht/src/rpc/handlers/get-providers.js","node_modules/libp2p-kad-dht/src/rpc/handlers/ping.js","node_modules/libp2p-kad-dht/src/content-fetching/index.js","node_modules/libp2p-kad-dht/src/query/index.js","node_modules/libp2p-kad-dht/src/query/run.js","node_modules/libp2p-kad-dht/src/peer-list/peer-distance-list.js","node_modules/libp2p-kad-dht/src/query/path.js","node_modules/libp2p-kad-dht/src/peer-list/peer-queue.js","node_modules/heap/index.js","node_modules/heap/lib/heap.js","node_modules/libp2p-kad-dht/src/query/worker-queue.js","node_modules/libp2p-kad-dht/src/content-routing/index.js","node_modules/libp2p-kad-dht/src/peer-list/limited-peer-list.js","node_modules/libp2p-kad-dht/src/peer-list/index.js","node_modules/libp2p-kad-dht/src/peer-routing/index.js","node_modules/libp2p-kad-dht/src/providers.js","node_modules/libp2p-kad-dht/src/query-manager.js","node_modules/ipfs-core-config/cjs/src/utils/ipns.js","node_modules/libp2p-bootstrap/src/index.js","node_modules/libp2p/src/index.js","node_modules/libp2p/src/peer-routing.js","node_modules/libp2p/src/content-routing/utils.js","node_modules/set-delayed-interval/src/index.js","node_modules/libp2p/src/content-routing/index.js","node_modules/libp2p/src/get-peer.js","node_modules/libp2p/src/config.js","node_modules/multiaddr/src/resolvers/index.js","node_modules/multiaddr/src/resolvers/dns.browser.js","node_modules/dns-over-http-resolver/src/index.js","node_modules/receptacle/index.js","node_modules/ms/index.js","node_modules/dns-over-http-resolver/src/utils.js","node_modules/libp2p/src/constants.js","node_modules/libp2p/src/identify/consts.js","node_modules/libp2p/package.json","node_modules/libp2p/src/circuit/constants.js","node_modules/libp2p-utils/src/address-sort.js","node_modules/libp2p-utils/src/multiaddr/is-private.js","node_modules/private-ip/index.js","node_modules/private-ip/lib/index.js","node_modules/netmask/lib/netmask.js","node_modules/ipaddr.js/lib/ipaddr.js","node_modules/libp2p/src/transport-manager.js","node_modules/p-settle/index.js","node_modules/p-reflect/index.js","node_modules/p-limit/index.js","node_modules/p-try/index.js","node_modules/libp2p/src/record/utils.js","node_modules/libp2p/src/record/peer-record/index.js","node_modules/libp2p-utils/src/array-equals.js","node_modules/libp2p/src/record/peer-record/peer-record.js","node_modules/libp2p/src/record/peer-record/consts.js","node_modules/libp2p/src/address-manager/index.js","node_modules/libp2p/src/connection-manager/index.js","node_modules/libp2p/src/connection-manager/latency-monitor.js","node_modules/libp2p/src/connection-manager/visibility-change-emitter.js","node_modules/retimer/retimer.js","node_modules/retimer/time-browser.js","node_modules/libp2p/src/circuit/transport.js","node_modules/libp2p/src/circuit/protocol/index.js","node_modules/libp2p-utils/src/stream-to-ma-conn.js","node_modules/libp2p/src/circuit/multicodec.js","node_modules/libp2p/src/circuit/listener.js","node_modules/libp2p/src/circuit/circuit/hop.js","node_modules/libp2p/src/circuit/circuit/utils.js","node_modules/libp2p/src/circuit/circuit/stream-handler.js","node_modules/libp2p/src/circuit/circuit/stop.js","node_modules/libp2p/src/circuit/index.js","node_modules/libp2p/src/circuit/auto-relay.js","node_modules/libp2p/src/circuit/utils.js","node_modules/libp2p/src/dialer/index.js","node_modules/libp2p/src/dialer/dial-request.js","node_modules/p-fifo/index.js","node_modules/p-any/index.js","node_modules/p-some/index.js","node_modules/p-cancelable/index.js","node_modules/libp2p/src/keychain/index.js","node_modules/sanitize-filename/index.js","node_modules/truncate-utf8-bytes/browser.js","node_modules/truncate-utf8-bytes/lib/truncate.js","node_modules/utf8-byte-length/browser.js","node_modules/libp2p/src/keychain/cms.js","node_modules/node-forge/lib/pkcs7.js","node_modules/node-forge/lib/pkcs7asn1.js","node_modules/node-forge/lib/x509.js","node_modules/node-forge/lib/mgf.js","node_modules/node-forge/lib/mgf1.js","node_modules/node-forge/lib/pss.js","node_modules/libp2p/src/keychain/util.js","node_modules/libp2p/src/metrics/index.js","node_modules/libp2p/src/metrics/old-peers.js","node_modules/libp2p/src/metrics/stats.js","node_modules/bignumber.js/bignumber.js","node_modules/@vascosantos/moving-average/index.js","node_modules/libp2p/src/upgrader.js","node_modules/multistream-select/src/index.js","node_modules/multistream-select/src/select.js","node_modules/multistream-select/src/multistream.js","node_modules/multistream-select/src/handle.js","node_modules/multistream-select/src/constants.js","node_modules/multistream-select/src/ls.js","node_modules/libp2p-interfaces/src/connection/index.js","node_modules/libp2p-interfaces/src/connection/connection.js","node_modules/libp2p-interfaces/src/connection/status.js","node_modules/mutable-proxy/build/index.js","node_modules/libp2p/src/peer-store/index.js","node_modules/libp2p/src/peer-store/address-book.js","node_modules/libp2p/src/peer-store/book.js","node_modules/libp2p/src/peer-store/key-book.js","node_modules/libp2p/src/peer-store/metadata-book.js","node_modules/libp2p/src/peer-store/proto-book.js","node_modules/libp2p/src/pubsub-adapter.js","node_modules/libp2p/src/peer-store/persistent/index.js","node_modules/libp2p/src/peer-store/persistent/consts.js","node_modules/libp2p/src/peer-store/persistent/pb/address-book.js","node_modules/libp2p/src/peer-store/persistent/pb/proto-book.js","node_modules/libp2p/src/registrar.js","node_modules/libp2p/src/ping/index.js","node_modules/libp2p/src/ping/constants.js","node_modules/libp2p/src/identify/index.js","node_modules/libp2p/src/identify/message.js","node_modules/libp2p/src/nat-manager.js","node_modules/es6-promisify/dist/promisify.mjs","node_modules/wherearewe/src/index.js","node_modules/p-retry/index.js","node_modules/retry/index.js","node_modules/retry/lib/retry.js","node_modules/retry/lib/retry_operation.js","node_modules/libp2p-utils/src/multiaddr/is-loopback.js","node_modules/is-loopback-addr/index.js","node_modules/ipfs-core/cjs/src/components/network.js","node_modules/ipfs-bitswap/cjs/src/index.js","node_modules/ipfs-bitswap/cjs/src/bitswap.js","node_modules/ipfs-bitswap/cjs/src/want-manager/index.js","node_modules/ipfs-bitswap/cjs/src/message/index.js","node_modules/varint-decoder/src/index.js","node_modules/varint-decoder/node_modules/varint/index.js","node_modules/varint-decoder/node_modules/varint/encode.js","node_modules/varint-decoder/node_modules/varint/decode.js","node_modules/varint-decoder/node_modules/varint/length.js","node_modules/ipfs-bitswap/cjs/src/utils/varint-encoder.js","node_modules/ipfs-bitswap/cjs/src/utils/index.js","node_modules/ipfs-bitswap/cjs/src/message/entry.js","node_modules/ipfs-bitswap/cjs/src/wantlist/index.js","node_modules/ipfs-bitswap/cjs/src/wantlist/entry.js","node_modules/ipfs-bitswap/cjs/src/message/message.js","node_modules/ipfs-bitswap/cjs/src/constants.js","node_modules/ipfs-bitswap/cjs/src/want-manager/msg-queue.js","node_modules/just-debounce-it/index.js","node_modules/ipfs-bitswap/cjs/src/network.js","node_modules/ipfs-bitswap/cjs/src/decision-engine/index.js","node_modules/ipfs-bitswap/cjs/src/decision-engine/ledger.js","node_modules/ipfs-bitswap/cjs/src/decision-engine/req-queue.js","node_modules/ipfs-bitswap/cjs/src/utils/sorted-map.js","node_modules/ipfs-bitswap/cjs/src/decision-engine/task-merger.js","node_modules/ipfs-bitswap/cjs/src/notifications.js","node_modules/ipfs-bitswap/cjs/src/stats/index.js","node_modules/ipfs-bitswap/cjs/src/stats/stat.js","node_modules/ipfs-core/cjs/src/block-storage.js","node_modules/blockstore-core/cjs/src/index.js","node_modules/blockstore-core/cjs/src/errors.js","node_modules/blockstore-core/cjs/src/memory.js","node_modules/ipfs-core/cjs/src/components/swarm/index.js","node_modules/ipfs-core/cjs/src/components/swarm/addrs.js","node_modules/ipfs-core/cjs/src/components/swarm/connect.js","node_modules/ipfs-core/cjs/src/components/swarm/disconnect.js","node_modules/ipfs-core/cjs/src/components/swarm/local-addrs.js","node_modules/ipfs-core/cjs/src/components/swarm/peers.js","node_modules/ipfs-core/cjs/src/components/ping.js","node_modules/ipfs-core/cjs/src/components/dht.js","node_modules/ipfs-core/cjs/src/components/pubsub.js","node_modules/hls.js/dist/webpack:/Hls/webpack/universalModuleDefinition","node_modules/hls.js/dist/webpack:/Hls/webpack/bootstrap","node_modules/hls.js/dist/webpack:/Hls/node_modules/eventemitter3/index.js","node_modules/hls.js/dist/webpack:/Hls/node_modules/url-toolkit/src/url-toolkit.js","node_modules/hls.js/dist/webpack:/Hls/node_modules/webworkify-webpack/index.js","node_modules/hls.js/dist/webpack:/Hls/src/crypt/aes-crypto.js","node_modules/hls.js/dist/webpack:/Hls/src/crypt/fast-aes-key.js","node_modules/hls.js/dist/webpack:/Hls/src/crypt/aes-decryptor.js","node_modules/hls.js/dist/webpack:/Hls/src/crypt/decrypter.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/adts.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/aacdemuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/mpegaudio.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/exp-golomb.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/sample-aes.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/tsdemuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/mp3demuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/remux/aac-helper.js","node_modules/hls.js/dist/webpack:/Hls/src/remux/mp4-generator.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/timescale-conversion.ts","node_modules/hls.js/dist/webpack:/Hls/src/remux/mp4-remuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/demuxer-inline.js","node_modules/hls.js/dist/webpack:/Hls/src/remux/passthrough-remuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/demuxer-worker.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/id3.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/mp4demuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/errors.ts","node_modules/hls.js/dist/webpack:/Hls/src/events.js","node_modules/hls.js/dist/webpack:/Hls/src/types/loader.ts","node_modules/hls.js/dist/webpack:/Hls/src/event-handler.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/level-key.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/fragment.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/level.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/attr-list.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/codecs.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/m3u8-parser.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/playlist-loader.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/fragment-loader.js","node_modules/hls.js/dist/webpack:/Hls/src/loader/key-loader.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/fragment-tracker.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/binary-search.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/buffer-helper.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/mediasource-helper.ts","node_modules/hls.js/dist/webpack:/Hls/src/observer.ts","node_modules/hls.js/dist/webpack:/Hls/src/demux/demuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/level-helper.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/time-ranges.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/discontinuities.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/fragment-finders.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/gap-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/task-loop.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/base-stream-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/stream-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/level-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/texttrack-utils.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/id3-track-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/ewma.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/ewma-bandwidth-estimator.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/abr-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/buffer-controller.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/cap-level-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/fps-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/xhr-loader.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/audio-track-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/audio-stream-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/vttcue.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/vttparser.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/cues.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/cea-608-parser.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/output-filter.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/webvtt-parser.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/timeline-controller.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/subtitle-track-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/mediakeys-helper.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/subtitle-stream-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/eme-controller.ts","node_modules/hls.js/dist/webpack:/Hls/src/config.ts","node_modules/hls.js/dist/webpack:/Hls/src/hls.ts","node_modules/hls.js/dist/webpack:/Hls/src/is-supported.ts","node_modules/hls.js/dist/webpack:/Hls/src/polyfills/number.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/get-self-scope.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/logger.js","node_modules/hlsjs-ipfs-loader/src/index.js"],"sourcesContent":["'use strict'\n\nimport { create } from 'ipfs-core'\nimport Hls from 'hls.js'\nimport HlsjsIpfsLoader from 'hlsjs-ipfs-loader'\n\ndocument.addEventListener('DOMContentLoaded', async () => {\n const hash = getUrlParameter('hash')\n const source = getUrlParameter('source')\n const title = getUrlParameter('title')\n const time = getUrlParameter('time')\n setUpContextMenu() // todo move back inside if(hash)\n if (title) {\n document.title = title\n }\n if (hash) {\n document.getElementById('help').style.display = 'none'\n const video = document.getElementById('video')\n video.style.display = 'block'\n const repoPath = 'ipfs-' + Math.random()\n showStatus('Connecting to IPFS')\n const node = await create({ repo: repoPath })\n showStatus('Connected')\n Hls.DefaultConfig.loader = HlsjsIpfsLoader\n Hls.DefaultConfig.debug = false\n if (Hls.isSupported()) {\n const hls = new Hls()\n hls.config.ipfs = node\n hls.config.ipfsHash = hash\n showStatus('Video loading')\n hls.loadSource(source || 'master.m3u8')\n hls.attachMedia(video)\n hls.on(Hls.Events.MANIFEST_PARSED, () => {\n showStatus('Video loaded', true)\n if (time) {\n video.currentTime = time\n }\n video.play()\n })\n }\n }\n setBodyHeight()\n window.addEventListener('resize', setBodyHeight)\n\n function setUpContextMenu() {\n const video = document.getElementById('video')\n const background = document.getElementById('contextBackground')\n const menu = document.getElementById('contextMenu')\n video.oncontextmenu = e => {\n background.classList.toggle('is-hidden')\n menu.style.left = e.pageX + 'px'\n menu.style.top = e.pageY + 'px'\n e.preventDefault()\n }\n background.onclick = e => {\n e.stopPropagation()\n background.classList.toggle('is-hidden')\n }\n const url = `http://ipfsvideo.cc?hash=${\n hash\n }${\n (title && '&title=' + encodeURIComponent(title))||''\n }${\n (source && '&source=' + encodeURIComponent(source))||''\n }`\n document.getElementById('contextMenu-url').onclick = e => {\n navigator.clipboard.writeText(url)\n }\n document.getElementById('contextMenu-urlWithTime').onclick = e => {\n navigator.clipboard.writeText(`${url}&time=${Math.round(video.currentTime)}`)\n }\n }\n})\n\nfunction getUrlParameter(name) {\n name = name.replace(/[\\[]/, '\\\\[').replace(/[\\]]/, '\\\\]')\n var regex = new RegExp('[\\\\?&]' + name + '=([^&#]*)')\n var results = regex.exec(location.search)\n return results === null ? null : decodeURIComponent(results[1].replace(/\\+/g, ' '))\n}\n\nfunction showStatus(message, hide = false) {\n const status = document.getElementById('status')\n status.classList.toggle('is-hiding', hide)\n status.innerText = message\n}\n\nfunction setBodyHeight() {\n document.body.style.height = window.innerHeight + 'px'\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('./components/index.js');\nvar crypto$1 = require('libp2p-crypto');\nvar isIpfs = require('is-ipfs');\nvar cid = require('multiformats/cid');\nvar multiaddr$1 = require('multiaddr');\nvar PeerId$1 = require('peer-id');\nvar globSourceImport = require('ipfs-utils/src/files/glob-source.js');\nvar urlSourceImport = require('ipfs-utils/src/files/url-source.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar crypto__default = /*#__PURE__*/_interopDefaultLegacy(crypto$1);\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId$1);\nvar globSourceImport__default = /*#__PURE__*/_interopDefaultLegacy(globSourceImport);\nvar urlSourceImport__default = /*#__PURE__*/_interopDefaultLegacy(urlSourceImport);\n\nconst create = index.create;\nconst crypto = crypto__default['default'];\nconst isIPFS = isIpfs__default['default'];\nconst CID = cid.CID;\nconst multiaddr = multiaddr$1.Multiaddr;\nconst PeerId = PeerId__default['default'];\nconst globSource = globSourceImport__default['default'];\nconst urlSource = urlSourceImport__default['default'];\n\nexports.CID = CID;\nexports.PeerId = PeerId;\nexports.create = create;\nexports.crypto = crypto;\nexports.globSource = globSource;\nexports.isIPFS = isIPFS;\nexports.multiaddr = multiaddr;\nexports.urlSource = urlSource;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mergeOpts = require('merge-options');\nvar env_js = require('ipfs-utils/src/env.js');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dagPB = require('@ipld/dag-pb');\nvar dagCBOR = require('@ipld/dag-cbor');\nvar identity = require('multiformats/hashes/identity');\nvar basics = require('multiformats/basics');\nvar initAssets = require('ipfs-core-config/init-assets');\nvar errors = require('../errors.js');\nvar fromString = require('uint8arrays/from-string');\nvar start = require('./start.js');\nvar stop = require('./stop.js');\nvar dns = require('./dns.js');\nvar isOnline = require('./is-online.js');\nvar resolve = require('./resolve.js');\nvar index = require('./pin/index.js');\nvar ipns = require('./ipns.js');\nvar index$2 = require('./name/index.js');\nvar index$4 = require('./refs/index.js');\nvar local = require('./refs/local.js');\nvar index$6 = require('./bitswap/index.js');\nvar index$7 = require('./bootstrap/index.js');\nvar index$1 = require('./block/index.js');\nvar root = require('./root.js');\nvar version = require('./version.js');\nvar id = require('./id.js');\nvar index$8 = require('./config/index.js');\nvar index$3 = require('./dag/index.js');\nvar preload = require('../preload.js');\nvar mfsPreload = require('../mfs-preload.js');\nvar index$5 = require('./files/index.js');\nvar index$9 = require('./key/index.js');\nvar index$a = require('./object/index.js');\nvar index$b = require('./repo/index.js');\nvar index$c = require('./stats/index.js');\nvar storage = require('./storage.js');\nvar network = require('./network.js');\nvar service = require('../utils/service.js');\nvar index$d = require('./swarm/index.js');\nvar ping = require('./ping.js');\nvar dht = require('./dht.js');\nvar pubsub = require('./pubsub.js');\nvar multicodecs = require('ipfs-core-utils/multicodecs');\nvar multihashes = require('ipfs-core-utils/multihashes');\nvar multibases = require('ipfs-core-utils/multibases');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar dagCBOR__namespace = /*#__PURE__*/_interopNamespace(dagCBOR);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs');\nclass IPFS {\n constructor({print, storage, codecs, options}) {\n const {peerId, repo, keychain} = storage;\n const network$1 = service.Service.create(network.Network);\n const preload$1 = preload.createPreloader(options.preload);\n const dns$1 = dns.createDns();\n const isOnline$1 = isOnline.createIsOnline({ network: network$1 });\n const ipns$1 = new ipns.IPNSAPI(options);\n const multihashHashers = Object.values(basics.hashes);\n (options.ipld && options.ipld.hashers ? options.ipld.hashers : []).forEach(hasher => multihashHashers.push(hasher));\n this.hashers = new multihashes.Multihashes({\n hashers: multihashHashers,\n loadHasher: options.ipld && options.ipld.loadHasher\n });\n const multibaseCodecs = Object.values(basics.bases);\n (options.ipld && options.ipld.bases ? options.ipld.bases : []).forEach(base => multibaseCodecs.push(base));\n this.bases = new multibases.Multibases({\n bases: multibaseCodecs,\n loadBase: options.ipld && options.ipld.loadBase\n });\n const pin = new index.PinAPI({\n repo,\n codecs\n });\n const block = new index$1.BlockAPI({\n codecs,\n hashers: this.hashers,\n preload: preload$1,\n repo\n });\n const name = new index$2.NameAPI({\n dns: dns$1,\n ipns: ipns$1,\n repo,\n codecs,\n peerId,\n isOnline: isOnline$1,\n keychain,\n options\n });\n const resolve$1 = resolve.createResolve({\n repo,\n codecs,\n bases: this.bases,\n name\n });\n const dag = new index$3.DagAPI({\n repo,\n codecs,\n hashers: this.hashers,\n preload: preload$1\n });\n const refs = Object.assign(index$4.createRefs({\n repo,\n codecs,\n resolve: resolve$1,\n preload: preload$1\n }), { local: local.createLocal({ repo: storage.repo }) });\n const {add, addAll, cat, get, ls} = new root.RootAPI({\n preload: preload$1,\n repo,\n options: options.EXPERIMENTAL\n });\n const files = index$5.createFiles({\n repo,\n preload: preload$1,\n hashers: this.hashers,\n options\n });\n const mfsPreload$1 = mfsPreload.createMfsPreloader({\n files,\n preload: preload$1,\n options: options.preload\n });\n this.preload = preload$1;\n this.name = name;\n this.ipns = ipns$1;\n this.pin = pin;\n this.resolve = resolve$1;\n this.block = block;\n this.refs = refs;\n this.start = start.createStart({\n network: network$1,\n peerId,\n repo,\n preload: preload$1,\n ipns: ipns$1,\n mfsPreload: mfsPreload$1,\n print,\n keychain,\n options\n });\n this.stop = stop.createStop({\n network: network$1,\n preload: preload$1,\n mfsPreload: mfsPreload$1,\n ipns: ipns$1,\n repo\n });\n this.dht = dht.createDht({\n network: network$1,\n repo\n });\n this.pubsub = pubsub.createPubsub({\n network: network$1,\n config: options.config\n });\n this.dns = dns$1;\n this.isOnline = isOnline$1;\n this.id = id.createId({\n network: network$1,\n peerId\n });\n this.version = version.createVersion({ repo });\n this.bitswap = new index$6.BitswapAPI({ network: network$1 });\n this.bootstrap = new index$7.BootstrapAPI({ repo });\n this.config = index$8.createConfig({ repo });\n this.ping = ping.createPing({ network: network$1 });\n this.add = add;\n this.addAll = addAll;\n this.cat = cat;\n this.get = get;\n this.ls = ls;\n this.dag = dag;\n this.files = files;\n this.key = new index$9.KeyAPI({ keychain });\n this.object = new index$a.ObjectAPI({\n preload: preload$1,\n codecs,\n repo\n });\n this.repo = new index$b.RepoAPI({\n repo,\n hashers: this.hashers\n });\n this.stats = new index$c.StatsAPI({\n repo,\n network: network$1\n });\n this.swarm = new index$d.SwarmAPI({ network: network$1 });\n Object.defineProperty(this, 'libp2p', {\n get() {\n const net = network$1.try();\n return net ? net.libp2p : undefined;\n }\n });\n const notImplemented = () => Promise.reject(errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED'));\n const notImplementedIter = async function* () {\n throw errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED');\n };\n this.commands = notImplemented;\n this.diag = {\n cmds: notImplemented,\n net: notImplemented,\n sys: notImplemented\n };\n this.log = {\n level: notImplemented,\n ls: notImplemented,\n tail: notImplementedIter\n };\n this.mount = notImplemented;\n this.codecs = codecs;\n }\n async init() {\n throw new errors.AlreadyInitializedError();\n }\n}\nconst addEmptyDir = async ipfs => {\n const buf = dagPB__namespace.encode({\n Data: new ipfsUnixfs.UnixFS({ type: 'directory' }).marshal(),\n Links: []\n });\n const cid = await ipfs.block.put(buf, {\n mhtype: 'sha2-256',\n format: 'dag-pb'\n });\n await ipfs.pin.add(cid);\n return cid;\n};\nconst getDefaultOptions = () => ({\n start: true,\n EXPERIMENTAL: {},\n preload: {\n enabled: !env_js.isTest,\n addresses: [\n '/dns4/node0.preload.ipfs.io/https',\n '/dns4/node1.preload.ipfs.io/https',\n '/dns4/node2.preload.ipfs.io/https',\n '/dns4/node3.preload.ipfs.io/https'\n ]\n }\n});\nasync function create(options = {}) {\n options = mergeOptions(getDefaultOptions(), options);\n const initOptions = options.init || {};\n const id = {\n name: identity.identity.name,\n code: identity.identity.code,\n encode: id => id,\n decode: id => id\n };\n const blockCodecs = Object.values(basics.codecs);\n [\n dagPB__namespace,\n dagCBOR__namespace,\n id\n ].concat(options.ipld && options.ipld.codecs || []).forEach(codec => blockCodecs.push(codec));\n const multicodecs$1 = new multicodecs.Multicodecs({\n codecs: blockCodecs,\n loadCodec: options.ipld && options.ipld.loadCodec\n });\n const print = options.silent ? log : console.log;\n const storage$1 = await storage.Storage.start(print, multicodecs$1, options);\n const config = await storage$1.repo.config.getAll();\n const ipfs = new IPFS({\n storage: storage$1,\n print,\n codecs: multicodecs$1,\n options: {\n ...options,\n config\n }\n });\n await ipfs.preload.start();\n ipfs.ipns.startOffline(storage$1);\n if (storage$1.isNew && !initOptions.emptyRepo) {\n const cid = await addEmptyDir(ipfs);\n log('adding default assets');\n await initAssets.initAssets({\n addAll: ipfs.addAll,\n print\n });\n log('initializing IPNS keyspace');\n await ipfs.ipns.initializeKeyspace(storage$1.peerId.privKey, fromString.fromString(`/ipfs/${ cid }`));\n }\n if (options.start !== false) {\n await ipfs.start();\n }\n return ipfs;\n}\n\nexports.create = create;\n","'use strict';\nconst isOptionObject = require('is-plain-obj');\n\nconst {hasOwnProperty} = Object.prototype;\nconst {propertyIsEnumerable} = Object;\nconst defineProperty = (object, name, value) => Object.defineProperty(object, name, {\n\tvalue,\n\twritable: true,\n\tenumerable: true,\n\tconfigurable: true\n});\n\nconst globalThis = this;\nconst defaultMergeOptions = {\n\tconcatArrays: false,\n\tignoreUndefined: false\n};\n\nconst getEnumerableOwnPropertyKeys = value => {\n\tconst keys = [];\n\n\tfor (const key in value) {\n\t\tif (hasOwnProperty.call(value, key)) {\n\t\t\tkeys.push(key);\n\t\t}\n\t}\n\n\t/* istanbul ignore else */\n\tif (Object.getOwnPropertySymbols) {\n\t\tconst symbols = Object.getOwnPropertySymbols(value);\n\n\t\tfor (const symbol of symbols) {\n\t\t\tif (propertyIsEnumerable.call(value, symbol)) {\n\t\t\t\tkeys.push(symbol);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn keys;\n};\n\nfunction clone(value) {\n\tif (Array.isArray(value)) {\n\t\treturn cloneArray(value);\n\t}\n\n\tif (isOptionObject(value)) {\n\t\treturn cloneOptionObject(value);\n\t}\n\n\treturn value;\n}\n\nfunction cloneArray(array) {\n\tconst result = array.slice(0, 0);\n\n\tgetEnumerableOwnPropertyKeys(array).forEach(key => {\n\t\tdefineProperty(result, key, clone(array[key]));\n\t});\n\n\treturn result;\n}\n\nfunction cloneOptionObject(object) {\n\tconst result = Object.getPrototypeOf(object) === null ? Object.create(null) : {};\n\n\tgetEnumerableOwnPropertyKeys(object).forEach(key => {\n\t\tdefineProperty(result, key, clone(object[key]));\n\t});\n\n\treturn result;\n}\n\n/**\n * @param {*} merged already cloned\n * @param {*} source something to merge\n * @param {string[]} keys keys to merge\n * @param {Object} config Config Object\n * @returns {*} cloned Object\n */\nconst mergeKeys = (merged, source, keys, config) => {\n\tkeys.forEach(key => {\n\t\tif (typeof source[key] === 'undefined' && config.ignoreUndefined) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Do not recurse into prototype chain of merged\n\t\tif (key in merged && merged[key] !== Object.getPrototypeOf(merged)) {\n\t\t\tdefineProperty(merged, key, merge(merged[key], source[key], config));\n\t\t} else {\n\t\t\tdefineProperty(merged, key, clone(source[key]));\n\t\t}\n\t});\n\n\treturn merged;\n};\n\n/**\n * @param {*} merged already cloned\n * @param {*} source something to merge\n * @param {Object} config Config Object\n * @returns {*} cloned Object\n *\n * see [Array.prototype.concat ( ...arguments )](http://www.ecma-international.org/ecma-262/6.0/#sec-array.prototype.concat)\n */\nconst concatArrays = (merged, source, config) => {\n\tlet result = merged.slice(0, 0);\n\tlet resultIndex = 0;\n\n\t[merged, source].forEach(array => {\n\t\tconst indices = [];\n\n\t\t// `result.concat(array)` with cloning\n\t\tfor (let k = 0; k < array.length; k++) {\n\t\t\tif (!hasOwnProperty.call(array, k)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tindices.push(String(k));\n\n\t\t\tif (array === merged) {\n\t\t\t\t// Already cloned\n\t\t\t\tdefineProperty(result, resultIndex++, array[k]);\n\t\t\t} else {\n\t\t\t\tdefineProperty(result, resultIndex++, clone(array[k]));\n\t\t\t}\n\t\t}\n\n\t\t// Merge non-index keys\n\t\tresult = mergeKeys(result, array, getEnumerableOwnPropertyKeys(array).filter(key => !indices.includes(key)), config);\n\t});\n\n\treturn result;\n};\n\n/**\n * @param {*} merged already cloned\n * @param {*} source something to merge\n * @param {Object} config Config Object\n * @returns {*} cloned Object\n */\nfunction merge(merged, source, config) {\n\tif (config.concatArrays && Array.isArray(merged) && Array.isArray(source)) {\n\t\treturn concatArrays(merged, source, config);\n\t}\n\n\tif (!isOptionObject(source) || !isOptionObject(merged)) {\n\t\treturn clone(source);\n\t}\n\n\treturn mergeKeys(merged, source, getEnumerableOwnPropertyKeys(source), config);\n}\n\nmodule.exports = function (...options) {\n\tconst config = merge(clone(defaultMergeOptions), (this !== globalThis && this) || {}, defaultMergeOptions);\n\tlet merged = {_: {}};\n\n\tfor (const option of options) {\n\t\tif (option === undefined) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (!isOptionObject(option)) {\n\t\t\tthrow new TypeError('`' + option + '` is not an Option Object');\n\t\t}\n\n\t\tmerged = merge(merged, {_: option}, config);\n\t}\n\n\treturn merged._;\n};\n","'use strict';\n\nmodule.exports = value => {\n\tif (Object.prototype.toString.call(value) !== '[object Object]') {\n\t\treturn false;\n\t}\n\n\tconst prototype = Object.getPrototypeOf(value);\n\treturn prototype === null || prototype === Object.prototype;\n};\n","'use strict'\nconst isElectron = require('is-electron')\n\nconst IS_ENV_WITH_DOM = typeof window === 'object' && typeof document === 'object' && document.nodeType === 9\n// @ts-ignore\nconst IS_ELECTRON = isElectron()\nconst IS_BROWSER = IS_ENV_WITH_DOM && !IS_ELECTRON\nconst IS_ELECTRON_MAIN = IS_ELECTRON && !IS_ENV_WITH_DOM\nconst IS_ELECTRON_RENDERER = IS_ELECTRON && IS_ENV_WITH_DOM\nconst IS_NODE = typeof require === 'function' && typeof process !== 'undefined' && typeof process.release !== 'undefined' && process.release.name === 'node' && !IS_ELECTRON\n// @ts-ignore - we either ignore worker scope or dom scope\nconst IS_WEBWORKER = typeof importScripts === 'function' && typeof self !== 'undefined' && typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope\nconst IS_TEST = typeof process !== 'undefined' && typeof process.env !== 'undefined' && process.env.NODE_ENV === 'test'\nconst IS_REACT_NATIVE = typeof navigator !== 'undefined' && navigator.product === 'ReactNative'\n\nmodule.exports = {\n isTest: IS_TEST,\n isElectron: IS_ELECTRON,\n isElectronMain: IS_ELECTRON_MAIN,\n isElectronRenderer: IS_ELECTRON_RENDERER,\n isNode: IS_NODE,\n /**\n * Detects browser main thread **NOT** web worker or service worker\n */\n isBrowser: IS_BROWSER,\n isWebWorker: IS_WEBWORKER,\n isEnvWithDom: IS_ENV_WITH_DOM,\n isReactNative: IS_REACT_NATIVE\n}\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","// https://github.com/electron/electron/issues/2288\nfunction isElectron() {\n // Renderer process\n if (typeof window !== 'undefined' && typeof window.process === 'object' && window.process.type === 'renderer') {\n return true;\n }\n\n // Main process\n if (typeof process !== 'undefined' && typeof process.versions === 'object' && !!process.versions.electron) {\n return true;\n }\n\n // Detect the user agent when the `nodeIntegration` option is set to false\n if (typeof navigator === 'object' && typeof navigator.userAgent === 'string' && navigator.userAgent.indexOf('Electron') >= 0) {\n return true;\n }\n\n return false;\n}\n\nmodule.exports = isElectron;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) && parseInt(RegExp.$1, 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tlet i;\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n\t\tconst len = split.length;\n\n\t\tfor (i = 0; i < len; i++) {\n\t\t\tif (!split[i]) {\n\t\t\t\t// ignore empty strings\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tnamespaces = split[i].replace(/\\*/g, '.*?');\n\n\t\t\tif (namespaces[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(new RegExp('^' + namespaces.substr(1) + '$'));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(new RegExp('^' + namespaces + '$'));\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names.map(toNamespace),\n\t\t\t...createDebug.skips.map(toNamespace).map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tif (name[name.length - 1] === '*') {\n\t\t\treturn true;\n\t\t}\n\n\t\tlet i;\n\t\tlet len;\n\n\t\tfor (i = 0, len = createDebug.skips.length; i < len; i++) {\n\t\t\tif (createDebug.skips[i].test(name)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (i = 0, len = createDebug.names.length; i < len; i++) {\n\t\t\tif (createDebug.names[i].test(name)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Convert regexp to namespace\n\t*\n\t* @param {RegExp} regxep\n\t* @return {String} namespace\n\t* @api private\n\t*/\n\tfunction toNamespace(regexp) {\n\t\treturn regexp.toString()\n\t\t\t.substring(2, regexp.toString().length - 2)\n\t\t\t.replace(/\\.\\*\\?$/, '*');\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function(val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","'use strict';\n\n/**\n * @typedef {{ [key: string]: any }} Extensions\n * @typedef {Error} Err\n * @property {string} message\n */\n\n/**\n *\n * @param {Error} obj\n * @param {Extensions} props\n * @returns {Error & Extensions}\n */\nfunction assign(obj, props) {\n for (const key in props) {\n Object.defineProperty(obj, key, {\n value: props[key],\n enumerable: true,\n configurable: true,\n });\n }\n\n return obj;\n}\n\n/**\n *\n * @param {any} err - An Error\n * @param {string|Extensions} code - A string code or props to set on the error\n * @param {Extensions} [props] - Props to set on the error\n * @returns {Error & Extensions}\n */\nfunction createError(err, code, props) {\n if (!err || typeof err === 'string') {\n throw new TypeError('Please pass an Error to err-code');\n }\n\n if (!props) {\n props = {};\n }\n\n if (typeof code === 'object') {\n props = code;\n code = '';\n }\n\n if (code) {\n props.code = code;\n }\n\n try {\n return assign(err, props);\n } catch (_) {\n props.message = err.message;\n props.stack = err.stack;\n\n const ErrClass = function () {};\n\n ErrClass.prototype = Object.create(Object.getPrototypeOf(err));\n\n // @ts-ignore\n const output = assign(new ErrClass(), props);\n\n return output;\n }\n}\n\nmodule.exports = createError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errcode = require('err-code');\nvar unixfs = require('./unixfs.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\n\nconst PBData = unixfs.Data;\nconst types = [\n 'raw',\n 'directory',\n 'file',\n 'metadata',\n 'symlink',\n 'hamt-sharded-directory'\n];\nconst dirTypes = [\n 'directory',\n 'hamt-sharded-directory'\n];\nconst DEFAULT_FILE_MODE = parseInt('0644', 8);\nconst DEFAULT_DIRECTORY_MODE = parseInt('0755', 8);\nfunction parseMode(mode) {\n if (mode == null) {\n return undefined;\n }\n if (typeof mode === 'number') {\n return mode & 4095;\n }\n mode = mode.toString();\n if (mode.substring(0, 1) === '0') {\n return parseInt(mode, 8) & 4095;\n }\n return parseInt(mode, 10) & 4095;\n}\nfunction parseMtime(input) {\n if (input == null) {\n return undefined;\n }\n let mtime;\n if (input.secs != null) {\n mtime = {\n secs: input.secs,\n nsecs: input.nsecs\n };\n }\n if (input.Seconds != null) {\n mtime = {\n secs: input.Seconds,\n nsecs: input.FractionalNanoseconds\n };\n }\n if (Array.isArray(input)) {\n mtime = {\n secs: input[0],\n nsecs: input[1]\n };\n }\n if (input instanceof Date) {\n const ms = input.getTime();\n const secs = Math.floor(ms / 1000);\n mtime = {\n secs: secs,\n nsecs: (ms - secs * 1000) * 1000\n };\n }\n if (!Object.prototype.hasOwnProperty.call(mtime, 'secs')) {\n return undefined;\n }\n if (mtime != null && mtime.nsecs != null && (mtime.nsecs < 0 || mtime.nsecs > 999999999)) {\n throw errcode__default['default'](new Error('mtime-nsecs must be within the range [0,999999999]'), 'ERR_INVALID_MTIME_NSECS');\n }\n return mtime;\n}\nclass UnixFS {\n static unmarshal(marshaled) {\n const message = PBData.decode(marshaled);\n const decoded = PBData.toObject(message, {\n defaults: false,\n arrays: true,\n longs: Number,\n objects: false\n });\n const data = new UnixFS({\n type: types[decoded.Type],\n data: decoded.Data,\n blockSizes: decoded.blocksizes,\n mode: decoded.mode,\n mtime: decoded.mtime ? {\n secs: decoded.mtime.Seconds,\n nsecs: decoded.mtime.FractionalNanoseconds\n } : undefined\n });\n data._originalMode = decoded.mode || 0;\n return data;\n }\n constructor(options = { type: 'file' }) {\n const {type, data, blockSizes, hashType, fanout, mtime, mode} = options;\n if (type && !types.includes(type)) {\n throw errcode__default['default'](new Error('Type: ' + type + ' is not valid'), 'ERR_INVALID_TYPE');\n }\n this.type = type || 'file';\n this.data = data;\n this.hashType = hashType;\n this.fanout = fanout;\n this.blockSizes = blockSizes || [];\n this._originalMode = 0;\n this.mode = parseMode(mode);\n if (mtime) {\n this.mtime = parseMtime(mtime);\n if (this.mtime && !this.mtime.nsecs) {\n this.mtime.nsecs = 0;\n }\n }\n }\n set mode(mode) {\n this._mode = this.isDirectory() ? DEFAULT_DIRECTORY_MODE : DEFAULT_FILE_MODE;\n const parsedMode = parseMode(mode);\n if (parsedMode !== undefined) {\n this._mode = parsedMode;\n }\n }\n get mode() {\n return this._mode;\n }\n isDirectory() {\n return Boolean(this.type && dirTypes.includes(this.type));\n }\n addBlockSize(size) {\n this.blockSizes.push(size);\n }\n removeBlockSize(index) {\n this.blockSizes.splice(index, 1);\n }\n fileSize() {\n if (this.isDirectory()) {\n return 0;\n }\n let sum = 0;\n this.blockSizes.forEach(size => {\n sum += size;\n });\n if (this.data) {\n sum += this.data.length;\n }\n return sum;\n }\n marshal() {\n let type;\n switch (this.type) {\n case 'raw':\n type = PBData.DataType.Raw;\n break;\n case 'directory':\n type = PBData.DataType.Directory;\n break;\n case 'file':\n type = PBData.DataType.File;\n break;\n case 'metadata':\n type = PBData.DataType.Metadata;\n break;\n case 'symlink':\n type = PBData.DataType.Symlink;\n break;\n case 'hamt-sharded-directory':\n type = PBData.DataType.HAMTShard;\n break;\n default:\n throw errcode__default['default'](new Error('Type: ' + type + ' is not valid'), 'ERR_INVALID_TYPE');\n }\n let data = this.data;\n if (!this.data || !this.data.length) {\n data = undefined;\n }\n let mode;\n if (this.mode != null) {\n mode = this._originalMode & 4294963200 | (parseMode(this.mode) || 0);\n if (mode === DEFAULT_FILE_MODE && !this.isDirectory()) {\n mode = undefined;\n }\n if (mode === DEFAULT_DIRECTORY_MODE && this.isDirectory()) {\n mode = undefined;\n }\n }\n let mtime;\n if (this.mtime != null) {\n const parsed = parseMtime(this.mtime);\n if (parsed) {\n mtime = {\n Seconds: parsed.secs,\n FractionalNanoseconds: parsed.nsecs\n };\n if (mtime.FractionalNanoseconds === 0) {\n delete mtime.FractionalNanoseconds;\n }\n }\n }\n const pbData = {\n Type: type,\n Data: data,\n filesize: this.isDirectory() ? undefined : this.fileSize(),\n blocksizes: this.blockSizes,\n hashType: this.hashType,\n fanout: this.fanout,\n mode,\n mtime\n };\n return PBData.encode(pbData).finish();\n }\n}\n\nexports.UnixFS = UnixFS;\nexports.parseMode = parseMode;\nexports.parseMtime = parseMtime;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar $protobuf = require('protobufjs/minimal.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar $protobuf__default = /*#__PURE__*/_interopDefaultLegacy($protobuf);\n\nconst $Reader = $protobuf__default['default'].Reader, $Writer = $protobuf__default['default'].Writer, $util = $protobuf__default['default'].util;\nconst $root = $protobuf__default['default'].roots['ipfs-unixfs'] || ($protobuf__default['default'].roots['ipfs-unixfs'] = {});\nconst Data = $root.Data = (() => {\n function Data(p) {\n this.blocksizes = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Data.prototype.Type = 0;\n Data.prototype.Data = $util.newBuffer([]);\n Data.prototype.filesize = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n Data.prototype.blocksizes = $util.emptyArray;\n Data.prototype.hashType = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n Data.prototype.fanout = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n Data.prototype.mode = 0;\n Data.prototype.mtime = null;\n Data.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(8).int32(m.Type);\n if (m.Data != null && Object.hasOwnProperty.call(m, 'Data'))\n w.uint32(18).bytes(m.Data);\n if (m.filesize != null && Object.hasOwnProperty.call(m, 'filesize'))\n w.uint32(24).uint64(m.filesize);\n if (m.blocksizes != null && m.blocksizes.length) {\n for (var i = 0; i < m.blocksizes.length; ++i)\n w.uint32(32).uint64(m.blocksizes[i]);\n }\n if (m.hashType != null && Object.hasOwnProperty.call(m, 'hashType'))\n w.uint32(40).uint64(m.hashType);\n if (m.fanout != null && Object.hasOwnProperty.call(m, 'fanout'))\n w.uint32(48).uint64(m.fanout);\n if (m.mode != null && Object.hasOwnProperty.call(m, 'mode'))\n w.uint32(56).uint32(m.mode);\n if (m.mtime != null && Object.hasOwnProperty.call(m, 'mtime'))\n $root.UnixTime.encode(m.mtime, w.uint32(66).fork()).ldelim();\n return w;\n };\n Data.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Data();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.Type = r.int32();\n break;\n case 2:\n m.Data = r.bytes();\n break;\n case 3:\n m.filesize = r.uint64();\n break;\n case 4:\n if (!(m.blocksizes && m.blocksizes.length))\n m.blocksizes = [];\n if ((t & 7) === 2) {\n var c2 = r.uint32() + r.pos;\n while (r.pos < c2)\n m.blocksizes.push(r.uint64());\n } else\n m.blocksizes.push(r.uint64());\n break;\n case 5:\n m.hashType = r.uint64();\n break;\n case 6:\n m.fanout = r.uint64();\n break;\n case 7:\n m.mode = r.uint32();\n break;\n case 8:\n m.mtime = $root.UnixTime.decode(r, r.uint32());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty('Type'))\n throw $util.ProtocolError('missing required \\'Type\\'', { instance: m });\n return m;\n };\n Data.fromObject = function fromObject(d) {\n if (d instanceof $root.Data)\n return d;\n var m = new $root.Data();\n switch (d.Type) {\n case 'Raw':\n case 0:\n m.Type = 0;\n break;\n case 'Directory':\n case 1:\n m.Type = 1;\n break;\n case 'File':\n case 2:\n m.Type = 2;\n break;\n case 'Metadata':\n case 3:\n m.Type = 3;\n break;\n case 'Symlink':\n case 4:\n m.Type = 4;\n break;\n case 'HAMTShard':\n case 5:\n m.Type = 5;\n break;\n }\n if (d.Data != null) {\n if (typeof d.Data === 'string')\n $util.base64.decode(d.Data, m.Data = $util.newBuffer($util.base64.length(d.Data)), 0);\n else if (d.Data.length)\n m.Data = d.Data;\n }\n if (d.filesize != null) {\n if ($util.Long)\n (m.filesize = $util.Long.fromValue(d.filesize)).unsigned = true;\n else if (typeof d.filesize === 'string')\n m.filesize = parseInt(d.filesize, 10);\n else if (typeof d.filesize === 'number')\n m.filesize = d.filesize;\n else if (typeof d.filesize === 'object')\n m.filesize = new $util.LongBits(d.filesize.low >>> 0, d.filesize.high >>> 0).toNumber(true);\n }\n if (d.blocksizes) {\n if (!Array.isArray(d.blocksizes))\n throw TypeError('.Data.blocksizes: array expected');\n m.blocksizes = [];\n for (var i = 0; i < d.blocksizes.length; ++i) {\n if ($util.Long)\n (m.blocksizes[i] = $util.Long.fromValue(d.blocksizes[i])).unsigned = true;\n else if (typeof d.blocksizes[i] === 'string')\n m.blocksizes[i] = parseInt(d.blocksizes[i], 10);\n else if (typeof d.blocksizes[i] === 'number')\n m.blocksizes[i] = d.blocksizes[i];\n else if (typeof d.blocksizes[i] === 'object')\n m.blocksizes[i] = new $util.LongBits(d.blocksizes[i].low >>> 0, d.blocksizes[i].high >>> 0).toNumber(true);\n }\n }\n if (d.hashType != null) {\n if ($util.Long)\n (m.hashType = $util.Long.fromValue(d.hashType)).unsigned = true;\n else if (typeof d.hashType === 'string')\n m.hashType = parseInt(d.hashType, 10);\n else if (typeof d.hashType === 'number')\n m.hashType = d.hashType;\n else if (typeof d.hashType === 'object')\n m.hashType = new $util.LongBits(d.hashType.low >>> 0, d.hashType.high >>> 0).toNumber(true);\n }\n if (d.fanout != null) {\n if ($util.Long)\n (m.fanout = $util.Long.fromValue(d.fanout)).unsigned = true;\n else if (typeof d.fanout === 'string')\n m.fanout = parseInt(d.fanout, 10);\n else if (typeof d.fanout === 'number')\n m.fanout = d.fanout;\n else if (typeof d.fanout === 'object')\n m.fanout = new $util.LongBits(d.fanout.low >>> 0, d.fanout.high >>> 0).toNumber(true);\n }\n if (d.mode != null) {\n m.mode = d.mode >>> 0;\n }\n if (d.mtime != null) {\n if (typeof d.mtime !== 'object')\n throw TypeError('.Data.mtime: object expected');\n m.mtime = $root.UnixTime.fromObject(d.mtime);\n }\n return m;\n };\n Data.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.blocksizes = [];\n }\n if (o.defaults) {\n d.Type = o.enums === String ? 'Raw' : 0;\n if (o.bytes === String)\n d.Data = '';\n else {\n d.Data = [];\n if (o.bytes !== Array)\n d.Data = $util.newBuffer(d.Data);\n }\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.filesize = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.filesize = o.longs === String ? '0' : 0;\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.hashType = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.hashType = o.longs === String ? '0' : 0;\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.fanout = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.fanout = o.longs === String ? '0' : 0;\n d.mode = 0;\n d.mtime = null;\n }\n if (m.Type != null && m.hasOwnProperty('Type')) {\n d.Type = o.enums === String ? $root.Data.DataType[m.Type] : m.Type;\n }\n if (m.Data != null && m.hasOwnProperty('Data')) {\n d.Data = o.bytes === String ? $util.base64.encode(m.Data, 0, m.Data.length) : o.bytes === Array ? Array.prototype.slice.call(m.Data) : m.Data;\n }\n if (m.filesize != null && m.hasOwnProperty('filesize')) {\n if (typeof m.filesize === 'number')\n d.filesize = o.longs === String ? String(m.filesize) : m.filesize;\n else\n d.filesize = o.longs === String ? $util.Long.prototype.toString.call(m.filesize) : o.longs === Number ? new $util.LongBits(m.filesize.low >>> 0, m.filesize.high >>> 0).toNumber(true) : m.filesize;\n }\n if (m.blocksizes && m.blocksizes.length) {\n d.blocksizes = [];\n for (var j = 0; j < m.blocksizes.length; ++j) {\n if (typeof m.blocksizes[j] === 'number')\n d.blocksizes[j] = o.longs === String ? String(m.blocksizes[j]) : m.blocksizes[j];\n else\n d.blocksizes[j] = o.longs === String ? $util.Long.prototype.toString.call(m.blocksizes[j]) : o.longs === Number ? new $util.LongBits(m.blocksizes[j].low >>> 0, m.blocksizes[j].high >>> 0).toNumber(true) : m.blocksizes[j];\n }\n }\n if (m.hashType != null && m.hasOwnProperty('hashType')) {\n if (typeof m.hashType === 'number')\n d.hashType = o.longs === String ? String(m.hashType) : m.hashType;\n else\n d.hashType = o.longs === String ? $util.Long.prototype.toString.call(m.hashType) : o.longs === Number ? new $util.LongBits(m.hashType.low >>> 0, m.hashType.high >>> 0).toNumber(true) : m.hashType;\n }\n if (m.fanout != null && m.hasOwnProperty('fanout')) {\n if (typeof m.fanout === 'number')\n d.fanout = o.longs === String ? String(m.fanout) : m.fanout;\n else\n d.fanout = o.longs === String ? $util.Long.prototype.toString.call(m.fanout) : o.longs === Number ? new $util.LongBits(m.fanout.low >>> 0, m.fanout.high >>> 0).toNumber(true) : m.fanout;\n }\n if (m.mode != null && m.hasOwnProperty('mode')) {\n d.mode = m.mode;\n }\n if (m.mtime != null && m.hasOwnProperty('mtime')) {\n d.mtime = $root.UnixTime.toObject(m.mtime, o);\n }\n return d;\n };\n Data.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default['default'].util.toJSONOptions);\n };\n Data.DataType = function () {\n const valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = 'Raw'] = 0;\n values[valuesById[1] = 'Directory'] = 1;\n values[valuesById[2] = 'File'] = 2;\n values[valuesById[3] = 'Metadata'] = 3;\n values[valuesById[4] = 'Symlink'] = 4;\n values[valuesById[5] = 'HAMTShard'] = 5;\n return values;\n }();\n return Data;\n})();\nconst UnixTime = $root.UnixTime = (() => {\n function UnixTime(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n UnixTime.prototype.Seconds = $util.Long ? $util.Long.fromBits(0, 0, false) : 0;\n UnixTime.prototype.FractionalNanoseconds = 0;\n UnixTime.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(8).int64(m.Seconds);\n if (m.FractionalNanoseconds != null && Object.hasOwnProperty.call(m, 'FractionalNanoseconds'))\n w.uint32(21).fixed32(m.FractionalNanoseconds);\n return w;\n };\n UnixTime.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.UnixTime();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.Seconds = r.int64();\n break;\n case 2:\n m.FractionalNanoseconds = r.fixed32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty('Seconds'))\n throw $util.ProtocolError('missing required \\'Seconds\\'', { instance: m });\n return m;\n };\n UnixTime.fromObject = function fromObject(d) {\n if (d instanceof $root.UnixTime)\n return d;\n var m = new $root.UnixTime();\n if (d.Seconds != null) {\n if ($util.Long)\n (m.Seconds = $util.Long.fromValue(d.Seconds)).unsigned = false;\n else if (typeof d.Seconds === 'string')\n m.Seconds = parseInt(d.Seconds, 10);\n else if (typeof d.Seconds === 'number')\n m.Seconds = d.Seconds;\n else if (typeof d.Seconds === 'object')\n m.Seconds = new $util.LongBits(d.Seconds.low >>> 0, d.Seconds.high >>> 0).toNumber();\n }\n if (d.FractionalNanoseconds != null) {\n m.FractionalNanoseconds = d.FractionalNanoseconds >>> 0;\n }\n return m;\n };\n UnixTime.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if ($util.Long) {\n var n = new $util.Long(0, 0, false);\n d.Seconds = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.Seconds = o.longs === String ? '0' : 0;\n d.FractionalNanoseconds = 0;\n }\n if (m.Seconds != null && m.hasOwnProperty('Seconds')) {\n if (typeof m.Seconds === 'number')\n d.Seconds = o.longs === String ? String(m.Seconds) : m.Seconds;\n else\n d.Seconds = o.longs === String ? $util.Long.prototype.toString.call(m.Seconds) : o.longs === Number ? new $util.LongBits(m.Seconds.low >>> 0, m.Seconds.high >>> 0).toNumber() : m.Seconds;\n }\n if (m.FractionalNanoseconds != null && m.hasOwnProperty('FractionalNanoseconds')) {\n d.FractionalNanoseconds = m.FractionalNanoseconds;\n }\n return d;\n };\n UnixTime.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default['default'].util.toJSONOptions);\n };\n return UnixTime;\n})();\nconst Metadata = $root.Metadata = (() => {\n function Metadata(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Metadata.prototype.MimeType = '';\n Metadata.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.MimeType != null && Object.hasOwnProperty.call(m, 'MimeType'))\n w.uint32(10).string(m.MimeType);\n return w;\n };\n Metadata.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Metadata();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.MimeType = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Metadata.fromObject = function fromObject(d) {\n if (d instanceof $root.Metadata)\n return d;\n var m = new $root.Metadata();\n if (d.MimeType != null) {\n m.MimeType = String(d.MimeType);\n }\n return m;\n };\n Metadata.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.MimeType = '';\n }\n if (m.MimeType != null && m.hasOwnProperty('MimeType')) {\n d.MimeType = m.MimeType;\n }\n return d;\n };\n Metadata.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default['default'].util.toJSONOptions);\n };\n return Metadata;\n})();\n\nexports.Data = Data;\nexports.Metadata = Metadata;\nexports.UnixTime = UnixTime;\nexports['default'] = $root;\n","// minimal library entry point.\n\n\"use strict\";\nmodule.exports = require(\"./src/index-minimal\");\n","\"use strict\";\nvar protobuf = exports;\n\n/**\n * Build type, one of `\"full\"`, `\"light\"` or `\"minimal\"`.\n * @name build\n * @type {string}\n * @const\n */\nprotobuf.build = \"minimal\";\n\n// Serialization\nprotobuf.Writer = require(\"./writer\");\nprotobuf.BufferWriter = require(\"./writer_buffer\");\nprotobuf.Reader = require(\"./reader\");\nprotobuf.BufferReader = require(\"./reader_buffer\");\n\n// Utility\nprotobuf.util = require(\"./util/minimal\");\nprotobuf.rpc = require(\"./rpc\");\nprotobuf.roots = require(\"./roots\");\nprotobuf.configure = configure;\n\n/* istanbul ignore next */\n/**\n * Reconfigures the library according to the environment.\n * @returns {undefined}\n */\nfunction configure() {\n protobuf.util._configure();\n protobuf.Writer._configure(protobuf.BufferWriter);\n protobuf.Reader._configure(protobuf.BufferReader);\n}\n\n// Set up buffer utility according to the environment\nconfigure();\n","\"use strict\";\nmodule.exports = Writer;\n\nvar util = require(\"./util/minimal\");\n\nvar BufferWriter; // cyclic\n\nvar LongBits = util.LongBits,\n base64 = util.base64,\n utf8 = util.utf8;\n\n/**\n * Constructs a new writer operation instance.\n * @classdesc Scheduled writer operation.\n * @constructor\n * @param {function(*, Uint8Array, number)} fn Function to call\n * @param {number} len Value byte length\n * @param {*} val Value to write\n * @ignore\n */\nfunction Op(fn, len, val) {\n\n /**\n * Function to call.\n * @type {function(Uint8Array, number, *)}\n */\n this.fn = fn;\n\n /**\n * Value byte length.\n * @type {number}\n */\n this.len = len;\n\n /**\n * Next operation.\n * @type {Writer.Op|undefined}\n */\n this.next = undefined;\n\n /**\n * Value to write.\n * @type {*}\n */\n this.val = val; // type varies\n}\n\n/* istanbul ignore next */\nfunction noop() {} // eslint-disable-line no-empty-function\n\n/**\n * Constructs a new writer state instance.\n * @classdesc Copied writer state.\n * @memberof Writer\n * @constructor\n * @param {Writer} writer Writer to copy state from\n * @ignore\n */\nfunction State(writer) {\n\n /**\n * Current head.\n * @type {Writer.Op}\n */\n this.head = writer.head;\n\n /**\n * Current tail.\n * @type {Writer.Op}\n */\n this.tail = writer.tail;\n\n /**\n * Current buffer length.\n * @type {number}\n */\n this.len = writer.len;\n\n /**\n * Next state.\n * @type {State|null}\n */\n this.next = writer.states;\n}\n\n/**\n * Constructs a new writer instance.\n * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`.\n * @constructor\n */\nfunction Writer() {\n\n /**\n * Current length.\n * @type {number}\n */\n this.len = 0;\n\n /**\n * Operations head.\n * @type {Object}\n */\n this.head = new Op(noop, 0, 0);\n\n /**\n * Operations tail\n * @type {Object}\n */\n this.tail = this.head;\n\n /**\n * Linked forked states.\n * @type {Object|null}\n */\n this.states = null;\n\n // When a value is written, the writer calculates its byte length and puts it into a linked\n // list of operations to perform when finish() is called. This both allows us to allocate\n // buffers of the exact required size and reduces the amount of work we have to do compared\n // to first calculating over objects and then encoding over objects. In our case, the encoding\n // part is just a linked list walk calling operations with already prepared values.\n}\n\nvar create = function create() {\n return util.Buffer\n ? function create_buffer_setup() {\n return (Writer.create = function create_buffer() {\n return new BufferWriter();\n })();\n }\n /* istanbul ignore next */\n : function create_array() {\n return new Writer();\n };\n};\n\n/**\n * Creates a new writer.\n * @function\n * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer}\n */\nWriter.create = create();\n\n/**\n * Allocates a buffer of the specified size.\n * @param {number} size Buffer size\n * @returns {Uint8Array} Buffer\n */\nWriter.alloc = function alloc(size) {\n return new util.Array(size);\n};\n\n// Use Uint8Array buffer pool in the browser, just like node does with buffers\n/* istanbul ignore else */\nif (util.Array !== Array)\n Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray);\n\n/**\n * Pushes a new operation to the queue.\n * @param {function(Uint8Array, number, *)} fn Function to call\n * @param {number} len Value byte length\n * @param {number} val Value to write\n * @returns {Writer} `this`\n * @private\n */\nWriter.prototype._push = function push(fn, len, val) {\n this.tail = this.tail.next = new Op(fn, len, val);\n this.len += len;\n return this;\n};\n\nfunction writeByte(val, buf, pos) {\n buf[pos] = val & 255;\n}\n\nfunction writeVarint32(val, buf, pos) {\n while (val > 127) {\n buf[pos++] = val & 127 | 128;\n val >>>= 7;\n }\n buf[pos] = val;\n}\n\n/**\n * Constructs a new varint writer operation instance.\n * @classdesc Scheduled varint writer operation.\n * @extends Op\n * @constructor\n * @param {number} len Value byte length\n * @param {number} val Value to write\n * @ignore\n */\nfunction VarintOp(len, val) {\n this.len = len;\n this.next = undefined;\n this.val = val;\n}\n\nVarintOp.prototype = Object.create(Op.prototype);\nVarintOp.prototype.fn = writeVarint32;\n\n/**\n * Writes an unsigned 32 bit value as a varint.\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.uint32 = function write_uint32(value) {\n // here, the call to this.push has been inlined and a varint specific Op subclass is used.\n // uint32 is by far the most frequently used operation and benefits significantly from this.\n this.len += (this.tail = this.tail.next = new VarintOp(\n (value = value >>> 0)\n < 128 ? 1\n : value < 16384 ? 2\n : value < 2097152 ? 3\n : value < 268435456 ? 4\n : 5,\n value)).len;\n return this;\n};\n\n/**\n * Writes a signed 32 bit value as a varint.\n * @function\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.int32 = function write_int32(value) {\n return value < 0\n ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec\n : this.uint32(value);\n};\n\n/**\n * Writes a 32 bit value as a varint, zig-zag encoded.\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.sint32 = function write_sint32(value) {\n return this.uint32((value << 1 ^ value >> 31) >>> 0);\n};\n\nfunction writeVarint64(val, buf, pos) {\n while (val.hi) {\n buf[pos++] = val.lo & 127 | 128;\n val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0;\n val.hi >>>= 7;\n }\n while (val.lo > 127) {\n buf[pos++] = val.lo & 127 | 128;\n val.lo = val.lo >>> 7;\n }\n buf[pos++] = val.lo;\n}\n\n/**\n * Writes an unsigned 64 bit value as a varint.\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.uint64 = function write_uint64(value) {\n var bits = LongBits.from(value);\n return this._push(writeVarint64, bits.length(), bits);\n};\n\n/**\n * Writes a signed 64 bit value as a varint.\n * @function\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.int64 = Writer.prototype.uint64;\n\n/**\n * Writes a signed 64 bit value as a varint, zig-zag encoded.\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.sint64 = function write_sint64(value) {\n var bits = LongBits.from(value).zzEncode();\n return this._push(writeVarint64, bits.length(), bits);\n};\n\n/**\n * Writes a boolish value as a varint.\n * @param {boolean} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.bool = function write_bool(value) {\n return this._push(writeByte, 1, value ? 1 : 0);\n};\n\nfunction writeFixed32(val, buf, pos) {\n buf[pos ] = val & 255;\n buf[pos + 1] = val >>> 8 & 255;\n buf[pos + 2] = val >>> 16 & 255;\n buf[pos + 3] = val >>> 24;\n}\n\n/**\n * Writes an unsigned 32 bit value as fixed 32 bits.\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.fixed32 = function write_fixed32(value) {\n return this._push(writeFixed32, 4, value >>> 0);\n};\n\n/**\n * Writes a signed 32 bit value as fixed 32 bits.\n * @function\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.sfixed32 = Writer.prototype.fixed32;\n\n/**\n * Writes an unsigned 64 bit value as fixed 64 bits.\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.fixed64 = function write_fixed64(value) {\n var bits = LongBits.from(value);\n return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi);\n};\n\n/**\n * Writes a signed 64 bit value as fixed 64 bits.\n * @function\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.sfixed64 = Writer.prototype.fixed64;\n\n/**\n * Writes a float (32 bit).\n * @function\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.float = function write_float(value) {\n return this._push(util.float.writeFloatLE, 4, value);\n};\n\n/**\n * Writes a double (64 bit float).\n * @function\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.double = function write_double(value) {\n return this._push(util.float.writeDoubleLE, 8, value);\n};\n\nvar writeBytes = util.Array.prototype.set\n ? function writeBytes_set(val, buf, pos) {\n buf.set(val, pos); // also works for plain array values\n }\n /* istanbul ignore next */\n : function writeBytes_for(val, buf, pos) {\n for (var i = 0; i < val.length; ++i)\n buf[pos + i] = val[i];\n };\n\n/**\n * Writes a sequence of bytes.\n * @param {Uint8Array|string} value Buffer or base64 encoded string to write\n * @returns {Writer} `this`\n */\nWriter.prototype.bytes = function write_bytes(value) {\n var len = value.length >>> 0;\n if (!len)\n return this._push(writeByte, 1, 0);\n if (util.isString(value)) {\n var buf = Writer.alloc(len = base64.length(value));\n base64.decode(value, buf, 0);\n value = buf;\n }\n return this.uint32(len)._push(writeBytes, len, value);\n};\n\n/**\n * Writes a string.\n * @param {string} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.string = function write_string(value) {\n var len = utf8.length(value);\n return len\n ? this.uint32(len)._push(utf8.write, len, value)\n : this._push(writeByte, 1, 0);\n};\n\n/**\n * Forks this writer's state by pushing it to a stack.\n * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state.\n * @returns {Writer} `this`\n */\nWriter.prototype.fork = function fork() {\n this.states = new State(this);\n this.head = this.tail = new Op(noop, 0, 0);\n this.len = 0;\n return this;\n};\n\n/**\n * Resets this instance to the last state.\n * @returns {Writer} `this`\n */\nWriter.prototype.reset = function reset() {\n if (this.states) {\n this.head = this.states.head;\n this.tail = this.states.tail;\n this.len = this.states.len;\n this.states = this.states.next;\n } else {\n this.head = this.tail = new Op(noop, 0, 0);\n this.len = 0;\n }\n return this;\n};\n\n/**\n * Resets to the last state and appends the fork state's current write length as a varint followed by its operations.\n * @returns {Writer} `this`\n */\nWriter.prototype.ldelim = function ldelim() {\n var head = this.head,\n tail = this.tail,\n len = this.len;\n this.reset().uint32(len);\n if (len) {\n this.tail.next = head.next; // skip noop\n this.tail = tail;\n this.len += len;\n }\n return this;\n};\n\n/**\n * Finishes the write operation.\n * @returns {Uint8Array} Finished buffer\n */\nWriter.prototype.finish = function finish() {\n var head = this.head.next, // skip noop\n buf = this.constructor.alloc(this.len),\n pos = 0;\n while (head) {\n head.fn(head.val, buf, pos);\n pos += head.len;\n head = head.next;\n }\n // this.head = this.tail = null;\n return buf;\n};\n\nWriter._configure = function(BufferWriter_) {\n BufferWriter = BufferWriter_;\n Writer.create = create();\n BufferWriter._configure();\n};\n","\"use strict\";\nvar util = exports;\n\n// used to return a Promise where callback is omitted\nutil.asPromise = require(\"@protobufjs/aspromise\");\n\n// converts to / from base64 encoded strings\nutil.base64 = require(\"@protobufjs/base64\");\n\n// base class of rpc.Service\nutil.EventEmitter = require(\"@protobufjs/eventemitter\");\n\n// float handling accross browsers\nutil.float = require(\"@protobufjs/float\");\n\n// requires modules optionally and hides the call from bundlers\nutil.inquire = require(\"@protobufjs/inquire\");\n\n// converts to / from utf8 encoded strings\nutil.utf8 = require(\"@protobufjs/utf8\");\n\n// provides a node-like buffer pool in the browser\nutil.pool = require(\"@protobufjs/pool\");\n\n// utility to work with the low and high bits of a 64 bit value\nutil.LongBits = require(\"./longbits\");\n\n/**\n * Whether running within node or not.\n * @memberof util\n * @type {boolean}\n */\nutil.isNode = Boolean(typeof global !== \"undefined\"\n && global\n && global.process\n && global.process.versions\n && global.process.versions.node);\n\n/**\n * Global object reference.\n * @memberof util\n * @type {Object}\n */\nutil.global = util.isNode && global\n || typeof window !== \"undefined\" && window\n || typeof self !== \"undefined\" && self\n || this; // eslint-disable-line no-invalid-this\n\n/**\n * An immuable empty array.\n * @memberof util\n * @type {Array.<*>}\n * @const\n */\nutil.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes\n\n/**\n * An immutable empty object.\n * @type {Object}\n * @const\n */\nutil.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes\n\n/**\n * Tests if the specified value is an integer.\n * @function\n * @param {*} value Value to test\n * @returns {boolean} `true` if the value is an integer\n */\nutil.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) {\n return typeof value === \"number\" && isFinite(value) && Math.floor(value) === value;\n};\n\n/**\n * Tests if the specified value is a string.\n * @param {*} value Value to test\n * @returns {boolean} `true` if the value is a string\n */\nutil.isString = function isString(value) {\n return typeof value === \"string\" || value instanceof String;\n};\n\n/**\n * Tests if the specified value is a non-null object.\n * @param {*} value Value to test\n * @returns {boolean} `true` if the value is a non-null object\n */\nutil.isObject = function isObject(value) {\n return value && typeof value === \"object\";\n};\n\n/**\n * Checks if a property on a message is considered to be present.\n * This is an alias of {@link util.isSet}.\n * @function\n * @param {Object} obj Plain object or message instance\n * @param {string} prop Property name\n * @returns {boolean} `true` if considered to be present, otherwise `false`\n */\nutil.isset =\n\n/**\n * Checks if a property on a message is considered to be present.\n * @param {Object} obj Plain object or message instance\n * @param {string} prop Property name\n * @returns {boolean} `true` if considered to be present, otherwise `false`\n */\nutil.isSet = function isSet(obj, prop) {\n var value = obj[prop];\n if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins\n return typeof value !== \"object\" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0;\n return false;\n};\n\n/**\n * Any compatible Buffer instance.\n * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings.\n * @interface Buffer\n * @extends Uint8Array\n */\n\n/**\n * Node's Buffer class if available.\n * @type {Constructor}\n */\nutil.Buffer = (function() {\n try {\n var Buffer = util.inquire(\"buffer\").Buffer;\n // refuse to use non-node buffers if not explicitly assigned (perf reasons):\n return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null;\n } catch (e) {\n /* istanbul ignore next */\n return null;\n }\n})();\n\n// Internal alias of or polyfull for Buffer.from.\nutil._Buffer_from = null;\n\n// Internal alias of or polyfill for Buffer.allocUnsafe.\nutil._Buffer_allocUnsafe = null;\n\n/**\n * Creates a new buffer of whatever type supported by the environment.\n * @param {number|number[]} [sizeOrArray=0] Buffer size or number array\n * @returns {Uint8Array|Buffer} Buffer\n */\nutil.newBuffer = function newBuffer(sizeOrArray) {\n /* istanbul ignore next */\n return typeof sizeOrArray === \"number\"\n ? util.Buffer\n ? util._Buffer_allocUnsafe(sizeOrArray)\n : new util.Array(sizeOrArray)\n : util.Buffer\n ? util._Buffer_from(sizeOrArray)\n : typeof Uint8Array === \"undefined\"\n ? sizeOrArray\n : new Uint8Array(sizeOrArray);\n};\n\n/**\n * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`.\n * @type {Constructor}\n */\nutil.Array = typeof Uint8Array !== \"undefined\" ? Uint8Array /* istanbul ignore next */ : Array;\n\n/**\n * Any compatible Long instance.\n * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js.\n * @interface Long\n * @property {number} low Low bits\n * @property {number} high High bits\n * @property {boolean} unsigned Whether unsigned or not\n */\n\n/**\n * Long.js's Long class if available.\n * @type {Constructor}\n */\nutil.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long\n || /* istanbul ignore next */ util.global.Long\n || util.inquire(\"long\");\n\n/**\n * Regular expression used to verify 2 bit (`bool`) map keys.\n * @type {RegExp}\n * @const\n */\nutil.key2Re = /^true|false|0|1$/;\n\n/**\n * Regular expression used to verify 32 bit (`int32` etc.) map keys.\n * @type {RegExp}\n * @const\n */\nutil.key32Re = /^-?(?:0|[1-9][0-9]*)$/;\n\n/**\n * Regular expression used to verify 64 bit (`int64` etc.) map keys.\n * @type {RegExp}\n * @const\n */\nutil.key64Re = /^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;\n\n/**\n * Converts a number or long to an 8 characters long hash string.\n * @param {Long|number} value Value to convert\n * @returns {string} Hash\n */\nutil.longToHash = function longToHash(value) {\n return value\n ? util.LongBits.from(value).toHash()\n : util.LongBits.zeroHash;\n};\n\n/**\n * Converts an 8 characters long hash string to a long or number.\n * @param {string} hash Hash\n * @param {boolean} [unsigned=false] Whether unsigned or not\n * @returns {Long|number} Original value\n */\nutil.longFromHash = function longFromHash(hash, unsigned) {\n var bits = util.LongBits.fromHash(hash);\n if (util.Long)\n return util.Long.fromBits(bits.lo, bits.hi, unsigned);\n return bits.toNumber(Boolean(unsigned));\n};\n\n/**\n * Merges the properties of the source object into the destination object.\n * @memberof util\n * @param {Object.} dst Destination object\n * @param {Object.} src Source object\n * @param {boolean} [ifNotSet=false] Merges only if the key is not already set\n * @returns {Object.} Destination object\n */\nfunction merge(dst, src, ifNotSet) { // used by converters\n for (var keys = Object.keys(src), i = 0; i < keys.length; ++i)\n if (dst[keys[i]] === undefined || !ifNotSet)\n dst[keys[i]] = src[keys[i]];\n return dst;\n}\n\nutil.merge = merge;\n\n/**\n * Converts the first character of a string to lower case.\n * @param {string} str String to convert\n * @returns {string} Converted string\n */\nutil.lcFirst = function lcFirst(str) {\n return str.charAt(0).toLowerCase() + str.substring(1);\n};\n\n/**\n * Creates a custom error constructor.\n * @memberof util\n * @param {string} name Error name\n * @returns {Constructor} Custom error constructor\n */\nfunction newError(name) {\n\n function CustomError(message, properties) {\n\n if (!(this instanceof CustomError))\n return new CustomError(message, properties);\n\n // Error.call(this, message);\n // ^ just returns a new error instance because the ctor can be called as a function\n\n Object.defineProperty(this, \"message\", { get: function() { return message; } });\n\n /* istanbul ignore next */\n if (Error.captureStackTrace) // node\n Error.captureStackTrace(this, CustomError);\n else\n Object.defineProperty(this, \"stack\", { value: new Error().stack || \"\" });\n\n if (properties)\n merge(this, properties);\n }\n\n (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError;\n\n Object.defineProperty(CustomError.prototype, \"name\", { get: function() { return name; } });\n\n CustomError.prototype.toString = function toString() {\n return this.name + \": \" + this.message;\n };\n\n return CustomError;\n}\n\nutil.newError = newError;\n\n/**\n * Constructs a new protocol error.\n * @classdesc Error subclass indicating a protocol specifc error.\n * @memberof util\n * @extends Error\n * @template T extends Message\n * @constructor\n * @param {string} message Error message\n * @param {Object.} [properties] Additional properties\n * @example\n * try {\n * MyMessage.decode(someBuffer); // throws if required fields are missing\n * } catch (e) {\n * if (e instanceof ProtocolError && e.instance)\n * console.log(\"decoded so far: \" + JSON.stringify(e.instance));\n * }\n */\nutil.ProtocolError = newError(\"ProtocolError\");\n\n/**\n * So far decoded message instance.\n * @name util.ProtocolError#instance\n * @type {Message}\n */\n\n/**\n * A OneOf getter as returned by {@link util.oneOfGetter}.\n * @typedef OneOfGetter\n * @type {function}\n * @returns {string|undefined} Set field name, if any\n */\n\n/**\n * Builds a getter for a oneof's present field name.\n * @param {string[]} fieldNames Field names\n * @returns {OneOfGetter} Unbound getter\n */\nutil.oneOfGetter = function getOneOf(fieldNames) {\n var fieldMap = {};\n for (var i = 0; i < fieldNames.length; ++i)\n fieldMap[fieldNames[i]] = 1;\n\n /**\n * @returns {string|undefined} Set field name, if any\n * @this Object\n * @ignore\n */\n return function() { // eslint-disable-line consistent-return\n for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i)\n if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null)\n return keys[i];\n };\n};\n\n/**\n * A OneOf setter as returned by {@link util.oneOfSetter}.\n * @typedef OneOfSetter\n * @type {function}\n * @param {string|undefined} value Field name\n * @returns {undefined}\n */\n\n/**\n * Builds a setter for a oneof's present field name.\n * @param {string[]} fieldNames Field names\n * @returns {OneOfSetter} Unbound setter\n */\nutil.oneOfSetter = function setOneOf(fieldNames) {\n\n /**\n * @param {string} name Field name\n * @returns {undefined}\n * @this Object\n * @ignore\n */\n return function(name) {\n for (var i = 0; i < fieldNames.length; ++i)\n if (fieldNames[i] !== name)\n delete this[fieldNames[i]];\n };\n};\n\n/**\n * Default conversion options used for {@link Message#toJSON} implementations.\n *\n * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely:\n *\n * - Longs become strings\n * - Enums become string keys\n * - Bytes become base64 encoded strings\n * - (Sub-)Messages become plain objects\n * - Maps become plain objects with all string keys\n * - Repeated fields become arrays\n * - NaN and Infinity for float and double fields become strings\n *\n * @type {IConversionOptions}\n * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json\n */\nutil.toJSONOptions = {\n longs: String,\n enums: String,\n bytes: String,\n json: true\n};\n\n// Sets up buffer utility according to the environment (called in index-minimal)\nutil._configure = function() {\n var Buffer = util.Buffer;\n /* istanbul ignore if */\n if (!Buffer) {\n util._Buffer_from = util._Buffer_allocUnsafe = null;\n return;\n }\n // because node 4.x buffers are incompatible & immutable\n // see: https://github.com/dcodeIO/protobuf.js/pull/665\n util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from ||\n /* istanbul ignore next */\n function Buffer_from(value, encoding) {\n return new Buffer(value, encoding);\n };\n util._Buffer_allocUnsafe = Buffer.allocUnsafe ||\n /* istanbul ignore next */\n function Buffer_allocUnsafe(size) {\n return new Buffer(size);\n };\n};\n","\"use strict\";\r\nmodule.exports = asPromise;\r\n\r\n/**\r\n * Callback as used by {@link util.asPromise}.\r\n * @typedef asPromiseCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {...*} params Additional arguments\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Returns a promise from a node-style callback function.\r\n * @memberof util\r\n * @param {asPromiseCallback} fn Function to call\r\n * @param {*} ctx Function context\r\n * @param {...*} params Function arguments\r\n * @returns {Promise<*>} Promisified function\r\n */\r\nfunction asPromise(fn, ctx/*, varargs */) {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0,\r\n index = 2,\r\n pending = true;\r\n while (index < arguments.length)\r\n params[offset++] = arguments[index++];\r\n return new Promise(function executor(resolve, reject) {\r\n params[offset] = function callback(err/*, varargs */) {\r\n if (pending) {\r\n pending = false;\r\n if (err)\r\n reject(err);\r\n else {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0;\r\n while (offset < params.length)\r\n params[offset++] = arguments[offset];\r\n resolve.apply(null, params);\r\n }\r\n }\r\n };\r\n try {\r\n fn.apply(ctx || null, params);\r\n } catch (err) {\r\n if (pending) {\r\n pending = false;\r\n reject(err);\r\n }\r\n }\r\n });\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal base64 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar base64 = exports;\r\n\r\n/**\r\n * Calculates the byte length of a base64 encoded string.\r\n * @param {string} string Base64 encoded string\r\n * @returns {number} Byte length\r\n */\r\nbase64.length = function length(string) {\r\n var p = string.length;\r\n if (!p)\r\n return 0;\r\n var n = 0;\r\n while (--p % 4 > 1 && string.charAt(p) === \"=\")\r\n ++n;\r\n return Math.ceil(string.length * 3) / 4 - n;\r\n};\r\n\r\n// Base64 encoding table\r\nvar b64 = new Array(64);\r\n\r\n// Base64 decoding table\r\nvar s64 = new Array(123);\r\n\r\n// 65..90, 97..122, 48..57, 43, 47\r\nfor (var i = 0; i < 64;)\r\n s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++;\r\n\r\n/**\r\n * Encodes a buffer to a base64 encoded string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} Base64 encoded string\r\n */\r\nbase64.encode = function encode(buffer, start, end) {\r\n var parts = null,\r\n chunk = [];\r\n var i = 0, // output index\r\n j = 0, // goto index\r\n t; // temporary\r\n while (start < end) {\r\n var b = buffer[start++];\r\n switch (j) {\r\n case 0:\r\n chunk[i++] = b64[b >> 2];\r\n t = (b & 3) << 4;\r\n j = 1;\r\n break;\r\n case 1:\r\n chunk[i++] = b64[t | b >> 4];\r\n t = (b & 15) << 2;\r\n j = 2;\r\n break;\r\n case 2:\r\n chunk[i++] = b64[t | b >> 6];\r\n chunk[i++] = b64[b & 63];\r\n j = 0;\r\n break;\r\n }\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (j) {\r\n chunk[i++] = b64[t];\r\n chunk[i++] = 61;\r\n if (j === 1)\r\n chunk[i++] = 61;\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\nvar invalidEncoding = \"invalid encoding\";\r\n\r\n/**\r\n * Decodes a base64 encoded string to a buffer.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Number of bytes written\r\n * @throws {Error} If encoding is invalid\r\n */\r\nbase64.decode = function decode(string, buffer, offset) {\r\n var start = offset;\r\n var j = 0, // goto index\r\n t; // temporary\r\n for (var i = 0; i < string.length;) {\r\n var c = string.charCodeAt(i++);\r\n if (c === 61 && j > 1)\r\n break;\r\n if ((c = s64[c]) === undefined)\r\n throw Error(invalidEncoding);\r\n switch (j) {\r\n case 0:\r\n t = c;\r\n j = 1;\r\n break;\r\n case 1:\r\n buffer[offset++] = t << 2 | (c & 48) >> 4;\r\n t = c;\r\n j = 2;\r\n break;\r\n case 2:\r\n buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2;\r\n t = c;\r\n j = 3;\r\n break;\r\n case 3:\r\n buffer[offset++] = (t & 3) << 6 | c;\r\n j = 0;\r\n break;\r\n }\r\n }\r\n if (j === 1)\r\n throw Error(invalidEncoding);\r\n return offset - start;\r\n};\r\n\r\n/**\r\n * Tests if the specified string appears to be base64 encoded.\r\n * @param {string} string String to test\r\n * @returns {boolean} `true` if probably base64 encoded, otherwise false\r\n */\r\nbase64.test = function test(string) {\r\n return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string);\r\n};\r\n","\"use strict\";\r\nmodule.exports = EventEmitter;\r\n\r\n/**\r\n * Constructs a new event emitter instance.\r\n * @classdesc A minimal event emitter.\r\n * @memberof util\r\n * @constructor\r\n */\r\nfunction EventEmitter() {\r\n\r\n /**\r\n * Registered listeners.\r\n * @type {Object.}\r\n * @private\r\n */\r\n this._listeners = {};\r\n}\r\n\r\n/**\r\n * Registers an event listener.\r\n * @param {string} evt Event name\r\n * @param {function} fn Listener\r\n * @param {*} [ctx] Listener context\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.on = function on(evt, fn, ctx) {\r\n (this._listeners[evt] || (this._listeners[evt] = [])).push({\r\n fn : fn,\r\n ctx : ctx || this\r\n });\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes an event listener or any matching listeners if arguments are omitted.\r\n * @param {string} [evt] Event name. Removes all listeners if omitted.\r\n * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted.\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.off = function off(evt, fn) {\r\n if (evt === undefined)\r\n this._listeners = {};\r\n else {\r\n if (fn === undefined)\r\n this._listeners[evt] = [];\r\n else {\r\n var listeners = this._listeners[evt];\r\n for (var i = 0; i < listeners.length;)\r\n if (listeners[i].fn === fn)\r\n listeners.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Emits an event by calling its listeners with the specified arguments.\r\n * @param {string} evt Event name\r\n * @param {...*} args Arguments\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.emit = function emit(evt) {\r\n var listeners = this._listeners[evt];\r\n if (listeners) {\r\n var args = [],\r\n i = 1;\r\n for (; i < arguments.length;)\r\n args.push(arguments[i++]);\r\n for (i = 0; i < listeners.length;)\r\n listeners[i].fn.apply(listeners[i++].ctx, args);\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\n\r\nmodule.exports = factory(factory);\r\n\r\n/**\r\n * Reads / writes floats / doubles from / to buffers.\r\n * @name util.float\r\n * @namespace\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using little endian byte order.\r\n * @name util.float.writeFloatLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using big endian byte order.\r\n * @name util.float.writeFloatBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using little endian byte order.\r\n * @name util.float.readFloatLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using big endian byte order.\r\n * @name util.float.readFloatBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using little endian byte order.\r\n * @name util.float.writeDoubleLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using big endian byte order.\r\n * @name util.float.writeDoubleBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using little endian byte order.\r\n * @name util.float.readDoubleLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using big endian byte order.\r\n * @name util.float.readDoubleBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n// Factory function for the purpose of node-based testing in modified global environments\r\nfunction factory(exports) {\r\n\r\n // float: typed array\r\n if (typeof Float32Array !== \"undefined\") (function() {\r\n\r\n var f32 = new Float32Array([ -0 ]),\r\n f8b = new Uint8Array(f32.buffer),\r\n le = f8b[3] === 128;\r\n\r\n function writeFloat_f32_cpy(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n }\r\n\r\n function writeFloat_f32_rev(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[3];\r\n buf[pos + 1] = f8b[2];\r\n buf[pos + 2] = f8b[1];\r\n buf[pos + 3] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy;\r\n\r\n function readFloat_f32_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n function readFloat_f32_rev(buf, pos) {\r\n f8b[3] = buf[pos ];\r\n f8b[2] = buf[pos + 1];\r\n f8b[1] = buf[pos + 2];\r\n f8b[0] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy;\r\n\r\n // float: ieee754\r\n })(); else (function() {\r\n\r\n function writeFloat_ieee754(writeUint, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0)\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos);\r\n else if (isNaN(val))\r\n writeUint(2143289344, buf, pos);\r\n else if (val > 3.4028234663852886e+38) // +-Infinity\r\n writeUint((sign << 31 | 2139095040) >>> 0, buf, pos);\r\n else if (val < 1.1754943508222875e-38) // denormal\r\n writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos);\r\n else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2),\r\n mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607;\r\n writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos);\r\n }\r\n }\r\n\r\n exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE);\r\n exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE);\r\n\r\n function readFloat_ieee754(readUint, buf, pos) {\r\n var uint = readUint(buf, pos),\r\n sign = (uint >> 31) * 2 + 1,\r\n exponent = uint >>> 23 & 255,\r\n mantissa = uint & 8388607;\r\n return exponent === 255\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 1.401298464324817e-45 * mantissa\r\n : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608);\r\n }\r\n\r\n exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE);\r\n exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE);\r\n\r\n })();\r\n\r\n // double: typed array\r\n if (typeof Float64Array !== \"undefined\") (function() {\r\n\r\n var f64 = new Float64Array([-0]),\r\n f8b = new Uint8Array(f64.buffer),\r\n le = f8b[7] === 128;\r\n\r\n function writeDouble_f64_cpy(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n buf[pos + 4] = f8b[4];\r\n buf[pos + 5] = f8b[5];\r\n buf[pos + 6] = f8b[6];\r\n buf[pos + 7] = f8b[7];\r\n }\r\n\r\n function writeDouble_f64_rev(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[7];\r\n buf[pos + 1] = f8b[6];\r\n buf[pos + 2] = f8b[5];\r\n buf[pos + 3] = f8b[4];\r\n buf[pos + 4] = f8b[3];\r\n buf[pos + 5] = f8b[2];\r\n buf[pos + 6] = f8b[1];\r\n buf[pos + 7] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy;\r\n\r\n function readDouble_f64_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n f8b[4] = buf[pos + 4];\r\n f8b[5] = buf[pos + 5];\r\n f8b[6] = buf[pos + 6];\r\n f8b[7] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n function readDouble_f64_rev(buf, pos) {\r\n f8b[7] = buf[pos ];\r\n f8b[6] = buf[pos + 1];\r\n f8b[5] = buf[pos + 2];\r\n f8b[4] = buf[pos + 3];\r\n f8b[3] = buf[pos + 4];\r\n f8b[2] = buf[pos + 5];\r\n f8b[1] = buf[pos + 6];\r\n f8b[0] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy;\r\n\r\n // double: ieee754\r\n })(); else (function() {\r\n\r\n function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1);\r\n } else if (isNaN(val)) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(2146959360, buf, pos + off1);\r\n } else if (val > 1.7976931348623157e+308) { // +-Infinity\r\n writeUint(0, buf, pos + off0);\r\n writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1);\r\n } else {\r\n var mantissa;\r\n if (val < 2.2250738585072014e-308) { // denormal\r\n mantissa = val / 5e-324;\r\n writeUint(mantissa >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1);\r\n } else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2);\r\n if (exponent === 1024)\r\n exponent = 1023;\r\n mantissa = val * Math.pow(2, -exponent);\r\n writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1);\r\n }\r\n }\r\n }\r\n\r\n exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4);\r\n exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0);\r\n\r\n function readDouble_ieee754(readUint, off0, off1, buf, pos) {\r\n var lo = readUint(buf, pos + off0),\r\n hi = readUint(buf, pos + off1);\r\n var sign = (hi >> 31) * 2 + 1,\r\n exponent = hi >>> 20 & 2047,\r\n mantissa = 4294967296 * (hi & 1048575) + lo;\r\n return exponent === 2047\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 5e-324 * mantissa\r\n : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496);\r\n }\r\n\r\n exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4);\r\n exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0);\r\n\r\n })();\r\n\r\n return exports;\r\n}\r\n\r\n// uint helpers\r\n\r\nfunction writeUintLE(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\nfunction writeUintBE(val, buf, pos) {\r\n buf[pos ] = val >>> 24;\r\n buf[pos + 1] = val >>> 16 & 255;\r\n buf[pos + 2] = val >>> 8 & 255;\r\n buf[pos + 3] = val & 255;\r\n}\r\n\r\nfunction readUintLE(buf, pos) {\r\n return (buf[pos ]\r\n | buf[pos + 1] << 8\r\n | buf[pos + 2] << 16\r\n | buf[pos + 3] << 24) >>> 0;\r\n}\r\n\r\nfunction readUintBE(buf, pos) {\r\n return (buf[pos ] << 24\r\n | buf[pos + 1] << 16\r\n | buf[pos + 2] << 8\r\n | buf[pos + 3]) >>> 0;\r\n}\r\n","\"use strict\";\r\nmodule.exports = inquire;\r\n\r\n/**\r\n * Requires a module only if available.\r\n * @memberof util\r\n * @param {string} moduleName Module to require\r\n * @returns {?Object} Required module if available and not empty, otherwise `null`\r\n */\r\nfunction inquire(moduleName) {\r\n try {\r\n var mod = eval(\"quire\".replace(/^/,\"re\"))(moduleName); // eslint-disable-line no-eval\r\n if (mod && (mod.length || Object.keys(mod).length))\r\n return mod;\r\n } catch (e) {} // eslint-disable-line no-empty\r\n return null;\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","\"use strict\";\r\nmodule.exports = pool;\r\n\r\n/**\r\n * An allocator as used by {@link util.pool}.\r\n * @typedef PoolAllocator\r\n * @type {function}\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\n\r\n/**\r\n * A slicer as used by {@link util.pool}.\r\n * @typedef PoolSlicer\r\n * @type {function}\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {Uint8Array} Buffer slice\r\n * @this {Uint8Array}\r\n */\r\n\r\n/**\r\n * A general purpose buffer pool.\r\n * @memberof util\r\n * @function\r\n * @param {PoolAllocator} alloc Allocator\r\n * @param {PoolSlicer} slice Slicer\r\n * @param {number} [size=8192] Slab size\r\n * @returns {PoolAllocator} Pooled allocator\r\n */\r\nfunction pool(alloc, slice, size) {\r\n var SIZE = size || 8192;\r\n var MAX = SIZE >>> 1;\r\n var slab = null;\r\n var offset = SIZE;\r\n return function pool_alloc(size) {\r\n if (size < 1 || size > MAX)\r\n return alloc(size);\r\n if (offset + size > SIZE) {\r\n slab = alloc(SIZE);\r\n offset = 0;\r\n }\r\n var buf = slice.call(slab, offset, offset += size);\r\n if (offset & 7) // align to 32 bit\r\n offset = (offset | 7) + 1;\r\n return buf;\r\n };\r\n}\r\n","\"use strict\";\nmodule.exports = LongBits;\n\nvar util = require(\"../util/minimal\");\n\n/**\n * Constructs new long bits.\n * @classdesc Helper class for working with the low and high bits of a 64 bit value.\n * @memberof util\n * @constructor\n * @param {number} lo Low 32 bits, unsigned\n * @param {number} hi High 32 bits, unsigned\n */\nfunction LongBits(lo, hi) {\n\n // note that the casts below are theoretically unnecessary as of today, but older statically\n // generated converter code might still call the ctor with signed 32bits. kept for compat.\n\n /**\n * Low bits.\n * @type {number}\n */\n this.lo = lo >>> 0;\n\n /**\n * High bits.\n * @type {number}\n */\n this.hi = hi >>> 0;\n}\n\n/**\n * Zero bits.\n * @memberof util.LongBits\n * @type {util.LongBits}\n */\nvar zero = LongBits.zero = new LongBits(0, 0);\n\nzero.toNumber = function() { return 0; };\nzero.zzEncode = zero.zzDecode = function() { return this; };\nzero.length = function() { return 1; };\n\n/**\n * Zero hash.\n * @memberof util.LongBits\n * @type {string}\n */\nvar zeroHash = LongBits.zeroHash = \"\\0\\0\\0\\0\\0\\0\\0\\0\";\n\n/**\n * Constructs new long bits from the specified number.\n * @param {number} value Value\n * @returns {util.LongBits} Instance\n */\nLongBits.fromNumber = function fromNumber(value) {\n if (value === 0)\n return zero;\n var sign = value < 0;\n if (sign)\n value = -value;\n var lo = value >>> 0,\n hi = (value - lo) / 4294967296 >>> 0;\n if (sign) {\n hi = ~hi >>> 0;\n lo = ~lo >>> 0;\n if (++lo > 4294967295) {\n lo = 0;\n if (++hi > 4294967295)\n hi = 0;\n }\n }\n return new LongBits(lo, hi);\n};\n\n/**\n * Constructs new long bits from a number, long or string.\n * @param {Long|number|string} value Value\n * @returns {util.LongBits} Instance\n */\nLongBits.from = function from(value) {\n if (typeof value === \"number\")\n return LongBits.fromNumber(value);\n if (util.isString(value)) {\n /* istanbul ignore else */\n if (util.Long)\n value = util.Long.fromString(value);\n else\n return LongBits.fromNumber(parseInt(value, 10));\n }\n return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero;\n};\n\n/**\n * Converts this long bits to a possibly unsafe JavaScript number.\n * @param {boolean} [unsigned=false] Whether unsigned or not\n * @returns {number} Possibly unsafe number\n */\nLongBits.prototype.toNumber = function toNumber(unsigned) {\n if (!unsigned && this.hi >>> 31) {\n var lo = ~this.lo + 1 >>> 0,\n hi = ~this.hi >>> 0;\n if (!lo)\n hi = hi + 1 >>> 0;\n return -(lo + hi * 4294967296);\n }\n return this.lo + this.hi * 4294967296;\n};\n\n/**\n * Converts this long bits to a long.\n * @param {boolean} [unsigned=false] Whether unsigned or not\n * @returns {Long} Long\n */\nLongBits.prototype.toLong = function toLong(unsigned) {\n return util.Long\n ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned))\n /* istanbul ignore next */\n : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) };\n};\n\nvar charCodeAt = String.prototype.charCodeAt;\n\n/**\n * Constructs new long bits from the specified 8 characters long hash.\n * @param {string} hash Hash\n * @returns {util.LongBits} Bits\n */\nLongBits.fromHash = function fromHash(hash) {\n if (hash === zeroHash)\n return zero;\n return new LongBits(\n ( charCodeAt.call(hash, 0)\n | charCodeAt.call(hash, 1) << 8\n | charCodeAt.call(hash, 2) << 16\n | charCodeAt.call(hash, 3) << 24) >>> 0\n ,\n ( charCodeAt.call(hash, 4)\n | charCodeAt.call(hash, 5) << 8\n | charCodeAt.call(hash, 6) << 16\n | charCodeAt.call(hash, 7) << 24) >>> 0\n );\n};\n\n/**\n * Converts this long bits to a 8 characters long hash.\n * @returns {string} Hash\n */\nLongBits.prototype.toHash = function toHash() {\n return String.fromCharCode(\n this.lo & 255,\n this.lo >>> 8 & 255,\n this.lo >>> 16 & 255,\n this.lo >>> 24 ,\n this.hi & 255,\n this.hi >>> 8 & 255,\n this.hi >>> 16 & 255,\n this.hi >>> 24\n );\n};\n\n/**\n * Zig-zag encodes this long bits.\n * @returns {util.LongBits} `this`\n */\nLongBits.prototype.zzEncode = function zzEncode() {\n var mask = this.hi >> 31;\n this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0;\n this.lo = ( this.lo << 1 ^ mask) >>> 0;\n return this;\n};\n\n/**\n * Zig-zag decodes this long bits.\n * @returns {util.LongBits} `this`\n */\nLongBits.prototype.zzDecode = function zzDecode() {\n var mask = -(this.lo & 1);\n this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0;\n this.hi = ( this.hi >>> 1 ^ mask) >>> 0;\n return this;\n};\n\n/**\n * Calculates the length of this longbits when encoded as a varint.\n * @returns {number} Length\n */\nLongBits.prototype.length = function length() {\n var part0 = this.lo,\n part1 = (this.lo >>> 28 | this.hi << 4) >>> 0,\n part2 = this.hi >>> 24;\n return part2 === 0\n ? part1 === 0\n ? part0 < 16384\n ? part0 < 128 ? 1 : 2\n : part0 < 2097152 ? 3 : 4\n : part1 < 16384\n ? part1 < 128 ? 5 : 6\n : part1 < 2097152 ? 7 : 8\n : part2 < 128 ? 9 : 10;\n};\n","\"use strict\";\nmodule.exports = BufferWriter;\n\n// extends Writer\nvar Writer = require(\"./writer\");\n(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter;\n\nvar util = require(\"./util/minimal\");\n\n/**\n * Constructs a new buffer writer instance.\n * @classdesc Wire format writer using node buffers.\n * @extends Writer\n * @constructor\n */\nfunction BufferWriter() {\n Writer.call(this);\n}\n\nBufferWriter._configure = function () {\n /**\n * Allocates a buffer of the specified size.\n * @function\n * @param {number} size Buffer size\n * @returns {Buffer} Buffer\n */\n BufferWriter.alloc = util._Buffer_allocUnsafe;\n\n BufferWriter.writeBytesBuffer = util.Buffer && util.Buffer.prototype instanceof Uint8Array && util.Buffer.prototype.set.name === \"set\"\n ? function writeBytesBuffer_set(val, buf, pos) {\n buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)\n // also works for plain array values\n }\n /* istanbul ignore next */\n : function writeBytesBuffer_copy(val, buf, pos) {\n if (val.copy) // Buffer values\n val.copy(buf, pos, 0, val.length);\n else for (var i = 0; i < val.length;) // plain array values\n buf[pos++] = val[i++];\n };\n};\n\n\n/**\n * @override\n */\nBufferWriter.prototype.bytes = function write_bytes_buffer(value) {\n if (util.isString(value))\n value = util._Buffer_from(value, \"base64\");\n var len = value.length >>> 0;\n this.uint32(len);\n if (len)\n this._push(BufferWriter.writeBytesBuffer, len, value);\n return this;\n};\n\nfunction writeStringBuffer(val, buf, pos) {\n if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions)\n util.utf8.write(val, buf, pos);\n else if (buf.utf8Write)\n buf.utf8Write(val, pos);\n else\n buf.write(val, pos);\n}\n\n/**\n * @override\n */\nBufferWriter.prototype.string = function write_string_buffer(value) {\n var len = util.Buffer.byteLength(value);\n this.uint32(len);\n if (len)\n this._push(writeStringBuffer, len, value);\n return this;\n};\n\n\n/**\n * Finishes the write operation.\n * @name BufferWriter#finish\n * @function\n * @returns {Buffer} Finished buffer\n */\n\nBufferWriter._configure();\n","\"use strict\";\nmodule.exports = Reader;\n\nvar util = require(\"./util/minimal\");\n\nvar BufferReader; // cyclic\n\nvar LongBits = util.LongBits,\n utf8 = util.utf8;\n\n/* istanbul ignore next */\nfunction indexOutOfRange(reader, writeLength) {\n return RangeError(\"index out of range: \" + reader.pos + \" + \" + (writeLength || 1) + \" > \" + reader.len);\n}\n\n/**\n * Constructs a new reader instance using the specified buffer.\n * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`.\n * @constructor\n * @param {Uint8Array} buffer Buffer to read from\n */\nfunction Reader(buffer) {\n\n /**\n * Read buffer.\n * @type {Uint8Array}\n */\n this.buf = buffer;\n\n /**\n * Read buffer position.\n * @type {number}\n */\n this.pos = 0;\n\n /**\n * Read buffer length.\n * @type {number}\n */\n this.len = buffer.length;\n}\n\nvar create_array = typeof Uint8Array !== \"undefined\"\n ? function create_typed_array(buffer) {\n if (buffer instanceof Uint8Array || Array.isArray(buffer))\n return new Reader(buffer);\n throw Error(\"illegal buffer\");\n }\n /* istanbul ignore next */\n : function create_array(buffer) {\n if (Array.isArray(buffer))\n return new Reader(buffer);\n throw Error(\"illegal buffer\");\n };\n\nvar create = function create() {\n return util.Buffer\n ? function create_buffer_setup(buffer) {\n return (Reader.create = function create_buffer(buffer) {\n return util.Buffer.isBuffer(buffer)\n ? new BufferReader(buffer)\n /* istanbul ignore next */\n : create_array(buffer);\n })(buffer);\n }\n /* istanbul ignore next */\n : create_array;\n};\n\n/**\n * Creates a new reader using the specified buffer.\n * @function\n * @param {Uint8Array|Buffer} buffer Buffer to read from\n * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader}\n * @throws {Error} If `buffer` is not a valid buffer\n */\nReader.create = create();\n\nReader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice;\n\n/**\n * Reads a varint as an unsigned 32 bit value.\n * @function\n * @returns {number} Value read\n */\nReader.prototype.uint32 = (function read_uint32_setup() {\n var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!)\n return function read_uint32() {\n value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value;\n value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value;\n value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value;\n value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value;\n value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value;\n\n /* istanbul ignore if */\n if ((this.pos += 5) > this.len) {\n this.pos = this.len;\n throw indexOutOfRange(this, 10);\n }\n return value;\n };\n})();\n\n/**\n * Reads a varint as a signed 32 bit value.\n * @returns {number} Value read\n */\nReader.prototype.int32 = function read_int32() {\n return this.uint32() | 0;\n};\n\n/**\n * Reads a zig-zag encoded varint as a signed 32 bit value.\n * @returns {number} Value read\n */\nReader.prototype.sint32 = function read_sint32() {\n var value = this.uint32();\n return value >>> 1 ^ -(value & 1) | 0;\n};\n\n/* eslint-disable no-invalid-this */\n\nfunction readLongVarint() {\n // tends to deopt with local vars for octet etc.\n var bits = new LongBits(0, 0);\n var i = 0;\n if (this.len - this.pos > 4) { // fast route (lo)\n for (; i < 4; ++i) {\n // 1st..4th\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n }\n // 5th\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0;\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n i = 0;\n } else {\n for (; i < 3; ++i) {\n /* istanbul ignore if */\n if (this.pos >= this.len)\n throw indexOutOfRange(this);\n // 1st..3th\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n }\n // 4th\n bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0;\n return bits;\n }\n if (this.len - this.pos > 4) { // fast route (hi)\n for (; i < 5; ++i) {\n // 6th..10th\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n }\n } else {\n for (; i < 5; ++i) {\n /* istanbul ignore if */\n if (this.pos >= this.len)\n throw indexOutOfRange(this);\n // 6th..10th\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n }\n }\n /* istanbul ignore next */\n throw Error(\"invalid varint encoding\");\n}\n\n/* eslint-enable no-invalid-this */\n\n/**\n * Reads a varint as a signed 64 bit value.\n * @name Reader#int64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads a varint as an unsigned 64 bit value.\n * @name Reader#uint64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads a zig-zag encoded varint as a signed 64 bit value.\n * @name Reader#sint64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads a varint as a boolean.\n * @returns {boolean} Value read\n */\nReader.prototype.bool = function read_bool() {\n return this.uint32() !== 0;\n};\n\nfunction readFixed32_end(buf, end) { // note that this uses `end`, not `pos`\n return (buf[end - 4]\n | buf[end - 3] << 8\n | buf[end - 2] << 16\n | buf[end - 1] << 24) >>> 0;\n}\n\n/**\n * Reads fixed 32 bits as an unsigned 32 bit integer.\n * @returns {number} Value read\n */\nReader.prototype.fixed32 = function read_fixed32() {\n\n /* istanbul ignore if */\n if (this.pos + 4 > this.len)\n throw indexOutOfRange(this, 4);\n\n return readFixed32_end(this.buf, this.pos += 4);\n};\n\n/**\n * Reads fixed 32 bits as a signed 32 bit integer.\n * @returns {number} Value read\n */\nReader.prototype.sfixed32 = function read_sfixed32() {\n\n /* istanbul ignore if */\n if (this.pos + 4 > this.len)\n throw indexOutOfRange(this, 4);\n\n return readFixed32_end(this.buf, this.pos += 4) | 0;\n};\n\n/* eslint-disable no-invalid-this */\n\nfunction readFixed64(/* this: Reader */) {\n\n /* istanbul ignore if */\n if (this.pos + 8 > this.len)\n throw indexOutOfRange(this, 8);\n\n return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4));\n}\n\n/* eslint-enable no-invalid-this */\n\n/**\n * Reads fixed 64 bits.\n * @name Reader#fixed64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads zig-zag encoded fixed 64 bits.\n * @name Reader#sfixed64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads a float (32 bit) as a number.\n * @function\n * @returns {number} Value read\n */\nReader.prototype.float = function read_float() {\n\n /* istanbul ignore if */\n if (this.pos + 4 > this.len)\n throw indexOutOfRange(this, 4);\n\n var value = util.float.readFloatLE(this.buf, this.pos);\n this.pos += 4;\n return value;\n};\n\n/**\n * Reads a double (64 bit float) as a number.\n * @function\n * @returns {number} Value read\n */\nReader.prototype.double = function read_double() {\n\n /* istanbul ignore if */\n if (this.pos + 8 > this.len)\n throw indexOutOfRange(this, 4);\n\n var value = util.float.readDoubleLE(this.buf, this.pos);\n this.pos += 8;\n return value;\n};\n\n/**\n * Reads a sequence of bytes preceeded by its length as a varint.\n * @returns {Uint8Array} Value read\n */\nReader.prototype.bytes = function read_bytes() {\n var length = this.uint32(),\n start = this.pos,\n end = this.pos + length;\n\n /* istanbul ignore if */\n if (end > this.len)\n throw indexOutOfRange(this, length);\n\n this.pos += length;\n if (Array.isArray(this.buf)) // plain array\n return this.buf.slice(start, end);\n return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1\n ? new this.buf.constructor(0)\n : this._slice.call(this.buf, start, end);\n};\n\n/**\n * Reads a string preceeded by its byte length as a varint.\n * @returns {string} Value read\n */\nReader.prototype.string = function read_string() {\n var bytes = this.bytes();\n return utf8.read(bytes, 0, bytes.length);\n};\n\n/**\n * Skips the specified number of bytes if specified, otherwise skips a varint.\n * @param {number} [length] Length if known, otherwise a varint is assumed\n * @returns {Reader} `this`\n */\nReader.prototype.skip = function skip(length) {\n if (typeof length === \"number\") {\n /* istanbul ignore if */\n if (this.pos + length > this.len)\n throw indexOutOfRange(this, length);\n this.pos += length;\n } else {\n do {\n /* istanbul ignore if */\n if (this.pos >= this.len)\n throw indexOutOfRange(this);\n } while (this.buf[this.pos++] & 128);\n }\n return this;\n};\n\n/**\n * Skips the next element of the specified wire type.\n * @param {number} wireType Wire type received\n * @returns {Reader} `this`\n */\nReader.prototype.skipType = function(wireType) {\n switch (wireType) {\n case 0:\n this.skip();\n break;\n case 1:\n this.skip(8);\n break;\n case 2:\n this.skip(this.uint32());\n break;\n case 3:\n while ((wireType = this.uint32() & 7) !== 4) {\n this.skipType(wireType);\n }\n break;\n case 5:\n this.skip(4);\n break;\n\n /* istanbul ignore next */\n default:\n throw Error(\"invalid wire type \" + wireType + \" at offset \" + this.pos);\n }\n return this;\n};\n\nReader._configure = function(BufferReader_) {\n BufferReader = BufferReader_;\n Reader.create = create();\n BufferReader._configure();\n\n var fn = util.Long ? \"toLong\" : /* istanbul ignore next */ \"toNumber\";\n util.merge(Reader.prototype, {\n\n int64: function read_int64() {\n return readLongVarint.call(this)[fn](false);\n },\n\n uint64: function read_uint64() {\n return readLongVarint.call(this)[fn](true);\n },\n\n sint64: function read_sint64() {\n return readLongVarint.call(this).zzDecode()[fn](false);\n },\n\n fixed64: function read_fixed64() {\n return readFixed64.call(this)[fn](true);\n },\n\n sfixed64: function read_sfixed64() {\n return readFixed64.call(this)[fn](false);\n }\n\n });\n};\n","\"use strict\";\nmodule.exports = BufferReader;\n\n// extends Reader\nvar Reader = require(\"./reader\");\n(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader;\n\nvar util = require(\"./util/minimal\");\n\n/**\n * Constructs a new buffer reader instance.\n * @classdesc Wire format reader using node buffers.\n * @extends Reader\n * @constructor\n * @param {Buffer} buffer Buffer to read from\n */\nfunction BufferReader(buffer) {\n Reader.call(this, buffer);\n\n /**\n * Read buffer.\n * @name BufferReader#buf\n * @type {Buffer}\n */\n}\n\nBufferReader._configure = function () {\n /* istanbul ignore else */\n if (util.Buffer)\n BufferReader.prototype._slice = util.Buffer.prototype.slice;\n};\n\n\n/**\n * @override\n */\nBufferReader.prototype.string = function read_string_buffer() {\n var len = this.uint32(); // modifies pos\n return this.buf.utf8Slice\n ? this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len))\n : this.buf.toString(\"utf-8\", this.pos, this.pos = Math.min(this.pos + len, this.len));\n};\n\n/**\n * Reads a sequence of bytes preceeded by its length as a varint.\n * @name BufferReader#bytes\n * @function\n * @returns {Buffer} Value read\n */\n\nBufferReader._configure();\n","\"use strict\";\n\n/**\n * Streaming RPC helpers.\n * @namespace\n */\nvar rpc = exports;\n\n/**\n * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets.\n * @typedef RPCImpl\n * @type {function}\n * @param {Method|rpc.ServiceMethod,Message<{}>>} method Reflected or static method being called\n * @param {Uint8Array} requestData Request data\n * @param {RPCImplCallback} callback Callback function\n * @returns {undefined}\n * @example\n * function rpcImpl(method, requestData, callback) {\n * if (protobuf.util.lcFirst(method.name) !== \"myMethod\") // compatible with static code\n * throw Error(\"no such method\");\n * asynchronouslyObtainAResponse(requestData, function(err, responseData) {\n * callback(err, responseData);\n * });\n * }\n */\n\n/**\n * Node-style callback as used by {@link RPCImpl}.\n * @typedef RPCImplCallback\n * @type {function}\n * @param {Error|null} error Error, if any, otherwise `null`\n * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error\n * @returns {undefined}\n */\n\nrpc.Service = require(\"./rpc/service\");\n","\"use strict\";\nmodule.exports = Service;\n\nvar util = require(\"../util/minimal\");\n\n// Extends EventEmitter\n(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service;\n\n/**\n * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}.\n *\n * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`.\n * @typedef rpc.ServiceMethodCallback\n * @template TRes extends Message\n * @type {function}\n * @param {Error|null} error Error, if any\n * @param {TRes} [response] Response message\n * @returns {undefined}\n */\n\n/**\n * A service method part of a {@link rpc.Service} as created by {@link Service.create}.\n * @typedef rpc.ServiceMethod\n * @template TReq extends Message\n * @template TRes extends Message\n * @type {function}\n * @param {TReq|Properties} request Request message or plain object\n * @param {rpc.ServiceMethodCallback} [callback] Node-style callback called with the error, if any, and the response message\n * @returns {Promise>} Promise if `callback` has been omitted, otherwise `undefined`\n */\n\n/**\n * Constructs a new RPC service instance.\n * @classdesc An RPC service as returned by {@link Service#create}.\n * @exports rpc.Service\n * @extends util.EventEmitter\n * @constructor\n * @param {RPCImpl} rpcImpl RPC implementation\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\n */\nfunction Service(rpcImpl, requestDelimited, responseDelimited) {\n\n if (typeof rpcImpl !== \"function\")\n throw TypeError(\"rpcImpl must be a function\");\n\n util.EventEmitter.call(this);\n\n /**\n * RPC implementation. Becomes `null` once the service is ended.\n * @type {RPCImpl|null}\n */\n this.rpcImpl = rpcImpl;\n\n /**\n * Whether requests are length-delimited.\n * @type {boolean}\n */\n this.requestDelimited = Boolean(requestDelimited);\n\n /**\n * Whether responses are length-delimited.\n * @type {boolean}\n */\n this.responseDelimited = Boolean(responseDelimited);\n}\n\n/**\n * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}.\n * @param {Method|rpc.ServiceMethod} method Reflected or static method\n * @param {Constructor} requestCtor Request constructor\n * @param {Constructor} responseCtor Response constructor\n * @param {TReq|Properties} request Request message or plain object\n * @param {rpc.ServiceMethodCallback} callback Service callback\n * @returns {undefined}\n * @template TReq extends Message\n * @template TRes extends Message\n */\nService.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) {\n\n if (!request)\n throw TypeError(\"request must be specified\");\n\n var self = this;\n if (!callback)\n return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request);\n\n if (!self.rpcImpl) {\n setTimeout(function() { callback(Error(\"already ended\")); }, 0);\n return undefined;\n }\n\n try {\n return self.rpcImpl(\n method,\n requestCtor[self.requestDelimited ? \"encodeDelimited\" : \"encode\"](request).finish(),\n function rpcCallback(err, response) {\n\n if (err) {\n self.emit(\"error\", err, method);\n return callback(err);\n }\n\n if (response === null) {\n self.end(/* endedByRPC */ true);\n return undefined;\n }\n\n if (!(response instanceof responseCtor)) {\n try {\n response = responseCtor[self.responseDelimited ? \"decodeDelimited\" : \"decode\"](response);\n } catch (err) {\n self.emit(\"error\", err, method);\n return callback(err);\n }\n }\n\n self.emit(\"data\", response, method);\n return callback(null, response);\n }\n );\n } catch (err) {\n self.emit(\"error\", err, method);\n setTimeout(function() { callback(err); }, 0);\n return undefined;\n }\n};\n\n/**\n * Ends this service and emits the `end` event.\n * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation.\n * @returns {rpc.Service} `this`\n */\nService.prototype.end = function end(endedByRPC) {\n if (this.rpcImpl) {\n if (!endedByRPC) // signal end to rpcImpl\n this.rpcImpl(null, null, null);\n this.rpcImpl = null;\n this.emit(\"end\").off();\n }\n return this;\n};\n","\"use strict\";\nmodule.exports = {};\n\n/**\n * Named roots.\n * This is where pbjs stores generated structures (the option `-r, --root` specifies a name).\n * Can also be used manually to make roots available accross modules.\n * @name roots\n * @type {Object.}\n * @example\n * // pbjs -r myroot -o compiled.js ...\n *\n * // in another module:\n * require(\"./compiled.js\");\n *\n * // in any subsequent module:\n * var root = protobuf.roots[\"myroot\"];\n */\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar pbDecode = require('./pb-decode.js');\nvar pbEncode = require('./pb-encode.js');\nvar util = require('./util.js');\n\nconst name = 'dag-pb';\nconst code = 112;\nfunction encode(node) {\n util.validate(node);\n const pbn = {};\n if (node.Links) {\n pbn.Links = node.Links.map(l => {\n const link = {};\n if (l.Hash) {\n link.Hash = l.Hash.bytes;\n }\n if (l.Name !== undefined) {\n link.Name = l.Name;\n }\n if (l.Tsize !== undefined) {\n link.Tsize = l.Tsize;\n }\n return link;\n });\n }\n if (node.Data) {\n pbn.Data = node.Data;\n }\n return pbEncode.encodeNode(pbn);\n}\nfunction decode(bytes) {\n const pbn = pbDecode.decodeNode(bytes);\n const node = {};\n if (pbn.Data) {\n node.Data = pbn.Data;\n }\n if (pbn.Links) {\n node.Links = pbn.Links.map(l => {\n const link = {};\n try {\n link.Hash = cid.CID.decode(l.Hash);\n } catch (e) {\n }\n if (!link.Hash) {\n throw new Error('Invalid Hash field found in link, expected CID');\n }\n if (l.Name !== undefined) {\n link.Name = l.Name;\n }\n if (l.Tsize !== undefined) {\n link.Tsize = l.Tsize;\n }\n return link;\n });\n }\n return node;\n}\n\nexports.createLink = util.createLink;\nexports.createNode = util.createNode;\nexports.prepare = util.prepare;\nexports.validate = util.validate;\nexports.code = code;\nexports.decode = decode;\nexports.encode = encode;\nexports.name = name;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar varint = require('./varint.js');\nvar digest = require('./hashes/digest.js');\nvar base58 = require('./bases/base58.js');\nvar base32 = require('./bases/base32.js');\nvar bytes = require('./bytes.js');\n\nclass CID {\n constructor(version, code, multihash, bytes) {\n this.code = code;\n this.version = version;\n this.multihash = multihash;\n this.bytes = bytes;\n this.byteOffset = bytes.byteOffset;\n this.byteLength = bytes.byteLength;\n this.asCID = this;\n this._baseCache = new Map();\n Object.defineProperties(this, {\n byteOffset: hidden,\n byteLength: hidden,\n code: readonly,\n version: readonly,\n multihash: readonly,\n bytes: readonly,\n _baseCache: hidden,\n asCID: hidden\n });\n }\n toV0() {\n switch (this.version) {\n case 0: {\n return this;\n }\n default: {\n const {code, multihash} = this;\n if (code !== DAG_PB_CODE) {\n throw new Error('Cannot convert a non dag-pb CID to CIDv0');\n }\n if (multihash.code !== SHA_256_CODE) {\n throw new Error('Cannot convert non sha2-256 multihash CID to CIDv0');\n }\n return CID.createV0(multihash);\n }\n }\n }\n toV1() {\n switch (this.version) {\n case 0: {\n const {code, digest: digest$1} = this.multihash;\n const multihash = digest.create(code, digest$1);\n return CID.createV1(this.code, multihash);\n }\n case 1: {\n return this;\n }\n default: {\n throw Error(`Can not convert CID version ${ this.version } to version 0. This is a bug please report`);\n }\n }\n }\n equals(other) {\n return other && this.code === other.code && this.version === other.version && digest.equals(this.multihash, other.multihash);\n }\n toString(base) {\n const {bytes, version, _baseCache} = this;\n switch (version) {\n case 0:\n return toStringV0(bytes, _baseCache, base || base58.base58btc.encoder);\n default:\n return toStringV1(bytes, _baseCache, base || base32.base32.encoder);\n }\n }\n toJSON() {\n return {\n code: this.code,\n version: this.version,\n hash: this.multihash.bytes\n };\n }\n get [Symbol.toStringTag]() {\n return 'CID';\n }\n [Symbol.for('nodejs.util.inspect.custom')]() {\n return 'CID(' + this.toString() + ')';\n }\n static isCID(value) {\n deprecate(/^0\\.0/, IS_CID_DEPRECATION);\n return !!(value && (value[cidSymbol] || value.asCID === value));\n }\n get toBaseEncodedString() {\n throw new Error('Deprecated, use .toString()');\n }\n get codec() {\n throw new Error('\"codec\" property is deprecated, use integer \"code\" property instead');\n }\n get buffer() {\n throw new Error('Deprecated .buffer property, use .bytes to get Uint8Array instead');\n }\n get multibaseName() {\n throw new Error('\"multibaseName\" property is deprecated');\n }\n get prefix() {\n throw new Error('\"prefix\" property is deprecated');\n }\n static asCID(value) {\n if (value instanceof CID) {\n return value;\n } else if (value != null && value.asCID === value) {\n const {version, code, multihash, bytes} = value;\n return new CID(version, code, multihash, bytes || encodeCID(version, code, multihash.bytes));\n } else if (value != null && value[cidSymbol] === true) {\n const {version, multihash, code} = value;\n const digest$1 = digest.decode(multihash);\n return CID.create(version, code, digest$1);\n } else {\n return null;\n }\n }\n static create(version, code, digest) {\n if (typeof code !== 'number') {\n throw new Error('String codecs are no longer supported');\n }\n switch (version) {\n case 0: {\n if (code !== DAG_PB_CODE) {\n throw new Error(`Version 0 CID must use dag-pb (code: ${ DAG_PB_CODE }) block encoding`);\n } else {\n return new CID(version, code, digest, digest.bytes);\n }\n }\n case 1: {\n const bytes = encodeCID(version, code, digest.bytes);\n return new CID(version, code, digest, bytes);\n }\n default: {\n throw new Error('Invalid version');\n }\n }\n }\n static createV0(digest) {\n return CID.create(0, DAG_PB_CODE, digest);\n }\n static createV1(code, digest) {\n return CID.create(1, code, digest);\n }\n static decode(bytes) {\n const [cid, remainder] = CID.decodeFirst(bytes);\n if (remainder.length) {\n throw new Error('Incorrect length');\n }\n return cid;\n }\n static decodeFirst(bytes$1) {\n const specs = CID.inspectBytes(bytes$1);\n const prefixSize = specs.size - specs.multihashSize;\n const multihashBytes = bytes.coerce(bytes$1.subarray(prefixSize, prefixSize + specs.multihashSize));\n if (multihashBytes.byteLength !== specs.multihashSize) {\n throw new Error('Incorrect length');\n }\n const digestBytes = multihashBytes.subarray(specs.multihashSize - specs.digestSize);\n const digest$1 = new digest.Digest(specs.multihashCode, specs.digestSize, digestBytes, multihashBytes);\n const cid = specs.version === 0 ? CID.createV0(digest$1) : CID.createV1(specs.codec, digest$1);\n return [\n cid,\n bytes$1.subarray(specs.size)\n ];\n }\n static inspectBytes(initialBytes) {\n let offset = 0;\n const next = () => {\n const [i, length] = varint.decode(initialBytes.subarray(offset));\n offset += length;\n return i;\n };\n let version = next();\n let codec = DAG_PB_CODE;\n if (version === 18) {\n version = 0;\n offset = 0;\n } else if (version === 1) {\n codec = next();\n }\n if (version !== 0 && version !== 1) {\n throw new RangeError(`Invalid CID version ${ version }`);\n }\n const prefixSize = offset;\n const multihashCode = next();\n const digestSize = next();\n const size = offset + digestSize;\n const multihashSize = size - prefixSize;\n return {\n version,\n codec,\n multihashCode,\n digestSize,\n multihashSize,\n size\n };\n }\n static parse(source, base) {\n const [prefix, bytes] = parseCIDtoBytes(source, base);\n const cid = CID.decode(bytes);\n cid._baseCache.set(prefix, source);\n return cid;\n }\n}\nconst parseCIDtoBytes = (source, base) => {\n switch (source[0]) {\n case 'Q': {\n const decoder = base || base58.base58btc;\n return [\n base58.base58btc.prefix,\n decoder.decode(`${ base58.base58btc.prefix }${ source }`)\n ];\n }\n case base58.base58btc.prefix: {\n const decoder = base || base58.base58btc;\n return [\n base58.base58btc.prefix,\n decoder.decode(source)\n ];\n }\n case base32.base32.prefix: {\n const decoder = base || base32.base32;\n return [\n base32.base32.prefix,\n decoder.decode(source)\n ];\n }\n default: {\n if (base == null) {\n throw Error('To parse non base32 or base58btc encoded CID multibase decoder must be provided');\n }\n return [\n source[0],\n base.decode(source)\n ];\n }\n }\n};\nconst toStringV0 = (bytes, cache, base) => {\n const {prefix} = base;\n if (prefix !== base58.base58btc.prefix) {\n throw Error(`Cannot string encode V0 in ${ base.name } encoding`);\n }\n const cid = cache.get(prefix);\n if (cid == null) {\n const cid = base.encode(bytes).slice(1);\n cache.set(prefix, cid);\n return cid;\n } else {\n return cid;\n }\n};\nconst toStringV1 = (bytes, cache, base) => {\n const {prefix} = base;\n const cid = cache.get(prefix);\n if (cid == null) {\n const cid = base.encode(bytes);\n cache.set(prefix, cid);\n return cid;\n } else {\n return cid;\n }\n};\nconst DAG_PB_CODE = 112;\nconst SHA_256_CODE = 18;\nconst encodeCID = (version, code, multihash) => {\n const codeOffset = varint.encodingLength(version);\n const hashOffset = codeOffset + varint.encodingLength(code);\n const bytes = new Uint8Array(hashOffset + multihash.byteLength);\n varint.encodeTo(version, bytes, 0);\n varint.encodeTo(code, bytes, codeOffset);\n bytes.set(multihash, hashOffset);\n return bytes;\n};\nconst cidSymbol = Symbol.for('@ipld/js-cid/CID');\nconst readonly = {\n writable: false,\n configurable: false,\n enumerable: true\n};\nconst hidden = {\n writable: false,\n enumerable: false,\n configurable: false\n};\nconst version = '0.0.0-dev';\nconst deprecate = (range, message) => {\n if (range.test(version)) {\n console.warn(message);\n } else {\n throw new Error(message);\n }\n};\nconst IS_CID_DEPRECATION = `CID.isCID(v) is deprecated and will be removed in the next major release.\nFollowing code pattern:\n\nif (CID.isCID(value)) {\n doSomethingWithCID(value)\n}\n\nIs replaced with:\n\nconst cid = CID.asCID(value)\nif (cid) {\n // Make sure to use cid instead of value\n doSomethingWithCID(cid)\n}\n`;\n\nexports.CID = CID;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar varint$1 = require('../vendor/varint.js');\n\nconst decode = data => {\n const code = varint$1.decode(data);\n return [\n code,\n varint$1.decode.bytes\n ];\n};\nconst encodeTo = (int, target, offset = 0) => {\n varint$1.encode(int, target, offset);\n return target;\n};\nconst encodingLength = int => {\n return varint$1.encodingLength(int);\n};\n\nexports.decode = decode;\nexports.encodeTo = encodeTo;\nexports.encodingLength = encodingLength;\n","'use strict';\n\nvar encode_1 = encode;\nvar MSB = 128, REST = 127, MSBALL = ~REST, INT = Math.pow(2, 31);\nfunction encode(num, out, offset) {\n out = out || [];\n offset = offset || 0;\n var oldOffset = offset;\n while (num >= INT) {\n out[offset++] = num & 255 | MSB;\n num /= 128;\n }\n while (num & MSBALL) {\n out[offset++] = num & 255 | MSB;\n num >>>= 7;\n }\n out[offset] = num | 0;\n encode.bytes = offset - oldOffset + 1;\n return out;\n}\nvar decode = read;\nvar MSB$1 = 128, REST$1 = 127;\nfunction read(buf, offset) {\n var res = 0, offset = offset || 0, shift = 0, counter = offset, b, l = buf.length;\n do {\n if (counter >= l) {\n read.bytes = 0;\n throw new RangeError('Could not decode varint');\n }\n b = buf[counter++];\n res += shift < 28 ? (b & REST$1) << shift : (b & REST$1) * Math.pow(2, shift);\n shift += 7;\n } while (b >= MSB$1);\n read.bytes = counter - offset;\n return res;\n}\nvar N1 = Math.pow(2, 7);\nvar N2 = Math.pow(2, 14);\nvar N3 = Math.pow(2, 21);\nvar N4 = Math.pow(2, 28);\nvar N5 = Math.pow(2, 35);\nvar N6 = Math.pow(2, 42);\nvar N7 = Math.pow(2, 49);\nvar N8 = Math.pow(2, 56);\nvar N9 = Math.pow(2, 63);\nvar length = function (value) {\n return value < N1 ? 1 : value < N2 ? 2 : value < N3 ? 3 : value < N4 ? 4 : value < N5 ? 5 : value < N6 ? 6 : value < N7 ? 7 : value < N8 ? 8 : value < N9 ? 9 : 10;\n};\nvar varint = {\n encode: encode_1,\n decode: decode,\n encodingLength: length\n};\nvar _brrp_varint = varint;\nvar varint$1 = _brrp_varint;\n\nmodule.exports = varint$1;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bytes = require('../bytes.js');\nvar varint = require('../varint.js');\n\nconst create = (code, digest) => {\n const size = digest.byteLength;\n const sizeOffset = varint.encodingLength(code);\n const digestOffset = sizeOffset + varint.encodingLength(size);\n const bytes = new Uint8Array(digestOffset + size);\n varint.encodeTo(code, bytes, 0);\n varint.encodeTo(size, bytes, sizeOffset);\n bytes.set(digest, digestOffset);\n return new Digest(code, size, digest, bytes);\n};\nconst decode = multihash => {\n const bytes$1 = bytes.coerce(multihash);\n const [code, sizeOffset] = varint.decode(bytes$1);\n const [size, digestOffset] = varint.decode(bytes$1.subarray(sizeOffset));\n const digest = bytes$1.subarray(sizeOffset + digestOffset);\n if (digest.byteLength !== size) {\n throw new Error('Incorrect length');\n }\n return new Digest(code, size, digest, bytes$1);\n};\nconst equals = (a, b) => {\n if (a === b) {\n return true;\n } else {\n return a.code === b.code && a.size === b.size && bytes.equals(a.bytes, b.bytes);\n }\n};\nclass Digest {\n constructor(code, size, digest, bytes) {\n this.code = code;\n this.size = size;\n this.digest = digest;\n this.bytes = bytes;\n }\n}\n\nexports.Digest = Digest;\nexports.create = create;\nexports.decode = decode;\nexports.equals = equals;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst empty = new Uint8Array(0);\nconst toHex = d => d.reduce((hex, byte) => hex + byte.toString(16).padStart(2, '0'), '');\nconst fromHex = hex => {\n const hexes = hex.match(/../g);\n return hexes ? new Uint8Array(hexes.map(b => parseInt(b, 16))) : empty;\n};\nconst equals = (aa, bb) => {\n if (aa === bb)\n return true;\n if (aa.byteLength !== bb.byteLength) {\n return false;\n }\n for (let ii = 0; ii < aa.byteLength; ii++) {\n if (aa[ii] !== bb[ii]) {\n return false;\n }\n }\n return true;\n};\nconst coerce = o => {\n if (o instanceof Uint8Array && o.constructor.name === 'Uint8Array')\n return o;\n if (o instanceof ArrayBuffer)\n return new Uint8Array(o);\n if (ArrayBuffer.isView(o)) {\n return new Uint8Array(o.buffer, o.byteOffset, o.byteLength);\n }\n throw new Error('Unknown type, must be binary type');\n};\nconst isBinary = o => o instanceof ArrayBuffer || ArrayBuffer.isView(o);\nconst fromString = str => new TextEncoder().encode(str);\nconst toString = b => new TextDecoder().decode(b);\n\nexports.coerce = coerce;\nexports.empty = empty;\nexports.equals = equals;\nexports.fromHex = fromHex;\nexports.fromString = fromString;\nexports.isBinary = isBinary;\nexports.toHex = toHex;\nexports.toString = toString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base58btc = base.baseX({\n name: 'base58btc',\n prefix: 'z',\n alphabet: '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz'\n});\nconst base58flickr = base.baseX({\n name: 'base58flickr',\n prefix: 'Z',\n alphabet: '123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ'\n});\n\nexports.base58btc = base58btc;\nexports.base58flickr = base58flickr;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar baseX$1 = require('../../vendor/base-x.js');\nvar bytes = require('../bytes.js');\n\nclass Encoder {\n constructor(name, prefix, baseEncode) {\n this.name = name;\n this.prefix = prefix;\n this.baseEncode = baseEncode;\n }\n encode(bytes) {\n if (bytes instanceof Uint8Array) {\n return `${ this.prefix }${ this.baseEncode(bytes) }`;\n } else {\n throw Error('Unknown type, must be binary type');\n }\n }\n}\nclass Decoder {\n constructor(name, prefix, baseDecode) {\n this.name = name;\n this.prefix = prefix;\n this.baseDecode = baseDecode;\n }\n decode(text) {\n if (typeof text === 'string') {\n switch (text[0]) {\n case this.prefix: {\n return this.baseDecode(text.slice(1));\n }\n default: {\n throw Error(`Unable to decode multibase string ${ JSON.stringify(text) }, ${ this.name } decoder only supports inputs prefixed with ${ this.prefix }`);\n }\n }\n } else {\n throw Error('Can only multibase decode strings');\n }\n }\n or(decoder) {\n return or(this, decoder);\n }\n}\nclass ComposedDecoder {\n constructor(decoders) {\n this.decoders = decoders;\n }\n or(decoder) {\n return or(this, decoder);\n }\n decode(input) {\n const prefix = input[0];\n const decoder = this.decoders[prefix];\n if (decoder) {\n return decoder.decode(input);\n } else {\n throw RangeError(`Unable to decode multibase string ${ JSON.stringify(input) }, only inputs prefixed with ${ Object.keys(this.decoders) } are supported`);\n }\n }\n}\nconst or = (left, right) => new ComposedDecoder({\n ...left.decoders || { [left.prefix]: left },\n ...right.decoders || { [right.prefix]: right }\n});\nclass Codec {\n constructor(name, prefix, baseEncode, baseDecode) {\n this.name = name;\n this.prefix = prefix;\n this.baseEncode = baseEncode;\n this.baseDecode = baseDecode;\n this.encoder = new Encoder(name, prefix, baseEncode);\n this.decoder = new Decoder(name, prefix, baseDecode);\n }\n encode(input) {\n return this.encoder.encode(input);\n }\n decode(input) {\n return this.decoder.decode(input);\n }\n}\nconst from = ({name, prefix, encode, decode}) => new Codec(name, prefix, encode, decode);\nconst baseX = ({prefix, name, alphabet}) => {\n const {encode, decode} = baseX$1(alphabet, name);\n return from({\n prefix,\n name,\n encode,\n decode: text => bytes.coerce(decode(text))\n });\n};\nconst decode = (string, alphabet, bitsPerChar, name) => {\n const codes = {};\n for (let i = 0; i < alphabet.length; ++i) {\n codes[alphabet[i]] = i;\n }\n let end = string.length;\n while (string[end - 1] === '=') {\n --end;\n }\n const out = new Uint8Array(end * bitsPerChar / 8 | 0);\n let bits = 0;\n let buffer = 0;\n let written = 0;\n for (let i = 0; i < end; ++i) {\n const value = codes[string[i]];\n if (value === undefined) {\n throw new SyntaxError(`Non-${ name } character`);\n }\n buffer = buffer << bitsPerChar | value;\n bits += bitsPerChar;\n if (bits >= 8) {\n bits -= 8;\n out[written++] = 255 & buffer >> bits;\n }\n }\n if (bits >= bitsPerChar || 255 & buffer << 8 - bits) {\n throw new SyntaxError('Unexpected end of data');\n }\n return out;\n};\nconst encode = (data, alphabet, bitsPerChar) => {\n const pad = alphabet[alphabet.length - 1] === '=';\n const mask = (1 << bitsPerChar) - 1;\n let out = '';\n let bits = 0;\n let buffer = 0;\n for (let i = 0; i < data.length; ++i) {\n buffer = buffer << 8 | data[i];\n bits += 8;\n while (bits > bitsPerChar) {\n bits -= bitsPerChar;\n out += alphabet[mask & buffer >> bits];\n }\n }\n if (bits) {\n out += alphabet[mask & buffer << bitsPerChar - bits];\n }\n if (pad) {\n while (out.length * bitsPerChar & 7) {\n out += '=';\n }\n }\n return out;\n};\nconst rfc4648 = ({name, prefix, bitsPerChar, alphabet}) => {\n return from({\n prefix,\n name,\n encode(input) {\n return encode(input, alphabet, bitsPerChar);\n },\n decode(input) {\n return decode(input, alphabet, bitsPerChar, name);\n }\n });\n};\n\nexports.Codec = Codec;\nexports.baseX = baseX;\nexports.from = from;\nexports.or = or;\nexports.rfc4648 = rfc4648;\n","'use strict';\n\nfunction base(ALPHABET, name) {\n if (ALPHABET.length >= 255) {\n throw new TypeError('Alphabet too long');\n }\n var BASE_MAP = new Uint8Array(256);\n for (var j = 0; j < BASE_MAP.length; j++) {\n BASE_MAP[j] = 255;\n }\n for (var i = 0; i < ALPHABET.length; i++) {\n var x = ALPHABET.charAt(i);\n var xc = x.charCodeAt(0);\n if (BASE_MAP[xc] !== 255) {\n throw new TypeError(x + ' is ambiguous');\n }\n BASE_MAP[xc] = i;\n }\n var BASE = ALPHABET.length;\n var LEADER = ALPHABET.charAt(0);\n var FACTOR = Math.log(BASE) / Math.log(256);\n var iFACTOR = Math.log(256) / Math.log(BASE);\n function encode(source) {\n if (source instanceof Uint8Array);\n else if (ArrayBuffer.isView(source)) {\n source = new Uint8Array(source.buffer, source.byteOffset, source.byteLength);\n } else if (Array.isArray(source)) {\n source = Uint8Array.from(source);\n }\n if (!(source instanceof Uint8Array)) {\n throw new TypeError('Expected Uint8Array');\n }\n if (source.length === 0) {\n return '';\n }\n var zeroes = 0;\n var length = 0;\n var pbegin = 0;\n var pend = source.length;\n while (pbegin !== pend && source[pbegin] === 0) {\n pbegin++;\n zeroes++;\n }\n var size = (pend - pbegin) * iFACTOR + 1 >>> 0;\n var b58 = new Uint8Array(size);\n while (pbegin !== pend) {\n var carry = source[pbegin];\n var i = 0;\n for (var it1 = size - 1; (carry !== 0 || i < length) && it1 !== -1; it1--, i++) {\n carry += 256 * b58[it1] >>> 0;\n b58[it1] = carry % BASE >>> 0;\n carry = carry / BASE >>> 0;\n }\n if (carry !== 0) {\n throw new Error('Non-zero carry');\n }\n length = i;\n pbegin++;\n }\n var it2 = size - length;\n while (it2 !== size && b58[it2] === 0) {\n it2++;\n }\n var str = LEADER.repeat(zeroes);\n for (; it2 < size; ++it2) {\n str += ALPHABET.charAt(b58[it2]);\n }\n return str;\n }\n function decodeUnsafe(source) {\n if (typeof source !== 'string') {\n throw new TypeError('Expected String');\n }\n if (source.length === 0) {\n return new Uint8Array();\n }\n var psz = 0;\n if (source[psz] === ' ') {\n return;\n }\n var zeroes = 0;\n var length = 0;\n while (source[psz] === LEADER) {\n zeroes++;\n psz++;\n }\n var size = (source.length - psz) * FACTOR + 1 >>> 0;\n var b256 = new Uint8Array(size);\n while (source[psz]) {\n var carry = BASE_MAP[source.charCodeAt(psz)];\n if (carry === 255) {\n return;\n }\n var i = 0;\n for (var it3 = size - 1; (carry !== 0 || i < length) && it3 !== -1; it3--, i++) {\n carry += BASE * b256[it3] >>> 0;\n b256[it3] = carry % 256 >>> 0;\n carry = carry / 256 >>> 0;\n }\n if (carry !== 0) {\n throw new Error('Non-zero carry');\n }\n length = i;\n psz++;\n }\n if (source[psz] === ' ') {\n return;\n }\n var it4 = size - length;\n while (it4 !== size && b256[it4] === 0) {\n it4++;\n }\n var vch = new Uint8Array(zeroes + (size - it4));\n var j = zeroes;\n while (it4 !== size) {\n vch[j++] = b256[it4++];\n }\n return vch;\n }\n function decode(string) {\n var buffer = decodeUnsafe(string);\n if (buffer) {\n return buffer;\n }\n throw new Error(`Non-${ name } character`);\n }\n return {\n encode: encode,\n decodeUnsafe: decodeUnsafe,\n decode: decode\n };\n}\nvar src = base;\nvar _brrp__multiformats_scope_baseX = src;\n\nmodule.exports = _brrp__multiformats_scope_baseX;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base32 = base.rfc4648({\n prefix: 'b',\n name: 'base32',\n alphabet: 'abcdefghijklmnopqrstuvwxyz234567',\n bitsPerChar: 5\n});\nconst base32upper = base.rfc4648({\n prefix: 'B',\n name: 'base32upper',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZ234567',\n bitsPerChar: 5\n});\nconst base32pad = base.rfc4648({\n prefix: 'c',\n name: 'base32pad',\n alphabet: 'abcdefghijklmnopqrstuvwxyz234567=',\n bitsPerChar: 5\n});\nconst base32padupper = base.rfc4648({\n prefix: 'C',\n name: 'base32padupper',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=',\n bitsPerChar: 5\n});\nconst base32hex = base.rfc4648({\n prefix: 'v',\n name: 'base32hex',\n alphabet: '0123456789abcdefghijklmnopqrstuv',\n bitsPerChar: 5\n});\nconst base32hexupper = base.rfc4648({\n prefix: 'V',\n name: 'base32hexupper',\n alphabet: '0123456789ABCDEFGHIJKLMNOPQRSTUV',\n bitsPerChar: 5\n});\nconst base32hexpad = base.rfc4648({\n prefix: 't',\n name: 'base32hexpad',\n alphabet: '0123456789abcdefghijklmnopqrstuv=',\n bitsPerChar: 5\n});\nconst base32hexpadupper = base.rfc4648({\n prefix: 'T',\n name: 'base32hexpadupper',\n alphabet: '0123456789ABCDEFGHIJKLMNOPQRSTUV=',\n bitsPerChar: 5\n});\nconst base32z = base.rfc4648({\n prefix: 'h',\n name: 'base32z',\n alphabet: 'ybndrfg8ejkmcpqxot1uwisza345h769',\n bitsPerChar: 5\n});\n\nexports.base32 = base32;\nexports.base32hex = base32hex;\nexports.base32hexpad = base32hexpad;\nexports.base32hexpadupper = base32hexpadupper;\nexports.base32hexupper = base32hexupper;\nexports.base32pad = base32pad;\nexports.base32padupper = base32padupper;\nexports.base32upper = base32upper;\nexports.base32z = base32z;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst textDecoder = new TextDecoder();\nfunction decodeVarint(bytes, offset) {\n let v = 0;\n for (let shift = 0;; shift += 7) {\n if (shift >= 64) {\n throw new Error('protobuf: varint overflow');\n }\n if (offset >= bytes.length) {\n throw new Error('protobuf: unexpected end of data');\n }\n const b = bytes[offset++];\n v += shift < 28 ? (b & 127) << shift : (b & 127) * 2 ** shift;\n if (b < 128) {\n break;\n }\n }\n return [\n v,\n offset\n ];\n}\nfunction decodeBytes(bytes, offset) {\n let byteLen;\n [byteLen, offset] = decodeVarint(bytes, offset);\n const postOffset = offset + byteLen;\n if (byteLen < 0 || postOffset < 0) {\n throw new Error('protobuf: invalid length');\n }\n if (postOffset > bytes.length) {\n throw new Error('protobuf: unexpected end of data');\n }\n return [\n bytes.subarray(offset, postOffset),\n postOffset\n ];\n}\nfunction decodeKey(bytes, index) {\n let wire;\n [wire, index] = decodeVarint(bytes, index);\n return [\n wire & 7,\n wire >> 3,\n index\n ];\n}\nfunction decodeLink(bytes) {\n const link = {};\n const l = bytes.length;\n let index = 0;\n while (index < l) {\n let wireType, fieldNum;\n [wireType, fieldNum, index] = decodeKey(bytes, index);\n if (fieldNum === 1) {\n if (link.Hash) {\n throw new Error('protobuf: (PBLink) duplicate Hash section');\n }\n if (wireType !== 2) {\n throw new Error(`protobuf: (PBLink) wrong wireType (${ wireType }) for Hash`);\n }\n if (link.Name !== undefined) {\n throw new Error('protobuf: (PBLink) invalid order, found Name before Hash');\n }\n if (link.Tsize !== undefined) {\n throw new Error('protobuf: (PBLink) invalid order, found Tsize before Hash');\n }\n ;\n [link.Hash, index] = decodeBytes(bytes, index);\n } else if (fieldNum === 2) {\n if (link.Name !== undefined) {\n throw new Error('protobuf: (PBLink) duplicate Name section');\n }\n if (wireType !== 2) {\n throw new Error(`protobuf: (PBLink) wrong wireType (${ wireType }) for Name`);\n }\n if (link.Tsize !== undefined) {\n throw new Error('protobuf: (PBLink) invalid order, found Tsize before Name');\n }\n let byts;\n [byts, index] = decodeBytes(bytes, index);\n link.Name = textDecoder.decode(byts);\n } else if (fieldNum === 3) {\n if (link.Tsize !== undefined) {\n throw new Error('protobuf: (PBLink) duplicate Tsize section');\n }\n if (wireType !== 0) {\n throw new Error(`protobuf: (PBLink) wrong wireType (${ wireType }) for Tsize`);\n }\n ;\n [link.Tsize, index] = decodeVarint(bytes, index);\n } else {\n throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${ fieldNum }`);\n }\n }\n if (index > l) {\n throw new Error('protobuf: (PBLink) unexpected end of data');\n }\n return link;\n}\nfunction decodeNode(bytes) {\n const l = bytes.length;\n let index = 0;\n let links;\n let linksBeforeData = false;\n let data;\n while (index < l) {\n let wireType, fieldNum;\n [wireType, fieldNum, index] = decodeKey(bytes, index);\n if (wireType !== 2) {\n throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${ wireType }`);\n }\n if (fieldNum === 1) {\n if (data) {\n throw new Error('protobuf: (PBNode) duplicate Data section');\n }\n ;\n [data, index] = decodeBytes(bytes, index);\n if (links) {\n linksBeforeData = true;\n }\n } else if (fieldNum === 2) {\n if (linksBeforeData) {\n throw new Error('protobuf: (PBNode) duplicate Links section');\n } else if (!links) {\n links = [];\n }\n let byts;\n [byts, index] = decodeBytes(bytes, index);\n links.push(decodeLink(byts));\n } else {\n throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${ fieldNum }`);\n }\n }\n if (index > l) {\n throw new Error('protobuf: (PBNode) unexpected end of data');\n }\n const node = {};\n if (data) {\n node.Data = data;\n }\n node.Links = links || [];\n return node;\n}\n\nexports.decodeNode = decodeNode;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst textEncoder = new TextEncoder();\nconst maxInt32 = 2 ** 32;\nconst maxUInt32 = 2 ** 31;\nfunction encodeLink(link, bytes) {\n let i = bytes.length;\n if (typeof link.Tsize === 'number') {\n if (link.Tsize < 0) {\n throw new Error('Tsize cannot be negative');\n }\n if (!Number.isSafeInteger(link.Tsize)) {\n throw new Error('Tsize too large for encoding');\n }\n i = encodeVarint(bytes, i, link.Tsize) - 1;\n bytes[i] = 24;\n }\n if (typeof link.Name === 'string') {\n const nameBytes = textEncoder.encode(link.Name);\n i -= nameBytes.length;\n bytes.set(nameBytes, i);\n i = encodeVarint(bytes, i, nameBytes.length) - 1;\n bytes[i] = 18;\n }\n if (link.Hash) {\n i -= link.Hash.length;\n bytes.set(link.Hash, i);\n i = encodeVarint(bytes, i, link.Hash.length) - 1;\n bytes[i] = 10;\n }\n return bytes.length - i;\n}\nfunction encodeNode(node) {\n const size = sizeNode(node);\n const bytes = new Uint8Array(size);\n let i = size;\n if (node.Data) {\n i -= node.Data.length;\n bytes.set(node.Data, i);\n i = encodeVarint(bytes, i, node.Data.length) - 1;\n bytes[i] = 10;\n }\n if (node.Links) {\n for (let index = node.Links.length - 1; index >= 0; index--) {\n const size = encodeLink(node.Links[index], bytes.subarray(0, i));\n i -= size;\n i = encodeVarint(bytes, i, size) - 1;\n bytes[i] = 18;\n }\n }\n return bytes;\n}\nfunction sizeLink(link) {\n let n = 0;\n if (link.Hash) {\n const l = link.Hash.length;\n n += 1 + l + sov(l);\n }\n if (typeof link.Name === 'string') {\n const l = textEncoder.encode(link.Name).length;\n n += 1 + l + sov(l);\n }\n if (typeof link.Tsize === 'number') {\n n += 1 + sov(link.Tsize);\n }\n return n;\n}\nfunction sizeNode(node) {\n let n = 0;\n if (node.Data) {\n const l = node.Data.length;\n n += 1 + l + sov(l);\n }\n if (node.Links) {\n for (const link of node.Links) {\n const l = sizeLink(link);\n n += 1 + l + sov(l);\n }\n }\n return n;\n}\nfunction encodeVarint(bytes, offset, v) {\n offset -= sov(v);\n const base = offset;\n while (v >= maxUInt32) {\n bytes[offset++] = v & 127 | 128;\n v /= 128;\n }\n while (v >= 128) {\n bytes[offset++] = v & 127 | 128;\n v >>>= 7;\n }\n bytes[offset] = v;\n return base;\n}\nfunction sov(x) {\n if (x % 2 === 0) {\n x++;\n }\n return Math.floor((len64(x) + 6) / 7);\n}\nfunction len64(x) {\n let n = 0;\n if (x >= maxInt32) {\n x = Math.floor(x / maxInt32);\n n = 32;\n }\n if (x >= 1 << 16) {\n x >>>= 16;\n n += 16;\n }\n if (x >= 1 << 8) {\n x >>>= 8;\n n += 8;\n }\n return n + len8tab[x];\n}\nconst len8tab = [\n 0,\n 1,\n 2,\n 2,\n 3,\n 3,\n 3,\n 3,\n 4,\n 4,\n 4,\n 4,\n 4,\n 4,\n 4,\n 4,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8\n];\n\nexports.encodeNode = encodeNode;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\n\nconst pbNodeProperties = [\n 'Data',\n 'Links'\n];\nconst pbLinkProperties = [\n 'Hash',\n 'Name',\n 'Tsize'\n];\nconst textEncoder = new TextEncoder();\nfunction linkComparator(a, b) {\n if (a === b) {\n return 0;\n }\n const abuf = a.Name ? textEncoder.encode(a.Name) : [];\n const bbuf = b.Name ? textEncoder.encode(b.Name) : [];\n let x = abuf.length;\n let y = bbuf.length;\n for (let i = 0, len = Math.min(x, y); i < len; ++i) {\n if (abuf[i] !== bbuf[i]) {\n x = abuf[i];\n y = bbuf[i];\n break;\n }\n }\n return x < y ? -1 : y < x ? 1 : 0;\n}\nfunction hasOnlyProperties(node, properties) {\n return !Object.keys(node).some(p => !properties.includes(p));\n}\nfunction asLink(link) {\n if (typeof link.asCID === 'object') {\n const Hash = cid.CID.asCID(link);\n if (!Hash) {\n throw new TypeError('Invalid DAG-PB form');\n }\n return { Hash };\n }\n if (typeof link !== 'object' || Array.isArray(link)) {\n throw new TypeError('Invalid DAG-PB form');\n }\n const pbl = {};\n if (link.Hash) {\n let cid$1 = cid.CID.asCID(link.Hash);\n try {\n if (!cid$1) {\n if (typeof link.Hash === 'string') {\n cid$1 = cid.CID.parse(link.Hash);\n } else if (link.Hash instanceof Uint8Array) {\n cid$1 = cid.CID.decode(link.Hash);\n }\n }\n } catch (e) {\n throw new TypeError(`Invalid DAG-PB form: ${ e.message }`);\n }\n if (cid$1) {\n pbl.Hash = cid$1;\n }\n }\n if (!pbl.Hash) {\n throw new TypeError('Invalid DAG-PB form');\n }\n if (typeof link.Name === 'string') {\n pbl.Name = link.Name;\n }\n if (typeof link.Tsize === 'number') {\n pbl.Tsize = link.Tsize;\n }\n return pbl;\n}\nfunction prepare(node) {\n if (node instanceof Uint8Array || typeof node === 'string') {\n node = { Data: node };\n }\n if (typeof node !== 'object' || Array.isArray(node)) {\n throw new TypeError('Invalid DAG-PB form');\n }\n const pbn = {};\n if (node.Data !== undefined) {\n if (typeof node.Data === 'string') {\n pbn.Data = textEncoder.encode(node.Data);\n } else if (node.Data instanceof Uint8Array) {\n pbn.Data = node.Data;\n } else {\n throw new TypeError('Invalid DAG-PB form');\n }\n }\n if (node.Links !== undefined) {\n if (Array.isArray(node.Links)) {\n pbn.Links = node.Links.map(asLink);\n pbn.Links.sort(linkComparator);\n } else {\n throw new TypeError('Invalid DAG-PB form');\n }\n } else {\n pbn.Links = [];\n }\n return pbn;\n}\nfunction validate(node) {\n if (!node || typeof node !== 'object' || Array.isArray(node)) {\n throw new TypeError('Invalid DAG-PB form');\n }\n if (!hasOnlyProperties(node, pbNodeProperties)) {\n throw new TypeError('Invalid DAG-PB form (extraneous properties)');\n }\n if (node.Data !== undefined && !(node.Data instanceof Uint8Array)) {\n throw new TypeError('Invalid DAG-PB form (Data must be a Uint8Array)');\n }\n if (!Array.isArray(node.Links)) {\n throw new TypeError('Invalid DAG-PB form (Links must be an array)');\n }\n for (let i = 0; i < node.Links.length; i++) {\n const link = node.Links[i];\n if (!link || typeof link !== 'object' || Array.isArray(link)) {\n throw new TypeError('Invalid DAG-PB form (bad link object)');\n }\n if (!hasOnlyProperties(link, pbLinkProperties)) {\n throw new TypeError('Invalid DAG-PB form (extraneous properties on link object)');\n }\n if (!link.Hash) {\n throw new TypeError('Invalid DAG-PB form (link must have a Hash)');\n }\n if (link.Hash.asCID !== link.Hash) {\n throw new TypeError('Invalid DAG-PB form (link Hash must be a CID)');\n }\n if (link.Name !== undefined && typeof link.Name !== 'string') {\n throw new TypeError('Invalid DAG-PB form (link Name must be a string)');\n }\n if (link.Tsize !== undefined && (typeof link.Tsize !== 'number' || link.Tsize % 1 !== 0)) {\n throw new TypeError('Invalid DAG-PB form (link Tsize must be an integer)');\n }\n if (i > 0 && linkComparator(link, node.Links[i - 1]) === -1) {\n throw new TypeError('Invalid DAG-PB form (links must be sorted by Name bytes)');\n }\n }\n}\nfunction createNode(data, links = []) {\n return prepare({\n Data: data,\n Links: links\n });\n}\nfunction createLink(name, size, cid) {\n return asLink({\n Hash: cid,\n Name: name,\n Tsize: size\n });\n}\n\nexports.createLink = createLink;\nexports.createNode = createNode;\nexports.prepare = prepare;\nexports.validate = validate;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cborg = require('cborg');\nvar cid = require('multiformats/cid');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar cborg__namespace = /*#__PURE__*/_interopNamespace(cborg);\n\nconst CID_CBOR_TAG = 42;\nfunction cidEncoder(obj) {\n if (obj.asCID !== obj) {\n return null;\n }\n const cid$1 = cid.CID.asCID(obj);\n if (!cid$1) {\n return null;\n }\n const bytes = new Uint8Array(cid$1.bytes.byteLength + 1);\n bytes.set(cid$1.bytes, 1);\n return [\n new cborg__namespace.Token(cborg__namespace.Type.tag, CID_CBOR_TAG),\n new cborg__namespace.Token(cborg__namespace.Type.bytes, bytes)\n ];\n}\nfunction undefinedEncoder() {\n throw new Error('`undefined` is not supported by the IPLD Data Model and cannot be encoded');\n}\nfunction numberEncoder(num) {\n if (Number.isNaN(num)) {\n throw new Error('`NaN` is not supported by the IPLD Data Model and cannot be encoded');\n }\n if (num === Infinity || num === -Infinity) {\n throw new Error('`Infinity` and `-Infinity` is not supported by the IPLD Data Model and cannot be encoded');\n }\n return null;\n}\nconst encodeOptions = {\n float64: true,\n typeEncoders: {\n Object: cidEncoder,\n undefined: undefinedEncoder,\n number: numberEncoder\n }\n};\nfunction cidDecoder(bytes) {\n if (bytes[0] !== 0) {\n throw new Error('Invalid CID for CBOR tag 42; expected leading 0x00');\n }\n return cid.CID.decode(bytes.subarray(1));\n}\nconst decodeOptions = {\n allowIndefinite: false,\n allowUndefined: false,\n allowNaN: false,\n allowInfinity: false,\n allowBigInt: true,\n strict: true,\n useMaps: false,\n tags: []\n};\ndecodeOptions.tags[CID_CBOR_TAG] = cidDecoder;\nconst name = 'dag-cbor';\nconst code = 113;\nconst encode = node => cborg__namespace.encode(node, encodeOptions);\nconst decode = data => cborg__namespace.decode(data, decodeOptions);\n\nexports.code = code;\nexports.decode = decode;\nexports.encode = encode;\nexports.name = name;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar encode = require('./lib/encode.js');\nvar decode = require('./lib/decode.js');\nvar token = require('./lib/token.js');\n\n\n\nexports.encode = encode.encode;\nexports.decode = decode.decode;\nexports.Token = token.Token;\nexports.Type = token.Type;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar is = require('./is.js');\nvar token = require('./token.js');\nvar bl = require('./bl.js');\nvar common = require('./common.js');\nvar jump = require('./jump.js');\nvar byteUtils = require('./byte-utils.js');\nvar _0uint = require('./0uint.js');\nvar _1negint = require('./1negint.js');\nvar _2bytes = require('./2bytes.js');\nvar _3string = require('./3string.js');\nvar _4array = require('./4array.js');\nvar _5map = require('./5map.js');\nvar _6tag = require('./6tag.js');\nvar _7float = require('./7float.js');\n\nconst defaultEncodeOptions = {\n float64: false,\n mapSorter,\n quickEncodeToken: jump.quickEncodeToken\n};\nconst cborEncoders = [];\ncborEncoders[token.Type.uint.major] = _0uint.encodeUint;\ncborEncoders[token.Type.negint.major] = _1negint.encodeNegint;\ncborEncoders[token.Type.bytes.major] = _2bytes.encodeBytes;\ncborEncoders[token.Type.string.major] = _3string.encodeString;\ncborEncoders[token.Type.array.major] = _4array.encodeArray;\ncborEncoders[token.Type.map.major] = _5map.encodeMap;\ncborEncoders[token.Type.tag.major] = _6tag.encodeTag;\ncborEncoders[token.Type.float.major] = _7float.encodeFloat;\nconst buf = new bl.Bl();\nclass Ref {\n constructor(obj, parent) {\n this.obj = obj;\n this.parent = parent;\n }\n includes(obj) {\n let p = this;\n do {\n if (p.obj === obj) {\n return true;\n }\n } while (p = p.parent);\n return false;\n }\n static createCheck(stack, obj) {\n if (stack && stack.includes(obj)) {\n throw new Error(`${ common.encodeErrPrefix } object contains circular references`);\n }\n return new Ref(obj, stack);\n }\n}\nconst simpleTokens = {\n null: new token.Token(token.Type.null, null),\n undefined: new token.Token(token.Type.undefined, undefined),\n true: new token.Token(token.Type.true, true),\n false: new token.Token(token.Type.false, false),\n emptyArray: new token.Token(token.Type.array, 0),\n emptyMap: new token.Token(token.Type.map, 0)\n};\nconst typeEncoders = {\n number(obj, _typ, _options, _refStack) {\n if (!Number.isInteger(obj) || !Number.isSafeInteger(obj)) {\n return new token.Token(token.Type.float, obj);\n } else if (obj >= 0) {\n return new token.Token(token.Type.uint, obj);\n } else {\n return new token.Token(token.Type.negint, obj);\n }\n },\n bigint(obj, _typ, _options, _refStack) {\n if (obj >= BigInt(0)) {\n return new token.Token(token.Type.uint, obj);\n } else {\n return new token.Token(token.Type.negint, obj);\n }\n },\n Uint8Array(obj, _typ, _options, _refStack) {\n return new token.Token(token.Type.bytes, obj);\n },\n string(obj, _typ, _options, _refStack) {\n return new token.Token(token.Type.string, obj);\n },\n boolean(obj, _typ, _options, _refStack) {\n return obj ? simpleTokens.true : simpleTokens.false;\n },\n null(_obj, _typ, _options, _refStack) {\n return simpleTokens.null;\n },\n undefined(_obj, _typ, _options, _refStack) {\n return simpleTokens.undefined;\n },\n ArrayBuffer(obj, _typ, _options, _refStack) {\n return new token.Token(token.Type.bytes, new Uint8Array(obj));\n },\n DataView(obj, _typ, _options, _refStack) {\n return new token.Token(token.Type.bytes, new Uint8Array(obj.buffer, obj.byteOffset, obj.byteLength));\n },\n Array(obj, _typ, options, refStack) {\n if (!obj.length) {\n if (options.addBreakTokens === true) {\n return [\n simpleTokens.emptyArray,\n new token.Token(token.Type.break)\n ];\n }\n return simpleTokens.emptyArray;\n }\n refStack = Ref.createCheck(refStack, obj);\n const entries = [];\n let i = 0;\n for (const e of obj) {\n entries[i++] = objectToTokens(e, options, refStack);\n }\n if (options.addBreakTokens) {\n return [\n new token.Token(token.Type.array, obj.length),\n entries,\n new token.Token(token.Type.break)\n ];\n }\n return [\n new token.Token(token.Type.array, obj.length),\n entries\n ];\n },\n Object(obj, typ, options, refStack) {\n const isMap = typ !== 'Object';\n const keys = isMap ? obj.keys() : Object.keys(obj);\n const length = isMap ? obj.size : keys.length;\n if (!length) {\n if (options.addBreakTokens === true) {\n return [\n simpleTokens.emptyMap,\n new token.Token(token.Type.break)\n ];\n }\n return simpleTokens.emptyMap;\n }\n refStack = Ref.createCheck(refStack, obj);\n const entries = [];\n let i = 0;\n for (const key of keys) {\n entries[i++] = [\n objectToTokens(key, options, refStack),\n objectToTokens(isMap ? obj.get(key) : obj[key], options, refStack)\n ];\n }\n sortMapEntries(entries, options);\n if (options.addBreakTokens) {\n return [\n new token.Token(token.Type.map, length),\n entries,\n new token.Token(token.Type.break)\n ];\n }\n return [\n new token.Token(token.Type.map, length),\n entries\n ];\n }\n};\ntypeEncoders.Map = typeEncoders.Object;\ntypeEncoders.Buffer = typeEncoders.Uint8Array;\nfor (const typ of 'Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64'.split(' ')) {\n typeEncoders[`${ typ }Array`] = typeEncoders.DataView;\n}\nfunction objectToTokens(obj, options = {}, refStack) {\n const typ = is.is(obj);\n const customTypeEncoder = options && options.typeEncoders && options.typeEncoders[typ] || typeEncoders[typ];\n if (typeof customTypeEncoder === 'function') {\n const tokens = customTypeEncoder(obj, typ, options, refStack);\n if (tokens != null) {\n return tokens;\n }\n }\n const typeEncoder = typeEncoders[typ];\n if (!typeEncoder) {\n throw new Error(`${ common.encodeErrPrefix } unsupported type: ${ typ }`);\n }\n return typeEncoder(obj, typ, options, refStack);\n}\nfunction sortMapEntries(entries, options) {\n if (options.mapSorter) {\n entries.sort(options.mapSorter);\n }\n}\nfunction mapSorter(e1, e2) {\n const keyToken1 = Array.isArray(e1[0]) ? e1[0][0] : e1[0];\n const keyToken2 = Array.isArray(e2[0]) ? e2[0][0] : e2[0];\n if (keyToken1.type !== keyToken2.type) {\n return keyToken1.type.compare(keyToken2.type);\n }\n const major = keyToken1.type.major;\n const tcmp = cborEncoders[major].compareTokens(keyToken1, keyToken2);\n if (tcmp === 0) {\n console.warn('WARNING: complex key types used, CBOR key sorting guarantees are gone');\n }\n return tcmp;\n}\nfunction tokensToEncoded(buf, tokens, encoders, options) {\n if (Array.isArray(tokens)) {\n for (const token of tokens) {\n tokensToEncoded(buf, token, encoders, options);\n }\n } else {\n encoders[tokens.type.major](buf, tokens, options);\n }\n}\nfunction encodeCustom(data, encoders, options) {\n const tokens = objectToTokens(data, options);\n if (!Array.isArray(tokens) && options.quickEncodeToken) {\n const quickBytes = options.quickEncodeToken(tokens);\n if (quickBytes) {\n return quickBytes;\n }\n const encoder = encoders[tokens.type.major];\n if (encoder.encodedSize) {\n const size = encoder.encodedSize(tokens, options);\n const buf = new bl.Bl(size);\n encoder(buf, tokens, options);\n if (buf.chunks.length !== 1) {\n throw new Error(`Unexpected error: pre-calculated length for ${ tokens } was wrong`);\n }\n return byteUtils.asU8A(buf.chunks[0]);\n }\n }\n tokensToEncoded(buf, tokens, encoders, options);\n return buf.toBytes(true);\n}\nfunction encode(data, options) {\n options = Object.assign({}, defaultEncodeOptions, options);\n return encodeCustom(data, cborEncoders, options);\n}\n\nexports.Ref = Ref;\nexports.encode = encode;\nexports.encodeCustom = encodeCustom;\nexports.objectToTokens = objectToTokens;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst typeofs = [\n 'string',\n 'number',\n 'bigint',\n 'symbol'\n];\nconst objectTypeNames = [\n 'Function',\n 'Generator',\n 'AsyncGenerator',\n 'GeneratorFunction',\n 'AsyncGeneratorFunction',\n 'AsyncFunction',\n 'Observable',\n 'Array',\n 'Buffer',\n 'Object',\n 'RegExp',\n 'Date',\n 'Error',\n 'Map',\n 'Set',\n 'WeakMap',\n 'WeakSet',\n 'ArrayBuffer',\n 'SharedArrayBuffer',\n 'DataView',\n 'Promise',\n 'URL',\n 'HTMLElement',\n 'Int8Array',\n 'Uint8Array',\n 'Uint8ClampedArray',\n 'Int16Array',\n 'Uint16Array',\n 'Int32Array',\n 'Uint32Array',\n 'Float32Array',\n 'Float64Array',\n 'BigInt64Array',\n 'BigUint64Array'\n];\nfunction is(value) {\n if (value === null) {\n return 'null';\n }\n if (value === undefined) {\n return 'undefined';\n }\n if (value === true || value === false) {\n return 'boolean';\n }\n const typeOf = typeof value;\n if (typeofs.includes(typeOf)) {\n return typeOf;\n }\n if (typeOf === 'function') {\n return 'Function';\n }\n if (Array.isArray(value)) {\n return 'Array';\n }\n if (isBuffer(value)) {\n return 'Buffer';\n }\n const objectType = getObjectType(value);\n if (objectType) {\n return objectType;\n }\n return 'Object';\n}\nfunction isBuffer(value) {\n return value && value.constructor && value.constructor.isBuffer && value.constructor.isBuffer.call(null, value);\n}\nfunction getObjectType(value) {\n const objectTypeName = Object.prototype.toString.call(value).slice(8, -1);\n if (objectTypeNames.includes(objectTypeName)) {\n return objectTypeName;\n }\n return undefined;\n}\n\nexports.is = is;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass Type {\n constructor(major, name, terminal) {\n this.major = major;\n this.majorEncoded = major << 5;\n this.name = name;\n this.terminal = terminal;\n }\n toString() {\n return `Type[${ this.major }].${ this.name }`;\n }\n compare(typ) {\n return this.major < typ.major ? -1 : this.major > typ.major ? 1 : 0;\n }\n}\nType.uint = new Type(0, 'uint', true);\nType.negint = new Type(1, 'negint', true);\nType.bytes = new Type(2, 'bytes', true);\nType.string = new Type(3, 'string', true);\nType.array = new Type(4, 'array', false);\nType.map = new Type(5, 'map', false);\nType.tag = new Type(6, 'tag', false);\nType.float = new Type(7, 'float', true);\nType.false = new Type(7, 'false', true);\nType.true = new Type(7, 'true', true);\nType.null = new Type(7, 'null', true);\nType.undefined = new Type(7, 'undefined', true);\nType.break = new Type(7, 'break', true);\nclass Token {\n constructor(type, value, encodedLength) {\n this.type = type;\n this.value = value;\n this.encodedLength = encodedLength;\n this.encodedBytes = undefined;\n }\n toString() {\n return `Token[${ this.type }].${ this.value }`;\n }\n}\n\nexports.Token = Token;\nexports.Type = Type;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar byteUtils = require('./byte-utils.js');\n\nconst defaultChunkSize = 256;\nclass Bl {\n constructor(chunkSize = defaultChunkSize) {\n this.chunkSize = chunkSize;\n this.cursor = 0;\n this.maxCursor = -1;\n this.chunks = [];\n this._initReuseChunk = null;\n }\n reset() {\n this.chunks = [];\n this.cursor = 0;\n this.maxCursor = -1;\n if (this._initReuseChunk !== null) {\n this.chunks.push(this._initReuseChunk);\n this.maxCursor = this._initReuseChunk.length - 1;\n }\n }\n push(bytes) {\n let topChunk = this.chunks[this.chunks.length - 1];\n const newMax = this.cursor + bytes.length;\n if (newMax <= this.maxCursor + 1) {\n const chunkPos = topChunk.length - (this.maxCursor - this.cursor) - 1;\n topChunk.set(bytes, chunkPos);\n } else {\n if (topChunk) {\n const chunkPos = topChunk.length - (this.maxCursor - this.cursor) - 1;\n if (chunkPos < topChunk.length) {\n this.chunks[this.chunks.length - 1] = topChunk.subarray(0, chunkPos);\n this.maxCursor = this.cursor - 1;\n }\n }\n if (bytes.length < 64 && bytes.length < this.chunkSize) {\n topChunk = byteUtils.alloc(this.chunkSize);\n this.chunks.push(topChunk);\n this.maxCursor += topChunk.length;\n if (this._initReuseChunk === null) {\n this._initReuseChunk = topChunk;\n }\n topChunk.set(bytes, 0);\n } else {\n this.chunks.push(bytes);\n this.maxCursor += bytes.length;\n }\n }\n this.cursor += bytes.length;\n }\n toBytes(reset = false) {\n let byts;\n if (this.chunks.length === 1) {\n const chunk = this.chunks[0];\n if (reset && this.cursor > chunk.length / 2) {\n byts = this.cursor === chunk.length ? chunk : chunk.subarray(0, this.cursor);\n this._initReuseChunk = null;\n this.chunks = [];\n } else {\n byts = byteUtils.slice(chunk, 0, this.cursor);\n }\n } else {\n byts = byteUtils.concat(this.chunks, this.cursor);\n }\n if (reset) {\n this.reset();\n }\n return byts;\n }\n}\n\nexports.Bl = Bl;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst useBuffer = globalThis.process && !globalThis.process.browser && globalThis.Buffer && typeof globalThis.Buffer.isBuffer === 'function';\nconst textDecoder = new TextDecoder();\nconst textEncoder = new TextEncoder();\nfunction isBuffer(buf) {\n return useBuffer && globalThis.Buffer.isBuffer(buf);\n}\nfunction asU8A(buf) {\n if (!(buf instanceof Uint8Array)) {\n return Uint8Array.from(buf);\n }\n return isBuffer(buf) ? new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength) : buf;\n}\nconst toString = useBuffer ? (bytes, start, end) => {\n return end - start > 64 ? globalThis.Buffer.from(bytes.subarray(start, end)).toString('utf8') : utf8Slice(bytes, start, end);\n} : (bytes, start, end) => {\n return end - start > 64 ? textDecoder.decode(bytes.subarray(start, end)) : utf8Slice(bytes, start, end);\n};\nconst fromString = useBuffer ? string => {\n return string.length > 64 ? globalThis.Buffer.from(string) : utf8ToBytes(string);\n} : string => {\n return string.length > 64 ? textEncoder.encode(string) : utf8ToBytes(string);\n};\nconst fromArray = arr => {\n return Uint8Array.from(arr);\n};\nconst slice = useBuffer ? (bytes, start, end) => {\n if (isBuffer(bytes)) {\n return new Uint8Array(bytes.subarray(start, end));\n }\n return bytes.slice(start, end);\n} : (bytes, start, end) => {\n return bytes.slice(start, end);\n};\nconst concat = useBuffer ? (chunks, length) => {\n chunks = chunks.map(c => c instanceof Uint8Array ? c : globalThis.Buffer.from(c));\n return asU8A(globalThis.Buffer.concat(chunks, length));\n} : (chunks, length) => {\n const out = new Uint8Array(length);\n let off = 0;\n for (let b of chunks) {\n if (off + b.length > out.length) {\n b = b.subarray(0, out.length - off);\n }\n out.set(b, off);\n off += b.length;\n }\n return out;\n};\nconst alloc = useBuffer ? size => {\n return globalThis.Buffer.allocUnsafe(size);\n} : size => {\n return new Uint8Array(size);\n};\nconst toHex = useBuffer ? d => {\n if (typeof d === 'string') {\n return d;\n }\n return globalThis.Buffer.from(toBytes(d)).toString('hex');\n} : d => {\n if (typeof d === 'string') {\n return d;\n }\n return Array.prototype.reduce.call(toBytes(d), (p, c) => `${ p }${ c.toString(16).padStart(2, '0') }`, '');\n};\nconst fromHex = useBuffer ? hex => {\n if (hex instanceof Uint8Array) {\n return hex;\n }\n return globalThis.Buffer.from(hex, 'hex');\n} : hex => {\n if (hex instanceof Uint8Array) {\n return hex;\n }\n if (!hex.length) {\n return new Uint8Array(0);\n }\n return new Uint8Array(hex.split('').map((c, i, d) => i % 2 === 0 ? `0x${ c }${ d[i + 1] }` : '').filter(Boolean).map(e => parseInt(e, 16)));\n};\nfunction toBytes(obj) {\n if (obj instanceof Uint8Array && obj.constructor.name === 'Uint8Array') {\n return obj;\n }\n if (obj instanceof ArrayBuffer) {\n return new Uint8Array(obj);\n }\n if (ArrayBuffer.isView(obj)) {\n return new Uint8Array(obj.buffer, obj.byteOffset, obj.byteLength);\n }\n throw new Error('Unknown type, must be binary type');\n}\nfunction compare(b1, b2) {\n if (isBuffer(b1) && isBuffer(b2)) {\n return b1.compare(b2);\n }\n for (let i = 0; i < b1.length; i++) {\n if (b1[i] === b2[i]) {\n continue;\n }\n return b1[i] < b2[i] ? -1 : 1;\n }\n return 0;\n}\nfunction utf8ToBytes(string, units = Infinity) {\n let codePoint;\n const length = string.length;\n let leadSurrogate = null;\n const bytes = [];\n for (let i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i);\n if (codePoint > 55295 && codePoint < 57344) {\n if (!leadSurrogate) {\n if (codePoint > 56319) {\n if ((units -= 3) > -1)\n bytes.push(239, 191, 189);\n continue;\n } else if (i + 1 === length) {\n if ((units -= 3) > -1)\n bytes.push(239, 191, 189);\n continue;\n }\n leadSurrogate = codePoint;\n continue;\n }\n if (codePoint < 56320) {\n if ((units -= 3) > -1)\n bytes.push(239, 191, 189);\n leadSurrogate = codePoint;\n continue;\n }\n codePoint = (leadSurrogate - 55296 << 10 | codePoint - 56320) + 65536;\n } else if (leadSurrogate) {\n if ((units -= 3) > -1)\n bytes.push(239, 191, 189);\n }\n leadSurrogate = null;\n if (codePoint < 128) {\n if ((units -= 1) < 0)\n break;\n bytes.push(codePoint);\n } else if (codePoint < 2048) {\n if ((units -= 2) < 0)\n break;\n bytes.push(codePoint >> 6 | 192, codePoint & 63 | 128);\n } else if (codePoint < 65536) {\n if ((units -= 3) < 0)\n break;\n bytes.push(codePoint >> 12 | 224, codePoint >> 6 & 63 | 128, codePoint & 63 | 128);\n } else if (codePoint < 1114112) {\n if ((units -= 4) < 0)\n break;\n bytes.push(codePoint >> 18 | 240, codePoint >> 12 & 63 | 128, codePoint >> 6 & 63 | 128, codePoint & 63 | 128);\n } else {\n throw new Error('Invalid code point');\n }\n }\n return bytes;\n}\nfunction utf8Slice(buf, offset, end) {\n const res = [];\n while (offset < end) {\n const firstByte = buf[offset];\n let codePoint = null;\n let bytesPerSequence = firstByte > 239 ? 4 : firstByte > 223 ? 3 : firstByte > 191 ? 2 : 1;\n if (offset + bytesPerSequence <= end) {\n let secondByte, thirdByte, fourthByte, tempCodePoint;\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 128) {\n codePoint = firstByte;\n }\n break;\n case 2:\n secondByte = buf[offset + 1];\n if ((secondByte & 192) === 128) {\n tempCodePoint = (firstByte & 31) << 6 | secondByte & 63;\n if (tempCodePoint > 127) {\n codePoint = tempCodePoint;\n }\n }\n break;\n case 3:\n secondByte = buf[offset + 1];\n thirdByte = buf[offset + 2];\n if ((secondByte & 192) === 128 && (thirdByte & 192) === 128) {\n tempCodePoint = (firstByte & 15) << 12 | (secondByte & 63) << 6 | thirdByte & 63;\n if (tempCodePoint > 2047 && (tempCodePoint < 55296 || tempCodePoint > 57343)) {\n codePoint = tempCodePoint;\n }\n }\n break;\n case 4:\n secondByte = buf[offset + 1];\n thirdByte = buf[offset + 2];\n fourthByte = buf[offset + 3];\n if ((secondByte & 192) === 128 && (thirdByte & 192) === 128 && (fourthByte & 192) === 128) {\n tempCodePoint = (firstByte & 15) << 18 | (secondByte & 63) << 12 | (thirdByte & 63) << 6 | fourthByte & 63;\n if (tempCodePoint > 65535 && tempCodePoint < 1114112) {\n codePoint = tempCodePoint;\n }\n }\n }\n }\n if (codePoint === null) {\n codePoint = 65533;\n bytesPerSequence = 1;\n } else if (codePoint > 65535) {\n codePoint -= 65536;\n res.push(codePoint >>> 10 & 1023 | 55296);\n codePoint = 56320 | codePoint & 1023;\n }\n res.push(codePoint);\n offset += bytesPerSequence;\n }\n return decodeCodePointsArray(res);\n}\nconst MAX_ARGUMENTS_LENGTH = 4096;\nfunction decodeCodePointsArray(codePoints) {\n const len = codePoints.length;\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints);\n }\n let res = '';\n let i = 0;\n while (i < len) {\n res += String.fromCharCode.apply(String, codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH));\n }\n return res;\n}\n\nexports.alloc = alloc;\nexports.asU8A = asU8A;\nexports.compare = compare;\nexports.concat = concat;\nexports.decodeCodePointsArray = decodeCodePointsArray;\nexports.fromArray = fromArray;\nexports.fromHex = fromHex;\nexports.fromString = fromString;\nexports.slice = slice;\nexports.toHex = toHex;\nexports.toString = toString;\nexports.useBuffer = useBuffer;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst decodeErrPrefix = 'CBOR decode error:';\nconst encodeErrPrefix = 'CBOR encode error:';\nconst uintMinorPrefixBytes = [];\nuintMinorPrefixBytes[23] = 1;\nuintMinorPrefixBytes[24] = 2;\nuintMinorPrefixBytes[25] = 3;\nuintMinorPrefixBytes[26] = 5;\nuintMinorPrefixBytes[27] = 9;\nfunction assertEnoughData(data, pos, need) {\n if (data.length - pos < need) {\n throw new Error(`${ decodeErrPrefix } not enough data for type`);\n }\n}\n\nexports.assertEnoughData = assertEnoughData;\nexports.decodeErrPrefix = decodeErrPrefix;\nexports.encodeErrPrefix = encodeErrPrefix;\nexports.uintMinorPrefixBytes = uintMinorPrefixBytes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\nvar _1negint = require('./1negint.js');\nvar _2bytes = require('./2bytes.js');\nvar _3string = require('./3string.js');\nvar _4array = require('./4array.js');\nvar _5map = require('./5map.js');\nvar _6tag = require('./6tag.js');\nvar _7float = require('./7float.js');\nvar common = require('./common.js');\nvar byteUtils = require('./byte-utils.js');\n\nfunction invalidMinor(data, pos, minor) {\n throw new Error(`${ common.decodeErrPrefix } encountered invalid minor (${ minor }) for major ${ data[pos] >>> 5 }`);\n}\nfunction errorer(msg) {\n return () => {\n throw new Error(`${ common.decodeErrPrefix } ${ msg }`);\n };\n}\nconst jump = [];\nfor (let i = 0; i <= 23; i++) {\n jump[i] = invalidMinor;\n}\njump[24] = _0uint.decodeUint8;\njump[25] = _0uint.decodeUint16;\njump[26] = _0uint.decodeUint32;\njump[27] = _0uint.decodeUint64;\njump[28] = invalidMinor;\njump[29] = invalidMinor;\njump[30] = invalidMinor;\njump[31] = invalidMinor;\nfor (let i = 32; i <= 55; i++) {\n jump[i] = invalidMinor;\n}\njump[56] = _1negint.decodeNegint8;\njump[57] = _1negint.decodeNegint16;\njump[58] = _1negint.decodeNegint32;\njump[59] = _1negint.decodeNegint64;\njump[60] = invalidMinor;\njump[61] = invalidMinor;\njump[62] = invalidMinor;\njump[63] = invalidMinor;\nfor (let i = 64; i <= 87; i++) {\n jump[i] = _2bytes.decodeBytesCompact;\n}\njump[88] = _2bytes.decodeBytes8;\njump[89] = _2bytes.decodeBytes16;\njump[90] = _2bytes.decodeBytes32;\njump[91] = _2bytes.decodeBytes64;\njump[92] = invalidMinor;\njump[93] = invalidMinor;\njump[94] = invalidMinor;\njump[95] = errorer('indefinite length bytes/strings are not supported');\nfor (let i = 96; i <= 119; i++) {\n jump[i] = _3string.decodeStringCompact;\n}\njump[120] = _3string.decodeString8;\njump[121] = _3string.decodeString16;\njump[122] = _3string.decodeString32;\njump[123] = _3string.decodeString64;\njump[124] = invalidMinor;\njump[125] = invalidMinor;\njump[126] = invalidMinor;\njump[127] = errorer('indefinite length bytes/strings are not supported');\nfor (let i = 128; i <= 151; i++) {\n jump[i] = _4array.decodeArrayCompact;\n}\njump[152] = _4array.decodeArray8;\njump[153] = _4array.decodeArray16;\njump[154] = _4array.decodeArray32;\njump[155] = _4array.decodeArray64;\njump[156] = invalidMinor;\njump[157] = invalidMinor;\njump[158] = invalidMinor;\njump[159] = _4array.decodeArrayIndefinite;\nfor (let i = 160; i <= 183; i++) {\n jump[i] = _5map.decodeMapCompact;\n}\njump[184] = _5map.decodeMap8;\njump[185] = _5map.decodeMap16;\njump[186] = _5map.decodeMap32;\njump[187] = _5map.decodeMap64;\njump[188] = invalidMinor;\njump[189] = invalidMinor;\njump[190] = invalidMinor;\njump[191] = _5map.decodeMapIndefinite;\nfor (let i = 192; i <= 215; i++) {\n jump[i] = _6tag.decodeTagCompact;\n}\njump[216] = _6tag.decodeTag8;\njump[217] = _6tag.decodeTag16;\njump[218] = _6tag.decodeTag32;\njump[219] = _6tag.decodeTag64;\njump[220] = invalidMinor;\njump[221] = invalidMinor;\njump[222] = invalidMinor;\njump[223] = invalidMinor;\nfor (let i = 224; i <= 243; i++) {\n jump[i] = errorer('simple values are not supported');\n}\njump[244] = invalidMinor;\njump[245] = invalidMinor;\njump[246] = invalidMinor;\njump[247] = _7float.decodeUndefined;\njump[248] = errorer('simple values are not supported');\njump[249] = _7float.decodeFloat16;\njump[250] = _7float.decodeFloat32;\njump[251] = _7float.decodeFloat64;\njump[252] = invalidMinor;\njump[253] = invalidMinor;\njump[254] = invalidMinor;\njump[255] = _7float.decodeBreak;\nconst quick = [];\nfor (let i = 0; i < 24; i++) {\n quick[i] = new token.Token(token.Type.uint, i, 1);\n}\nfor (let i = -1; i >= -24; i--) {\n quick[31 - i] = new token.Token(token.Type.negint, i, 1);\n}\nquick[64] = new token.Token(token.Type.bytes, new Uint8Array(0), 1);\nquick[96] = new token.Token(token.Type.string, '', 1);\nquick[128] = new token.Token(token.Type.array, 0, 1);\nquick[160] = new token.Token(token.Type.map, 0, 1);\nquick[244] = new token.Token(token.Type.false, false, 1);\nquick[245] = new token.Token(token.Type.true, true, 1);\nquick[246] = new token.Token(token.Type.null, null, 1);\nfunction quickEncodeToken(token$1) {\n switch (token$1.type) {\n case token.Type.false:\n return byteUtils.fromArray([244]);\n case token.Type.true:\n return byteUtils.fromArray([245]);\n case token.Type.null:\n return byteUtils.fromArray([246]);\n case token.Type.bytes:\n if (!token$1.value.length) {\n return byteUtils.fromArray([64]);\n }\n return;\n case token.Type.string:\n if (token$1.value === '') {\n return byteUtils.fromArray([96]);\n }\n return;\n case token.Type.array:\n if (token$1.value === 0) {\n return byteUtils.fromArray([128]);\n }\n return;\n case token.Type.map:\n if (token$1.value === 0) {\n return byteUtils.fromArray([160]);\n }\n return;\n case token.Type.uint:\n if (token$1.value < 24) {\n return byteUtils.fromArray([Number(token$1.value)]);\n }\n return;\n case token.Type.negint:\n if (token$1.value >= -24) {\n return byteUtils.fromArray([31 - Number(token$1.value)]);\n }\n }\n}\n\nexports.jump = jump;\nexports.quick = quick;\nexports.quickEncodeToken = quickEncodeToken;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar common = require('./common.js');\n\nconst uintBoundaries = [\n 24,\n 256,\n 65536,\n 4294967296,\n BigInt('18446744073709551616')\n];\nfunction readUint8(data, offset, options) {\n common.assertEnoughData(data, offset, 1);\n const value = data[offset];\n if (options.strict === true && value < uintBoundaries[0]) {\n throw new Error(`${ common.decodeErrPrefix } integer encoded in more bytes than necessary (strict decode)`);\n }\n return value;\n}\nfunction readUint16(data, offset, options) {\n common.assertEnoughData(data, offset, 2);\n const value = data[offset] << 8 | data[offset + 1];\n if (options.strict === true && value < uintBoundaries[1]) {\n throw new Error(`${ common.decodeErrPrefix } integer encoded in more bytes than necessary (strict decode)`);\n }\n return value;\n}\nfunction readUint32(data, offset, options) {\n common.assertEnoughData(data, offset, 4);\n const value = data[offset] * 16777216 + (data[offset + 1] << 16) + (data[offset + 2] << 8) + data[offset + 3];\n if (options.strict === true && value < uintBoundaries[2]) {\n throw new Error(`${ common.decodeErrPrefix } integer encoded in more bytes than necessary (strict decode)`);\n }\n return value;\n}\nfunction readUint64(data, offset, options) {\n common.assertEnoughData(data, offset, 8);\n const hi = data[offset] * 16777216 + (data[offset + 1] << 16) + (data[offset + 2] << 8) + data[offset + 3];\n const lo = data[offset + 4] * 16777216 + (data[offset + 5] << 16) + (data[offset + 6] << 8) + data[offset + 7];\n const value = (BigInt(hi) << BigInt(32)) + BigInt(lo);\n if (options.strict === true && value < uintBoundaries[3]) {\n throw new Error(`${ common.decodeErrPrefix } integer encoded in more bytes than necessary (strict decode)`);\n }\n if (value <= Number.MAX_SAFE_INTEGER) {\n return Number(value);\n }\n if (options.allowBigInt === true) {\n return value;\n }\n throw new Error(`${ common.decodeErrPrefix } integers outside of the safe integer range are not supported`);\n}\nfunction decodeUint8(data, pos, _minor, options) {\n return new token.Token(token.Type.uint, readUint8(data, pos + 1, options), 2);\n}\nfunction decodeUint16(data, pos, _minor, options) {\n return new token.Token(token.Type.uint, readUint16(data, pos + 1, options), 3);\n}\nfunction decodeUint32(data, pos, _minor, options) {\n return new token.Token(token.Type.uint, readUint32(data, pos + 1, options), 5);\n}\nfunction decodeUint64(data, pos, _minor, options) {\n return new token.Token(token.Type.uint, readUint64(data, pos + 1, options), 9);\n}\nfunction encodeUint(buf, token) {\n return encodeUintValue(buf, 0, token.value);\n}\nfunction encodeUintValue(buf, major, uint) {\n if (uint < uintBoundaries[0]) {\n const nuint = Number(uint);\n buf.push([major | nuint]);\n } else if (uint < uintBoundaries[1]) {\n const nuint = Number(uint);\n buf.push([\n major | 24,\n nuint\n ]);\n } else if (uint < uintBoundaries[2]) {\n const nuint = Number(uint);\n buf.push([\n major | 25,\n nuint >>> 8,\n nuint & 255\n ]);\n } else if (uint < uintBoundaries[3]) {\n const nuint = Number(uint);\n buf.push([\n major | 26,\n nuint >>> 24 & 255,\n nuint >>> 16 & 255,\n nuint >>> 8 & 255,\n nuint & 255\n ]);\n } else {\n const buint = BigInt(uint);\n if (buint < uintBoundaries[4]) {\n const set = [\n major | 27,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0\n ];\n let lo = Number(buint & BigInt(4294967295));\n let hi = Number(buint >> BigInt(32) & BigInt(4294967295));\n set[8] = lo & 255;\n lo = lo >> 8;\n set[7] = lo & 255;\n lo = lo >> 8;\n set[6] = lo & 255;\n lo = lo >> 8;\n set[5] = lo & 255;\n set[4] = hi & 255;\n hi = hi >> 8;\n set[3] = hi & 255;\n hi = hi >> 8;\n set[2] = hi & 255;\n hi = hi >> 8;\n set[1] = hi & 255;\n buf.push(set);\n } else {\n throw new Error(`${ common.decodeErrPrefix } encountered BigInt larger than allowable range`);\n }\n }\n}\nencodeUint.encodedSize = function encodedSize(token) {\n return encodeUintValue.encodedSize(token.value);\n};\nencodeUintValue.encodedSize = function encodedSize(uint) {\n if (uint < uintBoundaries[0]) {\n return 1;\n }\n if (uint < uintBoundaries[1]) {\n return 2;\n }\n if (uint < uintBoundaries[2]) {\n return 3;\n }\n if (uint < uintBoundaries[3]) {\n return 5;\n }\n return 9;\n};\nencodeUint.compareTokens = function compareTokens(tok1, tok2) {\n return tok1.value < tok2.value ? -1 : tok1.value > tok2.value ? 1 : 0;\n};\n\nexports.decodeUint16 = decodeUint16;\nexports.decodeUint32 = decodeUint32;\nexports.decodeUint64 = decodeUint64;\nexports.decodeUint8 = decodeUint8;\nexports.encodeUint = encodeUint;\nexports.encodeUintValue = encodeUintValue;\nexports.readUint16 = readUint16;\nexports.readUint32 = readUint32;\nexports.readUint64 = readUint64;\nexports.readUint8 = readUint8;\nexports.uintBoundaries = uintBoundaries;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\nvar common = require('./common.js');\n\nfunction decodeNegint8(data, pos, _minor, options) {\n return new token.Token(token.Type.negint, -1 - _0uint.readUint8(data, pos + 1, options), 2);\n}\nfunction decodeNegint16(data, pos, _minor, options) {\n return new token.Token(token.Type.negint, -1 - _0uint.readUint16(data, pos + 1, options), 3);\n}\nfunction decodeNegint32(data, pos, _minor, options) {\n return new token.Token(token.Type.negint, -1 - _0uint.readUint32(data, pos + 1, options), 5);\n}\nconst neg1b = BigInt(-1);\nconst pos1b = BigInt(1);\nfunction decodeNegint64(data, pos, _minor, options) {\n const int = _0uint.readUint64(data, pos + 1, options);\n if (typeof int !== 'bigint') {\n const value = -1 - int;\n if (value >= Number.MIN_SAFE_INTEGER) {\n return new token.Token(token.Type.negint, value, 9);\n }\n }\n if (options.allowBigInt !== true) {\n throw new Error(`${ common.decodeErrPrefix } integers outside of the safe integer range are not supported`);\n }\n return new token.Token(token.Type.negint, neg1b - BigInt(int), 9);\n}\nfunction encodeNegint(buf, token) {\n const negint = token.value;\n const unsigned = typeof negint === 'bigint' ? negint * neg1b - pos1b : negint * -1 - 1;\n _0uint.encodeUintValue(buf, token.type.majorEncoded, unsigned);\n}\nencodeNegint.encodedSize = function encodedSize(token) {\n const negint = token.value;\n const unsigned = typeof negint === 'bigint' ? negint * neg1b - pos1b : negint * -1 - 1;\n if (unsigned < _0uint.uintBoundaries[0]) {\n return 1;\n }\n if (unsigned < _0uint.uintBoundaries[1]) {\n return 2;\n }\n if (unsigned < _0uint.uintBoundaries[2]) {\n return 3;\n }\n if (unsigned < _0uint.uintBoundaries[3]) {\n return 5;\n }\n return 9;\n};\nencodeNegint.compareTokens = function compareTokens(tok1, tok2) {\n return tok1.value < tok2.value ? 1 : tok1.value > tok2.value ? -1 : 0;\n};\n\nexports.decodeNegint16 = decodeNegint16;\nexports.decodeNegint32 = decodeNegint32;\nexports.decodeNegint64 = decodeNegint64;\nexports.decodeNegint8 = decodeNegint8;\nexports.encodeNegint = encodeNegint;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar common = require('./common.js');\nvar _0uint = require('./0uint.js');\nvar byteUtils = require('./byte-utils.js');\n\nfunction toToken(data, pos, prefix, length) {\n common.assertEnoughData(data, pos, prefix + length);\n const buf = byteUtils.slice(data, pos + prefix, pos + prefix + length);\n return new token.Token(token.Type.bytes, buf, prefix + length);\n}\nfunction decodeBytesCompact(data, pos, minor, _options) {\n return toToken(data, pos, 1, minor);\n}\nfunction decodeBytes8(data, pos, _minor, options) {\n return toToken(data, pos, 2, _0uint.readUint8(data, pos + 1, options));\n}\nfunction decodeBytes16(data, pos, _minor, options) {\n return toToken(data, pos, 3, _0uint.readUint16(data, pos + 1, options));\n}\nfunction decodeBytes32(data, pos, _minor, options) {\n return toToken(data, pos, 5, _0uint.readUint32(data, pos + 1, options));\n}\nfunction decodeBytes64(data, pos, _minor, options) {\n const l = _0uint.readUint64(data, pos + 1, options);\n if (typeof l === 'bigint') {\n throw new Error(`${ common.decodeErrPrefix } 64-bit integer bytes lengths not supported`);\n }\n return toToken(data, pos, 9, l);\n}\nfunction tokenBytes(token$1) {\n if (token$1.encodedBytes === undefined) {\n token$1.encodedBytes = token$1.type === token.Type.string ? byteUtils.fromString(token$1.value) : token$1.value;\n }\n return token$1.encodedBytes;\n}\nfunction encodeBytes(buf, token) {\n const bytes = tokenBytes(token);\n _0uint.encodeUintValue(buf, token.type.majorEncoded, bytes.length);\n buf.push(bytes);\n}\nencodeBytes.encodedSize = function encodedSize(token) {\n const bytes = tokenBytes(token);\n return _0uint.encodeUintValue.encodedSize(bytes.length) + bytes.length;\n};\nencodeBytes.compareTokens = function compareTokens(tok1, tok2) {\n return compareBytes(tokenBytes(tok1), tokenBytes(tok2));\n};\nfunction compareBytes(b1, b2) {\n return b1.length < b2.length ? -1 : b1.length > b2.length ? 1 : byteUtils.compare(b1, b2);\n}\n\nexports.compareBytes = compareBytes;\nexports.decodeBytes16 = decodeBytes16;\nexports.decodeBytes32 = decodeBytes32;\nexports.decodeBytes64 = decodeBytes64;\nexports.decodeBytes8 = decodeBytes8;\nexports.decodeBytesCompact = decodeBytesCompact;\nexports.encodeBytes = encodeBytes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar common = require('./common.js');\nvar _0uint = require('./0uint.js');\nvar _2bytes = require('./2bytes.js');\nvar byteUtils = require('./byte-utils.js');\n\nfunction toToken(data, pos, prefix, length) {\n const totLength = prefix + length;\n common.assertEnoughData(data, pos, totLength);\n return new token.Token(token.Type.string, byteUtils.toString(data, pos + prefix, pos + totLength), totLength);\n}\nfunction decodeStringCompact(data, pos, minor, _options) {\n return toToken(data, pos, 1, minor);\n}\nfunction decodeString8(data, pos, _minor, options) {\n return toToken(data, pos, 2, _0uint.readUint8(data, pos + 1, options));\n}\nfunction decodeString16(data, pos, _minor, options) {\n return toToken(data, pos, 3, _0uint.readUint16(data, pos + 1, options));\n}\nfunction decodeString32(data, pos, _minor, options) {\n return toToken(data, pos, 5, _0uint.readUint32(data, pos + 1, options));\n}\nfunction decodeString64(data, pos, _minor, options) {\n const l = _0uint.readUint64(data, pos + 1, options);\n if (typeof l === 'bigint') {\n throw new Error(`${ common.decodeErrPrefix } 64-bit integer string lengths not supported`);\n }\n return toToken(data, pos, 9, l);\n}\nconst encodeString = _2bytes.encodeBytes;\n\nexports.decodeString16 = decodeString16;\nexports.decodeString32 = decodeString32;\nexports.decodeString64 = decodeString64;\nexports.decodeString8 = decodeString8;\nexports.decodeStringCompact = decodeStringCompact;\nexports.encodeString = encodeString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\nvar common = require('./common.js');\n\nfunction toToken(_data, _pos, prefix, length) {\n return new token.Token(token.Type.array, length, prefix);\n}\nfunction decodeArrayCompact(data, pos, minor, _options) {\n return toToken(data, pos, 1, minor);\n}\nfunction decodeArray8(data, pos, _minor, options) {\n return toToken(data, pos, 2, _0uint.readUint8(data, pos + 1, options));\n}\nfunction decodeArray16(data, pos, _minor, options) {\n return toToken(data, pos, 3, _0uint.readUint16(data, pos + 1, options));\n}\nfunction decodeArray32(data, pos, _minor, options) {\n return toToken(data, pos, 5, _0uint.readUint32(data, pos + 1, options));\n}\nfunction decodeArray64(data, pos, _minor, options) {\n const l = _0uint.readUint64(data, pos + 1, options);\n if (typeof l === 'bigint') {\n throw new Error(`${ common.decodeErrPrefix } 64-bit integer array lengths not supported`);\n }\n return toToken(data, pos, 9, l);\n}\nfunction decodeArrayIndefinite(data, pos, _minor, options) {\n if (options.allowIndefinite === false) {\n throw new Error(`${ common.decodeErrPrefix } indefinite length items not allowed`);\n }\n return toToken(data, pos, 1, Infinity);\n}\nfunction encodeArray(buf, token$1) {\n _0uint.encodeUintValue(buf, token.Type.array.majorEncoded, token$1.value);\n}\nencodeArray.compareTokens = _0uint.encodeUint.compareTokens;\n\nexports.decodeArray16 = decodeArray16;\nexports.decodeArray32 = decodeArray32;\nexports.decodeArray64 = decodeArray64;\nexports.decodeArray8 = decodeArray8;\nexports.decodeArrayCompact = decodeArrayCompact;\nexports.decodeArrayIndefinite = decodeArrayIndefinite;\nexports.encodeArray = encodeArray;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\nvar common = require('./common.js');\n\nfunction toToken(_data, _pos, prefix, length) {\n return new token.Token(token.Type.map, length, prefix);\n}\nfunction decodeMapCompact(data, pos, minor, _options) {\n return toToken(data, pos, 1, minor);\n}\nfunction decodeMap8(data, pos, _minor, options) {\n return toToken(data, pos, 2, _0uint.readUint8(data, pos + 1, options));\n}\nfunction decodeMap16(data, pos, _minor, options) {\n return toToken(data, pos, 3, _0uint.readUint16(data, pos + 1, options));\n}\nfunction decodeMap32(data, pos, _minor, options) {\n return toToken(data, pos, 5, _0uint.readUint32(data, pos + 1, options));\n}\nfunction decodeMap64(data, pos, _minor, options) {\n const l = _0uint.readUint64(data, pos + 1, options);\n if (typeof l === 'bigint') {\n throw new Error(`${ common.decodeErrPrefix } 64-bit integer map lengths not supported`);\n }\n return toToken(data, pos, 9, l);\n}\nfunction decodeMapIndefinite(data, pos, _minor, options) {\n if (options.allowIndefinite === false) {\n throw new Error(`${ common.decodeErrPrefix } indefinite length items not allowed`);\n }\n return toToken(data, pos, 1, Infinity);\n}\nfunction encodeMap(buf, token$1) {\n _0uint.encodeUintValue(buf, token.Type.map.majorEncoded, token$1.value);\n}\nencodeMap.compareTokens = _0uint.encodeUint.compareTokens;\n\nexports.decodeMap16 = decodeMap16;\nexports.decodeMap32 = decodeMap32;\nexports.decodeMap64 = decodeMap64;\nexports.decodeMap8 = decodeMap8;\nexports.decodeMapCompact = decodeMapCompact;\nexports.decodeMapIndefinite = decodeMapIndefinite;\nexports.encodeMap = encodeMap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\n\nfunction decodeTagCompact(_data, _pos, minor, _options) {\n return new token.Token(token.Type.tag, minor, 1);\n}\nfunction decodeTag8(data, pos, _minor, options) {\n return new token.Token(token.Type.tag, _0uint.readUint8(data, pos + 1, options), 2);\n}\nfunction decodeTag16(data, pos, _minor, options) {\n return new token.Token(token.Type.tag, _0uint.readUint16(data, pos + 1, options), 3);\n}\nfunction decodeTag32(data, pos, _minor, options) {\n return new token.Token(token.Type.tag, _0uint.readUint32(data, pos + 1, options), 5);\n}\nfunction decodeTag64(data, pos, _minor, options) {\n return new token.Token(token.Type.tag, _0uint.readUint64(data, pos + 1, options), 9);\n}\nfunction encodeTag(buf, token$1) {\n _0uint.encodeUintValue(buf, token.Type.tag.majorEncoded, token$1.value);\n}\nencodeTag.compareTokens = _0uint.encodeUint.compareTokens;\n\nexports.decodeTag16 = decodeTag16;\nexports.decodeTag32 = decodeTag32;\nexports.decodeTag64 = decodeTag64;\nexports.decodeTag8 = decodeTag8;\nexports.decodeTagCompact = decodeTagCompact;\nexports.encodeTag = encodeTag;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar common = require('./common.js');\nvar _0uint = require('./0uint.js');\n\nconst MINOR_FALSE = 20;\nconst MINOR_TRUE = 21;\nconst MINOR_NULL = 22;\nconst MINOR_UNDEFINED = 23;\nfunction decodeUndefined(_data, _pos, _minor, options) {\n if (options.allowUndefined === false) {\n throw new Error(`${ common.decodeErrPrefix } undefined values are not supported`);\n }\n return new token.Token(token.Type.undefined, undefined, 1);\n}\nfunction decodeBreak(_data, _pos, _minor, options) {\n if (options.allowIndefinite === false) {\n throw new Error(`${ common.decodeErrPrefix } indefinite length items not allowed`);\n }\n return new token.Token(token.Type.break, undefined, 1);\n}\nfunction createToken(value, bytes, options) {\n if (options) {\n if (options.allowNaN === false && Number.isNaN(value)) {\n throw new Error(`${ common.decodeErrPrefix } NaN values are not supported`);\n }\n if (options.allowInfinity === false && (value === Infinity || value === -Infinity)) {\n throw new Error(`${ common.decodeErrPrefix } Infinity values are not supported`);\n }\n }\n return new token.Token(token.Type.float, value, bytes);\n}\nfunction decodeFloat16(data, pos, _minor, options) {\n return createToken(readFloat16(data, pos + 1), 3, options);\n}\nfunction decodeFloat32(data, pos, _minor, options) {\n return createToken(readFloat32(data, pos + 1), 5, options);\n}\nfunction decodeFloat64(data, pos, _minor, options) {\n return createToken(readFloat64(data, pos + 1), 9, options);\n}\nfunction encodeFloat(buf, token$1, options) {\n const float = token$1.value;\n if (float === false) {\n buf.push([token.Type.float.majorEncoded | MINOR_FALSE]);\n } else if (float === true) {\n buf.push([token.Type.float.majorEncoded | MINOR_TRUE]);\n } else if (float === null) {\n buf.push([token.Type.float.majorEncoded | MINOR_NULL]);\n } else if (float === undefined) {\n buf.push([token.Type.float.majorEncoded | MINOR_UNDEFINED]);\n } else {\n let decoded;\n let success = false;\n if (!options || options.float64 !== true) {\n encodeFloat16(float);\n decoded = readFloat16(ui8a, 1);\n if (float === decoded || Number.isNaN(float)) {\n ui8a[0] = 249;\n buf.push(ui8a.slice(0, 3));\n success = true;\n } else {\n encodeFloat32(float);\n decoded = readFloat32(ui8a, 1);\n if (float === decoded) {\n ui8a[0] = 250;\n buf.push(ui8a.slice(0, 5));\n success = true;\n }\n }\n }\n if (!success) {\n encodeFloat64(float);\n decoded = readFloat64(ui8a, 1);\n ui8a[0] = 251;\n buf.push(ui8a.slice(0, 9));\n }\n }\n}\nencodeFloat.encodedSize = function encodedSize(token, options) {\n const float = token.value;\n if (float === false || float === true || float === null || float === undefined) {\n return 1;\n }\n let decoded;\n if (!options || options.float64 !== true) {\n encodeFloat16(float);\n decoded = readFloat16(ui8a, 1);\n if (float === decoded || Number.isNaN(float)) {\n return 3;\n }\n encodeFloat32(float);\n decoded = readFloat32(ui8a, 1);\n if (float === decoded) {\n return 5;\n }\n }\n return 9;\n};\nconst buffer = new ArrayBuffer(9);\nconst dataView = new DataView(buffer, 1);\nconst ui8a = new Uint8Array(buffer, 0);\nfunction encodeFloat16(inp) {\n if (inp === Infinity) {\n dataView.setUint16(0, 31744, false);\n } else if (inp === -Infinity) {\n dataView.setUint16(0, 64512, false);\n } else if (Number.isNaN(inp)) {\n dataView.setUint16(0, 32256, false);\n } else {\n dataView.setFloat32(0, inp);\n const valu32 = dataView.getUint32(0);\n const exponent = (valu32 & 2139095040) >> 23;\n const mantissa = valu32 & 8388607;\n if (exponent === 255) {\n dataView.setUint16(0, 31744, false);\n } else if (exponent === 0) {\n dataView.setUint16(0, (inp & 2147483648) >> 16 | mantissa >> 13, false);\n } else {\n const logicalExponent = exponent - 127;\n if (logicalExponent < -24) {\n dataView.setUint16(0, 0);\n } else if (logicalExponent < -14) {\n dataView.setUint16(0, (valu32 & 2147483648) >> 16 | 1 << 24 + logicalExponent, false);\n } else {\n dataView.setUint16(0, (valu32 & 2147483648) >> 16 | logicalExponent + 15 << 10 | mantissa >> 13, false);\n }\n }\n }\n}\nfunction readFloat16(ui8a, pos) {\n if (ui8a.length - pos < 2) {\n throw new Error(`${ common.decodeErrPrefix } not enough data for float16`);\n }\n const half = (ui8a[pos] << 8) + ui8a[pos + 1];\n if (half === 31744) {\n return Infinity;\n }\n if (half === 64512) {\n return -Infinity;\n }\n if (half === 32256) {\n return NaN;\n }\n const exp = half >> 10 & 31;\n const mant = half & 1023;\n let val;\n if (exp === 0) {\n val = mant * 2 ** -24;\n } else if (exp !== 31) {\n val = (mant + 1024) * 2 ** (exp - 25);\n } else {\n val = mant === 0 ? Infinity : NaN;\n }\n return half & 32768 ? -val : val;\n}\nfunction encodeFloat32(inp) {\n dataView.setFloat32(0, inp, false);\n}\nfunction readFloat32(ui8a, pos) {\n if (ui8a.length - pos < 4) {\n throw new Error(`${ common.decodeErrPrefix } not enough data for float32`);\n }\n const offset = (ui8a.byteOffset || 0) + pos;\n return new DataView(ui8a.buffer, offset, 4).getFloat32(0, false);\n}\nfunction encodeFloat64(inp) {\n dataView.setFloat64(0, inp, false);\n}\nfunction readFloat64(ui8a, pos) {\n if (ui8a.length - pos < 8) {\n throw new Error(`${ common.decodeErrPrefix } not enough data for float64`);\n }\n const offset = (ui8a.byteOffset || 0) + pos;\n return new DataView(ui8a.buffer, offset, 8).getFloat64(0, false);\n}\nencodeFloat.compareTokens = _0uint.encodeUint.compareTokens;\n\nexports.decodeBreak = decodeBreak;\nexports.decodeFloat16 = decodeFloat16;\nexports.decodeFloat32 = decodeFloat32;\nexports.decodeFloat64 = decodeFloat64;\nexports.decodeUndefined = decodeUndefined;\nexports.encodeFloat = encodeFloat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar common = require('./common.js');\nvar token = require('./token.js');\nvar jump = require('./jump.js');\n\nconst defaultDecodeOptions = {\n strict: false,\n allowIndefinite: true,\n allowUndefined: true,\n allowBigInt: true\n};\nclass Tokeniser {\n constructor(data, options = {}) {\n this.pos = 0;\n this.data = data;\n this.options = options;\n }\n done() {\n return this.pos >= this.data.length;\n }\n next() {\n const byt = this.data[this.pos];\n let token = jump.quick[byt];\n if (token === undefined) {\n const decoder = jump.jump[byt];\n if (!decoder) {\n throw new Error(`${ common.decodeErrPrefix } no decoder for major type ${ byt >>> 5 } (byte 0x${ byt.toString(16).padStart(2, '0') })`);\n }\n const minor = byt & 31;\n token = decoder(this.data, this.pos, minor, this.options);\n }\n this.pos += token.encodedLength;\n return token;\n }\n}\nconst DONE = Symbol.for('DONE');\nconst BREAK = Symbol.for('BREAK');\nfunction tokenToArray(token, tokeniser, options) {\n const arr = [];\n for (let i = 0; i < token.value; i++) {\n const value = tokensToObject(tokeniser, options);\n if (value === BREAK) {\n if (token.value === Infinity) {\n break;\n }\n throw new Error(`${ common.decodeErrPrefix } got unexpected break to lengthed array`);\n }\n if (value === DONE) {\n throw new Error(`${ common.decodeErrPrefix } found array but not enough entries (got ${ i }, expected ${ token.value })`);\n }\n arr[i] = value;\n }\n return arr;\n}\nfunction tokenToMap(token, tokeniser, options) {\n const useMaps = options.useMaps === true;\n const obj = useMaps ? undefined : {};\n const m = useMaps ? new Map() : undefined;\n for (let i = 0; i < token.value; i++) {\n const key = tokensToObject(tokeniser, options);\n if (key === BREAK) {\n if (token.value === Infinity) {\n break;\n }\n throw new Error(`${ common.decodeErrPrefix } got unexpected break to lengthed map`);\n }\n if (key === DONE) {\n throw new Error(`${ common.decodeErrPrefix } found map but not enough entries (got ${ i } [no key], expected ${ token.value })`);\n }\n if (useMaps !== true && typeof key !== 'string') {\n throw new Error(`${ common.decodeErrPrefix } non-string keys not supported (got ${ typeof key })`);\n }\n const value = tokensToObject(tokeniser, options);\n if (value === DONE) {\n throw new Error(`${ common.decodeErrPrefix } found map but not enough entries (got ${ i } [no value], expected ${ token.value })`);\n }\n if (useMaps) {\n m.set(key, value);\n } else {\n obj[key] = value;\n }\n }\n return useMaps ? m : obj;\n}\nfunction tokensToObject(tokeniser, options) {\n if (tokeniser.done()) {\n return DONE;\n }\n const token$1 = tokeniser.next();\n if (token$1.type === token.Type.break) {\n return BREAK;\n }\n if (token$1.type.terminal) {\n return token$1.value;\n }\n if (token$1.type === token.Type.array) {\n return tokenToArray(token$1, tokeniser, options);\n }\n if (token$1.type === token.Type.map) {\n return tokenToMap(token$1, tokeniser, options);\n }\n if (token$1.type === token.Type.tag) {\n if (options.tags && typeof options.tags[token$1.value] === 'function') {\n const tagged = tokensToObject(tokeniser, options);\n return options.tags[token$1.value](tagged);\n }\n throw new Error(`${ common.decodeErrPrefix } tag not supported (${ token$1.value })`);\n }\n throw new Error('unsupported');\n}\nfunction decode(data, options) {\n if (!(data instanceof Uint8Array)) {\n throw new Error(`${ common.decodeErrPrefix } data to decode must be a Uint8Array`);\n }\n options = Object.assign({}, defaultDecodeOptions, options);\n const tokeniser = options.tokenizer || new Tokeniser(data, options);\n const decoded = tokensToObject(tokeniser, options);\n if (decoded === DONE) {\n throw new Error(`${ common.decodeErrPrefix } did not find any content to decode`);\n }\n if (decoded === BREAK) {\n throw new Error(`${ common.decodeErrPrefix } got unexpected break`);\n }\n if (!tokeniser.done()) {\n throw new Error(`${ common.decodeErrPrefix } too many terminals, data makes no sense`);\n }\n return decoded;\n}\n\nexports.Tokeniser = Tokeniser;\nexports.decode = decode;\nexports.tokensToObject = tokensToObject;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hasher = require('./hasher.js');\nvar bytes = require('../bytes.js');\n\nconst identity = hasher.from({\n name: 'identity',\n code: 0,\n encode: input => bytes.coerce(input)\n});\n\nexports.identity = identity;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar digest = require('./digest.js');\n\nconst from = ({name, code, encode}) => new Hasher(name, code, encode);\nclass Hasher {\n constructor(name, code, encode) {\n this.name = name;\n this.code = code;\n this.encode = encode;\n }\n async digest(input) {\n if (input instanceof Uint8Array) {\n const digest$1 = await this.encode(input);\n return digest.create(this.code, digest$1);\n } else {\n throw Error('Unknown type, must be binary type');\n }\n }\n}\n\nexports.Hasher = Hasher;\nexports.from = from;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar identity = require('./bases/identity.js');\nvar base2 = require('./bases/base2.js');\nvar base8 = require('./bases/base8.js');\nvar base10 = require('./bases/base10.js');\nvar base16 = require('./bases/base16.js');\nvar base32 = require('./bases/base32.js');\nvar base36 = require('./bases/base36.js');\nvar base58 = require('./bases/base58.js');\nvar base64 = require('./bases/base64.js');\nvar sha2 = require('./hashes/sha2.js');\nvar identity$1 = require('./hashes/identity.js');\nvar raw = require('./codecs/raw.js');\nvar json = require('./codecs/json.js');\nrequire('./index.js');\nvar cid = require('./cid.js');\nvar hasher = require('./hashes/hasher.js');\nvar digest = require('./hashes/digest.js');\nvar varint = require('./varint.js');\nvar bytes = require('./bytes.js');\n\nconst bases = {\n ...identity,\n ...base2,\n ...base8,\n ...base10,\n ...base16,\n ...base32,\n ...base36,\n ...base58,\n ...base64\n};\nconst hashes = {\n ...sha2,\n ...identity$1\n};\nconst codecs = {\n raw,\n json\n};\n\nexports.CID = cid.CID;\nexports.hasher = hasher;\nexports.digest = digest;\nexports.varint = varint;\nexports.bytes = bytes;\nexports.bases = bases;\nexports.codecs = codecs;\nexports.hashes = hashes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar bytes = require('../bytes.js');\n\nconst identity = base.from({\n prefix: '\\0',\n name: 'identity',\n encode: buf => bytes.toString(buf),\n decode: str => bytes.fromString(str)\n});\n\nexports.identity = identity;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base2 = base.rfc4648({\n prefix: '0',\n name: 'base2',\n alphabet: '01',\n bitsPerChar: 1\n});\n\nexports.base2 = base2;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base8 = base.rfc4648({\n prefix: '7',\n name: 'base8',\n alphabet: '01234567',\n bitsPerChar: 3\n});\n\nexports.base8 = base8;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base10 = base.baseX({\n prefix: '9',\n name: 'base10',\n alphabet: '0123456789'\n});\n\nexports.base10 = base10;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base16 = base.rfc4648({\n prefix: 'f',\n name: 'base16',\n alphabet: '0123456789abcdef',\n bitsPerChar: 4\n});\nconst base16upper = base.rfc4648({\n prefix: 'F',\n name: 'base16upper',\n alphabet: '0123456789ABCDEF',\n bitsPerChar: 4\n});\n\nexports.base16 = base16;\nexports.base16upper = base16upper;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base36 = base.baseX({\n prefix: 'k',\n name: 'base36',\n alphabet: '0123456789abcdefghijklmnopqrstuvwxyz'\n});\nconst base36upper = base.baseX({\n prefix: 'K',\n name: 'base36upper',\n alphabet: '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'\n});\n\nexports.base36 = base36;\nexports.base36upper = base36upper;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base64 = base.rfc4648({\n prefix: 'm',\n name: 'base64',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',\n bitsPerChar: 6\n});\nconst base64pad = base.rfc4648({\n prefix: 'M',\n name: 'base64pad',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=',\n bitsPerChar: 6\n});\nconst base64url = base.rfc4648({\n prefix: 'u',\n name: 'base64url',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_',\n bitsPerChar: 6\n});\nconst base64urlpad = base.rfc4648({\n prefix: 'U',\n name: 'base64urlpad',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=',\n bitsPerChar: 6\n});\n\nexports.base64 = base64;\nexports.base64pad = base64pad;\nexports.base64url = base64url;\nexports.base64urlpad = base64urlpad;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hasher = require('./hasher.js');\n\nconst sha = name => async data => new Uint8Array(await crypto.subtle.digest(name, data));\nconst sha256 = hasher.from({\n name: 'sha2-256',\n code: 18,\n encode: sha('SHA-256')\n});\nconst sha512 = hasher.from({\n name: 'sha2-512',\n code: 19,\n encode: sha('SHA-512')\n});\n\nexports.sha256 = sha256;\nexports.sha512 = sha512;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bytes = require('../bytes.js');\n\nconst name = 'raw';\nconst code = 85;\nconst encode = node => bytes.coerce(node);\nconst decode = data => bytes.coerce(data);\n\nexports.code = code;\nexports.decode = decode;\nexports.encode = encode;\nexports.name = name;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst textEncoder = new TextEncoder();\nconst textDecoder = new TextDecoder();\nconst name = 'json';\nconst code = 512;\nconst encode = node => textEncoder.encode(JSON.stringify(node));\nconst decode = data => JSON.parse(textDecoder.decode(data));\n\nexports.code = code;\nexports.decode = decode;\nexports.encode = encode;\nexports.name = name;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('./cid.js');\nvar varint = require('./varint.js');\nvar bytes = require('./bytes.js');\nvar hasher = require('./hashes/hasher.js');\nvar digest = require('./hashes/digest.js');\n\n\n\nexports.CID = cid.CID;\nexports.varint = varint;\nexports.bytes = bytes;\nexports.hasher = hasher;\nexports.digest = digest;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction initAssets() {\n}\n\nexports.initAssets = initAssets;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass NotInitializedError extends Error {\n constructor(message = 'not initialized') {\n super(message);\n this.name = 'NotInitializedError';\n this.code = NotInitializedError.code;\n }\n}\nNotInitializedError.code = 'ERR_NOT_INITIALIZED';\nclass AlreadyInitializingError extends Error {\n constructor(message = 'cannot initialize an initializing node') {\n super(message);\n this.name = 'AlreadyInitializingError';\n this.code = AlreadyInitializedError.code;\n }\n}\nAlreadyInitializingError.code = 'ERR_ALREADY_INITIALIZING';\nclass AlreadyInitializedError extends Error {\n constructor(message = 'cannot re-initialize an initialized node') {\n super(message);\n this.name = 'AlreadyInitializedError';\n this.code = AlreadyInitializedError.code;\n }\n}\nAlreadyInitializedError.code = 'ERR_ALREADY_INITIALIZED';\nclass NotStartedError extends Error {\n constructor(message = 'not started') {\n super(message);\n this.name = 'NotStartedError';\n this.code = NotStartedError.code;\n }\n}\nNotStartedError.code = 'ERR_NOT_STARTED';\nclass AlreadyStartingError extends Error {\n constructor(message = 'cannot start, already startin') {\n super(message);\n this.name = 'AlreadyStartingError';\n this.code = AlreadyStartingError.code;\n }\n}\nAlreadyStartingError.code = 'ERR_ALREADY_STARTING';\nclass AlreadyStartedError extends Error {\n constructor(message = 'cannot start, already started') {\n super(message);\n this.name = 'AlreadyStartedError';\n this.code = AlreadyStartedError.code;\n }\n}\nAlreadyStartedError.code = 'ERR_ALREADY_STARTED';\nclass NotEnabledError extends Error {\n constructor(message = 'not enabled') {\n super(message);\n this.name = 'NotEnabledError';\n this.code = NotEnabledError.code;\n }\n}\nNotEnabledError.code = 'ERR_NOT_ENABLED';\n\nexports.AlreadyInitializedError = AlreadyInitializedError;\nexports.AlreadyInitializingError = AlreadyInitializingError;\nexports.AlreadyStartedError = AlreadyStartedError;\nexports.AlreadyStartingError = AlreadyStartingError;\nexports.NotEnabledError = NotEnabledError;\nexports.NotInitializedError = NotInitializedError;\nexports.NotStartedError = NotStartedError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bases = require('./util/bases.js');\n\nfunction fromString(string, encoding = 'utf8') {\n const base = bases[encoding];\n if (!base) {\n throw new Error(`Unsupported encoding \"${ encoding }\"`);\n }\n return base.decoder.decode(`${ base.prefix }${ string }`);\n}\n\nexports.fromString = fromString;\n","'use strict';\n\nvar basics = require('multiformats/basics');\n\nfunction createCodec(name, prefix, encode, decode) {\n return {\n name,\n prefix,\n encoder: {\n name,\n prefix,\n encode\n },\n decoder: { decode }\n };\n}\nconst string = createCodec('utf8', 'u', buf => {\n const decoder = new TextDecoder('utf8');\n return 'u' + decoder.decode(buf);\n}, str => {\n const encoder = new TextEncoder();\n return encoder.encode(str.substring(1));\n});\nconst ascii = createCodec('ascii', 'a', buf => {\n let string = 'a';\n for (let i = 0; i < buf.length; i++) {\n string += String.fromCharCode(buf[i]);\n }\n return string;\n}, str => {\n str = str.substring(1);\n const buf = new Uint8Array(str.length);\n for (let i = 0; i < str.length; i++) {\n buf[i] = str.charCodeAt(i);\n }\n return buf;\n});\nconst BASES = {\n utf8: string,\n 'utf-8': string,\n hex: basics.bases.base16,\n latin1: ascii,\n ascii: ascii,\n binary: ascii,\n ...basics.bases\n};\n\nmodule.exports = BASES;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar service = require('../utils/service.js');\n\nfunction createStart({network, preload, peerId, keychain, repo, ipns, mfsPreload, print, options}) {\n const start = async () => {\n const {libp2p} = await service.Service.start(network, {\n peerId,\n repo,\n print,\n options\n });\n await Promise.all([\n ipns.startOnline({\n keychain,\n libp2p,\n peerId,\n repo\n }),\n preload.start(),\n mfsPreload.start()\n ]);\n };\n return start;\n}\n\nexports.createStart = createStart;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('../errors.js');\nvar utils = require('../utils.js');\n\nclass Service {\n static create({start, stop}) {\n return new Service(start, stop);\n }\n static async start(service, options) {\n const {state, activate} = service;\n switch (state.status) {\n case 'stopped': {\n try {\n const promise = activate(options);\n service.state = {\n status: 'starting',\n ready: promise\n };\n const result = await promise;\n service.state = {\n status: 'started',\n value: result\n };\n return result;\n } catch (error) {\n service.state = { status: 'stopped' };\n throw error;\n }\n }\n case 'starting': {\n throw new errors.AlreadyStartingError();\n }\n case 'started': {\n throw new errors.AlreadyStartedError();\n }\n case 'stopping': {\n await state.ready;\n return await Service.start(service, options);\n }\n default: {\n return Service.panic(service);\n }\n }\n }\n static async stop(service) {\n const {state, deactivate} = service;\n switch (state.status) {\n case 'stopped': {\n break;\n }\n case 'starting': {\n try {\n await state.ready;\n } catch (_) {\n }\n return await Service.stop(service);\n }\n case 'stopping': {\n return await state.ready;\n }\n case 'started': {\n if (deactivate) {\n await deactivate(state.value);\n }\n service.state = { status: 'stopped' };\n break;\n }\n default: {\n Service.panic(state);\n }\n }\n }\n static try({state}) {\n switch (state.status) {\n case 'started':\n return state.value;\n default:\n return null;\n }\n }\n static async use({state}, options) {\n switch (state.status) {\n case 'started':\n return state.value;\n case 'starting':\n return await utils.withTimeout(state.ready, options);\n default:\n throw new errors.NotStartedError();\n }\n }\n static panic({state}) {\n const status = JSON.stringify({ status: state.status });\n throw RangeError(`Service in invalid state ${ status }, should never happen if you see this please report a bug`);\n }\n constructor(activate, deactivate) {\n this.activate = activate;\n this.deactivate = deactivate;\n this.state = { status: 'stopped' };\n }\n async use(options) {\n return await Service.use(this, options);\n }\n try() {\n return Service.try(this);\n }\n}\n\nexports.Service = Service;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar isIpfs = require('is-ipfs');\nvar cid = require('multiformats/cid');\nvar key = require('interface-datastore/key');\nvar errCode = require('err-code');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar toCidAndPath = require('ipfs-core-utils/to-cid-and-path');\nvar dagPB = require('@ipld/dag-pb');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nconst ERR_BAD_PATH = 'ERR_BAD_PATH';\nconst OFFLINE_ERROR = 'This command must be run in online mode. Try running \\'ipfs daemon\\' first.';\nconst MFS_ROOT_KEY = new key.Key('/local/filesroot');\nconst MFS_MAX_CHUNK_SIZE = 262144;\nconst MFS_MAX_LINKS = 174;\nconst normalizePath = pathStr => {\n const cid$1 = cid.CID.asCID(pathStr);\n if (cid$1) {\n return `/ipfs/${ pathStr }`;\n }\n const str = pathStr.toString();\n try {\n return `/ipfs/${ cid.CID.parse(str) }`;\n } catch {\n }\n if (isIpfs__default['default'].path(str)) {\n return str;\n } else {\n throw errCode__default['default'](new Error(`invalid path: ${ pathStr }`), ERR_BAD_PATH);\n }\n};\nconst normalizeCidPath = path => {\n if (path instanceof Uint8Array) {\n return cid.CID.decode(path).toString();\n }\n path = path.toString();\n if (path.indexOf('/ipfs/') === 0) {\n path = path.substring('/ipfs/'.length);\n }\n if (path.charAt(path.length - 1) === '/') {\n path = path.substring(0, path.length - 1);\n }\n return path;\n};\nconst resolvePath = async function (repo, codecs, ipfsPath, options = {}) {\n const {cid: cid$1, path} = toCidAndPath.toCidAndPath(ipfsPath);\n if (path) {\n options.path = path;\n }\n let lastCid = cid$1;\n let lastRemainderPath = options.path || '';\n if (lastRemainderPath.startsWith('/')) {\n lastRemainderPath = lastRemainderPath.substring(1);\n }\n if (options.path) {\n try {\n for await (const {value, remainderPath} of resolve(cid$1, options.path, codecs, repo, { signal: options.signal })) {\n if (!cid.CID.asCID(value)) {\n break;\n }\n lastRemainderPath = remainderPath;\n lastCid = value;\n }\n } catch (err) {\n if (err.message.startsWith('Object has no property')) {\n err.message = `no link named \"${ lastRemainderPath.split('/')[0] }\" under ${ lastCid }`;\n err.code = 'ERR_NO_LINK';\n }\n throw err;\n }\n }\n return {\n cid: lastCid,\n remainderPath: lastRemainderPath || ''\n };\n};\nconst mapFile = file => {\n if (file.type !== 'file' && file.type !== 'directory' && file.type !== 'raw') {\n throw new Error(`Unknown node type '${ file.type }'`);\n }\n const output = {\n cid: file.cid,\n path: file.path,\n name: file.name,\n size: file.size,\n type: 'file'\n };\n if (file.type === 'directory') {\n output.type = 'dir';\n }\n if (file.type === 'file') {\n output.size = file.unixfs.fileSize();\n }\n if (file.type === 'file' || file.type === 'directory') {\n output.mode = file.unixfs.mode;\n if (file.unixfs.mtime !== undefined) {\n output.mtime = file.unixfs.mtime;\n }\n }\n return output;\n};\nconst withTimeout = withTimeoutOption.withTimeoutOption(async (promise, _options) => await promise);\nconst resolve = async function* (cid$1, path, codecs, repo, options) {\n const load = async cid => {\n const codec = await codecs.getCodec(cid.code);\n const block = await repo.blocks.get(cid, options);\n return codec.decode(block);\n };\n const parts = path.split('/').filter(Boolean);\n let value = await load(cid$1);\n let lastCid = cid$1;\n if (!parts.length) {\n yield {\n value,\n remainderPath: ''\n };\n }\n while (parts.length) {\n const key = parts.shift();\n if (!key) {\n throw errCode__default['default'](new Error(`Could not resolve path \"${ path }\"`), 'ERR_INVALID_PATH');\n }\n if (cid$1.code === dagPB__namespace.code && Array.isArray(value.Links)) {\n const link = value.Links.find(l => l.Name === key);\n if (link) {\n yield {\n value: link.Hash,\n remainderPath: parts.join('/')\n };\n value = await load(link.Hash);\n lastCid = link.Hash;\n continue;\n }\n }\n if (Object.prototype.hasOwnProperty.call(value, key)) {\n value = value[key];\n yield {\n value,\n remainderPath: parts.join('/')\n };\n } else {\n throw errCode__default['default'](new Error(`no link named \"${ key }\" under ${ lastCid }`), 'ERR_NO_LINK');\n }\n if (cid.CID.asCID(value)) {\n lastCid = value;\n value = await load(value);\n }\n }\n};\n\nexports.MFS_MAX_CHUNK_SIZE = MFS_MAX_CHUNK_SIZE;\nexports.MFS_MAX_LINKS = MFS_MAX_LINKS;\nexports.MFS_ROOT_KEY = MFS_ROOT_KEY;\nexports.OFFLINE_ERROR = OFFLINE_ERROR;\nexports.mapFile = mapFile;\nexports.normalizeCidPath = normalizeCidPath;\nexports.normalizePath = normalizePath;\nexports.resolve = resolve;\nexports.resolvePath = resolvePath;\nexports.withTimeout = withTimeout;\n","'use strict'\n\nconst { base58btc } = require('multiformats/bases/base58')\nconst { base32 } = require('multiformats/bases/base32')\nconst Digest = require('multiformats/hashes/digest')\nconst { Multiaddr } = require('multiaddr')\nconst mafmt = require('mafmt')\nconst { CID } = require('multiformats/cid')\nconst { URL } = require('iso-url')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst pathGatewayPattern = /^https?:\\/\\/[^/]+\\/(ip[fn]s)\\/([^/?#]+)/\nconst pathPattern = /^\\/(ip[fn]s)\\/([^/?#]+)/\nconst defaultProtocolMatch = 1\nconst defaultHashMath = 2\n\n// CID, libp2p-key or DNSLink\nconst subdomainGatewayPattern = /^https?:\\/\\/([^/]+)\\.(ip[fn]s)\\.[^/?]+/\nconst subdomainIdMatch = 1\nconst subdomainProtocolMatch = 2\n\n// Fully qualified domain name (FQDN) that has an explicit .tld suffix\nconst fqdnWithTld = /^(([a-z0-9]|[a-z0-9][a-z0-9-]*[a-z0-9])\\.)+([a-z0-9]|[a-z0-9][a-z0-9-]*[a-z0-9])$/\n\n/**\n * @param {*} hash\n */\nfunction isMultihash (hash) {\n const formatted = convertToString(hash)\n try {\n Digest.decode(base58btc.decode('z' + formatted))\n } catch {\n return false\n }\n\n return true\n}\n\n/**\n * @param {*} hash\n */\nfunction isBase32EncodedMultibase (hash) {\n try {\n base32.decode(hash)\n } catch {\n return false\n }\n\n return true\n}\n\n/**\n * @param {*} hash\n */\nfunction isCID (hash) {\n try {\n if (typeof hash === 'string') {\n return Boolean(CID.parse(hash))\n }\n\n if (hash instanceof Uint8Array) {\n return Boolean(CID.decode(hash))\n }\n\n return Boolean(CID.asCID(hash)) // eslint-disable-line no-new\n } catch (e) {\n return false\n }\n}\n\n/**\n * @param {*} input\n */\nfunction isMultiaddr (input) {\n if (!input) return false\n if (Multiaddr.isMultiaddr(input)) return true\n try {\n new Multiaddr(input) // eslint-disable-line no-new\n return true\n } catch (e) {\n return false\n }\n}\n\n/**\n * @param {string | Uint8Array | Multiaddr} input\n */\nfunction isPeerMultiaddr (input) {\n return isMultiaddr(input) && mafmt.P2P.matches(input)\n}\n\n/**\n * @param {string | Uint8Array} input\n * @param {RegExp | string} pattern\n * @param {number} [protocolMatch=1]\n * @param {number} [hashMatch=2]\n */\nfunction isIpfs (input, pattern, protocolMatch = defaultProtocolMatch, hashMatch = defaultHashMath) {\n const formatted = convertToString(input)\n if (!formatted) {\n return false\n }\n\n const match = formatted.match(pattern)\n if (!match) {\n return false\n }\n\n if (match[protocolMatch] !== 'ipfs') {\n return false\n }\n\n let hash = match[hashMatch]\n\n if (hash && pattern === subdomainGatewayPattern) {\n // when doing checks for subdomain context\n // ensure hash is case-insensitive\n // (browsers force-lowercase authority component anyway)\n hash = hash.toLowerCase()\n }\n\n return isCID(hash)\n}\n\n/**\n *\n * @param {string | Uint8Array} input\n * @param {string | RegExp} pattern\n * @param {number} [protocolMatch=1]\n * @param {number} [hashMatch=1]\n */\nfunction isIpns (input, pattern, protocolMatch = defaultProtocolMatch, hashMatch = defaultHashMath) {\n const formatted = convertToString(input)\n if (!formatted) {\n return false\n }\n const match = formatted.match(pattern)\n if (!match) {\n return false\n }\n\n if (match[protocolMatch] !== 'ipns') {\n return false\n }\n\n let ipnsId = match[hashMatch]\n\n if (ipnsId && pattern === subdomainGatewayPattern) {\n // when doing checks for subdomain context\n // ensure ipnsId is case-insensitive\n // (browsers force-lowercase authority compotent anyway)\n ipnsId = ipnsId.toLowerCase()\n // Check if it is cidv1\n if (isCID(ipnsId)) return true\n // Check if it looks like FQDN\n try {\n if (!ipnsId.includes('.') && ipnsId.includes('-')) {\n // name without tld, assuming its inlined into a single DNS label\n // (https://github.com/ipfs/in-web-browsers/issues/169)\n // en-wikipedia--on--ipfs-org → en.wikipedia-on-ipfs.org\n ipnsId = ipnsId.replace(/--/g, '@').replace(/-/g, '.').replace(/@/g, '-')\n }\n // URL implementation in web browsers forces lowercase of the hostname\n const { hostname } = new URL(`http://${ipnsId}`) // eslint-disable-line no-new\n // Check if potential FQDN has an explicit TLD\n return fqdnWithTld.test(hostname)\n } catch (e) {\n return false\n }\n }\n\n return true\n}\n\n/**\n * @param {any} input\n */\nfunction isString (input) {\n return typeof input === 'string'\n}\n\n/**\n * @param {Uint8Array | string} input\n */\nfunction convertToString (input) {\n if (input instanceof Uint8Array) {\n return uint8ArrayToString(input, 'base58btc')\n }\n\n if (isString(input)) {\n return input\n }\n\n return false\n}\n\n/**\n * @param {string | Uint8Array} url\n */\nconst ipfsSubdomain = (url) => isIpfs(url, subdomainGatewayPattern, subdomainProtocolMatch, subdomainIdMatch)\n/**\n * @param {string | Uint8Array} url\n */\nconst ipnsSubdomain = (url) => isIpns(url, subdomainGatewayPattern, subdomainProtocolMatch, subdomainIdMatch)\n/**\n * @param {string | Uint8Array} url\n */\nconst subdomain = (url) => ipfsSubdomain(url) || ipnsSubdomain(url)\n\n/**\n * @param {string | Uint8Array} url\n */\nconst ipfsUrl = (url) => isIpfs(url, pathGatewayPattern) || ipfsSubdomain(url)\n/**\n * @param {string | Uint8Array} url\n */\nconst ipnsUrl = (url) => isIpns(url, pathGatewayPattern) || ipnsSubdomain(url)\n/**\n * @param {string | Uint8Array} url\n */\nconst url = (url) => ipfsUrl(url) || ipnsUrl(url) || subdomain(url)\n\n/**\n * @param {string | Uint8Array} path\n */\nconst path = (path) => isIpfs(path, pathPattern) || isIpns(path, pathPattern)\n\nmodule.exports = {\n multihash: isMultihash,\n multiaddr: isMultiaddr,\n peerMultiaddr: isPeerMultiaddr,\n cid: isCID,\n /**\n * @param {CID | string | Uint8Array} cid\n */\n base32cid: (cid) => (isBase32EncodedMultibase(cid) && isCID(cid)),\n ipfsSubdomain,\n ipnsSubdomain,\n subdomain,\n subdomainGatewayPattern,\n ipfsUrl,\n ipnsUrl,\n url,\n pathGatewayPattern: pathGatewayPattern,\n /**\n * @param {string | Uint8Array} path\n */\n ipfsPath: (path) => isIpfs(path, pathPattern),\n /**\n * @param {string | Uint8Array} path\n */\n ipnsPath: (path) => isIpns(path, pathPattern),\n path,\n pathPattern,\n /**\n * @param {string | Uint8Array} x\n */\n urlOrPath: (x) => url(x) || path(x),\n /**\n * @param {string | Uint8Array | CID} path\n */\n cidPath: path => isString(path) && !isCID(path) && isIpfs(`/ipfs/${path}`, pathPattern)\n}\n","'use strict'\n\nconst codec = require('./codec')\nconst protocols = require('./protocols-table')\nconst varint = require('varint')\nconst { CID } = require('multiformats/cid')\nconst { base58btc } = require('multiformats/bases/base58')\nconst errCode = require('err-code')\nconst inspect = Symbol.for('nodejs.util.inspect.custom')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\n/**\n * @typedef {(addr: Multiaddr) => Promise} Resolver\n * @typedef {string | Multiaddr | Uint8Array | null} MultiaddrInput\n * @typedef {import('./types').MultiaddrObject} MultiaddrObject\n * @typedef {import('./types').Protocol} Protocol\n */\n\n/** @type {Map} */\nconst resolvers = new Map()\nconst symbol = Symbol.for('@multiformats/js-multiaddr/multiaddr')\n\n/**\n * Creates a [multiaddr](https://github.com/multiformats/multiaddr) from\n * a Uint8Array, String or another Multiaddr instance\n * public key.\n *\n */\nclass Multiaddr {\n /**\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // \n * ```\n *\n * @param {MultiaddrInput} [addr] - If String or Uint8Array, needs to adhere to the address format of a [multiaddr](https://github.com/multiformats/multiaddr#string-format)\n */\n constructor (addr) {\n // default\n if (addr == null) {\n addr = ''\n }\n\n // Define symbol\n Object.defineProperty(this, symbol, { value: true })\n\n if (addr instanceof Uint8Array) {\n /** @type {Uint8Array} - The raw bytes representing this multiaddress */\n this.bytes = codec.fromBytes(addr)\n } else if (typeof addr === 'string') {\n if (addr.length > 0 && addr.charAt(0) !== '/') {\n throw new Error(`multiaddr \"${addr}\" must start with a \"/\"`)\n }\n this.bytes = codec.fromString(addr)\n } else if (Multiaddr.isMultiaddr(addr)) { // Multiaddr\n this.bytes = codec.fromBytes(addr.bytes) // validate + copy buffer\n } else {\n throw new Error('addr must be a string, Buffer, or another Multiaddr')\n }\n }\n\n /**\n * Returns Multiaddr as a String\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').toString()\n * // '/ip4/127.0.0.1/tcp/4001'\n * ```\n */\n toString () {\n return codec.bytesToString(this.bytes)\n }\n\n /**\n * Returns Multiaddr as a JSON encoded object\n *\n * @example\n * ```js\n * JSON.stringify(new Multiaddr('/ip4/127.0.0.1/tcp/4001'))\n * // '/ip4/127.0.0.1/tcp/4001'\n * ```\n */\n toJSON () {\n return this.toString()\n }\n\n /**\n * Returns Multiaddr as a convinient options object to be used with net.createConnection\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').toOptions()\n * // { family: 4, host: '127.0.0.1', transport: 'tcp', port: 4001 }\n * ```\n */\n toOptions () {\n /** @type {MultiaddrObject} */\n const opts = {}\n const parsed = this.toString().split('/')\n opts.family = parsed[1] === 'ip4' ? 4 : 6\n opts.host = parsed[2]\n opts.transport = parsed[3]\n opts.port = parseInt(parsed[4])\n return opts\n }\n\n /**\n * Returns the protocols the Multiaddr is defined with, as an array of objects, in\n * left-to-right order. Each object contains the protocol code, protocol name,\n * and the size of its address space in bits.\n * [See list of protocols](https://github.com/multiformats/multiaddr/blob/master/protocols.csv)\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').protos()\n * // [ { code: 4, size: 32, name: 'ip4' },\n * // { code: 6, size: 16, name: 'tcp' } ]\n * ```\n *\n * @returns {Protocol[]} protocols - All the protocols the address is composed of\n */\n protos () {\n return this.protoCodes().map(code => Object.assign({}, protocols(code)))\n }\n\n /**\n * Returns the codes of the protocols in left-to-right order.\n * [See list of protocols](https://github.com/multiformats/multiaddr/blob/master/protocols.csv)\n *\n * @example\n * ```js\n * Multiaddr('/ip4/127.0.0.1/tcp/4001').protoCodes()\n * // [ 4, 6 ]\n * ```\n *\n * @returns {number[]} protocol codes\n */\n protoCodes () {\n const codes = []\n const buf = this.bytes\n let i = 0\n while (i < buf.length) {\n const code = varint.decode(buf, i)\n const n = varint.decode.bytes\n\n const p = protocols(code)\n const size = codec.sizeForAddr(p, buf.slice(i + n))\n\n i += (size + n)\n codes.push(code)\n }\n\n return codes\n }\n\n /**\n * Returns the names of the protocols in left-to-right order.\n * [See list of protocols](https://github.com/multiformats/multiaddr/blob/master/protocols.csv)\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').protoNames()\n * // [ 'ip4', 'tcp' ]\n * ```\n *\n * @returns {string[]} protocol names\n */\n protoNames () {\n return this.protos().map(proto => proto.name)\n }\n\n /**\n * Returns a tuple of parts\n *\n * @example\n * ```js\n * new Multiaddr(\"/ip4/127.0.0.1/tcp/4001\").tuples()\n * // [ [ 4, ], [ 6, ] ]\n * ```\n */\n tuples () {\n return codec.bytesToTuples(this.bytes)\n }\n\n /**\n * Returns a tuple of string/number parts\n * - tuples[][0] = code of protocol\n * - tuples[][1] = contents of address\n *\n * @example\n * ```js\n * new Multiaddr(\"/ip4/127.0.0.1/tcp/4001\").stringTuples()\n * // [ [ 4, '127.0.0.1' ], [ 6, '4001' ] ]\n * ```\n */\n stringTuples () {\n const t = codec.bytesToTuples(this.bytes)\n return codec.tuplesToStringTuples(t)\n }\n\n /**\n * Encapsulates a Multiaddr in another Multiaddr\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080')\n * // \n *\n * const mh2 = new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // \n *\n * const mh3 = mh1.encapsulate(mh2)\n * // \n *\n * mh3.toString()\n * // '/ip4/8.8.8.8/tcp/1080/ip4/127.0.0.1/tcp/4001'\n * ```\n *\n * @param {MultiaddrInput} addr - Multiaddr to add into this Multiaddr\n */\n encapsulate (addr) {\n addr = new Multiaddr(addr)\n return new Multiaddr(this.toString() + addr.toString())\n }\n\n /**\n * Decapsulates a Multiaddr from another Multiaddr\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080')\n * // \n *\n * const mh2 = new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // \n *\n * const mh3 = mh1.encapsulate(mh2)\n * // \n *\n * mh3.decapsulate(mh2).toString()\n * // '/ip4/8.8.8.8/tcp/1080'\n * ```\n *\n * @param {Multiaddr | string} addr - Multiaddr to remove from this Multiaddr\n * @returns {Multiaddr}\n */\n decapsulate (addr) {\n const addrString = addr.toString()\n const s = this.toString()\n const i = s.lastIndexOf(addrString)\n if (i < 0) {\n throw new Error('Address ' + this + ' does not contain subaddress: ' + addr)\n }\n return new Multiaddr(s.slice(0, i))\n }\n\n /**\n * A more reliable version of `decapsulate` if you are targeting a\n * specific code, such as 421 (the `p2p` protocol code). The last index of the code\n * will be removed from the `Multiaddr`, and a new instance will be returned.\n * If the code is not present, the original `Multiaddr` is returned.\n *\n * @example\n * ```js\n * const addr = new Multiaddr('/ip4/0.0.0.0/tcp/8080/p2p/QmcgpsyWgH8Y8ajJz1Cu72KnS5uo2Aa2LpzU7kinSupNKC')\n * // \n *\n * addr.decapsulateCode(421).toString()\n * // '/ip4/0.0.0.0/tcp/8080'\n *\n * new Multiaddr('/ip4/127.0.0.1/tcp/8080').decapsulateCode(421).toString()\n * // '/ip4/127.0.0.1/tcp/8080'\n * ```\n *\n * @param {number} code - The code of the protocol to decapsulate from this Multiaddr\n * @returns {Multiaddr}\n */\n decapsulateCode (code) {\n const tuples = this.tuples()\n for (let i = tuples.length - 1; i >= 0; i--) {\n if (tuples[i][0] === code) {\n return new Multiaddr(codec.tuplesToBytes(tuples.slice(0, i)))\n }\n }\n return this\n }\n\n /**\n * Extract the peerId if the multiaddr contains one\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080/ipfs/QmValidBase58string')\n * // \n *\n * // should return QmValidBase58string or null if the id is missing or invalid\n * const peerId = mh1.getPeerId()\n * ```\n *\n * @returns {string | null} peerId - The id of the peer or null if invalid or missing from the ma\n */\n getPeerId () {\n try {\n const tuples = this.stringTuples().filter((tuple) => {\n if (tuple[0] === protocols.names.ipfs.code) {\n return true\n }\n return false\n })\n\n // Get the last ipfs tuple ['ipfs', 'peerid string']\n const tuple = tuples.pop()\n if (tuple && tuple[1]) {\n const peerIdStr = tuple[1]\n\n // peer id is base58btc encoded string but not multibase encoded so add the `z`\n // prefix so we can validate that it is correctly encoded\n if (peerIdStr[0] === 'Q' || peerIdStr[0] === '1') {\n return uint8ArrayToString(base58btc.decode(`z${peerIdStr}`), 'base58btc')\n }\n\n // try to parse peer id as CID\n return uint8ArrayToString(CID.parse(peerIdStr).multihash.bytes, 'base58btc')\n }\n\n return null\n } catch (e) {\n return null\n }\n }\n\n /**\n * Extract the path if the multiaddr contains one\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080/unix/tmp/p2p.sock')\n * // \n *\n * // should return utf8 string or null if the id is missing or invalid\n * const path = mh1.getPath()\n * ```js\n *\n * @returns {string | null} path - The path of the multiaddr, or null if no path protocol is present\n */\n getPath () {\n let path = null\n try {\n path = this.stringTuples().filter((tuple) => {\n const proto = protocols(tuple[0])\n if (proto.path) {\n return true\n }\n return false\n })[0][1]\n\n if (!path) {\n path = null\n }\n } catch (e) {\n path = null\n }\n return path\n }\n\n /**\n * Checks if two Multiaddrs are the same\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080')\n * // \n *\n * const mh2 = new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // \n *\n * mh1.equals(mh1)\n * // true\n *\n * mh1.equals(mh2)\n * // false\n * ```\n *\n * @param {Multiaddr} addr\n * @returns {boolean}\n */\n equals (addr) {\n return uint8ArrayEquals(this.bytes, addr.bytes)\n }\n\n /**\n * Resolve multiaddr if containing resolvable hostname.\n *\n * @example\n * ```js\n * Multiaddr.resolvers.set('dnsaddr', resolverFunction)\n * const mh1 = new Multiaddr('/dnsaddr/bootstrap.libp2p.io/p2p/QmbLHAnMoJPWSCR5Zhtx6BHJX9KiKNN6tpvbUcqanj75Nb')\n * const resolvedMultiaddrs = await mh1.resolve()\n * // [\n * // ,\n * // ,\n * // \n * // ]\n * ```\n *\n * @returns {Promise>}\n */\n async resolve () {\n const resolvableProto = this.protos().find((p) => p.resolvable)\n\n // Multiaddr is not resolvable?\n if (!resolvableProto) {\n return [this]\n }\n\n const resolver = resolvers.get(resolvableProto.name)\n if (!resolver) {\n throw errCode(new Error(`no available resolver for ${resolvableProto.name}`), 'ERR_NO_AVAILABLE_RESOLVER')\n }\n\n const addresses = await resolver(this)\n return addresses.map((a) => new Multiaddr(a))\n }\n\n /**\n * Gets a Multiaddrs node-friendly address object. Note that protocol information\n * is left out: in Node (and most network systems) the protocol is unknowable\n * given only the address.\n *\n * Has to be a ThinWaist Address, otherwise throws error\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').nodeAddress()\n * // {family: 4, address: '127.0.0.1', port: 4001}\n * ```\n *\n * @returns {{family: 4 | 6, address: string, port: number}}\n * @throws {Error} Throws error if Multiaddr is not a Thin Waist address\n */\n nodeAddress () {\n const codes = this.protoCodes()\n const names = this.protoNames()\n const parts = this.toString().split('/').slice(1)\n\n if (parts.length < 4) {\n throw new Error('multiaddr must have a valid format: \"/{ip4, ip6, dns4, dns6}/{address}/{tcp, udp}/{port}\".')\n } else if (codes[0] !== 4 && codes[0] !== 41 && codes[0] !== 54 && codes[0] !== 55) {\n throw new Error(`no protocol with name: \"'${names[0]}'\". Must have a valid family name: \"{ip4, ip6, dns4, dns6}\".`)\n } else if (parts[2] !== 'tcp' && parts[2] !== 'udp') {\n throw new Error(`no protocol with name: \"'${names[1]}'\". Must have a valid transport protocol: \"{tcp, udp}\".`)\n }\n\n return {\n family: (codes[0] === 41 || codes[0] === 55) ? 6 : 4,\n address: parts[1],\n port: parseInt(parts[3]) // tcp or udp port\n }\n }\n\n /**\n * Returns if a Multiaddr is a Thin Waist address or not.\n *\n * Thin Waist is if a Multiaddr adheres to the standard combination of:\n *\n * `{IPv4, IPv6}/{TCP, UDP}`\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // \n * const mh2 = new Multiaddr('/ip4/192.168.2.1/tcp/5001')\n * // \n * const mh3 = mh1.encapsulate(mh2)\n * // \n * const mh4 = new Multiaddr('/ip4/127.0.0.1/tcp/2000/wss/p2p-webrtc-star/p2p/QmcgpsyWgH8Y8ajJz1Cu72KnS5uo2Aa2LpzU7kinSooo2a')\n * // \n * mh1.isThinWaistAddress()\n * // true\n * mh2.isThinWaistAddress()\n * // true\n * mh3.isThinWaistAddress()\n * // false\n * mh4.isThinWaistAddress()\n * // false\n * ```\n *\n * @param {Multiaddr} [addr] - Defaults to using `this` instance\n */\n isThinWaistAddress (addr) {\n const protos = (addr || this).protos()\n\n if (protos.length !== 2) {\n return false\n }\n\n if (protos[0].code !== 4 && protos[0].code !== 41) {\n return false\n }\n if (protos[1].code !== 6 && protos[1].code !== 273) {\n return false\n }\n return true\n }\n\n /**\n * Creates a Multiaddr from a node-friendly address object\n *\n * @example\n * ```js\n * Multiaddr.fromNodeAddress({address: '127.0.0.1', port: '4001'}, 'tcp')\n * // \n * ```\n *\n * @param {{family: 4 | 6, address: string, port: number}} addr\n * @param {string} transport\n */\n static fromNodeAddress (addr, transport) {\n if (!addr) { throw new Error('requires node address object') }\n if (!transport) { throw new Error('requires transport protocol') }\n let ip\n switch (addr.family) {\n case 4:\n ip = 'ip4'\n break\n case 6:\n ip = 'ip6'\n break\n default:\n throw Error(`Invalid addr family. Got '${addr.family}' instead of 4 or 6`)\n }\n return new Multiaddr('/' + [ip, addr.address, transport, addr.port].join('/'))\n }\n\n /**\n * Returns if something is a Multiaddr that is a name\n *\n * @param {Multiaddr} addr\n * @returns {boolean} isName\n */\n static isName (addr) {\n if (!Multiaddr.isMultiaddr(addr)) {\n return false\n }\n\n // if a part of the multiaddr is resolvable, then return true\n return addr.protos().some((proto) => proto.resolvable)\n }\n\n /**\n * Check if object is a CID instance\n *\n * @param {any} value\n * @returns {value is Multiaddr}\n */\n static isMultiaddr (value) {\n return value instanceof Multiaddr || Boolean(value && value[symbol])\n }\n\n /**\n * Returns Multiaddr as a human-readable string.\n * For post Node.js v10.0.0.\n * https://nodejs.org/api/deprecations.html#deprecations_dep0079_custom_inspection_function_on_objects_via_inspect\n *\n * @example\n * ```js\n * console.log(new Multiaddr('/ip4/127.0.0.1/tcp/4001'))\n * // ''\n * ```\n *\n * @returns {string}\n */\n [inspect] () {\n return ''\n }\n\n /**\n * Returns Multiaddr as a human-readable string.\n * Fallback for pre Node.js v10.0.0.\n * https://nodejs.org/api/deprecations.html#deprecations_dep0079_custom_inspection_function_on_objects_via_inspect\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').inspect()\n * // ''\n * ```\n *\n * @returns {string}\n */\n inspect () {\n return ''\n }\n}\n\n/**\n * Object containing table, names and codes of all supported protocols.\n * To get the protocol values from a Multiaddr, you can use\n * [`.protos()`](#multiaddrprotos),\n * [`.protoCodes()`](#multiaddrprotocodes) or\n * [`.protoNames()`](#multiaddrprotonames)\n *\n * @returns {{table: Array, names: Object, codes: Object}}\n */\nMultiaddr.protocols = protocols\n\nMultiaddr.resolvers = resolvers\n\n/**\n * Static factory\n *\n * @param {MultiaddrInput} addr\n */\nfunction multiaddr (addr) {\n return new Multiaddr(addr)\n}\n\nmodule.exports = { Multiaddr, multiaddr, protocols, resolvers }\n","'use strict'\n\nconst convert = require('./convert')\nconst protocols = require('./protocols-table')\nconst varint = require('varint')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\n// export codec\nmodule.exports = {\n stringToStringTuples,\n stringTuplesToString,\n\n tuplesToStringTuples,\n stringTuplesToTuples,\n\n bytesToTuples,\n tuplesToBytes,\n\n bytesToString,\n stringToBytes,\n\n fromString,\n fromBytes,\n validateBytes,\n isValidBytes,\n cleanPath,\n\n ParseError,\n protoFromTuple,\n\n sizeForAddr\n}\n\n// string -> [[str name, str addr]... ]\n/**\n * @param {string} str\n */\nfunction stringToStringTuples (str) {\n const tuples = []\n const parts = str.split('/').slice(1) // skip first empty elem\n if (parts.length === 1 && parts[0] === '') {\n return []\n }\n\n for (let p = 0; p < parts.length; p++) {\n const part = parts[p]\n const proto = protocols(part)\n\n if (proto.size === 0) {\n tuples.push([part])\n continue\n }\n\n p++ // advance addr part\n if (p >= parts.length) {\n throw ParseError('invalid address: ' + str)\n }\n\n // if it's a path proto, take the rest\n if (proto.path) {\n tuples.push([\n part,\n // TODO: should we need to check each path part to see if it's a proto?\n // This would allow for other protocols to be added after a unix path,\n // however it would have issues if the path had a protocol name in the path\n cleanPath(parts.slice(p).join('/'))\n ])\n break\n }\n\n tuples.push([part, parts[p]])\n }\n\n return tuples\n}\n\n// [[str name, str addr]... ] -> string\n/**\n * @param {[number, string?][]} tuples\n */\nfunction stringTuplesToString (tuples) {\n /** @type {Array} */\n const parts = []\n tuples.map((tup) => {\n const proto = protoFromTuple(tup)\n parts.push(proto.name)\n if (tup.length > 1) {\n parts.push(tup[1])\n }\n return null\n })\n\n return cleanPath(parts.join('/'))\n}\n\n// [[str name, str addr]... ] -> [[int code, Uint8Array]... ]\n/**\n * @param {Array} tuples\n * @returns {[number , Uint8Array?][]}\n */\nfunction stringTuplesToTuples (tuples) {\n return tuples.map((tup) => {\n if (!Array.isArray(tup)) {\n tup = [tup]\n }\n const proto = protoFromTuple(tup)\n if (tup.length > 1) {\n return [proto.code, convert.toBytes(proto.code, tup[1])]\n }\n return [proto.code]\n })\n}\n\n/**\n * Convert tuples to string tuples\n *\n * [[int code, Uint8Array]... ] -> [[int code, str addr]... ]\n *\n * @param {Array<[number, Uint8Array?]>} tuples\n * @returns {Array<[number, string?]>}\n */\n\nfunction tuplesToStringTuples (tuples) {\n return tuples.map(tup => {\n const proto = protoFromTuple(tup)\n if (tup[1]) {\n return [proto.code, convert.toString(proto.code, tup[1])]\n }\n return [proto.code]\n })\n}\n\n// [[int code, Uint8Array ]... ] -> Uint8Array\n/**\n * @param {[number, Uint8Array?][]} tuples\n */\nfunction tuplesToBytes (tuples) {\n return fromBytes(uint8ArrayConcat(tuples.map((/** @type {any[]} */ tup) => {\n const proto = protoFromTuple(tup)\n let buf = Uint8Array.from(varint.encode(proto.code))\n\n if (tup.length > 1) {\n buf = uint8ArrayConcat([buf, tup[1]]) // add address buffer\n }\n\n return buf\n })))\n}\n\n/**\n * @param {import(\"./types\").Protocol} p\n * @param {Uint8Array | number[]} addr\n */\nfunction sizeForAddr (p, addr) {\n if (p.size > 0) {\n return p.size / 8\n } else if (p.size === 0) {\n return 0\n } else {\n const size = varint.decode(addr)\n return size + varint.decode.bytes\n }\n}\n\n/**\n *\n * @param {Uint8Array} buf\n * @returns {Array<[number, Uint8Array?]>}\n */\nfunction bytesToTuples (buf) {\n /** @type {Array<[number, Uint8Array?]>} */\n const tuples = []\n let i = 0\n while (i < buf.length) {\n const code = varint.decode(buf, i)\n const n = varint.decode.bytes\n\n const p = protocols(code)\n\n const size = sizeForAddr(p, buf.slice(i + n))\n\n if (size === 0) {\n tuples.push([code])\n i += n\n continue\n }\n\n const addr = buf.slice(i + n, i + n + size)\n\n i += (size + n)\n\n if (i > buf.length) { // did not end _exactly_ at buffer.length\n throw ParseError('Invalid address Uint8Array: ' + uint8ArrayToString(buf, 'base16'))\n }\n\n // ok, tuple seems good.\n tuples.push([code, addr])\n }\n\n return tuples\n}\n\n// Uint8Array -> String\n/**\n * @param {Uint8Array} buf\n */\nfunction bytesToString (buf) {\n const a = bytesToTuples(buf)\n const b = tuplesToStringTuples(a)\n return stringTuplesToString(b)\n}\n\n// String -> Uint8Array\n/**\n * @param {string} str\n */\nfunction stringToBytes (str) {\n str = cleanPath(str)\n const a = stringToStringTuples(str)\n const b = stringTuplesToTuples(a)\n\n return tuplesToBytes(b)\n}\n\n// String -> Uint8Array\n/**\n * @param {string} str\n */\nfunction fromString (str) {\n return stringToBytes(str)\n}\n\n// Uint8Array -> Uint8Array\n/**\n * @param {Uint8Array} buf\n */\nfunction fromBytes (buf) {\n const err = validateBytes(buf)\n if (err) throw err\n return Uint8Array.from(buf) // copy\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction validateBytes (buf) {\n try {\n bytesToTuples(buf) // try to parse. will throw if breaks\n } catch (err) {\n return err\n }\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction isValidBytes (buf) {\n return validateBytes(buf) === undefined\n}\n\n/**\n * @param {string} str\n */\nfunction cleanPath (str) {\n return '/' + str.trim().split('/').filter((/** @type {any} */ a) => a).join('/')\n}\n\n/**\n * @param {string} str\n */\nfunction ParseError (str) {\n return new Error('Error parsing address: ' + str)\n}\n\n/**\n * @param {any[]} tup\n */\nfunction protoFromTuple (tup) {\n const proto = protocols(tup[0])\n return proto\n}\n","'use strict'\n\nconst ip = require('./ip')\nconst protocols = require('./protocols-table')\nconst { CID } = require('multiformats/cid')\nconst { base32 } = require('multiformats/bases/base32')\nconst { base58btc } = require('multiformats/bases/base58')\nconst Digest = require('multiformats/hashes/digest')\nconst varint = require('varint')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\n\nmodule.exports = Convert\n\n// converts (serializes) addresses\n/**\n * @param {string} proto\n * @param {string | Uint8Array} a\n */\nfunction Convert (proto, a) {\n if (a instanceof Uint8Array) {\n return Convert.toString(proto, a)\n } else {\n return Convert.toBytes(proto, a)\n }\n}\n\n/**\n * Convert [code,Uint8Array] to string\n *\n * @param {number|string} proto\n * @param {Uint8Array} buf\n * @returns {string}\n */\nConvert.toString = function convertToString (proto, buf) {\n const protocol = protocols(proto)\n switch (protocol.code) {\n case 4: // ipv4\n case 41: // ipv6\n return bytes2ip(buf)\n\n case 6: // tcp\n case 273: // udp\n case 33: // dccp\n case 132: // sctp\n return bytes2port(buf).toString()\n\n case 53: // dns\n case 54: // dns4\n case 55: // dns6\n case 56: // dnsaddr\n case 400: // unix\n case 777: // memory\n return bytes2str(buf)\n\n case 421: // ipfs\n return bytes2mh(buf)\n case 444: // onion\n return bytes2onion(buf)\n case 445: // onion3\n return bytes2onion(buf)\n default:\n return uint8ArrayToString(buf, 'base16') // no clue. convert to hex\n }\n}\n\nConvert.toBytes = function convertToBytes (/** @type {string | number } */ proto, /** @type {string} */ str) {\n const protocol = protocols(proto)\n switch (protocol.code) {\n case 4: // ipv4\n return ip2bytes(str)\n case 41: // ipv6\n return ip2bytes(str)\n\n case 6: // tcp\n case 273: // udp\n case 33: // dccp\n case 132: // sctp\n return port2bytes(parseInt(str, 10))\n\n case 53: // dns\n case 54: // dns4\n case 55: // dns6\n case 56: // dnsaddr\n case 400: // unix\n case 777: // memory\n return str2bytes(str)\n\n case 421: // ipfs\n return mh2bytes(str)\n case 444: // onion\n return onion2bytes(str)\n case 445: // onion3\n return onion32bytes(str)\n default:\n return uint8ArrayFromString(str, 'base16') // no clue. convert from hex\n }\n}\n\n/**\n * @param {string} ipString\n */\nfunction ip2bytes (ipString) {\n if (!ip.isIP(ipString)) {\n throw new Error('invalid ip address')\n }\n return ip.toBytes(ipString)\n}\n\n/**\n * @param {Uint8Array} ipBuff\n */\nfunction bytes2ip (ipBuff) {\n const ipString = ip.toString(ipBuff)\n if (!ipString || !ip.isIP(ipString)) {\n throw new Error('invalid ip address')\n }\n return ipString\n}\n\n/**\n * @param {number} port\n */\nfunction port2bytes (port) {\n const buf = new ArrayBuffer(2)\n const view = new DataView(buf)\n view.setUint16(0, port)\n\n return new Uint8Array(buf)\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction bytes2port (buf) {\n const view = new DataView(buf.buffer)\n return view.getUint16(buf.byteOffset)\n}\n\n/**\n * @param {string} str\n */\nfunction str2bytes (str) {\n const buf = uint8ArrayFromString(str)\n const size = Uint8Array.from(varint.encode(buf.length))\n return uint8ArrayConcat([size, buf], size.length + buf.length)\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction bytes2str (buf) {\n const size = varint.decode(buf)\n buf = buf.slice(varint.decode.bytes)\n\n if (buf.length !== size) {\n throw new Error('inconsistent lengths')\n }\n\n return uint8ArrayToString(buf)\n}\n\n/**\n * @param {string} hash - base58btc string\n */\nfunction mh2bytes (hash) {\n let mh\n\n if (hash[0] === 'Q' || hash[0] === '1') {\n mh = Digest.decode(base58btc.decode(`z${hash}`)).bytes\n } else {\n mh = CID.parse(hash).multihash.bytes\n }\n\n // the address is a varint prefixed multihash string representation\n const size = Uint8Array.from(varint.encode(mh.length))\n return uint8ArrayConcat([size, mh], size.length + mh.length)\n}\n\n/**\n * Converts bytes to bas58btc string\n *\n * @param {Uint8Array} buf\n * @returns {string} base58btc string\n */\nfunction bytes2mh (buf) {\n const size = varint.decode(buf)\n const address = buf.slice(varint.decode.bytes)\n\n if (address.length !== size) {\n throw new Error('inconsistent lengths')\n }\n\n return uint8ArrayToString(address, 'base58btc')\n}\n\n/**\n * @param {string} str\n */\nfunction onion2bytes (str) {\n const addr = str.split(':')\n if (addr.length !== 2) {\n throw new Error('failed to parse onion addr: ' + addr + ' does not contain a port number')\n }\n if (addr[0].length !== 16) {\n throw new Error('failed to parse onion addr: ' + addr[0] + ' not a Tor onion address.')\n }\n\n // onion addresses do not include the multibase prefix, add it before decoding\n const buf = base32.decode('b' + addr[0])\n\n // onion port number\n const port = parseInt(addr[1], 10)\n if (port < 1 || port > 65536) {\n throw new Error('Port number is not in range(1, 65536)')\n }\n const portBuf = port2bytes(port)\n return uint8ArrayConcat([buf, portBuf], buf.length + portBuf.length)\n}\n\n/**\n * @param {string} str\n */\nfunction onion32bytes (str) {\n const addr = str.split(':')\n if (addr.length !== 2) {\n throw new Error('failed to parse onion addr: ' + addr + ' does not contain a port number')\n }\n if (addr[0].length !== 56) {\n throw new Error('failed to parse onion addr: ' + addr[0] + ' not a Tor onion3 address.')\n }\n // onion addresses do not include the multibase prefix, add it before decoding\n const buf = base32.decode('b' + addr[0])\n\n // onion port number\n const port = parseInt(addr[1], 10)\n if (port < 1 || port > 65536) {\n throw new Error('Port number is not in range(1, 65536)')\n }\n const portBuf = port2bytes(port)\n return uint8ArrayConcat([buf, portBuf], buf.length + portBuf.length)\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction bytes2onion (buf) {\n const addrBytes = buf.slice(0, buf.length - 2)\n const portBytes = buf.slice(buf.length - 2)\n const addr = uint8ArrayToString(addrBytes, 'base32')\n const port = bytes2port(portBytes)\n return addr + ':' + port\n}\n","'use strict'\n\nconst isIp = require('is-ip')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst isIP = isIp\nconst isV4 = isIp.v4\nconst isV6 = isIp.v6\n\n// Copied from https://github.com/indutny/node-ip/blob/master/lib/ip.js#L7\n// @ts-ignore - this is copied from the link above better to keep it the same\nconst toBytes = function (ip, buff, offset) {\n offset = ~~offset\n\n let result\n\n if (isV4(ip)) {\n result = buff || new Uint8Array(offset + 4)\n // @ts-ignore\n // eslint-disable-next-line array-callback-return\n ip.split(/\\./g).map(function (byte) {\n result[offset++] = parseInt(byte, 10) & 0xff\n })\n } else if (isV6(ip)) {\n const sections = ip.split(':', 8)\n\n let i\n for (i = 0; i < sections.length; i++) {\n const isv4 = isV4(sections[i])\n let v4Buffer\n\n if (isv4) {\n v4Buffer = toBytes(sections[i])\n sections[i] = uint8ArrayToString(v4Buffer.slice(0, 2), 'base16')\n }\n\n if (v4Buffer && ++i < 8) {\n sections.splice(i, 0, uint8ArrayToString(v4Buffer.slice(2, 4), 'base16'))\n }\n }\n\n if (sections[0] === '') {\n while (sections.length < 8) sections.unshift('0')\n } else if (sections[sections.length - 1] === '') {\n while (sections.length < 8) sections.push('0')\n } else if (sections.length < 8) {\n for (i = 0; i < sections.length && sections[i] !== ''; i++);\n const argv = [i, '1']\n for (i = 9 - sections.length; i > 0; i--) {\n argv.push('0')\n }\n sections.splice.apply(sections, argv)\n }\n\n result = buff || new Uint8Array(offset + 16)\n for (i = 0; i < sections.length; i++) {\n const word = parseInt(sections[i], 16)\n result[offset++] = (word >> 8) & 0xff\n result[offset++] = word & 0xff\n }\n }\n\n if (!result) {\n throw Error('Invalid ip address: ' + ip)\n }\n\n return result\n}\n\n// Copied from https://github.com/indutny/node-ip/blob/master/lib/ip.js#L63\n// @ts-ignore - this is copied from the link above better to keep it the same\nconst toString = function (buff, offset, length) {\n offset = ~~offset\n length = length || (buff.length - offset)\n\n const result = []\n let string\n const view = new DataView(buff.buffer)\n if (length === 4) {\n // IPv4\n for (let i = 0; i < length; i++) {\n result.push(buff[offset + i])\n }\n string = result.join('.')\n } else if (length === 16) {\n // IPv6\n for (let i = 0; i < length; i += 2) {\n result.push(view.getUint16(offset + i).toString(16))\n }\n string = result.join(':')\n string = string.replace(/(^|:)0(:0)*:0(:|$)/, '$1::$3')\n string = string.replace(/:{3,4}/, '::')\n }\n\n return string\n}\n\nmodule.exports = {\n isIP,\n isV4,\n isV6,\n toBytes,\n toString\n}\n","'use strict';\nconst ipRegex = require('ip-regex');\n\nconst isIp = string => ipRegex({exact: true}).test(string);\nisIp.v4 = string => ipRegex.v4({exact: true}).test(string);\nisIp.v6 = string => ipRegex.v6({exact: true}).test(string);\nisIp.version = string => isIp(string) ? (isIp.v4(string) ? 4 : 6) : undefined;\n\nmodule.exports = isIp;\n","'use strict';\n\nconst word = '[a-fA-F\\\\d:]';\nconst b = options => options && options.includeBoundaries ?\n\t`(?:(?<=\\\\s|^)(?=${word})|(?<=${word})(?=\\\\s|$))` :\n\t'';\n\nconst v4 = '(?:25[0-5]|2[0-4]\\\\d|1\\\\d\\\\d|[1-9]\\\\d|\\\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\\\d|1\\\\d\\\\d|[1-9]\\\\d|\\\\d)){3}';\n\nconst v6seg = '[a-fA-F\\\\d]{1,4}';\nconst v6 = `\n(?:\n(?:${v6seg}:){7}(?:${v6seg}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8\n(?:${v6seg}:){6}(?:${v4}|:${v6seg}|:)| // 1:2:3:4:5:6:: 1:2:3:4:5:6::8 1:2:3:4:5:6::8 1:2:3:4:5:6::1.2.3.4\n(?:${v6seg}:){5}(?::${v4}|(?::${v6seg}){1,2}|:)| // 1:2:3:4:5:: 1:2:3:4:5::7:8 1:2:3:4:5::8 1:2:3:4:5::7:1.2.3.4\n(?:${v6seg}:){4}(?:(?::${v6seg}){0,1}:${v4}|(?::${v6seg}){1,3}|:)| // 1:2:3:4:: 1:2:3:4::6:7:8 1:2:3:4::8 1:2:3:4::6:7:1.2.3.4\n(?:${v6seg}:){3}(?:(?::${v6seg}){0,2}:${v4}|(?::${v6seg}){1,4}|:)| // 1:2:3:: 1:2:3::5:6:7:8 1:2:3::8 1:2:3::5:6:7:1.2.3.4\n(?:${v6seg}:){2}(?:(?::${v6seg}){0,3}:${v4}|(?::${v6seg}){1,5}|:)| // 1:2:: 1:2::4:5:6:7:8 1:2::8 1:2::4:5:6:7:1.2.3.4\n(?:${v6seg}:){1}(?:(?::${v6seg}){0,4}:${v4}|(?::${v6seg}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4\n(?::(?:(?::${v6seg}){0,5}:${v4}|(?::${v6seg}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4\n)(?:%[0-9a-zA-Z]{1,})? // %eth0 %1\n`.replace(/\\s*\\/\\/.*$/gm, '').replace(/\\n/g, '').trim();\n\n// Pre-compile only the exact regexes because adding a global flag make regexes stateful\nconst v46Exact = new RegExp(`(?:^${v4}$)|(?:^${v6}$)`);\nconst v4exact = new RegExp(`^${v4}$`);\nconst v6exact = new RegExp(`^${v6}$`);\n\nconst ip = options => options && options.exact ?\n\tv46Exact :\n\tnew RegExp(`(?:${b(options)}${v4}${b(options)})|(?:${b(options)}${v6}${b(options)})`, 'g');\n\nip.v4 = options => options && options.exact ? v4exact : new RegExp(`${b(options)}${v4}${b(options)}`, 'g');\nip.v6 = options => options && options.exact ? v6exact : new RegExp(`${b(options)}${v6}${b(options)}`, 'g');\n\nmodule.exports = ip;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bases = require('./util/bases.js');\n\nfunction toString(array, encoding = 'utf8') {\n const base = bases[encoding];\n if (!base) {\n throw new Error(`Unsupported encoding \"${ encoding }\"`);\n }\n return base.encoder.encode(array).substring(1);\n}\n\nexports.toString = toString;\n","'use strict'\n/** @typedef {import(\"./types\").Protocol} Protocol */\n\n/**\n * Protocols\n *\n * @param {number | string} proto\n * @returns {Protocol}\n */\nfunction Protocols (proto) {\n if (typeof (proto) === 'number') {\n if (Protocols.codes[proto]) {\n return Protocols.codes[proto]\n }\n\n throw new Error('no protocol with code: ' + proto)\n } else if (typeof (proto) === 'string') {\n if (Protocols.names[proto]) {\n return Protocols.names[proto]\n }\n\n throw new Error('no protocol with name: ' + proto)\n }\n\n throw new Error('invalid protocol id type: ' + proto)\n}\n\nconst V = -1\nProtocols.lengthPrefixedVarSize = V\nProtocols.V = V\n\n/** @type {Array<[number, number, string, (string|boolean)?, string?]>} */\nProtocols.table = [\n [4, 32, 'ip4'],\n [6, 16, 'tcp'],\n [33, 16, 'dccp'],\n [41, 128, 'ip6'],\n [42, V, 'ip6zone'],\n [53, V, 'dns', 'resolvable'],\n [54, V, 'dns4', 'resolvable'],\n [55, V, 'dns6', 'resolvable'],\n [56, V, 'dnsaddr', 'resolvable'],\n [132, 16, 'sctp'],\n [273, 16, 'udp'],\n [275, 0, 'p2p-webrtc-star'],\n [276, 0, 'p2p-webrtc-direct'],\n [277, 0, 'p2p-stardust'],\n [290, 0, 'p2p-circuit'],\n [301, 0, 'udt'],\n [302, 0, 'utp'],\n [400, V, 'unix', false, 'path'],\n // `ipfs` is added before `p2p` for legacy support.\n // All text representations will default to `p2p`, but `ipfs` will\n // still be supported\n [421, V, 'ipfs'],\n // `p2p` is the preferred name for 421, and is now the default\n [421, V, 'p2p'],\n [443, 0, 'https'],\n [444, 96, 'onion'],\n [445, 296, 'onion3'],\n [446, V, 'garlic64'],\n [460, 0, 'quic'],\n [477, 0, 'ws'],\n [478, 0, 'wss'],\n [479, 0, 'p2p-websocket-star'],\n [480, 0, 'http'],\n [777, V, 'memory']\n]\n/** @type {Record} */\nProtocols.names = {}\n/** @type {Record} */\nProtocols.codes = {}\n\n// populate tables\nProtocols.table.map(row => {\n const proto = p.apply(null, row)\n Protocols.codes[proto.code] = proto\n Protocols.names[proto.name] = proto\n return null\n})\n\nProtocols.object = p\n\n/**\n *\n * Create a protocol\n *\n * @param {number} code\n * @param {number} size\n * @param {string} name\n * @param {any} [resolvable]\n * @param {any} [path]\n * @returns {Protocol}\n */\nfunction p (code, size, name, resolvable, path) {\n return {\n code,\n size,\n name,\n resolvable: Boolean(resolvable),\n path: Boolean(path)\n }\n}\n\nmodule.exports = Protocols\n","module.exports = {\n encode: require('./encode.js')\n , decode: require('./decode.js')\n , encodingLength: require('./length.js')\n}\n","module.exports = encode\n\nvar MSB = 0x80\n , REST = 0x7F\n , MSBALL = ~REST\n , INT = Math.pow(2, 31)\n\nfunction encode(num, out, offset) {\n if (Number.MAX_SAFE_INTEGER && num > Number.MAX_SAFE_INTEGER) {\n encode.bytes = 0\n throw new RangeError('Could not encode varint')\n }\n out = out || []\n offset = offset || 0\n var oldOffset = offset\n\n while(num >= INT) {\n out[offset++] = (num & 0xFF) | MSB\n num /= 128\n }\n while(num & MSBALL) {\n out[offset++] = (num & 0xFF) | MSB\n num >>>= 7\n }\n out[offset] = num | 0\n \n encode.bytes = offset - oldOffset + 1\n \n return out\n}\n","module.exports = read\n\nvar MSB = 0x80\n , REST = 0x7F\n\nfunction read(buf, offset) {\n var res = 0\n , offset = offset || 0\n , shift = 0\n , counter = offset\n , b\n , l = buf.length\n\n do {\n if (counter >= l || shift > 49) {\n read.bytes = 0\n throw new RangeError('Could not decode varint')\n }\n b = buf[counter++]\n res += shift < 28\n ? (b & REST) << shift\n : (b & REST) * Math.pow(2, shift)\n shift += 7\n } while (b >= MSB)\n\n read.bytes = counter - offset\n\n return res\n}\n","\nvar N1 = Math.pow(2, 7)\nvar N2 = Math.pow(2, 14)\nvar N3 = Math.pow(2, 21)\nvar N4 = Math.pow(2, 28)\nvar N5 = Math.pow(2, 35)\nvar N6 = Math.pow(2, 42)\nvar N7 = Math.pow(2, 49)\nvar N8 = Math.pow(2, 56)\nvar N9 = Math.pow(2, 63)\n\nmodule.exports = function (value) {\n return (\n value < N1 ? 1\n : value < N2 ? 2\n : value < N3 ? 3\n : value < N4 ? 4\n : value < N5 ? 5\n : value < N6 ? 6\n : value < N7 ? 7\n : value < N8 ? 8\n : value < N9 ? 9\n : 10\n )\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction concat(arrays, length) {\n if (!length) {\n length = arrays.reduce((acc, curr) => acc + curr.length, 0);\n }\n const output = new Uint8Array(length);\n let offset = 0;\n for (const arr of arrays) {\n output.set(arr, offset);\n offset += arr.length;\n }\n return output;\n}\n\nexports.concat = concat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction equals(a, b) {\n if (a === b) {\n return true;\n }\n if (a.byteLength !== b.byteLength) {\n return false;\n }\n for (let i = 0; i < a.byteLength; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n return true;\n}\n\nexports.equals = equals;\n","'use strict'\n\nconst { Multiaddr } = require('multiaddr')\n\n/**\n * @typedef {import('./types').MatchesFunction} MatchesFunction\n * @typedef {import('./types').PartialMatchesFunction} PartialMatchesFunction\n * @typedef {import('./types').Mafmt} Mafmt\n */\n\n/*\n * Valid combinations\n */\nconst DNS4 = base('dns4')\nconst DNS6 = base('dns6')\nconst DNSADDR = base('dnsaddr')\nconst DNS = or(\n base('dns'),\n DNSADDR,\n DNS4,\n DNS6\n)\n\nconst IP = or(base('ip4'), base('ip6'))\nconst TCP = or(\n and(IP, base('tcp')),\n and(DNS, base('tcp'))\n)\nconst UDP = and(IP, base('udp'))\nconst UTP = and(UDP, base('utp'))\n\nconst QUIC = and(UDP, base('quic'))\n\nconst WebSockets = or(\n and(TCP, base('ws')),\n and(DNS, base('ws'))\n)\n\nconst WebSocketsSecure = or(\n and(TCP, base('wss')),\n and(DNS, base('wss'))\n)\n\nconst HTTP = or(\n and(TCP, base('http')),\n and(IP, base('http')),\n and(DNS, base('http'))\n)\n\nconst HTTPS = or(\n and(TCP, base('https')),\n and(IP, base('https')),\n and(DNS, base('https'))\n)\n\nconst WebRTCStar = or(\n and(WebSockets, base('p2p-webrtc-star'), base('p2p')),\n and(WebSocketsSecure, base('p2p-webrtc-star'), base('p2p')),\n and(WebSockets, base('p2p-webrtc-star')),\n and(WebSocketsSecure, base('p2p-webrtc-star'))\n)\n\nconst WebSocketStar = or(\n and(WebSockets, base('p2p-websocket-star'), base('p2p')),\n and(WebSocketsSecure, base('p2p-websocket-star'), base('p2p')),\n and(WebSockets, base('p2p-websocket-star')),\n and(WebSocketsSecure, base('p2p-websocket-star'))\n)\n\nconst WebRTCDirect = or(\n and(HTTP, base('p2p-webrtc-direct'), base('p2p')),\n and(HTTPS, base('p2p-webrtc-direct'), base('p2p')),\n and(HTTP, base('p2p-webrtc-direct')),\n and(HTTPS, base('p2p-webrtc-direct'))\n)\n\nconst Reliable = or(\n WebSockets,\n WebSocketsSecure,\n HTTP,\n HTTPS,\n WebRTCStar,\n WebRTCDirect,\n TCP,\n UTP,\n QUIC,\n DNS\n)\n\n// Unlike ws-star, stardust can run over any transport thus removing the requirement for websockets (but don't even think about running a stardust server over webrtc-star ;) )\nconst Stardust = or(\n and(Reliable, base('p2p-stardust'), base('p2p')),\n and(Reliable, base('p2p-stardust'))\n)\n\nconst _P2P = or(\n and(Reliable, base('p2p')),\n WebRTCStar,\n WebRTCDirect,\n base('p2p')\n)\n\nconst _Circuit = or(\n and(_P2P, base('p2p-circuit'), _P2P),\n and(_P2P, base('p2p-circuit')),\n and(base('p2p-circuit'), _P2P),\n and(Reliable, base('p2p-circuit')),\n and(base('p2p-circuit'), Reliable),\n base('p2p-circuit')\n)\n\nconst CircuitRecursive = () => or(\n and(_Circuit, CircuitRecursive),\n _Circuit\n)\n\nconst Circuit = CircuitRecursive()\n\nconst P2P = or(\n and(Circuit, _P2P, Circuit),\n and(_P2P, Circuit),\n and(Circuit, _P2P),\n Circuit,\n _P2P\n)\n\nmodule.exports = {\n DNS,\n DNS4,\n DNS6,\n DNSADDR,\n IP,\n TCP,\n UDP,\n QUIC,\n UTP,\n HTTP,\n HTTPS,\n WebSockets,\n WebSocketsSecure,\n WebSocketStar,\n WebRTCStar,\n WebRTCDirect,\n Reliable,\n Stardust,\n Circuit,\n P2P,\n IPFS: P2P\n}\n\n/*\n * Validation funcs\n */\n\n/**\n * @param {PartialMatchesFunction} partialMatch\n */\nfunction makeMatchesFunction (partialMatch) {\n /**\n * @type {MatchesFunction}\n */\n function matches (a) {\n if (!Multiaddr.isMultiaddr(a)) {\n try {\n a = new Multiaddr(a)\n } catch (err) { // catch error\n return false // also if it's invalid it's propably not matching as well so return false\n }\n }\n const out = partialMatch(a.protoNames())\n if (out === null) {\n return false\n }\n\n if (out === true || out === false) {\n return out\n }\n\n return out.length === 0\n }\n\n return matches\n}\n\n/**\n * @param {Array Mafmt)>} args\n * @returns {Mafmt}\n */\nfunction and (...args) {\n /**\n * @type {PartialMatchesFunction}\n */\n function partialMatch (a) {\n if (a.length < args.length) {\n return null\n }\n\n /** @type {boolean | string[] | null} */\n let out = a\n\n args.some((arg) => {\n out = typeof arg === 'function'\n ? arg().partialMatch(a)\n : arg.partialMatch(a)\n\n if (Array.isArray(out)) {\n a = out\n }\n\n if (out === null) {\n return true\n }\n\n return false\n })\n\n return out\n }\n\n return {\n toString: function () { return '{ ' + args.join(' ') + ' }' },\n input: args,\n matches: makeMatchesFunction(partialMatch),\n partialMatch: partialMatch\n }\n}\n\n/**\n * @param {Array Mafmt)>} args\n * @returns {Mafmt}\n */\nfunction or (...args) {\n /**\n * @type {PartialMatchesFunction}\n */\n function partialMatch (a) {\n let out = null\n args.some((arg) => {\n const res = typeof arg === 'function'\n ? arg().partialMatch(a)\n : arg.partialMatch(a)\n if (res) {\n out = res\n return true\n }\n return false\n })\n\n return out\n }\n\n const result = {\n toString: function () { return '{ ' + args.join(' ') + ' }' },\n input: args,\n matches: makeMatchesFunction(partialMatch),\n partialMatch: partialMatch\n }\n\n return result\n}\n\n/**\n * @param {string} n\n * @returns {Mafmt}\n */\nfunction base (n) {\n const name = n\n\n /**\n * @type {MatchesFunction}\n */\n function matches (a) {\n let ma\n\n if (typeof a === 'string' || a instanceof Uint8Array) {\n try {\n ma = new Multiaddr(a)\n } catch (err) { // catch error\n return false // also if it's invalid it's probably not matching as well so return false\n }\n } else {\n ma = a\n }\n\n const pnames = ma.protoNames()\n if (pnames.length === 1 && pnames[0] === name) {\n return true\n }\n return false\n }\n\n /**\n * @type {PartialMatchesFunction}\n */\n function partialMatch (protos) {\n if (protos.length === 0) {\n return null\n }\n\n if (protos[0] === name) {\n return protos.slice(1)\n }\n return null\n }\n\n return {\n toString: function () { return name },\n matches: matches,\n partialMatch: partialMatch\n }\n}\n","'use strict'\n\nconst {\n URLWithLegacySupport,\n format,\n URLSearchParams,\n defaultBase\n} = require('./src/url')\nconst relative = require('./src/relative')\n\nmodule.exports = {\n URL: URLWithLegacySupport,\n URLSearchParams,\n format,\n relative,\n defaultBase\n}\n","'use strict'\n\nconst isReactNative =\n typeof navigator !== 'undefined' &&\n navigator.product === 'ReactNative'\n\nfunction getDefaultBase () {\n if (isReactNative) {\n return 'http://localhost'\n }\n // in some environments i.e. cloudflare workers location is not available\n if (!self.location) {\n return ''\n }\n\n return self.location.protocol + '//' + self.location.host\n}\n\nconst URL = self.URL\nconst defaultBase = getDefaultBase()\n\nclass URLWithLegacySupport {\n constructor (url = '', base = defaultBase) {\n this.super = new URL(url, base)\n this.path = this.pathname + this.search\n this.auth =\n this.username && this.password\n ? this.username + ':' + this.password\n : null\n\n this.query =\n this.search && this.search.startsWith('?')\n ? this.search.slice(1)\n : null\n }\n\n get hash () {\n return this.super.hash\n }\n\n get host () {\n return this.super.host\n }\n\n get hostname () {\n return this.super.hostname\n }\n\n get href () {\n return this.super.href\n }\n\n get origin () {\n return this.super.origin\n }\n\n get password () {\n return this.super.password\n }\n\n get pathname () {\n return this.super.pathname\n }\n\n get port () {\n return this.super.port\n }\n\n get protocol () {\n return this.super.protocol\n }\n\n get search () {\n return this.super.search\n }\n\n get searchParams () {\n return this.super.searchParams\n }\n\n get username () {\n return this.super.username\n }\n\n set hash (hash) {\n this.super.hash = hash\n }\n\n set host (host) {\n this.super.host = host\n }\n\n set hostname (hostname) {\n this.super.hostname = hostname\n }\n\n set href (href) {\n this.super.href = href\n }\n\n set password (password) {\n this.super.password = password\n }\n\n set pathname (pathname) {\n this.super.pathname = pathname\n }\n\n set port (port) {\n this.super.port = port\n }\n\n set protocol (protocol) {\n this.super.protocol = protocol\n }\n\n set search (search) {\n this.super.search = search\n }\n\n set username (username) {\n this.super.username = username\n }\n\n /**\n * @param {any} o\n */\n static createObjectURL (o) {\n return URL.createObjectURL(o)\n }\n\n /**\n * @param {string} o\n */\n static revokeObjectURL (o) {\n URL.revokeObjectURL(o)\n }\n\n toJSON () {\n return this.super.toJSON()\n }\n\n toString () {\n return this.super.toString()\n }\n\n format () {\n return this.toString()\n }\n}\n\n/**\n * @param {string | import('url').UrlObject} obj\n */\nfunction format (obj) {\n if (typeof obj === 'string') {\n const url = new URL(obj)\n\n return url.toString()\n }\n\n if (!(obj instanceof URL)) {\n const userPass =\n // @ts-ignore its not supported in node but we normalise\n obj.username && obj.password\n // @ts-ignore its not supported in node but we normalise\n ? `${obj.username}:${obj.password}@`\n : ''\n const auth = obj.auth ? obj.auth + '@' : ''\n const port = obj.port ? ':' + obj.port : ''\n const protocol = obj.protocol ? obj.protocol + '//' : ''\n const host = obj.host || ''\n const hostname = obj.hostname || ''\n const search = obj.search || (obj.query ? '?' + obj.query : '')\n const hash = obj.hash || ''\n const pathname = obj.pathname || ''\n // @ts-ignore - path is not supported in node but we normalise\n const path = obj.path || pathname + search\n\n return `${protocol}${userPass || auth}${\n host || hostname + port\n }${path}${hash}`\n }\n}\n\nmodule.exports = {\n URLWithLegacySupport,\n URLSearchParams: self.URLSearchParams,\n defaultBase,\n format\n}\n","'use strict'\n\nconst { URLWithLegacySupport, format } = require('./url')\n\n/**\n * @param {string | undefined} url\n * @param {any} [location]\n * @param {any} [protocolMap]\n * @param {any} [defaultProtocol]\n */\nmodule.exports = (url, location = {}, protocolMap = {}, defaultProtocol) => {\n let protocol = location.protocol\n ? location.protocol.replace(':', '')\n : 'http'\n\n // Check protocol map\n protocol = (protocolMap[protocol] || defaultProtocol || protocol) + ':'\n let urlParsed\n\n try {\n urlParsed = new URLWithLegacySupport(url)\n } catch (err) {\n urlParsed = {}\n }\n\n const base = Object.assign({}, location, {\n protocol: protocol || urlParsed.protocol,\n host: location.host || urlParsed.host\n })\n\n return new URLWithLegacySupport(url, format(base)).toString()\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar nanoid = require('nanoid');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\n\nconst pathSepS = '/';\nconst pathSepB = new TextEncoder().encode(pathSepS);\nconst pathSep = pathSepB[0];\nclass Key {\n constructor(s, clean) {\n if (typeof s === 'string') {\n this._buf = fromString.fromString(s);\n } else if (s instanceof Uint8Array) {\n this._buf = s;\n } else {\n throw new Error('Invalid key, should be String of Uint8Array');\n }\n if (clean == null) {\n clean = true;\n }\n if (clean) {\n this.clean();\n }\n if (this._buf.byteLength === 0 || this._buf[0] !== pathSep) {\n throw new Error('Invalid key');\n }\n }\n toString(encoding = 'utf8') {\n return toString.toString(this._buf, encoding);\n }\n uint8Array() {\n return this._buf;\n }\n get [Symbol.toStringTag]() {\n return `Key(${ this.toString() })`;\n }\n static withNamespaces(list) {\n return new Key(list.join(pathSepS));\n }\n static random() {\n return new Key(nanoid.nanoid().replace(/-/g, ''));\n }\n static asKey(other) {\n if (other instanceof Uint8Array || typeof other === 'string') {\n return new Key(other);\n }\n if (other.uint8Array) {\n return new Key(other.uint8Array());\n }\n return null;\n }\n clean() {\n if (!this._buf || this._buf.byteLength === 0) {\n this._buf = pathSepB;\n }\n if (this._buf[0] !== pathSep) {\n const bytes = new Uint8Array(this._buf.byteLength + 1);\n bytes.fill(pathSep, 0, 1);\n bytes.set(this._buf, 1);\n this._buf = bytes;\n }\n while (this._buf.byteLength > 1 && this._buf[this._buf.byteLength - 1] === pathSep) {\n this._buf = this._buf.subarray(0, -1);\n }\n }\n less(key) {\n const list1 = this.list();\n const list2 = key.list();\n for (let i = 0; i < list1.length; i++) {\n if (list2.length < i + 1) {\n return false;\n }\n const c1 = list1[i];\n const c2 = list2[i];\n if (c1 < c2) {\n return true;\n } else if (c1 > c2) {\n return false;\n }\n }\n return list1.length < list2.length;\n }\n reverse() {\n return Key.withNamespaces(this.list().slice().reverse());\n }\n namespaces() {\n return this.list();\n }\n baseNamespace() {\n const ns = this.namespaces();\n return ns[ns.length - 1];\n }\n list() {\n return this.toString().split(pathSepS).slice(1);\n }\n type() {\n return namespaceType(this.baseNamespace());\n }\n name() {\n return namespaceValue(this.baseNamespace());\n }\n instance(s) {\n return new Key(this.toString() + ':' + s);\n }\n path() {\n let p = this.parent().toString();\n if (!p.endsWith(pathSepS)) {\n p += pathSepS;\n }\n p += this.type();\n return new Key(p);\n }\n parent() {\n const list = this.list();\n if (list.length === 1) {\n return new Key(pathSepS);\n }\n return new Key(list.slice(0, -1).join(pathSepS));\n }\n child(key) {\n if (this.toString() === pathSepS) {\n return key;\n } else if (key.toString() === pathSepS) {\n return this;\n }\n return new Key(this.toString() + key.toString(), false);\n }\n isAncestorOf(other) {\n if (other.toString() === this.toString()) {\n return false;\n }\n return other.toString().startsWith(this.toString());\n }\n isDecendantOf(other) {\n if (other.toString() === this.toString()) {\n return false;\n }\n return this.toString().startsWith(other.toString());\n }\n isTopLevel() {\n return this.list().length === 1;\n }\n concat(...keys) {\n return Key.withNamespaces([\n ...this.namespaces(),\n ...flatten(keys.map(key => key.namespaces()))\n ]);\n }\n}\nfunction namespaceType(ns) {\n const parts = ns.split(':');\n if (parts.length < 2) {\n return '';\n }\n return parts.slice(0, -1).join(':');\n}\nfunction namespaceValue(ns) {\n const parts = ns.split(':');\n return parts[parts.length - 1];\n}\nfunction flatten(arr) {\n return [].concat(...arr);\n}\n\nexports.Key = Key;\n","import { urlAlphabet } from './url-alphabet/index.js'\nif (process.env.NODE_ENV !== 'production') {\n if (\n typeof navigator !== 'undefined' &&\n navigator.product === 'ReactNative' &&\n typeof crypto === 'undefined'\n ) {\n throw new Error(\n 'React Native does not have a built-in secure random generator. ' +\n 'If you don’t need unpredictable IDs use `nanoid/non-secure`. ' +\n 'For secure IDs, import `react-native-get-random-values` ' +\n 'before Nano ID.'\n )\n }\n if (typeof msCrypto !== 'undefined' && typeof crypto === 'undefined') {\n throw new Error(\n 'Import file with `if (!window.crypto) window.crypto = window.msCrypto`' +\n ' before importing Nano ID to fix IE 11 support'\n )\n }\n if (typeof crypto === 'undefined') {\n throw new Error(\n 'Your browser does not have secure random generator. ' +\n 'If you don’t need unpredictable IDs, you can use nanoid/non-secure.'\n )\n }\n}\nlet random = bytes => crypto.getRandomValues(new Uint8Array(bytes))\nlet customRandom = (alphabet, size, getRandom) => {\n let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1\n let step = -~((1.6 * mask * size) / alphabet.length)\n return () => {\n let id = ''\n while (true) {\n let bytes = getRandom(step)\n let j = step\n while (j--) {\n id += alphabet[bytes[j] & mask] || ''\n if (id.length === size) return id\n }\n }\n }\n}\nlet customAlphabet = (alphabet, size) => customRandom(alphabet, size, random)\nlet nanoid = (size = 21) => {\n let id = ''\n let bytes = crypto.getRandomValues(new Uint8Array(size))\n while (size--) {\n let byte = bytes[size] & 63\n if (byte < 36) {\n id += byte.toString(36)\n } else if (byte < 62) {\n id += (byte - 26).toString(36).toUpperCase()\n } else if (byte < 63) {\n id += '_'\n } else {\n id += '-'\n }\n }\n return id\n}\nexport { nanoid, customAlphabet, customRandom, urlAlphabet, random }\n","let urlAlphabet =\n 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'\nexport { urlAlphabet }\n","exports.interopDefault = function (a) {\n return a && a.__esModule ? a : {default: a};\n};\n\nexports.defineInteropFlag = function (a) {\n Object.defineProperty(a, '__esModule', {value: true});\n};\n\nexports.exportAll = function (source, dest) {\n Object.keys(source).forEach(function (key) {\n if (key === 'default' || key === '__esModule' || dest.hasOwnProperty(key)) {\n return;\n }\n\n Object.defineProperty(dest, key, {\n enumerable: true,\n get: function () {\n return source[key];\n },\n });\n });\n\n return dest;\n};\n\nexports.export = function (dest, destName, get) {\n Object.defineProperty(dest, destName, {\n enumerable: true,\n get: get,\n });\n};\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar TimeoutController = require('timeout-abort-controller');\nvar anySignal = require('any-signal');\nvar parseDuration = require('parse-duration');\nvar errors = require('./errors.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar TimeoutController__default = /*#__PURE__*/_interopDefaultLegacy(TimeoutController);\nvar parseDuration__default = /*#__PURE__*/_interopDefaultLegacy(parseDuration);\n\nfunction withTimeoutOption(fn, optionsArgIndex) {\n return (...args) => {\n const options = args[optionsArgIndex == null ? args.length - 1 : optionsArgIndex];\n if (!options || !options.timeout)\n return fn(...args);\n const timeout = typeof options.timeout === 'string' ? parseDuration__default['default'](options.timeout) : options.timeout;\n const controller = new TimeoutController__default['default'](timeout);\n options.signal = anySignal.anySignal([\n options.signal,\n controller.signal\n ]);\n const fnRes = fn(...args);\n const timeoutPromise = new Promise((_resolve, reject) => {\n controller.signal.addEventListener('abort', () => {\n reject(new errors.TimeoutError());\n });\n });\n const start = Date.now();\n const maybeThrowTimeoutError = () => {\n if (controller.signal.aborted) {\n throw new errors.TimeoutError();\n }\n const timeTaken = Date.now() - start;\n if (timeTaken > timeout) {\n controller.abort();\n throw new errors.TimeoutError();\n }\n };\n if (fnRes[Symbol.asyncIterator]) {\n return async function* () {\n const it = fnRes[Symbol.asyncIterator]();\n try {\n while (true) {\n const {value, done} = await Promise.race([\n it.next(),\n timeoutPromise\n ]);\n if (done) {\n break;\n }\n maybeThrowTimeoutError();\n yield value;\n }\n } catch (err) {\n maybeThrowTimeoutError();\n throw err;\n } finally {\n controller.clear();\n if (it.return) {\n it.return();\n }\n }\n }();\n }\n return (async () => {\n try {\n const res = await Promise.race([\n fnRes,\n timeoutPromise\n ]);\n maybeThrowTimeoutError();\n return res;\n } catch (err) {\n maybeThrowTimeoutError();\n throw err;\n } finally {\n controller.clear();\n }\n })();\n };\n}\n\nexports.withTimeoutOption = withTimeoutOption;\n","/* globals self, window */\n'use strict'\n\n// Get around https://github.com/mysticatea/abort-controller/pull/22\nconst { AbortController } =\n typeof self !== 'undefined' ? self\n : typeof window !== 'undefined' ? window\n /* otherwise */ : require('abort-controller')\n\nconst retimer = require('retimer')\n\nclass TimeoutController extends AbortController {\n /**\n * @constructor\n * @param {number} ms milliseconds\n */\n constructor (ms) {\n super()\n this._ms = ms\n this._timer = retimer(() => this.abort(), ms)\n // Patch for safari not supported extending built in classes\n Object.setPrototypeOf(this, TimeoutController.prototype)\n }\n\n /**\n * Aborts the controller and clears the timer\n */\n abort () {\n this._timer.clear()\n return super.abort()\n }\n\n /**\n * Clears the timer\n */\n clear () {\n this._timer.clear()\n }\n\n /**\n * Resets the timer\n */\n reset () {\n this._timer.clear()\n this._timer = retimer(() => this.abort(), this._ms)\n }\n}\n\nmodule.exports = TimeoutController\nmodule.exports.TimeoutController = TimeoutController\n","/*globals self, window */\n\"use strict\"\n\n/*eslint-disable @mysticatea/prettier */\nconst { AbortController, AbortSignal } =\n typeof self !== \"undefined\" ? self :\n typeof window !== \"undefined\" ? window :\n /* otherwise */ undefined\n/*eslint-enable @mysticatea/prettier */\n\nmodule.exports = AbortController\nmodule.exports.AbortSignal = AbortSignal\nmodule.exports.default = AbortController\n","'use strict'\n\nvar getTime = require('./time')\n\nfunction Retimer (callback, timeout, args) {\n var that = this\n\n this._started = getTime()\n this._rescheduled = 0\n this._scheduled = timeout\n this._args = args\n\n this._timer = setTimeout(timerWrapper, timeout)\n\n function timerWrapper () {\n if (that._rescheduled > 0) {\n that._scheduled = that._rescheduled - (getTime() - that._started)\n that._timer = setTimeout(timerWrapper, that._scheduled)\n that._rescheduled = 0\n } else {\n callback.apply(null, that._args)\n }\n }\n}\n\nRetimer.prototype.reschedule = function (timeout) {\n var now = getTime()\n if ((now + timeout) - (this._started + this._scheduled) < 0) {\n return false\n } else {\n this._started = now\n this._rescheduled = timeout\n return true\n }\n}\n\nRetimer.prototype.clear = function () {\n clearTimeout(this._timer)\n}\n\nfunction retimer () {\n if (typeof arguments[0] !== 'function') {\n throw new Error('callback needed')\n }\n\n if (typeof arguments[1] !== 'number') {\n throw new Error('timeout needed')\n }\n\n var args\n\n if (arguments.length > 0) {\n args = new Array(arguments.length - 2)\n\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 2]\n }\n }\n\n return new Retimer(arguments[0], arguments[1], args)\n}\n\nmodule.exports = retimer\n","'use strict'\n\nmodule.exports = function getTime () {\n return Date.now()\n}\n","const { AbortController } = require('native-abort-controller')\n\n/**\n * Takes an array of AbortSignals and returns a single signal.\n * If any signals are aborted, the returned signal will be aborted.\n * @param {Array} signals\n * @returns {AbortSignal}\n */\nfunction anySignal (signals) {\n const controller = new AbortController()\n\n function onAbort () {\n controller.abort()\n\n for (const signal of signals) {\n if (!signal || !signal.removeEventListener) continue\n signal.removeEventListener('abort', onAbort)\n }\n }\n\n for (const signal of signals) {\n if (!signal || !signal.addEventListener) continue\n if (signal.aborted) {\n onAbort()\n break\n }\n signal.addEventListener('abort', onAbort)\n }\n\n return controller.signal\n}\n\nmodule.exports = anySignal\nmodule.exports.anySignal = anySignal\n","'use strict'\n\nlet impl\n\nif (globalThis.AbortController && globalThis.AbortSignal) {\n impl = globalThis\n} else {\n impl = require('abort-controller')\n}\n\nmodule.exports.AbortSignal = impl.AbortSignal\nmodule.exports.AbortController = impl.AbortController\n","let durationRE = /(-?(?:\\d+\\.?\\d*|\\d*\\.?\\d+)(?:e[-+]?\\d+)?)\\s*([\\p{L}]*)/uig\r\n\r\n\r\n/**\r\n * conversion ratios\r\n */\r\n\r\nparse.nanosecond =\r\nparse.ns = 1 / 1e6\r\n\r\nparse['µs'] =\r\nparse['μs'] =\r\nparse.us =\r\nparse.microsecond = 1 / 1e3\r\n\r\nparse.millisecond =\r\nparse.ms =\r\nparse[''] = 1\r\n\r\nparse.second =\r\nparse.sec =\r\nparse.s = parse.ms * 1000\r\n\r\nparse.minute =\r\nparse.min =\r\nparse.m = parse.s * 60\r\n\r\nparse.hour =\r\nparse.hr =\r\nparse.h = parse.m * 60\r\n\r\nparse.day =\r\nparse.d = parse.h * 24\r\n\r\nparse.week =\r\nparse.wk =\r\nparse.w = parse.d * 7\r\n\r\nparse.month =\r\nparse.b =\r\nparse.d * (365.25 / 12)\r\n\r\nparse.year =\r\nparse.yr =\r\nparse.y = parse.d * 365.25\r\n\r\n/**\r\n * convert `str` to ms\r\n *\r\n * @param {String} str\r\n * @param {String} format\r\n * @return {Number}\r\n */\r\n\r\nfunction parse(str='', format='ms'){\r\n var result = null\r\n // ignore commas/placeholders\r\n str = (str+'').replace(/(\\d)[,_](\\d)/g, '$1$2')\r\n str.replace(durationRE, function(_, n, units){\r\n units = unitRatio(units)\r\n if (units) result = (result || 0) + parseFloat(n, 10) * units\r\n })\r\n\r\n return result && (result / (unitRatio(format) || 1))\r\n}\r\n\r\nfunction unitRatio(str) {\r\n return parse[str] || parse[str.toLowerCase().replace(/s$/, '')]\r\n}\r\n\r\nexport default parse\r\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass TimeoutError extends Error {\n constructor(message = 'request timed out') {\n super(message);\n this.name = 'TimeoutError';\n this.code = TimeoutError.code;\n }\n}\nTimeoutError.code = 'ERR_TIMEOUT';\n\nexports.TimeoutError = TimeoutError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst IPFS_PREFIX = '/ipfs/';\nfunction toCidAndPath(string) {\n if (string instanceof Uint8Array) {\n try {\n string = cid.CID.decode(string);\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_CID');\n }\n }\n let cid$1 = cid.CID.asCID(string);\n if (cid$1) {\n return {\n cid: cid$1,\n path: undefined\n };\n }\n string = string.toString();\n if (string.startsWith(IPFS_PREFIX)) {\n string = string.substring(IPFS_PREFIX.length);\n }\n const parts = string.split('/');\n let path;\n try {\n cid$1 = cid.CID.parse(parts.shift() || '');\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_CID');\n }\n if (parts.length) {\n path = `/${ parts.join('/') }`;\n }\n return {\n cid: cid$1,\n path\n };\n}\n\nexports.toCidAndPath = toCidAndPath;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar service = require('../utils/service.js');\n\nfunction createStop({network, preload, ipns, repo, mfsPreload}) {\n const stop = async () => {\n await Promise.all([\n preload.stop(),\n ipns.stop(),\n mfsPreload.stop(),\n service.Service.stop(network),\n repo.close()\n ]);\n };\n return stop;\n}\n\nexports.createStop = createStop;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dns = require('ipfs-core-config/dns');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction fqdnFixups(domain) {\n if (domain.endsWith('.eth')) {\n domain = domain.replace(/.eth$/, '.eth.link');\n }\n return domain;\n}\nfunction createDns() {\n const resolveDNS = async (domain, options = { recursive: true }) => {\n if (typeof domain !== 'string') {\n throw new Error('Invalid arguments, domain must be a string');\n }\n domain = fqdnFixups(domain);\n return dns.resolveDnslink(domain, options);\n };\n return withTimeoutOption.withTimeoutOption(resolveDNS);\n}\n\nexports.createDns = createDns;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar tlru = require('./utils/tlru.js');\nvar PQueue = require('p-queue');\nvar HTTP = require('ipfs-utils/src/http.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PQueue__default = /*#__PURE__*/_interopDefaultLegacy(PQueue);\nvar HTTP__default = /*#__PURE__*/_interopDefaultLegacy(HTTP);\n\nconst cache = new tlru.TLRU(1000);\nconst ttl = 60 * 1000;\nconst Queue = PQueue__default[\"default\"].default ? PQueue__default[\"default\"].default : PQueue__default[\"default\"];\nconst httpQueue = new Queue({ concurrency: 4 });\nconst ipfsPath = response => {\n if (response.Path)\n return response.Path;\n throw new Error(response.Message);\n};\nasync function resolveDnslink(fqdn, opts) {\n const resolve = async (fqdn, opts = {}) => {\n const searchParams = new URLSearchParams(opts);\n searchParams.set('arg', fqdn);\n const query = searchParams.toString();\n if (!opts.nocache && cache.has(query)) {\n const response = cache.get(query);\n return ipfsPath(response);\n }\n const response = await httpQueue.add(async () => {\n const res = await HTTP__default[\"default\"].get('https://ipfs.io/api/v0/dns', { searchParams });\n const query = new URL(res.url).search.slice(1);\n const json = await res.json();\n cache.set(query, json, ttl);\n return json;\n });\n return ipfsPath(response);\n };\n return resolve(fqdn, opts);\n}\n\nexports.resolveDnslink = resolveDnslink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hashlru = require('hashlru');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar hashlru__default = /*#__PURE__*/_interopDefaultLegacy(hashlru);\n\nclass TLRU {\n constructor(maxSize) {\n this.lru = hashlru__default[\"default\"](maxSize);\n }\n get(key) {\n const value = this.lru.get(key);\n if (value) {\n if (value.expire && value.expire < Date.now()) {\n this.lru.remove(key);\n return undefined;\n }\n return value.value;\n }\n return undefined;\n }\n set(key, value, ttl) {\n this.lru.set(key, {\n value,\n expire: Date.now() + ttl\n });\n }\n has(key) {\n const value = this.get(key);\n if (value) {\n return true;\n }\n return false;\n }\n remove(key) {\n this.lru.remove(key);\n }\n clear() {\n this.lru.clear();\n }\n}\n\nexports.TLRU = TLRU;\n","module.exports = function (max) {\n\n if (!max) throw Error('hashlru must have a max value, of type number, greater than 0')\n\n var size = 0, cache = Object.create(null), _cache = Object.create(null)\n\n function update (key, value) {\n cache[key] = value\n size ++\n if(size >= max) {\n size = 0\n _cache = cache\n cache = Object.create(null)\n }\n }\n\n return {\n has: function (key) {\n return cache[key] !== undefined || _cache[key] !== undefined\n },\n remove: function (key) {\n if(cache[key] !== undefined)\n cache[key] = undefined\n if(_cache[key] !== undefined)\n _cache[key] = undefined\n },\n get: function (key) {\n var v = cache[key]\n if(v !== undefined) return v\n if((v = _cache[key]) !== undefined) {\n update(key, v)\n return v\n }\n },\n set: function (key, value) {\n if(cache[key] !== undefined) cache[key] = value\n else update(key, value)\n },\n clear: function () {\n cache = Object.create(null)\n _cache = Object.create(null)\n }\n }\n}\n\n\n\n\n\n\n\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst EventEmitter = require(\"eventemitter3\");\nconst p_timeout_1 = require(\"p-timeout\");\nconst priority_queue_1 = require(\"./priority-queue\");\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nconst empty = () => { };\nconst timeoutError = new p_timeout_1.TimeoutError();\n/**\nPromise queue with concurrency control.\n*/\nclass PQueue extends EventEmitter {\n constructor(options) {\n var _a, _b, _c, _d;\n super();\n this._intervalCount = 0;\n this._intervalEnd = 0;\n this._pendingCount = 0;\n this._resolveEmpty = empty;\n this._resolveIdle = empty;\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\n options = Object.assign({ carryoverConcurrencyCount: false, intervalCap: Infinity, interval: 0, concurrency: Infinity, autoStart: true, queueClass: priority_queue_1.default }, options);\n if (!(typeof options.intervalCap === 'number' && options.intervalCap >= 1)) {\n throw new TypeError(`Expected \\`intervalCap\\` to be a number from 1 and up, got \\`${(_b = (_a = options.intervalCap) === null || _a === void 0 ? void 0 : _a.toString()) !== null && _b !== void 0 ? _b : ''}\\` (${typeof options.intervalCap})`);\n }\n if (options.interval === undefined || !(Number.isFinite(options.interval) && options.interval >= 0)) {\n throw new TypeError(`Expected \\`interval\\` to be a finite number >= 0, got \\`${(_d = (_c = options.interval) === null || _c === void 0 ? void 0 : _c.toString()) !== null && _d !== void 0 ? _d : ''}\\` (${typeof options.interval})`);\n }\n this._carryoverConcurrencyCount = options.carryoverConcurrencyCount;\n this._isIntervalIgnored = options.intervalCap === Infinity || options.interval === 0;\n this._intervalCap = options.intervalCap;\n this._interval = options.interval;\n this._queue = new options.queueClass();\n this._queueClass = options.queueClass;\n this.concurrency = options.concurrency;\n this._timeout = options.timeout;\n this._throwOnTimeout = options.throwOnTimeout === true;\n this._isPaused = options.autoStart === false;\n }\n get _doesIntervalAllowAnother() {\n return this._isIntervalIgnored || this._intervalCount < this._intervalCap;\n }\n get _doesConcurrentAllowAnother() {\n return this._pendingCount < this._concurrency;\n }\n _next() {\n this._pendingCount--;\n this._tryToStartAnother();\n this.emit('next');\n }\n _resolvePromises() {\n this._resolveEmpty();\n this._resolveEmpty = empty;\n if (this._pendingCount === 0) {\n this._resolveIdle();\n this._resolveIdle = empty;\n this.emit('idle');\n }\n }\n _onResumeInterval() {\n this._onInterval();\n this._initializeIntervalIfNeeded();\n this._timeoutId = undefined;\n }\n _isIntervalPaused() {\n const now = Date.now();\n if (this._intervalId === undefined) {\n const delay = this._intervalEnd - now;\n if (delay < 0) {\n // Act as the interval was done\n // We don't need to resume it here because it will be resumed on line 160\n this._intervalCount = (this._carryoverConcurrencyCount) ? this._pendingCount : 0;\n }\n else {\n // Act as the interval is pending\n if (this._timeoutId === undefined) {\n this._timeoutId = setTimeout(() => {\n this._onResumeInterval();\n }, delay);\n }\n return true;\n }\n }\n return false;\n }\n _tryToStartAnother() {\n if (this._queue.size === 0) {\n // We can clear the interval (\"pause\")\n // Because we can redo it later (\"resume\")\n if (this._intervalId) {\n clearInterval(this._intervalId);\n }\n this._intervalId = undefined;\n this._resolvePromises();\n return false;\n }\n if (!this._isPaused) {\n const canInitializeInterval = !this._isIntervalPaused();\n if (this._doesIntervalAllowAnother && this._doesConcurrentAllowAnother) {\n const job = this._queue.dequeue();\n if (!job) {\n return false;\n }\n this.emit('active');\n job();\n if (canInitializeInterval) {\n this._initializeIntervalIfNeeded();\n }\n return true;\n }\n }\n return false;\n }\n _initializeIntervalIfNeeded() {\n if (this._isIntervalIgnored || this._intervalId !== undefined) {\n return;\n }\n this._intervalId = setInterval(() => {\n this._onInterval();\n }, this._interval);\n this._intervalEnd = Date.now() + this._interval;\n }\n _onInterval() {\n if (this._intervalCount === 0 && this._pendingCount === 0 && this._intervalId) {\n clearInterval(this._intervalId);\n this._intervalId = undefined;\n }\n this._intervalCount = this._carryoverConcurrencyCount ? this._pendingCount : 0;\n this._processQueue();\n }\n /**\n Executes all queued functions until it reaches the limit.\n */\n _processQueue() {\n // eslint-disable-next-line no-empty\n while (this._tryToStartAnother()) { }\n }\n get concurrency() {\n return this._concurrency;\n }\n set concurrency(newConcurrency) {\n if (!(typeof newConcurrency === 'number' && newConcurrency >= 1)) {\n throw new TypeError(`Expected \\`concurrency\\` to be a number from 1 and up, got \\`${newConcurrency}\\` (${typeof newConcurrency})`);\n }\n this._concurrency = newConcurrency;\n this._processQueue();\n }\n /**\n Adds a sync or async task to the queue. Always returns a promise.\n */\n async add(fn, options = {}) {\n return new Promise((resolve, reject) => {\n const run = async () => {\n this._pendingCount++;\n this._intervalCount++;\n try {\n const operation = (this._timeout === undefined && options.timeout === undefined) ? fn() : p_timeout_1.default(Promise.resolve(fn()), (options.timeout === undefined ? this._timeout : options.timeout), () => {\n if (options.throwOnTimeout === undefined ? this._throwOnTimeout : options.throwOnTimeout) {\n reject(timeoutError);\n }\n return undefined;\n });\n resolve(await operation);\n }\n catch (error) {\n reject(error);\n }\n this._next();\n };\n this._queue.enqueue(run, options);\n this._tryToStartAnother();\n this.emit('add');\n });\n }\n /**\n Same as `.add()`, but accepts an array of sync or async functions.\n\n @returns A promise that resolves when all functions are resolved.\n */\n async addAll(functions, options) {\n return Promise.all(functions.map(async (function_) => this.add(function_, options)));\n }\n /**\n Start (or resume) executing enqueued tasks within concurrency limit. No need to call this if queue is not paused (via `options.autoStart = false` or by `.pause()` method.)\n */\n start() {\n if (!this._isPaused) {\n return this;\n }\n this._isPaused = false;\n this._processQueue();\n return this;\n }\n /**\n Put queue execution on hold.\n */\n pause() {\n this._isPaused = true;\n }\n /**\n Clear the queue.\n */\n clear() {\n this._queue = new this._queueClass();\n }\n /**\n Can be called multiple times. Useful if you for example add additional items at a later time.\n\n @returns A promise that settles when the queue becomes empty.\n */\n async onEmpty() {\n // Instantly resolve if the queue is empty\n if (this._queue.size === 0) {\n return;\n }\n return new Promise(resolve => {\n const existingResolve = this._resolveEmpty;\n this._resolveEmpty = () => {\n existingResolve();\n resolve();\n };\n });\n }\n /**\n The difference with `.onEmpty` is that `.onIdle` guarantees that all work from the queue has finished. `.onEmpty` merely signals that the queue is empty, but it could mean that some promises haven't completed yet.\n\n @returns A promise that settles when the queue becomes empty, and all promises have completed; `queue.size === 0 && queue.pending === 0`.\n */\n async onIdle() {\n // Instantly resolve if none pending and if nothing else is queued\n if (this._pendingCount === 0 && this._queue.size === 0) {\n return;\n }\n return new Promise(resolve => {\n const existingResolve = this._resolveIdle;\n this._resolveIdle = () => {\n existingResolve();\n resolve();\n };\n });\n }\n /**\n Size of the queue.\n */\n get size() {\n return this._queue.size;\n }\n /**\n Size of the queue, filtered by the given options.\n\n For example, this can be used to find the number of items remaining in the queue with a specific priority level.\n */\n sizeBy(options) {\n // eslint-disable-next-line unicorn/no-fn-reference-in-iterator\n return this._queue.filter(options).length;\n }\n /**\n Number of pending promises.\n */\n get pending() {\n return this._pendingCount;\n }\n /**\n Whether the queue is currently paused.\n */\n get isPaused() {\n return this._isPaused;\n }\n get timeout() {\n return this._timeout;\n }\n /**\n Set the timeout for future operations.\n */\n set timeout(milliseconds) {\n this._timeout = milliseconds;\n }\n}\nexports.default = PQueue;\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","'use strict';\n\nconst pFinally = require('p-finally');\n\nclass TimeoutError extends Error {\n\tconstructor(message) {\n\t\tsuper(message);\n\t\tthis.name = 'TimeoutError';\n\t}\n}\n\nconst pTimeout = (promise, milliseconds, fallback) => new Promise((resolve, reject) => {\n\tif (typeof milliseconds !== 'number' || milliseconds < 0) {\n\t\tthrow new TypeError('Expected `milliseconds` to be a positive number');\n\t}\n\n\tif (milliseconds === Infinity) {\n\t\tresolve(promise);\n\t\treturn;\n\t}\n\n\tconst timer = setTimeout(() => {\n\t\tif (typeof fallback === 'function') {\n\t\t\ttry {\n\t\t\t\tresolve(fallback());\n\t\t\t} catch (error) {\n\t\t\t\treject(error);\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst message = typeof fallback === 'string' ? fallback : `Promise timed out after ${milliseconds} milliseconds`;\n\t\tconst timeoutError = fallback instanceof Error ? fallback : new TimeoutError(message);\n\n\t\tif (typeof promise.cancel === 'function') {\n\t\t\tpromise.cancel();\n\t\t}\n\n\t\treject(timeoutError);\n\t}, milliseconds);\n\n\t// TODO: Use native `finally` keyword when targeting Node.js 10\n\tpFinally(\n\t\t// eslint-disable-next-line promise/prefer-await-to-then\n\t\tpromise.then(resolve, reject),\n\t\t() => {\n\t\t\tclearTimeout(timer);\n\t\t}\n\t);\n});\n\nmodule.exports = pTimeout;\n// TODO: Remove this for the next major release\nmodule.exports.default = pTimeout;\n\nmodule.exports.TimeoutError = TimeoutError;\n","'use strict';\nmodule.exports = (promise, onFinally) => {\n\tonFinally = onFinally || (() => {});\n\n\treturn promise.then(\n\t\tval => new Promise(resolve => {\n\t\t\tresolve(onFinally());\n\t\t}).then(() => val),\n\t\terr => new Promise(resolve => {\n\t\t\tresolve(onFinally());\n\t\t}).then(() => {\n\t\t\tthrow err;\n\t\t})\n\t);\n};\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst lower_bound_1 = require(\"./lower-bound\");\nclass PriorityQueue {\n constructor() {\n this._queue = [];\n }\n enqueue(run, options) {\n options = Object.assign({ priority: 0 }, options);\n const element = {\n priority: options.priority,\n run\n };\n if (this.size && this._queue[this.size - 1].priority >= options.priority) {\n this._queue.push(element);\n return;\n }\n const index = lower_bound_1.default(this._queue, element, (a, b) => b.priority - a.priority);\n this._queue.splice(index, 0, element);\n }\n dequeue() {\n const item = this._queue.shift();\n return item === null || item === void 0 ? void 0 : item.run;\n }\n filter(options) {\n return this._queue.filter((element) => element.priority === options.priority).map((element) => element.run);\n }\n get size() {\n return this._queue.length;\n }\n}\nexports.default = PriorityQueue;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// Port of lower_bound from https://en.cppreference.com/w/cpp/algorithm/lower_bound\n// Used to compute insertion index to keep queue sorted after insertion\nfunction lowerBound(array, value, comparator) {\n let first = 0;\n let count = array.length;\n while (count > 0) {\n const step = (count / 2) | 0;\n let it = first + step;\n if (comparator(array[it], value) <= 0) {\n first = ++it;\n count -= step + 1;\n }\n else {\n count = step;\n }\n }\n return first;\n}\nexports.default = lowerBound;\n","/* eslint-disable no-undef */\n'use strict'\n\nconst { fetch, Request, Headers } = require('./http/fetch')\nconst { TimeoutError, HTTPError } = require('./http/error')\nconst merge = require('merge-options').bind({ ignoreUndefined: true })\nconst { URL, URLSearchParams } = require('iso-url')\nconst { AbortController } = require('native-abort-controller')\nconst anySignal = require('any-signal')\n\n/**\n * @typedef {import('stream').Readable} NodeReadableStream\n * @typedef {import('./types').HTTPOptions} HTTPOptions\n * @typedef {import('./types').ExtendedResponse} ExtendedResponse\n */\n\n/**\n * @template TResponse\n * @param {Promise} promise\n * @param {number | undefined} ms\n * @param {AbortController} abortController\n * @returns {Promise}\n */\nconst timeout = (promise, ms, abortController) => {\n if (ms === undefined) {\n return promise\n }\n\n const start = Date.now()\n\n const timedOut = () => {\n const time = Date.now() - start\n\n return time >= ms\n }\n\n return new Promise((resolve, reject) => {\n const timeoutID = setTimeout(() => {\n if (timedOut()) {\n reject(new TimeoutError())\n abortController.abort()\n }\n }, ms)\n\n /**\n * @param {(value: any) => void } next\n */\n const after = (next) => {\n /**\n * @param {any} res\n */\n const fn = (res) => {\n clearTimeout(timeoutID)\n\n if (timedOut()) {\n reject(new TimeoutError())\n return\n }\n\n next(res)\n }\n return fn\n }\n\n promise\n .then(after(resolve), after(reject))\n })\n}\n\nconst defaults = {\n throwHttpErrors: true,\n credentials: 'same-origin'\n}\n\nclass HTTP {\n /**\n *\n * @param {HTTPOptions} options\n */\n constructor (options = {}) {\n /** @type {HTTPOptions} */\n this.opts = merge(defaults, options)\n }\n\n /**\n * Fetch\n *\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n * @returns {Promise}\n */\n async fetch (resource, options = {}) {\n /** @type {HTTPOptions} */\n const opts = merge(this.opts, options)\n const headers = new Headers(opts.headers)\n\n // validate resource type\n if (typeof resource !== 'string' && !(resource instanceof URL || resource instanceof Request)) {\n throw new TypeError('`resource` must be a string, URL, or Request')\n }\n\n const url = new URL(resource.toString(), opts.base)\n\n const {\n searchParams,\n transformSearchParams,\n json\n } = opts\n\n if (searchParams) {\n if (typeof transformSearchParams === 'function') {\n // @ts-ignore\n url.search = transformSearchParams(new URLSearchParams(opts.searchParams))\n } else {\n // @ts-ignore\n url.search = new URLSearchParams(opts.searchParams)\n }\n }\n\n if (json) {\n opts.body = JSON.stringify(opts.json)\n headers.set('content-type', 'application/json')\n }\n\n const abortController = new AbortController()\n // @ts-ignore\n const signal = anySignal([abortController.signal, opts.signal])\n\n const response = await timeout(\n fetch(\n url.toString(),\n {\n ...opts,\n signal,\n timeout: undefined,\n headers\n }\n ),\n opts.timeout,\n abortController\n )\n\n if (!response.ok && opts.throwHttpErrors) {\n if (opts.handleError) {\n await opts.handleError(response)\n }\n throw new HTTPError(response)\n }\n\n response.iterator = function () {\n return fromStream(response.body)\n }\n\n response.ndjson = async function * () {\n for await (const chunk of ndjson(response.iterator())) {\n if (options.transform) {\n yield options.transform(chunk)\n } else {\n yield chunk\n }\n }\n }\n\n return response\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n post (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'POST' })\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n get (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'GET' })\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n put (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'PUT' })\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n delete (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'DELETE' })\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n options (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'OPTIONS' })\n }\n}\n\n/**\n * Parses NDJSON chunks from an iterator\n *\n * @param {AsyncIterable} source\n * @returns {AsyncIterable}\n */\nconst ndjson = async function * (source) {\n const decoder = new TextDecoder()\n let buf = ''\n\n for await (const chunk of source) {\n buf += decoder.decode(chunk, { stream: true })\n const lines = buf.split(/\\r?\\n/)\n\n for (let i = 0; i < lines.length - 1; i++) {\n const l = lines[i].trim()\n if (l.length > 0) {\n yield JSON.parse(l)\n }\n }\n buf = lines[lines.length - 1]\n }\n buf += decoder.decode()\n buf = buf.trim()\n if (buf.length !== 0) {\n yield JSON.parse(buf)\n }\n}\n\n/**\n * Stream to AsyncIterable\n *\n * @template TChunk\n * @param {ReadableStream | NodeReadableStream | null} source\n * @returns {AsyncIterable}\n */\nconst fromStream = (source) => {\n // Workaround for https://github.com/node-fetch/node-fetch/issues/766\n if (isNodeReadableStream(source)) {\n const iter = source[Symbol.asyncIterator]()\n return {\n [Symbol.asyncIterator] () {\n return {\n next: iter.next.bind(iter),\n return (value) {\n source.destroy()\n if (typeof iter.return === 'function') {\n return iter.return()\n }\n return Promise.resolve({ done: true, value })\n }\n }\n }\n }\n }\n\n if (isWebReadableStream(source)) {\n const reader = source.getReader()\n return (async function * () {\n try {\n while (true) {\n // Read from the stream\n const { done, value } = await reader.read()\n // Exit if we're done\n if (done) return\n // Else yield the chunk\n if (value) {\n yield value\n }\n }\n } finally {\n reader.releaseLock()\n }\n })()\n }\n\n if (isAsyncIterable(source)) {\n return source\n }\n\n throw new TypeError('Body can\\'t be converted to AsyncIterable')\n}\n\n/**\n * Check if it's an AsyncIterable\n *\n * @template {unknown} TChunk\n * @template {any} Other\n * @param {Other|AsyncIterable} value\n * @returns {value is AsyncIterable}\n */\nconst isAsyncIterable = (value) => {\n return typeof value === 'object' &&\n value !== null &&\n typeof /** @type {any} */(value)[Symbol.asyncIterator] === 'function'\n}\n\n/**\n * Check for web readable stream\n *\n * @template {unknown} TChunk\n * @template {any} Other\n * @param {Other|ReadableStream} value\n * @returns {value is ReadableStream}\n */\nconst isWebReadableStream = (value) => {\n return value && typeof /** @type {any} */(value).getReader === 'function'\n}\n\n/**\n * @param {any} value\n * @returns {value is NodeReadableStream}\n */\nconst isNodeReadableStream = (value) =>\n Object.prototype.hasOwnProperty.call(value, 'readable') &&\n Object.prototype.hasOwnProperty.call(value, 'writable')\n\nHTTP.HTTPError = HTTPError\nHTTP.TimeoutError = TimeoutError\nHTTP.streamToAsyncIterator = fromStream\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.post = (resource, options) => new HTTP(options).post(resource, options)\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.get = (resource, options) => new HTTP(options).get(resource, options)\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.put = (resource, options) => new HTTP(options).put(resource, options)\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.delete = (resource, options) => new HTTP(options).delete(resource, options)\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.options = (resource, options) => new HTTP(options).options(resource, options)\n\nmodule.exports = HTTP\n","'use strict'\n\nconst { TimeoutError, AbortError } = require('./error')\nconst { Response, Request, Headers, default: fetch } = require('../fetch')\n\n/**\n * @typedef {import('../types').FetchOptions} FetchOptions\n * @typedef {import('../types').ProgressFn} ProgressFn\n */\n\n/**\n * Fetch with progress\n *\n * @param {string | Request} url\n * @param {FetchOptions} [options]\n * @returns {Promise}\n */\nconst fetchWithProgress = (url, options = {}) => {\n const request = new XMLHttpRequest()\n request.open(options.method || 'GET', url.toString(), true)\n\n const { timeout, headers } = options\n\n if (timeout && timeout > 0 && timeout < Infinity) {\n request.timeout = timeout\n }\n\n if (options.overrideMimeType != null) {\n request.overrideMimeType(options.overrideMimeType)\n }\n\n if (headers) {\n for (const [name, value] of new Headers(headers)) {\n request.setRequestHeader(name, value)\n }\n }\n\n if (options.signal) {\n options.signal.onabort = () => request.abort()\n }\n\n if (options.onUploadProgress) {\n request.upload.onprogress = options.onUploadProgress\n }\n\n // Note: Need to use `arraybuffer` here instead of `blob` because `Blob`\n // instances coming from JSDOM are not compatible with `Response` from\n // node-fetch (which is the setup we get when testing with jest because\n // it uses JSDOM which does not provide a global fetch\n // https://github.com/jsdom/jsdom/issues/1724)\n request.responseType = 'arraybuffer'\n\n return new Promise((resolve, reject) => {\n /**\n * @param {Event} event\n */\n const handleEvent = (event) => {\n switch (event.type) {\n case 'error': {\n resolve(Response.error())\n break\n }\n case 'load': {\n resolve(\n new ResponseWithURL(request.responseURL, request.response, {\n status: request.status,\n statusText: request.statusText,\n headers: parseHeaders(request.getAllResponseHeaders())\n })\n )\n break\n }\n case 'timeout': {\n reject(new TimeoutError())\n break\n }\n case 'abort': {\n reject(new AbortError())\n break\n }\n default: {\n break\n }\n }\n }\n request.onerror = handleEvent\n request.onload = handleEvent\n request.ontimeout = handleEvent\n request.onabort = handleEvent\n\n // @ts-expect-error options.body can be a node readable stream, which isn't compatible with XHR, but this\n // file is a browser override so you won't get a node readable stream so ignore the error\n request.send(options.body)\n })\n}\n\nconst fetchWithStreaming = fetch\n\n/**\n * @param {string | Request} url\n * @param {FetchOptions} options\n */\nconst fetchWith = (url, options = {}) =>\n (options.onUploadProgress != null)\n ? fetchWithProgress(url, options)\n : fetchWithStreaming(url, options)\n\n/**\n * Parse Headers from a XMLHttpRequest\n *\n * @param {string} input\n * @returns {Headers}\n */\nconst parseHeaders = (input) => {\n const headers = new Headers()\n for (const line of input.trim().split(/[\\r\\n]+/)) {\n const index = line.indexOf(': ')\n if (index > 0) {\n headers.set(line.slice(0, index), line.slice(index + 1))\n }\n }\n\n return headers\n}\n\nclass ResponseWithURL extends Response {\n /**\n * @param {string} url\n * @param {BodyInit} body\n * @param {ResponseInit} options\n */\n constructor (url, body, options) {\n super(body, options)\n Object.defineProperty(this, 'url', { value: url })\n }\n}\n\nmodule.exports = {\n fetch: fetchWith,\n Request,\n Headers\n}\n","'use strict'\n\nclass TimeoutError extends Error {\n constructor (message = 'Request timed out') {\n super(message)\n this.name = 'TimeoutError'\n }\n}\nexports.TimeoutError = TimeoutError\n\nclass AbortError extends Error {\n constructor (message = 'The operation was aborted.') {\n super(message)\n this.name = 'AbortError'\n }\n}\nexports.AbortError = AbortError\n\nclass HTTPError extends Error {\n /**\n * @param {Response} response\n */\n constructor (response) {\n super(response.statusText)\n this.name = 'HTTPError'\n this.response = response\n }\n}\nexports.HTTPError = HTTPError\n","'use strict'\n\nconst { isElectronMain } = require('./env')\n\nif (isElectronMain) {\n module.exports = require('electron-fetch')\n} else {\n// use window.fetch if it is available, fall back to node-fetch if not\n module.exports = require('native-fetch')\n}\n","'use strict'\n\nif (globalThis.fetch && globalThis.Headers && globalThis.Request && globalThis.Response) {\n module.exports = {\n default: globalThis.fetch,\n Headers: globalThis.Headers,\n Request: globalThis.Request,\n Response: globalThis.Response\n }\n} else {\n module.exports = {\n default: require('node-fetch').default,\n Headers: require('node-fetch').Headers,\n Request: require('node-fetch').Request,\n Response: require('node-fetch').Response\n }\n}\n","\"use strict\";\n\n// ref: https://github.com/tc39/proposal-global\nvar getGlobal = function () {\n\t// the only reliable means to get the global object is\n\t// `Function('return this')()`\n\t// However, this causes CSP violations in Chrome apps.\n\tif (typeof self !== 'undefined') { return self; }\n\tif (typeof window !== 'undefined') { return window; }\n\tif (typeof global !== 'undefined') { return global; }\n\tthrow new Error('unable to locate global object');\n}\n\nvar global = getGlobal();\n\nmodule.exports = exports = global.fetch;\n\n// Needed for TypeScript and Webpack.\nif (global.fetch) {\n\texports.default = global.fetch.bind(global);\n}\n\nexports.Headers = global.Headers;\nexports.Request = global.Request;\nexports.Response = global.Response;","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction createIsOnline({network}) {\n return () => {\n const net = network.try();\n return net != null && Boolean(net.libp2p.isStarted());\n };\n}\n\nexports.createIsOnline = createIsOnline;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar isIpfs = require('is-ipfs');\nvar cid = require('multiformats/cid');\nvar PeerId = require('peer-id');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar utils = require('../utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\n\nfunction createResolve({repo, codecs, bases, name}) {\n async function resolve(path, opts = {}) {\n if (!isIpfs__default['default'].path(path)) {\n throw new Error('invalid argument ' + path);\n }\n if (isIpfs__default['default'].ipnsPath(path)) {\n for await (const resolvedPath of name.resolve(path, opts)) {\n path = resolvedPath;\n }\n }\n const [, schema, hash, ...rest] = path.split('/');\n const base = opts.cidBase ? await bases.getBase(opts.cidBase) : undefined;\n const bytes = parseBytes(hash);\n if (rest.length === 0) {\n const str = base ? base.encoder.encode(bytes) : hash;\n return `/${ schema }/${ str }`;\n }\n const cid$1 = cid.CID.decode(bytes);\n path = rest.join('/');\n const results = utils.resolve(cid$1, path, codecs, repo, opts);\n let value = cid$1;\n let remainderPath = path;\n for await (const result of results) {\n if (cid.CID.asCID(result.value)) {\n value = result.value;\n remainderPath = result.remainderPath;\n }\n }\n return `/ipfs/${ value.toString(base && base.encoder) }${ remainderPath ? '/' + remainderPath : '' }`;\n }\n return withTimeoutOption.withTimeoutOption(resolve);\n}\nfunction parseBytes(str) {\n try {\n return PeerId__default['default'].parse(str).toBytes();\n } catch {\n return cid.CID.parse(str).bytes;\n }\n}\n\nexports.createResolve = createResolve;\n","/*\n * Id is an object representation of a peer Id. a peer Id is a multihash\n */\n\n'use strict'\n\nconst { CID } = require('multiformats/cid')\nconst b32 = require('multiformats/bases/base32')\nconst b36 = require('multiformats/bases/base36')\nconst b58 = require('multiformats/bases/base58')\nconst b64 = require('multiformats/bases/base64')\nconst { base58btc } = require('multiformats/bases/base58')\nconst { base32 } = require('multiformats/bases/base32')\nconst { base16 } = require('multiformats/bases/base16')\nconst Digest = require('multiformats/hashes/digest')\nconst cryptoKeys = require('libp2p-crypto/src/keys')\nconst withIs = require('class-is')\nconst { PeerIdProto } = require('./proto')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { identity } = require('multiformats/hashes/identity')\n\nconst bases = {\n ...b32,\n ...b36,\n ...b58,\n ...b64\n}\nconst baseDecoder = Object.keys(bases).reduce(\n (acc, curr) => acc.or(bases[curr]),\n base32.decoder\n)\n\n// these values are from https://github.com/multiformats/multicodec/blob/master/table.csv\nconst DAG_PB_CODE = 0x70\nconst LIBP2P_KEY_CODE = 0x72\n\nclass PeerId {\n constructor (id, privKey, pubKey) {\n if (!(id instanceof Uint8Array)) {\n throw new Error('invalid id provided')\n }\n\n if (privKey && pubKey && !uint8ArrayEquals(privKey.public.bytes, pubKey.bytes)) {\n throw new Error('inconsistent arguments')\n }\n\n this._id = id\n this._idB58String = base58btc.encode(this.id).substring(1)\n this._privKey = privKey\n this._pubKey = pubKey\n }\n\n get id () {\n return this._id\n }\n\n set id (val) {\n throw new Error('Id is immutable')\n }\n\n get privKey () {\n return this._privKey\n }\n\n set privKey (privKey) {\n this._privKey = privKey\n }\n\n get pubKey () {\n if (this._pubKey) {\n return this._pubKey\n }\n\n if (this._privKey) {\n return this._privKey.public\n }\n\n try {\n const decoded = Digest.decode(this.id)\n\n if (decoded.code === identity.code) {\n this._pubKey = cryptoKeys.unmarshalPublicKey(decoded.digest)\n }\n } catch (_) {\n // Ignore, there is no valid public key\n }\n\n return this._pubKey\n }\n\n set pubKey (pubKey) {\n this._pubKey = pubKey\n }\n\n // Return the protobuf version of the public key, matching go ipfs formatting\n marshalPubKey () {\n if (this.pubKey) {\n return cryptoKeys.marshalPublicKey(this.pubKey)\n }\n }\n\n // Return the protobuf version of the private key, matching go ipfs formatting\n marshalPrivKey () {\n if (this.privKey) {\n return cryptoKeys.marshalPrivateKey(this.privKey)\n }\n }\n\n // Return the protobuf version of the peer-id\n marshal (excludePriv) {\n return PeerIdProto.encode({\n id: this.toBytes(),\n pubKey: this.marshalPubKey(),\n privKey: excludePriv ? null : this.marshalPrivKey()\n }).finish()\n }\n\n toPrint () {\n let pid = this.toB58String()\n // All sha256 nodes start with Qm\n // We can skip the Qm to make the peer.ID more useful\n if (pid.startsWith('Qm')) {\n pid = pid.slice(2)\n }\n let maxRunes = 6\n if (pid.length < maxRunes) {\n maxRunes = pid.length\n }\n\n return ''\n }\n\n // return the jsonified version of the key, matching the formatting\n // of go-ipfs for its config file\n toJSON () {\n return {\n id: this.toB58String(),\n privKey: toB64Opt(this.marshalPrivKey()),\n pubKey: toB64Opt(this.marshalPubKey())\n }\n }\n\n // encode/decode functions\n toHexString () {\n return base16.encode(this.id).substring(1)\n }\n\n toBytes () {\n return this.id\n }\n\n toB58String () {\n return this._idB58String\n }\n\n // return self-describing String representation\n // in default format from RFC 0001: https://github.com/libp2p/specs/pull/209\n toString () {\n if (!this._idCIDString) {\n const cid = CID.createV1(LIBP2P_KEY_CODE, Digest.decode(this.id))\n\n Object.defineProperty(this, '_idCIDString', {\n value: cid.toString(),\n enumerable: false\n })\n }\n return this._idCIDString\n }\n\n /**\n * Checks the equality of `this` peer against a given PeerId.\n *\n * @param {Uint8Array|PeerId} id\n * @returns {boolean}\n */\n equals (id) {\n if (id instanceof Uint8Array) {\n return uint8ArrayEquals(this.id, id)\n } else if (id.id) {\n return uint8ArrayEquals(this.id, id.id)\n } else {\n throw new Error('not valid Id')\n }\n }\n\n /**\n * Checks the equality of `this` peer against a given PeerId.\n *\n * @deprecated Use `.equals`\n * @param {Uint8Array|PeerId} id\n * @returns {boolean}\n */\n isEqual (id) {\n return this.equals(id)\n }\n\n /*\n * Check if this PeerId instance is valid (privKey -> pubKey -> Id)\n */\n isValid () {\n // TODO: needs better checking\n return Boolean(this.privKey &&\n this.privKey.public &&\n this.privKey.public.bytes &&\n this.pubKey.bytes instanceof Uint8Array &&\n uint8ArrayEquals(this.privKey.public.bytes, this.pubKey.bytes))\n }\n\n /**\n * Check if the PeerId has an inline public key.\n *\n * @returns {boolean}\n */\n hasInlinePublicKey () {\n try {\n const decoded = Digest.decode(this.id)\n\n if (decoded.code === identity.code) {\n return true\n }\n } catch (_) {\n // Ignore, there is no valid public key\n }\n\n return false\n }\n}\n\nconst PeerIdWithIs = withIs(PeerId, {\n className: 'PeerId',\n symbolName: '@libp2p/js-peer-id/PeerId'\n})\n\nexports = module.exports = PeerIdWithIs\n\nconst computeDigest = (pubKey) => {\n if (pubKey.bytes.length <= 42) {\n return Digest.create(identity.code, pubKey.bytes).bytes\n } else {\n return pubKey.hash()\n }\n}\n\nconst computePeerId = async (privKey, pubKey) => {\n const digest = await computeDigest(pubKey)\n return new PeerIdWithIs(digest, privKey, pubKey)\n}\n\n// generation\nexports.create = async (opts) => {\n opts = opts || {}\n opts.bits = opts.bits || 2048\n opts.keyType = opts.keyType || 'RSA'\n\n const key = await cryptoKeys.generateKeyPair(opts.keyType, opts.bits)\n return computePeerId(key, key.public)\n}\n\nexports.createFromHexString = (str) => {\n return new PeerIdWithIs(base16.decode('f' + str))\n}\n\nexports.createFromBytes = (buf) => {\n try {\n const cid = CID.decode(buf)\n\n if (!validMulticodec(cid)) {\n throw new Error('Supplied PeerID CID is invalid')\n }\n\n return exports.createFromCID(cid)\n } catch {\n const digest = Digest.decode(buf)\n\n if (digest.code !== identity.code) {\n throw new Error('Supplied PeerID CID is invalid')\n }\n\n return new PeerIdWithIs(buf)\n }\n}\n\nexports.createFromB58String = (str) => {\n return exports.createFromBytes(base58btc.decode('z' + str))\n}\n\nconst validMulticodec = (cid) => {\n // supported: 'libp2p-key' (CIDv1) and 'dag-pb' (CIDv0 converted to CIDv1)\n return cid.code === LIBP2P_KEY_CODE || cid.code === DAG_PB_CODE\n}\n\nexports.createFromCID = (cid) => {\n cid = CID.asCID(cid)\n\n if (!cid || !validMulticodec(cid)) {\n throw new Error('Supplied PeerID CID is invalid')\n }\n\n return new PeerIdWithIs(cid.multihash.bytes)\n}\n\n// Public Key input will be a Uint8Array\nexports.createFromPubKey = async (key) => {\n let buf = key\n\n if (typeof buf === 'string') {\n buf = uint8ArrayFromString(key, 'base64pad')\n }\n\n if (!(buf instanceof Uint8Array)) {\n throw new Error('Supplied key is neither a base64 string nor a Uint8Array')\n }\n\n const pubKey = await cryptoKeys.unmarshalPublicKey(buf)\n return computePeerId(undefined, pubKey)\n}\n\n// Private key input will be a string\nexports.createFromPrivKey = async (key) => {\n if (typeof key === 'string') {\n key = uint8ArrayFromString(key, 'base64pad')\n }\n\n if (!(key instanceof Uint8Array)) {\n throw new Error('Supplied key is neither a base64 string nor a Uint8Array')\n }\n\n const privKey = await cryptoKeys.unmarshalPrivateKey(key)\n return computePeerId(privKey, privKey.public)\n}\n\nexports.createFromJSON = async (obj) => {\n const id = base58btc.decode('z' + obj.id)\n const rawPrivKey = obj.privKey && uint8ArrayFromString(obj.privKey, 'base64pad')\n const rawPubKey = obj.pubKey && uint8ArrayFromString(obj.pubKey, 'base64pad')\n const pub = rawPubKey && await cryptoKeys.unmarshalPublicKey(rawPubKey)\n\n if (!rawPrivKey) {\n return new PeerIdWithIs(id, undefined, pub)\n }\n\n const privKey = await cryptoKeys.unmarshalPrivateKey(rawPrivKey)\n const privDigest = await computeDigest(privKey.public)\n\n let pubDigest\n\n if (pub) {\n pubDigest = await computeDigest(pub)\n }\n\n if (pub && !uint8ArrayEquals(privDigest, pubDigest)) {\n throw new Error('Public and private key do not match')\n }\n\n if (id && !uint8ArrayEquals(privDigest, id)) {\n throw new Error('Id and private key do not match')\n }\n\n return new PeerIdWithIs(id, privKey, pub)\n}\n\nexports.createFromProtobuf = async (buf) => {\n if (typeof buf === 'string') {\n buf = uint8ArrayFromString(buf, 'base16')\n }\n\n let { id, privKey, pubKey } = PeerIdProto.decode(buf)\n\n privKey = privKey ? await cryptoKeys.unmarshalPrivateKey(privKey) : false\n pubKey = pubKey ? await cryptoKeys.unmarshalPublicKey(pubKey) : false\n\n let pubDigest\n let privDigest\n\n if (privKey) {\n privDigest = await computeDigest(privKey.public)\n }\n\n if (pubKey) {\n pubDigest = await computeDigest(pubKey)\n }\n\n if (privKey) {\n if (pubKey) {\n if (!uint8ArrayEquals(privDigest, pubDigest)) {\n throw new Error('Public and private key do not match')\n }\n }\n return new PeerIdWithIs(privDigest, privKey, privKey.public)\n }\n\n // TODO: val id and pubDigest\n\n if (pubKey) {\n return new PeerIdWithIs(pubDigest, undefined, pubKey)\n }\n\n if (id) {\n return new PeerIdWithIs(id)\n }\n\n throw new Error('Protobuf did not contain any usable key material')\n}\n\nexports.parse = (str) => {\n if (str.charAt(0) === '1' || str.charAt(0) === 'Q') {\n // identity hash ed25519 key or sha2-256 hash of rsa public key\n // base58btc encoded either way\n str = `z${str}`\n }\n\n return exports.createFromBytes(baseDecoder.decode(str))\n}\n\nexports.isPeerId = (peerId) => {\n return Boolean(typeof peerId === 'object' &&\n peerId._id &&\n peerId._idB58String)\n}\n\nfunction toB64Opt (val) {\n if (val) {\n return uint8ArrayToString(val, 'base64pad')\n }\n}\n","'use strict'\n\nconst keysPBM = require('./keys')\nrequire('node-forge/lib/asn1')\nrequire('node-forge/lib/pbe')\nconst forge = require('node-forge/lib/forge')\nconst errcode = require('err-code')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\nconst importer = require('./importer')\n\nconst supportedKeys = {\n rsa: require('./rsa-class'),\n ed25519: require('./ed25519-class'),\n secp256k1: require('./secp256k1-class')(keysPBM, require('../random-bytes'))\n}\n\nconst ErrMissingSecp256K1 = {\n message: 'secp256k1 support requires libp2p-crypto-secp256k1 package',\n code: 'ERR_MISSING_PACKAGE'\n}\n\nfunction typeToKey (type) {\n const key = supportedKeys[type.toLowerCase()]\n if (!key) {\n const supported = Object.keys(supportedKeys).join(' / ')\n throw errcode(new Error(`invalid or unsupported key type ${type}. Must be ${supported}`), 'ERR_UNSUPPORTED_KEY_TYPE')\n }\n return key\n}\n\n// Generates a keypair of the given type and bitsize\nconst generateKeyPair = async (type, bits) => { // eslint-disable-line require-await\n return typeToKey(type).generateKeyPair(bits)\n}\n\n// Generates a keypair of the given type and bitsize\n// seed is a 32 byte uint8array\nconst generateKeyPairFromSeed = async (type, seed, bits) => { // eslint-disable-line require-await\n const key = typeToKey(type)\n if (type.toLowerCase() !== 'ed25519') {\n throw errcode(new Error('Seed key derivation is unimplemented for RSA or secp256k1'), 'ERR_UNSUPPORTED_KEY_DERIVATION_TYPE')\n }\n return key.generateKeyPairFromSeed(seed, bits)\n}\n\n// Converts a protobuf serialized public key into its\n// representative object\nconst unmarshalPublicKey = (buf) => {\n const decoded = keysPBM.PublicKey.decode(buf)\n const data = decoded.Data\n\n switch (decoded.Type) {\n case keysPBM.KeyType.RSA:\n return supportedKeys.rsa.unmarshalRsaPublicKey(data)\n case keysPBM.KeyType.Ed25519:\n return supportedKeys.ed25519.unmarshalEd25519PublicKey(data)\n case keysPBM.KeyType.Secp256k1:\n if (supportedKeys.secp256k1) {\n return supportedKeys.secp256k1.unmarshalSecp256k1PublicKey(data)\n } else {\n throw errcode(new Error(ErrMissingSecp256K1.message), ErrMissingSecp256K1.code)\n }\n default:\n typeToKey(decoded.Type) // throws because type is not supported\n }\n}\n\n// Converts a public key object into a protobuf serialized public key\nconst marshalPublicKey = (key, type) => {\n type = (type || 'rsa').toLowerCase()\n typeToKey(type) // check type\n return key.bytes\n}\n\n// Converts a protobuf serialized private key into its\n// representative object\nconst unmarshalPrivateKey = async (buf) => { // eslint-disable-line require-await\n const decoded = keysPBM.PrivateKey.decode(buf)\n const data = decoded.Data\n\n switch (decoded.Type) {\n case keysPBM.KeyType.RSA:\n return supportedKeys.rsa.unmarshalRsaPrivateKey(data)\n case keysPBM.KeyType.Ed25519:\n return supportedKeys.ed25519.unmarshalEd25519PrivateKey(data)\n case keysPBM.KeyType.Secp256k1:\n if (supportedKeys.secp256k1) {\n return supportedKeys.secp256k1.unmarshalSecp256k1PrivateKey(data)\n } else {\n throw errcode(new Error(ErrMissingSecp256K1.message), ErrMissingSecp256K1.code)\n }\n default:\n typeToKey(decoded.Type) // throws because type is not supported\n }\n}\n\n// Converts a private key object into a protobuf serialized private key\nconst marshalPrivateKey = (key, type) => {\n type = (type || 'rsa').toLowerCase()\n typeToKey(type) // check type\n return key.bytes\n}\n\n/**\n *\n * @param {string} encryptedKey\n * @param {string} password\n */\nconst importKey = async (encryptedKey, password) => { // eslint-disable-line require-await\n try {\n const key = await importer.import(encryptedKey, password)\n return unmarshalPrivateKey(key)\n } catch (_) {\n // Ignore and try the old pem decrypt\n }\n\n // Only rsa supports pem right now\n const key = forge.pki.decryptRsaPrivateKey(encryptedKey, password)\n if (key === null) {\n throw errcode(new Error('Cannot read the key, most likely the password is wrong or not a RSA key'), 'ERR_CANNOT_DECRYPT_PEM')\n }\n let der = forge.asn1.toDer(forge.pki.privateKeyToAsn1(key))\n der = uint8ArrayFromString(der.getBytes(), 'ascii')\n return supportedKeys.rsa.unmarshalRsaPrivateKey(der)\n}\n\nmodule.exports = {\n supportedKeys,\n keysPBM,\n keyStretcher: require('./key-stretcher'),\n generateEphemeralKeyPair: require('./ephemeral-keys'),\n generateKeyPair,\n generateKeyPairFromSeed,\n unmarshalPublicKey,\n marshalPublicKey,\n unmarshalPrivateKey,\n marshalPrivateKey,\n import: importKey\n}\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-crypto-keys\"] || ($protobuf.roots[\"libp2p-crypto-keys\"] = {});\n\n/**\n * KeyType enum.\n * @exports KeyType\n * @enum {number}\n * @property {number} RSA=0 RSA value\n * @property {number} Ed25519=1 Ed25519 value\n * @property {number} Secp256k1=2 Secp256k1 value\n */\n$root.KeyType = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = \"RSA\"] = 0;\n values[valuesById[1] = \"Ed25519\"] = 1;\n values[valuesById[2] = \"Secp256k1\"] = 2;\n return values;\n})();\n\n$root.PublicKey = (function() {\n\n /**\n * Properties of a PublicKey.\n * @exports IPublicKey\n * @interface IPublicKey\n * @property {KeyType} Type PublicKey Type\n * @property {Uint8Array} Data PublicKey Data\n */\n\n /**\n * Constructs a new PublicKey.\n * @exports PublicKey\n * @classdesc Represents a PublicKey.\n * @implements IPublicKey\n * @constructor\n * @param {IPublicKey=} [p] Properties to set\n */\n function PublicKey(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * PublicKey Type.\n * @member {KeyType} Type\n * @memberof PublicKey\n * @instance\n */\n PublicKey.prototype.Type = 0;\n\n /**\n * PublicKey Data.\n * @member {Uint8Array} Data\n * @memberof PublicKey\n * @instance\n */\n PublicKey.prototype.Data = $util.newBuffer([]);\n\n /**\n * Encodes the specified PublicKey message. Does not implicitly {@link PublicKey.verify|verify} messages.\n * @function encode\n * @memberof PublicKey\n * @static\n * @param {IPublicKey} m PublicKey message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PublicKey.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(8).int32(m.Type);\n w.uint32(18).bytes(m.Data);\n return w;\n };\n\n /**\n * Decodes a PublicKey message from the specified reader or buffer.\n * @function decode\n * @memberof PublicKey\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PublicKey} PublicKey\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PublicKey.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PublicKey();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.Type = r.int32();\n break;\n case 2:\n m.Data = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty(\"Type\"))\n throw $util.ProtocolError(\"missing required 'Type'\", { instance: m });\n if (!m.hasOwnProperty(\"Data\"))\n throw $util.ProtocolError(\"missing required 'Data'\", { instance: m });\n return m;\n };\n\n /**\n * Creates a PublicKey message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PublicKey\n * @static\n * @param {Object.} d Plain object\n * @returns {PublicKey} PublicKey\n */\n PublicKey.fromObject = function fromObject(d) {\n if (d instanceof $root.PublicKey)\n return d;\n var m = new $root.PublicKey();\n switch (d.Type) {\n case \"RSA\":\n case 0:\n m.Type = 0;\n break;\n case \"Ed25519\":\n case 1:\n m.Type = 1;\n break;\n case \"Secp256k1\":\n case 2:\n m.Type = 2;\n break;\n }\n if (d.Data != null) {\n if (typeof d.Data === \"string\")\n $util.base64.decode(d.Data, m.Data = $util.newBuffer($util.base64.length(d.Data)), 0);\n else if (d.Data.length)\n m.Data = d.Data;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a PublicKey message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PublicKey\n * @static\n * @param {PublicKey} m PublicKey\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n PublicKey.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.Type = o.enums === String ? \"RSA\" : 0;\n if (o.bytes === String)\n d.Data = \"\";\n else {\n d.Data = [];\n if (o.bytes !== Array)\n d.Data = $util.newBuffer(d.Data);\n }\n }\n if (m.Type != null && m.hasOwnProperty(\"Type\")) {\n d.Type = o.enums === String ? $root.KeyType[m.Type] : m.Type;\n }\n if (m.Data != null && m.hasOwnProperty(\"Data\")) {\n d.Data = o.bytes === String ? $util.base64.encode(m.Data, 0, m.Data.length) : o.bytes === Array ? Array.prototype.slice.call(m.Data) : m.Data;\n }\n return d;\n };\n\n /**\n * Converts this PublicKey to JSON.\n * @function toJSON\n * @memberof PublicKey\n * @instance\n * @returns {Object.} JSON object\n */\n PublicKey.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return PublicKey;\n})();\n\n$root.PrivateKey = (function() {\n\n /**\n * Properties of a PrivateKey.\n * @exports IPrivateKey\n * @interface IPrivateKey\n * @property {KeyType} Type PrivateKey Type\n * @property {Uint8Array} Data PrivateKey Data\n */\n\n /**\n * Constructs a new PrivateKey.\n * @exports PrivateKey\n * @classdesc Represents a PrivateKey.\n * @implements IPrivateKey\n * @constructor\n * @param {IPrivateKey=} [p] Properties to set\n */\n function PrivateKey(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * PrivateKey Type.\n * @member {KeyType} Type\n * @memberof PrivateKey\n * @instance\n */\n PrivateKey.prototype.Type = 0;\n\n /**\n * PrivateKey Data.\n * @member {Uint8Array} Data\n * @memberof PrivateKey\n * @instance\n */\n PrivateKey.prototype.Data = $util.newBuffer([]);\n\n /**\n * Encodes the specified PrivateKey message. Does not implicitly {@link PrivateKey.verify|verify} messages.\n * @function encode\n * @memberof PrivateKey\n * @static\n * @param {IPrivateKey} m PrivateKey message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PrivateKey.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(8).int32(m.Type);\n w.uint32(18).bytes(m.Data);\n return w;\n };\n\n /**\n * Decodes a PrivateKey message from the specified reader or buffer.\n * @function decode\n * @memberof PrivateKey\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PrivateKey} PrivateKey\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PrivateKey.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PrivateKey();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.Type = r.int32();\n break;\n case 2:\n m.Data = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty(\"Type\"))\n throw $util.ProtocolError(\"missing required 'Type'\", { instance: m });\n if (!m.hasOwnProperty(\"Data\"))\n throw $util.ProtocolError(\"missing required 'Data'\", { instance: m });\n return m;\n };\n\n /**\n * Creates a PrivateKey message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PrivateKey\n * @static\n * @param {Object.} d Plain object\n * @returns {PrivateKey} PrivateKey\n */\n PrivateKey.fromObject = function fromObject(d) {\n if (d instanceof $root.PrivateKey)\n return d;\n var m = new $root.PrivateKey();\n switch (d.Type) {\n case \"RSA\":\n case 0:\n m.Type = 0;\n break;\n case \"Ed25519\":\n case 1:\n m.Type = 1;\n break;\n case \"Secp256k1\":\n case 2:\n m.Type = 2;\n break;\n }\n if (d.Data != null) {\n if (typeof d.Data === \"string\")\n $util.base64.decode(d.Data, m.Data = $util.newBuffer($util.base64.length(d.Data)), 0);\n else if (d.Data.length)\n m.Data = d.Data;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a PrivateKey message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PrivateKey\n * @static\n * @param {PrivateKey} m PrivateKey\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n PrivateKey.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.Type = o.enums === String ? \"RSA\" : 0;\n if (o.bytes === String)\n d.Data = \"\";\n else {\n d.Data = [];\n if (o.bytes !== Array)\n d.Data = $util.newBuffer(d.Data);\n }\n }\n if (m.Type != null && m.hasOwnProperty(\"Type\")) {\n d.Type = o.enums === String ? $root.KeyType[m.Type] : m.Type;\n }\n if (m.Data != null && m.hasOwnProperty(\"Data\")) {\n d.Data = o.bytes === String ? $util.base64.encode(m.Data, 0, m.Data.length) : o.bytes === Array ? Array.prototype.slice.call(m.Data) : m.Data;\n }\n return d;\n };\n\n /**\n * Converts this PrivateKey to JSON.\n * @function toJSON\n * @memberof PrivateKey\n * @instance\n * @returns {Object.} JSON object\n */\n PrivateKey.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return PrivateKey;\n})();\n\nmodule.exports = $root;\n","/**\n * Javascript implementation of Abstract Syntax Notation Number One.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n *\n * An API for storing data using the Abstract Syntax Notation Number One\n * format using DER (Distinguished Encoding Rules) encoding. This encoding is\n * commonly used to store data for PKI, i.e. X.509 Certificates, and this\n * implementation exists for that purpose.\n *\n * Abstract Syntax Notation Number One (ASN.1) is used to define the abstract\n * syntax of information without restricting the way the information is encoded\n * for transmission. It provides a standard that allows for open systems\n * communication. ASN.1 defines the syntax of information data and a number of\n * simple data types as well as a notation for describing them and specifying\n * values for them.\n *\n * The RSA algorithm creates public and private keys that are often stored in\n * X.509 or PKCS#X formats -- which use ASN.1 (encoded in DER format). This\n * class provides the most basic functionality required to store and load DSA\n * keys that are encoded according to ASN.1.\n *\n * The most common binary encodings for ASN.1 are BER (Basic Encoding Rules)\n * and DER (Distinguished Encoding Rules). DER is just a subset of BER that\n * has stricter requirements for how data must be encoded.\n *\n * Each ASN.1 structure has a tag (a byte identifying the ASN.1 structure type)\n * and a byte array for the value of this ASN1 structure which may be data or a\n * list of ASN.1 structures.\n *\n * Each ASN.1 structure using BER is (Tag-Length-Value):\n *\n * | byte 0 | bytes X | bytes Y |\n * |--------|---------|----------\n * | tag | length | value |\n *\n * ASN.1 allows for tags to be of \"High-tag-number form\" which allows a tag to\n * be two or more octets, but that is not supported by this class. A tag is\n * only 1 byte. Bits 1-5 give the tag number (ie the data type within a\n * particular 'class'), 6 indicates whether or not the ASN.1 value is\n * constructed from other ASN.1 values, and bits 7 and 8 give the 'class'. If\n * bits 7 and 8 are both zero, the class is UNIVERSAL. If only bit 7 is set,\n * then the class is APPLICATION. If only bit 8 is set, then the class is\n * CONTEXT_SPECIFIC. If both bits 7 and 8 are set, then the class is PRIVATE.\n * The tag numbers for the data types for the class UNIVERSAL are listed below:\n *\n * UNIVERSAL 0 Reserved for use by the encoding rules\n * UNIVERSAL 1 Boolean type\n * UNIVERSAL 2 Integer type\n * UNIVERSAL 3 Bitstring type\n * UNIVERSAL 4 Octetstring type\n * UNIVERSAL 5 Null type\n * UNIVERSAL 6 Object identifier type\n * UNIVERSAL 7 Object descriptor type\n * UNIVERSAL 8 External type and Instance-of type\n * UNIVERSAL 9 Real type\n * UNIVERSAL 10 Enumerated type\n * UNIVERSAL 11 Embedded-pdv type\n * UNIVERSAL 12 UTF8String type\n * UNIVERSAL 13 Relative object identifier type\n * UNIVERSAL 14-15 Reserved for future editions\n * UNIVERSAL 16 Sequence and Sequence-of types\n * UNIVERSAL 17 Set and Set-of types\n * UNIVERSAL 18-22, 25-30 Character string types\n * UNIVERSAL 23-24 Time types\n *\n * The length of an ASN.1 structure is specified after the tag identifier.\n * There is a definite form and an indefinite form. The indefinite form may\n * be used if the encoding is constructed and not all immediately available.\n * The indefinite form is encoded using a length byte with only the 8th bit\n * set. The end of the constructed object is marked using end-of-contents\n * octets (two zero bytes).\n *\n * The definite form looks like this:\n *\n * The length may take up 1 or more bytes, it depends on the length of the\n * value of the ASN.1 structure. DER encoding requires that if the ASN.1\n * structure has a value that has a length greater than 127, more than 1 byte\n * will be used to store its length, otherwise just one byte will be used.\n * This is strict.\n *\n * In the case that the length of the ASN.1 value is less than 127, 1 octet\n * (byte) is used to store the \"short form\" length. The 8th bit has a value of\n * 0 indicating the length is \"short form\" and not \"long form\" and bits 7-1\n * give the length of the data. (The 8th bit is the left-most, most significant\n * bit: also known as big endian or network format).\n *\n * In the case that the length of the ASN.1 value is greater than 127, 2 to\n * 127 octets (bytes) are used to store the \"long form\" length. The first\n * byte's 8th bit is set to 1 to indicate the length is \"long form.\" Bits 7-1\n * give the number of additional octets. All following octets are in base 256\n * with the most significant digit first (typical big-endian binary unsigned\n * integer storage). So, for instance, if the length of a value was 257, the\n * first byte would be set to:\n *\n * 10000010 = 130 = 0x82.\n *\n * This indicates there are 2 octets (base 256) for the length. The second and\n * third bytes (the octets just mentioned) would store the length in base 256:\n *\n * octet 2: 00000001 = 1 * 256^1 = 256\n * octet 3: 00000001 = 1 * 256^0 = 1\n * total = 257\n *\n * The algorithm for converting a js integer value of 257 to base-256 is:\n *\n * var value = 257;\n * var bytes = [];\n * bytes[0] = (value >>> 8) & 0xFF; // most significant byte first\n * bytes[1] = value & 0xFF; // least significant byte last\n *\n * On the ASN.1 UNIVERSAL Object Identifier (OID) type:\n *\n * An OID can be written like: \"value1.value2.value3...valueN\"\n *\n * The DER encoding rules:\n *\n * The first byte has the value 40 * value1 + value2.\n * The following bytes, if any, encode the remaining values. Each value is\n * encoded in base 128, most significant digit first (big endian), with as\n * few digits as possible, and the most significant bit of each byte set\n * to 1 except the last in each value's encoding. For example: Given the\n * OID \"1.2.840.113549\", its DER encoding is (remember each byte except the\n * last one in each encoding is OR'd with 0x80):\n *\n * byte 1: 40 * 1 + 2 = 42 = 0x2A.\n * bytes 2-3: 128 * 6 + 72 = 840 = 6 72 = 6 72 = 0x0648 = 0x8648\n * bytes 4-6: 16384 * 6 + 128 * 119 + 13 = 6 119 13 = 0x06770D = 0x86F70D\n *\n * The final value is: 0x2A864886F70D.\n * The full OID (including ASN.1 tag and length of 6 bytes) is:\n * 0x06062A864886F70D\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./oids');\n\n/* ASN.1 API */\nvar asn1 = module.exports = forge.asn1 = forge.asn1 || {};\n\n/**\n * ASN.1 classes.\n */\nasn1.Class = {\n UNIVERSAL: 0x00,\n APPLICATION: 0x40,\n CONTEXT_SPECIFIC: 0x80,\n PRIVATE: 0xC0\n};\n\n/**\n * ASN.1 types. Not all types are supported by this implementation, only\n * those necessary to implement a simple PKI are implemented.\n */\nasn1.Type = {\n NONE: 0,\n BOOLEAN: 1,\n INTEGER: 2,\n BITSTRING: 3,\n OCTETSTRING: 4,\n NULL: 5,\n OID: 6,\n ODESC: 7,\n EXTERNAL: 8,\n REAL: 9,\n ENUMERATED: 10,\n EMBEDDED: 11,\n UTF8: 12,\n ROID: 13,\n SEQUENCE: 16,\n SET: 17,\n PRINTABLESTRING: 19,\n IA5STRING: 22,\n UTCTIME: 23,\n GENERALIZEDTIME: 24,\n BMPSTRING: 30\n};\n\n/**\n * Creates a new asn1 object.\n *\n * @param tagClass the tag class for the object.\n * @param type the data type (tag number) for the object.\n * @param constructed true if the asn1 object is in constructed form.\n * @param value the value for the object, if it is not constructed.\n * @param [options] the options to use:\n * [bitStringContents] the plain BIT STRING content including padding\n * byte.\n *\n * @return the asn1 object.\n */\nasn1.create = function(tagClass, type, constructed, value, options) {\n /* An asn1 object has a tagClass, a type, a constructed flag, and a\n value. The value's type depends on the constructed flag. If\n constructed, it will contain a list of other asn1 objects. If not,\n it will contain the ASN.1 value as an array of bytes formatted\n according to the ASN.1 data type. */\n\n // remove undefined values\n if(forge.util.isArray(value)) {\n var tmp = [];\n for(var i = 0; i < value.length; ++i) {\n if(value[i] !== undefined) {\n tmp.push(value[i]);\n }\n }\n value = tmp;\n }\n\n var obj = {\n tagClass: tagClass,\n type: type,\n constructed: constructed,\n composed: constructed || forge.util.isArray(value),\n value: value\n };\n if(options && 'bitStringContents' in options) {\n // TODO: copy byte buffer if it's a buffer not a string\n obj.bitStringContents = options.bitStringContents;\n // TODO: add readonly flag to avoid this overhead\n // save copy to detect changes\n obj.original = asn1.copy(obj);\n }\n return obj;\n};\n\n/**\n * Copies an asn1 object.\n *\n * @param obj the asn1 object.\n * @param [options] copy options:\n * [excludeBitStringContents] true to not copy bitStringContents\n *\n * @return the a copy of the asn1 object.\n */\nasn1.copy = function(obj, options) {\n var copy;\n\n if(forge.util.isArray(obj)) {\n copy = [];\n for(var i = 0; i < obj.length; ++i) {\n copy.push(asn1.copy(obj[i], options));\n }\n return copy;\n }\n\n if(typeof obj === 'string') {\n // TODO: copy byte buffer if it's a buffer not a string\n return obj;\n }\n\n copy = {\n tagClass: obj.tagClass,\n type: obj.type,\n constructed: obj.constructed,\n composed: obj.composed,\n value: asn1.copy(obj.value, options)\n };\n if(options && !options.excludeBitStringContents) {\n // TODO: copy byte buffer if it's a buffer not a string\n copy.bitStringContents = obj.bitStringContents;\n }\n return copy;\n};\n\n/**\n * Compares asn1 objects for equality.\n *\n * Note this function does not run in constant time.\n *\n * @param obj1 the first asn1 object.\n * @param obj2 the second asn1 object.\n * @param [options] compare options:\n * [includeBitStringContents] true to compare bitStringContents\n *\n * @return true if the asn1 objects are equal.\n */\nasn1.equals = function(obj1, obj2, options) {\n if(forge.util.isArray(obj1)) {\n if(!forge.util.isArray(obj2)) {\n return false;\n }\n if(obj1.length !== obj2.length) {\n return false;\n }\n for(var i = 0; i < obj1.length; ++i) {\n if(!asn1.equals(obj1[i], obj2[i])) {\n return false;\n }\n }\n return true;\n }\n\n if(typeof obj1 !== typeof obj2) {\n return false;\n }\n\n if(typeof obj1 === 'string') {\n return obj1 === obj2;\n }\n\n var equal = obj1.tagClass === obj2.tagClass &&\n obj1.type === obj2.type &&\n obj1.constructed === obj2.constructed &&\n obj1.composed === obj2.composed &&\n asn1.equals(obj1.value, obj2.value);\n if(options && options.includeBitStringContents) {\n equal = equal && (obj1.bitStringContents === obj2.bitStringContents);\n }\n\n return equal;\n};\n\n/**\n * Gets the length of a BER-encoded ASN.1 value.\n *\n * In case the length is not specified, undefined is returned.\n *\n * @param b the BER-encoded ASN.1 byte buffer, starting with the first\n * length byte.\n *\n * @return the length of the BER-encoded ASN.1 value or undefined.\n */\nasn1.getBerValueLength = function(b) {\n // TODO: move this function and related DER/BER functions to a der.js\n // file; better abstract ASN.1 away from der/ber.\n var b2 = b.getByte();\n if(b2 === 0x80) {\n return undefined;\n }\n\n // see if the length is \"short form\" or \"long form\" (bit 8 set)\n var length;\n var longForm = b2 & 0x80;\n if(!longForm) {\n // length is just the first byte\n length = b2;\n } else {\n // the number of bytes the length is specified in bits 7 through 1\n // and each length byte is in big-endian base-256\n length = b.getInt((b2 & 0x7F) << 3);\n }\n return length;\n};\n\n/**\n * Check if the byte buffer has enough bytes. Throws an Error if not.\n *\n * @param bytes the byte buffer to parse from.\n * @param remaining the bytes remaining in the current parsing state.\n * @param n the number of bytes the buffer must have.\n */\nfunction _checkBufferLength(bytes, remaining, n) {\n if(n > remaining) {\n var error = new Error('Too few bytes to parse DER.');\n error.available = bytes.length();\n error.remaining = remaining;\n error.requested = n;\n throw error;\n }\n}\n\n/**\n * Gets the length of a BER-encoded ASN.1 value.\n *\n * In case the length is not specified, undefined is returned.\n *\n * @param bytes the byte buffer to parse from.\n * @param remaining the bytes remaining in the current parsing state.\n *\n * @return the length of the BER-encoded ASN.1 value or undefined.\n */\nvar _getValueLength = function(bytes, remaining) {\n // TODO: move this function and related DER/BER functions to a der.js\n // file; better abstract ASN.1 away from der/ber.\n // fromDer already checked that this byte exists\n var b2 = bytes.getByte();\n remaining--;\n if(b2 === 0x80) {\n return undefined;\n }\n\n // see if the length is \"short form\" or \"long form\" (bit 8 set)\n var length;\n var longForm = b2 & 0x80;\n if(!longForm) {\n // length is just the first byte\n length = b2;\n } else {\n // the number of bytes the length is specified in bits 7 through 1\n // and each length byte is in big-endian base-256\n var longFormBytes = b2 & 0x7F;\n _checkBufferLength(bytes, remaining, longFormBytes);\n length = bytes.getInt(longFormBytes << 3);\n }\n // FIXME: this will only happen for 32 bit getInt with high bit set\n if(length < 0) {\n throw new Error('Negative length: ' + length);\n }\n return length;\n};\n\n/**\n * Parses an asn1 object from a byte buffer in DER format.\n *\n * @param bytes the byte buffer to parse from.\n * @param [strict] true to be strict when checking value lengths, false to\n * allow truncated values (default: true).\n * @param [options] object with options or boolean strict flag\n * [strict] true to be strict when checking value lengths, false to\n * allow truncated values (default: true).\n * [decodeBitStrings] true to attempt to decode the content of\n * BIT STRINGs (not OCTET STRINGs) using strict mode. Note that\n * without schema support to understand the data context this can\n * erroneously decode values that happen to be valid ASN.1. This\n * flag will be deprecated or removed as soon as schema support is\n * available. (default: true)\n *\n * @return the parsed asn1 object.\n */\nasn1.fromDer = function(bytes, options) {\n if(options === undefined) {\n options = {\n strict: true,\n decodeBitStrings: true\n };\n }\n if(typeof options === 'boolean') {\n options = {\n strict: options,\n decodeBitStrings: true\n };\n }\n if(!('strict' in options)) {\n options.strict = true;\n }\n if(!('decodeBitStrings' in options)) {\n options.decodeBitStrings = true;\n }\n\n // wrap in buffer if needed\n if(typeof bytes === 'string') {\n bytes = forge.util.createBuffer(bytes);\n }\n\n return _fromDer(bytes, bytes.length(), 0, options);\n};\n\n/**\n * Internal function to parse an asn1 object from a byte buffer in DER format.\n *\n * @param bytes the byte buffer to parse from.\n * @param remaining the number of bytes remaining for this chunk.\n * @param depth the current parsing depth.\n * @param options object with same options as fromDer().\n *\n * @return the parsed asn1 object.\n */\nfunction _fromDer(bytes, remaining, depth, options) {\n // temporary storage for consumption calculations\n var start;\n\n // minimum length for ASN.1 DER structure is 2\n _checkBufferLength(bytes, remaining, 2);\n\n // get the first byte\n var b1 = bytes.getByte();\n // consumed one byte\n remaining--;\n\n // get the tag class\n var tagClass = (b1 & 0xC0);\n\n // get the type (bits 1-5)\n var type = b1 & 0x1F;\n\n // get the variable value length and adjust remaining bytes\n start = bytes.length();\n var length = _getValueLength(bytes, remaining);\n remaining -= start - bytes.length();\n\n // ensure there are enough bytes to get the value\n if(length !== undefined && length > remaining) {\n if(options.strict) {\n var error = new Error('Too few bytes to read ASN.1 value.');\n error.available = bytes.length();\n error.remaining = remaining;\n error.requested = length;\n throw error;\n }\n // Note: be lenient with truncated values and use remaining state bytes\n length = remaining;\n }\n\n // value storage\n var value;\n // possible BIT STRING contents storage\n var bitStringContents;\n\n // constructed flag is bit 6 (32 = 0x20) of the first byte\n var constructed = ((b1 & 0x20) === 0x20);\n if(constructed) {\n // parse child asn1 objects from the value\n value = [];\n if(length === undefined) {\n // asn1 object of indefinite length, read until end tag\n for(;;) {\n _checkBufferLength(bytes, remaining, 2);\n if(bytes.bytes(2) === String.fromCharCode(0, 0)) {\n bytes.getBytes(2);\n remaining -= 2;\n break;\n }\n start = bytes.length();\n value.push(_fromDer(bytes, remaining, depth + 1, options));\n remaining -= start - bytes.length();\n }\n } else {\n // parsing asn1 object of definite length\n while(length > 0) {\n start = bytes.length();\n value.push(_fromDer(bytes, length, depth + 1, options));\n remaining -= start - bytes.length();\n length -= start - bytes.length();\n }\n }\n }\n\n // if a BIT STRING, save the contents including padding\n if(value === undefined && tagClass === asn1.Class.UNIVERSAL &&\n type === asn1.Type.BITSTRING) {\n bitStringContents = bytes.bytes(length);\n }\n\n // determine if a non-constructed value should be decoded as a composed\n // value that contains other ASN.1 objects. BIT STRINGs (and OCTET STRINGs)\n // can be used this way.\n if(value === undefined && options.decodeBitStrings &&\n tagClass === asn1.Class.UNIVERSAL &&\n // FIXME: OCTET STRINGs not yet supported here\n // .. other parts of forge expect to decode OCTET STRINGs manually\n (type === asn1.Type.BITSTRING /*|| type === asn1.Type.OCTETSTRING*/) &&\n length > 1) {\n // save read position\n var savedRead = bytes.read;\n var savedRemaining = remaining;\n var unused = 0;\n if(type === asn1.Type.BITSTRING) {\n /* The first octet gives the number of bits by which the length of the\n bit string is less than the next multiple of eight (this is called\n the \"number of unused bits\").\n\n The second and following octets give the value of the bit string\n converted to an octet string. */\n _checkBufferLength(bytes, remaining, 1);\n unused = bytes.getByte();\n remaining--;\n }\n // if all bits are used, maybe the BIT/OCTET STRING holds ASN.1 objs\n if(unused === 0) {\n try {\n // attempt to parse child asn1 object from the value\n // (stored in array to signal composed value)\n start = bytes.length();\n var subOptions = {\n // enforce strict mode to avoid parsing ASN.1 from plain data\n verbose: options.verbose,\n strict: true,\n decodeBitStrings: true\n };\n var composed = _fromDer(bytes, remaining, depth + 1, subOptions);\n var used = start - bytes.length();\n remaining -= used;\n if(type == asn1.Type.BITSTRING) {\n used++;\n }\n\n // if the data all decoded and the class indicates UNIVERSAL or\n // CONTEXT_SPECIFIC then assume we've got an encapsulated ASN.1 object\n var tc = composed.tagClass;\n if(used === length &&\n (tc === asn1.Class.UNIVERSAL || tc === asn1.Class.CONTEXT_SPECIFIC)) {\n value = [composed];\n }\n } catch(ex) {\n }\n }\n if(value === undefined) {\n // restore read position\n bytes.read = savedRead;\n remaining = savedRemaining;\n }\n }\n\n if(value === undefined) {\n // asn1 not constructed or composed, get raw value\n // TODO: do DER to OID conversion and vice-versa in .toDer?\n\n if(length === undefined) {\n if(options.strict) {\n throw new Error('Non-constructed ASN.1 object of indefinite length.');\n }\n // be lenient and use remaining state bytes\n length = remaining;\n }\n\n if(type === asn1.Type.BMPSTRING) {\n value = '';\n for(; length > 0; length -= 2) {\n _checkBufferLength(bytes, remaining, 2);\n value += String.fromCharCode(bytes.getInt16());\n remaining -= 2;\n }\n } else {\n value = bytes.getBytes(length);\n }\n }\n\n // add BIT STRING contents if available\n var asn1Options = bitStringContents === undefined ? null : {\n bitStringContents: bitStringContents\n };\n\n // create and return asn1 object\n return asn1.create(tagClass, type, constructed, value, asn1Options);\n}\n\n/**\n * Converts the given asn1 object to a buffer of bytes in DER format.\n *\n * @param asn1 the asn1 object to convert to bytes.\n *\n * @return the buffer of bytes.\n */\nasn1.toDer = function(obj) {\n var bytes = forge.util.createBuffer();\n\n // build the first byte\n var b1 = obj.tagClass | obj.type;\n\n // for storing the ASN.1 value\n var value = forge.util.createBuffer();\n\n // use BIT STRING contents if available and data not changed\n var useBitStringContents = false;\n if('bitStringContents' in obj) {\n useBitStringContents = true;\n if(obj.original) {\n useBitStringContents = asn1.equals(obj, obj.original);\n }\n }\n\n if(useBitStringContents) {\n value.putBytes(obj.bitStringContents);\n } else if(obj.composed) {\n // if composed, use each child asn1 object's DER bytes as value\n // turn on 6th bit (0x20 = 32) to indicate asn1 is constructed\n // from other asn1 objects\n if(obj.constructed) {\n b1 |= 0x20;\n } else {\n // type is a bit string, add unused bits of 0x00\n value.putByte(0x00);\n }\n\n // add all of the child DER bytes together\n for(var i = 0; i < obj.value.length; ++i) {\n if(obj.value[i] !== undefined) {\n value.putBuffer(asn1.toDer(obj.value[i]));\n }\n }\n } else {\n // use asn1.value directly\n if(obj.type === asn1.Type.BMPSTRING) {\n for(var i = 0; i < obj.value.length; ++i) {\n value.putInt16(obj.value.charCodeAt(i));\n }\n } else {\n // ensure integer is minimally-encoded\n // TODO: should all leading bytes be stripped vs just one?\n // .. ex '00 00 01' => '01'?\n if(obj.type === asn1.Type.INTEGER &&\n obj.value.length > 1 &&\n // leading 0x00 for positive integer\n ((obj.value.charCodeAt(0) === 0 &&\n (obj.value.charCodeAt(1) & 0x80) === 0) ||\n // leading 0xFF for negative integer\n (obj.value.charCodeAt(0) === 0xFF &&\n (obj.value.charCodeAt(1) & 0x80) === 0x80))) {\n value.putBytes(obj.value.substr(1));\n } else {\n value.putBytes(obj.value);\n }\n }\n }\n\n // add tag byte\n bytes.putByte(b1);\n\n // use \"short form\" encoding\n if(value.length() <= 127) {\n // one byte describes the length\n // bit 8 = 0 and bits 7-1 = length\n bytes.putByte(value.length() & 0x7F);\n } else {\n // use \"long form\" encoding\n // 2 to 127 bytes describe the length\n // first byte: bit 8 = 1 and bits 7-1 = # of additional bytes\n // other bytes: length in base 256, big-endian\n var len = value.length();\n var lenBytes = '';\n do {\n lenBytes += String.fromCharCode(len & 0xFF);\n len = len >>> 8;\n } while(len > 0);\n\n // set first byte to # bytes used to store the length and turn on\n // bit 8 to indicate long-form length is used\n bytes.putByte(lenBytes.length | 0x80);\n\n // concatenate length bytes in reverse since they were generated\n // little endian and we need big endian\n for(var i = lenBytes.length - 1; i >= 0; --i) {\n bytes.putByte(lenBytes.charCodeAt(i));\n }\n }\n\n // concatenate value bytes\n bytes.putBuffer(value);\n return bytes;\n};\n\n/**\n * Converts an OID dot-separated string to a byte buffer. The byte buffer\n * contains only the DER-encoded value, not any tag or length bytes.\n *\n * @param oid the OID dot-separated string.\n *\n * @return the byte buffer.\n */\nasn1.oidToDer = function(oid) {\n // split OID into individual values\n var values = oid.split('.');\n var bytes = forge.util.createBuffer();\n\n // first byte is 40 * value1 + value2\n bytes.putByte(40 * parseInt(values[0], 10) + parseInt(values[1], 10));\n // other bytes are each value in base 128 with 8th bit set except for\n // the last byte for each value\n var last, valueBytes, value, b;\n for(var i = 2; i < values.length; ++i) {\n // produce value bytes in reverse because we don't know how many\n // bytes it will take to store the value\n last = true;\n valueBytes = [];\n value = parseInt(values[i], 10);\n do {\n b = value & 0x7F;\n value = value >>> 7;\n // if value is not last, then turn on 8th bit\n if(!last) {\n b |= 0x80;\n }\n valueBytes.push(b);\n last = false;\n } while(value > 0);\n\n // add value bytes in reverse (needs to be in big endian)\n for(var n = valueBytes.length - 1; n >= 0; --n) {\n bytes.putByte(valueBytes[n]);\n }\n }\n\n return bytes;\n};\n\n/**\n * Converts a DER-encoded byte buffer to an OID dot-separated string. The\n * byte buffer should contain only the DER-encoded value, not any tag or\n * length bytes.\n *\n * @param bytes the byte buffer.\n *\n * @return the OID dot-separated string.\n */\nasn1.derToOid = function(bytes) {\n var oid;\n\n // wrap in buffer if needed\n if(typeof bytes === 'string') {\n bytes = forge.util.createBuffer(bytes);\n }\n\n // first byte is 40 * value1 + value2\n var b = bytes.getByte();\n oid = Math.floor(b / 40) + '.' + (b % 40);\n\n // other bytes are each value in base 128 with 8th bit set except for\n // the last byte for each value\n var value = 0;\n while(bytes.length() > 0) {\n b = bytes.getByte();\n value = value << 7;\n // not the last byte for the value\n if(b & 0x80) {\n value += b & 0x7F;\n } else {\n // last byte\n oid += '.' + (value + b);\n value = 0;\n }\n }\n\n return oid;\n};\n\n/**\n * Converts a UTCTime value to a date.\n *\n * Note: GeneralizedTime has 4 digits for the year and is used for X.509\n * dates past 2049. Parsing that structure hasn't been implemented yet.\n *\n * @param utc the UTCTime value to convert.\n *\n * @return the date.\n */\nasn1.utcTimeToDate = function(utc) {\n /* The following formats can be used:\n\n YYMMDDhhmmZ\n YYMMDDhhmm+hh'mm'\n YYMMDDhhmm-hh'mm'\n YYMMDDhhmmssZ\n YYMMDDhhmmss+hh'mm'\n YYMMDDhhmmss-hh'mm'\n\n Where:\n\n YY is the least significant two digits of the year\n MM is the month (01 to 12)\n DD is the day (01 to 31)\n hh is the hour (00 to 23)\n mm are the minutes (00 to 59)\n ss are the seconds (00 to 59)\n Z indicates that local time is GMT, + indicates that local time is\n later than GMT, and - indicates that local time is earlier than GMT\n hh' is the absolute value of the offset from GMT in hours\n mm' is the absolute value of the offset from GMT in minutes */\n var date = new Date();\n\n // if YY >= 50 use 19xx, if YY < 50 use 20xx\n var year = parseInt(utc.substr(0, 2), 10);\n year = (year >= 50) ? 1900 + year : 2000 + year;\n var MM = parseInt(utc.substr(2, 2), 10) - 1; // use 0-11 for month\n var DD = parseInt(utc.substr(4, 2), 10);\n var hh = parseInt(utc.substr(6, 2), 10);\n var mm = parseInt(utc.substr(8, 2), 10);\n var ss = 0;\n\n // not just YYMMDDhhmmZ\n if(utc.length > 11) {\n // get character after minutes\n var c = utc.charAt(10);\n var end = 10;\n\n // see if seconds are present\n if(c !== '+' && c !== '-') {\n // get seconds\n ss = parseInt(utc.substr(10, 2), 10);\n end += 2;\n }\n }\n\n // update date\n date.setUTCFullYear(year, MM, DD);\n date.setUTCHours(hh, mm, ss, 0);\n\n if(end) {\n // get +/- after end of time\n c = utc.charAt(end);\n if(c === '+' || c === '-') {\n // get hours+minutes offset\n var hhoffset = parseInt(utc.substr(end + 1, 2), 10);\n var mmoffset = parseInt(utc.substr(end + 4, 2), 10);\n\n // calculate offset in milliseconds\n var offset = hhoffset * 60 + mmoffset;\n offset *= 60000;\n\n // apply offset\n if(c === '+') {\n date.setTime(+date - offset);\n } else {\n date.setTime(+date + offset);\n }\n }\n }\n\n return date;\n};\n\n/**\n * Converts a GeneralizedTime value to a date.\n *\n * @param gentime the GeneralizedTime value to convert.\n *\n * @return the date.\n */\nasn1.generalizedTimeToDate = function(gentime) {\n /* The following formats can be used:\n\n YYYYMMDDHHMMSS\n YYYYMMDDHHMMSS.fff\n YYYYMMDDHHMMSSZ\n YYYYMMDDHHMMSS.fffZ\n YYYYMMDDHHMMSS+hh'mm'\n YYYYMMDDHHMMSS.fff+hh'mm'\n YYYYMMDDHHMMSS-hh'mm'\n YYYYMMDDHHMMSS.fff-hh'mm'\n\n Where:\n\n YYYY is the year\n MM is the month (01 to 12)\n DD is the day (01 to 31)\n hh is the hour (00 to 23)\n mm are the minutes (00 to 59)\n ss are the seconds (00 to 59)\n .fff is the second fraction, accurate to three decimal places\n Z indicates that local time is GMT, + indicates that local time is\n later than GMT, and - indicates that local time is earlier than GMT\n hh' is the absolute value of the offset from GMT in hours\n mm' is the absolute value of the offset from GMT in minutes */\n var date = new Date();\n\n var YYYY = parseInt(gentime.substr(0, 4), 10);\n var MM = parseInt(gentime.substr(4, 2), 10) - 1; // use 0-11 for month\n var DD = parseInt(gentime.substr(6, 2), 10);\n var hh = parseInt(gentime.substr(8, 2), 10);\n var mm = parseInt(gentime.substr(10, 2), 10);\n var ss = parseInt(gentime.substr(12, 2), 10);\n var fff = 0;\n var offset = 0;\n var isUTC = false;\n\n if(gentime.charAt(gentime.length - 1) === 'Z') {\n isUTC = true;\n }\n\n var end = gentime.length - 5, c = gentime.charAt(end);\n if(c === '+' || c === '-') {\n // get hours+minutes offset\n var hhoffset = parseInt(gentime.substr(end + 1, 2), 10);\n var mmoffset = parseInt(gentime.substr(end + 4, 2), 10);\n\n // calculate offset in milliseconds\n offset = hhoffset * 60 + mmoffset;\n offset *= 60000;\n\n // apply offset\n if(c === '+') {\n offset *= -1;\n }\n\n isUTC = true;\n }\n\n // check for second fraction\n if(gentime.charAt(14) === '.') {\n fff = parseFloat(gentime.substr(14), 10) * 1000;\n }\n\n if(isUTC) {\n date.setUTCFullYear(YYYY, MM, DD);\n date.setUTCHours(hh, mm, ss, fff);\n\n // apply offset\n date.setTime(+date + offset);\n } else {\n date.setFullYear(YYYY, MM, DD);\n date.setHours(hh, mm, ss, fff);\n }\n\n return date;\n};\n\n/**\n * Converts a date to a UTCTime value.\n *\n * Note: GeneralizedTime has 4 digits for the year and is used for X.509\n * dates past 2049. Converting to a GeneralizedTime hasn't been\n * implemented yet.\n *\n * @param date the date to convert.\n *\n * @return the UTCTime value.\n */\nasn1.dateToUtcTime = function(date) {\n // TODO: validate; currently assumes proper format\n if(typeof date === 'string') {\n return date;\n }\n\n var rval = '';\n\n // create format YYMMDDhhmmssZ\n var format = [];\n format.push(('' + date.getUTCFullYear()).substr(2));\n format.push('' + (date.getUTCMonth() + 1));\n format.push('' + date.getUTCDate());\n format.push('' + date.getUTCHours());\n format.push('' + date.getUTCMinutes());\n format.push('' + date.getUTCSeconds());\n\n // ensure 2 digits are used for each format entry\n for(var i = 0; i < format.length; ++i) {\n if(format[i].length < 2) {\n rval += '0';\n }\n rval += format[i];\n }\n rval += 'Z';\n\n return rval;\n};\n\n/**\n * Converts a date to a GeneralizedTime value.\n *\n * @param date the date to convert.\n *\n * @return the GeneralizedTime value as a string.\n */\nasn1.dateToGeneralizedTime = function(date) {\n // TODO: validate; currently assumes proper format\n if(typeof date === 'string') {\n return date;\n }\n\n var rval = '';\n\n // create format YYYYMMDDHHMMSSZ\n var format = [];\n format.push('' + date.getUTCFullYear());\n format.push('' + (date.getUTCMonth() + 1));\n format.push('' + date.getUTCDate());\n format.push('' + date.getUTCHours());\n format.push('' + date.getUTCMinutes());\n format.push('' + date.getUTCSeconds());\n\n // ensure 2 digits are used for each format entry\n for(var i = 0; i < format.length; ++i) {\n if(format[i].length < 2) {\n rval += '0';\n }\n rval += format[i];\n }\n rval += 'Z';\n\n return rval;\n};\n\n/**\n * Converts a javascript integer to a DER-encoded byte buffer to be used\n * as the value for an INTEGER type.\n *\n * @param x the integer.\n *\n * @return the byte buffer.\n */\nasn1.integerToDer = function(x) {\n var rval = forge.util.createBuffer();\n if(x >= -0x80 && x < 0x80) {\n return rval.putSignedInt(x, 8);\n }\n if(x >= -0x8000 && x < 0x8000) {\n return rval.putSignedInt(x, 16);\n }\n if(x >= -0x800000 && x < 0x800000) {\n return rval.putSignedInt(x, 24);\n }\n if(x >= -0x80000000 && x < 0x80000000) {\n return rval.putSignedInt(x, 32);\n }\n var error = new Error('Integer too large; max is 32-bits.');\n error.integer = x;\n throw error;\n};\n\n/**\n * Converts a DER-encoded byte buffer to a javascript integer. This is\n * typically used to decode the value of an INTEGER type.\n *\n * @param bytes the byte buffer.\n *\n * @return the integer.\n */\nasn1.derToInteger = function(bytes) {\n // wrap in buffer if needed\n if(typeof bytes === 'string') {\n bytes = forge.util.createBuffer(bytes);\n }\n\n var n = bytes.length() * 8;\n if(n > 32) {\n throw new Error('Integer too large; max is 32-bits.');\n }\n return bytes.getSignedInt(n);\n};\n\n/**\n * Validates that the given ASN.1 object is at least a super set of the\n * given ASN.1 structure. Only tag classes and types are checked. An\n * optional map may also be provided to capture ASN.1 values while the\n * structure is checked.\n *\n * To capture an ASN.1 value, set an object in the validator's 'capture'\n * parameter to the key to use in the capture map. To capture the full\n * ASN.1 object, specify 'captureAsn1'. To capture BIT STRING bytes, including\n * the leading unused bits counter byte, specify 'captureBitStringContents'.\n * To capture BIT STRING bytes, without the leading unused bits counter byte,\n * specify 'captureBitStringValue'.\n *\n * Objects in the validator may set a field 'optional' to true to indicate\n * that it isn't necessary to pass validation.\n *\n * @param obj the ASN.1 object to validate.\n * @param v the ASN.1 structure validator.\n * @param capture an optional map to capture values in.\n * @param errors an optional array for storing validation errors.\n *\n * @return true on success, false on failure.\n */\nasn1.validate = function(obj, v, capture, errors) {\n var rval = false;\n\n // ensure tag class and type are the same if specified\n if((obj.tagClass === v.tagClass || typeof(v.tagClass) === 'undefined') &&\n (obj.type === v.type || typeof(v.type) === 'undefined')) {\n // ensure constructed flag is the same if specified\n if(obj.constructed === v.constructed ||\n typeof(v.constructed) === 'undefined') {\n rval = true;\n\n // handle sub values\n if(v.value && forge.util.isArray(v.value)) {\n var j = 0;\n for(var i = 0; rval && i < v.value.length; ++i) {\n rval = v.value[i].optional || false;\n if(obj.value[j]) {\n rval = asn1.validate(obj.value[j], v.value[i], capture, errors);\n if(rval) {\n ++j;\n } else if(v.value[i].optional) {\n rval = true;\n }\n }\n if(!rval && errors) {\n errors.push(\n '[' + v.name + '] ' +\n 'Tag class \"' + v.tagClass + '\", type \"' +\n v.type + '\" expected value length \"' +\n v.value.length + '\", got \"' +\n obj.value.length + '\"');\n }\n }\n }\n\n if(rval && capture) {\n if(v.capture) {\n capture[v.capture] = obj.value;\n }\n if(v.captureAsn1) {\n capture[v.captureAsn1] = obj;\n }\n if(v.captureBitStringContents && 'bitStringContents' in obj) {\n capture[v.captureBitStringContents] = obj.bitStringContents;\n }\n if(v.captureBitStringValue && 'bitStringContents' in obj) {\n var value;\n if(obj.bitStringContents.length < 2) {\n capture[v.captureBitStringValue] = '';\n } else {\n // FIXME: support unused bits with data shifting\n var unused = obj.bitStringContents.charCodeAt(0);\n if(unused !== 0) {\n throw new Error(\n 'captureBitStringValue only supported for zero unused bits');\n }\n capture[v.captureBitStringValue] = obj.bitStringContents.slice(1);\n }\n }\n }\n } else if(errors) {\n errors.push(\n '[' + v.name + '] ' +\n 'Expected constructed \"' + v.constructed + '\", got \"' +\n obj.constructed + '\"');\n }\n } else if(errors) {\n if(obj.tagClass !== v.tagClass) {\n errors.push(\n '[' + v.name + '] ' +\n 'Expected tag class \"' + v.tagClass + '\", got \"' +\n obj.tagClass + '\"');\n }\n if(obj.type !== v.type) {\n errors.push(\n '[' + v.name + '] ' +\n 'Expected type \"' + v.type + '\", got \"' + obj.type + '\"');\n }\n }\n return rval;\n};\n\n// regex for testing for non-latin characters\nvar _nonLatinRegex = /[^\\\\u0000-\\\\u00ff]/;\n\n/**\n * Pretty prints an ASN.1 object to a string.\n *\n * @param obj the object to write out.\n * @param level the level in the tree.\n * @param indentation the indentation to use.\n *\n * @return the string.\n */\nasn1.prettyPrint = function(obj, level, indentation) {\n var rval = '';\n\n // set default level and indentation\n level = level || 0;\n indentation = indentation || 2;\n\n // start new line for deep levels\n if(level > 0) {\n rval += '\\n';\n }\n\n // create indent\n var indent = '';\n for(var i = 0; i < level * indentation; ++i) {\n indent += ' ';\n }\n\n // print class:type\n rval += indent + 'Tag: ';\n switch(obj.tagClass) {\n case asn1.Class.UNIVERSAL:\n rval += 'Universal:';\n break;\n case asn1.Class.APPLICATION:\n rval += 'Application:';\n break;\n case asn1.Class.CONTEXT_SPECIFIC:\n rval += 'Context-Specific:';\n break;\n case asn1.Class.PRIVATE:\n rval += 'Private:';\n break;\n }\n\n if(obj.tagClass === asn1.Class.UNIVERSAL) {\n rval += obj.type;\n\n // known types\n switch(obj.type) {\n case asn1.Type.NONE:\n rval += ' (None)';\n break;\n case asn1.Type.BOOLEAN:\n rval += ' (Boolean)';\n break;\n case asn1.Type.INTEGER:\n rval += ' (Integer)';\n break;\n case asn1.Type.BITSTRING:\n rval += ' (Bit string)';\n break;\n case asn1.Type.OCTETSTRING:\n rval += ' (Octet string)';\n break;\n case asn1.Type.NULL:\n rval += ' (Null)';\n break;\n case asn1.Type.OID:\n rval += ' (Object Identifier)';\n break;\n case asn1.Type.ODESC:\n rval += ' (Object Descriptor)';\n break;\n case asn1.Type.EXTERNAL:\n rval += ' (External or Instance of)';\n break;\n case asn1.Type.REAL:\n rval += ' (Real)';\n break;\n case asn1.Type.ENUMERATED:\n rval += ' (Enumerated)';\n break;\n case asn1.Type.EMBEDDED:\n rval += ' (Embedded PDV)';\n break;\n case asn1.Type.UTF8:\n rval += ' (UTF8)';\n break;\n case asn1.Type.ROID:\n rval += ' (Relative Object Identifier)';\n break;\n case asn1.Type.SEQUENCE:\n rval += ' (Sequence)';\n break;\n case asn1.Type.SET:\n rval += ' (Set)';\n break;\n case asn1.Type.PRINTABLESTRING:\n rval += ' (Printable String)';\n break;\n case asn1.Type.IA5String:\n rval += ' (IA5String (ASCII))';\n break;\n case asn1.Type.UTCTIME:\n rval += ' (UTC time)';\n break;\n case asn1.Type.GENERALIZEDTIME:\n rval += ' (Generalized time)';\n break;\n case asn1.Type.BMPSTRING:\n rval += ' (BMP String)';\n break;\n }\n } else {\n rval += obj.type;\n }\n\n rval += '\\n';\n rval += indent + 'Constructed: ' + obj.constructed + '\\n';\n\n if(obj.composed) {\n var subvalues = 0;\n var sub = '';\n for(var i = 0; i < obj.value.length; ++i) {\n if(obj.value[i] !== undefined) {\n subvalues += 1;\n sub += asn1.prettyPrint(obj.value[i], level + 1, indentation);\n if((i + 1) < obj.value.length) {\n sub += ',';\n }\n }\n }\n rval += indent + 'Sub values: ' + subvalues + sub;\n } else {\n rval += indent + 'Value: ';\n if(obj.type === asn1.Type.OID) {\n var oid = asn1.derToOid(obj.value);\n rval += oid;\n if(forge.pki && forge.pki.oids) {\n if(oid in forge.pki.oids) {\n rval += ' (' + forge.pki.oids[oid] + ') ';\n }\n }\n }\n if(obj.type === asn1.Type.INTEGER) {\n try {\n rval += asn1.derToInteger(obj.value);\n } catch(ex) {\n rval += '0x' + forge.util.bytesToHex(obj.value);\n }\n } else if(obj.type === asn1.Type.BITSTRING) {\n // TODO: shift bits as needed to display without padding\n if(obj.value.length > 1) {\n // remove unused bits field\n rval += '0x' + forge.util.bytesToHex(obj.value.slice(1));\n } else {\n rval += '(none)';\n }\n // show unused bit count\n if(obj.value.length > 0) {\n var unused = obj.value.charCodeAt(0);\n if(unused == 1) {\n rval += ' (1 unused bit shown)';\n } else if(unused > 1) {\n rval += ' (' + unused + ' unused bits shown)';\n }\n }\n } else if(obj.type === asn1.Type.OCTETSTRING) {\n if(!_nonLatinRegex.test(obj.value)) {\n rval += '(' + obj.value + ') ';\n }\n rval += '0x' + forge.util.bytesToHex(obj.value);\n } else if(obj.type === asn1.Type.UTF8) {\n rval += forge.util.decodeUtf8(obj.value);\n } else if(obj.type === asn1.Type.PRINTABLESTRING ||\n obj.type === asn1.Type.IA5String) {\n rval += obj.value;\n } else if(_nonLatinRegex.test(obj.value)) {\n rval += '0x' + forge.util.bytesToHex(obj.value);\n } else if(obj.value.length === 0) {\n rval += '[null]';\n } else {\n rval += obj.value;\n }\n }\n\n return rval;\n};\n","/**\n * Node.js module for Forge.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2016 Digital Bazaar, Inc.\n */\nmodule.exports = {\n // default options\n options: {\n usePureJavaScript: false\n }\n};\n","/**\n * Utility functions for web applications.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2018 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nvar baseN = require('./baseN');\n\n/* Utilities API */\nvar util = module.exports = forge.util = forge.util || {};\n\n// define setImmediate and nextTick\n(function() {\n // use native nextTick (unless we're in webpack)\n // webpack (or better node-libs-browser polyfill) sets process.browser.\n // this way we can detect webpack properly\n if(typeof process !== 'undefined' && process.nextTick && !process.browser) {\n util.nextTick = process.nextTick;\n if(typeof setImmediate === 'function') {\n util.setImmediate = setImmediate;\n } else {\n // polyfill setImmediate with nextTick, older versions of node\n // (those w/o setImmediate) won't totally starve IO\n util.setImmediate = util.nextTick;\n }\n return;\n }\n\n // polyfill nextTick with native setImmediate\n if(typeof setImmediate === 'function') {\n util.setImmediate = function() { return setImmediate.apply(undefined, arguments); };\n util.nextTick = function(callback) {\n return setImmediate(callback);\n };\n return;\n }\n\n /* Note: A polyfill upgrade pattern is used here to allow combining\n polyfills. For example, MutationObserver is fast, but blocks UI updates,\n so it needs to allow UI updates periodically, so it falls back on\n postMessage or setTimeout. */\n\n // polyfill with setTimeout\n util.setImmediate = function(callback) {\n setTimeout(callback, 0);\n };\n\n // upgrade polyfill to use postMessage\n if(typeof window !== 'undefined' &&\n typeof window.postMessage === 'function') {\n var msg = 'forge.setImmediate';\n var callbacks = [];\n util.setImmediate = function(callback) {\n callbacks.push(callback);\n // only send message when one hasn't been sent in\n // the current turn of the event loop\n if(callbacks.length === 1) {\n window.postMessage(msg, '*');\n }\n };\n function handler(event) {\n if(event.source === window && event.data === msg) {\n event.stopPropagation();\n var copy = callbacks.slice();\n callbacks.length = 0;\n copy.forEach(function(callback) {\n callback();\n });\n }\n }\n window.addEventListener('message', handler, true);\n }\n\n // upgrade polyfill to use MutationObserver\n if(typeof MutationObserver !== 'undefined') {\n // polyfill with MutationObserver\n var now = Date.now();\n var attr = true;\n var div = document.createElement('div');\n var callbacks = [];\n new MutationObserver(function() {\n var copy = callbacks.slice();\n callbacks.length = 0;\n copy.forEach(function(callback) {\n callback();\n });\n }).observe(div, {attributes: true});\n var oldSetImmediate = util.setImmediate;\n util.setImmediate = function(callback) {\n if(Date.now() - now > 15) {\n now = Date.now();\n oldSetImmediate(callback);\n } else {\n callbacks.push(callback);\n // only trigger observer when it hasn't been triggered in\n // the current turn of the event loop\n if(callbacks.length === 1) {\n div.setAttribute('a', attr = !attr);\n }\n }\n };\n }\n\n util.nextTick = util.setImmediate;\n})();\n\n// check if running under Node.js\nutil.isNodejs =\n typeof process !== 'undefined' && process.versions && process.versions.node;\n\n\n// 'self' will also work in Web Workers (instance of WorkerGlobalScope) while\n// it will point to `window` in the main thread.\n// To remain compatible with older browsers, we fall back to 'window' if 'self'\n// is not available.\nutil.globalScope = (function() {\n if(util.isNodejs) {\n return global;\n }\n\n return typeof self === 'undefined' ? window : self;\n})();\n\n// define isArray\nutil.isArray = Array.isArray || function(x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n};\n\n// define isArrayBuffer\nutil.isArrayBuffer = function(x) {\n return typeof ArrayBuffer !== 'undefined' && x instanceof ArrayBuffer;\n};\n\n// define isArrayBufferView\nutil.isArrayBufferView = function(x) {\n return x && util.isArrayBuffer(x.buffer) && x.byteLength !== undefined;\n};\n\n/**\n * Ensure a bits param is 8, 16, 24, or 32. Used to validate input for\n * algorithms where bit manipulation, JavaScript limitations, and/or algorithm\n * design only allow for byte operations of a limited size.\n *\n * @param n number of bits.\n *\n * Throw Error if n invalid.\n */\nfunction _checkBitsParam(n) {\n if(!(n === 8 || n === 16 || n === 24 || n === 32)) {\n throw new Error('Only 8, 16, 24, or 32 bits supported: ' + n);\n }\n}\n\n// TODO: set ByteBuffer to best available backing\nutil.ByteBuffer = ByteStringBuffer;\n\n/** Buffer w/BinaryString backing */\n\n/**\n * Constructor for a binary string backed byte buffer.\n *\n * @param [b] the bytes to wrap (either encoded as string, one byte per\n * character, or as an ArrayBuffer or Typed Array).\n */\nfunction ByteStringBuffer(b) {\n // TODO: update to match DataBuffer API\n\n // the data in this buffer\n this.data = '';\n // the pointer for reading from this buffer\n this.read = 0;\n\n if(typeof b === 'string') {\n this.data = b;\n } else if(util.isArrayBuffer(b) || util.isArrayBufferView(b)) {\n if(typeof Buffer !== 'undefined' && b instanceof Buffer) {\n this.data = b.toString('binary');\n } else {\n // convert native buffer to forge buffer\n // FIXME: support native buffers internally instead\n var arr = new Uint8Array(b);\n try {\n this.data = String.fromCharCode.apply(null, arr);\n } catch(e) {\n for(var i = 0; i < arr.length; ++i) {\n this.putByte(arr[i]);\n }\n }\n }\n } else if(b instanceof ByteStringBuffer ||\n (typeof b === 'object' && typeof b.data === 'string' &&\n typeof b.read === 'number')) {\n // copy existing buffer\n this.data = b.data;\n this.read = b.read;\n }\n\n // used for v8 optimization\n this._constructedStringLength = 0;\n}\nutil.ByteStringBuffer = ByteStringBuffer;\n\n/* Note: This is an optimization for V8-based browsers. When V8 concatenates\n a string, the strings are only joined logically using a \"cons string\" or\n \"constructed/concatenated string\". These containers keep references to one\n another and can result in very large memory usage. For example, if a 2MB\n string is constructed by concatenating 4 bytes together at a time, the\n memory usage will be ~44MB; so ~22x increase. The strings are only joined\n together when an operation requiring their joining takes place, such as\n substr(). This function is called when adding data to this buffer to ensure\n these types of strings are periodically joined to reduce the memory\n footprint. */\nvar _MAX_CONSTRUCTED_STRING_LENGTH = 4096;\nutil.ByteStringBuffer.prototype._optimizeConstructedString = function(x) {\n this._constructedStringLength += x;\n if(this._constructedStringLength > _MAX_CONSTRUCTED_STRING_LENGTH) {\n // this substr() should cause the constructed string to join\n this.data.substr(0, 1);\n this._constructedStringLength = 0;\n }\n};\n\n/**\n * Gets the number of bytes in this buffer.\n *\n * @return the number of bytes in this buffer.\n */\nutil.ByteStringBuffer.prototype.length = function() {\n return this.data.length - this.read;\n};\n\n/**\n * Gets whether or not this buffer is empty.\n *\n * @return true if this buffer is empty, false if not.\n */\nutil.ByteStringBuffer.prototype.isEmpty = function() {\n return this.length() <= 0;\n};\n\n/**\n * Puts a byte in this buffer.\n *\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putByte = function(b) {\n return this.putBytes(String.fromCharCode(b));\n};\n\n/**\n * Puts a byte in this buffer N times.\n *\n * @param b the byte to put.\n * @param n the number of bytes of value b to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.fillWithByte = function(b, n) {\n b = String.fromCharCode(b);\n var d = this.data;\n while(n > 0) {\n if(n & 1) {\n d += b;\n }\n n >>>= 1;\n if(n > 0) {\n b += b;\n }\n }\n this.data = d;\n this._optimizeConstructedString(n);\n return this;\n};\n\n/**\n * Puts bytes in this buffer.\n *\n * @param bytes the bytes (as a binary encoded string) to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putBytes = function(bytes) {\n this.data += bytes;\n this._optimizeConstructedString(bytes.length);\n return this;\n};\n\n/**\n * Puts a UTF-16 encoded string into this buffer.\n *\n * @param str the string to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putString = function(str) {\n return this.putBytes(util.encodeUtf8(str));\n};\n\n/**\n * Puts a 16-bit integer in this buffer in big-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt16 = function(i) {\n return this.putBytes(\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n/**\n * Puts a 24-bit integer in this buffer in big-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt24 = function(i) {\n return this.putBytes(\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n/**\n * Puts a 32-bit integer in this buffer in big-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt32 = function(i) {\n return this.putBytes(\n String.fromCharCode(i >> 24 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n/**\n * Puts a 16-bit integer in this buffer in little-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt16Le = function(i) {\n return this.putBytes(\n String.fromCharCode(i & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF));\n};\n\n/**\n * Puts a 24-bit integer in this buffer in little-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt24Le = function(i) {\n return this.putBytes(\n String.fromCharCode(i & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF));\n};\n\n/**\n * Puts a 32-bit integer in this buffer in little-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt32Le = function(i) {\n return this.putBytes(\n String.fromCharCode(i & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 24 & 0xFF));\n};\n\n/**\n * Puts an n-bit integer in this buffer in big-endian order.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt = function(i, n) {\n _checkBitsParam(n);\n var bytes = '';\n do {\n n -= 8;\n bytes += String.fromCharCode((i >> n) & 0xFF);\n } while(n > 0);\n return this.putBytes(bytes);\n};\n\n/**\n * Puts a signed n-bit integer in this buffer in big-endian order. Two's\n * complement representation is used.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putSignedInt = function(i, n) {\n // putInt checks n\n if(i < 0) {\n i += 2 << (n - 1);\n }\n return this.putInt(i, n);\n};\n\n/**\n * Puts the given buffer into this buffer.\n *\n * @param buffer the buffer to put into this one.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putBuffer = function(buffer) {\n return this.putBytes(buffer.getBytes());\n};\n\n/**\n * Gets a byte from this buffer and advances the read pointer by 1.\n *\n * @return the byte.\n */\nutil.ByteStringBuffer.prototype.getByte = function() {\n return this.data.charCodeAt(this.read++);\n};\n\n/**\n * Gets a uint16 from this buffer in big-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.ByteStringBuffer.prototype.getInt16 = function() {\n var rval = (\n this.data.charCodeAt(this.read) << 8 ^\n this.data.charCodeAt(this.read + 1));\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in big-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.ByteStringBuffer.prototype.getInt24 = function() {\n var rval = (\n this.data.charCodeAt(this.read) << 16 ^\n this.data.charCodeAt(this.read + 1) << 8 ^\n this.data.charCodeAt(this.read + 2));\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in big-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.ByteStringBuffer.prototype.getInt32 = function() {\n var rval = (\n this.data.charCodeAt(this.read) << 24 ^\n this.data.charCodeAt(this.read + 1) << 16 ^\n this.data.charCodeAt(this.read + 2) << 8 ^\n this.data.charCodeAt(this.read + 3));\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets a uint16 from this buffer in little-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.ByteStringBuffer.prototype.getInt16Le = function() {\n var rval = (\n this.data.charCodeAt(this.read) ^\n this.data.charCodeAt(this.read + 1) << 8);\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in little-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.ByteStringBuffer.prototype.getInt24Le = function() {\n var rval = (\n this.data.charCodeAt(this.read) ^\n this.data.charCodeAt(this.read + 1) << 8 ^\n this.data.charCodeAt(this.read + 2) << 16);\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in little-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.ByteStringBuffer.prototype.getInt32Le = function() {\n var rval = (\n this.data.charCodeAt(this.read) ^\n this.data.charCodeAt(this.read + 1) << 8 ^\n this.data.charCodeAt(this.read + 2) << 16 ^\n this.data.charCodeAt(this.read + 3) << 24);\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets an n-bit integer from this buffer in big-endian order and advances the\n * read pointer by ceil(n/8).\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.ByteStringBuffer.prototype.getInt = function(n) {\n _checkBitsParam(n);\n var rval = 0;\n do {\n // TODO: Use (rval * 0x100) if adding support for 33 to 53 bits.\n rval = (rval << 8) + this.data.charCodeAt(this.read++);\n n -= 8;\n } while(n > 0);\n return rval;\n};\n\n/**\n * Gets a signed n-bit integer from this buffer in big-endian order, using\n * two's complement, and advances the read pointer by n/8.\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.ByteStringBuffer.prototype.getSignedInt = function(n) {\n // getInt checks n\n var x = this.getInt(n);\n var max = 2 << (n - 2);\n if(x >= max) {\n x -= max << 1;\n }\n return x;\n};\n\n/**\n * Reads bytes out as a binary encoded string and clears them from the\n * buffer. Note that the resulting string is binary encoded (in node.js this\n * encoding is referred to as `binary`, it is *not* `utf8`).\n *\n * @param count the number of bytes to read, undefined or null for all.\n *\n * @return a binary encoded string of bytes.\n */\nutil.ByteStringBuffer.prototype.getBytes = function(count) {\n var rval;\n if(count) {\n // read count bytes\n count = Math.min(this.length(), count);\n rval = this.data.slice(this.read, this.read + count);\n this.read += count;\n } else if(count === 0) {\n rval = '';\n } else {\n // read all bytes, optimize to only copy when needed\n rval = (this.read === 0) ? this.data : this.data.slice(this.read);\n this.clear();\n }\n return rval;\n};\n\n/**\n * Gets a binary encoded string of the bytes from this buffer without\n * modifying the read pointer.\n *\n * @param count the number of bytes to get, omit to get all.\n *\n * @return a string full of binary encoded characters.\n */\nutil.ByteStringBuffer.prototype.bytes = function(count) {\n return (typeof(count) === 'undefined' ?\n this.data.slice(this.read) :\n this.data.slice(this.read, this.read + count));\n};\n\n/**\n * Gets a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n *\n * @return the byte.\n */\nutil.ByteStringBuffer.prototype.at = function(i) {\n return this.data.charCodeAt(this.read + i);\n};\n\n/**\n * Puts a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.setAt = function(i, b) {\n this.data = this.data.substr(0, this.read + i) +\n String.fromCharCode(b) +\n this.data.substr(this.read + i + 1);\n return this;\n};\n\n/**\n * Gets the last byte without modifying the read pointer.\n *\n * @return the last byte.\n */\nutil.ByteStringBuffer.prototype.last = function() {\n return this.data.charCodeAt(this.data.length - 1);\n};\n\n/**\n * Creates a copy of this buffer.\n *\n * @return the copy.\n */\nutil.ByteStringBuffer.prototype.copy = function() {\n var c = util.createBuffer(this.data);\n c.read = this.read;\n return c;\n};\n\n/**\n * Compacts this buffer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.compact = function() {\n if(this.read > 0) {\n this.data = this.data.slice(this.read);\n this.read = 0;\n }\n return this;\n};\n\n/**\n * Clears this buffer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.clear = function() {\n this.data = '';\n this.read = 0;\n return this;\n};\n\n/**\n * Shortens this buffer by triming bytes off of the end of this buffer.\n *\n * @param count the number of bytes to trim off.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.truncate = function(count) {\n var len = Math.max(0, this.length() - count);\n this.data = this.data.substr(this.read, len);\n this.read = 0;\n return this;\n};\n\n/**\n * Converts this buffer to a hexadecimal string.\n *\n * @return a hexadecimal string.\n */\nutil.ByteStringBuffer.prototype.toHex = function() {\n var rval = '';\n for(var i = this.read; i < this.data.length; ++i) {\n var b = this.data.charCodeAt(i);\n if(b < 16) {\n rval += '0';\n }\n rval += b.toString(16);\n }\n return rval;\n};\n\n/**\n * Converts this buffer to a UTF-16 string (standard JavaScript string).\n *\n * @return a UTF-16 string.\n */\nutil.ByteStringBuffer.prototype.toString = function() {\n return util.decodeUtf8(this.bytes());\n};\n\n/** End Buffer w/BinaryString backing */\n\n/** Buffer w/UInt8Array backing */\n\n/**\n * FIXME: Experimental. Do not use yet.\n *\n * Constructor for an ArrayBuffer-backed byte buffer.\n *\n * The buffer may be constructed from a string, an ArrayBuffer, DataView, or a\n * TypedArray.\n *\n * If a string is given, its encoding should be provided as an option,\n * otherwise it will default to 'binary'. A 'binary' string is encoded such\n * that each character is one byte in length and size.\n *\n * If an ArrayBuffer, DataView, or TypedArray is given, it will be used\n * *directly* without any copying. Note that, if a write to the buffer requires\n * more space, the buffer will allocate a new backing ArrayBuffer to\n * accommodate. The starting read and write offsets for the buffer may be\n * given as options.\n *\n * @param [b] the initial bytes for this buffer.\n * @param options the options to use:\n * [readOffset] the starting read offset to use (default: 0).\n * [writeOffset] the starting write offset to use (default: the\n * length of the first parameter).\n * [growSize] the minimum amount, in bytes, to grow the buffer by to\n * accommodate writes (default: 1024).\n * [encoding] the encoding ('binary', 'utf8', 'utf16', 'hex') for the\n * first parameter, if it is a string (default: 'binary').\n */\nfunction DataBuffer(b, options) {\n // default options\n options = options || {};\n\n // pointers for read from/write to buffer\n this.read = options.readOffset || 0;\n this.growSize = options.growSize || 1024;\n\n var isArrayBuffer = util.isArrayBuffer(b);\n var isArrayBufferView = util.isArrayBufferView(b);\n if(isArrayBuffer || isArrayBufferView) {\n // use ArrayBuffer directly\n if(isArrayBuffer) {\n this.data = new DataView(b);\n } else {\n // TODO: adjust read/write offset based on the type of view\n // or specify that this must be done in the options ... that the\n // offsets are byte-based\n this.data = new DataView(b.buffer, b.byteOffset, b.byteLength);\n }\n this.write = ('writeOffset' in options ?\n options.writeOffset : this.data.byteLength);\n return;\n }\n\n // initialize to empty array buffer and add any given bytes using putBytes\n this.data = new DataView(new ArrayBuffer(0));\n this.write = 0;\n\n if(b !== null && b !== undefined) {\n this.putBytes(b);\n }\n\n if('writeOffset' in options) {\n this.write = options.writeOffset;\n }\n}\nutil.DataBuffer = DataBuffer;\n\n/**\n * Gets the number of bytes in this buffer.\n *\n * @return the number of bytes in this buffer.\n */\nutil.DataBuffer.prototype.length = function() {\n return this.write - this.read;\n};\n\n/**\n * Gets whether or not this buffer is empty.\n *\n * @return true if this buffer is empty, false if not.\n */\nutil.DataBuffer.prototype.isEmpty = function() {\n return this.length() <= 0;\n};\n\n/**\n * Ensures this buffer has enough empty space to accommodate the given number\n * of bytes. An optional parameter may be given that indicates a minimum\n * amount to grow the buffer if necessary. If the parameter is not given,\n * the buffer will be grown by some previously-specified default amount\n * or heuristic.\n *\n * @param amount the number of bytes to accommodate.\n * @param [growSize] the minimum amount, in bytes, to grow the buffer by if\n * necessary.\n */\nutil.DataBuffer.prototype.accommodate = function(amount, growSize) {\n if(this.length() >= amount) {\n return this;\n }\n growSize = Math.max(growSize || this.growSize, amount);\n\n // grow buffer\n var src = new Uint8Array(\n this.data.buffer, this.data.byteOffset, this.data.byteLength);\n var dst = new Uint8Array(this.length() + growSize);\n dst.set(src);\n this.data = new DataView(dst.buffer);\n\n return this;\n};\n\n/**\n * Puts a byte in this buffer.\n *\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putByte = function(b) {\n this.accommodate(1);\n this.data.setUint8(this.write++, b);\n return this;\n};\n\n/**\n * Puts a byte in this buffer N times.\n *\n * @param b the byte to put.\n * @param n the number of bytes of value b to put.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.fillWithByte = function(b, n) {\n this.accommodate(n);\n for(var i = 0; i < n; ++i) {\n this.data.setUint8(b);\n }\n return this;\n};\n\n/**\n * Puts bytes in this buffer. The bytes may be given as a string, an\n * ArrayBuffer, a DataView, or a TypedArray.\n *\n * @param bytes the bytes to put.\n * @param [encoding] the encoding for the first parameter ('binary', 'utf8',\n * 'utf16', 'hex'), if it is a string (default: 'binary').\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putBytes = function(bytes, encoding) {\n if(util.isArrayBufferView(bytes)) {\n var src = new Uint8Array(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n var len = src.byteLength - src.byteOffset;\n this.accommodate(len);\n var dst = new Uint8Array(this.data.buffer, this.write);\n dst.set(src);\n this.write += len;\n return this;\n }\n\n if(util.isArrayBuffer(bytes)) {\n var src = new Uint8Array(bytes);\n this.accommodate(src.byteLength);\n var dst = new Uint8Array(this.data.buffer);\n dst.set(src, this.write);\n this.write += src.byteLength;\n return this;\n }\n\n // bytes is a util.DataBuffer or equivalent\n if(bytes instanceof util.DataBuffer ||\n (typeof bytes === 'object' &&\n typeof bytes.read === 'number' && typeof bytes.write === 'number' &&\n util.isArrayBufferView(bytes.data))) {\n var src = new Uint8Array(bytes.data.byteLength, bytes.read, bytes.length());\n this.accommodate(src.byteLength);\n var dst = new Uint8Array(bytes.data.byteLength, this.write);\n dst.set(src);\n this.write += src.byteLength;\n return this;\n }\n\n if(bytes instanceof util.ByteStringBuffer) {\n // copy binary string and process as the same as a string parameter below\n bytes = bytes.data;\n encoding = 'binary';\n }\n\n // string conversion\n encoding = encoding || 'binary';\n if(typeof bytes === 'string') {\n var view;\n\n // decode from string\n if(encoding === 'hex') {\n this.accommodate(Math.ceil(bytes.length / 2));\n view = new Uint8Array(this.data.buffer, this.write);\n this.write += util.binary.hex.decode(bytes, view, this.write);\n return this;\n }\n if(encoding === 'base64') {\n this.accommodate(Math.ceil(bytes.length / 4) * 3);\n view = new Uint8Array(this.data.buffer, this.write);\n this.write += util.binary.base64.decode(bytes, view, this.write);\n return this;\n }\n\n // encode text as UTF-8 bytes\n if(encoding === 'utf8') {\n // encode as UTF-8 then decode string as raw binary\n bytes = util.encodeUtf8(bytes);\n encoding = 'binary';\n }\n\n // decode string as raw binary\n if(encoding === 'binary' || encoding === 'raw') {\n // one byte per character\n this.accommodate(bytes.length);\n view = new Uint8Array(this.data.buffer, this.write);\n this.write += util.binary.raw.decode(view);\n return this;\n }\n\n // encode text as UTF-16 bytes\n if(encoding === 'utf16') {\n // two bytes per character\n this.accommodate(bytes.length * 2);\n view = new Uint16Array(this.data.buffer, this.write);\n this.write += util.text.utf16.encode(view);\n return this;\n }\n\n throw new Error('Invalid encoding: ' + encoding);\n }\n\n throw Error('Invalid parameter: ' + bytes);\n};\n\n/**\n * Puts the given buffer into this buffer.\n *\n * @param buffer the buffer to put into this one.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putBuffer = function(buffer) {\n this.putBytes(buffer);\n buffer.clear();\n return this;\n};\n\n/**\n * Puts a string into this buffer.\n *\n * @param str the string to put.\n * @param [encoding] the encoding for the string (default: 'utf16').\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putString = function(str) {\n return this.putBytes(str, 'utf16');\n};\n\n/**\n * Puts a 16-bit integer in this buffer in big-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt16 = function(i) {\n this.accommodate(2);\n this.data.setInt16(this.write, i);\n this.write += 2;\n return this;\n};\n\n/**\n * Puts a 24-bit integer in this buffer in big-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt24 = function(i) {\n this.accommodate(3);\n this.data.setInt16(this.write, i >> 8 & 0xFFFF);\n this.data.setInt8(this.write, i >> 16 & 0xFF);\n this.write += 3;\n return this;\n};\n\n/**\n * Puts a 32-bit integer in this buffer in big-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt32 = function(i) {\n this.accommodate(4);\n this.data.setInt32(this.write, i);\n this.write += 4;\n return this;\n};\n\n/**\n * Puts a 16-bit integer in this buffer in little-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt16Le = function(i) {\n this.accommodate(2);\n this.data.setInt16(this.write, i, true);\n this.write += 2;\n return this;\n};\n\n/**\n * Puts a 24-bit integer in this buffer in little-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt24Le = function(i) {\n this.accommodate(3);\n this.data.setInt8(this.write, i >> 16 & 0xFF);\n this.data.setInt16(this.write, i >> 8 & 0xFFFF, true);\n this.write += 3;\n return this;\n};\n\n/**\n * Puts a 32-bit integer in this buffer in little-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt32Le = function(i) {\n this.accommodate(4);\n this.data.setInt32(this.write, i, true);\n this.write += 4;\n return this;\n};\n\n/**\n * Puts an n-bit integer in this buffer in big-endian order.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt = function(i, n) {\n _checkBitsParam(n);\n this.accommodate(n / 8);\n do {\n n -= 8;\n this.data.setInt8(this.write++, (i >> n) & 0xFF);\n } while(n > 0);\n return this;\n};\n\n/**\n * Puts a signed n-bit integer in this buffer in big-endian order. Two's\n * complement representation is used.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putSignedInt = function(i, n) {\n _checkBitsParam(n);\n this.accommodate(n / 8);\n if(i < 0) {\n i += 2 << (n - 1);\n }\n return this.putInt(i, n);\n};\n\n/**\n * Gets a byte from this buffer and advances the read pointer by 1.\n *\n * @return the byte.\n */\nutil.DataBuffer.prototype.getByte = function() {\n return this.data.getInt8(this.read++);\n};\n\n/**\n * Gets a uint16 from this buffer in big-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.DataBuffer.prototype.getInt16 = function() {\n var rval = this.data.getInt16(this.read);\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in big-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.DataBuffer.prototype.getInt24 = function() {\n var rval = (\n this.data.getInt16(this.read) << 8 ^\n this.data.getInt8(this.read + 2));\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in big-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.DataBuffer.prototype.getInt32 = function() {\n var rval = this.data.getInt32(this.read);\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets a uint16 from this buffer in little-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.DataBuffer.prototype.getInt16Le = function() {\n var rval = this.data.getInt16(this.read, true);\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in little-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.DataBuffer.prototype.getInt24Le = function() {\n var rval = (\n this.data.getInt8(this.read) ^\n this.data.getInt16(this.read + 1, true) << 8);\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in little-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.DataBuffer.prototype.getInt32Le = function() {\n var rval = this.data.getInt32(this.read, true);\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets an n-bit integer from this buffer in big-endian order and advances the\n * read pointer by n/8.\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.DataBuffer.prototype.getInt = function(n) {\n _checkBitsParam(n);\n var rval = 0;\n do {\n // TODO: Use (rval * 0x100) if adding support for 33 to 53 bits.\n rval = (rval << 8) + this.data.getInt8(this.read++);\n n -= 8;\n } while(n > 0);\n return rval;\n};\n\n/**\n * Gets a signed n-bit integer from this buffer in big-endian order, using\n * two's complement, and advances the read pointer by n/8.\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.DataBuffer.prototype.getSignedInt = function(n) {\n // getInt checks n\n var x = this.getInt(n);\n var max = 2 << (n - 2);\n if(x >= max) {\n x -= max << 1;\n }\n return x;\n};\n\n/**\n * Reads bytes out as a binary encoded string and clears them from the\n * buffer.\n *\n * @param count the number of bytes to read, undefined or null for all.\n *\n * @return a binary encoded string of bytes.\n */\nutil.DataBuffer.prototype.getBytes = function(count) {\n // TODO: deprecate this method, it is poorly named and\n // this.toString('binary') replaces it\n // add a toTypedArray()/toArrayBuffer() function\n var rval;\n if(count) {\n // read count bytes\n count = Math.min(this.length(), count);\n rval = this.data.slice(this.read, this.read + count);\n this.read += count;\n } else if(count === 0) {\n rval = '';\n } else {\n // read all bytes, optimize to only copy when needed\n rval = (this.read === 0) ? this.data : this.data.slice(this.read);\n this.clear();\n }\n return rval;\n};\n\n/**\n * Gets a binary encoded string of the bytes from this buffer without\n * modifying the read pointer.\n *\n * @param count the number of bytes to get, omit to get all.\n *\n * @return a string full of binary encoded characters.\n */\nutil.DataBuffer.prototype.bytes = function(count) {\n // TODO: deprecate this method, it is poorly named, add \"getString()\"\n return (typeof(count) === 'undefined' ?\n this.data.slice(this.read) :\n this.data.slice(this.read, this.read + count));\n};\n\n/**\n * Gets a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n *\n * @return the byte.\n */\nutil.DataBuffer.prototype.at = function(i) {\n return this.data.getUint8(this.read + i);\n};\n\n/**\n * Puts a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.setAt = function(i, b) {\n this.data.setUint8(i, b);\n return this;\n};\n\n/**\n * Gets the last byte without modifying the read pointer.\n *\n * @return the last byte.\n */\nutil.DataBuffer.prototype.last = function() {\n return this.data.getUint8(this.write - 1);\n};\n\n/**\n * Creates a copy of this buffer.\n *\n * @return the copy.\n */\nutil.DataBuffer.prototype.copy = function() {\n return new util.DataBuffer(this);\n};\n\n/**\n * Compacts this buffer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.compact = function() {\n if(this.read > 0) {\n var src = new Uint8Array(this.data.buffer, this.read);\n var dst = new Uint8Array(src.byteLength);\n dst.set(src);\n this.data = new DataView(dst);\n this.write -= this.read;\n this.read = 0;\n }\n return this;\n};\n\n/**\n * Clears this buffer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.clear = function() {\n this.data = new DataView(new ArrayBuffer(0));\n this.read = this.write = 0;\n return this;\n};\n\n/**\n * Shortens this buffer by triming bytes off of the end of this buffer.\n *\n * @param count the number of bytes to trim off.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.truncate = function(count) {\n this.write = Math.max(0, this.length() - count);\n this.read = Math.min(this.read, this.write);\n return this;\n};\n\n/**\n * Converts this buffer to a hexadecimal string.\n *\n * @return a hexadecimal string.\n */\nutil.DataBuffer.prototype.toHex = function() {\n var rval = '';\n for(var i = this.read; i < this.data.byteLength; ++i) {\n var b = this.data.getUint8(i);\n if(b < 16) {\n rval += '0';\n }\n rval += b.toString(16);\n }\n return rval;\n};\n\n/**\n * Converts this buffer to a string, using the given encoding. If no\n * encoding is given, 'utf8' (UTF-8) is used.\n *\n * @param [encoding] the encoding to use: 'binary', 'utf8', 'utf16', 'hex',\n * 'base64' (default: 'utf8').\n *\n * @return a string representation of the bytes in this buffer.\n */\nutil.DataBuffer.prototype.toString = function(encoding) {\n var view = new Uint8Array(this.data, this.read, this.length());\n encoding = encoding || 'utf8';\n\n // encode to string\n if(encoding === 'binary' || encoding === 'raw') {\n return util.binary.raw.encode(view);\n }\n if(encoding === 'hex') {\n return util.binary.hex.encode(view);\n }\n if(encoding === 'base64') {\n return util.binary.base64.encode(view);\n }\n\n // decode to text\n if(encoding === 'utf8') {\n return util.text.utf8.decode(view);\n }\n if(encoding === 'utf16') {\n return util.text.utf16.decode(view);\n }\n\n throw new Error('Invalid encoding: ' + encoding);\n};\n\n/** End Buffer w/UInt8Array backing */\n\n/**\n * Creates a buffer that stores bytes. A value may be given to populate the\n * buffer with data. This value can either be string of encoded bytes or a\n * regular string of characters. When passing a string of binary encoded\n * bytes, the encoding `raw` should be given. This is also the default. When\n * passing a string of characters, the encoding `utf8` should be given.\n *\n * @param [input] a string with encoded bytes to store in the buffer.\n * @param [encoding] (default: 'raw', other: 'utf8').\n */\nutil.createBuffer = function(input, encoding) {\n // TODO: deprecate, use new ByteBuffer() instead\n encoding = encoding || 'raw';\n if(input !== undefined && encoding === 'utf8') {\n input = util.encodeUtf8(input);\n }\n return new util.ByteBuffer(input);\n};\n\n/**\n * Fills a string with a particular value. If you want the string to be a byte\n * string, pass in String.fromCharCode(theByte).\n *\n * @param c the character to fill the string with, use String.fromCharCode\n * to fill the string with a byte value.\n * @param n the number of characters of value c to fill with.\n *\n * @return the filled string.\n */\nutil.fillString = function(c, n) {\n var s = '';\n while(n > 0) {\n if(n & 1) {\n s += c;\n }\n n >>>= 1;\n if(n > 0) {\n c += c;\n }\n }\n return s;\n};\n\n/**\n * Performs a per byte XOR between two byte strings and returns the result as a\n * string of bytes.\n *\n * @param s1 first string of bytes.\n * @param s2 second string of bytes.\n * @param n the number of bytes to XOR.\n *\n * @return the XOR'd result.\n */\nutil.xorBytes = function(s1, s2, n) {\n var s3 = '';\n var b = '';\n var t = '';\n var i = 0;\n var c = 0;\n for(; n > 0; --n, ++i) {\n b = s1.charCodeAt(i) ^ s2.charCodeAt(i);\n if(c >= 10) {\n s3 += t;\n t = '';\n c = 0;\n }\n t += String.fromCharCode(b);\n ++c;\n }\n s3 += t;\n return s3;\n};\n\n/**\n * Converts a hex string into a 'binary' encoded string of bytes.\n *\n * @param hex the hexadecimal string to convert.\n *\n * @return the binary-encoded string of bytes.\n */\nutil.hexToBytes = function(hex) {\n // TODO: deprecate: \"Deprecated. Use util.binary.hex.decode instead.\"\n var rval = '';\n var i = 0;\n if(hex.length & 1 == 1) {\n // odd number of characters, convert first character alone\n i = 1;\n rval += String.fromCharCode(parseInt(hex[0], 16));\n }\n // convert 2 characters (1 byte) at a time\n for(; i < hex.length; i += 2) {\n rval += String.fromCharCode(parseInt(hex.substr(i, 2), 16));\n }\n return rval;\n};\n\n/**\n * Converts a 'binary' encoded string of bytes to hex.\n *\n * @param bytes the byte string to convert.\n *\n * @return the string of hexadecimal characters.\n */\nutil.bytesToHex = function(bytes) {\n // TODO: deprecate: \"Deprecated. Use util.binary.hex.encode instead.\"\n return util.createBuffer(bytes).toHex();\n};\n\n/**\n * Converts an 32-bit integer to 4-big-endian byte string.\n *\n * @param i the integer.\n *\n * @return the byte string.\n */\nutil.int32ToBytes = function(i) {\n return (\n String.fromCharCode(i >> 24 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n// base64 characters, reverse mapping\nvar _base64 =\n 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';\nvar _base64Idx = [\n/*43 -43 = 0*/\n/*'+', 1, 2, 3,'/' */\n 62, -1, -1, -1, 63,\n\n/*'0','1','2','3','4','5','6','7','8','9' */\n 52, 53, 54, 55, 56, 57, 58, 59, 60, 61,\n\n/*15, 16, 17,'=', 19, 20, 21 */\n -1, -1, -1, 64, -1, -1, -1,\n\n/*65 - 43 = 22*/\n/*'A','B','C','D','E','F','G','H','I','J','K','L','M', */\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,\n\n/*'N','O','P','Q','R','S','T','U','V','W','X','Y','Z' */\n 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25,\n\n/*91 - 43 = 48 */\n/*48, 49, 50, 51, 52, 53 */\n -1, -1, -1, -1, -1, -1,\n\n/*97 - 43 = 54*/\n/*'a','b','c','d','e','f','g','h','i','j','k','l','m' */\n 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,\n\n/*'n','o','p','q','r','s','t','u','v','w','x','y','z' */\n 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51\n];\n\n// base58 characters (Bitcoin alphabet)\nvar _base58 = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';\n\n/**\n * Base64 encodes a 'binary' encoded string of bytes.\n *\n * @param input the binary encoded string of bytes to base64-encode.\n * @param maxline the maximum number of encoded characters per line to use,\n * defaults to none.\n *\n * @return the base64-encoded output.\n */\nutil.encode64 = function(input, maxline) {\n // TODO: deprecate: \"Deprecated. Use util.binary.base64.encode instead.\"\n var line = '';\n var output = '';\n var chr1, chr2, chr3;\n var i = 0;\n while(i < input.length) {\n chr1 = input.charCodeAt(i++);\n chr2 = input.charCodeAt(i++);\n chr3 = input.charCodeAt(i++);\n\n // encode 4 character group\n line += _base64.charAt(chr1 >> 2);\n line += _base64.charAt(((chr1 & 3) << 4) | (chr2 >> 4));\n if(isNaN(chr2)) {\n line += '==';\n } else {\n line += _base64.charAt(((chr2 & 15) << 2) | (chr3 >> 6));\n line += isNaN(chr3) ? '=' : _base64.charAt(chr3 & 63);\n }\n\n if(maxline && line.length > maxline) {\n output += line.substr(0, maxline) + '\\r\\n';\n line = line.substr(maxline);\n }\n }\n output += line;\n return output;\n};\n\n/**\n * Base64 decodes a string into a 'binary' encoded string of bytes.\n *\n * @param input the base64-encoded input.\n *\n * @return the binary encoded string.\n */\nutil.decode64 = function(input) {\n // TODO: deprecate: \"Deprecated. Use util.binary.base64.decode instead.\"\n\n // remove all non-base64 characters\n input = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, '');\n\n var output = '';\n var enc1, enc2, enc3, enc4;\n var i = 0;\n\n while(i < input.length) {\n enc1 = _base64Idx[input.charCodeAt(i++) - 43];\n enc2 = _base64Idx[input.charCodeAt(i++) - 43];\n enc3 = _base64Idx[input.charCodeAt(i++) - 43];\n enc4 = _base64Idx[input.charCodeAt(i++) - 43];\n\n output += String.fromCharCode((enc1 << 2) | (enc2 >> 4));\n if(enc3 !== 64) {\n // decoded at least 2 bytes\n output += String.fromCharCode(((enc2 & 15) << 4) | (enc3 >> 2));\n if(enc4 !== 64) {\n // decoded 3 bytes\n output += String.fromCharCode(((enc3 & 3) << 6) | enc4);\n }\n }\n }\n\n return output;\n};\n\n/**\n * Encodes the given string of characters (a standard JavaScript\n * string) as a binary encoded string where the bytes represent\n * a UTF-8 encoded string of characters. Non-ASCII characters will be\n * encoded as multiple bytes according to UTF-8.\n *\n * @param str a standard string of characters to encode.\n *\n * @return the binary encoded string.\n */\nutil.encodeUtf8 = function(str) {\n return unescape(encodeURIComponent(str));\n};\n\n/**\n * Decodes a binary encoded string that contains bytes that\n * represent a UTF-8 encoded string of characters -- into a\n * string of characters (a standard JavaScript string).\n *\n * @param str the binary encoded string to decode.\n *\n * @return the resulting standard string of characters.\n */\nutil.decodeUtf8 = function(str) {\n return decodeURIComponent(escape(str));\n};\n\n// binary encoding/decoding tools\n// FIXME: Experimental. Do not use yet.\nutil.binary = {\n raw: {},\n hex: {},\n base64: {},\n base58: {},\n baseN : {\n encode: baseN.encode,\n decode: baseN.decode\n }\n};\n\n/**\n * Encodes a Uint8Array as a binary-encoded string. This encoding uses\n * a value between 0 and 255 for each character.\n *\n * @param bytes the Uint8Array to encode.\n *\n * @return the binary-encoded string.\n */\nutil.binary.raw.encode = function(bytes) {\n return String.fromCharCode.apply(null, bytes);\n};\n\n/**\n * Decodes a binary-encoded string to a Uint8Array. This encoding uses\n * a value between 0 and 255 for each character.\n *\n * @param str the binary-encoded string to decode.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.binary.raw.decode = function(str, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(str.length);\n }\n offset = offset || 0;\n var j = offset;\n for(var i = 0; i < str.length; ++i) {\n out[j++] = str.charCodeAt(i);\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Encodes a 'binary' string, ArrayBuffer, DataView, TypedArray, or\n * ByteBuffer as a string of hexadecimal characters.\n *\n * @param bytes the bytes to convert.\n *\n * @return the string of hexadecimal characters.\n */\nutil.binary.hex.encode = util.bytesToHex;\n\n/**\n * Decodes a hex-encoded string to a Uint8Array.\n *\n * @param hex the hexadecimal string to convert.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.binary.hex.decode = function(hex, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(Math.ceil(hex.length / 2));\n }\n offset = offset || 0;\n var i = 0, j = offset;\n if(hex.length & 1) {\n // odd number of characters, convert first character alone\n i = 1;\n out[j++] = parseInt(hex[0], 16);\n }\n // convert 2 characters (1 byte) at a time\n for(; i < hex.length; i += 2) {\n out[j++] = parseInt(hex.substr(i, 2), 16);\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Base64-encodes a Uint8Array.\n *\n * @param input the Uint8Array to encode.\n * @param maxline the maximum number of encoded characters per line to use,\n * defaults to none.\n *\n * @return the base64-encoded output string.\n */\nutil.binary.base64.encode = function(input, maxline) {\n var line = '';\n var output = '';\n var chr1, chr2, chr3;\n var i = 0;\n while(i < input.byteLength) {\n chr1 = input[i++];\n chr2 = input[i++];\n chr3 = input[i++];\n\n // encode 4 character group\n line += _base64.charAt(chr1 >> 2);\n line += _base64.charAt(((chr1 & 3) << 4) | (chr2 >> 4));\n if(isNaN(chr2)) {\n line += '==';\n } else {\n line += _base64.charAt(((chr2 & 15) << 2) | (chr3 >> 6));\n line += isNaN(chr3) ? '=' : _base64.charAt(chr3 & 63);\n }\n\n if(maxline && line.length > maxline) {\n output += line.substr(0, maxline) + '\\r\\n';\n line = line.substr(maxline);\n }\n }\n output += line;\n return output;\n};\n\n/**\n * Decodes a base64-encoded string to a Uint8Array.\n *\n * @param input the base64-encoded input string.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.binary.base64.decode = function(input, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(Math.ceil(input.length / 4) * 3);\n }\n\n // remove all non-base64 characters\n input = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, '');\n\n offset = offset || 0;\n var enc1, enc2, enc3, enc4;\n var i = 0, j = offset;\n\n while(i < input.length) {\n enc1 = _base64Idx[input.charCodeAt(i++) - 43];\n enc2 = _base64Idx[input.charCodeAt(i++) - 43];\n enc3 = _base64Idx[input.charCodeAt(i++) - 43];\n enc4 = _base64Idx[input.charCodeAt(i++) - 43];\n\n out[j++] = (enc1 << 2) | (enc2 >> 4);\n if(enc3 !== 64) {\n // decoded at least 2 bytes\n out[j++] = ((enc2 & 15) << 4) | (enc3 >> 2);\n if(enc4 !== 64) {\n // decoded 3 bytes\n out[j++] = ((enc3 & 3) << 6) | enc4;\n }\n }\n }\n\n // make sure result is the exact decoded length\n return output ? (j - offset) : out.subarray(0, j);\n};\n\n// add support for base58 encoding/decoding with Bitcoin alphabet\nutil.binary.base58.encode = function(input, maxline) {\n return util.binary.baseN.encode(input, _base58, maxline);\n};\nutil.binary.base58.decode = function(input, maxline) {\n return util.binary.baseN.decode(input, _base58, maxline);\n};\n\n// text encoding/decoding tools\n// FIXME: Experimental. Do not use yet.\nutil.text = {\n utf8: {},\n utf16: {}\n};\n\n/**\n * Encodes the given string as UTF-8 in a Uint8Array.\n *\n * @param str the string to encode.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.text.utf8.encode = function(str, output, offset) {\n str = util.encodeUtf8(str);\n var out = output;\n if(!out) {\n out = new Uint8Array(str.length);\n }\n offset = offset || 0;\n var j = offset;\n for(var i = 0; i < str.length; ++i) {\n out[j++] = str.charCodeAt(i);\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Decodes the UTF-8 contents from a Uint8Array.\n *\n * @param bytes the Uint8Array to decode.\n *\n * @return the resulting string.\n */\nutil.text.utf8.decode = function(bytes) {\n return util.decodeUtf8(String.fromCharCode.apply(null, bytes));\n};\n\n/**\n * Encodes the given string as UTF-16 in a Uint8Array.\n *\n * @param str the string to encode.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.text.utf16.encode = function(str, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(str.length * 2);\n }\n var view = new Uint16Array(out.buffer);\n offset = offset || 0;\n var j = offset;\n var k = offset;\n for(var i = 0; i < str.length; ++i) {\n view[k++] = str.charCodeAt(i);\n j += 2;\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Decodes the UTF-16 contents from a Uint8Array.\n *\n * @param bytes the Uint8Array to decode.\n *\n * @return the resulting string.\n */\nutil.text.utf16.decode = function(bytes) {\n return String.fromCharCode.apply(null, new Uint16Array(bytes.buffer));\n};\n\n/**\n * Deflates the given data using a flash interface.\n *\n * @param api the flash interface.\n * @param bytes the data.\n * @param raw true to return only raw deflate data, false to include zlib\n * header and trailer.\n *\n * @return the deflated data as a string.\n */\nutil.deflate = function(api, bytes, raw) {\n bytes = util.decode64(api.deflate(util.encode64(bytes)).rval);\n\n // strip zlib header and trailer if necessary\n if(raw) {\n // zlib header is 2 bytes (CMF,FLG) where FLG indicates that\n // there is a 4-byte DICT (alder-32) block before the data if\n // its 5th bit is set\n var start = 2;\n var flg = bytes.charCodeAt(1);\n if(flg & 0x20) {\n start = 6;\n }\n // zlib trailer is 4 bytes of adler-32\n bytes = bytes.substring(start, bytes.length - 4);\n }\n\n return bytes;\n};\n\n/**\n * Inflates the given data using a flash interface.\n *\n * @param api the flash interface.\n * @param bytes the data.\n * @param raw true if the incoming data has no zlib header or trailer and is\n * raw DEFLATE data.\n *\n * @return the inflated data as a string, null on error.\n */\nutil.inflate = function(api, bytes, raw) {\n // TODO: add zlib header and trailer if necessary/possible\n var rval = api.inflate(util.encode64(bytes)).rval;\n return (rval === null) ? null : util.decode64(rval);\n};\n\n/**\n * Sets a storage object.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param obj the storage object, null to remove.\n */\nvar _setStorageObject = function(api, id, obj) {\n if(!api) {\n throw new Error('WebStorage not available.');\n }\n\n var rval;\n if(obj === null) {\n rval = api.removeItem(id);\n } else {\n // json-encode and base64-encode object\n obj = util.encode64(JSON.stringify(obj));\n rval = api.setItem(id, obj);\n }\n\n // handle potential flash error\n if(typeof(rval) !== 'undefined' && rval.rval !== true) {\n var error = new Error(rval.error.message);\n error.id = rval.error.id;\n error.name = rval.error.name;\n throw error;\n }\n};\n\n/**\n * Gets a storage object.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n *\n * @return the storage object entry or null if none exists.\n */\nvar _getStorageObject = function(api, id) {\n if(!api) {\n throw new Error('WebStorage not available.');\n }\n\n // get the existing entry\n var rval = api.getItem(id);\n\n /* Note: We check api.init because we can't do (api == localStorage)\n on IE because of \"Class doesn't support Automation\" exception. Only\n the flash api has an init method so this works too, but we need a\n better solution in the future. */\n\n // flash returns item wrapped in an object, handle special case\n if(api.init) {\n if(rval.rval === null) {\n if(rval.error) {\n var error = new Error(rval.error.message);\n error.id = rval.error.id;\n error.name = rval.error.name;\n throw error;\n }\n // no error, but also no item\n rval = null;\n } else {\n rval = rval.rval;\n }\n }\n\n // handle decoding\n if(rval !== null) {\n // base64-decode and json-decode data\n rval = JSON.parse(util.decode64(rval));\n }\n\n return rval;\n};\n\n/**\n * Stores an item in local storage.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param data the data for the item (any javascript object/primitive).\n */\nvar _setItem = function(api, id, key, data) {\n // get storage object\n var obj = _getStorageObject(api, id);\n if(obj === null) {\n // create a new storage object\n obj = {};\n }\n // update key\n obj[key] = data;\n\n // set storage object\n _setStorageObject(api, id, obj);\n};\n\n/**\n * Gets an item from local storage.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n *\n * @return the item.\n */\nvar _getItem = function(api, id, key) {\n // get storage object\n var rval = _getStorageObject(api, id);\n if(rval !== null) {\n // return data at key\n rval = (key in rval) ? rval[key] : null;\n }\n\n return rval;\n};\n\n/**\n * Removes an item from local storage.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n */\nvar _removeItem = function(api, id, key) {\n // get storage object\n var obj = _getStorageObject(api, id);\n if(obj !== null && key in obj) {\n // remove key\n delete obj[key];\n\n // see if entry has no keys remaining\n var empty = true;\n for(var prop in obj) {\n empty = false;\n break;\n }\n if(empty) {\n // remove entry entirely if no keys are left\n obj = null;\n }\n\n // set storage object\n _setStorageObject(api, id, obj);\n }\n};\n\n/**\n * Clears the local disk storage identified by the given ID.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n */\nvar _clearItems = function(api, id) {\n _setStorageObject(api, id, null);\n};\n\n/**\n * Calls a storage function.\n *\n * @param func the function to call.\n * @param args the arguments for the function.\n * @param location the location argument.\n *\n * @return the return value from the function.\n */\nvar _callStorageFunction = function(func, args, location) {\n var rval = null;\n\n // default storage types\n if(typeof(location) === 'undefined') {\n location = ['web', 'flash'];\n }\n\n // apply storage types in order of preference\n var type;\n var done = false;\n var exception = null;\n for(var idx in location) {\n type = location[idx];\n try {\n if(type === 'flash' || type === 'both') {\n if(args[0] === null) {\n throw new Error('Flash local storage not available.');\n }\n rval = func.apply(this, args);\n done = (type === 'flash');\n }\n if(type === 'web' || type === 'both') {\n args[0] = localStorage;\n rval = func.apply(this, args);\n done = true;\n }\n } catch(ex) {\n exception = ex;\n }\n if(done) {\n break;\n }\n }\n\n if(!done) {\n throw exception;\n }\n\n return rval;\n};\n\n/**\n * Stores an item on local disk.\n *\n * The available types of local storage include 'flash', 'web', and 'both'.\n *\n * The type 'flash' refers to flash local storage (SharedObject). In order\n * to use flash local storage, the 'api' parameter must be valid. The type\n * 'web' refers to WebStorage, if supported by the browser. The type 'both'\n * refers to storing using both 'flash' and 'web', not just one or the\n * other.\n *\n * The location array should list the storage types to use in order of\n * preference:\n *\n * ['flash']: flash only storage\n * ['web']: web only storage\n * ['both']: try to store in both\n * ['flash','web']: store in flash first, but if not available, 'web'\n * ['web','flash']: store in web first, but if not available, 'flash'\n *\n * The location array defaults to: ['web', 'flash']\n *\n * @param api the flash interface, null to use only WebStorage.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param data the data for the item (any javascript object/primitive).\n * @param location an array with the preferred types of storage to use.\n */\nutil.setItem = function(api, id, key, data, location) {\n _callStorageFunction(_setItem, arguments, location);\n};\n\n/**\n * Gets an item on local disk.\n *\n * Set setItem() for details on storage types.\n *\n * @param api the flash interface, null to use only WebStorage.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param location an array with the preferred types of storage to use.\n *\n * @return the item.\n */\nutil.getItem = function(api, id, key, location) {\n return _callStorageFunction(_getItem, arguments, location);\n};\n\n/**\n * Removes an item on local disk.\n *\n * Set setItem() for details on storage types.\n *\n * @param api the flash interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param location an array with the preferred types of storage to use.\n */\nutil.removeItem = function(api, id, key, location) {\n _callStorageFunction(_removeItem, arguments, location);\n};\n\n/**\n * Clears the local disk storage identified by the given ID.\n *\n * Set setItem() for details on storage types.\n *\n * @param api the flash interface if flash is available.\n * @param id the storage ID to use.\n * @param location an array with the preferred types of storage to use.\n */\nutil.clearItems = function(api, id, location) {\n _callStorageFunction(_clearItems, arguments, location);\n};\n\n/**\n * Parses the scheme, host, and port from an http(s) url.\n *\n * @param str the url string.\n *\n * @return the parsed url object or null if the url is invalid.\n */\nutil.parseUrl = function(str) {\n // FIXME: this regex looks a bit broken\n var regex = /^(https?):\\/\\/([^:&^\\/]*):?(\\d*)(.*)$/g;\n regex.lastIndex = 0;\n var m = regex.exec(str);\n var url = (m === null) ? null : {\n full: str,\n scheme: m[1],\n host: m[2],\n port: m[3],\n path: m[4]\n };\n if(url) {\n url.fullHost = url.host;\n if(url.port) {\n if(url.port !== 80 && url.scheme === 'http') {\n url.fullHost += ':' + url.port;\n } else if(url.port !== 443 && url.scheme === 'https') {\n url.fullHost += ':' + url.port;\n }\n } else if(url.scheme === 'http') {\n url.port = 80;\n } else if(url.scheme === 'https') {\n url.port = 443;\n }\n url.full = url.scheme + '://' + url.fullHost;\n }\n return url;\n};\n\n/* Storage for query variables */\nvar _queryVariables = null;\n\n/**\n * Returns the window location query variables. Query is parsed on the first\n * call and the same object is returned on subsequent calls. The mapping\n * is from keys to an array of values. Parameters without values will have\n * an object key set but no value added to the value array. Values are\n * unescaped.\n *\n * ...?k1=v1&k2=v2:\n * {\n * \"k1\": [\"v1\"],\n * \"k2\": [\"v2\"]\n * }\n *\n * ...?k1=v1&k1=v2:\n * {\n * \"k1\": [\"v1\", \"v2\"]\n * }\n *\n * ...?k1=v1&k2:\n * {\n * \"k1\": [\"v1\"],\n * \"k2\": []\n * }\n *\n * ...?k1=v1&k1:\n * {\n * \"k1\": [\"v1\"]\n * }\n *\n * ...?k1&k1:\n * {\n * \"k1\": []\n * }\n *\n * @param query the query string to parse (optional, default to cached\n * results from parsing window location search query).\n *\n * @return object mapping keys to variables.\n */\nutil.getQueryVariables = function(query) {\n var parse = function(q) {\n var rval = {};\n var kvpairs = q.split('&');\n for(var i = 0; i < kvpairs.length; i++) {\n var pos = kvpairs[i].indexOf('=');\n var key;\n var val;\n if(pos > 0) {\n key = kvpairs[i].substring(0, pos);\n val = kvpairs[i].substring(pos + 1);\n } else {\n key = kvpairs[i];\n val = null;\n }\n if(!(key in rval)) {\n rval[key] = [];\n }\n // disallow overriding object prototype keys\n if(!(key in Object.prototype) && val !== null) {\n rval[key].push(unescape(val));\n }\n }\n return rval;\n };\n\n var rval;\n if(typeof(query) === 'undefined') {\n // set cached variables if needed\n if(_queryVariables === null) {\n if(typeof(window) !== 'undefined' && window.location && window.location.search) {\n // parse window search query\n _queryVariables = parse(window.location.search.substring(1));\n } else {\n // no query variables available\n _queryVariables = {};\n }\n }\n rval = _queryVariables;\n } else {\n // parse given query\n rval = parse(query);\n }\n return rval;\n};\n\n/**\n * Parses a fragment into a path and query. This method will take a URI\n * fragment and break it up as if it were the main URI. For example:\n * /bar/baz?a=1&b=2\n * results in:\n * {\n * path: [\"bar\", \"baz\"],\n * query: {\"k1\": [\"v1\"], \"k2\": [\"v2\"]}\n * }\n *\n * @return object with a path array and query object.\n */\nutil.parseFragment = function(fragment) {\n // default to whole fragment\n var fp = fragment;\n var fq = '';\n // split into path and query if possible at the first '?'\n var pos = fragment.indexOf('?');\n if(pos > 0) {\n fp = fragment.substring(0, pos);\n fq = fragment.substring(pos + 1);\n }\n // split path based on '/' and ignore first element if empty\n var path = fp.split('/');\n if(path.length > 0 && path[0] === '') {\n path.shift();\n }\n // convert query into object\n var query = (fq === '') ? {} : util.getQueryVariables(fq);\n\n return {\n pathString: fp,\n queryString: fq,\n path: path,\n query: query\n };\n};\n\n/**\n * Makes a request out of a URI-like request string. This is intended to\n * be used where a fragment id (after a URI '#') is parsed as a URI with\n * path and query parts. The string should have a path beginning and\n * delimited by '/' and optional query parameters following a '?'. The\n * query should be a standard URL set of key value pairs delimited by\n * '&'. For backwards compatibility the initial '/' on the path is not\n * required. The request object has the following API, (fully described\n * in the method code):\n * {\n * path: .\n * query: ,\n * getPath(i): get part or all of the split path array,\n * getQuery(k, i): get part or all of a query key array,\n * getQueryLast(k, _default): get last element of a query key array.\n * }\n *\n * @return object with request parameters.\n */\nutil.makeRequest = function(reqString) {\n var frag = util.parseFragment(reqString);\n var req = {\n // full path string\n path: frag.pathString,\n // full query string\n query: frag.queryString,\n /**\n * Get path or element in path.\n *\n * @param i optional path index.\n *\n * @return path or part of path if i provided.\n */\n getPath: function(i) {\n return (typeof(i) === 'undefined') ? frag.path : frag.path[i];\n },\n /**\n * Get query, values for a key, or value for a key index.\n *\n * @param k optional query key.\n * @param i optional query key index.\n *\n * @return query, values for a key, or value for a key index.\n */\n getQuery: function(k, i) {\n var rval;\n if(typeof(k) === 'undefined') {\n rval = frag.query;\n } else {\n rval = frag.query[k];\n if(rval && typeof(i) !== 'undefined') {\n rval = rval[i];\n }\n }\n return rval;\n },\n getQueryLast: function(k, _default) {\n var rval;\n var vals = req.getQuery(k);\n if(vals) {\n rval = vals[vals.length - 1];\n } else {\n rval = _default;\n }\n return rval;\n }\n };\n return req;\n};\n\n/**\n * Makes a URI out of a path, an object with query parameters, and a\n * fragment. Uses jQuery.param() internally for query string creation.\n * If the path is an array, it will be joined with '/'.\n *\n * @param path string path or array of strings.\n * @param query object with query parameters. (optional)\n * @param fragment fragment string. (optional)\n *\n * @return string object with request parameters.\n */\nutil.makeLink = function(path, query, fragment) {\n // join path parts if needed\n path = jQuery.isArray(path) ? path.join('/') : path;\n\n var qstr = jQuery.param(query || {});\n fragment = fragment || '';\n return path +\n ((qstr.length > 0) ? ('?' + qstr) : '') +\n ((fragment.length > 0) ? ('#' + fragment) : '');\n};\n\n/**\n * Check if an object is empty.\n *\n * Taken from:\n * http://stackoverflow.com/questions/679915/how-do-i-test-for-an-empty-javascript-object-from-json/679937#679937\n *\n * @param object the object to check.\n */\nutil.isEmpty = function(obj) {\n for(var prop in obj) {\n if(obj.hasOwnProperty(prop)) {\n return false;\n }\n }\n return true;\n};\n\n/**\n * Format with simple printf-style interpolation.\n *\n * %%: literal '%'\n * %s,%o: convert next argument into a string.\n *\n * @param format the string to format.\n * @param ... arguments to interpolate into the format string.\n */\nutil.format = function(format) {\n var re = /%./g;\n // current match\n var match;\n // current part\n var part;\n // current arg index\n var argi = 0;\n // collected parts to recombine later\n var parts = [];\n // last index found\n var last = 0;\n // loop while matches remain\n while((match = re.exec(format))) {\n part = format.substring(last, re.lastIndex - 2);\n // don't add empty strings (ie, parts between %s%s)\n if(part.length > 0) {\n parts.push(part);\n }\n last = re.lastIndex;\n // switch on % code\n var code = match[0][1];\n switch(code) {\n case 's':\n case 'o':\n // check if enough arguments were given\n if(argi < arguments.length) {\n parts.push(arguments[argi++ + 1]);\n } else {\n parts.push('');\n }\n break;\n // FIXME: do proper formating for numbers, etc\n //case 'f':\n //case 'd':\n case '%':\n parts.push('%');\n break;\n default:\n parts.push('<%' + code + '?>');\n }\n }\n // add trailing part of format string\n parts.push(format.substring(last));\n return parts.join('');\n};\n\n/**\n * Formats a number.\n *\n * http://snipplr.com/view/5945/javascript-numberformat--ported-from-php/\n */\nutil.formatNumber = function(number, decimals, dec_point, thousands_sep) {\n // http://kevin.vanzonneveld.net\n // + original by: Jonas Raoni Soares Silva (http://www.jsfromhell.com)\n // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)\n // + bugfix by: Michael White (http://crestidg.com)\n // + bugfix by: Benjamin Lupton\n // + bugfix by: Allan Jensen (http://www.winternet.no)\n // + revised by: Jonas Raoni Soares Silva (http://www.jsfromhell.com)\n // * example 1: number_format(1234.5678, 2, '.', '');\n // * returns 1: 1234.57\n\n var n = number, c = isNaN(decimals = Math.abs(decimals)) ? 2 : decimals;\n var d = dec_point === undefined ? ',' : dec_point;\n var t = thousands_sep === undefined ?\n '.' : thousands_sep, s = n < 0 ? '-' : '';\n var i = parseInt((n = Math.abs(+n || 0).toFixed(c)), 10) + '';\n var j = (i.length > 3) ? i.length % 3 : 0;\n return s + (j ? i.substr(0, j) + t : '') +\n i.substr(j).replace(/(\\d{3})(?=\\d)/g, '$1' + t) +\n (c ? d + Math.abs(n - i).toFixed(c).slice(2) : '');\n};\n\n/**\n * Formats a byte size.\n *\n * http://snipplr.com/view/5949/format-humanize-file-byte-size-presentation-in-javascript/\n */\nutil.formatSize = function(size) {\n if(size >= 1073741824) {\n size = util.formatNumber(size / 1073741824, 2, '.', '') + ' GiB';\n } else if(size >= 1048576) {\n size = util.formatNumber(size / 1048576, 2, '.', '') + ' MiB';\n } else if(size >= 1024) {\n size = util.formatNumber(size / 1024, 0) + ' KiB';\n } else {\n size = util.formatNumber(size, 0) + ' bytes';\n }\n return size;\n};\n\n/**\n * Converts an IPv4 or IPv6 string representation into bytes (in network order).\n *\n * @param ip the IPv4 or IPv6 address to convert.\n *\n * @return the 4-byte IPv6 or 16-byte IPv6 address or null if the address can't\n * be parsed.\n */\nutil.bytesFromIP = function(ip) {\n if(ip.indexOf('.') !== -1) {\n return util.bytesFromIPv4(ip);\n }\n if(ip.indexOf(':') !== -1) {\n return util.bytesFromIPv6(ip);\n }\n return null;\n};\n\n/**\n * Converts an IPv4 string representation into bytes (in network order).\n *\n * @param ip the IPv4 address to convert.\n *\n * @return the 4-byte address or null if the address can't be parsed.\n */\nutil.bytesFromIPv4 = function(ip) {\n ip = ip.split('.');\n if(ip.length !== 4) {\n return null;\n }\n var b = util.createBuffer();\n for(var i = 0; i < ip.length; ++i) {\n var num = parseInt(ip[i], 10);\n if(isNaN(num)) {\n return null;\n }\n b.putByte(num);\n }\n return b.getBytes();\n};\n\n/**\n * Converts an IPv6 string representation into bytes (in network order).\n *\n * @param ip the IPv6 address to convert.\n *\n * @return the 16-byte address or null if the address can't be parsed.\n */\nutil.bytesFromIPv6 = function(ip) {\n var blanks = 0;\n ip = ip.split(':').filter(function(e) {\n if(e.length === 0) ++blanks;\n return true;\n });\n var zeros = (8 - ip.length + blanks) * 2;\n var b = util.createBuffer();\n for(var i = 0; i < 8; ++i) {\n if(!ip[i] || ip[i].length === 0) {\n b.fillWithByte(0, zeros);\n zeros = 0;\n continue;\n }\n var bytes = util.hexToBytes(ip[i]);\n if(bytes.length < 2) {\n b.putByte(0);\n }\n b.putBytes(bytes);\n }\n return b.getBytes();\n};\n\n/**\n * Converts 4-bytes into an IPv4 string representation or 16-bytes into\n * an IPv6 string representation. The bytes must be in network order.\n *\n * @param bytes the bytes to convert.\n *\n * @return the IPv4 or IPv6 string representation if 4 or 16 bytes,\n * respectively, are given, otherwise null.\n */\nutil.bytesToIP = function(bytes) {\n if(bytes.length === 4) {\n return util.bytesToIPv4(bytes);\n }\n if(bytes.length === 16) {\n return util.bytesToIPv6(bytes);\n }\n return null;\n};\n\n/**\n * Converts 4-bytes into an IPv4 string representation. The bytes must be\n * in network order.\n *\n * @param bytes the bytes to convert.\n *\n * @return the IPv4 string representation or null for an invalid # of bytes.\n */\nutil.bytesToIPv4 = function(bytes) {\n if(bytes.length !== 4) {\n return null;\n }\n var ip = [];\n for(var i = 0; i < bytes.length; ++i) {\n ip.push(bytes.charCodeAt(i));\n }\n return ip.join('.');\n};\n\n/**\n * Converts 16-bytes into an IPv16 string representation. The bytes must be\n * in network order.\n *\n * @param bytes the bytes to convert.\n *\n * @return the IPv16 string representation or null for an invalid # of bytes.\n */\nutil.bytesToIPv6 = function(bytes) {\n if(bytes.length !== 16) {\n return null;\n }\n var ip = [];\n var zeroGroups = [];\n var zeroMaxGroup = 0;\n for(var i = 0; i < bytes.length; i += 2) {\n var hex = util.bytesToHex(bytes[i] + bytes[i + 1]);\n // canonicalize zero representation\n while(hex[0] === '0' && hex !== '0') {\n hex = hex.substr(1);\n }\n if(hex === '0') {\n var last = zeroGroups[zeroGroups.length - 1];\n var idx = ip.length;\n if(!last || idx !== last.end + 1) {\n zeroGroups.push({start: idx, end: idx});\n } else {\n last.end = idx;\n if((last.end - last.start) >\n (zeroGroups[zeroMaxGroup].end - zeroGroups[zeroMaxGroup].start)) {\n zeroMaxGroup = zeroGroups.length - 1;\n }\n }\n }\n ip.push(hex);\n }\n if(zeroGroups.length > 0) {\n var group = zeroGroups[zeroMaxGroup];\n // only shorten group of length > 0\n if(group.end - group.start > 0) {\n ip.splice(group.start, group.end - group.start + 1, '');\n if(group.start === 0) {\n ip.unshift('');\n }\n if(group.end === 7) {\n ip.push('');\n }\n }\n }\n return ip.join(':');\n};\n\n/**\n * Estimates the number of processes that can be run concurrently. If\n * creating Web Workers, keep in mind that the main JavaScript process needs\n * its own core.\n *\n * @param options the options to use:\n * update true to force an update (not use the cached value).\n * @param callback(err, max) called once the operation completes.\n */\nutil.estimateCores = function(options, callback) {\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n if('cores' in util && !options.update) {\n return callback(null, util.cores);\n }\n if(typeof navigator !== 'undefined' &&\n 'hardwareConcurrency' in navigator &&\n navigator.hardwareConcurrency > 0) {\n util.cores = navigator.hardwareConcurrency;\n return callback(null, util.cores);\n }\n if(typeof Worker === 'undefined') {\n // workers not available\n util.cores = 1;\n return callback(null, util.cores);\n }\n if(typeof Blob === 'undefined') {\n // can't estimate, default to 2\n util.cores = 2;\n return callback(null, util.cores);\n }\n\n // create worker concurrency estimation code as blob\n var blobUrl = URL.createObjectURL(new Blob(['(',\n function() {\n self.addEventListener('message', function(e) {\n // run worker for 4 ms\n var st = Date.now();\n var et = st + 4;\n while(Date.now() < et);\n self.postMessage({st: st, et: et});\n });\n }.toString(),\n ')()'], {type: 'application/javascript'}));\n\n // take 5 samples using 16 workers\n sample([], 5, 16);\n\n function sample(max, samples, numWorkers) {\n if(samples === 0) {\n // get overlap average\n var avg = Math.floor(max.reduce(function(avg, x) {\n return avg + x;\n }, 0) / max.length);\n util.cores = Math.max(1, avg);\n URL.revokeObjectURL(blobUrl);\n return callback(null, util.cores);\n }\n map(numWorkers, function(err, results) {\n max.push(reduce(numWorkers, results));\n sample(max, samples - 1, numWorkers);\n });\n }\n\n function map(numWorkers, callback) {\n var workers = [];\n var results = [];\n for(var i = 0; i < numWorkers; ++i) {\n var worker = new Worker(blobUrl);\n worker.addEventListener('message', function(e) {\n results.push(e.data);\n if(results.length === numWorkers) {\n for(var i = 0; i < numWorkers; ++i) {\n workers[i].terminate();\n }\n callback(null, results);\n }\n });\n workers.push(worker);\n }\n for(var i = 0; i < numWorkers; ++i) {\n workers[i].postMessage(i);\n }\n }\n\n function reduce(numWorkers, results) {\n // find overlapping time windows\n var overlaps = [];\n for(var n = 0; n < numWorkers; ++n) {\n var r1 = results[n];\n var overlap = overlaps[n] = [];\n for(var i = 0; i < numWorkers; ++i) {\n if(n === i) {\n continue;\n }\n var r2 = results[i];\n if((r1.st > r2.st && r1.st < r2.et) ||\n (r2.st > r1.st && r2.st < r1.et)) {\n overlap.push(i);\n }\n }\n }\n // get maximum overlaps ... don't include overlapping worker itself\n // as the main JS process was also being scheduled during the work and\n // would have to be subtracted from the estimate anyway\n return overlaps.reduce(function(max, overlap) {\n return Math.max(max, overlap.length);\n }, 0);\n }\n};\n","/**\n * Base-N/Base-X encoding/decoding functions.\n *\n * Original implementation from base-x:\n * https://github.com/cryptocoinjs/base-x\n *\n * Which is MIT licensed:\n *\n * The MIT License (MIT)\n *\n * Copyright base-x contributors (c) 2016\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER\n * DEALINGS IN THE SOFTWARE.\n */\nvar api = {};\nmodule.exports = api;\n\n// baseN alphabet indexes\nvar _reverseAlphabets = {};\n\n/**\n * BaseN-encodes a Uint8Array using the given alphabet.\n *\n * @param input the Uint8Array to encode.\n * @param maxline the maximum number of encoded characters per line to use,\n * defaults to none.\n *\n * @return the baseN-encoded output string.\n */\napi.encode = function(input, alphabet, maxline) {\n if(typeof alphabet !== 'string') {\n throw new TypeError('\"alphabet\" must be a string.');\n }\n if(maxline !== undefined && typeof maxline !== 'number') {\n throw new TypeError('\"maxline\" must be a number.');\n }\n\n var output = '';\n\n if(!(input instanceof Uint8Array)) {\n // assume forge byte buffer\n output = _encodeWithByteBuffer(input, alphabet);\n } else {\n var i = 0;\n var base = alphabet.length;\n var first = alphabet.charAt(0);\n var digits = [0];\n for(i = 0; i < input.length; ++i) {\n for(var j = 0, carry = input[i]; j < digits.length; ++j) {\n carry += digits[j] << 8;\n digits[j] = carry % base;\n carry = (carry / base) | 0;\n }\n\n while(carry > 0) {\n digits.push(carry % base);\n carry = (carry / base) | 0;\n }\n }\n\n // deal with leading zeros\n for(i = 0; input[i] === 0 && i < input.length - 1; ++i) {\n output += first;\n }\n // convert digits to a string\n for(i = digits.length - 1; i >= 0; --i) {\n output += alphabet[digits[i]];\n }\n }\n\n if(maxline) {\n var regex = new RegExp('.{1,' + maxline + '}', 'g');\n output = output.match(regex).join('\\r\\n');\n }\n\n return output;\n};\n\n/**\n * Decodes a baseN-encoded (using the given alphabet) string to a\n * Uint8Array.\n *\n * @param input the baseN-encoded input string.\n *\n * @return the Uint8Array.\n */\napi.decode = function(input, alphabet) {\n if(typeof input !== 'string') {\n throw new TypeError('\"input\" must be a string.');\n }\n if(typeof alphabet !== 'string') {\n throw new TypeError('\"alphabet\" must be a string.');\n }\n\n var table = _reverseAlphabets[alphabet];\n if(!table) {\n // compute reverse alphabet\n table = _reverseAlphabets[alphabet] = [];\n for(var i = 0; i < alphabet.length; ++i) {\n table[alphabet.charCodeAt(i)] = i;\n }\n }\n\n // remove whitespace characters\n input = input.replace(/\\s/g, '');\n\n var base = alphabet.length;\n var first = alphabet.charAt(0);\n var bytes = [0];\n for(var i = 0; i < input.length; i++) {\n var value = table[input.charCodeAt(i)];\n if(value === undefined) {\n return;\n }\n\n for(var j = 0, carry = value; j < bytes.length; ++j) {\n carry += bytes[j] * base;\n bytes[j] = carry & 0xff;\n carry >>= 8;\n }\n\n while(carry > 0) {\n bytes.push(carry & 0xff);\n carry >>= 8;\n }\n }\n\n // deal with leading zeros\n for(var k = 0; input[k] === first && k < input.length - 1; ++k) {\n bytes.push(0);\n }\n\n if(typeof Buffer !== 'undefined') {\n return Buffer.from(bytes.reverse());\n }\n\n return new Uint8Array(bytes.reverse());\n};\n\nfunction _encodeWithByteBuffer(input, alphabet) {\n var i = 0;\n var base = alphabet.length;\n var first = alphabet.charAt(0);\n var digits = [0];\n for(i = 0; i < input.length(); ++i) {\n for(var j = 0, carry = input.at(i); j < digits.length; ++j) {\n carry += digits[j] << 8;\n digits[j] = carry % base;\n carry = (carry / base) | 0;\n }\n\n while(carry > 0) {\n digits.push(carry % base);\n carry = (carry / base) | 0;\n }\n }\n\n var output = '';\n\n // deal with leading zeros\n for(i = 0; input.at(i) === 0 && i < input.length() - 1; ++i) {\n output += first;\n }\n // convert digits to a string\n for(i = digits.length - 1; i >= 0; --i) {\n output += alphabet[digits[i]];\n }\n\n return output;\n}\n","/**\n * Object IDs for ASN.1.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\n\nforge.pki = forge.pki || {};\nvar oids = module.exports = forge.pki.oids = forge.oids = forge.oids || {};\n\n// set id to name mapping and name to id mapping\nfunction _IN(id, name) {\n oids[id] = name;\n oids[name] = id;\n}\n// set id to name mapping only\nfunction _I_(id, name) {\n oids[id] = name;\n}\n\n// algorithm OIDs\n_IN('1.2.840.113549.1.1.1', 'rsaEncryption');\n// Note: md2 & md4 not implemented\n//_IN('1.2.840.113549.1.1.2', 'md2WithRSAEncryption');\n//_IN('1.2.840.113549.1.1.3', 'md4WithRSAEncryption');\n_IN('1.2.840.113549.1.1.4', 'md5WithRSAEncryption');\n_IN('1.2.840.113549.1.1.5', 'sha1WithRSAEncryption');\n_IN('1.2.840.113549.1.1.7', 'RSAES-OAEP');\n_IN('1.2.840.113549.1.1.8', 'mgf1');\n_IN('1.2.840.113549.1.1.9', 'pSpecified');\n_IN('1.2.840.113549.1.1.10', 'RSASSA-PSS');\n_IN('1.2.840.113549.1.1.11', 'sha256WithRSAEncryption');\n_IN('1.2.840.113549.1.1.12', 'sha384WithRSAEncryption');\n_IN('1.2.840.113549.1.1.13', 'sha512WithRSAEncryption');\n// Edwards-curve Digital Signature Algorithm (EdDSA) Ed25519\n_IN('1.3.101.112', 'EdDSA25519');\n\n_IN('1.2.840.10040.4.3', 'dsa-with-sha1');\n\n_IN('1.3.14.3.2.7', 'desCBC');\n\n_IN('1.3.14.3.2.26', 'sha1');\n_IN('2.16.840.1.101.3.4.2.1', 'sha256');\n_IN('2.16.840.1.101.3.4.2.2', 'sha384');\n_IN('2.16.840.1.101.3.4.2.3', 'sha512');\n_IN('1.2.840.113549.2.5', 'md5');\n\n// pkcs#7 content types\n_IN('1.2.840.113549.1.7.1', 'data');\n_IN('1.2.840.113549.1.7.2', 'signedData');\n_IN('1.2.840.113549.1.7.3', 'envelopedData');\n_IN('1.2.840.113549.1.7.4', 'signedAndEnvelopedData');\n_IN('1.2.840.113549.1.7.5', 'digestedData');\n_IN('1.2.840.113549.1.7.6', 'encryptedData');\n\n// pkcs#9 oids\n_IN('1.2.840.113549.1.9.1', 'emailAddress');\n_IN('1.2.840.113549.1.9.2', 'unstructuredName');\n_IN('1.2.840.113549.1.9.3', 'contentType');\n_IN('1.2.840.113549.1.9.4', 'messageDigest');\n_IN('1.2.840.113549.1.9.5', 'signingTime');\n_IN('1.2.840.113549.1.9.6', 'counterSignature');\n_IN('1.2.840.113549.1.9.7', 'challengePassword');\n_IN('1.2.840.113549.1.9.8', 'unstructuredAddress');\n_IN('1.2.840.113549.1.9.14', 'extensionRequest');\n\n_IN('1.2.840.113549.1.9.20', 'friendlyName');\n_IN('1.2.840.113549.1.9.21', 'localKeyId');\n_IN('1.2.840.113549.1.9.22.1', 'x509Certificate');\n\n// pkcs#12 safe bags\n_IN('1.2.840.113549.1.12.10.1.1', 'keyBag');\n_IN('1.2.840.113549.1.12.10.1.2', 'pkcs8ShroudedKeyBag');\n_IN('1.2.840.113549.1.12.10.1.3', 'certBag');\n_IN('1.2.840.113549.1.12.10.1.4', 'crlBag');\n_IN('1.2.840.113549.1.12.10.1.5', 'secretBag');\n_IN('1.2.840.113549.1.12.10.1.6', 'safeContentsBag');\n\n// password-based-encryption for pkcs#12\n_IN('1.2.840.113549.1.5.13', 'pkcs5PBES2');\n_IN('1.2.840.113549.1.5.12', 'pkcs5PBKDF2');\n\n_IN('1.2.840.113549.1.12.1.1', 'pbeWithSHAAnd128BitRC4');\n_IN('1.2.840.113549.1.12.1.2', 'pbeWithSHAAnd40BitRC4');\n_IN('1.2.840.113549.1.12.1.3', 'pbeWithSHAAnd3-KeyTripleDES-CBC');\n_IN('1.2.840.113549.1.12.1.4', 'pbeWithSHAAnd2-KeyTripleDES-CBC');\n_IN('1.2.840.113549.1.12.1.5', 'pbeWithSHAAnd128BitRC2-CBC');\n_IN('1.2.840.113549.1.12.1.6', 'pbewithSHAAnd40BitRC2-CBC');\n\n// hmac OIDs\n_IN('1.2.840.113549.2.7', 'hmacWithSHA1');\n_IN('1.2.840.113549.2.8', 'hmacWithSHA224');\n_IN('1.2.840.113549.2.9', 'hmacWithSHA256');\n_IN('1.2.840.113549.2.10', 'hmacWithSHA384');\n_IN('1.2.840.113549.2.11', 'hmacWithSHA512');\n\n// symmetric key algorithm oids\n_IN('1.2.840.113549.3.7', 'des-EDE3-CBC');\n_IN('2.16.840.1.101.3.4.1.2', 'aes128-CBC');\n_IN('2.16.840.1.101.3.4.1.22', 'aes192-CBC');\n_IN('2.16.840.1.101.3.4.1.42', 'aes256-CBC');\n\n// certificate issuer/subject OIDs\n_IN('2.5.4.3', 'commonName');\n_IN('2.5.4.5', 'serialName');\n_IN('2.5.4.6', 'countryName');\n_IN('2.5.4.7', 'localityName');\n_IN('2.5.4.8', 'stateOrProvinceName');\n_IN('2.5.4.9', 'streetAddress');\n_IN('2.5.4.10', 'organizationName');\n_IN('2.5.4.11', 'organizationalUnitName');\n_IN('2.5.4.13', 'description');\n_IN('2.5.4.15', 'businessCategory');\n_IN('2.5.4.17', 'postalCode');\n_IN('1.3.6.1.4.1.311.60.2.1.2', 'jurisdictionOfIncorporationStateOrProvinceName');\n_IN('1.3.6.1.4.1.311.60.2.1.3', 'jurisdictionOfIncorporationCountryName');\n\n// X.509 extension OIDs\n_IN('2.16.840.1.113730.1.1', 'nsCertType');\n_IN('2.16.840.1.113730.1.13', 'nsComment'); // deprecated in theory; still widely used\n_I_('2.5.29.1', 'authorityKeyIdentifier'); // deprecated, use .35\n_I_('2.5.29.2', 'keyAttributes'); // obsolete use .37 or .15\n_I_('2.5.29.3', 'certificatePolicies'); // deprecated, use .32\n_I_('2.5.29.4', 'keyUsageRestriction'); // obsolete use .37 or .15\n_I_('2.5.29.5', 'policyMapping'); // deprecated use .33\n_I_('2.5.29.6', 'subtreesConstraint'); // obsolete use .30\n_I_('2.5.29.7', 'subjectAltName'); // deprecated use .17\n_I_('2.5.29.8', 'issuerAltName'); // deprecated use .18\n_I_('2.5.29.9', 'subjectDirectoryAttributes');\n_I_('2.5.29.10', 'basicConstraints'); // deprecated use .19\n_I_('2.5.29.11', 'nameConstraints'); // deprecated use .30\n_I_('2.5.29.12', 'policyConstraints'); // deprecated use .36\n_I_('2.5.29.13', 'basicConstraints'); // deprecated use .19\n_IN('2.5.29.14', 'subjectKeyIdentifier');\n_IN('2.5.29.15', 'keyUsage');\n_I_('2.5.29.16', 'privateKeyUsagePeriod');\n_IN('2.5.29.17', 'subjectAltName');\n_IN('2.5.29.18', 'issuerAltName');\n_IN('2.5.29.19', 'basicConstraints');\n_I_('2.5.29.20', 'cRLNumber');\n_I_('2.5.29.21', 'cRLReason');\n_I_('2.5.29.22', 'expirationDate');\n_I_('2.5.29.23', 'instructionCode');\n_I_('2.5.29.24', 'invalidityDate');\n_I_('2.5.29.25', 'cRLDistributionPoints'); // deprecated use .31\n_I_('2.5.29.26', 'issuingDistributionPoint'); // deprecated use .28\n_I_('2.5.29.27', 'deltaCRLIndicator');\n_I_('2.5.29.28', 'issuingDistributionPoint');\n_I_('2.5.29.29', 'certificateIssuer');\n_I_('2.5.29.30', 'nameConstraints');\n_IN('2.5.29.31', 'cRLDistributionPoints');\n_IN('2.5.29.32', 'certificatePolicies');\n_I_('2.5.29.33', 'policyMappings');\n_I_('2.5.29.34', 'policyConstraints'); // deprecated use .36\n_IN('2.5.29.35', 'authorityKeyIdentifier');\n_I_('2.5.29.36', 'policyConstraints');\n_IN('2.5.29.37', 'extKeyUsage');\n_I_('2.5.29.46', 'freshestCRL');\n_I_('2.5.29.54', 'inhibitAnyPolicy');\n\n// extKeyUsage purposes\n_IN('1.3.6.1.4.1.11129.2.4.2', 'timestampList');\n_IN('1.3.6.1.5.5.7.1.1', 'authorityInfoAccess');\n_IN('1.3.6.1.5.5.7.3.1', 'serverAuth');\n_IN('1.3.6.1.5.5.7.3.2', 'clientAuth');\n_IN('1.3.6.1.5.5.7.3.3', 'codeSigning');\n_IN('1.3.6.1.5.5.7.3.4', 'emailProtection');\n_IN('1.3.6.1.5.5.7.3.8', 'timeStamping');\n","/**\n * Password-based encryption functions.\n *\n * @author Dave Longley\n * @author Stefan Siegl \n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl \n *\n * An EncryptedPrivateKeyInfo:\n *\n * EncryptedPrivateKeyInfo ::= SEQUENCE {\n * encryptionAlgorithm EncryptionAlgorithmIdentifier,\n * encryptedData EncryptedData }\n *\n * EncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * EncryptedData ::= OCTET STRING\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./md');\nrequire('./oids');\nrequire('./pbkdf2');\nrequire('./pem');\nrequire('./random');\nrequire('./rc2');\nrequire('./rsa');\nrequire('./util');\n\nif(typeof BigInteger === 'undefined') {\n var BigInteger = forge.jsbn.BigInteger;\n}\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n/* Password-based encryption implementation. */\nvar pki = forge.pki = forge.pki || {};\nmodule.exports = pki.pbe = forge.pbe = forge.pbe || {};\nvar oids = pki.oids;\n\n// validator for an EncryptedPrivateKeyInfo structure\n// Note: Currently only works w/algorithm params\nvar encryptedPrivateKeyValidator = {\n name: 'EncryptedPrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedPrivateKeyInfo.encryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encryptionOid'\n }, {\n name: 'AlgorithmIdentifier.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'encryptionParams'\n }]\n }, {\n // encryptedData\n name: 'EncryptedPrivateKeyInfo.encryptedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encryptedData'\n }]\n};\n\n// validator for a PBES2Algorithms structure\n// Note: Currently only works w/PBKDF2 + AES encryption schemes\nvar PBES2AlgorithmsValidator = {\n name: 'PBES2Algorithms',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.keyDerivationFunc',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.keyDerivationFunc.oid',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'kdfOid'\n }, {\n name: 'PBES2Algorithms.params',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.params.salt',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'kdfSalt'\n }, {\n name: 'PBES2Algorithms.params.iterationCount',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'kdfIterationCount'\n }, {\n name: 'PBES2Algorithms.params.keyLength',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n optional: true,\n capture: 'keyLength'\n }, {\n // prf\n name: 'PBES2Algorithms.params.prf',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n value: [{\n name: 'PBES2Algorithms.params.prf.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'prfOid'\n }]\n }]\n }]\n }, {\n name: 'PBES2Algorithms.encryptionScheme',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.encryptionScheme.oid',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encOid'\n }, {\n name: 'PBES2Algorithms.encryptionScheme.iv',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encIv'\n }]\n }]\n};\n\nvar pkcs12PbeParamsValidator = {\n name: 'pkcs-12PbeParams',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'pkcs-12PbeParams.salt',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'salt'\n }, {\n name: 'pkcs-12PbeParams.iterations',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'iterations'\n }]\n};\n\n/**\n * Encrypts a ASN.1 PrivateKeyInfo object, producing an EncryptedPrivateKeyInfo.\n *\n * PBES2Algorithms ALGORITHM-IDENTIFIER ::=\n * { {PBES2-params IDENTIFIED BY id-PBES2}, ...}\n *\n * id-PBES2 OBJECT IDENTIFIER ::= {pkcs-5 13}\n *\n * PBES2-params ::= SEQUENCE {\n * keyDerivationFunc AlgorithmIdentifier {{PBES2-KDFs}},\n * encryptionScheme AlgorithmIdentifier {{PBES2-Encs}}\n * }\n *\n * PBES2-KDFs ALGORITHM-IDENTIFIER ::=\n * { {PBKDF2-params IDENTIFIED BY id-PBKDF2}, ... }\n *\n * PBES2-Encs ALGORITHM-IDENTIFIER ::= { ... }\n *\n * PBKDF2-params ::= SEQUENCE {\n * salt CHOICE {\n * specified OCTET STRING,\n * otherSource AlgorithmIdentifier {{PBKDF2-SaltSources}}\n * },\n * iterationCount INTEGER (1..MAX),\n * keyLength INTEGER (1..MAX) OPTIONAL,\n * prf AlgorithmIdentifier {{PBKDF2-PRFs}} DEFAULT algid-hmacWithSHA1\n * }\n *\n * @param obj the ASN.1 PrivateKeyInfo object.\n * @param password the password to encrypt with.\n * @param options:\n * algorithm the encryption algorithm to use\n * ('aes128', 'aes192', 'aes256', '3des'), defaults to 'aes128'.\n * count the iteration count to use.\n * saltSize the salt size to use.\n * prfAlgorithm the PRF message digest algorithm to use\n * ('sha1', 'sha224', 'sha256', 'sha384', 'sha512')\n *\n * @return the ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptPrivateKeyInfo = function(obj, password, options) {\n // set default options\n options = options || {};\n options.saltSize = options.saltSize || 8;\n options.count = options.count || 2048;\n options.algorithm = options.algorithm || 'aes128';\n options.prfAlgorithm = options.prfAlgorithm || 'sha1';\n\n // generate PBE params\n var salt = forge.random.getBytesSync(options.saltSize);\n var count = options.count;\n var countBytes = asn1.integerToDer(count);\n var dkLen;\n var encryptionAlgorithm;\n var encryptedData;\n if(options.algorithm.indexOf('aes') === 0 || options.algorithm === 'des') {\n // do PBES2\n var ivLen, encOid, cipherFn;\n switch(options.algorithm) {\n case 'aes128':\n dkLen = 16;\n ivLen = 16;\n encOid = oids['aes128-CBC'];\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes192':\n dkLen = 24;\n ivLen = 16;\n encOid = oids['aes192-CBC'];\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes256':\n dkLen = 32;\n ivLen = 16;\n encOid = oids['aes256-CBC'];\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'des':\n dkLen = 8;\n ivLen = 8;\n encOid = oids['desCBC'];\n cipherFn = forge.des.createEncryptionCipher;\n break;\n default:\n var error = new Error('Cannot encrypt private key. Unknown encryption algorithm.');\n error.algorithm = options.algorithm;\n throw error;\n }\n\n // get PRF message digest\n var prfAlgorithm = 'hmacWith' + options.prfAlgorithm.toUpperCase();\n var md = prfAlgorithmToMessageDigest(prfAlgorithm);\n\n // encrypt private key using pbe SHA-1 and AES/DES\n var dk = forge.pkcs5.pbkdf2(password, salt, count, dkLen, md);\n var iv = forge.random.getBytesSync(ivLen);\n var cipher = cipherFn(dk);\n cipher.start(iv);\n cipher.update(asn1.toDer(obj));\n cipher.finish();\n encryptedData = cipher.output.getBytes();\n\n // get PBKDF2-params\n var params = createPbkdf2Params(salt, countBytes, dkLen, prfAlgorithm);\n\n encryptionAlgorithm = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oids['pkcs5PBES2']).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // keyDerivationFunc\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oids['pkcs5PBKDF2']).getBytes()),\n // PBKDF2-params\n params\n ]),\n // encryptionScheme\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(encOid).getBytes()),\n // iv\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, iv)\n ])\n ])\n ]);\n } else if(options.algorithm === '3des') {\n // Do PKCS12 PBE\n dkLen = 24;\n\n var saltBytes = new forge.util.ByteBuffer(salt);\n var dk = pki.pbe.generatePkcs12Key(password, saltBytes, 1, count, dkLen);\n var iv = pki.pbe.generatePkcs12Key(password, saltBytes, 2, count, dkLen);\n var cipher = forge.des.createEncryptionCipher(dk);\n cipher.start(iv);\n cipher.update(asn1.toDer(obj));\n cipher.finish();\n encryptedData = cipher.output.getBytes();\n\n encryptionAlgorithm = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oids['pbeWithSHAAnd3-KeyTripleDES-CBC']).getBytes()),\n // pkcs-12PbeParams\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // salt\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, salt),\n // iteration count\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n countBytes.getBytes())\n ])\n ]);\n } else {\n var error = new Error('Cannot encrypt private key. Unknown encryption algorithm.');\n error.algorithm = options.algorithm;\n throw error;\n }\n\n // EncryptedPrivateKeyInfo\n var rval = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // encryptionAlgorithm\n encryptionAlgorithm,\n // encryptedData\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, encryptedData)\n ]);\n return rval;\n};\n\n/**\n * Decrypts a ASN.1 PrivateKeyInfo object.\n *\n * @param obj the ASN.1 EncryptedPrivateKeyInfo object.\n * @param password the password to decrypt with.\n *\n * @return the ASN.1 PrivateKeyInfo on success, null on failure.\n */\npki.decryptPrivateKeyInfo = function(obj, password) {\n var rval = null;\n\n // get PBE params\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, encryptedPrivateKeyValidator, capture, errors)) {\n var error = new Error('Cannot read encrypted private key. ' +\n 'ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n error.errors = errors;\n throw error;\n }\n\n // get cipher\n var oid = asn1.derToOid(capture.encryptionOid);\n var cipher = pki.pbe.getCipher(oid, capture.encryptionParams, password);\n\n // get encrypted data\n var encrypted = forge.util.createBuffer(capture.encryptedData);\n\n cipher.update(encrypted);\n if(cipher.finish()) {\n rval = asn1.fromDer(cipher.output);\n }\n\n return rval;\n};\n\n/**\n * Converts a EncryptedPrivateKeyInfo to PEM format.\n *\n * @param epki the EncryptedPrivateKeyInfo.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted encrypted private key.\n */\npki.encryptedPrivateKeyToPem = function(epki, maxline) {\n // convert to DER, then PEM-encode\n var msg = {\n type: 'ENCRYPTED PRIVATE KEY',\n body: asn1.toDer(epki).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts a PEM-encoded EncryptedPrivateKeyInfo to ASN.1 format. Decryption\n * is not performed.\n *\n * @param pem the EncryptedPrivateKeyInfo in PEM-format.\n *\n * @return the ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptedPrivateKeyFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'ENCRYPTED PRIVATE KEY') {\n var error = new Error('Could not convert encrypted private key from PEM; ' +\n 'PEM header type is \"ENCRYPTED PRIVATE KEY\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert encrypted private key from PEM; ' +\n 'PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n return asn1.fromDer(msg.body);\n};\n\n/**\n * Encrypts an RSA private key. By default, the key will be wrapped in\n * a PrivateKeyInfo and encrypted to produce a PKCS#8 EncryptedPrivateKeyInfo.\n * This is the standard, preferred way to encrypt a private key.\n *\n * To produce a non-standard PEM-encrypted private key that uses encapsulated\n * headers to indicate the encryption algorithm (old-style non-PKCS#8 OpenSSL\n * private key encryption), set the 'legacy' option to true. Note: Using this\n * option will cause the iteration count to be forced to 1.\n *\n * Note: The 'des' algorithm is supported, but it is not considered to be\n * secure because it only uses a single 56-bit key. If possible, it is highly\n * recommended that a different algorithm be used.\n *\n * @param rsaKey the RSA key to encrypt.\n * @param password the password to use.\n * @param options:\n * algorithm: the encryption algorithm to use\n * ('aes128', 'aes192', 'aes256', '3des', 'des').\n * count: the iteration count to use.\n * saltSize: the salt size to use.\n * legacy: output an old non-PKCS#8 PEM-encrypted+encapsulated\n * headers (DEK-Info) private key.\n *\n * @return the PEM-encoded ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptRsaPrivateKey = function(rsaKey, password, options) {\n // standard PKCS#8\n options = options || {};\n if(!options.legacy) {\n // encrypt PrivateKeyInfo\n var rval = pki.wrapRsaPrivateKey(pki.privateKeyToAsn1(rsaKey));\n rval = pki.encryptPrivateKeyInfo(rval, password, options);\n return pki.encryptedPrivateKeyToPem(rval);\n }\n\n // legacy non-PKCS#8\n var algorithm;\n var iv;\n var dkLen;\n var cipherFn;\n switch(options.algorithm) {\n case 'aes128':\n algorithm = 'AES-128-CBC';\n dkLen = 16;\n iv = forge.random.getBytesSync(16);\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes192':\n algorithm = 'AES-192-CBC';\n dkLen = 24;\n iv = forge.random.getBytesSync(16);\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes256':\n algorithm = 'AES-256-CBC';\n dkLen = 32;\n iv = forge.random.getBytesSync(16);\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case '3des':\n algorithm = 'DES-EDE3-CBC';\n dkLen = 24;\n iv = forge.random.getBytesSync(8);\n cipherFn = forge.des.createEncryptionCipher;\n break;\n case 'des':\n algorithm = 'DES-CBC';\n dkLen = 8;\n iv = forge.random.getBytesSync(8);\n cipherFn = forge.des.createEncryptionCipher;\n break;\n default:\n var error = new Error('Could not encrypt RSA private key; unsupported ' +\n 'encryption algorithm \"' + options.algorithm + '\".');\n error.algorithm = options.algorithm;\n throw error;\n }\n\n // encrypt private key using OpenSSL legacy key derivation\n var dk = forge.pbe.opensslDeriveBytes(password, iv.substr(0, 8), dkLen);\n var cipher = cipherFn(dk);\n cipher.start(iv);\n cipher.update(asn1.toDer(pki.privateKeyToAsn1(rsaKey)));\n cipher.finish();\n\n var msg = {\n type: 'RSA PRIVATE KEY',\n procType: {\n version: '4',\n type: 'ENCRYPTED'\n },\n dekInfo: {\n algorithm: algorithm,\n parameters: forge.util.bytesToHex(iv).toUpperCase()\n },\n body: cipher.output.getBytes()\n };\n return forge.pem.encode(msg);\n};\n\n/**\n * Decrypts an RSA private key.\n *\n * @param pem the PEM-formatted EncryptedPrivateKeyInfo to decrypt.\n * @param password the password to use.\n *\n * @return the RSA key on success, null on failure.\n */\npki.decryptRsaPrivateKey = function(pem, password) {\n var rval = null;\n\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'ENCRYPTED PRIVATE KEY' &&\n msg.type !== 'PRIVATE KEY' &&\n msg.type !== 'RSA PRIVATE KEY') {\n var error = new Error('Could not convert private key from PEM; PEM header type ' +\n 'is not \"ENCRYPTED PRIVATE KEY\", \"PRIVATE KEY\", or \"RSA PRIVATE KEY\".');\n error.headerType = error;\n throw error;\n }\n\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n var dkLen;\n var cipherFn;\n switch(msg.dekInfo.algorithm) {\n case 'DES-CBC':\n dkLen = 8;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n case 'DES-EDE3-CBC':\n dkLen = 24;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n case 'AES-128-CBC':\n dkLen = 16;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'AES-192-CBC':\n dkLen = 24;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'AES-256-CBC':\n dkLen = 32;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'RC2-40-CBC':\n dkLen = 5;\n cipherFn = function(key) {\n return forge.rc2.createDecryptionCipher(key, 40);\n };\n break;\n case 'RC2-64-CBC':\n dkLen = 8;\n cipherFn = function(key) {\n return forge.rc2.createDecryptionCipher(key, 64);\n };\n break;\n case 'RC2-128-CBC':\n dkLen = 16;\n cipherFn = function(key) {\n return forge.rc2.createDecryptionCipher(key, 128);\n };\n break;\n default:\n var error = new Error('Could not decrypt private key; unsupported ' +\n 'encryption algorithm \"' + msg.dekInfo.algorithm + '\".');\n error.algorithm = msg.dekInfo.algorithm;\n throw error;\n }\n\n // use OpenSSL legacy key derivation\n var iv = forge.util.hexToBytes(msg.dekInfo.parameters);\n var dk = forge.pbe.opensslDeriveBytes(password, iv.substr(0, 8), dkLen);\n var cipher = cipherFn(dk);\n cipher.start(iv);\n cipher.update(forge.util.createBuffer(msg.body));\n if(cipher.finish()) {\n rval = cipher.output.getBytes();\n } else {\n return rval;\n }\n } else {\n rval = msg.body;\n }\n\n if(msg.type === 'ENCRYPTED PRIVATE KEY') {\n rval = pki.decryptPrivateKeyInfo(asn1.fromDer(rval), password);\n } else {\n // decryption already performed above\n rval = asn1.fromDer(rval);\n }\n\n if(rval !== null) {\n rval = pki.privateKeyFromAsn1(rval);\n }\n\n return rval;\n};\n\n/**\n * Derives a PKCS#12 key.\n *\n * @param password the password to derive the key material from, null or\n * undefined for none.\n * @param salt the salt, as a ByteBuffer, to use.\n * @param id the PKCS#12 ID byte (1 = key material, 2 = IV, 3 = MAC).\n * @param iter the iteration count.\n * @param n the number of bytes to derive from the password.\n * @param md the message digest to use, defaults to SHA-1.\n *\n * @return a ByteBuffer with the bytes derived from the password.\n */\npki.pbe.generatePkcs12Key = function(password, salt, id, iter, n, md) {\n var j, l;\n\n if(typeof md === 'undefined' || md === null) {\n if(!('sha1' in forge.md)) {\n throw new Error('\"sha1\" hash algorithm unavailable.');\n }\n md = forge.md.sha1.create();\n }\n\n var u = md.digestLength;\n var v = md.blockLength;\n var result = new forge.util.ByteBuffer();\n\n /* Convert password to Unicode byte buffer + trailing 0-byte. */\n var passBuf = new forge.util.ByteBuffer();\n if(password !== null && password !== undefined) {\n for(l = 0; l < password.length; l++) {\n passBuf.putInt16(password.charCodeAt(l));\n }\n passBuf.putInt16(0);\n }\n\n /* Length of salt and password in BYTES. */\n var p = passBuf.length();\n var s = salt.length();\n\n /* 1. Construct a string, D (the \"diversifier\"), by concatenating\n v copies of ID. */\n var D = new forge.util.ByteBuffer();\n D.fillWithByte(id, v);\n\n /* 2. Concatenate copies of the salt together to create a string S of length\n v * ceil(s / v) bytes (the final copy of the salt may be trunacted\n to create S).\n Note that if the salt is the empty string, then so is S. */\n var Slen = v * Math.ceil(s / v);\n var S = new forge.util.ByteBuffer();\n for(l = 0; l < Slen; l++) {\n S.putByte(salt.at(l % s));\n }\n\n /* 3. Concatenate copies of the password together to create a string P of\n length v * ceil(p / v) bytes (the final copy of the password may be\n truncated to create P).\n Note that if the password is the empty string, then so is P. */\n var Plen = v * Math.ceil(p / v);\n var P = new forge.util.ByteBuffer();\n for(l = 0; l < Plen; l++) {\n P.putByte(passBuf.at(l % p));\n }\n\n /* 4. Set I=S||P to be the concatenation of S and P. */\n var I = S;\n I.putBuffer(P);\n\n /* 5. Set c=ceil(n / u). */\n var c = Math.ceil(n / u);\n\n /* 6. For i=1, 2, ..., c, do the following: */\n for(var i = 1; i <= c; i++) {\n /* a) Set Ai=H^r(D||I). (l.e. the rth hash of D||I, H(H(H(...H(D||I)))) */\n var buf = new forge.util.ByteBuffer();\n buf.putBytes(D.bytes());\n buf.putBytes(I.bytes());\n for(var round = 0; round < iter; round++) {\n md.start();\n md.update(buf.getBytes());\n buf = md.digest();\n }\n\n /* b) Concatenate copies of Ai to create a string B of length v bytes (the\n final copy of Ai may be truncated to create B). */\n var B = new forge.util.ByteBuffer();\n for(l = 0; l < v; l++) {\n B.putByte(buf.at(l % u));\n }\n\n /* c) Treating I as a concatenation I0, I1, ..., Ik-1 of v-byte blocks,\n where k=ceil(s / v) + ceil(p / v), modify I by setting\n Ij=(Ij+B+1) mod 2v for each j. */\n var k = Math.ceil(s / v) + Math.ceil(p / v);\n var Inew = new forge.util.ByteBuffer();\n for(j = 0; j < k; j++) {\n var chunk = new forge.util.ByteBuffer(I.getBytes(v));\n var x = 0x1ff;\n for(l = B.length() - 1; l >= 0; l--) {\n x = x >> 8;\n x += B.at(l) + chunk.at(l);\n chunk.setAt(l, x & 0xff);\n }\n Inew.putBuffer(chunk);\n }\n I = Inew;\n\n /* Add Ai to A. */\n result.putBuffer(buf);\n }\n\n result.truncate(result.length() - n);\n return result;\n};\n\n/**\n * Get new Forge cipher object instance.\n *\n * @param oid the OID (in string notation).\n * @param params the ASN.1 params object.\n * @param password the password to decrypt with.\n *\n * @return new cipher object instance.\n */\npki.pbe.getCipher = function(oid, params, password) {\n switch(oid) {\n case pki.oids['pkcs5PBES2']:\n return pki.pbe.getCipherForPBES2(oid, params, password);\n\n case pki.oids['pbeWithSHAAnd3-KeyTripleDES-CBC']:\n case pki.oids['pbewithSHAAnd40BitRC2-CBC']:\n return pki.pbe.getCipherForPKCS12PBE(oid, params, password);\n\n default:\n var error = new Error('Cannot read encrypted PBE data block. Unsupported OID.');\n error.oid = oid;\n error.supportedOids = [\n 'pkcs5PBES2',\n 'pbeWithSHAAnd3-KeyTripleDES-CBC',\n 'pbewithSHAAnd40BitRC2-CBC'\n ];\n throw error;\n }\n};\n\n/**\n * Get new Forge cipher object instance according to PBES2 params block.\n *\n * The returned cipher instance is already started using the IV\n * from PBES2 parameter block.\n *\n * @param oid the PKCS#5 PBKDF2 OID (in string notation).\n * @param params the ASN.1 PBES2-params object.\n * @param password the password to decrypt with.\n *\n * @return new cipher object instance.\n */\npki.pbe.getCipherForPBES2 = function(oid, params, password) {\n // get PBE params\n var capture = {};\n var errors = [];\n if(!asn1.validate(params, PBES2AlgorithmsValidator, capture, errors)) {\n var error = new Error('Cannot read password-based-encryption algorithm ' +\n 'parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n error.errors = errors;\n throw error;\n }\n\n // check oids\n oid = asn1.derToOid(capture.kdfOid);\n if(oid !== pki.oids['pkcs5PBKDF2']) {\n var error = new Error('Cannot read encrypted private key. ' +\n 'Unsupported key derivation function OID.');\n error.oid = oid;\n error.supportedOids = ['pkcs5PBKDF2'];\n throw error;\n }\n oid = asn1.derToOid(capture.encOid);\n if(oid !== pki.oids['aes128-CBC'] &&\n oid !== pki.oids['aes192-CBC'] &&\n oid !== pki.oids['aes256-CBC'] &&\n oid !== pki.oids['des-EDE3-CBC'] &&\n oid !== pki.oids['desCBC']) {\n var error = new Error('Cannot read encrypted private key. ' +\n 'Unsupported encryption scheme OID.');\n error.oid = oid;\n error.supportedOids = [\n 'aes128-CBC', 'aes192-CBC', 'aes256-CBC', 'des-EDE3-CBC', 'desCBC'];\n throw error;\n }\n\n // set PBE params\n var salt = capture.kdfSalt;\n var count = forge.util.createBuffer(capture.kdfIterationCount);\n count = count.getInt(count.length() << 3);\n var dkLen;\n var cipherFn;\n switch(pki.oids[oid]) {\n case 'aes128-CBC':\n dkLen = 16;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'aes192-CBC':\n dkLen = 24;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'aes256-CBC':\n dkLen = 32;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'des-EDE3-CBC':\n dkLen = 24;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n case 'desCBC':\n dkLen = 8;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n }\n\n // get PRF message digest\n var md = prfOidToMessageDigest(capture.prfOid);\n\n // decrypt private key using pbe with chosen PRF and AES/DES\n var dk = forge.pkcs5.pbkdf2(password, salt, count, dkLen, md);\n var iv = capture.encIv;\n var cipher = cipherFn(dk);\n cipher.start(iv);\n\n return cipher;\n};\n\n/**\n * Get new Forge cipher object instance for PKCS#12 PBE.\n *\n * The returned cipher instance is already started using the key & IV\n * derived from the provided password and PKCS#12 PBE salt.\n *\n * @param oid The PKCS#12 PBE OID (in string notation).\n * @param params The ASN.1 PKCS#12 PBE-params object.\n * @param password The password to decrypt with.\n *\n * @return the new cipher object instance.\n */\npki.pbe.getCipherForPKCS12PBE = function(oid, params, password) {\n // get PBE params\n var capture = {};\n var errors = [];\n if(!asn1.validate(params, pkcs12PbeParamsValidator, capture, errors)) {\n var error = new Error('Cannot read password-based-encryption algorithm ' +\n 'parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n error.errors = errors;\n throw error;\n }\n\n var salt = forge.util.createBuffer(capture.salt);\n var count = forge.util.createBuffer(capture.iterations);\n count = count.getInt(count.length() << 3);\n\n var dkLen, dIvLen, cipherFn;\n switch(oid) {\n case pki.oids['pbeWithSHAAnd3-KeyTripleDES-CBC']:\n dkLen = 24;\n dIvLen = 8;\n cipherFn = forge.des.startDecrypting;\n break;\n\n case pki.oids['pbewithSHAAnd40BitRC2-CBC']:\n dkLen = 5;\n dIvLen = 8;\n cipherFn = function(key, iv) {\n var cipher = forge.rc2.createDecryptionCipher(key, 40);\n cipher.start(iv, null);\n return cipher;\n };\n break;\n\n default:\n var error = new Error('Cannot read PKCS #12 PBE data block. Unsupported OID.');\n error.oid = oid;\n throw error;\n }\n\n // get PRF message digest\n var md = prfOidToMessageDigest(capture.prfOid);\n var key = pki.pbe.generatePkcs12Key(password, salt, 1, count, dkLen, md);\n md.start();\n var iv = pki.pbe.generatePkcs12Key(password, salt, 2, count, dIvLen, md);\n\n return cipherFn(key, iv);\n};\n\n/**\n * OpenSSL's legacy key derivation function.\n *\n * See: http://www.openssl.org/docs/crypto/EVP_BytesToKey.html\n *\n * @param password the password to derive the key from.\n * @param salt the salt to use, null for none.\n * @param dkLen the number of bytes needed for the derived key.\n * @param [options] the options to use:\n * [md] an optional message digest object to use.\n */\npki.pbe.opensslDeriveBytes = function(password, salt, dkLen, md) {\n if(typeof md === 'undefined' || md === null) {\n if(!('md5' in forge.md)) {\n throw new Error('\"md5\" hash algorithm unavailable.');\n }\n md = forge.md.md5.create();\n }\n if(salt === null) {\n salt = '';\n }\n var digests = [hash(md, password + salt)];\n for(var length = 16, i = 1; length < dkLen; ++i, length += 16) {\n digests.push(hash(md, digests[i - 1] + password + salt));\n }\n return digests.join('').substr(0, dkLen);\n};\n\nfunction hash(md, bytes) {\n return md.start().update(bytes).digest().getBytes();\n}\n\nfunction prfOidToMessageDigest(prfOid) {\n // get PRF algorithm, default to SHA-1\n var prfAlgorithm;\n if(!prfOid) {\n prfAlgorithm = 'hmacWithSHA1';\n } else {\n prfAlgorithm = pki.oids[asn1.derToOid(prfOid)];\n if(!prfAlgorithm) {\n var error = new Error('Unsupported PRF OID.');\n error.oid = prfOid;\n error.supported = [\n 'hmacWithSHA1', 'hmacWithSHA224', 'hmacWithSHA256', 'hmacWithSHA384',\n 'hmacWithSHA512'];\n throw error;\n }\n }\n return prfAlgorithmToMessageDigest(prfAlgorithm);\n}\n\nfunction prfAlgorithmToMessageDigest(prfAlgorithm) {\n var factory = forge.md;\n switch(prfAlgorithm) {\n case 'hmacWithSHA224':\n factory = forge.md.sha512;\n case 'hmacWithSHA1':\n case 'hmacWithSHA256':\n case 'hmacWithSHA384':\n case 'hmacWithSHA512':\n prfAlgorithm = prfAlgorithm.substr(8).toLowerCase();\n break;\n default:\n var error = new Error('Unsupported PRF algorithm.');\n error.algorithm = prfAlgorithm;\n error.supported = [\n 'hmacWithSHA1', 'hmacWithSHA224', 'hmacWithSHA256', 'hmacWithSHA384',\n 'hmacWithSHA512'];\n throw error;\n }\n if(!factory || !(prfAlgorithm in factory)) {\n throw new Error('Unknown hash algorithm: ' + prfAlgorithm);\n }\n return factory[prfAlgorithm].create();\n}\n\nfunction createPbkdf2Params(salt, countBytes, dkLen, prfAlgorithm) {\n var params = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // salt\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, salt),\n // iteration count\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n countBytes.getBytes())\n ]);\n // when PRF algorithm is not SHA-1 default, add key length and PRF algorithm\n if(prfAlgorithm !== 'hmacWithSHA1') {\n params.value.push(\n // key length\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(dkLen.toString(16))),\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids[prfAlgorithm]).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n }\n return params;\n}\n","/**\n * Advanced Encryption Standard (AES) implementation.\n *\n * This implementation is based on the public domain library 'jscrypto' which\n * was written by:\n *\n * Emily Stark (estark@stanford.edu)\n * Mike Hamburg (mhamburg@stanford.edu)\n * Dan Boneh (dabo@cs.stanford.edu)\n *\n * Parts of this code are based on the OpenSSL implementation of AES:\n * http://www.openssl.org\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./cipher');\nrequire('./cipherModes');\nrequire('./util');\n\n/* AES API */\nmodule.exports = forge.aes = forge.aes || {};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('AES-', key);\n * cipher.start({iv: iv});\n *\n * Creates an AES cipher object to encrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as a string of bytes, an array of bytes,\n * a byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.startEncrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: false,\n mode: mode\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('AES-', key);\n *\n * Creates an AES cipher object to encrypt data using the given symmetric key.\n *\n * The key may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.createEncryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: false,\n mode: mode\n });\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('AES-', key);\n * decipher.start({iv: iv});\n *\n * Creates an AES cipher object to decrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as a string of bytes, an array of bytes,\n * a byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.startDecrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: true,\n mode: mode\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('AES-', key);\n *\n * Creates an AES cipher object to decrypt data using the given symmetric key.\n *\n * The key may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.createDecryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: true,\n mode: mode\n });\n};\n\n/**\n * Creates a new AES cipher algorithm object.\n *\n * @param name the name of the algorithm.\n * @param mode the mode factory function.\n *\n * @return the AES algorithm object.\n */\nforge.aes.Algorithm = function(name, mode) {\n if(!init) {\n initialize();\n }\n var self = this;\n self.name = name;\n self.mode = new mode({\n blockSize: 16,\n cipher: {\n encrypt: function(inBlock, outBlock) {\n return _updateBlock(self._w, inBlock, outBlock, false);\n },\n decrypt: function(inBlock, outBlock) {\n return _updateBlock(self._w, inBlock, outBlock, true);\n }\n }\n });\n self._init = false;\n};\n\n/**\n * Initializes this AES algorithm by expanding its key.\n *\n * @param options the options to use.\n * key the key to use with this algorithm.\n * decrypt true if the algorithm should be initialized for decryption,\n * false for encryption.\n */\nforge.aes.Algorithm.prototype.initialize = function(options) {\n if(this._init) {\n return;\n }\n\n var key = options.key;\n var tmp;\n\n /* Note: The key may be a string of bytes, an array of bytes, a byte\n buffer, or an array of 32-bit integers. If the key is in bytes, then\n it must be 16, 24, or 32 bytes in length. If it is in 32-bit\n integers, it must be 4, 6, or 8 integers long. */\n\n if(typeof key === 'string' &&\n (key.length === 16 || key.length === 24 || key.length === 32)) {\n // convert key string into byte buffer\n key = forge.util.createBuffer(key);\n } else if(forge.util.isArray(key) &&\n (key.length === 16 || key.length === 24 || key.length === 32)) {\n // convert key integer array into byte buffer\n tmp = key;\n key = forge.util.createBuffer();\n for(var i = 0; i < tmp.length; ++i) {\n key.putByte(tmp[i]);\n }\n }\n\n // convert key byte buffer into 32-bit integer array\n if(!forge.util.isArray(key)) {\n tmp = key;\n key = [];\n\n // key lengths of 16, 24, 32 bytes allowed\n var len = tmp.length();\n if(len === 16 || len === 24 || len === 32) {\n len = len >>> 2;\n for(var i = 0; i < len; ++i) {\n key.push(tmp.getInt32());\n }\n }\n }\n\n // key must be an array of 32-bit integers by now\n if(!forge.util.isArray(key) ||\n !(key.length === 4 || key.length === 6 || key.length === 8)) {\n throw new Error('Invalid key parameter.');\n }\n\n // encryption operation is always used for these modes\n var mode = this.mode.name;\n var encryptOp = (['CFB', 'OFB', 'CTR', 'GCM'].indexOf(mode) !== -1);\n\n // do key expansion\n this._w = _expandKey(key, options.decrypt && !encryptOp);\n this._init = true;\n};\n\n/**\n * Expands a key. Typically only used for testing.\n *\n * @param key the symmetric key to expand, as an array of 32-bit words.\n * @param decrypt true to expand for decryption, false for encryption.\n *\n * @return the expanded key.\n */\nforge.aes._expandKey = function(key, decrypt) {\n if(!init) {\n initialize();\n }\n return _expandKey(key, decrypt);\n};\n\n/**\n * Updates a single block. Typically only used for testing.\n *\n * @param w the expanded key to use.\n * @param input an array of block-size 32-bit words.\n * @param output an array of block-size 32-bit words.\n * @param decrypt true to decrypt, false to encrypt.\n */\nforge.aes._updateBlock = _updateBlock;\n\n/** Register AES algorithms **/\n\nregisterAlgorithm('AES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('AES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('AES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('AES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('AES-CTR', forge.cipher.modes.ctr);\nregisterAlgorithm('AES-GCM', forge.cipher.modes.gcm);\n\nfunction registerAlgorithm(name, mode) {\n var factory = function() {\n return new forge.aes.Algorithm(name, mode);\n };\n forge.cipher.registerAlgorithm(name, factory);\n}\n\n/** AES implementation **/\n\nvar init = false; // not yet initialized\nvar Nb = 4; // number of words comprising the state (AES = 4)\nvar sbox; // non-linear substitution table used in key expansion\nvar isbox; // inversion of sbox\nvar rcon; // round constant word array\nvar mix; // mix-columns table\nvar imix; // inverse mix-columns table\n\n/**\n * Performs initialization, ie: precomputes tables to optimize for speed.\n *\n * One way to understand how AES works is to imagine that 'addition' and\n * 'multiplication' are interfaces that require certain mathematical\n * properties to hold true (ie: they are associative) but they might have\n * different implementations and produce different kinds of results ...\n * provided that their mathematical properties remain true. AES defines\n * its own methods of addition and multiplication but keeps some important\n * properties the same, ie: associativity and distributivity. The\n * explanation below tries to shed some light on how AES defines addition\n * and multiplication of bytes and 32-bit words in order to perform its\n * encryption and decryption algorithms.\n *\n * The basics:\n *\n * The AES algorithm views bytes as binary representations of polynomials\n * that have either 1 or 0 as the coefficients. It defines the addition\n * or subtraction of two bytes as the XOR operation. It also defines the\n * multiplication of two bytes as a finite field referred to as GF(2^8)\n * (Note: 'GF' means \"Galois Field\" which is a field that contains a finite\n * number of elements so GF(2^8) has 256 elements).\n *\n * This means that any two bytes can be represented as binary polynomials;\n * when they multiplied together and modularly reduced by an irreducible\n * polynomial of the 8th degree, the results are the field GF(2^8). The\n * specific irreducible polynomial that AES uses in hexadecimal is 0x11b.\n * This multiplication is associative with 0x01 as the identity:\n *\n * (b * 0x01 = GF(b, 0x01) = b).\n *\n * The operation GF(b, 0x02) can be performed at the byte level by left\n * shifting b once and then XOR'ing it (to perform the modular reduction)\n * with 0x11b if b is >= 128. Repeated application of the multiplication\n * of 0x02 can be used to implement the multiplication of any two bytes.\n *\n * For instance, multiplying 0x57 and 0x13, denoted as GF(0x57, 0x13), can\n * be performed by factoring 0x13 into 0x01, 0x02, and 0x10. Then these\n * factors can each be multiplied by 0x57 and then added together. To do\n * the multiplication, values for 0x57 multiplied by each of these 3 factors\n * can be precomputed and stored in a table. To add them, the values from\n * the table are XOR'd together.\n *\n * AES also defines addition and multiplication of words, that is 4-byte\n * numbers represented as polynomials of 3 degrees where the coefficients\n * are the values of the bytes.\n *\n * The word [a0, a1, a2, a3] is a polynomial a3x^3 + a2x^2 + a1x + a0.\n *\n * Addition is performed by XOR'ing like powers of x. Multiplication\n * is performed in two steps, the first is an algebriac expansion as\n * you would do normally (where addition is XOR). But the result is\n * a polynomial larger than 3 degrees and thus it cannot fit in a word. So\n * next the result is modularly reduced by an AES-specific polynomial of\n * degree 4 which will always produce a polynomial of less than 4 degrees\n * such that it will fit in a word. In AES, this polynomial is x^4 + 1.\n *\n * The modular product of two polynomials 'a' and 'b' is thus:\n *\n * d(x) = d3x^3 + d2x^2 + d1x + d0\n * with\n * d0 = GF(a0, b0) ^ GF(a3, b1) ^ GF(a2, b2) ^ GF(a1, b3)\n * d1 = GF(a1, b0) ^ GF(a0, b1) ^ GF(a3, b2) ^ GF(a2, b3)\n * d2 = GF(a2, b0) ^ GF(a1, b1) ^ GF(a0, b2) ^ GF(a3, b3)\n * d3 = GF(a3, b0) ^ GF(a2, b1) ^ GF(a1, b2) ^ GF(a0, b3)\n *\n * As a matrix:\n *\n * [d0] = [a0 a3 a2 a1][b0]\n * [d1] [a1 a0 a3 a2][b1]\n * [d2] [a2 a1 a0 a3][b2]\n * [d3] [a3 a2 a1 a0][b3]\n *\n * Special polynomials defined by AES (0x02 == {02}):\n * a(x) = {03}x^3 + {01}x^2 + {01}x + {02}\n * a^-1(x) = {0b}x^3 + {0d}x^2 + {09}x + {0e}.\n *\n * These polynomials are used in the MixColumns() and InverseMixColumns()\n * operations, respectively, to cause each element in the state to affect\n * the output (referred to as diffusing).\n *\n * RotWord() uses: a0 = a1 = a2 = {00} and a3 = {01}, which is the\n * polynomial x3.\n *\n * The ShiftRows() method modifies the last 3 rows in the state (where\n * the state is 4 words with 4 bytes per word) by shifting bytes cyclically.\n * The 1st byte in the second row is moved to the end of the row. The 1st\n * and 2nd bytes in the third row are moved to the end of the row. The 1st,\n * 2nd, and 3rd bytes are moved in the fourth row.\n *\n * More details on how AES arithmetic works:\n *\n * In the polynomial representation of binary numbers, XOR performs addition\n * and subtraction and multiplication in GF(2^8) denoted as GF(a, b)\n * corresponds with the multiplication of polynomials modulo an irreducible\n * polynomial of degree 8. In other words, for AES, GF(a, b) will multiply\n * polynomial 'a' with polynomial 'b' and then do a modular reduction by\n * an AES-specific irreducible polynomial of degree 8.\n *\n * A polynomial is irreducible if its only divisors are one and itself. For\n * the AES algorithm, this irreducible polynomial is:\n *\n * m(x) = x^8 + x^4 + x^3 + x + 1,\n *\n * or {01}{1b} in hexadecimal notation, where each coefficient is a bit:\n * 100011011 = 283 = 0x11b.\n *\n * For example, GF(0x57, 0x83) = 0xc1 because\n *\n * 0x57 = 87 = 01010111 = x^6 + x^4 + x^2 + x + 1\n * 0x85 = 131 = 10000101 = x^7 + x + 1\n *\n * (x^6 + x^4 + x^2 + x + 1) * (x^7 + x + 1)\n * = x^13 + x^11 + x^9 + x^8 + x^7 +\n * x^7 + x^5 + x^3 + x^2 + x +\n * x^6 + x^4 + x^2 + x + 1\n * = x^13 + x^11 + x^9 + x^8 + x^6 + x^5 + x^4 + x^3 + 1 = y\n * y modulo (x^8 + x^4 + x^3 + x + 1)\n * = x^7 + x^6 + 1.\n *\n * The modular reduction by m(x) guarantees the result will be a binary\n * polynomial of less than degree 8, so that it can fit in a byte.\n *\n * The operation to multiply a binary polynomial b with x (the polynomial\n * x in binary representation is 00000010) is:\n *\n * b_7x^8 + b_6x^7 + b_5x^6 + b_4x^5 + b_3x^4 + b_2x^3 + b_1x^2 + b_0x^1\n *\n * To get GF(b, x) we must reduce that by m(x). If b_7 is 0 (that is the\n * most significant bit is 0 in b) then the result is already reduced. If\n * it is 1, then we can reduce it by subtracting m(x) via an XOR.\n *\n * It follows that multiplication by x (00000010 or 0x02) can be implemented\n * by performing a left shift followed by a conditional bitwise XOR with\n * 0x1b. This operation on bytes is denoted by xtime(). Multiplication by\n * higher powers of x can be implemented by repeated application of xtime().\n *\n * By adding intermediate results, multiplication by any constant can be\n * implemented. For instance:\n *\n * GF(0x57, 0x13) = 0xfe because:\n *\n * xtime(b) = (b & 128) ? (b << 1 ^ 0x11b) : (b << 1)\n *\n * Note: We XOR with 0x11b instead of 0x1b because in javascript our\n * datatype for b can be larger than 1 byte, so a left shift will not\n * automatically eliminate bits that overflow a byte ... by XOR'ing the\n * overflow bit with 1 (the extra one from 0x11b) we zero it out.\n *\n * GF(0x57, 0x02) = xtime(0x57) = 0xae\n * GF(0x57, 0x04) = xtime(0xae) = 0x47\n * GF(0x57, 0x08) = xtime(0x47) = 0x8e\n * GF(0x57, 0x10) = xtime(0x8e) = 0x07\n *\n * GF(0x57, 0x13) = GF(0x57, (0x01 ^ 0x02 ^ 0x10))\n *\n * And by the distributive property (since XOR is addition and GF() is\n * multiplication):\n *\n * = GF(0x57, 0x01) ^ GF(0x57, 0x02) ^ GF(0x57, 0x10)\n * = 0x57 ^ 0xae ^ 0x07\n * = 0xfe.\n */\nfunction initialize() {\n init = true;\n\n /* Populate the Rcon table. These are the values given by\n [x^(i-1),{00},{00},{00}] where x^(i-1) are powers of x (and x = 0x02)\n in the field of GF(2^8), where i starts at 1.\n\n rcon[0] = [0x00, 0x00, 0x00, 0x00]\n rcon[1] = [0x01, 0x00, 0x00, 0x00] 2^(1-1) = 2^0 = 1\n rcon[2] = [0x02, 0x00, 0x00, 0x00] 2^(2-1) = 2^1 = 2\n ...\n rcon[9] = [0x1B, 0x00, 0x00, 0x00] 2^(9-1) = 2^8 = 0x1B\n rcon[10] = [0x36, 0x00, 0x00, 0x00] 2^(10-1) = 2^9 = 0x36\n\n We only store the first byte because it is the only one used.\n */\n rcon = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1B, 0x36];\n\n // compute xtime table which maps i onto GF(i, 0x02)\n var xtime = new Array(256);\n for(var i = 0; i < 128; ++i) {\n xtime[i] = i << 1;\n xtime[i + 128] = (i + 128) << 1 ^ 0x11B;\n }\n\n // compute all other tables\n sbox = new Array(256);\n isbox = new Array(256);\n mix = new Array(4);\n imix = new Array(4);\n for(var i = 0; i < 4; ++i) {\n mix[i] = new Array(256);\n imix[i] = new Array(256);\n }\n var e = 0, ei = 0, e2, e4, e8, sx, sx2, me, ime;\n for(var i = 0; i < 256; ++i) {\n /* We need to generate the SubBytes() sbox and isbox tables so that\n we can perform byte substitutions. This requires us to traverse\n all of the elements in GF, find their multiplicative inverses,\n and apply to each the following affine transformation:\n\n bi' = bi ^ b(i + 4) mod 8 ^ b(i + 5) mod 8 ^ b(i + 6) mod 8 ^\n b(i + 7) mod 8 ^ ci\n for 0 <= i < 8, where bi is the ith bit of the byte, and ci is the\n ith bit of a byte c with the value {63} or {01100011}.\n\n It is possible to traverse every possible value in a Galois field\n using what is referred to as a 'generator'. There are many\n generators (128 out of 256): 3,5,6,9,11,82 to name a few. To fully\n traverse GF we iterate 255 times, multiplying by our generator\n each time.\n\n On each iteration we can determine the multiplicative inverse for\n the current element.\n\n Suppose there is an element in GF 'e'. For a given generator 'g',\n e = g^x. The multiplicative inverse of e is g^(255 - x). It turns\n out that if use the inverse of a generator as another generator\n it will produce all of the corresponding multiplicative inverses\n at the same time. For this reason, we choose 5 as our inverse\n generator because it only requires 2 multiplies and 1 add and its\n inverse, 82, requires relatively few operations as well.\n\n In order to apply the affine transformation, the multiplicative\n inverse 'ei' of 'e' can be repeatedly XOR'd (4 times) with a\n bit-cycling of 'ei'. To do this 'ei' is first stored in 's' and\n 'x'. Then 's' is left shifted and the high bit of 's' is made the\n low bit. The resulting value is stored in 's'. Then 'x' is XOR'd\n with 's' and stored in 'x'. On each subsequent iteration the same\n operation is performed. When 4 iterations are complete, 'x' is\n XOR'd with 'c' (0x63) and the transformed value is stored in 'x'.\n For example:\n\n s = 01000001\n x = 01000001\n\n iteration 1: s = 10000010, x ^= s\n iteration 2: s = 00000101, x ^= s\n iteration 3: s = 00001010, x ^= s\n iteration 4: s = 00010100, x ^= s\n x ^= 0x63\n\n This can be done with a loop where s = (s << 1) | (s >> 7). However,\n it can also be done by using a single 16-bit (in this case 32-bit)\n number 'sx'. Since XOR is an associative operation, we can set 'sx'\n to 'ei' and then XOR it with 'sx' left-shifted 1,2,3, and 4 times.\n The most significant bits will flow into the high 8 bit positions\n and be correctly XOR'd with one another. All that remains will be\n to cycle the high 8 bits by XOR'ing them all with the lower 8 bits\n afterwards.\n\n At the same time we're populating sbox and isbox we can precompute\n the multiplication we'll need to do to do MixColumns() later.\n */\n\n // apply affine transformation\n sx = ei ^ (ei << 1) ^ (ei << 2) ^ (ei << 3) ^ (ei << 4);\n sx = (sx >> 8) ^ (sx & 255) ^ 0x63;\n\n // update tables\n sbox[e] = sx;\n isbox[sx] = e;\n\n /* Mixing columns is done using matrix multiplication. The columns\n that are to be mixed are each a single word in the current state.\n The state has Nb columns (4 columns). Therefore each column is a\n 4 byte word. So to mix the columns in a single column 'c' where\n its rows are r0, r1, r2, and r3, we use the following matrix\n multiplication:\n\n [2 3 1 1]*[r0,c]=[r'0,c]\n [1 2 3 1] [r1,c] [r'1,c]\n [1 1 2 3] [r2,c] [r'2,c]\n [3 1 1 2] [r3,c] [r'3,c]\n\n r0, r1, r2, and r3 are each 1 byte of one of the words in the\n state (a column). To do matrix multiplication for each mixed\n column c' we multiply the corresponding row from the left matrix\n with the corresponding column from the right matrix. In total, we\n get 4 equations:\n\n r0,c' = 2*r0,c + 3*r1,c + 1*r2,c + 1*r3,c\n r1,c' = 1*r0,c + 2*r1,c + 3*r2,c + 1*r3,c\n r2,c' = 1*r0,c + 1*r1,c + 2*r2,c + 3*r3,c\n r3,c' = 3*r0,c + 1*r1,c + 1*r2,c + 2*r3,c\n\n As usual, the multiplication is as previously defined and the\n addition is XOR. In order to optimize mixing columns we can store\n the multiplication results in tables. If you think of the whole\n column as a word (it might help to visualize by mentally rotating\n the equations above by counterclockwise 90 degrees) then you can\n see that it would be useful to map the multiplications performed on\n each byte (r0, r1, r2, r3) onto a word as well. For instance, we\n could map 2*r0,1*r0,1*r0,3*r0 onto a word by storing 2*r0 in the\n highest 8 bits and 3*r0 in the lowest 8 bits (with the other two\n respectively in the middle). This means that a table can be\n constructed that uses r0 as an index to the word. We can do the\n same with r1, r2, and r3, creating a total of 4 tables.\n\n To construct a full c', we can just look up each byte of c in\n their respective tables and XOR the results together.\n\n Also, to build each table we only have to calculate the word\n for 2,1,1,3 for every byte ... which we can do on each iteration\n of this loop since we will iterate over every byte. After we have\n calculated 2,1,1,3 we can get the results for the other tables\n by cycling the byte at the end to the beginning. For instance\n we can take the result of table 2,1,1,3 and produce table 3,2,1,1\n by moving the right most byte to the left most position just like\n how you can imagine the 3 moved out of 2,1,1,3 and to the front\n to produce 3,2,1,1.\n\n There is another optimization in that the same multiples of\n the current element we need in order to advance our generator\n to the next iteration can be reused in performing the 2,1,1,3\n calculation. We also calculate the inverse mix column tables,\n with e,9,d,b being the inverse of 2,1,1,3.\n\n When we're done, and we need to actually mix columns, the first\n byte of each state word should be put through mix[0] (2,1,1,3),\n the second through mix[1] (3,2,1,1) and so forth. Then they should\n be XOR'd together to produce the fully mixed column.\n */\n\n // calculate mix and imix table values\n sx2 = xtime[sx];\n e2 = xtime[e];\n e4 = xtime[e2];\n e8 = xtime[e4];\n me =\n (sx2 << 24) ^ // 2\n (sx << 16) ^ // 1\n (sx << 8) ^ // 1\n (sx ^ sx2); // 3\n ime =\n (e2 ^ e4 ^ e8) << 24 ^ // E (14)\n (e ^ e8) << 16 ^ // 9\n (e ^ e4 ^ e8) << 8 ^ // D (13)\n (e ^ e2 ^ e8); // B (11)\n // produce each of the mix tables by rotating the 2,1,1,3 value\n for(var n = 0; n < 4; ++n) {\n mix[n][e] = me;\n imix[n][sx] = ime;\n // cycle the right most byte to the left most position\n // ie: 2,1,1,3 becomes 3,2,1,1\n me = me << 24 | me >>> 8;\n ime = ime << 24 | ime >>> 8;\n }\n\n // get next element and inverse\n if(e === 0) {\n // 1 is the inverse of 1\n e = ei = 1;\n } else {\n // e = 2e + 2*2*2*(10e)) = multiply e by 82 (chosen generator)\n // ei = ei + 2*2*ei = multiply ei by 5 (inverse generator)\n e = e2 ^ xtime[xtime[xtime[e2 ^ e8]]];\n ei ^= xtime[xtime[ei]];\n }\n }\n}\n\n/**\n * Generates a key schedule using the AES key expansion algorithm.\n *\n * The AES algorithm takes the Cipher Key, K, and performs a Key Expansion\n * routine to generate a key schedule. The Key Expansion generates a total\n * of Nb*(Nr + 1) words: the algorithm requires an initial set of Nb words,\n * and each of the Nr rounds requires Nb words of key data. The resulting\n * key schedule consists of a linear array of 4-byte words, denoted [wi ],\n * with i in the range 0 <= i < Nb(Nr + 1).\n *\n * KeyExpansion(byte key[4*Nk], word w[Nb*(Nr+1)], Nk)\n * AES-128 (Nb=4, Nk=4, Nr=10)\n * AES-192 (Nb=4, Nk=6, Nr=12)\n * AES-256 (Nb=4, Nk=8, Nr=14)\n * Note: Nr=Nk+6.\n *\n * Nb is the number of columns (32-bit words) comprising the State (or\n * number of bytes in a block). For AES, Nb=4.\n *\n * @param key the key to schedule (as an array of 32-bit words).\n * @param decrypt true to modify the key schedule to decrypt, false not to.\n *\n * @return the generated key schedule.\n */\nfunction _expandKey(key, decrypt) {\n // copy the key's words to initialize the key schedule\n var w = key.slice(0);\n\n /* RotWord() will rotate a word, moving the first byte to the last\n byte's position (shifting the other bytes left).\n\n We will be getting the value of Rcon at i / Nk. 'i' will iterate\n from Nk to (Nb * Nr+1). Nk = 4 (4 byte key), Nb = 4 (4 words in\n a block), Nr = Nk + 6 (10). Therefore 'i' will iterate from\n 4 to 44 (exclusive). Each time we iterate 4 times, i / Nk will\n increase by 1. We use a counter iNk to keep track of this.\n */\n\n // go through the rounds expanding the key\n var temp, iNk = 1;\n var Nk = w.length;\n var Nr1 = Nk + 6 + 1;\n var end = Nb * Nr1;\n for(var i = Nk; i < end; ++i) {\n temp = w[i - 1];\n if(i % Nk === 0) {\n // temp = SubWord(RotWord(temp)) ^ Rcon[i / Nk]\n temp =\n sbox[temp >>> 16 & 255] << 24 ^\n sbox[temp >>> 8 & 255] << 16 ^\n sbox[temp & 255] << 8 ^\n sbox[temp >>> 24] ^ (rcon[iNk] << 24);\n iNk++;\n } else if(Nk > 6 && (i % Nk === 4)) {\n // temp = SubWord(temp)\n temp =\n sbox[temp >>> 24] << 24 ^\n sbox[temp >>> 16 & 255] << 16 ^\n sbox[temp >>> 8 & 255] << 8 ^\n sbox[temp & 255];\n }\n w[i] = w[i - Nk] ^ temp;\n }\n\n /* When we are updating a cipher block we always use the code path for\n encryption whether we are decrypting or not (to shorten code and\n simplify the generation of look up tables). However, because there\n are differences in the decryption algorithm, other than just swapping\n in different look up tables, we must transform our key schedule to\n account for these changes:\n\n 1. The decryption algorithm gets its key rounds in reverse order.\n 2. The decryption algorithm adds the round key before mixing columns\n instead of afterwards.\n\n We don't need to modify our key schedule to handle the first case,\n we can just traverse the key schedule in reverse order when decrypting.\n\n The second case requires a little work.\n\n The tables we built for performing rounds will take an input and then\n perform SubBytes() and MixColumns() or, for the decrypt version,\n InvSubBytes() and InvMixColumns(). But the decrypt algorithm requires\n us to AddRoundKey() before InvMixColumns(). This means we'll need to\n apply some transformations to the round key to inverse-mix its columns\n so they'll be correct for moving AddRoundKey() to after the state has\n had its columns inverse-mixed.\n\n To inverse-mix the columns of the state when we're decrypting we use a\n lookup table that will apply InvSubBytes() and InvMixColumns() at the\n same time. However, the round key's bytes are not inverse-substituted\n in the decryption algorithm. To get around this problem, we can first\n substitute the bytes in the round key so that when we apply the\n transformation via the InvSubBytes()+InvMixColumns() table, it will\n undo our substitution leaving us with the original value that we\n want -- and then inverse-mix that value.\n\n This change will correctly alter our key schedule so that we can XOR\n each round key with our already transformed decryption state. This\n allows us to use the same code path as the encryption algorithm.\n\n We make one more change to the decryption key. Since the decryption\n algorithm runs in reverse from the encryption algorithm, we reverse\n the order of the round keys to avoid having to iterate over the key\n schedule backwards when running the encryption algorithm later in\n decryption mode. In addition to reversing the order of the round keys,\n we also swap each round key's 2nd and 4th rows. See the comments\n section where rounds are performed for more details about why this is\n done. These changes are done inline with the other substitution\n described above.\n */\n if(decrypt) {\n var tmp;\n var m0 = imix[0];\n var m1 = imix[1];\n var m2 = imix[2];\n var m3 = imix[3];\n var wnew = w.slice(0);\n end = w.length;\n for(var i = 0, wi = end - Nb; i < end; i += Nb, wi -= Nb) {\n // do not sub the first or last round key (round keys are Nb\n // words) as no column mixing is performed before they are added,\n // but do change the key order\n if(i === 0 || i === (end - Nb)) {\n wnew[i] = w[wi];\n wnew[i + 1] = w[wi + 3];\n wnew[i + 2] = w[wi + 2];\n wnew[i + 3] = w[wi + 1];\n } else {\n // substitute each round key byte because the inverse-mix\n // table will inverse-substitute it (effectively cancel the\n // substitution because round key bytes aren't sub'd in\n // decryption mode) and swap indexes 3 and 1\n for(var n = 0; n < Nb; ++n) {\n tmp = w[wi + n];\n wnew[i + (3&-n)] =\n m0[sbox[tmp >>> 24]] ^\n m1[sbox[tmp >>> 16 & 255]] ^\n m2[sbox[tmp >>> 8 & 255]] ^\n m3[sbox[tmp & 255]];\n }\n }\n }\n w = wnew;\n }\n\n return w;\n}\n\n/**\n * Updates a single block (16 bytes) using AES. The update will either\n * encrypt or decrypt the block.\n *\n * @param w the key schedule.\n * @param input the input block (an array of 32-bit words).\n * @param output the updated output block.\n * @param decrypt true to decrypt the block, false to encrypt it.\n */\nfunction _updateBlock(w, input, output, decrypt) {\n /*\n Cipher(byte in[4*Nb], byte out[4*Nb], word w[Nb*(Nr+1)])\n begin\n byte state[4,Nb]\n state = in\n AddRoundKey(state, w[0, Nb-1])\n for round = 1 step 1 to Nr-1\n SubBytes(state)\n ShiftRows(state)\n MixColumns(state)\n AddRoundKey(state, w[round*Nb, (round+1)*Nb-1])\n end for\n SubBytes(state)\n ShiftRows(state)\n AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n out = state\n end\n\n InvCipher(byte in[4*Nb], byte out[4*Nb], word w[Nb*(Nr+1)])\n begin\n byte state[4,Nb]\n state = in\n AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n for round = Nr-1 step -1 downto 1\n InvShiftRows(state)\n InvSubBytes(state)\n AddRoundKey(state, w[round*Nb, (round+1)*Nb-1])\n InvMixColumns(state)\n end for\n InvShiftRows(state)\n InvSubBytes(state)\n AddRoundKey(state, w[0, Nb-1])\n out = state\n end\n */\n\n // Encrypt: AddRoundKey(state, w[0, Nb-1])\n // Decrypt: AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n var Nr = w.length / 4 - 1;\n var m0, m1, m2, m3, sub;\n if(decrypt) {\n m0 = imix[0];\n m1 = imix[1];\n m2 = imix[2];\n m3 = imix[3];\n sub = isbox;\n } else {\n m0 = mix[0];\n m1 = mix[1];\n m2 = mix[2];\n m3 = mix[3];\n sub = sbox;\n }\n var a, b, c, d, a2, b2, c2;\n a = input[0] ^ w[0];\n b = input[decrypt ? 3 : 1] ^ w[1];\n c = input[2] ^ w[2];\n d = input[decrypt ? 1 : 3] ^ w[3];\n var i = 3;\n\n /* In order to share code we follow the encryption algorithm when both\n encrypting and decrypting. To account for the changes required in the\n decryption algorithm, we use different lookup tables when decrypting\n and use a modified key schedule to account for the difference in the\n order of transformations applied when performing rounds. We also get\n key rounds in reverse order (relative to encryption). */\n for(var round = 1; round < Nr; ++round) {\n /* As described above, we'll be using table lookups to perform the\n column mixing. Each column is stored as a word in the state (the\n array 'input' has one column as a word at each index). In order to\n mix a column, we perform these transformations on each row in c,\n which is 1 byte in each word. The new column for c0 is c'0:\n\n m0 m1 m2 m3\n r0,c'0 = 2*r0,c0 + 3*r1,c0 + 1*r2,c0 + 1*r3,c0\n r1,c'0 = 1*r0,c0 + 2*r1,c0 + 3*r2,c0 + 1*r3,c0\n r2,c'0 = 1*r0,c0 + 1*r1,c0 + 2*r2,c0 + 3*r3,c0\n r3,c'0 = 3*r0,c0 + 1*r1,c0 + 1*r2,c0 + 2*r3,c0\n\n So using mix tables where c0 is a word with r0 being its upper\n 8 bits and r3 being its lower 8 bits:\n\n m0[c0 >> 24] will yield this word: [2*r0,1*r0,1*r0,3*r0]\n ...\n m3[c0 & 255] will yield this word: [1*r3,1*r3,3*r3,2*r3]\n\n Therefore to mix the columns in each word in the state we\n do the following (& 255 omitted for brevity):\n c'0,r0 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n c'0,r1 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n c'0,r2 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n c'0,r3 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n\n However, before mixing, the algorithm requires us to perform\n ShiftRows(). The ShiftRows() transformation cyclically shifts the\n last 3 rows of the state over different offsets. The first row\n (r = 0) is not shifted.\n\n s'_r,c = s_r,(c + shift(r, Nb) mod Nb\n for 0 < r < 4 and 0 <= c < Nb and\n shift(1, 4) = 1\n shift(2, 4) = 2\n shift(3, 4) = 3.\n\n This causes the first byte in r = 1 to be moved to the end of\n the row, the first 2 bytes in r = 2 to be moved to the end of\n the row, the first 3 bytes in r = 3 to be moved to the end of\n the row:\n\n r1: [c0 c1 c2 c3] => [c1 c2 c3 c0]\n r2: [c0 c1 c2 c3] [c2 c3 c0 c1]\n r3: [c0 c1 c2 c3] [c3 c0 c1 c2]\n\n We can make these substitutions inline with our column mixing to\n generate an updated set of equations to produce each word in the\n state (note the columns have changed positions):\n\n c0 c1 c2 c3 => c0 c1 c2 c3\n c0 c1 c2 c3 c1 c2 c3 c0 (cycled 1 byte)\n c0 c1 c2 c3 c2 c3 c0 c1 (cycled 2 bytes)\n c0 c1 c2 c3 c3 c0 c1 c2 (cycled 3 bytes)\n\n Therefore:\n\n c'0 = 2*r0,c0 + 3*r1,c1 + 1*r2,c2 + 1*r3,c3\n c'0 = 1*r0,c0 + 2*r1,c1 + 3*r2,c2 + 1*r3,c3\n c'0 = 1*r0,c0 + 1*r1,c1 + 2*r2,c2 + 3*r3,c3\n c'0 = 3*r0,c0 + 1*r1,c1 + 1*r2,c2 + 2*r3,c3\n\n c'1 = 2*r0,c1 + 3*r1,c2 + 1*r2,c3 + 1*r3,c0\n c'1 = 1*r0,c1 + 2*r1,c2 + 3*r2,c3 + 1*r3,c0\n c'1 = 1*r0,c1 + 1*r1,c2 + 2*r2,c3 + 3*r3,c0\n c'1 = 3*r0,c1 + 1*r1,c2 + 1*r2,c3 + 2*r3,c0\n\n ... and so forth for c'2 and c'3. The important distinction is\n that the columns are cycling, with c0 being used with the m0\n map when calculating c0, but c1 being used with the m0 map when\n calculating c1 ... and so forth.\n\n When performing the inverse we transform the mirror image and\n skip the bottom row, instead of the top one, and move upwards:\n\n c3 c2 c1 c0 => c0 c3 c2 c1 (cycled 3 bytes) *same as encryption\n c3 c2 c1 c0 c1 c0 c3 c2 (cycled 2 bytes)\n c3 c2 c1 c0 c2 c1 c0 c3 (cycled 1 byte) *same as encryption\n c3 c2 c1 c0 c3 c2 c1 c0\n\n If you compare the resulting matrices for ShiftRows()+MixColumns()\n and for InvShiftRows()+InvMixColumns() the 2nd and 4th columns are\n different (in encrypt mode vs. decrypt mode). So in order to use\n the same code to handle both encryption and decryption, we will\n need to do some mapping.\n\n If in encryption mode we let a=c0, b=c1, c=c2, d=c3, and r be\n a row number in the state, then the resulting matrix in encryption\n mode for applying the above transformations would be:\n\n r1: a b c d\n r2: b c d a\n r3: c d a b\n r4: d a b c\n\n If we did the same in decryption mode we would get:\n\n r1: a d c b\n r2: b a d c\n r3: c b a d\n r4: d c b a\n\n If instead we swap d and b (set b=c3 and d=c1), then we get:\n\n r1: a b c d\n r2: d a b c\n r3: c d a b\n r4: b c d a\n\n Now the 1st and 3rd rows are the same as the encryption matrix. All\n we need to do then to make the mapping exactly the same is to swap\n the 2nd and 4th rows when in decryption mode. To do this without\n having to do it on each iteration, we swapped the 2nd and 4th rows\n in the decryption key schedule. We also have to do the swap above\n when we first pull in the input and when we set the final output. */\n a2 =\n m0[a >>> 24] ^\n m1[b >>> 16 & 255] ^\n m2[c >>> 8 & 255] ^\n m3[d & 255] ^ w[++i];\n b2 =\n m0[b >>> 24] ^\n m1[c >>> 16 & 255] ^\n m2[d >>> 8 & 255] ^\n m3[a & 255] ^ w[++i];\n c2 =\n m0[c >>> 24] ^\n m1[d >>> 16 & 255] ^\n m2[a >>> 8 & 255] ^\n m3[b & 255] ^ w[++i];\n d =\n m0[d >>> 24] ^\n m1[a >>> 16 & 255] ^\n m2[b >>> 8 & 255] ^\n m3[c & 255] ^ w[++i];\n a = a2;\n b = b2;\n c = c2;\n }\n\n /*\n Encrypt:\n SubBytes(state)\n ShiftRows(state)\n AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n\n Decrypt:\n InvShiftRows(state)\n InvSubBytes(state)\n AddRoundKey(state, w[0, Nb-1])\n */\n // Note: rows are shifted inline\n output[0] =\n (sub[a >>> 24] << 24) ^\n (sub[b >>> 16 & 255] << 16) ^\n (sub[c >>> 8 & 255] << 8) ^\n (sub[d & 255]) ^ w[++i];\n output[decrypt ? 3 : 1] =\n (sub[b >>> 24] << 24) ^\n (sub[c >>> 16 & 255] << 16) ^\n (sub[d >>> 8 & 255] << 8) ^\n (sub[a & 255]) ^ w[++i];\n output[2] =\n (sub[c >>> 24] << 24) ^\n (sub[d >>> 16 & 255] << 16) ^\n (sub[a >>> 8 & 255] << 8) ^\n (sub[b & 255]) ^ w[++i];\n output[decrypt ? 1 : 3] =\n (sub[d >>> 24] << 24) ^\n (sub[a >>> 16 & 255] << 16) ^\n (sub[b >>> 8 & 255] << 8) ^\n (sub[c & 255]) ^ w[++i];\n}\n\n/**\n * Deprecated. Instead, use:\n *\n * forge.cipher.createCipher('AES-', key);\n * forge.cipher.createDecipher('AES-', key);\n *\n * Creates a deprecated AES cipher object. This object's mode will default to\n * CBC (cipher-block-chaining).\n *\n * The key and iv may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param options the options to use.\n * key the symmetric key to use.\n * output the buffer to write to.\n * decrypt true for decryption, false for encryption.\n * mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nfunction _createCipher(options) {\n options = options || {};\n var mode = (options.mode || 'CBC').toUpperCase();\n var algorithm = 'AES-' + mode;\n\n var cipher;\n if(options.decrypt) {\n cipher = forge.cipher.createDecipher(algorithm, options.key);\n } else {\n cipher = forge.cipher.createCipher(algorithm, options.key);\n }\n\n // backwards compatible start API\n var start = cipher.start;\n cipher.start = function(iv, options) {\n // backwards compatibility: support second arg as output buffer\n var output = null;\n if(options instanceof forge.util.ByteBuffer) {\n output = options;\n options = {};\n }\n options = options || {};\n options.output = output;\n options.iv = iv;\n start.call(cipher, options);\n };\n\n return cipher;\n}\n","/**\n * Cipher base API.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nmodule.exports = forge.cipher = forge.cipher || {};\n\n// registered algorithms\nforge.cipher.algorithms = forge.cipher.algorithms || {};\n\n/**\n * Creates a cipher object that can be used to encrypt data using the given\n * algorithm and key. The algorithm may be provided as a string value for a\n * previously registered algorithm or it may be given as a cipher algorithm\n * API object.\n *\n * @param algorithm the algorithm to use, either a string or an algorithm API\n * object.\n * @param key the key to use, as a binary-encoded string of bytes or a\n * byte buffer.\n *\n * @return the cipher.\n */\nforge.cipher.createCipher = function(algorithm, key) {\n var api = algorithm;\n if(typeof api === 'string') {\n api = forge.cipher.getAlgorithm(api);\n if(api) {\n api = api();\n }\n }\n if(!api) {\n throw new Error('Unsupported algorithm: ' + algorithm);\n }\n\n // assume block cipher\n return new forge.cipher.BlockCipher({\n algorithm: api,\n key: key,\n decrypt: false\n });\n};\n\n/**\n * Creates a decipher object that can be used to decrypt data using the given\n * algorithm and key. The algorithm may be provided as a string value for a\n * previously registered algorithm or it may be given as a cipher algorithm\n * API object.\n *\n * @param algorithm the algorithm to use, either a string or an algorithm API\n * object.\n * @param key the key to use, as a binary-encoded string of bytes or a\n * byte buffer.\n *\n * @return the cipher.\n */\nforge.cipher.createDecipher = function(algorithm, key) {\n var api = algorithm;\n if(typeof api === 'string') {\n api = forge.cipher.getAlgorithm(api);\n if(api) {\n api = api();\n }\n }\n if(!api) {\n throw new Error('Unsupported algorithm: ' + algorithm);\n }\n\n // assume block cipher\n return new forge.cipher.BlockCipher({\n algorithm: api,\n key: key,\n decrypt: true\n });\n};\n\n/**\n * Registers an algorithm by name. If the name was already registered, the\n * algorithm API object will be overwritten.\n *\n * @param name the name of the algorithm.\n * @param algorithm the algorithm API object.\n */\nforge.cipher.registerAlgorithm = function(name, algorithm) {\n name = name.toUpperCase();\n forge.cipher.algorithms[name] = algorithm;\n};\n\n/**\n * Gets a registered algorithm by name.\n *\n * @param name the name of the algorithm.\n *\n * @return the algorithm, if found, null if not.\n */\nforge.cipher.getAlgorithm = function(name) {\n name = name.toUpperCase();\n if(name in forge.cipher.algorithms) {\n return forge.cipher.algorithms[name];\n }\n return null;\n};\n\nvar BlockCipher = forge.cipher.BlockCipher = function(options) {\n this.algorithm = options.algorithm;\n this.mode = this.algorithm.mode;\n this.blockSize = this.mode.blockSize;\n this._finish = false;\n this._input = null;\n this.output = null;\n this._op = options.decrypt ? this.mode.decrypt : this.mode.encrypt;\n this._decrypt = options.decrypt;\n this.algorithm.initialize(options);\n};\n\n/**\n * Starts or restarts the encryption or decryption process, whichever\n * was previously configured.\n *\n * For non-GCM mode, the IV may be a binary-encoded string of bytes, an array\n * of bytes, a byte buffer, or an array of 32-bit integers. If the IV is in\n * bytes, then it must be Nb (16) bytes in length. If the IV is given in as\n * 32-bit integers, then it must be 4 integers long.\n *\n * Note: an IV is not required or used in ECB mode.\n *\n * For GCM-mode, the IV must be given as a binary-encoded string of bytes or\n * a byte buffer. The number of bytes should be 12 (96 bits) as recommended\n * by NIST SP-800-38D but another length may be given.\n *\n * @param options the options to use:\n * iv the initialization vector to use as a binary-encoded string of\n * bytes, null to reuse the last ciphered block from a previous\n * update() (this \"residue\" method is for legacy support only).\n * additionalData additional authentication data as a binary-encoded\n * string of bytes, for 'GCM' mode, (default: none).\n * tagLength desired length of authentication tag, in bits, for\n * 'GCM' mode (0-128, default: 128).\n * tag the authentication tag to check if decrypting, as a\n * binary-encoded string of bytes.\n * output the output the buffer to write to, null to create one.\n */\nBlockCipher.prototype.start = function(options) {\n options = options || {};\n var opts = {};\n for(var key in options) {\n opts[key] = options[key];\n }\n opts.decrypt = this._decrypt;\n this._finish = false;\n this._input = forge.util.createBuffer();\n this.output = options.output || forge.util.createBuffer();\n this.mode.start(opts);\n};\n\n/**\n * Updates the next block according to the cipher mode.\n *\n * @param input the buffer to read from.\n */\nBlockCipher.prototype.update = function(input) {\n if(input) {\n // input given, so empty it into the input buffer\n this._input.putBuffer(input);\n }\n\n // do cipher operation until it needs more input and not finished\n while(!this._op.call(this.mode, this._input, this.output, this._finish) &&\n !this._finish) {}\n\n // free consumed memory from input buffer\n this._input.compact();\n};\n\n/**\n * Finishes encrypting or decrypting.\n *\n * @param pad a padding function to use in CBC mode, null for default,\n * signature(blockSize, buffer, decrypt).\n *\n * @return true if successful, false on error.\n */\nBlockCipher.prototype.finish = function(pad) {\n // backwards-compatibility w/deprecated padding API\n // Note: will overwrite padding functions even after another start() call\n if(pad && (this.mode.name === 'ECB' || this.mode.name === 'CBC')) {\n this.mode.pad = function(input) {\n return pad(this.blockSize, input, false);\n };\n this.mode.unpad = function(output) {\n return pad(this.blockSize, output, true);\n };\n }\n\n // build options for padding and afterFinish functions\n var options = {};\n options.decrypt = this._decrypt;\n\n // get # of bytes that won't fill a block\n options.overflow = this._input.length() % this.blockSize;\n\n if(!this._decrypt && this.mode.pad) {\n if(!this.mode.pad(this._input, options)) {\n return false;\n }\n }\n\n // do final update\n this._finish = true;\n this.update();\n\n if(this._decrypt && this.mode.unpad) {\n if(!this.mode.unpad(this.output, options)) {\n return false;\n }\n }\n\n if(this.mode.afterFinish) {\n if(!this.mode.afterFinish(this.output, options)) {\n return false;\n }\n }\n\n return true;\n};\n","/**\n * Supported cipher modes.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nforge.cipher = forge.cipher || {};\n\n// supported cipher modes\nvar modes = module.exports = forge.cipher.modes = forge.cipher.modes || {};\n\n/** Electronic codebook (ECB) (Don't use this; it's not secure) **/\n\nmodes.ecb = function(options) {\n options = options || {};\n this.name = 'ECB';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = new Array(this._ints);\n this._outBlock = new Array(this._ints);\n};\n\nmodes.ecb.prototype.start = function(options) {};\n\nmodes.ecb.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // write output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n};\n\nmodes.ecb.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n }\n\n // decrypt block\n this.cipher.decrypt(this._inBlock, this._outBlock);\n\n // write output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n};\n\nmodes.ecb.prototype.pad = function(input, options) {\n // add PKCS#7 padding to block (each pad byte is the\n // value of the number of pad bytes)\n var padding = (input.length() === this.blockSize ?\n this.blockSize : (this.blockSize - input.length()));\n input.fillWithByte(padding, padding);\n return true;\n};\n\nmodes.ecb.prototype.unpad = function(output, options) {\n // check for error: input data not a multiple of blockSize\n if(options.overflow > 0) {\n return false;\n }\n\n // ensure padding byte count is valid\n var len = output.length();\n var count = output.at(len - 1);\n if(count > (this.blockSize << 2)) {\n return false;\n }\n\n // trim off padding bytes\n output.truncate(count);\n return true;\n};\n\n/** Cipher-block Chaining (CBC) **/\n\nmodes.cbc = function(options) {\n options = options || {};\n this.name = 'CBC';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = new Array(this._ints);\n this._outBlock = new Array(this._ints);\n};\n\nmodes.cbc.prototype.start = function(options) {\n // Note: legacy support for using IV residue (has security flaws)\n // if IV is null, reuse block from previous processing\n if(options.iv === null) {\n // must have a previous block\n if(!this._prev) {\n throw new Error('Invalid IV parameter.');\n }\n this._iv = this._prev.slice(0);\n } else if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n } else {\n // save IV as \"previous\" block\n this._iv = transformIV(options.iv, this.blockSize);\n this._prev = this._iv.slice(0);\n }\n};\n\nmodes.cbc.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n // CBC XOR's IV (or previous block) with plaintext\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._prev[i] ^ input.getInt32();\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // write output, save previous block\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n this._prev = this._outBlock;\n};\n\nmodes.cbc.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n }\n\n // decrypt block\n this.cipher.decrypt(this._inBlock, this._outBlock);\n\n // write output, save previous ciphered block\n // CBC XOR's IV (or previous block) with ciphertext\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._prev[i] ^ this._outBlock[i]);\n }\n this._prev = this._inBlock.slice(0);\n};\n\nmodes.cbc.prototype.pad = function(input, options) {\n // add PKCS#7 padding to block (each pad byte is the\n // value of the number of pad bytes)\n var padding = (input.length() === this.blockSize ?\n this.blockSize : (this.blockSize - input.length()));\n input.fillWithByte(padding, padding);\n return true;\n};\n\nmodes.cbc.prototype.unpad = function(output, options) {\n // check for error: input data not a multiple of blockSize\n if(options.overflow > 0) {\n return false;\n }\n\n // ensure padding byte count is valid\n var len = output.length();\n var count = output.at(len - 1);\n if(count > (this.blockSize << 2)) {\n return false;\n }\n\n // trim off padding bytes\n output.truncate(count);\n return true;\n};\n\n/** Cipher feedback (CFB) **/\n\nmodes.cfb = function(options) {\n options = options || {};\n this.name = 'CFB';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = null;\n this._outBlock = new Array(this._ints);\n this._partialBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n};\n\nmodes.cfb.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // use IV as first input\n this._iv = transformIV(options.iv, this.blockSize);\n this._inBlock = this._iv.slice(0);\n this._partialBytes = 0;\n};\n\nmodes.cfb.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output, write input as output\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32() ^ this._outBlock[i];\n output.putInt32(this._inBlock[i]);\n }\n return;\n }\n\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output, write input as partial output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialBlock[i] = input.getInt32() ^ this._outBlock[i];\n this._partialOutput.putInt32(this._partialBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n } else {\n // block complete, update input block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._partialBlock[i];\n }\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n};\n\nmodes.cfb.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block (CFB always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output, write input as output\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n output.putInt32(this._inBlock[i] ^ this._outBlock[i]);\n }\n return;\n }\n\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output, write input as partial output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialBlock[i] = input.getInt32();\n this._partialOutput.putInt32(this._partialBlock[i] ^ this._outBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n } else {\n // block complete, update input block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._partialBlock[i];\n }\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n};\n\n/** Output feedback (OFB) **/\n\nmodes.ofb = function(options) {\n options = options || {};\n this.name = 'OFB';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = null;\n this._outBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n};\n\nmodes.ofb.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // use IV as first input\n this._iv = transformIV(options.iv, this.blockSize);\n this._inBlock = this._iv.slice(0);\n this._partialBytes = 0;\n};\n\nmodes.ofb.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(input.length() === 0) {\n return true;\n }\n\n // encrypt block (OFB always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output and update next input\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(input.getInt32() ^ this._outBlock[i]);\n this._inBlock[i] = this._outBlock[i];\n }\n return;\n }\n\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialOutput.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n } else {\n // block complete, update input block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._outBlock[i];\n }\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n};\n\nmodes.ofb.prototype.decrypt = modes.ofb.prototype.encrypt;\n\n/** Counter (CTR) **/\n\nmodes.ctr = function(options) {\n options = options || {};\n this.name = 'CTR';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = null;\n this._outBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n};\n\nmodes.ctr.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // use IV as first input\n this._iv = transformIV(options.iv, this.blockSize);\n this._inBlock = this._iv.slice(0);\n this._partialBytes = 0;\n};\n\nmodes.ctr.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block (CTR always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n } else {\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialOutput.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n }\n\n // block complete, increment counter (input block)\n inc32(this._inBlock);\n};\n\nmodes.ctr.prototype.decrypt = modes.ctr.prototype.encrypt;\n\n/** Galois/Counter Mode (GCM) **/\n\nmodes.gcm = function(options) {\n options = options || {};\n this.name = 'GCM';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = new Array(this._ints);\n this._outBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n\n // R is actually this value concatenated with 120 more zero bits, but\n // we only XOR against R so the other zeros have no effect -- we just\n // apply this value to the first integer in a block\n this._R = 0xE1000000;\n};\n\nmodes.gcm.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // ensure IV is a byte buffer\n var iv = forge.util.createBuffer(options.iv);\n\n // no ciphered data processed yet\n this._cipherLength = 0;\n\n // default additional data is none\n var additionalData;\n if('additionalData' in options) {\n additionalData = forge.util.createBuffer(options.additionalData);\n } else {\n additionalData = forge.util.createBuffer();\n }\n\n // default tag length is 128 bits\n if('tagLength' in options) {\n this._tagLength = options.tagLength;\n } else {\n this._tagLength = 128;\n }\n\n // if tag is given, ensure tag matches tag length\n this._tag = null;\n if(options.decrypt) {\n // save tag to check later\n this._tag = forge.util.createBuffer(options.tag).getBytes();\n if(this._tag.length !== (this._tagLength / 8)) {\n throw new Error('Authentication tag does not match tag length.');\n }\n }\n\n // create tmp storage for hash calculation\n this._hashBlock = new Array(this._ints);\n\n // no tag generated yet\n this.tag = null;\n\n // generate hash subkey\n // (apply block cipher to \"zero\" block)\n this._hashSubkey = new Array(this._ints);\n this.cipher.encrypt([0, 0, 0, 0], this._hashSubkey);\n\n // generate table M\n // use 4-bit tables (32 component decomposition of a 16 byte value)\n // 8-bit tables take more space and are known to have security\n // vulnerabilities (in native implementations)\n this.componentBits = 4;\n this._m = this.generateHashTable(this._hashSubkey, this.componentBits);\n\n // Note: support IV length different from 96 bits? (only supporting\n // 96 bits is recommended by NIST SP-800-38D)\n // generate J_0\n var ivLength = iv.length();\n if(ivLength === 12) {\n // 96-bit IV\n this._j0 = [iv.getInt32(), iv.getInt32(), iv.getInt32(), 1];\n } else {\n // IV is NOT 96-bits\n this._j0 = [0, 0, 0, 0];\n while(iv.length() > 0) {\n this._j0 = this.ghash(\n this._hashSubkey, this._j0,\n [iv.getInt32(), iv.getInt32(), iv.getInt32(), iv.getInt32()]);\n }\n this._j0 = this.ghash(\n this._hashSubkey, this._j0, [0, 0].concat(from64To32(ivLength * 8)));\n }\n\n // generate ICB (initial counter block)\n this._inBlock = this._j0.slice(0);\n inc32(this._inBlock);\n this._partialBytes = 0;\n\n // consume authentication data\n additionalData = forge.util.createBuffer(additionalData);\n // save additional data length as a BE 64-bit number\n this._aDataLength = from64To32(additionalData.length() * 8);\n // pad additional data to 128 bit (16 byte) block size\n var overflow = additionalData.length() % this.blockSize;\n if(overflow) {\n additionalData.fillWithByte(0, this.blockSize - overflow);\n }\n this._s = [0, 0, 0, 0];\n while(additionalData.length() > 0) {\n this._s = this.ghash(this._hashSubkey, this._s, [\n additionalData.getInt32(),\n additionalData.getInt32(),\n additionalData.getInt32(),\n additionalData.getInt32()\n ]);\n }\n};\n\nmodes.gcm.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i] ^= input.getInt32());\n }\n this._cipherLength += this.blockSize;\n } else {\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialOutput.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n\n if(partialBytes <= 0 || finish) {\n // handle overflow prior to hashing\n if(finish) {\n // get block overflow\n var overflow = inputLength % this.blockSize;\n this._cipherLength += overflow;\n // truncate for hash function\n this._partialOutput.truncate(this.blockSize - overflow);\n } else {\n this._cipherLength += this.blockSize;\n }\n\n // get output block for hashing\n for(var i = 0; i < this._ints; ++i) {\n this._outBlock[i] = this._partialOutput.getInt32();\n }\n this._partialOutput.read -= this.blockSize;\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n // block still incomplete, restore input buffer, get partial output,\n // and return early\n input.read -= this.blockSize;\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n }\n\n // update hash block S\n this._s = this.ghash(this._hashSubkey, this._s, this._outBlock);\n\n // increment counter (input block)\n inc32(this._inBlock);\n};\n\nmodes.gcm.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n var inputLength = input.length();\n if(inputLength < this.blockSize && !(finish && inputLength > 0)) {\n return true;\n }\n\n // encrypt block (GCM always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // increment counter (input block)\n inc32(this._inBlock);\n\n // update hash block S\n this._hashBlock[0] = input.getInt32();\n this._hashBlock[1] = input.getInt32();\n this._hashBlock[2] = input.getInt32();\n this._hashBlock[3] = input.getInt32();\n this._s = this.ghash(this._hashSubkey, this._s, this._hashBlock);\n\n // XOR hash input with output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i] ^ this._hashBlock[i]);\n }\n\n // increment cipher data length\n if(inputLength < this.blockSize) {\n this._cipherLength += inputLength % this.blockSize;\n } else {\n this._cipherLength += this.blockSize;\n }\n};\n\nmodes.gcm.prototype.afterFinish = function(output, options) {\n var rval = true;\n\n // handle overflow\n if(options.decrypt && options.overflow) {\n output.truncate(this.blockSize - options.overflow);\n }\n\n // handle authentication tag\n this.tag = forge.util.createBuffer();\n\n // concatenate additional data length with cipher length\n var lengths = this._aDataLength.concat(from64To32(this._cipherLength * 8));\n\n // include lengths in hash\n this._s = this.ghash(this._hashSubkey, this._s, lengths);\n\n // do GCTR(J_0, S)\n var tag = [];\n this.cipher.encrypt(this._j0, tag);\n for(var i = 0; i < this._ints; ++i) {\n this.tag.putInt32(this._s[i] ^ tag[i]);\n }\n\n // trim tag to length\n this.tag.truncate(this.tag.length() % (this._tagLength / 8));\n\n // check authentication tag\n if(options.decrypt && this.tag.bytes() !== this._tag) {\n rval = false;\n }\n\n return rval;\n};\n\n/**\n * See NIST SP-800-38D 6.3 (Algorithm 1). This function performs Galois\n * field multiplication. The field, GF(2^128), is defined by the polynomial:\n *\n * x^128 + x^7 + x^2 + x + 1\n *\n * Which is represented in little-endian binary form as: 11100001 (0xe1). When\n * the value of a coefficient is 1, a bit is set. The value R, is the\n * concatenation of this value and 120 zero bits, yielding a 128-bit value\n * which matches the block size.\n *\n * This function will multiply two elements (vectors of bytes), X and Y, in\n * the field GF(2^128). The result is initialized to zero. For each bit of\n * X (out of 128), x_i, if x_i is set, then the result is multiplied (XOR'd)\n * by the current value of Y. For each bit, the value of Y will be raised by\n * a power of x (multiplied by the polynomial x). This can be achieved by\n * shifting Y once to the right. If the current value of Y, prior to being\n * multiplied by x, has 0 as its LSB, then it is a 127th degree polynomial.\n * Otherwise, we must divide by R after shifting to find the remainder.\n *\n * @param x the first block to multiply by the second.\n * @param y the second block to multiply by the first.\n *\n * @return the block result of the multiplication.\n */\nmodes.gcm.prototype.multiply = function(x, y) {\n var z_i = [0, 0, 0, 0];\n var v_i = y.slice(0);\n\n // calculate Z_128 (block has 128 bits)\n for(var i = 0; i < 128; ++i) {\n // if x_i is 0, Z_{i+1} = Z_i (unchanged)\n // else Z_{i+1} = Z_i ^ V_i\n // get x_i by finding 32-bit int position, then left shift 1 by remainder\n var x_i = x[(i / 32) | 0] & (1 << (31 - i % 32));\n if(x_i) {\n z_i[0] ^= v_i[0];\n z_i[1] ^= v_i[1];\n z_i[2] ^= v_i[2];\n z_i[3] ^= v_i[3];\n }\n\n // if LSB(V_i) is 1, V_i = V_i >> 1\n // else V_i = (V_i >> 1) ^ R\n this.pow(v_i, v_i);\n }\n\n return z_i;\n};\n\nmodes.gcm.prototype.pow = function(x, out) {\n // if LSB(x) is 1, x = x >>> 1\n // else x = (x >>> 1) ^ R\n var lsb = x[3] & 1;\n\n // always do x >>> 1:\n // starting with the rightmost integer, shift each integer to the right\n // one bit, pulling in the bit from the integer to the left as its top\n // most bit (do this for the last 3 integers)\n for(var i = 3; i > 0; --i) {\n out[i] = (x[i] >>> 1) | ((x[i - 1] & 1) << 31);\n }\n // shift the first integer normally\n out[0] = x[0] >>> 1;\n\n // if lsb was not set, then polynomial had a degree of 127 and doesn't\n // need to divided; otherwise, XOR with R to find the remainder; we only\n // need to XOR the first integer since R technically ends w/120 zero bits\n if(lsb) {\n out[0] ^= this._R;\n }\n};\n\nmodes.gcm.prototype.tableMultiply = function(x) {\n // assumes 4-bit tables are used\n var z = [0, 0, 0, 0];\n for(var i = 0; i < 32; ++i) {\n var idx = (i / 8) | 0;\n var x_i = (x[idx] >>> ((7 - (i % 8)) * 4)) & 0xF;\n var ah = this._m[i][x_i];\n z[0] ^= ah[0];\n z[1] ^= ah[1];\n z[2] ^= ah[2];\n z[3] ^= ah[3];\n }\n return z;\n};\n\n/**\n * A continuing version of the GHASH algorithm that operates on a single\n * block. The hash block, last hash value (Ym) and the new block to hash\n * are given.\n *\n * @param h the hash block.\n * @param y the previous value for Ym, use [0, 0, 0, 0] for a new hash.\n * @param x the block to hash.\n *\n * @return the hashed value (Ym).\n */\nmodes.gcm.prototype.ghash = function(h, y, x) {\n y[0] ^= x[0];\n y[1] ^= x[1];\n y[2] ^= x[2];\n y[3] ^= x[3];\n return this.tableMultiply(y);\n //return this.multiply(y, h);\n};\n\n/**\n * Precomputes a table for multiplying against the hash subkey. This\n * mechanism provides a substantial speed increase over multiplication\n * performed without a table. The table-based multiplication this table is\n * for solves X * H by multiplying each component of X by H and then\n * composing the results together using XOR.\n *\n * This function can be used to generate tables with different bit sizes\n * for the components, however, this implementation assumes there are\n * 32 components of X (which is a 16 byte vector), therefore each component\n * takes 4-bits (so the table is constructed with bits=4).\n *\n * @param h the hash subkey.\n * @param bits the bit size for a component.\n */\nmodes.gcm.prototype.generateHashTable = function(h, bits) {\n // TODO: There are further optimizations that would use only the\n // first table M_0 (or some variant) along with a remainder table;\n // this can be explored in the future\n var multiplier = 8 / bits;\n var perInt = 4 * multiplier;\n var size = 16 * multiplier;\n var m = new Array(size);\n for(var i = 0; i < size; ++i) {\n var tmp = [0, 0, 0, 0];\n var idx = (i / perInt) | 0;\n var shft = ((perInt - 1 - (i % perInt)) * bits);\n tmp[idx] = (1 << (bits - 1)) << shft;\n m[i] = this.generateSubHashTable(this.multiply(tmp, h), bits);\n }\n return m;\n};\n\n/**\n * Generates a table for multiplying against the hash subkey for one\n * particular component (out of all possible component values).\n *\n * @param mid the pre-multiplied value for the middle key of the table.\n * @param bits the bit size for a component.\n */\nmodes.gcm.prototype.generateSubHashTable = function(mid, bits) {\n // compute the table quickly by minimizing the number of\n // POW operations -- they only need to be performed for powers of 2,\n // all other entries can be composed from those powers using XOR\n var size = 1 << bits;\n var half = size >>> 1;\n var m = new Array(size);\n m[half] = mid.slice(0);\n var i = half >>> 1;\n while(i > 0) {\n // raise m0[2 * i] and store in m0[i]\n this.pow(m[2 * i], m[i] = []);\n i >>= 1;\n }\n i = 2;\n while(i < half) {\n for(var j = 1; j < i; ++j) {\n var m_i = m[i];\n var m_j = m[j];\n m[i + j] = [\n m_i[0] ^ m_j[0],\n m_i[1] ^ m_j[1],\n m_i[2] ^ m_j[2],\n m_i[3] ^ m_j[3]\n ];\n }\n i *= 2;\n }\n m[0] = [0, 0, 0, 0];\n /* Note: We could avoid storing these by doing composition during multiply\n calculate top half using composition by speed is preferred. */\n for(i = half + 1; i < size; ++i) {\n var c = m[i ^ half];\n m[i] = [mid[0] ^ c[0], mid[1] ^ c[1], mid[2] ^ c[2], mid[3] ^ c[3]];\n }\n return m;\n};\n\n/** Utility functions */\n\nfunction transformIV(iv, blockSize) {\n if(typeof iv === 'string') {\n // convert iv string into byte buffer\n iv = forge.util.createBuffer(iv);\n }\n\n if(forge.util.isArray(iv) && iv.length > 4) {\n // convert iv byte array into byte buffer\n var tmp = iv;\n iv = forge.util.createBuffer();\n for(var i = 0; i < tmp.length; ++i) {\n iv.putByte(tmp[i]);\n }\n }\n\n if(iv.length() < blockSize) {\n throw new Error(\n 'Invalid IV length; got ' + iv.length() +\n ' bytes and expected ' + blockSize + ' bytes.');\n }\n\n if(!forge.util.isArray(iv)) {\n // convert iv byte buffer into 32-bit integer array\n var ints = [];\n var blocks = blockSize / 4;\n for(var i = 0; i < blocks; ++i) {\n ints.push(iv.getInt32());\n }\n iv = ints;\n }\n\n return iv;\n}\n\nfunction inc32(block) {\n // increment last 32 bits of block only\n block[block.length - 1] = (block[block.length - 1] + 1) & 0xFFFFFFFF;\n}\n\nfunction from64To32(num) {\n // convert 64-bit number to two BE Int32s\n return [(num / 0x100000000) | 0, num & 0xFFFFFFFF];\n}\n","/**\n * DES (Data Encryption Standard) implementation.\n *\n * This implementation supports DES as well as 3DES-EDE in ECB and CBC mode.\n * It is based on the BSD-licensed implementation by Paul Tero:\n *\n * Paul Tero, July 2001\n * http://www.tero.co.uk/des/\n *\n * Optimised for performance with large blocks by\n * Michael Hayworth, November 2001\n * http://www.netdealing.com\n *\n * THIS SOFTWARE IS PROVIDED \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT\n * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY\n * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF\n * SUCH DAMAGE.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl \n * Copyright (c) 2012-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./cipher');\nrequire('./cipherModes');\nrequire('./util');\n\n/* DES API */\nmodule.exports = forge.des = forge.des || {};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('DES-', key);\n * cipher.start({iv: iv});\n *\n * Creates an DES cipher object to encrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as binary-encoded strings of bytes or\n * byte buffers.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC' if IV is\n * given, 'ECB' if null).\n *\n * @return the cipher.\n */\nforge.des.startEncrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: false,\n mode: mode || (iv === null ? 'ECB' : 'CBC')\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('DES-', key);\n *\n * Creates an DES cipher object to encrypt data using the given symmetric key.\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.des.createEncryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: false,\n mode: mode\n });\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('DES-', key);\n * decipher.start({iv: iv});\n *\n * Creates an DES cipher object to decrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as binary-encoded strings of bytes or\n * byte buffers.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC' if IV is\n * given, 'ECB' if null).\n *\n * @return the cipher.\n */\nforge.des.startDecrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: true,\n mode: mode || (iv === null ? 'ECB' : 'CBC')\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('DES-', key);\n *\n * Creates an DES cipher object to decrypt data using the given symmetric key.\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.des.createDecryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: true,\n mode: mode\n });\n};\n\n/**\n * Creates a new DES cipher algorithm object.\n *\n * @param name the name of the algorithm.\n * @param mode the mode factory function.\n *\n * @return the DES algorithm object.\n */\nforge.des.Algorithm = function(name, mode) {\n var self = this;\n self.name = name;\n self.mode = new mode({\n blockSize: 8,\n cipher: {\n encrypt: function(inBlock, outBlock) {\n return _updateBlock(self._keys, inBlock, outBlock, false);\n },\n decrypt: function(inBlock, outBlock) {\n return _updateBlock(self._keys, inBlock, outBlock, true);\n }\n }\n });\n self._init = false;\n};\n\n/**\n * Initializes this DES algorithm by expanding its key.\n *\n * @param options the options to use.\n * key the key to use with this algorithm.\n * decrypt true if the algorithm should be initialized for decryption,\n * false for encryption.\n */\nforge.des.Algorithm.prototype.initialize = function(options) {\n if(this._init) {\n return;\n }\n\n var key = forge.util.createBuffer(options.key);\n if(this.name.indexOf('3DES') === 0) {\n if(key.length() !== 24) {\n throw new Error('Invalid Triple-DES key size: ' + key.length() * 8);\n }\n }\n\n // do key expansion to 16 or 48 subkeys (single or triple DES)\n this._keys = _createKeys(key);\n this._init = true;\n};\n\n/** Register DES algorithms **/\n\nregisterAlgorithm('DES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('DES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('DES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('DES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('DES-CTR', forge.cipher.modes.ctr);\n\nregisterAlgorithm('3DES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('3DES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('3DES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('3DES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('3DES-CTR', forge.cipher.modes.ctr);\n\nfunction registerAlgorithm(name, mode) {\n var factory = function() {\n return new forge.des.Algorithm(name, mode);\n };\n forge.cipher.registerAlgorithm(name, factory);\n}\n\n/** DES implementation **/\n\nvar spfunction1 = [0x1010400,0,0x10000,0x1010404,0x1010004,0x10404,0x4,0x10000,0x400,0x1010400,0x1010404,0x400,0x1000404,0x1010004,0x1000000,0x4,0x404,0x1000400,0x1000400,0x10400,0x10400,0x1010000,0x1010000,0x1000404,0x10004,0x1000004,0x1000004,0x10004,0,0x404,0x10404,0x1000000,0x10000,0x1010404,0x4,0x1010000,0x1010400,0x1000000,0x1000000,0x400,0x1010004,0x10000,0x10400,0x1000004,0x400,0x4,0x1000404,0x10404,0x1010404,0x10004,0x1010000,0x1000404,0x1000004,0x404,0x10404,0x1010400,0x404,0x1000400,0x1000400,0,0x10004,0x10400,0,0x1010004];\nvar spfunction2 = [-0x7fef7fe0,-0x7fff8000,0x8000,0x108020,0x100000,0x20,-0x7fefffe0,-0x7fff7fe0,-0x7fffffe0,-0x7fef7fe0,-0x7fef8000,-0x80000000,-0x7fff8000,0x100000,0x20,-0x7fefffe0,0x108000,0x100020,-0x7fff7fe0,0,-0x80000000,0x8000,0x108020,-0x7ff00000,0x100020,-0x7fffffe0,0,0x108000,0x8020,-0x7fef8000,-0x7ff00000,0x8020,0,0x108020,-0x7fefffe0,0x100000,-0x7fff7fe0,-0x7ff00000,-0x7fef8000,0x8000,-0x7ff00000,-0x7fff8000,0x20,-0x7fef7fe0,0x108020,0x20,0x8000,-0x80000000,0x8020,-0x7fef8000,0x100000,-0x7fffffe0,0x100020,-0x7fff7fe0,-0x7fffffe0,0x100020,0x108000,0,-0x7fff8000,0x8020,-0x80000000,-0x7fefffe0,-0x7fef7fe0,0x108000];\nvar spfunction3 = [0x208,0x8020200,0,0x8020008,0x8000200,0,0x20208,0x8000200,0x20008,0x8000008,0x8000008,0x20000,0x8020208,0x20008,0x8020000,0x208,0x8000000,0x8,0x8020200,0x200,0x20200,0x8020000,0x8020008,0x20208,0x8000208,0x20200,0x20000,0x8000208,0x8,0x8020208,0x200,0x8000000,0x8020200,0x8000000,0x20008,0x208,0x20000,0x8020200,0x8000200,0,0x200,0x20008,0x8020208,0x8000200,0x8000008,0x200,0,0x8020008,0x8000208,0x20000,0x8000000,0x8020208,0x8,0x20208,0x20200,0x8000008,0x8020000,0x8000208,0x208,0x8020000,0x20208,0x8,0x8020008,0x20200];\nvar spfunction4 = [0x802001,0x2081,0x2081,0x80,0x802080,0x800081,0x800001,0x2001,0,0x802000,0x802000,0x802081,0x81,0,0x800080,0x800001,0x1,0x2000,0x800000,0x802001,0x80,0x800000,0x2001,0x2080,0x800081,0x1,0x2080,0x800080,0x2000,0x802080,0x802081,0x81,0x800080,0x800001,0x802000,0x802081,0x81,0,0,0x802000,0x2080,0x800080,0x800081,0x1,0x802001,0x2081,0x2081,0x80,0x802081,0x81,0x1,0x2000,0x800001,0x2001,0x802080,0x800081,0x2001,0x2080,0x800000,0x802001,0x80,0x800000,0x2000,0x802080];\nvar spfunction5 = [0x100,0x2080100,0x2080000,0x42000100,0x80000,0x100,0x40000000,0x2080000,0x40080100,0x80000,0x2000100,0x40080100,0x42000100,0x42080000,0x80100,0x40000000,0x2000000,0x40080000,0x40080000,0,0x40000100,0x42080100,0x42080100,0x2000100,0x42080000,0x40000100,0,0x42000000,0x2080100,0x2000000,0x42000000,0x80100,0x80000,0x42000100,0x100,0x2000000,0x40000000,0x2080000,0x42000100,0x40080100,0x2000100,0x40000000,0x42080000,0x2080100,0x40080100,0x100,0x2000000,0x42080000,0x42080100,0x80100,0x42000000,0x42080100,0x2080000,0,0x40080000,0x42000000,0x80100,0x2000100,0x40000100,0x80000,0,0x40080000,0x2080100,0x40000100];\nvar spfunction6 = [0x20000010,0x20400000,0x4000,0x20404010,0x20400000,0x10,0x20404010,0x400000,0x20004000,0x404010,0x400000,0x20000010,0x400010,0x20004000,0x20000000,0x4010,0,0x400010,0x20004010,0x4000,0x404000,0x20004010,0x10,0x20400010,0x20400010,0,0x404010,0x20404000,0x4010,0x404000,0x20404000,0x20000000,0x20004000,0x10,0x20400010,0x404000,0x20404010,0x400000,0x4010,0x20000010,0x400000,0x20004000,0x20000000,0x4010,0x20000010,0x20404010,0x404000,0x20400000,0x404010,0x20404000,0,0x20400010,0x10,0x4000,0x20400000,0x404010,0x4000,0x400010,0x20004010,0,0x20404000,0x20000000,0x400010,0x20004010];\nvar spfunction7 = [0x200000,0x4200002,0x4000802,0,0x800,0x4000802,0x200802,0x4200800,0x4200802,0x200000,0,0x4000002,0x2,0x4000000,0x4200002,0x802,0x4000800,0x200802,0x200002,0x4000800,0x4000002,0x4200000,0x4200800,0x200002,0x4200000,0x800,0x802,0x4200802,0x200800,0x2,0x4000000,0x200800,0x4000000,0x200800,0x200000,0x4000802,0x4000802,0x4200002,0x4200002,0x2,0x200002,0x4000000,0x4000800,0x200000,0x4200800,0x802,0x200802,0x4200800,0x802,0x4000002,0x4200802,0x4200000,0x200800,0,0x2,0x4200802,0,0x200802,0x4200000,0x800,0x4000002,0x4000800,0x800,0x200002];\nvar spfunction8 = [0x10001040,0x1000,0x40000,0x10041040,0x10000000,0x10001040,0x40,0x10000000,0x40040,0x10040000,0x10041040,0x41000,0x10041000,0x41040,0x1000,0x40,0x10040000,0x10000040,0x10001000,0x1040,0x41000,0x40040,0x10040040,0x10041000,0x1040,0,0,0x10040040,0x10000040,0x10001000,0x41040,0x40000,0x41040,0x40000,0x10041000,0x1000,0x40,0x10040040,0x1000,0x41040,0x10001000,0x40,0x10000040,0x10040000,0x10040040,0x10000000,0x40000,0x10001040,0,0x10041040,0x40040,0x10000040,0x10040000,0x10001000,0x10001040,0,0x10041040,0x41000,0x41000,0x1040,0x1040,0x40040,0x10000000,0x10041000];\n\n/**\n * Create necessary sub keys.\n *\n * @param key the 64-bit or 192-bit key.\n *\n * @return the expanded keys.\n */\nfunction _createKeys(key) {\n var pc2bytes0 = [0,0x4,0x20000000,0x20000004,0x10000,0x10004,0x20010000,0x20010004,0x200,0x204,0x20000200,0x20000204,0x10200,0x10204,0x20010200,0x20010204],\n pc2bytes1 = [0,0x1,0x100000,0x100001,0x4000000,0x4000001,0x4100000,0x4100001,0x100,0x101,0x100100,0x100101,0x4000100,0x4000101,0x4100100,0x4100101],\n pc2bytes2 = [0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808,0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808],\n pc2bytes3 = [0,0x200000,0x8000000,0x8200000,0x2000,0x202000,0x8002000,0x8202000,0x20000,0x220000,0x8020000,0x8220000,0x22000,0x222000,0x8022000,0x8222000],\n pc2bytes4 = [0,0x40000,0x10,0x40010,0,0x40000,0x10,0x40010,0x1000,0x41000,0x1010,0x41010,0x1000,0x41000,0x1010,0x41010],\n pc2bytes5 = [0,0x400,0x20,0x420,0,0x400,0x20,0x420,0x2000000,0x2000400,0x2000020,0x2000420,0x2000000,0x2000400,0x2000020,0x2000420],\n pc2bytes6 = [0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002,0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002],\n pc2bytes7 = [0,0x10000,0x800,0x10800,0x20000000,0x20010000,0x20000800,0x20010800,0x20000,0x30000,0x20800,0x30800,0x20020000,0x20030000,0x20020800,0x20030800],\n pc2bytes8 = [0,0x40000,0,0x40000,0x2,0x40002,0x2,0x40002,0x2000000,0x2040000,0x2000000,0x2040000,0x2000002,0x2040002,0x2000002,0x2040002],\n pc2bytes9 = [0,0x10000000,0x8,0x10000008,0,0x10000000,0x8,0x10000008,0x400,0x10000400,0x408,0x10000408,0x400,0x10000400,0x408,0x10000408],\n pc2bytes10 = [0,0x20,0,0x20,0x100000,0x100020,0x100000,0x100020,0x2000,0x2020,0x2000,0x2020,0x102000,0x102020,0x102000,0x102020],\n pc2bytes11 = [0,0x1000000,0x200,0x1000200,0x200000,0x1200000,0x200200,0x1200200,0x4000000,0x5000000,0x4000200,0x5000200,0x4200000,0x5200000,0x4200200,0x5200200],\n pc2bytes12 = [0,0x1000,0x8000000,0x8001000,0x80000,0x81000,0x8080000,0x8081000,0x10,0x1010,0x8000010,0x8001010,0x80010,0x81010,0x8080010,0x8081010],\n pc2bytes13 = [0,0x4,0x100,0x104,0,0x4,0x100,0x104,0x1,0x5,0x101,0x105,0x1,0x5,0x101,0x105];\n\n // how many iterations (1 for des, 3 for triple des)\n // changed by Paul 16/6/2007 to use Triple DES for 9+ byte keys\n var iterations = key.length() > 8 ? 3 : 1;\n\n // stores the return keys\n var keys = [];\n\n // now define the left shifts which need to be done\n var shifts = [0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0];\n\n var n = 0, tmp;\n for(var j = 0; j < iterations; j++) {\n var left = key.getInt32();\n var right = key.getInt32();\n\n tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n right ^= tmp;\n left ^= (tmp << 4);\n\n tmp = ((right >>> -16) ^ left) & 0x0000ffff;\n left ^= tmp;\n right ^= (tmp << -16);\n\n tmp = ((left >>> 2) ^ right) & 0x33333333;\n right ^= tmp;\n left ^= (tmp << 2);\n\n tmp = ((right >>> -16) ^ left) & 0x0000ffff;\n left ^= tmp;\n right ^= (tmp << -16);\n\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n left ^= tmp;\n right ^= (tmp << 8);\n\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n // right needs to be shifted and OR'd with last four bits of left\n tmp = (left << 8) | ((right >>> 20) & 0x000000f0);\n\n // left needs to be put upside down\n left = ((right << 24) | ((right << 8) & 0xff0000) |\n ((right >>> 8) & 0xff00) | ((right >>> 24) & 0xf0));\n right = tmp;\n\n // now go through and perform these shifts on the left and right keys\n for(var i = 0; i < shifts.length; ++i) {\n //shift the keys either one or two bits to the left\n if(shifts[i]) {\n left = (left << 2) | (left >>> 26);\n right = (right << 2) | (right >>> 26);\n } else {\n left = (left << 1) | (left >>> 27);\n right = (right << 1) | (right >>> 27);\n }\n left &= -0xf;\n right &= -0xf;\n\n // now apply PC-2, in such a way that E is easier when encrypting or\n // decrypting this conversion will look like PC-2 except only the last 6\n // bits of each byte are used rather than 48 consecutive bits and the\n // order of lines will be according to how the S selection functions will\n // be applied: S2, S4, S6, S8, S1, S3, S5, S7\n var lefttmp = (\n pc2bytes0[left >>> 28] | pc2bytes1[(left >>> 24) & 0xf] |\n pc2bytes2[(left >>> 20) & 0xf] | pc2bytes3[(left >>> 16) & 0xf] |\n pc2bytes4[(left >>> 12) & 0xf] | pc2bytes5[(left >>> 8) & 0xf] |\n pc2bytes6[(left >>> 4) & 0xf]);\n var righttmp = (\n pc2bytes7[right >>> 28] | pc2bytes8[(right >>> 24) & 0xf] |\n pc2bytes9[(right >>> 20) & 0xf] | pc2bytes10[(right >>> 16) & 0xf] |\n pc2bytes11[(right >>> 12) & 0xf] | pc2bytes12[(right >>> 8) & 0xf] |\n pc2bytes13[(right >>> 4) & 0xf]);\n tmp = ((righttmp >>> 16) ^ lefttmp) & 0x0000ffff;\n keys[n++] = lefttmp ^ tmp;\n keys[n++] = righttmp ^ (tmp << 16);\n }\n }\n\n return keys;\n}\n\n/**\n * Updates a single block (1 byte) using DES. The update will either\n * encrypt or decrypt the block.\n *\n * @param keys the expanded keys.\n * @param input the input block (an array of 32-bit words).\n * @param output the updated output block.\n * @param decrypt true to decrypt the block, false to encrypt it.\n */\nfunction _updateBlock(keys, input, output, decrypt) {\n // set up loops for single or triple DES\n var iterations = keys.length === 32 ? 3 : 9;\n var looping;\n if(iterations === 3) {\n looping = decrypt ? [30, -2, -2] : [0, 32, 2];\n } else {\n looping = (decrypt ?\n [94, 62, -2, 32, 64, 2, 30, -2, -2] :\n [0, 32, 2, 62, 30, -2, 64, 96, 2]);\n }\n\n var tmp;\n\n var left = input[0];\n var right = input[1];\n\n // first each 64 bit chunk of the message must be permuted according to IP\n tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n right ^= tmp;\n left ^= (tmp << 4);\n\n tmp = ((left >>> 16) ^ right) & 0x0000ffff;\n right ^= tmp;\n left ^= (tmp << 16);\n\n tmp = ((right >>> 2) ^ left) & 0x33333333;\n left ^= tmp;\n right ^= (tmp << 2);\n\n tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n left ^= tmp;\n right ^= (tmp << 8);\n\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n // rotate left 1 bit\n left = ((left << 1) | (left >>> 31));\n right = ((right << 1) | (right >>> 31));\n\n for(var j = 0; j < iterations; j += 3) {\n var endloop = looping[j + 1];\n var loopinc = looping[j + 2];\n\n // now go through and perform the encryption or decryption\n for(var i = looping[j]; i != endloop; i += loopinc) {\n var right1 = right ^ keys[i];\n var right2 = ((right >>> 4) | (right << 28)) ^ keys[i + 1];\n\n // passing these bytes through the S selection functions\n tmp = left;\n left = right;\n right = tmp ^ (\n spfunction2[(right1 >>> 24) & 0x3f] |\n spfunction4[(right1 >>> 16) & 0x3f] |\n spfunction6[(right1 >>> 8) & 0x3f] |\n spfunction8[right1 & 0x3f] |\n spfunction1[(right2 >>> 24) & 0x3f] |\n spfunction3[(right2 >>> 16) & 0x3f] |\n spfunction5[(right2 >>> 8) & 0x3f] |\n spfunction7[right2 & 0x3f]);\n }\n // unreverse left and right\n tmp = left;\n left = right;\n right = tmp;\n }\n\n // rotate right 1 bit\n left = ((left >>> 1) | (left << 31));\n right = ((right >>> 1) | (right << 31));\n\n // now perform IP-1, which is IP in the opposite direction\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n left ^= tmp;\n right ^= (tmp << 8);\n\n tmp = ((right >>> 2) ^ left) & 0x33333333;\n left ^= tmp;\n right ^= (tmp << 2);\n\n tmp = ((left >>> 16) ^ right) & 0x0000ffff;\n right ^= tmp;\n left ^= (tmp << 16);\n\n tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n right ^= tmp;\n left ^= (tmp << 4);\n\n output[0] = left;\n output[1] = right;\n}\n\n/**\n * Deprecated. Instead, use:\n *\n * forge.cipher.createCipher('DES-', key);\n * forge.cipher.createDecipher('DES-', key);\n *\n * Creates a deprecated DES cipher object. This object's mode will default to\n * CBC (cipher-block-chaining).\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param options the options to use.\n * key the symmetric key to use (64 or 192 bits).\n * output the buffer to write to.\n * decrypt true for decryption, false for encryption.\n * mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nfunction _createCipher(options) {\n options = options || {};\n var mode = (options.mode || 'CBC').toUpperCase();\n var algorithm = 'DES-' + mode;\n\n var cipher;\n if(options.decrypt) {\n cipher = forge.cipher.createDecipher(algorithm, options.key);\n } else {\n cipher = forge.cipher.createCipher(algorithm, options.key);\n }\n\n // backwards compatible start API\n var start = cipher.start;\n cipher.start = function(iv, options) {\n // backwards compatibility: support second arg as output buffer\n var output = null;\n if(options instanceof forge.util.ByteBuffer) {\n output = options;\n options = {};\n }\n options = options || {};\n options.output = output;\n options.iv = iv;\n start.call(cipher, options);\n };\n\n return cipher;\n}\n","/**\n * Node.js module for Forge message digests.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2017 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\n\nmodule.exports = forge.md = forge.md || {};\nforge.md.algorithms = forge.md.algorithms || {};\n","/**\n * Password-Based Key-Derivation Function #2 implementation.\n *\n * See RFC 2898 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./hmac');\nrequire('./md');\nrequire('./util');\n\nvar pkcs5 = forge.pkcs5 = forge.pkcs5 || {};\n\nvar crypto;\nif(forge.util.isNodejs && !forge.options.usePureJavaScript) {\n crypto = require('crypto');\n}\n\n/**\n * Derives a key from a password.\n *\n * @param p the password as a binary-encoded string of bytes.\n * @param s the salt as a binary-encoded string of bytes.\n * @param c the iteration count, a positive integer.\n * @param dkLen the intended length, in bytes, of the derived key,\n * (max: 2^32 - 1) * hash length of the PRF.\n * @param [md] the message digest (or algorithm identifier as a string) to use\n * in the PRF, defaults to SHA-1.\n * @param [callback(err, key)] presence triggers asynchronous version, called\n * once the operation completes.\n *\n * @return the derived key, as a binary-encoded string of bytes, for the\n * synchronous version (if no callback is specified).\n */\nmodule.exports = forge.pbkdf2 = pkcs5.pbkdf2 = function(\n p, s, c, dkLen, md, callback) {\n if(typeof md === 'function') {\n callback = md;\n md = null;\n }\n\n // use native implementation if possible and not disabled, note that\n // some node versions only support SHA-1, others allow digest to be changed\n if(forge.util.isNodejs && !forge.options.usePureJavaScript &&\n crypto.pbkdf2 && (md === null || typeof md !== 'object') &&\n (crypto.pbkdf2Sync.length > 4 || (!md || md === 'sha1'))) {\n if(typeof md !== 'string') {\n // default prf to SHA-1\n md = 'sha1';\n }\n p = Buffer.from(p, 'binary');\n s = Buffer.from(s, 'binary');\n if(!callback) {\n if(crypto.pbkdf2Sync.length === 4) {\n return crypto.pbkdf2Sync(p, s, c, dkLen).toString('binary');\n }\n return crypto.pbkdf2Sync(p, s, c, dkLen, md).toString('binary');\n }\n if(crypto.pbkdf2Sync.length === 4) {\n return crypto.pbkdf2(p, s, c, dkLen, function(err, key) {\n if(err) {\n return callback(err);\n }\n callback(null, key.toString('binary'));\n });\n }\n return crypto.pbkdf2(p, s, c, dkLen, md, function(err, key) {\n if(err) {\n return callback(err);\n }\n callback(null, key.toString('binary'));\n });\n }\n\n if(typeof md === 'undefined' || md === null) {\n // default prf to SHA-1\n md = 'sha1';\n }\n if(typeof md === 'string') {\n if(!(md in forge.md.algorithms)) {\n throw new Error('Unknown hash algorithm: ' + md);\n }\n md = forge.md[md].create();\n }\n\n var hLen = md.digestLength;\n\n /* 1. If dkLen > (2^32 - 1) * hLen, output \"derived key too long\" and\n stop. */\n if(dkLen > (0xFFFFFFFF * hLen)) {\n var err = new Error('Derived key is too long.');\n if(callback) {\n return callback(err);\n }\n throw err;\n }\n\n /* 2. Let len be the number of hLen-octet blocks in the derived key,\n rounding up, and let r be the number of octets in the last\n block:\n\n len = CEIL(dkLen / hLen),\n r = dkLen - (len - 1) * hLen. */\n var len = Math.ceil(dkLen / hLen);\n var r = dkLen - (len - 1) * hLen;\n\n /* 3. For each block of the derived key apply the function F defined\n below to the password P, the salt S, the iteration count c, and\n the block index to compute the block:\n\n T_1 = F(P, S, c, 1),\n T_2 = F(P, S, c, 2),\n ...\n T_len = F(P, S, c, len),\n\n where the function F is defined as the exclusive-or sum of the\n first c iterates of the underlying pseudorandom function PRF\n applied to the password P and the concatenation of the salt S\n and the block index i:\n\n F(P, S, c, i) = u_1 XOR u_2 XOR ... XOR u_c\n\n where\n\n u_1 = PRF(P, S || INT(i)),\n u_2 = PRF(P, u_1),\n ...\n u_c = PRF(P, u_{c-1}).\n\n Here, INT(i) is a four-octet encoding of the integer i, most\n significant octet first. */\n var prf = forge.hmac.create();\n prf.start(md, p);\n var dk = '';\n var xor, u_c, u_c1;\n\n // sync version\n if(!callback) {\n for(var i = 1; i <= len; ++i) {\n // PRF(P, S || INT(i)) (first iteration)\n prf.start(null, null);\n prf.update(s);\n prf.update(forge.util.int32ToBytes(i));\n xor = u_c1 = prf.digest().getBytes();\n\n // PRF(P, u_{c-1}) (other iterations)\n for(var j = 2; j <= c; ++j) {\n prf.start(null, null);\n prf.update(u_c1);\n u_c = prf.digest().getBytes();\n // F(p, s, c, i)\n xor = forge.util.xorBytes(xor, u_c, hLen);\n u_c1 = u_c;\n }\n\n /* 4. Concatenate the blocks and extract the first dkLen octets to\n produce a derived key DK:\n\n DK = T_1 || T_2 || ... || T_len<0..r-1> */\n dk += (i < len) ? xor : xor.substr(0, r);\n }\n /* 5. Output the derived key DK. */\n return dk;\n }\n\n // async version\n var i = 1, j;\n function outer() {\n if(i > len) {\n // done\n return callback(null, dk);\n }\n\n // PRF(P, S || INT(i)) (first iteration)\n prf.start(null, null);\n prf.update(s);\n prf.update(forge.util.int32ToBytes(i));\n xor = u_c1 = prf.digest().getBytes();\n\n // PRF(P, u_{c-1}) (other iterations)\n j = 2;\n inner();\n }\n\n function inner() {\n if(j <= c) {\n prf.start(null, null);\n prf.update(u_c1);\n u_c = prf.digest().getBytes();\n // F(p, s, c, i)\n xor = forge.util.xorBytes(xor, u_c, hLen);\n u_c1 = u_c;\n ++j;\n return forge.util.setImmediate(inner);\n }\n\n /* 4. Concatenate the blocks and extract the first dkLen octets to\n produce a derived key DK:\n\n DK = T_1 || T_2 || ... || T_len<0..r-1> */\n dk += (i < len) ? xor : xor.substr(0, r);\n\n ++i;\n outer();\n }\n\n outer();\n};\n","/**\n * Hash-based Message Authentication Code implementation. Requires a message\n * digest object that can be obtained, for example, from forge.md.sha1 or\n * forge.md.md5.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2012 Digital Bazaar, Inc. All rights reserved.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\n/* HMAC API */\nvar hmac = module.exports = forge.hmac = forge.hmac || {};\n\n/**\n * Creates an HMAC object that uses the given message digest object.\n *\n * @return an HMAC object.\n */\nhmac.create = function() {\n // the hmac key to use\n var _key = null;\n\n // the message digest to use\n var _md = null;\n\n // the inner padding\n var _ipadding = null;\n\n // the outer padding\n var _opadding = null;\n\n // hmac context\n var ctx = {};\n\n /**\n * Starts or restarts the HMAC with the given key and message digest.\n *\n * @param md the message digest to use, null to reuse the previous one,\n * a string to use builtin 'sha1', 'md5', 'sha256'.\n * @param key the key to use as a string, array of bytes, byte buffer,\n * or null to reuse the previous key.\n */\n ctx.start = function(md, key) {\n if(md !== null) {\n if(typeof md === 'string') {\n // create builtin message digest\n md = md.toLowerCase();\n if(md in forge.md.algorithms) {\n _md = forge.md.algorithms[md].create();\n } else {\n throw new Error('Unknown hash algorithm \"' + md + '\"');\n }\n } else {\n // store message digest\n _md = md;\n }\n }\n\n if(key === null) {\n // reuse previous key\n key = _key;\n } else {\n if(typeof key === 'string') {\n // convert string into byte buffer\n key = forge.util.createBuffer(key);\n } else if(forge.util.isArray(key)) {\n // convert byte array into byte buffer\n var tmp = key;\n key = forge.util.createBuffer();\n for(var i = 0; i < tmp.length; ++i) {\n key.putByte(tmp[i]);\n }\n }\n\n // if key is longer than blocksize, hash it\n var keylen = key.length();\n if(keylen > _md.blockLength) {\n _md.start();\n _md.update(key.bytes());\n key = _md.digest();\n }\n\n // mix key into inner and outer padding\n // ipadding = [0x36 * blocksize] ^ key\n // opadding = [0x5C * blocksize] ^ key\n _ipadding = forge.util.createBuffer();\n _opadding = forge.util.createBuffer();\n keylen = key.length();\n for(var i = 0; i < keylen; ++i) {\n var tmp = key.at(i);\n _ipadding.putByte(0x36 ^ tmp);\n _opadding.putByte(0x5C ^ tmp);\n }\n\n // if key is shorter than blocksize, add additional padding\n if(keylen < _md.blockLength) {\n var tmp = _md.blockLength - keylen;\n for(var i = 0; i < tmp; ++i) {\n _ipadding.putByte(0x36);\n _opadding.putByte(0x5C);\n }\n }\n _key = key;\n _ipadding = _ipadding.bytes();\n _opadding = _opadding.bytes();\n }\n\n // digest is done like so: hash(opadding | hash(ipadding | message))\n\n // prepare to do inner hash\n // hash(ipadding | message)\n _md.start();\n _md.update(_ipadding);\n };\n\n /**\n * Updates the HMAC with the given message bytes.\n *\n * @param bytes the bytes to update with.\n */\n ctx.update = function(bytes) {\n _md.update(bytes);\n };\n\n /**\n * Produces the Message Authentication Code (MAC).\n *\n * @return a byte buffer containing the digest value.\n */\n ctx.getMac = function() {\n // digest is done like so: hash(opadding | hash(ipadding | message))\n // here we do the outer hashing\n var inner = _md.digest().bytes();\n _md.start();\n _md.update(_opadding);\n _md.update(inner);\n return _md.digest();\n };\n // alias for getMac\n ctx.digest = ctx.getMac;\n\n return ctx;\n};\n","/**\n * Javascript implementation of basic PEM (Privacy Enhanced Mail) algorithms.\n *\n * See: RFC 1421.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2013-2014 Digital Bazaar, Inc.\n *\n * A Forge PEM object has the following fields:\n *\n * type: identifies the type of message (eg: \"RSA PRIVATE KEY\").\n *\n * procType: identifies the type of processing performed on the message,\n * it has two subfields: version and type, eg: 4,ENCRYPTED.\n *\n * contentDomain: identifies the type of content in the message, typically\n * only uses the value: \"RFC822\".\n *\n * dekInfo: identifies the message encryption algorithm and mode and includes\n * any parameters for the algorithm, it has two subfields: algorithm and\n * parameters, eg: DES-CBC,F8143EDE5960C597.\n *\n * headers: contains all other PEM encapsulated headers -- where order is\n * significant (for pairing data like recipient ID + key info).\n *\n * body: the binary-encoded body.\n */\nvar forge = require('./forge');\nrequire('./util');\n\n// shortcut for pem API\nvar pem = module.exports = forge.pem = forge.pem || {};\n\n/**\n * Encodes (serializes) the given PEM object.\n *\n * @param msg the PEM message object to encode.\n * @param options the options to use:\n * maxline the maximum characters per line for the body, (default: 64).\n *\n * @return the PEM-formatted string.\n */\npem.encode = function(msg, options) {\n options = options || {};\n var rval = '-----BEGIN ' + msg.type + '-----\\r\\n';\n\n // encode special headers\n var header;\n if(msg.procType) {\n header = {\n name: 'Proc-Type',\n values: [String(msg.procType.version), msg.procType.type]\n };\n rval += foldHeader(header);\n }\n if(msg.contentDomain) {\n header = {name: 'Content-Domain', values: [msg.contentDomain]};\n rval += foldHeader(header);\n }\n if(msg.dekInfo) {\n header = {name: 'DEK-Info', values: [msg.dekInfo.algorithm]};\n if(msg.dekInfo.parameters) {\n header.values.push(msg.dekInfo.parameters);\n }\n rval += foldHeader(header);\n }\n\n if(msg.headers) {\n // encode all other headers\n for(var i = 0; i < msg.headers.length; ++i) {\n rval += foldHeader(msg.headers[i]);\n }\n }\n\n // terminate header\n if(msg.procType) {\n rval += '\\r\\n';\n }\n\n // add body\n rval += forge.util.encode64(msg.body, options.maxline || 64) + '\\r\\n';\n\n rval += '-----END ' + msg.type + '-----\\r\\n';\n return rval;\n};\n\n/**\n * Decodes (deserializes) all PEM messages found in the given string.\n *\n * @param str the PEM-formatted string to decode.\n *\n * @return the PEM message objects in an array.\n */\npem.decode = function(str) {\n var rval = [];\n\n // split string into PEM messages (be lenient w/EOF on BEGIN line)\n var rMessage = /\\s*-----BEGIN ([A-Z0-9- ]+)-----\\r?\\n?([\\x21-\\x7e\\s]+?(?:\\r?\\n\\r?\\n))?([:A-Za-z0-9+\\/=\\s]+?)-----END \\1-----/g;\n var rHeader = /([\\x21-\\x7e]+):\\s*([\\x21-\\x7e\\s^:]+)/;\n var rCRLF = /\\r?\\n/;\n var match;\n while(true) {\n match = rMessage.exec(str);\n if(!match) {\n break;\n }\n\n var msg = {\n type: match[1],\n procType: null,\n contentDomain: null,\n dekInfo: null,\n headers: [],\n body: forge.util.decode64(match[3])\n };\n rval.push(msg);\n\n // no headers\n if(!match[2]) {\n continue;\n }\n\n // parse headers\n var lines = match[2].split(rCRLF);\n var li = 0;\n while(match && li < lines.length) {\n // get line, trim any rhs whitespace\n var line = lines[li].replace(/\\s+$/, '');\n\n // RFC2822 unfold any following folded lines\n for(var nl = li + 1; nl < lines.length; ++nl) {\n var next = lines[nl];\n if(!/\\s/.test(next[0])) {\n break;\n }\n line += next;\n li = nl;\n }\n\n // parse header\n match = line.match(rHeader);\n if(match) {\n var header = {name: match[1], values: []};\n var values = match[2].split(',');\n for(var vi = 0; vi < values.length; ++vi) {\n header.values.push(ltrim(values[vi]));\n }\n\n // Proc-Type must be the first header\n if(!msg.procType) {\n if(header.name !== 'Proc-Type') {\n throw new Error('Invalid PEM formatted message. The first ' +\n 'encapsulated header must be \"Proc-Type\".');\n } else if(header.values.length !== 2) {\n throw new Error('Invalid PEM formatted message. The \"Proc-Type\" ' +\n 'header must have two subfields.');\n }\n msg.procType = {version: values[0], type: values[1]};\n } else if(!msg.contentDomain && header.name === 'Content-Domain') {\n // special-case Content-Domain\n msg.contentDomain = values[0] || '';\n } else if(!msg.dekInfo && header.name === 'DEK-Info') {\n // special-case DEK-Info\n if(header.values.length === 0) {\n throw new Error('Invalid PEM formatted message. The \"DEK-Info\" ' +\n 'header must have at least one subfield.');\n }\n msg.dekInfo = {algorithm: values[0], parameters: values[1] || null};\n } else {\n msg.headers.push(header);\n }\n }\n\n ++li;\n }\n\n if(msg.procType === 'ENCRYPTED' && !msg.dekInfo) {\n throw new Error('Invalid PEM formatted message. The \"DEK-Info\" ' +\n 'header must be present if \"Proc-Type\" is \"ENCRYPTED\".');\n }\n }\n\n if(rval.length === 0) {\n throw new Error('Invalid PEM formatted message.');\n }\n\n return rval;\n};\n\nfunction foldHeader(header) {\n var rval = header.name + ': ';\n\n // ensure values with CRLF are folded\n var values = [];\n var insertSpace = function(match, $1) {\n return ' ' + $1;\n };\n for(var i = 0; i < header.values.length; ++i) {\n values.push(header.values[i].replace(/^(\\S+\\r\\n)/, insertSpace));\n }\n rval += values.join(',') + '\\r\\n';\n\n // do folding\n var length = 0;\n var candidate = -1;\n for(var i = 0; i < rval.length; ++i, ++length) {\n if(length > 65 && candidate !== -1) {\n var insert = rval[candidate];\n if(insert === ',') {\n ++candidate;\n rval = rval.substr(0, candidate) + '\\r\\n ' + rval.substr(candidate);\n } else {\n rval = rval.substr(0, candidate) +\n '\\r\\n' + insert + rval.substr(candidate + 1);\n }\n length = (i - candidate - 1);\n candidate = -1;\n ++i;\n } else if(rval[i] === ' ' || rval[i] === '\\t' || rval[i] === ',') {\n candidate = i;\n }\n }\n\n return rval;\n}\n\nfunction ltrim(str) {\n return str.replace(/^\\s+/, '');\n}\n","/**\n * An API for getting cryptographically-secure random bytes. The bytes are\n * generated using the Fortuna algorithm devised by Bruce Schneier and\n * Niels Ferguson.\n *\n * Getting strong random bytes is not yet easy to do in javascript. The only\n * truish random entropy that can be collected is from the mouse, keyboard, or\n * from timing with respect to page loads, etc. This generator makes a poor\n * attempt at providing random bytes when those sources haven't yet provided\n * enough entropy to initially seed or to reseed the PRNG.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2009-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./sha256');\nrequire('./prng');\nrequire('./util');\n\n(function() {\n\n// forge.random already defined\nif(forge.random && forge.random.getBytes) {\n module.exports = forge.random;\n return;\n}\n\n(function(jQuery) {\n\n// the default prng plugin, uses AES-128\nvar prng_aes = {};\nvar _prng_aes_output = new Array(4);\nvar _prng_aes_buffer = forge.util.createBuffer();\nprng_aes.formatKey = function(key) {\n // convert the key into 32-bit integers\n var tmp = forge.util.createBuffer(key);\n key = new Array(4);\n key[0] = tmp.getInt32();\n key[1] = tmp.getInt32();\n key[2] = tmp.getInt32();\n key[3] = tmp.getInt32();\n\n // return the expanded key\n return forge.aes._expandKey(key, false);\n};\nprng_aes.formatSeed = function(seed) {\n // convert seed into 32-bit integers\n var tmp = forge.util.createBuffer(seed);\n seed = new Array(4);\n seed[0] = tmp.getInt32();\n seed[1] = tmp.getInt32();\n seed[2] = tmp.getInt32();\n seed[3] = tmp.getInt32();\n return seed;\n};\nprng_aes.cipher = function(key, seed) {\n forge.aes._updateBlock(key, seed, _prng_aes_output, false);\n _prng_aes_buffer.putInt32(_prng_aes_output[0]);\n _prng_aes_buffer.putInt32(_prng_aes_output[1]);\n _prng_aes_buffer.putInt32(_prng_aes_output[2]);\n _prng_aes_buffer.putInt32(_prng_aes_output[3]);\n return _prng_aes_buffer.getBytes();\n};\nprng_aes.increment = function(seed) {\n // FIXME: do we care about carry or signed issues?\n ++seed[3];\n return seed;\n};\nprng_aes.md = forge.md.sha256;\n\n/**\n * Creates a new PRNG.\n */\nfunction spawnPrng() {\n var ctx = forge.prng.create(prng_aes);\n\n /**\n * Gets random bytes. If a native secure crypto API is unavailable, this\n * method tries to make the bytes more unpredictable by drawing from data that\n * can be collected from the user of the browser, eg: mouse movement.\n *\n * If a callback is given, this method will be called asynchronously.\n *\n * @param count the number of random bytes to get.\n * @param [callback(err, bytes)] called once the operation completes.\n *\n * @return the random bytes in a string.\n */\n ctx.getBytes = function(count, callback) {\n return ctx.generate(count, callback);\n };\n\n /**\n * Gets random bytes asynchronously. If a native secure crypto API is\n * unavailable, this method tries to make the bytes more unpredictable by\n * drawing from data that can be collected from the user of the browser,\n * eg: mouse movement.\n *\n * @param count the number of random bytes to get.\n *\n * @return the random bytes in a string.\n */\n ctx.getBytesSync = function(count) {\n return ctx.generate(count);\n };\n\n return ctx;\n}\n\n// create default prng context\nvar _ctx = spawnPrng();\n\n// add other sources of entropy only if window.crypto.getRandomValues is not\n// available -- otherwise this source will be automatically used by the prng\nvar getRandomValues = null;\nvar globalScope = forge.util.globalScope;\nvar _crypto = globalScope.crypto || globalScope.msCrypto;\nif(_crypto && _crypto.getRandomValues) {\n getRandomValues = function(arr) {\n return _crypto.getRandomValues(arr);\n };\n}\n\nif(forge.options.usePureJavaScript ||\n (!forge.util.isNodejs && !getRandomValues)) {\n // if this is a web worker, do not use weak entropy, instead register to\n // receive strong entropy asynchronously from the main thread\n if(typeof window === 'undefined' || window.document === undefined) {\n // FIXME:\n }\n\n // get load time entropy\n _ctx.collectInt(+new Date(), 32);\n\n // add some entropy from navigator object\n if(typeof(navigator) !== 'undefined') {\n var _navBytes = '';\n for(var key in navigator) {\n try {\n if(typeof(navigator[key]) == 'string') {\n _navBytes += navigator[key];\n }\n } catch(e) {\n /* Some navigator keys might not be accessible, e.g. the geolocation\n attribute throws an exception if touched in Mozilla chrome://\n context.\n\n Silently ignore this and just don't use this as a source of\n entropy. */\n }\n }\n _ctx.collect(_navBytes);\n _navBytes = null;\n }\n\n // add mouse and keyboard collectors if jquery is available\n if(jQuery) {\n // set up mouse entropy capture\n jQuery().mousemove(function(e) {\n // add mouse coords\n _ctx.collectInt(e.clientX, 16);\n _ctx.collectInt(e.clientY, 16);\n });\n\n // set up keyboard entropy capture\n jQuery().keypress(function(e) {\n _ctx.collectInt(e.charCode, 8);\n });\n }\n}\n\n/* Random API */\nif(!forge.random) {\n forge.random = _ctx;\n} else {\n // extend forge.random with _ctx\n for(var key in _ctx) {\n forge.random[key] = _ctx[key];\n }\n}\n\n// expose spawn PRNG\nforge.random.createInstance = spawnPrng;\n\nmodule.exports = forge.random;\n\n})(typeof(jQuery) !== 'undefined' ? jQuery : null);\n\n})();\n","/**\n * Secure Hash Algorithm with 256-bit digest (SHA-256) implementation.\n *\n * See FIPS 180-2 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha256 = module.exports = forge.sha256 = forge.sha256 || {};\nforge.md.sha256 = forge.md.algorithms.sha256 = sha256;\n\n/**\n * Creates a SHA-256 message digest object.\n *\n * @return a message digest object.\n */\nsha256.create = function() {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n // SHA-256 state contains eight 32-bit integers\n var _state = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for word storage\n var _w = new Array(64);\n\n // message digest object\n var md = {\n algorithm: 'sha256',\n blockLength: 64,\n digestLength: 32,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 8\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength64 for backwards-compatibility)\n md.fullMessageLength = md.messageLength64 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _state = {\n h0: 0x6A09E667,\n h1: 0xBB67AE85,\n h2: 0x3C6EF372,\n h3: 0xA54FF53A,\n h4: 0x510E527F,\n h5: 0x9B05688C,\n h6: 0x1F83D9AB,\n h7: 0x5BE0CD19\n };\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = ((len[1] / 0x100000000) >>> 0);\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_state, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate SHA-256 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 448 mod 512. In other words,\n the data to be digested must be a multiple of 512 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 8 bytes (64\n bits), that means that the last segment of the data must have 56 bytes\n (448 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 448 mod 512 because\n 512 - 128 = 448.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 448 mod 512, then 512 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in big-endian order; since length\n // is stored in bytes we multiply by 8 and add carry from next int\n var next, carry;\n var bits = md.fullMessageLength[0] * 8;\n for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n next = md.fullMessageLength[i + 1] * 8;\n carry = (next / 0x100000000) >>> 0;\n bits += carry;\n finalBlock.putInt32(bits >>> 0);\n bits = next >>> 0;\n }\n finalBlock.putInt32(bits);\n\n var s2 = {\n h0: _state.h0,\n h1: _state.h1,\n h2: _state.h2,\n h3: _state.h3,\n h4: _state.h4,\n h5: _state.h5,\n h6: _state.h6,\n h7: _state.h7\n };\n _update(s2, _w, finalBlock);\n var rval = forge.util.createBuffer();\n rval.putInt32(s2.h0);\n rval.putInt32(s2.h1);\n rval.putInt32(s2.h2);\n rval.putInt32(s2.h3);\n rval.putInt32(s2.h4);\n rval.putInt32(s2.h5);\n rval.putInt32(s2.h6);\n rval.putInt32(s2.h7);\n return rval;\n };\n\n return md;\n};\n\n// sha-256 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n// table of constants\nvar _k = null;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 64);\n\n // create K table for SHA-256\n _k = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2];\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates a SHA-256 state with the given byte buffer.\n *\n * @param s the SHA-256 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (64 byte) chunks\n var t1, t2, s0, s1, ch, maj, i, a, b, c, d, e, f, g, h;\n var len = bytes.length();\n while(len >= 64) {\n // the w array will be populated with sixteen 32-bit big-endian words\n // and then extended into 64 32-bit words according to SHA-256\n for(i = 0; i < 16; ++i) {\n w[i] = bytes.getInt32();\n }\n for(; i < 64; ++i) {\n // XOR word 2 words ago rot right 17, rot right 19, shft right 10\n t1 = w[i - 2];\n t1 =\n ((t1 >>> 17) | (t1 << 15)) ^\n ((t1 >>> 19) | (t1 << 13)) ^\n (t1 >>> 10);\n // XOR word 15 words ago rot right 7, rot right 18, shft right 3\n t2 = w[i - 15];\n t2 =\n ((t2 >>> 7) | (t2 << 25)) ^\n ((t2 >>> 18) | (t2 << 14)) ^\n (t2 >>> 3);\n // sum(t1, word 7 ago, t2, word 16 ago) modulo 2^32\n w[i] = (t1 + w[i - 7] + t2 + w[i - 16]) | 0;\n }\n\n // initialize hash value for this chunk\n a = s.h0;\n b = s.h1;\n c = s.h2;\n d = s.h3;\n e = s.h4;\n f = s.h5;\n g = s.h6;\n h = s.h7;\n\n // round function\n for(i = 0; i < 64; ++i) {\n // Sum1(e)\n s1 =\n ((e >>> 6) | (e << 26)) ^\n ((e >>> 11) | (e << 21)) ^\n ((e >>> 25) | (e << 7));\n // Ch(e, f, g) (optimized the same way as SHA-1)\n ch = g ^ (e & (f ^ g));\n // Sum0(a)\n s0 =\n ((a >>> 2) | (a << 30)) ^\n ((a >>> 13) | (a << 19)) ^\n ((a >>> 22) | (a << 10));\n // Maj(a, b, c) (optimized the same way as SHA-1)\n maj = (a & b) | (c & (a ^ b));\n\n // main algorithm\n t1 = h + s1 + ch + _k[i] + w[i];\n t2 = s0 + maj;\n h = g;\n g = f;\n f = e;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n // can't truncate with `| 0`\n e = (d + t1) >>> 0;\n d = c;\n c = b;\n b = a;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n // can't truncate with `| 0`\n a = (t1 + t2) >>> 0;\n }\n\n // update hash state\n s.h0 = (s.h0 + a) | 0;\n s.h1 = (s.h1 + b) | 0;\n s.h2 = (s.h2 + c) | 0;\n s.h3 = (s.h3 + d) | 0;\n s.h4 = (s.h4 + e) | 0;\n s.h5 = (s.h5 + f) | 0;\n s.h6 = (s.h6 + g) | 0;\n s.h7 = (s.h7 + h) | 0;\n len -= 64;\n }\n}\n","/**\n * A javascript implementation of a cryptographically-secure\n * Pseudo Random Number Generator (PRNG). The Fortuna algorithm is followed\n * here though the use of SHA-256 is not enforced; when generating an\n * a PRNG context, the hashing algorithm and block cipher used for\n * the generator are specified via a plugin.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nvar _crypto = null;\nif(forge.util.isNodejs && !forge.options.usePureJavaScript &&\n !process.versions['node-webkit']) {\n _crypto = require('crypto');\n}\n\n/* PRNG API */\nvar prng = module.exports = forge.prng = forge.prng || {};\n\n/**\n * Creates a new PRNG context.\n *\n * A PRNG plugin must be passed in that will provide:\n *\n * 1. A function that initializes the key and seed of a PRNG context. It\n * will be given a 16 byte key and a 16 byte seed. Any key expansion\n * or transformation of the seed from a byte string into an array of\n * integers (or similar) should be performed.\n * 2. The cryptographic function used by the generator. It takes a key and\n * a seed.\n * 3. A seed increment function. It takes the seed and returns seed + 1.\n * 4. An api to create a message digest.\n *\n * For an example, see random.js.\n *\n * @param plugin the PRNG plugin to use.\n */\nprng.create = function(plugin) {\n var ctx = {\n plugin: plugin,\n key: null,\n seed: null,\n time: null,\n // number of reseeds so far\n reseeds: 0,\n // amount of data generated so far\n generated: 0,\n // no initial key bytes\n keyBytes: ''\n };\n\n // create 32 entropy pools (each is a message digest)\n var md = plugin.md;\n var pools = new Array(32);\n for(var i = 0; i < 32; ++i) {\n pools[i] = md.create();\n }\n ctx.pools = pools;\n\n // entropy pools are written to cyclically, starting at index 0\n ctx.pool = 0;\n\n /**\n * Generates random bytes. The bytes may be generated synchronously or\n * asynchronously. Web workers must use the asynchronous interface or\n * else the behavior is undefined.\n *\n * @param count the number of random bytes to generate.\n * @param [callback(err, bytes)] called once the operation completes.\n *\n * @return count random bytes as a string.\n */\n ctx.generate = function(count, callback) {\n // do synchronously\n if(!callback) {\n return ctx.generateSync(count);\n }\n\n // simple generator using counter-based CBC\n var cipher = ctx.plugin.cipher;\n var increment = ctx.plugin.increment;\n var formatKey = ctx.plugin.formatKey;\n var formatSeed = ctx.plugin.formatSeed;\n var b = forge.util.createBuffer();\n\n // paranoid deviation from Fortuna:\n // reset key for every request to protect previously\n // generated random bytes should the key be discovered;\n // there is no 100ms based reseeding because of this\n // forced reseed for every `generate` call\n ctx.key = null;\n\n generate();\n\n function generate(err) {\n if(err) {\n return callback(err);\n }\n\n // sufficient bytes generated\n if(b.length() >= count) {\n return callback(null, b.getBytes(count));\n }\n\n // if amount of data generated is greater than 1 MiB, trigger reseed\n if(ctx.generated > 0xfffff) {\n ctx.key = null;\n }\n\n if(ctx.key === null) {\n // prevent stack overflow\n return forge.util.nextTick(function() {\n _reseed(generate);\n });\n }\n\n // generate the random bytes\n var bytes = cipher(ctx.key, ctx.seed);\n ctx.generated += bytes.length;\n b.putBytes(bytes);\n\n // generate bytes for a new key and seed\n ctx.key = formatKey(cipher(ctx.key, increment(ctx.seed)));\n ctx.seed = formatSeed(cipher(ctx.key, ctx.seed));\n\n forge.util.setImmediate(generate);\n }\n };\n\n /**\n * Generates random bytes synchronously.\n *\n * @param count the number of random bytes to generate.\n *\n * @return count random bytes as a string.\n */\n ctx.generateSync = function(count) {\n // simple generator using counter-based CBC\n var cipher = ctx.plugin.cipher;\n var increment = ctx.plugin.increment;\n var formatKey = ctx.plugin.formatKey;\n var formatSeed = ctx.plugin.formatSeed;\n\n // paranoid deviation from Fortuna:\n // reset key for every request to protect previously\n // generated random bytes should the key be discovered;\n // there is no 100ms based reseeding because of this\n // forced reseed for every `generateSync` call\n ctx.key = null;\n\n var b = forge.util.createBuffer();\n while(b.length() < count) {\n // if amount of data generated is greater than 1 MiB, trigger reseed\n if(ctx.generated > 0xfffff) {\n ctx.key = null;\n }\n\n if(ctx.key === null) {\n _reseedSync();\n }\n\n // generate the random bytes\n var bytes = cipher(ctx.key, ctx.seed);\n ctx.generated += bytes.length;\n b.putBytes(bytes);\n\n // generate bytes for a new key and seed\n ctx.key = formatKey(cipher(ctx.key, increment(ctx.seed)));\n ctx.seed = formatSeed(cipher(ctx.key, ctx.seed));\n }\n\n return b.getBytes(count);\n };\n\n /**\n * Private function that asynchronously reseeds a generator.\n *\n * @param callback(err) called once the operation completes.\n */\n function _reseed(callback) {\n if(ctx.pools[0].messageLength >= 32) {\n _seed();\n return callback();\n }\n // not enough seed data...\n var needed = (32 - ctx.pools[0].messageLength) << 5;\n ctx.seedFile(needed, function(err, bytes) {\n if(err) {\n return callback(err);\n }\n ctx.collect(bytes);\n _seed();\n callback();\n });\n }\n\n /**\n * Private function that synchronously reseeds a generator.\n */\n function _reseedSync() {\n if(ctx.pools[0].messageLength >= 32) {\n return _seed();\n }\n // not enough seed data...\n var needed = (32 - ctx.pools[0].messageLength) << 5;\n ctx.collect(ctx.seedFileSync(needed));\n _seed();\n }\n\n /**\n * Private function that seeds a generator once enough bytes are available.\n */\n function _seed() {\n // update reseed count\n ctx.reseeds = (ctx.reseeds === 0xffffffff) ? 0 : ctx.reseeds + 1;\n\n // goal is to update `key` via:\n // key = hash(key + s)\n // where 's' is all collected entropy from selected pools, then...\n\n // create a plugin-based message digest\n var md = ctx.plugin.md.create();\n\n // consume current key bytes\n md.update(ctx.keyBytes);\n\n // digest the entropy of pools whose index k meet the\n // condition 'n mod 2^k == 0' where n is the number of reseeds\n var _2powK = 1;\n for(var k = 0; k < 32; ++k) {\n if(ctx.reseeds % _2powK === 0) {\n md.update(ctx.pools[k].digest().getBytes());\n ctx.pools[k].start();\n }\n _2powK = _2powK << 1;\n }\n\n // get digest for key bytes\n ctx.keyBytes = md.digest().getBytes();\n\n // paranoid deviation from Fortuna:\n // update `seed` via `seed = hash(key)`\n // instead of initializing to zero once and only\n // ever incrementing it\n md.start();\n md.update(ctx.keyBytes);\n var seedBytes = md.digest().getBytes();\n\n // update state\n ctx.key = ctx.plugin.formatKey(ctx.keyBytes);\n ctx.seed = ctx.plugin.formatSeed(seedBytes);\n ctx.generated = 0;\n }\n\n /**\n * The built-in default seedFile. This seedFile is used when entropy\n * is needed immediately.\n *\n * @param needed the number of bytes that are needed.\n *\n * @return the random bytes.\n */\n function defaultSeedFile(needed) {\n // use window.crypto.getRandomValues strong source of entropy if available\n var getRandomValues = null;\n var globalScope = forge.util.globalScope;\n var _crypto = globalScope.crypto || globalScope.msCrypto;\n if(_crypto && _crypto.getRandomValues) {\n getRandomValues = function(arr) {\n return _crypto.getRandomValues(arr);\n };\n }\n\n var b = forge.util.createBuffer();\n if(getRandomValues) {\n while(b.length() < needed) {\n // max byte length is 65536 before QuotaExceededError is thrown\n // http://www.w3.org/TR/WebCryptoAPI/#RandomSource-method-getRandomValues\n var count = Math.max(1, Math.min(needed - b.length(), 65536) / 4);\n var entropy = new Uint32Array(Math.floor(count));\n try {\n getRandomValues(entropy);\n for(var i = 0; i < entropy.length; ++i) {\n b.putInt32(entropy[i]);\n }\n } catch(e) {\n /* only ignore QuotaExceededError */\n if(!(typeof QuotaExceededError !== 'undefined' &&\n e instanceof QuotaExceededError)) {\n throw e;\n }\n }\n }\n }\n\n // be sad and add some weak random data\n if(b.length() < needed) {\n /* Draws from Park-Miller \"minimal standard\" 31 bit PRNG,\n implemented with David G. Carta's optimization: with 32 bit math\n and without division (Public Domain). */\n var hi, lo, next;\n var seed = Math.floor(Math.random() * 0x010000);\n while(b.length() < needed) {\n lo = 16807 * (seed & 0xFFFF);\n hi = 16807 * (seed >> 16);\n lo += (hi & 0x7FFF) << 16;\n lo += hi >> 15;\n lo = (lo & 0x7FFFFFFF) + (lo >> 31);\n seed = lo & 0xFFFFFFFF;\n\n // consume lower 3 bytes of seed\n for(var i = 0; i < 3; ++i) {\n // throw in more pseudo random\n next = seed >>> (i << 3);\n next ^= Math.floor(Math.random() * 0x0100);\n b.putByte(String.fromCharCode(next & 0xFF));\n }\n }\n }\n\n return b.getBytes(needed);\n }\n // initialize seed file APIs\n if(_crypto) {\n // use nodejs async API\n ctx.seedFile = function(needed, callback) {\n _crypto.randomBytes(needed, function(err, bytes) {\n if(err) {\n return callback(err);\n }\n callback(null, bytes.toString());\n });\n };\n // use nodejs sync API\n ctx.seedFileSync = function(needed) {\n return _crypto.randomBytes(needed).toString();\n };\n } else {\n ctx.seedFile = function(needed, callback) {\n try {\n callback(null, defaultSeedFile(needed));\n } catch(e) {\n callback(e);\n }\n };\n ctx.seedFileSync = defaultSeedFile;\n }\n\n /**\n * Adds entropy to a prng ctx's accumulator.\n *\n * @param bytes the bytes of entropy as a string.\n */\n ctx.collect = function(bytes) {\n // iterate over pools distributing entropy cyclically\n var count = bytes.length;\n for(var i = 0; i < count; ++i) {\n ctx.pools[ctx.pool].update(bytes.substr(i, 1));\n ctx.pool = (ctx.pool === 31) ? 0 : ctx.pool + 1;\n }\n };\n\n /**\n * Collects an integer of n bits.\n *\n * @param i the integer entropy.\n * @param n the number of bits in the integer.\n */\n ctx.collectInt = function(i, n) {\n var bytes = '';\n for(var x = 0; x < n; x += 8) {\n bytes += String.fromCharCode((i >> x) & 0xFF);\n }\n ctx.collect(bytes);\n };\n\n /**\n * Registers a Web Worker to receive immediate entropy from the main thread.\n * This method is required until Web Workers can access the native crypto\n * API. This method should be called twice for each created worker, once in\n * the main thread, and once in the worker itself.\n *\n * @param worker the worker to register.\n */\n ctx.registerWorker = function(worker) {\n // worker receives random bytes\n if(worker === self) {\n ctx.seedFile = function(needed, callback) {\n function listener(e) {\n var data = e.data;\n if(data.forge && data.forge.prng) {\n self.removeEventListener('message', listener);\n callback(data.forge.prng.err, data.forge.prng.bytes);\n }\n }\n self.addEventListener('message', listener);\n self.postMessage({forge: {prng: {needed: needed}}});\n };\n } else {\n // main thread sends random bytes upon request\n var listener = function(e) {\n var data = e.data;\n if(data.forge && data.forge.prng) {\n ctx.seedFile(data.forge.prng.needed, function(err, bytes) {\n worker.postMessage({forge: {prng: {err: err, bytes: bytes}}});\n });\n }\n };\n // TODO: do we need to remove the event listener when the worker dies?\n worker.addEventListener('message', listener);\n }\n };\n\n return ctx;\n};\n","/**\n * RC2 implementation.\n *\n * @author Stefan Siegl\n *\n * Copyright (c) 2012 Stefan Siegl \n *\n * Information on the RC2 cipher is available from RFC #2268,\n * http://www.ietf.org/rfc/rfc2268.txt\n */\nvar forge = require('./forge');\nrequire('./util');\n\nvar piTable = [\n 0xd9, 0x78, 0xf9, 0xc4, 0x19, 0xdd, 0xb5, 0xed, 0x28, 0xe9, 0xfd, 0x79, 0x4a, 0xa0, 0xd8, 0x9d,\n 0xc6, 0x7e, 0x37, 0x83, 0x2b, 0x76, 0x53, 0x8e, 0x62, 0x4c, 0x64, 0x88, 0x44, 0x8b, 0xfb, 0xa2,\n 0x17, 0x9a, 0x59, 0xf5, 0x87, 0xb3, 0x4f, 0x13, 0x61, 0x45, 0x6d, 0x8d, 0x09, 0x81, 0x7d, 0x32,\n 0xbd, 0x8f, 0x40, 0xeb, 0x86, 0xb7, 0x7b, 0x0b, 0xf0, 0x95, 0x21, 0x22, 0x5c, 0x6b, 0x4e, 0x82,\n 0x54, 0xd6, 0x65, 0x93, 0xce, 0x60, 0xb2, 0x1c, 0x73, 0x56, 0xc0, 0x14, 0xa7, 0x8c, 0xf1, 0xdc,\n 0x12, 0x75, 0xca, 0x1f, 0x3b, 0xbe, 0xe4, 0xd1, 0x42, 0x3d, 0xd4, 0x30, 0xa3, 0x3c, 0xb6, 0x26,\n 0x6f, 0xbf, 0x0e, 0xda, 0x46, 0x69, 0x07, 0x57, 0x27, 0xf2, 0x1d, 0x9b, 0xbc, 0x94, 0x43, 0x03,\n 0xf8, 0x11, 0xc7, 0xf6, 0x90, 0xef, 0x3e, 0xe7, 0x06, 0xc3, 0xd5, 0x2f, 0xc8, 0x66, 0x1e, 0xd7,\n 0x08, 0xe8, 0xea, 0xde, 0x80, 0x52, 0xee, 0xf7, 0x84, 0xaa, 0x72, 0xac, 0x35, 0x4d, 0x6a, 0x2a,\n 0x96, 0x1a, 0xd2, 0x71, 0x5a, 0x15, 0x49, 0x74, 0x4b, 0x9f, 0xd0, 0x5e, 0x04, 0x18, 0xa4, 0xec,\n 0xc2, 0xe0, 0x41, 0x6e, 0x0f, 0x51, 0xcb, 0xcc, 0x24, 0x91, 0xaf, 0x50, 0xa1, 0xf4, 0x70, 0x39,\n 0x99, 0x7c, 0x3a, 0x85, 0x23, 0xb8, 0xb4, 0x7a, 0xfc, 0x02, 0x36, 0x5b, 0x25, 0x55, 0x97, 0x31,\n 0x2d, 0x5d, 0xfa, 0x98, 0xe3, 0x8a, 0x92, 0xae, 0x05, 0xdf, 0x29, 0x10, 0x67, 0x6c, 0xba, 0xc9,\n 0xd3, 0x00, 0xe6, 0xcf, 0xe1, 0x9e, 0xa8, 0x2c, 0x63, 0x16, 0x01, 0x3f, 0x58, 0xe2, 0x89, 0xa9,\n 0x0d, 0x38, 0x34, 0x1b, 0xab, 0x33, 0xff, 0xb0, 0xbb, 0x48, 0x0c, 0x5f, 0xb9, 0xb1, 0xcd, 0x2e,\n 0xc5, 0xf3, 0xdb, 0x47, 0xe5, 0xa5, 0x9c, 0x77, 0x0a, 0xa6, 0x20, 0x68, 0xfe, 0x7f, 0xc1, 0xad\n];\n\nvar s = [1, 2, 3, 5];\n\n/**\n * Rotate a word left by given number of bits.\n *\n * Bits that are shifted out on the left are put back in on the right\n * hand side.\n *\n * @param word The word to shift left.\n * @param bits The number of bits to shift by.\n * @return The rotated word.\n */\nvar rol = function(word, bits) {\n return ((word << bits) & 0xffff) | ((word & 0xffff) >> (16 - bits));\n};\n\n/**\n * Rotate a word right by given number of bits.\n *\n * Bits that are shifted out on the right are put back in on the left\n * hand side.\n *\n * @param word The word to shift right.\n * @param bits The number of bits to shift by.\n * @return The rotated word.\n */\nvar ror = function(word, bits) {\n return ((word & 0xffff) >> bits) | ((word << (16 - bits)) & 0xffff);\n};\n\n/* RC2 API */\nmodule.exports = forge.rc2 = forge.rc2 || {};\n\n/**\n * Perform RC2 key expansion as per RFC #2268, section 2.\n *\n * @param key variable-length user key (between 1 and 128 bytes)\n * @param effKeyBits number of effective key bits (default: 128)\n * @return the expanded RC2 key (ByteBuffer of 128 bytes)\n */\nforge.rc2.expandKey = function(key, effKeyBits) {\n if(typeof key === 'string') {\n key = forge.util.createBuffer(key);\n }\n effKeyBits = effKeyBits || 128;\n\n /* introduce variables that match the names used in RFC #2268 */\n var L = key;\n var T = key.length();\n var T1 = effKeyBits;\n var T8 = Math.ceil(T1 / 8);\n var TM = 0xff >> (T1 & 0x07);\n var i;\n\n for(i = T; i < 128; i++) {\n L.putByte(piTable[(L.at(i - 1) + L.at(i - T)) & 0xff]);\n }\n\n L.setAt(128 - T8, piTable[L.at(128 - T8) & TM]);\n\n for(i = 127 - T8; i >= 0; i--) {\n L.setAt(i, piTable[L.at(i + 1) ^ L.at(i + T8)]);\n }\n\n return L;\n};\n\n/**\n * Creates a RC2 cipher object.\n *\n * @param key the symmetric key to use (as base for key generation).\n * @param bits the number of effective key bits.\n * @param encrypt false for decryption, true for encryption.\n *\n * @return the cipher.\n */\nvar createCipher = function(key, bits, encrypt) {\n var _finish = false, _input = null, _output = null, _iv = null;\n var mixRound, mashRound;\n var i, j, K = [];\n\n /* Expand key and fill into K[] Array */\n key = forge.rc2.expandKey(key, bits);\n for(i = 0; i < 64; i++) {\n K.push(key.getInt16Le());\n }\n\n if(encrypt) {\n /**\n * Perform one mixing round \"in place\".\n *\n * @param R Array of four words to perform mixing on.\n */\n mixRound = function(R) {\n for(i = 0; i < 4; i++) {\n R[i] += K[j] + (R[(i + 3) % 4] & R[(i + 2) % 4]) +\n ((~R[(i + 3) % 4]) & R[(i + 1) % 4]);\n R[i] = rol(R[i], s[i]);\n j++;\n }\n };\n\n /**\n * Perform one mashing round \"in place\".\n *\n * @param R Array of four words to perform mashing on.\n */\n mashRound = function(R) {\n for(i = 0; i < 4; i++) {\n R[i] += K[R[(i + 3) % 4] & 63];\n }\n };\n } else {\n /**\n * Perform one r-mixing round \"in place\".\n *\n * @param R Array of four words to perform mixing on.\n */\n mixRound = function(R) {\n for(i = 3; i >= 0; i--) {\n R[i] = ror(R[i], s[i]);\n R[i] -= K[j] + (R[(i + 3) % 4] & R[(i + 2) % 4]) +\n ((~R[(i + 3) % 4]) & R[(i + 1) % 4]);\n j--;\n }\n };\n\n /**\n * Perform one r-mashing round \"in place\".\n *\n * @param R Array of four words to perform mashing on.\n */\n mashRound = function(R) {\n for(i = 3; i >= 0; i--) {\n R[i] -= K[R[(i + 3) % 4] & 63];\n }\n };\n }\n\n /**\n * Run the specified cipher execution plan.\n *\n * This function takes four words from the input buffer, applies the IV on\n * it (if requested) and runs the provided execution plan.\n *\n * The plan must be put together in form of a array of arrays. Where the\n * outer one is simply a list of steps to perform and the inner one needs\n * to have two elements: the first one telling how many rounds to perform,\n * the second one telling what to do (i.e. the function to call).\n *\n * @param {Array} plan The plan to execute.\n */\n var runPlan = function(plan) {\n var R = [];\n\n /* Get data from input buffer and fill the four words into R */\n for(i = 0; i < 4; i++) {\n var val = _input.getInt16Le();\n\n if(_iv !== null) {\n if(encrypt) {\n /* We're encrypting, apply the IV first. */\n val ^= _iv.getInt16Le();\n } else {\n /* We're decryption, keep cipher text for next block. */\n _iv.putInt16Le(val);\n }\n }\n\n R.push(val & 0xffff);\n }\n\n /* Reset global \"j\" variable as per spec. */\n j = encrypt ? 0 : 63;\n\n /* Run execution plan. */\n for(var ptr = 0; ptr < plan.length; ptr++) {\n for(var ctr = 0; ctr < plan[ptr][0]; ctr++) {\n plan[ptr][1](R);\n }\n }\n\n /* Write back result to output buffer. */\n for(i = 0; i < 4; i++) {\n if(_iv !== null) {\n if(encrypt) {\n /* We're encrypting in CBC-mode, feed back encrypted bytes into\n IV buffer to carry it forward to next block. */\n _iv.putInt16Le(R[i]);\n } else {\n R[i] ^= _iv.getInt16Le();\n }\n }\n\n _output.putInt16Le(R[i]);\n }\n };\n\n /* Create cipher object */\n var cipher = null;\n cipher = {\n /**\n * Starts or restarts the encryption or decryption process, whichever\n * was previously configured.\n *\n * To use the cipher in CBC mode, iv may be given either as a string\n * of bytes, or as a byte buffer. For ECB mode, give null as iv.\n *\n * @param iv the initialization vector to use, null for ECB mode.\n * @param output the output the buffer to write to, null to create one.\n */\n start: function(iv, output) {\n if(iv) {\n /* CBC mode */\n if(typeof iv === 'string') {\n iv = forge.util.createBuffer(iv);\n }\n }\n\n _finish = false;\n _input = forge.util.createBuffer();\n _output = output || new forge.util.createBuffer();\n _iv = iv;\n\n cipher.output = _output;\n },\n\n /**\n * Updates the next block.\n *\n * @param input the buffer to read from.\n */\n update: function(input) {\n if(!_finish) {\n // not finishing, so fill the input buffer with more input\n _input.putBuffer(input);\n }\n\n while(_input.length() >= 8) {\n runPlan([\n [ 5, mixRound ],\n [ 1, mashRound ],\n [ 6, mixRound ],\n [ 1, mashRound ],\n [ 5, mixRound ]\n ]);\n }\n },\n\n /**\n * Finishes encrypting or decrypting.\n *\n * @param pad a padding function to use, null for PKCS#7 padding,\n * signature(blockSize, buffer, decrypt).\n *\n * @return true if successful, false on error.\n */\n finish: function(pad) {\n var rval = true;\n\n if(encrypt) {\n if(pad) {\n rval = pad(8, _input, !encrypt);\n } else {\n // add PKCS#7 padding to block (each pad byte is the\n // value of the number of pad bytes)\n var padding = (_input.length() === 8) ? 8 : (8 - _input.length());\n _input.fillWithByte(padding, padding);\n }\n }\n\n if(rval) {\n // do final update\n _finish = true;\n cipher.update();\n }\n\n if(!encrypt) {\n // check for error: input data not a multiple of block size\n rval = (_input.length() === 0);\n if(rval) {\n if(pad) {\n rval = pad(8, _output, !encrypt);\n } else {\n // ensure padding byte count is valid\n var len = _output.length();\n var count = _output.at(len - 1);\n\n if(count > len) {\n rval = false;\n } else {\n // trim off padding bytes\n _output.truncate(count);\n }\n }\n }\n }\n\n return rval;\n }\n };\n\n return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to encrypt data in ECB or CBC mode using the\n * given symmetric key. The output will be stored in the 'output' member\n * of the returned cipher.\n *\n * The key and iv may be given as a string of bytes or a byte buffer.\n * The cipher is initialized to use 128 effective key bits.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n *\n * @return the cipher.\n */\nforge.rc2.startEncrypting = function(key, iv, output) {\n var cipher = forge.rc2.createEncryptionCipher(key, 128);\n cipher.start(iv, output);\n return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to encrypt data in ECB or CBC mode using the\n * given symmetric key.\n *\n * The key may be given as a string of bytes or a byte buffer.\n *\n * To start encrypting call start() on the cipher with an iv and optional\n * output buffer.\n *\n * @param key the symmetric key to use.\n *\n * @return the cipher.\n */\nforge.rc2.createEncryptionCipher = function(key, bits) {\n return createCipher(key, bits, true);\n};\n\n/**\n * Creates an RC2 cipher object to decrypt data in ECB or CBC mode using the\n * given symmetric key. The output will be stored in the 'output' member\n * of the returned cipher.\n *\n * The key and iv may be given as a string of bytes or a byte buffer.\n * The cipher is initialized to use 128 effective key bits.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n *\n * @return the cipher.\n */\nforge.rc2.startDecrypting = function(key, iv, output) {\n var cipher = forge.rc2.createDecryptionCipher(key, 128);\n cipher.start(iv, output);\n return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to decrypt data in ECB or CBC mode using the\n * given symmetric key.\n *\n * The key may be given as a string of bytes or a byte buffer.\n *\n * To start decrypting call start() on the cipher with an iv and optional\n * output buffer.\n *\n * @param key the symmetric key to use.\n *\n * @return the cipher.\n */\nforge.rc2.createDecryptionCipher = function(key, bits) {\n return createCipher(key, bits, false);\n};\n","/**\n * Javascript implementation of basic RSA algorithms.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n *\n * The only algorithm currently supported for PKI is RSA.\n *\n * An RSA key is often stored in ASN.1 DER format. The SubjectPublicKeyInfo\n * ASN.1 structure is composed of an algorithm of type AlgorithmIdentifier\n * and a subjectPublicKey of type bit string.\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of RSA, there aren't any.\n *\n * SubjectPublicKeyInfo ::= SEQUENCE {\n * algorithm AlgorithmIdentifier,\n * subjectPublicKey BIT STRING\n * }\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * For an RSA public key, the subjectPublicKey is:\n *\n * RSAPublicKey ::= SEQUENCE {\n * modulus INTEGER, -- n\n * publicExponent INTEGER -- e\n * }\n *\n * PrivateKeyInfo ::= SEQUENCE {\n * version Version,\n * privateKeyAlgorithm PrivateKeyAlgorithmIdentifier,\n * privateKey PrivateKey,\n * attributes [0] IMPLICIT Attributes OPTIONAL\n * }\n *\n * Version ::= INTEGER\n * PrivateKeyAlgorithmIdentifier ::= AlgorithmIdentifier\n * PrivateKey ::= OCTET STRING\n * Attributes ::= SET OF Attribute\n *\n * An RSA private key as the following structure:\n *\n * RSAPrivateKey ::= SEQUENCE {\n * version Version,\n * modulus INTEGER, -- n\n * publicExponent INTEGER, -- e\n * privateExponent INTEGER, -- d\n * prime1 INTEGER, -- p\n * prime2 INTEGER, -- q\n * exponent1 INTEGER, -- d mod (p-1)\n * exponent2 INTEGER, -- d mod (q-1)\n * coefficient INTEGER -- (inverse of q) mod p\n * }\n *\n * Version ::= INTEGER\n *\n * The OID for the RSA key algorithm is: 1.2.840.113549.1.1.1\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./jsbn');\nrequire('./oids');\nrequire('./pkcs1');\nrequire('./prime');\nrequire('./random');\nrequire('./util');\n\nif(typeof BigInteger === 'undefined') {\n var BigInteger = forge.jsbn.BigInteger;\n}\n\nvar _crypto = forge.util.isNodejs ? require('crypto') : null;\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for util API\nvar util = forge.util;\n\n/*\n * RSA encryption and decryption, see RFC 2313.\n */\nforge.pki = forge.pki || {};\nmodule.exports = forge.pki.rsa = forge.rsa = forge.rsa || {};\nvar pki = forge.pki;\n\n// for finding primes, which are 30k+i for i = 1, 7, 11, 13, 17, 19, 23, 29\nvar GCD_30_DELTA = [6, 4, 2, 4, 2, 4, 6, 2];\n\n// validator for a PrivateKeyInfo structure\nvar privateKeyValidator = {\n // PrivateKeyInfo\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // Version (INTEGER)\n name: 'PrivateKeyInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyVersion'\n }, {\n // privateKeyAlgorithm\n name: 'PrivateKeyInfo.privateKeyAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'privateKeyOid'\n }]\n }, {\n // PrivateKey\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'privateKey'\n }]\n};\n\n// validator for an RSA private key\nvar rsaPrivateKeyValidator = {\n // RSAPrivateKey\n name: 'RSAPrivateKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // Version (INTEGER)\n name: 'RSAPrivateKey.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyVersion'\n }, {\n // modulus (n)\n name: 'RSAPrivateKey.modulus',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyModulus'\n }, {\n // publicExponent (e)\n name: 'RSAPrivateKey.publicExponent',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPublicExponent'\n }, {\n // privateExponent (d)\n name: 'RSAPrivateKey.privateExponent',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPrivateExponent'\n }, {\n // prime1 (p)\n name: 'RSAPrivateKey.prime1',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPrime1'\n }, {\n // prime2 (q)\n name: 'RSAPrivateKey.prime2',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPrime2'\n }, {\n // exponent1 (d mod (p-1))\n name: 'RSAPrivateKey.exponent1',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyExponent1'\n }, {\n // exponent2 (d mod (q-1))\n name: 'RSAPrivateKey.exponent2',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyExponent2'\n }, {\n // coefficient ((inverse of q) mod p)\n name: 'RSAPrivateKey.coefficient',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyCoefficient'\n }]\n};\n\n// validator for an RSA public key\nvar rsaPublicKeyValidator = {\n // RSAPublicKey\n name: 'RSAPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // modulus (n)\n name: 'RSAPublicKey.modulus',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'publicKeyModulus'\n }, {\n // publicExponent (e)\n name: 'RSAPublicKey.exponent',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'publicKeyExponent'\n }]\n};\n\n// validator for an SubjectPublicKeyInfo structure\n// Note: Currently only works with an RSA public key\nvar publicKeyValidator = forge.pki.rsa.publicKeyValidator = {\n name: 'SubjectPublicKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'subjectPublicKeyInfo',\n value: [{\n name: 'SubjectPublicKeyInfo.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'publicKeyOid'\n }]\n }, {\n // subjectPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n value: [{\n // RSAPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n captureAsn1: 'rsaPublicKey'\n }]\n }]\n};\n\n/**\n * Wrap digest in DigestInfo object.\n *\n * This function implements EMSA-PKCS1-v1_5-ENCODE as per RFC 3447.\n *\n * DigestInfo ::= SEQUENCE {\n * digestAlgorithm DigestAlgorithmIdentifier,\n * digest Digest\n * }\n *\n * DigestAlgorithmIdentifier ::= AlgorithmIdentifier\n * Digest ::= OCTET STRING\n *\n * @param md the message digest object with the hash to sign.\n *\n * @return the encoded message (ready for RSA encrytion)\n */\nvar emsaPkcs1v15encode = function(md) {\n // get the oid for the algorithm\n var oid;\n if(md.algorithm in pki.oids) {\n oid = pki.oids[md.algorithm];\n } else {\n var error = new Error('Unknown message digest algorithm.');\n error.algorithm = md.algorithm;\n throw error;\n }\n var oidBytes = asn1.oidToDer(oid).getBytes();\n\n // create the digest info\n var digestInfo = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var digestAlgorithm = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n digestAlgorithm.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OID, false, oidBytes));\n digestAlgorithm.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.NULL, false, ''));\n var digest = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING,\n false, md.digest().getBytes());\n digestInfo.value.push(digestAlgorithm);\n digestInfo.value.push(digest);\n\n // encode digest info\n return asn1.toDer(digestInfo).getBytes();\n};\n\n/**\n * Performs x^c mod n (RSA encryption or decryption operation).\n *\n * @param x the number to raise and mod.\n * @param key the key to use.\n * @param pub true if the key is public, false if private.\n *\n * @return the result of x^c mod n.\n */\nvar _modPow = function(x, key, pub) {\n if(pub) {\n return x.modPow(key.e, key.n);\n }\n\n if(!key.p || !key.q) {\n // allow calculation without CRT params (slow)\n return x.modPow(key.d, key.n);\n }\n\n // pre-compute dP, dQ, and qInv if necessary\n if(!key.dP) {\n key.dP = key.d.mod(key.p.subtract(BigInteger.ONE));\n }\n if(!key.dQ) {\n key.dQ = key.d.mod(key.q.subtract(BigInteger.ONE));\n }\n if(!key.qInv) {\n key.qInv = key.q.modInverse(key.p);\n }\n\n /* Chinese remainder theorem (CRT) states:\n\n Suppose n1, n2, ..., nk are positive integers which are pairwise\n coprime (n1 and n2 have no common factors other than 1). For any\n integers x1, x2, ..., xk there exists an integer x solving the\n system of simultaneous congruences (where ~= means modularly\n congruent so a ~= b mod n means a mod n = b mod n):\n\n x ~= x1 mod n1\n x ~= x2 mod n2\n ...\n x ~= xk mod nk\n\n This system of congruences has a single simultaneous solution x\n between 0 and n - 1. Furthermore, each xk solution and x itself\n is congruent modulo the product n = n1*n2*...*nk.\n So x1 mod n = x2 mod n = xk mod n = x mod n.\n\n The single simultaneous solution x can be solved with the following\n equation:\n\n x = sum(xi*ri*si) mod n where ri = n/ni and si = ri^-1 mod ni.\n\n Where x is less than n, xi = x mod ni.\n\n For RSA we are only concerned with k = 2. The modulus n = pq, where\n p and q are coprime. The RSA decryption algorithm is:\n\n y = x^d mod n\n\n Given the above:\n\n x1 = x^d mod p\n r1 = n/p = q\n s1 = q^-1 mod p\n x2 = x^d mod q\n r2 = n/q = p\n s2 = p^-1 mod q\n\n So y = (x1r1s1 + x2r2s2) mod n\n = ((x^d mod p)q(q^-1 mod p) + (x^d mod q)p(p^-1 mod q)) mod n\n\n According to Fermat's Little Theorem, if the modulus P is prime,\n for any integer A not evenly divisible by P, A^(P-1) ~= 1 mod P.\n Since A is not divisible by P it follows that if:\n N ~= M mod (P - 1), then A^N mod P = A^M mod P. Therefore:\n\n A^N mod P = A^(M mod (P - 1)) mod P. (The latter takes less effort\n to calculate). In order to calculate x^d mod p more quickly the\n exponent d mod (p - 1) is stored in the RSA private key (the same\n is done for x^d mod q). These values are referred to as dP and dQ\n respectively. Therefore we now have:\n\n y = ((x^dP mod p)q(q^-1 mod p) + (x^dQ mod q)p(p^-1 mod q)) mod n\n\n Since we'll be reducing x^dP by modulo p (same for q) we can also\n reduce x by p (and q respectively) before hand. Therefore, let\n\n xp = ((x mod p)^dP mod p), and\n xq = ((x mod q)^dQ mod q), yielding:\n\n y = (xp*q*(q^-1 mod p) + xq*p*(p^-1 mod q)) mod n\n\n This can be further reduced to a simple algorithm that only\n requires 1 inverse (the q inverse is used) to be used and stored.\n The algorithm is called Garner's algorithm. If qInv is the\n inverse of q, we simply calculate:\n\n y = (qInv*(xp - xq) mod p) * q + xq\n\n However, there are two further complications. First, we need to\n ensure that xp > xq to prevent signed BigIntegers from being used\n so we add p until this is true (since we will be mod'ing with\n p anyway). Then, there is a known timing attack on algorithms\n using the CRT. To mitigate this risk, \"cryptographic blinding\"\n should be used. This requires simply generating a random number r\n between 0 and n-1 and its inverse and multiplying x by r^e before\n calculating y and then multiplying y by r^-1 afterwards. Note that\n r must be coprime with n (gcd(r, n) === 1) in order to have an\n inverse.\n */\n\n // cryptographic blinding\n var r;\n do {\n r = new BigInteger(\n forge.util.bytesToHex(forge.random.getBytes(key.n.bitLength() / 8)),\n 16);\n } while(r.compareTo(key.n) >= 0 || !r.gcd(key.n).equals(BigInteger.ONE));\n x = x.multiply(r.modPow(key.e, key.n)).mod(key.n);\n\n // calculate xp and xq\n var xp = x.mod(key.p).modPow(key.dP, key.p);\n var xq = x.mod(key.q).modPow(key.dQ, key.q);\n\n // xp must be larger than xq to avoid signed bit usage\n while(xp.compareTo(xq) < 0) {\n xp = xp.add(key.p);\n }\n\n // do last step\n var y = xp.subtract(xq)\n .multiply(key.qInv).mod(key.p)\n .multiply(key.q).add(xq);\n\n // remove effect of random for cryptographic blinding\n y = y.multiply(r.modInverse(key.n)).mod(key.n);\n\n return y;\n};\n\n/**\n * NOTE: THIS METHOD IS DEPRECATED, use 'sign' on a private key object or\n * 'encrypt' on a public key object instead.\n *\n * Performs RSA encryption.\n *\n * The parameter bt controls whether to put padding bytes before the\n * message passed in. Set bt to either true or false to disable padding\n * completely (in order to handle e.g. EMSA-PSS encoding seperately before),\n * signaling whether the encryption operation is a public key operation\n * (i.e. encrypting data) or not, i.e. private key operation (data signing).\n *\n * For PKCS#1 v1.5 padding pass in the block type to use, i.e. either 0x01\n * (for signing) or 0x02 (for encryption). The key operation mode (private\n * or public) is derived from this flag in that case).\n *\n * @param m the message to encrypt as a byte string.\n * @param key the RSA key to use.\n * @param bt for PKCS#1 v1.5 padding, the block type to use\n * (0x01 for private key, 0x02 for public),\n * to disable padding: true = public key, false = private key.\n *\n * @return the encrypted bytes as a string.\n */\npki.rsa.encrypt = function(m, key, bt) {\n var pub = bt;\n var eb;\n\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n if(bt !== false && bt !== true) {\n // legacy, default to PKCS#1 v1.5 padding\n pub = (bt === 0x02);\n eb = _encodePkcs1_v1_5(m, key, bt);\n } else {\n eb = forge.util.createBuffer();\n eb.putBytes(m);\n }\n\n // load encryption block as big integer 'x'\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var x = new BigInteger(eb.toHex(), 16);\n\n // do RSA encryption\n var y = _modPow(x, key, pub);\n\n // convert y into the encrypted data byte string, if y is shorter in\n // bytes than k, then prepend zero bytes to fill up ed\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var yhex = y.toString(16);\n var ed = forge.util.createBuffer();\n var zeros = k - Math.ceil(yhex.length / 2);\n while(zeros > 0) {\n ed.putByte(0x00);\n --zeros;\n }\n ed.putBytes(forge.util.hexToBytes(yhex));\n return ed.getBytes();\n};\n\n/**\n * NOTE: THIS METHOD IS DEPRECATED, use 'decrypt' on a private key object or\n * 'verify' on a public key object instead.\n *\n * Performs RSA decryption.\n *\n * The parameter ml controls whether to apply PKCS#1 v1.5 padding\n * or not. Set ml = false to disable padding removal completely\n * (in order to handle e.g. EMSA-PSS later on) and simply pass back\n * the RSA encryption block.\n *\n * @param ed the encrypted data to decrypt in as a byte string.\n * @param key the RSA key to use.\n * @param pub true for a public key operation, false for private.\n * @param ml the message length, if known, false to disable padding.\n *\n * @return the decrypted message as a byte string.\n */\npki.rsa.decrypt = function(ed, key, pub, ml) {\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n // error if the length of the encrypted data ED is not k\n if(ed.length !== k) {\n var error = new Error('Encrypted message length is invalid.');\n error.length = ed.length;\n error.expected = k;\n throw error;\n }\n\n // convert encrypted data into a big integer\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var y = new BigInteger(forge.util.createBuffer(ed).toHex(), 16);\n\n // y must be less than the modulus or it wasn't the result of\n // a previous mod operation (encryption) using that modulus\n if(y.compareTo(key.n) >= 0) {\n throw new Error('Encrypted message is invalid.');\n }\n\n // do RSA decryption\n var x = _modPow(y, key, pub);\n\n // create the encryption block, if x is shorter in bytes than k, then\n // prepend zero bytes to fill up eb\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var xhex = x.toString(16);\n var eb = forge.util.createBuffer();\n var zeros = k - Math.ceil(xhex.length / 2);\n while(zeros > 0) {\n eb.putByte(0x00);\n --zeros;\n }\n eb.putBytes(forge.util.hexToBytes(xhex));\n\n if(ml !== false) {\n // legacy, default to PKCS#1 v1.5 padding\n return _decodePkcs1_v1_5(eb.getBytes(), key, pub);\n }\n\n // return message\n return eb.getBytes();\n};\n\n/**\n * Creates an RSA key-pair generation state object. It is used to allow\n * key-generation to be performed in steps. It also allows for a UI to\n * display progress updates.\n *\n * @param bits the size for the private key in bits, defaults to 2048.\n * @param e the public exponent to use, defaults to 65537 (0x10001).\n * @param [options] the options to use.\n * prng a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\".\n * algorithm the algorithm to use (default: 'PRIMEINC').\n *\n * @return the state object to use to generate the key-pair.\n */\npki.rsa.createKeyPairGenerationState = function(bits, e, options) {\n // TODO: migrate step-based prime generation code to forge.prime\n\n // set default bits\n if(typeof(bits) === 'string') {\n bits = parseInt(bits, 10);\n }\n bits = bits || 2048;\n\n // create prng with api that matches BigInteger secure random\n options = options || {};\n var prng = options.prng || forge.random;\n var rng = {\n // x is an array to fill with bytes\n nextBytes: function(x) {\n var b = prng.getBytesSync(x.length);\n for(var i = 0; i < x.length; ++i) {\n x[i] = b.charCodeAt(i);\n }\n }\n };\n\n var algorithm = options.algorithm || 'PRIMEINC';\n\n // create PRIMEINC algorithm state\n var rval;\n if(algorithm === 'PRIMEINC') {\n rval = {\n algorithm: algorithm,\n state: 0,\n bits: bits,\n rng: rng,\n eInt: e || 65537,\n e: new BigInteger(null),\n p: null,\n q: null,\n qBits: bits >> 1,\n pBits: bits - (bits >> 1),\n pqState: 0,\n num: null,\n keys: null\n };\n rval.e.fromInt(rval.eInt);\n } else {\n throw new Error('Invalid key generation algorithm: ' + algorithm);\n }\n\n return rval;\n};\n\n/**\n * Attempts to runs the key-generation algorithm for at most n seconds\n * (approximately) using the given state. When key-generation has completed,\n * the keys will be stored in state.keys.\n *\n * To use this function to update a UI while generating a key or to prevent\n * causing browser lockups/warnings, set \"n\" to a value other than 0. A\n * simple pattern for generating a key and showing a progress indicator is:\n *\n * var state = pki.rsa.createKeyPairGenerationState(2048);\n * var step = function() {\n * // step key-generation, run algorithm for 100 ms, repeat\n * if(!forge.pki.rsa.stepKeyPairGenerationState(state, 100)) {\n * setTimeout(step, 1);\n * } else {\n * // key-generation complete\n * // TODO: turn off progress indicator here\n * // TODO: use the generated key-pair in \"state.keys\"\n * }\n * };\n * // TODO: turn on progress indicator here\n * setTimeout(step, 0);\n *\n * @param state the state to use.\n * @param n the maximum number of milliseconds to run the algorithm for, 0\n * to run the algorithm to completion.\n *\n * @return true if the key-generation completed, false if not.\n */\npki.rsa.stepKeyPairGenerationState = function(state, n) {\n // set default algorithm if not set\n if(!('algorithm' in state)) {\n state.algorithm = 'PRIMEINC';\n }\n\n // TODO: migrate step-based prime generation code to forge.prime\n // TODO: abstract as PRIMEINC algorithm\n\n // do key generation (based on Tom Wu's rsa.js, see jsbn.js license)\n // with some minor optimizations and designed to run in steps\n\n // local state vars\n var THIRTY = new BigInteger(null);\n THIRTY.fromInt(30);\n var deltaIdx = 0;\n var op_or = function(x, y) {return x | y;};\n\n // keep stepping until time limit is reached or done\n var t1 = +new Date();\n var t2;\n var total = 0;\n while(state.keys === null && (n <= 0 || total < n)) {\n // generate p or q\n if(state.state === 0) {\n /* Note: All primes are of the form:\n\n 30k+i, for i < 30 and gcd(30, i)=1, where there are 8 values for i\n\n When we generate a random number, we always align it at 30k + 1. Each\n time the number is determined not to be prime we add to get to the\n next 'i', eg: if the number was at 30k + 1 we add 6. */\n var bits = (state.p === null) ? state.pBits : state.qBits;\n var bits1 = bits - 1;\n\n // get a random number\n if(state.pqState === 0) {\n state.num = new BigInteger(bits, state.rng);\n // force MSB set\n if(!state.num.testBit(bits1)) {\n state.num.bitwiseTo(\n BigInteger.ONE.shiftLeft(bits1), op_or, state.num);\n }\n // align number on 30k+1 boundary\n state.num.dAddOffset(31 - state.num.mod(THIRTY).byteValue(), 0);\n deltaIdx = 0;\n\n ++state.pqState;\n } else if(state.pqState === 1) {\n // try to make the number a prime\n if(state.num.bitLength() > bits) {\n // overflow, try again\n state.pqState = 0;\n // do primality test\n } else if(state.num.isProbablePrime(\n _getMillerRabinTests(state.num.bitLength()))) {\n ++state.pqState;\n } else {\n // get next potential prime\n state.num.dAddOffset(GCD_30_DELTA[deltaIdx++ % 8], 0);\n }\n } else if(state.pqState === 2) {\n // ensure number is coprime with e\n state.pqState =\n (state.num.subtract(BigInteger.ONE).gcd(state.e)\n .compareTo(BigInteger.ONE) === 0) ? 3 : 0;\n } else if(state.pqState === 3) {\n // store p or q\n state.pqState = 0;\n if(state.p === null) {\n state.p = state.num;\n } else {\n state.q = state.num;\n }\n\n // advance state if both p and q are ready\n if(state.p !== null && state.q !== null) {\n ++state.state;\n }\n state.num = null;\n }\n } else if(state.state === 1) {\n // ensure p is larger than q (swap them if not)\n if(state.p.compareTo(state.q) < 0) {\n state.num = state.p;\n state.p = state.q;\n state.q = state.num;\n }\n ++state.state;\n } else if(state.state === 2) {\n // compute phi: (p - 1)(q - 1) (Euler's totient function)\n state.p1 = state.p.subtract(BigInteger.ONE);\n state.q1 = state.q.subtract(BigInteger.ONE);\n state.phi = state.p1.multiply(state.q1);\n ++state.state;\n } else if(state.state === 3) {\n // ensure e and phi are coprime\n if(state.phi.gcd(state.e).compareTo(BigInteger.ONE) === 0) {\n // phi and e are coprime, advance\n ++state.state;\n } else {\n // phi and e aren't coprime, so generate a new p and q\n state.p = null;\n state.q = null;\n state.state = 0;\n }\n } else if(state.state === 4) {\n // create n, ensure n is has the right number of bits\n state.n = state.p.multiply(state.q);\n\n // ensure n is right number of bits\n if(state.n.bitLength() === state.bits) {\n // success, advance\n ++state.state;\n } else {\n // failed, get new q\n state.q = null;\n state.state = 0;\n }\n } else if(state.state === 5) {\n // set keys\n var d = state.e.modInverse(state.phi);\n state.keys = {\n privateKey: pki.rsa.setPrivateKey(\n state.n, state.e, d, state.p, state.q,\n d.mod(state.p1), d.mod(state.q1),\n state.q.modInverse(state.p)),\n publicKey: pki.rsa.setPublicKey(state.n, state.e)\n };\n }\n\n // update timing\n t2 = +new Date();\n total += t2 - t1;\n t1 = t2;\n }\n\n return state.keys !== null;\n};\n\n/**\n * Generates an RSA public-private key pair in a single call.\n *\n * To generate a key-pair in steps (to allow for progress updates and to\n * prevent blocking or warnings in slow browsers) then use the key-pair\n * generation state functions.\n *\n * To generate a key-pair asynchronously (either through web-workers, if\n * available, or by breaking up the work on the main thread), pass a\n * callback function.\n *\n * @param [bits] the size for the private key in bits, defaults to 2048.\n * @param [e] the public exponent to use, defaults to 65537.\n * @param [options] options for key-pair generation, if given then 'bits'\n * and 'e' must *not* be given:\n * bits the size for the private key in bits, (default: 2048).\n * e the public exponent to use, (default: 65537 (0x10001)).\n * workerScript the worker script URL.\n * workers the number of web workers (if supported) to use,\n * (default: 2).\n * workLoad the size of the work load, ie: number of possible prime\n * numbers for each web worker to check per work assignment,\n * (default: 100).\n * prng a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\". Disables use of native APIs.\n * algorithm the algorithm to use (default: 'PRIMEINC').\n * @param [callback(err, keypair)] called once the operation completes.\n *\n * @return an object with privateKey and publicKey properties.\n */\npki.rsa.generateKeyPair = function(bits, e, options, callback) {\n // (bits), (options), (callback)\n if(arguments.length === 1) {\n if(typeof bits === 'object') {\n options = bits;\n bits = undefined;\n } else if(typeof bits === 'function') {\n callback = bits;\n bits = undefined;\n }\n } else if(arguments.length === 2) {\n // (bits, e), (bits, options), (bits, callback), (options, callback)\n if(typeof bits === 'number') {\n if(typeof e === 'function') {\n callback = e;\n e = undefined;\n } else if(typeof e !== 'number') {\n options = e;\n e = undefined;\n }\n } else {\n options = bits;\n callback = e;\n bits = undefined;\n e = undefined;\n }\n } else if(arguments.length === 3) {\n // (bits, e, options), (bits, e, callback), (bits, options, callback)\n if(typeof e === 'number') {\n if(typeof options === 'function') {\n callback = options;\n options = undefined;\n }\n } else {\n callback = options;\n options = e;\n e = undefined;\n }\n }\n options = options || {};\n if(bits === undefined) {\n bits = options.bits || 2048;\n }\n if(e === undefined) {\n e = options.e || 0x10001;\n }\n\n // use native code if permitted, available, and parameters are acceptable\n if(!forge.options.usePureJavaScript && !options.prng &&\n bits >= 256 && bits <= 16384 && (e === 0x10001 || e === 3)) {\n if(callback) {\n // try native async\n if(_detectNodeCrypto('generateKeyPair')) {\n return _crypto.generateKeyPair('rsa', {\n modulusLength: bits,\n publicExponent: e,\n publicKeyEncoding: {\n type: 'spki',\n format: 'pem'\n },\n privateKeyEncoding: {\n type: 'pkcs8',\n format: 'pem'\n }\n }, function(err, pub, priv) {\n if(err) {\n return callback(err);\n }\n callback(null, {\n privateKey: pki.privateKeyFromPem(priv),\n publicKey: pki.publicKeyFromPem(pub)\n });\n });\n }\n if(_detectSubtleCrypto('generateKey') &&\n _detectSubtleCrypto('exportKey')) {\n // use standard native generateKey\n return util.globalScope.crypto.subtle.generateKey({\n name: 'RSASSA-PKCS1-v1_5',\n modulusLength: bits,\n publicExponent: _intToUint8Array(e),\n hash: {name: 'SHA-256'}\n }, true /* key can be exported*/, ['sign', 'verify'])\n .then(function(pair) {\n return util.globalScope.crypto.subtle.exportKey(\n 'pkcs8', pair.privateKey);\n // avoiding catch(function(err) {...}) to support IE <= 8\n }).then(undefined, function(err) {\n callback(err);\n }).then(function(pkcs8) {\n if(pkcs8) {\n var privateKey = pki.privateKeyFromAsn1(\n asn1.fromDer(forge.util.createBuffer(pkcs8)));\n callback(null, {\n privateKey: privateKey,\n publicKey: pki.setRsaPublicKey(privateKey.n, privateKey.e)\n });\n }\n });\n }\n if(_detectSubtleMsCrypto('generateKey') &&\n _detectSubtleMsCrypto('exportKey')) {\n var genOp = util.globalScope.msCrypto.subtle.generateKey({\n name: 'RSASSA-PKCS1-v1_5',\n modulusLength: bits,\n publicExponent: _intToUint8Array(e),\n hash: {name: 'SHA-256'}\n }, true /* key can be exported*/, ['sign', 'verify']);\n genOp.oncomplete = function(e) {\n var pair = e.target.result;\n var exportOp = util.globalScope.msCrypto.subtle.exportKey(\n 'pkcs8', pair.privateKey);\n exportOp.oncomplete = function(e) {\n var pkcs8 = e.target.result;\n var privateKey = pki.privateKeyFromAsn1(\n asn1.fromDer(forge.util.createBuffer(pkcs8)));\n callback(null, {\n privateKey: privateKey,\n publicKey: pki.setRsaPublicKey(privateKey.n, privateKey.e)\n });\n };\n exportOp.onerror = function(err) {\n callback(err);\n };\n };\n genOp.onerror = function(err) {\n callback(err);\n };\n return;\n }\n } else {\n // try native sync\n if(_detectNodeCrypto('generateKeyPairSync')) {\n var keypair = _crypto.generateKeyPairSync('rsa', {\n modulusLength: bits,\n publicExponent: e,\n publicKeyEncoding: {\n type: 'spki',\n format: 'pem'\n },\n privateKeyEncoding: {\n type: 'pkcs8',\n format: 'pem'\n }\n });\n return {\n privateKey: pki.privateKeyFromPem(keypair.privateKey),\n publicKey: pki.publicKeyFromPem(keypair.publicKey)\n };\n }\n }\n }\n\n // use JavaScript implementation\n var state = pki.rsa.createKeyPairGenerationState(bits, e, options);\n if(!callback) {\n pki.rsa.stepKeyPairGenerationState(state, 0);\n return state.keys;\n }\n _generateKeyPair(state, options, callback);\n};\n\n/**\n * Sets an RSA public key from BigIntegers modulus and exponent.\n *\n * @param n the modulus.\n * @param e the exponent.\n *\n * @return the public key.\n */\npki.setRsaPublicKey = pki.rsa.setPublicKey = function(n, e) {\n var key = {\n n: n,\n e: e\n };\n\n /**\n * Encrypts the given data with this public key. Newer applications\n * should use the 'RSA-OAEP' decryption scheme, 'RSAES-PKCS1-V1_5' is for\n * legacy applications.\n *\n * @param data the byte string to encrypt.\n * @param scheme the encryption scheme to use:\n * 'RSAES-PKCS1-V1_5' (default),\n * 'RSA-OAEP',\n * 'RAW', 'NONE', or null to perform raw RSA encryption,\n * an object with an 'encode' property set to a function\n * with the signature 'function(data, key)' that returns\n * a binary-encoded string representing the encoded data.\n * @param schemeOptions any scheme-specific options.\n *\n * @return the encrypted byte string.\n */\n key.encrypt = function(data, scheme, schemeOptions) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSAES-PKCS1-V1_5';\n }\n\n if(scheme === 'RSAES-PKCS1-V1_5') {\n scheme = {\n encode: function(m, key, pub) {\n return _encodePkcs1_v1_5(m, key, 0x02).getBytes();\n }\n };\n } else if(scheme === 'RSA-OAEP' || scheme === 'RSAES-OAEP') {\n scheme = {\n encode: function(m, key) {\n return forge.pkcs1.encode_rsa_oaep(key, m, schemeOptions);\n }\n };\n } else if(['RAW', 'NONE', 'NULL', null].indexOf(scheme) !== -1) {\n scheme = {encode: function(e) {return e;}};\n } else if(typeof scheme === 'string') {\n throw new Error('Unsupported encryption scheme: \"' + scheme + '\".');\n }\n\n // do scheme-based encoding then rsa encryption\n var e = scheme.encode(data, key, true);\n return pki.rsa.encrypt(e, key, true);\n };\n\n /**\n * Verifies the given signature against the given digest.\n *\n * PKCS#1 supports multiple (currently two) signature schemes:\n * RSASSA-PKCS1-V1_5 and RSASSA-PSS.\n *\n * By default this implementation uses the \"old scheme\", i.e.\n * RSASSA-PKCS1-V1_5, in which case once RSA-decrypted, the\n * signature is an OCTET STRING that holds a DigestInfo.\n *\n * DigestInfo ::= SEQUENCE {\n * digestAlgorithm DigestAlgorithmIdentifier,\n * digest Digest\n * }\n * DigestAlgorithmIdentifier ::= AlgorithmIdentifier\n * Digest ::= OCTET STRING\n *\n * To perform PSS signature verification, provide an instance\n * of Forge PSS object as the scheme parameter.\n *\n * @param digest the message digest hash to compare against the signature,\n * as a binary-encoded string.\n * @param signature the signature to verify, as a binary-encoded string.\n * @param scheme signature verification scheme to use:\n * 'RSASSA-PKCS1-V1_5' or undefined for RSASSA PKCS#1 v1.5,\n * a Forge PSS object for RSASSA-PSS,\n * 'NONE' or null for none, DigestInfo will not be expected, but\n * PKCS#1 v1.5 padding will still be used.\n *\n * @return true if the signature was verified, false if not.\n */\n key.verify = function(digest, signature, scheme) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSASSA-PKCS1-V1_5';\n }\n\n if(scheme === 'RSASSA-PKCS1-V1_5') {\n scheme = {\n verify: function(digest, d) {\n // remove padding\n d = _decodePkcs1_v1_5(d, key, true);\n // d is ASN.1 BER-encoded DigestInfo\n var obj = asn1.fromDer(d);\n // compare the given digest to the decrypted one\n return digest === obj.value[1].value;\n }\n };\n } else if(scheme === 'NONE' || scheme === 'NULL' || scheme === null) {\n scheme = {\n verify: function(digest, d) {\n // remove padding\n d = _decodePkcs1_v1_5(d, key, true);\n return digest === d;\n }\n };\n }\n\n // do rsa decryption w/o any decoding, then verify -- which does decoding\n var d = pki.rsa.decrypt(signature, key, true, false);\n return scheme.verify(digest, d, key.n.bitLength());\n };\n\n return key;\n};\n\n/**\n * Sets an RSA private key from BigIntegers modulus, exponent, primes,\n * prime exponents, and modular multiplicative inverse.\n *\n * @param n the modulus.\n * @param e the public exponent.\n * @param d the private exponent ((inverse of e) mod n).\n * @param p the first prime.\n * @param q the second prime.\n * @param dP exponent1 (d mod (p-1)).\n * @param dQ exponent2 (d mod (q-1)).\n * @param qInv ((inverse of q) mod p)\n *\n * @return the private key.\n */\npki.setRsaPrivateKey = pki.rsa.setPrivateKey = function(\n n, e, d, p, q, dP, dQ, qInv) {\n var key = {\n n: n,\n e: e,\n d: d,\n p: p,\n q: q,\n dP: dP,\n dQ: dQ,\n qInv: qInv\n };\n\n /**\n * Decrypts the given data with this private key. The decryption scheme\n * must match the one used to encrypt the data.\n *\n * @param data the byte string to decrypt.\n * @param scheme the decryption scheme to use:\n * 'RSAES-PKCS1-V1_5' (default),\n * 'RSA-OAEP',\n * 'RAW', 'NONE', or null to perform raw RSA decryption.\n * @param schemeOptions any scheme-specific options.\n *\n * @return the decrypted byte string.\n */\n key.decrypt = function(data, scheme, schemeOptions) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSAES-PKCS1-V1_5';\n }\n\n // do rsa decryption w/o any decoding\n var d = pki.rsa.decrypt(data, key, false, false);\n\n if(scheme === 'RSAES-PKCS1-V1_5') {\n scheme = {decode: _decodePkcs1_v1_5};\n } else if(scheme === 'RSA-OAEP' || scheme === 'RSAES-OAEP') {\n scheme = {\n decode: function(d, key) {\n return forge.pkcs1.decode_rsa_oaep(key, d, schemeOptions);\n }\n };\n } else if(['RAW', 'NONE', 'NULL', null].indexOf(scheme) !== -1) {\n scheme = {decode: function(d) {return d;}};\n } else {\n throw new Error('Unsupported encryption scheme: \"' + scheme + '\".');\n }\n\n // decode according to scheme\n return scheme.decode(d, key, false);\n };\n\n /**\n * Signs the given digest, producing a signature.\n *\n * PKCS#1 supports multiple (currently two) signature schemes:\n * RSASSA-PKCS1-V1_5 and RSASSA-PSS.\n *\n * By default this implementation uses the \"old scheme\", i.e.\n * RSASSA-PKCS1-V1_5. In order to generate a PSS signature, provide\n * an instance of Forge PSS object as the scheme parameter.\n *\n * @param md the message digest object with the hash to sign.\n * @param scheme the signature scheme to use:\n * 'RSASSA-PKCS1-V1_5' or undefined for RSASSA PKCS#1 v1.5,\n * a Forge PSS object for RSASSA-PSS,\n * 'NONE' or null for none, DigestInfo will not be used but\n * PKCS#1 v1.5 padding will still be used.\n *\n * @return the signature as a byte string.\n */\n key.sign = function(md, scheme) {\n /* Note: The internal implementation of RSA operations is being\n transitioned away from a PKCS#1 v1.5 hard-coded scheme. Some legacy\n code like the use of an encoding block identifier 'bt' will eventually\n be removed. */\n\n // private key operation\n var bt = false;\n\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n }\n\n if(scheme === undefined || scheme === 'RSASSA-PKCS1-V1_5') {\n scheme = {encode: emsaPkcs1v15encode};\n bt = 0x01;\n } else if(scheme === 'NONE' || scheme === 'NULL' || scheme === null) {\n scheme = {encode: function() {return md;}};\n bt = 0x01;\n }\n\n // encode and then encrypt\n var d = scheme.encode(md, key.n.bitLength());\n return pki.rsa.encrypt(d, key, bt);\n };\n\n return key;\n};\n\n/**\n * Wraps an RSAPrivateKey ASN.1 object in an ASN.1 PrivateKeyInfo object.\n *\n * @param rsaKey the ASN.1 RSAPrivateKey.\n *\n * @return the ASN.1 PrivateKeyInfo.\n */\npki.wrapRsaPrivateKey = function(rsaKey) {\n // PrivateKeyInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version (0)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(0).getBytes()),\n // privateKeyAlgorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.rsaEncryption).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // PrivateKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n asn1.toDer(rsaKey).getBytes())\n ]);\n};\n\n/**\n * Converts a private key from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a PrivateKeyInfo containing an\n * RSAPrivateKey or an RSAPrivateKey.\n *\n * @return the private key.\n */\npki.privateKeyFromAsn1 = function(obj) {\n // get PrivateKeyInfo\n var capture = {};\n var errors = [];\n if(asn1.validate(obj, privateKeyValidator, capture, errors)) {\n obj = asn1.fromDer(forge.util.createBuffer(capture.privateKey));\n }\n\n // get RSAPrivateKey\n capture = {};\n errors = [];\n if(!asn1.validate(obj, rsaPrivateKeyValidator, capture, errors)) {\n var error = new Error('Cannot read private key. ' +\n 'ASN.1 object does not contain an RSAPrivateKey.');\n error.errors = errors;\n throw error;\n }\n\n // Note: Version is currently ignored.\n // capture.privateKeyVersion\n // FIXME: inefficient, get a BigInteger that uses byte strings\n var n, e, d, p, q, dP, dQ, qInv;\n n = forge.util.createBuffer(capture.privateKeyModulus).toHex();\n e = forge.util.createBuffer(capture.privateKeyPublicExponent).toHex();\n d = forge.util.createBuffer(capture.privateKeyPrivateExponent).toHex();\n p = forge.util.createBuffer(capture.privateKeyPrime1).toHex();\n q = forge.util.createBuffer(capture.privateKeyPrime2).toHex();\n dP = forge.util.createBuffer(capture.privateKeyExponent1).toHex();\n dQ = forge.util.createBuffer(capture.privateKeyExponent2).toHex();\n qInv = forge.util.createBuffer(capture.privateKeyCoefficient).toHex();\n\n // set private key\n return pki.setRsaPrivateKey(\n new BigInteger(n, 16),\n new BigInteger(e, 16),\n new BigInteger(d, 16),\n new BigInteger(p, 16),\n new BigInteger(q, 16),\n new BigInteger(dP, 16),\n new BigInteger(dQ, 16),\n new BigInteger(qInv, 16));\n};\n\n/**\n * Converts a private key to an ASN.1 RSAPrivateKey.\n *\n * @param key the private key.\n *\n * @return the ASN.1 representation of an RSAPrivateKey.\n */\npki.privateKeyToAsn1 = pki.privateKeyToRSAPrivateKey = function(key) {\n // RSAPrivateKey\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version (0 = only 2 primes, 1 multiple primes)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(0).getBytes()),\n // modulus (n)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.n)),\n // publicExponent (e)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.e)),\n // privateExponent (d)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.d)),\n // privateKeyPrime1 (p)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.p)),\n // privateKeyPrime2 (q)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.q)),\n // privateKeyExponent1 (dP)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.dP)),\n // privateKeyExponent2 (dQ)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.dQ)),\n // coefficient (qInv)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.qInv))\n ]);\n};\n\n/**\n * Converts a public key from an ASN.1 SubjectPublicKeyInfo or RSAPublicKey.\n *\n * @param obj the asn1 representation of a SubjectPublicKeyInfo or RSAPublicKey.\n *\n * @return the public key.\n */\npki.publicKeyFromAsn1 = function(obj) {\n // get SubjectPublicKeyInfo\n var capture = {};\n var errors = [];\n if(asn1.validate(obj, publicKeyValidator, capture, errors)) {\n // get oid\n var oid = asn1.derToOid(capture.publicKeyOid);\n if(oid !== pki.oids.rsaEncryption) {\n var error = new Error('Cannot read public key. Unknown OID.');\n error.oid = oid;\n throw error;\n }\n obj = capture.rsaPublicKey;\n }\n\n // get RSA params\n errors = [];\n if(!asn1.validate(obj, rsaPublicKeyValidator, capture, errors)) {\n var error = new Error('Cannot read public key. ' +\n 'ASN.1 object does not contain an RSAPublicKey.');\n error.errors = errors;\n throw error;\n }\n\n // FIXME: inefficient, get a BigInteger that uses byte strings\n var n = forge.util.createBuffer(capture.publicKeyModulus).toHex();\n var e = forge.util.createBuffer(capture.publicKeyExponent).toHex();\n\n // set public key\n return pki.setRsaPublicKey(\n new BigInteger(n, 16),\n new BigInteger(e, 16));\n};\n\n/**\n * Converts a public key to an ASN.1 SubjectPublicKeyInfo.\n *\n * @param key the public key.\n *\n * @return the asn1 representation of a SubjectPublicKeyInfo.\n */\npki.publicKeyToAsn1 = pki.publicKeyToSubjectPublicKeyInfo = function(key) {\n // SubjectPublicKeyInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.rsaEncryption).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // subjectPublicKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false, [\n pki.publicKeyToRSAPublicKey(key)\n ])\n ]);\n};\n\n/**\n * Converts a public key to an ASN.1 RSAPublicKey.\n *\n * @param key the public key.\n *\n * @return the asn1 representation of a RSAPublicKey.\n */\npki.publicKeyToRSAPublicKey = function(key) {\n // RSAPublicKey\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // modulus (n)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.n)),\n // publicExponent (e)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.e))\n ]);\n};\n\n/**\n * Encodes a message using PKCS#1 v1.5 padding.\n *\n * @param m the message to encode.\n * @param key the RSA key to use.\n * @param bt the block type to use, i.e. either 0x01 (for signing) or 0x02\n * (for encryption).\n *\n * @return the padded byte buffer.\n */\nfunction _encodePkcs1_v1_5(m, key, bt) {\n var eb = forge.util.createBuffer();\n\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n /* use PKCS#1 v1.5 padding */\n if(m.length > (k - 11)) {\n var error = new Error('Message is too long for PKCS#1 v1.5 padding.');\n error.length = m.length;\n error.max = k - 11;\n throw error;\n }\n\n /* A block type BT, a padding string PS, and the data D shall be\n formatted into an octet string EB, the encryption block:\n\n EB = 00 || BT || PS || 00 || D\n\n The block type BT shall be a single octet indicating the structure of\n the encryption block. For this version of the document it shall have\n value 00, 01, or 02. For a private-key operation, the block type\n shall be 00 or 01. For a public-key operation, it shall be 02.\n\n The padding string PS shall consist of k-3-||D|| octets. For block\n type 00, the octets shall have value 00; for block type 01, they\n shall have value FF; and for block type 02, they shall be\n pseudorandomly generated and nonzero. This makes the length of the\n encryption block EB equal to k. */\n\n // build the encryption block\n eb.putByte(0x00);\n eb.putByte(bt);\n\n // create the padding\n var padNum = k - 3 - m.length;\n var padByte;\n // private key op\n if(bt === 0x00 || bt === 0x01) {\n padByte = (bt === 0x00) ? 0x00 : 0xFF;\n for(var i = 0; i < padNum; ++i) {\n eb.putByte(padByte);\n }\n } else {\n // public key op\n // pad with random non-zero values\n while(padNum > 0) {\n var numZeros = 0;\n var padBytes = forge.random.getBytes(padNum);\n for(var i = 0; i < padNum; ++i) {\n padByte = padBytes.charCodeAt(i);\n if(padByte === 0) {\n ++numZeros;\n } else {\n eb.putByte(padByte);\n }\n }\n padNum = numZeros;\n }\n }\n\n // zero followed by message\n eb.putByte(0x00);\n eb.putBytes(m);\n\n return eb;\n}\n\n/**\n * Decodes a message using PKCS#1 v1.5 padding.\n *\n * @param em the message to decode.\n * @param key the RSA key to use.\n * @param pub true if the key is a public key, false if it is private.\n * @param ml the message length, if specified.\n *\n * @return the decoded bytes.\n */\nfunction _decodePkcs1_v1_5(em, key, pub, ml) {\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n /* It is an error if any of the following conditions occurs:\n\n 1. The encryption block EB cannot be parsed unambiguously.\n 2. The padding string PS consists of fewer than eight octets\n or is inconsisent with the block type BT.\n 3. The decryption process is a public-key operation and the block\n type BT is not 00 or 01, or the decryption process is a\n private-key operation and the block type is not 02.\n */\n\n // parse the encryption block\n var eb = forge.util.createBuffer(em);\n var first = eb.getByte();\n var bt = eb.getByte();\n if(first !== 0x00 ||\n (pub && bt !== 0x00 && bt !== 0x01) ||\n (!pub && bt != 0x02) ||\n (pub && bt === 0x00 && typeof(ml) === 'undefined')) {\n throw new Error('Encryption block is invalid.');\n }\n\n var padNum = 0;\n if(bt === 0x00) {\n // check all padding bytes for 0x00\n padNum = k - 3 - ml;\n for(var i = 0; i < padNum; ++i) {\n if(eb.getByte() !== 0x00) {\n throw new Error('Encryption block is invalid.');\n }\n }\n } else if(bt === 0x01) {\n // find the first byte that isn't 0xFF, should be after all padding\n padNum = 0;\n while(eb.length() > 1) {\n if(eb.getByte() !== 0xFF) {\n --eb.read;\n break;\n }\n ++padNum;\n }\n } else if(bt === 0x02) {\n // look for 0x00 byte\n padNum = 0;\n while(eb.length() > 1) {\n if(eb.getByte() === 0x00) {\n --eb.read;\n break;\n }\n ++padNum;\n }\n }\n\n // zero must be 0x00 and padNum must be (k - 3 - message length)\n var zero = eb.getByte();\n if(zero !== 0x00 || padNum !== (k - 3 - eb.length())) {\n throw new Error('Encryption block is invalid.');\n }\n\n return eb.getBytes();\n}\n\n/**\n * Runs the key-generation algorithm asynchronously, either in the background\n * via Web Workers, or using the main thread and setImmediate.\n *\n * @param state the key-pair generation state.\n * @param [options] options for key-pair generation:\n * workerScript the worker script URL.\n * workers the number of web workers (if supported) to use,\n * (default: 2, -1 to use estimated cores minus one).\n * workLoad the size of the work load, ie: number of possible prime\n * numbers for each web worker to check per work assignment,\n * (default: 100).\n * @param callback(err, keypair) called once the operation completes.\n */\nfunction _generateKeyPair(state, options, callback) {\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n\n var opts = {\n algorithm: {\n name: options.algorithm || 'PRIMEINC',\n options: {\n workers: options.workers || 2,\n workLoad: options.workLoad || 100,\n workerScript: options.workerScript\n }\n }\n };\n if('prng' in options) {\n opts.prng = options.prng;\n }\n\n generate();\n\n function generate() {\n // find p and then q (done in series to simplify)\n getPrime(state.pBits, function(err, num) {\n if(err) {\n return callback(err);\n }\n state.p = num;\n if(state.q !== null) {\n return finish(err, state.q);\n }\n getPrime(state.qBits, finish);\n });\n }\n\n function getPrime(bits, callback) {\n forge.prime.generateProbablePrime(bits, opts, callback);\n }\n\n function finish(err, num) {\n if(err) {\n return callback(err);\n }\n\n // set q\n state.q = num;\n\n // ensure p is larger than q (swap them if not)\n if(state.p.compareTo(state.q) < 0) {\n var tmp = state.p;\n state.p = state.q;\n state.q = tmp;\n }\n\n // ensure p is coprime with e\n if(state.p.subtract(BigInteger.ONE).gcd(state.e)\n .compareTo(BigInteger.ONE) !== 0) {\n state.p = null;\n generate();\n return;\n }\n\n // ensure q is coprime with e\n if(state.q.subtract(BigInteger.ONE).gcd(state.e)\n .compareTo(BigInteger.ONE) !== 0) {\n state.q = null;\n getPrime(state.qBits, finish);\n return;\n }\n\n // compute phi: (p - 1)(q - 1) (Euler's totient function)\n state.p1 = state.p.subtract(BigInteger.ONE);\n state.q1 = state.q.subtract(BigInteger.ONE);\n state.phi = state.p1.multiply(state.q1);\n\n // ensure e and phi are coprime\n if(state.phi.gcd(state.e).compareTo(BigInteger.ONE) !== 0) {\n // phi and e aren't coprime, so generate a new p and q\n state.p = state.q = null;\n generate();\n return;\n }\n\n // create n, ensure n is has the right number of bits\n state.n = state.p.multiply(state.q);\n if(state.n.bitLength() !== state.bits) {\n // failed, get new q\n state.q = null;\n getPrime(state.qBits, finish);\n return;\n }\n\n // set keys\n var d = state.e.modInverse(state.phi);\n state.keys = {\n privateKey: pki.rsa.setPrivateKey(\n state.n, state.e, d, state.p, state.q,\n d.mod(state.p1), d.mod(state.q1),\n state.q.modInverse(state.p)),\n publicKey: pki.rsa.setPublicKey(state.n, state.e)\n };\n\n callback(null, state.keys);\n }\n}\n\n/**\n * Converts a positive BigInteger into 2's-complement big-endian bytes.\n *\n * @param b the big integer to convert.\n *\n * @return the bytes.\n */\nfunction _bnToBytes(b) {\n // prepend 0x00 if first byte >= 0x80\n var hex = b.toString(16);\n if(hex[0] >= '8') {\n hex = '00' + hex;\n }\n var bytes = forge.util.hexToBytes(hex);\n\n // ensure integer is minimally-encoded\n if(bytes.length > 1 &&\n // leading 0x00 for positive integer\n ((bytes.charCodeAt(0) === 0 &&\n (bytes.charCodeAt(1) & 0x80) === 0) ||\n // leading 0xFF for negative integer\n (bytes.charCodeAt(0) === 0xFF &&\n (bytes.charCodeAt(1) & 0x80) === 0x80))) {\n return bytes.substr(1);\n }\n return bytes;\n}\n\n/**\n * Returns the required number of Miller-Rabin tests to generate a\n * prime with an error probability of (1/2)^80.\n *\n * See Handbook of Applied Cryptography Chapter 4, Table 4.4.\n *\n * @param bits the bit size.\n *\n * @return the required number of iterations.\n */\nfunction _getMillerRabinTests(bits) {\n if(bits <= 100) return 27;\n if(bits <= 150) return 18;\n if(bits <= 200) return 15;\n if(bits <= 250) return 12;\n if(bits <= 300) return 9;\n if(bits <= 350) return 8;\n if(bits <= 400) return 7;\n if(bits <= 500) return 6;\n if(bits <= 600) return 5;\n if(bits <= 800) return 4;\n if(bits <= 1250) return 3;\n return 2;\n}\n\n/**\n * Performs feature detection on the Node crypto interface.\n *\n * @param fn the feature (function) to detect.\n *\n * @return true if detected, false if not.\n */\nfunction _detectNodeCrypto(fn) {\n return forge.util.isNodejs && typeof _crypto[fn] === 'function';\n}\n\n/**\n * Performs feature detection on the SubtleCrypto interface.\n *\n * @param fn the feature (function) to detect.\n *\n * @return true if detected, false if not.\n */\nfunction _detectSubtleCrypto(fn) {\n return (typeof util.globalScope !== 'undefined' &&\n typeof util.globalScope.crypto === 'object' &&\n typeof util.globalScope.crypto.subtle === 'object' &&\n typeof util.globalScope.crypto.subtle[fn] === 'function');\n}\n\n/**\n * Performs feature detection on the deprecated Microsoft Internet Explorer\n * outdated SubtleCrypto interface. This function should only be used after\n * checking for the modern, standard SubtleCrypto interface.\n *\n * @param fn the feature (function) to detect.\n *\n * @return true if detected, false if not.\n */\nfunction _detectSubtleMsCrypto(fn) {\n return (typeof util.globalScope !== 'undefined' &&\n typeof util.globalScope.msCrypto === 'object' &&\n typeof util.globalScope.msCrypto.subtle === 'object' &&\n typeof util.globalScope.msCrypto.subtle[fn] === 'function');\n}\n\nfunction _intToUint8Array(x) {\n var bytes = forge.util.hexToBytes(x.toString(16));\n var buffer = new Uint8Array(bytes.length);\n for(var i = 0; i < bytes.length; ++i) {\n buffer[i] = bytes.charCodeAt(i);\n }\n return buffer;\n}\n\nfunction _privateKeyFromJwk(jwk) {\n if(jwk.kty !== 'RSA') {\n throw new Error(\n 'Unsupported key algorithm \"' + jwk.kty + '\"; algorithm must be \"RSA\".');\n }\n return pki.setRsaPrivateKey(\n _base64ToBigInt(jwk.n),\n _base64ToBigInt(jwk.e),\n _base64ToBigInt(jwk.d),\n _base64ToBigInt(jwk.p),\n _base64ToBigInt(jwk.q),\n _base64ToBigInt(jwk.dp),\n _base64ToBigInt(jwk.dq),\n _base64ToBigInt(jwk.qi));\n}\n\nfunction _publicKeyFromJwk(jwk) {\n if(jwk.kty !== 'RSA') {\n throw new Error('Key algorithm must be \"RSA\".');\n }\n return pki.setRsaPublicKey(\n _base64ToBigInt(jwk.n),\n _base64ToBigInt(jwk.e));\n}\n\nfunction _base64ToBigInt(b64) {\n return new BigInteger(forge.util.bytesToHex(forge.util.decode64(b64)), 16);\n}\n","// Copyright (c) 2005 Tom Wu\n// All Rights Reserved.\n// See \"LICENSE\" for details.\n\n// Basic JavaScript BN library - subset useful for RSA encryption.\n\n/*\nLicensing (LICENSE)\n-------------------\n\nThis software is covered under the following copyright:\n*/\n/*\n * Copyright (c) 2003-2005 Tom Wu\n * All Rights Reserved.\n *\n * Permission is hereby granted, free of charge, to any person obtaining\n * a copy of this software and associated documentation files (the\n * \"Software\"), to deal in the Software without restriction, including\n * without limitation the rights to use, copy, modify, merge, publish,\n * distribute, sublicense, and/or sell copies of the Software, and to\n * permit persons to whom the Software is furnished to do so, subject to\n * the following conditions:\n *\n * The above copyright notice and this permission notice shall be\n * included in all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS-IS\" AND WITHOUT WARRANTY OF ANY KIND,\n * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY\n * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.\n *\n * IN NO EVENT SHALL TOM WU BE LIABLE FOR ANY SPECIAL, INCIDENTAL,\n * INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, OR ANY DAMAGES WHATSOEVER\n * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER OR NOT ADVISED OF\n * THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF LIABILITY, ARISING OUT\n * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n *\n * In addition, the following condition applies:\n *\n * All redistributions must retain an intact copy of this copyright notice\n * and disclaimer.\n */\n/*\nAddress all questions regarding this license to:\n\n Tom Wu\n tjw@cs.Stanford.EDU\n*/\nvar forge = require('./forge');\n\nmodule.exports = forge.jsbn = forge.jsbn || {};\n\n// Bits per digit\nvar dbits;\n\n// JavaScript engine analysis\nvar canary = 0xdeadbeefcafe;\nvar j_lm = ((canary&0xffffff)==0xefcafe);\n\n// (public) Constructor\nfunction BigInteger(a,b,c) {\n this.data = [];\n if(a != null)\n if(\"number\" == typeof a) this.fromNumber(a,b,c);\n else if(b == null && \"string\" != typeof a) this.fromString(a,256);\n else this.fromString(a,b);\n}\nforge.jsbn.BigInteger = BigInteger;\n\n// return new, unset BigInteger\nfunction nbi() { return new BigInteger(null); }\n\n// am: Compute w_j += (x*this_i), propagate carries,\n// c is initial carry, returns final carry.\n// c < 3*dvalue, x < 2*dvalue, this_i < dvalue\n// We need to select the fastest one that works in this environment.\n\n// am1: use a single mult and divide to get the high bits,\n// max digit bits should be 26 because\n// max internal value = 2*dvalue^2-2*dvalue (< 2^53)\nfunction am1(i,x,w,j,c,n) {\n while(--n >= 0) {\n var v = x*this.data[i++]+w.data[j]+c;\n c = Math.floor(v/0x4000000);\n w.data[j++] = v&0x3ffffff;\n }\n return c;\n}\n// am2 avoids a big mult-and-extract completely.\n// Max digit bits should be <= 30 because we do bitwise ops\n// on values up to 2*hdvalue^2-hdvalue-1 (< 2^31)\nfunction am2(i,x,w,j,c,n) {\n var xl = x&0x7fff, xh = x>>15;\n while(--n >= 0) {\n var l = this.data[i]&0x7fff;\n var h = this.data[i++]>>15;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x7fff)<<15)+w.data[j]+(c&0x3fffffff);\n c = (l>>>30)+(m>>>15)+xh*h+(c>>>30);\n w.data[j++] = l&0x3fffffff;\n }\n return c;\n}\n// Alternately, set max digit bits to 28 since some\n// browsers slow down when dealing with 32-bit numbers.\nfunction am3(i,x,w,j,c,n) {\n var xl = x&0x3fff, xh = x>>14;\n while(--n >= 0) {\n var l = this.data[i]&0x3fff;\n var h = this.data[i++]>>14;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x3fff)<<14)+w.data[j]+c;\n c = (l>>28)+(m>>14)+xh*h;\n w.data[j++] = l&0xfffffff;\n }\n return c;\n}\n\n// node.js (no browser)\nif(typeof(navigator) === 'undefined')\n{\n BigInteger.prototype.am = am3;\n dbits = 28;\n} else if(j_lm && (navigator.appName == \"Microsoft Internet Explorer\")) {\n BigInteger.prototype.am = am2;\n dbits = 30;\n} else if(j_lm && (navigator.appName != \"Netscape\")) {\n BigInteger.prototype.am = am1;\n dbits = 26;\n} else { // Mozilla/Netscape seems to prefer am3\n BigInteger.prototype.am = am3;\n dbits = 28;\n}\n\nBigInteger.prototype.DB = dbits;\nBigInteger.prototype.DM = ((1<= 0; --i) r.data[i] = this.data[i];\n r.t = this.t;\n r.s = this.s;\n}\n\n// (protected) set from integer value x, -DV <= x < DV\nfunction bnpFromInt(x) {\n this.t = 1;\n this.s = (x<0)?-1:0;\n if(x > 0) this.data[0] = x;\n else if(x < -1) this.data[0] = x+this.DV;\n else this.t = 0;\n}\n\n// return bigint initialized to value\nfunction nbv(i) { var r = nbi(); r.fromInt(i); return r; }\n\n// (protected) set from string and radix\nfunction bnpFromString(s,b) {\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 256) k = 8; // byte array\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else { this.fromRadix(s,b); return; }\n this.t = 0;\n this.s = 0;\n var i = s.length, mi = false, sh = 0;\n while(--i >= 0) {\n var x = (k==8)?s[i]&0xff:intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\") mi = true;\n continue;\n }\n mi = false;\n if(sh == 0)\n this.data[this.t++] = x;\n else if(sh+k > this.DB) {\n this.data[this.t-1] |= (x&((1<<(this.DB-sh))-1))<>(this.DB-sh));\n } else\n this.data[this.t-1] |= x<= this.DB) sh -= this.DB;\n }\n if(k == 8 && (s[0]&0x80) != 0) {\n this.s = -1;\n if(sh > 0) this.data[this.t-1] |= ((1<<(this.DB-sh))-1)< 0 && this.data[this.t-1] == c) --this.t;\n}\n\n// (public) return string representation in given radix\nfunction bnToString(b) {\n if(this.s < 0) return \"-\"+this.negate().toString(b);\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else return this.toRadix(b);\n var km = (1< 0) {\n if(p < this.DB && (d = this.data[i]>>p) > 0) { m = true; r = int2char(d); }\n while(i >= 0) {\n if(p < k) {\n d = (this.data[i]&((1<>(p+=this.DB-k);\n } else {\n d = (this.data[i]>>(p-=k))&km;\n if(p <= 0) { p += this.DB; --i; }\n }\n if(d > 0) m = true;\n if(m) r += int2char(d);\n }\n }\n return m?r:\"0\";\n}\n\n// (public) -this\nfunction bnNegate() { var r = nbi(); BigInteger.ZERO.subTo(this,r); return r; }\n\n// (public) |this|\nfunction bnAbs() { return (this.s<0)?this.negate():this; }\n\n// (public) return + if this > a, - if this < a, 0 if equal\nfunction bnCompareTo(a) {\n var r = this.s-a.s;\n if(r != 0) return r;\n var i = this.t;\n r = i-a.t;\n if(r != 0) return (this.s<0)?-r:r;\n while(--i >= 0) if((r=this.data[i]-a.data[i]) != 0) return r;\n return 0;\n}\n\n// returns bit length of the integer x\nfunction nbits(x) {\n var r = 1, t;\n if((t=x>>>16) != 0) { x = t; r += 16; }\n if((t=x>>8) != 0) { x = t; r += 8; }\n if((t=x>>4) != 0) { x = t; r += 4; }\n if((t=x>>2) != 0) { x = t; r += 2; }\n if((t=x>>1) != 0) { x = t; r += 1; }\n return r;\n}\n\n// (public) return the number of bits in \"this\"\nfunction bnBitLength() {\n if(this.t <= 0) return 0;\n return this.DB*(this.t-1)+nbits(this.data[this.t-1]^(this.s&this.DM));\n}\n\n// (protected) r = this << n*DB\nfunction bnpDLShiftTo(n,r) {\n var i;\n for(i = this.t-1; i >= 0; --i) r.data[i+n] = this.data[i];\n for(i = n-1; i >= 0; --i) r.data[i] = 0;\n r.t = this.t+n;\n r.s = this.s;\n}\n\n// (protected) r = this >> n*DB\nfunction bnpDRShiftTo(n,r) {\n for(var i = n; i < this.t; ++i) r.data[i-n] = this.data[i];\n r.t = Math.max(this.t-n,0);\n r.s = this.s;\n}\n\n// (protected) r = this << n\nfunction bnpLShiftTo(n,r) {\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<= 0; --i) {\n r.data[i+ds+1] = (this.data[i]>>cbs)|c;\n c = (this.data[i]&bm)<= 0; --i) r.data[i] = 0;\n r.data[ds] = c;\n r.t = this.t+ds+1;\n r.s = this.s;\n r.clamp();\n}\n\n// (protected) r = this >> n\nfunction bnpRShiftTo(n,r) {\n r.s = this.s;\n var ds = Math.floor(n/this.DB);\n if(ds >= this.t) { r.t = 0; return; }\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<>bs;\n for(var i = ds+1; i < this.t; ++i) {\n r.data[i-ds-1] |= (this.data[i]&bm)<>bs;\n }\n if(bs > 0) r.data[this.t-ds-1] |= (this.s&bm)<>= this.DB;\n }\n if(a.t < this.t) {\n c -= a.s;\n while(i < this.t) {\n c += this.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n } else {\n c += this.s;\n while(i < a.t) {\n c -= a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c -= a.s;\n }\n r.s = (c<0)?-1:0;\n if(c < -1) r.data[i++] = this.DV+c;\n else if(c > 0) r.data[i++] = c;\n r.t = i;\n r.clamp();\n}\n\n// (protected) r = this * a, r != this,a (HAC 14.12)\n// \"this\" should be the larger one if appropriate.\nfunction bnpMultiplyTo(a,r) {\n var x = this.abs(), y = a.abs();\n var i = x.t;\n r.t = i+y.t;\n while(--i >= 0) r.data[i] = 0;\n for(i = 0; i < y.t; ++i) r.data[i+x.t] = x.am(0,y.data[i],r,i,0,x.t);\n r.s = 0;\n r.clamp();\n if(this.s != a.s) BigInteger.ZERO.subTo(r,r);\n}\n\n// (protected) r = this^2, r != this (HAC 14.16)\nfunction bnpSquareTo(r) {\n var x = this.abs();\n var i = r.t = 2*x.t;\n while(--i >= 0) r.data[i] = 0;\n for(i = 0; i < x.t-1; ++i) {\n var c = x.am(i,x.data[i],r,2*i,0,1);\n if((r.data[i+x.t]+=x.am(i+1,2*x.data[i],r,2*i+1,c,x.t-i-1)) >= x.DV) {\n r.data[i+x.t] -= x.DV;\n r.data[i+x.t+1] = 1;\n }\n }\n if(r.t > 0) r.data[r.t-1] += x.am(i,x.data[i],r,2*i,0,1);\n r.s = 0;\n r.clamp();\n}\n\n// (protected) divide this by m, quotient and remainder to q, r (HAC 14.20)\n// r != q, this != m. q or r may be null.\nfunction bnpDivRemTo(m,q,r) {\n var pm = m.abs();\n if(pm.t <= 0) return;\n var pt = this.abs();\n if(pt.t < pm.t) {\n if(q != null) q.fromInt(0);\n if(r != null) this.copyTo(r);\n return;\n }\n if(r == null) r = nbi();\n var y = nbi(), ts = this.s, ms = m.s;\n var nsh = this.DB-nbits(pm.data[pm.t-1]);\t// normalize modulus\n if(nsh > 0) { pm.lShiftTo(nsh,y); pt.lShiftTo(nsh,r); } else { pm.copyTo(y); pt.copyTo(r); }\n var ys = y.t;\n var y0 = y.data[ys-1];\n if(y0 == 0) return;\n var yt = y0*(1<1)?y.data[ys-2]>>this.F2:0);\n var d1 = this.FV/yt, d2 = (1<= 0) {\n r.data[r.t++] = 1;\n r.subTo(t,r);\n }\n BigInteger.ONE.dlShiftTo(ys,t);\n t.subTo(y,y);\t// \"negative\" y so we can replace sub with am later\n while(y.t < ys) y.data[y.t++] = 0;\n while(--j >= 0) {\n // Estimate quotient digit\n var qd = (r.data[--i]==y0)?this.DM:Math.floor(r.data[i]*d1+(r.data[i-1]+e)*d2);\n if((r.data[i]+=y.am(0,qd,r,j,0,ys)) < qd) {\t// Try it out\n y.dlShiftTo(j,t);\n r.subTo(t,r);\n while(r.data[i] < --qd) r.subTo(t,r);\n }\n }\n if(q != null) {\n r.drShiftTo(ys,q);\n if(ts != ms) BigInteger.ZERO.subTo(q,q);\n }\n r.t = ys;\n r.clamp();\n if(nsh > 0) r.rShiftTo(nsh,r);\t// Denormalize remainder\n if(ts < 0) BigInteger.ZERO.subTo(r,r);\n}\n\n// (public) this mod a\nfunction bnMod(a) {\n var r = nbi();\n this.abs().divRemTo(a,null,r);\n if(this.s < 0 && r.compareTo(BigInteger.ZERO) > 0) a.subTo(r,r);\n return r;\n}\n\n// Modular reduction using \"classic\" algorithm\nfunction Classic(m) { this.m = m; }\nfunction cConvert(x) {\n if(x.s < 0 || x.compareTo(this.m) >= 0) return x.mod(this.m);\n else return x;\n}\nfunction cRevert(x) { return x; }\nfunction cReduce(x) { x.divRemTo(this.m,null,x); }\nfunction cMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\nfunction cSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\nClassic.prototype.convert = cConvert;\nClassic.prototype.revert = cRevert;\nClassic.prototype.reduce = cReduce;\nClassic.prototype.mulTo = cMulTo;\nClassic.prototype.sqrTo = cSqrTo;\n\n// (protected) return \"-1/this % 2^DB\"; useful for Mont. reduction\n// justification:\n// xy == 1 (mod m)\n// xy = 1+km\n// xy(2-xy) = (1+km)(1-km)\n// x[y(2-xy)] = 1-k^2m^2\n// x[y(2-xy)] == 1 (mod m^2)\n// if y is 1/x mod m, then y(2-xy) is 1/x mod m^2\n// should reduce x and y(2-xy) by m^2 at each step to keep size bounded.\n// JS multiply \"overflows\" differently from C/C++, so care is needed here.\nfunction bnpInvDigit() {\n if(this.t < 1) return 0;\n var x = this.data[0];\n if((x&1) == 0) return 0;\n var y = x&3;\t\t// y == 1/x mod 2^2\n y = (y*(2-(x&0xf)*y))&0xf;\t// y == 1/x mod 2^4\n y = (y*(2-(x&0xff)*y))&0xff;\t// y == 1/x mod 2^8\n y = (y*(2-(((x&0xffff)*y)&0xffff)))&0xffff;\t// y == 1/x mod 2^16\n // last step - calculate inverse mod DV directly;\n // assumes 16 < DB <= 32 and assumes ability to handle 48-bit ints\n y = (y*(2-x*y%this.DV))%this.DV;\t\t// y == 1/x mod 2^dbits\n // we really want the negative inverse, and -DV < y < DV\n return (y>0)?this.DV-y:-y;\n}\n\n// Montgomery reduction\nfunction Montgomery(m) {\n this.m = m;\n this.mp = m.invDigit();\n this.mpl = this.mp&0x7fff;\n this.mph = this.mp>>15;\n this.um = (1<<(m.DB-15))-1;\n this.mt2 = 2*m.t;\n}\n\n// xR mod m\nfunction montConvert(x) {\n var r = nbi();\n x.abs().dlShiftTo(this.m.t,r);\n r.divRemTo(this.m,null,r);\n if(x.s < 0 && r.compareTo(BigInteger.ZERO) > 0) this.m.subTo(r,r);\n return r;\n}\n\n// x/R mod m\nfunction montRevert(x) {\n var r = nbi();\n x.copyTo(r);\n this.reduce(r);\n return r;\n}\n\n// x = x/R mod m (HAC 14.32)\nfunction montReduce(x) {\n while(x.t <= this.mt2)\t// pad x so am has enough room later\n x.data[x.t++] = 0;\n for(var i = 0; i < this.m.t; ++i) {\n // faster way of calculating u0 = x.data[i]*mp mod DV\n var j = x.data[i]&0x7fff;\n var u0 = (j*this.mpl+(((j*this.mph+(x.data[i]>>15)*this.mpl)&this.um)<<15))&x.DM;\n // use am to combine the multiply-shift-add into one call\n j = i+this.m.t;\n x.data[j] += this.m.am(0,u0,x,i,0,this.m.t);\n // propagate carry\n while(x.data[j] >= x.DV) { x.data[j] -= x.DV; x.data[++j]++; }\n }\n x.clamp();\n x.drShiftTo(this.m.t,x);\n if(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n}\n\n// r = \"x^2/R mod m\"; x != r\nfunction montSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n// r = \"xy/R mod m\"; x,y != r\nfunction montMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\nMontgomery.prototype.convert = montConvert;\nMontgomery.prototype.revert = montRevert;\nMontgomery.prototype.reduce = montReduce;\nMontgomery.prototype.mulTo = montMulTo;\nMontgomery.prototype.sqrTo = montSqrTo;\n\n// (protected) true iff this is even\nfunction bnpIsEven() { return ((this.t>0)?(this.data[0]&1):this.s) == 0; }\n\n// (protected) this^e, e < 2^32, doing sqr and mul with \"r\" (HAC 14.79)\nfunction bnpExp(e,z) {\n if(e > 0xffffffff || e < 1) return BigInteger.ONE;\n var r = nbi(), r2 = nbi(), g = z.convert(this), i = nbits(e)-1;\n g.copyTo(r);\n while(--i >= 0) {\n z.sqrTo(r,r2);\n if((e&(1< 0) z.mulTo(r2,g,r);\n else { var t = r; r = r2; r2 = t; }\n }\n return z.revert(r);\n}\n\n// (public) this^e % m, 0 <= e < 2^32\nfunction bnModPowInt(e,m) {\n var z;\n if(e < 256 || m.isEven()) z = new Classic(m); else z = new Montgomery(m);\n return this.exp(e,z);\n}\n\n// protected\nBigInteger.prototype.copyTo = bnpCopyTo;\nBigInteger.prototype.fromInt = bnpFromInt;\nBigInteger.prototype.fromString = bnpFromString;\nBigInteger.prototype.clamp = bnpClamp;\nBigInteger.prototype.dlShiftTo = bnpDLShiftTo;\nBigInteger.prototype.drShiftTo = bnpDRShiftTo;\nBigInteger.prototype.lShiftTo = bnpLShiftTo;\nBigInteger.prototype.rShiftTo = bnpRShiftTo;\nBigInteger.prototype.subTo = bnpSubTo;\nBigInteger.prototype.multiplyTo = bnpMultiplyTo;\nBigInteger.prototype.squareTo = bnpSquareTo;\nBigInteger.prototype.divRemTo = bnpDivRemTo;\nBigInteger.prototype.invDigit = bnpInvDigit;\nBigInteger.prototype.isEven = bnpIsEven;\nBigInteger.prototype.exp = bnpExp;\n\n// public\nBigInteger.prototype.toString = bnToString;\nBigInteger.prototype.negate = bnNegate;\nBigInteger.prototype.abs = bnAbs;\nBigInteger.prototype.compareTo = bnCompareTo;\nBigInteger.prototype.bitLength = bnBitLength;\nBigInteger.prototype.mod = bnMod;\nBigInteger.prototype.modPowInt = bnModPowInt;\n\n// \"constants\"\nBigInteger.ZERO = nbv(0);\nBigInteger.ONE = nbv(1);\n\n// jsbn2 lib\n\n//Copyright (c) 2005-2009 Tom Wu\n//All Rights Reserved.\n//See \"LICENSE\" for details (See jsbn.js for LICENSE).\n\n//Extended JavaScript BN functions, required for RSA private ops.\n\n//Version 1.1: new BigInteger(\"0\", 10) returns \"proper\" zero\n\n//(public)\nfunction bnClone() { var r = nbi(); this.copyTo(r); return r; }\n\n//(public) return value as integer\nfunction bnIntValue() {\nif(this.s < 0) {\n if(this.t == 1) return this.data[0]-this.DV;\n else if(this.t == 0) return -1;\n} else if(this.t == 1) return this.data[0];\nelse if(this.t == 0) return 0;\n// assumes 16 < DB < 32\nreturn ((this.data[1]&((1<<(32-this.DB))-1))<>24; }\n\n//(public) return value as short (assumes DB>=16)\nfunction bnShortValue() { return (this.t==0)?this.s:(this.data[0]<<16)>>16; }\n\n//(protected) return x s.t. r^x < DV\nfunction bnpChunkSize(r) { return Math.floor(Math.LN2*this.DB/Math.log(r)); }\n\n//(public) 0 if this == 0, 1 if this > 0\nfunction bnSigNum() {\nif(this.s < 0) return -1;\nelse if(this.t <= 0 || (this.t == 1 && this.data[0] <= 0)) return 0;\nelse return 1;\n}\n\n//(protected) convert to radix string\nfunction bnpToRadix(b) {\nif(b == null) b = 10;\nif(this.signum() == 0 || b < 2 || b > 36) return \"0\";\nvar cs = this.chunkSize(b);\nvar a = Math.pow(b,cs);\nvar d = nbv(a), y = nbi(), z = nbi(), r = \"\";\nthis.divRemTo(d,y,z);\nwhile(y.signum() > 0) {\n r = (a+z.intValue()).toString(b).substr(1) + r;\n y.divRemTo(d,y,z);\n}\nreturn z.intValue().toString(b) + r;\n}\n\n//(protected) convert from radix string\nfunction bnpFromRadix(s,b) {\nthis.fromInt(0);\nif(b == null) b = 10;\nvar cs = this.chunkSize(b);\nvar d = Math.pow(b,cs), mi = false, j = 0, w = 0;\nfor(var i = 0; i < s.length; ++i) {\n var x = intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\" && this.signum() == 0) mi = true;\n continue;\n }\n w = b*w+x;\n if(++j >= cs) {\n this.dMultiply(d);\n this.dAddOffset(w,0);\n j = 0;\n w = 0;\n }\n}\nif(j > 0) {\n this.dMultiply(Math.pow(b,j));\n this.dAddOffset(w,0);\n}\nif(mi) BigInteger.ZERO.subTo(this,this);\n}\n\n//(protected) alternate constructor\nfunction bnpFromNumber(a,b,c) {\nif(\"number\" == typeof b) {\n // new BigInteger(int,int,RNG)\n if(a < 2) this.fromInt(1);\n else {\n this.fromNumber(a,c);\n if(!this.testBit(a-1)) // force MSB set\n this.bitwiseTo(BigInteger.ONE.shiftLeft(a-1),op_or,this);\n if(this.isEven()) this.dAddOffset(1,0); // force odd\n while(!this.isProbablePrime(b)) {\n this.dAddOffset(2,0);\n if(this.bitLength() > a) this.subTo(BigInteger.ONE.shiftLeft(a-1),this);\n }\n }\n} else {\n // new BigInteger(int,RNG)\n var x = new Array(), t = a&7;\n x.length = (a>>3)+1;\n b.nextBytes(x);\n if(t > 0) x[0] &= ((1< 0) {\n if(p < this.DB && (d = this.data[i]>>p) != (this.s&this.DM)>>p)\n r[k++] = d|(this.s<<(this.DB-p));\n while(i >= 0) {\n if(p < 8) {\n d = (this.data[i]&((1<>(p+=this.DB-8);\n } else {\n d = (this.data[i]>>(p-=8))&0xff;\n if(p <= 0) { p += this.DB; --i; }\n }\n if((d&0x80) != 0) d |= -256;\n if(k == 0 && (this.s&0x80) != (d&0x80)) ++k;\n if(k > 0 || d != this.s) r[k++] = d;\n }\n}\nreturn r;\n}\n\nfunction bnEquals(a) { return(this.compareTo(a)==0); }\nfunction bnMin(a) { return(this.compareTo(a)<0)?this:a; }\nfunction bnMax(a) { return(this.compareTo(a)>0)?this:a; }\n\n//(protected) r = this op a (bitwise)\nfunction bnpBitwiseTo(a,op,r) {\nvar i, f, m = Math.min(a.t,this.t);\nfor(i = 0; i < m; ++i) r.data[i] = op(this.data[i],a.data[i]);\nif(a.t < this.t) {\n f = a.s&this.DM;\n for(i = m; i < this.t; ++i) r.data[i] = op(this.data[i],f);\n r.t = this.t;\n} else {\n f = this.s&this.DM;\n for(i = m; i < a.t; ++i) r.data[i] = op(f,a.data[i]);\n r.t = a.t;\n}\nr.s = op(this.s,a.s);\nr.clamp();\n}\n\n//(public) this & a\nfunction op_and(x,y) { return x&y; }\nfunction bnAnd(a) { var r = nbi(); this.bitwiseTo(a,op_and,r); return r; }\n\n//(public) this | a\nfunction op_or(x,y) { return x|y; }\nfunction bnOr(a) { var r = nbi(); this.bitwiseTo(a,op_or,r); return r; }\n\n//(public) this ^ a\nfunction op_xor(x,y) { return x^y; }\nfunction bnXor(a) { var r = nbi(); this.bitwiseTo(a,op_xor,r); return r; }\n\n//(public) this & ~a\nfunction op_andnot(x,y) { return x&~y; }\nfunction bnAndNot(a) { var r = nbi(); this.bitwiseTo(a,op_andnot,r); return r; }\n\n//(public) ~this\nfunction bnNot() {\nvar r = nbi();\nfor(var i = 0; i < this.t; ++i) r.data[i] = this.DM&~this.data[i];\nr.t = this.t;\nr.s = ~this.s;\nreturn r;\n}\n\n//(public) this << n\nfunction bnShiftLeft(n) {\nvar r = nbi();\nif(n < 0) this.rShiftTo(-n,r); else this.lShiftTo(n,r);\nreturn r;\n}\n\n//(public) this >> n\nfunction bnShiftRight(n) {\nvar r = nbi();\nif(n < 0) this.lShiftTo(-n,r); else this.rShiftTo(n,r);\nreturn r;\n}\n\n//return index of lowest 1-bit in x, x < 2^31\nfunction lbit(x) {\nif(x == 0) return -1;\nvar r = 0;\nif((x&0xffff) == 0) { x >>= 16; r += 16; }\nif((x&0xff) == 0) { x >>= 8; r += 8; }\nif((x&0xf) == 0) { x >>= 4; r += 4; }\nif((x&3) == 0) { x >>= 2; r += 2; }\nif((x&1) == 0) ++r;\nreturn r;\n}\n\n//(public) returns index of lowest 1-bit (or -1 if none)\nfunction bnGetLowestSetBit() {\nfor(var i = 0; i < this.t; ++i)\n if(this.data[i] != 0) return i*this.DB+lbit(this.data[i]);\nif(this.s < 0) return this.t*this.DB;\nreturn -1;\n}\n\n//return number of 1 bits in x\nfunction cbit(x) {\nvar r = 0;\nwhile(x != 0) { x &= x-1; ++r; }\nreturn r;\n}\n\n//(public) return number of set bits\nfunction bnBitCount() {\nvar r = 0, x = this.s&this.DM;\nfor(var i = 0; i < this.t; ++i) r += cbit(this.data[i]^x);\nreturn r;\n}\n\n//(public) true iff nth bit is set\nfunction bnTestBit(n) {\nvar j = Math.floor(n/this.DB);\nif(j >= this.t) return(this.s!=0);\nreturn((this.data[j]&(1<<(n%this.DB)))!=0);\n}\n\n//(protected) this op (1<>= this.DB;\n}\nif(a.t < this.t) {\n c += a.s;\n while(i < this.t) {\n c += this.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n} else {\n c += this.s;\n while(i < a.t) {\n c += a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += a.s;\n}\nr.s = (c<0)?-1:0;\nif(c > 0) r.data[i++] = c;\nelse if(c < -1) r.data[i++] = this.DV+c;\nr.t = i;\nr.clamp();\n}\n\n//(public) this + a\nfunction bnAdd(a) { var r = nbi(); this.addTo(a,r); return r; }\n\n//(public) this - a\nfunction bnSubtract(a) { var r = nbi(); this.subTo(a,r); return r; }\n\n//(public) this * a\nfunction bnMultiply(a) { var r = nbi(); this.multiplyTo(a,r); return r; }\n\n//(public) this / a\nfunction bnDivide(a) { var r = nbi(); this.divRemTo(a,r,null); return r; }\n\n//(public) this % a\nfunction bnRemainder(a) { var r = nbi(); this.divRemTo(a,null,r); return r; }\n\n//(public) [this/a,this%a]\nfunction bnDivideAndRemainder(a) {\nvar q = nbi(), r = nbi();\nthis.divRemTo(a,q,r);\nreturn new Array(q,r);\n}\n\n//(protected) this *= n, this >= 0, 1 < n < DV\nfunction bnpDMultiply(n) {\nthis.data[this.t] = this.am(0,n-1,this,0,0,this.t);\n++this.t;\nthis.clamp();\n}\n\n//(protected) this += n << w words, this >= 0\nfunction bnpDAddOffset(n,w) {\nif(n == 0) return;\nwhile(this.t <= w) this.data[this.t++] = 0;\nthis.data[w] += n;\nwhile(this.data[w] >= this.DV) {\n this.data[w] -= this.DV;\n if(++w >= this.t) this.data[this.t++] = 0;\n ++this.data[w];\n}\n}\n\n//A \"null\" reducer\nfunction NullExp() {}\nfunction nNop(x) { return x; }\nfunction nMulTo(x,y,r) { x.multiplyTo(y,r); }\nfunction nSqrTo(x,r) { x.squareTo(r); }\n\nNullExp.prototype.convert = nNop;\nNullExp.prototype.revert = nNop;\nNullExp.prototype.mulTo = nMulTo;\nNullExp.prototype.sqrTo = nSqrTo;\n\n//(public) this^e\nfunction bnPow(e) { return this.exp(e,new NullExp()); }\n\n//(protected) r = lower n words of \"this * a\", a.t <= n\n//\"this\" should be the larger one if appropriate.\nfunction bnpMultiplyLowerTo(a,n,r) {\nvar i = Math.min(this.t+a.t,n);\nr.s = 0; // assumes a,this >= 0\nr.t = i;\nwhile(i > 0) r.data[--i] = 0;\nvar j;\nfor(j = r.t-this.t; i < j; ++i) r.data[i+this.t] = this.am(0,a.data[i],r,i,0,this.t);\nfor(j = Math.min(a.t,n); i < j; ++i) this.am(0,a.data[i],r,i,0,n-i);\nr.clamp();\n}\n\n//(protected) r = \"this * a\" without lower n words, n > 0\n//\"this\" should be the larger one if appropriate.\nfunction bnpMultiplyUpperTo(a,n,r) {\n--n;\nvar i = r.t = this.t+a.t-n;\nr.s = 0; // assumes a,this >= 0\nwhile(--i >= 0) r.data[i] = 0;\nfor(i = Math.max(n-this.t,0); i < a.t; ++i)\n r.data[this.t+i-n] = this.am(n-i,a.data[i],r,0,0,this.t+i-n);\nr.clamp();\nr.drShiftTo(1,r);\n}\n\n//Barrett modular reduction\nfunction Barrett(m) {\n// setup Barrett\nthis.r2 = nbi();\nthis.q3 = nbi();\nBigInteger.ONE.dlShiftTo(2*m.t,this.r2);\nthis.mu = this.r2.divide(m);\nthis.m = m;\n}\n\nfunction barrettConvert(x) {\nif(x.s < 0 || x.t > 2*this.m.t) return x.mod(this.m);\nelse if(x.compareTo(this.m) < 0) return x;\nelse { var r = nbi(); x.copyTo(r); this.reduce(r); return r; }\n}\n\nfunction barrettRevert(x) { return x; }\n\n//x = x mod m (HAC 14.42)\nfunction barrettReduce(x) {\nx.drShiftTo(this.m.t-1,this.r2);\nif(x.t > this.m.t+1) { x.t = this.m.t+1; x.clamp(); }\nthis.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3);\nthis.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);\nwhile(x.compareTo(this.r2) < 0) x.dAddOffset(1,this.m.t+1);\nx.subTo(this.r2,x);\nwhile(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n}\n\n//r = x^2 mod m; x != r\nfunction barrettSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n//r = x*y mod m; x,y != r\nfunction barrettMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\nBarrett.prototype.convert = barrettConvert;\nBarrett.prototype.revert = barrettRevert;\nBarrett.prototype.reduce = barrettReduce;\nBarrett.prototype.mulTo = barrettMulTo;\nBarrett.prototype.sqrTo = barrettSqrTo;\n\n//(public) this^e % m (HAC 14.85)\nfunction bnModPow(e,m) {\nvar i = e.bitLength(), k, r = nbv(1), z;\nif(i <= 0) return r;\nelse if(i < 18) k = 1;\nelse if(i < 48) k = 3;\nelse if(i < 144) k = 4;\nelse if(i < 768) k = 5;\nelse k = 6;\nif(i < 8)\n z = new Classic(m);\nelse if(m.isEven())\n z = new Barrett(m);\nelse\n z = new Montgomery(m);\n\n// precomputation\nvar g = new Array(), n = 3, k1 = k-1, km = (1< 1) {\n var g2 = nbi();\n z.sqrTo(g[1],g2);\n while(n <= km) {\n g[n] = nbi();\n z.mulTo(g2,g[n-2],g[n]);\n n += 2;\n }\n}\n\nvar j = e.t-1, w, is1 = true, r2 = nbi(), t;\ni = nbits(e.data[j])-1;\nwhile(j >= 0) {\n if(i >= k1) w = (e.data[j]>>(i-k1))&km;\n else {\n w = (e.data[j]&((1<<(i+1))-1))<<(k1-i);\n if(j > 0) w |= e.data[j-1]>>(this.DB+i-k1);\n }\n\n n = k;\n while((w&1) == 0) { w >>= 1; --n; }\n if((i -= n) < 0) { i += this.DB; --j; }\n if(is1) { // ret == 1, don't bother squaring or multiplying it\n g[w].copyTo(r);\n is1 = false;\n } else {\n while(n > 1) { z.sqrTo(r,r2); z.sqrTo(r2,r); n -= 2; }\n if(n > 0) z.sqrTo(r,r2); else { t = r; r = r2; r2 = t; }\n z.mulTo(r2,g[w],r);\n }\n\n while(j >= 0 && (e.data[j]&(1< 0) {\n x.rShiftTo(g,x);\n y.rShiftTo(g,y);\n}\nwhile(x.signum() > 0) {\n if((i = x.getLowestSetBit()) > 0) x.rShiftTo(i,x);\n if((i = y.getLowestSetBit()) > 0) y.rShiftTo(i,y);\n if(x.compareTo(y) >= 0) {\n x.subTo(y,x);\n x.rShiftTo(1,x);\n } else {\n y.subTo(x,y);\n y.rShiftTo(1,y);\n }\n}\nif(g > 0) y.lShiftTo(g,y);\nreturn y;\n}\n\n//(protected) this % n, n < 2^26\nfunction bnpModInt(n) {\nif(n <= 0) return 0;\nvar d = this.DV%n, r = (this.s<0)?n-1:0;\nif(this.t > 0)\n if(d == 0) r = this.data[0]%n;\n else for(var i = this.t-1; i >= 0; --i) r = (d*r+this.data[i])%n;\nreturn r;\n}\n\n//(public) 1/this % m (HAC 14.61)\nfunction bnModInverse(m) {\nvar ac = m.isEven();\nif((this.isEven() && ac) || m.signum() == 0) return BigInteger.ZERO;\nvar u = m.clone(), v = this.clone();\nvar a = nbv(1), b = nbv(0), c = nbv(0), d = nbv(1);\nwhile(u.signum() != 0) {\n while(u.isEven()) {\n u.rShiftTo(1,u);\n if(ac) {\n if(!a.isEven() || !b.isEven()) { a.addTo(this,a); b.subTo(m,b); }\n a.rShiftTo(1,a);\n } else if(!b.isEven()) b.subTo(m,b);\n b.rShiftTo(1,b);\n }\n while(v.isEven()) {\n v.rShiftTo(1,v);\n if(ac) {\n if(!c.isEven() || !d.isEven()) { c.addTo(this,c); d.subTo(m,d); }\n c.rShiftTo(1,c);\n } else if(!d.isEven()) d.subTo(m,d);\n d.rShiftTo(1,d);\n }\n if(u.compareTo(v) >= 0) {\n u.subTo(v,u);\n if(ac) a.subTo(c,a);\n b.subTo(d,b);\n } else {\n v.subTo(u,v);\n if(ac) c.subTo(a,c);\n d.subTo(b,d);\n }\n}\nif(v.compareTo(BigInteger.ONE) != 0) return BigInteger.ZERO;\nif(d.compareTo(m) >= 0) return d.subtract(m);\nif(d.signum() < 0) d.addTo(m,d); else return d;\nif(d.signum() < 0) return d.add(m); else return d;\n}\n\nvar lowprimes = [2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509];\nvar lplim = (1<<26)/lowprimes[lowprimes.length-1];\n\n//(public) test primality with certainty >= 1-.5^t\nfunction bnIsProbablePrime(t) {\nvar i, x = this.abs();\nif(x.t == 1 && x.data[0] <= lowprimes[lowprimes.length-1]) {\n for(i = 0; i < lowprimes.length; ++i)\n if(x.data[0] == lowprimes[i]) return true;\n return false;\n}\nif(x.isEven()) return false;\ni = 1;\nwhile(i < lowprimes.length) {\n var m = lowprimes[i], j = i+1;\n while(j < lowprimes.length && m < lplim) m *= lowprimes[j++];\n m = x.modInt(m);\n while(i < j) if(m%lowprimes[i++] == 0) return false;\n}\nreturn x.millerRabin(t);\n}\n\n//(protected) true if probably prime (HAC 4.24, Miller-Rabin)\nfunction bnpMillerRabin(t) {\nvar n1 = this.subtract(BigInteger.ONE);\nvar k = n1.getLowestSetBit();\nif(k <= 0) return false;\nvar r = n1.shiftRight(k);\nvar prng = bnGetPrng();\nvar a;\nfor(var i = 0; i < t; ++i) {\n // select witness 'a' at random from between 1 and n1\n do {\n a = new BigInteger(this.bitLength(), prng);\n }\n while(a.compareTo(BigInteger.ONE) <= 0 || a.compareTo(n1) >= 0);\n var y = a.modPow(r,this);\n if(y.compareTo(BigInteger.ONE) != 0 && y.compareTo(n1) != 0) {\n var j = 1;\n while(j++ < k && y.compareTo(n1) != 0) {\n y = y.modPowInt(2,this);\n if(y.compareTo(BigInteger.ONE) == 0) return false;\n }\n if(y.compareTo(n1) != 0) return false;\n }\n}\nreturn true;\n}\n\n// get pseudo random number generator\nfunction bnGetPrng() {\n // create prng with api that matches BigInteger secure random\n return {\n // x is an array to fill with bytes\n nextBytes: function(x) {\n for(var i = 0; i < x.length; ++i) {\n x[i] = Math.floor(Math.random() * 0x0100);\n }\n }\n };\n}\n\n//protected\nBigInteger.prototype.chunkSize = bnpChunkSize;\nBigInteger.prototype.toRadix = bnpToRadix;\nBigInteger.prototype.fromRadix = bnpFromRadix;\nBigInteger.prototype.fromNumber = bnpFromNumber;\nBigInteger.prototype.bitwiseTo = bnpBitwiseTo;\nBigInteger.prototype.changeBit = bnpChangeBit;\nBigInteger.prototype.addTo = bnpAddTo;\nBigInteger.prototype.dMultiply = bnpDMultiply;\nBigInteger.prototype.dAddOffset = bnpDAddOffset;\nBigInteger.prototype.multiplyLowerTo = bnpMultiplyLowerTo;\nBigInteger.prototype.multiplyUpperTo = bnpMultiplyUpperTo;\nBigInteger.prototype.modInt = bnpModInt;\nBigInteger.prototype.millerRabin = bnpMillerRabin;\n\n//public\nBigInteger.prototype.clone = bnClone;\nBigInteger.prototype.intValue = bnIntValue;\nBigInteger.prototype.byteValue = bnByteValue;\nBigInteger.prototype.shortValue = bnShortValue;\nBigInteger.prototype.signum = bnSigNum;\nBigInteger.prototype.toByteArray = bnToByteArray;\nBigInteger.prototype.equals = bnEquals;\nBigInteger.prototype.min = bnMin;\nBigInteger.prototype.max = bnMax;\nBigInteger.prototype.and = bnAnd;\nBigInteger.prototype.or = bnOr;\nBigInteger.prototype.xor = bnXor;\nBigInteger.prototype.andNot = bnAndNot;\nBigInteger.prototype.not = bnNot;\nBigInteger.prototype.shiftLeft = bnShiftLeft;\nBigInteger.prototype.shiftRight = bnShiftRight;\nBigInteger.prototype.getLowestSetBit = bnGetLowestSetBit;\nBigInteger.prototype.bitCount = bnBitCount;\nBigInteger.prototype.testBit = bnTestBit;\nBigInteger.prototype.setBit = bnSetBit;\nBigInteger.prototype.clearBit = bnClearBit;\nBigInteger.prototype.flipBit = bnFlipBit;\nBigInteger.prototype.add = bnAdd;\nBigInteger.prototype.subtract = bnSubtract;\nBigInteger.prototype.multiply = bnMultiply;\nBigInteger.prototype.divide = bnDivide;\nBigInteger.prototype.remainder = bnRemainder;\nBigInteger.prototype.divideAndRemainder = bnDivideAndRemainder;\nBigInteger.prototype.modPow = bnModPow;\nBigInteger.prototype.modInverse = bnModInverse;\nBigInteger.prototype.pow = bnPow;\nBigInteger.prototype.gcd = bnGCD;\nBigInteger.prototype.isProbablePrime = bnIsProbablePrime;\n\n//BigInteger interfaces not implemented in jsbn:\n\n//BigInteger(int signum, byte[] magnitude)\n//double doubleValue()\n//float floatValue()\n//int hashCode()\n//long longValue()\n//static BigInteger valueOf(long val)\n","/**\n * Partial implementation of PKCS#1 v2.2: RSA-OEAP\n *\n * Modified but based on the following MIT and BSD licensed code:\n *\n * https://github.com/kjur/jsjws/blob/master/rsa.js:\n *\n * The 'jsjws'(JSON Web Signature JavaScript Library) License\n *\n * Copyright (c) 2012 Kenji Urushima\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n *\n * http://webrsa.cvs.sourceforge.net/viewvc/webrsa/Client/RSAES-OAEP.js?content-type=text%2Fplain:\n *\n * RSAES-OAEP.js\n * $Id: RSAES-OAEP.js,v 1.1.1.1 2003/03/19 15:37:20 ellispritchard Exp $\n * JavaScript Implementation of PKCS #1 v2.1 RSA CRYPTOGRAPHY STANDARD (RSA Laboratories, June 14, 2002)\n * Copyright (C) Ellis Pritchard, Guardian Unlimited 2003.\n * Contact: ellis@nukinetics.com\n * Distributed under the BSD License.\n *\n * Official documentation: http://www.rsa.com/rsalabs/node.asp?id=2125\n *\n * @author Evan Jones (http://evanjones.ca/)\n * @author Dave Longley\n *\n * Copyright (c) 2013-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./random');\nrequire('./sha1');\n\n// shortcut for PKCS#1 API\nvar pkcs1 = module.exports = forge.pkcs1 = forge.pkcs1 || {};\n\n/**\n * Encode the given RSAES-OAEP message (M) using key, with optional label (L)\n * and seed.\n *\n * This method does not perform RSA encryption, it only encodes the message\n * using RSAES-OAEP.\n *\n * @param key the RSA key to use.\n * @param message the message to encode.\n * @param options the options to use:\n * label an optional label to use.\n * seed the seed to use.\n * md the message digest object to use, undefined for SHA-1.\n * mgf1 optional mgf1 parameters:\n * md the message digest object to use for MGF1.\n *\n * @return the encoded message bytes.\n */\npkcs1.encode_rsa_oaep = function(key, message, options) {\n // parse arguments\n var label;\n var seed;\n var md;\n var mgf1Md;\n // legacy args (label, seed, md)\n if(typeof options === 'string') {\n label = options;\n seed = arguments[3] || undefined;\n md = arguments[4] || undefined;\n } else if(options) {\n label = options.label || undefined;\n seed = options.seed || undefined;\n md = options.md || undefined;\n if(options.mgf1 && options.mgf1.md) {\n mgf1Md = options.mgf1.md;\n }\n }\n\n // default OAEP to SHA-1 message digest\n if(!md) {\n md = forge.md.sha1.create();\n } else {\n md.start();\n }\n\n // default MGF-1 to same as OAEP\n if(!mgf1Md) {\n mgf1Md = md;\n }\n\n // compute length in bytes and check output\n var keyLength = Math.ceil(key.n.bitLength() / 8);\n var maxLength = keyLength - 2 * md.digestLength - 2;\n if(message.length > maxLength) {\n var error = new Error('RSAES-OAEP input message length is too long.');\n error.length = message.length;\n error.maxLength = maxLength;\n throw error;\n }\n\n if(!label) {\n label = '';\n }\n md.update(label, 'raw');\n var lHash = md.digest();\n\n var PS = '';\n var PS_length = maxLength - message.length;\n for(var i = 0; i < PS_length; i++) {\n PS += '\\x00';\n }\n\n var DB = lHash.getBytes() + PS + '\\x01' + message;\n\n if(!seed) {\n seed = forge.random.getBytes(md.digestLength);\n } else if(seed.length !== md.digestLength) {\n var error = new Error('Invalid RSAES-OAEP seed. The seed length must ' +\n 'match the digest length.');\n error.seedLength = seed.length;\n error.digestLength = md.digestLength;\n throw error;\n }\n\n var dbMask = rsa_mgf1(seed, keyLength - md.digestLength - 1, mgf1Md);\n var maskedDB = forge.util.xorBytes(DB, dbMask, DB.length);\n\n var seedMask = rsa_mgf1(maskedDB, md.digestLength, mgf1Md);\n var maskedSeed = forge.util.xorBytes(seed, seedMask, seed.length);\n\n // return encoded message\n return '\\x00' + maskedSeed + maskedDB;\n};\n\n/**\n * Decode the given RSAES-OAEP encoded message (EM) using key, with optional\n * label (L).\n *\n * This method does not perform RSA decryption, it only decodes the message\n * using RSAES-OAEP.\n *\n * @param key the RSA key to use.\n * @param em the encoded message to decode.\n * @param options the options to use:\n * label an optional label to use.\n * md the message digest object to use for OAEP, undefined for SHA-1.\n * mgf1 optional mgf1 parameters:\n * md the message digest object to use for MGF1.\n *\n * @return the decoded message bytes.\n */\npkcs1.decode_rsa_oaep = function(key, em, options) {\n // parse args\n var label;\n var md;\n var mgf1Md;\n // legacy args\n if(typeof options === 'string') {\n label = options;\n md = arguments[3] || undefined;\n } else if(options) {\n label = options.label || undefined;\n md = options.md || undefined;\n if(options.mgf1 && options.mgf1.md) {\n mgf1Md = options.mgf1.md;\n }\n }\n\n // compute length in bytes\n var keyLength = Math.ceil(key.n.bitLength() / 8);\n\n if(em.length !== keyLength) {\n var error = new Error('RSAES-OAEP encoded message length is invalid.');\n error.length = em.length;\n error.expectedLength = keyLength;\n throw error;\n }\n\n // default OAEP to SHA-1 message digest\n if(md === undefined) {\n md = forge.md.sha1.create();\n } else {\n md.start();\n }\n\n // default MGF-1 to same as OAEP\n if(!mgf1Md) {\n mgf1Md = md;\n }\n\n if(keyLength < 2 * md.digestLength + 2) {\n throw new Error('RSAES-OAEP key is too short for the hash function.');\n }\n\n if(!label) {\n label = '';\n }\n md.update(label, 'raw');\n var lHash = md.digest().getBytes();\n\n // split the message into its parts\n var y = em.charAt(0);\n var maskedSeed = em.substring(1, md.digestLength + 1);\n var maskedDB = em.substring(1 + md.digestLength);\n\n var seedMask = rsa_mgf1(maskedDB, md.digestLength, mgf1Md);\n var seed = forge.util.xorBytes(maskedSeed, seedMask, maskedSeed.length);\n\n var dbMask = rsa_mgf1(seed, keyLength - md.digestLength - 1, mgf1Md);\n var db = forge.util.xorBytes(maskedDB, dbMask, maskedDB.length);\n\n var lHashPrime = db.substring(0, md.digestLength);\n\n // constant time check that all values match what is expected\n var error = (y !== '\\x00');\n\n // constant time check lHash vs lHashPrime\n for(var i = 0; i < md.digestLength; ++i) {\n error |= (lHash.charAt(i) !== lHashPrime.charAt(i));\n }\n\n // \"constant time\" find the 0x1 byte separating the padding (zeros) from the\n // message\n // TODO: It must be possible to do this in a better/smarter way?\n var in_ps = 1;\n var index = md.digestLength;\n for(var j = md.digestLength; j < db.length; j++) {\n var code = db.charCodeAt(j);\n\n var is_0 = (code & 0x1) ^ 0x1;\n\n // non-zero if not 0 or 1 in the ps section\n var error_mask = in_ps ? 0xfffe : 0x0000;\n error |= (code & error_mask);\n\n // latch in_ps to zero after we find 0x1\n in_ps = in_ps & is_0;\n index += in_ps;\n }\n\n if(error || db.charCodeAt(index) !== 0x1) {\n throw new Error('Invalid RSAES-OAEP padding.');\n }\n\n return db.substring(index + 1);\n};\n\nfunction rsa_mgf1(seed, maskLength, hash) {\n // default to SHA-1 message digest\n if(!hash) {\n hash = forge.md.sha1.create();\n }\n var t = '';\n var count = Math.ceil(maskLength / hash.digestLength);\n for(var i = 0; i < count; ++i) {\n var c = String.fromCharCode(\n (i >> 24) & 0xFF, (i >> 16) & 0xFF, (i >> 8) & 0xFF, i & 0xFF);\n hash.start();\n hash.update(seed + c);\n t += hash.digest().getBytes();\n }\n return t.substring(0, maskLength);\n}\n","/**\n * Secure Hash Algorithm with 160-bit digest (SHA-1) implementation.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha1 = module.exports = forge.sha1 = forge.sha1 || {};\nforge.md.sha1 = forge.md.algorithms.sha1 = sha1;\n\n/**\n * Creates a SHA-1 message digest object.\n *\n * @return a message digest object.\n */\nsha1.create = function() {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n // SHA-1 state contains five 32-bit integers\n var _state = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for word storage\n var _w = new Array(80);\n\n // message digest object\n var md = {\n algorithm: 'sha1',\n blockLength: 64,\n digestLength: 20,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 8\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength64 for backwards-compatibility)\n md.fullMessageLength = md.messageLength64 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _state = {\n h0: 0x67452301,\n h1: 0xEFCDAB89,\n h2: 0x98BADCFE,\n h3: 0x10325476,\n h4: 0xC3D2E1F0\n };\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = ((len[1] / 0x100000000) >>> 0);\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_state, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate SHA-1 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 448 mod 512. In other words,\n the data to be digested must be a multiple of 512 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 8 bytes (64\n bits), that means that the last segment of the data must have 56 bytes\n (448 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 448 mod 512 because\n 512 - 128 = 448.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 448 mod 512, then 512 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in big-endian order; since length\n // is stored in bytes we multiply by 8 and add carry from next int\n var next, carry;\n var bits = md.fullMessageLength[0] * 8;\n for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n next = md.fullMessageLength[i + 1] * 8;\n carry = (next / 0x100000000) >>> 0;\n bits += carry;\n finalBlock.putInt32(bits >>> 0);\n bits = next >>> 0;\n }\n finalBlock.putInt32(bits);\n\n var s2 = {\n h0: _state.h0,\n h1: _state.h1,\n h2: _state.h2,\n h3: _state.h3,\n h4: _state.h4\n };\n _update(s2, _w, finalBlock);\n var rval = forge.util.createBuffer();\n rval.putInt32(s2.h0);\n rval.putInt32(s2.h1);\n rval.putInt32(s2.h2);\n rval.putInt32(s2.h3);\n rval.putInt32(s2.h4);\n return rval;\n };\n\n return md;\n};\n\n// sha-1 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 64);\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates a SHA-1 state with the given byte buffer.\n *\n * @param s the SHA-1 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (64 byte) chunks\n var t, a, b, c, d, e, f, i;\n var len = bytes.length();\n while(len >= 64) {\n // the w array will be populated with sixteen 32-bit big-endian words\n // and then extended into 80 32-bit words according to SHA-1 algorithm\n // and for 32-79 using Max Locktyukhin's optimization\n\n // initialize hash value for this chunk\n a = s.h0;\n b = s.h1;\n c = s.h2;\n d = s.h3;\n e = s.h4;\n\n // round 1\n for(i = 0; i < 16; ++i) {\n t = bytes.getInt32();\n w[i] = t;\n f = d ^ (b & (c ^ d));\n t = ((a << 5) | (a >>> 27)) + f + e + 0x5A827999 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n for(; i < 20; ++i) {\n t = (w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16]);\n t = (t << 1) | (t >>> 31);\n w[i] = t;\n f = d ^ (b & (c ^ d));\n t = ((a << 5) | (a >>> 27)) + f + e + 0x5A827999 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n // round 2\n for(; i < 32; ++i) {\n t = (w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16]);\n t = (t << 1) | (t >>> 31);\n w[i] = t;\n f = b ^ c ^ d;\n t = ((a << 5) | (a >>> 27)) + f + e + 0x6ED9EBA1 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n for(; i < 40; ++i) {\n t = (w[i - 6] ^ w[i - 16] ^ w[i - 28] ^ w[i - 32]);\n t = (t << 2) | (t >>> 30);\n w[i] = t;\n f = b ^ c ^ d;\n t = ((a << 5) | (a >>> 27)) + f + e + 0x6ED9EBA1 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n // round 3\n for(; i < 60; ++i) {\n t = (w[i - 6] ^ w[i - 16] ^ w[i - 28] ^ w[i - 32]);\n t = (t << 2) | (t >>> 30);\n w[i] = t;\n f = (b & c) | (d & (b ^ c));\n t = ((a << 5) | (a >>> 27)) + f + e + 0x8F1BBCDC + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n // round 4\n for(; i < 80; ++i) {\n t = (w[i - 6] ^ w[i - 16] ^ w[i - 28] ^ w[i - 32]);\n t = (t << 2) | (t >>> 30);\n w[i] = t;\n f = b ^ c ^ d;\n t = ((a << 5) | (a >>> 27)) + f + e + 0xCA62C1D6 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n\n // update hash state\n s.h0 = (s.h0 + a) | 0;\n s.h1 = (s.h1 + b) | 0;\n s.h2 = (s.h2 + c) | 0;\n s.h3 = (s.h3 + d) | 0;\n s.h4 = (s.h4 + e) | 0;\n\n len -= 64;\n }\n}\n","/**\n * Prime number generation API.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./jsbn');\nrequire('./random');\n\n(function() {\n\n// forge.prime already defined\nif(forge.prime) {\n module.exports = forge.prime;\n return;\n}\n\n/* PRIME API */\nvar prime = module.exports = forge.prime = forge.prime || {};\n\nvar BigInteger = forge.jsbn.BigInteger;\n\n// primes are 30k+i for i = 1, 7, 11, 13, 17, 19, 23, 29\nvar GCD_30_DELTA = [6, 4, 2, 4, 2, 4, 6, 2];\nvar THIRTY = new BigInteger(null);\nTHIRTY.fromInt(30);\nvar op_or = function(x, y) {return x|y;};\n\n/**\n * Generates a random probable prime with the given number of bits.\n *\n * Alternative algorithms can be specified by name as a string or as an\n * object with custom options like so:\n *\n * {\n * name: 'PRIMEINC',\n * options: {\n * maxBlockTime: ,\n * millerRabinTests: ,\n * workerScript: ,\n * workers: .\n * workLoad: the size of the work load, ie: number of possible prime\n * numbers for each web worker to check per work assignment,\n * (default: 100).\n * }\n * }\n *\n * @param bits the number of bits for the prime number.\n * @param options the options to use.\n * [algorithm] the algorithm to use (default: 'PRIMEINC').\n * [prng] a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\".\n *\n * @return callback(err, num) called once the operation completes.\n */\nprime.generateProbablePrime = function(bits, options, callback) {\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n\n // default to PRIMEINC algorithm\n var algorithm = options.algorithm || 'PRIMEINC';\n if(typeof algorithm === 'string') {\n algorithm = {name: algorithm};\n }\n algorithm.options = algorithm.options || {};\n\n // create prng with api that matches BigInteger secure random\n var prng = options.prng || forge.random;\n var rng = {\n // x is an array to fill with bytes\n nextBytes: function(x) {\n var b = prng.getBytesSync(x.length);\n for(var i = 0; i < x.length; ++i) {\n x[i] = b.charCodeAt(i);\n }\n }\n };\n\n if(algorithm.name === 'PRIMEINC') {\n return primeincFindPrime(bits, rng, algorithm.options, callback);\n }\n\n throw new Error('Invalid prime generation algorithm: ' + algorithm.name);\n};\n\nfunction primeincFindPrime(bits, rng, options, callback) {\n if('workers' in options) {\n return primeincFindPrimeWithWorkers(bits, rng, options, callback);\n }\n return primeincFindPrimeWithoutWorkers(bits, rng, options, callback);\n}\n\nfunction primeincFindPrimeWithoutWorkers(bits, rng, options, callback) {\n // initialize random number\n var num = generateRandom(bits, rng);\n\n /* Note: All primes are of the form 30k+i for i < 30 and gcd(30, i)=1. The\n number we are given is always aligned at 30k + 1. Each time the number is\n determined not to be prime we add to get to the next 'i', eg: if the number\n was at 30k + 1 we add 6. */\n var deltaIdx = 0;\n\n // get required number of MR tests\n var mrTests = getMillerRabinTests(num.bitLength());\n if('millerRabinTests' in options) {\n mrTests = options.millerRabinTests;\n }\n\n // find prime nearest to 'num' for maxBlockTime ms\n // 10 ms gives 5ms of leeway for other calculations before dropping\n // below 60fps (1000/60 == 16.67), but in reality, the number will\n // likely be higher due to an 'atomic' big int modPow\n var maxBlockTime = 10;\n if('maxBlockTime' in options) {\n maxBlockTime = options.maxBlockTime;\n }\n\n _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback);\n}\n\nfunction _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback) {\n var start = +new Date();\n do {\n // overflow, regenerate random number\n if(num.bitLength() > bits) {\n num = generateRandom(bits, rng);\n }\n // do primality test\n if(num.isProbablePrime(mrTests)) {\n return callback(null, num);\n }\n // get next potential prime\n num.dAddOffset(GCD_30_DELTA[deltaIdx++ % 8], 0);\n } while(maxBlockTime < 0 || (+new Date() - start < maxBlockTime));\n\n // keep trying later\n forge.util.setImmediate(function() {\n _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback);\n });\n}\n\n// NOTE: This algorithm is indeterminate in nature because workers\n// run in parallel looking at different segments of numbers. Even if this\n// algorithm is run twice with the same input from a predictable RNG, it\n// may produce different outputs.\nfunction primeincFindPrimeWithWorkers(bits, rng, options, callback) {\n // web workers unavailable\n if(typeof Worker === 'undefined') {\n return primeincFindPrimeWithoutWorkers(bits, rng, options, callback);\n }\n\n // initialize random number\n var num = generateRandom(bits, rng);\n\n // use web workers to generate keys\n var numWorkers = options.workers;\n var workLoad = options.workLoad || 100;\n var range = workLoad * 30 / 8;\n var workerScript = options.workerScript || 'forge/prime.worker.js';\n if(numWorkers === -1) {\n return forge.util.estimateCores(function(err, cores) {\n if(err) {\n // default to 2\n cores = 2;\n }\n numWorkers = cores - 1;\n generate();\n });\n }\n generate();\n\n function generate() {\n // require at least 1 worker\n numWorkers = Math.max(1, numWorkers);\n\n // TODO: consider optimizing by starting workers outside getPrime() ...\n // note that in order to clean up they will have to be made internally\n // asynchronous which may actually be slower\n\n // start workers immediately\n var workers = [];\n for(var i = 0; i < numWorkers; ++i) {\n // FIXME: fix path or use blob URLs\n workers[i] = new Worker(workerScript);\n }\n var running = numWorkers;\n\n // listen for requests from workers and assign ranges to find prime\n for(var i = 0; i < numWorkers; ++i) {\n workers[i].addEventListener('message', workerMessage);\n }\n\n /* Note: The distribution of random numbers is unknown. Therefore, each\n web worker is continuously allocated a range of numbers to check for a\n random number until one is found.\n\n Every 30 numbers will be checked just 8 times, because prime numbers\n have the form:\n\n 30k+i, for i < 30 and gcd(30, i)=1 (there are 8 values of i for this)\n\n Therefore, if we want a web worker to run N checks before asking for\n a new range of numbers, each range must contain N*30/8 numbers.\n\n For 100 checks (workLoad), this is a range of 375. */\n\n var found = false;\n function workerMessage(e) {\n // ignore message, prime already found\n if(found) {\n return;\n }\n\n --running;\n var data = e.data;\n if(data.found) {\n // terminate all workers\n for(var i = 0; i < workers.length; ++i) {\n workers[i].terminate();\n }\n found = true;\n return callback(null, new BigInteger(data.prime, 16));\n }\n\n // overflow, regenerate random number\n if(num.bitLength() > bits) {\n num = generateRandom(bits, rng);\n }\n\n // assign new range to check\n var hex = num.toString(16);\n\n // start prime search\n e.target.postMessage({\n hex: hex,\n workLoad: workLoad\n });\n\n num.dAddOffset(range, 0);\n }\n }\n}\n\n/**\n * Generates a random number using the given number of bits and RNG.\n *\n * @param bits the number of bits for the number.\n * @param rng the random number generator to use.\n *\n * @return the random number.\n */\nfunction generateRandom(bits, rng) {\n var num = new BigInteger(bits, rng);\n // force MSB set\n var bits1 = bits - 1;\n if(!num.testBit(bits1)) {\n num.bitwiseTo(BigInteger.ONE.shiftLeft(bits1), op_or, num);\n }\n // align number on 30k+1 boundary\n num.dAddOffset(31 - num.mod(THIRTY).byteValue(), 0);\n return num;\n}\n\n/**\n * Returns the required number of Miller-Rabin tests to generate a\n * prime with an error probability of (1/2)^80.\n *\n * See Handbook of Applied Cryptography Chapter 4, Table 4.4.\n *\n * @param bits the bit size.\n *\n * @return the required number of iterations.\n */\nfunction getMillerRabinTests(bits) {\n if(bits <= 100) return 27;\n if(bits <= 150) return 18;\n if(bits <= 200) return 15;\n if(bits <= 250) return 12;\n if(bits <= 300) return 9;\n if(bits <= 350) return 8;\n if(bits <= 400) return 7;\n if(bits <= 500) return 6;\n if(bits <= 600) return 5;\n if(bits <= 800) return 4;\n if(bits <= 1250) return 3;\n return 2;\n}\n\n})();\n","'use strict'\n\nconst { base64 } = require('multiformats/bases/base64')\nconst ciphers = require('../ciphers/aes-gcm')\n\nmodule.exports = {\n /**\n * Attempts to decrypt a base64 encoded PrivateKey string\n * with the given password. The privateKey must have been exported\n * using the same password and underlying cipher (aes-gcm)\n *\n * @param {string} privateKey - A base64 encoded encrypted key\n * @param {string} password\n * @returns {Promise} The private key protobuf\n */\n import: async function (privateKey, password) {\n const encryptedKey = base64.decode(privateKey)\n const cipher = ciphers.create()\n return await cipher.decrypt(encryptedKey, password)\n }\n}\n","'use strict'\n\nconst { concat } = require('uint8arrays/concat')\nconst { fromString } = require('uint8arrays/from-string')\n\nconst webcrypto = require('../webcrypto')\n\n// Based off of code from https://github.com/luke-park/SecureCompatibleEncryptionExamples\n\n/**\n *\n * @param {object} [options]\n * @param {string} [options.algorithm=AES-GCM]\n * @param {number} [options.nonceLength=12]\n * @param {number} [options.keyLength=16]\n * @param {string} [options.digest=sha256]\n * @param {number} [options.saltLength=16]\n * @param {number} [options.iterations=32767]\n * @returns {*}\n */\nfunction create ({\n algorithm = 'AES-GCM',\n nonceLength = 12,\n keyLength = 16,\n digest = 'SHA-256',\n saltLength = 16,\n iterations = 32767\n} = {}) {\n const crypto = webcrypto.get()\n keyLength *= 8 // Browser crypto uses bits instead of bytes\n\n /**\n * Uses the provided password to derive a pbkdf2 key. The key\n * will then be used to encrypt the data.\n *\n * @param {Uint8Array} data - The data to decrypt\n * @param {string} password - A plain password\n * @returns {Promise}\n */\n async function encrypt (data, password) { // eslint-disable-line require-await\n const salt = crypto.getRandomValues(new Uint8Array(saltLength))\n const nonce = crypto.getRandomValues(new Uint8Array(nonceLength))\n const aesGcm = { name: algorithm, iv: nonce }\n\n // Derive a key using PBKDF2.\n const deriveParams = { name: 'PBKDF2', salt, iterations, hash: { name: digest } }\n const rawKey = await crypto.subtle.importKey('raw', fromString(password), { name: 'PBKDF2' }, false, ['deriveKey', 'deriveBits'])\n const cryptoKey = await crypto.subtle.deriveKey(deriveParams, rawKey, { name: algorithm, length: keyLength }, true, ['encrypt'])\n\n // Encrypt the string.\n const ciphertext = await crypto.subtle.encrypt(aesGcm, cryptoKey, data)\n return concat([salt, aesGcm.iv, new Uint8Array(ciphertext)])\n }\n\n /**\n * Uses the provided password to derive a pbkdf2 key. The key\n * will then be used to decrypt the data. The options used to create\n * this decryption cipher must be the same as those used to create\n * the encryption cipher.\n *\n * @param {Uint8Array} data - The data to decrypt\n * @param {string} password - A plain password\n * @returns {Promise}\n */\n async function decrypt (data, password) {\n const salt = data.slice(0, saltLength)\n const nonce = data.slice(saltLength, saltLength + nonceLength)\n const ciphertext = data.slice(saltLength + nonceLength)\n const aesGcm = { name: algorithm, iv: nonce }\n\n // Derive the key using PBKDF2.\n const deriveParams = { name: 'PBKDF2', salt, iterations, hash: { name: digest } }\n const rawKey = await crypto.subtle.importKey('raw', fromString(password), { name: 'PBKDF2' }, false, ['deriveKey', 'deriveBits'])\n const cryptoKey = await crypto.subtle.deriveKey(deriveParams, rawKey, { name: algorithm, length: keyLength }, true, ['decrypt'])\n\n // Decrypt the string.\n const plaintext = await crypto.subtle.decrypt(aesGcm, cryptoKey, ciphertext)\n return new Uint8Array(plaintext)\n }\n\n return {\n encrypt,\n decrypt\n }\n}\n\nmodule.exports = {\n create\n}\n","/* eslint-env browser */\n\n'use strict'\n\n// Check native crypto exists and is enabled (In insecure context `self.crypto`\n// exists but `self.crypto.subtle` does not).\nexports.get = (win = self) => {\n const nativeCrypto = win.crypto || win.msCrypto\n\n if (!nativeCrypto || !nativeCrypto.subtle) {\n throw Object.assign(\n new Error(\n 'Missing Web Crypto API. ' +\n 'The most likely cause of this error is that this page is being accessed ' +\n 'from an insecure context (i.e. not HTTPS). For more information and ' +\n 'possible resolutions see ' +\n 'https://github.com/libp2p/js-libp2p-crypto/blob/master/README.md#web-crypto-api'\n ),\n { code: 'ERR_MISSING_WEB_CRYPTO' }\n )\n }\n\n return nativeCrypto\n}\n","'use strict'\n\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst errcode = require('err-code')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nrequire('node-forge/lib/sha512')\nrequire('node-forge/lib/ed25519')\nconst forge = require('node-forge/lib/forge')\n\nconst crypto = require('./rsa')\nconst pbm = require('./keys')\nconst exporter = require('./exporter')\n\nclass RsaPublicKey {\n constructor (key) {\n this._key = key\n }\n\n async verify (data, sig) { // eslint-disable-line require-await\n return crypto.hashAndVerify(this._key, sig, data)\n }\n\n marshal () {\n return crypto.utils.jwkToPkix(this._key)\n }\n\n get bytes () {\n return pbm.PublicKey.encode({\n Type: pbm.KeyType.RSA,\n Data: this.marshal()\n }).finish()\n }\n\n encrypt (bytes) {\n return crypto.encrypt(this._key, bytes)\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n}\n\nclass RsaPrivateKey {\n // key - Object of the jwk format\n // publicKey - Uint8Array of the spki format\n constructor (key, publicKey) {\n this._key = key\n this._publicKey = publicKey\n }\n\n genSecret () {\n return crypto.getRandomValues(16)\n }\n\n async sign (message) { // eslint-disable-line require-await\n return crypto.hashAndSign(this._key, message)\n }\n\n get public () {\n if (!this._publicKey) {\n throw errcode(new Error('public key not provided'), 'ERR_PUBKEY_NOT_PROVIDED')\n }\n\n return new RsaPublicKey(this._publicKey)\n }\n\n decrypt (bytes) {\n return crypto.decrypt(this._key, bytes)\n }\n\n marshal () {\n return crypto.utils.jwkToPkcs1(this._key)\n }\n\n get bytes () {\n return pbm.PrivateKey.encode({\n Type: pbm.KeyType.RSA,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n\n /**\n * Gets the ID of the key.\n *\n * The key id is the base58 encoding of the SHA-256 multihash of its public key.\n * The public key is a protobuf encoding containing a type and the DER encoding\n * of the PKCS SubjectPublicKeyInfo.\n *\n * @returns {Promise}\n */\n async id () {\n const hash = await this.public.hash()\n return uint8ArrayToString(hash, 'base58btc')\n }\n\n /**\n * Exports the key into a password protected PEM format\n *\n * @param {string} password - The password to read the encrypted PEM\n * @param {string} [format=pkcs-8] - The format in which to export as\n */\n async export (password, format = 'pkcs-8') { // eslint-disable-line require-await\n if (format === 'pkcs-8') {\n const buffer = new forge.util.ByteBuffer(this.marshal())\n const asn1 = forge.asn1.fromDer(buffer)\n const privateKey = forge.pki.privateKeyFromAsn1(asn1)\n\n const options = {\n algorithm: 'aes256',\n count: 10000,\n saltSize: 128 / 8,\n prfAlgorithm: 'sha512'\n }\n return forge.pki.encryptRsaPrivateKey(privateKey, password, options)\n } else if (format === 'libp2p-key') {\n return exporter.export(this.bytes, password)\n } else {\n throw errcode(new Error(`export format '${format}' is not supported`), 'ERR_INVALID_EXPORT_FORMAT')\n }\n }\n}\n\nasync function unmarshalRsaPrivateKey (bytes) {\n const jwk = crypto.utils.pkcs1ToJwk(bytes)\n const keys = await crypto.unmarshalPrivateKey(jwk)\n return new RsaPrivateKey(keys.privateKey, keys.publicKey)\n}\n\nfunction unmarshalRsaPublicKey (bytes) {\n const jwk = crypto.utils.pkixToJwk(bytes)\n return new RsaPublicKey(jwk)\n}\n\nasync function fromJwk (jwk) {\n const keys = await crypto.unmarshalPrivateKey(jwk)\n return new RsaPrivateKey(keys.privateKey, keys.publicKey)\n}\n\nasync function generateKeyPair (bits) {\n const keys = await crypto.generateKey(bits)\n return new RsaPrivateKey(keys.privateKey, keys.publicKey)\n}\n\nmodule.exports = {\n RsaPublicKey,\n RsaPrivateKey,\n unmarshalRsaPublicKey,\n unmarshalRsaPrivateKey,\n generateKeyPair,\n fromJwk\n}\n","/**\n * Secure Hash Algorithm with a 1024-bit block size implementation.\n *\n * This includes: SHA-512, SHA-384, SHA-512/224, and SHA-512/256. For\n * SHA-256 (block size 512 bits), see sha256.js.\n *\n * See FIPS 180-4 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2014-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha512 = module.exports = forge.sha512 = forge.sha512 || {};\n\n// SHA-512\nforge.md.sha512 = forge.md.algorithms.sha512 = sha512;\n\n// SHA-384\nvar sha384 = forge.sha384 = forge.sha512.sha384 = forge.sha512.sha384 || {};\nsha384.create = function() {\n return sha512.create('SHA-384');\n};\nforge.md.sha384 = forge.md.algorithms.sha384 = sha384;\n\n// SHA-512/256\nforge.sha512.sha256 = forge.sha512.sha256 || {\n create: function() {\n return sha512.create('SHA-512/256');\n }\n};\nforge.md['sha512/256'] = forge.md.algorithms['sha512/256'] =\n forge.sha512.sha256;\n\n// SHA-512/224\nforge.sha512.sha224 = forge.sha512.sha224 || {\n create: function() {\n return sha512.create('SHA-512/224');\n }\n};\nforge.md['sha512/224'] = forge.md.algorithms['sha512/224'] =\n forge.sha512.sha224;\n\n/**\n * Creates a SHA-2 message digest object.\n *\n * @param algorithm the algorithm to use (SHA-512, SHA-384, SHA-512/224,\n * SHA-512/256).\n *\n * @return a message digest object.\n */\nsha512.create = function(algorithm) {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n if(typeof algorithm === 'undefined') {\n algorithm = 'SHA-512';\n }\n\n if(!(algorithm in _states)) {\n throw new Error('Invalid SHA-512 algorithm: ' + algorithm);\n }\n\n // SHA-512 state contains eight 64-bit integers (each as two 32-bit ints)\n var _state = _states[algorithm];\n var _h = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for 64-bit word storage\n var _w = new Array(80);\n for(var wi = 0; wi < 80; ++wi) {\n _w[wi] = new Array(2);\n }\n\n // determine digest length by algorithm name (default)\n var digestLength = 64;\n switch(algorithm) {\n case 'SHA-384':\n digestLength = 48;\n break;\n case 'SHA-512/256':\n digestLength = 32;\n break;\n case 'SHA-512/224':\n digestLength = 28;\n break;\n }\n\n // message digest object\n var md = {\n // SHA-512 => sha512\n algorithm: algorithm.replace('-', '').toLowerCase(),\n blockLength: 128,\n digestLength: digestLength,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 16\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength128 for backwards-compatibility)\n md.fullMessageLength = md.messageLength128 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _h = new Array(_state.length);\n for(var i = 0; i < _state.length; ++i) {\n _h[i] = _state[i].slice(0);\n }\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = ((len[1] / 0x100000000) >>> 0);\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_h, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate SHA-512 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 896 mod 1024. In other words,\n the data to be digested must be a multiple of 1024 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 16 bytes (128\n bits), that means that the last segment of the data must have 112 bytes\n (896 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 896 mod 1024 because\n 1024 - 128 = 896.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 896 mod 1024, then 1024 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in big-endian order; since length\n // is stored in bytes we multiply by 8 and add carry from next int\n var next, carry;\n var bits = md.fullMessageLength[0] * 8;\n for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n next = md.fullMessageLength[i + 1] * 8;\n carry = (next / 0x100000000) >>> 0;\n bits += carry;\n finalBlock.putInt32(bits >>> 0);\n bits = next >>> 0;\n }\n finalBlock.putInt32(bits);\n\n var h = new Array(_h.length);\n for(var i = 0; i < _h.length; ++i) {\n h[i] = _h[i].slice(0);\n }\n _update(h, _w, finalBlock);\n var rval = forge.util.createBuffer();\n var hlen;\n if(algorithm === 'SHA-512') {\n hlen = h.length;\n } else if(algorithm === 'SHA-384') {\n hlen = h.length - 2;\n } else {\n hlen = h.length - 4;\n }\n for(var i = 0; i < hlen; ++i) {\n rval.putInt32(h[i][0]);\n if(i !== hlen - 1 || algorithm !== 'SHA-512/224') {\n rval.putInt32(h[i][1]);\n }\n }\n return rval;\n };\n\n return md;\n};\n\n// sha-512 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n// table of constants\nvar _k = null;\n\n// initial hash states\nvar _states = null;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 128);\n\n // create K table for SHA-512\n _k = [\n [0x428a2f98, 0xd728ae22], [0x71374491, 0x23ef65cd],\n [0xb5c0fbcf, 0xec4d3b2f], [0xe9b5dba5, 0x8189dbbc],\n [0x3956c25b, 0xf348b538], [0x59f111f1, 0xb605d019],\n [0x923f82a4, 0xaf194f9b], [0xab1c5ed5, 0xda6d8118],\n [0xd807aa98, 0xa3030242], [0x12835b01, 0x45706fbe],\n [0x243185be, 0x4ee4b28c], [0x550c7dc3, 0xd5ffb4e2],\n [0x72be5d74, 0xf27b896f], [0x80deb1fe, 0x3b1696b1],\n [0x9bdc06a7, 0x25c71235], [0xc19bf174, 0xcf692694],\n [0xe49b69c1, 0x9ef14ad2], [0xefbe4786, 0x384f25e3],\n [0x0fc19dc6, 0x8b8cd5b5], [0x240ca1cc, 0x77ac9c65],\n [0x2de92c6f, 0x592b0275], [0x4a7484aa, 0x6ea6e483],\n [0x5cb0a9dc, 0xbd41fbd4], [0x76f988da, 0x831153b5],\n [0x983e5152, 0xee66dfab], [0xa831c66d, 0x2db43210],\n [0xb00327c8, 0x98fb213f], [0xbf597fc7, 0xbeef0ee4],\n [0xc6e00bf3, 0x3da88fc2], [0xd5a79147, 0x930aa725],\n [0x06ca6351, 0xe003826f], [0x14292967, 0x0a0e6e70],\n [0x27b70a85, 0x46d22ffc], [0x2e1b2138, 0x5c26c926],\n [0x4d2c6dfc, 0x5ac42aed], [0x53380d13, 0x9d95b3df],\n [0x650a7354, 0x8baf63de], [0x766a0abb, 0x3c77b2a8],\n [0x81c2c92e, 0x47edaee6], [0x92722c85, 0x1482353b],\n [0xa2bfe8a1, 0x4cf10364], [0xa81a664b, 0xbc423001],\n [0xc24b8b70, 0xd0f89791], [0xc76c51a3, 0x0654be30],\n [0xd192e819, 0xd6ef5218], [0xd6990624, 0x5565a910],\n [0xf40e3585, 0x5771202a], [0x106aa070, 0x32bbd1b8],\n [0x19a4c116, 0xb8d2d0c8], [0x1e376c08, 0x5141ab53],\n [0x2748774c, 0xdf8eeb99], [0x34b0bcb5, 0xe19b48a8],\n [0x391c0cb3, 0xc5c95a63], [0x4ed8aa4a, 0xe3418acb],\n [0x5b9cca4f, 0x7763e373], [0x682e6ff3, 0xd6b2b8a3],\n [0x748f82ee, 0x5defb2fc], [0x78a5636f, 0x43172f60],\n [0x84c87814, 0xa1f0ab72], [0x8cc70208, 0x1a6439ec],\n [0x90befffa, 0x23631e28], [0xa4506ceb, 0xde82bde9],\n [0xbef9a3f7, 0xb2c67915], [0xc67178f2, 0xe372532b],\n [0xca273ece, 0xea26619c], [0xd186b8c7, 0x21c0c207],\n [0xeada7dd6, 0xcde0eb1e], [0xf57d4f7f, 0xee6ed178],\n [0x06f067aa, 0x72176fba], [0x0a637dc5, 0xa2c898a6],\n [0x113f9804, 0xbef90dae], [0x1b710b35, 0x131c471b],\n [0x28db77f5, 0x23047d84], [0x32caab7b, 0x40c72493],\n [0x3c9ebe0a, 0x15c9bebc], [0x431d67c4, 0x9c100d4c],\n [0x4cc5d4be, 0xcb3e42b6], [0x597f299c, 0xfc657e2a],\n [0x5fcb6fab, 0x3ad6faec], [0x6c44198c, 0x4a475817]\n ];\n\n // initial hash states\n _states = {};\n _states['SHA-512'] = [\n [0x6a09e667, 0xf3bcc908],\n [0xbb67ae85, 0x84caa73b],\n [0x3c6ef372, 0xfe94f82b],\n [0xa54ff53a, 0x5f1d36f1],\n [0x510e527f, 0xade682d1],\n [0x9b05688c, 0x2b3e6c1f],\n [0x1f83d9ab, 0xfb41bd6b],\n [0x5be0cd19, 0x137e2179]\n ];\n _states['SHA-384'] = [\n [0xcbbb9d5d, 0xc1059ed8],\n [0x629a292a, 0x367cd507],\n [0x9159015a, 0x3070dd17],\n [0x152fecd8, 0xf70e5939],\n [0x67332667, 0xffc00b31],\n [0x8eb44a87, 0x68581511],\n [0xdb0c2e0d, 0x64f98fa7],\n [0x47b5481d, 0xbefa4fa4]\n ];\n _states['SHA-512/256'] = [\n [0x22312194, 0xFC2BF72C],\n [0x9F555FA3, 0xC84C64C2],\n [0x2393B86B, 0x6F53B151],\n [0x96387719, 0x5940EABD],\n [0x96283EE2, 0xA88EFFE3],\n [0xBE5E1E25, 0x53863992],\n [0x2B0199FC, 0x2C85B8AA],\n [0x0EB72DDC, 0x81C52CA2]\n ];\n _states['SHA-512/224'] = [\n [0x8C3D37C8, 0x19544DA2],\n [0x73E19966, 0x89DCD4D6],\n [0x1DFAB7AE, 0x32FF9C82],\n [0x679DD514, 0x582F9FCF],\n [0x0F6D2B69, 0x7BD44DA8],\n [0x77E36F73, 0x04C48942],\n [0x3F9D85A8, 0x6A1D36C8],\n [0x1112E6AD, 0x91D692A1]\n ];\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates a SHA-512 state with the given byte buffer.\n *\n * @param s the SHA-512 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (128 byte) chunks\n var t1_hi, t1_lo;\n var t2_hi, t2_lo;\n var s0_hi, s0_lo;\n var s1_hi, s1_lo;\n var ch_hi, ch_lo;\n var maj_hi, maj_lo;\n var a_hi, a_lo;\n var b_hi, b_lo;\n var c_hi, c_lo;\n var d_hi, d_lo;\n var e_hi, e_lo;\n var f_hi, f_lo;\n var g_hi, g_lo;\n var h_hi, h_lo;\n var i, hi, lo, w2, w7, w15, w16;\n var len = bytes.length();\n while(len >= 128) {\n // the w array will be populated with sixteen 64-bit big-endian words\n // and then extended into 64 64-bit words according to SHA-512\n for(i = 0; i < 16; ++i) {\n w[i][0] = bytes.getInt32() >>> 0;\n w[i][1] = bytes.getInt32() >>> 0;\n }\n for(; i < 80; ++i) {\n // for word 2 words ago: ROTR 19(x) ^ ROTR 61(x) ^ SHR 6(x)\n w2 = w[i - 2];\n hi = w2[0];\n lo = w2[1];\n\n // high bits\n t1_hi = (\n ((hi >>> 19) | (lo << 13)) ^ // ROTR 19\n ((lo >>> 29) | (hi << 3)) ^ // ROTR 61/(swap + ROTR 29)\n (hi >>> 6)) >>> 0; // SHR 6\n // low bits\n t1_lo = (\n ((hi << 13) | (lo >>> 19)) ^ // ROTR 19\n ((lo << 3) | (hi >>> 29)) ^ // ROTR 61/(swap + ROTR 29)\n ((hi << 26) | (lo >>> 6))) >>> 0; // SHR 6\n\n // for word 15 words ago: ROTR 1(x) ^ ROTR 8(x) ^ SHR 7(x)\n w15 = w[i - 15];\n hi = w15[0];\n lo = w15[1];\n\n // high bits\n t2_hi = (\n ((hi >>> 1) | (lo << 31)) ^ // ROTR 1\n ((hi >>> 8) | (lo << 24)) ^ // ROTR 8\n (hi >>> 7)) >>> 0; // SHR 7\n // low bits\n t2_lo = (\n ((hi << 31) | (lo >>> 1)) ^ // ROTR 1\n ((hi << 24) | (lo >>> 8)) ^ // ROTR 8\n ((hi << 25) | (lo >>> 7))) >>> 0; // SHR 7\n\n // sum(t1, word 7 ago, t2, word 16 ago) modulo 2^64 (carry lo overflow)\n w7 = w[i - 7];\n w16 = w[i - 16];\n lo = (t1_lo + w7[1] + t2_lo + w16[1]);\n w[i][0] = (t1_hi + w7[0] + t2_hi + w16[0] +\n ((lo / 0x100000000) >>> 0)) >>> 0;\n w[i][1] = lo >>> 0;\n }\n\n // initialize hash value for this chunk\n a_hi = s[0][0];\n a_lo = s[0][1];\n b_hi = s[1][0];\n b_lo = s[1][1];\n c_hi = s[2][0];\n c_lo = s[2][1];\n d_hi = s[3][0];\n d_lo = s[3][1];\n e_hi = s[4][0];\n e_lo = s[4][1];\n f_hi = s[5][0];\n f_lo = s[5][1];\n g_hi = s[6][0];\n g_lo = s[6][1];\n h_hi = s[7][0];\n h_lo = s[7][1];\n\n // round function\n for(i = 0; i < 80; ++i) {\n // Sum1(e) = ROTR 14(e) ^ ROTR 18(e) ^ ROTR 41(e)\n s1_hi = (\n ((e_hi >>> 14) | (e_lo << 18)) ^ // ROTR 14\n ((e_hi >>> 18) | (e_lo << 14)) ^ // ROTR 18\n ((e_lo >>> 9) | (e_hi << 23))) >>> 0; // ROTR 41/(swap + ROTR 9)\n s1_lo = (\n ((e_hi << 18) | (e_lo >>> 14)) ^ // ROTR 14\n ((e_hi << 14) | (e_lo >>> 18)) ^ // ROTR 18\n ((e_lo << 23) | (e_hi >>> 9))) >>> 0; // ROTR 41/(swap + ROTR 9)\n\n // Ch(e, f, g) (optimized the same way as SHA-1)\n ch_hi = (g_hi ^ (e_hi & (f_hi ^ g_hi))) >>> 0;\n ch_lo = (g_lo ^ (e_lo & (f_lo ^ g_lo))) >>> 0;\n\n // Sum0(a) = ROTR 28(a) ^ ROTR 34(a) ^ ROTR 39(a)\n s0_hi = (\n ((a_hi >>> 28) | (a_lo << 4)) ^ // ROTR 28\n ((a_lo >>> 2) | (a_hi << 30)) ^ // ROTR 34/(swap + ROTR 2)\n ((a_lo >>> 7) | (a_hi << 25))) >>> 0; // ROTR 39/(swap + ROTR 7)\n s0_lo = (\n ((a_hi << 4) | (a_lo >>> 28)) ^ // ROTR 28\n ((a_lo << 30) | (a_hi >>> 2)) ^ // ROTR 34/(swap + ROTR 2)\n ((a_lo << 25) | (a_hi >>> 7))) >>> 0; // ROTR 39/(swap + ROTR 7)\n\n // Maj(a, b, c) (optimized the same way as SHA-1)\n maj_hi = ((a_hi & b_hi) | (c_hi & (a_hi ^ b_hi))) >>> 0;\n maj_lo = ((a_lo & b_lo) | (c_lo & (a_lo ^ b_lo))) >>> 0;\n\n // main algorithm\n // t1 = (h + s1 + ch + _k[i] + _w[i]) modulo 2^64 (carry lo overflow)\n lo = (h_lo + s1_lo + ch_lo + _k[i][1] + w[i][1]);\n t1_hi = (h_hi + s1_hi + ch_hi + _k[i][0] + w[i][0] +\n ((lo / 0x100000000) >>> 0)) >>> 0;\n t1_lo = lo >>> 0;\n\n // t2 = s0 + maj modulo 2^64 (carry lo overflow)\n lo = s0_lo + maj_lo;\n t2_hi = (s0_hi + maj_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n t2_lo = lo >>> 0;\n\n h_hi = g_hi;\n h_lo = g_lo;\n\n g_hi = f_hi;\n g_lo = f_lo;\n\n f_hi = e_hi;\n f_lo = e_lo;\n\n // e = (d + t1) modulo 2^64 (carry lo overflow)\n lo = d_lo + t1_lo;\n e_hi = (d_hi + t1_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n e_lo = lo >>> 0;\n\n d_hi = c_hi;\n d_lo = c_lo;\n\n c_hi = b_hi;\n c_lo = b_lo;\n\n b_hi = a_hi;\n b_lo = a_lo;\n\n // a = (t1 + t2) modulo 2^64 (carry lo overflow)\n lo = t1_lo + t2_lo;\n a_hi = (t1_hi + t2_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n a_lo = lo >>> 0;\n }\n\n // update hash state (additional modulo 2^64)\n lo = s[0][1] + a_lo;\n s[0][0] = (s[0][0] + a_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[0][1] = lo >>> 0;\n\n lo = s[1][1] + b_lo;\n s[1][0] = (s[1][0] + b_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[1][1] = lo >>> 0;\n\n lo = s[2][1] + c_lo;\n s[2][0] = (s[2][0] + c_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[2][1] = lo >>> 0;\n\n lo = s[3][1] + d_lo;\n s[3][0] = (s[3][0] + d_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[3][1] = lo >>> 0;\n\n lo = s[4][1] + e_lo;\n s[4][0] = (s[4][0] + e_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[4][1] = lo >>> 0;\n\n lo = s[5][1] + f_lo;\n s[5][0] = (s[5][0] + f_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[5][1] = lo >>> 0;\n\n lo = s[6][1] + g_lo;\n s[6][0] = (s[6][0] + g_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[6][1] = lo >>> 0;\n\n lo = s[7][1] + h_lo;\n s[7][0] = (s[7][0] + h_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[7][1] = lo >>> 0;\n\n len -= 128;\n }\n}\n","/**\n * JavaScript implementation of Ed25519.\n *\n * Copyright (c) 2017-2019 Digital Bazaar, Inc.\n *\n * This implementation is based on the most excellent TweetNaCl which is\n * in the public domain. Many thanks to its contributors:\n *\n * https://github.com/dchest/tweetnacl-js\n */\nvar forge = require('./forge');\nrequire('./jsbn');\nrequire('./random');\nrequire('./sha512');\nrequire('./util');\nvar asn1Validator = require('./asn1-validator');\nvar publicKeyValidator = asn1Validator.publicKeyValidator;\nvar privateKeyValidator = asn1Validator.privateKeyValidator;\n\nif(typeof BigInteger === 'undefined') {\n var BigInteger = forge.jsbn.BigInteger;\n}\n\nvar ByteBuffer = forge.util.ByteBuffer;\nvar NativeBuffer = typeof Buffer === 'undefined' ? Uint8Array : Buffer;\n\n/*\n * Ed25519 algorithms, see RFC 8032:\n * https://tools.ietf.org/html/rfc8032\n */\nforge.pki = forge.pki || {};\nmodule.exports = forge.pki.ed25519 = forge.ed25519 = forge.ed25519 || {};\nvar ed25519 = forge.ed25519;\n\ned25519.constants = {};\ned25519.constants.PUBLIC_KEY_BYTE_LENGTH = 32;\ned25519.constants.PRIVATE_KEY_BYTE_LENGTH = 64;\ned25519.constants.SEED_BYTE_LENGTH = 32;\ned25519.constants.SIGN_BYTE_LENGTH = 64;\ned25519.constants.HASH_BYTE_LENGTH = 64;\n\ned25519.generateKeyPair = function(options) {\n options = options || {};\n var seed = options.seed;\n if(seed === undefined) {\n // generate seed\n seed = forge.random.getBytesSync(ed25519.constants.SEED_BYTE_LENGTH);\n } else if(typeof seed === 'string') {\n if(seed.length !== ed25519.constants.SEED_BYTE_LENGTH) {\n throw new TypeError(\n '\"seed\" must be ' + ed25519.constants.SEED_BYTE_LENGTH +\n ' bytes in length.');\n }\n } else if(!(seed instanceof Uint8Array)) {\n throw new TypeError(\n '\"seed\" must be a node.js Buffer, Uint8Array, or a binary string.');\n }\n\n seed = messageToNativeBuffer({message: seed, encoding: 'binary'});\n\n var pk = new NativeBuffer(ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n var sk = new NativeBuffer(ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n for(var i = 0; i < 32; ++i) {\n sk[i] = seed[i];\n }\n crypto_sign_keypair(pk, sk);\n return {publicKey: pk, privateKey: sk};\n};\n\n/**\n * Converts a private key from a RFC8410 ASN.1 encoding.\n *\n * @param obj - The asn1 representation of a private key.\n *\n * @returns {Object} keyInfo - The key information.\n * @returns {Buffer|Uint8Array} keyInfo.privateKeyBytes - 32 private key bytes.\n */\ned25519.privateKeyFromAsn1 = function(obj) {\n var capture = {};\n var errors = [];\n var valid = forge.asn1.validate(obj, privateKeyValidator, capture, errors);\n if(!valid) {\n var error = new Error('Invalid Key.');\n error.errors = errors;\n throw error;\n }\n var oid = forge.asn1.derToOid(capture.privateKeyOid);\n var ed25519Oid = forge.oids.EdDSA25519;\n if(oid !== ed25519Oid) {\n throw new Error('Invalid OID \"' + oid + '\"; OID must be \"' +\n ed25519Oid + '\".');\n }\n var privateKey = capture.privateKey;\n // manually extract the private key bytes from nested octet string, see FIXME:\n // https://github.com/digitalbazaar/forge/blob/master/lib/asn1.js#L542\n var privateKeyBytes = messageToNativeBuffer({\n message: forge.asn1.fromDer(privateKey).value,\n encoding: 'binary'\n });\n // TODO: RFC8410 specifies a format for encoding the public key bytes along\n // with the private key bytes. `publicKeyBytes` can be returned in the\n // future. https://tools.ietf.org/html/rfc8410#section-10.3\n return {privateKeyBytes: privateKeyBytes};\n};\n\n/**\n * Converts a public key from a RFC8410 ASN.1 encoding.\n *\n * @param obj - The asn1 representation of a public key.\n *\n * @return {Buffer|Uint8Array} - 32 public key bytes.\n */\ned25519.publicKeyFromAsn1 = function(obj) {\n // get SubjectPublicKeyInfo\n var capture = {};\n var errors = [];\n var valid = forge.asn1.validate(obj, publicKeyValidator, capture, errors);\n if(!valid) {\n var error = new Error('Invalid Key.');\n error.errors = errors;\n throw error;\n }\n var oid = forge.asn1.derToOid(capture.publicKeyOid);\n var ed25519Oid = forge.oids.EdDSA25519;\n if(oid !== ed25519Oid) {\n throw new Error('Invalid OID \"' + oid + '\"; OID must be \"' +\n ed25519Oid + '\".');\n }\n var publicKeyBytes = capture.ed25519PublicKey;\n if(publicKeyBytes.length !== ed25519.constants.PUBLIC_KEY_BYTE_LENGTH) {\n throw new Error('Key length is invalid.');\n }\n return messageToNativeBuffer({\n message: publicKeyBytes,\n encoding: 'binary'\n });\n};\n\ned25519.publicKeyFromPrivateKey = function(options) {\n options = options || {};\n var privateKey = messageToNativeBuffer({\n message: options.privateKey, encoding: 'binary'\n });\n if(privateKey.length !== ed25519.constants.PRIVATE_KEY_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.privateKey\" must have a byte length of ' +\n ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n }\n\n var pk = new NativeBuffer(ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n for(var i = 0; i < pk.length; ++i) {\n pk[i] = privateKey[32 + i];\n }\n return pk;\n};\n\ned25519.sign = function(options) {\n options = options || {};\n var msg = messageToNativeBuffer(options);\n var privateKey = messageToNativeBuffer({\n message: options.privateKey,\n encoding: 'binary'\n });\n if(privateKey.length === ed25519.constants.SEED_BYTE_LENGTH) {\n var keyPair = ed25519.generateKeyPair({seed: privateKey});\n privateKey = keyPair.privateKey;\n } else if(privateKey.length !== ed25519.constants.PRIVATE_KEY_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.privateKey\" must have a byte length of ' +\n ed25519.constants.SEED_BYTE_LENGTH + ' or ' +\n ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n }\n\n var signedMsg = new NativeBuffer(\n ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n crypto_sign(signedMsg, msg, msg.length, privateKey);\n\n var sig = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH);\n for(var i = 0; i < sig.length; ++i) {\n sig[i] = signedMsg[i];\n }\n return sig;\n};\n\ned25519.verify = function(options) {\n options = options || {};\n var msg = messageToNativeBuffer(options);\n if(options.signature === undefined) {\n throw new TypeError(\n '\"options.signature\" must be a node.js Buffer, a Uint8Array, a forge ' +\n 'ByteBuffer, or a binary string.');\n }\n var sig = messageToNativeBuffer({\n message: options.signature,\n encoding: 'binary'\n });\n if(sig.length !== ed25519.constants.SIGN_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.signature\" must have a byte length of ' +\n ed25519.constants.SIGN_BYTE_LENGTH);\n }\n var publicKey = messageToNativeBuffer({\n message: options.publicKey,\n encoding: 'binary'\n });\n if(publicKey.length !== ed25519.constants.PUBLIC_KEY_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.publicKey\" must have a byte length of ' +\n ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n }\n\n var sm = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n var m = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n var i;\n for(i = 0; i < ed25519.constants.SIGN_BYTE_LENGTH; ++i) {\n sm[i] = sig[i];\n }\n for(i = 0; i < msg.length; ++i) {\n sm[i + ed25519.constants.SIGN_BYTE_LENGTH] = msg[i];\n }\n return (crypto_sign_open(m, sm, sm.length, publicKey) >= 0);\n};\n\nfunction messageToNativeBuffer(options) {\n var message = options.message;\n if(message instanceof Uint8Array || message instanceof NativeBuffer) {\n return message;\n }\n\n var encoding = options.encoding;\n if(message === undefined) {\n if(options.md) {\n // TODO: more rigorous validation that `md` is a MessageDigest\n message = options.md.digest().getBytes();\n encoding = 'binary';\n } else {\n throw new TypeError('\"options.message\" or \"options.md\" not specified.');\n }\n }\n\n if(typeof message === 'string' && !encoding) {\n throw new TypeError('\"options.encoding\" must be \"binary\" or \"utf8\".');\n }\n\n if(typeof message === 'string') {\n if(typeof Buffer !== 'undefined') {\n return Buffer.from(message, encoding);\n }\n message = new ByteBuffer(message, encoding);\n } else if(!(message instanceof ByteBuffer)) {\n throw new TypeError(\n '\"options.message\" must be a node.js Buffer, a Uint8Array, a forge ' +\n 'ByteBuffer, or a string with \"options.encoding\" specifying its ' +\n 'encoding.');\n }\n\n // convert to native buffer\n var buffer = new NativeBuffer(message.length());\n for(var i = 0; i < buffer.length; ++i) {\n buffer[i] = message.at(i);\n }\n return buffer;\n}\n\nvar gf0 = gf();\nvar gf1 = gf([1]);\nvar D = gf([\n 0x78a3, 0x1359, 0x4dca, 0x75eb, 0xd8ab, 0x4141, 0x0a4d, 0x0070,\n 0xe898, 0x7779, 0x4079, 0x8cc7, 0xfe73, 0x2b6f, 0x6cee, 0x5203]);\nvar D2 = gf([\n 0xf159, 0x26b2, 0x9b94, 0xebd6, 0xb156, 0x8283, 0x149a, 0x00e0,\n 0xd130, 0xeef3, 0x80f2, 0x198e, 0xfce7, 0x56df, 0xd9dc, 0x2406]);\nvar X = gf([\n 0xd51a, 0x8f25, 0x2d60, 0xc956, 0xa7b2, 0x9525, 0xc760, 0x692c,\n 0xdc5c, 0xfdd6, 0xe231, 0xc0a4, 0x53fe, 0xcd6e, 0x36d3, 0x2169]);\nvar Y = gf([\n 0x6658, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666,\n 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666]);\nvar L = new Float64Array([\n 0xed, 0xd3, 0xf5, 0x5c, 0x1a, 0x63, 0x12, 0x58,\n 0xd6, 0x9c, 0xf7, 0xa2, 0xde, 0xf9, 0xde, 0x14,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x10]);\nvar I = gf([\n 0xa0b0, 0x4a0e, 0x1b27, 0xc4ee, 0xe478, 0xad2f, 0x1806, 0x2f43,\n 0xd7a7, 0x3dfb, 0x0099, 0x2b4d, 0xdf0b, 0x4fc1, 0x2480, 0x2b83]);\n\n// TODO: update forge buffer implementation to use `Buffer` or `Uint8Array`,\n// whichever is available, to improve performance\nfunction sha512(msg, msgLen) {\n // Note: `out` and `msg` are NativeBuffer\n var md = forge.md.sha512.create();\n var buffer = new ByteBuffer(msg);\n md.update(buffer.getBytes(msgLen), 'binary');\n var hash = md.digest().getBytes();\n if(typeof Buffer !== 'undefined') {\n return Buffer.from(hash, 'binary');\n }\n var out = new NativeBuffer(ed25519.constants.HASH_BYTE_LENGTH);\n for(var i = 0; i < 64; ++i) {\n out[i] = hash.charCodeAt(i);\n }\n return out;\n}\n\nfunction crypto_sign_keypair(pk, sk) {\n var p = [gf(), gf(), gf(), gf()];\n var i;\n\n var d = sha512(sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n\n scalarbase(p, d);\n pack(pk, p);\n\n for(i = 0; i < 32; ++i) {\n sk[i + 32] = pk[i];\n }\n return 0;\n}\n\n// Note: difference from C - smlen returned, not passed as argument.\nfunction crypto_sign(sm, m, n, sk) {\n var i, j, x = new Float64Array(64);\n var p = [gf(), gf(), gf(), gf()];\n\n var d = sha512(sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n\n var smlen = n + 64;\n for(i = 0; i < n; ++i) {\n sm[64 + i] = m[i];\n }\n for(i = 0; i < 32; ++i) {\n sm[32 + i] = d[32 + i];\n }\n\n var r = sha512(sm.subarray(32), n + 32);\n reduce(r);\n scalarbase(p, r);\n pack(sm, p);\n\n for(i = 32; i < 64; ++i) {\n sm[i] = sk[i];\n }\n var h = sha512(sm, n + 64);\n reduce(h);\n\n for(i = 32; i < 64; ++i) {\n x[i] = 0;\n }\n for(i = 0; i < 32; ++i) {\n x[i] = r[i];\n }\n for(i = 0; i < 32; ++i) {\n for(j = 0; j < 32; j++) {\n x[i + j] += h[i] * d[j];\n }\n }\n\n modL(sm.subarray(32), x);\n return smlen;\n}\n\nfunction crypto_sign_open(m, sm, n, pk) {\n var i, mlen;\n var t = new NativeBuffer(32);\n var p = [gf(), gf(), gf(), gf()],\n q = [gf(), gf(), gf(), gf()];\n\n mlen = -1;\n if(n < 64) {\n return -1;\n }\n\n if(unpackneg(q, pk)) {\n return -1;\n }\n\n for(i = 0; i < n; ++i) {\n m[i] = sm[i];\n }\n for(i = 0; i < 32; ++i) {\n m[i + 32] = pk[i];\n }\n var h = sha512(m, n);\n reduce(h);\n scalarmult(p, q, h);\n\n scalarbase(q, sm.subarray(32));\n add(p, q);\n pack(t, p);\n\n n -= 64;\n if(crypto_verify_32(sm, 0, t, 0)) {\n for(i = 0; i < n; ++i) {\n m[i] = 0;\n }\n return -1;\n }\n\n for(i = 0; i < n; ++i) {\n m[i] = sm[i + 64];\n }\n mlen = n;\n return mlen;\n}\n\nfunction modL(r, x) {\n var carry, i, j, k;\n for(i = 63; i >= 32; --i) {\n carry = 0;\n for(j = i - 32, k = i - 12; j < k; ++j) {\n x[j] += carry - 16 * x[i] * L[j - (i - 32)];\n carry = (x[j] + 128) >> 8;\n x[j] -= carry * 256;\n }\n x[j] += carry;\n x[i] = 0;\n }\n carry = 0;\n for(j = 0; j < 32; ++j) {\n x[j] += carry - (x[31] >> 4) * L[j];\n carry = x[j] >> 8;\n x[j] &= 255;\n }\n for(j = 0; j < 32; ++j) {\n x[j] -= carry * L[j];\n }\n for(i = 0; i < 32; ++i) {\n x[i + 1] += x[i] >> 8;\n r[i] = x[i] & 255;\n }\n}\n\nfunction reduce(r) {\n var x = new Float64Array(64);\n for(var i = 0; i < 64; ++i) {\n x[i] = r[i];\n r[i] = 0;\n }\n modL(r, x);\n}\n\nfunction add(p, q) {\n var a = gf(), b = gf(), c = gf(),\n d = gf(), e = gf(), f = gf(),\n g = gf(), h = gf(), t = gf();\n\n Z(a, p[1], p[0]);\n Z(t, q[1], q[0]);\n M(a, a, t);\n A(b, p[0], p[1]);\n A(t, q[0], q[1]);\n M(b, b, t);\n M(c, p[3], q[3]);\n M(c, c, D2);\n M(d, p[2], q[2]);\n A(d, d, d);\n Z(e, b, a);\n Z(f, d, c);\n A(g, d, c);\n A(h, b, a);\n\n M(p[0], e, f);\n M(p[1], h, g);\n M(p[2], g, f);\n M(p[3], e, h);\n}\n\nfunction cswap(p, q, b) {\n for(var i = 0; i < 4; ++i) {\n sel25519(p[i], q[i], b);\n }\n}\n\nfunction pack(r, p) {\n var tx = gf(), ty = gf(), zi = gf();\n inv25519(zi, p[2]);\n M(tx, p[0], zi);\n M(ty, p[1], zi);\n pack25519(r, ty);\n r[31] ^= par25519(tx) << 7;\n}\n\nfunction pack25519(o, n) {\n var i, j, b;\n var m = gf(), t = gf();\n for(i = 0; i < 16; ++i) {\n t[i] = n[i];\n }\n car25519(t);\n car25519(t);\n car25519(t);\n for(j = 0; j < 2; ++j) {\n m[0] = t[0] - 0xffed;\n for(i = 1; i < 15; ++i) {\n m[i] = t[i] - 0xffff - ((m[i - 1] >> 16) & 1);\n m[i-1] &= 0xffff;\n }\n m[15] = t[15] - 0x7fff - ((m[14] >> 16) & 1);\n b = (m[15] >> 16) & 1;\n m[14] &= 0xffff;\n sel25519(t, m, 1 - b);\n }\n for (i = 0; i < 16; i++) {\n o[2 * i] = t[i] & 0xff;\n o[2 * i + 1] = t[i] >> 8;\n }\n}\n\nfunction unpackneg(r, p) {\n var t = gf(), chk = gf(), num = gf(),\n den = gf(), den2 = gf(), den4 = gf(),\n den6 = gf();\n\n set25519(r[2], gf1);\n unpack25519(r[1], p);\n S(num, r[1]);\n M(den, num, D);\n Z(num, num, r[2]);\n A(den, r[2], den);\n\n S(den2, den);\n S(den4, den2);\n M(den6, den4, den2);\n M(t, den6, num);\n M(t, t, den);\n\n pow2523(t, t);\n M(t, t, num);\n M(t, t, den);\n M(t, t, den);\n M(r[0], t, den);\n\n S(chk, r[0]);\n M(chk, chk, den);\n if(neq25519(chk, num)) {\n M(r[0], r[0], I);\n }\n\n S(chk, r[0]);\n M(chk, chk, den);\n if(neq25519(chk, num)) {\n return -1;\n }\n\n if(par25519(r[0]) === (p[31] >> 7)) {\n Z(r[0], gf0, r[0]);\n }\n\n M(r[3], r[0], r[1]);\n return 0;\n}\n\nfunction unpack25519(o, n) {\n var i;\n for(i = 0; i < 16; ++i) {\n o[i] = n[2 * i] + (n[2 * i + 1] << 8);\n }\n o[15] &= 0x7fff;\n}\n\nfunction pow2523(o, i) {\n var c = gf();\n var a;\n for(a = 0; a < 16; ++a) {\n c[a] = i[a];\n }\n for(a = 250; a >= 0; --a) {\n S(c, c);\n if(a !== 1) {\n M(c, c, i);\n }\n }\n for(a = 0; a < 16; ++a) {\n o[a] = c[a];\n }\n}\n\nfunction neq25519(a, b) {\n var c = new NativeBuffer(32);\n var d = new NativeBuffer(32);\n pack25519(c, a);\n pack25519(d, b);\n return crypto_verify_32(c, 0, d, 0);\n}\n\nfunction crypto_verify_32(x, xi, y, yi) {\n return vn(x, xi, y, yi, 32);\n}\n\nfunction vn(x, xi, y, yi, n) {\n var i, d = 0;\n for(i = 0; i < n; ++i) {\n d |= x[xi + i] ^ y[yi + i];\n }\n return (1 & ((d - 1) >>> 8)) - 1;\n}\n\nfunction par25519(a) {\n var d = new NativeBuffer(32);\n pack25519(d, a);\n return d[0] & 1;\n}\n\nfunction scalarmult(p, q, s) {\n var b, i;\n set25519(p[0], gf0);\n set25519(p[1], gf1);\n set25519(p[2], gf1);\n set25519(p[3], gf0);\n for(i = 255; i >= 0; --i) {\n b = (s[(i / 8)|0] >> (i & 7)) & 1;\n cswap(p, q, b);\n add(q, p);\n add(p, p);\n cswap(p, q, b);\n }\n}\n\nfunction scalarbase(p, s) {\n var q = [gf(), gf(), gf(), gf()];\n set25519(q[0], X);\n set25519(q[1], Y);\n set25519(q[2], gf1);\n M(q[3], X, Y);\n scalarmult(p, q, s);\n}\n\nfunction set25519(r, a) {\n var i;\n for(i = 0; i < 16; i++) {\n r[i] = a[i] | 0;\n }\n}\n\nfunction inv25519(o, i) {\n var c = gf();\n var a;\n for(a = 0; a < 16; ++a) {\n c[a] = i[a];\n }\n for(a = 253; a >= 0; --a) {\n S(c, c);\n if(a !== 2 && a !== 4) {\n M(c, c, i);\n }\n }\n for(a = 0; a < 16; ++a) {\n o[a] = c[a];\n }\n}\n\nfunction car25519(o) {\n var i, v, c = 1;\n for(i = 0; i < 16; ++i) {\n v = o[i] + c + 65535;\n c = Math.floor(v / 65536);\n o[i] = v - c * 65536;\n }\n o[0] += c - 1 + 37 * (c - 1);\n}\n\nfunction sel25519(p, q, b) {\n var t, c = ~(b - 1);\n for(var i = 0; i < 16; ++i) {\n t = c & (p[i] ^ q[i]);\n p[i] ^= t;\n q[i] ^= t;\n }\n}\n\nfunction gf(init) {\n var i, r = new Float64Array(16);\n if(init) {\n for(i = 0; i < init.length; ++i) {\n r[i] = init[i];\n }\n }\n return r;\n}\n\nfunction A(o, a, b) {\n for(var i = 0; i < 16; ++i) {\n o[i] = a[i] + b[i];\n }\n}\n\nfunction Z(o, a, b) {\n for(var i = 0; i < 16; ++i) {\n o[i] = a[i] - b[i];\n }\n}\n\nfunction S(o, a) {\n M(o, a, a);\n}\n\nfunction M(o, a, b) {\n var v, c,\n t0 = 0, t1 = 0, t2 = 0, t3 = 0, t4 = 0, t5 = 0, t6 = 0, t7 = 0,\n t8 = 0, t9 = 0, t10 = 0, t11 = 0, t12 = 0, t13 = 0, t14 = 0, t15 = 0,\n t16 = 0, t17 = 0, t18 = 0, t19 = 0, t20 = 0, t21 = 0, t22 = 0, t23 = 0,\n t24 = 0, t25 = 0, t26 = 0, t27 = 0, t28 = 0, t29 = 0, t30 = 0,\n b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11],\n b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n\n v = a[0];\n t0 += v * b0;\n t1 += v * b1;\n t2 += v * b2;\n t3 += v * b3;\n t4 += v * b4;\n t5 += v * b5;\n t6 += v * b6;\n t7 += v * b7;\n t8 += v * b8;\n t9 += v * b9;\n t10 += v * b10;\n t11 += v * b11;\n t12 += v * b12;\n t13 += v * b13;\n t14 += v * b14;\n t15 += v * b15;\n v = a[1];\n t1 += v * b0;\n t2 += v * b1;\n t3 += v * b2;\n t4 += v * b3;\n t5 += v * b4;\n t6 += v * b5;\n t7 += v * b6;\n t8 += v * b7;\n t9 += v * b8;\n t10 += v * b9;\n t11 += v * b10;\n t12 += v * b11;\n t13 += v * b12;\n t14 += v * b13;\n t15 += v * b14;\n t16 += v * b15;\n v = a[2];\n t2 += v * b0;\n t3 += v * b1;\n t4 += v * b2;\n t5 += v * b3;\n t6 += v * b4;\n t7 += v * b5;\n t8 += v * b6;\n t9 += v * b7;\n t10 += v * b8;\n t11 += v * b9;\n t12 += v * b10;\n t13 += v * b11;\n t14 += v * b12;\n t15 += v * b13;\n t16 += v * b14;\n t17 += v * b15;\n v = a[3];\n t3 += v * b0;\n t4 += v * b1;\n t5 += v * b2;\n t6 += v * b3;\n t7 += v * b4;\n t8 += v * b5;\n t9 += v * b6;\n t10 += v * b7;\n t11 += v * b8;\n t12 += v * b9;\n t13 += v * b10;\n t14 += v * b11;\n t15 += v * b12;\n t16 += v * b13;\n t17 += v * b14;\n t18 += v * b15;\n v = a[4];\n t4 += v * b0;\n t5 += v * b1;\n t6 += v * b2;\n t7 += v * b3;\n t8 += v * b4;\n t9 += v * b5;\n t10 += v * b6;\n t11 += v * b7;\n t12 += v * b8;\n t13 += v * b9;\n t14 += v * b10;\n t15 += v * b11;\n t16 += v * b12;\n t17 += v * b13;\n t18 += v * b14;\n t19 += v * b15;\n v = a[5];\n t5 += v * b0;\n t6 += v * b1;\n t7 += v * b2;\n t8 += v * b3;\n t9 += v * b4;\n t10 += v * b5;\n t11 += v * b6;\n t12 += v * b7;\n t13 += v * b8;\n t14 += v * b9;\n t15 += v * b10;\n t16 += v * b11;\n t17 += v * b12;\n t18 += v * b13;\n t19 += v * b14;\n t20 += v * b15;\n v = a[6];\n t6 += v * b0;\n t7 += v * b1;\n t8 += v * b2;\n t9 += v * b3;\n t10 += v * b4;\n t11 += v * b5;\n t12 += v * b6;\n t13 += v * b7;\n t14 += v * b8;\n t15 += v * b9;\n t16 += v * b10;\n t17 += v * b11;\n t18 += v * b12;\n t19 += v * b13;\n t20 += v * b14;\n t21 += v * b15;\n v = a[7];\n t7 += v * b0;\n t8 += v * b1;\n t9 += v * b2;\n t10 += v * b3;\n t11 += v * b4;\n t12 += v * b5;\n t13 += v * b6;\n t14 += v * b7;\n t15 += v * b8;\n t16 += v * b9;\n t17 += v * b10;\n t18 += v * b11;\n t19 += v * b12;\n t20 += v * b13;\n t21 += v * b14;\n t22 += v * b15;\n v = a[8];\n t8 += v * b0;\n t9 += v * b1;\n t10 += v * b2;\n t11 += v * b3;\n t12 += v * b4;\n t13 += v * b5;\n t14 += v * b6;\n t15 += v * b7;\n t16 += v * b8;\n t17 += v * b9;\n t18 += v * b10;\n t19 += v * b11;\n t20 += v * b12;\n t21 += v * b13;\n t22 += v * b14;\n t23 += v * b15;\n v = a[9];\n t9 += v * b0;\n t10 += v * b1;\n t11 += v * b2;\n t12 += v * b3;\n t13 += v * b4;\n t14 += v * b5;\n t15 += v * b6;\n t16 += v * b7;\n t17 += v * b8;\n t18 += v * b9;\n t19 += v * b10;\n t20 += v * b11;\n t21 += v * b12;\n t22 += v * b13;\n t23 += v * b14;\n t24 += v * b15;\n v = a[10];\n t10 += v * b0;\n t11 += v * b1;\n t12 += v * b2;\n t13 += v * b3;\n t14 += v * b4;\n t15 += v * b5;\n t16 += v * b6;\n t17 += v * b7;\n t18 += v * b8;\n t19 += v * b9;\n t20 += v * b10;\n t21 += v * b11;\n t22 += v * b12;\n t23 += v * b13;\n t24 += v * b14;\n t25 += v * b15;\n v = a[11];\n t11 += v * b0;\n t12 += v * b1;\n t13 += v * b2;\n t14 += v * b3;\n t15 += v * b4;\n t16 += v * b5;\n t17 += v * b6;\n t18 += v * b7;\n t19 += v * b8;\n t20 += v * b9;\n t21 += v * b10;\n t22 += v * b11;\n t23 += v * b12;\n t24 += v * b13;\n t25 += v * b14;\n t26 += v * b15;\n v = a[12];\n t12 += v * b0;\n t13 += v * b1;\n t14 += v * b2;\n t15 += v * b3;\n t16 += v * b4;\n t17 += v * b5;\n t18 += v * b6;\n t19 += v * b7;\n t20 += v * b8;\n t21 += v * b9;\n t22 += v * b10;\n t23 += v * b11;\n t24 += v * b12;\n t25 += v * b13;\n t26 += v * b14;\n t27 += v * b15;\n v = a[13];\n t13 += v * b0;\n t14 += v * b1;\n t15 += v * b2;\n t16 += v * b3;\n t17 += v * b4;\n t18 += v * b5;\n t19 += v * b6;\n t20 += v * b7;\n t21 += v * b8;\n t22 += v * b9;\n t23 += v * b10;\n t24 += v * b11;\n t25 += v * b12;\n t26 += v * b13;\n t27 += v * b14;\n t28 += v * b15;\n v = a[14];\n t14 += v * b0;\n t15 += v * b1;\n t16 += v * b2;\n t17 += v * b3;\n t18 += v * b4;\n t19 += v * b5;\n t20 += v * b6;\n t21 += v * b7;\n t22 += v * b8;\n t23 += v * b9;\n t24 += v * b10;\n t25 += v * b11;\n t26 += v * b12;\n t27 += v * b13;\n t28 += v * b14;\n t29 += v * b15;\n v = a[15];\n t15 += v * b0;\n t16 += v * b1;\n t17 += v * b2;\n t18 += v * b3;\n t19 += v * b4;\n t20 += v * b5;\n t21 += v * b6;\n t22 += v * b7;\n t23 += v * b8;\n t24 += v * b9;\n t25 += v * b10;\n t26 += v * b11;\n t27 += v * b12;\n t28 += v * b13;\n t29 += v * b14;\n t30 += v * b15;\n\n t0 += 38 * t16;\n t1 += 38 * t17;\n t2 += 38 * t18;\n t3 += 38 * t19;\n t4 += 38 * t20;\n t5 += 38 * t21;\n t6 += 38 * t22;\n t7 += 38 * t23;\n t8 += 38 * t24;\n t9 += 38 * t25;\n t10 += 38 * t26;\n t11 += 38 * t27;\n t12 += 38 * t28;\n t13 += 38 * t29;\n t14 += 38 * t30;\n // t15 left as is\n\n // first car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c-1 + 37 * (c-1);\n\n // second car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c-1 + 37 * (c-1);\n\n o[ 0] = t0;\n o[ 1] = t1;\n o[ 2] = t2;\n o[ 3] = t3;\n o[ 4] = t4;\n o[ 5] = t5;\n o[ 6] = t6;\n o[ 7] = t7;\n o[ 8] = t8;\n o[ 9] = t9;\n o[10] = t10;\n o[11] = t11;\n o[12] = t12;\n o[13] = t13;\n o[14] = t14;\n o[15] = t15;\n}\n","/**\n * Copyright (c) 2019 Digital Bazaar, Inc.\n */\n\nvar forge = require('./forge');\nrequire('./asn1');\nvar asn1 = forge.asn1;\n\nexports.privateKeyValidator = {\n // PrivateKeyInfo\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // Version (INTEGER)\n name: 'PrivateKeyInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyVersion'\n }, {\n // privateKeyAlgorithm\n name: 'PrivateKeyInfo.privateKeyAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'privateKeyOid'\n }]\n }, {\n // PrivateKey\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'privateKey'\n }]\n};\n\nexports.publicKeyValidator = {\n name: 'SubjectPublicKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'subjectPublicKeyInfo',\n value: [{\n name: 'SubjectPublicKeyInfo.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'publicKeyOid'\n }]\n },\n // capture group for ed25519PublicKey\n {\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n composed: true,\n captureBitStringValue: 'ed25519PublicKey'\n }\n // FIXME: this is capture group for rsaPublicKey, use it in this API or\n // discard?\n /* {\n // subjectPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n value: [{\n // RSAPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n captureAsn1: 'rsaPublicKey'\n }]\n } */\n ]\n};\n","'use strict'\n\nconst webcrypto = require('../webcrypto')\nconst randomBytes = require('../random-bytes')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\nexports.utils = require('./rsa-utils')\n\nexports.generateKey = async function (bits) {\n const pair = await webcrypto.get().subtle.generateKey(\n {\n name: 'RSASSA-PKCS1-v1_5',\n modulusLength: bits,\n publicExponent: new Uint8Array([0x01, 0x00, 0x01]),\n hash: { name: 'SHA-256' }\n },\n true,\n ['sign', 'verify']\n )\n\n const keys = await exportKey(pair)\n\n return {\n privateKey: keys[0],\n publicKey: keys[1]\n }\n}\n\n// Takes a jwk key\nexports.unmarshalPrivateKey = async function (key) {\n const privateKey = await webcrypto.get().subtle.importKey(\n 'jwk',\n key,\n {\n name: 'RSASSA-PKCS1-v1_5',\n hash: { name: 'SHA-256' }\n },\n true,\n ['sign']\n )\n\n const pair = [\n privateKey,\n await derivePublicFromPrivate(key)\n ]\n\n const keys = await exportKey({\n privateKey: pair[0],\n publicKey: pair[1]\n })\n\n return {\n privateKey: keys[0],\n publicKey: keys[1]\n }\n}\n\nexports.getRandomValues = randomBytes\n\nexports.hashAndSign = async function (key, msg) {\n const privateKey = await webcrypto.get().subtle.importKey(\n 'jwk',\n key,\n {\n name: 'RSASSA-PKCS1-v1_5',\n hash: { name: 'SHA-256' }\n },\n false,\n ['sign']\n )\n\n const sig = await webcrypto.get().subtle.sign(\n { name: 'RSASSA-PKCS1-v1_5' },\n privateKey,\n Uint8Array.from(msg)\n )\n\n return new Uint8Array(sig, sig.byteOffset, sig.byteLength)\n}\n\nexports.hashAndVerify = async function (key, sig, msg) {\n const publicKey = await webcrypto.get().subtle.importKey(\n 'jwk',\n key,\n {\n name: 'RSASSA-PKCS1-v1_5',\n hash: { name: 'SHA-256' }\n },\n false,\n ['verify']\n )\n\n return webcrypto.get().subtle.verify(\n { name: 'RSASSA-PKCS1-v1_5' },\n publicKey,\n sig,\n msg\n )\n}\n\nfunction exportKey (pair) {\n return Promise.all([\n webcrypto.get().subtle.exportKey('jwk', pair.privateKey),\n webcrypto.get().subtle.exportKey('jwk', pair.publicKey)\n ])\n}\n\nfunction derivePublicFromPrivate (jwKey) {\n return webcrypto.get().subtle.importKey(\n 'jwk',\n {\n kty: jwKey.kty,\n n: jwKey.n,\n e: jwKey.e\n },\n {\n name: 'RSASSA-PKCS1-v1_5',\n hash: { name: 'SHA-256' }\n },\n true,\n ['verify']\n )\n}\n\n/*\n\nRSA encryption/decryption for the browser with webcrypto workarround\n\"bloody dark magic. webcrypto's why.\"\n\nExplanation:\n - Convert JWK to nodeForge\n - Convert msg Uint8Array to nodeForge buffer: ByteBuffer is a \"binary-string backed buffer\", so let's make our Uint8Array a binary string\n - Convert resulting nodeForge buffer to Uint8Array: it returns a binary string, turn that into a Uint8Array\n\n*/\n\nconst { jwk2pub, jwk2priv } = require('./jwk2pem')\n\nfunction convertKey (key, pub, msg, handle) {\n const fkey = pub ? jwk2pub(key) : jwk2priv(key)\n const fmsg = uint8ArrayToString(Uint8Array.from(msg), 'ascii')\n const fomsg = handle(fmsg, fkey)\n return uint8ArrayFromString(fomsg, 'ascii')\n}\n\nexports.encrypt = function (key, msg) {\n return convertKey(key, true, msg, (msg, key) => key.encrypt(msg))\n}\n\nexports.decrypt = function (key, msg) {\n return convertKey(key, false, msg, (msg, key) => key.decrypt(msg))\n}\n","'use strict'\nconst randomBytes = require('iso-random-stream/src/random')\nconst errcode = require('err-code')\n\nmodule.exports = function (length) {\n if (isNaN(length) || length <= 0) {\n throw errcode(new Error('random bytes length must be a Number bigger than 0'), 'ERR_INVALID_LENGTH')\n }\n return randomBytes(length)\n}\n","'use strict'\n\n// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nconst MAX_BYTES = 65536\n\n/**\n * @param {number} size\n */\nfunction randomBytes(size) {\n const bytes = new Uint8Array(size)\n let generated = 0\n\n if (size > 0) {\n // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) {\n while (generated < size) {\n if (generated + MAX_BYTES > size) {\n crypto.getRandomValues(\n bytes.subarray(generated, generated + (size - generated))\n )\n generated += size - generated\n } else {\n crypto.getRandomValues(\n bytes.subarray(generated, generated + MAX_BYTES)\n )\n generated += MAX_BYTES\n }\n }\n } else {\n crypto.getRandomValues(bytes)\n }\n }\n\n return bytes\n}\n\nmodule.exports = randomBytes\n","'use strict'\n\nrequire('node-forge/lib/asn1')\nrequire('node-forge/lib/rsa')\nconst forge = require('node-forge/lib/forge')\nconst { bigIntegerToUintBase64url, base64urlToBigInteger } = require('./../util')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\n// Convert a PKCS#1 in ASN1 DER format to a JWK key\nexports.pkcs1ToJwk = function (bytes) {\n const asn1 = forge.asn1.fromDer(uint8ArrayToString(bytes, 'ascii'))\n const privateKey = forge.pki.privateKeyFromAsn1(asn1)\n\n // https://tools.ietf.org/html/rfc7518#section-6.3.1\n return {\n kty: 'RSA',\n n: bigIntegerToUintBase64url(privateKey.n),\n e: bigIntegerToUintBase64url(privateKey.e),\n d: bigIntegerToUintBase64url(privateKey.d),\n p: bigIntegerToUintBase64url(privateKey.p),\n q: bigIntegerToUintBase64url(privateKey.q),\n dp: bigIntegerToUintBase64url(privateKey.dP),\n dq: bigIntegerToUintBase64url(privateKey.dQ),\n qi: bigIntegerToUintBase64url(privateKey.qInv),\n alg: 'RS256',\n kid: '2011-04-29'\n }\n}\n\n// Convert a JWK key into PKCS#1 in ASN1 DER format\nexports.jwkToPkcs1 = function (jwk) {\n const asn1 = forge.pki.privateKeyToAsn1({\n n: base64urlToBigInteger(jwk.n),\n e: base64urlToBigInteger(jwk.e),\n d: base64urlToBigInteger(jwk.d),\n p: base64urlToBigInteger(jwk.p),\n q: base64urlToBigInteger(jwk.q),\n dP: base64urlToBigInteger(jwk.dp),\n dQ: base64urlToBigInteger(jwk.dq),\n qInv: base64urlToBigInteger(jwk.qi)\n })\n\n return uint8ArrayFromString(forge.asn1.toDer(asn1).getBytes(), 'ascii')\n}\n\n// Convert a PKCIX in ASN1 DER format to a JWK key\nexports.pkixToJwk = function (bytes) {\n const asn1 = forge.asn1.fromDer(uint8ArrayToString(bytes, 'ascii'))\n const publicKey = forge.pki.publicKeyFromAsn1(asn1)\n\n return {\n kty: 'RSA',\n n: bigIntegerToUintBase64url(publicKey.n),\n e: bigIntegerToUintBase64url(publicKey.e),\n alg: 'RS256',\n kid: '2011-04-29'\n }\n}\n\n// Convert a JWK key to PKCIX in ASN1 DER format\nexports.jwkToPkix = function (jwk) {\n const asn1 = forge.pki.publicKeyToAsn1({\n n: base64urlToBigInteger(jwk.n),\n e: base64urlToBigInteger(jwk.e)\n })\n\n return uint8ArrayFromString(forge.asn1.toDer(asn1).getBytes(), 'ascii')\n}\n","'use strict'\n\nrequire('node-forge/lib/util')\nrequire('node-forge/lib/jsbn')\nconst forge = require('node-forge/lib/forge')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\n\nexports.bigIntegerToUintBase64url = (num, len) => {\n // Call `.abs()` to convert to unsigned\n let buf = Uint8Array.from(num.abs().toByteArray()) // toByteArray converts to big endian\n\n // toByteArray() gives us back a signed array, which will include a leading 0\n // byte if the most significant bit of the number is 1:\n // https://docs.microsoft.com/en-us/windows/win32/seccertenroll/about-integer\n // Our number will always be positive so we should remove the leading padding.\n buf = buf[0] === 0 ? buf.slice(1) : buf\n\n if (len != null) {\n if (buf.length > len) throw new Error('byte array longer than desired length')\n buf = uint8ArrayConcat([new Uint8Array(len - buf.length), buf])\n }\n\n return uint8ArrayToString(buf, 'base64url')\n}\n\n// Convert a base64url encoded string to a BigInteger\nexports.base64urlToBigInteger = str => {\n const buf = exports.base64urlToBuffer(str)\n return new forge.jsbn.BigInteger(uint8ArrayToString(buf, 'base16'), 16)\n}\n\nexports.base64urlToBuffer = (str, len) => {\n let buf = uint8ArrayFromString(str, 'base64urlpad')\n\n if (len != null) {\n if (buf.length > len) throw new Error('byte array longer than desired length')\n buf = uint8ArrayConcat([new Uint8Array(len - buf.length), buf])\n }\n\n return buf\n}\n","'use strict'\n\nrequire('node-forge/lib/rsa')\nconst forge = require('node-forge/lib/forge')\nconst { base64urlToBigInteger } = require('../util')\n\nfunction convert (key, types) {\n return types.map(t => base64urlToBigInteger(key[t]))\n}\n\nfunction jwk2priv (key) {\n return forge.pki.setRsaPrivateKey(...convert(key, ['n', 'e', 'd', 'p', 'q', 'dp', 'dq', 'qi']))\n}\n\nfunction jwk2pub (key) {\n return forge.pki.setRsaPublicKey(...convert(key, ['n', 'e']))\n}\n\nmodule.exports = {\n jwk2pub,\n jwk2priv\n}\n","'use strict'\n\nconst { base64 } = require('multiformats/bases/base64')\nconst ciphers = require('../ciphers/aes-gcm')\n\nmodule.exports = {\n /**\n * Exports the given PrivateKey as a base64 encoded string.\n * The PrivateKey is encrypted via a password derived PBKDF2 key\n * leveraging the aes-gcm cipher algorithm.\n *\n * @param {Uint8Array} privateKey - The PrivateKey protobuf\n * @param {string} password\n * @returns {Promise} A base64 encoded string\n */\n export: async function (privateKey, password) {\n const cipher = ciphers.create()\n const encryptedKey = await cipher.encrypt(privateKey, password)\n return base64.encode(encryptedKey)\n }\n}\n","'use strict'\n\nconst errcode = require('err-code')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst { base58btc } = require('multiformats/bases/base58')\nconst { identity } = require('multiformats/hashes/identity')\nconst crypto = require('./ed25519')\nconst pbm = require('./keys')\nconst exporter = require('./exporter')\n\nclass Ed25519PublicKey {\n constructor (key) {\n this._key = ensureKey(key, crypto.publicKeyLength)\n }\n\n async verify (data, sig) { // eslint-disable-line require-await\n return crypto.hashAndVerify(this._key, sig, data)\n }\n\n marshal () {\n return this._key\n }\n\n get bytes () {\n return pbm.PublicKey.encode({\n Type: pbm.KeyType.Ed25519,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n}\n\nclass Ed25519PrivateKey {\n // key - 64 byte Uint8Array containing private key\n // publicKey - 32 byte Uint8Array containing public key\n constructor (key, publicKey) {\n this._key = ensureKey(key, crypto.privateKeyLength)\n this._publicKey = ensureKey(publicKey, crypto.publicKeyLength)\n }\n\n async sign (message) { // eslint-disable-line require-await\n return crypto.hashAndSign(this._key, message)\n }\n\n get public () {\n return new Ed25519PublicKey(this._publicKey)\n }\n\n marshal () {\n return this._key\n }\n\n get bytes () {\n return pbm.PrivateKey.encode({\n Type: pbm.KeyType.Ed25519,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n\n /**\n * Gets the ID of the key.\n *\n * The key id is the base58 encoding of the identity multihash containing its public key.\n * The public key is a protobuf encoding containing a type and the DER encoding\n * of the PKCS SubjectPublicKeyInfo.\n *\n * @returns {Promise}\n */\n async id () {\n const encoding = await identity.digest(this.public.bytes)\n return base58btc.encode(encoding.bytes).substring(1)\n }\n\n /**\n * Exports the key into a password protected `format`\n *\n * @param {string} password - The password to encrypt the key\n * @param {string} [format=libp2p-key] - The format in which to export as\n * @returns {Promise} The encrypted private key\n */\n async export (password, format = 'libp2p-key') { // eslint-disable-line require-await\n if (format === 'libp2p-key') {\n return exporter.export(this.bytes, password)\n } else {\n throw errcode(new Error(`export format '${format}' is not supported`), 'ERR_INVALID_EXPORT_FORMAT')\n }\n }\n}\n\nfunction unmarshalEd25519PrivateKey (bytes) {\n // Try the old, redundant public key version\n if (bytes.length > crypto.privateKeyLength) {\n bytes = ensureKey(bytes, crypto.privateKeyLength + crypto.publicKeyLength)\n const privateKeyBytes = bytes.slice(0, crypto.privateKeyLength)\n const publicKeyBytes = bytes.slice(crypto.privateKeyLength, bytes.length)\n return new Ed25519PrivateKey(privateKeyBytes, publicKeyBytes)\n }\n\n bytes = ensureKey(bytes, crypto.privateKeyLength)\n const privateKeyBytes = bytes.slice(0, crypto.privateKeyLength)\n const publicKeyBytes = bytes.slice(crypto.publicKeyLength)\n return new Ed25519PrivateKey(privateKeyBytes, publicKeyBytes)\n}\n\nfunction unmarshalEd25519PublicKey (bytes) {\n bytes = ensureKey(bytes, crypto.publicKeyLength)\n return new Ed25519PublicKey(bytes)\n}\n\nasync function generateKeyPair () {\n const { privateKey, publicKey } = await crypto.generateKey()\n return new Ed25519PrivateKey(privateKey, publicKey)\n}\n\nasync function generateKeyPairFromSeed (seed) {\n const { privateKey, publicKey } = await crypto.generateKeyFromSeed(seed)\n return new Ed25519PrivateKey(privateKey, publicKey)\n}\n\nfunction ensureKey (key, length) {\n key = Uint8Array.from(key || [])\n if (key.length !== length) {\n throw errcode(new Error(`Key must be a Uint8Array of length ${length}, got ${key.length}`), 'ERR_INVALID_KEY_TYPE')\n }\n return key\n}\n\nmodule.exports = {\n Ed25519PublicKey,\n Ed25519PrivateKey,\n unmarshalEd25519PrivateKey,\n unmarshalEd25519PublicKey,\n generateKeyPair,\n generateKeyPairFromSeed\n}\n","'use strict'\n\nrequire('node-forge/lib/ed25519')\nconst forge = require('node-forge/lib/forge')\nexports.publicKeyLength = forge.pki.ed25519.constants.PUBLIC_KEY_BYTE_LENGTH\nexports.privateKeyLength = forge.pki.ed25519.constants.PRIVATE_KEY_BYTE_LENGTH\n\nexports.generateKey = async function () { // eslint-disable-line require-await\n return forge.pki.ed25519.generateKeyPair()\n}\n\n// seed should be a 32 byte uint8array\nexports.generateKeyFromSeed = async function (seed) { // eslint-disable-line require-await\n return forge.pki.ed25519.generateKeyPair({ seed })\n}\n\nexports.hashAndSign = async function (key, msg) { // eslint-disable-line require-await\n return forge.pki.ed25519.sign({ message: msg, privateKey: key })\n // return Uint8Array.from(nacl.sign.detached(msg, key))\n}\n\nexports.hashAndVerify = async function (key, sig, msg) { // eslint-disable-line require-await\n return forge.pki.ed25519.verify({ signature: sig, message: msg, publicKey: key })\n}\n","'use strict'\n\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst errcode = require('err-code')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst exporter = require('./exporter')\n\nmodule.exports = (keysProtobuf, randomBytes, crypto) => {\n crypto = crypto || require('./secp256k1')(randomBytes)\n\n class Secp256k1PublicKey {\n constructor (key) {\n crypto.validatePublicKey(key)\n this._key = key\n }\n\n verify (data, sig) {\n return crypto.hashAndVerify(this._key, sig, data)\n }\n\n marshal () {\n return crypto.compressPublicKey(this._key)\n }\n\n get bytes () {\n return keysProtobuf.PublicKey.encode({\n Type: keysProtobuf.KeyType.Secp256k1,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n }\n\n class Secp256k1PrivateKey {\n constructor (key, publicKey) {\n this._key = key\n this._publicKey = publicKey || crypto.computePublicKey(key)\n crypto.validatePrivateKey(this._key)\n crypto.validatePublicKey(this._publicKey)\n }\n\n sign (message) {\n return crypto.hashAndSign(this._key, message)\n }\n\n get public () {\n return new Secp256k1PublicKey(this._publicKey)\n }\n\n marshal () {\n return this._key\n }\n\n get bytes () {\n return keysProtobuf.PrivateKey.encode({\n Type: keysProtobuf.KeyType.Secp256k1,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n\n /**\n * Gets the ID of the key.\n *\n * The key id is the base58 encoding of the SHA-256 multihash of its public key.\n * The public key is a protobuf encoding containing a type and the DER encoding\n * of the PKCS SubjectPublicKeyInfo.\n *\n * @returns {Promise}\n */\n async id () {\n const hash = await this.public.hash()\n return uint8ArrayToString(hash, 'base58btc')\n }\n\n /**\n * Exports the key into a password protected `format`\n *\n * @param {string} password - The password to encrypt the key\n * @param {string} [format=libp2p-key] - The format in which to export as\n * @returns {Promise} The encrypted private key\n */\n async export (password, format = 'libp2p-key') { // eslint-disable-line require-await\n if (format === 'libp2p-key') {\n return exporter.export(this.bytes, password)\n } else {\n throw errcode(new Error(`export format '${format}' is not supported`), 'ERR_INVALID_EXPORT_FORMAT')\n }\n }\n }\n\n function unmarshalSecp256k1PrivateKey (bytes) {\n return new Secp256k1PrivateKey(bytes)\n }\n\n function unmarshalSecp256k1PublicKey (bytes) {\n return new Secp256k1PublicKey(bytes)\n }\n\n async function generateKeyPair () {\n const privateKeyBytes = await crypto.generateKey()\n return new Secp256k1PrivateKey(privateKeyBytes)\n }\n\n return {\n Secp256k1PublicKey,\n Secp256k1PrivateKey,\n unmarshalSecp256k1PrivateKey,\n unmarshalSecp256k1PublicKey,\n generateKeyPair\n }\n}\n","'use strict'\n\nconst secp256k1 = require('secp256k1')\nconst { sha256 } = require('multiformats/hashes/sha2')\n\nmodule.exports = (randomBytes) => {\n const privateKeyLength = 32\n\n function generateKey () {\n let privateKey\n do {\n privateKey = randomBytes(32)\n } while (!secp256k1.privateKeyVerify(privateKey))\n return privateKey\n }\n\n async function hashAndSign (key, msg) {\n const { digest } = await sha256.digest(msg)\n const sig = secp256k1.ecdsaSign(digest, key)\n return secp256k1.signatureExport(sig.signature)\n }\n\n async function hashAndVerify (key, sig, msg) {\n const { digest } = await sha256.digest(msg)\n sig = secp256k1.signatureImport(sig)\n return secp256k1.ecdsaVerify(sig, digest, key)\n }\n\n function compressPublicKey (key) {\n if (!secp256k1.publicKeyVerify(key)) {\n throw new Error('Invalid public key')\n }\n return secp256k1.publicKeyConvert(key, true)\n }\n\n function decompressPublicKey (key) {\n return secp256k1.publicKeyConvert(key, false)\n }\n\n function validatePrivateKey (key) {\n if (!secp256k1.privateKeyVerify(key)) {\n throw new Error('Invalid private key')\n }\n }\n\n function validatePublicKey (key) {\n if (!secp256k1.publicKeyVerify(key)) {\n throw new Error('Invalid public key')\n }\n }\n\n function computePublicKey (privateKey) {\n validatePrivateKey(privateKey)\n return secp256k1.publicKeyCreate(privateKey)\n }\n\n return {\n generateKey,\n privateKeyLength,\n hashAndSign,\n hashAndVerify,\n compressPublicKey,\n decompressPublicKey,\n validatePrivateKey,\n validatePublicKey,\n computePublicKey\n }\n}\n","module.exports = require('./lib')(require('./lib/elliptic'))\n","const errors = {\n IMPOSSIBLE_CASE: 'Impossible case. Please create issue.',\n TWEAK_ADD:\n 'The tweak was out of range or the resulted private key is invalid',\n TWEAK_MUL: 'The tweak was out of range or equal to zero',\n CONTEXT_RANDOMIZE_UNKNOW: 'Unknow error on context randomization',\n SECKEY_INVALID: 'Private Key is invalid',\n PUBKEY_PARSE: 'Public Key could not be parsed',\n PUBKEY_SERIALIZE: 'Public Key serialization error',\n PUBKEY_COMBINE: 'The sum of the public keys is not valid',\n SIG_PARSE: 'Signature could not be parsed',\n SIGN: 'The nonce generation function failed, or the private key was invalid',\n RECOVER: 'Public key could not be recover',\n ECDH: 'Scalar was invalid (zero or overflow)'\n}\n\nfunction assert (cond, msg) {\n if (!cond) throw new Error(msg)\n}\n\nfunction isUint8Array (name, value, length) {\n assert(value instanceof Uint8Array, `Expected ${name} to be an Uint8Array`)\n\n if (length !== undefined) {\n if (Array.isArray(length)) {\n const numbers = length.join(', ')\n const msg = `Expected ${name} to be an Uint8Array with length [${numbers}]`\n assert(length.includes(value.length), msg)\n } else {\n const msg = `Expected ${name} to be an Uint8Array with length ${length}`\n assert(value.length === length, msg)\n }\n }\n}\n\nfunction isCompressed (value) {\n assert(toTypeString(value) === 'Boolean', 'Expected compressed to be a Boolean')\n}\n\nfunction getAssertedOutput (output = (len) => new Uint8Array(len), length) {\n if (typeof output === 'function') output = output(length)\n isUint8Array('output', output, length)\n return output\n}\n\nfunction toTypeString (value) {\n return Object.prototype.toString.call(value).slice(8, -1)\n}\n\nmodule.exports = (secp256k1) => {\n return {\n contextRandomize (seed) {\n assert(\n seed === null || seed instanceof Uint8Array,\n 'Expected seed to be an Uint8Array or null'\n )\n if (seed !== null) isUint8Array('seed', seed, 32)\n\n switch (secp256k1.contextRandomize(seed)) {\n case 1:\n throw new Error(errors.CONTEXT_RANDOMIZE_UNKNOW)\n }\n },\n\n privateKeyVerify (seckey) {\n isUint8Array('private key', seckey, 32)\n\n return secp256k1.privateKeyVerify(seckey) === 0\n },\n\n privateKeyNegate (seckey) {\n isUint8Array('private key', seckey, 32)\n\n switch (secp256k1.privateKeyNegate(seckey)) {\n case 0:\n return seckey\n case 1:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n privateKeyTweakAdd (seckey, tweak) {\n isUint8Array('private key', seckey, 32)\n isUint8Array('tweak', tweak, 32)\n\n switch (secp256k1.privateKeyTweakAdd(seckey, tweak)) {\n case 0:\n return seckey\n case 1:\n throw new Error(errors.TWEAK_ADD)\n }\n },\n\n privateKeyTweakMul (seckey, tweak) {\n isUint8Array('private key', seckey, 32)\n isUint8Array('tweak', tweak, 32)\n\n switch (secp256k1.privateKeyTweakMul(seckey, tweak)) {\n case 0:\n return seckey\n case 1:\n throw new Error(errors.TWEAK_MUL)\n }\n },\n\n publicKeyVerify (pubkey) {\n isUint8Array('public key', pubkey, [33, 65])\n\n return secp256k1.publicKeyVerify(pubkey) === 0\n },\n\n publicKeyCreate (seckey, compressed = true, output) {\n isUint8Array('private key', seckey, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyCreate(output, seckey)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.SECKEY_INVALID)\n case 2:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyConvert (pubkey, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyConvert(output, pubkey)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyNegate (pubkey, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyNegate(output, pubkey)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n case 3:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyCombine (pubkeys, compressed = true, output) {\n assert(Array.isArray(pubkeys), 'Expected public keys to be an Array')\n assert(pubkeys.length > 0, 'Expected public keys array will have more than zero items')\n for (const pubkey of pubkeys) {\n isUint8Array('public key', pubkey, [33, 65])\n }\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyCombine(output, pubkeys)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.PUBKEY_COMBINE)\n case 3:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyTweakAdd (pubkey, tweak, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isUint8Array('tweak', tweak, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyTweakAdd(output, pubkey, tweak)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.TWEAK_ADD)\n }\n },\n\n publicKeyTweakMul (pubkey, tweak, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isUint8Array('tweak', tweak, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyTweakMul(output, pubkey, tweak)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.TWEAK_MUL)\n }\n },\n\n signatureNormalize (sig) {\n isUint8Array('signature', sig, 64)\n\n switch (secp256k1.signatureNormalize(sig)) {\n case 0:\n return sig\n case 1:\n throw new Error(errors.SIG_PARSE)\n }\n },\n\n signatureExport (sig, output) {\n isUint8Array('signature', sig, 64)\n output = getAssertedOutput(output, 72)\n\n const obj = { output, outputlen: 72 }\n switch (secp256k1.signatureExport(obj, sig)) {\n case 0:\n return output.slice(0, obj.outputlen)\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n signatureImport (sig, output) {\n isUint8Array('signature', sig)\n output = getAssertedOutput(output, 64)\n\n switch (secp256k1.signatureImport(output, sig)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n ecdsaSign (msg32, seckey, options = {}, output) {\n isUint8Array('message', msg32, 32)\n isUint8Array('private key', seckey, 32)\n assert(toTypeString(options) === 'Object', 'Expected options to be an Object')\n if (options.data !== undefined) isUint8Array('options.data', options.data)\n if (options.noncefn !== undefined) assert(toTypeString(options.noncefn) === 'Function', 'Expected options.noncefn to be a Function')\n output = getAssertedOutput(output, 64)\n\n const obj = { signature: output, recid: null }\n switch (secp256k1.ecdsaSign(obj, msg32, seckey, options.data, options.noncefn)) {\n case 0:\n return obj\n case 1:\n throw new Error(errors.SIGN)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n ecdsaVerify (sig, msg32, pubkey) {\n isUint8Array('signature', sig, 64)\n isUint8Array('message', msg32, 32)\n isUint8Array('public key', pubkey, [33, 65])\n\n switch (secp256k1.ecdsaVerify(sig, msg32, pubkey)) {\n case 0:\n return true\n case 3:\n return false\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.PUBKEY_PARSE)\n }\n },\n\n ecdsaRecover (sig, recid, msg32, compressed = true, output) {\n isUint8Array('signature', sig, 64)\n assert(\n toTypeString(recid) === 'Number' &&\n recid >= 0 &&\n recid <= 3,\n 'Expected recovery id to be a Number within interval [0, 3]'\n )\n isUint8Array('message', msg32, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.ecdsaRecover(output, sig, recid, msg32)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.RECOVER)\n case 3:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n ecdh (pubkey, seckey, options = {}, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isUint8Array('private key', seckey, 32)\n assert(toTypeString(options) === 'Object', 'Expected options to be an Object')\n if (options.data !== undefined) isUint8Array('options.data', options.data)\n if (options.hashfn !== undefined) {\n assert(toTypeString(options.hashfn) === 'Function', 'Expected options.hashfn to be a Function')\n if (options.xbuf !== undefined) isUint8Array('options.xbuf', options.xbuf, 32)\n if (options.ybuf !== undefined) isUint8Array('options.ybuf', options.ybuf, 32)\n isUint8Array('output', output)\n } else {\n output = getAssertedOutput(output, 32)\n }\n\n switch (secp256k1.ecdh(output, pubkey, seckey, options.data, options.hashfn, options.xbuf, options.ybuf)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.ECDH)\n }\n }\n }\n}\n","const EC = require('elliptic').ec\n\nconst ec = new EC('secp256k1')\nconst ecparams = ec.curve\n\n// Hack, we can not use bn.js@5, while elliptic uses bn.js@4\n// See https://github.com/indutny/elliptic/issues/191#issuecomment-569888758\nconst BN = ecparams.n.constructor\n\nfunction loadCompressedPublicKey (first, xbuf) {\n let x = new BN(xbuf)\n\n // overflow\n if (x.cmp(ecparams.p) >= 0) return null\n x = x.toRed(ecparams.red)\n\n // compute corresponding Y\n let y = x.redSqr().redIMul(x).redIAdd(ecparams.b).redSqrt()\n if ((first === 0x03) !== y.isOdd()) y = y.redNeg()\n\n return ec.keyPair({ pub: { x: x, y: y } })\n}\n\nfunction loadUncompressedPublicKey (first, xbuf, ybuf) {\n let x = new BN(xbuf)\n let y = new BN(ybuf)\n\n // overflow\n if (x.cmp(ecparams.p) >= 0 || y.cmp(ecparams.p) >= 0) return null\n\n x = x.toRed(ecparams.red)\n y = y.toRed(ecparams.red)\n\n // is odd flag\n if ((first === 0x06 || first === 0x07) && y.isOdd() !== (first === 0x07)) return null\n\n // x*x*x + b = y*y\n const x3 = x.redSqr().redIMul(x)\n if (!y.redSqr().redISub(x3.redIAdd(ecparams.b)).isZero()) return null\n\n return ec.keyPair({ pub: { x: x, y: y } })\n}\n\nfunction loadPublicKey (pubkey) {\n // length should be validated in interface\n const first = pubkey[0]\n switch (first) {\n case 0x02:\n case 0x03:\n if (pubkey.length !== 33) return null\n return loadCompressedPublicKey(first, pubkey.subarray(1, 33))\n case 0x04:\n case 0x06:\n case 0x07:\n if (pubkey.length !== 65) return null\n return loadUncompressedPublicKey(first, pubkey.subarray(1, 33), pubkey.subarray(33, 65))\n default:\n return null\n }\n}\n\nfunction savePublicKey (output, point) {\n const pubkey = point.encode(null, output.length === 33)\n // Loop should be faster because we do not need create extra Uint8Array\n // output.set(new Uint8Array(pubkey))\n for (let i = 0; i < output.length; ++i) output[i] = pubkey[i]\n}\n\nmodule.exports = {\n contextRandomize () {\n return 0\n },\n\n privateKeyVerify (seckey) {\n const bn = new BN(seckey)\n return bn.cmp(ecparams.n) < 0 && !bn.isZero() ? 0 : 1\n },\n\n privateKeyNegate (seckey) {\n const bn = new BN(seckey)\n const negate = ecparams.n.sub(bn).umod(ecparams.n).toArrayLike(Uint8Array, 'be', 32)\n seckey.set(negate)\n return 0\n },\n\n privateKeyTweakAdd (seckey, tweak) {\n const bn = new BN(tweak)\n if (bn.cmp(ecparams.n) >= 0) return 1\n\n bn.iadd(new BN(seckey))\n if (bn.cmp(ecparams.n) >= 0) bn.isub(ecparams.n)\n if (bn.isZero()) return 1\n\n const tweaked = bn.toArrayLike(Uint8Array, 'be', 32)\n seckey.set(tweaked)\n\n return 0\n },\n\n privateKeyTweakMul (seckey, tweak) {\n let bn = new BN(tweak)\n if (bn.cmp(ecparams.n) >= 0 || bn.isZero()) return 1\n\n bn.imul(new BN(seckey))\n if (bn.cmp(ecparams.n) >= 0) bn = bn.umod(ecparams.n)\n\n const tweaked = bn.toArrayLike(Uint8Array, 'be', 32)\n seckey.set(tweaked)\n\n return 0\n },\n\n publicKeyVerify (pubkey) {\n const pair = loadPublicKey(pubkey)\n return pair === null ? 1 : 0\n },\n\n publicKeyCreate (output, seckey) {\n const bn = new BN(seckey)\n if (bn.cmp(ecparams.n) >= 0 || bn.isZero()) return 1\n\n const point = ec.keyFromPrivate(seckey).getPublic()\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyConvert (output, pubkey) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n const point = pair.getPublic()\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyNegate (output, pubkey) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n const point = pair.getPublic()\n point.y = point.y.redNeg()\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyCombine (output, pubkeys) {\n const pairs = new Array(pubkeys.length)\n for (let i = 0; i < pubkeys.length; ++i) {\n pairs[i] = loadPublicKey(pubkeys[i])\n if (pairs[i] === null) return 1\n }\n\n let point = pairs[0].getPublic()\n for (let i = 1; i < pairs.length; ++i) point = point.add(pairs[i].pub)\n if (point.isInfinity()) return 2\n\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyTweakAdd (output, pubkey, tweak) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n tweak = new BN(tweak)\n if (tweak.cmp(ecparams.n) >= 0) return 2\n\n const point = pair.getPublic().add(ecparams.g.mul(tweak))\n if (point.isInfinity()) return 2\n\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyTweakMul (output, pubkey, tweak) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n tweak = new BN(tweak)\n if (tweak.cmp(ecparams.n) >= 0 || tweak.isZero()) return 2\n\n const point = pair.getPublic().mul(tweak)\n savePublicKey(output, point)\n\n return 0\n },\n\n signatureNormalize (sig) {\n const r = new BN(sig.subarray(0, 32))\n const s = new BN(sig.subarray(32, 64))\n if (r.cmp(ecparams.n) >= 0 || s.cmp(ecparams.n) >= 0) return 1\n\n if (s.cmp(ec.nh) === 1) {\n sig.set(ecparams.n.sub(s).toArrayLike(Uint8Array, 'be', 32), 32)\n }\n\n return 0\n },\n\n // Copied 1-to-1 from https://github.com/bitcoinjs/bip66/blob/master/index.js\n // Adapted for Uint8Array instead Buffer\n signatureExport (obj, sig) {\n const sigR = sig.subarray(0, 32)\n const sigS = sig.subarray(32, 64)\n if (new BN(sigR).cmp(ecparams.n) >= 0) return 1\n if (new BN(sigS).cmp(ecparams.n) >= 0) return 1\n\n const { output } = obj\n\n // Prepare R\n let r = output.subarray(4, 4 + 33)\n r[0] = 0x00\n r.set(sigR, 1)\n\n let lenR = 33\n let posR = 0\n for (; lenR > 1 && r[posR] === 0x00 && !(r[posR + 1] & 0x80); --lenR, ++posR);\n\n r = r.subarray(posR)\n if (r[0] & 0x80) return 1\n if (lenR > 1 && (r[0] === 0x00) && !(r[1] & 0x80)) return 1\n\n // Prepare S\n let s = output.subarray(6 + 33, 6 + 33 + 33)\n s[0] = 0x00\n s.set(sigS, 1)\n\n let lenS = 33\n let posS = 0\n for (; lenS > 1 && s[posS] === 0x00 && !(s[posS + 1] & 0x80); --lenS, ++posS);\n\n s = s.subarray(posS)\n if (s[0] & 0x80) return 1\n if (lenS > 1 && (s[0] === 0x00) && !(s[1] & 0x80)) return 1\n\n // Set output length for return\n obj.outputlen = 6 + lenR + lenS\n\n // Output in specified format\n // 0x30 [total-length] 0x02 [R-length] [R] 0x02 [S-length] [S]\n output[0] = 0x30\n output[1] = obj.outputlen - 2\n output[2] = 0x02\n output[3] = r.length\n output.set(r, 4)\n output[4 + lenR] = 0x02\n output[5 + lenR] = s.length\n output.set(s, 6 + lenR)\n\n return 0\n },\n\n // Copied 1-to-1 from https://github.com/bitcoinjs/bip66/blob/master/index.js\n // Adapted for Uint8Array instead Buffer\n signatureImport (output, sig) {\n if (sig.length < 8) return 1\n if (sig.length > 72) return 1\n if (sig[0] !== 0x30) return 1\n if (sig[1] !== sig.length - 2) return 1\n if (sig[2] !== 0x02) return 1\n\n const lenR = sig[3]\n if (lenR === 0) return 1\n if (5 + lenR >= sig.length) return 1\n if (sig[4 + lenR] !== 0x02) return 1\n\n const lenS = sig[5 + lenR]\n if (lenS === 0) return 1\n if ((6 + lenR + lenS) !== sig.length) return 1\n\n if (sig[4] & 0x80) return 1\n if (lenR > 1 && (sig[4] === 0x00) && !(sig[5] & 0x80)) return 1\n\n if (sig[lenR + 6] & 0x80) return 1\n if (lenS > 1 && (sig[lenR + 6] === 0x00) && !(sig[lenR + 7] & 0x80)) return 1\n\n let sigR = sig.subarray(4, 4 + lenR)\n if (sigR.length === 33 && sigR[0] === 0x00) sigR = sigR.subarray(1)\n if (sigR.length > 32) return 1\n\n let sigS = sig.subarray(6 + lenR)\n if (sigS.length === 33 && sigS[0] === 0x00) sigS = sigS.slice(1)\n if (sigS.length > 32) throw new Error('S length is too long')\n\n let r = new BN(sigR)\n if (r.cmp(ecparams.n) >= 0) r = new BN(0)\n\n let s = new BN(sig.subarray(6 + lenR))\n if (s.cmp(ecparams.n) >= 0) s = new BN(0)\n\n output.set(r.toArrayLike(Uint8Array, 'be', 32), 0)\n output.set(s.toArrayLike(Uint8Array, 'be', 32), 32)\n\n return 0\n },\n\n ecdsaSign (obj, message, seckey, data, noncefn) {\n if (noncefn) {\n const _noncefn = noncefn\n noncefn = (counter) => {\n const nonce = _noncefn(message, seckey, null, data, counter)\n\n const isValid = nonce instanceof Uint8Array && nonce.length === 32\n if (!isValid) throw new Error('This is the way')\n\n return new BN(nonce)\n }\n }\n\n const d = new BN(seckey)\n if (d.cmp(ecparams.n) >= 0 || d.isZero()) return 1\n\n let sig\n try {\n sig = ec.sign(message, seckey, { canonical: true, k: noncefn, pers: data })\n } catch (err) {\n return 1\n }\n\n obj.signature.set(sig.r.toArrayLike(Uint8Array, 'be', 32), 0)\n obj.signature.set(sig.s.toArrayLike(Uint8Array, 'be', 32), 32)\n obj.recid = sig.recoveryParam\n\n return 0\n },\n\n ecdsaVerify (sig, msg32, pubkey) {\n const sigObj = { r: sig.subarray(0, 32), s: sig.subarray(32, 64) }\n\n const sigr = new BN(sigObj.r)\n const sigs = new BN(sigObj.s)\n if (sigr.cmp(ecparams.n) >= 0 || sigs.cmp(ecparams.n) >= 0) return 1\n if (sigs.cmp(ec.nh) === 1 || sigr.isZero() || sigs.isZero()) return 3\n\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 2\n\n const point = pair.getPublic()\n const isValid = ec.verify(msg32, sigObj, point)\n return isValid ? 0 : 3\n },\n\n ecdsaRecover (output, sig, recid, msg32) {\n const sigObj = { r: sig.slice(0, 32), s: sig.slice(32, 64) }\n\n const sigr = new BN(sigObj.r)\n const sigs = new BN(sigObj.s)\n if (sigr.cmp(ecparams.n) >= 0 || sigs.cmp(ecparams.n) >= 0) return 1\n\n if (sigr.isZero() || sigs.isZero()) return 2\n\n // Can throw `throw new Error('Unable to find sencond key candinate');`\n let point\n try {\n point = ec.recoverPubKey(msg32, sigObj, recid)\n } catch (err) {\n return 2\n }\n\n savePublicKey(output, point)\n\n return 0\n },\n\n ecdh (output, pubkey, seckey, data, hashfn, xbuf, ybuf) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n const scalar = new BN(seckey)\n if (scalar.cmp(ecparams.n) >= 0 || scalar.isZero()) return 2\n\n const point = pair.getPublic().mul(scalar)\n\n if (hashfn === undefined) {\n const data = point.encode(null, true)\n const sha256 = ec.hash().update(data).digest()\n for (let i = 0; i < 32; ++i) output[i] = sha256[i]\n } else {\n if (!xbuf) xbuf = new Uint8Array(32)\n const x = point.getX().toArray('be', 32)\n for (let i = 0; i < 32; ++i) xbuf[i] = x[i]\n\n if (!ybuf) ybuf = new Uint8Array(32)\n const y = point.getY().toArray('be', 32)\n for (let i = 0; i < 32; ++i) ybuf[i] = y[i]\n\n const hash = hashfn(xbuf, ybuf, data)\n\n const isValid = hash instanceof Uint8Array && hash.length === output.length\n if (!isValid) return 2\n\n output.set(hash)\n }\n\n return 0\n }\n}\n","'use strict';\n\nvar elliptic = exports;\n\nelliptic.version = require('../package.json').version;\nelliptic.utils = require('./elliptic/utils');\nelliptic.rand = require('brorand');\nelliptic.curve = require('./elliptic/curve');\nelliptic.curves = require('./elliptic/curves');\n\n// Protocols\nelliptic.ec = require('./elliptic/ec');\nelliptic.eddsa = require('./elliptic/eddsa');\n","{\n \"name\": \"elliptic\",\n \"version\": \"6.5.4\",\n \"description\": \"EC cryptography\",\n \"main\": \"lib/elliptic.js\",\n \"files\": [\n \"lib\"\n ],\n \"scripts\": {\n \"lint\": \"eslint lib test\",\n \"lint:fix\": \"npm run lint -- --fix\",\n \"unit\": \"istanbul test _mocha --reporter=spec test/index.js\",\n \"test\": \"npm run lint && npm run unit\",\n \"version\": \"grunt dist && git add dist/\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git@github.com:indutny/elliptic\"\n },\n \"keywords\": [\n \"EC\",\n \"Elliptic\",\n \"curve\",\n \"Cryptography\"\n ],\n \"author\": \"Fedor Indutny \",\n \"license\": \"MIT\",\n \"bugs\": {\n \"url\": \"https://github.com/indutny/elliptic/issues\"\n },\n \"homepage\": \"https://github.com/indutny/elliptic\",\n \"devDependencies\": {\n \"brfs\": \"^2.0.2\",\n \"coveralls\": \"^3.1.0\",\n \"eslint\": \"^7.6.0\",\n \"grunt\": \"^1.2.1\",\n \"grunt-browserify\": \"^5.3.0\",\n \"grunt-cli\": \"^1.3.2\",\n \"grunt-contrib-connect\": \"^3.0.0\",\n \"grunt-contrib-copy\": \"^1.0.0\",\n \"grunt-contrib-uglify\": \"^5.0.0\",\n \"grunt-mocha-istanbul\": \"^5.0.2\",\n \"grunt-saucelabs\": \"^9.0.1\",\n \"istanbul\": \"^0.4.5\",\n \"mocha\": \"^8.0.1\"\n },\n \"dependencies\": {\n \"bn.js\": \"^4.11.9\",\n \"brorand\": \"^1.1.0\",\n \"hash.js\": \"^1.0.0\",\n \"hmac-drbg\": \"^1.0.1\",\n \"inherits\": \"^2.0.4\",\n \"minimalistic-assert\": \"^1.0.1\",\n \"minimalistic-crypto-utils\": \"^1.0.1\"\n }\n}\n","'use strict';\n\nvar utils = exports;\nvar BN = require('bn.js');\nvar minAssert = require('minimalistic-assert');\nvar minUtils = require('minimalistic-crypto-utils');\n\nutils.assert = minAssert;\nutils.toArray = minUtils.toArray;\nutils.zero2 = minUtils.zero2;\nutils.toHex = minUtils.toHex;\nutils.encode = minUtils.encode;\n\n// Represent num in a w-NAF form\nfunction getNAF(num, w, bits) {\n var naf = new Array(Math.max(num.bitLength(), bits) + 1);\n naf.fill(0);\n\n var ws = 1 << (w + 1);\n var k = num.clone();\n\n for (var i = 0; i < naf.length; i++) {\n var z;\n var mod = k.andln(ws - 1);\n if (k.isOdd()) {\n if (mod > (ws >> 1) - 1)\n z = (ws >> 1) - mod;\n else\n z = mod;\n k.isubn(z);\n } else {\n z = 0;\n }\n\n naf[i] = z;\n k.iushrn(1);\n }\n\n return naf;\n}\nutils.getNAF = getNAF;\n\n// Represent k1, k2 in a Joint Sparse Form\nfunction getJSF(k1, k2) {\n var jsf = [\n [],\n [],\n ];\n\n k1 = k1.clone();\n k2 = k2.clone();\n var d1 = 0;\n var d2 = 0;\n var m8;\n while (k1.cmpn(-d1) > 0 || k2.cmpn(-d2) > 0) {\n // First phase\n var m14 = (k1.andln(3) + d1) & 3;\n var m24 = (k2.andln(3) + d2) & 3;\n if (m14 === 3)\n m14 = -1;\n if (m24 === 3)\n m24 = -1;\n var u1;\n if ((m14 & 1) === 0) {\n u1 = 0;\n } else {\n m8 = (k1.andln(7) + d1) & 7;\n if ((m8 === 3 || m8 === 5) && m24 === 2)\n u1 = -m14;\n else\n u1 = m14;\n }\n jsf[0].push(u1);\n\n var u2;\n if ((m24 & 1) === 0) {\n u2 = 0;\n } else {\n m8 = (k2.andln(7) + d2) & 7;\n if ((m8 === 3 || m8 === 5) && m14 === 2)\n u2 = -m24;\n else\n u2 = m24;\n }\n jsf[1].push(u2);\n\n // Second phase\n if (2 * d1 === u1 + 1)\n d1 = 1 - d1;\n if (2 * d2 === u2 + 1)\n d2 = 1 - d2;\n k1.iushrn(1);\n k2.iushrn(1);\n }\n\n return jsf;\n}\nutils.getJSF = getJSF;\n\nfunction cachedProperty(obj, name, computer) {\n var key = '_' + name;\n obj.prototype[name] = function cachedProperty() {\n return this[key] !== undefined ? this[key] :\n this[key] = computer.call(this);\n };\n}\nutils.cachedProperty = cachedProperty;\n\nfunction parseBytes(bytes) {\n return typeof bytes === 'string' ? utils.toArray(bytes, 'hex') :\n bytes;\n}\nutils.parseBytes = parseBytes;\n\nfunction intFromLE(bytes) {\n return new BN(bytes, 'hex', 'le');\n}\nutils.intFromLE = intFromLE;\n\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","module.exports = assert;\n\nfunction assert(val, msg) {\n if (!val)\n throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n if (l != r)\n throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n","'use strict';\n\nvar utils = exports;\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg !== 'string') {\n for (var i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n return res;\n }\n if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (var i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n } else {\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n var hi = c >> 8;\n var lo = c & 0xff;\n if (hi)\n res.push(hi, lo);\n else\n res.push(lo);\n }\n }\n return res;\n}\nutils.toArray = toArray;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nutils.zero2 = zero2;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nutils.toHex = toHex;\n\nutils.encode = function encode(arr, enc) {\n if (enc === 'hex')\n return toHex(arr);\n else\n return arr;\n};\n","var r;\n\nmodule.exports = function rand(len) {\n if (!r)\n r = new Rand(null);\n\n return r.generate(len);\n};\n\nfunction Rand(rand) {\n this.rand = rand;\n}\nmodule.exports.Rand = Rand;\n\nRand.prototype.generate = function generate(len) {\n return this._rand(len);\n};\n\n// Emulate crypto API using randy\nRand.prototype._rand = function _rand(n) {\n if (this.rand.getBytes)\n return this.rand.getBytes(n);\n\n var res = new Uint8Array(n);\n for (var i = 0; i < res.length; i++)\n res[i] = this.rand.getByte();\n return res;\n};\n\nif (typeof self === 'object') {\n if (self.crypto && self.crypto.getRandomValues) {\n // Modern browsers\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.crypto.getRandomValues(arr);\n return arr;\n };\n } else if (self.msCrypto && self.msCrypto.getRandomValues) {\n // IE\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.msCrypto.getRandomValues(arr);\n return arr;\n };\n\n // Safari's WebWorkers do not have `crypto`\n } else if (typeof window === 'object') {\n // Old junk\n Rand.prototype._rand = function() {\n throw new Error('Not implemented yet');\n };\n }\n} else {\n // Node.js or Web worker with no crypto support\n try {\n var crypto = require('crypto');\n if (typeof crypto.randomBytes !== 'function')\n throw new Error('Not supported');\n\n Rand.prototype._rand = function _rand(n) {\n return crypto.randomBytes(n);\n };\n } catch (e) {\n }\n}\n","'use strict';\n\nvar curve = exports;\n\ncurve.base = require('./base');\ncurve.short = require('./short');\ncurve.mont = require('./mont');\ncurve.edwards = require('./edwards');\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar getNAF = utils.getNAF;\nvar getJSF = utils.getJSF;\nvar assert = utils.assert;\n\nfunction BaseCurve(type, conf) {\n this.type = type;\n this.p = new BN(conf.p, 16);\n\n // Use Montgomery, when there is no fast reduction for the prime\n this.red = conf.prime ? BN.red(conf.prime) : BN.mont(this.p);\n\n // Useful for many curves\n this.zero = new BN(0).toRed(this.red);\n this.one = new BN(1).toRed(this.red);\n this.two = new BN(2).toRed(this.red);\n\n // Curve configuration, optional\n this.n = conf.n && new BN(conf.n, 16);\n this.g = conf.g && this.pointFromJSON(conf.g, conf.gRed);\n\n // Temporary arrays\n this._wnafT1 = new Array(4);\n this._wnafT2 = new Array(4);\n this._wnafT3 = new Array(4);\n this._wnafT4 = new Array(4);\n\n this._bitLength = this.n ? this.n.bitLength() : 0;\n\n // Generalized Greg Maxwell's trick\n var adjustCount = this.n && this.p.div(this.n);\n if (!adjustCount || adjustCount.cmpn(100) > 0) {\n this.redN = null;\n } else {\n this._maxwellTrick = true;\n this.redN = this.n.toRed(this.red);\n }\n}\nmodule.exports = BaseCurve;\n\nBaseCurve.prototype.point = function point() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype.validate = function validate() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype._fixedNafMul = function _fixedNafMul(p, k) {\n assert(p.precomputed);\n var doubles = p._getDoubles();\n\n var naf = getNAF(k, 1, this._bitLength);\n var I = (1 << (doubles.step + 1)) - (doubles.step % 2 === 0 ? 2 : 1);\n I /= 3;\n\n // Translate into more windowed form\n var repr = [];\n var j;\n var nafW;\n for (j = 0; j < naf.length; j += doubles.step) {\n nafW = 0;\n for (var l = j + doubles.step - 1; l >= j; l--)\n nafW = (nafW << 1) + naf[l];\n repr.push(nafW);\n }\n\n var a = this.jpoint(null, null, null);\n var b = this.jpoint(null, null, null);\n for (var i = I; i > 0; i--) {\n for (j = 0; j < repr.length; j++) {\n nafW = repr[j];\n if (nafW === i)\n b = b.mixedAdd(doubles.points[j]);\n else if (nafW === -i)\n b = b.mixedAdd(doubles.points[j].neg());\n }\n a = a.add(b);\n }\n return a.toP();\n};\n\nBaseCurve.prototype._wnafMul = function _wnafMul(p, k) {\n var w = 4;\n\n // Precompute window\n var nafPoints = p._getNAFPoints(w);\n w = nafPoints.wnd;\n var wnd = nafPoints.points;\n\n // Get NAF form\n var naf = getNAF(k, w, this._bitLength);\n\n // Add `this`*(N+1) for every w-NAF index\n var acc = this.jpoint(null, null, null);\n for (var i = naf.length - 1; i >= 0; i--) {\n // Count zeroes\n for (var l = 0; i >= 0 && naf[i] === 0; i--)\n l++;\n if (i >= 0)\n l++;\n acc = acc.dblp(l);\n\n if (i < 0)\n break;\n var z = naf[i];\n assert(z !== 0);\n if (p.type === 'affine') {\n // J +- P\n if (z > 0)\n acc = acc.mixedAdd(wnd[(z - 1) >> 1]);\n else\n acc = acc.mixedAdd(wnd[(-z - 1) >> 1].neg());\n } else {\n // J +- J\n if (z > 0)\n acc = acc.add(wnd[(z - 1) >> 1]);\n else\n acc = acc.add(wnd[(-z - 1) >> 1].neg());\n }\n }\n return p.type === 'affine' ? acc.toP() : acc;\n};\n\nBaseCurve.prototype._wnafMulAdd = function _wnafMulAdd(defW,\n points,\n coeffs,\n len,\n jacobianResult) {\n var wndWidth = this._wnafT1;\n var wnd = this._wnafT2;\n var naf = this._wnafT3;\n\n // Fill all arrays\n var max = 0;\n var i;\n var j;\n var p;\n for (i = 0; i < len; i++) {\n p = points[i];\n var nafPoints = p._getNAFPoints(defW);\n wndWidth[i] = nafPoints.wnd;\n wnd[i] = nafPoints.points;\n }\n\n // Comb small window NAFs\n for (i = len - 1; i >= 1; i -= 2) {\n var a = i - 1;\n var b = i;\n if (wndWidth[a] !== 1 || wndWidth[b] !== 1) {\n naf[a] = getNAF(coeffs[a], wndWidth[a], this._bitLength);\n naf[b] = getNAF(coeffs[b], wndWidth[b], this._bitLength);\n max = Math.max(naf[a].length, max);\n max = Math.max(naf[b].length, max);\n continue;\n }\n\n var comb = [\n points[a], /* 1 */\n null, /* 3 */\n null, /* 5 */\n points[b], /* 7 */\n ];\n\n // Try to avoid Projective points, if possible\n if (points[a].y.cmp(points[b].y) === 0) {\n comb[1] = points[a].add(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n } else if (points[a].y.cmp(points[b].y.redNeg()) === 0) {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].add(points[b].neg());\n } else {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n }\n\n var index = [\n -3, /* -1 -1 */\n -1, /* -1 0 */\n -5, /* -1 1 */\n -7, /* 0 -1 */\n 0, /* 0 0 */\n 7, /* 0 1 */\n 5, /* 1 -1 */\n 1, /* 1 0 */\n 3, /* 1 1 */\n ];\n\n var jsf = getJSF(coeffs[a], coeffs[b]);\n max = Math.max(jsf[0].length, max);\n naf[a] = new Array(max);\n naf[b] = new Array(max);\n for (j = 0; j < max; j++) {\n var ja = jsf[0][j] | 0;\n var jb = jsf[1][j] | 0;\n\n naf[a][j] = index[(ja + 1) * 3 + (jb + 1)];\n naf[b][j] = 0;\n wnd[a] = comb;\n }\n }\n\n var acc = this.jpoint(null, null, null);\n var tmp = this._wnafT4;\n for (i = max; i >= 0; i--) {\n var k = 0;\n\n while (i >= 0) {\n var zero = true;\n for (j = 0; j < len; j++) {\n tmp[j] = naf[j][i] | 0;\n if (tmp[j] !== 0)\n zero = false;\n }\n if (!zero)\n break;\n k++;\n i--;\n }\n if (i >= 0)\n k++;\n acc = acc.dblp(k);\n if (i < 0)\n break;\n\n for (j = 0; j < len; j++) {\n var z = tmp[j];\n p;\n if (z === 0)\n continue;\n else if (z > 0)\n p = wnd[j][(z - 1) >> 1];\n else if (z < 0)\n p = wnd[j][(-z - 1) >> 1].neg();\n\n if (p.type === 'affine')\n acc = acc.mixedAdd(p);\n else\n acc = acc.add(p);\n }\n }\n // Zeroify references\n for (i = 0; i < len; i++)\n wnd[i] = null;\n\n if (jacobianResult)\n return acc;\n else\n return acc.toP();\n};\n\nfunction BasePoint(curve, type) {\n this.curve = curve;\n this.type = type;\n this.precomputed = null;\n}\nBaseCurve.BasePoint = BasePoint;\n\nBasePoint.prototype.eq = function eq(/*other*/) {\n throw new Error('Not implemented');\n};\n\nBasePoint.prototype.validate = function validate() {\n return this.curve.validate(this);\n};\n\nBaseCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n bytes = utils.toArray(bytes, enc);\n\n var len = this.p.byteLength();\n\n // uncompressed, hybrid-odd, hybrid-even\n if ((bytes[0] === 0x04 || bytes[0] === 0x06 || bytes[0] === 0x07) &&\n bytes.length - 1 === 2 * len) {\n if (bytes[0] === 0x06)\n assert(bytes[bytes.length - 1] % 2 === 0);\n else if (bytes[0] === 0x07)\n assert(bytes[bytes.length - 1] % 2 === 1);\n\n var res = this.point(bytes.slice(1, 1 + len),\n bytes.slice(1 + len, 1 + 2 * len));\n\n return res;\n } else if ((bytes[0] === 0x02 || bytes[0] === 0x03) &&\n bytes.length - 1 === len) {\n return this.pointFromX(bytes.slice(1, 1 + len), bytes[0] === 0x03);\n }\n throw new Error('Unknown point format');\n};\n\nBasePoint.prototype.encodeCompressed = function encodeCompressed(enc) {\n return this.encode(enc, true);\n};\n\nBasePoint.prototype._encode = function _encode(compact) {\n var len = this.curve.p.byteLength();\n var x = this.getX().toArray('be', len);\n\n if (compact)\n return [ this.getY().isEven() ? 0x02 : 0x03 ].concat(x);\n\n return [ 0x04 ].concat(x, this.getY().toArray('be', len));\n};\n\nBasePoint.prototype.encode = function encode(enc, compact) {\n return utils.encode(this._encode(compact), enc);\n};\n\nBasePoint.prototype.precompute = function precompute(power) {\n if (this.precomputed)\n return this;\n\n var precomputed = {\n doubles: null,\n naf: null,\n beta: null,\n };\n precomputed.naf = this._getNAFPoints(8);\n precomputed.doubles = this._getDoubles(4, power);\n precomputed.beta = this._getBeta();\n this.precomputed = precomputed;\n\n return this;\n};\n\nBasePoint.prototype._hasDoubles = function _hasDoubles(k) {\n if (!this.precomputed)\n return false;\n\n var doubles = this.precomputed.doubles;\n if (!doubles)\n return false;\n\n return doubles.points.length >= Math.ceil((k.bitLength() + 1) / doubles.step);\n};\n\nBasePoint.prototype._getDoubles = function _getDoubles(step, power) {\n if (this.precomputed && this.precomputed.doubles)\n return this.precomputed.doubles;\n\n var doubles = [ this ];\n var acc = this;\n for (var i = 0; i < power; i += step) {\n for (var j = 0; j < step; j++)\n acc = acc.dbl();\n doubles.push(acc);\n }\n return {\n step: step,\n points: doubles,\n };\n};\n\nBasePoint.prototype._getNAFPoints = function _getNAFPoints(wnd) {\n if (this.precomputed && this.precomputed.naf)\n return this.precomputed.naf;\n\n var res = [ this ];\n var max = (1 << wnd) - 1;\n var dbl = max === 1 ? null : this.dbl();\n for (var i = 1; i < max; i++)\n res[i] = res[i - 1].add(dbl);\n return {\n wnd: wnd,\n points: res,\n };\n};\n\nBasePoint.prototype._getBeta = function _getBeta() {\n return null;\n};\n\nBasePoint.prototype.dblp = function dblp(k) {\n var r = this;\n for (var i = 0; i < k; i++)\n r = r.dbl();\n return r;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction ShortCurve(conf) {\n Base.call(this, 'short', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.tinv = this.two.redInvm();\n\n this.zeroA = this.a.fromRed().cmpn(0) === 0;\n this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0;\n\n // If the curve is endomorphic, precalculate beta and lambda\n this.endo = this._getEndomorphism(conf);\n this._endoWnafT1 = new Array(4);\n this._endoWnafT2 = new Array(4);\n}\ninherits(ShortCurve, Base);\nmodule.exports = ShortCurve;\n\nShortCurve.prototype._getEndomorphism = function _getEndomorphism(conf) {\n // No efficient endomorphism\n if (!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1)\n return;\n\n // Compute beta and lambda, that lambda * P = (beta * Px; Py)\n var beta;\n var lambda;\n if (conf.beta) {\n beta = new BN(conf.beta, 16).toRed(this.red);\n } else {\n var betas = this._getEndoRoots(this.p);\n // Choose the smallest beta\n beta = betas[0].cmp(betas[1]) < 0 ? betas[0] : betas[1];\n beta = beta.toRed(this.red);\n }\n if (conf.lambda) {\n lambda = new BN(conf.lambda, 16);\n } else {\n // Choose the lambda that is matching selected beta\n var lambdas = this._getEndoRoots(this.n);\n if (this.g.mul(lambdas[0]).x.cmp(this.g.x.redMul(beta)) === 0) {\n lambda = lambdas[0];\n } else {\n lambda = lambdas[1];\n assert(this.g.mul(lambda).x.cmp(this.g.x.redMul(beta)) === 0);\n }\n }\n\n // Get basis vectors, used for balanced length-two representation\n var basis;\n if (conf.basis) {\n basis = conf.basis.map(function(vec) {\n return {\n a: new BN(vec.a, 16),\n b: new BN(vec.b, 16),\n };\n });\n } else {\n basis = this._getEndoBasis(lambda);\n }\n\n return {\n beta: beta,\n lambda: lambda,\n basis: basis,\n };\n};\n\nShortCurve.prototype._getEndoRoots = function _getEndoRoots(num) {\n // Find roots of for x^2 + x + 1 in F\n // Root = (-1 +- Sqrt(-3)) / 2\n //\n var red = num === this.p ? this.red : BN.mont(num);\n var tinv = new BN(2).toRed(red).redInvm();\n var ntinv = tinv.redNeg();\n\n var s = new BN(3).toRed(red).redNeg().redSqrt().redMul(tinv);\n\n var l1 = ntinv.redAdd(s).fromRed();\n var l2 = ntinv.redSub(s).fromRed();\n return [ l1, l2 ];\n};\n\nShortCurve.prototype._getEndoBasis = function _getEndoBasis(lambda) {\n // aprxSqrt >= sqrt(this.n)\n var aprxSqrt = this.n.ushrn(Math.floor(this.n.bitLength() / 2));\n\n // 3.74\n // Run EGCD, until r(L + 1) < aprxSqrt\n var u = lambda;\n var v = this.n.clone();\n var x1 = new BN(1);\n var y1 = new BN(0);\n var x2 = new BN(0);\n var y2 = new BN(1);\n\n // NOTE: all vectors are roots of: a + b * lambda = 0 (mod n)\n var a0;\n var b0;\n // First vector\n var a1;\n var b1;\n // Second vector\n var a2;\n var b2;\n\n var prevR;\n var i = 0;\n var r;\n var x;\n while (u.cmpn(0) !== 0) {\n var q = v.div(u);\n r = v.sub(q.mul(u));\n x = x2.sub(q.mul(x1));\n var y = y2.sub(q.mul(y1));\n\n if (!a1 && r.cmp(aprxSqrt) < 0) {\n a0 = prevR.neg();\n b0 = x1;\n a1 = r.neg();\n b1 = x;\n } else if (a1 && ++i === 2) {\n break;\n }\n prevR = r;\n\n v = u;\n u = r;\n x2 = x1;\n x1 = x;\n y2 = y1;\n y1 = y;\n }\n a2 = r.neg();\n b2 = x;\n\n var len1 = a1.sqr().add(b1.sqr());\n var len2 = a2.sqr().add(b2.sqr());\n if (len2.cmp(len1) >= 0) {\n a2 = a0;\n b2 = b0;\n }\n\n // Normalize signs\n if (a1.negative) {\n a1 = a1.neg();\n b1 = b1.neg();\n }\n if (a2.negative) {\n a2 = a2.neg();\n b2 = b2.neg();\n }\n\n return [\n { a: a1, b: b1 },\n { a: a2, b: b2 },\n ];\n};\n\nShortCurve.prototype._endoSplit = function _endoSplit(k) {\n var basis = this.endo.basis;\n var v1 = basis[0];\n var v2 = basis[1];\n\n var c1 = v2.b.mul(k).divRound(this.n);\n var c2 = v1.b.neg().mul(k).divRound(this.n);\n\n var p1 = c1.mul(v1.a);\n var p2 = c2.mul(v2.a);\n var q1 = c1.mul(v1.b);\n var q2 = c2.mul(v2.b);\n\n // Calculate answer\n var k1 = k.sub(p1).sub(p2);\n var k2 = q1.add(q2).neg();\n return { k1: k1, k2: k2 };\n};\n\nShortCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var y2 = x.redSqr().redMul(x).redIAdd(x.redMul(this.a)).redIAdd(this.b);\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n // XXX Is there any way to tell if the number is odd without converting it\n // to non-red form?\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nShortCurve.prototype.validate = function validate(point) {\n if (point.inf)\n return true;\n\n var x = point.x;\n var y = point.y;\n\n var ax = this.a.redMul(x);\n var rhs = x.redSqr().redMul(x).redIAdd(ax).redIAdd(this.b);\n return y.redSqr().redISub(rhs).cmpn(0) === 0;\n};\n\nShortCurve.prototype._endoWnafMulAdd =\n function _endoWnafMulAdd(points, coeffs, jacobianResult) {\n var npoints = this._endoWnafT1;\n var ncoeffs = this._endoWnafT2;\n for (var i = 0; i < points.length; i++) {\n var split = this._endoSplit(coeffs[i]);\n var p = points[i];\n var beta = p._getBeta();\n\n if (split.k1.negative) {\n split.k1.ineg();\n p = p.neg(true);\n }\n if (split.k2.negative) {\n split.k2.ineg();\n beta = beta.neg(true);\n }\n\n npoints[i * 2] = p;\n npoints[i * 2 + 1] = beta;\n ncoeffs[i * 2] = split.k1;\n ncoeffs[i * 2 + 1] = split.k2;\n }\n var res = this._wnafMulAdd(1, npoints, ncoeffs, i * 2, jacobianResult);\n\n // Clean-up references to points and coefficients\n for (var j = 0; j < i * 2; j++) {\n npoints[j] = null;\n ncoeffs[j] = null;\n }\n return res;\n };\n\nfunction Point(curve, x, y, isRed) {\n Base.BasePoint.call(this, curve, 'affine');\n if (x === null && y === null) {\n this.x = null;\n this.y = null;\n this.inf = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n // Force redgomery representation when loading from JSON\n if (isRed) {\n this.x.forceRed(this.curve.red);\n this.y.forceRed(this.curve.red);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n this.inf = false;\n }\n}\ninherits(Point, Base.BasePoint);\n\nShortCurve.prototype.point = function point(x, y, isRed) {\n return new Point(this, x, y, isRed);\n};\n\nShortCurve.prototype.pointFromJSON = function pointFromJSON(obj, red) {\n return Point.fromJSON(this, obj, red);\n};\n\nPoint.prototype._getBeta = function _getBeta() {\n if (!this.curve.endo)\n return;\n\n var pre = this.precomputed;\n if (pre && pre.beta)\n return pre.beta;\n\n var beta = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y);\n if (pre) {\n var curve = this.curve;\n var endoMul = function(p) {\n return curve.point(p.x.redMul(curve.endo.beta), p.y);\n };\n pre.beta = beta;\n beta.precomputed = {\n beta: null,\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(endoMul),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(endoMul),\n },\n };\n }\n return beta;\n};\n\nPoint.prototype.toJSON = function toJSON() {\n if (!this.precomputed)\n return [ this.x, this.y ];\n\n return [ this.x, this.y, this.precomputed && {\n doubles: this.precomputed.doubles && {\n step: this.precomputed.doubles.step,\n points: this.precomputed.doubles.points.slice(1),\n },\n naf: this.precomputed.naf && {\n wnd: this.precomputed.naf.wnd,\n points: this.precomputed.naf.points.slice(1),\n },\n } ];\n};\n\nPoint.fromJSON = function fromJSON(curve, obj, red) {\n if (typeof obj === 'string')\n obj = JSON.parse(obj);\n var res = curve.point(obj[0], obj[1], red);\n if (!obj[2])\n return res;\n\n function obj2point(obj) {\n return curve.point(obj[0], obj[1], red);\n }\n\n var pre = obj[2];\n res.precomputed = {\n beta: null,\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: [ res ].concat(pre.doubles.points.map(obj2point)),\n },\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: [ res ].concat(pre.naf.points.map(obj2point)),\n },\n };\n return res;\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n return this.inf;\n};\n\nPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.inf)\n return p;\n\n // P + O = P\n if (p.inf)\n return this;\n\n // P + P = 2P\n if (this.eq(p))\n return this.dbl();\n\n // P + (-P) = O\n if (this.neg().eq(p))\n return this.curve.point(null, null);\n\n // P + Q = O\n if (this.x.cmp(p.x) === 0)\n return this.curve.point(null, null);\n\n var c = this.y.redSub(p.y);\n if (c.cmpn(0) !== 0)\n c = c.redMul(this.x.redSub(p.x).redInvm());\n var nx = c.redSqr().redISub(this.x).redISub(p.x);\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.inf)\n return this;\n\n // 2P = O\n var ys1 = this.y.redAdd(this.y);\n if (ys1.cmpn(0) === 0)\n return this.curve.point(null, null);\n\n var a = this.curve.a;\n\n var x2 = this.x.redSqr();\n var dyinv = ys1.redInvm();\n var c = x2.redAdd(x2).redIAdd(x2).redIAdd(a).redMul(dyinv);\n\n var nx = c.redSqr().redISub(this.x.redAdd(this.x));\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.getX = function getX() {\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n return this.y.fromRed();\n};\n\nPoint.prototype.mul = function mul(k) {\n k = new BN(k, 16);\n if (this.isInfinity())\n return this;\n else if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else if (this.curve.endo)\n return this.curve._endoWnafMulAdd([ this ], [ k ]);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs, true);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2, true);\n};\n\nPoint.prototype.eq = function eq(p) {\n return this === p ||\n this.inf === p.inf &&\n (this.inf || this.x.cmp(p.x) === 0 && this.y.cmp(p.y) === 0);\n};\n\nPoint.prototype.neg = function neg(_precompute) {\n if (this.inf)\n return this;\n\n var res = this.curve.point(this.x, this.y.redNeg());\n if (_precompute && this.precomputed) {\n var pre = this.precomputed;\n var negate = function(p) {\n return p.neg();\n };\n res.precomputed = {\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(negate),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(negate),\n },\n };\n }\n return res;\n};\n\nPoint.prototype.toJ = function toJ() {\n if (this.inf)\n return this.curve.jpoint(null, null, null);\n\n var res = this.curve.jpoint(this.x, this.y, this.curve.one);\n return res;\n};\n\nfunction JPoint(curve, x, y, z) {\n Base.BasePoint.call(this, curve, 'jacobian');\n if (x === null && y === null && z === null) {\n this.x = this.curve.one;\n this.y = this.curve.one;\n this.z = new BN(0);\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = new BN(z, 16);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n\n this.zOne = this.z === this.curve.one;\n}\ninherits(JPoint, Base.BasePoint);\n\nShortCurve.prototype.jpoint = function jpoint(x, y, z) {\n return new JPoint(this, x, y, z);\n};\n\nJPoint.prototype.toP = function toP() {\n if (this.isInfinity())\n return this.curve.point(null, null);\n\n var zinv = this.z.redInvm();\n var zinv2 = zinv.redSqr();\n var ax = this.x.redMul(zinv2);\n var ay = this.y.redMul(zinv2).redMul(zinv);\n\n return this.curve.point(ax, ay);\n};\n\nJPoint.prototype.neg = function neg() {\n return this.curve.jpoint(this.x, this.y.redNeg(), this.z);\n};\n\nJPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.isInfinity())\n return p;\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 12M + 4S + 7A\n var pz2 = p.z.redSqr();\n var z2 = this.z.redSqr();\n var u1 = this.x.redMul(pz2);\n var u2 = p.x.redMul(z2);\n var s1 = this.y.redMul(pz2.redMul(p.z));\n var s2 = p.y.redMul(z2.redMul(this.z));\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(p.z).redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mixedAdd = function mixedAdd(p) {\n // O + P = P\n if (this.isInfinity())\n return p.toJ();\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 8M + 3S + 7A\n var z2 = this.z.redSqr();\n var u1 = this.x;\n var u2 = p.x.redMul(z2);\n var s1 = this.y;\n var s2 = p.y.redMul(z2).redMul(this.z);\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.dblp = function dblp(pow) {\n if (pow === 0)\n return this;\n if (this.isInfinity())\n return this;\n if (!pow)\n return this.dbl();\n\n var i;\n if (this.curve.zeroA || this.curve.threeA) {\n var r = this;\n for (i = 0; i < pow; i++)\n r = r.dbl();\n return r;\n }\n\n // 1M + 2S + 1A + N * (4S + 5M + 8A)\n // N = 1 => 6M + 6S + 9A\n var a = this.curve.a;\n var tinv = this.curve.tinv;\n\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n // Reuse results\n var jyd = jy.redAdd(jy);\n for (i = 0; i < pow; i++) {\n var jx2 = jx.redSqr();\n var jyd2 = jyd.redSqr();\n var jyd4 = jyd2.redSqr();\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var t1 = jx.redMul(jyd2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n var dny = c.redMul(t2);\n dny = dny.redIAdd(dny).redISub(jyd4);\n var nz = jyd.redMul(jz);\n if (i + 1 < pow)\n jz4 = jz4.redMul(jyd4);\n\n jx = nx;\n jz = nz;\n jyd = dny;\n }\n\n return this.curve.jpoint(jx, jyd.redMul(tinv), jz);\n};\n\nJPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n if (this.curve.zeroA)\n return this._zeroDbl();\n else if (this.curve.threeA)\n return this._threeDbl();\n else\n return this._dbl();\n};\n\nJPoint.prototype._zeroDbl = function _zeroDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 14A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // T = M ^ 2 - 2*S\n var t = m.redSqr().redISub(s).redISub(s);\n\n // 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2*Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-dbl-2009-l\n // 2M + 5S + 13A\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = B^2\n var c = b.redSqr();\n // D = 2 * ((X1 + B)^2 - A - C)\n var d = this.x.redAdd(b).redSqr().redISub(a).redISub(c);\n d = d.redIAdd(d);\n // E = 3 * A\n var e = a.redAdd(a).redIAdd(a);\n // F = E^2\n var f = e.redSqr();\n\n // 8 * C\n var c8 = c.redIAdd(c);\n c8 = c8.redIAdd(c8);\n c8 = c8.redIAdd(c8);\n\n // X3 = F - 2 * D\n nx = f.redISub(d).redISub(d);\n // Y3 = E * (D - X3) - 8 * C\n ny = e.redMul(d.redISub(nx)).redISub(c8);\n // Z3 = 2 * Y1 * Z1\n nz = this.y.redMul(this.z);\n nz = nz.redIAdd(nz);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._threeDbl = function _threeDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 15A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a\n var m = xx.redAdd(xx).redIAdd(xx).redIAdd(this.curve.a);\n // T = M^2 - 2 * S\n var t = m.redSqr().redISub(s).redISub(s);\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2 * Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html#doubling-dbl-2001-b\n // 3M + 5S\n\n // delta = Z1^2\n var delta = this.z.redSqr();\n // gamma = Y1^2\n var gamma = this.y.redSqr();\n // beta = X1 * gamma\n var beta = this.x.redMul(gamma);\n // alpha = 3 * (X1 - delta) * (X1 + delta)\n var alpha = this.x.redSub(delta).redMul(this.x.redAdd(delta));\n alpha = alpha.redAdd(alpha).redIAdd(alpha);\n // X3 = alpha^2 - 8 * beta\n var beta4 = beta.redIAdd(beta);\n beta4 = beta4.redIAdd(beta4);\n var beta8 = beta4.redAdd(beta4);\n nx = alpha.redSqr().redISub(beta8);\n // Z3 = (Y1 + Z1)^2 - gamma - delta\n nz = this.y.redAdd(this.z).redSqr().redISub(gamma).redISub(delta);\n // Y3 = alpha * (4 * beta - X3) - 8 * gamma^2\n var ggamma8 = gamma.redSqr();\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ny = alpha.redMul(beta4.redISub(nx)).redISub(ggamma8);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._dbl = function _dbl() {\n var a = this.curve.a;\n\n // 4M + 6S + 10A\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n var jx2 = jx.redSqr();\n var jy2 = jy.redSqr();\n\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var jxd4 = jx.redAdd(jx);\n jxd4 = jxd4.redIAdd(jxd4);\n var t1 = jxd4.redMul(jy2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n\n var jyd8 = jy2.redSqr();\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n var ny = c.redMul(t2).redISub(jyd8);\n var nz = jy.redAdd(jy).redMul(jz);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.trpl = function trpl() {\n if (!this.curve.zeroA)\n return this.dbl().add(this);\n\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html#tripling-tpl-2007-bl\n // 5M + 10S + ...\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // ZZ = Z1^2\n var zz = this.z.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // M = 3 * XX + a * ZZ2; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // MM = M^2\n var mm = m.redSqr();\n // E = 6 * ((X1 + YY)^2 - XX - YYYY) - MM\n var e = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n e = e.redIAdd(e);\n e = e.redAdd(e).redIAdd(e);\n e = e.redISub(mm);\n // EE = E^2\n var ee = e.redSqr();\n // T = 16*YYYY\n var t = yyyy.redIAdd(yyyy);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n // U = (M + E)^2 - MM - EE - T\n var u = m.redIAdd(e).redSqr().redISub(mm).redISub(ee).redISub(t);\n // X3 = 4 * (X1 * EE - 4 * YY * U)\n var yyu4 = yy.redMul(u);\n yyu4 = yyu4.redIAdd(yyu4);\n yyu4 = yyu4.redIAdd(yyu4);\n var nx = this.x.redMul(ee).redISub(yyu4);\n nx = nx.redIAdd(nx);\n nx = nx.redIAdd(nx);\n // Y3 = 8 * Y1 * (U * (T - U) - E * EE)\n var ny = this.y.redMul(u.redMul(t.redISub(u)).redISub(e.redMul(ee)));\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n // Z3 = (Z1 + E)^2 - ZZ - EE\n var nz = this.z.redAdd(e).redSqr().redISub(zz).redISub(ee);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mul = function mul(k, kbase) {\n k = new BN(k, kbase);\n\n return this.curve._wnafMul(this, k);\n};\n\nJPoint.prototype.eq = function eq(p) {\n if (p.type === 'affine')\n return this.eq(p.toJ());\n\n if (this === p)\n return true;\n\n // x1 * z2^2 == x2 * z1^2\n var z2 = this.z.redSqr();\n var pz2 = p.z.redSqr();\n if (this.x.redMul(pz2).redISub(p.x.redMul(z2)).cmpn(0) !== 0)\n return false;\n\n // y1 * z2^3 == y2 * z1^3\n var z3 = z2.redMul(this.z);\n var pz3 = pz2.redMul(p.z);\n return this.y.redMul(pz3).redISub(p.y.redMul(z3)).cmpn(0) === 0;\n};\n\nJPoint.prototype.eqXToP = function eqXToP(x) {\n var zs = this.z.redSqr();\n var rx = x.toRed(this.curve.red).redMul(zs);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(zs);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\nJPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nJPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","'use strict';\n\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar utils = require('../utils');\n\nfunction MontCurve(conf) {\n Base.call(this, 'mont', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.i4 = new BN(4).toRed(this.red).redInvm();\n this.two = new BN(2).toRed(this.red);\n this.a24 = this.i4.redMul(this.a.redAdd(this.two));\n}\ninherits(MontCurve, Base);\nmodule.exports = MontCurve;\n\nMontCurve.prototype.validate = function validate(point) {\n var x = point.normalize().x;\n var x2 = x.redSqr();\n var rhs = x2.redMul(x).redAdd(x2.redMul(this.a)).redAdd(x);\n var y = rhs.redSqrt();\n\n return y.redSqr().cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, z) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && z === null) {\n this.x = this.curve.one;\n this.z = this.curve.zero;\n } else {\n this.x = new BN(x, 16);\n this.z = new BN(z, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n }\n}\ninherits(Point, Base.BasePoint);\n\nMontCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n return this.point(utils.toArray(bytes, enc), 1);\n};\n\nMontCurve.prototype.point = function point(x, z) {\n return new Point(this, x, z);\n};\n\nMontCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nPoint.prototype.precompute = function precompute() {\n // No-op\n};\n\nPoint.prototype._encode = function _encode() {\n return this.getX().toArray('be', this.curve.p.byteLength());\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1] || curve.one);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n\nPoint.prototype.dbl = function dbl() {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#doubling-dbl-1987-m-3\n // 2M + 2S + 4A\n\n // A = X1 + Z1\n var a = this.x.redAdd(this.z);\n // AA = A^2\n var aa = a.redSqr();\n // B = X1 - Z1\n var b = this.x.redSub(this.z);\n // BB = B^2\n var bb = b.redSqr();\n // C = AA - BB\n var c = aa.redSub(bb);\n // X3 = AA * BB\n var nx = aa.redMul(bb);\n // Z3 = C * (BB + A24 * C)\n var nz = c.redMul(bb.redAdd(this.curve.a24.redMul(c)));\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.add = function add() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.diffAdd = function diffAdd(p, diff) {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#diffadd-dadd-1987-m-3\n // 4M + 2S + 6A\n\n // A = X2 + Z2\n var a = this.x.redAdd(this.z);\n // B = X2 - Z2\n var b = this.x.redSub(this.z);\n // C = X3 + Z3\n var c = p.x.redAdd(p.z);\n // D = X3 - Z3\n var d = p.x.redSub(p.z);\n // DA = D * A\n var da = d.redMul(a);\n // CB = C * B\n var cb = c.redMul(b);\n // X5 = Z1 * (DA + CB)^2\n var nx = diff.z.redMul(da.redAdd(cb).redSqr());\n // Z5 = X1 * (DA - CB)^2\n var nz = diff.x.redMul(da.redISub(cb).redSqr());\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.mul = function mul(k) {\n var t = k.clone();\n var a = this; // (N / 2) * Q + Q\n var b = this.curve.point(null, null); // (N / 2) * Q\n var c = this; // Q\n\n for (var bits = []; t.cmpn(0) !== 0; t.iushrn(1))\n bits.push(t.andln(1));\n\n for (var i = bits.length - 1; i >= 0; i--) {\n if (bits[i] === 0) {\n // N * Q + Q = ((N / 2) * Q + Q)) + (N / 2) * Q\n a = a.diffAdd(b, c);\n // N * Q = 2 * ((N / 2) * Q + Q))\n b = b.dbl();\n } else {\n // N * Q = ((N / 2) * Q + Q) + ((N / 2) * Q)\n b = a.diffAdd(b, c);\n // N * Q + Q = 2 * ((N / 2) * Q + Q)\n a = a.dbl();\n }\n }\n return b;\n};\n\nPoint.prototype.mulAdd = function mulAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.jumlAdd = function jumlAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.eq = function eq(other) {\n return this.getX().cmp(other.getX()) === 0;\n};\n\nPoint.prototype.normalize = function normalize() {\n this.x = this.x.redMul(this.z.redInvm());\n this.z = this.curve.one;\n return this;\n};\n\nPoint.prototype.getX = function getX() {\n // Normalize coordinates\n this.normalize();\n\n return this.x.fromRed();\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction EdwardsCurve(conf) {\n // NOTE: Important as we are creating point in Base.call()\n this.twisted = (conf.a | 0) !== 1;\n this.mOneA = this.twisted && (conf.a | 0) === -1;\n this.extended = this.mOneA;\n\n Base.call(this, 'edwards', conf);\n\n this.a = new BN(conf.a, 16).umod(this.red.m);\n this.a = this.a.toRed(this.red);\n this.c = new BN(conf.c, 16).toRed(this.red);\n this.c2 = this.c.redSqr();\n this.d = new BN(conf.d, 16).toRed(this.red);\n this.dd = this.d.redAdd(this.d);\n\n assert(!this.twisted || this.c.fromRed().cmpn(1) === 0);\n this.oneC = (conf.c | 0) === 1;\n}\ninherits(EdwardsCurve, Base);\nmodule.exports = EdwardsCurve;\n\nEdwardsCurve.prototype._mulA = function _mulA(num) {\n if (this.mOneA)\n return num.redNeg();\n else\n return this.a.redMul(num);\n};\n\nEdwardsCurve.prototype._mulC = function _mulC(num) {\n if (this.oneC)\n return num;\n else\n return this.c.redMul(num);\n};\n\n// Just for compatibility with Short curve\nEdwardsCurve.prototype.jpoint = function jpoint(x, y, z, t) {\n return this.point(x, y, z, t);\n};\n\nEdwardsCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var x2 = x.redSqr();\n var rhs = this.c2.redSub(this.a.redMul(x2));\n var lhs = this.one.redSub(this.c2.redMul(this.d).redMul(x2));\n\n var y2 = rhs.redMul(lhs.redInvm());\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.pointFromY = function pointFromY(y, odd) {\n y = new BN(y, 16);\n if (!y.red)\n y = y.toRed(this.red);\n\n // x^2 = (y^2 - c^2) / (c^2 d y^2 - a)\n var y2 = y.redSqr();\n var lhs = y2.redSub(this.c2);\n var rhs = y2.redMul(this.d).redMul(this.c2).redSub(this.a);\n var x2 = lhs.redMul(rhs.redInvm());\n\n if (x2.cmp(this.zero) === 0) {\n if (odd)\n throw new Error('invalid point');\n else\n return this.point(this.zero, y);\n }\n\n var x = x2.redSqrt();\n if (x.redSqr().redSub(x2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n if (x.fromRed().isOdd() !== odd)\n x = x.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.validate = function validate(point) {\n if (point.isInfinity())\n return true;\n\n // Curve: A * X^2 + Y^2 = C^2 * (1 + D * X^2 * Y^2)\n point.normalize();\n\n var x2 = point.x.redSqr();\n var y2 = point.y.redSqr();\n var lhs = x2.redMul(this.a).redAdd(y2);\n var rhs = this.c2.redMul(this.one.redAdd(this.d.redMul(x2).redMul(y2)));\n\n return lhs.cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, y, z, t) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && y === null && z === null) {\n this.x = this.curve.zero;\n this.y = this.curve.one;\n this.z = this.curve.one;\n this.t = this.curve.zero;\n this.zOne = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = z ? new BN(z, 16) : this.curve.one;\n this.t = t && new BN(t, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n if (this.t && !this.t.red)\n this.t = this.t.toRed(this.curve.red);\n this.zOne = this.z === this.curve.one;\n\n // Use extended coordinates\n if (this.curve.extended && !this.t) {\n this.t = this.x.redMul(this.y);\n if (!this.zOne)\n this.t = this.t.redMul(this.z.redInvm());\n }\n }\n}\ninherits(Point, Base.BasePoint);\n\nEdwardsCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nEdwardsCurve.prototype.point = function point(x, y, z, t) {\n return new Point(this, x, y, z, t);\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1], obj[2]);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.x.cmpn(0) === 0 &&\n (this.y.cmp(this.z) === 0 ||\n (this.zOne && this.y.cmp(this.curve.c) === 0));\n};\n\nPoint.prototype._extDbl = function _extDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #doubling-dbl-2008-hwcd\n // 4M + 4S\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = 2 * Z1^2\n var c = this.z.redSqr();\n c = c.redIAdd(c);\n // D = a * A\n var d = this.curve._mulA(a);\n // E = (X1 + Y1)^2 - A - B\n var e = this.x.redAdd(this.y).redSqr().redISub(a).redISub(b);\n // G = D + B\n var g = d.redAdd(b);\n // F = G - C\n var f = g.redSub(c);\n // H = D - B\n var h = d.redSub(b);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projDbl = function _projDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #doubling-dbl-2008-bbjlp\n // #doubling-dbl-2007-bl\n // and others\n // Generally 3M + 4S or 2M + 4S\n\n // B = (X1 + Y1)^2\n var b = this.x.redAdd(this.y).redSqr();\n // C = X1^2\n var c = this.x.redSqr();\n // D = Y1^2\n var d = this.y.redSqr();\n\n var nx;\n var ny;\n var nz;\n var e;\n var h;\n var j;\n if (this.curve.twisted) {\n // E = a * C\n e = this.curve._mulA(c);\n // F = E + D\n var f = e.redAdd(d);\n if (this.zOne) {\n // X3 = (B - C - D) * (F - 2)\n nx = b.redSub(c).redSub(d).redMul(f.redSub(this.curve.two));\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F^2 - 2 * F\n nz = f.redSqr().redSub(f).redSub(f);\n } else {\n // H = Z1^2\n h = this.z.redSqr();\n // J = F - 2 * H\n j = f.redSub(h).redISub(h);\n // X3 = (B-C-D)*J\n nx = b.redSub(c).redISub(d).redMul(j);\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F * J\n nz = f.redMul(j);\n }\n } else {\n // E = C + D\n e = c.redAdd(d);\n // H = (c * Z1)^2\n h = this.curve._mulC(this.z).redSqr();\n // J = E - 2 * H\n j = e.redSub(h).redSub(h);\n // X3 = c * (B - E) * J\n nx = this.curve._mulC(b.redISub(e)).redMul(j);\n // Y3 = c * E * (C - D)\n ny = this.curve._mulC(e).redMul(c.redISub(d));\n // Z3 = E * J\n nz = e.redMul(j);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n // Double in extended coordinates\n if (this.curve.extended)\n return this._extDbl();\n else\n return this._projDbl();\n};\n\nPoint.prototype._extAdd = function _extAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #addition-add-2008-hwcd-3\n // 8M\n\n // A = (Y1 - X1) * (Y2 - X2)\n var a = this.y.redSub(this.x).redMul(p.y.redSub(p.x));\n // B = (Y1 + X1) * (Y2 + X2)\n var b = this.y.redAdd(this.x).redMul(p.y.redAdd(p.x));\n // C = T1 * k * T2\n var c = this.t.redMul(this.curve.dd).redMul(p.t);\n // D = Z1 * 2 * Z2\n var d = this.z.redMul(p.z.redAdd(p.z));\n // E = B - A\n var e = b.redSub(a);\n // F = D - C\n var f = d.redSub(c);\n // G = D + C\n var g = d.redAdd(c);\n // H = B + A\n var h = b.redAdd(a);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projAdd = function _projAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #addition-add-2008-bbjlp\n // #addition-add-2007-bl\n // 10M + 1S\n\n // A = Z1 * Z2\n var a = this.z.redMul(p.z);\n // B = A^2\n var b = a.redSqr();\n // C = X1 * X2\n var c = this.x.redMul(p.x);\n // D = Y1 * Y2\n var d = this.y.redMul(p.y);\n // E = d * C * D\n var e = this.curve.d.redMul(c).redMul(d);\n // F = B - E\n var f = b.redSub(e);\n // G = B + E\n var g = b.redAdd(e);\n // X3 = A * F * ((X1 + Y1) * (X2 + Y2) - C - D)\n var tmp = this.x.redAdd(this.y).redMul(p.x.redAdd(p.y)).redISub(c).redISub(d);\n var nx = a.redMul(f).redMul(tmp);\n var ny;\n var nz;\n if (this.curve.twisted) {\n // Y3 = A * G * (D - a * C)\n ny = a.redMul(g).redMul(d.redSub(this.curve._mulA(c)));\n // Z3 = F * G\n nz = f.redMul(g);\n } else {\n // Y3 = A * G * (D - C)\n ny = a.redMul(g).redMul(d.redSub(c));\n // Z3 = c * F * G\n nz = this.curve._mulC(f).redMul(g);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.add = function add(p) {\n if (this.isInfinity())\n return p;\n if (p.isInfinity())\n return this;\n\n if (this.curve.extended)\n return this._extAdd(p);\n else\n return this._projAdd(p);\n};\n\nPoint.prototype.mul = function mul(k) {\n if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, false);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, true);\n};\n\nPoint.prototype.normalize = function normalize() {\n if (this.zOne)\n return this;\n\n // Normalize coordinates\n var zi = this.z.redInvm();\n this.x = this.x.redMul(zi);\n this.y = this.y.redMul(zi);\n if (this.t)\n this.t = this.t.redMul(zi);\n this.z = this.curve.one;\n this.zOne = true;\n return this;\n};\n\nPoint.prototype.neg = function neg() {\n return this.curve.point(this.x.redNeg(),\n this.y,\n this.z,\n this.t && this.t.redNeg());\n};\n\nPoint.prototype.getX = function getX() {\n this.normalize();\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n this.normalize();\n return this.y.fromRed();\n};\n\nPoint.prototype.eq = function eq(other) {\n return this === other ||\n this.getX().cmp(other.getX()) === 0 &&\n this.getY().cmp(other.getY()) === 0;\n};\n\nPoint.prototype.eqXToP = function eqXToP(x) {\n var rx = x.toRed(this.curve.red).redMul(this.z);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(this.z);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\n// Compatibility with BaseCurve\nPoint.prototype.toP = Point.prototype.normalize;\nPoint.prototype.mixedAdd = Point.prototype.add;\n","'use strict';\n\nvar curves = exports;\n\nvar hash = require('hash.js');\nvar curve = require('./curve');\nvar utils = require('./utils');\n\nvar assert = utils.assert;\n\nfunction PresetCurve(options) {\n if (options.type === 'short')\n this.curve = new curve.short(options);\n else if (options.type === 'edwards')\n this.curve = new curve.edwards(options);\n else\n this.curve = new curve.mont(options);\n this.g = this.curve.g;\n this.n = this.curve.n;\n this.hash = options.hash;\n\n assert(this.g.validate(), 'Invalid curve');\n assert(this.g.mul(this.n).isInfinity(), 'Invalid curve, G*N != O');\n}\ncurves.PresetCurve = PresetCurve;\n\nfunction defineCurve(name, options) {\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n get: function() {\n var curve = new PresetCurve(options);\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n value: curve,\n });\n return curve;\n },\n });\n}\n\ndefineCurve('p192', {\n type: 'short',\n prime: 'p192',\n p: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc',\n b: '64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1',\n n: 'ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831',\n hash: hash.sha256,\n gRed: false,\n g: [\n '188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012',\n '07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811',\n ],\n});\n\ndefineCurve('p224', {\n type: 'short',\n prime: 'p224',\n p: 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe',\n b: 'b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4',\n n: 'ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d',\n hash: hash.sha256,\n gRed: false,\n g: [\n 'b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21',\n 'bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34',\n ],\n});\n\ndefineCurve('p256', {\n type: 'short',\n prime: null,\n p: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff',\n a: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc',\n b: '5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b',\n n: 'ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551',\n hash: hash.sha256,\n gRed: false,\n g: [\n '6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296',\n '4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5',\n ],\n});\n\ndefineCurve('p384', {\n type: 'short',\n prime: null,\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 ffffffff',\n a: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 fffffffc',\n b: 'b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f ' +\n '5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef',\n n: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 ' +\n 'f4372ddf 581a0db2 48b0a77a ecec196a ccc52973',\n hash: hash.sha384,\n gRed: false,\n g: [\n 'aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 ' +\n '5502f25d bf55296c 3a545e38 72760ab7',\n '3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 ' +\n '0a60b1ce 1d7e819d 7a431d7c 90ea0e5f',\n ],\n});\n\ndefineCurve('p521', {\n type: 'short',\n prime: null,\n p: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff',\n a: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff fffffffc',\n b: '00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b ' +\n '99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd ' +\n '3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00',\n n: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 ' +\n 'f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409',\n hash: hash.sha512,\n gRed: false,\n g: [\n '000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 ' +\n '053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 ' +\n 'a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66',\n '00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 ' +\n '579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 ' +\n '3fad0761 353c7086 a272c240 88be9476 9fd16650',\n ],\n});\n\ndefineCurve('curve25519', {\n type: 'mont',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '76d06',\n b: '1',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '9',\n ],\n});\n\ndefineCurve('ed25519', {\n type: 'edwards',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '-1',\n c: '1',\n // -121665 * (121666^(-1)) (mod P)\n d: '52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a',\n\n // 4/5\n '6666666666666666666666666666666666666666666666666666666666666658',\n ],\n});\n\nvar pre;\ntry {\n pre = require('./precomputed/secp256k1');\n} catch (e) {\n pre = undefined;\n}\n\ndefineCurve('secp256k1', {\n type: 'short',\n prime: 'k256',\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f',\n a: '0',\n b: '7',\n n: 'ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141',\n h: '1',\n hash: hash.sha256,\n\n // Precomputed endomorphism\n beta: '7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee',\n lambda: '5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72',\n basis: [\n {\n a: '3086d221a7d46bcde86c90e49284eb15',\n b: '-e4437ed6010e88286f547fa90abfe4c3',\n },\n {\n a: '114ca50f7a8e2f3f657c1108d9d44cfd8',\n b: '3086d221a7d46bcde86c90e49284eb15',\n },\n ],\n\n gRed: false,\n g: [\n '79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',\n '483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',\n pre,\n ],\n});\n","var hash = exports;\n\nhash.utils = require('./hash/utils');\nhash.common = require('./hash/common');\nhash.sha = require('./hash/sha');\nhash.ripemd = require('./hash/ripemd');\nhash.hmac = require('./hash/hmac');\n\n// Proxy hash functions to the main object\nhash.sha1 = hash.sha.sha1;\nhash.sha256 = hash.sha.sha256;\nhash.sha224 = hash.sha.sha224;\nhash.sha384 = hash.sha.sha384;\nhash.sha512 = hash.sha.sha512;\nhash.ripemd160 = hash.ripemd.ripemd160;\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nexports.inherits = inherits;\n\nfunction isSurrogatePair(msg, i) {\n if ((msg.charCodeAt(i) & 0xFC00) !== 0xD800) {\n return false;\n }\n if (i < 0 || i + 1 >= msg.length) {\n return false;\n }\n return (msg.charCodeAt(i + 1) & 0xFC00) === 0xDC00;\n}\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg === 'string') {\n if (!enc) {\n // Inspired by stringToUtf8ByteArray() in closure-library by Google\n // https://github.com/google/closure-library/blob/8598d87242af59aac233270742c8984e2b2bdbe0/closure/goog/crypt/crypt.js#L117-L143\n // Apache License 2.0\n // https://github.com/google/closure-library/blob/master/LICENSE\n var p = 0;\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n if (c < 128) {\n res[p++] = c;\n } else if (c < 2048) {\n res[p++] = (c >> 6) | 192;\n res[p++] = (c & 63) | 128;\n } else if (isSurrogatePair(msg, i)) {\n c = 0x10000 + ((c & 0x03FF) << 10) + (msg.charCodeAt(++i) & 0x03FF);\n res[p++] = (c >> 18) | 240;\n res[p++] = ((c >> 12) & 63) | 128;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n } else {\n res[p++] = (c >> 12) | 224;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n }\n }\n } else if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n }\n } else {\n for (i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n }\n return res;\n}\nexports.toArray = toArray;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nexports.toHex = toHex;\n\nfunction htonl(w) {\n var res = (w >>> 24) |\n ((w >>> 8) & 0xff00) |\n ((w << 8) & 0xff0000) |\n ((w & 0xff) << 24);\n return res >>> 0;\n}\nexports.htonl = htonl;\n\nfunction toHex32(msg, endian) {\n var res = '';\n for (var i = 0; i < msg.length; i++) {\n var w = msg[i];\n if (endian === 'little')\n w = htonl(w);\n res += zero8(w.toString(16));\n }\n return res;\n}\nexports.toHex32 = toHex32;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nexports.zero2 = zero2;\n\nfunction zero8(word) {\n if (word.length === 7)\n return '0' + word;\n else if (word.length === 6)\n return '00' + word;\n else if (word.length === 5)\n return '000' + word;\n else if (word.length === 4)\n return '0000' + word;\n else if (word.length === 3)\n return '00000' + word;\n else if (word.length === 2)\n return '000000' + word;\n else if (word.length === 1)\n return '0000000' + word;\n else\n return word;\n}\nexports.zero8 = zero8;\n\nfunction join32(msg, start, end, endian) {\n var len = end - start;\n assert(len % 4 === 0);\n var res = new Array(len / 4);\n for (var i = 0, k = start; i < res.length; i++, k += 4) {\n var w;\n if (endian === 'big')\n w = (msg[k] << 24) | (msg[k + 1] << 16) | (msg[k + 2] << 8) | msg[k + 3];\n else\n w = (msg[k + 3] << 24) | (msg[k + 2] << 16) | (msg[k + 1] << 8) | msg[k];\n res[i] = w >>> 0;\n }\n return res;\n}\nexports.join32 = join32;\n\nfunction split32(msg, endian) {\n var res = new Array(msg.length * 4);\n for (var i = 0, k = 0; i < msg.length; i++, k += 4) {\n var m = msg[i];\n if (endian === 'big') {\n res[k] = m >>> 24;\n res[k + 1] = (m >>> 16) & 0xff;\n res[k + 2] = (m >>> 8) & 0xff;\n res[k + 3] = m & 0xff;\n } else {\n res[k + 3] = m >>> 24;\n res[k + 2] = (m >>> 16) & 0xff;\n res[k + 1] = (m >>> 8) & 0xff;\n res[k] = m & 0xff;\n }\n }\n return res;\n}\nexports.split32 = split32;\n\nfunction rotr32(w, b) {\n return (w >>> b) | (w << (32 - b));\n}\nexports.rotr32 = rotr32;\n\nfunction rotl32(w, b) {\n return (w << b) | (w >>> (32 - b));\n}\nexports.rotl32 = rotl32;\n\nfunction sum32(a, b) {\n return (a + b) >>> 0;\n}\nexports.sum32 = sum32;\n\nfunction sum32_3(a, b, c) {\n return (a + b + c) >>> 0;\n}\nexports.sum32_3 = sum32_3;\n\nfunction sum32_4(a, b, c, d) {\n return (a + b + c + d) >>> 0;\n}\nexports.sum32_4 = sum32_4;\n\nfunction sum32_5(a, b, c, d, e) {\n return (a + b + c + d + e) >>> 0;\n}\nexports.sum32_5 = sum32_5;\n\nfunction sum64(buf, pos, ah, al) {\n var bh = buf[pos];\n var bl = buf[pos + 1];\n\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n buf[pos] = hi >>> 0;\n buf[pos + 1] = lo;\n}\nexports.sum64 = sum64;\n\nfunction sum64_hi(ah, al, bh, bl) {\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n return hi >>> 0;\n}\nexports.sum64_hi = sum64_hi;\n\nfunction sum64_lo(ah, al, bh, bl) {\n var lo = al + bl;\n return lo >>> 0;\n}\nexports.sum64_lo = sum64_lo;\n\nfunction sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n\n var hi = ah + bh + ch + dh + carry;\n return hi >>> 0;\n}\nexports.sum64_4_hi = sum64_4_hi;\n\nfunction sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) {\n var lo = al + bl + cl + dl;\n return lo >>> 0;\n}\nexports.sum64_4_lo = sum64_4_lo;\n\nfunction sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n lo = (lo + el) >>> 0;\n carry += lo < el ? 1 : 0;\n\n var hi = ah + bh + ch + dh + eh + carry;\n return hi >>> 0;\n}\nexports.sum64_5_hi = sum64_5_hi;\n\nfunction sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var lo = al + bl + cl + dl + el;\n\n return lo >>> 0;\n}\nexports.sum64_5_lo = sum64_5_lo;\n\nfunction rotr64_hi(ah, al, num) {\n var r = (al << (32 - num)) | (ah >>> num);\n return r >>> 0;\n}\nexports.rotr64_hi = rotr64_hi;\n\nfunction rotr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.rotr64_lo = rotr64_lo;\n\nfunction shr64_hi(ah, al, num) {\n return ah >>> num;\n}\nexports.shr64_hi = shr64_hi;\n\nfunction shr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.shr64_lo = shr64_lo;\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction BlockHash() {\n this.pending = null;\n this.pendingTotal = 0;\n this.blockSize = this.constructor.blockSize;\n this.outSize = this.constructor.outSize;\n this.hmacStrength = this.constructor.hmacStrength;\n this.padLength = this.constructor.padLength / 8;\n this.endian = 'big';\n\n this._delta8 = this.blockSize / 8;\n this._delta32 = this.blockSize / 32;\n}\nexports.BlockHash = BlockHash;\n\nBlockHash.prototype.update = function update(msg, enc) {\n // Convert message to array, pad it, and join into 32bit blocks\n msg = utils.toArray(msg, enc);\n if (!this.pending)\n this.pending = msg;\n else\n this.pending = this.pending.concat(msg);\n this.pendingTotal += msg.length;\n\n // Enough data, try updating\n if (this.pending.length >= this._delta8) {\n msg = this.pending;\n\n // Process pending data in blocks\n var r = msg.length % this._delta8;\n this.pending = msg.slice(msg.length - r, msg.length);\n if (this.pending.length === 0)\n this.pending = null;\n\n msg = utils.join32(msg, 0, msg.length - r, this.endian);\n for (var i = 0; i < msg.length; i += this._delta32)\n this._update(msg, i, i + this._delta32);\n }\n\n return this;\n};\n\nBlockHash.prototype.digest = function digest(enc) {\n this.update(this._pad());\n assert(this.pending === null);\n\n return this._digest(enc);\n};\n\nBlockHash.prototype._pad = function pad() {\n var len = this.pendingTotal;\n var bytes = this._delta8;\n var k = bytes - ((len + this.padLength) % bytes);\n var res = new Array(k + this.padLength);\n res[0] = 0x80;\n for (var i = 1; i < k; i++)\n res[i] = 0;\n\n // Append length\n len <<= 3;\n if (this.endian === 'big') {\n for (var t = 8; t < this.padLength; t++)\n res[i++] = 0;\n\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = len & 0xff;\n } else {\n res[i++] = len & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n\n for (t = 8; t < this.padLength; t++)\n res[i++] = 0;\n }\n\n return res;\n};\n","'use strict';\n\nexports.sha1 = require('./sha/1');\nexports.sha224 = require('./sha/224');\nexports.sha256 = require('./sha/256');\nexports.sha384 = require('./sha/384');\nexports.sha512 = require('./sha/512');\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_5 = utils.sum32_5;\nvar ft_1 = shaCommon.ft_1;\nvar BlockHash = common.BlockHash;\n\nvar sha1_K = [\n 0x5A827999, 0x6ED9EBA1,\n 0x8F1BBCDC, 0xCA62C1D6\n];\n\nfunction SHA1() {\n if (!(this instanceof SHA1))\n return new SHA1();\n\n BlockHash.call(this);\n this.h = [\n 0x67452301, 0xefcdab89, 0x98badcfe,\n 0x10325476, 0xc3d2e1f0 ];\n this.W = new Array(80);\n}\n\nutils.inherits(SHA1, BlockHash);\nmodule.exports = SHA1;\n\nSHA1.blockSize = 512;\nSHA1.outSize = 160;\nSHA1.hmacStrength = 80;\nSHA1.padLength = 64;\n\nSHA1.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n\n for(; i < W.length; i++)\n W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n\n for (i = 0; i < W.length; i++) {\n var s = ~~(i / 20);\n var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]);\n e = d;\n d = c;\n c = rotl32(b, 30);\n b = a;\n a = t;\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n};\n\nSHA1.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar rotr32 = utils.rotr32;\n\nfunction ft_1(s, x, y, z) {\n if (s === 0)\n return ch32(x, y, z);\n if (s === 1 || s === 3)\n return p32(x, y, z);\n if (s === 2)\n return maj32(x, y, z);\n}\nexports.ft_1 = ft_1;\n\nfunction ch32(x, y, z) {\n return (x & y) ^ ((~x) & z);\n}\nexports.ch32 = ch32;\n\nfunction maj32(x, y, z) {\n return (x & y) ^ (x & z) ^ (y & z);\n}\nexports.maj32 = maj32;\n\nfunction p32(x, y, z) {\n return x ^ y ^ z;\n}\nexports.p32 = p32;\n\nfunction s0_256(x) {\n return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22);\n}\nexports.s0_256 = s0_256;\n\nfunction s1_256(x) {\n return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25);\n}\nexports.s1_256 = s1_256;\n\nfunction g0_256(x) {\n return rotr32(x, 7) ^ rotr32(x, 18) ^ (x >>> 3);\n}\nexports.g0_256 = g0_256;\n\nfunction g1_256(x) {\n return rotr32(x, 17) ^ rotr32(x, 19) ^ (x >>> 10);\n}\nexports.g1_256 = g1_256;\n","'use strict';\n\nvar utils = require('../utils');\nvar SHA256 = require('./256');\n\nfunction SHA224() {\n if (!(this instanceof SHA224))\n return new SHA224();\n\n SHA256.call(this);\n this.h = [\n 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 ];\n}\nutils.inherits(SHA224, SHA256);\nmodule.exports = SHA224;\n\nSHA224.blockSize = 512;\nSHA224.outSize = 224;\nSHA224.hmacStrength = 192;\nSHA224.padLength = 64;\n\nSHA224.prototype._digest = function digest(enc) {\n // Just truncate output\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 7), 'big');\n else\n return utils.split32(this.h.slice(0, 7), 'big');\n};\n\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\nvar assert = require('minimalistic-assert');\n\nvar sum32 = utils.sum32;\nvar sum32_4 = utils.sum32_4;\nvar sum32_5 = utils.sum32_5;\nvar ch32 = shaCommon.ch32;\nvar maj32 = shaCommon.maj32;\nvar s0_256 = shaCommon.s0_256;\nvar s1_256 = shaCommon.s1_256;\nvar g0_256 = shaCommon.g0_256;\nvar g1_256 = shaCommon.g1_256;\n\nvar BlockHash = common.BlockHash;\n\nvar sha256_K = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n];\n\nfunction SHA256() {\n if (!(this instanceof SHA256))\n return new SHA256();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a,\n 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19\n ];\n this.k = sha256_K;\n this.W = new Array(64);\n}\nutils.inherits(SHA256, BlockHash);\nmodule.exports = SHA256;\n\nSHA256.blockSize = 512;\nSHA256.outSize = 256;\nSHA256.hmacStrength = 192;\nSHA256.padLength = 64;\n\nSHA256.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i++)\n W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n var f = this.h[5];\n var g = this.h[6];\n var h = this.h[7];\n\n assert(this.k.length === W.length);\n for (i = 0; i < W.length; i++) {\n var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]);\n var T2 = sum32(s0_256(a), maj32(a, b, c));\n h = g;\n g = f;\n f = e;\n e = sum32(d, T1);\n d = c;\n c = b;\n b = a;\n a = sum32(T1, T2);\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n this.h[5] = sum32(this.h[5], f);\n this.h[6] = sum32(this.h[6], g);\n this.h[7] = sum32(this.h[7], h);\n};\n\nSHA256.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\n\nvar SHA512 = require('./512');\n\nfunction SHA384() {\n if (!(this instanceof SHA384))\n return new SHA384();\n\n SHA512.call(this);\n this.h = [\n 0xcbbb9d5d, 0xc1059ed8,\n 0x629a292a, 0x367cd507,\n 0x9159015a, 0x3070dd17,\n 0x152fecd8, 0xf70e5939,\n 0x67332667, 0xffc00b31,\n 0x8eb44a87, 0x68581511,\n 0xdb0c2e0d, 0x64f98fa7,\n 0x47b5481d, 0xbefa4fa4 ];\n}\nutils.inherits(SHA384, SHA512);\nmodule.exports = SHA384;\n\nSHA384.blockSize = 1024;\nSHA384.outSize = 384;\nSHA384.hmacStrength = 192;\nSHA384.padLength = 128;\n\nSHA384.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 12), 'big');\n else\n return utils.split32(this.h.slice(0, 12), 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar assert = require('minimalistic-assert');\n\nvar rotr64_hi = utils.rotr64_hi;\nvar rotr64_lo = utils.rotr64_lo;\nvar shr64_hi = utils.shr64_hi;\nvar shr64_lo = utils.shr64_lo;\nvar sum64 = utils.sum64;\nvar sum64_hi = utils.sum64_hi;\nvar sum64_lo = utils.sum64_lo;\nvar sum64_4_hi = utils.sum64_4_hi;\nvar sum64_4_lo = utils.sum64_4_lo;\nvar sum64_5_hi = utils.sum64_5_hi;\nvar sum64_5_lo = utils.sum64_5_lo;\n\nvar BlockHash = common.BlockHash;\n\nvar sha512_K = [\n 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n];\n\nfunction SHA512() {\n if (!(this instanceof SHA512))\n return new SHA512();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xf3bcc908,\n 0xbb67ae85, 0x84caa73b,\n 0x3c6ef372, 0xfe94f82b,\n 0xa54ff53a, 0x5f1d36f1,\n 0x510e527f, 0xade682d1,\n 0x9b05688c, 0x2b3e6c1f,\n 0x1f83d9ab, 0xfb41bd6b,\n 0x5be0cd19, 0x137e2179 ];\n this.k = sha512_K;\n this.W = new Array(160);\n}\nutils.inherits(SHA512, BlockHash);\nmodule.exports = SHA512;\n\nSHA512.blockSize = 1024;\nSHA512.outSize = 512;\nSHA512.hmacStrength = 192;\nSHA512.padLength = 128;\n\nSHA512.prototype._prepareBlock = function _prepareBlock(msg, start) {\n var W = this.W;\n\n // 32 x 32bit words\n for (var i = 0; i < 32; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i += 2) {\n var c0_hi = g1_512_hi(W[i - 4], W[i - 3]); // i - 2\n var c0_lo = g1_512_lo(W[i - 4], W[i - 3]);\n var c1_hi = W[i - 14]; // i - 7\n var c1_lo = W[i - 13];\n var c2_hi = g0_512_hi(W[i - 30], W[i - 29]); // i - 15\n var c2_lo = g0_512_lo(W[i - 30], W[i - 29]);\n var c3_hi = W[i - 32]; // i - 16\n var c3_lo = W[i - 31];\n\n W[i] = sum64_4_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n W[i + 1] = sum64_4_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n }\n};\n\nSHA512.prototype._update = function _update(msg, start) {\n this._prepareBlock(msg, start);\n\n var W = this.W;\n\n var ah = this.h[0];\n var al = this.h[1];\n var bh = this.h[2];\n var bl = this.h[3];\n var ch = this.h[4];\n var cl = this.h[5];\n var dh = this.h[6];\n var dl = this.h[7];\n var eh = this.h[8];\n var el = this.h[9];\n var fh = this.h[10];\n var fl = this.h[11];\n var gh = this.h[12];\n var gl = this.h[13];\n var hh = this.h[14];\n var hl = this.h[15];\n\n assert(this.k.length === W.length);\n for (var i = 0; i < W.length; i += 2) {\n var c0_hi = hh;\n var c0_lo = hl;\n var c1_hi = s1_512_hi(eh, el);\n var c1_lo = s1_512_lo(eh, el);\n var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl);\n var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl);\n var c3_hi = this.k[i];\n var c3_lo = this.k[i + 1];\n var c4_hi = W[i];\n var c4_lo = W[i + 1];\n\n var T1_hi = sum64_5_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n var T1_lo = sum64_5_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n\n c0_hi = s0_512_hi(ah, al);\n c0_lo = s0_512_lo(ah, al);\n c1_hi = maj64_hi(ah, al, bh, bl, ch, cl);\n c1_lo = maj64_lo(ah, al, bh, bl, ch, cl);\n\n var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo);\n var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo);\n\n hh = gh;\n hl = gl;\n\n gh = fh;\n gl = fl;\n\n fh = eh;\n fl = el;\n\n eh = sum64_hi(dh, dl, T1_hi, T1_lo);\n el = sum64_lo(dl, dl, T1_hi, T1_lo);\n\n dh = ch;\n dl = cl;\n\n ch = bh;\n cl = bl;\n\n bh = ah;\n bl = al;\n\n ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo);\n al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo);\n }\n\n sum64(this.h, 0, ah, al);\n sum64(this.h, 2, bh, bl);\n sum64(this.h, 4, ch, cl);\n sum64(this.h, 6, dh, dl);\n sum64(this.h, 8, eh, el);\n sum64(this.h, 10, fh, fl);\n sum64(this.h, 12, gh, gl);\n sum64(this.h, 14, hh, hl);\n};\n\nSHA512.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n\nfunction ch64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ ((~xh) & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction ch64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ ((~xl) & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ (xh & zh) ^ (yh & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ (xl & zl) ^ (yl & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 28);\n var c1_hi = rotr64_hi(xl, xh, 2); // 34\n var c2_hi = rotr64_hi(xl, xh, 7); // 39\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 28);\n var c1_lo = rotr64_lo(xl, xh, 2); // 34\n var c2_lo = rotr64_lo(xl, xh, 7); // 39\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 14);\n var c1_hi = rotr64_hi(xh, xl, 18);\n var c2_hi = rotr64_hi(xl, xh, 9); // 41\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 14);\n var c1_lo = rotr64_lo(xh, xl, 18);\n var c2_lo = rotr64_lo(xl, xh, 9); // 41\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 1);\n var c1_hi = rotr64_hi(xh, xl, 8);\n var c2_hi = shr64_hi(xh, xl, 7);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 1);\n var c1_lo = rotr64_lo(xh, xl, 8);\n var c2_lo = shr64_lo(xh, xl, 7);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 19);\n var c1_hi = rotr64_hi(xl, xh, 29); // 61\n var c2_hi = shr64_hi(xh, xl, 6);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 19);\n var c1_lo = rotr64_lo(xl, xh, 29); // 61\n var c2_lo = shr64_lo(xh, xl, 6);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n","'use strict';\n\nvar utils = require('./utils');\nvar common = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_3 = utils.sum32_3;\nvar sum32_4 = utils.sum32_4;\nvar BlockHash = common.BlockHash;\n\nfunction RIPEMD160() {\n if (!(this instanceof RIPEMD160))\n return new RIPEMD160();\n\n BlockHash.call(this);\n\n this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ];\n this.endian = 'little';\n}\nutils.inherits(RIPEMD160, BlockHash);\nexports.ripemd160 = RIPEMD160;\n\nRIPEMD160.blockSize = 512;\nRIPEMD160.outSize = 160;\nRIPEMD160.hmacStrength = 192;\nRIPEMD160.padLength = 64;\n\nRIPEMD160.prototype._update = function update(msg, start) {\n var A = this.h[0];\n var B = this.h[1];\n var C = this.h[2];\n var D = this.h[3];\n var E = this.h[4];\n var Ah = A;\n var Bh = B;\n var Ch = C;\n var Dh = D;\n var Eh = E;\n for (var j = 0; j < 80; j++) {\n var T = sum32(\n rotl32(\n sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)),\n s[j]),\n E);\n A = E;\n E = D;\n D = rotl32(C, 10);\n C = B;\n B = T;\n T = sum32(\n rotl32(\n sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)),\n sh[j]),\n Eh);\n Ah = Eh;\n Eh = Dh;\n Dh = rotl32(Ch, 10);\n Ch = Bh;\n Bh = T;\n }\n T = sum32_3(this.h[1], C, Dh);\n this.h[1] = sum32_3(this.h[2], D, Eh);\n this.h[2] = sum32_3(this.h[3], E, Ah);\n this.h[3] = sum32_3(this.h[4], A, Bh);\n this.h[4] = sum32_3(this.h[0], B, Ch);\n this.h[0] = T;\n};\n\nRIPEMD160.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'little');\n else\n return utils.split32(this.h, 'little');\n};\n\nfunction f(j, x, y, z) {\n if (j <= 15)\n return x ^ y ^ z;\n else if (j <= 31)\n return (x & y) | ((~x) & z);\n else if (j <= 47)\n return (x | (~y)) ^ z;\n else if (j <= 63)\n return (x & z) | (y & (~z));\n else\n return x ^ (y | (~z));\n}\n\nfunction K(j) {\n if (j <= 15)\n return 0x00000000;\n else if (j <= 31)\n return 0x5a827999;\n else if (j <= 47)\n return 0x6ed9eba1;\n else if (j <= 63)\n return 0x8f1bbcdc;\n else\n return 0xa953fd4e;\n}\n\nfunction Kh(j) {\n if (j <= 15)\n return 0x50a28be6;\n else if (j <= 31)\n return 0x5c4dd124;\n else if (j <= 47)\n return 0x6d703ef3;\n else if (j <= 63)\n return 0x7a6d76e9;\n else\n return 0x00000000;\n}\n\nvar r = [\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n];\n\nvar rh = [\n 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n];\n\nvar s = [\n 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n];\n\nvar sh = [\n 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n];\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction Hmac(hash, key, enc) {\n if (!(this instanceof Hmac))\n return new Hmac(hash, key, enc);\n this.Hash = hash;\n this.blockSize = hash.blockSize / 8;\n this.outSize = hash.outSize / 8;\n this.inner = null;\n this.outer = null;\n\n this._init(utils.toArray(key, enc));\n}\nmodule.exports = Hmac;\n\nHmac.prototype._init = function init(key) {\n // Shorten key, if needed\n if (key.length > this.blockSize)\n key = new this.Hash().update(key).digest();\n assert(key.length <= this.blockSize);\n\n // Add padding to key\n for (var i = key.length; i < this.blockSize; i++)\n key.push(0);\n\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x36;\n this.inner = new this.Hash().update(key);\n\n // 0x36 ^ 0x5c = 0x6a\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x6a;\n this.outer = new this.Hash().update(key);\n};\n\nHmac.prototype.update = function update(msg, enc) {\n this.inner.update(msg, enc);\n return this;\n};\n\nHmac.prototype.digest = function digest(enc) {\n this.outer.update(this.inner.digest());\n return this.outer.digest(enc);\n};\n","module.exports = {\n doubles: {\n step: 4,\n points: [\n [\n 'e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a',\n 'f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821',\n ],\n [\n '8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508',\n '11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf',\n ],\n [\n '175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739',\n 'd3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695',\n ],\n [\n '363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640',\n '4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9',\n ],\n [\n '8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c',\n '4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36',\n ],\n [\n '723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda',\n '96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f',\n ],\n [\n 'eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa',\n '5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999',\n ],\n [\n '100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0',\n 'cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09',\n ],\n [\n 'e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d',\n '9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d',\n ],\n [\n 'feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d',\n 'e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088',\n ],\n [\n 'da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1',\n '9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d',\n ],\n [\n '53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0',\n '5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8',\n ],\n [\n '8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047',\n '10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a',\n ],\n [\n '385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862',\n '283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453',\n ],\n [\n '6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7',\n '7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160',\n ],\n [\n '3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd',\n '56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0',\n ],\n [\n '85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83',\n '7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6',\n ],\n [\n '948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a',\n '53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589',\n ],\n [\n '6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8',\n 'bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17',\n ],\n [\n 'e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d',\n '4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda',\n ],\n [\n 'e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725',\n '7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd',\n ],\n [\n '213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754',\n '4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2',\n ],\n [\n '4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c',\n '17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6',\n ],\n [\n 'fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6',\n '6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f',\n ],\n [\n '76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39',\n 'c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01',\n ],\n [\n 'c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891',\n '893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3',\n ],\n [\n 'd895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b',\n 'febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f',\n ],\n [\n 'b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03',\n '2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7',\n ],\n [\n 'e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d',\n 'eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78',\n ],\n [\n 'a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070',\n '7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1',\n ],\n [\n '90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4',\n 'e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150',\n ],\n [\n '8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da',\n '662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82',\n ],\n [\n 'e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11',\n '1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc',\n ],\n [\n '8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e',\n 'efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b',\n ],\n [\n 'e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41',\n '2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51',\n ],\n [\n 'b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef',\n '67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45',\n ],\n [\n 'd68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8',\n 'db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120',\n ],\n [\n '324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d',\n '648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84',\n ],\n [\n '4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96',\n '35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d',\n ],\n [\n '9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd',\n 'ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d',\n ],\n [\n '6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5',\n '9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8',\n ],\n [\n 'a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266',\n '40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8',\n ],\n [\n '7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71',\n '34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac',\n ],\n [\n '928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac',\n 'c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f',\n ],\n [\n '85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751',\n '1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962',\n ],\n [\n 'ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e',\n '493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907',\n ],\n [\n '827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241',\n 'c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec',\n ],\n [\n 'eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3',\n 'be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d',\n ],\n [\n 'e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f',\n '4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414',\n ],\n [\n '1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19',\n 'aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd',\n ],\n [\n '146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be',\n 'b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0',\n ],\n [\n 'fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9',\n '6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811',\n ],\n [\n 'da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2',\n '8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1',\n ],\n [\n 'a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13',\n '7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c',\n ],\n [\n '174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c',\n 'ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73',\n ],\n [\n '959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba',\n '2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd',\n ],\n [\n 'd2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151',\n 'e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405',\n ],\n [\n '64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073',\n 'd99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589',\n ],\n [\n '8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458',\n '38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e',\n ],\n [\n '13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b',\n '69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27',\n ],\n [\n 'bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366',\n 'd3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1',\n ],\n [\n '8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa',\n '40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482',\n ],\n [\n '8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0',\n '620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945',\n ],\n [\n 'dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787',\n '7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573',\n ],\n [\n 'f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e',\n 'ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82',\n ],\n ],\n },\n naf: {\n wnd: 7,\n points: [\n [\n 'f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9',\n '388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672',\n ],\n [\n '2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4',\n 'd8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6',\n ],\n [\n '5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc',\n '6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da',\n ],\n [\n 'acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe',\n 'cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37',\n ],\n [\n '774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb',\n 'd984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b',\n ],\n [\n 'f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8',\n 'ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81',\n ],\n [\n 'd7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e',\n '581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58',\n ],\n [\n 'defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34',\n '4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77',\n ],\n [\n '2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c',\n '85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a',\n ],\n [\n '352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5',\n '321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c',\n ],\n [\n '2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f',\n '2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67',\n ],\n [\n '9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714',\n '73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402',\n ],\n [\n 'daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729',\n 'a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55',\n ],\n [\n 'c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db',\n '2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482',\n ],\n [\n '6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4',\n 'e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82',\n ],\n [\n '1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5',\n 'b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396',\n ],\n [\n '605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479',\n '2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49',\n ],\n [\n '62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d',\n '80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf',\n ],\n [\n '80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f',\n '1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a',\n ],\n [\n '7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb',\n 'd0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7',\n ],\n [\n 'd528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9',\n 'eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933',\n ],\n [\n '49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963',\n '758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a',\n ],\n [\n '77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74',\n '958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6',\n ],\n [\n 'f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530',\n 'e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37',\n ],\n [\n '463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b',\n '5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e',\n ],\n [\n 'f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247',\n 'cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6',\n ],\n [\n 'caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1',\n 'cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476',\n ],\n [\n '2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120',\n '4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40',\n ],\n [\n '7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435',\n '91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61',\n ],\n [\n '754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18',\n '673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683',\n ],\n [\n 'e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8',\n '59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5',\n ],\n [\n '186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb',\n '3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b',\n ],\n [\n 'df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f',\n '55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417',\n ],\n [\n '5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143',\n 'efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868',\n ],\n [\n '290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba',\n 'e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a',\n ],\n [\n 'af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45',\n 'f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6',\n ],\n [\n '766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a',\n '744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996',\n ],\n [\n '59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e',\n 'c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e',\n ],\n [\n 'f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8',\n 'e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d',\n ],\n [\n '7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c',\n '30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2',\n ],\n [\n '948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519',\n 'e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e',\n ],\n [\n '7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab',\n '100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437',\n ],\n [\n '3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca',\n 'ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311',\n ],\n [\n 'd3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf',\n '8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4',\n ],\n [\n '1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610',\n '68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575',\n ],\n [\n '733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4',\n 'f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d',\n ],\n [\n '15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c',\n 'd56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d',\n ],\n [\n 'a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940',\n 'edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629',\n ],\n [\n 'e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980',\n 'a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06',\n ],\n [\n '311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3',\n '66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374',\n ],\n [\n '34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf',\n '9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee',\n ],\n [\n 'f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63',\n '4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1',\n ],\n [\n 'd7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448',\n 'fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b',\n ],\n [\n '32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf',\n '5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661',\n ],\n [\n '7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5',\n '8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6',\n ],\n [\n 'ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6',\n '8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e',\n ],\n [\n '16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5',\n '5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d',\n ],\n [\n 'eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99',\n 'f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc',\n ],\n [\n '78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51',\n 'f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4',\n ],\n [\n '494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5',\n '42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c',\n ],\n [\n 'a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5',\n '204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b',\n ],\n [\n 'c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997',\n '4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913',\n ],\n [\n '841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881',\n '73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154',\n ],\n [\n '5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5',\n '39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865',\n ],\n [\n '36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66',\n 'd2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc',\n ],\n [\n '336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726',\n 'ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224',\n ],\n [\n '8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede',\n '6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e',\n ],\n [\n '1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94',\n '60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6',\n ],\n [\n '85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31',\n '3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511',\n ],\n [\n '29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51',\n 'b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b',\n ],\n [\n 'a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252',\n 'ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2',\n ],\n [\n '4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5',\n 'cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c',\n ],\n [\n 'd24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b',\n '6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3',\n ],\n [\n 'ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4',\n '322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d',\n ],\n [\n 'af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f',\n '6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700',\n ],\n [\n 'e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889',\n '2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4',\n ],\n [\n '591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246',\n 'b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196',\n ],\n [\n '11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984',\n '998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4',\n ],\n [\n '3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a',\n 'b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257',\n ],\n [\n 'cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030',\n 'bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13',\n ],\n [\n 'c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197',\n '6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096',\n ],\n [\n 'c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593',\n 'c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38',\n ],\n [\n 'a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef',\n '21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f',\n ],\n [\n '347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38',\n '60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448',\n ],\n [\n 'da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a',\n '49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a',\n ],\n [\n 'c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111',\n '5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4',\n ],\n [\n '4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502',\n '7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437',\n ],\n [\n '3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea',\n 'be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7',\n ],\n [\n 'cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26',\n '8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d',\n ],\n [\n 'b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986',\n '39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a',\n ],\n [\n 'd4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e',\n '62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54',\n ],\n [\n '48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4',\n '25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77',\n ],\n [\n 'dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda',\n 'ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517',\n ],\n [\n '6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859',\n 'cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10',\n ],\n [\n 'e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f',\n 'f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125',\n ],\n [\n 'eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c',\n '6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e',\n ],\n [\n '13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942',\n 'fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1',\n ],\n [\n 'ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a',\n '1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2',\n ],\n [\n 'b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80',\n '5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423',\n ],\n [\n 'ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d',\n '438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8',\n ],\n [\n '8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1',\n 'cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758',\n ],\n [\n '52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63',\n 'c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375',\n ],\n [\n 'e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352',\n '6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d',\n ],\n [\n '7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193',\n 'ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec',\n ],\n [\n '5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00',\n '9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0',\n ],\n [\n '32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58',\n 'ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c',\n ],\n [\n 'e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7',\n 'd3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4',\n ],\n [\n '8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8',\n 'c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f',\n ],\n [\n '4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e',\n '67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649',\n ],\n [\n '3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d',\n 'cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826',\n ],\n [\n '674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b',\n '299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5',\n ],\n [\n 'd32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f',\n 'f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87',\n ],\n [\n '30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6',\n '462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b',\n ],\n [\n 'be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297',\n '62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc',\n ],\n [\n '93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a',\n '7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c',\n ],\n [\n 'b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c',\n 'ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f',\n ],\n [\n 'd5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52',\n '4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a',\n ],\n [\n 'd3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb',\n 'bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46',\n ],\n [\n '463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065',\n 'bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f',\n ],\n [\n '7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917',\n '603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03',\n ],\n [\n '74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9',\n 'cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08',\n ],\n [\n '30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3',\n '553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8',\n ],\n [\n '9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57',\n '712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373',\n ],\n [\n '176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66',\n 'ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3',\n ],\n [\n '75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8',\n '9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8',\n ],\n [\n '809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721',\n '9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1',\n ],\n [\n '1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180',\n '4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9',\n ],\n ],\n },\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar HmacDRBG = require('hmac-drbg');\nvar utils = require('../utils');\nvar curves = require('../curves');\nvar rand = require('brorand');\nvar assert = utils.assert;\n\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EC(options) {\n if (!(this instanceof EC))\n return new EC(options);\n\n // Shortcut `elliptic.ec(curve-name)`\n if (typeof options === 'string') {\n assert(Object.prototype.hasOwnProperty.call(curves, options),\n 'Unknown curve ' + options);\n\n options = curves[options];\n }\n\n // Shortcut for `elliptic.ec(elliptic.curves.curveName)`\n if (options instanceof curves.PresetCurve)\n options = { curve: options };\n\n this.curve = options.curve.curve;\n this.n = this.curve.n;\n this.nh = this.n.ushrn(1);\n this.g = this.curve.g;\n\n // Point on curve\n this.g = options.curve.g;\n this.g.precompute(options.curve.n.bitLength() + 1);\n\n // Hash for function for DRBG\n this.hash = options.hash || options.curve.hash;\n}\nmodule.exports = EC;\n\nEC.prototype.keyPair = function keyPair(options) {\n return new KeyPair(this, options);\n};\n\nEC.prototype.keyFromPrivate = function keyFromPrivate(priv, enc) {\n return KeyPair.fromPrivate(this, priv, enc);\n};\n\nEC.prototype.keyFromPublic = function keyFromPublic(pub, enc) {\n return KeyPair.fromPublic(this, pub, enc);\n};\n\nEC.prototype.genKeyPair = function genKeyPair(options) {\n if (!options)\n options = {};\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n entropy: options.entropy || rand(this.hash.hmacStrength),\n entropyEnc: options.entropy && options.entropyEnc || 'utf8',\n nonce: this.n.toArray(),\n });\n\n var bytes = this.n.byteLength();\n var ns2 = this.n.sub(new BN(2));\n for (;;) {\n var priv = new BN(drbg.generate(bytes));\n if (priv.cmp(ns2) > 0)\n continue;\n\n priv.iaddn(1);\n return this.keyFromPrivate(priv);\n }\n};\n\nEC.prototype._truncateToN = function _truncateToN(msg, truncOnly) {\n var delta = msg.byteLength() * 8 - this.n.bitLength();\n if (delta > 0)\n msg = msg.ushrn(delta);\n if (!truncOnly && msg.cmp(this.n) >= 0)\n return msg.sub(this.n);\n else\n return msg;\n};\n\nEC.prototype.sign = function sign(msg, key, enc, options) {\n if (typeof enc === 'object') {\n options = enc;\n enc = null;\n }\n if (!options)\n options = {};\n\n key = this.keyFromPrivate(key, enc);\n msg = this._truncateToN(new BN(msg, 16));\n\n // Zero-extend key to provide enough entropy\n var bytes = this.n.byteLength();\n var bkey = key.getPrivate().toArray('be', bytes);\n\n // Zero-extend nonce to have the same byte size as N\n var nonce = msg.toArray('be', bytes);\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n entropy: bkey,\n nonce: nonce,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n });\n\n // Number of bytes to generate\n var ns1 = this.n.sub(new BN(1));\n\n for (var iter = 0; ; iter++) {\n var k = options.k ?\n options.k(iter) :\n new BN(drbg.generate(this.n.byteLength()));\n k = this._truncateToN(k, true);\n if (k.cmpn(1) <= 0 || k.cmp(ns1) >= 0)\n continue;\n\n var kp = this.g.mul(k);\n if (kp.isInfinity())\n continue;\n\n var kpX = kp.getX();\n var r = kpX.umod(this.n);\n if (r.cmpn(0) === 0)\n continue;\n\n var s = k.invm(this.n).mul(r.mul(key.getPrivate()).iadd(msg));\n s = s.umod(this.n);\n if (s.cmpn(0) === 0)\n continue;\n\n var recoveryParam = (kp.getY().isOdd() ? 1 : 0) |\n (kpX.cmp(r) !== 0 ? 2 : 0);\n\n // Use complement of `s`, if it is > `n / 2`\n if (options.canonical && s.cmp(this.nh) > 0) {\n s = this.n.sub(s);\n recoveryParam ^= 1;\n }\n\n return new Signature({ r: r, s: s, recoveryParam: recoveryParam });\n }\n};\n\nEC.prototype.verify = function verify(msg, signature, key, enc) {\n msg = this._truncateToN(new BN(msg, 16));\n key = this.keyFromPublic(key, enc);\n signature = new Signature(signature, 'hex');\n\n // Perform primitive values validation\n var r = signature.r;\n var s = signature.s;\n if (r.cmpn(1) < 0 || r.cmp(this.n) >= 0)\n return false;\n if (s.cmpn(1) < 0 || s.cmp(this.n) >= 0)\n return false;\n\n // Validate signature\n var sinv = s.invm(this.n);\n var u1 = sinv.mul(msg).umod(this.n);\n var u2 = sinv.mul(r).umod(this.n);\n var p;\n\n if (!this.curve._maxwellTrick) {\n p = this.g.mulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n return p.getX().umod(this.n).cmp(r) === 0;\n }\n\n // NOTE: Greg Maxwell's trick, inspired by:\n // https://git.io/vad3K\n\n p = this.g.jmulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n // Compare `p.x` of Jacobian point with `r`,\n // this will do `p.x == r * p.z^2` instead of multiplying `p.x` by the\n // inverse of `p.z^2`\n return p.eqXToP(r);\n};\n\nEC.prototype.recoverPubKey = function(msg, signature, j, enc) {\n assert((3 & j) === j, 'The recovery param is more than two bits');\n signature = new Signature(signature, enc);\n\n var n = this.n;\n var e = new BN(msg);\n var r = signature.r;\n var s = signature.s;\n\n // A set LSB signifies that the y-coordinate is odd\n var isYOdd = j & 1;\n var isSecondKey = j >> 1;\n if (r.cmp(this.curve.p.umod(this.curve.n)) >= 0 && isSecondKey)\n throw new Error('Unable to find sencond key candinate');\n\n // 1.1. Let x = r + jn.\n if (isSecondKey)\n r = this.curve.pointFromX(r.add(this.curve.n), isYOdd);\n else\n r = this.curve.pointFromX(r, isYOdd);\n\n var rInv = signature.r.invm(n);\n var s1 = n.sub(e).mul(rInv).umod(n);\n var s2 = s.mul(rInv).umod(n);\n\n // 1.6.1 Compute Q = r^-1 (sR - eG)\n // Q = r^-1 (sR + -eG)\n return this.g.mulAdd(s1, r, s2);\n};\n\nEC.prototype.getKeyRecoveryParam = function(e, signature, Q, enc) {\n signature = new Signature(signature, enc);\n if (signature.recoveryParam !== null)\n return signature.recoveryParam;\n\n for (var i = 0; i < 4; i++) {\n var Qprime;\n try {\n Qprime = this.recoverPubKey(e, signature, i);\n } catch (e) {\n continue;\n }\n\n if (Qprime.eq(Q))\n return i;\n }\n throw new Error('Unable to find valid recovery factor');\n};\n","'use strict';\n\nvar hash = require('hash.js');\nvar utils = require('minimalistic-crypto-utils');\nvar assert = require('minimalistic-assert');\n\nfunction HmacDRBG(options) {\n if (!(this instanceof HmacDRBG))\n return new HmacDRBG(options);\n this.hash = options.hash;\n this.predResist = !!options.predResist;\n\n this.outLen = this.hash.outSize;\n this.minEntropy = options.minEntropy || this.hash.hmacStrength;\n\n this._reseed = null;\n this.reseedInterval = null;\n this.K = null;\n this.V = null;\n\n var entropy = utils.toArray(options.entropy, options.entropyEnc || 'hex');\n var nonce = utils.toArray(options.nonce, options.nonceEnc || 'hex');\n var pers = utils.toArray(options.pers, options.persEnc || 'hex');\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n this._init(entropy, nonce, pers);\n}\nmodule.exports = HmacDRBG;\n\nHmacDRBG.prototype._init = function init(entropy, nonce, pers) {\n var seed = entropy.concat(nonce).concat(pers);\n\n this.K = new Array(this.outLen / 8);\n this.V = new Array(this.outLen / 8);\n for (var i = 0; i < this.V.length; i++) {\n this.K[i] = 0x00;\n this.V[i] = 0x01;\n }\n\n this._update(seed);\n this._reseed = 1;\n this.reseedInterval = 0x1000000000000; // 2^48\n};\n\nHmacDRBG.prototype._hmac = function hmac() {\n return new hash.hmac(this.hash, this.K);\n};\n\nHmacDRBG.prototype._update = function update(seed) {\n var kmac = this._hmac()\n .update(this.V)\n .update([ 0x00 ]);\n if (seed)\n kmac = kmac.update(seed);\n this.K = kmac.digest();\n this.V = this._hmac().update(this.V).digest();\n if (!seed)\n return;\n\n this.K = this._hmac()\n .update(this.V)\n .update([ 0x01 ])\n .update(seed)\n .digest();\n this.V = this._hmac().update(this.V).digest();\n};\n\nHmacDRBG.prototype.reseed = function reseed(entropy, entropyEnc, add, addEnc) {\n // Optional entropy enc\n if (typeof entropyEnc !== 'string') {\n addEnc = add;\n add = entropyEnc;\n entropyEnc = null;\n }\n\n entropy = utils.toArray(entropy, entropyEnc);\n add = utils.toArray(add, addEnc);\n\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n\n this._update(entropy.concat(add || []));\n this._reseed = 1;\n};\n\nHmacDRBG.prototype.generate = function generate(len, enc, add, addEnc) {\n if (this._reseed > this.reseedInterval)\n throw new Error('Reseed is required');\n\n // Optional encoding\n if (typeof enc !== 'string') {\n addEnc = add;\n add = enc;\n enc = null;\n }\n\n // Optional additional data\n if (add) {\n add = utils.toArray(add, addEnc || 'hex');\n this._update(add);\n }\n\n var temp = [];\n while (temp.length < len) {\n this.V = this._hmac().update(this.V).digest();\n temp = temp.concat(this.V);\n }\n\n var res = temp.slice(0, len);\n this._update(add);\n this._reseed++;\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction KeyPair(ec, options) {\n this.ec = ec;\n this.priv = null;\n this.pub = null;\n\n // KeyPair(ec, { priv: ..., pub: ... })\n if (options.priv)\n this._importPrivate(options.priv, options.privEnc);\n if (options.pub)\n this._importPublic(options.pub, options.pubEnc);\n}\nmodule.exports = KeyPair;\n\nKeyPair.fromPublic = function fromPublic(ec, pub, enc) {\n if (pub instanceof KeyPair)\n return pub;\n\n return new KeyPair(ec, {\n pub: pub,\n pubEnc: enc,\n });\n};\n\nKeyPair.fromPrivate = function fromPrivate(ec, priv, enc) {\n if (priv instanceof KeyPair)\n return priv;\n\n return new KeyPair(ec, {\n priv: priv,\n privEnc: enc,\n });\n};\n\nKeyPair.prototype.validate = function validate() {\n var pub = this.getPublic();\n\n if (pub.isInfinity())\n return { result: false, reason: 'Invalid public key' };\n if (!pub.validate())\n return { result: false, reason: 'Public key is not a point' };\n if (!pub.mul(this.ec.curve.n).isInfinity())\n return { result: false, reason: 'Public key * N != O' };\n\n return { result: true, reason: null };\n};\n\nKeyPair.prototype.getPublic = function getPublic(compact, enc) {\n // compact is optional argument\n if (typeof compact === 'string') {\n enc = compact;\n compact = null;\n }\n\n if (!this.pub)\n this.pub = this.ec.g.mul(this.priv);\n\n if (!enc)\n return this.pub;\n\n return this.pub.encode(enc, compact);\n};\n\nKeyPair.prototype.getPrivate = function getPrivate(enc) {\n if (enc === 'hex')\n return this.priv.toString(16, 2);\n else\n return this.priv;\n};\n\nKeyPair.prototype._importPrivate = function _importPrivate(key, enc) {\n this.priv = new BN(key, enc || 16);\n\n // Ensure that the priv won't be bigger than n, otherwise we may fail\n // in fixed multiplication method\n this.priv = this.priv.umod(this.ec.curve.n);\n};\n\nKeyPair.prototype._importPublic = function _importPublic(key, enc) {\n if (key.x || key.y) {\n // Montgomery points only have an `x` coordinate.\n // Weierstrass/Edwards points on the other hand have both `x` and\n // `y` coordinates.\n if (this.ec.curve.type === 'mont') {\n assert(key.x, 'Need x coordinate');\n } else if (this.ec.curve.type === 'short' ||\n this.ec.curve.type === 'edwards') {\n assert(key.x && key.y, 'Need both x and y coordinate');\n }\n this.pub = this.ec.curve.point(key.x, key.y);\n return;\n }\n this.pub = this.ec.curve.decodePoint(key, enc);\n};\n\n// ECDH\nKeyPair.prototype.derive = function derive(pub) {\n if(!pub.validate()) {\n assert(pub.validate(), 'public point not validated');\n }\n return pub.mul(this.priv).getX();\n};\n\n// ECDSA\nKeyPair.prototype.sign = function sign(msg, enc, options) {\n return this.ec.sign(msg, this, enc, options);\n};\n\nKeyPair.prototype.verify = function verify(msg, signature) {\n return this.ec.verify(msg, signature, this);\n};\n\nKeyPair.prototype.inspect = function inspect() {\n return '';\n};\n","'use strict';\n\nvar BN = require('bn.js');\n\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction Signature(options, enc) {\n if (options instanceof Signature)\n return options;\n\n if (this._importDER(options, enc))\n return;\n\n assert(options.r && options.s, 'Signature without r or s');\n this.r = new BN(options.r, 16);\n this.s = new BN(options.s, 16);\n if (options.recoveryParam === undefined)\n this.recoveryParam = null;\n else\n this.recoveryParam = options.recoveryParam;\n}\nmodule.exports = Signature;\n\nfunction Position() {\n this.place = 0;\n}\n\nfunction getLength(buf, p) {\n var initial = buf[p.place++];\n if (!(initial & 0x80)) {\n return initial;\n }\n var octetLen = initial & 0xf;\n\n // Indefinite length or overflow\n if (octetLen === 0 || octetLen > 4) {\n return false;\n }\n\n var val = 0;\n for (var i = 0, off = p.place; i < octetLen; i++, off++) {\n val <<= 8;\n val |= buf[off];\n val >>>= 0;\n }\n\n // Leading zeroes\n if (val <= 0x7f) {\n return false;\n }\n\n p.place = off;\n return val;\n}\n\nfunction rmPadding(buf) {\n var i = 0;\n var len = buf.length - 1;\n while (!buf[i] && !(buf[i + 1] & 0x80) && i < len) {\n i++;\n }\n if (i === 0) {\n return buf;\n }\n return buf.slice(i);\n}\n\nSignature.prototype._importDER = function _importDER(data, enc) {\n data = utils.toArray(data, enc);\n var p = new Position();\n if (data[p.place++] !== 0x30) {\n return false;\n }\n var len = getLength(data, p);\n if (len === false) {\n return false;\n }\n if ((len + p.place) !== data.length) {\n return false;\n }\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var rlen = getLength(data, p);\n if (rlen === false) {\n return false;\n }\n var r = data.slice(p.place, rlen + p.place);\n p.place += rlen;\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var slen = getLength(data, p);\n if (slen === false) {\n return false;\n }\n if (data.length !== slen + p.place) {\n return false;\n }\n var s = data.slice(p.place, slen + p.place);\n if (r[0] === 0) {\n if (r[1] & 0x80) {\n r = r.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n if (s[0] === 0) {\n if (s[1] & 0x80) {\n s = s.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n\n this.r = new BN(r);\n this.s = new BN(s);\n this.recoveryParam = null;\n\n return true;\n};\n\nfunction constructLength(arr, len) {\n if (len < 0x80) {\n arr.push(len);\n return;\n }\n var octets = 1 + (Math.log(len) / Math.LN2 >>> 3);\n arr.push(octets | 0x80);\n while (--octets) {\n arr.push((len >>> (octets << 3)) & 0xff);\n }\n arr.push(len);\n}\n\nSignature.prototype.toDER = function toDER(enc) {\n var r = this.r.toArray();\n var s = this.s.toArray();\n\n // Pad values\n if (r[0] & 0x80)\n r = [ 0 ].concat(r);\n // Pad values\n if (s[0] & 0x80)\n s = [ 0 ].concat(s);\n\n r = rmPadding(r);\n s = rmPadding(s);\n\n while (!s[0] && !(s[1] & 0x80)) {\n s = s.slice(1);\n }\n var arr = [ 0x02 ];\n constructLength(arr, r.length);\n arr = arr.concat(r);\n arr.push(0x02);\n constructLength(arr, s.length);\n var backHalf = arr.concat(s);\n var res = [ 0x30 ];\n constructLength(res, backHalf.length);\n res = res.concat(backHalf);\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar hash = require('hash.js');\nvar curves = require('../curves');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EDDSA(curve) {\n assert(curve === 'ed25519', 'only tested with ed25519 so far');\n\n if (!(this instanceof EDDSA))\n return new EDDSA(curve);\n\n curve = curves[curve].curve;\n this.curve = curve;\n this.g = curve.g;\n this.g.precompute(curve.n.bitLength() + 1);\n\n this.pointClass = curve.point().constructor;\n this.encodingLength = Math.ceil(curve.n.bitLength() / 8);\n this.hash = hash.sha512;\n}\n\nmodule.exports = EDDSA;\n\n/**\n* @param {Array|String} message - message bytes\n* @param {Array|String|KeyPair} secret - secret bytes or a keypair\n* @returns {Signature} - signature\n*/\nEDDSA.prototype.sign = function sign(message, secret) {\n message = parseBytes(message);\n var key = this.keyFromSecret(secret);\n var r = this.hashInt(key.messagePrefix(), message);\n var R = this.g.mul(r);\n var Rencoded = this.encodePoint(R);\n var s_ = this.hashInt(Rencoded, key.pubBytes(), message)\n .mul(key.priv());\n var S = r.add(s_).umod(this.curve.n);\n return this.makeSignature({ R: R, S: S, Rencoded: Rencoded });\n};\n\n/**\n* @param {Array} message - message bytes\n* @param {Array|String|Signature} sig - sig bytes\n* @param {Array|String|Point|KeyPair} pub - public key\n* @returns {Boolean} - true if public key matches sig of message\n*/\nEDDSA.prototype.verify = function verify(message, sig, pub) {\n message = parseBytes(message);\n sig = this.makeSignature(sig);\n var key = this.keyFromPublic(pub);\n var h = this.hashInt(sig.Rencoded(), key.pubBytes(), message);\n var SG = this.g.mul(sig.S());\n var RplusAh = sig.R().add(key.pub().mul(h));\n return RplusAh.eq(SG);\n};\n\nEDDSA.prototype.hashInt = function hashInt() {\n var hash = this.hash();\n for (var i = 0; i < arguments.length; i++)\n hash.update(arguments[i]);\n return utils.intFromLE(hash.digest()).umod(this.curve.n);\n};\n\nEDDSA.prototype.keyFromPublic = function keyFromPublic(pub) {\n return KeyPair.fromPublic(this, pub);\n};\n\nEDDSA.prototype.keyFromSecret = function keyFromSecret(secret) {\n return KeyPair.fromSecret(this, secret);\n};\n\nEDDSA.prototype.makeSignature = function makeSignature(sig) {\n if (sig instanceof Signature)\n return sig;\n return new Signature(this, sig);\n};\n\n/**\n* * https://tools.ietf.org/html/draft-josefsson-eddsa-ed25519-03#section-5.2\n*\n* EDDSA defines methods for encoding and decoding points and integers. These are\n* helper convenience methods, that pass along to utility functions implied\n* parameters.\n*\n*/\nEDDSA.prototype.encodePoint = function encodePoint(point) {\n var enc = point.getY().toArray('le', this.encodingLength);\n enc[this.encodingLength - 1] |= point.getX().isOdd() ? 0x80 : 0;\n return enc;\n};\n\nEDDSA.prototype.decodePoint = function decodePoint(bytes) {\n bytes = utils.parseBytes(bytes);\n\n var lastIx = bytes.length - 1;\n var normed = bytes.slice(0, lastIx).concat(bytes[lastIx] & ~0x80);\n var xIsOdd = (bytes[lastIx] & 0x80) !== 0;\n\n var y = utils.intFromLE(normed);\n return this.curve.pointFromY(y, xIsOdd);\n};\n\nEDDSA.prototype.encodeInt = function encodeInt(num) {\n return num.toArray('le', this.encodingLength);\n};\n\nEDDSA.prototype.decodeInt = function decodeInt(bytes) {\n return utils.intFromLE(bytes);\n};\n\nEDDSA.prototype.isPoint = function isPoint(val) {\n return val instanceof this.pointClass;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar cachedProperty = utils.cachedProperty;\n\n/**\n* @param {EDDSA} eddsa - instance\n* @param {Object} params - public/private key parameters\n*\n* @param {Array} [params.secret] - secret seed bytes\n* @param {Point} [params.pub] - public key point (aka `A` in eddsa terms)\n* @param {Array} [params.pub] - public key point encoded as bytes\n*\n*/\nfunction KeyPair(eddsa, params) {\n this.eddsa = eddsa;\n this._secret = parseBytes(params.secret);\n if (eddsa.isPoint(params.pub))\n this._pub = params.pub;\n else\n this._pubBytes = parseBytes(params.pub);\n}\n\nKeyPair.fromPublic = function fromPublic(eddsa, pub) {\n if (pub instanceof KeyPair)\n return pub;\n return new KeyPair(eddsa, { pub: pub });\n};\n\nKeyPair.fromSecret = function fromSecret(eddsa, secret) {\n if (secret instanceof KeyPair)\n return secret;\n return new KeyPair(eddsa, { secret: secret });\n};\n\nKeyPair.prototype.secret = function secret() {\n return this._secret;\n};\n\ncachedProperty(KeyPair, 'pubBytes', function pubBytes() {\n return this.eddsa.encodePoint(this.pub());\n});\n\ncachedProperty(KeyPair, 'pub', function pub() {\n if (this._pubBytes)\n return this.eddsa.decodePoint(this._pubBytes);\n return this.eddsa.g.mul(this.priv());\n});\n\ncachedProperty(KeyPair, 'privBytes', function privBytes() {\n var eddsa = this.eddsa;\n var hash = this.hash();\n var lastIx = eddsa.encodingLength - 1;\n\n var a = hash.slice(0, eddsa.encodingLength);\n a[0] &= 248;\n a[lastIx] &= 127;\n a[lastIx] |= 64;\n\n return a;\n});\n\ncachedProperty(KeyPair, 'priv', function priv() {\n return this.eddsa.decodeInt(this.privBytes());\n});\n\ncachedProperty(KeyPair, 'hash', function hash() {\n return this.eddsa.hash().update(this.secret()).digest();\n});\n\ncachedProperty(KeyPair, 'messagePrefix', function messagePrefix() {\n return this.hash().slice(this.eddsa.encodingLength);\n});\n\nKeyPair.prototype.sign = function sign(message) {\n assert(this._secret, 'KeyPair can only verify');\n return this.eddsa.sign(message, this);\n};\n\nKeyPair.prototype.verify = function verify(message, sig) {\n return this.eddsa.verify(message, sig, this);\n};\n\nKeyPair.prototype.getSecret = function getSecret(enc) {\n assert(this._secret, 'KeyPair is public only');\n return utils.encode(this.secret(), enc);\n};\n\nKeyPair.prototype.getPublic = function getPublic(enc) {\n return utils.encode(this.pubBytes(), enc);\n};\n\nmodule.exports = KeyPair;\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar cachedProperty = utils.cachedProperty;\nvar parseBytes = utils.parseBytes;\n\n/**\n* @param {EDDSA} eddsa - eddsa instance\n* @param {Array|Object} sig -\n* @param {Array|Point} [sig.R] - R point as Point or bytes\n* @param {Array|bn} [sig.S] - S scalar as bn or bytes\n* @param {Array} [sig.Rencoded] - R point encoded\n* @param {Array} [sig.Sencoded] - S scalar encoded\n*/\nfunction Signature(eddsa, sig) {\n this.eddsa = eddsa;\n\n if (typeof sig !== 'object')\n sig = parseBytes(sig);\n\n if (Array.isArray(sig)) {\n sig = {\n R: sig.slice(0, eddsa.encodingLength),\n S: sig.slice(eddsa.encodingLength),\n };\n }\n\n assert(sig.R && sig.S, 'Signature without R or S');\n\n if (eddsa.isPoint(sig.R))\n this._R = sig.R;\n if (sig.S instanceof BN)\n this._S = sig.S;\n\n this._Rencoded = Array.isArray(sig.R) ? sig.R : sig.Rencoded;\n this._Sencoded = Array.isArray(sig.S) ? sig.S : sig.Sencoded;\n}\n\ncachedProperty(Signature, 'S', function S() {\n return this.eddsa.decodeInt(this.Sencoded());\n});\n\ncachedProperty(Signature, 'R', function R() {\n return this.eddsa.decodePoint(this.Rencoded());\n});\n\ncachedProperty(Signature, 'Rencoded', function Rencoded() {\n return this.eddsa.encodePoint(this.R());\n});\n\ncachedProperty(Signature, 'Sencoded', function Sencoded() {\n return this.eddsa.encodeInt(this.S());\n});\n\nSignature.prototype.toBytes = function toBytes() {\n return this.Rencoded().concat(this.Sencoded());\n};\n\nSignature.prototype.toHex = function toHex() {\n return utils.encode(this.toBytes(), 'hex').toUpperCase();\n};\n\nmodule.exports = Signature;\n","'use strict'\n\nconst errcode = require('err-code')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst hmac = require('../hmac')\n\nconst cipherMap = {\n 'AES-128': {\n ivSize: 16,\n keySize: 16\n },\n 'AES-256': {\n ivSize: 16,\n keySize: 32\n },\n Blowfish: {\n ivSize: 8,\n cipherKeySize: 32\n }\n}\n\n// Generates a set of keys for each party by stretching the shared key.\n// (myIV, theirIV, myCipherKey, theirCipherKey, myMACKey, theirMACKey)\nmodule.exports = async (cipherType, hash, secret) => {\n const cipher = cipherMap[cipherType]\n\n if (!cipher) {\n const allowed = Object.keys(cipherMap).join(' / ')\n throw errcode(new Error(`unknown cipher type '${cipherType}'. Must be ${allowed}`), 'ERR_INVALID_CIPHER_TYPE')\n }\n\n if (!hash) {\n throw errcode(new Error('missing hash type'), 'ERR_MISSING_HASH_TYPE')\n }\n\n const cipherKeySize = cipher.keySize\n const ivSize = cipher.ivSize\n const hmacKeySize = 20\n const seed = uint8ArrayFromString('key expansion')\n const resultLength = 2 * (ivSize + cipherKeySize + hmacKeySize)\n\n const m = await hmac.create(hash, secret)\n let a = await m.digest(seed)\n\n const result = []\n let j = 0\n\n while (j < resultLength) {\n const b = await m.digest(uint8ArrayConcat([a, seed]))\n let todo = b.length\n\n if (j + todo > resultLength) {\n todo = resultLength - j\n }\n\n result.push(b)\n j += todo\n a = await m.digest(a)\n }\n\n const half = resultLength / 2\n const resultBuffer = uint8ArrayConcat(result)\n const r1 = resultBuffer.slice(0, half)\n const r2 = resultBuffer.slice(half, resultLength)\n\n const createKey = (res) => ({\n iv: res.slice(0, ivSize),\n cipherKey: res.slice(ivSize, ivSize + cipherKeySize),\n macKey: res.slice(ivSize + cipherKeySize)\n })\n\n return {\n k1: createKey(r1),\n k2: createKey(r2)\n }\n}\n","'use strict'\n\nconst webcrypto = require('../webcrypto')\nconst lengths = require('./lengths')\n\nconst hashTypes = {\n SHA1: 'SHA-1',\n SHA256: 'SHA-256',\n SHA512: 'SHA-512'\n}\n\nconst sign = async (key, data) => {\n const buf = await webcrypto.get().subtle.sign({ name: 'HMAC' }, key, data)\n return new Uint8Array(buf, buf.byteOffset, buf.byteLength)\n}\n\nexports.create = async function (hashType, secret) {\n const hash = hashTypes[hashType]\n\n const key = await webcrypto.get().subtle.importKey(\n 'raw',\n secret,\n {\n name: 'HMAC',\n hash: { name: hash }\n },\n false,\n ['sign']\n )\n\n return {\n async digest (data) { // eslint-disable-line require-await\n return sign(key, data)\n },\n length: lengths[hashType]\n }\n}\n","'use strict'\n\nmodule.exports = {\n SHA1: 20,\n SHA256: 32,\n SHA512: 64\n}\n","'use strict'\n\nconst ecdh = require('./ecdh')\n\n// Generates an ephemeral public key and returns a function that will compute\n// the shared secret key.\n//\n// Focuses only on ECDH now, but can be made more general in the future.\nmodule.exports = async (curve) => ecdh.generateEphmeralKeyPair(curve) // eslint-disable-line require-await\n","'use strict'\n\nconst errcode = require('err-code')\nconst webcrypto = require('../webcrypto')\nconst { base64urlToBuffer } = require('../util')\nconst validateCurveType = require('./validate-curve-type')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\nconst bits = {\n 'P-256': 256,\n 'P-384': 384,\n 'P-521': 521\n}\n\nexports.generateEphmeralKeyPair = async function (curve) {\n validateCurveType(Object.keys(bits), curve)\n const pair = await webcrypto.get().subtle.generateKey(\n {\n name: 'ECDH',\n namedCurve: curve\n },\n true,\n ['deriveBits']\n )\n\n // forcePrivate is used for testing only\n const genSharedKey = async (theirPub, forcePrivate) => {\n let privateKey\n\n if (forcePrivate) {\n privateKey = await webcrypto.get().subtle.importKey(\n 'jwk',\n unmarshalPrivateKey(curve, forcePrivate),\n {\n name: 'ECDH',\n namedCurve: curve\n },\n false,\n ['deriveBits']\n )\n } else {\n privateKey = pair.privateKey\n }\n\n const keys = [\n await webcrypto.get().subtle.importKey(\n 'jwk',\n unmarshalPublicKey(curve, theirPub),\n {\n name: 'ECDH',\n namedCurve: curve\n },\n false,\n []\n ),\n privateKey\n ]\n\n const buffer = await webcrypto.get().subtle.deriveBits(\n {\n name: 'ECDH',\n namedCurve: curve,\n public: keys[0]\n },\n keys[1],\n bits[curve]\n )\n\n return new Uint8Array(buffer, buffer.byteOffset, buffer.byteLength)\n }\n\n const publicKey = await webcrypto.get().subtle.exportKey('jwk', pair.publicKey)\n\n return {\n key: marshalPublicKey(publicKey),\n genSharedKey\n }\n}\n\nconst curveLengths = {\n 'P-256': 32,\n 'P-384': 48,\n 'P-521': 66\n}\n\n// Marshal converts a jwk encodec ECDH public key into the\n// form specified in section 4.3.6 of ANSI X9.62. (This is the format\n// go-ipfs uses)\nfunction marshalPublicKey (jwk) {\n const byteLen = curveLengths[jwk.crv]\n\n return uint8ArrayConcat([\n Uint8Array.from([4]), // uncompressed point\n base64urlToBuffer(jwk.x, byteLen),\n base64urlToBuffer(jwk.y, byteLen)\n ], 1 + byteLen * 2)\n}\n\n// Unmarshal converts a point, serialized by Marshal, into an jwk encoded key\nfunction unmarshalPublicKey (curve, key) {\n const byteLen = curveLengths[curve]\n\n if (uint8ArrayEquals(!key.slice(0, 1), Uint8Array.from([4]))) {\n throw errcode(new Error('Cannot unmarshal public key - invalid key format'), 'ERR_INVALID_KEY_FORMAT')\n }\n\n return {\n kty: 'EC',\n crv: curve,\n x: uint8ArrayToString(key.slice(1, byteLen + 1), 'base64url'),\n y: uint8ArrayToString(key.slice(1 + byteLen), 'base64url'),\n ext: true\n }\n}\n\nconst unmarshalPrivateKey = (curve, key) => ({\n ...unmarshalPublicKey(curve, key.public),\n d: uint8ArrayToString(key.private, 'base64url')\n})\n","'use strict'\n\nconst errcode = require('err-code')\n\nmodule.exports = function (curveTypes, type) {\n if (!curveTypes.includes(type)) {\n const names = curveTypes.join(' / ')\n throw errcode(new Error(`Unknown curve: ${type}. Must be ${names}`), 'ERR_INVALID_CURVE')\n }\n}\n","'use strict';\n\nfunction withIs(Class, { className, symbolName }) {\n const symbol = Symbol.for(symbolName);\n\n const ClassIsWrapper = {\n // The code below assigns the class wrapper to an object to trick\n // JavaScript engines to show the name of the extended class when\n // logging an instances.\n // We are assigning an anonymous class (class wrapper) to the object\n // with key `className` to keep the correct name.\n // If this is not supported it falls back to logging `ClassIsWrapper`.\n [className]: class extends Class {\n constructor(...args) {\n super(...args);\n Object.defineProperty(this, symbol, { value: true });\n }\n\n get [Symbol.toStringTag]() {\n return className;\n }\n },\n }[className];\n\n ClassIsWrapper[`is${className}`] = (obj) => !!(obj && obj[symbol]);\n\n return ClassIsWrapper;\n}\n\nfunction withIsProto(Class, { className, symbolName, withoutNew }) {\n const symbol = Symbol.for(symbolName);\n\n /* eslint-disable object-shorthand */\n const ClassIsWrapper = {\n [className]: function (...args) {\n if (withoutNew && !(this instanceof ClassIsWrapper)) {\n return new ClassIsWrapper(...args);\n }\n\n const _this = Class.call(this, ...args) || this;\n\n if (_this && !_this[symbol]) {\n Object.defineProperty(_this, symbol, { value: true });\n }\n\n return _this;\n },\n }[className];\n /* eslint-enable object-shorthand */\n\n ClassIsWrapper.prototype = Object.create(Class.prototype);\n ClassIsWrapper.prototype.constructor = ClassIsWrapper;\n\n Object.defineProperty(ClassIsWrapper.prototype, Symbol.toStringTag, {\n get() {\n return className;\n },\n });\n\n ClassIsWrapper[`is${className}`] = (obj) => !!(obj && obj[symbol]);\n\n return ClassIsWrapper;\n}\n\nmodule.exports = withIs;\nmodule.exports.proto = withIsProto;\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-peer-id\"] || ($protobuf.roots[\"libp2p-peer-id\"] = {});\n\n$root.PeerIdProto = (function() {\n\n /**\n * Properties of a PeerIdProto.\n * @exports IPeerIdProto\n * @interface IPeerIdProto\n * @property {Uint8Array} id PeerIdProto id\n * @property {Uint8Array|null} [pubKey] PeerIdProto pubKey\n * @property {Uint8Array|null} [privKey] PeerIdProto privKey\n */\n\n /**\n * Constructs a new PeerIdProto.\n * @exports PeerIdProto\n * @classdesc Represents a PeerIdProto.\n * @implements IPeerIdProto\n * @constructor\n * @param {IPeerIdProto=} [p] Properties to set\n */\n function PeerIdProto(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * PeerIdProto id.\n * @member {Uint8Array} id\n * @memberof PeerIdProto\n * @instance\n */\n PeerIdProto.prototype.id = $util.newBuffer([]);\n\n /**\n * PeerIdProto pubKey.\n * @member {Uint8Array} pubKey\n * @memberof PeerIdProto\n * @instance\n */\n PeerIdProto.prototype.pubKey = $util.newBuffer([]);\n\n /**\n * PeerIdProto privKey.\n * @member {Uint8Array} privKey\n * @memberof PeerIdProto\n * @instance\n */\n PeerIdProto.prototype.privKey = $util.newBuffer([]);\n\n /**\n * Encodes the specified PeerIdProto message. Does not implicitly {@link PeerIdProto.verify|verify} messages.\n * @function encode\n * @memberof PeerIdProto\n * @static\n * @param {IPeerIdProto} m PeerIdProto message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PeerIdProto.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(10).bytes(m.id);\n if (m.pubKey != null && Object.hasOwnProperty.call(m, \"pubKey\"))\n w.uint32(18).bytes(m.pubKey);\n if (m.privKey != null && Object.hasOwnProperty.call(m, \"privKey\"))\n w.uint32(26).bytes(m.privKey);\n return w;\n };\n\n /**\n * Decodes a PeerIdProto message from the specified reader or buffer.\n * @function decode\n * @memberof PeerIdProto\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PeerIdProto} PeerIdProto\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PeerIdProto.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PeerIdProto();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.id = r.bytes();\n break;\n case 2:\n m.pubKey = r.bytes();\n break;\n case 3:\n m.privKey = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty(\"id\"))\n throw $util.ProtocolError(\"missing required 'id'\", { instance: m });\n return m;\n };\n\n /**\n * Creates a PeerIdProto message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PeerIdProto\n * @static\n * @param {Object.} d Plain object\n * @returns {PeerIdProto} PeerIdProto\n */\n PeerIdProto.fromObject = function fromObject(d) {\n if (d instanceof $root.PeerIdProto)\n return d;\n var m = new $root.PeerIdProto();\n if (d.id != null) {\n if (typeof d.id === \"string\")\n $util.base64.decode(d.id, m.id = $util.newBuffer($util.base64.length(d.id)), 0);\n else if (d.id.length)\n m.id = d.id;\n }\n if (d.pubKey != null) {\n if (typeof d.pubKey === \"string\")\n $util.base64.decode(d.pubKey, m.pubKey = $util.newBuffer($util.base64.length(d.pubKey)), 0);\n else if (d.pubKey.length)\n m.pubKey = d.pubKey;\n }\n if (d.privKey != null) {\n if (typeof d.privKey === \"string\")\n $util.base64.decode(d.privKey, m.privKey = $util.newBuffer($util.base64.length(d.privKey)), 0);\n else if (d.privKey.length)\n m.privKey = d.privKey;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a PeerIdProto message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PeerIdProto\n * @static\n * @param {PeerIdProto} m PeerIdProto\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n PeerIdProto.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.id = \"\";\n else {\n d.id = [];\n if (o.bytes !== Array)\n d.id = $util.newBuffer(d.id);\n }\n if (o.bytes === String)\n d.pubKey = \"\";\n else {\n d.pubKey = [];\n if (o.bytes !== Array)\n d.pubKey = $util.newBuffer(d.pubKey);\n }\n if (o.bytes === String)\n d.privKey = \"\";\n else {\n d.privKey = [];\n if (o.bytes !== Array)\n d.privKey = $util.newBuffer(d.privKey);\n }\n }\n if (m.id != null && m.hasOwnProperty(\"id\")) {\n d.id = o.bytes === String ? $util.base64.encode(m.id, 0, m.id.length) : o.bytes === Array ? Array.prototype.slice.call(m.id) : m.id;\n }\n if (m.pubKey != null && m.hasOwnProperty(\"pubKey\")) {\n d.pubKey = o.bytes === String ? $util.base64.encode(m.pubKey, 0, m.pubKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.pubKey) : m.pubKey;\n }\n if (m.privKey != null && m.hasOwnProperty(\"privKey\")) {\n d.privKey = o.bytes === String ? $util.base64.encode(m.privKey, 0, m.privKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.privKey) : m.privKey;\n }\n return d;\n };\n\n /**\n * Converts this PeerIdProto to JSON.\n * @function toJSON\n * @memberof PeerIdProto\n * @instance\n * @returns {Object.} JSON object\n */\n PeerIdProto.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return PeerIdProto;\n})();\n\nmodule.exports = $root;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar add = require('./add.js');\nvar addAll = require('./add-all.js');\nvar ls = require('./ls.js');\nvar rm = require('./rm.js');\nvar rmAll = require('./rm-all.js');\n\nclass PinAPI {\n constructor({codecs, repo}) {\n const addAll$1 = addAll.createAddAll({\n codecs,\n repo\n });\n this.addAll = addAll$1;\n this.add = add.createAdd({ addAll: addAll$1 });\n const rmAll$1 = rmAll.createRmAll({\n codecs,\n repo\n });\n this.rmAll = rmAll$1;\n this.rm = rm.createRm({ rmAll: rmAll$1 });\n this.ls = ls.createLs({\n codecs,\n repo\n });\n this.remote = {\n add: (cid, options = {}) => Promise.reject(new Error('Not implemented')),\n ls: async function* (query, options = {}) {\n return Promise.reject(new Error('Not implemented'));\n },\n rm: (query, options = {}) => Promise.reject(new Error('Not implemented')),\n rmAll: (query, options = {}) => Promise.reject(new Error('Not implemented')),\n service: {\n add: (name, credentials) => Promise.reject(new Error('Not implemented')),\n rm: (name, options = {}) => Promise.reject(new Error('Not implemented')),\n ls: (options = {}) => Promise.reject(new Error('Not implemented'))\n }\n };\n }\n}\n\nexports.PinAPI = PinAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar last = require('it-last');\nvar cid = require('multiformats/cid');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createAdd({addAll}) {\n return (path, options = {}) => {\n let iter;\n const cid$1 = cid.CID.asCID(path);\n if (cid$1) {\n iter = addAll([{\n cid: cid$1,\n ...options\n }], options);\n } else {\n iter = addAll([{\n path: path.toString(),\n ...options\n }], options);\n }\n return last__default['default'](iter);\n };\n}\n\nexports.createAdd = createAdd;\n","'use strict'\n\n/**\n * Returns the last item of an (async) iterable, unless empty, in which case\n * return `undefined`.\n *\n * @template T\n * @param {AsyncIterable|Iterable} source\n */\nconst last = async (source) => {\n let res\n\n for await (const entry of source) {\n res = entry\n }\n\n return res\n}\n\nmodule.exports = last\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar pinTypes = require('ipfs-repo/pin-types');\n\nfunction createAddAll({repo, codecs}) {\n async function* addAll(source, options = {}) {\n const pinAdd = async function* () {\n for await (const {path, recursive, metadata} of normaliseInput.normaliseInput(source)) {\n const {cid} = await utils.resolvePath(repo, codecs, path);\n const {reason} = await repo.pins.isPinnedWithType(cid, [\n pinTypes.PinTypes.recursive,\n pinTypes.PinTypes.direct\n ]);\n if (reason === 'recursive' && !recursive) {\n throw new Error(`${ cid } already pinned recursively`);\n }\n if (recursive) {\n await repo.pins.pinRecursively(cid, { metadata });\n } else {\n await repo.pins.pinDirectly(cid, { metadata });\n }\n yield cid;\n }\n };\n const lock = Boolean(options.lock);\n if (!lock) {\n yield* pinAdd();\n return;\n }\n const release = await repo.gcLock.readLock();\n try {\n yield* pinAdd();\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(addAll);\n}\n\nexports.createAddAll = createAddAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar cid = require('multiformats/cid');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nasync function* normaliseInput(input) {\n if (input === null || input === undefined) {\n throw errCode__default['default'](new Error(`Unexpected input: ${ input }`), 'ERR_UNEXPECTED_INPUT');\n }\n const cid$1 = cid.CID.asCID(input);\n if (cid$1) {\n yield toPin({ cid: cid$1 });\n return;\n }\n if (input instanceof String || typeof input === 'string') {\n yield toPin({ path: input });\n return;\n }\n if (input.cid != null || input.path != null) {\n return yield toPin(input);\n }\n if (Symbol.iterator in input) {\n const iterator = input[Symbol.iterator]();\n const first = iterator.next();\n if (first.done)\n return iterator;\n if (cid.CID.asCID(first.value) || first.value instanceof String || typeof first.value === 'string') {\n yield toPin({ cid: first.value });\n for (const cid of iterator) {\n yield toPin({ cid });\n }\n return;\n }\n if (first.value.cid != null || first.value.path != null) {\n yield toPin(first.value);\n for (const obj of iterator) {\n yield toPin(obj);\n }\n return;\n }\n throw errCode__default['default'](new Error('Unexpected input: ' + typeof input), 'ERR_UNEXPECTED_INPUT');\n }\n if (Symbol.asyncIterator in input) {\n const iterator = input[Symbol.asyncIterator]();\n const first = await iterator.next();\n if (first.done)\n return iterator;\n if (cid.CID.asCID(first.value) || first.value instanceof String || typeof first.value === 'string') {\n yield toPin({ cid: first.value });\n for await (const cid of iterator) {\n yield toPin({ cid });\n }\n return;\n }\n if (first.value.cid != null || first.value.path != null) {\n yield toPin(first.value);\n for await (const obj of iterator) {\n yield toPin(obj);\n }\n return;\n }\n throw errCode__default['default'](new Error('Unexpected input: ' + typeof input), 'ERR_UNEXPECTED_INPUT');\n }\n throw errCode__default['default'](new Error('Unexpected input: ' + typeof input), 'ERR_UNEXPECTED_INPUT');\n}\nfunction toPin(input) {\n const path = input.cid || `${ input.path }`;\n if (!path) {\n throw errCode__default['default'](new Error('Unexpected input: Please path either a CID or an IPFS path'), 'ERR_UNEXPECTED_INPUT');\n }\n const pin = {\n path,\n recursive: input.recursive !== false\n };\n if (input.metadata != null) {\n pin.metadata = input.metadata;\n }\n return pin;\n}\n\nexports.normaliseInput = normaliseInput;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst PinTypes = {\n direct: 'direct',\n recursive: 'recursive',\n indirect: 'indirect',\n all: 'all'\n};\n\nexports.PinTypes = PinTypes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar errCode = require('err-code');\nvar pinTypes = require('ipfs-repo/pin-types');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction toPin(type, cid, metadata) {\n const output = {\n type,\n cid\n };\n if (metadata) {\n output.metadata = metadata;\n }\n return output;\n}\nfunction createLs({repo, codecs}) {\n async function* ls(options = {}) {\n let type = pinTypes.PinTypes.all;\n if (options.type) {\n type = options.type;\n if (!Object.keys(pinTypes.PinTypes).includes(type)) {\n throw errCode__default['default'](new Error('Invalid pin type'), 'ERR_INVALID_PIN_TYPE');\n }\n }\n if (options.paths) {\n let matched = false;\n for await (const {path} of normaliseInput.normaliseInput(options.paths)) {\n const {cid} = await utils.resolvePath(repo, codecs, path);\n const {reason, pinned, parent, metadata} = await repo.pins.isPinnedWithType(cid, type);\n if (!pinned) {\n throw errCode__default['default'](new Error(`path '${ path }' is not pinned`), 'ERR_NOT_PINNED');\n }\n switch (reason) {\n case pinTypes.PinTypes.direct:\n case pinTypes.PinTypes.recursive:\n matched = true;\n yield toPin(reason, cid, metadata);\n break;\n default:\n matched = true;\n yield toPin(`${ pinTypes.PinTypes.indirect } through ${ parent }`, cid, metadata);\n }\n }\n if (!matched) {\n throw new Error('No match found');\n }\n return;\n }\n if (type === pinTypes.PinTypes.recursive || type === pinTypes.PinTypes.all) {\n for await (const {cid, metadata} of repo.pins.recursiveKeys()) {\n yield toPin(pinTypes.PinTypes.recursive, cid, metadata);\n }\n }\n if (type === pinTypes.PinTypes.indirect || type === pinTypes.PinTypes.all) {\n for await (const cid of repo.pins.indirectKeys(options)) {\n yield toPin(pinTypes.PinTypes.indirect, cid);\n }\n }\n if (type === pinTypes.PinTypes.direct || type === pinTypes.PinTypes.all) {\n for await (const {cid, metadata} of repo.pins.directKeys()) {\n yield toPin(pinTypes.PinTypes.direct, cid, metadata);\n }\n }\n }\n return withTimeoutOption.withTimeoutOption(ls);\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar last = require('it-last');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createRm({rmAll}) {\n async function rm(path, options = {}) {\n const cid = await last__default['default'](rmAll([{\n path,\n ...options\n }], options));\n if (!cid) {\n throw new Error('CID expected');\n }\n return cid;\n }\n return rm;\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar pinTypes = require('ipfs-repo/pin-types');\n\nfunction createRmAll({repo, codecs}) {\n async function* rmAll(source, _options = {}) {\n const release = await repo.gcLock.readLock();\n try {\n for await (const {path, recursive} of normaliseInput.normaliseInput(source)) {\n const {cid} = await utils.resolvePath(repo, codecs, path);\n const {pinned, reason} = await repo.pins.isPinnedWithType(cid, pinTypes.PinTypes.all);\n if (!pinned) {\n throw new Error(`${ cid } is not pinned`);\n }\n switch (reason) {\n case pinTypes.PinTypes.recursive:\n if (!recursive) {\n throw new Error(`${ cid } is pinned recursively`);\n }\n await repo.pins.unpin(cid);\n yield cid;\n break;\n case pinTypes.PinTypes.direct:\n await repo.pins.unpin(cid);\n yield cid;\n break;\n default:\n throw new Error(`${ cid } is pinned indirectly under ${ reason }`);\n }\n }\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(rmAll);\n}\n\nexports.createRmAll = createRmAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('../ipns/index.js');\nvar config = require('../ipns/routing/config.js');\nvar offlineDatastore = require('../ipns/routing/offline-datastore.js');\nvar errors = require('../errors.js');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:components:ipns');\nclass IPNSAPI {\n constructor(options = { pass: '' }) {\n this.options = options;\n this.offline = null;\n this.online = null;\n }\n getIPNS() {\n const ipns = this.online || this.offline;\n if (ipns) {\n return ipns;\n } else {\n throw new errors.NotInitializedError();\n }\n }\n get routing() {\n return this.getIPNS().routing;\n }\n startOffline({repo, peerId, keychain}) {\n if (this.offline != null) {\n throw new errors.AlreadyInitializedError();\n }\n log('initializing IPNS keyspace');\n const routing = new offlineDatastore.OfflineDatastore(repo);\n const ipns = new index.IPNS(routing, repo.datastore, peerId, keychain, this.options);\n this.offline = ipns;\n }\n async startOnline({libp2p, repo, peerId, keychain}) {\n if (this.online != null) {\n throw new errors.AlreadyInitializedError();\n }\n const routing = config.createRouting({\n libp2p,\n repo,\n peerId,\n options: this.options\n });\n const ipns = new index.IPNS(routing, repo.datastore, peerId, keychain, this.options);\n await ipns.republisher.start();\n this.online = ipns;\n }\n async stop() {\n const ipns = this.online;\n if (ipns) {\n await ipns.republisher.stop();\n this.online = null;\n }\n }\n publish(privKey, value, lifetime) {\n return this.getIPNS().publish(privKey, value, lifetime);\n }\n resolve(name, options) {\n return this.getIPNS().resolve(name, options);\n }\n initializeKeyspace(privKey, value) {\n return this.getIPNS().initializeKeyspace(privKey, value);\n }\n}\n\nexports.IPNSAPI = IPNSAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar publisher = require('./publisher.js');\nvar republisher = require('./republisher.js');\nvar resolver = require('./resolver.js');\nvar tlru = require('../utils/tlru.js');\nvar toString = require('uint8arrays/to-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns'), { error: debug__default['default']('ipfs:ipns:error') });\nconst defaultRecordTtl = 60 * 1000;\nclass IPNS {\n constructor(routing, datastore, peerId, keychain, options) {\n this.publisher = new publisher.IpnsPublisher(routing, datastore);\n this.republisher = new republisher.IpnsRepublisher(this.publisher, datastore, peerId, keychain, options);\n this.resolver = new resolver.IpnsResolver(routing);\n this.cache = new tlru.TLRU(1000);\n this.routing = routing;\n }\n async publish(privKey, value, lifetime = publisher.IpnsPublisher.defaultRecordLifetime) {\n try {\n const peerId = await PeerId.createFromPrivKey(privKey.bytes);\n await this.publisher.publishWithEOL(privKey, value, lifetime);\n log(`IPNS value ${ toString.toString(value, 'base32') } was published correctly`);\n const id = peerId.toB58String();\n const ttEol = parseFloat(lifetime);\n const ttl = ttEol < defaultRecordTtl ? ttEol : defaultRecordTtl;\n this.cache.set(id, value, ttl);\n log(`IPNS value ${ toString.toString(value, 'base32') } was cached correctly`);\n return {\n name: id,\n value: value\n };\n } catch (err) {\n log.error(err);\n throw err;\n }\n }\n async resolve(name, options = {}) {\n if (typeof name !== 'string') {\n throw errCode__default['default'](new Error('name received is not valid'), 'ERR_INVALID_NAME');\n }\n if (!options.nocache && !options.recursive) {\n const id = name.split('/')[2];\n const result = this.cache.get(id);\n if (result) {\n return result;\n }\n }\n try {\n const result = await this.resolver.resolve(name, options);\n log(`IPNS record from ${ name } was resolved correctly`);\n return result;\n } catch (err) {\n log.error(err);\n throw err;\n }\n }\n async initializeKeyspace(privKey, value) {\n return this.publish(privKey, value, publisher.IpnsPublisher.defaultRecordLifetime);\n }\n}\n\nexports.IPNS = IPNS;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar key = require('interface-datastore/key');\nvar Errors = require('datastore-core/errors');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar toString = require('uint8arrays/to-string');\nvar equals = require('uint8arrays/equals');\nvar ipns = require('ipns');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:publisher'), { error: debug__default['default']('ipfs:ipns:publisher:error') });\nconst ERR_NOT_FOUND = Errors.notFoundError().code;\nconst defaultRecordLifetime = 60 * 60 * 1000;\nclass IpnsPublisher {\n constructor(routing, datastore) {\n this._routing = routing;\n this._datastore = datastore;\n }\n async publishWithEOL(privKey, value, lifetime) {\n if (!privKey || !privKey.bytes) {\n throw errCode__default['default'](new Error('invalid private key'), 'ERR_INVALID_PRIVATE_KEY');\n }\n const peerId = await PeerId__default['default'].createFromPrivKey(privKey.bytes);\n const record = await this._updateOrCreateRecord(privKey, value, lifetime, peerId);\n return this._putRecordToRouting(record, peerId);\n }\n publish(privKey, value) {\n return this.publishWithEOL(privKey, value, defaultRecordLifetime);\n }\n async _putRecordToRouting(record, peerId) {\n if (!PeerId__default['default'].isPeerId(peerId)) {\n const errMsg = 'peerId received is not valid';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_PEER_ID');\n }\n const publicKey = peerId._pubKey;\n const embedPublicKeyRecord = await ipns__namespace.embedPublicKey(publicKey, record);\n const keys = ipns__namespace.getIdKeys(peerId.toBytes());\n await this._publishEntry(keys.routingKey, embedPublicKeyRecord || record);\n await this._publishPublicKey(keys.routingPubKey, publicKey);\n return embedPublicKeyRecord || record;\n }\n async _publishEntry(key$1, entry) {\n const k = key.Key.asKey(key$1);\n if (!k) {\n const errMsg = 'datastore key does not have a valid format';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_DATASTORE_KEY');\n }\n let entryData;\n try {\n entryData = ipns__namespace.marshal(entry);\n } catch (err) {\n log.error(err);\n throw err;\n }\n try {\n const res = await this._routing.put(k.uint8Array(), entryData);\n log(`ipns record for ${ toString.toString(k.uint8Array(), 'base64') } was stored in the routing`);\n return res;\n } catch (err) {\n const errMsg = `ipns record for ${ toString.toString(k.uint8Array(), 'base64') } could not be stored in the routing`;\n log.error(errMsg);\n log.error(err);\n throw errCode__default['default'](new Error(errMsg), 'ERR_PUTTING_TO_ROUTING');\n }\n }\n async _publishPublicKey(key$1, publicKey) {\n const k = key.Key.asKey(key$1);\n if (!k) {\n const errMsg = 'datastore key does not have a valid format';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_DATASTORE_KEY');\n }\n if (!publicKey || !publicKey.bytes) {\n const errMsg = 'one or more of the provided parameters are not defined';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_UNDEFINED_PARAMETER');\n }\n try {\n const res = await this._routing.put(k.uint8Array(), publicKey.bytes);\n log(`public key for ${ toString.toString(k.uint8Array(), 'base64') } was stored in the routing`);\n return res;\n } catch (err) {\n const errMsg = `public key for ${ toString.toString(k.uint8Array(), 'base64') } could not be stored in the routing`;\n log.error(errMsg);\n log.error(err);\n throw errCode__default['default'](new Error(errMsg), 'ERR_PUTTING_TO_ROUTING');\n }\n }\n async _getPublished(peerId, options = {}) {\n if (!PeerId__default['default'].isPeerId(peerId)) {\n const errMsg = 'peerId received is not valid';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_PEER_ID');\n }\n const checkRouting = options.checkRouting !== false;\n try {\n const dsVal = await this._datastore.get(ipns__namespace.getLocalKey(peerId.id));\n return this._unmarshalData(dsVal);\n } catch (err) {\n if (err.code !== ERR_NOT_FOUND) {\n const errMsg = `unexpected error getting the ipns record ${ peerId.id } from datastore`;\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_UNEXPECTED_DATASTORE_RESPONSE');\n }\n if (!checkRouting) {\n throw errCode__default['default'](err, 'ERR_NOT_FOUND_AND_CHECK_ROUTING_NOT_ENABLED');\n }\n try {\n const keys = ipns__namespace.getIdKeys(peerId.toBytes());\n const res = await this._routing.get(keys.routingKey.uint8Array());\n return this._unmarshalData(res);\n } catch (err) {\n log.error(err);\n throw err;\n }\n }\n }\n _unmarshalData(data) {\n try {\n return ipns__namespace.unmarshal(data);\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_RECORD_DATA');\n }\n }\n async _updateOrCreateRecord(privKey, value, lifetime, peerId) {\n if (!PeerId__default['default'].isPeerId(peerId)) {\n const errMsg = 'peerId received is not valid';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_PEER_ID');\n }\n const getPublishedOptions = { checkRouting: true };\n let record;\n try {\n record = await this._getPublished(peerId, getPublishedOptions);\n } catch (err) {\n if (err.code !== ERR_NOT_FOUND) {\n const errMsg = `unexpected error when determining the last published IPNS record for ${ peerId.id } ${ err.stack }`;\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_DETERMINING_PUBLISHED_RECORD');\n }\n }\n let seqNumber = 0;\n if (record && record.sequence !== undefined) {\n seqNumber = !equals.equals(record.value, value) ? BigInt(record.sequence) + BigInt(1) : BigInt(record.sequence);\n }\n let entryData;\n try {\n entryData = await ipns__namespace.create(privKey, value, seqNumber, lifetime);\n } catch (err) {\n const errMsg = `ipns record for ${ value } could not be created`;\n log.error(err);\n throw errCode__default['default'](new Error(errMsg), 'ERR_CREATING_IPNS_RECORD');\n }\n try {\n const data = ipns__namespace.marshal(entryData);\n await this._datastore.put(ipns__namespace.getLocalKey(peerId.id), data);\n log(`ipns record for ${ toString.toString(value, 'base32') } was stored in the datastore`);\n return entryData;\n } catch (err) {\n const errMsg = `ipns record for ${ value } could not be stored in the datastore`;\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_STORING_IN_DATASTORE');\n }\n }\n}\nIpnsPublisher.defaultRecordLifetime = defaultRecordLifetime;\n\nexports.IpnsPublisher = IpnsPublisher;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction dbOpenFailedError(err) {\n err = err || new Error('Cannot open database');\n return errCode__default['default'](err, 'ERR_DB_OPEN_FAILED');\n}\nfunction dbDeleteFailedError(err) {\n err = err || new Error('Delete failed');\n return errCode__default['default'](err, 'ERR_DB_DELETE_FAILED');\n}\nfunction dbWriteFailedError(err) {\n err = err || new Error('Write failed');\n return errCode__default['default'](err, 'ERR_DB_WRITE_FAILED');\n}\nfunction notFoundError(err) {\n err = err || new Error('Not Found');\n return errCode__default['default'](err, 'ERR_NOT_FOUND');\n}\nfunction abortedError(err) {\n err = err || new Error('Aborted');\n return errCode__default['default'](err, 'ERR_ABORTED');\n}\n\nexports.abortedError = abortedError;\nexports.dbDeleteFailedError = dbDeleteFailedError;\nexports.dbOpenFailedError = dbOpenFailedError;\nexports.dbWriteFailedError = dbWriteFailedError;\nexports.notFoundError = notFoundError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar NanoDate = require('timestamp-nano');\nvar key = require('interface-datastore/key');\nvar crypto = require('libp2p-crypto');\nvar PeerId = require('peer-id');\nvar Digest = require('multiformats/hashes/digest');\nvar identity = require('multiformats/hashes/identity');\nvar errCode = require('err-code');\nvar base32 = require('multiformats/bases/base32');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar concat = require('uint8arrays/concat');\nvar equals = require('uint8arrays/equals');\nvar cborg = require('cborg');\nvar Long = require('long');\nvar debug = require('debug');\nvar ipns = require('./pb/ipns.js');\nvar utils = require('./utils.js');\nvar errors = require('./errors.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar NanoDate__default = /*#__PURE__*/_interopDefaultLegacy(NanoDate);\nvar crypto__default = /*#__PURE__*/_interopDefaultLegacy(crypto);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar cborg__namespace = /*#__PURE__*/_interopNamespace(cborg);\nvar Long__default = /*#__PURE__*/_interopDefaultLegacy(Long);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('jsipns'), { error: debug__default['default']('jsipns:error') });\nconst ID_MULTIHASH_CODE = identity.identity.code;\nconst IPNS_PREFIX = fromString.fromString('/ipns/');\nconst namespace = '/ipns/';\nconst namespaceLength = namespace.length;\nconst create = (privateKey, value, seq, lifetime) => {\n const expirationDate = new NanoDate__default['default'](Date.now() + Number(lifetime));\n const validityType = ipns.IpnsEntry.ValidityType.EOL;\n const [ms, ns] = lifetime.toString().split('.');\n const lifetimeNs = BigInt(ms) * BigInt(100000) + BigInt(ns || 0);\n return _create(privateKey, value, seq, validityType, expirationDate, lifetimeNs);\n};\nconst createWithExpiration = (privateKey, value, seq, expiration) => {\n const expirationDate = NanoDate__default['default'].fromString(expiration);\n const validityType = ipns.IpnsEntry.ValidityType.EOL;\n const ttlMs = expirationDate.toDate().getTime() - Date.now();\n const ttlNs = BigInt(ttlMs) * BigInt(100000) + BigInt(expirationDate.getNano());\n return _create(privateKey, value, seq, validityType, expirationDate, ttlNs);\n};\nconst _create = async (privateKey, value, seq, validityType, expirationDate, ttl) => {\n seq = BigInt(seq);\n const isoValidity = fromString.fromString(expirationDate.toString());\n const signatureV1 = await sign(privateKey, value, validityType, isoValidity);\n const data = createCborData(value, isoValidity, validityType, seq, ttl);\n const sigData = ipnsEntryDataForV2Sig(data);\n const signatureV2 = await privateKey.sign(sigData);\n const entry = {\n value,\n signature: signatureV1,\n validityType: validityType,\n validity: isoValidity,\n sequence: seq,\n ttl,\n signatureV2,\n data\n };\n log(`ipns entry for ${ value } created`);\n return entry;\n};\nconst createCborData = (value, validity, validityType, sequence, ttl) => {\n const data = {\n Value: value,\n Validity: validity,\n ValidityType: validityType,\n Sequence: sequence,\n TTL: ttl\n };\n return cborg__namespace.encode(data);\n};\nconst validate = async (publicKey, entry) => {\n const {value, validityType, validity} = entry;\n let dataForSignature;\n let signature;\n if (entry.signatureV2 && entry.data) {\n signature = entry.signatureV2;\n dataForSignature = ipnsEntryDataForV2Sig(entry.data);\n validateCborDataMatchesPbData(entry);\n } else {\n signature = entry.signature;\n dataForSignature = ipnsEntryDataForV1Sig(value, validityType, validity);\n }\n let isValid;\n try {\n isValid = await publicKey.verify(dataForSignature, signature);\n } catch (err) {\n isValid = false;\n }\n if (!isValid) {\n log.error('record signature verification failed');\n throw errCode__default['default'](new Error('record signature verification failed'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (validityType === ipns.IpnsEntry.ValidityType.EOL) {\n let validityDate;\n try {\n validityDate = utils.parseRFC3339(toString.toString(validity));\n } catch (e) {\n log.error('unrecognized validity format (not an rfc3339 format)');\n throw errCode__default['default'](new Error('unrecognized validity format (not an rfc3339 format)'), errors.ERR_UNRECOGNIZED_FORMAT);\n }\n if (validityDate.getTime() < Date.now()) {\n log.error('record has expired');\n throw errCode__default['default'](new Error('record has expired'), errors.ERR_IPNS_EXPIRED_RECORD);\n }\n } else if (validityType) {\n log.error('unrecognized validity type');\n throw errCode__default['default'](new Error('unrecognized validity type'), errors.ERR_UNRECOGNIZED_VALIDITY);\n }\n log(`ipns entry for ${ value } is valid`);\n};\nconst validateCborDataMatchesPbData = entry => {\n if (!entry.data) {\n throw errCode__default['default'](new Error('Record data is missing'), errors.ERR_INVALID_RECORD_DATA);\n }\n const data = cborg__namespace.decode(entry.data);\n if (Number.isInteger(data.Sequence)) {\n data.Sequence = BigInt(data.Sequence);\n }\n if (Number.isInteger(data.TTL)) {\n data.TTL = BigInt(data.TTL);\n }\n if (!equals.equals(data.Value, entry.value)) {\n throw errCode__default['default'](new Error('Field \"value\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (!equals.equals(data.Validity, entry.validity)) {\n throw errCode__default['default'](new Error('Field \"validity\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (data.ValidityType !== entry.validityType) {\n throw errCode__default['default'](new Error('Field \"validityType\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (data.Sequence !== entry.sequence) {\n throw errCode__default['default'](new Error('Field \"sequence\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (data.TTL !== entry.ttl) {\n throw errCode__default['default'](new Error('Field \"ttl\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n};\nconst embedPublicKey = async (publicKey, entry) => {\n if (!publicKey || !publicKey.bytes || !entry) {\n const error = new Error('one or more of the provided parameters are not defined');\n log.error(error);\n throw errCode__default['default'](error, errors.ERR_UNDEFINED_PARAMETER);\n }\n let peerId;\n try {\n peerId = await PeerId__default['default'].createFromPubKey(publicKey.bytes);\n } catch (err) {\n throw errCode__default['default'](err, errors.ERR_PEER_ID_FROM_PUBLIC_KEY);\n }\n let extractedPublicKey;\n try {\n extractedPublicKey = extractPublicKeyFromId(peerId);\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](err, errors.ERR_PUBLIC_KEY_FROM_ID);\n }\n if (extractedPublicKey) {\n return null;\n }\n try {\n entry.pubKey = crypto__default['default'].keys.marshalPublicKey(publicKey);\n } catch (err) {\n log.error(err);\n throw err;\n }\n return entry;\n};\nconst extractPublicKey = async (peerId, entry) => {\n if (!entry || !peerId) {\n const error = new Error('one or more of the provided parameters are not defined');\n log.error(error);\n throw errCode__default['default'](error, errors.ERR_UNDEFINED_PARAMETER);\n }\n let pubKey;\n if (entry.pubKey) {\n try {\n pubKey = crypto__default['default'].keys.unmarshalPublicKey(entry.pubKey);\n } catch (err) {\n log.error(err);\n throw err;\n }\n const otherId = await PeerId__default['default'].createFromPubKey(entry.pubKey);\n if (!otherId.equals(peerId)) {\n throw errCode__default['default'](new Error('Embedded public key did not match PeerID'), errors.ERR_INVALID_EMBEDDED_KEY);\n }\n } else if (peerId.pubKey) {\n pubKey = peerId.pubKey;\n }\n if (pubKey) {\n return pubKey;\n }\n throw errCode__default['default'](new Error('no public key is available'), errors.ERR_UNDEFINED_PARAMETER);\n};\nconst rawStdEncoding = key => base32.base32upper.encode(key).slice(1);\nconst getLocalKey = key$1 => new key.Key(`/ipns/${ rawStdEncoding(key$1) }`);\nconst getIdKeys = pid => {\n const pkBuffer = fromString.fromString('/pk/');\n const ipnsBuffer = fromString.fromString('/ipns/');\n return {\n routingPubKey: new key.Key(concat.concat([\n pkBuffer,\n pid\n ]), false),\n pkKey: new key.Key(rawStdEncoding(concat.concat([\n pkBuffer,\n pid\n ]))),\n routingKey: new key.Key(concat.concat([\n ipnsBuffer,\n pid\n ]), false),\n ipnsKey: new key.Key(rawStdEncoding(concat.concat([\n ipnsBuffer,\n pid\n ])))\n };\n};\nconst sign = (privateKey, value, validityType, validity) => {\n try {\n const dataForSignature = ipnsEntryDataForV1Sig(value, validityType, validity);\n return privateKey.sign(dataForSignature);\n } catch (error) {\n log.error('record signature creation failed');\n throw errCode__default['default'](new Error('record signature creation failed: ' + error.message), errors.ERR_SIGNATURE_CREATION);\n }\n};\nconst getValidityType = validityType => {\n if (validityType.toString() === '0') {\n return 'EOL';\n }\n const error = new Error(`unrecognized validity type ${ validityType.toString() }`);\n log.error(error);\n throw errCode__default['default'](error, errors.ERR_UNRECOGNIZED_VALIDITY);\n};\nconst ipnsEntryDataForV1Sig = (value, validityType, validity) => {\n const validityTypeBuffer = fromString.fromString(getValidityType(validityType));\n return concat.concat([\n value,\n validity,\n validityTypeBuffer\n ]);\n};\nconst ipnsEntryDataForV2Sig = data => {\n const entryData = fromString.fromString('ipns-signature:');\n return concat.concat([\n entryData,\n data\n ]);\n};\nconst extractPublicKeyFromId = peerId => {\n const digest = Digest__namespace.decode(peerId.id);\n if (digest.code !== ID_MULTIHASH_CODE) {\n return null;\n }\n return crypto__default['default'].keys.unmarshalPublicKey(digest.digest);\n};\nconst marshal = obj => {\n return ipns.IpnsEntry.encode({\n ...obj,\n sequence: Long__default['default'].fromString(obj.sequence.toString()),\n ttl: obj.ttl == null ? undefined : Long__default['default'].fromString(obj.ttl.toString())\n }).finish();\n};\nconst unmarshal = buf => {\n const message = ipns.IpnsEntry.decode(buf);\n const object = ipns.IpnsEntry.toObject(message, {\n defaults: false,\n arrays: true,\n objects: false\n });\n return {\n value: object.value,\n signature: object.signature,\n validityType: object.validityType,\n validity: object.validity,\n sequence: Object.hasOwnProperty.call(object, 'sequence') ? BigInt(`${ object.sequence }`) : 0,\n pubKey: object.pubKey,\n ttl: Object.hasOwnProperty.call(object, 'ttl') ? BigInt(`${ object.ttl }`) : undefined,\n signatureV2: object.signatureV2,\n data: object.data\n };\n};\nconst validator = {\n validate: async (marshalledData, key) => {\n const receivedEntry = unmarshal(marshalledData);\n const bufferId = key.slice(IPNS_PREFIX.length);\n const peerId = PeerId__default['default'].createFromBytes(bufferId);\n const pubKey = await extractPublicKey(peerId, receivedEntry);\n await validate(pubKey, receivedEntry);\n },\n select: (dataA, dataB) => {\n const entryA = unmarshal(dataA);\n const entryB = unmarshal(dataB);\n if (entryA.signatureV2 && !entryB.signatureV2) {\n return 0;\n } else if (entryB.signatureV2 && !entryA.signatureV2) {\n return 1;\n }\n if (entryA.sequence > entryB.sequence) {\n return 0;\n } else if (entryA.sequence < entryB.sequence) {\n return 1;\n }\n const entryAValidityDate = utils.parseRFC3339(toString.toString(entryA.validity));\n const entryBValidityDate = utils.parseRFC3339(toString.toString(entryB.validity));\n return entryBValidityDate.getTime() > entryAValidityDate.getTime() ? 1 : 0;\n }\n};\n\nexports.create = create;\nexports.createWithExpiration = createWithExpiration;\nexports.embedPublicKey = embedPublicKey;\nexports.extractPublicKey = extractPublicKey;\nexports.getIdKeys = getIdKeys;\nexports.getLocalKey = getLocalKey;\nexports.marshal = marshal;\nexports.namespace = namespace;\nexports.namespaceLength = namespaceLength;\nexports.unmarshal = unmarshal;\nexports.validate = validate;\nexports.validator = validator;\n","/**\n * Timestamp for 64-bit time_t, nanosecond precision and strftime\n *\n * @author Yusuke Kawasaki\n * @license MIT\n * @see https://github.com/kawanet/timestamp-nano\n */\n\nvar Timestamp = (function() {\n if (\"undefined\" !== typeof module) module.exports = Timestamp;\n\n var SEC_DAY = 24 * 3600; // seconds per day\n var YEAR_SLOT = 3200; // years per slot\n var DAY_SLOT = (365 * 400 + 97) * YEAR_SLOT / 400; // days per slot\n var SEC_SLOT = SEC_DAY * DAY_SLOT; // seconds per slot\n var MSEC_SLOT = SEC_SLOT * 1000; // mseconds per slot\n\n // 15.9.1.1 Time Values and Time Range\n // The actual range of times supported by ECMAScript Date objects is\n // exactly –100,000,000 days to 100,000,000 days measured relative to\n // midnight at the beginning of 01 January, 1970 UTC.\n var MAX_MSEC = 1000 * 10000 * 10000 * SEC_DAY;\n\n var BIT24 = 0x1000000;\n var BIT32 = 0x10000 * 0x10000;\n var DEC6 = 1000 * 1000;\n var DEC9 = 1000 * 1000 * 1000;\n var ZERO9 = \"000000000\";\n\n var trunc = Math.trunc || Math_trunc;\n var P = Timestamp.prototype;\n\n // static methods\n Timestamp.fromDate = fromDate;\n Timestamp.fromInt64BE = buildFromInt64(0, 1, 2, 3, 0, 4);\n Timestamp.fromInt64LE = buildFromInt64(3, 2, 1, 0, 4, 0);\n Timestamp.fromString = fromString;\n Timestamp.fromTimeT = fromTimeT;\n\n // private properties\n P.year = 0; // Offset number for year precision\n P.time = 0; // Milliseconds from epoch\n P.nano = 0; // Offset number for nanosecond precision\n\n // instance methods\n P.addNano = addNano;\n P.getNano = getNano;\n P.getTimeT = getTimeT;\n P.getYear = getYear;\n P.toDate = toDate;\n P.toJSON = toJSON;\n P.toString = toString;\n P.writeInt64BE = buildWriteInt64(0, 1, 2, 3, 0, 4);\n P.writeInt64LE = buildWriteInt64(3, 2, 1, 0, 4, 0);\n\n var FMT_JSON = \"%Y-%m-%dT%H:%M:%S.%NZ\";\n\n var FMT_MONTH = [\n \"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"\n ];\n\n var FMT_DAY = [\n \"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"\n ];\n\n var FMT_STRING = {\n \"%\": \"%\",\n F: \"%Y-%m-%d\",\n n: \"\\n\",\n R: \"%H:%M\",\n T: \"%H:%M:%S\",\n t: \"\\t\",\n X: \"%T\",\n Z: \"GMT\",\n z: \"+0000\"\n };\n\n return Timestamp;\n\n function Timestamp(time, nano, year) {\n var ts = this;\n if (!(ts instanceof Timestamp)) return new Timestamp(time, nano, year);\n ts.time = +time || 0;\n ts.nano = +nano || 0;\n ts.year = +year || 0;\n normalize(ts);\n }\n\n function getYear() {\n var year = this.toDate().getUTCFullYear();\n return year + this.year;\n }\n\n function normalize(ts) {\n var year = ts.year;\n var time = ts.time;\n var nano = ts.nano;\n var changed;\n var slot;\n\n // normalize nano\n if (nano < 0 || DEC6 <= nano) {\n var n = Math.floor(nano / DEC6);\n nano -= n * DEC6;\n time += n;\n changed = 1;\n }\n\n var y = year % YEAR_SLOT;\n if (time < -MAX_MSEC || MAX_MSEC < time || y) {\n // shrink time into the minimal slot\n slot = trunc(time / MSEC_SLOT);\n if (slot) {\n year += slot * YEAR_SLOT;\n time -= slot * MSEC_SLOT;\n }\n\n // add year offset smaller than a slot\n var dt = newDate(time);\n dt.setUTCFullYear(y + dt.getUTCFullYear());\n year -= y;\n time = +dt;\n\n // use full range of 100 million days.\n slot = trunc(year / YEAR_SLOT);\n var total = time + slot * MSEC_SLOT;\n if (slot && -MAX_MSEC <= total && total <= MAX_MSEC) {\n year -= slot * YEAR_SLOT;\n time = total;\n }\n\n changed = 1;\n }\n\n if (changed) {\n ts.year = year;\n ts.time = time;\n ts.nano = nano;\n }\n\n return ts;\n }\n\n function toDate() {\n var ts = normalize(this);\n return newDate(ts.time);\n }\n\n function newDate(time) {\n var dt = new Date(0);\n dt.setTime(time);\n return dt;\n }\n\n function addNano(nano) {\n this.nano += +nano || 0;\n return this;\n }\n\n function getNano() {\n var ts = normalize(this);\n return ((ts.time % 1000) * DEC6 + (+ts.nano) + DEC9) % DEC9;\n }\n\n function fromString(string) {\n var time;\n var ts = new Timestamp();\n string += \"\";\n\n var array = string.replace(/^\\s*[+\\-]?\\d+/, function(match) {\n var year = +match;\n // Use only years around 1970 to avoid Date's terrible behavior:\n // 15.9.4.3 Date.UTC\n // If y is not NaN and 0 <= y <= 99, then let yr be 1900+y\n var y = 1970 + ((year - 1970) % 400);\n ts.year = year - y;\n return y;\n }).replace(/(?:Z|([+\\-]\\d{2}):?(\\d{2}))$/, function(match, hour, min) {\n // time zone\n if (hour < 0) min *= -1;\n time = ((+hour) * 60 + (+min)) * 60000;\n return \"\";\n }).replace(/\\.\\d+$/, function(match) {\n // nanoseconds\n ts.nano = +((match + ZERO9).substr(1, 9));\n return \"\";\n }).split(/\\D+/);\n\n if (array.length > 1) {\n array[1]--; // month starts from 0\n } else {\n array[1] = 0;\n }\n\n ts.time = time = Date.UTC.apply(Date, array) - (time || 0);\n\n if (isNaN(time)) {\n throw new TypeError(\"Invalid Date\");\n }\n\n return normalize(ts);\n }\n\n function fromDate(date) {\n return new Timestamp(+date);\n }\n\n function fromTimeT(time) {\n return fromTime(time, 0);\n }\n\n function fromTime(low, high) {\n high |= 0;\n high *= BIT32;\n low = +low || 0;\n\n // slot count\n var slot = trunc(high / SEC_SLOT) + trunc(low / SEC_SLOT);\n\n // seconds within slot\n var second = (high % SEC_SLOT) + (low % SEC_SLOT);\n\n // slot offset\n var offset = trunc(second / SEC_SLOT);\n if (offset) {\n slot += offset;\n second -= offset * SEC_SLOT;\n }\n\n return new Timestamp(second * 1000, 0, slot * YEAR_SLOT);\n }\n\n function getTimeT() {\n var ts = normalize(this);\n var time = Math.floor(ts.time / 1000);\n\n var year = ts.year;\n if (year) time += year * DAY_SLOT * SEC_DAY / YEAR_SLOT;\n\n // this may loose some bits over than 53 bit precision\n return time;\n }\n\n function toJSON() {\n return this.toString().replace(/0{1,6}Z$/, \"Z\");\n }\n\n function toString(format) {\n var ts = this;\n var dt = ts.toDate();\n var map = {\n H: H,\n L: L,\n M: M,\n N: N,\n S: S,\n Y: Y,\n a: a,\n b: b,\n d: d,\n e: e,\n m: m\n };\n\n return strftime(format || FMT_JSON);\n\n function strftime(format) {\n return format.replace(/%./g, function(match) {\n var m = match[1];\n var c = FMT_STRING[m];\n var f = map[m];\n return c ? strftime(c) : f ? f() : match;\n });\n }\n\n function Y() {\n var year = ts.getYear();\n if (year > 999999) {\n return \"+\" + year;\n } else if (year > 9999) {\n return \"+\" + pad(year, 6);\n } else if (year >= 0) {\n return pad(year, 4);\n } else if (year >= -999999) {\n return \"-\" + pad(-year, 6);\n } else {\n return year;\n }\n }\n\n function m() {\n return pad2(dt.getUTCMonth() + 1);\n }\n\n function d() {\n return pad2(dt.getUTCDate());\n }\n\n function e() {\n return padS(dt.getUTCDate());\n }\n\n function H() {\n return pad2(dt.getUTCHours());\n }\n\n function M() {\n return pad2(dt.getUTCMinutes());\n }\n\n function S() {\n return pad2(dt.getUTCSeconds());\n }\n\n function L() {\n return pad(dt.getUTCMilliseconds(), 3);\n }\n\n function N() {\n return pad(ts.getNano(), 9);\n }\n\n function a() {\n return FMT_DAY[dt.getUTCDay()];\n }\n\n function b() {\n return FMT_MONTH[dt.getUTCMonth()];\n }\n }\n\n function buildWriteInt64(pos0, pos1, pos2, pos3, posH, posL) {\n return writeInt64;\n\n function writeInt64(buffer, offset) {\n var ts = normalize(this);\n if (!buffer) buffer = new Array(8);\n checkRange(buffer, offset |= 0);\n\n var second = Math.floor(ts.time / 1000);\n var day = ts.year * (DAY_SLOT * SEC_DAY / YEAR_SLOT);\n var high = trunc(day / BIT32) + trunc(second / BIT32);\n var low = (day % BIT32) + (second % BIT32);\n\n // slot offset\n var slot = Math.floor(low / BIT32);\n if (slot) {\n high += slot;\n low -= slot * BIT32;\n }\n\n writeUint32(buffer, offset + posH, high);\n writeUint32(buffer, offset + posL, low);\n return buffer;\n }\n\n function writeUint32(buffer, offset, value) {\n buffer[offset + pos0] = (value >> 24) & 255;\n buffer[offset + pos1] = (value >> 16) & 255;\n buffer[offset + pos2] = (value >> 8) & 255;\n buffer[offset + pos3] = value & 255;\n }\n }\n\n function buildFromInt64(pos0, pos1, pos2, pos3, posH, posL) {\n return fromInt64;\n\n function fromInt64(buffer, offset) {\n checkRange(buffer, offset |= 0);\n var high = readUint32(buffer, offset + posH);\n var low = readUint32(buffer, offset + posL);\n return fromTime(low, high);\n }\n\n function readUint32(buffer, offset) {\n return (buffer[offset + pos0] * BIT24) +\n ((buffer[offset + pos1] << 16) |\n (buffer[offset + pos2] << 8) |\n buffer[offset + pos3]);\n }\n }\n\n function checkRange(buffer, offset) {\n var last = buffer && buffer.length;\n if (last == null) throw new TypeError(\"Invalid Buffer\");\n if (last < offset + 8) throw new RangeError(\"Out of range\");\n }\n\n function Math_trunc(x) {\n var n = x - x % 1;\n return n === 0 && (x < 0 || (x === 0 && (1 / x !== 1 / 0))) ? -0 : n;\n }\n\n function padS(v) {\n return (v > 9 ? \"\" : \" \") + (v | 0);\n }\n\n function pad2(v) {\n return (v > 9 ? \"\" : \"0\") + (v | 0);\n }\n\n function pad(v, len) {\n return (ZERO9 + (v | 0)).substr(-len);\n }\n})();\n","'use strict'\n\nconst hmac = require('./hmac')\nconst aes = require('./aes')\nconst keys = require('./keys')\n\nexports.aes = aes\nexports.hmac = hmac\nexports.keys = keys\nexports.randomBytes = require('./random-bytes')\nexports.pbkdf2 = require('./pbkdf2')\n","'use strict'\n\nconst ciphers = require('./ciphers')\nconst cipherMode = require('./cipher-mode')\n\nexports.create = async function (key, iv) { // eslint-disable-line require-await\n const mode = cipherMode(key)\n const cipher = ciphers.createCipheriv(mode, key, iv)\n const decipher = ciphers.createDecipheriv(mode, key, iv)\n\n const res = {\n async encrypt (data) { // eslint-disable-line require-await\n return cipher.update(data)\n },\n\n async decrypt (data) { // eslint-disable-line require-await\n return decipher.update(data)\n }\n }\n\n return res\n}\n","'use strict'\n\nrequire('node-forge/lib/aes')\nconst forge = require('node-forge/lib/forge')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\nmodule.exports = {\n createCipheriv: (mode, key, iv) => {\n const cipher2 = forge.cipher.createCipher('AES-CTR', uint8ArrayToString(key, 'ascii'))\n cipher2.start({ iv: uint8ArrayToString(iv, 'ascii') })\n return {\n update: (data) => {\n cipher2.update(forge.util.createBuffer(uint8ArrayToString(data, 'ascii')))\n return uint8ArrayFromString(cipher2.output.getBytes(), 'ascii')\n }\n }\n },\n createDecipheriv: (mode, key, iv) => {\n const cipher2 = forge.cipher.createDecipher('AES-CTR', uint8ArrayToString(key, 'ascii'))\n cipher2.start({ iv: uint8ArrayToString(iv, 'ascii') })\n return {\n update: (data) => {\n cipher2.update(forge.util.createBuffer(uint8ArrayToString(data, 'ascii')))\n return uint8ArrayFromString(cipher2.output.getBytes(), 'ascii')\n }\n }\n }\n}\n","'use strict'\n\nconst errcode = require('err-code')\n\nconst CIPHER_MODES = {\n 16: 'aes-128-ctr',\n 32: 'aes-256-ctr'\n}\n\nmodule.exports = function (key) {\n const mode = CIPHER_MODES[key.length]\n if (!mode) {\n const modes = Object.entries(CIPHER_MODES).map(([k, v]) => `${k} (${v})`).join(' / ')\n throw errcode(new Error(`Invalid key length ${key.length} bytes. Must be ${modes}`), 'ERR_INVALID_KEY_LENGTH')\n }\n return mode\n}\n","'use strict'\n\nconst forgePbkdf2 = require('node-forge/lib/pbkdf2')\nconst forgeUtil = require('node-forge/lib/util')\nconst errcode = require('err-code')\n\n/**\n * Maps an IPFS hash name to its node-forge equivalent.\n *\n * See https://github.com/multiformats/multihash/blob/master/hashtable.csv\n *\n * @private\n */\nconst hashName = {\n sha1: 'sha1',\n 'sha2-256': 'sha256',\n 'sha2-512': 'sha512'\n}\n\n/**\n * Computes the Password-Based Key Derivation Function 2.\n *\n * @param {string} password\n * @param {string} salt\n * @param {number} iterations\n * @param {number} keySize - (in bytes)\n * @param {string} hash - The hash name ('sha1', 'sha2-512, ...)\n * @returns {string} - A new password\n */\nfunction pbkdf2 (password, salt, iterations, keySize, hash) {\n const hasher = hashName[hash]\n if (!hasher) {\n const types = Object.keys(hashName).join(' / ')\n throw errcode(new Error(`Hash '${hash}' is unknown or not supported. Must be ${types}`), 'ERR_UNSUPPORTED_HASH_TYPE')\n }\n const dek = forgePbkdf2(\n password,\n salt,\n iterations,\n keySize,\n hasher)\n return forgeUtil.encode64(dek)\n}\n\nmodule.exports = pbkdf2\n","module.exports = Long;\r\n\r\n/**\r\n * wasm optimizations, to do native i64 multiplication and divide\r\n */\r\nvar wasm = null;\r\n\r\ntry {\r\n wasm = new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([\r\n 0, 97, 115, 109, 1, 0, 0, 0, 1, 13, 2, 96, 0, 1, 127, 96, 4, 127, 127, 127, 127, 1, 127, 3, 7, 6, 0, 1, 1, 1, 1, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 50, 6, 3, 109, 117, 108, 0, 1, 5, 100, 105, 118, 95, 115, 0, 2, 5, 100, 105, 118, 95, 117, 0, 3, 5, 114, 101, 109, 95, 115, 0, 4, 5, 114, 101, 109, 95, 117, 0, 5, 8, 103, 101, 116, 95, 104, 105, 103, 104, 0, 0, 10, 191, 1, 6, 4, 0, 35, 0, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 126, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 127, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 128, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 129, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 130, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11\r\n ])), {}).exports;\r\n} catch (e) {\r\n // no wasm support :(\r\n}\r\n\r\n/**\r\n * Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as *signed* integers.\r\n * See the from* functions below for more convenient ways of constructing Longs.\r\n * @exports Long\r\n * @class A Long class for representing a 64 bit two's-complement integer value.\r\n * @param {number} low The low (signed) 32 bits of the long\r\n * @param {number} high The high (signed) 32 bits of the long\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @constructor\r\n */\r\nfunction Long(low, high, unsigned) {\r\n\r\n /**\r\n * The low 32 bits as a signed value.\r\n * @type {number}\r\n */\r\n this.low = low | 0;\r\n\r\n /**\r\n * The high 32 bits as a signed value.\r\n * @type {number}\r\n */\r\n this.high = high | 0;\r\n\r\n /**\r\n * Whether unsigned or not.\r\n * @type {boolean}\r\n */\r\n this.unsigned = !!unsigned;\r\n}\r\n\r\n// The internal representation of a long is the two given signed, 32-bit values.\r\n// We use 32-bit pieces because these are the size of integers on which\r\n// Javascript performs bit-operations. For operations like addition and\r\n// multiplication, we split each number into 16 bit pieces, which can easily be\r\n// multiplied within Javascript's floating-point representation without overflow\r\n// or change in sign.\r\n//\r\n// In the algorithms below, we frequently reduce the negative case to the\r\n// positive case by negating the input(s) and then post-processing the result.\r\n// Note that we must ALWAYS check specially whether those values are MIN_VALUE\r\n// (-2^63) because -MIN_VALUE == MIN_VALUE (since 2^63 cannot be represented as\r\n// a positive number, it overflows back into a negative). Not handling this\r\n// case would often result in infinite recursion.\r\n//\r\n// Common constant values ZERO, ONE, NEG_ONE, etc. are defined below the from*\r\n// methods on which they depend.\r\n\r\n/**\r\n * An indicator used to reliably determine if an object is a Long or not.\r\n * @type {boolean}\r\n * @const\r\n * @private\r\n */\r\nLong.prototype.__isLong__;\r\n\r\nObject.defineProperty(Long.prototype, \"__isLong__\", { value: true });\r\n\r\n/**\r\n * @function\r\n * @param {*} obj Object\r\n * @returns {boolean}\r\n * @inner\r\n */\r\nfunction isLong(obj) {\r\n return (obj && obj[\"__isLong__\"]) === true;\r\n}\r\n\r\n/**\r\n * Tests if the specified object is a Long.\r\n * @function\r\n * @param {*} obj Object\r\n * @returns {boolean}\r\n */\r\nLong.isLong = isLong;\r\n\r\n/**\r\n * A cache of the Long representations of small integer values.\r\n * @type {!Object}\r\n * @inner\r\n */\r\nvar INT_CACHE = {};\r\n\r\n/**\r\n * A cache of the Long representations of small unsigned integer values.\r\n * @type {!Object}\r\n * @inner\r\n */\r\nvar UINT_CACHE = {};\r\n\r\n/**\r\n * @param {number} value\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromInt(value, unsigned) {\r\n var obj, cachedObj, cache;\r\n if (unsigned) {\r\n value >>>= 0;\r\n if (cache = (0 <= value && value < 256)) {\r\n cachedObj = UINT_CACHE[value];\r\n if (cachedObj)\r\n return cachedObj;\r\n }\r\n obj = fromBits(value, (value | 0) < 0 ? -1 : 0, true);\r\n if (cache)\r\n UINT_CACHE[value] = obj;\r\n return obj;\r\n } else {\r\n value |= 0;\r\n if (cache = (-128 <= value && value < 128)) {\r\n cachedObj = INT_CACHE[value];\r\n if (cachedObj)\r\n return cachedObj;\r\n }\r\n obj = fromBits(value, value < 0 ? -1 : 0, false);\r\n if (cache)\r\n INT_CACHE[value] = obj;\r\n return obj;\r\n }\r\n}\r\n\r\n/**\r\n * Returns a Long representing the given 32 bit integer value.\r\n * @function\r\n * @param {number} value The 32 bit integer in question\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromInt = fromInt;\r\n\r\n/**\r\n * @param {number} value\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromNumber(value, unsigned) {\r\n if (isNaN(value))\r\n return unsigned ? UZERO : ZERO;\r\n if (unsigned) {\r\n if (value < 0)\r\n return UZERO;\r\n if (value >= TWO_PWR_64_DBL)\r\n return MAX_UNSIGNED_VALUE;\r\n } else {\r\n if (value <= -TWO_PWR_63_DBL)\r\n return MIN_VALUE;\r\n if (value + 1 >= TWO_PWR_63_DBL)\r\n return MAX_VALUE;\r\n }\r\n if (value < 0)\r\n return fromNumber(-value, unsigned).neg();\r\n return fromBits((value % TWO_PWR_32_DBL) | 0, (value / TWO_PWR_32_DBL) | 0, unsigned);\r\n}\r\n\r\n/**\r\n * Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned.\r\n * @function\r\n * @param {number} value The number in question\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromNumber = fromNumber;\r\n\r\n/**\r\n * @param {number} lowBits\r\n * @param {number} highBits\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromBits(lowBits, highBits, unsigned) {\r\n return new Long(lowBits, highBits, unsigned);\r\n}\r\n\r\n/**\r\n * Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is\r\n * assumed to use 32 bits.\r\n * @function\r\n * @param {number} lowBits The low 32 bits\r\n * @param {number} highBits The high 32 bits\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromBits = fromBits;\r\n\r\n/**\r\n * @function\r\n * @param {number} base\r\n * @param {number} exponent\r\n * @returns {number}\r\n * @inner\r\n */\r\nvar pow_dbl = Math.pow; // Used 4 times (4*8 to 15+4)\r\n\r\n/**\r\n * @param {string} str\r\n * @param {(boolean|number)=} unsigned\r\n * @param {number=} radix\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromString(str, unsigned, radix) {\r\n if (str.length === 0)\r\n throw Error('empty string');\r\n if (str === \"NaN\" || str === \"Infinity\" || str === \"+Infinity\" || str === \"-Infinity\")\r\n return ZERO;\r\n if (typeof unsigned === 'number') {\r\n // For goog.math.long compatibility\r\n radix = unsigned,\r\n unsigned = false;\r\n } else {\r\n unsigned = !! unsigned;\r\n }\r\n radix = radix || 10;\r\n if (radix < 2 || 36 < radix)\r\n throw RangeError('radix');\r\n\r\n var p;\r\n if ((p = str.indexOf('-')) > 0)\r\n throw Error('interior hyphen');\r\n else if (p === 0) {\r\n return fromString(str.substring(1), unsigned, radix).neg();\r\n }\r\n\r\n // Do several (8) digits each time through the loop, so as to\r\n // minimize the calls to the very expensive emulated div.\r\n var radixToPower = fromNumber(pow_dbl(radix, 8));\r\n\r\n var result = ZERO;\r\n for (var i = 0; i < str.length; i += 8) {\r\n var size = Math.min(8, str.length - i),\r\n value = parseInt(str.substring(i, i + size), radix);\r\n if (size < 8) {\r\n var power = fromNumber(pow_dbl(radix, size));\r\n result = result.mul(power).add(fromNumber(value));\r\n } else {\r\n result = result.mul(radixToPower);\r\n result = result.add(fromNumber(value));\r\n }\r\n }\r\n result.unsigned = unsigned;\r\n return result;\r\n}\r\n\r\n/**\r\n * Returns a Long representation of the given string, written using the specified radix.\r\n * @function\r\n * @param {string} str The textual representation of the Long\r\n * @param {(boolean|number)=} unsigned Whether unsigned or not, defaults to signed\r\n * @param {number=} radix The radix in which the text is written (2-36), defaults to 10\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromString = fromString;\r\n\r\n/**\r\n * @function\r\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromValue(val, unsigned) {\r\n if (typeof val === 'number')\r\n return fromNumber(val, unsigned);\r\n if (typeof val === 'string')\r\n return fromString(val, unsigned);\r\n // Throws for non-objects, converts non-instanceof Long:\r\n return fromBits(val.low, val.high, typeof unsigned === 'boolean' ? unsigned : val.unsigned);\r\n}\r\n\r\n/**\r\n * Converts the specified value to a Long using the appropriate from* function for its type.\r\n * @function\r\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val Value\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long}\r\n */\r\nLong.fromValue = fromValue;\r\n\r\n// NOTE: the compiler should inline these constant values below and then remove these variables, so there should be\r\n// no runtime penalty for these.\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_16_DBL = 1 << 16;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_24_DBL = 1 << 24;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_32_DBL = TWO_PWR_16_DBL * TWO_PWR_16_DBL;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_64_DBL = TWO_PWR_32_DBL * TWO_PWR_32_DBL;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_63_DBL = TWO_PWR_64_DBL / 2;\r\n\r\n/**\r\n * @type {!Long}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_24 = fromInt(TWO_PWR_24_DBL);\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar ZERO = fromInt(0);\r\n\r\n/**\r\n * Signed zero.\r\n * @type {!Long}\r\n */\r\nLong.ZERO = ZERO;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar UZERO = fromInt(0, true);\r\n\r\n/**\r\n * Unsigned zero.\r\n * @type {!Long}\r\n */\r\nLong.UZERO = UZERO;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar ONE = fromInt(1);\r\n\r\n/**\r\n * Signed one.\r\n * @type {!Long}\r\n */\r\nLong.ONE = ONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar UONE = fromInt(1, true);\r\n\r\n/**\r\n * Unsigned one.\r\n * @type {!Long}\r\n */\r\nLong.UONE = UONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar NEG_ONE = fromInt(-1);\r\n\r\n/**\r\n * Signed negative one.\r\n * @type {!Long}\r\n */\r\nLong.NEG_ONE = NEG_ONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MAX_VALUE = fromBits(0xFFFFFFFF|0, 0x7FFFFFFF|0, false);\r\n\r\n/**\r\n * Maximum signed value.\r\n * @type {!Long}\r\n */\r\nLong.MAX_VALUE = MAX_VALUE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MAX_UNSIGNED_VALUE = fromBits(0xFFFFFFFF|0, 0xFFFFFFFF|0, true);\r\n\r\n/**\r\n * Maximum unsigned value.\r\n * @type {!Long}\r\n */\r\nLong.MAX_UNSIGNED_VALUE = MAX_UNSIGNED_VALUE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MIN_VALUE = fromBits(0, 0x80000000|0, false);\r\n\r\n/**\r\n * Minimum signed value.\r\n * @type {!Long}\r\n */\r\nLong.MIN_VALUE = MIN_VALUE;\r\n\r\n/**\r\n * @alias Long.prototype\r\n * @inner\r\n */\r\nvar LongPrototype = Long.prototype;\r\n\r\n/**\r\n * Converts the Long to a 32 bit integer, assuming it is a 32 bit integer.\r\n * @returns {number}\r\n */\r\nLongPrototype.toInt = function toInt() {\r\n return this.unsigned ? this.low >>> 0 : this.low;\r\n};\r\n\r\n/**\r\n * Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa).\r\n * @returns {number}\r\n */\r\nLongPrototype.toNumber = function toNumber() {\r\n if (this.unsigned)\r\n return ((this.high >>> 0) * TWO_PWR_32_DBL) + (this.low >>> 0);\r\n return this.high * TWO_PWR_32_DBL + (this.low >>> 0);\r\n};\r\n\r\n/**\r\n * Converts the Long to a string written in the specified radix.\r\n * @param {number=} radix Radix (2-36), defaults to 10\r\n * @returns {string}\r\n * @override\r\n * @throws {RangeError} If `radix` is out of range\r\n */\r\nLongPrototype.toString = function toString(radix) {\r\n radix = radix || 10;\r\n if (radix < 2 || 36 < radix)\r\n throw RangeError('radix');\r\n if (this.isZero())\r\n return '0';\r\n if (this.isNegative()) { // Unsigned Longs are never negative\r\n if (this.eq(MIN_VALUE)) {\r\n // We need to change the Long value before it can be negated, so we remove\r\n // the bottom-most digit in this base and then recurse to do the rest.\r\n var radixLong = fromNumber(radix),\r\n div = this.div(radixLong),\r\n rem1 = div.mul(radixLong).sub(this);\r\n return div.toString(radix) + rem1.toInt().toString(radix);\r\n } else\r\n return '-' + this.neg().toString(radix);\r\n }\r\n\r\n // Do several (6) digits each time through the loop, so as to\r\n // minimize the calls to the very expensive emulated div.\r\n var radixToPower = fromNumber(pow_dbl(radix, 6), this.unsigned),\r\n rem = this;\r\n var result = '';\r\n while (true) {\r\n var remDiv = rem.div(radixToPower),\r\n intval = rem.sub(remDiv.mul(radixToPower)).toInt() >>> 0,\r\n digits = intval.toString(radix);\r\n rem = remDiv;\r\n if (rem.isZero())\r\n return digits + result;\r\n else {\r\n while (digits.length < 6)\r\n digits = '0' + digits;\r\n result = '' + digits + result;\r\n }\r\n }\r\n};\r\n\r\n/**\r\n * Gets the high 32 bits as a signed integer.\r\n * @returns {number} Signed high bits\r\n */\r\nLongPrototype.getHighBits = function getHighBits() {\r\n return this.high;\r\n};\r\n\r\n/**\r\n * Gets the high 32 bits as an unsigned integer.\r\n * @returns {number} Unsigned high bits\r\n */\r\nLongPrototype.getHighBitsUnsigned = function getHighBitsUnsigned() {\r\n return this.high >>> 0;\r\n};\r\n\r\n/**\r\n * Gets the low 32 bits as a signed integer.\r\n * @returns {number} Signed low bits\r\n */\r\nLongPrototype.getLowBits = function getLowBits() {\r\n return this.low;\r\n};\r\n\r\n/**\r\n * Gets the low 32 bits as an unsigned integer.\r\n * @returns {number} Unsigned low bits\r\n */\r\nLongPrototype.getLowBitsUnsigned = function getLowBitsUnsigned() {\r\n return this.low >>> 0;\r\n};\r\n\r\n/**\r\n * Gets the number of bits needed to represent the absolute value of this Long.\r\n * @returns {number}\r\n */\r\nLongPrototype.getNumBitsAbs = function getNumBitsAbs() {\r\n if (this.isNegative()) // Unsigned Longs are never negative\r\n return this.eq(MIN_VALUE) ? 64 : this.neg().getNumBitsAbs();\r\n var val = this.high != 0 ? this.high : this.low;\r\n for (var bit = 31; bit > 0; bit--)\r\n if ((val & (1 << bit)) != 0)\r\n break;\r\n return this.high != 0 ? bit + 33 : bit + 1;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals zero.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isZero = function isZero() {\r\n return this.high === 0 && this.low === 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals zero. This is an alias of {@link Long#isZero}.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.eqz = LongPrototype.isZero;\r\n\r\n/**\r\n * Tests if this Long's value is negative.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isNegative = function isNegative() {\r\n return !this.unsigned && this.high < 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is positive.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isPositive = function isPositive() {\r\n return this.unsigned || this.high >= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is odd.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isOdd = function isOdd() {\r\n return (this.low & 1) === 1;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is even.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isEven = function isEven() {\r\n return (this.low & 1) === 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.equals = function equals(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n if (this.unsigned !== other.unsigned && (this.high >>> 31) === 1 && (other.high >>> 31) === 1)\r\n return false;\r\n return this.high === other.high && this.low === other.low;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals the specified's. This is an alias of {@link Long#equals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.eq = LongPrototype.equals;\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.notEquals = function notEquals(other) {\r\n return !this.eq(/* validates */ other);\r\n};\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.neq = LongPrototype.notEquals;\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.ne = LongPrototype.notEquals;\r\n\r\n/**\r\n * Tests if this Long's value is less than the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lessThan = function lessThan(other) {\r\n return this.comp(/* validates */ other) < 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is less than the specified's. This is an alias of {@link Long#lessThan}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lt = LongPrototype.lessThan;\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lessThanOrEqual = function lessThanOrEqual(other) {\r\n return this.comp(/* validates */ other) <= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lte = LongPrototype.lessThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.le = LongPrototype.lessThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is greater than the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.greaterThan = function greaterThan(other) {\r\n return this.comp(/* validates */ other) > 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is greater than the specified's. This is an alias of {@link Long#greaterThan}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.gt = LongPrototype.greaterThan;\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.greaterThanOrEqual = function greaterThanOrEqual(other) {\r\n return this.comp(/* validates */ other) >= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.gte = LongPrototype.greaterThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.ge = LongPrototype.greaterThanOrEqual;\r\n\r\n/**\r\n * Compares this Long's value with the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\r\n * if the given one is greater\r\n */\r\nLongPrototype.compare = function compare(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n if (this.eq(other))\r\n return 0;\r\n var thisNeg = this.isNegative(),\r\n otherNeg = other.isNegative();\r\n if (thisNeg && !otherNeg)\r\n return -1;\r\n if (!thisNeg && otherNeg)\r\n return 1;\r\n // At this point the sign bits are the same\r\n if (!this.unsigned)\r\n return this.sub(other).isNegative() ? -1 : 1;\r\n // Both are positive if at least one is unsigned\r\n return (other.high >>> 0) > (this.high >>> 0) || (other.high === this.high && (other.low >>> 0) > (this.low >>> 0)) ? -1 : 1;\r\n};\r\n\r\n/**\r\n * Compares this Long's value with the specified's. This is an alias of {@link Long#compare}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\r\n * if the given one is greater\r\n */\r\nLongPrototype.comp = LongPrototype.compare;\r\n\r\n/**\r\n * Negates this Long's value.\r\n * @returns {!Long} Negated Long\r\n */\r\nLongPrototype.negate = function negate() {\r\n if (!this.unsigned && this.eq(MIN_VALUE))\r\n return MIN_VALUE;\r\n return this.not().add(ONE);\r\n};\r\n\r\n/**\r\n * Negates this Long's value. This is an alias of {@link Long#negate}.\r\n * @function\r\n * @returns {!Long} Negated Long\r\n */\r\nLongPrototype.neg = LongPrototype.negate;\r\n\r\n/**\r\n * Returns the sum of this and the specified Long.\r\n * @param {!Long|number|string} addend Addend\r\n * @returns {!Long} Sum\r\n */\r\nLongPrototype.add = function add(addend) {\r\n if (!isLong(addend))\r\n addend = fromValue(addend);\r\n\r\n // Divide each number into 4 chunks of 16 bits, and then sum the chunks.\r\n\r\n var a48 = this.high >>> 16;\r\n var a32 = this.high & 0xFFFF;\r\n var a16 = this.low >>> 16;\r\n var a00 = this.low & 0xFFFF;\r\n\r\n var b48 = addend.high >>> 16;\r\n var b32 = addend.high & 0xFFFF;\r\n var b16 = addend.low >>> 16;\r\n var b00 = addend.low & 0xFFFF;\r\n\r\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\r\n c00 += a00 + b00;\r\n c16 += c00 >>> 16;\r\n c00 &= 0xFFFF;\r\n c16 += a16 + b16;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c32 += a32 + b32;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c48 += a48 + b48;\r\n c48 &= 0xFFFF;\r\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the difference of this and the specified Long.\r\n * @param {!Long|number|string} subtrahend Subtrahend\r\n * @returns {!Long} Difference\r\n */\r\nLongPrototype.subtract = function subtract(subtrahend) {\r\n if (!isLong(subtrahend))\r\n subtrahend = fromValue(subtrahend);\r\n return this.add(subtrahend.neg());\r\n};\r\n\r\n/**\r\n * Returns the difference of this and the specified Long. This is an alias of {@link Long#subtract}.\r\n * @function\r\n * @param {!Long|number|string} subtrahend Subtrahend\r\n * @returns {!Long} Difference\r\n */\r\nLongPrototype.sub = LongPrototype.subtract;\r\n\r\n/**\r\n * Returns the product of this and the specified Long.\r\n * @param {!Long|number|string} multiplier Multiplier\r\n * @returns {!Long} Product\r\n */\r\nLongPrototype.multiply = function multiply(multiplier) {\r\n if (this.isZero())\r\n return ZERO;\r\n if (!isLong(multiplier))\r\n multiplier = fromValue(multiplier);\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n var low = wasm.mul(this.low,\r\n this.high,\r\n multiplier.low,\r\n multiplier.high);\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n if (multiplier.isZero())\r\n return ZERO;\r\n if (this.eq(MIN_VALUE))\r\n return multiplier.isOdd() ? MIN_VALUE : ZERO;\r\n if (multiplier.eq(MIN_VALUE))\r\n return this.isOdd() ? MIN_VALUE : ZERO;\r\n\r\n if (this.isNegative()) {\r\n if (multiplier.isNegative())\r\n return this.neg().mul(multiplier.neg());\r\n else\r\n return this.neg().mul(multiplier).neg();\r\n } else if (multiplier.isNegative())\r\n return this.mul(multiplier.neg()).neg();\r\n\r\n // If both longs are small, use float multiplication\r\n if (this.lt(TWO_PWR_24) && multiplier.lt(TWO_PWR_24))\r\n return fromNumber(this.toNumber() * multiplier.toNumber(), this.unsigned);\r\n\r\n // Divide each long into 4 chunks of 16 bits, and then add up 4x4 products.\r\n // We can skip products that would overflow.\r\n\r\n var a48 = this.high >>> 16;\r\n var a32 = this.high & 0xFFFF;\r\n var a16 = this.low >>> 16;\r\n var a00 = this.low & 0xFFFF;\r\n\r\n var b48 = multiplier.high >>> 16;\r\n var b32 = multiplier.high & 0xFFFF;\r\n var b16 = multiplier.low >>> 16;\r\n var b00 = multiplier.low & 0xFFFF;\r\n\r\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\r\n c00 += a00 * b00;\r\n c16 += c00 >>> 16;\r\n c00 &= 0xFFFF;\r\n c16 += a16 * b00;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c16 += a00 * b16;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c32 += a32 * b00;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c32 += a16 * b16;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c32 += a00 * b32;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c48 += a48 * b00 + a32 * b16 + a16 * b32 + a00 * b48;\r\n c48 &= 0xFFFF;\r\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the product of this and the specified Long. This is an alias of {@link Long#multiply}.\r\n * @function\r\n * @param {!Long|number|string} multiplier Multiplier\r\n * @returns {!Long} Product\r\n */\r\nLongPrototype.mul = LongPrototype.multiply;\r\n\r\n/**\r\n * Returns this Long divided by the specified. The result is signed if this Long is signed or\r\n * unsigned if this Long is unsigned.\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Quotient\r\n */\r\nLongPrototype.divide = function divide(divisor) {\r\n if (!isLong(divisor))\r\n divisor = fromValue(divisor);\r\n if (divisor.isZero())\r\n throw Error('division by zero');\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n // guard against signed division overflow: the largest\r\n // negative number / -1 would be 1 larger than the largest\r\n // positive number, due to two's complement.\r\n if (!this.unsigned &&\r\n this.high === -0x80000000 &&\r\n divisor.low === -1 && divisor.high === -1) {\r\n // be consistent with non-wasm code path\r\n return this;\r\n }\r\n var low = (this.unsigned ? wasm.div_u : wasm.div_s)(\r\n this.low,\r\n this.high,\r\n divisor.low,\r\n divisor.high\r\n );\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n if (this.isZero())\r\n return this.unsigned ? UZERO : ZERO;\r\n var approx, rem, res;\r\n if (!this.unsigned) {\r\n // This section is only relevant for signed longs and is derived from the\r\n // closure library as a whole.\r\n if (this.eq(MIN_VALUE)) {\r\n if (divisor.eq(ONE) || divisor.eq(NEG_ONE))\r\n return MIN_VALUE; // recall that -MIN_VALUE == MIN_VALUE\r\n else if (divisor.eq(MIN_VALUE))\r\n return ONE;\r\n else {\r\n // At this point, we have |other| >= 2, so |this/other| < |MIN_VALUE|.\r\n var halfThis = this.shr(1);\r\n approx = halfThis.div(divisor).shl(1);\r\n if (approx.eq(ZERO)) {\r\n return divisor.isNegative() ? ONE : NEG_ONE;\r\n } else {\r\n rem = this.sub(divisor.mul(approx));\r\n res = approx.add(rem.div(divisor));\r\n return res;\r\n }\r\n }\r\n } else if (divisor.eq(MIN_VALUE))\r\n return this.unsigned ? UZERO : ZERO;\r\n if (this.isNegative()) {\r\n if (divisor.isNegative())\r\n return this.neg().div(divisor.neg());\r\n return this.neg().div(divisor).neg();\r\n } else if (divisor.isNegative())\r\n return this.div(divisor.neg()).neg();\r\n res = ZERO;\r\n } else {\r\n // The algorithm below has not been made for unsigned longs. It's therefore\r\n // required to take special care of the MSB prior to running it.\r\n if (!divisor.unsigned)\r\n divisor = divisor.toUnsigned();\r\n if (divisor.gt(this))\r\n return UZERO;\r\n if (divisor.gt(this.shru(1))) // 15 >>> 1 = 7 ; with divisor = 8 ; true\r\n return UONE;\r\n res = UZERO;\r\n }\r\n\r\n // Repeat the following until the remainder is less than other: find a\r\n // floating-point that approximates remainder / other *from below*, add this\r\n // into the result, and subtract it from the remainder. It is critical that\r\n // the approximate value is less than or equal to the real value so that the\r\n // remainder never becomes negative.\r\n rem = this;\r\n while (rem.gte(divisor)) {\r\n // Approximate the result of division. This may be a little greater or\r\n // smaller than the actual value.\r\n approx = Math.max(1, Math.floor(rem.toNumber() / divisor.toNumber()));\r\n\r\n // We will tweak the approximate result by changing it in the 48-th digit or\r\n // the smallest non-fractional digit, whichever is larger.\r\n var log2 = Math.ceil(Math.log(approx) / Math.LN2),\r\n delta = (log2 <= 48) ? 1 : pow_dbl(2, log2 - 48),\r\n\r\n // Decrease the approximation until it is smaller than the remainder. Note\r\n // that if it is too large, the product overflows and is negative.\r\n approxRes = fromNumber(approx),\r\n approxRem = approxRes.mul(divisor);\r\n while (approxRem.isNegative() || approxRem.gt(rem)) {\r\n approx -= delta;\r\n approxRes = fromNumber(approx, this.unsigned);\r\n approxRem = approxRes.mul(divisor);\r\n }\r\n\r\n // We know the answer can't be zero... and actually, zero would cause\r\n // infinite recursion since we would make no progress.\r\n if (approxRes.isZero())\r\n approxRes = ONE;\r\n\r\n res = res.add(approxRes);\r\n rem = rem.sub(approxRem);\r\n }\r\n return res;\r\n};\r\n\r\n/**\r\n * Returns this Long divided by the specified. This is an alias of {@link Long#divide}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Quotient\r\n */\r\nLongPrototype.div = LongPrototype.divide;\r\n\r\n/**\r\n * Returns this Long modulo the specified.\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.modulo = function modulo(divisor) {\r\n if (!isLong(divisor))\r\n divisor = fromValue(divisor);\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n var low = (this.unsigned ? wasm.rem_u : wasm.rem_s)(\r\n this.low,\r\n this.high,\r\n divisor.low,\r\n divisor.high\r\n );\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n return this.sub(this.div(divisor).mul(divisor));\r\n};\r\n\r\n/**\r\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.mod = LongPrototype.modulo;\r\n\r\n/**\r\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.rem = LongPrototype.modulo;\r\n\r\n/**\r\n * Returns the bitwise NOT of this Long.\r\n * @returns {!Long}\r\n */\r\nLongPrototype.not = function not() {\r\n return fromBits(~this.low, ~this.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise AND of this Long and the specified.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.and = function and(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low & other.low, this.high & other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise OR of this Long and the specified.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.or = function or(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low | other.low, this.high | other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise XOR of this Long and the given one.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.xor = function xor(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low ^ other.low, this.high ^ other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits shifted to the left by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftLeft = function shiftLeft(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n if ((numBits &= 63) === 0)\r\n return this;\r\n else if (numBits < 32)\r\n return fromBits(this.low << numBits, (this.high << numBits) | (this.low >>> (32 - numBits)), this.unsigned);\r\n else\r\n return fromBits(0, this.low << (numBits - 32), this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits shifted to the left by the given amount. This is an alias of {@link Long#shiftLeft}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shl = LongPrototype.shiftLeft;\r\n\r\n/**\r\n * Returns this Long with bits arithmetically shifted to the right by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftRight = function shiftRight(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n if ((numBits &= 63) === 0)\r\n return this;\r\n else if (numBits < 32)\r\n return fromBits((this.low >>> numBits) | (this.high << (32 - numBits)), this.high >> numBits, this.unsigned);\r\n else\r\n return fromBits(this.high >> (numBits - 32), this.high >= 0 ? 0 : -1, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits arithmetically shifted to the right by the given amount. This is an alias of {@link Long#shiftRight}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shr = LongPrototype.shiftRight;\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftRightUnsigned = function shiftRightUnsigned(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n numBits &= 63;\r\n if (numBits === 0)\r\n return this;\r\n else {\r\n var high = this.high;\r\n if (numBits < 32) {\r\n var low = this.low;\r\n return fromBits((low >>> numBits) | (high << (32 - numBits)), high >>> numBits, this.unsigned);\r\n } else if (numBits === 32)\r\n return fromBits(high, 0, this.unsigned);\r\n else\r\n return fromBits(high >>> (numBits - 32), 0, this.unsigned);\r\n }\r\n};\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shru = LongPrototype.shiftRightUnsigned;\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shr_u = LongPrototype.shiftRightUnsigned;\r\n\r\n/**\r\n * Converts this Long to signed.\r\n * @returns {!Long} Signed long\r\n */\r\nLongPrototype.toSigned = function toSigned() {\r\n if (!this.unsigned)\r\n return this;\r\n return fromBits(this.low, this.high, false);\r\n};\r\n\r\n/**\r\n * Converts this Long to unsigned.\r\n * @returns {!Long} Unsigned long\r\n */\r\nLongPrototype.toUnsigned = function toUnsigned() {\r\n if (this.unsigned)\r\n return this;\r\n return fromBits(this.low, this.high, true);\r\n};\r\n\r\n/**\r\n * Converts this Long to its byte representation.\r\n * @param {boolean=} le Whether little or big endian, defaults to big endian\r\n * @returns {!Array.} Byte representation\r\n */\r\nLongPrototype.toBytes = function toBytes(le) {\r\n return le ? this.toBytesLE() : this.toBytesBE();\r\n};\r\n\r\n/**\r\n * Converts this Long to its little endian byte representation.\r\n * @returns {!Array.} Little endian byte representation\r\n */\r\nLongPrototype.toBytesLE = function toBytesLE() {\r\n var hi = this.high,\r\n lo = this.low;\r\n return [\r\n lo & 0xff,\r\n lo >>> 8 & 0xff,\r\n lo >>> 16 & 0xff,\r\n lo >>> 24 ,\r\n hi & 0xff,\r\n hi >>> 8 & 0xff,\r\n hi >>> 16 & 0xff,\r\n hi >>> 24\r\n ];\r\n};\r\n\r\n/**\r\n * Converts this Long to its big endian byte representation.\r\n * @returns {!Array.} Big endian byte representation\r\n */\r\nLongPrototype.toBytesBE = function toBytesBE() {\r\n var hi = this.high,\r\n lo = this.low;\r\n return [\r\n hi >>> 24 ,\r\n hi >>> 16 & 0xff,\r\n hi >>> 8 & 0xff,\r\n hi & 0xff,\r\n lo >>> 24 ,\r\n lo >>> 16 & 0xff,\r\n lo >>> 8 & 0xff,\r\n lo & 0xff\r\n ];\r\n};\r\n\r\n/**\r\n * Creates a Long from its byte representation.\r\n * @param {!Array.} bytes Byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @param {boolean=} le Whether little or big endian, defaults to big endian\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytes = function fromBytes(bytes, unsigned, le) {\r\n return le ? Long.fromBytesLE(bytes, unsigned) : Long.fromBytesBE(bytes, unsigned);\r\n};\r\n\r\n/**\r\n * Creates a Long from its little endian byte representation.\r\n * @param {!Array.} bytes Little endian byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytesLE = function fromBytesLE(bytes, unsigned) {\r\n return new Long(\r\n bytes[0] |\r\n bytes[1] << 8 |\r\n bytes[2] << 16 |\r\n bytes[3] << 24,\r\n bytes[4] |\r\n bytes[5] << 8 |\r\n bytes[6] << 16 |\r\n bytes[7] << 24,\r\n unsigned\r\n );\r\n};\r\n\r\n/**\r\n * Creates a Long from its big endian byte representation.\r\n * @param {!Array.} bytes Big endian byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytesBE = function fromBytesBE(bytes, unsigned) {\r\n return new Long(\r\n bytes[4] << 24 |\r\n bytes[5] << 16 |\r\n bytes[6] << 8 |\r\n bytes[7],\r\n bytes[0] << 24 |\r\n bytes[1] << 16 |\r\n bytes[2] << 8 |\r\n bytes[3],\r\n unsigned\r\n );\r\n};\r\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar $protobuf = require('protobufjs/minimal.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar $protobuf__default = /*#__PURE__*/_interopDefaultLegacy($protobuf);\n\nconst $Reader = $protobuf__default['default'].Reader, $Writer = $protobuf__default['default'].Writer, $util = $protobuf__default['default'].util;\nconst $root = $protobuf__default['default'].roots['ipfs-ipns'] || ($protobuf__default['default'].roots['ipfs-ipns'] = {});\nconst IpnsEntry = $root.IpnsEntry = (() => {\n function IpnsEntry(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n IpnsEntry.prototype.value = $util.newBuffer([]);\n IpnsEntry.prototype.signature = $util.newBuffer([]);\n IpnsEntry.prototype.validityType = 0;\n IpnsEntry.prototype.validity = $util.newBuffer([]);\n IpnsEntry.prototype.sequence = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n IpnsEntry.prototype.ttl = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n IpnsEntry.prototype.pubKey = $util.newBuffer([]);\n IpnsEntry.prototype.signatureV2 = $util.newBuffer([]);\n IpnsEntry.prototype.data = $util.newBuffer([]);\n IpnsEntry.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.value != null && Object.hasOwnProperty.call(m, 'value'))\n w.uint32(10).bytes(m.value);\n if (m.signature != null && Object.hasOwnProperty.call(m, 'signature'))\n w.uint32(18).bytes(m.signature);\n if (m.validityType != null && Object.hasOwnProperty.call(m, 'validityType'))\n w.uint32(24).int32(m.validityType);\n if (m.validity != null && Object.hasOwnProperty.call(m, 'validity'))\n w.uint32(34).bytes(m.validity);\n if (m.sequence != null && Object.hasOwnProperty.call(m, 'sequence'))\n w.uint32(40).uint64(m.sequence);\n if (m.ttl != null && Object.hasOwnProperty.call(m, 'ttl'))\n w.uint32(48).uint64(m.ttl);\n if (m.pubKey != null && Object.hasOwnProperty.call(m, 'pubKey'))\n w.uint32(58).bytes(m.pubKey);\n if (m.signatureV2 != null && Object.hasOwnProperty.call(m, 'signatureV2'))\n w.uint32(66).bytes(m.signatureV2);\n if (m.data != null && Object.hasOwnProperty.call(m, 'data'))\n w.uint32(74).bytes(m.data);\n return w;\n };\n IpnsEntry.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.IpnsEntry();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.value = r.bytes();\n break;\n case 2:\n m.signature = r.bytes();\n break;\n case 3:\n m.validityType = r.int32();\n break;\n case 4:\n m.validity = r.bytes();\n break;\n case 5:\n m.sequence = r.uint64();\n break;\n case 6:\n m.ttl = r.uint64();\n break;\n case 7:\n m.pubKey = r.bytes();\n break;\n case 8:\n m.signatureV2 = r.bytes();\n break;\n case 9:\n m.data = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n IpnsEntry.fromObject = function fromObject(d) {\n if (d instanceof $root.IpnsEntry)\n return d;\n var m = new $root.IpnsEntry();\n if (d.value != null) {\n if (typeof d.value === 'string')\n $util.base64.decode(d.value, m.value = $util.newBuffer($util.base64.length(d.value)), 0);\n else if (d.value.length)\n m.value = d.value;\n }\n if (d.signature != null) {\n if (typeof d.signature === 'string')\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n switch (d.validityType) {\n case 'EOL':\n case 0:\n m.validityType = 0;\n break;\n }\n if (d.validity != null) {\n if (typeof d.validity === 'string')\n $util.base64.decode(d.validity, m.validity = $util.newBuffer($util.base64.length(d.validity)), 0);\n else if (d.validity.length)\n m.validity = d.validity;\n }\n if (d.sequence != null) {\n if ($util.Long)\n (m.sequence = $util.Long.fromValue(d.sequence)).unsigned = true;\n else if (typeof d.sequence === 'string')\n m.sequence = parseInt(d.sequence, 10);\n else if (typeof d.sequence === 'number')\n m.sequence = d.sequence;\n else if (typeof d.sequence === 'object')\n m.sequence = new $util.LongBits(d.sequence.low >>> 0, d.sequence.high >>> 0).toNumber(true);\n }\n if (d.ttl != null) {\n if ($util.Long)\n (m.ttl = $util.Long.fromValue(d.ttl)).unsigned = true;\n else if (typeof d.ttl === 'string')\n m.ttl = parseInt(d.ttl, 10);\n else if (typeof d.ttl === 'number')\n m.ttl = d.ttl;\n else if (typeof d.ttl === 'object')\n m.ttl = new $util.LongBits(d.ttl.low >>> 0, d.ttl.high >>> 0).toNumber(true);\n }\n if (d.pubKey != null) {\n if (typeof d.pubKey === 'string')\n $util.base64.decode(d.pubKey, m.pubKey = $util.newBuffer($util.base64.length(d.pubKey)), 0);\n else if (d.pubKey.length)\n m.pubKey = d.pubKey;\n }\n if (d.signatureV2 != null) {\n if (typeof d.signatureV2 === 'string')\n $util.base64.decode(d.signatureV2, m.signatureV2 = $util.newBuffer($util.base64.length(d.signatureV2)), 0);\n else if (d.signatureV2.length)\n m.signatureV2 = d.signatureV2;\n }\n if (d.data != null) {\n if (typeof d.data === 'string')\n $util.base64.decode(d.data, m.data = $util.newBuffer($util.base64.length(d.data)), 0);\n else if (d.data.length)\n m.data = d.data;\n }\n return m;\n };\n IpnsEntry.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.value = '';\n else {\n d.value = [];\n if (o.bytes !== Array)\n d.value = $util.newBuffer(d.value);\n }\n if (o.bytes === String)\n d.signature = '';\n else {\n d.signature = [];\n if (o.bytes !== Array)\n d.signature = $util.newBuffer(d.signature);\n }\n d.validityType = o.enums === String ? 'EOL' : 0;\n if (o.bytes === String)\n d.validity = '';\n else {\n d.validity = [];\n if (o.bytes !== Array)\n d.validity = $util.newBuffer(d.validity);\n }\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.sequence = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.sequence = o.longs === String ? '0' : 0;\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.ttl = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.ttl = o.longs === String ? '0' : 0;\n if (o.bytes === String)\n d.pubKey = '';\n else {\n d.pubKey = [];\n if (o.bytes !== Array)\n d.pubKey = $util.newBuffer(d.pubKey);\n }\n if (o.bytes === String)\n d.signatureV2 = '';\n else {\n d.signatureV2 = [];\n if (o.bytes !== Array)\n d.signatureV2 = $util.newBuffer(d.signatureV2);\n }\n if (o.bytes === String)\n d.data = '';\n else {\n d.data = [];\n if (o.bytes !== Array)\n d.data = $util.newBuffer(d.data);\n }\n }\n if (m.value != null && m.hasOwnProperty('value')) {\n d.value = o.bytes === String ? $util.base64.encode(m.value, 0, m.value.length) : o.bytes === Array ? Array.prototype.slice.call(m.value) : m.value;\n }\n if (m.signature != null && m.hasOwnProperty('signature')) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n }\n if (m.validityType != null && m.hasOwnProperty('validityType')) {\n d.validityType = o.enums === String ? $root.IpnsEntry.ValidityType[m.validityType] : m.validityType;\n }\n if (m.validity != null && m.hasOwnProperty('validity')) {\n d.validity = o.bytes === String ? $util.base64.encode(m.validity, 0, m.validity.length) : o.bytes === Array ? Array.prototype.slice.call(m.validity) : m.validity;\n }\n if (m.sequence != null && m.hasOwnProperty('sequence')) {\n if (typeof m.sequence === 'number')\n d.sequence = o.longs === String ? String(m.sequence) : m.sequence;\n else\n d.sequence = o.longs === String ? $util.Long.prototype.toString.call(m.sequence) : o.longs === Number ? new $util.LongBits(m.sequence.low >>> 0, m.sequence.high >>> 0).toNumber(true) : m.sequence;\n }\n if (m.ttl != null && m.hasOwnProperty('ttl')) {\n if (typeof m.ttl === 'number')\n d.ttl = o.longs === String ? String(m.ttl) : m.ttl;\n else\n d.ttl = o.longs === String ? $util.Long.prototype.toString.call(m.ttl) : o.longs === Number ? new $util.LongBits(m.ttl.low >>> 0, m.ttl.high >>> 0).toNumber(true) : m.ttl;\n }\n if (m.pubKey != null && m.hasOwnProperty('pubKey')) {\n d.pubKey = o.bytes === String ? $util.base64.encode(m.pubKey, 0, m.pubKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.pubKey) : m.pubKey;\n }\n if (m.signatureV2 != null && m.hasOwnProperty('signatureV2')) {\n d.signatureV2 = o.bytes === String ? $util.base64.encode(m.signatureV2, 0, m.signatureV2.length) : o.bytes === Array ? Array.prototype.slice.call(m.signatureV2) : m.signatureV2;\n }\n if (m.data != null && m.hasOwnProperty('data')) {\n d.data = o.bytes === String ? $util.base64.encode(m.data, 0, m.data.length) : o.bytes === Array ? Array.prototype.slice.call(m.data) : m.data;\n }\n return d;\n };\n IpnsEntry.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default['default'].util.toJSONOptions);\n };\n IpnsEntry.ValidityType = function () {\n const valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = 'EOL'] = 0;\n return values;\n }();\n return IpnsEntry;\n})();\n\nexports.IpnsEntry = IpnsEntry;\nexports['default'] = $root;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction toRFC3339(time) {\n const year = time.getUTCFullYear();\n const month = String(time.getUTCMonth() + 1).padStart(2, '0');\n const day = String(time.getUTCDate()).padStart(2, '0');\n const hour = String(time.getUTCHours()).padStart(2, '0');\n const minute = String(time.getUTCMinutes()).padStart(2, '0');\n const seconds = String(time.getUTCSeconds()).padStart(2, '0');\n const milliseconds = time.getUTCMilliseconds();\n const nanoseconds = milliseconds * 1000 * 1000;\n return `${ year }-${ month }-${ day }T${ hour }:${ minute }:${ seconds }.${ nanoseconds }Z`;\n}\nfunction parseRFC3339(time) {\n const rfc3339Matcher = new RegExp('(\\\\d{4})-(\\\\d{2})-(\\\\d{2})T' + '(\\\\d{2}):(\\\\d{2}):(\\\\d{2})' + '\\\\.(\\\\d+)Z');\n const m = String(time).trim().match(rfc3339Matcher);\n if (!m) {\n throw new Error('Invalid format');\n }\n const year = parseInt(m[1], 10);\n const month = parseInt(m[2], 10) - 1;\n const date = parseInt(m[3], 10);\n const hour = parseInt(m[4], 10);\n const minute = parseInt(m[5], 10);\n const second = parseInt(m[6], 10);\n const millisecond = parseInt(m[7].slice(0, -6), 10);\n return new Date(Date.UTC(year, month, date, hour, minute, second, millisecond));\n}\n\nexports.parseRFC3339 = parseRFC3339;\nexports.toRFC3339 = toRFC3339;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst ERR_IPNS_EXPIRED_RECORD = 'ERR_IPNS_EXPIRED_RECORD';\nconst ERR_UNRECOGNIZED_VALIDITY = 'ERR_UNRECOGNIZED_VALIDITY';\nconst ERR_SIGNATURE_CREATION = 'ERR_SIGNATURE_CREATION';\nconst ERR_SIGNATURE_VERIFICATION = 'ERR_SIGNATURE_VERIFICATION';\nconst ERR_UNRECOGNIZED_FORMAT = 'ERR_UNRECOGNIZED_FORMAT';\nconst ERR_PEER_ID_FROM_PUBLIC_KEY = 'ERR_PEER_ID_FROM_PUBLIC_KEY';\nconst ERR_PUBLIC_KEY_FROM_ID = 'ERR_PUBLIC_KEY_FROM_ID';\nconst ERR_UNDEFINED_PARAMETER = 'ERR_UNDEFINED_PARAMETER';\nconst ERR_INVALID_RECORD_DATA = 'ERR_INVALID_RECORD_DATA';\nconst ERR_INVALID_EMBEDDED_KEY = 'ERR_INVALID_EMBEDDED_KEY';\n\nexports.ERR_INVALID_EMBEDDED_KEY = ERR_INVALID_EMBEDDED_KEY;\nexports.ERR_INVALID_RECORD_DATA = ERR_INVALID_RECORD_DATA;\nexports.ERR_IPNS_EXPIRED_RECORD = ERR_IPNS_EXPIRED_RECORD;\nexports.ERR_PEER_ID_FROM_PUBLIC_KEY = ERR_PEER_ID_FROM_PUBLIC_KEY;\nexports.ERR_PUBLIC_KEY_FROM_ID = ERR_PUBLIC_KEY_FROM_ID;\nexports.ERR_SIGNATURE_CREATION = ERR_SIGNATURE_CREATION;\nexports.ERR_SIGNATURE_VERIFICATION = ERR_SIGNATURE_VERIFICATION;\nexports.ERR_UNDEFINED_PARAMETER = ERR_UNDEFINED_PARAMETER;\nexports.ERR_UNRECOGNIZED_FORMAT = ERR_UNRECOGNIZED_FORMAT;\nexports.ERR_UNRECOGNIZED_VALIDITY = ERR_UNRECOGNIZED_VALIDITY;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipns = require('ipns');\nvar crypto = require('libp2p-crypto');\nvar PeerId = require('peer-id');\nvar errCode = require('err-code');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\nvar crypto__default = /*#__PURE__*/_interopDefaultLegacy(crypto);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:republisher'), { error: debug__default['default']('ipfs:ipns:republisher:error') });\nconst minute = 60 * 1000;\nconst hour = 60 * minute;\nconst defaultBroadcastInterval = 4 * hour;\nconst defaultRecordLifetime = 24 * hour;\nclass IpnsRepublisher {\n constructor(publisher, datastore, peerId, keychain, options = { pass: '' }) {\n this._publisher = publisher;\n this._datastore = datastore;\n this._peerId = peerId;\n this._keychain = keychain;\n this._options = options;\n this._republishHandle = null;\n }\n async start() {\n if (this._republishHandle) {\n throw errCode__default['default'](new Error('republisher is already running'), 'ERR_REPUBLISH_ALREADY_RUNNING');\n }\n const republishHandle = {\n _task: null,\n _inflightTask: null,\n _timeoutId: null,\n runPeriodically: period => {\n republishHandle._timeoutId = setTimeout(async () => {\n republishHandle._timeoutId = null;\n try {\n republishHandle._inflightTask = republishHandle._task();\n await republishHandle._inflightTask;\n if (republishHandle._task) {\n republishHandle.runPeriodically(period);\n }\n } catch (err) {\n log.error(err);\n }\n }, period());\n },\n cancel: async () => {\n if (republishHandle._timeoutId != null) {\n clearTimeout(republishHandle._timeoutId);\n }\n republishHandle._task = null;\n await republishHandle._inflightTask;\n }\n };\n const {privKey} = this._peerId;\n const {pass} = this._options;\n let firstRun = true;\n republishHandle._task = () => this._republishEntries(privKey, pass);\n republishHandle.runPeriodically(() => {\n if (firstRun) {\n firstRun = false;\n return this._options.initialBroadcastInterval || minute;\n }\n return this._options.broadcastInterval || defaultBroadcastInterval;\n });\n this._republishHandle = republishHandle;\n }\n async stop() {\n const republishHandle = this._republishHandle;\n if (!republishHandle) {\n throw errCode__default['default'](new Error('republisher is not running'), 'ERR_REPUBLISH_NOT_RUNNING');\n }\n this._republishHandle = null;\n await republishHandle.cancel();\n }\n async _republishEntries(privateKey, pass) {\n try {\n await this._republishEntry(privateKey);\n } catch (err) {\n const errMsg = 'cannot republish entry for the node\\'s private key';\n log.error(errMsg);\n return;\n }\n if (pass) {\n try {\n const keys = await this._keychain.listKeys();\n for (const key of keys) {\n if (key.name === 'self') {\n continue;\n }\n const pem = await this._keychain.exportKey(key.name, pass);\n const privKey = await crypto__default['default'].keys.import(pem, pass);\n await this._republishEntry(privKey);\n }\n } catch (err) {\n log.error(err);\n }\n }\n }\n async _republishEntry(privateKey) {\n if (!privateKey || !privateKey.bytes) {\n throw errCode__default['default'](new Error('invalid private key'), 'ERR_INVALID_PRIVATE_KEY');\n }\n try {\n const peerId = await PeerId__default['default'].createFromPrivKey(privateKey.bytes);\n const value = await this._getPreviousValue(peerId);\n await this._publisher.publishWithEOL(privateKey, value, defaultRecordLifetime);\n } catch (err) {\n if (err.code === 'ERR_NO_ENTRY_FOUND') {\n return;\n }\n throw err;\n }\n }\n async _getPreviousValue(peerId) {\n if (!PeerId__default['default'].isPeerId(peerId)) {\n throw errCode__default['default'](new Error('invalid peer ID'), 'ERR_INVALID_PEER_ID');\n }\n try {\n const dsVal = await this._datastore.get(ipns__namespace.getLocalKey(peerId.id));\n if (!(dsVal instanceof Uint8Array)) {\n throw errCode__default['default'](new Error('found ipns record that we couldn\\'t process'), 'ERR_INVALID_IPNS_RECORD');\n }\n try {\n const record = ipns__namespace.unmarshal(dsVal);\n return record.value;\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](new Error('found ipns record that we couldn\\'t convert to a value'), 'ERR_INVALID_IPNS_RECORD');\n }\n } catch (err) {\n if (err && err.notFound) {\n throw errCode__default['default'](new Error(`no previous entry for record with id: ${ peerId.id }`), 'ERR_NO_ENTRY_FOUND');\n }\n throw err;\n }\n }\n}\n\nexports.IpnsRepublisher = IpnsRepublisher;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipns = require('ipns');\nvar PeerId = require('peer-id');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar toString = require('uint8arrays/to-string');\nvar Errors = require('datastore-core/errors');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar Errors__namespace = /*#__PURE__*/_interopNamespace(Errors);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:resolver'), { error: debug__default['default']('ipfs:ipns:resolver:error') });\nconst ERR_NOT_FOUND = Errors__namespace.notFoundError().code;\nconst defaultMaximumRecursiveDepth = 32;\nclass IpnsResolver {\n constructor(routing) {\n this._routing = routing;\n }\n async resolve(name, options = {}) {\n if (typeof name !== 'string') {\n throw errCode__default['default'](new Error('invalid name'), 'ERR_INVALID_NAME');\n }\n const recursive = options.recursive && options.recursive.toString() === 'true';\n const nameSegments = name.split('/');\n if (nameSegments.length !== 3 || nameSegments[0] !== '') {\n throw errCode__default['default'](new Error('invalid name'), 'ERR_INVALID_NAME');\n }\n const key = nameSegments[2];\n let depth = Infinity;\n if (recursive) {\n depth = defaultMaximumRecursiveDepth;\n }\n const res = await this.resolver(key, depth);\n log(`${ name } was locally resolved correctly`);\n return res;\n }\n async resolver(name, depth) {\n if (depth === 0) {\n const errMsg = `could not resolve name (recursion limit of ${ defaultMaximumRecursiveDepth } exceeded)`;\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_RESOLVE_RECURSION_LIMIT');\n }\n const res = await this._resolveName(name);\n const nameSegments = res.split('/');\n if (nameSegments[1] === 'ipfs' || !depth) {\n return res;\n }\n return this.resolver(nameSegments[2], depth - 1);\n }\n async _resolveName(name) {\n const peerId = PeerId__default['default'].parse(name);\n const {routingKey} = ipns__namespace.getIdKeys(peerId.toBytes());\n let record;\n try {\n record = await this._routing.get(routingKey.uint8Array());\n } catch (err) {\n log.error('could not get record from routing', err);\n if (err.code === ERR_NOT_FOUND) {\n throw errCode__default['default'](new Error(`record requested for ${ name } was not found in the network`), 'ERR_NO_RECORD_FOUND');\n }\n throw errCode__default['default'](new Error(`unexpected error getting the ipns record ${ peerId.toString() }`), 'ERR_UNEXPECTED_ERROR_GETTING_RECORD');\n }\n let ipnsEntry;\n try {\n ipnsEntry = ipns__namespace.unmarshal(record);\n } catch (err) {\n log.error('could not unmarshal record', err);\n throw errCode__default['default'](new Error('found ipns record that we couldn\\'t convert to a value'), 'ERR_INVALID_RECORD_RECEIVED');\n }\n return this._validateRecord(peerId, ipnsEntry);\n }\n async _validateRecord(peerId, ipnsEntry) {\n const pubKey = await ipns__namespace.extractPublicKey(peerId, ipnsEntry);\n await ipns__namespace.validate(pubKey, ipnsEntry);\n return toString.toString(ipnsEntry.value);\n }\n}\n\nexports.IpnsResolver = IpnsResolver;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hashlru = require('hashlru');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar hashlru__default = /*#__PURE__*/_interopDefaultLegacy(hashlru);\n\nclass TLRU {\n constructor(maxSize) {\n this.lru = hashlru__default['default'](maxSize);\n }\n get(key) {\n const value = this.lru.get(key);\n if (value) {\n if (value.expire && value.expire < Date.now()) {\n this.lru.remove(key);\n return undefined;\n }\n return value.value;\n }\n return undefined;\n }\n set(key, value, ttl) {\n this.lru.set(key, {\n value,\n expire: Date.now() + ttl\n });\n }\n has(key) {\n const value = this.get(key);\n if (value) {\n return true;\n }\n return false;\n }\n remove(key) {\n this.lru.remove(key);\n }\n clear() {\n this.lru.clear();\n }\n}\n\nexports.TLRU = TLRU;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar tiered = require('datastore-core/tiered');\nvar get = require('dlv');\nvar pubsubDatastore = require('./pubsub-datastore.js');\nvar offlineDatastore = require('./offline-datastore.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar get__default = /*#__PURE__*/_interopDefaultLegacy(get);\n\nfunction createRouting({libp2p, repo, peerId, options}) {\n const ipnsStores = [];\n let pubsubDs;\n if (get__default['default'](options, 'EXPERIMENTAL.ipnsPubsub', false)) {\n const pubsub = libp2p.pubsub;\n const localDatastore = repo.datastore;\n pubsubDs = new pubsubDatastore.IpnsPubsubDatastore(pubsub, localDatastore, peerId);\n ipnsStores.push(pubsubDs);\n }\n if (get__default['default'](options, 'offline') || !get__default['default'](options, 'libp2p.config.dht.enabled', false)) {\n const offlineDatastore$1 = new offlineDatastore.OfflineDatastore(repo);\n ipnsStores.push(offlineDatastore$1);\n } else {\n ipnsStores.push(libp2p._dht);\n }\n return new tiered.TieredDatastore(ipnsStores);\n}\n\nexports.createRouting = createRouting;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar errors = require('./errors.js');\nvar debug = require('debug');\nvar pushable = require('it-pushable');\nvar drain = require('it-drain');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar pushable__default = /*#__PURE__*/_interopDefaultLegacy(pushable);\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\n\nconst log = debug__default['default']('datastore:core:tiered');\nclass TieredDatastore extends base.BaseDatastore {\n constructor(stores) {\n super();\n this.stores = stores.slice();\n }\n async open() {\n try {\n await Promise.all(this.stores.map(store => store.open()));\n } catch (err) {\n throw errors.dbOpenFailedError();\n }\n }\n async put(key, value) {\n try {\n await Promise.all(this.stores.map(store => store.put(key, value)));\n } catch (err) {\n throw errors.dbWriteFailedError();\n }\n }\n async get(key, options) {\n for (const store of this.stores) {\n try {\n const res = await store.get(key, options);\n if (res)\n return res;\n } catch (err) {\n log(err);\n }\n }\n throw errors.notFoundError();\n }\n async has(key, options) {\n for (const s of this.stores) {\n if (await s.has(key, options)) {\n return true;\n }\n }\n return false;\n }\n async delete(key, options) {\n try {\n await Promise.all(this.stores.map(store => store.delete(key, options)));\n } catch (err) {\n throw errors.dbDeleteFailedError();\n }\n }\n async *putMany(source, options = {}) {\n let error;\n const pushables = this.stores.map(store => {\n const source = pushable__default['default']();\n drain__default['default'](store.putMany(source, options)).catch(err => {\n error = err;\n });\n return source;\n });\n try {\n for await (const pair of source) {\n if (error) {\n throw error;\n }\n pushables.forEach(p => p.push(pair));\n yield pair;\n }\n } finally {\n pushables.forEach(p => p.end());\n }\n }\n async *deleteMany(source, options = {}) {\n let error;\n const pushables = this.stores.map(store => {\n const source = pushable__default['default']();\n drain__default['default'](store.deleteMany(source, options)).catch(err => {\n error = err;\n });\n return source;\n });\n try {\n for await (const key of source) {\n if (error) {\n throw error;\n }\n pushables.forEach(p => p.push(key));\n yield key;\n }\n } finally {\n pushables.forEach(p => p.end());\n }\n }\n async close() {\n await Promise.all(this.stores.map(store => store.close()));\n }\n batch() {\n const batches = this.stores.map(store => store.batch());\n return {\n put: (key, value) => {\n batches.forEach(b => b.put(key, value));\n },\n delete: key => {\n batches.forEach(b => b.delete(key));\n },\n commit: async options => {\n for (const batch of batches) {\n await batch.commit(options);\n }\n }\n };\n }\n query(q, options) {\n return this.stores[this.stores.length - 1].query(q, options);\n }\n queryKeys(q, options) {\n return this.stores[this.stores.length - 1].queryKeys(q, options);\n }\n}\n\nexports.TieredDatastore = TieredDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar drain = require('it-drain');\nvar filter = require('it-filter');\nvar take = require('it-take');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar take__default = /*#__PURE__*/_interopDefaultLegacy(take);\n\nclass BaseDatastore {\n open() {\n return Promise.reject(new Error('.open is not implemented'));\n }\n close() {\n return Promise.reject(new Error('.close is not implemented'));\n }\n put(key, val, options) {\n return Promise.reject(new Error('.put is not implemented'));\n }\n get(key, options) {\n return Promise.reject(new Error('.get is not implemented'));\n }\n has(key, options) {\n return Promise.reject(new Error('.has is not implemented'));\n }\n delete(key, options) {\n return Promise.reject(new Error('.delete is not implemented'));\n }\n async *putMany(source, options = {}) {\n for await (const {key, value} of source) {\n await this.put(key, value, options);\n yield {\n key,\n value\n };\n }\n }\n async *getMany(source, options = {}) {\n for await (const key of source) {\n yield this.get(key, options);\n }\n }\n async *deleteMany(source, options = {}) {\n for await (const key of source) {\n await this.delete(key, options);\n yield key;\n }\n }\n batch() {\n let puts = [];\n let dels = [];\n return {\n put(key, value) {\n puts.push({\n key,\n value\n });\n },\n delete(key) {\n dels.push(key);\n },\n commit: async options => {\n await drain__default['default'](this.putMany(puts, options));\n puts = [];\n await drain__default['default'](this.deleteMany(dels, options));\n dels = [];\n }\n };\n }\n async *_all(q, options) {\n throw new Error('._all is not implemented');\n }\n async *_allKeys(q, options) {\n throw new Error('._allKeys is not implemented');\n }\n query(q, options) {\n let it = this._all(q, options);\n if (q.prefix != null) {\n it = filter__default['default'](it, e => e.key.toString().startsWith(q.prefix));\n }\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => utils.sortAll(it, f), it);\n }\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null) {\n it = take__default['default'](it, q.limit);\n }\n return it;\n }\n queryKeys(q, options) {\n let it = this._allKeys(q, options);\n if (q.prefix != null) {\n it = filter__default['default'](it, key => key.toString().startsWith(q.prefix));\n }\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => utils.sortAll(it, f), it);\n }\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null) {\n it = take__default['default'](it, q.limit);\n }\n return it;\n }\n}\n\nexports.BaseDatastore = BaseDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar all = require('it-all');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\n\nconst sortAll = (iterable, sorter) => {\n return async function* () {\n const values = await all__default['default'](iterable);\n yield* values.sort(sorter);\n }();\n};\nconst replaceStartWith = (s, r) => {\n const matcher = new RegExp('^' + r);\n return s.replace(matcher, '');\n};\n\nexports.replaceStartWith = replaceStartWith;\nexports.sortAll = sortAll;\n","'use strict'\n\n/**\n * Collects all values from an (async) iterable into an array and returns it.\n *\n * @template T\n * @param {AsyncIterable|Iterable} source\n */\nconst all = async (source) => {\n const arr = []\n\n for await (const entry of source) {\n arr.push(entry)\n }\n\n return arr\n}\n\nmodule.exports = all\n","'use strict'\n\n/**\n * Drains an (async) iterable discarding its' content and does not return\n * anything.\n *\n * @template T\n * @param {AsyncIterable|Iterable} source\n * @returns {Promise}\n */\nconst drain = async (source) => {\n for await (const _ of source) { } // eslint-disable-line no-unused-vars,no-empty\n}\n\nmodule.exports = drain\n","'use strict'\n\n/**\n * Filters the passed (async) iterable by using the filter function\n *\n * @template T\n * @param {AsyncIterable|Iterable} source\n * @param {function(T):boolean|Promise} fn\n */\nconst filter = async function * (source, fn) {\n for await (const entry of source) {\n if (await fn(entry)) {\n yield entry\n }\n }\n}\n\nmodule.exports = filter\n","'use strict'\n\n/**\n * Stop iteration after n items have been received.\n *\n * @template T\n * @param {AsyncIterable|Iterable} source\n * @param {number} limit\n * @returns {AsyncIterable}\n */\nconst take = async function * (source, limit) {\n let items = 0\n\n if (limit < 1) {\n return\n }\n\n for await (const entry of source) {\n yield entry\n\n items++\n\n if (items === limit) {\n return\n }\n }\n}\n\nmodule.exports = take\n","const FIFO = require('fast-fifo')\n\nmodule.exports = (options) => {\n options = options || {}\n let onEnd\n\n if (typeof options === 'function') {\n onEnd = options\n options = {}\n } else {\n onEnd = options.onEnd\n }\n\n let buffer = new FIFO()\n let pushable, onNext, ended\n\n const waitNext = () => {\n if (!buffer.isEmpty()) {\n if (options.writev) {\n let next\n const values = []\n while (!buffer.isEmpty()) {\n next = buffer.shift()\n if (next.error) throw next.error\n values.push(next.value)\n }\n return { done: next.done, value: values }\n }\n\n const next = buffer.shift()\n if (next.error) throw next.error\n return next\n }\n\n if (ended) return { done: true }\n\n return new Promise((resolve, reject) => {\n onNext = next => {\n onNext = null\n if (next.error) {\n reject(next.error)\n } else {\n if (options.writev && !next.done) {\n resolve({ done: next.done, value: [next.value] })\n } else {\n resolve(next)\n }\n }\n return pushable\n }\n })\n }\n\n const bufferNext = next => {\n if (onNext) return onNext(next)\n buffer.push(next)\n return pushable\n }\n\n const bufferError = err => {\n buffer = new FIFO()\n if (onNext) return onNext({ error: err })\n buffer.push({ error: err })\n return pushable\n }\n\n const push = value => {\n if (ended) return pushable\n return bufferNext({ done: false, value })\n }\n const end = err => {\n if (ended) return pushable\n ended = true\n return err ? bufferError(err) : bufferNext({ done: true })\n }\n const _return = () => {\n buffer = new FIFO()\n end()\n return { done: true }\n }\n const _throw = err => {\n end(err)\n return { done: true }\n }\n\n pushable = {\n [Symbol.asyncIterator] () { return this },\n next: waitNext,\n return: _return,\n throw: _throw,\n push,\n end\n }\n\n if (!onEnd) return pushable\n\n const _pushable = pushable\n\n pushable = {\n [Symbol.asyncIterator] () { return this },\n next () {\n return _pushable.next()\n },\n throw (err) {\n _pushable.throw(err)\n if (onEnd) {\n onEnd(err)\n onEnd = null\n }\n return { done: true }\n },\n return () {\n _pushable.return()\n if (onEnd) {\n onEnd()\n onEnd = null\n }\n return { done: true }\n },\n push,\n end (err) {\n _pushable.end(err)\n if (onEnd) {\n onEnd(err)\n onEnd = null\n }\n return pushable\n }\n }\n\n return pushable\n}\n","const FixedFIFO = require('./fixed-size')\n\nmodule.exports = class FastFIFO {\n constructor (hwm) {\n this.hwm = hwm || 16\n this.head = new FixedFIFO(this.hwm)\n this.tail = this.head\n }\n\n push (val) {\n if (!this.head.push(val)) {\n const prev = this.head\n this.head = prev.next = new FixedFIFO(2 * this.head.buffer.length)\n this.head.push(val)\n }\n }\n\n shift () {\n const val = this.tail.shift()\n if (val === undefined && this.tail.next) {\n const next = this.tail.next\n this.tail.next = null\n this.tail = next\n return this.tail.shift()\n }\n return val\n }\n\n isEmpty () {\n return this.head.isEmpty()\n }\n}\n","module.exports = class FixedFIFO {\n constructor (hwm) {\n if (!(hwm > 0) || ((hwm - 1) & hwm) !== 0) throw new Error('Max size for a FixedFIFO should be a power of two')\n this.buffer = new Array(hwm)\n this.mask = hwm - 1\n this.top = 0\n this.btm = 0\n this.next = null\n }\n\n push (data) {\n if (this.buffer[this.top] !== undefined) return false\n this.buffer[this.top] = data\n this.top = (this.top + 1) & this.mask\n return true\n }\n\n shift () {\n const last = this.buffer[this.btm]\n if (last === undefined) return undefined\n this.buffer[this.btm] = undefined\n this.btm = (this.btm + 1) & this.mask\n return last\n }\n\n isEmpty () {\n return this.buffer[this.btm] === undefined\n }\n}\n","export default function dlv(obj, key, def, p, undef) {\n\tkey = key.split ? key.split('.') : key;\n\tfor (p = 0; p < key.length; p++) {\n\t\tobj = obj ? obj[key[p]] : undef;\n\t}\n\treturn obj === undef ? def : obj;\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipns = require('ipns');\nvar base58 = require('multiformats/bases/base58');\nvar datastorePubsub = require('datastore-pubsub');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar errCode = require('err-code');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:pubsub'), { error: debug__default['default']('ipfs:ipns:pubsub:error') });\nclass IpnsPubsubDatastore {\n constructor(pubsub, localDatastore, peerId) {\n this._subscriptions = {};\n this._handleSubscriptionKey = this._handleSubscriptionKey.bind(this);\n this._pubsubDs = new datastorePubsub.PubsubDatastore(pubsub, localDatastore, peerId, ipns__namespace.validator, this._handleSubscriptionKey);\n }\n put(key, value) {\n return this._pubsubDs.put(key, value);\n }\n async get(key) {\n let res;\n let err;\n try {\n res = await this._pubsubDs.get(key);\n } catch (e) {\n err = e;\n }\n const ns = key.slice(0, ipns__namespace.namespaceLength);\n if (toString.toString(ns) === ipns__namespace.namespace) {\n const stringifiedTopic = base58.base58btc.encode(key).substring(1);\n const id = base58.base58btc.encode(key.slice(ipns__namespace.namespaceLength)).substring(1);\n this._subscriptions[stringifiedTopic] = id;\n log(`subscribed to pubsub topic ${ stringifiedTopic }, id ${ id }`);\n }\n if (err) {\n throw err;\n }\n return res;\n }\n _handleSubscriptionKey(key) {\n if (key instanceof Uint8Array) {\n key = toString.toString(key, 'base58btc');\n }\n const subscriber = this._subscriptions[key];\n if (!subscriber) {\n throw errCode__default['default'](new Error(`key ${ key } does not correspond to a subscription`), 'ERR_INVALID_KEY');\n }\n let keys;\n try {\n keys = ipns__namespace.getIdKeys(fromString.fromString(subscriber, 'base58btc'));\n } catch (err) {\n log.error(err);\n throw err;\n }\n return keys.routingKey.uint8Array();\n }\n getSubscriptions() {\n const subscriptions = Object.values(this._subscriptions).filter(Boolean);\n return subscriptions.map(sub => `${ ipns__namespace.namespace }${ sub }`);\n }\n async cancel(name) {\n if (typeof name !== 'string') {\n throw errCode__default['default'](new Error('invalid subscription name'), 'ERR_INVALID_SUBSCRIPTION_NAME');\n }\n if (name.startsWith(ipns__namespace.namespace)) {\n name = name.substring(ipns__namespace.namespaceLength);\n }\n const stringifiedTopic = Object.keys(this._subscriptions).find(key => this._subscriptions[key] === name);\n if (!stringifiedTopic) {\n return { canceled: false };\n }\n const bufTopic = fromString.fromString(stringifiedTopic);\n this._pubsubDs.unsubscribe(bufTopic);\n delete this._subscriptions[stringifiedTopic];\n log(`unsubscribed pubsub ${ stringifiedTopic }: ${ name }`);\n return { canceled: true };\n }\n}\n\nexports.IpnsPubsubDatastore = IpnsPubsubDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar datastoreCore = require('datastore-core');\nvar utils = require('./utils.js');\nvar equals = require('uint8arrays/equals');\nvar errcode = require('err-code');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('datastore-pubsub:publisher'), { error: debug__default['default']('datastore-pubsub:publisher:error') });\nclass PubsubDatastore extends datastoreCore.BaseDatastore {\n constructor(pubsub, datastore, peerId, validator, subscriptionKeyFn) {\n super();\n if (!validator) {\n throw errcode__default['default'](new TypeError('missing validator'), 'ERR_INVALID_PARAMETERS');\n }\n if (typeof validator.validate !== 'function') {\n throw errcode__default['default'](new TypeError('missing validate function'), 'ERR_INVALID_PARAMETERS');\n }\n if (typeof validator.select !== 'function') {\n throw errcode__default['default'](new TypeError('missing select function'), 'ERR_INVALID_PARAMETERS');\n }\n if (subscriptionKeyFn && typeof subscriptionKeyFn !== 'function') {\n throw errcode__default['default'](new TypeError('invalid subscriptionKeyFn received'), 'ERR_INVALID_PARAMETERS');\n }\n this._pubsub = pubsub;\n this._datastore = datastore;\n this._peerId = peerId;\n this._validator = validator;\n this._handleSubscriptionKeyFn = subscriptionKeyFn;\n this._onMessage = this._onMessage.bind(this);\n }\n async put(key, val) {\n if (!(key instanceof Uint8Array)) {\n const errMsg = 'datastore key does not have a valid format';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_INVALID_DATASTORE_KEY');\n }\n if (!(val instanceof Uint8Array)) {\n const errMsg = 'received value is not a Uint8Array';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_INVALID_VALUE_RECEIVED');\n }\n const stringifiedTopic = utils.keyToTopic(key);\n log(`publish value for topic ${ stringifiedTopic }`);\n await this._pubsub.publish(stringifiedTopic, val);\n }\n async get(key) {\n if (!(key instanceof Uint8Array)) {\n const errMsg = 'datastore key does not have a valid format';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_INVALID_DATASTORE_KEY');\n }\n const stringifiedTopic = utils.keyToTopic(key);\n const subscriptions = await this._pubsub.getTopics();\n if (subscriptions && Array.isArray(subscriptions) && subscriptions.indexOf(stringifiedTopic) > -1) {\n return this._getLocal(key);\n }\n try {\n this._pubsub.on(stringifiedTopic, this._onMessage);\n await this._pubsub.subscribe(stringifiedTopic);\n } catch (err) {\n const errMsg = `cannot subscribe topic ${ stringifiedTopic }`;\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_SUBSCRIBING_TOPIC');\n }\n log(`subscribed values for key ${ stringifiedTopic }`);\n return this._getLocal(key);\n }\n unsubscribe(key) {\n const stringifiedTopic = utils.keyToTopic(key);\n this._pubsub.removeListener(stringifiedTopic, this._onMessage);\n return this._pubsub.unsubscribe(stringifiedTopic);\n }\n async _getLocal(key) {\n const routingKey = new interfaceDatastore.Key('/' + utils.encodeBase32(key), false);\n let dsVal;\n try {\n dsVal = await this._datastore.get(routingKey);\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n const errMsg = `unexpected error getting the ipns record for ${ routingKey.toString() }`;\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_UNEXPECTED_ERROR_GETTING_RECORD');\n }\n const errMsg = `local record requested was not found for ${ routingKey.toString() }`;\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_NOT_FOUND');\n }\n if (!(dsVal instanceof Uint8Array)) {\n const errMsg = 'found record that we couldn\\'t convert to a value';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_INVALID_RECORD_RECEIVED');\n }\n return dsVal;\n }\n async _onMessage(msg) {\n const {data, from, topicIDs} = msg;\n let key;\n try {\n key = utils.topicToKey(topicIDs[0]);\n } catch (err) {\n log.error(err);\n return;\n }\n log(`message received for topic ${ topicIDs[0] }`);\n if (from === this._peerId.toB58String()) {\n log('message discarded as it is from the same peer');\n return;\n }\n if (this._handleSubscriptionKeyFn) {\n let res;\n try {\n res = await this._handleSubscriptionKeyFn(key);\n } catch (err) {\n log.error('message discarded by the subscriptionKeyFn');\n return;\n }\n key = res;\n }\n try {\n await this._storeIfSubscriptionIsBetter(key, data);\n } catch (err) {\n log.error(err);\n }\n }\n async _storeIfSubscriptionIsBetter(key, data) {\n let isBetter = false;\n try {\n isBetter = await this._isBetter(key, data);\n } catch (err) {\n if (err.code !== 'ERR_NOT_VALID_RECORD') {\n throw err;\n }\n }\n if (isBetter) {\n await this._storeRecord(key, data);\n }\n }\n async _validateRecord(value, peerId) {\n return this._validator.validate(value, peerId);\n }\n async _selectRecord(key, records) {\n const res = await this._validator.select(key, records);\n return res === 0;\n }\n async _isBetter(key, val) {\n try {\n await this._validateRecord(val, key);\n } catch (err) {\n const errMsg = 'record received through pubsub is not valid';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_NOT_VALID_RECORD');\n }\n const dsKey = new interfaceDatastore.Key(key);\n let currentRecord;\n try {\n currentRecord = await this._getLocal(dsKey.uint8Array());\n } catch (err) {\n return true;\n }\n if (equals.equals(currentRecord, val)) {\n return false;\n }\n return this._selectRecord(key, [\n currentRecord,\n val\n ]);\n }\n async _storeRecord(key, data) {\n const routingKey = new interfaceDatastore.Key('/' + utils.encodeBase32(key), false);\n await this._datastore.put(routingKey, data);\n log(`record for ${ utils.keyToTopic(key) } was stored in the datastore`);\n }\n}\n\nexports.PubsubDatastore = PubsubDatastore;\n","module.exports = require('./cjs/src/index.js')\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('./key.js');\n\n\n\nexports.Key = key.Key;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('./errors.js');\nvar shard$1 = require('./shard.js');\nvar base = require('./base.js');\nvar memory = require('./memory.js');\nvar keytransform = require('./keytransform.js');\nvar sharding = require('./sharding.js');\nvar mount = require('./mount.js');\nvar tiered = require('./tiered.js');\nvar namespace = require('./namespace.js');\n\nconst Errors = { ...errors };\nconst shard = { ...shard$1 };\n\nexports.BaseDatastore = base.BaseDatastore;\nexports.MemoryDatastore = memory.MemoryDatastore;\nexports.KeyTransformDatastore = keytransform.KeyTransformDatastore;\nexports.ShardingDatastore = sharding.ShardingDatastore;\nexports.MountDatastore = mount.MountDatastore;\nexports.TieredDatastore = tiered.TieredDatastore;\nexports.NamespaceDatastore = namespace.NamespaceDatastore;\nexports.Errors = Errors;\nexports.shard = shard;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar shardReadme = require('./shard-readme.js');\n\nconst PREFIX = '/repo/flatfs/shard/';\nconst SHARDING_FN = 'SHARDING';\nconst README_FN = '_README';\nclass ShardBase {\n constructor(param) {\n this.param = param;\n this.name = 'base';\n this._padding = '';\n }\n fun(s) {\n return 'implement me';\n }\n toString() {\n return `${ PREFIX }v1/${ this.name }/${ this.param }`;\n }\n}\nclass Prefix extends ShardBase {\n constructor(prefixLen) {\n super(prefixLen);\n this._padding = ''.padStart(prefixLen, '_');\n this.name = 'prefix';\n }\n fun(noslash) {\n return (noslash + this._padding).slice(0, this.param);\n }\n}\nclass Suffix extends ShardBase {\n constructor(suffixLen) {\n super(suffixLen);\n this._padding = ''.padStart(suffixLen, '_');\n this.name = 'suffix';\n }\n fun(noslash) {\n const s = this._padding + noslash;\n return s.slice(s.length - this.param);\n }\n}\nclass NextToLast extends ShardBase {\n constructor(suffixLen) {\n super(suffixLen);\n this._padding = ''.padStart(suffixLen + 1, '_');\n this.name = 'next-to-last';\n }\n fun(noslash) {\n const s = this._padding + noslash;\n const offset = s.length - this.param - 1;\n return s.slice(offset, offset + this.param);\n }\n}\nfunction parseShardFun(str) {\n str = str.trim();\n if (str.length === 0) {\n throw new Error('empty shard string');\n }\n if (!str.startsWith(PREFIX)) {\n throw new Error(`invalid or no path prefix: ${ str }`);\n }\n const parts = str.slice(PREFIX.length).split('/');\n const version = parts[0];\n if (version !== 'v1') {\n throw new Error(`expect 'v1' version, got '${ version }'`);\n }\n const name = parts[1];\n if (!parts[2]) {\n throw new Error('missing param');\n }\n const param = parseInt(parts[2], 10);\n switch (name) {\n case 'prefix':\n return new Prefix(param);\n case 'suffix':\n return new Suffix(param);\n case 'next-to-last':\n return new NextToLast(param);\n default:\n throw new Error(`unkown sharding function: ${ name }`);\n }\n}\nconst readShardFun = async (path, store) => {\n const key$1 = new key.Key(path).child(new key.Key(SHARDING_FN));\n const get = typeof store.getRaw === 'function' ? store.getRaw.bind(store) : store.get.bind(store);\n const res = await get(key$1);\n return parseShardFun(new TextDecoder().decode(res || '').trim());\n};\n\nexports.readme = shardReadme;\nexports.NextToLast = NextToLast;\nexports.PREFIX = PREFIX;\nexports.Prefix = Prefix;\nexports.README_FN = README_FN;\nexports.SHARDING_FN = SHARDING_FN;\nexports.ShardBase = ShardBase;\nexports.Suffix = Suffix;\nexports.parseShardFun = parseShardFun;\nexports.readShardFun = readShardFun;\n","'use strict';\n\nvar readme = `This is a repository of IPLD objects. Each IPLD object is in a single file,\nnamed .data. Where is the\n\"base32\" encoding of the CID (as specified in\nhttps://github.com/multiformats/multibase) without the 'B' prefix.\nAll the object files are placed in a tree of directories, based on a\nfunction of the CID. This is a form of sharding similar to\nthe objects directory in git repositories. Previously, we used\nprefixes, we now use the next-to-last two charters.\n func NextToLast(base32cid string) {\n nextToLastLen := 2\n offset := len(base32cid) - nextToLastLen - 1\n return str[offset : offset+nextToLastLen]\n }\nFor example, an object with a base58 CIDv1 of\n zb2rhYSxw4ZjuzgCnWSt19Q94ERaeFhu9uSqRgjSdx9bsgM6f\nhas a base32 CIDv1 of\n BAFKREIA22FLID5AJ2KU7URG47MDLROZIH6YF2KALU2PWEFPVI37YLKRSCA\nand will be placed at\n SC/AFKREIA22FLID5AJ2KU7URG47MDLROZIH6YF2KALU2PWEFPVI37YLKRSCA.data\nwith 'SC' being the last-to-next two characters and the 'B' at the\nbeginning of the CIDv1 string is the multibase prefix that is not\nstored in the filename.\n`;\n\nmodule.exports = readme;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar key = require('interface-datastore/key');\nvar errors = require('./errors.js');\n\nclass MemoryDatastore extends base.BaseDatastore {\n constructor() {\n super();\n this.data = {};\n }\n open() {\n return Promise.resolve();\n }\n close() {\n return Promise.resolve();\n }\n async put(key, val) {\n this.data[key.toString()] = val;\n }\n async get(key) {\n const exists = await this.has(key);\n if (!exists)\n throw errors.notFoundError();\n return this.data[key.toString()];\n }\n async has(key) {\n return this.data[key.toString()] !== undefined;\n }\n async delete(key) {\n delete this.data[key.toString()];\n }\n async *_all() {\n yield* Object.entries(this.data).map(([key$1, value]) => ({\n key: new key.Key(key$1),\n value\n }));\n }\n async *_allKeys() {\n yield* Object.entries(this.data).map(([key$1]) => new key.Key(key$1));\n }\n}\n\nexports.MemoryDatastore = MemoryDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar map = require('it-map');\nvar itPipe = require('it-pipe');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\n\nclass KeyTransformDatastore extends base.BaseDatastore {\n constructor(child, transform) {\n super();\n this.child = child;\n this.transform = transform;\n }\n open() {\n return this.child.open();\n }\n put(key, val, options) {\n return this.child.put(this.transform.convert(key), val, options);\n }\n get(key, options) {\n return this.child.get(this.transform.convert(key), options);\n }\n has(key, options) {\n return this.child.has(this.transform.convert(key), options);\n }\n delete(key, options) {\n return this.child.delete(this.transform.convert(key), options);\n }\n async *putMany(source, options = {}) {\n const transform = this.transform;\n const child = this.child;\n yield* itPipe.pipe(source, async function* (source) {\n yield* map__default['default'](source, ({key, value}) => ({\n key: transform.convert(key),\n value\n }));\n }, async function* (source) {\n yield* child.putMany(source, options);\n }, async function* (source) {\n yield* map__default['default'](source, ({key, value}) => ({\n key: transform.invert(key),\n value\n }));\n });\n }\n async *getMany(source, options = {}) {\n const transform = this.transform;\n const child = this.child;\n yield* itPipe.pipe(source, async function* (source) {\n yield* map__default['default'](source, key => transform.convert(key));\n }, async function* (source) {\n yield* child.getMany(source, options);\n });\n }\n async *deleteMany(source, options = {}) {\n const transform = this.transform;\n const child = this.child;\n yield* itPipe.pipe(source, async function* (source) {\n yield* map__default['default'](source, key => transform.convert(key));\n }, async function* (source) {\n yield* child.deleteMany(source, options);\n }, async function* (source) {\n yield* map__default['default'](source, key => transform.invert(key));\n });\n }\n batch() {\n const b = this.child.batch();\n return {\n put: (key, value) => {\n b.put(this.transform.convert(key), value);\n },\n delete: key => {\n b.delete(this.transform.convert(key));\n },\n commit: options => {\n return b.commit(options);\n }\n };\n }\n query(q, options) {\n return map__default['default'](this.child.query(q, options), ({key, value}) => {\n return {\n key: this.transform.invert(key),\n value\n };\n });\n }\n queryKeys(q, options) {\n return map__default['default'](this.child.queryKeys(q, options), key => {\n return this.transform.invert(key);\n });\n }\n close() {\n return this.child.close();\n }\n}\n\nexports.KeyTransformDatastore = KeyTransformDatastore;\n","'use strict'\n\n/**\n * Takes an (async) iterable and returns one with each item mapped by the passed\n * function.\n *\n * @template I,O\n * @param {AsyncIterable|Iterable} source\n * @param {function(I):O|Promise} func\n * @returns {AsyncIterable}\n */\nconst map = async function * (source, func) {\n for await (const val of source) {\n yield func(val)\n }\n}\n\nmodule.exports = map\n","const rawPipe = (...fns) => {\n let res\n while (fns.length) {\n res = fns.shift()(res)\n }\n return res\n}\n\nconst isIterable = obj => obj && (\n typeof obj[Symbol.asyncIterator] === 'function' ||\n typeof obj[Symbol.iterator] === 'function' ||\n typeof obj.next === 'function' // Probably, right?\n)\n\nconst isDuplex = obj => obj && typeof obj.sink === 'function' && isIterable(obj.source)\n\nconst duplexPipelineFn = duplex => source => {\n duplex.sink(source) // TODO: error on sink side is unhandled rejection - this is the same as pull streams\n return duplex.source\n}\n\nconst pipe = (...fns) => {\n // Duplex at start: wrap in function and return duplex source\n if (isDuplex(fns[0])) {\n const duplex = fns[0]\n fns[0] = () => duplex.source\n // Iterable at start: wrap in function\n } else if (isIterable(fns[0])) {\n const source = fns[0]\n fns[0] = () => source\n }\n\n if (fns.length > 1) {\n // Duplex at end: use duplex sink\n if (isDuplex(fns[fns.length - 1])) {\n fns[fns.length - 1] = fns[fns.length - 1].sink\n }\n }\n\n if (fns.length > 2) {\n // Duplex in the middle, consume source with duplex sink and return duplex source\n for (let i = 1; i < fns.length - 1; i++) {\n if (isDuplex(fns[i])) {\n fns[i] = duplexPipelineFn(fns[i])\n }\n }\n }\n\n return rawPipe(...fns)\n}\n\nmodule.exports = pipe\nmodule.exports.pipe = pipe\nmodule.exports.rawPipe = rawPipe\nmodule.exports.isIterable = isIterable\nmodule.exports.isDuplex = isDuplex\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar shard = require('./shard.js');\nvar base = require('./base.js');\nvar keytransform = require('./keytransform.js');\nvar errors = require('./errors.js');\nvar shardReadme = require('./shard-readme.js');\n\nconst shardKey = new interfaceDatastore.Key(shard.SHARDING_FN);\nconst shardReadmeKey = new interfaceDatastore.Key(shard.README_FN);\nclass ShardingDatastore extends base.BaseDatastore {\n constructor(store, shard) {\n super();\n this.child = new keytransform.KeyTransformDatastore(store, {\n convert: this._convertKey.bind(this),\n invert: this._invertKey.bind(this)\n });\n this.shard = shard;\n }\n async open() {\n await this.child.open();\n this.shard = await ShardingDatastore.create(this.child, this.shard);\n }\n _convertKey(key) {\n const s = key.toString();\n if (s === shardKey.toString() || s === shardReadmeKey.toString()) {\n return key;\n }\n const parent = new interfaceDatastore.Key(this.shard.fun(s));\n return parent.child(key);\n }\n _invertKey(key) {\n const s = key.toString();\n if (s === shardKey.toString() || s === shardReadmeKey.toString()) {\n return key;\n }\n return interfaceDatastore.Key.withNamespaces(key.list().slice(1));\n }\n static async createOrOpen(store, shard) {\n try {\n await ShardingDatastore.create(store, shard);\n } catch (err) {\n if (err && err.message !== 'datastore exists')\n throw err;\n }\n return ShardingDatastore.open(store);\n }\n static async open(store) {\n const shard$1 = await shard.readShardFun('/', store);\n return new ShardingDatastore(store, shard$1);\n }\n static async create(store, shard$1) {\n const hasShard = await store.has(shardKey);\n if (!hasShard && !shard$1) {\n throw errors.dbOpenFailedError(Error('Shard is required when datastore doesn\\'t have a shard key already.'));\n }\n if (!hasShard) {\n const put = typeof store.putRaw === 'function' ? store.putRaw.bind(store) : store.put.bind(store);\n await Promise.all([\n put(shardKey, new TextEncoder().encode(shard$1.toString() + '\\n')),\n put(shardReadmeKey, new TextEncoder().encode(shardReadme))\n ]);\n return shard$1;\n }\n const diskShard = await shard.readShardFun('/', store);\n const a = (diskShard || '').toString();\n const b = shard$1.toString();\n if (a !== b) {\n throw new Error(`specified fun ${ b } does not match repo shard fun ${ a }`);\n }\n return diskShard;\n }\n put(key, val, options) {\n return this.child.put(key, val, options);\n }\n get(key, options) {\n return this.child.get(key, options);\n }\n has(key, options) {\n return this.child.has(key, options);\n }\n delete(key, options) {\n return this.child.delete(key, options);\n }\n async *putMany(source, options = {}) {\n yield* this.child.putMany(source, options);\n }\n async *getMany(source, options = {}) {\n yield* this.child.getMany(source, options);\n }\n async *deleteMany(source, options = {}) {\n yield* this.child.deleteMany(source, options);\n }\n batch() {\n return this.child.batch();\n }\n query(q, options) {\n const tq = {\n offset: q.offset,\n limit: q.limit,\n orders: [],\n filters: [\n e => e.key.toString() !== shardKey.toString(),\n e => e.key.toString() !== shardReadmeKey.toString()\n ]\n };\n const {prefix} = q;\n if (prefix != null) {\n tq.filters.push(e => {\n return this._invertKey(e.key).toString().startsWith(prefix);\n });\n }\n if (q.filters != null) {\n const filters = q.filters.map(f => {\n const filter = ({key, value}) => {\n return f({\n key: this._invertKey(key),\n value\n });\n };\n return filter;\n });\n tq.filters = tq.filters.concat(filters);\n }\n if (q.orders != null) {\n tq.orders = q.orders.map(o => {\n const order = (a, b) => {\n return o({\n key: this._invertKey(a.key),\n value: a.value\n }, {\n key: this._invertKey(b.key),\n value: b.value\n });\n };\n return order;\n });\n }\n return this.child.query(tq, options);\n }\n queryKeys(q, options) {\n const tq = {\n offset: q.offset,\n limit: q.limit,\n orders: [],\n filters: [\n key => key.toString() !== shardKey.toString(),\n key => key.toString() !== shardReadmeKey.toString()\n ]\n };\n const {prefix} = q;\n if (prefix != null) {\n tq.filters.push(key => {\n return this._invertKey(key).toString().startsWith(prefix);\n });\n }\n if (q.filters != null) {\n const filters = q.filters.map(f => {\n const filter = key => {\n return f(this._invertKey(key));\n };\n return filter;\n });\n tq.filters = tq.filters.concat(filters);\n }\n if (q.orders != null) {\n tq.orders = q.orders.map(o => {\n const order = (a, b) => o(this._invertKey(a), this._invertKey(b));\n return order;\n });\n }\n return this.child.queryKeys(tq, options);\n }\n close() {\n return this.child.close();\n }\n}\n\nexports.ShardingDatastore = ShardingDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar filter = require('it-filter');\nvar take = require('it-take');\nvar merge = require('it-merge');\nvar base = require('./base.js');\nvar keytransform = require('./keytransform.js');\nvar errors = require('./errors.js');\nvar utils = require('./utils.js');\nvar key = require('interface-datastore/key');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar take__default = /*#__PURE__*/_interopDefaultLegacy(take);\nvar merge__default = /*#__PURE__*/_interopDefaultLegacy(merge);\n\nclass MountDatastore extends base.BaseDatastore {\n constructor(mounts) {\n super();\n this.mounts = mounts.slice();\n }\n async open() {\n await Promise.all(this.mounts.map(m => m.datastore.open()));\n }\n _lookup(key$1) {\n for (const mount of this.mounts) {\n if (mount.prefix.toString() === key$1.toString() || mount.prefix.isAncestorOf(key$1)) {\n const s = utils.replaceStartWith(key$1.toString(), mount.prefix.toString());\n return {\n datastore: mount.datastore,\n mountpoint: mount.prefix,\n rest: new key.Key(s)\n };\n }\n }\n }\n put(key, value, options) {\n const match = this._lookup(key);\n if (match == null) {\n throw errors.dbWriteFailedError(new Error('No datastore mounted for this key'));\n }\n return match.datastore.put(match.rest, value, options);\n }\n get(key, options) {\n const match = this._lookup(key);\n if (match == null) {\n throw errors.notFoundError(new Error('No datastore mounted for this key'));\n }\n return match.datastore.get(match.rest, options);\n }\n has(key, options) {\n const match = this._lookup(key);\n if (match == null) {\n return Promise.resolve(false);\n }\n return match.datastore.has(match.rest, options);\n }\n delete(key, options) {\n const match = this._lookup(key);\n if (match == null) {\n throw errors.dbDeleteFailedError(new Error('No datastore mounted for this key'));\n }\n return match.datastore.delete(match.rest, options);\n }\n async close() {\n await Promise.all(this.mounts.map(m => {\n return m.datastore.close();\n }));\n }\n batch() {\n const batchMounts = {};\n const lookup = key => {\n const match = this._lookup(key);\n if (match == null) {\n throw new Error('No datastore mounted for this key');\n }\n const m = match.mountpoint.toString();\n if (batchMounts[m] == null) {\n batchMounts[m] = match.datastore.batch();\n }\n return {\n batch: batchMounts[m],\n rest: match.rest\n };\n };\n return {\n put: (key, value) => {\n const match = lookup(key);\n match.batch.put(match.rest, value);\n },\n delete: key => {\n const match = lookup(key);\n match.batch.delete(match.rest);\n },\n commit: async options => {\n await Promise.all(Object.keys(batchMounts).map(p => batchMounts[p].commit(options)));\n }\n };\n }\n query(q, options) {\n const qs = this.mounts.map(m => {\n const ks = new keytransform.KeyTransformDatastore(m.datastore, {\n convert: key => {\n throw new Error('should never be called');\n },\n invert: key => {\n return m.prefix.child(key);\n }\n });\n let prefix;\n if (q.prefix != null) {\n prefix = utils.replaceStartWith(q.prefix, m.prefix.toString());\n }\n return ks.query({\n prefix: prefix,\n filters: q.filters\n }, options);\n });\n let it = merge__default['default'](...qs);\n if (q.filters)\n q.filters.forEach(f => {\n it = filter__default['default'](it, f);\n });\n if (q.orders)\n q.orders.forEach(o => {\n it = utils.sortAll(it, o);\n });\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null)\n it = take__default['default'](it, q.limit);\n return it;\n }\n queryKeys(q, options) {\n const qs = this.mounts.map(m => {\n const ks = new keytransform.KeyTransformDatastore(m.datastore, {\n convert: key => {\n throw new Error('should never be called');\n },\n invert: key => {\n return m.prefix.child(key);\n }\n });\n let prefix;\n if (q.prefix != null) {\n prefix = utils.replaceStartWith(q.prefix, m.prefix.toString());\n }\n return ks.queryKeys({\n prefix: prefix,\n filters: q.filters\n }, options);\n });\n let it = merge__default['default'](...qs);\n if (q.filters)\n q.filters.forEach(f => {\n it = filter__default['default'](it, f);\n });\n if (q.orders)\n q.orders.forEach(o => {\n it = utils.sortAll(it, o);\n });\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null)\n it = take__default['default'](it, q.limit);\n return it;\n }\n}\n\nexports.MountDatastore = MountDatastore;\n","'use strict'\n\nconst pushable = require('it-pushable')\n\n/**\n * Treat one or more iterables as a single iterable.\n *\n * Nb. sources are iterated over in parallel so the\n * order of emitted items is not guaranteed.\n *\n * @template T\n * @param {...AsyncIterable|Iterable} sources\n * @returns {AsyncIterable}\n */\nconst merge = async function * (...sources) {\n const output = pushable()\n\n setTimeout(async () => {\n try {\n await Promise.all(\n sources.map(async (source) => {\n for await (const item of source) {\n output.push(item)\n }\n })\n )\n\n output.end()\n } catch (/** @type {any} */ err) {\n output.end(err)\n }\n }, 0)\n\n yield * output\n}\n\nmodule.exports = merge\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar keytransform = require('./keytransform.js');\n\nclass NamespaceDatastore extends keytransform.KeyTransformDatastore {\n constructor(child, prefix) {\n super(child, {\n convert(key) {\n return prefix.child(key);\n },\n invert(key) {\n if (prefix.toString() === '/') {\n return key;\n }\n if (!prefix.isAncestorOf(key)) {\n throw new Error(`Expected prefix: (${ prefix.toString() }) in key: ${ key.toString() }`);\n }\n return new interfaceDatastore.Key(key.toString().slice(prefix.toString().length), false);\n }\n });\n this.prefix = prefix;\n }\n query(q, options) {\n if (q.prefix && this.prefix.toString() !== '/') {\n return super.query(Object.assign({}, q, { prefix: this.prefix.child(new interfaceDatastore.Key(q.prefix)).toString() }));\n }\n return super.query(q, options);\n }\n queryKeys(q, options) {\n if (q.prefix && this.prefix.toString() !== '/') {\n return super.queryKeys(Object.assign({}, q, { prefix: this.prefix.child(new interfaceDatastore.Key(q.prefix)).toString() }));\n }\n return super.queryKeys(q, options);\n }\n}\n\nexports.NamespaceDatastore = NamespaceDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errcode = require('err-code');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\n\nconst namespace = '/record/';\nfunction encodeBase32(buf) {\n return toString.toString(buf, 'base32');\n}\nfunction keyToTopic(key) {\n if (typeof key === 'string' || key instanceof String) {\n key = fromString.fromString(key.toString());\n }\n const b64url = toString.toString(key, 'base64url');\n return `${ namespace }${ b64url }`;\n}\nfunction topicToKey(topic) {\n if (topic.substring(0, namespace.length) !== namespace) {\n throw errcode__default['default'](new Error('topic received is not from a record'), 'ERR_TOPIC_IS_NOT_FROM_RECORD_NAMESPACE');\n }\n const key = topic.substring(namespace.length);\n return fromString.fromString(key, 'base64url');\n}\n\nexports.encodeBase32 = encodeBase32;\nexports.keyToTopic = keyToTopic;\nexports.topicToKey = topicToKey;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar libp2pRecord = require('libp2p-record');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar toString = require('uint8arrays/to-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:offline-datastore'), { error: debug__default['default']('ipfs:ipns:offline-datastore:error') });\nclass OfflineDatastore {\n constructor(repo) {\n this._repo = repo;\n this.stores = [];\n }\n async put(key, value) {\n if (!(key instanceof Uint8Array)) {\n throw errCode__default['default'](new Error('Offline datastore key must be a Uint8Array'), 'ERR_INVALID_KEY');\n }\n if (!(value instanceof Uint8Array)) {\n throw errCode__default['default'](new Error('Offline datastore value must be a Uint8Array'), 'ERR_INVALID_VALUE');\n }\n let routingKey;\n try {\n routingKey = this._routingKey(key);\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](new Error('Not possible to generate the routing key'), 'ERR_GENERATING_ROUTING_KEY');\n }\n const record = new libp2pRecord.Record(key, value);\n return this._repo.datastore.put(routingKey, record.serialize());\n }\n async get(key) {\n if (!(key instanceof Uint8Array)) {\n throw errCode__default['default'](new Error('Offline datastore key must be a Uint8Array'), 'ERR_INVALID_KEY');\n }\n let routingKey;\n try {\n routingKey = this._routingKey(key);\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](new Error('Not possible to generate the routing key'), 'ERR_GENERATING_ROUTING_KEY');\n }\n const res = await this._repo.datastore.get(routingKey);\n let record;\n try {\n record = libp2pRecord.Record.deserialize(res);\n } catch (err) {\n log.error(err);\n throw err;\n }\n return record.value;\n }\n _routingKey(key$1) {\n return new key.Key('/' + toString.toString(key$1, 'base32upper'), false);\n }\n}\n\nexports.OfflineDatastore = OfflineDatastore;\n","'use strict'\n\nmodule.exports = {\n Record: require('./record'),\n validator: require('./validator'),\n selection: require('./selection')\n}\n","'use strict'\n\nconst {\n Record: PBRecord\n} = require('./record')\nconst utils = require('../utils')\n\n/**\n * @typedef {{ key: Uint8Array, value: Uint8Array, timeReceived: string }} ProtobufRecord\n */\n\nclass Record {\n /**\n * @param {Uint8Array} [key]\n * @param {Uint8Array} [value]\n * @param {Date} [timeReceived]\n */\n constructor (key, value, timeReceived) {\n if (!(key instanceof Uint8Array)) {\n throw new Error('key must be a Uint8Array')\n }\n\n if (!(value instanceof Uint8Array)) {\n throw new Error('value must be a Uint8Array')\n }\n\n this.key = key\n this.value = value\n this.timeReceived = timeReceived\n }\n\n serialize () {\n return PBRecord.encode(this.prepareSerialize()).finish()\n }\n\n /**\n * Return the object format ready to be given to the protobuf library.\n */\n prepareSerialize () {\n return {\n key: this.key,\n value: this.value,\n timeReceived: this.timeReceived && utils.toRFC3339(this.timeReceived)\n }\n }\n\n /**\n * Decode a protobuf encoded record.\n *\n * @param {Uint8Array} raw\n */\n static deserialize (raw) {\n const message = PBRecord.decode(raw)\n return Record.fromDeserialized(PBRecord.toObject(message, {\n defaults: false,\n arrays: true,\n longs: Number,\n objects: false\n }))\n }\n\n /**\n * Create a record from the raw object returned from the protobuf library.\n *\n * @param {{ [k: string]: any }} obj\n */\n static fromDeserialized (obj) {\n let recvtime\n if (obj.timeReceived) {\n recvtime = utils.parseRFC3339(obj.timeReceived)\n }\n\n const rec = new Record(\n obj.key, obj.value, recvtime\n )\n\n return rec\n }\n}\n\nmodule.exports = Record\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-record\"] || ($protobuf.roots[\"libp2p-record\"] = {});\n\n$root.Record = (function() {\n\n /**\n * Properties of a Record.\n * @exports IRecord\n * @interface IRecord\n * @property {Uint8Array|null} [key] Record key\n * @property {Uint8Array|null} [value] Record value\n * @property {string|null} [timeReceived] Record timeReceived\n */\n\n /**\n * Constructs a new Record.\n * @exports Record\n * @classdesc Represents a Record.\n * @implements IRecord\n * @constructor\n * @param {IRecord=} [p] Properties to set\n */\n function Record(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Record key.\n * @member {Uint8Array} key\n * @memberof Record\n * @instance\n */\n Record.prototype.key = $util.newBuffer([]);\n\n /**\n * Record value.\n * @member {Uint8Array} value\n * @memberof Record\n * @instance\n */\n Record.prototype.value = $util.newBuffer([]);\n\n /**\n * Record timeReceived.\n * @member {string} timeReceived\n * @memberof Record\n * @instance\n */\n Record.prototype.timeReceived = \"\";\n\n /**\n * Encodes the specified Record message. Does not implicitly {@link Record.verify|verify} messages.\n * @function encode\n * @memberof Record\n * @static\n * @param {IRecord} m Record message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Record.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(10).bytes(m.key);\n if (m.value != null && Object.hasOwnProperty.call(m, \"value\"))\n w.uint32(18).bytes(m.value);\n if (m.timeReceived != null && Object.hasOwnProperty.call(m, \"timeReceived\"))\n w.uint32(42).string(m.timeReceived);\n return w;\n };\n\n /**\n * Decodes a Record message from the specified reader or buffer.\n * @function decode\n * @memberof Record\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Record} Record\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Record.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Record();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.key = r.bytes();\n break;\n case 2:\n m.value = r.bytes();\n break;\n case 5:\n m.timeReceived = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Record message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Record\n * @static\n * @param {Object.} d Plain object\n * @returns {Record} Record\n */\n Record.fromObject = function fromObject(d) {\n if (d instanceof $root.Record)\n return d;\n var m = new $root.Record();\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n if (d.value != null) {\n if (typeof d.value === \"string\")\n $util.base64.decode(d.value, m.value = $util.newBuffer($util.base64.length(d.value)), 0);\n else if (d.value.length)\n m.value = d.value;\n }\n if (d.timeReceived != null) {\n m.timeReceived = String(d.timeReceived);\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Record message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Record\n * @static\n * @param {Record} m Record\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Record.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.key = \"\";\n else {\n d.key = [];\n if (o.bytes !== Array)\n d.key = $util.newBuffer(d.key);\n }\n if (o.bytes === String)\n d.value = \"\";\n else {\n d.value = [];\n if (o.bytes !== Array)\n d.value = $util.newBuffer(d.value);\n }\n d.timeReceived = \"\";\n }\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n }\n if (m.value != null && m.hasOwnProperty(\"value\")) {\n d.value = o.bytes === String ? $util.base64.encode(m.value, 0, m.value.length) : o.bytes === Array ? Array.prototype.slice.call(m.value) : m.value;\n }\n if (m.timeReceived != null && m.hasOwnProperty(\"timeReceived\")) {\n d.timeReceived = m.timeReceived;\n }\n return d;\n };\n\n /**\n * Converts this Record to JSON.\n * @function toJSON\n * @memberof Record\n * @instance\n * @returns {Object.} JSON object\n */\n Record.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Record;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\n/**\n * Convert a JavaScript date into an `RFC3339Nano` formatted\n * string.\n *\n * @param {Date} time\n */\nmodule.exports.toRFC3339 = (time) => {\n const year = time.getUTCFullYear()\n const month = String(time.getUTCMonth() + 1).padStart(2, '0')\n const day = String(time.getUTCDate()).padStart(2, '0')\n const hour = String(time.getUTCHours()).padStart(2, '0')\n const minute = String(time.getUTCMinutes()).padStart(2, '0')\n const seconds = String(time.getUTCSeconds()).padStart(2, '0')\n const milliseconds = time.getUTCMilliseconds()\n const nanoseconds = milliseconds * 1000 * 1000\n\n return `${year}-${month}-${day}T${hour}:${minute}:${seconds}.${nanoseconds}Z`\n}\n\n/**\n * Parses a date string formatted as `RFC3339Nano` into a\n * JavaScript Date object.\n *\n * @param {string} time\n */\nmodule.exports.parseRFC3339 = (time) => {\n const rfc3339Matcher = new RegExp(\n // 2006-01-02T\n '(\\\\d{4})-(\\\\d{2})-(\\\\d{2})T' +\n // 15:04:05\n '(\\\\d{2}):(\\\\d{2}):(\\\\d{2})' +\n // .999999999Z\n '\\\\.(\\\\d+)Z'\n )\n const m = String(time).trim().match(rfc3339Matcher)\n\n if (!m) {\n throw new Error('Invalid format')\n }\n\n const year = parseInt(m[1], 10)\n const month = parseInt(m[2], 10) - 1\n const date = parseInt(m[3], 10)\n const hour = parseInt(m[4], 10)\n const minute = parseInt(m[5], 10)\n const second = parseInt(m[6], 10)\n const millisecond = parseInt(m[7].slice(0, -6), 10)\n\n return new Date(Date.UTC(year, month, date, hour, minute, second, millisecond))\n}\n","'use strict'\n\nconst errcode = require('err-code')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\n/**\n * @typedef {import('./record')} Record\n */\n\n/**\n * Checks a record and ensures it is still valid.\n * It runs the needed validators.\n * If verification fails the returned Promise will reject with the error.\n *\n * @param {import('libp2p-interfaces/src/types').DhtValidators} validators\n * @param {Record} record\n */\nconst verifyRecord = (validators, record) => {\n const key = record.key\n const keyString = uint8ArrayToString(key)\n const parts = keyString.split('/')\n\n if (parts.length < 3) {\n // No validator available\n return\n }\n\n const validator = validators[parts[1].toString()]\n\n if (!validator) {\n const errMsg = 'Invalid record keytype'\n\n throw errcode(new Error(errMsg), 'ERR_INVALID_RECORD_KEY_TYPE')\n }\n\n return validator.func(key, record.value)\n}\n\nmodule.exports = {\n verifyRecord: verifyRecord,\n validators: require('./validators')\n}\n","'use strict'\n\nmodule.exports = {\n pk: require('./public-key')\n}\n","'use strict'\n\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst errcode = require('err-code')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\n/**\n * Validator for public key records.\n * Verifies that the passed in record value is the PublicKey\n * that matches the passed in key.\n * If validation fails the returned Promise will reject with the error.\n *\n * @param {Uint8Array} key - A valid key is of the form `'/pk/'`\n * @param {Uint8Array} publicKey - The public key to validate against (protobuf encoded).\n */\nconst validatePublicKeyRecord = async (key, publicKey) => {\n if (!(key instanceof Uint8Array)) {\n throw errcode(new Error('\"key\" must be a Uint8Array'), 'ERR_INVALID_RECORD_KEY_NOT_BUFFER')\n }\n\n if (key.byteLength < 5) {\n throw errcode(new Error('invalid public key record'), 'ERR_INVALID_RECORD_KEY_TOO_SHORT')\n }\n\n const prefix = uint8ArrayToString(key.subarray(0, 4))\n\n if (prefix !== '/pk/') {\n throw errcode(new Error('key was not prefixed with /pk/'), 'ERR_INVALID_RECORD_KEY_BAD_PREFIX')\n }\n\n const keyhash = key.slice(4)\n\n const publicKeyHash = await sha256.digest(publicKey)\n\n if (!uint8ArrayEquals(keyhash, publicKeyHash.bytes)) {\n throw errcode(new Error('public key does not match passed in key'), 'ERR_INVALID_RECORD_HASH_MISMATCH')\n }\n}\n\nmodule.exports = {\n func: validatePublicKeyRecord,\n sign: false\n}\n","'use strict'\n\nconst errcode = require('err-code')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\n/**\n * Select the best record out of the given records.\n *\n * @param {import('libp2p-interfaces/src/types').DhtSelectors} selectors\n * @param {Uint8Array} k\n * @param {Array} records\n */\nconst bestRecord = (selectors, k, records) => {\n if (records.length === 0) {\n const errMsg = 'No records given'\n\n throw errcode(new Error(errMsg), 'ERR_NO_RECORDS_RECEIVED')\n }\n\n const kStr = uint8ArrayToString(k)\n const parts = kStr.split('/')\n\n if (parts.length < 3) {\n const errMsg = 'Record key does not have a selector function'\n\n throw errcode(new Error(errMsg), 'ERR_NO_SELECTOR_FUNCTION_FOR_RECORD_KEY')\n }\n\n const selector = selectors[parts[1].toString()]\n\n if (!selector) {\n const errMsg = `Unrecognized key prefix: ${parts[1]}`\n\n throw errcode(new Error(errMsg), 'ERR_UNRECOGNIZED_KEY_PREFIX')\n }\n\n if (records.length === 1) {\n return 0\n }\n\n return selector(k, records)\n}\n\nmodule.exports = {\n bestRecord: bestRecord,\n selectors: require('./selectors')\n}\n","'use strict'\n\nmodule.exports = {\n pk: require('./public-key')\n}\n","'use strict'\n\n/**\n * Best record selector, for public key records.\n * Simply returns the first record, as all valid public key\n * records are equal.\n *\n * @param {Uint8Array} k\n * @param {Array} records\n */\nconst publicKeySelector = (k, records) => {\n return 0\n}\n\nmodule.exports = publicKeySelector\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar publish = require('./publish.js');\nvar resolve = require('./resolve.js');\nvar index = require('./pubsub/index.js');\n\nclass NameAPI {\n constructor({dns, ipns, repo, codecs, peerId, isOnline, keychain, options}) {\n this.publish = publish.createPublish({\n ipns,\n repo,\n codecs,\n peerId,\n isOnline,\n keychain\n });\n this.resolve = resolve.createResolve({\n dns,\n ipns,\n peerId,\n isOnline,\n options\n });\n this.pubsub = new index.PubSubAPI({\n ipns,\n options\n });\n }\n}\n\nexports.NameAPI = NameAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar parseDuration = require('parse-duration');\nvar crypto = require('libp2p-crypto');\nvar errCode = require('err-code');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar utils$1 = require('./utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar parseDuration__default = /*#__PURE__*/_interopDefaultLegacy(parseDuration);\nvar crypto__default = /*#__PURE__*/_interopDefaultLegacy(crypto);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst log = Object.assign(debug__default['default']('ipfs:name:publish'), { error: debug__default['default']('ipfs:name:publish:error') });\nfunction createPublish({ipns, repo, codecs, peerId, isOnline, keychain}) {\n const lookupKey = async keyName => {\n if (keyName === 'self') {\n return peerId.privKey;\n }\n try {\n const pem = await keychain.exportKey(keyName, 'temp');\n const privateKey = await crypto__default['default'].keys.import(pem, 'temp');\n return privateKey;\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](err, 'ERR_CANNOT_GET_KEY');\n }\n };\n async function publish(value, options = {}) {\n const resolve = !(options.resolve === false);\n const lifetime = options.lifetime || '24h';\n const key = options.key || 'self';\n if (!isOnline()) {\n throw errCode__default['default'](new Error(utils.OFFLINE_ERROR), 'OFFLINE_ERROR');\n }\n try {\n value = utils.normalizePath(value);\n } catch (err) {\n log.error(err);\n throw err;\n }\n let pubLifetime = 0;\n try {\n pubLifetime = parseDuration__default['default'](lifetime) || 0;\n pubLifetime = parseFloat(pubLifetime.toFixed(6));\n } catch (err) {\n log.error(err);\n throw err;\n }\n const results = await Promise.all([\n lookupKey(key),\n resolve ? utils$1.resolvePath({\n ipns,\n repo,\n codecs\n }, value) : Promise.resolve()\n ]);\n const bytes = fromString.fromString(value);\n const result = await ipns.publish(results[0], bytes, pubLifetime);\n return {\n name: result.name,\n value: toString.toString(result.value)\n };\n }\n return withTimeoutOption.withTimeoutOption(publish);\n}\n\nexports.createPublish = createPublish;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar isIpfs = require('is-ipfs');\nvar toCidAndPath = require('ipfs-core-utils/to-cid-and-path');\nvar drain = require('it-drain');\nvar utils = require('../../utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\n\nasync function resolvePath({ipns, repo, codecs}, name, options) {\n if (isIpfs__default['default'].ipnsPath(name)) {\n return ipns.resolve(name);\n }\n const {cid, path} = toCidAndPath.toCidAndPath(name);\n await drain__default['default'](utils.resolve(cid, path || '', codecs, repo, options));\n}\n\nexports.resolvePath = resolvePath;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar mergeOpts = require('merge-options');\nvar cid = require('multiformats/cid');\nvar PeerId = require('peer-id');\nvar isDomain = require('is-domain-name');\nvar toString = require('uint8arrays/to-string');\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar isDomain__default = /*#__PURE__*/_interopDefaultLegacy(isDomain);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = Object.assign(debug__default['default']('ipfs:name:resolve'), { error: debug__default['default']('ipfs:name:resolve:error') });\nconst appendRemainder = (result, remainder) => remainder.length > 0 ? result + '/' + remainder.join('/') : result;\nfunction createResolve({\n dns,\n ipns,\n peerId,\n isOnline,\n options: {offline}\n}) {\n async function* resolve(name, options = {}) {\n options = mergeOptions({\n nocache: false,\n recursive: true\n }, options);\n if (offline && options && options.nocache) {\n throw errCode__default['default'](new Error('cannot specify both offline and nocache'), 'ERR_NOCACHE_AND_OFFLINE');\n }\n if (!name) {\n name = peerId.toB58String();\n }\n if (!name.startsWith('/ipns/')) {\n name = `/ipns/${ name }`;\n }\n const [namespace, hash, ...remainder] = name.slice(1).split('/');\n try {\n if (hash.substring(0, 1) === '1') {\n PeerId__default['default'].parse(hash);\n } else {\n cid.CID.parse(hash);\n }\n } catch (err) {\n if (isDomain__default['default'](hash)) {\n yield appendRemainder(await dns(hash, options), remainder);\n return;\n }\n log.error(err);\n throw errCode__default['default'](new Error('Invalid IPNS name'), 'ERR_IPNS_INVALID_NAME');\n }\n if (!isOnline() && !offline) {\n throw errCode__default['default'](new Error(utils.OFFLINE_ERROR), 'OFFLINE_ERROR');\n }\n const value = await ipns.resolve(`/${ namespace }/${ hash }`, options);\n yield appendRemainder(value instanceof Uint8Array ? toString.toString(value) : value, remainder);\n }\n return withTimeoutOption.withTimeoutOption(resolve);\n}\n\nexports.createResolve = createResolve;\n","'use strict'\n\n// Adapted from RFC 2181 (See section 11)\n//\n// The RFC defines a Domain Name to be at most 255 chars including seperators\n// between labels.\n// Subdomains are labels plus a seperator. A label is a string starting and\n// ending with an alphanum, with dashes allowed in the middle. It is between 1 and 63 chars.\n//\n// We make some assumptions below that go beyond the RFC. We assume the TLD\n// to be at least 2 chars. The regex also allows domains longer than 255 chars,\n// but allows at most 127 subdomains, as assuming a lower-bound of one char per\n// subdomain will yield 252, and adding a TLD of 2 chars sums to 254.\n/*\n(?: // Group 1: This is for subdomain, which is composed of a label and a seperator (length = [1, 63] + 1)\n [a-z0-9]\n (?:\n [a-z0-9\\-]{0,61} // Limited to 61 chars as we have at least two chars if we reach this group (61 + 2 = 63 which is the limit)\n [a-z0-9]\n )?\n \\. // Label seperator\n){0,126} // If we assume the lower-bound of 1 char labels, we can at most have 126 groups before approaching the total limit of 255 chars\n(?: // Group 2: Assume that the TLD is at least 2 chars (for sanity)\n [a-z0-9]\n [a-z0-9\\-]{0,61}\n [a-z0-9]\n)\n\\.? // Some consider a trailing dot to be considered valid as it signifies the root of the domain tree\n */\nvar domainNameRegex = /^(?:[a-z0-9](?:[a-z0-9\\-]{0,61}[a-z0-9])?\\.){0,126}(?:[a-z0-9](?:[a-z0-9\\-]{0,61}[a-z0-9]))\\.?$/i\n\n/**\n * Test whether a string is a valid domain name, optionally checking for a root dot as well\n * @param {String} domainName\n * @param {Boolean} rootDot Check for a root dot eg. 'example.com.'. Defaults to false\n * @return {Boolean}\n */\nmodule.exports = function isDomainName (domainName, rootDot) {\n if (rootDot == null) rootDot = false\n\n if (domainName.length < 2) return false\n if (domainName.length > 255) return false\n\n var lastChar = domainName[domainName.length - 1]\n if (rootDot) {\n if (lastChar !== '.') return false\n } else {\n if (lastChar === '.') return false\n }\n\n return domainNameRegex.test(domainName)\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cancel = require('./cancel.js');\nvar state = require('./state.js');\nvar subs = require('./subs.js');\n\nclass PubSubAPI {\n constructor({ipns, options}) {\n this.cancel = cancel.createCancel({\n ipns,\n options\n });\n this.state = state.createState({\n ipns,\n options\n });\n this.subs = subs.createSubs({\n ipns,\n options\n });\n }\n}\n\nexports.PubSubAPI = PubSubAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createCancel({ipns, options}) {\n const experimental = options.EXPERIMENTAL;\n async function cancel(name, options = {}) {\n const pubsub = utils.getPubsubRouting(ipns, experimental);\n return pubsub.cancel(name, options);\n }\n return withTimeoutOption.withTimeoutOption(cancel);\n}\n\nexports.createCancel = createCancel;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar pubsubDatastore = require('../../../ipns/routing/pubsub-datastore.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction getPubsubRouting(ipns, options) {\n if (!ipns || !(options && options.ipnsPubsub)) {\n throw errCode__default['default'](new Error('IPNS pubsub subsystem is not enabled'), 'ERR_IPNS_PUBSUB_NOT_ENABLED');\n }\n if (ipns.routing instanceof pubsubDatastore.IpnsPubsubDatastore) {\n return ipns.routing;\n }\n const pubsub = (ipns.routing.stores || []).find(s => s instanceof pubsubDatastore.IpnsPubsubDatastore);\n if (!pubsub) {\n throw errCode__default['default'](new Error('IPNS pubsub datastore not found'), 'ERR_PUBSUB_DATASTORE_NOT_FOUND');\n }\n return pubsub;\n}\n\nexports.getPubsubRouting = getPubsubRouting;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createState({ipns, options}) {\n const experimental = options.EXPERIMENTAL;\n async function state(_options = {}) {\n try {\n return { enabled: Boolean(utils.getPubsubRouting(ipns, experimental)) };\n } catch (err) {\n return { enabled: false };\n }\n }\n return withTimeoutOption.withTimeoutOption(state);\n}\n\nexports.createState = createState;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createSubs({ipns, options}) {\n const experimental = options.EXPERIMENTAL;\n async function subs(options = {}) {\n const pubsub = utils.getPubsubRouting(ipns, experimental);\n return pubsub.getSubscriptions(options);\n }\n return withTimeoutOption.withTimeoutOption(subs);\n}\n\nexports.createSubs = createSubs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar Errors = require('datastore-core/errors');\nvar toCidAndPath = require('ipfs-core-utils/to-cid-and-path');\nvar cid = require('multiformats/cid');\nvar TimeoutController = require('timeout-abort-controller');\nvar anySignal = require('any-signal');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar TimeoutController__default = /*#__PURE__*/_interopDefaultLegacy(TimeoutController);\n\nconst ERR_NOT_FOUND = Errors.notFoundError().code;\nconst Format = {\n default: '',\n edges: ' -> '\n};\nfunction createRefs({repo, codecs, resolve, preload}) {\n async function* refs(ipfsPath, options = {}) {\n if (options.maxDepth === 0) {\n return;\n }\n if (options.edges && options.format && options.format !== Format.default) {\n throw new Error('Cannot set edges to true and also specify format');\n }\n options.format = options.edges ? Format.edges : options.format;\n if (typeof options.maxDepth !== 'number') {\n options.maxDepth = options.recursive ? Infinity : 1;\n }\n if (options.timeout) {\n const controller = new TimeoutController__default['default'](options.timeout);\n options.signal = anySignal.anySignal([\n options.signal,\n controller.signal\n ]);\n }\n const rawPaths = Array.isArray(ipfsPath) ? ipfsPath : [ipfsPath];\n const paths = rawPaths.map(p => getFullPath(preload, p, options));\n for (const path of paths) {\n try {\n yield* refsStream(resolve, repo, codecs, path, options);\n } catch (err) {\n yield {\n ref: '',\n err: err.message\n };\n }\n }\n }\n return refs;\n}\nfunction getFullPath(preload, ipfsPath, options) {\n const {cid, path} = toCidAndPath.toCidAndPath(ipfsPath);\n if (options.preload !== false) {\n preload(cid);\n }\n return `/ipfs/${ cid }${ path || '' }`;\n}\nasync function* refsStream(resolve, repo, codecs, path, options) {\n const resPath = await resolve(path, options);\n const {cid} = toCidAndPath.toCidAndPath(resPath);\n const maxDepth = options.maxDepth != null ? options.maxDepth : Infinity;\n const unique = options.unique || false;\n for await (const obj of objectStream(repo, codecs, cid, maxDepth, unique, options)) {\n if (!obj.parent) {\n continue;\n }\n if (obj.isDuplicate) {\n continue;\n }\n yield { ref: formatLink(obj.parent.cid, obj.node.cid, obj.node.name, options.format) };\n }\n}\nfunction formatLink(srcCid, dstCid, linkName = '', format = Format.default) {\n let out = format.replace(//g, srcCid.toString());\n out = out.replace(//g, dstCid.toString());\n out = out.replace(//g, linkName);\n return out;\n}\nasync function* objectStream(repo, codecs, rootCid, maxDepth, uniqueOnly, options) {\n const seen = new Set();\n async function* traverseLevel(parent, depth) {\n const nextLevelDepth = depth + 1;\n if (nextLevelDepth > maxDepth) {\n return;\n }\n try {\n for await (const link of getLinks(repo, codecs, parent.cid, options)) {\n yield {\n parent: parent,\n node: link,\n isDuplicate: uniqueOnly && seen.has(link.cid.toString())\n };\n if (uniqueOnly) {\n seen.add(link.cid.toString());\n }\n yield* traverseLevel(link, nextLevelDepth);\n }\n } catch (err) {\n if (err.code === ERR_NOT_FOUND) {\n err.message = `Could not find object with CID: ${ parent.cid }`;\n }\n throw err;\n }\n }\n yield* traverseLevel({ cid: rootCid }, 0);\n}\nasync function* getLinks(repo, codecs, cid, options) {\n const block = await repo.blocks.get(cid, options);\n const codec = await codecs.getCodec(cid.code);\n const value = codec.decode(block);\n const isDagPb = cid.code === dagPB__namespace.code;\n const base = [];\n for (const [name, cid] of links(value, base)) {\n if (isDagPb) {\n const match = name.match(/^Links\\/(\\d+)\\/Hash$/);\n if (match) {\n const index = Number(match[1]);\n if (index < value.Links.length) {\n yield {\n name: value.Links[index].Name,\n cid\n };\n continue;\n }\n }\n }\n yield {\n name,\n cid\n };\n }\n}\nconst links = function* (source, base) {\n if (source == null) {\n return;\n }\n if (source instanceof Uint8Array) {\n return;\n }\n for (const [key, value] of Object.entries(source)) {\n const path = [\n ...base,\n key\n ];\n if (value != null && typeof value === 'object') {\n if (Array.isArray(value)) {\n for (const [index, element] of value.entries()) {\n const elementPath = [\n ...path,\n index\n ];\n const cid$1 = cid.CID.asCID(element);\n if (cid$1) {\n yield [\n elementPath.join('/'),\n cid$1\n ];\n } else if (typeof element === 'object') {\n yield* links(element, elementPath);\n }\n }\n } else {\n const cid$1 = cid.CID.asCID(value);\n if (cid$1) {\n yield [\n path.join('/'),\n cid$1\n ];\n } else {\n yield* links(value, path);\n }\n }\n }\n }\n return [];\n};\n\nexports.Format = Format;\nexports.createRefs = createRefs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createLocal({repo}) {\n async function* refsLocal(options = {}) {\n for await (const cid of repo.blocks.queryKeys({}, { signal: options.signal })) {\n yield { ref: cid.toString() };\n }\n }\n return withTimeoutOption.withTimeoutOption(refsLocal);\n}\n\nexports.createLocal = createLocal;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar wantlist = require('./wantlist.js');\nvar wantlistForPeer = require('./wantlist-for-peer.js');\nvar unwant = require('./unwant.js');\nvar stat = require('./stat.js');\n\nclass BitswapAPI {\n constructor({network}) {\n this.wantlist = wantlist.createWantlist({ network });\n this.wantlistForPeer = wantlistForPeer.createWantlistForPeer({ network });\n this.unwant = unwant.createUnwant({ network });\n this.stat = stat.createStat({ network });\n }\n}\n\nexports.BitswapAPI = BitswapAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createWantlist({network}) {\n async function wantlist(options = {}) {\n const {bitswap} = await network.use(options);\n const list = bitswap.getWantlist();\n return Array.from(list).map(e => e[1].cid);\n }\n return withTimeoutOption.withTimeoutOption(wantlist);\n}\n\nexports.createWantlist = createWantlist;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\n\nfunction createWantlistForPeer({network}) {\n async function wantlistForPeer(peerId, options = {}) {\n const {bitswap} = await network.use(options);\n const list = bitswap.wantlistForPeer(PeerId__default['default'].createFromB58String(peerId));\n return Array.from(list).map(e => e[1].cid);\n }\n return withTimeoutOption.withTimeoutOption(wantlistForPeer);\n}\n\nexports.createWantlistForPeer = createWantlistForPeer;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createUnwant({network}) {\n async function unwant(cids, options = {}) {\n const {bitswap} = await network.use(options);\n if (!Array.isArray(cids)) {\n cids = [cids];\n }\n return bitswap.unwant(cids);\n }\n return withTimeoutOption.withTimeoutOption(unwant);\n}\n\nexports.createUnwant = createUnwant;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createStat({network}) {\n async function stat(options = {}) {\n const bitswap = (await network.use(options)).bitswap;\n const snapshot = bitswap.stat().snapshot;\n return {\n provideBufLen: parseInt(snapshot.providesBufferLength.toString()),\n blocksReceived: BigInt(snapshot.blocksReceived.toString()),\n wantlist: Array.from(bitswap.getWantlist()).map(e => e[1].cid),\n peers: bitswap.peers().map(id => id.toB58String()),\n dupBlksReceived: BigInt(snapshot.dupBlksReceived.toString()),\n dupDataReceived: BigInt(snapshot.dupDataReceived.toString()),\n dataReceived: BigInt(snapshot.dataReceived.toString()),\n blocksSent: BigInt(snapshot.blocksSent.toString()),\n dataSent: BigInt(snapshot.dataSent.toString())\n };\n }\n return withTimeoutOption.withTimeoutOption(stat);\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar add = require('./add.js');\nvar clear = require('./clear.js');\nvar list = require('./list.js');\nvar reset = require('./reset.js');\nvar rm = require('./rm.js');\n\nclass BootstrapAPI {\n constructor({repo}) {\n this.add = add.createAdd({ repo });\n this.list = list.createList({ repo });\n this.rm = rm.createRm({ repo });\n this.clear = clear.createClear({ repo });\n this.reset = reset.createReset({ repo });\n }\n}\n\nexports.BootstrapAPI = BootstrapAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createAdd({repo}) {\n async function add(multiaddr, options = {}) {\n if (!utils.isValidMultiaddr(multiaddr)) {\n throw new Error(`${ multiaddr } is not a valid Multiaddr`);\n }\n const config = await repo.config.getAll(options);\n const boostrappers = config.Bootstrap || [];\n boostrappers.push(multiaddr.toString());\n config.Bootstrap = Array.from(new Set(boostrappers)).sort((a, b) => a.localeCompare(b));\n await repo.config.replace(config);\n return { Peers: [multiaddr] };\n }\n return withTimeoutOption.withTimeoutOption(add);\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mafmt = require('mafmt');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mafmt__default = /*#__PURE__*/_interopDefaultLegacy(mafmt);\n\nfunction isValidMultiaddr(ma) {\n try {\n return mafmt__default['default'].IPFS.matches(ma);\n } catch (err) {\n return false;\n }\n}\n\nexports.isValidMultiaddr = isValidMultiaddr;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar multiaddr = require('multiaddr');\n\nfunction createClear({repo}) {\n async function clear(options = {}) {\n const config = await repo.config.getAll(options);\n const removed = config.Bootstrap || [];\n config.Bootstrap = [];\n await repo.config.replace(config);\n return { Peers: removed.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return withTimeoutOption.withTimeoutOption(clear);\n}\n\nexports.createClear = createClear;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar multiaddr = require('multiaddr');\n\nfunction createList({repo}) {\n async function list(options = {}) {\n const peers = await repo.config.get('Bootstrap', options);\n return { Peers: (peers || []).map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return withTimeoutOption.withTimeoutOption(list);\n}\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar getDefaultConfig = require('ipfs-core-config/config');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar multiaddr = require('multiaddr');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar getDefaultConfig__default = /*#__PURE__*/_interopDefaultLegacy(getDefaultConfig);\n\nfunction createReset({repo}) {\n async function reset(options = {}) {\n const config = await repo.config.getAll(options);\n config.Bootstrap = getDefaultConfig__default['default']().Bootstrap;\n await repo.config.replace(config);\n return { Peers: getDefaultConfig__default['default']().Bootstrap.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return withTimeoutOption.withTimeoutOption(reset);\n}\n\nexports.createReset = createReset;\n","'use strict';\n\nvar config_browser = () => ({\n Addresses: {\n Swarm: [],\n Announce: [],\n NoAnnounce: [],\n API: '',\n Gateway: '',\n RPC: '',\n Delegates: [\n '/dns4/node0.delegate.ipfs.io/tcp/443/https',\n '/dns4/node1.delegate.ipfs.io/tcp/443/https',\n '/dns4/node2.delegate.ipfs.io/tcp/443/https',\n '/dns4/node3.delegate.ipfs.io/tcp/443/https'\n ]\n },\n Discovery: {\n MDNS: {\n Enabled: false,\n Interval: 10\n },\n webRTCStar: { Enabled: true }\n },\n Bootstrap: [\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmNnooDu7bfjPFoTZYxMNLWUQJyrVwtbZg5gBMjTezGAJN',\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmbLHAnMoJPWSCR5Zhtx6BHJX9KiKNN6tpvbUcqanj75Nb',\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmZa1sAxajnQjVM8WjWXoMbmPd7NsWhfKsPkErzpm9wGkp',\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmQCU2EcMqAqQPR2i9bChDtGNJchTbq5TbXJJ16u19uLTa',\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmcZf59bWwK5XFi76CZX8cbJ4BhTzzA3gU1ZjYZcYW3dwt',\n '/dns4/node0.preload.ipfs.io/tcp/443/wss/p2p/QmZMxNdpMkewiVZLMRxaNxUeZpDUb34pWjZ1kZvsd16Zic',\n '/dns4/node1.preload.ipfs.io/tcp/443/wss/p2p/Qmbut9Ywz9YEDrz8ySBSgWyJk41Uvm2QJPhwDJzJyGFsD6',\n '/dns4/node2.preload.ipfs.io/tcp/443/wss/p2p/QmV7gnbW5VTcJ3oyM2Xk1rdFBJ3kTkvxc87UFGsun29STS',\n '/dns4/node3.preload.ipfs.io/tcp/443/wss/p2p/QmY7JB6MQXhxHvq7dBDh4HpbH29v4yE9JRadAVpndvzySN'\n ],\n Pubsub: { Enabled: true },\n Swarm: {\n ConnMgr: {\n LowWater: 200,\n HighWater: 500\n },\n DisableNatPortMap: true\n },\n Routing: { Type: 'none' }\n});\n\nmodule.exports = config_browser;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createRm({repo}) {\n async function rm(multiaddr, options = {}) {\n if (!utils.isValidMultiaddr(multiaddr)) {\n throw new Error(`${ multiaddr } is not a valid Multiaddr`);\n }\n const config = await repo.config.getAll(options);\n config.Bootstrap = (config.Bootstrap || []).filter(ma => ma.toString() !== multiaddr.toString());\n await repo.config.replace(config);\n return { Peers: [multiaddr] };\n }\n return withTimeoutOption.withTimeoutOption(rm);\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar get = require('./get.js');\nvar put = require('./put.js');\nvar rm = require('./rm.js');\nvar stat = require('./stat.js');\n\nclass BlockAPI {\n constructor({codecs, hashers, preload, repo}) {\n this.get = get.createGet({\n preload,\n repo\n });\n this.put = put.createPut({\n codecs,\n hashers,\n preload,\n repo\n });\n this.rm = rm.createRm({ repo });\n this.stat = stat.createStat({\n preload,\n repo\n });\n }\n}\n\nexports.BlockAPI = BlockAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createGet({preload, repo}) {\n async function get(cid, options = {}) {\n if (options.preload !== false) {\n preload(cid);\n }\n return repo.blocks.get(cid, options);\n }\n return withTimeoutOption.withTimeoutOption(get);\n}\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createPut({codecs, hashers, repo, preload}) {\n async function put(block, options = {}) {\n const release = options.pin ? await repo.gcLock.readLock() : null;\n try {\n const cidVersion = options.version != null ? options.version : 0;\n const codecName = options.format || (cidVersion === 0 ? 'dag-pb' : 'raw');\n const hasher = await hashers.getHasher(options.mhtype || 'sha2-256');\n const hash = await hasher.digest(block);\n const codec = await codecs.getCodec(codecName);\n const cid$1 = cid.CID.create(cidVersion, codec.code, hash);\n await repo.blocks.put(cid$1, block, { signal: options.signal });\n if (options.preload !== false) {\n preload(cid$1);\n }\n if (options.pin === true) {\n await repo.pins.pinRecursively(cid$1, { signal: options.signal });\n }\n return cid$1;\n } finally {\n if (release) {\n release();\n }\n }\n }\n return withTimeoutOption.withTimeoutOption(put);\n}\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar parallel = require('it-parallel');\nvar map = require('it-map');\nvar filter = require('it-filter');\nvar itPipe = require('it-pipe');\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar parallel__default = /*#__PURE__*/_interopDefaultLegacy(parallel);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\n\nconst BLOCK_RM_CONCURRENCY = 8;\nfunction createRm({repo}) {\n async function* rm(cids, options = {}) {\n if (!Array.isArray(cids)) {\n cids = [cids];\n }\n const release = await repo.gcLock.writeLock();\n try {\n yield* itPipe.pipe(cids, source => map__default['default'](source, cid => {\n return async () => {\n cid = utils.cleanCid(cid);\n const result = { cid };\n try {\n const has = await repo.blocks.has(cid);\n if (!has) {\n throw errCode__default['default'](new Error('block not found'), 'ERR_BLOCK_NOT_FOUND');\n }\n await repo.blocks.delete(cid);\n } catch (err) {\n if (!options.force) {\n err.message = `cannot remove ${ cid }: ${ err.message }`;\n result.error = err;\n }\n }\n return result;\n };\n }), source => parallel__default['default'](source, BLOCK_RM_CONCURRENCY), source => filter__default['default'](source, () => !options.quiet));\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(rm);\n}\n\nexports.createRm = createRm;\n","'use strict'\n\nconst defer = require('p-defer')\nconst EventEmitter = require('events').EventEmitter\n\n/**\n * Takes an (async) iterator that emits promise-returning functions,\n * invokes them in parallel and emits the results as they become available but\n * in the same order as the input\n *\n * @template T\n * @param {Iterable<() => Promise> | AsyncIterable<() => Promise>} source\n * @param {number} [concurrency=1]\n * @returns {AsyncIterable}\n */\nasync function * parallel (source, concurrency = 1) {\n if (concurrency < 1) {\n concurrency = 1\n }\n\n const emitter = new EventEmitter()\n\n /** @type {any[]} */\n const ops = []\n let slotAvailable = defer()\n let sourceFinished = false\n\n let resultAvailable = defer()\n\n emitter.on('task-complete', () => {\n resultAvailable.resolve()\n resultAvailable = defer()\n })\n\n Promise.resolve().then(async () => {\n try {\n for await (const task of source) {\n if (ops.length === concurrency) {\n await slotAvailable.promise\n }\n\n /**\n * @type {any}\n */\n const op = {\n done: false\n }\n ops.push(op)\n\n task()\n .then(result => {\n op.done = true\n op.ok = true\n op.value = result\n emitter.emit('task-complete')\n }, err => {\n op.done = true\n op.err = err\n emitter.emit('task-complete')\n })\n }\n\n sourceFinished = true\n } catch (err) {\n emitter.emit('task-complete')\n }\n })\n\n while (true) {\n await resultAvailable.promise\n\n while (ops.length && ops[0].done) {\n const op = ops[0]\n ops.shift()\n\n if (op.ok) {\n yield op.value\n } else {\n throw op.err\n }\n\n slotAvailable.resolve()\n slotAvailable = defer()\n }\n\n if (sourceFinished && ops.length === 0) {\n // not waiting for any results and no more tasks so we are done\n break\n }\n }\n}\n\nmodule.exports = parallel\n","'use strict';\n\nconst pDefer = () => {\n\tconst deferred = {};\n\n\tdeferred.promise = new Promise((resolve, reject) => {\n\t\tdeferred.resolve = resolve;\n\t\tdeferred.reject = reject;\n\t});\n\n\treturn deferred;\n};\n\nmodule.exports = pDefer;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n };\n\n eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n }\n });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\n\nfunction cleanCid(cid$1) {\n if (cid$1 instanceof Uint8Array) {\n return cid.CID.decode(cid$1);\n }\n return cid.CID.parse(cid$1.toString());\n}\n\nexports.cleanCid = cleanCid;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createStat({repo, preload}) {\n async function stat(cid, options = {}) {\n cid = utils.cleanCid(cid);\n if (options.preload !== false) {\n preload(cid);\n }\n const block = await repo.blocks.get(cid);\n return {\n cid,\n size: block.length\n };\n }\n return withTimeoutOption.withTimeoutOption(stat);\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar add = require('./add.js');\nvar index = require('./add-all/index.js');\nvar cat = require('./cat.js');\nvar get = require('./get.js');\nvar ls = require('./ls.js');\n\nclass RootAPI {\n constructor({preload, repo, options}) {\n const addAll = index.createAddAll({\n preload,\n repo,\n options\n });\n this.addAll = addAll;\n this.add = add.createAdd({ addAll });\n this.cat = cat.createCat({\n repo,\n preload\n });\n this.get = get.createGet({\n repo,\n preload\n });\n this.ls = ls.createLs({\n repo,\n preload\n });\n }\n}\n\nexports.RootAPI = RootAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar last = require('it-last');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createAdd({addAll}) {\n async function add(entry, options = {}) {\n const result = await last__default['default'](addAll(entry, options));\n if (result == null) {\n throw Error('Failed to add a file, if you see this please report a bug');\n }\n return result;\n }\n return add;\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsImporter = require('ipfs-unixfs-importer');\nvar normaliseInput = require('ipfs-core-utils/files/normalise-input');\nvar utils = require('./utils.js');\nvar itPipe = require('it-pipe');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar mergeOpts = require('merge-options');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nfunction createAddAll({repo, preload, options}) {\n const isShardingEnabled = options && options.sharding;\n async function* addAll(source, options = {}) {\n const opts = mergeOptions({\n shardSplitThreshold: isShardingEnabled ? 1000 : Infinity,\n strategy: 'balanced'\n }, options, { ...utils.parseChunkerString(options.chunker) });\n if (opts.hashAlg && opts.hashAlg !== 'sha2-256' && opts.cidVersion !== 1) {\n opts.cidVersion = 1;\n }\n if (opts.trickle) {\n opts.strategy = 'trickle';\n }\n if (opts.strategy === 'trickle') {\n opts.leafType = 'raw';\n opts.reduceSingleLeafToSelf = false;\n }\n if (opts.cidVersion > 0 && opts.rawLeaves === undefined) {\n opts.rawLeaves = true;\n }\n if (opts.hashAlg !== undefined && opts.rawLeaves === undefined) {\n opts.rawLeaves = true;\n }\n delete opts.trickle;\n const totals = {};\n if (opts.progress) {\n const prog = opts.progress;\n opts.progress = (bytes, path) => {\n if (!totals[path]) {\n totals[path] = 0;\n }\n totals[path] += bytes;\n prog(totals[path], path);\n };\n }\n const iterator = itPipe.pipe(normaliseInput.normaliseInput(source), source => ipfsUnixfsImporter.importer(source, repo.blocks, {\n ...opts,\n pin: false\n }), transformFile(opts), preloadFile(preload, opts), pinFile(repo, opts));\n const releaseLock = await repo.gcLock.readLock();\n try {\n for await (const added of iterator) {\n delete totals[added.path];\n yield added;\n }\n } finally {\n releaseLock();\n }\n }\n return withTimeoutOption.withTimeoutOption(addAll);\n}\nfunction transformFile(opts) {\n async function* transformFile(source) {\n for await (const file of source) {\n let cid = file.cid;\n if (opts.cidVersion === 1) {\n cid = cid.toV1();\n }\n let path = file.path ? file.path : cid.toString();\n if (opts.wrapWithDirectory && !file.path) {\n path = '';\n }\n yield {\n path,\n cid: cid,\n size: file.size,\n mode: file.unixfs && file.unixfs.mode,\n mtime: file.unixfs && file.unixfs.mtime\n };\n }\n }\n return transformFile;\n}\nfunction preloadFile(preload, opts) {\n async function* maybePreloadFile(source) {\n for await (const file of source) {\n const isRootFile = !file.path || opts.wrapWithDirectory ? file.path === '' : !file.path.includes('/');\n const shouldPreload = isRootFile && !opts.onlyHash && opts.preload !== false;\n if (shouldPreload) {\n preload(file.cid);\n }\n yield file;\n }\n }\n return maybePreloadFile;\n}\nfunction pinFile(repo, opts) {\n async function* maybePinFile(source) {\n for await (const file of source) {\n const isRootDir = !(file.path && file.path.includes('/'));\n const shouldPin = (opts.pin == null ? true : opts.pin) && isRootDir && !opts.onlyHash;\n if (shouldPin) {\n await repo.pins.pinRecursively(file.cid);\n }\n yield file;\n }\n }\n return maybePinFile;\n}\n\nexports.createAddAll = createAddAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar parallelBatch = require('it-parallel-batch');\nvar options = require('./options.js');\nvar index = require('./dag-builder/index.js');\nvar treeBuilder = require('./tree-builder.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar parallelBatch__default = /*#__PURE__*/_interopDefaultLegacy(parallelBatch);\n\nasync function* importer(source, blockstore, options$1 = {}) {\n const opts = options(options$1);\n let dagBuilder;\n if (typeof options$1.dagBuilder === 'function') {\n dagBuilder = options$1.dagBuilder;\n } else {\n dagBuilder = index;\n }\n let treeBuilder$1;\n if (typeof options$1.treeBuilder === 'function') {\n treeBuilder$1 = options$1.treeBuilder;\n } else {\n treeBuilder$1 = treeBuilder;\n }\n let candidates;\n if (Symbol.asyncIterator in source || Symbol.iterator in source) {\n candidates = source;\n } else {\n candidates = [source];\n }\n for await (const entry of treeBuilder$1(parallelBatch__default['default'](dagBuilder(candidates, blockstore, opts), opts.fileImportConcurrency), blockstore, opts)) {\n yield {\n cid: entry.cid,\n path: entry.path,\n unixfs: entry.unixfs,\n size: entry.size\n };\n }\n}\n\nexports.importer = importer;\n","'use strict'\n\nconst batch = require('it-batch')\n\n/**\n * @template T\n * @typedef {{ok:true, value:T}} Success\n */\n\n/**\n * @typedef {{ok:false, err:Error}} Failure\n */\n\n/**\n * Takes an (async) iterator that emits promise-returning functions,\n * invokes them in parallel and emits the results as they become available but\n * in the same order as the input\n *\n * @template T\n * @param {AsyncIterable<() => Promise>} source\n * @param {number} [size=1]\n * @returns {AsyncIterable}\n */\nasync function * parallelBatch (source, size = 1) {\n for await (const tasks of batch(source, size)) {\n /** @type {Promise|Failure>[]} */\n const things = tasks.map(\n /**\n * @param {() => Promise} p\n */\n p => {\n return p().then(value => ({ ok: true, value }), err => ({ ok: false, err }))\n })\n\n for (let i = 0; i < things.length; i++) {\n const result = await things[i]\n\n if (result.ok) {\n yield result.value\n } else {\n throw result.err\n }\n }\n }\n}\n\nmodule.exports = parallelBatch\n","'use strict'\n\n/**\n * Takes an (async) iterable that emits things and returns an async iterable that\n * emits those things in fixed-sized batches.\n *\n * @template T\n * @param {AsyncIterable|Iterable} source\n * @param {number} [size=1]\n * @returns {AsyncIterable}\n */\nasync function * batch (source, size = 1) {\n /** @type {T[]} */\n let things = []\n\n if (size < 1) {\n size = 1\n }\n\n for await (const thing of source) {\n things.push(thing)\n\n while (things.length >= size) {\n yield things.slice(0, size)\n\n things = things.slice(size)\n }\n }\n\n while (things.length) {\n yield things.slice(0, size)\n\n things = things.slice(size)\n }\n}\n\nmodule.exports = batch\n","'use strict';\n\nvar mergeOptions = require('merge-options');\nvar sha2 = require('multiformats/hashes/sha2');\nvar murmur3 = require('@multiformats/murmur3');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOptions__default = /*#__PURE__*/_interopDefaultLegacy(mergeOptions);\n\nasync function hamtHashFn(buf) {\n return (await murmur3.murmur3128.encode(buf)).slice(0, 8).reverse();\n}\nconst defaultOptions = {\n chunker: 'fixed',\n strategy: 'balanced',\n rawLeaves: false,\n onlyHash: false,\n reduceSingleLeafToSelf: true,\n hasher: sha2.sha256,\n leafType: 'file',\n cidVersion: 0,\n progress: () => () => {\n },\n shardSplitThreshold: 1000,\n fileImportConcurrency: 50,\n blockWriteConcurrency: 10,\n minChunkSize: 262144,\n maxChunkSize: 262144,\n avgChunkSize: 262144,\n window: 16,\n polynomial: 17437180132763652,\n maxChildrenPerNode: 174,\n layerRepeat: 4,\n wrapWithDirectory: false,\n recursive: false,\n hidden: false,\n timeout: undefined,\n hamtHashFn,\n hamtHashCode: 34,\n hamtBucketBits: 8\n};\nvar defaultOptions$1 = (options = {}) => {\n const defaults = mergeOptions__default['default'].bind({ ignoreUndefined: true });\n return defaults(defaultOptions, options);\n};\n\nmodule.exports = defaultOptions$1;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hasher = require('multiformats/hashes/hasher');\nvar multiformats = require('multiformats');\nvar mur = require('murmurhash3js-revisited');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mur__default = /*#__PURE__*/_interopDefaultLegacy(mur);\n\nfunction fromNumberTo32BitBuf(number) {\n const bytes = new Array(4);\n for (let i = 0; i < 4; i++) {\n bytes[i] = number & 255;\n number = number >> 8;\n }\n return new Uint8Array(bytes);\n}\nconst murmur332 = hasher.from({\n name: 'murmur3-32',\n code: 35,\n encode: input => fromNumberTo32BitBuf(mur__default[\"default\"].x86.hash32(input))\n});\nconst murmur3128 = hasher.from({\n name: 'murmur3-128',\n code: 34,\n encode: input => multiformats.bytes.fromHex(mur__default[\"default\"].x64.hash128(input))\n});\n\nexports.murmur3128 = murmur3128;\nexports.murmur332 = murmur332;\n","module.exports = require('./lib/murmurHash3js');\n","/* jshint -W086: true */\n// +----------------------------------------------------------------------+\n// | murmurHash3js.js v3.0.1 // https://github.com/pid/murmurHash3js\n// | A javascript implementation of MurmurHash3's x86 hashing algorithms. |\n// |----------------------------------------------------------------------|\n// | Copyright (c) 2012-2015 Karan Lyons |\n// | https://github.com/karanlyons/murmurHash3.js/blob/c1778f75792abef7bdd74bc85d2d4e1a3d25cfe9/murmurHash3.js |\n// | Freely distributable under the MIT license. |\n// +----------------------------------------------------------------------+\n\n;(function (root, undefined) {\n 'use strict';\n\n // Create a local object that'll be exported or referenced globally.\n var library = {\n 'version': '3.0.0',\n 'x86': {},\n 'x64': {},\n 'inputValidation': true\n };\n\n // PRIVATE FUNCTIONS\n // -----------------\n\n function _validBytes(bytes) {\n // check the input is an array or a typed array\n if (!Array.isArray(bytes) && !ArrayBuffer.isView(bytes)) {\n return false;\n }\n\n // check all bytes are actually bytes\n for (var i = 0; i < bytes.length; i++) {\n if (!Number.isInteger(bytes[i]) || bytes[i] < 0 || bytes[i] > 255) {\n return false;\n }\n }\n return true;\n }\n\n function _x86Multiply(m, n) {\n //\n // Given two 32bit ints, returns the two multiplied together as a\n // 32bit int.\n //\n\n return ((m & 0xffff) * n) + ((((m >>> 16) * n) & 0xffff) << 16);\n }\n\n function _x86Rotl(m, n) {\n //\n // Given a 32bit int and an int representing a number of bit positions,\n // returns the 32bit int rotated left by that number of positions.\n //\n\n return (m << n) | (m >>> (32 - n));\n }\n\n function _x86Fmix(h) {\n //\n // Given a block, returns murmurHash3's final x86 mix of that block.\n //\n\n h ^= h >>> 16;\n h = _x86Multiply(h, 0x85ebca6b);\n h ^= h >>> 13;\n h = _x86Multiply(h, 0xc2b2ae35);\n h ^= h >>> 16;\n\n return h;\n }\n\n function _x64Add(m, n) {\n //\n // Given two 64bit ints (as an array of two 32bit ints) returns the two\n // added together as a 64bit int (as an array of two 32bit ints).\n //\n\n m = [m[0] >>> 16, m[0] & 0xffff, m[1] >>> 16, m[1] & 0xffff];\n n = [n[0] >>> 16, n[0] & 0xffff, n[1] >>> 16, n[1] & 0xffff];\n var o = [0, 0, 0, 0];\n\n o[3] += m[3] + n[3];\n o[2] += o[3] >>> 16;\n o[3] &= 0xffff;\n\n o[2] += m[2] + n[2];\n o[1] += o[2] >>> 16;\n o[2] &= 0xffff;\n\n o[1] += m[1] + n[1];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n\n o[0] += m[0] + n[0];\n o[0] &= 0xffff;\n\n return [(o[0] << 16) | o[1], (o[2] << 16) | o[3]];\n }\n\n function _x64Multiply(m, n) {\n //\n // Given two 64bit ints (as an array of two 32bit ints) returns the two\n // multiplied together as a 64bit int (as an array of two 32bit ints).\n //\n\n m = [m[0] >>> 16, m[0] & 0xffff, m[1] >>> 16, m[1] & 0xffff];\n n = [n[0] >>> 16, n[0] & 0xffff, n[1] >>> 16, n[1] & 0xffff];\n var o = [0, 0, 0, 0];\n\n o[3] += m[3] * n[3];\n o[2] += o[3] >>> 16;\n o[3] &= 0xffff;\n\n o[2] += m[2] * n[3];\n o[1] += o[2] >>> 16;\n o[2] &= 0xffff;\n\n o[2] += m[3] * n[2];\n o[1] += o[2] >>> 16;\n o[2] &= 0xffff;\n\n o[1] += m[1] * n[3];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n\n o[1] += m[2] * n[2];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n\n o[1] += m[3] * n[1];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n\n o[0] += (m[0] * n[3]) + (m[1] * n[2]) + (m[2] * n[1]) + (m[3] * n[0]);\n o[0] &= 0xffff;\n\n return [(o[0] << 16) | o[1], (o[2] << 16) | o[3]];\n }\n\n function _x64Rotl(m, n) {\n //\n // Given a 64bit int (as an array of two 32bit ints) and an int\n // representing a number of bit positions, returns the 64bit int (as an\n // array of two 32bit ints) rotated left by that number of positions.\n //\n\n n %= 64;\n\n if (n === 32) {\n return [m[1], m[0]];\n } else if (n < 32) {\n return [(m[0] << n) | (m[1] >>> (32 - n)), (m[1] << n) | (m[0] >>> (32 - n))];\n } else {\n n -= 32;\n return [(m[1] << n) | (m[0] >>> (32 - n)), (m[0] << n) | (m[1] >>> (32 - n))];\n }\n }\n\n function _x64LeftShift(m, n) {\n //\n // Given a 64bit int (as an array of two 32bit ints) and an int\n // representing a number of bit positions, returns the 64bit int (as an\n // array of two 32bit ints) shifted left by that number of positions.\n //\n\n n %= 64;\n\n if (n === 0) {\n return m;\n } else if (n < 32) {\n return [(m[0] << n) | (m[1] >>> (32 - n)), m[1] << n];\n } else {\n return [m[1] << (n - 32), 0];\n }\n }\n\n function _x64Xor(m, n) {\n //\n // Given two 64bit ints (as an array of two 32bit ints) returns the two\n // xored together as a 64bit int (as an array of two 32bit ints).\n //\n\n return [m[0] ^ n[0], m[1] ^ n[1]];\n }\n\n function _x64Fmix(h) {\n //\n // Given a block, returns murmurHash3's final x64 mix of that block.\n // (`[0, h[0] >>> 1]` is a 33 bit unsigned right shift. This is the\n // only place where we need to right shift 64bit ints.)\n //\n\n h = _x64Xor(h, [0, h[0] >>> 1]);\n h = _x64Multiply(h, [0xff51afd7, 0xed558ccd]);\n h = _x64Xor(h, [0, h[0] >>> 1]);\n h = _x64Multiply(h, [0xc4ceb9fe, 0x1a85ec53]);\n h = _x64Xor(h, [0, h[0] >>> 1]);\n\n return h;\n }\n\n // PUBLIC FUNCTIONS\n // ----------------\n\n library.x86.hash32 = function (bytes, seed) {\n //\n // Given a string and an optional seed as an int, returns a 32 bit hash\n // using the x86 flavor of MurmurHash3, as an unsigned int.\n //\n if (library.inputValidation && !_validBytes(bytes)) {\n return undefined;\n }\n seed = seed || 0;\n\n var remainder = bytes.length % 4;\n var blocks = bytes.length - remainder;\n\n var h1 = seed;\n\n var k1 = 0;\n\n var c1 = 0xcc9e2d51;\n var c2 = 0x1b873593;\n\n for (var i = 0; i < blocks; i = i + 4) {\n k1 = (bytes[i]) | (bytes[i + 1] << 8) | (bytes[i + 2] << 16) | (bytes[i + 3] << 24);\n\n k1 = _x86Multiply(k1, c1);\n k1 = _x86Rotl(k1, 15);\n k1 = _x86Multiply(k1, c2);\n\n h1 ^= k1;\n h1 = _x86Rotl(h1, 13);\n h1 = _x86Multiply(h1, 5) + 0xe6546b64;\n }\n\n k1 = 0;\n\n switch (remainder) {\n case 3:\n k1 ^= bytes[i + 2] << 16;\n\n case 2:\n k1 ^= bytes[i + 1] << 8;\n\n case 1:\n k1 ^= bytes[i];\n k1 = _x86Multiply(k1, c1);\n k1 = _x86Rotl(k1, 15);\n k1 = _x86Multiply(k1, c2);\n h1 ^= k1;\n }\n\n h1 ^= bytes.length;\n h1 = _x86Fmix(h1);\n\n return h1 >>> 0;\n };\n\n library.x86.hash128 = function (bytes, seed) {\n //\n // Given a string and an optional seed as an int, returns a 128 bit\n // hash using the x86 flavor of MurmurHash3, as an unsigned hex.\n //\n if (library.inputValidation && !_validBytes(bytes)) {\n return undefined;\n }\n\n seed = seed || 0;\n var remainder = bytes.length % 16;\n var blocks = bytes.length - remainder;\n\n var h1 = seed;\n var h2 = seed;\n var h3 = seed;\n var h4 = seed;\n\n var k1 = 0;\n var k2 = 0;\n var k3 = 0;\n var k4 = 0;\n\n var c1 = 0x239b961b;\n var c2 = 0xab0e9789;\n var c3 = 0x38b34ae5;\n var c4 = 0xa1e38b93;\n\n for (var i = 0; i < blocks; i = i + 16) {\n k1 = (bytes[i]) | (bytes[i + 1] << 8) | (bytes[i + 2] << 16) | (bytes[i + 3] << 24);\n k2 = (bytes[i + 4]) | (bytes[i + 5] << 8) | (bytes[i + 6] << 16) | (bytes[i + 7] << 24);\n k3 = (bytes[i + 8]) | (bytes[i + 9] << 8) | (bytes[i + 10] << 16) | (bytes[i + 11] << 24);\n k4 = (bytes[i + 12]) | (bytes[i + 13] << 8) | (bytes[i + 14] << 16) | (bytes[i + 15] << 24);\n\n k1 = _x86Multiply(k1, c1);\n k1 = _x86Rotl(k1, 15);\n k1 = _x86Multiply(k1, c2);\n h1 ^= k1;\n\n h1 = _x86Rotl(h1, 19);\n h1 += h2;\n h1 = _x86Multiply(h1, 5) + 0x561ccd1b;\n\n k2 = _x86Multiply(k2, c2);\n k2 = _x86Rotl(k2, 16);\n k2 = _x86Multiply(k2, c3);\n h2 ^= k2;\n\n h2 = _x86Rotl(h2, 17);\n h2 += h3;\n h2 = _x86Multiply(h2, 5) + 0x0bcaa747;\n\n k3 = _x86Multiply(k3, c3);\n k3 = _x86Rotl(k3, 17);\n k3 = _x86Multiply(k3, c4);\n h3 ^= k3;\n\n h3 = _x86Rotl(h3, 15);\n h3 += h4;\n h3 = _x86Multiply(h3, 5) + 0x96cd1c35;\n\n k4 = _x86Multiply(k4, c4);\n k4 = _x86Rotl(k4, 18);\n k4 = _x86Multiply(k4, c1);\n h4 ^= k4;\n\n h4 = _x86Rotl(h4, 13);\n h4 += h1;\n h4 = _x86Multiply(h4, 5) + 0x32ac3b17;\n }\n\n k1 = 0;\n k2 = 0;\n k3 = 0;\n k4 = 0;\n\n switch (remainder) {\n case 15:\n k4 ^= bytes[i + 14] << 16;\n\n case 14:\n k4 ^= bytes[i + 13] << 8;\n\n case 13:\n k4 ^= bytes[i + 12];\n k4 = _x86Multiply(k4, c4);\n k4 = _x86Rotl(k4, 18);\n k4 = _x86Multiply(k4, c1);\n h4 ^= k4;\n\n case 12:\n k3 ^= bytes[i + 11] << 24;\n\n case 11:\n k3 ^= bytes[i + 10] << 16;\n\n case 10:\n k3 ^= bytes[i + 9] << 8;\n\n case 9:\n k3 ^= bytes[i + 8];\n k3 = _x86Multiply(k3, c3);\n k3 = _x86Rotl(k3, 17);\n k3 = _x86Multiply(k3, c4);\n h3 ^= k3;\n\n case 8:\n k2 ^= bytes[i + 7] << 24;\n\n case 7:\n k2 ^= bytes[i + 6] << 16;\n\n case 6:\n k2 ^= bytes[i + 5] << 8;\n\n case 5:\n k2 ^= bytes[i + 4];\n k2 = _x86Multiply(k2, c2);\n k2 = _x86Rotl(k2, 16);\n k2 = _x86Multiply(k2, c3);\n h2 ^= k2;\n\n case 4:\n k1 ^= bytes[i + 3] << 24;\n\n case 3:\n k1 ^= bytes[i + 2] << 16;\n\n case 2:\n k1 ^= bytes[i + 1] << 8;\n\n case 1:\n k1 ^= bytes[i];\n k1 = _x86Multiply(k1, c1);\n k1 = _x86Rotl(k1, 15);\n k1 = _x86Multiply(k1, c2);\n h1 ^= k1;\n }\n\n h1 ^= bytes.length;\n h2 ^= bytes.length;\n h3 ^= bytes.length;\n h4 ^= bytes.length;\n\n h1 += h2;\n h1 += h3;\n h1 += h4;\n h2 += h1;\n h3 += h1;\n h4 += h1;\n\n h1 = _x86Fmix(h1);\n h2 = _x86Fmix(h2);\n h3 = _x86Fmix(h3);\n h4 = _x86Fmix(h4);\n\n h1 += h2;\n h1 += h3;\n h1 += h4;\n h2 += h1;\n h3 += h1;\n h4 += h1;\n\n return (\"00000000\" + (h1 >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h2 >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h3 >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h4 >>> 0).toString(16)).slice(-8);\n };\n\n library.x64.hash128 = function (bytes, seed) {\n //\n // Given a string and an optional seed as an int, returns a 128 bit\n // hash using the x64 flavor of MurmurHash3, as an unsigned hex.\n //\n if (library.inputValidation && !_validBytes(bytes)) {\n return undefined;\n }\n seed = seed || 0;\n\n var remainder = bytes.length % 16;\n var blocks = bytes.length - remainder;\n\n var h1 = [0, seed];\n var h2 = [0, seed];\n\n var k1 = [0, 0];\n var k2 = [0, 0];\n\n var c1 = [0x87c37b91, 0x114253d5];\n var c2 = [0x4cf5ad43, 0x2745937f];\n\n for (var i = 0; i < blocks; i = i + 16) {\n k1 = [(bytes[i + 4]) | (bytes[i + 5] << 8) | (bytes[i + 6] << 16) | (bytes[i + 7] << 24), (bytes[i]) |\n (bytes[i + 1] << 8) | (bytes[i + 2] << 16) | (bytes[i + 3] << 24)];\n k2 = [(bytes[i + 12]) | (bytes[i + 13] << 8) | (bytes[i + 14] << 16) | (bytes[i + 15] << 24), (bytes[i + 8]) |\n (bytes[i + 9] << 8) | (bytes[i + 10] << 16) | (bytes[i + 11] << 24)];\n\n k1 = _x64Multiply(k1, c1);\n k1 = _x64Rotl(k1, 31);\n k1 = _x64Multiply(k1, c2);\n h1 = _x64Xor(h1, k1);\n\n h1 = _x64Rotl(h1, 27);\n h1 = _x64Add(h1, h2);\n h1 = _x64Add(_x64Multiply(h1, [0, 5]), [0, 0x52dce729]);\n\n k2 = _x64Multiply(k2, c2);\n k2 = _x64Rotl(k2, 33);\n k2 = _x64Multiply(k2, c1);\n h2 = _x64Xor(h2, k2);\n\n h2 = _x64Rotl(h2, 31);\n h2 = _x64Add(h2, h1);\n h2 = _x64Add(_x64Multiply(h2, [0, 5]), [0, 0x38495ab5]);\n }\n\n k1 = [0, 0];\n k2 = [0, 0];\n\n switch (remainder) {\n case 15:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 14]], 48));\n\n case 14:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 13]], 40));\n\n case 13:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 12]], 32));\n\n case 12:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 11]], 24));\n\n case 11:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 10]], 16));\n\n case 10:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 9]], 8));\n\n case 9:\n k2 = _x64Xor(k2, [0, bytes[i + 8]]);\n k2 = _x64Multiply(k2, c2);\n k2 = _x64Rotl(k2, 33);\n k2 = _x64Multiply(k2, c1);\n h2 = _x64Xor(h2, k2);\n\n case 8:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 7]], 56));\n\n case 7:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 6]], 48));\n\n case 6:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 5]], 40));\n\n case 5:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 4]], 32));\n\n case 4:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 3]], 24));\n\n case 3:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 2]], 16));\n\n case 2:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 1]], 8));\n\n case 1:\n k1 = _x64Xor(k1, [0, bytes[i]]);\n k1 = _x64Multiply(k1, c1);\n k1 = _x64Rotl(k1, 31);\n k1 = _x64Multiply(k1, c2);\n h1 = _x64Xor(h1, k1);\n }\n\n h1 = _x64Xor(h1, [0, bytes.length]);\n h2 = _x64Xor(h2, [0, bytes.length]);\n\n h1 = _x64Add(h1, h2);\n h2 = _x64Add(h2, h1);\n\n h1 = _x64Fmix(h1);\n h2 = _x64Fmix(h2);\n\n h1 = _x64Add(h1, h2);\n h2 = _x64Add(h2, h1);\n\n return (\"00000000\" + (h1[0] >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h1[1] >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h2[0] >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h2[1] >>> 0).toString(16)).slice(-8);\n };\n\n // INITIALIZATION\n // --------------\n\n // Export murmurHash3 for CommonJS, either as an AMD module or just as part\n // of the global object.\n if (typeof exports !== 'undefined') {\n\n if (typeof module !== 'undefined' && module.exports) {\n exports = module.exports = library;\n }\n\n exports.murmurHash3 = library;\n\n } else if (typeof define === 'function' && define.amd) {\n\n define([], function () {\n return library;\n });\n } else {\n\n // Use murmurHash3.noConflict to restore `murmurHash3` back to its\n // original value. Returns a reference to the library object, to allow\n // it to be used under a different name.\n library._murmurHash3 = root.murmurHash3;\n\n library.noConflict = function () {\n root.murmurHash3 = library._murmurHash3;\n library._murmurHash3 = undefined;\n library.noConflict = undefined;\n\n return library;\n };\n\n root.murmurHash3 = library;\n }\n})(this);\n","'use strict';\n\nvar dir = require('./dir.js');\nvar index = require('./file/index.js');\nvar errCode = require('err-code');\nvar rabin = require('../chunker/rabin.js');\nvar fixedSize = require('../chunker/fixed-size.js');\nvar validateChunks = require('./validate-chunks.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction isIterable(thing) {\n return Symbol.iterator in thing;\n}\nfunction isAsyncIterable(thing) {\n return Symbol.asyncIterator in thing;\n}\nfunction contentAsAsyncIterable(content) {\n try {\n if (content instanceof Uint8Array) {\n return async function* () {\n yield content;\n }();\n } else if (isIterable(content)) {\n return async function* () {\n yield* content;\n }();\n } else if (isAsyncIterable(content)) {\n return content;\n }\n } catch {\n throw errCode__default['default'](new Error('Content was invalid'), 'ERR_INVALID_CONTENT');\n }\n throw errCode__default['default'](new Error('Content was invalid'), 'ERR_INVALID_CONTENT');\n}\nasync function* dagBuilder(source, blockstore, options) {\n for await (const entry of source) {\n if (entry.path) {\n if (entry.path.substring(0, 2) === './') {\n options.wrapWithDirectory = true;\n }\n entry.path = entry.path.split('/').filter(path => path && path !== '.').join('/');\n }\n if (entry.content) {\n let chunker;\n if (typeof options.chunker === 'function') {\n chunker = options.chunker;\n } else if (options.chunker === 'rabin') {\n chunker = rabin;\n } else {\n chunker = fixedSize;\n }\n let chunkValidator;\n if (typeof options.chunkValidator === 'function') {\n chunkValidator = options.chunkValidator;\n } else {\n chunkValidator = validateChunks;\n }\n const file = {\n path: entry.path,\n mtime: entry.mtime,\n mode: entry.mode,\n content: chunker(chunkValidator(contentAsAsyncIterable(entry.content), options), options)\n };\n yield () => index(file, blockstore, options);\n } else if (entry.path) {\n const dir$1 = {\n path: entry.path,\n mtime: entry.mtime,\n mode: entry.mode\n };\n yield () => dir(dir$1, blockstore, options);\n } else {\n throw new Error('Import candidate must have content or path or both');\n }\n }\n}\n\nmodule.exports = dagBuilder;\n","'use strict';\n\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar persist = require('../utils/persist.js');\nvar dagPb = require('@ipld/dag-pb');\n\nconst dirBuilder = async (item, blockstore, options) => {\n const unixfs = new ipfsUnixfs.UnixFS({\n type: 'directory',\n mtime: item.mtime,\n mode: item.mode\n });\n const buffer = dagPb.encode(dagPb.prepare({ Data: unixfs.marshal() }));\n const cid = await persist(buffer, blockstore, options);\n const path = item.path;\n return {\n cid,\n path,\n unixfs,\n size: buffer.length\n };\n};\n\nmodule.exports = dirBuilder;\n","'use strict';\n\nvar cid = require('multiformats/cid');\nvar dagPb = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\n\nconst persist = async (buffer, blockstore, options) => {\n if (!options.codec) {\n options.codec = dagPb__namespace;\n }\n if (!options.hasher) {\n options.hasher = sha2.sha256;\n }\n if (options.cidVersion === undefined) {\n options.cidVersion = 1;\n }\n if (options.codec === dagPb__namespace && options.hasher !== sha2.sha256) {\n options.cidVersion = 1;\n }\n const multihash = await options.hasher.digest(buffer);\n const cid$1 = cid.CID.create(options.cidVersion, options.codec.code, multihash);\n if (!options.onlyHash) {\n await blockstore.put(cid$1, buffer, { signal: options.signal });\n }\n return cid$1;\n};\n\nmodule.exports = persist;\n","'use strict';\n\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar persist = require('../../utils/persist.js');\nvar dagPb = require('@ipld/dag-pb');\nvar parallelBatch = require('it-parallel-batch');\nvar rawCodec = require('multiformats/codecs/raw');\nvar flat = require('./flat.js');\nvar balanced = require('./balanced.js');\nvar trickle = require('./trickle.js');\nvar bufferImporter = require('./buffer-importer.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar parallelBatch__default = /*#__PURE__*/_interopDefaultLegacy(parallelBatch);\nvar rawCodec__namespace = /*#__PURE__*/_interopNamespace(rawCodec);\n\nconst dagBuilders = {\n flat: flat,\n balanced: balanced,\n trickle: trickle\n};\nasync function* buildFileBatch(file, blockstore, options) {\n let count = -1;\n let previous;\n let bufferImporter$1;\n if (typeof options.bufferImporter === 'function') {\n bufferImporter$1 = options.bufferImporter;\n } else {\n bufferImporter$1 = bufferImporter;\n }\n for await (const entry of parallelBatch__default['default'](bufferImporter$1(file, blockstore, options), options.blockWriteConcurrency)) {\n count++;\n if (count === 0) {\n previous = entry;\n continue;\n } else if (count === 1 && previous) {\n yield previous;\n previous = null;\n }\n yield entry;\n }\n if (previous) {\n previous.single = true;\n yield previous;\n }\n}\nconst reduce = (file, blockstore, options) => {\n async function reducer(leaves) {\n if (leaves.length === 1 && leaves[0].single && options.reduceSingleLeafToSelf) {\n const leaf = leaves[0];\n if (leaf.cid.code === rawCodec__namespace.code && (file.mtime !== undefined || file.mode !== undefined)) {\n let buffer = await blockstore.get(leaf.cid);\n leaf.unixfs = new ipfsUnixfs.UnixFS({\n type: 'file',\n mtime: file.mtime,\n mode: file.mode,\n data: buffer\n });\n buffer = dagPb.encode(dagPb.prepare({ Data: leaf.unixfs.marshal() }));\n leaf.cid = await persist(buffer, blockstore, {\n ...options,\n codec: dagPb__namespace,\n hasher: options.hasher,\n cidVersion: options.cidVersion\n });\n leaf.size = buffer.length;\n }\n return {\n cid: leaf.cid,\n path: file.path,\n unixfs: leaf.unixfs,\n size: leaf.size\n };\n }\n const f = new ipfsUnixfs.UnixFS({\n type: 'file',\n mtime: file.mtime,\n mode: file.mode\n });\n const links = leaves.filter(leaf => {\n if (leaf.cid.code === rawCodec__namespace.code && leaf.size) {\n return true;\n }\n if (leaf.unixfs && !leaf.unixfs.data && leaf.unixfs.fileSize()) {\n return true;\n }\n return Boolean(leaf.unixfs && leaf.unixfs.data && leaf.unixfs.data.length);\n }).map(leaf => {\n if (leaf.cid.code === rawCodec__namespace.code) {\n f.addBlockSize(leaf.size);\n return {\n Name: '',\n Tsize: leaf.size,\n Hash: leaf.cid\n };\n }\n if (!leaf.unixfs || !leaf.unixfs.data) {\n f.addBlockSize(leaf.unixfs && leaf.unixfs.fileSize() || 0);\n } else {\n f.addBlockSize(leaf.unixfs.data.length);\n }\n return {\n Name: '',\n Tsize: leaf.size,\n Hash: leaf.cid\n };\n });\n const node = {\n Data: f.marshal(),\n Links: links\n };\n const buffer = dagPb.encode(dagPb.prepare(node));\n const cid = await persist(buffer, blockstore, options);\n return {\n cid,\n path: file.path,\n unixfs: f,\n size: buffer.length + node.Links.reduce((acc, curr) => acc + curr.Tsize, 0)\n };\n }\n return reducer;\n};\nfunction fileBuilder(file, block, options) {\n const dagBuilder = dagBuilders[options.strategy];\n if (!dagBuilder) {\n throw errCode__default['default'](new Error(`Unknown importer build strategy name: ${ options.strategy }`), 'ERR_BAD_STRATEGY');\n }\n return dagBuilder(buildFileBatch(file, block, options), reduce(file, block, options), options);\n}\n\nmodule.exports = fileBuilder;\n","'use strict';\n\nvar all = require('it-all');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\n\nasync function flat(source, reduce) {\n return reduce(await all__default['default'](source));\n}\n\nmodule.exports = flat;\n","'use strict';\n\nvar batch = require('it-batch');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar batch__default = /*#__PURE__*/_interopDefaultLegacy(batch);\n\nfunction balanced(source, reduce, options) {\n return reduceToParents(source, reduce, options);\n}\nasync function reduceToParents(source, reduce, options) {\n const roots = [];\n for await (const chunked of batch__default['default'](source, options.maxChildrenPerNode)) {\n roots.push(await reduce(chunked));\n }\n if (roots.length > 1) {\n return reduceToParents(roots, reduce, options);\n }\n return roots[0];\n}\n\nmodule.exports = balanced;\n","'use strict';\n\nvar batch = require('it-batch');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar batch__default = /*#__PURE__*/_interopDefaultLegacy(batch);\n\nasync function trickleStream(source, reduce, options) {\n const root = new Root(options.layerRepeat);\n let iteration = 0;\n let maxDepth = 1;\n let subTree = root;\n for await (const layer of batch__default['default'](source, options.maxChildrenPerNode)) {\n if (subTree.isFull()) {\n if (subTree !== root) {\n root.addChild(await subTree.reduce(reduce));\n }\n if (iteration && iteration % options.layerRepeat === 0) {\n maxDepth++;\n }\n subTree = new SubTree(maxDepth, options.layerRepeat, iteration);\n iteration++;\n }\n subTree.append(layer);\n }\n if (subTree && subTree !== root) {\n root.addChild(await subTree.reduce(reduce));\n }\n return root.reduce(reduce);\n}\nclass SubTree {\n constructor(maxDepth, layerRepeat, iteration = 0) {\n this.maxDepth = maxDepth;\n this.layerRepeat = layerRepeat;\n this.currentDepth = 1;\n this.iteration = iteration;\n this.root = this.node = this.parent = {\n children: [],\n depth: this.currentDepth,\n maxDepth,\n maxChildren: (this.maxDepth - this.currentDepth) * this.layerRepeat\n };\n }\n isFull() {\n if (!this.root.data) {\n return false;\n }\n if (this.currentDepth < this.maxDepth && this.node.maxChildren) {\n this._addNextNodeToParent(this.node);\n return false;\n }\n const distantRelative = this._findParent(this.node, this.currentDepth);\n if (distantRelative) {\n this._addNextNodeToParent(distantRelative);\n return false;\n }\n return true;\n }\n _addNextNodeToParent(parent) {\n this.parent = parent;\n const nextNode = {\n children: [],\n depth: parent.depth + 1,\n parent,\n maxDepth: this.maxDepth,\n maxChildren: Math.floor(parent.children.length / this.layerRepeat) * this.layerRepeat\n };\n parent.children.push(nextNode);\n this.currentDepth = nextNode.depth;\n this.node = nextNode;\n }\n append(layer) {\n this.node.data = layer;\n }\n reduce(reduce) {\n return this._reduce(this.root, reduce);\n }\n async _reduce(node, reduce) {\n let children = [];\n if (node.children.length) {\n children = await Promise.all(node.children.filter(child => child.data).map(child => this._reduce(child, reduce)));\n }\n return reduce((node.data || []).concat(children));\n }\n _findParent(node, depth) {\n const parent = node.parent;\n if (!parent || parent.depth === 0) {\n return;\n }\n if (parent.children.length === parent.maxChildren || !parent.maxChildren) {\n return this._findParent(parent, depth);\n }\n return parent;\n }\n}\nclass Root extends SubTree {\n constructor(layerRepeat) {\n super(0, layerRepeat);\n this.root.depth = 0;\n this.currentDepth = 1;\n }\n addChild(child) {\n this.root.children.push(child);\n }\n reduce(reduce) {\n return reduce((this.root.data || []).concat(this.root.children));\n }\n}\n\nmodule.exports = trickleStream;\n","'use strict';\n\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar persist = require('../../utils/persist.js');\nvar dagPb = require('@ipld/dag-pb');\nvar rawCodec = require('multiformats/codecs/raw');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar rawCodec__namespace = /*#__PURE__*/_interopNamespace(rawCodec);\n\nasync function* bufferImporter(file, block, options) {\n for await (let buffer of file.content) {\n yield async () => {\n options.progress(buffer.length, file.path);\n let unixfs;\n const opts = {\n codec: dagPb__namespace,\n cidVersion: options.cidVersion,\n hasher: options.hasher,\n onlyHash: options.onlyHash\n };\n if (options.rawLeaves) {\n opts.codec = rawCodec__namespace;\n opts.cidVersion = 1;\n } else {\n unixfs = new ipfsUnixfs.UnixFS({\n type: options.leafType,\n data: buffer,\n mtime: file.mtime,\n mode: file.mode\n });\n buffer = dagPb__namespace.encode({\n Data: unixfs.marshal(),\n Links: []\n });\n }\n return {\n cid: await persist(buffer, block, opts),\n unixfs,\n size: buffer.length\n };\n };\n }\n}\n\nmodule.exports = bufferImporter;\n","'use strict';\n\nvar BufferList = require('bl/BufferList.js');\nvar rabinWasm = require('rabin-wasm');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar BufferList__default = /*#__PURE__*/_interopDefaultLegacy(BufferList);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nasync function* rabinChunker(source, options) {\n let min, max, avg;\n if (options.minChunkSize && options.maxChunkSize && options.avgChunkSize) {\n avg = options.avgChunkSize;\n min = options.minChunkSize;\n max = options.maxChunkSize;\n } else if (!options.avgChunkSize) {\n throw errCode__default['default'](new Error('please specify an average chunk size'), 'ERR_INVALID_AVG_CHUNK_SIZE');\n } else {\n avg = options.avgChunkSize;\n min = avg / 3;\n max = avg + avg / 2;\n }\n if (min < 16) {\n throw errCode__default['default'](new Error('rabin min must be greater than 16'), 'ERR_INVALID_MIN_CHUNK_SIZE');\n }\n if (max < min) {\n max = min;\n }\n if (avg < min) {\n avg = min;\n }\n const sizepow = Math.floor(Math.log2(avg));\n for await (const chunk of rabin(source, {\n min: min,\n max: max,\n bits: sizepow,\n window: options.window,\n polynomial: options.polynomial\n })) {\n yield chunk;\n }\n}\nasync function* rabin(source, options) {\n const r = await rabinWasm.create(options.bits, options.min, options.max, options.window);\n const buffers = new BufferList__default['default']();\n for await (const chunk of source) {\n buffers.append(chunk);\n const sizes = r.fingerprint(chunk);\n for (let i = 0; i < sizes.length; i++) {\n const size = sizes[i];\n const buf = buffers.slice(0, size);\n buffers.consume(size);\n yield buf;\n }\n }\n if (buffers.length) {\n yield buffers.slice(0);\n }\n}\n\nmodule.exports = rabinChunker;\n","'use strict'\n\nconst { Buffer } = require('buffer')\nconst symbol = Symbol.for('BufferList')\n\nfunction BufferList (buf) {\n if (!(this instanceof BufferList)) {\n return new BufferList(buf)\n }\n\n BufferList._init.call(this, buf)\n}\n\nBufferList._init = function _init (buf) {\n Object.defineProperty(this, symbol, { value: true })\n\n this._bufs = []\n this.length = 0\n\n if (buf) {\n this.append(buf)\n }\n}\n\nBufferList.prototype._new = function _new (buf) {\n return new BufferList(buf)\n}\n\nBufferList.prototype._offset = function _offset (offset) {\n if (offset === 0) {\n return [0, 0]\n }\n\n let tot = 0\n\n for (let i = 0; i < this._bufs.length; i++) {\n const _t = tot + this._bufs[i].length\n if (offset < _t || i === this._bufs.length - 1) {\n return [i, offset - tot]\n }\n tot = _t\n }\n}\n\nBufferList.prototype._reverseOffset = function (blOffset) {\n const bufferId = blOffset[0]\n let offset = blOffset[1]\n\n for (let i = 0; i < bufferId; i++) {\n offset += this._bufs[i].length\n }\n\n return offset\n}\n\nBufferList.prototype.get = function get (index) {\n if (index > this.length || index < 0) {\n return undefined\n }\n\n const offset = this._offset(index)\n\n return this._bufs[offset[0]][offset[1]]\n}\n\nBufferList.prototype.slice = function slice (start, end) {\n if (typeof start === 'number' && start < 0) {\n start += this.length\n }\n\n if (typeof end === 'number' && end < 0) {\n end += this.length\n }\n\n return this.copy(null, 0, start, end)\n}\n\nBufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) {\n if (typeof srcStart !== 'number' || srcStart < 0) {\n srcStart = 0\n }\n\n if (typeof srcEnd !== 'number' || srcEnd > this.length) {\n srcEnd = this.length\n }\n\n if (srcStart >= this.length) {\n return dst || Buffer.alloc(0)\n }\n\n if (srcEnd <= 0) {\n return dst || Buffer.alloc(0)\n }\n\n const copy = !!dst\n const off = this._offset(srcStart)\n const len = srcEnd - srcStart\n let bytes = len\n let bufoff = (copy && dstStart) || 0\n let start = off[1]\n\n // copy/slice everything\n if (srcStart === 0 && srcEnd === this.length) {\n if (!copy) {\n // slice, but full concat if multiple buffers\n return this._bufs.length === 1\n ? this._bufs[0]\n : Buffer.concat(this._bufs, this.length)\n }\n\n // copy, need to copy individual buffers\n for (let i = 0; i < this._bufs.length; i++) {\n this._bufs[i].copy(dst, bufoff)\n bufoff += this._bufs[i].length\n }\n\n return dst\n }\n\n // easy, cheap case where it's a subset of one of the buffers\n if (bytes <= this._bufs[off[0]].length - start) {\n return copy\n ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes)\n : this._bufs[off[0]].slice(start, start + bytes)\n }\n\n if (!copy) {\n // a slice, we need something to copy in to\n dst = Buffer.allocUnsafe(len)\n }\n\n for (let i = off[0]; i < this._bufs.length; i++) {\n const l = this._bufs[i].length - start\n\n if (bytes > l) {\n this._bufs[i].copy(dst, bufoff, start)\n bufoff += l\n } else {\n this._bufs[i].copy(dst, bufoff, start, start + bytes)\n bufoff += l\n break\n }\n\n bytes -= l\n\n if (start) {\n start = 0\n }\n }\n\n // safeguard so that we don't return uninitialized memory\n if (dst.length > bufoff) return dst.slice(0, bufoff)\n\n return dst\n}\n\nBufferList.prototype.shallowSlice = function shallowSlice (start, end) {\n start = start || 0\n end = typeof end !== 'number' ? this.length : end\n\n if (start < 0) {\n start += this.length\n }\n\n if (end < 0) {\n end += this.length\n }\n\n if (start === end) {\n return this._new()\n }\n\n const startOffset = this._offset(start)\n const endOffset = this._offset(end)\n const buffers = this._bufs.slice(startOffset[0], endOffset[0] + 1)\n\n if (endOffset[1] === 0) {\n buffers.pop()\n } else {\n buffers[buffers.length - 1] = buffers[buffers.length - 1].slice(0, endOffset[1])\n }\n\n if (startOffset[1] !== 0) {\n buffers[0] = buffers[0].slice(startOffset[1])\n }\n\n return this._new(buffers)\n}\n\nBufferList.prototype.toString = function toString (encoding, start, end) {\n return this.slice(start, end).toString(encoding)\n}\n\nBufferList.prototype.consume = function consume (bytes) {\n // first, normalize the argument, in accordance with how Buffer does it\n bytes = Math.trunc(bytes)\n // do nothing if not a positive number\n if (Number.isNaN(bytes) || bytes <= 0) return this\n\n while (this._bufs.length) {\n if (bytes >= this._bufs[0].length) {\n bytes -= this._bufs[0].length\n this.length -= this._bufs[0].length\n this._bufs.shift()\n } else {\n this._bufs[0] = this._bufs[0].slice(bytes)\n this.length -= bytes\n break\n }\n }\n\n return this\n}\n\nBufferList.prototype.duplicate = function duplicate () {\n const copy = this._new()\n\n for (let i = 0; i < this._bufs.length; i++) {\n copy.append(this._bufs[i])\n }\n\n return copy\n}\n\nBufferList.prototype.append = function append (buf) {\n if (buf == null) {\n return this\n }\n\n if (buf.buffer) {\n // append a view of the underlying ArrayBuffer\n this._appendBuffer(Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength))\n } else if (Array.isArray(buf)) {\n for (let i = 0; i < buf.length; i++) {\n this.append(buf[i])\n }\n } else if (this._isBufferList(buf)) {\n // unwrap argument into individual BufferLists\n for (let i = 0; i < buf._bufs.length; i++) {\n this.append(buf._bufs[i])\n }\n } else {\n // coerce number arguments to strings, since Buffer(number) does\n // uninitialized memory allocation\n if (typeof buf === 'number') {\n buf = buf.toString()\n }\n\n this._appendBuffer(Buffer.from(buf))\n }\n\n return this\n}\n\nBufferList.prototype._appendBuffer = function appendBuffer (buf) {\n this._bufs.push(buf)\n this.length += buf.length\n}\n\nBufferList.prototype.indexOf = function (search, offset, encoding) {\n if (encoding === undefined && typeof offset === 'string') {\n encoding = offset\n offset = undefined\n }\n\n if (typeof search === 'function' || Array.isArray(search)) {\n throw new TypeError('The \"value\" argument must be one of type string, Buffer, BufferList, or Uint8Array.')\n } else if (typeof search === 'number') {\n search = Buffer.from([search])\n } else if (typeof search === 'string') {\n search = Buffer.from(search, encoding)\n } else if (this._isBufferList(search)) {\n search = search.slice()\n } else if (Array.isArray(search.buffer)) {\n search = Buffer.from(search.buffer, search.byteOffset, search.byteLength)\n } else if (!Buffer.isBuffer(search)) {\n search = Buffer.from(search)\n }\n\n offset = Number(offset || 0)\n\n if (isNaN(offset)) {\n offset = 0\n }\n\n if (offset < 0) {\n offset = this.length + offset\n }\n\n if (offset < 0) {\n offset = 0\n }\n\n if (search.length === 0) {\n return offset > this.length ? this.length : offset\n }\n\n const blOffset = this._offset(offset)\n let blIndex = blOffset[0] // index of which internal buffer we're working on\n let buffOffset = blOffset[1] // offset of the internal buffer we're working on\n\n // scan over each buffer\n for (; blIndex < this._bufs.length; blIndex++) {\n const buff = this._bufs[blIndex]\n\n while (buffOffset < buff.length) {\n const availableWindow = buff.length - buffOffset\n\n if (availableWindow >= search.length) {\n const nativeSearchResult = buff.indexOf(search, buffOffset)\n\n if (nativeSearchResult !== -1) {\n return this._reverseOffset([blIndex, nativeSearchResult])\n }\n\n buffOffset = buff.length - search.length + 1 // end of native search window\n } else {\n const revOffset = this._reverseOffset([blIndex, buffOffset])\n\n if (this._match(revOffset, search)) {\n return revOffset\n }\n\n buffOffset++\n }\n }\n\n buffOffset = 0\n }\n\n return -1\n}\n\nBufferList.prototype._match = function (offset, search) {\n if (this.length - offset < search.length) {\n return false\n }\n\n for (let searchOffset = 0; searchOffset < search.length; searchOffset++) {\n if (this.get(offset + searchOffset) !== search[searchOffset]) {\n return false\n }\n }\n return true\n}\n\n;(function () {\n const methods = {\n readDoubleBE: 8,\n readDoubleLE: 8,\n readFloatBE: 4,\n readFloatLE: 4,\n readInt32BE: 4,\n readInt32LE: 4,\n readUInt32BE: 4,\n readUInt32LE: 4,\n readInt16BE: 2,\n readInt16LE: 2,\n readUInt16BE: 2,\n readUInt16LE: 2,\n readInt8: 1,\n readUInt8: 1,\n readIntBE: null,\n readIntLE: null,\n readUIntBE: null,\n readUIntLE: null\n }\n\n for (const m in methods) {\n (function (m) {\n if (methods[m] === null) {\n BufferList.prototype[m] = function (offset, byteLength) {\n return this.slice(offset, offset + byteLength)[m](0, byteLength)\n }\n } else {\n BufferList.prototype[m] = function (offset = 0) {\n return this.slice(offset, offset + methods[m])[m](0)\n }\n }\n }(m))\n }\n}())\n\n// Used internally by the class and also as an indicator of this object being\n// a `BufferList`. It's not possible to use `instanceof BufferList` in a browser\n// environment because there could be multiple different copies of the\n// BufferList class and some `BufferList`s might be `BufferList`s.\nBufferList.prototype._isBufferList = function _isBufferList (b) {\n return b instanceof BufferList || BufferList.isBufferList(b)\n}\n\nBufferList.isBufferList = function isBufferList (b) {\n return b != null && b[symbol]\n}\n\nmodule.exports = BufferList\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar customInspectSymbol =\n (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n : null\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nvar K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n var arr = new Uint8Array(1)\n var proto = { foo: function () { return 42 } }\n Object.setPrototypeOf(proto, Uint8Array.prototype)\n Object.setPrototypeOf(arr, proto)\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.buffer\n }\n})\n\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.byteOffset\n }\n})\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n }\n // Return an augmented `Uint8Array` instance\n var buf = new Uint8Array(length)\n Object.setPrototypeOf(buf, Buffer.prototype)\n return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError(\n 'The \"string\" argument must be of type string. Received type number'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value)\n }\n\n if (value == null) {\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n }\n\n if (isInstance(value, ArrayBuffer) ||\n (value && isInstance(value.buffer, ArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof SharedArrayBuffer !== 'undefined' &&\n (isInstance(value, SharedArrayBuffer) ||\n (value && isInstance(value.buffer, SharedArrayBuffer)))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'number') {\n throw new TypeError(\n 'The \"value\" argument must not be of type number. Received type number'\n )\n }\n\n var valueOf = value.valueOf && value.valueOf()\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length)\n }\n\n var b = fromObject(value)\n if (b) return b\n\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(\n value[Symbol.toPrimitive]('string'), encodingOrOffset, length\n )\n }\n\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype)\nObject.setPrototypeOf(Buffer, Uint8Array)\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number')\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpreted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n\n var length = byteLength(string, encoding) | 0\n var buf = createBuffer(length)\n\n var actual = buf.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n var buf = createBuffer(length)\n for (var i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayView (arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n var copy = new Uint8Array(arrayView)\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n }\n return fromArrayLike(arrayView)\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds')\n }\n\n var buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype)\n\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n var buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return b != null && b._isBuffer === true &&\n b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n}\n\nBuffer.compare = function compare (a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength)\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength)\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError(\n 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n )\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n Buffer.from(buf).copy(buffer, pos)\n } else {\n Uint8Array.prototype.set.call(\n buffer,\n buf,\n pos\n )\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n } else {\n buf.copy(buffer, pos)\n }\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n throw new TypeError(\n 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n 'Received type ' + typeof string\n )\n }\n\n var len = string.length\n var mustMatch = (arguments.length > 2 && arguments[2] === true)\n if (!mustMatch && len === 0) return 0\n\n // Use a for loop to avoid recursion\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) {\n return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n }\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n var length = this.length\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.toLocaleString = Buffer.prototype.toString\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n var str = ''\n var max = exports.INSPECT_MAX_BYTES\n str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim()\n if (this.length > max) str += ' ... '\n return ''\n}\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength)\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError(\n 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n 'Received type ' + (typeof target)\n )\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [val], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n var indexSize = 1\n var arrLength = arr.length\n var valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n var i\n if (dir) {\n var foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n var found = true\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n var remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n var strLen = string.length\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (numberIsNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0\n if (isFinite(length)) {\n length = length >>> 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n case 'latin1':\n case 'binary':\n return asciiWrite(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF)\n ? 4\n : (firstByte > 0xDF)\n ? 3\n : (firstByte > 0xBF)\n ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = ''\n var i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += hexSliceLookupTable[buf[i]]\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (var i = 0; i < bytes.length - 1; i += 2) {\n res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype)\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUintLE =\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUintBE =\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUint8 =\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUint16LE =\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUint16BE =\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUint32LE =\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUint32BE =\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var i = byteLength\n var mul = 1\n var val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUintLE =\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUintBE =\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUint8 =\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUint16LE =\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUint16BE =\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUint32LE =\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUint32BE =\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end)\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, end),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if ((encoding === 'utf8' && code < 128) ||\n encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n } else if (typeof val === 'boolean') {\n val = Number(val)\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : Buffer.from(val, encoding)\n var len = bytes.length\n if (len === 0) {\n throw new TypeError('The value \"' + val +\n '\" is invalid for argument \"value\"')\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0]\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n var c, hi, lo\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance (obj, type) {\n return obj instanceof type ||\n (obj != null && obj.constructor != null && obj.constructor.name != null &&\n obj.constructor.name === type.name)\n}\nfunction numberIsNaN (obj) {\n // For IE11 support\n return obj !== obj // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nvar hexSliceLookupTable = (function () {\n var alphabet = '0123456789abcdef'\n var table = new Array(256)\n for (var i = 0; i < 16; ++i) {\n var i16 = i * 16\n for (var j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j]\n }\n }\n return table\n})()\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","const Rabin = require('./rabin')\nconst getRabin = require('../dist/rabin-wasm.node.js')\n\nconst create = async (avg, min, max, windowSize, polynomial) => {\n const compiled = await getRabin()\n return new Rabin(compiled, avg, min, max, windowSize, polynomial)\n}\n\nmodule.exports = {\n Rabin,\n create\n}\n","/**\n * Rabin fingerprinting\n *\n * @class Rabin\n */\nclass Rabin {\n /**\n * Creates an instance of Rabin.\n * @param { import(\"./../dist/rabin-wasm\") } asModule\n * @param {number} [bits=12]\n * @param {number} [min=8 * 1024]\n * @param {number} [max=32 * 1024]\n * @param {number} polynomial\n * @memberof Rabin\n */\n constructor(asModule, bits = 12, min = 8 * 1024, max = 32 * 1024, windowSize = 64, polynomial) {\n this.bits = bits\n this.min = min\n this.max = max\n this.asModule = asModule\n this.rabin = new asModule.Rabin(bits, min, max, windowSize, polynomial)\n this.polynomial = polynomial\n }\n\n /**\n * Fingerprints the buffer\n *\n * @param {Uint8Array} buf\n * @returns {Array}\n * @memberof Rabin\n */\n fingerprint(buf) {\n const {\n __retain,\n __release,\n __allocArray,\n __getInt32Array,\n Int32Array_ID,\n Uint8Array_ID\n } = this.asModule\n\n const lengths = new Int32Array(Math.ceil(buf.length/this.min))\n const lengthsPtr = __retain(__allocArray(Int32Array_ID, lengths))\n const pointer = __retain(__allocArray(Uint8Array_ID, buf))\n\n const out = this.rabin.fingerprint(pointer, lengthsPtr)\n const processed = __getInt32Array(out)\n\n __release(pointer)\n __release(lengthsPtr)\n\n const end = processed.indexOf(0);\n return end >= 0 ? processed.subarray(0, end) : processed;\n }\n}\n\nmodule.exports = Rabin","\nconst { instantiate } = require(\"@assemblyscript/loader\");\n\nloadWebAssembly.supported = typeof WebAssembly !== 'undefined'\n\nfunction loadWebAssembly (imp = {}) {\n if (!loadWebAssembly.supported) return null\n \n var wasm = new Uint8Array([0,97,115,109,1,0,0,0,1,78,14,96,2,127,126,0,96,1,127,1,126,96,2,127,127,0,96,1,127,1,127,96,1,127,0,96,2,127,127,1,127,96,3,127,127,127,1,127,96,0,0,96,3,127,127,127,0,96,0,1,127,96,4,127,127,127,127,0,96,5,127,127,127,127,127,1,127,96,1,126,1,127,96,2,126,126,1,126,2,13,1,3,101,110,118,5,97,98,111,114,116,0,10,3,54,53,2,2,8,9,3,5,2,8,6,5,3,4,2,6,9,12,13,2,5,11,3,2,3,2,3,2,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,6,7,7,4,4,5,3,1,0,1,6,47,9,127,1,65,0,11,127,1,65,0,11,127,0,65,3,11,127,0,65,4,11,127,1,65,0,11,127,1,65,0,11,127,1,65,0,11,127,0,65,240,2,11,127,0,65,6,11,7,240,5,41,6,109,101,109,111,114,121,2,0,7,95,95,97,108,108,111,99,0,10,8,95,95,114,101,116,97,105,110,0,11,9,95,95,114,101,108,101,97,115,101,0,12,9,95,95,99,111,108,108,101,99,116,0,51,11,95,95,114,116,116,105,95,98,97,115,101,3,7,13,73,110,116,51,50,65,114,114,97,121,95,73,68,3,2,13,85,105,110,116,56,65,114,114,97,121,95,73,68,3,3,6,100,101,103,114,101,101,0,16,3,109,111,100,0,17,5,82,97,98,105,110,3,8,16,82,97,98,105,110,35,103,101,116,58,119,105,110,100,111,119,0,21,16,82,97,98,105,110,35,115,101,116,58,119,105,110,100,111,119,0,22,21,82,97,98,105,110,35,103,101,116,58,119,105,110,100,111,119,95,115,105,122,101,0,23,21,82,97,98,105,110,35,115,101,116,58,119,105,110,100,111,119,95,115,105,122,101,0,24,14,82,97,98,105,110,35,103,101,116,58,119,112,111,115,0,25,14,82,97,98,105,110,35,115,101,116,58,119,112,111,115,0,26,15,82,97,98,105,110,35,103,101,116,58,99,111,117,110,116,0,27,15,82,97,98,105,110,35,115,101,116,58,99,111,117,110,116,0,28,13,82,97,98,105,110,35,103,101,116,58,112,111,115,0,29,13,82,97,98,105,110,35,115,101,116,58,112,111,115,0,30,15,82,97,98,105,110,35,103,101,116,58,115,116,97,114,116,0,31,15,82,97,98,105,110,35,115,101,116,58,115,116,97,114,116,0,32,16,82,97,98,105,110,35,103,101,116,58,100,105,103,101,115,116,0,33,16,82,97,98,105,110,35,115,101,116,58,100,105,103,101,115,116,0,34,21,82,97,98,105,110,35,103,101,116,58,99,104,117,110,107,95,115,116,97,114,116,0,35,21,82,97,98,105,110,35,115,101,116,58,99,104,117,110,107,95,115,116,97,114,116,0,36,22,82,97,98,105,110,35,103,101,116,58,99,104,117,110,107,95,108,101,110,103,116,104,0,37,22,82,97,98,105,110,35,115,101,116,58,99,104,117,110,107,95,108,101,110,103,116,104,0,38,31,82,97,98,105,110,35,103,101,116,58,99,104,117,110,107,95,99,117,116,95,102,105,110,103,101,114,112,114,105,110,116,0,39,31,82,97,98,105,110,35,115,101,116,58,99,104,117,110,107,95,99,117,116,95,102,105,110,103,101,114,112,114,105,110,116,0,40,20,82,97,98,105,110,35,103,101,116,58,112,111,108,121,110,111,109,105,97,108,0,41,20,82,97,98,105,110,35,115,101,116,58,112,111,108,121,110,111,109,105,97,108,0,42,17,82,97,98,105,110,35,103,101,116,58,109,105,110,115,105,122,101,0,43,17,82,97,98,105,110,35,115,101,116,58,109,105,110,115,105,122,101,0,44,17,82,97,98,105,110,35,103,101,116,58,109,97,120,115,105,122,101,0,45,17,82,97,98,105,110,35,115,101,116,58,109,97,120,115,105,122,101,0,46,14,82,97,98,105,110,35,103,101,116,58,109,97,115,107,0,47,14,82,97,98,105,110,35,115,101,116,58,109,97,115,107,0,48,17,82,97,98,105,110,35,99,111,110,115,116,114,117,99,116,111,114,0,20,17,82,97,98,105,110,35,102,105,110,103,101,114,112,114,105,110,116,0,49,8,1,50,10,165,31,53,199,1,1,4,127,32,1,40,2,0,65,124,113,34,2,65,128,2,73,4,127,32,2,65,4,118,33,4,65,0,5,32,2,65,31,32,2,103,107,34,3,65,4,107,118,65,16,115,33,4,32,3,65,7,107,11,33,3,32,1,40,2,20,33,2,32,1,40,2,16,34,5,4,64,32,5,32,2,54,2,20,11,32,2,4,64,32,2,32,5,54,2,16,11,32,1,32,0,32,4,32,3,65,4,116,106,65,2,116,106,40,2,96,70,4,64,32,0,32,4,32,3,65,4,116,106,65,2,116,106,32,2,54,2,96,32,2,69,4,64,32,0,32,3,65,2,116,106,32,0,32,3,65,2,116,106,40,2,4,65,1,32,4,116,65,127,115,113,34,1,54,2,4,32,1,69,4,64,32,0,32,0,40,2,0,65,1,32,3,116,65,127,115,113,54,2,0,11,11,11,11,226,2,1,6,127,32,1,40,2,0,33,3,32,1,65,16,106,32,1,40,2,0,65,124,113,106,34,4,40,2,0,34,5,65,1,113,4,64,32,3,65,124,113,65,16,106,32,5,65,124,113,106,34,2,65,240,255,255,255,3,73,4,64,32,0,32,4,16,1,32,1,32,2,32,3,65,3,113,114,34,3,54,2,0,32,1,65,16,106,32,1,40,2,0,65,124,113,106,34,4,40,2,0,33,5,11,11,32,3,65,2,113,4,64,32,1,65,4,107,40,2,0,34,2,40,2,0,34,6,65,124,113,65,16,106,32,3,65,124,113,106,34,7,65,240,255,255,255,3,73,4,64,32,0,32,2,16,1,32,2,32,7,32,6,65,3,113,114,34,3,54,2,0,32,2,33,1,11,11,32,4,32,5,65,2,114,54,2,0,32,4,65,4,107,32,1,54,2,0,32,0,32,3,65,124,113,34,2,65,128,2,73,4,127,32,2,65,4,118,33,4,65,0,5,32,2,65,31,32,2,103,107,34,2,65,4,107,118,65,16,115,33,4,32,2,65,7,107,11,34,3,65,4,116,32,4,106,65,2,116,106,40,2,96,33,2,32,1,65,0,54,2,16,32,1,32,2,54,2,20,32,2,4,64,32,2,32,1,54,2,16,11,32,0,32,4,32,3,65,4,116,106,65,2,116,106,32,1,54,2,96,32,0,32,0,40,2,0,65,1,32,3,116,114,54,2,0,32,0,32,3,65,2,116,106,32,0,32,3,65,2,116,106,40,2,4,65,1,32,4,116,114,54,2,4,11,119,1,1,127,32,2,2,127,32,0,40,2,160,12,34,2,4,64,32,2,32,1,65,16,107,70,4,64,32,2,40,2,0,33,3,32,1,65,16,107,33,1,11,11,32,1,11,107,34,2,65,48,73,4,64,15,11,32,1,32,3,65,2,113,32,2,65,32,107,65,1,114,114,54,2,0,32,1,65,0,54,2,16,32,1,65,0,54,2,20,32,1,32,2,106,65,16,107,34,2,65,2,54,2,0,32,0,32,2,54,2,160,12,32,0,32,1,16,2,11,155,1,1,3,127,35,0,34,0,69,4,64,65,1,63,0,34,0,74,4,127,65,1,32,0,107,64,0,65,0,72,5,65,0,11,4,64,0,11,65,176,3,34,0,65,0,54,2,0,65,208,15,65,0,54,2,0,3,64,32,1,65,23,73,4,64,32,1,65,2,116,65,176,3,106,65,0,54,2,4,65,0,33,2,3,64,32,2,65,16,73,4,64,32,1,65,4,116,32,2,106,65,2,116,65,176,3,106,65,0,54,2,96,32,2,65,1,106,33,2,12,1,11,11,32,1,65,1,106,33,1,12,1,11,11,65,176,3,65,224,15,63,0,65,16,116,16,3,65,176,3,36,0,11,32,0,11,45,0,32,0,65,240,255,255,255,3,79,4,64,65,32,65,224,0,65,201,3,65,29,16,0,0,11,32,0,65,15,106,65,112,113,34,0,65,16,32,0,65,16,75,27,11,169,1,1,1,127,32,0,32,1,65,128,2,73,4,127,32,1,65,4,118,33,1,65,0,5,32,1,65,248,255,255,255,1,73,4,64,32,1,65,1,65,27,32,1,103,107,116,106,65,1,107,33,1,11,32,1,65,31,32,1,103,107,34,2,65,4,107,118,65,16,115,33,1,32,2,65,7,107,11,34,2,65,2,116,106,40,2,4,65,127,32,1,116,113,34,1,4,127,32,0,32,1,104,32,2,65,4,116,106,65,2,116,106,40,2,96,5,32,0,40,2,0,65,127,32,2,65,1,106,116,113,34,1,4,127,32,0,32,0,32,1,104,34,0,65,2,116,106,40,2,4,104,32,0,65,4,116,106,65,2,116,106,40,2,96,5,65,0,11,11,11,111,1,1,127,63,0,34,2,32,1,65,248,255,255,255,1,73,4,127,32,1,65,1,65,27,32,1,103,107,116,65,1,107,106,5,32,1,11,65,16,32,0,40,2,160,12,32,2,65,16,116,65,16,107,71,116,106,65,255,255,3,106,65,128,128,124,113,65,16,118,34,1,32,2,32,1,74,27,64,0,65,0,72,4,64,32,1,64,0,65,0,72,4,64,0,11,11,32,0,32,2,65,16,116,63,0,65,16,116,16,3,11,113,1,2,127,32,1,40,2,0,34,3,65,124,113,32,2,107,34,4,65,32,79,4,64,32,1,32,2,32,3,65,2,113,114,54,2,0,32,2,32,1,65,16,106,106,34,1,32,4,65,16,107,65,1,114,54,2,0,32,0,32,1,16,2,5,32,1,32,3,65,126,113,54,2,0,32,1,65,16,106,32,1,40,2,0,65,124,113,106,32,1,65,16,106,32,1,40,2,0,65,124,113,106,40,2,0,65,125,113,54,2,0,11,11,91,1,2,127,32,0,32,1,16,5,34,4,16,6,34,3,69,4,64,65,1,36,1,65,0,36,1,32,0,32,4,16,6,34,3,69,4,64,32,0,32,4,16,7,32,0,32,4,16,6,33,3,11,11,32,3,65,0,54,2,4,32,3,32,2,54,2,8,32,3,32,1,54,2,12,32,0,32,3,16,1,32,0,32,3,32,4,16,8,32,3,11,13,0,16,4,32,0,32,1,16,9,65,16,106,11,33,1,1,127,32,0,65,172,3,75,4,64,32,0,65,16,107,34,1,32,1,40,2,4,65,1,106,54,2,4,11,32,0,11,18,0,32,0,65,172,3,75,4,64,32,0,65,16,107,16,52,11,11,140,3,1,1,127,2,64,32,1,69,13,0,32,0,65,0,58,0,0,32,0,32,1,106,65,1,107,65,0,58,0,0,32,1,65,2,77,13,0,32,0,65,1,106,65,0,58,0,0,32,0,65,2,106,65,0,58,0,0,32,0,32,1,106,34,2,65,2,107,65,0,58,0,0,32,2,65,3,107,65,0,58,0,0,32,1,65,6,77,13,0,32,0,65,3,106,65,0,58,0,0,32,0,32,1,106,65,4,107,65,0,58,0,0,32,1,65,8,77,13,0,32,1,65,0,32,0,107,65,3,113,34,1,107,33,2,32,0,32,1,106,34,0,65,0,54,2,0,32,0,32,2,65,124,113,34,1,106,65,4,107,65,0,54,2,0,32,1,65,8,77,13,0,32,0,65,4,106,65,0,54,2,0,32,0,65,8,106,65,0,54,2,0,32,0,32,1,106,34,2,65,12,107,65,0,54,2,0,32,2,65,8,107,65,0,54,2,0,32,1,65,24,77,13,0,32,0,65,12,106,65,0,54,2,0,32,0,65,16,106,65,0,54,2,0,32,0,65,20,106,65,0,54,2,0,32,0,65,24,106,65,0,54,2,0,32,0,32,1,106,34,2,65,28,107,65,0,54,2,0,32,2,65,24,107,65,0,54,2,0,32,2,65,20,107,65,0,54,2,0,32,2,65,16,107,65,0,54,2,0,32,0,32,0,65,4,113,65,24,106,34,2,106,33,0,32,1,32,2,107,33,1,3,64,32,1,65,32,79,4,64,32,0,66,0,55,3,0,32,0,65,8,106,66,0,55,3,0,32,0,65,16,106,66,0,55,3,0,32,0,65,24,106,66,0,55,3,0,32,1,65,32,107,33,1,32,0,65,32,106,33,0,12,1,11,11,11,11,178,1,1,3,127,32,1,65,240,255,255,255,3,32,2,118,75,4,64,65,144,1,65,192,1,65,23,65,56,16,0,0,11,32,1,32,2,116,34,3,65,0,16,10,34,2,32,3,16,13,32,0,69,4,64,65,12,65,2,16,10,34,0,65,172,3,75,4,64,32,0,65,16,107,34,1,32,1,40,2,4,65,1,106,54,2,4,11,11,32,0,65,0,54,2,0,32,0,65,0,54,2,4,32,0,65,0,54,2,8,32,2,34,1,32,0,40,2,0,34,4,71,4,64,32,1,65,172,3,75,4,64,32,1,65,16,107,34,5,32,5,40,2,4,65,1,106,54,2,4,11,32,4,16,12,11,32,0,32,1,54,2,0,32,0,32,2,54,2,4,32,0,32,3,54,2,8,32,0,11,46,1,2,127,65,12,65,5,16,10,34,0,65,172,3,75,4,64,32,0,65,16,107,34,1,32,1,40,2,4,65,1,106,54,2,4,11,32,0,65,128,2,65,3,16,14,11,9,0,65,63,32,0,121,167,107,11,49,1,2,127,65,63,32,1,121,167,107,33,2,3,64,65,63,32,0,121,167,107,32,2,107,34,3,65,0,78,4,64,32,0,32,1,32,3,172,134,133,33,0,12,1,11,11,32,0,11,40,0,32,1,32,0,40,2,8,79,4,64,65,128,2,65,192,2,65,163,1,65,44,16,0,0,11,32,1,32,0,40,2,4,106,65,0,58,0,0,11,38,0,32,1,32,0,40,2,8,79,4,64,65,128,2,65,192,2,65,152,1,65,44,16,0,0,11,32,1,32,0,40,2,4,106,45,0,0,11,254,5,2,1,127,4,126,32,0,69,4,64,65,232,0,65,6,16,10,34,0,65,172,3,75,4,64,32,0,65,16,107,34,5,32,5,40,2,4,65,1,106,54,2,4,11,11,32,0,65,0,54,2,0,32,0,65,0,54,2,4,32,0,65,0,54,2,8,32,0,66,0,55,3,16,32,0,66,0,55,3,24,32,0,66,0,55,3,32,32,0,66,0,55,3,40,32,0,66,0,55,3,48,32,0,66,0,55,3,56,32,0,66,0,55,3,64,32,0,66,0,55,3,72,32,0,66,0,55,3,80,32,0,66,0,55,3,88,32,0,66,0,55,3,96,32,0,32,2,173,55,3,80,32,0,32,3,173,55,3,88,65,12,65,4,16,10,34,2,65,172,3,75,4,64,32,2,65,16,107,34,3,32,3,40,2,4,65,1,106,54,2,4,11,32,2,32,4,65,0,16,14,33,2,32,0,40,2,0,16,12,32,0,32,2,54,2,0,32,0,32,4,54,2,4,32,0,66,1,32,1,173,134,66,1,125,55,3,96,32,0,66,243,130,183,218,216,230,232,30,55,3,72,35,4,69,4,64,65,0,33,2,3,64,32,2,65,128,2,72,4,64,32,2,65,255,1,113,173,33,6,32,0,41,3,72,34,7,33,8,65,63,32,7,121,167,107,33,1,3,64,65,63,32,6,121,167,107,32,1,107,34,3,65,0,78,4,64,32,6,32,8,32,3,172,134,133,33,6,12,1,11,11,65,0,33,4,3,64,32,4,32,0,40,2,4,65,1,107,72,4,64,32,6,66,8,134,33,6,32,0,41,3,72,34,7,33,8,65,63,32,7,121,167,107,33,1,3,64,65,63,32,6,121,167,107,32,1,107,34,3,65,0,78,4,64,32,6,32,8,32,3,172,134,133,33,6,12,1,11,11,32,4,65,1,106,33,4,12,1,11,11,35,6,40,2,4,32,2,65,3,116,106,32,6,55,3,0,32,2,65,1,106,33,2,12,1,11,11,65,63,32,0,41,3,72,121,167,107,172,33,7,65,0,33,2,3,64,32,2,65,128,2,72,4,64,35,5,33,1,32,2,172,32,7,134,34,8,33,6,65,63,32,0,41,3,72,34,9,121,167,107,33,3,3,64,65,63,32,6,121,167,107,32,3,107,34,4,65,0,78,4,64,32,6,32,9,32,4,172,134,133,33,6,12,1,11,11,32,1,40,2,4,32,2,65,3,116,106,32,6,32,8,132,55,3,0,32,2,65,1,106,33,2,12,1,11,11,65,1,36,4,11,32,0,66,0,55,3,24,32,0,66,0,55,3,32,65,0,33,2,3,64,32,2,32,0,40,2,4,72,4,64,32,0,40,2,0,32,2,16,18,32,2,65,1,106,33,2,12,1,11,11,32,0,66,0,55,3,40,32,0,65,0,54,2,8,32,0,66,0,55,3,16,32,0,66,0,55,3,40,32,0,40,2,0,32,0,40,2,8,16,19,33,1,32,0,40,2,8,32,0,40,2,0,40,2,4,106,65,1,58,0,0,32,0,32,0,41,3,40,35,6,40,2,4,32,1,65,3,116,106,41,3,0,133,55,3,40,32,0,32,0,40,2,8,65,1,106,32,0,40,2,4,111,54,2,8,32,0,35,5,40,2,4,32,0,41,3,40,34,6,66,45,136,167,65,3,116,106,41,3,0,32,6,66,8,134,66,1,132,133,55,3,40,32,0,11,38,1,1,127,32,0,40,2,0,34,0,65,172,3,75,4,64,32,0,65,16,107,34,1,32,1,40,2,4,65,1,106,54,2,4,11,32,0,11,55,1,2,127,32,1,32,0,40,2,0,34,2,71,4,64,32,1,65,172,3,75,4,64,32,1,65,16,107,34,3,32,3,40,2,4,65,1,106,54,2,4,11,32,2,16,12,11,32,0,32,1,54,2,0,11,7,0,32,0,40,2,4,11,9,0,32,0,32,1,54,2,4,11,7,0,32,0,40,2,8,11,9,0,32,0,32,1,54,2,8,11,7,0,32,0,41,3,16,11,9,0,32,0,32,1,55,3,16,11,7,0,32,0,41,3,24,11,9,0,32,0,32,1,55,3,24,11,7,0,32,0,41,3,32,11,9,0,32,0,32,1,55,3,32,11,7,0,32,0,41,3,40,11,9,0,32,0,32,1,55,3,40,11,7,0,32,0,41,3,48,11,9,0,32,0,32,1,55,3,48,11,7,0,32,0,41,3,56,11,9,0,32,0,32,1,55,3,56,11,7,0,32,0,41,3,64,11,9,0,32,0,32,1,55,3,64,11,7,0,32,0,41,3,72,11,9,0,32,0,32,1,55,3,72,11,7,0,32,0,41,3,80,11,9,0,32,0,32,1,55,3,80,11,7,0,32,0,41,3,88,11,9,0,32,0,32,1,55,3,88,11,7,0,32,0,41,3,96,11,9,0,32,0,32,1,55,3,96,11,172,4,2,5,127,1,126,32,2,65,172,3,75,4,64,32,2,65,16,107,34,4,32,4,40,2,4,65,1,106,54,2,4,11,32,2,33,4,65,0,33,2,32,1,40,2,8,33,5,32,1,40,2,4,33,6,3,64,2,127,65,0,33,3,3,64,32,3,32,5,72,4,64,32,3,32,6,106,45,0,0,33,1,32,0,40,2,0,32,0,40,2,8,16,19,33,7,32,0,40,2,8,32,0,40,2,0,40,2,4,106,32,1,58,0,0,32,0,32,0,41,3,40,35,6,40,2,4,32,7,65,3,116,106,41,3,0,133,55,3,40,32,0,32,0,40,2,8,65,1,106,32,0,40,2,4,111,54,2,8,32,0,35,5,40,2,4,32,0,41,3,40,34,8,66,45,136,167,65,3,116,106,41,3,0,32,1,173,32,8,66,8,134,132,133,55,3,40,32,0,32,0,41,3,16,66,1,124,55,3,16,32,0,32,0,41,3,24,66,1,124,55,3,24,32,0,41,3,16,32,0,41,3,80,90,4,127,32,0,41,3,40,32,0,41,3,96,131,80,5,65,0,11,4,127,65,1,5,32,0,41,3,16,32,0,41,3,88,90,11,4,64,32,0,32,0,41,3,32,55,3,48,32,0,32,0,41,3,16,55,3,56,32,0,32,0,41,3,40,55,3,64,65,0,33,1,3,64,32,1,32,0,40,2,4,72,4,64,32,0,40,2,0,32,1,16,18,32,1,65,1,106,33,1,12,1,11,11,32,0,66,0,55,3,40,32,0,65,0,54,2,8,32,0,66,0,55,3,16,32,0,66,0,55,3,40,32,0,40,2,0,32,0,40,2,8,16,19,33,1,32,0,40,2,8,32,0,40,2,0,40,2,4,106,65,1,58,0,0,32,0,32,0,41,3,40,35,6,40,2,4,32,1,65,3,116,106,41,3,0,133,55,3,40,32,0,32,0,40,2,8,65,1,106,32,0,40,2,4,111,54,2,8,32,0,35,5,40,2,4,32,0,41,3,40,34,8,66,45,136,167,65,3,116,106,41,3,0,32,8,66,8,134,66,1,132,133,55,3,40,32,3,65,1,106,12,3,11,32,3,65,1,106,33,3,12,1,11,11,65,127,11,34,1,65,0,78,4,64,32,5,32,1,107,33,5,32,1,32,6,106,33,6,32,2,34,1,65,1,106,33,2,32,4,40,2,4,32,1,65,2,116,106,32,0,41,3,56,62,2,0,12,1,11,11,32,4,11,10,0,16,15,36,5,16,15,36,6,11,3,0,1,11,73,1,2,127,32,0,40,2,4,34,1,65,255,255,255,255,0,113,34,2,65,1,70,4,64,32,0,65,16,106,16,53,32,0,32,0,40,2,0,65,1,114,54,2,0,35,0,32,0,16,2,5,32,0,32,2,65,1,107,32,1,65,128,128,128,128,127,113,114,54,2,4,11,11,58,0,2,64,2,64,2,64,32,0,65,8,107,40,2,0,14,7,0,0,1,1,1,1,1,2,11,15,11,32,0,40,2,0,34,0,4,64,32,0,65,172,3,79,4,64,32,0,65,16,107,16,52,11,11,15,11,0,11,11,137,3,7,0,65,16,11,55,40,0,0,0,1,0,0,0,1,0,0,0,40,0,0,0,97,0,108,0,108,0,111,0,99,0,97,0,116,0,105,0,111,0,110,0,32,0,116,0,111,0,111,0,32,0,108,0,97,0,114,0,103,0,101,0,65,208,0,11,45,30,0,0,0,1,0,0,0,1,0,0,0,30,0,0,0,126,0,108,0,105,0,98,0,47,0,114,0,116,0,47,0,116,0,108,0,115,0,102,0,46,0,116,0,115,0,65,128,1,11,43,28,0,0,0,1,0,0,0,1,0,0,0,28,0,0,0,73,0,110,0,118,0,97,0,108,0,105,0,100,0,32,0,108,0,101,0,110,0,103,0,116,0,104,0,65,176,1,11,53,38,0,0,0,1,0,0,0,1,0,0,0,38,0,0,0,126,0,108,0,105,0,98,0,47,0,97,0,114,0,114,0,97,0,121,0,98,0,117,0,102,0,102,0,101,0,114,0,46,0,116,0,115,0,65,240,1,11,51,36,0,0,0,1,0,0,0,1,0,0,0,36,0,0,0,73,0,110,0,100,0,101,0,120,0,32,0,111,0,117,0,116,0,32,0,111,0,102,0,32,0,114,0,97,0,110,0,103,0,101,0,65,176,2,11,51,36,0,0,0,1,0,0,0,1,0,0,0,36,0,0,0,126,0,108,0,105,0,98,0,47,0,116,0,121,0,112,0,101,0,100,0,97,0,114,0,114,0,97,0,121,0,46,0,116,0,115,0,65,240,2,11,53,7,0,0,0,16,0,0,0,0,0,0,0,16,0,0,0,0,0,0,0,16,0,0,0,0,0,0,0,145,4,0,0,2,0,0,0,49,0,0,0,2,0,0,0,17,1,0,0,2,0,0,0,16,0,34,16,115,111,117,114,99,101,77,97,112,112,105,110,103,85,82,76,16,46,47,114,97,98,105,110,46,119,97,115,109,46,109,97,112])\n // make it work async because browsers throw when a wasm module is bigger than 4kb and load sync\n return instantiate(new Response(new Blob([wasm], {type: 'application/wasm'})), imp)\n}\nmodule.exports = loadWebAssembly\n","\"use strict\";\n\n// Runtime header offsets\nconst ID_OFFSET = -8;\nconst SIZE_OFFSET = -4;\n\n// Runtime ids\nconst ARRAYBUFFER_ID = 0;\nconst STRING_ID = 1;\nconst ARRAYBUFFERVIEW_ID = 2;\n\n// Runtime type information\nconst ARRAYBUFFERVIEW = 1 << 0;\nconst ARRAY = 1 << 1;\nconst SET = 1 << 2;\nconst MAP = 1 << 3;\nconst VAL_ALIGN_OFFSET = 5;\nconst VAL_ALIGN = 1 << VAL_ALIGN_OFFSET;\nconst VAL_SIGNED = 1 << 10;\nconst VAL_FLOAT = 1 << 11;\nconst VAL_NULLABLE = 1 << 12;\nconst VAL_MANAGED = 1 << 13;\nconst KEY_ALIGN_OFFSET = 14;\nconst KEY_ALIGN = 1 << KEY_ALIGN_OFFSET;\nconst KEY_SIGNED = 1 << 19;\nconst KEY_FLOAT = 1 << 20;\nconst KEY_NULLABLE = 1 << 21;\nconst KEY_MANAGED = 1 << 22;\n\n// Array(BufferView) layout\nconst ARRAYBUFFERVIEW_BUFFER_OFFSET = 0;\nconst ARRAYBUFFERVIEW_DATASTART_OFFSET = 4;\nconst ARRAYBUFFERVIEW_DATALENGTH_OFFSET = 8;\nconst ARRAYBUFFERVIEW_SIZE = 12;\nconst ARRAY_LENGTH_OFFSET = 12;\nconst ARRAY_SIZE = 16;\n\nconst BIGINT = typeof BigUint64Array !== \"undefined\";\nconst THIS = Symbol();\nconst CHUNKSIZE = 1024;\n\n/** Gets a string from an U32 and an U16 view on a memory. */\nfunction getStringImpl(buffer, ptr) {\n const U32 = new Uint32Array(buffer);\n const U16 = new Uint16Array(buffer);\n var length = U32[(ptr + SIZE_OFFSET) >>> 2] >>> 1;\n var offset = ptr >>> 1;\n if (length <= CHUNKSIZE) return String.fromCharCode.apply(String, U16.subarray(offset, offset + length));\n const parts = [];\n do {\n const last = U16[offset + CHUNKSIZE - 1];\n const size = last >= 0xD800 && last < 0xDC00 ? CHUNKSIZE - 1 : CHUNKSIZE;\n parts.push(String.fromCharCode.apply(String, U16.subarray(offset, offset += size)));\n length -= size;\n } while (length > CHUNKSIZE);\n return parts.join(\"\") + String.fromCharCode.apply(String, U16.subarray(offset, offset + length));\n}\n\n/** Prepares the base module prior to instantiation. */\nfunction preInstantiate(imports) {\n const baseModule = {};\n\n function getString(memory, ptr) {\n if (!memory) return \"\";\n return getStringImpl(memory.buffer, ptr);\n }\n\n // add common imports used by stdlib for convenience\n const env = (imports.env = imports.env || {});\n env.abort = env.abort || function abort(mesg, file, line, colm) {\n const memory = baseModule.memory || env.memory; // prefer exported, otherwise try imported\n throw Error(\"abort: \" + getString(memory, mesg) + \" at \" + getString(memory, file) + \":\" + line + \":\" + colm);\n }\n env.trace = env.trace || function trace(mesg, n) {\n const memory = baseModule.memory || env.memory;\n console.log(\"trace: \" + getString(memory, mesg) + (n ? \" \" : \"\") + Array.prototype.slice.call(arguments, 2, 2 + n).join(\", \"));\n }\n imports.Math = imports.Math || Math;\n imports.Date = imports.Date || Date;\n\n return baseModule;\n}\n\n/** Prepares the final module once instantiation is complete. */\nfunction postInstantiate(baseModule, instance) {\n const rawExports = instance.exports;\n const memory = rawExports.memory;\n const table = rawExports.table;\n const alloc = rawExports[\"__alloc\"];\n const retain = rawExports[\"__retain\"];\n const rttiBase = rawExports[\"__rtti_base\"] || ~0; // oob if not present\n\n /** Gets the runtime type info for the given id. */\n function getInfo(id) {\n const U32 = new Uint32Array(memory.buffer);\n const count = U32[rttiBase >>> 2];\n if ((id >>>= 0) >= count) throw Error(\"invalid id: \" + id);\n return U32[(rttiBase + 4 >>> 2) + id * 2];\n }\n\n /** Gets the runtime base id for the given id. */\n function getBase(id) {\n const U32 = new Uint32Array(memory.buffer);\n const count = U32[rttiBase >>> 2];\n if ((id >>>= 0) >= count) throw Error(\"invalid id: \" + id);\n return U32[(rttiBase + 4 >>> 2) + id * 2 + 1];\n }\n\n /** Gets the runtime alignment of a collection's values. */\n function getValueAlign(info) {\n return 31 - Math.clz32((info >>> VAL_ALIGN_OFFSET) & 31); // -1 if none\n }\n\n /** Gets the runtime alignment of a collection's keys. */\n function getKeyAlign(info) {\n return 31 - Math.clz32((info >>> KEY_ALIGN_OFFSET) & 31); // -1 if none\n }\n\n /** Allocates a new string in the module's memory and returns its retained pointer. */\n function __allocString(str) {\n const length = str.length;\n const ptr = alloc(length << 1, STRING_ID);\n const U16 = new Uint16Array(memory.buffer);\n for (var i = 0, p = ptr >>> 1; i < length; ++i) U16[p + i] = str.charCodeAt(i);\n return ptr;\n }\n\n baseModule.__allocString = __allocString;\n\n /** Reads a string from the module's memory by its pointer. */\n function __getString(ptr) {\n const buffer = memory.buffer;\n const id = new Uint32Array(buffer)[ptr + ID_OFFSET >>> 2];\n if (id !== STRING_ID) throw Error(\"not a string: \" + ptr);\n return getStringImpl(buffer, ptr);\n }\n\n baseModule.__getString = __getString;\n\n /** Gets the view matching the specified alignment, signedness and floatness. */\n function getView(alignLog2, signed, float) {\n const buffer = memory.buffer;\n if (float) {\n switch (alignLog2) {\n case 2: return new Float32Array(buffer);\n case 3: return new Float64Array(buffer);\n }\n } else {\n switch (alignLog2) {\n case 0: return new (signed ? Int8Array : Uint8Array)(buffer);\n case 1: return new (signed ? Int16Array : Uint16Array)(buffer);\n case 2: return new (signed ? Int32Array : Uint32Array)(buffer);\n case 3: return new (signed ? BigInt64Array : BigUint64Array)(buffer);\n }\n }\n throw Error(\"unsupported align: \" + alignLog2);\n }\n\n /** Allocates a new array in the module's memory and returns its retained pointer. */\n function __allocArray(id, values) {\n const info = getInfo(id);\n if (!(info & (ARRAYBUFFERVIEW | ARRAY))) throw Error(\"not an array: \" + id + \" @ \" + info);\n const align = getValueAlign(info);\n const length = values.length;\n const buf = alloc(length << align, ARRAYBUFFER_ID);\n const arr = alloc(info & ARRAY ? ARRAY_SIZE : ARRAYBUFFERVIEW_SIZE, id);\n const U32 = new Uint32Array(memory.buffer);\n U32[arr + ARRAYBUFFERVIEW_BUFFER_OFFSET >>> 2] = retain(buf);\n U32[arr + ARRAYBUFFERVIEW_DATASTART_OFFSET >>> 2] = buf;\n U32[arr + ARRAYBUFFERVIEW_DATALENGTH_OFFSET >>> 2] = length << align;\n if (info & ARRAY) U32[arr + ARRAY_LENGTH_OFFSET >>> 2] = length;\n const view = getView(align, info & VAL_SIGNED, info & VAL_FLOAT);\n if (info & VAL_MANAGED) {\n for (let i = 0; i < length; ++i) view[(buf >>> align) + i] = retain(values[i]);\n } else {\n view.set(values, buf >>> align);\n }\n return arr;\n }\n\n baseModule.__allocArray = __allocArray;\n\n /** Gets a live view on an array's values in the module's memory. Infers the array type from RTTI. */\n function __getArrayView(arr) {\n const U32 = new Uint32Array(memory.buffer);\n const id = U32[arr + ID_OFFSET >>> 2];\n const info = getInfo(id);\n if (!(info & ARRAYBUFFERVIEW)) throw Error(\"not an array: \" + id);\n const align = getValueAlign(info);\n var buf = U32[arr + ARRAYBUFFERVIEW_DATASTART_OFFSET >>> 2];\n const length = info & ARRAY\n ? U32[arr + ARRAY_LENGTH_OFFSET >>> 2]\n : U32[buf + SIZE_OFFSET >>> 2] >>> align;\n return getView(align, info & VAL_SIGNED, info & VAL_FLOAT)\n .subarray(buf >>>= align, buf + length);\n }\n\n baseModule.__getArrayView = __getArrayView;\n\n /** Copies an array's values from the module's memory. Infers the array type from RTTI. */\n function __getArray(arr) {\n const input = __getArrayView(arr);\n const len = input.length;\n const out = new Array(len);\n for (let i = 0; i < len; i++) out[i] = input[i];\n return out;\n }\n\n baseModule.__getArray = __getArray;\n\n /** Copies an ArrayBuffer's value from the module's memory. */\n function __getArrayBuffer(ptr) {\n const buffer = memory.buffer;\n const length = new Uint32Array(buffer)[ptr + SIZE_OFFSET >>> 2];\n return buffer.slice(ptr, ptr + length);\n }\n\n baseModule.__getArrayBuffer = __getArrayBuffer;\n\n /** Copies a typed array's values from the module's memory. */\n function getTypedArray(Type, alignLog2, ptr) {\n return new Type(getTypedArrayView(Type, alignLog2, ptr));\n }\n\n /** Gets a live view on a typed array's values in the module's memory. */\n function getTypedArrayView(Type, alignLog2, ptr) {\n const buffer = memory.buffer;\n const U32 = new Uint32Array(buffer);\n const bufPtr = U32[ptr + ARRAYBUFFERVIEW_DATASTART_OFFSET >>> 2];\n return new Type(buffer, bufPtr, U32[bufPtr + SIZE_OFFSET >>> 2] >>> alignLog2);\n }\n\n baseModule.__getInt8Array = getTypedArray.bind(null, Int8Array, 0);\n baseModule.__getInt8ArrayView = getTypedArrayView.bind(null, Int8Array, 0);\n baseModule.__getUint8Array = getTypedArray.bind(null, Uint8Array, 0);\n baseModule.__getUint8ArrayView = getTypedArrayView.bind(null, Uint8Array, 0);\n baseModule.__getUint8ClampedArray = getTypedArray.bind(null, Uint8ClampedArray, 0);\n baseModule.__getUint8ClampedArrayView = getTypedArrayView.bind(null, Uint8ClampedArray, 0);\n baseModule.__getInt16Array = getTypedArray.bind(null, Int16Array, 1);\n baseModule.__getInt16ArrayView = getTypedArrayView.bind(null, Int16Array, 1);\n baseModule.__getUint16Array = getTypedArray.bind(null, Uint16Array, 1);\n baseModule.__getUint16ArrayView = getTypedArrayView.bind(null, Uint16Array, 1);\n baseModule.__getInt32Array = getTypedArray.bind(null, Int32Array, 2);\n baseModule.__getInt32ArrayView = getTypedArrayView.bind(null, Int32Array, 2);\n baseModule.__getUint32Array = getTypedArray.bind(null, Uint32Array, 2);\n baseModule.__getUint32ArrayView = getTypedArrayView.bind(null, Uint32Array, 2);\n if (BIGINT) {\n baseModule.__getInt64Array = getTypedArray.bind(null, BigInt64Array, 3);\n baseModule.__getInt64ArrayView = getTypedArrayView.bind(null, BigInt64Array, 3);\n baseModule.__getUint64Array = getTypedArray.bind(null, BigUint64Array, 3);\n baseModule.__getUint64ArrayView = getTypedArrayView.bind(null, BigUint64Array, 3);\n }\n baseModule.__getFloat32Array = getTypedArray.bind(null, Float32Array, 2);\n baseModule.__getFloat32ArrayView = getTypedArrayView.bind(null, Float32Array, 2);\n baseModule.__getFloat64Array = getTypedArray.bind(null, Float64Array, 3);\n baseModule.__getFloat64ArrayView = getTypedArrayView.bind(null, Float64Array, 3);\n\n /** Tests whether an object is an instance of the class represented by the specified base id. */\n function __instanceof(ptr, baseId) {\n const U32 = new Uint32Array(memory.buffer);\n var id = U32[(ptr + ID_OFFSET) >>> 2];\n if (id <= U32[rttiBase >>> 2]) {\n do if (id == baseId) return true;\n while (id = getBase(id));\n }\n return false;\n }\n\n baseModule.__instanceof = __instanceof;\n\n // Pull basic exports to baseModule so code in preInstantiate can use them\n baseModule.memory = baseModule.memory || memory;\n baseModule.table = baseModule.table || table;\n\n // Demangle exports and provide the usual utility on the prototype\n return demangle(rawExports, baseModule);\n}\n\nfunction isResponse(o) {\n return typeof Response !== \"undefined\" && o instanceof Response;\n}\n\n/** Asynchronously instantiates an AssemblyScript module from anything that can be instantiated. */\nasync function instantiate(source, imports) {\n if (isResponse(source = await source)) return instantiateStreaming(source, imports);\n return postInstantiate(\n preInstantiate(imports || (imports = {})),\n await WebAssembly.instantiate(\n source instanceof WebAssembly.Module\n ? source\n : await WebAssembly.compile(source),\n imports\n )\n );\n}\n\nexports.instantiate = instantiate;\n\n/** Synchronously instantiates an AssemblyScript module from a WebAssembly.Module or binary buffer. */\nfunction instantiateSync(source, imports) {\n return postInstantiate(\n preInstantiate(imports || (imports = {})),\n new WebAssembly.Instance(\n source instanceof WebAssembly.Module\n ? source\n : new WebAssembly.Module(source),\n imports\n )\n )\n}\n\nexports.instantiateSync = instantiateSync;\n\n/** Asynchronously instantiates an AssemblyScript module from a response, i.e. as obtained by `fetch`. */\nasync function instantiateStreaming(source, imports) {\n if (!WebAssembly.instantiateStreaming) {\n return instantiate(\n isResponse(source = await source)\n ? source.arrayBuffer()\n : source,\n imports\n );\n }\n return postInstantiate(\n preInstantiate(imports || (imports = {})),\n (await WebAssembly.instantiateStreaming(source, imports)).instance\n );\n}\n\nexports.instantiateStreaming = instantiateStreaming;\n\n/** Demangles an AssemblyScript module's exports to a friendly object structure. */\nfunction demangle(exports, baseModule) {\n var module = baseModule ? Object.create(baseModule) : {};\n var setArgumentsLength = exports[\"__argumentsLength\"]\n ? function(length) { exports[\"__argumentsLength\"].value = length; }\n : exports[\"__setArgumentsLength\"] || exports[\"__setargc\"] || function() {};\n for (let internalName in exports) {\n if (!Object.prototype.hasOwnProperty.call(exports, internalName)) continue;\n const elem = exports[internalName];\n let parts = internalName.split(\".\");\n let curr = module;\n while (parts.length > 1) {\n let part = parts.shift();\n if (!Object.prototype.hasOwnProperty.call(curr, part)) curr[part] = {};\n curr = curr[part];\n }\n let name = parts[0];\n let hash = name.indexOf(\"#\");\n if (hash >= 0) {\n let className = name.substring(0, hash);\n let classElem = curr[className];\n if (typeof classElem === \"undefined\" || !classElem.prototype) {\n let ctor = function(...args) {\n return ctor.wrap(ctor.prototype.constructor(0, ...args));\n };\n ctor.prototype = {\n valueOf: function valueOf() {\n return this[THIS];\n }\n };\n ctor.wrap = function(thisValue) {\n return Object.create(ctor.prototype, { [THIS]: { value: thisValue, writable: false } });\n };\n if (classElem) Object.getOwnPropertyNames(classElem).forEach(name =>\n Object.defineProperty(ctor, name, Object.getOwnPropertyDescriptor(classElem, name))\n );\n curr[className] = ctor;\n }\n name = name.substring(hash + 1);\n curr = curr[className].prototype;\n if (/^(get|set):/.test(name)) {\n if (!Object.prototype.hasOwnProperty.call(curr, name = name.substring(4))) {\n let getter = exports[internalName.replace(\"set:\", \"get:\")];\n let setter = exports[internalName.replace(\"get:\", \"set:\")];\n Object.defineProperty(curr, name, {\n get: function() { return getter(this[THIS]); },\n set: function(value) { setter(this[THIS], value); },\n enumerable: true\n });\n }\n } else {\n if (name === 'constructor') {\n (curr[name] = (...args) => {\n setArgumentsLength(args.length);\n return elem(...args);\n }).original = elem;\n } else { // instance method\n (curr[name] = function(...args) { // !\n setArgumentsLength(args.length);\n return elem(this[THIS], ...args);\n }).original = elem;\n }\n }\n } else {\n if (/^(get|set):/.test(name)) {\n if (!Object.prototype.hasOwnProperty.call(curr, name = name.substring(4))) {\n Object.defineProperty(curr, name, {\n get: exports[internalName.replace(\"set:\", \"get:\")],\n set: exports[internalName.replace(\"get:\", \"set:\")],\n enumerable: true\n });\n }\n } else if (typeof elem === \"function\" && elem !== setArgumentsLength) {\n (curr[name] = (...args) => {\n setArgumentsLength(args.length);\n return elem(...args);\n }).original = elem;\n } else {\n curr[name] = elem;\n }\n }\n }\n return module;\n}\n\nexports.demangle = demangle;\n","'use strict';\n\nvar BufferList = require('bl/BufferList.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar BufferList__default = /*#__PURE__*/_interopDefaultLegacy(BufferList);\n\nasync function* fixedSizeChunker(source, options) {\n let bl = new BufferList__default['default']();\n let currentLength = 0;\n let emitted = false;\n const maxChunkSize = options.maxChunkSize;\n for await (const buffer of source) {\n bl.append(buffer);\n currentLength += buffer.length;\n while (currentLength >= maxChunkSize) {\n yield bl.slice(0, maxChunkSize);\n emitted = true;\n if (maxChunkSize === bl.length) {\n bl = new BufferList__default['default']();\n currentLength = 0;\n } else {\n const newBl = new BufferList__default['default']();\n newBl.append(bl.shallowSlice(maxChunkSize));\n bl = newBl;\n currentLength -= maxChunkSize;\n }\n }\n }\n if (!emitted || currentLength) {\n yield bl.slice(0, currentLength);\n }\n}\n\nmodule.exports = fixedSizeChunker;\n","'use strict';\n\nvar errCode = require('err-code');\nvar fromString = require('uint8arrays/from-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nasync function* validateChunks(source) {\n for await (const content of source) {\n if (content.length === undefined) {\n throw errCode__default['default'](new Error('Content was invalid'), 'ERR_INVALID_CONTENT');\n }\n if (typeof content === 'string' || content instanceof String) {\n yield fromString.fromString(content.toString());\n } else if (Array.isArray(content)) {\n yield Uint8Array.from(content);\n } else if (content instanceof Uint8Array) {\n yield content;\n } else {\n throw errCode__default['default'](new Error('Content was invalid'), 'ERR_INVALID_CONTENT');\n }\n }\n}\n\nmodule.exports = validateChunks;\n","'use strict';\n\nvar dirFlat = require('./dir-flat.js');\nvar flatToShard = require('./flat-to-shard.js');\nvar dir = require('./dir.js');\nvar toPathComponents = require('./utils/to-path-components.js');\n\nasync function addToTree(elem, tree, options) {\n const pathElems = toPathComponents(elem.path || '');\n const lastIndex = pathElems.length - 1;\n let parent = tree;\n let currentPath = '';\n for (let i = 0; i < pathElems.length; i++) {\n const pathElem = pathElems[i];\n currentPath += `${ currentPath ? '/' : '' }${ pathElem }`;\n const last = i === lastIndex;\n parent.dirty = true;\n parent.cid = undefined;\n parent.size = undefined;\n if (last) {\n await parent.put(pathElem, elem);\n tree = await flatToShard(null, parent, options.shardSplitThreshold, options);\n } else {\n let dir$1 = await parent.get(pathElem);\n if (!dir$1 || !(dir$1 instanceof dir)) {\n dir$1 = new dirFlat({\n root: false,\n dir: true,\n parent: parent,\n parentKey: pathElem,\n path: currentPath,\n dirty: true,\n flat: true,\n mtime: dir$1 && dir$1.unixfs && dir$1.unixfs.mtime,\n mode: dir$1 && dir$1.unixfs && dir$1.unixfs.mode\n }, options);\n }\n await parent.put(pathElem, dir$1);\n parent = dir$1;\n }\n }\n return tree;\n}\nasync function* flushAndYield(tree, blockstore) {\n if (!(tree instanceof dir)) {\n if (tree && tree.unixfs && tree.unixfs.isDirectory()) {\n yield tree;\n }\n return;\n }\n yield* tree.flush(blockstore);\n}\nasync function* treeBuilder(source, block, options) {\n let tree = new dirFlat({\n root: true,\n dir: true,\n path: '',\n dirty: true,\n flat: true\n }, options);\n for await (const entry of source) {\n if (!entry) {\n continue;\n }\n tree = await addToTree(entry, tree, options);\n if (!entry.unixfs || !entry.unixfs.isDirectory()) {\n yield entry;\n }\n }\n if (options.wrapWithDirectory) {\n yield* flushAndYield(tree, block);\n } else {\n for await (const unwrapped of tree.eachChildSeries()) {\n if (!unwrapped) {\n continue;\n }\n yield* flushAndYield(unwrapped.child, block);\n }\n }\n}\n\nmodule.exports = treeBuilder;\n","'use strict';\n\nvar dagPb = require('@ipld/dag-pb');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dir = require('./dir.js');\nvar persist = require('./utils/persist.js');\n\nclass DirFlat extends dir {\n constructor(props, options) {\n super(props, options);\n this._children = {};\n }\n async put(name, value) {\n this.cid = undefined;\n this.size = undefined;\n this._children[name] = value;\n }\n get(name) {\n return Promise.resolve(this._children[name]);\n }\n childCount() {\n return Object.keys(this._children).length;\n }\n directChildrenCount() {\n return this.childCount();\n }\n onlyChild() {\n return this._children[Object.keys(this._children)[0]];\n }\n async *eachChildSeries() {\n const keys = Object.keys(this._children);\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n yield {\n key: key,\n child: this._children[key]\n };\n }\n }\n async *flush(block) {\n const children = Object.keys(this._children);\n const links = [];\n for (let i = 0; i < children.length; i++) {\n let child = this._children[children[i]];\n if (child instanceof dir) {\n for await (const entry of child.flush(block)) {\n child = entry;\n yield child;\n }\n }\n if (child.size != null && child.cid) {\n links.push({\n Name: children[i],\n Tsize: child.size,\n Hash: child.cid\n });\n }\n }\n const unixfs = new ipfsUnixfs.UnixFS({\n type: 'directory',\n mtime: this.mtime,\n mode: this.mode\n });\n const node = {\n Data: unixfs.marshal(),\n Links: links\n };\n const buffer = dagPb.encode(dagPb.prepare(node));\n const cid = await persist(buffer, block, this.options);\n const size = buffer.length + node.Links.reduce((acc, curr) => acc + (curr.Tsize == null ? 0 : curr.Tsize), 0);\n this.cid = cid;\n this.size = size;\n yield {\n cid,\n unixfs,\n path: this.path,\n size\n };\n }\n}\n\nmodule.exports = DirFlat;\n","'use strict';\n\nclass Dir {\n constructor(props, options) {\n this.options = options || {};\n this.root = props.root;\n this.dir = props.dir;\n this.path = props.path;\n this.dirty = props.dirty;\n this.flat = props.flat;\n this.parent = props.parent;\n this.parentKey = props.parentKey;\n this.unixfs = props.unixfs;\n this.mode = props.mode;\n this.mtime = props.mtime;\n this.cid = undefined;\n this.size = undefined;\n }\n async put(name, value) {\n }\n get(name) {\n return Promise.resolve(this);\n }\n async *eachChildSeries() {\n }\n async *flush(blockstore) {\n }\n}\n\nmodule.exports = Dir;\n","'use strict';\n\nvar dirSharded = require('./dir-sharded.js');\nvar dirFlat = require('./dir-flat.js');\n\nasync function flatToShard(child, dir, threshold, options) {\n let newDir = dir;\n if (dir instanceof dirFlat && dir.directChildrenCount() >= threshold) {\n newDir = await convertToShard(dir, options);\n }\n const parent = newDir.parent;\n if (parent) {\n if (newDir !== dir) {\n if (child) {\n child.parent = newDir;\n }\n if (!newDir.parentKey) {\n throw new Error('No parent key found');\n }\n await parent.put(newDir.parentKey, newDir);\n }\n return flatToShard(newDir, parent, threshold, options);\n }\n return newDir;\n}\nasync function convertToShard(oldDir, options) {\n const newDir = new dirSharded({\n root: oldDir.root,\n dir: true,\n parent: oldDir.parent,\n parentKey: oldDir.parentKey,\n path: oldDir.path,\n dirty: oldDir.dirty,\n flat: false,\n mtime: oldDir.mtime,\n mode: oldDir.mode\n }, options);\n for await (const {key, child} of oldDir.eachChildSeries()) {\n await newDir.put(key, child);\n }\n return newDir;\n}\n\nmodule.exports = flatToShard;\n","'use strict';\n\nvar dagPb = require('@ipld/dag-pb');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dir = require('./dir.js');\nvar persist = require('./utils/persist.js');\nvar hamtSharding = require('hamt-sharding');\n\nclass DirSharded extends dir {\n constructor(props, options) {\n super(props, options);\n this._bucket = hamtSharding.createHAMT({\n hashFn: options.hamtHashFn,\n bits: options.hamtBucketBits\n });\n }\n async put(name, value) {\n await this._bucket.put(name, value);\n }\n get(name) {\n return this._bucket.get(name);\n }\n childCount() {\n return this._bucket.leafCount();\n }\n directChildrenCount() {\n return this._bucket.childrenCount();\n }\n onlyChild() {\n return this._bucket.onlyChild();\n }\n async *eachChildSeries() {\n for await (const {key, value} of this._bucket.eachLeafSeries()) {\n yield {\n key,\n child: value\n };\n }\n }\n async *flush(blockstore) {\n for await (const entry of flush(this._bucket, blockstore, this, this.options)) {\n yield {\n ...entry,\n path: this.path\n };\n }\n }\n}\nasync function* flush(bucket, blockstore, shardRoot, options) {\n const children = bucket._children;\n const links = [];\n let childrenSize = 0;\n for (let i = 0; i < children.length; i++) {\n const child = children.get(i);\n if (!child) {\n continue;\n }\n const labelPrefix = i.toString(16).toUpperCase().padStart(2, '0');\n if (child instanceof hamtSharding.Bucket) {\n let shard;\n for await (const subShard of await flush(child, blockstore, null, options)) {\n shard = subShard;\n }\n if (!shard) {\n throw new Error('Could not flush sharded directory, no subshard found');\n }\n links.push({\n Name: labelPrefix,\n Tsize: shard.size,\n Hash: shard.cid\n });\n childrenSize += shard.size;\n } else if (typeof child.value.flush === 'function') {\n const dir = child.value;\n let flushedDir;\n for await (const entry of dir.flush(blockstore)) {\n flushedDir = entry;\n yield flushedDir;\n }\n const label = labelPrefix + child.key;\n links.push({\n Name: label,\n Tsize: flushedDir.size,\n Hash: flushedDir.cid\n });\n childrenSize += flushedDir.size;\n } else {\n const value = child.value;\n if (!value.cid) {\n continue;\n }\n const label = labelPrefix + child.key;\n const size = value.size;\n links.push({\n Name: label,\n Tsize: size,\n Hash: value.cid\n });\n childrenSize += size;\n }\n }\n const data = Uint8Array.from(children.bitField().reverse());\n const dir = new ipfsUnixfs.UnixFS({\n type: 'hamt-sharded-directory',\n data,\n fanout: bucket.tableSize(),\n hashType: options.hamtHashCode,\n mtime: shardRoot && shardRoot.mtime,\n mode: shardRoot && shardRoot.mode\n });\n const node = {\n Data: dir.marshal(),\n Links: links\n };\n const buffer = dagPb.encode(dagPb.prepare(node));\n const cid = await persist(buffer, blockstore, options);\n const size = buffer.length + childrenSize;\n yield {\n cid,\n unixfs: dir,\n size\n };\n}\n\nmodule.exports = DirSharded;\n","'use strict'\n\nconst Bucket = require('./bucket')\nconst wrapHash = require('./consumable-hash')\n\n/**\n * @typedef {object} UserBucketOptions\n * @property {(value: Uint8Array) => Promise} hashFn\n * @property {number} [bits=8]\n */\n\n/**\n * @param {UserBucketOptions} options\n */\nfunction createHAMT (options) {\n if (!options || !options.hashFn) {\n throw new Error('please define an options.hashFn')\n }\n\n const bucketOptions = {\n bits: options.bits || 8,\n hash: wrapHash(options.hashFn)\n }\n\n return new Bucket(bucketOptions)\n}\n\nmodule.exports = {\n createHAMT,\n Bucket\n}\n","'use strict'\n\n// @ts-ignore\nconst SparseArray = require('sparse-array')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\n/**\n * @typedef {import('./consumable-hash').InfiniteHash} InfiniteHash\n * @typedef {import('../').UserBucketOptions} UserBucketOptions\n */\n\n/**\n * @template V\n * @typedef {object} BucketChild\n * @property {string} key\n * @property {V} value\n * @property {InfiniteHash} hash\n */\n\n/**\n * @template B\n *\n * @typedef {object} SA\n * @property {number} length\n * @property {() => B[]} compactArray\n * @property {(i: number) => B} get\n * @property {(i: number, value: B) => void} set\n * @property { (fn: (acc: A, curr: B, index: number) => A, initial: A) => B} reduce\n * @property {(fn: (item: B) => boolean) => B | undefined} find\n * @property {() => number[]} bitField\n * @property {(i: number) => void} unset\n */\n\n/**\n * @template T\n *\n * @typedef {object} BucketPosition\n * @property {Bucket} bucket\n * @property {number} pos\n * @property {InfiniteHash} hash\n * @property {BucketChild} [existingChild]\n */\n\n/**\n * @typedef {object} BucketOptions\n * @property {number} bits\n * @property {(value: Uint8Array | InfiniteHash) => InfiniteHash} hash\n */\n\n/**\n * @template T\n */\nclass Bucket {\n /**\n * @param {BucketOptions} options\n * @param {Bucket} [parent]\n * @param {number} [posAtParent=0]\n */\n constructor (options, parent, posAtParent = 0) {\n this._options = options\n this._popCount = 0\n this._parent = parent\n this._posAtParent = posAtParent\n\n /** @type {SA | BucketChild>} */\n this._children = new SparseArray()\n\n /** @type {string | null} */\n this.key = null\n }\n\n /**\n * @param {string} key\n * @param {T} value\n */\n async put (key, value) {\n const place = await this._findNewBucketAndPos(key)\n\n await place.bucket._putAt(place, key, value)\n }\n\n /**\n * @param {string} key\n */\n async get (key) {\n const child = await this._findChild(key)\n\n if (child) {\n return child.value\n }\n }\n\n /**\n * @param {string} key\n */\n async del (key) {\n const place = await this._findPlace(key)\n const child = place.bucket._at(place.pos)\n\n if (child && child.key === key) {\n place.bucket._delAt(place.pos)\n }\n }\n\n /**\n * @returns {number}\n */\n leafCount () {\n const children = this._children.compactArray()\n\n return children.reduce((acc, child) => {\n if (child instanceof Bucket) {\n return acc + child.leafCount()\n }\n\n return acc + 1\n }, 0)\n }\n\n childrenCount () {\n return this._children.length\n }\n\n onlyChild () {\n return this._children.get(0)\n }\n\n /**\n * @returns {Iterable>}\n */\n * eachLeafSeries () {\n const children = this._children.compactArray()\n\n for (const child of children) {\n if (child instanceof Bucket) {\n yield * child.eachLeafSeries()\n } else {\n yield child\n }\n }\n\n // this is necessary because tsc requires a @return annotation as it\n // can't derive a return type due to the recursion, and eslint requires\n // a return statement when there is a @return annotation\n return []\n }\n\n /**\n * @param {(value: BucketChild, index: number) => T} map\n * @param {(reduced: any) => any} reduce\n */\n serialize (map, reduce) {\n /** @type {T[]} */\n const acc = []\n // serialize to a custom non-sparse representation\n return reduce(this._children.reduce((acc, child, index) => {\n if (child) {\n if (child instanceof Bucket) {\n acc.push(child.serialize(map, reduce))\n } else {\n acc.push(map(child, index))\n }\n }\n return acc\n }, acc))\n }\n\n /**\n * @param {(value: BucketChild) => Promise} asyncMap\n * @param {(reduced: any) => Promise} asyncReduce\n */\n asyncTransform (asyncMap, asyncReduce) {\n return asyncTransformBucket(this, asyncMap, asyncReduce)\n }\n\n toJSON () {\n return this.serialize(mapNode, reduceNodes)\n }\n\n prettyPrint () {\n return JSON.stringify(this.toJSON(), null, ' ')\n }\n\n tableSize () {\n return Math.pow(2, this._options.bits)\n }\n\n /**\n * @param {string} key\n * @returns {Promise | undefined>}\n */\n async _findChild (key) {\n const result = await this._findPlace(key)\n const child = result.bucket._at(result.pos)\n\n if (child instanceof Bucket) {\n // should not be possible, this._findPlace should always\n // return a location for a child, not a bucket\n return undefined\n }\n\n if (child && child.key === key) {\n return child\n }\n }\n\n /**\n * @param {string | InfiniteHash} key\n * @returns {Promise>}\n */\n async _findPlace (key) {\n const hashValue = this._options.hash(typeof key === 'string' ? uint8ArrayFromString(key) : key)\n const index = await hashValue.take(this._options.bits)\n\n const child = this._children.get(index)\n\n if (child instanceof Bucket) {\n return child._findPlace(hashValue)\n }\n\n return {\n bucket: this,\n pos: index,\n hash: hashValue,\n existingChild: child\n }\n }\n\n /**\n * @param {string | InfiniteHash} key\n * @returns {Promise>}\n */\n async _findNewBucketAndPos (key) {\n const place = await this._findPlace(key)\n\n if (place.existingChild && place.existingChild.key !== key) {\n // conflict\n const bucket = new Bucket(this._options, place.bucket, place.pos)\n place.bucket._putObjectAt(place.pos, bucket)\n\n // put the previous value\n const newPlace = await bucket._findPlace(place.existingChild.hash)\n newPlace.bucket._putAt(newPlace, place.existingChild.key, place.existingChild.value)\n\n return bucket._findNewBucketAndPos(place.hash)\n }\n\n // no conflict, we found the place\n return place\n }\n\n /**\n * @param {BucketPosition} place\n * @param {string} key\n * @param {T} value\n */\n _putAt (place, key, value) {\n this._putObjectAt(place.pos, {\n key: key,\n value: value,\n hash: place.hash\n })\n }\n\n /**\n * @param {number} pos\n * @param {Bucket | BucketChild} object\n */\n _putObjectAt (pos, object) {\n if (!this._children.get(pos)) {\n this._popCount++\n }\n this._children.set(pos, object)\n }\n\n /**\n * @param {number} pos\n */\n _delAt (pos) {\n if (pos === -1) {\n throw new Error('Invalid position')\n }\n\n if (this._children.get(pos)) {\n this._popCount--\n }\n this._children.unset(pos)\n this._level()\n }\n\n _level () {\n if (this._parent && this._popCount <= 1) {\n if (this._popCount === 1) {\n // remove myself from parent, replacing me with my only child\n const onlyChild = this._children.find(exists)\n\n if (onlyChild && !(onlyChild instanceof Bucket)) {\n const hash = onlyChild.hash\n hash.untake(this._options.bits)\n const place = {\n pos: this._posAtParent,\n hash: hash,\n bucket: this._parent\n }\n this._parent._putAt(place, onlyChild.key, onlyChild.value)\n }\n } else {\n this._parent._delAt(this._posAtParent)\n }\n }\n }\n\n /**\n * @param {number} index\n * @returns {BucketChild | Bucket | undefined}\n */\n _at (index) {\n return this._children.get(index)\n }\n}\n\n/**\n * @param {any} o\n */\nfunction exists (o) {\n return Boolean(o)\n}\n\n/**\n *\n * @param {*} node\n * @param {number} index\n */\nfunction mapNode (node, index) {\n return node.key\n}\n\n/**\n * @param {*} nodes\n */\nfunction reduceNodes (nodes) {\n return nodes\n}\n\n/**\n * @template T\n *\n * @param {Bucket} bucket\n * @param {(value: BucketChild) => Promise} asyncMap\n * @param {(reduced: any) => Promise} asyncReduce\n */\nasync function asyncTransformBucket (bucket, asyncMap, asyncReduce) {\n const output = []\n\n for (const child of bucket._children.compactArray()) {\n if (child instanceof Bucket) {\n await asyncTransformBucket(child, asyncMap, asyncReduce)\n } else {\n const mappedChildren = await asyncMap(child)\n\n output.push({\n bitField: bucket._children.bitField(),\n children: mappedChildren\n })\n }\n }\n\n return asyncReduce(output)\n}\n\nmodule.exports = Bucket\n","'use strict'\n\n// JS treats subjects of bitwise operators as SIGNED 32 bit numbers,\n// which means the maximum amount of bits we can store inside each byte\n// is 7..\nconst BITS_PER_BYTE = 7\n\nmodule.exports = class SparseArray {\n constructor () {\n this._bitArrays = []\n this._data = []\n this._length = 0\n this._changedLength = false\n this._changedData = false\n }\n\n set (index, value) {\n let pos = this._internalPositionFor(index, false)\n if (value === undefined) {\n // unsetting\n if (pos !== -1) {\n // remove item from bit array and array itself\n this._unsetInternalPos(pos)\n this._unsetBit(index)\n this._changedLength = true\n this._changedData = true\n }\n } else {\n let needsSort = false\n if (pos === -1) {\n pos = this._data.length\n this._setBit(index)\n this._changedData = true\n } else {\n needsSort = true\n }\n this._setInternalPos(pos, index, value, needsSort)\n this._changedLength = true\n }\n }\n\n unset (index) {\n this.set(index, undefined)\n }\n\n get (index) {\n this._sortData()\n const pos = this._internalPositionFor(index, true)\n if (pos === -1) {\n return undefined\n }\n return this._data[pos][1]\n }\n\n push (value) {\n this.set(this.length, value)\n return this.length\n }\n\n get length () {\n this._sortData()\n if (this._changedLength) {\n const last = this._data[this._data.length - 1]\n this._length = last ? last[0] + 1 : 0\n this._changedLength = false\n }\n return this._length\n }\n\n forEach (iterator) {\n let i = 0\n while(i < this.length) {\n iterator(this.get(i), i, this)\n i++\n }\n }\n\n map (iterator) {\n let i = 0\n let mapped = new Array(this.length)\n while(i < this.length) {\n mapped[i] = iterator(this.get(i), i, this)\n i++\n }\n return mapped\n }\n\n reduce (reducer, initialValue) {\n let i = 0\n let acc = initialValue\n while(i < this.length) {\n const value = this.get(i)\n acc = reducer(acc, value, i)\n i++\n }\n return acc\n }\n\n find (finder) {\n let i = 0, found, last\n while ((i < this.length) && !found) {\n last = this.get(i)\n found = finder(last)\n i++\n }\n return found ? last : undefined\n }\n\n _internalPositionFor (index, noCreate) {\n const bytePos = this._bytePosFor(index, noCreate)\n if (bytePos >= this._bitArrays.length) {\n return -1\n }\n const byte = this._bitArrays[bytePos]\n const bitPos = index - bytePos * BITS_PER_BYTE\n const exists = (byte & (1 << bitPos)) > 0\n if (!exists) {\n return -1\n }\n const previousPopCount = this._bitArrays.slice(0, bytePos).reduce(popCountReduce, 0)\n\n const mask = ~(0xffffffff << (bitPos + 1))\n const bytePopCount = popCount(byte & mask)\n const arrayPos = previousPopCount + bytePopCount - 1\n return arrayPos\n }\n\n _bytePosFor (index, noCreate) {\n const bytePos = Math.floor(index / BITS_PER_BYTE)\n const targetLength = bytePos + 1\n while (!noCreate && this._bitArrays.length < targetLength) {\n this._bitArrays.push(0)\n }\n return bytePos\n }\n\n _setBit (index) {\n const bytePos = this._bytePosFor(index, false)\n this._bitArrays[bytePos] |= (1 << (index - (bytePos * BITS_PER_BYTE)))\n }\n\n _unsetBit(index) {\n const bytePos = this._bytePosFor(index, false)\n this._bitArrays[bytePos] &= ~(1 << (index - (bytePos * BITS_PER_BYTE)))\n }\n\n _setInternalPos(pos, index, value, needsSort) {\n const data =this._data\n const elem = [index, value]\n if (needsSort) {\n this._sortData()\n data[pos] = elem\n } else {\n // new element. just shove it into the array\n // but be nice about where we shove it\n // in order to make sorting it later easier\n if (data.length) {\n if (data[data.length - 1][0] >= index) {\n data.push(elem)\n } else if (data[0][0] <= index) {\n data.unshift(elem)\n } else {\n const randomIndex = Math.round(data.length / 2)\n this._data = data.slice(0, randomIndex).concat(elem).concat(data.slice(randomIndex))\n }\n } else {\n this._data.push(elem)\n }\n this._changedData = true\n this._changedLength = true\n }\n }\n\n _unsetInternalPos (pos) {\n this._data.splice(pos, 1)\n }\n\n _sortData () {\n if (this._changedData) {\n this._data.sort(sortInternal)\n }\n\n this._changedData = false\n }\n\n bitField () {\n const bytes = []\n let pendingBitsForResultingByte = 8\n let pendingBitsForNewByte = 0\n let resultingByte = 0\n let newByte\n const pending = this._bitArrays.slice()\n while (pending.length || pendingBitsForNewByte) {\n if (pendingBitsForNewByte === 0) {\n newByte = pending.shift()\n pendingBitsForNewByte = 7\n }\n\n const usingBits = Math.min(pendingBitsForNewByte, pendingBitsForResultingByte)\n const mask = ~(0b11111111 << usingBits)\n const masked = newByte & mask\n resultingByte |= masked << (8 - pendingBitsForResultingByte)\n newByte = newByte >>> usingBits\n pendingBitsForNewByte -= usingBits\n pendingBitsForResultingByte -= usingBits\n\n if (!pendingBitsForResultingByte || (!pendingBitsForNewByte && !pending.length)) {\n bytes.push(resultingByte)\n resultingByte = 0\n pendingBitsForResultingByte = 8\n }\n }\n\n // remove trailing zeroes\n for(var i = bytes.length - 1; i > 0; i--) {\n const value = bytes[i]\n if (value === 0) {\n bytes.pop()\n } else {\n break\n }\n }\n\n return bytes\n }\n\n compactArray () {\n this._sortData()\n return this._data.map(valueOnly)\n }\n}\n\nfunction popCountReduce (count, byte) {\n return count + popCount(byte)\n}\n\nfunction popCount(_v) {\n let v = _v\n v = v - ((v >> 1) & 0x55555555) // reuse input as temporary\n v = (v & 0x33333333) + ((v >> 2) & 0x33333333) // temp\n return ((v + (v >> 4) & 0xF0F0F0F) * 0x1010101) >> 24\n}\n\nfunction sortInternal (a, b) {\n return a[0] - b[0]\n}\n\nfunction valueOnly (elem) {\n return elem[1]\n}","'use strict'\n\nconst ConsumableBuffer = require('./consumable-buffer')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\n\n/**\n * @param {(value: Uint8Array) => Promise} hashFn\n */\nfunction wrapHash (hashFn) {\n /**\n * @param {InfiniteHash | Uint8Array} value\n */\n function hashing (value) {\n if (value instanceof InfiniteHash) {\n // already a hash. return it\n return value\n } else {\n return new InfiniteHash(value, hashFn)\n }\n }\n\n return hashing\n}\n\nclass InfiniteHash {\n /**\n *\n * @param {Uint8Array} value\n * @param {(value: Uint8Array) => Promise} hashFn\n */\n constructor (value, hashFn) {\n if (!(value instanceof Uint8Array)) {\n throw new Error('can only hash Uint8Arrays')\n }\n\n this._value = value\n this._hashFn = hashFn\n this._depth = -1\n this._availableBits = 0\n this._currentBufferIndex = 0\n\n /** @type {ConsumableBuffer[]} */\n this._buffers = []\n }\n\n /**\n * @param {number} bits\n */\n async take (bits) {\n let pendingBits = bits\n\n while (this._availableBits < pendingBits) {\n await this._produceMoreBits()\n }\n\n let result = 0\n\n while (pendingBits > 0) {\n const hash = this._buffers[this._currentBufferIndex]\n const available = Math.min(hash.availableBits(), pendingBits)\n const took = hash.take(available)\n result = (result << available) + took\n pendingBits -= available\n this._availableBits -= available\n\n if (hash.availableBits() === 0) {\n this._currentBufferIndex++\n }\n }\n\n return result\n }\n\n /**\n * @param {number} bits\n */\n untake (bits) {\n let pendingBits = bits\n\n while (pendingBits > 0) {\n const hash = this._buffers[this._currentBufferIndex]\n const availableForUntake = Math.min(hash.totalBits() - hash.availableBits(), pendingBits)\n hash.untake(availableForUntake)\n pendingBits -= availableForUntake\n this._availableBits += availableForUntake\n\n if (this._currentBufferIndex > 0 && hash.totalBits() === hash.availableBits()) {\n this._depth--\n this._currentBufferIndex--\n }\n }\n }\n\n async _produceMoreBits () {\n this._depth++\n\n const value = this._depth ? uint8ArrayConcat([this._value, Uint8Array.from([this._depth])]) : this._value\n const hashValue = await this._hashFn(value)\n const buffer = new ConsumableBuffer(hashValue)\n\n this._buffers.push(buffer)\n this._availableBits += buffer.availableBits()\n }\n}\n\nmodule.exports = wrapHash\nmodule.exports.InfiniteHash = InfiniteHash\n","'use strict'\n\nconst START_MASKS = [\n 0b11111111,\n 0b11111110,\n 0b11111100,\n 0b11111000,\n 0b11110000,\n 0b11100000,\n 0b11000000,\n 0b10000000\n]\n\nconst STOP_MASKS = [\n 0b00000001,\n 0b00000011,\n 0b00000111,\n 0b00001111,\n 0b00011111,\n 0b00111111,\n 0b01111111,\n 0b11111111\n]\n\nmodule.exports = class ConsumableBuffer {\n /**\n * @param {Uint8Array} value\n */\n constructor (value) {\n this._value = value\n this._currentBytePos = value.length - 1\n this._currentBitPos = 7\n }\n\n availableBits () {\n return this._currentBitPos + 1 + this._currentBytePos * 8\n }\n\n totalBits () {\n return this._value.length * 8\n }\n\n /**\n * @param {number} bits\n */\n take (bits) {\n let pendingBits = bits\n let result = 0\n while (pendingBits && this._haveBits()) {\n const byte = this._value[this._currentBytePos]\n const availableBits = this._currentBitPos + 1\n const taking = Math.min(availableBits, pendingBits)\n const value = byteBitsToInt(byte, availableBits - taking, taking)\n result = (result << taking) + value\n\n pendingBits -= taking\n\n this._currentBitPos -= taking\n if (this._currentBitPos < 0) {\n this._currentBitPos = 7\n this._currentBytePos--\n }\n }\n\n return result\n }\n\n /**\n * @param {number} bits\n */\n untake (bits) {\n this._currentBitPos += bits\n while (this._currentBitPos > 7) {\n this._currentBitPos -= 8\n this._currentBytePos += 1\n }\n }\n\n _haveBits () {\n return this._currentBytePos >= 0\n }\n}\n\n/**\n * @param {number} byte\n * @param {number} start\n * @param {number} length\n */\nfunction byteBitsToInt (byte, start, length) {\n const mask = maskFor(start, length)\n return (byte & mask) >>> start\n}\n\n/**\n * @param {number} start\n * @param {number} length\n */\nfunction maskFor (start, length) {\n return START_MASKS[start] & STOP_MASKS[Math.min(length + start - 1, 7)]\n}\n","'use strict';\n\nconst toPathComponents = (path = '') => {\n return (path.trim().match(/([^\\\\^/]|\\\\\\/)+/g) || []).filter(Boolean);\n};\n\nmodule.exports = toPathComponents;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseContent = require('./normalise-content.js');\nvar normalise = require('./normalise.js');\n\nfunction normaliseInput(input) {\n return normalise.normalise(input, normaliseContent.normaliseContent);\n}\n\nexports.normaliseInput = normaliseInput;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar fromString = require('uint8arrays/from-string');\nvar browserStreamToIt = require('browser-readablestream-to-it');\nvar blobToIt = require('blob-to-it');\nvar itPeekable = require('it-peekable');\nvar all = require('it-all');\nvar map = require('it-map');\nvar utils = require('./utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar browserStreamToIt__default = /*#__PURE__*/_interopDefaultLegacy(browserStreamToIt);\nvar blobToIt__default = /*#__PURE__*/_interopDefaultLegacy(blobToIt);\nvar itPeekable__default = /*#__PURE__*/_interopDefaultLegacy(itPeekable);\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\n\nasync function normaliseContent(input) {\n return toAsyncGenerator(input);\n}\nasync function* toAsyncGenerator(input) {\n if (utils.isBytes(input)) {\n yield toBytes(input);\n return;\n }\n if (typeof input === 'string' || input instanceof String) {\n yield toBytes(input.toString());\n return;\n }\n if (utils.isBlob(input)) {\n yield* blobToIt__default['default'](input);\n return;\n }\n if (utils.isReadableStream(input)) {\n input = browserStreamToIt__default['default'](input);\n }\n if (Symbol.iterator in input || Symbol.asyncIterator in input) {\n const peekable = itPeekable__default['default'](input);\n const {value, done} = await peekable.peek();\n if (done) {\n yield* [];\n return;\n }\n peekable.push(value);\n if (Number.isInteger(value)) {\n yield Uint8Array.from(await all__default['default'](peekable));\n return;\n }\n if (utils.isBytes(value) || typeof value === 'string' || value instanceof String) {\n yield* map__default['default'](peekable, toBytes);\n return;\n }\n }\n throw errCode__default['default'](new Error(`Unexpected input: ${ input }`), 'ERR_UNEXPECTED_INPUT');\n}\nfunction toBytes(chunk) {\n if (chunk instanceof Uint8Array) {\n return chunk;\n }\n if (ArrayBuffer.isView(chunk)) {\n return new Uint8Array(chunk.buffer, chunk.byteOffset, chunk.byteLength);\n }\n if (chunk instanceof ArrayBuffer) {\n return new Uint8Array(chunk);\n }\n if (Array.isArray(chunk)) {\n return Uint8Array.from(chunk);\n }\n return fromString.fromString(chunk.toString());\n}\n\nexports.normaliseContent = normaliseContent;\n","'use strict'\n\n/**\n * Turns a browser readable stream into an async iterable. Async iteration over\n * returned iterable will lock give stream, preventing any other consumer from\n * acquiring a reader. The lock will be released if iteration loop is broken. To\n * prevent stream cancelling optional `{ preventCancel: true }` could be passed\n * as a second argument.\n * @template T\n * @param {ReadableStream} stream\n * @param {Object} [options]\n * @param {boolean} [options.preventCancel=boolean]\n * @returns {AsyncIterable}\n */\nasync function * browserReadableStreamToIt (stream, options = {}) {\n const reader = stream.getReader()\n\n try {\n while (true) {\n const result = await reader.read()\n\n if (result.done) {\n return\n }\n\n yield result.value\n }\n } finally {\n if (options.preventCancel !== true) {\n reader.cancel()\n }\n\n reader.releaseLock()\n }\n}\n\nmodule.exports = browserReadableStreamToIt\n","/* eslint-env browser */\n\n'use strict'\n\nconst browserReadableStreamToIt = require('browser-readablestream-to-it')\n\n/**\n * @param {Blob} blob\n * @returns {AsyncIterable}\n */\nfunction blobToIt (blob) {\n if (typeof blob.stream === 'function') {\n // @ts-ignore missing some properties\n return browserReadableStreamToIt(blob.stream())\n }\n\n // firefox < 69 does not support blob.stream()\n // @ts-ignore - response.body is optional, but in practice it's a stream.\n return browserReadableStreamToIt(new Response(blob).body)\n}\n\nmodule.exports = blobToIt\n","'use strict'\n\n/**\n * @template T\n * @typedef {Object} Peek\n * @property {() => IteratorResult} peek\n */\n\n/**\n * @template T\n * @typedef {Object} AsyncPeek\n * @property {() => Promise>} peek\n */\n\n/**\n * @template T\n * @typedef {Object} Push\n * @property {(value:T) => void} push\n */\n\n/**\n * @template T\n * @typedef {Iterable & Peek & Push & Iterator} Peekable\n */\n\n/**\n * @template T\n * @typedef {AsyncIterable & AsyncPeek & Push & AsyncIterator} AsyncPeekable\n */\n\n/**\n * @template {Iterable | AsyncIterable} I\n * @param {I} iterable\n * @returns {I extends Iterable\n * ? Peekable\n * : I extends AsyncIterable\n * ? AsyncPeekable\n * : never\n * }\n */\nfunction peekableIterator (iterable) {\n // @ts-ignore\n const [iterator, symbol] = iterable[Symbol.asyncIterator]\n // @ts-ignore\n ? [iterable[Symbol.asyncIterator](), Symbol.asyncIterator]\n // @ts-ignore\n : [iterable[Symbol.iterator](), Symbol.iterator]\n\n /** @type {any[]} */\n const queue = []\n\n // @ts-ignore\n return {\n peek: () => {\n return iterator.next()\n },\n push: (value) => {\n queue.push(value)\n },\n next: () => {\n if (queue.length) {\n return {\n done: false,\n value: queue.shift()\n }\n }\n\n return iterator.next()\n },\n [symbol] () {\n return this\n }\n }\n}\n\nmodule.exports = peekableIterator\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction isBytes(obj) {\n return ArrayBuffer.isView(obj) || obj instanceof ArrayBuffer;\n}\nfunction isBlob(obj) {\n return obj.constructor && (obj.constructor.name === 'Blob' || obj.constructor.name === 'File') && typeof obj.stream === 'function';\n}\nfunction isFileObject(obj) {\n return typeof obj === 'object' && (obj.path || obj.content);\n}\nconst isReadableStream = value => value && typeof value.getReader === 'function';\n\nexports.isBlob = isBlob;\nexports.isBytes = isBytes;\nexports.isFileObject = isFileObject;\nexports.isReadableStream = isReadableStream;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar browserStreamToIt = require('browser-readablestream-to-it');\nvar itPeekable = require('it-peekable');\nvar map = require('it-map');\nvar utils = require('./utils.js');\nvar ipfsUnixfs = require('ipfs-unixfs');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar browserStreamToIt__default = /*#__PURE__*/_interopDefaultLegacy(browserStreamToIt);\nvar itPeekable__default = /*#__PURE__*/_interopDefaultLegacy(itPeekable);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\n\nasync function* normalise(input, normaliseContent) {\n if (input === null || input === undefined) {\n throw errCode__default['default'](new Error(`Unexpected input: ${ input }`), 'ERR_UNEXPECTED_INPUT');\n }\n if (typeof input === 'string' || input instanceof String) {\n yield toFileObject(input.toString(), normaliseContent);\n return;\n }\n if (utils.isBytes(input) || utils.isBlob(input)) {\n yield toFileObject(input, normaliseContent);\n return;\n }\n if (utils.isReadableStream(input)) {\n input = browserStreamToIt__default['default'](input);\n }\n if (Symbol.iterator in input || Symbol.asyncIterator in input) {\n const peekable = itPeekable__default['default'](input);\n const {value, done} = await peekable.peek();\n if (done) {\n yield* [];\n return;\n }\n peekable.push(value);\n if (Number.isInteger(value) || utils.isBytes(value)) {\n yield toFileObject(peekable, normaliseContent);\n return;\n }\n if (value._readableState) {\n yield* map__default['default'](peekable, value => toFileObject({ content: value }, normaliseContent));\n return;\n }\n if (utils.isFileObject(value) || utils.isBlob(value) || typeof value === 'string' || value instanceof String) {\n yield* map__default['default'](peekable, value => toFileObject(value, normaliseContent));\n return;\n }\n if (value[Symbol.iterator] || value[Symbol.asyncIterator] || utils.isReadableStream(value)) {\n yield* map__default['default'](peekable, value => toFileObject(value, normaliseContent));\n return;\n }\n }\n if (utils.isFileObject(input)) {\n yield toFileObject(input, normaliseContent);\n return;\n }\n throw errCode__default['default'](new Error('Unexpected input: ' + typeof input), 'ERR_UNEXPECTED_INPUT');\n}\nasync function toFileObject(input, normaliseContent) {\n const {path, mode, mtime, content} = input;\n const file = {\n path: path || '',\n mode: ipfsUnixfs.parseMode(mode),\n mtime: ipfsUnixfs.parseMtime(mtime)\n };\n if (content) {\n file.content = await normaliseContent(content);\n } else if (!path) {\n file.content = await normaliseContent(input);\n }\n return file;\n}\n\nexports.normalise = normalise;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst parseChunkerString = chunker => {\n if (!chunker) {\n return { chunker: 'fixed' };\n } else if (chunker.startsWith('size-')) {\n const sizeStr = chunker.split('-')[1];\n const size = parseInt(sizeStr);\n if (isNaN(size)) {\n throw new Error('Chunker parameter size must be an integer');\n }\n return {\n chunker: 'fixed',\n maxChunkSize: size\n };\n } else if (chunker.startsWith('rabin')) {\n return {\n chunker: 'rabin',\n ...parseRabinString(chunker)\n };\n } else {\n throw new Error(`Unrecognized chunker option: ${ chunker }`);\n }\n};\nconst parseRabinString = chunker => {\n const options = {};\n const parts = chunker.split('-');\n switch (parts.length) {\n case 1:\n options.avgChunkSize = 262144;\n break;\n case 2:\n options.avgChunkSize = parseChunkSize(parts[1], 'avg');\n break;\n case 4:\n options.minChunkSize = parseChunkSize(parts[1], 'min');\n options.avgChunkSize = parseChunkSize(parts[2], 'avg');\n options.maxChunkSize = parseChunkSize(parts[3], 'max');\n break;\n default:\n throw new Error('Incorrect chunker format (expected \"rabin\" \"rabin-[avg]\" or \"rabin-[min]-[avg]-[max]\"');\n }\n return options;\n};\nconst parseChunkSize = (str, name) => {\n const size = parseInt(str);\n if (isNaN(size)) {\n throw new Error(`Chunker parameter ${ name } must be an integer`);\n }\n return size;\n};\n\nexports.parseChunkSize = parseChunkSize;\nexports.parseChunkerString = parseChunkerString;\nexports.parseRabinString = parseRabinString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar utils = require('../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar cid = require('multiformats/cid');\n\nfunction createCat({repo, preload}) {\n async function* cat(ipfsPath, options = {}) {\n ipfsPath = utils.normalizeCidPath(ipfsPath);\n if (options.preload !== false) {\n const pathComponents = ipfsPath.split('/');\n preload(cid.CID.parse(pathComponents[0]));\n }\n const file = await ipfsUnixfsExporter.exporter(ipfsPath, repo.blocks, options);\n if (file.type === 'directory') {\n throw new Error('this dag node is a directory');\n }\n if (!file.content) {\n throw new Error('this dag node has no content');\n }\n yield* file.content(options);\n }\n return withTimeoutOption.withTimeoutOption(cat);\n}\n\nexports.createCat = createCat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar cid = require('multiformats/cid');\nvar index = require('./resolvers/index.js');\nvar last = require('it-last');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst toPathComponents = (path = '') => {\n return (path.trim().match(/([^\\\\^/]|\\\\\\/)+/g) || []).filter(Boolean);\n};\nconst cidAndRest = path => {\n if (path instanceof Uint8Array) {\n return {\n cid: cid.CID.decode(path),\n toResolve: []\n };\n }\n const cid$1 = cid.CID.asCID(path);\n if (cid$1) {\n return {\n cid: cid$1,\n toResolve: []\n };\n }\n if (typeof path === 'string') {\n if (path.indexOf('/ipfs/') === 0) {\n path = path.substring(6);\n }\n const output = toPathComponents(path);\n return {\n cid: cid.CID.parse(output[0]),\n toResolve: output.slice(1)\n };\n }\n throw errCode__default['default'](new Error(`Unknown path type ${ path }`), 'ERR_BAD_PATH');\n};\nasync function* walkPath(path, blockstore, options = {}) {\n let {cid, toResolve} = cidAndRest(path);\n let name = cid.toString();\n let entryPath = name;\n const startingDepth = toResolve.length;\n while (true) {\n const result = await index(cid, name, entryPath, toResolve, startingDepth, blockstore, options);\n if (!result.entry && !result.next) {\n throw errCode__default['default'](new Error(`Could not resolve ${ path }`), 'ERR_NOT_FOUND');\n }\n if (result.entry) {\n yield result.entry;\n }\n if (!result.next) {\n return;\n }\n toResolve = result.next.toResolve;\n cid = result.next.cid;\n name = result.next.name;\n entryPath = result.next.path;\n }\n}\nasync function exporter(path, blockstore, options = {}) {\n const result = await last__default['default'](walkPath(path, blockstore, options));\n if (!result) {\n throw errCode__default['default'](new Error(`Could not resolve ${ path }`), 'ERR_NOT_FOUND');\n }\n return result;\n}\nasync function* recursive(path, blockstore, options = {}) {\n const node = await exporter(path, blockstore, options);\n if (!node) {\n return;\n }\n yield node;\n if (node.type === 'directory') {\n for await (const child of recurse(node, options)) {\n yield child;\n }\n }\n async function* recurse(node, options) {\n for await (const file of node.content(options)) {\n yield file;\n if (file instanceof Uint8Array) {\n continue;\n }\n if (file.type === 'directory') {\n yield* recurse(file, options);\n }\n }\n }\n}\n\nexports.exporter = exporter;\nexports.recursive = recursive;\nexports.walkPath = walkPath;\n","'use strict';\n\nvar errCode = require('err-code');\nvar dagPb = require('@ipld/dag-pb');\nvar dagCbor = require('@ipld/dag-cbor');\nvar raw = require('multiformats/codecs/raw');\nvar identity = require('multiformats/hashes/identity');\nvar index = require('./unixfs-v1/index.js');\nvar raw$1 = require('./raw.js');\nvar dagCbor$1 = require('./dag-cbor.js');\nvar identity$1 = require('./identity.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar dagCbor__namespace = /*#__PURE__*/_interopNamespace(dagCbor);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\n\nconst resolvers = {\n [dagPb__namespace.code]: index,\n [raw__namespace.code]: raw$1,\n [dagCbor__namespace.code]: dagCbor$1,\n [identity.identity.code]: identity$1\n};\nfunction resolve(cid, name, path, toResolve, depth, blockstore, options) {\n const resolver = resolvers[cid.code];\n if (!resolver) {\n throw errCode__default['default'](new Error(`No resolver for code ${ cid.code }`), 'ERR_NO_RESOLVER');\n }\n return resolver(cid, name, path, toResolve, resolve, depth, blockstore, options);\n}\n\nmodule.exports = resolve;\n","'use strict';\n\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar findCidInShard = require('../../utils/find-cid-in-shard.js');\nvar dagPb = require('@ipld/dag-pb');\nvar file = require('./content/file.js');\nvar directory = require('./content/directory.js');\nvar hamtShardedDirectory = require('./content/hamt-sharded-directory.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst findLinkCid = (node, name) => {\n const link = node.Links.find(link => link.Name === name);\n return link && link.Hash;\n};\nconst contentExporters = {\n raw: file,\n file: file,\n directory: directory,\n 'hamt-sharded-directory': hamtShardedDirectory,\n metadata: (cid, node, unixfs, path, resolve, depth, blockstore) => {\n return () => [];\n },\n symlink: (cid, node, unixfs, path, resolve, depth, blockstore) => {\n return () => [];\n }\n};\nconst unixFsResolver = async (cid, name, path, toResolve, resolve, depth, blockstore, options) => {\n const block = await blockstore.get(cid, options);\n const node = dagPb.decode(block);\n let unixfs;\n let next;\n if (!name) {\n name = cid.toString();\n }\n if (node.Data == null) {\n throw errCode__default['default'](new Error('no data in PBNode'), 'ERR_NOT_UNIXFS');\n }\n try {\n unixfs = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_NOT_UNIXFS');\n }\n if (!path) {\n path = name;\n }\n if (toResolve.length) {\n let linkCid;\n if (unixfs && unixfs.type === 'hamt-sharded-directory') {\n linkCid = await findCidInShard(node, toResolve[0], blockstore);\n } else {\n linkCid = findLinkCid(node, toResolve[0]);\n }\n if (!linkCid) {\n throw errCode__default['default'](new Error('file does not exist'), 'ERR_NOT_FOUND');\n }\n const nextName = toResolve.shift();\n const nextPath = `${ path }/${ nextName }`;\n next = {\n cid: linkCid,\n toResolve,\n name: nextName || '',\n path: nextPath\n };\n }\n return {\n entry: {\n type: unixfs.isDirectory() ? 'directory' : 'file',\n name,\n path,\n cid,\n content: contentExporters[unixfs.type](cid, node, unixfs, path, resolve, depth, blockstore),\n unixfs,\n depth,\n node,\n size: unixfs.fileSize()\n },\n next\n };\n};\n\nmodule.exports = unixFsResolver;\n","'use strict';\n\nvar hamtSharding = require('hamt-sharding');\nvar dagPb = require('@ipld/dag-pb');\nvar murmur3 = require('@multiformats/murmur3');\n\nconst hashFn = async function (buf) {\n return (await murmur3.murmur3128.encode(buf)).slice(0, 8).reverse();\n};\nconst addLinksToHamtBucket = (links, bucket, rootBucket) => {\n return Promise.all(links.map(link => {\n if (link.Name == null) {\n throw new Error('Unexpected Link without a Name');\n }\n if (link.Name.length === 2) {\n const pos = parseInt(link.Name, 16);\n return bucket._putObjectAt(pos, new hamtSharding.Bucket({\n hash: rootBucket._options.hash,\n bits: rootBucket._options.bits\n }, bucket, pos));\n }\n return rootBucket.put(link.Name.substring(2), true);\n }));\n};\nconst toPrefix = position => {\n return position.toString(16).toUpperCase().padStart(2, '0').substring(0, 2);\n};\nconst toBucketPath = position => {\n let bucket = position.bucket;\n const path = [];\n while (bucket._parent) {\n path.push(bucket);\n bucket = bucket._parent;\n }\n path.push(bucket);\n return path.reverse();\n};\nconst findShardCid = async (node, name, blockstore, context, options) => {\n if (!context) {\n const rootBucket = hamtSharding.createHAMT({ hashFn });\n context = {\n rootBucket,\n hamtDepth: 1,\n lastBucket: rootBucket\n };\n }\n await addLinksToHamtBucket(node.Links, context.lastBucket, context.rootBucket);\n const position = await context.rootBucket._findNewBucketAndPos(name);\n let prefix = toPrefix(position.pos);\n const bucketPath = toBucketPath(position);\n if (bucketPath.length > context.hamtDepth) {\n context.lastBucket = bucketPath[context.hamtDepth];\n prefix = toPrefix(context.lastBucket._posAtParent);\n }\n const link = node.Links.find(link => {\n if (link.Name == null) {\n return false;\n }\n const entryPrefix = link.Name.substring(0, 2);\n const entryName = link.Name.substring(2);\n if (entryPrefix !== prefix) {\n return false;\n }\n if (entryName && entryName !== name) {\n return false;\n }\n return true;\n });\n if (!link) {\n return null;\n }\n if (link.Name != null && link.Name.substring(2) === name) {\n return link.Hash;\n }\n context.hamtDepth++;\n const block = await blockstore.get(link.Hash, options);\n node = dagPb.decode(block);\n return findShardCid(node, name, blockstore, context, options);\n};\n\nmodule.exports = findShardCid;\n","'use strict';\n\nvar extractDataFromBlock = require('../../../utils/extract-data-from-block.js');\nvar validateOffsetAndLength = require('../../../utils/validate-offset-and-length.js');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar errCode = require('err-code');\nvar dagPb = require('@ipld/dag-pb');\nvar dagCbor = require('@ipld/dag-cbor');\nvar raw = require('multiformats/codecs/raw');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar dagCbor__namespace = /*#__PURE__*/_interopNamespace(dagCbor);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\n\nasync function* emitBytes(blockstore, node, start, end, streamPosition = 0, options) {\n if (node instanceof Uint8Array) {\n const buf = extractDataFromBlock(node, streamPosition, start, end);\n if (buf.length) {\n yield buf;\n }\n streamPosition += buf.length;\n return streamPosition;\n }\n if (node.Data == null) {\n throw errCode__default['default'](new Error('no data in PBNode'), 'ERR_NOT_UNIXFS');\n }\n let file;\n try {\n file = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_NOT_UNIXFS');\n }\n if (file.data && file.data.length) {\n const buf = extractDataFromBlock(file.data, streamPosition, start, end);\n if (buf.length) {\n yield buf;\n }\n streamPosition += file.data.length;\n }\n let childStart = streamPosition;\n for (let i = 0; i < node.Links.length; i++) {\n const childLink = node.Links[i];\n const childEnd = streamPosition + file.blockSizes[i];\n if (start >= childStart && start < childEnd || end > childStart && end <= childEnd || start < childStart && end > childEnd) {\n const block = await blockstore.get(childLink.Hash, { signal: options.signal });\n let child;\n switch (childLink.Hash.code) {\n case dagPb__namespace.code:\n child = await dagPb__namespace.decode(block);\n break;\n case raw__namespace.code:\n child = block;\n break;\n case dagCbor__namespace.code:\n child = await dagCbor__namespace.decode(block);\n break;\n default:\n throw Error(`Unsupported codec: ${ childLink.Hash.code }`);\n }\n for await (const buf of emitBytes(blockstore, child, start, end, streamPosition, options)) {\n streamPosition += buf.length;\n yield buf;\n }\n }\n streamPosition = childEnd;\n childStart = childEnd + 1;\n }\n}\nconst fileContent = (cid, node, unixfs, path, resolve, depth, blockstore) => {\n function yieldFileContent(options = {}) {\n const fileSize = unixfs.fileSize();\n if (fileSize === undefined) {\n throw new Error('File was a directory');\n }\n const {offset, length} = validateOffsetAndLength(fileSize, options.offset, options.length);\n const start = offset;\n const end = offset + length;\n return emitBytes(blockstore, node, start, end, 0, options);\n }\n return yieldFileContent;\n};\n\nmodule.exports = fileContent;\n","'use strict';\n\nfunction extractDataFromBlock(block, blockStart, requestedStart, requestedEnd) {\n const blockLength = block.length;\n const blockEnd = blockStart + blockLength;\n if (requestedStart >= blockEnd || requestedEnd < blockStart) {\n return new Uint8Array(0);\n }\n if (requestedEnd >= blockStart && requestedEnd < blockEnd) {\n block = block.slice(0, requestedEnd - blockStart);\n }\n if (requestedStart >= blockStart && requestedStart < blockEnd) {\n block = block.slice(requestedStart - blockStart);\n }\n return block;\n}\n\nmodule.exports = extractDataFromBlock;\n","'use strict';\n\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst validateOffsetAndLength = (size, offset, length) => {\n if (!offset) {\n offset = 0;\n }\n if (offset < 0) {\n throw errCode__default['default'](new Error('Offset must be greater than or equal to 0'), 'ERR_INVALID_PARAMS');\n }\n if (offset > size) {\n throw errCode__default['default'](new Error('Offset must be less than the file size'), 'ERR_INVALID_PARAMS');\n }\n if (!length && length !== 0) {\n length = size - offset;\n }\n if (length < 0) {\n throw errCode__default['default'](new Error('Length must be greater than or equal to 0'), 'ERR_INVALID_PARAMS');\n }\n if (offset + length > size) {\n length = size - offset;\n }\n return {\n offset,\n length\n };\n};\n\nmodule.exports = validateOffsetAndLength;\n","'use strict';\n\nconst directoryContent = (cid, node, unixfs, path, resolve, depth, blockstore) => {\n async function* yieldDirectoryContent(options = {}) {\n const offset = options.offset || 0;\n const length = options.length || node.Links.length;\n const links = node.Links.slice(offset, length);\n for (const link of links) {\n const result = await resolve(link.Hash, link.Name || '', `${ path }/${ link.Name || '' }`, [], depth + 1, blockstore, options);\n if (result.entry) {\n yield result.entry;\n }\n }\n }\n return yieldDirectoryContent;\n};\n\nmodule.exports = directoryContent;\n","'use strict';\n\nvar dagPb = require('@ipld/dag-pb');\n\nconst hamtShardedDirectoryContent = (cid, node, unixfs, path, resolve, depth, blockstore) => {\n function yieldHamtDirectoryContent(options = {}) {\n return listDirectory(node, path, resolve, depth, blockstore, options);\n }\n return yieldHamtDirectoryContent;\n};\nasync function* listDirectory(node, path, resolve, depth, blockstore, options) {\n const links = node.Links;\n for (const link of links) {\n const name = link.Name != null ? link.Name.substring(2) : null;\n if (name) {\n const result = await resolve(link.Hash, name, `${ path }/${ name }`, [], depth + 1, blockstore, options);\n yield result.entry;\n } else {\n const block = await blockstore.get(link.Hash);\n node = dagPb.decode(block);\n for await (const file of listDirectory(node, path, resolve, depth, blockstore, options)) {\n yield file;\n }\n }\n }\n}\n\nmodule.exports = hamtShardedDirectoryContent;\n","'use strict';\n\nvar errCode = require('err-code');\nvar extractDataFromBlock = require('../utils/extract-data-from-block.js');\nvar validateOffsetAndLength = require('../utils/validate-offset-and-length.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst rawContent = node => {\n async function* contentGenerator(options = {}) {\n const {offset, length} = validateOffsetAndLength(node.length, options.offset, options.length);\n yield extractDataFromBlock(node, 0, offset, offset + length);\n }\n return contentGenerator;\n};\nconst resolve = async (cid, name, path, toResolve, resolve, depth, blockstore, options) => {\n if (toResolve.length) {\n throw errCode__default['default'](new Error(`No link named ${ path } found in raw node ${ cid }`), 'ERR_NOT_FOUND');\n }\n const block = await blockstore.get(cid, options);\n return {\n entry: {\n type: 'raw',\n name,\n path,\n cid,\n content: rawContent(block),\n depth,\n size: block.length,\n node: block\n }\n };\n};\n\nmodule.exports = resolve;\n","'use strict';\n\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\nvar dagCbor = require('@ipld/dag-cbor');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagCbor__namespace = /*#__PURE__*/_interopNamespace(dagCbor);\n\nconst resolve = async (cid$1, name, path, toResolve, resolve, depth, blockstore, options) => {\n const block = await blockstore.get(cid$1);\n const object = dagCbor__namespace.decode(block);\n let subObject = object;\n let subPath = path;\n while (toResolve.length) {\n const prop = toResolve[0];\n if (prop in subObject) {\n toResolve.shift();\n subPath = `${ subPath }/${ prop }`;\n const subObjectCid = cid.CID.asCID(subObject[prop]);\n if (subObjectCid) {\n return {\n entry: {\n type: 'object',\n name,\n path,\n cid: cid$1,\n node: block,\n depth,\n size: block.length,\n content: async function* () {\n yield object;\n }\n },\n next: {\n cid: subObjectCid,\n name: prop,\n path: subPath,\n toResolve\n }\n };\n }\n subObject = subObject[prop];\n } else {\n throw errCode__default['default'](new Error(`No property named ${ prop } found in cbor node ${ cid$1 }`), 'ERR_NO_PROP');\n }\n }\n return {\n entry: {\n type: 'object',\n name,\n path,\n cid: cid$1,\n node: block,\n depth,\n size: block.length,\n content: async function* () {\n yield object;\n }\n }\n };\n};\n\nmodule.exports = resolve;\n","'use strict';\n\nvar errCode = require('err-code');\nvar extractDataFromBlock = require('../utils/extract-data-from-block.js');\nvar validateOffsetAndLength = require('../utils/validate-offset-and-length.js');\nvar mh = require('multiformats/hashes/digest');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar mh__namespace = /*#__PURE__*/_interopNamespace(mh);\n\nconst rawContent = node => {\n async function* contentGenerator(options = {}) {\n const {offset, length} = validateOffsetAndLength(node.length, options.offset, options.length);\n yield extractDataFromBlock(node, 0, offset, offset + length);\n }\n return contentGenerator;\n};\nconst resolve = async (cid, name, path, toResolve, resolve, depth, blockstore, options) => {\n if (toResolve.length) {\n throw errCode__default['default'](new Error(`No link named ${ path } found in raw node ${ cid }`), 'ERR_NOT_FOUND');\n }\n const buf = await mh__namespace.decode(cid.multihash.bytes);\n return {\n entry: {\n type: 'identity',\n name,\n path,\n cid,\n content: rawContent(buf.digest),\n depth,\n size: buf.digest.length,\n node: buf.digest\n }\n };\n};\n\nmodule.exports = resolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar errCode = require('err-code');\nvar utils = require('../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar cid = require('multiformats/cid');\nvar itTar = require('it-tar');\nvar itPipe = require('it-pipe');\nvar Pako = require('pako');\nvar map = require('it-map');\nvar toBuffer = require('it-to-buffer');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar Pako__default = /*#__PURE__*/_interopDefaultLegacy(Pako);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar toBuffer__default = /*#__PURE__*/_interopDefaultLegacy(toBuffer);\n\nconst DEFAULT_COMPRESSION_LEVEL = 6;\nfunction createGet({repo, preload}) {\n async function* get(ipfsPath, options = {}) {\n if (options.compressionLevel < 0 || options.compressionLevel > 9) {\n throw errCode__default['default'](new Error('Compression level must be between 1 and 9'), 'ERR_INVALID_PARAMS');\n }\n if (options.preload !== false) {\n let pathComponents;\n try {\n pathComponents = utils.normalizeCidPath(ipfsPath).split('/');\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_PATH');\n }\n preload(cid.CID.parse(pathComponents[0]));\n }\n const ipfsPathOrCid = cid.CID.asCID(ipfsPath) || ipfsPath;\n const file = await ipfsUnixfsExporter.exporter(ipfsPathOrCid, repo.blocks, options);\n if (file.type === 'file' || file.type === 'raw') {\n const args = [];\n if (!options.compress || options.archive === true) {\n args.push([{\n header: {\n name: file.path,\n mode: file.type === 'file' && file.unixfs.mode,\n mtime: file.type === 'file' && file.unixfs.mtime ? new Date(file.unixfs.mtime.secs * 1000) : undefined,\n size: file.size,\n type: 'file'\n },\n body: file.content()\n }], itTar.pack(), source => map__default['default'](source, buf => buf.slice()));\n } else {\n args.push(file.content);\n }\n if (options.compress) {\n args.push(async function* (source) {\n const buf = await toBuffer__default['default'](source);\n yield Pako__default['default'].gzip(buf, { level: options.compressionLevel || DEFAULT_COMPRESSION_LEVEL });\n });\n }\n yield* itPipe.pipe(...args);\n return;\n }\n if (file.type === 'directory') {\n const args = [\n ipfsUnixfsExporter.recursive(ipfsPathOrCid, repo.blocks, options),\n async function* (source) {\n for await (const entry of source) {\n const output = {\n header: {\n name: entry.path,\n size: entry.size\n }\n };\n if (entry.type === 'file') {\n output.header.type = 'file';\n output.header.mode = entry.unixfs.mode != null ? entry.unixfs.mode : undefined;\n output.header.mtime = entry.unixfs.mtime ? new Date(entry.unixfs.mtime.secs * 1000) : undefined;\n output.body = entry.content();\n } else if (entry.type === 'raw') {\n output.header.type = 'file';\n output.body = entry.content();\n } else if (entry.type === 'directory') {\n output.header.type = 'directory';\n output.header.mode = entry.unixfs.mode != null ? entry.unixfs.mode : undefined;\n output.header.mtime = entry.unixfs.mtime ? new Date(entry.unixfs.mtime.secs * 1000) : undefined;\n } else {\n throw errCode__default['default'](new Error('Not a UnixFS node'), 'ERR_NOT_UNIXFS');\n }\n yield output;\n }\n },\n itTar.pack(),\n source => map__default['default'](source, buf => buf.slice())\n ];\n if (options.compress) {\n if (!options.archive) {\n throw errCode__default['default'](new Error('file is not regular'), 'ERR_INVALID_PATH');\n }\n if (options.compress) {\n args.push(async function* (source) {\n const buf = await toBuffer__default['default'](source);\n yield Pako__default['default'].gzip(buf, { level: options.compressionLevel || DEFAULT_COMPRESSION_LEVEL });\n });\n }\n }\n yield* itPipe.pipe(...args);\n return;\n }\n throw errCode__default['default'](new Error('Not a UnixFS node'), 'ERR_NOT_UNIXFS');\n }\n return withTimeoutOption.withTimeoutOption(get);\n}\n\nexports.createGet = createGet;\n","exports.extract = require('./extract')\nexports.pack = require('./pack')\n","const defer = require('p-defer')\nconst Headers = require('./extract-headers')\nconst LteReader = require('./lte-reader')\n\nfunction getPadding (size) {\n size &= 511\n return size && 512 - size\n}\n\nasync function discardPadding (reader, size) {\n const overflow = getPadding(size)\n if (overflow) await reader.next(overflow)\n}\n\nmodule.exports = options => {\n options = options || {}\n options.highWaterMark = options.highWaterMark || 1024 * 16\n\n return source => (async function * () {\n const reader = LteReader(source)\n let gnuLongPath, gnuLongLinkPath, paxGlobal, pax\n\n try {\n while (true) {\n let headerBytes\n try {\n const { done, value } = await reader.next(512)\n if (done) return\n headerBytes = value\n } catch (err) {\n // Is ok, this is the end of the stream!\n if (err.code === 'ERR_UNDER_READ') return\n throw err\n }\n\n const header = Headers.decode(headerBytes, options.filenameEncoding)\n if (!header) continue\n\n if (header.type === 'gnu-long-path') {\n const { done, value: gnuLongPathBytes } = await reader.next(header.size)\n if (done) return\n gnuLongPath = Headers.decodeLongPath(gnuLongPathBytes, options.filenameEncoding)\n await discardPadding(reader, header.size)\n continue\n }\n\n if (header.type === 'gnu-long-link-path') {\n const { done, value: gnuLongLinkPathBytes } = await reader.next(header.size)\n if (done) return\n gnuLongLinkPath = Headers.decodeLongPath(gnuLongLinkPathBytes, options.filenameEncoding)\n await discardPadding(reader, header.size)\n continue\n }\n\n if (header.type === 'pax-global-header') {\n const { done, value: paxGlobalBytes } = await reader.next(header.size)\n if (done) return\n paxGlobal = Headers.decodePax(paxGlobalBytes, options.filenameEncoding)\n await discardPadding(reader, header.size)\n continue\n }\n\n if (header.type === 'pax-header') {\n const { done, value: paxBytes } = await reader.next(header.size)\n if (done) return\n pax = Headers.decodePax(paxBytes, options.filenameEncoding)\n if (paxGlobal) pax = { ...paxGlobal, ...pax }\n await discardPadding(reader, header.size)\n continue\n }\n\n if (gnuLongPath) {\n header.name = gnuLongPath\n gnuLongPath = null\n }\n\n if (gnuLongLinkPath) {\n header.linkname = gnuLongLinkPath\n gnuLongLinkPath = null\n }\n\n if (pax) {\n if (pax.path) header.name = pax.path\n if (pax.linkpath) header.linkname = pax.linkpath\n if (pax.size) header.size = parseInt(pax.size, 10)\n header.pax = pax\n pax = null\n }\n\n if (!header.size || header.type === 'directory') {\n yield { header, body: (async function * () {})() }\n continue\n }\n\n let bytesRemaining = header.size\n const bodyConsumed = defer()\n\n // Prefetch the first chunk.\n // This allows us to stream entries for small files from the tar without\n // explicitly streaming the body of each.\n const firstChunk = await reader.nextLte(Math.min(bytesRemaining, options.highWaterMark))\n bytesRemaining -= firstChunk.value.length\n\n if (!bytesRemaining) bodyConsumed.resolve()\n\n const body = (async function * () {\n try {\n yield firstChunk.value\n\n while (bytesRemaining) {\n const { done, value } = await reader.nextLte(bytesRemaining)\n if (done) {\n bytesRemaining = 0\n return\n }\n bytesRemaining -= value.length\n yield value\n }\n } finally {\n bodyConsumed.resolve()\n }\n })()\n\n yield { header, body }\n\n // Wait for the body to be consumed\n await bodyConsumed.promise\n\n // Incase the body was not consumed entirely...\n if (bytesRemaining) {\n for await (const _ of body) {} // eslint-disable-line no-unused-vars,no-empty\n }\n\n await discardPadding(reader, header.size)\n }\n } finally {\n await reader.return()\n }\n })()\n}\n","const { Buffer } = require('buffer')\nconst BufferList = require('bl/BufferList')\n\nconst ZERO_OFFSET = '0'.charCodeAt(0)\nconst USTAR_MAGIC = Buffer.from('ustar\\x00', 'binary')\nconst GNU_MAGIC = Buffer.from('ustar\\x20', 'binary')\nconst GNU_VER = Buffer.from('\\x20\\x00', 'binary')\nconst MAGIC_OFFSET = 257\nconst VERSION_OFFSET = 263\n\nconst clamp = function (index, len, defaultValue) {\n if (typeof index !== 'number') return defaultValue\n index = ~~index // Coerce to integer.\n if (index >= len) return len\n if (index >= 0) return index\n index += len\n if (index >= 0) return index\n return 0\n}\n\nconst toType = function (flag) {\n switch (flag) {\n case 0:\n return 'file'\n case 1:\n return 'link'\n case 2:\n return 'symlink'\n case 3:\n return 'character-device'\n case 4:\n return 'block-device'\n case 5:\n return 'directory'\n case 6:\n return 'fifo'\n case 7:\n return 'contiguous-file'\n case 72:\n return 'pax-header'\n case 55:\n return 'pax-global-header'\n case 27:\n return 'gnu-long-link-path'\n case 28:\n case 30:\n return 'gnu-long-path'\n }\n\n return null\n}\n\nconst indexOf = function (block, num, offset, end) {\n for (; offset < end; offset++) {\n if (block.get(offset) === num) return offset\n }\n return end\n}\n\nconst cksum = function (block) {\n let sum = 8 * 32\n for (let i = 0; i < 148; i++) sum += block.get(i)\n for (let j = 156; j < 512; j++) sum += block.get(j)\n return sum\n}\n\n/* Copied from the node-tar repo and modified to meet\n * tar-stream coding standard.\n *\n * Source: https://github.com/npm/node-tar/blob/51b6627a1f357d2eb433e7378e5f05e83b7aa6cd/lib/header.js#L349\n */\nfunction parse256 (buf) {\n // first byte MUST be either 80 or FF\n // 80 for positive, FF for 2's comp\n let positive\n if (buf.get(0) === 0x80) positive = true\n else if (buf.get(0) === 0xFF) positive = false\n else return null\n\n // build up a base-256 tuple from the least sig to the highest\n let zero = false\n const tuple = []\n for (let i = buf.length - 1; i > 0; i--) {\n const byte = buf.get(i)\n if (positive) tuple.push(byte)\n else if (zero && byte === 0) tuple.push(0)\n else if (zero) {\n zero = false\n tuple.push(0x100 - byte)\n } else tuple.push(0xFF - byte)\n }\n\n let sum = 0\n const l = tuple.length\n for (let i = 0; i < l; i++) {\n sum += tuple[i] * Math.pow(256, i)\n }\n\n return positive ? sum : -1 * sum\n}\n\nconst decodeOct = function (val, offset, length) {\n val = val.shallowSlice(offset, offset + length)\n offset = 0\n\n // If prefixed with 0x80 then parse as a base-256 integer\n if (val.get(offset) & 0x80) {\n return parse256(val)\n } else {\n // Older versions of tar can prefix with spaces\n while (offset < val.length && val.get(offset) === 32) offset++\n const end = clamp(indexOf(val, 32, offset, val.length), val.length, val.length)\n while (offset < end && val.get(offset) === 0) offset++\n if (end === offset) return 0\n return parseInt(val.shallowSlice(offset, end).toString(), 8)\n }\n}\n\nconst decodeStr = function (val, offset, length, encoding) {\n return val.shallowSlice(offset, indexOf(val, 0, offset, offset + length)).toString(encoding)\n}\n\nexports.decodeLongPath = function (buf, encoding) {\n buf = BufferList.isBufferList(buf) ? buf : new BufferList(buf)\n return decodeStr(buf, 0, buf.length, encoding)\n}\n\nexports.decodePax = function (buf) {\n buf = BufferList.isBufferList(buf) ? buf : new BufferList(buf)\n const result = {}\n\n while (buf.length) {\n let i = 0\n while (i < buf.length && buf.get(i) !== 32) i++\n const len = parseInt(buf.shallowSlice(0, i).toString(), 10)\n if (!len) return result\n\n const b = buf.shallowSlice(i + 1, len - 1).toString()\n const keyIndex = b.indexOf('=')\n if (keyIndex === -1) return result\n result[b.slice(0, keyIndex)] = b.slice(keyIndex + 1)\n\n buf = buf.shallowSlice(len)\n }\n\n return result\n}\n\nexports.decode = function (buf, filenameEncoding) {\n buf = BufferList.isBufferList(buf) ? buf : new BufferList(buf)\n let typeflag = buf.get(156) === 0 ? 0 : buf.get(156) - ZERO_OFFSET\n\n let name = decodeStr(buf, 0, 100, filenameEncoding)\n const mode = decodeOct(buf, 100, 8)\n const uid = decodeOct(buf, 108, 8)\n const gid = decodeOct(buf, 116, 8)\n const size = decodeOct(buf, 124, 12)\n const mtime = decodeOct(buf, 136, 12)\n const type = toType(typeflag)\n const linkname = buf.get(157) === 0 ? null : decodeStr(buf, 157, 100, filenameEncoding)\n const uname = decodeStr(buf, 265, 32)\n const gname = decodeStr(buf, 297, 32)\n const devmajor = decodeOct(buf, 329, 8)\n const devminor = decodeOct(buf, 337, 8)\n\n const c = cksum(buf)\n\n // checksum is still initial value if header was null.\n if (c === 8 * 32) return null\n\n // valid checksum\n if (c !== decodeOct(buf, 148, 8)) throw new Error('Invalid tar header. Maybe the tar is corrupted or it needs to be gunzipped?')\n\n if (USTAR_MAGIC.compare(buf.slice(MAGIC_OFFSET, MAGIC_OFFSET + 6)) === 0) {\n // ustar (posix) format.\n // prepend prefix, if present.\n if (buf.get(345)) name = decodeStr(buf, 345, 155, filenameEncoding) + '/' + name\n } else if (GNU_MAGIC.compare(buf.slice(MAGIC_OFFSET, MAGIC_OFFSET + 6)) === 0 &&\n GNU_VER.compare(buf.slice(VERSION_OFFSET, VERSION_OFFSET + 2)) === 0) {\n // 'gnu'/'oldgnu' format. Similar to ustar, but has support for incremental and\n // multi-volume tarballs.\n } else {\n throw new Error('Invalid tar header: unknown format.')\n }\n\n // to support old tar versions that use trailing / to indicate dirs\n if (typeflag === 0 && name && name[name.length - 1] === '/') typeflag = 5\n\n return {\n name: name,\n mode: mode,\n uid: uid,\n gid: gid,\n size: size,\n mtime: new Date(1000 * mtime),\n type: type,\n linkname: linkname,\n uname: uname,\n gname: gname,\n devmajor: devmajor,\n devminor: devminor\n }\n}\n","const BufferList = require('bl/BufferList')\nconst Reader = require('it-reader')\n\nmodule.exports = function LteReader (source) {\n const reader = Reader(source)\n let overflow\n const lteReader = {\n [Symbol.asyncIterator]: () => lteReader,\n async next (bytes) {\n if (overflow) {\n let value\n if (bytes == null || overflow.length === bytes) {\n value = overflow\n overflow = null\n } else if (overflow.length > bytes) {\n value = overflow.shallowSlice(0, bytes)\n overflow = overflow.shallowSlice(bytes)\n } else if (overflow.length < bytes) {\n const { value: nextValue, done } = await reader.next(bytes - overflow.length)\n if (done) {\n throw Object.assign(\n new Error(`stream ended before ${bytes - overflow.length} bytes became available`),\n { code: 'ERR_UNDER_READ' }\n )\n }\n value = new BufferList([overflow, nextValue])\n overflow = null\n }\n return { value }\n }\n return reader.next(bytes)\n },\n async nextLte (bytes) {\n let { done, value } = await lteReader.next()\n if (done) return { done }\n if (value.length <= bytes) return { value }\n value = BufferList.isBufferList(value) ? value : new BufferList(value)\n if (overflow) {\n overflow.append(value.shallowSlice(bytes))\n } else {\n overflow = value.shallowSlice(bytes)\n }\n return { value: value.shallowSlice(0, bytes) }\n },\n return () {\n return reader.return()\n }\n }\n return lteReader\n}\n","const BufferList = require('bl/BufferList')\n\nmodule.exports = source => {\n const reader = (async function * () {\n let bytes = yield // Allows us to receive 8 when reader.next(8) is called\n let bl = new BufferList()\n\n for await (const chunk of source) {\n if (!bytes) {\n bytes = yield bl.append(chunk)\n bl = new BufferList()\n continue\n }\n\n bl.append(chunk)\n\n while (bl.length >= bytes) {\n const data = bl.shallowSlice(0, bytes)\n bl.consume(bytes)\n bytes = yield data\n\n // If we no longer want a specific byte length, we yield the rest now\n if (!bytes) {\n if (bl.length) {\n bytes = yield bl\n bl = new BufferList()\n }\n break // bytes is null and/or no more buffer to yield\n }\n }\n }\n\n // Consumer wants more bytes but the source has ended and our buffer\n // is not big enough to satisfy.\n if (bytes) {\n throw Object.assign(\n new Error(`stream ended before ${bytes} bytes became available`),\n { code: 'ERR_UNDER_READ', buffer: bl }\n )\n }\n })()\n\n reader.next()\n return reader\n}\n","const { Buffer } = require('buffer')\nconst BufferList = require('bl/BufferList')\nconst { S_IFMT, S_IFBLK, S_IFCHR, S_IFDIR, S_IFIFO, S_IFLNK } = require('iso-constants')\nconst concat = require('it-concat')\nconst Headers = require('./pack-headers')\n\nconst DMODE = parseInt('755', 8)\nconst FMODE = parseInt('644', 8)\n\nconst END_OF_TAR = Buffer.alloc(1024)\n\nfunction modeToType (mode) {\n switch (mode & S_IFMT) {\n case S_IFBLK: return 'block-device'\n case S_IFCHR: return 'character-device'\n case S_IFDIR: return 'directory'\n case S_IFIFO: return 'fifo'\n case S_IFLNK: return 'symlink'\n }\n return 'file'\n}\n\nfunction getPadding (size) {\n size &= 511\n if (size) return new BufferList(END_OF_TAR.slice(0, 512 - size))\n}\n\nfunction encode (header) {\n if (!header.pax) {\n const encoded = Headers.encode(header)\n if (encoded) return encoded\n }\n return encodePax(header)\n}\n\nfunction encodePax (header) {\n const paxHeader = Headers.encodePax({\n name: header.name,\n linkname: header.linkname,\n pax: header.pax\n })\n\n const newHeader = {\n name: 'PaxHeader',\n mode: header.mode,\n uid: header.uid,\n gid: header.gid,\n size: paxHeader.length,\n mtime: header.mtime,\n type: 'pax-header',\n linkname: header.linkname && 'PaxHeader',\n uname: header.uname,\n gname: header.gname,\n devmajor: header.devmajor,\n devminor: header.devminor\n }\n\n return new BufferList([\n Headers.encode(newHeader),\n paxHeader,\n getPadding(paxHeader.length),\n Headers.encode({ ...newHeader, size: header.size, type: header.type })\n ])\n}\n\nmodule.exports = () => async function * (source) {\n for await (let { header, body } of source) {\n if (!header.size || header.type === 'symlink') header.size = 0\n if (!header.type) header.type = modeToType(header.mode)\n if (!header.mode) header.mode = header.type === 'directory' ? DMODE : FMODE\n if (!header.uid) header.uid = 0\n if (!header.gid) header.gid = 0\n if (!header.mtime) header.mtime = new Date()\n\n if (typeof body === 'string') body = Buffer.from(body)\n\n if (Buffer.isBuffer(body) || BufferList.isBufferList(body)) {\n header.size = body.length\n yield new BufferList([encode(header), body, getPadding(header.size)])\n continue\n }\n\n if (header.type === 'symlink' && !header.linkname) {\n header.linkname = (await concat(body)).toString()\n yield encode(header)\n continue\n }\n\n yield encode(header)\n\n if (header.type !== 'file' && header.type !== 'contiguous-file') {\n continue\n }\n\n let written = 0\n for await (const chunk of body) {\n written += chunk.length\n yield BufferList.isBufferList(chunk) ? chunk : new BufferList(chunk)\n }\n\n if (written !== header.size) { // corrupting tar\n throw new Error('size mismatch')\n }\n\n const overflow = getPadding(header.size)\n if (overflow) yield overflow\n }\n\n yield new BufferList(END_OF_TAR)\n}\n","\n'use strict';\n\nmodule.exports = {\n 'RTLD_LAZY': 1,\n 'RTLD_NOW': 2,\n 'RTLD_GLOBAL': 256,\n 'RTLD_LOCAL': 0,\n 'RTLD_DEEPBIND': 8,\n 'E2BIG': 7,\n 'EACCES': 13,\n 'EADDRINUSE': 98,\n 'EADDRNOTAVAIL': 99,\n 'EAFNOSUPPORT': 97,\n 'EAGAIN': 11,\n 'EALREADY': 114,\n 'EBADF': 9,\n 'EBADMSG': 74,\n 'EBUSY': 16,\n 'ECANCELED': 125,\n 'ECHILD': 10,\n 'ECONNABORTED': 103,\n 'ECONNREFUSED': 111,\n 'ECONNRESET': 104,\n 'EDEADLK': 35,\n 'EDESTADDRREQ': 89,\n 'EDOM': 33,\n 'EDQUOT': 122,\n 'EEXIST': 17,\n 'EFAULT': 14,\n 'EFBIG': 27,\n 'EHOSTUNREACH': 113,\n 'EIDRM': 43,\n 'EILSEQ': 84,\n 'EINPROGRESS': 115,\n 'EINTR': 4,\n 'EINVAL': 22,\n 'EIO': 5,\n 'EISCONN': 106,\n 'EISDIR': 21,\n 'ELOOP': 40,\n 'EMFILE': 24,\n 'EMLINK': 31,\n 'EMSGSIZE': 90,\n 'EMULTIHOP': 72,\n 'ENAMETOOLONG': 36,\n 'ENETDOWN': 100,\n 'ENETRESET': 102,\n 'ENETUNREACH': 101,\n 'ENFILE': 23,\n 'ENOBUFS': 105,\n 'ENODATA': 61,\n 'ENODEV': 19,\n 'ENOENT': 2,\n 'ENOEXEC': 8,\n 'ENOLCK': 37,\n 'ENOLINK': 67,\n 'ENOMEM': 12,\n 'ENOMSG': 42,\n 'ENOPROTOOPT': 92,\n 'ENOSPC': 28,\n 'ENOSR': 63,\n 'ENOSTR': 60,\n 'ENOSYS': 38,\n 'ENOTCONN': 107,\n 'ENOTDIR': 20,\n 'ENOTEMPTY': 39,\n 'ENOTSOCK': 88,\n 'ENOTSUP': 95,\n 'ENOTTY': 25,\n 'ENXIO': 6,\n 'EOPNOTSUPP': 95,\n 'EOVERFLOW': 75,\n 'EPERM': 1,\n 'EPIPE': 32,\n 'EPROTO': 71,\n 'EPROTONOSUPPORT': 93,\n 'EPROTOTYPE': 91,\n 'ERANGE': 34,\n 'EROFS': 30,\n 'ESPIPE': 29,\n 'ESRCH': 3,\n 'ESTALE': 116,\n 'ETIME': 62,\n 'ETIMEDOUT': 110,\n 'ETXTBSY': 26,\n 'EWOULDBLOCK': 11,\n 'EXDEV': 18,\n 'PRIORITY_LOW': 19,\n 'PRIORITY_BELOW_NORMAL': 10,\n 'PRIORITY_NORMAL': 0,\n 'PRIORITY_ABOVE_NORMAL': -7,\n 'PRIORITY_HIGH': -14,\n 'PRIORITY_HIGHEST': -20,\n 'SIGHUP': 1,\n 'SIGINT': 2,\n 'SIGQUIT': 3,\n 'SIGILL': 4,\n 'SIGTRAP': 5,\n 'SIGABRT': 6,\n 'SIGIOT': 6,\n 'SIGBUS': 7,\n 'SIGFPE': 8,\n 'SIGKILL': 9,\n 'SIGUSR1': 10,\n 'SIGSEGV': 11,\n 'SIGUSR2': 12,\n 'SIGPIPE': 13,\n 'SIGALRM': 14,\n 'SIGTERM': 15,\n 'SIGCHLD': 17,\n 'SIGSTKFLT': 16,\n 'SIGCONT': 18,\n 'SIGSTOP': 19,\n 'SIGTSTP': 20,\n 'SIGTTIN': 21,\n 'SIGTTOU': 22,\n 'SIGURG': 23,\n 'SIGXCPU': 24,\n 'SIGXFSZ': 25,\n 'SIGVTALRM': 26,\n 'SIGPROF': 27,\n 'SIGWINCH': 28,\n 'SIGIO': 29,\n 'SIGPOLL': 29,\n 'SIGPWR': 30,\n 'SIGSYS': 31,\n 'SIGUNUSED': 31,\n 'UV_FS_SYMLINK_DIR': 1,\n 'UV_FS_SYMLINK_JUNCTION': 2,\n 'O_RDONLY': 0,\n 'O_WRONLY': 1,\n 'O_RDWR': 2,\n 'UV_DIRENT_UNKNOWN': 0,\n 'UV_DIRENT_FILE': 1,\n 'UV_DIRENT_DIR': 2,\n 'UV_DIRENT_LINK': 3,\n 'UV_DIRENT_FIFO': 4,\n 'UV_DIRENT_SOCKET': 5,\n 'UV_DIRENT_CHAR': 6,\n 'UV_DIRENT_BLOCK': 7,\n 'S_IFMT': 61440,\n 'S_IFREG': 32768,\n 'S_IFDIR': 16384,\n 'S_IFCHR': 8192,\n 'S_IFBLK': 24576,\n 'S_IFIFO': 4096,\n 'S_IFLNK': 40960,\n 'S_IFSOCK': 49152,\n 'O_CREAT': 64,\n 'O_EXCL': 128,\n 'UV_FS_O_FILEMAP': 0,\n 'O_NOCTTY': 256,\n 'O_TRUNC': 512,\n 'O_APPEND': 1024,\n 'O_DIRECTORY': 65536,\n 'O_NOATIME': 262144,\n 'O_NOFOLLOW': 131072,\n 'O_SYNC': 1052672,\n 'O_DSYNC': 4096,\n 'O_DIRECT': 16384,\n 'O_NONBLOCK': 2048,\n 'S_IRWXU': 448,\n 'S_IRUSR': 256,\n 'S_IWUSR': 128,\n 'S_IXUSR': 64,\n 'S_IRWXG': 56,\n 'S_IRGRP': 32,\n 'S_IWGRP': 16,\n 'S_IXGRP': 8,\n 'S_IRWXO': 7,\n 'S_IROTH': 4,\n 'S_IWOTH': 2,\n 'S_IXOTH': 1,\n 'F_OK': 0,\n 'R_OK': 4,\n 'W_OK': 2,\n 'X_OK': 1,\n 'UV_FS_COPYFILE_EXCL': 1,\n 'COPYFILE_EXCL': 1,\n 'UV_FS_COPYFILE_FICLONE': 2,\n 'COPYFILE_FICLONE': 2,\n 'UV_FS_COPYFILE_FICLONE_FORCE': 4,\n 'COPYFILE_FICLONE_FORCE': 4,\n 'OPENSSL_VERSION_NUMBER': 269488319,\n 'SSL_OP_ALL': 2147485780,\n 'SSL_OP_ALLOW_NO_DHE_KEX': 1024,\n 'SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION': 262144,\n 'SSL_OP_CIPHER_SERVER_PREFERENCE': 4194304,\n 'SSL_OP_CISCO_ANYCONNECT': 32768,\n 'SSL_OP_COOKIE_EXCHANGE': 8192,\n 'SSL_OP_CRYPTOPRO_TLSEXT_BUG': 2147483648,\n 'SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS': 2048,\n 'SSL_OP_EPHEMERAL_RSA': 0,\n 'SSL_OP_LEGACY_SERVER_CONNECT': 4,\n 'SSL_OP_MICROSOFT_BIG_SSLV3_BUFFER': 0,\n 'SSL_OP_MICROSOFT_SESS_ID_BUG': 0,\n 'SSL_OP_MSIE_SSLV2_RSA_PADDING': 0,\n 'SSL_OP_NETSCAPE_CA_DN_BUG': 0,\n 'SSL_OP_NETSCAPE_CHALLENGE_BUG': 0,\n 'SSL_OP_NETSCAPE_DEMO_CIPHER_CHANGE_BUG': 0,\n 'SSL_OP_NETSCAPE_REUSE_CIPHER_CHANGE_BUG': 0,\n 'SSL_OP_NO_COMPRESSION': 131072,\n 'SSL_OP_NO_ENCRYPT_THEN_MAC': 524288,\n 'SSL_OP_NO_QUERY_MTU': 4096,\n 'SSL_OP_NO_RENEGOTIATION': 1073741824,\n 'SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION': 65536,\n 'SSL_OP_NO_SSLv2': 0,\n 'SSL_OP_NO_SSLv3': 33554432,\n 'SSL_OP_NO_TICKET': 16384,\n 'SSL_OP_NO_TLSv1': 67108864,\n 'SSL_OP_NO_TLSv1_1': 268435456,\n 'SSL_OP_NO_TLSv1_2': 134217728,\n 'SSL_OP_NO_TLSv1_3': 536870912,\n 'SSL_OP_PKCS1_CHECK_1': 0,\n 'SSL_OP_PKCS1_CHECK_2': 0,\n 'SSL_OP_PRIORITIZE_CHACHA': 2097152,\n 'SSL_OP_SINGLE_DH_USE': 0,\n 'SSL_OP_SINGLE_ECDH_USE': 0,\n 'SSL_OP_SSLEAY_080_CLIENT_DH_BUG': 0,\n 'SSL_OP_SSLREF2_REUSE_CERT_TYPE_BUG': 0,\n 'SSL_OP_TLS_BLOCK_PADDING_BUG': 0,\n 'SSL_OP_TLS_D5_BUG': 0,\n 'SSL_OP_TLS_ROLLBACK_BUG': 8388608,\n 'ENGINE_METHOD_RSA': 1,\n 'ENGINE_METHOD_DSA': 2,\n 'ENGINE_METHOD_DH': 4,\n 'ENGINE_METHOD_RAND': 8,\n 'ENGINE_METHOD_EC': 2048,\n 'ENGINE_METHOD_CIPHERS': 64,\n 'ENGINE_METHOD_DIGESTS': 128,\n 'ENGINE_METHOD_PKEY_METHS': 512,\n 'ENGINE_METHOD_PKEY_ASN1_METHS': 1024,\n 'ENGINE_METHOD_ALL': 65535,\n 'ENGINE_METHOD_NONE': 0,\n 'DH_CHECK_P_NOT_SAFE_PRIME': 2,\n 'DH_CHECK_P_NOT_PRIME': 1,\n 'DH_UNABLE_TO_CHECK_GENERATOR': 4,\n 'DH_NOT_SUITABLE_GENERATOR': 8,\n 'ALPN_ENABLED': 1,\n 'RSA_PKCS1_PADDING': 1,\n 'RSA_SSLV23_PADDING': 2,\n 'RSA_NO_PADDING': 3,\n 'RSA_PKCS1_OAEP_PADDING': 4,\n 'RSA_X931_PADDING': 5,\n 'RSA_PKCS1_PSS_PADDING': 6,\n 'RSA_PSS_SALTLEN_DIGEST': -1,\n 'RSA_PSS_SALTLEN_MAX_SIGN': -2,\n 'RSA_PSS_SALTLEN_AUTO': -2,\n 'defaultCoreCipherList': 'TLS_AES_256_GCM_SHA384:TLS_CHACHA20_POLY1305_SHA256:TLS_AES_128_GCM_SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA384:DHE-RSA-AES256-SHA384:ECDHE-RSA-AES256-SHA256:DHE-RSA-AES256-SHA256:HIGH:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!SRP:!CAMELLIA',\n 'TLS1_VERSION': 769,\n 'TLS1_1_VERSION': 770,\n 'TLS1_2_VERSION': 771,\n 'TLS1_3_VERSION': 772,\n 'POINT_CONVERSION_COMPRESSED': 2,\n 'POINT_CONVERSION_UNCOMPRESSED': 4,\n 'POINT_CONVERSION_HYBRID': 6\n};\n\n","const BufferList = require('bl/BufferList')\n\nconst TypeDefault = {\n string: () => '',\n buffer: () => BufferList()\n}\n\nmodule.exports = async (source, options) => {\n options = options || {}\n\n if (options.type && !TypeDefault[options.type]) {\n throw new Error(`invalid type \"${options.type}\"`)\n }\n\n let res, type\n for await (const chunk of source) {\n if (!res) {\n type = options.type || (typeof chunk === 'string' ? 'string' : 'buffer')\n res = TypeDefault[type]()\n }\n\n if (type === 'string') {\n res += chunk\n } else {\n res.append(chunk)\n }\n }\n\n return res || TypeDefault[options.type || 'buffer']()\n}\n","const { Buffer } = require('buffer')\n\nconst alloc = Buffer.alloc\n\nconst ZEROS = '0000000000000000000'\nconst SEVENS = '7777777777777777777'\nconst ZERO_OFFSET = '0'.charCodeAt(0)\nconst USTAR_MAGIC = Buffer.from('ustar\\x00', 'binary')\nconst USTAR_VER = Buffer.from('00', 'binary')\nconst MASK = parseInt('7777', 8)\nconst MAGIC_OFFSET = 257\nconst VERSION_OFFSET = 263\n\nconst toTypeflag = function (flag) {\n switch (flag) {\n case 'file':\n return 0\n case 'link':\n return 1\n case 'symlink':\n return 2\n case 'character-device':\n return 3\n case 'block-device':\n return 4\n case 'directory':\n return 5\n case 'fifo':\n return 6\n case 'contiguous-file':\n return 7\n case 'pax-header':\n return 72\n }\n\n return 0\n}\n\nconst cksum = function (block) {\n let sum = 8 * 32\n for (let i = 0; i < 148; i++) sum += block[i]\n for (let j = 156; j < 512; j++) sum += block[j]\n return sum\n}\n\nconst encodeOct = function (val, n) {\n val = val.toString(8)\n if (val.length > n) return SEVENS.slice(0, n) + ' '\n else return ZEROS.slice(0, n - val.length) + val + ' '\n}\n\nconst addLength = function (str) {\n const len = Buffer.byteLength(str)\n let digits = Math.floor(Math.log(len) / Math.log(10)) + 1\n if (len + digits >= Math.pow(10, digits)) digits++\n\n return (len + digits) + str\n}\n\nexports.encodePax = function (opts) { // TODO: encode more stuff in pax\n let result = ''\n if (opts.name) result += addLength(' path=' + opts.name + '\\n')\n if (opts.linkname) result += addLength(' linkpath=' + opts.linkname + '\\n')\n const pax = opts.pax\n if (pax) {\n for (const key in pax) {\n result += addLength(' ' + key + '=' + pax[key] + '\\n')\n }\n }\n return Buffer.from(result)\n}\n\nexports.encode = function (opts) {\n const buf = alloc(512)\n let name = opts.name\n let prefix = ''\n\n if (opts.typeflag === 5 && name[name.length - 1] !== '/') name += '/'\n if (Buffer.byteLength(name) !== name.length) return null // utf-8\n\n while (Buffer.byteLength(name) > 100) {\n const i = name.indexOf('/')\n if (i === -1) return null\n prefix += prefix ? '/' + name.slice(0, i) : name.slice(0, i)\n name = name.slice(i + 1)\n }\n\n if (Buffer.byteLength(name) > 100 || Buffer.byteLength(prefix) > 155) return null\n if (opts.linkname && Buffer.byteLength(opts.linkname) > 100) return null\n\n buf.write(name)\n buf.write(encodeOct(opts.mode & MASK, 6), 100)\n buf.write(encodeOct(opts.uid, 6), 108)\n buf.write(encodeOct(opts.gid, 6), 116)\n buf.write(encodeOct(opts.size, 11), 124)\n buf.write(encodeOct((opts.mtime.getTime() / 1000) | 0, 11), 136)\n\n buf[156] = ZERO_OFFSET + toTypeflag(opts.type)\n\n if (opts.linkname) buf.write(opts.linkname, 157)\n\n USTAR_MAGIC.copy(buf, MAGIC_OFFSET)\n USTAR_VER.copy(buf, VERSION_OFFSET)\n if (opts.uname) buf.write(opts.uname, 265)\n if (opts.gname) buf.write(opts.gname, 297)\n buf.write(encodeOct(opts.devmajor || 0, 6), 329)\n buf.write(encodeOct(opts.devminor || 0, 6), 337)\n\n if (prefix) buf.write(prefix, 345)\n\n buf.write(encodeOct(cksum(buf), 6), 148)\n\n return buf\n}\n","// Top level file is just a mixin of submodules & constants\n'use strict';\n\nvar assign = require('./lib/utils/common').assign;\n\nvar deflate = require('./lib/deflate');\nvar inflate = require('./lib/inflate');\nvar constants = require('./lib/zlib/constants');\n\nvar pako = {};\n\nassign(pako, deflate, inflate, constants);\n\nmodule.exports = pako;\n","'use strict';\n\n\nvar TYPED_OK = (typeof Uint8Array !== 'undefined') &&\n (typeof Uint16Array !== 'undefined') &&\n (typeof Int32Array !== 'undefined');\n\nfunction _has(obj, key) {\n return Object.prototype.hasOwnProperty.call(obj, key);\n}\n\nexports.assign = function (obj /*from1, from2, from3, ...*/) {\n var sources = Array.prototype.slice.call(arguments, 1);\n while (sources.length) {\n var source = sources.shift();\n if (!source) { continue; }\n\n if (typeof source !== 'object') {\n throw new TypeError(source + 'must be non-object');\n }\n\n for (var p in source) {\n if (_has(source, p)) {\n obj[p] = source[p];\n }\n }\n }\n\n return obj;\n};\n\n\n// reduce buffer size, avoiding mem copy\nexports.shrinkBuf = function (buf, size) {\n if (buf.length === size) { return buf; }\n if (buf.subarray) { return buf.subarray(0, size); }\n buf.length = size;\n return buf;\n};\n\n\nvar fnTyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n if (src.subarray && dest.subarray) {\n dest.set(src.subarray(src_offs, src_offs + len), dest_offs);\n return;\n }\n // Fallback to ordinary array\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n var i, l, len, pos, chunk, result;\n\n // calculate data length\n len = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n len += chunks[i].length;\n }\n\n // join chunks\n result = new Uint8Array(len);\n pos = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n chunk = chunks[i];\n result.set(chunk, pos);\n pos += chunk.length;\n }\n\n return result;\n }\n};\n\nvar fnUntyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n return [].concat.apply([], chunks);\n }\n};\n\n\n// Enable/Disable typed arrays use, for testing\n//\nexports.setTyped = function (on) {\n if (on) {\n exports.Buf8 = Uint8Array;\n exports.Buf16 = Uint16Array;\n exports.Buf32 = Int32Array;\n exports.assign(exports, fnTyped);\n } else {\n exports.Buf8 = Array;\n exports.Buf16 = Array;\n exports.Buf32 = Array;\n exports.assign(exports, fnUntyped);\n }\n};\n\nexports.setTyped(TYPED_OK);\n","'use strict';\n\n\nvar zlib_deflate = require('./zlib/deflate');\nvar utils = require('./utils/common');\nvar strings = require('./utils/strings');\nvar msg = require('./zlib/messages');\nvar ZStream = require('./zlib/zstream');\n\nvar toString = Object.prototype.toString;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nvar Z_NO_FLUSH = 0;\nvar Z_FINISH = 4;\n\nvar Z_OK = 0;\nvar Z_STREAM_END = 1;\nvar Z_SYNC_FLUSH = 2;\n\nvar Z_DEFAULT_COMPRESSION = -1;\n\nvar Z_DEFAULT_STRATEGY = 0;\n\nvar Z_DEFLATED = 8;\n\n/* ===========================================================================*/\n\n\n/**\n * class Deflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[deflate]],\n * [[deflateRaw]] and [[gzip]].\n **/\n\n/* internal\n * Deflate.chunks -> Array\n *\n * Chunks of output data, if [[Deflate#onData]] not overridden.\n **/\n\n/**\n * Deflate.result -> Uint8Array|Array\n *\n * Compressed result, generated by default [[Deflate#onData]]\n * and [[Deflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Deflate#push]] with `Z_FINISH` / `true` param) or if you\n * push a chunk with explicit flush (call [[Deflate#push]] with\n * `Z_SYNC_FLUSH` param).\n **/\n\n/**\n * Deflate.err -> Number\n *\n * Error code after deflate finished. 0 (Z_OK) on success.\n * You will not need it in real life, because deflate errors\n * are possible only on wrong options or bad `onData` / `onEnd`\n * custom handlers.\n **/\n\n/**\n * Deflate.msg -> String\n *\n * Error message, if [[Deflate.err]] != 0\n **/\n\n\n/**\n * new Deflate(options)\n * - options (Object): zlib deflate options.\n *\n * Creates new deflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `level`\n * - `windowBits`\n * - `memLevel`\n * - `strategy`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw deflate\n * - `gzip` (Boolean) - create gzip wrapper\n * - `to` (String) - if equal to 'string', then result will be \"binary string\"\n * (each char code [0..255])\n * - `header` (Object) - custom header for gzip\n * - `text` (Boolean) - true if compressed data believed to be text\n * - `time` (Number) - modification time, unix timestamp\n * - `os` (Number) - operation system code\n * - `extra` (Array) - array of bytes with extra data (max 65536)\n * - `name` (String) - file name (binary string)\n * - `comment` (String) - comment (binary string)\n * - `hcrc` (Boolean) - true if header crc should be added\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * var deflate = new pako.Deflate({ level: 3});\n *\n * deflate.push(chunk1, false);\n * deflate.push(chunk2, true); // true -> last chunk\n *\n * if (deflate.err) { throw new Error(deflate.err); }\n *\n * console.log(deflate.result);\n * ```\n **/\nfunction Deflate(options) {\n if (!(this instanceof Deflate)) return new Deflate(options);\n\n this.options = utils.assign({\n level: Z_DEFAULT_COMPRESSION,\n method: Z_DEFLATED,\n chunkSize: 16384,\n windowBits: 15,\n memLevel: 8,\n strategy: Z_DEFAULT_STRATEGY,\n to: ''\n }, options || {});\n\n var opt = this.options;\n\n if (opt.raw && (opt.windowBits > 0)) {\n opt.windowBits = -opt.windowBits;\n }\n\n else if (opt.gzip && (opt.windowBits > 0) && (opt.windowBits < 16)) {\n opt.windowBits += 16;\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new ZStream();\n this.strm.avail_out = 0;\n\n var status = zlib_deflate.deflateInit2(\n this.strm,\n opt.level,\n opt.method,\n opt.windowBits,\n opt.memLevel,\n opt.strategy\n );\n\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n\n if (opt.header) {\n zlib_deflate.deflateSetHeader(this.strm, opt.header);\n }\n\n if (opt.dictionary) {\n var dict;\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n // If we need to compress text, change encoding to utf8.\n dict = strings.string2buf(opt.dictionary);\n } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n dict = new Uint8Array(opt.dictionary);\n } else {\n dict = opt.dictionary;\n }\n\n status = zlib_deflate.deflateSetDictionary(this.strm, dict);\n\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n\n this._dict_set = true;\n }\n}\n\n/**\n * Deflate#push(data[, mode]) -> Boolean\n * - data (Uint8Array|Array|ArrayBuffer|String): input data. Strings will be\n * converted to utf8 byte sequence.\n * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` means Z_FINISH.\n *\n * Sends input data to deflate pipe, generating [[Deflate#onData]] calls with\n * new compressed chunks. Returns `true` on success. The last data block must have\n * mode Z_FINISH (or `true`). That will flush internal pending buffers and call\n * [[Deflate#onEnd]]. For interim explicit flushes (without ending the stream) you\n * can use mode Z_SYNC_FLUSH, keeping the compression context.\n *\n * On fail call [[Deflate#onEnd]] with error code and return false.\n *\n * We strongly recommend to use `Uint8Array` on input for best speed (output\n * array format is detected automatically). Also, don't skip last param and always\n * use the same type in your code (boolean or number). That will improve JS speed.\n *\n * For regular `Array`-s make sure all elements are [0..255].\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nDeflate.prototype.push = function (data, mode) {\n var strm = this.strm;\n var chunkSize = this.options.chunkSize;\n var status, _mode;\n\n if (this.ended) { return false; }\n\n _mode = (mode === ~~mode) ? mode : ((mode === true) ? Z_FINISH : Z_NO_FLUSH);\n\n // Convert data if needed\n if (typeof data === 'string') {\n // If we need to compress text, change encoding to utf8.\n strm.input = strings.string2buf(data);\n } else if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n do {\n if (strm.avail_out === 0) {\n strm.output = new utils.Buf8(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n status = zlib_deflate.deflate(strm, _mode); /* no bad return value */\n\n if (status !== Z_STREAM_END && status !== Z_OK) {\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n if (strm.avail_out === 0 || (strm.avail_in === 0 && (_mode === Z_FINISH || _mode === Z_SYNC_FLUSH))) {\n if (this.options.to === 'string') {\n this.onData(strings.buf2binstring(utils.shrinkBuf(strm.output, strm.next_out)));\n } else {\n this.onData(utils.shrinkBuf(strm.output, strm.next_out));\n }\n }\n } while ((strm.avail_in > 0 || strm.avail_out === 0) && status !== Z_STREAM_END);\n\n // Finalize on the last chunk.\n if (_mode === Z_FINISH) {\n status = zlib_deflate.deflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === Z_OK;\n }\n\n // callback interim results if Z_SYNC_FLUSH.\n if (_mode === Z_SYNC_FLUSH) {\n this.onEnd(Z_OK);\n strm.avail_out = 0;\n return true;\n }\n\n return true;\n};\n\n\n/**\n * Deflate#onData(chunk) -> Void\n * - chunk (Uint8Array|Array|String): output data. Type of array depends\n * on js engine support. When string output requested, each chunk\n * will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nDeflate.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Deflate#onEnd(status) -> Void\n * - status (Number): deflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called once after you tell deflate that the input stream is\n * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)\n * or if an error happened. By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nDeflate.prototype.onEnd = function (status) {\n // On success - join\n if (status === Z_OK) {\n if (this.options.to === 'string') {\n this.result = this.chunks.join('');\n } else {\n this.result = utils.flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * deflate(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * Compress `data` with deflate algorithm and `options`.\n *\n * Supported options are:\n *\n * - level\n * - windowBits\n * - memLevel\n * - strategy\n * - dictionary\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be \"binary string\"\n * (each char code [0..255])\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , data = Uint8Array([1,2,3,4,5,6,7,8,9]);\n *\n * console.log(pako.deflate(data));\n * ```\n **/\nfunction deflate(input, options) {\n var deflator = new Deflate(options);\n\n deflator.push(input, true);\n\n // That will never happens, if you don't cheat with options :)\n if (deflator.err) { throw deflator.msg || msg[deflator.err]; }\n\n return deflator.result;\n}\n\n\n/**\n * deflateRaw(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction deflateRaw(input, options) {\n options = options || {};\n options.raw = true;\n return deflate(input, options);\n}\n\n\n/**\n * gzip(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but create gzip wrapper instead of\n * deflate one.\n **/\nfunction gzip(input, options) {\n options = options || {};\n options.gzip = true;\n return deflate(input, options);\n}\n\n\nexports.Deflate = Deflate;\nexports.deflate = deflate;\nexports.deflateRaw = deflateRaw;\nexports.gzip = gzip;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar utils = require('../utils/common');\nvar trees = require('./trees');\nvar adler32 = require('./adler32');\nvar crc32 = require('./crc32');\nvar msg = require('./messages');\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n/* Allowed flush values; see deflate() and inflate() below for details */\nvar Z_NO_FLUSH = 0;\nvar Z_PARTIAL_FLUSH = 1;\n//var Z_SYNC_FLUSH = 2;\nvar Z_FULL_FLUSH = 3;\nvar Z_FINISH = 4;\nvar Z_BLOCK = 5;\n//var Z_TREES = 6;\n\n\n/* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\nvar Z_OK = 0;\nvar Z_STREAM_END = 1;\n//var Z_NEED_DICT = 2;\n//var Z_ERRNO = -1;\nvar Z_STREAM_ERROR = -2;\nvar Z_DATA_ERROR = -3;\n//var Z_MEM_ERROR = -4;\nvar Z_BUF_ERROR = -5;\n//var Z_VERSION_ERROR = -6;\n\n\n/* compression levels */\n//var Z_NO_COMPRESSION = 0;\n//var Z_BEST_SPEED = 1;\n//var Z_BEST_COMPRESSION = 9;\nvar Z_DEFAULT_COMPRESSION = -1;\n\n\nvar Z_FILTERED = 1;\nvar Z_HUFFMAN_ONLY = 2;\nvar Z_RLE = 3;\nvar Z_FIXED = 4;\nvar Z_DEFAULT_STRATEGY = 0;\n\n/* Possible values of the data_type field (though see inflate()) */\n//var Z_BINARY = 0;\n//var Z_TEXT = 1;\n//var Z_ASCII = 1; // = Z_TEXT\nvar Z_UNKNOWN = 2;\n\n\n/* The deflate compression method */\nvar Z_DEFLATED = 8;\n\n/*============================================================================*/\n\n\nvar MAX_MEM_LEVEL = 9;\n/* Maximum value for memLevel in deflateInit2 */\nvar MAX_WBITS = 15;\n/* 32K LZ77 window */\nvar DEF_MEM_LEVEL = 8;\n\n\nvar LENGTH_CODES = 29;\n/* number of length codes, not counting the special END_BLOCK code */\nvar LITERALS = 256;\n/* number of literal bytes 0..255 */\nvar L_CODES = LITERALS + 1 + LENGTH_CODES;\n/* number of Literal or Length codes, including the END_BLOCK code */\nvar D_CODES = 30;\n/* number of distance codes */\nvar BL_CODES = 19;\n/* number of codes used to transfer the bit lengths */\nvar HEAP_SIZE = 2 * L_CODES + 1;\n/* maximum heap size */\nvar MAX_BITS = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nvar MIN_MATCH = 3;\nvar MAX_MATCH = 258;\nvar MIN_LOOKAHEAD = (MAX_MATCH + MIN_MATCH + 1);\n\nvar PRESET_DICT = 0x20;\n\nvar INIT_STATE = 42;\nvar EXTRA_STATE = 69;\nvar NAME_STATE = 73;\nvar COMMENT_STATE = 91;\nvar HCRC_STATE = 103;\nvar BUSY_STATE = 113;\nvar FINISH_STATE = 666;\n\nvar BS_NEED_MORE = 1; /* block not completed, need more input or more output */\nvar BS_BLOCK_DONE = 2; /* block flush performed */\nvar BS_FINISH_STARTED = 3; /* finish started, need only more output at next deflate */\nvar BS_FINISH_DONE = 4; /* finish done, accept no more input or output */\n\nvar OS_CODE = 0x03; // Unix :) . Don't detect, use this default.\n\nfunction err(strm, errorCode) {\n strm.msg = msg[errorCode];\n return errorCode;\n}\n\nfunction rank(f) {\n return ((f) << 1) - ((f) > 4 ? 9 : 0);\n}\n\nfunction zero(buf) { var len = buf.length; while (--len >= 0) { buf[len] = 0; } }\n\n\n/* =========================================================================\n * Flush as much pending output as possible. All deflate() output goes\n * through this function so some applications may wish to modify it\n * to avoid allocating a large strm->output buffer and copying into it.\n * (See also read_buf()).\n */\nfunction flush_pending(strm) {\n var s = strm.state;\n\n //_tr_flush_bits(s);\n var len = s.pending;\n if (len > strm.avail_out) {\n len = strm.avail_out;\n }\n if (len === 0) { return; }\n\n utils.arraySet(strm.output, s.pending_buf, s.pending_out, len, strm.next_out);\n strm.next_out += len;\n s.pending_out += len;\n strm.total_out += len;\n strm.avail_out -= len;\n s.pending -= len;\n if (s.pending === 0) {\n s.pending_out = 0;\n }\n}\n\n\nfunction flush_block_only(s, last) {\n trees._tr_flush_block(s, (s.block_start >= 0 ? s.block_start : -1), s.strstart - s.block_start, last);\n s.block_start = s.strstart;\n flush_pending(s.strm);\n}\n\n\nfunction put_byte(s, b) {\n s.pending_buf[s.pending++] = b;\n}\n\n\n/* =========================================================================\n * Put a short in the pending buffer. The 16-bit value is put in MSB order.\n * IN assertion: the stream state is correct and there is enough room in\n * pending_buf.\n */\nfunction putShortMSB(s, b) {\n// put_byte(s, (Byte)(b >> 8));\n// put_byte(s, (Byte)(b & 0xff));\n s.pending_buf[s.pending++] = (b >>> 8) & 0xff;\n s.pending_buf[s.pending++] = b & 0xff;\n}\n\n\n/* ===========================================================================\n * Read a new buffer from the current input stream, update the adler32\n * and total number of bytes read. All deflate() input goes through\n * this function so some applications may wish to modify it to avoid\n * allocating a large strm->input buffer and copying from it.\n * (See also flush_pending()).\n */\nfunction read_buf(strm, buf, start, size) {\n var len = strm.avail_in;\n\n if (len > size) { len = size; }\n if (len === 0) { return 0; }\n\n strm.avail_in -= len;\n\n // zmemcpy(buf, strm->next_in, len);\n utils.arraySet(buf, strm.input, strm.next_in, len, start);\n if (strm.state.wrap === 1) {\n strm.adler = adler32(strm.adler, buf, len, start);\n }\n\n else if (strm.state.wrap === 2) {\n strm.adler = crc32(strm.adler, buf, len, start);\n }\n\n strm.next_in += len;\n strm.total_in += len;\n\n return len;\n}\n\n\n/* ===========================================================================\n * Set match_start to the longest match starting at the given string and\n * return its length. Matches shorter or equal to prev_length are discarded,\n * in which case the result is equal to prev_length and match_start is\n * garbage.\n * IN assertions: cur_match is the head of the hash chain for the current\n * string (strstart) and its distance is <= MAX_DIST, and prev_length >= 1\n * OUT assertion: the match length is not greater than s->lookahead.\n */\nfunction longest_match(s, cur_match) {\n var chain_length = s.max_chain_length; /* max hash chain length */\n var scan = s.strstart; /* current string */\n var match; /* matched string */\n var len; /* length of current match */\n var best_len = s.prev_length; /* best match length so far */\n var nice_match = s.nice_match; /* stop if match long enough */\n var limit = (s.strstart > (s.w_size - MIN_LOOKAHEAD)) ?\n s.strstart - (s.w_size - MIN_LOOKAHEAD) : 0/*NIL*/;\n\n var _win = s.window; // shortcut\n\n var wmask = s.w_mask;\n var prev = s.prev;\n\n /* Stop when cur_match becomes <= limit. To simplify the code,\n * we prevent matches with the string of window index 0.\n */\n\n var strend = s.strstart + MAX_MATCH;\n var scan_end1 = _win[scan + best_len - 1];\n var scan_end = _win[scan + best_len];\n\n /* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16.\n * It is easy to get rid of this optimization if necessary.\n */\n // Assert(s->hash_bits >= 8 && MAX_MATCH == 258, \"Code too clever\");\n\n /* Do not waste too much time if we already have a good match: */\n if (s.prev_length >= s.good_match) {\n chain_length >>= 2;\n }\n /* Do not look for matches beyond the end of the input. This is necessary\n * to make deflate deterministic.\n */\n if (nice_match > s.lookahead) { nice_match = s.lookahead; }\n\n // Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, \"need lookahead\");\n\n do {\n // Assert(cur_match < s->strstart, \"no future\");\n match = cur_match;\n\n /* Skip to next match if the match length cannot increase\n * or if the match length is less than 2. Note that the checks below\n * for insufficient lookahead only occur occasionally for performance\n * reasons. Therefore uninitialized memory will be accessed, and\n * conditional jumps will be made that depend on those values.\n * However the length of the match is limited to the lookahead, so\n * the output of deflate is not affected by the uninitialized values.\n */\n\n if (_win[match + best_len] !== scan_end ||\n _win[match + best_len - 1] !== scan_end1 ||\n _win[match] !== _win[scan] ||\n _win[++match] !== _win[scan + 1]) {\n continue;\n }\n\n /* The check at best_len-1 can be removed because it will be made\n * again later. (This heuristic is not always a win.)\n * It is not necessary to compare scan[2] and match[2] since they\n * are always equal when the other bytes match, given that\n * the hash keys are equal and that HASH_BITS >= 8.\n */\n scan += 2;\n match++;\n // Assert(*scan == *match, \"match[2]?\");\n\n /* We check for insufficient lookahead only every 8th comparison;\n * the 256th check will be made at strstart+258.\n */\n do {\n /*jshint noempty:false*/\n } while (_win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n scan < strend);\n\n // Assert(scan <= s->window+(unsigned)(s->window_size-1), \"wild scan\");\n\n len = MAX_MATCH - (strend - scan);\n scan = strend - MAX_MATCH;\n\n if (len > best_len) {\n s.match_start = cur_match;\n best_len = len;\n if (len >= nice_match) {\n break;\n }\n scan_end1 = _win[scan + best_len - 1];\n scan_end = _win[scan + best_len];\n }\n } while ((cur_match = prev[cur_match & wmask]) > limit && --chain_length !== 0);\n\n if (best_len <= s.lookahead) {\n return best_len;\n }\n return s.lookahead;\n}\n\n\n/* ===========================================================================\n * Fill the window when the lookahead becomes insufficient.\n * Updates strstart and lookahead.\n *\n * IN assertion: lookahead < MIN_LOOKAHEAD\n * OUT assertions: strstart <= window_size-MIN_LOOKAHEAD\n * At least one byte has been read, or avail_in == 0; reads are\n * performed for at least two bytes (required for the zip translate_eol\n * option -- not supported here).\n */\nfunction fill_window(s) {\n var _w_size = s.w_size;\n var p, n, m, more, str;\n\n //Assert(s->lookahead < MIN_LOOKAHEAD, \"already enough lookahead\");\n\n do {\n more = s.window_size - s.lookahead - s.strstart;\n\n // JS ints have 32 bit, block below not needed\n /* Deal with !@#$% 64K limit: */\n //if (sizeof(int) <= 2) {\n // if (more == 0 && s->strstart == 0 && s->lookahead == 0) {\n // more = wsize;\n //\n // } else if (more == (unsigned)(-1)) {\n // /* Very unlikely, but possible on 16 bit machine if\n // * strstart == 0 && lookahead == 1 (input done a byte at time)\n // */\n // more--;\n // }\n //}\n\n\n /* If the window is almost full and there is insufficient lookahead,\n * move the upper half to the lower one to make room in the upper half.\n */\n if (s.strstart >= _w_size + (_w_size - MIN_LOOKAHEAD)) {\n\n utils.arraySet(s.window, s.window, _w_size, _w_size, 0);\n s.match_start -= _w_size;\n s.strstart -= _w_size;\n /* we now have strstart >= MAX_DIST */\n s.block_start -= _w_size;\n\n /* Slide the hash table (could be avoided with 32 bit values\n at the expense of memory usage). We slide even when level == 0\n to keep the hash table consistent if we switch back to level > 0\n later. (Using level 0 permanently is not an optimal usage of\n zlib, so we don't care about this pathological case.)\n */\n\n n = s.hash_size;\n p = n;\n do {\n m = s.head[--p];\n s.head[p] = (m >= _w_size ? m - _w_size : 0);\n } while (--n);\n\n n = _w_size;\n p = n;\n do {\n m = s.prev[--p];\n s.prev[p] = (m >= _w_size ? m - _w_size : 0);\n /* If n is not on any hash chain, prev[n] is garbage but\n * its value will never be used.\n */\n } while (--n);\n\n more += _w_size;\n }\n if (s.strm.avail_in === 0) {\n break;\n }\n\n /* If there was no sliding:\n * strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 &&\n * more == window_size - lookahead - strstart\n * => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1)\n * => more >= window_size - 2*WSIZE + 2\n * In the BIG_MEM or MMAP case (not yet supported),\n * window_size == input_size + MIN_LOOKAHEAD &&\n * strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD.\n * Otherwise, window_size == 2*WSIZE so more >= 2.\n * If there was sliding, more >= WSIZE. So in all cases, more >= 2.\n */\n //Assert(more >= 2, \"more < 2\");\n n = read_buf(s.strm, s.window, s.strstart + s.lookahead, more);\n s.lookahead += n;\n\n /* Initialize the hash value now that we have some input: */\n if (s.lookahead + s.insert >= MIN_MATCH) {\n str = s.strstart - s.insert;\n s.ins_h = s.window[str];\n\n /* UPDATE_HASH(s, s->ins_h, s->window[str + 1]); */\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[str + 1]) & s.hash_mask;\n//#if MIN_MATCH != 3\n// Call update_hash() MIN_MATCH-3 more times\n//#endif\n while (s.insert) {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask;\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = str;\n str++;\n s.insert--;\n if (s.lookahead + s.insert < MIN_MATCH) {\n break;\n }\n }\n }\n /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage,\n * but this is not important since only literal bytes will be emitted.\n */\n\n } while (s.lookahead < MIN_LOOKAHEAD && s.strm.avail_in !== 0);\n\n /* If the WIN_INIT bytes after the end of the current data have never been\n * written, then zero those bytes in order to avoid memory check reports of\n * the use of uninitialized (or uninitialised as Julian writes) bytes by\n * the longest match routines. Update the high water mark for the next\n * time through here. WIN_INIT is set to MAX_MATCH since the longest match\n * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead.\n */\n// if (s.high_water < s.window_size) {\n// var curr = s.strstart + s.lookahead;\n// var init = 0;\n//\n// if (s.high_water < curr) {\n// /* Previous high water mark below current data -- zero WIN_INIT\n// * bytes or up to end of window, whichever is less.\n// */\n// init = s.window_size - curr;\n// if (init > WIN_INIT)\n// init = WIN_INIT;\n// zmemzero(s->window + curr, (unsigned)init);\n// s->high_water = curr + init;\n// }\n// else if (s->high_water < (ulg)curr + WIN_INIT) {\n// /* High water mark at or above current data, but below current data\n// * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up\n// * to end of window, whichever is less.\n// */\n// init = (ulg)curr + WIN_INIT - s->high_water;\n// if (init > s->window_size - s->high_water)\n// init = s->window_size - s->high_water;\n// zmemzero(s->window + s->high_water, (unsigned)init);\n// s->high_water += init;\n// }\n// }\n//\n// Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD,\n// \"not enough room for search\");\n}\n\n/* ===========================================================================\n * Copy without compression as much as possible from the input stream, return\n * the current block state.\n * This function does not insert new strings in the dictionary since\n * uncompressible data is probably not useful. This function is used\n * only for the level=0 compression option.\n * NOTE: this function should be optimized to avoid extra copying from\n * window to pending_buf.\n */\nfunction deflate_stored(s, flush) {\n /* Stored blocks are limited to 0xffff bytes, pending_buf is limited\n * to pending_buf_size, and each stored block has a 5 byte header:\n */\n var max_block_size = 0xffff;\n\n if (max_block_size > s.pending_buf_size - 5) {\n max_block_size = s.pending_buf_size - 5;\n }\n\n /* Copy as much as possible from input to output: */\n for (;;) {\n /* Fill the window as much as possible: */\n if (s.lookahead <= 1) {\n\n //Assert(s->strstart < s->w_size+MAX_DIST(s) ||\n // s->block_start >= (long)s->w_size, \"slide too late\");\n// if (!(s.strstart < s.w_size + (s.w_size - MIN_LOOKAHEAD) ||\n// s.block_start >= s.w_size)) {\n// throw new Error(\"slide too late\");\n// }\n\n fill_window(s);\n if (s.lookahead === 0 && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n\n if (s.lookahead === 0) {\n break;\n }\n /* flush the current block */\n }\n //Assert(s->block_start >= 0L, \"block gone\");\n// if (s.block_start < 0) throw new Error(\"block gone\");\n\n s.strstart += s.lookahead;\n s.lookahead = 0;\n\n /* Emit a stored block if pending_buf will be full: */\n var max_start = s.block_start + max_block_size;\n\n if (s.strstart === 0 || s.strstart >= max_start) {\n /* strstart == 0 is possible when wraparound on 16-bit machine */\n s.lookahead = s.strstart - max_start;\n s.strstart = max_start;\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n\n\n }\n /* Flush if we may have to slide, otherwise block_start may become\n * negative and the data will be gone:\n */\n if (s.strstart - s.block_start >= (s.w_size - MIN_LOOKAHEAD)) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n\n s.insert = 0;\n\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n\n if (s.strstart > s.block_start) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n return BS_NEED_MORE;\n}\n\n/* ===========================================================================\n * Compress as much as possible from the input stream, return the current\n * block state.\n * This function does not perform lazy evaluation of matches and inserts\n * new strings in the dictionary only for unmatched strings or for short\n * matches. It is used only for the fast compression options.\n */\nfunction deflate_fast(s, flush) {\n var hash_head; /* head of the hash chain */\n var bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) {\n break; /* flush the current block */\n }\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n * At this point we have always match_length < MIN_MATCH\n */\n if (hash_head !== 0/*NIL*/ && ((s.strstart - hash_head) <= (s.w_size - MIN_LOOKAHEAD))) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n }\n if (s.match_length >= MIN_MATCH) {\n // check_match(s, s.strstart, s.match_start, s.match_length); // for debug only\n\n /*** _tr_tally_dist(s, s.strstart - s.match_start,\n s.match_length - MIN_MATCH, bflush); ***/\n bflush = trees._tr_tally(s, s.strstart - s.match_start, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n\n /* Insert new strings in the hash table only if the match length\n * is not too large. This saves time but degrades compression.\n */\n if (s.match_length <= s.max_lazy_match/*max_insert_length*/ && s.lookahead >= MIN_MATCH) {\n s.match_length--; /* string at strstart already in table */\n do {\n s.strstart++;\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n /* strstart never exceeds WSIZE-MAX_MATCH, so there are\n * always MIN_MATCH bytes ahead.\n */\n } while (--s.match_length !== 0);\n s.strstart++;\n } else\n {\n s.strstart += s.match_length;\n s.match_length = 0;\n s.ins_h = s.window[s.strstart];\n /* UPDATE_HASH(s, s.ins_h, s.window[s.strstart+1]); */\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + 1]) & s.hash_mask;\n\n//#if MIN_MATCH != 3\n// Call UPDATE_HASH() MIN_MATCH-3 more times\n//#endif\n /* If lookahead < MIN_MATCH, ins_h is garbage, but it does not\n * matter since it will be recomputed at next deflate call.\n */\n }\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s.window[s.strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = ((s.strstart < (MIN_MATCH - 1)) ? s.strstart : MIN_MATCH - 1);\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n}\n\n/* ===========================================================================\n * Same as above, but achieves better compression. We use a lazy\n * evaluation for matches: a match is finally adopted only if there is\n * no better match at the next window position.\n */\nfunction deflate_slow(s, flush) {\n var hash_head; /* head of hash chain */\n var bflush; /* set if current block must be flushed */\n\n var max_insert;\n\n /* Process the input block. */\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n */\n s.prev_length = s.match_length;\n s.prev_match = s.match_start;\n s.match_length = MIN_MATCH - 1;\n\n if (hash_head !== 0/*NIL*/ && s.prev_length < s.max_lazy_match &&\n s.strstart - hash_head <= (s.w_size - MIN_LOOKAHEAD)/*MAX_DIST(s)*/) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n\n if (s.match_length <= 5 &&\n (s.strategy === Z_FILTERED || (s.match_length === MIN_MATCH && s.strstart - s.match_start > 4096/*TOO_FAR*/))) {\n\n /* If prev_match is also MIN_MATCH, match_start is garbage\n * but we will ignore the current match anyway.\n */\n s.match_length = MIN_MATCH - 1;\n }\n }\n /* If there was a match at the previous step and the current\n * match is not better, output the previous match:\n */\n if (s.prev_length >= MIN_MATCH && s.match_length <= s.prev_length) {\n max_insert = s.strstart + s.lookahead - MIN_MATCH;\n /* Do not insert strings in hash table beyond this. */\n\n //check_match(s, s.strstart-1, s.prev_match, s.prev_length);\n\n /***_tr_tally_dist(s, s.strstart - 1 - s.prev_match,\n s.prev_length - MIN_MATCH, bflush);***/\n bflush = trees._tr_tally(s, s.strstart - 1 - s.prev_match, s.prev_length - MIN_MATCH);\n /* Insert in hash table all strings up to the end of the match.\n * strstart-1 and strstart are already inserted. If there is not\n * enough lookahead, the last two strings are not inserted in\n * the hash table.\n */\n s.lookahead -= s.prev_length - 1;\n s.prev_length -= 2;\n do {\n if (++s.strstart <= max_insert) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n } while (--s.prev_length !== 0);\n s.match_available = 0;\n s.match_length = MIN_MATCH - 1;\n s.strstart++;\n\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n } else if (s.match_available) {\n /* If there was no match at the previous position, output a\n * single literal. If there was a match but the current match\n * is longer, truncate the previous match to a single literal.\n */\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]);\n\n if (bflush) {\n /*** FLUSH_BLOCK_ONLY(s, 0) ***/\n flush_block_only(s, false);\n /***/\n }\n s.strstart++;\n s.lookahead--;\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n } else {\n /* There is no previous match to compare with, wait for\n * the next step to decide.\n */\n s.match_available = 1;\n s.strstart++;\n s.lookahead--;\n }\n }\n //Assert (flush != Z_NO_FLUSH, \"no flush?\");\n if (s.match_available) {\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]);\n\n s.match_available = 0;\n }\n s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1;\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n return BS_BLOCK_DONE;\n}\n\n\n/* ===========================================================================\n * For Z_RLE, simply look for runs of bytes, generate matches only of distance\n * one. Do not maintain a hash table. (It will be regenerated if this run of\n * deflate switches away from Z_RLE.)\n */\nfunction deflate_rle(s, flush) {\n var bflush; /* set if current block must be flushed */\n var prev; /* byte at distance one to match */\n var scan, strend; /* scan goes up to strend for length of run */\n\n var _win = s.window;\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the longest run, plus one for the unrolled loop.\n */\n if (s.lookahead <= MAX_MATCH) {\n fill_window(s);\n if (s.lookahead <= MAX_MATCH && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* See how many times the previous byte repeats */\n s.match_length = 0;\n if (s.lookahead >= MIN_MATCH && s.strstart > 0) {\n scan = s.strstart - 1;\n prev = _win[scan];\n if (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan]) {\n strend = s.strstart + MAX_MATCH;\n do {\n /*jshint noempty:false*/\n } while (prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n scan < strend);\n s.match_length = MAX_MATCH - (strend - scan);\n if (s.match_length > s.lookahead) {\n s.match_length = s.lookahead;\n }\n }\n //Assert(scan <= s->window+(uInt)(s->window_size-1), \"wild scan\");\n }\n\n /* Emit match if have run of MIN_MATCH or longer, else emit literal */\n if (s.match_length >= MIN_MATCH) {\n //check_match(s, s.strstart, s.strstart - 1, s.match_length);\n\n /*** _tr_tally_dist(s, 1, s.match_length - MIN_MATCH, bflush); ***/\n bflush = trees._tr_tally(s, 1, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n s.strstart += s.match_length;\n s.match_length = 0;\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n}\n\n/* ===========================================================================\n * For Z_HUFFMAN_ONLY, do not look for matches. Do not maintain a hash table.\n * (It will be regenerated if this run of deflate switches away from Huffman.)\n */\nfunction deflate_huff(s, flush) {\n var bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we have a literal to write. */\n if (s.lookahead === 0) {\n fill_window(s);\n if (s.lookahead === 0) {\n if (flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n break; /* flush the current block */\n }\n }\n\n /* Output a literal byte */\n s.match_length = 0;\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart]);\n s.lookahead--;\n s.strstart++;\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n}\n\n/* Values for max_lazy_match, good_match and max_chain_length, depending on\n * the desired pack level (0..9). The values given below have been tuned to\n * exclude worst case performance for pathological files. Better values may be\n * found for specific files.\n */\nfunction Config(good_length, max_lazy, nice_length, max_chain, func) {\n this.good_length = good_length;\n this.max_lazy = max_lazy;\n this.nice_length = nice_length;\n this.max_chain = max_chain;\n this.func = func;\n}\n\nvar configuration_table;\n\nconfiguration_table = [\n /* good lazy nice chain */\n new Config(0, 0, 0, 0, deflate_stored), /* 0 store only */\n new Config(4, 4, 8, 4, deflate_fast), /* 1 max speed, no lazy matches */\n new Config(4, 5, 16, 8, deflate_fast), /* 2 */\n new Config(4, 6, 32, 32, deflate_fast), /* 3 */\n\n new Config(4, 4, 16, 16, deflate_slow), /* 4 lazy matches */\n new Config(8, 16, 32, 32, deflate_slow), /* 5 */\n new Config(8, 16, 128, 128, deflate_slow), /* 6 */\n new Config(8, 32, 128, 256, deflate_slow), /* 7 */\n new Config(32, 128, 258, 1024, deflate_slow), /* 8 */\n new Config(32, 258, 258, 4096, deflate_slow) /* 9 max compression */\n];\n\n\n/* ===========================================================================\n * Initialize the \"longest match\" routines for a new zlib stream\n */\nfunction lm_init(s) {\n s.window_size = 2 * s.w_size;\n\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n\n /* Set the default configuration parameters:\n */\n s.max_lazy_match = configuration_table[s.level].max_lazy;\n s.good_match = configuration_table[s.level].good_length;\n s.nice_match = configuration_table[s.level].nice_length;\n s.max_chain_length = configuration_table[s.level].max_chain;\n\n s.strstart = 0;\n s.block_start = 0;\n s.lookahead = 0;\n s.insert = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n s.ins_h = 0;\n}\n\n\nfunction DeflateState() {\n this.strm = null; /* pointer back to this zlib stream */\n this.status = 0; /* as the name implies */\n this.pending_buf = null; /* output still pending */\n this.pending_buf_size = 0; /* size of pending_buf */\n this.pending_out = 0; /* next pending byte to output to the stream */\n this.pending = 0; /* nb of bytes in the pending buffer */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.gzhead = null; /* gzip header information to write */\n this.gzindex = 0; /* where in extra, name, or comment */\n this.method = Z_DEFLATED; /* can only be DEFLATED */\n this.last_flush = -1; /* value of flush param for previous deflate call */\n\n this.w_size = 0; /* LZ77 window size (32K by default) */\n this.w_bits = 0; /* log2(w_size) (8..16) */\n this.w_mask = 0; /* w_size - 1 */\n\n this.window = null;\n /* Sliding window. Input bytes are read into the second half of the window,\n * and move to the first half later to keep a dictionary of at least wSize\n * bytes. With this organization, matches are limited to a distance of\n * wSize-MAX_MATCH bytes, but this ensures that IO is always\n * performed with a length multiple of the block size.\n */\n\n this.window_size = 0;\n /* Actual size of window: 2*wSize, except when the user input buffer\n * is directly used as sliding window.\n */\n\n this.prev = null;\n /* Link to older string with same hash index. To limit the size of this\n * array to 64K, this link is maintained only for the last 32K strings.\n * An index in this array is thus a window index modulo 32K.\n */\n\n this.head = null; /* Heads of the hash chains or NIL. */\n\n this.ins_h = 0; /* hash index of string to be inserted */\n this.hash_size = 0; /* number of elements in hash table */\n this.hash_bits = 0; /* log2(hash_size) */\n this.hash_mask = 0; /* hash_size-1 */\n\n this.hash_shift = 0;\n /* Number of bits by which ins_h must be shifted at each input\n * step. It must be such that after MIN_MATCH steps, the oldest\n * byte no longer takes part in the hash key, that is:\n * hash_shift * MIN_MATCH >= hash_bits\n */\n\n this.block_start = 0;\n /* Window position at the beginning of the current output block. Gets\n * negative when the window is moved backwards.\n */\n\n this.match_length = 0; /* length of best match */\n this.prev_match = 0; /* previous match */\n this.match_available = 0; /* set if previous match exists */\n this.strstart = 0; /* start of string to insert */\n this.match_start = 0; /* start of matching string */\n this.lookahead = 0; /* number of valid bytes ahead in window */\n\n this.prev_length = 0;\n /* Length of the best match at previous step. Matches not greater than this\n * are discarded. This is used in the lazy match evaluation.\n */\n\n this.max_chain_length = 0;\n /* To speed up deflation, hash chains are never searched beyond this\n * length. A higher limit improves compression ratio but degrades the\n * speed.\n */\n\n this.max_lazy_match = 0;\n /* Attempt to find a better match only when the current match is strictly\n * smaller than this value. This mechanism is used only for compression\n * levels >= 4.\n */\n // That's alias to max_lazy_match, don't use directly\n //this.max_insert_length = 0;\n /* Insert new strings in the hash table only if the match length is not\n * greater than this length. This saves time but degrades compression.\n * max_insert_length is used only for compression levels <= 3.\n */\n\n this.level = 0; /* compression level (1..9) */\n this.strategy = 0; /* favor or force Huffman coding*/\n\n this.good_match = 0;\n /* Use a faster search when the previous match is longer than this */\n\n this.nice_match = 0; /* Stop searching when current match exceeds this */\n\n /* used by trees.c: */\n\n /* Didn't use ct_data typedef below to suppress compiler warning */\n\n // struct ct_data_s dyn_ltree[HEAP_SIZE]; /* literal and length tree */\n // struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */\n // struct ct_data_s bl_tree[2*BL_CODES+1]; /* Huffman tree for bit lengths */\n\n // Use flat array of DOUBLE size, with interleaved fata,\n // because JS does not support effective\n this.dyn_ltree = new utils.Buf16(HEAP_SIZE * 2);\n this.dyn_dtree = new utils.Buf16((2 * D_CODES + 1) * 2);\n this.bl_tree = new utils.Buf16((2 * BL_CODES + 1) * 2);\n zero(this.dyn_ltree);\n zero(this.dyn_dtree);\n zero(this.bl_tree);\n\n this.l_desc = null; /* desc. for literal tree */\n this.d_desc = null; /* desc. for distance tree */\n this.bl_desc = null; /* desc. for bit length tree */\n\n //ush bl_count[MAX_BITS+1];\n this.bl_count = new utils.Buf16(MAX_BITS + 1);\n /* number of codes at each bit length for an optimal tree */\n\n //int heap[2*L_CODES+1]; /* heap used to build the Huffman trees */\n this.heap = new utils.Buf16(2 * L_CODES + 1); /* heap used to build the Huffman trees */\n zero(this.heap);\n\n this.heap_len = 0; /* number of elements in the heap */\n this.heap_max = 0; /* element of largest frequency */\n /* The sons of heap[n] are heap[2*n] and heap[2*n+1]. heap[0] is not used.\n * The same heap array is used to build all trees.\n */\n\n this.depth = new utils.Buf16(2 * L_CODES + 1); //uch depth[2*L_CODES+1];\n zero(this.depth);\n /* Depth of each subtree used as tie breaker for trees of equal frequency\n */\n\n this.l_buf = 0; /* buffer index for literals or lengths */\n\n this.lit_bufsize = 0;\n /* Size of match buffer for literals/lengths. There are 4 reasons for\n * limiting lit_bufsize to 64K:\n * - frequencies can be kept in 16 bit counters\n * - if compression is not successful for the first block, all input\n * data is still in the window so we can still emit a stored block even\n * when input comes from standard input. (This can also be done for\n * all blocks if lit_bufsize is not greater than 32K.)\n * - if compression is not successful for a file smaller than 64K, we can\n * even emit a stored file instead of a stored block (saving 5 bytes).\n * This is applicable only for zip (not gzip or zlib).\n * - creating new Huffman trees less frequently may not provide fast\n * adaptation to changes in the input data statistics. (Take for\n * example a binary file with poorly compressible code followed by\n * a highly compressible string table.) Smaller buffer sizes give\n * fast adaptation but have of course the overhead of transmitting\n * trees more frequently.\n * - I can't count above 4\n */\n\n this.last_lit = 0; /* running index in l_buf */\n\n this.d_buf = 0;\n /* Buffer index for distances. To simplify the code, d_buf and l_buf have\n * the same number of elements. To use different lengths, an extra flag\n * array would be necessary.\n */\n\n this.opt_len = 0; /* bit length of current block with optimal trees */\n this.static_len = 0; /* bit length of current block with static trees */\n this.matches = 0; /* number of string matches in current block */\n this.insert = 0; /* bytes at end of window left to insert */\n\n\n this.bi_buf = 0;\n /* Output buffer. bits are inserted starting at the bottom (least\n * significant bits).\n */\n this.bi_valid = 0;\n /* Number of valid bits in bi_buf. All bits above the last valid bit\n * are always zero.\n */\n\n // Used for window memory init. We safely ignore it for JS. That makes\n // sense only for pointers and memory check tools.\n //this.high_water = 0;\n /* High water mark offset in window for initialized bytes -- bytes above\n * this are set to zero in order to avoid memory check warnings when\n * longest match routines access bytes past the input. This is then\n * updated to the new high water mark.\n */\n}\n\n\nfunction deflateResetKeep(strm) {\n var s;\n\n if (!strm || !strm.state) {\n return err(strm, Z_STREAM_ERROR);\n }\n\n strm.total_in = strm.total_out = 0;\n strm.data_type = Z_UNKNOWN;\n\n s = strm.state;\n s.pending = 0;\n s.pending_out = 0;\n\n if (s.wrap < 0) {\n s.wrap = -s.wrap;\n /* was made negative by deflate(..., Z_FINISH); */\n }\n s.status = (s.wrap ? INIT_STATE : BUSY_STATE);\n strm.adler = (s.wrap === 2) ?\n 0 // crc32(0, Z_NULL, 0)\n :\n 1; // adler32(0, Z_NULL, 0)\n s.last_flush = Z_NO_FLUSH;\n trees._tr_init(s);\n return Z_OK;\n}\n\n\nfunction deflateReset(strm) {\n var ret = deflateResetKeep(strm);\n if (ret === Z_OK) {\n lm_init(strm.state);\n }\n return ret;\n}\n\n\nfunction deflateSetHeader(strm, head) {\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n if (strm.state.wrap !== 2) { return Z_STREAM_ERROR; }\n strm.state.gzhead = head;\n return Z_OK;\n}\n\n\nfunction deflateInit2(strm, level, method, windowBits, memLevel, strategy) {\n if (!strm) { // === Z_NULL\n return Z_STREAM_ERROR;\n }\n var wrap = 1;\n\n if (level === Z_DEFAULT_COMPRESSION) {\n level = 6;\n }\n\n if (windowBits < 0) { /* suppress zlib wrapper */\n wrap = 0;\n windowBits = -windowBits;\n }\n\n else if (windowBits > 15) {\n wrap = 2; /* write gzip wrapper instead */\n windowBits -= 16;\n }\n\n\n if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method !== Z_DEFLATED ||\n windowBits < 8 || windowBits > 15 || level < 0 || level > 9 ||\n strategy < 0 || strategy > Z_FIXED) {\n return err(strm, Z_STREAM_ERROR);\n }\n\n\n if (windowBits === 8) {\n windowBits = 9;\n }\n /* until 256-byte window bug fixed */\n\n var s = new DeflateState();\n\n strm.state = s;\n s.strm = strm;\n\n s.wrap = wrap;\n s.gzhead = null;\n s.w_bits = windowBits;\n s.w_size = 1 << s.w_bits;\n s.w_mask = s.w_size - 1;\n\n s.hash_bits = memLevel + 7;\n s.hash_size = 1 << s.hash_bits;\n s.hash_mask = s.hash_size - 1;\n s.hash_shift = ~~((s.hash_bits + MIN_MATCH - 1) / MIN_MATCH);\n\n s.window = new utils.Buf8(s.w_size * 2);\n s.head = new utils.Buf16(s.hash_size);\n s.prev = new utils.Buf16(s.w_size);\n\n // Don't need mem init magic for JS.\n //s.high_water = 0; /* nothing written to s->window yet */\n\n s.lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */\n\n s.pending_buf_size = s.lit_bufsize * 4;\n\n //overlay = (ushf *) ZALLOC(strm, s->lit_bufsize, sizeof(ush)+2);\n //s->pending_buf = (uchf *) overlay;\n s.pending_buf = new utils.Buf8(s.pending_buf_size);\n\n // It is offset from `s.pending_buf` (size is `s.lit_bufsize * 2`)\n //s->d_buf = overlay + s->lit_bufsize/sizeof(ush);\n s.d_buf = 1 * s.lit_bufsize;\n\n //s->l_buf = s->pending_buf + (1+sizeof(ush))*s->lit_bufsize;\n s.l_buf = (1 + 2) * s.lit_bufsize;\n\n s.level = level;\n s.strategy = strategy;\n s.method = method;\n\n return deflateReset(strm);\n}\n\nfunction deflateInit(strm, level) {\n return deflateInit2(strm, level, Z_DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY);\n}\n\n\nfunction deflate(strm, flush) {\n var old_flush, s;\n var beg, val; // for gzip header write only\n\n if (!strm || !strm.state ||\n flush > Z_BLOCK || flush < 0) {\n return strm ? err(strm, Z_STREAM_ERROR) : Z_STREAM_ERROR;\n }\n\n s = strm.state;\n\n if (!strm.output ||\n (!strm.input && strm.avail_in !== 0) ||\n (s.status === FINISH_STATE && flush !== Z_FINISH)) {\n return err(strm, (strm.avail_out === 0) ? Z_BUF_ERROR : Z_STREAM_ERROR);\n }\n\n s.strm = strm; /* just in case */\n old_flush = s.last_flush;\n s.last_flush = flush;\n\n /* Write the header */\n if (s.status === INIT_STATE) {\n\n if (s.wrap === 2) { // GZIP header\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n put_byte(s, 31);\n put_byte(s, 139);\n put_byte(s, 8);\n if (!s.gzhead) { // s->gzhead == Z_NULL\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, OS_CODE);\n s.status = BUSY_STATE;\n }\n else {\n put_byte(s, (s.gzhead.text ? 1 : 0) +\n (s.gzhead.hcrc ? 2 : 0) +\n (!s.gzhead.extra ? 0 : 4) +\n (!s.gzhead.name ? 0 : 8) +\n (!s.gzhead.comment ? 0 : 16)\n );\n put_byte(s, s.gzhead.time & 0xff);\n put_byte(s, (s.gzhead.time >> 8) & 0xff);\n put_byte(s, (s.gzhead.time >> 16) & 0xff);\n put_byte(s, (s.gzhead.time >> 24) & 0xff);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, s.gzhead.os & 0xff);\n if (s.gzhead.extra && s.gzhead.extra.length) {\n put_byte(s, s.gzhead.extra.length & 0xff);\n put_byte(s, (s.gzhead.extra.length >> 8) & 0xff);\n }\n if (s.gzhead.hcrc) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending, 0);\n }\n s.gzindex = 0;\n s.status = EXTRA_STATE;\n }\n }\n else // DEFLATE header\n {\n var header = (Z_DEFLATED + ((s.w_bits - 8) << 4)) << 8;\n var level_flags = -1;\n\n if (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2) {\n level_flags = 0;\n } else if (s.level < 6) {\n level_flags = 1;\n } else if (s.level === 6) {\n level_flags = 2;\n } else {\n level_flags = 3;\n }\n header |= (level_flags << 6);\n if (s.strstart !== 0) { header |= PRESET_DICT; }\n header += 31 - (header % 31);\n\n s.status = BUSY_STATE;\n putShortMSB(s, header);\n\n /* Save the adler32 of the preset dictionary: */\n if (s.strstart !== 0) {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n strm.adler = 1; // adler32(0L, Z_NULL, 0);\n }\n }\n\n//#ifdef GZIP\n if (s.status === EXTRA_STATE) {\n if (s.gzhead.extra/* != Z_NULL*/) {\n beg = s.pending; /* start of bytes to update crc */\n\n while (s.gzindex < (s.gzhead.extra.length & 0xffff)) {\n if (s.pending === s.pending_buf_size) {\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n flush_pending(strm);\n beg = s.pending;\n if (s.pending === s.pending_buf_size) {\n break;\n }\n }\n put_byte(s, s.gzhead.extra[s.gzindex] & 0xff);\n s.gzindex++;\n }\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n if (s.gzindex === s.gzhead.extra.length) {\n s.gzindex = 0;\n s.status = NAME_STATE;\n }\n }\n else {\n s.status = NAME_STATE;\n }\n }\n if (s.status === NAME_STATE) {\n if (s.gzhead.name/* != Z_NULL*/) {\n beg = s.pending; /* start of bytes to update crc */\n //int val;\n\n do {\n if (s.pending === s.pending_buf_size) {\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n flush_pending(strm);\n beg = s.pending;\n if (s.pending === s.pending_buf_size) {\n val = 1;\n break;\n }\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.name.length) {\n val = s.gzhead.name.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n if (val === 0) {\n s.gzindex = 0;\n s.status = COMMENT_STATE;\n }\n }\n else {\n s.status = COMMENT_STATE;\n }\n }\n if (s.status === COMMENT_STATE) {\n if (s.gzhead.comment/* != Z_NULL*/) {\n beg = s.pending; /* start of bytes to update crc */\n //int val;\n\n do {\n if (s.pending === s.pending_buf_size) {\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n flush_pending(strm);\n beg = s.pending;\n if (s.pending === s.pending_buf_size) {\n val = 1;\n break;\n }\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.comment.length) {\n val = s.gzhead.comment.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n if (val === 0) {\n s.status = HCRC_STATE;\n }\n }\n else {\n s.status = HCRC_STATE;\n }\n }\n if (s.status === HCRC_STATE) {\n if (s.gzhead.hcrc) {\n if (s.pending + 2 > s.pending_buf_size) {\n flush_pending(strm);\n }\n if (s.pending + 2 <= s.pending_buf_size) {\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n s.status = BUSY_STATE;\n }\n }\n else {\n s.status = BUSY_STATE;\n }\n }\n//#endif\n\n /* Flush as much pending output as possible */\n if (s.pending !== 0) {\n flush_pending(strm);\n if (strm.avail_out === 0) {\n /* Since avail_out is 0, deflate will be called again with\n * more output space, but possibly with both pending and\n * avail_in equal to zero. There won't be anything to do,\n * but this is not an error situation so make sure we\n * return OK instead of BUF_ERROR at next call of deflate:\n */\n s.last_flush = -1;\n return Z_OK;\n }\n\n /* Make sure there is something to do and avoid duplicate consecutive\n * flushes. For repeated and useless calls with Z_FINISH, we keep\n * returning Z_STREAM_END instead of Z_BUF_ERROR.\n */\n } else if (strm.avail_in === 0 && rank(flush) <= rank(old_flush) &&\n flush !== Z_FINISH) {\n return err(strm, Z_BUF_ERROR);\n }\n\n /* User must not provide more input after the first FINISH: */\n if (s.status === FINISH_STATE && strm.avail_in !== 0) {\n return err(strm, Z_BUF_ERROR);\n }\n\n /* Start a new block or continue the current one.\n */\n if (strm.avail_in !== 0 || s.lookahead !== 0 ||\n (flush !== Z_NO_FLUSH && s.status !== FINISH_STATE)) {\n var bstate = (s.strategy === Z_HUFFMAN_ONLY) ? deflate_huff(s, flush) :\n (s.strategy === Z_RLE ? deflate_rle(s, flush) :\n configuration_table[s.level].func(s, flush));\n\n if (bstate === BS_FINISH_STARTED || bstate === BS_FINISH_DONE) {\n s.status = FINISH_STATE;\n }\n if (bstate === BS_NEED_MORE || bstate === BS_FINISH_STARTED) {\n if (strm.avail_out === 0) {\n s.last_flush = -1;\n /* avoid BUF_ERROR next call, see above */\n }\n return Z_OK;\n /* If flush != Z_NO_FLUSH && avail_out == 0, the next call\n * of deflate should use the same flush parameter to make sure\n * that the flush is complete. So we don't have to output an\n * empty block here, this will be done at next call. This also\n * ensures that for a very small output buffer, we emit at most\n * one empty block.\n */\n }\n if (bstate === BS_BLOCK_DONE) {\n if (flush === Z_PARTIAL_FLUSH) {\n trees._tr_align(s);\n }\n else if (flush !== Z_BLOCK) { /* FULL_FLUSH or SYNC_FLUSH */\n\n trees._tr_stored_block(s, 0, 0, false);\n /* For a full flush, this empty block will be recognized\n * as a special marker by inflate_sync().\n */\n if (flush === Z_FULL_FLUSH) {\n /*** CLEAR_HASH(s); ***/ /* forget history */\n zero(s.head); // Fill with NIL (= 0);\n\n if (s.lookahead === 0) {\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n }\n }\n flush_pending(strm);\n if (strm.avail_out === 0) {\n s.last_flush = -1; /* avoid BUF_ERROR at next call, see above */\n return Z_OK;\n }\n }\n }\n //Assert(strm->avail_out > 0, \"bug2\");\n //if (strm.avail_out <= 0) { throw new Error(\"bug2\");}\n\n if (flush !== Z_FINISH) { return Z_OK; }\n if (s.wrap <= 0) { return Z_STREAM_END; }\n\n /* Write the trailer */\n if (s.wrap === 2) {\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n put_byte(s, (strm.adler >> 16) & 0xff);\n put_byte(s, (strm.adler >> 24) & 0xff);\n put_byte(s, strm.total_in & 0xff);\n put_byte(s, (strm.total_in >> 8) & 0xff);\n put_byte(s, (strm.total_in >> 16) & 0xff);\n put_byte(s, (strm.total_in >> 24) & 0xff);\n }\n else\n {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n\n flush_pending(strm);\n /* If avail_out is zero, the application will call deflate again\n * to flush the rest.\n */\n if (s.wrap > 0) { s.wrap = -s.wrap; }\n /* write the trailer only once! */\n return s.pending !== 0 ? Z_OK : Z_STREAM_END;\n}\n\nfunction deflateEnd(strm) {\n var status;\n\n if (!strm/*== Z_NULL*/ || !strm.state/*== Z_NULL*/) {\n return Z_STREAM_ERROR;\n }\n\n status = strm.state.status;\n if (status !== INIT_STATE &&\n status !== EXTRA_STATE &&\n status !== NAME_STATE &&\n status !== COMMENT_STATE &&\n status !== HCRC_STATE &&\n status !== BUSY_STATE &&\n status !== FINISH_STATE\n ) {\n return err(strm, Z_STREAM_ERROR);\n }\n\n strm.state = null;\n\n return status === BUSY_STATE ? err(strm, Z_DATA_ERROR) : Z_OK;\n}\n\n\n/* =========================================================================\n * Initializes the compression dictionary from the given byte\n * sequence without producing any compressed output.\n */\nfunction deflateSetDictionary(strm, dictionary) {\n var dictLength = dictionary.length;\n\n var s;\n var str, n;\n var wrap;\n var avail;\n var next;\n var input;\n var tmpDict;\n\n if (!strm/*== Z_NULL*/ || !strm.state/*== Z_NULL*/) {\n return Z_STREAM_ERROR;\n }\n\n s = strm.state;\n wrap = s.wrap;\n\n if (wrap === 2 || (wrap === 1 && s.status !== INIT_STATE) || s.lookahead) {\n return Z_STREAM_ERROR;\n }\n\n /* when using zlib wrappers, compute Adler-32 for provided dictionary */\n if (wrap === 1) {\n /* adler32(strm->adler, dictionary, dictLength); */\n strm.adler = adler32(strm.adler, dictionary, dictLength, 0);\n }\n\n s.wrap = 0; /* avoid computing Adler-32 in read_buf */\n\n /* if dictionary would fill window, just replace the history */\n if (dictLength >= s.w_size) {\n if (wrap === 0) { /* already empty otherwise */\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n /* use the tail */\n // dictionary = dictionary.slice(dictLength - s.w_size);\n tmpDict = new utils.Buf8(s.w_size);\n utils.arraySet(tmpDict, dictionary, dictLength - s.w_size, s.w_size, 0);\n dictionary = tmpDict;\n dictLength = s.w_size;\n }\n /* insert dictionary into window and hash */\n avail = strm.avail_in;\n next = strm.next_in;\n input = strm.input;\n strm.avail_in = dictLength;\n strm.next_in = 0;\n strm.input = dictionary;\n fill_window(s);\n while (s.lookahead >= MIN_MATCH) {\n str = s.strstart;\n n = s.lookahead - (MIN_MATCH - 1);\n do {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask;\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n\n s.head[s.ins_h] = str;\n str++;\n } while (--n);\n s.strstart = str;\n s.lookahead = MIN_MATCH - 1;\n fill_window(s);\n }\n s.strstart += s.lookahead;\n s.block_start = s.strstart;\n s.insert = s.lookahead;\n s.lookahead = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n strm.next_in = next;\n strm.input = input;\n strm.avail_in = avail;\n s.wrap = wrap;\n return Z_OK;\n}\n\n\nexports.deflateInit = deflateInit;\nexports.deflateInit2 = deflateInit2;\nexports.deflateReset = deflateReset;\nexports.deflateResetKeep = deflateResetKeep;\nexports.deflateSetHeader = deflateSetHeader;\nexports.deflate = deflate;\nexports.deflateEnd = deflateEnd;\nexports.deflateSetDictionary = deflateSetDictionary;\nexports.deflateInfo = 'pako deflate (from Nodeca project)';\n\n/* Not implemented\nexports.deflateBound = deflateBound;\nexports.deflateCopy = deflateCopy;\nexports.deflateParams = deflateParams;\nexports.deflatePending = deflatePending;\nexports.deflatePrime = deflatePrime;\nexports.deflateTune = deflateTune;\n*/\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n/* eslint-disable space-unary-ops */\n\nvar utils = require('../utils/common');\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n//var Z_FILTERED = 1;\n//var Z_HUFFMAN_ONLY = 2;\n//var Z_RLE = 3;\nvar Z_FIXED = 4;\n//var Z_DEFAULT_STRATEGY = 0;\n\n/* Possible values of the data_type field (though see inflate()) */\nvar Z_BINARY = 0;\nvar Z_TEXT = 1;\n//var Z_ASCII = 1; // = Z_TEXT\nvar Z_UNKNOWN = 2;\n\n/*============================================================================*/\n\n\nfunction zero(buf) { var len = buf.length; while (--len >= 0) { buf[len] = 0; } }\n\n// From zutil.h\n\nvar STORED_BLOCK = 0;\nvar STATIC_TREES = 1;\nvar DYN_TREES = 2;\n/* The three kinds of block type */\n\nvar MIN_MATCH = 3;\nvar MAX_MATCH = 258;\n/* The minimum and maximum match lengths */\n\n// From deflate.h\n/* ===========================================================================\n * Internal compression state.\n */\n\nvar LENGTH_CODES = 29;\n/* number of length codes, not counting the special END_BLOCK code */\n\nvar LITERALS = 256;\n/* number of literal bytes 0..255 */\n\nvar L_CODES = LITERALS + 1 + LENGTH_CODES;\n/* number of Literal or Length codes, including the END_BLOCK code */\n\nvar D_CODES = 30;\n/* number of distance codes */\n\nvar BL_CODES = 19;\n/* number of codes used to transfer the bit lengths */\n\nvar HEAP_SIZE = 2 * L_CODES + 1;\n/* maximum heap size */\n\nvar MAX_BITS = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nvar Buf_size = 16;\n/* size of bit buffer in bi_buf */\n\n\n/* ===========================================================================\n * Constants\n */\n\nvar MAX_BL_BITS = 7;\n/* Bit length codes must not exceed MAX_BL_BITS bits */\n\nvar END_BLOCK = 256;\n/* end of block literal code */\n\nvar REP_3_6 = 16;\n/* repeat previous bit length 3-6 times (2 bits of repeat count) */\n\nvar REPZ_3_10 = 17;\n/* repeat a zero length 3-10 times (3 bits of repeat count) */\n\nvar REPZ_11_138 = 18;\n/* repeat a zero length 11-138 times (7 bits of repeat count) */\n\n/* eslint-disable comma-spacing,array-bracket-spacing */\nvar extra_lbits = /* extra bits for each length code */\n [0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0];\n\nvar extra_dbits = /* extra bits for each distance code */\n [0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13];\n\nvar extra_blbits = /* extra bits for each bit length code */\n [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7];\n\nvar bl_order =\n [16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15];\n/* eslint-enable comma-spacing,array-bracket-spacing */\n\n/* The lengths of the bit length codes are sent in order of decreasing\n * probability, to avoid transmitting the lengths for unused bit length codes.\n */\n\n/* ===========================================================================\n * Local data. These are initialized only once.\n */\n\n// We pre-fill arrays with 0 to avoid uninitialized gaps\n\nvar DIST_CODE_LEN = 512; /* see definition of array dist_code below */\n\n// !!!! Use flat array instead of structure, Freq = i*2, Len = i*2+1\nvar static_ltree = new Array((L_CODES + 2) * 2);\nzero(static_ltree);\n/* The static literal tree. Since the bit lengths are imposed, there is no\n * need for the L_CODES extra codes used during heap construction. However\n * The codes 286 and 287 are needed to build a canonical tree (see _tr_init\n * below).\n */\n\nvar static_dtree = new Array(D_CODES * 2);\nzero(static_dtree);\n/* The static distance tree. (Actually a trivial tree since all codes use\n * 5 bits.)\n */\n\nvar _dist_code = new Array(DIST_CODE_LEN);\nzero(_dist_code);\n/* Distance codes. The first 256 values correspond to the distances\n * 3 .. 258, the last 256 values correspond to the top 8 bits of\n * the 15 bit distances.\n */\n\nvar _length_code = new Array(MAX_MATCH - MIN_MATCH + 1);\nzero(_length_code);\n/* length code for each normalized match length (0 == MIN_MATCH) */\n\nvar base_length = new Array(LENGTH_CODES);\nzero(base_length);\n/* First normalized length for each code (0 = MIN_MATCH) */\n\nvar base_dist = new Array(D_CODES);\nzero(base_dist);\n/* First normalized distance for each code (0 = distance of 1) */\n\n\nfunction StaticTreeDesc(static_tree, extra_bits, extra_base, elems, max_length) {\n\n this.static_tree = static_tree; /* static tree or NULL */\n this.extra_bits = extra_bits; /* extra bits for each code or NULL */\n this.extra_base = extra_base; /* base index for extra_bits */\n this.elems = elems; /* max number of elements in the tree */\n this.max_length = max_length; /* max bit length for the codes */\n\n // show if `static_tree` has data or dummy - needed for monomorphic objects\n this.has_stree = static_tree && static_tree.length;\n}\n\n\nvar static_l_desc;\nvar static_d_desc;\nvar static_bl_desc;\n\n\nfunction TreeDesc(dyn_tree, stat_desc) {\n this.dyn_tree = dyn_tree; /* the dynamic tree */\n this.max_code = 0; /* largest code with non zero frequency */\n this.stat_desc = stat_desc; /* the corresponding static tree */\n}\n\n\n\nfunction d_code(dist) {\n return dist < 256 ? _dist_code[dist] : _dist_code[256 + (dist >>> 7)];\n}\n\n\n/* ===========================================================================\n * Output a short LSB first on the stream.\n * IN assertion: there is enough room in pendingBuf.\n */\nfunction put_short(s, w) {\n// put_byte(s, (uch)((w) & 0xff));\n// put_byte(s, (uch)((ush)(w) >> 8));\n s.pending_buf[s.pending++] = (w) & 0xff;\n s.pending_buf[s.pending++] = (w >>> 8) & 0xff;\n}\n\n\n/* ===========================================================================\n * Send a value on a given number of bits.\n * IN assertion: length <= 16 and value fits in length bits.\n */\nfunction send_bits(s, value, length) {\n if (s.bi_valid > (Buf_size - length)) {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n put_short(s, s.bi_buf);\n s.bi_buf = value >> (Buf_size - s.bi_valid);\n s.bi_valid += length - Buf_size;\n } else {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n s.bi_valid += length;\n }\n}\n\n\nfunction send_code(s, c, tree) {\n send_bits(s, tree[c * 2]/*.Code*/, tree[c * 2 + 1]/*.Len*/);\n}\n\n\n/* ===========================================================================\n * Reverse the first len bits of a code, using straightforward code (a faster\n * method would use a table)\n * IN assertion: 1 <= len <= 15\n */\nfunction bi_reverse(code, len) {\n var res = 0;\n do {\n res |= code & 1;\n code >>>= 1;\n res <<= 1;\n } while (--len > 0);\n return res >>> 1;\n}\n\n\n/* ===========================================================================\n * Flush the bit buffer, keeping at most 7 bits in it.\n */\nfunction bi_flush(s) {\n if (s.bi_valid === 16) {\n put_short(s, s.bi_buf);\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n } else if (s.bi_valid >= 8) {\n s.pending_buf[s.pending++] = s.bi_buf & 0xff;\n s.bi_buf >>= 8;\n s.bi_valid -= 8;\n }\n}\n\n\n/* ===========================================================================\n * Compute the optimal bit lengths for a tree and update the total bit length\n * for the current block.\n * IN assertion: the fields freq and dad are set, heap[heap_max] and\n * above are the tree nodes sorted by increasing frequency.\n * OUT assertions: the field len is set to the optimal bit length, the\n * array bl_count contains the frequencies for each bit length.\n * The length opt_len is updated; static_len is also updated if stree is\n * not null.\n */\nfunction gen_bitlen(s, desc)\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n{\n var tree = desc.dyn_tree;\n var max_code = desc.max_code;\n var stree = desc.stat_desc.static_tree;\n var has_stree = desc.stat_desc.has_stree;\n var extra = desc.stat_desc.extra_bits;\n var base = desc.stat_desc.extra_base;\n var max_length = desc.stat_desc.max_length;\n var h; /* heap index */\n var n, m; /* iterate over the tree elements */\n var bits; /* bit length */\n var xbits; /* extra bits */\n var f; /* frequency */\n var overflow = 0; /* number of elements with bit length too large */\n\n for (bits = 0; bits <= MAX_BITS; bits++) {\n s.bl_count[bits] = 0;\n }\n\n /* In a first pass, compute the optimal bit lengths (which may\n * overflow in the case of the bit length tree).\n */\n tree[s.heap[s.heap_max] * 2 + 1]/*.Len*/ = 0; /* root of the heap */\n\n for (h = s.heap_max + 1; h < HEAP_SIZE; h++) {\n n = s.heap[h];\n bits = tree[tree[n * 2 + 1]/*.Dad*/ * 2 + 1]/*.Len*/ + 1;\n if (bits > max_length) {\n bits = max_length;\n overflow++;\n }\n tree[n * 2 + 1]/*.Len*/ = bits;\n /* We overwrite tree[n].Dad which is no longer needed */\n\n if (n > max_code) { continue; } /* not a leaf node */\n\n s.bl_count[bits]++;\n xbits = 0;\n if (n >= base) {\n xbits = extra[n - base];\n }\n f = tree[n * 2]/*.Freq*/;\n s.opt_len += f * (bits + xbits);\n if (has_stree) {\n s.static_len += f * (stree[n * 2 + 1]/*.Len*/ + xbits);\n }\n }\n if (overflow === 0) { return; }\n\n // Trace((stderr,\"\\nbit length overflow\\n\"));\n /* This happens for example on obj2 and pic of the Calgary corpus */\n\n /* Find the first bit length which could increase: */\n do {\n bits = max_length - 1;\n while (s.bl_count[bits] === 0) { bits--; }\n s.bl_count[bits]--; /* move one leaf down the tree */\n s.bl_count[bits + 1] += 2; /* move one overflow item as its brother */\n s.bl_count[max_length]--;\n /* The brother of the overflow item also moves one step up,\n * but this does not affect bl_count[max_length]\n */\n overflow -= 2;\n } while (overflow > 0);\n\n /* Now recompute all bit lengths, scanning in increasing frequency.\n * h is still equal to HEAP_SIZE. (It is simpler to reconstruct all\n * lengths instead of fixing only the wrong ones. This idea is taken\n * from 'ar' written by Haruhiko Okumura.)\n */\n for (bits = max_length; bits !== 0; bits--) {\n n = s.bl_count[bits];\n while (n !== 0) {\n m = s.heap[--h];\n if (m > max_code) { continue; }\n if (tree[m * 2 + 1]/*.Len*/ !== bits) {\n // Trace((stderr,\"code %d bits %d->%d\\n\", m, tree[m].Len, bits));\n s.opt_len += (bits - tree[m * 2 + 1]/*.Len*/) * tree[m * 2]/*.Freq*/;\n tree[m * 2 + 1]/*.Len*/ = bits;\n }\n n--;\n }\n }\n}\n\n\n/* ===========================================================================\n * Generate the codes for a given tree and bit counts (which need not be\n * optimal).\n * IN assertion: the array bl_count contains the bit length statistics for\n * the given tree and the field len is set for all tree elements.\n * OUT assertion: the field code is set for all tree elements of non\n * zero code length.\n */\nfunction gen_codes(tree, max_code, bl_count)\n// ct_data *tree; /* the tree to decorate */\n// int max_code; /* largest code with non zero frequency */\n// ushf *bl_count; /* number of codes at each bit length */\n{\n var next_code = new Array(MAX_BITS + 1); /* next code value for each bit length */\n var code = 0; /* running code value */\n var bits; /* bit index */\n var n; /* code index */\n\n /* The distribution counts are first used to generate the code values\n * without bit reversal.\n */\n for (bits = 1; bits <= MAX_BITS; bits++) {\n next_code[bits] = code = (code + bl_count[bits - 1]) << 1;\n }\n /* Check that the bit counts in bl_count are consistent. The last code\n * must be all ones.\n */\n //Assert (code + bl_count[MAX_BITS]-1 == (1< length code (0..28) */\n length = 0;\n for (code = 0; code < LENGTH_CODES - 1; code++) {\n base_length[code] = length;\n for (n = 0; n < (1 << extra_lbits[code]); n++) {\n _length_code[length++] = code;\n }\n }\n //Assert (length == 256, \"tr_static_init: length != 256\");\n /* Note that the length 255 (match length 258) can be represented\n * in two different ways: code 284 + 5 bits or code 285, so we\n * overwrite length_code[255] to use the best encoding:\n */\n _length_code[length - 1] = code;\n\n /* Initialize the mapping dist (0..32K) -> dist code (0..29) */\n dist = 0;\n for (code = 0; code < 16; code++) {\n base_dist[code] = dist;\n for (n = 0; n < (1 << extra_dbits[code]); n++) {\n _dist_code[dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: dist != 256\");\n dist >>= 7; /* from now on, all distances are divided by 128 */\n for (; code < D_CODES; code++) {\n base_dist[code] = dist << 7;\n for (n = 0; n < (1 << (extra_dbits[code] - 7)); n++) {\n _dist_code[256 + dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: 256+dist != 512\");\n\n /* Construct the codes of the static literal tree */\n for (bits = 0; bits <= MAX_BITS; bits++) {\n bl_count[bits] = 0;\n }\n\n n = 0;\n while (n <= 143) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n while (n <= 255) {\n static_ltree[n * 2 + 1]/*.Len*/ = 9;\n n++;\n bl_count[9]++;\n }\n while (n <= 279) {\n static_ltree[n * 2 + 1]/*.Len*/ = 7;\n n++;\n bl_count[7]++;\n }\n while (n <= 287) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n /* Codes 286 and 287 do not exist, but we must include them in the\n * tree construction to get a canonical Huffman tree (longest code\n * all ones)\n */\n gen_codes(static_ltree, L_CODES + 1, bl_count);\n\n /* The static distance tree is trivial: */\n for (n = 0; n < D_CODES; n++) {\n static_dtree[n * 2 + 1]/*.Len*/ = 5;\n static_dtree[n * 2]/*.Code*/ = bi_reverse(n, 5);\n }\n\n // Now data ready and we can init static trees\n static_l_desc = new StaticTreeDesc(static_ltree, extra_lbits, LITERALS + 1, L_CODES, MAX_BITS);\n static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0, D_CODES, MAX_BITS);\n static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0, BL_CODES, MAX_BL_BITS);\n\n //static_init_done = true;\n}\n\n\n/* ===========================================================================\n * Initialize a new block.\n */\nfunction init_block(s) {\n var n; /* iterates over tree elements */\n\n /* Initialize the trees. */\n for (n = 0; n < L_CODES; n++) { s.dyn_ltree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < D_CODES; n++) { s.dyn_dtree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < BL_CODES; n++) { s.bl_tree[n * 2]/*.Freq*/ = 0; }\n\n s.dyn_ltree[END_BLOCK * 2]/*.Freq*/ = 1;\n s.opt_len = s.static_len = 0;\n s.last_lit = s.matches = 0;\n}\n\n\n/* ===========================================================================\n * Flush the bit buffer and align the output on a byte boundary\n */\nfunction bi_windup(s)\n{\n if (s.bi_valid > 8) {\n put_short(s, s.bi_buf);\n } else if (s.bi_valid > 0) {\n //put_byte(s, (Byte)s->bi_buf);\n s.pending_buf[s.pending++] = s.bi_buf;\n }\n s.bi_buf = 0;\n s.bi_valid = 0;\n}\n\n/* ===========================================================================\n * Copy a stored block, storing first the length and its\n * one's complement if requested.\n */\nfunction copy_block(s, buf, len, header)\n//DeflateState *s;\n//charf *buf; /* the input data */\n//unsigned len; /* its length */\n//int header; /* true if block header must be written */\n{\n bi_windup(s); /* align on byte boundary */\n\n if (header) {\n put_short(s, len);\n put_short(s, ~len);\n }\n// while (len--) {\n// put_byte(s, *buf++);\n// }\n utils.arraySet(s.pending_buf, s.window, buf, len, s.pending);\n s.pending += len;\n}\n\n/* ===========================================================================\n * Compares to subtrees, using the tree depth as tie breaker when\n * the subtrees have equal frequency. This minimizes the worst case length.\n */\nfunction smaller(tree, n, m, depth) {\n var _n2 = n * 2;\n var _m2 = m * 2;\n return (tree[_n2]/*.Freq*/ < tree[_m2]/*.Freq*/ ||\n (tree[_n2]/*.Freq*/ === tree[_m2]/*.Freq*/ && depth[n] <= depth[m]));\n}\n\n/* ===========================================================================\n * Restore the heap property by moving down the tree starting at node k,\n * exchanging a node with the smallest of its two sons if necessary, stopping\n * when the heap property is re-established (each father smaller than its\n * two sons).\n */\nfunction pqdownheap(s, tree, k)\n// deflate_state *s;\n// ct_data *tree; /* the tree to restore */\n// int k; /* node to move down */\n{\n var v = s.heap[k];\n var j = k << 1; /* left son of k */\n while (j <= s.heap_len) {\n /* Set j to the smallest of the two sons: */\n if (j < s.heap_len &&\n smaller(tree, s.heap[j + 1], s.heap[j], s.depth)) {\n j++;\n }\n /* Exit if v is smaller than both sons */\n if (smaller(tree, v, s.heap[j], s.depth)) { break; }\n\n /* Exchange v with the smallest son */\n s.heap[k] = s.heap[j];\n k = j;\n\n /* And continue down the tree, setting j to the left son of k */\n j <<= 1;\n }\n s.heap[k] = v;\n}\n\n\n// inlined manually\n// var SMALLEST = 1;\n\n/* ===========================================================================\n * Send the block data compressed using the given Huffman trees\n */\nfunction compress_block(s, ltree, dtree)\n// deflate_state *s;\n// const ct_data *ltree; /* literal tree */\n// const ct_data *dtree; /* distance tree */\n{\n var dist; /* distance of matched string */\n var lc; /* match length or unmatched char (if dist == 0) */\n var lx = 0; /* running index in l_buf */\n var code; /* the code to send */\n var extra; /* number of extra bits to send */\n\n if (s.last_lit !== 0) {\n do {\n dist = (s.pending_buf[s.d_buf + lx * 2] << 8) | (s.pending_buf[s.d_buf + lx * 2 + 1]);\n lc = s.pending_buf[s.l_buf + lx];\n lx++;\n\n if (dist === 0) {\n send_code(s, lc, ltree); /* send a literal byte */\n //Tracecv(isgraph(lc), (stderr,\" '%c' \", lc));\n } else {\n /* Here, lc is the match length - MIN_MATCH */\n code = _length_code[lc];\n send_code(s, code + LITERALS + 1, ltree); /* send the length code */\n extra = extra_lbits[code];\n if (extra !== 0) {\n lc -= base_length[code];\n send_bits(s, lc, extra); /* send the extra length bits */\n }\n dist--; /* dist is now the match distance - 1 */\n code = d_code(dist);\n //Assert (code < D_CODES, \"bad d_code\");\n\n send_code(s, code, dtree); /* send the distance code */\n extra = extra_dbits[code];\n if (extra !== 0) {\n dist -= base_dist[code];\n send_bits(s, dist, extra); /* send the extra distance bits */\n }\n } /* literal or match pair ? */\n\n /* Check that the overlay between pending_buf and d_buf+l_buf is ok: */\n //Assert((uInt)(s->pending) < s->lit_bufsize + 2*lx,\n // \"pendingBuf overflow\");\n\n } while (lx < s.last_lit);\n }\n\n send_code(s, END_BLOCK, ltree);\n}\n\n\n/* ===========================================================================\n * Construct one Huffman tree and assigns the code bit strings and lengths.\n * Update the total bit length for the current block.\n * IN assertion: the field freq is set for all tree elements.\n * OUT assertions: the fields len and code are set to the optimal bit length\n * and corresponding code. The length opt_len is updated; static_len is\n * also updated if stree is not null. The field max_code is set.\n */\nfunction build_tree(s, desc)\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n{\n var tree = desc.dyn_tree;\n var stree = desc.stat_desc.static_tree;\n var has_stree = desc.stat_desc.has_stree;\n var elems = desc.stat_desc.elems;\n var n, m; /* iterate over heap elements */\n var max_code = -1; /* largest code with non zero frequency */\n var node; /* new node being created */\n\n /* Construct the initial heap, with least frequent element in\n * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1].\n * heap[0] is not used.\n */\n s.heap_len = 0;\n s.heap_max = HEAP_SIZE;\n\n for (n = 0; n < elems; n++) {\n if (tree[n * 2]/*.Freq*/ !== 0) {\n s.heap[++s.heap_len] = max_code = n;\n s.depth[n] = 0;\n\n } else {\n tree[n * 2 + 1]/*.Len*/ = 0;\n }\n }\n\n /* The pkzip format requires that at least one distance code exists,\n * and that at least one bit should be sent even if there is only one\n * possible code. So to avoid special checks later on we force at least\n * two codes of non zero frequency.\n */\n while (s.heap_len < 2) {\n node = s.heap[++s.heap_len] = (max_code < 2 ? ++max_code : 0);\n tree[node * 2]/*.Freq*/ = 1;\n s.depth[node] = 0;\n s.opt_len--;\n\n if (has_stree) {\n s.static_len -= stree[node * 2 + 1]/*.Len*/;\n }\n /* node is 0 or 1 so it does not have extra bits */\n }\n desc.max_code = max_code;\n\n /* The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree,\n * establish sub-heaps of increasing lengths:\n */\n for (n = (s.heap_len >> 1/*int /2*/); n >= 1; n--) { pqdownheap(s, tree, n); }\n\n /* Construct the Huffman tree by repeatedly combining the least two\n * frequent nodes.\n */\n node = elems; /* next internal node of the tree */\n do {\n //pqremove(s, tree, n); /* n = node of least frequency */\n /*** pqremove ***/\n n = s.heap[1/*SMALLEST*/];\n s.heap[1/*SMALLEST*/] = s.heap[s.heap_len--];\n pqdownheap(s, tree, 1/*SMALLEST*/);\n /***/\n\n m = s.heap[1/*SMALLEST*/]; /* m = node of next least frequency */\n\n s.heap[--s.heap_max] = n; /* keep the nodes sorted by frequency */\n s.heap[--s.heap_max] = m;\n\n /* Create a new node father of n and m */\n tree[node * 2]/*.Freq*/ = tree[n * 2]/*.Freq*/ + tree[m * 2]/*.Freq*/;\n s.depth[node] = (s.depth[n] >= s.depth[m] ? s.depth[n] : s.depth[m]) + 1;\n tree[n * 2 + 1]/*.Dad*/ = tree[m * 2 + 1]/*.Dad*/ = node;\n\n /* and insert the new node in the heap */\n s.heap[1/*SMALLEST*/] = node++;\n pqdownheap(s, tree, 1/*SMALLEST*/);\n\n } while (s.heap_len >= 2);\n\n s.heap[--s.heap_max] = s.heap[1/*SMALLEST*/];\n\n /* At this point, the fields freq and dad are set. We can now\n * generate the bit lengths.\n */\n gen_bitlen(s, desc);\n\n /* The field len is now set, we can generate the bit codes */\n gen_codes(tree, max_code, s.bl_count);\n}\n\n\n/* ===========================================================================\n * Scan a literal or distance tree to determine the frequencies of the codes\n * in the bit length tree.\n */\nfunction scan_tree(s, tree, max_code)\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n{\n var n; /* iterates over all tree elements */\n var prevlen = -1; /* last emitted length */\n var curlen; /* length of current code */\n\n var nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n var count = 0; /* repeat count of the current code */\n var max_count = 7; /* max repeat count */\n var min_count = 4; /* min repeat count */\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n tree[(max_code + 1) * 2 + 1]/*.Len*/ = 0xffff; /* guard */\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n s.bl_tree[curlen * 2]/*.Freq*/ += count;\n\n } else if (curlen !== 0) {\n\n if (curlen !== prevlen) { s.bl_tree[curlen * 2]/*.Freq*/++; }\n s.bl_tree[REP_3_6 * 2]/*.Freq*/++;\n\n } else if (count <= 10) {\n s.bl_tree[REPZ_3_10 * 2]/*.Freq*/++;\n\n } else {\n s.bl_tree[REPZ_11_138 * 2]/*.Freq*/++;\n }\n\n count = 0;\n prevlen = curlen;\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n}\n\n\n/* ===========================================================================\n * Send a literal or distance tree in compressed form, using the codes in\n * bl_tree.\n */\nfunction send_tree(s, tree, max_code)\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n{\n var n; /* iterates over all tree elements */\n var prevlen = -1; /* last emitted length */\n var curlen; /* length of current code */\n\n var nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n var count = 0; /* repeat count of the current code */\n var max_count = 7; /* max repeat count */\n var min_count = 4; /* min repeat count */\n\n /* tree[max_code+1].Len = -1; */ /* guard already set */\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n do { send_code(s, curlen, s.bl_tree); } while (--count !== 0);\n\n } else if (curlen !== 0) {\n if (curlen !== prevlen) {\n send_code(s, curlen, s.bl_tree);\n count--;\n }\n //Assert(count >= 3 && count <= 6, \" 3_6?\");\n send_code(s, REP_3_6, s.bl_tree);\n send_bits(s, count - 3, 2);\n\n } else if (count <= 10) {\n send_code(s, REPZ_3_10, s.bl_tree);\n send_bits(s, count - 3, 3);\n\n } else {\n send_code(s, REPZ_11_138, s.bl_tree);\n send_bits(s, count - 11, 7);\n }\n\n count = 0;\n prevlen = curlen;\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n}\n\n\n/* ===========================================================================\n * Construct the Huffman tree for the bit lengths and return the index in\n * bl_order of the last bit length code to send.\n */\nfunction build_bl_tree(s) {\n var max_blindex; /* index of last bit length code of non zero freq */\n\n /* Determine the bit length frequencies for literal and distance trees */\n scan_tree(s, s.dyn_ltree, s.l_desc.max_code);\n scan_tree(s, s.dyn_dtree, s.d_desc.max_code);\n\n /* Build the bit length tree: */\n build_tree(s, s.bl_desc);\n /* opt_len now includes the length of the tree representations, except\n * the lengths of the bit lengths codes and the 5+5+4 bits for the counts.\n */\n\n /* Determine the number of bit length codes to send. The pkzip format\n * requires that at least 4 bit length codes be sent. (appnote.txt says\n * 3 but the actual value used is 4.)\n */\n for (max_blindex = BL_CODES - 1; max_blindex >= 3; max_blindex--) {\n if (s.bl_tree[bl_order[max_blindex] * 2 + 1]/*.Len*/ !== 0) {\n break;\n }\n }\n /* Update opt_len to include the bit length tree and counts */\n s.opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4;\n //Tracev((stderr, \"\\ndyn trees: dyn %ld, stat %ld\",\n // s->opt_len, s->static_len));\n\n return max_blindex;\n}\n\n\n/* ===========================================================================\n * Send the header for a block using dynamic Huffman trees: the counts, the\n * lengths of the bit length codes, the literal tree and the distance tree.\n * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4.\n */\nfunction send_all_trees(s, lcodes, dcodes, blcodes)\n// deflate_state *s;\n// int lcodes, dcodes, blcodes; /* number of codes for each tree */\n{\n var rank; /* index in bl_order */\n\n //Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, \"not enough codes\");\n //Assert (lcodes <= L_CODES && dcodes <= D_CODES && blcodes <= BL_CODES,\n // \"too many codes\");\n //Tracev((stderr, \"\\nbl counts: \"));\n send_bits(s, lcodes - 257, 5); /* not +255 as stated in appnote.txt */\n send_bits(s, dcodes - 1, 5);\n send_bits(s, blcodes - 4, 4); /* not -3 as stated in appnote.txt */\n for (rank = 0; rank < blcodes; rank++) {\n //Tracev((stderr, \"\\nbl code %2d \", bl_order[rank]));\n send_bits(s, s.bl_tree[bl_order[rank] * 2 + 1]/*.Len*/, 3);\n }\n //Tracev((stderr, \"\\nbl tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_ltree, lcodes - 1); /* literal tree */\n //Tracev((stderr, \"\\nlit tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_dtree, dcodes - 1); /* distance tree */\n //Tracev((stderr, \"\\ndist tree: sent %ld\", s->bits_sent));\n}\n\n\n/* ===========================================================================\n * Check if the data type is TEXT or BINARY, using the following algorithm:\n * - TEXT if the two conditions below are satisfied:\n * a) There are no non-portable control characters belonging to the\n * \"black list\" (0..6, 14..25, 28..31).\n * b) There is at least one printable character belonging to the\n * \"white list\" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255).\n * - BINARY otherwise.\n * - The following partially-portable control characters form a\n * \"gray list\" that is ignored in this detection algorithm:\n * (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}).\n * IN assertion: the fields Freq of dyn_ltree are set.\n */\nfunction detect_data_type(s) {\n /* black_mask is the bit mask of black-listed bytes\n * set bits 0..6, 14..25, and 28..31\n * 0xf3ffc07f = binary 11110011111111111100000001111111\n */\n var black_mask = 0xf3ffc07f;\n var n;\n\n /* Check for non-textual (\"black-listed\") bytes. */\n for (n = 0; n <= 31; n++, black_mask >>>= 1) {\n if ((black_mask & 1) && (s.dyn_ltree[n * 2]/*.Freq*/ !== 0)) {\n return Z_BINARY;\n }\n }\n\n /* Check for textual (\"white-listed\") bytes. */\n if (s.dyn_ltree[9 * 2]/*.Freq*/ !== 0 || s.dyn_ltree[10 * 2]/*.Freq*/ !== 0 ||\n s.dyn_ltree[13 * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n for (n = 32; n < LITERALS; n++) {\n if (s.dyn_ltree[n * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n }\n\n /* There are no \"black-listed\" or \"white-listed\" bytes:\n * this stream either is empty or has tolerated (\"gray-listed\") bytes only.\n */\n return Z_BINARY;\n}\n\n\nvar static_init_done = false;\n\n/* ===========================================================================\n * Initialize the tree data structures for a new zlib stream.\n */\nfunction _tr_init(s)\n{\n\n if (!static_init_done) {\n tr_static_init();\n static_init_done = true;\n }\n\n s.l_desc = new TreeDesc(s.dyn_ltree, static_l_desc);\n s.d_desc = new TreeDesc(s.dyn_dtree, static_d_desc);\n s.bl_desc = new TreeDesc(s.bl_tree, static_bl_desc);\n\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n /* Initialize the first block of the first file: */\n init_block(s);\n}\n\n\n/* ===========================================================================\n * Send a stored block\n */\nfunction _tr_stored_block(s, buf, stored_len, last)\n//DeflateState *s;\n//charf *buf; /* input block */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n{\n send_bits(s, (STORED_BLOCK << 1) + (last ? 1 : 0), 3); /* send block type */\n copy_block(s, buf, stored_len, true); /* with header */\n}\n\n\n/* ===========================================================================\n * Send one empty static block to give enough lookahead for inflate.\n * This takes 10 bits, of which 7 may remain in the bit buffer.\n */\nfunction _tr_align(s) {\n send_bits(s, STATIC_TREES << 1, 3);\n send_code(s, END_BLOCK, static_ltree);\n bi_flush(s);\n}\n\n\n/* ===========================================================================\n * Determine the best encoding for the current block: dynamic trees, static\n * trees or store, and output the encoded block to the zip file.\n */\nfunction _tr_flush_block(s, buf, stored_len, last)\n//DeflateState *s;\n//charf *buf; /* input block, or NULL if too old */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n{\n var opt_lenb, static_lenb; /* opt_len and static_len in bytes */\n var max_blindex = 0; /* index of last bit length code of non zero freq */\n\n /* Build the Huffman trees unless a stored block is forced */\n if (s.level > 0) {\n\n /* Check if the file is binary or text */\n if (s.strm.data_type === Z_UNKNOWN) {\n s.strm.data_type = detect_data_type(s);\n }\n\n /* Construct the literal and distance trees */\n build_tree(s, s.l_desc);\n // Tracev((stderr, \"\\nlit data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n\n build_tree(s, s.d_desc);\n // Tracev((stderr, \"\\ndist data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n /* At this point, opt_len and static_len are the total bit lengths of\n * the compressed block data, excluding the tree representations.\n */\n\n /* Build the bit length tree for the above two trees, and get the index\n * in bl_order of the last bit length code to send.\n */\n max_blindex = build_bl_tree(s);\n\n /* Determine the best encoding. Compute the block lengths in bytes. */\n opt_lenb = (s.opt_len + 3 + 7) >>> 3;\n static_lenb = (s.static_len + 3 + 7) >>> 3;\n\n // Tracev((stderr, \"\\nopt %lu(%lu) stat %lu(%lu) stored %lu lit %u \",\n // opt_lenb, s->opt_len, static_lenb, s->static_len, stored_len,\n // s->last_lit));\n\n if (static_lenb <= opt_lenb) { opt_lenb = static_lenb; }\n\n } else {\n // Assert(buf != (char*)0, \"lost buf\");\n opt_lenb = static_lenb = stored_len + 5; /* force a stored block */\n }\n\n if ((stored_len + 4 <= opt_lenb) && (buf !== -1)) {\n /* 4: two words for the lengths */\n\n /* The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE.\n * Otherwise we can't have processed more than WSIZE input bytes since\n * the last block flush, because compression would have been\n * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to\n * transform a block into a stored block.\n */\n _tr_stored_block(s, buf, stored_len, last);\n\n } else if (s.strategy === Z_FIXED || static_lenb === opt_lenb) {\n\n send_bits(s, (STATIC_TREES << 1) + (last ? 1 : 0), 3);\n compress_block(s, static_ltree, static_dtree);\n\n } else {\n send_bits(s, (DYN_TREES << 1) + (last ? 1 : 0), 3);\n send_all_trees(s, s.l_desc.max_code + 1, s.d_desc.max_code + 1, max_blindex + 1);\n compress_block(s, s.dyn_ltree, s.dyn_dtree);\n }\n // Assert (s->compressed_len == s->bits_sent, \"bad compressed size\");\n /* The above check is made mod 2^32, for files larger than 512 MB\n * and uLong implemented on 32 bits.\n */\n init_block(s);\n\n if (last) {\n bi_windup(s);\n }\n // Tracev((stderr,\"\\ncomprlen %lu(%lu) \", s->compressed_len>>3,\n // s->compressed_len-7*last));\n}\n\n/* ===========================================================================\n * Save the match info and tally the frequency counts. Return true if\n * the current block must be flushed.\n */\nfunction _tr_tally(s, dist, lc)\n// deflate_state *s;\n// unsigned dist; /* distance of matched string */\n// unsigned lc; /* match length-MIN_MATCH or unmatched char (if dist==0) */\n{\n //var out_length, in_length, dcode;\n\n s.pending_buf[s.d_buf + s.last_lit * 2] = (dist >>> 8) & 0xff;\n s.pending_buf[s.d_buf + s.last_lit * 2 + 1] = dist & 0xff;\n\n s.pending_buf[s.l_buf + s.last_lit] = lc & 0xff;\n s.last_lit++;\n\n if (dist === 0) {\n /* lc is the unmatched char */\n s.dyn_ltree[lc * 2]/*.Freq*/++;\n } else {\n s.matches++;\n /* Here, lc is the match length - MIN_MATCH */\n dist--; /* dist = match distance - 1 */\n //Assert((ush)dist < (ush)MAX_DIST(s) &&\n // (ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) &&\n // (ush)d_code(dist) < (ush)D_CODES, \"_tr_tally: bad match\");\n\n s.dyn_ltree[(_length_code[lc] + LITERALS + 1) * 2]/*.Freq*/++;\n s.dyn_dtree[d_code(dist) * 2]/*.Freq*/++;\n }\n\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n\n//#ifdef TRUNCATE_BLOCK\n// /* Try to guess if it is profitable to stop the current block here */\n// if ((s.last_lit & 0x1fff) === 0 && s.level > 2) {\n// /* Compute an upper bound for the compressed length */\n// out_length = s.last_lit*8;\n// in_length = s.strstart - s.block_start;\n//\n// for (dcode = 0; dcode < D_CODES; dcode++) {\n// out_length += s.dyn_dtree[dcode*2]/*.Freq*/ * (5 + extra_dbits[dcode]);\n// }\n// out_length >>>= 3;\n// //Tracev((stderr,\"\\nlast_lit %u, in %ld, out ~%ld(%ld%%) \",\n// // s->last_lit, in_length, out_length,\n// // 100L - out_length*100L/in_length));\n// if (s.matches < (s.last_lit>>1)/*int /2*/ && out_length < (in_length>>1)/*int /2*/) {\n// return true;\n// }\n// }\n//#endif\n\n return (s.last_lit === s.lit_bufsize - 1);\n /* We avoid equality with lit_bufsize because of wraparound at 64K\n * on 16 bit machines and because stored blocks are restricted to\n * 64K-1 bytes.\n */\n}\n\nexports._tr_init = _tr_init;\nexports._tr_stored_block = _tr_stored_block;\nexports._tr_flush_block = _tr_flush_block;\nexports._tr_tally = _tr_tally;\nexports._tr_align = _tr_align;\n","'use strict';\n\n// Note: adler32 takes 12% for level 0 and 2% for level 6.\n// It isn't worth it to make additional optimizations as in original.\n// Small size is preferable.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction adler32(adler, buf, len, pos) {\n var s1 = (adler & 0xffff) |0,\n s2 = ((adler >>> 16) & 0xffff) |0,\n n = 0;\n\n while (len !== 0) {\n // Set limit ~ twice less than 5552, to keep\n // s2 in 31-bits, because we force signed ints.\n // in other case %= will fail.\n n = len > 2000 ? 2000 : len;\n len -= n;\n\n do {\n s1 = (s1 + buf[pos++]) |0;\n s2 = (s2 + s1) |0;\n } while (--n);\n\n s1 %= 65521;\n s2 %= 65521;\n }\n\n return (s1 | (s2 << 16)) |0;\n}\n\n\nmodule.exports = adler32;\n","'use strict';\n\n// Note: we can't get significant speed boost here.\n// So write code to minimize size - no pregenerated tables\n// and array tools dependencies.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// Use ordinary array, since untyped makes no boost here\nfunction makeTable() {\n var c, table = [];\n\n for (var n = 0; n < 256; n++) {\n c = n;\n for (var k = 0; k < 8; k++) {\n c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));\n }\n table[n] = c;\n }\n\n return table;\n}\n\n// Create table on load. Just 255 signed longs. Not a problem.\nvar crcTable = makeTable();\n\n\nfunction crc32(crc, buf, len, pos) {\n var t = crcTable,\n end = pos + len;\n\n crc ^= -1;\n\n for (var i = pos; i < end; i++) {\n crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];\n }\n\n return (crc ^ (-1)); // >>> 0;\n}\n\n\nmodule.exports = crc32;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nmodule.exports = {\n 2: 'need dictionary', /* Z_NEED_DICT 2 */\n 1: 'stream end', /* Z_STREAM_END 1 */\n 0: '', /* Z_OK 0 */\n '-1': 'file error', /* Z_ERRNO (-1) */\n '-2': 'stream error', /* Z_STREAM_ERROR (-2) */\n '-3': 'data error', /* Z_DATA_ERROR (-3) */\n '-4': 'insufficient memory', /* Z_MEM_ERROR (-4) */\n '-5': 'buffer error', /* Z_BUF_ERROR (-5) */\n '-6': 'incompatible version' /* Z_VERSION_ERROR (-6) */\n};\n","// String encode/decode helpers\n'use strict';\n\n\nvar utils = require('./common');\n\n\n// Quick check if we can use fast array to bin string conversion\n//\n// - apply(Array) can fail on Android 2.2\n// - apply(Uint8Array) can fail on iOS 5.1 Safari\n//\nvar STR_APPLY_OK = true;\nvar STR_APPLY_UIA_OK = true;\n\ntry { String.fromCharCode.apply(null, [ 0 ]); } catch (__) { STR_APPLY_OK = false; }\ntry { String.fromCharCode.apply(null, new Uint8Array(1)); } catch (__) { STR_APPLY_UIA_OK = false; }\n\n\n// Table with utf8 lengths (calculated by first byte of sequence)\n// Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,\n// because max possible codepoint is 0x10ffff\nvar _utf8len = new utils.Buf8(256);\nfor (var q = 0; q < 256; q++) {\n _utf8len[q] = (q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1);\n}\n_utf8len[254] = _utf8len[254] = 1; // Invalid sequence start\n\n\n// convert string to array (typed, when possible)\nexports.string2buf = function (str) {\n var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;\n\n // count binary size\n for (m_pos = 0; m_pos < str_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\n }\n\n // allocate buffer\n buf = new utils.Buf8(buf_len);\n\n // convert\n for (i = 0, m_pos = 0; i < buf_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n if (c < 0x80) {\n /* one byte */\n buf[i++] = c;\n } else if (c < 0x800) {\n /* two bytes */\n buf[i++] = 0xC0 | (c >>> 6);\n buf[i++] = 0x80 | (c & 0x3f);\n } else if (c < 0x10000) {\n /* three bytes */\n buf[i++] = 0xE0 | (c >>> 12);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n } else {\n /* four bytes */\n buf[i++] = 0xf0 | (c >>> 18);\n buf[i++] = 0x80 | (c >>> 12 & 0x3f);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n }\n\n return buf;\n};\n\n// Helper (used in 2 places)\nfunction buf2binstring(buf, len) {\n // On Chrome, the arguments in a function call that are allowed is `65534`.\n // If the length of the buffer is smaller than that, we can use this optimization,\n // otherwise we will take a slower path.\n if (len < 65534) {\n if ((buf.subarray && STR_APPLY_UIA_OK) || (!buf.subarray && STR_APPLY_OK)) {\n return String.fromCharCode.apply(null, utils.shrinkBuf(buf, len));\n }\n }\n\n var result = '';\n for (var i = 0; i < len; i++) {\n result += String.fromCharCode(buf[i]);\n }\n return result;\n}\n\n\n// Convert byte array to binary string\nexports.buf2binstring = function (buf) {\n return buf2binstring(buf, buf.length);\n};\n\n\n// Convert binary string (typed, when possible)\nexports.binstring2buf = function (str) {\n var buf = new utils.Buf8(str.length);\n for (var i = 0, len = buf.length; i < len; i++) {\n buf[i] = str.charCodeAt(i);\n }\n return buf;\n};\n\n\n// convert array to string\nexports.buf2string = function (buf, max) {\n var i, out, c, c_len;\n var len = max || buf.length;\n\n // Reserve max possible length (2 words per char)\n // NB: by unknown reasons, Array is significantly faster for\n // String.fromCharCode.apply than Uint16Array.\n var utf16buf = new Array(len * 2);\n\n for (out = 0, i = 0; i < len;) {\n c = buf[i++];\n // quick process ascii\n if (c < 0x80) { utf16buf[out++] = c; continue; }\n\n c_len = _utf8len[c];\n // skip 5 & 6 byte codes\n if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len - 1; continue; }\n\n // apply mask on first byte\n c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;\n // join the rest\n while (c_len > 1 && i < len) {\n c = (c << 6) | (buf[i++] & 0x3f);\n c_len--;\n }\n\n // terminated by end of string?\n if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }\n\n if (c < 0x10000) {\n utf16buf[out++] = c;\n } else {\n c -= 0x10000;\n utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);\n utf16buf[out++] = 0xdc00 | (c & 0x3ff);\n }\n }\n\n return buf2binstring(utf16buf, out);\n};\n\n\n// Calculate max possible position in utf8 buffer,\n// that will not break sequence. If that's not possible\n// - (very small limits) return max size as is.\n//\n// buf[] - utf8 bytes array\n// max - length limit (mandatory);\nexports.utf8border = function (buf, max) {\n var pos;\n\n max = max || buf.length;\n if (max > buf.length) { max = buf.length; }\n\n // go back from last position, until start of sequence found\n pos = max - 1;\n while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }\n\n // Very small and broken sequence,\n // return max, because we should return something anyway.\n if (pos < 0) { return max; }\n\n // If we came to start of buffer - that means buffer is too small,\n // return max too.\n if (pos === 0) { return max; }\n\n return (pos + _utf8len[buf[pos]] > max) ? pos : max;\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction ZStream() {\n /* next input byte */\n this.input = null; // JS specific, because we have no pointers\n this.next_in = 0;\n /* number of bytes available at input */\n this.avail_in = 0;\n /* total number of input bytes read so far */\n this.total_in = 0;\n /* next output byte should be put there */\n this.output = null; // JS specific, because we have no pointers\n this.next_out = 0;\n /* remaining free space at output */\n this.avail_out = 0;\n /* total number of bytes output so far */\n this.total_out = 0;\n /* last error message, NULL if no error */\n this.msg = ''/*Z_NULL*/;\n /* not visible by applications */\n this.state = null;\n /* best guess about the data type: binary or text */\n this.data_type = 2/*Z_UNKNOWN*/;\n /* adler32 value of the uncompressed data */\n this.adler = 0;\n}\n\nmodule.exports = ZStream;\n","'use strict';\n\n\nvar zlib_inflate = require('./zlib/inflate');\nvar utils = require('./utils/common');\nvar strings = require('./utils/strings');\nvar c = require('./zlib/constants');\nvar msg = require('./zlib/messages');\nvar ZStream = require('./zlib/zstream');\nvar GZheader = require('./zlib/gzheader');\n\nvar toString = Object.prototype.toString;\n\n/**\n * class Inflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[inflate]]\n * and [[inflateRaw]].\n **/\n\n/* internal\n * inflate.chunks -> Array\n *\n * Chunks of output data, if [[Inflate#onData]] not overridden.\n **/\n\n/**\n * Inflate.result -> Uint8Array|Array|String\n *\n * Uncompressed result, generated by default [[Inflate#onData]]\n * and [[Inflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Inflate#push]] with `Z_FINISH` / `true` param) or if you\n * push a chunk with explicit flush (call [[Inflate#push]] with\n * `Z_SYNC_FLUSH` param).\n **/\n\n/**\n * Inflate.err -> Number\n *\n * Error code after inflate finished. 0 (Z_OK) on success.\n * Should be checked if broken data possible.\n **/\n\n/**\n * Inflate.msg -> String\n *\n * Error message, if [[Inflate.err]] != 0\n **/\n\n\n/**\n * new Inflate(options)\n * - options (Object): zlib inflate options.\n *\n * Creates new inflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `windowBits`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw inflate\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n * By default, when no options set, autodetect deflate/gzip data format via\n * wrapper header.\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * var inflate = new pako.Inflate({ level: 3});\n *\n * inflate.push(chunk1, false);\n * inflate.push(chunk2, true); // true -> last chunk\n *\n * if (inflate.err) { throw new Error(inflate.err); }\n *\n * console.log(inflate.result);\n * ```\n **/\nfunction Inflate(options) {\n if (!(this instanceof Inflate)) return new Inflate(options);\n\n this.options = utils.assign({\n chunkSize: 16384,\n windowBits: 0,\n to: ''\n }, options || {});\n\n var opt = this.options;\n\n // Force window size for `raw` data, if not set directly,\n // because we have no header for autodetect.\n if (opt.raw && (opt.windowBits >= 0) && (opt.windowBits < 16)) {\n opt.windowBits = -opt.windowBits;\n if (opt.windowBits === 0) { opt.windowBits = -15; }\n }\n\n // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate\n if ((opt.windowBits >= 0) && (opt.windowBits < 16) &&\n !(options && options.windowBits)) {\n opt.windowBits += 32;\n }\n\n // Gzip header has no info about windows size, we can do autodetect only\n // for deflate. So, if window size not set, force it to max when gzip possible\n if ((opt.windowBits > 15) && (opt.windowBits < 48)) {\n // bit 3 (16) -> gzipped data\n // bit 4 (32) -> autodetect gzip/deflate\n if ((opt.windowBits & 15) === 0) {\n opt.windowBits |= 15;\n }\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new ZStream();\n this.strm.avail_out = 0;\n\n var status = zlib_inflate.inflateInit2(\n this.strm,\n opt.windowBits\n );\n\n if (status !== c.Z_OK) {\n throw new Error(msg[status]);\n }\n\n this.header = new GZheader();\n\n zlib_inflate.inflateGetHeader(this.strm, this.header);\n\n // Setup dictionary\n if (opt.dictionary) {\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n opt.dictionary = strings.string2buf(opt.dictionary);\n } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n opt.dictionary = new Uint8Array(opt.dictionary);\n }\n if (opt.raw) { //In raw mode we need to set the dictionary early\n status = zlib_inflate.inflateSetDictionary(this.strm, opt.dictionary);\n if (status !== c.Z_OK) {\n throw new Error(msg[status]);\n }\n }\n }\n}\n\n/**\n * Inflate#push(data[, mode]) -> Boolean\n * - data (Uint8Array|Array|ArrayBuffer|String): input data\n * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` means Z_FINISH.\n *\n * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with\n * new output chunks. Returns `true` on success. The last data block must have\n * mode Z_FINISH (or `true`). That will flush internal pending buffers and call\n * [[Inflate#onEnd]]. For interim explicit flushes (without ending the stream) you\n * can use mode Z_SYNC_FLUSH, keeping the decompression context.\n *\n * On fail call [[Inflate#onEnd]] with error code and return false.\n *\n * We strongly recommend to use `Uint8Array` on input for best speed (output\n * format is detected automatically). Also, don't skip last param and always\n * use the same type in your code (boolean or number). That will improve JS speed.\n *\n * For regular `Array`-s make sure all elements are [0..255].\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nInflate.prototype.push = function (data, mode) {\n var strm = this.strm;\n var chunkSize = this.options.chunkSize;\n var dictionary = this.options.dictionary;\n var status, _mode;\n var next_out_utf8, tail, utf8str;\n\n // Flag to properly process Z_BUF_ERROR on testing inflate call\n // when we check that all output data was flushed.\n var allowBufError = false;\n\n if (this.ended) { return false; }\n _mode = (mode === ~~mode) ? mode : ((mode === true) ? c.Z_FINISH : c.Z_NO_FLUSH);\n\n // Convert data if needed\n if (typeof data === 'string') {\n // Only binary strings can be decompressed on practice\n strm.input = strings.binstring2buf(data);\n } else if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n do {\n if (strm.avail_out === 0) {\n strm.output = new utils.Buf8(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n status = zlib_inflate.inflate(strm, c.Z_NO_FLUSH); /* no bad return value */\n\n if (status === c.Z_NEED_DICT && dictionary) {\n status = zlib_inflate.inflateSetDictionary(this.strm, dictionary);\n }\n\n if (status === c.Z_BUF_ERROR && allowBufError === true) {\n status = c.Z_OK;\n allowBufError = false;\n }\n\n if (status !== c.Z_STREAM_END && status !== c.Z_OK) {\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n\n if (strm.next_out) {\n if (strm.avail_out === 0 || status === c.Z_STREAM_END || (strm.avail_in === 0 && (_mode === c.Z_FINISH || _mode === c.Z_SYNC_FLUSH))) {\n\n if (this.options.to === 'string') {\n\n next_out_utf8 = strings.utf8border(strm.output, strm.next_out);\n\n tail = strm.next_out - next_out_utf8;\n utf8str = strings.buf2string(strm.output, next_out_utf8);\n\n // move tail\n strm.next_out = tail;\n strm.avail_out = chunkSize - tail;\n if (tail) { utils.arraySet(strm.output, strm.output, next_out_utf8, tail, 0); }\n\n this.onData(utf8str);\n\n } else {\n this.onData(utils.shrinkBuf(strm.output, strm.next_out));\n }\n }\n }\n\n // When no more input data, we should check that internal inflate buffers\n // are flushed. The only way to do it when avail_out = 0 - run one more\n // inflate pass. But if output data not exists, inflate return Z_BUF_ERROR.\n // Here we set flag to process this error properly.\n //\n // NOTE. Deflate does not return error in this case and does not needs such\n // logic.\n if (strm.avail_in === 0 && strm.avail_out === 0) {\n allowBufError = true;\n }\n\n } while ((strm.avail_in > 0 || strm.avail_out === 0) && status !== c.Z_STREAM_END);\n\n if (status === c.Z_STREAM_END) {\n _mode = c.Z_FINISH;\n }\n\n // Finalize on the last chunk.\n if (_mode === c.Z_FINISH) {\n status = zlib_inflate.inflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === c.Z_OK;\n }\n\n // callback interim results if Z_SYNC_FLUSH.\n if (_mode === c.Z_SYNC_FLUSH) {\n this.onEnd(c.Z_OK);\n strm.avail_out = 0;\n return true;\n }\n\n return true;\n};\n\n\n/**\n * Inflate#onData(chunk) -> Void\n * - chunk (Uint8Array|Array|String): output data. Type of array depends\n * on js engine support. When string output requested, each chunk\n * will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nInflate.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Inflate#onEnd(status) -> Void\n * - status (Number): inflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called either after you tell inflate that the input stream is\n * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)\n * or if an error happened. By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nInflate.prototype.onEnd = function (status) {\n // On success - join\n if (status === c.Z_OK) {\n if (this.options.to === 'string') {\n // Glue & convert here, until we teach pako to send\n // utf8 aligned strings to onData\n this.result = this.chunks.join('');\n } else {\n this.result = utils.flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * inflate(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Decompress `data` with inflate/ungzip and `options`. Autodetect\n * format via wrapper header by default. That's why we don't provide\n * separate `ungzip` method.\n *\n * Supported options are:\n *\n * - windowBits\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , input = pako.deflate([1,2,3,4,5,6,7,8,9])\n * , output;\n *\n * try {\n * output = pako.inflate(input);\n * } catch (err)\n * console.log(err);\n * }\n * ```\n **/\nfunction inflate(input, options) {\n var inflator = new Inflate(options);\n\n inflator.push(input, true);\n\n // That will never happens, if you don't cheat with options :)\n if (inflator.err) { throw inflator.msg || msg[inflator.err]; }\n\n return inflator.result;\n}\n\n\n/**\n * inflateRaw(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * The same as [[inflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction inflateRaw(input, options) {\n options = options || {};\n options.raw = true;\n return inflate(input, options);\n}\n\n\n/**\n * ungzip(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Just shortcut to [[inflate]], because it autodetects format\n * by header.content. Done for convenience.\n **/\n\n\nexports.Inflate = Inflate;\nexports.inflate = inflate;\nexports.inflateRaw = inflateRaw;\nexports.ungzip = inflate;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar utils = require('../utils/common');\nvar adler32 = require('./adler32');\nvar crc32 = require('./crc32');\nvar inflate_fast = require('./inffast');\nvar inflate_table = require('./inftrees');\n\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n/* Allowed flush values; see deflate() and inflate() below for details */\n//var Z_NO_FLUSH = 0;\n//var Z_PARTIAL_FLUSH = 1;\n//var Z_SYNC_FLUSH = 2;\n//var Z_FULL_FLUSH = 3;\nvar Z_FINISH = 4;\nvar Z_BLOCK = 5;\nvar Z_TREES = 6;\n\n\n/* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\nvar Z_OK = 0;\nvar Z_STREAM_END = 1;\nvar Z_NEED_DICT = 2;\n//var Z_ERRNO = -1;\nvar Z_STREAM_ERROR = -2;\nvar Z_DATA_ERROR = -3;\nvar Z_MEM_ERROR = -4;\nvar Z_BUF_ERROR = -5;\n//var Z_VERSION_ERROR = -6;\n\n/* The deflate compression method */\nvar Z_DEFLATED = 8;\n\n\n/* STATES ====================================================================*/\n/* ===========================================================================*/\n\n\nvar HEAD = 1; /* i: waiting for magic header */\nvar FLAGS = 2; /* i: waiting for method and flags (gzip) */\nvar TIME = 3; /* i: waiting for modification time (gzip) */\nvar OS = 4; /* i: waiting for extra flags and operating system (gzip) */\nvar EXLEN = 5; /* i: waiting for extra length (gzip) */\nvar EXTRA = 6; /* i: waiting for extra bytes (gzip) */\nvar NAME = 7; /* i: waiting for end of file name (gzip) */\nvar COMMENT = 8; /* i: waiting for end of comment (gzip) */\nvar HCRC = 9; /* i: waiting for header crc (gzip) */\nvar DICTID = 10; /* i: waiting for dictionary check value */\nvar DICT = 11; /* waiting for inflateSetDictionary() call */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\nvar TYPEDO = 13; /* i: same, but skip check to exit inflate on new block */\nvar STORED = 14; /* i: waiting for stored size (length and complement) */\nvar COPY_ = 15; /* i/o: same as COPY below, but only first time in */\nvar COPY = 16; /* i/o: waiting for input or output to copy stored block */\nvar TABLE = 17; /* i: waiting for dynamic block table lengths */\nvar LENLENS = 18; /* i: waiting for code length code lengths */\nvar CODELENS = 19; /* i: waiting for length/lit and distance code lengths */\nvar LEN_ = 20; /* i: same as LEN below, but only first time in */\nvar LEN = 21; /* i: waiting for length/lit/eob code */\nvar LENEXT = 22; /* i: waiting for length extra bits */\nvar DIST = 23; /* i: waiting for distance code */\nvar DISTEXT = 24; /* i: waiting for distance extra bits */\nvar MATCH = 25; /* o: waiting for output space to copy string */\nvar LIT = 26; /* o: waiting for output space to write literal */\nvar CHECK = 27; /* i: waiting for 32-bit check value */\nvar LENGTH = 28; /* i: waiting for 32-bit length (gzip) */\nvar DONE = 29; /* finished check, done -- remain here until reset */\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar MEM = 31; /* got an inflate() memory error -- remain here until reset */\nvar SYNC = 32; /* looking for synchronization bytes to restart inflate() */\n\n/* ===========================================================================*/\n\n\n\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nvar MAX_WBITS = 15;\n/* 32K LZ77 window */\nvar DEF_WBITS = MAX_WBITS;\n\n\nfunction zswap32(q) {\n return (((q >>> 24) & 0xff) +\n ((q >>> 8) & 0xff00) +\n ((q & 0xff00) << 8) +\n ((q & 0xff) << 24));\n}\n\n\nfunction InflateState() {\n this.mode = 0; /* current inflate mode */\n this.last = false; /* true if processing last block */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.havedict = false; /* true if dictionary provided */\n this.flags = 0; /* gzip header method and flags (0 if zlib) */\n this.dmax = 0; /* zlib header max distance (INFLATE_STRICT) */\n this.check = 0; /* protected copy of check value */\n this.total = 0; /* protected copy of output count */\n // TODO: may be {}\n this.head = null; /* where to save gzip header information */\n\n /* sliding window */\n this.wbits = 0; /* log base 2 of requested window size */\n this.wsize = 0; /* window size or zero if not using window */\n this.whave = 0; /* valid bytes in the window */\n this.wnext = 0; /* window write index */\n this.window = null; /* allocated sliding window, if needed */\n\n /* bit accumulator */\n this.hold = 0; /* input bit accumulator */\n this.bits = 0; /* number of bits in \"in\" */\n\n /* for string and stored block copying */\n this.length = 0; /* literal or length of data to copy */\n this.offset = 0; /* distance back to copy string from */\n\n /* for table and code decoding */\n this.extra = 0; /* extra bits needed */\n\n /* fixed and dynamic code tables */\n this.lencode = null; /* starting table for length/literal codes */\n this.distcode = null; /* starting table for distance codes */\n this.lenbits = 0; /* index bits for lencode */\n this.distbits = 0; /* index bits for distcode */\n\n /* dynamic table building */\n this.ncode = 0; /* number of code length code lengths */\n this.nlen = 0; /* number of length code lengths */\n this.ndist = 0; /* number of distance code lengths */\n this.have = 0; /* number of code lengths in lens[] */\n this.next = null; /* next available space in codes[] */\n\n this.lens = new utils.Buf16(320); /* temporary storage for code lengths */\n this.work = new utils.Buf16(288); /* work area for code table building */\n\n /*\n because we don't have pointers in js, we use lencode and distcode directly\n as buffers so we don't need codes\n */\n //this.codes = new utils.Buf32(ENOUGH); /* space for code tables */\n this.lendyn = null; /* dynamic table for length/literal codes (JS specific) */\n this.distdyn = null; /* dynamic table for distance codes (JS specific) */\n this.sane = 0; /* if false, allow invalid distance too far */\n this.back = 0; /* bits back of last unprocessed length/lit */\n this.was = 0; /* initial length of match */\n}\n\nfunction inflateResetKeep(strm) {\n var state;\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n strm.total_in = strm.total_out = state.total = 0;\n strm.msg = ''; /*Z_NULL*/\n if (state.wrap) { /* to support ill-conceived Java test suite */\n strm.adler = state.wrap & 1;\n }\n state.mode = HEAD;\n state.last = 0;\n state.havedict = 0;\n state.dmax = 32768;\n state.head = null/*Z_NULL*/;\n state.hold = 0;\n state.bits = 0;\n //state.lencode = state.distcode = state.next = state.codes;\n state.lencode = state.lendyn = new utils.Buf32(ENOUGH_LENS);\n state.distcode = state.distdyn = new utils.Buf32(ENOUGH_DISTS);\n\n state.sane = 1;\n state.back = -1;\n //Tracev((stderr, \"inflate: reset\\n\"));\n return Z_OK;\n}\n\nfunction inflateReset(strm) {\n var state;\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n state.wsize = 0;\n state.whave = 0;\n state.wnext = 0;\n return inflateResetKeep(strm);\n\n}\n\nfunction inflateReset2(strm, windowBits) {\n var wrap;\n var state;\n\n /* get the state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n\n /* extract wrap request from windowBits parameter */\n if (windowBits < 0) {\n wrap = 0;\n windowBits = -windowBits;\n }\n else {\n wrap = (windowBits >> 4) + 1;\n if (windowBits < 48) {\n windowBits &= 15;\n }\n }\n\n /* set number of window bits, free window if different */\n if (windowBits && (windowBits < 8 || windowBits > 15)) {\n return Z_STREAM_ERROR;\n }\n if (state.window !== null && state.wbits !== windowBits) {\n state.window = null;\n }\n\n /* update state and reset the rest of it */\n state.wrap = wrap;\n state.wbits = windowBits;\n return inflateReset(strm);\n}\n\nfunction inflateInit2(strm, windowBits) {\n var ret;\n var state;\n\n if (!strm) { return Z_STREAM_ERROR; }\n //strm.msg = Z_NULL; /* in case we return an error */\n\n state = new InflateState();\n\n //if (state === Z_NULL) return Z_MEM_ERROR;\n //Tracev((stderr, \"inflate: allocated\\n\"));\n strm.state = state;\n state.window = null/*Z_NULL*/;\n ret = inflateReset2(strm, windowBits);\n if (ret !== Z_OK) {\n strm.state = null/*Z_NULL*/;\n }\n return ret;\n}\n\nfunction inflateInit(strm) {\n return inflateInit2(strm, DEF_WBITS);\n}\n\n\n/*\n Return state with length and distance decoding tables and index sizes set to\n fixed code decoding. Normally this returns fixed tables from inffixed.h.\n If BUILDFIXED is defined, then instead this routine builds the tables the\n first time it's called, and returns those tables the first time and\n thereafter. This reduces the size of the code by about 2K bytes, in\n exchange for a little execution time. However, BUILDFIXED should not be\n used for threaded applications, since the rewriting of the tables and virgin\n may not be thread-safe.\n */\nvar virgin = true;\n\nvar lenfix, distfix; // We have no pointers in JS, so keep tables separate\n\nfunction fixedtables(state) {\n /* build fixed huffman tables if first call (may not be thread safe) */\n if (virgin) {\n var sym;\n\n lenfix = new utils.Buf32(512);\n distfix = new utils.Buf32(32);\n\n /* literal/length table */\n sym = 0;\n while (sym < 144) { state.lens[sym++] = 8; }\n while (sym < 256) { state.lens[sym++] = 9; }\n while (sym < 280) { state.lens[sym++] = 7; }\n while (sym < 288) { state.lens[sym++] = 8; }\n\n inflate_table(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });\n\n /* distance table */\n sym = 0;\n while (sym < 32) { state.lens[sym++] = 5; }\n\n inflate_table(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 });\n\n /* do this just once */\n virgin = false;\n }\n\n state.lencode = lenfix;\n state.lenbits = 9;\n state.distcode = distfix;\n state.distbits = 5;\n}\n\n\n/*\n Update the window with the last wsize (normally 32K) bytes written before\n returning. If window does not exist yet, create it. This is only called\n when a window is already in use, or when output has been written during this\n inflate call, but the end of the deflate stream has not been reached yet.\n It is also called to create a window for dictionary data when a dictionary\n is loaded.\n\n Providing output buffers larger than 32K to inflate() should provide a speed\n advantage, since only the last 32K of output is copied to the sliding window\n upon return from inflate(), and since all distances after the first 32K of\n output will fall in the output data, making match copies simpler and faster.\n The advantage may be dependent on the size of the processor's data caches.\n */\nfunction updatewindow(strm, src, end, copy) {\n var dist;\n var state = strm.state;\n\n /* if it hasn't been done already, allocate space for the window */\n if (state.window === null) {\n state.wsize = 1 << state.wbits;\n state.wnext = 0;\n state.whave = 0;\n\n state.window = new utils.Buf8(state.wsize);\n }\n\n /* copy state->wsize or less output bytes into the circular window */\n if (copy >= state.wsize) {\n utils.arraySet(state.window, src, end - state.wsize, state.wsize, 0);\n state.wnext = 0;\n state.whave = state.wsize;\n }\n else {\n dist = state.wsize - state.wnext;\n if (dist > copy) {\n dist = copy;\n }\n //zmemcpy(state->window + state->wnext, end - copy, dist);\n utils.arraySet(state.window, src, end - copy, dist, state.wnext);\n copy -= dist;\n if (copy) {\n //zmemcpy(state->window, end - copy, copy);\n utils.arraySet(state.window, src, end - copy, copy, 0);\n state.wnext = copy;\n state.whave = state.wsize;\n }\n else {\n state.wnext += dist;\n if (state.wnext === state.wsize) { state.wnext = 0; }\n if (state.whave < state.wsize) { state.whave += dist; }\n }\n }\n return 0;\n}\n\nfunction inflate(strm, flush) {\n var state;\n var input, output; // input/output buffers\n var next; /* next input INDEX */\n var put; /* next output INDEX */\n var have, left; /* available input and output */\n var hold; /* bit buffer */\n var bits; /* bits in bit buffer */\n var _in, _out; /* save starting available input and output */\n var copy; /* number of stored or match bytes to copy */\n var from; /* where to copy match bytes from */\n var from_source;\n var here = 0; /* current decoding table entry */\n var here_bits, here_op, here_val; // paked \"here\" denormalized (JS specific)\n //var last; /* parent table entry */\n var last_bits, last_op, last_val; // paked \"last\" denormalized (JS specific)\n var len; /* length to copy for repeats, bits to drop */\n var ret; /* return code */\n var hbuf = new utils.Buf8(4); /* buffer for gzip header crc calculation */\n var opts;\n\n var n; // temporary var for NEED_BITS\n\n var order = /* permutation of code lengths */\n [ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ];\n\n\n if (!strm || !strm.state || !strm.output ||\n (!strm.input && strm.avail_in !== 0)) {\n return Z_STREAM_ERROR;\n }\n\n state = strm.state;\n if (state.mode === TYPE) { state.mode = TYPEDO; } /* skip check */\n\n\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n _in = have;\n _out = left;\n ret = Z_OK;\n\n inf_leave: // goto emulation\n for (;;) {\n switch (state.mode) {\n case HEAD:\n if (state.wrap === 0) {\n state.mode = TYPEDO;\n break;\n }\n //=== NEEDBITS(16);\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 2) && hold === 0x8b1f) { /* gzip header */\n state.check = 0/*crc32(0L, Z_NULL, 0)*/;\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = FLAGS;\n break;\n }\n state.flags = 0; /* expect zlib header */\n if (state.head) {\n state.head.done = false;\n }\n if (!(state.wrap & 1) || /* check if zlib header allowed */\n (((hold & 0xff)/*BITS(8)*/ << 8) + (hold >> 8)) % 31) {\n strm.msg = 'incorrect header check';\n state.mode = BAD;\n break;\n }\n if ((hold & 0x0f)/*BITS(4)*/ !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n len = (hold & 0x0f)/*BITS(4)*/ + 8;\n if (state.wbits === 0) {\n state.wbits = len;\n }\n else if (len > state.wbits) {\n strm.msg = 'invalid window size';\n state.mode = BAD;\n break;\n }\n state.dmax = 1 << len;\n //Tracev((stderr, \"inflate: zlib header ok\\n\"));\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = hold & 0x200 ? DICTID : TYPE;\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n break;\n case FLAGS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.flags = hold;\n if ((state.flags & 0xff) !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n if (state.flags & 0xe000) {\n strm.msg = 'unknown header flags set';\n state.mode = BAD;\n break;\n }\n if (state.head) {\n state.head.text = ((hold >> 8) & 1);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = TIME;\n /* falls through */\n case TIME:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.time = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC4(state.check, hold)\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n hbuf[2] = (hold >>> 16) & 0xff;\n hbuf[3] = (hold >>> 24) & 0xff;\n state.check = crc32(state.check, hbuf, 4, 0);\n //===\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = OS;\n /* falls through */\n case OS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.xflags = (hold & 0xff);\n state.head.os = (hold >> 8);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = EXLEN;\n /* falls through */\n case EXLEN:\n if (state.flags & 0x0400) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length = hold;\n if (state.head) {\n state.head.extra_len = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n else if (state.head) {\n state.head.extra = null/*Z_NULL*/;\n }\n state.mode = EXTRA;\n /* falls through */\n case EXTRA:\n if (state.flags & 0x0400) {\n copy = state.length;\n if (copy > have) { copy = have; }\n if (copy) {\n if (state.head) {\n len = state.head.extra_len - state.length;\n if (!state.head.extra) {\n // Use untyped array for more convenient processing later\n state.head.extra = new Array(state.head.extra_len);\n }\n utils.arraySet(\n state.head.extra,\n input,\n next,\n // extra field is limited to 65536 bytes\n // - no need for additional size check\n copy,\n /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/\n len\n );\n //zmemcpy(state.head.extra + len, next,\n // len + copy > state.head.extra_max ?\n // state.head.extra_max - len : copy);\n }\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n state.length -= copy;\n }\n if (state.length) { break inf_leave; }\n }\n state.length = 0;\n state.mode = NAME;\n /* falls through */\n case NAME:\n if (state.flags & 0x0800) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n // TODO: 2 or 1 bytes?\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.name_max*/)) {\n state.head.name += String.fromCharCode(len);\n }\n } while (len && copy < have);\n\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.name = null;\n }\n state.length = 0;\n state.mode = COMMENT;\n /* falls through */\n case COMMENT:\n if (state.flags & 0x1000) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.comm_max*/)) {\n state.head.comment += String.fromCharCode(len);\n }\n } while (len && copy < have);\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.comment = null;\n }\n state.mode = HCRC;\n /* falls through */\n case HCRC:\n if (state.flags & 0x0200) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.check & 0xffff)) {\n strm.msg = 'header crc mismatch';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n if (state.head) {\n state.head.hcrc = ((state.flags >> 9) & 1);\n state.head.done = true;\n }\n strm.adler = state.check = 0;\n state.mode = TYPE;\n break;\n case DICTID:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n strm.adler = state.check = zswap32(hold);\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = DICT;\n /* falls through */\n case DICT:\n if (state.havedict === 0) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n return Z_NEED_DICT;\n }\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = TYPE;\n /* falls through */\n case TYPE:\n if (flush === Z_BLOCK || flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case TYPEDO:\n if (state.last) {\n //--- BYTEBITS() ---//\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n state.mode = CHECK;\n break;\n }\n //=== NEEDBITS(3); */\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.last = (hold & 0x01)/*BITS(1)*/;\n //--- DROPBITS(1) ---//\n hold >>>= 1;\n bits -= 1;\n //---//\n\n switch ((hold & 0x03)/*BITS(2)*/) {\n case 0: /* stored block */\n //Tracev((stderr, \"inflate: stored block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = STORED;\n break;\n case 1: /* fixed block */\n fixedtables(state);\n //Tracev((stderr, \"inflate: fixed codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = LEN_; /* decode codes */\n if (flush === Z_TREES) {\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break inf_leave;\n }\n break;\n case 2: /* dynamic block */\n //Tracev((stderr, \"inflate: dynamic codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = TABLE;\n break;\n case 3:\n strm.msg = 'invalid block type';\n state.mode = BAD;\n }\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break;\n case STORED:\n //--- BYTEBITS() ---// /* go to byte boundary */\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {\n strm.msg = 'invalid stored block lengths';\n state.mode = BAD;\n break;\n }\n state.length = hold & 0xffff;\n //Tracev((stderr, \"inflate: stored length %u\\n\",\n // state.length));\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = COPY_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case COPY_:\n state.mode = COPY;\n /* falls through */\n case COPY:\n copy = state.length;\n if (copy) {\n if (copy > have) { copy = have; }\n if (copy > left) { copy = left; }\n if (copy === 0) { break inf_leave; }\n //--- zmemcpy(put, next, copy); ---\n utils.arraySet(output, input, next, copy, put);\n //---//\n have -= copy;\n next += copy;\n left -= copy;\n put += copy;\n state.length -= copy;\n break;\n }\n //Tracev((stderr, \"inflate: stored end\\n\"));\n state.mode = TYPE;\n break;\n case TABLE:\n //=== NEEDBITS(14); */\n while (bits < 14) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.nlen = (hold & 0x1f)/*BITS(5)*/ + 257;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ndist = (hold & 0x1f)/*BITS(5)*/ + 1;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ncode = (hold & 0x0f)/*BITS(4)*/ + 4;\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n//#ifndef PKZIP_BUG_WORKAROUND\n if (state.nlen > 286 || state.ndist > 30) {\n strm.msg = 'too many length or distance symbols';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracev((stderr, \"inflate: table sizes ok\\n\"));\n state.have = 0;\n state.mode = LENLENS;\n /* falls through */\n case LENLENS:\n while (state.have < state.ncode) {\n //=== NEEDBITS(3);\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.lens[order[state.have++]] = (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n while (state.have < 19) {\n state.lens[order[state.have++]] = 0;\n }\n // We have separate tables & no pointers. 2 commented lines below not needed.\n //state.next = state.codes;\n //state.lencode = state.next;\n // Switch to use dynamic table\n state.lencode = state.lendyn;\n state.lenbits = 7;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);\n state.lenbits = opts.bits;\n\n if (ret) {\n strm.msg = 'invalid code lengths set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, \"inflate: code lengths ok\\n\"));\n state.have = 0;\n state.mode = CODELENS;\n /* falls through */\n case CODELENS:\n while (state.have < state.nlen + state.ndist) {\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)];/*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_val < 16) {\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.lens[state.have++] = here_val;\n }\n else {\n if (here_val === 16) {\n //=== NEEDBITS(here.bits + 2);\n n = here_bits + 2;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n if (state.have === 0) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n len = state.lens[state.have - 1];\n copy = 3 + (hold & 0x03);//BITS(2);\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n }\n else if (here_val === 17) {\n //=== NEEDBITS(here.bits + 3);\n n = here_bits + 3;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 3 + (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n else {\n //=== NEEDBITS(here.bits + 7);\n n = here_bits + 7;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 11 + (hold & 0x7f);//BITS(7);\n //--- DROPBITS(7) ---//\n hold >>>= 7;\n bits -= 7;\n //---//\n }\n if (state.have + copy > state.nlen + state.ndist) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n while (copy--) {\n state.lens[state.have++] = len;\n }\n }\n }\n\n /* handle error breaks in while */\n if (state.mode === BAD) { break; }\n\n /* check for end-of-block code (better have one) */\n if (state.lens[256] === 0) {\n strm.msg = 'invalid code -- missing end-of-block';\n state.mode = BAD;\n break;\n }\n\n /* build code tables -- note: do not change the lenbits or distbits\n values here (9 and 6) without reading the comments in inftrees.h\n concerning the ENOUGH constants, which depend on those values */\n state.lenbits = 9;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.lenbits = opts.bits;\n // state.lencode = state.next;\n\n if (ret) {\n strm.msg = 'invalid literal/lengths set';\n state.mode = BAD;\n break;\n }\n\n state.distbits = 6;\n //state.distcode.copy(state.codes);\n // Switch to use dynamic table\n state.distcode = state.distdyn;\n opts = { bits: state.distbits };\n ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.distbits = opts.bits;\n // state.distcode = state.next;\n\n if (ret) {\n strm.msg = 'invalid distances set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, 'inflate: codes ok\\n'));\n state.mode = LEN_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case LEN_:\n state.mode = LEN;\n /* falls through */\n case LEN:\n if (have >= 6 && left >= 258) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n inflate_fast(strm, _out);\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n if (state.mode === TYPE) {\n state.back = -1;\n }\n break;\n }\n state.back = 0;\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if (here_bits <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_op && (here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.lencode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n state.length = here_val;\n if (here_op === 0) {\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n state.mode = LIT;\n break;\n }\n if (here_op & 32) {\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.back = -1;\n state.mode = TYPE;\n break;\n }\n if (here_op & 64) {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break;\n }\n state.extra = here_op & 15;\n state.mode = LENEXT;\n /* falls through */\n case LENEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", state.length));\n state.was = state.length;\n state.mode = DIST;\n /* falls through */\n case DIST:\n for (;;) {\n here = state.distcode[hold & ((1 << state.distbits) - 1)];/*BITS(state.distbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if ((here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.distcode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n if (here_op & 64) {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break;\n }\n state.offset = here_val;\n state.extra = (here_op) & 15;\n state.mode = DISTEXT;\n /* falls through */\n case DISTEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.offset += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n//#ifdef INFLATE_STRICT\n if (state.offset > state.dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracevv((stderr, \"inflate: distance %u\\n\", state.offset));\n state.mode = MATCH;\n /* falls through */\n case MATCH:\n if (left === 0) { break inf_leave; }\n copy = _out - left;\n if (state.offset > copy) { /* copy from window */\n copy = state.offset - copy;\n if (copy > state.whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// Trace((stderr, \"inflate.c too far\\n\"));\n// copy -= state.whave;\n// if (copy > state.length) { copy = state.length; }\n// if (copy > left) { copy = left; }\n// left -= copy;\n// state.length -= copy;\n// do {\n// output[put++] = 0;\n// } while (--copy);\n// if (state.length === 0) { state.mode = LEN; }\n// break;\n//#endif\n }\n if (copy > state.wnext) {\n copy -= state.wnext;\n from = state.wsize - copy;\n }\n else {\n from = state.wnext - copy;\n }\n if (copy > state.length) { copy = state.length; }\n from_source = state.window;\n }\n else { /* copy from output */\n from_source = output;\n from = put - state.offset;\n copy = state.length;\n }\n if (copy > left) { copy = left; }\n left -= copy;\n state.length -= copy;\n do {\n output[put++] = from_source[from++];\n } while (--copy);\n if (state.length === 0) { state.mode = LEN; }\n break;\n case LIT:\n if (left === 0) { break inf_leave; }\n output[put++] = state.length;\n left--;\n state.mode = LEN;\n break;\n case CHECK:\n if (state.wrap) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n // Use '|' instead of '+' to make sure that result is signed\n hold |= input[next++] << bits;\n bits += 8;\n }\n //===//\n _out -= left;\n strm.total_out += _out;\n state.total += _out;\n if (_out) {\n strm.adler = state.check =\n /*UPDATE(state.check, put - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, put - _out) : adler32(state.check, output, _out, put - _out));\n\n }\n _out = left;\n // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too\n if ((state.flags ? hold : zswap32(hold)) !== state.check) {\n strm.msg = 'incorrect data check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: check matches trailer\\n\"));\n }\n state.mode = LENGTH;\n /* falls through */\n case LENGTH:\n if (state.wrap && state.flags) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.total & 0xffffffff)) {\n strm.msg = 'incorrect length check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: length matches trailer\\n\"));\n }\n state.mode = DONE;\n /* falls through */\n case DONE:\n ret = Z_STREAM_END;\n break inf_leave;\n case BAD:\n ret = Z_DATA_ERROR;\n break inf_leave;\n case MEM:\n return Z_MEM_ERROR;\n case SYNC:\n /* falls through */\n default:\n return Z_STREAM_ERROR;\n }\n }\n\n // inf_leave <- here is real place for \"goto inf_leave\", emulated via \"break inf_leave\"\n\n /*\n Return from inflate(), updating the total counts and the check value.\n If there was no progress during the inflate() call, return a buffer\n error. Call updatewindow() to create and/or update the window state.\n Note: a memory error from inflate() is non-recoverable.\n */\n\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n\n if (state.wsize || (_out !== strm.avail_out && state.mode < BAD &&\n (state.mode < CHECK || flush !== Z_FINISH))) {\n if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n }\n _in -= strm.avail_in;\n _out -= strm.avail_out;\n strm.total_in += _in;\n strm.total_out += _out;\n state.total += _out;\n if (state.wrap && _out) {\n strm.adler = state.check = /*UPDATE(state.check, strm.next_out - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, strm.next_out - _out) : adler32(state.check, output, _out, strm.next_out - _out));\n }\n strm.data_type = state.bits + (state.last ? 64 : 0) +\n (state.mode === TYPE ? 128 : 0) +\n (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);\n if (((_in === 0 && _out === 0) || flush === Z_FINISH) && ret === Z_OK) {\n ret = Z_BUF_ERROR;\n }\n return ret;\n}\n\nfunction inflateEnd(strm) {\n\n if (!strm || !strm.state /*|| strm->zfree == (free_func)0*/) {\n return Z_STREAM_ERROR;\n }\n\n var state = strm.state;\n if (state.window) {\n state.window = null;\n }\n strm.state = null;\n return Z_OK;\n}\n\nfunction inflateGetHeader(strm, head) {\n var state;\n\n /* check state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR; }\n\n /* save header structure */\n state.head = head;\n head.done = false;\n return Z_OK;\n}\n\nfunction inflateSetDictionary(strm, dictionary) {\n var dictLength = dictionary.length;\n\n var state;\n var dictid;\n var ret;\n\n /* check state */\n if (!strm /* == Z_NULL */ || !strm.state /* == Z_NULL */) { return Z_STREAM_ERROR; }\n state = strm.state;\n\n if (state.wrap !== 0 && state.mode !== DICT) {\n return Z_STREAM_ERROR;\n }\n\n /* check for correct dictionary identifier */\n if (state.mode === DICT) {\n dictid = 1; /* adler32(0, null, 0)*/\n /* dictid = adler32(dictid, dictionary, dictLength); */\n dictid = adler32(dictid, dictionary, dictLength, 0);\n if (dictid !== state.check) {\n return Z_DATA_ERROR;\n }\n }\n /* copy dictionary to window using updatewindow(), which will amend the\n existing dictionary if appropriate */\n ret = updatewindow(strm, dictionary, dictLength, dictLength);\n if (ret) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n state.havedict = 1;\n // Tracev((stderr, \"inflate: dictionary set\\n\"));\n return Z_OK;\n}\n\nexports.inflateReset = inflateReset;\nexports.inflateReset2 = inflateReset2;\nexports.inflateResetKeep = inflateResetKeep;\nexports.inflateInit = inflateInit;\nexports.inflateInit2 = inflateInit2;\nexports.inflate = inflate;\nexports.inflateEnd = inflateEnd;\nexports.inflateGetHeader = inflateGetHeader;\nexports.inflateSetDictionary = inflateSetDictionary;\nexports.inflateInfo = 'pako inflate (from Nodeca project)';\n\n/* Not implemented\nexports.inflateCopy = inflateCopy;\nexports.inflateGetDictionary = inflateGetDictionary;\nexports.inflateMark = inflateMark;\nexports.inflatePrime = inflatePrime;\nexports.inflateSync = inflateSync;\nexports.inflateSyncPoint = inflateSyncPoint;\nexports.inflateUndermine = inflateUndermine;\n*/\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// See state defs from inflate.js\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\n\n/*\n Decode literal, length, and distance codes and write out the resulting\n literal and match bytes until either not enough input or output is\n available, an end-of-block is encountered, or a data error is encountered.\n When large enough input and output buffers are supplied to inflate(), for\n example, a 16K input buffer and a 64K output buffer, more than 95% of the\n inflate execution time is spent in this routine.\n\n Entry assumptions:\n\n state.mode === LEN\n strm.avail_in >= 6\n strm.avail_out >= 258\n start >= strm.avail_out\n state.bits < 8\n\n On return, state.mode is one of:\n\n LEN -- ran out of enough output space or enough available input\n TYPE -- reached end of block code, inflate() to interpret next block\n BAD -- error in block data\n\n Notes:\n\n - The maximum input bits used by a length/distance pair is 15 bits for the\n length code, 5 bits for the length extra, 15 bits for the distance code,\n and 13 bits for the distance extra. This totals 48 bits, or six bytes.\n Therefore if strm.avail_in >= 6, then there is enough input to avoid\n checking for available input while decoding.\n\n - The maximum bytes that a single length/distance pair can output is 258\n bytes, which is the maximum length that can be coded. inflate_fast()\n requires strm.avail_out >= 258 for each loop to avoid checking for\n output space.\n */\nmodule.exports = function inflate_fast(strm, start) {\n var state;\n var _in; /* local strm.input */\n var last; /* have enough input while in < last */\n var _out; /* local strm.output */\n var beg; /* inflate()'s initial strm.output */\n var end; /* while out < end, enough space available */\n//#ifdef INFLATE_STRICT\n var dmax; /* maximum distance from zlib header */\n//#endif\n var wsize; /* window size or zero if not using window */\n var whave; /* valid bytes in the window */\n var wnext; /* window write index */\n // Use `s_window` instead `window`, avoid conflict with instrumentation tools\n var s_window; /* allocated sliding window, if wsize != 0 */\n var hold; /* local strm.hold */\n var bits; /* local strm.bits */\n var lcode; /* local strm.lencode */\n var dcode; /* local strm.distcode */\n var lmask; /* mask for first level of length codes */\n var dmask; /* mask for first level of distance codes */\n var here; /* retrieved table entry */\n var op; /* code bits, operation, extra bits, or */\n /* window position, window bytes to copy */\n var len; /* match length, unused bytes */\n var dist; /* match distance */\n var from; /* where to copy match from */\n var from_source;\n\n\n var input, output; // JS specific, because we have no pointers\n\n /* copy state to local variables */\n state = strm.state;\n //here = state.here;\n _in = strm.next_in;\n input = strm.input;\n last = _in + (strm.avail_in - 5);\n _out = strm.next_out;\n output = strm.output;\n beg = _out - (start - strm.avail_out);\n end = _out + (strm.avail_out - 257);\n//#ifdef INFLATE_STRICT\n dmax = state.dmax;\n//#endif\n wsize = state.wsize;\n whave = state.whave;\n wnext = state.wnext;\n s_window = state.window;\n hold = state.hold;\n bits = state.bits;\n lcode = state.lencode;\n dcode = state.distcode;\n lmask = (1 << state.lenbits) - 1;\n dmask = (1 << state.distbits) - 1;\n\n\n /* decode literals and length/distances until end-of-block or not enough\n input data or output space */\n\n top:\n do {\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n\n here = lcode[hold & lmask];\n\n dolen:\n for (;;) { // Goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n if (op === 0) { /* literal */\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n output[_out++] = here & 0xffff/*here.val*/;\n }\n else if (op & 16) { /* length base */\n len = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (op) {\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n len += hold & ((1 << op) - 1);\n hold >>>= op;\n bits -= op;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", len));\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n here = dcode[hold & dmask];\n\n dodist:\n for (;;) { // goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n\n if (op & 16) { /* distance base */\n dist = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n }\n dist += hold & ((1 << op) - 1);\n//#ifdef INFLATE_STRICT\n if (dist > dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n//#endif\n hold >>>= op;\n bits -= op;\n //Tracevv((stderr, \"inflate: distance %u\\n\", dist));\n op = _out - beg; /* max distance in output */\n if (dist > op) { /* see if copy from window */\n op = dist - op; /* distance back in window */\n if (op > whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// if (len <= op - whave) {\n// do {\n// output[_out++] = 0;\n// } while (--len);\n// continue top;\n// }\n// len -= op - whave;\n// do {\n// output[_out++] = 0;\n// } while (--op > whave);\n// if (op === 0) {\n// from = _out - dist;\n// do {\n// output[_out++] = output[from++];\n// } while (--len);\n// continue top;\n// }\n//#endif\n }\n from = 0; // window index\n from_source = s_window;\n if (wnext === 0) { /* very common case */\n from += wsize - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n else if (wnext < op) { /* wrap around window */\n from += wsize + wnext - op;\n op -= wnext;\n if (op < len) { /* some from end of window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = 0;\n if (wnext < len) { /* some from start of window */\n op = wnext;\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n }\n else { /* contiguous in window */\n from += wnext - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n while (len > 2) {\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n len -= 3;\n }\n if (len) {\n output[_out++] = from_source[from++];\n if (len > 1) {\n output[_out++] = from_source[from++];\n }\n }\n }\n else {\n from = _out - dist; /* copy direct from output */\n do { /* minimum length is three */\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n len -= 3;\n } while (len > 2);\n if (len) {\n output[_out++] = output[from++];\n if (len > 1) {\n output[_out++] = output[from++];\n }\n }\n }\n }\n else if ((op & 64) === 0) { /* 2nd level distance code */\n here = dcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dodist;\n }\n else {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n }\n else if ((op & 64) === 0) { /* 2nd level length code */\n here = lcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dolen;\n }\n else if (op & 32) { /* end-of-block */\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.mode = TYPE;\n break top;\n }\n else {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n } while (_in < last && _out < end);\n\n /* return unused bytes (on entry, bits < 8, so in won't go too far back) */\n len = bits >> 3;\n _in -= len;\n bits -= len << 3;\n hold &= (1 << bits) - 1;\n\n /* update state and return */\n strm.next_in = _in;\n strm.next_out = _out;\n strm.avail_in = (_in < last ? 5 + (last - _in) : 5 - (_in - last));\n strm.avail_out = (_out < end ? 257 + (end - _out) : 257 - (_out - end));\n state.hold = hold;\n state.bits = bits;\n return;\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar utils = require('../utils/common');\n\nvar MAXBITS = 15;\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\n\nvar lbase = [ /* Length codes 257..285 base */\n 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,\n 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0\n];\n\nvar lext = [ /* Length codes 257..285 extra */\n 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,\n 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78\n];\n\nvar dbase = [ /* Distance codes 0..29 base */\n 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,\n 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,\n 8193, 12289, 16385, 24577, 0, 0\n];\n\nvar dext = [ /* Distance codes 0..29 extra */\n 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,\n 23, 23, 24, 24, 25, 25, 26, 26, 27, 27,\n 28, 28, 29, 29, 64, 64\n];\n\nmodule.exports = function inflate_table(type, lens, lens_index, codes, table, table_index, work, opts)\n{\n var bits = opts.bits;\n //here = opts.here; /* table entry for duplication */\n\n var len = 0; /* a code's length in bits */\n var sym = 0; /* index of code symbols */\n var min = 0, max = 0; /* minimum and maximum code lengths */\n var root = 0; /* number of index bits for root table */\n var curr = 0; /* number of index bits for current table */\n var drop = 0; /* code bits to drop for sub-table */\n var left = 0; /* number of prefix codes available */\n var used = 0; /* code entries in table used */\n var huff = 0; /* Huffman code */\n var incr; /* for incrementing code, index */\n var fill; /* index for replicating entries */\n var low; /* low bits for current root entry */\n var mask; /* mask for low root bits */\n var next; /* next available space in table */\n var base = null; /* base value table to use */\n var base_index = 0;\n// var shoextra; /* extra bits table to use */\n var end; /* use base and extra for symbol > end */\n var count = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* number of codes of each length */\n var offs = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* offsets in table for each length */\n var extra = null;\n var extra_index = 0;\n\n var here_bits, here_op, here_val;\n\n /*\n Process a set of code lengths to create a canonical Huffman code. The\n code lengths are lens[0..codes-1]. Each length corresponds to the\n symbols 0..codes-1. The Huffman code is generated by first sorting the\n symbols by length from short to long, and retaining the symbol order\n for codes with equal lengths. Then the code starts with all zero bits\n for the first code of the shortest length, and the codes are integer\n increments for the same length, and zeros are appended as the length\n increases. For the deflate format, these bits are stored backwards\n from their more natural integer increment ordering, and so when the\n decoding tables are built in the large loop below, the integer codes\n are incremented backwards.\n\n This routine assumes, but does not check, that all of the entries in\n lens[] are in the range 0..MAXBITS. The caller must assure this.\n 1..MAXBITS is interpreted as that code length. zero means that that\n symbol does not occur in this code.\n\n The codes are sorted by computing a count of codes for each length,\n creating from that a table of starting indices for each length in the\n sorted table, and then entering the symbols in order in the sorted\n table. The sorted table is work[], with that space being provided by\n the caller.\n\n The length counts are used for other purposes as well, i.e. finding\n the minimum and maximum length codes, determining if there are any\n codes at all, checking for a valid set of lengths, and looking ahead\n at length counts to determine sub-table sizes when building the\n decoding tables.\n */\n\n /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */\n for (len = 0; len <= MAXBITS; len++) {\n count[len] = 0;\n }\n for (sym = 0; sym < codes; sym++) {\n count[lens[lens_index + sym]]++;\n }\n\n /* bound code lengths, force root to be within code lengths */\n root = bits;\n for (max = MAXBITS; max >= 1; max--) {\n if (count[max] !== 0) { break; }\n }\n if (root > max) {\n root = max;\n }\n if (max === 0) { /* no symbols to code at all */\n //table.op[opts.table_index] = 64; //here.op = (var char)64; /* invalid code marker */\n //table.bits[opts.table_index] = 1; //here.bits = (var char)1;\n //table.val[opts.table_index++] = 0; //here.val = (var short)0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n\n //table.op[opts.table_index] = 64;\n //table.bits[opts.table_index] = 1;\n //table.val[opts.table_index++] = 0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n opts.bits = 1;\n return 0; /* no symbols, but wait for decoding to report error */\n }\n for (min = 1; min < max; min++) {\n if (count[min] !== 0) { break; }\n }\n if (root < min) {\n root = min;\n }\n\n /* check for an over-subscribed or incomplete set of lengths */\n left = 1;\n for (len = 1; len <= MAXBITS; len++) {\n left <<= 1;\n left -= count[len];\n if (left < 0) {\n return -1;\n } /* over-subscribed */\n }\n if (left > 0 && (type === CODES || max !== 1)) {\n return -1; /* incomplete set */\n }\n\n /* generate offsets into symbol table for each length for sorting */\n offs[1] = 0;\n for (len = 1; len < MAXBITS; len++) {\n offs[len + 1] = offs[len] + count[len];\n }\n\n /* sort symbols by length, by symbol order within each length */\n for (sym = 0; sym < codes; sym++) {\n if (lens[lens_index + sym] !== 0) {\n work[offs[lens[lens_index + sym]]++] = sym;\n }\n }\n\n /*\n Create and fill in decoding tables. In this loop, the table being\n filled is at next and has curr index bits. The code being used is huff\n with length len. That code is converted to an index by dropping drop\n bits off of the bottom. For codes where len is less than drop + curr,\n those top drop + curr - len bits are incremented through all values to\n fill the table with replicated entries.\n\n root is the number of index bits for the root table. When len exceeds\n root, sub-tables are created pointed to by the root entry with an index\n of the low root bits of huff. This is saved in low to check for when a\n new sub-table should be started. drop is zero when the root table is\n being filled, and drop is root when sub-tables are being filled.\n\n When a new sub-table is needed, it is necessary to look ahead in the\n code lengths to determine what size sub-table is needed. The length\n counts are used for this, and so count[] is decremented as codes are\n entered in the tables.\n\n used keeps track of how many table entries have been allocated from the\n provided *table space. It is checked for LENS and DIST tables against\n the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in\n the initial root table size constants. See the comments in inftrees.h\n for more information.\n\n sym increments through all symbols, and the loop terminates when\n all codes of length max, i.e. all codes, have been processed. This\n routine permits incomplete codes, so another loop after this one fills\n in the rest of the decoding tables with invalid code markers.\n */\n\n /* set up for code type */\n // poor man optimization - use if-else instead of switch,\n // to avoid deopts in old v8\n if (type === CODES) {\n base = extra = work; /* dummy value--not used */\n end = 19;\n\n } else if (type === LENS) {\n base = lbase;\n base_index -= 257;\n extra = lext;\n extra_index -= 257;\n end = 256;\n\n } else { /* DISTS */\n base = dbase;\n extra = dext;\n end = -1;\n }\n\n /* initialize opts for loop */\n huff = 0; /* starting code */\n sym = 0; /* starting code symbol */\n len = min; /* starting code length */\n next = table_index; /* current table to fill in */\n curr = root; /* current table index bits */\n drop = 0; /* current bits to drop from code for index */\n low = -1; /* trigger new sub-table when len > root */\n used = 1 << root; /* use root table entries */\n mask = used - 1; /* mask for comparing low */\n\n /* check available table space */\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* process all codes and make table entries */\n for (;;) {\n /* create table entry */\n here_bits = len - drop;\n if (work[sym] < end) {\n here_op = 0;\n here_val = work[sym];\n }\n else if (work[sym] > end) {\n here_op = extra[extra_index + work[sym]];\n here_val = base[base_index + work[sym]];\n }\n else {\n here_op = 32 + 64; /* end of block */\n here_val = 0;\n }\n\n /* replicate for those indices with low len bits equal to huff */\n incr = 1 << (len - drop);\n fill = 1 << curr;\n min = fill; /* save offset to next table */\n do {\n fill -= incr;\n table[next + (huff >> drop) + fill] = (here_bits << 24) | (here_op << 16) | here_val |0;\n } while (fill !== 0);\n\n /* backwards increment the len-bit code huff */\n incr = 1 << (len - 1);\n while (huff & incr) {\n incr >>= 1;\n }\n if (incr !== 0) {\n huff &= incr - 1;\n huff += incr;\n } else {\n huff = 0;\n }\n\n /* go to next symbol, update count, len */\n sym++;\n if (--count[len] === 0) {\n if (len === max) { break; }\n len = lens[lens_index + work[sym]];\n }\n\n /* create new sub-table if needed */\n if (len > root && (huff & mask) !== low) {\n /* if first time, transition to sub-tables */\n if (drop === 0) {\n drop = root;\n }\n\n /* increment past last table */\n next += min; /* here min is 1 << curr */\n\n /* determine length of next table */\n curr = len - drop;\n left = 1 << curr;\n while (curr + drop < max) {\n left -= count[curr + drop];\n if (left <= 0) { break; }\n curr++;\n left <<= 1;\n }\n\n /* check for enough space */\n used += 1 << curr;\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* point entry in root table to sub-table */\n low = huff & mask;\n /*table.op[low] = curr;\n table.bits[low] = root;\n table.val[low] = next - opts.table_index;*/\n table[low] = (root << 24) | (curr << 16) | (next - table_index) |0;\n }\n }\n\n /* fill in remaining table entry if code is incomplete (guaranteed to have\n at most one remaining entry, since if the code is incomplete, the\n maximum code length that was allowed to get this far is one bit) */\n if (huff !== 0) {\n //table.op[next + huff] = 64; /* invalid code marker */\n //table.bits[next + huff] = len - drop;\n //table.val[next + huff] = 0;\n table[next + huff] = ((len - drop) << 24) | (64 << 16) |0;\n }\n\n /* set return parameters */\n //opts.table_index += used;\n opts.bits = root;\n return 0;\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nmodule.exports = {\n\n /* Allowed flush values; see deflate() and inflate() below for details */\n Z_NO_FLUSH: 0,\n Z_PARTIAL_FLUSH: 1,\n Z_SYNC_FLUSH: 2,\n Z_FULL_FLUSH: 3,\n Z_FINISH: 4,\n Z_BLOCK: 5,\n Z_TREES: 6,\n\n /* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\n Z_OK: 0,\n Z_STREAM_END: 1,\n Z_NEED_DICT: 2,\n Z_ERRNO: -1,\n Z_STREAM_ERROR: -2,\n Z_DATA_ERROR: -3,\n //Z_MEM_ERROR: -4,\n Z_BUF_ERROR: -5,\n //Z_VERSION_ERROR: -6,\n\n /* compression levels */\n Z_NO_COMPRESSION: 0,\n Z_BEST_SPEED: 1,\n Z_BEST_COMPRESSION: 9,\n Z_DEFAULT_COMPRESSION: -1,\n\n\n Z_FILTERED: 1,\n Z_HUFFMAN_ONLY: 2,\n Z_RLE: 3,\n Z_FIXED: 4,\n Z_DEFAULT_STRATEGY: 0,\n\n /* Possible values of the data_type field (though see inflate()) */\n Z_BINARY: 0,\n Z_TEXT: 1,\n //Z_ASCII: 1, // = Z_TEXT (deprecated)\n Z_UNKNOWN: 2,\n\n /* The deflate compression method */\n Z_DEFLATED: 8\n //Z_NULL: null // Use -1 or null inline, depending on var type\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction GZheader() {\n /* true if compressed data believed to be text */\n this.text = 0;\n /* modification time */\n this.time = 0;\n /* extra flags (not used when writing a gzip file) */\n this.xflags = 0;\n /* operating system */\n this.os = 0;\n /* pointer to extra field or Z_NULL if none */\n this.extra = null;\n /* extra field length (valid if extra != Z_NULL) */\n this.extra_len = 0; // Actually, we don't need it in JS,\n // but leave for few code modifications\n\n //\n // Setup limits is not necessary because in js we should not preallocate memory\n // for inflate use constant limit in 65536 bytes\n //\n\n /* space at extra (only when reading header) */\n // this.extra_max = 0;\n /* pointer to zero-terminated file name or Z_NULL */\n this.name = '';\n /* space at name (only when reading header) */\n // this.name_max = 0;\n /* pointer to zero-terminated comment or Z_NULL */\n this.comment = '';\n /* space at comment (only when reading header) */\n // this.comm_max = 0;\n /* true if there was or will be a header crc */\n this.hcrc = 0;\n /* true when done reading gzip header (not used when writing a gzip file) */\n this.done = false;\n}\n\nmodule.exports = GZheader;\n","'use strict'\n\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\n\n/**\n * Takes an (async) iterable that yields buffer-like-objects and concats them\n * into one buffer\n * @param {AsyncIterable|Iterable} stream\n */\nasync function toBuffer (stream) {\n let buffer = new Uint8Array(0)\n\n for await (const buf of stream) {\n buffer = uint8ArrayConcat([buffer, buf], buffer.length + buf.length)\n }\n\n return buffer\n}\n\nmodule.exports = toBuffer\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar errCode = require('err-code');\nvar utils = require('../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar cid = require('multiformats/cid');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction createLs({repo, preload}) {\n async function* ls(ipfsPath, options = {}) {\n const legacyPath = utils.normalizeCidPath(ipfsPath);\n const pathComponents = legacyPath.split('/');\n if (options.preload !== false) {\n preload(cid.CID.parse(pathComponents[0]));\n }\n const ipfsPathOrCid = cid.CID.asCID(legacyPath) || legacyPath;\n const file = await ipfsUnixfsExporter.exporter(ipfsPathOrCid, repo.blocks, options);\n if (file.type === 'file') {\n yield utils.mapFile(file);\n return;\n }\n if (file.type === 'directory') {\n for await (const child of file.content()) {\n yield utils.mapFile(child);\n }\n return;\n }\n throw errCode__default['default'](new Error(`Unknown UnixFS type ${ file.type }`), 'ERR_UNKNOWN_UNIXFS_TYPE');\n }\n return withTimeoutOption.withTimeoutOption(ls);\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar version = require('../version.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createVersion({repo}) {\n async function version$1(_options = {}) {\n const repoVersion = await repo.version.get();\n return {\n version: version.ipfsCore,\n commit: version.commit,\n repo: `${ repoVersion }`,\n 'ipfs-core': version.ipfsCore,\n 'interface-ipfs-core': version.interfaceIpfsCore\n };\n }\n return withTimeoutOption.withTimeoutOption(version$1);\n}\n\nexports.createVersion = createVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst ipfsCore = '0.11.1';\nconst commit = '5ddd0c555cc6577ee15667f4ef4e7f3a3b17d04c';\nconst interfaceIpfsCore = '^0.151.1';\n\nexports.commit = commit;\nexports.interfaceIpfsCore = interfaceIpfsCore;\nexports.ipfsCore = ipfsCore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar version = require('../version.js');\nvar multiaddr = require('multiaddr');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar toString = require('uint8arrays/to-string');\nvar PeerId = require('peer-id');\nvar errors = require('../errors.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\n\nfunction createId({peerId, network}) {\n async function id(options = {}) {\n if (options.peerId === peerId.toB58String()) {\n delete options.peerId;\n }\n const net = network.try();\n if (!net) {\n if (options.peerId) {\n throw new errors.NotStartedError();\n }\n const idStr = peerId.toB58String();\n return {\n id: idStr,\n publicKey: toString.toString(peerId.pubKey.bytes, 'base64pad'),\n addresses: [],\n agentVersion: `js-ipfs/${ version.ipfsCore }`,\n protocolVersion: '9000',\n protocols: []\n };\n }\n const id = options.peerId ? PeerId__default['default'].createFromB58String(options.peerId.toString()) : peerId;\n const {libp2p} = net;\n const publicKey = options.peerId ? libp2p.peerStore.keyBook.get(id) : id.pubKey;\n const addresses = options.peerId ? libp2p.peerStore.addressBook.getMultiaddrsForPeer(id) : libp2p.multiaddrs;\n const protocols = options.peerId ? libp2p.peerStore.protoBook.get(id) : Array.from(libp2p.upgrader.protocols.keys());\n const agentVersion = toString.toString(libp2p.peerStore.metadataBook.getValue(id, 'AgentVersion') || new Uint8Array());\n const protocolVersion = toString.toString(libp2p.peerStore.metadataBook.getValue(id, 'ProtocolVersion') || new Uint8Array());\n const idStr = id.toB58String();\n return {\n id: idStr,\n publicKey: toString.toString(publicKey.bytes, 'base64pad'),\n addresses: (addresses || []).map(ma => {\n const str = ma.toString();\n if (str.endsWith(`/p2p/${ idStr }`)) {\n return str;\n }\n return `${ str }/p2p/${ idStr }`;\n }).sort().map(ma => new multiaddr.Multiaddr(ma)),\n agentVersion,\n protocolVersion,\n protocols: (protocols || []).sort()\n };\n }\n return withTimeoutOption.withTimeoutOption(id);\n}\n\nexports.createId = createId;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar debug = require('debug');\nvar profiles = require('./profiles.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:core:config');\nfunction createConfig({repo}) {\n return {\n getAll: withTimeoutOption.withTimeoutOption(getAll),\n get: withTimeoutOption.withTimeoutOption(get),\n set: withTimeoutOption.withTimeoutOption(set),\n replace: withTimeoutOption.withTimeoutOption(replace),\n profiles: {\n apply: withTimeoutOption.withTimeoutOption(applyProfile),\n list: withTimeoutOption.withTimeoutOption(listProfiles)\n }\n };\n async function getAll(options = {}) {\n return repo.config.getAll(options);\n }\n async function get(key, options) {\n if (!key) {\n return Promise.reject(new Error('key argument is required'));\n }\n return repo.config.get(key, options);\n }\n async function set(key, value, options) {\n return repo.config.set(key, value, options);\n }\n async function replace(value, options) {\n return repo.config.replace(value, options);\n }\n async function applyProfile(profileName, options = { dryRun: false }) {\n const {dryRun} = options;\n const profile = profiles.profiles[profileName];\n if (!profile) {\n throw new Error(`No profile with name '${ profileName }' exists`);\n }\n try {\n const oldCfg = await repo.config.getAll(options);\n let newCfg = JSON.parse(JSON.stringify(oldCfg));\n newCfg = profile.transform(newCfg);\n if (!dryRun) {\n await repo.config.replace(newCfg, options);\n }\n delete oldCfg.Identity.PrivKey;\n delete newCfg.Identity.PrivKey;\n return {\n original: oldCfg,\n updated: newCfg\n };\n } catch (err) {\n log(err);\n throw new Error(`Could not apply profile '${ profileName }' to config: ${ err.message }`);\n }\n }\n}\nasync function listProfiles(_options) {\n return Object.keys(profiles.profiles).map(name => ({\n name,\n description: profiles.profiles[name].description\n }));\n}\n\nexports.createConfig = createConfig;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar set = require('just-safe-set');\nvar getDefaultConfig = require('ipfs-core-config/config');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar set__default = /*#__PURE__*/_interopDefaultLegacy(set);\nvar getDefaultConfig__default = /*#__PURE__*/_interopDefaultLegacy(getDefaultConfig);\n\nconst profiles = {\n server: {\n description: 'Recommended for nodes with public IPv4 address (servers, VPSes, etc.), disables host and content discovery and UPnP in local networks.',\n transform: config => {\n set__default['default'](config, 'Discovery.MDNS.Enabled', false);\n set__default['default'](config, 'Discovery.webRTCStar.Enabled', false);\n config.Swarm = {\n ...config.Swarm || {},\n DisableNatPortMap: true\n };\n return config;\n }\n },\n 'local-discovery': {\n description: 'Sets default values to fields affected by `server` profile, enables discovery and UPnP in local networks.',\n transform: config => {\n set__default['default'](config, 'Discovery.MDNS.Enabled', true);\n set__default['default'](config, 'Discovery.webRTCStar.Enabled', true);\n set__default['default'](config, 'Swarm', {\n ...config.Swarm || {},\n DisableNatPortMap: false\n });\n return config;\n }\n },\n test: {\n description: 'Reduces external interference, useful for running ipfs in test environments. Note that with these settings node won\\'t be able to talk to the rest of the network without manual bootstrap.',\n transform: config => {\n const defaultConfig = getDefaultConfig__default['default']();\n set__default['default'](config, 'Addresses.API', defaultConfig.Addresses.API ? '/ip4/127.0.0.1/tcp/0' : '');\n set__default['default'](config, 'Addresses.Gateway', defaultConfig.Addresses.Gateway ? '/ip4/127.0.0.1/tcp/0' : '');\n set__default['default'](config, 'Addresses.Swarm', defaultConfig.Addresses.Swarm.length ? ['/ip4/127.0.0.1/tcp/0'] : []);\n set__default['default'](config, 'Addresses.Delegates', []);\n set__default['default'](config, 'Bootstrap', []);\n set__default['default'](config, 'Discovery.MDNS.Enabled', false);\n set__default['default'](config, 'Discovery.webRTCStar.Enabled', false);\n set__default['default'](config, 'Swarm', {\n ...config.Swarm || {},\n DisableNatPortMap: true\n });\n return config;\n }\n },\n 'default-networking': {\n description: 'Restores default network settings. Inverse profile of the `test` profile.',\n transform: config => {\n const defaultConfig = getDefaultConfig__default['default']();\n set__default['default'](config, 'Addresses.API', defaultConfig.Addresses.API);\n set__default['default'](config, 'Addresses.Gateway', defaultConfig.Addresses.Gateway);\n set__default['default'](config, 'Addresses.Swarm', defaultConfig.Addresses.Swarm);\n set__default['default'](config, 'Addresses.Delegates', defaultConfig.Addresses.Delegates);\n set__default['default'](config, 'Bootstrap', defaultConfig.Bootstrap);\n set__default['default'](config, 'Discovery.MDNS.Enabled', defaultConfig.Discovery.MDNS.Enabled);\n set__default['default'](config, 'Discovery.webRTCStar.Enabled', defaultConfig.Discovery.webRTCStar.Enabled);\n set__default['default'](config, 'Swarm', {\n ...config.Swarm || {},\n DisableNatPortMap: false\n });\n return config;\n }\n },\n lowpower: {\n description: 'Reduces daemon overhead on the system. May affect node functionality,performance of content discovery and data fetching may be degraded. Recommended for low power systems.',\n transform: config => {\n const Swarm = config.Swarm || {};\n const ConnMgr = Swarm.ConnMgr || {};\n ConnMgr.LowWater = 20;\n ConnMgr.HighWater = 40;\n Swarm.ConnMgr = ConnMgr;\n config.Swarm = Swarm;\n return config;\n }\n },\n 'default-power': {\n description: 'Inverse of \"lowpower\" profile.',\n transform: config => {\n const defaultConfig = getDefaultConfig__default['default']();\n config.Swarm = defaultConfig.Swarm;\n return config;\n }\n }\n};\n\nexports.profiles = profiles;\n","module.exports = set;\n\n/*\n var obj1 = {};\n set(obj1, 'a.aa.aaa', 4); // true\n obj1; // {a: {aa: {aaa: 4}}}\n\n var obj2 = {};\n set(obj2, ['a', 'aa', 'aaa'], 4); // true\n obj2; // {a: {aa: {aaa: 4}}}\n\n var obj3 = {a: {aa: {aaa: 2}}};\n set(obj3, 'a.aa.aaa', 3); // true\n obj3; // {a: {aa: {aaa: 3}}}\n\n // don't clobber existing\n var obj4 = {a: {aa: {aaa: 2}}};\n set(obj4, 'a.aa', {bbb: 7}); // false\n\n const obj5 = {a: {}};\n const sym = Symbol();\n set(obj5.a, sym, 7); // true\n obj5; // {a: {Symbol(): 7}}\n*/\n\nfunction set(obj, propsArg, value) {\n var props, lastProp;\n if (Array.isArray(propsArg)) {\n props = propsArg.slice(0);\n }\n if (typeof propsArg == 'string') {\n props = propsArg.split('.');\n }\n if (typeof propsArg == 'symbol') {\n props = [propsArg];\n }\n if (!Array.isArray(props)) {\n throw new Error('props arg must be an array, a string or a symbol');\n }\n lastProp = props.pop();\n if (!lastProp) {\n return false;\n }\n prototypeCheck(lastProp);\n var thisProp;\n while ((thisProp = props.shift())) {\n prototypeCheck(thisProp);\n if (typeof obj[thisProp] == 'undefined') {\n obj[thisProp] = {};\n }\n obj = obj[thisProp];\n if (!obj || typeof obj != 'object') {\n return false;\n }\n }\n obj[lastProp] = value;\n return true;\n}\n\nfunction prototypeCheck(prop) {\n if (prop === '__proto__' || prop === 'constructor' || prop === 'prototype') {\n throw new Error('setting of prototype values not supported');\n }\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _export = require('./export.js');\nvar get = require('./get.js');\nvar _import = require('./import.js');\nvar put = require('./put.js');\nvar resolve = require('./resolve.js');\n\nclass DagAPI {\n constructor({repo, codecs, hashers, preload}) {\n this.export = _export.createExport({\n repo,\n preload,\n codecs\n });\n this.get = get.createGet({\n codecs,\n repo,\n preload\n });\n this.import = _import.createImport({ repo });\n this.resolve = resolve.createResolve({\n repo,\n codecs,\n preload\n });\n this.put = put.createPut({\n repo,\n codecs,\n hashers,\n preload\n });\n }\n}\n\nexports.DagAPI = DagAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar block = require('multiformats/block');\nvar base58 = require('multiformats/bases/base58');\nvar writer = require('@ipld/car/writer');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar debug = require('debug');\nvar raw = require('multiformats/codecs/raw');\nvar json = require('multiformats/codecs/json');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar json__namespace = /*#__PURE__*/_interopNamespace(json);\n\nconst log = debug__default['default']('ipfs:components:dag:import');\nconst NO_LINKS_CODECS = [\n raw__namespace.code,\n json__namespace.code\n];\nfunction createExport({repo, preload, codecs}) {\n async function* dagExport(root, options = {}) {\n if (options.preload !== false) {\n preload(root);\n }\n const cid$1 = cid.CID.asCID(root);\n if (!cid$1) {\n throw new Error(`Unexpected error converting CID type: ${ root }`);\n }\n log(`Exporting ${ cid$1 } as car`);\n const {writer: writer$1, out} = await writer.CarWriter.create([cid$1]);\n let err = null;\n (async () => {\n try {\n await traverseWrite(repo, {\n signal: options.signal,\n timeout: options.timeout\n }, cid$1, writer$1, codecs);\n writer$1.close();\n } catch (e) {\n err = e;\n }\n })();\n for await (const chunk of out) {\n if (err) {\n break;\n }\n yield chunk;\n }\n if (err) {\n throw err;\n }\n }\n return withTimeoutOption.withTimeoutOption(dagExport);\n}\nasync function traverseWrite(repo, options, cid, writer, codecs, seen = new Set()) {\n const b58Cid = cid.toString(base58.base58btc);\n if (seen.has(b58Cid)) {\n return;\n }\n const block = await getBlock(repo, options, cid, codecs);\n log(`Adding block ${ cid } to car`);\n await writer.put(block);\n seen.add(b58Cid);\n for (const link of block.links) {\n await traverseWrite(repo, options, link, writer, codecs, seen);\n }\n}\nasync function getBlock(repo, options, cid, codecs) {\n const bytes = await repo.blocks.get(cid, options);\n let links = [];\n const codec = await codecs.getCodec(cid.code);\n if (codec) {\n const block$1 = block.createUnsafe({\n bytes,\n cid,\n codec\n });\n links = [...block$1.links()].map(l => l[1]);\n } else if (!NO_LINKS_CODECS.includes(cid.code)) {\n throw new Error(`Can't decode links in block with codec 0x${ cid.code.toString(16) } to form complete DAG`);\n }\n return {\n cid,\n bytes,\n links\n };\n}\n\nexports.createExport = createExport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nrequire('./index.js');\nvar cid = require('./cid.js');\nvar bytes = require('./bytes.js');\n\nconst readonly = ({enumerable = true, configurable = false} = {}) => ({\n enumerable,\n configurable,\n writable: false\n});\nconst links = function* (source, base) {\n if (source == null)\n return;\n if (source instanceof Uint8Array)\n return;\n for (const [key, value] of Object.entries(source)) {\n const path = [\n ...base,\n key\n ];\n if (value != null && typeof value === 'object') {\n if (Array.isArray(value)) {\n for (const [index, element] of value.entries()) {\n const elementPath = [\n ...path,\n index\n ];\n const cid$1 = cid.CID.asCID(element);\n if (cid$1) {\n yield [\n elementPath.join('/'),\n cid$1\n ];\n } else if (typeof element === 'object') {\n yield* links(element, elementPath);\n }\n }\n } else {\n const cid$1 = cid.CID.asCID(value);\n if (cid$1) {\n yield [\n path.join('/'),\n cid$1\n ];\n } else {\n yield* links(value, path);\n }\n }\n }\n }\n};\nconst tree = function* (source, base) {\n if (source == null)\n return;\n for (const [key, value] of Object.entries(source)) {\n const path = [\n ...base,\n key\n ];\n yield path.join('/');\n if (value != null && !(value instanceof Uint8Array) && typeof value === 'object' && !cid.CID.asCID(value)) {\n if (Array.isArray(value)) {\n for (const [index, element] of value.entries()) {\n const elementPath = [\n ...path,\n index\n ];\n yield elementPath.join('/');\n if (typeof element === 'object' && !cid.CID.asCID(element)) {\n yield* tree(element, elementPath);\n }\n }\n } else {\n yield* tree(value, path);\n }\n }\n }\n};\nconst get = (source, path) => {\n let node = source;\n for (const [index, key] of path.entries()) {\n node = node[key];\n if (node == null) {\n throw new Error(`Object has no property at ${ path.slice(0, index + 1).map(part => `[${ JSON.stringify(part) }]`).join('') }`);\n }\n const cid$1 = cid.CID.asCID(node);\n if (cid$1) {\n return {\n value: cid$1,\n remaining: path.slice(index + 1).join('/')\n };\n }\n }\n return { value: node };\n};\nclass Block {\n constructor({cid, bytes, value}) {\n if (!cid || !bytes || typeof value === 'undefined')\n throw new Error('Missing required argument');\n this.cid = cid;\n this.bytes = bytes;\n this.value = value;\n this.asBlock = this;\n Object.defineProperties(this, {\n cid: readonly(),\n bytes: readonly(),\n value: readonly(),\n asBlock: readonly()\n });\n }\n links() {\n return links(this.value, []);\n }\n tree() {\n return tree(this.value, []);\n }\n get(path = '/') {\n return get(this.value, path.split('/').filter(Boolean));\n }\n}\nconst encode = async ({value, codec, hasher}) => {\n if (typeof value === 'undefined')\n throw new Error('Missing required argument \"value\"');\n if (!codec || !hasher)\n throw new Error('Missing required argument: codec or hasher');\n const bytes = codec.encode(value);\n const hash = await hasher.digest(bytes);\n const cid$1 = cid.CID.create(1, codec.code, hash);\n return new Block({\n value,\n bytes,\n cid: cid$1\n });\n};\nconst decode = async ({bytes, codec, hasher}) => {\n if (!bytes)\n throw new Error('Missing required argument \"bytes\"');\n if (!codec || !hasher)\n throw new Error('Missing required argument: codec or hasher');\n const value = codec.decode(bytes);\n const hash = await hasher.digest(bytes);\n const cid$1 = cid.CID.create(1, codec.code, hash);\n return new Block({\n value,\n bytes,\n cid: cid$1\n });\n};\nconst createUnsafe = ({\n bytes,\n cid,\n value: maybeValue,\n codec\n}) => {\n const value = maybeValue !== undefined ? maybeValue : codec && codec.decode(bytes);\n if (value === undefined)\n throw new Error('Missing required argument, must either provide \"value\" or \"codec\"');\n return new Block({\n cid,\n bytes,\n value\n });\n};\nconst create = async ({bytes: bytes$1, cid, hasher, codec}) => {\n if (!bytes$1)\n throw new Error('Missing required argument \"bytes\"');\n if (!hasher)\n throw new Error('Missing required argument \"hasher\"');\n const value = codec.decode(bytes$1);\n const hash = await hasher.digest(bytes$1);\n if (!bytes.equals(cid.multihash.bytes, hash.bytes)) {\n throw new Error('CID hash does not match bytes');\n }\n return createUnsafe({\n bytes: bytes$1,\n cid,\n value,\n codec\n });\n};\n\nexports.Block = Block;\nexports.create = create;\nexports.createUnsafe = createUnsafe;\nexports.decode = decode;\nexports.encode = encode;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar encoder = require('./encoder.js');\nvar iteratorChannel = require('./iterator-channel.js');\nvar decoder = require('./decoder.js');\n\nclass CarWriter {\n constructor(roots, encoder) {\n this._encoder = encoder;\n this._mutex = encoder.setRoots(roots);\n this._ended = false;\n }\n async put(block) {\n if (!(block.bytes instanceof Uint8Array) || !block.cid) {\n throw new TypeError('Can only write {cid, bytes} objects');\n }\n if (this._ended) {\n throw new Error('Already closed');\n }\n const cid$1 = cid.CID.asCID(block.cid);\n if (!cid$1) {\n throw new TypeError('Can only write {cid, bytes} objects');\n }\n this._mutex = this._mutex.then(() => this._encoder.writeBlock({\n cid: cid$1,\n bytes: block.bytes\n }));\n return this._mutex;\n }\n async close() {\n if (this._ended) {\n throw new Error('Already closed');\n }\n await this._mutex;\n this._ended = true;\n return this._encoder.close();\n }\n static create(roots) {\n roots = toRoots(roots);\n const {encoder, iterator} = encodeWriter();\n const writer = new CarWriter(roots, encoder);\n const out = new CarWriterOut(iterator);\n return {\n writer,\n out\n };\n }\n static createAppender() {\n const {encoder, iterator} = encodeWriter();\n encoder.setRoots = () => Promise.resolve();\n const writer = new CarWriter([], encoder);\n const out = new CarWriterOut(iterator);\n return {\n writer,\n out\n };\n }\n static async updateRootsInBytes(bytes, roots) {\n const reader = decoder.bytesReader(bytes);\n await decoder.readHeader(reader);\n const newHeader = encoder.createHeader(roots);\n if (reader.pos !== newHeader.length) {\n throw new Error(`updateRoots() can only overwrite a header of the same length (old header is ${ reader.pos } bytes, new header is ${ newHeader.length } bytes)`);\n }\n bytes.set(newHeader, 0);\n return bytes;\n }\n}\nclass CarWriterOut {\n constructor(iterator) {\n this._iterator = iterator;\n }\n [Symbol.asyncIterator]() {\n if (this._iterating) {\n throw new Error('Multiple iterator not supported');\n }\n this._iterating = true;\n return this._iterator;\n }\n}\nfunction encodeWriter() {\n const iw = iteratorChannel.create();\n const {writer, iterator} = iw;\n const encoder$1 = encoder.createEncoder(writer);\n return {\n encoder: encoder$1,\n iterator\n };\n}\nfunction toRoots(roots) {\n if (roots === undefined) {\n return [];\n }\n if (!Array.isArray(roots)) {\n const cid$1 = cid.CID.asCID(roots);\n if (!cid$1) {\n throw new TypeError('roots must be a single CID or an array of CIDs');\n }\n return [cid$1];\n }\n const _roots = [];\n for (const root of roots) {\n const _root = cid.CID.asCID(root);\n if (!_root) {\n throw new TypeError('roots must be a single CID or an array of CIDs');\n }\n _roots.push(_root);\n }\n return _roots;\n}\nconst __browser = true;\n\nexports.CarWriter = CarWriter;\nexports.CarWriterOut = CarWriterOut;\nexports.__browser = __browser;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar varint = require('varint');\nvar dagCbor = require('@ipld/dag-cbor');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar varint__default = /*#__PURE__*/_interopDefaultLegacy(varint);\n\nfunction createHeader(roots) {\n const headerBytes = dagCbor.encode({\n version: 1,\n roots\n });\n const varintBytes = varint__default[\"default\"].encode(headerBytes.length);\n const header = new Uint8Array(varintBytes.length + headerBytes.length);\n header.set(varintBytes, 0);\n header.set(headerBytes, varintBytes.length);\n return header;\n}\nfunction createEncoder(writer) {\n return {\n async setRoots(roots) {\n const bytes = createHeader(roots);\n await writer.write(bytes);\n },\n async writeBlock(block) {\n const {cid, bytes} = block;\n await writer.write(new Uint8Array(varint__default[\"default\"].encode(cid.bytes.length + bytes.length)));\n await writer.write(cid.bytes);\n if (bytes.length) {\n await writer.write(bytes);\n }\n },\n async close() {\n return writer.end();\n }\n };\n}\n\nexports.createEncoder = createEncoder;\nexports.createHeader = createHeader;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction noop() {\n}\nfunction create() {\n const chunkQueue = [];\n let drainer = null;\n let drainerResolver = noop;\n let ended = false;\n let outWait = null;\n let outWaitResolver = noop;\n const makeDrainer = () => {\n if (!drainer) {\n drainer = new Promise(resolve => {\n drainerResolver = () => {\n drainer = null;\n drainerResolver = noop;\n resolve();\n };\n });\n }\n return drainer;\n };\n const writer = {\n write(chunk) {\n chunkQueue.push(chunk);\n const drainer = makeDrainer();\n outWaitResolver();\n return drainer;\n },\n async end() {\n ended = true;\n const drainer = makeDrainer();\n outWaitResolver();\n return drainer;\n }\n };\n const iterator = {\n async next() {\n const chunk = chunkQueue.shift();\n if (chunk) {\n if (chunkQueue.length === 0) {\n drainerResolver();\n }\n return {\n done: false,\n value: chunk\n };\n }\n if (ended) {\n drainerResolver();\n return {\n done: true,\n value: undefined\n };\n }\n if (!outWait) {\n outWait = new Promise(resolve => {\n outWaitResolver = () => {\n outWait = null;\n outWaitResolver = noop;\n return resolve(iterator.next());\n };\n });\n }\n return outWait;\n }\n };\n return {\n writer,\n iterator\n };\n}\n\nexports.create = create;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar varint = require('varint');\nvar cid = require('multiformats/cid');\nvar Digest = require('multiformats/hashes/digest');\nvar dagCbor = require('@ipld/dag-cbor');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar varint__default = /*#__PURE__*/_interopDefaultLegacy(varint);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\n\nconst CIDV0_BYTES = {\n SHA2_256: 18,\n LENGTH: 32,\n DAG_PB: 112\n};\nasync function readVarint(reader) {\n const bytes = await reader.upTo(8);\n const i = varint__default[\"default\"].decode(bytes);\n reader.seek(varint__default[\"default\"].decode.bytes);\n return i;\n}\nasync function readHeader(reader) {\n const length = await readVarint(reader);\n if (length === 0) {\n throw new Error('Invalid CAR header (zero length)');\n }\n const header = await reader.exactly(length);\n reader.seek(length);\n const block = dagCbor.decode(header);\n if (block == null || Array.isArray(block) || typeof block !== 'object') {\n throw new Error('Invalid CAR header format');\n }\n if (block.version !== 1) {\n if (typeof block.version === 'string') {\n throw new Error(`Invalid CAR version: \"${ block.version }\"`);\n }\n throw new Error(`Invalid CAR version: ${ block.version }`);\n }\n if (!Array.isArray(block.roots)) {\n throw new Error('Invalid CAR header format');\n }\n if (Object.keys(block).filter(p => p !== 'roots' && p !== 'version').length) {\n throw new Error('Invalid CAR header format');\n }\n return block;\n}\nasync function readMultihash(reader) {\n const bytes = await reader.upTo(8);\n varint__default[\"default\"].decode(bytes);\n const codeLength = varint__default[\"default\"].decode.bytes;\n const length = varint__default[\"default\"].decode(bytes.subarray(varint__default[\"default\"].decode.bytes));\n const lengthLength = varint__default[\"default\"].decode.bytes;\n const mhLength = codeLength + lengthLength + length;\n const multihash = await reader.exactly(mhLength);\n reader.seek(mhLength);\n return multihash;\n}\nasync function readCid(reader) {\n const first = await reader.exactly(2);\n if (first[0] === CIDV0_BYTES.SHA2_256 && first[1] === CIDV0_BYTES.LENGTH) {\n const bytes = await reader.exactly(34);\n reader.seek(34);\n const multihash = Digest__namespace.decode(bytes);\n return cid.CID.create(0, CIDV0_BYTES.DAG_PB, multihash);\n }\n const version = await readVarint(reader);\n if (version !== 1) {\n throw new Error(`Unexpected CID version (${ version })`);\n }\n const codec = await readVarint(reader);\n const bytes = await readMultihash(reader);\n const multihash = Digest__namespace.decode(bytes);\n return cid.CID.create(version, codec, multihash);\n}\nasync function readBlockHead(reader) {\n const start = reader.pos;\n let length = await readVarint(reader);\n if (length === 0) {\n throw new Error('Invalid CAR section (zero length)');\n }\n length += reader.pos - start;\n const cid = await readCid(reader);\n const blockLength = length - (reader.pos - start);\n return {\n cid,\n length,\n blockLength\n };\n}\nasync function readBlock(reader) {\n const {cid, blockLength} = await readBlockHead(reader);\n const bytes = await reader.exactly(blockLength);\n reader.seek(blockLength);\n return {\n bytes,\n cid\n };\n}\nasync function readBlockIndex(reader) {\n const offset = reader.pos;\n const {cid, length, blockLength} = await readBlockHead(reader);\n const index = {\n cid,\n length,\n blockLength,\n offset,\n blockOffset: reader.pos\n };\n reader.seek(index.blockLength);\n return index;\n}\nfunction createDecoder(reader) {\n const headerPromise = readHeader(reader);\n return {\n header: () => headerPromise,\n async *blocks() {\n await headerPromise;\n while ((await reader.upTo(8)).length > 0) {\n yield await readBlock(reader);\n }\n },\n async *blocksIndex() {\n await headerPromise;\n while ((await reader.upTo(8)).length > 0) {\n yield await readBlockIndex(reader);\n }\n }\n };\n}\nfunction bytesReader(bytes) {\n let pos = 0;\n return {\n async upTo(length) {\n return bytes.subarray(pos, pos + Math.min(length, bytes.length - pos));\n },\n async exactly(length) {\n if (length > bytes.length - pos) {\n throw new Error('Unexpected end of data');\n }\n return bytes.subarray(pos, pos + length);\n },\n seek(length) {\n pos += length;\n },\n get pos() {\n return pos;\n }\n };\n}\nfunction chunkReader(readChunk) {\n let pos = 0;\n let have = 0;\n let offset = 0;\n let currentChunk = new Uint8Array(0);\n const read = async length => {\n have = currentChunk.length - offset;\n const bufa = [currentChunk.subarray(offset)];\n while (have < length) {\n const chunk = await readChunk();\n if (chunk == null) {\n break;\n }\n if (have < 0) {\n if (chunk.length > have) {\n bufa.push(chunk.subarray(-have));\n }\n } else {\n bufa.push(chunk);\n }\n have += chunk.length;\n }\n currentChunk = new Uint8Array(bufa.reduce((p, c) => p + c.length, 0));\n let off = 0;\n for (const b of bufa) {\n currentChunk.set(b, off);\n off += b.length;\n }\n offset = 0;\n };\n return {\n async upTo(length) {\n if (currentChunk.length - offset < length) {\n await read(length);\n }\n return currentChunk.subarray(offset, offset + Math.min(currentChunk.length - offset, length));\n },\n async exactly(length) {\n if (currentChunk.length - offset < length) {\n await read(length);\n }\n if (currentChunk.length - offset < length) {\n throw new Error('Unexpected end of data');\n }\n return currentChunk.subarray(offset, offset + length);\n },\n seek(length) {\n pos += length;\n offset += length;\n },\n get pos() {\n return pos;\n }\n };\n}\nfunction asyncIterableReader(asyncIterable) {\n const iterator = asyncIterable[Symbol.asyncIterator]();\n async function readChunk() {\n const next = await iterator.next();\n if (next.done) {\n return null;\n }\n return next.value;\n }\n return chunkReader(readChunk);\n}\n\nexports.asyncIterableReader = asyncIterableReader;\nexports.bytesReader = bytesReader;\nexports.chunkReader = chunkReader;\nexports.createDecoder = createDecoder;\nexports.readHeader = readHeader;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar first = require('it-first');\nvar last = require('it-last');\nvar utils = require('../../utils.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar first__default = /*#__PURE__*/_interopDefaultLegacy(first);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction createGet({codecs, repo, preload}) {\n const get = async function get(cid, options = {}) {\n if (options.preload !== false) {\n preload(cid);\n }\n if (options.path) {\n const entry = options.localResolve ? await first__default['default'](utils.resolve(cid, options.path, codecs, repo, options)) : await last__default['default'](utils.resolve(cid, options.path, codecs, repo, options));\n const result = entry;\n if (!result) {\n throw errCode__default['default'](new Error('Not found'), 'ERR_NOT_FOUND');\n }\n return result;\n }\n const codec = await codecs.getCodec(cid.code);\n const block = await repo.blocks.get(cid, options);\n const node = codec.decode(block);\n return {\n value: node,\n remainderPath: ''\n };\n };\n return withTimeoutOption.withTimeoutOption(get);\n}\n\nexports.createGet = createGet;\n","'use strict'\n\n/**\n * Returns the first result from an (async) iterable, unless empty, in which\n * case returns `undefined`.\n *\n * @template T\n * @param {AsyncIterable|Iterable} source\n */\nconst first = async (source) => {\n for await (const entry of source) { // eslint-disable-line no-unreachable-loop\n return entry\n }\n\n return undefined\n}\n\nmodule.exports = first\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar iterator = require('@ipld/car/iterator');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar itPeekable = require('it-peekable');\nvar drain = require('it-drain');\nvar map = require('it-map');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar itPeekable__default = /*#__PURE__*/_interopDefaultLegacy(itPeekable);\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:components:dag:import');\nfunction createImport({repo}) {\n async function* dagImport(sources, options = {}) {\n const release = await repo.gcLock.readLock();\n try {\n const abortOptions = {\n signal: options.signal,\n timeout: options.timeout\n };\n const peekable = itPeekable__default['default'](sources);\n const {value, done} = await peekable.peek();\n if (done) {\n return;\n }\n if (value) {\n peekable.push(value);\n }\n let cars;\n if (value instanceof Uint8Array) {\n cars = [peekable];\n } else {\n cars = peekable;\n }\n for await (const car of cars) {\n const roots = await importCar(repo, abortOptions, car);\n if (options.pinRoots !== false) {\n for (const cid of roots) {\n let pinErrorMsg = '';\n try {\n if (await repo.blocks.has(cid)) {\n log(`Pinning root ${ cid }`);\n await repo.pins.pinRecursively(cid);\n } else {\n pinErrorMsg = 'blockstore: block not found';\n }\n } catch (err) {\n pinErrorMsg = err.message;\n }\n yield {\n root: {\n cid,\n pinErrorMsg\n }\n };\n }\n }\n }\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(dagImport);\n}\nasync function importCar(repo, options, source) {\n const reader = await iterator.CarBlockIterator.fromIterable(source);\n const roots = await reader.getRoots();\n await drain__default['default'](repo.blocks.putMany(map__default['default'](reader, ({\n cid: key,\n bytes: value\n }) => {\n log(`Import block ${ key }`);\n return {\n key,\n value\n };\n }), { signal: options.signal }));\n return roots;\n}\n\nexports.createImport = createImport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar decoder = require('./decoder.js');\n\nclass CarIteratorBase {\n constructor(version, roots, iterable) {\n this._version = version;\n this._roots = roots;\n this._iterable = iterable;\n this._decoded = false;\n }\n get version() {\n return this._version;\n }\n async getRoots() {\n return this._roots;\n }\n}\nclass CarBlockIterator extends CarIteratorBase {\n [Symbol.asyncIterator]() {\n if (this._decoded) {\n throw new Error('Cannot decode more than once');\n }\n if (!this._iterable) {\n throw new Error('Block iterable not found');\n }\n this._decoded = true;\n return this._iterable[Symbol.asyncIterator]();\n }\n static async fromBytes(bytes) {\n const {version, roots, iterator} = await fromBytes(bytes);\n return new CarBlockIterator(version, roots, iterator);\n }\n static async fromIterable(asyncIterable) {\n const {version, roots, iterator} = await fromIterable(asyncIterable);\n return new CarBlockIterator(version, roots, iterator);\n }\n}\nclass CarCIDIterator extends CarIteratorBase {\n [Symbol.asyncIterator]() {\n if (this._decoded) {\n throw new Error('Cannot decode more than once');\n }\n if (!this._iterable) {\n throw new Error('Block iterable not found');\n }\n this._decoded = true;\n const iterable = this._iterable[Symbol.asyncIterator]();\n return {\n async next() {\n const next = await iterable.next();\n if (next.done) {\n return next;\n }\n return {\n done: false,\n value: next.value.cid\n };\n }\n };\n }\n static async fromBytes(bytes) {\n const {version, roots, iterator} = await fromBytes(bytes);\n return new CarCIDIterator(version, roots, iterator);\n }\n static async fromIterable(asyncIterable) {\n const {version, roots, iterator} = await fromIterable(asyncIterable);\n return new CarCIDIterator(version, roots, iterator);\n }\n}\nasync function fromBytes(bytes) {\n if (!(bytes instanceof Uint8Array)) {\n throw new TypeError('fromBytes() requires a Uint8Array');\n }\n return decodeIterator(decoder.bytesReader(bytes));\n}\nasync function fromIterable(asyncIterable) {\n if (!asyncIterable || !(typeof asyncIterable[Symbol.asyncIterator] === 'function')) {\n throw new TypeError('fromIterable() requires an async iterable');\n }\n return decodeIterator(decoder.asyncIterableReader(asyncIterable));\n}\nasync function decodeIterator(reader) {\n const decoder$1 = decoder.createDecoder(reader);\n const {version, roots} = await decoder$1.header();\n return {\n version,\n roots,\n iterator: decoder$1.blocks()\n };\n}\n\nexports.CarBlockIterator = CarBlockIterator;\nexports.CarCIDIterator = CarCIDIterator;\nexports.CarIteratorBase = CarIteratorBase;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createPut({repo, codecs, hashers, preload}) {\n async function put(dagNode, options = {}) {\n const release = options.pin ? await repo.gcLock.readLock() : null;\n try {\n const codecName = options.format || 'dag-cbor';\n const cidVersion = options.version != null ? options.version : codecName === 'dag-pb' ? 0 : 1;\n const codec = await codecs.getCodec(codecName);\n if (!codec) {\n throw new Error(`Unknown codec ${ options.format }, please configure additional BlockCodecs for this IPFS instance`);\n }\n const hasher = await hashers.getHasher(options.hashAlg || 'sha2-256');\n if (!hasher) {\n throw new Error(`Unknown hash algorithm ${ options.hashAlg }, please configure additional MultihashHashers for this IPFS instance`);\n }\n const buf = codec.encode(dagNode);\n const hash = await hasher.digest(buf);\n const cid$1 = cid.CID.create(cidVersion, codec.code, hash);\n await repo.blocks.put(cid$1, buf, { signal: options.signal });\n if (options.pin) {\n await repo.pins.pinRecursively(cid$1);\n }\n if (options.preload !== false) {\n preload(cid$1);\n }\n return cid$1;\n } finally {\n if (release) {\n release();\n }\n }\n }\n return withTimeoutOption.withTimeoutOption(put);\n}\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar toCidAndPath = require('ipfs-core-utils/to-cid-and-path');\nvar utils = require('../../utils.js');\n\nfunction createResolve({repo, codecs, preload}) {\n async function dagResolve(ipfsPath, options = {}) {\n const {cid} = toCidAndPath.toCidAndPath(ipfsPath);\n if (options.preload !== false) {\n preload(cid);\n }\n return utils.resolvePath(repo, codecs, ipfsPath, options);\n }\n return withTimeoutOption.withTimeoutOption(dagResolve);\n}\n\nexports.createResolve = createResolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar toUri = require('multiaddr-to-uri');\nvar debug = require('debug');\nvar shuffle = require('array-shuffle');\nvar nativeAbortController = require('native-abort-controller');\nvar preload = require('ipfs-core-config/preload');\nvar hashlru = require('hashlru');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar toUri__default = /*#__PURE__*/_interopDefaultLegacy(toUri);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar shuffle__default = /*#__PURE__*/_interopDefaultLegacy(shuffle);\nvar hashlru__default = /*#__PURE__*/_interopDefaultLegacy(hashlru);\n\nconst log = Object.assign(debug__default['default']('ipfs:preload'), { error: debug__default['default']('ipfs:preload:error') });\nfunction createPreloader(options = {}) {\n options.enabled = Boolean(options.enabled);\n options.addresses = options.addresses || [];\n options.cache = options.cache || 1000;\n if (!options.enabled || !options.addresses.length) {\n log('preload disabled');\n const api = () => {\n };\n return Object.assign(api, {\n start: () => {\n },\n stop: () => {\n }\n });\n }\n let stopped = true;\n let requests = [];\n const apiUris = options.addresses.map(toUri__default['default']);\n const cache = hashlru__default['default'](options.cache);\n const api = async cid => {\n try {\n if (stopped) {\n throw new Error(`preload ${ cid } but preloader is not started`);\n }\n const path = cid.toString();\n if (cache.has(path)) {\n return;\n }\n cache.set(path, true);\n const fallbackApiUris = shuffle__default['default'](apiUris);\n let success = false;\n const now = Date.now();\n for (const uri of fallbackApiUris) {\n if (stopped)\n throw new Error(`preload aborted for ${ path }`);\n let controller;\n try {\n controller = new nativeAbortController.AbortController();\n requests = requests.concat(controller);\n await preload.preload(`${ uri }/api/v0/refs?r=true&arg=${ encodeURIComponent(path) }`, { signal: controller.signal });\n success = true;\n } catch (err) {\n if (err.type !== 'aborted')\n log.error(err);\n } finally {\n requests = requests.filter(r => r !== controller);\n }\n if (success)\n break;\n }\n log(`${ success ? '' : 'un' }successfully preloaded ${ path } in ${ Date.now() - now }ms`);\n } catch (err) {\n log.error(err);\n }\n };\n api.start = () => {\n stopped = false;\n };\n api.stop = () => {\n stopped = true;\n log(`aborting ${ requests.length } pending preload request(s)`);\n requests.forEach(r => r.abort());\n requests = [];\n };\n return api;\n}\n\nexports.createPreloader = createPreloader;\n","const { Multiaddr } = require('multiaddr')\n\nconst reduceValue = (_, v) => v\nconst tcpUri = (str, port, parts, opts) => {\n // return tcp when explicitly requested\n if (opts && opts.assumeHttp === false) return `tcp://${str}:${port}`\n // check if tcp is the last protocol in multiaddr\n let protocol = 'tcp'\n let explicitPort = `:${port}`\n const last = parts[parts.length - 1]\n if (last.protocol === 'tcp') {\n // assume http and produce clean urls\n protocol = port === '443' ? 'https' : 'http'\n explicitPort = port === '443' || port === '80' ? '' : explicitPort\n }\n return `${protocol}://${str}${explicitPort}`\n}\n\nconst Reducers = {\n ip4: reduceValue,\n ip6: (str, content, i, parts) => (\n parts.length === 1 && parts[0].protocol === 'ip6'\n ? content\n : `[${content}]`\n ),\n tcp: (str, content, i, parts, opts) => (\n parts.some(p => ['http', 'https', 'ws', 'wss'].includes(p.protocol))\n ? `${str}:${content}`\n : tcpUri(str, content, parts, opts)\n ),\n udp: (str, content) => `udp://${str}:${content}`,\n dnsaddr: reduceValue,\n dns4: reduceValue,\n dns6: reduceValue,\n ipfs: (str, content) => `${str}/ipfs/${content}`,\n p2p: (str, content) => `${str}/p2p/${content}`,\n http: str => `http://${str}`,\n https: str => `https://${str}`,\n ws: str => `ws://${str}`,\n wss: str => `wss://${str}`,\n 'p2p-websocket-star': str => `${str}/p2p-websocket-star`,\n 'p2p-webrtc-star': str => `${str}/p2p-webrtc-star`,\n 'p2p-webrtc-direct': str => `${str}/p2p-webrtc-direct`\n}\n\nmodule.exports = (multiaddr, opts) => {\n const ma = new Multiaddr(multiaddr)\n const parts = multiaddr.toString().split('/').slice(1)\n return ma\n .tuples()\n .map(tuple => ({\n protocol: parts.shift(),\n content: tuple[1] ? parts.shift() : null\n }))\n .reduce((str, part, i, parts) => {\n const reduce = Reducers[part.protocol]\n if (!reduce) throw new Error(`Unsupported protocol ${part.protocol}`)\n return reduce(str, part.content, i, parts, opts)\n }, '')\n}\n","'use strict';\n\nmodule.exports = array => {\n\tif (!Array.isArray(array)) {\n\t\tthrow new TypeError(`Expected an array, got ${typeof array}`);\n\t}\n\n\tarray = [...array];\n\n\tfor (let index = array.length - 1; index > 0; index--) {\n\t\tconst newIndex = Math.floor(Math.random() * (index + 1));\n\t\t[array[index], array[newIndex]] = [array[newIndex], array[index]];\n\t}\n\n\treturn array;\n};\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar HTTP = require('ipfs-utils/src/http.js');\nvar debug = require('debug');\nvar PQueue = require('p-queue');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar HTTP__default = /*#__PURE__*/_interopDefaultLegacy(HTTP);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar PQueue__default = /*#__PURE__*/_interopDefaultLegacy(PQueue);\n\nconst log = Object.assign(debug__default[\"default\"]('ipfs:preload'), { error: debug__default[\"default\"]('ipfs:preload:error') });\nconst Queue = PQueue__default[\"default\"].default ? PQueue__default[\"default\"].default : PQueue__default[\"default\"];\nconst httpQueue = new Queue({ concurrency: 4 });\nfunction preload(url, options = {}) {\n log(url);\n return httpQueue.add(async () => {\n const res = await HTTP__default[\"default\"].post(url, { signal: options.signal });\n const reader = res.body.getReader();\n try {\n while (true) {\n const {done} = await reader.read();\n if (done)\n return;\n }\n } finally {\n reader.releaseLock();\n }\n });\n}\n\nexports.preload = preload;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:mfs-preload'), { error: debug__default['default']('ipfs:mfs-preload:error') });\nfunction createMfsPreloader({preload, files, options = {}}) {\n options.interval = options.interval || 30 * 1000;\n if (!options.enabled) {\n log('MFS preload disabled');\n const noop = async () => {\n };\n return {\n start: noop,\n stop: noop\n };\n }\n let rootCid = '';\n let timeoutId;\n const preloadMfs = async () => {\n try {\n const stats = await files.stat('/');\n const nextRootCid = stats.cid.toString();\n if (rootCid !== nextRootCid) {\n log(`preloading updated MFS root ${ rootCid } -> ${ stats.cid }`);\n await preload(stats.cid);\n rootCid = nextRootCid;\n }\n } catch (err) {\n log.error('failed to preload MFS root', err);\n } finally {\n timeoutId = setTimeout(preloadMfs, options.interval);\n }\n };\n return {\n async start() {\n const stats = await files.stat('/');\n rootCid = stats.cid.toString();\n log(`monitoring MFS root ${ stats.cid }`);\n timeoutId = setTimeout(preloadMfs, options.interval);\n },\n stop() {\n clearTimeout(timeoutId);\n }\n };\n}\n\nexports.createMfsPreloader = createMfsPreloader;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar createLock = require('./utils/create-lock.js');\nvar isIpfs = require('is-ipfs');\nvar stat = require('./stat.js');\nvar chmod = require('./chmod.js');\nvar cp = require('./cp.js');\nvar flush = require('./flush.js');\nvar mkdir = require('./mkdir.js');\nvar mv = require('./mv.js');\nvar rm = require('./rm.js');\nvar touch = require('./touch.js');\nvar read = require('./read.js');\nvar write = require('./write.js');\nvar ls = require('./ls.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\n\nconst readOperations = { stat: stat.createStat };\nconst writeOperations = {\n chmod: chmod.createChmod,\n cp: cp.createCp,\n flush: flush.createFlush,\n mkdir: mkdir.createMkdir,\n mv: mv.createMv,\n rm: rm.createRm,\n touch: touch.createTouch\n};\nconst unwrappedOperations = {\n write: write.createWrite,\n read: read.createRead,\n ls: ls.createLs\n};\nconst wrap = ({options, mfs, operations, lock}) => {\n Object.keys(operations).forEach(key => {\n mfs[key] = lock(operations[key](options));\n });\n};\nconst defaultOptions = {\n repoOwner: true,\n repo: null\n};\nfunction createMfs(options) {\n const {repoOwner} = Object.assign({}, defaultOptions || {}, options);\n const lock = createLock.createLock(repoOwner);\n const readLock = operation => {\n return lock.readLock(operation);\n };\n const writeLock = operation => {\n return lock.writeLock(operation);\n };\n const mfs = {};\n wrap({\n options,\n mfs,\n operations: readOperations,\n lock: readLock\n });\n wrap({\n options,\n mfs,\n operations: writeOperations,\n lock: writeLock\n });\n Object.keys(unwrappedOperations).forEach(key => {\n mfs[key] = unwrappedOperations[key](options);\n });\n return mfs;\n}\nfunction createFiles({\n repo,\n preload,\n hashers,\n options: constructorOptions\n}) {\n const methods = createMfs({\n repo,\n repoOwner: Boolean(constructorOptions.repoOwner),\n hashers\n });\n const withPreload = fn => {\n const wrapped = (...args) => {\n const paths = args.filter(arg => isIpfs__default['default'].ipfsPath(arg) || isIpfs__default['default'].cid(arg));\n if (paths.length) {\n const options = args[args.length - 1];\n if (options && options.preload !== false) {\n paths.forEach(path => preload(path));\n }\n }\n return fn(...args);\n };\n return wrapped;\n };\n return {\n ...methods,\n chmod: methods.chmod,\n cp: withPreload(methods.cp),\n mkdir: methods.mkdir,\n stat: withPreload(methods.stat),\n rm: methods.rm,\n read: withPreload(methods.read),\n touch: methods.touch,\n write: methods.write,\n mv: withPreload(methods.mv),\n flush: methods.flush,\n ls: withPreload(async function* (...args) {\n for await (const file of methods.ls(...args)) {\n yield {\n ...file,\n size: file.size || 0\n };\n }\n })\n };\n}\n\nexports.createFiles = createFiles;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mortice = require('mortice');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mortice__default = /*#__PURE__*/_interopDefaultLegacy(mortice);\n\nlet lock;\nfunction createLock(repoOwner = false) {\n if (lock) {\n return lock;\n }\n const mutex = mortice__default['default']({ singleProcess: repoOwner });\n lock = {\n readLock: func => {\n return async (...args) => {\n const releaseLock = await mutex.readLock();\n try {\n return await func.apply(null, args);\n } finally {\n releaseLock();\n }\n };\n },\n writeLock: func => {\n return async (...args) => {\n const releaseLock = await mutex.writeLock();\n try {\n return await func.apply(null, args);\n } finally {\n releaseLock();\n }\n };\n }\n };\n return lock;\n}\n\nexports.createLock = createLock;\n","const node = require('./node')\nconst browser = require('./browser')\nconst { default: Queue } = require('p-queue')\nconst { timeout } = require('promise-timeout')\nconst observe = require('observable-webworkers')\n\nconst mutexes = {}\nlet implementation\n\nfunction createReleaseable (queue, options) {\n let res\n\n const p = new Promise((resolve) => {\n res = resolve\n })\n\n queue.add(() => timeout((() => {\n return new Promise((resolve) => {\n res(() => {\n resolve()\n })\n })\n })(), options.timeout))\n\n return p\n}\n\nconst createMutex = (name, options) => {\n if (implementation.isWorker) {\n return {\n readLock: implementation.readLock(name, options),\n writeLock: implementation.writeLock(name, options)\n }\n }\n\n const masterQueue = new Queue({ concurrency: 1 })\n let readQueue = null\n\n return {\n readLock: () => {\n // If there's already a read queue, just add the task to it\n if (readQueue) {\n return createReleaseable(readQueue, options)\n }\n\n // Create a new read queue\n readQueue = new Queue({\n concurrency: options.concurrency,\n autoStart: false\n })\n const localReadQueue = readQueue\n\n // Add the task to the read queue\n const readPromise = createReleaseable(readQueue, options)\n\n masterQueue.add(() => {\n // Start the task only once the master queue has completed processing\n // any previous tasks\n localReadQueue.start()\n\n // Once all the tasks in the read queue have completed, remove it so\n // that the next read lock will occur after any write locks that were\n // started in the interim\n return localReadQueue.onIdle()\n .then(() => {\n if (readQueue === localReadQueue) {\n readQueue = null\n }\n })\n })\n\n return readPromise\n },\n writeLock: () => {\n // Remove the read queue reference, so that any later read locks will be\n // added to a new queue that starts after this write lock has been\n // released\n readQueue = null\n\n return createReleaseable(masterQueue, options)\n }\n }\n}\n\nconst defaultOptions = {\n concurrency: Infinity,\n timeout: 84600000,\n global: global,\n singleProcess: false\n}\n\nmodule.exports = (name, options) => {\n if (!options) {\n options = {}\n }\n\n if (typeof name === 'object') {\n options = name\n name = 'lock'\n }\n\n if (!name) {\n name = 'lock'\n }\n\n options = Object.assign({}, defaultOptions, options)\n\n if (!implementation) {\n implementation = node(options) || browser(options)\n\n if (!implementation.isWorker) {\n // we are master, set up worker requests\n implementation.on('requestReadLock', (name, fn) => {\n if (!mutexes[name]) {\n return\n }\n\n mutexes[name].readLock()\n .then(release => fn().finally(() => release()))\n })\n\n implementation.on('requestWriteLock', async (name, fn) => {\n if (!mutexes[name]) {\n return\n }\n\n mutexes[name].writeLock()\n .then(release => fn().finally(() => release()))\n })\n }\n }\n\n if (!mutexes[name]) {\n mutexes[name] = createMutex(name, options)\n }\n\n return mutexes[name]\n}\n\nmodule.exports.Worker = function (script, Impl) {\n Impl = Impl || global.Worker\n let worker\n\n try {\n worker = new Impl(script)\n } catch (error) {\n if (error.message.includes('not a constructor')) {\n worker = Impl(script)\n }\n }\n\n if (!worker) {\n throw new Error('Could not create Worker from', Impl)\n }\n\n observe(worker)\n\n return worker\n}\n","const EventEmitter = require('events').EventEmitter\nconst { nanoid } = require('nanoid')\nconst {\n WORKER_REQUEST_READ_LOCK,\n WORKER_RELEASE_READ_LOCK,\n MASTER_GRANT_READ_LOCK,\n WORKER_REQUEST_WRITE_LOCK,\n WORKER_RELEASE_WRITE_LOCK,\n MASTER_GRANT_WRITE_LOCK\n} = require('./constants')\nlet cluster\n\nconst handleWorkerLockRequest = (emitter, masterEvent, requestType, releaseType, grantType) => {\n return (worker, requestEvent) => {\n if (requestEvent && requestEvent.type === requestType) {\n emitter.emit(masterEvent, requestEvent.name, () => {\n // grant lock to worker\n worker.send({\n type: grantType,\n name: requestEvent.name,\n identifier: requestEvent.identifier\n })\n\n // wait for worker to finish\n return new Promise((resolve) => {\n const releaseEventListener = (releaseEvent) => {\n if (releaseEvent && releaseEvent.type === releaseType && releaseEvent.identifier === requestEvent.identifier) {\n worker.removeListener('message', releaseEventListener)\n resolve()\n }\n }\n\n worker.on('message', releaseEventListener)\n })\n })\n }\n }\n}\n\nconst makeWorkerLockRequest = (name, requestType, grantType, releaseType) => {\n return () => {\n const id = nanoid()\n\n process.send({\n type: requestType,\n identifier: id,\n name\n })\n\n return new Promise((resolve) => {\n const listener = (event) => {\n if (event && event.type === grantType && event.identifier === id) {\n process.removeListener('message', listener)\n\n // grant lock\n resolve(() => {\n // release lock\n process.send({\n type: releaseType,\n identifier: id,\n name\n })\n })\n }\n }\n\n process.on('message', listener)\n })\n }\n}\n\nmodule.exports = (options) => {\n try {\n cluster = require('cluster')\n\n if (!Object.keys(cluster).length) {\n return\n }\n } catch (_) {\n return\n }\n\n if (cluster.isMaster || options.singleProcess) {\n const emitter = new EventEmitter()\n\n cluster.on('message', handleWorkerLockRequest(emitter, 'requestReadLock', WORKER_REQUEST_READ_LOCK, WORKER_RELEASE_READ_LOCK, MASTER_GRANT_READ_LOCK))\n cluster.on('message', handleWorkerLockRequest(emitter, 'requestWriteLock', WORKER_REQUEST_WRITE_LOCK, WORKER_RELEASE_WRITE_LOCK, MASTER_GRANT_WRITE_LOCK))\n\n return emitter\n }\n\n return {\n isWorker: true,\n readLock: (name) => makeWorkerLockRequest(name, WORKER_REQUEST_READ_LOCK, MASTER_GRANT_READ_LOCK, WORKER_RELEASE_READ_LOCK),\n writeLock: (name) => makeWorkerLockRequest(name, WORKER_REQUEST_WRITE_LOCK, MASTER_GRANT_WRITE_LOCK, WORKER_RELEASE_WRITE_LOCK)\n }\n}\n","\nmodule.exports = {\n WORKER_REQUEST_READ_LOCK: 'lock:worker:request-read',\n WORKER_RELEASE_READ_LOCK: 'lock:worker:release-read',\n MASTER_GRANT_READ_LOCK: 'lock:master:grant-read',\n\n WORKER_REQUEST_WRITE_LOCK: 'lock:worker:request-write',\n WORKER_RELEASE_WRITE_LOCK: 'lock:worker:release-write',\n MASTER_GRANT_WRITE_LOCK: 'lock:master:grant-write'\n}\n","const EventEmitter = require('events').EventEmitter\nconst { nanoid } = require('nanoid')\nconst {\n WORKER_REQUEST_READ_LOCK,\n WORKER_RELEASE_READ_LOCK,\n MASTER_GRANT_READ_LOCK,\n WORKER_REQUEST_WRITE_LOCK,\n WORKER_RELEASE_WRITE_LOCK,\n MASTER_GRANT_WRITE_LOCK\n} = require('./constants')\nconst observer = require('observable-webworkers')\n\nconst handleWorkerLockRequest = (emitter, masterEvent, requestType, releaseType, grantType) => {\n return (worker, event) => {\n if (!event || !event.data || event.data.type !== requestType) {\n return\n }\n\n const requestEvent = {\n type: event.data.type,\n name: event.data.name,\n identifier: event.data.identifier\n }\n\n emitter.emit(masterEvent, requestEvent.name, () => {\n // grant lock to worker\n worker.postMessage({\n type: grantType,\n name: requestEvent.name,\n identifier: requestEvent.identifier\n })\n\n // wait for worker to finish\n return new Promise((resolve) => {\n const releaseEventListener = (event) => {\n if (!event || !event.data) {\n return\n }\n\n const releaseEvent = {\n type: event.data.type,\n name: event.data.name,\n identifier: event.data.identifier\n }\n\n if (releaseEvent && releaseEvent.type === releaseType && releaseEvent.identifier === requestEvent.identifier) {\n worker.removeEventListener('message', releaseEventListener)\n resolve()\n }\n }\n\n worker.addEventListener('message', releaseEventListener)\n })\n })\n }\n}\n\nconst makeWorkerLockRequest = (name, requestType, grantType, releaseType) => {\n return () => {\n const id = nanoid()\n\n globalThis.postMessage({\n type: requestType,\n identifier: id,\n name\n })\n\n return new Promise((resolve) => {\n const listener = (event) => {\n if (!event || !event.data) {\n return\n }\n\n const responseEvent = {\n type: event.data.type,\n identifier: event.data.identifier\n }\n\n if (responseEvent && responseEvent.type === grantType && responseEvent.identifier === id) {\n globalThis.removeEventListener('message', listener)\n\n // grant lock\n resolve(() => {\n // release lock\n globalThis.postMessage({\n type: releaseType,\n identifier: id,\n name\n })\n })\n }\n }\n\n globalThis.addEventListener('message', listener)\n })\n }\n}\n\nconst defaultOptions = {\n singleProcess: false\n}\n\nmodule.exports = (options) => {\n options = Object.assign({}, defaultOptions, options)\n const isMaster = !!globalThis.document || options.singleProcess\n\n if (isMaster) {\n const emitter = new EventEmitter()\n\n observer.addEventListener('message', handleWorkerLockRequest(emitter, 'requestReadLock', WORKER_REQUEST_READ_LOCK, WORKER_RELEASE_READ_LOCK, MASTER_GRANT_READ_LOCK))\n observer.addEventListener('message', handleWorkerLockRequest(emitter, 'requestWriteLock', WORKER_REQUEST_WRITE_LOCK, WORKER_RELEASE_WRITE_LOCK, MASTER_GRANT_WRITE_LOCK))\n\n return emitter\n }\n\n return {\n isWorker: true,\n readLock: (name) => makeWorkerLockRequest(name, WORKER_REQUEST_READ_LOCK, MASTER_GRANT_READ_LOCK, WORKER_RELEASE_READ_LOCK),\n writeLock: (name) => makeWorkerLockRequest(name, WORKER_REQUEST_WRITE_LOCK, MASTER_GRANT_WRITE_LOCK, WORKER_RELEASE_WRITE_LOCK)\n }\n}\n","const events = {}\n\nconst observable = (worker) => {\n worker.addEventListener('message', (event) => {\n observable.dispatchEvent('message', worker, event)\n })\n\n if (worker.port) {\n worker.port.addEventListener('message', (event) => {\n observable.dispatchEvent('message', worker, event)\n })\n }\n}\n\nobservable.addEventListener = (type, fn) => {\n if (!events[type]) {\n events[type] = []\n }\n\n events[type].push(fn)\n}\n\nobservable.removeEventListener = (type, fn) => {\n if (!events[type]) {\n return\n }\n\n events[type] = events[type]\n .filter(listener => listener === fn)\n}\n\nobservable.dispatchEvent = function () {\n const args = Array.prototype.slice.call(arguments)\n const type = args.shift()\n\n if (!events[type]) {\n return\n }\n\n events[type].forEach(fn => fn.apply(null, args))\n}\n\nmodule.exports = observable\n","// Copyright (c) 2015-2017 David M. Lee, II\n'use strict';\n\n/**\n * Local reference to TimeoutError\n * @private\n */\nvar TimeoutError;\n\n/**\n * Rejects a promise with a {@link TimeoutError} if it does not settle within\n * the specified timeout.\n *\n * @param {Promise} promise The promise.\n * @param {number} timeoutMillis Number of milliseconds to wait on settling.\n * @returns {Promise} Either resolves/rejects with `promise`, or rejects with\n * `TimeoutError`, whichever settles first.\n */\nvar timeout = module.exports.timeout = function(promise, timeoutMillis) {\n var error = new TimeoutError(),\n timeout;\n\n return Promise.race([\n promise,\n new Promise(function(resolve, reject) {\n timeout = setTimeout(function() {\n reject(error);\n }, timeoutMillis);\n }),\n ]).then(function(v) {\n clearTimeout(timeout);\n return v;\n }, function(err) {\n clearTimeout(timeout);\n throw err;\n });\n};\n\n/**\n * Exception indicating that the timeout expired.\n */\nTimeoutError = module.exports.TimeoutError = function() {\n Error.call(this)\n this.stack = Error().stack\n this.message = 'Timeout';\n};\n\nTimeoutError.prototype = Object.create(Error.prototype);\nTimeoutError.prototype.name = \"TimeoutError\";\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mergeOpts = require('merge-options');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar dagPB = require('@ipld/dag-pb');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:stat');\nconst defaultOptions = { withLocal: false };\nfunction createStat(context) {\n async function mfsStat(path, options = {}) {\n options = mergeOptions(defaultOptions, options);\n log(`Fetching stats for ${ path }`);\n const {type, cid, mfsPath} = await toMfsPath.toMfsPath(context, path, options);\n const exportPath = type === 'ipfs' && cid ? cid : mfsPath;\n let file;\n try {\n file = await ipfsUnixfsExporter.exporter(exportPath, context.repo.blocks);\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n throw errCode__default['default'](new Error(`${ path } does not exist`), 'ERR_NOT_FOUND');\n }\n throw err;\n }\n if (!statters[file.type]) {\n throw new Error(`Cannot stat codec ${ file.cid.code }`);\n }\n return statters[file.type](file);\n }\n return withTimeoutOption.withTimeoutOption(mfsStat);\n}\nconst statters = {\n raw: file => {\n return {\n cid: file.cid,\n size: file.node.length,\n cumulativeSize: file.node.length,\n blocks: 0,\n type: 'file',\n local: undefined,\n sizeLocal: undefined,\n withLocality: false\n };\n },\n file: file => {\n const stat = {\n cid: file.cid,\n type: 'file',\n size: file.unixfs.fileSize(),\n cumulativeSize: dagPB__namespace.encode(file.node).length + (file.node.Links || []).reduce((acc, curr) => acc + (curr.Tsize || 0), 0),\n blocks: file.unixfs.blockSizes.length,\n local: undefined,\n sizeLocal: undefined,\n withLocality: false,\n mode: file.unixfs.mode\n };\n if (file.unixfs.mtime) {\n stat.mtime = file.unixfs.mtime;\n }\n return stat;\n },\n directory: file => {\n const stat = {\n cid: file.cid,\n type: 'directory',\n size: 0,\n cumulativeSize: dagPB__namespace.encode(file.node).length + (file.node.Links || []).reduce((acc, curr) => acc + (curr.Tsize || 0), 0),\n blocks: file.node.Links.length,\n local: undefined,\n sizeLocal: undefined,\n withLocality: false,\n mode: file.unixfs.mode\n };\n if (file.unixfs.mtime) {\n stat.mtime = file.unixfs.mtime;\n }\n return stat;\n },\n object: file => {\n return {\n cid: file.cid,\n size: file.node.length,\n cumulativeSize: file.node.length,\n type: 'file',\n blocks: 0,\n local: undefined,\n sizeLocal: undefined,\n withLocality: false\n };\n },\n identity: file => {\n return {\n cid: file.cid,\n size: file.node.length,\n cumulativeSize: file.node.length,\n blocks: 0,\n type: 'file',\n local: undefined,\n sizeLocal: undefined,\n withLocality: false\n };\n }\n};\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withMfsRoot = require('./with-mfs-root.js');\nvar toPathComponents = require('./to-path-components.js');\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar errCode = require('err-code');\nvar cid = require('multiformats/cid');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst IPFS_PREFIX = 'ipfs';\nconst toMfsPath = async (context, path, options) => {\n const root = await withMfsRoot.loadMfsRoot(context, options);\n let output = { entryType: 'file' };\n let ipfsPath = '';\n if (cid.CID.asCID(path)) {\n ipfsPath = `/ipfs/${ path }`;\n } else {\n ipfsPath = path.toString();\n }\n ipfsPath = ipfsPath.trim();\n ipfsPath = ipfsPath.replace(/(\\/\\/+)/g, '/');\n if (ipfsPath.endsWith('/') && ipfsPath.length > 1) {\n ipfsPath = ipfsPath.substring(0, ipfsPath.length - 1);\n }\n if (!ipfsPath) {\n throw errCode__default['default'](new Error('paths must not be empty'), 'ERR_NO_PATH');\n }\n if (ipfsPath.substring(0, 1) !== '/') {\n throw errCode__default['default'](new Error('paths must start with a leading slash'), 'ERR_INVALID_PATH');\n }\n if (ipfsPath.substring(ipfsPath.length - 1) === '/') {\n ipfsPath = ipfsPath.substring(0, ipfsPath.length - 1);\n }\n const pathComponents = toPathComponents.toPathComponents(ipfsPath);\n if (pathComponents[0] === IPFS_PREFIX) {\n let mfsDirectory;\n if (pathComponents.length === 2) {\n mfsDirectory = `/${ pathComponents.join('/') }`;\n } else {\n mfsDirectory = `/${ pathComponents.slice(0, pathComponents.length - 1).join('/') }`;\n }\n output = {\n type: 'ipfs',\n depth: pathComponents.length - 2,\n entryType: 'file',\n mfsPath: `/${ pathComponents.join('/') }`,\n mfsDirectory,\n parts: pathComponents,\n path: `/${ pathComponents.join('/') }`,\n name: pathComponents[pathComponents.length - 1]\n };\n } else {\n const mfsPath = `/${ IPFS_PREFIX }/${ root }${ pathComponents.length ? '/' + pathComponents.join('/') : '' }`;\n const mfsDirectory = `/${ IPFS_PREFIX }/${ root }/${ pathComponents.slice(0, pathComponents.length - 1).join('/') }`;\n output = {\n type: 'mfs',\n depth: pathComponents.length,\n entryType: 'file',\n mfsDirectory,\n mfsPath,\n parts: pathComponents,\n path: `/${ pathComponents.join('/') }`,\n name: pathComponents[pathComponents.length - 1]\n };\n }\n const cidPath = output.type === 'mfs' ? output.mfsPath : output.path;\n try {\n const res = await ipfsUnixfsExporter.exporter(cidPath, context.repo.blocks, options);\n output.cid = res.cid;\n output.mfsPath = `/ipfs/${ res.path }`;\n output.entryType = res.type;\n output.content = res.content;\n if ((output.entryType === 'file' || output.entryType === 'directory') && (res.type === 'file' || res.type === 'directory')) {\n output.unixfs = res.unixfs;\n }\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n }\n output.exists = Boolean(output.cid);\n return output;\n};\n\nexports.toMfsPath = toMfsPath;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dagPB = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar utils = require('../../../utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst log = debug__default['default']('ipfs:mfs:utils:with-mfs-root');\nasync function loadMfsRoot(context, options) {\n if (options && options.signal && options.signal.aborted) {\n throw errCode__default['default'](new Error('Request aborted'), 'ERR_ABORTED', { name: 'Aborted' });\n }\n await context.repo.datastore.open();\n let cid$1;\n try {\n const buf = await context.repo.datastore.get(utils.MFS_ROOT_KEY);\n cid$1 = cid.CID.decode(buf);\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n log('Creating new MFS root');\n const buf = dagPB__namespace.encode({\n Data: new ipfsUnixfs.UnixFS({ type: 'directory' }).marshal(),\n Links: []\n });\n const hash = await sha2.sha256.digest(buf);\n cid$1 = cid.CID.createV0(hash);\n await context.repo.blocks.put(cid$1, buf);\n if (options && options.signal && options.signal.aborted) {\n throw errCode__default['default'](new Error('Request aborted'), 'ERR_ABORTED', { name: 'Aborted' });\n }\n await context.repo.datastore.put(utils.MFS_ROOT_KEY, cid$1.bytes);\n }\n log(`Loaded MFS root /ipfs/${ cid$1 }`);\n return cid$1;\n}\n\nexports.loadMfsRoot = loadMfsRoot;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction toPathComponents(path = '') {\n return (path.trim().match(/([^\\\\^/]|\\\\\\/)+/g) || []).filter(Boolean);\n}\n\nexports.toPathComponents = toPathComponents;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mergeOpts = require('merge-options');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar toTrail = require('./utils/to-trail.js');\nvar addLink = require('./utils/add-link.js');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar itPipe = require('it-pipe');\nvar ipfsUnixfsImporter = require('ipfs-unixfs-importer');\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar last = require('it-last');\nvar cp = require('./cp.js');\nvar rm = require('./rm.js');\nvar persist = require('./utils/persist.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:touch');\nconst defaultOptions = {\n flush: true,\n shardSplitThreshold: 1000,\n hashAlg: 'sha2-256',\n cidVersion: 0,\n recursive: false\n};\nfunction calculateModification(mode, originalMode, isDirectory) {\n let modification = 0;\n if (mode.includes('x') || mode.includes('X') && (isDirectory || (originalMode & 1 || originalMode & 8 || originalMode & 64))) {\n modification += 1;\n }\n if (mode.includes('w')) {\n modification += 2;\n }\n if (mode.includes('r')) {\n modification += 4;\n }\n return modification;\n}\nfunction calculateUGO(references, modification) {\n let ugo = 0;\n if (references.includes('u')) {\n ugo += modification << 6;\n }\n if (references.includes('g')) {\n ugo += modification << 3;\n }\n if (references.includes('o')) {\n ugo += modification;\n }\n return ugo;\n}\nfunction calculateSpecial(references, mode, modification) {\n if (mode.includes('t')) {\n modification += parseInt('1000', 8);\n }\n if (mode.includes('s')) {\n if (references.includes('u')) {\n modification += parseInt('4000', 8);\n }\n if (references.includes('g')) {\n modification += parseInt('2000', 8);\n }\n }\n return modification;\n}\nfunction parseSymbolicMode(input, originalMode, isDirectory) {\n if (!originalMode) {\n originalMode = 0;\n }\n const match = input.match(/^(u?g?o?a?)(-?\\+?=?)?(r?w?x?X?s?t?)$/);\n if (!match) {\n throw new Error(`Invalid file mode: ${ input }`);\n }\n let [, references, operator, mode] = match;\n if (references === 'a' || !references) {\n references = 'ugo';\n }\n let modification = calculateModification(mode, originalMode, isDirectory);\n modification = calculateUGO(references, modification);\n modification = calculateSpecial(references, mode, modification);\n if (operator === '=') {\n if (references.includes('u')) {\n originalMode = originalMode & parseInt('7077', 8);\n originalMode = originalMode | modification;\n }\n if (references.includes('g')) {\n originalMode = originalMode & parseInt('7707', 8);\n originalMode = originalMode | modification;\n }\n if (references.includes('o')) {\n originalMode = originalMode & parseInt('7770', 8);\n originalMode = originalMode | modification;\n }\n return originalMode;\n }\n if (operator === '+') {\n return modification | originalMode;\n }\n if (operator === '-') {\n return modification ^ originalMode;\n }\n return originalMode;\n}\nfunction calculateMode(mode, metadata) {\n if (mode instanceof String || typeof mode === 'string') {\n const strMode = `${ mode }`;\n if (strMode.match(/^\\d+$/g)) {\n mode = parseInt(strMode, 8);\n } else {\n mode = 0 + strMode.split(',').reduce((curr, acc) => {\n return parseSymbolicMode(acc, curr, metadata.isDirectory());\n }, metadata.mode || 0);\n }\n }\n return mode;\n}\nfunction createChmod(context) {\n async function mfsChmod(path, mode, options = {}) {\n const opts = mergeOptions(defaultOptions, options);\n log(`Fetching stats for ${ path }`);\n const {cid: cid$1, mfsDirectory, name} = await toMfsPath.toMfsPath(context, path, opts);\n if (cid$1.code !== dagPB__namespace.code) {\n throw errCode__default['default'](new Error(`${ path } was not a UnixFS node`), 'ERR_NOT_UNIXFS');\n }\n if (opts.recursive) {\n const root = await itPipe.pipe(async function* () {\n for await (const entry of ipfsUnixfsExporter.recursive(cid$1, context.repo.blocks)) {\n if (entry.type !== 'file' && entry.type !== 'directory') {\n throw errCode__default['default'](new Error(`${ path } was not a UnixFS node`), 'ERR_NOT_UNIXFS');\n }\n entry.unixfs.mode = calculateMode(mode, entry.unixfs);\n const node = dagPB__namespace.prepare({\n Data: entry.unixfs.marshal(),\n Links: entry.node.Links\n });\n yield {\n path: entry.path,\n content: node\n };\n }\n }, source => ipfsUnixfsImporter.importer(source, context.repo.blocks, {\n ...opts,\n pin: false,\n dagBuilder: async function* (source, block, opts) {\n for await (const entry of source) {\n yield async function () {\n const node = entry.content;\n const buf = dagPB__namespace.encode(node);\n const cid = await persist.persist(buf, block, opts);\n if (!node.Data) {\n throw errCode__default['default'](new Error(`${ cid } had no data`), 'ERR_INVALID_NODE');\n }\n const unixfs = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n return {\n cid,\n size: buf.length,\n path: entry.path,\n unixfs\n };\n };\n }\n }\n }), nodes => last__default['default'](nodes));\n if (!root) {\n throw errCode__default['default'](new Error(`Could not chmod ${ path }`), 'ERR_COULD_NOT_CHMOD');\n }\n await rm.createRm(context)(path, opts);\n await cp.createCp(context)(`/ipfs/${ root.cid }`, path, opts);\n return;\n }\n const block = await context.repo.blocks.get(cid$1);\n const node = dagPB__namespace.decode(block);\n if (!node.Data) {\n throw errCode__default['default'](new Error(`${ cid$1 } had no data`), 'ERR_INVALID_NODE');\n }\n const metadata = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n metadata.mode = calculateMode(mode, metadata);\n const updatedBlock = dagPB__namespace.encode({\n Data: metadata.marshal(),\n Links: node.Links\n });\n const hashAlg = opts.hashAlg || defaultOptions.hashAlg;\n const hasher = await context.hashers.getHasher(hashAlg);\n const hash = await hasher.digest(updatedBlock);\n const updatedCid = cid.CID.create(opts.cidVersion, dagPB__namespace.code, hash);\n if (opts.flush) {\n await context.repo.blocks.put(updatedCid, updatedBlock);\n }\n const trail = await toTrail.toTrail(context, mfsDirectory);\n const parent = trail[trail.length - 1];\n const parentCid = cid.CID.decode(parent.cid.bytes);\n const parentBlock = await context.repo.blocks.get(parentCid);\n const parentNode = dagPB__namespace.decode(parentBlock);\n const result = await addLink.addLink(context, {\n parent: parentNode,\n name: name,\n cid: updatedCid,\n size: updatedBlock.length,\n flush: opts.flush,\n hashAlg,\n cidVersion: cid$1.version,\n shardSplitThreshold: Infinity\n });\n parent.cid = result.cid;\n const newRootCid = await updateTree.updateTree(context, trail, opts);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, opts);\n }\n return withTimeoutOption.withTimeoutOption(mfsChmod);\n}\n\nexports.createChmod = createChmod;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:mfs:utils:to-trail');\nasync function toTrail(context, path) {\n log(`Creating trail for path ${ path }`);\n const output = [];\n for await (const fsEntry of ipfsUnixfsExporter.walkPath(path, context.repo.blocks)) {\n output.push({\n name: fsEntry.name,\n cid: fsEntry.cid,\n size: fsEntry.size,\n type: fsEntry.type\n });\n }\n return output;\n}\n\nexports.toTrail = toTrail;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar debug = require('debug');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dirSharded = require('./dir-sharded.js');\nvar hamtUtils = require('./hamt-utils.js');\nvar errCode = require('err-code');\nvar last = require('it-last');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst log = debug__default['default']('ipfs:mfs:core:utils:add-link');\nasync function addLink(context, options) {\n let parent = options.parent;\n if (options.parentCid) {\n const parentCid = cid.CID.asCID(options.parentCid);\n if (parentCid === null) {\n throw errCode__default['default'](new Error('Invalid CID passed to addLink'), 'EINVALIDPARENTCID');\n }\n if (parentCid.code !== dagPB__namespace.code) {\n throw errCode__default['default'](new Error('Unsupported codec. Only DAG-PB is supported'), 'EINVALIDPARENTCID');\n }\n log(`Loading parent node ${ parentCid }`);\n const block = await context.repo.blocks.get(parentCid);\n parent = dagPB__namespace.decode(block);\n }\n if (!parent) {\n throw errCode__default['default'](new Error('No parent node or CID passed to addLink'), 'EINVALIDPARENT');\n }\n if (!options.cid) {\n throw errCode__default['default'](new Error('No child cid passed to addLink'), 'EINVALIDCHILDCID');\n }\n if (!options.name) {\n throw errCode__default['default'](new Error('No child name passed to addLink'), 'EINVALIDCHILDNAME');\n }\n if (!options.size && options.size !== 0) {\n throw errCode__default['default'](new Error('No child size passed to addLink'), 'EINVALIDCHILDSIZE');\n }\n if (!parent.Data) {\n throw errCode__default['default'](new Error('Parent node with no data passed to addLink'), 'ERR_INVALID_PARENT');\n }\n const meta = ipfsUnixfs.UnixFS.unmarshal(parent.Data);\n if (meta.type === 'hamt-sharded-directory') {\n log('Adding link to sharded directory');\n return addToShardedDirectory(context, {\n ...options,\n parent\n });\n }\n if (parent.Links.length >= options.shardSplitThreshold) {\n log('Converting directory to sharded directory');\n return convertToShardedDirectory(context, {\n ...options,\n parent,\n mtime: meta.mtime,\n mode: meta.mode\n });\n }\n log(`Adding ${ options.name } (${ options.cid }) to regular directory`);\n return addToDirectory(context, {\n ...options,\n parent\n });\n}\nconst convertToShardedDirectory = async (context, options) => {\n const result = await hamtUtils.createShard(context, options.parent.Links.map(link => ({\n name: link.Name || '',\n size: link.Tsize || 0,\n cid: link.Hash\n })).concat({\n name: options.name,\n size: options.size,\n cid: options.cid\n }), options);\n log(`Converted directory to sharded directory ${ result.cid }`);\n return result;\n};\nconst addToDirectory = async (context, options) => {\n const parentLinks = options.parent.Links.filter(link => {\n return link.Name !== options.name;\n });\n parentLinks.push({\n Name: options.name,\n Tsize: options.size,\n Hash: options.cid\n });\n if (!options.parent.Data) {\n throw errCode__default['default'](new Error('Parent node with no data passed to addToDirectory'), 'ERR_INVALID_PARENT');\n }\n const node = ipfsUnixfs.UnixFS.unmarshal(options.parent.Data);\n let data;\n if (node.mtime) {\n const ms = Date.now();\n const secs = Math.floor(ms / 1000);\n node.mtime = {\n secs: secs,\n nsecs: (ms - secs * 1000) * 1000\n };\n data = node.marshal();\n } else {\n data = options.parent.Data;\n }\n options.parent = dagPB__namespace.prepare({\n Data: data,\n Links: parentLinks\n });\n const hasher = await context.hashers.getHasher(options.hashAlg);\n const buf = dagPB__namespace.encode(options.parent);\n const hash = await hasher.digest(buf);\n const cid$1 = cid.CID.create(options.cidVersion, dagPB__namespace.code, hash);\n if (options.flush) {\n await context.repo.blocks.put(cid$1, buf);\n }\n return {\n node: options.parent,\n cid: cid$1,\n size: buf.length\n };\n};\nconst addToShardedDirectory = async (context, options) => {\n const {shard, path} = await addFileToShardedDirectory(context, options);\n const result = await last__default['default'](shard.flush(context.repo.blocks));\n if (!result) {\n throw new Error('No result from flushing shard');\n }\n const block = await context.repo.blocks.get(result.cid);\n const node = dagPB__namespace.decode(block);\n const parentLinks = options.parent.Links.filter(link => {\n return (link.Name || '').substring(0, 2) !== path[0].prefix;\n });\n const newLink = node.Links.find(link => (link.Name || '').substring(0, 2) === path[0].prefix);\n if (!newLink) {\n throw new Error(`No link found with prefix ${ path[0].prefix }`);\n }\n parentLinks.push(newLink);\n return hamtUtils.updateHamtDirectory(context, parentLinks, path[0].bucket, options);\n};\nconst addFileToShardedDirectory = async (context, options) => {\n const file = {\n name: options.name,\n cid: options.cid,\n size: options.size\n };\n if (!options.parent.Data) {\n throw errCode__default['default'](new Error('Parent node with no data passed to addFileToShardedDirectory'), 'ERR_INVALID_PARENT');\n }\n const rootBucket = await hamtUtils.recreateInitialHamtLevel(options.parent.Links);\n const node = ipfsUnixfs.UnixFS.unmarshal(options.parent.Data);\n const shard = new dirSharded.DirSharded({\n root: true,\n dir: true,\n parent: undefined,\n parentKey: undefined,\n path: '',\n dirty: true,\n flat: false,\n mode: node.mode\n }, options);\n shard._bucket = rootBucket;\n if (node.mtime) {\n shard.mtime = { secs: Math.round(Date.now() / 1000) };\n }\n const position = await rootBucket._findNewBucketAndPos(file.name);\n const path = toBucketPath(position);\n path[0].node = options.parent;\n let index = 0;\n while (index < path.length) {\n const segment = path[index];\n index++;\n const node = segment.node;\n if (!node) {\n throw new Error('Segment had no node');\n }\n const link = node.Links.find(link => (link.Name || '').substring(0, 2) === segment.prefix);\n if (!link) {\n log(`Link ${ segment.prefix }${ file.name } will be added`);\n index = path.length;\n break;\n }\n if (link.Name === `${ segment.prefix }${ file.name }`) {\n log(`Link ${ segment.prefix }${ file.name } will be replaced`);\n index = path.length;\n break;\n }\n if ((link.Name || '').length > 2) {\n log(`Link ${ link.Name } ${ link.Hash } will be replaced with a subshard`);\n index = path.length;\n break;\n }\n log(`Found subshard ${ segment.prefix }`);\n const block = await context.repo.blocks.get(link.Hash);\n const subShard = dagPB__namespace.decode(block);\n if (!path[index]) {\n log(`Loaded new subshard ${ segment.prefix }`);\n await hamtUtils.recreateHamtLevel(subShard.Links, rootBucket, segment.bucket, parseInt(segment.prefix, 16));\n const position = await rootBucket._findNewBucketAndPos(file.name);\n path.push({\n bucket: position.bucket,\n prefix: hamtUtils.toPrefix(position.pos),\n node: subShard\n });\n break;\n }\n const nextSegment = path[index];\n await hamtUtils.addLinksToHamtBucket(subShard.Links, nextSegment.bucket, rootBucket);\n nextSegment.node = subShard;\n }\n await shard._bucket.put(file.name, {\n size: file.size,\n cid: file.cid\n });\n return {\n shard,\n path\n };\n};\nconst toBucketPath = position => {\n const path = [{\n bucket: position.bucket,\n prefix: hamtUtils.toPrefix(position.pos)\n }];\n let bucket = position.bucket._parent;\n let positionInBucket = position.bucket._posAtParent;\n while (bucket) {\n path.push({\n bucket,\n prefix: hamtUtils.toPrefix(positionInBucket)\n });\n positionInBucket = bucket._posAtParent;\n bucket = bucket._parent;\n }\n path.reverse();\n return path;\n};\n\nexports.addLink = addLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar persist = require('./persist.js');\nvar hamtSharding = require('hamt-sharding');\nvar hamtConstants = require('./hamt-constants.js');\n\nclass Dir {\n constructor(props, options) {\n this.options = options || {};\n this.root = props.root;\n this.dir = props.dir;\n this.path = props.path;\n this.dirty = props.dirty;\n this.flat = props.flat;\n this.parent = props.parent;\n this.parentKey = props.parentKey;\n this.unixfs = props.unixfs;\n this.mode = props.mode;\n this.mtime = props.mtime;\n this.cid = undefined;\n this.size = undefined;\n }\n async put(name, value) {\n }\n get(name) {\n return Promise.resolve(this);\n }\n async *eachChildSeries() {\n }\n async *flush(blockstore) {\n }\n}\nclass DirSharded extends Dir {\n constructor(props, options) {\n super(props, options);\n this._bucket = hamtSharding.createHAMT({\n hashFn: hamtConstants.hamtHashFn,\n bits: hamtConstants.hamtBucketBits\n });\n }\n async put(name, value) {\n await this._bucket.put(name, value);\n }\n get(name) {\n return this._bucket.get(name);\n }\n childCount() {\n return this._bucket.leafCount();\n }\n directChildrenCount() {\n return this._bucket.childrenCount();\n }\n onlyChild() {\n return this._bucket.onlyChild();\n }\n async *eachChildSeries() {\n for await (const {key, value} of this._bucket.eachLeafSeries()) {\n yield {\n key,\n child: value\n };\n }\n }\n async *flush(blockstore) {\n yield* flush(this._bucket, blockstore, this, this.options);\n }\n}\nasync function* flush(bucket, blockstore, shardRoot, options) {\n const children = bucket._children;\n const links = [];\n let childrenSize = 0;\n for (let i = 0; i < children.length; i++) {\n const child = children.get(i);\n if (!child) {\n continue;\n }\n const labelPrefix = i.toString(16).toUpperCase().padStart(2, '0');\n if (child instanceof hamtSharding.Bucket) {\n let shard;\n for await (const subShard of await flush(child, blockstore, null, options)) {\n shard = subShard;\n }\n if (!shard) {\n throw new Error('Could not flush sharded directory, no subshard found');\n }\n links.push({\n Name: labelPrefix,\n Tsize: shard.size,\n Hash: shard.cid\n });\n childrenSize += shard.size;\n } else if (typeof child.value.flush === 'function') {\n const dir = child.value;\n let flushedDir;\n for await (const entry of dir.flush(blockstore)) {\n flushedDir = entry;\n yield flushedDir;\n }\n const label = labelPrefix + child.key;\n links.push({\n Name: label,\n Tsize: flushedDir.size,\n Hash: flushedDir.cid\n });\n childrenSize += flushedDir.size;\n } else {\n const value = child.value;\n if (!value.cid) {\n continue;\n }\n const label = labelPrefix + child.key;\n const size = value.size;\n links.push({\n Name: label,\n Tsize: size,\n Hash: value.cid\n });\n childrenSize += size;\n }\n }\n const data = Uint8Array.from(children.bitField().reverse());\n const dir = new ipfsUnixfs.UnixFS({\n type: 'hamt-sharded-directory',\n data,\n fanout: bucket.tableSize(),\n hashType: hamtConstants.hamtHashCode,\n mtime: shardRoot && shardRoot.mtime,\n mode: shardRoot && shardRoot.mode\n });\n const node = {\n Data: dir.marshal(),\n Links: links\n };\n const buffer = dagPB.encode(dagPB.prepare(node));\n const cid = await persist.persist(buffer, blockstore, options);\n const size = buffer.length + childrenSize;\n yield {\n cid,\n node,\n size\n };\n}\n\nexports.Dir = Dir;\nexports.DirSharded = DirSharded;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar dagPB = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nconst persist = async (buffer, blockstore, options) => {\n if (!options.codec) {\n options.codec = dagPB__namespace;\n }\n if (!options.hasher) {\n options.hasher = sha2.sha256;\n }\n if (options.cidVersion === undefined) {\n options.cidVersion = 1;\n }\n if (options.codec === dagPB__namespace && options.hasher !== sha2.sha256) {\n options.cidVersion = 1;\n }\n const multihash = await options.hasher.digest(buffer);\n const cid$1 = cid.CID.create(options.cidVersion, options.codec.code, multihash);\n if (!options.onlyHash) {\n await blockstore.put(cid$1, buffer, { signal: options.signal });\n }\n return cid$1;\n};\n\nexports.persist = persist;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar murmur3 = require('@multiformats/murmur3');\n\nconst hamtHashCode = murmur3.murmur3128.code;\nconst hamtBucketBits = 8;\nasync function hamtHashFn(buf) {\n return (await murmur3.murmur3128.encode(buf)).slice(0, 8).reverse();\n}\n\nexports.hamtBucketBits = hamtBucketBits;\nexports.hamtHashCode = hamtHashCode;\nexports.hamtHashFn = hamtHashFn;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar hamtSharding = require('hamt-sharding');\nvar dirSharded = require('./dir-sharded.js');\nvar debug = require('debug');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar last = require('it-last');\nvar cid = require('multiformats/cid');\nvar hamtConstants = require('./hamt-constants.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst log = debug__default['default']('ipfs:mfs:core:utils:hamt-utils');\nconst updateHamtDirectory = async (context, links, bucket, options) => {\n if (!options.parent.Data) {\n throw new Error('Could not update HAMT directory because parent had no data');\n }\n const data = Uint8Array.from(bucket._children.bitField().reverse());\n const node = ipfsUnixfs.UnixFS.unmarshal(options.parent.Data);\n const dir = new ipfsUnixfs.UnixFS({\n type: 'hamt-sharded-directory',\n data,\n fanout: bucket.tableSize(),\n hashType: hamtConstants.hamtHashCode,\n mode: node.mode,\n mtime: node.mtime\n });\n const hasher = await context.hashers.getHasher(options.hashAlg);\n const parent = {\n Data: dir.marshal(),\n Links: links.sort((a, b) => (a.Name || '').localeCompare(b.Name || ''))\n };\n const buf = dagPB__namespace.encode(parent);\n const hash = await hasher.digest(buf);\n const cid$1 = cid.CID.create(options.cidVersion, dagPB__namespace.code, hash);\n if (options.flush) {\n await context.repo.blocks.put(cid$1, buf);\n }\n return {\n node: parent,\n cid: cid$1,\n size: links.reduce((sum, link) => sum + (link.Tsize || 0), buf.length)\n };\n};\nconst recreateHamtLevel = async (links, rootBucket, parentBucket, positionAtParent) => {\n const bucket = new hamtSharding.Bucket({\n hash: rootBucket._options.hash,\n bits: rootBucket._options.bits\n }, parentBucket, positionAtParent);\n parentBucket._putObjectAt(positionAtParent, bucket);\n await addLinksToHamtBucket(links, bucket, rootBucket);\n return bucket;\n};\nconst recreateInitialHamtLevel = async links => {\n const bucket = hamtSharding.createHAMT({\n hashFn: hamtConstants.hamtHashFn,\n bits: hamtConstants.hamtBucketBits\n });\n await addLinksToHamtBucket(links, bucket, bucket);\n return bucket;\n};\nconst addLinksToHamtBucket = async (links, bucket, rootBucket) => {\n await Promise.all(links.map(link => {\n const linkName = link.Name || '';\n if (linkName.length === 2) {\n const pos = parseInt(linkName, 16);\n bucket._putObjectAt(pos, new hamtSharding.Bucket({\n hash: rootBucket._options.hash,\n bits: rootBucket._options.bits\n }, bucket, pos));\n return Promise.resolve();\n }\n return rootBucket.put(linkName.substring(2), {\n size: link.Tsize,\n cid: link.Hash\n });\n }));\n};\nconst toPrefix = position => {\n return position.toString(16).toUpperCase().padStart(2, '0').substring(0, 2);\n};\nconst generatePath = async (context, fileName, rootNode) => {\n const rootBucket = await recreateInitialHamtLevel(rootNode.Links);\n const position = await rootBucket._findNewBucketAndPos(fileName);\n const path = [{\n bucket: position.bucket,\n prefix: toPrefix(position.pos)\n }];\n let currentBucket = position.bucket;\n while (currentBucket !== rootBucket) {\n path.push({\n bucket: currentBucket,\n prefix: toPrefix(currentBucket._posAtParent)\n });\n currentBucket = currentBucket._parent;\n }\n path.reverse();\n path[0].node = rootNode;\n for (let i = 0; i < path.length; i++) {\n const segment = path[i];\n if (!segment.node) {\n throw new Error('Could not generate HAMT path');\n }\n const link = segment.node.Links.filter(link => (link.Name || '').substring(0, 2) === segment.prefix).pop();\n if (!link) {\n log(`Link ${ segment.prefix }${ fileName } will be added`);\n continue;\n }\n if (link.Name === `${ segment.prefix }${ fileName }`) {\n log(`Link ${ segment.prefix }${ fileName } will be replaced`);\n continue;\n }\n log(`Found subshard ${ segment.prefix }`);\n const block = await context.repo.blocks.get(link.Hash);\n const node = dagPB__namespace.decode(block);\n if (!path[i + 1]) {\n log(`Loaded new subshard ${ segment.prefix }`);\n await recreateHamtLevel(node.Links, rootBucket, segment.bucket, parseInt(segment.prefix, 16));\n const position = await rootBucket._findNewBucketAndPos(fileName);\n path.push({\n bucket: position.bucket,\n prefix: toPrefix(position.pos),\n node: node\n });\n continue;\n }\n const nextSegment = path[i + 1];\n await addLinksToHamtBucket(node.Links, nextSegment.bucket, rootBucket);\n nextSegment.node = node;\n }\n await rootBucket.put(fileName, true);\n path.reverse();\n return {\n rootBucket,\n path\n };\n};\nconst createShard = async (context, contents, options = {}) => {\n const shard = new dirSharded.DirSharded({\n root: true,\n dir: true,\n parent: undefined,\n parentKey: undefined,\n path: '',\n dirty: true,\n flat: false,\n mtime: options.mtime,\n mode: options.mode\n }, options);\n for (let i = 0; i < contents.length; i++) {\n await shard._bucket.put(contents[i].name, {\n size: contents[i].size,\n cid: contents[i].cid\n });\n }\n const res = await last__default['default'](shard.flush(context.repo.blocks));\n if (!res) {\n throw new Error('Flushing shard yielded no result');\n }\n return res;\n};\n\nexports.addLinksToHamtBucket = addLinksToHamtBucket;\nexports.createShard = createShard;\nexports.generatePath = generatePath;\nexports.recreateHamtLevel = recreateHamtLevel;\nexports.recreateInitialHamtLevel = recreateInitialHamtLevel;\nexports.toPrefix = toPrefix;\nexports.updateHamtDirectory = updateHamtDirectory;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar addLink = require('./add-link.js');\nvar dagPB = require('@ipld/dag-pb');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:mfs:utils:update-tree');\nconst defaultOptions = { shardSplitThreshold: 1000 };\nasync function updateTree(context, trail, options) {\n options = Object.assign({}, defaultOptions, options);\n log('Trail', trail);\n trail = trail.slice().reverse();\n let index = 0;\n let child;\n for await (const block of context.repo.blocks.getMany(trail.map(node => node.cid))) {\n const node = dagPB.decode(block);\n const cid = trail[index].cid;\n const name = trail[index].name;\n index++;\n if (!child) {\n child = {\n cid,\n name,\n size: block.length\n };\n continue;\n }\n const result = await addLink.addLink(context, {\n parent: node,\n name: child.name,\n cid: child.cid,\n size: child.size,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion\n });\n child = {\n cid: result.cid,\n name,\n size: result.size\n };\n }\n const {cid} = child;\n log(`Final CID ${ cid }`);\n return cid;\n}\n\nexports.updateTree = updateTree;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar utils = require('../../../utils.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst log = debug__default['default']('ipfs:mfs:utils:update-mfs-root');\nasync function updateMfsRoot(context, cid, options) {\n if (options && options.signal && options.signal.aborted) {\n throw errCode__default['default'](new Error('Request aborted'), 'ERR_ABORTED', { name: 'Aborted' });\n }\n log(`New MFS root will be ${ cid }`);\n await context.repo.datastore.put(utils.MFS_ROOT_KEY, cid.bytes);\n return cid;\n}\n\nexports.updateMfsRoot = updateMfsRoot;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mkdir = require('./mkdir.js');\nvar stat = require('./stat.js');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar addLink = require('./utils/add-link.js');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar mergeOpts = require('merge-options');\nvar toTrail = require('./utils/to-trail.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:cp');\nconst defaultOptions = {\n parents: false,\n flush: true,\n hashAlg: 'sha2-256',\n cidVersion: 0,\n shardSplitThreshold: 1000\n};\nfunction createCp(context) {\n async function mfsCp(from, to, opts = {}) {\n const options = mergeOptions(defaultOptions, opts);\n if (!Array.isArray(from)) {\n from = [from];\n }\n const sources = await Promise.all(from.map(path => toMfsPath.toMfsPath(context, path, options)));\n let destination = await toMfsPath.toMfsPath(context, to, options);\n if (!sources.length || !destination) {\n throw errCode__default['default'](new Error('Please supply at least one source'), 'ERR_INVALID_PARAMS');\n }\n const missing = sources.find(source => !source.exists);\n if (missing) {\n throw errCode__default['default'](new Error(`${ missing.path } does not exist`), 'ERR_INVALID_PARAMS');\n }\n const destinationIsDirectory = isDirectory(destination);\n if (destination.exists) {\n log('Destination exists');\n if (sources.length === 1 && !destinationIsDirectory) {\n throw errCode__default['default'](new Error('directory already has entry by that name'), 'ERR_ALREADY_EXISTS');\n }\n } else {\n log('Destination does not exist');\n if (sources.length > 1) {\n if (!options.parents) {\n throw errCode__default['default'](new Error('destination did not exist, pass -p to create intermediate directories'), 'ERR_INVALID_PARAMS');\n }\n await mkdir.createMkdir(context)(destination.path, options);\n destination = await toMfsPath.toMfsPath(context, destination.path, options);\n } else if (destination.parts.length > 1) {\n const parentFolder = `/${ destination.parts.slice(0, -1).join('/') }`;\n try {\n await stat.createStat(context)(parentFolder, options);\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n if (!options.parents) {\n throw errCode__default['default'](new Error('destination did not exist, pass -p to create intermediate directories'), 'ERR_INVALID_PARAMS');\n }\n await mkdir.createMkdir(context)(parentFolder, options);\n destination = await toMfsPath.toMfsPath(context, destination.path, options);\n }\n }\n }\n const destinationPath = isDirectory(destination) ? destination.mfsPath : destination.mfsDirectory;\n const trail = await toTrail.toTrail(context, destinationPath);\n if (sources.length === 1) {\n const source = sources.pop();\n if (!source) {\n throw errCode__default['default'](new Error('could not find source'), 'ERR_INVALID_PARAMS');\n }\n const destinationName = destinationIsDirectory ? source.name : destination.name;\n log(`Only one source, copying to destination ${ destinationIsDirectory ? 'directory' : 'file' } ${ destinationName }`);\n return copyToFile(context, source, destinationName, trail, options);\n }\n log('Multiple sources, wrapping in a directory');\n return copyToDirectory(context, sources, destination, trail, options);\n }\n return withTimeoutOption.withTimeoutOption(mfsCp);\n}\nconst isDirectory = destination => {\n return destination.unixfs && destination.unixfs.type && destination.unixfs.type.includes('directory');\n};\nconst copyToFile = async (context, source, destination, destinationTrail, options) => {\n let parent = destinationTrail.pop();\n if (!parent) {\n throw errCode__default['default'](new Error('destination had no parent'), 'ERR_INVALID_PARAMS');\n }\n parent = await addSourceToParent(context, source, destination, parent, options);\n destinationTrail.push(parent);\n const newRootCid = await updateTree.updateTree(context, destinationTrail, options);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, options);\n};\nconst copyToDirectory = async (context, sources, destination, destinationTrail, options) => {\n for (let i = 0; i < sources.length; i++) {\n const source = sources[i];\n destination = await addSourceToParent(context, source, source.name, destination, options);\n }\n destinationTrail[destinationTrail.length - 1] = destination;\n const newRootCid = await updateTree.updateTree(context, destinationTrail, options);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, options);\n};\nconst addSourceToParent = async (context, source, childName, parent, options) => {\n const sourceBlock = await context.repo.blocks.get(source.cid);\n const {node, cid, size} = await addLink.addLink(context, {\n parentCid: parent.cid,\n size: sourceBlock.length,\n cid: source.cid,\n name: childName,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold\n });\n parent.node = node;\n parent.cid = cid;\n parent.size = size;\n return parent;\n};\n\nexports.createCp = createCp;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar createNode = require('./utils/create-node.js');\nvar toPathComponents = require('./utils/to-path-components.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar updateTree = require('./utils/update-tree.js');\nvar addLink = require('./utils/add-link.js');\nvar withMfsRoot = require('./utils/with-mfs-root.js');\nvar mergeOpts = require('merge-options');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:mkdir');\nconst defaultOptions = {\n parents: false,\n hashAlg: 'sha2-256',\n cidVersion: 0,\n shardSplitThreshold: 1000,\n flush: true\n};\nfunction createMkdir(context) {\n async function mfsMkdir(path, options = {}) {\n const opts = mergeOptions(defaultOptions, options);\n if (!path) {\n throw new Error('no path given to Mkdir');\n }\n path = path.trim();\n if (path === '/') {\n if (opts.parents) {\n return;\n }\n throw errCode__default['default'](new Error('cannot create directory \\'/\\': Already exists'), 'ERR_INVALID_PATH');\n }\n if (path.substring(0, 1) !== '/') {\n throw errCode__default['default'](new Error('paths must start with a leading slash'), 'ERR_INVALID_PATH');\n }\n log(`Creating ${ path }`);\n const pathComponents = toPathComponents.toPathComponents(path);\n if (pathComponents[0] === 'ipfs') {\n throw errCode__default['default'](new Error('path cannot have the prefix \\'ipfs\\''), 'ERR_INVALID_PATH');\n }\n const root = await withMfsRoot.loadMfsRoot(context, opts);\n let parent;\n const trail = [];\n const emptyDir = await createNode.createNode(context, 'directory', opts);\n for (let i = 0; i <= pathComponents.length; i++) {\n const subPathComponents = pathComponents.slice(0, i);\n const subPath = `/ipfs/${ root }/${ subPathComponents.join('/') }`;\n try {\n parent = await ipfsUnixfsExporter.exporter(subPath, context.repo.blocks);\n if (parent.type !== 'file' && parent.type !== 'directory') {\n throw errCode__default['default'](new Error(`${ path } was not a UnixFS node`), 'ERR_NOT_UNIXFS');\n }\n if (i === pathComponents.length) {\n if (opts.parents) {\n return;\n }\n throw errCode__default['default'](new Error('file already exists'), 'ERR_ALREADY_EXISTS');\n }\n trail.push({\n name: parent.name,\n cid: parent.cid\n });\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n if (i < pathComponents.length && !opts.parents) {\n throw errCode__default['default'](new Error(`Intermediate directory path ${ subPath } does not exist, use the -p flag to create it`), 'ERR_NOT_FOUND');\n }\n await addEmptyDir(context, subPathComponents[subPathComponents.length - 1], emptyDir, trail[trail.length - 1], trail, opts);\n } else {\n throw err;\n }\n }\n }\n const newRootCid = await updateTree.updateTree(context, trail, opts);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, opts);\n }\n return withTimeoutOption.withTimeoutOption(mfsMkdir);\n}\nconst addEmptyDir = async (context, childName, emptyDir, parent, trail, options) => {\n log(`Adding empty dir called ${ childName } to ${ parent.cid }`);\n const result = await addLink.addLink(context, {\n parent: parent.node,\n parentCid: parent.cid,\n size: 0,\n cid: emptyDir.cid,\n name: childName,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold\n });\n trail[trail.length - 1].cid = result.cid;\n trail.push({\n name: childName,\n cid: emptyDir.cid\n });\n};\n\nexports.createMkdir = createMkdir;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nasync function createNode(context, type, options) {\n const metadata = new ipfsUnixfs.UnixFS({\n type,\n mode: options.mode,\n mtime: options.mtime\n });\n const hasher = await context.hashers.getHasher(options.hashAlg);\n const node = {\n Data: metadata.marshal(),\n Links: []\n };\n const buf = dagPB__namespace.encode(node);\n const hash = await hasher.digest(buf);\n const cid$1 = cid.CID.create(options.cidVersion, dagPB__namespace.code, hash);\n if (options.flush) {\n await context.repo.blocks.put(cid$1, buf);\n }\n return {\n cid: cid$1,\n node\n };\n}\n\nexports.createNode = createNode;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar removeLink = require('./utils/remove-link.js');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar toTrail = require('./utils/to-trail.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar mergeOpts = require('merge-options');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst defaultOptions = {\n recursive: false,\n cidVersion: 0,\n hashAlg: 'sha2-256',\n flush: true,\n shardSplitThreshold: 1000\n};\nfunction createRm(context) {\n async function mfsRm(paths, opts = {}) {\n const options = mergeOptions(defaultOptions, opts);\n if (!Array.isArray(paths)) {\n paths = [paths];\n }\n const sources = await Promise.all(paths.map(path => toMfsPath.toMfsPath(context, path, options)));\n if (!sources.length) {\n throw errCode__default['default'](new Error('Please supply at least one path to remove'), 'ERR_INVALID_PARAMS');\n }\n sources.forEach(source => {\n if (source.path === '/') {\n throw errCode__default['default'](new Error('Cannot delete root'), 'ERR_INVALID_PARAMS');\n }\n });\n for (const source of sources) {\n await removePath(context, source.path, options);\n }\n }\n return withTimeoutOption.withTimeoutOption(mfsRm);\n}\nconst removePath = async (context, path, options) => {\n const mfsPath = await toMfsPath.toMfsPath(context, path, options);\n const trail = await toTrail.toTrail(context, mfsPath.mfsPath);\n const child = trail[trail.length - 1];\n trail.pop();\n const parent = trail[trail.length - 1];\n if (!parent) {\n throw errCode__default['default'](new Error(`${ path } does not exist`), 'ERR_NOT_FOUND');\n }\n if (child.type === 'directory' && !options.recursive) {\n throw errCode__default['default'](new Error(`${ path } is a directory, use -r to remove directories`), 'ERR_WAS_DIR');\n }\n const {cid} = await removeLink.removeLink(context, {\n parentCid: parent.cid,\n name: child.name,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold\n });\n parent.cid = cid;\n const newRootCid = await updateTree.updateTree(context, trail, options);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, options);\n};\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar debug = require('debug');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar hamtUtils = require('./hamt-utils.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst log = debug__default['default']('ipfs:mfs:core:utils:remove-link');\nasync function removeLink(context, options) {\n let parent = options.parent;\n if (options.parentCid) {\n const parentCid = cid.CID.asCID(options.parentCid);\n if (parentCid === null) {\n throw errCode__default['default'](new Error('Invalid CID passed to removeLink'), 'EINVALIDPARENTCID');\n }\n log(`Loading parent node ${ parentCid }`);\n const block = await context.repo.blocks.get(parentCid);\n parent = dagPB__namespace.decode(block);\n }\n if (!parent) {\n throw errCode__default['default'](new Error('No parent node or CID passed to removeLink'), 'EINVALIDPARENT');\n }\n if (!options.name) {\n throw errCode__default['default'](new Error('No child name passed to removeLink'), 'EINVALIDCHILDNAME');\n }\n if (!parent.Data) {\n throw errCode__default['default'](new Error('Parent node had no data'), 'ERR_INVALID_NODE');\n }\n const meta = ipfsUnixfs.UnixFS.unmarshal(parent.Data);\n if (meta.type === 'hamt-sharded-directory') {\n log(`Removing ${ options.name } from sharded directory`);\n return removeFromShardedDirectory(context, {\n ...options,\n parent\n });\n }\n log(`Removing link ${ options.name } regular directory`);\n return removeFromDirectory(context, {\n ...options,\n parent\n });\n}\nconst removeFromDirectory = async (context, options) => {\n options.parent.Links = options.parent.Links.filter(link => {\n return link.Name !== options.name;\n });\n const parentBlock = await dagPB__namespace.encode(options.parent);\n const hasher = await context.hashers.getHasher(options.hashAlg);\n const hash = await hasher.digest(parentBlock);\n const parentCid = cid.CID.create(options.cidVersion, dagPB__namespace.code, hash);\n await context.repo.blocks.put(parentCid, parentBlock);\n log(`Updated regular directory ${ parentCid }`);\n return {\n node: options.parent,\n cid: parentCid\n };\n};\nconst removeFromShardedDirectory = async (context, options) => {\n const {rootBucket, path} = await hamtUtils.generatePath(context, options.name, options.parent);\n await rootBucket.del(options.name);\n const {node} = await updateShard(context, path, options.name, options);\n return hamtUtils.updateHamtDirectory(context, node.Links, rootBucket, options);\n};\nconst updateShard = async (context, positions, name, options) => {\n const last = positions.pop();\n if (!last) {\n throw errCode__default['default'](new Error('Could not find parent'), 'EINVALIDPARENT');\n }\n const {bucket, prefix, node} = last;\n if (!node) {\n throw errCode__default['default'](new Error('Could not find parent'), 'EINVALIDPARENT');\n }\n const link = node.Links.find(link => (link.Name || '').substring(0, 2) === prefix);\n if (!link) {\n throw errCode__default['default'](new Error(`No link found with prefix ${ prefix } for file ${ name }`), 'ERR_NOT_FOUND');\n }\n if (link.Name === `${ prefix }${ name }`) {\n log(`Removing existing link ${ link.Name }`);\n const links = node.Links.filter(nodeLink => {\n return nodeLink.Name !== link.Name;\n });\n await bucket.del(name);\n return hamtUtils.updateHamtDirectory(context, links, bucket, options);\n }\n log(`Descending into sub-shard ${ link.Name } for ${ prefix }${ name }`);\n const result = await updateShard(context, positions, name, options);\n let cid = result.cid;\n let size = result.size;\n let newName = prefix;\n if (result.node.Links.length === 1) {\n log(`Removing subshard for ${ prefix }`);\n const link = result.node.Links[0];\n newName = `${ prefix }${ (link.Name || '').substring(2) }`;\n cid = link.Hash;\n size = link.Tsize || 0;\n }\n log(`Updating shard ${ prefix } with name ${ newName }`);\n return updateShardParent(context, bucket, node, prefix, newName, size, cid, options);\n};\nconst updateShardParent = (context, bucket, parent, oldName, newName, size, cid, options) => {\n const parentLinks = parent.Links.filter(link => {\n return link.Name !== oldName;\n });\n parentLinks.push({\n Name: newName,\n Tsize: size,\n Hash: cid\n });\n return hamtUtils.updateHamtDirectory(context, parentLinks, bucket, options);\n};\n\nexports.removeLink = removeLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar stat = require('./stat.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar mergeOpts = require('merge-options');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst defaultOptions = {};\nfunction createFlush(context) {\n async function mfsFlush(path, options = {}) {\n options = mergeOptions(defaultOptions, options);\n const {cid} = await stat.createStat(context)(path, options);\n return cid;\n }\n return withTimeoutOption.withTimeoutOption(mfsFlush);\n}\n\nexports.createFlush = createFlush;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cp = require('./cp.js');\nvar rm = require('./rm.js');\nvar mergeOpts = require('merge-options');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst defaultOptions = {\n parents: false,\n flush: true,\n cidVersion: 0,\n hashAlg: 'sha2-256',\n shardSplitThreshold: 1000\n};\nfunction createMv(context) {\n async function mfsMv(from, to, options = {}) {\n const opts = mergeOptions(defaultOptions, options);\n await cp.createCp(context)(from, to, opts);\n await rm.createRm(context)(from, {\n ...opts,\n recursive: true\n });\n }\n return withTimeoutOption.withTimeoutOption(mfsMv);\n}\n\nexports.createMv = createMv;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mergeOpts = require('merge-options');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar toTrail = require('./utils/to-trail.js');\nvar addLink = require('./utils/add-link.js');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:touch');\nconst defaultOptions = {\n flush: true,\n shardSplitThreshold: 1000,\n cidVersion: 0,\n hashAlg: 'sha2-256'\n};\nfunction createTouch(context) {\n async function mfsTouch(path, options = {}) {\n const settings = mergeOptions(defaultOptions, options);\n settings.mtime = settings.mtime || new Date();\n log(`Touching ${ path } mtime: ${ settings.mtime }`);\n const {cid: cid$1, mfsDirectory, name, exists} = await toMfsPath.toMfsPath(context, path, settings);\n const hashAlg = options.hashAlg || defaultOptions.hashAlg;\n const hasher = await context.hashers.getHasher(hashAlg);\n let updatedBlock;\n let updatedCid;\n let cidVersion = settings.cidVersion;\n if (!exists) {\n const metadata = new ipfsUnixfs.UnixFS({\n type: 'file',\n mtime: settings.mtime\n });\n updatedBlock = dagPB__namespace.encode({\n Data: metadata.marshal(),\n Links: []\n });\n const hash = await hasher.digest(updatedBlock);\n updatedCid = cid.CID.create(settings.cidVersion, dagPB__namespace.code, hash);\n if (settings.flush) {\n await context.repo.blocks.put(updatedCid, updatedBlock);\n }\n } else {\n if (cid$1.code !== dagPB__namespace.code) {\n throw errCode__default['default'](new Error(`${ path } was not a UnixFS node`), 'ERR_NOT_UNIXFS');\n }\n cidVersion = cid$1.version;\n const block = await context.repo.blocks.get(cid$1);\n const node = dagPB__namespace.decode(block);\n if (!node.Data) {\n throw errCode__default['default'](new Error(`${ path } had no data`), 'ERR_INVALID_NODE');\n }\n const metadata = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n metadata.mtime = settings.mtime;\n updatedBlock = dagPB__namespace.encode({\n Data: metadata.marshal(),\n Links: node.Links\n });\n const hash = await hasher.digest(updatedBlock);\n updatedCid = cid.CID.create(settings.cidVersion, dagPB__namespace.code, hash);\n if (settings.flush) {\n await context.repo.blocks.put(updatedCid, updatedBlock);\n }\n }\n const trail = await toTrail.toTrail(context, mfsDirectory);\n const parent = trail[trail.length - 1];\n const parentCid = parent.cid;\n const parentBlock = await context.repo.blocks.get(parentCid);\n const parentNode = dagPB__namespace.decode(parentBlock);\n const result = await addLink.addLink(context, {\n parent: parentNode,\n name: name,\n cid: updatedCid,\n size: updatedBlock.length,\n flush: settings.flush,\n shardSplitThreshold: settings.shardSplitThreshold,\n hashAlg: settings.hashAlg,\n cidVersion\n });\n parent.cid = result.cid;\n const newRootCid = await updateTree.updateTree(context, trail, settings);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, settings);\n }\n return withTimeoutOption.withTimeoutOption(mfsTouch);\n}\n\nexports.createTouch = createTouch;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar mergeOpts = require('merge-options');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar errCode = require('err-code');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst defaultOptions = {\n offset: 0,\n length: Infinity\n};\nfunction createRead(context) {\n function mfsRead(path, options = {}) {\n options = mergeOptions(defaultOptions, options);\n return {\n [Symbol.asyncIterator]: async function* read() {\n const mfsPath = await toMfsPath.toMfsPath(context, path, options);\n const result = await ipfsUnixfsExporter.exporter(mfsPath.mfsPath, context.repo.blocks);\n if (result.type !== 'file') {\n throw errCode__default['default'](new Error(`${ path } was not a file`), 'ERR_NOT_FILE');\n }\n if (!result.content) {\n throw errCode__default['default'](new Error(`Could not load content stream from ${ path }`), 'ERR_NO_CONTENT');\n }\n for await (const buf of result.content({\n offset: options.offset,\n length: options.length\n })) {\n yield buf;\n }\n }\n };\n }\n return withTimeoutOption.withTimeoutOption(mfsRead);\n}\n\nexports.createRead = createRead;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar ipfsUnixfsImporter = require('ipfs-unixfs-importer');\nvar dagPB = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\nvar stat = require('./stat.js');\nvar mkdir = require('./mkdir.js');\nvar addLink = require('./utils/add-link.js');\nvar mergeOpts = require('merge-options');\nvar createLock = require('./utils/create-lock.js');\nvar toAsyncIterator = require('./utils/to-async-iterator.js');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar toPathComponents = require('./utils/to-path-components.js');\nvar toTrail = require('./utils/to-trail.js');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar errCode = require('err-code');\nvar utils = require('../../utils.js');\nvar last = require('it-last');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar ipfsUnixfs = require('ipfs-unixfs');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:write');\nconst defaultOptions = {\n offset: 0,\n length: Infinity,\n create: false,\n truncate: false,\n rawLeaves: false,\n reduceSingleLeafToSelf: false,\n cidVersion: 0,\n hashAlg: 'sha2-256',\n parents: false,\n progress: (bytes, path) => {\n },\n strategy: 'trickle',\n flush: true,\n leafType: 'raw',\n shardSplitThreshold: 1000\n};\nfunction createWrite(context) {\n async function mfsWrite(path, content, opts = {}) {\n const options = mergeOptions(defaultOptions, opts);\n let source;\n let destination;\n let parent;\n log('Reading source, destination and parent');\n await createLock.createLock().readLock(async () => {\n source = await toAsyncIterator.toAsyncIterator(content);\n destination = await toMfsPath.toMfsPath(context, path, options);\n parent = await toMfsPath.toMfsPath(context, destination.mfsDirectory, options);\n })();\n log('Read source, destination and parent');\n if (!options.parents && !parent.exists) {\n throw errCode__default['default'](new Error('directory does not exist'), 'ERR_NO_EXIST');\n }\n if (source == null) {\n throw errCode__default['default'](new Error('could not create source'), 'ERR_NO_SOURCE');\n }\n if (destination == null) {\n throw errCode__default['default'](new Error('could not create destination'), 'ERR_NO_DESTINATION');\n }\n if (!options.create && !destination.exists) {\n throw errCode__default['default'](new Error('file does not exist'), 'ERR_NO_EXIST');\n }\n if (destination.entryType !== 'file') {\n throw errCode__default['default'](new Error('not a file'), 'ERR_NOT_A_FILE');\n }\n return updateOrImport(context, path, source, destination, options);\n }\n return withTimeoutOption.withTimeoutOption(mfsWrite);\n}\nconst updateOrImport = async (context, path, source, destination, options) => {\n const child = await write(context, source, destination, options);\n await createLock.createLock().writeLock(async () => {\n const pathComponents = toPathComponents.toPathComponents(path);\n const fileName = pathComponents.pop();\n if (fileName == null) {\n throw errCode__default['default'](new Error('source does not exist'), 'ERR_NO_EXIST');\n }\n let parentExists = false;\n try {\n await stat.createStat(context)(`/${ pathComponents.join('/') }`, options);\n parentExists = true;\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n }\n if (!parentExists) {\n await mkdir.createMkdir(context)(`/${ pathComponents.join('/') }`, options);\n }\n const updatedPath = await toMfsPath.toMfsPath(context, path, options);\n const trail = await toTrail.toTrail(context, updatedPath.mfsDirectory);\n const parent = trail[trail.length - 1];\n if (!parent) {\n throw errCode__default['default'](new Error('directory does not exist'), 'ERR_NO_EXIST');\n }\n if (!parent.type || !parent.type.includes('directory')) {\n throw errCode__default['default'](new Error(`cannot write to ${ parent.name }: Not a directory`), 'ERR_NOT_A_DIRECTORY');\n }\n const parentBlock = await context.repo.blocks.get(parent.cid);\n const parentNode = dagPB.decode(parentBlock);\n const result = await addLink.addLink(context, {\n parent: parentNode,\n name: fileName,\n cid: child.cid,\n size: child.size,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion\n });\n parent.cid = result.cid;\n const newRootCid = await updateTree.updateTree(context, trail, options);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, options);\n })();\n};\nconst write = async (context, source, destination, options) => {\n if (destination.exists) {\n log(`Overwriting file ${ destination.cid } offset ${ options.offset } length ${ options.length }`);\n } else {\n log(`Writing file offset ${ options.offset } length ${ options.length }`);\n }\n const sources = [];\n if (options.offset > 0) {\n if (destination.unixfs) {\n log(`Writing first ${ options.offset } bytes of original file`);\n sources.push(() => {\n return destination.content({\n offset: 0,\n length: options.offset\n });\n });\n if (destination.unixfs.fileSize() < options.offset) {\n const extra = options.offset - destination.unixfs.fileSize();\n log(`Writing zeros for extra ${ extra } bytes`);\n sources.push(asyncZeroes(extra));\n }\n } else {\n log(`Writing zeros for first ${ options.offset } bytes`);\n sources.push(asyncZeroes(options.offset));\n }\n }\n sources.push(limitAsyncStreamBytes(source, options.length));\n const content = countBytesStreamed(catAsyncIterators(sources), bytesWritten => {\n if (destination.unixfs && !options.truncate) {\n const fileSize = destination.unixfs.fileSize();\n if (fileSize > bytesWritten) {\n log(`Writing last ${ fileSize - bytesWritten } of ${ fileSize } bytes from original file starting at offset ${ bytesWritten }`);\n return destination.content({ offset: bytesWritten });\n } else {\n log('Not writing last bytes from original file');\n }\n }\n return {\n [Symbol.asyncIterator]: async function* () {\n }\n };\n });\n let mode;\n if (options.mode !== undefined && options.mode !== null) {\n mode = ipfsUnixfs.parseMode(options.mode);\n } else if (destination && destination.unixfs) {\n mode = destination.unixfs.mode;\n }\n let mtime;\n if (options.mtime != null) {\n mtime = ipfsUnixfs.parseMtime(options.mtime);\n } else if (destination && destination.unixfs) {\n mtime = destination.unixfs.mtime;\n }\n let hasher;\n switch (options.hashAlg) {\n case 'sha2-256':\n hasher = sha2.sha256;\n break;\n case 'sha2-512':\n hasher = sha2.sha512;\n break;\n default:\n throw new Error(`TODO vmx 2021-03-31: Proper error message for unsupported hash algorithms like ${ options.hashAlg }`);\n }\n const result = await last__default['default'](ipfsUnixfsImporter.importer([{\n content: content,\n mode,\n mtime\n }], context.repo.blocks, {\n progress: options.progress,\n hasher,\n cidVersion: options.cidVersion,\n strategy: options.strategy,\n rawLeaves: options.rawLeaves,\n reduceSingleLeafToSelf: options.reduceSingleLeafToSelf,\n leafType: options.leafType\n }));\n if (!result) {\n throw errCode__default['default'](new Error(`cannot write to ${ parent.name }`), 'ERR_COULD_NOT_WRITE');\n }\n log(`Wrote ${ result.cid }`);\n return {\n cid: result.cid,\n size: result.size\n };\n};\nconst limitAsyncStreamBytes = (stream, limit) => {\n return async function* _limitAsyncStreamBytes() {\n let emitted = 0;\n for await (const buf of stream) {\n emitted += buf.length;\n if (emitted > limit) {\n yield buf.slice(0, limit - emitted);\n return;\n }\n yield buf;\n }\n };\n};\nconst asyncZeroes = (count, chunkSize = utils.MFS_MAX_CHUNK_SIZE) => {\n const buf = new Uint8Array(chunkSize);\n async function* _asyncZeroes() {\n while (true) {\n yield buf.slice();\n }\n }\n return limitAsyncStreamBytes(_asyncZeroes(), count);\n};\nconst catAsyncIterators = async function* (sources) {\n for (let i = 0; i < sources.length; i++) {\n yield* sources[i]();\n }\n};\nconst countBytesStreamed = async function* (source, notify) {\n let wrote = 0;\n for await (const buf of source) {\n wrote += buf.length;\n yield buf;\n }\n for await (const buf of notify(wrote)) {\n wrote += buf.length;\n yield buf;\n }\n};\n\nexports.createWrite = createWrite;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar utils = require('../../../utils.js');\nvar fromString = require('uint8arrays/from-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:mfs:utils:to-async-iterator');\nfunction toAsyncIterator(content) {\n if (!content) {\n throw errCode__default['default'](new Error('paths must start with a leading slash'), 'ERR_INVALID_PATH');\n }\n if (typeof content === 'string' || content instanceof String) {\n log('Content was a string');\n content = fromString.fromString(content.toString());\n }\n if (content.length) {\n log('Content was array-like');\n return {\n [Symbol.asyncIterator]: function* bufferContent() {\n yield content;\n }\n };\n }\n if (content[Symbol.asyncIterator]) {\n log('Content was an async iterator');\n return content;\n }\n if (content[Symbol.iterator]) {\n log('Content was an iterator');\n return content;\n }\n if (global.Blob && content instanceof global.Blob) {\n log('Content was an HTML5 Blob');\n let index = 0;\n const iterator = {\n next: () => {\n if (index > content.size) {\n return { done: true };\n }\n return new Promise((resolve, reject) => {\n const chunk = content.slice(index, utils.MFS_MAX_CHUNK_SIZE);\n index += utils.MFS_MAX_CHUNK_SIZE;\n const reader = new global.FileReader();\n const handleLoad = ev => {\n reader.removeEventListener('loadend', handleLoad, false);\n if (ev.error) {\n return reject(ev.error);\n }\n resolve({\n done: false,\n value: new Uint8Array(reader.result)\n });\n };\n reader.addEventListener('loadend', handleLoad);\n reader.readAsArrayBuffer(chunk);\n });\n }\n };\n return {\n [Symbol.asyncIterator]: () => {\n return iterator;\n }\n };\n }\n throw errCode__default['default'](new Error(`Don't know how to convert ${ content } into an async iterator`), 'ERR_INVALID_PARAMS');\n}\n\nexports.toAsyncIterator = toAsyncIterator;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar map = require('it-map');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\n\nconst toOutput = fsEntry => {\n const output = {\n cid: fsEntry.cid,\n name: fsEntry.name,\n type: fsEntry.type === 'directory' ? 'directory' : 'file',\n size: fsEntry.size\n };\n if (fsEntry.type === 'file' || fsEntry.type === 'directory') {\n output.mode = fsEntry.unixfs.mode;\n output.mtime = fsEntry.unixfs.mtime;\n }\n return output;\n};\nfunction createLs(context) {\n async function* mfsLs(path, options = {}) {\n const mfsPath = await toMfsPath.toMfsPath(context, path, options);\n const fsEntry = await ipfsUnixfsExporter.exporter(mfsPath.mfsPath, context.repo.blocks);\n if (fsEntry.type === 'directory') {\n yield* map__default['default'](fsEntry.content(options), toOutput);\n return;\n }\n yield toOutput(fsEntry);\n }\n return withTimeoutOption.withTimeoutOption(mfsLs);\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _export = require('./export.js');\nvar gen = require('./gen.js');\nvar _import = require('./import.js');\nvar info = require('./info.js');\nvar list = require('./list.js');\nvar rename = require('./rename.js');\nvar rm = require('./rm.js');\n\nclass KeyAPI {\n constructor({keychain}) {\n this.gen = gen.createGen({ keychain });\n this.list = list.createList({ keychain });\n this.rm = rm.createRm({ keychain });\n this.rename = rename.createRename({ keychain });\n this.export = _export.createExport({ keychain });\n this.import = _import.createImport({ keychain });\n this.info = info.createInfo({ keychain });\n }\n}\n\nexports.KeyAPI = KeyAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createExport({keychain}) {\n const exportKey = (name, password) => keychain.exportKey(name, password);\n return withTimeoutOption.withTimeoutOption(exportKey);\n}\n\nexports.createExport = createExport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nconst DEFAULT_KEY_TYPE = 'ed25519';\nconst DEFAULT_KEY_SIZE = 2048;\nfunction createGen({keychain}) {\n const gen = (name, options = {\n type: DEFAULT_KEY_TYPE,\n size: DEFAULT_KEY_SIZE\n }) => {\n return keychain.createKey(name, options.type || DEFAULT_KEY_TYPE, options.size || DEFAULT_KEY_SIZE);\n };\n return withTimeoutOption.withTimeoutOption(gen);\n}\n\nexports.createGen = createGen;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createImport({keychain}) {\n const importKey = (name, pem, password) => {\n return keychain.importKey(name, pem, password);\n };\n return withTimeoutOption.withTimeoutOption(importKey);\n}\n\nexports.createImport = createImport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createInfo({keychain}) {\n const info = name => keychain.findKeyByName(name);\n return withTimeoutOption.withTimeoutOption(info);\n}\n\nexports.createInfo = createInfo;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createList({keychain}) {\n const list = () => keychain.listKeys();\n return withTimeoutOption.withTimeoutOption(list);\n}\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createRename({keychain}) {\n const rename = async (oldName, newName) => {\n const key = await keychain.renameKey(oldName, newName);\n return {\n was: oldName,\n now: key.name,\n id: key.id,\n overwrite: false\n };\n };\n return withTimeoutOption.withTimeoutOption(rename);\n}\n\nexports.createRename = createRename;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createRm({keychain}) {\n const rm = name => keychain.removeKey(name);\n return withTimeoutOption.withTimeoutOption(rm);\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar data = require('./data.js');\nvar get = require('./get.js');\nvar links = require('./links.js');\nvar _new = require('./new.js');\nvar put = require('./put.js');\nvar stat = require('./stat.js');\nvar index = require('./patch/index.js');\n\nclass ObjectAPI {\n constructor({repo, codecs, preload}) {\n this.data = data.createData({\n repo,\n preload\n });\n this.get = get.createGet({\n repo,\n preload\n });\n this.links = links.createLinks({\n repo,\n codecs\n });\n this.new = _new.createNew({\n repo,\n preload\n });\n this.put = put.createPut({\n repo,\n preload\n });\n this.stat = stat.createStat({\n repo,\n preload\n });\n this.patch = new index.ObjectPatchAPI({\n repo,\n preload\n });\n }\n}\n\nexports.ObjectAPI = ObjectAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('./get.js');\n\nfunction createData({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n async function data(multihash, options = {}) {\n const node = await get$1(multihash, options);\n return node.Data || new Uint8Array(0);\n }\n return withTimeoutOption.withTimeoutOption(data);\n}\n\nexports.createData = createData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nfunction createGet({repo, preload}) {\n async function get(cid, options = {}) {\n if (options.preload !== false) {\n preload(cid);\n }\n const block = await repo.blocks.get(cid, options);\n return dagPB__namespace.decode(block);\n }\n return withTimeoutOption.withTimeoutOption(get);\n}\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar dagCBOR = require('@ipld/dag-cbor');\nvar raw = require('multiformats/codecs/raw');\nvar cid = require('multiformats/cid');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar dagCBOR__namespace = /*#__PURE__*/_interopNamespace(dagCBOR);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\n\nfunction findLinks(node, links = []) {\n for (const key in node) {\n const val = node[key];\n if (key === '/' && Object.keys(node).length === 1) {\n try {\n links.push({\n Name: '',\n Tsize: 0,\n Hash: cid.CID.parse(val)\n });\n continue;\n } catch (_) {\n }\n }\n const cid$1 = cid.CID.asCID(val);\n if (cid$1) {\n links.push({\n Name: '',\n Tsize: 0,\n Hash: cid$1\n });\n continue;\n }\n if (Array.isArray(val)) {\n findLinks(val, links);\n }\n if (val && typeof val === 'object') {\n findLinks(val, links);\n }\n }\n return links;\n}\nfunction createLinks({repo, codecs}) {\n async function links(cid, options = {}) {\n const codec = await codecs.getCodec(cid.code);\n const block = await repo.blocks.get(cid, options);\n const node = codec.decode(block);\n if (cid.code === raw__namespace.code) {\n return [];\n }\n if (cid.code === dagPB__namespace.code) {\n return node.Links;\n }\n if (cid.code === dagCBOR__namespace.code) {\n return findLinks(node);\n }\n throw new Error(`Cannot resolve links from codec ${ cid.code }`);\n }\n return withTimeoutOption.withTimeoutOption(links);\n}\n\nexports.createLinks = createLinks;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar cid = require('multiformats/cid');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nfunction createNew({repo, preload}) {\n async function _new(options = {}) {\n let data;\n if (options.template) {\n if (options.template === 'unixfs-dir') {\n data = new ipfsUnixfs.UnixFS({ type: 'directory' }).marshal();\n } else {\n throw new Error('unknown template');\n }\n }\n const buf = dagPB__namespace.encode({\n Data: data,\n Links: []\n });\n const hash = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(hash);\n await repo.blocks.put(cid$1, buf, { signal: options.signal });\n if (options.preload !== false) {\n preload(cid$1);\n }\n return cid$1;\n }\n return withTimeoutOption.withTimeoutOption(_new);\n}\n\nexports.createNew = createNew;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar sha2 = require('multiformats/hashes/sha2');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nfunction createPut({repo, preload}) {\n async function put(obj, options = {}) {\n const release = await repo.gcLock.readLock();\n try {\n const buf = dagPB__namespace.encode(obj);\n const hash = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(hash);\n await repo.blocks.put(cid$1, buf, { signal: options.signal });\n if (options.preload !== false) {\n preload(cid$1);\n }\n if (options.pin) {\n await repo.pins.pinRecursively(cid$1, { signal: options.signal });\n }\n return cid$1;\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(put);\n}\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('./get.js');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nfunction createStat({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n async function stat(cid, options = {}) {\n const node = await get$1(cid, options);\n const serialized = dagPB__namespace.encode(node);\n const blockSize = serialized.length;\n const linkLength = node.Links.reduce((a, l) => a + (l.Tsize || 0), 0);\n return {\n Hash: cid,\n NumLinks: node.Links.length,\n BlockSize: blockSize,\n LinksSize: blockSize - (node.Data || []).length,\n DataSize: (node.Data || []).length,\n CumulativeSize: blockSize + linkLength\n };\n }\n return withTimeoutOption.withTimeoutOption(stat);\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addLink = require('./add-link.js');\nvar appendData = require('./append-data.js');\nvar rmLink = require('./rm-link.js');\nvar setData = require('./set-data.js');\n\nclass ObjectPatchAPI {\n constructor({repo, preload}) {\n this.addLink = addLink.createAddLink({\n repo,\n preload\n });\n this.appendData = appendData.createAppendData({\n repo,\n preload\n });\n this.rmLink = rmLink.createRmLink({\n repo,\n preload\n });\n this.setData = setData.createSetData({\n repo,\n preload\n });\n }\n}\n\nexports.ObjectPatchAPI = ObjectPatchAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('../get.js');\nvar put = require('../put.js');\n\nfunction createAddLink({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n const put$1 = put.createPut({\n repo,\n preload\n });\n async function addLink(cid, link, options = {}) {\n const node = await get$1(cid, options);\n return put$1({\n ...node,\n Links: node.Links.concat([link])\n }, options);\n }\n return withTimeoutOption.withTimeoutOption(addLink);\n}\n\nexports.createAddLink = createAddLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar concat = require('uint8arrays/concat');\nvar get = require('../get.js');\nvar put = require('../put.js');\n\nfunction createAppendData({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n const put$1 = put.createPut({\n repo,\n preload\n });\n async function appendData(cid, data, options = {}) {\n const node = await get$1(cid, options);\n const newData = concat.concat([\n node.Data || [],\n data\n ]);\n return put$1({\n ...node,\n Data: newData\n }, options);\n }\n return withTimeoutOption.withTimeoutOption(appendData);\n}\n\nexports.createAppendData = createAppendData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('../get.js');\nvar put = require('../put.js');\n\nfunction createRmLink({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n const put$1 = put.createPut({\n repo,\n preload\n });\n async function rmLink(multihash, linkRef, options = {}) {\n const node = await get$1(multihash, options);\n const name = (typeof linkRef === 'string' ? linkRef : linkRef.Name) || '';\n node.Links = node.Links.filter(l => l.Name !== name);\n return put$1(node, options);\n }\n return withTimeoutOption.withTimeoutOption(rmLink);\n}\n\nexports.createRmLink = createRmLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('../get.js');\nvar put = require('../put.js');\n\nfunction createSetData({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n const put$1 = put.createPut({\n repo,\n preload\n });\n async function setData(cid, data, options = {}) {\n const node = await get$1(cid, options);\n return put$1({\n ...node,\n Data: data\n }, options);\n }\n return withTimeoutOption.withTimeoutOption(setData);\n}\n\nexports.createSetData = createSetData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar gc = require('./gc.js');\nvar stat = require('./stat.js');\nvar version = require('./version.js');\n\nclass RepoAPI {\n constructor({repo, hashers}) {\n this.gc = gc.createGc({\n repo,\n hashers\n });\n this.stat = stat.createStat({ repo });\n this.version = version.createVersion({ repo });\n this.setApiAddr = addr => repo.apiAddr.set(addr);\n }\n}\n\nexports.RepoAPI = RepoAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar withMfsRoot = require('../files/utils/with-mfs-root.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:repo:gc');\nfunction createGc({repo, hashers}) {\n async function* gc(options = {}) {\n const start = Date.now();\n let mfsRootCid;\n try {\n mfsRootCid = await withMfsRoot.loadMfsRoot({\n repo,\n hashers\n }, options);\n await repo.pins.pinRecursively(mfsRootCid);\n yield* repo.gc();\n } finally {\n if (mfsRootCid) {\n await repo.pins.unpin(mfsRootCid);\n }\n }\n log(`Complete (${ Date.now() - start }ms)`);\n }\n return withTimeoutOption.withTimeoutOption(gc);\n}\n\nexports.createGc = createGc;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createStat({repo}) {\n async function stat(options = {}) {\n const stats = await repo.stat();\n return {\n numObjects: BigInt(stats.numObjects.toString()),\n repoSize: BigInt(stats.repoSize.toString()),\n repoPath: stats.repoPath,\n version: `${ stats.version }`,\n storageMax: BigInt(stats.storageMax.toString())\n };\n }\n return withTimeoutOption.withTimeoutOption(stat);\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar constants = require('ipfs-repo/constants');\n\nfunction createVersion({repo}) {\n async function version(options = {}) {\n try {\n await repo._checkInitialized(options);\n } catch (err) {\n const match = [\n /Key not found in database \\[\\/version\\]/,\n /ENOENT/,\n /repo is not initialized yet/\n ].some(m => {\n return m.test(err.message);\n });\n if (match) {\n return constants.repoVersion;\n }\n throw err;\n }\n return repo.version.get();\n }\n return withTimeoutOption.withTimeoutOption(version);\n}\n\nexports.createVersion = createVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst repoVersion = 11;\n\nexports.repoVersion = repoVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bw = require('./bw.js');\nvar stat = require('../repo/stat.js');\nvar stat$1 = require('../bitswap/stat.js');\n\nclass StatsAPI {\n constructor({repo, network}) {\n this.repo = stat.createStat({ repo });\n this.bw = bw.createBw({ network });\n this.bitswap = stat$1.createStat({ network });\n }\n}\n\nexports.StatsAPI = StatsAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar parseDuration = require('parse-duration');\nvar errCode = require('err-code');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar parseDuration__default = /*#__PURE__*/_interopDefaultLegacy(parseDuration);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction getBandwidthStats(libp2p, opts) {\n let stats;\n if (!libp2p.metrics) {\n stats = undefined;\n } else if (opts.peer) {\n stats = libp2p.metrics.forPeer(opts.peer);\n } else if (opts.proto) {\n stats = libp2p.metrics.forProtocol(opts.proto);\n } else {\n stats = libp2p.metrics.global;\n }\n if (!stats) {\n return {\n totalIn: BigInt(0),\n totalOut: BigInt(0),\n rateIn: 0,\n rateOut: 0\n };\n }\n const {movingAverages, snapshot} = stats;\n return {\n totalIn: BigInt(snapshot.dataReceived.integerValue().toString()),\n totalOut: BigInt(snapshot.dataSent.integerValue().toString()),\n rateIn: movingAverages.dataReceived[60000].movingAverage() / 60,\n rateOut: movingAverages.dataSent[60000].movingAverage() / 60\n };\n}\nfunction createBw({network}) {\n const bw = async function* (options = {}) {\n const {libp2p} = await network.use(options);\n if (!options.poll) {\n yield getBandwidthStats(libp2p, options);\n return;\n }\n const interval = options.interval || 1000;\n let ms = -1;\n try {\n ms = typeof interval === 'string' ? parseDuration__default['default'](interval) || -1 : interval;\n if (!ms || ms < 0)\n throw new Error('invalid duration');\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_POLL_INTERVAL');\n }\n let timeoutId;\n try {\n while (true) {\n yield getBandwidthStats(libp2p, options);\n await new Promise(resolve => {\n timeoutId = setTimeout(resolve, ms);\n });\n }\n } finally {\n clearTimeout(timeoutId);\n }\n };\n return withTimeoutOption.withTimeoutOption(bw);\n}\n\nexports.createBw = createBw;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar repo = require('ipfs-core-config/repo');\nvar getDefaultConfig = require('ipfs-core-config/config');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar PeerId = require('peer-id');\nvar mergeOpts = require('merge-options');\nvar profiles = require('./config/profiles.js');\nvar errors$1 = require('../errors.js');\nvar libp2p = require('./libp2p.js');\nvar errors = require('ipfs-repo/errors');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar getDefaultConfig__default = /*#__PURE__*/_interopDefaultLegacy(getDefaultConfig);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:components:peer:storage');\nclass Storage {\n constructor(peerId, keychain, repo, print, isNew) {\n this.print = print;\n this.peerId = peerId;\n this.keychain = keychain;\n this.repo = repo;\n this.print = print;\n this.isNew = isNew;\n }\n static async start(print, codecs, options) {\n const {\n repoAutoMigrate,\n repo: inputRepo,\n onMigrationProgress\n } = options;\n const repo$1 = typeof inputRepo === 'string' || inputRepo == null ? repo.createRepo(print, codecs, {\n path: inputRepo,\n autoMigrate: repoAutoMigrate,\n onMigrationProgress: onMigrationProgress\n }) : inputRepo;\n const {peerId, keychain, isNew} = await loadRepo(print, repo$1, options);\n return new Storage(peerId, keychain, repo$1, print, isNew);\n }\n}\nconst loadRepo = async (print, repo, options) => {\n if (!repo.closed) {\n return {\n ...await configureRepo(repo, options),\n isNew: false\n };\n }\n try {\n await repo.open();\n return {\n ...await configureRepo(repo, options),\n isNew: false\n };\n } catch (err) {\n if (err.code !== errors.ERR_REPO_NOT_INITIALIZED) {\n throw err;\n }\n if (options.init && options.init.allowNew === false) {\n throw new errors$1.NotEnabledError('Initialization of new repos disabled by config, pass `config.init.isNew: true` to enable it');\n }\n return {\n ...await initRepo(print, repo, options),\n isNew: true\n };\n }\n};\nconst initRepo = async (print, repo, options) => {\n const initOptions = options.init || {};\n const exists = await repo.exists();\n log('repo exists?', exists);\n if (exists === true) {\n throw new Error('repo already exists');\n }\n const peerId = initOptions.privateKey ? await decodePeerId(initOptions.privateKey) : await initPeerId(print, initOptions);\n const identity = peerIdToIdentity(peerId);\n log('peer identity: %s', identity.PeerID);\n const config = {\n ...mergeOptions(applyProfiles(getDefaultConfig__default['default'](), initOptions.profiles), options.config),\n Identity: identity\n };\n await repo.init(config);\n await repo.open();\n log('repo opened');\n const keychainConfig = { pass: options.pass };\n try {\n keychainConfig.dek = await repo.config.get('Keychain.DEK');\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n }\n const libp2p$1 = await libp2p.createLibp2p({\n options: undefined,\n multiaddrs: undefined,\n peerId,\n repo,\n config,\n keychainConfig\n });\n if (libp2p$1.keychain && libp2p$1.keychain.opts) {\n await libp2p$1.loadKeychain();\n await repo.config.set('Keychain', { DEK: libp2p$1.keychain.opts.dek });\n }\n return {\n peerId,\n keychain: libp2p$1.keychain\n };\n};\nconst decodePeerId = peerId => {\n log('using user-supplied private-key');\n return typeof peerId === 'object' ? peerId : PeerId__default['default'].createFromPrivKey(fromString.fromString(peerId, 'base64pad'));\n};\nconst initPeerId = (print, {algorithm = 'Ed25519', bits = 2048}) => {\n print('generating %s keypair...', algorithm);\n return PeerId__default['default'].create({\n keyType: algorithm,\n bits\n });\n};\nconst peerIdToIdentity = peerId => ({\n PeerID: peerId.toB58String(),\n PrivKey: toString.toString(peerId.privKey.bytes, 'base64pad')\n});\nconst configureRepo = async (repo, options) => {\n const config = options.config;\n const profiles = options.init && options.init.profiles || [];\n const pass = options.pass;\n const original = await repo.config.getAll();\n const changed = mergeConfigs(applyProfiles(original, profiles), config);\n if (original !== changed) {\n await repo.config.replace(changed);\n }\n if (!changed.Identity || !changed.Identity.PrivKey) {\n throw new errors$1.NotInitializedError('No private key was found in the config, please intialize the repo');\n }\n const peerId = await PeerId__default['default'].createFromPrivKey(changed.Identity.PrivKey);\n const libp2p$1 = await libp2p.createLibp2p({\n options: undefined,\n multiaddrs: undefined,\n peerId,\n repo,\n config: changed,\n keychainConfig: {\n pass,\n ...changed.Keychain\n }\n });\n if (libp2p$1.keychain) {\n await libp2p$1.loadKeychain();\n }\n return {\n peerId,\n keychain: libp2p$1.keychain\n };\n};\nconst mergeConfigs = (config, changes) => changes ? mergeOptions(config, changes) : config;\nconst applyProfiles = (config, profiles$1) => {\n return (profiles$1 || []).reduce((config, name) => {\n const profile = profiles.profiles[name];\n if (!profile) {\n throw new Error(`Could not find profile with name '${ name }'`);\n }\n log('applying profile %s', name);\n return profile.transform(config);\n }, config);\n};\n\nexports.Storage = Storage;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsRepo = require('ipfs-repo');\nvar datastoreLevel = require('datastore-level');\nvar blockstoreDatastoreAdapter = require('blockstore-datastore-adapter');\nvar memory = require('ipfs-repo/locks/memory');\n\nfunction createRepo(print, codecs, options) {\n const repoPath = options.path || 'ipfs';\n return ipfsRepo.createRepo(repoPath, codeOrName => codecs.getCodec(codeOrName), {\n root: new datastoreLevel.LevelDatastore(repoPath, {\n prefix: '',\n version: 2\n }),\n blocks: new blockstoreDatastoreAdapter.BlockstoreDatastoreAdapter(new datastoreLevel.LevelDatastore(`${ repoPath }/blocks`, {\n prefix: '',\n version: 2\n })),\n datastore: new datastoreLevel.LevelDatastore(`${ repoPath }/datastore`, {\n prefix: '',\n version: 2\n }),\n keys: new datastoreLevel.LevelDatastore(`${ repoPath }/keys`, {\n prefix: '',\n version: 2\n }),\n pins: new datastoreLevel.LevelDatastore(`${ repoPath }/pins`, {\n prefix: '',\n version: 2\n })\n }, {\n autoMigrate: options.autoMigrate,\n onMigrationProgress: options.onMigrationProgress || print,\n repoLock: memory.MemoryLock\n });\n}\n\nexports.createRepo = createRepo;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _get = require('just-safe-get');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar migrator = require('ipfs-repo-migrations');\nvar bytes = require('bytes');\nvar merge = require('merge-options');\nvar constants = require('./constants.js');\nvar version = require('./version.js');\nvar config = require('./config.js');\nvar spec = require('./spec.js');\nvar apiAddr = require('./api-addr.js');\nvar idstore = require('./idstore.js');\nvar defaultOptions = require('./default-options.js');\nvar defaultDatastore = require('./default-datastore.js');\nvar errors = require('./errors.js');\nvar pinManager = require('./pin-manager.js');\nvar pinnedBlockstore = require('./pinned-blockstore.js');\nvar mortice = require('mortice');\nvar gc = require('./gc.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar _get__default = /*#__PURE__*/_interopDefaultLegacy(_get);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar migrator__namespace = /*#__PURE__*/_interopNamespace(migrator);\nvar bytes__default = /*#__PURE__*/_interopDefaultLegacy(bytes);\nvar merge__default = /*#__PURE__*/_interopDefaultLegacy(merge);\nvar mortice__default = /*#__PURE__*/_interopDefaultLegacy(mortice);\n\nconst log = debug__default[\"default\"]('ipfs:repo');\nconst noLimit = Number.MAX_SAFE_INTEGER;\nconst AUTO_MIGRATE_CONFIG_KEY = 'repoAutoMigrate';\nclass Repo {\n constructor(path, loadCodec, backends, options) {\n if (typeof path !== 'string') {\n throw new Error('missing repo path');\n }\n if (typeof loadCodec !== 'function') {\n throw new Error('missing codec loader');\n }\n this.options = merge__default[\"default\"](defaultOptions, options);\n this.closed = true;\n this.path = path;\n this.root = backends.root;\n this.datastore = backends.datastore;\n this.keys = backends.keys;\n const blockstore = backends.blocks;\n const pinstore = backends.pins;\n this.pins = new pinManager.PinManager({\n pinstore,\n blockstore,\n loadCodec\n });\n const pinnedBlockstore$1 = pinnedBlockstore.createPinnedBlockstore(this.pins, blockstore);\n this.blocks = idstore.createIdStore(pinnedBlockstore$1);\n this.version = version.version(this.root);\n this.config = config.config(this.root);\n this.spec = spec.spec(this.root);\n this.apiAddr = apiAddr.apiAddr(this.root);\n this.gcLock = mortice__default[\"default\"](path, { singleProcess: this.options.repoOwner !== false });\n this.gc = gc.gc({\n gcLock: this.gcLock,\n pins: this.pins,\n blockstore: this.blocks,\n root: this.root,\n loadCodec\n });\n }\n async init(config) {\n log('initializing at: %s', this.path);\n await this._openRoot();\n await this.config.replace(buildConfig(config));\n await this.spec.set(buildDatastoreSpec(config));\n await this.version.set(constants.repoVersion);\n }\n async isInitialized() {\n if (!this.closed) {\n return true;\n }\n try {\n await this._openRoot();\n await this._checkInitialized();\n await this.root.close();\n return true;\n } catch (err) {\n return false;\n }\n }\n async open() {\n if (!this.closed) {\n throw errCode__default[\"default\"](new Error('repo is already open'), errors.ERR_REPO_ALREADY_OPEN);\n }\n log('opening at: %s', this.path);\n try {\n await this._openRoot();\n await this._checkInitialized();\n this._lockfile = await this._openLock();\n log('acquired repo.lock');\n const isCompatible = await this.version.check(constants.repoVersion);\n if (!isCompatible) {\n if (await this._isAutoMigrationEnabled()) {\n await this._migrate(constants.repoVersion, {\n root: this.root,\n datastore: this.datastore,\n pins: this.pins.pinstore,\n blocks: this.pins.blockstore,\n keys: this.keys\n });\n } else {\n throw new errors.InvalidRepoVersionError('Incompatible repo versions. Automatic migrations disabled. Please migrate the repo manually.');\n }\n }\n log('creating datastore');\n await this.datastore.open();\n log('creating blocks');\n await this.blocks.open();\n log('creating keystore');\n await this.keys.open();\n log('creating pins');\n await this.pins.pinstore.open();\n this.closed = false;\n log('all opened');\n } catch (err) {\n if (this._lockfile) {\n try {\n await this._closeLock();\n this._lockfile = null;\n } catch (err2) {\n log('error removing lock', err2);\n }\n }\n throw err;\n }\n }\n async _openRoot() {\n try {\n await this.root.open();\n } catch (err) {\n if (err.message !== 'Already open') {\n throw err;\n }\n }\n }\n async _openLock() {\n const lockfile = await this.options.repoLock.lock(this.path);\n if (typeof lockfile.close !== 'function') {\n throw errCode__default[\"default\"](new Error('Locks must have a close method'), 'ERR_NO_CLOSE_FUNCTION');\n }\n return lockfile;\n }\n _closeLock() {\n return this._lockfile && this._lockfile.close();\n }\n async _checkInitialized() {\n log('init check');\n let config;\n try {\n [config] = await Promise.all([\n this.config.exists(),\n this.spec.exists(),\n this.version.exists()\n ]);\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n throw errCode__default[\"default\"](new Error('repo is not initialized yet'), errors.ERR_REPO_NOT_INITIALIZED, { path: this.path });\n }\n throw err;\n }\n if (!config) {\n throw errCode__default[\"default\"](new Error('repo is not initialized yet'), errors.ERR_REPO_NOT_INITIALIZED, { path: this.path });\n }\n }\n async close() {\n if (this.closed) {\n throw errCode__default[\"default\"](new Error('repo is already closed'), errors.ERR_REPO_ALREADY_CLOSED);\n }\n log('closing at: %s', this.path);\n try {\n await this.apiAddr.delete();\n } catch (err) {\n if (err.code !== errors.ERR_REPO_NOT_INITIALIZED && !err.message.startsWith('ENOENT')) {\n throw err;\n }\n }\n await Promise.all([\n this.root,\n this.blocks,\n this.keys,\n this.datastore,\n this.pins.pinstore\n ].map(store => store && store.close()));\n log('unlocking');\n this.closed = true;\n await this._closeLock();\n }\n exists() {\n return this.version.exists();\n }\n async stat() {\n if (this.datastore && this.keys) {\n const [storageMax, blocks, version, datastore, keys] = await Promise.all([\n this._storageMaxStat(),\n this._blockStat(),\n this.version.get(),\n getSize(this.datastore),\n getSize(this.keys)\n ]);\n const size = blocks.size + datastore + keys;\n return {\n repoPath: this.path,\n storageMax,\n version: version,\n numObjects: blocks.count,\n repoSize: size\n };\n }\n throw errCode__default[\"default\"](new Error('repo is not initialized yet'), errors.ERR_REPO_NOT_INITIALIZED, { path: this.path });\n }\n async _isAutoMigrationEnabled() {\n if (this.options.autoMigrate !== undefined) {\n return this.options.autoMigrate;\n }\n let autoMigrateConfig;\n try {\n autoMigrateConfig = await this.config.get(AUTO_MIGRATE_CONFIG_KEY);\n } catch (e) {\n if (e.code === errors.NotFoundError.code) {\n autoMigrateConfig = true;\n } else {\n throw e;\n }\n }\n return autoMigrateConfig;\n }\n async _migrate(toVersion, backends) {\n const currentRepoVersion = await this.version.get();\n if (currentRepoVersion > toVersion) {\n log(`reverting to version ${ toVersion }`);\n return migrator__namespace.revert(this.path, backends, this.options, toVersion, {\n ignoreLock: true,\n onProgress: this.options.onMigrationProgress\n });\n } else {\n log(`migrating to version ${ toVersion }`);\n return migrator__namespace.migrate(this.path, backends, this.options, toVersion, {\n ignoreLock: true,\n onProgress: this.options.onMigrationProgress\n });\n }\n }\n async _storageMaxStat() {\n try {\n const max = await this.config.get('Datastore.StorageMax');\n return BigInt(bytes__default[\"default\"](max));\n } catch (err) {\n return BigInt(noLimit);\n }\n }\n async _blockStat() {\n let count = BigInt(0);\n let size = BigInt(0);\n if (this.blocks) {\n for await (const {key, value} of this.blocks.query({})) {\n count += BigInt(1);\n size += BigInt(value.byteLength);\n size += BigInt(key.bytes.byteLength);\n }\n }\n return {\n count,\n size\n };\n }\n}\nasync function getSize(datastore) {\n let sum = BigInt(0);\n for await (const block of datastore.query({})) {\n sum += BigInt(block.value.byteLength);\n sum += BigInt(block.key.uint8Array().byteLength);\n }\n return sum;\n}\nfunction createRepo(path, loadCodec, backends, options) {\n return new Repo(path, loadCodec, backends, options);\n}\nfunction buildConfig(_config) {\n _config.Datastore = Object.assign({}, defaultDatastore, _get__default[\"default\"](_config, 'datastore'));\n return _config;\n}\nfunction buildDatastoreSpec(_config) {\n const spec = {\n ...defaultDatastore.Spec,\n ..._get__default[\"default\"](_config, 'Datastore.Spec')\n };\n return {\n type: spec.type,\n mounts: spec.mounts.map(mounting => ({\n mountpoint: mounting.mountpoint,\n type: mounting.child.type,\n path: mounting.child.path,\n shardFunc: mounting.child.shardFunc\n }))\n };\n}\n\nexports.createRepo = createRepo;\n","module.exports = get;\n\n/*\n const obj = {a: {aa: {aaa: 2}}, b: 4};\n\n get(obj, 'a.aa.aaa'); // 2\n get(obj, ['a', 'aa', 'aaa']); // 2\n\n get(obj, 'b.bb.bbb'); // undefined\n get(obj, ['b', 'bb', 'bbb']); // undefined\n\n get(obj.a, 'aa.aaa'); // 2\n get(obj.a, ['aa', 'aaa']); // 2\n\n get(obj.b, 'bb.bbb'); // undefined\n get(obj.b, ['bb', 'bbb']); // undefined\n\n get(obj.b, 'bb.bbb', 42); // 42\n get(obj.b, ['bb', 'bbb'], 42); // 42\n\n get(null, 'a'); // undefined\n get(undefined, ['a']); // undefined\n\n get(null, 'a', 42); // 42\n get(undefined, ['a'], 42); // 42\n\n const obj = {a: {}};\n const sym = Symbol();\n obj.a[sym] = 4;\n get(obj.a, sym); // 4\n*/\n\nfunction get(obj, propsArg, defaultValue) {\n if (!obj) {\n return defaultValue;\n }\n var props, prop;\n if (Array.isArray(propsArg)) {\n props = propsArg.slice(0);\n }\n if (typeof propsArg == 'string') {\n props = propsArg.split('.');\n }\n if (typeof propsArg == 'symbol') {\n props = [propsArg];\n }\n if (!Array.isArray(props)) {\n throw new Error('props arg must be an array, a string or a symbol');\n }\n while (props.length) {\n prop = props.shift();\n if (!obj) {\n return defaultValue;\n }\n obj = obj[prop];\n if (obj === undefined) {\n return defaultValue;\n }\n }\n return obj;\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('../migrations/index.js');\nvar version = require('./repo/version.js');\nvar errors$1 = require('./errors.js');\nvar utils = require('./utils.js');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:migrator');\nfunction getLatestMigrationVersion(migrations) {\n migrations = migrations || index;\n if (!Array.isArray(migrations) || migrations.length === 0) {\n return 0;\n }\n return migrations[migrations.length - 1].version;\n}\nasync function migrate(path, backends, repoOptions, toVersion, {ignoreLock = false, onProgress, isDryRun = false, migrations}) {\n migrations = migrations || index;\n if (!path) {\n throw new errors.RequiredParameterError('Path argument is required!');\n }\n if (!repoOptions) {\n throw new errors.RequiredParameterError('repoOptions argument is required!');\n }\n if (!toVersion) {\n throw new errors.RequiredParameterError('toVersion argument is required!');\n }\n if (!Number.isInteger(toVersion) || toVersion <= 0) {\n throw new errors.InvalidValueError('Version has to be positive integer!');\n }\n backends = utils.wrapBackends(backends);\n const currentVersion = await version.getVersion(backends);\n if (currentVersion === toVersion) {\n log('Nothing to migrate.');\n return;\n }\n if (currentVersion > toVersion) {\n throw new errors.InvalidValueError(`Current repo's version (${ currentVersion }) is higher then toVersion (${ toVersion }), you probably wanted to revert it?`);\n }\n verifyAvailableMigrations(migrations, currentVersion, toVersion);\n let lock;\n if (!isDryRun && !ignoreLock) {\n lock = await repoOptions.repoLock.lock(path);\n }\n try {\n for (const migration of migrations) {\n if (toVersion !== undefined && migration.version > toVersion) {\n break;\n }\n if (migration.version <= currentVersion) {\n continue;\n }\n log(`Migrating version ${ migration.version }`);\n try {\n if (!isDryRun) {\n let progressCallback = () => {\n };\n if (onProgress) {\n progressCallback = (percent, message) => onProgress(migration.version, percent.toFixed(2), message);\n }\n await migration.migrate(backends, progressCallback);\n }\n } catch (e) {\n const lastSuccessfullyMigratedVersion = migration.version - 1;\n log(`An exception was raised during execution of migration. Setting the repo's version to last successfully migrated version: ${ lastSuccessfullyMigratedVersion }`);\n await version.setVersion(lastSuccessfullyMigratedVersion, backends);\n throw new Error(`During migration to version ${ migration.version } exception was raised: ${ e.stack || e.message || e }`);\n }\n log(`Migrating to version ${ migration.version } finished`);\n }\n if (!isDryRun) {\n await version.setVersion(toVersion || getLatestMigrationVersion(migrations), backends);\n }\n log('Repo successfully migrated', toVersion !== undefined ? `to version ${ toVersion }!` : 'to latest version!');\n } finally {\n if (!isDryRun && !ignoreLock && lock) {\n await lock.close();\n }\n }\n}\nasync function revert(path, backends, repoOptions, toVersion, {ignoreLock = false, onProgress, isDryRun = false, migrations}) {\n migrations = migrations || index;\n if (!path) {\n throw new errors.RequiredParameterError('Path argument is required!');\n }\n if (!repoOptions) {\n throw new errors.RequiredParameterError('repoOptions argument is required!');\n }\n if (!toVersion) {\n throw new errors.RequiredParameterError('When reverting migrations, you have to specify to which version to revert!');\n }\n if (!Number.isInteger(toVersion) || toVersion <= 0) {\n throw new errors.InvalidValueError('Version has to be positive integer!');\n }\n backends = utils.wrapBackends(backends);\n const currentVersion = await version.getVersion(backends);\n if (currentVersion === toVersion) {\n log('Nothing to revert.');\n return;\n }\n if (currentVersion < toVersion) {\n throw new errors.InvalidValueError(`Current repo's version (${ currentVersion }) is lower then toVersion (${ toVersion }), you probably wanted to migrate it?`);\n }\n verifyAvailableMigrations(migrations, toVersion, currentVersion, true);\n let lock;\n if (!isDryRun && !ignoreLock) {\n lock = await repoOptions.repoLock.lock(path);\n }\n log(`Reverting from version ${ currentVersion } to ${ toVersion }`);\n try {\n const reversedMigrationArray = migrations.slice().reverse();\n for (const migration of reversedMigrationArray) {\n if (migration.version <= toVersion) {\n break;\n }\n if (migration.version > currentVersion) {\n continue;\n }\n log(`Reverting migration version ${ migration.version }`);\n try {\n if (!isDryRun) {\n let progressCallback = () => {\n };\n if (onProgress) {\n progressCallback = (percent, message) => onProgress(migration.version, percent.toFixed(2), message);\n }\n await migration.revert(backends, progressCallback);\n }\n } catch (e) {\n const lastSuccessfullyRevertedVersion = migration.version;\n log(`An exception was raised during execution of migration. Setting the repo's version to last successfully reverted version: ${ lastSuccessfullyRevertedVersion }`);\n await version.setVersion(lastSuccessfullyRevertedVersion, backends);\n e.message = `During reversion to version ${ migration.version } exception was raised: ${ e.message }`;\n throw e;\n }\n log(`Reverting to version ${ migration.version } finished`);\n }\n if (!isDryRun) {\n await version.setVersion(toVersion, backends);\n }\n log(`All migrations successfully reverted to version ${ toVersion }!`);\n } finally {\n if (!isDryRun && !ignoreLock && lock) {\n await lock.close();\n }\n }\n}\nfunction verifyAvailableMigrations(migrations, fromVersion, toVersion, checkReversibility = false) {\n let migrationCounter = 0;\n for (const migration of migrations) {\n if (migration.version > toVersion) {\n break;\n }\n if (migration.version > fromVersion) {\n if (checkReversibility && !migration.revert) {\n throw new errors.NonReversibleMigrationError(`It is not possible to revert to version ${ fromVersion } because migration version ${ migration.version } is not reversible. Cancelling reversion.`);\n }\n migrationCounter++;\n }\n }\n if (migrationCounter !== toVersion - fromVersion) {\n throw new errors.InvalidValueError(`The ipfs-repo-migrations package does not have all migration to migrate from version ${ fromVersion } to ${ toVersion }`);\n }\n}\nconst getCurrentRepoVersion = version.getVersion;\nconst errors = errors$1;\nconst migrations = index;\n\nexports.errors = errors;\nexports.getCurrentRepoVersion = getCurrentRepoVersion;\nexports.getLatestMigrationVersion = getLatestMigrationVersion;\nexports.migrate = migrate;\nexports.migrations = migrations;\nexports.revert = revert;\n","'use strict';\n\nvar index = require('./migration-8/index.js');\nvar index$1 = require('./migration-9/index.js');\nvar index$2 = require('./migration-10/index.js');\nvar index$3 = require('./migration-11/index.js');\n\nconst emptyMigration = {\n description: 'Empty migration.',\n migrate: () => {\n },\n revert: () => {\n },\n empty: true\n};\nvar defaultMigrations = [\n Object.assign({ version: 1 }, emptyMigration),\n Object.assign({ version: 2 }, emptyMigration),\n Object.assign({ version: 3 }, emptyMigration),\n Object.assign({ version: 4 }, emptyMigration),\n Object.assign({ version: 5 }, emptyMigration),\n Object.assign({ version: 6 }, emptyMigration),\n Object.assign({ version: 7 }, emptyMigration),\n index.migration,\n index$1.migration,\n index$2.migration,\n index$3.migration\n];\n\nmodule.exports = defaultMigrations;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar key = require('interface-datastore/key');\nvar debug = require('debug');\nvar length = require('it-length');\nvar base32 = require('multiformats/bases/base32');\nvar raw = require('multiformats/codecs/raw');\nvar mhd = require('multiformats/hashes/digest');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar length__default = /*#__PURE__*/_interopDefaultLegacy(length);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar mhd__namespace = /*#__PURE__*/_interopNamespace(mhd);\n\nconst log = debug__default[\"default\"]('ipfs:repo:migrator:migration-8');\nfunction unwrap(blockstore) {\n if (blockstore.child) {\n return unwrap(blockstore.child);\n }\n return blockstore;\n}\nfunction keyToMultihash(key$1) {\n try {\n const buf = base32.base32.decode(`b${ key$1.toString().toLowerCase().slice(1) }`);\n const multihash = cid.CID.decode(buf).multihash.bytes;\n const multihashStr = base32.base32.encode(multihash).slice(1).toUpperCase();\n return new key.Key(`/${ multihashStr }`, false);\n } catch (err) {\n return key$1;\n }\n}\nfunction keyToCid(key$1) {\n try {\n const buf = base32.base32.decode(`b${ key$1.toString().toLowerCase().slice(1) }`);\n const digest = mhd__namespace.decode(buf);\n const multihash = base32.base32.encode(cid.CID.createV1(raw__namespace.code, digest).bytes).slice(1);\n return new key.Key(`/${ multihash.toUpperCase() }`, false);\n } catch {\n return key$1;\n }\n}\nasync function process(backends, onProgress, keyFunction) {\n const blockstore = backends.blocks;\n await blockstore.open();\n const unwrapped = unwrap(blockstore);\n const blockCount = await length__default[\"default\"](unwrapped.queryKeys({\n filters: [key => {\n const newKey = keyFunction(key);\n return newKey.toString() !== key.toString();\n }]\n }));\n try {\n let counter = 0;\n for await (const block of unwrapped.query({})) {\n const newKey = keyFunction(block.key);\n if (newKey.toString() !== block.key.toString()) {\n counter += 1;\n log(`Migrating Block from ${ block.key } to ${ newKey }`, await unwrapped.has(block.key));\n await unwrapped.delete(block.key);\n await unwrapped.put(newKey, block.value);\n onProgress(counter / blockCount * 100, `Migrated Block from ${ block.key } to ${ newKey }`);\n }\n }\n } finally {\n await blockstore.close();\n }\n}\nconst migration = {\n version: 8,\n description: 'Transforms key names into base32 encoding and converts Block store to use bare multihashes encoded as base32',\n migrate: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, keyToMultihash);\n },\n revert: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, keyToCid);\n }\n};\n\nexports.migration = migration;\n","'use strict'\n\n/**\n * Consumes the passed iterator and returns the number of items it contained.\n *\n * @param {AsyncIterable | Iterable} iterator\n * @returns {Promise}\n */\nconst length = async (iterator) => {\n let count = 0\n\n for await (const _ of iterator) { // eslint-disable-line no-unused-vars\n count++\n }\n\n return count\n}\n\nmodule.exports = length\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar dagPb = require('@ipld/dag-pb');\nvar cbor = require('cborg');\nvar pinSet = require('./pin-set.js');\nvar utils = require('./utils.js');\nvar length = require('it-length');\nvar sha2 = require('multiformats/hashes/sha2');\nvar mhd = require('multiformats/hashes/digest');\nvar base32 = require('multiformats/bases/base32');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar cbor__namespace = /*#__PURE__*/_interopNamespace(cbor);\nvar length__default = /*#__PURE__*/_interopDefaultLegacy(length);\nvar mhd__namespace = /*#__PURE__*/_interopNamespace(mhd);\n\nasync function pinsToDatastore(blockstore, datastore, pinstore, onProgress) {\n if (!await datastore.has(utils.PIN_DS_KEY)) {\n return;\n }\n const mh = await datastore.get(utils.PIN_DS_KEY);\n const cid$1 = cid.CID.decode(mh);\n const pinRootBuf = await blockstore.get(cid$1);\n const pinRoot = dagPb__namespace.decode(pinRootBuf);\n let counter = 0;\n const pinCount = await length__default[\"default\"](pinSet.loadSet(blockstore, pinRoot, utils.PinTypes.recursive)) + await length__default[\"default\"](pinSet.loadSet(blockstore, pinRoot, utils.PinTypes.direct));\n for await (const cid of pinSet.loadSet(blockstore, pinRoot, utils.PinTypes.recursive)) {\n counter++;\n const pin = { depth: Infinity };\n if (cid.version !== 0) {\n pin.version = cid.version;\n }\n if (cid.code !== dagPb__namespace.code) {\n pin.codec = cid.code;\n }\n await pinstore.put(utils.cidToKey(cid), cbor__namespace.encode(pin));\n onProgress(counter / pinCount * 100, `Migrated recursive pin ${ cid }`);\n }\n for await (const cid of pinSet.loadSet(blockstore, pinRoot, utils.PinTypes.direct)) {\n counter++;\n const pin = { depth: 0 };\n if (cid.version !== 0) {\n pin.version = cid.version;\n }\n if (cid.code !== dagPb__namespace.code) {\n pin.codec = cid.code;\n }\n await pinstore.put(utils.cidToKey(cid), cbor__namespace.encode(pin));\n onProgress(counter / pinCount * 100, `Migrated direct pin ${ cid }`);\n }\n await blockstore.delete(cid$1);\n await datastore.delete(utils.PIN_DS_KEY);\n}\nasync function pinsToDAG(blockstore, datastore, pinstore, onProgress) {\n const recursivePins = [];\n const directPins = [];\n let counter = 0;\n const pinCount = await length__default[\"default\"](pinstore.queryKeys({}));\n for await (const {key, value} of pinstore.query({})) {\n counter++;\n const pin = cbor__namespace.decode(value);\n const cid$1 = cid.CID.create(pin.version || 0, pin.codec || dagPb__namespace.code, mhd__namespace.decode(base32.base32.decode('b' + key.toString().toLowerCase().split('/').pop())));\n if (pin.depth === 0) {\n onProgress(counter / pinCount * 100, `Reverted direct pin ${ cid$1 }`);\n directPins.push(cid$1);\n } else {\n onProgress(counter / pinCount * 100, `Reverted recursive pin ${ cid$1 }`);\n recursivePins.push(cid$1);\n }\n }\n onProgress(100, 'Updating pin root');\n const pinRoot = {\n Links: [\n await pinSet.storeSet(blockstore, utils.PinTypes.direct, directPins),\n await pinSet.storeSet(blockstore, utils.PinTypes.recursive, recursivePins)\n ]\n };\n const buf = dagPb__namespace.encode(pinRoot);\n const digest = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(digest);\n await blockstore.put(cid$1, buf);\n await datastore.put(utils.PIN_DS_KEY, cid$1.bytes);\n}\nasync function process(backends, onProgress, fn) {\n const blockstore = backends.blocks;\n const datastore = backends.datastore;\n const pinstore = backends.pins;\n await blockstore.open();\n await datastore.open();\n await pinstore.open();\n try {\n await fn(blockstore, datastore, pinstore, onProgress);\n } finally {\n await pinstore.close();\n await datastore.close();\n await blockstore.close();\n }\n}\nconst migration = {\n version: 9,\n description: 'Migrates pins to datastore',\n migrate: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, pinsToDatastore);\n },\n revert: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, pinsToDAG);\n }\n};\n\nexports.migration = migration;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar pin = require('./pin.js');\nvar fnv1a = require('fnv1a');\nvar varint = require('varint');\nvar dagPb = require('@ipld/dag-pb');\nvar utils = require('./utils.js');\nvar concat = require('uint8arrays/concat');\nvar compare = require('uint8arrays/compare');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\nvar sha2 = require('multiformats/hashes/sha2');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar fnv1a__default = /*#__PURE__*/_interopDefaultLegacy(fnv1a);\nvar varint__default = /*#__PURE__*/_interopDefaultLegacy(varint);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\n\nconst PinSet = pin.ipfs.pin.Set;\nfunction readHeader(rootNode) {\n const rootData = rootNode.Data;\n if (!rootData) {\n throw new Error('No data present');\n }\n const hdrLength = varint__default[\"default\"].decode(rootData);\n const vBytes = varint__default[\"default\"].decode.bytes;\n if (vBytes <= 0) {\n throw new Error('Invalid Set header length');\n }\n if (vBytes + hdrLength > rootData.length) {\n throw new Error('Impossibly large set header length');\n }\n const hdrSlice = rootData.slice(vBytes, hdrLength + vBytes);\n const header = PinSet.toObject(PinSet.decode(hdrSlice), {\n defaults: false,\n arrays: true,\n longs: Number,\n objects: false\n });\n if (header.version !== 1) {\n throw new Error(`Unsupported Set version: ${ header.version }`);\n }\n if (header.fanout > rootNode.Links.length) {\n throw new Error('Impossibly large fanout');\n }\n return {\n header: header,\n data: rootData.slice(hdrLength + vBytes)\n };\n}\nfunction hash(seed, key) {\n const buffer = new Uint8Array(4);\n const dataView = new DataView(buffer.buffer);\n dataView.setUint32(0, seed, true);\n const encodedKey = fromString.fromString(key.toString());\n const data = concat.concat([\n buffer,\n encodedKey\n ], buffer.byteLength + encodedKey.byteLength);\n return fnv1a__default[\"default\"](toString.toString(data));\n}\nasync function* walkItems(blockstore, node) {\n const pbh = readHeader(node);\n let idx = 0;\n for (const link of node.Links) {\n if (idx < pbh.header.fanout) {\n const linkHash = link.Hash;\n if (!utils.EMPTY_KEY.equals(linkHash)) {\n const buf = await blockstore.get(linkHash);\n const node = dagPb__namespace.decode(buf);\n yield* walkItems(blockstore, node);\n }\n } else {\n yield link.Hash;\n }\n idx++;\n }\n}\nasync function* loadSet(blockstore, rootNode, name) {\n const link = rootNode.Links.find(l => l.Name === name);\n if (!link) {\n throw new Error('No link found with name ' + name);\n }\n const buf = await blockstore.get(link.Hash);\n const node = dagPb__namespace.decode(buf);\n yield* walkItems(blockstore, node);\n}\nfunction storeItems(blockstore, items) {\n return storePins(items, 0);\n async function storePins(pins, depth) {\n const pbHeader = PinSet.encode({\n version: 1,\n fanout: utils.DEFAULT_FANOUT,\n seed: depth\n }).finish();\n const header = varint__default[\"default\"].encode(pbHeader.length);\n const headerBuf = concat.concat([\n header,\n pbHeader\n ]);\n const fanoutLinks = [];\n for (let i = 0; i < utils.DEFAULT_FANOUT; i++) {\n fanoutLinks.push({\n Name: '',\n Tsize: 1,\n Hash: utils.EMPTY_KEY\n });\n }\n if (pins.length <= utils.MAX_ITEMS) {\n const nodes = pins.map(item => {\n return {\n link: {\n Name: '',\n Tsize: 1,\n Hash: item.key\n },\n data: item.data || new Uint8Array()\n };\n }).sort((a, b) => {\n return compare.compare(a.link.Hash.bytes, b.link.Hash.bytes);\n });\n const rootLinks = fanoutLinks.concat(nodes.map(item => item.link));\n const rootData = concat.concat([\n headerBuf,\n ...nodes.map(item => item.data)\n ]);\n return {\n Data: rootData,\n Links: rootLinks\n };\n } else {\n const bins = pins.reduce((bins, pin) => {\n const n = hash(depth, pin.key) % utils.DEFAULT_FANOUT;\n bins[n] = n in bins ? bins[n].concat([pin]) : [pin];\n return bins;\n }, []);\n let idx = 0;\n for (const bin of bins) {\n const child = await storePins(bin, depth + 1);\n await storeChild(child, idx);\n idx++;\n }\n return {\n Data: headerBuf,\n Links: fanoutLinks\n };\n }\n async function storeChild(child, binIdx) {\n const buf = dagPb__namespace.encode(child);\n const digest = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(digest);\n await blockstore.put(cid$1, buf);\n const size = child.Links.reduce((acc, curr) => acc + (curr.Tsize || 0), 0) + buf.length;\n fanoutLinks[binIdx] = {\n Name: '',\n Tsize: size,\n Hash: cid$1\n };\n }\n }\n}\nasync function storeSet(blockstore, type, cids) {\n const rootNode = await storeItems(blockstore, cids.map(cid => {\n return { key: cid };\n }));\n const buf = dagPb__namespace.encode(rootNode);\n const digest = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(digest);\n await blockstore.put(cid$1, buf);\n const size = rootNode.Links.reduce((acc, curr) => acc + curr.Tsize, 0) + buf.length;\n return {\n Name: type,\n Tsize: size,\n Hash: cid$1\n };\n}\n\nexports.loadSet = loadSet;\nexports.storeSet = storeSet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar $protobuf = require('protobufjs/minimal.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar $protobuf__default = /*#__PURE__*/_interopDefaultLegacy($protobuf);\n\nconst $Reader = $protobuf__default[\"default\"].Reader, $Writer = $protobuf__default[\"default\"].Writer, $util = $protobuf__default[\"default\"].util;\nconst $root = $protobuf__default[\"default\"].roots['default'] || ($protobuf__default[\"default\"].roots['default'] = {});\nconst ipfs = $root.ipfs = (() => {\n const ipfs = {};\n ipfs.pin = function () {\n const pin = {};\n pin.Set = function () {\n function Set(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Set.prototype.version = 0;\n Set.prototype.fanout = 0;\n Set.prototype.seed = 0;\n Set.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.version != null && Object.hasOwnProperty.call(m, 'version'))\n w.uint32(8).uint32(m.version);\n if (m.fanout != null && Object.hasOwnProperty.call(m, 'fanout'))\n w.uint32(16).uint32(m.fanout);\n if (m.seed != null && Object.hasOwnProperty.call(m, 'seed'))\n w.uint32(29).fixed32(m.seed);\n return w;\n };\n Set.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.ipfs.pin.Set();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.version = r.uint32();\n break;\n case 2:\n m.fanout = r.uint32();\n break;\n case 3:\n m.seed = r.fixed32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Set.fromObject = function fromObject(d) {\n if (d instanceof $root.ipfs.pin.Set)\n return d;\n var m = new $root.ipfs.pin.Set();\n if (d.version != null) {\n m.version = d.version >>> 0;\n }\n if (d.fanout != null) {\n m.fanout = d.fanout >>> 0;\n }\n if (d.seed != null) {\n m.seed = d.seed >>> 0;\n }\n return m;\n };\n Set.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.version = 0;\n d.fanout = 0;\n d.seed = 0;\n }\n if (m.version != null && m.hasOwnProperty('version')) {\n d.version = m.version;\n }\n if (m.fanout != null && m.hasOwnProperty('fanout')) {\n d.fanout = m.fanout;\n }\n if (m.seed != null && m.hasOwnProperty('seed')) {\n d.seed = m.seed;\n }\n return d;\n };\n Set.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n return Set;\n }();\n return pin;\n }();\n return ipfs;\n})();\n\nexports[\"default\"] = $root;\nexports.ipfs = ipfs;\n","/**\n * Created by schwarzkopfb on 15/11/17.\n */\n\n/**\n * FNV-1a hash generation init value.\n * It's exposed, because this allows user to override it.\n *\n * @type {number}\n */\nhash.BASE = 0x811c9dc5\n\n/**\n * Generates 32 bit FNV-1a hash from the given string.\n * As explained here: http://isthe.com/chongo/tech/comp/fnv/\n *\n * @param s {string} String to generate hash from.\n * @returns {number} The result integer hash.\n */\nfunction hash(s) {\n var h = hash.BASE\n\n for (var i = 0, l = s.length; i < l; i++) {\n h ^= s.charCodeAt(i)\n h += (h << 1) + (h << 4) + (h << 7) + (h << 8) + (h << 24)\n }\n\n return h >>> 0\n}\n\nmodule.exports = hash\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar base32 = require('multiformats/bases/base32');\nvar cid = require('multiformats/cid');\n\nconst PIN_DS_KEY = new key.Key('/local/pins');\nconst DEFAULT_FANOUT = 256;\nconst MAX_ITEMS = 8192;\nconst EMPTY_KEY = cid.CID.parse('QmdfTbBqBPQ7VNxZEYEj14VmRuZBkqFbiwReogJgS1zR1n');\nconst PinTypes = {\n direct: 'direct',\n recursive: 'recursive'\n};\nfunction cidToKey(cid) {\n return new key.Key(`/${ base32.base32.encode(cid.multihash.bytes).toUpperCase().substring(1) }`);\n}\n\nexports.DEFAULT_FANOUT = DEFAULT_FANOUT;\nexports.EMPTY_KEY = EMPTY_KEY;\nexports.MAX_ITEMS = MAX_ITEMS;\nexports.PIN_DS_KEY = PIN_DS_KEY;\nexports.PinTypes = PinTypes;\nexports.cidToKey = cidToKey;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction compare(a, b) {\n for (let i = 0; i < a.byteLength; i++) {\n if (a[i] < b[i]) {\n return -1;\n }\n if (a[i] > b[i]) {\n return 1;\n }\n }\n if (a.byteLength > b.byteLength) {\n return 1;\n }\n if (a.byteLength < b.byteLength) {\n return -1;\n }\n return 0;\n}\n\nexports.compare = compare;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('../../src/utils.js');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\n\nasync function keysToBinary(name, store, onProgress = () => {\n}) {\n const db = utils.findLevelJs(store);\n if (!db) {\n onProgress(`${ name } did not need an upgrade`);\n return;\n }\n onProgress(`Upgrading ${ name }`);\n const upgrade = (key, value) => {\n return [\n {\n type: 'del',\n key: key\n },\n {\n type: 'put',\n key: fromString.fromString(key),\n value: value\n }\n ];\n };\n await withEach(db, upgrade);\n}\nasync function keysToStrings(name, store, onProgress = () => {\n}) {\n const db = utils.findLevelJs(store);\n if (!db) {\n onProgress(`${ name } did not need a downgrade`);\n return;\n }\n onProgress(`Downgrading ${ name }`);\n const downgrade = (key, value) => {\n return [\n {\n type: 'del',\n key: key\n },\n {\n type: 'put',\n key: toString.toString(key),\n value: value\n }\n ];\n };\n await withEach(db, downgrade);\n}\nfunction unwrap(store) {\n if (store.child) {\n return unwrap(store.child);\n }\n return store;\n}\nasync function process(backends, onProgress, fn) {\n const datastores = Object.entries(backends).map(([key, backend]) => ({\n key,\n backend: unwrap(backend)\n })).filter(({key, backend}) => backend.constructor.name === 'LevelDatastore').map(({key, backend}) => ({\n name: key,\n store: backend\n }));\n onProgress(0, `Migrating ${ datastores.length } dbs`);\n let migrated = 0;\n const progress = message => {\n onProgress(Math.round(migrated / datastores.length * 100), message);\n };\n for (const {name, store} of datastores) {\n await store.open();\n try {\n await fn(name, store, progress);\n } finally {\n migrated++;\n await store.close();\n }\n }\n onProgress(100, `Migrated ${ datastores.length } dbs`);\n}\nconst migration = {\n version: 10,\n description: 'Migrates datastore-level keys to binary',\n migrate: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, keysToBinary);\n },\n revert: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, keysToStrings);\n }\n};\nfunction withEach(db, fn) {\n function batch(operations, next) {\n const store = db.store('readwrite');\n const transaction = store.transaction;\n let index = 0;\n let error;\n transaction.onabort = () => next(error || transaction.error || new Error('aborted by user'));\n transaction.oncomplete = () => next();\n function loop() {\n const op = operations[index++];\n const key = op.key;\n let req;\n try {\n req = op.type === 'del' ? store.delete(key) : store.put(op.value, key);\n } catch (err) {\n error = err;\n transaction.abort();\n return;\n }\n if (index < operations.length) {\n req.onsuccess = loop;\n }\n }\n loop();\n }\n return new Promise((resolve, reject) => {\n const it = db.iterator();\n const id = data => data;\n it._deserializeKey = it._deserializeValue = id;\n next();\n function next() {\n const handleNext = (err, key, value) => {\n if (err || key === undefined) {\n const handleEnd = err2 => {\n if (err2) {\n reject(err2);\n return;\n }\n resolve();\n };\n it.end(handleEnd);\n return;\n }\n batch(fn(key, value), next);\n };\n it.next(handleNext);\n }\n });\n}\n\nexports.migration = migration;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar errors = require('datastore-core/errors');\n\nconst CONFIG_KEY = new key.Key('/config');\nconst VERSION_KEY = new key.Key('/version');\nfunction findLevelJs(store) {\n let db = store;\n while (db.db || db.child) {\n db = db.db || db.child;\n if (db.type === 'level-js' || db.constructor.name === 'Level') {\n return db;\n }\n }\n}\nasync function hasWithFallback(key, has, store) {\n const result = await has(key);\n if (result) {\n return result;\n }\n const levelJs = findLevelJs(store);\n if (!levelJs) {\n return false;\n }\n return new Promise((resolve, reject) => {\n const req = levelJs.store('readonly').get(key.toString());\n req.transaction.onabort = () => {\n reject(req.transaction.error);\n };\n req.transaction.oncomplete = () => {\n resolve(Boolean(req.result));\n };\n });\n}\nasync function getWithFallback(key, get, has, store) {\n if (await has(key)) {\n return get(key);\n }\n const levelJs = findLevelJs(store);\n if (!levelJs) {\n throw errors.notFoundError();\n }\n return new Promise((resolve, reject) => {\n const req = levelJs.store('readonly').get(key.toString());\n req.transaction.onabort = () => {\n reject(req.transaction.error);\n };\n req.transaction.oncomplete = () => {\n if (req.result) {\n return resolve(req.result);\n }\n reject(errors.notFoundError());\n };\n });\n}\nfunction wrapStore(store) {\n const originalGet = store.get.bind(store);\n const originalHas = store.has.bind(store);\n store.get = key => getWithFallback(key, originalGet, originalHas, store);\n store.has = key => hasWithFallback(key, originalHas, store);\n return store;\n}\nfunction wrapBackends(backends) {\n return {\n ...backends,\n root: wrapStore(backends.root),\n datastore: wrapStore(backends.datastore),\n pins: wrapStore(backends.pins),\n keys: wrapStore(backends.keys)\n };\n}\n\nexports.CONFIG_KEY = CONFIG_KEY;\nexports.VERSION_KEY = VERSION_KEY;\nexports.findLevelJs = findLevelJs;\nexports.hasWithFallback = hasWithFallback;\nexports.wrapBackends = wrapBackends;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\n\nconst MFS_ROOT_KEY = new key.Key('/local/filesroot');\nasync function storeMfsRootInDatastore(backends, onProgress = () => {\n}) {\n onProgress(100, 'Migrating MFS root to repo datastore');\n await backends.root.open();\n await backends.datastore.open();\n if (await backends.root.has(MFS_ROOT_KEY)) {\n const root = await backends.root.get(MFS_ROOT_KEY);\n await backends.datastore.put(MFS_ROOT_KEY, root);\n await backends.root.delete(MFS_ROOT_KEY);\n }\n await backends.datastore.close();\n await backends.root.close();\n onProgress(100, 'Stored MFS root in repo datastore');\n}\nasync function storeMfsRootInRoot(backends, onProgress = () => {\n}) {\n onProgress(100, 'Migrating MFS root to repo root datastore');\n await backends.root.open();\n await backends.datastore.open();\n if (await backends.datastore.has(MFS_ROOT_KEY)) {\n const root = await backends.datastore.get(MFS_ROOT_KEY);\n await backends.root.put(MFS_ROOT_KEY, root);\n await backends.datastore.delete(MFS_ROOT_KEY);\n }\n await backends.datastore.close();\n await backends.root.close();\n onProgress(100, 'Stored MFS root in repo root datastore');\n}\nconst migration = {\n version: 11,\n description: 'Store mfs root in the datastore',\n migrate: storeMfsRootInDatastore,\n revert: storeMfsRootInRoot\n};\n\nexports.migration = migration;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar init = require('./init.js');\nvar errors = require('../errors.js');\nvar utils = require('../utils.js');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\n\nasync function getVersion(backends) {\n if (!await init.isRepoInitialized(backends)) {\n throw new errors.NotInitializedRepoError('Repo is not initialized!');\n }\n const store = backends.root;\n await store.open();\n try {\n return parseInt(toString.toString(await store.get(utils.VERSION_KEY)));\n } finally {\n await store.close();\n }\n}\nasync function setVersion(version, backends) {\n if (!backends) {\n throw new errors.MissingRepoOptionsError('Please pass repo options when trying to open a repo');\n }\n const store = backends.root;\n await store.open();\n await store.put(utils.VERSION_KEY, fromString.fromString(String(version)));\n await store.close();\n}\n\nexports.getVersion = getVersion;\nexports.setVersion = setVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar utils = require('../utils.js');\nvar errors = require('../errors.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:migrator:repo:init');\nasync function isRepoInitialized(backends) {\n if (!backends) {\n throw new errors.MissingRepoOptionsError('Please pass repo options when trying to open a repo');\n }\n const root = backends.root;\n try {\n await root.open();\n const versionCheck = await root.has(utils.VERSION_KEY);\n const configCheck = await root.has(utils.CONFIG_KEY);\n if (!versionCheck || !configCheck) {\n log(`Version entry present: ${ versionCheck }`);\n log(`Config entry present: ${ configCheck }`);\n return false;\n }\n return true;\n } catch (e) {\n log('While checking if repo is initialized error was thrown: ' + e.message);\n return false;\n } finally {\n if (root !== undefined) {\n try {\n await root.close();\n } catch {\n }\n }\n }\n}\n\nexports.isRepoInitialized = isRepoInitialized;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass NonReversibleMigrationError extends Error {\n constructor(message) {\n super(message);\n this.name = 'NonReversibleMigrationError';\n this.code = NonReversibleMigrationError.code;\n this.message = message;\n }\n}\nNonReversibleMigrationError.code = 'ERR_NON_REVERSIBLE_MIGRATION';\nclass NotInitializedRepoError extends Error {\n constructor(message) {\n super(message);\n this.name = 'NotInitializedRepoError';\n this.code = NotInitializedRepoError.code;\n this.message = message;\n }\n}\nNotInitializedRepoError.code = 'ERR_NOT_INITIALIZED_REPO';\nclass RequiredParameterError extends Error {\n constructor(message) {\n super(message);\n this.name = 'RequiredParameterError';\n this.code = RequiredParameterError.code;\n this.message = message;\n }\n}\nRequiredParameterError.code = 'ERR_REQUIRED_PARAMETER';\nclass InvalidValueError extends Error {\n constructor(message) {\n super(message);\n this.name = 'InvalidValueError';\n this.code = InvalidValueError.code;\n this.message = message;\n }\n}\nInvalidValueError.code = 'ERR_INVALID_VALUE';\nclass MissingRepoOptionsError extends Error {\n constructor(message) {\n super(message);\n this.name = 'MissingRepoOptionsError';\n this.code = MissingRepoOptionsError.code;\n this.message = message;\n }\n}\nMissingRepoOptionsError.code = 'ERR_MISSING_REPO_OPTIONS';\n\nexports.InvalidValueError = InvalidValueError;\nexports.MissingRepoOptionsError = MissingRepoOptionsError;\nexports.NonReversibleMigrationError = NonReversibleMigrationError;\nexports.NotInitializedRepoError = NotInitializedRepoError;\nexports.RequiredParameterError = RequiredParameterError;\n","/*!\n * bytes\n * Copyright(c) 2012-2014 TJ Holowaychuk\n * Copyright(c) 2015 Jed Watson\n * MIT Licensed\n */\n\n'use strict';\n\n/**\n * Module exports.\n * @public\n */\n\nmodule.exports = bytes;\nmodule.exports.format = format;\nmodule.exports.parse = parse;\n\n/**\n * Module variables.\n * @private\n */\n\nvar formatThousandsRegExp = /\\B(?=(\\d{3})+(?!\\d))/g;\n\nvar formatDecimalsRegExp = /(?:\\.0*|(\\.[^0]+)0+)$/;\n\nvar map = {\n b: 1,\n kb: 1 << 10,\n mb: 1 << 20,\n gb: 1 << 30,\n tb: Math.pow(1024, 4),\n pb: Math.pow(1024, 5),\n};\n\nvar parseRegExp = /^((-|\\+)?(\\d+(?:\\.\\d+)?)) *(kb|mb|gb|tb|pb)$/i;\n\n/**\n * Convert the given value in bytes into a string or parse to string to an integer in bytes.\n *\n * @param {string|number} value\n * @param {{\n * case: [string],\n * decimalPlaces: [number]\n * fixedDecimals: [boolean]\n * thousandsSeparator: [string]\n * unitSeparator: [string]\n * }} [options] bytes options.\n *\n * @returns {string|number|null}\n */\n\nfunction bytes(value, options) {\n if (typeof value === 'string') {\n return parse(value);\n }\n\n if (typeof value === 'number') {\n return format(value, options);\n }\n\n return null;\n}\n\n/**\n * Format the given value in bytes into a string.\n *\n * If the value is negative, it is kept as such. If it is a float,\n * it is rounded.\n *\n * @param {number} value\n * @param {object} [options]\n * @param {number} [options.decimalPlaces=2]\n * @param {number} [options.fixedDecimals=false]\n * @param {string} [options.thousandsSeparator=]\n * @param {string} [options.unit=]\n * @param {string} [options.unitSeparator=]\n *\n * @returns {string|null}\n * @public\n */\n\nfunction format(value, options) {\n if (!Number.isFinite(value)) {\n return null;\n }\n\n var mag = Math.abs(value);\n var thousandsSeparator = (options && options.thousandsSeparator) || '';\n var unitSeparator = (options && options.unitSeparator) || '';\n var decimalPlaces = (options && options.decimalPlaces !== undefined) ? options.decimalPlaces : 2;\n var fixedDecimals = Boolean(options && options.fixedDecimals);\n var unit = (options && options.unit) || '';\n\n if (!unit || !map[unit.toLowerCase()]) {\n if (mag >= map.pb) {\n unit = 'PB';\n } else if (mag >= map.tb) {\n unit = 'TB';\n } else if (mag >= map.gb) {\n unit = 'GB';\n } else if (mag >= map.mb) {\n unit = 'MB';\n } else if (mag >= map.kb) {\n unit = 'KB';\n } else {\n unit = 'B';\n }\n }\n\n var val = value / map[unit.toLowerCase()];\n var str = val.toFixed(decimalPlaces);\n\n if (!fixedDecimals) {\n str = str.replace(formatDecimalsRegExp, '$1');\n }\n\n if (thousandsSeparator) {\n str = str.split('.').map(function (s, i) {\n return i === 0\n ? s.replace(formatThousandsRegExp, thousandsSeparator)\n : s\n }).join('.');\n }\n\n return str + unitSeparator + unit;\n}\n\n/**\n * Parse the string value into an integer in bytes.\n *\n * If no unit is given, it is assumed the value is in bytes.\n *\n * @param {number|string} val\n *\n * @returns {number|null}\n * @public\n */\n\nfunction parse(val) {\n if (typeof val === 'number' && !isNaN(val)) {\n return val;\n }\n\n if (typeof val !== 'string') {\n return null;\n }\n\n // Test if the string passed is valid\n var results = parseRegExp.exec(val);\n var floatValue;\n var unit = 'b';\n\n if (!results) {\n // Nothing could be extracted from the given string\n floatValue = parseInt(val, 10);\n unit = 'b'\n } else {\n // Retrieve the value and the unit\n floatValue = parseFloat(results[1]);\n unit = results[4].toLowerCase();\n }\n\n return Math.floor(map[unit] * floatValue);\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar debug = require('debug');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\nvar level = require('./utils/level.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:version');\nconst versionKey = new key.Key('version');\nfunction version(store) {\n return {\n async exists() {\n return level.hasWithFallback(versionKey, store.has.bind(store), store);\n },\n async get() {\n const buf = await level.getWithFallback(versionKey, store.get.bind(store), store.has.bind(store), store);\n return parseInt(toString.toString(buf), 10);\n },\n set(version) {\n return store.put(versionKey, fromString.fromString(String(version)));\n },\n async check(expected) {\n const version = await this.get();\n log('comparing version: %s and %s', version, expected);\n const compatibleVersion = version === 6 && expected === 7 || expected === 6 && version === 7;\n return version === expected || compatibleVersion;\n }\n };\n}\n\nexports.version = version;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('../errors.js');\n\nasync function hasWithFallback(key, has, store) {\n const result = await has(key);\n if (result) {\n return result;\n }\n const levelJs = findLevelJs(store);\n if (!levelJs) {\n return false;\n }\n return new Promise((resolve, reject) => {\n const req = levelJs.store('readonly').get(key.toString());\n req.transaction.onabort = () => {\n reject(req.transaction.error);\n };\n req.transaction.oncomplete = () => {\n resolve(Boolean(req.result));\n };\n });\n}\nasync function getWithFallback(key, get, has, store) {\n if (await has(key)) {\n return get(key);\n }\n const levelJs = findLevelJs(store);\n if (!levelJs) {\n throw new errors.NotFoundError();\n }\n return new Promise((resolve, reject) => {\n const req = levelJs.store('readonly').get(key.toString());\n req.transaction.onabort = () => {\n reject(req.transaction.error);\n };\n req.transaction.oncomplete = () => {\n if (req.result) {\n return resolve(req.result);\n }\n reject(new errors.NotFoundError());\n };\n });\n}\nfunction findLevelJs(store) {\n let db = store;\n while (db.db || db.child) {\n db = db.db || db.child;\n if (db.type === 'level-js' || db.constructor.name === 'Level') {\n return db;\n }\n }\n}\n\nexports.getWithFallback = getWithFallback;\nexports.hasWithFallback = hasWithFallback;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass LockExistsError extends Error {\n constructor(message) {\n super(message);\n this.name = 'LockExistsError';\n this.code = LockExistsError.code;\n }\n}\nLockExistsError.code = 'ERR_LOCK_EXISTS';\nclass NotFoundError extends Error {\n constructor(message) {\n super(message);\n this.name = 'NotFoundError';\n this.code = NotFoundError.code;\n }\n}\nNotFoundError.code = 'ERR_NOT_FOUND';\nclass InvalidRepoVersionError extends Error {\n constructor(message) {\n super(message);\n this.name = 'InvalidRepoVersionError';\n this.code = InvalidRepoVersionError.code;\n }\n}\nInvalidRepoVersionError.code = 'ERR_INVALID_REPO_VERSION';\nconst ERR_REPO_NOT_INITIALIZED = 'ERR_REPO_NOT_INITIALIZED';\nconst ERR_REPO_ALREADY_OPEN = 'ERR_REPO_ALREADY_OPEN';\nconst ERR_REPO_ALREADY_CLOSED = 'ERR_REPO_ALREADY_CLOSED';\n\nexports.ERR_REPO_ALREADY_CLOSED = ERR_REPO_ALREADY_CLOSED;\nexports.ERR_REPO_ALREADY_OPEN = ERR_REPO_ALREADY_OPEN;\nexports.ERR_REPO_NOT_INITIALIZED = ERR_REPO_NOT_INITIALIZED;\nexports.InvalidRepoVersionError = InvalidRepoVersionError;\nexports.LockExistsError = LockExistsError;\nexports.NotFoundError = NotFoundError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar PQueue = require('p-queue');\nvar _get = require('just-safe-get');\nvar _set = require('just-safe-set');\nvar errCode = require('err-code');\nvar errors = require('./errors.js');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\nvar level = require('./utils/level.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PQueue__default = /*#__PURE__*/_interopDefaultLegacy(PQueue);\nvar _get__default = /*#__PURE__*/_interopDefaultLegacy(_get);\nvar _set__default = /*#__PURE__*/_interopDefaultLegacy(_set);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst Queue = PQueue__default[\"default\"].default ? PQueue__default[\"default\"].default : PQueue__default[\"default\"];\nconst configKey = new key.Key('config');\nfunction config(store) {\n const setQueue = new Queue({ concurrency: 1 });\n const configStore = {\n async getAll(options = {}) {\n const encodedValue = await level.getWithFallback(configKey, store.get.bind(store), store.has.bind(store), store);\n return JSON.parse(toString.toString(encodedValue));\n },\n async get(key, options = {}) {\n if (key == null) {\n throw new errors.NotFoundError(`Key ${ key } does not exist in config`);\n }\n const config = await this.getAll(options);\n const value = _get__default[\"default\"](config, key);\n if (value === undefined) {\n throw new errors.NotFoundError(`Key ${ key } does not exist in config`);\n }\n return value;\n },\n set(key, value, options = {}) {\n if (typeof key !== 'string' && !(key instanceof String)) {\n throw errCode__default[\"default\"](new Error('Invalid key type: ' + typeof key), 'ERR_INVALID_KEY');\n }\n if (value === undefined || value instanceof Uint8Array) {\n throw errCode__default[\"default\"](new Error('Invalid value type: ' + typeof value), 'ERR_INVALID_VALUE');\n }\n return setQueue.add(() => _maybeDoSet({\n key: key,\n value: value\n }, options.signal));\n },\n replace(value, options = {}) {\n if (!value || value instanceof Uint8Array) {\n throw errCode__default[\"default\"](new Error('Invalid value type: ' + typeof value), 'ERR_INVALID_VALUE');\n }\n return setQueue.add(() => _maybeDoSet({\n key: undefined,\n value: value\n }, options.signal));\n },\n async exists() {\n return level.hasWithFallback(configKey, store.has.bind(store), store);\n }\n };\n return configStore;\n async function _maybeDoSet(m, signal) {\n if (signal && signal.aborted) {\n return;\n }\n const key = m.key;\n const value = m.value;\n if (key) {\n const config = await configStore.getAll();\n if (typeof config === 'object' && config !== null) {\n _set__default[\"default\"](config, key, value);\n }\n return _saveAll(config);\n }\n return _saveAll(value);\n }\n function _saveAll(config) {\n const buf = fromString.fromString(JSON.stringify(config, null, 2));\n return store.put(configKey, buf);\n }\n}\n\nexports.config = config;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar sortKeys = require('sort-keys');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar sortKeys__default = /*#__PURE__*/_interopDefaultLegacy(sortKeys);\n\nconst specKey = new interfaceDatastore.Key('datastore_spec');\nfunction spec(store) {\n return {\n exists() {\n return store.has(specKey);\n },\n async get() {\n const buf = await store.get(specKey);\n return JSON.parse(toString.toString(buf));\n },\n async set(spec) {\n return store.put(specKey, fromString.fromString(JSON.stringify(sortKeys__default[\"default\"](spec, { deep: true }))));\n }\n };\n}\n\nexports.spec = spec;\n","'use strict';\nconst isPlainObject = require('is-plain-obj');\n\nmodule.exports = (object, options = {}) => {\n\tif (!isPlainObject(object) && !Array.isArray(object)) {\n\t\tthrow new TypeError('Expected a plain object or array');\n\t}\n\n\tconst {deep} = options;\n\tconst seenInput = [];\n\tconst seenOutput = [];\n\n\tconst deepSortArray = array => {\n\t\tconst seenIndex = seenInput.indexOf(array);\n\n\t\tif (seenIndex !== -1) {\n\t\t\treturn seenOutput[seenIndex];\n\t\t}\n\n\t\tconst result = [];\n\t\tseenInput.push(array);\n\t\tseenOutput.push(result);\n\n\t\tresult.push(...array.map(item => {\n\t\t\tif (Array.isArray(item)) {\n\t\t\t\treturn deepSortArray(item);\n\t\t\t}\n\n\t\t\tif (isPlainObject(item)) {\n\t\t\t\treturn sortKeys(item);\n\t\t\t}\n\n\t\t\treturn item;\n\t\t}));\n\n\t\treturn result;\n\t};\n\n\tconst sortKeys = object => {\n\t\tconst seenIndex = seenInput.indexOf(object);\n\n\t\tif (seenIndex !== -1) {\n\t\t\treturn seenOutput[seenIndex];\n\t\t}\n\n\t\tconst result = {};\n\t\tconst keys = Object.keys(object).sort(options.compare);\n\n\t\tseenInput.push(object);\n\t\tseenOutput.push(result);\n\n\t\tfor (const key of keys) {\n\t\t\tconst value = object[key];\n\t\t\tlet newValue;\n\n\t\t\tif (deep && Array.isArray(value)) {\n\t\t\t\tnewValue = deepSortArray(value);\n\t\t\t} else {\n\t\t\t\tnewValue = deep && isPlainObject(value) ? sortKeys(value) : value;\n\t\t\t}\n\n\t\t\tObject.defineProperty(result, key, {\n\t\t\t\t...Object.getOwnPropertyDescriptor(object, key),\n\t\t\t\tvalue: newValue\n\t\t\t});\n\t\t}\n\n\t\treturn result;\n\t};\n\n\tif (Array.isArray(object)) {\n\t\treturn deep ? deepSortArray(object) : object.slice();\n\t}\n\n\treturn sortKeys(object);\n};\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar fromString = require('uint8arrays/from-string');\n\nconst apiFile = new key.Key('api');\nfunction apiAddr(store) {\n return {\n async get() {\n const value = await store.get(apiFile);\n return value && value.toString();\n },\n set(value) {\n return store.put(apiFile, fromString.fromString(value.toString()));\n },\n delete() {\n return store.delete(apiFile);\n }\n };\n}\n\nexports.apiAddr = apiAddr;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar filter = require('it-filter');\nvar pushable = require('it-pushable');\nvar drain = require('it-drain');\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\nvar identity = require('multiformats/hashes/identity');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar pushable__default = /*#__PURE__*/_interopDefaultLegacy(pushable);\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction createIdStore(store) {\n return {\n open() {\n return store.open();\n },\n close() {\n return store.close();\n },\n query(query, options) {\n return store.query(query, options);\n },\n queryKeys(query, options) {\n return store.queryKeys(query, options);\n },\n async get(cid, options) {\n const extracted = extractContents(cid);\n if (extracted.isIdentity) {\n return Promise.resolve(extracted.digest);\n }\n return store.get(cid, options);\n },\n async *getMany(cids, options) {\n for await (const cid of cids) {\n yield this.get(cid, options);\n }\n },\n async put(cid, buf, options) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return;\n }\n await store.put(cid, buf, options);\n },\n async *putMany(pairs, options) {\n const output = pushable__default[\"default\"]();\n const runner = globalThis.process && globalThis.process.nextTick ? globalThis.process.nextTick : globalThis.setImmediate || globalThis.setTimeout;\n runner(async () => {\n try {\n await drain__default[\"default\"](store.putMany(async function* () {\n for await (const {key, value} of pairs) {\n if (!extractContents(key).isIdentity) {\n yield {\n key,\n value\n };\n }\n output.push({\n key,\n value\n });\n }\n }()));\n output.end();\n } catch (err) {\n output.end(err);\n }\n });\n yield* output;\n },\n has(cid, options) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return Promise.resolve(true);\n }\n return store.has(cid, options);\n },\n delete(cid, options) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return Promise.resolve();\n }\n return store.delete(cid, options);\n },\n deleteMany(cids, options) {\n return store.deleteMany(filter__default[\"default\"](cids, cid => !extractContents(cid).isIdentity), options);\n },\n batch() {\n const batch = store.batch();\n return {\n put(cid, buf) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return;\n }\n batch.put(cid, buf);\n },\n delete(cid) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return;\n }\n batch.delete(cid);\n },\n commit: options => {\n return batch.commit(options);\n }\n };\n }\n };\n}\nfunction extractContents(k) {\n const cid$1 = cid.CID.asCID(k);\n if (cid$1 == null) {\n throw errCode__default[\"default\"](new Error('Not a valid cid'), 'ERR_INVALID_CID');\n }\n if (cid$1.multihash.code !== identity.identity.code) {\n return { isIdentity: false };\n }\n return {\n isIdentity: true,\n digest: cid$1.multihash.digest\n };\n}\n\nexports.createIdStore = createIdStore;\n","'use strict';\n\nvar memory = require('./locks/memory.js');\n\nvar defaultOptions = {\n autoMigrate: true,\n onMigrationProgress: () => {\n },\n repoOwner: true,\n repoLock: memory.MemoryLock\n};\n\nmodule.exports = defaultOptions;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('../errors.js');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:lock:memory');\nconst lockFile = 'repo.lock';\nconst LOCKS = {};\nasync function lock(dir) {\n const file = dir + '/' + lockFile;\n log('locking %s', file);\n if (LOCKS[file] === true) {\n throw new errors.LockExistsError(`Lock already being held for file: ${ file }`);\n }\n LOCKS[file] = true;\n const closer = {\n async close() {\n if (LOCKS[file]) {\n delete LOCKS[file];\n }\n }\n };\n return closer;\n}\nasync function locked(dir) {\n const file = dir + '/' + lockFile;\n log(`checking lock: ${ file }`);\n return Boolean(LOCKS[file]);\n}\nconst MemoryLock = {\n lock,\n locked\n};\n\nexports.MemoryLock = MemoryLock;\n","'use strict';\n\nvar defaultDatastore = {\n Spec: {\n type: 'mount',\n mounts: [\n {\n mountpoint: '/blocks',\n type: 'measure',\n prefix: 'flatfs.datastore',\n child: {\n type: 'flatfs',\n path: 'blocks',\n sync: true,\n shardFunc: '/repo/flatfs/shard/v1/next-to-last/2'\n }\n },\n {\n mountpoint: '/',\n type: 'measure',\n prefix: 'leveldb.datastore',\n child: {\n type: 'levelds',\n path: 'datastore',\n compression: 'none'\n }\n }\n ]\n }\n};\n\nmodule.exports = defaultDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar first = require('it-first');\nvar block = require('multiformats/block');\nvar cborg = require('cborg');\nvar dagPb = require('@ipld/dag-pb');\nvar blockstore = require('./utils/blockstore.js');\nvar walkDag = require('./utils/walk-dag.js');\nvar pinTypes = require('./pin-types.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar first__default = /*#__PURE__*/_interopDefaultLegacy(first);\nvar cborg__namespace = /*#__PURE__*/_interopNamespace(cborg);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\n\nfunction invalidPinTypeErr(type) {\n const errMsg = `Invalid type '${ type }', must be one of {direct, indirect, recursive, all}`;\n return errCode__default[\"default\"](new Error(errMsg), 'ERR_INVALID_PIN_TYPE');\n}\nclass PinManager {\n constructor({pinstore, blockstore, loadCodec}) {\n this.pinstore = pinstore;\n this.blockstore = blockstore;\n this.loadCodec = loadCodec;\n this.log = debug__default[\"default\"]('ipfs:repo:pin');\n this.directPins = new Set();\n this.recursivePins = new Set();\n }\n async pinDirectly(cid, options = {}) {\n await this.blockstore.get(cid, options);\n const pin = { depth: 0 };\n if (cid.version !== 0) {\n pin.version = cid.version;\n }\n if (cid.code !== dagPb__namespace.code) {\n pin.codec = cid.code;\n }\n if (options.metadata) {\n pin.metadata = options.metadata;\n }\n return this.pinstore.put(blockstore.cidToKey(cid), cborg__namespace.encode(pin));\n }\n unpin(cid, options) {\n return this.pinstore.delete(blockstore.cidToKey(cid), options);\n }\n async pinRecursively(cid, options = {}) {\n await this.fetchCompleteDag(cid, options);\n const pin = { depth: Infinity };\n if (cid.version !== 0) {\n pin.version = cid.version;\n }\n if (cid.code !== dagPb__namespace.code) {\n pin.codec = cid.code;\n }\n if (options.metadata) {\n pin.metadata = options.metadata;\n }\n await this.pinstore.put(blockstore.cidToKey(cid), cborg__namespace.encode(pin));\n }\n async *directKeys(options) {\n for await (const entry of this.pinstore.query({\n filters: [entry => {\n const pin = cborg__namespace.decode(entry.value);\n return pin.depth === 0;\n }]\n })) {\n const pin = cborg__namespace.decode(entry.value);\n const version = pin.version || 0;\n const codec = pin.codec != null ? pin.codec : dagPb__namespace.code;\n const multihash = blockstore.keyToMultihash(entry.key);\n yield {\n cid: cid.CID.create(version, codec, multihash),\n metadata: pin.metadata\n };\n }\n }\n async *recursiveKeys(options) {\n for await (const entry of this.pinstore.query({\n filters: [entry => {\n const pin = cborg__namespace.decode(entry.value);\n return pin.depth === Infinity;\n }]\n })) {\n const pin = cborg__namespace.decode(entry.value);\n const version = pin.version || 0;\n const codec = pin.codec != null ? pin.codec : dagPb__namespace.code;\n const multihash = blockstore.keyToMultihash(entry.key);\n yield {\n cid: cid.CID.create(version, codec, multihash),\n metadata: pin.metadata\n };\n }\n }\n async *indirectKeys(options) {\n for await (const {cid} of this.recursiveKeys()) {\n for await (const childCid of walkDag.walkDag(cid, this.blockstore, this.loadCodec, options)) {\n const types = [pinTypes.PinTypes.recursive];\n const result = await this.isPinnedWithType(childCid, types);\n if (result.pinned) {\n continue;\n }\n yield childCid;\n }\n }\n }\n async isPinnedWithType(cid, types, options) {\n if (!Array.isArray(types)) {\n types = [types];\n }\n const all = types.includes(pinTypes.PinTypes.all);\n const direct = types.includes(pinTypes.PinTypes.direct);\n const recursive = types.includes(pinTypes.PinTypes.recursive);\n const indirect = types.includes(pinTypes.PinTypes.indirect);\n if (recursive || direct || all) {\n const result = await first__default[\"default\"](this.pinstore.query({\n prefix: blockstore.cidToKey(cid).toString(),\n filters: [entry => {\n if (all) {\n return true;\n }\n const pin = cborg__namespace.decode(entry.value);\n return types.includes(pin.depth === 0 ? pinTypes.PinTypes.direct : pinTypes.PinTypes.recursive);\n }],\n limit: 1\n }));\n if (result) {\n const pin = cborg__namespace.decode(result.value);\n return {\n cid,\n pinned: true,\n reason: pin.depth === 0 ? pinTypes.PinTypes.direct : pinTypes.PinTypes.recursive,\n metadata: pin.metadata\n };\n }\n }\n const self = this;\n async function* findChild(key, source) {\n for await (const {cid: parentCid} of source) {\n for await (const childCid of walkDag.walkDag(parentCid, self.blockstore, self.loadCodec)) {\n if (childCid.equals(key)) {\n yield parentCid;\n return;\n }\n }\n }\n }\n if (all || indirect) {\n const parentCid = await first__default[\"default\"](findChild(cid, this.recursiveKeys()));\n if (parentCid) {\n return {\n cid,\n pinned: true,\n reason: pinTypes.PinTypes.indirect,\n parent: parentCid\n };\n }\n }\n return {\n cid,\n pinned: false\n };\n }\n async fetchCompleteDag(cid, options) {\n const seen = new Set();\n const walkDag = async (cid, options) => {\n if (seen.has(cid.toString())) {\n return;\n }\n seen.add(cid.toString());\n const bytes = await this.blockstore.get(cid, options);\n const codec = await this.loadCodec(cid.code);\n const block$1 = block.createUnsafe({\n bytes,\n cid,\n codec\n });\n await Promise.all([...block$1.links()].map(([, childCid]) => walkDag(childCid, options)));\n };\n await walkDag(cid, options);\n }\n static checkPinType(type) {\n if (typeof type !== 'string' || !Object.keys(pinTypes.PinTypes).includes(type)) {\n throw invalidPinTypeErr(type);\n }\n return true;\n }\n}\n\nexports.PinManager = PinManager;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar multiformats = require('multiformats');\nvar raw = require('multiformats/codecs/raw');\nvar errCode = require('err-code');\nvar base32 = require('multiformats/bases/base32');\nvar Digest = require('multiformats/hashes/digest');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\n\nfunction cidToKey(c) {\n const cid = multiformats.CID.asCID(c);\n if (cid == null) {\n throw errCode__default[\"default\"](new Error('Not a valid cid'), 'ERR_INVALID_CID');\n }\n const encoded = base32.base32.encode(cid.multihash.bytes);\n return new key.Key('/' + encoded.slice(1).toUpperCase(), false);\n}\nfunction keyToCid(key) {\n return multiformats.CID.createV1(raw__namespace.code, keyToMultihash(key));\n}\nfunction keyToMultihash(key) {\n return Digest__namespace.decode(base32.base32.decode(`b${ key.toString().toLowerCase().substring(1) }`));\n}\n\nexports.cidToKey = cidToKey;\nexports.keyToCid = keyToCid;\nexports.keyToMultihash = keyToMultihash;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar block = require('multiformats/block');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:utils:walk-dag');\nasync function* walkDag(cid, blockstore, loadCodec, options) {\n try {\n const bytes = await blockstore.get(cid, options);\n const codec = await loadCodec(cid.code);\n const block$1 = block.createUnsafe({\n bytes,\n cid,\n codec\n });\n for (const [, childCid] of block$1.links()) {\n yield childCid;\n yield* walkDag(childCid, blockstore, loadCodec, options);\n }\n } catch (err) {\n log('Could not walk DAG for CID', cid.toString(), err);\n throw err;\n }\n}\n\nexports.walkDag = walkDag;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar map = require('it-map');\nvar errCode = require('err-code');\nvar pinTypes = require('./pin-types.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction createPinnedBlockstore(pins, store) {\n return {\n open() {\n return store.open();\n },\n close() {\n return store.close();\n },\n query(query, options) {\n return store.query(query, options);\n },\n queryKeys(query, options) {\n return store.queryKeys(query, options);\n },\n async get(cid, options) {\n return store.get(cid, options);\n },\n async *getMany(cids, options) {\n yield* store.getMany(cids, options);\n },\n async put(cid, buf, options) {\n await store.put(cid, buf, options);\n },\n async *putMany(pairs, options) {\n yield* store.putMany(pairs, options);\n },\n has(cid, options) {\n return store.has(cid, options);\n },\n async delete(cid, options) {\n await ensureNotPinned(cid, pins);\n return store.delete(cid, options);\n },\n deleteMany(cids, options) {\n return store.deleteMany(map__default[\"default\"](cids, async cid => {\n await ensureNotPinned(cid, pins);\n return cid;\n }), options);\n },\n batch() {\n return store.batch();\n }\n };\n}\nasync function ensureNotPinned(cid, pins) {\n const {pinned, reason} = await pins.isPinnedWithType(cid, pinTypes.PinTypes.all);\n if (pinned) {\n throw errCode__default[\"default\"](new Error(`pinned: ${ reason }`), 'ERR_BLOCK_PINNED');\n }\n}\n\nexports.createPinnedBlockstore = createPinnedBlockstore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar debug = require('debug');\nvar errors = require('datastore-core/errors');\nvar parallelBatch = require('it-parallel-batch');\nvar itPipe = require('it-pipe');\nvar merge = require('it-merge');\nvar map = require('it-map');\nvar filter = require('it-filter');\nvar key = require('interface-datastore/key');\nvar base32 = require('multiformats/bases/base32');\nvar walkDag = require('./utils/walk-dag.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar parallelBatch__default = /*#__PURE__*/_interopDefaultLegacy(parallelBatch);\nvar merge__default = /*#__PURE__*/_interopDefaultLegacy(merge);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\n\nconst log = debug__default[\"default\"]('ipfs:repo:gc');\nconst ERR_NOT_FOUND = errors.notFoundError().code;\nconst BLOCK_RM_CONCURRENCY = 256;\nconst MFS_ROOT_KEY = new key.Key('/local/filesroot');\nfunction gc({gcLock, pins, blockstore, root, loadCodec}) {\n async function* gc() {\n const start = Date.now();\n log('Creating set of marked blocks');\n const release = await gcLock.writeLock();\n try {\n const markedSet = await createMarkedSet({\n pins,\n blockstore,\n root,\n loadCodec\n });\n const blockKeys = blockstore.queryKeys({});\n yield* deleteUnmarkedBlocks({ blockstore }, markedSet, blockKeys);\n log(`Complete (${ Date.now() - start }ms)`);\n } finally {\n release();\n }\n }\n return gc;\n}\nasync function createMarkedSet({pins, blockstore, loadCodec, root}) {\n const mfsSource = async function* () {\n let mh;\n try {\n mh = await root.get(MFS_ROOT_KEY);\n } catch (err) {\n if (err.code === ERR_NOT_FOUND) {\n log('No blocks in MFS');\n return;\n }\n throw err;\n }\n const rootCid = cid.CID.decode(mh);\n yield rootCid;\n yield* walkDag.walkDag(rootCid, blockstore, loadCodec);\n }();\n const pinsSource = merge__default[\"default\"](map__default[\"default\"](pins.recursiveKeys(), ({cid}) => cid), pins.indirectKeys(), map__default[\"default\"](pins.directKeys(), ({cid}) => cid), mfsSource);\n const output = new Set();\n for await (const cid of merge__default[\"default\"](pinsSource, mfsSource)) {\n output.add(base32.base32.encode(cid.multihash.bytes));\n }\n return output;\n}\nasync function* deleteUnmarkedBlocks({blockstore}, markedSet, blockKeys) {\n let blocksCount = 0;\n let removedBlocksCount = 0;\n const removeBlock = async cid => {\n return async function remove() {\n blocksCount++;\n try {\n const b32 = base32.base32.encode(cid.multihash.bytes);\n if (markedSet.has(b32)) {\n return null;\n }\n try {\n await blockstore.delete(cid);\n removedBlocksCount++;\n } catch (err) {\n return { err: new Error(`Could not delete block with CID ${ cid }: ${ err.message }`) };\n }\n return { cid };\n } catch (err) {\n const msg = `Could delete block with CID ${ cid }`;\n log(msg, err);\n return { err: new Error(msg + `: ${ err.message }`) };\n }\n };\n };\n yield* itPipe.pipe(parallelBatch__default[\"default\"](map__default[\"default\"](blockKeys, removeBlock), BLOCK_RM_CONCURRENCY), source => filter__default[\"default\"](source, Boolean));\n log(`Marked set has ${ markedSet.size } unique blocks. Blockstore has ${ blocksCount } blocks. ` + `Deleted ${ removedBlocksCount } blocks.`);\n}\n\nexports.gc = gc;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar datastoreCore = require('datastore-core');\nvar filter = require('it-filter');\nvar map = require('it-map');\nvar take = require('it-take');\nvar sort = require('it-sort');\nvar Level = require('level');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar take__default = /*#__PURE__*/_interopDefaultLegacy(take);\nvar sort__default = /*#__PURE__*/_interopDefaultLegacy(sort);\nvar Level__default = /*#__PURE__*/_interopDefaultLegacy(Level);\n\nclass LevelDatastore extends datastoreCore.BaseDatastore {\n constructor(path, opts) {\n super();\n this.path = path;\n this.opts = opts;\n if (opts && opts.db) {\n this.database = opts.db;\n delete opts.db;\n } else {\n this.database = Level__default['default'];\n }\n }\n _initDb() {\n return new Promise((resolve, reject) => {\n this.db = this.database(this.path, {\n ...this.opts,\n valueEncoding: 'binary',\n compression: false\n }, err => {\n if (err) {\n return reject(err);\n }\n resolve(this.db);\n });\n });\n }\n async open() {\n try {\n if (this.db) {\n await this.db.open();\n } else {\n this.db = await this._initDb();\n }\n } catch (err) {\n throw datastoreCore.Errors.dbOpenFailedError(err);\n }\n }\n async put(key, value) {\n try {\n await this.db.put(key.toString(), value);\n } catch (err) {\n throw datastoreCore.Errors.dbWriteFailedError(err);\n }\n }\n async get(key) {\n let data;\n try {\n data = await this.db.get(key.toString());\n } catch (err) {\n if (err.notFound)\n throw datastoreCore.Errors.notFoundError(err);\n throw datastoreCore.Errors.dbWriteFailedError(err);\n }\n return data;\n }\n async has(key) {\n try {\n await this.db.get(key.toString());\n } catch (err) {\n if (err.notFound)\n return false;\n throw err;\n }\n return true;\n }\n async delete(key) {\n try {\n await this.db.del(key.toString());\n } catch (err) {\n throw datastoreCore.Errors.dbDeleteFailedError(err);\n }\n }\n close() {\n return this.db && this.db.close();\n }\n batch() {\n const ops = [];\n return {\n put: (key, value) => {\n ops.push({\n type: 'put',\n key: key.toString(),\n value: value\n });\n },\n delete: key => {\n ops.push({\n type: 'del',\n key: key.toString()\n });\n },\n commit: () => {\n return this.db.batch(ops);\n }\n };\n }\n query(q) {\n let it = this._query({\n values: true,\n prefix: q.prefix\n });\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => sort__default['default'](it, f), it);\n }\n const {offset, limit} = q;\n if (offset) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= offset);\n }\n if (limit) {\n it = take__default['default'](it, limit);\n }\n return it;\n }\n queryKeys(q) {\n let it = map__default['default'](this._query({\n values: false,\n prefix: q.prefix\n }), ({key}) => key);\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => sort__default['default'](it, f), it);\n }\n const {offset, limit} = q;\n if (offset) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= offset);\n }\n if (limit) {\n it = take__default['default'](it, limit);\n }\n return it;\n }\n _query(opts) {\n const iteratorOpts = {\n keys: true,\n keyAsBuffer: true,\n values: opts.values\n };\n if (opts.prefix != null) {\n const prefix = opts.prefix.toString();\n iteratorOpts.gte = prefix;\n iteratorOpts.lt = prefix + 'ÿ';\n }\n return levelIteratorToIterator(this.db.iterator(iteratorOpts));\n }\n}\nfunction levelIteratorToIterator(li) {\n return {\n [Symbol.asyncIterator]() {\n return {\n next: () => new Promise((resolve, reject) => {\n li.next((err, key, value) => {\n if (err)\n return reject(err);\n if (key == null) {\n return li.end(err => {\n if (err)\n return reject(err);\n resolve({\n done: true,\n value: undefined\n });\n });\n }\n resolve({\n done: false,\n value: {\n key: new interfaceDatastore.Key(key, false),\n value\n }\n });\n });\n }),\n return: () => new Promise((resolve, reject) => {\n li.end(err => {\n if (err)\n return reject(err);\n resolve({\n done: true,\n value: undefined\n });\n });\n })\n };\n }\n };\n}\n\nexports.LevelDatastore = LevelDatastore;\n","'use strict'\n\nconst all = require('it-all')\n\n/**\n * Collects all values from an async iterator, sorts them\n * using the passed function and yields them\n *\n * @template T\n * @param {AsyncIterable | Iterable} source\n * @param {(a: T, b: T) => -1 | 0 | 1} sorter\n */\nconst sort = async function * (source, sorter) {\n const arr = await all(source)\n\n yield * arr.sort(sorter)\n}\n\nmodule.exports = sort\n","module.exports = require('level-packager')(require('level-js'))\n","'use strict'\n\nconst levelup = require('levelup')\nconst encode = require('encoding-down')\n\nfunction packager (leveldown) {\n function Level (location, options, callback) {\n if (typeof location === 'function') {\n callback = location\n } else if (typeof options === 'function') {\n callback = options\n }\n\n if (!isObject(options)) {\n options = isObject(location) ? location : {}\n }\n\n return levelup(encode(leveldown(location, options), options), options, callback)\n }\n\n function isObject (o) {\n return typeof o === 'object' && o !== null\n }\n\n for (const m of ['destroy', 'repair']) {\n if (typeof leveldown[m] === 'function') {\n Level[m] = function (...args) {\n leveldown[m](...args)\n }\n }\n }\n\n Level.errors = levelup.errors\n\n return Level\n}\n\nmodule.exports = packager\n","'use strict'\n\nconst EventEmitter = require('events').EventEmitter\nconst inherits = require('util').inherits\nconst DeferredLevelDOWN = require('deferred-leveldown')\nconst IteratorStream = require('level-iterator-stream')\nconst Batch = require('./batch')\nconst errors = require('level-errors')\nconst supports = require('level-supports')\nconst catering = require('catering')\nconst getCallback = require('./common').getCallback\nconst getOptions = require('./common').getOptions\n\n// TODO: after we drop node 10, also use queueMicrotask() in node\nconst nextTick = require('./next-tick')\n\nconst WriteError = errors.WriteError\nconst ReadError = errors.ReadError\nconst NotFoundError = errors.NotFoundError\nconst OpenError = errors.OpenError\nconst InitializationError = errors.InitializationError\n\nfunction LevelUP (db, options, callback) {\n if (!(this instanceof LevelUP)) {\n return new LevelUP(db, options, callback)\n }\n\n let error\n\n EventEmitter.call(this)\n this.setMaxListeners(Infinity)\n\n if (typeof options === 'function') {\n callback = options\n options = {}\n }\n\n options = options || {}\n\n if (!db || typeof db !== 'object') {\n error = new InitializationError('First argument must be an abstract-leveldown compliant store')\n if (typeof callback === 'function') {\n return nextTick(callback, error)\n }\n throw error\n }\n\n if (typeof db.status !== 'string') {\n throw new Error('.status required, old abstract-leveldown')\n }\n\n this.options = getOptions(options)\n this._db = db\n this.db = null\n this.open(callback || ((err) => {\n if (err) this.emit('error', err)\n }))\n\n // Create manifest based on deferred-leveldown's\n this.supports = supports(this.db.supports, {\n status: true,\n deferredOpen: true,\n openCallback: true,\n promises: true,\n streams: true\n })\n\n // Experimental: enrich levelup interface\n for (const method of Object.keys(this.supports.additionalMethods)) {\n if (this[method] != null) continue\n\n // Don't do this.db[method].bind() because this.db is dynamic.\n this[method] = function (...args) {\n return this.db[method](...args)\n }\n }\n}\n\nLevelUP.prototype.emit = EventEmitter.prototype.emit\nLevelUP.prototype.once = EventEmitter.prototype.once\ninherits(LevelUP, EventEmitter)\n\n// TODO: tests\nObject.defineProperty(LevelUP.prototype, 'status', {\n enumerable: true,\n get () {\n return this.db.status\n }\n})\n\n// TODO: tests\nLevelUP.prototype.isOperational = function () {\n return this.db.status === 'open' || this.db.status === 'opening'\n}\n\nLevelUP.prototype.open = function (opts, callback) {\n if (typeof opts === 'function') {\n callback = opts\n opts = null\n }\n\n callback = catering.fromCallback(callback)\n\n if (!opts) {\n opts = this.options\n }\n\n // 1) Don't check db.status until levelup has opened,\n // in order for levelup events to be consistent\n if (this.db && this.isOpen()) {\n nextTick(callback, null, this)\n return callback.promise\n }\n\n if (this.db && this._isOpening()) {\n this.once('open', () => { callback(null, this) })\n return callback.promise\n }\n\n // 2) Instead let deferred-leveldown handle already-open cases.\n // TODO: ideally though, levelup would have its own status\n this.db = new DeferredLevelDOWN(this._db)\n this.emit('opening')\n\n this.db.open(opts, (err) => {\n if (err) {\n return callback(new OpenError(err))\n }\n this.db = this._db\n callback(null, this)\n this.emit('open')\n this.emit('ready')\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.close = function (callback) {\n callback = catering.fromCallback(callback)\n\n if (this.isOpen()) {\n this.db.close((err, ...rest) => {\n this.emit('closed')\n callback(err, ...rest)\n })\n this.emit('closing')\n } else if (this.isClosed()) {\n nextTick(callback)\n } else if (this.db.status === 'closing') {\n this.once('closed', callback)\n } else if (this._isOpening()) {\n this.once('open', () => {\n this.close(callback)\n })\n }\n\n return callback.promise\n}\n\n// TODO: remove in future major\nLevelUP.prototype.isOpen = function () {\n return this.db.status === 'open'\n}\n\n// TODO: remove in future major\nLevelUP.prototype._isOpening = function () {\n return this.db.status === 'opening'\n}\n\n// TODO: remove in future major\nLevelUP.prototype.isClosed = function () {\n return (/^clos|new/).test(this.db.status)\n}\n\nLevelUP.prototype.get = function (key, options, callback) {\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n options = getOptions(options)\n\n this.db.get(key, options, function (err, value) {\n if (err) {\n if ((/notfound/i).test(err) || err.notFound) {\n err = new NotFoundError('Key not found in database [' + key + ']', err)\n } else {\n err = new ReadError(err)\n }\n return callback(err)\n }\n callback(null, value)\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.getMany = function (keys, options, callback) {\n return this.db.getMany(keys, options, callback)\n}\n\nLevelUP.prototype.put = function (key, value, options, callback) {\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n options = getOptions(options)\n\n this.db.put(key, value, options, (err) => {\n if (err) {\n return callback(new WriteError(err))\n }\n this.emit('put', key, value)\n callback()\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.del = function (key, options, callback) {\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n options = getOptions(options)\n\n this.db.del(key, options, (err) => {\n if (err) {\n return callback(new WriteError(err))\n }\n this.emit('del', key)\n callback()\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.batch = function (arr, options, callback) {\n if (!arguments.length) {\n return new Batch(this)\n }\n\n if (typeof arr === 'function') callback = arr\n else callback = getCallback(options, callback)\n\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n options = getOptions(options)\n\n this.db.batch(arr, options, (err) => {\n if (err) {\n return callback(new WriteError(err))\n }\n this.emit('batch', arr)\n callback()\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.iterator = function (options) {\n return this.db.iterator(options)\n}\n\nLevelUP.prototype.clear = function (options, callback) {\n callback = getCallback(options, callback)\n options = getOptions(options)\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n this.db.clear(options, (err) => {\n if (err) {\n return callback(new WriteError(err))\n }\n this.emit('clear', options)\n callback()\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.readStream =\nLevelUP.prototype.createReadStream = function (options) {\n options = Object.assign({ keys: true, values: true }, options)\n if (typeof options.limit !== 'number') { options.limit = -1 }\n return new IteratorStream(this.db.iterator(options), options)\n}\n\nLevelUP.prototype.keyStream =\nLevelUP.prototype.createKeyStream = function (options) {\n return this.createReadStream(Object.assign({}, options, { keys: true, values: false }))\n}\n\nLevelUP.prototype.valueStream =\nLevelUP.prototype.createValueStream = function (options) {\n return this.createReadStream(Object.assign({}, options, { keys: false, values: true }))\n}\n\nLevelUP.prototype.toString = function () {\n return 'LevelUP'\n}\n\nLevelUP.prototype.type = 'levelup'\n\n// Expose nextTick for API parity with abstract-leveldown\nLevelUP.prototype._nextTick = nextTick\n\nfunction maybeError (db, callback) {\n if (!db.isOperational()) {\n nextTick(callback, new ReadError('Database is not open'))\n return true\n }\n\n return false\n}\n\nLevelUP.errors = errors\nmodule.exports = LevelUP\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors ||\n function getOwnPropertyDescriptors(obj) {\n var keys = Object.keys(obj);\n var descriptors = {};\n for (var i = 0; i < keys.length; i++) {\n descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);\n }\n return descriptors;\n };\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n if (!isString(f)) {\n var objects = [];\n for (var i = 0; i < arguments.length; i++) {\n objects.push(inspect(arguments[i]));\n }\n return objects.join(' ');\n }\n\n var i = 1;\n var args = arguments;\n var len = args.length;\n var str = String(f).replace(formatRegExp, function(x) {\n if (x === '%%') return '%';\n if (i >= len) return x;\n switch (x) {\n case '%s': return String(args[i++]);\n case '%d': return Number(args[i++]);\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n default:\n return x;\n }\n });\n for (var x = args[i]; i < len; x = args[++i]) {\n if (isNull(x) || !isObject(x)) {\n str += ' ' + x;\n } else {\n str += ' ' + inspect(x);\n }\n }\n return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n if (typeof process !== 'undefined' && process.noDeprecation === true) {\n return fn;\n }\n\n // Allow for deprecating things in the process of starting up.\n if (typeof process === 'undefined') {\n return function() {\n return exports.deprecate(fn, msg).apply(this, arguments);\n };\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (process.throwDeprecation) {\n throw new Error(msg);\n } else if (process.traceDeprecation) {\n console.trace(msg);\n } else {\n console.error(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnvRegex = /^$/;\n\nif (process.env.NODE_DEBUG) {\n var debugEnv = process.env.NODE_DEBUG;\n debugEnv = debugEnv.replace(/[|\\\\{}()[\\]^$+?.]/g, '\\\\$&')\n .replace(/\\*/g, '.*')\n .replace(/,/g, '$|^')\n .toUpperCase();\n debugEnvRegex = new RegExp('^' + debugEnv + '$', 'i');\n}\nexports.debuglog = function(set) {\n set = set.toUpperCase();\n if (!debugs[set]) {\n if (debugEnvRegex.test(set)) {\n var pid = process.pid;\n debugs[set] = function() {\n var msg = exports.format.apply(exports, arguments);\n console.error('%s %d: %s', set, pid, msg);\n };\n } else {\n debugs[set] = function() {};\n }\n }\n return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n // default options\n var ctx = {\n seen: [],\n stylize: stylizeNoColor\n };\n // legacy...\n if (arguments.length >= 3) ctx.depth = arguments[2];\n if (arguments.length >= 4) ctx.colors = arguments[3];\n if (isBoolean(opts)) {\n // legacy...\n ctx.showHidden = opts;\n } else if (opts) {\n // got an \"options\" object\n exports._extend(ctx, opts);\n }\n // set default options\n if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n if (isUndefined(ctx.depth)) ctx.depth = 2;\n if (isUndefined(ctx.colors)) ctx.colors = false;\n if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n if (ctx.colors) ctx.stylize = stylizeWithColor;\n return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n 'bold' : [1, 22],\n 'italic' : [3, 23],\n 'underline' : [4, 24],\n 'inverse' : [7, 27],\n 'white' : [37, 39],\n 'grey' : [90, 39],\n 'black' : [30, 39],\n 'blue' : [34, 39],\n 'cyan' : [36, 39],\n 'green' : [32, 39],\n 'magenta' : [35, 39],\n 'red' : [31, 39],\n 'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n 'special': 'cyan',\n 'number': 'yellow',\n 'boolean': 'yellow',\n 'undefined': 'grey',\n 'null': 'bold',\n 'string': 'green',\n 'date': 'magenta',\n // \"name\": intentionally not styling\n 'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n var style = inspect.styles[styleType];\n\n if (style) {\n return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n '\\u001b[' + inspect.colors[style][1] + 'm';\n } else {\n return str;\n }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n return str;\n}\n\n\nfunction arrayToHash(array) {\n var hash = {};\n\n array.forEach(function(val, idx) {\n hash[val] = true;\n });\n\n return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n // Provide a hook for user-specified inspect functions.\n // Check that value is an object with an inspect function on it\n if (ctx.customInspect &&\n value &&\n isFunction(value.inspect) &&\n // Filter out the util module, it's inspect function is special\n value.inspect !== exports.inspect &&\n // Also filter out any prototype objects using the circular check.\n !(value.constructor && value.constructor.prototype === value)) {\n var ret = value.inspect(recurseTimes, ctx);\n if (!isString(ret)) {\n ret = formatValue(ctx, ret, recurseTimes);\n }\n return ret;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n\n if (ctx.showHidden) {\n keys = Object.getOwnPropertyNames(value);\n }\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (isError(value)\n && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n\n var base = '', array = false, braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n\n ctx.seen.push(value);\n\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function(key) {\n return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n });\n }\n\n ctx.seen.pop();\n\n return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n if (isUndefined(value))\n return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n .replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"') + '\\'';\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value))\n return ctx.stylize('' + value, 'number');\n if (isBoolean(value))\n return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value))\n return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n String(i), true));\n } else {\n output.push('');\n }\n }\n keys.forEach(function(key) {\n if (!key.match(/^\\d+$/)) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n key, true));\n }\n });\n return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n').substr(2);\n } else {\n str = '\\n' + str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.substr(1, name.length - 2);\n name = ctx.stylize(name, 'name');\n } else {\n name = name.replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"')\n .replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n\n return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function(prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n\n if (length > 60) {\n return braces[0] +\n (base === '' ? '' : base + '\\n ') +\n ' ' +\n output.join(',\\n ') +\n ' ' +\n braces[1];\n }\n\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nexports.types = require('./support/types');\n\nfunction isArray(ar) {\n return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\nexports.types.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\nexports.types.isDate = isDate;\n\nfunction isError(e) {\n return isObject(e) &&\n (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\nexports.types.isNativeError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n 'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n var d = new Date();\n var time = [pad(d.getHours()),\n pad(d.getMinutes()),\n pad(d.getSeconds())].join(':');\n return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n * prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n // Don't do anything if add isn't an object\n if (!add || !isObject(add)) return origin;\n\n var keys = Object.keys(add);\n var i = keys.length;\n while (i--) {\n origin[keys[i]] = add[keys[i]];\n }\n return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nvar kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;\n\nexports.promisify = function promisify(original) {\n if (typeof original !== 'function')\n throw new TypeError('The \"original\" argument must be of type Function');\n\n if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {\n var fn = original[kCustomPromisifiedSymbol];\n if (typeof fn !== 'function') {\n throw new TypeError('The \"util.promisify.custom\" argument must be of type Function');\n }\n Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return fn;\n }\n\n function fn() {\n var promiseResolve, promiseReject;\n var promise = new Promise(function (resolve, reject) {\n promiseResolve = resolve;\n promiseReject = reject;\n });\n\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n args.push(function (err, value) {\n if (err) {\n promiseReject(err);\n } else {\n promiseResolve(value);\n }\n });\n\n try {\n original.apply(this, args);\n } catch (err) {\n promiseReject(err);\n }\n\n return promise;\n }\n\n Object.setPrototypeOf(fn, Object.getPrototypeOf(original));\n\n if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return Object.defineProperties(\n fn,\n getOwnPropertyDescriptors(original)\n );\n}\n\nexports.promisify.custom = kCustomPromisifiedSymbol\n\nfunction callbackifyOnRejected(reason, cb) {\n // `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).\n // Because `null` is a special error value in callbacks which means \"no error\n // occurred\", we error-wrap so the callback consumer can distinguish between\n // \"the promise rejected with null\" or \"the promise fulfilled with undefined\".\n if (!reason) {\n var newReason = new Error('Promise was rejected with a falsy value');\n newReason.reason = reason;\n reason = newReason;\n }\n return cb(reason);\n}\n\nfunction callbackify(original) {\n if (typeof original !== 'function') {\n throw new TypeError('The \"original\" argument must be of type Function');\n }\n\n // We DO NOT return the promise as it gives the user a false sense that\n // the promise is actually somehow related to the callback's execution\n // and that the callback throwing will reject the promise.\n function callbackified() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n\n var maybeCb = args.pop();\n if (typeof maybeCb !== 'function') {\n throw new TypeError('The last argument must be of type Function');\n }\n var self = this;\n var cb = function() {\n return maybeCb.apply(self, arguments);\n };\n // In true node style we process the callback on `nextTick` with all the\n // implications (stack, `uncaughtException`, `async_hooks`)\n original.apply(this, args)\n .then(function(ret) { process.nextTick(cb.bind(null, null, ret)) },\n function(rej) { process.nextTick(callbackifyOnRejected.bind(null, rej, cb)) });\n }\n\n Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));\n Object.defineProperties(callbackified,\n getOwnPropertyDescriptors(original));\n return callbackified;\n}\nexports.callbackify = callbackify;\n","// Currently in sync with Node.js lib/internal/util/types.js\n// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9\n\n'use strict';\n\nvar isArgumentsObject = require('is-arguments');\nvar isGeneratorFunction = require('is-generator-function');\nvar whichTypedArray = require('which-typed-array');\nvar isTypedArray = require('is-typed-array');\n\nfunction uncurryThis(f) {\n return f.call.bind(f);\n}\n\nvar BigIntSupported = typeof BigInt !== 'undefined';\nvar SymbolSupported = typeof Symbol !== 'undefined';\n\nvar ObjectToString = uncurryThis(Object.prototype.toString);\n\nvar numberValue = uncurryThis(Number.prototype.valueOf);\nvar stringValue = uncurryThis(String.prototype.valueOf);\nvar booleanValue = uncurryThis(Boolean.prototype.valueOf);\n\nif (BigIntSupported) {\n var bigIntValue = uncurryThis(BigInt.prototype.valueOf);\n}\n\nif (SymbolSupported) {\n var symbolValue = uncurryThis(Symbol.prototype.valueOf);\n}\n\nfunction checkBoxedPrimitive(value, prototypeValueOf) {\n if (typeof value !== 'object') {\n return false;\n }\n try {\n prototypeValueOf(value);\n return true;\n } catch(e) {\n return false;\n }\n}\n\nexports.isArgumentsObject = isArgumentsObject;\nexports.isGeneratorFunction = isGeneratorFunction;\nexports.isTypedArray = isTypedArray;\n\n// Taken from here and modified for better browser support\n// https://github.com/sindresorhus/p-is-promise/blob/cda35a513bda03f977ad5cde3a079d237e82d7ef/index.js\nfunction isPromise(input) {\n\treturn (\n\t\t(\n\t\t\ttypeof Promise !== 'undefined' &&\n\t\t\tinput instanceof Promise\n\t\t) ||\n\t\t(\n\t\t\tinput !== null &&\n\t\t\ttypeof input === 'object' &&\n\t\t\ttypeof input.then === 'function' &&\n\t\t\ttypeof input.catch === 'function'\n\t\t)\n\t);\n}\nexports.isPromise = isPromise;\n\nfunction isArrayBufferView(value) {\n if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView) {\n return ArrayBuffer.isView(value);\n }\n\n return (\n isTypedArray(value) ||\n isDataView(value)\n );\n}\nexports.isArrayBufferView = isArrayBufferView;\n\n\nfunction isUint8Array(value) {\n return whichTypedArray(value) === 'Uint8Array';\n}\nexports.isUint8Array = isUint8Array;\n\nfunction isUint8ClampedArray(value) {\n return whichTypedArray(value) === 'Uint8ClampedArray';\n}\nexports.isUint8ClampedArray = isUint8ClampedArray;\n\nfunction isUint16Array(value) {\n return whichTypedArray(value) === 'Uint16Array';\n}\nexports.isUint16Array = isUint16Array;\n\nfunction isUint32Array(value) {\n return whichTypedArray(value) === 'Uint32Array';\n}\nexports.isUint32Array = isUint32Array;\n\nfunction isInt8Array(value) {\n return whichTypedArray(value) === 'Int8Array';\n}\nexports.isInt8Array = isInt8Array;\n\nfunction isInt16Array(value) {\n return whichTypedArray(value) === 'Int16Array';\n}\nexports.isInt16Array = isInt16Array;\n\nfunction isInt32Array(value) {\n return whichTypedArray(value) === 'Int32Array';\n}\nexports.isInt32Array = isInt32Array;\n\nfunction isFloat32Array(value) {\n return whichTypedArray(value) === 'Float32Array';\n}\nexports.isFloat32Array = isFloat32Array;\n\nfunction isFloat64Array(value) {\n return whichTypedArray(value) === 'Float64Array';\n}\nexports.isFloat64Array = isFloat64Array;\n\nfunction isBigInt64Array(value) {\n return whichTypedArray(value) === 'BigInt64Array';\n}\nexports.isBigInt64Array = isBigInt64Array;\n\nfunction isBigUint64Array(value) {\n return whichTypedArray(value) === 'BigUint64Array';\n}\nexports.isBigUint64Array = isBigUint64Array;\n\nfunction isMapToString(value) {\n return ObjectToString(value) === '[object Map]';\n}\nisMapToString.working = (\n typeof Map !== 'undefined' &&\n isMapToString(new Map())\n);\n\nfunction isMap(value) {\n if (typeof Map === 'undefined') {\n return false;\n }\n\n return isMapToString.working\n ? isMapToString(value)\n : value instanceof Map;\n}\nexports.isMap = isMap;\n\nfunction isSetToString(value) {\n return ObjectToString(value) === '[object Set]';\n}\nisSetToString.working = (\n typeof Set !== 'undefined' &&\n isSetToString(new Set())\n);\nfunction isSet(value) {\n if (typeof Set === 'undefined') {\n return false;\n }\n\n return isSetToString.working\n ? isSetToString(value)\n : value instanceof Set;\n}\nexports.isSet = isSet;\n\nfunction isWeakMapToString(value) {\n return ObjectToString(value) === '[object WeakMap]';\n}\nisWeakMapToString.working = (\n typeof WeakMap !== 'undefined' &&\n isWeakMapToString(new WeakMap())\n);\nfunction isWeakMap(value) {\n if (typeof WeakMap === 'undefined') {\n return false;\n }\n\n return isWeakMapToString.working\n ? isWeakMapToString(value)\n : value instanceof WeakMap;\n}\nexports.isWeakMap = isWeakMap;\n\nfunction isWeakSetToString(value) {\n return ObjectToString(value) === '[object WeakSet]';\n}\nisWeakSetToString.working = (\n typeof WeakSet !== 'undefined' &&\n isWeakSetToString(new WeakSet())\n);\nfunction isWeakSet(value) {\n return isWeakSetToString(value);\n}\nexports.isWeakSet = isWeakSet;\n\nfunction isArrayBufferToString(value) {\n return ObjectToString(value) === '[object ArrayBuffer]';\n}\nisArrayBufferToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n isArrayBufferToString(new ArrayBuffer())\n);\nfunction isArrayBuffer(value) {\n if (typeof ArrayBuffer === 'undefined') {\n return false;\n }\n\n return isArrayBufferToString.working\n ? isArrayBufferToString(value)\n : value instanceof ArrayBuffer;\n}\nexports.isArrayBuffer = isArrayBuffer;\n\nfunction isDataViewToString(value) {\n return ObjectToString(value) === '[object DataView]';\n}\nisDataViewToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n typeof DataView !== 'undefined' &&\n isDataViewToString(new DataView(new ArrayBuffer(1), 0, 1))\n);\nfunction isDataView(value) {\n if (typeof DataView === 'undefined') {\n return false;\n }\n\n return isDataViewToString.working\n ? isDataViewToString(value)\n : value instanceof DataView;\n}\nexports.isDataView = isDataView;\n\n// Store a copy of SharedArrayBuffer in case it's deleted elsewhere\nvar SharedArrayBufferCopy = typeof SharedArrayBuffer !== 'undefined' ? SharedArrayBuffer : undefined;\nfunction isSharedArrayBufferToString(value) {\n return ObjectToString(value) === '[object SharedArrayBuffer]';\n}\nfunction isSharedArrayBuffer(value) {\n if (typeof SharedArrayBufferCopy === 'undefined') {\n return false;\n }\n\n if (typeof isSharedArrayBufferToString.working === 'undefined') {\n isSharedArrayBufferToString.working = isSharedArrayBufferToString(new SharedArrayBufferCopy());\n }\n\n return isSharedArrayBufferToString.working\n ? isSharedArrayBufferToString(value)\n : value instanceof SharedArrayBufferCopy;\n}\nexports.isSharedArrayBuffer = isSharedArrayBuffer;\n\nfunction isAsyncFunction(value) {\n return ObjectToString(value) === '[object AsyncFunction]';\n}\nexports.isAsyncFunction = isAsyncFunction;\n\nfunction isMapIterator(value) {\n return ObjectToString(value) === '[object Map Iterator]';\n}\nexports.isMapIterator = isMapIterator;\n\nfunction isSetIterator(value) {\n return ObjectToString(value) === '[object Set Iterator]';\n}\nexports.isSetIterator = isSetIterator;\n\nfunction isGeneratorObject(value) {\n return ObjectToString(value) === '[object Generator]';\n}\nexports.isGeneratorObject = isGeneratorObject;\n\nfunction isWebAssemblyCompiledModule(value) {\n return ObjectToString(value) === '[object WebAssembly.Module]';\n}\nexports.isWebAssemblyCompiledModule = isWebAssemblyCompiledModule;\n\nfunction isNumberObject(value) {\n return checkBoxedPrimitive(value, numberValue);\n}\nexports.isNumberObject = isNumberObject;\n\nfunction isStringObject(value) {\n return checkBoxedPrimitive(value, stringValue);\n}\nexports.isStringObject = isStringObject;\n\nfunction isBooleanObject(value) {\n return checkBoxedPrimitive(value, booleanValue);\n}\nexports.isBooleanObject = isBooleanObject;\n\nfunction isBigIntObject(value) {\n return BigIntSupported && checkBoxedPrimitive(value, bigIntValue);\n}\nexports.isBigIntObject = isBigIntObject;\n\nfunction isSymbolObject(value) {\n return SymbolSupported && checkBoxedPrimitive(value, symbolValue);\n}\nexports.isSymbolObject = isSymbolObject;\n\nfunction isBoxedPrimitive(value) {\n return (\n isNumberObject(value) ||\n isStringObject(value) ||\n isBooleanObject(value) ||\n isBigIntObject(value) ||\n isSymbolObject(value)\n );\n}\nexports.isBoxedPrimitive = isBoxedPrimitive;\n\nfunction isAnyArrayBuffer(value) {\n return typeof Uint8Array !== 'undefined' && (\n isArrayBuffer(value) ||\n isSharedArrayBuffer(value)\n );\n}\nexports.isAnyArrayBuffer = isAnyArrayBuffer;\n\n['isProxy', 'isExternal', 'isModuleNamespaceObject'].forEach(function(method) {\n Object.defineProperty(exports, method, {\n enumerable: false,\n value: function() {\n throw new Error(method + ' is not supported in userland');\n }\n });\n});\n","'use strict';\n\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar callBound = require('call-bind/callBound');\n\nvar $toString = callBound('Object.prototype.toString');\n\nvar isStandardArguments = function isArguments(value) {\n\tif (hasToStringTag && value && typeof value === 'object' && Symbol.toStringTag in value) {\n\t\treturn false;\n\t}\n\treturn $toString(value) === '[object Arguments]';\n};\n\nvar isLegacyArguments = function isArguments(value) {\n\tif (isStandardArguments(value)) {\n\t\treturn true;\n\t}\n\treturn value !== null &&\n\t\ttypeof value === 'object' &&\n\t\ttypeof value.length === 'number' &&\n\t\tvalue.length >= 0 &&\n\t\t$toString(value) !== '[object Array]' &&\n\t\t$toString(value.callee) === '[object Function]';\n};\n\nvar supportsStandardArguments = (function () {\n\treturn isStandardArguments(arguments);\n}());\n\nisStandardArguments.isLegacyArguments = isLegacyArguments; // for tests\n\nmodule.exports = supportsStandardArguments ? isStandardArguments : isLegacyArguments;\n","'use strict';\n\nvar hasSymbols = require('has-symbols/shams');\n\nmodule.exports = function hasToStringTagShams() {\n\treturn hasSymbols() && !!Symbol.toStringTag;\n};\n","'use strict';\n\n/* eslint complexity: [2, 18], max-statements: [2, 33] */\nmodule.exports = function hasSymbols() {\n\tif (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }\n\tif (typeof Symbol.iterator === 'symbol') { return true; }\n\n\tvar obj = {};\n\tvar sym = Symbol('test');\n\tvar symObj = Object(sym);\n\tif (typeof sym === 'string') { return false; }\n\n\tif (Object.prototype.toString.call(sym) !== '[object Symbol]') { return false; }\n\tif (Object.prototype.toString.call(symObj) !== '[object Symbol]') { return false; }\n\n\t// temp disabled per https://github.com/ljharb/object.assign/issues/17\n\t// if (sym instanceof Symbol) { return false; }\n\t// temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4\n\t// if (!(symObj instanceof Symbol)) { return false; }\n\n\t// if (typeof Symbol.prototype.toString !== 'function') { return false; }\n\t// if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; }\n\n\tvar symVal = 42;\n\tobj[sym] = symVal;\n\tfor (sym in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop\n\tif (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }\n\n\tif (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }\n\n\tvar syms = Object.getOwnPropertySymbols(obj);\n\tif (syms.length !== 1 || syms[0] !== sym) { return false; }\n\n\tif (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }\n\n\tif (typeof Object.getOwnPropertyDescriptor === 'function') {\n\t\tvar descriptor = Object.getOwnPropertyDescriptor(obj, sym);\n\t\tif (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }\n\t}\n\n\treturn true;\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar callBind = require('./');\n\nvar $indexOf = callBind(GetIntrinsic('String.prototype.indexOf'));\n\nmodule.exports = function callBoundIntrinsic(name, allowMissing) {\n\tvar intrinsic = GetIntrinsic(name, !!allowMissing);\n\tif (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) {\n\t\treturn callBind(intrinsic);\n\t}\n\treturn intrinsic;\n};\n","'use strict';\n\nvar undefined;\n\nvar $SyntaxError = SyntaxError;\nvar $Function = Function;\nvar $TypeError = TypeError;\n\n// eslint-disable-next-line consistent-return\nvar getEvalledConstructor = function (expressionSyntax) {\n\ttry {\n\t\treturn $Function('\"use strict\"; return (' + expressionSyntax + ').constructor;')();\n\t} catch (e) {}\n};\n\nvar $gOPD = Object.getOwnPropertyDescriptor;\nif ($gOPD) {\n\ttry {\n\t\t$gOPD({}, '');\n\t} catch (e) {\n\t\t$gOPD = null; // this is IE 8, which has a broken gOPD\n\t}\n}\n\nvar throwTypeError = function () {\n\tthrow new $TypeError();\n};\nvar ThrowTypeError = $gOPD\n\t? (function () {\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties\n\t\t\targuments.callee; // IE 8 does not throw here\n\t\t\treturn throwTypeError;\n\t\t} catch (calleeThrows) {\n\t\t\ttry {\n\t\t\t\t// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')\n\t\t\t\treturn $gOPD(arguments, 'callee').get;\n\t\t\t} catch (gOPDthrows) {\n\t\t\t\treturn throwTypeError;\n\t\t\t}\n\t\t}\n\t}())\n\t: throwTypeError;\n\nvar hasSymbols = require('has-symbols')();\n\nvar getProto = Object.getPrototypeOf || function (x) { return x.__proto__; }; // eslint-disable-line no-proto\n\nvar needsEval = {};\n\nvar TypedArray = typeof Uint8Array === 'undefined' ? undefined : getProto(Uint8Array);\n\nvar INTRINSICS = {\n\t'%AggregateError%': typeof AggregateError === 'undefined' ? undefined : AggregateError,\n\t'%Array%': Array,\n\t'%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer,\n\t'%ArrayIteratorPrototype%': hasSymbols ? getProto([][Symbol.iterator]()) : undefined,\n\t'%AsyncFromSyncIteratorPrototype%': undefined,\n\t'%AsyncFunction%': needsEval,\n\t'%AsyncGenerator%': needsEval,\n\t'%AsyncGeneratorFunction%': needsEval,\n\t'%AsyncIteratorPrototype%': needsEval,\n\t'%Atomics%': typeof Atomics === 'undefined' ? undefined : Atomics,\n\t'%BigInt%': typeof BigInt === 'undefined' ? undefined : BigInt,\n\t'%Boolean%': Boolean,\n\t'%DataView%': typeof DataView === 'undefined' ? undefined : DataView,\n\t'%Date%': Date,\n\t'%decodeURI%': decodeURI,\n\t'%decodeURIComponent%': decodeURIComponent,\n\t'%encodeURI%': encodeURI,\n\t'%encodeURIComponent%': encodeURIComponent,\n\t'%Error%': Error,\n\t'%eval%': eval, // eslint-disable-line no-eval\n\t'%EvalError%': EvalError,\n\t'%Float32Array%': typeof Float32Array === 'undefined' ? undefined : Float32Array,\n\t'%Float64Array%': typeof Float64Array === 'undefined' ? undefined : Float64Array,\n\t'%FinalizationRegistry%': typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry,\n\t'%Function%': $Function,\n\t'%GeneratorFunction%': needsEval,\n\t'%Int8Array%': typeof Int8Array === 'undefined' ? undefined : Int8Array,\n\t'%Int16Array%': typeof Int16Array === 'undefined' ? undefined : Int16Array,\n\t'%Int32Array%': typeof Int32Array === 'undefined' ? undefined : Int32Array,\n\t'%isFinite%': isFinite,\n\t'%isNaN%': isNaN,\n\t'%IteratorPrototype%': hasSymbols ? getProto(getProto([][Symbol.iterator]())) : undefined,\n\t'%JSON%': typeof JSON === 'object' ? JSON : undefined,\n\t'%Map%': typeof Map === 'undefined' ? undefined : Map,\n\t'%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols ? undefined : getProto(new Map()[Symbol.iterator]()),\n\t'%Math%': Math,\n\t'%Number%': Number,\n\t'%Object%': Object,\n\t'%parseFloat%': parseFloat,\n\t'%parseInt%': parseInt,\n\t'%Promise%': typeof Promise === 'undefined' ? undefined : Promise,\n\t'%Proxy%': typeof Proxy === 'undefined' ? undefined : Proxy,\n\t'%RangeError%': RangeError,\n\t'%ReferenceError%': ReferenceError,\n\t'%Reflect%': typeof Reflect === 'undefined' ? undefined : Reflect,\n\t'%RegExp%': RegExp,\n\t'%Set%': typeof Set === 'undefined' ? undefined : Set,\n\t'%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols ? undefined : getProto(new Set()[Symbol.iterator]()),\n\t'%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer,\n\t'%String%': String,\n\t'%StringIteratorPrototype%': hasSymbols ? getProto(''[Symbol.iterator]()) : undefined,\n\t'%Symbol%': hasSymbols ? Symbol : undefined,\n\t'%SyntaxError%': $SyntaxError,\n\t'%ThrowTypeError%': ThrowTypeError,\n\t'%TypedArray%': TypedArray,\n\t'%TypeError%': $TypeError,\n\t'%Uint8Array%': typeof Uint8Array === 'undefined' ? undefined : Uint8Array,\n\t'%Uint8ClampedArray%': typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray,\n\t'%Uint16Array%': typeof Uint16Array === 'undefined' ? undefined : Uint16Array,\n\t'%Uint32Array%': typeof Uint32Array === 'undefined' ? undefined : Uint32Array,\n\t'%URIError%': URIError,\n\t'%WeakMap%': typeof WeakMap === 'undefined' ? undefined : WeakMap,\n\t'%WeakRef%': typeof WeakRef === 'undefined' ? undefined : WeakRef,\n\t'%WeakSet%': typeof WeakSet === 'undefined' ? undefined : WeakSet\n};\n\nvar doEval = function doEval(name) {\n\tvar value;\n\tif (name === '%AsyncFunction%') {\n\t\tvalue = getEvalledConstructor('async function () {}');\n\t} else if (name === '%GeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('function* () {}');\n\t} else if (name === '%AsyncGeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('async function* () {}');\n\t} else if (name === '%AsyncGenerator%') {\n\t\tvar fn = doEval('%AsyncGeneratorFunction%');\n\t\tif (fn) {\n\t\t\tvalue = fn.prototype;\n\t\t}\n\t} else if (name === '%AsyncIteratorPrototype%') {\n\t\tvar gen = doEval('%AsyncGenerator%');\n\t\tif (gen) {\n\t\t\tvalue = getProto(gen.prototype);\n\t\t}\n\t}\n\n\tINTRINSICS[name] = value;\n\n\treturn value;\n};\n\nvar LEGACY_ALIASES = {\n\t'%ArrayBufferPrototype%': ['ArrayBuffer', 'prototype'],\n\t'%ArrayPrototype%': ['Array', 'prototype'],\n\t'%ArrayProto_entries%': ['Array', 'prototype', 'entries'],\n\t'%ArrayProto_forEach%': ['Array', 'prototype', 'forEach'],\n\t'%ArrayProto_keys%': ['Array', 'prototype', 'keys'],\n\t'%ArrayProto_values%': ['Array', 'prototype', 'values'],\n\t'%AsyncFunctionPrototype%': ['AsyncFunction', 'prototype'],\n\t'%AsyncGenerator%': ['AsyncGeneratorFunction', 'prototype'],\n\t'%AsyncGeneratorPrototype%': ['AsyncGeneratorFunction', 'prototype', 'prototype'],\n\t'%BooleanPrototype%': ['Boolean', 'prototype'],\n\t'%DataViewPrototype%': ['DataView', 'prototype'],\n\t'%DatePrototype%': ['Date', 'prototype'],\n\t'%ErrorPrototype%': ['Error', 'prototype'],\n\t'%EvalErrorPrototype%': ['EvalError', 'prototype'],\n\t'%Float32ArrayPrototype%': ['Float32Array', 'prototype'],\n\t'%Float64ArrayPrototype%': ['Float64Array', 'prototype'],\n\t'%FunctionPrototype%': ['Function', 'prototype'],\n\t'%Generator%': ['GeneratorFunction', 'prototype'],\n\t'%GeneratorPrototype%': ['GeneratorFunction', 'prototype', 'prototype'],\n\t'%Int8ArrayPrototype%': ['Int8Array', 'prototype'],\n\t'%Int16ArrayPrototype%': ['Int16Array', 'prototype'],\n\t'%Int32ArrayPrototype%': ['Int32Array', 'prototype'],\n\t'%JSONParse%': ['JSON', 'parse'],\n\t'%JSONStringify%': ['JSON', 'stringify'],\n\t'%MapPrototype%': ['Map', 'prototype'],\n\t'%NumberPrototype%': ['Number', 'prototype'],\n\t'%ObjectPrototype%': ['Object', 'prototype'],\n\t'%ObjProto_toString%': ['Object', 'prototype', 'toString'],\n\t'%ObjProto_valueOf%': ['Object', 'prototype', 'valueOf'],\n\t'%PromisePrototype%': ['Promise', 'prototype'],\n\t'%PromiseProto_then%': ['Promise', 'prototype', 'then'],\n\t'%Promise_all%': ['Promise', 'all'],\n\t'%Promise_reject%': ['Promise', 'reject'],\n\t'%Promise_resolve%': ['Promise', 'resolve'],\n\t'%RangeErrorPrototype%': ['RangeError', 'prototype'],\n\t'%ReferenceErrorPrototype%': ['ReferenceError', 'prototype'],\n\t'%RegExpPrototype%': ['RegExp', 'prototype'],\n\t'%SetPrototype%': ['Set', 'prototype'],\n\t'%SharedArrayBufferPrototype%': ['SharedArrayBuffer', 'prototype'],\n\t'%StringPrototype%': ['String', 'prototype'],\n\t'%SymbolPrototype%': ['Symbol', 'prototype'],\n\t'%SyntaxErrorPrototype%': ['SyntaxError', 'prototype'],\n\t'%TypedArrayPrototype%': ['TypedArray', 'prototype'],\n\t'%TypeErrorPrototype%': ['TypeError', 'prototype'],\n\t'%Uint8ArrayPrototype%': ['Uint8Array', 'prototype'],\n\t'%Uint8ClampedArrayPrototype%': ['Uint8ClampedArray', 'prototype'],\n\t'%Uint16ArrayPrototype%': ['Uint16Array', 'prototype'],\n\t'%Uint32ArrayPrototype%': ['Uint32Array', 'prototype'],\n\t'%URIErrorPrototype%': ['URIError', 'prototype'],\n\t'%WeakMapPrototype%': ['WeakMap', 'prototype'],\n\t'%WeakSetPrototype%': ['WeakSet', 'prototype']\n};\n\nvar bind = require('function-bind');\nvar hasOwn = require('has');\nvar $concat = bind.call(Function.call, Array.prototype.concat);\nvar $spliceApply = bind.call(Function.apply, Array.prototype.splice);\nvar $replace = bind.call(Function.call, String.prototype.replace);\nvar $strSlice = bind.call(Function.call, String.prototype.slice);\n\n/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */\nvar rePropName = /[^%.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|%$))/g;\nvar reEscapeChar = /\\\\(\\\\)?/g; /** Used to match backslashes in property paths. */\nvar stringToPath = function stringToPath(string) {\n\tvar first = $strSlice(string, 0, 1);\n\tvar last = $strSlice(string, -1);\n\tif (first === '%' && last !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected closing `%`');\n\t} else if (last === '%' && first !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected opening `%`');\n\t}\n\tvar result = [];\n\t$replace(string, rePropName, function (match, number, quote, subString) {\n\t\tresult[result.length] = quote ? $replace(subString, reEscapeChar, '$1') : number || match;\n\t});\n\treturn result;\n};\n/* end adaptation */\n\nvar getBaseIntrinsic = function getBaseIntrinsic(name, allowMissing) {\n\tvar intrinsicName = name;\n\tvar alias;\n\tif (hasOwn(LEGACY_ALIASES, intrinsicName)) {\n\t\talias = LEGACY_ALIASES[intrinsicName];\n\t\tintrinsicName = '%' + alias[0] + '%';\n\t}\n\n\tif (hasOwn(INTRINSICS, intrinsicName)) {\n\t\tvar value = INTRINSICS[intrinsicName];\n\t\tif (value === needsEval) {\n\t\t\tvalue = doEval(intrinsicName);\n\t\t}\n\t\tif (typeof value === 'undefined' && !allowMissing) {\n\t\t\tthrow new $TypeError('intrinsic ' + name + ' exists, but is not available. Please file an issue!');\n\t\t}\n\n\t\treturn {\n\t\t\talias: alias,\n\t\t\tname: intrinsicName,\n\t\t\tvalue: value\n\t\t};\n\t}\n\n\tthrow new $SyntaxError('intrinsic ' + name + ' does not exist!');\n};\n\nmodule.exports = function GetIntrinsic(name, allowMissing) {\n\tif (typeof name !== 'string' || name.length === 0) {\n\t\tthrow new $TypeError('intrinsic name must be a non-empty string');\n\t}\n\tif (arguments.length > 1 && typeof allowMissing !== 'boolean') {\n\t\tthrow new $TypeError('\"allowMissing\" argument must be a boolean');\n\t}\n\n\tvar parts = stringToPath(name);\n\tvar intrinsicBaseName = parts.length > 0 ? parts[0] : '';\n\n\tvar intrinsic = getBaseIntrinsic('%' + intrinsicBaseName + '%', allowMissing);\n\tvar intrinsicRealName = intrinsic.name;\n\tvar value = intrinsic.value;\n\tvar skipFurtherCaching = false;\n\n\tvar alias = intrinsic.alias;\n\tif (alias) {\n\t\tintrinsicBaseName = alias[0];\n\t\t$spliceApply(parts, $concat([0, 1], alias));\n\t}\n\n\tfor (var i = 1, isOwn = true; i < parts.length; i += 1) {\n\t\tvar part = parts[i];\n\t\tvar first = $strSlice(part, 0, 1);\n\t\tvar last = $strSlice(part, -1);\n\t\tif (\n\t\t\t(\n\t\t\t\t(first === '\"' || first === \"'\" || first === '`')\n\t\t\t\t|| (last === '\"' || last === \"'\" || last === '`')\n\t\t\t)\n\t\t\t&& first !== last\n\t\t) {\n\t\t\tthrow new $SyntaxError('property names with quotes must have matching quotes');\n\t\t}\n\t\tif (part === 'constructor' || !isOwn) {\n\t\t\tskipFurtherCaching = true;\n\t\t}\n\n\t\tintrinsicBaseName += '.' + part;\n\t\tintrinsicRealName = '%' + intrinsicBaseName + '%';\n\n\t\tif (hasOwn(INTRINSICS, intrinsicRealName)) {\n\t\t\tvalue = INTRINSICS[intrinsicRealName];\n\t\t} else if (value != null) {\n\t\t\tif (!(part in value)) {\n\t\t\t\tif (!allowMissing) {\n\t\t\t\t\tthrow new $TypeError('base intrinsic for ' + name + ' exists, but the property is not available.');\n\t\t\t\t}\n\t\t\t\treturn void undefined;\n\t\t\t}\n\t\t\tif ($gOPD && (i + 1) >= parts.length) {\n\t\t\t\tvar desc = $gOPD(value, part);\n\t\t\t\tisOwn = !!desc;\n\n\t\t\t\t// By convention, when a data property is converted to an accessor\n\t\t\t\t// property to emulate a data property that does not suffer from\n\t\t\t\t// the override mistake, that accessor's getter is marked with\n\t\t\t\t// an `originalValue` property. Here, when we detect this, we\n\t\t\t\t// uphold the illusion by pretending to see that original data\n\t\t\t\t// property, i.e., returning the value rather than the getter\n\t\t\t\t// itself.\n\t\t\t\tif (isOwn && 'get' in desc && !('originalValue' in desc.get)) {\n\t\t\t\t\tvalue = desc.get;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = value[part];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tisOwn = hasOwn(value, part);\n\t\t\t\tvalue = value[part];\n\t\t\t}\n\n\t\t\tif (isOwn && !skipFurtherCaching) {\n\t\t\t\tINTRINSICS[intrinsicRealName] = value;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n","'use strict';\n\nvar origSymbol = typeof Symbol !== 'undefined' && Symbol;\nvar hasSymbolSham = require('./shams');\n\nmodule.exports = function hasNativeSymbols() {\n\tif (typeof origSymbol !== 'function') { return false; }\n\tif (typeof Symbol !== 'function') { return false; }\n\tif (typeof origSymbol('foo') !== 'symbol') { return false; }\n\tif (typeof Symbol('bar') !== 'symbol') { return false; }\n\n\treturn hasSymbolSham();\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = Function.prototype.bind || implementation;\n","'use strict';\n\n/* eslint no-invalid-this: 1 */\n\nvar ERROR_MESSAGE = 'Function.prototype.bind called on incompatible ';\nvar slice = Array.prototype.slice;\nvar toStr = Object.prototype.toString;\nvar funcType = '[object Function]';\n\nmodule.exports = function bind(that) {\n var target = this;\n if (typeof target !== 'function' || toStr.call(target) !== funcType) {\n throw new TypeError(ERROR_MESSAGE + target);\n }\n var args = slice.call(arguments, 1);\n\n var bound;\n var binder = function () {\n if (this instanceof bound) {\n var result = target.apply(\n this,\n args.concat(slice.call(arguments))\n );\n if (Object(result) === result) {\n return result;\n }\n return this;\n } else {\n return target.apply(\n that,\n args.concat(slice.call(arguments))\n );\n }\n };\n\n var boundLength = Math.max(0, target.length - args.length);\n var boundArgs = [];\n for (var i = 0; i < boundLength; i++) {\n boundArgs.push('$' + i);\n }\n\n bound = Function('binder', 'return function (' + boundArgs.join(',') + '){ return binder.apply(this,arguments); }')(binder);\n\n if (target.prototype) {\n var Empty = function Empty() {};\n Empty.prototype = target.prototype;\n bound.prototype = new Empty();\n Empty.prototype = null;\n }\n\n return bound;\n};\n","'use strict';\n\nvar bind = require('function-bind');\n\nmodule.exports = bind.call(Function.call, Object.prototype.hasOwnProperty);\n","'use strict';\n\nvar bind = require('function-bind');\nvar GetIntrinsic = require('get-intrinsic');\n\nvar $apply = GetIntrinsic('%Function.prototype.apply%');\nvar $call = GetIntrinsic('%Function.prototype.call%');\nvar $reflectApply = GetIntrinsic('%Reflect.apply%', true) || bind.call($call, $apply);\n\nvar $gOPD = GetIntrinsic('%Object.getOwnPropertyDescriptor%', true);\nvar $defineProperty = GetIntrinsic('%Object.defineProperty%', true);\nvar $max = GetIntrinsic('%Math.max%');\n\nif ($defineProperty) {\n\ttry {\n\t\t$defineProperty({}, 'a', { value: 1 });\n\t} catch (e) {\n\t\t// IE 8 has a broken defineProperty\n\t\t$defineProperty = null;\n\t}\n}\n\nmodule.exports = function callBind(originalFunction) {\n\tvar func = $reflectApply(bind, $call, arguments);\n\tif ($gOPD && $defineProperty) {\n\t\tvar desc = $gOPD(func, 'length');\n\t\tif (desc.configurable) {\n\t\t\t// original length, plus the receiver, minus any additional arguments (after the receiver)\n\t\t\t$defineProperty(\n\t\t\t\tfunc,\n\t\t\t\t'length',\n\t\t\t\t{ value: 1 + $max(0, originalFunction.length - (arguments.length - 1)) }\n\t\t\t);\n\t\t}\n\t}\n\treturn func;\n};\n\nvar applyBind = function applyBind() {\n\treturn $reflectApply(bind, $apply, arguments);\n};\n\nif ($defineProperty) {\n\t$defineProperty(module.exports, 'apply', { value: applyBind });\n} else {\n\tmodule.exports.apply = applyBind;\n}\n","'use strict';\n\nvar toStr = Object.prototype.toString;\nvar fnToStr = Function.prototype.toString;\nvar isFnRegex = /^\\s*(?:function)?\\*/;\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar getProto = Object.getPrototypeOf;\nvar getGeneratorFunc = function () { // eslint-disable-line consistent-return\n\tif (!hasToStringTag) {\n\t\treturn false;\n\t}\n\ttry {\n\t\treturn Function('return function*() {}')();\n\t} catch (e) {\n\t}\n};\nvar GeneratorFunction;\n\nmodule.exports = function isGeneratorFunction(fn) {\n\tif (typeof fn !== 'function') {\n\t\treturn false;\n\t}\n\tif (isFnRegex.test(fnToStr.call(fn))) {\n\t\treturn true;\n\t}\n\tif (!hasToStringTag) {\n\t\tvar str = toStr.call(fn);\n\t\treturn str === '[object GeneratorFunction]';\n\t}\n\tif (!getProto) {\n\t\treturn false;\n\t}\n\tif (typeof GeneratorFunction === 'undefined') {\n\t\tvar generatorFunc = getGeneratorFunc();\n\t\tGeneratorFunction = generatorFunc ? getProto(generatorFunc) : false;\n\t}\n\treturn getProto(fn) === GeneratorFunction;\n};\n","'use strict';\n\nvar forEach = require('foreach');\nvar availableTypedArrays = require('available-typed-arrays');\nvar callBound = require('call-bind/callBound');\n\nvar $toString = callBound('Object.prototype.toString');\nvar hasToStringTag = require('has-tostringtag/shams')();\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\nvar typedArrays = availableTypedArrays();\n\nvar $slice = callBound('String.prototype.slice');\nvar toStrTags = {};\nvar gOPD = require('es-abstract/helpers/getOwnPropertyDescriptor');\nvar getPrototypeOf = Object.getPrototypeOf; // require('getprototypeof');\nif (hasToStringTag && gOPD && getPrototypeOf) {\n\tforEach(typedArrays, function (typedArray) {\n\t\tif (typeof g[typedArray] === 'function') {\n\t\t\tvar arr = new g[typedArray]();\n\t\t\tif (Symbol.toStringTag in arr) {\n\t\t\t\tvar proto = getPrototypeOf(arr);\n\t\t\t\tvar descriptor = gOPD(proto, Symbol.toStringTag);\n\t\t\t\tif (!descriptor) {\n\t\t\t\t\tvar superProto = getPrototypeOf(proto);\n\t\t\t\t\tdescriptor = gOPD(superProto, Symbol.toStringTag);\n\t\t\t\t}\n\t\t\t\ttoStrTags[typedArray] = descriptor.get;\n\t\t\t}\n\t\t}\n\t});\n}\n\nvar tryTypedArrays = function tryAllTypedArrays(value) {\n\tvar foundName = false;\n\tforEach(toStrTags, function (getter, typedArray) {\n\t\tif (!foundName) {\n\t\t\ttry {\n\t\t\t\tvar name = getter.call(value);\n\t\t\t\tif (name === typedArray) {\n\t\t\t\t\tfoundName = name;\n\t\t\t\t}\n\t\t\t} catch (e) {}\n\t\t}\n\t});\n\treturn foundName;\n};\n\nvar isTypedArray = require('is-typed-array');\n\nmodule.exports = function whichTypedArray(value) {\n\tif (!isTypedArray(value)) { return false; }\n\tif (!hasToStringTag || !(Symbol.toStringTag in value)) { return $slice($toString(value), 8, -1); }\n\treturn tryTypedArrays(value);\n};\n","\nvar hasOwn = Object.prototype.hasOwnProperty;\nvar toString = Object.prototype.toString;\n\nmodule.exports = function forEach (obj, fn, ctx) {\n if (toString.call(fn) !== '[object Function]') {\n throw new TypeError('iterator must be a function');\n }\n var l = obj.length;\n if (l === +l) {\n for (var i = 0; i < l; i++) {\n fn.call(ctx, obj[i], i, obj);\n }\n } else {\n for (var k in obj) {\n if (hasOwn.call(obj, k)) {\n fn.call(ctx, obj[k], k, obj);\n }\n }\n }\n};\n\n","'use strict';\n\nvar possibleNames = [\n\t'BigInt64Array',\n\t'BigUint64Array',\n\t'Float32Array',\n\t'Float64Array',\n\t'Int16Array',\n\t'Int32Array',\n\t'Int8Array',\n\t'Uint16Array',\n\t'Uint32Array',\n\t'Uint8Array',\n\t'Uint8ClampedArray'\n];\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\n\nmodule.exports = function availableTypedArrays() {\n\tvar out = [];\n\tfor (var i = 0; i < possibleNames.length; i++) {\n\t\tif (typeof g[possibleNames[i]] === 'function') {\n\t\t\tout[out.length] = possibleNames[i];\n\t\t}\n\t}\n\treturn out;\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar $gOPD = GetIntrinsic('%Object.getOwnPropertyDescriptor%', true);\nif ($gOPD) {\n\ttry {\n\t\t$gOPD([], 'length');\n\t} catch (e) {\n\t\t// IE 8 has a broken gOPD\n\t\t$gOPD = null;\n\t}\n}\n\nmodule.exports = $gOPD;\n","'use strict';\n\nvar forEach = require('foreach');\nvar availableTypedArrays = require('available-typed-arrays');\nvar callBound = require('call-bind/callBound');\n\nvar $toString = callBound('Object.prototype.toString');\nvar hasToStringTag = require('has-tostringtag/shams')();\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\nvar typedArrays = availableTypedArrays();\n\nvar $indexOf = callBound('Array.prototype.indexOf', true) || function indexOf(array, value) {\n\tfor (var i = 0; i < array.length; i += 1) {\n\t\tif (array[i] === value) {\n\t\t\treturn i;\n\t\t}\n\t}\n\treturn -1;\n};\nvar $slice = callBound('String.prototype.slice');\nvar toStrTags = {};\nvar gOPD = require('es-abstract/helpers/getOwnPropertyDescriptor');\nvar getPrototypeOf = Object.getPrototypeOf; // require('getprototypeof');\nif (hasToStringTag && gOPD && getPrototypeOf) {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tif (Symbol.toStringTag in arr) {\n\t\t\tvar proto = getPrototypeOf(arr);\n\t\t\tvar descriptor = gOPD(proto, Symbol.toStringTag);\n\t\t\tif (!descriptor) {\n\t\t\t\tvar superProto = getPrototypeOf(proto);\n\t\t\t\tdescriptor = gOPD(superProto, Symbol.toStringTag);\n\t\t\t}\n\t\t\ttoStrTags[typedArray] = descriptor.get;\n\t\t}\n\t});\n}\n\nvar tryTypedArrays = function tryAllTypedArrays(value) {\n\tvar anyTrue = false;\n\tforEach(toStrTags, function (getter, typedArray) {\n\t\tif (!anyTrue) {\n\t\t\ttry {\n\t\t\t\tanyTrue = getter.call(value) === typedArray;\n\t\t\t} catch (e) { /**/ }\n\t\t}\n\t});\n\treturn anyTrue;\n};\n\nmodule.exports = function isTypedArray(value) {\n\tif (!value || typeof value !== 'object') { return false; }\n\tif (!hasToStringTag || !(Symbol.toStringTag in value)) {\n\t\tvar tag = $slice($toString(value), 8, -1);\n\t\treturn $indexOf(typedArrays, tag) > -1;\n\t}\n\tif (!gOPD) { return false; }\n\treturn tryTypedArrays(value);\n};\n","module.exports = function isBuffer(arg) {\n return arg && typeof arg === 'object'\n && typeof arg.copy === 'function'\n && typeof arg.fill === 'function'\n && typeof arg.readUInt8 === 'function';\n}","'use strict'\n\nconst { AbstractLevelDOWN } = require('abstract-leveldown')\nconst inherits = require('inherits')\nconst DeferredIterator = require('./deferred-iterator')\nconst DeferredChainedBatch = require('./deferred-chained-batch')\nconst getCallback = require('./util').getCallback\n\nconst deferrables = ['put', 'get', 'getMany', 'del', 'batch', 'clear']\nconst optionalDeferrables = ['approximateSize', 'compactRange']\n\nconst kInnerDb = Symbol('innerDb')\nconst kOperations = Symbol('operations')\nconst kPromise = Symbol('promise')\n\nfunction DeferredLevelDOWN (db) {\n AbstractLevelDOWN.call(this, db.supports || {})\n\n // TODO (future major): remove this fallback; db must have manifest that\n // declares approximateSize and compactRange in additionalMethods.\n for (const m of optionalDeferrables) {\n if (typeof db[m] === 'function' && !this.supports.additionalMethods[m]) {\n this.supports.additionalMethods[m] = true\n }\n }\n\n this[kInnerDb] = db\n this[kOperations] = []\n\n implement(this)\n}\n\ninherits(DeferredLevelDOWN, AbstractLevelDOWN)\n\nDeferredLevelDOWN.prototype.type = 'deferred-leveldown'\n\n// Backwards compatibility for reachdown and subleveldown\nObject.defineProperty(DeferredLevelDOWN.prototype, '_db', {\n enumerable: true,\n get () {\n return this[kInnerDb]\n }\n})\n\nDeferredLevelDOWN.prototype._open = function (options, callback) {\n const onopen = (err) => {\n if (err || this[kInnerDb].status !== 'open') {\n // TODO: reject scheduled operations\n return callback(err || new Error('Database is not open'))\n }\n\n const operations = this[kOperations]\n this[kOperations] = []\n\n for (const op of operations) {\n if (op.iterator) {\n op.iterator.setDb(this[kInnerDb])\n } else {\n this[kInnerDb][op.method](...op.args)\n }\n }\n\n /* istanbul ignore if: assertion */\n if (this[kOperations].length > 0) {\n throw new Error('Did not expect further operations')\n }\n\n callback()\n }\n\n if (this[kInnerDb].status === 'new' || this[kInnerDb].status === 'closed') {\n this[kInnerDb].open(options, onopen)\n } else {\n this._nextTick(onopen)\n }\n}\n\nDeferredLevelDOWN.prototype._close = function (callback) {\n this[kInnerDb].close(callback)\n}\n\nDeferredLevelDOWN.prototype._isOperational = function () {\n return this.status === 'opening'\n}\n\nfunction implement (self) {\n const additionalMethods = Object.keys(self.supports.additionalMethods)\n\n for (const method of deferrables.concat(additionalMethods)) {\n // Override the public rather than private methods to cover cases where abstract-leveldown\n // has a fast-path like on db.batch([]) which bypasses _batch() because the array is empty.\n self[method] = function (...args) {\n if (method === 'batch' && args.length === 0) {\n return new DeferredChainedBatch(this)\n } else if (this.status === 'open') {\n return this[kInnerDb][method](...args)\n }\n\n const callback = getCallback(args, kPromise)\n\n if (this.status === 'opening') {\n this[kOperations].push({ method, args })\n } else {\n this._nextTick(callback, new Error('Database is not open'))\n }\n\n return callback[kPromise]\n }\n }\n\n self.iterator = function (options) {\n if (this.status === 'open') {\n return this[kInnerDb].iterator(options)\n } else if (this.status === 'opening') {\n const iterator = new DeferredIterator(this, options)\n this[kOperations].push({ iterator })\n return iterator\n } else {\n throw new Error('Database is not open')\n }\n }\n\n for (const method of deferrables.concat(['iterator'])) {\n self['_' + method] = function () {\n /* istanbul ignore next: assertion */\n throw new Error('Did not expect private method to be called: ' + method)\n }\n }\n}\n\nmodule.exports = DeferredLevelDOWN\nmodule.exports.DeferredIterator = DeferredIterator\n","'use strict'\n\nexports.AbstractLevelDOWN = require('./abstract-leveldown')\nexports.AbstractIterator = require('./abstract-iterator')\nexports.AbstractChainedBatch = require('./abstract-chained-batch')\n","'use strict'\n\nconst supports = require('level-supports')\nconst isBuffer = require('is-buffer')\nconst catering = require('catering')\nconst AbstractIterator = require('./abstract-iterator')\nconst AbstractChainedBatch = require('./abstract-chained-batch')\nconst getCallback = require('./lib/common').getCallback\nconst getOptions = require('./lib/common').getOptions\n\nconst hasOwnProperty = Object.prototype.hasOwnProperty\nconst rangeOptions = ['lt', 'lte', 'gt', 'gte']\n\nfunction AbstractLevelDOWN (manifest) {\n this.status = 'new'\n\n // TODO (next major): make this mandatory\n this.supports = supports(manifest, {\n status: true\n })\n}\n\nAbstractLevelDOWN.prototype.open = function (options, callback) {\n const oldStatus = this.status\n\n if (typeof options === 'function') callback = options\n\n if (typeof callback !== 'function') {\n throw new Error('open() requires a callback argument')\n }\n\n if (typeof options !== 'object' || options === null) options = {}\n\n options.createIfMissing = options.createIfMissing !== false\n options.errorIfExists = !!options.errorIfExists\n\n this.status = 'opening'\n this._open(options, (err) => {\n if (err) {\n this.status = oldStatus\n return callback(err)\n }\n this.status = 'open'\n callback()\n })\n}\n\nAbstractLevelDOWN.prototype._open = function (options, callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.close = function (callback) {\n const oldStatus = this.status\n\n if (typeof callback !== 'function') {\n throw new Error('close() requires a callback argument')\n }\n\n this.status = 'closing'\n this._close((err) => {\n if (err) {\n this.status = oldStatus\n return callback(err)\n }\n this.status = 'closed'\n callback()\n })\n}\n\nAbstractLevelDOWN.prototype._close = function (callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.get = function (key, options, callback) {\n if (typeof options === 'function') callback = options\n\n if (typeof callback !== 'function') {\n throw new Error('get() requires a callback argument')\n }\n\n const err = this._checkKey(key)\n if (err) return this._nextTick(callback, err)\n\n key = this._serializeKey(key)\n\n if (typeof options !== 'object' || options === null) options = {}\n\n options.asBuffer = options.asBuffer !== false\n\n this._get(key, options, callback)\n}\n\nAbstractLevelDOWN.prototype._get = function (key, options, callback) {\n this._nextTick(function () { callback(new Error('NotFound')) })\n}\n\nAbstractLevelDOWN.prototype.getMany = function (keys, options, callback) {\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n options = getOptions(options)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n if (!Array.isArray(keys)) {\n this._nextTick(callback, new Error('getMany() requires an array argument'))\n return callback.promise\n }\n\n if (keys.length === 0) {\n this._nextTick(callback, null, [])\n return callback.promise\n }\n\n if (typeof options.asBuffer !== 'boolean') {\n options = { ...options, asBuffer: true }\n }\n\n const serialized = new Array(keys.length)\n\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i]\n const err = this._checkKey(key)\n\n if (err) {\n this._nextTick(callback, err)\n return callback.promise\n }\n\n serialized[i] = this._serializeKey(key)\n }\n\n this._getMany(serialized, options, callback)\n return callback.promise\n}\n\nAbstractLevelDOWN.prototype._getMany = function (keys, options, callback) {\n this._nextTick(callback, null, new Array(keys.length).fill(undefined))\n}\n\nAbstractLevelDOWN.prototype.put = function (key, value, options, callback) {\n if (typeof options === 'function') callback = options\n\n if (typeof callback !== 'function') {\n throw new Error('put() requires a callback argument')\n }\n\n const err = this._checkKey(key) || this._checkValue(value)\n if (err) return this._nextTick(callback, err)\n\n key = this._serializeKey(key)\n value = this._serializeValue(value)\n\n if (typeof options !== 'object' || options === null) options = {}\n\n this._put(key, value, options, callback)\n}\n\nAbstractLevelDOWN.prototype._put = function (key, value, options, callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.del = function (key, options, callback) {\n if (typeof options === 'function') callback = options\n\n if (typeof callback !== 'function') {\n throw new Error('del() requires a callback argument')\n }\n\n const err = this._checkKey(key)\n if (err) return this._nextTick(callback, err)\n\n key = this._serializeKey(key)\n\n if (typeof options !== 'object' || options === null) options = {}\n\n this._del(key, options, callback)\n}\n\nAbstractLevelDOWN.prototype._del = function (key, options, callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.batch = function (array, options, callback) {\n if (!arguments.length) return this._chainedBatch()\n\n if (typeof options === 'function') callback = options\n\n if (typeof array === 'function') callback = array\n\n if (typeof callback !== 'function') {\n throw new Error('batch(array) requires a callback argument')\n }\n\n if (!Array.isArray(array)) {\n return this._nextTick(callback, new Error('batch(array) requires an array argument'))\n }\n\n if (array.length === 0) {\n return this._nextTick(callback)\n }\n\n if (typeof options !== 'object' || options === null) options = {}\n\n const serialized = new Array(array.length)\n\n for (let i = 0; i < array.length; i++) {\n if (typeof array[i] !== 'object' || array[i] === null) {\n return this._nextTick(callback, new Error('batch(array) element must be an object and not `null`'))\n }\n\n const e = Object.assign({}, array[i])\n\n if (e.type !== 'put' && e.type !== 'del') {\n return this._nextTick(callback, new Error(\"`type` must be 'put' or 'del'\"))\n }\n\n const err = this._checkKey(e.key)\n if (err) return this._nextTick(callback, err)\n\n e.key = this._serializeKey(e.key)\n\n if (e.type === 'put') {\n const valueErr = this._checkValue(e.value)\n if (valueErr) return this._nextTick(callback, valueErr)\n\n e.value = this._serializeValue(e.value)\n }\n\n serialized[i] = e\n }\n\n this._batch(serialized, options, callback)\n}\n\nAbstractLevelDOWN.prototype._batch = function (array, options, callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.clear = function (options, callback) {\n if (typeof options === 'function') {\n callback = options\n } else if (typeof callback !== 'function') {\n throw new Error('clear() requires a callback argument')\n }\n\n options = cleanRangeOptions(this, options)\n options.reverse = !!options.reverse\n options.limit = 'limit' in options ? options.limit : -1\n\n this._clear(options, callback)\n}\n\nAbstractLevelDOWN.prototype._clear = function (options, callback) {\n // Avoid setupIteratorOptions, would serialize range options a second time.\n options.keys = true\n options.values = false\n options.keyAsBuffer = true\n options.valueAsBuffer = true\n\n const iterator = this._iterator(options)\n const emptyOptions = {}\n\n const next = (err) => {\n if (err) {\n return iterator.end(function () {\n callback(err)\n })\n }\n\n iterator.next((err, key) => {\n if (err) return next(err)\n if (key === undefined) return iterator.end(callback)\n\n // This could be optimized by using a batch, but the default _clear\n // is not meant to be fast. Implementations have more room to optimize\n // if they override _clear. Note: using _del bypasses key serialization.\n this._del(key, emptyOptions, next)\n })\n }\n\n next()\n}\n\nAbstractLevelDOWN.prototype._setupIteratorOptions = function (options) {\n options = cleanRangeOptions(this, options)\n\n options.reverse = !!options.reverse\n options.keys = options.keys !== false\n options.values = options.values !== false\n options.limit = 'limit' in options ? options.limit : -1\n options.keyAsBuffer = options.keyAsBuffer !== false\n options.valueAsBuffer = options.valueAsBuffer !== false\n\n return options\n}\n\nfunction cleanRangeOptions (db, options) {\n const result = {}\n\n for (const k in options) {\n if (!hasOwnProperty.call(options, k)) continue\n\n if (k === 'start' || k === 'end') {\n throw new Error('Legacy range options (\"start\" and \"end\") have been removed')\n }\n\n let opt = options[k]\n\n if (isRangeOption(k)) {\n // Note that we don't reject nullish and empty options here. While\n // those types are invalid as keys, they are valid as range options.\n opt = db._serializeKey(opt)\n }\n\n result[k] = opt\n }\n\n return result\n}\n\nfunction isRangeOption (k) {\n return rangeOptions.indexOf(k) !== -1\n}\n\nAbstractLevelDOWN.prototype.iterator = function (options) {\n if (typeof options !== 'object' || options === null) options = {}\n options = this._setupIteratorOptions(options)\n return this._iterator(options)\n}\n\nAbstractLevelDOWN.prototype._iterator = function (options) {\n return new AbstractIterator(this)\n}\n\nAbstractLevelDOWN.prototype._chainedBatch = function () {\n return new AbstractChainedBatch(this)\n}\n\nAbstractLevelDOWN.prototype._serializeKey = function (key) {\n return key\n}\n\nAbstractLevelDOWN.prototype._serializeValue = function (value) {\n return value\n}\n\nAbstractLevelDOWN.prototype._checkKey = function (key) {\n if (key === null || key === undefined) {\n return new Error('key cannot be `null` or `undefined`')\n } else if (isBuffer(key) && key.length === 0) { // TODO: replace with typed array check\n return new Error('key cannot be an empty Buffer')\n } else if (key === '') {\n return new Error('key cannot be an empty String')\n } else if (Array.isArray(key) && key.length === 0) {\n return new Error('key cannot be an empty Array')\n }\n}\n\nAbstractLevelDOWN.prototype._checkValue = function (value) {\n if (value === null || value === undefined) {\n return new Error('value cannot be `null` or `undefined`')\n }\n}\n\n// TODO: docs and tests\nAbstractLevelDOWN.prototype.isOperational = function () {\n return this.status === 'open' || this._isOperational()\n}\n\n// Implementation may accept operations in other states too\nAbstractLevelDOWN.prototype._isOperational = function () {\n return false\n}\n\n// Expose browser-compatible nextTick for dependents\n// TODO: rename _nextTick to _queueMicrotask\n// TODO: after we drop node 10, also use queueMicrotask in node\nAbstractLevelDOWN.prototype._nextTick = require('./next-tick')\n\nmodule.exports = AbstractLevelDOWN\n\nfunction maybeError (db, callback) {\n if (!db.isOperational()) {\n db._nextTick(callback, new Error('Database is not open'))\n return true\n }\n\n return false\n}\n","'use strict'\n\nmodule.exports = function supports (...manifests) {\n const manifest = manifests.reduce((acc, m) => Object.assign(acc, m), {})\n\n return Object.assign(manifest, {\n // Features of abstract-leveldown\n bufferKeys: manifest.bufferKeys || false,\n snapshots: manifest.snapshots || false,\n permanence: manifest.permanence || false,\n seek: manifest.seek || false,\n clear: manifest.clear || false,\n getMany: manifest.getMany || false,\n keyIterator: manifest.keyIterator || false,\n valueIterator: manifest.valueIterator || false,\n iteratorNextv: manifest.iteratorNextv || false,\n iteratorAll: manifest.iteratorAll || false,\n\n // Features of abstract-leveldown that levelup doesn't have\n status: manifest.status || false,\n idempotentOpen: manifest.idempotentOpen || false,\n passiveOpen: manifest.passiveOpen || false,\n serialize: manifest.serialize || false,\n\n // Features of disk-based implementations\n createIfMissing: manifest.createIfMissing || false,\n errorIfExists: manifest.errorIfExists || false,\n\n // Features of level(up) that abstract-leveldown doesn't have yet\n deferredOpen: manifest.deferredOpen || false,\n openCallback: manifest.openCallback || false,\n promises: manifest.promises || false,\n streams: manifest.streams || false,\n encodings: maybeObject(manifest.encodings),\n events: maybeObject(manifest.events),\n\n // Methods that are not part of abstract-leveldown or levelup\n additionalMethods: Object.assign({}, manifest.additionalMethods)\n })\n}\n\nfunction maybeObject (value) {\n return !value ? false : Object.assign({}, value)\n}\n","/*!\n * Determine if an object is a Buffer\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n\nmodule.exports = function isBuffer (obj) {\n return obj != null && obj.constructor != null &&\n typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n","'use strict'\n\nvar queueTick = require('queue-tick')\n\nexports.fromCallback = function (callback, symbol) {\n if (callback === undefined) {\n var promise = new Promise(function (resolve, reject) {\n callback = function (err, res) {\n if (err) reject(err)\n else resolve(res)\n }\n })\n\n callback[symbol !== undefined ? symbol : 'promise'] = promise\n } else if (typeof callback !== 'function') {\n throw new TypeError('Callback must be a function')\n }\n\n return callback\n}\n\nexports.fromPromise = function (promise, callback) {\n if (callback === undefined) return promise\n\n promise\n .then(function (res) { queueTick(() => callback(null, res)) })\n .catch(function (err) { queueTick(() => callback(err)) })\n}\n","module.exports = typeof queueMicrotask === 'function' ? queueMicrotask : (fn) => Promise.resolve().then(fn)\n","'use strict'\n\nfunction AbstractIterator (db) {\n if (typeof db !== 'object' || db === null) {\n throw new TypeError('First argument must be an abstract-leveldown compliant store')\n }\n\n this.db = db\n this._ended = false\n this._nexting = false\n}\n\nAbstractIterator.prototype.next = function (callback) {\n // In callback mode, we return `this`\n let ret = this\n\n if (callback === undefined) {\n ret = new Promise(function (resolve, reject) {\n callback = function (err, key, value) {\n if (err) reject(err)\n else if (key === undefined && value === undefined) resolve()\n else resolve([key, value])\n }\n })\n } else if (typeof callback !== 'function') {\n throw new Error('next() requires a callback argument')\n }\n\n if (this._ended) {\n this._nextTick(callback, new Error('cannot call next() after end()'))\n return ret\n }\n\n if (this._nexting) {\n this._nextTick(callback, new Error('cannot call next() before previous next() has completed'))\n return ret\n }\n\n this._nexting = true\n this._next((err, ...rest) => {\n this._nexting = false\n callback(err, ...rest)\n })\n\n return ret\n}\n\nAbstractIterator.prototype._next = function (callback) {\n this._nextTick(callback)\n}\n\nAbstractIterator.prototype.seek = function (target) {\n if (this._ended) {\n throw new Error('cannot call seek() after end()')\n }\n if (this._nexting) {\n throw new Error('cannot call seek() before next() has completed')\n }\n\n target = this.db._serializeKey(target)\n this._seek(target)\n}\n\nAbstractIterator.prototype._seek = function (target) {}\n\nAbstractIterator.prototype.end = function (callback) {\n let promise\n\n if (callback === undefined) {\n promise = new Promise(function (resolve, reject) {\n callback = function (err) {\n if (err) reject(err)\n else resolve()\n }\n })\n } else if (typeof callback !== 'function') {\n throw new Error('end() requires a callback argument')\n }\n\n if (this._ended) {\n this._nextTick(callback, new Error('end() already called on iterator'))\n return promise\n }\n\n this._ended = true\n this._end(callback)\n\n return promise\n}\n\nAbstractIterator.prototype._end = function (callback) {\n this._nextTick(callback)\n}\n\nAbstractIterator.prototype[Symbol.asyncIterator] = async function * () {\n try {\n let kv\n\n while ((kv = (await this.next())) !== undefined) {\n yield kv\n }\n } finally {\n if (!this._ended) await this.end()\n }\n}\n\n// Expose browser-compatible nextTick for dependents\nAbstractIterator.prototype._nextTick = require('./next-tick')\n\nmodule.exports = AbstractIterator\n","'use strict'\n\nconst queueMicrotask = require('queue-microtask')\n\nmodule.exports = function (fn, ...args) {\n if (args.length === 0) {\n queueMicrotask(fn)\n } else {\n queueMicrotask(() => fn(...args))\n }\n}\n","/*! queue-microtask. MIT License. Feross Aboukhadijeh */\nlet promise\n\nmodule.exports = typeof queueMicrotask === 'function'\n ? queueMicrotask.bind(typeof window !== 'undefined' ? window : global)\n // reuse resolved promise, and allocate it lazily\n : cb => (promise || (promise = Promise.resolve()))\n .then(cb)\n .catch(err => setTimeout(() => { throw err }, 0))\n","'use strict'\n\nconst emptyOptions = Object.freeze({})\n\nfunction AbstractChainedBatch (db) {\n if (typeof db !== 'object' || db === null) {\n throw new TypeError('First argument must be an abstract-leveldown compliant store')\n }\n\n this.db = db\n this._operations = []\n this._written = false\n}\n\nAbstractChainedBatch.prototype._checkWritten = function () {\n if (this._written) {\n throw new Error('write() already called on this batch')\n }\n}\n\nAbstractChainedBatch.prototype.put = function (key, value, options) {\n this._checkWritten()\n\n const err = this.db._checkKey(key) || this.db._checkValue(value)\n if (err) throw err\n\n key = this.db._serializeKey(key)\n value = this.db._serializeValue(value)\n\n this._put(key, value, options != null ? options : emptyOptions)\n\n return this\n}\n\nAbstractChainedBatch.prototype._put = function (key, value, options) {\n this._operations.push({ ...options, type: 'put', key, value })\n}\n\nAbstractChainedBatch.prototype.del = function (key, options) {\n this._checkWritten()\n\n const err = this.db._checkKey(key)\n if (err) throw err\n\n key = this.db._serializeKey(key)\n this._del(key, options != null ? options : emptyOptions)\n\n return this\n}\n\nAbstractChainedBatch.prototype._del = function (key, options) {\n this._operations.push({ ...options, type: 'del', key })\n}\n\nAbstractChainedBatch.prototype.clear = function () {\n this._checkWritten()\n this._clear()\n\n return this\n}\n\nAbstractChainedBatch.prototype._clear = function () {\n this._operations = []\n}\n\nAbstractChainedBatch.prototype.write = function (options, callback) {\n this._checkWritten()\n\n if (typeof options === 'function') {\n callback = options\n }\n if (typeof callback !== 'function') {\n throw new Error('write() requires a callback argument')\n }\n if (typeof options !== 'object' || options === null) {\n options = {}\n }\n\n this._written = true\n this._write(options, callback)\n}\n\nAbstractChainedBatch.prototype._write = function (options, callback) {\n this.db._batch(this._operations, options, callback)\n}\n\n// Expose browser-compatible nextTick for dependents\nAbstractChainedBatch.prototype._nextTick = require('./next-tick')\n\nmodule.exports = AbstractChainedBatch\n","'use strict'\n\nexports.getCallback = function (options, callback) {\n return typeof options === 'function' ? options : callback\n}\n\nexports.getOptions = function (options) {\n return typeof options === 'object' && options !== null ? options : {}\n}\n","'use strict'\n\nconst { AbstractIterator } = require('abstract-leveldown')\nconst inherits = require('inherits')\nconst getCallback = require('./util').getCallback\n\nconst kOptions = Symbol('options')\nconst kIterator = Symbol('iterator')\nconst kOperations = Symbol('operations')\nconst kPromise = Symbol('promise')\n\nfunction DeferredIterator (db, options) {\n AbstractIterator.call(this, db)\n\n this[kOptions] = options\n this[kIterator] = null\n this[kOperations] = []\n}\n\ninherits(DeferredIterator, AbstractIterator)\n\nDeferredIterator.prototype.setDb = function (db) {\n this[kIterator] = db.iterator(this[kOptions])\n\n for (const op of this[kOperations].splice(0, this[kOperations].length)) {\n this[kIterator][op.method](...op.args)\n }\n}\n\nDeferredIterator.prototype.next = function (...args) {\n if (this.db.status === 'open') {\n return this[kIterator].next(...args)\n }\n\n const callback = getCallback(args, kPromise, function map (key, value) {\n if (key === undefined && value === undefined) {\n return undefined\n } else {\n return [key, value]\n }\n })\n\n if (this.db.status === 'opening') {\n this[kOperations].push({ method: 'next', args })\n } else {\n this._nextTick(callback, new Error('Database is not open'))\n }\n\n return callback[kPromise] || this\n}\n\nDeferredIterator.prototype.seek = function (...args) {\n if (this.db.status === 'open') {\n this[kIterator].seek(...args)\n } else if (this.db.status === 'opening') {\n this[kOperations].push({ method: 'seek', args })\n } else {\n throw new Error('Database is not open')\n }\n}\n\nDeferredIterator.prototype.end = function (...args) {\n if (this.db.status === 'open') {\n return this[kIterator].end(...args)\n }\n\n const callback = getCallback(args, kPromise)\n\n if (this.db.status === 'opening') {\n this[kOperations].push({ method: 'end', args })\n } else {\n this._nextTick(callback, new Error('Database is not open'))\n }\n\n return callback[kPromise] || this\n}\n\nfor (const method of ['next', 'seek', 'end']) {\n DeferredIterator.prototype['_' + method] = function () {\n /* istanbul ignore next: assertion */\n throw new Error('Did not expect private method to be called: ' + method)\n }\n}\n\nmodule.exports = DeferredIterator\n","'use strict'\n\nexports.getCallback = function (args, symbol, map) {\n let callback = args[args.length - 1]\n\n if (typeof callback !== 'function') {\n const promise = new Promise((resolve, reject) => {\n args.push(callback = function (err, ...results) {\n if (err) reject(err)\n else resolve(map ? map(...results) : results[0])\n })\n })\n\n callback[symbol] = promise\n }\n\n return callback\n}\n","'use strict'\n\nconst { AbstractChainedBatch } = require('abstract-leveldown')\nconst kOperations = Symbol('operations')\n\nmodule.exports = class DeferredChainedBatch extends AbstractChainedBatch {\n constructor (db) {\n super(db)\n this[kOperations] = []\n }\n\n _put (key, value, options) {\n this[kOperations].push({ ...options, type: 'put', key, value })\n }\n\n _del (key, options) {\n this[kOperations].push({ ...options, type: 'del', key })\n }\n\n _clear () {\n this[kOperations] = []\n }\n\n _write (options, callback) {\n // AbstractChainedBatch would call _batch(), we call batch()\n this.db.batch(this[kOperations], options, callback)\n }\n}\n","'use strict'\n\nconst inherits = require('inherits')\nconst { Readable } = require('readable-stream')\n\nmodule.exports = ReadStream\ninherits(ReadStream, Readable)\n\nfunction ReadStream (iterator, options) {\n if (!(this instanceof ReadStream)) return new ReadStream(iterator, options)\n options = options || {}\n Readable.call(this, Object.assign({}, options, {\n objectMode: true\n }))\n this._iterator = iterator\n this._options = options\n this.on('end', this.destroy.bind(this, null, null))\n}\n\nReadStream.prototype._read = function () {\n if (this.destroyed) return\n\n this._iterator.next((err, key, value) => {\n if (this.destroyed) return\n if (err) return this.destroy(err)\n\n if (key === undefined && value === undefined) {\n this.push(null)\n } else if (this._options.keys !== false && this._options.values === false) {\n this.push(key)\n } else if (this._options.keys === false && this._options.values !== false) {\n this.push(value)\n } else {\n this.push({ key, value })\n }\n })\n}\n\nReadStream.prototype._destroy = function (err, callback) {\n this._iterator.end(function (err2) {\n callback(err || err2)\n })\n}\n","exports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = exports;\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\nexports.finished = require('./lib/internal/streams/end-of-stream.js');\nexports.pipeline = require('./lib/internal/streams/pipeline.js');\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n'use strict';\n\nmodule.exports = Readable;\n/**/\n\nvar Duplex;\n/**/\n\nReadable.ReadableState = ReadableState;\n/**/\n\nvar EE = require('events').EventEmitter;\n\nvar EElistenerCount = function EElistenerCount(emitter, type) {\n return emitter.listeners(type).length;\n};\n/**/\n\n/**/\n\n\nvar Stream = require('./internal/streams/stream');\n/**/\n\n\nvar Buffer = require('buffer').Buffer;\n\nvar OurUint8Array = global.Uint8Array || function () {};\n\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\n\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n/**/\n\n\nvar debugUtil = require('util');\n\nvar debug;\n\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function debug() {};\n}\n/**/\n\n\nvar BufferList = require('./internal/streams/buffer_list');\n\nvar destroyImpl = require('./internal/streams/destroy');\n\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\n\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT; // Lazy loaded to improve the startup performance.\n\n\nvar StringDecoder;\nvar createReadableStreamAsyncIterator;\nvar from;\n\nrequire('inherits')(Readable, Stream);\n\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\n\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn); // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\n\nfunction ReadableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {}; // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n\n this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex); // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false; // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n\n this.sync = true; // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n this.paused = true; // Should close be emitted on destroy. Defaults to true.\n\n this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'end' (and potentially 'finish')\n\n this.autoDestroy = !!options.autoDestroy; // has it been destroyed\n\n this.destroyed = false; // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n\n this.defaultEncoding = options.defaultEncoding || 'utf8'; // the number of writers that are awaiting a drain event in .pipe()s\n\n this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled\n\n this.readingMore = false;\n this.decoder = null;\n this.encoding = null;\n\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\n\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n if (!(this instanceof Readable)) return new Readable(options); // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5\n\n var isDuplex = this instanceof Duplex;\n this._readableState = new ReadableState(options, this, isDuplex); // legacy\n\n this.readable = true;\n\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n\n Stream.call(this);\n}\n\nObject.defineProperty(Readable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined) {\n return false;\n }\n\n return this._readableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n } // backward compatibility, the user is explicitly\n // managing destroyed\n\n\n this._readableState.destroyed = value;\n }\n});\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\n\nReadable.prototype._destroy = function (err, cb) {\n cb(err);\n}; // Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\n\n\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n}; // Unshift should *always* be something directly out of read()\n\n\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\n\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n debug('readableAddChunk', chunk);\n var state = stream._readableState;\n\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n\n if (er) {\n errorOrDestroy(stream, er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (addToFront) {\n if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());\n } else if (state.destroyed) {\n return false;\n } else {\n state.reading = false;\n\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n maybeReadMore(stream, state);\n }\n } // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n\n\n return !state.ended && (state.length < state.highWaterMark || state.length === 0);\n}\n\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n state.awaitDrain = 0;\n stream.emit('data', chunk);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n if (state.needReadable) emitReadable(stream);\n }\n\n maybeReadMore(stream, state);\n}\n\nfunction chunkInvalid(state, chunk) {\n var er;\n\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);\n }\n\n return er;\n}\n\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n}; // backwards compatibility.\n\n\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n var decoder = new StringDecoder(enc);\n this._readableState.decoder = decoder; // If setEncoding(null), decoder.encoding equals utf8\n\n this._readableState.encoding = this._readableState.decoder.encoding; // Iterate over current buffer to convert already stored Buffers:\n\n var p = this._readableState.buffer.head;\n var content = '';\n\n while (p !== null) {\n content += decoder.write(p.data);\n p = p.next;\n }\n\n this._readableState.buffer.clear();\n\n if (content !== '') this._readableState.buffer.push(content);\n this._readableState.length = content.length;\n return this;\n}; // Don't raise the hwm > 1GB\n\n\nvar MAX_HWM = 0x40000000;\n\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n\n return n;\n} // This function is designed to be inlinable, so please take care when making\n// changes to the function body.\n\n\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n } // If we're asking for more than the current hwm, then raise the hwm.\n\n\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n; // Don't have enough\n\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n\n return state.length;\n} // you can override either this method, or the async _read(n) below.\n\n\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n if (n !== 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n\n if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n\n n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up.\n\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n } // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n // if we need a readable event, then we need to do some reading.\n\n\n var doRead = state.needReadable;\n debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some\n\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n } // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n\n\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true; // if the length is currently zero, then we *need* a readable event.\n\n if (state.length === 0) state.needReadable = true; // call internal read method\n\n this._read(state.highWaterMark);\n\n state.sync = false; // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark;\n n = 0;\n } else {\n state.length -= n;\n state.awaitDrain = 0;\n }\n\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick.\n\n if (nOrig !== n && state.ended) endReadable(this);\n }\n\n if (ret !== null) this.emit('data', ret);\n return ret;\n};\n\nfunction onEofChunk(stream, state) {\n debug('onEofChunk');\n if (state.ended) return;\n\n if (state.decoder) {\n var chunk = state.decoder.end();\n\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n\n state.ended = true;\n\n if (state.sync) {\n // if we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call\n emitReadable(stream);\n } else {\n // emit 'readable' now to make sure it gets picked up.\n state.needReadable = false;\n\n if (!state.emittedReadable) {\n state.emittedReadable = true;\n emitReadable_(stream);\n }\n }\n} // Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\n\n\nfunction emitReadable(stream) {\n var state = stream._readableState;\n debug('emitReadable', state.needReadable, state.emittedReadable);\n state.needReadable = false;\n\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n process.nextTick(emitReadable_, stream);\n }\n}\n\nfunction emitReadable_(stream) {\n var state = stream._readableState;\n debug('emitReadable_', state.destroyed, state.length, state.ended);\n\n if (!state.destroyed && (state.length || state.ended)) {\n stream.emit('readable');\n state.emittedReadable = false;\n } // The stream needs another readable event if\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n\n\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;\n flow(stream);\n} // at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\n\n\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n process.nextTick(maybeReadMore_, stream, state);\n }\n}\n\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {\n var len = state.length;\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length) // didn't get any data, stop spinning.\n break;\n }\n\n state.readingMore = false;\n} // abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\n\n\nReadable.prototype._read = function (n) {\n errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));\n};\n\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n\n default:\n state.pipes.push(dest);\n break;\n }\n\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);\n dest.on('unpipe', onunpipe);\n\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n\n function onend() {\n debug('onend');\n dest.end();\n } // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n\n\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n var cleanedUp = false;\n\n function cleanup() {\n debug('cleanup'); // cleanup event handlers once the pipe is broken\n\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n cleanedUp = true; // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n\n src.on('data', ondata);\n\n function ondata(chunk) {\n debug('ondata');\n var ret = dest.write(chunk);\n debug('dest.write', ret);\n\n if (ret === false) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n }\n\n src.pause();\n }\n } // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n\n\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);\n } // Make sure our error handler is attached before userland ones.\n\n\n prependListener(dest, 'error', onerror); // Both close and finish should trigger unpipe, but only once.\n\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n\n dest.once('close', onclose);\n\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n\n dest.once('finish', onfinish);\n\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n } // tell the dest that it's being piped to\n\n\n dest.emit('pipe', src); // start the flow if it hasn't been started already.\n\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n\n return dest;\n};\n\nfunction pipeOnDrain(src) {\n return function pipeOnDrainFunctionResult() {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\n\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = {\n hasUnpiped: false\n }; // if we're not piping anywhere, then do nothing.\n\n if (state.pipesCount === 0) return this; // just one destination. most common case.\n\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n if (!dest) dest = state.pipes; // got a match.\n\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n } // slow case. multiple pipe destinations.\n\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n\n for (var i = 0; i < len; i++) {\n dests[i].emit('unpipe', this, {\n hasUnpiped: false\n });\n }\n\n return this;\n } // try to find the right one.\n\n\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n dest.emit('unpipe', this, unpipeInfo);\n return this;\n}; // set up data events if they are asked for\n// Ensure readable listeners eventually get something\n\n\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n var state = this._readableState;\n\n if (ev === 'data') {\n // update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0; // Try start flowing on next tick if stream isn't explicitly paused\n\n if (state.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.flowing = false;\n state.emittedReadable = false;\n debug('on readable', state.length, state.reading);\n\n if (state.length) {\n emitReadable(this);\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this);\n }\n }\n }\n\n return res;\n};\n\nReadable.prototype.addListener = Readable.prototype.on;\n\nReadable.prototype.removeListener = function (ev, fn) {\n var res = Stream.prototype.removeListener.call(this, ev, fn);\n\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n\n return res;\n};\n\nReadable.prototype.removeAllListeners = function (ev) {\n var res = Stream.prototype.removeAllListeners.apply(this, arguments);\n\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n\n return res;\n};\n\nfunction updateReadableListening(self) {\n var state = self._readableState;\n state.readableListening = self.listenerCount('readable') > 0;\n\n if (state.resumeScheduled && !state.paused) {\n // flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true; // crude way to check if we should resume\n } else if (self.listenerCount('data') > 0) {\n self.resume();\n }\n}\n\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n} // pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\n\n\nReadable.prototype.resume = function () {\n var state = this._readableState;\n\n if (!state.flowing) {\n debug('resume'); // we flow only if there is no one listening\n // for readable, but we still have to call\n // resume()\n\n state.flowing = !state.readableListening;\n resume(this, state);\n }\n\n state.paused = false;\n return this;\n};\n\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n process.nextTick(resume_, stream, state);\n }\n}\n\nfunction resume_(stream, state) {\n debug('resume', state.reading);\n\n if (!state.reading) {\n stream.read(0);\n }\n\n state.resumeScheduled = false;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\n\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n\n if (this._readableState.flowing !== false) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n\n this._readableState.paused = true;\n return this;\n};\n\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n\n while (state.flowing && stream.read() !== null) {\n ;\n }\n} // wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\n\n\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n\n var state = this._readableState;\n var paused = false;\n stream.on('end', function () {\n debug('wrapped end');\n\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n\n _this.push(null);\n });\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode\n\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\n var ret = _this.push(chunk);\n\n if (!ret) {\n paused = true;\n stream.pause();\n }\n }); // proxy all the other methods.\n // important when wrapping filters and duplexes.\n\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function methodWrap(method) {\n return function methodWrapReturnFunction() {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n } // proxy certain important events.\n\n\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n } // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n\n\n this._read = function (n) {\n debug('wrapped _read', n);\n\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n\n return this;\n};\n\nif (typeof Symbol === 'function') {\n Readable.prototype[Symbol.asyncIterator] = function () {\n if (createReadableStreamAsyncIterator === undefined) {\n createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');\n }\n\n return createReadableStreamAsyncIterator(this);\n };\n}\n\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.highWaterMark;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState && this._readableState.buffer;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableFlowing', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.flowing;\n },\n set: function set(state) {\n if (this._readableState) {\n this._readableState.flowing = state;\n }\n }\n}); // exposed for testing purposes only.\n\nReadable._fromList = fromList;\nObject.defineProperty(Readable.prototype, 'readableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.length;\n }\n}); // Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\n\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = state.buffer.consume(n, state.decoder);\n }\n return ret;\n}\n\nfunction endReadable(stream) {\n var state = stream._readableState;\n debug('endReadable', state.endEmitted);\n\n if (!state.endEmitted) {\n state.ended = true;\n process.nextTick(endReadableNT, state, stream);\n }\n}\n\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length); // Check that we didn't get one last unshift.\n\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well\n var wState = stream._writableState;\n\n if (!wState || wState.autoDestroy && wState.finished) {\n stream.destroy();\n }\n }\n }\n}\n\nif (typeof Symbol === 'function') {\n Readable.from = function (iterable, opts) {\n if (from === undefined) {\n from = require('./internal/streams/from');\n }\n\n return from(Readable, iterable, opts);\n };\n}\n\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n\n return -1;\n}","module.exports = require('events').EventEmitter;\n","'use strict';\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nvar _require = require('buffer'),\n Buffer = _require.Buffer;\n\nvar _require2 = require('util'),\n inspect = _require2.inspect;\n\nvar custom = inspect && inspect.custom || 'inspect';\n\nfunction copyBuffer(src, target, offset) {\n Buffer.prototype.copy.call(src, target, offset);\n}\n\nmodule.exports =\n/*#__PURE__*/\nfunction () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n\n _createClass(BufferList, [{\n key: \"push\",\n value: function push(v) {\n var entry = {\n data: v,\n next: null\n };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n }\n }, {\n key: \"unshift\",\n value: function unshift(v) {\n var entry = {\n data: v,\n next: this.head\n };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n }\n }, {\n key: \"shift\",\n value: function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.head = this.tail = null;\n this.length = 0;\n }\n }, {\n key: \"join\",\n value: function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n\n while (p = p.next) {\n ret += s + p.data;\n }\n\n return ret;\n }\n }, {\n key: \"concat\",\n value: function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n\n return ret;\n } // Consumes a specified amount of bytes or characters from the buffered data.\n\n }, {\n key: \"consume\",\n value: function consume(n, hasStrings) {\n var ret;\n\n if (n < this.head.data.length) {\n // `slice` is the same for buffers and strings.\n ret = this.head.data.slice(0, n);\n this.head.data = this.head.data.slice(n);\n } else if (n === this.head.data.length) {\n // First chunk is a perfect match.\n ret = this.shift();\n } else {\n // Result spans more than one buffer.\n ret = hasStrings ? this._getString(n) : this._getBuffer(n);\n }\n\n return ret;\n }\n }, {\n key: \"first\",\n value: function first() {\n return this.head.data;\n } // Consumes a specified amount of characters from the buffered data.\n\n }, {\n key: \"_getString\",\n value: function _getString(n) {\n var p = this.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = str.slice(nb);\n }\n\n break;\n }\n\n ++c;\n }\n\n this.length -= c;\n return ret;\n } // Consumes a specified amount of bytes from the buffered data.\n\n }, {\n key: \"_getBuffer\",\n value: function _getBuffer(n) {\n var ret = Buffer.allocUnsafe(n);\n var p = this.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = buf.slice(nb);\n }\n\n break;\n }\n\n ++c;\n }\n\n this.length -= c;\n return ret;\n } // Make sure the linked list only shows the minimal necessary information.\n\n }, {\n key: custom,\n value: function value(_, options) {\n return inspect(this, _objectSpread({}, options, {\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n }));\n }\n }]);\n\n return BufferList;\n}();","'use strict'; // undocumented cb() API, needed for core, not for public API\n\nfunction destroy(err, cb) {\n var _this = this;\n\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n process.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n process.nextTick(emitErrorNT, this, err);\n }\n }\n\n return this;\n } // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n } // if this is a duplex stream mark the writable part as destroyed as well\n\n\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n } else if (cb) {\n process.nextTick(emitCloseNT, _this);\n cb(err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n });\n\n return this;\n}\n\nfunction emitErrorAndCloseNT(self, err) {\n emitErrorNT(self, err);\n emitCloseNT(self);\n}\n\nfunction emitCloseNT(self) {\n if (self._writableState && !self._writableState.emitClose) return;\n if (self._readableState && !self._readableState.emitClose) return;\n self.emit('close');\n}\n\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\n\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\n\nfunction errorOrDestroy(stream, err) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n var rState = stream._readableState;\n var wState = stream._writableState;\n if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);\n}\n\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy,\n errorOrDestroy: errorOrDestroy\n};","'use strict';\n\nvar ERR_INVALID_OPT_VALUE = require('../../../errors').codes.ERR_INVALID_OPT_VALUE;\n\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;\n}\n\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);\n\n if (hwm != null) {\n if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {\n var name = isDuplex ? duplexKey : 'highWaterMark';\n throw new ERR_INVALID_OPT_VALUE(name, hwm);\n }\n\n return Math.floor(hwm);\n } // Default value\n\n\n return state.objectMode ? 16 : 16 * 1024;\n}\n\nmodule.exports = {\n getHighWaterMark: getHighWaterMark\n};","'use strict';\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar codes = {};\n\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n\n var NodeError =\n /*#__PURE__*/\n function (_Base) {\n _inheritsLoose(NodeError, _Base);\n\n function NodeError(arg1, arg2, arg3) {\n return _Base.call(this, getMessage(arg1, arg2, arg3)) || this;\n }\n\n return NodeError;\n }(Base);\n\n NodeError.prototype.name = Base.name;\n NodeError.prototype.code = code;\n codes[code] = NodeError;\n} // https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\n\n\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\n\n\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\n\n\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n\n return str.substring(this_len - search.length, this_len) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\n\n\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\n\ncreateErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {\n return 'The value \"' + value + '\" is invalid for option \"' + name + '\"';\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n var determiner;\n\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n\n var msg;\n\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n\n msg += \". Received type \".concat(typeof actual);\n return msg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');\ncreateErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {\n return 'The ' + name + ' method is not implemented';\n});\ncreateErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');\ncreateErrorType('ERR_STREAM_DESTROYED', function (name) {\n return 'Cannot call ' + name + ' after a stream was destroyed';\n});\ncreateErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');\ncreateErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');\ncreateErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');\ncreateErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);\ncreateErrorType('ERR_UNKNOWN_ENCODING', function (arg) {\n return 'Unknown encoding: ' + arg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');\nmodule.exports.codes = codes;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n'use strict';\n/**/\n\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n\n for (var key in obj) {\n keys.push(key);\n }\n\n return keys;\n};\n/**/\n\n\nmodule.exports = Duplex;\n\nvar Readable = require('./_stream_readable');\n\nvar Writable = require('./_stream_writable');\n\nrequire('inherits')(Duplex, Readable);\n\n{\n // Allow the keys array to be GC'ed.\n var keys = objectKeys(Writable.prototype);\n\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\n\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n Readable.call(this, options);\n Writable.call(this, options);\n this.allowHalfOpen = true;\n\n if (options) {\n if (options.readable === false) this.readable = false;\n if (options.writable === false) this.writable = false;\n\n if (options.allowHalfOpen === false) {\n this.allowHalfOpen = false;\n this.once('end', onend);\n }\n }\n}\n\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n}); // the no-half-open enforcer\n\nfunction onend() {\n // If the writable side ended, then we're ok.\n if (this._writableState.ended) return; // no more data can be written.\n // But allow more writes to happen in this tick.\n\n process.nextTick(onEndNT, this);\n}\n\nfunction onEndNT(self) {\n self.end();\n}\n\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n } // backward compatibility, the user is explicitly\n // managing destroyed\n\n\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n'use strict';\n\nmodule.exports = Writable;\n/* */\n\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n} // It seems a linked list but it is not\n// there will be only 2 of these for each stream\n\n\nfunction CorkedRequest(state) {\n var _this = this;\n\n this.next = null;\n this.entry = null;\n\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* */\n\n/**/\n\n\nvar Duplex;\n/**/\n\nWritable.WritableState = WritableState;\n/**/\n\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/**/\n\n/**/\n\nvar Stream = require('./internal/streams/stream');\n/**/\n\n\nvar Buffer = require('buffer').Buffer;\n\nvar OurUint8Array = global.Uint8Array || function () {};\n\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\n\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\nvar destroyImpl = require('./internal/streams/destroy');\n\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\n\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,\n ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;\n\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\n\nrequire('inherits')(Writable, Stream);\n\nfunction nop() {}\n\nfunction WritableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {}; // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n\n this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex); // if _final has been called\n\n this.finalCalled = false; // drain event flag.\n\n this.needDrain = false; // at the start of calling end()\n\n this.ending = false; // when end() has been called, and returned\n\n this.ended = false; // when 'finish' is emitted\n\n this.finished = false; // has it been destroyed\n\n this.destroyed = false; // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode; // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n\n this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n\n this.length = 0; // a flag to see when we're in the middle of a write.\n\n this.writing = false; // when true all writes will be buffered until .uncork() call\n\n this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n\n this.sync = true; // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n\n this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb)\n\n this.onwrite = function (er) {\n onwrite(stream, er);\n }; // the callback that the user supplies to write(chunk,encoding,cb)\n\n\n this.writecb = null; // the amount that is being written when _write is called.\n\n this.writelen = 0;\n this.bufferedRequest = null;\n this.lastBufferedRequest = null; // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n\n this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n\n this.prefinished = false; // True if the error was already emitted and should not be thrown again\n\n this.errorEmitted = false; // Should close be emitted on destroy. Defaults to true.\n\n this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'finish' (and potentially 'end')\n\n this.autoDestroy = !!options.autoDestroy; // count buffered requests\n\n this.bufferedRequestCount = 0; // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n\n this.corkedRequestsFree = new CorkedRequest(this);\n}\n\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n\n while (current) {\n out.push(current);\n current = current.next;\n }\n\n return out;\n};\n\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function writableStateBufferGetter() {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})(); // Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\n\n\nvar realHasInstance;\n\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function value(object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function realHasInstance(object) {\n return object instanceof this;\n };\n}\n\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex'); // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5\n\n var isDuplex = this instanceof Duplex;\n if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);\n this._writableState = new WritableState(options, this, isDuplex); // legacy.\n\n this.writable = true;\n\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n if (typeof options.writev === 'function') this._writev = options.writev;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n if (typeof options.final === 'function') this._final = options.final;\n }\n\n Stream.call(this);\n} // Otherwise people can pipe Writable streams, which is just wrong.\n\n\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());\n};\n\nfunction writeAfterEnd(stream, cb) {\n var er = new ERR_STREAM_WRITE_AFTER_END(); // TODO: defer error events consistently everywhere, not just the cb\n\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n} // Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\n\n\nfunction validChunk(stream, state, chunk, cb) {\n var er;\n\n if (chunk === null) {\n er = new ERR_STREAM_NULL_VALUES();\n } else if (typeof chunk !== 'string' && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);\n }\n\n if (er) {\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n return false;\n }\n\n return true;\n}\n\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n if (typeof cb !== 'function') cb = nop;\n if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n return ret;\n};\n\nWritable.prototype.cork = function () {\n this._writableState.corked++;\n};\n\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n\n if (state.corked) {\n state.corked--;\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\n\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\n\nObject.defineProperty(Writable.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\n\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n\n return chunk;\n}\n\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n}); // if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\n\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n\n var len = state.objectMode ? 1 : chunk.length;\n state.length += len;\n var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false.\n\n if (!ret) state.needDrain = true;\n\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n\n return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n process.nextTick(cb, er); // this can emit finish, and it will always happen\n // after error\n\n process.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er); // this can emit finish, but finish must\n // always follow error\n\n finishMaybe(stream, state);\n }\n}\n\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();\n onwriteStateUpdate(state);\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state) || stream.destroyed;\n\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n\n if (sync) {\n process.nextTick(afterWrite, stream, state, finished, cb);\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n} // Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\n\n\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n} // if there's something in the buffer waiting, then process it\n\n\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n var count = 0;\n var allBuffers = true;\n\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n\n buffer.allBuffers = allBuffers;\n doWrite(stream, state, true, state.length, buffer, '', holder.finish); // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n\n state.pendingcb++;\n state.lastBufferedRequest = null;\n\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--; // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n\n if (state.writing) {\n break;\n }\n }\n\n if (entry === null) state.lastBufferedRequest = null;\n }\n\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); // .end() fully uncorks\n\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n } // ignore unnecessary end() calls.\n\n\n if (!state.ending) endWritable(this, state, cb);\n return this;\n};\n\nObject.defineProperty(Writable.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\n\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\n\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n\n if (err) {\n errorOrDestroy(stream, err);\n }\n\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\n\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.pendingcb++;\n state.finalCalled = true;\n process.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\n\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n\n if (need) {\n prefinish(stream, state);\n\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well\n var rState = stream._readableState;\n\n if (!rState || rState.autoDestroy && rState.endEmitted) {\n stream.destroy();\n }\n }\n }\n }\n\n return need;\n}\n\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n\n if (cb) {\n if (state.finished) process.nextTick(cb);else stream.once('finish', cb);\n }\n\n state.ended = true;\n stream.writable = false;\n}\n\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n } // reuse the free corkReq.\n\n\n state.corkedRequestsFree.next = corkReq;\n}\n\nObject.defineProperty(Writable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._writableState === undefined) {\n return false;\n }\n\n return this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n } // backward compatibility, the user is explicitly\n // managing destroyed\n\n\n this._writableState.destroyed = value;\n }\n});\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\n\nWritable.prototype._destroy = function (err, cb) {\n cb(err);\n};","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\n/**/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':\n return true;\n default:\n return false;\n }\n};\n\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n};\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\n\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\n\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\n\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\n\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\n\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","/*! safe-buffer. MIT License. Feross Aboukhadijeh */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","'use strict';\n\nvar _Object$setPrototypeO;\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar finished = require('./end-of-stream');\n\nvar kLastResolve = Symbol('lastResolve');\nvar kLastReject = Symbol('lastReject');\nvar kError = Symbol('error');\nvar kEnded = Symbol('ended');\nvar kLastPromise = Symbol('lastPromise');\nvar kHandlePromise = Symbol('handlePromise');\nvar kStream = Symbol('stream');\n\nfunction createIterResult(value, done) {\n return {\n value: value,\n done: done\n };\n}\n\nfunction readAndResolve(iter) {\n var resolve = iter[kLastResolve];\n\n if (resolve !== null) {\n var data = iter[kStream].read(); // we defer if data is null\n // we can be expecting either 'end' or\n // 'error'\n\n if (data !== null) {\n iter[kLastPromise] = null;\n iter[kLastResolve] = null;\n iter[kLastReject] = null;\n resolve(createIterResult(data, false));\n }\n }\n}\n\nfunction onReadable(iter) {\n // we wait for the next tick, because it might\n // emit an error with process.nextTick\n process.nextTick(readAndResolve, iter);\n}\n\nfunction wrapForNext(lastPromise, iter) {\n return function (resolve, reject) {\n lastPromise.then(function () {\n if (iter[kEnded]) {\n resolve(createIterResult(undefined, true));\n return;\n }\n\n iter[kHandlePromise](resolve, reject);\n }, reject);\n };\n}\n\nvar AsyncIteratorPrototype = Object.getPrototypeOf(function () {});\nvar ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {\n get stream() {\n return this[kStream];\n },\n\n next: function next() {\n var _this = this;\n\n // if we have detected an error in the meanwhile\n // reject straight away\n var error = this[kError];\n\n if (error !== null) {\n return Promise.reject(error);\n }\n\n if (this[kEnded]) {\n return Promise.resolve(createIterResult(undefined, true));\n }\n\n if (this[kStream].destroyed) {\n // We need to defer via nextTick because if .destroy(err) is\n // called, the error will be emitted via nextTick, and\n // we cannot guarantee that there is no error lingering around\n // waiting to be emitted.\n return new Promise(function (resolve, reject) {\n process.nextTick(function () {\n if (_this[kError]) {\n reject(_this[kError]);\n } else {\n resolve(createIterResult(undefined, true));\n }\n });\n });\n } // if we have multiple next() calls\n // we will wait for the previous Promise to finish\n // this logic is optimized to support for await loops,\n // where next() is only called once at a time\n\n\n var lastPromise = this[kLastPromise];\n var promise;\n\n if (lastPromise) {\n promise = new Promise(wrapForNext(lastPromise, this));\n } else {\n // fast path needed to support multiple this.push()\n // without triggering the next() queue\n var data = this[kStream].read();\n\n if (data !== null) {\n return Promise.resolve(createIterResult(data, false));\n }\n\n promise = new Promise(this[kHandlePromise]);\n }\n\n this[kLastPromise] = promise;\n return promise;\n }\n}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {\n return this;\n}), _defineProperty(_Object$setPrototypeO, \"return\", function _return() {\n var _this2 = this;\n\n // destroy(err, cb) is a private API\n // we can guarantee we have that here, because we control the\n // Readable class this is attached to\n return new Promise(function (resolve, reject) {\n _this2[kStream].destroy(null, function (err) {\n if (err) {\n reject(err);\n return;\n }\n\n resolve(createIterResult(undefined, true));\n });\n });\n}), _Object$setPrototypeO), AsyncIteratorPrototype);\n\nvar createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {\n var _Object$create;\n\n var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {\n value: stream,\n writable: true\n }), _defineProperty(_Object$create, kLastResolve, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kLastReject, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kError, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kEnded, {\n value: stream._readableState.endEmitted,\n writable: true\n }), _defineProperty(_Object$create, kHandlePromise, {\n value: function value(resolve, reject) {\n var data = iterator[kStream].read();\n\n if (data) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(data, false));\n } else {\n iterator[kLastResolve] = resolve;\n iterator[kLastReject] = reject;\n }\n },\n writable: true\n }), _Object$create));\n iterator[kLastPromise] = null;\n finished(stream, function (err) {\n if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n var reject = iterator[kLastReject]; // reject if we are waiting for data in the Promise\n // returned by next() and store the error\n\n if (reject !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n reject(err);\n }\n\n iterator[kError] = err;\n return;\n }\n\n var resolve = iterator[kLastResolve];\n\n if (resolve !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(undefined, true));\n }\n\n iterator[kEnded] = true;\n });\n stream.on('readable', onReadable.bind(null, iterator));\n return iterator;\n};\n\nmodule.exports = createReadableStreamAsyncIterator;","// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n'use strict';\n\nvar ERR_STREAM_PREMATURE_CLOSE = require('../../../errors').codes.ERR_STREAM_PREMATURE_CLOSE;\n\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n callback.apply(this, args);\n };\n}\n\nfunction noop() {}\n\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\n\nfunction eos(stream, opts, callback) {\n if (typeof opts === 'function') return eos(stream, null, opts);\n if (!opts) opts = {};\n callback = once(callback || noop);\n var readable = opts.readable || opts.readable !== false && stream.readable;\n var writable = opts.writable || opts.writable !== false && stream.writable;\n\n var onlegacyfinish = function onlegacyfinish() {\n if (!stream.writable) onfinish();\n };\n\n var writableEnded = stream._writableState && stream._writableState.finished;\n\n var onfinish = function onfinish() {\n writable = false;\n writableEnded = true;\n if (!readable) callback.call(stream);\n };\n\n var readableEnded = stream._readableState && stream._readableState.endEmitted;\n\n var onend = function onend() {\n readable = false;\n readableEnded = true;\n if (!writable) callback.call(stream);\n };\n\n var onerror = function onerror(err) {\n callback.call(stream, err);\n };\n\n var onclose = function onclose() {\n var err;\n\n if (readable && !readableEnded) {\n if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n\n if (writable && !writableEnded) {\n if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n };\n\n var onrequest = function onrequest() {\n stream.req.on('finish', onfinish);\n };\n\n if (isRequest(stream)) {\n stream.on('complete', onfinish);\n stream.on('abort', onclose);\n if (stream.req) onrequest();else stream.on('request', onrequest);\n } else if (writable && !stream._writableState) {\n // legacy streams\n stream.on('end', onlegacyfinish);\n stream.on('close', onlegacyfinish);\n }\n\n stream.on('end', onend);\n stream.on('finish', onfinish);\n if (opts.error !== false) stream.on('error', onerror);\n stream.on('close', onclose);\n return function () {\n stream.removeListener('complete', onfinish);\n stream.removeListener('abort', onclose);\n stream.removeListener('request', onrequest);\n if (stream.req) stream.req.removeListener('finish', onfinish);\n stream.removeListener('end', onlegacyfinish);\n stream.removeListener('close', onlegacyfinish);\n stream.removeListener('finish', onfinish);\n stream.removeListener('end', onend);\n stream.removeListener('error', onerror);\n stream.removeListener('close', onclose);\n };\n}\n\nmodule.exports = eos;","module.exports = function () {\n throw new Error('Readable.from is not available in the browser')\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n'use strict';\n\nmodule.exports = Transform;\n\nvar _require$codes = require('../errors').codes,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,\n ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;\n\nvar Duplex = require('./_stream_duplex');\n\nrequire('inherits')(Transform, Duplex);\n\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n var cb = ts.writecb;\n\n if (cb === null) {\n return this.emit('error', new ERR_MULTIPLE_CALLBACK());\n }\n\n ts.writechunk = null;\n ts.writecb = null;\n if (data != null) // single equals check for both `null` and `undefined`\n this.push(data);\n cb(er);\n var rs = this._readableState;\n rs.reading = false;\n\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\n\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n Duplex.call(this, options);\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n }; // start out asking for a readable event once data is transformed.\n\n this._readableState.needReadable = true; // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n\n this._readableState.sync = false;\n\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n if (typeof options.flush === 'function') this._flush = options.flush;\n } // When the writable side finishes, then flush out anything remaining.\n\n\n this.on('prefinish', prefinish);\n}\n\nfunction prefinish() {\n var _this = this;\n\n if (typeof this._flush === 'function' && !this._readableState.destroyed) {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\n\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n}; // This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\n\n\nTransform.prototype._transform = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));\n};\n\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n}; // Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\n\n\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n\n if (ts.writechunk !== null && !ts.transforming) {\n ts.transforming = true;\n\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\n\nTransform.prototype._destroy = function (err, cb) {\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n });\n};\n\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n if (data != null) // single equals check for both `null` and `undefined`\n stream.push(data); // TODO(BridgeAR): Write a test for these two error cases\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n\n if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();\n if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();\n return stream.push(null);\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n'use strict';\n\nmodule.exports = PassThrough;\n\nvar Transform = require('./_stream_transform');\n\nrequire('inherits')(PassThrough, Transform);\n\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n Transform.call(this, options);\n}\n\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n'use strict';\n\nvar eos;\n\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n callback.apply(void 0, arguments);\n };\n}\n\nvar _require$codes = require('../../../errors').codes,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;\n\nfunction noop(err) {\n // Rethrow the error if it exists to avoid swallowing it\n if (err) throw err;\n}\n\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\n\nfunction destroyer(stream, reading, writing, callback) {\n callback = once(callback);\n var closed = false;\n stream.on('close', function () {\n closed = true;\n });\n if (eos === undefined) eos = require('./end-of-stream');\n eos(stream, {\n readable: reading,\n writable: writing\n }, function (err) {\n if (err) return callback(err);\n closed = true;\n callback();\n });\n var destroyed = false;\n return function (err) {\n if (closed) return;\n if (destroyed) return;\n destroyed = true; // request.destroy just do .end - .abort is what we want\n\n if (isRequest(stream)) return stream.abort();\n if (typeof stream.destroy === 'function') return stream.destroy();\n callback(err || new ERR_STREAM_DESTROYED('pipe'));\n };\n}\n\nfunction call(fn) {\n fn();\n}\n\nfunction pipe(from, to) {\n return from.pipe(to);\n}\n\nfunction popCallback(streams) {\n if (!streams.length) return noop;\n if (typeof streams[streams.length - 1] !== 'function') return noop;\n return streams.pop();\n}\n\nfunction pipeline() {\n for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {\n streams[_key] = arguments[_key];\n }\n\n var callback = popCallback(streams);\n if (Array.isArray(streams[0])) streams = streams[0];\n\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams');\n }\n\n var error;\n var destroys = streams.map(function (stream, i) {\n var reading = i < streams.length - 1;\n var writing = i > 0;\n return destroyer(stream, reading, writing, function (err) {\n if (!error) error = err;\n if (err) destroys.forEach(call);\n if (reading) return;\n destroys.forEach(call);\n callback(error);\n });\n });\n return streams.reduce(pipe);\n}\n\nmodule.exports = pipeline;","'use strict'\n\nconst WriteError = require('level-errors').WriteError\nconst catering = require('catering')\nconst getCallback = require('./common').getCallback\nconst getOptions = require('./common').getOptions\n\nfunction Batch (levelup) {\n this.db = levelup\n this.batch = levelup.db.batch()\n this.ops = []\n this.length = 0\n}\n\nBatch.prototype.put = function (key, value, options) {\n try {\n this.batch.put(key, value, options)\n } catch (e) {\n throw new WriteError(e)\n }\n\n this.ops.push({ ...options, type: 'put', key, value })\n this.length++\n\n return this\n}\n\nBatch.prototype.del = function (key, options) {\n try {\n this.batch.del(key, options)\n } catch (err) {\n throw new WriteError(err)\n }\n\n this.ops.push({ ...options, type: 'del', key })\n this.length++\n\n return this\n}\n\nBatch.prototype.clear = function () {\n try {\n this.batch.clear()\n } catch (err) {\n throw new WriteError(err)\n }\n\n this.ops = []\n this.length = 0\n\n return this\n}\n\nBatch.prototype.write = function (options, callback) {\n const levelup = this.db\n const ops = this.ops\n\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n options = getOptions(options)\n\n try {\n this.batch.write(options, function (err) {\n if (err) { return callback(new WriteError(err)) }\n levelup.emit('batch', ops)\n callback()\n })\n } catch (err) {\n throw new WriteError(err)\n }\n\n return callback.promise\n}\n\nmodule.exports = Batch\n","'use strict'\n\nfunction createError (type, Proto) {\n const Err = function (message, cause) {\n if (typeof message === 'object' && message !== null) {\n // Can be passed just a cause\n cause = cause || message\n message = message.message || message.name\n }\n\n message = message || ''\n cause = cause || undefined\n\n // If input is already of type, return as-is to keep its stack trace.\n // Avoid instanceof, for when node_modules has multiple copies of level-errors.\n if (typeof cause === 'object' && cause.type === type && cause.message === message) {\n return cause\n }\n\n Object.defineProperty(this, 'type', { value: type, enumerable: false, writable: true, configurable: true })\n Object.defineProperty(this, 'name', { value: type, enumerable: false, writable: true, configurable: true })\n Object.defineProperty(this, 'cause', { value: cause, enumerable: false, writable: true, configurable: true })\n Object.defineProperty(this, 'message', { value: message, enumerable: false, writable: true, configurable: true })\n\n Error.call(this)\n\n if (typeof Error.captureStackTrace === 'function') {\n Error.captureStackTrace(this, Err)\n }\n }\n\n Err.prototype = new Proto()\n return Err\n}\n\nconst LevelUPError = createError('LevelUPError', Error)\n\nmodule.exports = {\n LevelUPError: LevelUPError,\n InitializationError: createError('InitializationError', LevelUPError),\n OpenError: createError('OpenError', LevelUPError),\n ReadError: createError('ReadError', LevelUPError),\n WriteError: createError('WriteError', LevelUPError),\n NotFoundError: createError('NotFoundError', LevelUPError),\n EncodingError: createError('EncodingError', LevelUPError)\n}\n\nmodule.exports.NotFoundError.prototype.notFound = true\nmodule.exports.NotFoundError.prototype.status = 404\n","'use strict'\n\nexports.getCallback = function (options, callback) {\n return typeof options === 'function' ? options : callback\n}\n\nexports.getOptions = function (options) {\n return typeof options === 'object' && options !== null ? options : {}\n}\n","'use strict'\n\nconst queueMicrotask = require('queue-microtask')\n\nmodule.exports = function (fn, ...args) {\n if (args.length === 0) {\n queueMicrotask(fn)\n } else {\n queueMicrotask(() => fn(...args))\n }\n}\n","'use strict'\n\nconst AbstractLevelDOWN = require('abstract-leveldown').AbstractLevelDOWN\nconst AbstractChainedBatch = require('abstract-leveldown').AbstractChainedBatch\nconst AbstractIterator = require('abstract-leveldown').AbstractIterator\nconst inherits = require('inherits')\nconst Codec = require('level-codec')\nconst EncodingError = require('level-errors').EncodingError\nconst rangeMethods = ['approximateSize', 'compactRange']\n\nmodule.exports = DB\n\nfunction DB (db, opts) {\n if (!(this instanceof DB)) return new DB(db, opts)\n\n const manifest = db.supports || {}\n const additionalMethods = manifest.additionalMethods || {}\n\n AbstractLevelDOWN.call(this, manifest)\n\n this.supports.encodings = true\n this.supports.additionalMethods = {}\n\n rangeMethods.forEach(function (m) {\n // TODO (future major): remove this fallback\n const fallback = typeof db[m] === 'function'\n\n if (additionalMethods[m] || fallback) {\n this.supports.additionalMethods[m] = true\n\n this[m] = function (start, end, opts, cb) {\n start = this.codec.encodeKey(start, opts)\n end = this.codec.encodeKey(end, opts)\n return this.db[m](start, end, opts, cb)\n }\n }\n }, this)\n\n opts = opts || {}\n if (typeof opts.keyEncoding === 'undefined') opts.keyEncoding = 'utf8'\n if (typeof opts.valueEncoding === 'undefined') opts.valueEncoding = 'utf8'\n\n this.db = db\n this.codec = new Codec(opts)\n}\n\ninherits(DB, AbstractLevelDOWN)\n\nDB.prototype.type = 'encoding-down'\n\nDB.prototype._serializeKey =\nDB.prototype._serializeValue = function (datum) {\n return datum\n}\n\nDB.prototype._open = function (opts, cb) {\n this.db.open(opts, cb)\n}\n\nDB.prototype._close = function (cb) {\n this.db.close(cb)\n}\n\nDB.prototype._put = function (key, value, opts, cb) {\n key = this.codec.encodeKey(key, opts)\n value = this.codec.encodeValue(value, opts)\n this.db.put(key, value, opts, cb)\n}\n\nDB.prototype._get = function (key, opts, cb) {\n key = this.codec.encodeKey(key, opts)\n opts.asBuffer = this.codec.valueAsBuffer(opts)\n\n this.db.get(key, opts, (err, value) => {\n if (err) return cb(err)\n\n try {\n value = this.codec.decodeValue(value, opts)\n } catch (err) {\n return cb(new EncodingError(err))\n }\n\n cb(null, value)\n })\n}\n\nDB.prototype._getMany = function (keys, opts, cb) {\n keys = keys.map((key) => this.codec.encodeKey(key, opts))\n opts.asBuffer = this.codec.valueAsBuffer(opts)\n\n this.db.getMany(keys, opts, (err, values) => {\n if (err) return cb(err)\n\n const decoded = new Array(values.length)\n\n for (let i = 0; i < values.length; i++) {\n if (values[i] === undefined) {\n decoded[i] = undefined\n continue\n }\n\n try {\n decoded[i] = this.codec.decodeValue(values[i], opts)\n } catch (err) {\n return cb(new EncodingError(err))\n }\n }\n\n cb(null, decoded)\n })\n}\n\nDB.prototype._del = function (key, opts, cb) {\n key = this.codec.encodeKey(key, opts)\n this.db.del(key, opts, cb)\n}\n\nDB.prototype._chainedBatch = function () {\n return new Batch(this)\n}\n\nDB.prototype._batch = function (ops, opts, cb) {\n ops = this.codec.encodeBatch(ops, opts)\n this.db.batch(ops, opts, cb)\n}\n\nDB.prototype._iterator = function (opts) {\n opts.keyAsBuffer = this.codec.keyAsBuffer(opts)\n opts.valueAsBuffer = this.codec.valueAsBuffer(opts)\n return new Iterator(this, opts)\n}\n\nDB.prototype._clear = function (opts, callback) {\n opts = this.codec.encodeLtgt(opts)\n this.db.clear(opts, callback)\n}\n\nfunction Iterator (db, opts) {\n AbstractIterator.call(this, db)\n this.codec = db.codec\n this.keys = opts.keys\n this.values = opts.values\n this.opts = this.codec.encodeLtgt(opts)\n this.it = db.db.iterator(this.opts)\n}\n\ninherits(Iterator, AbstractIterator)\n\nIterator.prototype._next = function (cb) {\n this.it.next((err, key, value) => {\n if (err) return cb(err)\n\n try {\n if (this.keys && typeof key !== 'undefined') {\n key = this.codec.decodeKey(key, this.opts)\n } else {\n key = undefined\n }\n\n if (this.values && typeof value !== 'undefined') {\n value = this.codec.decodeValue(value, this.opts)\n } else {\n value = undefined\n }\n } catch (err) {\n return cb(new EncodingError(err))\n }\n\n cb(null, key, value)\n })\n}\n\nIterator.prototype._seek = function (key) {\n key = this.codec.encodeKey(key, this.opts)\n this.it.seek(key)\n}\n\nIterator.prototype._end = function (cb) {\n this.it.end(cb)\n}\n\nfunction Batch (db, codec) {\n AbstractChainedBatch.call(this, db)\n this.codec = db.codec\n this.batch = db.db.batch()\n}\n\ninherits(Batch, AbstractChainedBatch)\n\nBatch.prototype._put = function (key, value, options) {\n key = this.codec.encodeKey(key, options)\n value = this.codec.encodeValue(value, options)\n this.batch.put(key, value)\n}\n\nBatch.prototype._del = function (key, options) {\n key = this.codec.encodeKey(key, options)\n this.batch.del(key)\n}\n\nBatch.prototype._clear = function () {\n this.batch.clear()\n}\n\nBatch.prototype._write = function (opts, cb) {\n this.batch.write(opts, cb)\n}\n","'use strict'\n\nconst encodings = require('./lib/encodings')\nconst rangeOptions = new Set(['lt', 'gt', 'lte', 'gte'])\n\nmodule.exports = Codec\n\nfunction Codec (opts) {\n if (!(this instanceof Codec)) {\n return new Codec(opts)\n }\n this.opts = opts || {}\n this.encodings = encodings\n}\n\nCodec.prototype._encoding = function (encoding) {\n if (typeof encoding === 'string') encoding = encodings[encoding]\n if (!encoding) encoding = encodings.id\n return encoding\n}\n\nCodec.prototype._keyEncoding = function (opts, batchOpts) {\n return this._encoding((batchOpts && batchOpts.keyEncoding) ||\n (opts && opts.keyEncoding) ||\n this.opts.keyEncoding)\n}\n\nCodec.prototype._valueEncoding = function (opts, batchOpts) {\n return this._encoding((batchOpts && (batchOpts.valueEncoding || batchOpts.encoding)) ||\n (opts && (opts.valueEncoding || opts.encoding)) ||\n (this.opts.valueEncoding || this.opts.encoding))\n}\n\nCodec.prototype.encodeKey = function (key, opts, batchOpts) {\n return this._keyEncoding(opts, batchOpts).encode(key)\n}\n\nCodec.prototype.encodeValue = function (value, opts, batchOpts) {\n return this._valueEncoding(opts, batchOpts).encode(value)\n}\n\nCodec.prototype.decodeKey = function (key, opts) {\n return this._keyEncoding(opts).decode(key)\n}\n\nCodec.prototype.decodeValue = function (value, opts) {\n return this._valueEncoding(opts).decode(value)\n}\n\nCodec.prototype.encodeBatch = function (ops, opts) {\n return ops.map((_op) => {\n const op = {\n type: _op.type,\n key: this.encodeKey(_op.key, opts, _op)\n }\n if (this.keyAsBuffer(opts, _op)) op.keyEncoding = 'binary'\n if (_op.prefix) op.prefix = _op.prefix\n if ('value' in _op) {\n op.value = this.encodeValue(_op.value, opts, _op)\n if (this.valueAsBuffer(opts, _op)) op.valueEncoding = 'binary'\n }\n return op\n })\n}\n\nCodec.prototype.encodeLtgt = function (ltgt) {\n const ret = {}\n\n for (const key of Object.keys(ltgt)) {\n if (key === 'start' || key === 'end') {\n throw new Error('Legacy range options (\"start\" and \"end\") have been removed')\n }\n\n ret[key] = rangeOptions.has(key)\n ? this.encodeKey(ltgt[key], ltgt)\n : ltgt[key]\n }\n\n return ret\n}\n\nCodec.prototype.createStreamDecoder = function (opts) {\n if (opts.keys && opts.values) {\n return (key, value) => {\n return {\n key: this.decodeKey(key, opts),\n value: this.decodeValue(value, opts)\n }\n }\n } else if (opts.keys) {\n return (key) => {\n return this.decodeKey(key, opts)\n }\n } else if (opts.values) {\n return (_, value) => {\n return this.decodeValue(value, opts)\n }\n } else {\n return function () {}\n }\n}\n\nCodec.prototype.keyAsBuffer = function (opts) {\n return this._keyEncoding(opts).buffer\n}\n\nCodec.prototype.valueAsBuffer = function (opts) {\n return this._valueEncoding(opts).buffer\n}\n","'use strict'\n\nconst { Buffer } = require('buffer')\n\nexports.utf8 = exports['utf-8'] = {\n encode: function (data) {\n return isBinary(data) ? data : String(data)\n },\n decode: identity,\n buffer: false,\n type: 'utf8'\n}\n\nexports.json = {\n encode: JSON.stringify,\n decode: JSON.parse,\n buffer: false,\n type: 'json'\n}\n\nexports.binary = {\n encode: function (data) {\n return isBinary(data) ? data : Buffer.from(data)\n },\n decode: identity,\n buffer: true,\n type: 'binary'\n}\n\nexports.none = {\n encode: identity,\n decode: identity,\n buffer: false,\n type: 'id'\n}\n\nexports.id = exports.none\n\nconst bufferEncodings = [\n 'hex',\n 'ascii',\n 'base64',\n 'ucs2',\n 'ucs-2',\n 'utf16le',\n 'utf-16le'\n]\n\nfor (const type of bufferEncodings) {\n exports[type] = {\n encode: function (data) {\n return isBinary(data) ? data : Buffer.from(data, type)\n },\n decode: function (buffer) {\n return buffer.toString(type)\n },\n buffer: true,\n type: type\n }\n}\n\nfunction identity (value) {\n return value\n}\n\nfunction isBinary (data) {\n return data === undefined || data === null || Buffer.isBuffer(data)\n}\n","/* global indexedDB */\n\n'use strict'\n\nmodule.exports = Level\n\nconst AbstractLevelDOWN = require('abstract-leveldown').AbstractLevelDOWN\nconst inherits = require('inherits')\nconst parallel = require('run-parallel-limit')\nconst Iterator = require('./iterator')\nconst serialize = require('./util/serialize')\nconst deserialize = require('./util/deserialize')\nconst support = require('./util/support')\nconst clear = require('./util/clear')\nconst createKeyRange = require('./util/key-range')\n\nconst DEFAULT_PREFIX = 'level-js-'\n\nfunction Level (location, opts) {\n if (!(this instanceof Level)) return new Level(location, opts)\n\n AbstractLevelDOWN.call(this, {\n bufferKeys: support.bufferKeys(indexedDB),\n snapshots: true,\n permanence: true,\n clear: true,\n getMany: true\n })\n\n opts = opts || {}\n\n if (typeof location !== 'string') {\n throw new Error('constructor requires a location string argument')\n }\n\n this.location = location\n this.prefix = opts.prefix == null ? DEFAULT_PREFIX : opts.prefix\n this.version = parseInt(opts.version || 1, 10)\n}\n\ninherits(Level, AbstractLevelDOWN)\n\nLevel.prototype.type = 'level-js'\n\nLevel.prototype._open = function (options, callback) {\n const req = indexedDB.open(this.prefix + this.location, this.version)\n\n req.onerror = function () {\n callback(req.error || new Error('unknown error'))\n }\n\n req.onsuccess = () => {\n this.db = req.result\n callback()\n }\n\n req.onupgradeneeded = (ev) => {\n const db = ev.target.result\n\n if (!db.objectStoreNames.contains(this.location)) {\n db.createObjectStore(this.location)\n }\n }\n}\n\nLevel.prototype.store = function (mode) {\n const transaction = this.db.transaction([this.location], mode)\n return transaction.objectStore(this.location)\n}\n\nLevel.prototype.await = function (request, callback) {\n const transaction = request.transaction\n\n // Take advantage of the fact that a non-canceled request error aborts\n // the transaction. I.e. no need to listen for \"request.onerror\".\n transaction.onabort = function () {\n callback(transaction.error || new Error('aborted by user'))\n }\n\n transaction.oncomplete = function () {\n callback(null, request.result)\n }\n}\n\nLevel.prototype._get = function (key, options, callback) {\n const store = this.store('readonly')\n let req\n\n try {\n req = store.get(key)\n } catch (err) {\n return this._nextTick(callback, err)\n }\n\n this.await(req, function (err, value) {\n if (err) return callback(err)\n\n if (value === undefined) {\n // 'NotFound' error, consistent with LevelDOWN API\n return callback(new Error('NotFound'))\n }\n\n callback(null, deserialize(value, options.asBuffer))\n })\n}\n\nLevel.prototype._getMany = function (keys, options, callback) {\n const asBuffer = options.asBuffer\n const store = this.store('readonly')\n const tasks = keys.map((key) => (next) => {\n let request\n\n try {\n request = store.get(key)\n } catch (err) {\n return next(err)\n }\n\n request.onsuccess = () => {\n const value = request.result\n next(null, value === undefined ? value : deserialize(value, asBuffer))\n }\n\n request.onerror = (ev) => {\n ev.stopPropagation()\n next(request.error)\n }\n })\n\n parallel(tasks, 16, callback)\n}\n\nLevel.prototype._del = function (key, options, callback) {\n const store = this.store('readwrite')\n let req\n\n try {\n req = store.delete(key)\n } catch (err) {\n return this._nextTick(callback, err)\n }\n\n this.await(req, callback)\n}\n\nLevel.prototype._put = function (key, value, options, callback) {\n const store = this.store('readwrite')\n let req\n\n try {\n // Will throw a DataError or DataCloneError if the environment\n // does not support serializing the key or value respectively.\n req = store.put(value, key)\n } catch (err) {\n return this._nextTick(callback, err)\n }\n\n this.await(req, callback)\n}\n\nLevel.prototype._serializeKey = function (key) {\n return serialize(key, this.supports.bufferKeys)\n}\n\nLevel.prototype._serializeValue = function (value) {\n return serialize(value, true)\n}\n\nLevel.prototype._iterator = function (options) {\n return new Iterator(this, this.location, options)\n}\n\nLevel.prototype._batch = function (operations, options, callback) {\n if (operations.length === 0) return this._nextTick(callback)\n\n const store = this.store('readwrite')\n const transaction = store.transaction\n let index = 0\n let error\n\n transaction.onabort = function () {\n callback(error || transaction.error || new Error('aborted by user'))\n }\n\n transaction.oncomplete = function () {\n callback()\n }\n\n // Wait for a request to complete before making the next, saving CPU.\n function loop () {\n const op = operations[index++]\n const key = op.key\n\n let req\n\n try {\n req = op.type === 'del' ? store.delete(key) : store.put(op.value, key)\n } catch (err) {\n error = err\n transaction.abort()\n return\n }\n\n if (index < operations.length) {\n req.onsuccess = loop\n }\n }\n\n loop()\n}\n\nLevel.prototype._clear = function (options, callback) {\n let keyRange\n let req\n\n try {\n keyRange = createKeyRange(options)\n } catch (e) {\n // The lower key is greater than the upper key.\n // IndexedDB throws an error, but we'll just do nothing.\n return this._nextTick(callback)\n }\n\n if (options.limit >= 0) {\n // IDBObjectStore#delete(range) doesn't have such an option.\n // Fall back to cursor-based implementation.\n return clear(this, this.location, keyRange, options, callback)\n }\n\n try {\n const store = this.store('readwrite')\n req = keyRange ? store.delete(keyRange) : store.clear()\n } catch (err) {\n return this._nextTick(callback, err)\n }\n\n this.await(req, callback)\n}\n\nLevel.prototype._close = function (callback) {\n this.db.close()\n this._nextTick(callback)\n}\n\n// NOTE: remove in a next major release\nLevel.prototype.upgrade = function (callback) {\n if (this.status !== 'open') {\n return this._nextTick(callback, new Error('cannot upgrade() before open()'))\n }\n\n const it = this.iterator()\n const batchOptions = {}\n const self = this\n\n it._deserializeKey = it._deserializeValue = identity\n next()\n\n function next (err) {\n if (err) return finish(err)\n it.next(each)\n }\n\n function each (err, key, value) {\n if (err || key === undefined) {\n return finish(err)\n }\n\n const newKey = self._serializeKey(deserialize(key, true))\n const newValue = self._serializeValue(deserialize(value, true))\n\n // To bypass serialization on the old key, use _batch() instead of batch().\n // NOTE: if we disable snapshotting (#86) this could lead to a loop of\n // inserting and then iterating those same entries, because the new keys\n // possibly sort after the old keys.\n self._batch([\n { type: 'del', key: key },\n { type: 'put', key: newKey, value: newValue }\n ], batchOptions, next)\n }\n\n function finish (err) {\n it.end(function (err2) {\n callback(err || err2)\n })\n }\n\n function identity (data) {\n return data\n }\n}\n\nLevel.destroy = function (location, prefix, callback) {\n if (typeof prefix === 'function') {\n callback = prefix\n prefix = DEFAULT_PREFIX\n }\n const request = indexedDB.deleteDatabase(prefix + location)\n request.onsuccess = function () {\n callback()\n }\n request.onerror = function (err) {\n callback(err)\n }\n}\n","/*! run-parallel-limit. MIT License. Feross Aboukhadijeh */\nmodule.exports = runParallelLimit\n\nconst queueMicrotask = require('queue-microtask')\n\nfunction runParallelLimit (tasks, limit, cb) {\n if (typeof limit !== 'number') throw new Error('second argument must be a Number')\n let results, len, pending, keys, isErrored\n let isSync = true\n let next\n\n if (Array.isArray(tasks)) {\n results = []\n pending = len = tasks.length\n } else {\n keys = Object.keys(tasks)\n results = {}\n pending = len = keys.length\n }\n\n function done (err) {\n function end () {\n if (cb) cb(err, results)\n cb = null\n }\n if (isSync) queueMicrotask(end)\n else end()\n }\n\n function each (i, err, result) {\n results[i] = result\n if (err) isErrored = true\n if (--pending === 0 || err) {\n done(err)\n } else if (!isErrored && next < len) {\n let key\n if (keys) {\n key = keys[next]\n next += 1\n tasks[key](function (err, result) { each(key, err, result) })\n } else {\n key = next\n next += 1\n tasks[key](function (err, result) { each(key, err, result) })\n }\n }\n }\n\n next = limit\n if (!pending) {\n // empty\n done(null)\n } else if (keys) {\n // object\n keys.some(function (key, i) {\n tasks[key](function (err, result) { each(key, err, result) })\n if (i === limit - 1) return true // early return\n return false\n })\n } else {\n // array\n tasks.some(function (task, i) {\n task(function (err, result) { each(i, err, result) })\n if (i === limit - 1) return true // early return\n return false\n })\n }\n\n isSync = false\n}\n","'use strict'\n\nconst inherits = require('inherits')\nconst AbstractIterator = require('abstract-leveldown').AbstractIterator\nconst createKeyRange = require('./util/key-range')\nconst deserialize = require('./util/deserialize')\nconst noop = function () {}\n\nmodule.exports = Iterator\n\nfunction Iterator (db, location, options) {\n AbstractIterator.call(this, db)\n\n this._limit = options.limit\n this._count = 0\n this._callback = null\n this._cache = []\n this._completed = false\n this._aborted = false\n this._error = null\n this._transaction = null\n\n this._keys = options.keys\n this._values = options.values\n this._keyAsBuffer = options.keyAsBuffer\n this._valueAsBuffer = options.valueAsBuffer\n\n if (this._limit === 0) {\n this._completed = true\n return\n }\n\n let keyRange\n\n try {\n keyRange = createKeyRange(options)\n } catch (e) {\n // The lower key is greater than the upper key.\n // IndexedDB throws an error, but we'll just return 0 results.\n this._completed = true\n return\n }\n\n this.createIterator(location, keyRange, options.reverse)\n}\n\ninherits(Iterator, AbstractIterator)\n\nIterator.prototype.createIterator = function (location, keyRange, reverse) {\n const transaction = this.db.db.transaction([location], 'readonly')\n const store = transaction.objectStore(location)\n const req = store.openCursor(keyRange, reverse ? 'prev' : 'next')\n\n req.onsuccess = (ev) => {\n const cursor = ev.target.result\n if (cursor) this.onItem(cursor)\n }\n\n this._transaction = transaction\n\n // If an error occurs (on the request), the transaction will abort.\n transaction.onabort = () => {\n this.onAbort(this._transaction.error || new Error('aborted by user'))\n }\n\n transaction.oncomplete = () => {\n this.onComplete()\n }\n}\n\nIterator.prototype.onItem = function (cursor) {\n this._cache.push(cursor.key, cursor.value)\n\n if (this._limit <= 0 || ++this._count < this._limit) {\n cursor.continue()\n }\n\n this.maybeNext()\n}\n\nIterator.prototype.onAbort = function (err) {\n this._aborted = true\n this._error = err\n this.maybeNext()\n}\n\nIterator.prototype.onComplete = function () {\n this._completed = true\n this.maybeNext()\n}\n\nIterator.prototype.maybeNext = function () {\n if (this._callback) {\n this._next(this._callback)\n this._callback = null\n }\n}\n\nIterator.prototype._next = function (callback) {\n if (this._aborted) {\n // The error should be picked up by either next() or end().\n const err = this._error\n this._error = null\n this._nextTick(callback, err)\n } else if (this._cache.length > 0) {\n let key = this._cache.shift()\n let value = this._cache.shift()\n\n if (this._keys && key !== undefined) {\n key = this._deserializeKey(key, this._keyAsBuffer)\n } else {\n key = undefined\n }\n\n if (this._values && value !== undefined) {\n value = this._deserializeValue(value, this._valueAsBuffer)\n } else {\n value = undefined\n }\n\n this._nextTick(callback, null, key, value)\n } else if (this._completed) {\n this._nextTick(callback)\n } else {\n this._callback = callback\n }\n}\n\n// Exposed for the v4 to v5 upgrade utility\nIterator.prototype._deserializeKey = deserialize\nIterator.prototype._deserializeValue = deserialize\n\nIterator.prototype._end = function (callback) {\n if (this._aborted || this._completed) {\n return this._nextTick(callback, this._error)\n }\n\n // Don't advance the cursor anymore, and the transaction will complete\n // on its own in the next tick. This approach is much cleaner than calling\n // transaction.abort() with its unpredictable event order.\n this.onItem = noop\n this.onAbort = callback\n this.onComplete = callback\n}\n","/* global IDBKeyRange */\n\n'use strict'\n\nconst ltgt = require('ltgt')\nconst NONE = Symbol('none')\n\nmodule.exports = function createKeyRange (options) {\n const lower = ltgt.lowerBound(options, NONE)\n const upper = ltgt.upperBound(options, NONE)\n const lowerOpen = ltgt.lowerBoundExclusive(options, NONE)\n const upperOpen = ltgt.upperBoundExclusive(options, NONE)\n\n if (lower !== NONE && upper !== NONE) {\n return IDBKeyRange.bound(lower, upper, lowerOpen, upperOpen)\n } else if (lower !== NONE) {\n return IDBKeyRange.lowerBound(lower, lowerOpen)\n } else if (upper !== NONE) {\n return IDBKeyRange.upperBound(upper, upperOpen)\n } else {\n return null\n }\n}\n","\nexports.compare = function (a, b) {\n\n if(Buffer.isBuffer(a)) {\n var l = Math.min(a.length, b.length)\n for(var i = 0; i < l; i++) {\n var cmp = a[i] - b[i]\n if(cmp) return cmp\n }\n return a.length - b.length\n }\n\n return a < b ? -1 : a > b ? 1 : 0\n}\n\n// to be compatible with the current abstract-leveldown tests\n// nullish or empty strings.\n// I could use !!val but I want to permit numbers and booleans,\n// if possible.\n\nfunction isDef (val) {\n return val !== undefined && val !== ''\n}\n\nfunction has (range, name) {\n return Object.hasOwnProperty.call(range, name)\n}\n\nfunction hasKey(range, name) {\n return Object.hasOwnProperty.call(range, name) && name\n}\n\nvar lowerBoundKey = exports.lowerBoundKey = function (range) {\n return (\n hasKey(range, 'gt')\n || hasKey(range, 'gte')\n || hasKey(range, 'min')\n || (range.reverse ? hasKey(range, 'end') : hasKey(range, 'start'))\n || undefined\n )\n}\n\nvar lowerBound = exports.lowerBound = function (range, def) {\n var k = lowerBoundKey(range)\n return k ? range[k] : def\n}\n\nvar lowerBoundInclusive = exports.lowerBoundInclusive = function (range) {\n return has(range, 'gt') ? false : true\n}\n\nvar upperBoundInclusive = exports.upperBoundInclusive =\n function (range) {\n return (has(range, 'lt') /*&& !range.maxEx*/) ? false : true\n }\n\nvar lowerBoundExclusive = exports.lowerBoundExclusive =\n function (range) {\n return !lowerBoundInclusive(range)\n }\n\nvar upperBoundExclusive = exports.upperBoundExclusive =\n function (range) {\n return !upperBoundInclusive(range)\n }\n\nvar upperBoundKey = exports.upperBoundKey = function (range) {\n return (\n hasKey(range, 'lt')\n || hasKey(range, 'lte')\n || hasKey(range, 'max')\n || (range.reverse ? hasKey(range, 'start') : hasKey(range, 'end'))\n || undefined\n )\n}\n\nvar upperBound = exports.upperBound = function (range, def) {\n var k = upperBoundKey(range)\n return k ? range[k] : def\n}\n\nexports.start = function (range, def) {\n return range.reverse ? upperBound(range, def) : lowerBound(range, def)\n}\nexports.end = function (range, def) {\n return range.reverse ? lowerBound(range, def) : upperBound(range, def)\n}\nexports.startInclusive = function (range) {\n return (\n range.reverse\n ? upperBoundInclusive(range)\n : lowerBoundInclusive(range)\n )\n}\nexports.endInclusive = function (range) {\n return (\n range.reverse\n ? lowerBoundInclusive(range)\n : upperBoundInclusive(range)\n )\n}\n\nfunction id (e) { return e }\n\nexports.toLtgt = function (range, _range, map, lower, upper) {\n _range = _range || {}\n map = map || id\n var defaults = arguments.length > 3\n var lb = exports.lowerBoundKey(range)\n var ub = exports.upperBoundKey(range)\n if(lb) {\n if(lb === 'gt') _range.gt = map(range.gt, false)\n else _range.gte = map(range[lb], false)\n }\n else if(defaults)\n _range.gte = map(lower, false)\n\n if(ub) {\n if(ub === 'lt') _range.lt = map(range.lt, true)\n else _range.lte = map(range[ub], true)\n }\n else if(defaults)\n _range.lte = map(upper, true)\n\n if(range.reverse != null)\n _range.reverse = !!range.reverse\n\n //if range was used mutably\n //(in level-sublevel it's part of an options object\n //that has more properties on it.)\n if(has(_range, 'max')) delete _range.max\n if(has(_range, 'min')) delete _range.min\n if(has(_range, 'start')) delete _range.start\n if(has(_range, 'end')) delete _range.end\n\n return _range\n}\n\nexports.contains = function (range, key, compare) {\n compare = compare || exports.compare\n\n var lb = lowerBound(range)\n if(isDef(lb)) {\n var cmp = compare(key, lb)\n if(cmp < 0 || (cmp === 0 && lowerBoundExclusive(range)))\n return false\n }\n\n var ub = upperBound(range)\n if(isDef(ub)) {\n var cmp = compare(key, ub)\n if(cmp > 0 || (cmp === 0) && upperBoundExclusive(range))\n return false\n }\n\n return true\n}\n\nexports.filter = function (range, compare) {\n return function (key) {\n return exports.contains(range, key, compare)\n }\n}\n\n\n","'use strict'\n\nconst Buffer = require('buffer').Buffer\nconst ta2str = (function () {\n if (global.TextDecoder) {\n const decoder = new TextDecoder('utf-8')\n return decoder.decode.bind(decoder)\n } else {\n return function ta2str (ta) {\n return ta2buf(ta).toString()\n }\n }\n})()\n\nconst ab2str = (function () {\n if (global.TextDecoder) {\n const decoder = new TextDecoder('utf-8')\n return decoder.decode.bind(decoder)\n } else {\n return function ab2str (ab) {\n return Buffer.from(ab).toString()\n }\n }\n})()\n\nfunction ta2buf (ta) {\n const buf = Buffer.from(ta.buffer)\n\n if (ta.byteLength === ta.buffer.byteLength) {\n return buf\n } else {\n return buf.slice(ta.byteOffset, ta.byteOffset + ta.byteLength)\n }\n}\n\nmodule.exports = function (data, asBuffer) {\n if (data instanceof Uint8Array) {\n return asBuffer ? ta2buf(data) : ta2str(data)\n } else if (data instanceof ArrayBuffer) {\n return asBuffer ? Buffer.from(data) : ab2str(data)\n } else {\n return asBuffer ? Buffer.from(String(data)) : String(data)\n }\n}\n","'use strict'\n\nconst Buffer = require('buffer').Buffer\n// Returns either a Uint8Array or Buffer (doesn't matter to\n// IndexedDB, because Buffer is a subclass of Uint8Array)\nconst str2bin = (function () {\n if (global.TextEncoder) {\n const encoder = new TextEncoder('utf-8')\n return encoder.encode.bind(encoder)\n } else {\n return Buffer.from\n }\n})()\n\nmodule.exports = function (data, asBuffer) {\n if (asBuffer) {\n return Buffer.isBuffer(data) ? data : str2bin(String(data))\n } else {\n return String(data)\n }\n}\n","'use strict'\n\nconst Buffer = require('buffer').Buffer\n\nexports.test = function (key) {\n return function test (impl) {\n try {\n impl.cmp(key, 0)\n return true\n } catch (err) {\n return false\n }\n }\n}\n\n// Detect binary key support (IndexedDB Second Edition)\nexports.bufferKeys = exports.test(Buffer.alloc(0))\n","'use strict'\n\nmodule.exports = function clear (db, location, keyRange, options, callback) {\n if (options.limit === 0) return db._nextTick(callback)\n\n const transaction = db.db.transaction([location], 'readwrite')\n const store = transaction.objectStore(location)\n let count = 0\n\n transaction.oncomplete = function () {\n callback()\n }\n\n transaction.onabort = function () {\n callback(transaction.error || new Error('aborted by user'))\n }\n\n // A key cursor is faster (skips reading values) but not supported by IE\n const method = store.openKeyCursor ? 'openKeyCursor' : 'openCursor'\n const direction = options.reverse ? 'prev' : 'next'\n\n store[method](keyRange, direction).onsuccess = function (ev) {\n const cursor = ev.target.result\n\n if (cursor) {\n // Wait for a request to complete before continuing, saving CPU.\n store.delete(cursor.key).onsuccess = function () {\n if (options.limit <= 0 || ++count < options.limit) {\n cursor.continue()\n }\n }\n }\n }\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar drain = require('it-drain');\nvar pushable = require('it-pushable');\nvar key = require('interface-datastore/key');\nvar cid = require('multiformats/cid');\nvar raw = require('multiformats/codecs/raw');\nvar Digest = require('multiformats/hashes/digest');\nvar base32 = require('multiformats/bases/base32');\nvar base58 = require('multiformats/bases/base58');\nvar errcode = require('err-code');\nvar base = require('blockstore-core/base');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar pushable__default = /*#__PURE__*/_interopDefaultLegacy(pushable);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\n\nfunction cidToKey(cid$1) {\n const c = cid.CID.asCID(cid$1);\n if (!c) {\n throw errcode__default['default'](new Error('Not a valid cid'), 'ERR_INVALID_CID');\n }\n return new key.Key('/' + base32.base32.encode(c.multihash.bytes).slice(1).toUpperCase(), false);\n}\nfunction keyToCid(key) {\n return cid.CID.createV1(raw__namespace.code, Digest__namespace.decode(base32.base32.decode('b' + key.toString().slice(1).toLowerCase())));\n}\nfunction convertPrefix(prefix) {\n const firstChar = prefix.substring(0, 1);\n if (firstChar === '/') {\n return convertPrefix(prefix.substring(1));\n }\n let decoder;\n if (firstChar.toLowerCase() === 'b') {\n decoder = input => base32.base32.decode(input.toLowerCase()).subarray(2);\n } else if (firstChar.toLowerCase() === 'c') {\n decoder = input => base32.base32pad.decode(input.toLowerCase()).subarray(2);\n } else if (firstChar === 'z') {\n decoder = input => base58.base58btc.decode(input).subarray(2);\n } else if (firstChar === 'Q') {\n decoder = input => base58.base58btc.decode('z' + input);\n } else {\n decoder = input => base32.base32.decode('b' + input.toLowerCase()).subarray(2);\n }\n let bytes;\n for (let i = 1; i < prefix.length; i++) {\n try {\n bytes = decoder(prefix.substring(0, i));\n } catch (err) {\n if (err.message !== 'Unexpected end of data') {\n throw err;\n }\n }\n }\n let str = '/C';\n if (bytes) {\n str = `/${ base32.base32.encode(bytes).slice(1, -1).toUpperCase() || 'C' }`;\n }\n return str;\n}\nfunction convertQuery(query) {\n return {\n ...query,\n prefix: query.prefix ? convertPrefix(query.prefix) : undefined,\n filters: query.filters ? query.filters.map(filter => pair => {\n return filter({\n key: keyToCid(pair.key),\n value: pair.value\n });\n }) : undefined,\n orders: query.orders ? query.orders.map(order => (a, b) => {\n return order({\n key: keyToCid(a.key),\n value: a.value\n }, {\n key: keyToCid(b.key),\n value: b.value\n });\n }) : undefined\n };\n}\nfunction convertKeyQuery(query) {\n return {\n ...query,\n prefix: query.prefix ? convertPrefix(query.prefix) : undefined,\n filters: query.filters ? query.filters.map(filter => key => {\n return filter(keyToCid(key));\n }) : undefined,\n orders: query.orders ? query.orders.map(order => (a, b) => {\n return order(keyToCid(a), keyToCid(b));\n }) : undefined\n };\n}\nclass BlockstoreDatastoreAdapter extends base.BaseBlockstore {\n constructor(datastore) {\n super();\n this.child = datastore;\n }\n open() {\n return this.child.open();\n }\n close() {\n return this.child.close();\n }\n async *query(query, options) {\n for await (const {key, value} of this.child.query(convertQuery(query), options)) {\n yield {\n key: keyToCid(key),\n value\n };\n }\n }\n async *queryKeys(query, options) {\n for await (const key of this.child.queryKeys(convertKeyQuery(query), options)) {\n yield keyToCid(key);\n }\n }\n async get(cid, options) {\n return this.child.get(cidToKey(cid), options);\n }\n async *getMany(cids, options) {\n for await (const cid of cids) {\n yield this.get(cid, options);\n }\n }\n async put(cid, value, options) {\n await this.child.put(cidToKey(cid), value, options);\n }\n async *putMany(blocks, options) {\n const output = pushable__default['default']();\n const runner = globalThis.process && globalThis.process.nextTick ? globalThis.process.nextTick : globalThis.setImmediate || globalThis.setTimeout;\n runner(async () => {\n try {\n const store = this.child;\n await drain__default['default'](this.child.putMany(async function* () {\n for await (const block of blocks) {\n const key = cidToKey(block.key);\n const exists = await store.has(key, options);\n if (!exists) {\n yield {\n key,\n value: block.value\n };\n }\n output.push(block);\n }\n }()));\n output.end();\n } catch (err) {\n output.end(err);\n }\n });\n yield* output;\n }\n has(cid, options) {\n return this.child.has(cidToKey(cid), options);\n }\n delete(cid, options) {\n return this.child.delete(cidToKey(cid), options);\n }\n deleteMany(cids, options) {\n const out = pushable__default['default']();\n drain__default['default'](this.child.deleteMany(async function* () {\n for await (const cid of cids) {\n yield cidToKey(cid);\n out.push(cid);\n }\n out.end();\n }(), options)).catch(err => {\n out.end(err);\n });\n return out;\n }\n}\n\nexports.BlockstoreDatastoreAdapter = BlockstoreDatastoreAdapter;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar drain = require('it-drain');\nvar filter = require('it-filter');\nvar take = require('it-take');\nvar all = require('it-all');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar take__default = /*#__PURE__*/_interopDefaultLegacy(take);\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\n\nconst sortAll = (iterable, sorter) => {\n return async function* () {\n const values = await all__default['default'](iterable);\n yield* values.sort(sorter);\n }();\n};\nclass BaseBlockstore {\n open() {\n return Promise.reject(new Error('.open is not implemented'));\n }\n close() {\n return Promise.reject(new Error('.close is not implemented'));\n }\n put(key, val, options) {\n return Promise.reject(new Error('.put is not implemented'));\n }\n get(key, options) {\n return Promise.reject(new Error('.get is not implemented'));\n }\n has(key, options) {\n return Promise.reject(new Error('.has is not implemented'));\n }\n delete(key, options) {\n return Promise.reject(new Error('.delete is not implemented'));\n }\n async *putMany(source, options = {}) {\n for await (const {key, value} of source) {\n await this.put(key, value, options);\n yield {\n key,\n value\n };\n }\n }\n async *getMany(source, options = {}) {\n for await (const key of source) {\n yield this.get(key, options);\n }\n }\n async *deleteMany(source, options = {}) {\n for await (const key of source) {\n await this.delete(key, options);\n yield key;\n }\n }\n batch() {\n let puts = [];\n let dels = [];\n return {\n put(key, value) {\n puts.push({\n key,\n value\n });\n },\n delete(key) {\n dels.push(key);\n },\n commit: async options => {\n await drain__default['default'](this.putMany(puts, options));\n puts = [];\n await drain__default['default'](this.deleteMany(dels, options));\n dels = [];\n }\n };\n }\n async *_all(q, options) {\n throw new Error('._all is not implemented');\n }\n async *_allKeys(q, options) {\n throw new Error('._allKeys is not implemented');\n }\n query(q, options) {\n let it = this._all(q, options);\n if (q.prefix != null) {\n it = filter__default['default'](it, e => e.key.toString().startsWith(q.prefix || ''));\n }\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => sortAll(it, f), it);\n }\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= (q.offset || 0));\n }\n if (q.limit != null) {\n it = take__default['default'](it, q.limit);\n }\n return it;\n }\n queryKeys(q, options) {\n let it = this._allKeys(q, options);\n if (q.prefix != null) {\n it = filter__default['default'](it, cid => cid.toString().startsWith(q.prefix || ''));\n }\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => sortAll(it, f), it);\n }\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null) {\n it = take__default['default'](it, q.limit);\n }\n return it;\n }\n}\n\nexports.BaseBlockstore = BaseBlockstore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar get = require('dlv');\nvar mergeOpts = require('merge-options');\nvar errCode = require('err-code');\nvar libp2pPubsubRouters = require('ipfs-core-config/libp2p-pubsub-routers');\nvar DelegatedPeerRouter = require('libp2p-delegated-peer-routing');\nvar DelegatedContentRouter = require('libp2p-delegated-content-routing');\nvar ipfsHttpClient = require('ipfs-http-client');\nvar multiaddr = require('multiaddr');\nvar version = require('../version.js');\nvar libp2p = require('ipfs-core-config/libp2p');\nvar bootstrap = require('libp2p-bootstrap');\nvar Libp2p = require('libp2p');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar get__default = /*#__PURE__*/_interopDefaultLegacy(get);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar DelegatedPeerRouter__default = /*#__PURE__*/_interopDefaultLegacy(DelegatedPeerRouter);\nvar DelegatedContentRouter__default = /*#__PURE__*/_interopDefaultLegacy(DelegatedContentRouter);\nvar bootstrap__default = /*#__PURE__*/_interopDefaultLegacy(bootstrap);\nvar Libp2p__default = /*#__PURE__*/_interopDefaultLegacy(Libp2p);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nfunction createLibp2p({options = {}, peerId, multiaddrs = [], repo, keychainConfig = {}, config = {}}) {\n const {datastore, keys} = repo;\n const libp2pOptions = getLibp2pOptions({\n options,\n config,\n datastore,\n keys,\n keychainConfig,\n peerId,\n multiaddrs\n });\n if (typeof options.libp2p === 'function') {\n return options.libp2p({\n libp2pOptions,\n options,\n config,\n datastore,\n peerId\n });\n }\n return Libp2p__default['default'].create(libp2pOptions);\n}\nfunction getLibp2pOptions({options, config, datastore, keys, keychainConfig, peerId, multiaddrs}) {\n const getPubsubRouter = () => {\n const router = get__default['default'](config, 'Pubsub.Router') || 'gossipsub';\n if (!libp2pPubsubRouters.routers[router]) {\n throw errCode__default['default'](new Error(`Router unavailable. Configure libp2p.modules.pubsub to use the ${ router } router.`), 'ERR_NOT_SUPPORTED');\n }\n return libp2pPubsubRouters.routers[router];\n };\n const libp2pDefaults = {\n datastore,\n peerId: peerId,\n modules: {}\n };\n const libp2pOptions = {\n modules: {\n pubsub: getPubsubRouter(),\n contentRouting: [],\n peerRouting: []\n },\n config: {\n peerDiscovery: {\n mdns: { enabled: get__default['default'](options, 'config.Discovery.MDNS.Enabled', get__default['default'](config, 'Discovery.MDNS.Enabled', true)) },\n webRTCStar: { enabled: get__default['default'](options, 'config.Discovery.webRTCStar.Enabled', get__default['default'](config, 'Discovery.webRTCStar.Enabled', true)) },\n bootstrap: { list: get__default['default'](options, 'config.Bootstrap', get__default['default'](config, 'Bootstrap', [])) }\n },\n relay: {\n enabled: get__default['default'](options, 'relay.enabled', get__default['default'](config, 'relay.enabled', true)),\n hop: {\n enabled: get__default['default'](options, 'relay.hop.enabled', get__default['default'](config, 'relay.hop.enabled', false)),\n active: get__default['default'](options, 'relay.hop.active', get__default['default'](config, 'relay.hop.active', false))\n }\n },\n dht: {\n enabled: get__default['default'](config, 'Routing.Type', 'none') !== 'none',\n clientMode: get__default['default'](config, 'Routing.Type', 'dht') !== 'dhtserver',\n kBucketSize: get__default['default'](options, 'dht.kBucketSize', 20)\n },\n pubsub: { enabled: get__default['default'](options, 'config.Pubsub.Enabled', get__default['default'](config, 'Pubsub.Enabled', true)) },\n nat: { enabled: !get__default['default'](config, 'Swarm.DisableNatPortMap', false) }\n },\n addresses: {\n listen: multiaddrs.map(ma => ma.toString()),\n announce: get__default['default'](options, 'addresses.announce', get__default['default'](config, 'Addresses.Announce', [])),\n noAnnounce: get__default['default'](options, 'addresses.noAnnounce', get__default['default'](config, 'Addresses.NoAnnounce', []))\n },\n connectionManager: get__default['default'](options, 'connectionManager', {\n maxConnections: get__default['default'](options, 'config.Swarm.ConnMgr.HighWater', get__default['default'](config, 'Swarm.ConnMgr.HighWater')),\n minConnections: get__default['default'](options, 'config.Swarm.ConnMgr.LowWater', get__default['default'](config, 'Swarm.ConnMgr.LowWater'))\n }),\n keychain: {\n datastore: keys,\n ...keychainConfig\n },\n host: { agentVersion: `js-ipfs/${ version.ipfsCore }` }\n };\n let constructorOptions = get__default['default'](options, 'libp2p', undefined);\n if (typeof constructorOptions === 'function') {\n constructorOptions = undefined;\n }\n const libp2pConfig = mergeOptions(libp2pDefaults, libp2p.libp2pConfig(), libp2pOptions, constructorOptions);\n const bootstrapList = get__default['default'](libp2pConfig, 'config.peerDiscovery.bootstrap.list', []);\n if (bootstrapList.length > 0) {\n libp2pConfig.modules.peerDiscovery.push(bootstrap__default['default']);\n }\n const delegateHosts = get__default['default'](options, 'config.Addresses.Delegates', get__default['default'](config, 'Addresses.Delegates', []));\n if (delegateHosts.length > 0) {\n const delegateString = delegateHosts[Math.floor(Math.random() * delegateHosts.length)];\n const delegateAddr = new multiaddr.Multiaddr(delegateString).toOptions();\n const delegateApiOptions = {\n host: delegateAddr.host,\n protocol: parseInt(delegateAddr.port) === 443 ? 'https' : 'http',\n port: delegateAddr.port\n };\n const delegateHttpClient = ipfsHttpClient.create(delegateApiOptions);\n libp2pOptions.modules.contentRouting = libp2pOptions.modules.contentRouting || [];\n libp2pOptions.modules.contentRouting.push(new DelegatedContentRouter__default['default'](peerId, delegateHttpClient));\n libp2pOptions.modules.peerRouting = libp2pOptions.modules.peerRouting || [];\n libp2pOptions.modules.peerRouting.push(new DelegatedPeerRouter__default['default'](delegateHttpClient));\n }\n return libp2pConfig;\n}\n\nexports.createLibp2p = createLibp2p;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar GossipSub = require('libp2p-gossipsub');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar GossipSub__default = /*#__PURE__*/_interopDefaultLegacy(GossipSub);\n\nconst routers = { gossipsub: GossipSub__default[\"default\"] };\n\nexports.routers = routers;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nconst pubsub_1 = __importStar(require(\"libp2p-interfaces/src/pubsub\"));\nconst message_cache_1 = require(\"./message-cache\");\nconst rpc_1 = require(\"./message/rpc\");\nconst constants = __importStar(require(\"./constants\"));\nconst heartbeat_1 = require(\"./heartbeat\");\nconst get_gossip_peers_1 = require(\"./get-gossip-peers\");\nconst utils_1 = require(\"./utils\");\nconst score_1 = require(\"./score\");\nconst tracer_1 = require(\"./tracer\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst TimeCache = require(\"time-cache\");\nconst PeerId = require(\"peer-id\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst Envelope = require(\"libp2p/src/record/envelope\");\nclass Gossipsub extends pubsub_1.default {\n // TODO: add remaining props\n /**\n * @param {Libp2p} libp2p\n * @param {Object} [options]\n * @param {boolean} [options.emitSelf = false] if publish should emit to self, if subscribed\n * @param {boolean} [options.canRelayMessage = false] - if can relay messages not subscribed\n * @param {boolean} [options.gossipIncoming = true] if incoming messages on a subscribed topic should be automatically gossiped\n * @param {boolean} [options.fallbackToFloodsub = true] if dial should fallback to floodsub\n * @param {boolean} [options.floodPublish = true] if self-published messages should be sent to all peers\n * @param {boolean} [options.doPX = false] whether PX is enabled; this should be enabled in bootstrappers and other well connected/trusted nodes.\n * @param {Object} [options.messageCache] override the default MessageCache\n * @param {string} [options.globalSignaturePolicy = \"StrictSign\"] signing policy to apply across all messages\n * @param {Object} [options.scoreParams] peer score parameters\n * @param {Object} [options.scoreThresholds] peer score thresholds\n * @param {AddrInfo[]} [options.directPeers] peers with which we will maintain direct connections\n * @constructor\n */\n constructor(libp2p, options = {}) {\n const multicodecs = [constants.GossipsubIDv11, constants.GossipsubIDv10];\n const opts = Object.assign(Object.assign({ gossipIncoming: true, fallbackToFloodsub: true, floodPublish: true, doPX: false, directPeers: [], D: constants.GossipsubD, Dlo: constants.GossipsubDlo, Dhi: constants.GossipsubDhi, Dscore: constants.GossipsubDscore, Dout: constants.GossipsubDout, Dlazy: constants.GossipsubDlazy, heartbeatInterval: constants.GossipsubHeartbeatInterval, fanoutTTL: constants.GossipsubFanoutTTL, mcacheLength: constants.GossipsubHistoryLength, mcacheGossip: constants.GossipsubHistoryGossip, seenTTL: constants.GossipsubSeenTTL }, options), { scoreParams: score_1.createPeerScoreParams(options.scoreParams), scoreThresholds: score_1.createPeerScoreThresholds(options.scoreThresholds) });\n // Also wants to get notified of peers connected using floodsub\n if (opts.fallbackToFloodsub) {\n multicodecs.push(constants.FloodsubID);\n }\n super(Object.assign({ debugName: 'libp2p:gossipsub', multicodecs,\n libp2p }, opts));\n this._options = opts;\n /**\n * Direct peers\n * @type {Set}\n */\n this.direct = new Set(opts.directPeers.map(p => p.id.toB58String()));\n // set direct peer addresses in the address book\n opts.directPeers.forEach(p => {\n libp2p.peerStore.addressBook.add(p.id, p.addrs);\n });\n /**\n * Cache of seen messages\n *\n * @type {TimeCache}\n */\n this.seenCache = new TimeCache({ validity: opts.seenTTL / 1000 });\n /**\n * Map of topic meshes\n * topic => peer id set\n *\n * @type {Map>}\n */\n this.mesh = new Map();\n /**\n * Map of topics to set of peers. These mesh peers are the ones to which we are publishing without a topic membership\n * topic => peer id set\n *\n * @type {Map>}\n */\n this.fanout = new Map();\n /**\n * Map of last publish time for fanout topics\n * topic => last publish time\n *\n * @type {Map}\n */\n this.lastpub = new Map();\n /**\n * Map of pending messages to gossip\n * peer id => control messages\n *\n * @type {Map> }\n */\n this.gossip = new Map();\n /**\n * Map of control messages\n * peer id => control message\n *\n * @type {Map}\n */\n this.control = new Map();\n /**\n * Number of IHAVEs received from peer in the last heartbeat\n * @type {Map}\n */\n this.peerhave = new Map();\n /**\n * Number of messages we have asked from peer in the last heartbeat\n * @type {Map}\n */\n this.iasked = new Map();\n /**\n * Prune backoff map\n */\n this.backoff = new Map();\n /**\n * Connection direction cache, marks peers with outbound connections\n * peer id => direction\n *\n * @type {Map}\n */\n this.outbound = new Map();\n /**\n * A message cache that contains the messages for last few hearbeat ticks\n *\n */\n this.messageCache = options.messageCache || new message_cache_1.MessageCache(opts.mcacheGossip, opts.mcacheLength, this.getMsgId.bind(this));\n /**\n * A heartbeat timer that maintains the mesh\n */\n this.heartbeat = new heartbeat_1.Heartbeat(this);\n /**\n * Number of heartbeats since the beginning of time\n * This allows us to amortize some resource cleanup -- eg: backoff cleanup\n */\n this.heartbeatTicks = 0;\n /**\n * Tracks IHAVE/IWANT promises broken by peers\n */\n this.gossipTracer = new tracer_1.IWantTracer(this.getMsgId.bind(this));\n /**\n * libp2p\n */\n this._libp2p = libp2p;\n /**\n * Peer score tracking\n */\n this.score = new score_1.PeerScore(this._options.scoreParams, libp2p.connectionManager, this.getMsgId.bind(this));\n }\n /**\n * Decode a Uint8Array into an RPC object\n * Overrided to use an extended protocol-specific protobuf decoder\n * @override\n * @param {Uint8Array} bytes\n * @returns {RPC}\n */\n _decodeRpc(bytes) {\n return rpc_1.RPC.decode(bytes);\n }\n /**\n * Encode an RPC object into a Uint8Array\n * Overrided to use an extended protocol-specific protobuf encoder\n * @override\n * @param {RPC} rpc\n * @returns {Uint8Array}\n */\n _encodeRpc(rpc) {\n return rpc_1.RPC.encode(rpc).finish();\n }\n /**\n * Add a peer to the router\n * @override\n * @param {PeerId} peerId\n * @param {string} protocol\n * @returns {PeerStreams}\n */\n _addPeer(peerId, protocol) {\n const p = super._addPeer(peerId, protocol);\n // Add to peer scoring\n this.score.addPeer(peerId.toB58String());\n // track the connection direction\n let outbound = false;\n for (const c of this._libp2p.connectionManager.getAll(peerId)) {\n if (c.stat.direction === 'outbound') {\n if (Array.from(c.registry.values()).some(rvalue => protocol === rvalue.protocol)) {\n outbound = true;\n break;\n }\n }\n }\n this.outbound.set(p.id.toB58String(), outbound);\n return p;\n }\n /**\n * Removes a peer from the router\n * @override\n * @param {PeerId} peer\n * @returns {PeerStreams | undefined}\n */\n _removePeer(peerId) {\n const peerStreams = super._removePeer(peerId);\n const id = peerId.toB58String();\n // Remove this peer from the mesh\n // eslint-disable-next-line no-unused-vars\n for (const peers of this.mesh.values()) {\n peers.delete(id);\n }\n // Remove this peer from the fanout\n // eslint-disable-next-line no-unused-vars\n for (const peers of this.fanout.values()) {\n peers.delete(id);\n }\n // Remove from gossip mapping\n this.gossip.delete(id);\n // Remove from control mapping\n this.control.delete(id);\n // Remove from backoff mapping\n this.outbound.delete(id);\n // Remove from peer scoring\n this.score.removePeer(id);\n return peerStreams;\n }\n /**\n * Handles an rpc request from a peer\n *\n * @override\n * @param {String} idB58Str\n * @param {PeerStreams} peerStreams\n * @param {RPC} rpc\n * @returns {Promise}\n */\n _processRpc(id, peerStreams, rpc) {\n const _super = Object.create(null, {\n _processRpc: { get: () => super._processRpc }\n });\n return __awaiter(this, void 0, void 0, function* () {\n if (yield _super._processRpc.call(this, id, peerStreams, rpc)) {\n if (rpc.control) {\n this._processRpcControlMessage(id, rpc.control);\n }\n return true;\n }\n return false;\n });\n }\n /**\n * Handles an rpc control message from a peer\n * @param {string} id peer id\n * @param {RPC.IControlMessage} controlMsg\n * @returns {void}\n */\n _processRpcControlMessage(id, controlMsg) {\n if (!controlMsg) {\n return;\n }\n const iwant = controlMsg.ihave ? this._handleIHave(id, controlMsg.ihave) : [];\n const ihave = controlMsg.iwant ? this._handleIWant(id, controlMsg.iwant) : [];\n const prune = controlMsg.graft ? this._handleGraft(id, controlMsg.graft) : [];\n controlMsg.prune && this._handlePrune(id, controlMsg.prune);\n if (!iwant.length && !ihave.length && !prune.length) {\n return;\n }\n const outRpc = utils_1.createGossipRpc(ihave, { iwant, prune });\n this._sendRpc(id, outRpc);\n }\n /**\n * Process incoming message,\n * emitting locally and forwarding on to relevant floodsub and gossipsub peers\n * @override\n * @param {InMessage} msg\n * @returns {Promise}\n */\n _processRpcMessage(msg) {\n const _super = Object.create(null, {\n _processRpcMessage: { get: () => super._processRpcMessage }\n });\n return __awaiter(this, void 0, void 0, function* () {\n const msgID = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgID);\n // Ignore if we've already seen the message\n if (this.seenCache.has(msgIdStr)) {\n this.score.duplicateMessage(msg);\n return;\n }\n this.seenCache.put(msgIdStr);\n yield this.score.validateMessage(msg);\n yield _super._processRpcMessage.call(this, msg);\n });\n }\n /**\n * Whether to accept a message from a peer\n * @override\n * @param {string} id\n * @returns {boolean}\n */\n _acceptFrom(id) {\n return this.direct.has(id) || this.score.score(id) >= this._options.scoreThresholds.graylistThreshold;\n }\n /**\n * Validate incoming message\n * @override\n * @param {InMessage} message\n * @returns {Promise}\n */\n validate(message) {\n const _super = Object.create(null, {\n validate: { get: () => super.validate }\n });\n return __awaiter(this, void 0, void 0, function* () {\n try {\n yield _super.validate.call(this, message);\n }\n catch (e) {\n this.score.rejectMessage(message, e.code);\n this.gossipTracer.rejectMessage(message, e.code);\n throw e;\n }\n });\n }\n /**\n * Handles IHAVE messages\n * @param {string} id peer id\n * @param {Array} ihave\n * @returns {RPC.IControlIWant}\n */\n _handleIHave(id, ihave) {\n if (!ihave.length) {\n return [];\n }\n // we ignore IHAVE gossip from any peer whose score is below the gossips threshold\n const score = this.score.score(id);\n if (score < this._options.scoreThresholds.gossipThreshold) {\n this.log('IHAVE: ignoring peer %s with score below threshold [ score = %d ]', id, score);\n return [];\n }\n // IHAVE flood protection\n const peerhave = (this.peerhave.get(id) || 0) + 1;\n this.peerhave.set(id, peerhave);\n if (peerhave > constants.GossipsubMaxIHaveMessages) {\n this.log('IHAVE: peer %s has advertised too many times (%d) within this heartbeat interval; ignoring', id, peerhave);\n return [];\n }\n const iasked = this.iasked.get(id) || 0;\n if (iasked >= constants.GossipsubMaxIHaveLength) {\n this.log('IHAVE: peer %s has already advertised too many messages (%d); ignoring', id, iasked);\n return [];\n }\n // string msgId => msgId\n const iwant = new Map();\n ihave.forEach(({ topicID, messageIDs }) => {\n if (!topicID || !messageIDs || !this.mesh.has(topicID)) {\n return;\n }\n messageIDs.forEach((msgID) => {\n const msgIdStr = utils_1.messageIdToString(msgID);\n if (this.seenCache.has(msgIdStr)) {\n return;\n }\n iwant.set(msgIdStr, msgID);\n });\n });\n if (!iwant.size) {\n return [];\n }\n let iask = iwant.size;\n if (iask + iasked > constants.GossipsubMaxIHaveLength) {\n iask = constants.GossipsubMaxIHaveLength - iasked;\n }\n this.log('IHAVE: Asking for %d out of %d messages from %s', iask, iwant.size, id);\n let iwantList = Array.from(iwant.values());\n // ask in random order\n utils_1.shuffle(iwantList);\n // truncate to the messages we are actually asking for and update the iasked counter\n iwantList = iwantList.slice(0, iask);\n this.iasked.set(id, iasked + iask);\n this.gossipTracer.addPromise(id, iwantList);\n return [{\n messageIDs: iwantList\n }];\n }\n /**\n * Handles IWANT messages\n * Returns messages to send back to peer\n * @param {string} id peer id\n * @param {Array} iwant\n * @returns {Array}\n */\n _handleIWant(id, iwant) {\n if (!iwant.length) {\n return [];\n }\n // we don't respond to IWANT requests from any per whose score is below the gossip threshold\n const score = this.score.score(id);\n if (score < this._options.scoreThresholds.gossipThreshold) {\n this.log('IWANT: ignoring peer %s with score below threshold [score = %d]', id, score);\n return [];\n }\n // @type {Map}\n const ihave = new Map();\n iwant.forEach(({ messageIDs }) => {\n messageIDs && messageIDs.forEach((msgID) => {\n const [msg, count] = this.messageCache.getForPeer(msgID, id);\n if (!msg) {\n return;\n }\n if (count > constants.GossipsubGossipRetransmission) {\n this.log('IWANT: Peer %s has asked for message %s too many times: ignoring request', id, msgID);\n return;\n }\n ihave.set(utils_1.messageIdToString(msgID), msg);\n });\n });\n if (!ihave.size) {\n return [];\n }\n this.log('IWANT: Sending %d messages to %s', ihave.size, id);\n return Array.from(ihave.values()).map(pubsub_1.utils.normalizeOutRpcMessage);\n }\n /**\n * Handles Graft messages\n * @param {string} id peer id\n * @param {Array} graft\n * @return {Array}\n */\n _handleGraft(id, graft) {\n const prune = [];\n const score = this.score.score(id);\n const now = this._now();\n let doPX = this._options.doPX;\n graft.forEach(({ topicID }) => {\n var _a;\n if (!topicID) {\n return;\n }\n const peersInMesh = this.mesh.get(topicID);\n if (!peersInMesh) {\n // don't do PX when there is an unknown topic to avoid leaking our peers\n doPX = false;\n // spam hardening: ignore GRAFTs for unknown topics\n return;\n }\n // check if peer is already in the mesh; if so do nothing\n if (peersInMesh.has(id)) {\n return;\n }\n // we don't GRAFT to/from direct peers; complain loudly if this happens\n if (this.direct.has(id)) {\n this.log('GRAFT: ignoring request from direct peer %s', id);\n // this is possibly a bug from a non-reciprical configuration; send a PRUNE\n prune.push(topicID);\n // but don't px\n doPX = false;\n return;\n }\n // make sure we are not backing off that peer\n const expire = (_a = this.backoff.get(topicID)) === null || _a === void 0 ? void 0 : _a.get(id);\n if (typeof expire === 'number' && now < expire) {\n this.log('GRAFT: ignoring backed off peer %s', id);\n // add behavioral penalty\n this.score.addPenalty(id, 1);\n // no PX\n doPX = false;\n // check the flood cutoff -- is the GRAFT coming too fast?\n const floodCutoff = expire + constants.GossipsubGraftFloodThreshold - constants.GossipsubPruneBackoff;\n if (now < floodCutoff) {\n // extra penalty\n this.score.addPenalty(id, 1);\n }\n // refresh the backoff\n this._addBackoff(id, topicID);\n prune.push(topicID);\n return;\n }\n // check the score\n if (score < 0) {\n // we don't GRAFT peers with negative score\n this.log('GRAFT: ignoring peer %s with negative score: score=%d, topic=%s', id, score, topicID);\n // we do send them PRUNE however, because it's a matter of protocol correctness\n prune.push(topicID);\n // but we won't PX to them\n doPX = false;\n // add/refresh backoff so that we don't reGRAFT too early even if the score decays\n this._addBackoff(id, topicID);\n return;\n }\n // check the number of mesh peers; if it is at (or over) Dhi, we only accept grafts\n // from peers with outbound connections; this is a defensive check to restrict potential\n // mesh takeover attacks combined with love bombing\n if (peersInMesh.size >= this._options.Dhi && !this.outbound.get(id)) {\n prune.push(topicID);\n this._addBackoff(id, topicID);\n return;\n }\n this.log('GRAFT: Add mesh link from %s in %s', id, topicID);\n this.score.graft(id, topicID);\n peersInMesh.add(id);\n });\n if (!prune.length) {\n return [];\n }\n return prune.map(topic => this._makePrune(id, topic, doPX));\n }\n /**\n * Handles Prune messages\n * @param {string} id peer id\n * @param {Array} prune\n * @returns {void}\n */\n _handlePrune(id, prune) {\n const score = this.score.score(id);\n prune.forEach(({ topicID, backoff, peers }) => {\n if (!topicID) {\n return;\n }\n const peersInMesh = this.mesh.get(topicID);\n if (!peersInMesh) {\n return;\n }\n this.log('PRUNE: Remove mesh link to %s in %s', id, topicID);\n this.score.prune(id, topicID);\n peersInMesh.delete(id);\n // is there a backoff specified by the peer? if so obey it\n if (typeof backoff === 'number' && backoff > 0) {\n this._doAddBackoff(id, topicID, backoff * 1000);\n }\n else {\n this._addBackoff(id, topicID);\n }\n // PX\n if (peers && peers.length) {\n // we ignore PX from peers with insufficient scores\n if (score < this._options.scoreThresholds.acceptPXThreshold) {\n this.log('PRUNE: ignoring PX from peer %s with insufficient score [score = %d, topic = %s]', id, score, topicID);\n return;\n }\n this._pxConnect(peers);\n }\n });\n }\n /**\n * Add standard backoff log for a peer in a topic\n * @param {string} id\n * @param {string} topic\n * @returns {void}\n */\n _addBackoff(id, topic) {\n this._doAddBackoff(id, topic, constants.GossipsubPruneBackoff);\n }\n /**\n * Add backoff expiry interval for a peer in a topic\n * @param {string} id\n * @param {string} topic\n * @param {number} interval backoff duration in milliseconds\n * @returns {void}\n */\n _doAddBackoff(id, topic, interval) {\n let backoff = this.backoff.get(topic);\n if (!backoff) {\n backoff = new Map();\n this.backoff.set(topic, backoff);\n }\n const expire = this._now() + interval;\n const existingExpire = backoff.get(id) || 0;\n if (existingExpire < expire) {\n backoff.set(id, expire);\n }\n }\n /**\n * Apply penalties from broken IHAVE/IWANT promises\n * @returns {void}\n */\n _applyIwantPenalties() {\n this.gossipTracer.getBrokenPromises().forEach((count, p) => {\n this.log('peer %s didn\\'t follow up in %d IWANT requests; adding penalty', p, count);\n this.score.addPenalty(p, count);\n });\n }\n /**\n * Clear expired backoff expiries\n * @returns {void}\n */\n _clearBackoff() {\n // we only clear once every GossipsubPruneBackoffTicks ticks to avoid iterating over the maps too much\n if (this.heartbeatTicks % constants.GossipsubPruneBackoffTicks !== 0) {\n return;\n }\n const now = this._now();\n this.backoff.forEach((backoff, topic) => {\n backoff.forEach((expire, id) => {\n if (expire < now) {\n backoff.delete(id);\n }\n });\n if (backoff.size === 0) {\n this.backoff.delete(topic);\n }\n });\n }\n /**\n * Maybe reconnect to direct peers\n * @returns {void}\n */\n _directConnect() {\n // we only do this every few ticks to allow pending connections to complete and account for\n // restarts/downtime\n if (this.heartbeatTicks % constants.GossipsubDirectConnectTicks !== 0) {\n return;\n }\n const toconnect = [];\n this.direct.forEach(id => {\n const peer = this.peers.get(id);\n if (!peer || !peer.isWritable) {\n toconnect.push(id);\n }\n });\n if (toconnect.length) {\n toconnect.forEach(id => {\n this._connect(id);\n });\n }\n }\n /**\n * Maybe attempt connection given signed peer records\n * @param {RPC.IPeerInfo[]} peers\n * @returns {Promise}\n */\n _pxConnect(peers) {\n return __awaiter(this, void 0, void 0, function* () {\n if (peers.length > constants.GossipsubPrunePeers) {\n utils_1.shuffle(peers);\n peers = peers.slice(0, constants.GossipsubPrunePeers);\n }\n const toconnect = [];\n yield Promise.all(peers.map((pi) => __awaiter(this, void 0, void 0, function* () {\n if (!pi.peerID) {\n return;\n }\n const p = PeerId.createFromBytes(pi.peerID);\n const id = p.toB58String();\n if (this.peers.has(id)) {\n return;\n }\n if (!pi.signedPeerRecord) {\n toconnect.push(id);\n return;\n }\n // The peer sent us a signed record\n // This is not a record from the peer who sent the record, but another peer who is connected with it\n // Ensure that it is valid\n try {\n const envelope = yield Envelope.openAndCertify(pi.signedPeerRecord, 'libp2p-peer-record');\n const eid = envelope.peerId.toB58String();\n if (id !== eid) {\n this.log('bogus peer record obtained through px: peer ID %s doesn\\'t match expected peer %s', eid, id);\n return;\n }\n if (!this._libp2p.peerStore.addressBook.consumePeerRecord(envelope)) {\n this.log('bogus peer record obtained through px: could not add peer record to address book');\n return;\n }\n toconnect.push(id);\n }\n catch (e) {\n this.log('bogus peer record obtained through px: invalid signature or not a peer record');\n }\n })));\n if (!toconnect.length) {\n return;\n }\n toconnect.forEach(id => this._connect(id));\n });\n }\n /**\n * Mounts the gossipsub protocol onto the libp2p node and sends our\n * our subscriptions to every peer connected\n * @override\n * @returns {void}\n */\n start() {\n super.start();\n this.heartbeat.start();\n this.score.start();\n // connect to direct peers\n this._directPeerInitial = setTimeout(() => {\n this.direct.forEach(id => {\n this._connect(id);\n });\n }, constants.GossipsubDirectConnectInitialDelay);\n }\n /**\n * Unmounts the gossipsub protocol and shuts down every connection\n * @override\n * @returns {void}\n */\n stop() {\n super.stop();\n this.heartbeat.stop();\n this.score.stop();\n this.mesh = new Map();\n this.fanout = new Map();\n this.lastpub = new Map();\n this.gossip = new Map();\n this.control = new Map();\n this.peerhave = new Map();\n this.iasked = new Map();\n this.backoff = new Map();\n this.outbound = new Map();\n this.gossipTracer.clear();\n clearTimeout(this._directPeerInitial);\n }\n /**\n * Connect to a peer using the gossipsub protocol\n * @param {string} id\n * @returns {void}\n */\n _connect(id) {\n this.log('Initiating connection with %s', id);\n this._libp2p.dialProtocol(PeerId.createFromB58String(id), this.multicodecs);\n }\n /**\n * Subscribes to a topic\n * @override\n * @param {string} topic\n * @returns {void}\n */\n subscribe(topic) {\n super.subscribe(topic);\n this.join(topic);\n }\n /**\n * Unsubscribe to a topic\n * @override\n * @param {string} topic\n * @returns {void}\n */\n unsubscribe(topic) {\n super.unsubscribe(topic);\n this.leave(topic);\n }\n /**\n * Join topic\n * @param {string} topic\n * @returns {void}\n */\n join(topic) {\n if (!this.started) {\n throw new Error('Gossipsub has not started');\n }\n this.log('JOIN %s', topic);\n const fanoutPeers = this.fanout.get(topic);\n if (fanoutPeers) {\n // these peers have a score above the publish threshold, which may be negative\n // so drop the ones with a negative score\n fanoutPeers.forEach(id => {\n if (this.score.score(id) < 0) {\n fanoutPeers.delete(id);\n }\n });\n if (fanoutPeers.size < this._options.D) {\n // we need more peers; eager, as this would get fixed in the next heartbeat\n get_gossip_peers_1.getGossipPeers(this, topic, this._options.D - fanoutPeers.size, (id) => {\n // filter our current peers, direct peers, and peers with negative scores\n return !fanoutPeers.has(id) && !this.direct.has(id) && this.score.score(id) >= 0;\n }).forEach(id => fanoutPeers.add(id));\n }\n this.mesh.set(topic, fanoutPeers);\n this.fanout.delete(topic);\n this.lastpub.delete(topic);\n }\n else {\n const peers = get_gossip_peers_1.getGossipPeers(this, topic, this._options.D, (id) => {\n // filter direct peers and peers with negative score\n return !this.direct.has(id) && this.score.score(id) >= 0;\n });\n this.mesh.set(topic, peers);\n }\n this.mesh.get(topic).forEach((id) => {\n this.log('JOIN: Add mesh link to %s in %s', id, topic);\n this._sendGraft(id, topic);\n });\n }\n /**\n * Leave topic\n * @param {string} topic\n * @returns {void}\n */\n leave(topic) {\n if (!this.started) {\n throw new Error('Gossipsub has not started');\n }\n this.log('LEAVE %s', topic);\n // Send PRUNE to mesh peers\n const meshPeers = this.mesh.get(topic);\n if (meshPeers) {\n meshPeers.forEach((id) => {\n this.log('LEAVE: Remove mesh link to %s in %s', id, topic);\n this._sendPrune(id, topic);\n });\n this.mesh.delete(topic);\n }\n }\n /**\n * Publish messages\n *\n * @override\n * @param {InMessage} msg\n * @returns {void}\n */\n _publish(msg) {\n return __awaiter(this, void 0, void 0, function* () {\n if (msg.receivedFrom !== this.peerId.toB58String()) {\n this.score.deliverMessage(msg);\n this.gossipTracer.deliverMessage(msg);\n }\n const msgID = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgID);\n // put in seen cache\n this.seenCache.put(msgIdStr);\n this.messageCache.put(msg);\n const tosend = new Set();\n msg.topicIDs.forEach((topic) => {\n const peersInTopic = this.topics.get(topic);\n if (!peersInTopic) {\n return;\n }\n if (this._options.floodPublish && msg.from === this.peerId.toB58String()) {\n // flood-publish behavior\n // send to direct peers and _all_ peers meeting the publishThreshold\n peersInTopic.forEach(id => {\n if (this.direct.has(id) || this.score.score(id) >= this._options.scoreThresholds.publishThreshold) {\n tosend.add(id);\n }\n });\n }\n else {\n // non-flood-publish behavior\n // send to direct peers, subscribed floodsub peers\n // and some mesh peers above publishThreshold\n // direct peers\n this.direct.forEach(id => {\n tosend.add(id);\n });\n // floodsub peers\n peersInTopic.forEach((id) => {\n const score = this.score.score(id);\n const peerStreams = this.peers.get(id);\n if (!peerStreams) {\n return;\n }\n if (peerStreams.protocol === constants.FloodsubID && score >= this._options.scoreThresholds.publishThreshold) {\n tosend.add(id);\n }\n });\n // Gossipsub peers handling\n let meshPeers = this.mesh.get(topic);\n if (!meshPeers || !meshPeers.size) {\n // We are not in the mesh for topic, use fanout peers\n meshPeers = this.fanout.get(topic);\n if (!meshPeers) {\n // If we are not in the fanout, then pick peers in topic above the publishThreshold\n const peers = get_gossip_peers_1.getGossipPeers(this, topic, this._options.D, id => {\n return this.score.score(id) >= this._options.scoreThresholds.publishThreshold;\n });\n if (peers.size > 0) {\n meshPeers = peers;\n this.fanout.set(topic, peers);\n }\n else {\n meshPeers = new Set();\n }\n }\n // Store the latest publishing time\n this.lastpub.set(topic, this._now());\n }\n meshPeers.forEach((peer) => {\n tosend.add(peer);\n });\n }\n });\n // Publish messages to peers\n const rpc = utils_1.createGossipRpc([\n pubsub_1.utils.normalizeOutRpcMessage(msg)\n ]);\n tosend.forEach((id) => {\n if (id === msg.from) {\n return;\n }\n this._sendRpc(id, rpc);\n });\n });\n }\n /**\n * Sends a GRAFT message to a peer\n * @param {string} id peer id\n * @param {string} topic\n * @returns {void}\n */\n _sendGraft(id, topic) {\n const graft = [{\n topicID: topic\n }];\n const out = utils_1.createGossipRpc([], { graft });\n this._sendRpc(id, out);\n }\n /**\n * Sends a PRUNE message to a peer\n * @param {string} id peer id\n * @param {string} topic\n * @returns {void}\n */\n _sendPrune(id, topic) {\n const prune = [\n this._makePrune(id, topic, this._options.doPX)\n ];\n const out = utils_1.createGossipRpc([], { prune });\n this._sendRpc(id, out);\n }\n /**\n * @override\n */\n _sendRpc(id, outRpc) {\n const peerStreams = this.peers.get(id);\n if (!peerStreams || !peerStreams.isWritable) {\n return;\n }\n // piggyback control message retries\n const ctrl = this.control.get(id);\n if (ctrl) {\n this._piggybackControl(id, outRpc, ctrl);\n this.control.delete(id);\n }\n // piggyback gossip\n const ihave = this.gossip.get(id);\n if (ihave) {\n this._piggybackGossip(id, outRpc, ihave);\n this.gossip.delete(id);\n }\n peerStreams.write(rpc_1.RPC.encode(outRpc).finish());\n }\n _piggybackControl(id, outRpc, ctrl) {\n const tograft = (ctrl.graft || [])\n .filter(({ topicID }) => (topicID && this.mesh.get(topicID) || new Set()).has(id));\n const toprune = (ctrl.prune || [])\n .filter(({ topicID }) => !(topicID && this.mesh.get(topicID) || new Set()).has(id));\n if (!tograft.length && !toprune.length) {\n return;\n }\n if (outRpc.control) {\n outRpc.control.graft = outRpc.control.graft && outRpc.control.graft.concat(tograft);\n outRpc.control.prune = outRpc.control.prune && outRpc.control.prune.concat(toprune);\n }\n else {\n outRpc.control = { ihave: [], iwant: [], graft: tograft, prune: toprune };\n }\n }\n _piggybackGossip(id, outRpc, ihave) {\n if (!outRpc.control) {\n outRpc.control = { ihave: [], iwant: [], graft: [], prune: [] };\n }\n outRpc.control.ihave = ihave;\n }\n /**\n * Send graft and prune messages\n * @param {Map>} tograft peer id => topic[]\n * @param {Map>} toprune peer id => topic[]\n */\n _sendGraftPrune(tograft, toprune, noPX) {\n const doPX = this._options.doPX;\n for (const [id, topics] of tograft) {\n const graft = topics.map((topicID) => ({ topicID }));\n let prune = [];\n // If a peer also has prunes, process them now\n const pruning = toprune.get(id);\n if (pruning) {\n prune = pruning.map((topicID) => this._makePrune(id, topicID, doPX && !noPX.get(id)));\n toprune.delete(id);\n }\n const outRpc = utils_1.createGossipRpc([], { graft, prune });\n this._sendRpc(id, outRpc);\n }\n for (const [id, topics] of toprune) {\n const prune = topics.map((topicID) => this._makePrune(id, topicID, doPX && !noPX.get(id)));\n const outRpc = utils_1.createGossipRpc([], { prune });\n this._sendRpc(id, outRpc);\n }\n }\n /**\n * Emits gossip to peers in a particular topic\n * @param {string} topic\n * @param {Set} exclude peers to exclude\n * @returns {void}\n */\n _emitGossip(topic, exclude) {\n const messageIDs = this.messageCache.getGossipIDs(topic);\n if (!messageIDs.length) {\n return;\n }\n // shuffle to emit in random order\n utils_1.shuffle(messageIDs);\n // if we are emitting more than GossipsubMaxIHaveLength ids, truncate the list\n if (messageIDs.length > constants.GossipsubMaxIHaveLength) {\n // we do the truncation (with shuffling) per peer below\n this.log('too many messages for gossip; will truncate IHAVE list (%d messages)', messageIDs.length);\n }\n // Send gossip to GossipFactor peers above threshold with a minimum of D_lazy\n // First we collect the peers above gossipThreshold that are not in the exclude set\n // and then randomly select from that set\n // We also exclude direct peers, as there is no reason to emit gossip to them\n const peersToGossip = [];\n const topicPeers = this.topics.get(topic);\n if (!topicPeers) {\n // no topic peers, no gossip\n return;\n }\n topicPeers.forEach(id => {\n const peerStreams = this.peers.get(id);\n if (!peerStreams) {\n return;\n }\n if (!exclude.has(id) &&\n !this.direct.has(id) &&\n utils_1.hasGossipProtocol(peerStreams.protocol) &&\n this.score.score(id) >= this._options.scoreThresholds.gossipThreshold) {\n peersToGossip.push(id);\n }\n });\n let target = this._options.Dlazy;\n const factor = constants.GossipsubGossipFactor * peersToGossip.length;\n if (factor > target) {\n target = factor;\n }\n if (target > peersToGossip.length) {\n target = peersToGossip.length;\n }\n else {\n utils_1.shuffle(peersToGossip);\n }\n // Emit the IHAVE gossip to the selected peers up to the target\n peersToGossip.slice(0, target).forEach(id => {\n let peerMessageIDs = messageIDs;\n if (messageIDs.length > constants.GossipsubMaxIHaveLength) {\n // shuffle and slice message IDs per peer so that we emit a different set for each peer\n // we have enough reduncancy in the system that this will significantly increase the message\n // coverage when we do truncate\n peerMessageIDs = utils_1.shuffle(peerMessageIDs.slice()).slice(0, constants.GossipsubMaxIHaveLength);\n }\n this._pushGossip(id, {\n topicID: topic,\n messageIDs: peerMessageIDs\n });\n });\n }\n /**\n * Flush gossip and control messages\n */\n _flush() {\n // send gossip first, which will also piggyback control\n for (const [peer, ihave] of this.gossip.entries()) {\n this.gossip.delete(peer);\n const out = utils_1.createGossipRpc([], { ihave });\n this._sendRpc(peer, out);\n }\n // send the remaining control messages\n for (const [peer, control] of this.control.entries()) {\n this.control.delete(peer);\n const out = utils_1.createGossipRpc([], { graft: control.graft, prune: control.prune });\n this._sendRpc(peer, out);\n }\n }\n /**\n * Adds new IHAVE messages to pending gossip\n * @param {PeerStreams} peerStreams\n * @param {Array} controlIHaveMsgs\n * @returns {void}\n */\n _pushGossip(id, controlIHaveMsgs) {\n this.log('Add gossip to %s', id);\n const gossip = this.gossip.get(id) || [];\n this.gossip.set(id, gossip.concat(controlIHaveMsgs));\n }\n /**\n * Returns the current time in milliseconds\n * @returns {number}\n */\n _now() {\n return Date.now();\n }\n /**\n * Make a PRUNE control message for a peer in a topic\n * @param {string} id\n * @param {string} topic\n * @param {boolean} doPX\n * @returns {RPC.IControlPrune}\n */\n _makePrune(id, topic, doPX) {\n if (this.peers.get(id).protocol === constants.GossipsubIDv10) {\n // Gossipsub v1.0 -- no backoff, the peer won't be able to parse it anyway\n return {\n topicID: topic,\n peers: []\n };\n }\n // backoff is measured in seconds\n // GossipsubPruneBackoff is measured in milliseconds\n const backoff = constants.GossipsubPruneBackoff / 1000;\n const px = [];\n if (doPX) {\n // select peers for Peer eXchange\n const peers = get_gossip_peers_1.getGossipPeers(this, topic, constants.GossipsubPrunePeers, (xid) => {\n return xid !== id && this.score.score(xid) >= 0;\n });\n peers.forEach(p => {\n // see if we have a signed record to send back; if we don't, just send\n // the peer ID and let the pruned peer find them in the DHT -- we can't trust\n // unsigned address records through PX anyways\n // Finding signed records in the DHT is not supported at the time of writing in js-libp2p\n const peerId = PeerId.createFromB58String(p);\n px.push({\n peerID: peerId.toBytes(),\n signedPeerRecord: this._libp2p.peerStore.addressBook.getRawEnvelope(peerId)\n });\n });\n }\n return {\n topicID: topic,\n peers: px,\n backoff: backoff\n };\n }\n}\nGossipsub.multicodec = constants.GossipsubIDv11;\nmodule.exports = Gossipsub;\n","'use strict'\n\nconst debug = require('debug')\nconst { EventEmitter } = require('events')\nconst errcode = require('err-code')\n\nconst { pipe } = require('it-pipe')\nconst { default: Queue } = require('p-queue')\n\nconst MulticodecTopology = require('../topology/multicodec-topology')\nconst { codes } = require('./errors')\n\nconst { RPC } = require('./message/rpc')\nconst PeerStreams = require('./peer-streams')\nconst { SignaturePolicy } = require('./signature-policy')\nconst utils = require('./utils')\n\nconst {\n signMessage,\n verifySignature\n} = require('./message/sign')\n\n/**\n * @typedef {any} Libp2p\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('bl')} BufferList\n * @typedef {import('../stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('../connection/connection')} Connection\n * @typedef {import('./signature-policy').SignaturePolicyType} SignaturePolicyType\n * @typedef {import('./message/rpc').IRPC} IRPC\n * @typedef {import('./message/rpc').RPC.SubOpts} RPCSubOpts\n * @typedef {import('./message/rpc').RPC.Message} RPCMessage\n */\n\n/**\n * @typedef {Object} InMessage\n * @property {string} [from]\n * @property {string} receivedFrom\n * @property {string[]} topicIDs\n * @property {Uint8Array} [seqno]\n * @property {Uint8Array} data\n * @property {Uint8Array} [signature]\n * @property {Uint8Array} [key]\n *\n * @typedef {Object} PubsubProperties\n * @property {string} debugName - log namespace\n * @property {Array|string} multicodecs - protocol identificers to connect\n * @property {Libp2p} libp2p\n *\n * @typedef {Object} PubsubOptions\n * @property {SignaturePolicyType} [globalSignaturePolicy = SignaturePolicy.StrictSign] - defines how signatures should be handled\n * @property {boolean} [canRelayMessage = false] - if can relay messages not subscribed\n * @property {boolean} [emitSelf = false] - if publish should emit to self, if subscribed\n * @property {number} [messageProcessingConcurrency = 10] - handle this many incoming pubsub messages concurrently\n */\n\n/**\n * PubsubBaseProtocol handles the peers and connections logic for pubsub routers\n * and specifies the API that pubsub routers should have.\n */\nclass PubsubBaseProtocol extends EventEmitter {\n /**\n * @param {PubsubProperties & PubsubOptions} props\n * @abstract\n */\n constructor ({\n debugName,\n multicodecs,\n libp2p,\n globalSignaturePolicy = SignaturePolicy.StrictSign,\n canRelayMessage = false,\n emitSelf = false,\n messageProcessingConcurrency = 10\n }) {\n if (typeof debugName !== 'string') {\n throw new Error('a debugname `string` is required')\n }\n\n if (!multicodecs) {\n throw new Error('multicodecs are required')\n }\n\n if (!libp2p) {\n throw new Error('libp2p is required')\n }\n\n super()\n\n this.log = Object.assign(debug(debugName), {\n err: debug(`${debugName}:error`)\n })\n\n /**\n * @type {Array}\n */\n this.multicodecs = utils.ensureArray(multicodecs)\n this._libp2p = libp2p\n this.registrar = libp2p.registrar\n /**\n * @type {PeerId}\n */\n this.peerId = libp2p.peerId\n\n this.started = false\n\n /**\n * Map of topics to which peers are subscribed to\n *\n * @type {Map>}\n */\n this.topics = new Map()\n\n /**\n * List of our subscriptions\n *\n * @type {Set}\n */\n this.subscriptions = new Set()\n\n /**\n * Map of peer streams\n *\n * @type {Map}\n */\n this.peers = new Map()\n\n // validate signature policy\n if (!SignaturePolicy[globalSignaturePolicy]) {\n throw errcode(new Error('Invalid global signature policy'), codes.ERR_INVALID_SIGNATURE_POLICY)\n }\n\n /**\n * The signature policy to follow by default\n *\n * @type {string}\n */\n this.globalSignaturePolicy = globalSignaturePolicy\n\n /**\n * If router can relay received messages, even if not subscribed\n *\n * @type {boolean}\n */\n this.canRelayMessage = canRelayMessage\n\n /**\n * if publish should emit to self, if subscribed\n *\n * @type {boolean}\n */\n this.emitSelf = emitSelf\n\n /**\n * Topic validator function\n *\n * @typedef {function(string, InMessage): Promise} validator\n */\n /**\n * Topic validator map\n *\n * Keyed by topic\n * Topic validators are functions with the following input:\n *\n * @type {Map}\n */\n this.topicValidators = new Map()\n\n /**\n * @type {Queue}\n */\n this.queue = new Queue({ concurrency: messageProcessingConcurrency })\n\n this._registrarId = undefined\n this._onIncomingStream = this._onIncomingStream.bind(this)\n this._onPeerConnected = this._onPeerConnected.bind(this)\n this._onPeerDisconnected = this._onPeerDisconnected.bind(this)\n }\n\n // LIFECYCLE METHODS\n\n /**\n * Register the pubsub protocol onto the libp2p node.\n *\n * @returns {void}\n */\n start () {\n if (this.started) {\n return\n }\n this.log('starting')\n\n // Incoming streams\n // Called after a peer dials us\n this.registrar.handle(this.multicodecs, this._onIncomingStream)\n\n // register protocol with topology\n // Topology callbacks called on connection manager changes\n const topology = new MulticodecTopology({\n multicodecs: this.multicodecs,\n handlers: {\n onConnect: this._onPeerConnected,\n onDisconnect: this._onPeerDisconnected\n }\n })\n this._registrarId = this.registrar.register(topology)\n\n this.log('started')\n this.started = true\n }\n\n /**\n * Unregister the pubsub protocol and the streams with other peers will be closed.\n *\n * @returns {void}\n */\n stop () {\n if (!this.started) {\n return\n }\n\n // unregister protocol and handlers\n this.registrar.unregister(this._registrarId)\n\n this.log('stopping')\n this.peers.forEach((peerStreams) => peerStreams.close())\n\n this.peers = new Map()\n this.subscriptions = new Set()\n this.started = false\n this.log('stopped')\n }\n\n /**\n * On an inbound stream opened.\n *\n * @protected\n * @param {Object} props\n * @param {string} props.protocol\n * @param {MuxedStream} props.stream\n * @param {Connection} props.connection - connection\n */\n _onIncomingStream ({ protocol, stream, connection }) {\n const peerId = connection.remotePeer\n const idB58Str = peerId.toB58String()\n const peer = this._addPeer(peerId, protocol)\n const inboundStream = peer.attachInboundStream(stream)\n\n this._processMessages(idB58Str, inboundStream, peer)\n }\n\n /**\n * Registrar notifies an established connection with pubsub protocol.\n *\n * @protected\n * @param {PeerId} peerId - remote peer-id\n * @param {Connection} conn - connection to the peer\n */\n async _onPeerConnected (peerId, conn) {\n const idB58Str = peerId.toB58String()\n this.log('connected', idB58Str)\n\n try {\n const { stream, protocol } = await conn.newStream(this.multicodecs)\n const peer = this._addPeer(peerId, protocol)\n await peer.attachOutboundStream(stream)\n } catch (err) {\n this.log.err(err)\n }\n\n // Immediately send my own subscriptions to the newly established conn\n this._sendSubscriptions(idB58Str, Array.from(this.subscriptions), true)\n }\n\n /**\n * Registrar notifies a closing connection with pubsub protocol.\n *\n * @protected\n * @param {PeerId} peerId - peerId\n * @param {Error} [err] - error for connection end\n */\n _onPeerDisconnected (peerId, err) {\n const idB58Str = peerId.toB58String()\n\n this.log('connection ended', idB58Str, err ? err.message : '')\n this._removePeer(peerId)\n }\n\n /**\n * Notifies the router that a peer has been connected\n *\n * @protected\n * @param {PeerId} peerId\n * @param {string} protocol\n * @returns {PeerStreams}\n */\n _addPeer (peerId, protocol) {\n const id = peerId.toB58String()\n const existing = this.peers.get(id)\n\n // If peer streams already exists, do nothing\n if (existing) {\n return existing\n }\n\n // else create a new peer streams\n this.log('new peer', id)\n\n const peerStreams = new PeerStreams({\n id: peerId,\n protocol\n })\n\n this.peers.set(id, peerStreams)\n peerStreams.once('close', () => this._removePeer(peerId))\n\n return peerStreams\n }\n\n /**\n * Notifies the router that a peer has been disconnected.\n *\n * @protected\n * @param {PeerId} peerId\n * @returns {PeerStreams | undefined}\n */\n _removePeer (peerId) {\n if (!peerId) return\n const id = peerId.toB58String()\n const peerStreams = this.peers.get(id)\n if (!peerStreams) return\n\n // close peer streams\n peerStreams.removeAllListeners()\n peerStreams.close()\n\n // delete peer streams\n this.log('delete peer', id)\n this.peers.delete(id)\n\n // remove peer from topics map\n for (const peers of this.topics.values()) {\n peers.delete(id)\n }\n\n return peerStreams\n }\n\n // MESSAGE METHODS\n\n /**\n * Responsible for processing each RPC message received by other peers.\n *\n * @param {string} idB58Str - peer id string in base58\n * @param {AsyncIterable} stream - inbound stream\n * @param {PeerStreams} peerStreams - PubSub peer\n * @returns {Promise}\n */\n async _processMessages (idB58Str, stream, peerStreams) {\n try {\n await pipe(\n stream,\n async (source) => {\n for await (const data of source) {\n const rpcBytes = data instanceof Uint8Array ? data : data.slice()\n const rpcMsg = this._decodeRpc(rpcBytes)\n\n // Since _processRpc may be overridden entirely in unsafe ways,\n // the simplest/safest option here is to wrap in a function and capture all errors\n // to prevent a top-level unhandled exception\n // This processing of rpc messages should happen without awaiting full validation/execution of prior messages\n ;(async () => {\n try {\n await this._processRpc(idB58Str, peerStreams, rpcMsg)\n } catch (err) {\n this.log.err(err)\n }\n })()\n }\n }\n )\n } catch (err) {\n this._onPeerDisconnected(peerStreams.id, err)\n }\n }\n\n /**\n * Handles an rpc request from a peer\n *\n * @param {string} idB58Str\n * @param {PeerStreams} peerStreams\n * @param {RPC} rpc\n * @returns {Promise}\n */\n async _processRpc (idB58Str, peerStreams, rpc) {\n this.log('rpc from', idB58Str)\n const subs = rpc.subscriptions\n const msgs = rpc.msgs\n\n if (subs.length) {\n // update peer subscriptions\n subs.forEach((subOpt) => {\n this._processRpcSubOpt(idB58Str, subOpt)\n })\n this.emit('pubsub:subscription-change', peerStreams.id, subs)\n }\n\n if (!this._acceptFrom(idB58Str)) {\n this.log('received message from unacceptable peer %s', idB58Str)\n return false\n }\n\n if (msgs.length) {\n this.queue.addAll(msgs.map(message => async () => {\n if (!(this.canRelayMessage || (message.topicIDs && message.topicIDs.some((topic) => this.subscriptions.has(topic))))) {\n this.log('received message we didn\\'t subscribe to. Dropping.')\n return\n }\n\n try {\n const msg = utils.normalizeInRpcMessage(message, idB58Str)\n\n await this._processRpcMessage(msg)\n } catch (err) {\n this.log.err(err)\n }\n }))\n }\n return true\n }\n\n /**\n * Handles a subscription change from a peer\n *\n * @param {string} id\n * @param {RPC.ISubOpts} subOpt\n */\n _processRpcSubOpt (id, subOpt) {\n const t = subOpt.topicID\n\n if (!t) {\n return\n }\n\n let topicSet = this.topics.get(t)\n if (!topicSet) {\n topicSet = new Set()\n this.topics.set(t, topicSet)\n }\n\n if (subOpt.subscribe) {\n // subscribe peer to new topic\n topicSet.add(id)\n } else {\n // unsubscribe from existing topic\n topicSet.delete(id)\n }\n }\n\n /**\n * Handles an message from a peer\n *\n * @param {InMessage} msg\n * @returns {Promise}\n */\n async _processRpcMessage (msg) {\n if (this.peerId.toB58String() === msg.from && !this.emitSelf) {\n return\n }\n\n // Ensure the message is valid before processing it\n try {\n await this.validate(msg)\n } catch (err) {\n this.log('Message is invalid, dropping it. %O', err)\n return\n }\n\n // Emit to self\n this._emitMessage(msg)\n\n return this._publish(utils.normalizeOutRpcMessage(msg))\n }\n\n /**\n * Emit a message from a peer\n *\n * @param {InMessage} message\n */\n _emitMessage (message) {\n message.topicIDs.forEach((topic) => {\n if (this.subscriptions.has(topic)) {\n this.emit(topic, message)\n }\n })\n }\n\n /**\n * The default msgID implementation\n * Child class can override this.\n *\n * @param {InMessage} msg - the message object\n * @returns {Promise | Uint8Array} message id as bytes\n */\n getMsgId (msg) {\n const signaturePolicy = this.globalSignaturePolicy\n switch (signaturePolicy) {\n case SignaturePolicy.StrictSign:\n // @ts-ignore seqno is optional in protobuf definition but it will exist\n return utils.msgId(msg.from, msg.seqno)\n case SignaturePolicy.StrictNoSign:\n return utils.noSignMsgId(msg.data)\n default:\n throw errcode(new Error('Cannot get message id: unhandled signature policy: ' + signaturePolicy), codes.ERR_UNHANDLED_SIGNATURE_POLICY)\n }\n }\n\n /**\n * Whether to accept a message from a peer\n * Override to create a graylist\n *\n * @param {string} id\n * @returns {boolean}\n */\n _acceptFrom (id) {\n return true\n }\n\n /**\n * Decode Uint8Array into an RPC object.\n * This can be override to use a custom router protobuf.\n *\n * @param {Uint8Array} bytes\n * @returns {RPC}\n */\n _decodeRpc (bytes) {\n return RPC.decode(bytes)\n }\n\n /**\n * Encode RPC object into a Uint8Array.\n * This can be override to use a custom router protobuf.\n *\n * @param {IRPC} rpc\n * @returns {Uint8Array}\n */\n _encodeRpc (rpc) {\n return RPC.encode(rpc).finish()\n }\n\n /**\n * Send an rpc object to a peer\n *\n * @param {string} id - peer id\n * @param {IRPC} rpc\n * @returns {void}\n */\n _sendRpc (id, rpc) {\n const peerStreams = this.peers.get(id)\n if (!peerStreams || !peerStreams.isWritable) {\n const msg = `Cannot send RPC to ${id} as there is no open stream to it available`\n\n this.log.err(msg)\n return\n }\n peerStreams.write(this._encodeRpc(rpc))\n }\n\n /**\n * Send subscroptions to a peer\n *\n * @param {string} id - peer id\n * @param {string[]} topics\n * @param {boolean} subscribe - set to false for unsubscriptions\n * @returns {void}\n */\n _sendSubscriptions (id, topics, subscribe) {\n return this._sendRpc(id, {\n subscriptions: topics.map(t => ({ topicID: t, subscribe: subscribe }))\n })\n }\n\n /**\n * Validates the given message. The signature will be checked for authenticity.\n * Throws an error on invalid messages\n *\n * @param {InMessage} message\n * @returns {Promise}\n */\n async validate (message) { // eslint-disable-line require-await\n const signaturePolicy = this.globalSignaturePolicy\n switch (signaturePolicy) {\n case SignaturePolicy.StrictNoSign:\n if (message.from) {\n throw errcode(new Error('StrictNoSigning: from should not be present'), codes.ERR_UNEXPECTED_FROM)\n }\n if (message.signature) {\n throw errcode(new Error('StrictNoSigning: signature should not be present'), codes.ERR_UNEXPECTED_SIGNATURE)\n }\n if (message.key) {\n throw errcode(new Error('StrictNoSigning: key should not be present'), codes.ERR_UNEXPECTED_KEY)\n }\n if (message.seqno) {\n throw errcode(new Error('StrictNoSigning: seqno should not be present'), codes.ERR_UNEXPECTED_SEQNO)\n }\n break\n case SignaturePolicy.StrictSign:\n if (!message.signature) {\n throw errcode(new Error('StrictSigning: Signing required and no signature was present'), codes.ERR_MISSING_SIGNATURE)\n }\n if (!message.seqno) {\n throw errcode(new Error('StrictSigning: Signing required and no seqno was present'), codes.ERR_MISSING_SEQNO)\n }\n if (!(await verifySignature(message))) {\n throw errcode(new Error('StrictSigning: Invalid message signature'), codes.ERR_INVALID_SIGNATURE)\n }\n break\n default:\n throw errcode(new Error('Cannot validate message: unhandled signature policy: ' + signaturePolicy), codes.ERR_UNHANDLED_SIGNATURE_POLICY)\n }\n\n for (const topic of message.topicIDs) {\n const validatorFn = this.topicValidators.get(topic)\n if (validatorFn) {\n await validatorFn(topic, message)\n }\n }\n }\n\n /**\n * Normalizes the message and signs it, if signing is enabled.\n * Should be used by the routers to create the message to send.\n *\n * @protected\n * @param {InMessage} message\n * @returns {Promise}\n */\n _buildMessage (message) {\n const signaturePolicy = this.globalSignaturePolicy\n switch (signaturePolicy) {\n case SignaturePolicy.StrictSign:\n message.from = this.peerId.toB58String()\n message.seqno = utils.randomSeqno()\n return signMessage(this.peerId, message)\n case SignaturePolicy.StrictNoSign:\n return Promise.resolve(message)\n default:\n throw errcode(new Error('Cannot build message: unhandled signature policy: ' + signaturePolicy), codes.ERR_UNHANDLED_SIGNATURE_POLICY)\n }\n }\n\n // API METHODS\n\n /**\n * Get a list of the peer-ids that are subscribed to one topic.\n *\n * @param {string} topic\n * @returns {Array}\n */\n getSubscribers (topic) {\n if (!this.started) {\n throw errcode(new Error('not started yet'), 'ERR_NOT_STARTED_YET')\n }\n\n if (!topic || typeof topic !== 'string') {\n throw errcode(new Error('a string topic must be provided'), 'ERR_NOT_VALID_TOPIC')\n }\n\n const peersInTopic = this.topics.get(topic)\n if (!peersInTopic) {\n return []\n }\n return Array.from(peersInTopic)\n }\n\n /**\n * Publishes messages to all subscribed peers\n *\n * @param {string} topic\n * @param {Uint8Array} message\n * @returns {Promise}\n */\n async publish (topic, message) {\n if (!this.started) {\n throw new Error('Pubsub has not started')\n }\n\n this.log('publish', topic, message)\n\n const from = this.peerId.toB58String()\n const msgObject = {\n receivedFrom: from,\n data: message,\n topicIDs: [topic]\n }\n\n // ensure that the message follows the signature policy\n const outMsg = await this._buildMessage(msgObject)\n // @ts-ignore different type as from is converted\n const msg = utils.normalizeInRpcMessage(outMsg)\n\n // Emit to self if I'm interested and emitSelf enabled\n this.emitSelf && this._emitMessage(msg)\n\n // send to all the other peers\n await this._publish(msg)\n }\n\n /**\n * Overriding the implementation of publish should handle the appropriate algorithms for the publish/subscriber implementation.\n * For example, a Floodsub implementation might simply publish each message to each topic for every peer\n *\n * @abstract\n * @param {InMessage|RPCMessage} message\n * @returns {Promise}\n *\n */\n _publish (message) {\n throw errcode(new Error('publish must be implemented by the subclass'), 'ERR_NOT_IMPLEMENTED')\n }\n\n /**\n * Subscribes to a given topic.\n *\n * @abstract\n * @param {string} topic\n * @returns {void}\n */\n subscribe (topic) {\n if (!this.started) {\n throw new Error('Pubsub has not started')\n }\n\n if (!this.subscriptions.has(topic)) {\n this.subscriptions.add(topic)\n this.peers.forEach((_, id) => this._sendSubscriptions(id, [topic], true))\n }\n }\n\n /**\n * Unsubscribe from the given topic.\n *\n * @param {string} topic\n * @returns {void}\n */\n unsubscribe (topic) {\n if (!this.started) {\n throw new Error('Pubsub is not started')\n }\n\n if (this.subscriptions.has(topic) && this.listenerCount(topic) === 0) {\n this.subscriptions.delete(topic)\n this.peers.forEach((_, id) => this._sendSubscriptions(id, [topic], false))\n }\n }\n\n /**\n * Get the list of topics which the peer is subscribed to.\n *\n * @returns {Array}\n */\n getTopics () {\n if (!this.started) {\n throw new Error('Pubsub is not started')\n }\n\n return Array.from(this.subscriptions)\n }\n}\n\nPubsubBaseProtocol.utils = utils\nPubsubBaseProtocol.SignaturePolicy = SignaturePolicy\n\nmodule.exports = PubsubBaseProtocol\n","'use strict'\n\nconst Topology = require('./index')\nconst multicodecTopologySymbol = Symbol.for('@libp2p/js-interfaces/topology/multicodec-topology')\n\nclass MulticodecTopology extends Topology {\n /**\n * @param {TopologyOptions & MulticodecOptions} props\n */\n constructor ({\n min,\n max,\n multicodecs,\n handlers\n }) {\n super({ min, max, handlers })\n\n if (!multicodecs) {\n throw new Error('one or more multicodec should be provided')\n }\n\n if (!handlers) {\n throw new Error('the handlers should be provided')\n }\n\n if (typeof handlers.onConnect !== 'function') {\n throw new Error('the \\'onConnect\\' handler must be provided')\n }\n\n if (typeof handlers.onDisconnect !== 'function') {\n throw new Error('the \\'onDisconnect\\' handler must be provided')\n }\n\n this.multicodecs = Array.isArray(multicodecs) ? multicodecs : [multicodecs]\n this._registrar = undefined\n\n this._onProtocolChange = this._onProtocolChange.bind(this)\n this._onPeerConnect = this._onPeerConnect.bind(this)\n }\n\n get [Symbol.toStringTag] () {\n return 'Topology'\n }\n\n get [multicodecTopologySymbol] () {\n return true\n }\n\n /**\n * Checks if the given value is a `MulticodecTopology` instance.\n *\n * @param {any} other\n * @returns {other is MulticodecTopology}\n */\n static isMulticodecTopology (other) {\n return Boolean(other && other[multicodecTopologySymbol])\n }\n\n /**\n * @param {any} registrar\n */\n set registrar (registrar) { // eslint-disable-line\n this._registrar = registrar\n this._registrar.peerStore.on('change:protocols', this._onProtocolChange)\n this._registrar.connectionManager.on('peer:connect', this._onPeerConnect)\n\n // Update topology peers\n this._updatePeers(this._registrar.peerStore.peers.values())\n }\n\n /**\n * Update topology.\n *\n * @param {Array<{id: PeerId, multiaddrs: Array, protocols: Array}>} peerDataIterable\n * @returns {void}\n */\n _updatePeers (peerDataIterable) {\n for (const { id, protocols } of peerDataIterable) {\n if (this.multicodecs.filter(multicodec => protocols.includes(multicodec)).length) {\n // Add the peer regardless of whether or not there is currently a connection\n this.peers.add(id.toB58String())\n // If there is a connection, call _onConnect\n const connection = this._registrar.getConnection(id)\n connection && this._onConnect(id, connection)\n } else {\n // Remove any peers we might be tracking that are no longer of value to us\n this.peers.delete(id.toB58String())\n }\n }\n }\n\n /**\n * Check if a new peer support the multicodecs for this topology.\n *\n * @param {Object} props\n * @param {PeerId} props.peerId\n * @param {Array} props.protocols\n */\n _onProtocolChange ({ peerId, protocols }) {\n const hadPeer = this.peers.has(peerId.toB58String())\n const hasProtocol = protocols.filter(protocol => this.multicodecs.includes(protocol))\n\n // Not supporting the protocol anymore?\n if (hadPeer && hasProtocol.length === 0) {\n this._onDisconnect(peerId)\n }\n\n // New to protocol support\n for (const protocol of protocols) {\n if (this.multicodecs.includes(protocol)) {\n const peerData = this._registrar.peerStore.get(peerId)\n this._updatePeers([peerData])\n return\n }\n }\n }\n\n /**\n * Verify if a new connected peer has a topology multicodec and call _onConnect.\n *\n * @param {Connection} connection\n * @returns {void}\n */\n _onPeerConnect (connection) {\n // @ts-ignore - remotePeer does not existist on Connection\n const peerId = connection.remotePeer\n const protocols = this._registrar.peerStore.protoBook.get(peerId)\n\n if (!protocols) {\n return\n }\n\n if (this.multicodecs.find(multicodec => protocols.includes(multicodec))) {\n this.peers.add(peerId.toB58String())\n this._onConnect(peerId, connection)\n }\n }\n}\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr')} Multiaddr\n * @typedef {import('../connection/connection')} Connection\n * @typedef {import('.').Options} TopologyOptions\n * @typedef {Object} MulticodecOptions\n * @property {string[]} multicodecs - protocol multicodecs\n * @property {Required} handlers\n * @typedef {import('.').Handlers} Handlers\n */\nmodule.exports = MulticodecTopology\n","'use strict'\n\nconst noop = () => {}\nconst topologySymbol = Symbol.for('@libp2p/js-interfaces/topology')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * @typedef {Object} Options\n * @property {number} [min=0] - minimum needed connections.\n * @property {number} [max=Infinity] - maximum needed connections.\n * @property {Handlers} [handlers]\n *\n * @typedef {Object} Handlers\n * @property {(peerId: PeerId, conn: Connection) => void} [onConnect] - protocol \"onConnect\" handler\n * @property {(peerId: PeerId, error?:Error) => void} [onDisconnect] - protocol \"onDisconnect\" handler\n *\n * @typedef {import('../connection/connection')} Connection\n */\n\nclass Topology {\n /**\n * @param {Options} options\n */\n constructor ({\n min = 0,\n max = Infinity,\n handlers = {}\n }) {\n this.min = min\n this.max = max\n\n // Handlers\n this._onConnect = handlers.onConnect || noop\n this._onDisconnect = handlers.onDisconnect || noop\n\n /**\n * Set of peers that support the protocol.\n *\n * @type {Set}\n */\n this.peers = new Set()\n }\n\n get [Symbol.toStringTag] () {\n return 'Topology'\n }\n\n get [topologySymbol] () {\n return true\n }\n\n /**\n * Checks if the given value is a Topology instance.\n *\n * @param {any} other\n * @returns {other is Topology}\n */\n static isTopology (other) {\n return Boolean(other && other[topologySymbol])\n }\n\n /**\n * @param {any} registrar\n */\n set registrar (registrar) { // eslint-disable-line\n this._registrar = registrar\n }\n\n /**\n * Notify about peer disconnected event.\n *\n * @param {PeerId} peerId\n * @returns {void}\n */\n disconnect (peerId) {\n this._onDisconnect(peerId)\n }\n}\n\nmodule.exports = Topology\n","'use strict'\n\nexports.codes = {\n /**\n * Signature policy is invalid\n */\n ERR_INVALID_SIGNATURE_POLICY: 'ERR_INVALID_SIGNATURE_POLICY',\n /**\n * Signature policy is unhandled\n */\n ERR_UNHANDLED_SIGNATURE_POLICY: 'ERR_UNHANDLED_SIGNATURE_POLICY',\n\n // Strict signing codes\n\n /**\n * Message expected to have a `signature`, but doesn't\n */\n ERR_MISSING_SIGNATURE: 'ERR_MISSING_SIGNATURE',\n /**\n * Message expected to have a `seqno`, but doesn't\n */\n ERR_MISSING_SEQNO: 'ERR_MISSING_SEQNO',\n /**\n * Message `signature` is invalid\n */\n ERR_INVALID_SIGNATURE: 'ERR_INVALID_SIGNATURE',\n\n // Strict no-signing codes\n\n /**\n * Message expected to not have a `from`, but does\n */\n ERR_UNEXPECTED_FROM: 'ERR_UNEXPECTED_FROM',\n /**\n * Message expected to not have a `signature`, but does\n */\n ERR_UNEXPECTED_SIGNATURE: 'ERR_UNEXPECTED_SIGNATURE',\n /**\n * Message expected to not have a `key`, but does\n */\n ERR_UNEXPECTED_KEY: 'ERR_UNEXPECTED_KEY',\n /**\n * Message expected to not have a `seqno`, but does\n */\n ERR_UNEXPECTED_SEQNO: 'ERR_UNEXPECTED_SEQNO'\n}\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-pubsub-rpc\"] || ($protobuf.roots[\"libp2p-pubsub-rpc\"] = {});\n\n$root.RPC = (function() {\n\n /**\n * Properties of a RPC.\n * @exports IRPC\n * @interface IRPC\n * @property {Array.|null} [subscriptions] RPC subscriptions\n * @property {Array.|null} [msgs] RPC msgs\n */\n\n /**\n * Constructs a new RPC.\n * @exports RPC\n * @classdesc Represents a RPC.\n * @implements IRPC\n * @constructor\n * @param {IRPC=} [p] Properties to set\n */\n function RPC(p) {\n this.subscriptions = [];\n this.msgs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * RPC subscriptions.\n * @member {Array.} subscriptions\n * @memberof RPC\n * @instance\n */\n RPC.prototype.subscriptions = $util.emptyArray;\n\n /**\n * RPC msgs.\n * @member {Array.} msgs\n * @memberof RPC\n * @instance\n */\n RPC.prototype.msgs = $util.emptyArray;\n\n /**\n * Encodes the specified RPC message. Does not implicitly {@link RPC.verify|verify} messages.\n * @function encode\n * @memberof RPC\n * @static\n * @param {IRPC} m RPC message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n RPC.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.subscriptions != null && m.subscriptions.length) {\n for (var i = 0; i < m.subscriptions.length; ++i)\n $root.RPC.SubOpts.encode(m.subscriptions[i], w.uint32(10).fork()).ldelim();\n }\n if (m.msgs != null && m.msgs.length) {\n for (var i = 0; i < m.msgs.length; ++i)\n $root.RPC.Message.encode(m.msgs[i], w.uint32(18).fork()).ldelim();\n }\n return w;\n };\n\n /**\n * Decodes a RPC message from the specified reader or buffer.\n * @function decode\n * @memberof RPC\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC} RPC\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n RPC.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.subscriptions && m.subscriptions.length))\n m.subscriptions = [];\n m.subscriptions.push($root.RPC.SubOpts.decode(r, r.uint32()));\n break;\n case 2:\n if (!(m.msgs && m.msgs.length))\n m.msgs = [];\n m.msgs.push($root.RPC.Message.decode(r, r.uint32()));\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a RPC message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC} RPC\n */\n RPC.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC)\n return d;\n var m = new $root.RPC();\n if (d.subscriptions) {\n if (!Array.isArray(d.subscriptions))\n throw TypeError(\".RPC.subscriptions: array expected\");\n m.subscriptions = [];\n for (var i = 0; i < d.subscriptions.length; ++i) {\n if (typeof d.subscriptions[i] !== \"object\")\n throw TypeError(\".RPC.subscriptions: object expected\");\n m.subscriptions[i] = $root.RPC.SubOpts.fromObject(d.subscriptions[i]);\n }\n }\n if (d.msgs) {\n if (!Array.isArray(d.msgs))\n throw TypeError(\".RPC.msgs: array expected\");\n m.msgs = [];\n for (var i = 0; i < d.msgs.length; ++i) {\n if (typeof d.msgs[i] !== \"object\")\n throw TypeError(\".RPC.msgs: object expected\");\n m.msgs[i] = $root.RPC.Message.fromObject(d.msgs[i]);\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a RPC message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC\n * @static\n * @param {RPC} m RPC\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n RPC.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.subscriptions = [];\n d.msgs = [];\n }\n if (m.subscriptions && m.subscriptions.length) {\n d.subscriptions = [];\n for (var j = 0; j < m.subscriptions.length; ++j) {\n d.subscriptions[j] = $root.RPC.SubOpts.toObject(m.subscriptions[j], o);\n }\n }\n if (m.msgs && m.msgs.length) {\n d.msgs = [];\n for (var j = 0; j < m.msgs.length; ++j) {\n d.msgs[j] = $root.RPC.Message.toObject(m.msgs[j], o);\n }\n }\n return d;\n };\n\n /**\n * Converts this RPC to JSON.\n * @function toJSON\n * @memberof RPC\n * @instance\n * @returns {Object.} JSON object\n */\n RPC.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n RPC.SubOpts = (function() {\n\n /**\n * Properties of a SubOpts.\n * @memberof RPC\n * @interface ISubOpts\n * @property {boolean|null} [subscribe] SubOpts subscribe\n * @property {string|null} [topicID] SubOpts topicID\n */\n\n /**\n * Constructs a new SubOpts.\n * @memberof RPC\n * @classdesc Represents a SubOpts.\n * @implements ISubOpts\n * @constructor\n * @param {RPC.ISubOpts=} [p] Properties to set\n */\n function SubOpts(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * SubOpts subscribe.\n * @member {boolean|null|undefined} subscribe\n * @memberof RPC.SubOpts\n * @instance\n */\n SubOpts.prototype.subscribe = null;\n\n /**\n * SubOpts topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.SubOpts\n * @instance\n */\n SubOpts.prototype.topicID = null;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * SubOpts _subscribe.\n * @member {\"subscribe\"|undefined} _subscribe\n * @memberof RPC.SubOpts\n * @instance\n */\n Object.defineProperty(SubOpts.prototype, \"_subscribe\", {\n get: $util.oneOfGetter($oneOfFields = [\"subscribe\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * SubOpts _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.SubOpts\n * @instance\n */\n Object.defineProperty(SubOpts.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified SubOpts message. Does not implicitly {@link RPC.SubOpts.verify|verify} messages.\n * @function encode\n * @memberof RPC.SubOpts\n * @static\n * @param {RPC.ISubOpts} m SubOpts message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n SubOpts.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.subscribe != null && Object.hasOwnProperty.call(m, \"subscribe\"))\n w.uint32(8).bool(m.subscribe);\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(18).string(m.topicID);\n return w;\n };\n\n /**\n * Decodes a SubOpts message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.SubOpts\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.SubOpts} SubOpts\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n SubOpts.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.SubOpts();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.subscribe = r.bool();\n break;\n case 2:\n m.topicID = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a SubOpts message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.SubOpts\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.SubOpts} SubOpts\n */\n SubOpts.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.SubOpts)\n return d;\n var m = new $root.RPC.SubOpts();\n if (d.subscribe != null) {\n m.subscribe = Boolean(d.subscribe);\n }\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n return m;\n };\n\n /**\n * Creates a plain object from a SubOpts message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.SubOpts\n * @static\n * @param {RPC.SubOpts} m SubOpts\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n SubOpts.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.subscribe != null && m.hasOwnProperty(\"subscribe\")) {\n d.subscribe = m.subscribe;\n if (o.oneofs)\n d._subscribe = \"subscribe\";\n }\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n return d;\n };\n\n /**\n * Converts this SubOpts to JSON.\n * @function toJSON\n * @memberof RPC.SubOpts\n * @instance\n * @returns {Object.} JSON object\n */\n SubOpts.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return SubOpts;\n })();\n\n RPC.Message = (function() {\n\n /**\n * Properties of a Message.\n * @memberof RPC\n * @interface IMessage\n * @property {Uint8Array|null} [from] Message from\n * @property {Uint8Array|null} [data] Message data\n * @property {Uint8Array|null} [seqno] Message seqno\n * @property {Array.|null} [topicIDs] Message topicIDs\n * @property {Uint8Array|null} [signature] Message signature\n * @property {Uint8Array|null} [key] Message key\n */\n\n /**\n * Constructs a new Message.\n * @memberof RPC\n * @classdesc Represents a Message.\n * @implements IMessage\n * @constructor\n * @param {RPC.IMessage=} [p] Properties to set\n */\n function Message(p) {\n this.topicIDs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Message from.\n * @member {Uint8Array|null|undefined} from\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.from = null;\n\n /**\n * Message data.\n * @member {Uint8Array|null|undefined} data\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.data = null;\n\n /**\n * Message seqno.\n * @member {Uint8Array|null|undefined} seqno\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.seqno = null;\n\n /**\n * Message topicIDs.\n * @member {Array.} topicIDs\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.topicIDs = $util.emptyArray;\n\n /**\n * Message signature.\n * @member {Uint8Array|null|undefined} signature\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.signature = null;\n\n /**\n * Message key.\n * @member {Uint8Array|null|undefined} key\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.key = null;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * Message _from.\n * @member {\"from\"|undefined} _from\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_from\", {\n get: $util.oneOfGetter($oneOfFields = [\"from\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _data.\n * @member {\"data\"|undefined} _data\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_data\", {\n get: $util.oneOfGetter($oneOfFields = [\"data\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _seqno.\n * @member {\"seqno\"|undefined} _seqno\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_seqno\", {\n get: $util.oneOfGetter($oneOfFields = [\"seqno\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _signature.\n * @member {\"signature\"|undefined} _signature\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_signature\", {\n get: $util.oneOfGetter($oneOfFields = [\"signature\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _key.\n * @member {\"key\"|undefined} _key\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_key\", {\n get: $util.oneOfGetter($oneOfFields = [\"key\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified Message message. Does not implicitly {@link RPC.Message.verify|verify} messages.\n * @function encode\n * @memberof RPC.Message\n * @static\n * @param {RPC.IMessage} m Message message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Message.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.from != null && Object.hasOwnProperty.call(m, \"from\"))\n w.uint32(10).bytes(m.from);\n if (m.data != null && Object.hasOwnProperty.call(m, \"data\"))\n w.uint32(18).bytes(m.data);\n if (m.seqno != null && Object.hasOwnProperty.call(m, \"seqno\"))\n w.uint32(26).bytes(m.seqno);\n if (m.topicIDs != null && m.topicIDs.length) {\n for (var i = 0; i < m.topicIDs.length; ++i)\n w.uint32(34).string(m.topicIDs[i]);\n }\n if (m.signature != null && Object.hasOwnProperty.call(m, \"signature\"))\n w.uint32(42).bytes(m.signature);\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(50).bytes(m.key);\n return w;\n };\n\n /**\n * Decodes a Message message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.Message\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.Message} Message\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Message.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.Message();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.from = r.bytes();\n break;\n case 2:\n m.data = r.bytes();\n break;\n case 3:\n m.seqno = r.bytes();\n break;\n case 4:\n if (!(m.topicIDs && m.topicIDs.length))\n m.topicIDs = [];\n m.topicIDs.push(r.string());\n break;\n case 5:\n m.signature = r.bytes();\n break;\n case 6:\n m.key = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Message message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.Message\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.Message} Message\n */\n Message.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.Message)\n return d;\n var m = new $root.RPC.Message();\n if (d.from != null) {\n if (typeof d.from === \"string\")\n $util.base64.decode(d.from, m.from = $util.newBuffer($util.base64.length(d.from)), 0);\n else if (d.from.length)\n m.from = d.from;\n }\n if (d.data != null) {\n if (typeof d.data === \"string\")\n $util.base64.decode(d.data, m.data = $util.newBuffer($util.base64.length(d.data)), 0);\n else if (d.data.length)\n m.data = d.data;\n }\n if (d.seqno != null) {\n if (typeof d.seqno === \"string\")\n $util.base64.decode(d.seqno, m.seqno = $util.newBuffer($util.base64.length(d.seqno)), 0);\n else if (d.seqno.length)\n m.seqno = d.seqno;\n }\n if (d.topicIDs) {\n if (!Array.isArray(d.topicIDs))\n throw TypeError(\".RPC.Message.topicIDs: array expected\");\n m.topicIDs = [];\n for (var i = 0; i < d.topicIDs.length; ++i) {\n m.topicIDs[i] = String(d.topicIDs[i]);\n }\n }\n if (d.signature != null) {\n if (typeof d.signature === \"string\")\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Message message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.Message\n * @static\n * @param {RPC.Message} m Message\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Message.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.topicIDs = [];\n }\n if (m.from != null && m.hasOwnProperty(\"from\")) {\n d.from = o.bytes === String ? $util.base64.encode(m.from, 0, m.from.length) : o.bytes === Array ? Array.prototype.slice.call(m.from) : m.from;\n if (o.oneofs)\n d._from = \"from\";\n }\n if (m.data != null && m.hasOwnProperty(\"data\")) {\n d.data = o.bytes === String ? $util.base64.encode(m.data, 0, m.data.length) : o.bytes === Array ? Array.prototype.slice.call(m.data) : m.data;\n if (o.oneofs)\n d._data = \"data\";\n }\n if (m.seqno != null && m.hasOwnProperty(\"seqno\")) {\n d.seqno = o.bytes === String ? $util.base64.encode(m.seqno, 0, m.seqno.length) : o.bytes === Array ? Array.prototype.slice.call(m.seqno) : m.seqno;\n if (o.oneofs)\n d._seqno = \"seqno\";\n }\n if (m.topicIDs && m.topicIDs.length) {\n d.topicIDs = [];\n for (var j = 0; j < m.topicIDs.length; ++j) {\n d.topicIDs[j] = m.topicIDs[j];\n }\n }\n if (m.signature != null && m.hasOwnProperty(\"signature\")) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n if (o.oneofs)\n d._signature = \"signature\";\n }\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n if (o.oneofs)\n d._key = \"key\";\n }\n return d;\n };\n\n /**\n * Converts this Message to JSON.\n * @function toJSON\n * @memberof RPC.Message\n * @instance\n * @returns {Object.} JSON object\n */\n Message.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Message;\n })();\n\n return RPC;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p-pubsub:peer-streams'), {\n error: debug('libp2p-pubsub:peer-streams:err')\n})\nconst { EventEmitter } = require('events')\n\nconst lp = require('it-length-prefixed')\nconst pushable = require('it-pushable')\nconst { pipe } = require('it-pipe')\nconst { source: abortable } = require('abortable-iterator')\nconst AbortController = require('abort-controller').default\n\n/**\n * @typedef {import('../stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('it-pushable').Pushable} PushableStream\n */\n\n/**\n * Thin wrapper around a peer's inbound / outbound pubsub streams\n */\nclass PeerStreams extends EventEmitter {\n /**\n * @param {object} properties - properties of the PeerStreams.\n * @param {PeerId} properties.id\n * @param {string} properties.protocol\n */\n constructor ({ id, protocol }) {\n super()\n\n /**\n * @type {import('peer-id')}\n */\n this.id = id\n /**\n * Established protocol\n *\n * @type {string}\n */\n this.protocol = protocol\n /**\n * The raw outbound stream, as retrieved from conn.newStream\n *\n * @private\n * @type {null|MuxedStream}\n */\n this._rawOutboundStream = null\n /**\n * The raw inbound stream, as retrieved from the callback from libp2p.handle\n *\n * @private\n * @type {null|MuxedStream}\n */\n this._rawInboundStream = null\n /**\n * An AbortController for controlled shutdown of the inbound stream\n *\n * @private\n * @type {AbortController}\n */\n this._inboundAbortController = new AbortController()\n /**\n * Write stream -- its preferable to use the write method\n *\n * @type {null|PushableStream}\n */\n this.outboundStream = null\n /**\n * Read stream\n *\n * @type {null| AsyncIterable}\n */\n this.inboundStream = null\n }\n\n /**\n * Do we have a connection to read from?\n *\n * @type {boolean}\n */\n get isReadable () {\n return Boolean(this.inboundStream)\n }\n\n /**\n * Do we have a connection to write on?\n *\n * @type {boolean}\n */\n get isWritable () {\n return Boolean(this.outboundStream)\n }\n\n /**\n * Send a message to this peer.\n * Throws if there is no `stream` to write to available.\n *\n * @param {Uint8Array} data\n * @returns {void}\n */\n write (data) {\n if (!this.outboundStream) {\n const id = this.id.toB58String()\n throw new Error('No writable connection to ' + id)\n }\n\n this.outboundStream.push(data)\n }\n\n /**\n * Attach a raw inbound stream and setup a read stream\n *\n * @param {MuxedStream} stream\n * @returns {AsyncIterable}\n */\n attachInboundStream (stream) {\n // Create and attach a new inbound stream\n // The inbound stream is:\n // - abortable, set to only return on abort, rather than throw\n // - transformed with length-prefix transform\n this._rawInboundStream = stream\n this.inboundStream = abortable(\n pipe(\n this._rawInboundStream,\n lp.decode()\n ),\n this._inboundAbortController.signal,\n { returnOnAbort: true }\n )\n\n this.emit('stream:inbound')\n return this.inboundStream\n }\n\n /**\n * Attach a raw outbound stream and setup a write stream\n *\n * @param {MuxedStream} stream\n * @returns {Promise}\n */\n async attachOutboundStream (stream) {\n // If an outbound stream already exists, gently close it\n const _prevStream = this.outboundStream\n if (this.outboundStream) {\n // End the stream without emitting a close event\n await this.outboundStream.end()\n }\n\n this._rawOutboundStream = stream\n this.outboundStream = pushable({\n onEnd: (shouldEmit) => {\n // close writable side of the stream\n this._rawOutboundStream && this._rawOutboundStream.reset && this._rawOutboundStream.reset()\n this._rawOutboundStream = null\n this.outboundStream = null\n if (shouldEmit) {\n this.emit('close')\n }\n }\n })\n\n pipe(\n this.outboundStream,\n lp.encode(),\n this._rawOutboundStream\n ).catch(/** @param {Error} err */ err => {\n log.error(err)\n })\n\n // Only emit if the connection is new\n if (!_prevStream) {\n this.emit('stream:outbound')\n }\n }\n\n /**\n * Closes the open connection to peer\n *\n * @returns {void}\n */\n close () {\n // End the outbound stream\n if (this.outboundStream) {\n this.outboundStream.end()\n }\n // End the inbound stream\n if (this.inboundStream) {\n this._inboundAbortController.abort()\n }\n\n this._rawOutboundStream = null\n this.outboundStream = null\n this._rawInboundStream = null\n this.inboundStream = null\n this.emit('close')\n }\n}\n\nmodule.exports = PeerStreams\n","'use strict'\n\n/**\n * @typedef {import('./types').EncoderOptions} EncoderOptions\n * @typedef {import('./types').DecoderOptions} DecoderOptions\n */\n\nexports.encode = require('./encode')\nexports.decode = require('./decode')\n\nexports.varintEncode = require('./varint-encode')\nexports.varintDecode = require('./varint-decode')\n\nexports.int32BEEncode = require('./int32BE-encode')\nexports.int32BEDecode = require('./int32BE-decode')\n","'use strict'\n\nconst { Buffer } = require('buffer')\n// @ts-ignore\nconst BufferList = require('bl/BufferList')\nconst varintEncode = require('./varint-encode')\n\nconst MIN_POOL_SIZE = 8 // Varint.encode(Number.MAX_SAFE_INTEGER).length\nconst DEFAULT_POOL_SIZE = 10 * 1024\n\n/**\n * @param {import('./types').EncoderOptions} [options]\n */\nfunction encode (options) {\n options = options || {}\n\n const poolSize = Math.max(options.poolSize || DEFAULT_POOL_SIZE, options.minPoolSize || MIN_POOL_SIZE)\n const encodeLength = options.lengthEncoder || varintEncode\n\n /**\n * @param {AsyncIterable} source\n */\n const encoder = async function * (source) {\n let pool = Buffer.alloc(poolSize)\n let poolOffset = 0\n\n for await (const chunk of source) {\n encodeLength(chunk.length, pool, poolOffset)\n const encodedLength = pool.slice(poolOffset, poolOffset + encodeLength.bytes)\n poolOffset += encodeLength.bytes\n\n if (pool.length - poolOffset < MIN_POOL_SIZE) {\n pool = Buffer.alloc(poolSize)\n poolOffset = 0\n }\n\n yield new BufferList().append(encodedLength).append(chunk)\n // yield Buffer.concat([encodedLength, chunk])\n }\n }\n\n return encoder\n}\n\n/**\n * @param {BufferList | Buffer} chunk\n * @param {import('./types').EncoderOptions} [options]\n */\nencode.single = (chunk, options) => {\n options = options || {}\n const encodeLength = options.lengthEncoder || varintEncode\n return new BufferList([encodeLength(chunk.length), chunk.slice()])\n}\n\nmodule.exports = encode\nmodule.exports.MIN_POOL_SIZE = MIN_POOL_SIZE\nmodule.exports.DEFAULT_POOL_SIZE = DEFAULT_POOL_SIZE\n","'use strict'\n\n// @ts-ignore no types\nconst Varint = require('varint')\nconst { Buffer } = require('buffer')\n\n/**\n * Encode the passed length `value` to the `target` buffer at the given `offset`\n *\n * @type {import('./types').LengthEncoderFunction}\n */\n// @ts-ignore cannot declare expected bytes property\nconst varintEncode = (value, target, offset) => {\n const ret = Varint.encode(value, target, offset)\n varintEncode.bytes = Varint.encode.bytes\n // If no target, create Buffer from returned array\n return target || Buffer.from(ret)\n}\n\nmodule.exports = varintEncode\n","'use strict'\n\nconst { Buffer } = require('buffer')\n// @ts-ignore\nconst BufferList = require('bl/BufferList')\nconst varintDecode = require('./varint-decode')\n\n// Maximum length of the length section of the message\nconst MAX_LENGTH_LENGTH = 8 // Varint.encode(Number.MAX_SAFE_INTEGER).length\n// Maximum length of the data section of the message\nconst MAX_DATA_LENGTH = 1024 * 1024 * 4\n\nconst Empty = Buffer.alloc(0)\nconst ReadModes = { LENGTH: 'readLength', DATA: 'readData' }\n\nconst ReadHandlers = {\n /**\n * @param {BufferList} chunk\n * @param {BufferList} buffer\n * @param {import('./types').ReadState | undefined} state\n * @param {import('./types').DecoderOptions} options\n * @returns {import('./types').ReadResult}\n */\n [ReadModes.LENGTH]: (chunk, buffer, state, options) => {\n // console.log(ReadModes.LENGTH, chunk.length)\n buffer = buffer.append(chunk)\n\n let dataLength\n try {\n dataLength = options.lengthDecoder(buffer)\n } catch (err) {\n if (buffer.length > options.maxLengthLength) {\n throw Object.assign(err, { message: 'message length too long', code: 'ERR_MSG_LENGTH_TOO_LONG' })\n }\n if (err instanceof RangeError) {\n return { mode: ReadModes.LENGTH, buffer, chunk: undefined, state: undefined, data: undefined }\n }\n throw err\n }\n\n if (dataLength > options.maxDataLength) {\n throw Object.assign(new Error('message data too long'), { code: 'ERR_MSG_DATA_TOO_LONG' })\n }\n\n chunk = buffer.shallowSlice(options.lengthDecoder.bytes)\n buffer = new BufferList()\n\n if (options.onLength) options.onLength(dataLength)\n\n if (dataLength <= 0) {\n if (options.onData) options.onData(Empty)\n return { mode: ReadModes.LENGTH, chunk, buffer, data: Empty }\n }\n\n return { mode: ReadModes.DATA, chunk, buffer, state: { dataLength }, data: undefined }\n },\n\n /**\n * @param {BufferList} chunk\n * @param {BufferList} buffer\n * @param {import('./types').ReadState | undefined} state\n * @param {import('./types').DecoderOptions} options\n * @returns {import('./types').ReadResult}\n */\n [ReadModes.DATA]: (chunk, buffer, state, options) => {\n // console.log(ReadModes.DATA, chunk.length)\n buffer = buffer.append(chunk)\n\n if (!state) {\n throw new Error('state is required')\n }\n\n if (buffer.length < state.dataLength) {\n return { mode: ReadModes.DATA, buffer, state, chunk: undefined, data: undefined }\n }\n\n const { dataLength } = state\n const data = buffer.shallowSlice(0, dataLength)\n\n const nextChunk = buffer.length > dataLength ? buffer.shallowSlice(dataLength) : undefined\n buffer = new BufferList()\n\n if (options.onData) options.onData(data)\n return { mode: ReadModes.LENGTH, chunk: nextChunk, buffer, state: undefined, data }\n }\n}\n\n/**\n * @param {any} [options]\n */\nfunction decode (options) {\n options = options || {}\n\n /**\n * @type {import('./types').DecoderOptions}\n */\n const opts = {\n lengthDecoder: options.lengthDecoder || varintDecode,\n maxLengthLength: options.maxLengthLength || MAX_LENGTH_LENGTH,\n maxDataLength: options.maxDataLength || MAX_DATA_LENGTH,\n onLength: options.onLength,\n onData: options.onData\n }\n\n /**\n * @param {AsyncIterable} source\n */\n const decoder = async function * (source) {\n let buffer = new BufferList()\n let mode = ReadModes.LENGTH // current parsing mode\n let state // accumulated state for the current mode\n\n for await (const chunk of source) {\n /** @type {BufferList | undefined} */\n let nextChunk = chunk\n\n // Each chunk may contain multiple messages - keep calling handler for the\n // current parsing mode until all handlers have consumed the chunk.\n while (nextChunk) {\n const result = ReadHandlers[mode](nextChunk, buffer, state, opts)\n\n mode = result.mode\n nextChunk = result.chunk\n buffer = result.buffer\n state = result.state\n\n if (result.data) {\n yield result.data\n }\n }\n }\n\n if (buffer.length) {\n throw Object.assign(new Error('unexpected end of input'), { code: 'ERR_UNEXPECTED_EOF' })\n }\n }\n\n return decoder\n}\n\n/**\n * @param {*} reader\n * @param {import('./types').DecoderOptions} [options]\n * @returns\n */\ndecode.fromReader = (reader, options) => {\n let byteLength = 1 // Read single byte chunks until the length is known\n\n const varByteSource = {\n [Symbol.asyncIterator] () { return this },\n next: async () => {\n try {\n return await reader.next(byteLength)\n } catch (err) {\n if (err.code === 'ERR_UNDER_READ') {\n return { done: true, value: null }\n }\n throw err\n } finally {\n // Reset the byteLength so we continue to check for varints\n byteLength = 1\n }\n }\n }\n\n /**\n * Once the length has been parsed, read chunk for that length\n *\n * @param {number} l\n */\n const onLength = l => { byteLength = l }\n return decode({\n ...(options || {}),\n onLength\n })(varByteSource)\n}\n\nmodule.exports = decode\nmodule.exports.MAX_LENGTH_LENGTH = MAX_LENGTH_LENGTH\nmodule.exports.MAX_DATA_LENGTH = MAX_DATA_LENGTH\n","'use strict'\n\n// @ts-ignore no types\nconst Varint = require('varint')\nconst { Buffer } = require('buffer')\n\n/**\n * @param {any} bl\n */\nconst toBufferProxy = bl => new Proxy({}, {\n get: (_, prop) => {\n // @ts-ignore magic\n return prop[0] === 'l' ? bl[prop] : bl.get(parseInt(prop))\n }\n})\n\n/**\n * @type {import('./types').LengthDecoderFunction}\n */\n// @ts-ignore cannot declare expected bytes property\nconst varintDecode = data => {\n const len = Varint.decode(Buffer.isBuffer(data) ? data : toBufferProxy(data))\n varintDecode.bytes = Varint.decode.bytes\n return len\n}\n\nmodule.exports = varintDecode\n","'use strict'\n\nconst { Buffer } = require('buffer')\n\n/**\n * @param {number} value\n * @param {Buffer} target\n * @param {number} offset\n */\nconst int32BEEncode = (value, target, offset) => {\n target = target || Buffer.allocUnsafe(4)\n target.writeInt32BE(value, offset)\n return target\n}\n\nint32BEEncode.bytes = 4 // Always because fixed length\n\nmodule.exports = int32BEEncode\n","'use strict'\n\n/**\n * @param {import('buffer').Buffer} data\n */\nconst int32BEDecode = data => {\n if (data.length < 4) throw RangeError('Could not decode int32BE')\n return data.readInt32BE(0)\n}\n\nint32BEDecode.bytes = 4 // Always because fixed length\n\nmodule.exports = int32BEDecode\n","const getIterator = require('get-iterator')\nconst AbortError = require('./AbortError')\n\n// Wrap an iterator to make it abortable, allow cleanup when aborted via onAbort\nconst toAbortableSource = (source, signal, options) => (\n toMultiAbortableSource(source, Array.isArray(signal) ? signal : [{ signal, options }])\n)\n\nconst toMultiAbortableSource = (source, signals) => {\n source = getIterator(source)\n signals = signals.map(({ signal, options }) => ({ signal, options: options || {} }))\n\n async function * abortable () {\n let nextAbortHandler\n const abortHandler = () => {\n if (nextAbortHandler) nextAbortHandler()\n }\n\n for (const { signal } of signals) {\n signal.addEventListener('abort', abortHandler)\n }\n\n while (true) {\n let result\n try {\n for (const { signal, options } of signals) {\n if (signal.aborted) {\n const { abortMessage, abortCode } = options\n throw new AbortError(abortMessage, abortCode)\n }\n }\n\n const abort = new Promise((resolve, reject) => {\n nextAbortHandler = () => {\n const { options } = signals.find(({ signal }) => signal.aborted)\n const { abortMessage, abortCode } = options\n reject(new AbortError(abortMessage, abortCode))\n }\n })\n\n // Race the iterator and the abort signals\n result = await Promise.race([abort, source.next()])\n nextAbortHandler = null\n } catch (err) {\n for (const { signal } of signals) {\n signal.removeEventListener('abort', abortHandler)\n }\n\n // Might not have been aborted by a known signal\n const aborter = signals.find(({ signal }) => signal.aborted)\n const isKnownAborter = err.type === 'aborted' && aborter\n\n if (isKnownAborter && aborter.options.onAbort) {\n // Do any custom abort handling for the iterator\n await aborter.options.onAbort(source)\n }\n\n // End the iterator if it is a generator\n if (typeof source.return === 'function') {\n await source.return()\n }\n\n if (isKnownAborter && aborter.options.returnOnAbort) {\n return\n }\n\n throw err\n }\n\n if (result.done) break\n yield result.value\n }\n\n for (const { signal } of signals) {\n signal.removeEventListener('abort', abortHandler)\n }\n }\n\n return abortable()\n}\n\nconst toAbortableSink = (sink, signal, options) => (\n toMultiAbortableSink(sink, Array.isArray(signal) ? signal : [{ signal, options }])\n)\n\nconst toMultiAbortableSink = (sink, signals) => source => (\n sink(toMultiAbortableSource(source, signals))\n)\n\nconst toAbortableDuplex = (duplex, signal, options) => (\n toMultiAbortableDuplex(duplex, Array.isArray(signal) ? signal : [{ signal, options }])\n)\n\nconst toMultiAbortableDuplex = (duplex, signals) => ({\n sink: toMultiAbortableSink(duplex.sink, signals),\n source: toMultiAbortableSource(duplex.source, signals)\n})\n\nmodule.exports = toAbortableSource\nmodule.exports.AbortError = AbortError\nmodule.exports.source = toAbortableSource\nmodule.exports.sink = toAbortableSink\nmodule.exports.transform = toAbortableSink\nmodule.exports.duplex = toAbortableDuplex\n","// If the passed object is an (async) iterable, then get the iterator\n// If it's probably an iterator already (i.e. has next function) return it\n// else throw\nmodule.exports = function getIterator (obj) {\n if (obj) {\n if (typeof obj[Symbol.iterator] === 'function') {\n return obj[Symbol.iterator]()\n }\n if (typeof obj[Symbol.asyncIterator] === 'function') {\n return obj[Symbol.asyncIterator]()\n }\n if (typeof obj.next === 'function') {\n return obj // probably an iterator\n }\n }\n throw new Error('argument is not an iterator or iterable')\n}\n","module.exports = class AbortError extends Error {\n constructor (message, code) {\n super(message || 'The operation was aborted')\n this.type = 'aborted'\n this.code = code || 'ABORT_ERR'\n }\n}\n","'use strict'\n\n/**\n * Enum for Signature Policy\n * Details how message signatures are produced/consumed\n */\nconst SignaturePolicy = {\n /**\n * On the producing side:\n * * Build messages with the signature, key (from may be enough for certain inlineable public key types), from and seqno fields.\n *\n * On the consuming side:\n * * Enforce the fields to be present, reject otherwise.\n * * Propagate only if the fields are valid and signature can be verified, reject otherwise.\n */\n StrictSign: /** @type {'StrictSign'} */ ('StrictSign'),\n /**\n * On the producing side:\n * * Build messages without the signature, key, from and seqno fields.\n * * The corresponding protobuf key-value pairs are absent from the marshalled message, not just empty.\n *\n * On the consuming side:\n * * Enforce the fields to be absent, reject otherwise.\n * * Propagate only if the fields are absent, reject otherwise.\n * * A message_id function will not be able to use the above fields, and should instead rely on the data field. A commonplace strategy is to calculate a hash.\n */\n StrictNoSign: /** @type {'StrictNoSign'} */ ('StrictNoSign')\n}\nexports.SignaturePolicy = SignaturePolicy\n\n/**\n * @typedef {SignaturePolicy[keyof SignaturePolicy]} SignaturePolicyType\n */\n","'use strict'\n\n// @ts-ignore libp2p crypto has no types\nconst randomBytes = require('libp2p-crypto/src/random-bytes')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst PeerId = require('peer-id')\nconst { sha256 } = require('multiformats/hashes/sha2')\n\n/**\n * @typedef {import('./message/rpc').RPC.IMessage} IMessage\n * @typedef {import('./message/rpc').RPC.Message} Message\n * @typedef {import('.').InMessage} NormalizedIMessage\n */\n\n/**\n * Generatea random sequence number.\n *\n * @returns {Uint8Array}\n * @private\n */\nconst randomSeqno = () => {\n return randomBytes(8)\n}\n\n/**\n * Generate a message id, based on the `from` and `seqno`.\n *\n * @param {Uint8Array|string} from\n * @param {Uint8Array} seqno\n * @returns {Uint8Array}\n * @private\n */\nconst msgId = (from, seqno) => {\n let fromBytes\n\n if (from instanceof Uint8Array) {\n fromBytes = PeerId.createFromBytes(from).id\n } else {\n fromBytes = PeerId.parse(from).id\n }\n\n const msgId = new Uint8Array(fromBytes.length + seqno.length)\n msgId.set(fromBytes, 0)\n msgId.set(seqno, fromBytes.length)\n return msgId\n}\n\n/**\n * Generate a message id, based on message `data`.\n *\n * @param {Uint8Array} data\n * @private\n */\nconst noSignMsgId = (data) => sha256.encode(data)\n\n/**\n * Check if any member of the first set is also a member\n * of the second set.\n *\n * @param {Set|Array} a\n * @param {Set|Array} b\n * @returns {boolean}\n * @private\n */\nconst anyMatch = (a, b) => {\n let bHas\n if (Array.isArray(b)) {\n /**\n * @param {number} val\n */\n bHas = (val) => b.indexOf(val) > -1\n } else {\n /**\n * @param {number} val\n */\n bHas = (val) => b.has(val)\n }\n\n for (const val of a) {\n if (bHas(val)) {\n return true\n }\n }\n\n return false\n}\n\n/**\n * Make everything an array.\n *\n * @template T\n * @param {T|T[]} maybeArray\n * @returns {T[]}\n * @private\n */\nconst ensureArray = (maybeArray) => {\n if (!Array.isArray(maybeArray)) {\n return [maybeArray]\n }\n\n return maybeArray\n}\n\n/**\n * Ensures `message.from` is base58 encoded\n *\n * @template {{from?:any}} T\n * @param {T & IMessage} message\n * @param {string} [peerId]\n * @returns {NormalizedIMessage}\n */\nconst normalizeInRpcMessage = (message, peerId) => {\n /** @type {NormalizedIMessage} */\n // @ts-ignore receivedFrom not yet defined\n const m = Object.assign({}, message)\n if (message.from instanceof Uint8Array) {\n m.from = uint8ArrayToString(message.from, 'base58btc')\n }\n if (peerId) {\n m.receivedFrom = peerId\n }\n return m\n}\n\n/**\n * @template {{from?:any, data?:any}} T\n *\n * @param {T & NormalizedIMessage} message\n * @returns {Message}\n */\nconst normalizeOutRpcMessage = (message) => {\n /** @type {Message} */\n // @ts-ignore from not yet defined\n const m = Object.assign({}, message)\n if (typeof message.from === 'string') {\n m.from = uint8ArrayFromString(message.from, 'base58btc')\n }\n if (typeof message.data === 'string') {\n m.data = uint8ArrayFromString(message.data)\n }\n return m\n}\n\nmodule.exports = {\n randomSeqno,\n msgId,\n noSignMsgId,\n anyMatch,\n ensureArray,\n normalizeInRpcMessage,\n normalizeOutRpcMessage\n}\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { RPC } = require('./rpc')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst SignPrefix = uint8ArrayFromString('libp2p-pubsub:')\nconst { normalizeOutRpcMessage } = require('../utils')\n\n/**\n * @typedef {import('..').InMessage}\n */\n\n/**\n * Signs the provided message with the given `peerId`\n *\n * @param {PeerId} peerId\n * @param {InMessage} message\n * @returns {Promise}\n */\nasync function signMessage (peerId, message) {\n // Get the message in bytes, and prepend with the pubsub prefix\n const bytes = uint8ArrayConcat([\n SignPrefix,\n RPC.Message.encode(normalizeOutRpcMessage(message)).finish()\n ])\n\n const signature = await peerId.privKey.sign(bytes)\n\n return {\n ...message,\n signature: signature,\n key: peerId.pubKey.bytes\n }\n}\n\n/**\n * Verifies the signature of the given message\n *\n * @param {InMessage} message\n * @returns {Promise}\n */\nasync function verifySignature (message) {\n if (!message.signature) {\n throw new Error('Message must contain a signature to be verified')\n }\n\n if (!message.from) {\n throw new Error('Message must contain a from property to be verified')\n }\n\n // Get message sans the signature\n const bytes = uint8ArrayConcat([\n SignPrefix,\n RPC.Message.encode({\n ...message,\n from: PeerId.createFromB58String(message.from).toBytes(),\n signature: undefined,\n key: undefined\n }).finish()\n ])\n\n // Get the public key\n const pubKey = await messagePublicKey(message)\n\n // verify the base message\n return pubKey.verify(bytes, message.signature)\n}\n\n/**\n * Returns the PublicKey associated with the given message.\n * If no, valid PublicKey can be retrieved an error will be returned.\n *\n * @param {InMessage} message\n * @returns {Promise}\n */\nasync function messagePublicKey (message) {\n // should be available in the from property of the message (peer id)\n if (!message.from) {\n throw new Error('Could not get the public key from the originator id')\n }\n\n const from = PeerId.createFromB58String(message.from)\n\n if (message.key) {\n const keyPeerId = await PeerId.createFromPubKey(message.key)\n\n // the key belongs to the sender, return the key\n if (keyPeerId.equals(from)) return keyPeerId.pubKey\n // We couldn't validate pubkey is from the originator, error\n throw new Error('Public Key does not match the originator')\n } else if (from.pubKey) {\n return from.pubKey\n } else {\n throw new Error('Could not get the public key from the originator id')\n }\n}\n\n/**\n * @typedef {import('..').InMessage} InMessage\n * @typedef {import('libp2p-crypto').PublicKey} PublicKey\n */\n\nmodule.exports = {\n messagePublicKey,\n signMessage,\n SignPrefix,\n verifySignature\n}\n","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MessageCache = void 0;\nconst utils_1 = require(\"./utils\");\nclass MessageCache {\n /**\n * @param {Number} gossip\n * @param {Number} history\n * @param {msgIdFn} msgIdFn a function that returns message id from a message\n *\n * @constructor\n */\n constructor(gossip, history, msgIdFn) {\n /**\n * @type {Map}\n */\n this.msgs = new Map();\n this.peertx = new Map();\n /**\n * @type {Array>}\n */\n this.history = [];\n for (let i = 0; i < history; i++) {\n this.history[i] = [];\n }\n /**\n * @type {Number}\n */\n this.gossip = gossip;\n /**\n * @type {Function}\n */\n this.msgIdFn = msgIdFn;\n }\n /**\n * Adds a message to the current window and the cache\n *\n * @param {RPC.Message} msg\n * @returns {Promise}\n */\n put(msg) {\n return __awaiter(this, void 0, void 0, function* () {\n const msgID = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgID);\n this.msgs.set(msgIdStr, msg);\n this.history[0].push({ msgID, topics: msg.topicIDs });\n });\n }\n /**\n * Get message id of message.\n * @param {RPC.Message} msg\n * @returns {Promise | Uint8Array}\n */\n getMsgId(msg) {\n return this.msgIdFn(msg);\n }\n /**\n * Retrieves a message from the cache by its ID, if it is still present\n *\n * @param {Uint8Array} msgID\n * @returns {Message}\n */\n get(msgID) {\n return this.msgs.get(utils_1.messageIdToString(msgID));\n }\n /**\n * Retrieves a message from the cache by its ID, if it is present\n * for a specific peer.\n * Returns the message and the number of times the peer has requested the message\n *\n * @param {string} msgID\n * @param {string} p\n * @returns {[InMessage | undefined, number]}\n */\n getForPeer(msgID, p) {\n const msgIdStr = utils_1.messageIdToString(msgID);\n const msg = this.msgs.get(msgIdStr);\n if (!msg) {\n return [undefined, 0];\n }\n let peertx = this.peertx.get(msgIdStr);\n if (!peertx) {\n peertx = new Map();\n this.peertx.set(msgIdStr, peertx);\n }\n const count = (peertx.get(p) || 0) + 1;\n peertx.set(p, count);\n return [msg, count];\n }\n /**\n * Retrieves a list of message IDs for a given topic\n *\n * @param {String} topic\n *\n * @returns {Array}\n */\n getGossipIDs(topic) {\n const msgIDs = [];\n for (let i = 0; i < this.gossip; i++) {\n this.history[i].forEach((entry) => {\n for (const t of entry.topics) {\n if (t === topic) {\n msgIDs.push(entry.msgID);\n break;\n }\n }\n });\n }\n return msgIDs;\n }\n /**\n * Shifts the current window, discarding messages older than this.history.length of the cache\n *\n * @returns {void}\n */\n shift() {\n const last = this.history[this.history.length - 1];\n last.forEach((entry) => {\n const msgIdStr = utils_1.messageIdToString(entry.msgID);\n this.msgs.delete(msgIdStr);\n this.peertx.delete(msgIdStr);\n });\n this.history.pop();\n this.history.unshift([]);\n }\n}\nexports.MessageCache = MessageCache;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__exportStar(require(\"./create-gossip-rpc\"), exports);\n__exportStar(require(\"./shuffle\"), exports);\n__exportStar(require(\"./has-gossip-protocol\"), exports);\n__exportStar(require(\"./messageIdToString\"), exports);\n","'use strict';\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.createGossipRpc = void 0;\n/**\n * Create a gossipsub RPC object\n * @param {Array} msgs\n * @param {Partial} control\n * @returns {IRPC}\n */\nfunction createGossipRpc(msgs = [], control = {}) {\n return {\n subscriptions: [],\n msgs: msgs,\n control: Object.assign({ ihave: [], iwant: [], graft: [], prune: [] }, control)\n };\n}\nexports.createGossipRpc = createGossipRpc;\n","'use strict';\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.shuffle = void 0;\n/**\n * Pseudo-randomly shuffles an array\n *\n * Mutates the input array\n *\n * @param {Array} arr\n * @returns {Array}\n */\nfunction shuffle(arr) {\n if (arr.length <= 1) {\n return arr;\n }\n const randInt = () => {\n return Math.floor(Math.random() * Math.floor(arr.length));\n };\n for (let i = 0; i < arr.length; i++) {\n const j = randInt();\n const tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n }\n return arr;\n}\nexports.shuffle = shuffle;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.hasGossipProtocol = void 0;\nconst constants_1 = require(\"../constants\");\nfunction hasGossipProtocol(protocol) {\n return (protocol === constants_1.GossipsubIDv10 || protocol === constants_1.GossipsubIDv11);\n}\nexports.hasGossipProtocol = hasGossipProtocol;\n","'use strict';\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ERR_TOPIC_VALIDATOR_IGNORE = exports.ERR_TOPIC_VALIDATOR_REJECT = exports.TimeCacheDuration = exports.GossipsubSeenTTL = exports.GossipsubIWantFollowupTime = exports.GossipsubMaxIHaveMessages = exports.GossipsubMaxIHaveLength = exports.GossipsubGraftFloodThreshold = exports.GossipsubOpportunisticGraftPeers = exports.GossipsubOpportunisticGraftTicks = exports.GossipsubDirectConnectInitialDelay = exports.GossipsubDirectConnectTicks = exports.GossipsubConnectionTimeout = exports.GossipsubMaxPendingConnections = exports.GossipsubConnectors = exports.GossipsubPruneBackoffTicks = exports.GossipsubPruneBackoff = exports.GossipsubPrunePeers = exports.GossipsubFanoutTTL = exports.GossipsubHeartbeatInterval = exports.GossipsubHeartbeatInitialDelay = exports.GossipsubGossipRetransmission = exports.GossipsubGossipFactor = exports.GossipsubDlazy = exports.GossipsubHistoryGossip = exports.GossipsubHistoryLength = exports.GossipsubDout = exports.GossipsubDscore = exports.GossipsubDhi = exports.GossipsubDlo = exports.GossipsubD = exports.GossipsubIDv11 = exports.GossipsubIDv10 = exports.FloodsubID = exports.minute = exports.second = void 0;\nexports.second = 1000;\nexports.minute = 60 * exports.second;\n// Protocol identifiers\nexports.FloodsubID = '/floodsub/1.0.0';\n/**\n * The protocol ID for version 1.0.0 of the Gossipsub protocol\n * It is advertised along with GossipsubIDv11 for backwards compatability\n */\nexports.GossipsubIDv10 = '/meshsub/1.0.0';\n/**\n * The protocol ID for version 1.1.0 of the Gossipsub protocol\n * See the spec for details about how v1.1.0 compares to v1.0.0:\n * https://github.com/libp2p/specs/blob/master/pubsub/gossipsub/gossipsub-v1.1.md\n */\nexports.GossipsubIDv11 = '/meshsub/1.1.0';\n// Overlay parameters\n/**\n * GossipsubD sets the optimal degree for a Gossipsub topic mesh. For example, if GossipsubD == 6,\n * each peer will want to have about six peers in their mesh for each topic they're subscribed to.\n * GossipsubD should be set somewhere between GossipsubDlo and GossipsubDhi.\n */\nexports.GossipsubD = 6;\n/**\n * GossipsubDlo sets the lower bound on the number of peers we keep in a Gossipsub topic mesh.\n * If we have fewer than GossipsubDlo peers, we will attempt to graft some more into the mesh at\n * the next heartbeat.\n */\nexports.GossipsubDlo = 4;\n/**\n * GossipsubDhi sets the upper bound on the number of peers we keep in a Gossipsub topic mesh.\n * If we have more than GossipsubDhi peers, we will select some to prune from the mesh at the next heartbeat.\n */\nexports.GossipsubDhi = 12;\n/**\n * GossipsubDscore affects how peers are selected when pruning a mesh due to over subscription.\n * At least GossipsubDscore of the retained peers will be high-scoring, while the remainder are\n * chosen randomly.\n */\nexports.GossipsubDscore = 4;\n/**\n * GossipsubDout sets the quota for the number of outbound connections to maintain in a topic mesh.\n * When the mesh is pruned due to over subscription, we make sure that we have outbound connections\n * to at least GossipsubDout of the survivor peers. This prevents sybil attackers from overwhelming\n * our mesh with incoming connections.\n *\n * GossipsubDout must be set below GossipsubDlo, and must not exceed GossipsubD / 2.\n */\nexports.GossipsubDout = 2;\n// Gossip parameters\n/**\n * GossipsubHistoryLength controls the size of the message cache used for gossip.\n * The message cache will remember messages for GossipsubHistoryLength heartbeats.\n */\nexports.GossipsubHistoryLength = 5;\n/**\n * GossipsubHistoryGossip controls how many cached message ids we will advertise in\n * IHAVE gossip messages. When asked for our seen message IDs, we will return\n * only those from the most recent GossipsubHistoryGossip heartbeats. The slack between\n * GossipsubHistoryGossip and GossipsubHistoryLength allows us to avoid advertising messages\n * that will be expired by the time they're requested.\n *\n * GossipsubHistoryGossip must be less than or equal to GossipsubHistoryLength to\n * avoid a runtime panic.\n */\nexports.GossipsubHistoryGossip = 3;\n/**\n * GossipsubDlazy affects how many peers we will emit gossip to at each heartbeat.\n * We will send gossip to at least GossipsubDlazy peers outside our mesh. The actual\n * number may be more, depending on GossipsubGossipFactor and how many peers we're\n * connected to.\n */\nexports.GossipsubDlazy = 6;\n/**\n * GossipsubGossipFactor affects how many peers we will emit gossip to at each heartbeat.\n * We will send gossip to GossipsubGossipFactor * (total number of non-mesh peers), or\n * GossipsubDlazy, whichever is greater.\n */\nexports.GossipsubGossipFactor = 0.25;\n/**\n * GossipsubGossipRetransmission controls how many times we will allow a peer to request\n * the same message id through IWANT gossip before we start ignoring them. This is designed\n * to prevent peers from spamming us with requests and wasting our resources.\n */\nexports.GossipsubGossipRetransmission = 3;\n// Heartbeat interval\n/**\n * GossipsubHeartbeatInitialDelay is the short delay before the heartbeat timer begins\n * after the router is initialized.\n */\nexports.GossipsubHeartbeatInitialDelay = 100;\n/**\n * GossipsubHeartbeatInterval controls the time between heartbeats.\n */\nexports.GossipsubHeartbeatInterval = exports.second;\n/**\n * GossipsubFanoutTTL controls how long we keep track of the fanout state. If it's been\n * GossipsubFanoutTTL since we've published to a topic that we're not subscribed to,\n * we'll delete the fanout map for that topic.\n */\nexports.GossipsubFanoutTTL = exports.minute;\n/**\n * GossipsubPrunePeers controls the number of peers to include in prune Peer eXchange.\n * When we prune a peer that's eligible for PX (has a good score, etc), we will try to\n * send them signed peer records for up to GossipsubPrunePeers other peers that we\n * know of.\n */\nexports.GossipsubPrunePeers = 16;\n/**\n * GossipsubPruneBackoff controls the backoff time for pruned peers. This is how long\n * a peer must wait before attempting to graft into our mesh again after being pruned.\n * When pruning a peer, we send them our value of GossipsubPruneBackoff so they know\n * the minimum time to wait. Peers running older versions may not send a backoff time,\n * so if we receive a prune message without one, we will wait at least GossipsubPruneBackoff\n * before attempting to re-graft.\n */\nexports.GossipsubPruneBackoff = exports.minute;\n/**\n * GossipsubPruneBackoffTicks is the number of heartbeat ticks for attempting to prune expired\n * backoff timers.\n */\nexports.GossipsubPruneBackoffTicks = 15;\n/**\n * GossipsubConnectors controls the number of active connection attempts for peers obtained through PX.\n */\nexports.GossipsubConnectors = 8;\n/**\n * GossipsubMaxPendingConnections sets the maximum number of pending connections for peers attempted through px.\n */\nexports.GossipsubMaxPendingConnections = 128;\n/**\n * GossipsubConnectionTimeout controls the timeout for connection attempts.\n */\nexports.GossipsubConnectionTimeout = 30 * exports.second;\n/**\n * GossipsubDirectConnectTicks is the number of heartbeat ticks for attempting to reconnect direct peers\n * that are not currently connected.\n */\nexports.GossipsubDirectConnectTicks = 300;\n/**\n * GossipsubDirectConnectInitialDelay is the initial delay before opening connections to direct peers\n */\nexports.GossipsubDirectConnectInitialDelay = exports.second;\n/**\n * GossipsubOpportunisticGraftTicks is the number of heartbeat ticks for attempting to improve the mesh\n * with opportunistic grafting. Every GossipsubOpportunisticGraftTicks we will attempt to select some\n * high-scoring mesh peers to replace lower-scoring ones, if the median score of our mesh peers falls\n * below a threshold\n */\nexports.GossipsubOpportunisticGraftTicks = 60;\n/**\n * GossipsubOpportunisticGraftPeers is the number of peers to opportunistically graft.\n */\nexports.GossipsubOpportunisticGraftPeers = 2;\n/**\n * If a GRAFT comes before GossipsubGraftFloodThreshold has elapsed since the last PRUNE,\n * then there is an extra score penalty applied to the peer through P7.\n */\nexports.GossipsubGraftFloodThreshold = 10 * exports.second;\n/**\n * GossipsubMaxIHaveLength is the maximum number of messages to include in an IHAVE message.\n * Also controls the maximum number of IHAVE ids we will accept and request with IWANT from a\n * peer within a heartbeat, to protect from IHAVE floods. You should adjust this value from the\n * default if your system is pushing more than 5000 messages in GossipsubHistoryGossip heartbeats;\n * with the defaults this is 1666 messages/s.\n */\nexports.GossipsubMaxIHaveLength = 5000;\n/**\n * GossipsubMaxIHaveMessages is the maximum number of IHAVE messages to accept from a peer within a heartbeat.\n */\nexports.GossipsubMaxIHaveMessages = 10;\n/**\n * Time to wait for a message requested through IWANT following an IHAVE advertisement.\n * If the message is not received within this window, a broken promise is declared and\n * the router may apply bahavioural penalties.\n */\nexports.GossipsubIWantFollowupTime = 3 * exports.second;\n/**\n * Time in milliseconds to keep message ids in the seen cache\n */\nexports.GossipsubSeenTTL = 30 * exports.second;\nexports.TimeCacheDuration = 120 * 1000;\nexports.ERR_TOPIC_VALIDATOR_REJECT = 'ERR_TOPIC_VALIDATOR_REJECT';\nexports.ERR_TOPIC_VALIDATOR_IGNORE = 'ERR_TOPIC_VALIDATOR_IGNORE';\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.messageIdToString = void 0;\nconst to_string_1 = require(\"uint8arrays/to-string\");\nfunction messageIdToString(msgId) {\n return to_string_1.toString(msgId, 'base64');\n}\nexports.messageIdToString = messageIdToString;\n","/*eslint-disable*/\n(function(global, factory) { /* global define, require, module */\n\n /* AMD */ if (typeof define === 'function' && define.amd)\n define([\"protobufjs/minimal\"], factory);\n\n /* CommonJS */ else if (typeof require === 'function' && typeof module === 'object' && module && module.exports)\n module.exports = factory(require(\"protobufjs/minimal\"));\n\n})(this, function($protobuf) {\n \"use strict\";\n\n // Common aliases\n var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n \n // Exported root namespace\n var $root = $protobuf.roots[\"default\"] || ($protobuf.roots[\"default\"] = {});\n \n $root.RPC = (function() {\n \n /**\n * Properties of a RPC.\n * @exports IRPC\n * @interface IRPC\n * @property {Array.|null} [subscriptions] RPC subscriptions\n * @property {Array.|null} [msgs] RPC msgs\n * @property {RPC.IControlMessage|null} [control] RPC control\n */\n \n /**\n * Constructs a new RPC.\n * @exports RPC\n * @classdesc Represents a RPC.\n * @implements IRPC\n * @constructor\n * @param {IRPC=} [p] Properties to set\n */\n function RPC(p) {\n this.subscriptions = [];\n this.msgs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * RPC subscriptions.\n * @member {Array.} subscriptions\n * @memberof RPC\n * @instance\n */\n RPC.prototype.subscriptions = $util.emptyArray;\n \n /**\n * RPC msgs.\n * @member {Array.} msgs\n * @memberof RPC\n * @instance\n */\n RPC.prototype.msgs = $util.emptyArray;\n \n /**\n * RPC control.\n * @member {RPC.IControlMessage|null|undefined} control\n * @memberof RPC\n * @instance\n */\n RPC.prototype.control = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * RPC _control.\n * @member {\"control\"|undefined} _control\n * @memberof RPC\n * @instance\n */\n Object.defineProperty(RPC.prototype, \"_control\", {\n get: $util.oneOfGetter($oneOfFields = [\"control\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified RPC message. Does not implicitly {@link RPC.verify|verify} messages.\n * @function encode\n * @memberof RPC\n * @static\n * @param {IRPC} m RPC message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n RPC.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.subscriptions != null && m.subscriptions.length) {\n for (var i = 0; i < m.subscriptions.length; ++i)\n $root.RPC.SubOpts.encode(m.subscriptions[i], w.uint32(10).fork()).ldelim();\n }\n if (m.msgs != null && m.msgs.length) {\n for (var i = 0; i < m.msgs.length; ++i)\n $root.RPC.Message.encode(m.msgs[i], w.uint32(18).fork()).ldelim();\n }\n if (m.control != null && Object.hasOwnProperty.call(m, \"control\"))\n $root.RPC.ControlMessage.encode(m.control, w.uint32(26).fork()).ldelim();\n return w;\n };\n \n /**\n * Decodes a RPC message from the specified reader or buffer.\n * @function decode\n * @memberof RPC\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC} RPC\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n RPC.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.subscriptions && m.subscriptions.length))\n m.subscriptions = [];\n m.subscriptions.push($root.RPC.SubOpts.decode(r, r.uint32()));\n break;\n case 2:\n if (!(m.msgs && m.msgs.length))\n m.msgs = [];\n m.msgs.push($root.RPC.Message.decode(r, r.uint32()));\n break;\n case 3:\n m.control = $root.RPC.ControlMessage.decode(r, r.uint32());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a RPC message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC} RPC\n */\n RPC.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC)\n return d;\n var m = new $root.RPC();\n if (d.subscriptions) {\n if (!Array.isArray(d.subscriptions))\n throw TypeError(\".RPC.subscriptions: array expected\");\n m.subscriptions = [];\n for (var i = 0; i < d.subscriptions.length; ++i) {\n if (typeof d.subscriptions[i] !== \"object\")\n throw TypeError(\".RPC.subscriptions: object expected\");\n m.subscriptions[i] = $root.RPC.SubOpts.fromObject(d.subscriptions[i]);\n }\n }\n if (d.msgs) {\n if (!Array.isArray(d.msgs))\n throw TypeError(\".RPC.msgs: array expected\");\n m.msgs = [];\n for (var i = 0; i < d.msgs.length; ++i) {\n if (typeof d.msgs[i] !== \"object\")\n throw TypeError(\".RPC.msgs: object expected\");\n m.msgs[i] = $root.RPC.Message.fromObject(d.msgs[i]);\n }\n }\n if (d.control != null) {\n if (typeof d.control !== \"object\")\n throw TypeError(\".RPC.control: object expected\");\n m.control = $root.RPC.ControlMessage.fromObject(d.control);\n }\n return m;\n };\n \n /**\n * Creates a plain object from a RPC message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC\n * @static\n * @param {RPC} m RPC\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n RPC.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.subscriptions = [];\n d.msgs = [];\n }\n if (m.subscriptions && m.subscriptions.length) {\n d.subscriptions = [];\n for (var j = 0; j < m.subscriptions.length; ++j) {\n d.subscriptions[j] = $root.RPC.SubOpts.toObject(m.subscriptions[j], o);\n }\n }\n if (m.msgs && m.msgs.length) {\n d.msgs = [];\n for (var j = 0; j < m.msgs.length; ++j) {\n d.msgs[j] = $root.RPC.Message.toObject(m.msgs[j], o);\n }\n }\n if (m.control != null && m.hasOwnProperty(\"control\")) {\n d.control = $root.RPC.ControlMessage.toObject(m.control, o);\n if (o.oneofs)\n d._control = \"control\";\n }\n return d;\n };\n \n /**\n * Converts this RPC to JSON.\n * @function toJSON\n * @memberof RPC\n * @instance\n * @returns {Object.} JSON object\n */\n RPC.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n RPC.SubOpts = (function() {\n \n /**\n * Properties of a SubOpts.\n * @memberof RPC\n * @interface ISubOpts\n * @property {boolean|null} [subscribe] SubOpts subscribe\n * @property {string|null} [topicID] SubOpts topicID\n */\n \n /**\n * Constructs a new SubOpts.\n * @memberof RPC\n * @classdesc Represents a SubOpts.\n * @implements ISubOpts\n * @constructor\n * @param {RPC.ISubOpts=} [p] Properties to set\n */\n function SubOpts(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * SubOpts subscribe.\n * @member {boolean|null|undefined} subscribe\n * @memberof RPC.SubOpts\n * @instance\n */\n SubOpts.prototype.subscribe = null;\n \n /**\n * SubOpts topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.SubOpts\n * @instance\n */\n SubOpts.prototype.topicID = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * SubOpts _subscribe.\n * @member {\"subscribe\"|undefined} _subscribe\n * @memberof RPC.SubOpts\n * @instance\n */\n Object.defineProperty(SubOpts.prototype, \"_subscribe\", {\n get: $util.oneOfGetter($oneOfFields = [\"subscribe\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * SubOpts _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.SubOpts\n * @instance\n */\n Object.defineProperty(SubOpts.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified SubOpts message. Does not implicitly {@link RPC.SubOpts.verify|verify} messages.\n * @function encode\n * @memberof RPC.SubOpts\n * @static\n * @param {RPC.ISubOpts} m SubOpts message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n SubOpts.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.subscribe != null && Object.hasOwnProperty.call(m, \"subscribe\"))\n w.uint32(8).bool(m.subscribe);\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(18).string(m.topicID);\n return w;\n };\n \n /**\n * Decodes a SubOpts message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.SubOpts\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.SubOpts} SubOpts\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n SubOpts.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.SubOpts();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.subscribe = r.bool();\n break;\n case 2:\n m.topicID = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a SubOpts message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.SubOpts\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.SubOpts} SubOpts\n */\n SubOpts.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.SubOpts)\n return d;\n var m = new $root.RPC.SubOpts();\n if (d.subscribe != null) {\n m.subscribe = Boolean(d.subscribe);\n }\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n return m;\n };\n \n /**\n * Creates a plain object from a SubOpts message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.SubOpts\n * @static\n * @param {RPC.SubOpts} m SubOpts\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n SubOpts.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.subscribe != null && m.hasOwnProperty(\"subscribe\")) {\n d.subscribe = m.subscribe;\n if (o.oneofs)\n d._subscribe = \"subscribe\";\n }\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n return d;\n };\n \n /**\n * Converts this SubOpts to JSON.\n * @function toJSON\n * @memberof RPC.SubOpts\n * @instance\n * @returns {Object.} JSON object\n */\n SubOpts.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return SubOpts;\n })();\n \n RPC.Message = (function() {\n \n /**\n * Properties of a Message.\n * @memberof RPC\n * @interface IMessage\n * @property {Uint8Array|null} [from] Message from\n * @property {Uint8Array|null} [data] Message data\n * @property {Uint8Array|null} [seqno] Message seqno\n * @property {Array.|null} [topicIDs] Message topicIDs\n * @property {Uint8Array|null} [signature] Message signature\n * @property {Uint8Array|null} [key] Message key\n */\n \n /**\n * Constructs a new Message.\n * @memberof RPC\n * @classdesc Represents a Message.\n * @implements IMessage\n * @constructor\n * @param {RPC.IMessage=} [p] Properties to set\n */\n function Message(p) {\n this.topicIDs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * Message from.\n * @member {Uint8Array|null|undefined} from\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.from = null;\n \n /**\n * Message data.\n * @member {Uint8Array|null|undefined} data\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.data = null;\n \n /**\n * Message seqno.\n * @member {Uint8Array|null|undefined} seqno\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.seqno = null;\n \n /**\n * Message topicIDs.\n * @member {Array.} topicIDs\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.topicIDs = $util.emptyArray;\n \n /**\n * Message signature.\n * @member {Uint8Array|null|undefined} signature\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.signature = null;\n \n /**\n * Message key.\n * @member {Uint8Array|null|undefined} key\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.key = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * Message _from.\n * @member {\"from\"|undefined} _from\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_from\", {\n get: $util.oneOfGetter($oneOfFields = [\"from\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Message _data.\n * @member {\"data\"|undefined} _data\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_data\", {\n get: $util.oneOfGetter($oneOfFields = [\"data\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Message _seqno.\n * @member {\"seqno\"|undefined} _seqno\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_seqno\", {\n get: $util.oneOfGetter($oneOfFields = [\"seqno\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Message _signature.\n * @member {\"signature\"|undefined} _signature\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_signature\", {\n get: $util.oneOfGetter($oneOfFields = [\"signature\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Message _key.\n * @member {\"key\"|undefined} _key\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_key\", {\n get: $util.oneOfGetter($oneOfFields = [\"key\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified Message message. Does not implicitly {@link RPC.Message.verify|verify} messages.\n * @function encode\n * @memberof RPC.Message\n * @static\n * @param {RPC.IMessage} m Message message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Message.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.from != null && Object.hasOwnProperty.call(m, \"from\"))\n w.uint32(10).bytes(m.from);\n if (m.data != null && Object.hasOwnProperty.call(m, \"data\"))\n w.uint32(18).bytes(m.data);\n if (m.seqno != null && Object.hasOwnProperty.call(m, \"seqno\"))\n w.uint32(26).bytes(m.seqno);\n if (m.topicIDs != null && m.topicIDs.length) {\n for (var i = 0; i < m.topicIDs.length; ++i)\n w.uint32(34).string(m.topicIDs[i]);\n }\n if (m.signature != null && Object.hasOwnProperty.call(m, \"signature\"))\n w.uint32(42).bytes(m.signature);\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(50).bytes(m.key);\n return w;\n };\n \n /**\n * Decodes a Message message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.Message\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.Message} Message\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Message.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.Message();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.from = r.bytes();\n break;\n case 2:\n m.data = r.bytes();\n break;\n case 3:\n m.seqno = r.bytes();\n break;\n case 4:\n if (!(m.topicIDs && m.topicIDs.length))\n m.topicIDs = [];\n m.topicIDs.push(r.string());\n break;\n case 5:\n m.signature = r.bytes();\n break;\n case 6:\n m.key = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a Message message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.Message\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.Message} Message\n */\n Message.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.Message)\n return d;\n var m = new $root.RPC.Message();\n if (d.from != null) {\n if (typeof d.from === \"string\")\n $util.base64.decode(d.from, m.from = $util.newBuffer($util.base64.length(d.from)), 0);\n else if (d.from.length)\n m.from = d.from;\n }\n if (d.data != null) {\n if (typeof d.data === \"string\")\n $util.base64.decode(d.data, m.data = $util.newBuffer($util.base64.length(d.data)), 0);\n else if (d.data.length)\n m.data = d.data;\n }\n if (d.seqno != null) {\n if (typeof d.seqno === \"string\")\n $util.base64.decode(d.seqno, m.seqno = $util.newBuffer($util.base64.length(d.seqno)), 0);\n else if (d.seqno.length)\n m.seqno = d.seqno;\n }\n if (d.topicIDs) {\n if (!Array.isArray(d.topicIDs))\n throw TypeError(\".RPC.Message.topicIDs: array expected\");\n m.topicIDs = [];\n for (var i = 0; i < d.topicIDs.length; ++i) {\n m.topicIDs[i] = String(d.topicIDs[i]);\n }\n }\n if (d.signature != null) {\n if (typeof d.signature === \"string\")\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n return m;\n };\n \n /**\n * Creates a plain object from a Message message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.Message\n * @static\n * @param {RPC.Message} m Message\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Message.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.topicIDs = [];\n }\n if (m.from != null && m.hasOwnProperty(\"from\")) {\n d.from = o.bytes === String ? $util.base64.encode(m.from, 0, m.from.length) : o.bytes === Array ? Array.prototype.slice.call(m.from) : m.from;\n if (o.oneofs)\n d._from = \"from\";\n }\n if (m.data != null && m.hasOwnProperty(\"data\")) {\n d.data = o.bytes === String ? $util.base64.encode(m.data, 0, m.data.length) : o.bytes === Array ? Array.prototype.slice.call(m.data) : m.data;\n if (o.oneofs)\n d._data = \"data\";\n }\n if (m.seqno != null && m.hasOwnProperty(\"seqno\")) {\n d.seqno = o.bytes === String ? $util.base64.encode(m.seqno, 0, m.seqno.length) : o.bytes === Array ? Array.prototype.slice.call(m.seqno) : m.seqno;\n if (o.oneofs)\n d._seqno = \"seqno\";\n }\n if (m.topicIDs && m.topicIDs.length) {\n d.topicIDs = [];\n for (var j = 0; j < m.topicIDs.length; ++j) {\n d.topicIDs[j] = m.topicIDs[j];\n }\n }\n if (m.signature != null && m.hasOwnProperty(\"signature\")) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n if (o.oneofs)\n d._signature = \"signature\";\n }\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n if (o.oneofs)\n d._key = \"key\";\n }\n return d;\n };\n \n /**\n * Converts this Message to JSON.\n * @function toJSON\n * @memberof RPC.Message\n * @instance\n * @returns {Object.} JSON object\n */\n Message.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return Message;\n })();\n \n RPC.ControlMessage = (function() {\n \n /**\n * Properties of a ControlMessage.\n * @memberof RPC\n * @interface IControlMessage\n * @property {Array.|null} [ihave] ControlMessage ihave\n * @property {Array.|null} [iwant] ControlMessage iwant\n * @property {Array.|null} [graft] ControlMessage graft\n * @property {Array.|null} [prune] ControlMessage prune\n */\n \n /**\n * Constructs a new ControlMessage.\n * @memberof RPC\n * @classdesc Represents a ControlMessage.\n * @implements IControlMessage\n * @constructor\n * @param {RPC.IControlMessage=} [p] Properties to set\n */\n function ControlMessage(p) {\n this.ihave = [];\n this.iwant = [];\n this.graft = [];\n this.prune = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlMessage ihave.\n * @member {Array.} ihave\n * @memberof RPC.ControlMessage\n * @instance\n */\n ControlMessage.prototype.ihave = $util.emptyArray;\n \n /**\n * ControlMessage iwant.\n * @member {Array.} iwant\n * @memberof RPC.ControlMessage\n * @instance\n */\n ControlMessage.prototype.iwant = $util.emptyArray;\n \n /**\n * ControlMessage graft.\n * @member {Array.} graft\n * @memberof RPC.ControlMessage\n * @instance\n */\n ControlMessage.prototype.graft = $util.emptyArray;\n \n /**\n * ControlMessage prune.\n * @member {Array.} prune\n * @memberof RPC.ControlMessage\n * @instance\n */\n ControlMessage.prototype.prune = $util.emptyArray;\n \n /**\n * Encodes the specified ControlMessage message. Does not implicitly {@link RPC.ControlMessage.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlMessage\n * @static\n * @param {RPC.IControlMessage} m ControlMessage message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlMessage.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.ihave != null && m.ihave.length) {\n for (var i = 0; i < m.ihave.length; ++i)\n $root.RPC.ControlIHave.encode(m.ihave[i], w.uint32(10).fork()).ldelim();\n }\n if (m.iwant != null && m.iwant.length) {\n for (var i = 0; i < m.iwant.length; ++i)\n $root.RPC.ControlIWant.encode(m.iwant[i], w.uint32(18).fork()).ldelim();\n }\n if (m.graft != null && m.graft.length) {\n for (var i = 0; i < m.graft.length; ++i)\n $root.RPC.ControlGraft.encode(m.graft[i], w.uint32(26).fork()).ldelim();\n }\n if (m.prune != null && m.prune.length) {\n for (var i = 0; i < m.prune.length; ++i)\n $root.RPC.ControlPrune.encode(m.prune[i], w.uint32(34).fork()).ldelim();\n }\n return w;\n };\n \n /**\n * Decodes a ControlMessage message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlMessage\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlMessage} ControlMessage\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlMessage.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlMessage();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.ihave && m.ihave.length))\n m.ihave = [];\n m.ihave.push($root.RPC.ControlIHave.decode(r, r.uint32()));\n break;\n case 2:\n if (!(m.iwant && m.iwant.length))\n m.iwant = [];\n m.iwant.push($root.RPC.ControlIWant.decode(r, r.uint32()));\n break;\n case 3:\n if (!(m.graft && m.graft.length))\n m.graft = [];\n m.graft.push($root.RPC.ControlGraft.decode(r, r.uint32()));\n break;\n case 4:\n if (!(m.prune && m.prune.length))\n m.prune = [];\n m.prune.push($root.RPC.ControlPrune.decode(r, r.uint32()));\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlMessage message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlMessage\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.ControlMessage} ControlMessage\n */\n ControlMessage.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlMessage)\n return d;\n var m = new $root.RPC.ControlMessage();\n if (d.ihave) {\n if (!Array.isArray(d.ihave))\n throw TypeError(\".RPC.ControlMessage.ihave: array expected\");\n m.ihave = [];\n for (var i = 0; i < d.ihave.length; ++i) {\n if (typeof d.ihave[i] !== \"object\")\n throw TypeError(\".RPC.ControlMessage.ihave: object expected\");\n m.ihave[i] = $root.RPC.ControlIHave.fromObject(d.ihave[i]);\n }\n }\n if (d.iwant) {\n if (!Array.isArray(d.iwant))\n throw TypeError(\".RPC.ControlMessage.iwant: array expected\");\n m.iwant = [];\n for (var i = 0; i < d.iwant.length; ++i) {\n if (typeof d.iwant[i] !== \"object\")\n throw TypeError(\".RPC.ControlMessage.iwant: object expected\");\n m.iwant[i] = $root.RPC.ControlIWant.fromObject(d.iwant[i]);\n }\n }\n if (d.graft) {\n if (!Array.isArray(d.graft))\n throw TypeError(\".RPC.ControlMessage.graft: array expected\");\n m.graft = [];\n for (var i = 0; i < d.graft.length; ++i) {\n if (typeof d.graft[i] !== \"object\")\n throw TypeError(\".RPC.ControlMessage.graft: object expected\");\n m.graft[i] = $root.RPC.ControlGraft.fromObject(d.graft[i]);\n }\n }\n if (d.prune) {\n if (!Array.isArray(d.prune))\n throw TypeError(\".RPC.ControlMessage.prune: array expected\");\n m.prune = [];\n for (var i = 0; i < d.prune.length; ++i) {\n if (typeof d.prune[i] !== \"object\")\n throw TypeError(\".RPC.ControlMessage.prune: object expected\");\n m.prune[i] = $root.RPC.ControlPrune.fromObject(d.prune[i]);\n }\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlMessage message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlMessage\n * @static\n * @param {RPC.ControlMessage} m ControlMessage\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n ControlMessage.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.ihave = [];\n d.iwant = [];\n d.graft = [];\n d.prune = [];\n }\n if (m.ihave && m.ihave.length) {\n d.ihave = [];\n for (var j = 0; j < m.ihave.length; ++j) {\n d.ihave[j] = $root.RPC.ControlIHave.toObject(m.ihave[j], o);\n }\n }\n if (m.iwant && m.iwant.length) {\n d.iwant = [];\n for (var j = 0; j < m.iwant.length; ++j) {\n d.iwant[j] = $root.RPC.ControlIWant.toObject(m.iwant[j], o);\n }\n }\n if (m.graft && m.graft.length) {\n d.graft = [];\n for (var j = 0; j < m.graft.length; ++j) {\n d.graft[j] = $root.RPC.ControlGraft.toObject(m.graft[j], o);\n }\n }\n if (m.prune && m.prune.length) {\n d.prune = [];\n for (var j = 0; j < m.prune.length; ++j) {\n d.prune[j] = $root.RPC.ControlPrune.toObject(m.prune[j], o);\n }\n }\n return d;\n };\n \n /**\n * Converts this ControlMessage to JSON.\n * @function toJSON\n * @memberof RPC.ControlMessage\n * @instance\n * @returns {Object.} JSON object\n */\n ControlMessage.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlMessage;\n })();\n \n RPC.ControlIHave = (function() {\n \n /**\n * Properties of a ControlIHave.\n * @memberof RPC\n * @interface IControlIHave\n * @property {string|null} [topicID] ControlIHave topicID\n * @property {Array.|null} [messageIDs] ControlIHave messageIDs\n */\n \n /**\n * Constructs a new ControlIHave.\n * @memberof RPC\n * @classdesc Represents a ControlIHave.\n * @implements IControlIHave\n * @constructor\n * @param {RPC.IControlIHave=} [p] Properties to set\n */\n function ControlIHave(p) {\n this.messageIDs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlIHave topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.ControlIHave\n * @instance\n */\n ControlIHave.prototype.topicID = null;\n \n /**\n * ControlIHave messageIDs.\n * @member {Array.} messageIDs\n * @memberof RPC.ControlIHave\n * @instance\n */\n ControlIHave.prototype.messageIDs = $util.emptyArray;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * ControlIHave _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.ControlIHave\n * @instance\n */\n Object.defineProperty(ControlIHave.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified ControlIHave message. Does not implicitly {@link RPC.ControlIHave.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlIHave\n * @static\n * @param {RPC.IControlIHave} m ControlIHave message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlIHave.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(10).string(m.topicID);\n if (m.messageIDs != null && m.messageIDs.length) {\n for (var i = 0; i < m.messageIDs.length; ++i)\n w.uint32(18).bytes(m.messageIDs[i]);\n }\n return w;\n };\n \n /**\n * Decodes a ControlIHave message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlIHave\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlIHave} ControlIHave\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlIHave.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlIHave();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.topicID = r.string();\n break;\n case 2:\n if (!(m.messageIDs && m.messageIDs.length))\n m.messageIDs = [];\n m.messageIDs.push(r.bytes());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlIHave message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlIHave\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.ControlIHave} ControlIHave\n */\n ControlIHave.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlIHave)\n return d;\n var m = new $root.RPC.ControlIHave();\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n if (d.messageIDs) {\n if (!Array.isArray(d.messageIDs))\n throw TypeError(\".RPC.ControlIHave.messageIDs: array expected\");\n m.messageIDs = [];\n for (var i = 0; i < d.messageIDs.length; ++i) {\n if (typeof d.messageIDs[i] === \"string\")\n $util.base64.decode(d.messageIDs[i], m.messageIDs[i] = $util.newBuffer($util.base64.length(d.messageIDs[i])), 0);\n else if (d.messageIDs[i].length)\n m.messageIDs[i] = d.messageIDs[i];\n }\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlIHave message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlIHave\n * @static\n * @param {RPC.ControlIHave} m ControlIHave\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n ControlIHave.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.messageIDs = [];\n }\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n if (m.messageIDs && m.messageIDs.length) {\n d.messageIDs = [];\n for (var j = 0; j < m.messageIDs.length; ++j) {\n d.messageIDs[j] = o.bytes === String ? $util.base64.encode(m.messageIDs[j], 0, m.messageIDs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.messageIDs[j]) : m.messageIDs[j];\n }\n }\n return d;\n };\n \n /**\n * Converts this ControlIHave to JSON.\n * @function toJSON\n * @memberof RPC.ControlIHave\n * @instance\n * @returns {Object.} JSON object\n */\n ControlIHave.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlIHave;\n })();\n \n RPC.ControlIWant = (function() {\n \n /**\n * Properties of a ControlIWant.\n * @memberof RPC\n * @interface IControlIWant\n * @property {Array.|null} [messageIDs] ControlIWant messageIDs\n */\n \n /**\n * Constructs a new ControlIWant.\n * @memberof RPC\n * @classdesc Represents a ControlIWant.\n * @implements IControlIWant\n * @constructor\n * @param {RPC.IControlIWant=} [p] Properties to set\n */\n function ControlIWant(p) {\n this.messageIDs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlIWant messageIDs.\n * @member {Array.} messageIDs\n * @memberof RPC.ControlIWant\n * @instance\n */\n ControlIWant.prototype.messageIDs = $util.emptyArray;\n \n /**\n * Encodes the specified ControlIWant message. Does not implicitly {@link RPC.ControlIWant.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlIWant\n * @static\n * @param {RPC.IControlIWant} m ControlIWant message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlIWant.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.messageIDs != null && m.messageIDs.length) {\n for (var i = 0; i < m.messageIDs.length; ++i)\n w.uint32(10).bytes(m.messageIDs[i]);\n }\n return w;\n };\n \n /**\n * Decodes a ControlIWant message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlIWant\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlIWant} ControlIWant\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlIWant.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlIWant();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.messageIDs && m.messageIDs.length))\n m.messageIDs = [];\n m.messageIDs.push(r.bytes());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlIWant message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlIWant\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.ControlIWant} ControlIWant\n */\n ControlIWant.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlIWant)\n return d;\n var m = new $root.RPC.ControlIWant();\n if (d.messageIDs) {\n if (!Array.isArray(d.messageIDs))\n throw TypeError(\".RPC.ControlIWant.messageIDs: array expected\");\n m.messageIDs = [];\n for (var i = 0; i < d.messageIDs.length; ++i) {\n if (typeof d.messageIDs[i] === \"string\")\n $util.base64.decode(d.messageIDs[i], m.messageIDs[i] = $util.newBuffer($util.base64.length(d.messageIDs[i])), 0);\n else if (d.messageIDs[i].length)\n m.messageIDs[i] = d.messageIDs[i];\n }\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlIWant message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlIWant\n * @static\n * @param {RPC.ControlIWant} m ControlIWant\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n ControlIWant.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.messageIDs = [];\n }\n if (m.messageIDs && m.messageIDs.length) {\n d.messageIDs = [];\n for (var j = 0; j < m.messageIDs.length; ++j) {\n d.messageIDs[j] = o.bytes === String ? $util.base64.encode(m.messageIDs[j], 0, m.messageIDs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.messageIDs[j]) : m.messageIDs[j];\n }\n }\n return d;\n };\n \n /**\n * Converts this ControlIWant to JSON.\n * @function toJSON\n * @memberof RPC.ControlIWant\n * @instance\n * @returns {Object.} JSON object\n */\n ControlIWant.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlIWant;\n })();\n \n RPC.ControlGraft = (function() {\n \n /**\n * Properties of a ControlGraft.\n * @memberof RPC\n * @interface IControlGraft\n * @property {string|null} [topicID] ControlGraft topicID\n */\n \n /**\n * Constructs a new ControlGraft.\n * @memberof RPC\n * @classdesc Represents a ControlGraft.\n * @implements IControlGraft\n * @constructor\n * @param {RPC.IControlGraft=} [p] Properties to set\n */\n function ControlGraft(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlGraft topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.ControlGraft\n * @instance\n */\n ControlGraft.prototype.topicID = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * ControlGraft _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.ControlGraft\n * @instance\n */\n Object.defineProperty(ControlGraft.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified ControlGraft message. Does not implicitly {@link RPC.ControlGraft.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlGraft\n * @static\n * @param {RPC.IControlGraft} m ControlGraft message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlGraft.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(10).string(m.topicID);\n return w;\n };\n \n /**\n * Decodes a ControlGraft message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlGraft\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlGraft} ControlGraft\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlGraft.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlGraft();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.topicID = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlGraft message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlGraft\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.ControlGraft} ControlGraft\n */\n ControlGraft.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlGraft)\n return d;\n var m = new $root.RPC.ControlGraft();\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlGraft message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlGraft\n * @static\n * @param {RPC.ControlGraft} m ControlGraft\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n ControlGraft.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n return d;\n };\n \n /**\n * Converts this ControlGraft to JSON.\n * @function toJSON\n * @memberof RPC.ControlGraft\n * @instance\n * @returns {Object.} JSON object\n */\n ControlGraft.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlGraft;\n })();\n \n RPC.ControlPrune = (function() {\n \n /**\n * Properties of a ControlPrune.\n * @memberof RPC\n * @interface IControlPrune\n * @property {string|null} [topicID] ControlPrune topicID\n * @property {Array.|null} [peers] ControlPrune peers\n * @property {number|null} [backoff] ControlPrune backoff\n */\n \n /**\n * Constructs a new ControlPrune.\n * @memberof RPC\n * @classdesc Represents a ControlPrune.\n * @implements IControlPrune\n * @constructor\n * @param {RPC.IControlPrune=} [p] Properties to set\n */\n function ControlPrune(p) {\n this.peers = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlPrune topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.ControlPrune\n * @instance\n */\n ControlPrune.prototype.topicID = null;\n \n /**\n * ControlPrune peers.\n * @member {Array.} peers\n * @memberof RPC.ControlPrune\n * @instance\n */\n ControlPrune.prototype.peers = $util.emptyArray;\n \n /**\n * ControlPrune backoff.\n * @member {number|null|undefined} backoff\n * @memberof RPC.ControlPrune\n * @instance\n */\n ControlPrune.prototype.backoff = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * ControlPrune _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.ControlPrune\n * @instance\n */\n Object.defineProperty(ControlPrune.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * ControlPrune _backoff.\n * @member {\"backoff\"|undefined} _backoff\n * @memberof RPC.ControlPrune\n * @instance\n */\n Object.defineProperty(ControlPrune.prototype, \"_backoff\", {\n get: $util.oneOfGetter($oneOfFields = [\"backoff\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified ControlPrune message. Does not implicitly {@link RPC.ControlPrune.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlPrune\n * @static\n * @param {RPC.IControlPrune} m ControlPrune message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlPrune.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(10).string(m.topicID);\n if (m.peers != null && m.peers.length) {\n for (var i = 0; i < m.peers.length; ++i)\n $root.RPC.PeerInfo.encode(m.peers[i], w.uint32(18).fork()).ldelim();\n }\n if (m.backoff != null && Object.hasOwnProperty.call(m, \"backoff\"))\n w.uint32(24).uint64(m.backoff);\n return w;\n };\n \n /**\n * Decodes a ControlPrune message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlPrune\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlPrune} ControlPrune\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlPrune.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlPrune();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.topicID = r.string();\n break;\n case 2:\n if (!(m.peers && m.peers.length))\n m.peers = [];\n m.peers.push($root.RPC.PeerInfo.decode(r, r.uint32()));\n break;\n case 3:\n m.backoff = r.uint64();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlPrune message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlPrune\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.ControlPrune} ControlPrune\n */\n ControlPrune.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlPrune)\n return d;\n var m = new $root.RPC.ControlPrune();\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n if (d.peers) {\n if (!Array.isArray(d.peers))\n throw TypeError(\".RPC.ControlPrune.peers: array expected\");\n m.peers = [];\n for (var i = 0; i < d.peers.length; ++i) {\n if (typeof d.peers[i] !== \"object\")\n throw TypeError(\".RPC.ControlPrune.peers: object expected\");\n m.peers[i] = $root.RPC.PeerInfo.fromObject(d.peers[i]);\n }\n }\n if (d.backoff != null) {\n if ($util.Long)\n (m.backoff = $util.Long.fromValue(d.backoff)).unsigned = true;\n else if (typeof d.backoff === \"string\")\n m.backoff = parseInt(d.backoff, 10);\n else if (typeof d.backoff === \"number\")\n m.backoff = d.backoff;\n else if (typeof d.backoff === \"object\")\n m.backoff = new $util.LongBits(d.backoff.low >>> 0, d.backoff.high >>> 0).toNumber(true);\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlPrune message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlPrune\n * @static\n * @param {RPC.ControlPrune} m ControlPrune\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n ControlPrune.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.peers = [];\n }\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n if (m.peers && m.peers.length) {\n d.peers = [];\n for (var j = 0; j < m.peers.length; ++j) {\n d.peers[j] = $root.RPC.PeerInfo.toObject(m.peers[j], o);\n }\n }\n if (m.backoff != null && m.hasOwnProperty(\"backoff\")) {\n if (typeof m.backoff === \"number\")\n d.backoff = o.longs === String ? String(m.backoff) : m.backoff;\n else\n d.backoff = o.longs === String ? $util.Long.prototype.toString.call(m.backoff) : o.longs === Number ? new $util.LongBits(m.backoff.low >>> 0, m.backoff.high >>> 0).toNumber(true) : m.backoff;\n if (o.oneofs)\n d._backoff = \"backoff\";\n }\n return d;\n };\n \n /**\n * Converts this ControlPrune to JSON.\n * @function toJSON\n * @memberof RPC.ControlPrune\n * @instance\n * @returns {Object.} JSON object\n */\n ControlPrune.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlPrune;\n })();\n \n RPC.PeerInfo = (function() {\n \n /**\n * Properties of a PeerInfo.\n * @memberof RPC\n * @interface IPeerInfo\n * @property {Uint8Array|null} [peerID] PeerInfo peerID\n * @property {Uint8Array|null} [signedPeerRecord] PeerInfo signedPeerRecord\n */\n \n /**\n * Constructs a new PeerInfo.\n * @memberof RPC\n * @classdesc Represents a PeerInfo.\n * @implements IPeerInfo\n * @constructor\n * @param {RPC.IPeerInfo=} [p] Properties to set\n */\n function PeerInfo(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * PeerInfo peerID.\n * @member {Uint8Array|null|undefined} peerID\n * @memberof RPC.PeerInfo\n * @instance\n */\n PeerInfo.prototype.peerID = null;\n \n /**\n * PeerInfo signedPeerRecord.\n * @member {Uint8Array|null|undefined} signedPeerRecord\n * @memberof RPC.PeerInfo\n * @instance\n */\n PeerInfo.prototype.signedPeerRecord = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * PeerInfo _peerID.\n * @member {\"peerID\"|undefined} _peerID\n * @memberof RPC.PeerInfo\n * @instance\n */\n Object.defineProperty(PeerInfo.prototype, \"_peerID\", {\n get: $util.oneOfGetter($oneOfFields = [\"peerID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * PeerInfo _signedPeerRecord.\n * @member {\"signedPeerRecord\"|undefined} _signedPeerRecord\n * @memberof RPC.PeerInfo\n * @instance\n */\n Object.defineProperty(PeerInfo.prototype, \"_signedPeerRecord\", {\n get: $util.oneOfGetter($oneOfFields = [\"signedPeerRecord\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified PeerInfo message. Does not implicitly {@link RPC.PeerInfo.verify|verify} messages.\n * @function encode\n * @memberof RPC.PeerInfo\n * @static\n * @param {RPC.IPeerInfo} m PeerInfo message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PeerInfo.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.peerID != null && Object.hasOwnProperty.call(m, \"peerID\"))\n w.uint32(10).bytes(m.peerID);\n if (m.signedPeerRecord != null && Object.hasOwnProperty.call(m, \"signedPeerRecord\"))\n w.uint32(18).bytes(m.signedPeerRecord);\n return w;\n };\n \n /**\n * Decodes a PeerInfo message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.PeerInfo\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.PeerInfo} PeerInfo\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PeerInfo.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.PeerInfo();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.peerID = r.bytes();\n break;\n case 2:\n m.signedPeerRecord = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a PeerInfo message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.PeerInfo\n * @static\n * @param {Object.} d Plain object\n * @returns {RPC.PeerInfo} PeerInfo\n */\n PeerInfo.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.PeerInfo)\n return d;\n var m = new $root.RPC.PeerInfo();\n if (d.peerID != null) {\n if (typeof d.peerID === \"string\")\n $util.base64.decode(d.peerID, m.peerID = $util.newBuffer($util.base64.length(d.peerID)), 0);\n else if (d.peerID.length)\n m.peerID = d.peerID;\n }\n if (d.signedPeerRecord != null) {\n if (typeof d.signedPeerRecord === \"string\")\n $util.base64.decode(d.signedPeerRecord, m.signedPeerRecord = $util.newBuffer($util.base64.length(d.signedPeerRecord)), 0);\n else if (d.signedPeerRecord.length)\n m.signedPeerRecord = d.signedPeerRecord;\n }\n return m;\n };\n \n /**\n * Creates a plain object from a PeerInfo message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.PeerInfo\n * @static\n * @param {RPC.PeerInfo} m PeerInfo\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n PeerInfo.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.peerID != null && m.hasOwnProperty(\"peerID\")) {\n d.peerID = o.bytes === String ? $util.base64.encode(m.peerID, 0, m.peerID.length) : o.bytes === Array ? Array.prototype.slice.call(m.peerID) : m.peerID;\n if (o.oneofs)\n d._peerID = \"peerID\";\n }\n if (m.signedPeerRecord != null && m.hasOwnProperty(\"signedPeerRecord\")) {\n d.signedPeerRecord = o.bytes === String ? $util.base64.encode(m.signedPeerRecord, 0, m.signedPeerRecord.length) : o.bytes === Array ? Array.prototype.slice.call(m.signedPeerRecord) : m.signedPeerRecord;\n if (o.oneofs)\n d._signedPeerRecord = \"signedPeerRecord\";\n }\n return d;\n };\n \n /**\n * Converts this PeerInfo to JSON.\n * @function toJSON\n * @memberof RPC.PeerInfo\n * @instance\n * @returns {Object.} JSON object\n */\n PeerInfo.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return PeerInfo;\n })();\n \n return RPC;\n })();\n\n return $root;\n});\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Heartbeat = void 0;\nconst constants = __importStar(require(\"./constants\"));\nconst get_gossip_peers_1 = require(\"./get-gossip-peers\");\nconst utils_1 = require(\"./utils\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\nclass Heartbeat {\n /**\n * @param {Object} gossipsub\n * @constructor\n */\n constructor(gossipsub) {\n this.gossipsub = gossipsub;\n }\n start() {\n if (this._heartbeatTimer) {\n return;\n }\n const heartbeat = this._heartbeat.bind(this);\n const timeout = setTimeout(() => {\n heartbeat();\n this._heartbeatTimer.runPeriodically(heartbeat, this.gossipsub._options.heartbeatInterval);\n }, constants.GossipsubHeartbeatInitialDelay);\n this._heartbeatTimer = {\n _intervalId: undefined,\n runPeriodically: (fn, period) => {\n this._heartbeatTimer._intervalId = setInterval(fn, period);\n },\n cancel: () => {\n clearTimeout(timeout);\n clearInterval(this._heartbeatTimer._intervalId);\n }\n };\n }\n /**\n * Unmounts the gossipsub protocol and shuts down every connection\n * @override\n * @returns {void}\n */\n stop() {\n if (!this._heartbeatTimer) {\n return;\n }\n this._heartbeatTimer.cancel();\n this._heartbeatTimer = null;\n }\n /**\n * Maintains the mesh and fanout maps in gossipsub.\n *\n * @returns {void}\n */\n _heartbeat() {\n const { D, Dlo, Dhi, Dscore, Dout, fanoutTTL } = this.gossipsub._options;\n this.gossipsub.heartbeatTicks++;\n // cache scores throught the heartbeat\n const scores = new Map();\n const getScore = (id) => {\n let s = scores.get(id);\n if (s === undefined) {\n s = this.gossipsub.score.score(id);\n scores.set(id, s);\n }\n return s;\n };\n // peer id => topic[]\n const tograft = new Map();\n // peer id => topic[]\n const toprune = new Map();\n // peer id => don't px\n const noPX = new Map();\n // clean up expired backoffs\n this.gossipsub._clearBackoff();\n // clean up peerhave/iasked counters\n this.gossipsub.peerhave.clear();\n this.gossipsub.iasked.clear();\n // apply IWANT request penalties\n this.gossipsub._applyIwantPenalties();\n // ensure direct peers are connected\n this.gossipsub._directConnect();\n // maintain the mesh for topics we have joined\n this.gossipsub.mesh.forEach((peers, topic) => {\n // prune/graft helper functions (defined per topic)\n const prunePeer = (id) => {\n this.gossipsub.log('HEARTBEAT: Remove mesh link to %s in %s', id, topic);\n // update peer score\n this.gossipsub.score.prune(id, topic);\n // add prune backoff record\n this.gossipsub._addBackoff(id, topic);\n // remove peer from mesh\n peers.delete(id);\n // add to toprune\n const topics = toprune.get(id);\n if (!topics) {\n toprune.set(id, [topic]);\n }\n else {\n topics.push(topic);\n }\n };\n const graftPeer = (id) => {\n this.gossipsub.log('HEARTBEAT: Add mesh link to %s in %s', id, topic);\n // update peer score\n this.gossipsub.score.graft(id, topic);\n // add peer to mesh\n peers.add(id);\n // add to tograft\n const topics = tograft.get(id);\n if (!topics) {\n tograft.set(id, [topic]);\n }\n else {\n topics.push(topic);\n }\n };\n // drop all peers with negative score, without PX\n peers.forEach(id => {\n const score = getScore(id);\n if (score < 0) {\n this.gossipsub.log('HEARTBEAT: Prune peer %s with negative score: score=%d, topic=%s', id, score, topic);\n prunePeer(id);\n noPX.set(id, true);\n }\n });\n // do we have enough peers?\n if (peers.size < Dlo) {\n const backoff = this.gossipsub.backoff.get(topic);\n const ineed = D - peers.size;\n const peersSet = get_gossip_peers_1.getGossipPeers(this.gossipsub, topic, ineed, id => {\n // filter out mesh peers, direct peers, peers we are backing off, peers with negative score\n return !peers.has(id) && !this.gossipsub.direct.has(id) && (!backoff || !backoff.has(id)) && getScore(id) >= 0;\n });\n peersSet.forEach(graftPeer);\n }\n // do we have to many peers?\n if (peers.size > Dhi) {\n let peersArray = Array.from(peers);\n // sort by score\n peersArray.sort((a, b) => getScore(b) - getScore(a));\n // We keep the first D_score peers by score and the remaining up to D randomly\n // under the constraint that we keep D_out peers in the mesh (if we have that many)\n peersArray = peersArray.slice(0, Dscore).concat(utils_1.shuffle(peersArray.slice(Dscore)));\n // count the outbound peers we are keeping\n let outbound = 0;\n peersArray.slice(0, D).forEach(p => {\n if (this.gossipsub.outbound.get(p)) {\n outbound++;\n }\n });\n // if it's less than D_out, bubble up some outbound peers from the random selection\n if (outbound < Dout) {\n const rotate = (i) => {\n // rotate the peersArray to the right and put the ith peer in the front\n const p = peersArray[i];\n for (let j = i; j > 0; j--) {\n peersArray[j] = peersArray[j - 1];\n }\n peersArray[0] = p;\n };\n // first bubble up all outbound peers already in the selection to the front\n if (outbound > 0) {\n let ihave = outbound;\n for (let i = 1; i < D && ihave > 0; i++) {\n if (this.gossipsub.outbound.get(peersArray[i])) {\n rotate(i);\n ihave--;\n }\n }\n }\n // now bubble up enough outbound peers outside the selection to the front\n let ineed = D - outbound;\n for (let i = D; i < peersArray.length && ineed > 0; i++) {\n if (this.gossipsub.outbound.get(peersArray[i])) {\n rotate(i);\n ineed--;\n }\n }\n }\n // prune the excess peers\n peersArray.slice(D).forEach(prunePeer);\n }\n // do we have enough outbound peers?\n if (peers.size >= Dlo) {\n // count the outbound peers we have\n let outbound = 0;\n peers.forEach(p => {\n if (this.gossipsub.outbound.get(p)) {\n outbound++;\n }\n });\n // if it's less than D_out, select some peers with outbound connections and graft them\n if (outbound < Dout) {\n const ineed = Dout - outbound;\n const backoff = this.gossipsub.backoff.get(topic);\n get_gossip_peers_1.getGossipPeers(this.gossipsub, topic, ineed, (id) => {\n // filter our current mesh peers, direct peers, peers we are backing off, peers with negative score\n return !peers.has(id) && !this.gossipsub.direct.has(id) && (!backoff || !backoff.has(id)) && getScore(id) >= 0;\n }).forEach(graftPeer);\n }\n }\n // should we try to improve the mesh with opportunistic grafting?\n if (this.gossipsub.heartbeatTicks % constants.GossipsubOpportunisticGraftTicks === 0 && peers.size > 1) {\n // Opportunistic grafting works as follows: we check the median score of peers in the\n // mesh; if this score is below the opportunisticGraftThreshold, we select a few peers at\n // random with score over the median.\n // The intention is to (slowly) improve an underperforming mesh by introducing good\n // scoring peers that may have been gossiping at us. This allows us to get out of sticky\n // situations where we are stuck with poor peers and also recover from churn of good peers.\n // now compute the median peer score in the mesh\n const peersList = Array.from(peers)\n .sort((a, b) => getScore(a) - getScore(b));\n const medianIndex = Math.floor(peers.size / 2);\n const medianScore = getScore(peersList[medianIndex]);\n // if the median score is below the threshold, select a better peer (if any) and GRAFT\n if (medianScore < this.gossipsub._options.scoreThresholds.opportunisticGraftThreshold) {\n const backoff = this.gossipsub.backoff.get(topic);\n const peersToGraft = get_gossip_peers_1.getGossipPeers(this.gossipsub, topic, constants.GossipsubOpportunisticGraftPeers, (id) => {\n // filter out current mesh peers, direct peers, peers we are backing off, peers below or at threshold\n return peers.has(id) && !this.gossipsub.direct.has(id) && (!backoff || !backoff.has(id)) && getScore(id) > medianScore;\n });\n peersToGraft.forEach(id => {\n this.gossipsub.log('HEARTBEAT: Opportunistically graft peer %s on topic %s', id, topic);\n graftPeer(id);\n });\n }\n }\n // 2nd arg are mesh peers excluded from gossip. We have already pushed\n // messages to them, so its redundant to gossip IHAVEs.\n this.gossipsub._emitGossip(topic, peers);\n });\n // expire fanout for topics we haven't published to in a while\n const now = this.gossipsub._now();\n this.gossipsub.lastpub.forEach((lastpb, topic) => {\n if ((lastpb + fanoutTTL) < now) {\n this.gossipsub.fanout.delete(topic);\n this.gossipsub.lastpub.delete(topic);\n }\n });\n // maintain our fanout for topics we are publishing but we have not joined\n this.gossipsub.fanout.forEach((fanoutPeers, topic) => {\n // checks whether our peers are still in the topic and have a score above the publish threshold\n const topicPeers = this.gossipsub.topics.get(topic);\n fanoutPeers.forEach(id => {\n if (!topicPeers.has(id) ||\n getScore(id) < this.gossipsub._options.scoreThresholds.publishThreshold) {\n fanoutPeers.delete(id);\n }\n });\n // do we need more peers?\n if (fanoutPeers.size < D) {\n const ineed = D - fanoutPeers.size;\n const peersSet = get_gossip_peers_1.getGossipPeers(this.gossipsub, topic, ineed, (id) => {\n // filter out existing fanout peers, direct peers, and peers with score above the publish threshold\n return !fanoutPeers.has(id) &&\n !this.gossipsub.direct.has(id) &&\n getScore(id) >= this.gossipsub._options.scoreThresholds.publishThreshold;\n });\n peersSet.forEach(id => {\n fanoutPeers.add(id);\n });\n }\n // 2nd arg are fanout peers excluded from gossip.\n // We have already pushed messages to them, so its redundant to gossip IHAVEs\n this.gossipsub._emitGossip(topic, fanoutPeers);\n });\n // send coalesced GRAFT/PRUNE messages (will piggyback gossip)\n this.gossipsub._sendGraftPrune(tograft, toprune, noPX);\n // flush pending gossip that wasn't piggybacked above\n this.gossipsub._flush();\n // advance the message history window\n this.gossipsub.messageCache.shift();\n this.gossipsub.emit('gossipsub:heartbeat');\n }\n}\nexports.Heartbeat = Heartbeat;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getGossipPeers = void 0;\nconst utils_1 = require(\"./utils\");\n/**\n * Given a topic, returns up to count peers subscribed to that topic\n * that pass an optional filter function\n *\n * @param {Gossipsub} router\n * @param {String} topic\n * @param {Number} count\n * @param {Function} [filter] a function to filter acceptable peers\n * @returns {Set}\n *\n */\nfunction getGossipPeers(router, topic, count, filter = () => true) {\n const peersInTopic = router.topics.get(topic);\n if (!peersInTopic) {\n return new Set();\n }\n // Adds all peers using our protocol\n // that also pass the filter function\n let peers = [];\n peersInTopic.forEach((id) => {\n const peerStreams = router.peers.get(id);\n if (!peerStreams) {\n return;\n }\n if (utils_1.hasGossipProtocol(peerStreams.protocol) &&\n filter(id)) {\n peers.push(id);\n }\n });\n // Pseudo-randomly shuffles peers\n peers = utils_1.shuffle(peers);\n if (count > 0 && peers.length > count) {\n peers = peers.slice(0, count);\n }\n return new Set(peers);\n}\nexports.getGossipPeers = getGossipPeers;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__exportStar(require(\"./peer-score-params\"), exports);\n__exportStar(require(\"./peer-score-thresholds\"), exports);\n__exportStar(require(\"./peer-score\"), exports);\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateTopicScoreParams = exports.validatePeerScoreParams = exports.createTopicScoreParams = exports.createPeerScoreParams = exports.defaultTopicScoreParams = exports.defaultPeerScoreParams = void 0;\nconst constants_1 = require(\"./constants\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst errcode = require(\"err-code\");\nexports.defaultPeerScoreParams = {\n topics: {},\n topicScoreCap: 10,\n appSpecificScore: () => 0,\n appSpecificWeight: 10,\n IPColocationFactorWeight: -5,\n IPColocationFactorThreshold: 10,\n IPColocationFactorWhitelist: new Set(),\n behaviourPenaltyWeight: -10,\n behaviourPenaltyDecay: 0.2,\n decayInterval: 1000,\n decayToZero: 0.1,\n retainScore: 3600 * 1000\n};\nexports.defaultTopicScoreParams = {\n topicWeight: 0.5,\n timeInMeshWeight: 1,\n timeInMeshQuantum: 1,\n timeInMeshCap: 3600,\n firstMessageDeliveriesWeight: 1,\n firstMessageDeliveriesDecay: 0.5,\n firstMessageDeliveriesCap: 2000,\n meshMessageDeliveriesWeight: -1,\n meshMessageDeliveriesDecay: 0.5,\n meshMessageDeliveriesCap: 100,\n meshMessageDeliveriesThreshold: 20,\n meshMessageDeliveriesWindow: 10,\n meshMessageDeliveriesActivation: 5000,\n meshFailurePenaltyWeight: -1,\n meshFailurePenaltyDecay: 0.5,\n invalidMessageDeliveriesWeight: -1,\n invalidMessageDeliveriesDecay: 0.3\n};\nfunction createPeerScoreParams(p = {}) {\n return Object.assign(Object.assign(Object.assign({}, exports.defaultPeerScoreParams), p), { topics: p.topics\n ? Object.entries(p.topics)\n .reduce((topics, [topic, topicScoreParams]) => {\n topics[topic] = createTopicScoreParams(topicScoreParams);\n return topics;\n }, {})\n : {} });\n}\nexports.createPeerScoreParams = createPeerScoreParams;\nfunction createTopicScoreParams(p = {}) {\n return Object.assign(Object.assign({}, exports.defaultTopicScoreParams), p);\n}\nexports.createTopicScoreParams = createTopicScoreParams;\n// peer score parameter validation\nfunction validatePeerScoreParams(p) {\n for (const [topic, params] of Object.entries(p.topics)) {\n try {\n validateTopicScoreParams(params);\n }\n catch (e) {\n throw errcode(new Error(`invalid score parameters for topic ${topic}: ${e.message}`), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n }\n // check that the topic score is 0 or something positive\n if (p.topicScoreCap < 0) {\n throw errcode(new Error('invalid topic score cap; must be positive (or 0 for no cap)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check that we have an app specific score; the weight can be anything (but expected positive)\n if (p.appSpecificScore === null || p.appSpecificScore === undefined) {\n throw errcode(new Error('missing application specific score function'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check the IP colocation factor\n if (p.IPColocationFactorWeight > 0) {\n throw errcode(new Error('invalid IPColocationFactorWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.IPColocationFactorWeight !== 0 && p.IPColocationFactorThreshold < 1) {\n throw errcode(new Error('invalid IPColocationFactorThreshold; must be at least 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check the behaviour penalty\n if (p.behaviourPenaltyWeight > 0) {\n throw errcode(new Error('invalid BehaviourPenaltyWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.behaviourPenaltyWeight !== 0 && (p.behaviourPenaltyDecay <= 0 || p.behaviourPenaltyDecay >= 1)) {\n throw errcode(new Error('invalid BehaviourPenaltyDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check the decay parameters\n if (p.decayInterval < 1000) {\n throw errcode(new Error('invalid DecayInterval; must be at least 1s'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.decayToZero <= 0 || p.decayToZero >= 1) {\n throw errcode(new Error('invalid DecayToZero; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // no need to check the score retention; a value of 0 means that we don't retain scores\n}\nexports.validatePeerScoreParams = validatePeerScoreParams;\nfunction validateTopicScoreParams(p) {\n // make sure we have a sane topic weight\n if (p.topicWeight < 0) {\n throw errcode(new Error('invalid topic weight; must be >= 0'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P1\n if (p.timeInMeshQuantum === 0) {\n throw errcode(new Error('invalid TimeInMeshQuantum; must be non zero'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.timeInMeshWeight < 0) {\n throw errcode(new Error('invalid TimeInMeshWeight; must be positive (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.timeInMeshWeight !== 0 && p.timeInMeshQuantum <= 0) {\n throw errcode(new Error('invalid TimeInMeshQuantum; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.timeInMeshWeight !== 0 && p.timeInMeshCap <= 0) {\n throw errcode(new Error('invalid TimeInMeshCap; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P2\n if (p.firstMessageDeliveriesWeight < 0) {\n throw errcode(new Error('invallid FirstMessageDeliveriesWeight; must be positive (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.firstMessageDeliveriesWeight !== 0 && (p.firstMessageDeliveriesDecay <= 0 || p.firstMessageDeliveriesDecay >= 1)) {\n throw errcode(new Error('invalid FirstMessageDeliveriesDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.firstMessageDeliveriesWeight !== 0 && p.firstMessageDeliveriesCap <= 0) {\n throw errcode(new Error('invalid FirstMessageDeliveriesCap; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P3\n if (p.meshMessageDeliveriesWeight > 0) {\n throw errcode(new Error('invalid MeshMessageDeliveriesWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWeight !== 0 && (p.meshMessageDeliveriesDecay <= 0 || p.meshMessageDeliveriesDecay >= 1)) {\n throw errcode(new Error('invalid MeshMessageDeliveriesDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWeight !== 0 && p.meshMessageDeliveriesCap <= 0) {\n throw errcode(new Error('invalid MeshMessageDeliveriesCap; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWeight !== 0 && p.meshMessageDeliveriesThreshold <= 0) {\n throw errcode(new Error('invalid MeshMessageDeliveriesThreshold; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWindow < 0) {\n throw errcode(new Error('invalid MeshMessageDeliveriesWindow; must be non-negative'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWeight !== 0 && p.meshMessageDeliveriesActivation < 1000) {\n throw errcode(new Error('invalid MeshMessageDeliveriesActivation; must be at least 1s'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P3b\n if (p.meshFailurePenaltyWeight > 0) {\n throw errcode(new Error('invalid MeshFailurePenaltyWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshFailurePenaltyWeight !== 0 && (p.meshFailurePenaltyDecay <= 0 || p.meshFailurePenaltyDecay >= 1)) {\n throw errcode(new Error('invalid MeshFailurePenaltyDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P4\n if (p.invalidMessageDeliveriesWeight > 0) {\n throw errcode(new Error('invalid InvalidMessageDeliveriesWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.invalidMessageDeliveriesDecay <= 0 || p.invalidMessageDeliveriesDecay >= 1) {\n throw errcode(new Error('invalid InvalidMessageDeliveriesDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n}\nexports.validateTopicScoreParams = validateTopicScoreParams;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ERR_INVALID_PEER_SCORE_THRESHOLDS = exports.ERR_INVALID_PEER_SCORE_PARAMS = void 0;\nexports.ERR_INVALID_PEER_SCORE_PARAMS = 'ERR_INVALID_PEER_SCORE_PARAMS';\nexports.ERR_INVALID_PEER_SCORE_THRESHOLDS = 'ERR_INVALID_PEER_SCORE_THRESHOLDS';\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validatePeerScoreThresholds = exports.createPeerScoreThresholds = exports.defaultPeerScoreThresholds = void 0;\nconst constants_1 = require(\"./constants\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst errcode = require(\"err-code\");\nexports.defaultPeerScoreThresholds = {\n gossipThreshold: -10,\n publishThreshold: -50,\n graylistThreshold: -80,\n acceptPXThreshold: 10,\n opportunisticGraftThreshold: 20\n};\nfunction createPeerScoreThresholds(p = {}) {\n return Object.assign(Object.assign({}, exports.defaultPeerScoreThresholds), p);\n}\nexports.createPeerScoreThresholds = createPeerScoreThresholds;\nfunction validatePeerScoreThresholds(p) {\n if (p.gossipThreshold > 0) {\n throw errcode(new Error('invalid gossip threshold; it must be <= 0'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n if (p.publishThreshold > 0 || p.publishThreshold > p.gossipThreshold) {\n throw errcode(new Error('invalid publish threshold; it must be <= 0 and <= gossip threshold'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n if (p.graylistThreshold > 0 || p.graylistThreshold > p.publishThreshold) {\n throw errcode(new Error('invalid graylist threshold; it must be <= 0 and <= publish threshold'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n if (p.acceptPXThreshold < 0) {\n throw errcode(new Error('invalid accept PX threshold; it must be >= 0'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n if (p.opportunisticGraftThreshold < 0) {\n throw errcode(new Error('invalid opportunistic grafting threshold; it must be >= 0'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n}\nexports.validatePeerScoreThresholds = validatePeerScoreThresholds;\n","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.PeerScore = void 0;\nconst peer_score_params_1 = require(\"./peer-score-params\");\nconst peer_stats_1 = require(\"./peer-stats\");\nconst compute_score_1 = require(\"./compute-score\");\nconst message_deliveries_1 = require(\"./message-deliveries\");\nconst constants_1 = require(\"../constants\");\nconst peer_id_1 = __importDefault(require(\"peer-id\"));\nconst debug = require(\"debug\");\nconst pubsubErrors = require(\"libp2p-interfaces/src/pubsub/errors\");\nconst { ERR_INVALID_SIGNATURE, ERR_MISSING_SIGNATURE } = pubsubErrors.codes;\nconst log = debug('libp2p:gossipsub:score');\nclass PeerScore {\n constructor(params, connectionManager, msgId) {\n peer_score_params_1.validatePeerScoreParams(params);\n this.params = params;\n this._connectionManager = connectionManager;\n this.peerStats = new Map();\n this.peerIPs = new Map();\n this.deliveryRecords = new message_deliveries_1.MessageDeliveries();\n this.msgId = msgId;\n }\n /**\n * Start PeerScore instance\n * @returns {void}\n */\n start() {\n if (this._backgroundInterval) {\n log('Peer score already running');\n return;\n }\n this._backgroundInterval = setInterval(() => this.background(), this.params.decayInterval);\n log('started');\n }\n /**\n * Stop PeerScore instance\n * @returns {void}\n */\n stop() {\n if (!this._backgroundInterval) {\n log('Peer score already stopped');\n return;\n }\n clearInterval(this._backgroundInterval);\n delete this._backgroundInterval;\n this.peerIPs.clear();\n this.peerStats.clear();\n this.deliveryRecords.clear();\n log('stopped');\n }\n /**\n * Periodic maintenance\n * @returns {void}\n */\n background() {\n this._refreshScores();\n this._updateIPs();\n this.deliveryRecords.gc();\n }\n /**\n * Decays scores, and purges score records for disconnected peers once their expiry has elapsed.\n * @returns {void}\n */\n _refreshScores() {\n const now = Date.now();\n const decayToZero = this.params.decayToZero;\n this.peerStats.forEach((pstats, id) => {\n if (!pstats.connected) {\n // has the retention perious expired?\n if (now > pstats.expire) {\n // yes, throw it away (but clean up the IP tracking first)\n this._removeIPs(id, pstats.ips);\n this.peerStats.delete(id);\n }\n // we don't decay retained scores, as the peer is not active.\n // this way the peer cannot reset a negative score by simply disconnecting and reconnecting,\n // unless the retention period has ellapsed.\n // similarly, a well behaved peer does not lose its score by getting disconnected.\n return;\n }\n Object.entries(pstats.topics).forEach(([topic, tstats]) => {\n const tparams = this.params.topics[topic];\n if (!tparams) {\n // we are not scoring this topic\n // should be unreachable, we only add scored topics to pstats\n return;\n }\n // decay counters\n tstats.firstMessageDeliveries *= tparams.firstMessageDeliveriesDecay;\n if (tstats.firstMessageDeliveries < decayToZero) {\n tstats.firstMessageDeliveries = 0;\n }\n tstats.meshMessageDeliveries *= tparams.meshMessageDeliveriesDecay;\n if (tstats.meshMessageDeliveries < decayToZero) {\n tstats.meshMessageDeliveries = 0;\n }\n tstats.meshFailurePenalty *= tparams.meshFailurePenaltyDecay;\n if (tstats.meshFailurePenalty < decayToZero) {\n tstats.meshFailurePenalty = 0;\n }\n tstats.invalidMessageDeliveries *= tparams.invalidMessageDeliveriesDecay;\n if (tstats.invalidMessageDeliveries < decayToZero) {\n tstats.invalidMessageDeliveries = 0;\n }\n // update mesh time and activate mesh message delivery parameter if need be\n if (tstats.inMesh) {\n tstats.meshTime = now - tstats.graftTime;\n if (tstats.meshTime > tparams.meshMessageDeliveriesActivation) {\n tstats.meshMessageDeliveriesActive = true;\n }\n }\n });\n // decay P7 counter\n pstats.behaviourPenalty *= this.params.behaviourPenaltyDecay;\n if (pstats.behaviourPenalty < decayToZero) {\n pstats.behaviourPenalty = 0;\n }\n });\n }\n /**\n * Return the score for a peer\n * @param {string} id\n * @returns {Number}\n */\n score(id) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return 0;\n }\n return compute_score_1.computeScore(id, pstats, this.params, this.peerIPs);\n }\n /**\n * Apply a behavioural penalty to a peer\n * @param {string} id\n * @param {Number} penalty\n * @returns {void}\n */\n addPenalty(id, penalty) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n pstats.behaviourPenalty += penalty;\n }\n /**\n * @param {string} id\n * @returns {void}\n */\n addPeer(id) {\n // create peer stats (not including topic stats for each topic to be scored)\n // topic stats will be added as needed\n const pstats = peer_stats_1.createPeerStats({\n connected: true\n });\n this.peerStats.set(id, pstats);\n // get + update peer IPs\n const ips = this._getIPs(id);\n this._setIPs(id, ips, pstats.ips);\n pstats.ips = ips;\n }\n /**\n * @param {string} id\n * @returns {void}\n */\n removePeer(id) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n // decide whether to retain the score; this currently only retains non-positive scores\n // to dissuade attacks on the score function.\n if (this.score(id) > 0) {\n this._removeIPs(id, pstats.ips);\n this.peerStats.delete(id);\n return;\n }\n // furthermore, when we decide to retain the score, the firstMessageDelivery counters are\n // reset to 0 and mesh delivery penalties applied.\n Object.entries(pstats.topics).forEach(([topic, tstats]) => {\n tstats.firstMessageDeliveries = 0;\n const threshold = this.params.topics[topic].meshMessageDeliveriesThreshold;\n if (tstats.inMesh && tstats.meshMessageDeliveriesActive && tstats.meshMessageDeliveries < threshold) {\n const deficit = threshold - tstats.meshMessageDeliveries;\n tstats.meshFailurePenalty += deficit * deficit;\n }\n tstats.inMesh = false;\n });\n pstats.connected = false;\n pstats.expire = Date.now() + this.params.retainScore;\n }\n /**\n * @param {string} id\n * @param {String} topic\n * @returns {void}\n */\n graft(id, topic) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n tstats.inMesh = true;\n tstats.graftTime = Date.now();\n tstats.meshTime = 0;\n tstats.meshMessageDeliveriesActive = false;\n }\n /**\n * @param {string} id\n * @param {string} topic\n * @returns {void}\n */\n prune(id, topic) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n // sticky mesh delivery rate failure penalty\n const threshold = this.params.topics[topic].meshMessageDeliveriesThreshold;\n if (tstats.meshMessageDeliveriesActive && tstats.meshMessageDeliveries < threshold) {\n const deficit = threshold - tstats.meshMessageDeliveries;\n tstats.meshFailurePenalty += deficit * deficit;\n }\n tstats.inMesh = false;\n }\n /**\n * @param {InMessage} message\n * @returns {Promise}\n */\n validateMessage(message) {\n return __awaiter(this, void 0, void 0, function* () {\n this.deliveryRecords.ensureRecord(yield this.msgId(message));\n });\n }\n /**\n * @param {InMessage} message\n * @returns {Promise}\n */\n deliverMessage(message) {\n return __awaiter(this, void 0, void 0, function* () {\n const id = message.receivedFrom;\n this._markFirstMessageDelivery(id, message);\n const drec = this.deliveryRecords.ensureRecord(yield this.msgId(message));\n const now = Date.now();\n // defensive check that this is the first delivery trace -- delivery status should be unknown\n if (drec.status !== message_deliveries_1.DeliveryRecordStatus.unknown) {\n log('unexpected delivery: message from %s was first seen %s ago and has delivery status %d', id, now - drec.firstSeen, message_deliveries_1.DeliveryRecordStatus[drec.status]);\n return;\n }\n // mark the message as valid and reward mesh peers that have already forwarded it to us\n drec.status = message_deliveries_1.DeliveryRecordStatus.valid;\n drec.validated = now;\n drec.peers.forEach(p => {\n // this check is to make sure a peer can't send us a message twice and get a double count\n // if it is a first delivery.\n if (p !== id) {\n this._markDuplicateMessageDelivery(p, message);\n }\n });\n });\n }\n /**\n * @param {InMessage} message\n * @param {string} reason\n * @returns {Promise}\n */\n rejectMessage(message, reason) {\n return __awaiter(this, void 0, void 0, function* () {\n const id = message.receivedFrom;\n switch (reason) {\n case ERR_MISSING_SIGNATURE:\n case ERR_INVALID_SIGNATURE:\n this._markInvalidMessageDelivery(id, message);\n return;\n }\n const drec = this.deliveryRecords.ensureRecord(yield this.msgId(message));\n // defensive check that this is the first rejection -- delivery status should be unknown\n if (drec.status !== message_deliveries_1.DeliveryRecordStatus.unknown) {\n log('unexpected rejection: message from %s was first seen %s ago and has delivery status %d', id, Date.now() - drec.firstSeen, message_deliveries_1.DeliveryRecordStatus[drec.status]);\n return;\n }\n switch (reason) {\n case constants_1.ERR_TOPIC_VALIDATOR_IGNORE:\n // we were explicitly instructed by the validator to ignore the message but not penalize the peer\n drec.status = message_deliveries_1.DeliveryRecordStatus.ignored;\n return;\n }\n // mark the message as invalid and penalize peers that have already forwarded it.\n drec.status = message_deliveries_1.DeliveryRecordStatus.invalid;\n this._markInvalidMessageDelivery(id, message);\n drec.peers.forEach(p => {\n this._markInvalidMessageDelivery(p, message);\n });\n });\n }\n /**\n * @param {InMessage} message\n * @returns {Promise}\n */\n duplicateMessage(message) {\n return __awaiter(this, void 0, void 0, function* () {\n const id = message.receivedFrom;\n const drec = this.deliveryRecords.ensureRecord(yield this.msgId(message));\n if (drec.peers.has(id)) {\n // we have already seen this duplicate\n return;\n }\n switch (drec.status) {\n case message_deliveries_1.DeliveryRecordStatus.unknown:\n // the message is being validated; track the peer delivery and wait for\n // the Deliver/Reject/Ignore notification.\n drec.peers.add(id);\n break;\n case message_deliveries_1.DeliveryRecordStatus.valid:\n // mark the peer delivery time to only count a duplicate delivery once.\n drec.peers.add(id);\n this._markDuplicateMessageDelivery(id, message, drec.validated);\n break;\n case message_deliveries_1.DeliveryRecordStatus.invalid:\n // we no longer track delivery time\n this._markInvalidMessageDelivery(id, message);\n break;\n }\n });\n }\n /**\n * Increments the \"invalid message deliveries\" counter for all scored topics the message is published in.\n * @param {string} id\n * @param {InMessage} message\n * @returns {void}\n */\n _markInvalidMessageDelivery(id, message) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n message.topicIDs.forEach(topic => {\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n tstats.invalidMessageDeliveries += 1;\n });\n }\n /**\n * Increments the \"first message deliveries\" counter for all scored topics the message is published in,\n * as well as the \"mesh message deliveries\" counter, if the peer is in the mesh for the topic.\n * @param {string} id\n * @param {InMessage} message\n * @returns {void}\n */\n _markFirstMessageDelivery(id, message) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n message.topicIDs.forEach(topic => {\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n let cap = this.params.topics[topic].firstMessageDeliveriesCap;\n tstats.firstMessageDeliveries += 1;\n if (tstats.firstMessageDeliveries > cap) {\n tstats.firstMessageDeliveries = cap;\n }\n if (!tstats.inMesh) {\n return;\n }\n cap = this.params.topics[topic].meshMessageDeliveriesCap;\n tstats.meshMessageDeliveries += 1;\n if (tstats.meshMessageDeliveries > cap) {\n tstats.meshMessageDeliveries = cap;\n }\n });\n }\n /**\n * Increments the \"mesh message deliveries\" counter for messages we've seen before,\n * as long the message was received within the P3 window.\n * @param {string} id\n * @param {InMessage} message\n * @param {number} validatedTime\n * @returns {void}\n */\n _markDuplicateMessageDelivery(id, message, validatedTime = 0) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n const now = validatedTime ? Date.now() : 0;\n message.topicIDs.forEach(topic => {\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n if (!tstats.inMesh) {\n return;\n }\n const tparams = this.params.topics[topic];\n // check against the mesh delivery window -- if the validated time is passed as 0, then\n // the message was received before we finished validation and thus falls within the mesh\n // delivery window.\n if (validatedTime && now > validatedTime + tparams.meshMessageDeliveriesWindow) {\n return;\n }\n const cap = tparams.meshMessageDeliveriesCap;\n tstats.meshMessageDeliveries += 1;\n if (tstats.meshMessageDeliveries > cap) {\n tstats.meshMessageDeliveries = cap;\n }\n });\n }\n /**\n * Gets the current IPs for a peer.\n * @param {string} id\n * @returns {Array}\n */\n _getIPs(id) {\n return this._connectionManager.getAll(peer_id_1.default.createFromB58String(id))\n .map(c => c.remoteAddr.toOptions().host);\n }\n /**\n * Adds tracking for the new IPs in the list, and removes tracking from the obsolete IPs.\n * @param {string} id\n * @param {Array} newIPs\n * @param {Array} oldIPs\n * @returns {void}\n */\n _setIPs(id, newIPs, oldIPs) {\n // add the new IPs to the tracking\n // eslint-disable-next-line no-labels\n addNewIPs: for (const ip of newIPs) {\n // check if it is in the old ips list\n for (const xip of oldIPs) {\n if (ip === xip) {\n // eslint-disable-next-line no-labels\n continue addNewIPs;\n }\n }\n // no, it's a new one -- add it to the tracker\n let peers = this.peerIPs.get(ip);\n if (!peers) {\n peers = new Set();\n this.peerIPs.set(ip, peers);\n }\n peers.add(id);\n }\n // remove the obsolete old IPs from the tracking\n // eslint-disable-next-line no-labels\n removeOldIPs: for (const ip of oldIPs) {\n // check if it is in the new ips list\n for (const xip of newIPs) {\n if (ip === xip) {\n // eslint-disable-next-line no-labels\n continue removeOldIPs;\n }\n }\n // no, its obselete -- remove it from the tracker\n const peers = this.peerIPs.get(ip);\n if (!peers) {\n continue;\n }\n peers.delete(id);\n if (!peers.size) {\n this.peerIPs.delete(ip);\n }\n }\n }\n /**\n * Removes an IP list from the tracking list for a peer.\n * @param {string} id\n * @param {Array} ips\n * @returns {void}\n */\n _removeIPs(id, ips) {\n ips.forEach(ip => {\n const peers = this.peerIPs.get(ip);\n if (!peers) {\n return;\n }\n peers.delete(id);\n if (!peers.size) {\n this.peerIPs.delete(ip);\n }\n });\n }\n /**\n * Update all peer IPs to currently open connections\n * @returns {void}\n */\n _updateIPs() {\n this.peerStats.forEach((pstats, id) => {\n const newIPs = this._getIPs(id);\n this._setIPs(id, newIPs, pstats.ips);\n pstats.ips = newIPs;\n });\n }\n}\nexports.PeerScore = PeerScore;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ensureTopicStats = exports.createTopicStats = exports.createPeerStats = void 0;\nfunction createPeerStats(ps = {}) {\n return Object.assign(Object.assign({ connected: false, expire: 0, ips: [], behaviourPenalty: 0 }, ps), { topics: ps.topics\n ? Object.entries(ps.topics)\n .reduce((topics, [topic, topicStats]) => {\n topics[topic] = createTopicStats(topicStats);\n return topics;\n }, {})\n : {} });\n}\nexports.createPeerStats = createPeerStats;\nfunction createTopicStats(ts = {}) {\n return Object.assign({ inMesh: false, graftTime: 0, meshTime: 0, firstMessageDeliveries: 0, meshMessageDeliveries: 0, meshMessageDeliveriesActive: false, meshFailurePenalty: 0, invalidMessageDeliveries: 0 }, ts);\n}\nexports.createTopicStats = createTopicStats;\nfunction ensureTopicStats(topic, ps, params) {\n let ts = ps.topics[topic];\n if (ts) {\n return ts;\n }\n if (!params.topics[topic]) {\n return undefined;\n }\n ps.topics[topic] = ts = createTopicStats();\n return ts;\n}\nexports.ensureTopicStats = ensureTopicStats;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.computeScore = void 0;\nfunction computeScore(peer, pstats, params, peerIPs) {\n let score = 0;\n // topic stores\n Object.entries(pstats.topics).forEach(([topic, tstats]) => {\n // the topic parameters\n const topicParams = params.topics[topic];\n if (!topicParams) {\n // we are not scoring this topic\n return;\n }\n let topicScore = 0;\n // P1: time in Mesh\n if (tstats.inMesh) {\n let p1 = tstats.meshTime / topicParams.timeInMeshQuantum;\n if (p1 > topicParams.timeInMeshCap) {\n p1 = topicParams.timeInMeshCap;\n }\n topicScore += p1 * topicParams.timeInMeshWeight;\n }\n // P2: first message deliveries\n const p2 = tstats.firstMessageDeliveries;\n topicScore += p2 * topicParams.firstMessageDeliveriesWeight;\n // P3: mesh message deliveries\n if (tstats.meshMessageDeliveriesActive) {\n if (tstats.meshMessageDeliveries < topicParams.meshMessageDeliveriesThreshold) {\n const deficit = topicParams.meshMessageDeliveriesThreshold - tstats.meshMessageDeliveries;\n const p3 = deficit * deficit;\n topicScore += p3 * topicParams.meshMessageDeliveriesWeight;\n }\n }\n // P3b:\n // NOTE: the weight of P3b is negative (validated in validateTopicScoreParams) so this detracts\n const p3b = tstats.meshFailurePenalty;\n topicScore += p3b * topicParams.meshFailurePenaltyWeight;\n // P4: invalid messages\n // NOTE: the weight of P4 is negative (validated in validateTopicScoreParams) so this detracts\n const p4 = tstats.invalidMessageDeliveries * tstats.invalidMessageDeliveries;\n topicScore += p4 * topicParams.invalidMessageDeliveriesWeight;\n // update score, mixing with topic weight\n score += topicScore * topicParams.topicWeight;\n });\n // apply the topic score cap, if any\n if (params.topicScoreCap > 0 && score > params.topicScoreCap) {\n score = params.topicScoreCap;\n }\n // P5: application-specific score\n const p5 = params.appSpecificScore(peer);\n score += p5 * params.appSpecificWeight;\n // P6: IP colocation factor\n pstats.ips.forEach(ip => {\n if (params.IPColocationFactorWhitelist.has(ip)) {\n return;\n }\n // P6 has a cliff (IPColocationFactorThreshold)\n // It's only applied if at least that many peers are connected to us from that source IP addr.\n // It is quadratic, and the weight is negative (validated in validatePeerScoreParams)\n const peersInIP = peerIPs.get(ip);\n const numPeersInIP = peersInIP ? peersInIP.size : 0;\n if (numPeersInIP > params.IPColocationFactorThreshold) {\n const surplus = numPeersInIP - params.IPColocationFactorThreshold;\n const p6 = surplus * surplus;\n score += p6 * params.IPColocationFactorWeight;\n }\n });\n // P7: behavioural pattern penalty\n const p7 = pstats.behaviourPenalty * pstats.behaviourPenalty;\n score += p7 * params.behaviourPenaltyWeight;\n return score;\n}\nexports.computeScore = computeScore;\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MessageDeliveries = exports.DeliveryRecordStatus = void 0;\nconst constants_1 = require(\"../constants\");\nconst denque_1 = __importDefault(require(\"denque\"));\nconst utils_1 = require(\"../utils\");\nvar DeliveryRecordStatus;\n(function (DeliveryRecordStatus) {\n /**\n * we don't know (yet) if the message is valid\n */\n DeliveryRecordStatus[DeliveryRecordStatus[\"unknown\"] = 0] = \"unknown\";\n /**\n * we know the message is valid\n */\n DeliveryRecordStatus[DeliveryRecordStatus[\"valid\"] = 1] = \"valid\";\n /**\n * we know the message is invalid\n */\n DeliveryRecordStatus[DeliveryRecordStatus[\"invalid\"] = 2] = \"invalid\";\n /**\n * we were instructed by the validator to ignore the message\n */\n DeliveryRecordStatus[DeliveryRecordStatus[\"ignored\"] = 3] = \"ignored\";\n})(DeliveryRecordStatus = exports.DeliveryRecordStatus || (exports.DeliveryRecordStatus = {}));\n/**\n * Map of message ID to DeliveryRecord\n *\n * Maintains an internal queue for efficient gc of old messages\n */\nclass MessageDeliveries {\n constructor() {\n this.records = new Map();\n this.queue = new denque_1.default();\n }\n ensureRecord(msgId) {\n const msgIdStr = utils_1.messageIdToString(msgId);\n let drec = this.records.get(msgIdStr);\n if (drec) {\n return drec;\n }\n // record doesn't exist yet\n // create record\n drec = {\n status: DeliveryRecordStatus.unknown,\n firstSeen: Date.now(),\n validated: 0,\n peers: new Set()\n };\n this.records.set(msgIdStr, drec);\n // and add msgId to the queue\n const entry = {\n msgId: msgIdStr,\n expire: Date.now() + constants_1.TimeCacheDuration\n };\n this.queue.push(entry);\n return drec;\n }\n gc() {\n const now = Date.now();\n // queue is sorted by expiry time\n // remove expired messages, remove from queue until first un-expired message found\n let head = this.queue.peekFront();\n while (head && head.expire < now) {\n this.records.delete(head.msgId);\n this.queue.shift();\n head = this.queue.peekFront();\n }\n }\n clear() {\n this.records.clear();\n this.queue.clear();\n }\n}\nexports.MessageDeliveries = MessageDeliveries;\n","'use strict';\n\n/**\n * Custom implementation of a double ended queue.\n */\nfunction Denque(array, options) {\n var options = options || {};\n\n this._head = 0;\n this._tail = 0;\n this._capacity = options.capacity;\n this._capacityMask = 0x3;\n this._list = new Array(4);\n if (Array.isArray(array)) {\n this._fromArray(array);\n }\n}\n\n/**\n * -------------\n * PUBLIC API\n * -------------\n */\n\n/**\n * Returns the item at the specified index from the list.\n * 0 is the first element, 1 is the second, and so on...\n * Elements at negative values are that many from the end: -1 is one before the end\n * (the last element), -2 is two before the end (one before last), etc.\n * @param index\n * @returns {*}\n */\nDenque.prototype.peekAt = function peekAt(index) {\n var i = index;\n // expect a number or return undefined\n if ((i !== (i | 0))) {\n return void 0;\n }\n var len = this.size();\n if (i >= len || i < -len) return undefined;\n if (i < 0) i += len;\n i = (this._head + i) & this._capacityMask;\n return this._list[i];\n};\n\n/**\n * Alias for peekAt()\n * @param i\n * @returns {*}\n */\nDenque.prototype.get = function get(i) {\n return this.peekAt(i);\n};\n\n/**\n * Returns the first item in the list without removing it.\n * @returns {*}\n */\nDenque.prototype.peek = function peek() {\n if (this._head === this._tail) return undefined;\n return this._list[this._head];\n};\n\n/**\n * Alias for peek()\n * @returns {*}\n */\nDenque.prototype.peekFront = function peekFront() {\n return this.peek();\n};\n\n/**\n * Returns the item that is at the back of the queue without removing it.\n * Uses peekAt(-1)\n */\nDenque.prototype.peekBack = function peekBack() {\n return this.peekAt(-1);\n};\n\n/**\n * Returns the current length of the queue\n * @return {Number}\n */\nObject.defineProperty(Denque.prototype, 'length', {\n get: function length() {\n return this.size();\n }\n});\n\n/**\n * Return the number of items on the list, or 0 if empty.\n * @returns {number}\n */\nDenque.prototype.size = function size() {\n if (this._head === this._tail) return 0;\n if (this._head < this._tail) return this._tail - this._head;\n else return this._capacityMask + 1 - (this._head - this._tail);\n};\n\n/**\n * Add an item at the beginning of the list.\n * @param item\n */\nDenque.prototype.unshift = function unshift(item) {\n if (item === undefined) return this.size();\n var len = this._list.length;\n this._head = (this._head - 1 + len) & this._capacityMask;\n this._list[this._head] = item;\n if (this._tail === this._head) this._growArray();\n if (this._capacity && this.size() > this._capacity) this.pop();\n if (this._head < this._tail) return this._tail - this._head;\n else return this._capacityMask + 1 - (this._head - this._tail);\n};\n\n/**\n * Remove and return the first item on the list,\n * Returns undefined if the list is empty.\n * @returns {*}\n */\nDenque.prototype.shift = function shift() {\n var head = this._head;\n if (head === this._tail) return undefined;\n var item = this._list[head];\n this._list[head] = undefined;\n this._head = (head + 1) & this._capacityMask;\n if (head < 2 && this._tail > 10000 && this._tail <= this._list.length >>> 2) this._shrinkArray();\n return item;\n};\n\n/**\n * Add an item to the bottom of the list.\n * @param item\n */\nDenque.prototype.push = function push(item) {\n if (item === undefined) return this.size();\n var tail = this._tail;\n this._list[tail] = item;\n this._tail = (tail + 1) & this._capacityMask;\n if (this._tail === this._head) {\n this._growArray();\n }\n if (this._capacity && this.size() > this._capacity) {\n this.shift();\n }\n if (this._head < this._tail) return this._tail - this._head;\n else return this._capacityMask + 1 - (this._head - this._tail);\n};\n\n/**\n * Remove and return the last item on the list.\n * Returns undefined if the list is empty.\n * @returns {*}\n */\nDenque.prototype.pop = function pop() {\n var tail = this._tail;\n if (tail === this._head) return undefined;\n var len = this._list.length;\n this._tail = (tail - 1 + len) & this._capacityMask;\n var item = this._list[this._tail];\n this._list[this._tail] = undefined;\n if (this._head < 2 && tail > 10000 && tail <= len >>> 2) this._shrinkArray();\n return item;\n};\n\n/**\n * Remove and return the item at the specified index from the list.\n * Returns undefined if the list is empty.\n * @param index\n * @returns {*}\n */\nDenque.prototype.removeOne = function removeOne(index) {\n var i = index;\n // expect a number or return undefined\n if ((i !== (i | 0))) {\n return void 0;\n }\n if (this._head === this._tail) return void 0;\n var size = this.size();\n var len = this._list.length;\n if (i >= size || i < -size) return void 0;\n if (i < 0) i += size;\n i = (this._head + i) & this._capacityMask;\n var item = this._list[i];\n var k;\n if (index < size / 2) {\n for (k = index; k > 0; k--) {\n this._list[i] = this._list[i = (i - 1 + len) & this._capacityMask];\n }\n this._list[i] = void 0;\n this._head = (this._head + 1 + len) & this._capacityMask;\n } else {\n for (k = size - 1 - index; k > 0; k--) {\n this._list[i] = this._list[i = ( i + 1 + len) & this._capacityMask];\n }\n this._list[i] = void 0;\n this._tail = (this._tail - 1 + len) & this._capacityMask;\n }\n return item;\n};\n\n/**\n * Remove number of items from the specified index from the list.\n * Returns array of removed items.\n * Returns undefined if the list is empty.\n * @param index\n * @param count\n * @returns {array}\n */\nDenque.prototype.remove = function remove(index, count) {\n var i = index;\n var removed;\n var del_count = count;\n // expect a number or return undefined\n if ((i !== (i | 0))) {\n return void 0;\n }\n if (this._head === this._tail) return void 0;\n var size = this.size();\n var len = this._list.length;\n if (i >= size || i < -size || count < 1) return void 0;\n if (i < 0) i += size;\n if (count === 1 || !count) {\n removed = new Array(1);\n removed[0] = this.removeOne(i);\n return removed;\n }\n if (i === 0 && i + count >= size) {\n removed = this.toArray();\n this.clear();\n return removed;\n }\n if (i + count > size) count = size - i;\n var k;\n removed = new Array(count);\n for (k = 0; k < count; k++) {\n removed[k] = this._list[(this._head + i + k) & this._capacityMask];\n }\n i = (this._head + i) & this._capacityMask;\n if (index + count === size) {\n this._tail = (this._tail - count + len) & this._capacityMask;\n for (k = count; k > 0; k--) {\n this._list[i = (i + 1 + len) & this._capacityMask] = void 0;\n }\n return removed;\n }\n if (index === 0) {\n this._head = (this._head + count + len) & this._capacityMask;\n for (k = count - 1; k > 0; k--) {\n this._list[i = (i + 1 + len) & this._capacityMask] = void 0;\n }\n return removed;\n }\n if (i < size / 2) {\n this._head = (this._head + index + count + len) & this._capacityMask;\n for (k = index; k > 0; k--) {\n this.unshift(this._list[i = (i - 1 + len) & this._capacityMask]);\n }\n i = (this._head - 1 + len) & this._capacityMask;\n while (del_count > 0) {\n this._list[i = (i - 1 + len) & this._capacityMask] = void 0;\n del_count--;\n }\n if (index < 0) this._tail = i;\n } else {\n this._tail = i;\n i = (i + count + len) & this._capacityMask;\n for (k = size - (count + index); k > 0; k--) {\n this.push(this._list[i++]);\n }\n i = this._tail;\n while (del_count > 0) {\n this._list[i = (i + 1 + len) & this._capacityMask] = void 0;\n del_count--;\n }\n }\n if (this._head < 2 && this._tail > 10000 && this._tail <= len >>> 2) this._shrinkArray();\n return removed;\n};\n\n/**\n * Native splice implementation.\n * Remove number of items from the specified index from the list and/or add new elements.\n * Returns array of removed items or empty array if count == 0.\n * Returns undefined if the list is empty.\n *\n * @param index\n * @param count\n * @param {...*} [elements]\n * @returns {array}\n */\nDenque.prototype.splice = function splice(index, count) {\n var i = index;\n // expect a number or return undefined\n if ((i !== (i | 0))) {\n return void 0;\n }\n var size = this.size();\n if (i < 0) i += size;\n if (i > size) return void 0;\n if (arguments.length > 2) {\n var k;\n var temp;\n var removed;\n var arg_len = arguments.length;\n var len = this._list.length;\n var arguments_index = 2;\n if (!size || i < size / 2) {\n temp = new Array(i);\n for (k = 0; k < i; k++) {\n temp[k] = this._list[(this._head + k) & this._capacityMask];\n }\n if (count === 0) {\n removed = [];\n if (i > 0) {\n this._head = (this._head + i + len) & this._capacityMask;\n }\n } else {\n removed = this.remove(i, count);\n this._head = (this._head + i + len) & this._capacityMask;\n }\n while (arg_len > arguments_index) {\n this.unshift(arguments[--arg_len]);\n }\n for (k = i; k > 0; k--) {\n this.unshift(temp[k - 1]);\n }\n } else {\n temp = new Array(size - (i + count));\n var leng = temp.length;\n for (k = 0; k < leng; k++) {\n temp[k] = this._list[(this._head + i + count + k) & this._capacityMask];\n }\n if (count === 0) {\n removed = [];\n if (i != size) {\n this._tail = (this._head + i + len) & this._capacityMask;\n }\n } else {\n removed = this.remove(i, count);\n this._tail = (this._tail - leng + len) & this._capacityMask;\n }\n while (arguments_index < arg_len) {\n this.push(arguments[arguments_index++]);\n }\n for (k = 0; k < leng; k++) {\n this.push(temp[k]);\n }\n }\n return removed;\n } else {\n return this.remove(i, count);\n }\n};\n\n/**\n * Soft clear - does not reset capacity.\n */\nDenque.prototype.clear = function clear() {\n this._head = 0;\n this._tail = 0;\n};\n\n/**\n * Returns true or false whether the list is empty.\n * @returns {boolean}\n */\nDenque.prototype.isEmpty = function isEmpty() {\n return this._head === this._tail;\n};\n\n/**\n * Returns an array of all queue items.\n * @returns {Array}\n */\nDenque.prototype.toArray = function toArray() {\n return this._copyArray(false);\n};\n\n/**\n * -------------\n * INTERNALS\n * -------------\n */\n\n/**\n * Fills the queue with items from an array\n * For use in the constructor\n * @param array\n * @private\n */\nDenque.prototype._fromArray = function _fromArray(array) {\n for (var i = 0; i < array.length; i++) this.push(array[i]);\n};\n\n/**\n *\n * @param fullCopy\n * @returns {Array}\n * @private\n */\nDenque.prototype._copyArray = function _copyArray(fullCopy) {\n var newArray = [];\n var list = this._list;\n var len = list.length;\n var i;\n if (fullCopy || this._head > this._tail) {\n for (i = this._head; i < len; i++) newArray.push(list[i]);\n for (i = 0; i < this._tail; i++) newArray.push(list[i]);\n } else {\n for (i = this._head; i < this._tail; i++) newArray.push(list[i]);\n }\n return newArray;\n};\n\n/**\n * Grows the internal list array.\n * @private\n */\nDenque.prototype._growArray = function _growArray() {\n if (this._head) {\n // copy existing data, head to end, then beginning to tail.\n this._list = this._copyArray(true);\n this._head = 0;\n }\n\n // head is at 0 and array is now full, safe to extend\n this._tail = this._list.length;\n\n this._list.length <<= 1;\n this._capacityMask = (this._capacityMask << 1) | 1;\n};\n\n/**\n * Shrinks the internal list array.\n * @private\n */\nDenque.prototype._shrinkArray = function _shrinkArray() {\n this._list.length >>>= 1;\n this._capacityMask >>>= 1;\n};\n\n\nmodule.exports = Denque;\n","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.IWantTracer = void 0;\nconst constants_1 = require(\"./constants\");\nconst utils_1 = require(\"./utils\");\nconst pubsubErrors = require(\"libp2p-interfaces/src/pubsub/errors\");\nconst { ERR_INVALID_SIGNATURE, ERR_MISSING_SIGNATURE } = pubsubErrors.codes;\n/**\n * IWantTracer is an internal tracer that tracks IWANT requests in order to penalize\n * peers who don't follow up on IWANT requests after an IHAVE advertisement.\n * The tracking of promises is probabilistic to avoid using too much memory.\n *\n * Note: Do not confuse these 'promises' with JS Promise objects.\n * These 'promises' are merely expectations of a peer's behavior.\n */\nclass IWantTracer {\n constructor(getMsgId) {\n this.getMsgId = getMsgId;\n this.promises = new Map();\n }\n /**\n * Track a promise to deliver a message from a list of msgIDs we are requesting\n * @param {string} p peer id\n * @param {string[]} msgIds\n * @returns {void}\n */\n addPromise(p, msgIds) {\n // pick msgId randomly from the list\n const ix = Math.floor(Math.random() * msgIds.length);\n const msgId = msgIds[ix];\n const msgIdStr = utils_1.messageIdToString(msgId);\n let peers = this.promises.get(msgIdStr);\n if (!peers) {\n peers = new Map();\n this.promises.set(msgIdStr, peers);\n }\n if (!peers.has(p)) {\n peers.set(p, Date.now() + constants_1.GossipsubIWantFollowupTime);\n }\n }\n /**\n * Returns the number of broken promises for each peer who didn't follow up on an IWANT request.\n * @returns {Map}\n */\n getBrokenPromises() {\n const now = Date.now();\n const result = new Map();\n this.promises.forEach((peers, msgId) => {\n peers.forEach((expire, p) => {\n // the promise has been broken\n if (expire < now) {\n // add 1 to result\n result.set(p, (result.get(p) || 0) + 1);\n // delete from tracked promises\n peers.delete(p);\n }\n });\n // clean up empty promises for a msgId\n if (!peers.size) {\n this.promises.delete(msgId);\n }\n });\n return result;\n }\n /**\n * Someone delivered a message, stop tracking promises for it\n * @param {InMessage} msg\n * @returns {Promise}\n */\n deliverMessage(msg) {\n return __awaiter(this, void 0, void 0, function* () {\n const msgId = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgId);\n this.promises.delete(msgIdStr);\n });\n }\n /**\n * A message got rejected, so we can stop tracking promises and let the score penalty apply from invalid message delivery,\n * unless its an obviously invalid message.\n * @param {InMessage} msg\n * @param {string} reason\n * @returns {Promise}\n */\n rejectMessage(msg, reason) {\n return __awaiter(this, void 0, void 0, function* () {\n switch (reason) {\n case ERR_INVALID_SIGNATURE:\n case ERR_MISSING_SIGNATURE:\n return;\n }\n const msgId = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgId);\n this.promises.delete(msgIdStr);\n });\n }\n clear() {\n this.promises.clear();\n }\n}\nexports.IWantTracer = IWantTracer;\n","'use strict'\n\nconst throttle = require('lodash.throttle')\nexports = module.exports = TimeCache\n\nfunction TimeCache (options) {\n if (!(this instanceof TimeCache)) {\n return new TimeCache(options)\n }\n\n options = options || {}\n\n const validity = options.validity || 30 // seconds\n\n const entries = new Map()\n\n const sweep = throttle(() => {\n entries.forEach((entry, key) => {\n const v = entry.validity || validity\n const delta = getTimeElapsed(entry.timestamp)\n if (delta > v) {\n entries.delete(key)\n }\n })\n }, 200)\n\n this.put = (key, value, validity) => {\n if (!this.has(key)) {\n entries.set(key, {\n value: value,\n timestamp: new Date(),\n validity: validity\n })\n }\n\n sweep()\n }\n\n this.get = (key) => {\n if (entries.has(key)) {\n return entries.get(key).value\n } else {\n throw new Error('key does not exist')\n }\n }\n\n this.has = (key) => {\n return entries.has(key)\n }\n}\n\nfunction getTimeElapsed (prevTime) {\n const currentTime = new Date()\n const a = currentTime.getTime() - prevTime.getTime()\n\n return Math.floor(a / 1000)\n}\n","/**\n * lodash (Custom Build) \n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n result = wait - timeSinceLastCall;\n\n return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\n/**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n * Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\nfunction throttle(func, wait, options) {\n var leading = true,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (isObject(options)) {\n leading = 'leading' in options ? !!options.leading : leading;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n return debounce(func, wait, {\n 'leading': leading,\n 'maxWait': wait,\n 'trailing': trailing\n });\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && objectToString.call(value) == symbolTag);\n}\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = value.replace(reTrim, '');\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = throttle;\n","'use strict'\n\nconst errCode = require('err-code')\nconst { concat: uint8arraysConcat } = require('uint8arrays/concat')\nconst { fromString: uint8arraysFromString } = require('uint8arrays/from-string')\n// @ts-ignore libp2p-crypto does not support types\nconst cryptoKeys = require('libp2p-crypto/src/keys')\nconst PeerId = require('peer-id')\nconst varint = require('varint')\nconst { equals: uint8arraysEquals } = require('uint8arrays/equals')\n\nconst { codes } = require('../../errors')\nconst { Envelope: Protobuf } = require('./envelope')\n\n/**\n * @typedef {import('libp2p-interfaces/src/record/types').Record} Record\n */\n\nclass Envelope {\n /**\n * The Envelope is responsible for keeping an arbitrary signed record\n * by a libp2p peer.\n *\n * @class\n * @param {object} params\n * @param {PeerId} params.peerId\n * @param {Uint8Array} params.payloadType\n * @param {Uint8Array} params.payload - marshaled record\n * @param {Uint8Array} params.signature - signature of the domain string :: type hint :: payload.\n */\n constructor ({ peerId, payloadType, payload, signature }) {\n this.peerId = peerId\n this.payloadType = payloadType\n this.payload = payload\n this.signature = signature\n\n // Cache\n this._marshal = undefined\n }\n\n /**\n * Marshal the envelope content.\n *\n * @returns {Uint8Array}\n */\n marshal () {\n if (this._marshal) {\n return this._marshal\n }\n\n const publicKey = cryptoKeys.marshalPublicKey(this.peerId.pubKey)\n\n this._marshal = Protobuf.encode({\n publicKey: publicKey,\n payloadType: this.payloadType,\n payload: this.payload,\n signature: this.signature\n }).finish()\n\n return this._marshal\n }\n\n /**\n * Verifies if the other Envelope is identical to this one.\n *\n * @param {Envelope} other\n * @returns {boolean}\n */\n equals (other) {\n return uint8arraysEquals(this.peerId.pubKey.bytes, other.peerId.pubKey.bytes) &&\n uint8arraysEquals(this.payloadType, other.payloadType) &&\n uint8arraysEquals(this.payload, other.payload) &&\n uint8arraysEquals(this.signature, other.signature)\n }\n\n /**\n * Validate envelope data signature for the given domain.\n *\n * @param {string} domain\n * @returns {Promise}\n */\n validate (domain) {\n const signData = formatSignaturePayload(domain, this.payloadType, this.payload)\n\n return this.peerId.pubKey.verify(signData, this.signature)\n }\n}\n\n/**\n * Helper function that prepares a Uint8Array to sign or verify a signature.\n *\n * @param {string} domain\n * @param {Uint8Array} payloadType\n * @param {Uint8Array} payload\n * @returns {Uint8Array}\n */\nconst formatSignaturePayload = (domain, payloadType, payload) => {\n // When signing, a peer will prepare a Uint8Array by concatenating the following:\n // - The length of the domain separation string string in bytes\n // - The domain separation string, encoded as UTF-8\n // - The length of the payload_type field in bytes\n // - The value of the payload_type field\n // - The length of the payload field in bytes\n // - The value of the payload field\n\n const domainUint8Array = uint8arraysFromString(domain)\n const domainLength = varint.encode(domainUint8Array.byteLength)\n const payloadTypeLength = varint.encode(payloadType.length)\n const payloadLength = varint.encode(payload.length)\n\n return uint8arraysConcat([\n new Uint8Array(domainLength),\n domainUint8Array,\n new Uint8Array(payloadTypeLength),\n payloadType,\n new Uint8Array(payloadLength),\n payload\n ])\n}\n\n/**\n * Unmarshal a serialized Envelope protobuf message.\n *\n * @param {Uint8Array} data\n * @returns {Promise}\n */\nEnvelope.createFromProtobuf = async (data) => {\n const envelopeData = Protobuf.decode(data)\n const peerId = await PeerId.createFromPubKey(envelopeData.publicKey)\n\n return new Envelope({\n peerId,\n payloadType: envelopeData.payloadType,\n payload: envelopeData.payload,\n signature: envelopeData.signature\n })\n}\n\n/**\n * Seal marshals the given Record, places the marshaled bytes inside an Envelope\n * and signs it with the given peerId's private key.\n *\n * @async\n * @param {Record} record\n * @param {PeerId} peerId\n * @returns {Promise}\n */\nEnvelope.seal = async (record, peerId) => {\n const domain = record.domain\n const payloadType = record.codec\n const payload = record.marshal()\n\n const signData = formatSignaturePayload(domain, payloadType, payload)\n const signature = await peerId.privKey.sign(signData)\n\n return new Envelope({\n peerId,\n payloadType,\n payload,\n signature\n })\n}\n\n/**\n * Open and certify a given marshalled envelope.\n * Data is unmarshalled and the signature validated for the given domain.\n *\n * @param {Uint8Array} data\n * @param {string} domain\n * @returns {Promise}\n */\nEnvelope.openAndCertify = async (data, domain) => {\n const envelope = await Envelope.createFromProtobuf(data)\n const valid = await envelope.validate(domain)\n\n if (!valid) {\n throw errCode(new Error('envelope signature is not valid for the given domain'), codes.ERR_SIGNATURE_NOT_VALID)\n }\n\n return envelope\n}\n\nmodule.exports = Envelope\n","'use strict'\n\nexports.messages = {\n NOT_STARTED_YET: 'The libp2p node is not started yet',\n DHT_DISABLED: 'DHT is not available',\n CONN_ENCRYPTION_REQUIRED: 'At least one connection encryption module is required'\n}\n\nexports.codes = {\n DHT_DISABLED: 'ERR_DHT_DISABLED',\n PUBSUB_NOT_STARTED: 'ERR_PUBSUB_NOT_STARTED',\n DHT_NOT_STARTED: 'ERR_DHT_NOT_STARTED',\n CONN_ENCRYPTION_REQUIRED: 'ERR_CONN_ENCRYPTION_REQUIRED',\n ERR_INVALID_PROTOCOLS_FOR_STREAM: 'ERR_INVALID_PROTOCOLS_FOR_STREAM',\n ERR_CONNECTION_ENDED: 'ERR_CONNECTION_ENDED',\n ERR_CONNECTION_FAILED: 'ERR_CONNECTION_FAILED',\n ERR_NODE_NOT_STARTED: 'ERR_NODE_NOT_STARTED',\n ERR_ALREADY_ABORTED: 'ERR_ALREADY_ABORTED',\n ERR_TOO_MANY_ADDRESSES: 'ERR_TOO_MANY_ADDRESSES',\n ERR_NO_VALID_ADDRESSES: 'ERR_NO_VALID_ADDRESSES',\n ERR_RELAYED_DIAL: 'ERR_RELAYED_DIAL',\n ERR_DIALED_SELF: 'ERR_DIALED_SELF',\n ERR_DISCOVERED_SELF: 'ERR_DISCOVERED_SELF',\n ERR_DUPLICATE_TRANSPORT: 'ERR_DUPLICATE_TRANSPORT',\n ERR_ENCRYPTION_FAILED: 'ERR_ENCRYPTION_FAILED',\n ERR_HOP_REQUEST_FAILED: 'ERR_HOP_REQUEST_FAILED',\n ERR_INVALID_KEY: 'ERR_INVALID_KEY',\n ERR_INVALID_MESSAGE: 'ERR_INVALID_MESSAGE',\n ERR_INVALID_PARAMETERS: 'ERR_INVALID_PARAMETERS',\n ERR_INVALID_PEER: 'ERR_INVALID_PEER',\n ERR_MUXER_UNAVAILABLE: 'ERR_MUXER_UNAVAILABLE',\n ERR_TIMEOUT: 'ERR_TIMEOUT',\n ERR_TRANSPORT_UNAVAILABLE: 'ERR_TRANSPORT_UNAVAILABLE',\n ERR_TRANSPORT_DIAL_FAILED: 'ERR_TRANSPORT_DIAL_FAILED',\n ERR_UNSUPPORTED_PROTOCOL: 'ERR_UNSUPPORTED_PROTOCOL',\n ERR_INVALID_MULTIADDR: 'ERR_INVALID_MULTIADDR',\n ERR_SIGNATURE_NOT_VALID: 'ERR_SIGNATURE_NOT_VALID'\n}\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-envelope\"] || ($protobuf.roots[\"libp2p-envelope\"] = {});\n\n$root.Envelope = (function() {\n\n /**\n * Properties of an Envelope.\n * @exports IEnvelope\n * @interface IEnvelope\n * @property {Uint8Array|null} [publicKey] Envelope publicKey\n * @property {Uint8Array|null} [payloadType] Envelope payloadType\n * @property {Uint8Array|null} [payload] Envelope payload\n * @property {Uint8Array|null} [signature] Envelope signature\n */\n\n /**\n * Constructs a new Envelope.\n * @exports Envelope\n * @classdesc Represents an Envelope.\n * @implements IEnvelope\n * @constructor\n * @param {IEnvelope=} [p] Properties to set\n */\n function Envelope(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Envelope publicKey.\n * @member {Uint8Array} publicKey\n * @memberof Envelope\n * @instance\n */\n Envelope.prototype.publicKey = $util.newBuffer([]);\n\n /**\n * Envelope payloadType.\n * @member {Uint8Array} payloadType\n * @memberof Envelope\n * @instance\n */\n Envelope.prototype.payloadType = $util.newBuffer([]);\n\n /**\n * Envelope payload.\n * @member {Uint8Array} payload\n * @memberof Envelope\n * @instance\n */\n Envelope.prototype.payload = $util.newBuffer([]);\n\n /**\n * Envelope signature.\n * @member {Uint8Array} signature\n * @memberof Envelope\n * @instance\n */\n Envelope.prototype.signature = $util.newBuffer([]);\n\n /**\n * Encodes the specified Envelope message. Does not implicitly {@link Envelope.verify|verify} messages.\n * @function encode\n * @memberof Envelope\n * @static\n * @param {IEnvelope} m Envelope message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Envelope.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.publicKey != null && Object.hasOwnProperty.call(m, \"publicKey\"))\n w.uint32(10).bytes(m.publicKey);\n if (m.payloadType != null && Object.hasOwnProperty.call(m, \"payloadType\"))\n w.uint32(18).bytes(m.payloadType);\n if (m.payload != null && Object.hasOwnProperty.call(m, \"payload\"))\n w.uint32(26).bytes(m.payload);\n if (m.signature != null && Object.hasOwnProperty.call(m, \"signature\"))\n w.uint32(42).bytes(m.signature);\n return w;\n };\n\n /**\n * Decodes an Envelope message from the specified reader or buffer.\n * @function decode\n * @memberof Envelope\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Envelope} Envelope\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Envelope.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Envelope();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.publicKey = r.bytes();\n break;\n case 2:\n m.payloadType = r.bytes();\n break;\n case 3:\n m.payload = r.bytes();\n break;\n case 5:\n m.signature = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an Envelope message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Envelope\n * @static\n * @param {Object.} d Plain object\n * @returns {Envelope} Envelope\n */\n Envelope.fromObject = function fromObject(d) {\n if (d instanceof $root.Envelope)\n return d;\n var m = new $root.Envelope();\n if (d.publicKey != null) {\n if (typeof d.publicKey === \"string\")\n $util.base64.decode(d.publicKey, m.publicKey = $util.newBuffer($util.base64.length(d.publicKey)), 0);\n else if (d.publicKey.length)\n m.publicKey = d.publicKey;\n }\n if (d.payloadType != null) {\n if (typeof d.payloadType === \"string\")\n $util.base64.decode(d.payloadType, m.payloadType = $util.newBuffer($util.base64.length(d.payloadType)), 0);\n else if (d.payloadType.length)\n m.payloadType = d.payloadType;\n }\n if (d.payload != null) {\n if (typeof d.payload === \"string\")\n $util.base64.decode(d.payload, m.payload = $util.newBuffer($util.base64.length(d.payload)), 0);\n else if (d.payload.length)\n m.payload = d.payload;\n }\n if (d.signature != null) {\n if (typeof d.signature === \"string\")\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n return m;\n };\n\n /**\n * Creates a plain object from an Envelope message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Envelope\n * @static\n * @param {Envelope} m Envelope\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Envelope.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.publicKey = \"\";\n else {\n d.publicKey = [];\n if (o.bytes !== Array)\n d.publicKey = $util.newBuffer(d.publicKey);\n }\n if (o.bytes === String)\n d.payloadType = \"\";\n else {\n d.payloadType = [];\n if (o.bytes !== Array)\n d.payloadType = $util.newBuffer(d.payloadType);\n }\n if (o.bytes === String)\n d.payload = \"\";\n else {\n d.payload = [];\n if (o.bytes !== Array)\n d.payload = $util.newBuffer(d.payload);\n }\n if (o.bytes === String)\n d.signature = \"\";\n else {\n d.signature = [];\n if (o.bytes !== Array)\n d.signature = $util.newBuffer(d.signature);\n }\n }\n if (m.publicKey != null && m.hasOwnProperty(\"publicKey\")) {\n d.publicKey = o.bytes === String ? $util.base64.encode(m.publicKey, 0, m.publicKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.publicKey) : m.publicKey;\n }\n if (m.payloadType != null && m.hasOwnProperty(\"payloadType\")) {\n d.payloadType = o.bytes === String ? $util.base64.encode(m.payloadType, 0, m.payloadType.length) : o.bytes === Array ? Array.prototype.slice.call(m.payloadType) : m.payloadType;\n }\n if (m.payload != null && m.hasOwnProperty(\"payload\")) {\n d.payload = o.bytes === String ? $util.base64.encode(m.payload, 0, m.payload.length) : o.bytes === Array ? Array.prototype.slice.call(m.payload) : m.payload;\n }\n if (m.signature != null && m.hasOwnProperty(\"signature\")) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n }\n return d;\n };\n\n /**\n * Converts this Envelope to JSON.\n * @function toJSON\n * @memberof Envelope\n * @instance\n * @returns {Object.} JSON object\n */\n Envelope.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Envelope;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { base58btc } = require('multiformats/bases/base58')\nconst { default: PQueue } = require('p-queue')\nconst defer = require('p-defer')\nconst debug = require('debug')\n\nconst log = debug('libp2p-delegated-peer-routing')\nlog.error = debug('libp2p-delegated-peer-routing:error')\n\nconst DEFAULT_TIMEOUT = 30e3 // 30 second default\nconst CONCURRENT_HTTP_REQUESTS = 4\n\nclass DelegatedPeerRouting {\n /**\n * Create a new DelegatedPeerRouting instance.\n *\n * @param {object} client - an instance of the ipfs-http-client module\n */\n constructor (client) {\n if (client == null) {\n throw new Error('missing ipfs http client')\n }\n\n this._client = client\n\n // limit concurrency to avoid request flood in web browser\n // https://github.com/libp2p/js-libp2p-delegated-content-routing/issues/12\n this._httpQueue = new PQueue({\n concurrency: CONCURRENT_HTTP_REQUESTS\n })\n\n const {\n protocol,\n host,\n port\n } = client.getEndpointConfig()\n\n log(`enabled DelegatedPeerRouting via ${protocol}://${host}:${port}`)\n }\n\n /**\n * Attempts to find the given peer\n *\n * @param {PeerID} id\n * @param {object} options\n * @param {number} options.timeout - How long the query can take. Defaults to 30 seconds\n * @returns {Promise<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async findPeer (id, options = {}) {\n let idStr = id\n if (PeerId.isPeerId(idStr)) {\n idStr = id.toB58String()\n }\n\n log('findPeer starts: ' + id)\n\n options.timeout = options.timeout || DEFAULT_TIMEOUT\n\n try {\n return await this._httpQueue.add(async () => {\n const { addrs } = await this._client.dht.findPeer(idStr, {\n timeout: options.timeout\n })\n\n return {\n id,\n multiaddrs: addrs\n }\n })\n } catch (err) {\n if (err.message.includes('not found')) {\n return undefined\n }\n\n throw err\n } finally {\n log('findPeer finished: ' + id)\n }\n }\n\n /**\n * Attempt to find the closest peers on the network to the given key\n *\n * @param {Uint8Array} key - A CID like key\n * @param {object} [options]\n * @param {number} [options.timeout=30e3] - How long the query can take.\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * getClosestPeers (key, options = {}) {\n const keyStr = base58btc.encode(key).substring(1)\n\n log('getClosestPeers starts:', keyStr)\n options.timeout = options.timeout || DEFAULT_TIMEOUT\n\n const onStart = defer()\n const onFinish = defer()\n\n this._httpQueue.add(() => {\n onStart.resolve()\n return onFinish.promise\n })\n\n try {\n await onStart.promise\n\n const peers = new Map()\n\n for await (const result of this._client.dht.query(keyStr, {\n timeout: options.timeout\n })) {\n switch (result.type) {\n case 1: // Found Closer\n // Track the addresses, so we can yield them when done\n result.responses.forEach(response => {\n peers.set(response.id, {\n id: PeerId.parse(response.id),\n multiaddrs: response.addrs\n })\n })\n break\n case 2: // Final Peer\n yield peers.get(result.id.string) || {\n id: PeerId.createFromCID(result.id),\n multiaddrs: []\n }\n break\n default:\n log('getClosestPeers unhandled response', result)\n }\n }\n } catch (err) {\n log.error('getClosestPeers errored:', err)\n throw err\n } finally {\n onFinish.resolve()\n log('getClosestPeers finished:', keyStr)\n }\n }\n}\n\nmodule.exports = DelegatedPeerRouting\n","'use strict'\n\nconst debug = require('debug')\nconst PeerId = require('peer-id')\nconst drain = require('it-drain')\n\nconst { default: PQueue } = require('p-queue')\nconst defer = require('p-defer')\n\nconst log = debug('libp2p-delegated-content-routing')\nlog.error = debug('libp2p-delegated-content-routing:error')\n\nconst DEFAULT_TIMEOUT = 30e3 // 30 second default\nconst CONCURRENT_HTTP_REQUESTS = 4\n\n/**\n * @typedef {import('peer-id').PeerID} PeerID\n * @typedef {import('cids').CID} CID\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * An implementation of content routing, using a delegated peer.\n */\nclass DelegatedContentRouting {\n /**\n * Create a new DelegatedContentRouting instance.\n *\n * @param {PeerID} peerId - the id of the node that is using this routing.\n * @param {object} client - an instance of the ipfs-http-client module\n */\n constructor (peerId, client) {\n if (peerId == null) {\n throw new Error('missing self peerId')\n }\n\n if (client == null) {\n throw new Error('missing ipfs http client')\n }\n\n this._client = client\n this.peerId = peerId\n\n // limit concurrency to avoid request flood in web browser\n // https://github.com/libp2p/js-libp2p-delegated-content-routing/issues/12\n const concurrency = { concurrency: CONCURRENT_HTTP_REQUESTS }\n this._httpQueue = new PQueue(concurrency)\n // sometimes refs requests take long time, they need separate queue\n // to not suffocate regular business\n this._httpQueueRefs = new PQueue(Object.assign({}, concurrency, {\n concurrency: 2\n }))\n\n const {\n protocol,\n host,\n port\n } = client.getEndpointConfig()\n\n log(`enabled DelegatedContentRouting via ${protocol}://${host}:${port}`)\n }\n\n /**\n * Search the dht for providers of the given CID.\n *\n * - call `findProviders` on the delegated node.\n *\n * @param {CID} key - The CID to find providers for\n * @param {object} options - Options\n * @param {number} options.timeout - How long the query can take. Defaults to 30 seconds\n * @param {number} options.numProviders - How many providers to find, defaults to 20\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} - An async iterable of PeerId/Multiaddrs\n */\n async * findProviders (key, options = {}) {\n log(`findProviders starts: ${key}`)\n options.timeout = options.timeout || DEFAULT_TIMEOUT\n\n let providers = 0\n const onStart = defer()\n const onFinish = defer()\n\n this._httpQueue.add(() => {\n onStart.resolve()\n return onFinish.promise\n })\n\n try {\n await onStart.promise\n\n for await (const { id, addrs } of this._client.dht.findProvs(key, {\n numProviders: options.numProviders,\n timeout: options.timeout\n })) {\n yield {\n id: PeerId.parse(id),\n multiaddrs: addrs\n }\n providers++\n }\n } catch (err) {\n log.error('findProviders errored:', err)\n throw err\n } finally {\n onFinish.resolve()\n log(`findProviders finished: ${key} found ${providers} providers`)\n }\n }\n\n /**\n * Announce to the network that the delegated node can provide the given key.\n *\n * Currently this uses the following hack\n * - delegate is one of bootstrap nodes, so we are always connected to it\n * - call block stat on the delegated node, so it fetches the content\n * - call dht provide with the passed cid\n *\n * N.B. this must be called for every block in the dag you want provided otherwise\n * the delegate will only be able to supply the root block of the dag when asked\n * for the data by an interested peer.\n *\n * @param {CID} key - The delegate will publish a provider record for this CID\n * @returns {Promise}\n */\n async provide (key) {\n log(`provide starts: ${key}`)\n await this._httpQueueRefs.add(async () => {\n await this._client.block.stat(key)\n await drain(this._client.dht.provide(key))\n })\n log(`provide finished: ${key}`)\n }\n}\n\nmodule.exports = DelegatedContentRouting\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multibases = require('ipfs-core-utils/multibases');\nvar multicodecs = require('ipfs-core-utils/multicodecs');\nvar multihashes = require('ipfs-core-utils/multihashes');\nvar dagPB = require('@ipld/dag-pb');\nvar dagCBOR = require('@ipld/dag-cbor');\nvar identity = require('multiformats/hashes/identity');\nvar basics = require('multiformats/basics');\nvar index = require('./bitswap/index.js');\nvar index$1 = require('./block/index.js');\nvar index$2 = require('./bootstrap/index.js');\nvar index$3 = require('./config/index.js');\nvar index$4 = require('./dag/index.js');\nvar index$5 = require('./dht/index.js');\nvar index$6 = require('./diag/index.js');\nvar index$7 = require('./files/index.js');\nvar index$8 = require('./key/index.js');\nvar index$9 = require('./log/index.js');\nvar index$a = require('./name/index.js');\nvar index$b = require('./object/index.js');\nvar index$c = require('./pin/index.js');\nvar index$d = require('./pubsub/index.js');\nvar index$e = require('./refs/index.js');\nvar index$f = require('./repo/index.js');\nvar index$g = require('./stats/index.js');\nvar index$h = require('./swarm/index.js');\nvar add = require('./add.js');\nvar addAll = require('./add-all.js');\nvar cat = require('./cat.js');\nvar commands = require('./commands.js');\nvar dns = require('./dns.js');\nvar getEndpointConfig = require('./get-endpoint-config.js');\nvar get = require('./get.js');\nvar id = require('./id.js');\nvar isOnline = require('./is-online.js');\nvar ls = require('./ls.js');\nvar mount = require('./mount.js');\nvar ping = require('./ping.js');\nvar resolve = require('./resolve.js');\nvar start = require('./start.js');\nvar stop = require('./stop.js');\nvar version = require('./version.js');\nvar globSourceImport = require('ipfs-utils/src/files/glob-source.js');\nvar cid = require('multiformats/cid');\nvar multiaddr = require('multiaddr');\nvar urlSource_js = require('ipfs-utils/src/files/url-source.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar dagCBOR__namespace = /*#__PURE__*/_interopNamespace(dagCBOR);\nvar globSourceImport__default = /*#__PURE__*/_interopDefaultLegacy(globSourceImport);\nvar urlSource_js__default = /*#__PURE__*/_interopDefaultLegacy(urlSource_js);\n\nfunction create(options = {}) {\n const id$1 = {\n name: identity.identity.name,\n code: identity.identity.code,\n encode: id => id,\n decode: id => id\n };\n const multibaseCodecs = Object.values(basics.bases);\n (options.ipld && options.ipld.bases ? options.ipld.bases : []).forEach(base => multibaseCodecs.push(base));\n const multibases$1 = new multibases.Multibases({\n bases: multibaseCodecs,\n loadBase: options.ipld && options.ipld.loadBase\n });\n const blockCodecs = Object.values(basics.codecs);\n [\n dagPB__namespace,\n dagCBOR__namespace,\n id$1\n ].concat(options.ipld && options.ipld.codecs || []).forEach(codec => blockCodecs.push(codec));\n const multicodecs$1 = new multicodecs.Multicodecs({\n codecs: blockCodecs,\n loadCodec: options.ipld && options.ipld.loadCodec\n });\n const multihashHashers = Object.values(basics.hashes);\n (options.ipld && options.ipld.hashers ? options.ipld.hashers : []).forEach(hasher => multihashHashers.push(hasher));\n const multihashes$1 = new multihashes.Multihashes({\n hashers: multihashHashers,\n loadHasher: options.ipld && options.ipld.loadHasher\n });\n const client = {\n add: add.createAdd(options),\n addAll: addAll.createAddAll(options),\n bitswap: index.createBitswap(options),\n block: index$1.createBlock(options),\n bootstrap: index$2.createBootstrap(options),\n cat: cat.createCat(options),\n commands: commands.createCommands(options),\n config: index$3.createConfig(options),\n dag: index$4.createDag(multicodecs$1, options),\n dht: index$5.createDht(options),\n diag: index$6.createDiag(options),\n dns: dns.createDns(options),\n files: index$7.createFiles(options),\n get: get.createGet(options),\n getEndpointConfig: getEndpointConfig.createGetEndpointConfig(options),\n id: id.createId(options),\n isOnline: isOnline.createIsOnline(options),\n key: index$8.createKey(options),\n log: index$9.createLog(options),\n ls: ls.createLs(options),\n mount: mount.createMount(options),\n name: index$a.createName(options),\n object: index$b.createObject(multicodecs$1, options),\n pin: index$c.createPin(options),\n ping: ping.createPing(options),\n pubsub: index$d.createPubsub(options),\n refs: index$e.createRefs(options),\n repo: index$f.createRepo(options),\n resolve: resolve.createResolve(options),\n start: start.createStart(options),\n stats: index$g.createStats(options),\n stop: stop.createStop(options),\n swarm: index$h.createSwarm(options),\n version: version.createVersion(options),\n bases: multibases$1,\n codecs: multicodecs$1,\n hashers: multihashes$1\n };\n return client;\n}\nconst globSource = globSourceImport__default['default'];\n\nObject.defineProperty(exports, 'CID', {\n enumerable: true,\n get: function () {\n return cid.CID;\n }\n});\nObject.defineProperty(exports, 'multiaddr', {\n enumerable: true,\n get: function () {\n return multiaddr.Multiaddr;\n }\n});\nObject.defineProperty(exports, 'urlSource', {\n enumerable: true,\n get: function () {\n return urlSource_js__default['default'];\n }\n});\nexports.create = create;\nexports.globSource = globSource;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst LOAD_BASE = name => Promise.reject(new Error(`No base found for \"${ name }\"`));\nclass Multibases {\n constructor(options) {\n this._basesByName = {};\n this._basesByPrefix = {};\n this._loadBase = options.loadBase || LOAD_BASE;\n for (const base of options.bases) {\n this.addBase(base);\n }\n }\n addBase(base) {\n if (this._basesByName[base.name] || this._basesByPrefix[base.prefix]) {\n throw new Error(`Codec already exists for codec \"${ base.name }\"`);\n }\n this._basesByName[base.name] = base;\n this._basesByPrefix[base.prefix] = base;\n }\n removeBase(base) {\n delete this._basesByName[base.name];\n delete this._basesByPrefix[base.prefix];\n }\n async getBase(nameOrPrefix) {\n if (this._basesByName[nameOrPrefix]) {\n return this._basesByName[nameOrPrefix];\n }\n if (this._basesByPrefix[nameOrPrefix]) {\n return this._basesByPrefix[nameOrPrefix];\n }\n const base = await this._loadBase(nameOrPrefix);\n if (this._basesByName[base.name] == null && this._basesByPrefix[base.prefix] == null) {\n this.addBase(base);\n }\n return base;\n }\n listBases() {\n return Object.values(this._basesByName);\n }\n}\n\nexports.Multibases = Multibases;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst LOAD_CODEC = codeOrName => Promise.reject(new Error(`No codec found for \"${ codeOrName }\"`));\nclass Multicodecs {\n constructor(options) {\n this._codecsByName = {};\n this._codecsByCode = {};\n this._loadCodec = options.loadCodec || LOAD_CODEC;\n for (const codec of options.codecs) {\n this.addCodec(codec);\n }\n }\n addCodec(codec) {\n if (this._codecsByName[codec.name] || this._codecsByCode[codec.code]) {\n throw new Error(`Resolver already exists for codec \"${ codec.name }\"`);\n }\n this._codecsByName[codec.name] = codec;\n this._codecsByCode[codec.code] = codec;\n }\n removeCodec(codec) {\n delete this._codecsByName[codec.name];\n delete this._codecsByCode[codec.code];\n }\n async getCodec(code) {\n const table = typeof code === 'string' ? this._codecsByName : this._codecsByCode;\n if (table[code]) {\n return table[code];\n }\n const codec = await this._loadCodec(code);\n if (table[code] == null) {\n this.addCodec(codec);\n }\n return codec;\n }\n listCodecs() {\n return Object.values(this._codecsByName);\n }\n}\n\nexports.Multicodecs = Multicodecs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst LOAD_HASHER = codeOrName => Promise.reject(new Error(`No hasher found for \"${ codeOrName }\"`));\nclass Multihashes {\n constructor(options) {\n this._hashersByName = {};\n this._hashersByCode = {};\n this._loadHasher = options.loadHasher || LOAD_HASHER;\n for (const hasher of options.hashers) {\n this.addHasher(hasher);\n }\n }\n addHasher(hasher) {\n if (this._hashersByName[hasher.name] || this._hashersByCode[hasher.code]) {\n throw new Error(`Resolver already exists for codec \"${ hasher.name }\"`);\n }\n this._hashersByName[hasher.name] = hasher;\n this._hashersByCode[hasher.code] = hasher;\n }\n removeHasher(hasher) {\n delete this._hashersByName[hasher.name];\n delete this._hashersByCode[hasher.code];\n }\n async getHasher(code) {\n const table = typeof code === 'string' ? this._hashersByName : this._hashersByCode;\n if (table[code]) {\n return table[code];\n }\n const hasher = await this._loadHasher(code);\n if (table[code] == null) {\n this.addHasher(hasher);\n }\n return hasher;\n }\n listHashers() {\n return Object.values(this._hashersByName);\n }\n}\n\nexports.Multihashes = Multihashes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar wantlist = require('./wantlist.js');\nvar wantlistForPeer = require('./wantlist-for-peer.js');\nvar stat = require('./stat.js');\nvar unwant = require('./unwant.js');\n\nfunction createBitswap(config) {\n return {\n wantlist: wantlist.createWantlist(config),\n wantlistForPeer: wantlistForPeer.createWantlistForPeer(config),\n unwant: unwant.createUnwant(config),\n stat: stat.createStat(config)\n };\n}\n\nexports.createBitswap = createBitswap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createWantlist = configure.configure(api => {\n async function wantlist(options = {}) {\n const res = await (await api.post('bitswap/wantlist', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n })).json();\n return (res.Keys || []).map(k => cid.CID.parse(k['/']));\n }\n return wantlist;\n});\n\nexports.createWantlist = createWantlist;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar core = require('./core.js');\n\nconst configure = fn => {\n return options => {\n return fn(new core.Client(options), options);\n };\n};\n\nexports.configure = configure;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar env_js = require('ipfs-utils/src/env.js');\nvar parseDuration = require('parse-duration');\nvar debug = require('debug');\nvar HTTP = require('ipfs-utils/src/http.js');\nvar mergeOpts = require('merge-options');\nvar toUrlString = require('ipfs-core-utils/to-url-string');\nvar getAgent = require('ipfs-core-utils/agent');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar parseDuration__default = /*#__PURE__*/_interopDefaultLegacy(parseDuration);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar HTTP__default = /*#__PURE__*/_interopDefaultLegacy(HTTP);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar getAgent__default = /*#__PURE__*/_interopDefaultLegacy(getAgent);\n\nconst log = debug__default['default']('ipfs-http-client:lib:error-handler');\nconst merge = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst DEFAULT_PROTOCOL = env_js.isBrowser || env_js.isWebWorker ? location.protocol : 'http';\nconst DEFAULT_HOST = env_js.isBrowser || env_js.isWebWorker ? location.hostname : 'localhost';\nconst DEFAULT_PORT = env_js.isBrowser || env_js.isWebWorker ? location.port : '5001';\nconst normalizeOptions = (options = {}) => {\n let url;\n let opts = {};\n let agent;\n if (typeof options === 'string' || multiaddr.Multiaddr.isMultiaddr(options)) {\n url = new URL(toUrlString.toUrlString(options));\n } else if (options instanceof URL) {\n url = options;\n } else if (typeof options.url === 'string' || multiaddr.Multiaddr.isMultiaddr(options.url)) {\n url = new URL(toUrlString.toUrlString(options.url));\n opts = options;\n } else if (options.url instanceof URL) {\n url = options.url;\n opts = options;\n } else {\n opts = options || {};\n const protocol = (opts.protocol || DEFAULT_PROTOCOL).replace(':', '');\n const host = (opts.host || DEFAULT_HOST).split(':')[0];\n const port = opts.port || DEFAULT_PORT;\n url = new URL(`${ protocol }://${ host }:${ port }`);\n }\n if (opts.apiPath) {\n url.pathname = opts.apiPath;\n } else if (url.pathname === '/' || url.pathname === undefined) {\n url.pathname = 'api/v0';\n }\n if (env_js.isNode) {\n const Agent = getAgent__default['default'](url);\n agent = opts.agent || new Agent({\n keepAlive: true,\n maxSockets: 6\n });\n }\n return {\n ...opts,\n host: url.host,\n protocol: url.protocol.replace(':', ''),\n port: Number(url.port),\n apiPath: url.pathname,\n url,\n agent\n };\n};\nconst errorHandler = async response => {\n let msg;\n try {\n if ((response.headers.get('Content-Type') || '').startsWith('application/json')) {\n const data = await response.json();\n log(data);\n msg = data.Message || data.message;\n } else {\n msg = await response.text();\n }\n } catch (err) {\n log('Failed to parse error response', err);\n msg = err.message;\n }\n let error = new HTTP__default['default'].HTTPError(response);\n if (msg) {\n if (msg.includes('deadline has elapsed')) {\n error = new HTTP__default['default'].TimeoutError();\n }\n if (msg && msg.includes('context deadline exceeded')) {\n error = new HTTP__default['default'].TimeoutError();\n }\n }\n if (msg && msg.includes('request timed out')) {\n error = new HTTP__default['default'].TimeoutError();\n }\n if (msg) {\n error.message = msg;\n }\n throw error;\n};\nconst KEBAB_REGEX = /[A-Z\\u00C0-\\u00D6\\u00D8-\\u00DE]/g;\nconst kebabCase = str => {\n return str.replace(KEBAB_REGEX, function (match) {\n return '-' + match.toLowerCase();\n });\n};\nconst parseTimeout = value => {\n return typeof value === 'string' ? parseDuration__default['default'](value) : value;\n};\nclass Client extends HTTP__default['default'] {\n constructor(options = {}) {\n const opts = normalizeOptions(options);\n super({\n timeout: parseTimeout(opts.timeout || 0) || undefined,\n headers: opts.headers,\n base: `${ opts.url }`,\n handleError: errorHandler,\n transformSearchParams: search => {\n const out = new URLSearchParams();\n for (const [key, value] of search) {\n if (value !== 'undefined' && value !== 'null' && key !== 'signal') {\n out.append(kebabCase(key), value);\n }\n if (key === 'timeout' && !isNaN(value)) {\n out.append(kebabCase(key), value);\n }\n }\n return out;\n },\n agent: opts.agent\n });\n delete this.get;\n delete this.put;\n delete this.delete;\n delete this.options;\n const fetch = this.fetch;\n this.fetch = (resource, options = {}) => {\n if (typeof resource === 'string' && !resource.startsWith('/')) {\n resource = `${ opts.url }/${ resource }`;\n }\n return fetch.call(this, resource, merge(options, { method: 'POST' }));\n };\n }\n}\nconst HTTPError = HTTP__default['default'].HTTPError;\n\nexports.Client = Client;\nexports.HTTPError = HTTPError;\nexports.errorHandler = errorHandler;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar multiAddrToUri = require('multiaddr-to-uri');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar multiAddrToUri__default = /*#__PURE__*/_interopDefaultLegacy(multiAddrToUri);\n\nfunction toUrlString(url) {\n try {\n url = multiAddrToUri__default['default'](new multiaddr.Multiaddr(url));\n } catch (err) {\n }\n url = url.toString();\n return url;\n}\n\nexports.toUrlString = toUrlString;\n","'use strict';\n\nvar agent_browser = () => {\n};\n\nmodule.exports = agent_browser;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar modeToString = require('./mode-to-string.js');\nvar parseMtime = require('./parse-mtime.js');\n\nfunction toUrlSearchParams({arg, searchParams, hashAlg, mtime, mode, ...options} = {}) {\n if (searchParams) {\n options = {\n ...options,\n ...searchParams\n };\n }\n if (hashAlg) {\n options.hash = hashAlg;\n }\n if (mtime != null) {\n mtime = parseMtime.parseMtime(mtime);\n options.mtime = mtime.secs;\n options.mtimeNsecs = mtime.nsecs;\n }\n if (mode != null) {\n options.mode = modeToString.modeToString(mode);\n }\n if (options.timeout && !isNaN(options.timeout)) {\n options.timeout = `${ options.timeout }ms`;\n }\n if (arg === undefined || arg === null) {\n arg = [];\n } else if (!Array.isArray(arg)) {\n arg = [arg];\n }\n const urlSearchParams = new URLSearchParams(options);\n arg.forEach(arg => urlSearchParams.append('arg', arg));\n return urlSearchParams;\n}\n\nexports.toUrlSearchParams = toUrlSearchParams;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction modeToString(mode) {\n if (mode == null) {\n return undefined;\n }\n if (typeof mode === 'string') {\n return mode;\n }\n return mode.toString(8).padStart(4, '0');\n}\n\nexports.modeToString = modeToString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction parseMtime(input) {\n if (input == null) {\n return undefined;\n }\n let mtime;\n if (input.secs != null) {\n mtime = {\n secs: input.secs,\n nsecs: input.nsecs\n };\n }\n if (input.Seconds != null) {\n mtime = {\n secs: input.Seconds,\n nsecs: input.FractionalNanoseconds\n };\n }\n if (Array.isArray(input)) {\n mtime = {\n secs: input[0],\n nsecs: input[1]\n };\n }\n if (input instanceof Date) {\n const ms = input.getTime();\n const secs = Math.floor(ms / 1000);\n mtime = {\n secs: secs,\n nsecs: (ms - secs * 1000) * 1000\n };\n }\n if (!Object.prototype.hasOwnProperty.call(mtime, 'secs')) {\n return undefined;\n }\n if (mtime != null && mtime.nsecs != null && (mtime.nsecs < 0 || mtime.nsecs > 999999999)) {\n throw errCode__default['default'](new Error('mtime-nsecs must be within the range [0,999999999]'), 'ERR_INVALID_MTIME_NSECS');\n }\n return mtime;\n}\n\nexports.parseMtime = parseMtime;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createWantlistForPeer = configure.configure(api => {\n async function wantlistForPeer(peerId, options = {}) {\n const res = await (await api.post('bitswap/wantlist', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n peer: peerId.toString()\n }),\n headers: options.headers\n })).json();\n return (res.Keys || []).map(k => cid.CID.parse(k['/']));\n }\n return wantlistForPeer;\n});\n\nexports.createWantlistForPeer = createWantlistForPeer;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(options = {}) {\n const res = await api.post('bitswap/stat', {\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n signal: options.signal,\n headers: options.headers\n });\n return toCoreInterface(await res.json());\n }\n return stat;\n});\nfunction toCoreInterface(res) {\n return {\n provideBufLen: res.ProvideBufLen,\n wantlist: (res.Wantlist || []).map(k => cid.CID.parse(k['/'])),\n peers: res.Peers || [],\n blocksReceived: BigInt(res.BlocksReceived),\n dataReceived: BigInt(res.DataReceived),\n blocksSent: BigInt(res.BlocksSent),\n dataSent: BigInt(res.DataSent),\n dupBlksReceived: BigInt(res.DupBlksReceived),\n dupDataReceived: BigInt(res.DupDataReceived)\n };\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createUnwant = configure.configure(api => {\n async function unwant(cid, options = {}) {\n const res = await api.post('bitswap/unwant', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.toString(),\n ...options\n }),\n headers: options.headers\n });\n return res.json();\n }\n return unwant;\n});\n\nexports.createUnwant = createUnwant;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar get = require('./get.js');\nvar put = require('./put.js');\nvar rm = require('./rm.js');\nvar stat = require('./stat.js');\n\nfunction createBlock(config) {\n return {\n get: get.createGet(config),\n put: put.createPut(config),\n rm: rm.createRm(config),\n stat: stat.createStat(config)\n };\n}\n\nexports.createBlock = createBlock;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGet = configure.configure(api => {\n async function get(cid, options = {}) {\n const res = await api.post('block/get', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.toString(),\n ...options\n }),\n headers: options.headers\n });\n return new Uint8Array(await res.arrayBuffer());\n }\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createPut = configure.configure(api => {\n async function put(data, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n let res;\n try {\n const response = await api.post('block/put', {\n signal: signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n ...await multipartRequest.multipartRequest(data, controller, options.headers)\n });\n res = await response.json();\n } catch (err) {\n if (options.format === 'dag-pb') {\n return put(data, {\n ...options,\n format: 'protobuf'\n });\n } else if (options.format === 'dag-cbor') {\n return put(data, {\n ...options,\n format: 'cbor'\n });\n }\n throw err;\n }\n return cid.CID.parse(res.Key);\n }\n return put;\n});\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseInput_browser = require('./files/normalise-input.browser.js');\nvar modeToString = require('./mode-to-string.js');\n\nasync function multipartRequest(source, abortController, headers = {}) {\n const parts = [];\n const formData = new FormData();\n let index = 0;\n let total = 0;\n for await (const {content, path, mode, mtime} of normaliseInput_browser.normaliseInput(source)) {\n let fileSuffix = '';\n const type = content ? 'file' : 'dir';\n if (index > 0) {\n fileSuffix = `-${ index }`;\n }\n let fieldName = type + fileSuffix;\n const qs = [];\n if (mode !== null && mode !== undefined) {\n qs.push(`mode=${ modeToString.modeToString(mode) }`);\n }\n if (mtime != null) {\n const {secs, nsecs} = mtime;\n qs.push(`mtime=${ secs }`);\n if (nsecs != null) {\n qs.push(`mtime-nsecs=${ nsecs }`);\n }\n }\n if (qs.length) {\n fieldName = `${ fieldName }?${ qs.join('&') }`;\n }\n if (content) {\n formData.set(fieldName, content, path != null ? encodeURIComponent(path) : undefined);\n const end = total + content.size;\n parts.push({\n name: path,\n start: total,\n end\n });\n total = end;\n } else if (path != null) {\n formData.set(fieldName, new File([''], encodeURIComponent(path), { type: 'application/x-directory' }));\n } else {\n throw new Error('path or content or both must be set');\n }\n index++;\n }\n return {\n total,\n parts,\n headers,\n body: formData\n };\n}\n\nexports.multipartRequest = multipartRequest;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseContent_browser = require('./normalise-content.browser.js');\nvar normalise = require('./normalise.js');\n\nfunction normaliseInput(input) {\n return normalise.normalise(input, normaliseContent_browser.normaliseContent);\n}\n\nexports.normaliseInput = normaliseInput;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar itPeekable = require('it-peekable');\nvar browserStreamToIt = require('browser-readablestream-to-it');\nvar all = require('it-all');\nvar utils = require('./utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar itPeekable__default = /*#__PURE__*/_interopDefaultLegacy(itPeekable);\nvar browserStreamToIt__default = /*#__PURE__*/_interopDefaultLegacy(browserStreamToIt);\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\n\nasync function normaliseContent(input) {\n if (utils.isBytes(input)) {\n return new Blob([input]);\n }\n if (typeof input === 'string' || input instanceof String) {\n return new Blob([input.toString()]);\n }\n if (utils.isBlob(input)) {\n return input;\n }\n if (utils.isReadableStream(input)) {\n input = browserStreamToIt__default['default'](input);\n }\n if (Symbol.iterator in input || Symbol.asyncIterator in input) {\n const peekable = itPeekable__default['default'](input);\n const {value, done} = await peekable.peek();\n if (done) {\n return itToBlob(peekable);\n }\n peekable.push(value);\n if (Number.isInteger(value)) {\n return new Blob([Uint8Array.from(await all__default['default'](peekable))]);\n }\n if (utils.isBytes(value) || typeof value === 'string' || value instanceof String) {\n return itToBlob(peekable);\n }\n }\n throw errCode__default['default'](new Error(`Unexpected input: ${ input }`), 'ERR_UNEXPECTED_INPUT');\n}\nasync function itToBlob(stream) {\n const parts = [];\n for await (const chunk of stream) {\n parts.push(chunk);\n }\n return new Blob(parts);\n}\n\nexports.normaliseContent = normaliseContent;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction modeToString(mode) {\n if (mode == null) {\n return undefined;\n }\n if (typeof mode === 'string') {\n return mode;\n }\n return mode.toString(8).padStart(4, '0');\n}\n\nexports.modeToString = modeToString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar anySignal = require('any-signal');\n\nfunction filter(signals) {\n return signals.filter(Boolean);\n}\nfunction abortSignal(...signals) {\n return anySignal.anySignal(filter(signals));\n}\n\nexports.abortSignal = abortSignal;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRm = configure.configure(api => {\n async function* rm(cid, options = {}) {\n if (!Array.isArray(cid)) {\n cid = [cid];\n }\n const res = await api.post('block/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.map(cid => cid.toString()),\n 'stream-channels': true,\n ...options\n }),\n headers: options.headers\n });\n for await (const removed of res.ndjson()) {\n yield toCoreInterface(removed);\n }\n }\n return rm;\n});\nfunction toCoreInterface(removed) {\n const out = { cid: cid.CID.parse(removed.Hash) };\n if (removed.Error) {\n out.error = new Error(removed.Error);\n }\n return out;\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(cid$1, options = {}) {\n const res = await api.post('block/stat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid$1.toString(),\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return {\n cid: cid.CID.parse(data.Key),\n size: data.Size\n };\n }\n return stat;\n});\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar add = require('./add.js');\nvar clear = require('./clear.js');\nvar list = require('./list.js');\nvar reset = require('./reset.js');\nvar rm = require('./rm.js');\n\nfunction createBootstrap(config) {\n return {\n add: add.createAdd(config),\n clear: clear.createClear(config),\n list: list.createList(config),\n reset: reset.createReset(config),\n rm: rm.createRm(config)\n };\n}\n\nexports.createBootstrap = createBootstrap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createAdd = configure.configure(api => {\n async function add(addr, options = {}) {\n const res = await api.post('bootstrap/add', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: addr,\n ...options\n }),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return add;\n});\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createClear = configure.configure(api => {\n async function clear(options = {}) {\n const res = await api.post('bootstrap/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n all: true\n }),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return clear;\n});\n\nexports.createClear = createClear;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createList = configure.configure(api => {\n async function list(options = {}) {\n const res = await api.post('bootstrap/list', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return list;\n});\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createReset = configure.configure(api => {\n async function reset(options = {}) {\n const res = await api.post('bootstrap/add', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n default: true\n }),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return reset;\n});\n\nexports.createReset = createReset;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createRm = configure.configure(api => {\n async function rm(addr, options = {}) {\n const res = await api.post('bootstrap/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: addr,\n ...options\n }),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return rm;\n});\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('./profiles/index.js');\nvar get = require('./get.js');\nvar getAll = require('./get-all.js');\nvar replace = require('./replace.js');\nvar set = require('./set.js');\n\nfunction createConfig(config) {\n return {\n getAll: getAll.createGetAll(config),\n get: get.createGet(config),\n set: set.createSet(config),\n replace: replace.createReplace(config),\n profiles: index.createProfiles(config)\n };\n}\n\nexports.createConfig = createConfig;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar apply = require('./apply.js');\nvar list = require('./list.js');\n\nfunction createProfiles(config) {\n return {\n apply: apply.createApply(config),\n list: list.createList(config)\n };\n}\n\nexports.createProfiles = createProfiles;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createApply = configure.configure(api => {\n async function apply(profile, options = {}) {\n const res = await api.post('config/profile/apply', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: profile,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return {\n original: data.OldCfg,\n updated: data.NewCfg\n };\n }\n return apply;\n});\n\nexports.createApply = createApply;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../../lib/object-to-camel.js');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createList = configure.configure(api => {\n async function list(options = {}) {\n const res = await api.post('config/profile/list', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return data.map(profile => objectToCamel.objectToCamel(profile));\n }\n return list;\n});\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction objectToCamel(obj) {\n if (obj == null) {\n return obj;\n }\n const caps = /^[A-Z]+$/;\n const output = {};\n return Object.keys(obj).reduce((camelObj, k) => {\n if (caps.test(k)) {\n camelObj[k.toLowerCase()] = obj[k];\n } else if (caps.test(k[0])) {\n camelObj[k[0].toLowerCase() + k.slice(1)] = obj[k];\n } else {\n camelObj[k] = obj[k];\n }\n return camelObj;\n }, output);\n}\n\nexports.objectToCamel = objectToCamel;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGet = configure.configure(api => {\n const get = async (key, options = {}) => {\n if (!key) {\n throw new Error('key argument is required');\n }\n const res = await api.post('config', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: key,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return data.Value;\n };\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGetAll = configure.configure(api => {\n const getAll = async (options = {}) => {\n const res = await api.post('config/show', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({ ...options }),\n headers: options.headers\n });\n const data = await res.json();\n return data;\n };\n return getAll;\n});\n\nexports.createGetAll = createGetAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar fromString = require('uint8arrays/from-string');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createReplace = configure.configure(api => {\n const replace = async (config, options = {}) => {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('config/replace', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n ...await multipartRequest.multipartRequest(fromString.fromString(JSON.stringify(config)), controller, options.headers)\n });\n await res.text();\n };\n return replace;\n});\n\nexports.createReplace = createReplace;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createSet = configure.configure(api => {\n const set = async (key, value, options = {}) => {\n if (typeof key !== 'string') {\n throw new Error('Invalid key type');\n }\n const params = {\n ...options,\n ...encodeParam(key, value)\n };\n const res = await api.post('config', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(params),\n headers: options.headers\n });\n await res.text();\n };\n return set;\n});\nconst encodeParam = (key, value) => {\n switch (typeof value) {\n case 'boolean':\n return {\n arg: [\n key,\n value.toString()\n ],\n bool: true\n };\n case 'string':\n return {\n arg: [\n key,\n value\n ]\n };\n default:\n return {\n arg: [\n key,\n JSON.stringify(value)\n ],\n json: true\n };\n }\n};\n\nexports.createSet = createSet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _export = require('./export.js');\nvar get = require('./get.js');\nvar _import = require('./import.js');\nvar put = require('./put.js');\nvar resolve = require('./resolve.js');\n\nfunction createDag(codecs, config) {\n return {\n export: _export.createExport(config),\n get: get.createGet(codecs, config),\n import: _import.createImport(config),\n put: put.createPut(codecs, config),\n resolve: resolve.createResolve(config)\n };\n}\n\nexports.createDag = createDag;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createExport = configure.configure(api => {\n async function* dagExport(root, options = {}) {\n const res = await api.post('dag/export', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({ arg: root.toString() }),\n headers: options.headers\n });\n yield* res.iterator();\n }\n return dagExport;\n});\n\nexports.createExport = createExport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar resolve = require('../lib/resolve.js');\nvar first = require('it-first');\nvar last = require('it-last');\nvar errCode = require('err-code');\nvar get = require('../block/get.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar first__default = /*#__PURE__*/_interopDefaultLegacy(first);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst createGet = (codecs, options) => {\n const fn = configure.configure((api, opts) => {\n const getBlock = get.createGet(opts);\n const get$1 = async (cid, options = {}) => {\n if (options.path) {\n const entry = options.localResolve ? await first__default['default'](resolve.resolve(cid, options.path, codecs, getBlock, options)) : await last__default['default'](resolve.resolve(cid, options.path, codecs, getBlock, options));\n const result = entry;\n if (!result) {\n throw errCode__default['default'](new Error('Not found'), 'ERR_NOT_FOUND');\n }\n return result;\n }\n const codec = await codecs.getCodec(cid.code);\n const block = await getBlock(cid, options);\n const node = codec.decode(block);\n return {\n value: node,\n remainderPath: ''\n };\n };\n return get$1;\n });\n return fn(options);\n};\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nasync function* resolve(cid$1, path, codecs, getBlock, options) {\n const load = async cid => {\n const codec = await codecs.getCodec(cid.code);\n const block = await getBlock(cid, options);\n return codec.decode(block);\n };\n const parts = path.split('/').filter(Boolean);\n let value = await load(cid$1);\n let lastCid = cid$1;\n if (!parts.length) {\n yield {\n value,\n remainderPath: ''\n };\n }\n while (parts.length) {\n const key = parts.shift();\n if (!key) {\n throw errCode__default['default'](new Error(`Could not resolve path \"${ path }\"`), 'ERR_INVALID_PATH');\n }\n if (Object.prototype.hasOwnProperty.call(value, key)) {\n value = value[key];\n yield {\n value,\n remainderPath: parts.join('/')\n };\n } else {\n throw errCode__default['default'](new Error(`no link named \"${ key }\" under ${ lastCid }`), 'ERR_NO_LINK');\n }\n const cid$1 = cid.CID.asCID(value);\n if (cid$1) {\n lastCid = cid$1;\n value = await load(value);\n }\n }\n}\n\nexports.resolve = resolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar nativeAbortController = require('native-abort-controller');\nvar cid = require('multiformats/cid');\n\nconst createImport = configure.configure(api => {\n async function* dagImport(source, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const {headers, body} = await multipartRequest.multipartRequest(source, controller, options.headers);\n const res = await api.post('dag/import', {\n signal,\n headers,\n body,\n searchParams: toUrlSearchParams.toUrlSearchParams({ 'pin-roots': options.pinRoots })\n });\n for await (const {Root} of res.ndjson()) {\n if (Root !== undefined) {\n const {\n Cid: {'/': Cid},\n PinErrorMsg\n } = Root;\n yield {\n root: {\n cid: cid.CID.parse(Cid),\n pinErrorMsg: PinErrorMsg\n }\n };\n }\n }\n }\n return dagImport;\n});\n\nexports.createImport = createImport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createPut = (codecs, options) => {\n const fn = configure.configure(api => {\n const put = async (dagNode, options = {}) => {\n const settings = {\n format: 'dag-cbor',\n hashAlg: 'sha2-256',\n inputEnc: 'raw',\n ...options\n };\n const codec = await codecs.getCodec(settings.format);\n const serialized = codec.encode(dagNode);\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, settings.signal);\n const res = await api.post('dag/put', {\n timeout: settings.timeout,\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(settings),\n ...await multipartRequest.multipartRequest(serialized, controller, settings.headers)\n });\n const data = await res.json();\n return cid.CID.parse(data.Cid['/']);\n };\n return put;\n });\n return fn(options);\n};\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createResolve = configure.configure(api => {\n const resolve = async (ipfsPath, options = {}) => {\n const res = await api.post('dag/resolve', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ ipfsPath }${ options.path ? `/${ options.path }`.replace(/\\/[/]+/g, '/') : '' }`,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return {\n cid: cid.CID.parse(data.Cid['/']),\n remainderPath: data.RemPath\n };\n };\n return resolve;\n});\n\nexports.createResolve = createResolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar findPeer = require('./find-peer.js');\nvar findProvs = require('./find-provs.js');\nvar get = require('./get.js');\nvar provide = require('./provide.js');\nvar put = require('./put.js');\nvar query = require('./query.js');\n\nfunction createDht(config) {\n return {\n findPeer: findPeer.createFindPeer(config),\n findProvs: findProvs.createFindProvs(config),\n get: get.createGet(config),\n provide: provide.createProvide(config),\n put: put.createPut(config),\n query: query.createQuery(config)\n };\n}\n\nexports.createDht = createDht;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar responseTypes = require('./response-types.js');\n\nconst createFindPeer = configure.configure(api => {\n async function findPeer(peerId, options = {}) {\n const res = await api.post('dht/findpeer', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: peerId,\n ...options\n }),\n headers: options.headers\n });\n for await (const data of res.ndjson()) {\n if (data.Type === responseTypes.FinalPeer && data.Responses) {\n const {ID, Addrs} = data.Responses[0];\n return {\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n };\n }\n }\n throw new Error('not found');\n }\n return findPeer;\n});\n\nexports.createFindPeer = createFindPeer;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst SendingQuery = 0;\nconst PeerResponse = 1;\nconst FinalPeer = 2;\nconst QueryError = 3;\nconst Provider = 4;\nconst Value = 5;\nconst AddingPeer = 6;\nconst DialingPeer = 7;\n\nexports.AddingPeer = AddingPeer;\nexports.DialingPeer = DialingPeer;\nexports.FinalPeer = FinalPeer;\nexports.PeerResponse = PeerResponse;\nexports.Provider = Provider;\nexports.QueryError = QueryError;\nexports.SendingQuery = SendingQuery;\nexports.Value = Value;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar responseTypes = require('./response-types.js');\n\nconst createFindProvs = configure.configure(api => {\n async function* findProvs(cid, options = {}) {\n const res = await api.post('dht/findprovs', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.toString(),\n ...options\n }),\n headers: options.headers\n });\n for await (const message of res.ndjson()) {\n if (message.Type === responseTypes.Provider && message.Responses) {\n for (const {ID, Addrs} of message.Responses) {\n yield {\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n };\n }\n }\n }\n }\n return findProvs;\n});\n\nexports.createFindProvs = createFindProvs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar responseTypes = require('./response-types.js');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\n\nconst createGet = configure.configure(api => {\n async function get(key, options = {}) {\n const res = await api.post('dht/get', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: key instanceof Uint8Array ? toString.toString(key) : key,\n ...options\n }),\n headers: options.headers\n });\n for await (const message of res.ndjson()) {\n if (message.Type === responseTypes.Value) {\n return fromString.fromString(message.Extra, 'base64pad');\n }\n }\n throw new Error('not found');\n }\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createProvide = configure.configure(api => {\n async function* provide(cids, options = { recursive: false }) {\n const cidArr = Array.isArray(cids) ? cids : [cids];\n const res = await api.post('dht/provide', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cidArr.map(cid => cid.toString()),\n ...options\n }),\n headers: options.headers\n });\n for await (let message of res.ndjson()) {\n message = objectToCamel.objectToCamel(message);\n if (message.responses) {\n message.responses = message.responses.map(({ID, Addrs}) => ({\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n }));\n } else {\n message.responses = [];\n }\n yield message;\n }\n }\n return provide;\n});\n\nexports.createProvide = createProvide;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\nvar toString = require('uint8arrays/to-string');\n\nconst createPut = configure.configure(api => {\n async function* put(key, value, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('dht/put', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: toString.toString(key),\n ...options\n }),\n ...await multipartRequest.multipartRequest(value, controller, options.headers)\n });\n for await (let message of res.ndjson()) {\n message = objectToCamel.objectToCamel(message);\n if (message.responses) {\n message.responses = message.responses.map(({ID, Addrs}) => ({\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n }));\n }\n yield message;\n }\n }\n return put;\n});\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createQuery = configure.configure(api => {\n async function* query(peerId, options = {}) {\n const res = await api.post('dht/query', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: peerId.toString(),\n ...options\n }),\n headers: options.headers\n });\n for await (let message of res.ndjson()) {\n message = objectToCamel.objectToCamel(message);\n message.responses = (message.responses || []).map(({ID, Addrs}) => ({\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n }));\n yield message;\n }\n }\n return query;\n});\n\nexports.createQuery = createQuery;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cmds = require('./cmds.js');\nvar net = require('./net.js');\nvar sys = require('./sys.js');\n\nfunction createDiag(config) {\n return {\n cmds: cmds.createCmds(config),\n net: net.createNet(config),\n sys: sys.createSys(config)\n };\n}\n\nexports.createDiag = createDiag;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createCmds = configure.configure(api => {\n async function cmds(options = {}) {\n const res = await api.post('diag/cmds', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return res.json();\n }\n return cmds;\n});\n\nexports.createCmds = createCmds;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createNet = configure.configure(api => {\n async function net(options = {}) {\n const res = await api.post('diag/net', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return res.json();\n }\n return net;\n});\n\nexports.createNet = createNet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createSys = configure.configure(api => {\n async function sys(options = {}) {\n const res = await api.post('diag/sys', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return res.json();\n }\n return sys;\n});\n\nexports.createSys = createSys;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar chmod = require('./chmod.js');\nvar cp = require('./cp.js');\nvar flush = require('./flush.js');\nvar ls = require('./ls.js');\nvar mkdir = require('./mkdir.js');\nvar mv = require('./mv.js');\nvar read = require('./read.js');\nvar rm = require('./rm.js');\nvar stat = require('./stat.js');\nvar touch = require('./touch.js');\nvar write = require('./write.js');\n\nfunction createFiles(config) {\n return {\n chmod: chmod.createChmod(config),\n cp: cp.createCp(config),\n flush: flush.createFlush(config),\n ls: ls.createLs(config),\n mkdir: mkdir.createMkdir(config),\n mv: mv.createMv(config),\n read: read.createRead(config),\n rm: rm.createRm(config),\n stat: stat.createStat(config),\n touch: touch.createTouch(config),\n write: write.createWrite(config)\n };\n}\n\nexports.createFiles = createFiles;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createChmod = configure.configure(api => {\n async function chmod(path, mode, options = {}) {\n const res = await api.post('files/chmod', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n mode,\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return chmod;\n});\n\nexports.createChmod = createChmod;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createCp = configure.configure(api => {\n async function cp(sources, destination, options = {}) {\n const sourceArr = Array.isArray(sources) ? sources : [sources];\n const res = await api.post('files/cp', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: sourceArr.concat(destination).map(src => cid.CID.asCID(src) ? `/ipfs/${ src }` : src),\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return cp;\n});\n\nexports.createCp = createCp;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createFlush = configure.configure(api => {\n async function flush(path, options = {}) {\n if (!path || typeof path !== 'string') {\n throw new Error('ipfs.files.flush requires a path');\n }\n const res = await api.post('files/flush', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return cid.CID.parse(data.Cid);\n }\n return flush;\n});\n\nexports.createFlush = createFlush;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar objectToCamelWithMetadata = require('../lib/object-to-camel-with-metadata.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLs = configure.configure(api => {\n async function* ls(path, options = {}) {\n if (!path) {\n throw new Error('ipfs.files.ls requires a path');\n }\n const res = await api.post('files/ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.CID.asCID(path) ? `/ipfs/${ path }` : path,\n long: true,\n ...options,\n stream: true\n }),\n headers: options.headers\n });\n for await (const result of res.ndjson()) {\n if ('Entries' in result) {\n for (const entry of result.Entries || []) {\n yield toCoreInterface(objectToCamelWithMetadata.objectToCamelWithMetadata(entry));\n }\n } else {\n yield toCoreInterface(objectToCamelWithMetadata.objectToCamelWithMetadata(result));\n }\n }\n }\n return ls;\n});\nfunction toCoreInterface(entry) {\n if (entry.hash) {\n entry.cid = cid.CID.parse(entry.hash);\n }\n delete entry.hash;\n entry.type = entry.type === 1 ? 'directory' : 'file';\n return entry;\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./object-to-camel.js');\n\nfunction objectToCamelWithMetadata(entry) {\n const file = objectToCamel.objectToCamel(entry);\n if (Object.prototype.hasOwnProperty.call(file, 'mode')) {\n file.mode = parseInt(file.mode, 8);\n }\n if (Object.prototype.hasOwnProperty.call(file, 'mtime')) {\n file.mtime = {\n secs: file.mtime,\n nsecs: file.mtimeNsecs || 0\n };\n delete file.mtimeNsecs;\n }\n return file;\n}\n\nexports.objectToCamelWithMetadata = objectToCamelWithMetadata;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createMkdir = configure.configure(api => {\n async function mkdir(path, options = {}) {\n const res = await api.post('files/mkdir', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return mkdir;\n});\n\nexports.createMkdir = createMkdir;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createMv = configure.configure(api => {\n async function mv(sources, destination, options = {}) {\n if (!Array.isArray(sources)) {\n sources = [sources];\n }\n const res = await api.post('files/mv', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: sources.concat(destination),\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return mv;\n});\n\nexports.createMv = createMv;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar toIterable = require('stream-to-it/source.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar toIterable__default = /*#__PURE__*/_interopDefaultLegacy(toIterable);\n\nconst createRead = configure.configure(api => {\n async function* read(path, options = {}) {\n const res = await api.post('files/read', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n count: options.length,\n ...options\n }),\n headers: options.headers\n });\n yield* toIterable__default['default'](res.body);\n }\n return read;\n});\n\nexports.createRead = createRead;\n","module.exports = readable => {\n // Node.js stream\n if (readable[Symbol.asyncIterator]) return readable\n\n // Browser ReadableStream\n if (readable.getReader) {\n return (async function * () {\n const reader = readable.getReader()\n\n try {\n while (true) {\n const { done, value } = await reader.read()\n if (done) return\n yield value\n }\n } finally {\n reader.releaseLock()\n }\n })()\n }\n\n throw new Error('unknown stream')\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRm = configure.configure(api => {\n async function rm(path, options = {}) {\n const res = await api.post('files/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return rm;\n});\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar objectToCamelWithMetadata = require('../lib/object-to-camel-with-metadata.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(path, options = {}) {\n const res = await api.post('files/stat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n data.WithLocality = data.WithLocality || false;\n return toCoreInterface(objectToCamelWithMetadata.objectToCamelWithMetadata(data));\n }\n return stat;\n});\nfunction toCoreInterface(entry) {\n entry.cid = cid.CID.parse(entry.hash);\n delete entry.hash;\n return entry;\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createTouch = configure.configure(api => {\n async function touch(path, options = {}) {\n const res = await api.post('files/touch', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return touch;\n});\n\nexports.createTouch = createTouch;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar modeToString = require('../lib/mode-to-string.js');\nvar parseMtime = require('../lib/parse-mtime.js');\nvar configure = require('../lib/configure.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createWrite = configure.configure(api => {\n async function write(path, input, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('files/write', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n streamChannels: true,\n count: options.length,\n ...options\n }),\n ...await multipartRequest.multipartRequest({\n content: input,\n path: 'arg',\n mode: modeToString.modeToString(options.mode),\n mtime: parseMtime.parseMtime(options.mtime)\n }, controller, options.headers)\n });\n await res.text();\n }\n return write;\n});\n\nexports.createWrite = createWrite;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _export = require('./export.js');\nvar gen = require('./gen.js');\nvar _import = require('./import.js');\nvar info = require('./info.js');\nvar list = require('./list.js');\nvar rename = require('./rename.js');\nvar rm = require('./rm.js');\n\nfunction createKey(config) {\n return {\n export: _export.createExport(config),\n gen: gen.createGen(config),\n import: _import.createImport(config),\n info: info.createInfo(config),\n list: list.createList(config),\n rename: rename.createRename(config),\n rm: rm.createRm(config)\n };\n}\n\nexports.createKey = createKey;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst createExport = configure.configure(api => {\n const exportKey = async (name, password, options = {}) => {\n throw errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED');\n };\n return exportKey;\n});\n\nexports.createExport = createExport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGen = configure.configure(api => {\n async function gen(name, options = {\n type: 'rsa',\n size: 2048\n }) {\n const res = await api.post('key/gen', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: name,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return objectToCamel.objectToCamel(data);\n }\n return gen;\n});\n\nexports.createGen = createGen;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createImport = configure.configure(api => {\n async function importKey(name, pem, password, options = {}) {\n const res = await api.post('key/import', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: name,\n pem,\n password,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return objectToCamel.objectToCamel(data);\n }\n return importKey;\n});\n\nexports.createImport = createImport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst createInfo = configure.configure(api => {\n const info = async (name, options = {}) => {\n throw errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED');\n };\n return info;\n});\n\nexports.createInfo = createInfo;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createList = configure.configure(api => {\n async function list(options = {}) {\n const res = await api.post('key/list', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return (data.Keys || []).map(k => objectToCamel.objectToCamel(k));\n }\n return list;\n});\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRename = configure.configure(api => {\n async function rename(oldName, newName, options = {}) {\n const res = await api.post('key/rename', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n oldName,\n newName\n ],\n ...options\n }),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return rename;\n});\n\nexports.createRename = createRename;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRm = configure.configure(api => {\n async function rm(name, options = {}) {\n const res = await api.post('key/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: name,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return objectToCamel.objectToCamel(data.Keys[0]);\n }\n return rm;\n});\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar level = require('./level.js');\nvar ls = require('./ls.js');\nvar tail = require('./tail.js');\n\nfunction createLog(config) {\n return {\n level: level.createLevel(config),\n ls: ls.createLs(config),\n tail: tail.createTail(config)\n };\n}\n\nexports.createLog = createLog;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLevel = configure.configure(api => {\n async function level(subsystem, level, options = {}) {\n const res = await api.post('log/level', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n subsystem,\n level\n ],\n ...options\n }),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return level;\n});\n\nexports.createLevel = createLevel;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLs = configure.configure(api => {\n async function ls(options = {}) {\n const res = await api.post('log/ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return data.Strings;\n }\n return ls;\n});\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createTail = configure.configure(api => {\n async function* tail(options = {}) {\n const res = await api.post('log/tail', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n yield* res.ndjson();\n }\n return tail;\n});\n\nexports.createTail = createTail;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar publish = require('./publish.js');\nvar resolve = require('./resolve.js');\nvar index = require('./pubsub/index.js');\n\nfunction createName(config) {\n return {\n publish: publish.createPublish(config),\n resolve: resolve.createResolve(config),\n pubsub: index.createPubsub(config)\n };\n}\n\nexports.createName = createName;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createPublish = configure.configure(api => {\n async function publish(path, options = {}) {\n const res = await api.post('name/publish', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ path }`,\n ...options\n }),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return publish;\n});\n\nexports.createPublish = createPublish;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createResolve = configure.configure(api => {\n async function* resolve(path, options = {}) {\n const res = await api.post('name/resolve', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n stream: true,\n ...options\n }),\n headers: options.headers\n });\n for await (const result of res.ndjson()) {\n yield result.Path;\n }\n }\n return resolve;\n});\n\nexports.createResolve = createResolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cancel = require('./cancel.js');\nvar state = require('./state.js');\nvar subs = require('./subs.js');\n\nfunction createPubsub(config) {\n return {\n cancel: cancel.createCancel(config),\n state: state.createState(config),\n subs: subs.createSubs(config)\n };\n}\n\nexports.createPubsub = createPubsub;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../../lib/object-to-camel.js');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createCancel = configure.configure(api => {\n async function cancel(name, options = {}) {\n const res = await api.post('name/pubsub/cancel', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: name,\n ...options\n }),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return cancel;\n});\n\nexports.createCancel = createCancel;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../../lib/object-to-camel.js');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createState = configure.configure(api => {\n async function state(options = {}) {\n const res = await api.post('name/pubsub/state', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return state;\n});\n\nexports.createState = createState;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createSubs = configure.configure(api => {\n async function subs(options = {}) {\n const res = await api.post('name/pubsub/subs', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return data.Strings || [];\n }\n return subs;\n});\n\nexports.createSubs = createSubs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar data = require('./data.js');\nvar get = require('./get.js');\nvar links = require('./links.js');\nvar _new = require('./new.js');\nvar put = require('./put.js');\nvar stat = require('./stat.js');\nvar index = require('./patch/index.js');\n\nfunction createObject(codecs, config) {\n return {\n data: data.createData(config),\n get: get.createGet(config),\n links: links.createLinks(config),\n new: _new.createNew(config),\n put: put.createPut(codecs, config),\n stat: stat.createStat(config),\n patch: index.createPatch(config)\n };\n}\n\nexports.createObject = createObject;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createData = configure.configure(api => {\n async function data(cid$1, options = {}) {\n const res = await api.post('object/data', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 instanceof Uint8Array ? cid.CID.decode(cid$1) : cid$1 }`,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.arrayBuffer();\n return new Uint8Array(data, 0, data.byteLength);\n }\n return data;\n});\n\nexports.createData = createData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar fromString = require('uint8arrays/from-string');\n\nconst createGet = configure.configure(api => {\n async function get(cid$1, options = {}) {\n const res = await api.post('object/get', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 instanceof Uint8Array ? cid.CID.decode(cid$1) : cid$1 }`,\n dataEncoding: 'base64',\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return {\n Data: fromString.fromString(data.Data, 'base64pad'),\n Links: (data.Links || []).map(link => ({\n Name: link.Name,\n Hash: cid.CID.parse(link.Hash),\n Tsize: link.Size\n }))\n };\n }\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLinks = configure.configure(api => {\n async function links(cid$1, options = {}) {\n const res = await api.post('object/links', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 instanceof Uint8Array ? cid.CID.decode(cid$1) : cid$1 }`,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return (data.Links || []).map(l => ({\n Name: l.Name,\n Tsize: l.Size,\n Hash: cid.CID.parse(l.Hash)\n }));\n }\n return links;\n});\n\nexports.createLinks = createLinks;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createNew = configure.configure(api => {\n async function newObject(options = {}) {\n const res = await api.post('object/new', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: options.template,\n ...options\n }),\n headers: options.headers\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return newObject;\n});\n\nexports.createNew = createNew;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar put = require('../dag/put.js');\n\nconst createPut = (codecs, options) => {\n const fn = configure.configure(api => {\n const dagPut = put.createPut(codecs, options);\n async function put$1(obj, options = {}) {\n return dagPut(obj, {\n ...options,\n format: 'dag-pb',\n hashAlg: 'sha2-256',\n version: 0\n });\n }\n return put$1;\n });\n return fn(options);\n};\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(cid$1, options = {}) {\n const res = await api.post('object/stat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 }`,\n ...options\n }),\n headers: options.headers\n });\n const output = await res.json();\n return {\n ...output,\n Hash: cid.CID.parse(output.Hash)\n };\n }\n return stat;\n});\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addLink = require('./add-link.js');\nvar appendData = require('./append-data.js');\nvar rmLink = require('./rm-link.js');\nvar setData = require('./set-data.js');\n\nfunction createPatch(config) {\n return {\n addLink: addLink.createAddLink(config),\n appendData: appendData.createAppendData(config),\n rmLink: rmLink.createRmLink(config),\n setData: setData.createSetData(config)\n };\n}\n\nexports.createPatch = createPatch;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createAddLink = configure.configure(api => {\n async function addLink(cid$1, dLink, options = {}) {\n const res = await api.post('object/patch/add-link', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n `${ cid$1 }`,\n dLink.Name || dLink.name || '',\n (dLink.Hash || dLink.cid || '').toString() || null\n ],\n ...options\n }),\n headers: options.headers\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return addLink;\n});\n\nexports.createAddLink = createAddLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\nvar abortSignal = require('../../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createAppendData = configure.configure(api => {\n async function appendData(cid$1, data, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('object/patch/append-data', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 }`,\n ...options\n }),\n ...await multipartRequest.multipartRequest(data, controller, options.headers)\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return appendData;\n});\n\nexports.createAppendData = createAppendData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createRmLink = configure.configure(api => {\n async function rmLink(cid$1, dLink, options = {}) {\n const res = await api.post('object/patch/rm-link', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n `${ cid$1 }`,\n dLink.Name || dLink.name || null\n ],\n ...options\n }),\n headers: options.headers\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return rmLink;\n});\n\nexports.createRmLink = createRmLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\nvar abortSignal = require('../../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createSetData = configure.configure(api => {\n async function setData(cid$1, data, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('object/patch/set-data', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [`${ cid$1 }`],\n ...options\n }),\n ...await multipartRequest.multipartRequest(data, controller, options.headers)\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return setData;\n});\n\nexports.createSetData = createSetData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addAll = require('./add-all.js');\nvar add = require('./add.js');\nvar ls = require('./ls.js');\nvar rmAll = require('./rm-all.js');\nvar rm = require('./rm.js');\nvar index = require('./remote/index.js');\n\nfunction createPin(config) {\n return {\n addAll: addAll.createAddAll(config),\n add: add.createAdd(config),\n ls: ls.createLs(config),\n rmAll: rmAll.createRmAll(config),\n rm: rm.createRm(config),\n remote: index.createRemote(config)\n };\n}\n\nexports.createPin = createPin;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createAddAll = configure.configure(api => {\n async function* addAll(source, options = {}) {\n for await (const {path, recursive, metadata} of normaliseInput.normaliseInput(source)) {\n const res = await api.post('pin/add', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n arg: path,\n recursive,\n metadata: metadata ? JSON.stringify(metadata) : undefined,\n stream: true\n }),\n headers: options.headers\n });\n for await (const pin of res.ndjson()) {\n if (pin.Pins) {\n for (const cid$1 of pin.Pins) {\n yield cid.CID.parse(cid$1);\n }\n continue;\n }\n yield cid.CID.parse(pin);\n }\n }\n }\n return addAll;\n});\n\nexports.createAddAll = createAddAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addAll = require('./add-all.js');\nvar last = require('it-last');\nvar configure = require('../lib/configure.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createAdd(config) {\n const all = addAll.createAddAll(config);\n return configure.configure(() => {\n async function add(path, options = {}) {\n return last__default['default'](all([{\n path,\n ...options\n }], options));\n }\n return add;\n })(config);\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nfunction toPin(type, cid$1, metadata) {\n const pin = {\n type,\n cid: cid.CID.parse(cid$1)\n };\n if (metadata) {\n pin.metadata = metadata;\n }\n return pin;\n}\nconst createLs = configure.configure(api => {\n async function* ls(options = {}) {\n let paths = [];\n if (options.paths) {\n paths = Array.isArray(options.paths) ? options.paths : [options.paths];\n }\n const res = await api.post('pin/ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n arg: paths.map(path => `${ path }`),\n stream: true\n }),\n headers: options.headers\n });\n for await (const pin of res.ndjson()) {\n if (pin.Keys) {\n for (const cid of Object.keys(pin.Keys)) {\n yield toPin(pin.Keys[cid].Type, cid, pin.Keys[cid].Metadata);\n }\n return;\n }\n yield toPin(pin.Type, pin.Cid, pin.Metadata);\n }\n }\n return ls;\n});\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRmAll = configure.configure(api => {\n async function* rmAll(source, options = {}) {\n for await (const {path, recursive} of normaliseInput.normaliseInput(source)) {\n const searchParams = new URLSearchParams(options.searchParams);\n searchParams.append('arg', `${ path }`);\n if (recursive != null)\n searchParams.set('recursive', String(recursive));\n const res = await api.post('pin/rm', {\n signal: options.signal,\n headers: options.headers,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n arg: `${ path }`,\n recursive\n })\n });\n for await (const pin of res.ndjson()) {\n if (pin.Pins) {\n yield* pin.Pins.map(cid$1 => cid.CID.parse(cid$1));\n continue;\n }\n yield cid.CID.parse(pin);\n }\n }\n }\n return rmAll;\n});\n\nexports.createRmAll = createRmAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar rmAll = require('./rm-all.js');\nvar last = require('it-last');\nvar configure = require('../lib/configure.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst createRm = config => {\n const all = rmAll.createRmAll(config);\n return configure.configure(() => {\n async function rm(path, options = {}) {\n return last__default['default'](all([{\n path,\n ...options\n }], options));\n }\n return rm;\n })(config);\n};\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar core = require('../../lib/core.js');\nvar add = require('./add.js');\nvar ls = require('./ls.js');\nvar rm = require('./rm.js');\nvar rmAll = require('./rm-all.js');\nvar index = require('./service/index.js');\n\nfunction createRemote(config) {\n const client = new core.Client(config);\n return {\n add: add.createAdd(client),\n ls: ls.createLs(client),\n rm: rm.createRm(client),\n rmAll: rmAll.createRmAll(client),\n service: index.createService(config)\n };\n}\n\nexports.createRemote = createRemote;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\n\nfunction createAdd(client) {\n async function add(cid, {timeout, signal, headers, ...query}) {\n const response = await client.post('pin/remote/add', {\n timeout,\n signal,\n headers,\n searchParams: utils.encodeAddParams({\n cid,\n ...query\n })\n });\n return utils.decodePin(await response.json());\n }\n return add;\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst decodePin = ({\n Name: name,\n Status: status,\n Cid: cid$1\n}) => {\n return {\n cid: cid.CID.parse(cid$1),\n name,\n status\n };\n};\nconst encodeService = service => {\n if (typeof service === 'string' && service !== '') {\n return service;\n } else {\n throw new TypeError('service name must be passed');\n }\n};\nconst encodeCID = cid$1 => {\n if (cid.CID.asCID(cid$1)) {\n return cid$1.toString();\n } else {\n throw new TypeError(`CID instance expected instead of ${ typeof cid$1 }`);\n }\n};\nconst encodeQuery = ({service, cid, name, status, all}) => {\n const query = toUrlSearchParams.toUrlSearchParams({\n service: encodeService(service),\n name,\n force: all ? true : undefined\n });\n if (cid) {\n for (const value of cid) {\n query.append('cid', encodeCID(value));\n }\n }\n if (status) {\n for (const value of status) {\n query.append('status', value);\n }\n }\n return query;\n};\nconst encodeAddParams = ({cid, service, background, name, origins}) => {\n const params = toUrlSearchParams.toUrlSearchParams({\n arg: encodeCID(cid),\n service: encodeService(service),\n name,\n background: background ? true : undefined\n });\n if (origins) {\n for (const origin of origins) {\n params.append('origin', origin.toString());\n }\n }\n return params;\n};\n\nexports.decodePin = decodePin;\nexports.encodeAddParams = encodeAddParams;\nexports.encodeCID = encodeCID;\nexports.encodeQuery = encodeQuery;\nexports.encodeService = encodeService;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\n\nfunction createLs(client) {\n async function* ls({timeout, signal, headers, ...query}) {\n const response = await client.post('pin/remote/ls', {\n timeout,\n signal,\n headers,\n searchParams: utils.encodeQuery(query)\n });\n for await (const pin of response.ndjson()) {\n yield utils.decodePin(pin);\n }\n }\n return ls;\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\n\nfunction createRm(client) {\n async function rm({timeout, signal, headers, ...query}) {\n await client.post('pin/remote/rm', {\n timeout,\n signal,\n headers,\n searchParams: utils.encodeQuery({\n ...query,\n all: false\n })\n });\n }\n return rm;\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\n\nfunction createRmAll(client) {\n async function rmAll({timeout, signal, headers, ...query}) {\n await client.post('pin/remote/rm', {\n timeout,\n signal,\n headers,\n searchParams: utils.encodeQuery({\n ...query,\n all: true\n })\n });\n }\n return rmAll;\n}\n\nexports.createRmAll = createRmAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar core = require('../../../lib/core.js');\nvar add = require('./add.js');\nvar ls = require('./ls.js');\nvar rm = require('./rm.js');\n\nfunction createService(config) {\n const client = new core.Client(config);\n return {\n add: add.createAdd(client),\n ls: ls.createLs(client),\n rm: rm.createRm(client)\n };\n}\n\nexports.createService = createService;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar toUrlSearchParams = require('../../../lib/to-url-search-params.js');\nvar utils = require('./utils.js');\n\nfunction createAdd(client) {\n async function add(name, options) {\n const {endpoint, key, headers, timeout, signal} = options;\n await client.post('pin/remote/service/add', {\n timeout,\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n name,\n utils.encodeEndpoint(endpoint),\n key\n ]\n }),\n headers\n });\n }\n return add;\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction encodeEndpoint(url) {\n const href = String(url);\n if (href === 'undefined') {\n throw Error('endpoint is required');\n }\n return href[href.length - 1] === '/' ? href.slice(0, -1) : href;\n}\nfunction decodeRemoteService(json) {\n return {\n service: json.Service,\n endpoint: new URL(json.ApiEndpoint),\n ...json.Stat && { stat: decodeStat(json.Stat) }\n };\n}\nfunction decodeStat(json) {\n switch (json.Status) {\n case 'valid': {\n const {Pinning, Pinned, Queued, Failed} = json.PinCount;\n return {\n status: 'valid',\n pinCount: {\n queued: Queued,\n pinning: Pinning,\n pinned: Pinned,\n failed: Failed\n }\n };\n }\n case 'invalid': {\n return { status: 'invalid' };\n }\n default: {\n return { status: json.Status };\n }\n }\n}\n\nexports.decodeRemoteService = decodeRemoteService;\nexports.decodeStat = decodeStat;\nexports.encodeEndpoint = encodeEndpoint;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar toUrlSearchParams = require('../../../lib/to-url-search-params.js');\nvar utils = require('./utils.js');\n\nfunction createLs(client) {\n async function ls(options = {}) {\n const {stat, headers, timeout, signal} = options;\n const response = await client.post('pin/remote/service/ls', {\n timeout,\n signal,\n headers,\n searchParams: stat === true ? toUrlSearchParams.toUrlSearchParams({ stat }) : undefined\n });\n const {RemoteServices} = await response.json();\n return RemoteServices.map(utils.decodeRemoteService);\n }\n return ls;\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar toUrlSearchParams = require('../../../lib/to-url-search-params.js');\n\nfunction createRm(client) {\n async function rm(name, options = {}) {\n await client.post('pin/remote/service/rm', {\n signal: options.signal,\n headers: options.headers,\n searchParams: toUrlSearchParams.toUrlSearchParams({ arg: name })\n });\n }\n return rm;\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ls = require('./ls.js');\nvar peers = require('./peers.js');\nvar publish = require('./publish.js');\nvar subscribe = require('./subscribe.js');\nvar unsubscribe = require('./unsubscribe.js');\nvar subscriptionTracker = require('./subscription-tracker.js');\n\nfunction createPubsub(config) {\n const subscriptionTracker$1 = new subscriptionTracker.SubscriptionTracker();\n return {\n ls: ls.createLs(config),\n peers: peers.createPeers(config),\n publish: publish.createPublish(config),\n subscribe: subscribe.createSubscribe(config, subscriptionTracker$1),\n unsubscribe: unsubscribe.createUnsubscribe(config, subscriptionTracker$1)\n };\n}\n\nexports.createPubsub = createPubsub;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLs = configure.configure(api => {\n async function ls(options = {}) {\n const {Strings} = await (await api.post('pubsub/ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n })).json();\n return Strings || [];\n }\n return ls;\n});\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createPeers = configure.configure(api => {\n async function peers(topic, options = {}) {\n const res = await api.post('pubsub/peers', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: topic,\n ...options\n }),\n headers: options.headers\n });\n const {Strings} = await res.json();\n return Strings || [];\n }\n return peers;\n});\n\nexports.createPeers = createPeers;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createPublish = configure.configure(api => {\n async function publish(topic, data, options = {}) {\n const searchParams = toUrlSearchParams.toUrlSearchParams({\n arg: topic,\n ...options\n });\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('pubsub/pub', {\n signal,\n searchParams,\n ...await multipartRequest.multipartRequest(data, controller, options.headers)\n });\n await res.text();\n }\n return publish;\n});\n\nexports.createPublish = createPublish;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar debug = require('debug');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs-http-client:pubsub:subscribe');\nconst createSubscribe = (options, subsTracker) => {\n return configure.configure(api => {\n async function subscribe(topic, handler, options = {}) {\n options.signal = subsTracker.subscribe(topic, handler, options.signal);\n let done;\n let fail;\n const result = new Promise((resolve, reject) => {\n done = resolve;\n fail = reject;\n });\n const ffWorkaround = setTimeout(() => done(), 1000);\n api.post('pubsub/sub', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: topic,\n ...options\n }),\n headers: options.headers\n }).catch(err => {\n subsTracker.unsubscribe(topic, handler);\n fail(err);\n }).then(response => {\n clearTimeout(ffWorkaround);\n if (!response) {\n return;\n }\n readMessages(response, {\n onMessage: handler,\n onEnd: () => subsTracker.unsubscribe(topic, handler),\n onError: options.onError\n });\n done();\n });\n return result;\n }\n return subscribe;\n })(options);\n};\nasync function readMessages(response, {onMessage, onEnd, onError}) {\n onError = onError || log;\n try {\n for await (const msg of response.ndjson()) {\n try {\n if (!msg.from) {\n continue;\n }\n onMessage({\n from: toString.toString(fromString.fromString(msg.from, 'base64pad'), 'base58btc'),\n data: fromString.fromString(msg.data, 'base64pad'),\n seqno: fromString.fromString(msg.seqno, 'base64pad'),\n topicIDs: msg.topicIDs\n });\n } catch (err) {\n err.message = `Failed to parse pubsub message: ${ err.message }`;\n onError(err, false, msg);\n }\n }\n } catch (err) {\n if (!isAbortError(err)) {\n onError(err, true);\n }\n } finally {\n onEnd();\n }\n}\nconst isAbortError = error => {\n switch (error.type) {\n case 'aborted':\n return true;\n case 'abort':\n return true;\n default:\n return error.name === 'AbortError';\n }\n};\n\nexports.createSubscribe = createSubscribe;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst createUnsubscribe = (options, subsTracker) => {\n async function unsubscribe(topic, handler) {\n subsTracker.unsubscribe(topic, handler);\n }\n return unsubscribe;\n};\n\nexports.createUnsubscribe = createUnsubscribe;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar nativeAbortController = require('native-abort-controller');\n\nclass SubscriptionTracker {\n constructor() {\n this._subs = new Map();\n }\n subscribe(topic, handler, signal) {\n const topicSubs = this._subs.get(topic) || [];\n if (topicSubs.find(s => s.handler === handler)) {\n throw new Error(`Already subscribed to ${ topic } with this handler`);\n }\n const controller = new nativeAbortController.AbortController();\n this._subs.set(topic, [{\n handler,\n controller\n }].concat(topicSubs));\n if (signal) {\n signal.addEventListener('abort', () => this.unsubscribe(topic, handler));\n }\n return controller.signal;\n }\n unsubscribe(topic, handler) {\n const subs = this._subs.get(topic) || [];\n let unsubs;\n if (handler) {\n this._subs.set(topic, subs.filter(s => s.handler !== handler));\n unsubs = subs.filter(s => s.handler === handler);\n } else {\n this._subs.set(topic, []);\n unsubs = subs;\n }\n if (!(this._subs.get(topic) || []).length) {\n this._subs.delete(topic);\n }\n unsubs.forEach(s => s.controller.abort());\n }\n}\n\nexports.SubscriptionTracker = SubscriptionTracker;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar local = require('./local.js');\n\nconst createRefs = configure.configure((api, opts) => {\n const refs = async function* (args, options = {}) {\n const argsArr = Array.isArray(args) ? args : [args];\n const res = await api.post('refs', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: argsArr.map(arg => `${ arg instanceof Uint8Array ? cid.CID.decode(arg) : arg }`),\n ...options\n }),\n headers: options.headers,\n transform: objectToCamel.objectToCamel\n });\n yield* res.ndjson();\n };\n return Object.assign(refs, { local: local.createLocal(opts) });\n});\n\nexports.createRefs = createRefs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLocal = configure.configure(api => {\n async function* refsLocal(options = {}) {\n const res = await api.post('refs/local', {\n signal: options.signal,\n transform: objectToCamel.objectToCamel,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n yield* res.ndjson();\n }\n return refsLocal;\n});\n\nexports.createLocal = createLocal;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar gc = require('./gc.js');\nvar stat = require('./stat.js');\nvar version = require('./version.js');\n\nfunction createRepo(config) {\n return {\n gc: gc.createGc(config),\n stat: stat.createStat(config),\n version: version.createVersion(config)\n };\n}\n\nexports.createRepo = createRepo;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGc = configure.configure(api => {\n async function* gc(options = {}) {\n const res = await api.post('repo/gc', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers,\n transform: res => {\n return {\n err: res.Error ? new Error(res.Error) : null,\n cid: (res.Key || {})['/'] ? cid.CID.parse(res.Key['/']) : null\n };\n }\n });\n yield* res.ndjson();\n }\n return gc;\n});\n\nexports.createGc = createGc;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(options = {}) {\n const res = await api.post('repo/stat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return {\n numObjects: BigInt(data.NumObjects),\n repoSize: BigInt(data.RepoSize),\n repoPath: data.RepoPath,\n version: data.Version,\n storageMax: BigInt(data.StorageMax)\n };\n }\n return stat;\n});\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createVersion = configure.configure(api => {\n async function version(options = {}) {\n const res = await (await api.post('repo/version', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n })).json();\n return res.Version;\n }\n return version;\n});\n\nexports.createVersion = createVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar stat = require('../bitswap/stat.js');\nvar stat$1 = require('../repo/stat.js');\nvar bw = require('./bw.js');\n\nfunction createStats(config) {\n return {\n bitswap: stat.createStat(config),\n repo: stat$1.createStat(config),\n bw: bw.createBw(config)\n };\n}\n\nexports.createStats = createStats;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createBw = configure.configure(api => {\n async function* bw(options = {}) {\n const res = await api.post('stats/bw', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers,\n transform: stats => ({\n totalIn: BigInt(stats.TotalIn),\n totalOut: BigInt(stats.TotalOut),\n rateIn: parseFloat(stats.RateIn),\n rateOut: parseFloat(stats.RateOut)\n })\n });\n yield* res.ndjson();\n }\n return bw;\n});\n\nexports.createBw = createBw;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addrs = require('./addrs.js');\nvar connect = require('./connect.js');\nvar disconnect = require('./disconnect.js');\nvar localAddrs = require('./local-addrs.js');\nvar peers = require('./peers.js');\n\nfunction createSwarm(config) {\n return {\n addrs: addrs.createAddrs(config),\n connect: connect.createConnect(config),\n disconnect: disconnect.createDisconnect(config),\n localAddrs: localAddrs.createLocalAddrs(config),\n peers: peers.createPeers(config)\n };\n}\n\nexports.createSwarm = createSwarm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createAddrs = configure.configure(api => {\n async function addrs(options = {}) {\n const res = await api.post('swarm/addrs', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const {Addrs} = await res.json();\n return Object.keys(Addrs).map(id => ({\n id,\n addrs: (Addrs[id] || []).map(a => new multiaddr.Multiaddr(a))\n }));\n }\n return addrs;\n});\n\nexports.createAddrs = createAddrs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createConnect = configure.configure(api => {\n async function connect(addr, options = {}) {\n const res = await api.post('swarm/connect', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: addr,\n ...options\n }),\n headers: options.headers\n });\n const {Strings} = await res.json();\n return Strings || [];\n }\n return connect;\n});\n\nexports.createConnect = createConnect;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createDisconnect = configure.configure(api => {\n async function disconnect(addr, options = {}) {\n const res = await api.post('swarm/disconnect', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: addr,\n ...options\n }),\n headers: options.headers\n });\n const {Strings} = await res.json();\n return Strings || [];\n }\n return disconnect;\n});\n\nexports.createDisconnect = createDisconnect;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLocalAddrs = configure.configure(api => {\n async function localAddrs(options = {}) {\n const res = await api.post('swarm/addrs/local', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const {Strings} = await res.json();\n return (Strings || []).map(a => new multiaddr.Multiaddr(a));\n }\n return localAddrs;\n});\n\nexports.createLocalAddrs = createLocalAddrs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createPeers = configure.configure(api => {\n async function peers(options = {}) {\n const res = await api.post('swarm/peers', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return (Peers || []).map(peer => {\n return {\n addr: new multiaddr.Multiaddr(peer.Addr),\n peer: peer.Peer,\n muxer: peer.Muxer,\n latency: peer.Latency,\n streams: peer.Streams,\n direction: peer.Direction == null ? undefined : peer.Direction === 0 ? 'inbound' : 'outbound'\n };\n });\n }\n return peers;\n});\n\nexports.createPeers = createPeers;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addAll = require('./add-all.js');\nvar last = require('it-last');\nvar configure = require('./lib/configure.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createAdd(options) {\n const all = addAll.createAddAll(options);\n return configure.configure(() => {\n async function add(input, options = {}) {\n return await last__default['default'](all(input, options));\n }\n return add;\n })(options);\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar configure = require('./lib/configure.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\nvar abortSignal = require('./lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createAddAll = configure.configure(api => {\n async function* addAll(source, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const {headers, body, total, parts} = await multipartRequest.multipartRequest(source, controller, options.headers);\n const [progressFn, onUploadProgress] = typeof options.progress === 'function' ? createProgressHandler(total, parts, options.progress) : [\n undefined,\n undefined\n ];\n const res = await api.post('add', {\n searchParams: toUrlSearchParams.toUrlSearchParams({\n 'stream-channels': true,\n ...options,\n progress: Boolean(progressFn)\n }),\n onUploadProgress,\n signal,\n headers,\n body\n });\n for await (let file of res.ndjson()) {\n file = objectToCamel.objectToCamel(file);\n if (file.hash !== undefined) {\n yield toCoreInterface(file);\n } else if (progressFn) {\n progressFn(file.bytes || 0, file.name);\n }\n }\n }\n return addAll;\n});\nconst createProgressHandler = (total, parts, progress) => parts ? [\n undefined,\n createOnUploadProgress(total, parts, progress)\n] : [\n progress,\n undefined\n];\nconst createOnUploadProgress = (size, parts, progress) => {\n let index = 0;\n const count = parts.length;\n return ({loaded, total}) => {\n const position = Math.floor(loaded / total * size);\n while (index < count) {\n const {start, end, name} = parts[index];\n if (position < end) {\n progress(position - start, name);\n break;\n } else {\n progress(end - start, name);\n index += 1;\n }\n }\n };\n};\nfunction toCoreInterface({name, hash, size, mode, mtime, mtimeNsecs}) {\n const output = {\n path: name,\n cid: cid.CID.parse(hash),\n size: parseInt(size)\n };\n if (mode != null) {\n output.mode = parseInt(mode, 8);\n }\n if (mtime != null) {\n output.mtime = {\n secs: mtime,\n nsecs: mtimeNsecs || 0\n };\n }\n return output;\n}\n\nexports.createAddAll = createAddAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createCat = configure.configure(api => {\n async function* cat(path, options = {}) {\n const res = await api.post('cat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path.toString(),\n ...options\n }),\n headers: options.headers\n });\n yield* res.iterator();\n }\n return cat;\n});\n\nexports.createCat = createCat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createCommands = configure.configure(api => {\n const commands = async (options = {}) => {\n const res = await api.post('commands', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return res.json();\n };\n return commands;\n});\n\nexports.createCommands = createCommands;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createDns = configure.configure(api => {\n const dns = async (domain, options = {}) => {\n const res = await api.post('dns', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: domain,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return data.Path;\n };\n return dns;\n});\n\nexports.createDns = createDns;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\n\nconst createGetEndpointConfig = configure.configure(api => {\n return () => {\n const url = new URL(api.opts.base || '');\n return {\n host: url.hostname,\n port: url.port,\n protocol: url.protocol,\n pathname: url.pathname,\n 'api-path': url.pathname\n };\n };\n});\n\nexports.createGetEndpointConfig = createGetEndpointConfig;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createGet = configure.configure(api => {\n async function* get(path, options = {}) {\n const opts = {\n arg: `${ path instanceof Uint8Array ? cid.CID.decode(path) : path }`,\n ...options\n };\n if (opts.compressionLevel) {\n opts['compression-level'] = opts.compressionLevel;\n delete opts.compressionLevel;\n }\n const res = await api.post('get', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(opts),\n headers: options.headers\n });\n yield* res.iterator();\n }\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar multiaddr = require('multiaddr');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createId = configure.configure(api => {\n async function id(options = {}) {\n const res = await api.post('id', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: options.peerId ? options.peerId.toString() : undefined,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n const output = { ...objectToCamel.objectToCamel(data) };\n if (output.addresses) {\n output.addresses = output.addresses.map(ma => new multiaddr.Multiaddr(ma));\n }\n return output;\n }\n return id;\n});\n\nexports.createId = createId;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar id = require('./id.js');\n\nconst createIsOnline = options => {\n const id$1 = id.createId(options);\n async function isOnline(options = {}) {\n const res = await id$1(options);\n return Boolean(res && res.addresses && res.addresses.length);\n }\n return isOnline;\n};\n\nexports.createIsOnline = createIsOnline;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\nvar stat = require('./files/stat.js');\n\nconst createLs = configure.configure((api, opts) => {\n async function* ls(path, options = {}) {\n const pathStr = `${ path instanceof Uint8Array ? cid.CID.decode(path) : path }`;\n async function mapLink(link) {\n let hash = link.Hash;\n if (hash.includes('/')) {\n const ipfsPath = hash.startsWith('/ipfs/') ? hash : `/ipfs/${ hash }`;\n const stats = await stat.createStat(opts)(ipfsPath);\n hash = stats.cid;\n } else {\n hash = cid.CID.parse(hash);\n }\n const entry = {\n name: link.Name,\n path: pathStr + (link.Name ? `/${ link.Name }` : ''),\n size: link.Size,\n cid: hash,\n type: typeOf(link)\n };\n if (link.Mode) {\n entry.mode = parseInt(link.Mode, 8);\n }\n if (link.Mtime !== undefined && link.Mtime !== null) {\n entry.mtime = { secs: link.Mtime };\n if (link.MtimeNsecs !== undefined && link.MtimeNsecs !== null) {\n entry.mtime.nsecs = link.MtimeNsecs;\n }\n }\n return entry;\n }\n const res = await api.post('ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: pathStr,\n ...options\n }),\n headers: options.headers\n });\n for await (let result of res.ndjson()) {\n result = result.Objects;\n if (!result) {\n throw new Error('expected .Objects in results');\n }\n result = result[0];\n if (!result) {\n throw new Error('expected one array in results.Objects');\n }\n const links = result.Links;\n if (!Array.isArray(links)) {\n throw new Error('expected one array in results.Objects[0].Links');\n }\n if (!links.length) {\n yield mapLink(result);\n return;\n }\n yield* links.map(mapLink);\n }\n }\n return ls;\n});\nfunction typeOf(link) {\n switch (link.Type) {\n case 1:\n case 5:\n return 'dir';\n case 2:\n return 'file';\n default:\n return 'file';\n }\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createMount = configure.configure(api => {\n async function mount(options = {}) {\n const res = await api.post('dns', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return mount;\n});\n\nexports.createMount = createMount;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createPing = configure.configure(api => {\n async function* ping(peerId, options = {}) {\n const res = await api.post('ping', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ peerId }`,\n ...options\n }),\n headers: options.headers,\n transform: objectToCamel.objectToCamel\n });\n yield* res.ndjson();\n }\n return ping;\n});\n\nexports.createPing = createPing;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createResolve = configure.configure(api => {\n async function resolve(path, options = {}) {\n const res = await api.post('resolve', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n const {Path} = await res.json();\n return Path;\n }\n return resolve;\n});\n\nexports.createResolve = createResolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst createStart = configure.configure(api => {\n const start = async (options = {}) => {\n throw errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED');\n };\n return start;\n});\n\nexports.createStart = createStart;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createStop = configure.configure(api => {\n async function stop(options = {}) {\n const res = await api.post('shutdown', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n await res.text();\n }\n return stop;\n});\n\nexports.createStop = createStop;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createVersion = configure.configure(api => {\n async function version(options = {}) {\n const res = await api.post('version', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return {\n ...objectToCamel.objectToCamel(await res.json()),\n 'ipfs-http-client': '1.0.0'\n };\n }\n return version;\n});\n\nexports.createVersion = createVersion;\n","'use strict'\n\nconst HTTP = require('../http')\n\n/**\n *\n * @param {string} url\n * @param {import(\"../types\").HTTPOptions} [options]\n * @returns {{ path: string; content?: AsyncIterable }}\n */\nconst urlSource = (url, options) => {\n return {\n path: decodeURIComponent(new URL(url).pathname.split('/').pop() || ''),\n content: readURLContent(url, options)\n }\n}\n\n/**\n *\n * @param {string} url\n * @param {import(\"../types\").HTTPOptions} [options]\n * @returns {AsyncIterable}\n */\nasync function * readURLContent (url, options) {\n const http = new HTTP()\n const response = await http.get(url, options)\n\n yield * response.iterator()\n}\n\nmodule.exports = urlSource\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar WS = require('libp2p-websockets');\nvar WebRTCStar = require('libp2p-webrtc-star');\nvar Multiplex = require('libp2p-mplex');\nvar libp2pNoise = require('@chainsafe/libp2p-noise');\nvar KadDHT = require('libp2p-kad-dht');\nvar GossipSub = require('libp2p-gossipsub');\nvar ipns = require('./utils/ipns.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar WS__default = /*#__PURE__*/_interopDefaultLegacy(WS);\nvar WebRTCStar__default = /*#__PURE__*/_interopDefaultLegacy(WebRTCStar);\nvar Multiplex__default = /*#__PURE__*/_interopDefaultLegacy(Multiplex);\nvar KadDHT__default = /*#__PURE__*/_interopDefaultLegacy(KadDHT);\nvar GossipSub__default = /*#__PURE__*/_interopDefaultLegacy(GossipSub);\n\nfunction libp2pConfig() {\n const options = {\n dialer: {\n maxParallelDials: 150,\n maxDialsPerPeer: 4,\n dialTimeout: 10000\n },\n modules: {\n transport: [\n WS__default[\"default\"],\n WebRTCStar__default[\"default\"]\n ],\n streamMuxer: [Multiplex__default[\"default\"]],\n connEncryption: [libp2pNoise.NOISE],\n peerDiscovery: [],\n dht: KadDHT__default[\"default\"],\n pubsub: GossipSub__default[\"default\"]\n },\n config: {\n peerDiscovery: {\n autoDial: true,\n bootstrap: { enabled: true },\n webRTCStar: { enabled: true }\n },\n dht: {\n kBucketSize: 20,\n enabled: false,\n clientMode: true,\n randomWalk: { enabled: false },\n validators: { ipns: ipns.validator },\n selectors: { ipns: ipns.selector }\n },\n pubsub: {\n enabled: true,\n emitSelf: true\n },\n nat: { enabled: false }\n },\n metrics: { enabled: true },\n peerStore: {\n persistence: true,\n threshold: 1\n }\n };\n return options;\n}\n\nexports.libp2pConfig = libp2pConfig;\n","'use strict'\n\nconst connect = require('it-ws/client')\nconst withIs = require('class-is')\nconst toUri = require('multiaddr-to-uri')\nconst { AbortError } = require('abortable-iterator')\nconst pDefer = require('p-defer')\n\nconst debug = require('debug')\nconst log = debug('libp2p:websockets')\nlog.error = debug('libp2p:websockets:error')\nconst env = require('ipfs-utils/src/env')\n\nconst createListener = require('./listener')\nconst toConnection = require('./socket-to-conn')\nconst filters = require('./filters')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @class WebSockets\n */\nclass WebSockets {\n /**\n * @class\n * @param {object} options\n * @param {Upgrader} options.upgrader\n * @param {(multiaddrs: Array) => Array} options.filter - override transport addresses filter\n */\n constructor ({ upgrader, filter }) {\n if (!upgrader) {\n throw new Error('An upgrader must be provided. See https://github.com/libp2p/interface-transport#upgrader.')\n }\n this._upgrader = upgrader\n this._filter = filter\n }\n\n /**\n * @async\n * @param {Multiaddr} ma\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - Used to abort dial requests\n * @returns {Connection} An upgraded Connection\n */\n async dial (ma, options = {}) {\n log('dialing %s', ma)\n\n const socket = await this._connect(ma, options)\n const maConn = toConnection(socket, { remoteAddr: ma, signal: options.signal })\n log('new outbound connection %s', maConn.remoteAddr)\n\n const conn = await this._upgrader.upgradeOutbound(maConn)\n log('outbound connection %s upgraded', maConn.remoteAddr)\n return conn\n }\n\n /**\n * @private\n * @param {Multiaddr} ma\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - Used to abort dial requests\n * @returns {Promise} Resolves a extended duplex iterable on top of a WebSocket\n */\n async _connect (ma, options = {}) {\n if (options.signal && options.signal.aborted) {\n throw new AbortError()\n }\n const cOpts = ma.toOptions()\n log('dialing %s:%s', cOpts.host, cOpts.port)\n\n const errorPromise = pDefer()\n const errfn = (err) => {\n const msg = `connection error: ${err.message}`\n log.error(msg)\n\n errorPromise.reject(err)\n }\n\n const rawSocket = connect(toUri(ma), Object.assign({ binary: true }, options))\n\n if (rawSocket.socket.on) {\n rawSocket.socket.on('error', errfn)\n } else {\n rawSocket.socket.onerror = errfn\n }\n\n if (!options.signal) {\n await Promise.race([rawSocket.connected(), errorPromise.promise])\n\n log('connected %s', ma)\n return rawSocket\n }\n\n // Allow abort via signal during connect\n let onAbort\n const abort = new Promise((resolve, reject) => {\n onAbort = () => {\n reject(new AbortError())\n // FIXME: https://github.com/libp2p/js-libp2p-websockets/issues/121\n setTimeout(() => {\n rawSocket.close()\n })\n }\n\n // Already aborted?\n if (options.signal.aborted) return onAbort()\n options.signal.addEventListener('abort', onAbort)\n })\n\n try {\n await Promise.race([abort, errorPromise.promise, rawSocket.connected()])\n } finally {\n options.signal.removeEventListener('abort', onAbort)\n }\n\n log('connected %s', ma)\n return rawSocket\n }\n\n /**\n * Creates a Websockets listener. The provided `handler` function will be called\n * anytime a new incoming Connection has been successfully upgraded via\n * `upgrader.upgradeInbound`.\n *\n * @param {object} [options]\n * @param {http.Server} [options.server] - A pre-created Node.js HTTP/S server.\n * @param {function (Connection)} handler\n * @returns {Listener} A Websockets listener\n */\n createListener (options = {}, handler) {\n if (typeof options === 'function') {\n handler = options\n options = {}\n }\n\n return createListener({ handler, upgrader: this._upgrader }, options)\n }\n\n /**\n * Takes a list of `Multiaddr`s and returns only valid Websockets addresses.\n * By default, in a browser environment only DNS+WSS multiaddr is accepted,\n * while in a Node.js environment DNS+{WS, WSS} multiaddrs are accepted.\n *\n * @param {Multiaddr[]} multiaddrs\n * @returns {Multiaddr[]} Valid Websockets multiaddrs\n */\n filter (multiaddrs) {\n multiaddrs = Array.isArray(multiaddrs) ? multiaddrs : [multiaddrs]\n\n if (this._filter) {\n return this._filter(multiaddrs)\n }\n\n // Browser\n if (env.isBrowser || env.isWebWorker) {\n return filters.dnsWss(multiaddrs)\n }\n\n return filters.all(multiaddrs)\n }\n}\n\nmodule.exports = withIs(WebSockets, {\n className: 'WebSockets',\n symbolName: '@libp2p/js-libp2p-websockets/websockets'\n})\n","'use strict'\n\n// load websocket library if we are not in the browser\nvar WebSocket = require('./web-socket')\nvar duplex = require('./duplex')\nvar wsurl = require('./ws-url')\n\nmodule.exports = function (addr, opts = {}) {\n const location = typeof window === 'undefined' ? {} : window.location\n\n const url = wsurl(addr, location)\n const socket = new WebSocket(url, opts.websocket)\n\n const stream = duplex(socket, opts)\n stream.remoteAddress = url\n stream.close = () => new Promise((resolve, reject) => {\n socket.addEventListener('close', resolve)\n socket.close()\n })\n stream.destroy = () => {\n if (socket.terminate) {\n socket.terminate()\n } else {\n socket.close()\n }\n }\n stream.socket = socket\n\n return stream\n}\n\nmodule.exports.connect = module.exports\n","/* eslint-env browser */\nmodule.exports = typeof WebSocket === 'undefined' ? require('ws') : WebSocket\n","const source = require('./source')\nconst sink = require('./sink')\n\nmodule.exports = (socket, options) => {\n options = options || {}\n\n if (options.binaryType) {\n socket.binaryType = options.binaryType\n } else if (options.binary) {\n socket.binaryType = 'arraybuffer'\n }\n\n const duplex = {\n sink: sink(socket, options),\n source: source(socket, options),\n connected: () => duplex.source.connected()\n }\n\n return duplex\n}\n","const { Buffer } = require('buffer')\nconst { EventIterator } = require('event-iterator')\n\n// copied from github.com/feross/buffer\n// Some ArrayBuffers are not passing the instanceof check, so we need to do a bit more work :(\nfunction isArrayBuffer (obj) {\n return obj instanceof ArrayBuffer ||\n (obj != null && obj.constructor != null && obj.constructor.name === 'ArrayBuffer' &&\n typeof obj.byteLength === 'number')\n}\n\nmodule.exports = socket => {\n const removeListener = socket.removeEventListener || socket.removeListener\n\n const source = (async function * () {\n const messages = new EventIterator(\n ({ push, stop, fail }) => {\n socket.addEventListener('message', push)\n socket.addEventListener('error', fail)\n socket.addEventListener('close', stop)\n\n return () => {\n removeListener.call(socket, 'message', push)\n removeListener.call(socket, 'error', fail)\n removeListener.call(socket, 'close', stop)\n }\n },\n { highWaterMark: Infinity }\n )\n\n for await (const { data } of messages) {\n yield isArrayBuffer(data) ? Buffer.from(data) : data\n }\n })()\n\n let connected = socket.readyState === 1\n let connError\n\n socket.addEventListener('open', () => {\n connected = true\n connError = null\n })\n\n socket.addEventListener('close', () => {\n connected = false\n connError = null\n })\n\n socket.addEventListener('error', err => {\n if (!connected) connError = err\n })\n\n source.connected = () => new Promise((resolve, reject) => {\n if (connected) return resolve()\n if (connError) return reject(connError)\n\n const cleanUp = cont => {\n removeListener.call(socket, 'open', onOpen)\n removeListener.call(socket, 'error', onError)\n cont()\n }\n\n const onOpen = () => cleanUp(resolve)\n const onError = err => cleanUp(() => reject(err))\n\n socket.addEventListener('open', onOpen)\n socket.addEventListener('error', onError)\n })\n\n return source\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst event_iterator_1 = require(\"./event-iterator\");\nexports.EventIterator = event_iterator_1.EventIterator;\nfunction subscribe(event, options, evOptions) {\n return new event_iterator_1.EventIterator(({ push }) => {\n this.addEventListener(event, push, options);\n return () => this.removeEventListener(event, push, options);\n }, evOptions);\n}\nexports.subscribe = subscribe;\nexports.default = event_iterator_1.EventIterator;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nclass EventQueue {\n constructor() {\n this.pullQueue = [];\n this.pushQueue = [];\n this.eventHandlers = {};\n this.isPaused = false;\n this.isStopped = false;\n }\n push(value) {\n if (this.isStopped)\n return;\n const resolution = { value, done: false };\n if (this.pullQueue.length) {\n const placeholder = this.pullQueue.shift();\n if (placeholder)\n placeholder.resolve(resolution);\n }\n else {\n this.pushQueue.push(Promise.resolve(resolution));\n if (this.highWaterMark !== undefined &&\n this.pushQueue.length >= this.highWaterMark &&\n !this.isPaused) {\n this.isPaused = true;\n if (this.eventHandlers.highWater) {\n this.eventHandlers.highWater();\n }\n else if (console) {\n console.warn(`EventIterator queue reached ${this.pushQueue.length} items`);\n }\n }\n }\n }\n stop() {\n if (this.isStopped)\n return;\n this.isStopped = true;\n this.remove();\n for (const placeholder of this.pullQueue) {\n placeholder.resolve({ value: undefined, done: true });\n }\n this.pullQueue.length = 0;\n }\n fail(error) {\n if (this.isStopped)\n return;\n this.isStopped = true;\n this.remove();\n if (this.pullQueue.length) {\n for (const placeholder of this.pullQueue) {\n placeholder.reject(error);\n }\n this.pullQueue.length = 0;\n }\n else {\n const rejection = Promise.reject(error);\n /* Attach error handler to avoid leaking an unhandled promise rejection. */\n rejection.catch(() => { });\n this.pushQueue.push(rejection);\n }\n }\n remove() {\n Promise.resolve().then(() => {\n if (this.removeCallback)\n this.removeCallback();\n });\n }\n [Symbol.asyncIterator]() {\n return {\n next: (value) => {\n const result = this.pushQueue.shift();\n if (result) {\n if (this.lowWaterMark !== undefined &&\n this.pushQueue.length <= this.lowWaterMark &&\n this.isPaused) {\n this.isPaused = false;\n if (this.eventHandlers.lowWater) {\n this.eventHandlers.lowWater();\n }\n }\n return result;\n }\n else if (this.isStopped) {\n return Promise.resolve({ value: undefined, done: true });\n }\n else {\n return new Promise((resolve, reject) => {\n this.pullQueue.push({ resolve, reject });\n });\n }\n },\n return: () => {\n this.isStopped = true;\n this.pushQueue.length = 0;\n this.remove();\n return Promise.resolve({ value: undefined, done: true });\n },\n };\n }\n}\nclass EventIterator {\n constructor(listen, { highWaterMark = 100, lowWaterMark = 1 } = {}) {\n const queue = new EventQueue();\n queue.highWaterMark = highWaterMark;\n queue.lowWaterMark = lowWaterMark;\n queue.removeCallback =\n listen({\n push: value => queue.push(value),\n stop: () => queue.stop(),\n fail: error => queue.fail(error),\n on: (event, fn) => {\n queue.eventHandlers[event] = fn;\n },\n }) || (() => { });\n this[Symbol.asyncIterator] = () => queue[Symbol.asyncIterator]();\n Object.freeze(this);\n }\n}\nexports.EventIterator = EventIterator;\nexports.default = EventIterator;\n","const ready = require('./ready')\n\nmodule.exports = (socket, options) => {\n options = options || {}\n options.closeOnEnd = options.closeOnEnd !== false\n\n return async source => {\n for await (const data of source) {\n try {\n await ready(socket)\n } catch (err) {\n if (err.message === 'socket closed') break\n throw err\n }\n\n socket.send(data)\n }\n\n if (options.closeOnEnd && socket.readyState <= 1) {\n return new Promise((resolve, reject) => {\n socket.addEventListener('close', event => {\n if (event.wasClean || event.code === 1006) {\n resolve()\n } else {\n const err = Object.assign(new Error('ws error'), { event })\n reject(err)\n }\n })\n\n setTimeout(() => socket.close())\n })\n }\n }\n}\n","module.exports = async socket => {\n // if the socket is closing or closed, return end\n if (socket.readyState >= 2) {\n throw new Error('socket closed')\n }\n\n // if open, return\n if (socket.readyState === 1) {\n return\n }\n\n return new Promise((resolve, reject) => {\n const remove = socket && (socket.removeEventListener || socket.removeListener)\n\n function cleanup () {\n if (typeof remove === 'function') {\n remove.call(socket, 'open', handleOpen)\n remove.call(socket, 'error', handleErr)\n }\n }\n\n function handleOpen () {\n cleanup(); resolve()\n }\n\n function handleErr (evt) {\n cleanup(); reject(evt)\n }\n\n socket.addEventListener('open', handleOpen)\n socket.addEventListener('error', handleErr)\n })\n}\n","const { relative } = require('iso-url')\nconst map = { http: 'ws', https: 'wss' }\nconst def = 'ws'\n\nmodule.exports = (url, location) => relative(url, location, map, def)\n","'use strict'\n\nmodule.exports = function () {\n throw new Error('WebSocket Servers can not be created in the browser!')\n}\n","'use strict'\n\nconst abortable = require('abortable-iterator')\nconst { CLOSE_TIMEOUT } = require('./constants')\nconst toMultiaddr = require('libp2p-utils/src/ip-port-to-multiaddr')\n\nconst pTimeout = require('p-timeout')\n\nconst debug = require('debug')\nconst log = debug('libp2p:websockets:socket')\nlog.error = debug('libp2p:websockets:socket:error')\n\n// Convert a stream into a MultiaddrConnection\n// https://github.com/libp2p/interface-transport#multiaddrconnection\nmodule.exports = (stream, options = {}) => {\n const maConn = {\n async sink (source) {\n if (options.signal) {\n source = abortable(source, options.signal)\n }\n\n try {\n await stream.sink((async function * () {\n for await (const chunk of source) {\n // Convert BufferList to Buffer\n yield chunk instanceof Uint8Array ? chunk : chunk.slice()\n }\n })())\n } catch (err) {\n if (err.type !== 'aborted') {\n log.error(err)\n }\n }\n },\n\n source: options.signal ? abortable(stream.source, options.signal) : stream.source,\n\n conn: stream,\n\n localAddr: options.localAddr || (stream.localAddress && stream.localPort\n ? toMultiaddr(stream.localAddress, stream.localPort)\n : undefined),\n\n // If the remote address was passed, use it - it may have the peer ID encapsulated\n remoteAddr: options.remoteAddr || toMultiaddr(stream.remoteAddress, stream.remotePort),\n\n timeline: { open: Date.now() },\n\n async close () {\n const start = Date.now()\n\n try {\n await pTimeout(stream.close(), CLOSE_TIMEOUT)\n } catch (err) {\n const { host, port } = maConn.remoteAddr.toOptions()\n log('timeout closing stream to %s:%s after %dms, destroying it manually',\n host, port, Date.now() - start)\n\n stream.destroy()\n } finally {\n maConn.timeline.close = Date.now()\n }\n }\n }\n\n stream.socket.once && stream.socket.once('close', () => {\n // In instances where `close` was not explicitly called,\n // such as an iterable stream ending, ensure we have set the close\n // timeline\n if (!maConn.timeline.close) {\n maConn.timeline.close = Date.now()\n }\n })\n\n return maConn\n}\n","'use strict'\n\n// p2p multi-address code\nexports.CODE_P2P = 421\nexports.CODE_CIRCUIT = 290\n\nexports.CODE_TCP = 6\nexports.CODE_WS = 477\nexports.CODE_WSS = 478\n\n// Time to wait for a connection to close gracefully before destroying it manually\nexports.CLOSE_TIMEOUT = 2000\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:ip-port-to-multiaddr'), {\n error: debug('libp2p:ip-port-to-multiaddr:err')\n})\nconst { Multiaddr } = require('multiaddr')\nconst errCode = require('err-code')\nconst { Address4, Address6 } = require('ip-address')\n\nconst errors = {\n ERR_INVALID_IP_PARAMETER: 'ERR_INVALID_IP_PARAMETER',\n ERR_INVALID_PORT_PARAMETER: 'ERR_INVALID_PORT_PARAMETER',\n ERR_INVALID_IP: 'ERR_INVALID_IP'\n}\n\n/**\n * Transform an IP, Port pair into a multiaddr\n *\n * @param {string} ip\n * @param {number|string} port\n */\nfunction ipPortToMultiaddr (ip, port) {\n if (typeof ip !== 'string') {\n throw errCode(new Error(`invalid ip provided: ${ip}`), errors.ERR_INVALID_IP_PARAMETER)\n }\n\n if (typeof port === 'string') {\n port = parseInt(port)\n }\n\n if (isNaN(port)) {\n throw errCode(new Error(`invalid port provided: ${port}`), errors.ERR_INVALID_PORT_PARAMETER)\n }\n\n try {\n // Test valid IPv4\n new Address4(ip) // eslint-disable-line no-new\n return new Multiaddr(`/ip4/${ip}/tcp/${port}`)\n } catch {}\n\n try {\n // Test valid IPv6\n const ip6 = new Address6(ip)\n return ip6.is4()\n ? new Multiaddr(`/ip4/${ip6.to4().correctForm()}/tcp/${port}`)\n : new Multiaddr(`/ip6/${ip}/tcp/${port}`)\n } catch (err) {\n const errMsg = `invalid ip:port for creating a multiaddr: ${ip}:${port}`\n log.error(errMsg)\n throw errCode(new Error(errMsg), errors.ERR_INVALID_IP)\n }\n}\n\nmodule.exports = ipPortToMultiaddr\n\nmodule.exports.Errors = errors\n",null,null,null,null,null,"(function(){\n\n // Copyright (c) 2005 Tom Wu\n // All Rights Reserved.\n // See \"LICENSE\" for details.\n\n // Basic JavaScript BN library - subset useful for RSA encryption.\n\n // Bits per digit\n var dbits;\n\n // JavaScript engine analysis\n var canary = 0xdeadbeefcafe;\n var j_lm = ((canary&0xffffff)==0xefcafe);\n\n // (public) Constructor\n function BigInteger(a,b,c) {\n if(a != null)\n if(\"number\" == typeof a) this.fromNumber(a,b,c);\n else if(b == null && \"string\" != typeof a) this.fromString(a,256);\n else this.fromString(a,b);\n }\n\n // return new, unset BigInteger\n function nbi() { return new BigInteger(null); }\n\n // am: Compute w_j += (x*this_i), propagate carries,\n // c is initial carry, returns final carry.\n // c < 3*dvalue, x < 2*dvalue, this_i < dvalue\n // We need to select the fastest one that works in this environment.\n\n // am1: use a single mult and divide to get the high bits,\n // max digit bits should be 26 because\n // max internal value = 2*dvalue^2-2*dvalue (< 2^53)\n function am1(i,x,w,j,c,n) {\n while(--n >= 0) {\n var v = x*this[i++]+w[j]+c;\n c = Math.floor(v/0x4000000);\n w[j++] = v&0x3ffffff;\n }\n return c;\n }\n // am2 avoids a big mult-and-extract completely.\n // Max digit bits should be <= 30 because we do bitwise ops\n // on values up to 2*hdvalue^2-hdvalue-1 (< 2^31)\n function am2(i,x,w,j,c,n) {\n var xl = x&0x7fff, xh = x>>15;\n while(--n >= 0) {\n var l = this[i]&0x7fff;\n var h = this[i++]>>15;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x7fff)<<15)+w[j]+(c&0x3fffffff);\n c = (l>>>30)+(m>>>15)+xh*h+(c>>>30);\n w[j++] = l&0x3fffffff;\n }\n return c;\n }\n // Alternately, set max digit bits to 28 since some\n // browsers slow down when dealing with 32-bit numbers.\n function am3(i,x,w,j,c,n) {\n var xl = x&0x3fff, xh = x>>14;\n while(--n >= 0) {\n var l = this[i]&0x3fff;\n var h = this[i++]>>14;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x3fff)<<14)+w[j]+c;\n c = (l>>28)+(m>>14)+xh*h;\n w[j++] = l&0xfffffff;\n }\n return c;\n }\n var inBrowser = typeof navigator !== \"undefined\";\n if(inBrowser && j_lm && (navigator.appName == \"Microsoft Internet Explorer\")) {\n BigInteger.prototype.am = am2;\n dbits = 30;\n }\n else if(inBrowser && j_lm && (navigator.appName != \"Netscape\")) {\n BigInteger.prototype.am = am1;\n dbits = 26;\n }\n else { // Mozilla/Netscape seems to prefer am3\n BigInteger.prototype.am = am3;\n dbits = 28;\n }\n\n BigInteger.prototype.DB = dbits;\n BigInteger.prototype.DM = ((1<= 0; --i) r[i] = this[i];\n r.t = this.t;\n r.s = this.s;\n }\n\n // (protected) set from integer value x, -DV <= x < DV\n function bnpFromInt(x) {\n this.t = 1;\n this.s = (x<0)?-1:0;\n if(x > 0) this[0] = x;\n else if(x < -1) this[0] = x+this.DV;\n else this.t = 0;\n }\n\n // return bigint initialized to value\n function nbv(i) { var r = nbi(); r.fromInt(i); return r; }\n\n // (protected) set from string and radix\n function bnpFromString(s,b) {\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 256) k = 8; // byte array\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else { this.fromRadix(s,b); return; }\n this.t = 0;\n this.s = 0;\n var i = s.length, mi = false, sh = 0;\n while(--i >= 0) {\n var x = (k==8)?s[i]&0xff:intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\") mi = true;\n continue;\n }\n mi = false;\n if(sh == 0)\n this[this.t++] = x;\n else if(sh+k > this.DB) {\n this[this.t-1] |= (x&((1<<(this.DB-sh))-1))<>(this.DB-sh));\n }\n else\n this[this.t-1] |= x<= this.DB) sh -= this.DB;\n }\n if(k == 8 && (s[0]&0x80) != 0) {\n this.s = -1;\n if(sh > 0) this[this.t-1] |= ((1<<(this.DB-sh))-1)< 0 && this[this.t-1] == c) --this.t;\n }\n\n // (public) return string representation in given radix\n function bnToString(b) {\n if(this.s < 0) return \"-\"+this.negate().toString(b);\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else return this.toRadix(b);\n var km = (1< 0) {\n if(p < this.DB && (d = this[i]>>p) > 0) { m = true; r = int2char(d); }\n while(i >= 0) {\n if(p < k) {\n d = (this[i]&((1<>(p+=this.DB-k);\n }\n else {\n d = (this[i]>>(p-=k))&km;\n if(p <= 0) { p += this.DB; --i; }\n }\n if(d > 0) m = true;\n if(m) r += int2char(d);\n }\n }\n return m?r:\"0\";\n }\n\n // (public) -this\n function bnNegate() { var r = nbi(); BigInteger.ZERO.subTo(this,r); return r; }\n\n // (public) |this|\n function bnAbs() { return (this.s<0)?this.negate():this; }\n\n // (public) return + if this > a, - if this < a, 0 if equal\n function bnCompareTo(a) {\n var r = this.s-a.s;\n if(r != 0) return r;\n var i = this.t;\n r = i-a.t;\n if(r != 0) return (this.s<0)?-r:r;\n while(--i >= 0) if((r=this[i]-a[i]) != 0) return r;\n return 0;\n }\n\n // returns bit length of the integer x\n function nbits(x) {\n var r = 1, t;\n if((t=x>>>16) != 0) { x = t; r += 16; }\n if((t=x>>8) != 0) { x = t; r += 8; }\n if((t=x>>4) != 0) { x = t; r += 4; }\n if((t=x>>2) != 0) { x = t; r += 2; }\n if((t=x>>1) != 0) { x = t; r += 1; }\n return r;\n }\n\n // (public) return the number of bits in \"this\"\n function bnBitLength() {\n if(this.t <= 0) return 0;\n return this.DB*(this.t-1)+nbits(this[this.t-1]^(this.s&this.DM));\n }\n\n // (protected) r = this << n*DB\n function bnpDLShiftTo(n,r) {\n var i;\n for(i = this.t-1; i >= 0; --i) r[i+n] = this[i];\n for(i = n-1; i >= 0; --i) r[i] = 0;\n r.t = this.t+n;\n r.s = this.s;\n }\n\n // (protected) r = this >> n*DB\n function bnpDRShiftTo(n,r) {\n for(var i = n; i < this.t; ++i) r[i-n] = this[i];\n r.t = Math.max(this.t-n,0);\n r.s = this.s;\n }\n\n // (protected) r = this << n\n function bnpLShiftTo(n,r) {\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<= 0; --i) {\n r[i+ds+1] = (this[i]>>cbs)|c;\n c = (this[i]&bm)<= 0; --i) r[i] = 0;\n r[ds] = c;\n r.t = this.t+ds+1;\n r.s = this.s;\n r.clamp();\n }\n\n // (protected) r = this >> n\n function bnpRShiftTo(n,r) {\n r.s = this.s;\n var ds = Math.floor(n/this.DB);\n if(ds >= this.t) { r.t = 0; return; }\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<>bs;\n for(var i = ds+1; i < this.t; ++i) {\n r[i-ds-1] |= (this[i]&bm)<>bs;\n }\n if(bs > 0) r[this.t-ds-1] |= (this.s&bm)<>= this.DB;\n }\n if(a.t < this.t) {\n c -= a.s;\n while(i < this.t) {\n c += this[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n }\n else {\n c += this.s;\n while(i < a.t) {\n c -= a[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n c -= a.s;\n }\n r.s = (c<0)?-1:0;\n if(c < -1) r[i++] = this.DV+c;\n else if(c > 0) r[i++] = c;\n r.t = i;\n r.clamp();\n }\n\n // (protected) r = this * a, r != this,a (HAC 14.12)\n // \"this\" should be the larger one if appropriate.\n function bnpMultiplyTo(a,r) {\n var x = this.abs(), y = a.abs();\n var i = x.t;\n r.t = i+y.t;\n while(--i >= 0) r[i] = 0;\n for(i = 0; i < y.t; ++i) r[i+x.t] = x.am(0,y[i],r,i,0,x.t);\n r.s = 0;\n r.clamp();\n if(this.s != a.s) BigInteger.ZERO.subTo(r,r);\n }\n\n // (protected) r = this^2, r != this (HAC 14.16)\n function bnpSquareTo(r) {\n var x = this.abs();\n var i = r.t = 2*x.t;\n while(--i >= 0) r[i] = 0;\n for(i = 0; i < x.t-1; ++i) {\n var c = x.am(i,x[i],r,2*i,0,1);\n if((r[i+x.t]+=x.am(i+1,2*x[i],r,2*i+1,c,x.t-i-1)) >= x.DV) {\n r[i+x.t] -= x.DV;\n r[i+x.t+1] = 1;\n }\n }\n if(r.t > 0) r[r.t-1] += x.am(i,x[i],r,2*i,0,1);\n r.s = 0;\n r.clamp();\n }\n\n // (protected) divide this by m, quotient and remainder to q, r (HAC 14.20)\n // r != q, this != m. q or r may be null.\n function bnpDivRemTo(m,q,r) {\n var pm = m.abs();\n if(pm.t <= 0) return;\n var pt = this.abs();\n if(pt.t < pm.t) {\n if(q != null) q.fromInt(0);\n if(r != null) this.copyTo(r);\n return;\n }\n if(r == null) r = nbi();\n var y = nbi(), ts = this.s, ms = m.s;\n var nsh = this.DB-nbits(pm[pm.t-1]); // normalize modulus\n if(nsh > 0) { pm.lShiftTo(nsh,y); pt.lShiftTo(nsh,r); }\n else { pm.copyTo(y); pt.copyTo(r); }\n var ys = y.t;\n var y0 = y[ys-1];\n if(y0 == 0) return;\n var yt = y0*(1<1)?y[ys-2]>>this.F2:0);\n var d1 = this.FV/yt, d2 = (1<= 0) {\n r[r.t++] = 1;\n r.subTo(t,r);\n }\n BigInteger.ONE.dlShiftTo(ys,t);\n t.subTo(y,y); // \"negative\" y so we can replace sub with am later\n while(y.t < ys) y[y.t++] = 0;\n while(--j >= 0) {\n // Estimate quotient digit\n var qd = (r[--i]==y0)?this.DM:Math.floor(r[i]*d1+(r[i-1]+e)*d2);\n if((r[i]+=y.am(0,qd,r,j,0,ys)) < qd) { // Try it out\n y.dlShiftTo(j,t);\n r.subTo(t,r);\n while(r[i] < --qd) r.subTo(t,r);\n }\n }\n if(q != null) {\n r.drShiftTo(ys,q);\n if(ts != ms) BigInteger.ZERO.subTo(q,q);\n }\n r.t = ys;\n r.clamp();\n if(nsh > 0) r.rShiftTo(nsh,r); // Denormalize remainder\n if(ts < 0) BigInteger.ZERO.subTo(r,r);\n }\n\n // (public) this mod a\n function bnMod(a) {\n var r = nbi();\n this.abs().divRemTo(a,null,r);\n if(this.s < 0 && r.compareTo(BigInteger.ZERO) > 0) a.subTo(r,r);\n return r;\n }\n\n // Modular reduction using \"classic\" algorithm\n function Classic(m) { this.m = m; }\n function cConvert(x) {\n if(x.s < 0 || x.compareTo(this.m) >= 0) return x.mod(this.m);\n else return x;\n }\n function cRevert(x) { return x; }\n function cReduce(x) { x.divRemTo(this.m,null,x); }\n function cMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n function cSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n Classic.prototype.convert = cConvert;\n Classic.prototype.revert = cRevert;\n Classic.prototype.reduce = cReduce;\n Classic.prototype.mulTo = cMulTo;\n Classic.prototype.sqrTo = cSqrTo;\n\n // (protected) return \"-1/this % 2^DB\"; useful for Mont. reduction\n // justification:\n // xy == 1 (mod m)\n // xy = 1+km\n // xy(2-xy) = (1+km)(1-km)\n // x[y(2-xy)] = 1-k^2m^2\n // x[y(2-xy)] == 1 (mod m^2)\n // if y is 1/x mod m, then y(2-xy) is 1/x mod m^2\n // should reduce x and y(2-xy) by m^2 at each step to keep size bounded.\n // JS multiply \"overflows\" differently from C/C++, so care is needed here.\n function bnpInvDigit() {\n if(this.t < 1) return 0;\n var x = this[0];\n if((x&1) == 0) return 0;\n var y = x&3; // y == 1/x mod 2^2\n y = (y*(2-(x&0xf)*y))&0xf; // y == 1/x mod 2^4\n y = (y*(2-(x&0xff)*y))&0xff; // y == 1/x mod 2^8\n y = (y*(2-(((x&0xffff)*y)&0xffff)))&0xffff; // y == 1/x mod 2^16\n // last step - calculate inverse mod DV directly;\n // assumes 16 < DB <= 32 and assumes ability to handle 48-bit ints\n y = (y*(2-x*y%this.DV))%this.DV; // y == 1/x mod 2^dbits\n // we really want the negative inverse, and -DV < y < DV\n return (y>0)?this.DV-y:-y;\n }\n\n // Montgomery reduction\n function Montgomery(m) {\n this.m = m;\n this.mp = m.invDigit();\n this.mpl = this.mp&0x7fff;\n this.mph = this.mp>>15;\n this.um = (1<<(m.DB-15))-1;\n this.mt2 = 2*m.t;\n }\n\n // xR mod m\n function montConvert(x) {\n var r = nbi();\n x.abs().dlShiftTo(this.m.t,r);\n r.divRemTo(this.m,null,r);\n if(x.s < 0 && r.compareTo(BigInteger.ZERO) > 0) this.m.subTo(r,r);\n return r;\n }\n\n // x/R mod m\n function montRevert(x) {\n var r = nbi();\n x.copyTo(r);\n this.reduce(r);\n return r;\n }\n\n // x = x/R mod m (HAC 14.32)\n function montReduce(x) {\n while(x.t <= this.mt2) // pad x so am has enough room later\n x[x.t++] = 0;\n for(var i = 0; i < this.m.t; ++i) {\n // faster way of calculating u0 = x[i]*mp mod DV\n var j = x[i]&0x7fff;\n var u0 = (j*this.mpl+(((j*this.mph+(x[i]>>15)*this.mpl)&this.um)<<15))&x.DM;\n // use am to combine the multiply-shift-add into one call\n j = i+this.m.t;\n x[j] += this.m.am(0,u0,x,i,0,this.m.t);\n // propagate carry\n while(x[j] >= x.DV) { x[j] -= x.DV; x[++j]++; }\n }\n x.clamp();\n x.drShiftTo(this.m.t,x);\n if(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n }\n\n // r = \"x^2/R mod m\"; x != r\n function montSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n // r = \"xy/R mod m\"; x,y != r\n function montMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\n Montgomery.prototype.convert = montConvert;\n Montgomery.prototype.revert = montRevert;\n Montgomery.prototype.reduce = montReduce;\n Montgomery.prototype.mulTo = montMulTo;\n Montgomery.prototype.sqrTo = montSqrTo;\n\n // (protected) true iff this is even\n function bnpIsEven() { return ((this.t>0)?(this[0]&1):this.s) == 0; }\n\n // (protected) this^e, e < 2^32, doing sqr and mul with \"r\" (HAC 14.79)\n function bnpExp(e,z) {\n if(e > 0xffffffff || e < 1) return BigInteger.ONE;\n var r = nbi(), r2 = nbi(), g = z.convert(this), i = nbits(e)-1;\n g.copyTo(r);\n while(--i >= 0) {\n z.sqrTo(r,r2);\n if((e&(1< 0) z.mulTo(r2,g,r);\n else { var t = r; r = r2; r2 = t; }\n }\n return z.revert(r);\n }\n\n // (public) this^e % m, 0 <= e < 2^32\n function bnModPowInt(e,m) {\n var z;\n if(e < 256 || m.isEven()) z = new Classic(m); else z = new Montgomery(m);\n return this.exp(e,z);\n }\n\n // protected\n BigInteger.prototype.copyTo = bnpCopyTo;\n BigInteger.prototype.fromInt = bnpFromInt;\n BigInteger.prototype.fromString = bnpFromString;\n BigInteger.prototype.clamp = bnpClamp;\n BigInteger.prototype.dlShiftTo = bnpDLShiftTo;\n BigInteger.prototype.drShiftTo = bnpDRShiftTo;\n BigInteger.prototype.lShiftTo = bnpLShiftTo;\n BigInteger.prototype.rShiftTo = bnpRShiftTo;\n BigInteger.prototype.subTo = bnpSubTo;\n BigInteger.prototype.multiplyTo = bnpMultiplyTo;\n BigInteger.prototype.squareTo = bnpSquareTo;\n BigInteger.prototype.divRemTo = bnpDivRemTo;\n BigInteger.prototype.invDigit = bnpInvDigit;\n BigInteger.prototype.isEven = bnpIsEven;\n BigInteger.prototype.exp = bnpExp;\n\n // public\n BigInteger.prototype.toString = bnToString;\n BigInteger.prototype.negate = bnNegate;\n BigInteger.prototype.abs = bnAbs;\n BigInteger.prototype.compareTo = bnCompareTo;\n BigInteger.prototype.bitLength = bnBitLength;\n BigInteger.prototype.mod = bnMod;\n BigInteger.prototype.modPowInt = bnModPowInt;\n\n // \"constants\"\n BigInteger.ZERO = nbv(0);\n BigInteger.ONE = nbv(1);\n\n // Copyright (c) 2005-2009 Tom Wu\n // All Rights Reserved.\n // See \"LICENSE\" for details.\n\n // Extended JavaScript BN functions, required for RSA private ops.\n\n // Version 1.1: new BigInteger(\"0\", 10) returns \"proper\" zero\n // Version 1.2: square() API, isProbablePrime fix\n\n // (public)\n function bnClone() { var r = nbi(); this.copyTo(r); return r; }\n\n // (public) return value as integer\n function bnIntValue() {\n if(this.s < 0) {\n if(this.t == 1) return this[0]-this.DV;\n else if(this.t == 0) return -1;\n }\n else if(this.t == 1) return this[0];\n else if(this.t == 0) return 0;\n // assumes 16 < DB < 32\n return ((this[1]&((1<<(32-this.DB))-1))<>24; }\n\n // (public) return value as short (assumes DB>=16)\n function bnShortValue() { return (this.t==0)?this.s:(this[0]<<16)>>16; }\n\n // (protected) return x s.t. r^x < DV\n function bnpChunkSize(r) { return Math.floor(Math.LN2*this.DB/Math.log(r)); }\n\n // (public) 0 if this == 0, 1 if this > 0\n function bnSigNum() {\n if(this.s < 0) return -1;\n else if(this.t <= 0 || (this.t == 1 && this[0] <= 0)) return 0;\n else return 1;\n }\n\n // (protected) convert to radix string\n function bnpToRadix(b) {\n if(b == null) b = 10;\n if(this.signum() == 0 || b < 2 || b > 36) return \"0\";\n var cs = this.chunkSize(b);\n var a = Math.pow(b,cs);\n var d = nbv(a), y = nbi(), z = nbi(), r = \"\";\n this.divRemTo(d,y,z);\n while(y.signum() > 0) {\n r = (a+z.intValue()).toString(b).substr(1) + r;\n y.divRemTo(d,y,z);\n }\n return z.intValue().toString(b) + r;\n }\n\n // (protected) convert from radix string\n function bnpFromRadix(s,b) {\n this.fromInt(0);\n if(b == null) b = 10;\n var cs = this.chunkSize(b);\n var d = Math.pow(b,cs), mi = false, j = 0, w = 0;\n for(var i = 0; i < s.length; ++i) {\n var x = intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\" && this.signum() == 0) mi = true;\n continue;\n }\n w = b*w+x;\n if(++j >= cs) {\n this.dMultiply(d);\n this.dAddOffset(w,0);\n j = 0;\n w = 0;\n }\n }\n if(j > 0) {\n this.dMultiply(Math.pow(b,j));\n this.dAddOffset(w,0);\n }\n if(mi) BigInteger.ZERO.subTo(this,this);\n }\n\n // (protected) alternate constructor\n function bnpFromNumber(a,b,c) {\n if(\"number\" == typeof b) {\n // new BigInteger(int,int,RNG)\n if(a < 2) this.fromInt(1);\n else {\n this.fromNumber(a,c);\n if(!this.testBit(a-1)) // force MSB set\n this.bitwiseTo(BigInteger.ONE.shiftLeft(a-1),op_or,this);\n if(this.isEven()) this.dAddOffset(1,0); // force odd\n while(!this.isProbablePrime(b)) {\n this.dAddOffset(2,0);\n if(this.bitLength() > a) this.subTo(BigInteger.ONE.shiftLeft(a-1),this);\n }\n }\n }\n else {\n // new BigInteger(int,RNG)\n var x = new Array(), t = a&7;\n x.length = (a>>3)+1;\n b.nextBytes(x);\n if(t > 0) x[0] &= ((1< 0) {\n if(p < this.DB && (d = this[i]>>p) != (this.s&this.DM)>>p)\n r[k++] = d|(this.s<<(this.DB-p));\n while(i >= 0) {\n if(p < 8) {\n d = (this[i]&((1<>(p+=this.DB-8);\n }\n else {\n d = (this[i]>>(p-=8))&0xff;\n if(p <= 0) { p += this.DB; --i; }\n }\n if((d&0x80) != 0) d |= -256;\n if(k == 0 && (this.s&0x80) != (d&0x80)) ++k;\n if(k > 0 || d != this.s) r[k++] = d;\n }\n }\n return r;\n }\n\n function bnEquals(a) { return(this.compareTo(a)==0); }\n function bnMin(a) { return(this.compareTo(a)<0)?this:a; }\n function bnMax(a) { return(this.compareTo(a)>0)?this:a; }\n\n // (protected) r = this op a (bitwise)\n function bnpBitwiseTo(a,op,r) {\n var i, f, m = Math.min(a.t,this.t);\n for(i = 0; i < m; ++i) r[i] = op(this[i],a[i]);\n if(a.t < this.t) {\n f = a.s&this.DM;\n for(i = m; i < this.t; ++i) r[i] = op(this[i],f);\n r.t = this.t;\n }\n else {\n f = this.s&this.DM;\n for(i = m; i < a.t; ++i) r[i] = op(f,a[i]);\n r.t = a.t;\n }\n r.s = op(this.s,a.s);\n r.clamp();\n }\n\n // (public) this & a\n function op_and(x,y) { return x&y; }\n function bnAnd(a) { var r = nbi(); this.bitwiseTo(a,op_and,r); return r; }\n\n // (public) this | a\n function op_or(x,y) { return x|y; }\n function bnOr(a) { var r = nbi(); this.bitwiseTo(a,op_or,r); return r; }\n\n // (public) this ^ a\n function op_xor(x,y) { return x^y; }\n function bnXor(a) { var r = nbi(); this.bitwiseTo(a,op_xor,r); return r; }\n\n // (public) this & ~a\n function op_andnot(x,y) { return x&~y; }\n function bnAndNot(a) { var r = nbi(); this.bitwiseTo(a,op_andnot,r); return r; }\n\n // (public) ~this\n function bnNot() {\n var r = nbi();\n for(var i = 0; i < this.t; ++i) r[i] = this.DM&~this[i];\n r.t = this.t;\n r.s = ~this.s;\n return r;\n }\n\n // (public) this << n\n function bnShiftLeft(n) {\n var r = nbi();\n if(n < 0) this.rShiftTo(-n,r); else this.lShiftTo(n,r);\n return r;\n }\n\n // (public) this >> n\n function bnShiftRight(n) {\n var r = nbi();\n if(n < 0) this.lShiftTo(-n,r); else this.rShiftTo(n,r);\n return r;\n }\n\n // return index of lowest 1-bit in x, x < 2^31\n function lbit(x) {\n if(x == 0) return -1;\n var r = 0;\n if((x&0xffff) == 0) { x >>= 16; r += 16; }\n if((x&0xff) == 0) { x >>= 8; r += 8; }\n if((x&0xf) == 0) { x >>= 4; r += 4; }\n if((x&3) == 0) { x >>= 2; r += 2; }\n if((x&1) == 0) ++r;\n return r;\n }\n\n // (public) returns index of lowest 1-bit (or -1 if none)\n function bnGetLowestSetBit() {\n for(var i = 0; i < this.t; ++i)\n if(this[i] != 0) return i*this.DB+lbit(this[i]);\n if(this.s < 0) return this.t*this.DB;\n return -1;\n }\n\n // return number of 1 bits in x\n function cbit(x) {\n var r = 0;\n while(x != 0) { x &= x-1; ++r; }\n return r;\n }\n\n // (public) return number of set bits\n function bnBitCount() {\n var r = 0, x = this.s&this.DM;\n for(var i = 0; i < this.t; ++i) r += cbit(this[i]^x);\n return r;\n }\n\n // (public) true iff nth bit is set\n function bnTestBit(n) {\n var j = Math.floor(n/this.DB);\n if(j >= this.t) return(this.s!=0);\n return((this[j]&(1<<(n%this.DB)))!=0);\n }\n\n // (protected) this op (1<>= this.DB;\n }\n if(a.t < this.t) {\n c += a.s;\n while(i < this.t) {\n c += this[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n }\n else {\n c += this.s;\n while(i < a.t) {\n c += a[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += a.s;\n }\n r.s = (c<0)?-1:0;\n if(c > 0) r[i++] = c;\n else if(c < -1) r[i++] = this.DV+c;\n r.t = i;\n r.clamp();\n }\n\n // (public) this + a\n function bnAdd(a) { var r = nbi(); this.addTo(a,r); return r; }\n\n // (public) this - a\n function bnSubtract(a) { var r = nbi(); this.subTo(a,r); return r; }\n\n // (public) this * a\n function bnMultiply(a) { var r = nbi(); this.multiplyTo(a,r); return r; }\n\n // (public) this^2\n function bnSquare() { var r = nbi(); this.squareTo(r); return r; }\n\n // (public) this / a\n function bnDivide(a) { var r = nbi(); this.divRemTo(a,r,null); return r; }\n\n // (public) this % a\n function bnRemainder(a) { var r = nbi(); this.divRemTo(a,null,r); return r; }\n\n // (public) [this/a,this%a]\n function bnDivideAndRemainder(a) {\n var q = nbi(), r = nbi();\n this.divRemTo(a,q,r);\n return new Array(q,r);\n }\n\n // (protected) this *= n, this >= 0, 1 < n < DV\n function bnpDMultiply(n) {\n this[this.t] = this.am(0,n-1,this,0,0,this.t);\n ++this.t;\n this.clamp();\n }\n\n // (protected) this += n << w words, this >= 0\n function bnpDAddOffset(n,w) {\n if(n == 0) return;\n while(this.t <= w) this[this.t++] = 0;\n this[w] += n;\n while(this[w] >= this.DV) {\n this[w] -= this.DV;\n if(++w >= this.t) this[this.t++] = 0;\n ++this[w];\n }\n }\n\n // A \"null\" reducer\n function NullExp() {}\n function nNop(x) { return x; }\n function nMulTo(x,y,r) { x.multiplyTo(y,r); }\n function nSqrTo(x,r) { x.squareTo(r); }\n\n NullExp.prototype.convert = nNop;\n NullExp.prototype.revert = nNop;\n NullExp.prototype.mulTo = nMulTo;\n NullExp.prototype.sqrTo = nSqrTo;\n\n // (public) this^e\n function bnPow(e) { return this.exp(e,new NullExp()); }\n\n // (protected) r = lower n words of \"this * a\", a.t <= n\n // \"this\" should be the larger one if appropriate.\n function bnpMultiplyLowerTo(a,n,r) {\n var i = Math.min(this.t+a.t,n);\n r.s = 0; // assumes a,this >= 0\n r.t = i;\n while(i > 0) r[--i] = 0;\n var j;\n for(j = r.t-this.t; i < j; ++i) r[i+this.t] = this.am(0,a[i],r,i,0,this.t);\n for(j = Math.min(a.t,n); i < j; ++i) this.am(0,a[i],r,i,0,n-i);\n r.clamp();\n }\n\n // (protected) r = \"this * a\" without lower n words, n > 0\n // \"this\" should be the larger one if appropriate.\n function bnpMultiplyUpperTo(a,n,r) {\n --n;\n var i = r.t = this.t+a.t-n;\n r.s = 0; // assumes a,this >= 0\n while(--i >= 0) r[i] = 0;\n for(i = Math.max(n-this.t,0); i < a.t; ++i)\n r[this.t+i-n] = this.am(n-i,a[i],r,0,0,this.t+i-n);\n r.clamp();\n r.drShiftTo(1,r);\n }\n\n // Barrett modular reduction\n function Barrett(m) {\n // setup Barrett\n this.r2 = nbi();\n this.q3 = nbi();\n BigInteger.ONE.dlShiftTo(2*m.t,this.r2);\n this.mu = this.r2.divide(m);\n this.m = m;\n }\n\n function barrettConvert(x) {\n if(x.s < 0 || x.t > 2*this.m.t) return x.mod(this.m);\n else if(x.compareTo(this.m) < 0) return x;\n else { var r = nbi(); x.copyTo(r); this.reduce(r); return r; }\n }\n\n function barrettRevert(x) { return x; }\n\n // x = x mod m (HAC 14.42)\n function barrettReduce(x) {\n x.drShiftTo(this.m.t-1,this.r2);\n if(x.t > this.m.t+1) { x.t = this.m.t+1; x.clamp(); }\n this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3);\n this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);\n while(x.compareTo(this.r2) < 0) x.dAddOffset(1,this.m.t+1);\n x.subTo(this.r2,x);\n while(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n }\n\n // r = x^2 mod m; x != r\n function barrettSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n // r = x*y mod m; x,y != r\n function barrettMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\n Barrett.prototype.convert = barrettConvert;\n Barrett.prototype.revert = barrettRevert;\n Barrett.prototype.reduce = barrettReduce;\n Barrett.prototype.mulTo = barrettMulTo;\n Barrett.prototype.sqrTo = barrettSqrTo;\n\n // (public) this^e % m (HAC 14.85)\n function bnModPow(e,m) {\n var i = e.bitLength(), k, r = nbv(1), z;\n if(i <= 0) return r;\n else if(i < 18) k = 1;\n else if(i < 48) k = 3;\n else if(i < 144) k = 4;\n else if(i < 768) k = 5;\n else k = 6;\n if(i < 8)\n z = new Classic(m);\n else if(m.isEven())\n z = new Barrett(m);\n else\n z = new Montgomery(m);\n\n // precomputation\n var g = new Array(), n = 3, k1 = k-1, km = (1< 1) {\n var g2 = nbi();\n z.sqrTo(g[1],g2);\n while(n <= km) {\n g[n] = nbi();\n z.mulTo(g2,g[n-2],g[n]);\n n += 2;\n }\n }\n\n var j = e.t-1, w, is1 = true, r2 = nbi(), t;\n i = nbits(e[j])-1;\n while(j >= 0) {\n if(i >= k1) w = (e[j]>>(i-k1))&km;\n else {\n w = (e[j]&((1<<(i+1))-1))<<(k1-i);\n if(j > 0) w |= e[j-1]>>(this.DB+i-k1);\n }\n\n n = k;\n while((w&1) == 0) { w >>= 1; --n; }\n if((i -= n) < 0) { i += this.DB; --j; }\n if(is1) { // ret == 1, don't bother squaring or multiplying it\n g[w].copyTo(r);\n is1 = false;\n }\n else {\n while(n > 1) { z.sqrTo(r,r2); z.sqrTo(r2,r); n -= 2; }\n if(n > 0) z.sqrTo(r,r2); else { t = r; r = r2; r2 = t; }\n z.mulTo(r2,g[w],r);\n }\n\n while(j >= 0 && (e[j]&(1< 0) {\n x.rShiftTo(g,x);\n y.rShiftTo(g,y);\n }\n while(x.signum() > 0) {\n if((i = x.getLowestSetBit()) > 0) x.rShiftTo(i,x);\n if((i = y.getLowestSetBit()) > 0) y.rShiftTo(i,y);\n if(x.compareTo(y) >= 0) {\n x.subTo(y,x);\n x.rShiftTo(1,x);\n }\n else {\n y.subTo(x,y);\n y.rShiftTo(1,y);\n }\n }\n if(g > 0) y.lShiftTo(g,y);\n return y;\n }\n\n // (protected) this % n, n < 2^26\n function bnpModInt(n) {\n if(n <= 0) return 0;\n var d = this.DV%n, r = (this.s<0)?n-1:0;\n if(this.t > 0)\n if(d == 0) r = this[0]%n;\n else for(var i = this.t-1; i >= 0; --i) r = (d*r+this[i])%n;\n return r;\n }\n\n // (public) 1/this % m (HAC 14.61)\n function bnModInverse(m) {\n var ac = m.isEven();\n if((this.isEven() && ac) || m.signum() == 0) return BigInteger.ZERO;\n var u = m.clone(), v = this.clone();\n var a = nbv(1), b = nbv(0), c = nbv(0), d = nbv(1);\n while(u.signum() != 0) {\n while(u.isEven()) {\n u.rShiftTo(1,u);\n if(ac) {\n if(!a.isEven() || !b.isEven()) { a.addTo(this,a); b.subTo(m,b); }\n a.rShiftTo(1,a);\n }\n else if(!b.isEven()) b.subTo(m,b);\n b.rShiftTo(1,b);\n }\n while(v.isEven()) {\n v.rShiftTo(1,v);\n if(ac) {\n if(!c.isEven() || !d.isEven()) { c.addTo(this,c); d.subTo(m,d); }\n c.rShiftTo(1,c);\n }\n else if(!d.isEven()) d.subTo(m,d);\n d.rShiftTo(1,d);\n }\n if(u.compareTo(v) >= 0) {\n u.subTo(v,u);\n if(ac) a.subTo(c,a);\n b.subTo(d,b);\n }\n else {\n v.subTo(u,v);\n if(ac) c.subTo(a,c);\n d.subTo(b,d);\n }\n }\n if(v.compareTo(BigInteger.ONE) != 0) return BigInteger.ZERO;\n if(d.compareTo(m) >= 0) return d.subtract(m);\n if(d.signum() < 0) d.addTo(m,d); else return d;\n if(d.signum() < 0) return d.add(m); else return d;\n }\n\n var lowprimes = [2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997];\n var lplim = (1<<26)/lowprimes[lowprimes.length-1];\n\n // (public) test primality with certainty >= 1-.5^t\n function bnIsProbablePrime(t) {\n var i, x = this.abs();\n if(x.t == 1 && x[0] <= lowprimes[lowprimes.length-1]) {\n for(i = 0; i < lowprimes.length; ++i)\n if(x[0] == lowprimes[i]) return true;\n return false;\n }\n if(x.isEven()) return false;\n i = 1;\n while(i < lowprimes.length) {\n var m = lowprimes[i], j = i+1;\n while(j < lowprimes.length && m < lplim) m *= lowprimes[j++];\n m = x.modInt(m);\n while(i < j) if(m%lowprimes[i++] == 0) return false;\n }\n return x.millerRabin(t);\n }\n\n // (protected) true if probably prime (HAC 4.24, Miller-Rabin)\n function bnpMillerRabin(t) {\n var n1 = this.subtract(BigInteger.ONE);\n var k = n1.getLowestSetBit();\n if(k <= 0) return false;\n var r = n1.shiftRight(k);\n t = (t+1)>>1;\n if(t > lowprimes.length) t = lowprimes.length;\n var a = nbi();\n for(var i = 0; i < t; ++i) {\n //Pick bases at random, instead of starting at 2\n a.fromInt(lowprimes[Math.floor(Math.random()*lowprimes.length)]);\n var y = a.modPow(r,this);\n if(y.compareTo(BigInteger.ONE) != 0 && y.compareTo(n1) != 0) {\n var j = 1;\n while(j++ < k && y.compareTo(n1) != 0) {\n y = y.modPowInt(2,this);\n if(y.compareTo(BigInteger.ONE) == 0) return false;\n }\n if(y.compareTo(n1) != 0) return false;\n }\n }\n return true;\n }\n\n // protected\n BigInteger.prototype.chunkSize = bnpChunkSize;\n BigInteger.prototype.toRadix = bnpToRadix;\n BigInteger.prototype.fromRadix = bnpFromRadix;\n BigInteger.prototype.fromNumber = bnpFromNumber;\n BigInteger.prototype.bitwiseTo = bnpBitwiseTo;\n BigInteger.prototype.changeBit = bnpChangeBit;\n BigInteger.prototype.addTo = bnpAddTo;\n BigInteger.prototype.dMultiply = bnpDMultiply;\n BigInteger.prototype.dAddOffset = bnpDAddOffset;\n BigInteger.prototype.multiplyLowerTo = bnpMultiplyLowerTo;\n BigInteger.prototype.multiplyUpperTo = bnpMultiplyUpperTo;\n BigInteger.prototype.modInt = bnpModInt;\n BigInteger.prototype.millerRabin = bnpMillerRabin;\n\n // public\n BigInteger.prototype.clone = bnClone;\n BigInteger.prototype.intValue = bnIntValue;\n BigInteger.prototype.byteValue = bnByteValue;\n BigInteger.prototype.shortValue = bnShortValue;\n BigInteger.prototype.signum = bnSigNum;\n BigInteger.prototype.toByteArray = bnToByteArray;\n BigInteger.prototype.equals = bnEquals;\n BigInteger.prototype.min = bnMin;\n BigInteger.prototype.max = bnMax;\n BigInteger.prototype.and = bnAnd;\n BigInteger.prototype.or = bnOr;\n BigInteger.prototype.xor = bnXor;\n BigInteger.prototype.andNot = bnAndNot;\n BigInteger.prototype.not = bnNot;\n BigInteger.prototype.shiftLeft = bnShiftLeft;\n BigInteger.prototype.shiftRight = bnShiftRight;\n BigInteger.prototype.getLowestSetBit = bnGetLowestSetBit;\n BigInteger.prototype.bitCount = bnBitCount;\n BigInteger.prototype.testBit = bnTestBit;\n BigInteger.prototype.setBit = bnSetBit;\n BigInteger.prototype.clearBit = bnClearBit;\n BigInteger.prototype.flipBit = bnFlipBit;\n BigInteger.prototype.add = bnAdd;\n BigInteger.prototype.subtract = bnSubtract;\n BigInteger.prototype.multiply = bnMultiply;\n BigInteger.prototype.divide = bnDivide;\n BigInteger.prototype.remainder = bnRemainder;\n BigInteger.prototype.divideAndRemainder = bnDivideAndRemainder;\n BigInteger.prototype.modPow = bnModPow;\n BigInteger.prototype.modInverse = bnModInverse;\n BigInteger.prototype.pow = bnPow;\n BigInteger.prototype.gcd = bnGCD;\n BigInteger.prototype.isProbablePrime = bnIsProbablePrime;\n\n // JSBN-specific extension\n BigInteger.prototype.square = bnSquare;\n\n // Expose the Barrett function\n BigInteger.prototype.Barrett = Barrett\n\n // BigInteger interfaces not implemented in jsbn:\n\n // BigInteger(int signum, byte[] magnitude)\n // double doubleValue()\n // float floatValue()\n // int hashCode()\n // long longValue()\n // static BigInteger valueOf(long val)\n\n // Random number generator - requires a PRNG backend, e.g. prng4.js\n\n // For best results, put code like\n // \n // in your main HTML document.\n\n var rng_state;\n var rng_pool;\n var rng_pptr;\n\n // Mix in a 32-bit integer into the pool\n function rng_seed_int(x) {\n rng_pool[rng_pptr++] ^= x & 255;\n rng_pool[rng_pptr++] ^= (x >> 8) & 255;\n rng_pool[rng_pptr++] ^= (x >> 16) & 255;\n rng_pool[rng_pptr++] ^= (x >> 24) & 255;\n if(rng_pptr >= rng_psize) rng_pptr -= rng_psize;\n }\n\n // Mix in the current time (w/milliseconds) into the pool\n function rng_seed_time() {\n rng_seed_int(new Date().getTime());\n }\n\n // Initialize the pool with junk if needed.\n if(rng_pool == null) {\n rng_pool = new Array();\n rng_pptr = 0;\n var t;\n if(typeof window !== \"undefined\" && window.crypto) {\n if (window.crypto.getRandomValues) {\n // Use webcrypto if available\n var ua = new Uint8Array(32);\n window.crypto.getRandomValues(ua);\n for(t = 0; t < 32; ++t)\n rng_pool[rng_pptr++] = ua[t];\n }\n else if(navigator.appName == \"Netscape\" && navigator.appVersion < \"5\") {\n // Extract entropy (256 bits) from NS4 RNG if available\n var z = window.crypto.random(32);\n for(t = 0; t < z.length; ++t)\n rng_pool[rng_pptr++] = z.charCodeAt(t) & 255;\n }\n }\n while(rng_pptr < rng_psize) { // extract some randomness from Math.random()\n t = Math.floor(65536 * Math.random());\n rng_pool[rng_pptr++] = t >>> 8;\n rng_pool[rng_pptr++] = t & 255;\n }\n rng_pptr = 0;\n rng_seed_time();\n //rng_seed_int(window.screenX);\n //rng_seed_int(window.screenY);\n }\n\n function rng_get_byte() {\n if(rng_state == null) {\n rng_seed_time();\n rng_state = prng_newstate();\n rng_state.init(rng_pool);\n for(rng_pptr = 0; rng_pptr < rng_pool.length; ++rng_pptr)\n rng_pool[rng_pptr] = 0;\n rng_pptr = 0;\n //rng_pool = null;\n }\n // TODO: allow reseeding after first request\n return rng_state.next();\n }\n\n function rng_get_bytes(ba) {\n var i;\n for(i = 0; i < ba.length; ++i) ba[i] = rng_get_byte();\n }\n\n function SecureRandom() {}\n\n SecureRandom.prototype.nextBytes = rng_get_bytes;\n\n // prng4.js - uses Arcfour as a PRNG\n\n function Arcfour() {\n this.i = 0;\n this.j = 0;\n this.S = new Array();\n }\n\n // Initialize arcfour context from key, an array of ints, each from [0..255]\n function ARC4init(key) {\n var i, j, t;\n for(i = 0; i < 256; ++i)\n this.S[i] = i;\n j = 0;\n for(i = 0; i < 256; ++i) {\n j = (j + this.S[i] + key[i % key.length]) & 255;\n t = this.S[i];\n this.S[i] = this.S[j];\n this.S[j] = t;\n }\n this.i = 0;\n this.j = 0;\n }\n\n function ARC4next() {\n var t;\n this.i = (this.i + 1) & 255;\n this.j = (this.j + this.S[this.i]) & 255;\n t = this.S[this.i];\n this.S[this.i] = this.S[this.j];\n this.S[this.j] = t;\n return this.S[(t + this.S[this.i]) & 255];\n }\n\n Arcfour.prototype.init = ARC4init;\n Arcfour.prototype.next = ARC4next;\n\n // Plug in your RNG constructor here\n function prng_newstate() {\n return new Arcfour();\n }\n\n // Pool size must be a multiple of 4 and greater than 32.\n // An array of bytes the size of the pool will be passed to init()\n var rng_psize = 256;\n\n if (typeof exports !== 'undefined') {\n exports = module.exports = {\n default: BigInteger,\n BigInteger: BigInteger,\n SecureRandom: SecureRandom,\n };\n } else {\n this.jsbn = {\n BigInteger: BigInteger,\n SecureRandom: SecureRandom\n };\n }\n\n}).call(this);\n","/* global window, exports, define */\n\n!function() {\n 'use strict'\n\n var re = {\n not_string: /[^s]/,\n not_bool: /[^t]/,\n not_type: /[^T]/,\n not_primitive: /[^v]/,\n number: /[diefg]/,\n numeric_arg: /[bcdiefguxX]/,\n json: /[j]/,\n not_json: /[^j]/,\n text: /^[^\\x25]+/,\n modulo: /^\\x25{2}/,\n placeholder: /^\\x25(?:([1-9]\\d*)\\$|\\(([^)]+)\\))?(\\+)?(0|'[^$])?(-)?(\\d+)?(?:\\.(\\d+))?([b-gijostTuvxX])/,\n key: /^([a-z_][a-z_\\d]*)/i,\n key_access: /^\\.([a-z_][a-z_\\d]*)/i,\n index_access: /^\\[(\\d+)\\]/,\n sign: /^[+-]/\n }\n\n function sprintf(key) {\n // `arguments` is not an array, but should be fine for this call\n return sprintf_format(sprintf_parse(key), arguments)\n }\n\n function vsprintf(fmt, argv) {\n return sprintf.apply(null, [fmt].concat(argv || []))\n }\n\n function sprintf_format(parse_tree, argv) {\n var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign\n for (i = 0; i < tree_length; i++) {\n if (typeof parse_tree[i] === 'string') {\n output += parse_tree[i]\n }\n else if (typeof parse_tree[i] === 'object') {\n ph = parse_tree[i] // convenience purposes only\n if (ph.keys) { // keyword argument\n arg = argv[cursor]\n for (k = 0; k < ph.keys.length; k++) {\n if (arg == undefined) {\n throw new Error(sprintf('[sprintf] Cannot access property \"%s\" of undefined value \"%s\"', ph.keys[k], ph.keys[k-1]))\n }\n arg = arg[ph.keys[k]]\n }\n }\n else if (ph.param_no) { // positional argument (explicit)\n arg = argv[ph.param_no]\n }\n else { // positional argument (implicit)\n arg = argv[cursor++]\n }\n\n if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) {\n arg = arg()\n }\n\n if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) {\n throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg))\n }\n\n if (re.number.test(ph.type)) {\n is_positive = arg >= 0\n }\n\n switch (ph.type) {\n case 'b':\n arg = parseInt(arg, 10).toString(2)\n break\n case 'c':\n arg = String.fromCharCode(parseInt(arg, 10))\n break\n case 'd':\n case 'i':\n arg = parseInt(arg, 10)\n break\n case 'j':\n arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0)\n break\n case 'e':\n arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential()\n break\n case 'f':\n arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg)\n break\n case 'g':\n arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg)\n break\n case 'o':\n arg = (parseInt(arg, 10) >>> 0).toString(8)\n break\n case 's':\n arg = String(arg)\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 't':\n arg = String(!!arg)\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 'T':\n arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase()\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 'u':\n arg = parseInt(arg, 10) >>> 0\n break\n case 'v':\n arg = arg.valueOf()\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 'x':\n arg = (parseInt(arg, 10) >>> 0).toString(16)\n break\n case 'X':\n arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase()\n break\n }\n if (re.json.test(ph.type)) {\n output += arg\n }\n else {\n if (re.number.test(ph.type) && (!is_positive || ph.sign)) {\n sign = is_positive ? '+' : '-'\n arg = arg.toString().replace(re.sign, '')\n }\n else {\n sign = ''\n }\n pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' '\n pad_length = ph.width - (sign + arg).length\n pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : ''\n output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg)\n }\n }\n }\n return output\n }\n\n var sprintf_cache = Object.create(null)\n\n function sprintf_parse(fmt) {\n if (sprintf_cache[fmt]) {\n return sprintf_cache[fmt]\n }\n\n var _fmt = fmt, match, parse_tree = [], arg_names = 0\n while (_fmt) {\n if ((match = re.text.exec(_fmt)) !== null) {\n parse_tree.push(match[0])\n }\n else if ((match = re.modulo.exec(_fmt)) !== null) {\n parse_tree.push('%')\n }\n else if ((match = re.placeholder.exec(_fmt)) !== null) {\n if (match[2]) {\n arg_names |= 1\n var field_list = [], replacement_field = match[2], field_match = []\n if ((field_match = re.key.exec(replacement_field)) !== null) {\n field_list.push(field_match[1])\n while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') {\n if ((field_match = re.key_access.exec(replacement_field)) !== null) {\n field_list.push(field_match[1])\n }\n else if ((field_match = re.index_access.exec(replacement_field)) !== null) {\n field_list.push(field_match[1])\n }\n else {\n throw new SyntaxError('[sprintf] failed to parse named argument key')\n }\n }\n }\n else {\n throw new SyntaxError('[sprintf] failed to parse named argument key')\n }\n match[2] = field_list\n }\n else {\n arg_names |= 2\n }\n if (arg_names === 3) {\n throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported')\n }\n\n parse_tree.push(\n {\n placeholder: match[0],\n param_no: match[1],\n keys: match[2],\n sign: match[3],\n pad_char: match[4],\n align: match[5],\n width: match[6],\n precision: match[7],\n type: match[8]\n }\n )\n }\n else {\n throw new SyntaxError('[sprintf] unexpected placeholder')\n }\n _fmt = _fmt.substring(match[0].length)\n }\n return sprintf_cache[fmt] = parse_tree\n }\n\n /**\n * export to either browser or node.js\n */\n /* eslint-disable quote-props */\n if (typeof exports !== 'undefined') {\n exports['sprintf'] = sprintf\n exports['vsprintf'] = vsprintf\n }\n if (typeof window !== 'undefined') {\n window['sprintf'] = sprintf\n window['vsprintf'] = vsprintf\n\n if (typeof define === 'function' && define['amd']) {\n define(function() {\n return {\n 'sprintf': sprintf,\n 'vsprintf': vsprintf\n }\n })\n }\n }\n /* eslint-enable quote-props */\n}(); // eslint-disable-line\n",null,null,null,null,"'use strict';\n\nclass TimeoutError extends Error {\n\tconstructor(message) {\n\t\tsuper(message);\n\t\tthis.name = 'TimeoutError';\n\t}\n}\n\nconst pTimeout = (promise, milliseconds, fallback, options) => {\n\tlet timer;\n\tconst cancelablePromise = new Promise((resolve, reject) => {\n\t\tif (typeof milliseconds !== 'number' || milliseconds < 0) {\n\t\t\tthrow new TypeError('Expected `milliseconds` to be a positive number');\n\t\t}\n\n\t\tif (milliseconds === Infinity) {\n\t\t\tresolve(promise);\n\t\t\treturn;\n\t\t}\n\n\t\toptions = {\n\t\t\tcustomTimers: {setTimeout, clearTimeout},\n\t\t\t...options\n\t\t};\n\n\t\ttimer = options.customTimers.setTimeout.call(undefined, () => {\n\t\t\tif (typeof fallback === 'function') {\n\t\t\t\ttry {\n\t\t\t\t\tresolve(fallback());\n\t\t\t\t} catch (error) {\n\t\t\t\t\treject(error);\n\t\t\t\t}\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst message = typeof fallback === 'string' ? fallback : `Promise timed out after ${milliseconds} milliseconds`;\n\t\t\tconst timeoutError = fallback instanceof Error ? fallback : new TimeoutError(message);\n\n\t\t\tif (typeof promise.cancel === 'function') {\n\t\t\t\tpromise.cancel();\n\t\t\t}\n\n\t\t\treject(timeoutError);\n\t\t}, milliseconds);\n\n\t\t(async () => {\n\t\t\ttry {\n\t\t\t\tresolve(await promise);\n\t\t\t} catch (error) {\n\t\t\t\treject(error);\n\t\t\t} finally {\n\t\t\t\toptions.customTimers.clearTimeout.call(undefined, timer);\n\t\t\t}\n\t\t})();\n\t});\n\n\tcancelablePromise.clear = () => {\n\t\tclearTimeout(timer);\n\t\ttimer = undefined;\n\t};\n\n\treturn cancelablePromise;\n};\n\nmodule.exports = pTimeout;\n// TODO: Remove this for the next major release\nmodule.exports.default = pTimeout;\n\nmodule.exports.TimeoutError = TimeoutError;\n","'use strict'\n\nconst mafmt = require('mafmt')\nconst {\n CODE_CIRCUIT,\n CODE_P2P,\n CODE_TCP,\n CODE_WS,\n CODE_WSS\n} = require('./constants')\n\nmodule.exports = {\n all: (multiaddrs) => multiaddrs.filter((ma) => {\n if (ma.protoCodes().includes(CODE_CIRCUIT)) {\n return false\n }\n\n const testMa = ma.decapsulateCode(CODE_P2P)\n\n return mafmt.WebSockets.matches(testMa) ||\n mafmt.WebSocketsSecure.matches(testMa)\n }),\n dnsWss: (multiaddrs) => multiaddrs.filter((ma) => {\n if (ma.protoCodes().includes(CODE_CIRCUIT)) {\n return false\n }\n\n const testMa = ma.decapsulateCode(CODE_P2P)\n\n return mafmt.WebSocketsSecure.matches(testMa) &&\n mafmt.DNS.matches(testMa.decapsulateCode(CODE_TCP).decapsulateCode(CODE_WSS))\n }),\n dnsWsOrWss: (multiaddrs) => multiaddrs.filter((ma) => {\n if (ma.protoCodes().includes(CODE_CIRCUIT)) {\n return false\n }\n\n const testMa = ma.decapsulateCode(CODE_P2P)\n\n // WS\n if (mafmt.WebSockets.matches(testMa)) {\n return mafmt.DNS.matches(testMa.decapsulateCode(CODE_TCP).decapsulateCode(CODE_WS))\n }\n\n // WSS\n return mafmt.WebSocketsSecure.matches(testMa) &&\n mafmt.DNS.matches(testMa.decapsulateCode(CODE_TCP).decapsulateCode(CODE_WSS))\n })\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = debug('libp2p:webrtc-star')\nlog.error = debug('libp2p:webrtc-star:error')\n\nconst { EventEmitter } = require('events')\nconst errcode = require('err-code')\nconst withIs = require('class-is')\n\nconst { AbortError } = require('abortable-iterator')\nconst SimplePeer = require('libp2p-webrtc-peer')\nconst { supportsWebRTCDataChannels: webrtcSupport } = require('ipfs-utils/src/supports')\n\nconst { Multiaddr } = require('multiaddr')\nconst mafmt = require('mafmt')\nconst PeerId = require('peer-id')\n\nconst { CODE_CIRCUIT } = require('./constants')\nconst createListener = require('./listener')\nconst toConnection = require('./socket-to-conn')\nconst { cleanMultiaddr, cleanUrlSIO } = require('./utils')\n\nfunction noop () { }\n\n/**\n * @class WebRTCStar\n */\nclass WebRTCStar {\n /**\n * @class\n * @param {object} options\n * @param {Upgrader} options.upgrader\n */\n constructor (options = {}) {\n if (!options.upgrader) {\n throw new Error('An upgrader must be provided. See https://github.com/libp2p/interface-transport#upgrader.')\n }\n\n this._upgrader = options.upgrader\n\n this.sioOptions = {\n transports: ['websocket'],\n 'force new connection': true\n }\n\n if (options.wrtc) {\n this.wrtc = options.wrtc\n }\n\n // Keep Signalling references\n this.sigReferences = new Map()\n\n // Discovery\n this.discovery = new EventEmitter()\n this.discovery.tag = 'webRTCStar'\n this.discovery._isStarted = false\n this.discovery.start = () => {\n this.discovery._isStarted = true\n }\n this.discovery.stop = () => {\n this.discovery._isStarted = false\n }\n this._peerDiscovered = this._peerDiscovered.bind(this)\n }\n\n /**\n * @async\n * @param {Multiaddr} ma\n * @param {object} options\n * @param {AbortSignal} options.signal - Used to abort dial requests\n * @returns {Connection} An upgraded Connection\n */\n async dial (ma, options = {}) {\n const rawConn = await this._connect(ma, options)\n const maConn = toConnection(rawConn, { remoteAddr: ma, signal: options.signal })\n log('new outbound connection %s', maConn.remoteAddr)\n const conn = await this._upgrader.upgradeOutbound(maConn)\n log('outbound connection %s upgraded', maConn.remoteAddr)\n return conn\n }\n\n /**\n * @private\n * @param {Multiaddr} ma\n * @param {object} options\n * @param {AbortSignal} options.signal - Used to abort dial requests\n * @returns {Promise} Resolves a SimplePeer Webrtc channel\n */\n _connect (ma, options = {}) {\n if (options.signal && options.signal.aborted) {\n throw new AbortError()\n }\n\n const spOptions = {\n initiator: true,\n trickle: false,\n ...options.spOptions || {}\n }\n\n // Use custom WebRTC implementation\n if (this.wrtc) { spOptions.wrtc = this.wrtc }\n\n const cOpts = ma.toOptions()\n const intentId = (~~(Math.random() * 1e9)).toString(36) + Date.now()\n\n return new Promise((resolve, reject) => {\n const sio = this.sigReferences.get(cleanUrlSIO(ma))\n\n if (!sio || !sio.listener) {\n return reject(errcode(new Error('unknown signal server to use'), 'ERR_UNKNOWN_SIGNAL_SERVER'))\n }\n\n const sioClient = sio.listener.io\n\n const start = Date.now()\n let connected\n\n log('dialing %s:%s', cOpts.host, cOpts.port)\n const channel = new SimplePeer(spOptions)\n\n const onError = (err) => {\n if (!connected) {\n const msg = `connection error ${cOpts.host}:${cOpts.port}: ${err.message}`\n log.error(msg)\n done(err)\n }\n }\n\n const onTimeout = () => {\n log('connnection timeout %s:%s', cOpts.host, cOpts.port)\n const err = errcode(new Error(`connection timeout after ${Date.now() - start}ms`), 'ERR_CONNECT_TIMEOUT')\n // Note: this will result in onError() being called\n channel.emit('error', err)\n }\n\n const onConnect = () => {\n connected = true\n\n log('connection opened %s:%s', cOpts.host, cOpts.port)\n done(null)\n }\n\n const onAbort = () => {\n log.error('connection aborted %s:%s', cOpts.host, cOpts.port)\n channel.destroy()\n done(new AbortError())\n }\n\n const done = (err) => {\n channel.removeListener('timeout', onTimeout)\n channel.removeListener('connect', onConnect)\n options.signal && options.signal.removeEventListener('abort', onAbort)\n\n err ? reject(err) : resolve(channel)\n }\n\n channel.on('error', onError)\n channel.once('timeout', onTimeout)\n channel.once('connect', onConnect)\n channel.on('close', () => {\n channel.removeListener('error', onError)\n })\n options.signal && options.signal.addEventListener('abort', onAbort)\n\n channel.on('signal', (signal) => {\n sioClient.emit('ss-handshake', {\n intentId: intentId,\n srcMultiaddr: sio.signallingAddr.toString(),\n dstMultiaddr: ma.toString(),\n signal: signal\n })\n })\n\n // NOTE: aegir segfaults if we do .once on the socket.io event emitter and we\n // are clueless as to why.\n sioClient.on('ws-handshake', (offer) => {\n if (offer.intentId === intentId && offer.err) {\n channel.destroy()\n reject(errcode(offer.err instanceof Error ? offer.err : new Error(offer.err), 'ERR_SIGNALLING_FAILED'))\n }\n\n if (offer.intentId !== intentId || !offer.answer || channel.destroyed) {\n return\n }\n\n channel.signal(offer.signal)\n })\n })\n }\n\n /**\n * Creates a WebrtcStar listener. The provided `handler` function will be called\n * anytime a new incoming Connection has been successfully upgraded via\n * `upgrader.upgradeInbound`.\n *\n * @param {object} [options] - simple-peer options for listener\n * @param {function (Connection)} handler\n * @returns {Listener} A WebrtcStar listener\n */\n createListener (options = {}, handler) {\n if (!webrtcSupport && !this.wrtc) {\n throw errcode(new Error('no WebRTC support'), 'ERR_NO_WEBRTC_SUPPORT')\n }\n\n if (typeof options === 'function') {\n handler = options\n options = {}\n }\n\n handler = handler || noop\n\n return createListener({ handler, upgrader: this._upgrader }, this, options)\n }\n\n /**\n * Takes a list of `Multiaddr`s and returns only valid TCP addresses\n *\n * @param {Multiaddr[]} multiaddrs\n * @returns {Multiaddr[]} Valid TCP multiaddrs\n */\n filter (multiaddrs) {\n multiaddrs = Array.isArray(multiaddrs) ? multiaddrs : [multiaddrs]\n\n return multiaddrs.filter((ma) => {\n if (ma.protoCodes().includes(CODE_CIRCUIT)) {\n return false\n }\n\n return mafmt.WebRTCStar.matches(ma)\n })\n }\n\n _peerDiscovered (maStr) {\n if (!this.discovery._isStarted) return\n\n log('Peer Discovered:', maStr)\n maStr = cleanMultiaddr(maStr)\n\n const ma = new Multiaddr(maStr)\n const peerId = PeerId.createFromB58String(ma.getPeerId())\n\n this.discovery.emit('peer', {\n id: peerId,\n multiaddrs: [ma]\n })\n }\n}\n\nmodule.exports = withIs(WebRTCStar, { className: 'WebRTCStar', symbolName: '@libp2p/js-libp2p-webrtc-star/webrtcstar' })\n","/*! simple-peer. MIT License. Feross Aboukhadijeh */\nvar debug = require('debug')('simple-peer')\nvar getBrowserRTC = require('get-browser-rtc')\nvar randombytes = require('randombytes')\nvar stream = require('readable-stream')\nvar queueMicrotask = require('queue-microtask') // TODO: remove when Node 10 is not supported\nvar errCode = require('err-code')\n\nvar MAX_BUFFERED_AMOUNT = 64 * 1024\nvar ICECOMPLETE_TIMEOUT = 5 * 1000\nvar CHANNEL_CLOSING_TIMEOUT = 5 * 1000\n\n// HACK: Filter trickle lines when trickle is disabled #354\nfunction filterTrickle (sdp) {\n return sdp.replace(/a=ice-options:trickle\\s\\n/g, '')\n}\n\nfunction warn (message) {\n console.warn(message)\n}\n\n/**\n * WebRTC peer connection. Same API as node core `net.Socket`, plus a few extra methods.\n * Duplex stream.\n * @param {Object} opts\n */\nclass Peer extends stream.Duplex {\n constructor (opts) {\n opts = Object.assign({\n allowHalfOpen: false\n }, opts)\n\n super(opts)\n\n this._id = randombytes(4).toString('hex').slice(0, 7)\n this._debug('new peer %o', opts)\n\n this.channelName = opts.initiator\n ? opts.channelName || randombytes(20).toString('hex')\n : null\n\n this.initiator = opts.initiator || false\n this.channelConfig = opts.channelConfig || Peer.channelConfig\n this.negotiated = this.channelConfig.negotiated\n this.config = Object.assign({}, Peer.config, opts.config)\n this.offerOptions = opts.offerOptions || {}\n this.answerOptions = opts.answerOptions || {}\n this.sdpTransform = opts.sdpTransform || (sdp => sdp)\n this.streams = opts.streams || (opts.stream ? [opts.stream] : []) // support old \"stream\" option\n this.trickle = opts.trickle !== undefined ? opts.trickle : true\n this.allowHalfTrickle = opts.allowHalfTrickle !== undefined ? opts.allowHalfTrickle : false\n this.iceCompleteTimeout = opts.iceCompleteTimeout || ICECOMPLETE_TIMEOUT\n\n this._connected = false\n\n this.remoteAddress = undefined\n this.remoteFamily = undefined\n this.remotePort = undefined\n this.localAddress = undefined\n this.localFamily = undefined\n this.localPort = undefined\n\n this._wrtc = (opts.wrtc && typeof opts.wrtc === 'object')\n ? opts.wrtc\n : getBrowserRTC()\n\n if (!this._wrtc) {\n if (typeof window === 'undefined') {\n throw errCode(new Error('No WebRTC support: Specify `opts.wrtc` option in this environment'), 'ERR_WEBRTC_SUPPORT')\n } else {\n throw errCode(new Error('No WebRTC support: Not a supported browser'), 'ERR_WEBRTC_SUPPORT')\n }\n }\n\n this._pcReady = false\n this._channelReady = false\n this._iceComplete = false // ice candidate trickle done (got null candidate)\n this._iceCompleteTimer = null // send an offer/answer anyway after some timeout\n this._channel = null\n this._pendingCandidates = []\n\n this._isNegotiating = this.negotiated ? false : !this.initiator // is this peer waiting for negotiation to complete?\n this._batchedNegotiation = false // batch synchronous negotiations\n this._queuedNegotiation = false // is there a queued negotiation request?\n this._sendersAwaitingStable = []\n this._senderMap = new Map()\n this._firstStable = true\n this._closingInterval = null\n\n this._remoteTracks = []\n this._remoteStreams = []\n\n this._chunk = null\n this._cb = null\n this._interval = null\n\n try {\n this._pc = new (this._wrtc.RTCPeerConnection)(this.config)\n } catch (err) {\n queueMicrotask(() => this.destroy(errCode(err, 'ERR_PC_CONSTRUCTOR')))\n return\n }\n\n // We prefer feature detection whenever possible, but sometimes that's not\n // possible for certain implementations.\n this._isReactNativeWebrtc = typeof this._pc._peerConnectionId === 'number'\n\n this._pc.oniceconnectionstatechange = () => {\n this._onIceStateChange()\n }\n this._pc.onicegatheringstatechange = () => {\n this._onIceStateChange()\n }\n this._pc.onconnectionstatechange = () => {\n this._onConnectionStateChange()\n }\n this._pc.onsignalingstatechange = () => {\n this._onSignalingStateChange()\n }\n this._pc.onicecandidate = event => {\n this._onIceCandidate(event)\n }\n\n // Other spec events, unused by this implementation:\n // - onconnectionstatechange\n // - onicecandidateerror\n // - onfingerprintfailure\n // - onnegotiationneeded\n\n if (this.initiator || this.negotiated) {\n this._setupData({\n channel: this._pc.createDataChannel(this.channelName, this.channelConfig)\n })\n } else {\n this._pc.ondatachannel = event => {\n this._setupData(event)\n }\n }\n\n if (this.streams) {\n this.streams.forEach(stream => {\n this.addStream(stream)\n })\n }\n this._pc.ontrack = event => {\n this._onTrack(event)\n }\n\n if (this.initiator) {\n this._needsNegotiation()\n }\n\n this._onFinishBound = () => {\n this._onFinish()\n }\n this.once('finish', this._onFinishBound)\n }\n\n get bufferSize () {\n return (this._channel && this._channel.bufferedAmount) || 0\n }\n\n // HACK: it's possible channel.readyState is \"closing\" before peer.destroy() fires\n // https://bugs.chromium.org/p/chromium/issues/detail?id=882743\n get connected () {\n return (this._connected && this._channel.readyState === 'open')\n }\n\n address () {\n return { port: this.localPort, family: this.localFamily, address: this.localAddress }\n }\n\n signal (data) {\n if (this.destroyed) throw errCode(new Error('cannot signal after peer is destroyed'), 'ERR_SIGNALING')\n if (typeof data === 'string') {\n try {\n data = JSON.parse(data)\n } catch (err) {\n data = {}\n }\n }\n this._debug('signal()')\n\n if (data.renegotiate && this.initiator) {\n this._debug('got request to renegotiate')\n this._needsNegotiation()\n }\n if (data.transceiverRequest && this.initiator) {\n this._debug('got request for transceiver')\n this.addTransceiver(data.transceiverRequest.kind, data.transceiverRequest.init)\n }\n if (data.candidate) {\n if (this._pc.remoteDescription && this._pc.remoteDescription.type) {\n this._addIceCandidate(data.candidate)\n } else {\n this._pendingCandidates.push(data.candidate)\n }\n }\n if (data.sdp) {\n this._pc.setRemoteDescription(new (this._wrtc.RTCSessionDescription)(data))\n .then(() => {\n if (this.destroyed) return\n\n this._pendingCandidates.forEach(candidate => {\n this._addIceCandidate(candidate)\n })\n this._pendingCandidates = []\n\n if (this._pc.remoteDescription.type === 'offer') this._createAnswer()\n })\n .catch(err => {\n this.destroy(errCode(err, 'ERR_SET_REMOTE_DESCRIPTION'))\n })\n }\n if (!data.sdp && !data.candidate && !data.renegotiate && !data.transceiverRequest) {\n this.destroy(errCode(new Error('signal() called with invalid signal data'), 'ERR_SIGNALING'))\n }\n }\n\n _addIceCandidate (candidate) {\n var iceCandidateObj = new this._wrtc.RTCIceCandidate(candidate)\n this._pc.addIceCandidate(iceCandidateObj)\n .catch(err => {\n if (!iceCandidateObj.address || iceCandidateObj.address.endsWith('.local')) {\n warn('Ignoring unsupported ICE candidate.')\n } else {\n this.destroy(errCode(err, 'ERR_ADD_ICE_CANDIDATE'))\n }\n })\n }\n\n /**\n * Send text/binary data to the remote peer.\n * @param {ArrayBufferView|ArrayBuffer|Buffer|string|Blob} chunk\n */\n send (chunk) {\n this._channel.send(chunk)\n }\n\n /**\n * Add a Transceiver to the connection.\n * @param {String} kind\n * @param {Object} init\n */\n addTransceiver (kind, init) {\n this._debug('addTransceiver()')\n\n if (this.initiator) {\n try {\n this._pc.addTransceiver(kind, init)\n this._needsNegotiation()\n } catch (err) {\n this.destroy(errCode(err, 'ERR_ADD_TRANSCEIVER'))\n }\n } else {\n this.emit('signal', { // request initiator to renegotiate\n transceiverRequest: { kind, init }\n })\n }\n }\n\n /**\n * Add a MediaStream to the connection.\n * @param {MediaStream} stream\n */\n addStream (stream) {\n this._debug('addStream()')\n\n stream.getTracks().forEach(track => {\n this.addTrack(track, stream)\n })\n }\n\n /**\n * Add a MediaStreamTrack to the connection.\n * @param {MediaStreamTrack} track\n * @param {MediaStream} stream\n */\n addTrack (track, stream) {\n this._debug('addTrack()')\n\n var submap = this._senderMap.get(track) || new Map() // nested Maps map [track, stream] to sender\n var sender = submap.get(stream)\n if (!sender) {\n sender = this._pc.addTrack(track, stream)\n submap.set(stream, sender)\n this._senderMap.set(track, submap)\n this._needsNegotiation()\n } else if (sender.removed) {\n throw errCode(new Error('Track has been removed. You should enable/disable tracks that you want to re-add.'), 'ERR_SENDER_REMOVED')\n } else {\n throw errCode(new Error('Track has already been added to that stream.'), 'ERR_SENDER_ALREADY_ADDED')\n }\n }\n\n /**\n * Replace a MediaStreamTrack by another in the connection.\n * @param {MediaStreamTrack} oldTrack\n * @param {MediaStreamTrack} newTrack\n * @param {MediaStream} stream\n */\n replaceTrack (oldTrack, newTrack, stream) {\n this._debug('replaceTrack()')\n\n var submap = this._senderMap.get(oldTrack)\n var sender = submap ? submap.get(stream) : null\n if (!sender) {\n throw errCode(new Error('Cannot replace track that was never added.'), 'ERR_TRACK_NOT_ADDED')\n }\n if (newTrack) this._senderMap.set(newTrack, submap)\n\n if (sender.replaceTrack != null) {\n sender.replaceTrack(newTrack)\n } else {\n this.destroy(errCode(new Error('replaceTrack is not supported in this browser'), 'ERR_UNSUPPORTED_REPLACETRACK'))\n }\n }\n\n /**\n * Remove a MediaStreamTrack from the connection.\n * @param {MediaStreamTrack} track\n * @param {MediaStream} stream\n */\n removeTrack (track, stream) {\n this._debug('removeSender()')\n\n var submap = this._senderMap.get(track)\n var sender = submap ? submap.get(stream) : null\n if (!sender) {\n throw errCode(new Error('Cannot remove track that was never added.'), 'ERR_TRACK_NOT_ADDED')\n }\n try {\n sender.removed = true\n this._pc.removeTrack(sender)\n } catch (err) {\n if (err.name === 'NS_ERROR_UNEXPECTED') {\n this._sendersAwaitingStable.push(sender) // HACK: Firefox must wait until (signalingState === stable) https://bugzilla.mozilla.org/show_bug.cgi?id=1133874\n } else {\n this.destroy(errCode(err, 'ERR_REMOVE_TRACK'))\n }\n }\n this._needsNegotiation()\n }\n\n /**\n * Remove a MediaStream from the connection.\n * @param {MediaStream} stream\n */\n removeStream (stream) {\n this._debug('removeSenders()')\n\n stream.getTracks().forEach(track => {\n this.removeTrack(track, stream)\n })\n }\n\n _needsNegotiation () {\n this._debug('_needsNegotiation')\n if (this._batchedNegotiation) return // batch synchronous renegotiations\n this._batchedNegotiation = true\n queueMicrotask(() => {\n this._batchedNegotiation = false\n this._debug('starting batched negotiation')\n this.negotiate()\n })\n }\n\n negotiate () {\n if (this.initiator) {\n if (this._isNegotiating) {\n this._queuedNegotiation = true\n this._debug('already negotiating, queueing')\n } else {\n this._debug('start negotiation')\n setTimeout(() => { // HACK: Chrome crashes if we immediately call createOffer\n this._createOffer()\n }, 0)\n }\n } else {\n if (this._isNegotiating) {\n this._queuedNegotiation = true\n this._debug('already negotiating, queueing')\n } else {\n this._debug('requesting negotiation from initiator')\n this.emit('signal', { // request initiator to renegotiate\n renegotiate: true\n })\n }\n }\n this._isNegotiating = true\n }\n\n _destroy (err, cb) {\n this._debug('destroy (error: %s)', err && (err.message || err))\n\n this.readable = this.writable = false\n\n if (!this._readableState.ended) this.push(null)\n if (!this._writableState.finished) this.end()\n\n this._connected = false\n this._pcReady = false\n this._channelReady = false\n this._remoteTracks = null\n this._remoteStreams = null\n this._senderMap = null\n\n clearInterval(this._closingInterval)\n this._closingInterval = null\n\n clearInterval(this._interval)\n this._interval = null\n this._chunk = null\n this._cb = null\n\n if (this._onFinishBound) this.removeListener('finish', this._onFinishBound)\n this._onFinishBound = null\n\n if (this._channel) {\n try {\n this._channel.close()\n } catch (err) {}\n\n this._channel.onmessage = null\n this._channel.onopen = null\n this._channel.onclose = null\n this._channel.onerror = null\n }\n if (this._pc) {\n try {\n this._pc.close()\n } catch (err) {}\n\n this._pc.oniceconnectionstatechange = null\n this._pc.onicegatheringstatechange = null\n this._pc.onsignalingstatechange = null\n this._pc.onicecandidate = null\n this._pc.ontrack = null\n this._pc.ondatachannel = null\n }\n this._pc = null\n this._channel = null\n\n cb(err)\n }\n\n _setupData (event) {\n if (!event.channel) {\n // In some situations `pc.createDataChannel()` returns `undefined` (in wrtc),\n // which is invalid behavior. Handle it gracefully.\n // See: https://github.com/feross/simple-peer/issues/163\n return this.destroy(errCode(new Error('Data channel event is missing `channel` property'), 'ERR_DATA_CHANNEL'))\n }\n\n this._channel = event.channel\n this._channel.binaryType = 'arraybuffer'\n\n if (typeof this._channel.bufferedAmountLowThreshold === 'number') {\n this._channel.bufferedAmountLowThreshold = MAX_BUFFERED_AMOUNT\n }\n\n this.channelName = this._channel.label\n\n this._channel.onmessage = event => {\n this._onChannelMessage(event)\n }\n this._channel.onbufferedamountlow = () => {\n this._onChannelBufferedAmountLow()\n }\n this._channel.onopen = () => {\n this._onChannelOpen()\n }\n this._channel.onclose = () => {\n this._onChannelClose()\n }\n this._channel.onerror = err => {\n this.destroy(errCode(err, 'ERR_DATA_CHANNEL'))\n }\n\n // HACK: Chrome will sometimes get stuck in readyState \"closing\", let's check for this condition\n // https://bugs.chromium.org/p/chromium/issues/detail?id=882743\n var isClosing = false\n this._closingInterval = setInterval(() => { // No \"onclosing\" event\n if (this._channel && this._channel.readyState === 'closing') {\n if (isClosing) this._onChannelClose() // closing timed out: equivalent to onclose firing\n isClosing = true\n } else {\n isClosing = false\n }\n }, CHANNEL_CLOSING_TIMEOUT)\n }\n\n _read () {}\n\n _write (chunk, encoding, cb) {\n if (this.destroyed) return cb(errCode(new Error('cannot write after peer is destroyed'), 'ERR_DATA_CHANNEL'))\n\n if (this._connected) {\n try {\n this.send(chunk)\n } catch (err) {\n return this.destroy(errCode(err, 'ERR_DATA_CHANNEL'))\n }\n if (this._channel.bufferedAmount > MAX_BUFFERED_AMOUNT) {\n this._debug('start backpressure: bufferedAmount %d', this._channel.bufferedAmount)\n this._cb = cb\n } else {\n cb(null)\n }\n } else {\n this._debug('write before connect')\n this._chunk = chunk\n this._cb = cb\n }\n }\n\n // When stream finishes writing, close socket. Half open connections are not\n // supported.\n _onFinish () {\n if (this.destroyed) return\n\n // Wait a bit before destroying so the socket flushes.\n // TODO: is there a more reliable way to accomplish this?\n const destroySoon = () => {\n setTimeout(() => this.destroy(), 1000)\n }\n\n if (this._connected) {\n destroySoon()\n } else {\n this.once('connect', destroySoon)\n }\n }\n\n _startIceCompleteTimeout () {\n if (this.destroyed) return\n if (this._iceCompleteTimer) return\n this._debug('started iceComplete timeout')\n this._iceCompleteTimer = setTimeout(() => {\n if (!this._iceComplete) {\n this._iceComplete = true\n this._debug('iceComplete timeout completed')\n this.emit('iceTimeout')\n this.emit('_iceComplete')\n }\n }, this.iceCompleteTimeout)\n }\n\n _createOffer () {\n if (this.destroyed) return\n\n this._pc.createOffer(this.offerOptions)\n .then(offer => {\n if (this.destroyed) return\n if (!this.trickle && !this.allowHalfTrickle) offer.sdp = filterTrickle(offer.sdp)\n offer.sdp = this.sdpTransform(offer.sdp)\n\n const sendOffer = () => {\n if (this.destroyed) return\n var signal = this._pc.localDescription || offer\n this._debug('signal')\n this.emit('signal', {\n type: signal.type,\n sdp: signal.sdp\n })\n }\n\n const onSuccess = () => {\n this._debug('createOffer success')\n if (this.destroyed) return\n if (this.trickle || this._iceComplete) sendOffer()\n else this.once('_iceComplete', sendOffer) // wait for candidates\n }\n\n const onError = err => {\n this.destroy(errCode(err, 'ERR_SET_LOCAL_DESCRIPTION'))\n }\n\n this._pc.setLocalDescription(offer)\n .then(onSuccess)\n .catch(onError)\n })\n .catch(err => {\n this.destroy(errCode(err, 'ERR_CREATE_OFFER'))\n })\n }\n\n _requestMissingTransceivers () {\n if (this._pc.getTransceivers) {\n this._pc.getTransceivers().forEach(transceiver => {\n if (!transceiver.mid && transceiver.sender.track && !transceiver.requested) {\n transceiver.requested = true // HACK: Safari returns negotiated transceivers with a null mid\n this.addTransceiver(transceiver.sender.track.kind)\n }\n })\n }\n }\n\n _createAnswer () {\n if (this.destroyed) return\n\n this._pc.createAnswer(this.answerOptions)\n .then(answer => {\n if (this.destroyed) return\n if (!this.trickle && !this.allowHalfTrickle) answer.sdp = filterTrickle(answer.sdp)\n answer.sdp = this.sdpTransform(answer.sdp)\n\n const sendAnswer = () => {\n if (this.destroyed) return\n var signal = this._pc.localDescription || answer\n this._debug('signal')\n this.emit('signal', {\n type: signal.type,\n sdp: signal.sdp\n })\n if (!this.initiator) this._requestMissingTransceivers()\n }\n\n const onSuccess = () => {\n if (this.destroyed) return\n if (this.trickle || this._iceComplete) sendAnswer()\n else this.once('_iceComplete', sendAnswer)\n }\n\n const onError = err => {\n this.destroy(errCode(err, 'ERR_SET_LOCAL_DESCRIPTION'))\n }\n\n this._pc.setLocalDescription(answer)\n .then(onSuccess)\n .catch(onError)\n })\n .catch(err => {\n this.destroy(errCode(err, 'ERR_CREATE_ANSWER'))\n })\n }\n\n _onConnectionStateChange () {\n if (this.destroyed) return\n if (this._pc.connectionState === 'failed') {\n this.destroy(errCode(new Error('Connection failed.'), 'ERR_CONNECTION_FAILURE'))\n }\n }\n\n _onIceStateChange () {\n if (this.destroyed) return\n var iceConnectionState = this._pc.iceConnectionState\n var iceGatheringState = this._pc.iceGatheringState\n\n this._debug(\n 'iceStateChange (connection: %s) (gathering: %s)',\n iceConnectionState,\n iceGatheringState\n )\n this.emit('iceStateChange', iceConnectionState, iceGatheringState)\n\n if (iceConnectionState === 'connected' || iceConnectionState === 'completed') {\n this._pcReady = true\n this._maybeReady()\n }\n if (iceConnectionState === 'failed') {\n this.destroy(errCode(new Error('Ice connection failed.'), 'ERR_ICE_CONNECTION_FAILURE'))\n }\n if (iceConnectionState === 'closed') {\n this.destroy(errCode(new Error('Ice connection closed.'), 'ERR_ICE_CONNECTION_CLOSED'))\n }\n }\n\n getStats (cb) {\n // statreports can come with a value array instead of properties\n const flattenValues = report => {\n if (Object.prototype.toString.call(report.values) === '[object Array]') {\n report.values.forEach(value => {\n Object.assign(report, value)\n })\n }\n return report\n }\n\n // Promise-based getStats() (standard)\n if (this._pc.getStats.length === 0 || this._isReactNativeWebrtc) {\n this._pc.getStats()\n .then(res => {\n var reports = []\n res.forEach(report => {\n reports.push(flattenValues(report))\n })\n cb(null, reports)\n }, err => cb(err))\n\n // Single-parameter callback-based getStats() (non-standard)\n } else if (this._pc.getStats.length > 0) {\n this._pc.getStats(res => {\n // If we destroy connection in `connect` callback this code might happen to run when actual connection is already closed\n if (this.destroyed) return\n\n var reports = []\n res.result().forEach(result => {\n var report = {}\n result.names().forEach(name => {\n report[name] = result.stat(name)\n })\n report.id = result.id\n report.type = result.type\n report.timestamp = result.timestamp\n reports.push(flattenValues(report))\n })\n cb(null, reports)\n }, err => cb(err))\n\n // Unknown browser, skip getStats() since it's anyone's guess which style of\n // getStats() they implement.\n } else {\n cb(null, [])\n }\n }\n\n _maybeReady () {\n this._debug('maybeReady pc %s channel %s', this._pcReady, this._channelReady)\n if (this._connected || this._connecting || !this._pcReady || !this._channelReady) return\n\n this._connecting = true\n\n // HACK: We can't rely on order here, for details see https://github.com/js-platform/node-webrtc/issues/339\n const findCandidatePair = () => {\n if (this.destroyed) return\n\n this.getStats((err, items) => {\n if (this.destroyed) return\n\n // Treat getStats error as non-fatal. It's not essential.\n if (err) items = []\n\n var remoteCandidates = {}\n var localCandidates = {}\n var candidatePairs = {}\n var foundSelectedCandidatePair = false\n\n items.forEach(item => {\n // TODO: Once all browsers support the hyphenated stats report types, remove\n // the non-hypenated ones\n if (item.type === 'remotecandidate' || item.type === 'remote-candidate') {\n remoteCandidates[item.id] = item\n }\n if (item.type === 'localcandidate' || item.type === 'local-candidate') {\n localCandidates[item.id] = item\n }\n if (item.type === 'candidatepair' || item.type === 'candidate-pair') {\n candidatePairs[item.id] = item\n }\n })\n\n const setSelectedCandidatePair = selectedCandidatePair => {\n foundSelectedCandidatePair = true\n\n var local = localCandidates[selectedCandidatePair.localCandidateId]\n\n if (local && (local.ip || local.address)) {\n // Spec\n this.localAddress = local.ip || local.address\n this.localPort = Number(local.port)\n } else if (local && local.ipAddress) {\n // Firefox\n this.localAddress = local.ipAddress\n this.localPort = Number(local.portNumber)\n } else if (typeof selectedCandidatePair.googLocalAddress === 'string') {\n // TODO: remove this once Chrome 58 is released\n local = selectedCandidatePair.googLocalAddress.split(':')\n this.localAddress = local[0]\n this.localPort = Number(local[1])\n }\n if (this.localAddress) {\n this.localFamily = this.localAddress.includes(':') ? 'IPv6' : 'IPv4'\n }\n\n var remote = remoteCandidates[selectedCandidatePair.remoteCandidateId]\n\n if (remote && (remote.ip || remote.address)) {\n // Spec\n this.remoteAddress = remote.ip || remote.address\n this.remotePort = Number(remote.port)\n } else if (remote && remote.ipAddress) {\n // Firefox\n this.remoteAddress = remote.ipAddress\n this.remotePort = Number(remote.portNumber)\n } else if (typeof selectedCandidatePair.googRemoteAddress === 'string') {\n // TODO: remove this once Chrome 58 is released\n remote = selectedCandidatePair.googRemoteAddress.split(':')\n this.remoteAddress = remote[0]\n this.remotePort = Number(remote[1])\n }\n if (this.remoteAddress) {\n this.remoteFamily = this.remoteAddress.includes(':') ? 'IPv6' : 'IPv4'\n }\n\n this._debug(\n 'connect local: %s:%s remote: %s:%s',\n this.localAddress, this.localPort, this.remoteAddress, this.remotePort\n )\n }\n\n items.forEach(item => {\n // Spec-compliant\n if (item.type === 'transport' && item.selectedCandidatePairId) {\n setSelectedCandidatePair(candidatePairs[item.selectedCandidatePairId])\n }\n\n // Old implementations\n if (\n (item.type === 'googCandidatePair' && item.googActiveConnection === 'true') ||\n ((item.type === 'candidatepair' || item.type === 'candidate-pair') && item.selected)\n ) {\n setSelectedCandidatePair(item)\n }\n })\n\n // Ignore candidate pair selection in browsers like Safari 11 that do not have any local or remote candidates\n // But wait until at least 1 candidate pair is available\n if (!foundSelectedCandidatePair && (!Object.keys(candidatePairs).length || Object.keys(localCandidates).length)) {\n setTimeout(findCandidatePair, 100)\n return\n } else {\n this._connecting = false\n this._connected = true\n }\n\n if (this._chunk) {\n try {\n this.send(this._chunk)\n } catch (err) {\n return this.destroy(errCode(err, 'ERR_DATA_CHANNEL'))\n }\n this._chunk = null\n this._debug('sent chunk from \"write before connect\"')\n\n var cb = this._cb\n this._cb = null\n cb(null)\n }\n\n // If `bufferedAmountLowThreshold` and 'onbufferedamountlow' are unsupported,\n // fallback to using setInterval to implement backpressure.\n if (typeof this._channel.bufferedAmountLowThreshold !== 'number') {\n this._interval = setInterval(() => this._onInterval(), 150)\n if (this._interval.unref) this._interval.unref()\n }\n\n this._debug('connect')\n this.emit('connect')\n })\n }\n findCandidatePair()\n }\n\n _onInterval () {\n if (!this._cb || !this._channel || this._channel.bufferedAmount > MAX_BUFFERED_AMOUNT) {\n return\n }\n this._onChannelBufferedAmountLow()\n }\n\n _onSignalingStateChange () {\n if (this.destroyed) return\n\n if (this._pc.signalingState === 'stable' && !this._firstStable) {\n this._isNegotiating = false\n\n // HACK: Firefox doesn't yet support removing tracks when signalingState !== 'stable'\n this._debug('flushing sender queue', this._sendersAwaitingStable)\n this._sendersAwaitingStable.forEach(sender => {\n this._pc.removeTrack(sender)\n this._queuedNegotiation = true\n })\n this._sendersAwaitingStable = []\n\n if (this._queuedNegotiation) {\n this._debug('flushing negotiation queue')\n this._queuedNegotiation = false\n this._needsNegotiation() // negotiate again\n }\n\n this._debug('negotiate')\n this.emit('negotiate')\n }\n this._firstStable = false\n\n this._debug('signalingStateChange %s', this._pc.signalingState)\n this.emit('signalingStateChange', this._pc.signalingState)\n }\n\n _onIceCandidate (event) {\n if (this.destroyed) return\n if (event.candidate && this.trickle) {\n this.emit('signal', {\n candidate: {\n candidate: event.candidate.candidate,\n sdpMLineIndex: event.candidate.sdpMLineIndex,\n sdpMid: event.candidate.sdpMid\n }\n })\n } else if (!event.candidate && !this._iceComplete) {\n this._iceComplete = true\n this.emit('_iceComplete')\n }\n // as soon as we've received one valid candidate start timeout\n if (event.candidate) {\n this._startIceCompleteTimeout()\n }\n }\n\n _onChannelMessage (event) {\n if (this.destroyed) return\n var data = event.data\n if (data instanceof ArrayBuffer) data = new Uint8Array(data)\n this.push(data)\n }\n\n _onChannelBufferedAmountLow () {\n if (this.destroyed || !this._cb) return\n this._debug('ending backpressure: bufferedAmount %d', this._channel.bufferedAmount)\n var cb = this._cb\n this._cb = null\n cb(null)\n }\n\n _onChannelOpen () {\n if (this._connected || this.destroyed) return\n this._debug('on channel open')\n this._channelReady = true\n this._maybeReady()\n }\n\n _onChannelClose () {\n if (this.destroyed) return\n this._debug('on channel close')\n this.destroy()\n }\n\n _onTrack (event) {\n if (this.destroyed) return\n\n event.streams.forEach(eventStream => {\n this._debug('on track')\n this.emit('track', event.track, eventStream)\n\n this._remoteTracks.push({\n track: event.track,\n stream: eventStream\n })\n\n if (this._remoteStreams.some(remoteStream => {\n return remoteStream.id === eventStream.id\n })) return // Only fire one 'stream' event, even though there may be multiple tracks per stream\n\n this._remoteStreams.push(eventStream)\n queueMicrotask(() => {\n this.emit('stream', eventStream) // ensure all tracks have been added\n })\n })\n }\n\n _debug () {\n var args = [].slice.call(arguments)\n args[0] = '[' + this._id + '] ' + args[0]\n debug.apply(null, args)\n }\n}\n\nPeer.WEBRTC_SUPPORT = !!getBrowserRTC()\n\n/**\n * Expose peer and data channel config for overriding all Peer\n * instances. Otherwise, just set opts.config or opts.channelConfig\n * when constructing a Peer.\n */\nPeer.config = {\n iceServers: [\n {\n urls: [\n 'stun:stun.l.google.com:19302',\n 'stun:global.stun.twilio.com:3478'\n ]\n }\n ],\n sdpSemantics: 'unified-plan'\n}\n\nPeer.channelConfig = {}\n\nmodule.exports = Peer\n","// originally pulled out of simple-peer\n\nmodule.exports = function getBrowserRTC () {\n if (typeof globalThis === 'undefined') return null\n var wrtc = {\n RTCPeerConnection: globalThis.RTCPeerConnection || globalThis.mozRTCPeerConnection ||\n globalThis.webkitRTCPeerConnection,\n RTCSessionDescription: globalThis.RTCSessionDescription ||\n globalThis.mozRTCSessionDescription || globalThis.webkitRTCSessionDescription,\n RTCIceCandidate: globalThis.RTCIceCandidate || globalThis.mozRTCIceCandidate ||\n globalThis.webkitRTCIceCandidate\n }\n if (!wrtc.RTCPeerConnection) return null\n return wrtc\n}\n","'use strict'\n\n// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nvar MAX_BYTES = 65536\n\n// Node supports requesting up to this number of bytes\n// https://github.com/nodejs/node/blob/master/lib/internal/crypto/random.js#L48\nvar MAX_UINT32 = 4294967295\n\nfunction oldBrowser () {\n throw new Error('Secure random number generation is not supported by this browser.\\nUse Chrome, Firefox or Internet Explorer 11')\n}\n\nvar Buffer = require('safe-buffer').Buffer\nvar crypto = global.crypto || global.msCrypto\n\nif (crypto && crypto.getRandomValues) {\n module.exports = randomBytes\n} else {\n module.exports = oldBrowser\n}\n\nfunction randomBytes (size, cb) {\n // phantomjs needs to throw\n if (size > MAX_UINT32) throw new RangeError('requested too many random bytes')\n\n var bytes = Buffer.allocUnsafe(size)\n\n if (size > 0) { // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) { // this is the max bytes crypto.getRandomValues\n // can do at once see https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues\n for (var generated = 0; generated < size; generated += MAX_BYTES) {\n // buffer.slice automatically checks if the end is past the end of\n // the buffer so we don't have to here\n crypto.getRandomValues(bytes.slice(generated, generated + MAX_BYTES))\n }\n } else {\n crypto.getRandomValues(bytes)\n }\n }\n\n if (typeof cb === 'function') {\n return process.nextTick(function () {\n cb(null, bytes)\n })\n }\n\n return bytes\n}\n","/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","'use strict';\n\nfunction assign(obj, props) {\n for (const key in props) {\n Object.defineProperty(obj, key, {\n value: props[key],\n enumerable: true,\n configurable: true,\n });\n }\n\n return obj;\n}\n\nfunction createError(err, code, props) {\n if (!err || typeof err === 'string') {\n throw new TypeError('Please pass an Error to err-code');\n }\n\n if (!props) {\n props = {};\n }\n\n if (typeof code === 'object') {\n props = code;\n code = undefined;\n }\n\n if (code != null) {\n props.code = code;\n }\n\n try {\n return assign(err, props);\n } catch (_) {\n props.message = err.message;\n props.stack = err.stack;\n\n const ErrClass = function () {};\n\n ErrClass.prototype = Object.create(Object.getPrototypeOf(err));\n\n return assign(new ErrClass(), props);\n }\n}\n\nmodule.exports = createError;\n","'use strict'\n\nmodule.exports = {\n // in React Native: global === window === self\n supportsFileReader: typeof self !== 'undefined' && 'FileReader' in self,\n supportsWebRTC: 'RTCPeerConnection' in globalThis &&\n (typeof navigator !== 'undefined' && typeof navigator.mediaDevices !== 'undefined' && 'getUserMedia' in navigator.mediaDevices),\n supportsWebRTCDataChannels: 'RTCPeerConnection' in globalThis\n}\n","'use strict'\n\n// p2p multi-address code\nexports.CODE_P2P = 421\nexports.CODE_CIRCUIT = 290\n\n// Time to wait for a connection to close gracefully before destroying it manually\nexports.CLOSE_TIMEOUT = 2000\n","'use strict'\n\nconst EventEmitter = require('events')\nconst debug = require('debug')\nconst log = debug('libp2p:webrtc-star:listener')\nlog.error = debug('libp2p:webrtc-star:listener:error')\n\nconst errCode = require('err-code')\nconst io = require('socket.io-client')\nconst SimplePeer = require('libp2p-webrtc-peer')\nconst pDefer = require('p-defer')\n\nconst toConnection = require('./socket-to-conn')\nconst { cleanUrlSIO } = require('./utils')\nconst { CODE_P2P } = require('./constants')\n\nconst sioOptions = {\n transports: ['websocket'],\n 'force new connection': true,\n path: '/socket.io-next/' // This should be removed when socket.io@2 support is removed\n}\n\nmodule.exports = ({ handler, upgrader }, WebRTCStar, options = {}) => {\n const listener = new EventEmitter()\n let listeningAddr\n let signallingUrl\n\n listener.__connections = []\n listener.__spChannels = new Map()\n listener.__pendingIntents = new Map()\n listener.listen = (ma) => {\n // Should only be used if not already listening\n if (listeningAddr) {\n throw errCode(new Error('listener already in use'), 'ERR_ALREADY_LISTENING')\n }\n\n const defer = pDefer()\n\n // Should be kept unmodified\n listeningAddr = ma\n\n let signallingAddr\n if (!ma.protoCodes().includes(CODE_P2P) && upgrader.localPeer) {\n signallingAddr = ma.encapsulate(`/p2p/${upgrader.localPeer.toB58String()}`)\n } else {\n signallingAddr = ma\n }\n\n listener.on('error', () => defer.reject())\n\n signallingUrl = cleanUrlSIO(ma)\n\n log('Dialing to Signalling Server on: ' + signallingUrl)\n listener.io = io.connect(signallingUrl, sioOptions)\n\n const incomingDial = (offer) => {\n if (offer.answer || offer.err || !offer.intentId) {\n return\n }\n\n const intentId = offer.intentId\n let pendings = listener.__pendingIntents.get(intentId)\n if (!pendings) {\n pendings = []\n listener.__pendingIntents.set(intentId, pendings)\n }\n\n let channel = listener.__spChannels.get(intentId)\n if (channel) {\n channel.signal(offer.signal)\n return\n } else if (offer.signal.type !== 'offer') {\n pendings.push(offer)\n return\n }\n\n const spOptions = {\n trickle: false,\n ...options\n }\n\n // Use custom WebRTC implementation\n if (WebRTCStar.wrtc) { spOptions.wrtc = WebRTCStar.wrtc }\n\n channel = new SimplePeer(spOptions)\n\n const onError = (err) => {\n log.error('incoming connection errored', err)\n }\n\n channel.on('error', onError)\n channel.once('close', (...args) => {\n channel.removeListener('error', onError)\n })\n\n channel.on('signal', (signal) => {\n offer.signal = signal\n offer.answer = true\n listener.io.emit('ss-handshake', offer)\n })\n\n channel.signal(offer.signal)\n for (const pendingOffer of pendings) {\n channel.signal(pendingOffer.signal)\n }\n listener.__pendingIntents.set(intentId, [])\n\n channel.once('connect', async () => {\n const maConn = toConnection(channel)\n log('new inbound connection %s', maConn.remoteAddr)\n\n let conn\n try {\n conn = await upgrader.upgradeInbound(maConn)\n } catch (err) {\n log.error('inbound connection failed to upgrade', err)\n return maConn.close()\n }\n\n if (!conn.remoteAddr) {\n try {\n conn.remoteAddr = ma.decapsulateCode(CODE_P2P).encapsulate(`/p2p/${conn.remotePeer.toB58String()}`)\n } catch (err) {\n log.error('could not determine remote address', err)\n }\n }\n\n log('inbound connection %s upgraded', maConn.remoteAddr)\n\n trackConn(listener, maConn, intentId)\n\n listener.emit('connection', conn)\n handler(conn)\n })\n listener.__spChannels.set(intentId, channel)\n }\n\n listener.io.once('connect_error', (err) => defer.reject(err))\n listener.io.once('error', (err) => {\n listener.emit('error', err)\n listener.emit('close')\n })\n\n listener.io.on('ws-handshake', incomingDial)\n listener.io.on('ws-peer', WebRTCStar._peerDiscovered)\n\n listener.io.on('connect', () => {\n listener.io.emit('ss-join', signallingAddr.toString())\n })\n\n listener.io.once('connect', () => {\n listener.emit('listening')\n defer.resolve()\n })\n\n // Store listen and signal reference addresses\n WebRTCStar.sigReferences.set(signallingUrl, {\n listener,\n signallingAddr\n })\n\n return defer.promise\n }\n\n listener.close = async () => {\n // Close listener\n const ref = WebRTCStar.sigReferences.get(signallingUrl)\n if (ref && ref.listener.io) {\n ref.listener.io.emit('ss-leave')\n ref.listener.io.close()\n }\n\n await Promise.all(listener.__connections.map(maConn => maConn.close()))\n listener.emit('close')\n listener.removeAllListeners()\n\n // Reset state\n listeningAddr = undefined\n WebRTCStar.sigReferences.delete(signallingUrl)\n }\n\n listener.getAddrs = () => {\n return [listeningAddr]\n }\n\n return listener\n}\n\nfunction trackConn (listener, maConn, intentId) {\n listener.__connections.push(maConn)\n\n const untrackConn = () => {\n listener.__connections = listener.__connections.filter(c => c !== maConn)\n listener.__spChannels.delete(intentId)\n listener.__pendingIntents.delete(intentId)\n }\n\n maConn.conn.once('close', untrackConn)\n}\n","import { url } from \"./url.js\";\nimport { Manager } from \"./manager.js\";\nimport { Socket } from \"./socket.js\";\n/**\n * Managers cache.\n */\nconst cache = {};\nfunction lookup(uri, opts) {\n if (typeof uri === \"object\") {\n opts = uri;\n uri = undefined;\n }\n opts = opts || {};\n const parsed = url(uri, opts.path || \"/socket.io\");\n const source = parsed.source;\n const id = parsed.id;\n const path = parsed.path;\n const sameNamespace = cache[id] && path in cache[id][\"nsps\"];\n const newConnection = opts.forceNew ||\n opts[\"force new connection\"] ||\n false === opts.multiplex ||\n sameNamespace;\n let io;\n if (newConnection) {\n io = new Manager(source, opts);\n }\n else {\n if (!cache[id]) {\n cache[id] = new Manager(source, opts);\n }\n io = cache[id];\n }\n if (parsed.query && !opts.query) {\n opts.query = parsed.queryKey;\n }\n return io.socket(parsed.path, opts);\n}\n// so that \"lookup\" can be used both as a function (e.g. `io(...)`) and as a\n// namespace (e.g. `io.connect(...)`), for backward compatibility\nObject.assign(lookup, {\n Manager,\n Socket,\n io: lookup,\n connect: lookup,\n});\n/**\n * Protocol version.\n *\n * @public\n */\nexport { protocol } from \"socket.io-parser\";\n/**\n * Expose constructors for standalone build.\n *\n * @public\n */\nexport { Manager, Socket, lookup as io, lookup as connect, lookup as default, };\n","import parseuri from \"parseuri\";\n/**\n * URL parser.\n *\n * @param uri - url\n * @param path - the request path of the connection\n * @param loc - An object meant to mimic window.location.\n * Defaults to window.location.\n * @public\n */\nexport function url(uri, path = \"\", loc) {\n let obj = uri;\n // default to window.location\n loc = loc || (typeof location !== \"undefined\" && location);\n if (null == uri)\n uri = loc.protocol + \"//\" + loc.host;\n // relative path support\n if (typeof uri === \"string\") {\n if (\"/\" === uri.charAt(0)) {\n if (\"/\" === uri.charAt(1)) {\n uri = loc.protocol + uri;\n }\n else {\n uri = loc.host + uri;\n }\n }\n if (!/^(https?|wss?):\\/\\//.test(uri)) {\n if (\"undefined\" !== typeof loc) {\n uri = loc.protocol + \"//\" + uri;\n }\n else {\n uri = \"https://\" + uri;\n }\n }\n // parse\n obj = parseuri(uri);\n }\n // make sure we treat `localhost:80` and `localhost` equally\n if (!obj.port) {\n if (/^(http|ws)$/.test(obj.protocol)) {\n obj.port = \"80\";\n }\n else if (/^(http|ws)s$/.test(obj.protocol)) {\n obj.port = \"443\";\n }\n }\n obj.path = obj.path || \"/\";\n const ipv6 = obj.host.indexOf(\":\") !== -1;\n const host = ipv6 ? \"[\" + obj.host + \"]\" : obj.host;\n // define unique id\n obj.id = obj.protocol + \"://\" + host + \":\" + obj.port + path;\n // define href\n obj.href =\n obj.protocol +\n \"://\" +\n host +\n (loc && loc.port === obj.port ? \"\" : \":\" + obj.port);\n return obj;\n}\n","/**\n * Parses an URI\n *\n * @author Steven Levithan (MIT license)\n * @api private\n */\n\nvar re = /^(?:(?![^:@]+:[^:@\\/]*@)(http|https|ws|wss):\\/\\/)?((?:(([^:@]*)(?::([^:@]*))?)?@)?((?:[a-f0-9]{0,4}:){2,7}[a-f0-9]{0,4}|[^:\\/?#]*)(?::(\\d*))?)(((\\/(?:[^?#](?![^?#\\/]*\\.[^?#\\/.]+(?:[?#]|$)))*\\/?)?([^?#\\/]*))(?:\\?([^#]*))?(?:#(.*))?)/;\n\nvar parts = [\n 'source', 'protocol', 'authority', 'userInfo', 'user', 'password', 'host', 'port', 'relative', 'path', 'directory', 'file', 'query', 'anchor'\n];\n\nmodule.exports = function parseuri(str) {\n var src = str,\n b = str.indexOf('['),\n e = str.indexOf(']');\n\n if (b != -1 && e != -1) {\n str = str.substring(0, b) + str.substring(b, e).replace(/:/g, ';') + str.substring(e, str.length);\n }\n\n var m = re.exec(str || ''),\n uri = {},\n i = 14;\n\n while (i--) {\n uri[parts[i]] = m[i] || '';\n }\n\n if (b != -1 && e != -1) {\n uri.source = src;\n uri.host = uri.host.substring(1, uri.host.length - 1).replace(/;/g, ':');\n uri.authority = uri.authority.replace('[', '').replace(']', '').replace(/;/g, ':');\n uri.ipv6uri = true;\n }\n\n uri.pathNames = pathNames(uri, uri['path']);\n uri.queryKey = queryKey(uri, uri['query']);\n\n return uri;\n};\n\nfunction pathNames(obj, path) {\n var regx = /\\/{2,9}/g,\n names = path.replace(regx, \"/\").split(\"/\");\n\n if (path.substr(0, 1) == '/' || path.length === 0) {\n names.splice(0, 1);\n }\n if (path.substr(path.length - 1, 1) == '/') {\n names.splice(names.length - 1, 1);\n }\n\n return names;\n}\n\nfunction queryKey(uri, query) {\n var data = {};\n\n query.replace(/(?:^|&)([^&=]*)=?([^&]*)/g, function ($0, $1, $2) {\n if ($1) {\n data[$1] = $2;\n }\n });\n\n return data;\n}\n","import { Socket as Engine, installTimerFunctions, } from \"engine.io-client\";\nimport { Socket } from \"./socket.js\";\nimport * as parser from \"socket.io-parser\";\nimport { on } from \"./on.js\";\nimport Backoff from \"backo2\";\nimport { Emitter, } from \"@socket.io/component-emitter\";\nexport class Manager extends Emitter {\n constructor(uri, opts) {\n var _a;\n super();\n this.nsps = {};\n this.subs = [];\n if (uri && \"object\" === typeof uri) {\n opts = uri;\n uri = undefined;\n }\n opts = opts || {};\n opts.path = opts.path || \"/socket.io\";\n this.opts = opts;\n installTimerFunctions(this, opts);\n this.reconnection(opts.reconnection !== false);\n this.reconnectionAttempts(opts.reconnectionAttempts || Infinity);\n this.reconnectionDelay(opts.reconnectionDelay || 1000);\n this.reconnectionDelayMax(opts.reconnectionDelayMax || 5000);\n this.randomizationFactor((_a = opts.randomizationFactor) !== null && _a !== void 0 ? _a : 0.5);\n this.backoff = new Backoff({\n min: this.reconnectionDelay(),\n max: this.reconnectionDelayMax(),\n jitter: this.randomizationFactor(),\n });\n this.timeout(null == opts.timeout ? 20000 : opts.timeout);\n this._readyState = \"closed\";\n this.uri = uri;\n const _parser = opts.parser || parser;\n this.encoder = new _parser.Encoder();\n this.decoder = new _parser.Decoder();\n this._autoConnect = opts.autoConnect !== false;\n if (this._autoConnect)\n this.open();\n }\n reconnection(v) {\n if (!arguments.length)\n return this._reconnection;\n this._reconnection = !!v;\n return this;\n }\n reconnectionAttempts(v) {\n if (v === undefined)\n return this._reconnectionAttempts;\n this._reconnectionAttempts = v;\n return this;\n }\n reconnectionDelay(v) {\n var _a;\n if (v === undefined)\n return this._reconnectionDelay;\n this._reconnectionDelay = v;\n (_a = this.backoff) === null || _a === void 0 ? void 0 : _a.setMin(v);\n return this;\n }\n randomizationFactor(v) {\n var _a;\n if (v === undefined)\n return this._randomizationFactor;\n this._randomizationFactor = v;\n (_a = this.backoff) === null || _a === void 0 ? void 0 : _a.setJitter(v);\n return this;\n }\n reconnectionDelayMax(v) {\n var _a;\n if (v === undefined)\n return this._reconnectionDelayMax;\n this._reconnectionDelayMax = v;\n (_a = this.backoff) === null || _a === void 0 ? void 0 : _a.setMax(v);\n return this;\n }\n timeout(v) {\n if (!arguments.length)\n return this._timeout;\n this._timeout = v;\n return this;\n }\n /**\n * Starts trying to reconnect if reconnection is enabled and we have not\n * started reconnecting yet\n *\n * @private\n */\n maybeReconnectOnOpen() {\n // Only try to reconnect if it's the first time we're connecting\n if (!this._reconnecting &&\n this._reconnection &&\n this.backoff.attempts === 0) {\n // keeps reconnection from firing twice for the same reconnection loop\n this.reconnect();\n }\n }\n /**\n * Sets the current transport `socket`.\n *\n * @param {Function} fn - optional, callback\n * @return self\n * @public\n */\n open(fn) {\n if (~this._readyState.indexOf(\"open\"))\n return this;\n this.engine = new Engine(this.uri, this.opts);\n const socket = this.engine;\n const self = this;\n this._readyState = \"opening\";\n this.skipReconnect = false;\n // emit `open`\n const openSubDestroy = on(socket, \"open\", function () {\n self.onopen();\n fn && fn();\n });\n // emit `error`\n const errorSub = on(socket, \"error\", (err) => {\n self.cleanup();\n self._readyState = \"closed\";\n this.emitReserved(\"error\", err);\n if (fn) {\n fn(err);\n }\n else {\n // Only do this if there is no fn to handle the error\n self.maybeReconnectOnOpen();\n }\n });\n if (false !== this._timeout) {\n const timeout = this._timeout;\n if (timeout === 0) {\n openSubDestroy(); // prevents a race condition with the 'open' event\n }\n // set timer\n const timer = this.setTimeoutFn(() => {\n openSubDestroy();\n socket.close();\n // @ts-ignore\n socket.emit(\"error\", new Error(\"timeout\"));\n }, timeout);\n if (this.opts.autoUnref) {\n timer.unref();\n }\n this.subs.push(function subDestroy() {\n clearTimeout(timer);\n });\n }\n this.subs.push(openSubDestroy);\n this.subs.push(errorSub);\n return this;\n }\n /**\n * Alias for open()\n *\n * @return self\n * @public\n */\n connect(fn) {\n return this.open(fn);\n }\n /**\n * Called upon transport open.\n *\n * @private\n */\n onopen() {\n // clear old subs\n this.cleanup();\n // mark as open\n this._readyState = \"open\";\n this.emitReserved(\"open\");\n // add new subs\n const socket = this.engine;\n this.subs.push(on(socket, \"ping\", this.onping.bind(this)), on(socket, \"data\", this.ondata.bind(this)), on(socket, \"error\", this.onerror.bind(this)), on(socket, \"close\", this.onclose.bind(this)), on(this.decoder, \"decoded\", this.ondecoded.bind(this)));\n }\n /**\n * Called upon a ping.\n *\n * @private\n */\n onping() {\n this.emitReserved(\"ping\");\n }\n /**\n * Called with data.\n *\n * @private\n */\n ondata(data) {\n this.decoder.add(data);\n }\n /**\n * Called when parser fully decodes a packet.\n *\n * @private\n */\n ondecoded(packet) {\n this.emitReserved(\"packet\", packet);\n }\n /**\n * Called upon socket error.\n *\n * @private\n */\n onerror(err) {\n this.emitReserved(\"error\", err);\n }\n /**\n * Creates a new socket for the given `nsp`.\n *\n * @return {Socket}\n * @public\n */\n socket(nsp, opts) {\n let socket = this.nsps[nsp];\n if (!socket) {\n socket = new Socket(this, nsp, opts);\n this.nsps[nsp] = socket;\n }\n return socket;\n }\n /**\n * Called upon a socket close.\n *\n * @param socket\n * @private\n */\n _destroy(socket) {\n const nsps = Object.keys(this.nsps);\n for (const nsp of nsps) {\n const socket = this.nsps[nsp];\n if (socket.active) {\n return;\n }\n }\n this._close();\n }\n /**\n * Writes a packet.\n *\n * @param packet\n * @private\n */\n _packet(packet) {\n const encodedPackets = this.encoder.encode(packet);\n for (let i = 0; i < encodedPackets.length; i++) {\n this.engine.write(encodedPackets[i], packet.options);\n }\n }\n /**\n * Clean up transport subscriptions and packet buffer.\n *\n * @private\n */\n cleanup() {\n this.subs.forEach((subDestroy) => subDestroy());\n this.subs.length = 0;\n this.decoder.destroy();\n }\n /**\n * Close the current socket.\n *\n * @private\n */\n _close() {\n this.skipReconnect = true;\n this._reconnecting = false;\n this.onclose(\"forced close\");\n if (this.engine)\n this.engine.close();\n }\n /**\n * Alias for close()\n *\n * @private\n */\n disconnect() {\n return this._close();\n }\n /**\n * Called upon engine close.\n *\n * @private\n */\n onclose(reason) {\n this.cleanup();\n this.backoff.reset();\n this._readyState = \"closed\";\n this.emitReserved(\"close\", reason);\n if (this._reconnection && !this.skipReconnect) {\n this.reconnect();\n }\n }\n /**\n * Attempt a reconnection.\n *\n * @private\n */\n reconnect() {\n if (this._reconnecting || this.skipReconnect)\n return this;\n const self = this;\n if (this.backoff.attempts >= this._reconnectionAttempts) {\n this.backoff.reset();\n this.emitReserved(\"reconnect_failed\");\n this._reconnecting = false;\n }\n else {\n const delay = this.backoff.duration();\n this._reconnecting = true;\n const timer = this.setTimeoutFn(() => {\n if (self.skipReconnect)\n return;\n this.emitReserved(\"reconnect_attempt\", self.backoff.attempts);\n // check again for the case socket closed in above events\n if (self.skipReconnect)\n return;\n self.open((err) => {\n if (err) {\n self._reconnecting = false;\n self.reconnect();\n this.emitReserved(\"reconnect_error\", err);\n }\n else {\n self.onreconnect();\n }\n });\n }, delay);\n if (this.opts.autoUnref) {\n timer.unref();\n }\n this.subs.push(function subDestroy() {\n clearTimeout(timer);\n });\n }\n }\n /**\n * Called upon successful reconnect.\n *\n * @private\n */\n onreconnect() {\n const attempt = this.backoff.attempts;\n this._reconnecting = false;\n this.backoff.reset();\n this.emitReserved(\"reconnect\", attempt);\n }\n}\n","import { Socket } from \"./socket.js\";\nexport { Socket };\nexport const protocol = Socket.protocol;\nexport { Transport } from \"./transport.js\";\nexport { transports } from \"./transports/index.js\";\nexport { installTimerFunctions } from \"./util.js\";\n","import { transports } from \"./transports/index.js\";\nimport { installTimerFunctions } from \"./util.js\";\nimport parseqs from \"parseqs\";\nimport parseuri from \"parseuri\";\nimport { Emitter } from \"@socket.io/component-emitter\";\nimport { protocol } from \"engine.io-parser\";\nexport class Socket extends Emitter {\n /**\n * Socket constructor.\n *\n * @param {String|Object} uri or options\n * @param {Object} opts - options\n * @api public\n */\n constructor(uri, opts = {}) {\n super();\n if (uri && \"object\" === typeof uri) {\n opts = uri;\n uri = null;\n }\n if (uri) {\n uri = parseuri(uri);\n opts.hostname = uri.host;\n opts.secure = uri.protocol === \"https\" || uri.protocol === \"wss\";\n opts.port = uri.port;\n if (uri.query)\n opts.query = uri.query;\n }\n else if (opts.host) {\n opts.hostname = parseuri(opts.host).host;\n }\n installTimerFunctions(this, opts);\n this.secure =\n null != opts.secure\n ? opts.secure\n : typeof location !== \"undefined\" && \"https:\" === location.protocol;\n if (opts.hostname && !opts.port) {\n // if no port is specified manually, use the protocol default\n opts.port = this.secure ? \"443\" : \"80\";\n }\n this.hostname =\n opts.hostname ||\n (typeof location !== \"undefined\" ? location.hostname : \"localhost\");\n this.port =\n opts.port ||\n (typeof location !== \"undefined\" && location.port\n ? location.port\n : this.secure\n ? \"443\"\n : \"80\");\n this.transports = opts.transports || [\"polling\", \"websocket\"];\n this.readyState = \"\";\n this.writeBuffer = [];\n this.prevBufferLen = 0;\n this.opts = Object.assign({\n path: \"/engine.io\",\n agent: false,\n withCredentials: false,\n upgrade: true,\n timestampParam: \"t\",\n rememberUpgrade: false,\n rejectUnauthorized: true,\n perMessageDeflate: {\n threshold: 1024\n },\n transportOptions: {},\n closeOnBeforeunload: true\n }, opts);\n this.opts.path = this.opts.path.replace(/\\/$/, \"\") + \"/\";\n if (typeof this.opts.query === \"string\") {\n this.opts.query = parseqs.decode(this.opts.query);\n }\n // set on handshake\n this.id = null;\n this.upgrades = null;\n this.pingInterval = null;\n this.pingTimeout = null;\n // set on heartbeat\n this.pingTimeoutTimer = null;\n if (typeof addEventListener === \"function\") {\n if (this.opts.closeOnBeforeunload) {\n // Firefox closes the connection when the \"beforeunload\" event is emitted but not Chrome. This event listener\n // ensures every browser behaves the same (no \"disconnect\" event at the Socket.IO level when the page is\n // closed/reloaded)\n addEventListener(\"beforeunload\", () => {\n if (this.transport) {\n // silently close the transport\n this.transport.removeAllListeners();\n this.transport.close();\n }\n }, false);\n }\n if (this.hostname !== \"localhost\") {\n this.offlineEventListener = () => {\n this.onClose(\"transport close\");\n };\n addEventListener(\"offline\", this.offlineEventListener, false);\n }\n }\n this.open();\n }\n /**\n * Creates transport of the given type.\n *\n * @param {String} transport name\n * @return {Transport}\n * @api private\n */\n createTransport(name) {\n const query = clone(this.opts.query);\n // append engine.io protocol identifier\n query.EIO = protocol;\n // transport name\n query.transport = name;\n // session id if we already have one\n if (this.id)\n query.sid = this.id;\n const opts = Object.assign({}, this.opts.transportOptions[name], this.opts, {\n query,\n socket: this,\n hostname: this.hostname,\n secure: this.secure,\n port: this.port\n });\n return new transports[name](opts);\n }\n /**\n * Initializes transport to use and starts probe.\n *\n * @api private\n */\n open() {\n let transport;\n if (this.opts.rememberUpgrade &&\n Socket.priorWebsocketSuccess &&\n this.transports.indexOf(\"websocket\") !== -1) {\n transport = \"websocket\";\n }\n else if (0 === this.transports.length) {\n // Emit error on next tick so it can be listened to\n this.setTimeoutFn(() => {\n this.emitReserved(\"error\", \"No transports available\");\n }, 0);\n return;\n }\n else {\n transport = this.transports[0];\n }\n this.readyState = \"opening\";\n // Retry with the next transport if the transport is disabled (jsonp: false)\n try {\n transport = this.createTransport(transport);\n }\n catch (e) {\n this.transports.shift();\n this.open();\n return;\n }\n transport.open();\n this.setTransport(transport);\n }\n /**\n * Sets the current transport. Disables the existing one (if any).\n *\n * @api private\n */\n setTransport(transport) {\n if (this.transport) {\n this.transport.removeAllListeners();\n }\n // set up transport\n this.transport = transport;\n // set up transport listeners\n transport\n .on(\"drain\", this.onDrain.bind(this))\n .on(\"packet\", this.onPacket.bind(this))\n .on(\"error\", this.onError.bind(this))\n .on(\"close\", () => {\n this.onClose(\"transport close\");\n });\n }\n /**\n * Probes a transport.\n *\n * @param {String} transport name\n * @api private\n */\n probe(name) {\n let transport = this.createTransport(name);\n let failed = false;\n Socket.priorWebsocketSuccess = false;\n const onTransportOpen = () => {\n if (failed)\n return;\n transport.send([{ type: \"ping\", data: \"probe\" }]);\n transport.once(\"packet\", msg => {\n if (failed)\n return;\n if (\"pong\" === msg.type && \"probe\" === msg.data) {\n this.upgrading = true;\n this.emitReserved(\"upgrading\", transport);\n if (!transport)\n return;\n Socket.priorWebsocketSuccess = \"websocket\" === transport.name;\n this.transport.pause(() => {\n if (failed)\n return;\n if (\"closed\" === this.readyState)\n return;\n cleanup();\n this.setTransport(transport);\n transport.send([{ type: \"upgrade\" }]);\n this.emitReserved(\"upgrade\", transport);\n transport = null;\n this.upgrading = false;\n this.flush();\n });\n }\n else {\n const err = new Error(\"probe error\");\n // @ts-ignore\n err.transport = transport.name;\n this.emitReserved(\"upgradeError\", err);\n }\n });\n };\n function freezeTransport() {\n if (failed)\n return;\n // Any callback called by transport should be ignored since now\n failed = true;\n cleanup();\n transport.close();\n transport = null;\n }\n // Handle any error that happens while probing\n const onerror = err => {\n const error = new Error(\"probe error: \" + err);\n // @ts-ignore\n error.transport = transport.name;\n freezeTransport();\n this.emitReserved(\"upgradeError\", error);\n };\n function onTransportClose() {\n onerror(\"transport closed\");\n }\n // When the socket is closed while we're probing\n function onclose() {\n onerror(\"socket closed\");\n }\n // When the socket is upgraded while we're probing\n function onupgrade(to) {\n if (transport && to.name !== transport.name) {\n freezeTransport();\n }\n }\n // Remove all listeners on the transport and on self\n const cleanup = () => {\n transport.removeListener(\"open\", onTransportOpen);\n transport.removeListener(\"error\", onerror);\n transport.removeListener(\"close\", onTransportClose);\n this.off(\"close\", onclose);\n this.off(\"upgrading\", onupgrade);\n };\n transport.once(\"open\", onTransportOpen);\n transport.once(\"error\", onerror);\n transport.once(\"close\", onTransportClose);\n this.once(\"close\", onclose);\n this.once(\"upgrading\", onupgrade);\n transport.open();\n }\n /**\n * Called when connection is deemed open.\n *\n * @api private\n */\n onOpen() {\n this.readyState = \"open\";\n Socket.priorWebsocketSuccess = \"websocket\" === this.transport.name;\n this.emitReserved(\"open\");\n this.flush();\n // we check for `readyState` in case an `open`\n // listener already closed the socket\n if (\"open\" === this.readyState &&\n this.opts.upgrade &&\n this.transport.pause) {\n let i = 0;\n const l = this.upgrades.length;\n for (; i < l; i++) {\n this.probe(this.upgrades[i]);\n }\n }\n }\n /**\n * Handles a packet.\n *\n * @api private\n */\n onPacket(packet) {\n if (\"opening\" === this.readyState ||\n \"open\" === this.readyState ||\n \"closing\" === this.readyState) {\n this.emitReserved(\"packet\", packet);\n // Socket is live - any packet counts\n this.emitReserved(\"heartbeat\");\n switch (packet.type) {\n case \"open\":\n this.onHandshake(JSON.parse(packet.data));\n break;\n case \"ping\":\n this.resetPingTimeout();\n this.sendPacket(\"pong\");\n this.emitReserved(\"ping\");\n this.emitReserved(\"pong\");\n break;\n case \"error\":\n const err = new Error(\"server error\");\n // @ts-ignore\n err.code = packet.data;\n this.onError(err);\n break;\n case \"message\":\n this.emitReserved(\"data\", packet.data);\n this.emitReserved(\"message\", packet.data);\n break;\n }\n }\n else {\n }\n }\n /**\n * Called upon handshake completion.\n *\n * @param {Object} data - handshake obj\n * @api private\n */\n onHandshake(data) {\n this.emitReserved(\"handshake\", data);\n this.id = data.sid;\n this.transport.query.sid = data.sid;\n this.upgrades = this.filterUpgrades(data.upgrades);\n this.pingInterval = data.pingInterval;\n this.pingTimeout = data.pingTimeout;\n this.onOpen();\n // In case open handler closes socket\n if (\"closed\" === this.readyState)\n return;\n this.resetPingTimeout();\n }\n /**\n * Sets and resets ping timeout timer based on server pings.\n *\n * @api private\n */\n resetPingTimeout() {\n this.clearTimeoutFn(this.pingTimeoutTimer);\n this.pingTimeoutTimer = this.setTimeoutFn(() => {\n this.onClose(\"ping timeout\");\n }, this.pingInterval + this.pingTimeout);\n if (this.opts.autoUnref) {\n this.pingTimeoutTimer.unref();\n }\n }\n /**\n * Called on `drain` event\n *\n * @api private\n */\n onDrain() {\n this.writeBuffer.splice(0, this.prevBufferLen);\n // setting prevBufferLen = 0 is very important\n // for example, when upgrading, upgrade packet is sent over,\n // and a nonzero prevBufferLen could cause problems on `drain`\n this.prevBufferLen = 0;\n if (0 === this.writeBuffer.length) {\n this.emitReserved(\"drain\");\n }\n else {\n this.flush();\n }\n }\n /**\n * Flush write buffers.\n *\n * @api private\n */\n flush() {\n if (\"closed\" !== this.readyState &&\n this.transport.writable &&\n !this.upgrading &&\n this.writeBuffer.length) {\n this.transport.send(this.writeBuffer);\n // keep track of current length of writeBuffer\n // splice writeBuffer and callbackBuffer on `drain`\n this.prevBufferLen = this.writeBuffer.length;\n this.emitReserved(\"flush\");\n }\n }\n /**\n * Sends a message.\n *\n * @param {String} message.\n * @param {Function} callback function.\n * @param {Object} options.\n * @return {Socket} for chaining.\n * @api public\n */\n write(msg, options, fn) {\n this.sendPacket(\"message\", msg, options, fn);\n return this;\n }\n send(msg, options, fn) {\n this.sendPacket(\"message\", msg, options, fn);\n return this;\n }\n /**\n * Sends a packet.\n *\n * @param {String} packet type.\n * @param {String} data.\n * @param {Object} options.\n * @param {Function} callback function.\n * @api private\n */\n sendPacket(type, data, options, fn) {\n if (\"function\" === typeof data) {\n fn = data;\n data = undefined;\n }\n if (\"function\" === typeof options) {\n fn = options;\n options = null;\n }\n if (\"closing\" === this.readyState || \"closed\" === this.readyState) {\n return;\n }\n options = options || {};\n options.compress = false !== options.compress;\n const packet = {\n type: type,\n data: data,\n options: options\n };\n this.emitReserved(\"packetCreate\", packet);\n this.writeBuffer.push(packet);\n if (fn)\n this.once(\"flush\", fn);\n this.flush();\n }\n /**\n * Closes the connection.\n *\n * @api public\n */\n close() {\n const close = () => {\n this.onClose(\"forced close\");\n this.transport.close();\n };\n const cleanupAndClose = () => {\n this.off(\"upgrade\", cleanupAndClose);\n this.off(\"upgradeError\", cleanupAndClose);\n close();\n };\n const waitForUpgrade = () => {\n // wait for upgrade to finish since we can't send packets while pausing a transport\n this.once(\"upgrade\", cleanupAndClose);\n this.once(\"upgradeError\", cleanupAndClose);\n };\n if (\"opening\" === this.readyState || \"open\" === this.readyState) {\n this.readyState = \"closing\";\n if (this.writeBuffer.length) {\n this.once(\"drain\", () => {\n if (this.upgrading) {\n waitForUpgrade();\n }\n else {\n close();\n }\n });\n }\n else if (this.upgrading) {\n waitForUpgrade();\n }\n else {\n close();\n }\n }\n return this;\n }\n /**\n * Called upon transport error\n *\n * @api private\n */\n onError(err) {\n Socket.priorWebsocketSuccess = false;\n this.emitReserved(\"error\", err);\n this.onClose(\"transport error\", err);\n }\n /**\n * Called upon transport close.\n *\n * @api private\n */\n onClose(reason, desc) {\n if (\"opening\" === this.readyState ||\n \"open\" === this.readyState ||\n \"closing\" === this.readyState) {\n // clear timers\n this.clearTimeoutFn(this.pingTimeoutTimer);\n // stop event from firing again for transport\n this.transport.removeAllListeners(\"close\");\n // ensure transport won't stay open\n this.transport.close();\n // ignore further transport communication\n this.transport.removeAllListeners();\n if (typeof removeEventListener === \"function\") {\n removeEventListener(\"offline\", this.offlineEventListener, false);\n }\n // set ready state\n this.readyState = \"closed\";\n // clear session id\n this.id = null;\n // emit close event\n this.emitReserved(\"close\", reason, desc);\n // clean buffers after, so users can still\n // grab the buffers on `close` event\n this.writeBuffer = [];\n this.prevBufferLen = 0;\n }\n }\n /**\n * Filters upgrades, returning only those matching client transports.\n *\n * @param {Array} server upgrades\n * @api private\n *\n */\n filterUpgrades(upgrades) {\n const filteredUpgrades = [];\n let i = 0;\n const j = upgrades.length;\n for (; i < j; i++) {\n if (~this.transports.indexOf(upgrades[i]))\n filteredUpgrades.push(upgrades[i]);\n }\n return filteredUpgrades;\n }\n}\nSocket.protocol = protocol;\nfunction clone(obj) {\n const o = {};\n for (let i in obj) {\n if (obj.hasOwnProperty(i)) {\n o[i] = obj[i];\n }\n }\n return o;\n}\n","import { XHR } from \"./polling-xhr.js\";\nimport { WS } from \"./websocket.js\";\nexport const transports = {\n websocket: WS,\n polling: XHR\n};\n","/* global attachEvent */\nimport XMLHttpRequest from \"./xmlhttprequest.js\";\nimport globalThis from \"../globalThis.js\";\nimport { installTimerFunctions, pick } from \"../util.js\";\nimport { Emitter } from \"@socket.io/component-emitter\";\nimport { Polling } from \"./polling.js\";\n/**\n * Empty function\n */\nfunction empty() { }\nconst hasXHR2 = (function () {\n const xhr = new XMLHttpRequest({\n xdomain: false\n });\n return null != xhr.responseType;\n})();\nexport class XHR extends Polling {\n /**\n * XHR Polling constructor.\n *\n * @param {Object} opts\n * @api public\n */\n constructor(opts) {\n super(opts);\n if (typeof location !== \"undefined\") {\n const isSSL = \"https:\" === location.protocol;\n let port = location.port;\n // some user agents have empty `location.port`\n if (!port) {\n port = isSSL ? \"443\" : \"80\";\n }\n this.xd =\n (typeof location !== \"undefined\" &&\n opts.hostname !== location.hostname) ||\n port !== opts.port;\n this.xs = opts.secure !== isSSL;\n }\n /**\n * XHR supports binary\n */\n const forceBase64 = opts && opts.forceBase64;\n this.supportsBinary = hasXHR2 && !forceBase64;\n }\n /**\n * Creates a request.\n *\n * @param {String} method\n * @api private\n */\n request(opts = {}) {\n Object.assign(opts, { xd: this.xd, xs: this.xs }, this.opts);\n return new Request(this.uri(), opts);\n }\n /**\n * Sends data.\n *\n * @param {String} data to send.\n * @param {Function} called upon flush.\n * @api private\n */\n doWrite(data, fn) {\n const req = this.request({\n method: \"POST\",\n data: data\n });\n req.on(\"success\", fn);\n req.on(\"error\", err => {\n this.onError(\"xhr post error\", err);\n });\n }\n /**\n * Starts a poll cycle.\n *\n * @api private\n */\n doPoll() {\n const req = this.request();\n req.on(\"data\", this.onData.bind(this));\n req.on(\"error\", err => {\n this.onError(\"xhr poll error\", err);\n });\n this.pollXhr = req;\n }\n}\nexport class Request extends Emitter {\n /**\n * Request constructor\n *\n * @param {Object} options\n * @api public\n */\n constructor(uri, opts) {\n super();\n installTimerFunctions(this, opts);\n this.opts = opts;\n this.method = opts.method || \"GET\";\n this.uri = uri;\n this.async = false !== opts.async;\n this.data = undefined !== opts.data ? opts.data : null;\n this.create();\n }\n /**\n * Creates the XHR object and sends the request.\n *\n * @api private\n */\n create() {\n const opts = pick(this.opts, \"agent\", \"pfx\", \"key\", \"passphrase\", \"cert\", \"ca\", \"ciphers\", \"rejectUnauthorized\", \"autoUnref\");\n opts.xdomain = !!this.opts.xd;\n opts.xscheme = !!this.opts.xs;\n const xhr = (this.xhr = new XMLHttpRequest(opts));\n try {\n xhr.open(this.method, this.uri, this.async);\n try {\n if (this.opts.extraHeaders) {\n xhr.setDisableHeaderCheck && xhr.setDisableHeaderCheck(true);\n for (let i in this.opts.extraHeaders) {\n if (this.opts.extraHeaders.hasOwnProperty(i)) {\n xhr.setRequestHeader(i, this.opts.extraHeaders[i]);\n }\n }\n }\n }\n catch (e) { }\n if (\"POST\" === this.method) {\n try {\n xhr.setRequestHeader(\"Content-type\", \"text/plain;charset=UTF-8\");\n }\n catch (e) { }\n }\n try {\n xhr.setRequestHeader(\"Accept\", \"*/*\");\n }\n catch (e) { }\n // ie6 check\n if (\"withCredentials\" in xhr) {\n xhr.withCredentials = this.opts.withCredentials;\n }\n if (this.opts.requestTimeout) {\n xhr.timeout = this.opts.requestTimeout;\n }\n xhr.onreadystatechange = () => {\n if (4 !== xhr.readyState)\n return;\n if (200 === xhr.status || 1223 === xhr.status) {\n this.onLoad();\n }\n else {\n // make sure the `error` event handler that's user-set\n // does not throw in the same tick and gets caught here\n this.setTimeoutFn(() => {\n this.onError(typeof xhr.status === \"number\" ? xhr.status : 0);\n }, 0);\n }\n };\n xhr.send(this.data);\n }\n catch (e) {\n // Need to defer since .create() is called directly from the constructor\n // and thus the 'error' event can only be only bound *after* this exception\n // occurs. Therefore, also, we cannot throw here at all.\n this.setTimeoutFn(() => {\n this.onError(e);\n }, 0);\n return;\n }\n if (typeof document !== \"undefined\") {\n this.index = Request.requestsCount++;\n Request.requests[this.index] = this;\n }\n }\n /**\n * Called upon successful response.\n *\n * @api private\n */\n onSuccess() {\n this.emit(\"success\");\n this.cleanup();\n }\n /**\n * Called if we have data.\n *\n * @api private\n */\n onData(data) {\n this.emit(\"data\", data);\n this.onSuccess();\n }\n /**\n * Called upon error.\n *\n * @api private\n */\n onError(err) {\n this.emit(\"error\", err);\n this.cleanup(true);\n }\n /**\n * Cleans up house.\n *\n * @api private\n */\n cleanup(fromError) {\n if (\"undefined\" === typeof this.xhr || null === this.xhr) {\n return;\n }\n this.xhr.onreadystatechange = empty;\n if (fromError) {\n try {\n this.xhr.abort();\n }\n catch (e) { }\n }\n if (typeof document !== \"undefined\") {\n delete Request.requests[this.index];\n }\n this.xhr = null;\n }\n /**\n * Called upon load.\n *\n * @api private\n */\n onLoad() {\n const data = this.xhr.responseText;\n if (data !== null) {\n this.onData(data);\n }\n }\n /**\n * Aborts the request.\n *\n * @api public\n */\n abort() {\n this.cleanup();\n }\n}\nRequest.requestsCount = 0;\nRequest.requests = {};\n/**\n * Aborts pending requests when unloading the window. This is needed to prevent\n * memory leaks (e.g. when using IE) and to ensure that no spurious error is\n * emitted.\n */\nif (typeof document !== \"undefined\") {\n // @ts-ignore\n if (typeof attachEvent === \"function\") {\n // @ts-ignore\n attachEvent(\"onunload\", unloadHandler);\n }\n else if (typeof addEventListener === \"function\") {\n const terminationEvent = \"onpagehide\" in globalThis ? \"pagehide\" : \"unload\";\n addEventListener(terminationEvent, unloadHandler, false);\n }\n}\nfunction unloadHandler() {\n for (let i in Request.requests) {\n if (Request.requests.hasOwnProperty(i)) {\n Request.requests[i].abort();\n }\n }\n}\n","// browser shim for xmlhttprequest module\nimport hasCORS from \"has-cors\";\nimport globalThis from \"../globalThis.js\";\nexport default function (opts) {\n const xdomain = opts.xdomain;\n // XMLHttpRequest can be disabled on IE\n try {\n if (\"undefined\" !== typeof XMLHttpRequest && (!xdomain || hasCORS)) {\n return new XMLHttpRequest();\n }\n }\n catch (e) { }\n if (!xdomain) {\n try {\n return new globalThis[[\"Active\"].concat(\"Object\").join(\"X\")](\"Microsoft.XMLHTTP\");\n }\n catch (e) { }\n }\n}\n","\n/**\n * Module exports.\n *\n * Logic borrowed from Modernizr:\n *\n * - https://github.com/Modernizr/Modernizr/blob/master/feature-detects/cors.js\n */\n\ntry {\n module.exports = typeof XMLHttpRequest !== 'undefined' &&\n 'withCredentials' in new XMLHttpRequest();\n} catch (err) {\n // if XMLHttp support is disabled in IE then it will throw\n // when trying to create\n module.exports = false;\n}\n","export default (() => {\n if (typeof self !== \"undefined\") {\n return self;\n }\n else if (typeof window !== \"undefined\") {\n return window;\n }\n else {\n return Function(\"return this\")();\n }\n})();\n","import globalThis from \"./globalThis.js\";\nexport function pick(obj, ...attr) {\n return attr.reduce((acc, k) => {\n if (obj.hasOwnProperty(k)) {\n acc[k] = obj[k];\n }\n return acc;\n }, {});\n}\n// Keep a reference to the real timeout functions so they can be used when overridden\nconst NATIVE_SET_TIMEOUT = setTimeout;\nconst NATIVE_CLEAR_TIMEOUT = clearTimeout;\nexport function installTimerFunctions(obj, opts) {\n if (opts.useNativeTimers) {\n obj.setTimeoutFn = NATIVE_SET_TIMEOUT.bind(globalThis);\n obj.clearTimeoutFn = NATIVE_CLEAR_TIMEOUT.bind(globalThis);\n }\n else {\n obj.setTimeoutFn = setTimeout.bind(globalThis);\n obj.clearTimeoutFn = clearTimeout.bind(globalThis);\n }\n}\n","\n/**\n * Expose `Emitter`.\n */\n\nexports.Emitter = Emitter;\n\n/**\n * Initialize a new `Emitter`.\n *\n * @api public\n */\n\nfunction Emitter(obj) {\n if (obj) return mixin(obj);\n}\n\n/**\n * Mixin the emitter properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\nfunction mixin(obj) {\n for (var key in Emitter.prototype) {\n obj[key] = Emitter.prototype[key];\n }\n return obj;\n}\n\n/**\n * Listen on the given `event` with `fn`.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.on =\nEmitter.prototype.addEventListener = function(event, fn){\n this._callbacks = this._callbacks || {};\n (this._callbacks['$' + event] = this._callbacks['$' + event] || [])\n .push(fn);\n return this;\n};\n\n/**\n * Adds an `event` listener that will be invoked a single\n * time then automatically removed.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.once = function(event, fn){\n function on() {\n this.off(event, on);\n fn.apply(this, arguments);\n }\n\n on.fn = fn;\n this.on(event, on);\n return this;\n};\n\n/**\n * Remove the given callback for `event` or all\n * registered callbacks.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.off =\nEmitter.prototype.removeListener =\nEmitter.prototype.removeAllListeners =\nEmitter.prototype.removeEventListener = function(event, fn){\n this._callbacks = this._callbacks || {};\n\n // all\n if (0 == arguments.length) {\n this._callbacks = {};\n return this;\n }\n\n // specific event\n var callbacks = this._callbacks['$' + event];\n if (!callbacks) return this;\n\n // remove all handlers\n if (1 == arguments.length) {\n delete this._callbacks['$' + event];\n return this;\n }\n\n // remove specific handler\n var cb;\n for (var i = 0; i < callbacks.length; i++) {\n cb = callbacks[i];\n if (cb === fn || cb.fn === fn) {\n callbacks.splice(i, 1);\n break;\n }\n }\n\n // Remove event specific arrays for event types that no\n // one is subscribed for to avoid memory leak.\n if (callbacks.length === 0) {\n delete this._callbacks['$' + event];\n }\n\n return this;\n};\n\n/**\n * Emit `event` with the given args.\n *\n * @param {String} event\n * @param {Mixed} ...\n * @return {Emitter}\n */\n\nEmitter.prototype.emit = function(event){\n this._callbacks = this._callbacks || {};\n\n var args = new Array(arguments.length - 1)\n , callbacks = this._callbacks['$' + event];\n\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n\n if (callbacks) {\n callbacks = callbacks.slice(0);\n for (var i = 0, len = callbacks.length; i < len; ++i) {\n callbacks[i].apply(this, args);\n }\n }\n\n return this;\n};\n\n// alias used for reserved events (protected method)\nEmitter.prototype.emitReserved = Emitter.prototype.emit;\n\n/**\n * Return array of callbacks for `event`.\n *\n * @param {String} event\n * @return {Array}\n * @api public\n */\n\nEmitter.prototype.listeners = function(event){\n this._callbacks = this._callbacks || {};\n return this._callbacks['$' + event] || [];\n};\n\n/**\n * Check if this emitter has `event` handlers.\n *\n * @param {String} event\n * @return {Boolean}\n * @api public\n */\n\nEmitter.prototype.hasListeners = function(event){\n return !! this.listeners(event).length;\n};\n","import { Transport } from \"../transport.js\";\nimport yeast from \"yeast\";\nimport parseqs from \"parseqs\";\nimport { encodePayload, decodePayload } from \"engine.io-parser\";\nexport class Polling extends Transport {\n constructor() {\n super(...arguments);\n this.polling = false;\n }\n /**\n * Transport name.\n */\n get name() {\n return \"polling\";\n }\n /**\n * Opens the socket (triggers polling). We write a PING message to determine\n * when the transport is open.\n *\n * @api private\n */\n doOpen() {\n this.poll();\n }\n /**\n * Pauses polling.\n *\n * @param {Function} callback upon buffers are flushed and transport is paused\n * @api private\n */\n pause(onPause) {\n this.readyState = \"pausing\";\n const pause = () => {\n this.readyState = \"paused\";\n onPause();\n };\n if (this.polling || !this.writable) {\n let total = 0;\n if (this.polling) {\n total++;\n this.once(\"pollComplete\", function () {\n --total || pause();\n });\n }\n if (!this.writable) {\n total++;\n this.once(\"drain\", function () {\n --total || pause();\n });\n }\n }\n else {\n pause();\n }\n }\n /**\n * Starts polling cycle.\n *\n * @api public\n */\n poll() {\n this.polling = true;\n this.doPoll();\n this.emit(\"poll\");\n }\n /**\n * Overloads onData to detect payloads.\n *\n * @api private\n */\n onData(data) {\n const callback = packet => {\n // if its the first message we consider the transport open\n if (\"opening\" === this.readyState && packet.type === \"open\") {\n this.onOpen();\n }\n // if its a close packet, we close the ongoing requests\n if (\"close\" === packet.type) {\n this.onClose();\n return false;\n }\n // otherwise bypass onData and handle the message\n this.onPacket(packet);\n };\n // decode payload\n decodePayload(data, this.socket.binaryType).forEach(callback);\n // if an event did not trigger closing\n if (\"closed\" !== this.readyState) {\n // if we got data we're not polling\n this.polling = false;\n this.emit(\"pollComplete\");\n if (\"open\" === this.readyState) {\n this.poll();\n }\n else {\n }\n }\n }\n /**\n * For polling, send a close packet.\n *\n * @api private\n */\n doClose() {\n const close = () => {\n this.write([{ type: \"close\" }]);\n };\n if (\"open\" === this.readyState) {\n close();\n }\n else {\n // in case we're trying to close while\n // handshaking is in progress (GH-164)\n this.once(\"open\", close);\n }\n }\n /**\n * Writes a packets payload.\n *\n * @param {Array} data packets\n * @param {Function} drain callback\n * @api private\n */\n write(packets) {\n this.writable = false;\n encodePayload(packets, data => {\n this.doWrite(data, () => {\n this.writable = true;\n this.emit(\"drain\");\n });\n });\n }\n /**\n * Generates uri for connection.\n *\n * @api private\n */\n uri() {\n let query = this.query || {};\n const schema = this.opts.secure ? \"https\" : \"http\";\n let port = \"\";\n // cache busting is forced\n if (false !== this.opts.timestampRequests) {\n query[this.opts.timestampParam] = yeast();\n }\n if (!this.supportsBinary && !query.sid) {\n query.b64 = 1;\n }\n // avoid port if default for schema\n if (this.opts.port &&\n ((\"https\" === schema && Number(this.opts.port) !== 443) ||\n (\"http\" === schema && Number(this.opts.port) !== 80))) {\n port = \":\" + this.opts.port;\n }\n const encodedQuery = parseqs.encode(query);\n const ipv6 = this.opts.hostname.indexOf(\":\") !== -1;\n return (schema +\n \"://\" +\n (ipv6 ? \"[\" + this.opts.hostname + \"]\" : this.opts.hostname) +\n port +\n this.opts.path +\n (encodedQuery.length ? \"?\" + encodedQuery : \"\"));\n }\n}\n","import { decodePacket } from \"engine.io-parser\";\nimport { Emitter } from \"@socket.io/component-emitter\";\nimport { installTimerFunctions } from \"./util.js\";\nexport class Transport extends Emitter {\n /**\n * Transport abstract constructor.\n *\n * @param {Object} options.\n * @api private\n */\n constructor(opts) {\n super();\n this.writable = false;\n installTimerFunctions(this, opts);\n this.opts = opts;\n this.query = opts.query;\n this.readyState = \"\";\n this.socket = opts.socket;\n }\n /**\n * Emits an error.\n *\n * @param {String} str\n * @return {Transport} for chaining\n * @api protected\n */\n onError(msg, desc) {\n const err = new Error(msg);\n // @ts-ignore\n err.type = \"TransportError\";\n // @ts-ignore\n err.description = desc;\n super.emit(\"error\", err);\n return this;\n }\n /**\n * Opens the transport.\n *\n * @api public\n */\n open() {\n if (\"closed\" === this.readyState || \"\" === this.readyState) {\n this.readyState = \"opening\";\n this.doOpen();\n }\n return this;\n }\n /**\n * Closes the transport.\n *\n * @api public\n */\n close() {\n if (\"opening\" === this.readyState || \"open\" === this.readyState) {\n this.doClose();\n this.onClose();\n }\n return this;\n }\n /**\n * Sends multiple packets.\n *\n * @param {Array} packets\n * @api public\n */\n send(packets) {\n if (\"open\" === this.readyState) {\n this.write(packets);\n }\n else {\n // this might happen if the transport was silently closed in the beforeunload event handler\n }\n }\n /**\n * Called upon open\n *\n * @api protected\n */\n onOpen() {\n this.readyState = \"open\";\n this.writable = true;\n super.emit(\"open\");\n }\n /**\n * Called with data.\n *\n * @param {String} data\n * @api protected\n */\n onData(data) {\n const packet = decodePacket(data, this.socket.binaryType);\n this.onPacket(packet);\n }\n /**\n * Called with a decoded packet.\n *\n * @api protected\n */\n onPacket(packet) {\n super.emit(\"packet\", packet);\n }\n /**\n * Called upon close.\n *\n * @api protected\n */\n onClose() {\n this.readyState = \"closed\";\n super.emit(\"close\");\n }\n}\n","import encodePacket from \"./encodePacket.js\";\nimport decodePacket from \"./decodePacket.js\";\nconst SEPARATOR = String.fromCharCode(30); // see https://en.wikipedia.org/wiki/Delimiter#ASCII_delimited_text\nconst encodePayload = (packets, callback) => {\n // some packets may be added to the array while encoding, so the initial length must be saved\n const length = packets.length;\n const encodedPackets = new Array(length);\n let count = 0;\n packets.forEach((packet, i) => {\n // force base64 encoding for binary packets\n encodePacket(packet, false, encodedPacket => {\n encodedPackets[i] = encodedPacket;\n if (++count === length) {\n callback(encodedPackets.join(SEPARATOR));\n }\n });\n });\n};\nconst decodePayload = (encodedPayload, binaryType) => {\n const encodedPackets = encodedPayload.split(SEPARATOR);\n const packets = [];\n for (let i = 0; i < encodedPackets.length; i++) {\n const decodedPacket = decodePacket(encodedPackets[i], binaryType);\n packets.push(decodedPacket);\n if (decodedPacket.type === \"error\") {\n break;\n }\n }\n return packets;\n};\nexport const protocol = 4;\nexport { encodePacket, encodePayload, decodePacket, decodePayload };\n","import { PACKET_TYPES } from \"./commons.js\";\nconst withNativeBlob = typeof Blob === \"function\" ||\n (typeof Blob !== \"undefined\" &&\n Object.prototype.toString.call(Blob) === \"[object BlobConstructor]\");\nconst withNativeArrayBuffer = typeof ArrayBuffer === \"function\";\n// ArrayBuffer.isView method is not defined in IE10\nconst isView = obj => {\n return typeof ArrayBuffer.isView === \"function\"\n ? ArrayBuffer.isView(obj)\n : obj && obj.buffer instanceof ArrayBuffer;\n};\nconst encodePacket = ({ type, data }, supportsBinary, callback) => {\n if (withNativeBlob && data instanceof Blob) {\n if (supportsBinary) {\n return callback(data);\n }\n else {\n return encodeBlobAsBase64(data, callback);\n }\n }\n else if (withNativeArrayBuffer &&\n (data instanceof ArrayBuffer || isView(data))) {\n if (supportsBinary) {\n return callback(data);\n }\n else {\n return encodeBlobAsBase64(new Blob([data]), callback);\n }\n }\n // plain string\n return callback(PACKET_TYPES[type] + (data || \"\"));\n};\nconst encodeBlobAsBase64 = (data, callback) => {\n const fileReader = new FileReader();\n fileReader.onload = function () {\n const content = fileReader.result.split(\",\")[1];\n callback(\"b\" + content);\n };\n return fileReader.readAsDataURL(data);\n};\nexport default encodePacket;\n","const PACKET_TYPES = Object.create(null); // no Map = no polyfill\nPACKET_TYPES[\"open\"] = \"0\";\nPACKET_TYPES[\"close\"] = \"1\";\nPACKET_TYPES[\"ping\"] = \"2\";\nPACKET_TYPES[\"pong\"] = \"3\";\nPACKET_TYPES[\"message\"] = \"4\";\nPACKET_TYPES[\"upgrade\"] = \"5\";\nPACKET_TYPES[\"noop\"] = \"6\";\nconst PACKET_TYPES_REVERSE = Object.create(null);\nObject.keys(PACKET_TYPES).forEach(key => {\n PACKET_TYPES_REVERSE[PACKET_TYPES[key]] = key;\n});\nconst ERROR_PACKET = { type: \"error\", data: \"parser error\" };\nexport { PACKET_TYPES, PACKET_TYPES_REVERSE, ERROR_PACKET };\n","import { ERROR_PACKET, PACKET_TYPES_REVERSE } from \"./commons.js\";\nimport { decode } from \"base64-arraybuffer\";\nconst withNativeArrayBuffer = typeof ArrayBuffer === \"function\";\nconst decodePacket = (encodedPacket, binaryType) => {\n if (typeof encodedPacket !== \"string\") {\n return {\n type: \"message\",\n data: mapBinary(encodedPacket, binaryType)\n };\n }\n const type = encodedPacket.charAt(0);\n if (type === \"b\") {\n return {\n type: \"message\",\n data: decodeBase64Packet(encodedPacket.substring(1), binaryType)\n };\n }\n const packetType = PACKET_TYPES_REVERSE[type];\n if (!packetType) {\n return ERROR_PACKET;\n }\n return encodedPacket.length > 1\n ? {\n type: PACKET_TYPES_REVERSE[type],\n data: encodedPacket.substring(1)\n }\n : {\n type: PACKET_TYPES_REVERSE[type]\n };\n};\nconst decodeBase64Packet = (data, binaryType) => {\n if (withNativeArrayBuffer) {\n const decoded = decode(data);\n return mapBinary(decoded, binaryType);\n }\n else {\n return { base64: true, data }; // fallback for old browsers\n }\n};\nconst mapBinary = (data, binaryType) => {\n switch (binaryType) {\n case \"blob\":\n return data instanceof ArrayBuffer ? new Blob([data]) : data;\n case \"arraybuffer\":\n default:\n return data; // assuming the data is already an ArrayBuffer\n }\n};\nexport default decodePacket;\n",null,"'use strict';\n\nvar alphabet = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz-_'.split('')\n , length = 64\n , map = {}\n , seed = 0\n , i = 0\n , prev;\n\n/**\n * Return a string representing the specified number.\n *\n * @param {Number} num The number to convert.\n * @returns {String} The string representation of the number.\n * @api public\n */\nfunction encode(num) {\n var encoded = '';\n\n do {\n encoded = alphabet[num % length] + encoded;\n num = Math.floor(num / length);\n } while (num > 0);\n\n return encoded;\n}\n\n/**\n * Return the integer value specified by the given string.\n *\n * @param {String} str The string to convert.\n * @returns {Number} The integer value represented by the string.\n * @api public\n */\nfunction decode(str) {\n var decoded = 0;\n\n for (i = 0; i < str.length; i++) {\n decoded = decoded * length + map[str.charAt(i)];\n }\n\n return decoded;\n}\n\n/**\n * Yeast: A tiny growing id generator.\n *\n * @returns {String} A unique id.\n * @api public\n */\nfunction yeast() {\n var now = encode(+new Date());\n\n if (now !== prev) return seed = 0, prev = now;\n return now +'.'+ encode(seed++);\n}\n\n//\n// Map each character to its index.\n//\nfor (; i < length; i++) map[alphabet[i]] = i;\n\n//\n// Expose the `yeast`, `encode` and `decode` functions.\n//\nyeast.encode = encode;\nyeast.decode = decode;\nmodule.exports = yeast;\n","/**\n * Compiles a querystring\n * Returns string representation of the object\n *\n * @param {Object}\n * @api private\n */\n\nexports.encode = function (obj) {\n var str = '';\n\n for (var i in obj) {\n if (obj.hasOwnProperty(i)) {\n if (str.length) str += '&';\n str += encodeURIComponent(i) + '=' + encodeURIComponent(obj[i]);\n }\n }\n\n return str;\n};\n\n/**\n * Parses a simple querystring into an object\n *\n * @param {String} qs\n * @api private\n */\n\nexports.decode = function(qs){\n var qry = {};\n var pairs = qs.split('&');\n for (var i = 0, l = pairs.length; i < l; i++) {\n var pair = pairs[i].split('=');\n qry[decodeURIComponent(pair[0])] = decodeURIComponent(pair[1]);\n }\n return qry;\n};\n","import { Transport } from \"../transport.js\";\nimport parseqs from \"parseqs\";\nimport yeast from \"yeast\";\nimport { pick } from \"../util.js\";\nimport { defaultBinaryType, nextTick, usingBrowserWebSocket, WebSocket } from \"./websocket-constructor.js\";\nimport { encodePacket } from \"engine.io-parser\";\n// detect ReactNative environment\nconst isReactNative = typeof navigator !== \"undefined\" &&\n typeof navigator.product === \"string\" &&\n navigator.product.toLowerCase() === \"reactnative\";\nexport class WS extends Transport {\n /**\n * WebSocket transport constructor.\n *\n * @api {Object} connection options\n * @api public\n */\n constructor(opts) {\n super(opts);\n this.supportsBinary = !opts.forceBase64;\n }\n /**\n * Transport name.\n *\n * @api public\n */\n get name() {\n return \"websocket\";\n }\n /**\n * Opens socket.\n *\n * @api private\n */\n doOpen() {\n if (!this.check()) {\n // let probe timeout\n return;\n }\n const uri = this.uri();\n const protocols = this.opts.protocols;\n // React Native only supports the 'headers' option, and will print a warning if anything else is passed\n const opts = isReactNative\n ? {}\n : pick(this.opts, \"agent\", \"perMessageDeflate\", \"pfx\", \"key\", \"passphrase\", \"cert\", \"ca\", \"ciphers\", \"rejectUnauthorized\", \"localAddress\", \"protocolVersion\", \"origin\", \"maxPayload\", \"family\", \"checkServerIdentity\");\n if (this.opts.extraHeaders) {\n opts.headers = this.opts.extraHeaders;\n }\n try {\n this.ws =\n usingBrowserWebSocket && !isReactNative\n ? protocols\n ? new WebSocket(uri, protocols)\n : new WebSocket(uri)\n : new WebSocket(uri, protocols, opts);\n }\n catch (err) {\n return this.emit(\"error\", err);\n }\n this.ws.binaryType = this.socket.binaryType || defaultBinaryType;\n this.addEventListeners();\n }\n /**\n * Adds event listeners to the socket\n *\n * @api private\n */\n addEventListeners() {\n this.ws.onopen = () => {\n if (this.opts.autoUnref) {\n this.ws._socket.unref();\n }\n this.onOpen();\n };\n this.ws.onclose = this.onClose.bind(this);\n this.ws.onmessage = ev => this.onData(ev.data);\n this.ws.onerror = e => this.onError(\"websocket error\", e);\n }\n /**\n * Writes data to socket.\n *\n * @param {Array} array of packets.\n * @api private\n */\n write(packets) {\n this.writable = false;\n // encodePacket efficient as it uses WS framing\n // no need for encodePayload\n for (let i = 0; i < packets.length; i++) {\n const packet = packets[i];\n const lastPacket = i === packets.length - 1;\n encodePacket(packet, this.supportsBinary, data => {\n // always create a new object (GH-437)\n const opts = {};\n if (!usingBrowserWebSocket) {\n if (packet.options) {\n opts.compress = packet.options.compress;\n }\n if (this.opts.perMessageDeflate) {\n const len = \"string\" === typeof data ? Buffer.byteLength(data) : data.length;\n if (len < this.opts.perMessageDeflate.threshold) {\n opts.compress = false;\n }\n }\n }\n // Sometimes the websocket has already been closed but the browser didn't\n // have a chance of informing us about it yet, in that case send will\n // throw an error\n try {\n if (usingBrowserWebSocket) {\n // TypeError is thrown when passing the second argument on Safari\n this.ws.send(data);\n }\n else {\n this.ws.send(data, opts);\n }\n }\n catch (e) {\n }\n if (lastPacket) {\n // fake drain\n // defer to next tick to allow Socket to clear writeBuffer\n nextTick(() => {\n this.writable = true;\n this.emit(\"drain\");\n }, this.setTimeoutFn);\n }\n });\n }\n }\n /**\n * Closes socket.\n *\n * @api private\n */\n doClose() {\n if (typeof this.ws !== \"undefined\") {\n this.ws.close();\n this.ws = null;\n }\n }\n /**\n * Generates uri for connection.\n *\n * @api private\n */\n uri() {\n let query = this.query || {};\n const schema = this.opts.secure ? \"wss\" : \"ws\";\n let port = \"\";\n // avoid port if default for schema\n if (this.opts.port &&\n ((\"wss\" === schema && Number(this.opts.port) !== 443) ||\n (\"ws\" === schema && Number(this.opts.port) !== 80))) {\n port = \":\" + this.opts.port;\n }\n // append timestamp to URI\n if (this.opts.timestampRequests) {\n query[this.opts.timestampParam] = yeast();\n }\n // communicate binary support capabilities\n if (!this.supportsBinary) {\n query.b64 = 1;\n }\n const encodedQuery = parseqs.encode(query);\n const ipv6 = this.opts.hostname.indexOf(\":\") !== -1;\n return (schema +\n \"://\" +\n (ipv6 ? \"[\" + this.opts.hostname + \"]\" : this.opts.hostname) +\n port +\n this.opts.path +\n (encodedQuery.length ? \"?\" + encodedQuery : \"\"));\n }\n /**\n * Feature detection for WebSocket.\n *\n * @return {Boolean} whether this transport is available.\n * @api public\n */\n check() {\n return (!!WebSocket &&\n !(\"__initialize\" in WebSocket && this.name === WS.prototype.name));\n }\n}\n","import globalThis from \"../globalThis.js\";\nexport const nextTick = (() => {\n const isPromiseAvailable = typeof Promise === \"function\" && typeof Promise.resolve === \"function\";\n if (isPromiseAvailable) {\n return cb => Promise.resolve().then(cb);\n }\n else {\n return (cb, setTimeoutFn) => setTimeoutFn(cb, 0);\n }\n})();\nexport const WebSocket = globalThis.WebSocket || globalThis.MozWebSocket;\nexport const usingBrowserWebSocket = true;\nexport const defaultBinaryType = \"arraybuffer\";\n","import { PacketType } from \"socket.io-parser\";\nimport { on } from \"./on.js\";\nimport { Emitter, } from \"@socket.io/component-emitter\";\n/**\n * Internal events.\n * These events can't be emitted by the user.\n */\nconst RESERVED_EVENTS = Object.freeze({\n connect: 1,\n connect_error: 1,\n disconnect: 1,\n disconnecting: 1,\n // EventEmitter reserved events: https://nodejs.org/api/events.html#events_event_newlistener\n newListener: 1,\n removeListener: 1,\n});\nexport class Socket extends Emitter {\n /**\n * `Socket` constructor.\n *\n * @public\n */\n constructor(io, nsp, opts) {\n super();\n this.connected = false;\n this.disconnected = true;\n this.receiveBuffer = [];\n this.sendBuffer = [];\n this.ids = 0;\n this.acks = {};\n this.flags = {};\n this.io = io;\n this.nsp = nsp;\n if (opts && opts.auth) {\n this.auth = opts.auth;\n }\n if (this.io._autoConnect)\n this.open();\n }\n /**\n * Subscribe to open, close and packet events\n *\n * @private\n */\n subEvents() {\n if (this.subs)\n return;\n const io = this.io;\n this.subs = [\n on(io, \"open\", this.onopen.bind(this)),\n on(io, \"packet\", this.onpacket.bind(this)),\n on(io, \"error\", this.onerror.bind(this)),\n on(io, \"close\", this.onclose.bind(this)),\n ];\n }\n /**\n * Whether the Socket will try to reconnect when its Manager connects or reconnects\n */\n get active() {\n return !!this.subs;\n }\n /**\n * \"Opens\" the socket.\n *\n * @public\n */\n connect() {\n if (this.connected)\n return this;\n this.subEvents();\n if (!this.io[\"_reconnecting\"])\n this.io.open(); // ensure open\n if (\"open\" === this.io._readyState)\n this.onopen();\n return this;\n }\n /**\n * Alias for connect()\n */\n open() {\n return this.connect();\n }\n /**\n * Sends a `message` event.\n *\n * @return self\n * @public\n */\n send(...args) {\n args.unshift(\"message\");\n this.emit.apply(this, args);\n return this;\n }\n /**\n * Override `emit`.\n * If the event is in `events`, it's emitted normally.\n *\n * @return self\n * @public\n */\n emit(ev, ...args) {\n if (RESERVED_EVENTS.hasOwnProperty(ev)) {\n throw new Error('\"' + ev + '\" is a reserved event name');\n }\n args.unshift(ev);\n const packet = {\n type: PacketType.EVENT,\n data: args,\n };\n packet.options = {};\n packet.options.compress = this.flags.compress !== false;\n // event ack callback\n if (\"function\" === typeof args[args.length - 1]) {\n const id = this.ids++;\n const ack = args.pop();\n this._registerAckCallback(id, ack);\n packet.id = id;\n }\n const isTransportWritable = this.io.engine &&\n this.io.engine.transport &&\n this.io.engine.transport.writable;\n const discardPacket = this.flags.volatile && (!isTransportWritable || !this.connected);\n if (discardPacket) {\n }\n else if (this.connected) {\n this.packet(packet);\n }\n else {\n this.sendBuffer.push(packet);\n }\n this.flags = {};\n return this;\n }\n /**\n * @private\n */\n _registerAckCallback(id, ack) {\n const timeout = this.flags.timeout;\n if (timeout === undefined) {\n this.acks[id] = ack;\n return;\n }\n // @ts-ignore\n const timer = this.io.setTimeoutFn(() => {\n delete this.acks[id];\n for (let i = 0; i < this.sendBuffer.length; i++) {\n if (this.sendBuffer[i].id === id) {\n this.sendBuffer.splice(i, 1);\n }\n }\n ack.call(this, new Error(\"operation has timed out\"));\n }, timeout);\n this.acks[id] = (...args) => {\n // @ts-ignore\n this.io.clearTimeoutFn(timer);\n ack.apply(this, [null, ...args]);\n };\n }\n /**\n * Sends a packet.\n *\n * @param packet\n * @private\n */\n packet(packet) {\n packet.nsp = this.nsp;\n this.io._packet(packet);\n }\n /**\n * Called upon engine `open`.\n *\n * @private\n */\n onopen() {\n if (typeof this.auth == \"function\") {\n this.auth((data) => {\n this.packet({ type: PacketType.CONNECT, data });\n });\n }\n else {\n this.packet({ type: PacketType.CONNECT, data: this.auth });\n }\n }\n /**\n * Called upon engine or manager `error`.\n *\n * @param err\n * @private\n */\n onerror(err) {\n if (!this.connected) {\n this.emitReserved(\"connect_error\", err);\n }\n }\n /**\n * Called upon engine `close`.\n *\n * @param reason\n * @private\n */\n onclose(reason) {\n this.connected = false;\n this.disconnected = true;\n delete this.id;\n this.emitReserved(\"disconnect\", reason);\n }\n /**\n * Called with socket packet.\n *\n * @param packet\n * @private\n */\n onpacket(packet) {\n const sameNamespace = packet.nsp === this.nsp;\n if (!sameNamespace)\n return;\n switch (packet.type) {\n case PacketType.CONNECT:\n if (packet.data && packet.data.sid) {\n const id = packet.data.sid;\n this.onconnect(id);\n }\n else {\n this.emitReserved(\"connect_error\", new Error(\"It seems you are trying to reach a Socket.IO server in v2.x with a v3.x client, but they are not compatible (more information here: https://socket.io/docs/v3/migrating-from-2-x-to-3-0/)\"));\n }\n break;\n case PacketType.EVENT:\n this.onevent(packet);\n break;\n case PacketType.BINARY_EVENT:\n this.onevent(packet);\n break;\n case PacketType.ACK:\n this.onack(packet);\n break;\n case PacketType.BINARY_ACK:\n this.onack(packet);\n break;\n case PacketType.DISCONNECT:\n this.ondisconnect();\n break;\n case PacketType.CONNECT_ERROR:\n this.destroy();\n const err = new Error(packet.data.message);\n // @ts-ignore\n err.data = packet.data.data;\n this.emitReserved(\"connect_error\", err);\n break;\n }\n }\n /**\n * Called upon a server event.\n *\n * @param packet\n * @private\n */\n onevent(packet) {\n const args = packet.data || [];\n if (null != packet.id) {\n args.push(this.ack(packet.id));\n }\n if (this.connected) {\n this.emitEvent(args);\n }\n else {\n this.receiveBuffer.push(Object.freeze(args));\n }\n }\n emitEvent(args) {\n if (this._anyListeners && this._anyListeners.length) {\n const listeners = this._anyListeners.slice();\n for (const listener of listeners) {\n listener.apply(this, args);\n }\n }\n super.emit.apply(this, args);\n }\n /**\n * Produces an ack callback to emit with an event.\n *\n * @private\n */\n ack(id) {\n const self = this;\n let sent = false;\n return function (...args) {\n // prevent double callbacks\n if (sent)\n return;\n sent = true;\n self.packet({\n type: PacketType.ACK,\n id: id,\n data: args,\n });\n };\n }\n /**\n * Called upon a server acknowlegement.\n *\n * @param packet\n * @private\n */\n onack(packet) {\n const ack = this.acks[packet.id];\n if (\"function\" === typeof ack) {\n ack.apply(this, packet.data);\n delete this.acks[packet.id];\n }\n else {\n }\n }\n /**\n * Called upon server connect.\n *\n * @private\n */\n onconnect(id) {\n this.id = id;\n this.connected = true;\n this.disconnected = false;\n this.emitBuffered();\n this.emitReserved(\"connect\");\n }\n /**\n * Emit buffered events (received and emitted).\n *\n * @private\n */\n emitBuffered() {\n this.receiveBuffer.forEach((args) => this.emitEvent(args));\n this.receiveBuffer = [];\n this.sendBuffer.forEach((packet) => this.packet(packet));\n this.sendBuffer = [];\n }\n /**\n * Called upon server disconnect.\n *\n * @private\n */\n ondisconnect() {\n this.destroy();\n this.onclose(\"io server disconnect\");\n }\n /**\n * Called upon forced client/server side disconnections,\n * this method ensures the manager stops tracking us and\n * that reconnections don't get triggered for this.\n *\n * @private\n */\n destroy() {\n if (this.subs) {\n // clean subscriptions to avoid reconnections\n this.subs.forEach((subDestroy) => subDestroy());\n this.subs = undefined;\n }\n this.io[\"_destroy\"](this);\n }\n /**\n * Disconnects the socket manually.\n *\n * @return self\n * @public\n */\n disconnect() {\n if (this.connected) {\n this.packet({ type: PacketType.DISCONNECT });\n }\n // remove socket from pool\n this.destroy();\n if (this.connected) {\n // fire events\n this.onclose(\"io client disconnect\");\n }\n return this;\n }\n /**\n * Alias for disconnect()\n *\n * @return self\n * @public\n */\n close() {\n return this.disconnect();\n }\n /**\n * Sets the compress flag.\n *\n * @param compress - if `true`, compresses the sending data\n * @return self\n * @public\n */\n compress(compress) {\n this.flags.compress = compress;\n return this;\n }\n /**\n * Sets a modifier for a subsequent event emission that the event message will be dropped when this socket is not\n * ready to send messages.\n *\n * @returns self\n * @public\n */\n get volatile() {\n this.flags.volatile = true;\n return this;\n }\n /**\n * Sets a modifier for a subsequent event emission that the callback will be called with an error when the\n * given number of milliseconds have elapsed without an acknowledgement from the server:\n *\n * ```\n * socket.timeout(5000).emit(\"my-event\", (err) => {\n * if (err) {\n * // the server did not acknowledge the event in the given delay\n * }\n * });\n * ```\n *\n * @returns self\n * @public\n */\n timeout(timeout) {\n this.flags.timeout = timeout;\n return this;\n }\n /**\n * Adds a listener that will be fired when any event is emitted. The event name is passed as the first argument to the\n * callback.\n *\n * @param listener\n * @public\n */\n onAny(listener) {\n this._anyListeners = this._anyListeners || [];\n this._anyListeners.push(listener);\n return this;\n }\n /**\n * Adds a listener that will be fired when any event is emitted. The event name is passed as the first argument to the\n * callback. The listener is added to the beginning of the listeners array.\n *\n * @param listener\n * @public\n */\n prependAny(listener) {\n this._anyListeners = this._anyListeners || [];\n this._anyListeners.unshift(listener);\n return this;\n }\n /**\n * Removes the listener that will be fired when any event is emitted.\n *\n * @param listener\n * @public\n */\n offAny(listener) {\n if (!this._anyListeners) {\n return this;\n }\n if (listener) {\n const listeners = this._anyListeners;\n for (let i = 0; i < listeners.length; i++) {\n if (listener === listeners[i]) {\n listeners.splice(i, 1);\n return this;\n }\n }\n }\n else {\n this._anyListeners = [];\n }\n return this;\n }\n /**\n * Returns an array of listeners that are listening for any event that is specified. This array can be manipulated,\n * e.g. to remove listeners.\n *\n * @public\n */\n listenersAny() {\n return this._anyListeners || [];\n }\n}\n","import { Emitter } from \"@socket.io/component-emitter\";\nimport { deconstructPacket, reconstructPacket } from \"./binary.js\";\nimport { isBinary, hasBinary } from \"./is-binary.js\";\n/**\n * Protocol version.\n *\n * @public\n */\nexport const protocol = 5;\nexport var PacketType;\n(function (PacketType) {\n PacketType[PacketType[\"CONNECT\"] = 0] = \"CONNECT\";\n PacketType[PacketType[\"DISCONNECT\"] = 1] = \"DISCONNECT\";\n PacketType[PacketType[\"EVENT\"] = 2] = \"EVENT\";\n PacketType[PacketType[\"ACK\"] = 3] = \"ACK\";\n PacketType[PacketType[\"CONNECT_ERROR\"] = 4] = \"CONNECT_ERROR\";\n PacketType[PacketType[\"BINARY_EVENT\"] = 5] = \"BINARY_EVENT\";\n PacketType[PacketType[\"BINARY_ACK\"] = 6] = \"BINARY_ACK\";\n})(PacketType || (PacketType = {}));\n/**\n * A socket.io Encoder instance\n */\nexport class Encoder {\n /**\n * Encode a packet as a single string if non-binary, or as a\n * buffer sequence, depending on packet type.\n *\n * @param {Object} obj - packet object\n */\n encode(obj) {\n if (obj.type === PacketType.EVENT || obj.type === PacketType.ACK) {\n if (hasBinary(obj)) {\n obj.type =\n obj.type === PacketType.EVENT\n ? PacketType.BINARY_EVENT\n : PacketType.BINARY_ACK;\n return this.encodeAsBinary(obj);\n }\n }\n return [this.encodeAsString(obj)];\n }\n /**\n * Encode packet as string.\n */\n encodeAsString(obj) {\n // first is type\n let str = \"\" + obj.type;\n // attachments if we have them\n if (obj.type === PacketType.BINARY_EVENT ||\n obj.type === PacketType.BINARY_ACK) {\n str += obj.attachments + \"-\";\n }\n // if we have a namespace other than `/`\n // we append it followed by a comma `,`\n if (obj.nsp && \"/\" !== obj.nsp) {\n str += obj.nsp + \",\";\n }\n // immediately followed by the id\n if (null != obj.id) {\n str += obj.id;\n }\n // json data\n if (null != obj.data) {\n str += JSON.stringify(obj.data);\n }\n return str;\n }\n /**\n * Encode packet as 'buffer sequence' by removing blobs, and\n * deconstructing packet into object with placeholders and\n * a list of buffers.\n */\n encodeAsBinary(obj) {\n const deconstruction = deconstructPacket(obj);\n const pack = this.encodeAsString(deconstruction.packet);\n const buffers = deconstruction.buffers;\n buffers.unshift(pack); // add packet info to beginning of data list\n return buffers; // write all the buffers\n }\n}\n/**\n * A socket.io Decoder instance\n *\n * @return {Object} decoder\n */\nexport class Decoder extends Emitter {\n constructor() {\n super();\n }\n /**\n * Decodes an encoded packet string into packet JSON.\n *\n * @param {String} obj - encoded packet\n */\n add(obj) {\n let packet;\n if (typeof obj === \"string\") {\n packet = this.decodeString(obj);\n if (packet.type === PacketType.BINARY_EVENT ||\n packet.type === PacketType.BINARY_ACK) {\n // binary packet's json\n this.reconstructor = new BinaryReconstructor(packet);\n // no attachments, labeled binary but no binary data to follow\n if (packet.attachments === 0) {\n super.emitReserved(\"decoded\", packet);\n }\n }\n else {\n // non-binary full packet\n super.emitReserved(\"decoded\", packet);\n }\n }\n else if (isBinary(obj) || obj.base64) {\n // raw binary data\n if (!this.reconstructor) {\n throw new Error(\"got binary data when not reconstructing a packet\");\n }\n else {\n packet = this.reconstructor.takeBinaryData(obj);\n if (packet) {\n // received final buffer\n this.reconstructor = null;\n super.emitReserved(\"decoded\", packet);\n }\n }\n }\n else {\n throw new Error(\"Unknown type: \" + obj);\n }\n }\n /**\n * Decode a packet String (JSON data)\n *\n * @param {String} str\n * @return {Object} packet\n */\n decodeString(str) {\n let i = 0;\n // look up type\n const p = {\n type: Number(str.charAt(0)),\n };\n if (PacketType[p.type] === undefined) {\n throw new Error(\"unknown packet type \" + p.type);\n }\n // look up attachments if type binary\n if (p.type === PacketType.BINARY_EVENT ||\n p.type === PacketType.BINARY_ACK) {\n const start = i + 1;\n while (str.charAt(++i) !== \"-\" && i != str.length) { }\n const buf = str.substring(start, i);\n if (buf != Number(buf) || str.charAt(i) !== \"-\") {\n throw new Error(\"Illegal attachments\");\n }\n p.attachments = Number(buf);\n }\n // look up namespace (if any)\n if (\"/\" === str.charAt(i + 1)) {\n const start = i + 1;\n while (++i) {\n const c = str.charAt(i);\n if (\",\" === c)\n break;\n if (i === str.length)\n break;\n }\n p.nsp = str.substring(start, i);\n }\n else {\n p.nsp = \"/\";\n }\n // look up id\n const next = str.charAt(i + 1);\n if (\"\" !== next && Number(next) == next) {\n const start = i + 1;\n while (++i) {\n const c = str.charAt(i);\n if (null == c || Number(c) != c) {\n --i;\n break;\n }\n if (i === str.length)\n break;\n }\n p.id = Number(str.substring(start, i + 1));\n }\n // look up json data\n if (str.charAt(++i)) {\n const payload = tryParse(str.substr(i));\n if (Decoder.isPayloadValid(p.type, payload)) {\n p.data = payload;\n }\n else {\n throw new Error(\"invalid payload\");\n }\n }\n return p;\n }\n static isPayloadValid(type, payload) {\n switch (type) {\n case PacketType.CONNECT:\n return typeof payload === \"object\";\n case PacketType.DISCONNECT:\n return payload === undefined;\n case PacketType.CONNECT_ERROR:\n return typeof payload === \"string\" || typeof payload === \"object\";\n case PacketType.EVENT:\n case PacketType.BINARY_EVENT:\n return Array.isArray(payload) && payload.length > 0;\n case PacketType.ACK:\n case PacketType.BINARY_ACK:\n return Array.isArray(payload);\n }\n }\n /**\n * Deallocates a parser's resources\n */\n destroy() {\n if (this.reconstructor) {\n this.reconstructor.finishedReconstruction();\n }\n }\n}\nfunction tryParse(str) {\n try {\n return JSON.parse(str);\n }\n catch (e) {\n return false;\n }\n}\n/**\n * A manager of a binary event's 'buffer sequence'. Should\n * be constructed whenever a packet of type BINARY_EVENT is\n * decoded.\n *\n * @param {Object} packet\n * @return {BinaryReconstructor} initialized reconstructor\n */\nclass BinaryReconstructor {\n constructor(packet) {\n this.packet = packet;\n this.buffers = [];\n this.reconPack = packet;\n }\n /**\n * Method to be called when binary data received from connection\n * after a BINARY_EVENT packet.\n *\n * @param {Buffer | ArrayBuffer} binData - the raw binary data received\n * @return {null | Object} returns null if more binary data is expected or\n * a reconstructed packet object if all buffers have been received.\n */\n takeBinaryData(binData) {\n this.buffers.push(binData);\n if (this.buffers.length === this.reconPack.attachments) {\n // done with buffer list\n const packet = reconstructPacket(this.reconPack, this.buffers);\n this.finishedReconstruction();\n return packet;\n }\n return null;\n }\n /**\n * Cleans up binary packet reconstruction variables.\n */\n finishedReconstruction() {\n this.reconPack = null;\n this.buffers = [];\n }\n}\n","import { isBinary } from \"./is-binary.js\";\n/**\n * Replaces every Buffer | ArrayBuffer | Blob | File in packet with a numbered placeholder.\n *\n * @param {Object} packet - socket.io event packet\n * @return {Object} with deconstructed packet and list of buffers\n * @public\n */\nexport function deconstructPacket(packet) {\n const buffers = [];\n const packetData = packet.data;\n const pack = packet;\n pack.data = _deconstructPacket(packetData, buffers);\n pack.attachments = buffers.length; // number of binary 'attachments'\n return { packet: pack, buffers: buffers };\n}\nfunction _deconstructPacket(data, buffers) {\n if (!data)\n return data;\n if (isBinary(data)) {\n const placeholder = { _placeholder: true, num: buffers.length };\n buffers.push(data);\n return placeholder;\n }\n else if (Array.isArray(data)) {\n const newData = new Array(data.length);\n for (let i = 0; i < data.length; i++) {\n newData[i] = _deconstructPacket(data[i], buffers);\n }\n return newData;\n }\n else if (typeof data === \"object\" && !(data instanceof Date)) {\n const newData = {};\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n newData[key] = _deconstructPacket(data[key], buffers);\n }\n }\n return newData;\n }\n return data;\n}\n/**\n * Reconstructs a binary packet from its placeholder packet and buffers\n *\n * @param {Object} packet - event packet with placeholders\n * @param {Array} buffers - binary buffers to put in placeholder positions\n * @return {Object} reconstructed packet\n * @public\n */\nexport function reconstructPacket(packet, buffers) {\n packet.data = _reconstructPacket(packet.data, buffers);\n packet.attachments = undefined; // no longer useful\n return packet;\n}\nfunction _reconstructPacket(data, buffers) {\n if (!data)\n return data;\n if (data && data._placeholder) {\n return buffers[data.num]; // appropriate buffer (should be natural order anyway)\n }\n else if (Array.isArray(data)) {\n for (let i = 0; i < data.length; i++) {\n data[i] = _reconstructPacket(data[i], buffers);\n }\n }\n else if (typeof data === \"object\") {\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n data[key] = _reconstructPacket(data[key], buffers);\n }\n }\n }\n return data;\n}\n","const withNativeArrayBuffer = typeof ArrayBuffer === \"function\";\nconst isView = (obj) => {\n return typeof ArrayBuffer.isView === \"function\"\n ? ArrayBuffer.isView(obj)\n : obj.buffer instanceof ArrayBuffer;\n};\nconst toString = Object.prototype.toString;\nconst withNativeBlob = typeof Blob === \"function\" ||\n (typeof Blob !== \"undefined\" &&\n toString.call(Blob) === \"[object BlobConstructor]\");\nconst withNativeFile = typeof File === \"function\" ||\n (typeof File !== \"undefined\" &&\n toString.call(File) === \"[object FileConstructor]\");\n/**\n * Returns true if obj is a Buffer, an ArrayBuffer, a Blob or a File.\n *\n * @private\n */\nexport function isBinary(obj) {\n return ((withNativeArrayBuffer && (obj instanceof ArrayBuffer || isView(obj))) ||\n (withNativeBlob && obj instanceof Blob) ||\n (withNativeFile && obj instanceof File));\n}\nexport function hasBinary(obj, toJSON) {\n if (!obj || typeof obj !== \"object\") {\n return false;\n }\n if (Array.isArray(obj)) {\n for (let i = 0, l = obj.length; i < l; i++) {\n if (hasBinary(obj[i])) {\n return true;\n }\n }\n return false;\n }\n if (isBinary(obj)) {\n return true;\n }\n if (obj.toJSON &&\n typeof obj.toJSON === \"function\" &&\n arguments.length === 1) {\n return hasBinary(obj.toJSON(), true);\n }\n for (const key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key) && hasBinary(obj[key])) {\n return true;\n }\n }\n return false;\n}\n","export function on(obj, ev, fn) {\n obj.on(ev, fn);\n return function subDestroy() {\n obj.off(ev, fn);\n };\n}\n","\n/**\n * Expose `Backoff`.\n */\n\nmodule.exports = Backoff;\n\n/**\n * Initialize backoff timer with `opts`.\n *\n * - `min` initial timeout in milliseconds [100]\n * - `max` max timeout [10000]\n * - `jitter` [0]\n * - `factor` [2]\n *\n * @param {Object} opts\n * @api public\n */\n\nfunction Backoff(opts) {\n opts = opts || {};\n this.ms = opts.min || 100;\n this.max = opts.max || 10000;\n this.factor = opts.factor || 2;\n this.jitter = opts.jitter > 0 && opts.jitter <= 1 ? opts.jitter : 0;\n this.attempts = 0;\n}\n\n/**\n * Return the backoff duration.\n *\n * @return {Number}\n * @api public\n */\n\nBackoff.prototype.duration = function(){\n var ms = this.ms * Math.pow(this.factor, this.attempts++);\n if (this.jitter) {\n var rand = Math.random();\n var deviation = Math.floor(rand * this.jitter * ms);\n ms = (Math.floor(rand * 10) & 1) == 0 ? ms - deviation : ms + deviation;\n }\n return Math.min(ms, this.max) | 0;\n};\n\n/**\n * Reset the number of attempts.\n *\n * @api public\n */\n\nBackoff.prototype.reset = function(){\n this.attempts = 0;\n};\n\n/**\n * Set the minimum duration\n *\n * @api public\n */\n\nBackoff.prototype.setMin = function(min){\n this.ms = min;\n};\n\n/**\n * Set the maximum duration\n *\n * @api public\n */\n\nBackoff.prototype.setMax = function(max){\n this.max = max;\n};\n\n/**\n * Set the jitter\n *\n * @api public\n */\n\nBackoff.prototype.setJitter = function(jitter){\n this.jitter = jitter;\n};\n\n","'use strict'\n\nconst abortable = require('abortable-iterator')\nconst toIterable = require('stream-to-it')\nconst { CLOSE_TIMEOUT } = require('./constants')\nconst toMultiaddr = require('libp2p-utils/src/ip-port-to-multiaddr')\n\nconst debug = require('debug')\nconst log = debug('libp2p:webrtc-star:socket')\nlog.error = debug('libp2p:webrtc-star:socket:error')\n\nconst toWebrtcMultiaddr = (address, port) => {\n if (!address || !port) return undefined\n\n try {\n return toMultiaddr(address, port)\n } catch (err) {\n log.error(err)\n // Account for mdns hostnames, just make it a local ip for now\n return toMultiaddr('0.0.0.0', port)\n }\n}\n\n// Convert a socket into a MultiaddrConnection\n// https://github.com/libp2p/js-libp2p-interfaces/tree/master/src/transport#multiaddrconnection\nmodule.exports = (socket, options = {}) => {\n const { sink, source } = toIterable.duplex(socket)\n\n // If the remote address was passed, use it - it may have the peer ID encapsulated\n const remoteAddr = options.remoteAddr || toWebrtcMultiaddr(socket.remoteAddress, socket.remotePort)\n const localAddr = toWebrtcMultiaddr(socket.localAddress, socket.localPort)\n\n const maConn = {\n async sink (source) {\n if (options.signal) {\n source = abortable(source, options.signal)\n }\n\n try {\n await sink((async function * () {\n for await (const chunk of source) {\n // Convert BufferList to Buffer\n yield chunk instanceof Uint8Array ? chunk : chunk.slice()\n }\n })())\n } catch (err) {\n // If aborted we can safely ignore\n if (err.type !== 'aborted') {\n // If the source errored the socket will already have been destroyed by\n // toIterable.duplex(). If the socket errored it will already be\n // destroyed. There's nothing to do here except log the error & return.\n log.error(err)\n }\n }\n },\n\n source: options.signal ? abortable(source, options.signal) : source,\n\n conn: socket,\n\n localAddr,\n remoteAddr,\n\n timeline: { open: Date.now() },\n\n close () {\n if (socket.destroyed) return\n\n return new Promise((resolve, reject) => {\n const start = Date.now()\n\n // Attempt to end the socket. If it takes longer to close than the\n // timeout, destroy it manually.\n const timeout = setTimeout(() => {\n if (maConn.remoteAddr) {\n const { host, port } = maConn.remoteAddr.toOptions()\n log('timeout closing socket to %s:%s after %dms, destroying it manually',\n host, port, Date.now() - start)\n }\n\n if (!socket.destroyed) {\n socket.destroy()\n }\n }, CLOSE_TIMEOUT)\n\n socket.once('close', () => {\n resolve()\n })\n\n socket.end(err => {\n clearTimeout(timeout)\n\n maConn.timeline.close = Date.now()\n if (err) return reject(err)\n })\n })\n }\n }\n\n socket.once('close', () => {\n // In instances where `close` was not explicitly called,\n // such as an iterable stream ending, ensure we have set the close\n // timeline\n if (!maConn.timeline.close) {\n maConn.timeline.close = Date.now()\n }\n })\n\n return maConn\n}\n","module.exports = require('./source')\nmodule.exports.source = require('./source')\nmodule.exports.sink = require('./sink')\nmodule.exports.transform = require('./transform')\nmodule.exports.duplex = require('./duplex')\n","const getIterator = require('get-iterator')\n\nmodule.exports = writable => async source => {\n source = getIterator(source)\n\n const maybeEndSource = (source) => {\n if (typeof source.return === 'function') source.return()\n }\n\n let error = null\n let errCb = null\n const errorHandler = (err) => {\n error = err\n if (errCb) errCb(err)\n // When the writable errors, try to end the source to exit iteration early\n maybeEndSource(source)\n }\n\n let closeCb = null\n let closed = false\n const closeHandler = () => {\n closed = true\n if (closeCb) closeCb()\n }\n\n let finishCb = null\n let finished = false\n const finishHandler = () => {\n finished = true\n if (finishCb) finishCb()\n }\n\n let drainCb = null\n const drainHandler = () => {\n if (drainCb) drainCb()\n }\n\n const waitForDrainOrClose = () => {\n return new Promise((resolve, reject) => {\n closeCb = drainCb = resolve\n errCb = reject\n writable.once('drain', drainHandler)\n })\n }\n\n const waitForDone = () => {\n // Immediately try to end the source\n maybeEndSource(source)\n return new Promise((resolve, reject) => {\n if (closed || finished || error) return resolve()\n finishCb = closeCb = resolve\n errCb = reject\n })\n }\n\n const cleanup = () => {\n writable.removeListener('error', errorHandler)\n writable.removeListener('close', closeHandler)\n writable.removeListener('finish', finishHandler)\n writable.removeListener('drain', drainHandler)\n }\n\n writable.once('error', errorHandler)\n writable.once('close', closeHandler)\n writable.once('finish', finishHandler)\n\n try {\n for await (const value of source) {\n if (!writable.writable || writable.destroyed || error) break\n\n if (writable.write(value) === false) {\n await waitForDrainOrClose()\n }\n }\n } catch (err) {\n // error is set by stream error handler so only destroy stream if source threw\n if (!error) {\n writable.destroy()\n }\n\n // could we be obscuring an error here?\n error = err\n }\n\n try {\n // We're done writing, end everything (n.b. stream may be destroyed at this point but then this is a no-op)\n if (writable.writable) {\n writable.end()\n }\n\n // Wait until we close or finish. This supports halfClosed streams\n await waitForDone()\n\n // Notify the user an error occurred\n if (error) throw error\n } finally {\n // Clean up listeners\n cleanup()\n }\n}\n","const toDuplex = require('./duplex')\n\nmodule.exports = transform => async function * (source) {\n const duplex = toDuplex(transform)\n // In a transform the sink and source are connected, an error in the sink\n // will be thrown in the source also. Catch the sink error to avoid unhandled\n // rejections and yield from the source.\n let sinkError\n duplex.sink(source).catch(err => { sinkError = err })\n\n yield * duplex.source\n if (sinkError) throw sinkError\n}\n","const toSink = require('./sink')\nconst toSource = require('./source')\n\nmodule.exports = duplex => ({ sink: toSink(duplex), source: toSource(duplex) })\n","'use strict'\n\nconst { Multiaddr } = require('multiaddr')\n\nfunction cleanUrlSIO (ma) {\n const maStrSplit = ma.toString().split('/')\n const tcpProto = ma.protos()[1].name\n const wsProto = ma.protos()[2].name\n const tcpPort = ma.stringTuples()[1][1]\n\n if (tcpProto !== 'tcp' || (wsProto !== 'ws' && wsProto !== 'wss')) {\n throw new Error('invalid multiaddr: ' + ma.toString())\n }\n\n if (!Multiaddr.isName(ma)) {\n return 'http://' + maStrSplit[2] + ':' + maStrSplit[4]\n }\n\n if (wsProto === 'ws') {\n return 'http://' + maStrSplit[2] + (tcpPort === '80' ? '' : ':' + tcpPort)\n }\n\n if (wsProto === 'wss') {\n return 'https://' + maStrSplit[2] + (tcpPort === '443' ? '' : ':' + tcpPort)\n }\n}\n\nfunction cleanMultiaddr (maStr) {\n const legacy = '/libp2p-webrtc-star'\n\n if (maStr.indexOf(legacy) !== -1) {\n maStr = maStr.substring(legacy.length, maStr.length)\n let ma = new Multiaddr(maStr)\n const tuppleIPFS = ma.stringTuples().filter((tupple) => {\n return tupple[0] === 421 // ipfs code\n })[0]\n\n ma = ma.decapsulate('p2p')\n ma = ma.encapsulate('/p2p-webrtc-star')\n ma = ma.encapsulate(`/p2p/${tuppleIPFS[1]}`)\n maStr = ma.toString()\n }\n\n return maStr\n}\n\nmodule.exports = {\n cleanUrlSIO,\n cleanMultiaddr\n}\n","'use strict'\n\nmodule.exports = require('./mplex')\n","'use strict'\n\nconst pipe = require('it-pipe')\nconst pushable = require('it-pushable')\nconst log = require('debug')('libp2p:mplex')\nconst abortable = require('abortable-iterator')\nconst Coder = require('./coder')\nconst restrictSize = require('./restrict-size')\nconst { MessageTypes, MessageTypeNames } = require('./message-types')\nconst createStream = require('./stream')\n\nclass Mplex {\n /**\n * @class\n * @param {object} options\n * @param {function(*)} options.onStream - Called whenever an inbound stream is created\n * @param {function(*)} options.onStreamEnd - Called whenever a stream ends\n * @param {AbortSignal} options.signal - An AbortController signal\n */\n constructor (options) {\n options = options || {}\n options = typeof options === 'function' ? { onStream: options } : options\n\n this._streamId = 0\n this._streams = {\n /**\n * @type {Map} Stream to ids map\n */\n initiators: new Map(),\n /**\n * @type {Map} Stream to ids map\n */\n receivers: new Map()\n }\n this._options = options\n\n /**\n * An iterable sink\n */\n this.sink = this._createSink()\n\n /**\n * An iterable source\n */\n this.source = this._createSource()\n\n /**\n * @property {Function} onStream\n */\n this.onStream = options.onStream\n\n /**\n * @property {Function} onStreamEnd\n */\n this.onStreamEnd = options.onStreamEnd\n }\n\n /**\n * Returns a Map of streams and their ids\n *\n * @returns {Map}\n */\n get streams () {\n // Inbound and Outbound streams may have the same ids, so we need to make those unique\n const streams = []\n this._streams.initiators.forEach(stream => {\n streams.push(stream)\n })\n this._streams.receivers.forEach(stream => {\n streams.push(stream)\n })\n return streams\n }\n\n /**\n * Initiate a new stream with the given name. If no name is\n * provided, the id of th stream will be used.\n *\n * @param {string} [name] - If name is not a string it will be cast to one\n * @returns {Stream}\n */\n newStream (name) {\n const id = this._streamId++\n name = name == null ? id.toString() : String(name)\n const registry = this._streams.initiators\n return this._newStream({ id, name, type: 'initiator', registry })\n }\n\n /**\n * Called whenever an inbound stream is created\n *\n * @private\n * @param {*} options\n * @param {number} options.id\n * @param {string} options.name\n * @returns {*} A muxed stream\n */\n _newReceiverStream ({ id, name }) {\n const registry = this._streams.receivers\n return this._newStream({ id, name, type: 'receiver', registry })\n }\n\n /**\n * Creates a new stream\n *\n * @private\n * @param {object} options\n * @param {number} options.id\n * @param {string} options.name\n * @param {string} options.type\n * @param {Map} options.registry - A map of streams to their ids\n * @returns {*} A muxed stream\n */\n _newStream ({ id, name, type, registry }) {\n if (registry.has(id)) {\n throw new Error(`${type} stream ${id} already exists!`)\n }\n log('new %s stream %s %s', type, id, name)\n const send = msg => {\n if (log.enabled) {\n log('%s stream %s %s send', type, id, name, { ...msg, type: MessageTypeNames[msg.type], data: msg.data && msg.data.slice() })\n }\n return this.source.push(msg)\n }\n const onEnd = () => {\n log('%s stream %s %s ended', type, id, name)\n registry.delete(id)\n this.onStreamEnd && this.onStreamEnd(stream)\n }\n const stream = createStream({ id, name, send, type, onEnd, maxMsgSize: this._options.maxMsgSize })\n registry.set(id, stream)\n return stream\n }\n\n /**\n * Creates a sink with an abortable source. Incoming messages will\n * also have their size restricted. All messages will be varint decoded.\n *\n * @private\n * @returns {*} Returns an iterable sink\n */\n _createSink () {\n return async source => {\n if (this._options.signal) {\n source = abortable(source, this._options.signal)\n }\n\n try {\n await pipe(\n source,\n Coder.decode,\n restrictSize(this._options.maxMsgSize),\n async source => {\n for await (const msgs of source) {\n for (const msg of msgs) {\n this._handleIncoming(msg)\n }\n }\n }\n )\n } catch (err) {\n log('error in sink', err)\n return this.source.end(err) // End the source with an error\n }\n\n this.source.end()\n }\n }\n\n /**\n * Creates a source that restricts outgoing message sizes\n * and varint encodes them.\n *\n * @private\n * @returns {*} An iterable source\n */\n _createSource () {\n const onEnd = err => {\n const { initiators, receivers } = this._streams\n // Abort all the things!\n for (const s of initiators.values()) s.abort(err)\n for (const s of receivers.values()) s.abort(err)\n }\n const source = pushable({ onEnd, writev: true })\n return Object.assign(Coder.encode(source), {\n push: source.push,\n end: source.end,\n return: source.return\n })\n }\n\n /**\n * @private\n * @param {object} options\n * @param {number} options.id\n * @param {string} options.type\n * @param {Uint8Array|BufferList} options.data\n * @returns {void}\n */\n _handleIncoming ({ id, type, data }) {\n if (log.enabled) {\n log('incoming message', { id, type: MessageTypeNames[type], data: data.slice() })\n }\n\n // Create a new stream?\n if (type === MessageTypes.NEW_STREAM && this.onStream) {\n const stream = this._newReceiverStream({ id, name: data.toString() })\n return this.onStream(stream)\n }\n\n const list = type & 1 ? this._streams.initiators : this._streams.receivers\n const stream = list.get(id)\n\n if (!stream) return log('missing stream %s', id)\n\n switch (type) {\n case MessageTypes.MESSAGE_INITIATOR:\n case MessageTypes.MESSAGE_RECEIVER:\n stream.source.push(data)\n break\n case MessageTypes.CLOSE_INITIATOR:\n case MessageTypes.CLOSE_RECEIVER:\n stream.close()\n break\n case MessageTypes.RESET_INITIATOR:\n case MessageTypes.RESET_RECEIVER:\n stream.reset()\n break\n default:\n log('unknown message type %s', type)\n }\n }\n}\n\nMplex.multicodec = '/mplex/6.7.0'\n\nmodule.exports = Mplex\n","'use strict'\n\nexports.encode = require('./encode')\nexports.decode = require('./decode')\n","'use strict'\n\nconst varint = require('varint')\nconst BufferList = require('bl/BufferList')\n\nconst POOL_SIZE = 10 * 1024\n\nclass Encoder {\n constructor () {\n this._pool = new Uint8Array(POOL_SIZE)\n this._poolOffset = 0\n }\n\n /**\n * Encodes the given message and returns it and its header\n *\n * @param {*} msg - The message object to encode\n * @returns {Uint8Array|Uint8Array[]}\n */\n write (msg) {\n const pool = this._pool\n let offset = this._poolOffset\n\n varint.encode(msg.id << 3 | msg.type, pool, offset)\n offset += varint.encode.bytes\n varint.encode(msg.data ? msg.data.length : 0, pool, offset)\n offset += varint.encode.bytes\n\n const header = pool.subarray(this._poolOffset, offset)\n\n if (POOL_SIZE - offset < 100) {\n this._pool = new Uint8Array(POOL_SIZE)\n this._poolOffset = 0\n } else {\n this._poolOffset = offset\n }\n\n if (!msg.data) return header\n\n return [header, msg.data]\n }\n}\n\nconst encoder = new Encoder()\n\n// Encode one or more messages and yield a BufferList of encoded messages\nmodule.exports = source => (async function * encode () {\n for await (const msg of source) {\n if (Array.isArray(msg)) {\n yield new BufferList(msg.map(m => encoder.write(m)))\n } else {\n yield new BufferList(encoder.write(msg))\n }\n }\n})()\n","'use strict'\n\nconst varint = require('varint')\nconst BufferList = require('bl/BufferList')\n\n// Decode a chunk and yield an _array_ of decoded messages\nmodule.exports = source => (async function * decode () {\n const decoder = new Decoder()\n for await (const chunk of source) {\n const msgs = decoder.write(chunk)\n if (msgs.length) yield msgs\n }\n})()\n\nclass Decoder {\n constructor () {\n this._buffer = new BufferList()\n // optimization to allow varint to take a BufferList (well a proxy to)\n this._bufferProxy = new Proxy({}, {\n get: (_, prop) => prop[0] === 'l' ? this._buffer[prop] : this._buffer.get(parseInt(prop))\n })\n this._headerInfo = null\n }\n\n /**\n * @param {Uint8Array|BufferList} chunk\n * @returns {object[]} An array of message objects\n */\n write (chunk) {\n if (!chunk || !chunk.length) return []\n\n this._buffer.append(chunk)\n const msgs = []\n\n while (true) {\n if (!this._headerInfo) {\n try {\n this._headerInfo = this._decodeHeader(this._bufferProxy)\n } catch (_) {\n break // We haven't received enough data yet\n }\n }\n\n const { id, type, length, offset } = this._headerInfo\n const bufferedDataLength = this._buffer.length - offset\n\n if (bufferedDataLength < length) break // not enough data yet\n\n msgs.push({ id, type, data: this._buffer.shallowSlice(offset, offset + length) })\n\n this._buffer.consume(offset + length)\n this._headerInfo = null\n }\n\n return msgs\n }\n\n /**\n * Attempts to decode the message header from the buffer\n *\n * @private\n * @param {Uint8Array} data\n * @returns {*} message header (id, type, offset, length)\n */\n _decodeHeader (data) {\n const h = varint.decode(data)\n let offset = varint.decode.bytes\n const length = varint.decode(data, offset)\n offset += varint.decode.bytes\n return { id: h >> 3, type: h & 7, offset, length }\n }\n}\n","'use strict'\n\nconst MAX_MSG_SIZE = 1 << 20 // 1MB\n\n/**\n * Creates an iterable transform that restricts message sizes to\n * the given maximum size.\n *\n * @param {number} [max] - The maximum message size. Defaults to 1MB\n * @returns {*} An iterable transform.\n */\nmodule.exports = max => {\n max = max || MAX_MSG_SIZE\n\n const checkSize = msg => {\n if (msg.data && msg.data.length > max) {\n throw Object.assign(new Error('message size too large!'), { code: 'ERR_MSG_TOO_BIG' })\n }\n }\n\n return source => {\n return (async function * restrictSize () {\n for await (const msg of source) {\n if (Array.isArray(msg)) {\n msg.forEach(checkSize)\n } else {\n checkSize(msg)\n }\n yield msg\n }\n })()\n }\n}\n\nmodule.exports.MAX_MSG_SIZE = MAX_MSG_SIZE\n","'use strict'\n\nconst MessageTypes = Object.freeze({\n NEW_STREAM: 0,\n MESSAGE_RECEIVER: 1,\n MESSAGE_INITIATOR: 2,\n CLOSE_RECEIVER: 3,\n CLOSE_INITIATOR: 4,\n RESET_RECEIVER: 5,\n RESET_INITIATOR: 6\n})\n\nexports.MessageTypes = MessageTypes\n\nexports.InitiatorMessageTypes = Object.freeze({\n NEW_STREAM: MessageTypes.NEW_STREAM,\n MESSAGE: MessageTypes.MESSAGE_INITIATOR,\n CLOSE: MessageTypes.CLOSE_INITIATOR,\n RESET: MessageTypes.RESET_INITIATOR\n})\n\nexports.ReceiverMessageTypes = Object.freeze({\n MESSAGE: MessageTypes.MESSAGE_RECEIVER,\n CLOSE: MessageTypes.CLOSE_RECEIVER,\n RESET: MessageTypes.RESET_RECEIVER\n})\n\nexports.MessageTypeNames = Object.freeze(\n Object.entries(MessageTypes).reduce((obj, e) => {\n obj[e[1]] = e[0]\n return obj\n }, {})\n)\n","'use strict'\n\nconst abortable = require('abortable-iterator')\nconst AbortController = require('abort-controller')\nconst log = require('debug')('libp2p:mplex:stream')\nconst pushable = require('it-pushable')\nconst BufferList = require('bl/BufferList')\nconst errCode = require('err-code')\nconst { MAX_MSG_SIZE } = require('./restrict-size')\nconst { InitiatorMessageTypes, ReceiverMessageTypes } = require('./message-types')\n\nconst ERR_MPLEX_STREAM_RESET = 'ERR_MPLEX_STREAM_RESET'\nconst ERR_MPLEX_STREAM_ABORT = 'ERR_MPLEX_STREAM_ABORT'\n\n/**\n * @param {object} options\n * @param {number} options.id\n * @param {string} options.name\n * @param {function(*)} options.send - Called to send data through the stream\n * @param {function(Error)} [options.onEnd] - Called whenever the stream ends\n * @param {string} [options.type] - One of ['initiator','receiver']. Defaults to 'initiator'\n * @param {number} [options.maxMsgSize] - Max size of an mplex message in bytes. Writes > size are automatically split. Defaults to 1MB\n * @returns {*} A muxed stream\n */\nmodule.exports = ({ id, name, send, onEnd = () => {}, type = 'initiator', maxMsgSize = MAX_MSG_SIZE }) => {\n const abortController = new AbortController()\n const resetController = new AbortController()\n const Types = type === 'initiator' ? InitiatorMessageTypes : ReceiverMessageTypes\n const externalId = type === 'initiator' ? (`i${id}`) : `r${id}`\n\n name = String(name == null ? id : name)\n\n let sourceEnded = false\n let sinkEnded = false\n let endErr\n\n const onSourceEnd = err => {\n if (sourceEnded) return\n sourceEnded = true\n log('%s stream %s source end', type, name, err)\n if (err && !endErr) endErr = err\n if (sinkEnded) {\n stream.timeline.close = Date.now()\n onEnd(endErr)\n }\n }\n\n const onSinkEnd = err => {\n if (sinkEnded) return\n sinkEnded = true\n log('%s stream %s sink end', type, name, err)\n if (err && !endErr) endErr = err\n if (sourceEnded) {\n stream.timeline.close = Date.now()\n onEnd(endErr)\n }\n }\n\n const stream = {\n // Close for reading\n close: () => stream.source.end(),\n // Close for reading and writing (local error)\n abort: err => {\n log('%s stream %s abort', type, name, err)\n // End the source with the passed error\n stream.source.end(err)\n abortController.abort()\n onSinkEnd(err)\n },\n // Close immediately for reading and writing (remote error)\n reset: () => {\n const err = errCode(new Error('stream reset'), ERR_MPLEX_STREAM_RESET)\n resetController.abort()\n stream.source.end(err)\n onSinkEnd(err)\n },\n sink: async source => {\n source = abortable(source, [\n { signal: abortController.signal, options: { abortMessage: 'stream aborted', abortCode: ERR_MPLEX_STREAM_ABORT } },\n { signal: resetController.signal, options: { abortMessage: 'stream reset', abortCode: ERR_MPLEX_STREAM_RESET } }\n ])\n\n if (type === 'initiator') { // If initiator, open a new stream\n send({ id, type: Types.NEW_STREAM, data: name })\n }\n\n try {\n for await (let data of source) {\n while (data.length) {\n if (data.length <= maxMsgSize) {\n send({ id, type: Types.MESSAGE, data })\n break\n }\n data = BufferList.isBufferList(data) ? data : new BufferList(data)\n send({ id, type: Types.MESSAGE, data: data.shallowSlice(0, maxMsgSize) })\n data.consume(maxMsgSize)\n }\n }\n } catch (err) {\n // Send no more data if this stream was remotely reset\n if (err.code === ERR_MPLEX_STREAM_RESET) {\n log('%s stream %s reset', type, name)\n } else {\n log('%s stream %s error', type, name, err)\n send({ id, type: Types.RESET })\n }\n\n stream.source.end(err)\n return onSinkEnd(err)\n }\n\n send({ id, type: Types.CLOSE })\n onSinkEnd()\n },\n source: pushable(onSourceEnd),\n timeline: {\n open: Date.now(),\n close: null\n },\n id: externalId\n }\n\n return stream\n}\n","import { Noise } from './noise'\nexport * from './noise'\n\n/**\n * Default configuration, it will generate new noise static key and enable noise pipes (IK handshake).\n */\nexport const NOISE = new Noise()\n","import * as x25519 from '@stablelib/x25519'\nimport { Buffer } from 'buffer'\nimport Wrap from 'it-pb-rpc'\nimport DuplexPair from 'it-pair/duplex'\nimport ensureBuffer from 'it-buffer'\nimport pipe from 'it-pipe'\nimport { encode, decode } from 'it-length-prefixed'\n\nimport { XXHandshake } from './handshake-xx'\nimport { IKHandshake } from './handshake-ik'\nimport { XXFallbackHandshake } from './handshake-xx-fallback'\nimport { generateKeypair, getPayload } from './utils'\nimport { uint16BEDecode, uint16BEEncode } from './encoder'\nimport { decryptStream, encryptStream } from './crypto'\nimport { bytes } from './@types/basic'\nimport { INoiseConnection, KeyPair, SecureOutbound } from './@types/libp2p'\nimport { Duplex } from 'it-pair'\nimport { IHandshake } from './@types/handshake-interface'\nimport { KeyCache } from './keycache'\nimport { logger } from './logger'\nimport PeerId from 'peer-id'\nimport { NOISE_MSG_MAX_LENGTH_BYTES } from './constants'\n\nexport type WrappedConnection = ReturnType\n\ninterface HandshakeParams {\n connection: WrappedConnection\n isInitiator: boolean\n localPeer: PeerId\n remotePeer?: PeerId\n}\n\nexport class Noise implements INoiseConnection {\n public protocol = '/noise'\n\n private readonly prologue = Buffer.alloc(0)\n private readonly staticKeys: KeyPair\n private readonly earlyData?: bytes\n private readonly useNoisePipes: boolean\n\n /**\n *\n * @param {bytes} staticNoiseKey - x25519 private key, reuse for faster handshakes\n * @param {bytes} earlyData\n */\n constructor (staticNoiseKey?: bytes, earlyData?: bytes) {\n this.earlyData = earlyData ?? Buffer.alloc(0)\n // disabled until properly specked\n this.useNoisePipes = false\n\n if (staticNoiseKey) {\n // accepts x25519 private key of length 32\n const keyPair = x25519.generateKeyPairFromSeed(staticNoiseKey)\n this.staticKeys = {\n privateKey: Buffer.from(\n keyPair.secretKey.buffer,\n keyPair.secretKey.byteOffset,\n keyPair.secretKey.length\n ),\n publicKey: Buffer.from(\n keyPair.publicKey.buffer,\n keyPair.publicKey.byteOffset,\n keyPair.publicKey.length\n )\n }\n } else {\n this.staticKeys = generateKeypair()\n }\n }\n\n /**\n * Encrypt outgoing data to the remote party (handshake as initiator)\n *\n * @param {PeerId} localPeer - PeerId of the receiving peer\n * @param {any} connection - streaming iterable duplex that will be encrypted\n * @param {PeerId} remotePeer - PeerId of the remote peer. Used to validate the integrity of the remote peer.\n * @returns {Promise}\n */\n public async secureOutbound (localPeer: PeerId, connection: any, remotePeer: PeerId): Promise {\n const wrappedConnection = Wrap(\n connection,\n {\n lengthEncoder: uint16BEEncode,\n lengthDecoder: uint16BEDecode,\n maxDataLength: NOISE_MSG_MAX_LENGTH_BYTES\n }\n )\n const handshake = await this.performHandshake({\n connection: wrappedConnection,\n isInitiator: true,\n localPeer,\n remotePeer\n })\n const conn = await this.createSecureConnection(wrappedConnection, handshake)\n\n return {\n conn,\n remoteEarlyData: handshake.remoteEarlyData,\n remotePeer: handshake.remotePeer\n }\n }\n\n /**\n * Decrypt incoming data (handshake as responder).\n *\n * @param {PeerId} localPeer - PeerId of the receiving peer.\n * @param {any} connection - streaming iterable duplex that will be encryption.\n * @param {PeerId} remotePeer - optional PeerId of the initiating peer, if known. This may only exist during transport upgrades.\n * @returns {Promise}\n */\n public async secureInbound (localPeer: PeerId, connection: any, remotePeer?: PeerId): Promise {\n const wrappedConnection = Wrap(\n connection,\n {\n lengthEncoder: uint16BEEncode,\n lengthDecoder: uint16BEDecode,\n maxDataLength: NOISE_MSG_MAX_LENGTH_BYTES\n }\n )\n const handshake = await this.performHandshake({\n connection: wrappedConnection,\n isInitiator: false,\n localPeer,\n remotePeer\n })\n const conn = await this.createSecureConnection(wrappedConnection, handshake)\n\n return {\n conn,\n remoteEarlyData: handshake.remoteEarlyData,\n remotePeer: handshake.remotePeer\n }\n }\n\n /**\n * If Noise pipes supported, tries IK handshake first with XX as fallback if it fails.\n * If noise pipes disabled or remote peer static key is unknown, use XX.\n *\n * @param {HandshakeParams} params\n */\n private async performHandshake (params: HandshakeParams): Promise {\n const payload = await getPayload(params.localPeer, this.staticKeys.publicKey, this.earlyData)\n let tryIK = this.useNoisePipes\n if (params.isInitiator && KeyCache.load(params.remotePeer) === null) {\n // if we are initiator and remote static key is unknown, don't try IK\n tryIK = false\n }\n // Try IK if acting as responder or initiator that has remote's static key.\n if (tryIK) {\n // Try IK first\n const { remotePeer, connection, isInitiator } = params\n const ikHandshake = new IKHandshake(\n isInitiator,\n payload,\n this.prologue,\n this.staticKeys,\n connection,\n // safe to cast as we did checks\n KeyCache.load(params.remotePeer) ?? Buffer.alloc(32),\n remotePeer as PeerId\n )\n\n try {\n return await this.performIKHandshake(ikHandshake)\n } catch (e) {\n // IK failed, go to XX fallback\n let ephemeralKeys\n if (params.isInitiator) {\n ephemeralKeys = ikHandshake.getLocalEphemeralKeys()\n }\n return await this.performXXFallbackHandshake(params, payload, e.initialMsg, ephemeralKeys)\n }\n } else {\n // run XX handshake\n return await this.performXXHandshake(params, payload)\n }\n }\n\n private async performXXFallbackHandshake (\n params: HandshakeParams,\n payload: bytes,\n initialMsg: bytes,\n ephemeralKeys?: KeyPair\n ): Promise {\n const { isInitiator, remotePeer, connection } = params\n const handshake =\n new XXFallbackHandshake(isInitiator, payload, this.prologue, this.staticKeys, connection, initialMsg, remotePeer, ephemeralKeys)\n\n try {\n await handshake.propose()\n await handshake.exchange()\n await handshake.finish()\n } catch (e) {\n logger(e)\n const err = e as Error\n throw new Error(`Error occurred during XX Fallback handshake: ${err.message}`)\n }\n\n return handshake\n }\n\n private async performXXHandshake (\n params: HandshakeParams,\n payload: bytes\n ): Promise {\n const { isInitiator, remotePeer, connection } = params\n const handshake = new XXHandshake(isInitiator, payload, this.prologue, this.staticKeys, connection, remotePeer)\n\n try {\n await handshake.propose()\n await handshake.exchange()\n await handshake.finish()\n\n if (this.useNoisePipes && handshake.remotePeer) {\n KeyCache.store(handshake.remotePeer, handshake.getRemoteStaticKey())\n }\n } catch (e) {\n const err = e as Error\n throw new Error(`Error occurred during XX handshake: ${err.message}`)\n }\n\n return handshake\n }\n\n private async performIKHandshake (\n handshake: IKHandshake\n ): Promise {\n await handshake.stage0()\n await handshake.stage1()\n\n return handshake\n }\n\n private async createSecureConnection (\n connection: WrappedConnection,\n handshake: IHandshake\n ): Promise {\n // Create encryption box/unbox wrapper\n const [secure, user] = DuplexPair()\n const network = connection.unwrap()\n\n await pipe(\n secure, // write to wrapper\n ensureBuffer, // ensure any type of data is converted to buffer\n encryptStream(handshake), // data is encrypted\n encode({ lengthEncoder: uint16BEEncode }), // prefix with message length\n network, // send to the remote peer\n decode({ lengthDecoder: uint16BEDecode }), // read message length prefix\n ensureBuffer, // ensure any type of data is converted to buffer\n decryptStream(handshake), // decrypt the incoming data\n secure // pipe to the wrapper\n )\n\n return user\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package x25519 implements X25519 key agreement.\n */\n\nimport { randomBytes, RandomSource } from \"@stablelib/random\";\nimport { wipe } from \"@stablelib/wipe\";\n\nexport const PUBLIC_KEY_LENGTH = 32;\nexport const SECRET_KEY_LENGTH = 32;\nexport const SHARED_KEY_LENGTH = 32;\n\n// TODO(dchest): some functions are copies of ../sign/ed25519.\n// Find a way to combine them without opening up to public.\n\n// Ported from TweetNaCl.js, which is ported from TweetNaCl\n// by Dmitry Chestnykh and Devi Mandiri.\n// Public domain.\n// https://tweetnacl.js.org\n\n// TweetNaCl contributors:\n// Daniel J. Bernstein, Bernard van Gastel, Wesley Janssen,\n// Tanja Lange, Peter Schwabe, Sjaak Smetsers.\n// Public domain.\n// https://tweetnacl.cr.yp.to/\n\ntype GF = Float64Array;\n\n// Returns new zero-filled 16-element GF (Float64Array).\n// If passed an array of numbers, prefills the returned\n// array with them.\n//\n// We use Float64Array, because we need 48-bit numbers\n// for this implementation.\nfunction gf(init?: number[]): GF {\n const r = new Float64Array(16);\n if (init) {\n for (let i = 0; i < init.length; i++) {\n r[i] = init[i];\n }\n }\n return r;\n}\n\n// Base point.\nconst _9 = new Uint8Array(32); _9[0] = 9;\n\nconst _121665 = gf([0xdb41, 1]);\n\nfunction car25519(o: GF) {\n let c = 1;\n for (let i = 0; i < 16; i++) {\n let v = o[i] + c + 65535;\n c = Math.floor(v / 65536);\n o[i] = v - c * 65536;\n }\n o[0] += c - 1 + 37 * (c - 1);\n}\n\nfunction sel25519(p: GF, q: GF, b: number) {\n const c = ~(b - 1);\n for (let i = 0; i < 16; i++) {\n const t = c & (p[i] ^ q[i]);\n p[i] ^= t;\n q[i] ^= t;\n }\n}\n\nfunction pack25519(o: Uint8Array, n: GF) {\n const m = gf();\n const t = gf();\n for (let i = 0; i < 16; i++) {\n t[i] = n[i];\n }\n car25519(t);\n car25519(t);\n car25519(t);\n for (let j = 0; j < 2; j++) {\n m[0] = t[0] - 0xffed;\n for (let i = 1; i < 15; i++) {\n m[i] = t[i] - 0xffff - ((m[i - 1] >> 16) & 1);\n m[i - 1] &= 0xffff;\n }\n m[15] = t[15] - 0x7fff - ((m[14] >> 16) & 1);\n const b = (m[15] >> 16) & 1;\n m[14] &= 0xffff;\n sel25519(t, m, 1 - b);\n }\n for (let i = 0; i < 16; i++) {\n o[2 * i] = t[i] & 0xff;\n o[2 * i + 1] = t[i] >> 8;\n }\n}\n\nfunction unpack25519(o: GF, n: Uint8Array) {\n for (let i = 0; i < 16; i++) {\n o[i] = n[2 * i] + (n[2 * i + 1] << 8);\n }\n o[15] &= 0x7fff;\n}\n\nfunction add(o: GF, a: GF, b: GF) {\n for (let i = 0; i < 16; i++) {\n o[i] = a[i] + b[i];\n }\n}\n\nfunction sub(o: GF, a: GF, b: GF) {\n for (let i = 0; i < 16; i++) {\n o[i] = a[i] - b[i];\n }\n}\n\nfunction mul(o: GF, a: GF, b: GF) {\n let v: number, c: number,\n t0 = 0, t1 = 0, t2 = 0, t3 = 0, t4 = 0, t5 = 0, t6 = 0, t7 = 0,\n t8 = 0, t9 = 0, t10 = 0, t11 = 0, t12 = 0, t13 = 0, t14 = 0, t15 = 0,\n t16 = 0, t17 = 0, t18 = 0, t19 = 0, t20 = 0, t21 = 0, t22 = 0, t23 = 0,\n t24 = 0, t25 = 0, t26 = 0, t27 = 0, t28 = 0, t29 = 0, t30 = 0,\n b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11],\n b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n\n v = a[0];\n t0 += v * b0;\n t1 += v * b1;\n t2 += v * b2;\n t3 += v * b3;\n t4 += v * b4;\n t5 += v * b5;\n t6 += v * b6;\n t7 += v * b7;\n t8 += v * b8;\n t9 += v * b9;\n t10 += v * b10;\n t11 += v * b11;\n t12 += v * b12;\n t13 += v * b13;\n t14 += v * b14;\n t15 += v * b15;\n v = a[1];\n t1 += v * b0;\n t2 += v * b1;\n t3 += v * b2;\n t4 += v * b3;\n t5 += v * b4;\n t6 += v * b5;\n t7 += v * b6;\n t8 += v * b7;\n t9 += v * b8;\n t10 += v * b9;\n t11 += v * b10;\n t12 += v * b11;\n t13 += v * b12;\n t14 += v * b13;\n t15 += v * b14;\n t16 += v * b15;\n v = a[2];\n t2 += v * b0;\n t3 += v * b1;\n t4 += v * b2;\n t5 += v * b3;\n t6 += v * b4;\n t7 += v * b5;\n t8 += v * b6;\n t9 += v * b7;\n t10 += v * b8;\n t11 += v * b9;\n t12 += v * b10;\n t13 += v * b11;\n t14 += v * b12;\n t15 += v * b13;\n t16 += v * b14;\n t17 += v * b15;\n v = a[3];\n t3 += v * b0;\n t4 += v * b1;\n t5 += v * b2;\n t6 += v * b3;\n t7 += v * b4;\n t8 += v * b5;\n t9 += v * b6;\n t10 += v * b7;\n t11 += v * b8;\n t12 += v * b9;\n t13 += v * b10;\n t14 += v * b11;\n t15 += v * b12;\n t16 += v * b13;\n t17 += v * b14;\n t18 += v * b15;\n v = a[4];\n t4 += v * b0;\n t5 += v * b1;\n t6 += v * b2;\n t7 += v * b3;\n t8 += v * b4;\n t9 += v * b5;\n t10 += v * b6;\n t11 += v * b7;\n t12 += v * b8;\n t13 += v * b9;\n t14 += v * b10;\n t15 += v * b11;\n t16 += v * b12;\n t17 += v * b13;\n t18 += v * b14;\n t19 += v * b15;\n v = a[5];\n t5 += v * b0;\n t6 += v * b1;\n t7 += v * b2;\n t8 += v * b3;\n t9 += v * b4;\n t10 += v * b5;\n t11 += v * b6;\n t12 += v * b7;\n t13 += v * b8;\n t14 += v * b9;\n t15 += v * b10;\n t16 += v * b11;\n t17 += v * b12;\n t18 += v * b13;\n t19 += v * b14;\n t20 += v * b15;\n v = a[6];\n t6 += v * b0;\n t7 += v * b1;\n t8 += v * b2;\n t9 += v * b3;\n t10 += v * b4;\n t11 += v * b5;\n t12 += v * b6;\n t13 += v * b7;\n t14 += v * b8;\n t15 += v * b9;\n t16 += v * b10;\n t17 += v * b11;\n t18 += v * b12;\n t19 += v * b13;\n t20 += v * b14;\n t21 += v * b15;\n v = a[7];\n t7 += v * b0;\n t8 += v * b1;\n t9 += v * b2;\n t10 += v * b3;\n t11 += v * b4;\n t12 += v * b5;\n t13 += v * b6;\n t14 += v * b7;\n t15 += v * b8;\n t16 += v * b9;\n t17 += v * b10;\n t18 += v * b11;\n t19 += v * b12;\n t20 += v * b13;\n t21 += v * b14;\n t22 += v * b15;\n v = a[8];\n t8 += v * b0;\n t9 += v * b1;\n t10 += v * b2;\n t11 += v * b3;\n t12 += v * b4;\n t13 += v * b5;\n t14 += v * b6;\n t15 += v * b7;\n t16 += v * b8;\n t17 += v * b9;\n t18 += v * b10;\n t19 += v * b11;\n t20 += v * b12;\n t21 += v * b13;\n t22 += v * b14;\n t23 += v * b15;\n v = a[9];\n t9 += v * b0;\n t10 += v * b1;\n t11 += v * b2;\n t12 += v * b3;\n t13 += v * b4;\n t14 += v * b5;\n t15 += v * b6;\n t16 += v * b7;\n t17 += v * b8;\n t18 += v * b9;\n t19 += v * b10;\n t20 += v * b11;\n t21 += v * b12;\n t22 += v * b13;\n t23 += v * b14;\n t24 += v * b15;\n v = a[10];\n t10 += v * b0;\n t11 += v * b1;\n t12 += v * b2;\n t13 += v * b3;\n t14 += v * b4;\n t15 += v * b5;\n t16 += v * b6;\n t17 += v * b7;\n t18 += v * b8;\n t19 += v * b9;\n t20 += v * b10;\n t21 += v * b11;\n t22 += v * b12;\n t23 += v * b13;\n t24 += v * b14;\n t25 += v * b15;\n v = a[11];\n t11 += v * b0;\n t12 += v * b1;\n t13 += v * b2;\n t14 += v * b3;\n t15 += v * b4;\n t16 += v * b5;\n t17 += v * b6;\n t18 += v * b7;\n t19 += v * b8;\n t20 += v * b9;\n t21 += v * b10;\n t22 += v * b11;\n t23 += v * b12;\n t24 += v * b13;\n t25 += v * b14;\n t26 += v * b15;\n v = a[12];\n t12 += v * b0;\n t13 += v * b1;\n t14 += v * b2;\n t15 += v * b3;\n t16 += v * b4;\n t17 += v * b5;\n t18 += v * b6;\n t19 += v * b7;\n t20 += v * b8;\n t21 += v * b9;\n t22 += v * b10;\n t23 += v * b11;\n t24 += v * b12;\n t25 += v * b13;\n t26 += v * b14;\n t27 += v * b15;\n v = a[13];\n t13 += v * b0;\n t14 += v * b1;\n t15 += v * b2;\n t16 += v * b3;\n t17 += v * b4;\n t18 += v * b5;\n t19 += v * b6;\n t20 += v * b7;\n t21 += v * b8;\n t22 += v * b9;\n t23 += v * b10;\n t24 += v * b11;\n t25 += v * b12;\n t26 += v * b13;\n t27 += v * b14;\n t28 += v * b15;\n v = a[14];\n t14 += v * b0;\n t15 += v * b1;\n t16 += v * b2;\n t17 += v * b3;\n t18 += v * b4;\n t19 += v * b5;\n t20 += v * b6;\n t21 += v * b7;\n t22 += v * b8;\n t23 += v * b9;\n t24 += v * b10;\n t25 += v * b11;\n t26 += v * b12;\n t27 += v * b13;\n t28 += v * b14;\n t29 += v * b15;\n v = a[15];\n t15 += v * b0;\n t16 += v * b1;\n t17 += v * b2;\n t18 += v * b3;\n t19 += v * b4;\n t20 += v * b5;\n t21 += v * b6;\n t22 += v * b7;\n t23 += v * b8;\n t24 += v * b9;\n t25 += v * b10;\n t26 += v * b11;\n t27 += v * b12;\n t28 += v * b13;\n t29 += v * b14;\n t30 += v * b15;\n\n t0 += 38 * t16;\n t1 += 38 * t17;\n t2 += 38 * t18;\n t3 += 38 * t19;\n t4 += 38 * t20;\n t5 += 38 * t21;\n t6 += 38 * t22;\n t7 += 38 * t23;\n t8 += 38 * t24;\n t9 += 38 * t25;\n t10 += 38 * t26;\n t11 += 38 * t27;\n t12 += 38 * t28;\n t13 += 38 * t29;\n t14 += 38 * t30;\n // t15 left as is\n\n // first car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c - 1 + 37 * (c - 1);\n\n // second car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c - 1 + 37 * (c - 1);\n\n o[0] = t0;\n o[1] = t1;\n o[2] = t2;\n o[3] = t3;\n o[4] = t4;\n o[5] = t5;\n o[6] = t6;\n o[7] = t7;\n o[8] = t8;\n o[9] = t9;\n o[10] = t10;\n o[11] = t11;\n o[12] = t12;\n o[13] = t13;\n o[14] = t14;\n o[15] = t15;\n}\n\nfunction square(o: GF, a: GF) {\n mul(o, a, a);\n}\n\nfunction inv25519(o: GF, inp: GF) {\n const c = gf();\n for (let i = 0; i < 16; i++) {\n c[i] = inp[i];\n }\n for (let i = 253; i >= 0; i--) {\n square(c, c);\n if (i !== 2 && i !== 4) {\n mul(c, c, inp);\n }\n }\n for (let i = 0; i < 16; i++) {\n o[i] = c[i];\n }\n}\n\nexport function scalarMult(n: Uint8Array, p: Uint8Array): Uint8Array {\n const z = new Uint8Array(32);\n const x = new Float64Array(80);\n const a = gf(), b = gf(), c = gf(),\n d = gf(), e = gf(), f = gf();\n\n for (let i = 0; i < 31; i++) {\n z[i] = n[i];\n }\n z[31] = (n[31] & 127) | 64;\n z[0] &= 248;\n\n unpack25519(x, p);\n\n for (let i = 0; i < 16; i++) {\n b[i] = x[i];\n }\n\n a[0] = d[0] = 1;\n\n for (let i = 254; i >= 0; --i) {\n const r = (z[i >>> 3] >>> (i & 7)) & 1;\n sel25519(a, b, r);\n sel25519(c, d, r);\n add(e, a, c);\n sub(a, a, c);\n add(c, b, d);\n sub(b, b, d);\n square(d, e);\n square(f, a);\n mul(a, c, a);\n mul(c, b, e);\n add(e, a, c);\n sub(a, a, c);\n square(b, a);\n sub(c, d, f);\n mul(a, c, _121665);\n add(a, a, d);\n mul(c, c, a);\n mul(a, d, f);\n mul(d, b, x);\n square(b, e);\n sel25519(a, b, r);\n sel25519(c, d, r);\n }\n for (let i = 0; i < 16; i++) {\n x[i + 16] = a[i];\n x[i + 32] = c[i];\n x[i + 48] = b[i];\n x[i + 64] = d[i];\n }\n const x32 = x.subarray(32);\n const x16 = x.subarray(16);\n inv25519(x32, x32);\n mul(x16, x16, x32);\n const q = new Uint8Array(32);\n pack25519(q, x16);\n return q;\n}\n\nexport function scalarMultBase(n: Uint8Array): Uint8Array {\n return scalarMult(n, _9);\n}\n\nexport interface KeyPair {\n publicKey: Uint8Array;\n secretKey: Uint8Array;\n}\n\nexport function generateKeyPairFromSeed(seed: Uint8Array): KeyPair {\n if (seed.length !== SECRET_KEY_LENGTH) {\n throw new Error(`x25519: seed must be ${SECRET_KEY_LENGTH} bytes`);\n }\n const secretKey = new Uint8Array(seed);\n const publicKey = scalarMultBase(secretKey);\n return {\n publicKey,\n secretKey\n };\n}\n\nexport function generateKeyPair(prng?: RandomSource): KeyPair {\n const seed = randomBytes(32, prng);\n const result = generateKeyPairFromSeed(seed);\n wipe(seed);\n return result;\n}\n\n/**\n * Returns a shared key between our secret key and a peer's public key.\n *\n * Throws an error if the given keys are of wrong length.\n *\n * If rejectZero is true throws if the calculated shared key is all-zero.\n * From RFC 7748:\n *\n * > Protocol designers using Diffie-Hellman over the curves defined in\n * > this document must not assume \"contributory behavior\". Specially,\n * > contributory behavior means that both parties' private keys\n * > contribute to the resulting shared key. Since curve25519 and\n * > curve448 have cofactors of 8 and 4 (respectively), an input point of\n * > small order will eliminate any contribution from the other party's\n * > private key. This situation can be detected by checking for the all-\n * > zero output, which implementations MAY do, as specified in Section 6.\n * > However, a large number of existing implementations do not do this.\n *\n * IMPORTANT: the returned key is a raw result of scalar multiplication.\n * To use it as a key material, hash it with a cryptographic hash function.\n */\nexport function sharedKey(mySecretKey: Uint8Array, theirPublicKey: Uint8Array, rejectZero = false): Uint8Array {\n if (mySecretKey.length !== PUBLIC_KEY_LENGTH) {\n throw new Error(\"X25519: incorrect secret key length\");\n }\n if (theirPublicKey.length !== PUBLIC_KEY_LENGTH) {\n throw new Error(\"X25519: incorrect public key length\");\n }\n\n const result = scalarMult(mySecretKey, theirPublicKey);\n\n if (rejectZero) {\n let zeros = 0;\n for (let i = 0; i < result.length; i++) {\n zeros |= result[i];\n }\n if (zeros === 0) {\n throw new Error(\"X25519: invalid shared key\");\n }\n }\n\n return result;\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package random provides functions to access system's\n * cryptographically secure random byte generator.\n */\n\nimport { RandomSource } from \"./source\";\nimport { SystemRandomSource } from \"./source/system\";\nimport { readUint32LE } from \"@stablelib/binary\";\nimport { wipe } from \"@stablelib/wipe\";\n\nexport { RandomSource } from \"./source\";\n\nexport const defaultRandomSource = new SystemRandomSource();\n\nexport function randomBytes(length: number, prng: RandomSource = defaultRandomSource): Uint8Array {\n return prng.randomBytes(length);\n}\n\n/**\n * Returns a uniformly random unsigned 32-bit integer.\n */\nexport function randomUint32(prng: RandomSource = defaultRandomSource): number {\n // Generate 4-byte random buffer.\n const buf = randomBytes(4, prng);\n\n // Convert bytes from buffer into a 32-bit integer.\n // It's not important which byte order to use, since\n // the result is random.\n const result = readUint32LE(buf);\n\n // Clean the buffer.\n wipe(buf);\n\n return result;\n}\n\n/** 62 alphanumeric characters for default charset of randomString() */\nconst ALPHANUMERIC = \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz\";\n\n/**\n * Returns a uniform random string of the given length\n * with characters from the given charset.\n *\n * Charset must not have more than 256 characters.\n *\n * Default charset generates case-sensitive alphanumeric\n * strings (0-9, A-Z, a-z).\n */\nexport function randomString(\n length: number,\n charset = ALPHANUMERIC,\n prng: RandomSource = defaultRandomSource\n): string {\n if (charset.length < 2) {\n throw new Error(\"randomString charset is too short\");\n }\n if (charset.length > 256) {\n throw new Error(\"randomString charset is too long\");\n }\n let out = '';\n const charsLen = charset.length;\n const maxByte = 256 - (256 % charsLen);\n while (length > 0) {\n const buf = randomBytes(Math.ceil(length * 256 / maxByte), prng);\n for (let i = 0; i < buf.length && length > 0; i++) {\n const randomByte = buf[i];\n if (randomByte < maxByte) {\n out += charset.charAt(randomByte % charsLen);\n length--;\n }\n }\n wipe(buf);\n }\n return out;\n}\n\n/**\n * Returns uniform random string containing at least the given\n * number of bits of entropy.\n *\n * For example, randomStringForEntropy(128) will return a 22-character\n * alphanumeric string, while randomStringForEntropy(128, \"0123456789\")\n * will return a 39-character numeric string, both will contain at\n * least 128 bits of entropy.\n *\n * Default charset generates case-sensitive alphanumeric\n * strings (0-9, A-Z, a-z).\n */\nexport function randomStringForEntropy(\n bits: number,\n charset = ALPHANUMERIC,\n prng: RandomSource = defaultRandomSource\n): string {\n const length = Math.ceil(bits / (Math.log(charset.length) / Math.LN2));\n return randomString(length, charset, prng);\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\nimport { RandomSource } from \"./\";\nimport { BrowserRandomSource } from \"./browser\";\nimport { NodeRandomSource } from \"./node\";\n\nexport class SystemRandomSource implements RandomSource {\n isAvailable = false;\n name = \"\";\n private _source: RandomSource;\n\n constructor() {\n // Try browser.\n this._source = new BrowserRandomSource();\n if (this._source.isAvailable) {\n this.isAvailable = true;\n this.name = \"Browser\";\n return;\n }\n\n // If no browser source, try Node.\n this._source = new NodeRandomSource();\n if (this._source.isAvailable) {\n this.isAvailable = true;\n this.name = \"Node\";\n return;\n }\n\n // No sources, we're out of options.\n }\n\n randomBytes(length: number): Uint8Array {\n if (!this.isAvailable) {\n throw new Error(\"System random byte generator is not available.\");\n }\n return this._source.randomBytes(length);\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\nimport { RandomSource } from \"./\";\n\nconst QUOTA = 65536;\n\nexport class BrowserRandomSource implements RandomSource {\n isAvailable = false;\n isInstantiated = false;\n\n private _crypto?: { getRandomValues: typeof window.crypto.getRandomValues };\n\n constructor() {\n const browserCrypto = typeof self !== 'undefined'\n ? (self.crypto || (self as { msCrypto?: any }).msCrypto) // IE11 has msCrypto\n : null;\n\n if (browserCrypto && browserCrypto.getRandomValues) {\n this._crypto = browserCrypto;\n this.isAvailable = true;\n this.isInstantiated = true;\n }\n }\n\n randomBytes(length: number): Uint8Array {\n if (!this.isAvailable || !this._crypto) {\n throw new Error(\"Browser random byte generator is not available.\");\n }\n const out = new Uint8Array(length);\n for (let i = 0; i < out.length; i += QUOTA) {\n this._crypto.getRandomValues(out.subarray(i, i + Math.min(out.length - i, QUOTA)));\n }\n return out;\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\nimport { RandomSource } from \"./\";\nimport { wipe } from \"@stablelib/wipe\";\n\ndeclare function require(name: string): any;\n\nexport class NodeRandomSource implements RandomSource {\n isAvailable = false;\n isInstantiated = false;\n\n private _crypto: { randomBytes(n: number): Uint8Array } | undefined;\n\n constructor() {\n if (typeof require !== \"undefined\") {\n const nodeCrypto = require(\"crypto\");\n if (nodeCrypto && nodeCrypto.randomBytes) {\n this._crypto = nodeCrypto;\n this.isAvailable = true;\n this.isInstantiated = true;\n }\n }\n }\n\n randomBytes(length: number): Uint8Array {\n if (!this.isAvailable || !this._crypto) {\n throw new Error(\"Node.js random byte generator is not available.\");\n }\n\n // Get random bytes (result is Buffer).\n let buffer = this._crypto.randomBytes(length);\n\n // Make sure we got the length that we requested.\n if (buffer.length !== length) {\n throw new Error(\"NodeRandomSource: got fewer bytes than requested\");\n }\n\n // Allocate output array.\n const out = new Uint8Array(length);\n\n // Copy bytes from buffer to output.\n for (let i = 0; i < out.length; i++) {\n out[i] = buffer[i];\n }\n\n // Cleanup.\n wipe(buffer);\n\n return out;\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package wipe implements functions for zeroing arrays.\n */\n\nexport type NumericArray = number[] | Uint8Array | Int8Array | Uint16Array\n | Int16Array | Uint32Array | Int32Array | Float32Array | Float64Array;\n\n/**\n * Sets all values in the given array to zero and returns it.\n *\n * The fact that it sets bytes to zero can be relied on.\n *\n * There is no guarantee that this function makes data disappear from memory,\n * as runtime implementation can, for example, have copying garbage collector\n * that will make copies of sensitive data before we wipe it. Or that an\n * operating system will write our data to swap or sleep image. Another thing\n * is that an optimizing compiler can remove calls to this function or make it\n * no-op. There's nothing we can do with it, so we just do our best and hope\n * that everything will be okay and good will triumph over evil.\n */\nexport function wipe(array: NumericArray): NumericArray {\n // Right now it's similar to array.fill(0). If it turns\n // out that runtimes optimize this call away, maybe\n // we can try something else.\n for (let i = 0; i < array.length; i++) {\n array[i] = 0;\n }\n return array;\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package binary provides functions for encoding and decoding numbers in byte arrays.\n */\n\nimport { isSafeInteger } from \"@stablelib/int\";\n\n// TODO(dchest): add asserts for correct value ranges and array offsets.\n\n/**\n * Reads 2 bytes from array starting at offset as big-endian\n * signed 16-bit integer and returns it.\n */\nexport function readInt16BE(array: Uint8Array, offset = 0): number {\n return (((array[offset + 0] << 8) | array[offset + 1]) << 16) >> 16;\n}\n\n/**\n * Reads 2 bytes from array starting at offset as big-endian\n * unsigned 16-bit integer and returns it.\n */\nexport function readUint16BE(array: Uint8Array, offset = 0): number {\n return ((array[offset + 0] << 8) | array[offset + 1]) >>> 0;\n}\n\n/**\n * Reads 2 bytes from array starting at offset as little-endian\n * signed 16-bit integer and returns it.\n */\nexport function readInt16LE(array: Uint8Array, offset = 0): number {\n return (((array[offset + 1] << 8) | array[offset]) << 16) >> 16;\n}\n\n/**\n * Reads 2 bytes from array starting at offset as little-endian\n * unsigned 16-bit integer and returns it.\n */\nexport function readUint16LE(array: Uint8Array, offset = 0): number {\n return ((array[offset + 1] << 8) | array[offset]) >>> 0;\n}\n\n/**\n * Writes 2-byte big-endian representation of 16-bit unsigned\n * value to byte array starting at offset.\n *\n * If byte array is not given, creates a new 2-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint16BE(value: number, out = new Uint8Array(2), offset = 0): Uint8Array {\n out[offset + 0] = value >>> 8;\n out[offset + 1] = value >>> 0;\n return out;\n}\n\nexport const writeInt16BE = writeUint16BE;\n\n/**\n * Writes 2-byte little-endian representation of 16-bit unsigned\n * value to array starting at offset.\n *\n * If byte array is not given, creates a new 2-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint16LE(value: number, out = new Uint8Array(2), offset = 0): Uint8Array {\n out[offset + 0] = value >>> 0;\n out[offset + 1] = value >>> 8;\n return out;\n}\n\nexport const writeInt16LE = writeUint16LE;\n\n/**\n * Reads 4 bytes from array starting at offset as big-endian\n * signed 32-bit integer and returns it.\n */\nexport function readInt32BE(array: Uint8Array, offset = 0): number {\n return (array[offset] << 24) |\n (array[offset + 1] << 16) |\n (array[offset + 2] << 8) |\n array[offset + 3];\n}\n\n/**\n * Reads 4 bytes from array starting at offset as big-endian\n * unsigned 32-bit integer and returns it.\n */\nexport function readUint32BE(array: Uint8Array, offset = 0): number {\n return ((array[offset] << 24) |\n (array[offset + 1] << 16) |\n (array[offset + 2] << 8) |\n array[offset + 3]) >>> 0;\n}\n\n/**\n * Reads 4 bytes from array starting at offset as little-endian\n * signed 32-bit integer and returns it.\n */\nexport function readInt32LE(array: Uint8Array, offset = 0): number {\n return (array[offset + 3] << 24) |\n (array[offset + 2] << 16) |\n (array[offset + 1] << 8) |\n array[offset];\n}\n\n/**\n * Reads 4 bytes from array starting at offset as little-endian\n * unsigned 32-bit integer and returns it.\n */\nexport function readUint32LE(array: Uint8Array, offset = 0): number {\n return ((array[offset + 3] << 24) |\n (array[offset + 2] << 16) |\n (array[offset + 1] << 8) |\n array[offset]) >>> 0;\n}\n\n/**\n * Writes 4-byte big-endian representation of 32-bit unsigned\n * value to byte array starting at offset.\n *\n * If byte array is not given, creates a new 4-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint32BE(value: number, out = new Uint8Array(4), offset = 0): Uint8Array {\n out[offset + 0] = value >>> 24;\n out[offset + 1] = value >>> 16;\n out[offset + 2] = value >>> 8;\n out[offset + 3] = value >>> 0;\n return out;\n}\n\nexport const writeInt32BE = writeUint32BE;\n\n/**\n * Writes 4-byte little-endian representation of 32-bit unsigned\n * value to array starting at offset.\n *\n * If byte array is not given, creates a new 4-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint32LE(value: number, out = new Uint8Array(4), offset = 0): Uint8Array {\n out[offset + 0] = value >>> 0;\n out[offset + 1] = value >>> 8;\n out[offset + 2] = value >>> 16;\n out[offset + 3] = value >>> 24;\n return out;\n}\n\n\nexport const writeInt32LE = writeUint32LE;\n\n/**\n * Reads 8 bytes from array starting at offset as big-endian\n * signed 64-bit integer and returns it.\n *\n * IMPORTANT: due to JavaScript limitation, supports exact\n * numbers in range -9007199254740991 to 9007199254740991.\n * If the number stored in the byte array is outside this range,\n * the result is not exact.\n */\nexport function readInt64BE(array: Uint8Array, offset = 0): number {\n const hi = readInt32BE(array, offset);\n const lo = readInt32BE(array, offset + 4);\n return hi * 0x100000000 + lo - ((lo>>31) * 0x100000000);\n}\n\n/**\n * Reads 8 bytes from array starting at offset as big-endian\n * unsigned 64-bit integer and returns it.\n *\n * IMPORTANT: due to JavaScript limitation, supports values up to 2^53-1.\n */\nexport function readUint64BE(array: Uint8Array, offset = 0): number {\n const hi = readUint32BE(array, offset);\n const lo = readUint32BE(array, offset + 4);\n return hi * 0x100000000 + lo;\n}\n\n/**\n * Reads 8 bytes from array starting at offset as little-endian\n * signed 64-bit integer and returns it.\n *\n * IMPORTANT: due to JavaScript limitation, supports exact\n * numbers in range -9007199254740991 to 9007199254740991.\n * If the number stored in the byte array is outside this range,\n * the result is not exact.\n */\nexport function readInt64LE(array: Uint8Array, offset = 0): number {\n const lo = readInt32LE(array, offset);\n const hi = readInt32LE(array, offset + 4);\n return hi * 0x100000000 + lo - ((lo>>31) * 0x100000000);\n}\n\n\n/**\n * Reads 8 bytes from array starting at offset as little-endian\n * unsigned 64-bit integer and returns it.\n *\n * IMPORTANT: due to JavaScript limitation, supports values up to 2^53-1.\n */\nexport function readUint64LE(array: Uint8Array, offset = 0): number {\n const lo = readUint32LE(array, offset);\n const hi = readUint32LE(array, offset + 4);\n return hi * 0x100000000 + lo;\n}\n\n/**\n * Writes 8-byte big-endian representation of 64-bit unsigned\n * value to byte array starting at offset.\n *\n * Due to JavaScript limitation, supports values up to 2^53-1.\n *\n * If byte array is not given, creates a new 8-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint64BE(value: number, out = new Uint8Array(8), offset = 0): Uint8Array {\n writeUint32BE(value / 0x100000000 >>> 0, out, offset);\n writeUint32BE(value >>> 0, out, offset + 4);\n return out;\n}\n\nexport const writeInt64BE = writeUint64BE;\n\n/**\n * Writes 8-byte little-endian representation of 64-bit unsigned\n * value to byte array starting at offset.\n *\n * Due to JavaScript limitation, supports values up to 2^53-1.\n *\n * If byte array is not given, creates a new 8-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint64LE(value: number, out = new Uint8Array(8), offset = 0): Uint8Array {\n writeUint32LE(value >>> 0, out, offset);\n writeUint32LE(value / 0x100000000 >>> 0, out, offset + 4);\n return out;\n}\n\nexport const writeInt64LE = writeUint64LE;\n\n/**\n * Reads bytes from array starting at offset as big-endian\n * unsigned bitLen-bit integer and returns it.\n *\n * Supports bit lengths divisible by 8, up to 48.\n */\nexport function readUintBE(bitLength: number, array: Uint8Array, offset = 0): number {\n // TODO(dchest): implement support for bitLengths non-divisible by 8\n if (bitLength % 8 !== 0) {\n throw new Error(\"readUintBE supports only bitLengths divisible by 8\");\n }\n if (bitLength / 8 > array.length - offset) {\n throw new Error(\"readUintBE: array is too short for the given bitLength\");\n }\n let result = 0;\n let mul = 1;\n for (let i = bitLength / 8 + offset - 1; i >= offset; i--) {\n result += array[i] * mul;\n mul *= 256;\n }\n return result;\n}\n\n/**\n * Reads bytes from array starting at offset as little-endian\n * unsigned bitLen-bit integer and returns it.\n *\n * Supports bit lengths divisible by 8, up to 48.\n */\nexport function readUintLE(bitLength: number, array: Uint8Array, offset = 0): number {\n // TODO(dchest): implement support for bitLengths non-divisible by 8\n if (bitLength % 8 !== 0) {\n throw new Error(\"readUintLE supports only bitLengths divisible by 8\");\n }\n if (bitLength / 8 > array.length - offset) {\n throw new Error(\"readUintLE: array is too short for the given bitLength\");\n }\n let result = 0;\n let mul = 1;\n for (let i = offset; i < offset + bitLength / 8; i++) {\n result += array[i] * mul;\n mul *= 256;\n }\n return result;\n}\n\n/**\n * Writes a big-endian representation of bitLen-bit unsigned\n * value to array starting at offset.\n *\n * Supports bit lengths divisible by 8, up to 48.\n *\n * If byte array is not given, creates a new one.\n *\n * Returns the output byte array.\n */\nexport function writeUintBE(bitLength: number, value: number,\n out = new Uint8Array(bitLength / 8), offset = 0): Uint8Array {\n // TODO(dchest): implement support for bitLengths non-divisible by 8\n if (bitLength % 8 !== 0) {\n throw new Error(\"writeUintBE supports only bitLengths divisible by 8\");\n }\n if (!isSafeInteger(value)) {\n throw new Error(\"writeUintBE value must be an integer\");\n }\n let div = 1;\n for (let i = bitLength / 8 + offset - 1; i >= offset; i--) {\n out[i] = (value / div) & 0xff;\n div *= 256;\n }\n return out;\n}\n\n/**\n * Writes a little-endian representation of bitLen-bit unsigned\n * value to array starting at offset.\n *\n * Supports bit lengths divisible by 8, up to 48.\n *\n * If byte array is not given, creates a new one.\n *\n * Returns the output byte array.\n */\nexport function writeUintLE(bitLength: number, value: number,\n out = new Uint8Array(bitLength / 8), offset = 0): Uint8Array {\n // TODO(dchest): implement support for bitLengths non-divisible by 8\n if (bitLength % 8 !== 0) {\n throw new Error(\"writeUintLE supports only bitLengths divisible by 8\");\n }\n if (!isSafeInteger(value)) {\n throw new Error(\"writeUintLE value must be an integer\");\n }\n let div = 1;\n for (let i = offset; i < offset + bitLength / 8; i++) {\n out[i] = (value / div) & 0xff;\n div *= 256;\n }\n return out;\n}\n\n/**\n * Reads 4 bytes from array starting at offset as big-endian\n * 32-bit floating-point number and returns it.\n */\nexport function readFloat32BE(array: Uint8Array, offset = 0): number {\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat32(offset);\n}\n\n/**\n * Reads 4 bytes from array starting at offset as little-endian\n * 32-bit floating-point number and returns it.\n */\nexport function readFloat32LE(array: Uint8Array, offset = 0): number {\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat32(offset, true);\n}\n\n/**\n * Reads 8 bytes from array starting at offset as big-endian\n * 64-bit floating-point number (\"double\") and returns it.\n */\nexport function readFloat64BE(array: Uint8Array, offset = 0): number {\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat64(offset);\n}\n\n/**\n * Reads 8 bytes from array starting at offset as little-endian\n * 64-bit floating-point number (\"double\") and returns it.\n */\nexport function readFloat64LE(array: Uint8Array, offset = 0): number {\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat64(offset, true);\n}\n\n/**\n * Writes 4-byte big-endian floating-point representation of value\n * to byte array starting at offset.\n *\n * If byte array is not given, creates a new 4-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeFloat32BE(value: number, out = new Uint8Array(4), offset = 0): Uint8Array {\n const view = new DataView(out.buffer, out.byteOffset, out.byteLength);\n view.setFloat32(offset, value);\n return out;\n}\n\n/**\n * Writes 4-byte little-endian floating-point representation of value\n * to byte array starting at offset.\n *\n * If byte array is not given, creates a new 4-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeFloat32LE(value: number, out = new Uint8Array(4), offset = 0): Uint8Array {\n const view = new DataView(out.buffer, out.byteOffset, out.byteLength);\n view.setFloat32(offset, value, true);\n return out;\n}\n\n/**\n * Writes 8-byte big-endian floating-point representation of value\n * to byte array starting at offset.\n *\n * If byte array is not given, creates a new 8-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeFloat64BE(value: number, out = new Uint8Array(8), offset = 0): Uint8Array {\n const view = new DataView(out.buffer, out.byteOffset, out.byteLength);\n view.setFloat64(offset, value);\n return out;\n}\n\n/**\n * Writes 8-byte little-endian floating-point representation of value\n * to byte array starting at offset.\n *\n * If byte array is not given, creates a new 8-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeFloat64LE(value: number, out = new Uint8Array(8), offset = 0): Uint8Array {\n const view = new DataView(out.buffer, out.byteOffset, out.byteLength);\n view.setFloat64(offset, value, true);\n return out;\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package int provides helper functions for integerss.\n */\n\n// Shim using 16-bit pieces.\nfunction imulShim(a: number, b: number): number {\n const ah = (a >>> 16) & 0xffff, al = a & 0xffff;\n const bh = (b >>> 16) & 0xffff, bl = b & 0xffff;\n return ((al * bl) + (((ah * bl + al * bh) << 16) >>> 0) | 0);\n}\n\n/** 32-bit integer multiplication. */\n// Use system Math.imul if available, otherwise use our shim.\nexport const mul = (Math as { imul?(a: number, b: number): number }).imul || imulShim;\n\n/** 32-bit integer addition. */\nexport function add(a: number, b: number): number {\n return (a + b) | 0;\n}\n\n/** 32-bit integer subtraction. */\nexport function sub(a: number, b: number): number {\n return (a - b) | 0;\n}\n\n/** 32-bit integer left rotation */\nexport function rotl(x: number, n: number): number {\n return x << n | x >>> (32 - n);\n}\n\n/** 32-bit integer left rotation */\nexport function rotr(x: number, n: number): number {\n return x << (32 - n) | x >>> n;\n}\n\nfunction isIntegerShim(n: number): boolean {\n return typeof n === \"number\" && isFinite(n) && Math.floor(n) === n;\n}\n\n/**\n * Returns true if the argument is an integer number.\n *\n * In ES2015, Number.isInteger.\n */\nexport const isInteger = (Number as { isInteger?(n: number): boolean }).isInteger || isIntegerShim;\n\n/**\n * Math.pow(2, 53) - 1\n *\n * In ES2015 Number.MAX_SAFE_INTEGER.\n */\nexport const MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Returns true if the argument is a safe integer number\n * (-MIN_SAFE_INTEGER < number <= MAX_SAFE_INTEGER)\n *\n * In ES2015, Number.isSafeInteger.\n */\nexport const isSafeInteger = (n: number): boolean =>\n isInteger(n) && (n >= -MAX_SAFE_INTEGER && n <= MAX_SAFE_INTEGER);\n","'use strict'\n\nconst isBuffer = require('is-buffer')\nconst Shake = require('it-handshake')\nconst lp = require('it-length-prefixed')\n\nmodule.exports = (duplex, opts = {}) => {\n const shake = Shake(duplex)\n const lpReader = lp.decode.fromReader(\n shake.reader,\n opts\n )\n\n let isDone = false\n\n const W = {\n read: async (bytes) => {\n // just read\n\n const { value, done } = await shake.reader.next(bytes)\n\n if (done && value.length < bytes) {\n throw new Error('Couldn\\'t read enough bytes')\n }\n\n isDone = done\n\n if (!value) { throw new Error('Value is null') }\n return value\n },\n readLP: async () => {\n // read, decode\n const { value, done } = await lpReader.next()\n\n isDone = done\n\n if (!value) { throw new Error('Value is null') }\n return value\n },\n readPB: async (proto) => {\n // readLP, decode\n const value = await W.readLP()\n\n if (!value) { throw new Error('Value is null') }\n\n // Is this a buffer?\n const buf = isBuffer(value) ? value : value.slice()\n\n return proto.decode(buf)\n },\n write: (data) => {\n // just write\n shake.writer.push(data)\n },\n writeLP: (data) => {\n // encode, write\n W.write(lp.encode.single(data, opts))\n },\n writePB: (data, proto) => {\n // encode, writeLP\n W.writeLP(proto.encode(data))\n },\n\n pb: (proto) => {\n return {\n read: () => W.readPB(proto),\n write: (d) => W.writePB(d, proto)\n }\n },\n\n unwrap: () => {\n // returns vanilla duplex again, terminates all reads/writes from this object\n shake.rest()\n return shake.stream\n }\n }\n\n return W\n}\n","'use strict'\n\nconst Reader = require('it-reader')\nconst Writer = require('it-pushable')\nconst defer = require('p-defer')\n\n// Convert a duplex stream into a reader and writer and rest stream\nmodule.exports = stream => {\n const writer = Writer() // Write bytes on demand to the sink\n const reader = Reader(stream.source) // Read bytes on demand from the source\n\n // Waits for a source to be passed to the rest stream's sink\n const sourcePromise = defer()\n let sinkErr\n\n const sinkPromise = stream.sink((async function * () {\n yield * writer\n const source = await sourcePromise.promise\n yield * source\n })())\n\n sinkPromise.catch(err => {\n sinkErr = err\n })\n\n const rest = {\n sink: source => {\n if (sinkErr) {\n return Promise.reject(sinkErr)\n }\n\n sourcePromise.resolve(source)\n return sinkPromise\n },\n source: reader\n }\n\n return {\n reader,\n writer,\n stream: rest,\n rest: () => writer.end(),\n write: writer.push,\n read: async () => {\n return (await reader.next()).value\n }\n }\n}\n","\nvar Pair = require('./')\nmodule.exports = function () {\n var a = Pair()\n var b = Pair()\n return [\n {\n source: a.source,\n sink: b.sink\n },\n {\n source: b.source,\n sink: a.sink\n }\n ]\n}\n","'use strict'\n\nconst getIterator = require('get-iterator')\n\n// a pair of streams where one drains from the other\nmodule.exports = function pair () {\n let _source, onSource\n\n const sink = async source => {\n if (_source) throw new Error('already piped')\n _source = getIterator(source)\n if (onSource) onSource(_source)\n }\n\n const source = {\n [Symbol.asyncIterator] () {\n return this\n },\n next () {\n if (_source) return _source.next()\n return new Promise(resolve => {\n onSource = source => {\n onSource = null\n resolve(source.next())\n }\n })\n }\n }\n\n return { sink, source }\n}\n","'use strict'\n\nconst { Buffer } = require('buffer')\nconst BufferList = require('bl/BufferList')\n\nmodule.exports = async function * (source) {\n for await (const b of source) {\n if (Buffer.isBuffer(b)) {\n yield b\n } else if (BufferList.isBufferList(b)) {\n yield b.slice()\n } else {\n yield Buffer.from(b)\n }\n }\n}\n\nmodule.exports.toBuffer = module.exports\n\nmodule.exports.toList = async function * (source) {\n for await (const b of source) {\n if (Buffer.isBuffer(b)) {\n yield new BufferList().append(b)\n } else if (BufferList.isBufferList(b)) {\n yield b\n } else {\n yield new BufferList().append(Buffer.from(b))\n }\n }\n}\n","import { Buffer } from 'buffer'\n\nimport { XX } from './handshakes/xx'\nimport { KeyPair } from './@types/libp2p'\nimport { bytes, bytes32 } from './@types/basic'\nimport { NoiseSession } from './@types/handshake'\nimport { IHandshake } from './@types/handshake-interface'\nimport {\n decodePayload,\n getPeerIdFromPayload,\n verifySignedPayload\n} from './utils'\nimport {\n logger,\n logLocalStaticKeys,\n logLocalEphemeralKeys,\n logRemoteEphemeralKey,\n logRemoteStaticKey,\n logCipherState\n} from './logger'\nimport { decode0, decode1, decode2, encode0, encode1, encode2 } from './encoder'\nimport { WrappedConnection } from './noise'\nimport PeerId from 'peer-id'\n\nexport class XXHandshake implements IHandshake {\n public isInitiator: boolean\n public session: NoiseSession\n public remotePeer!: PeerId\n public remoteEarlyData: Buffer\n\n protected payload: bytes\n protected connection: WrappedConnection\n protected xx: XX\n protected staticKeypair: KeyPair\n\n private readonly prologue: bytes32\n\n constructor (\n isInitiator: boolean,\n payload: bytes,\n prologue: bytes32,\n staticKeypair: KeyPair,\n connection: WrappedConnection,\n remotePeer?: PeerId,\n handshake?: XX\n ) {\n this.isInitiator = isInitiator\n this.payload = payload\n this.prologue = prologue\n this.staticKeypair = staticKeypair\n this.connection = connection\n if (remotePeer) {\n this.remotePeer = remotePeer\n }\n this.xx = handshake ?? new XX()\n this.session = this.xx.initSession(this.isInitiator, this.prologue, this.staticKeypair)\n this.remoteEarlyData = Buffer.alloc(0)\n }\n\n // stage 0\n public async propose (): Promise {\n logLocalStaticKeys(this.session.hs.s)\n if (this.isInitiator) {\n logger('Stage 0 - Initiator starting to send first message.')\n const messageBuffer = this.xx.sendMessage(this.session, Buffer.alloc(0))\n this.connection.writeLP(encode0(messageBuffer))\n logger('Stage 0 - Initiator finished sending first message.')\n logLocalEphemeralKeys(this.session.hs.e)\n } else {\n logger('Stage 0 - Responder waiting to receive first message...')\n const receivedMessageBuffer = decode0((await this.connection.readLP()).slice())\n const { valid } = this.xx.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('xx handshake stage 0 validation fail')\n }\n logger('Stage 0 - Responder received first message.')\n logRemoteEphemeralKey(this.session.hs.re)\n }\n }\n\n // stage 1\n public async exchange (): Promise {\n if (this.isInitiator) {\n logger('Stage 1 - Initiator waiting to receive first message from responder...')\n const receivedMessageBuffer = decode1((await this.connection.readLP()).slice())\n const { plaintext, valid } = this.xx.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('xx handshake stage 1 validation fail')\n }\n logger('Stage 1 - Initiator received the message.')\n logRemoteEphemeralKey(this.session.hs.re)\n logRemoteStaticKey(this.session.hs.rs)\n\n logger(\"Initiator going to check remote's signature...\")\n try {\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n this.remotePeer = await verifySignedPayload(receivedMessageBuffer.ns, decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n } catch (e) {\n const err = e as Error\n throw new Error(`Error occurred while verifying signed payload: ${err.message}`)\n }\n logger('All good with the signature!')\n } else {\n logger('Stage 1 - Responder sending out first message with signed payload and static key.')\n const messageBuffer = this.xx.sendMessage(this.session, this.payload)\n this.connection.writeLP(encode1(messageBuffer))\n logger('Stage 1 - Responder sent the second handshake message with signed payload.')\n logLocalEphemeralKeys(this.session.hs.e)\n }\n }\n\n // stage 2\n public async finish (): Promise {\n if (this.isInitiator) {\n logger('Stage 2 - Initiator sending third handshake message.')\n const messageBuffer = this.xx.sendMessage(this.session, this.payload)\n this.connection.writeLP(encode2(messageBuffer))\n logger('Stage 2 - Initiator sent message with signed payload.')\n } else {\n logger('Stage 2 - Responder waiting for third handshake message...')\n const receivedMessageBuffer = decode2((await this.connection.readLP()).slice())\n const { plaintext, valid } = this.xx.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('xx handshake stage 2 validation fail')\n }\n logger('Stage 2 - Responder received the message, finished handshake.')\n\n try {\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n await verifySignedPayload(this.session.hs.rs, decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n } catch (e) {\n const err = e as Error\n throw new Error(`Error occurred while verifying signed payload: ${err.message}`)\n }\n }\n logCipherState(this.session)\n }\n\n public encrypt (plaintext: bytes, session: NoiseSession): bytes {\n const cs = this.getCS(session)\n\n return this.xx.encryptWithAd(cs, Buffer.alloc(0), plaintext)\n }\n\n public decrypt (ciphertext: bytes, session: NoiseSession): {plaintext: bytes, valid: boolean} {\n const cs = this.getCS(session, false)\n return this.xx.decryptWithAd(cs, Buffer.alloc(0), ciphertext)\n }\n\n public getRemoteStaticKey (): bytes {\n return this.session.hs.rs\n }\n\n private getCS (session: NoiseSession, encryption = true) {\n if (!session.cs1 || !session.cs2) {\n throw new Error('Handshake not completed properly, cipher state does not exist.')\n }\n\n if (this.isInitiator) {\n return encryption ? session.cs1 : session.cs2\n } else {\n return encryption ? session.cs2 : session.cs1\n }\n }\n\n protected setRemoteEarlyData (data: Uint8Array|null|undefined): void {\n if (data) {\n this.remoteEarlyData = Buffer.from(data.buffer, data.byteOffset, data.length)\n }\n }\n}\n","import { Buffer } from 'buffer'\nimport { bytes32, bytes } from '../@types/basic'\nimport { KeyPair } from '../@types/libp2p'\nimport { generateKeypair, isValidPublicKey } from '../utils'\nimport { CipherState, HandshakeState, MessageBuffer, NoiseSession } from '../@types/handshake'\nimport { AbstractHandshake } from './abstract-handshake'\n\nexport class XX extends AbstractHandshake {\n private initializeInitiator (prologue: bytes32, s: KeyPair, rs: bytes32, psk: bytes32): HandshakeState {\n const name = 'Noise_XX_25519_ChaChaPoly_SHA256'\n const ss = this.initializeSymmetric(name)\n this.mixHash(ss, prologue)\n const re = Buffer.alloc(32)\n\n return { ss, s, rs, psk, re }\n }\n\n private initializeResponder (prologue: bytes32, s: KeyPair, rs: bytes32, psk: bytes32): HandshakeState {\n const name = 'Noise_XX_25519_ChaChaPoly_SHA256'\n const ss = this.initializeSymmetric(name)\n this.mixHash(ss, prologue)\n const re = Buffer.alloc(32)\n\n return { ss, s, rs, psk, re }\n }\n\n private writeMessageA (hs: HandshakeState, payload: bytes, e?: KeyPair): MessageBuffer {\n const ns = Buffer.alloc(0)\n\n if (e !== undefined) {\n hs.e = e\n } else {\n hs.e = generateKeypair()\n }\n\n const ne = hs.e.publicKey\n\n this.mixHash(hs.ss, ne)\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n\n return { ne, ns, ciphertext }\n }\n\n private writeMessageB (hs: HandshakeState, payload: bytes): MessageBuffer {\n hs.e = generateKeypair()\n const ne = hs.e.publicKey\n this.mixHash(hs.ss, ne)\n\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.re))\n const spk = Buffer.from(hs.s.publicKey)\n const ns = this.encryptAndHash(hs.ss, spk)\n\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.re))\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n\n return { ne, ns, ciphertext }\n }\n\n private writeMessageC (hs: HandshakeState, payload: bytes) {\n const spk = Buffer.from(hs.s.publicKey)\n const ns = this.encryptAndHash(hs.ss, spk)\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.re))\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n const ne = this.createEmptyKey()\n const messageBuffer: MessageBuffer = { ne, ns, ciphertext }\n const { cs1, cs2 } = this.split(hs.ss)\n\n return { h: hs.ss.h, messageBuffer, cs1, cs2 }\n }\n\n private readMessageA (hs: HandshakeState, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n if (isValidPublicKey(message.ne)) {\n hs.re = message.ne\n }\n\n this.mixHash(hs.ss, hs.re)\n return this.decryptAndHash(hs.ss, message.ciphertext)\n }\n\n private readMessageB (hs: HandshakeState, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n if (isValidPublicKey(message.ne)) {\n hs.re = message.ne\n }\n\n this.mixHash(hs.ss, hs.re)\n if (!hs.e) {\n throw new Error('Handshake state `e` param is missing.')\n }\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.re))\n const { plaintext: ns, valid: valid1 } = this.decryptAndHash(hs.ss, message.ns)\n if (valid1 && ns.length === 32 && isValidPublicKey(ns)) {\n hs.rs = ns\n }\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.rs))\n const { plaintext, valid: valid2 } = this.decryptAndHash(hs.ss, message.ciphertext)\n return { plaintext, valid: (valid1 && valid2) }\n }\n\n private readMessageC (hs: HandshakeState, message: MessageBuffer): {h: bytes, plaintext: bytes, valid: boolean, cs1: CipherState, cs2: CipherState} {\n const { plaintext: ns, valid: valid1 } = this.decryptAndHash(hs.ss, message.ns)\n if (valid1 && ns.length === 32 && isValidPublicKey(ns)) {\n hs.rs = ns\n }\n if (!hs.e) {\n throw new Error('Handshake state `e` param is missing.')\n }\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.rs))\n\n const { plaintext, valid: valid2 } = this.decryptAndHash(hs.ss, message.ciphertext)\n const { cs1, cs2 } = this.split(hs.ss)\n\n return { h: hs.ss.h, plaintext, valid: (valid1 && valid2), cs1, cs2 }\n }\n\n public initSession (initiator: boolean, prologue: bytes32, s: KeyPair): NoiseSession {\n const psk = this.createEmptyKey()\n const rs = Buffer.alloc(32) // no static key yet\n let hs\n\n if (initiator) {\n hs = this.initializeInitiator(prologue, s, rs, psk)\n } else {\n hs = this.initializeResponder(prologue, s, rs, psk)\n }\n\n return {\n hs,\n i: initiator,\n mc: 0\n }\n }\n\n public sendMessage (session: NoiseSession, message: bytes, ephemeral?: KeyPair): MessageBuffer {\n let messageBuffer: MessageBuffer\n if (session.mc === 0) {\n messageBuffer = this.writeMessageA(session.hs, message, ephemeral)\n } else if (session.mc === 1) {\n messageBuffer = this.writeMessageB(session.hs, message)\n } else if (session.mc === 2) {\n const { h, messageBuffer: resultingBuffer, cs1, cs2 } = this.writeMessageC(session.hs, message)\n messageBuffer = resultingBuffer\n session.h = h\n session.cs1 = cs1\n session.cs2 = cs2\n } else if (session.mc > 2) {\n if (session.i) {\n if (!session.cs1) {\n throw new Error('CS1 (cipher state) is not defined')\n }\n\n messageBuffer = this.writeMessageRegular(session.cs1, message)\n } else {\n if (!session.cs2) {\n throw new Error('CS2 (cipher state) is not defined')\n }\n\n messageBuffer = this.writeMessageRegular(session.cs2, message)\n }\n } else {\n throw new Error('Session invalid.')\n }\n\n session.mc++\n return messageBuffer\n }\n\n public recvMessage (session: NoiseSession, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n let plaintext: bytes = Buffer.alloc(0)\n let valid = false\n if (session.mc === 0) {\n ({ plaintext, valid } = this.readMessageA(session.hs, message))\n } else if (session.mc === 1) {\n ({ plaintext, valid } = this.readMessageB(session.hs, message))\n } else if (session.mc === 2) {\n const { h, plaintext: resultingPlaintext, valid: resultingValid, cs1, cs2 } = this.readMessageC(session.hs, message)\n plaintext = resultingPlaintext\n valid = resultingValid\n session.h = h\n session.cs1 = cs1\n session.cs2 = cs2\n }\n session.mc++\n return { plaintext, valid }\n }\n}\n","import { HKDF } from '@stablelib/hkdf'\nimport { SHA256 } from '@stablelib/sha256'\nimport * as x25519 from '@stablelib/x25519'\nimport { Buffer } from 'buffer'\nimport PeerId from 'peer-id'\nimport { keys } from 'libp2p-crypto'\nimport { KeyPair } from './@types/libp2p'\nimport { bytes, bytes32 } from './@types/basic'\nimport { Hkdf, INoisePayload } from './@types/handshake'\nimport { pb } from './proto/payload'\nimport { equals as uint8ArrayEquals } from 'uint8arrays/equals'\n\nconst NoiseHandshakePayloadProto = pb.NoiseHandshakePayload\n\nexport function generateKeypair (): KeyPair {\n const keypair = x25519.generateKeyPair()\n\n return {\n publicKey: Buffer.from(keypair.publicKey.buffer, keypair.publicKey.byteOffset, keypair.publicKey.length),\n privateKey: Buffer.from(keypair.secretKey.buffer, keypair.secretKey.byteOffset, keypair.secretKey.length)\n }\n}\n\nexport async function getPayload (\n localPeer: PeerId,\n staticPublicKey: bytes,\n earlyData?: bytes\n): Promise {\n const signedPayload = await signPayload(localPeer, getHandshakePayload(staticPublicKey))\n const earlyDataPayload = earlyData ?? Buffer.alloc(0)\n\n return createHandshakePayload(\n localPeer.marshalPubKey(),\n signedPayload,\n earlyDataPayload\n )\n}\n\nexport function createHandshakePayload (\n libp2pPublicKey: Uint8Array,\n signedPayload: Uint8Array,\n earlyData?: Uint8Array\n): bytes {\n const payloadInit = NoiseHandshakePayloadProto.create({\n identityKey: Buffer.from(libp2pPublicKey),\n identitySig: signedPayload,\n data: earlyData ?? null\n })\n\n return Buffer.from(NoiseHandshakePayloadProto.encode(payloadInit).finish())\n}\n\nexport async function signPayload (peerId: PeerId, payload: bytes): Promise {\n return Buffer.from(await peerId.privKey.sign(payload))\n}\n\nexport async function getPeerIdFromPayload (payload: pb.INoiseHandshakePayload): Promise {\n return await PeerId.createFromPubKey(Buffer.from(payload.identityKey as Uint8Array))\n}\n\nexport function decodePayload (payload: bytes|Uint8Array): pb.INoiseHandshakePayload {\n return NoiseHandshakePayloadProto.toObject(\n NoiseHandshakePayloadProto.decode(Buffer.from(payload))\n ) as INoisePayload\n}\n\nexport function getHandshakePayload (publicKey: bytes): bytes {\n return Buffer.concat([Buffer.from('noise-libp2p-static-key:'), publicKey])\n}\n\nasync function isValidPeerId (peerId: Uint8Array, publicKeyProtobuf: bytes): Promise {\n const generatedPeerId = await PeerId.createFromPubKey(publicKeyProtobuf)\n return uint8ArrayEquals(generatedPeerId.id, peerId)\n}\n\n/**\n * Verifies signed payload, throws on any irregularities.\n *\n * @param {bytes} noiseStaticKey - owner's noise static key\n * @param {bytes} payload - decoded payload\n * @param {PeerId} remotePeer - owner's libp2p peer ID\n * @returns {Promise} - peer ID of payload owner\n */\nexport async function verifySignedPayload (\n noiseStaticKey: bytes,\n payload: pb.INoiseHandshakePayload,\n remotePeer: PeerId\n): Promise {\n const identityKey = Buffer.from(payload.identityKey as Uint8Array)\n if (!(await isValidPeerId(remotePeer.id, identityKey))) {\n throw new Error(\"Peer ID doesn't match libp2p public key.\")\n }\n const generatedPayload = getHandshakePayload(noiseStaticKey)\n // Unmarshaling from PublicKey protobuf\n const publicKey = keys.unmarshalPublicKey(identityKey)\n // TODO remove this after libp2p-crypto ships proper types\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n if (!payload.identitySig || !publicKey.verify(generatedPayload, Buffer.from(payload.identitySig))) {\n throw new Error(\"Static key doesn't match to peer that signed payload!\")\n }\n return await PeerId.createFromPubKey(identityKey)\n}\n\nexport function getHkdf (ck: bytes32, ikm: bytes): Hkdf {\n const hkdf = new HKDF(SHA256, ikm, ck)\n const okmU8Array = hkdf.expand(96)\n const okm = Buffer.from(okmU8Array.buffer, okmU8Array.byteOffset, okmU8Array.length)\n\n const k1 = okm.slice(0, 32)\n const k2 = okm.slice(32, 64)\n const k3 = okm.slice(64, 96)\n\n return [k1, k2, k3]\n}\n\nexport function isValidPublicKey (pk: bytes): boolean {\n if (!Buffer.isBuffer(pk)) {\n return false\n }\n\n if (pk.length !== 32) {\n return false\n }\n\n return true\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package hkdf implements HKDF key derivation function.\n */\n\nimport { Hash } from \"@stablelib/hash\";\nimport { HMAC, hmac } from \"@stablelib/hmac\";\nimport { wipe } from \"@stablelib/wipe\";\n\n/**\n * HMAC-based Extract-and-Expand Key Derivation Function.\n *\n * Implements HKDF from RFC5869.\n *\n * Expands the given master key with salt and info into\n * a limited stream of key material.\n */\nexport class HKDF {\n private _hmac: HMAC;\n private _buffer: Uint8Array;\n private _bufpos: number;\n private _counter = new Uint8Array(1); // starts with zero\n private _hash: new () => Hash;\n private _info?: Uint8Array;\n\n /**\n * Create a new HKDF instance for the given hash function\n * with the master key, optional salt, and info.\n *\n * - Master key is a high-entropy secret key (not a password).\n * - Salt is a non-secret random value.\n * - Info is application- and/or context-specific information.\n */\n constructor(hash: new () => Hash,\n key: Uint8Array,\n salt = new Uint8Array(0),\n info?: Uint8Array) {\n\n this._hash = hash;\n this._info = info;\n\n // HKDF-Extract uses salt as HMAC key, and key as data.\n const okm = hmac(this._hash, salt, key);\n\n // Initialize HMAC for expanding with extracted key.\n this._hmac = new HMAC(hash, okm);\n\n // Allocate buffer.\n this._buffer = new Uint8Array(this._hmac.digestLength);\n this._bufpos = this._buffer.length;\n }\n\n // Fill buffer with new block of HKDF-Extract output.\n private _fillBuffer(): void {\n // Increment counter.\n this._counter[0]++;\n\n const ctr = this._counter[0];\n\n // Check if counter overflowed.\n if (ctr === 0) {\n throw new Error(\"hkdf: cannot expand more\");\n }\n\n // Prepare HMAC instance for new data with old key.\n this._hmac.reset();\n\n // Hash in previous output if it was generated\n // (i.e. counter is greater than 1).\n if (ctr > 1) {\n this._hmac.update(this._buffer);\n }\n\n // Hash in info if it exists.\n if (this._info) {\n this._hmac.update(this._info);\n }\n\n // Hash in the counter.\n this._hmac.update(this._counter);\n\n // Output result to buffer and clean HMAC instance.\n this._hmac.finish(this._buffer);\n\n // Reset buffer position.\n this._bufpos = 0;\n }\n\n /**\n * Expand returns next key material of the given length.\n *\n * It throws if expansion limit is reached (which is\n * 254 digests of the underlying HMAC function).\n */\n expand(length: number): Uint8Array {\n const out = new Uint8Array(length);\n for (let i = 0; i < out.length; i++) {\n if (this._bufpos === this._buffer.length) {\n this._fillBuffer();\n }\n out[i] = this._buffer[this._bufpos++];\n }\n return out;\n }\n\n clean(): void {\n this._hmac.clean();\n wipe(this._buffer);\n wipe(this._counter);\n this._bufpos = 0;\n }\n}\n\n// TODO(dchest): maybe implement deriveKey?\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package hmac implements HMAC algorithm.\n */\n\nimport { Hash, SerializableHash, isSerializableHash } from \"@stablelib/hash\";\nimport { equal as constantTimeEqual } from \"@stablelib/constant-time\";\nimport { wipe } from \"@stablelib/wipe\";\n\n/**\n * HMAC implements hash-based message authentication algorithm.\n */\nexport class HMAC implements SerializableHash {\n readonly blockSize: number;\n readonly digestLength: number;\n\n private _inner: Hash; // inner hash\n private _outer: Hash; // outer hash\n\n private _finished = false; // true if HMAC was finalized\n\n // Copies of hash states after keying.\n // Need for quick reset without hashing the key again.\n private _innerKeyedState: any | undefined;\n private _outerKeyedState: any | undefined;\n\n /**\n * Constructs a new HMAC with the given Hash and secret key.\n */\n constructor(hash: new () => Hash | SerializableHash, key: Uint8Array) {\n // Initialize inner and outer hashes.\n this._inner = new hash();\n this._outer = new hash();\n\n // Set block and digest sizes for this HMAC\n // instance to values from the hash.\n this.blockSize = this._outer.blockSize;\n this.digestLength = this._outer.digestLength;\n\n // Pad temporary stores a key (or its hash) padded with zeroes.\n const pad = new Uint8Array(this.blockSize);\n\n if (key.length > this.blockSize) {\n // If key is bigger than hash block size, it must be\n // hashed and this hash is used as a key instead.\n this._inner.update(key).finish(pad).clean();\n } else {\n // Otherwise, copy the key into pad.\n pad.set(key);\n }\n\n // Now two different keys are derived from padded key\n // by xoring a different byte value to each.\n\n // To make inner hash key, xor byte 0x36 into pad.\n for (let i = 0; i < pad.length; i++) {\n pad[i] ^= 0x36;\n }\n // Update inner hash with the result.\n this._inner.update(pad);\n\n // To make outer hash key, xor byte 0x5c into pad.\n // But since we already xored 0x36 there, we must\n // first undo this by xoring it again.\n for (let i = 0; i < pad.length; i++) {\n pad[i] ^= 0x36 ^ 0x5c;\n }\n // Update outer hash with the result.\n this._outer.update(pad);\n\n // Save states of both hashes, so that we can quickly restore\n // them later in reset() without the need to remember the actual\n // key and perform this initialization again.\n if (isSerializableHash(this._inner) && isSerializableHash(this._outer)) {\n this._innerKeyedState = this._inner.saveState();\n this._outerKeyedState = this._outer.saveState();\n }\n\n // Clean pad.\n wipe(pad);\n }\n\n /**\n * Returns HMAC state to the state initialized with key\n * to make it possible to run HMAC over the other data with the same\n * key without creating a new instance.\n */\n reset(): this {\n if (!isSerializableHash(this._inner) || !isSerializableHash(this._outer)) {\n throw new Error(\"hmac: can't reset() because hash doesn't implement restoreState()\");\n }\n // Restore keyed states of inner and outer hashes.\n this._inner.restoreState(this._innerKeyedState);\n this._outer.restoreState(this._outerKeyedState);\n this._finished = false;\n return this;\n }\n\n /**\n * Cleans HMAC state.\n */\n clean() {\n if (isSerializableHash(this._inner)) {\n this._inner.cleanSavedState(this._innerKeyedState);\n }\n if (isSerializableHash(this._outer)) {\n this._outer.cleanSavedState(this._outerKeyedState);\n }\n this._inner.clean();\n this._outer.clean();\n }\n\n /**\n * Updates state with provided data.\n */\n update(data: Uint8Array): this {\n this._inner.update(data);\n return this;\n }\n\n /**\n * Finalizes HMAC and puts the result in out.\n */\n finish(out: Uint8Array): this {\n if (this._finished) {\n // If HMAC was finalized, outer hash is also finalized,\n // so it produces the same digest it produced when it\n // was finalized.\n this._outer.finish(out);\n return this;\n }\n\n // Finalize inner hash and store the result temporarily.\n this._inner.finish(out);\n\n // Update outer hash with digest of inner hash and and finalize it.\n this._outer.update(out.subarray(0, this.digestLength)).finish(out);\n this._finished = true;\n\n return this;\n }\n\n /**\n * Returns the computed message authentication code.\n */\n digest(): Uint8Array {\n const out = new Uint8Array(this.digestLength);\n this.finish(out);\n return out;\n }\n\n /**\n * Saves HMAC state.\n * This function is needed for PBKDF2 optimization.\n */\n saveState(): any {\n if (!isSerializableHash(this._inner)) {\n throw new Error(\"hmac: can't saveState() because hash doesn't implement it\");\n }\n return this._inner.saveState();\n }\n\n restoreState(savedState: any): this {\n if (!isSerializableHash(this._inner) || !isSerializableHash(this._outer)) {\n throw new Error(\"hmac: can't restoreState() because hash doesn't implement it\");\n }\n this._inner.restoreState(savedState);\n this._outer.restoreState(this._outerKeyedState);\n this._finished = false;\n return this;\n }\n\n cleanSavedState(savedState: any) {\n if (!isSerializableHash(this._inner)) {\n throw new Error(\"hmac: can't cleanSavedState() because hash doesn't implement it\");\n }\n this._inner.cleanSavedState(savedState);\n }\n}\n\n/**\n * Returns HMAC using the given hash constructor for the key over data.\n */\nexport function hmac(hash: new () => Hash, key: Uint8Array, data: Uint8Array): Uint8Array {\n const h = new HMAC(hash, key);\n h.update(data);\n const digest = h.digest();\n h.clean();\n return digest;\n}\n\n/**\n * Returns true if two HMAC digests are equal.\n * Uses constant-time comparison to avoid leaking timing information.\n *\n * Example:\n *\n * const receivedDigest = ...\n * const realDigest = hmac(SHA256, key, data);\n * if (!equal(receivedDigest, realDigest)) {\n * throw new Error(\"Authentication error\");\n * }\n */\nexport const equal = constantTimeEqual;\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package hash provides interface for hash functions.\n */\n\n/**\n * Hash interface describes properties of\n * cryptographic hash functions.\n */\nexport interface Hash {\n readonly digestLength: number;\n readonly blockSize: number;\n update(data: Uint8Array): this;\n reset(): this;\n finish(out: Uint8Array): this;\n digest(): Uint8Array;\n clean(): void;\n}\n\nexport interface SerializableHash extends Hash {\n saveState(): any;\n restoreState(savedState: any): this;\n cleanSavedState(savedState: any): void;\n}\n\nexport function isSerializableHash(h: Hash): h is SerializableHash {\n return (\n typeof (h as SerializableHash).saveState !== \"undefined\" &&\n typeof (h as SerializableHash).restoreState !== \"undefined\" &&\n typeof (h as SerializableHash).cleanSavedState !== \"undefined\"\n );\n}\n\n// TODO(dchest): figure out the standardized interface for XOF such as\n// SHAKE and BLAKE2X.\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package constant-time provides functions for performing algorithmically constant-time operations.\n */\n\n/**\n * NOTE! Due to the inability to guarantee real constant time evaluation of\n * anything in JavaScript VM, this is module is the best effort.\n */\n\n/**\n * Returns resultIfOne if subject is 1, or resultIfZero if subject is 0.\n *\n * Supports only 32-bit integers, so resultIfOne or resultIfZero are not\n * integers, they'll be converted to them with bitwise operations.\n */\nexport function select(subject: number, resultIfOne: number, resultIfZero: number): number {\n return (~(subject - 1) & resultIfOne) | ((subject - 1) & resultIfZero);\n}\n\n/**\n * Returns 1 if a <= b, or 0 if not.\n * Arguments must be positive 32-bit integers less than or equal to 2^31 - 1.\n */\nexport function lessOrEqual(a: number, b: number): number {\n return (((a | 0) - (b | 0) - 1) >>> 31) & 1;\n}\n\n/**\n * Returns 1 if a and b are of equal length and their contents\n * are equal, or 0 otherwise.\n *\n * Note that unlike in equal(), zero-length inputs are considered\n * the same, so this function will return 1.\n */\nexport function compare(a: Uint8Array, b: Uint8Array): number {\n if (a.length !== b.length) {\n return 0;\n }\n let result = 0;\n for (let i = 0; i < a.length; i++) {\n result |= a[i] ^ b[i];\n }\n return (1 & ((result - 1) >>> 8));\n}\n\n/**\n * Returns true if a and b are of equal non-zero length,\n * and their contents are equal, or false otherwise.\n *\n * Note that unlike in compare() zero-length inputs are considered\n * _not_ equal, so this function will return false.\n */\nexport function equal(a: Uint8Array, b: Uint8Array): boolean {\n if (a.length === 0 || b.length === 0) {\n return false;\n }\n return compare(a, b) !== 0;\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package sha256 implements SHA-2-256 cryptographic hash function.\n */\n\nimport { SerializableHash } from \"@stablelib/hash\";\nimport { readUint32BE, writeUint32BE } from \"@stablelib/binary\";\nimport { wipe } from \"@stablelib/wipe\";\n\nexport const DIGEST_LENGTH = 32;\nexport const BLOCK_SIZE = 64;\n\n/**\n * SHA2-256 cryptographic hash algorithm.\n */\nexport class SHA256 implements SerializableHash {\n /** Length of hash output */\n readonly digestLength: number = DIGEST_LENGTH;\n\n /** Block size */\n readonly blockSize: number = BLOCK_SIZE;\n\n // Note: Int32Array is used instead of Uint32Array for performance reasons.\n protected _state = new Int32Array(8); // hash state\n private _temp = new Int32Array(64); // temporary state\n private _buffer = new Uint8Array(128); // buffer for data to hash\n private _bufferLength = 0; // number of bytes in buffer\n private _bytesHashed = 0; // number of total bytes hashed\n private _finished = false; // indicates whether the hash was finalized\n\n constructor() {\n this.reset();\n }\n\n protected _initState() {\n this._state[0] = 0x6a09e667;\n this._state[1] = 0xbb67ae85;\n this._state[2] = 0x3c6ef372;\n this._state[3] = 0xa54ff53a;\n this._state[4] = 0x510e527f;\n this._state[5] = 0x9b05688c;\n this._state[6] = 0x1f83d9ab;\n this._state[7] = 0x5be0cd19;\n }\n\n /**\n * Resets hash state making it possible\n * to re-use this instance to hash other data.\n */\n reset(): this {\n this._initState();\n this._bufferLength = 0;\n this._bytesHashed = 0;\n this._finished = false;\n return this;\n }\n\n /**\n * Cleans internal buffers and resets hash state.\n */\n clean() {\n wipe(this._buffer);\n wipe(this._temp);\n this.reset();\n }\n\n /**\n * Updates hash state with the given data.\n *\n * Throws error when trying to update already finalized hash:\n * instance must be reset to update it again.\n */\n update(data: Uint8Array, dataLength: number = data.length): this {\n if (this._finished) {\n throw new Error(\"SHA256: can't update because hash was finished.\");\n }\n let dataPos = 0;\n this._bytesHashed += dataLength;\n if (this._bufferLength > 0) {\n while (this._bufferLength < this.blockSize && dataLength > 0) {\n this._buffer[this._bufferLength++] = data[dataPos++];\n dataLength--;\n }\n if (this._bufferLength === this.blockSize) {\n hashBlocks(this._temp, this._state, this._buffer, 0, this.blockSize);\n this._bufferLength = 0;\n }\n }\n if (dataLength >= this.blockSize) {\n dataPos = hashBlocks(this._temp, this._state, data, dataPos, dataLength);\n dataLength %= this.blockSize;\n }\n while (dataLength > 0) {\n this._buffer[this._bufferLength++] = data[dataPos++];\n dataLength--;\n }\n return this;\n }\n\n /**\n * Finalizes hash state and puts hash into out.\n * If hash was already finalized, puts the same value.\n */\n finish(out: Uint8Array): this {\n if (!this._finished) {\n const bytesHashed = this._bytesHashed;\n const left = this._bufferLength;\n const bitLenHi = (bytesHashed / 0x20000000) | 0;\n const bitLenLo = bytesHashed << 3;\n const padLength = (bytesHashed % 64 < 56) ? 64 : 128;\n\n this._buffer[left] = 0x80;\n for (let i = left + 1; i < padLength - 8; i++) {\n this._buffer[i] = 0;\n }\n writeUint32BE(bitLenHi, this._buffer, padLength - 8);\n writeUint32BE(bitLenLo, this._buffer, padLength - 4);\n\n hashBlocks(this._temp, this._state, this._buffer, 0, padLength);\n\n this._finished = true;\n }\n\n for (let i = 0; i < this.digestLength / 4; i++) {\n writeUint32BE(this._state[i], out, i * 4);\n }\n\n return this;\n }\n\n /**\n * Returns the final hash digest.\n */\n digest(): Uint8Array {\n const out = new Uint8Array(this.digestLength);\n this.finish(out);\n return out;\n }\n\n /**\n * Function useful for HMAC/PBKDF2 optimization.\n * Returns hash state to be used with restoreState().\n * Only chain value is saved, not buffers or other\n * state variables.\n */\n saveState(): SavedState {\n if (this._finished) {\n throw new Error(\"SHA256: cannot save finished state\");\n }\n return {\n state: new Int32Array(this._state),\n buffer: this._bufferLength > 0 ? new Uint8Array(this._buffer) : undefined,\n bufferLength: this._bufferLength,\n bytesHashed: this._bytesHashed\n };\n }\n\n /**\n * Function useful for HMAC/PBKDF2 optimization.\n * Restores state saved by saveState() and sets bytesHashed\n * to the given value.\n */\n restoreState(savedState: SavedState): this {\n this._state.set(savedState.state);\n this._bufferLength = savedState.bufferLength;\n if (savedState.buffer) {\n this._buffer.set(savedState.buffer);\n }\n this._bytesHashed = savedState.bytesHashed;\n this._finished = false;\n return this;\n }\n\n /**\n * Cleans state returned by saveState().\n */\n cleanSavedState(savedState: SavedState) {\n wipe(savedState.state);\n if (savedState.buffer) {\n wipe(savedState.buffer);\n }\n savedState.bufferLength = 0;\n savedState.bytesHashed = 0;\n }\n}\n\nexport type SavedState = {\n state: Int32Array;\n buffer: Uint8Array | undefined;\n bufferLength: number;\n bytesHashed: number;\n};\n\n// Constants\nconst K = new Int32Array([\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b,\n 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01,\n 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7,\n 0xc19bf174, 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, 0x983e5152,\n 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147,\n 0x06ca6351, 0x14292967, 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc,\n 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819,\n 0xd6990624, 0xf40e3585, 0x106aa070, 0x19a4c116, 0x1e376c08,\n 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f,\n 0x682e6ff3, 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n]);\n\nfunction hashBlocks(w: Int32Array, v: Int32Array, p: Uint8Array, pos: number, len: number): number {\n while (len >= 64) {\n let a = v[0];\n let b = v[1];\n let c = v[2];\n let d = v[3];\n let e = v[4];\n let f = v[5];\n let g = v[6];\n let h = v[7];\n\n for (let i = 0; i < 16; i++) {\n let j = pos + i * 4;\n w[i] = readUint32BE(p, j);\n }\n\n for (let i = 16; i < 64; i++) {\n let u = w[i - 2];\n let t1 = (u >>> 17 | u << (32 - 17)) ^ (u >>> 19 | u << (32 - 19)) ^ (u >>> 10);\n\n u = w[i - 15];\n let t2 = (u >>> 7 | u << (32 - 7)) ^ (u >>> 18 | u << (32 - 18)) ^ (u >>> 3);\n\n w[i] = (t1 + w[i - 7] | 0) + (t2 + w[i - 16] | 0);\n }\n\n for (let i = 0; i < 64; i++) {\n let t1 = (((((e >>> 6 | e << (32 - 6)) ^ (e >>> 11 | e << (32 - 11)) ^\n (e >>> 25 | e << (32 - 25))) + ((e & f) ^ (~e & g))) | 0) +\n ((h + ((K[i] + w[i]) | 0)) | 0)) | 0;\n\n let t2 = (((a >>> 2 | a << (32 - 2)) ^ (a >>> 13 | a << (32 - 13)) ^\n (a >>> 22 | a << (32 - 22))) + ((a & b) ^ (a & c) ^ (b & c))) | 0;\n\n h = g;\n g = f;\n f = e;\n e = (d + t1) | 0;\n d = c;\n c = b;\n b = a;\n a = (t1 + t2) | 0;\n }\n\n v[0] += a;\n v[1] += b;\n v[2] += c;\n v[3] += d;\n v[4] += e;\n v[5] += f;\n v[6] += g;\n v[7] += h;\n\n pos += 64;\n len -= 64;\n }\n return pos;\n}\n\nexport function hash(data: Uint8Array): Uint8Array {\n const h = new SHA256();\n h.update(data);\n const digest = h.digest();\n h.clean();\n return digest;\n}\n","/*eslint-disable block-scoped-var, id-length, no-control-regex, no-magic-numbers, no-prototype-builtins, no-redeclare, no-shadow, no-var, sort-vars*/\n(function(global, factory) { /* global define, require, module */\n\n /* AMD */ if (typeof define === 'function' && define.amd)\n define([\"protobufjs/minimal\"], factory);\n\n /* CommonJS */ else if (typeof require === 'function' && typeof module === 'object' && module && module.exports)\n module.exports = factory(require(\"protobufjs/minimal\"));\n\n})(this, function($protobuf) {\n \"use strict\";\n\n // Common aliases\n var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n \n // Exported root namespace\n var $root = $protobuf.roots[\"libp2p-noise\"] || ($protobuf.roots[\"libp2p-noise\"] = {});\n \n $root.pb = (function() {\n \n /**\n * Namespace pb.\n * @exports pb\n * @namespace\n */\n var pb = {};\n \n pb.NoiseHandshakePayload = (function() {\n \n /**\n * Properties of a NoiseHandshakePayload.\n * @memberof pb\n * @interface INoiseHandshakePayload\n * @property {Uint8Array|null} [identityKey] NoiseHandshakePayload identityKey\n * @property {Uint8Array|null} [identitySig] NoiseHandshakePayload identitySig\n * @property {Uint8Array|null} [data] NoiseHandshakePayload data\n */\n \n /**\n * Constructs a new NoiseHandshakePayload.\n * @memberof pb\n * @classdesc Represents a NoiseHandshakePayload.\n * @implements INoiseHandshakePayload\n * @constructor\n * @param {pb.INoiseHandshakePayload=} [properties] Properties to set\n */\n function NoiseHandshakePayload(properties) {\n if (properties)\n for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)\n if (properties[keys[i]] != null)\n this[keys[i]] = properties[keys[i]];\n }\n \n /**\n * NoiseHandshakePayload identityKey.\n * @member {Uint8Array} identityKey\n * @memberof pb.NoiseHandshakePayload\n * @instance\n */\n NoiseHandshakePayload.prototype.identityKey = $util.newBuffer([]);\n \n /**\n * NoiseHandshakePayload identitySig.\n * @member {Uint8Array} identitySig\n * @memberof pb.NoiseHandshakePayload\n * @instance\n */\n NoiseHandshakePayload.prototype.identitySig = $util.newBuffer([]);\n \n /**\n * NoiseHandshakePayload data.\n * @member {Uint8Array} data\n * @memberof pb.NoiseHandshakePayload\n * @instance\n */\n NoiseHandshakePayload.prototype.data = $util.newBuffer([]);\n \n /**\n * Creates a new NoiseHandshakePayload instance using the specified properties.\n * @function create\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {pb.INoiseHandshakePayload=} [properties] Properties to set\n * @returns {pb.NoiseHandshakePayload} NoiseHandshakePayload instance\n */\n NoiseHandshakePayload.create = function create(properties) {\n return new NoiseHandshakePayload(properties);\n };\n \n /**\n * Encodes the specified NoiseHandshakePayload message. Does not implicitly {@link pb.NoiseHandshakePayload.verify|verify} messages.\n * @function encode\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {pb.INoiseHandshakePayload} message NoiseHandshakePayload message or plain object to encode\n * @param {$protobuf.Writer} [writer] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n NoiseHandshakePayload.encode = function encode(message, writer) {\n if (!writer)\n writer = $Writer.create();\n if (message.identityKey != null && Object.hasOwnProperty.call(message, \"identityKey\"))\n writer.uint32(/* id 1, wireType 2 =*/10).bytes(message.identityKey);\n if (message.identitySig != null && Object.hasOwnProperty.call(message, \"identitySig\"))\n writer.uint32(/* id 2, wireType 2 =*/18).bytes(message.identitySig);\n if (message.data != null && Object.hasOwnProperty.call(message, \"data\"))\n writer.uint32(/* id 3, wireType 2 =*/26).bytes(message.data);\n return writer;\n };\n \n /**\n * Encodes the specified NoiseHandshakePayload message, length delimited. Does not implicitly {@link pb.NoiseHandshakePayload.verify|verify} messages.\n * @function encodeDelimited\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {pb.INoiseHandshakePayload} message NoiseHandshakePayload message or plain object to encode\n * @param {$protobuf.Writer} [writer] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n NoiseHandshakePayload.encodeDelimited = function encodeDelimited(message, writer) {\n return this.encode(message, writer).ldelim();\n };\n \n /**\n * Decodes a NoiseHandshakePayload message from the specified reader or buffer.\n * @function decode\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from\n * @param {number} [length] Message length if known beforehand\n * @returns {pb.NoiseHandshakePayload} NoiseHandshakePayload\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n NoiseHandshakePayload.decode = function decode(reader, length) {\n if (!(reader instanceof $Reader))\n reader = $Reader.create(reader);\n var end = length === undefined ? reader.len : reader.pos + length, message = new $root.pb.NoiseHandshakePayload();\n while (reader.pos < end) {\n var tag = reader.uint32();\n switch (tag >>> 3) {\n case 1:\n message.identityKey = reader.bytes();\n break;\n case 2:\n message.identitySig = reader.bytes();\n break;\n case 3:\n message.data = reader.bytes();\n break;\n default:\n reader.skipType(tag & 7);\n break;\n }\n }\n return message;\n };\n \n /**\n * Decodes a NoiseHandshakePayload message from the specified reader or buffer, length delimited.\n * @function decodeDelimited\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from\n * @returns {pb.NoiseHandshakePayload} NoiseHandshakePayload\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n NoiseHandshakePayload.decodeDelimited = function decodeDelimited(reader) {\n if (!(reader instanceof $Reader))\n reader = new $Reader(reader);\n return this.decode(reader, reader.uint32());\n };\n \n /**\n * Verifies a NoiseHandshakePayload message.\n * @function verify\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {Object.} message Plain object to verify\n * @returns {string|null} `null` if valid, otherwise the reason why it is not\n */\n NoiseHandshakePayload.verify = function verify(message) {\n if (typeof message !== \"object\" || message === null)\n return \"object expected\";\n if (message.identityKey != null && message.hasOwnProperty(\"identityKey\"))\n if (!(message.identityKey && typeof message.identityKey.length === \"number\" || $util.isString(message.identityKey)))\n return \"identityKey: buffer expected\";\n if (message.identitySig != null && message.hasOwnProperty(\"identitySig\"))\n if (!(message.identitySig && typeof message.identitySig.length === \"number\" || $util.isString(message.identitySig)))\n return \"identitySig: buffer expected\";\n if (message.data != null && message.hasOwnProperty(\"data\"))\n if (!(message.data && typeof message.data.length === \"number\" || $util.isString(message.data)))\n return \"data: buffer expected\";\n return null;\n };\n \n /**\n * Creates a NoiseHandshakePayload message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {Object.} object Plain object\n * @returns {pb.NoiseHandshakePayload} NoiseHandshakePayload\n */\n NoiseHandshakePayload.fromObject = function fromObject(object) {\n if (object instanceof $root.pb.NoiseHandshakePayload)\n return object;\n var message = new $root.pb.NoiseHandshakePayload();\n if (object.identityKey != null)\n if (typeof object.identityKey === \"string\")\n $util.base64.decode(object.identityKey, message.identityKey = $util.newBuffer($util.base64.length(object.identityKey)), 0);\n else if (object.identityKey.length)\n message.identityKey = object.identityKey;\n if (object.identitySig != null)\n if (typeof object.identitySig === \"string\")\n $util.base64.decode(object.identitySig, message.identitySig = $util.newBuffer($util.base64.length(object.identitySig)), 0);\n else if (object.identitySig.length)\n message.identitySig = object.identitySig;\n if (object.data != null)\n if (typeof object.data === \"string\")\n $util.base64.decode(object.data, message.data = $util.newBuffer($util.base64.length(object.data)), 0);\n else if (object.data.length)\n message.data = object.data;\n return message;\n };\n \n /**\n * Creates a plain object from a NoiseHandshakePayload message. Also converts values to other types if specified.\n * @function toObject\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {pb.NoiseHandshakePayload} message NoiseHandshakePayload\n * @param {$protobuf.IConversionOptions} [options] Conversion options\n * @returns {Object.} Plain object\n */\n NoiseHandshakePayload.toObject = function toObject(message, options) {\n if (!options)\n options = {};\n var object = {};\n if (options.defaults) {\n if (options.bytes === String)\n object.identityKey = \"\";\n else {\n object.identityKey = [];\n if (options.bytes !== Array)\n object.identityKey = $util.newBuffer(object.identityKey);\n }\n if (options.bytes === String)\n object.identitySig = \"\";\n else {\n object.identitySig = [];\n if (options.bytes !== Array)\n object.identitySig = $util.newBuffer(object.identitySig);\n }\n if (options.bytes === String)\n object.data = \"\";\n else {\n object.data = [];\n if (options.bytes !== Array)\n object.data = $util.newBuffer(object.data);\n }\n }\n if (message.identityKey != null && message.hasOwnProperty(\"identityKey\"))\n object.identityKey = options.bytes === String ? $util.base64.encode(message.identityKey, 0, message.identityKey.length) : options.bytes === Array ? Array.prototype.slice.call(message.identityKey) : message.identityKey;\n if (message.identitySig != null && message.hasOwnProperty(\"identitySig\"))\n object.identitySig = options.bytes === String ? $util.base64.encode(message.identitySig, 0, message.identitySig.length) : options.bytes === Array ? Array.prototype.slice.call(message.identitySig) : message.identitySig;\n if (message.data != null && message.hasOwnProperty(\"data\"))\n object.data = options.bytes === String ? $util.base64.encode(message.data, 0, message.data.length) : options.bytes === Array ? Array.prototype.slice.call(message.data) : message.data;\n return object;\n };\n \n /**\n * Converts this NoiseHandshakePayload to JSON.\n * @function toJSON\n * @memberof pb.NoiseHandshakePayload\n * @instance\n * @returns {Object.} JSON object\n */\n NoiseHandshakePayload.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return NoiseHandshakePayload;\n })();\n \n return pb;\n })();\n\n return $root;\n});\n","import { Buffer } from 'buffer'\nimport * as x25519 from '@stablelib/x25519'\nimport * as SHA256 from '@stablelib/sha256'\nimport { ChaCha20Poly1305 } from '@stablelib/chacha20poly1305'\n\nimport { bytes, bytes32, uint32 } from '../@types/basic'\nimport { CipherState, MessageBuffer, SymmetricState } from '../@types/handshake'\nimport { getHkdf } from '../utils'\nimport { logger } from '../logger'\n\nexport const MIN_NONCE = 0\n\nexport abstract class AbstractHandshake {\n public encryptWithAd (cs: CipherState, ad: bytes, plaintext: bytes): bytes {\n const e = this.encrypt(cs.k, cs.n, ad, plaintext)\n this.setNonce(cs, this.incrementNonce(cs.n))\n\n return e\n }\n\n public decryptWithAd (cs: CipherState, ad: bytes, ciphertext: bytes): {plaintext: bytes, valid: boolean} {\n const { plaintext, valid } = this.decrypt(cs.k, cs.n, ad, ciphertext)\n this.setNonce(cs, this.incrementNonce(cs.n))\n\n return { plaintext, valid }\n }\n\n // Cipher state related\n protected hasKey (cs: CipherState): boolean {\n return !this.isEmptyKey(cs.k)\n }\n\n protected setNonce (cs: CipherState, nonce: uint32): void {\n cs.n = nonce\n }\n\n protected createEmptyKey (): bytes32 {\n return Buffer.alloc(32)\n }\n\n protected isEmptyKey (k: bytes32): boolean {\n const emptyKey = this.createEmptyKey()\n return emptyKey.equals(k)\n }\n\n protected incrementNonce (n: uint32): uint32 {\n return n + 1\n }\n\n protected nonceToBytes (n: uint32): bytes {\n const nonce = Buffer.alloc(12)\n nonce.writeUInt32LE(n, 4)\n\n return nonce\n }\n\n protected encrypt (k: bytes32, n: uint32, ad: bytes, plaintext: bytes): bytes {\n const nonce = this.nonceToBytes(n)\n const ctx = new ChaCha20Poly1305(k)\n const encryptedMessage = ctx.seal(nonce, plaintext, ad)\n return Buffer.from(encryptedMessage.buffer, encryptedMessage.byteOffset, encryptedMessage.length)\n }\n\n protected encryptAndHash (ss: SymmetricState, plaintext: bytes): bytes {\n let ciphertext\n if (this.hasKey(ss.cs)) {\n ciphertext = this.encryptWithAd(ss.cs, ss.h, plaintext)\n } else {\n ciphertext = plaintext\n }\n\n this.mixHash(ss, ciphertext)\n return ciphertext\n }\n\n protected decrypt (k: bytes32, n: uint32, ad: bytes, ciphertext: bytes): {plaintext: bytes, valid: boolean} {\n const nonce = this.nonceToBytes(n)\n const ctx = new ChaCha20Poly1305(k)\n const encryptedMessage = ctx.open(\n nonce,\n ciphertext,\n ad\n )\n if (encryptedMessage) {\n return {\n plaintext: Buffer.from(\n encryptedMessage.buffer,\n encryptedMessage.byteOffset,\n encryptedMessage.length\n ),\n valid: true\n }\n } else {\n return {\n plaintext: Buffer.from(''),\n valid: false\n }\n }\n }\n\n protected decryptAndHash (ss: SymmetricState, ciphertext: bytes): {plaintext: bytes, valid: boolean} {\n let plaintext: bytes; let valid = true\n if (this.hasKey(ss.cs)) {\n ({ plaintext, valid } = this.decryptWithAd(ss.cs, ss.h, ciphertext))\n } else {\n plaintext = ciphertext\n }\n\n this.mixHash(ss, ciphertext)\n return { plaintext, valid }\n }\n\n protected dh (privateKey: bytes32, publicKey: bytes32): bytes32 {\n try {\n const derivedU8 = x25519.sharedKey(privateKey, publicKey)\n const derived = Buffer.from(derivedU8.buffer, derivedU8.byteOffset, derivedU8.length)\n const result = Buffer.alloc(32)\n derived.copy(result)\n return result\n } catch (e) {\n logger(e.message)\n return Buffer.alloc(32)\n }\n }\n\n protected mixHash (ss: SymmetricState, data: bytes): void {\n ss.h = this.getHash(ss.h, data)\n }\n\n protected getHash (a: bytes, b: bytes): bytes32 {\n const hash = SHA256.hash(Buffer.from([...a, ...b]))\n return Buffer.from(hash.buffer, hash.byteOffset, hash.length)\n }\n\n protected mixKey (ss: SymmetricState, ikm: bytes32): void {\n const [ck, tempK] = getHkdf(ss.ck, ikm)\n ss.cs = this.initializeKey(tempK)\n ss.ck = ck\n }\n\n protected initializeKey (k: bytes32): CipherState {\n const n = MIN_NONCE\n return { k, n }\n }\n\n // Symmetric state related\n\n protected initializeSymmetric (protocolName: string): SymmetricState {\n const protocolNameBytes: bytes = Buffer.from(protocolName, 'utf-8')\n const h = this.hashProtocolName(protocolNameBytes)\n\n const ck = h\n const key = this.createEmptyKey()\n const cs: CipherState = this.initializeKey(key)\n\n return { cs, ck, h }\n }\n\n protected hashProtocolName (protocolName: bytes): bytes32 {\n if (protocolName.length <= 32) {\n const h = Buffer.alloc(32)\n protocolName.copy(h)\n return h\n } else {\n return this.getHash(protocolName, Buffer.alloc(0))\n }\n }\n\n protected split (ss: SymmetricState): {cs1: CipherState, cs2: CipherState} {\n const [tempk1, tempk2] = getHkdf(ss.ck, Buffer.alloc(0))\n const cs1 = this.initializeKey(tempk1)\n const cs2 = this.initializeKey(tempk2)\n\n return { cs1, cs2 }\n }\n\n protected writeMessageRegular (cs: CipherState, payload: bytes): MessageBuffer {\n const ciphertext = this.encryptWithAd(cs, Buffer.alloc(0), payload)\n const ne = this.createEmptyKey()\n const ns = Buffer.alloc(0)\n\n return { ne, ns, ciphertext }\n }\n\n protected readMessageRegular (cs: CipherState, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n return this.decryptWithAd(cs, Buffer.alloc(0), message.ciphertext)\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package chacha20poly1305 implements ChaCha20-Poly1305 AEAD.\n */\n\nimport { AEAD } from \"@stablelib/aead\";\nimport { streamXOR, stream } from \"@stablelib/chacha\";\nimport { Poly1305 } from \"@stablelib/poly1305\";\nimport { wipe } from \"@stablelib/wipe\";\nimport { writeUint64LE } from \"@stablelib/binary\";\nimport { equal } from \"@stablelib/constant-time\";\n\nexport const KEY_LENGTH = 32;\nexport const NONCE_LENGTH = 12;\nexport const TAG_LENGTH = 16;\n\nconst ZEROS = new Uint8Array(16);\n\n/**\n * ChaCha20-Poly1305 Authenticated Encryption with Associated Data.\n *\n * Defined in RFC7539.\n */\nexport class ChaCha20Poly1305 implements AEAD {\n readonly nonceLength = NONCE_LENGTH;\n readonly tagLength = TAG_LENGTH;\n\n private _key: Uint8Array;\n\n /**\n * Creates a new instance with the given 32-byte key.\n */\n constructor(key: Uint8Array) {\n if (key.length !== KEY_LENGTH) {\n throw new Error(\"ChaCha20Poly1305 needs 32-byte key\");\n }\n // Copy key.\n this._key = new Uint8Array(key);\n }\n\n /**\n * Encrypts and authenticates plaintext, authenticates associated data,\n * and returns sealed ciphertext, which includes authentication tag.\n *\n * RFC7539 specifies 12 bytes for nonce. It may be this 12-byte nonce\n * (\"IV\"), or full 16-byte counter (called \"32-bit fixed-common part\")\n * and nonce.\n *\n * If dst is given (it must be the size of plaintext + the size of tag\n * length) the result will be put into it. Dst and plaintext must not\n * overlap.\n */\n seal(nonce: Uint8Array, plaintext: Uint8Array, associatedData?: Uint8Array,\n dst?: Uint8Array): Uint8Array {\n if (nonce.length > 16) {\n throw new Error(\"ChaCha20Poly1305: incorrect nonce length\");\n }\n\n // Allocate space for counter, and set nonce as last bytes of it.\n const counter = new Uint8Array(16);\n counter.set(nonce, counter.length - nonce.length);\n\n // Generate authentication key by taking first 32-bytes of stream.\n // We pass full counter, which has 12-byte nonce and 4-byte block counter,\n // and it will get incremented after generating the block, which is\n // exactly what we need: we only use the first 32 bytes of 64-byte\n // ChaCha block and discard the next 32 bytes.\n const authKey = new Uint8Array(32);\n stream(this._key, counter, authKey, 4);\n\n // Allocate space for sealed ciphertext.\n const resultLength = plaintext.length + this.tagLength;\n let result;\n if (dst) {\n if (dst.length !== resultLength) {\n throw new Error(\"ChaCha20Poly1305: incorrect destination length\");\n }\n result = dst;\n } else {\n result = new Uint8Array(resultLength);\n }\n\n // Encrypt plaintext.\n streamXOR(this._key, counter, plaintext, result, 4);\n\n // Authenticate.\n // XXX: can \"simplify\" here: pass full result (which is already padded\n // due to zeroes prepared for tag), and ciphertext length instead of\n // subarray of result.\n this._authenticate(result.subarray(result.length - this.tagLength, result.length),\n authKey, result.subarray(0, result.length - this.tagLength), associatedData);\n\n // Cleanup.\n wipe(counter);\n\n return result;\n }\n\n /**\n * Authenticates sealed ciphertext (which includes authentication tag) and\n * associated data, decrypts ciphertext and returns decrypted plaintext.\n *\n * RFC7539 specifies 12 bytes for nonce. It may be this 12-byte nonce\n * (\"IV\"), or full 16-byte counter (called \"32-bit fixed-common part\")\n * and nonce.\n *\n * If authentication fails, it returns null.\n *\n * If dst is given (it must be of ciphertext length minus tag length),\n * the result will be put into it. Dst and plaintext must not overlap.\n */\n open(nonce: Uint8Array, sealed: Uint8Array, associatedData?: Uint8Array,\n dst?: Uint8Array): Uint8Array | null {\n if (nonce.length > 16) {\n throw new Error(\"ChaCha20Poly1305: incorrect nonce length\");\n }\n\n // Sealed ciphertext should at least contain tag.\n if (sealed.length < this.tagLength) {\n // TODO(dchest): should we throw here instead?\n return null;\n }\n\n // Allocate space for counter, and set nonce as last bytes of it.\n const counter = new Uint8Array(16);\n counter.set(nonce, counter.length - nonce.length);\n\n // Generate authentication key by taking first 32-bytes of stream.\n const authKey = new Uint8Array(32);\n stream(this._key, counter, authKey, 4);\n\n // Authenticate.\n // XXX: can simplify and avoid allocation: since authenticate()\n // already allocates tag (from Poly1305.digest(), it can return)\n // it instead of copying to calculatedTag. But then in seal()\n // we'll need to copy it.\n const calculatedTag = new Uint8Array(this.tagLength);\n this._authenticate(calculatedTag, authKey,\n sealed.subarray(0, sealed.length - this.tagLength), associatedData);\n\n // Constant-time compare tags and return null if they differ.\n if (!equal(calculatedTag,\n sealed.subarray(sealed.length - this.tagLength, sealed.length))) {\n return null;\n }\n\n // Allocate space for decrypted plaintext.\n const resultLength = sealed.length - this.tagLength;\n let result;\n if (dst) {\n if (dst.length !== resultLength) {\n throw new Error(\"ChaCha20Poly1305: incorrect destination length\");\n }\n result = dst;\n } else {\n result = new Uint8Array(resultLength);\n }\n\n // Decrypt.\n streamXOR(this._key, counter,\n sealed.subarray(0, sealed.length - this.tagLength), result, 4);\n\n // Cleanup.\n wipe(counter);\n\n return result;\n }\n\n clean(): this {\n wipe(this._key);\n return this;\n }\n\n private _authenticate(tagOut: Uint8Array, authKey: Uint8Array,\n ciphertext: Uint8Array, associatedData?: Uint8Array) {\n\n // Initialize Poly1305 with authKey.\n const h = new Poly1305(authKey);\n\n // Authenticate padded associated data.\n if (associatedData) {\n h.update(associatedData);\n if (associatedData.length % 16 > 0) {\n h.update(ZEROS.subarray(associatedData.length % 16));\n }\n }\n\n // Authenticate padded ciphertext.\n h.update(ciphertext);\n if (ciphertext.length % 16 > 0) {\n h.update(ZEROS.subarray(ciphertext.length % 16));\n }\n\n // Authenticate length of associated data.\n // XXX: can avoid allocation here?\n const length = new Uint8Array(8);\n if (associatedData) {\n writeUint64LE(associatedData.length, length);\n }\n h.update(length);\n\n // Authenticate length of ciphertext.\n writeUint64LE(ciphertext.length, length);\n h.update(length);\n\n // Get tag and copy it into tagOut.\n const tag = h.digest();\n for (let i = 0; i < tag.length; i++) {\n tagOut[i] = tag[i];\n }\n\n // Cleanup.\n h.clean();\n wipe(tag);\n wipe(length);\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package chacha implements ChaCha stream cipher.\n */\n\nimport { writeUint32LE } from \"@stablelib/binary\";\nimport { wipe } from \"@stablelib/wipe\";\n\n// Number of ChaCha rounds (ChaCha20).\nconst ROUNDS = 20;\n\n// Applies the ChaCha core function to 16-byte input,\n// 32-byte key key, and puts the result into 64-byte array out.\nfunction core(out: Uint8Array, input: Uint8Array, key: Uint8Array): void {\n let j0 = 0x61707865; // \"expa\" -- ChaCha's \"sigma\" constant\n let j1 = 0x3320646E; // \"nd 3\" for 32-byte keys\n let j2 = 0x79622D32; // \"2-by\"\n let j3 = 0x6B206574; // \"te k\"\n let j4 = (key[3] << 24) | (key[2] << 16) | (key[1] << 8) | key[0];\n let j5 = (key[7] << 24) | (key[6] << 16) | (key[5] << 8) | key[4];\n let j6 = (key[11] << 24) | (key[10] << 16) | (key[9] << 8) | key[8];\n let j7 = (key[15] << 24) | (key[14] << 16) | (key[13] << 8) | key[12];\n let j8 = (key[19] << 24) | (key[18] << 16) | (key[17] << 8) | key[16];\n let j9 = (key[23] << 24) | (key[22] << 16) | (key[21] << 8) | key[20];\n let j10 = (key[27] << 24) | (key[26] << 16) | (key[25] << 8) | key[24];\n let j11 = (key[31] << 24) | (key[30] << 16) | (key[29] << 8) | key[28];\n let j12 = (input[3] << 24) | (input[2] << 16) | (input[1] << 8) | input[0];\n let j13 = (input[7] << 24) | (input[6] << 16) | (input[5] << 8) | input[4];\n let j14 = (input[11] << 24) | (input[10] << 16) | (input[9] << 8) | input[8];\n let j15 = (input[15] << 24) | (input[14] << 16) | (input[13] << 8) | input[12];\n\n let x0 = j0;\n let x1 = j1;\n let x2 = j2;\n let x3 = j3;\n let x4 = j4;\n let x5 = j5;\n let x6 = j6;\n let x7 = j7;\n let x8 = j8;\n let x9 = j9;\n let x10 = j10;\n let x11 = j11;\n let x12 = j12;\n let x13 = j13;\n let x14 = j14;\n let x15 = j15;\n\n for (let i = 0; i < ROUNDS; i += 2) {\n x0 = x0 + x4 | 0; x12 ^= x0; x12 = x12 >>> (32 - 16) | x12 << 16;\n x8 = x8 + x12 | 0; x4 ^= x8; x4 = x4 >>> (32 - 12) | x4 << 12;\n x1 = x1 + x5 | 0; x13 ^= x1; x13 = x13 >>> (32 - 16) | x13 << 16;\n x9 = x9 + x13 | 0; x5 ^= x9; x5 = x5 >>> (32 - 12) | x5 << 12;\n\n x2 = x2 + x6 | 0; x14 ^= x2; x14 = x14 >>> (32 - 16) | x14 << 16;\n x10 = x10 + x14 | 0; x6 ^= x10; x6 = x6 >>> (32 - 12) | x6 << 12;\n x3 = x3 + x7 | 0; x15 ^= x3; x15 = x15 >>> (32 - 16) | x15 << 16;\n x11 = x11 + x15 | 0; x7 ^= x11; x7 = x7 >>> (32 - 12) | x7 << 12;\n\n x2 = x2 + x6 | 0; x14 ^= x2; x14 = x14 >>> (32 - 8) | x14 << 8;\n x10 = x10 + x14 | 0; x6 ^= x10; x6 = x6 >>> (32 - 7) | x6 << 7;\n x3 = x3 + x7 | 0; x15 ^= x3; x15 = x15 >>> (32 - 8) | x15 << 8;\n x11 = x11 + x15 | 0; x7 ^= x11; x7 = x7 >>> (32 - 7) | x7 << 7;\n\n x1 = x1 + x5 | 0; x13 ^= x1; x13 = x13 >>> (32 - 8) | x13 << 8;\n x9 = x9 + x13 | 0; x5 ^= x9; x5 = x5 >>> (32 - 7) | x5 << 7;\n x0 = x0 + x4 | 0; x12 ^= x0; x12 = x12 >>> (32 - 8) | x12 << 8;\n x8 = x8 + x12 | 0; x4 ^= x8; x4 = x4 >>> (32 - 7) | x4 << 7;\n\n x0 = x0 + x5 | 0; x15 ^= x0; x15 = x15 >>> (32 - 16) | x15 << 16;\n x10 = x10 + x15 | 0; x5 ^= x10; x5 = x5 >>> (32 - 12) | x5 << 12;\n x1 = x1 + x6 | 0; x12 ^= x1; x12 = x12 >>> (32 - 16) | x12 << 16;\n x11 = x11 + x12 | 0; x6 ^= x11; x6 = x6 >>> (32 - 12) | x6 << 12;\n\n x2 = x2 + x7 | 0; x13 ^= x2; x13 = x13 >>> (32 - 16) | x13 << 16;\n x8 = x8 + x13 | 0; x7 ^= x8; x7 = x7 >>> (32 - 12) | x7 << 12;\n x3 = x3 + x4 | 0; x14 ^= x3; x14 = x14 >>> (32 - 16) | x14 << 16;\n x9 = x9 + x14 | 0; x4 ^= x9; x4 = x4 >>> (32 - 12) | x4 << 12;\n\n x2 = x2 + x7 | 0; x13 ^= x2; x13 = x13 >>> (32 - 8) | x13 << 8;\n x8 = x8 + x13 | 0; x7 ^= x8; x7 = x7 >>> (32 - 7) | x7 << 7;\n x3 = x3 + x4 | 0; x14 ^= x3; x14 = x14 >>> (32 - 8) | x14 << 8;\n x9 = x9 + x14 | 0; x4 ^= x9; x4 = x4 >>> (32 - 7) | x4 << 7;\n\n x1 = x1 + x6 | 0; x12 ^= x1; x12 = x12 >>> (32 - 8) | x12 << 8;\n x11 = x11 + x12 | 0; x6 ^= x11; x6 = x6 >>> (32 - 7) | x6 << 7;\n x0 = x0 + x5 | 0; x15 ^= x0; x15 = x15 >>> (32 - 8) | x15 << 8;\n x10 = x10 + x15 | 0; x5 ^= x10; x5 = x5 >>> (32 - 7) | x5 << 7;\n }\n writeUint32LE(x0 + j0 | 0, out, 0);\n writeUint32LE(x1 + j1 | 0, out, 4);\n writeUint32LE(x2 + j2 | 0, out, 8);\n writeUint32LE(x3 + j3 | 0, out, 12);\n writeUint32LE(x4 + j4 | 0, out, 16);\n writeUint32LE(x5 + j5 | 0, out, 20);\n writeUint32LE(x6 + j6 | 0, out, 24);\n writeUint32LE(x7 + j7 | 0, out, 28);\n writeUint32LE(x8 + j8 | 0, out, 32);\n writeUint32LE(x9 + j9 | 0, out, 36);\n writeUint32LE(x10 + j10 | 0, out, 40);\n writeUint32LE(x11 + j11 | 0, out, 44);\n writeUint32LE(x12 + j12 | 0, out, 48);\n writeUint32LE(x13 + j13 | 0, out, 52);\n writeUint32LE(x14 + j14 | 0, out, 56);\n writeUint32LE(x15 + j15 | 0, out, 60);\n}\n\n/**\n * Encrypt src with ChaCha20 stream generated for the given 32-byte key and\n * 8-byte (as in original implementation) or 12-byte (as in RFC7539) nonce and\n * write the result into dst and return it.\n *\n * dst and src may be the same, but otherwise must not overlap.\n *\n * If nonce is 12 bytes, users should not encrypt more than 256 GiB with the\n * same key and nonce, otherwise the stream will repeat. The function will\n * throw error if counter overflows to prevent this.\n *\n * If nonce is 8 bytes, the output is practically unlimited (2^70 bytes, which\n * is more than a million petabytes). However, it is not recommended to\n * generate 8-byte nonces randomly, as the chance of collision is high.\n *\n * Never use the same key and nonce to encrypt more than one message.\n *\n * If nonceInplaceCounterLength is not 0, the nonce is assumed to be a 16-byte\n * array with stream counter in first nonceInplaceCounterLength bytes and nonce\n * in the last remaining bytes. The counter will be incremented inplace for\n * each ChaCha block. This is useful if you need to encrypt one stream of data\n * in chunks.\n */\nexport function streamXOR(key: Uint8Array, nonce: Uint8Array,\n src: Uint8Array, dst: Uint8Array, nonceInplaceCounterLength = 0): Uint8Array {\n // We only support 256-bit keys.\n if (key.length !== 32) {\n throw new Error(\"ChaCha: key size must be 32 bytes\");\n }\n\n if (dst.length < src.length) {\n throw new Error(\"ChaCha: destination is shorter than source\");\n }\n\n let nc: Uint8Array;\n let counterLength: number;\n\n if (nonceInplaceCounterLength === 0) {\n if (nonce.length !== 8 && nonce.length !== 12) {\n throw new Error(\"ChaCha nonce must be 8 or 12 bytes\");\n }\n nc = new Uint8Array(16);\n // First counterLength bytes of nc are counter, starting with zero.\n counterLength = nc.length - nonce.length;\n // Last bytes of nc after counterLength are nonce, set them.\n nc.set(nonce, counterLength);\n } else {\n if (nonce.length !== 16) {\n throw new Error(\"ChaCha nonce with counter must be 16 bytes\");\n }\n // This will update passed nonce with counter inplace.\n nc = nonce;\n counterLength = nonceInplaceCounterLength;\n }\n\n // Allocate temporary space for ChaCha block.\n const block = new Uint8Array(64);\n\n for (let i = 0; i < src.length; i += 64) {\n // Generate a block.\n core(block, nc, key);\n\n // XOR block bytes with src into dst.\n for (let j = i; j < i + 64 && j < src.length; j++) {\n dst[j] = src[j] ^ block[j - i];\n }\n\n // Increment counter.\n incrementCounter(nc, 0, counterLength);\n }\n\n // Cleanup temporary space.\n wipe(block);\n\n if (nonceInplaceCounterLength === 0) {\n // Cleanup counter.\n wipe(nc);\n }\n\n return dst;\n}\n\n/**\n * Generate ChaCha20 stream for the given 32-byte key and 8-byte or 12-byte\n * nonce and write it into dst and return it.\n *\n * Never use the same key and nonce to generate more than one stream.\n *\n * If nonceInplaceCounterLength is not 0, it behaves the same with respect to\n * the nonce as described in the streamXOR documentation.\n *\n * stream is like streamXOR with all-zero src.\n */\nexport function stream(key: Uint8Array, nonce: Uint8Array,\n dst: Uint8Array, nonceInplaceCounterLength = 0): Uint8Array {\n wipe(dst);\n return streamXOR(key, nonce, dst, dst, nonceInplaceCounterLength);\n}\n\nfunction incrementCounter(counter: Uint8Array, pos: number, len: number) {\n let carry = 1;\n while (len--) {\n carry = carry + (counter[pos] & 0xff) | 0;\n counter[pos] = carry & 0xff;\n carry >>>= 8;\n pos++;\n }\n if (carry > 0) {\n throw new Error(\"ChaCha: counter overflow\");\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package poly1305 implements Poly1305 one-time message authentication algorithm.\n */\n\nimport { equal as constantTimeEqual } from \"@stablelib/constant-time\";\nimport { wipe } from \"@stablelib/wipe\";\n\nexport const DIGEST_LENGTH = 16;\n\n// Port of Andrew Moon's Poly1305-donna-16. Public domain.\n// https://github.com/floodyberry/poly1305-donna\n\n/**\n * Poly1305 computes 16-byte authenticator of message using\n * a one-time 32-byte key.\n *\n * Important: key should be used for only one message,\n * it should never repeat.\n */\nexport class Poly1305 {\n readonly digestLength = DIGEST_LENGTH;\n\n private _buffer = new Uint8Array(16);\n private _r = new Uint16Array(10);\n private _h = new Uint16Array(10);\n private _pad = new Uint16Array(8);\n private _leftover = 0;\n private _fin = 0;\n private _finished = false;\n\n constructor(key: Uint8Array) {\n let t0 = key[0] | key[1] << 8; this._r[0] = (t0) & 0x1fff;\n let t1 = key[2] | key[3] << 8; this._r[1] = ((t0 >>> 13) | (t1 << 3)) & 0x1fff;\n let t2 = key[4] | key[5] << 8; this._r[2] = ((t1 >>> 10) | (t2 << 6)) & 0x1f03;\n let t3 = key[6] | key[7] << 8; this._r[3] = ((t2 >>> 7) | (t3 << 9)) & 0x1fff;\n let t4 = key[8] | key[9] << 8; this._r[4] = ((t3 >>> 4) | (t4 << 12)) & 0x00ff;\n this._r[5] = ((t4 >>> 1)) & 0x1ffe;\n let t5 = key[10] | key[11] << 8; this._r[6] = ((t4 >>> 14) | (t5 << 2)) & 0x1fff;\n let t6 = key[12] | key[13] << 8; this._r[7] = ((t5 >>> 11) | (t6 << 5)) & 0x1f81;\n let t7 = key[14] | key[15] << 8; this._r[8] = ((t6 >>> 8) | (t7 << 8)) & 0x1fff;\n this._r[9] = ((t7 >>> 5)) & 0x007f;\n\n this._pad[0] = key[16] | key[17] << 8;\n this._pad[1] = key[18] | key[19] << 8;\n this._pad[2] = key[20] | key[21] << 8;\n this._pad[3] = key[22] | key[23] << 8;\n this._pad[4] = key[24] | key[25] << 8;\n this._pad[5] = key[26] | key[27] << 8;\n this._pad[6] = key[28] | key[29] << 8;\n this._pad[7] = key[30] | key[31] << 8;\n }\n\n private _blocks(m: Uint8Array, mpos: number, bytes: number) {\n let hibit = this._fin ? 0 : 1 << 11;\n\n let h0 = this._h[0],\n h1 = this._h[1],\n h2 = this._h[2],\n h3 = this._h[3],\n h4 = this._h[4],\n h5 = this._h[5],\n h6 = this._h[6],\n h7 = this._h[7],\n h8 = this._h[8],\n h9 = this._h[9];\n\n let r0 = this._r[0],\n r1 = this._r[1],\n r2 = this._r[2],\n r3 = this._r[3],\n r4 = this._r[4],\n r5 = this._r[5],\n r6 = this._r[6],\n r7 = this._r[7],\n r8 = this._r[8],\n r9 = this._r[9];\n\n while (bytes >= 16) {\n let t0 = m[mpos + 0] | m[mpos + 1] << 8; h0 += (t0) & 0x1fff;\n let t1 = m[mpos + 2] | m[mpos + 3] << 8; h1 += ((t0 >>> 13) | (t1 << 3)) & 0x1fff;\n let t2 = m[mpos + 4] | m[mpos + 5] << 8; h2 += ((t1 >>> 10) | (t2 << 6)) & 0x1fff;\n let t3 = m[mpos + 6] | m[mpos + 7] << 8; h3 += ((t2 >>> 7) | (t3 << 9)) & 0x1fff;\n let t4 = m[mpos + 8] | m[mpos + 9] << 8; h4 += ((t3 >>> 4) | (t4 << 12)) & 0x1fff;\n h5 += ((t4 >>> 1)) & 0x1fff;\n let t5 = m[mpos + 10] | m[mpos + 11] << 8; h6 += ((t4 >>> 14) | (t5 << 2)) & 0x1fff;\n let t6 = m[mpos + 12] | m[mpos + 13] << 8; h7 += ((t5 >>> 11) | (t6 << 5)) & 0x1fff;\n let t7 = m[mpos + 14] | m[mpos + 15] << 8; h8 += ((t6 >>> 8) | (t7 << 8)) & 0x1fff;\n h9 += ((t7 >>> 5)) | hibit;\n\n let c = 0;\n\n let d0 = c;\n d0 += h0 * r0;\n d0 += h1 * (5 * r9);\n d0 += h2 * (5 * r8);\n d0 += h3 * (5 * r7);\n d0 += h4 * (5 * r6);\n c = (d0 >>> 13); d0 &= 0x1fff;\n d0 += h5 * (5 * r5);\n d0 += h6 * (5 * r4);\n d0 += h7 * (5 * r3);\n d0 += h8 * (5 * r2);\n d0 += h9 * (5 * r1);\n c += (d0 >>> 13); d0 &= 0x1fff;\n\n let d1 = c;\n d1 += h0 * r1;\n d1 += h1 * r0;\n d1 += h2 * (5 * r9);\n d1 += h3 * (5 * r8);\n d1 += h4 * (5 * r7);\n c = (d1 >>> 13); d1 &= 0x1fff;\n d1 += h5 * (5 * r6);\n d1 += h6 * (5 * r5);\n d1 += h7 * (5 * r4);\n d1 += h8 * (5 * r3);\n d1 += h9 * (5 * r2);\n c += (d1 >>> 13); d1 &= 0x1fff;\n\n let d2 = c;\n d2 += h0 * r2;\n d2 += h1 * r1;\n d2 += h2 * r0;\n d2 += h3 * (5 * r9);\n d2 += h4 * (5 * r8);\n c = (d2 >>> 13); d2 &= 0x1fff;\n d2 += h5 * (5 * r7);\n d2 += h6 * (5 * r6);\n d2 += h7 * (5 * r5);\n d2 += h8 * (5 * r4);\n d2 += h9 * (5 * r3);\n c += (d2 >>> 13); d2 &= 0x1fff;\n\n let d3 = c;\n d3 += h0 * r3;\n d3 += h1 * r2;\n d3 += h2 * r1;\n d3 += h3 * r0;\n d3 += h4 * (5 * r9);\n c = (d3 >>> 13); d3 &= 0x1fff;\n d3 += h5 * (5 * r8);\n d3 += h6 * (5 * r7);\n d3 += h7 * (5 * r6);\n d3 += h8 * (5 * r5);\n d3 += h9 * (5 * r4);\n c += (d3 >>> 13); d3 &= 0x1fff;\n\n let d4 = c;\n d4 += h0 * r4;\n d4 += h1 * r3;\n d4 += h2 * r2;\n d4 += h3 * r1;\n d4 += h4 * r0;\n c = (d4 >>> 13); d4 &= 0x1fff;\n d4 += h5 * (5 * r9);\n d4 += h6 * (5 * r8);\n d4 += h7 * (5 * r7);\n d4 += h8 * (5 * r6);\n d4 += h9 * (5 * r5);\n c += (d4 >>> 13); d4 &= 0x1fff;\n\n let d5 = c;\n d5 += h0 * r5;\n d5 += h1 * r4;\n d5 += h2 * r3;\n d5 += h3 * r2;\n d5 += h4 * r1;\n c = (d5 >>> 13); d5 &= 0x1fff;\n d5 += h5 * r0;\n d5 += h6 * (5 * r9);\n d5 += h7 * (5 * r8);\n d5 += h8 * (5 * r7);\n d5 += h9 * (5 * r6);\n c += (d5 >>> 13); d5 &= 0x1fff;\n\n let d6 = c;\n d6 += h0 * r6;\n d6 += h1 * r5;\n d6 += h2 * r4;\n d6 += h3 * r3;\n d6 += h4 * r2;\n c = (d6 >>> 13); d6 &= 0x1fff;\n d6 += h5 * r1;\n d6 += h6 * r0;\n d6 += h7 * (5 * r9);\n d6 += h8 * (5 * r8);\n d6 += h9 * (5 * r7);\n c += (d6 >>> 13); d6 &= 0x1fff;\n\n let d7 = c;\n d7 += h0 * r7;\n d7 += h1 * r6;\n d7 += h2 * r5;\n d7 += h3 * r4;\n d7 += h4 * r3;\n c = (d7 >>> 13); d7 &= 0x1fff;\n d7 += h5 * r2;\n d7 += h6 * r1;\n d7 += h7 * r0;\n d7 += h8 * (5 * r9);\n d7 += h9 * (5 * r8);\n c += (d7 >>> 13); d7 &= 0x1fff;\n\n let d8 = c;\n d8 += h0 * r8;\n d8 += h1 * r7;\n d8 += h2 * r6;\n d8 += h3 * r5;\n d8 += h4 * r4;\n c = (d8 >>> 13); d8 &= 0x1fff;\n d8 += h5 * r3;\n d8 += h6 * r2;\n d8 += h7 * r1;\n d8 += h8 * r0;\n d8 += h9 * (5 * r9);\n c += (d8 >>> 13); d8 &= 0x1fff;\n\n let d9 = c;\n d9 += h0 * r9;\n d9 += h1 * r8;\n d9 += h2 * r7;\n d9 += h3 * r6;\n d9 += h4 * r5;\n c = (d9 >>> 13); d9 &= 0x1fff;\n d9 += h5 * r4;\n d9 += h6 * r3;\n d9 += h7 * r2;\n d9 += h8 * r1;\n d9 += h9 * r0;\n c += (d9 >>> 13); d9 &= 0x1fff;\n\n c = (((c << 2) + c)) | 0;\n c = (c + d0) | 0;\n d0 = c & 0x1fff;\n c = (c >>> 13);\n d1 += c;\n\n h0 = d0;\n h1 = d1;\n h2 = d2;\n h3 = d3;\n h4 = d4;\n h5 = d5;\n h6 = d6;\n h7 = d7;\n h8 = d8;\n h9 = d9;\n\n mpos += 16;\n bytes -= 16;\n }\n this._h[0] = h0;\n this._h[1] = h1;\n this._h[2] = h2;\n this._h[3] = h3;\n this._h[4] = h4;\n this._h[5] = h5;\n this._h[6] = h6;\n this._h[7] = h7;\n this._h[8] = h8;\n this._h[9] = h9;\n }\n\n finish(mac: Uint8Array, macpos = 0): this {\n const g = new Uint16Array(10);\n let c: number;\n let mask: number;\n let f: number;\n let i: number;\n\n if (this._leftover) {\n i = this._leftover;\n this._buffer[i++] = 1;\n for (; i < 16; i++) {\n this._buffer[i] = 0;\n }\n this._fin = 1;\n this._blocks(this._buffer, 0, 16);\n }\n\n c = this._h[1] >>> 13;\n this._h[1] &= 0x1fff;\n for (i = 2; i < 10; i++) {\n this._h[i] += c;\n c = this._h[i] >>> 13;\n this._h[i] &= 0x1fff;\n }\n this._h[0] += (c * 5);\n c = this._h[0] >>> 13;\n this._h[0] &= 0x1fff;\n this._h[1] += c;\n c = this._h[1] >>> 13;\n this._h[1] &= 0x1fff;\n this._h[2] += c;\n\n g[0] = this._h[0] + 5;\n c = g[0] >>> 13;\n g[0] &= 0x1fff;\n for (i = 1; i < 10; i++) {\n g[i] = this._h[i] + c;\n c = g[i] >>> 13;\n g[i] &= 0x1fff;\n }\n g[9] -= (1 << 13);\n\n mask = (c ^ 1) - 1;\n for (i = 0; i < 10; i++) {\n g[i] &= mask;\n }\n mask = ~mask;\n for (i = 0; i < 10; i++) {\n this._h[i] = (this._h[i] & mask) | g[i];\n }\n\n this._h[0] = ((this._h[0]) | (this._h[1] << 13)) & 0xffff;\n this._h[1] = ((this._h[1] >>> 3) | (this._h[2] << 10)) & 0xffff;\n this._h[2] = ((this._h[2] >>> 6) | (this._h[3] << 7)) & 0xffff;\n this._h[3] = ((this._h[3] >>> 9) | (this._h[4] << 4)) & 0xffff;\n this._h[4] = ((this._h[4] >>> 12) | (this._h[5] << 1) | (this._h[6] << 14)) & 0xffff;\n this._h[5] = ((this._h[6] >>> 2) | (this._h[7] << 11)) & 0xffff;\n this._h[6] = ((this._h[7] >>> 5) | (this._h[8] << 8)) & 0xffff;\n this._h[7] = ((this._h[8] >>> 8) | (this._h[9] << 5)) & 0xffff;\n\n f = this._h[0] + this._pad[0];\n this._h[0] = f & 0xffff;\n for (i = 1; i < 8; i++) {\n f = (((this._h[i] + this._pad[i]) | 0) + (f >>> 16)) | 0;\n this._h[i] = f & 0xffff;\n }\n\n mac[macpos + 0] = this._h[0] >>> 0;\n mac[macpos + 1] = this._h[0] >>> 8;\n mac[macpos + 2] = this._h[1] >>> 0;\n mac[macpos + 3] = this._h[1] >>> 8;\n mac[macpos + 4] = this._h[2] >>> 0;\n mac[macpos + 5] = this._h[2] >>> 8;\n mac[macpos + 6] = this._h[3] >>> 0;\n mac[macpos + 7] = this._h[3] >>> 8;\n mac[macpos + 8] = this._h[4] >>> 0;\n mac[macpos + 9] = this._h[4] >>> 8;\n mac[macpos + 10] = this._h[5] >>> 0;\n mac[macpos + 11] = this._h[5] >>> 8;\n mac[macpos + 12] = this._h[6] >>> 0;\n mac[macpos + 13] = this._h[6] >>> 8;\n mac[macpos + 14] = this._h[7] >>> 0;\n mac[macpos + 15] = this._h[7] >>> 8;\n\n this._finished = true;\n return this;\n }\n\n update(m: Uint8Array): this {\n let mpos = 0;\n let bytes = m.length;\n let want: number;\n\n if (this._leftover) {\n want = (16 - this._leftover);\n if (want > bytes) {\n want = bytes;\n }\n for (let i = 0; i < want; i++) {\n this._buffer[this._leftover + i] = m[mpos + i];\n }\n bytes -= want;\n mpos += want;\n this._leftover += want;\n if (this._leftover < 16) {\n return this;\n }\n this._blocks(this._buffer, 0, 16);\n this._leftover = 0;\n }\n\n if (bytes >= 16) {\n want = bytes - (bytes % 16);\n this._blocks(m, mpos, want);\n mpos += want;\n bytes -= want;\n }\n\n if (bytes) {\n for (let i = 0; i < bytes; i++) {\n this._buffer[this._leftover + i] = m[mpos + i];\n }\n this._leftover += bytes;\n }\n\n return this;\n }\n\n digest(): Uint8Array {\n // TODO(dchest): it behaves differently than other hashes/HMAC,\n // because it throws when finished — others just return saved result.\n if (this._finished) {\n throw new Error(\"Poly1305 was finished\");\n }\n let mac = new Uint8Array(16);\n this.finish(mac);\n return mac;\n }\n\n clean(): this {\n wipe(this._buffer);\n wipe(this._r);\n wipe(this._h);\n wipe(this._pad);\n this._leftover = 0;\n this._fin = 0;\n this._finished = true; // mark as finished even if not\n return this;\n }\n}\n\n/**\n * Returns 16-byte authenticator of data using a one-time 32-byte key.\n *\n * Important: key should be used for only one message, it should never repeat.\n */\nexport function oneTimeAuth(key: Uint8Array, data: Uint8Array): Uint8Array {\n const h = new Poly1305(key);\n h.update(data);\n const digest = h.digest();\n h.clean();\n return digest;\n}\n\n/**\n * Returns true if two authenticators are 16-byte long and equal.\n * Uses contant-time comparison to avoid leaking timing information.\n */\nexport function equal(a: Uint8Array, b: Uint8Array): boolean {\n if (a.length !== DIGEST_LENGTH || b.length !== DIGEST_LENGTH) {\n return false;\n }\n return constantTimeEqual(a, b);\n}\n","import debug from 'debug'\nimport { DUMP_SESSION_KEYS } from './constants'\nimport { KeyPair } from './@types/libp2p'\nimport { NoiseSession } from './@types/handshake'\n\nexport const logger = debug('libp2p:noise')\n\nlet keyLogger\nif (DUMP_SESSION_KEYS) {\n keyLogger = logger\n} else {\n keyLogger = () => { /* do nothing */ }\n}\n\nexport function logLocalStaticKeys (s: KeyPair): void {\n keyLogger(`LOCAL_STATIC_PUBLIC_KEY ${s.publicKey.toString('hex')}`)\n keyLogger(`LOCAL_STATIC_PRIVATE_KEY ${s.privateKey.toString('hex')}`)\n}\n\nexport function logLocalEphemeralKeys (e: KeyPair|undefined): void {\n if (e) {\n keyLogger(`LOCAL_PUBLIC_EPHEMERAL_KEY ${e.publicKey.toString('hex')}`)\n keyLogger(`LOCAL_PRIVATE_EPHEMERAL_KEY ${e.privateKey.toString('hex')}`)\n } else {\n keyLogger('Missing local ephemeral keys.')\n }\n}\n\nexport function logRemoteStaticKey (rs: Buffer): void {\n keyLogger(`REMOTE_STATIC_PUBLIC_KEY ${rs.toString('hex')}`)\n}\n\nexport function logRemoteEphemeralKey (re: Buffer): void {\n keyLogger(`REMOTE_EPHEMERAL_PUBLIC_KEY ${re.toString('hex')}`)\n}\n\nexport function logCipherState (session: NoiseSession): void {\n if (session.cs1 && session.cs2) {\n keyLogger(`CIPHER_STATE_1 ${session.cs1.n} ${session.cs1.k.toString('hex')}`)\n keyLogger(`CIPHER_STATE_2 ${session.cs2.n} ${session.cs2.k.toString('hex')}`)\n } else {\n keyLogger('Missing cipher state.')\n }\n}\n","export const NOISE_MSG_MAX_LENGTH_BYTES = 65535\nexport const NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG = NOISE_MSG_MAX_LENGTH_BYTES - 16\n\nexport const DUMP_SESSION_KEYS = process.env.DUMP_SESSION_KEYS\n","import { Buffer } from 'buffer'\nimport { bytes } from './@types/basic'\nimport { MessageBuffer } from './@types/handshake'\nimport BufferList from 'bl'\n\nexport const uint16BEEncode = (value: number, target: Buffer, offset: number): Buffer => {\n target = target || Buffer.allocUnsafe(2)\n target.writeUInt16BE(value, offset)\n return target\n}\nuint16BEEncode.bytes = 2\n\nexport const uint16BEDecode = (data: Buffer | BufferList): number => {\n if (data.length < 2) throw RangeError('Could not decode int16BE')\n return data.readUInt16BE(0)\n}\nuint16BEDecode.bytes = 2\n\n// Note: IK and XX encoder usage is opposite (XX uses in stages encode0 where IK uses encode1)\n\nexport function encode0 (message: MessageBuffer): bytes {\n return Buffer.concat([message.ne, message.ciphertext])\n}\n\nexport function encode1 (message: MessageBuffer): bytes {\n return Buffer.concat([message.ne, message.ns, message.ciphertext])\n}\n\nexport function encode2 (message: MessageBuffer): bytes {\n return Buffer.concat([message.ns, message.ciphertext])\n}\n\nexport function decode0 (input: bytes): MessageBuffer {\n if (input.length < 32) {\n throw new Error('Cannot decode stage 0 MessageBuffer: length less than 32 bytes.')\n }\n\n return {\n ne: input.slice(0, 32),\n ciphertext: input.slice(32, input.length),\n ns: Buffer.alloc(0)\n }\n}\n\nexport function decode1 (input: bytes): MessageBuffer {\n if (input.length < 80) {\n throw new Error('Cannot decode stage 1 MessageBuffer: length less than 80 bytes.')\n }\n\n return {\n ne: input.slice(0, 32),\n ns: input.slice(32, 80),\n ciphertext: input.slice(80, input.length)\n }\n}\n\nexport function decode2 (input: bytes): MessageBuffer {\n if (input.length < 48) {\n throw new Error('Cannot decode stage 2 MessageBuffer: length less than 48 bytes.')\n }\n\n return {\n ne: Buffer.alloc(0),\n ns: input.slice(0, 48),\n ciphertext: input.slice(48, input.length)\n }\n}\n","import { WrappedConnection } from './noise'\nimport { IK } from './handshakes/ik'\nimport { NoiseSession } from './@types/handshake'\nimport { bytes, bytes32 } from './@types/basic'\nimport { KeyPair } from './@types/libp2p'\nimport { IHandshake } from './@types/handshake-interface'\nimport { Buffer } from 'buffer'\nimport { decode0, decode1, encode0, encode1 } from './encoder'\nimport { decodePayload, getPeerIdFromPayload, verifySignedPayload } from './utils'\nimport { FailedIKError } from './errors'\nimport {\n logger,\n logLocalStaticKeys,\n logRemoteStaticKey,\n logLocalEphemeralKeys,\n logRemoteEphemeralKey,\n logCipherState\n} from './logger'\nimport PeerId from 'peer-id'\n\nexport class IKHandshake implements IHandshake {\n public isInitiator: boolean\n public session: NoiseSession\n public remotePeer!: PeerId\n public remoteEarlyData: Buffer\n\n private readonly payload: bytes\n private readonly prologue: bytes32\n private readonly staticKeypair: KeyPair\n private readonly connection: WrappedConnection\n private readonly ik: IK\n\n constructor (\n isInitiator: boolean,\n payload: bytes,\n prologue: bytes32,\n staticKeypair: KeyPair,\n connection: WrappedConnection,\n remoteStaticKey: bytes,\n remotePeer?: PeerId,\n handshake?: IK\n ) {\n this.isInitiator = isInitiator\n this.payload = Buffer.from(payload)\n this.prologue = prologue\n this.staticKeypair = staticKeypair\n this.connection = connection\n if (remotePeer) {\n this.remotePeer = remotePeer\n }\n this.ik = handshake ?? new IK()\n this.session = this.ik.initSession(this.isInitiator, this.prologue, this.staticKeypair, remoteStaticKey)\n this.remoteEarlyData = Buffer.alloc(0)\n }\n\n public async stage0 (): Promise {\n logLocalStaticKeys(this.session.hs.s)\n logRemoteStaticKey(this.session.hs.rs)\n if (this.isInitiator) {\n logger('IK Stage 0 - Initiator sending message...')\n const messageBuffer = this.ik.sendMessage(this.session, this.payload)\n this.connection.writeLP(encode1(messageBuffer))\n logger('IK Stage 0 - Initiator sent message.')\n logLocalEphemeralKeys(this.session.hs.e)\n } else {\n logger('IK Stage 0 - Responder receiving message...')\n const receivedMsg = await this.connection.readLP()\n try {\n const receivedMessageBuffer = decode1(receivedMsg.slice())\n const { plaintext, valid } = this.ik.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('ik handshake stage 0 decryption validation fail')\n }\n logger('IK Stage 0 - Responder got message, going to verify payload.')\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n await verifySignedPayload(this.session.hs.rs, decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n logger('IK Stage 0 - Responder successfully verified payload!')\n logRemoteEphemeralKey(this.session.hs.re)\n } catch (e) {\n const err = e as Error\n logger('Responder breaking up with IK handshake in stage 0.')\n\n throw new FailedIKError(receivedMsg, `Error occurred while verifying initiator's signed payload: ${err.message}`)\n }\n }\n }\n\n public async stage1 (): Promise {\n if (this.isInitiator) {\n logger('IK Stage 1 - Initiator receiving message...')\n const receivedMsg = (await this.connection.readLP()).slice()\n const receivedMessageBuffer = decode0(Buffer.from(receivedMsg))\n const { plaintext, valid } = this.ik.recvMessage(this.session, receivedMessageBuffer)\n logger('IK Stage 1 - Initiator got message, going to verify payload.')\n try {\n if (!valid) {\n throw new Error('ik stage 1 decryption validation fail')\n }\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n await verifySignedPayload(receivedMessageBuffer.ns.slice(0, 32), decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n logger('IK Stage 1 - Initiator successfully verified payload!')\n logRemoteEphemeralKey(this.session.hs.re)\n } catch (e) {\n const err = e as Error\n logger('Initiator breaking up with IK handshake in stage 1.')\n throw new FailedIKError(receivedMsg, `Error occurred while verifying responder's signed payload: ${err.message}`)\n }\n } else {\n logger('IK Stage 1 - Responder sending message...')\n const messageBuffer = this.ik.sendMessage(this.session, this.payload)\n this.connection.writeLP(encode0(messageBuffer))\n logger('IK Stage 1 - Responder sent message...')\n logLocalEphemeralKeys(this.session.hs.e)\n }\n logCipherState(this.session)\n }\n\n public decrypt (ciphertext: bytes, session: NoiseSession): {plaintext: bytes, valid: boolean} {\n const cs = this.getCS(session, false)\n return this.ik.decryptWithAd(cs, Buffer.alloc(0), ciphertext)\n }\n\n public encrypt (plaintext: Buffer, session: NoiseSession): Buffer {\n const cs = this.getCS(session)\n return this.ik.encryptWithAd(cs, Buffer.alloc(0), plaintext)\n }\n\n public getLocalEphemeralKeys (): KeyPair {\n if (!this.session.hs.e) {\n throw new Error('Ephemeral keys do not exist.')\n }\n\n return this.session.hs.e\n }\n\n private getCS (session: NoiseSession, encryption = true) {\n if (!session.cs1 || !session.cs2) {\n throw new Error('Handshake not completed properly, cipher state does not exist.')\n }\n\n if (this.isInitiator) {\n return encryption ? session.cs1 : session.cs2\n } else {\n return encryption ? session.cs2 : session.cs1\n }\n }\n\n private setRemoteEarlyData (data: Uint8Array|null|undefined): void {\n if (data) {\n this.remoteEarlyData = Buffer.from(data.buffer, data.byteOffset, data.length)\n }\n }\n}\n","import { Buffer } from 'buffer'\nimport { CipherState, HandshakeState, MessageBuffer, NoiseSession } from '../@types/handshake'\nimport { bytes, bytes32 } from '../@types/basic'\nimport { generateKeypair, isValidPublicKey } from '../utils'\nimport { AbstractHandshake } from './abstract-handshake'\nimport { KeyPair } from '../@types/libp2p'\n\nexport class IK extends AbstractHandshake {\n public initSession (initiator: boolean, prologue: bytes32, s: KeyPair, rs: bytes32): NoiseSession {\n const psk = this.createEmptyKey()\n\n let hs\n if (initiator) {\n hs = this.initializeInitiator(prologue, s, rs, psk)\n } else {\n hs = this.initializeResponder(prologue, s, rs, psk)\n }\n\n return {\n hs,\n i: initiator,\n mc: 0\n }\n }\n\n public sendMessage (session: NoiseSession, message: bytes): MessageBuffer {\n let messageBuffer: MessageBuffer\n if (session.mc === 0) {\n messageBuffer = this.writeMessageA(session.hs, message)\n } else if (session.mc === 1) {\n const { messageBuffer: mb, h, cs1, cs2 } = this.writeMessageB(session.hs, message)\n messageBuffer = mb\n session.h = h\n session.cs1 = cs1\n session.cs2 = cs2\n } else if (session.mc > 1) {\n if (session.i) {\n if (!session.cs1) {\n throw new Error('CS1 (cipher state) is not defined')\n }\n\n messageBuffer = this.writeMessageRegular(session.cs1, message)\n } else {\n if (!session.cs2) {\n throw new Error('CS2 (cipher state) is not defined')\n }\n\n messageBuffer = this.writeMessageRegular(session.cs2, message)\n }\n } else {\n throw new Error('Session invalid.')\n }\n\n session.mc++\n return messageBuffer\n }\n\n public recvMessage (session: NoiseSession, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n let plaintext = Buffer.alloc(0); let valid = false\n if (session.mc === 0) {\n ({ plaintext, valid } = this.readMessageA(session.hs, message))\n }\n if (session.mc === 1) {\n const { plaintext: pt, valid: v, h, cs1, cs2 } = this.readMessageB(session.hs, message)\n plaintext = pt\n valid = v\n session.h = h\n session.cs1 = cs1\n session.cs2 = cs2\n }\n session.mc++\n return { plaintext, valid }\n }\n\n private writeMessageA (hs: HandshakeState, payload: bytes): MessageBuffer {\n hs.e = generateKeypair()\n const ne = hs.e.publicKey\n this.mixHash(hs.ss, ne)\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.rs))\n const spk = Buffer.from(hs.s.publicKey)\n const ns = this.encryptAndHash(hs.ss, spk)\n\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.rs))\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n\n return { ne, ns, ciphertext }\n }\n\n private writeMessageB (hs: HandshakeState, payload: bytes) {\n hs.e = generateKeypair()\n const ne = hs.e.publicKey\n this.mixHash(hs.ss, ne)\n\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.re))\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.rs))\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n const ns = this.createEmptyKey()\n const messageBuffer: MessageBuffer = { ne, ns, ciphertext }\n const { cs1, cs2 } = this.split(hs.ss)\n\n return { messageBuffer, cs1, cs2, h: hs.ss.h }\n }\n\n private readMessageA (hs: HandshakeState, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n if (isValidPublicKey(message.ne)) {\n hs.re = message.ne\n }\n\n this.mixHash(hs.ss, hs.re)\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.re))\n const { plaintext: ns, valid: valid1 } = this.decryptAndHash(hs.ss, message.ns)\n if (valid1 && ns.length === 32 && isValidPublicKey(ns)) {\n hs.rs = ns\n }\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.rs))\n const { plaintext, valid: valid2 } = this.decryptAndHash(hs.ss, message.ciphertext)\n return { plaintext, valid: (valid1 && valid2) }\n }\n\n private readMessageB (hs: HandshakeState, message: MessageBuffer): {h: bytes, plaintext: bytes, valid: boolean, cs1: CipherState, cs2: CipherState} {\n if (isValidPublicKey(message.ne)) {\n hs.re = message.ne\n }\n\n this.mixHash(hs.ss, hs.re)\n if (!hs.e) {\n throw new Error('Handshake state should contain ephemeral key by now.')\n }\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.re))\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.re))\n const { plaintext, valid } = this.decryptAndHash(hs.ss, message.ciphertext)\n const { cs1, cs2 } = this.split(hs.ss)\n\n return { h: hs.ss.h, valid, plaintext, cs1, cs2 }\n }\n\n private initializeInitiator (prologue: bytes32, s: KeyPair, rs: bytes32, psk: bytes32): HandshakeState {\n const name = 'Noise_IK_25519_ChaChaPoly_SHA256'\n const ss = this.initializeSymmetric(name)\n this.mixHash(ss, prologue)\n this.mixHash(ss, rs)\n const re = Buffer.alloc(32)\n\n return { ss, s, rs, re, psk }\n }\n\n private initializeResponder (prologue: bytes32, s: KeyPair, rs: bytes32, psk: bytes32): HandshakeState {\n const name = 'Noise_IK_25519_ChaChaPoly_SHA256'\n const ss = this.initializeSymmetric(name)\n this.mixHash(ss, prologue)\n this.mixHash(ss, s.publicKey)\n const re = Buffer.alloc(32)\n\n return { ss, s, rs, re, psk }\n }\n}\n","import BufferList from 'bl'\n\nexport class FailedIKError extends Error {\n public initialMsg: string|BufferList|Buffer\n\n constructor (initialMsg: string|BufferList|Buffer, message?: string) {\n super(message)\n\n this.initialMsg = initialMsg\n this.name = 'FailedIKhandshake'\n }\n}\n","import { Buffer } from 'buffer'\nimport { XXHandshake } from './handshake-xx'\nimport { XX } from './handshakes/xx'\nimport { KeyPair } from './@types/libp2p'\nimport { bytes, bytes32 } from './@types/basic'\nimport { decodePayload, getPeerIdFromPayload, verifySignedPayload } from './utils'\nimport { logger, logLocalEphemeralKeys, logRemoteEphemeralKey, logRemoteStaticKey } from './logger'\nimport { WrappedConnection } from './noise'\nimport { decode0, decode1 } from './encoder'\nimport PeerId from 'peer-id'\n\nexport class XXFallbackHandshake extends XXHandshake {\n private readonly ephemeralKeys?: KeyPair\n private readonly initialMsg: bytes\n\n constructor (\n isInitiator: boolean,\n payload: bytes,\n prologue: bytes32,\n staticKeypair: KeyPair,\n connection: WrappedConnection,\n initialMsg: bytes,\n remotePeer?: PeerId,\n ephemeralKeys?: KeyPair,\n handshake?: XX\n ) {\n super(isInitiator, payload, prologue, staticKeypair, connection, remotePeer, handshake)\n if (ephemeralKeys) {\n this.ephemeralKeys = ephemeralKeys\n }\n this.initialMsg = initialMsg\n }\n\n // stage 0\n // eslint-disable-next-line require-await\n public async propose (): Promise {\n if (this.isInitiator) {\n this.xx.sendMessage(this.session, Buffer.alloc(0), this.ephemeralKeys)\n logger('XX Fallback Stage 0 - Initialized state as the first message was sent by initiator.')\n logLocalEphemeralKeys(this.session.hs.e)\n } else {\n logger('XX Fallback Stage 0 - Responder decoding initial msg from IK.')\n const receivedMessageBuffer = decode0(this.initialMsg)\n const { valid } = this.xx.recvMessage(this.session, {\n ne: receivedMessageBuffer.ne,\n ns: Buffer.alloc(0),\n ciphertext: Buffer.alloc(0)\n })\n if (!valid) {\n throw new Error('xx fallback stage 0 decryption validation fail')\n }\n logger('XX Fallback Stage 0 - Responder used received message from IK.')\n logRemoteEphemeralKey(this.session.hs.re)\n }\n }\n\n // stage 1\n public async exchange (): Promise {\n if (this.isInitiator) {\n const receivedMessageBuffer = decode1(this.initialMsg)\n const { plaintext, valid } = this.xx.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('xx fallback stage 1 decryption validation fail')\n }\n logger('XX Fallback Stage 1 - Initiator used received message from IK.')\n logRemoteEphemeralKey(this.session.hs.re)\n logRemoteStaticKey(this.session.hs.rs)\n\n logger(\"Initiator going to check remote's signature...\")\n try {\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n await verifySignedPayload(this.session.hs.rs, decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n } catch (e) {\n const err = e as Error\n throw new Error(`Error occurred while verifying signed payload from responder: ${err.message}`)\n }\n logger('All good with the signature!')\n } else {\n logger('XX Fallback Stage 1 - Responder start')\n await super.exchange()\n logger('XX Fallback Stage 1 - Responder end')\n }\n }\n}\n","import { Buffer } from 'buffer'\nimport { IHandshake } from './@types/handshake-interface'\nimport { NOISE_MSG_MAX_LENGTH_BYTES, NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG } from './constants'\n\ninterface IReturnEncryptionWrapper {\n (source: Iterable): AsyncIterableIterator\n}\n\n// Returns generator that encrypts payload from the user\nexport function encryptStream (handshake: IHandshake): IReturnEncryptionWrapper {\n return async function * (source) {\n for await (const chunk of source) {\n const chunkBuffer = Buffer.from(chunk.buffer, chunk.byteOffset, chunk.length)\n\n for (let i = 0; i < chunkBuffer.length; i += NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG) {\n let end = i + NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG\n if (end > chunkBuffer.length) {\n end = chunkBuffer.length\n }\n\n const data = handshake.encrypt(chunkBuffer.slice(i, end), handshake.session)\n yield data\n }\n }\n }\n}\n\n// Decrypt received payload to the user\nexport function decryptStream (handshake: IHandshake): IReturnEncryptionWrapper {\n return async function * (source) {\n for await (const chunk of source) {\n const chunkBuffer = Buffer.from(chunk.buffer, chunk.byteOffset, chunk.length)\n\n for (let i = 0; i < chunkBuffer.length; i += NOISE_MSG_MAX_LENGTH_BYTES) {\n let end = i + NOISE_MSG_MAX_LENGTH_BYTES\n if (end > chunkBuffer.length) {\n end = chunkBuffer.length\n }\n\n const chunk = chunkBuffer.slice(i, end)\n const { plaintext: decrypted, valid } = await handshake.decrypt(chunk, handshake.session)\n if (!valid) {\n throw new Error('Failed to validate decrypted chunk')\n }\n yield decrypted\n }\n }\n }\n}\n","import { bytes32 } from './@types/basic'\nimport PeerId from 'peer-id'\n\n/**\n * Storage for static keys of previously connected peers.\n */\nclass Keycache {\n private readonly storage = new Map()\n\n public store (peerId: PeerId, key: bytes32): void {\n this.storage.set(peerId.id, key)\n }\n\n public load (peerId?: PeerId): bytes32 | null {\n if (!peerId) {\n return null\n }\n return this.storage.get(peerId.id) ?? null\n }\n\n public resetStorage (): void {\n this.storage.clear()\n }\n}\n\nconst KeyCache = new Keycache()\nexport {\n KeyCache\n}\n","'use strict'\n\nconst { EventEmitter } = require('events')\nconst errcode = require('err-code')\n\nconst libp2pRecord = require('libp2p-record')\nconst { MemoryDatastore } = require('datastore-core/memory')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst RoutingTable = require('./routing-table')\nconst utils = require('./utils')\nconst c = require('./constants')\nconst Network = require('./network')\nconst contentFetching = require('./content-fetching')\nconst contentRouting = require('./content-routing')\nconst peerRouting = require('./peer-routing')\nconst Message = require('./message')\nconst Providers = require('./providers')\nconst QueryManager = require('./query-manager')\n\nconst Record = libp2pRecord.Record\n\n/**\n * @typedef {*} Libp2p\n * @typedef {*} PeerStore\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('interface-datastore').Datastore} Datastore\n * @typedef {*} Dialer\n * @typedef {*} Registrar\n * @typedef {import('multiformats/cid').CID} CID\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {object} PeerData\n * @property {PeerId} id\n * @property {Multiaddr[]} multiaddrs\n */\n\n/**\n * A DHT implementation modeled after Kademlia with S/Kademlia modifications.\n * Original implementation in go: https://github.com/libp2p/go-libp2p-kad-dht.\n */\nclass KadDHT extends EventEmitter {\n /**\n * Create a new KadDHT.\n *\n * @param {Object} props\n * @param {Libp2p} props.libp2p - the libp2p instance\n * @param {Dialer} props.dialer - libp2p dialer instance\n * @param {PeerId} props.peerId - peer's peerId\n * @param {PeerStore} props.peerStore - libp2p peerStore\n * @param {Registrar} props.registrar - libp2p registrar instance\n * @param {string} [props.protocolPrefix = '/ipfs'] - libp2p registrar handle protocol\n * @param {boolean} [props.forceProtocolLegacy = false] - WARNING: this is not recommended and should only be used for legacy purposes\n * @param {number} props.kBucketSize - k-bucket size (default 20)\n * @param {boolean} props.clientMode - If true, the DHT will not respond to queries. This should be true if your node will not be dialable. (default: false)\n * @param {number} props.concurrency - alpha concurrency of queries (default 3)\n * @param {Datastore} props.datastore - datastore (default MemoryDatastore)\n * @param {object} props.validators - validators object with namespace as keys and function(key, record, callback)\n * @param {object} props.selectors - selectors object with namespace as keys and function(key, records)\n * @param {function(import('libp2p-record').Record, PeerId): void} [props.onPut] - Called when an entry is added to or changed in the datastore\n * @param {function(import('libp2p-record').Record): void} [props.onRemove] - Called when an entry is removed from the datastore\n */\n constructor ({\n libp2p,\n dialer,\n peerId,\n peerStore,\n registrar,\n protocolPrefix = '/ipfs',\n forceProtocolLegacy = false,\n datastore = new MemoryDatastore(),\n kBucketSize = c.K,\n clientMode = false,\n concurrency = c.ALPHA,\n validators = {},\n selectors = {},\n onPut = () => {},\n onRemove = () => {}\n }) {\n super()\n\n if (!dialer) {\n throw new Error('libp2p-kad-dht requires an instance of Dialer')\n }\n\n /**\n * Local reference to the libp2p instance. May be undefined.\n *\n * @type {Libp2p}\n */\n this.libp2p = libp2p\n\n /**\n * Local reference to the libp2p dialer instance\n *\n * @type {Dialer}\n */\n this.dialer = dialer\n\n /**\n * Local peer-id\n *\n * @type {PeerId}\n */\n this.peerId = peerId\n\n /**\n * Local PeerStore\n *\n * @type {PeerStore}\n */\n this.peerStore = peerStore\n\n /**\n * Local peer info\n *\n * @type {Registrar}\n */\n this.registrar = registrar\n\n /**\n * Registrar protocol\n *\n * @type {string}\n */\n this.protocol = protocolPrefix + (forceProtocolLegacy ? '' : c.PROTOCOL_DHT)\n\n /**\n * k-bucket size\n *\n * @type {number}\n */\n this.kBucketSize = kBucketSize\n\n this._clientMode = clientMode\n\n /**\n * ALPHA concurrency at which each query path with run, defaults to 3\n *\n * @type {number}\n */\n this.concurrency = concurrency\n\n /**\n * Number of disjoint query paths to use\n * This is set to `kBucketSize`/2 per the S/Kademlia paper\n *\n * @type {number}\n */\n this.disjointPaths = Math.ceil(this.kBucketSize / 2)\n\n /**\n * The routing table.\n *\n * @type {RoutingTable}\n */\n this.routingTable = new RoutingTable(this, { kBucketSize: this.kBucketSize })\n\n /**\n * Reference to the datastore, uses an in-memory store if none given.\n *\n * @type {Datastore}\n */\n this.datastore = datastore\n\n /**\n * Provider management\n *\n * @type {Providers}\n */\n this.providers = new Providers(this.datastore, this.peerId)\n\n this.validators = {\n pk: libp2pRecord.validator.validators.pk,\n ...validators\n }\n\n this.selectors = {\n pk: libp2pRecord.selection.selectors.pk,\n ...selectors\n }\n\n this.network = new Network(this)\n\n this._log = utils.logger(this.peerId)\n\n /**\n * Keeps track of running queries\n *\n * @type {QueryManager}\n */\n this._queryManager = new QueryManager()\n\n this._running = false\n\n // DHT components\n this.contentFetching = contentFetching(this)\n this.contentRouting = contentRouting(this)\n this.peerRouting = peerRouting(this)\n\n // datastore events\n this.onPut = onPut\n this.onRemove = onRemove\n }\n\n /**\n * Is this DHT running.\n */\n get isStarted () {\n return this._running\n }\n\n /**\n * Start listening to incoming connections.\n */\n start () {\n this._running = true\n\n return Promise.all([\n this.providers.start(),\n this._queryManager.start(),\n this.network.start(),\n this.routingTable.start()\n ])\n }\n\n /**\n * Stop accepting incoming connections and sending outgoing\n * messages.\n */\n stop () {\n this._running = false\n\n return Promise.all([\n this.providers.stop(),\n this._queryManager.stop(),\n this.network.stop(),\n this.routingTable.stop()\n ])\n }\n\n /**\n * Store the given key/value pair in the DHT.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n * @param {Object} [options] - put options\n * @param {number} [options.minPeers] - minimum number of peers required to successfully put (default: closestPeers.length)\n * @returns {Promise}\n */\n async put (key, value, options = {}) { // eslint-disable-line require-await\n return this.contentFetching.put(key, value, options)\n }\n\n /**\n * Get the value to the given key.\n * Times out after 1 minute by default.\n *\n * @param {Uint8Array} key\n * @param {Object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n * @returns {Promise}\n */\n async get (key, options = {}) { // eslint-disable-line require-await\n return this.contentFetching.get(key, options)\n }\n\n /**\n * Get the `n` values to the given key without sorting.\n *\n * @param {Uint8Array} key\n * @param {number} nvals\n * @param {Object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n */\n async getMany (key, nvals, options = {}) { // eslint-disable-line require-await\n return this.contentFetching.getMany(key, nvals, options)\n }\n\n /**\n * Remove the given key from the local datastore.\n *\n * @param {Uint8Array} key\n */\n async removeLocal (key) {\n this._log(`removeLocal: ${uint8ArrayToString(key, 'base32')}`)\n const dsKey = utils.bufferToKey(key)\n\n try {\n await this.datastore.delete(dsKey)\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n return undefined\n }\n throw err\n }\n }\n\n /**\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n */\n async _putLocal (key, value) {\n this._log(`_putLocal: ${uint8ArrayToString(key, 'base32')}`)\n const dsKey = utils.bufferToKey(key)\n\n await this.datastore.put(dsKey, value)\n }\n\n // ----------- Content Routing\n\n /**\n * Announce to the network that we can provide given key's value.\n *\n * @param {CID} key\n * @returns {Promise}\n */\n async provide (key) { // eslint-disable-line require-await\n return this.contentRouting.provide(key)\n }\n\n /**\n * Search the dht for up to `K` providers of the given CID.\n *\n * @param {CID} key\n * @param {Object} [options] - findProviders options\n * @param {number} [options.timeout=60000] - how long the query should maximally run, in milliseconds (default: 60000)\n * @param {number} [options.maxNumProviders=5] - maximum number of providers to find\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * findProviders (key, options = { timeout: 6000, maxNumProviders: 5 }) {\n for await (const peerData of this.contentRouting.findProviders(key, options)) {\n yield peerData\n }\n }\n\n // ----------- Peer Routing -----------\n\n /**\n * Search for a peer with the given ID.\n *\n * @param {PeerId} id\n * @param {Object} [options] - findPeer options\n * @param {number} [options.timeout=60000] - how long the query should maximally run, in milliseconds (default: 60000)\n * @returns {Promise<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async findPeer (id, options = { timeout: 60000 }) { // eslint-disable-line require-await\n return this.peerRouting.findPeer(id, options)\n }\n\n /**\n * Kademlia 'node lookup' operation.\n *\n * @param {Uint8Array} key\n * @param {Object} [options]\n * @param {boolean} [options.shallow = false] - shallow query\n */\n async * getClosestPeers (key, options = { shallow: false }) {\n yield * this.peerRouting.getClosestPeers(key, options)\n }\n\n /**\n * Get the public key for the given peer id.\n *\n * @param {PeerId} peer\n */\n getPublicKey (peer) {\n return this.peerRouting.getPublicKey(peer)\n }\n\n // ----------- Discovery -----------\n\n /**\n * @param {PeerId} peerId\n * @param {Multiaddr[]} multiaddrs\n */\n _peerDiscovered (peerId, multiaddrs) {\n this.emit('peer', {\n id: peerId,\n multiaddrs\n })\n }\n\n // ----------- Internals -----------\n\n /**\n * Returns the routing tables closest peers, for the key of\n * the message.\n *\n * @param {Message} msg\n */\n async _nearestPeersToQuery (msg) {\n const key = await utils.convertBuffer(msg.key)\n const ids = this.routingTable.closestPeers(key, this.kBucketSize)\n\n return ids.map((p) => {\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peer = this.peerStore.get(p)\n\n return {\n id: p,\n multiaddrs: peer ? peer.addresses.map((address) => address.multiaddr) : []\n }\n })\n }\n\n /**\n * Get the nearest peers to the given query, but iff closer\n * than self.\n *\n * @param {Message} msg\n * @param {PeerId} peerId\n */\n async _betterPeersToQuery (msg, peerId) {\n this._log('betterPeersToQuery')\n const closer = await this._nearestPeersToQuery(msg)\n\n return closer.filter((closer) => {\n if (this._isSelf(closer.id)) {\n // Should bail, not sure\n this._log.error('trying to return self as closer')\n return false\n }\n\n return !closer.id.isEqual(peerId)\n })\n }\n\n /**\n * Try to fetch a given record by from the local datastore.\n * Returns the record iff it is still valid, meaning\n * - it was either authored by this node, or\n * - it was received less than `MAX_RECORD_AGE` ago.\n *\n * @param {Uint8Array} key\n */\n\n async _checkLocalDatastore (key) {\n this._log(`checkLocalDatastore: ${uint8ArrayToString(key)} %b`, key)\n const dsKey = utils.bufferToKey(key)\n\n // Fetch value from ds\n let rawRecord\n try {\n rawRecord = await this.datastore.get(dsKey)\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n return undefined\n }\n throw err\n }\n\n // Create record from the returned bytes\n const record = Record.deserialize(rawRecord)\n\n if (!record) {\n throw errcode(new Error('Invalid record'), 'ERR_INVALID_RECORD')\n }\n\n // Check validity: compare time received with max record age\n if (record.timeReceived == null ||\n utils.now() - record.timeReceived.getTime() > c.MAX_RECORD_AGE) {\n // If record is bad delete it and return\n await this.datastore.delete(dsKey)\n this.onRemove(record)\n return undefined\n }\n\n // Record is valid\n return record\n }\n\n /**\n * Add the peer to the routing table and update it in the peerStore.\n *\n * @param {PeerId} peerId\n */\n async _add (peerId) {\n await this.routingTable.add(peerId)\n }\n\n /**\n * Verify a record without searching the DHT.\n *\n * @param {import('libp2p-record').Record} record\n */\n async _verifyRecordLocally (record) {\n this._log('verifyRecordLocally')\n\n await libp2pRecord.validator.verifyRecord(this.validators, record)\n }\n\n /**\n * Is the given peer id our PeerId?\n *\n * @param {PeerId} other\n */\n _isSelf (other) {\n return other && uint8ArrayEquals(this.peerId.id, other.id)\n }\n\n /**\n * Store the given key/value pair at the peer `target`.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} rec - encoded record\n * @param {PeerId} target\n */\n async _putValueToPeer (key, rec, target) {\n const msg = new Message(Message.TYPES.PUT_VALUE, key, 0)\n msg.record = Record.deserialize(rec)\n\n const resp = await this.network.sendRequest(target, msg)\n\n if (resp.record && !uint8ArrayEquals(resp.record.value, Record.deserialize(rec).value)) {\n throw errcode(new Error('value not put correctly'), 'ERR_PUT_VALUE_INVALID')\n }\n }\n\n /**\n * Query a particular peer for the value for the given key.\n * It will either return the value or a list of closer peers.\n *\n * Note: The peerStore is updated with new addresses found for the given peer.\n *\n * @param {PeerId} peer\n * @param {Uint8Array} key\n */\n async _getValueOrPeers (peer, key) {\n const msg = await this._getValueSingle(peer, key)\n\n const peers = msg.closerPeers\n const record = msg.record\n\n if (record) {\n // We have a record\n try {\n await this._verifyRecordOnline(record)\n } catch (err) {\n const errMsg = 'invalid record received, discarded'\n this._log(errMsg)\n throw errcode(new Error(errMsg), 'ERR_INVALID_RECORD')\n }\n\n return { record, peers }\n }\n\n if (peers.length > 0) {\n return { peers }\n }\n\n throw errcode(new Error('Not found'), 'ERR_NOT_FOUND')\n }\n\n /**\n * Get a value via rpc call for the given parameters.\n *\n * @param {PeerId} peer\n * @param {Uint8Array} key\n */\n async _getValueSingle (peer, key) { // eslint-disable-line require-await\n const msg = new Message(Message.TYPES.GET_VALUE, key, 0)\n return this.network.sendRequest(peer, msg)\n }\n\n /**\n * Verify a record, fetching missing public keys from the network.\n * Calls back with an error if the record is invalid.\n *\n * @param {import('libp2p-record').Record} record\n * @returns {Promise}\n */\n async _verifyRecordOnline (record) {\n await libp2pRecord.validator.verifyRecord(this.validators, record)\n }\n}\n\nmodule.exports = KadDHT\nmodule.exports.multicodec = '/ipfs' + c.PROTOCOL_DHT\n","'use strict'\n\n// @ts-ignore\nconst KBuck = require('k-bucket')\nconst { xor: uint8ArrayXor } = require('uint8arrays/xor')\nconst GENERATED_PREFIXES = require('./generated-prefix-list.json')\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst crypto = require('libp2p-crypto')\nconst PeerId = require('peer-id')\nconst utils = require('../utils')\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:dht:routing-table'), {\n error: debug('libp2p:dht:routing-table:error')\n})\n// @ts-ignore\nconst length = require('it-length')\n\n/**\n * @typedef {object} KBucketPeer\n * @property {Uint8Array} id\n * @property {PeerId} peer\n *\n * @typedef {object} KBucket\n * @property {Uint8Array} id\n * @property {KBucketPeer[]} contacts\n * @property {boolean} dontSplit\n * @property {KBucket} left\n * @property {KBucket} right\n *\n * @typedef {object} KBucketTree\n * @property {KBucket} root\n * @property {Uint8Array} localNodeId\n * @property {(event: string, callback: Function) => void} on\n * @property {(key: Uint8Array, count: number) => KBucketPeer[]} closest\n * @property {(key: Uint8Array) => KBucketPeer} closestPeer\n * @property {(key: Uint8Array) => void} remove\n * @property {(peer: KBucketPeer) => void} add\n * @property {() => number} count\n * @property {() => Iterable} toIterable\n */\n\n/**\n * Cannot generate random KadIds longer than this + 1\n */\nconst MAX_COMMON_PREFIX_LENGTH = 15\n\n/**\n * A wrapper around `k-bucket`, to provide easy store and\n * retrieval for peers.\n */\nclass RoutingTable {\n /**\n * @param {import('../')} dht\n * @param {object} [options]\n * @param {number} [options.kBucketSize=20]\n * @param {number} [options.refreshInterval=30000]\n */\n constructor (dht, { kBucketSize, refreshInterval } = {}) {\n this.peerId = dht.peerId\n this.dht = dht\n this._kBucketSize = kBucketSize || 20\n this._refreshInterval = refreshInterval || 30000\n\n /** @type {KBucketTree} */\n this.kb = new KBuck({\n numberOfNodesPerKBucket: this._kBucketSize,\n numberOfNodesToPing: 1\n })\n\n /** @type {Date[]} */\n this.commonPrefixLengthRefreshedAt = []\n\n this._refreshTable = this._refreshTable.bind(this)\n this._onPing = this._onPing.bind(this)\n }\n\n async start () {\n this.kb.localNodeId = await utils.convertPeerId(this.peerId)\n this.kb.on('ping', this._onPing)\n\n await this._refreshTable(true)\n }\n\n async stop () {\n if (this._refreshTimeoutId) {\n clearTimeout(this._refreshTimeoutId)\n }\n }\n\n /**\n * To speed lookups, we seed the table with random PeerIds. This means\n * when we are asked to locate a peer on the network, we can find a KadId\n * that is close to the requested peer ID and query that, then network\n * peers will tell us who they know who is close to the fake ID\n *\n * @param {boolean} [force=false]\n */\n async _refreshTable (force) {\n log('refreshing routing table')\n\n const prefixLength = this._maxCommonPrefix()\n const refreshCpls = this._getTrackedCommonPrefixLengthsForRefresh(prefixLength)\n\n log(`max common prefix length ${prefixLength}`)\n log(`tracked CPLs [ ${refreshCpls.map(date => `${date.getFullYear()}-${(date.getMonth() + 1).toString().padStart(2, '0')}-${date.getDate().toString().padStart(2, '0')} ${date.getHours().toString().padStart(2, '0')}:${date.getMinutes().toString().padStart(2, '0')}:${date.getSeconds().toString().padStart(2, '0')}`).join(', ')} ]`)\n\n /**\n * If we see a gap at a common prefix length in the Routing table, we ONLY refresh up until\n * the maximum cpl we have in the Routing Table OR (2 * (Cpl+ 1) with the gap), whichever\n * is smaller.\n *\n * This is to prevent refreshes for Cpls that have no peers in the network but happen to be\n * before a very high max Cpl for which we do have peers in the network.\n *\n * The number of 2 * (Cpl + 1) can be proved and a proof would have been written here if\n * the programmer had paid more attention in the Math classes at university.\n *\n * So, please be patient and a doc explaining it will be published soon.\n *\n * https://github.com/libp2p/go-libp2p-kad-dht/commit/2851c88acb0a3f86bcfe3cfd0f4604a03db801d8#diff-ad45f4ba97ffbc4083c2eb87a4420c1157057b233f048030d67c6b551855ccf6R219\n */\n await Promise.all(\n refreshCpls.map(async (lastRefresh, index) => {\n try {\n await this._refreshCommonPrefixLength(index, lastRefresh, force === true)\n\n if (this._numPeersForCpl(prefixLength) === 0) {\n const lastCpl = Math.min(2 * (index + 1), refreshCpls.length - 1)\n\n for (let n = index + 1; n < lastCpl + 1; n++) {\n try {\n await this._refreshCommonPrefixLength(n, lastRefresh, force === true)\n } catch (err) {\n log.error(err)\n }\n }\n }\n } catch (err) {\n log.error(err)\n }\n })\n )\n\n this._refreshTimeoutId = setTimeout(this._refreshTable, this._refreshInterval)\n // @ts-ignore\n this._refreshTimeoutId.unref()\n }\n\n /**\n * @param {number} cpl\n * @param {Date} lastRefresh\n * @param {boolean} force\n */\n async _refreshCommonPrefixLength (cpl, lastRefresh, force) {\n if (!force && lastRefresh.getTime() > (Date.now() - this._refreshInterval)) {\n log(`not running refresh for cpl ${cpl} as time since last refresh not above interval`)\n return\n }\n\n // gen a key for the query to refresh the cpl\n const peerId = await this._generateRandomPeerId(cpl)\n\n log(`starting refreshing cpl ${cpl} with key ${peerId.toB58String()} (routing table size was ${this.kb.count()})`)\n\n const peers = await length(this.dht.getClosestPeers(peerId.toBytes(), {}))\n\n log(`found ${peers} peers that were close to imaginary peer ${peerId.toB58String()}`)\n\n log(`finished refreshing cpl ${cpl} with key ${peerId.toB58String()} (routing table size was ${this.kb.count()})`)\n }\n\n /**\n * @param {number} maxCommonPrefix\n */\n _getTrackedCommonPrefixLengthsForRefresh (maxCommonPrefix) {\n if (maxCommonPrefix > MAX_COMMON_PREFIX_LENGTH) {\n maxCommonPrefix = MAX_COMMON_PREFIX_LENGTH\n }\n\n const dates = []\n\n for (let i = 0; i <= maxCommonPrefix; i++) {\n // defaults to the zero value if we haven't refreshed it yet.\n dates[i] = this.commonPrefixLengthRefreshedAt[i] || new Date()\n }\n\n return dates\n }\n\n /**\n *\n * @param {number} targetCommonPrefixLength\n */\n async _generateRandomPeerId (targetCommonPrefixLength) {\n const randomBytes = crypto.randomBytes(2)\n const randomUint16 = (randomBytes[1] << 8) + randomBytes[0]\n\n const key = await this._makePeerId(this.kb.localNodeId, randomUint16, targetCommonPrefixLength)\n\n return PeerId.createFromBytes(key)\n }\n\n /**\n * @param {Uint8Array} localKadId\n * @param {number} randomPrefix\n * @param {number} targetCommonPrefixLength\n */\n async _makePeerId (localKadId, randomPrefix, targetCommonPrefixLength) {\n if (targetCommonPrefixLength > MAX_COMMON_PREFIX_LENGTH) {\n throw new Error(`Cannot generate peer ID for common prefix length greater than ${MAX_COMMON_PREFIX_LENGTH}`)\n }\n\n const view = new DataView(localKadId.buffer, localKadId.byteOffset, localKadId.byteLength)\n const localPrefix = view.getUint16(0, false)\n\n // For host with ID `L`, an ID `K` belongs to a bucket with ID `B` ONLY IF CommonPrefixLen(L,K) is EXACTLY B.\n // Hence, to achieve a targetPrefix `T`, we must toggle the (T+1)th bit in L & then copy (T+1) bits from L\n // to our randomly generated prefix.\n const toggledLocalPrefix = localPrefix ^ (0x8000 >> targetCommonPrefixLength)\n\n // Combine the toggled local prefix and the random bits at the correct offset\n // such that ONLY the first `targetCommonPrefixLength` bits match the local ID.\n const mask = 65535 << (16 - (targetCommonPrefixLength + 1))\n const targetPrefix = (toggledLocalPrefix & mask) | (randomPrefix & ~mask)\n\n // Convert to a known peer ID.\n const keyPrefix = GENERATED_PREFIXES[targetPrefix]\n\n const keyBuffer = new ArrayBuffer(34)\n const keyView = new DataView(keyBuffer, 0, keyBuffer.byteLength)\n keyView.setUint8(0, sha256.code)\n keyView.setUint8(1, 32)\n keyView.setUint32(2, keyPrefix, false)\n\n return new Uint8Array(keyView.buffer, keyView.byteOffset, keyView.byteLength)\n }\n\n /**\n * returns the maximum common prefix length between any peer in the table\n * and the current peer\n */\n _maxCommonPrefix () {\n if (!this.kb.localNodeId) {\n return 0\n }\n\n // xor our KadId with every KadId in the k-bucket tree,\n // return the longest id prefix that is the same\n let prefixLength = 0\n\n for (const length of this._prefixLengths()) {\n if (length > prefixLength) {\n prefixLength = length\n }\n }\n\n return prefixLength\n }\n\n /**\n * Returns the number of peers in the table with a given prefix length\n *\n * @param {number} prefixLength\n */\n _numPeersForCpl (prefixLength) {\n let count = 0\n\n for (const length of this._prefixLengths()) {\n if (length === prefixLength) {\n count++\n }\n }\n\n return count\n }\n\n /**\n * Yields the common prefix length of every peer in the table\n */\n * _prefixLengths () {\n for (const { id } of this.kb.toIterable()) {\n const distance = uint8ArrayXor(this.kb.localNodeId, id)\n let leadingZeros = 0\n\n for (const byte of distance) {\n if (byte === 0) {\n leadingZeros++\n } else {\n break\n }\n }\n\n yield leadingZeros\n }\n }\n\n /**\n * Called on the `ping` event from `k-bucket`.\n * Currently this just removes the oldest contact from\n * the list, without actually pinging the individual peers.\n * This is the same as go does, but should probably\n * be upgraded to actually ping the individual peers.\n *\n * @param {KBucketPeer[]} oldContacts\n * @param {KBucketPeer} newContact\n */\n _onPing (oldContacts, newContact) {\n // just use the first one (k-bucket sorts from oldest to newest)\n const oldest = oldContacts[0]\n\n if (oldest) {\n // remove the oldest one\n this.kb.remove(oldest.id)\n }\n\n // add the new one\n this.kb.add(newContact)\n }\n\n // -- Public Interface\n\n /**\n * Amount of currently stored peers.\n */\n get size () {\n return this.kb.count()\n }\n\n /**\n * Find a specific peer by id.\n *\n * @param {PeerId} peer\n */\n async find (peer) {\n const key = await utils.convertPeerId(peer)\n const closest = this.closestPeer(key)\n\n if (closest && peer.equals(closest)) {\n return closest\n }\n }\n\n /**\n * Retrieve the closest peers to the given key.\n *\n * @param {Uint8Array} key\n */\n closestPeer (key) {\n const res = this.closestPeers(key, 1)\n\n if (res.length > 0) {\n return res[0]\n }\n }\n\n /**\n * Retrieve the `count`-closest peers to the given key.\n *\n * @param {Uint8Array} key\n * @param {number} count\n */\n closestPeers (key, count) {\n const closest = this.kb.closest(key, count)\n\n return closest.map(p => p.peer)\n }\n\n /**\n * Add or update the routing table with the given peer.\n *\n * @param {PeerId} peer\n */\n async add (peer) {\n const id = await utils.convertPeerId(peer)\n\n this.kb.add({ id: id, peer: peer })\n }\n\n /**\n * Remove a given peer from the table.\n *\n * @param {PeerId} peer\n */\n async remove (peer) {\n const id = await utils.convertPeerId(peer)\n\n this.kb.remove(id)\n }\n}\n\nmodule.exports = RoutingTable\n","/*\nindex.js - Kademlia DHT K-bucket implementation as a binary tree.\n\nThe MIT License (MIT)\n\nCopyright (c) 2013-2021 Tristan Slominski\n\nPermission is hereby granted, free of charge, to any person\nobtaining a copy of this software and associated documentation\nfiles (the \"Software\"), to deal in the Software without\nrestriction, including without limitation the rights to use,\ncopy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the\nSoftware is furnished to do so, subject to the following\nconditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES\nOF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\nNONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\nHOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,\nWHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\nFROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR\nOTHER DEALINGS IN THE SOFTWARE.\n*/\n'use strict'\n\nconst randomBytes = require('randombytes')\nconst { EventEmitter } = require('events')\n\n/**\n * @param {Uint8Array} array1\n * @param {Uint8Array} array2\n * @return {Boolean}\n */\nfunction arrayEquals (array1, array2) {\n if (array1 === array2) {\n return true\n }\n if (array1.length !== array2.length) {\n return false\n }\n for (let i = 0, length = array1.length; i < length; ++i) {\n if (array1[i] !== array2[i]) {\n return false\n }\n }\n return true\n}\n\nfunction createNode () {\n return { contacts: [], dontSplit: false, left: null, right: null }\n}\n\nfunction ensureInt8 (name, val) {\n if (!(val instanceof Uint8Array)) {\n throw new TypeError(name + ' is not a Uint8Array')\n }\n}\n\n/**\n * Implementation of a Kademlia DHT k-bucket used for storing\n * contact (peer node) information.\n *\n * @extends EventEmitter\n */\nclass KBucket extends EventEmitter {\n /**\n * `options`:\n * `distance`: _Function_\n * `function (firstId, secondId) { return distance }` An optional\n * `distance` function that gets two `id` Uint8Arrays\n * and return distance (as number) between them.\n * `arbiter`: _Function_ _(Default: vectorClock arbiter)_\n * `function (incumbent, candidate) { return contact; }` An optional\n * `arbiter` function that givent two `contact` objects with the same `id`\n * returns the desired object to be used for updating the k-bucket. For\n * more details, see [arbiter function](#arbiter-function).\n * `localNodeId`: _Uint8Array_ An optional Uint8Array representing the local node id.\n * If not provided, a local node id will be created via `randomBytes(20)`.\n * `metadata`: _Object_ _(Default: {})_ Optional satellite data to include\n * with the k-bucket. `metadata` property is guaranteed not be altered by,\n * it is provided as an explicit container for users of k-bucket to store\n * implementation-specific data.\n * `numberOfNodesPerKBucket`: _Integer_ _(Default: 20)_ The number of nodes\n * that a k-bucket can contain before being full or split.\n * `numberOfNodesToPing`: _Integer_ _(Default: 3)_ The number of nodes to\n * ping when a bucket that should not be split becomes full. KBucket will\n * emit a `ping` event that contains `numberOfNodesToPing` nodes that have\n * not been contacted the longest.\n *\n * @param {Object=} options optional\n */\n constructor (options = {}) {\n super()\n\n this.localNodeId = options.localNodeId || randomBytes(20)\n this.numberOfNodesPerKBucket = options.numberOfNodesPerKBucket || 20\n this.numberOfNodesToPing = options.numberOfNodesToPing || 3\n this.distance = options.distance || KBucket.distance\n // use an arbiter from options or vectorClock arbiter by default\n this.arbiter = options.arbiter || KBucket.arbiter\n this.metadata = Object.assign({}, options.metadata)\n\n ensureInt8('option.localNodeId as parameter 1', this.localNodeId)\n\n this.root = createNode()\n }\n\n /**\n * Default arbiter function for contacts with the same id. Uses\n * contact.vectorClock to select which contact to update the k-bucket with.\n * Contact with larger vectorClock field will be selected. If vectorClock is\n * the same, candidat will be selected.\n *\n * @param {Object} incumbent Contact currently stored in the k-bucket.\n * @param {Object} candidate Contact being added to the k-bucket.\n * @return {Object} Contact to updated the k-bucket with.\n */\n static arbiter (incumbent, candidate) {\n return incumbent.vectorClock > candidate.vectorClock ? incumbent : candidate\n }\n\n /**\n * Default distance function. Finds the XOR\n * distance between firstId and secondId.\n *\n * @param {Uint8Array} firstId Uint8Array containing first id.\n * @param {Uint8Array} secondId Uint8Array containing second id.\n * @return {Number} Integer The XOR distance between firstId\n * and secondId.\n */\n static distance (firstId, secondId) {\n let distance = 0\n let i = 0\n const min = Math.min(firstId.length, secondId.length)\n const max = Math.max(firstId.length, secondId.length)\n for (; i < min; ++i) {\n distance = distance * 256 + (firstId[i] ^ secondId[i])\n }\n for (; i < max; ++i) distance = distance * 256 + 255\n return distance\n }\n\n /**\n * Adds a contact to the k-bucket.\n *\n * @param {Object} contact the contact object to add\n */\n add (contact) {\n ensureInt8('contact.id', (contact || {}).id)\n\n let bitIndex = 0\n let node = this.root\n\n while (node.contacts === null) {\n // this is not a leaf node but an inner node with 'low' and 'high'\n // branches; we will check the appropriate bit of the identifier and\n // delegate to the appropriate node for further processing\n node = this._determineNode(node, contact.id, bitIndex++)\n }\n\n // check if the contact already exists\n const index = this._indexOf(node, contact.id)\n if (index >= 0) {\n this._update(node, index, contact)\n return this\n }\n\n if (node.contacts.length < this.numberOfNodesPerKBucket) {\n node.contacts.push(contact)\n this.emit('added', contact)\n return this\n }\n\n // the bucket is full\n if (node.dontSplit) {\n // we are not allowed to split the bucket\n // we need to ping the first this.numberOfNodesToPing\n // in order to determine if they are alive\n // only if one of the pinged nodes does not respond, can the new contact\n // be added (this prevents DoS flodding with new invalid contacts)\n this.emit('ping', node.contacts.slice(0, this.numberOfNodesToPing), contact)\n return this\n }\n\n this._split(node, bitIndex)\n return this.add(contact)\n }\n\n /**\n * Get the n closest contacts to the provided node id. \"Closest\" here means:\n * closest according to the XOR metric of the contact node id.\n *\n * @param {Uint8Array} id Contact node id\n * @param {Number=} n Integer (Default: Infinity) The maximum number of\n * closest contacts to return\n * @return {Array} Array Maximum of n closest contacts to the node id\n */\n closest (id, n = Infinity) {\n ensureInt8('id', id)\n\n if ((!Number.isInteger(n) && n !== Infinity) || n <= 0) {\n throw new TypeError('n is not positive number')\n }\n\n let contacts = []\n\n for (let nodes = [this.root], bitIndex = 0; nodes.length > 0 && contacts.length < n;) {\n const node = nodes.pop()\n if (node.contacts === null) {\n const detNode = this._determineNode(node, id, bitIndex++)\n nodes.push(node.left === detNode ? node.right : node.left)\n nodes.push(detNode)\n } else {\n contacts = contacts.concat(node.contacts)\n }\n }\n\n return contacts\n .map(a => [this.distance(a.id, id), a])\n .sort((a, b) => a[0] - b[0])\n .slice(0, n)\n .map(a => a[1])\n }\n\n /**\n * Counts the total number of contacts in the tree.\n *\n * @return {Number} The number of contacts held in the tree\n */\n count () {\n // return this.toArray().length\n let count = 0\n for (const nodes = [this.root]; nodes.length > 0;) {\n const node = nodes.pop()\n if (node.contacts === null) nodes.push(node.right, node.left)\n else count += node.contacts.length\n }\n return count\n }\n\n /**\n * Determines whether the id at the bitIndex is 0 or 1.\n * Return left leaf if `id` at `bitIndex` is 0, right leaf otherwise\n *\n * @param {Object} node internal object that has 2 leafs: left and right\n * @param {Uint8Array} id Id to compare localNodeId with.\n * @param {Number} bitIndex Integer (Default: 0) The bit index to which bit\n * to check in the id Uint8Array.\n * @return {Object} left leaf if id at bitIndex is 0, right leaf otherwise.\n */\n _determineNode (node, id, bitIndex) {\n // **NOTE** remember that id is a Uint8Array and has granularity of\n // bytes (8 bits), whereas the bitIndex is the _bit_ index (not byte)\n\n // id's that are too short are put in low bucket (1 byte = 8 bits)\n // (bitIndex >> 3) finds how many bytes the bitIndex describes\n // bitIndex % 8 checks if we have extra bits beyond byte multiples\n // if number of bytes is <= no. of bytes described by bitIndex and there\n // are extra bits to consider, this means id has less bits than what\n // bitIndex describes, id therefore is too short, and will be put in low\n // bucket\n const bytesDescribedByBitIndex = bitIndex >> 3\n const bitIndexWithinByte = bitIndex % 8\n if ((id.length <= bytesDescribedByBitIndex) && (bitIndexWithinByte !== 0)) {\n return node.left\n }\n\n const byteUnderConsideration = id[bytesDescribedByBitIndex]\n\n // byteUnderConsideration is an integer from 0 to 255 represented by 8 bits\n // where 255 is 11111111 and 0 is 00000000\n // in order to find out whether the bit at bitIndexWithinByte is set\n // we construct (1 << (7 - bitIndexWithinByte)) which will consist\n // of all bits being 0, with only one bit set to 1\n // for example, if bitIndexWithinByte is 3, we will construct 00010000 by\n // (1 << (7 - 3)) -> (1 << 4) -> 16\n if (byteUnderConsideration & (1 << (7 - bitIndexWithinByte))) {\n return node.right\n }\n\n return node.left\n }\n\n /**\n * Get a contact by its exact ID.\n * If this is a leaf, loop through the bucket contents and return the correct\n * contact if we have it or null if not. If this is an inner node, determine\n * which branch of the tree to traverse and repeat.\n *\n * @param {Uint8Array} id The ID of the contact to fetch.\n * @return {Object|Null} The contact if available, otherwise null\n */\n get (id) {\n ensureInt8('id', id)\n\n let bitIndex = 0\n\n let node = this.root\n while (node.contacts === null) {\n node = this._determineNode(node, id, bitIndex++)\n }\n\n // index of uses contact id for matching\n const index = this._indexOf(node, id)\n return index >= 0 ? node.contacts[index] : null\n }\n\n /**\n * Returns the index of the contact with provided\n * id if it exists, returns -1 otherwise.\n *\n * @param {Object} node internal object that has 2 leafs: left and right\n * @param {Uint8Array} id Contact node id.\n * @return {Number} Integer Index of contact with provided id if it\n * exists, -1 otherwise.\n */\n _indexOf (node, id) {\n for (let i = 0; i < node.contacts.length; ++i) {\n if (arrayEquals(node.contacts[i].id, id)) return i\n }\n\n return -1\n }\n\n /**\n * Removes contact with the provided id.\n *\n * @param {Uint8Array} id The ID of the contact to remove.\n * @return {Object} The k-bucket itself.\n */\n remove (id) {\n ensureInt8('the id as parameter 1', id)\n\n let bitIndex = 0\n let node = this.root\n\n while (node.contacts === null) {\n node = this._determineNode(node, id, bitIndex++)\n }\n\n const index = this._indexOf(node, id)\n if (index >= 0) {\n const contact = node.contacts.splice(index, 1)[0]\n this.emit('removed', contact)\n }\n\n return this\n }\n\n /**\n * Splits the node, redistributes contacts to the new nodes, and marks the\n * node that was split as an inner node of the binary tree of nodes by\n * setting this.root.contacts = null\n *\n * @param {Object} node node for splitting\n * @param {Number} bitIndex the bitIndex to which byte to check in the\n * Uint8Array for navigating the binary tree\n */\n _split (node, bitIndex) {\n node.left = createNode()\n node.right = createNode()\n\n // redistribute existing contacts amongst the two newly created nodes\n for (const contact of node.contacts) {\n this._determineNode(node, contact.id, bitIndex).contacts.push(contact)\n }\n\n node.contacts = null // mark as inner tree node\n\n // don't split the \"far away\" node\n // we check where the local node would end up and mark the other one as\n // \"dontSplit\" (i.e. \"far away\")\n const detNode = this._determineNode(node, this.localNodeId, bitIndex)\n const otherNode = node.left === detNode ? node.right : node.left\n otherNode.dontSplit = true\n }\n\n /**\n * Returns all the contacts contained in the tree as an array.\n * If this is a leaf, return a copy of the bucket. If this is not a leaf,\n * return the union of the low and high branches (themselves also as arrays).\n *\n * @return {Array} All of the contacts in the tree, as an array\n */\n toArray () {\n let result = []\n for (const nodes = [this.root]; nodes.length > 0;) {\n const node = nodes.pop()\n if (node.contacts === null) nodes.push(node.right, node.left)\n else result = result.concat(node.contacts)\n }\n return result\n }\n\n /**\n * Similar to `toArray()` but instead of buffering everything up into an\n * array before returning it, yields contacts as they are encountered while\n * walking the tree.\n *\n * @return {Iterable} All of the contacts in the tree, as an iterable\n */\n * toIterable () {\n for (const nodes = [this.root]; nodes.length > 0;) {\n const node = nodes.pop()\n if (node.contacts === null) {\n nodes.push(node.right, node.left)\n } else {\n yield * node.contacts\n }\n }\n }\n\n /**\n * Updates the contact selected by the arbiter.\n * If the selection is our old contact and the candidate is some new contact\n * then the new contact is abandoned (not added).\n * If the selection is our old contact and the candidate is our old contact\n * then we are refreshing the contact and it is marked as most recently\n * contacted (by being moved to the right/end of the bucket array).\n * If the selection is our new contact, the old contact is removed and the new\n * contact is marked as most recently contacted.\n *\n * @param {Object} node internal object that has 2 leafs: left and right\n * @param {Number} index the index in the bucket where contact exists\n * (index has already been computed in a previous\n * calculation)\n * @param {Object} contact The contact object to update.\n */\n _update (node, index, contact) {\n // sanity check\n if (!arrayEquals(node.contacts[index].id, contact.id)) {\n throw new Error('wrong index for _update')\n }\n\n const incumbent = node.contacts[index]\n const selection = this.arbiter(incumbent, contact)\n // if the selection is our old contact and the candidate is some new\n // contact, then there is nothing to do\n if (selection === incumbent && incumbent !== contact) return\n\n node.contacts.splice(index, 1) // remove old contact\n node.contacts.push(selection) // add more recent contact version\n this.emit('updated', incumbent, selection)\n }\n}\n\nmodule.exports = KBucket\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction xor(a, b) {\n if (a.length !== b.length) {\n throw new Error('Inputs should have the same length');\n }\n const result = new Uint8Array(a.length);\n for (let i = 0; i < a.length; i++) {\n result[i] = a[i] ^ b[i];\n }\n return result;\n}\n\nexports.xor = xor;\n","[\n\t77591, 22417, 43971, 28421, 740, 29829, 71467, 228973, 196661, 78537, 27689, 36431, 44415, 14362, 19456, 106025,\n\t96308, 2882, 49509, 21149, 87173, 131409, 75844, 23676, 121838, 30291, 17492, 2953, 7564, 110620, 129477, 127283,\n\t53113, 72417, 165166, 109690, 21200, 102125, 24049, 71504, 90342, 25307, 72039, 26812, 26715, 32264, 133800, 71161,\n\t88956, 171987, 51779, 24425, 16671, 30251, 186294, 247761, 14202, 2121, 8465, 35024, 4876, 85917, 169730, 3638,\n\t256836, 96184, 943, 18678, 6583, 52907, 35807, 112254, 214097, 18796, 11595, 9243, 23554, 887, 268203, 382004,\n\t24590, 111335, 11625, 16619, 29039, 102425, 69006, 97976, 92362, 32552, 63717, 41433, 128974, 137630, 59943, 10019,\n\t13986, 35430, 33665, 108037, 43799, 43280, 38195, 29078, 58629, 18265, 14425, 46832, 235538, 40830, 77881, 110717,\n\t58937, 3463, 325358, 51300, 47623, 117252, 19007, 10170, 20540, 91237, 294813, 4951, 79841, 56232, 36270, 128547,\n\t69209, 66275, 100156, 32063, 73531, 34439, 80937, 28892, 44466, 88595, 216307, 32583, 49620, 16605, 82127, 45807,\n\t21630, 78726, 20235, 40163, 111007, 96926, 5567, 72083, 21665, 58844, 39419, 179767, 48328, 42662, 51550, 5251,\n\t37811, 49608, 81056, 50854, 55513, 20922, 18891, 197409, 164656, 32593, 71449, 220474, 58919, 85682, 67854, 13758,\n\t35066, 3565, 61905, 214793, 119572, 141419, 21504, 10302, 27354, 67003, 46131, 32668, 15165, 64871, 34450, 17821,\n\t2757, 11452, 34189, 5160, 12257, 85523, 560, 53385, 65887, 119549, 135620, 312353, 115979, 122356, 10867, 193231,\n\t124537, 54783, 90675, 120791, 4715, 142253, 50943, 17271, 43358, 25331, 4917, 120566, 34580, 12878, 33786, 160528,\n\t32523, 4869, 301307, 104817, 81491, 23276, 8832, 97911, 31265, 52065, 7998, 49622, 9715, 43998, 34091, 84587,\n\t20664, 69041, 29419, 53205, 10838, 58288, 116145, 6185, 5154, 141795, 35924, 21307, 144738, 43730, 12085, 8279,\n\t10002, 119, 133779, 199668, 72938, 31768, 39176, 67875, 38453, 9700, 44144, 4121, 116048, 41733, 12868, 82669,\n\t92308, 128, 34262, 11332, 7712, 90764, 36141, 13553, 71312, 77470, 117314, 96549, 49135, 23602, 54468, 28605,\n\t6327, 62308, 17171, 67531, 21319, 14105, 894, 107722, 46157, 8503, 51069, 100472, 45138, 15246, 14577, 35609,\n\t191464, 1757, 13364, 161349, 32067, 91705, 81144, 52339, 5408, 91066, 21983, 14157, 100545, 4372, 26630, 129112,\n\t1423, 29676, 213626, 4397, 88436, 99190, 6877, 49958, 26122, 114348, 60661, 29818, 293118, 50042, 179738, 16400,\n\t163423, 89627, 31040, 43973, 36638, 45952, 5153, 1894, 109322, 1898, 134021, 12402, 112077, 68309, 190269, 69866,\n\t31938, 107383, 11522, 105232, 11248, 14868, 39852, 71707, 186525, 16530, 38162, 106212, 11700, 5130, 16608, 26998,\n\t59586, 108399, 230033, 43683, 48135, 82179, 2073, 5015, 196684, 189293, 16378, 23452, 8301, 35640, 11632, 214551,\n\t29240, 57644, 33137, 91949, 55157, 52384, 117313, 5090, 17717, 89668, 49363, 82238, 241035, 66216, 29066, 184088,\n\t97206, 62820, 26595, 4241, 135635, 173672, 8202, 459, 71355, 146294, 29587, 3008, 135385, 141203, 14803, 6634,\n\t45094, 69362, 50925, 546, 51884, 62011, 83296, 234584, 44515, 56050, 89476, 87751, 19373, 12691, 149923, 19794,\n\t13833, 35846, 87557, 58339, 2884, 19145, 25647, 12224, 11024, 77338, 64608, 122297, 53025, 7205, 36189, 36294,\n\t170779, 21750, 7739, 173883, 75192, 35664, 224240, 113121, 30181, 26267, 27036, 117827, 92015, 106516, 55628, 203549,\n\t67949, 60462, 60844, 35911, 20457, 1820, 920, 19773, 8738, 73173, 181993, 38521, 98254, 76257, 46008, 92796,\n\t5384, 26868, 151566, 22124, 2411, 15919, 186872, 180021, 28099, 152961, 78811, 80237, 62352, 102653, 74259, 184890,\n\t16792, 123702, 224945, 29940, 19512, 75283, 14059, 112691, 92811, 233329, 20411, 138569, 53341, 109802, 50600, 134528,\n\t66747, 5529, 166531, 31578, 64732, 67189, 1596, 126357, 967, 167999, 206598, 109752, 119431, 207825, 78791, 91938,\n\t10301, 27311, 24233, 252343, 28831, 32812, 66002, 112267, 90895, 8786, 8095, 16824, 22866, 21813, 60507, 174833,\n\t19549, 130985, 117051, 52110, 6938, 81923, 123864, 38061, 919, 18680, 53534, 46739, 112893, 161529, 85429, 26761,\n\t11900, 81121, 91968, 15390, 217947, 56524, 1713, 6654, 37089, 85630, 138866, 61850, 16491, 75577, 16884, 98296,\n\t73523, 6140, 44645, 6062, 36366, 29844, 57946, 37932, 42472, 5266, 20834, 19309, 33753, 127182, 134259, 35810,\n\t41805, 45878, 312001, 14881, 47757, 49251, 120050, 44252, 3708, 25856, 107864, 120347, 1228, 36550, 41682, 34496,\n\t47025, 8393, 173365, 246526, 12894, 161607, 35670, 90785, 126572, 2095, 124731, 157033, 58694, 554, 12786, 9642,\n\t4817, 16136, 47864, 174698, 66992, 4639, 69284, 10625, 40710, 27763, 51738, 30404, 264105, 137904, 109882, 52487,\n\t42824, 57514, 2740, 10479, 146799, 107390, 16586, 88038, 174951, 9410, 16185, 44158, 5568, 40658, 46108, 12763,\n\t97385, 26175, 108859, 664, 230732, 67470, 46663, 14395, 50750, 141320, 93140, 15361, 47997, 55784, 6791, 307840,\n\t118569, 107326, 18056, 58281, 260415, 54691, 8790, 73332, 45633, 7511, 45674, 143373, 14031, 11799, 94491, 35646,\n\t96544, 14560, 26049, 32983, 25791, 83814, 42094, 231370, 63955, 139212, 2359, 169908, 3108, 183486, 105867, 28197,\n\t32941, 124968, 26402, 88267, 149768, 23053, 3078, 19091, 52924, 25383, 19209, 111548, 97361, 3959, 24880, 235061,\n\t9099, 24921, 161254, 151405, 20508, 7159, 34381, 20133, 11434, 74036, 19974, 34769, 36585, 1076, 22454, 17354,\n\t38727, 235160, 111547, 96454, 117448, 156940, 91330, 37299, 7310, 26915, 117060, 51369, 22620, 61861, 322264, 106850,\n\t111694, 15091, 2624, 40345, 300446, 177064, 1707, 27389, 54792, 327783, 132669, 183543, 59003, 17744, 20603, 151134,\n\t106923, 53084, 71803, 279424, 319816, 11579, 21946, 16728, 38274, 72711, 5085, 83391, 88646, 40159, 25027, 34680,\n\t10752, 12988, 54126, 30365, 18338, 100445, 230674, 44874, 84974, 143877, 123253, 139372, 28082, 91477, 144002, 13096,\n\t219729, 46016, 50029, 42377, 14601, 6660, 58244, 58978, 23918, 88206, 113611, 64452, 17541, 41032, 10942, 12021,\n\t49189, 10978, 40175, 37156, 10947, 71709, 106894, 112538, 57007, 137486, 150608, 152719, 40615, 7746, 279716, 13101,\n\t19524, 28708, 40578, 72320, 1096, 182051, 94527, 51275, 22833, 45164, 81917, 77519, 48508, 5421, 140302, 37845,\n\t149830, 5587, 27579, 5357, 428725, 248187, 6326, 206760, 39814, 32585, 89923, 44341, 288753, 284443, 96368, 31201,\n\t94189, 119504, 20359, 52073, 103216, 179, 27934, 32801, 96035, 34111, 34309, 101326, 18198, 20704, 210266, 37643,\n\t27880, 141873, 106000, 19414, 56614, 167714, 66483, 107885, 86602, 4379, 20796, 75467, 4987, 5017, 118857, 26003,\n\t34308, 114428, 29198, 6686, 29697, 73632, 3739, 69795, 16798, 41504, 7207, 30722, 21436, 36735, 28067, 28545,\n\t3239, 11221, 36031, 41889, 100010, 19247, 317673, 29495, 174554, 6424, 129725, 53845, 94986, 7955, 59676, 2604,\n\t191497, 19735, 102214, 62954, 23844, 11872, 179525, 261436, 34492, 428, 78404, 142035, 16747, 17246, 27578, 37021,\n\t33672, 57944, 26056, 135760, 2369, 61674, 122066, 31327, 19374, 157065, 40553, 130982, 69619, 71290, 38855, 72100,\n\t92903, 95940, 51422, 165999, 65713, 57873, 50726, 7288, 20272, 2081, 42326, 22624, 81120, 57914, 79352, 19447,\n\t1684, 72302, 11774, 302559, 161481, 96396, 13692, 414988, 3721, 79066, 56627, 46883, 21150, 11747, 12184, 5856,\n\t113458, 176117, 84416, 52079, 27933, 3354, 59765, 141359, 2212, 216309, 2555, 23458, 196722, 142463, 45701, 44548,\n\t28798, 19418, 215, 29916, 9396, 10574, 114226, 84475, 13520, 18694, 34056, 4524, 90302, 62930, 13539, 19407,\n\t77209, 7728, 38088, 9535, 2263, 23875, 183945, 17750, 26274, 67172, 10585, 28042, 22199, 7478, 51331, 66030,\n\t26774, 192929, 31434, 25850, 50197, 52926, 178158, 4679, 181256, 70184, 229600, 9959, 105594, 72158, 73974, 2726,\n\t35085, 78087, 23284, 35568, 51713, 155676, 5401, 27254, 11966, 17569, 223253, 71993, 103357, 111477, 55722, 30504,\n\t26034, 46774, 35392, 36285, 214814, 41143, 163465, 1051, 16094, 81044, 6636, 76489, 179102, 20712, 39178, 35683,\n\t125177, 54219, 30617, 52994, 25324, 50123, 2543, 87529, 58995, 10688, 125199, 12388, 60158, 125481, 131646, 7642,\n\t133350, 65874, 3438, 97277, 101450, 10075, 56344, 116821, 50778, 60547, 98016, 106135, 13859, 14255, 16300, 77373,\n\t173521, 8285, 45932, 37426, 4054, 114295, 55947, 7703, 39114, 52, 51119, 128135, 19714, 60715, 9554, 50492,\n\t88180, 2823, 118271, 52993, 122625, 97919, 23859, 37895, 25040, 33614, 32102, 20431, 3577, 9275, 15686, 43031,\n\t157741, 110358, 1884, 40291, 125391, 13736, 5008, 64881, 87336, 77381, 70711, 43032, 49155, 118587, 70494, 4318,\n\t10168, 30126, 12580, 10524, 280104, 104001, 145413, 2862, 84140, 6603, 106005, 13566, 12780, 11251, 42830, 571,\n\t179910, 82443, 13146, 469, 42714, 32591, 265217, 424024, 92553, 54721, 134100, 6007, 15242, 114681, 59030, 16718,\n\t85465, 200214, 85982, 55174, 165013, 23493, 56964, 82529, 109150, 32706, 27568, 82442, 5350, 14976, 13165, 44890,\n\t60021, 21343, 33978, 17264, 4655, 22328, 27819, 75730, 16567, 55483, 14510, 17926, 45827, 150609, 3704, 7385,\n\t272531, 161543, 76904, 122163, 52405, 2039, 19165, 41623, 14423, 228354, 3369, 176360, 85491, 7122, 35789, 303724,\n\t4465, 13628, 2233, 55311, 118771, 20713, 10006, 221519, 45115, 71021, 35650, 29775, 7337, 10864, 20665, 21142,\n\t1746, 15080, 1624, 32449, 10905, 105743, 229797, 7701, 3940, 22997, 178467, 57208, 389057, 39683, 59403, 63344,\n\t63125, 54847, 69691, 18336, 56448, 3362, 37202, 18282, 29648, 138224, 35867, 10495, 5911, 28814, 26653, 31514,\n\t176702, 26550, 45621, 11734, 4525, 40543, 73944, 121080, 27858, 155561, 14887, 44670, 30742, 8796, 107455, 113472,\n\t56369, 75581, 183777, 240095, 133699, 153299, 8768, 160464, 26058, 49078, 103971, 21875, 71486, 44888, 17156, 9678,\n\t89541, 123019, 102337, 3972, 83930, 21245, 87852, 109660, 287918, 183019, 686, 10100, 39177, 283941, 11274, 24736,\n\t26793, 26214, 25995, 77011, 141580, 4070, 23742, 46285, 46632, 30700, 26669, 19056, 35951, 115575, 174034, 56097,\n\t35463, 87425, 24575, 44245, 38701, 82317, 85922, 281616, 100333, 147697, 61503, 7730, 84330, 8530, 59917, 61597,\n\t17173, 9092, 32658, 90288, 193136, 39023, 20381, 56654, 31132, 7779, 1919, 1375, 117128, 30819, 11169, 40938,\n\t23935, 115201, 101155, 151034, 4835, 11231, 74550, 89388, 59951, 91704, 107312, 167882, 115062, 12732, 72738, 88703,\n\t464019, 158267, 57995, 60496, 737, 14371, 123867, 4174, 243339, 159946, 7568, 16025, 134556, 110916, 38103, 191,\n\t80226, 88794, 29688, 27230, 10454, 76308, 57647, 77409, 113483, 66864, 14745, 19808, 12023, 46583, 84805, 16015,\n\t17102, 2231, 20611, 3547, 95740, 250131, 34559, 108894, 8498, 15853, 159169, 148920, 20942, 2813, 93160, 45188,\n\t210613, 45531, 52587, 149062, 39782, 28194, 57849, 60965, 84954, 89766, 84453, 100927, 16501, 27658, 165311, 103841,\n\t54192, 207341, 19558, 20084, 319622, 5672, 205467, 98462, 61849, 36279, 13609, 147177, 24726, 165015, 209489, 59591,\n\t31157, 6551, 117580, 75060, 141146, 277310, 21072, 22023, 106474, 63041, 137443, 122965, 68371, 5383, 42146, 98961,\n\t113467, 30863, 23794, 4843, 99630, 30392, 82679, 13699, 241612, 33601, 93146, 24319, 18643, 32155, 95669, 40440,\n\t15333, 34089, 67799, 142144, 58245, 38633, 114531, 117400, 77861, 188726, 5507, 2568, 8853, 10987, 107222, 2663,\n\t2421, 11530, 13345, 30075, 41785, 118661, 104786, 17459, 12490, 16281, 71936, 193555, 17431, 5944, 71758, 26485,\n\t77317, 20803, 367167, 158, 7362, 93430, 11735, 172445, 46002, 11532, 54482, 930, 62911, 2235, 23004, 179236,\n\t4764, 101859, 208113, 22477, 55163, 95579, 14098, 67320, 162556, 90709, 156949, 3826, 57492, 4025, 34092, 87442,\n\t104565, 6718, 186015, 28214, 14209, 10039, 107186, 233912, 58877, 81637, 55265, 39828, 6194, 145813, 50831, 105849,\n\t4974, 88319, 122296, 10272, 197216, 95714, 51540, 72418, 23324, 91555, 8743, 140452, 250249, 51666, 34124, 7229,\n\t38592, 129641, 78169, 174242, 22464, 149964, 51450, 14034, 10026, 95376, 26190, 120062, 14401, 8700, 265, 31386,\n\t143573, 7203, 229889, 61567, 4227, 140981, 2466, 72052, 10787, 10062, 30958, 6099, 38471, 30103, 23202, 208101,\n\t70847, 467, 58934, 32271, 32984, 36637, 24107, 30771, 17109, 73353, 13650, 2098, 157040, 67366, 66904, 106018,\n\t265380, 107238, 18535, 44025, 32681, 144983, 62505, 91295, 56120, 3082, 77508, 10322, 63023, 36700, 81885, 224127,\n\t16721, 45023, 239261, 111272, 13852, 7866, 149243, 204199, 32309, 22084, 42029, 38316, 126644, 104973, 14406, 43454,\n\t67322, 61310, 15789, 40285, 24026, 181047, 6301, 70927, 23319, 115823, 27248, 66693, 115875, 278566, 63007, 146844,\n\t56841, 59007, 87368, 180001, 22370, 42114, 80605, 12022, 10374, 308, 25079, 14689, 12618, 63368, 7936, 264973,\n\t212291, 136713, 95999, 105801, 18965, 32075, 48700, 52230, 35119, 96912, 32992, 8586, 16606, 101333, 101812, 14969,\n\t39930, 759, 193090, 27387, 42914, 12937, 5058, 62646, 64528, 38624, 25743, 37502, 3716, 4435, 30352, 178687,\n\t26461, 132611, 42002, 138442, 35833, 59582, 16345, 8048, 60319, 49349, 309, 47800, 49739, 90482, 26405, 34470,\n\t63786, 32479, 85028, 39866, 47846, 11649, 23934, 29466, 2816, 42864, 31828, 7410, 74885, 49632, 47629, 111801,\n\t90749, 19536, 18767, 105764, 59606, 21223, 10746, 76298, 22220, 39408, 7190, 79654, 64856, 11602, 82156, 272765,\n\t17079, 70089, 245473, 51813, 184407, 384678, 1576, 122249, 5064, 27481, 6188, 25790, 74361, 27541, 318284, 45430,\n\t31488, 620, 93579, 45723, 192118, 22670, 51913, 4162, 70244, 35966, 26397, 16199, 50899, 209613, 121702, 287507,\n\t2993, 36101, 132229, 67345, 33062, 76295, 118628, 78705, 52316, 34375, 107083, 107454, 44863, 127561, 33964, 3073,\n\t154010, 190914, 55967, 39074, 6272, 31047, 5550, 41123, 26154, 98638, 47110, 19998, 148091, 50229, 31329, 59900,\n\t195442, 19106, 61347, 73497, 70015, 682, 45850, 25776, 38022, 148951, 6288, 37411, 232526, 109277, 27286, 32342,\n\t9262, 5220, 16651, 23175, 46740, 129438, 78614, 121925, 66914, 88710, 127952, 5563, 21500, 34521, 10739, 14863,\n\t191006, 62956, 17359, 16749, 67027, 56284, 69134, 43301, 35039, 58883, 54466, 60823, 404451, 75743, 59856, 86979,\n\t7923, 34273, 83785, 32142, 7693, 268986, 197428, 282681, 17049, 22346, 22990, 92245, 107180, 3357, 37104, 96724,\n\t49153, 7683, 31197, 43267, 82231, 164276, 23696, 20848, 188364, 22309, 24821, 158707, 1018, 22514, 70922, 27792,\n\t45589, 59709, 10765, 736, 35218, 63479, 51987, 24275, 63588, 55361, 92929, 81964, 4658, 20122, 12330, 44058,\n\t13065, 311456, 72224, 8337, 211229, 38979, 22590, 138478, 52757, 32595, 133600, 8838, 31549, 94412, 43391, 90056,\n\t1585, 94802, 127271, 6223, 31889, 137038, 132910, 2165, 57616, 230152, 6080, 10748, 36737, 74579, 134062, 50525,\n\t180532, 119270, 34556, 76155, 82394, 52595, 29258, 31435, 87820, 67996, 26943, 183878, 38007, 2410, 13526, 180297,\n\t69856, 3503, 187396, 167700, 7838, 16701, 9199, 56267, 3661, 37407, 65994, 23767, 5708, 62508, 221700, 67088,\n\t86978, 46776, 84434, 32088, 5612, 9149, 88244, 21685, 95151, 46750, 189612, 2979, 506311, 2594, 3628, 40074,\n\t105039, 78243, 28523, 6651, 38058, 71999, 30992, 12764, 68261, 108991, 6165, 26450, 61961, 13400, 22426, 7490,\n\t60890, 109623, 2070, 12958, 50355, 67979, 257096, 7213, 42578, 52121, 35716, 65461, 7516, 124758, 39268, 302,\n\t64712, 14977, 1467, 219452, 2840, 34229, 11121, 21602, 19270, 63574, 8024, 1532, 17331, 79839, 78885, 52029,\n\t180767, 57957, 6069, 91265, 61380, 55767, 8927, 32881, 287603, 22149, 35029, 68876, 6428, 199567, 46926, 13412,\n\t104132, 21434, 366616, 45060, 110046, 81924, 128910, 45886, 52821, 130416, 29416, 77342, 21762, 67329, 121432, 79924,\n\t11724, 38625, 81006, 102033, 28338, 13326, 3250, 82056, 82526, 38212, 21112, 12382, 111495, 3263, 7414, 86274,\n\t93490, 40844, 30224, 45212, 24019, 48411, 71367, 24941, 76729, 57776, 3769, 38114, 202019, 197745, 31953, 237533,\n\t33270, 201580, 255648, 100798, 44741, 32241, 98468, 106931, 10085, 15090, 170358, 33154, 66787, 18819, 69760, 25061,\n\t234005, 82660, 6295, 131975, 16874, 9076, 4094, 25005, 17740, 40908, 19533, 220019, 44330, 99792, 50040, 19619,\n\t13950, 55228, 24423, 31253, 95308, 103177, 184795, 28590, 82285, 5059, 3210, 75525, 49894, 70007, 56178, 10580,\n\t36051, 139681, 21617, 98736, 3555, 106306, 164189, 37352, 63915, 47824, 24883, 145530, 61904, 28444, 11483, 19837,\n\t145446, 30420, 112972, 85939, 11835, 191233, 2262, 20705, 58630, 1753, 148334, 1197, 144714, 6887, 11223, 107667,\n\t60879, 77914, 4151, 57417, 81594, 96681, 169430, 1784, 20444, 95138, 254041, 27038, 596, 7117, 72808, 13759,\n\t3353, 126776, 21074, 55322, 27081, 36942, 39547, 139830, 179275, 4453, 713, 8722, 71399, 19204, 25785, 22794,\n\t23923, 104114, 11291, 25458, 102309, 88396, 75288, 230440, 206396, 104551, 58447, 130857, 37247, 94734, 31548, 176529,\n\t226077, 65159, 20104, 10096, 66881, 94191, 237909, 27109, 37404, 1520, 27421, 25220, 113003, 23423, 24884, 50585,\n\t6286, 231877, 150800, 11789, 3226, 90004, 60642, 5053, 202400, 61442, 132531, 175329, 57138, 30116, 103847, 9973,\n\t75367, 16452, 32360, 59119, 21246, 10191, 164804, 23305, 61051, 37348, 154530, 13214, 5468, 50403, 66754, 130976,\n\t50559, 80515, 14436, 155492, 84017, 5472, 43107, 41240, 2890, 90431, 70188, 382, 76234, 48040, 50211, 281038,\n\t237007, 32115, 142178, 1536, 22761, 96429, 1811, 31243, 1679, 49143, 55209, 17402, 235054, 61494, 7462, 77030,\n\t34925, 87609, 78002, 9499, 9027, 73289, 201078, 101379, 63544, 27666, 5469, 10642, 30029, 49816, 132979, 95620,\n\t58086, 351930, 116300, 2110, 2043, 30845, 6154, 11279, 16727, 4122, 2277, 27281, 4971, 3650, 39060, 61970,\n\t65951, 39674, 75686, 38151, 11370, 130809, 177895, 32665, 63725, 122267, 7857, 39618, 118483, 44792, 157755, 178624,\n\t136994, 24260, 41308, 22471, 12404, 21707, 12486, 30473, 52781, 50246, 20247, 39065, 909, 56825, 103158, 128603,\n\t31542, 1089, 41935, 32744, 12428, 37963, 84420, 33134, 72921, 208449, 42622, 168151, 127335, 147107, 46699, 38216,\n\t12591, 94342, 85814, 31423, 24944, 2605, 87542, 67473, 192551, 4496, 56321, 91819, 17630, 6300, 256183, 114569,\n\t202090, 33209, 35289, 34897, 24967, 40520, 43470, 5344, 10199, 34810, 14283, 10381, 10017, 62923, 49924, 23233,\n\t64539, 13051, 35686, 19698, 11570, 135555, 120868, 44924, 87065, 52318, 52335, 47586, 140906, 245885, 109834, 78668,\n\t9065, 46990, 25258, 72022, 61243, 40838, 4545, 146387, 10537, 11557, 17470, 36930, 68104, 46711, 24264, 79401,\n\t81043, 18225, 120488, 24746, 84338, 81652, 28266, 13776, 21878, 46973, 1047, 230465, 73357, 95777, 24973, 210160,\n\t62210, 58404, 110633, 169651, 6937, 41870, 9909, 26822, 191062, 76553, 27519, 96256, 239070, 2478, 205678, 67955,\n\t58532, 20601, 50120, 19148, 78501, 195724, 110740, 8249, 109665, 27446, 30568, 57631, 31425, 49752, 32820, 65504,\n\t50079, 3663, 102256, 219898, 23849, 211315, 14645, 4359, 91767, 9528, 12449, 49366, 7941, 49763, 107848, 8930,\n\t27086, 50686, 9744, 10447, 81935, 39513, 46514, 1670, 29229, 6172, 22312, 137280, 97759, 9806, 14445, 22976,\n\t56458, 73391, 34983, 93760, 174219, 52573, 33149, 59747, 2429, 136277, 75123, 165263, 91040, 7446, 57632, 48633,\n\t97140, 246081, 84766, 151684, 79918, 93268, 120346, 54059, 54875, 77858, 32996, 103590, 45276, 11968, 19600, 25849,\n\t17159, 132907, 42828, 16817, 4913, 99462, 103303, 27395, 5737, 74184, 20749, 21160, 14377, 77062, 131403, 158735,\n\t10999, 27799, 77785, 9320, 34366, 51593, 61070, 33746, 47048, 29268, 36675, 30262, 53297, 9832, 82000, 20188,\n\t122292, 39917, 7331, 18160, 68301, 185935, 134830, 15031, 4935, 10004, 165845, 185534, 46923, 30109, 44134, 122631,\n\t18874, 22903, 112790, 26561, 18549, 348902, 82871, 140345, 255565, 135390, 63556, 103747, 145055, 179600, 145662, 296111,\n\t61661, 211987, 23952, 52342, 126343, 48450, 32919, 44277, 82185, 9591, 62139, 205363, 376969, 394874, 108461, 18040,\n\t120885, 14798, 39863, 16571, 16794, 58271, 81025, 55206, 14640, 118656, 6361, 44092, 85970, 6262, 153863, 108244,\n\t180200, 72264, 79947, 38044, 10050, 5735, 61221, 80712, 5471, 115689, 11391, 11661, 184257, 20010, 60116, 30320,\n\t19327, 134598, 45455, 27542, 18004, 125092, 452272, 1549, 91523, 46567, 180063, 156026, 2608, 11174, 58848, 37788,\n\t65907, 80194, 30490, 5786, 40775, 119519, 106241, 11323, 156297, 8425, 61495, 2617, 29675, 2425, 59886, 112582,\n\t49142, 59618, 4863, 50597, 86710, 50650, 168632, 27693, 85641, 83643, 18993, 25768, 84284, 28090, 93592, 36627,\n\t312804, 43381, 9887, 9402, 100931, 97165, 3311, 173330, 66805, 28935, 4963, 184460, 3201, 78102, 19126, 21607,\n\t37496, 24938, 22615, 16153, 32862, 134792, 153318, 61120, 6067, 2812, 12826, 12792, 23825, 37559, 64662, 202250,\n\t102694, 155488, 85881, 149193, 46233, 65383, 15521, 106982, 11358, 176786, 25752, 39717, 34208, 24510, 32464, 77742,\n\t39371, 72028, 138229, 60688, 71386, 102834, 132477, 2208, 11548, 63670, 271279, 28351, 30338, 38620, 32491, 99845,\n\t143885, 152266, 13252, 2825, 178663, 108097, 1775, 78201, 14897, 113573, 163346, 62292, 171129, 22183, 96598, 38733,\n\t64971, 166776, 117445, 9968, 146393, 44677, 74867, 20908, 97328, 12761, 25656, 26785, 9148, 112344, 26115, 99176,\n\t110121, 22437, 49547, 6180, 79320, 5835, 31392, 43328, 33377, 75870, 119860, 69497, 80273, 7325, 155219, 43167,\n\t111173, 28347, 20222, 3763, 71752, 55041, 47252, 14618, 28088, 15012, 97805, 194698, 54636, 2036, 41349, 6173,\n\t96604, 61530, 51859, 43782, 13361, 24334, 22668, 24792, 7070, 23441, 16789, 3209, 36211, 208475, 26242, 32880,\n\t122181, 182407, 21444, 31060, 88459, 29929, 77907, 12716, 10934, 97005, 20599, 31690, 8403, 58445, 30303, 22700,\n\t10336, 86731, 103115, 337709, 72556, 46788, 112566, 47684, 67089, 53548, 36874, 56487, 41387, 125985, 26893, 40071,\n\t106683, 73712, 18787, 40105, 72992, 67246, 137276, 50802, 36790, 70328, 138827, 22466, 39263, 183295, 29858, 50975,\n\t9322, 57397, 10654, 24364, 30383, 55799, 41600, 23584, 127295, 296610, 129078, 143558, 244131, 86397, 36049, 1085,\n\t80677, 3820, 108139, 5476, 34767, 24683, 7758, 13060, 7239, 131671, 250593, 59556, 103392, 29810, 4188, 252323,\n\t39404, 116877, 7651, 43600, 40338, 13554, 157253, 39196, 25978, 144387, 61211, 234, 50104, 6129, 10449, 93777,\n\t9240, 356378, 274148, 4439, 72970, 3724, 147770, 78680, 62570, 115877, 40027, 40547, 36817, 224392, 64609, 34795,\n\t165027, 67440, 2477, 37206, 23431, 50754, 164797, 46018, 94995, 170982, 27051, 7957, 22767, 3674, 27900, 56419,\n\t18930, 60701, 41302, 2692, 84749, 339721, 61996, 111094, 80221, 50129, 1045, 8153, 62945, 19202, 8250, 37208,\n\t37418, 32560, 79477, 41106, 88569, 33963, 36693, 5892, 30570, 1581, 66471, 49647, 11922, 160717, 29442, 5643,\n\t114865, 82962, 95982, 132098, 22633, 22838, 94726, 54556, 28566, 205039, 162340, 33216, 16849, 35847, 221339, 94851,\n\t26533, 71469, 1805, 3804, 12935, 45483, 71020, 36310, 65381, 192960, 34240, 35165, 59773, 1248, 46954, 155332,\n\t96864, 4246, 388800, 16129, 57133, 74592, 44807, 442014, 38203, 42574, 80818, 91592, 26377, 36424, 65760, 977,\n\t77387, 22628, 147610, 28018, 30561, 98454, 6969, 119628, 63648, 18170, 36854, 26601, 64018, 22027, 37279, 51395,\n\t152934, 21153, 9430, 58760, 194742, 5330, 55115, 34158, 28917, 174111, 13171, 122326, 1526, 43896, 66094, 25325,\n\t4234, 148354, 11450, 275, 18999, 112191, 44365, 22723, 68409, 8733, 57746, 96565, 75007, 14196, 108844, 29475,\n\t88599, 177563, 100792, 106156, 86323, 93726, 14248, 135341, 194131, 40126, 47099, 14779, 8272, 39597, 95983, 171398,\n\t65882, 28052, 10393, 47213, 40689, 22120, 72212, 106829, 34964, 109146, 753, 648, 21660, 30047, 17527, 181025,\n\t5619, 145357, 4085, 216883, 9359, 186951, 24779, 53931, 24545, 36197, 223296, 62628, 168101, 4243, 107313, 30321,\n\t26642, 13049, 51059, 31027, 107912, 807, 73550, 26551, 84369, 122422, 165872, 49754, 74213, 234264, 33151, 52014,\n\t33100, 87183, 22365, 52500, 40013, 23302, 5652, 72723, 21404, 26107, 48434, 587, 94049, 168493, 96418, 32871,\n\t70860, 31709, 25128, 443, 71597, 166253, 15670, 70994, 26341, 133675, 28280, 75491, 54756, 47955, 56028, 26182,\n\t11952, 113272, 472197, 64640, 110753, 17919, 337, 50642, 22576, 142, 87371, 53391, 93210, 126694, 15285, 19642,\n\t85667, 14148, 1506, 42092, 52962, 33243, 11970, 20734, 135843, 57044, 58880, 13002, 219134, 22876, 64754, 232519,\n\t4257, 43120, 321573, 24799, 64526, 124728, 52579, 81472, 70831, 276848, 17403, 74359, 23021, 182101, 74597, 23744,\n\t148267, 12055, 7976, 5349, 11772, 67540, 167347, 65318, 18720, 127832, 108238, 22828, 90233, 9987, 259080, 118185,\n\t73209, 79270, 13775, 90100, 137742, 90799, 70569, 15699, 19961, 9087, 67475, 57872, 39731, 8810, 134897, 131868,\n\t146849, 19898, 3334, 2281, 167061, 91073, 60356, 467742, 74712, 188, 53179, 137679, 92769, 29241, 9537, 132595,\n\t80119, 1041, 88962, 5976, 40171, 44911, 102859, 139059, 104558, 98987, 47761, 19272, 71472, 113864, 175377, 73338,\n\t10857, 23402, 23758, 1591, 139864, 5644, 4076, 118760, 16427, 134198, 18853, 20291, 100849, 37423, 22038, 36677,\n\t19071, 195521, 57445, 11069, 31869, 55718, 66882, 148490, 44, 41296, 75242, 49704, 166810, 9906, 20943, 122258,\n\t49112, 105667, 15969, 10344, 6408, 187694, 21399, 72742, 58970, 14867, 14376, 81889, 41856, 23225, 15042, 56993,\n\t16074, 131389, 74276, 72407, 53875, 383108, 53597, 37363, 68993, 44854, 122548, 430927, 198279, 38430, 80409, 12245,\n\t2981, 628, 2818, 17760, 37437, 238229, 7968, 46892, 2200, 3730, 34190, 65983, 37959, 112291, 87850, 70827,\n\t6522, 20750, 73913, 111621, 41652, 19587, 2780, 58668, 25916, 85259, 18200, 168962, 95781, 42445, 102050, 7776,\n\t57662, 103313, 47742, 96358, 41964, 66174, 100396, 29069, 204735, 19679, 27978, 7479, 40264, 22534, 61183, 36081,\n\t107436, 58223, 14680, 23002, 101311, 24716, 124108, 12908, 5646, 31750, 40380, 14215, 232799, 102772, 14122, 96775,\n\t61398, 50917, 12096, 149880, 67833, 598749, 124194, 155871, 49216, 790, 14677, 65319, 56917, 7440, 145744, 95701,\n\t12206, 49405, 129269, 76199, 45732, 9767, 11058, 9047, 210885, 11051, 7392, 26307, 2130, 8132, 147526, 20802,\n\t232698, 115660, 50060, 59789, 57344, 107623, 80343, 112676, 23291, 9866, 160971, 34032, 118291, 15719, 59730, 164911,\n\t28975, 2659, 58046, 78480, 21854, 66209, 53863, 109085, 116045, 29021, 46481, 107552, 22130, 18764, 70254, 31272,\n\t11300, 52460, 43933, 84738, 20721, 53869, 190840, 79673, 105300, 7561, 321817, 66924, 13940, 33281, 101046, 183181,\n\t32176, 71878, 5678, 62924, 79535, 56646, 40303, 19559, 27703, 93042, 73368, 42187, 3670, 37376, 46440, 7023,\n\t36816, 109628, 20680, 5940, 276440, 275233, 170848, 112093, 136996, 14984, 20226, 111441, 77693, 112960, 48577, 39370,\n\t55707, 50314, 123404, 26570, 54281, 61372, 123391, 4857, 35928, 246740, 132507, 106646, 44241, 7196, 92258, 9825,\n\t37688, 51197, 303141, 5590, 15476, 132986, 10955, 85782, 34486, 26696, 7991, 28813, 18858, 39546, 11703, 11365,\n\t38185, 5716, 93555, 11925, 40121, 60002, 6985, 10976, 171384, 3887, 43394, 13337, 56346, 6381, 252336, 39573,\n\t75042, 53711, 1028, 31781, 44295, 95925, 131713, 7214, 68125, 43571, 70954, 213234, 1628, 8760, 13391, 65485,\n\t17320, 56038, 1710, 25248, 60803, 57399, 19839, 3870, 326, 281556, 50945, 72400, 21460, 316244, 75619, 56246,\n\t98775, 481, 13513, 55765, 50427, 7388, 123519, 32929, 57908, 27124, 61316, 101097, 57467, 30228, 48792, 10788,\n\t20402, 37318, 50526, 155730, 34456, 158065, 145305, 17832, 43733, 64052, 4506, 35072, 205355, 177028, 184004, 187081,\n\t68616, 35938, 83703, 10367, 36892, 93186, 260137, 51934, 89970, 4985, 23445, 26755, 21558, 7948, 78741, 23376,\n\t124405, 85594, 68596, 57536, 49351, 12619, 56593, 132668, 99924, 109728, 71844, 71935, 196018, 65464, 17617, 14987,\n\t89701, 143773, 33997, 8687, 22701, 33258, 2914, 4436, 72108, 85610, 9671, 49067, 2327, 82988, 1361, 1672,\n\t44033, 35777, 30269, 24057, 10605, 82236, 616, 15793, 13919, 47249, 112086, 116698, 9484, 80207, 90574, 33304,\n\t68624, 93127, 56101, 42210, 160929, 4827, 38995, 38095, 4701, 125119, 5027, 33680, 9236, 231236, 14135, 87837,\n\t23318, 70261, 78893, 30151, 81482, 14332, 1084, 74256, 27532, 46644, 79185, 3148, 62615, 6981, 55672, 31668,\n\t36825, 1849, 14536, 37446, 14738, 23779, 43058, 162749, 72199, 1168, 21346, 5592, 85932, 85302, 9668, 18351,\n\t57135, 150360, 2080, 228015, 77953, 34670, 119302, 151751, 31009, 106725, 84265, 45214, 59289, 74178, 113071, 263206,\n\t111009, 4021, 44449, 188119, 192629, 123592, 392506, 292847, 114487, 12831, 205858, 9852, 20780, 79648, 75767, 357014,\n\t97721, 18166, 21005, 67950, 33226, 204009, 16536, 2987, 11335, 66717, 144910, 47950, 17262, 55060, 15063, 2934,\n\t51038, 26775, 178497, 66008, 3427, 49433, 128592, 20036, 157553, 63861, 3089, 23015, 51210, 28696, 35933, 49942,\n\t71135, 231518, 99620, 17248, 21835, 176536, 20676, 16944, 38700, 165831, 233253, 295625, 36723, 13023, 52745, 10907,\n\t19423, 67972, 125868, 95473, 82875, 1183, 108455, 52685, 33417, 64095, 21433, 52438, 33191, 127809, 44505, 211823,\n\t7810, 2752, 95548, 162031, 7185, 91196, 47563, 61721, 33359, 17897, 23682, 42806, 178101, 22874, 49707, 199897,\n\t75419, 82456, 8618, 11171, 79712, 116847, 18783, 44190, 46564, 5346, 59046, 95032, 7893, 14916, 3214, 26800,\n\t24172, 121453, 34362, 10250, 17408, 18888, 4840, 68696, 22831, 13162, 36005, 32512, 14800, 62357, 41723, 45046,\n\t27247, 37486, 5372, 2564, 34261, 298500, 66509, 133920, 89138, 31305, 117697, 19097, 108304, 81386, 84106, 23802,\n\t46411, 63304, 946, 51417, 41777, 41041, 19501, 115864, 60743, 294354, 37955, 94165, 18116, 1156, 17937, 20645,\n\t57114, 90804, 58042, 48643, 92288, 9861, 2557, 88546, 61333, 101008, 12853, 5148, 87856, 4152, 144503, 73841,\n\t18718, 9789, 147565, 10846, 42085, 12789, 30223, 8993, 56352, 67203, 2448, 28215, 6052, 23540, 126319, 75933,\n\t36689, 80235, 23231, 23561, 21383, 38800, 77548, 102798, 21234, 31468, 158608, 46188, 63960, 191679, 8051, 67014,\n\t11185, 170078, 42186, 28827, 34777, 41930, 212079, 12421, 34750, 24111, 110344, 73918, 45171, 70826, 141949, 40063,\n\t23979, 24254, 37309, 26724, 27179, 24718, 83648, 54938, 14591, 17425, 29525, 102675, 48975, 48654, 12316, 8929,\n\t60640, 41709, 50168, 63264, 89812, 50716, 48632, 38755, 138583, 160123, 55579, 71829, 24230, 233277, 46322, 39650,\n\t166388, 34718, 24108, 98252, 7031, 106695, 62498, 18258, 35062, 217827, 78731, 34824, 33354, 19520, 60852, 2432,\n\t60224, 8587, 2836, 62955, 702, 20227, 42285, 40560, 95592, 62486, 11094, 53035, 143291, 18842, 46177, 77994,\n\t1770, 9657, 107422, 172915, 32655, 128716, 25886, 25164, 156740, 119928, 165875, 85817, 11007, 89110, 33956, 12652,\n\t65156, 180266, 8494, 36889, 19958, 20955, 96, 1264, 118288, 135769, 44754, 86671, 5632, 19026, 168220, 289120,\n\t33569, 93821, 66144, 70635, 7687, 5642, 2714, 55445, 56636, 71545, 184182, 93133, 7332, 37389, 12643, 52315,\n\t22729, 11014, 158742, 17050, 152889, 50178, 34601, 41945, 52136, 9948, 26914, 63548, 95721, 115951, 40759, 8960,\n\t158258, 38938, 49232, 48325, 42234, 81523, 253019, 66128, 40978, 20048, 238048, 38760, 62928, 122560, 118532, 43687,\n\t137472, 163689, 26680, 9878, 17448, 51035, 16211, 60834, 36749, 29178, 14241, 59868, 150086, 2305, 26477, 42422,\n\t34342, 165341, 83279, 33894, 14257, 29928, 12743, 13957, 125571, 89134, 66712, 10952, 16507, 147839, 30146, 7249,\n\t16565, 45399, 39874, 114565, 215780, 31990, 230881, 171477, 102, 196546, 44538, 10880, 84948, 281705, 86651, 10617,\n\t31395, 2342, 453658, 43569, 60561, 132901, 21845, 17727, 58556, 258242, 22262, 58728, 4008, 77997, 11806, 37431,\n\t30599, 81375, 109137, 185787, 114085, 217292, 97453, 169085, 30593, 60212, 11544, 102056, 65580, 2384, 91655, 4855,\n\t95725, 7295, 157994, 16228, 20669, 53276, 141590, 105246, 17334, 25440, 76067, 17967, 39321, 38911, 11362, 28559,\n\t63807, 21627, 26468, 85816, 40120, 1025, 15234, 58319, 69516, 66512, 124548, 75845, 78873, 22137, 46681, 51242,\n\t85683, 32909, 76747, 35555, 43396, 101465, 1765, 73094, 1077, 2962, 39028, 66777, 57831, 42048, 15828, 13962,\n\t36041, 63657, 52412, 5242, 58846, 2141, 5506, 219012, 134451, 3936, 182230, 17558, 17153, 152237, 22621, 49377,\n\t170216, 35257, 68233, 65374, 6510, 11126, 212151, 7184, 2480, 22517, 3437, 33073, 30156, 16557, 3768, 55067,\n\t86829, 91000, 12350, 148650, 66017, 79424, 70885, 49066, 28250, 21369, 51213, 34533, 11510, 3258, 18176, 18465,\n\t84413, 6315, 36411, 163765, 4346, 356, 107618, 598, 13727, 285026, 162695, 8749, 14583, 7132, 63521, 184253,\n\t32378, 25991, 5604, 30961, 53675, 4874, 84693, 5086, 34811, 26978, 56564, 7904, 33519, 51221, 113942, 69253,\n\t6664, 125563, 22055, 220680, 102008, 742, 51930, 19494, 176108, 44424, 35123, 13025, 75685, 11759, 74335, 22250,\n\t181453, 131147, 16984, 132115, 154311, 11991, 76452, 52609, 85351, 196, 30969, 9198, 74919, 2529, 56838, 71779,\n\t29187, 116304, 3504, 62330, 41190, 86153, 28393, 254926, 104228, 105189, 13264, 84359, 3574, 12415, 8534, 57147,\n\t10175, 188174, 59504, 60932, 66318, 16407, 107921, 17638, 99103, 49278, 28403, 39786, 145865, 8462, 3558, 43406,\n\t142271, 29139, 21989, 36552, 93955, 72365, 7176, 13556, 106185, 37957, 321774, 17782, 129017, 51154, 27938, 24952,\n\t1935, 39366, 2791, 33489, 41582, 56078, 24558, 9311, 5449, 218786, 27808, 190429, 68013, 36020, 86003, 29735,\n\t3404, 87348, 119357, 115714, 2324, 86796, 81973, 40992, 43376, 93621, 28784, 16808, 36367, 2517, 2909, 191926,\n\t24978, 55303, 53308, 205724, 60068, 3098, 21375, 64784, 23949, 26579, 63121, 12319, 80145, 39967, 97861, 6757,\n\t70143, 67642, 37082, 34698, 69140, 122883, 46151, 62187, 80934, 429, 19437, 135071, 137885, 222647, 13331, 154065,\n\t327, 61778, 74257, 40116, 37493, 14855, 85079, 237641, 42342, 102164, 199965, 71204, 4662, 29368, 5042, 113914,\n\t122214, 8955, 13149, 102503, 43173, 5659, 163787, 69003, 307084, 63392, 171080, 21390, 81918, 86666, 36622, 24126,\n\t28887, 5736, 28054, 207170, 163428, 79891, 346467, 95363, 38980, 111806, 80828, 9200, 19288, 294896, 114468, 87405,\n\t111715, 141705, 7015, 72754, 68463, 48738, 243147, 33397, 101210, 37051, 98801, 82847, 20397, 4940, 185559, 18716,\n\t54718, 83491, 11725, 40803, 1128, 12128, 23060, 5174, 7745, 67007, 46701, 1571, 27807, 180186, 256996, 18975,\n\t16837, 7877, 212758, 250379, 15440, 87954, 57755, 24719, 124057, 83461, 258, 50864, 8874, 29038, 71289, 31627,\n\t15429, 9005, 4061, 113851, 107716, 82819, 13651, 79656, 117851, 17539, 111446, 12938, 39724, 190787, 4352, 15402,\n\t21070, 62708, 8539, 23777, 73853, 13552, 38810, 86117, 16285, 56400, 1718, 75342, 142863, 29033, 378, 110113,\n\t180321, 32586, 23606, 26393, 160984, 207987, 23783, 8406, 16904, 24596, 47274, 11693, 46539, 60524, 78595, 48423,\n\t31718, 20170, 9009, 146268, 15183, 191060, 172765, 1349, 138436, 37365, 10970, 40509, 225817, 20021, 70394, 152138,\n\t21541, 66559, 66544, 89352, 2725, 17258, 91345, 7313, 3815, 115868, 8660, 40362, 4071, 103524, 39388, 118275,\n\t21950, 6549, 38226, 32754, 209574, 29201, 43495, 18028, 20296, 40597, 18370, 47520, 202450, 24134, 2219, 8195,\n\t69545, 38041, 136934, 46374, 19041, 159811, 84865, 58620, 846, 98749, 13569, 30714, 97246, 32186, 4479, 27355,\n\t92973, 35214, 151491, 75963, 37631, 1561, 27200, 238083, 23182, 60756, 12291, 25766, 39355, 102333, 87362, 65741,\n\t59906, 19538, 201575, 48772, 102938, 24438, 292580, 39964, 66366, 9004, 61379, 50548, 37622, 38732, 28379, 68180,\n\t76622, 17488, 69849, 5963, 7219, 48143, 43413, 55358, 540, 58691, 29506, 19245, 52193, 48621, 5518, 13048,\n\t118625, 44755, 191081, 42061, 89197, 2259, 60665, 66994, 71210, 51232, 3585, 142096, 55024, 7892, 8345, 58653,\n\t463307, 65658, 64319, 137941, 136323, 53499, 12746, 43492, 6978, 95163, 29925, 60175, 5128, 7352, 41463, 184756,\n\t121146, 20473, 18426, 4598, 5309, 54580, 14277, 121151, 10691, 56711, 43880, 63409, 76682, 11830, 172218, 264898,\n\t32632, 66536, 81062, 31649, 25788, 92774, 60222, 11100, 63159, 9432, 224657, 25240, 53613, 152, 138620, 163829,\n\t2397, 85345, 12501, 37507, 64932, 38575, 43522, 65789, 80198, 78796, 35226, 3851, 108891, 73311, 3060, 28391,\n\t93671, 39663, 46142, 30982, 66041, 37281, 68157, 26553, 71872, 81142, 211527, 39747, 118119, 22695, 2859, 11066,\n\t20232, 168911, 7933, 197005, 17066, 111071, 44434, 133994, 120798, 12766, 227798, 45756, 132852, 29917, 36076, 55352,\n\t65281, 129800, 41958, 18944, 84678, 18580, 168093, 132621, 39997, 54092, 27740, 32354, 3770, 114118, 103242, 43918,\n\t15899, 18574, 145944, 3190, 123469, 219903, 24169, 100571, 62403, 16776, 92779, 14535, 17168, 16475, 14304, 37231,\n\t1712, 28218, 242754, 61688, 28980, 1318, 51359, 222657, 99200, 67989, 31772, 23932, 35351, 201251, 49041, 27306,\n\t19128, 40135, 3986, 77333, 19649, 120683, 151927, 21081, 7076, 78375, 77501, 101599, 8011, 89585, 96715, 58179,\n\t5378, 102138, 106793, 26051, 217276, 4197, 16297, 27014, 46721, 13322, 22806, 5278, 29629, 70632, 9647, 71519,\n\t58818, 40603, 128530, 8903, 36770, 56900, 31483, 26935, 43845, 34265, 34920, 87658, 6114, 84767, 64250, 47318,\n\t50720, 19264, 162514, 33357, 13117, 6705, 46696, 75032, 71054, 87004, 42035, 69138, 11903, 99854, 102328, 19611,\n\t34525, 69312, 6431, 49842, 101600, 133178, 108751, 41829, 89939, 225664, 48916, 99556, 9195, 130387, 5960, 36857,\n\t116724, 53518, 94002, 39077, 53996, 6945, 22261, 64291, 8314, 152785, 57588, 16522, 9091, 5048, 87671, 35441,\n\t39509, 1945, 12423, 158923, 178413, 37549, 14095, 1475, 73188, 62878, 4819, 24012, 68534, 42606, 4010, 120809,\n\t57497, 59564, 101758, 103718, 32701, 80116, 12345, 95834, 46918, 21468, 53213, 15665, 31200, 3867, 5140, 96013,\n\t250744, 21016, 10069, 13968, 35449, 180829, 27683, 39704, 59956, 22893, 3115, 26293, 32785, 75934, 62445, 141162,\n\t62720, 2018, 83638, 19949, 114012, 95006, 3330, 99829, 130935, 309272, 9565, 55874, 121727, 37017, 23586, 319858,\n\t40970, 27602, 8625, 112329, 61060, 100088, 118525, 25922, 16232, 1907, 60671, 51583, 44553, 80993, 5262, 94679,\n\t8676, 940, 20736, 11823, 3020, 16476, 12340, 152600, 97416, 3703, 25744, 66826, 16245, 16876, 46446, 84798,\n\t74227, 176020, 45192, 61955, 75496, 23946, 23626, 40372, 26036, 6149, 11822, 30582, 16541, 41914, 82385, 232823,\n\t40921, 80773, 14930, 3631, 7517, 39619, 4348, 36180, 126106, 138939, 62611, 1477, 113512, 47321, 25052, 14546,\n\t118881, 29060, 23589, 128322, 36795, 18401, 137921, 104699, 267929, 36194, 172791, 18113, 4766, 188215, 30083, 332586,\n\t94089, 5805, 77909, 22194, 68234, 154976, 43220, 40660, 70001, 184893, 138095, 11128, 103010, 22663, 5108, 212615,\n\t8485, 5565, 49222, 54614, 26530, 42639, 16319, 55062, 152662, 105595, 21114, 22216, 10294, 68158, 10436, 86950,\n\t7206, 62115, 3977, 3657, 59874, 456, 118617, 18156, 106663, 112229, 80992, 17442, 8217, 55551, 5133, 34344,\n\t251927, 51153, 39364, 201321, 7816, 66803, 23057, 156724, 145664, 14276, 95705, 979, 2796, 6875, 13429, 212525,\n\t50602, 26276, 28284, 3424, 19465, 52397, 46963, 31420, 51399, 206476, 92317, 48851, 637, 100820, 83349, 10317,\n\t60227, 21972, 6908, 282439, 32857, 224767, 95629, 83882, 42106, 87338, 69757, 29840, 68709, 37665, 45244, 114577,\n\t49188, 175943, 54009, 186746, 106158, 70168, 3358, 234002, 50555, 9221, 129338, 9562, 20118, 32923, 78479, 118280,\n\t65752, 4977, 10474, 102174, 60947, 129006, 10570, 83451, 8598, 8078, 159367, 123785, 80438, 16742, 5905, 5281,\n\t181513, 42402, 6977, 163136, 93179, 42191, 14968, 50421, 112401, 105440, 33456, 57347, 121611, 4221, 94954, 36517,\n\t24046, 27796, 6255, 33394, 72990, 135408, 116627, 1233, 57874, 25654, 95419, 68156, 401399, 313338, 55208, 45573,\n\t93124, 119251, 47200, 38196, 11909, 130667, 45391, 73904, 64964, 167846, 4137, 115606, 52036, 62214, 7969, 160925,\n\t7187, 1132, 134835, 40309, 73195, 64494, 80472, 444841, 61111, 26500, 45323, 40743, 53625, 52797, 22659, 15631,\n\t29739, 36706, 28841, 39147, 102836, 26794, 10536, 14845, 87305, 45874, 12241, 127587, 83833, 57183, 79722, 30844,\n\t41304, 84655, 20825, 92500, 3722, 25655, 27811, 10157, 81634, 31362, 34088, 92487, 70123, 22190, 185100, 72658,\n\t139035, 192523, 88241, 2078, 230490, 44528, 85638, 100198, 22088, 29982, 291233, 241062, 13865, 4445, 137791, 37835,\n\t107218, 31726, 19718, 38234, 72528, 23046, 19177, 66695, 5109, 17251, 28077, 5617, 21554, 47839, 72425, 133825,\n\t1486, 73065, 181275, 141508, 21768, 62971, 63082, 2512, 34200, 9904, 120309, 6392, 91243, 68416, 268253, 41199,\n\t116757, 138551, 185526, 41246, 28986, 4093, 19057, 17295, 4148, 245766, 122360, 35356, 112075, 20301, 75441, 10998,\n\t7977, 19769, 62922, 937, 63547, 100196, 26427, 157820, 20983, 236696, 22935, 8140, 90315, 156004, 47204, 140973,\n\t7726, 45097, 52725, 22636, 23436, 257282, 105247, 522, 88389, 216031, 202204, 46812, 211666, 19693, 68828, 81691,\n\t45925, 11256, 30292, 372, 5236, 167826, 88328, 232776, 151611, 5360, 82104, 18841, 80393, 25465, 18285, 20320,\n\t72377, 31730, 33160, 45803, 38715, 27705, 37379, 24163, 18360, 103586, 4015, 32305, 269494, 91252, 20080, 36567,\n\t54650, 7797, 57073, 12650, 31164, 42209, 6375, 261663, 105528, 81661, 106002, 2800, 5375, 17247, 43151, 4442,\n\t15727, 194619, 100855, 144898, 62320, 78465, 39929, 16454, 1967, 28311, 61363, 17219, 9395, 8745, 121445, 76939,\n\t80385, 162380, 22009, 54191, 44248, 16299, 122830, 48151, 74429, 78291, 64755, 14238, 44966, 2511, 17712, 67954,\n\t93583, 829, 105899, 49935, 84750, 11591, 33185, 85447, 42717, 27409, 208542, 28965, 62052, 52525, 5597, 25694,\n\t65594, 16343, 63224, 276188, 12475, 9331, 127507, 38522, 57287, 24128, 133161, 79723, 105548, 133695, 48917, 27558,\n\t43278, 46520, 13778, 141954, 110785, 83366, 17715, 46317, 105763, 66298, 147013, 41086, 94180, 16478, 220447, 44611,\n\t730, 19722, 78975, 117889, 125643, 26254, 16574, 18480, 65006, 15806, 38549, 246418, 46052, 36056, 8440, 34984,\n\t30170, 3163, 59800, 4458, 115442, 4283, 41970, 33507, 104078, 1653, 22, 121158, 276486, 3655, 6338, 24048,\n\t133421, 23641, 2161, 24422, 36006, 8086, 10675, 181474, 12307, 29514, 59143, 14729, 52509, 87128, 122470, 19446,\n\t80852, 33314, 24573, 119864, 14237, 9652, 57779, 6612, 51851, 15284, 98871, 90581, 124466, 156831, 21190, 22015,\n\t71380, 161906, 87247, 69201, 18392, 17908, 108470, 72962, 40719, 14338, 17911, 95260, 43339, 20610, 78916, 20710,\n\t72451, 11315, 31448, 17263, 58853, 178878, 48111, 116002, 45497, 80506, 82605, 85880, 36300, 121755, 25215, 36118,\n\t301929, 88728, 405223, 276136, 553, 34704, 212438, 49970, 78329, 922, 20711, 25036, 257130, 38295, 145369, 18128,\n\t15385, 30829, 55656, 48345, 8012, 3561, 28004, 122041, 192900, 58338, 112508, 41085, 29976, 87040, 47117, 23905,\n\t4336, 92061, 138880, 97407, 42083, 172121, 6256, 25192, 172671, 5, 93568, 1420, 12677, 31605, 56743, 40620,\n\t6015, 78415, 231077, 31298, 80026, 13902, 19048, 24924, 170586, 32955, 176119, 87859, 36731, 6773, 27711, 24658,\n\t26475, 115216, 133207, 93250, 95820, 88522, 8317, 5714, 124047, 55219, 86860, 19677, 23961, 22928, 162209, 8904,\n\t225992, 359835, 56084, 96201, 29392, 96558, 86071, 93643, 55114, 13347, 8183, 95129, 82012, 2017, 123336, 34219,\n\t115554, 157159, 47747, 101684, 41008, 18735, 193781, 104151, 226906, 7552, 179874, 124113, 31159, 21162, 44010, 14771,\n\t51268, 166128, 31382, 73124, 77438, 92830, 205709, 12113, 1292, 38937, 13114, 1334, 2118, 15597, 69581, 14449,\n\t21934, 76618, 48728, 67038, 14967, 51495, 24243, 87736, 147249, 26720, 11119, 46063, 43749, 5843, 44147, 152629,\n\t133428, 65703, 14269, 45604, 57982, 28672, 55616, 45957, 8438, 95433, 37698, 220862, 132034, 39456, 61870, 4161,\n\t26501, 73560, 56418, 9845, 4654, 20916, 10456, 88920, 119358, 9015, 65931, 96507, 48029, 38534, 21676, 109081,\n\t43078, 34943, 25089, 6131, 28766, 23665, 5477, 10255, 16695, 67, 45778, 42443, 42770, 29534, 23733, 100513,\n\t62617, 42630, 48746, 14191, 43753, 50295, 26007, 8792, 57243, 43119, 54725, 164253, 58250, 112304, 131796, 25165,\n\t4651, 3188, 24831, 47748, 3705, 19540, 13211, 102095, 5593, 18699, 23666, 32005, 117571, 33541, 60584, 74573,\n\t86311, 99443, 25172, 27222, 168938, 7143, 11853, 53560, 18834, 19960, 86522, 28217, 53266, 117700, 72989, 34323,\n\t18721, 66450, 34346, 74056, 47217, 202002, 46269, 9429, 68582, 75458, 37823, 82843, 96652, 32549, 145144, 27958,\n\t19820, 158086, 31955, 201406, 135379, 31207, 192545, 12950, 51704, 9094, 248263, 76147, 64028, 110009, 79407, 89345,\n\t99284, 223492, 47966, 26848, 15359, 201137, 2861, 110507, 71231, 72297, 31851, 118777, 71039, 151051, 240855, 16333,\n\t50766, 14727, 7939, 4149, 80908, 418780, 88378, 59276, 1327, 7284, 38576, 79814, 65820, 42199, 84860, 49574,\n\t62596, 12396, 70598, 40117, 8648, 7994, 16836, 7630, 14047, 359699, 106878, 525, 29037, 28064, 13380, 11675,\n\t50669, 74216, 103539, 180314, 27449, 56299, 172344, 19274, 7301, 246099, 32043, 19422, 36506, 129317, 6806, 30140,\n\t4614, 46639, 66926, 932, 86600, 6322, 27847, 233103, 10541, 39025, 34887, 3517, 12972, 26220, 2031, 66561,\n\t115015, 48658, 47596, 12714, 33845, 3893, 16165, 35237, 89983, 14769, 11962, 147224, 47018, 29977, 27979, 5552,\n\t82338, 86023, 131368, 1218, 24853, 237840, 132193, 15455, 40873, 3668, 65351, 53388, 15229, 59889, 272245, 47934,\n\t11858, 34347, 18038, 90853, 86981, 300602, 19343, 114181, 29362, 84921, 6095, 106059, 79472, 38015, 1206, 48741,\n\t6208, 80000, 21916, 17423, 6002, 108083, 24479, 34931, 56661, 9511, 26995, 100694, 163853, 35997, 81254, 58321,\n\t18919, 171890, 86877, 91341, 74503, 70477, 53412, 7027, 59281, 39892, 131302, 5864, 15947, 61301, 67466, 162369,\n\t47956, 27874, 35624, 282324, 21270, 111847, 102548, 41482, 30955, 116737, 28264, 8592, 55458, 22301, 75090, 29821,\n\t30697, 51709, 3041, 19208, 8038, 24634, 30467, 87509, 126428, 19389, 18814, 152686, 20701, 83474, 45832, 80891,\n\t105808, 11378, 153223, 120770, 98186, 150633, 49838, 9141, 12755, 30962, 5260, 74490, 21256, 31678, 65062, 33326,\n\t289838, 187831, 20595, 89768, 2805, 58535, 10844, 70085, 12090, 2451, 138068, 98544, 24461, 4511, 6754, 41684,\n\t28203, 3383, 65355, 82833, 30161, 83924, 234361, 128424, 28921, 222594, 33975, 125491, 34069, 11508, 67464, 144226,\n\t41850, 98703, 34371, 7901, 21254, 38398, 65651, 23549, 53883, 213340, 123269, 12028, 71764, 177701, 28758, 2623,\n\t68395, 11549, 15232, 68603, 9660, 63116, 36079, 57093, 31198, 20475, 48467, 89984, 35619, 186847, 107469, 31389,\n\t43631, 73867, 41949, 68841, 114250, 1605, 30564, 63403, 17588, 27680, 99533, 12641, 70325, 50428, 73426, 78379,\n\t11855, 91651, 72081, 91720, 60198, 15743, 12065, 83398, 140046, 6761, 46598, 45900, 5068, 886, 62448, 148968,\n\t37347, 19405, 9680, 15819, 43496, 63370, 75667, 163700, 37639, 3633, 22774, 34341, 183131, 134335, 37200, 23915,\n\t7054, 14194, 12970, 26438, 13350, 285521, 25594, 8219, 104410, 91039, 168804, 138480, 149734, 15907, 33818, 61132,\n\t60082, 4622, 110187, 56736, 13551, 73571, 3945, 73463, 65498, 17758, 263266, 17593, 2710, 27585, 54469, 38200,\n\t45367, 63754, 28881, 3473, 12791, 98287, 31895, 65787, 4463, 94536, 24951, 36332, 59901, 28803, 52130, 86403,\n\t7668, 181822, 74831, 18977, 9850, 177206, 145485, 109798, 7292, 31421, 26280, 77211, 58511, 12507, 127004, 11113,\n\t147, 8729, 56208, 43066, 79926, 129937, 31345, 83947, 39915, 46146, 98763, 42566, 1337, 13192, 18323, 105163,\n\t80570, 117753, 16555, 72883, 11077, 159438, 40764, 70933, 83329, 26066, 12276, 72059, 21655, 173836, 126713, 69454,\n\t153482, 91585, 70644, 102558, 110483, 6764, 127864, 190133, 3961, 101798, 20945, 71138, 82402, 90884, 69669, 44753,\n\t923, 16939, 59700, 164258, 25969, 27082, 31399, 43846, 6306, 246093, 51342, 6153, 151581, 202801, 182731, 56475,\n\t162188, 89426, 141356, 14355, 121815, 27536, 28023, 65257, 77523, 106668, 127314, 24947, 12790, 38796, 169698, 23555,\n\t10725, 44573, 183083, 42088, 62716, 43265, 105958, 32050, 44067, 50118, 1668, 3874, 6243, 318411, 16599, 1691,\n\t94999, 52378, 28671, 216728, 123258, 2059, 34969, 69225, 5913, 136280, 171443, 141515, 91662, 22175, 135282, 80020,\n\t92270, 1663, 4808, 4482, 3495, 34691, 5226, 109830, 108512, 17342, 107488, 11606, 123190, 100247, 29666, 146527,\n\t113014, 15794, 30894, 13224, 39585, 243192, 22351, 9903, 7836, 47699, 11078, 25468, 122291, 48821, 26780, 122679,\n\t75521, 81450, 630, 4895, 92900, 55074, 74293, 17441, 3563, 111657, 103102, 51613, 12318, 52370, 36191, 68245,\n\t34269, 40445, 41354, 122901, 168604, 182500, 62012, 42557, 11259, 24428, 115113, 86345, 12362, 3909, 78430, 86852,\n\t134602, 20459, 47853, 93879, 22577, 7659, 3688, 38555, 13349, 17381, 56715, 91639, 12493, 10895, 92438, 3142,\n\t37057, 28928, 2004, 36427, 32268, 34222, 209974, 10432, 67436, 41989, 173518, 107930, 27079, 62729, 30908, 55558,\n\t5828, 45031, 14902, 53546, 8204, 144263, 60255, 14520, 88212, 86582, 109589, 69356, 8064, 47449, 8505, 66558,\n\t16886, 4844, 52817, 111260, 215129, 12941, 91118, 650, 20770, 6273, 73089, 40618, 62790, 2873, 35002, 14023,\n\t97208, 19386, 102646, 36993, 143736, 135457, 35385, 113601, 17893, 32627, 84439, 100619, 56016, 6581, 57264, 172160,\n\t45452, 111710, 203627, 70131, 24100, 322787, 1996, 35665, 70078, 22358, 90922, 83658, 4097, 63200, 58499, 14542,\n\t99153, 52159, 6615, 12414, 63415, 31986, 16823, 1579, 65405, 137809, 8841, 16898, 48082, 259, 33014, 42375,\n\t12260, 179850, 73667, 91389, 98882, 29532, 17311, 326251, 41092, 5928, 20742, 44964, 48019, 43505, 9317, 49265,\n\t6643, 192712, 48424, 163487, 19861, 20113, 70848, 31928, 105333, 23685, 78563, 14638, 54755, 7158, 24142, 44018,\n\t20774, 125255, 20331, 24280, 10163, 1285, 2336, 39851, 4299, 117269, 46714, 63816, 87779, 159624, 11731, 9971,\n\t990, 137317, 108831, 50994, 74554, 162680, 23640, 131597, 146962, 170620, 34829, 91205, 21184, 1913, 63616, 18427,\n\t93136, 156592, 17519, 67565, 115882, 138220, 78622, 88535, 18115, 2711, 33554, 109492, 54298, 971, 24914, 25863,\n\t36363, 45715, 27099, 194995, 14299, 178181, 111488, 72395, 322385, 157719, 130787, 11897, 81843, 83999, 11369, 49280,\n\t118604, 40922, 61332, 110343, 53407, 75639, 40582, 300440, 54722, 25637, 13694, 48248, 48278, 194521, 56203, 52779,\n\t48783, 72627, 10953, 376, 16733, 280238, 26351, 230789, 15132, 25168, 137270, 3588, 63704, 73376, 94031, 74284,\n\t19443, 159557, 9697, 39901, 13351, 119050, 15406, 146455, 3460, 29556, 75195, 37673, 102524, 92329, 47289, 98413,\n\t15311, 100684, 56345, 7116, 95480, 11590, 7200, 167, 23610, 58426, 17730, 136656, 27944, 53151, 2701, 8824,\n\t103124, 3017, 90744, 113588, 53216, 79736, 65940, 26931, 498, 29568, 80540, 143543, 21292, 1740, 59268, 16561,\n\t180816, 42323, 50174, 40890, 52866, 10703, 57169, 4700, 17191, 4424, 93511, 49698, 166650, 26972, 48631, 165169,\n\t82879, 69326, 202970, 4007, 2376, 231325, 139592, 22119, 62851, 37504, 68816, 58345, 67398, 186643, 43331, 277416,\n\t53749, 15746, 23102, 17432, 4793, 151138, 48822, 54265, 48203, 198688, 14305, 54287, 2291, 18018, 113378, 123260,\n\t7180, 97549, 87027, 120085, 2920, 76080, 8190, 102005, 5641, 64580, 14955, 59802, 54028, 58884, 19367, 81779,\n\t412567, 85957, 97053, 103637, 78871, 29364, 27637, 141728, 4767, 30686, 112738, 130146, 42745, 12730, 105040, 14844,\n\t232, 210944, 36581, 152317, 135543, 29744, 3129, 55647, 58149, 46319, 27265, 17499, 28005, 59948, 7170, 34138,\n\t5702, 293047, 110892, 408, 91760, 218674, 18469, 46095, 81403, 14389, 4610, 35672, 73060, 11006, 74848, 104820,\n\t118143, 190357, 20043, 105358, 141735, 5115, 27093, 45924, 123073, 52599, 29433, 9616, 238350, 78610, 24851, 58858,\n\t26769, 31969, 24613, 18294, 4982, 32735, 39639, 143563, 112073, 202205, 12567, 4873, 88601, 44897, 81503, 101648,\n\t81362, 34662, 85277, 17574, 48173, 21435, 221188, 40215, 39576, 80786, 26544, 64668, 81841, 10731, 37733, 247986,\n\t149188, 127703, 495, 18382, 54388, 72446, 43071, 30974, 198723, 89608, 41360, 190, 33045, 8386, 31658, 19992,\n\t237838, 119015, 137622, 50890, 100913, 6460, 116233, 267230, 26621, 104129, 65114, 14190, 41542, 14888, 85962, 23342,\n\t23041, 26453, 43725, 71809, 45186, 4770, 46452, 53894, 56616, 221286, 18973, 9038, 109299, 55365, 19366, 26863,\n\t18808, 60909, 69353, 41738, 83463, 12100, 68561, 72860, 3980, 13796, 49340, 12332, 31311, 27418, 4255, 53430,\n\t18976, 45523, 510, 14224, 30477, 26581, 4530, 3651, 101663, 139840, 22709, 150861, 31996, 63923, 120623, 262522,\n\t3076, 10528, 2929, 14672, 130238, 18087, 9816, 121894, 100308, 25085, 55111, 14565, 18952, 53293, 2042, 369988,\n\t23674, 61789, 133529, 28783, 108293, 35477, 47119, 36448, 71049, 40015, 33055, 78598, 198442, 1833, 159937, 40654,\n\t77444, 189245, 113153, 8621, 18599, 38553, 35223, 166072, 2375, 11659, 21786, 89523, 6032, 12116, 63046, 159398,\n\t18454, 3678, 32521, 47626, 11411, 103527, 38896, 42946, 15696, 26370, 10185, 8413, 37080, 165583, 4331, 63555,\n\t14907, 72220, 50056, 6623, 62236, 36565, 49783, 10049, 17503, 100581, 55951, 146244, 24724, 9626, 17969, 25524,\n\t109300, 173965, 99994, 101056, 46459, 43647, 53737, 277968, 8347, 123521, 74858, 33829, 44762, 77574, 877, 81377,\n\t222525, 123532, 30602, 43881, 53145, 2973, 16284, 81940, 61281, 127044, 63620, 9875, 14756, 114829, 19032, 9202,\n\t52759, 119141, 23928, 120551, 19607, 3599, 33401, 76821, 73233, 117430, 39968, 36539, 7071, 5446, 121735, 194059,\n\t15206, 45283, 6706, 15603, 65615, 1207, 165723, 92275, 34773, 104447, 8396, 32353, 205240, 164323, 13600, 60555,\n\t79205, 25532, 22907, 33410, 57480, 107111, 69630, 32137, 47832, 70913, 33161, 20321, 2371, 117348, 10714, 86246,\n\t1625, 11763, 17900, 268, 78457, 99175, 97940, 101092, 86660, 32221, 14041, 128504, 125080, 53744, 124263, 31017,\n\t13897, 403, 31859, 21964, 5633, 111630, 5547, 77329, 17961, 18241, 84995, 25984, 12983, 67491, 62168, 47262,\n\t5241, 297, 51191, 7351, 8967, 147212, 82060, 16821, 782, 11033, 82431, 62957, 5026, 43459, 77963, 203477,\n\t53528, 6247, 191852, 87774, 74164, 215654, 13467, 1522, 219964, 28589, 244104, 16242, 117821, 67725, 72570, 156792,\n\t17186, 15979, 26990, 44128, 193014, 35276, 57125, 16212, 166451, 68017, 6905, 77608, 16364, 53777, 75921, 76426,\n\t37975, 26203, 269296, 64099, 84122, 12077, 38533, 830, 4407, 20139, 963, 43028, 38902, 42911, 37503, 83343,\n\t85045, 16979, 1165, 60835, 137387, 58380, 86990, 110066, 134540, 56331, 193845, 81238, 17922, 163093, 38744, 110641,\n\t12502, 56404, 34862, 26865, 125964, 12965, 111648, 25547, 7771, 27196, 136980, 9555, 29551, 107158, 57885, 18831,\n\t37705, 35505, 101742, 13970, 102109, 62548, 124657, 23328, 11124, 89592, 146376, 248050, 6241, 22033, 18337, 80685,\n\t29898, 11908, 216623, 67721, 106162, 146610, 21377, 15085, 91552, 42041, 62560, 122532, 125336, 102365, 121537, 142559,\n\t29693, 223919, 11515, 110495, 18776, 22494, 5895, 185059, 103592, 229351, 51220, 100102, 37027, 257855, 29359, 54123,\n\t36066, 106493, 12244, 79258, 32002, 432, 56205, 94836, 90182, 6726, 14762, 29391, 48938, 26864, 38083, 60364,\n\t3310, 60192, 14766, 205567, 57504, 110760, 22649, 24666, 46333, 21517, 3430, 13135, 28873, 27052, 158809, 11597,\n\t20529, 6695, 23138, 22960, 37137, 45574, 6545, 305877, 43423, 26153, 24769, 59844, 14501, 10430, 134352, 56169,\n\t13213, 103432, 49523, 35181, 13435, 12408, 129475, 64620, 230854, 77390, 51990, 15653, 83248, 33466, 44571, 117828,\n\t51481, 2187, 10559, 68019, 18021, 54895, 48247, 18354, 33737, 4554, 108595, 37288, 39767, 116707, 9175, 3726,\n\t108877, 21616, 83684, 49862, 1938, 8543, 276466, 20134, 108498, 48770, 102254, 31914, 131520, 185291, 100559, 51890,\n\t209, 19526, 76471, 50544, 71814, 99351, 8172, 198526, 28816, 20419, 9109, 98389, 136777, 76479, 75596, 30635,\n\t165417, 48216, 120220, 25955, 211071, 39314, 24308, 32164, 2559, 146280, 43403, 9233, 17947, 90585, 1786, 86920,\n\t125662, 2457, 64741, 32152, 32918, 122882, 78538, 44001, 31723, 56426, 23375, 103172, 88177, 145697, 52506, 49319,\n\t68016, 31664, 41488, 18486, 110400, 7030, 28241, 986, 109199, 19900, 42147, 56864, 65287, 49183, 7858, 24000,\n\t30453, 840, 16673, 25907, 68916, 89927, 6309, 158335, 36407, 199737, 130464, 13137, 59603, 201778, 195292, 21015,\n\t42466, 179062, 172561, 89492, 11075, 180407, 31868, 72493, 20998, 60217, 9865, 19530, 39274, 130266, 54539, 21623,\n\t12535, 13505, 40641, 73375, 4087, 85633, 2153, 3117, 70680, 55788, 92096, 47509, 98493, 37490, 271936, 151475,\n\t3032, 16171, 96642, 34106, 78425, 125761, 19591, 3366, 19316, 54508, 24183, 50786, 194248, 91528, 33253, 34622,\n\t108355, 41741, 705, 3814, 3883, 108929, 13203, 67831, 10142, 59754, 68208, 29128, 84820, 56880, 38794, 24972,\n\t48571, 40821, 40476, 18137, 164254, 24064, 236309, 79181, 11282, 395, 39169, 2013, 51587, 28551, 9645, 701,\n\t109513, 115899, 113566, 12762, 62045, 58322, 103726, 41343, 40866, 244102, 143816, 2490, 70346, 40973, 52618, 15412,\n\t30720, 104315, 38917, 42027, 93676, 17513, 107418, 20706, 123890, 13399, 97727, 24044, 87962, 65606, 44250, 98044,\n\t65276, 74790, 101473, 19350, 91570, 1326, 87790, 172042, 7577, 100813, 86896, 85891, 41512, 108130, 27794, 14875,\n\t71431, 12835, 156250, 58135, 3759, 22476, 42176, 115873, 34686, 56523, 73643, 108505, 51491, 20838, 12721, 32863,\n\t45700, 29496, 13700, 34294, 55360, 29206, 155942, 123812, 7706, 163234, 203, 132720, 49358, 144431, 8130, 175788,\n\t35818, 3270, 76832, 25710, 54095, 97274, 28779, 94621, 74396, 19092, 128242, 58067, 20885, 14670, 93255, 15107,\n\t63291, 23654, 126900, 129421, 59294, 262659, 9798, 3251, 67344, 28600, 44629, 50672, 29072, 26999, 31526, 23183,\n\t49175, 165843, 175455, 17282, 175411, 32022, 45989, 30298, 90690, 78118, 83156, 23749, 35636, 31317, 7069, 80381,\n\t94561, 133756, 14960, 97404, 6138, 41065, 78041, 32843, 16601, 34123, 9559, 146529, 123377, 96395, 54441, 42012,\n\t84257, 123541, 10745, 22139, 106459, 11720, 150883, 172651, 154996, 110538, 4728, 53447, 25704, 2009, 71152, 119354,\n\t21166, 66604, 1429, 216162, 8637, 122250, 63520, 27180, 29172, 36124, 276428, 107787, 77184, 4680, 14952, 104903,\n\t24418, 14793, 51561, 52931, 8371, 26342, 48526, 7118, 92066, 67280, 40653, 8847, 34597, 105438, 14198, 50163,\n\t61188, 146286, 50315, 41205, 170829, 161496, 585, 197359, 95056, 1687, 365794, 91349, 48507, 5804, 49263, 5146,\n\t104902, 96365, 117343, 132222, 46084, 96919, 16875, 8073, 262381, 79982, 52663, 13928, 16056, 153908, 15145, 109256,\n\t132308, 18763, 24904, 167644, 13618, 40750, 18686, 147124, 114709, 150038, 52849, 2938, 12568, 48617, 8778, 5459,\n\t44202, 44591, 74914, 17183, 248689, 13878, 7822, 80060, 23116, 194037, 18487, 2067, 7798, 43077, 33678, 244028,\n\t31320, 74273, 2794, 19466, 8218, 36280, 183997, 48124, 19416, 29656, 19280, 98734, 7715, 18311, 30701, 133602,\n\t150307, 126956, 7378, 2933, 79903, 13178, 12593, 86571, 26604, 92446, 13574, 44205, 65699, 427599, 21118, 8245,\n\t14407, 27877, 47936, 33542, 7916, 26460, 117762, 21596, 37818, 2249, 127359, 209394, 60044, 47677, 308089, 36791,\n\t154971, 31417, 6998, 150042, 174360, 12255, 43009, 29335, 48739, 3912, 101398, 53340, 2580, 146939, 151295, 45360,\n\t125275, 15273, 45383, 27456, 48761, 23314, 8750, 60801, 85823, 104759, 27894, 123685, 66968, 39480, 26917, 55290,\n\t83305, 2696, 98390, 57569, 145853, 340733, 4919, 20024, 52268, 30884, 7413, 203685, 70989, 112855, 4129, 50536,\n\t349518, 68205, 332641, 159581, 135361, 236026, 37563, 176404, 64899, 6578, 122033, 63871, 1850, 85234, 82089, 66124,\n\t74145, 121098, 107351, 12687, 36881, 117334, 13136, 14698, 85933, 93866, 18047, 32620, 310, 15094, 46000, 88451,\n\t23632, 36645, 27940, 87618, 80520, 58892, 20976, 27702, 140090, 96075, 67841, 103292, 238964, 87778, 107338, 17019,\n\t83427, 67522, 7302, 8261, 47570, 116787, 8730, 80484, 61772, 174422, 56005, 131193, 52875, 14588, 28471, 59817,\n\t9586, 15720, 158155, 51307, 109734, 15196, 11025, 59331, 3884, 52626, 102602, 84797, 25158, 27314, 4437, 20488,\n\t76214, 189248, 35023, 114952, 157376, 2827, 62439, 102878, 129749, 36405, 10329, 109339, 108633, 36662, 1254, 13267,\n\t5470, 87105, 58004, 15397, 10434, 159667, 21864, 52022, 179464, 3013, 32147, 31496, 116832, 18494, 105502, 129227,\n\t107267, 50033, 13481, 9954, 24267, 22141, 16257, 116154, 36185, 950, 115685, 11305, 176708, 2048, 178671, 112573,\n\t287867, 162328, 497663, 95170, 50979, 193861, 50987, 30368, 136257, 31830, 46549, 15119, 169876, 23788, 17462, 249887,\n\t57377, 1949, 35448, 14791, 43769, 210091, 3783, 34612, 282103, 88380, 245190, 5457, 20491, 98908, 11402, 86899,\n\t117916, 16028, 162584, 60644, 320177, 156096, 31065, 55876, 22000, 77655, 9992, 23397, 13757, 317623, 63978, 215255,\n\t2443, 17648, 93231, 27388, 104529, 93807, 55505, 140477, 12046, 112040, 70887, 40152, 94365, 112353, 25063, 114679,\n\t266061, 71248, 119555, 15589, 2244, 617, 14129, 211431, 70110, 100652, 7777, 4383, 85911, 89221, 21010, 120615,\n\t58357, 86405, 37554, 41647, 18, 15143, 69662, 60491, 14714, 186134, 148344, 42347, 5410, 168175, 44535, 42449,\n\t343894, 129417, 99682, 20659, 27272, 140483, 63455, 222159, 17536, 13722, 42637, 62324, 11976, 114691, 148109, 2283,\n\t32057, 182393, 4295, 147364, 33705, 2075, 44303, 30274, 28331, 63740, 69740, 29148, 10346, 44862, 33716, 73937,\n\t153333, 12930, 38784, 247159, 2515, 41053, 20256, 83368, 256189, 54639, 115240, 5096, 24661, 175419, 153552, 26516,\n\t141, 138176, 63885, 34115, 47222, 55709, 2765, 28479, 38875, 236608, 12229, 22921, 77291, 54426, 45388, 2860,\n\t57787, 114579, 295139, 105782, 17826, 71066, 19119, 54364, 69385, 16568, 12323, 28057, 33346, 34919, 124763, 155533,\n\t101386, 31644, 8627, 49001, 303600, 29868, 63213, 9103, 77280, 71333, 9696, 138789, 37059, 24823, 5057, 21352,\n\t32368, 114208, 56803, 19424, 10445, 58514, 8661, 209508, 26187, 171838, 10460, 63454, 14016, 122504, 41328, 21329,\n\t46618, 32493, 38225, 7855, 31763, 7945, 29876, 8734, 6438, 24205, 97490, 139977, 130740, 47323, 33195, 85390,\n\t57194, 13813, 60600, 21313, 96251, 7699, 27584, 170521, 139271, 1363, 4402, 336738, 129223, 84983, 69150, 13147,\n\t3590, 163929, 207225, 155260, 55916, 20288, 4503, 8398, 98490, 11773, 27512, 37113, 84976, 86558, 28365, 11756,\n\t116005, 182148, 13733, 115313, 47644, 67208, 85069, 9347, 14995, 226141, 14704, 101835, 41159, 35314, 13113, 63526,\n\t214039, 29978, 50446, 83339, 17440, 129441, 72522, 118641, 97816, 24907, 73844, 15717, 118884, 167255, 96509, 162793,\n\t30847, 36849, 51297, 78974, 77793, 10427, 1873, 2972, 9999, 35074, 28190, 64297, 146836, 46298, 60038, 163007,\n\t108919, 61219, 2403, 75022, 127339, 4233, 110389, 69022, 9833, 128097, 88016, 79390, 222936, 22570, 94657, 28462,\n\t56956, 38803, 81536, 30474, 152794, 19566, 16481, 147408, 74574, 81895, 20731, 1918, 1366, 76367, 187321, 54494,\n\t24366, 21690, 61696, 33283, 107477, 77499, 31112, 414383, 74362, 18463, 218441, 120929, 59848, 258629, 201924, 69269,\n\t454, 19989, 13054, 59894, 3623, 58908, 20681, 35723, 78523, 102680, 38988, 184112, 108087, 50944, 132704, 52966,\n\t21699, 18860, 96349, 201411, 82697, 85395, 95658, 5093, 6427, 177894, 44191, 32755, 26961, 155739, 6249, 31310,\n\t81030, 26574, 84311, 120155, 86730, 113535, 7424, 48888, 13516, 45747, 98098, 20077, 183995, 81945, 43210, 26704,\n\t40420, 75831, 45648, 11180, 6855, 57927, 65528, 124096, 34851, 2598, 156633, 107572, 127352, 38169, 123845, 60142,\n\t62722, 105584, 232364, 23211, 68120, 1601, 22169, 89299, 747, 258039, 80572, 7258, 152249, 11862, 101204, 8834,\n\t121434, 33761, 19175, 133142, 46343, 40178, 48723, 3589, 41977, 30210, 38868, 62257, 10087, 82658, 87827, 90646,\n\t16415, 47552, 351723, 28298, 72225, 91146, 272760, 1701, 11295, 1652, 109651, 300747, 51863, 198800, 29446, 11794,\n\t32345, 37538, 22356, 33102, 37590, 113544, 37970, 11478, 179743, 25454, 103417, 59905, 221970, 105196, 145604, 7817,\n\t164809, 102360, 16974, 75840, 255333, 56902, 6659, 1954, 645, 59400, 67769, 7689, 18675, 5215, 13793, 20536,\n\t27852, 3387, 29523, 259718, 16860, 94625, 43143, 29245, 15848, 233581, 22685, 63631, 78557, 22836, 133302, 84513,\n\t1348, 51826, 47129, 98836, 58284, 1830, 1749, 94642, 10933, 6145, 12506, 10975, 13879, 103781, 144434, 10268,\n\t28409, 32346, 52968, 121567, 107374, 77268, 23686, 35097, 10501, 155275, 15303, 47136, 21102, 168741, 55332, 90385,\n\t15996, 84817, 681, 137803, 25054, 142275, 6163, 38175, 8056, 124296, 240642, 65621, 4934, 178205, 16101, 62803,\n\t60964, 18230, 100622, 76465, 44689, 14545, 9543, 47514, 16852, 93380, 28048, 12047, 107106, 37575, 101485, 77047,\n\t57326, 34819, 96137, 76916, 6469, 46264, 115983, 75768, 87668, 69942, 13027, 165, 8373, 114231, 26434, 52844,\n\t42799, 182044, 23580, 146254, 38081, 43236, 33883, 146220, 382894, 14606, 46035, 36481, 166621, 35417, 95382, 2957,\n\t59384, 60428, 36358, 66343, 75378, 22267, 22950, 83528, 17577, 56474, 25285, 4619, 179691, 75355, 95836, 53295,\n\t34588, 171410, 4487, 14679, 84208, 44015, 18562, 109133, 54101, 11531, 86052, 174479, 303157, 28095, 9953, 35642,\n\t14564, 39802, 16145, 77606, 117406, 53038, 121117, 53624, 22062, 1212, 7632, 127157, 237292, 189087, 10478, 127345,\n\t102515, 181997, 86752, 87623, 10966, 121602, 68783, 68681, 83042, 114380, 138349, 191305, 67176, 50085, 39016, 1427,\n\t42384, 1412, 67118, 122616, 72389, 25260, 2237, 13576, 137346, 19938, 20304, 2191, 68759, 5373, 61364, 238507,\n\t75814, 23931, 69565, 38993, 131741, 38364, 12528, 87762, 5679, 129853, 5310, 186831, 32653, 90338, 260176, 389531,\n\t108118, 26843, 43985, 50175, 30563, 25106, 56965, 18130, 140428, 4542, 165503, 117991, 24219, 229605, 1819, 129663,\n\t1240, 3797, 76093, 18398, 71339, 51919, 93043, 27175, 47060, 216257, 6483, 35051, 1217, 16512, 80798, 129064,\n\t13225, 69339, 8548, 237079, 72298, 2575, 34280, 51379, 117910, 55671, 53345, 247552, 29486, 39328, 140821, 34681,\n\t57045, 60177, 5004, 90269, 78522, 2479, 322607, 48474, 61296, 13057, 31558, 4678, 59271, 6699, 27044, 31988,\n\t35944, 12503, 83480, 4389, 136508, 3781, 114121, 70279, 4488, 155829, 42214, 2898, 68191, 75695, 305850, 45041,\n\t74344, 106509, 30087, 17429, 93292, 12477, 290, 23080, 114802, 35714, 18751, 26554, 105424, 17775, 2144, 2412,\n\t100610, 65192, 113975, 52975, 180272, 135050, 129815, 76238, 106483, 21440, 63186, 4260, 46189, 9711, 28249, 4169,\n\t23429, 23390, 8324, 141585, 63809, 67668, 38457, 38063, 39226, 59972, 1189, 203916, 62368, 14403, 16949, 61767,\n\t85801, 1739, 40147, 35049, 76757, 33124, 62102, 15780, 103593, 103009, 53484, 22952, 67973, 114645, 6566, 5245,\n\t50462, 7601, 8288, 3513, 194571, 80276, 1908, 54592, 5124, 58571, 2513, 6800, 273997, 193904, 1119, 17991,\n\t117245, 2508, 129156, 82366, 26278, 71465, 63341, 56943, 39662, 106116, 94966, 156875, 9736, 2204, 122308, 94418,\n\t27134, 1280, 24539, 49022, 45314, 3764, 50904, 46424, 30699, 28087, 293839, 9400, 33646, 40165, 822, 147499,\n\t50263, 116179, 29085, 11863, 31314, 5578, 17797, 5104, 12454, 1604, 15342, 219206, 10232, 67800, 94261, 25872,\n\t13565, 90339, 78971, 75377, 26649, 41184, 47695, 11514, 35369, 20767, 14227, 41953, 309396, 148270, 147938, 33074,\n\t14453, 27499, 109019, 39018, 25738, 240196, 158931, 52820, 8612, 95853, 21524, 137010, 84901, 70869, 70021, 116794,\n\t48404, 38771, 6732, 1070, 70990, 187297, 49140, 5238, 576, 3564, 253975, 16027, 16483, 2811, 37775, 19034,\n\t25259, 4053, 2000, 70083, 95774, 19713, 33431, 92703, 91314, 42381, 288770, 48194, 95985, 3991, 77418, 13406,\n\t241328, 245086, 56533, 35275, 62725, 9246, 51924, 70181, 95331, 16163, 31410, 79016, 39312, 120878, 119371, 275987,\n\t80124, 27712, 9186, 220, 23598, 146167, 85209, 68238, 282190, 57048, 31273, 30555, 80913, 17594, 75779, 59160,\n\t135002, 101219, 189377, 29225, 96735, 60126, 62522, 104000, 27620, 86814, 17240, 147533, 11001, 5425, 43682, 410,\n\t49460, 87270, 69480, 46315, 59448, 1816, 76201, 9431, 11788, 87960, 29063, 65539, 47347, 11678, 33846, 7008,\n\t196704, 9895, 6753, 8633, 120892, 59970, 572824, 115934, 6646, 202559, 892, 48351, 37611, 251282, 57823, 67263,\n\t57750, 26527, 34485, 90747, 7685, 88370, 6144, 64182, 1709, 41969, 21458, 62327, 181657, 49247, 225330, 122600,\n\t114574, 107124, 85361, 111833, 63243, 71420, 15655, 191178, 72430, 18063, 51425, 54002, 12364, 53225, 86557, 18193,\n\t97580, 41232, 138398, 67821, 128724, 8944, 233212, 101353, 52099, 42127, 14006, 120107, 32789, 32132, 3498, 18123,\n\t33758, 56058, 5779, 128760, 59888, 98869, 18445, 84702, 51911, 13234, 218379, 20093, 39031, 8074, 70195, 20708,\n\t23462, 24355, 131384, 60189, 26390, 10403, 41060, 7140, 10781, 49410, 42261, 87202, 82566, 41663, 43105, 60276,\n\t2768, 5733, 74176, 28329, 2297, 145430, 131632, 83615, 122915, 105441, 655, 224102, 5284, 136426, 67763, 16294,\n\t188511, 32538, 61049, 27893, 3394, 13951, 159099, 28542, 17930, 145360, 9492, 190122, 32285, 78855, 26440, 13570,\n\t58648, 73908, 4239, 124561, 2444, 74172, 53131, 11468, 10794, 73566, 11623, 35343, 64710, 30481, 4163, 10328,\n\t38309, 29901, 10538, 154377, 76132, 92405, 24839, 11679, 3465, 13449, 11637, 7824, 2337, 57754, 1260, 14458,\n\t41118, 19878, 38661, 13416, 159180, 37074, 163164, 54137, 28627, 52134, 184900, 8520, 40385, 29546, 30502, 22386,\n\t66527, 107458, 6850, 24022, 47983, 30603, 35083, 8934, 304066, 39500, 9, 28261, 33026, 77251, 9374, 44833,\n\t116312, 34990, 29236, 63563, 125639, 135405, 165398, 159055, 55690, 88141, 69643, 236964, 31983, 25572, 20436, 36746,\n\t60896, 31850, 16179, 11828, 5888, 3043, 66368, 9750, 31167, 7915, 53111, 36430, 1333, 64344, 93659, 20061,\n\t60596, 180191, 51630, 6792, 30244, 43509, 101058, 22409, 420, 44210, 109783, 43223, 27030, 72477, 72831, 32679,\n\t29235, 7675, 47556, 12258, 39907, 149412, 84926, 118247, 24692, 71717, 105038, 86009, 45941, 41189, 89453, 29856,\n\t52543, 30627, 226798, 67303, 59230, 67415, 34408, 1367, 99685, 16867, 128419, 52147, 4111, 125381, 117881, 16173,\n\t44093, 102224, 31575, 23234, 24870, 83790, 127407, 239098, 3200, 994, 1255, 100903, 242275, 117266, 55116, 38205,\n\t16140, 29662, 11307, 40414, 208793, 123355, 56470, 4862, 75600, 30119, 58218, 70828, 24075, 26974, 7802, 192353,\n\t4851, 5475, 78720, 66596, 3409, 28573, 64396, 30381, 30690, 59859, 88256, 5406, 99945, 103064, 34463, 37727,\n\t24238, 86643, 60088, 4057, 23741, 5967, 162904, 38240, 28356, 93858, 25510, 122879, 6897, 3278, 7057, 11971,\n\t4400, 35461, 211413, 21395, 59615, 39471, 87233, 55795, 128426, 3051, 22470, 41950, 14705, 3974, 180108, 80476,\n\t78442, 204996, 91987, 15634, 67610, 139015, 142373, 35611, 51134, 10387, 4353, 153456, 57749, 181039, 14183, 68447,\n\t151532, 21107, 36452, 20551, 3186, 46247, 46383, 129666, 88736, 140662, 146243, 2066, 8360, 7978, 64818, 106963,\n\t17896, 47801, 10723, 114821, 223295, 74192, 3293, 3393, 16987, 74064, 11277, 91622, 4270, 29828, 27951, 387869,\n\t103235, 1374, 61988, 120083, 477, 145892, 128378, 11779, 211263, 61354, 18221, 17869, 46530, 83061, 108538, 157981,\n\t90608, 67199, 95080, 49064, 195814, 12302, 66307, 10348, 231346, 160732, 112859, 63633, 146558, 21271, 31037, 198802,\n\t47622, 12862, 95710, 3910, 77850, 73961, 85585, 34752, 61000, 4082, 24595, 103679, 71107, 8208, 79568, 150019,\n\t16615, 24961, 139857, 32664, 197366, 4559, 54735, 32696, 4126, 162019, 75698, 13916, 70108, 159638, 19834, 9349,\n\t24675, 175560, 49643, 18206, 52459, 27992, 10809, 88865, 401975, 133172, 29000, 34558, 30915, 3658, 25834, 42430,\n\t36562, 125265, 18182, 10155, 40149, 97082, 208980, 19575, 60853, 90529, 66545, 9600, 789, 46420, 2317, 88593,\n\t55595, 98980, 115302, 5742, 169155, 1073, 177901, 3472, 11189, 63711, 78643, 65472, 50459, 127979, 93, 42202,\n\t67053, 21720, 157650, 11145, 141378, 42033, 22824, 85705, 79114, 35584, 15974, 1510, 54172, 28562, 12451, 104226,\n\t19190, 97151, 73024, 20948, 5151, 81741, 21499, 29006, 84183, 198074, 54003, 45120, 170125, 26240, 35177, 28389,\n\t64863, 79974, 60778, 176915, 232183, 45342, 2038, 80253, 41564, 40703, 32689, 5430, 100689, 5366, 23007, 134279,\n\t14266, 26712, 73993, 24934, 64242, 52113, 102887, 61801, 46415, 201049, 54251, 62133, 122757, 164883, 30815, 139966,\n\t2319, 30842, 766, 13362, 10287, 134518, 86111, 81665, 82440, 28333, 43019, 18963, 8804, 161944, 23439, 102144,\n\t101145, 80029, 39052, 248708, 30350, 117340, 11878, 128467, 974, 138625, 63961, 5237, 74778, 61834, 67040, 43814,\n\t13690, 65947, 33809, 232476, 115258, 181745, 28824, 94013, 9510, 10246, 93722, 81976, 7217, 114383, 3493, 16014,\n\t69045, 72692, 12145, 80981, 9507, 6692, 1620, 60820, 330444, 35474, 33962, 4797, 7053, 295463, 46445, 27026,\n\t12491, 77988, 49524, 35675, 90947, 29114, 166705, 101385, 133782, 32704, 6186, 84595, 176031, 185623, 45966, 151302,\n\t63069, 1699, 107491, 947, 15458, 74452, 196212, 6046, 10498, 12163, 10239, 35191, 243951, 9277, 9090, 29539,\n\t54460, 22820, 26514, 112549, 60372, 51753, 48756, 21812, 70861, 260326, 41, 44222, 10441, 16961, 48148, 138771,\n\t216194, 5914, 52153, 53400, 212036, 56519, 26245, 10117, 45888, 15294, 138019, 90913, 26368, 43842, 42111, 23348,\n\t6082, 194845, 161089, 156206, 51546, 11647, 30759, 302912, 262094, 8635, 78876, 26535, 35283, 54183, 31183, 85484,\n\t147873, 12989, 5197, 6356, 72894, 65347, 20150, 27370, 73787, 1493, 45918, 12366, 190217, 20724, 13858, 10981,\n\t67449, 81213, 7553, 14115, 72242, 271517, 11842, 48310, 88743, 143726, 22177, 3290, 243231, 58452, 62937, 12592,\n\t1654, 40066, 33477, 13751, 9921, 128442, 15868, 7106, 75236, 83773, 10775, 36938, 10482, 170465, 17368, 17469,\n\t161508, 32752, 98340, 800, 19824, 264456, 3901, 87319, 2867, 26782, 9630, 113102, 185815, 24197, 44584, 86366,\n\t40224, 3636, 140916, 31731, 267731, 9567, 53678, 72984, 29389, 27963, 17106, 50282, 284911, 60170, 8322, 12608,\n\t23374, 89652, 5268, 39044, 229766, 8869, 151350, 31436, 177342, 12269, 183212, 120418, 116270, 2843, 78888, 69192,\n\t7865, 184099, 1086, 129897, 18383, 70508, 20242, 18508, 229924, 124569, 35749, 50589, 55626, 9884, 83115, 40971,\n\t30671, 18135, 14452, 38861, 17844, 201826, 5549, 26413, 17189, 13561, 38539, 10679, 143331, 3314, 36785, 171194,\n\t49685, 187713, 67506, 4618, 104039, 17060, 195080, 50648, 33159, 19238, 67559, 134840, 28599, 157523, 17130, 38064,\n\t117398, 94355, 31918, 13575, 34538, 40326, 13997, 3494, 348283, 62481, 26862, 3603, 104426, 244363, 153709, 112487,\n\t304612, 199674, 41239, 35545, 54869, 293005, 28223, 26277, 26899, 4533, 18518, 15492, 38587, 80488, 70485, 160395,\n\t263, 60162, 11382, 222152, 4696, 250751, 51921, 182609, 10707, 48463, 46243, 1227, 49111, 111564, 46502, 33342,\n\t56846, 68541, 63559, 858, 139927, 16654, 229375, 76759, 26478, 33205, 95828, 23399, 92945, 2637, 35630, 28470,\n\t143992, 50214, 14174, 21456, 166191, 65665, 1711, 21594, 78019, 97599, 111701, 36, 147151, 110246, 189022, 43021,\n\t30397, 40757, 131935, 42065, 73335, 48039, 26596, 28984, 15102, 2361, 7421, 202167, 69744, 43766, 52826, 3642,\n\t83304, 33873, 75140, 63169, 192389, 36551, 92748, 13039, 123959, 233220, 21738, 84447, 77230, 20228, 187852, 19095,\n\t25799, 92136, 108774, 29237, 53947, 2299, 118106, 2687, 8830, 42331, 202924, 33667, 2023, 73763, 30704, 19363,\n\t19779, 16737, 35629, 48081, 24068, 101013, 162338, 291912, 13749, 24745, 328289, 167679, 70086, 48299, 23306, 16732,\n\t17801, 43322, 54589, 3586, 63653, 43624, 53474, 925, 109177, 251316, 43805, 13082, 19511, 86565, 142182, 92461,\n\t17117, 101033, 103319, 64589, 4022, 4351, 235897, 5352, 82705, 107142, 46391, 156084, 5860, 61365, 10558, 13045,\n\t7717, 18357, 33922, 12590, 33065, 6928, 46993, 783, 46937, 67846, 8952, 26295, 6107, 119656, 18799, 17458,\n\t50747, 4229, 179559, 112727, 118080, 20683, 41464, 125468, 51560, 49749, 44231, 7359, 35339, 62988, 136487, 67015,\n\t5208, 29150, 24956, 105186, 48858, 6143, 18097, 6972, 16404, 73489, 58742, 97196, 36357, 164616, 5834, 32267,\n\t13746, 147733, 15113, 132091, 34127, 106298, 39729, 106426, 22294, 9780, 15602, 36213, 71502, 42808, 66802, 599,\n\t60755, 5851, 39120, 67363, 108623, 126368, 72770, 91263, 32486, 30596, 151717, 7951, 52002, 43103, 11768, 68942,\n\t40901, 39344, 24037, 127500, 116890, 48403, 16926, 86750, 17745, 48648, 159545, 34460, 58419, 5634, 114317, 67865,\n\t31462, 23352, 24010, 98185, 125708, 69686, 68337, 13610, 26271, 70691, 2980, 4768, 27225, 102402, 75453, 28106,\n\t8104, 6931, 1176, 6274, 6475, 112635, 22498, 6176, 238686, 26832, 28893, 90319, 14441, 15682, 15087, 39517,\n\t45270, 109134, 104440, 45965, 47645, 81772, 7876, 52683, 87720, 12898, 4505, 185665, 2769, 113401, 15664, 57592,\n\t105229, 137381, 97059, 119268, 6876, 43309, 33886, 128363, 35476, 144249, 67013, 143587, 83367, 25703, 91436, 59347,\n\t53236, 2289, 16519, 19844, 46309, 58558, 99834, 23313, 218816, 231303, 36388, 51333, 183535, 109792, 139277, 54306,\n\t90139, 18235, 8275, 32710, 37677, 82464, 86025, 92204, 88842, 117723, 37570, 128723, 234242, 76350, 73795, 34896,\n\t148247, 58424, 11105, 11744, 45746, 63372, 17118, 49772, 199520, 81902, 38004, 22911, 33752, 3125, 1995, 53792,\n\t4689, 26909, 108150, 146062, 69674, 41811, 161444, 84855, 8999, 28561, 16731, 93937, 3189, 21967, 24890, 22943,\n\t1356, 145300, 51569, 28802, 517, 118679, 31703, 40607, 48098, 108854, 25003, 10233, 73969, 177495, 5248, 24516,\n\t215347, 146192, 48712, 60626, 69188, 40735, 5866, 586, 101541, 6509, 47590, 52129, 5969, 222045, 110933, 25733,\n\t24223, 65339, 62812, 2414, 155418, 35819, 16022, 78423, 43138, 20995, 128255, 240673, 46745, 236093, 72176, 57085,\n\t97841, 61248, 107, 36068, 193177, 105427, 55726, 215229, 20446, 47228, 100420, 87091, 14429, 121708, 23605, 21157,\n\t187721, 21880, 2997, 203976, 99166, 95068, 25877, 7724, 98925, 83401, 4829, 13182, 18229, 13718, 239662, 38653,\n\t116505, 153497, 30589, 89029, 38962, 181302, 43853, 78872, 180301, 4786, 248240, 7401, 106136, 112590, 77745, 19731,\n\t60880, 77789, 125748, 135487, 5975, 48627, 34084, 12419, 215770, 47557, 254582, 10364, 106495, 21856, 67539, 88981,\n\t38805, 21428, 48732, 42316, 12149, 16078, 52808, 25327, 51322, 33850, 51147, 12253, 122354, 46077, 56483, 254553,\n\t115417, 81834, 150991, 94662, 86668, 7381, 12841, 100650, 18218, 15741, 22372, 68294, 50705, 15535, 84660, 61887,\n\t22553, 72299, 31361, 24824, 17743, 46820, 64288, 31582, 77006, 111674, 116384, 30760, 80920, 86149, 77192, 51979,\n\t79691, 60342, 122805, 103800, 240873, 160744, 233114, 78962, 54920, 8608, 3484, 316104, 72548, 24337, 5088, 230040,\n\t21926, 10172, 36838, 26, 86221, 83458, 102176, 12062, 17571, 41929, 41170, 28428, 68239, 41750, 103930, 2634,\n\t18313, 53019, 34825, 97837, 63115, 24606, 73157, 152474, 14715, 91439, 37033, 109806, 140259, 30668, 174760, 380,\n\t135597, 95673, 136073, 65073, 134249, 13829, 17279, 122305, 4420, 46444, 10237, 64848, 203623, 70728, 10349, 182885,\n\t65075, 24519, 25783, 40318, 34139, 22222, 63394, 55266, 102764, 41422, 20126, 65100, 90408, 53640, 35128, 48932,\n\t11192, 38935, 96839, 34782, 39492, 19396, 41332, 6250, 5511, 19492, 51304, 25936, 104466, 54099, 73771, 86115,\n\t5080, 7669, 30891, 111700, 13931, 25276, 72289, 135447, 14820, 258641, 25265, 31005, 281179, 75286, 393, 95359,\n\t14623, 13584, 6680, 101227, 80173, 44933, 76666, 54542, 13244, 39348, 458, 25379, 109451, 134348, 81143, 6959,\n\t65554, 12027, 51311, 8716, 57589, 140731, 28467, 23316, 17272, 30458, 25980, 55229, 77197, 83798, 28302, 114784,\n\t7428, 34548, 26241, 14712, 39336, 103304, 18928, 54080, 12870, 334, 87722, 15208, 16895, 142098, 114262, 39820,\n\t83913, 57817, 28682, 7721, 14900, 108672, 11250, 62246, 42849, 415188, 1724, 26555, 24549, 25505, 26443, 107450,\n\t145899, 61035, 43528, 6901, 60726, 65906, 267741, 21338, 147590, 42079, 18924, 73017, 135236, 15393, 5206, 4026,\n\t84185, 1531, 5988, 113890, 82647, 303391, 7386, 69844, 71611, 189865, 76523, 31877, 13315, 19314, 198575, 32821,\n\t1928, 67641, 25913, 104475, 103489, 3297, 70391, 18406, 15446, 113347, 19295, 93790, 27856, 1792, 167471, 116449,\n\t8541, 4408, 41757, 63233, 25765, 86680, 64501, 27034, 24816, 34975, 6079, 4486, 49693, 36229, 16917, 21581,\n\t62426, 27862, 11612, 54284, 35702, 194034, 355, 24277, 48262, 87411, 70504, 310164, 118018, 12516, 47559, 43502,\n\t57433, 107139, 9290, 66533, 80863, 14634, 34312, 91725, 28606, 21342, 67241, 72355, 43244, 375789, 37402, 174015,\n\t105070, 8342, 44167, 67494, 1890, 16365, 11723, 271002, 1865, 47918, 8350, 45564, 27742, 25110, 125803, 8553,\n\t49504, 81925, 62211, 4534, 15491, 19011, 80373, 206920, 667, 102405, 128623, 245524, 5553, 113309, 192739, 65766,\n\t19567, 22832, 261958, 29679, 21293, 71134, 20962, 105123, 24721, 860, 21752, 33448, 18372, 157167, 94822, 35770,\n\t173224, 232737, 75729, 28937, 46828, 28062, 25453, 5207, 140366, 36665, 30652, 6169, 67920, 150458, 92040, 23186,\n\t184604, 92330, 20891, 176492, 49427, 27828, 38305, 42495, 143982, 49560, 25503, 90043, 29747, 65328, 47830, 12932,\n\t11068, 77721, 9003, 25213, 94205, 140426, 46090, 89945, 138173, 192691, 33329, 112232, 129905, 35709, 27514, 1841,\n\t19957, 31411, 127476, 53572, 17497, 173549, 55063, 175135, 19841, 69314, 5192, 237921, 117660, 150697, 4060, 273045,\n\t50414, 98940, 65348, 153665, 164423, 58804, 156695, 48994, 213928, 86036, 28608, 8355, 39574, 34540, 16927, 135680,\n\t18374, 151587, 10830, 53805, 16878, 16623, 4282, 48030, 8537, 14986, 46102, 13062, 72897, 72, 33050, 108227,\n\t39451, 45935, 651, 113320, 40535, 95176, 57450, 48843, 5003, 19019, 10407, 211163, 3848, 1068, 4988, 32091,\n\t30095, 41692, 15099, 43602, 107434, 50744, 7627, 171349, 16313, 150832, 352665, 207750, 33937, 38256, 51091, 156000,\n\t87889, 90663, 84175, 24908, 114900, 50365, 31494, 83829, 5398, 169342, 47521, 54818, 18935, 8356, 43094, 41212,\n\t174536, 10082, 92550, 6678, 60614, 23355, 69721, 14796, 34149, 128830, 58187, 3179, 208, 40325, 28399, 225029,\n\t401412, 51150, 31580, 207268, 6657, 10993, 69818, 64282, 289845, 23308, 12961, 38447, 6681, 52944, 31855, 2572,\n\t47646, 120728, 179148, 37240, 45196, 218274, 4816, 3695, 21961, 50084, 35209, 18073, 51452, 27004, 6100, 33941,\n\t1377, 84831, 171214, 85, 141510, 9078, 99227, 32610, 6417, 11718, 49868, 65579, 87902, 73018, 49062, 46280,\n\t61742, 21512, 40862, 107733, 15941, 29168, 157765, 144919, 14487, 5767, 158014, 140070, 7241, 573, 71584, 16921,\n\t223566, 40331, 179473, 35081, 47926, 140885, 41508, 52104, 59180, 42310, 32811, 29048, 123517, 102413, 80208, 10104,\n\t14746, 12649, 153641, 126022, 37965, 113017, 4171, 83, 142592, 2809, 6362, 50416, 71323, 116894, 260776, 16204,\n\t1524, 5760, 30351, 12658, 20703, 54403, 36083, 45408, 74772, 4946, 14485, 50759, 111222, 10890, 2195, 167147,\n\t92962, 130534, 16283, 177256, 35016, 15472, 210156, 151187, 73922, 117691, 43250, 52051, 37392, 24811, 24358, 30830,\n\t5775, 818, 21969, 1476, 127322, 151783, 58392, 31021, 106913, 65215, 89407, 90802, 28531, 11690, 20234, 95249,\n\t44602, 37256, 18707, 11928, 5161, 4410, 26571, 51903, 49768, 22008, 25252, 65780, 209499, 68769, 203726, 13249,\n\t137363, 48845, 86823, 6658, 5674, 31881, 1083, 1823, 108676, 34518, 166752, 13791, 14287, 91576, 91429, 8665,\n\t11529, 26401, 16191, 91972, 30964, 5254, 28486, 54697, 79613, 66520, 18447, 22870, 45203, 194466, 22822, 51703,\n\t12278, 76716, 44595, 73455, 33546, 12235, 144843, 36154, 51247, 11116, 33040, 3180, 225753, 60864, 1972, 28469,\n\t12891, 28879, 10338, 144157, 56294, 353058, 38302, 41447, 87532, 110616, 27065, 168438, 6557, 1213, 50804, 144643,\n\t24817, 2390, 136531, 38174, 247513, 16190, 4059, 122791, 131994, 137430, 39506, 57650, 16305, 5188, 54309, 106128,\n\t20628, 88071, 67394, 395446, 250285, 66176, 91254, 1399, 114196, 43915, 60230, 44853, 27206, 106353, 43013, 18733,\n\t345105, 226453, 51202, 16607, 57106, 117175, 35492, 10476, 89598, 127439, 15187, 39624, 13688, 61570, 10615, 31111,\n\t59370, 6238, 175252, 32143, 224492, 41388, 95408, 34384, 148238, 78307, 38959, 9340, 160091, 61443, 15737, 11216,\n\t41244, 170, 38299, 102443, 113097, 26382, 14027, 33707, 3957, 76300, 66160, 19431, 18900, 6952, 1717, 108656,\n\t82206, 188021, 257335, 27295, 43999, 41210, 31777, 46956, 57457, 12657, 11489, 15697, 48060, 204748, 53583, 82422,\n\t284790, 30503, 137341, 8120, 19615, 220311, 15991, 10217, 63424, 9808, 67431, 70976, 98221, 4491, 15177, 28535,\n\t144789, 751, 13230, 2394, 1504, 33977, 132104, 30316, 22230, 931, 97193, 185240, 24826, 22687, 174322, 15307,\n\t22988, 1390, 188745, 180325, 29580, 59068, 74903, 18994, 29195, 79, 15436, 7622, 38462, 11566, 138710, 44828,\n\t45774, 37768, 99236, 68137, 84083, 19282, 22698, 17134, 74807, 126662, 173497, 46248, 16938, 119735, 3212, 28292,\n\t213652, 49013, 9975, 32180, 45660, 86250, 4801, 68788, 95490, 77482, 113751, 11994, 44624, 94452, 46839, 128497,\n\t100316, 5798, 58588, 73184, 202987, 65417, 37790, 88524, 1606, 43156, 97964, 105717, 34947, 11203, 100060, 37742,\n\t130074, 93653, 107799, 94311, 196106, 41347, 8035, 10780, 16390, 27883, 118236, 167395, 1979, 25006, 19375, 31628,\n\t18916, 144723, 78502, 114047, 103107, 86492, 107686, 5844, 20934, 206963, 23556, 22591, 16562, 146333, 20167, 10471,\n\t117434, 33085, 2863, 9740, 36669, 41849, 37271, 22790, 18209, 28979, 8231, 12952, 54408, 21731, 25130, 45208,\n\t55748, 138120, 75826, 414, 29593, 9925, 292865, 25999, 683, 123149, 7036, 92159, 86055, 61827, 103680, 23176,\n\t54918, 58466, 57578, 13305, 5709, 86479, 16697, 31064, 17660, 200919, 10770, 49793, 33423, 32370, 52047, 16488,\n\t62555, 6459, 8426, 83493, 7763, 59725, 82812, 18628, 67760, 79405, 68557, 9612, 7673, 28102, 56517, 69620,\n\t171797, 32458, 29541, 15870, 81109, 32080, 207644, 71495, 21202, 11039, 91036, 61230, 2810, 130800, 32260, 4613,\n\t60590, 37112, 75214, 33979, 126402, 155062, 30642, 63875, 12810, 194463, 82799, 47664, 16725, 36685, 43367, 61099,\n\t449, 172150, 102867, 21691, 301838, 36745, 7130, 18671, 57316, 34852, 38034, 54182, 35578, 65900, 99486, 19771,\n\t3456, 2658, 16914, 99866, 28390, 28109, 8262, 21147, 34353, 20006, 4228, 137085, 1675, 203023, 283196, 198286,\n\t214375, 163329, 290603, 152574, 40471, 83506, 30068, 14730, 23177, 131539, 34759, 27668, 32178, 71896, 104799, 116305,\n\t85430, 119262, 42860, 25160, 8911, 23428, 49437, 105322, 6519, 16203, 6349, 74711, 1230, 38045, 8540, 75165,\n\t44736, 25909, 51026, 317034, 4984, 32281, 91312, 27060, 44431, 17817, 45363, 155937, 239085, 35697, 59784, 91993,\n\t29531, 126740, 213757, 76560, 167776, 285273, 24262, 8237, 65030, 41160, 74437, 48804, 118916, 13159, 37842, 1031,\n\t75349, 1478, 11655, 108777, 23435, 277425, 101734, 67469, 70231, 124711, 43532, 28514, 65526, 54956, 1000, 21882,\n\t17728, 25302, 40952, 52214, 149632, 1999, 2111, 3259, 63362, 89961, 220561, 39777, 26335, 9063, 10572, 12416,\n\t34551, 34623, 38604, 24723, 5947, 15588, 69927, 66252, 119177, 69173, 46629, 28714, 70715, 212408, 20521, 406913,\n\t74380, 11716, 50659, 50862, 37009, 88460, 130101, 7210, 53853, 538, 65120, 151950, 55806, 163748, 52837, 13153,\n\t21100, 16674, 64536, 6091, 138201, 44837, 58547, 3723, 163, 2177, 32288, 85454, 34033, 8497, 14282, 25742,\n\t10535, 10741, 79559, 117493, 243787, 49337, 100718, 79495, 40139, 42956, 7551, 55433, 15421, 31509, 23034, 45081,\n\t547, 61176, 53434, 328001, 8470, 36263, 30145, 4519, 74173, 53935, 11845, 73774, 60211, 78025, 3, 4102,\n\t73782, 109293, 315332, 48412, 26683, 13714, 6865, 20128, 18490, 104141, 325, 39470, 171970, 115860, 15707, 7268,\n\t73301, 74336, 31370, 2368, 111827, 107757, 136231, 142844, 97138, 96638, 84053, 38691, 23801, 1588, 10573, 122098,\n\t77039, 240, 186135, 146101, 11996, 18143, 112963, 46171, 155836, 348769, 47795, 121213, 116266, 132515, 3344, 144804,\n\t31286, 99187, 255838, 129694, 35894, 48779, 55235, 148582, 71967, 65282, 15174, 13920, 47080, 6147, 108242, 157593,\n\t125025, 7136, 1286, 28957, 127956, 28402, 98813, 20805, 7532, 109417, 40610, 5041, 32958, 15142, 18408, 108596,\n\t33543, 50517, 27748, 80114, 233434, 91447, 487, 37094, 100048, 30541, 43477, 10639, 89862, 155868, 37667, 8726,\n\t60684, 237903, 73408, 99589, 12190, 38739, 97348, 3914, 13594, 2680, 149016, 13907, 30171, 28343, 23530, 115225,\n\t61104, 35821, 147679, 14337, 4297, 244282, 24085, 326976, 56428, 7851, 21303, 131620, 71446, 83253, 68692, 111870,\n\t5224, 15813, 38197, 49026, 45057, 13660, 3306, 76345, 40671, 27905, 91072, 996, 68527, 62085, 91351, 122634,\n\t55109, 168209, 2024, 27560, 112707, 17352, 8306, 167115, 169921, 166958, 5031, 46020, 11844, 67284, 19130, 76185,\n\t6920, 32849, 5450, 14610, 22451, 21002, 17392, 31872, 66682, 84796, 13709, 40210, 59898, 12029, 8719, 53564,\n\t21462, 91884, 21647, 88379, 194428, 12754, 37797, 132826, 160016, 22567, 54383, 53186, 77611, 31107, 8339, 4694,\n\t19185, 90355, 23597, 17222, 140675, 28442, 23668, 55977, 9128, 61555, 28774, 155229, 17658, 9390, 24379, 69357,\n\t15752, 127381, 239631, 62460, 93181, 55913, 45133, 140155, 18676, 25249, 33164, 29581, 82837, 67223, 22362, 29975,\n\t7317, 52813, 1943, 29613, 20012, 207130, 49617, 49651, 5636, 15334, 36313, 29226, 28084, 95247, 72072, 19000,\n\t224932, 15811, 114, 32127, 38097, 37508, 88507, 37225, 27359, 91626, 12193, 69279, 20608, 11055, 88156, 92808,\n\t2152, 57259, 55275, 72789, 24475, 104414, 1708, 9882, 3818, 48661, 66897, 1631, 34806, 227930, 85815, 87753,\n\t18321, 250664, 72733, 25107, 206797, 50891, 8082, 196411, 92596, 96764, 152823, 65514, 22819, 387277, 62176, 51225,\n\t40329, 15563, 189, 3659, 73670, 64357, 51793, 275136, 33482, 86653, 74615, 67058, 11318, 125720, 15388, 22388,\n\t8267, 1730, 102663, 170910, 40784, 7144, 85373, 13040, 7088, 94309, 583, 44224, 140424, 77439, 18496, 164026,\n\t36578, 4722, 9151, 5824, 63365, 26510, 35199, 40500, 79277, 32495, 44614, 35233, 9566, 203293, 152144, 7097,\n\t2330, 183480, 98629, 13423, 330887, 44130, 68600, 30939, 97829, 31012, 345465, 56747, 94879, 4939, 160027, 149761,\n\t99423, 46099, 32251, 15332, 8761, 96094, 128555, 5763, 235318, 222223, 55729, 30241, 55420, 201746, 3987, 81382,\n\t8259, 49325, 23287, 7719, 24633, 251100, 92311, 18591, 110533, 64759, 170260, 393860, 7175, 21144, 132887, 3593,\n\t75346, 101277, 91109, 16387, 259187, 11627, 57459, 173829, 44694, 55780, 49797, 89192, 120443, 62622, 3904, 14814,\n\t23887, 1027, 112258, 64955, 99800, 11132, 66353, 36202, 48624, 18158, 88481, 96882, 43059, 11040, 2455, 7077,\n\t21651, 181159, 99126, 100434, 61388, 68186, 19161, 110468, 120052, 8819, 55324, 41494, 7014, 37689, 3618, 87729,\n\t92615, 207943, 9823, 128657, 12587, 15857, 6379, 67628, 51216, 71775, 157617, 63244, 1503, 3864, 218754, 110864,\n\t5769, 21492, 7243, 1192, 87921, 85529, 31512, 18537, 42698, 35350, 73510, 84474, 34301, 8991, 21013, 35034,\n\t566, 38832, 19838, 35586, 37216, 39413, 55006, 12178, 59742, 856, 84563, 6900, 25632, 17437, 49786, 30723,\n\t13847, 70845, 4044, 7843, 23944, 235976, 55530, 48942, 6518, 20939, 73769, 192653, 52936, 95207, 23895, 132542,\n\t142982, 22632, 87452, 48042, 54018, 178468, 10728, 26230, 23559, 363, 81269, 142012, 5718, 346258, 31456, 84333,\n\t246476, 51018, 66692, 101804, 120570, 39962, 30373, 70593, 2864, 60541, 19425, 54209, 104092, 7201, 31545, 48018,\n\t25865, 15442, 46257, 40443, 8328, 6451, 111782, 47527, 97754, 33046, 470, 245116, 31095, 39, 91934, 87208,\n\t73470, 36708, 36521, 12801, 70624, 36272, 8892, 79768, 12427, 55454, 103756, 5908, 52390, 62962, 22720, 141138,\n\t94634, 41689, 128402, 126390, 6628, 106394, 35527, 134394, 82727, 254651, 194502, 148064, 89549, 3202, 28359, 957,\n\t21954, 27906, 49840, 142747, 8307, 24206, 48978, 1186, 71728, 133038, 71474, 91306, 6333, 110959, 74600, 70387,\n\t18983, 62609, 56057, 22970, 1147, 135850, 1321, 28834, 3578, 59715, 102227, 32827, 81415, 99952, 55636, 257598,\n\t390, 22702, 35701, 85872, 402916, 39216, 189795, 14929, 19467, 10112, 144422, 61514, 5279, 63421, 134686, 41436,\n\t8424, 51925, 10598, 132295, 124416, 4604, 194739, 210929, 57866, 31829, 51626, 50007, 9976, 91878, 61906, 56168,\n\t81906, 60918, 61859, 40017, 23059, 16887, 40927, 62064, 12785, 32893, 32913, 21782, 93965, 20169, 44387, 79084,\n\t38463, 11457, 93950, 27127, 157050, 2697, 337088, 5116, 54128, 48255, 33279, 8821, 27352, 25515, 124022, 65710,\n\t28906, 38557, 33390, 1722, 104435, 72215, 38551, 12094, 30978, 25113, 6671, 37355, 175109, 42862, 98024, 65406,\n\t221276, 59624, 118012, 64637, 78760, 86697, 21426, 1639, 40350, 12584, 67193, 84144, 31396, 7863, 143011, 69629,\n\t63112, 9454, 28666, 65798, 46372, 134721, 6314, 51402, 30837, 151922, 2847, 38676, 38008, 92823, 136245, 17540,\n\t5504, 109295, 205242, 37606, 5211, 214892, 1586, 20670, 208711, 137743, 19328, 40652, 16995, 20023, 14657, 154919,\n\t34422, 12996, 13918, 38221, 47690, 16398, 2959, 37680, 89122, 6721, 198469, 91876, 172043, 83898, 101992, 26084,\n\t94570, 3635, 76958, 22853, 76497, 38266, 176590, 168403, 44464, 142840, 79180, 184594, 1984, 41806, 83147, 11985,\n\t6546, 366068, 59732, 24533, 271505, 8736, 39084, 222992, 93429, 28962, 58985, 86665, 8432, 30028, 14548, 32439,\n\t54424, 165029, 55175, 27458, 69046, 121277, 46168, 33732, 20661, 24581, 135574, 123110, 37556, 79260, 72611, 16957,\n\t12939, 46162, 58238, 44907, 72936, 253758, 41324, 32518, 96480, 11949, 124438, 65280, 43256, 34107, 53533, 43531,\n\t37037, 28366, 45970, 32741, 173438, 6121, 194202, 62969, 26355, 30314, 58370, 28455, 1848, 50519, 82830, 90393,\n\t21761, 295490, 10936, 256940, 133568, 44050, 20269, 4089, 27457, 21610, 219460, 36743, 14821, 101388, 52005, 13124,\n\t30979, 140816, 167362, 26054, 18458, 60789, 34917, 40447, 26606, 33422, 9066, 3452, 83614, 5761, 20263, 137238,\n\t25038, 91310, 101, 52322, 74548, 42572, 38084, 214054, 186568, 31802, 17665, 30620, 141936, 37730, 14420, 4265,\n\t187218, 49640, 188208, 51441, 55388, 96452, 66659, 40869, 42039, 60967, 221027, 19234, 178581, 29105, 96050, 9165,\n\t196118, 157335, 3738, 40354, 117436, 2965, 34136, 59659, 15570, 50843, 230035, 31444, 71260, 43886, 18316, 5387,\n\t38500, 168508, 17406, 32174, 8828, 103373, 143806, 90367, 3560, 18719, 122310, 16508, 26719, 2541, 105429, 6645,\n\t37998, 73190, 10591, 235916, 49737, 87112, 233941, 53188, 32193, 79154, 4544, 52905, 126477, 7580, 63501, 57314,\n\t3216, 31337, 6541, 103083, 60846, 49, 9756, 15481, 1355, 43840, 14319, 13743, 27486, 10222, 73114, 230718,\n\t418644, 16706, 6674, 279748, 23058, 45273, 295831, 86306, 2743, 5535, 88773, 21829, 35253, 120938, 31153, 3169,\n\t16839, 42847, 8751, 80974, 33942, 36867, 35514, 16485, 26474, 77775, 56877, 5391, 48346, 3882, 108713, 31403,\n\t27804, 55248, 26235, 43821, 136104, 40118, 175507, 28034, 203908, 18732, 1788, 34030, 106427, 36958, 54359, 7251,\n\t44936, 15356, 69139, 455, 157915, 22173, 140291, 50348, 43275, 82066, 49621, 54952, 15216, 36226, 96695, 66855,\n\t6936, 1987, 8227, 196087, 4631, 68827, 99004, 47541, 110265, 17953, 147605, 110242, 58520, 31312, 38724, 329975,\n\t642, 3155, 34497, 75937, 6207, 73843, 6120, 17249, 51429, 117746, 3218, 910, 68961, 319671, 14938, 29555,\n\t34700, 1649, 66673, 72268, 9655, 76800, 153087, 6941, 210168, 27130, 35398, 1780, 73242, 3135, 56689, 19556,\n\t165307, 8765, 35967, 121458, 13333, 70453, 17350, 117253, 22265, 13340, 44265, 39869, 441, 3742, 135025, 23581,\n\t33309, 16543, 17731, 13291, 157637, 283005, 21408, 101360, 63887, 52312, 83873, 5338, 233779, 23759, 186949, 34531,\n\t177320, 38069, 156465, 91004, 19353, 59852, 68160, 14891, 1338, 1072, 29823, 1950, 28901, 81407, 313445, 73038,\n\t84807, 162348, 240257, 37162, 138934, 16111, 58013, 41253, 102951, 16457, 96056, 19541, 56402, 67217, 41638, 94381,\n\t89674, 29481, 37456, 80815, 151579, 13937, 13683, 132537, 19699, 134545, 67020, 29816, 222341, 141235, 427578, 48868,\n\t129557, 233342, 23077, 87871, 16213, 18728, 16184, 9469, 37913, 19680, 2798, 171356, 178328, 13216, 50049, 72690,\n\t71904, 124644, 55455, 7504, 29052, 41036, 266546, 19899, 30391, 188755, 8659, 59469, 16, 104298, 112943, 53865,\n\t76203, 138226, 68857, 139953, 14125, 107625, 119795, 173133, 4398, 50273, 48808, 54390, 16466, 122086, 31835, 67035,\n\t50971, 48859, 7508, 46427, 66477, 73021, 84615, 39985, 83076, 46779, 201569, 53336, 36443, 60865, 168164, 143810,\n\t51393, 25548, 169307, 32896, 24485, 38424, 21837, 29087, 275813, 51674, 6714, 64883, 46169, 187369, 55186, 76192,\n\t12852, 12018, 62134, 31067, 118303, 16542, 12125, 10579, 4928, 26291, 43854, 7091, 10946, 253716, 109062, 39283,\n\t17261, 113012, 258512, 47764, 125126, 32646, 55892, 80279, 201623, 149872, 3192, 385, 1208, 48750, 5376, 58738,\n\t22335, 5427, 82416, 47811, 32435, 143086, 38930, 94128, 59975, 156037, 37977, 38224, 62485, 7698, 50405, 71027,\n\t16462, 21559, 136153, 34131, 107506, 162069, 63703, 3101, 215029, 40407, 4178, 3774, 9187, 80019, 17880, 97926,\n\t67579, 2600, 18405, 8351, 47924, 86638, 70820, 92206, 86453, 29610, 42241, 119200, 3198, 15466, 67813, 57863,\n\t35454, 4779, 99518, 4649, 104641, 144269, 33730, 38073, 65864, 6838, 109456, 193298, 154007, 5623, 45741, 30846,\n\t182578, 25573, 157224, 1543, 58575, 138703, 146140, 44971, 49356, 18275, 59064, 20300, 13122, 11848, 24453, 11973,\n\t9797, 86843, 2919, 25530, 49210, 1130, 161220, 76788, 75373, 85604, 34926, 36014, 17777, 17255, 51533, 11676,\n\t92226, 51845, 119859, 21525, 5936, 18507, 28050, 1140, 31418, 14857, 34207, 47859, 10750, 36382, 32079, 106909,\n\t59426, 87757, 38393, 110042, 15965, 97104, 33757, 35344, 97993, 53979, 33651, 45407, 41884, 82515, 173089, 7177,\n\t58371, 35365, 47543, 51927, 35587, 10670, 23544, 29306, 84233, 39976, 76076, 62097, 9007, 8668, 28119, 78281,\n\t120790, 19835, 143020, 54968, 18670, 64959, 20649, 34469, 42570, 33001, 136570, 87796, 120044, 1106, 58700, 63951,\n\t127623, 12805, 83057, 40212, 31773, 49850, 7361, 54336, 347524, 101314, 23751, 19569, 48791, 29174, 49369, 20467,\n\t7465, 75842, 38281, 623, 112457, 60210, 28849, 51003, 94720, 6426, 90047, 85560, 43761, 3579, 85105, 34607,\n\t90410, 118528, 7224, 42907, 111163, 18168, 6960, 161135, 191298, 5247, 100584, 127552, 171568, 20121, 91173, 12636,\n\t54615, 20199, 63730, 98105, 2396, 40387, 14438, 125012, 4765, 33235, 12865, 45299, 37728, 82098, 77872, 114037,\n\t59253, 19675, 24838, 398016, 102561, 11446, 17069, 57508, 178277, 65836, 99941, 26114, 2585, 271882, 136866, 50126,\n\t11027, 155648, 118367, 14585, 8910, 123015, 335383, 40434, 41016, 53021, 14439, 87098, 176860, 201543, 121888, 2358,\n\t9286, 5739, 22666, 54270, 37884, 169381, 33984, 93859, 16124, 89364, 72207, 51639, 76366, 99029, 65812, 2198,\n\t12147, 174891, 194289, 6986, 30252, 88822, 21284, 11445, 288337, 160821, 33034, 100869, 43852, 25761, 52882, 1144,\n\t103809, 1924, 84458, 86079, 43411, 13542, 139276, 18141, 34978, 41298, 7276, 26481, 173800, 33210, 17951, 142652,\n\t33616, 33677, 2210, 19941, 98568, 2486, 192414, 80136, 12058, 235883, 50963, 249638, 29572, 27221, 47034, 6124,\n\t72107, 63346, 97620, 158513, 299699, 40388, 23235, 37176, 224244, 198386, 121323, 67992, 23827, 63170, 17838, 106622,\n\t158590, 26807, 5345, 23489, 91891, 55474, 74834, 37981, 13058, 5977, 72552, 34706, 26828, 145172, 19904, 21367,\n\t34043, 960, 77092, 91381, 4733, 47446, 7680, 41697, 5170, 16960, 14741, 46101, 13656, 473, 51842, 37433,\n\t11103, 11551, 121951, 13191, 97536, 165932, 50397, 51628, 129028, 9069, 44885, 6590, 59195, 47045, 32940, 225472,\n\t90345, 21833, 13303, 29407, 96615, 141951, 5198, 6028, 18395, 7181, 3861, 14966, 156358, 167182, 36529, 55253,\n\t25942, 173153, 30959, 27261, 50691, 150176, 162201, 38467, 48462, 80602, 42163, 118482, 168, 108756, 26011, 17166,\n\t54149, 456538, 22512, 91374, 13816, 90358, 131615, 18132, 226707, 1824, 28139, 26860, 42253, 93877, 77351, 65575,\n\t8980, 80574, 22020, 27948, 40422, 91324, 76376, 13528, 39281, 91685, 82215, 122541, 144066, 1983, 193851, 17283,\n\t26320, 2739, 194978, 4790, 26845, 42627, 61300, 65815, 174612, 55133, 4200, 191130, 79771, 158321, 52280, 166796,\n\t221620, 62461, 11278, 4067, 88152, 83409, 31717, 121367, 13522, 47325, 37945, 10406, 174348, 249321, 154101, 64912,\n\t29938, 51775, 17220, 15776, 166138, 78890, 84425, 54121, 42861, 16368, 24572, 291647, 10197, 32073, 22651, 11677,\n\t97509, 26952, 35787, 18424, 41910, 71614, 94977, 72318, 41594, 70024, 275419, 37702, 60199, 7335, 39107, 61315,\n\t18271, 18394, 33768, 87884, 104277, 123724, 7277, 56288, 71981, 189803, 49320, 3352, 6798, 14240, 8954, 69220,\n\t94433, 57372, 28620, 68863, 193727, 85575, 42309, 41667, 67689, 42081, 22543, 44824, 12719, 28540, 114236, 101553,\n\t27638, 27296, 4300, 5353, 4663, 19379, 94098, 3758, 95888, 95144, 80344, 87320, 28447, 259518, 12718, 71391,\n\t152731, 37063, 24132, 31911, 104896, 15672, 103782, 1521, 4945, 72541, 23717, 122632, 15619, 87175, 206120, 29428,\n\t189780, 61416, 28350, 44457, 972, 1175, 47233, 198738, 95789, 41907, 21953, 97034, 59341, 22864, 53713, 16873,\n\t32971, 20693, 20954, 31336, 21477, 16169, 38370, 16412, 9019, 3841, 24599, 21938, 17085, 6484, 81198, 76413,\n\t5849, 72514, 12320, 65247, 276175, 37234, 59796, 52642, 16312, 57349, 198507, 94148, 46134, 18958, 125552, 1747,\n\t18725, 151873, 14901, 5490, 68287, 29470, 3689, 64794, 40814, 26018, 25692, 54450, 2703, 88278, 124886, 173087,\n\t174000, 24159, 179477, 24276, 46004, 201876, 209202, 445, 52876, 31948, 30206, 157610, 39180, 18439, 44124, 50469,\n\t5774, 96278, 222758, 200216, 50290, 45486, 20435, 46986, 46276, 140133, 142326, 15569, 13363, 47522, 92583, 2182,\n\t7135, 16853, 22998, 30272, 4952, 63263, 35623, 39096, 53789, 44864, 20053, 110392, 124213, 4630, 16087, 28221,\n\t127787, 25839, 77481, 44693, 13464, 113146, 6983, 27069, 55717, 50102, 4760, 7107, 26186, 66507, 59145, 36032,\n\t104182, 71328, 29425, 64317, 50781, 47465, 94298, 69706, 74899, 22754, 120756, 25108, 93077, 56834, 73286, 39928,\n\t16218, 41699, 176763, 7555, 70819, 50083, 26895, 23315, 26014, 16773, 123079, 41712, 5719, 31516, 90427, 158540,\n\t85051, 183128, 40864, 27505, 55392, 9058, 45224, 96857, 30901, 136622, 96557, 56304, 120061, 11501, 151448, 5773,\n\t89743, 7769, 86069, 2935, 18471, 41628, 10114, 33660, 110170, 49479, 26745, 92846, 33221, 26731, 18795, 87076,\n\t8550, 2100, 29972, 120289, 3077, 72490, 33784, 2630, 208722, 50861, 63483, 79029, 6419, 39467, 14302, 45286,\n\t64207, 9686, 67513, 44170, 1050, 77246, 59266, 17055, 53801, 7150, 11111, 42432, 4278, 94579, 362117, 36175,\n\t42902, 41933, 39002, 98489, 22913, 74161, 84773, 57036, 17556, 162288, 74485, 178760, 93867, 73635, 128860, 50362,\n\t261, 67455, 80001, 46080, 35662, 4368, 25247, 19230, 74393, 22588, 1822, 27682, 235324, 13798, 85998, 13194,\n\t235067, 23514, 71669, 147632, 23191, 134748, 214683, 105101, 1518, 25489, 247114, 7380, 54842, 26922, 3971, 26361,\n\t20844, 68642, 170517, 77339, 123255, 8963, 77818, 150998, 48466, 36806, 2732, 23261, 11741, 236162, 18243, 126216,\n\t28690, 50546, 16385, 92760, 197383, 246558, 201295, 88255, 67588, 71687, 176076, 172653, 169058, 33906, 63747, 24835,\n\t157621, 43338, 30050, 46152, 132741, 2770, 51371, 94835, 6614, 15112, 11749, 56936, 1250, 19027, 399017, 58036,\n\t100215, 23388, 55815, 308768, 124152, 94803, 9521, 64186, 8971, 28, 30427, 62163, 7616, 103838, 35079, 29203,\n\t131235, 7743, 17389, 10882, 37420, 61460, 228512, 85363, 41581, 131077, 62822, 119647, 10130, 54445, 26925, 19968,\n\t29016, 24446, 74028, 24176, 61448, 67185, 9254, 8563, 119129, 9771, 99184, 37716, 39514, 10532, 221512, 258753,\n\t218630, 55980, 23394, 32141, 61924, 66749, 32411, 3741, 36475, 26678, 77010, 44946, 91203, 128749, 116953, 20476,\n\t49625, 53116, 13735, 102335, 29376, 51946, 83407, 67892, 59212, 34685, 21083, 1546, 112982, 32972, 74397, 1078,\n\t190545, 16082, 86140, 58591, 89611, 101531, 10061, 105104, 76319, 20035, 17551, 52611, 169061, 190842, 100780, 23907,\n\t90413, 115619, 9675, 34710, 193435, 49443, 129734, 11183, 258877, 16318, 136182, 126808, 44635, 27304, 192375, 2599,\n\t125648, 47051, 12091, 23814, 721, 58800, 40137, 66726, 97930, 60877, 74487, 7942, 54326, 9841, 41428, 13762,\n\t8211, 85383, 6950, 99177, 79806, 201786, 296464, 124087, 13144, 29741, 41721, 47634, 55088, 254286, 106408, 17041,\n\t99064, 12942, 64086, 45233, 14005, 2612, 55827, 255, 7984, 13980, 38574, 12776, 46654, 73499, 249951, 2101,\n\t26676, 25996, 132326, 116415, 119062, 50449, 31033, 23038, 11589, 179252, 20007, 14860, 129270, 21143, 17796, 144715,\n\t60106, 70758, 69842, 34674, 282133, 44014, 16774, 57268, 38528, 24053, 46373, 201667, 28327, 471023, 51889, 102667,\n\t21193, 114909, 84132, 69317, 96723, 67969, 16134, 68145, 15058, 28765, 32035, 2524, 101089, 98664, 25045, 76571,\n\t14957, 86040, 118506, 262428, 154764, 81573, 39681, 283900, 73287, 127825, 544, 80448, 52347, 38512, 175971, 15180,\n\t45467, 33086, 46552, 48894, 81107, 43213, 36672, 54025, 76703, 8053, 7608, 13299, 56619, 20752, 238099, 54164,\n\t105133, 1444, 32942, 953, 37564, 8000, 66316, 119463, 106817, 404, 13667, 149108, 128597, 31267, 10269, 49836,\n\t106150, 1484, 52330, 76965, 160486, 171648, 38456, 31263, 22424, 37738, 66245, 67467, 143369, 60471, 75610, 20895,\n\t115528, 86070, 60854, 40796, 49347, 18989, 15030, 11371, 37578, 15779, 79867, 10187, 86462, 46402, 155626, 93200,\n\t40229, 7090, 57547, 108053, 99598, 11088, 47505, 41218, 206017, 2173, 20988, 30219, 22919, 80563, 57566, 42369,\n\t93141, 41675, 2407, 182519, 120495, 27154, 16702, 29456, 14349, 7958, 16688, 117177, 140375, 42467, 261919, 74916,\n\t153569, 10836, 34742, 49526, 7621, 105997, 12212, 2270, 392377, 7755, 17959, 25086, 232152, 138791, 33847, 13860,\n\t35316, 5811, 1344, 71259, 50452, 207539, 92635, 50359, 5821, 33674, 30255, 2086, 2587, 96264, 17543, 42,\n\t6029, 9580, 43007, 139248, 82831, 12917, 29607, 25786, 51467, 42137, 85161, 100698, 31561, 88989, 121990, 278500,\n\t3602, 109344, 37982, 15279, 116442, 28936, 30880, 87894, 58079, 128661, 126731, 67392, 28051, 146885, 4861, 16216,\n\t97344, 42827, 147561, 153948, 22684, 21335, 47685, 1853, 43349, 15185, 59642, 10229, 25520, 187921, 108972, 5579,\n\t98037, 24945, 6697, 19193, 63734, 137934, 75056, 89740, 19767, 224268, 56138, 63643, 151661, 39313, 70618, 84031,\n\t89723, 84074, 13703, 85626, 35460, 8867, 64845, 3439, 57906, 99776, 63968, 49270, 81130, 34356, 16210, 23547,\n\t36446, 34090, 140028, 72439, 2221, 22163, 57058, 363492, 113754, 18913, 95451, 48663, 54464, 54037, 176097, 68425,\n\t3023, 34906, 29482, 117389, 341780, 80431, 58330, 16753, 92616, 60907, 94846, 147486, 4498, 48646, 7773, 46801,\n\t7778, 18946, 464978, 47558, 33223, 177444, 7328, 15626, 63337, 94700, 11743, 9351, 255024, 39098, 16447, 42647,\n\t96230, 39769, 58840, 10068, 63439, 35800, 65843, 58823, 413844, 9156, 51258, 7434, 61791, 85018, 6872, 3692,\n\t28096, 7121, 33024, 6009, 75532, 31997, 192535, 9661, 3304, 9547, 14753, 31987, 25314, 55689, 15896, 20430,\n\t39472, 31340, 99744, 25398, 115569, 54883, 28719, 205423, 23071, 57855, 64638, 149867, 25671, 82403, 37616, 20668,\n\t39989, 77996, 74948, 140555, 175248, 64810, 36515, 46595, 4958, 248773, 24045, 28728, 136673, 168704, 20804, 114833,\n\t100325, 27135, 21205, 96151, 153134, 45992, 7093, 13992, 76047, 1980, 19432, 145001, 75159, 87462, 17710, 1013,\n\t45556, 34297, 144882, 20648, 26061, 11319, 129567, 108555, 18872, 464580, 33386, 22717, 65948, 167189, 5603, 135042,\n\t79542, 8801, 202632, 18114, 91882, 5973, 5239, 67315, 4431, 60916, 47819, 71693, 32597, 32606, 18183, 45072,\n\t80329, 76385, 24749, 51305, 40314, 156514, 14693, 130345, 13168, 66214, 18029, 12858, 34801, 27628, 14544, 10823,\n\t40522, 40185, 33739, 148694, 23548, 9923, 61012, 28859, 17933, 19442, 34364, 99849, 164107, 141167, 30629, 21054,\n\t6744, 36491, 8096, 42474, 41706, 155060, 30650, 10600, 163442, 1143, 96655, 61390, 52359, 7559, 51568, 64256,\n\t203854, 4467, 22453, 14504, 436398, 7878, 6980, 8293, 63610, 293747, 16167, 35763, 19627, 147603, 15419, 18032,\n\t110744, 51346, 33681, 54571, 40472, 48615, 39073, 21604, 13754, 173027, 92560, 11083, 47299, 63062, 11813, 52007,\n\t29883, 9734, 139722, 15953, 1550, 20651, 13616, 49306, 16113, 90089, 92326, 7584, 30712, 72424, 164858, 6831,\n\t152871, 55746, 197721, 34167, 196442, 6022, 112107, 55215, 7538, 123381, 4920, 43539, 77165, 8939, 50392, 34192,\n\t20225, 79762, 22505, 58667, 40770, 29788, 97180, 82835, 4568, 8579, 13273, 363569, 35898, 49983, 436, 36598,\n\t3237, 131691, 62418, 35591, 8101, 4073, 379438, 65218, 76072, 33887, 2968, 27573, 212619, 288680, 68278, 72851,\n\t150504, 217896, 6913, 121339, 22017, 35340, 51072, 43616, 75043, 31437, 10833, 81487, 4364, 22968, 41454, 106687,\n\t85446, 19863, 109625, 149241, 524, 141850, 214404, 54376, 657, 237023, 9401, 108137, 53800, 32474, 49712, 53334,\n\t126876, 27337, 45552, 177696, 8269, 15036, 12097, 42240, 2328, 125374, 119295, 99715, 2500, 19624, 39441, 27220,\n\t102691, 60957, 94543, 39101, 18566, 67362, 13975, 78230, 25017, 34017, 239007, 90027, 39351, 41681, 35354, 43822,\n\t1043, 916, 58587, 141983, 94818, 38799, 75459, 41114, 67432, 16195, 36606, 59568, 22272, 126769, 31424, 68659,\n\t12287, 134302, 257977, 5756, 207285, 95637, 47248, 117689, 19583, 77451, 22373, 12200, 54993, 117118, 34244, 29386,\n\t34562, 53819, 71267, 64172, 77665, 49368, 7716, 59301, 25749, 45426, 194789, 17297, 2650, 1766, 32501, 45198,\n\t20403, 20984, 6600, 14171, 94604, 19037, 5402, 29896, 9938, 59935, 109708, 88081, 145182, 44844, 39167, 352626,\n\t164173, 35374, 45982, 6122, 154, 73419, 220487, 53834, 53601, 17992, 8609, 229321, 5610, 68098, 66815, 71012,\n\t95069, 140968, 27396, 8957, 134489, 24656, 86659, 56598, 134852, 17316, 123838, 255436, 6613, 41610, 138033, 81452,\n\t32023, 32396, 123687, 63398, 8693, 29712, 30407, 19296, 121188, 3551, 36099, 20032, 111948, 56624, 16547, 27453,\n\t35916, 15378, 52039, 56849, 13489, 22214, 73177, 53097, 277349, 2157, 14029, 187886, 10260, 141743, 246460, 91880,\n\t50869, 3788, 49486, 133566, 54950, 33120, 129337, 53768, 18333, 9525, 26902, 312251, 10297, 9020, 70759, 16647,\n\t112432, 59260, 84609, 9818, 82766, 73569, 468, 46001, 75780, 55028, 52106, 11498, 43645, 108069, 17150, 17753,\n\t29417, 16705, 31799, 9606, 289, 122254, 115975, 8620, 6133, 255357, 56908, 14456, 133464, 43554, 79224, 11247,\n\t29630, 160, 12756, 25464, 65960, 350428, 62521, 321796, 100359, 67358, 35169, 46172, 113128, 48988, 88868, 31094,\n\t33266, 6847, 60887, 98188, 49659, 69117, 92977, 220228, 13947, 80181, 35103, 62170, 97351, 13475, 2440, 199768,\n\t19498, 36597, 46971, 25234, 67806, 62881, 84717, 73648, 181966, 10488, 94149, 21550, 26655, 63436, 48375, 14405,\n\t165650, 9621, 24439, 28043, 42735, 4490, 29963, 56674, 45373, 1934, 262446, 50855, 67098, 26898, 5261, 52696,\n\t40644, 33900, 9440, 180286, 87162, 22940, 19704, 26936, 69769, 10254, 101759, 27406, 12243, 48000, 73926, 113215,\n\t54935, 5726, 192787, 4312, 106216, 9366, 11550, 52949, 23457, 212271, 277152, 133895, 108374, 6191, 96477, 29980,\n\t218916, 58024, 54696, 40853, 91124, 65894, 91170, 65908, 252552, 6793, 29212, 15389, 44516, 122515, 52617, 35058,\n\t9017, 103536, 39510, 49136, 19242, 130652, 662077, 74699, 47024, 31422, 8517, 73351, 24399, 13867, 128360, 4810,\n\t4434, 61779, 111983, 61036, 17798, 110240, 59722, 102960, 39688, 10001, 23803, 23039, 176498, 56659, 44814, 134295,\n\t17188, 77577, 74466, 226175, 102472, 154333, 63900, 111747, 18062, 41171, 79669, 32773, 408933, 42562, 28931, 30907,\n\t107388, 43487, 2946, 240310, 23938, 24354, 319, 184983, 7927, 6488, 1422, 10790, 68809, 68209, 64775, 4361,\n\t202, 17123, 59634, 51200, 44391, 18188, 17843, 2619, 74278, 3230, 9540, 47187, 21702, 36274, 56894, 43907,\n\t16310, 34790, 16866, 6150, 5561, 13587, 107545, 108873, 126867, 86986, 28640, 33427, 19017, 5762, 80637, 17430,\n\t46903, 2047, 131055, 25958, 13558, 5444, 47152, 13900, 44563, 122857, 45348, 70863, 39593, 54332, 38068, 33637,\n\t318, 40310, 143467, 18502, 24520, 11377, 62013, 28942, 27246, 28269, 83545, 17999, 59015, 90707, 30065, 15161,\n\t34720, 1263, 37008, 2012, 6060, 98575, 92933, 5721, 299, 199555, 24578, 29223, 2985, 743, 115825, 109523,\n\t136657, 47454, 26378, 53586, 3733, 174945, 93340, 244456, 5693, 37386, 28782, 89767, 27545, 23573, 18798, 136425,\n\t34320, 84778, 20041, 48453, 38215, 7477, 71958, 40621, 8773, 5874, 187927, 105965, 51100, 43533, 18083, 8443,\n\t10180, 43597, 2003, 183999, 69689, 12216, 129696, 146188, 62389, 34044, 68410, 12765, 43273, 26949, 266807, 3345,\n\t34477, 79197, 5688, 47539, 213110, 21634, 22257, 50092, 32222, 42346, 39530, 63668, 98, 134978, 74022, 5152,\n\t59088, 174145, 37220, 9934, 9545, 118937, 5724, 87240, 19875, 15784, 40143, 23263, 87513, 181654, 285152, 37881,\n\t263241, 4966, 43934, 10433, 186657, 6470, 74416, 225854, 25908, 142677, 246262, 32280, 6192, 75890, 45546, 143264,\n\t135305, 29742, 47013, 77787, 11732, 126658, 8763, 37950, 21806, 57557, 113464, 89465, 108995, 164574, 23894, 22996,\n\t23169, 15369, 23117, 17642, 130607, 40503, 36239, 280990, 44666, 9981, 40427, 147487, 26869, 168452, 32886, 32991,\n\t46798, 240839, 15111, 70502, 65697, 88548, 44145, 28701, 48767, 31139, 206777, 35659, 181164, 166262, 14554, 171445,\n\t31786, 66523, 76607, 17956, 6507, 31279, 90476, 116611, 167918, 6560, 1243, 115324, 80128, 41867, 55897, 187323,\n\t37069, 32596, 189444, 145931, 13390, 105530, 65709, 26805, 6999, 55714, 41300, 22915, 68951, 22138, 21120, 22264,\n\t10058, 19945, 33635, 56123, 99085, 10032, 5818, 6016, 46649, 57476, 35264, 94413, 112522, 262288, 93686, 83038,\n\t14341, 23204, 28807, 66084, 77987, 6101, 126673, 7133, 38126, 5923, 122091, 170240, 97772, 46874, 215746, 43948,\n\t41622, 3272, 55596, 8332, 146411, 251315, 13533, 8561, 81521, 115449, 48616, 175175, 2063, 186556, 3036, 134537,\n\t75772, 29728, 82360, 22973, 186559, 86348, 89100, 38388, 82297, 45610, 2613, 87082, 9986, 177812, 57884, 23591,\n\t47485, 42543, 33582, 44713, 74439, 257444, 252451, 31825, 35631, 38540, 33066, 5147, 13973, 4343, 51830, 70378,\n\t22827, 26448, 95560, 36896, 241741, 48067, 203953, 298860, 61620, 20450, 3220, 67272, 6586, 107662, 100160, 108684,\n\t6929, 57226, 4762, 7457, 1320, 40404, 77204, 99309, 62750, 208653, 59977, 44000, 74315, 34332, 5819, 172217,\n\t64904, 114077, 18147, 84012, 1791, 98456, 90930, 21446, 116669, 103938, 7422, 85140, 59713, 5768, 326211, 16239,\n\t75411, 13229, 29398, 10758, 236107, 1539, 112472, 95979, 152154, 151294, 306, 21196, 38146, 10700, 6891, 84282,\n\t109646, 56492, 40539, 6589, 119491, 51354, 30685, 140209, 136906, 29622, 73617, 49553, 70525, 51671, 166869, 139616,\n\t74395, 37439, 49595, 45678, 11959, 33211, 86560, 52434, 9282, 62690, 112155, 130810, 5243, 108261, 99970, 265613,\n\t72551, 80049, 6391, 33365, 90721, 66737, 69872, 87011, 1860, 9032, 112544, 60905, 37371, 89015, 140351, 19076,\n\t850, 373531, 2802, 36725, 218795, 72062, 28990, 16550, 24614, 7815, 6187, 26336, 33373, 32162, 42791, 73555,\n\t32062, 23386, 10244, 56392, 49442, 27076, 136262, 12412, 14883, 1134, 33675, 97153, 199281, 15608, 100152, 74072,\n\t47942, 254301, 36451, 16026, 10687, 65067, 56708, 254030, 30290, 50490, 13864, 57941, 259331, 35588, 23485, 43486,\n\t24869, 21620, 92971, 22072, 88645, 1048, 182050, 13343, 32452, 14825, 19509, 3325, 216938, 45740, 99716, 189082,\n\t53740, 78245, 25609, 24311, 176777, 47340, 308354, 40669, 66085, 14102, 125339, 9225, 128709, 97207, 1271, 200933,\n\t78439, 113451, 88975, 18324, 46521, 11819, 18570, 141756, 72512, 170020, 52754, 63550, 118515, 103073, 93330, 32736,\n\t50499, 14722, 31600, 68452, 398867, 29316, 172786, 18417, 104924, 2606, 5670, 84818, 16288, 67106, 59580, 82929,\n\t607401, 291, 85829, 359, 15897, 35830, 50696, 65630, 52672, 22115, 356968, 29895, 40837, 231192, 34024, 38957,\n\t26722, 406, 23335, 124952, 72068, 68804, 13268, 147101, 164740, 276569, 162596, 66943, 11569, 26654, 66358, 4777,\n\t23229, 102127, 5848, 978, 2921, 59666, 5371, 28212, 90108, 42938, 39320, 2499, 4271, 108792, 33510, 125072,\n\t71653, 65239, 38250, 66357, 38577, 13964, 86251, 35708, 50755, 36010, 29448, 12209, 3844, 38222, 206337, 100876,\n\t67827, 137088, 14167, 252225, 84163, 195270, 1306, 5703, 54198, 779, 46802, 22028, 51124, 86759, 70560, 113164,\n\t35685, 162145, 45471, 34561, 422, 2611, 6464, 47486, 19223, 38246, 9191, 18331, 89942, 243642, 212364, 15893,\n\t17518, 22617, 6409, 30046, 126182, 59716, 36560, 104428, 18846, 26592, 19458, 50793, 147333, 30826, 1388, 27647,\n\t10922, 14495, 33545, 19269, 135828, 39727, 41601, 46931, 233379, 49169, 131130, 182112, 16276, 82381, 118209, 142445,\n\t128310, 19672, 28740, 82907, 33436, 3118, 102206, 28723, 24819, 41937, 38854, 5157, 3881, 111491, 1142, 9776,\n\t421673, 152241, 29309, 14961, 87854, 6054, 15424, 3796, 82656, 54996, 2108, 55367, 239450, 154525, 9643, 118103,\n\t106041, 64601, 68549, 48707, 30266, 25772, 18740, 9462, 229669, 91798, 112152, 191327, 14493, 72828, 8175, 66636,\n\t236474, 25817, 87351, 129027, 76653, 20422, 22983, 71240, 27846, 44661, 12399, 46158, 77704, 53101, 35032, 11072,\n\t17300, 109294, 33638, 24408, 1895, 11241, 760, 17584, 82479, 125877, 63150, 141075, 34259, 23274, 81698, 15732,\n\t43577, 48340, 91584, 14688, 16379, 24481, 150280, 96420, 262050, 48635, 43727, 61819, 56268, 72003, 88178, 17281,\n\t79912, 13218, 122519, 125295, 166396, 11811, 2171, 118930, 67746, 17636, 178278, 174656, 95661, 173039, 83845, 79689,\n\t17473, 98555, 127696, 203415, 54730, 22925, 232239, 9309, 12136, 175026, 20740, 180188, 10747, 39816, 314017, 266131,\n\t10040, 175732, 112550, 220651, 31974, 37393, 888, 23008, 86799, 4303, 64905, 148467, 75337, 251, 3284, 370102,\n\t50264, 9835, 5438, 23655, 4481, 29851, 329, 12855, 7162, 64931, 78141, 12804, 42372, 296771, 83547, 18624,\n\t34874, 86271, 3360, 48665, 77735, 88767, 11463, 63527, 28889, 22258, 29140, 194315, 113924, 25499, 6406, 31334,\n\t1845, 4802, 49184, 43455, 35469, 127594, 92970, 61038, 115005, 38840, 87761, 106838, 8811, 20572, 55637, 11162,\n\t96721, 132425, 108925, 2948, 125457, 36356, 3502, 75270, 27622, 127192, 2561, 123095, 49394, 61155, 16897, 110064,\n\t9699, 89448, 53356, 19628, 220310, 21622, 83036, 9885, 112214, 6087, 26713, 17901, 161912, 91492, 3440, 68594,\n\t9266, 92238, 8087, 6866, 150194, 72175, 80701, 13459, 31836, 43243, 239700, 95846, 44749, 50647, 21945, 230538,\n\t120612, 132371, 244604, 5193, 105637, 34661, 41341, 68775, 85393, 1874, 8771, 33718, 49672, 77403, 595452, 99507,\n\t6490, 58895, 128742, 7704, 39239, 73217, 43816, 62824, 37804, 199976, 22361, 80005, 87514, 94832, 14089, 4574,\n\t139975, 59142, 75523, 100268, 43906, 53442, 15152, 2547, 186002, 17011, 19513, 204282, 3343, 60568, 128318, 119250,\n\t4298, 51871, 41336, 71759, 21921, 45074, 98169, 145889, 99427, 11350, 1237, 5520, 28799, 7803, 53702, 21026,\n\t136352, 38293, 128690, 12158, 90132, 44600, 10184, 26957, 39459, 126025, 78904, 82999, 59373, 39301, 150198, 120529,\n\t153042, 20177, 50089, 14764, 271571, 30530, 123161, 38975, 101562, 22941, 5648, 124654, 109243, 69817, 71675, 49162,\n\t106884, 21241, 107795, 30258, 16572, 188262, 141456, 7688, 60718, 8271, 11044, 32440, 104608, 103419, 236109, 93156,\n\t43293, 128929, 42107, 67180, 25201, 115254, 185488, 130954, 72813, 167547, 20537, 39969, 38432, 22582, 184022, 1139,\n\t27199, 5655, 17767, 97412, 122606, 209377, 27070, 35871, 326617, 188954, 42680, 73512, 80911, 22629, 3011, 95021,\n\t315242, 157737, 383, 41821, 41808, 19335, 27950, 15674, 25677, 110950, 35375, 76835, 59108, 57370, 35262, 16569,\n\t160415, 37706, 78086, 32041, 49691, 137143, 9782, 172080, 50148, 77917, 6323, 10110, 69172, 17711, 21795, 59511,\n\t76184, 135114, 31046, 132319, 59105, 157578, 20549, 80778, 57649, 158421, 65143, 4575, 72235, 21899, 10797, 92745,\n\t34035, 106079, 80159, 4508, 78304, 25350, 75457, 46458, 32937, 25623, 47, 8531, 104751, 84953, 8138, 36508,\n\t187199, 66310, 115274, 13253, 32461, 38536, 1916, 42007, 187160, 35055, 26325, 84394, 35963, 94216, 45590, 97782\n]\n","'use strict'\n\nconst debug = require('debug')\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst { base58btc } = require('multiformats/bases/base58')\nconst { Key } = require('interface-datastore/key')\nconst { xor: uint8ArrayXor } = require('uint8arrays/xor')\nconst { compare: uint8ArrayCompare } = require('uint8arrays/compare')\nconst pMap = require('p-map')\nconst { Record } = require('libp2p-record')\nconst PeerId = require('peer-id')\nconst errcode = require('err-code')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst pTimeout = require('p-timeout')\n\n/**\n * Creates a DHT ID by hashing a given Uint8Array.\n *\n * @param {Uint8Array} buf\n * @returns {Promise}\n */\nexports.convertBuffer = async (buf) => {\n return (await sha256.digest(buf)).digest\n}\n\n/**\n * Creates a DHT ID by hashing a Peer ID\n *\n * @param {PeerId} peer\n * @returns {Promise}\n */\nexports.convertPeerId = async (peer) => {\n return (await sha256.digest(peer.id)).digest\n}\n\n/**\n * Convert a Uint8Array to their SHA2-256 hash.\n *\n * @param {Uint8Array} buf\n * @returns {Key}\n */\nexports.bufferToKey = (buf) => {\n return new Key('/' + exports.encodeBase32(buf), false)\n}\n\n/**\n * Generate the key for a public key.\n *\n * @param {PeerId} peer\n * @returns {Uint8Array}\n */\nexports.keyForPublicKey = (peer) => {\n return uint8ArrayConcat([\n uint8ArrayFromString('/pk/'),\n peer.id\n ])\n}\n\n/**\n * @param {Uint8Array} key\n */\nexports.isPublicKeyKey = (key) => {\n return uint8ArrayToString(key.slice(0, 4)) === '/pk/'\n}\n\n/**\n * @param {Uint8Array} key\n */\nexports.fromPublicKeyKey = (key) => {\n return new PeerId(key.slice(4))\n}\n\n/**\n * Get the current time as timestamp.\n *\n * @returns {number}\n */\nexports.now = () => {\n return Date.now()\n}\n\n/**\n * Encode a given Uint8Array into a base32 string.\n *\n * @param {Uint8Array} buf\n * @returns {string}\n */\nexports.encodeBase32 = (buf) => {\n return uint8ArrayToString(buf, 'base32')\n}\n\n/**\n * Decode a given base32 string into a Uint8Array.\n *\n * @param {string} raw\n * @returns {Uint8Array}\n */\nexports.decodeBase32 = (raw) => {\n return uint8ArrayFromString(raw, 'base32')\n}\n\n/**\n * Sort peers by distance to the given `target`.\n *\n * @param {Array} peers\n * @param {Uint8Array} target\n */\nexports.sortClosestPeers = async (peers, target) => {\n const distances = await pMap(peers, async (peer) => {\n const id = await exports.convertPeerId(peer)\n\n return {\n peer: peer,\n distance: uint8ArrayXor(id, target)\n }\n })\n\n return distances.sort(exports.xorCompare).map((d) => d.peer)\n}\n\n/**\n * Compare function to sort an array of elements which have a distance property which is the xor distance to a given element.\n *\n * @param {{ distance: Uint8Array }} a\n * @param {{ distance: Uint8Array }} b\n */\nexports.xorCompare = (a, b) => {\n return uint8ArrayCompare(a.distance, b.distance)\n}\n\n/**\n * Computes how many results to collect on each disjoint path, rounding up.\n * This ensures that we look for at least one result per path.\n *\n * @param {number} resultsWanted\n * @param {number} numPaths - total number of paths\n */\nexports.pathSize = (resultsWanted, numPaths) => {\n return Math.ceil(resultsWanted / numPaths)\n}\n\n/**\n * Create a new put record, encodes and signs it if enabled.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n * @returns {Uint8Array}\n */\nexports.createPutRecord = (key, value) => {\n const timeReceived = new Date()\n const rec = new Record(key, value, timeReceived)\n\n return rec.serialize()\n}\n\n/**\n * Creates a logger for the given subsystem\n *\n * @param {PeerId} [id]\n * @param {string} [subsystem]\n */\nexports.logger = (id, subsystem) => {\n const name = ['libp2p', 'dht']\n if (subsystem) {\n name.push(subsystem)\n }\n if (id) {\n name.push(`${id.toB58String().slice(0, 8)}`)\n }\n\n // Add a formatter for converting to a base58 string\n debug.formatters.b = (v) => {\n return base58btc.baseEncode(v)\n }\n\n const logger = Object.assign(debug(name.join(':')), {\n error: debug(name.concat(['error']).join(':'))\n })\n\n return logger\n}\n\nexports.TimeoutError = class TimeoutError extends Error {\n get code () {\n return 'ETIMEDOUT'\n }\n}\n\n/**\n * Creates an async function that calls the given `asyncFn` and Errors\n * if it does not resolve within `time` ms\n *\n * @template T\n * @param {(...args: any[]) => Promise} asyncFn\n * @param {number} [time]\n */\nexports.withTimeout = (asyncFn, time) => {\n /**\n * @param {...any} args\n * @returns {Promise}\n */\n async function timeoutFn (...args) {\n if (!time) {\n return asyncFn(...args)\n }\n\n let res\n\n try {\n res = await pTimeout(asyncFn(...args), time)\n } catch (err) {\n if (err instanceof pTimeout.TimeoutError) {\n throw errcode(err, 'ETIMEDOUT')\n }\n\n throw err\n }\n\n return res\n }\n\n return timeoutFn\n}\n\n/**\n * Iterates the given `asyncIterator` and runs each item through the given `asyncFn` in parallel.\n * Returns a promise that resolves when all items of the `asyncIterator` have been passed\n * through `asyncFn`.\n *\n * @template T\n * @template O\n *\n * @param {AsyncIterable} asyncIterator\n * @param {(arg0: T) => Promise} asyncFn\n */\nexports.mapParallel = async function (asyncIterator, asyncFn) {\n const tasks = []\n for await (const item of asyncIterator) {\n tasks.push(asyncFn(item))\n }\n return Promise.all(tasks)\n}\n","'use strict';\nconst AggregateError = require('aggregate-error');\n\nmodule.exports = async (\n\titerable,\n\tmapper,\n\t{\n\t\tconcurrency = Infinity,\n\t\tstopOnError = true\n\t} = {}\n) => {\n\treturn new Promise((resolve, reject) => {\n\t\tif (typeof mapper !== 'function') {\n\t\t\tthrow new TypeError('Mapper function is required');\n\t\t}\n\n\t\tif (!((Number.isSafeInteger(concurrency) || concurrency === Infinity) && concurrency >= 1)) {\n\t\t\tthrow new TypeError(`Expected \\`concurrency\\` to be an integer from 1 and up or \\`Infinity\\`, got \\`${concurrency}\\` (${typeof concurrency})`);\n\t\t}\n\n\t\tconst result = [];\n\t\tconst errors = [];\n\t\tconst iterator = iterable[Symbol.iterator]();\n\t\tlet isRejected = false;\n\t\tlet isIterableDone = false;\n\t\tlet resolvingCount = 0;\n\t\tlet currentIndex = 0;\n\n\t\tconst next = () => {\n\t\t\tif (isRejected) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst nextItem = iterator.next();\n\t\t\tconst index = currentIndex;\n\t\t\tcurrentIndex++;\n\n\t\t\tif (nextItem.done) {\n\t\t\t\tisIterableDone = true;\n\n\t\t\t\tif (resolvingCount === 0) {\n\t\t\t\t\tif (!stopOnError && errors.length !== 0) {\n\t\t\t\t\t\treject(new AggregateError(errors));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresolve(result);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tresolvingCount++;\n\n\t\t\t(async () => {\n\t\t\t\ttry {\n\t\t\t\t\tconst element = await nextItem.value;\n\t\t\t\t\tresult[index] = await mapper(element, index);\n\t\t\t\t\tresolvingCount--;\n\t\t\t\t\tnext();\n\t\t\t\t} catch (error) {\n\t\t\t\t\tif (stopOnError) {\n\t\t\t\t\t\tisRejected = true;\n\t\t\t\t\t\treject(error);\n\t\t\t\t\t} else {\n\t\t\t\t\t\terrors.push(error);\n\t\t\t\t\t\tresolvingCount--;\n\t\t\t\t\t\tnext();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t})();\n\t\t};\n\n\t\tfor (let i = 0; i < concurrency; i++) {\n\t\t\tnext();\n\n\t\t\tif (isIterableDone) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t});\n};\n","'use strict';\nconst indentString = require('indent-string');\nconst cleanStack = require('clean-stack');\n\nconst cleanInternalStack = stack => stack.replace(/\\s+at .*aggregate-error\\/index.js:\\d+:\\d+\\)?/g, '');\n\nclass AggregateError extends Error {\n\tconstructor(errors) {\n\t\tif (!Array.isArray(errors)) {\n\t\t\tthrow new TypeError(`Expected input to be an Array, got ${typeof errors}`);\n\t\t}\n\n\t\terrors = [...errors].map(error => {\n\t\t\tif (error instanceof Error) {\n\t\t\t\treturn error;\n\t\t\t}\n\n\t\t\tif (error !== null && typeof error === 'object') {\n\t\t\t\t// Handle plain error objects with message property and/or possibly other metadata\n\t\t\t\treturn Object.assign(new Error(error.message), error);\n\t\t\t}\n\n\t\t\treturn new Error(error);\n\t\t});\n\n\t\tlet message = errors\n\t\t\t.map(error => {\n\t\t\t\t// The `stack` property is not standardized, so we can't assume it exists\n\t\t\t\treturn typeof error.stack === 'string' ? cleanInternalStack(cleanStack(error.stack)) : String(error);\n\t\t\t})\n\t\t\t.join('\\n');\n\t\tmessage = '\\n' + indentString(message, 4);\n\t\tsuper(message);\n\n\t\tthis.name = 'AggregateError';\n\n\t\tObject.defineProperty(this, '_errors', {value: errors});\n\t}\n\n\t* [Symbol.iterator]() {\n\t\tfor (const error of this._errors) {\n\t\t\tyield error;\n\t\t}\n\t}\n}\n\nmodule.exports = AggregateError;\n","'use strict';\n\nmodule.exports = (string, count = 1, options) => {\n\toptions = {\n\t\tindent: ' ',\n\t\tincludeEmptyLines: false,\n\t\t...options\n\t};\n\n\tif (typeof string !== 'string') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`input\\` to be a \\`string\\`, got \\`${typeof string}\\``\n\t\t);\n\t}\n\n\tif (typeof count !== 'number') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`count\\` to be a \\`number\\`, got \\`${typeof count}\\``\n\t\t);\n\t}\n\n\tif (typeof options.indent !== 'string') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`options.indent\\` to be a \\`string\\`, got \\`${typeof options.indent}\\``\n\t\t);\n\t}\n\n\tif (count === 0) {\n\t\treturn string;\n\t}\n\n\tconst regex = options.includeEmptyLines ? /^/gm : /^(?!\\s*$)/gm;\n\n\treturn string.replace(regex, options.indent.repeat(count));\n};\n","'use strict';\nconst os = require('os');\n\nconst extractPathRegex = /\\s+at.*(?:\\(|\\s)(.*)\\)?/;\nconst pathRegex = /^(?:(?:(?:node|(?:internal\\/[\\w/]*|.*node_modules\\/(?:babel-polyfill|pirates)\\/.*)?\\w+)\\.js:\\d+:\\d+)|native)/;\nconst homeDir = typeof os.homedir === 'undefined' ? '' : os.homedir();\n\nmodule.exports = (stack, options) => {\n\toptions = Object.assign({pretty: false}, options);\n\n\treturn stack.replace(/\\\\/g, '/')\n\t\t.split('\\n')\n\t\t.filter(line => {\n\t\t\tconst pathMatches = line.match(extractPathRegex);\n\t\t\tif (pathMatches === null || !pathMatches[1]) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\tconst match = pathMatches[1];\n\n\t\t\t// Electron\n\t\t\tif (\n\t\t\t\tmatch.includes('.app/Contents/Resources/electron.asar') ||\n\t\t\t\tmatch.includes('.app/Contents/Resources/default_app.asar')\n\t\t\t) {\n\t\t\t\treturn false;\n\t\t\t}\n\n\t\t\treturn !pathRegex.test(match);\n\t\t})\n\t\t.filter(line => line.trim() !== '')\n\t\t.map(line => {\n\t\t\tif (options.pretty) {\n\t\t\t\treturn line.replace(extractPathRegex, (m, p1) => m.replace(p1, p1.replace(homeDir, '~')));\n\t\t\t}\n\n\t\t\treturn line;\n\t\t})\n\t\t.join('\\n');\n};\n","'use strict'\n\n// MaxRecordAge specifies the maximum time that any node will hold onto a record\n// from the time its received. This does not apply to any other forms of validity that\n// the record may contain.\n// For example, a record may contain an ipns entry with an EOL saying its valid\n// until the year 2020 (a great time in the future). For that record to stick around\n// it must be rebroadcasted more frequently than once every 'MaxRecordAge'\n\nconst second = exports.second = 1000\nconst minute = exports.minute = 60 * second\nconst hour = exports.hour = 60 * minute\n\nexports.MAX_RECORD_AGE = 36 * hour\n\nexports.PROTOCOL_DHT = '/kad/1.0.0'\n\nexports.PROVIDERS_KEY_PREFIX = '/providers/'\n\nexports.PROVIDERS_LRU_CACHE_SIZE = 256\n\nexports.PROVIDERS_VALIDITY = 24 * hour\n\nexports.PROVIDERS_CLEANUP_INTERVAL = hour\n\nexports.READ_MESSAGE_TIMEOUT = 10 * second\n\n// The number of records that will be retrieved on a call to getMany()\nexports.GET_MANY_RECORD_COUNT = 16\n\n// K is the maximum number of requests to perform before returning failure\nexports.K = 20\n\n// Alpha is the concurrency for asynchronous requests\nexports.ALPHA = 3\n","'use strict'\n\nconst errcode = require('err-code')\n\nconst { pipe } = require('it-pipe')\nconst lp = require('it-length-prefixed')\nconst pTimeout = require('p-timeout')\nconst { consume } = require('streaming-iterables')\nconst first = require('it-first')\n\nconst MulticodecTopology = require('libp2p-interfaces/src/topology/multicodec-topology')\n\nconst rpc = require('./rpc')\nconst c = require('./constants')\nconst Message = require('./message')\nconst utils = require('./utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\n/**\n * Handle network operations for the dht\n */\nclass Network {\n /**\n * Create a new network\n *\n * @param {import('./index')} dht\n */\n constructor (dht) {\n this.dht = dht\n this.readMessageTimeout = c.READ_MESSAGE_TIMEOUT\n this._log = utils.logger(this.dht.peerId, 'net')\n this._rpc = rpc(this.dht)\n this._onPeerConnected = this._onPeerConnected.bind(this)\n this._running = false\n }\n\n /**\n * Start the network\n */\n start () {\n if (this._running) {\n return\n }\n\n if (!this.dht.isStarted) {\n throw errcode(new Error('Can not start network'), 'ERR_CANNOT_START_NETWORK')\n }\n\n this._running = true\n\n // Only respond to queries when not in client mode\n if (this.dht._clientMode === false) {\n // Incoming streams\n this.dht.registrar.handle(this.dht.protocol, this._rpc)\n }\n\n // register protocol with topology\n const topology = new MulticodecTopology({\n multicodecs: [this.dht.protocol],\n handlers: {\n onConnect: this._onPeerConnected,\n onDisconnect: () => {}\n }\n })\n this._registrarId = this.dht.registrar.register(topology)\n }\n\n /**\n * Stop all network activity\n */\n stop () {\n if (!this.dht.isStarted && !this.isStarted) {\n return\n }\n this._running = false\n\n // unregister protocol and handlers\n if (this._registrarId) {\n this.dht.registrar.unregister(this._registrarId)\n }\n }\n\n /**\n * Is the network online?\n *\n * @type {boolean}\n */\n get isStarted () {\n return this._running\n }\n\n /**\n * Are all network components there?\n *\n * @type {boolean}\n */\n get isConnected () {\n // TODO add a way to check if switch has started or not\n return this.dht.isStarted && this.isStarted\n }\n\n /**\n * Registrar notifies a connection successfully with dht protocol.\n *\n * @param {PeerId} peerId - remote peer id\n */\n async _onPeerConnected (peerId) {\n await this.dht._add(peerId)\n this._log('added to the routing table: %s', peerId.toB58String())\n }\n\n /**\n * Send a request and record RTT for latency measurements.\n *\n * @async\n * @param {PeerId} to - The peer that should receive a message\n * @param {Message} msg - The message to send.\n */\n async sendRequest (to, msg) {\n // TODO: record latency\n if (!this.isConnected) {\n throw errcode(new Error('Network is offline'), 'ERR_NETWORK_OFFLINE')\n }\n\n const id = to.toB58String()\n this._log('sending to: %s', id)\n\n let conn = this.dht.registrar.connectionManager.get(to)\n if (!conn) {\n conn = await this.dht.dialer.connectToPeer(to)\n }\n\n const { stream } = await conn.newStream(this.dht.protocol)\n\n return this._writeReadMessage(stream, msg.serialize())\n }\n\n /**\n * Sends a message without expecting an answer.\n *\n * @param {PeerId} to\n * @param {Message} msg\n */\n async sendMessage (to, msg) {\n if (!this.isConnected) {\n throw errcode(new Error('Network is offline'), 'ERR_NETWORK_OFFLINE')\n }\n\n const id = to.toB58String()\n this._log('sending to: %s', id)\n\n let conn = this.dht.registrar.connectionManager.get(to)\n if (!conn) {\n conn = await this.dht.dialer.connectToPeer(to)\n }\n const { stream } = await conn.newStream(this.dht.protocol)\n\n return this._writeMessage(stream, msg.serialize())\n }\n\n /**\n * Write a message and read its response.\n * If no response is received after the specified timeout\n * this will error out.\n *\n * @param {MuxedStream} stream - the stream to use\n * @param {Uint8Array} msg - the message to send\n */\n async _writeReadMessage (stream, msg) { // eslint-disable-line require-await\n return pTimeout(\n writeReadMessage(stream, msg),\n this.readMessageTimeout\n )\n }\n\n /**\n * Write a message to the given stream.\n *\n * @param {MuxedStream} stream - the stream to use\n * @param {Uint8Array} msg - the message to send\n */\n _writeMessage (stream, msg) {\n return pipe(\n [msg],\n lp.encode(),\n stream,\n consume\n )\n }\n}\n\n/**\n * @param {MuxedStream} stream\n * @param {Uint8Array} msg\n */\nasync function writeReadMessage (stream, msg) {\n const res = await pipe(\n [msg],\n lp.encode(),\n stream,\n lp.decode(),\n /**\n * @param {AsyncIterable} source\n */\n async source => {\n const buf = await first(source)\n\n if (buf) {\n return buf.slice()\n }\n }\n )\n\n if (res.length === 0) {\n throw errcode(new Error('No message received'), 'ERR_NO_MESSAGE_RECEIVED')\n }\n\n return Message.deserialize(res)\n}\n\nmodule.exports = Network\n","async function* _batch(size, iterable) {\n let dataBatch = [];\n for await (const data of iterable) {\n dataBatch.push(data);\n if (dataBatch.length === size) {\n yield dataBatch;\n dataBatch = [];\n }\n }\n if (dataBatch.length > 0) {\n yield dataBatch;\n }\n}\nfunction* _syncBatch(size, iterable) {\n let dataBatch = [];\n for (const data of iterable) {\n dataBatch.push(data);\n if (dataBatch.length === size) {\n yield dataBatch;\n dataBatch = [];\n }\n }\n if (dataBatch.length > 0) {\n yield dataBatch;\n }\n}\nfunction batch(size, iterable) {\n if (iterable === undefined) {\n return curriedIterable => batch(size, curriedIterable);\n }\n if (iterable[Symbol.asyncIterator]) {\n return _batch(size, iterable);\n }\n return _syncBatch(size, iterable);\n}\n\nfunction getIterator(iterable) {\n if (typeof iterable.next === 'function') {\n return iterable;\n }\n if (typeof iterable[Symbol.iterator] === 'function') {\n return iterable[Symbol.iterator]();\n }\n if (typeof iterable[Symbol.asyncIterator] === 'function') {\n return iterable[Symbol.asyncIterator]();\n }\n throw new TypeError('\"values\" does not to conform to any of the iterator or iterable protocols');\n}\n\nfunction defer() {\n let reject;\n let resolve;\n const promise = new Promise((resolveFunc, rejectFunc) => {\n resolve = resolveFunc;\n reject = rejectFunc;\n });\n return {\n promise,\n reject,\n resolve,\n };\n}\n\n/// \nfunction _buffer(size, iterable) {\n const iterator = getIterator(iterable);\n const resultQueue = [];\n const readQueue = [];\n let reading = false;\n let ended = false;\n function fulfillReadQueue() {\n while (readQueue.length > 0 && resultQueue.length > 0) {\n const readDeferred = readQueue.shift();\n const { error, value } = resultQueue.shift();\n if (error) {\n readDeferred.reject(error);\n }\n else {\n readDeferred.resolve({ done: false, value });\n }\n }\n while (readQueue.length > 0 && ended) {\n const { resolve } = readQueue.shift();\n resolve({ done: true, value: undefined });\n }\n }\n async function fillQueue() {\n if (ended) {\n return;\n }\n if (reading) {\n return;\n }\n if (resultQueue.length >= size) {\n return;\n }\n reading = true;\n try {\n const { done, value } = await iterator.next();\n if (done) {\n ended = true;\n }\n else {\n resultQueue.push({ value });\n }\n }\n catch (error) {\n ended = true;\n resultQueue.push({ error });\n }\n fulfillReadQueue();\n reading = false;\n fillQueue();\n }\n async function next() {\n if (resultQueue.length > 0) {\n const { error, value } = resultQueue.shift();\n if (error) {\n throw error;\n }\n fillQueue();\n return { done: false, value };\n }\n if (ended) {\n return { done: true, value: undefined }; // stupid ts\n }\n const deferred = defer();\n readQueue.push(deferred);\n fillQueue();\n return deferred.promise;\n }\n const asyncIterableIterator = {\n next,\n [Symbol.asyncIterator]: () => asyncIterableIterator,\n };\n return asyncIterableIterator;\n}\nfunction* syncBuffer(size, iterable) {\n const valueQueue = [];\n let e;\n try {\n for (const value of iterable) {\n valueQueue.push(value);\n if (valueQueue.length <= size) {\n continue;\n }\n yield valueQueue.shift();\n }\n }\n catch (error) {\n e = error;\n }\n for (const value of valueQueue) {\n yield value;\n }\n if (e) {\n throw e;\n }\n}\nfunction buffer(size, iterable) {\n if (iterable === undefined) {\n return curriedIterable => buffer(size, curriedIterable);\n }\n if (size === 0) {\n return iterable;\n }\n if (iterable[Symbol.asyncIterator]) {\n return _buffer(size, iterable);\n }\n return syncBuffer(size, iterable);\n}\n\nasync function _collect(iterable) {\n const values = [];\n for await (const value of iterable) {\n values.push(value);\n }\n return values;\n}\nfunction collect(iterable) {\n if (iterable[Symbol.asyncIterator]) {\n return _collect(iterable);\n }\n return Array.from(iterable);\n}\n\nasync function* _concat(iterables) {\n for await (const iterable of iterables) {\n yield* iterable;\n }\n}\nfunction* _syncConcat(iterables) {\n for (const iterable of iterables) {\n yield* iterable;\n }\n}\nfunction concat(...iterables) {\n const hasAnyAsync = iterables.find(itr => itr[Symbol.asyncIterator] !== undefined);\n if (hasAnyAsync) {\n return _concat(iterables);\n }\n else {\n return _syncConcat(iterables);\n }\n}\n\nasync function _consume(iterable) {\n for await (const val of iterable) {\n // do nothing\n }\n}\nfunction consume(iterable) {\n if (iterable[Symbol.asyncIterator]) {\n return _consume(iterable);\n }\n for (const val of iterable) {\n // do nothing\n }\n}\n\nasync function* _filter(filterFunc, iterable) {\n for await (const data of iterable) {\n if (await filterFunc(data)) {\n yield data;\n }\n }\n}\nfunction filter(filterFunc, iterable) {\n if (iterable === undefined) {\n return (curriedIterable) => _filter(filterFunc, curriedIterable);\n }\n return _filter(filterFunc, iterable);\n}\n\nasync function* flatten(iterable) {\n for await (const maybeItr of iterable) {\n if (maybeItr && typeof maybeItr !== 'string' && (maybeItr[Symbol.iterator] || maybeItr[Symbol.asyncIterator])) {\n yield* flatten(maybeItr);\n }\n else {\n yield maybeItr;\n }\n }\n}\n\nasync function* _map(func, iterable) {\n for await (const val of iterable) {\n yield await func(val);\n }\n}\nfunction map(func, iterable) {\n if (iterable === undefined) {\n return curriedIterable => _map(func, curriedIterable);\n }\n return _map(func, iterable);\n}\n\nfunction flatMap(func, iterable) {\n if (iterable === undefined) {\n return curriedIterable => flatMap(func, curriedIterable);\n }\n return filter(i => i !== undefined && i !== null, flatten(map(func, iterable)));\n}\n\nfunction _flatTransform(concurrency, func, iterable) {\n const iterator = getIterator(iterable);\n const resultQueue = [];\n const readQueue = [];\n let ended = false;\n let reading = false;\n let inflightCount = 0;\n let lastError = null;\n function fulfillReadQueue() {\n while (readQueue.length > 0 && resultQueue.length > 0) {\n const { resolve } = readQueue.shift();\n const value = resultQueue.shift();\n resolve({ done: false, value });\n }\n while (readQueue.length > 0 && inflightCount === 0 && ended) {\n const { resolve, reject } = readQueue.shift();\n if (lastError) {\n reject(lastError);\n lastError = null;\n }\n else {\n resolve({ done: true, value: undefined });\n }\n }\n }\n async function fillQueue() {\n if (ended) {\n fulfillReadQueue();\n return;\n }\n if (reading) {\n return;\n }\n if (inflightCount + resultQueue.length >= concurrency) {\n return;\n }\n reading = true;\n inflightCount++;\n try {\n const { done, value } = await iterator.next();\n if (done) {\n ended = true;\n inflightCount--;\n fulfillReadQueue();\n }\n else {\n mapAndQueue(value);\n }\n }\n catch (error) {\n ended = true;\n inflightCount--;\n lastError = error;\n fulfillReadQueue();\n }\n reading = false;\n fillQueue();\n }\n async function mapAndQueue(itrValue) {\n try {\n const value = await func(itrValue);\n if (value && value[Symbol.asyncIterator]) {\n for await (const asyncVal of value) {\n resultQueue.push(asyncVal);\n }\n }\n else {\n resultQueue.push(value);\n }\n }\n catch (error) {\n ended = true;\n lastError = error;\n }\n inflightCount--;\n fulfillReadQueue();\n fillQueue();\n }\n async function next() {\n if (resultQueue.length === 0) {\n const deferred = defer();\n readQueue.push(deferred);\n fillQueue();\n return deferred.promise;\n }\n const value = resultQueue.shift();\n fillQueue();\n return { done: false, value };\n }\n const asyncIterableIterator = {\n next,\n [Symbol.asyncIterator]: () => asyncIterableIterator,\n };\n return asyncIterableIterator;\n}\nfunction flatTransform(concurrency, func, iterable) {\n if (func === undefined) {\n return (curriedFunc, curriedIterable) => curriedIterable\n ? flatTransform(concurrency, curriedFunc, curriedIterable)\n : flatTransform(concurrency, curriedFunc);\n }\n if (iterable === undefined) {\n return (curriedIterable) => flatTransform(concurrency, func, curriedIterable);\n }\n return filter(i => i !== undefined && i !== null, flatten(_flatTransform(concurrency, func, iterable)));\n}\n\nasync function onceReadable(stream) {\n return new Promise(resolve => {\n stream.once('readable', () => {\n resolve();\n });\n });\n}\nasync function* _fromStream(stream) {\n while (true) {\n const data = stream.read();\n if (data !== null) {\n yield data;\n continue;\n }\n if (stream._readableState.ended) {\n break;\n }\n await onceReadable(stream);\n }\n}\nfunction fromStream(stream) {\n if (typeof stream[Symbol.asyncIterator] === 'function') {\n return stream;\n }\n return _fromStream(stream);\n}\n\nasync function* merge(...iterables) {\n const sources = new Set(iterables.map(getIterator));\n while (sources.size > 0) {\n for (const iterator of sources) {\n const nextVal = await iterator.next();\n if (nextVal.done) {\n sources.delete(iterator);\n }\n else {\n yield nextVal.value;\n }\n }\n }\n}\n\nfunction pipeline(firstFn, ...fns) {\n let previousFn = firstFn();\n for (const func of fns) {\n previousFn = func(previousFn);\n }\n return previousFn;\n}\n\nasync function* _parallelMap(concurrency, func, iterable) {\n let transformError = null;\n const wrapFunc = value => ({\n value: func(value),\n });\n const stopOnError = async function* (source) {\n for await (const value of source) {\n if (transformError) {\n return;\n }\n yield value;\n }\n };\n const output = pipeline(() => iterable, buffer(1), stopOnError, map(wrapFunc), buffer(concurrency - 1));\n const itr = getIterator(output);\n while (true) {\n const { value, done } = await itr.next();\n if (done) {\n break;\n }\n try {\n const val = await value.value;\n if (!transformError) {\n yield val;\n }\n }\n catch (error) {\n transformError = error;\n }\n }\n if (transformError) {\n throw transformError;\n }\n}\nfunction parallelMap(concurrency, func, iterable) {\n if (func === undefined) {\n return (curriedFunc, curriedIterable) => parallelMap(concurrency, curriedFunc, curriedIterable);\n }\n if (iterable === undefined) {\n return curriedIterable => parallelMap(concurrency, func, curriedIterable);\n }\n if (concurrency === 1) {\n return map(func, iterable);\n }\n return _parallelMap(concurrency, func, iterable);\n}\n\nfunction parallelFlatMap(concurrency, func, iterable) {\n if (func === undefined) {\n return (curriedFunc, curriedIterable) => curriedIterable\n ? parallelFlatMap(concurrency, curriedFunc, curriedIterable)\n : parallelFlatMap(concurrency, curriedFunc);\n }\n if (iterable === undefined) {\n return (curriedIterable) => parallelFlatMap(concurrency, func, curriedIterable);\n }\n return filter(i => i !== undefined && i !== null, flatten(parallelMap(concurrency, func, iterable)));\n}\n\n/// \nasync function* parallelMerge(...iterables) {\n const inputs = iterables.map(getIterator);\n const concurrentWork = new Set();\n const values = new Map();\n let lastError = null;\n let errCb = null;\n let valueCb = null;\n const notifyError = err => {\n lastError = err;\n if (errCb) {\n errCb(err);\n }\n };\n const notifyDone = value => {\n if (valueCb) {\n valueCb(value);\n }\n };\n const waitForQueue = () => new Promise((resolve, reject) => {\n if (lastError) {\n reject(lastError);\n }\n if (values.size > 0) {\n return resolve();\n }\n valueCb = resolve;\n errCb = reject;\n });\n const queueNext = input => {\n const nextVal = Promise.resolve(input.next()).then(async ({ done, value }) => {\n if (!done) {\n values.set(input, value);\n }\n concurrentWork.delete(nextVal);\n });\n concurrentWork.add(nextVal);\n nextVal.then(notifyDone, notifyError);\n };\n for (const input of inputs) {\n queueNext(input);\n }\n while (true) {\n // We technically don't have to check `values.size` as the for loop should have emptied it\n // However I haven't yet found specs verifying that behavior, only tests\n // the guard in waitForQueue() checking for values is in place for the same reason\n if (concurrentWork.size === 0 && values.size === 0) {\n return;\n }\n await waitForQueue();\n for (const [input, value] of values) {\n values.delete(input);\n yield value;\n queueNext(input);\n }\n }\n}\n\nasync function _reduce(func, start, iterable) {\n let value = start;\n for await (const nextItem of iterable) {\n value = await func(value, nextItem);\n }\n return value;\n}\nfunction reduce(func, start, iterable) {\n if (start === undefined) {\n return (curriedStart, curriedIterable) => curriedIterable ? _reduce(func, curriedStart, curriedIterable) : reduce(func, curriedStart);\n }\n if (iterable === undefined) {\n return (curriedIterable) => reduce(func, start, curriedIterable);\n }\n return _reduce(func, start, iterable);\n}\n\nasync function* _take(count, iterable) {\n let taken = 0;\n for await (const val of iterable) {\n yield await val;\n taken++;\n if (taken >= count) {\n break;\n }\n }\n}\nfunction* _syncTake(count, iterable) {\n let taken = 0;\n for (const val of iterable) {\n yield val;\n taken++;\n if (taken >= count) {\n break;\n }\n }\n}\nfunction take(count, iterable) {\n if (iterable === undefined) {\n return curriedIterable => take(count, curriedIterable);\n }\n if (iterable[Symbol.asyncIterator]) {\n return _take(count, iterable);\n }\n return _syncTake(count, iterable);\n}\n\nasync function* _asyncTap(func, iterable) {\n for await (const val of iterable) {\n await func(val);\n yield val;\n }\n}\nfunction tap(func, iterable) {\n if (iterable === undefined) {\n return (curriedIterable) => _asyncTap(func, curriedIterable);\n }\n return _asyncTap(func, iterable);\n}\n\nfunction addTime(a, b) {\n let seconds = a[0] + b[0];\n let nanoseconds = a[1] + b[1];\n if (nanoseconds >= 1000000000) {\n const remainder = nanoseconds % 1000000000;\n seconds += (nanoseconds - remainder) / 1000000000;\n nanoseconds = remainder;\n }\n return [seconds, nanoseconds];\n}\nasync function* _asyncTime(config, iterable) {\n const itr = iterable[Symbol.asyncIterator]();\n let total = [0, 0];\n while (true) {\n const start = process.hrtime();\n const { value, done } = await itr.next();\n const delta = process.hrtime(start);\n total = addTime(total, delta);\n if (config.progress) {\n config.progress(delta, total);\n }\n if (done) {\n if (config.total) {\n config.total(total);\n }\n return value;\n }\n yield value;\n }\n}\nfunction* _syncTime(config, iterable) {\n const itr = iterable[Symbol.iterator]();\n let total = [0, 0];\n while (true) {\n const start = process.hrtime();\n const { value, done } = itr.next();\n const delta = process.hrtime(start);\n total = addTime(total, delta);\n if (config.progress) {\n config.progress(delta, total);\n }\n if (done) {\n if (config.total) {\n config.total(total);\n }\n return value;\n }\n yield value;\n }\n}\nfunction time(config = {}, iterable) {\n if (iterable === undefined) {\n return curriedIterable => time(config, curriedIterable);\n }\n if (iterable[Symbol.asyncIterator] !== undefined) {\n return _asyncTime(config, iterable);\n }\n else {\n return _syncTime(config, iterable);\n }\n}\n\nfunction _transform(concurrency, func, iterable) {\n const iterator = getIterator(iterable);\n const resultQueue = [];\n const readQueue = [];\n let ended = false;\n let reading = false;\n let inflightCount = 0;\n let lastError = null;\n function fulfillReadQueue() {\n while (readQueue.length > 0 && resultQueue.length > 0) {\n const { resolve } = readQueue.shift();\n const value = resultQueue.shift();\n resolve({ done: false, value });\n }\n while (readQueue.length > 0 && inflightCount === 0 && ended) {\n const { resolve, reject } = readQueue.shift();\n if (lastError) {\n reject(lastError);\n lastError = null;\n }\n else {\n resolve({ done: true, value: undefined });\n }\n }\n }\n async function fillQueue() {\n if (ended) {\n fulfillReadQueue();\n return;\n }\n if (reading) {\n return;\n }\n if (inflightCount + resultQueue.length >= concurrency) {\n return;\n }\n reading = true;\n inflightCount++;\n try {\n const { done, value } = await iterator.next();\n if (done) {\n ended = true;\n inflightCount--;\n fulfillReadQueue();\n }\n else {\n mapAndQueue(value);\n }\n }\n catch (error) {\n ended = true;\n inflightCount--;\n lastError = error;\n fulfillReadQueue();\n }\n reading = false;\n fillQueue();\n }\n async function mapAndQueue(itrValue) {\n try {\n const value = await func(itrValue);\n resultQueue.push(value);\n }\n catch (error) {\n ended = true;\n lastError = error;\n }\n inflightCount--;\n fulfillReadQueue();\n fillQueue();\n }\n async function next() {\n if (resultQueue.length === 0) {\n const deferred = defer();\n readQueue.push(deferred);\n fillQueue();\n return deferred.promise;\n }\n const value = resultQueue.shift();\n fillQueue();\n return { done: false, value };\n }\n const asyncIterableIterator = {\n next,\n [Symbol.asyncIterator]: () => asyncIterableIterator,\n };\n return asyncIterableIterator;\n}\nfunction transform(concurrency, func, iterable) {\n if (func === undefined) {\n return (curriedFunc, curriedIterable) => curriedIterable\n ? transform(concurrency, curriedFunc, curriedIterable)\n : transform(concurrency, curriedFunc);\n }\n if (iterable === undefined) {\n return (curriedIterable) => transform(concurrency, func, curriedIterable);\n }\n return _transform(concurrency, func, iterable);\n}\n\nasync function _writeToStream(stream, iterable) {\n let lastError = null;\n let errCb = null;\n let drainCb = null;\n const notifyError = err => {\n lastError = err;\n if (errCb) {\n errCb(err);\n }\n };\n const notifyDrain = () => {\n if (drainCb) {\n drainCb();\n }\n };\n const cleanup = () => {\n stream.removeListener('error', notifyError);\n stream.removeListener('drain', notifyDrain);\n };\n stream.once('error', notifyError);\n const waitForDrain = () => new Promise((resolve, reject) => {\n if (lastError) {\n return reject(lastError);\n }\n stream.once('drain', notifyDrain);\n drainCb = resolve;\n errCb = reject;\n });\n for await (const value of iterable) {\n if (stream.write(value) === false) {\n await waitForDrain();\n }\n if (lastError) {\n break;\n }\n }\n cleanup();\n if (lastError) {\n throw lastError;\n }\n}\nfunction writeToStream(stream, iterable) {\n if (iterable === undefined) {\n return (curriedIterable) => _writeToStream(stream, curriedIterable);\n }\n return _writeToStream(stream, iterable);\n}\n\nexport { batch, buffer, collect, concat, consume, filter, flatMap, flatTransform, flatten, fromStream, getIterator, map, merge, parallelFlatMap, parallelMap, parallelMerge, pipeline, reduce, take, tap, time, transform, writeToStream };\n","'use strict'\n\nconst { pipe } = require('it-pipe')\nconst lp = require('it-length-prefixed')\n\nconst Message = require('../message')\nconst handlers = require('./handlers')\nconst utils = require('../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\n/**\n * @param {import('../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc')\n const getMessageHandler = handlers(dht)\n\n /**\n * Process incoming DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function handleMessage (peerId, msg) {\n // get handler & execute it\n const handler = getMessageHandler(msg.type)\n\n try {\n await dht._add(peerId)\n } catch (err) {\n log.error('Failed to update the kbucket store', err)\n }\n\n if (!handler) {\n log.error(`no handler found for message type: ${msg.type}`)\n return\n }\n\n return handler(peerId, msg)\n }\n\n /**\n * Handle incoming streams on the dht protocol\n *\n * @param {object} props\n * @param {MuxedStream} props.stream\n * @param {import('libp2p-interfaces/src/connection').Connection} props.connection\n */\n async function onIncomingStream ({ stream, connection }) {\n const peerId = connection.remotePeer\n\n try {\n await dht._add(peerId)\n } catch (err) {\n log.error(err)\n }\n\n const idB58Str = peerId.toB58String()\n log('from: %s', idB58Str)\n\n await pipe(\n stream.source,\n lp.decode(),\n /**\n * @param {AsyncIterable} source\n */\n source => (async function * () {\n for await (const msg of source) {\n // handle the message\n const desMessage = Message.deserialize(msg.slice())\n const res = await handleMessage(peerId, desMessage)\n\n // Not all handlers will return a response\n if (res) {\n yield res.serialize()\n }\n }\n })(),\n lp.encode(),\n stream.sink\n )\n }\n\n return onIncomingStream\n}\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\nconst { Record } = require('libp2p-record')\nconst Proto = require('./dht')\n\nconst MESSAGE_TYPE = Proto.Message.MessageType\nconst CONNECTION_TYPE = Proto.Message.ConnectionType\n\n/**\n * @typedef {0|1|2|3|4} ConnectionType\n *\n * @typedef {object} PBPeer\n * @property {Uint8Array} id\n * @property {Uint8Array[]} addrs\n * @property {ConnectionType} connection\n *\n * @typedef {import('../index').PeerData} PeerData\n */\n\n/**\n * Represents a single DHT control message.\n */\nclass Message {\n /**\n * @param {import('./dht').Message.MessageType} type\n * @param {Uint8Array} key\n * @param {number} level\n */\n constructor (type, key, level) {\n if (key && !(key instanceof Uint8Array)) {\n throw new Error('Key must be a Uint8Array')\n }\n\n this.type = type\n this.key = key\n this._clusterLevelRaw = level\n\n /** @type {PeerData[]} */\n this.closerPeers = []\n /** @type {PeerData[]} */\n this.providerPeers = []\n /** @type {import('libp2p-record').Record | undefined} */\n this.record = undefined\n }\n\n /**\n * @type {number}\n */\n get clusterLevel () {\n const level = this._clusterLevelRaw - 1\n if (level < 0) {\n return 0\n }\n\n return level\n }\n\n set clusterLevel (level) {\n this._clusterLevelRaw = level\n }\n\n /**\n * Encode into protobuf\n */\n serialize () {\n const obj = {\n key: this.key,\n type: this.type,\n clusterLevelRaw: this._clusterLevelRaw,\n closerPeers: this.closerPeers.map(toPbPeer),\n providerPeers: this.providerPeers.map(toPbPeer),\n\n /** @type {Uint8Array | undefined} */\n record: undefined\n }\n\n if (this.record) {\n if (this.record instanceof Uint8Array) {\n obj.record = this.record\n } else {\n obj.record = this.record.serialize()\n }\n }\n\n return Proto.Message.encode(obj).finish()\n }\n\n /**\n * Decode from protobuf\n *\n * @param {Uint8Array} raw\n */\n static deserialize (raw) {\n const dec = Proto.Message.decode(raw)\n\n const msg = new Message(dec.type || 0, dec.key || Uint8Array.from([]), dec.clusterLevelRaw || 0)\n\n msg.closerPeers = dec.closerPeers.map(fromPbPeer)\n msg.providerPeers = dec.providerPeers.map(fromPbPeer)\n\n if (dec.record && dec.record.length) {\n msg.record = Record.deserialize(dec.record)\n }\n\n return msg\n }\n}\n\nMessage.TYPES = MESSAGE_TYPE\nMessage.CONNECTION_TYPES = CONNECTION_TYPE\n\n/**\n * @param {PeerData} peer\n */\nfunction toPbPeer (peer) {\n /** @type {PBPeer} */\n const output = {\n id: peer.id.id,\n addrs: (peer.multiaddrs || []).map((m) => m.bytes),\n connection: CONNECTION_TYPE.CONNECTED\n }\n\n return output\n}\n\n/**\n * @param {import('./dht').Message.IPeer} peer\n */\nfunction fromPbPeer (peer) {\n return {\n // @ts-ignore id is optional on protobuf, but it will exist?\n id: new PeerId(peer.id),\n multiaddrs: (peer.addrs || []).map((a) => new Multiaddr(a))\n }\n}\n\nmodule.exports = Message\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-dht-message\"] || ($protobuf.roots[\"libp2p-dht-message\"] = {});\n\n$root.Record = (function() {\n\n /**\n * Properties of a Record.\n * @exports IRecord\n * @interface IRecord\n * @property {Uint8Array|null} [key] Record key\n * @property {Uint8Array|null} [value] Record value\n * @property {Uint8Array|null} [author] Record author\n * @property {Uint8Array|null} [signature] Record signature\n * @property {string|null} [timeReceived] Record timeReceived\n */\n\n /**\n * Constructs a new Record.\n * @exports Record\n * @classdesc Represents a Record.\n * @implements IRecord\n * @constructor\n * @param {IRecord=} [p] Properties to set\n */\n function Record(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Record key.\n * @member {Uint8Array|null|undefined} key\n * @memberof Record\n * @instance\n */\n Record.prototype.key = null;\n\n /**\n * Record value.\n * @member {Uint8Array|null|undefined} value\n * @memberof Record\n * @instance\n */\n Record.prototype.value = null;\n\n /**\n * Record author.\n * @member {Uint8Array|null|undefined} author\n * @memberof Record\n * @instance\n */\n Record.prototype.author = null;\n\n /**\n * Record signature.\n * @member {Uint8Array|null|undefined} signature\n * @memberof Record\n * @instance\n */\n Record.prototype.signature = null;\n\n /**\n * Record timeReceived.\n * @member {string|null|undefined} timeReceived\n * @memberof Record\n * @instance\n */\n Record.prototype.timeReceived = null;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * Record _key.\n * @member {\"key\"|undefined} _key\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_key\", {\n get: $util.oneOfGetter($oneOfFields = [\"key\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Record _value.\n * @member {\"value\"|undefined} _value\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_value\", {\n get: $util.oneOfGetter($oneOfFields = [\"value\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Record _author.\n * @member {\"author\"|undefined} _author\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_author\", {\n get: $util.oneOfGetter($oneOfFields = [\"author\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Record _signature.\n * @member {\"signature\"|undefined} _signature\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_signature\", {\n get: $util.oneOfGetter($oneOfFields = [\"signature\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Record _timeReceived.\n * @member {\"timeReceived\"|undefined} _timeReceived\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_timeReceived\", {\n get: $util.oneOfGetter($oneOfFields = [\"timeReceived\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified Record message. Does not implicitly {@link Record.verify|verify} messages.\n * @function encode\n * @memberof Record\n * @static\n * @param {IRecord} m Record message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Record.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(10).bytes(m.key);\n if (m.value != null && Object.hasOwnProperty.call(m, \"value\"))\n w.uint32(18).bytes(m.value);\n if (m.author != null && Object.hasOwnProperty.call(m, \"author\"))\n w.uint32(26).bytes(m.author);\n if (m.signature != null && Object.hasOwnProperty.call(m, \"signature\"))\n w.uint32(34).bytes(m.signature);\n if (m.timeReceived != null && Object.hasOwnProperty.call(m, \"timeReceived\"))\n w.uint32(42).string(m.timeReceived);\n return w;\n };\n\n /**\n * Decodes a Record message from the specified reader or buffer.\n * @function decode\n * @memberof Record\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Record} Record\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Record.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Record();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.key = r.bytes();\n break;\n case 2:\n m.value = r.bytes();\n break;\n case 3:\n m.author = r.bytes();\n break;\n case 4:\n m.signature = r.bytes();\n break;\n case 5:\n m.timeReceived = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Record message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Record\n * @static\n * @param {Object.} d Plain object\n * @returns {Record} Record\n */\n Record.fromObject = function fromObject(d) {\n if (d instanceof $root.Record)\n return d;\n var m = new $root.Record();\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n if (d.value != null) {\n if (typeof d.value === \"string\")\n $util.base64.decode(d.value, m.value = $util.newBuffer($util.base64.length(d.value)), 0);\n else if (d.value.length)\n m.value = d.value;\n }\n if (d.author != null) {\n if (typeof d.author === \"string\")\n $util.base64.decode(d.author, m.author = $util.newBuffer($util.base64.length(d.author)), 0);\n else if (d.author.length)\n m.author = d.author;\n }\n if (d.signature != null) {\n if (typeof d.signature === \"string\")\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n if (d.timeReceived != null) {\n m.timeReceived = String(d.timeReceived);\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Record message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Record\n * @static\n * @param {Record} m Record\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Record.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n if (o.oneofs)\n d._key = \"key\";\n }\n if (m.value != null && m.hasOwnProperty(\"value\")) {\n d.value = o.bytes === String ? $util.base64.encode(m.value, 0, m.value.length) : o.bytes === Array ? Array.prototype.slice.call(m.value) : m.value;\n if (o.oneofs)\n d._value = \"value\";\n }\n if (m.author != null && m.hasOwnProperty(\"author\")) {\n d.author = o.bytes === String ? $util.base64.encode(m.author, 0, m.author.length) : o.bytes === Array ? Array.prototype.slice.call(m.author) : m.author;\n if (o.oneofs)\n d._author = \"author\";\n }\n if (m.signature != null && m.hasOwnProperty(\"signature\")) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n if (o.oneofs)\n d._signature = \"signature\";\n }\n if (m.timeReceived != null && m.hasOwnProperty(\"timeReceived\")) {\n d.timeReceived = m.timeReceived;\n if (o.oneofs)\n d._timeReceived = \"timeReceived\";\n }\n return d;\n };\n\n /**\n * Converts this Record to JSON.\n * @function toJSON\n * @memberof Record\n * @instance\n * @returns {Object.} JSON object\n */\n Record.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Record;\n})();\n\n$root.Message = (function() {\n\n /**\n * Properties of a Message.\n * @exports IMessage\n * @interface IMessage\n * @property {Message.MessageType|null} [type] Message type\n * @property {number|null} [clusterLevelRaw] Message clusterLevelRaw\n * @property {Uint8Array|null} [key] Message key\n * @property {Uint8Array|null} [record] Message record\n * @property {Array.|null} [closerPeers] Message closerPeers\n * @property {Array.|null} [providerPeers] Message providerPeers\n */\n\n /**\n * Constructs a new Message.\n * @exports Message\n * @classdesc Represents a Message.\n * @implements IMessage\n * @constructor\n * @param {IMessage=} [p] Properties to set\n */\n function Message(p) {\n this.closerPeers = [];\n this.providerPeers = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Message type.\n * @member {Message.MessageType|null|undefined} type\n * @memberof Message\n * @instance\n */\n Message.prototype.type = null;\n\n /**\n * Message clusterLevelRaw.\n * @member {number|null|undefined} clusterLevelRaw\n * @memberof Message\n * @instance\n */\n Message.prototype.clusterLevelRaw = null;\n\n /**\n * Message key.\n * @member {Uint8Array|null|undefined} key\n * @memberof Message\n * @instance\n */\n Message.prototype.key = null;\n\n /**\n * Message record.\n * @member {Uint8Array|null|undefined} record\n * @memberof Message\n * @instance\n */\n Message.prototype.record = null;\n\n /**\n * Message closerPeers.\n * @member {Array.} closerPeers\n * @memberof Message\n * @instance\n */\n Message.prototype.closerPeers = $util.emptyArray;\n\n /**\n * Message providerPeers.\n * @member {Array.} providerPeers\n * @memberof Message\n * @instance\n */\n Message.prototype.providerPeers = $util.emptyArray;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * Message _type.\n * @member {\"type\"|undefined} _type\n * @memberof Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_type\", {\n get: $util.oneOfGetter($oneOfFields = [\"type\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _clusterLevelRaw.\n * @member {\"clusterLevelRaw\"|undefined} _clusterLevelRaw\n * @memberof Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_clusterLevelRaw\", {\n get: $util.oneOfGetter($oneOfFields = [\"clusterLevelRaw\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _key.\n * @member {\"key\"|undefined} _key\n * @memberof Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_key\", {\n get: $util.oneOfGetter($oneOfFields = [\"key\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _record.\n * @member {\"record\"|undefined} _record\n * @memberof Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_record\", {\n get: $util.oneOfGetter($oneOfFields = [\"record\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified Message message. Does not implicitly {@link Message.verify|verify} messages.\n * @function encode\n * @memberof Message\n * @static\n * @param {IMessage} m Message message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Message.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.type != null && Object.hasOwnProperty.call(m, \"type\"))\n w.uint32(8).int32(m.type);\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(18).bytes(m.key);\n if (m.record != null && Object.hasOwnProperty.call(m, \"record\"))\n w.uint32(26).bytes(m.record);\n if (m.closerPeers != null && m.closerPeers.length) {\n for (var i = 0; i < m.closerPeers.length; ++i)\n $root.Message.Peer.encode(m.closerPeers[i], w.uint32(66).fork()).ldelim();\n }\n if (m.providerPeers != null && m.providerPeers.length) {\n for (var i = 0; i < m.providerPeers.length; ++i)\n $root.Message.Peer.encode(m.providerPeers[i], w.uint32(74).fork()).ldelim();\n }\n if (m.clusterLevelRaw != null && Object.hasOwnProperty.call(m, \"clusterLevelRaw\"))\n w.uint32(80).int32(m.clusterLevelRaw);\n return w;\n };\n\n /**\n * Decodes a Message message from the specified reader or buffer.\n * @function decode\n * @memberof Message\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Message} Message\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Message.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.type = r.int32();\n break;\n case 10:\n m.clusterLevelRaw = r.int32();\n break;\n case 2:\n m.key = r.bytes();\n break;\n case 3:\n m.record = r.bytes();\n break;\n case 8:\n if (!(m.closerPeers && m.closerPeers.length))\n m.closerPeers = [];\n m.closerPeers.push($root.Message.Peer.decode(r, r.uint32()));\n break;\n case 9:\n if (!(m.providerPeers && m.providerPeers.length))\n m.providerPeers = [];\n m.providerPeers.push($root.Message.Peer.decode(r, r.uint32()));\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Message message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Message\n * @static\n * @param {Object.} d Plain object\n * @returns {Message} Message\n */\n Message.fromObject = function fromObject(d) {\n if (d instanceof $root.Message)\n return d;\n var m = new $root.Message();\n switch (d.type) {\n case \"PUT_VALUE\":\n case 0:\n m.type = 0;\n break;\n case \"GET_VALUE\":\n case 1:\n m.type = 1;\n break;\n case \"ADD_PROVIDER\":\n case 2:\n m.type = 2;\n break;\n case \"GET_PROVIDERS\":\n case 3:\n m.type = 3;\n break;\n case \"FIND_NODE\":\n case 4:\n m.type = 4;\n break;\n case \"PING\":\n case 5:\n m.type = 5;\n break;\n }\n if (d.clusterLevelRaw != null) {\n m.clusterLevelRaw = d.clusterLevelRaw | 0;\n }\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n if (d.record != null) {\n if (typeof d.record === \"string\")\n $util.base64.decode(d.record, m.record = $util.newBuffer($util.base64.length(d.record)), 0);\n else if (d.record.length)\n m.record = d.record;\n }\n if (d.closerPeers) {\n if (!Array.isArray(d.closerPeers))\n throw TypeError(\".Message.closerPeers: array expected\");\n m.closerPeers = [];\n for (var i = 0; i < d.closerPeers.length; ++i) {\n if (typeof d.closerPeers[i] !== \"object\")\n throw TypeError(\".Message.closerPeers: object expected\");\n m.closerPeers[i] = $root.Message.Peer.fromObject(d.closerPeers[i]);\n }\n }\n if (d.providerPeers) {\n if (!Array.isArray(d.providerPeers))\n throw TypeError(\".Message.providerPeers: array expected\");\n m.providerPeers = [];\n for (var i = 0; i < d.providerPeers.length; ++i) {\n if (typeof d.providerPeers[i] !== \"object\")\n throw TypeError(\".Message.providerPeers: object expected\");\n m.providerPeers[i] = $root.Message.Peer.fromObject(d.providerPeers[i]);\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Message message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Message\n * @static\n * @param {Message} m Message\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Message.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.closerPeers = [];\n d.providerPeers = [];\n }\n if (m.type != null && m.hasOwnProperty(\"type\")) {\n d.type = o.enums === String ? $root.Message.MessageType[m.type] : m.type;\n if (o.oneofs)\n d._type = \"type\";\n }\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n if (o.oneofs)\n d._key = \"key\";\n }\n if (m.record != null && m.hasOwnProperty(\"record\")) {\n d.record = o.bytes === String ? $util.base64.encode(m.record, 0, m.record.length) : o.bytes === Array ? Array.prototype.slice.call(m.record) : m.record;\n if (o.oneofs)\n d._record = \"record\";\n }\n if (m.closerPeers && m.closerPeers.length) {\n d.closerPeers = [];\n for (var j = 0; j < m.closerPeers.length; ++j) {\n d.closerPeers[j] = $root.Message.Peer.toObject(m.closerPeers[j], o);\n }\n }\n if (m.providerPeers && m.providerPeers.length) {\n d.providerPeers = [];\n for (var j = 0; j < m.providerPeers.length; ++j) {\n d.providerPeers[j] = $root.Message.Peer.toObject(m.providerPeers[j], o);\n }\n }\n if (m.clusterLevelRaw != null && m.hasOwnProperty(\"clusterLevelRaw\")) {\n d.clusterLevelRaw = m.clusterLevelRaw;\n if (o.oneofs)\n d._clusterLevelRaw = \"clusterLevelRaw\";\n }\n return d;\n };\n\n /**\n * Converts this Message to JSON.\n * @function toJSON\n * @memberof Message\n * @instance\n * @returns {Object.} JSON object\n */\n Message.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n /**\n * MessageType enum.\n * @name Message.MessageType\n * @enum {number}\n * @property {number} PUT_VALUE=0 PUT_VALUE value\n * @property {number} GET_VALUE=1 GET_VALUE value\n * @property {number} ADD_PROVIDER=2 ADD_PROVIDER value\n * @property {number} GET_PROVIDERS=3 GET_PROVIDERS value\n * @property {number} FIND_NODE=4 FIND_NODE value\n * @property {number} PING=5 PING value\n */\n Message.MessageType = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = \"PUT_VALUE\"] = 0;\n values[valuesById[1] = \"GET_VALUE\"] = 1;\n values[valuesById[2] = \"ADD_PROVIDER\"] = 2;\n values[valuesById[3] = \"GET_PROVIDERS\"] = 3;\n values[valuesById[4] = \"FIND_NODE\"] = 4;\n values[valuesById[5] = \"PING\"] = 5;\n return values;\n })();\n\n /**\n * ConnectionType enum.\n * @name Message.ConnectionType\n * @enum {number}\n * @property {number} NOT_CONNECTED=0 NOT_CONNECTED value\n * @property {number} CONNECTED=1 CONNECTED value\n * @property {number} CAN_CONNECT=2 CAN_CONNECT value\n * @property {number} CANNOT_CONNECT=3 CANNOT_CONNECT value\n */\n Message.ConnectionType = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = \"NOT_CONNECTED\"] = 0;\n values[valuesById[1] = \"CONNECTED\"] = 1;\n values[valuesById[2] = \"CAN_CONNECT\"] = 2;\n values[valuesById[3] = \"CANNOT_CONNECT\"] = 3;\n return values;\n })();\n\n Message.Peer = (function() {\n\n /**\n * Properties of a Peer.\n * @memberof Message\n * @interface IPeer\n * @property {Uint8Array|null} [id] Peer id\n * @property {Array.|null} [addrs] Peer addrs\n * @property {Message.ConnectionType|null} [connection] Peer connection\n */\n\n /**\n * Constructs a new Peer.\n * @memberof Message\n * @classdesc Represents a Peer.\n * @implements IPeer\n * @constructor\n * @param {Message.IPeer=} [p] Properties to set\n */\n function Peer(p) {\n this.addrs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Peer id.\n * @member {Uint8Array|null|undefined} id\n * @memberof Message.Peer\n * @instance\n */\n Peer.prototype.id = null;\n\n /**\n * Peer addrs.\n * @member {Array.} addrs\n * @memberof Message.Peer\n * @instance\n */\n Peer.prototype.addrs = $util.emptyArray;\n\n /**\n * Peer connection.\n * @member {Message.ConnectionType|null|undefined} connection\n * @memberof Message.Peer\n * @instance\n */\n Peer.prototype.connection = null;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * Peer _id.\n * @member {\"id\"|undefined} _id\n * @memberof Message.Peer\n * @instance\n */\n Object.defineProperty(Peer.prototype, \"_id\", {\n get: $util.oneOfGetter($oneOfFields = [\"id\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Peer _connection.\n * @member {\"connection\"|undefined} _connection\n * @memberof Message.Peer\n * @instance\n */\n Object.defineProperty(Peer.prototype, \"_connection\", {\n get: $util.oneOfGetter($oneOfFields = [\"connection\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified Peer message. Does not implicitly {@link Message.Peer.verify|verify} messages.\n * @function encode\n * @memberof Message.Peer\n * @static\n * @param {Message.IPeer} m Peer message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Peer.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.id != null && Object.hasOwnProperty.call(m, \"id\"))\n w.uint32(10).bytes(m.id);\n if (m.addrs != null && m.addrs.length) {\n for (var i = 0; i < m.addrs.length; ++i)\n w.uint32(18).bytes(m.addrs[i]);\n }\n if (m.connection != null && Object.hasOwnProperty.call(m, \"connection\"))\n w.uint32(24).int32(m.connection);\n return w;\n };\n\n /**\n * Decodes a Peer message from the specified reader or buffer.\n * @function decode\n * @memberof Message.Peer\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Message.Peer} Peer\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Peer.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.Peer();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.id = r.bytes();\n break;\n case 2:\n if (!(m.addrs && m.addrs.length))\n m.addrs = [];\n m.addrs.push(r.bytes());\n break;\n case 3:\n m.connection = r.int32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Peer message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Message.Peer\n * @static\n * @param {Object.} d Plain object\n * @returns {Message.Peer} Peer\n */\n Peer.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.Peer)\n return d;\n var m = new $root.Message.Peer();\n if (d.id != null) {\n if (typeof d.id === \"string\")\n $util.base64.decode(d.id, m.id = $util.newBuffer($util.base64.length(d.id)), 0);\n else if (d.id.length)\n m.id = d.id;\n }\n if (d.addrs) {\n if (!Array.isArray(d.addrs))\n throw TypeError(\".Message.Peer.addrs: array expected\");\n m.addrs = [];\n for (var i = 0; i < d.addrs.length; ++i) {\n if (typeof d.addrs[i] === \"string\")\n $util.base64.decode(d.addrs[i], m.addrs[i] = $util.newBuffer($util.base64.length(d.addrs[i])), 0);\n else if (d.addrs[i].length)\n m.addrs[i] = d.addrs[i];\n }\n }\n switch (d.connection) {\n case \"NOT_CONNECTED\":\n case 0:\n m.connection = 0;\n break;\n case \"CONNECTED\":\n case 1:\n m.connection = 1;\n break;\n case \"CAN_CONNECT\":\n case 2:\n m.connection = 2;\n break;\n case \"CANNOT_CONNECT\":\n case 3:\n m.connection = 3;\n break;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Peer message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Message.Peer\n * @static\n * @param {Message.Peer} m Peer\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Peer.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.addrs = [];\n }\n if (m.id != null && m.hasOwnProperty(\"id\")) {\n d.id = o.bytes === String ? $util.base64.encode(m.id, 0, m.id.length) : o.bytes === Array ? Array.prototype.slice.call(m.id) : m.id;\n if (o.oneofs)\n d._id = \"id\";\n }\n if (m.addrs && m.addrs.length) {\n d.addrs = [];\n for (var j = 0; j < m.addrs.length; ++j) {\n d.addrs[j] = o.bytes === String ? $util.base64.encode(m.addrs[j], 0, m.addrs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.addrs[j]) : m.addrs[j];\n }\n }\n if (m.connection != null && m.hasOwnProperty(\"connection\")) {\n d.connection = o.enums === String ? $root.Message.ConnectionType[m.connection] : m.connection;\n if (o.oneofs)\n d._connection = \"connection\";\n }\n return d;\n };\n\n /**\n * Converts this Peer to JSON.\n * @function toJSON\n * @memberof Message.Peer\n * @instance\n * @returns {Object.} JSON object\n */\n Peer.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Peer;\n })();\n\n return Message;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst T = require('../../message').TYPES\n\n/**\n *\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const handlers = {\n [T.GET_VALUE]: require('./get-value')(dht),\n [T.PUT_VALUE]: require('./put-value')(dht),\n [T.FIND_NODE]: require('./find-node')(dht),\n [T.ADD_PROVIDER]: require('./add-provider')(dht),\n [T.GET_PROVIDERS]: require('./get-providers')(dht),\n [T.PING]: require('./ping')(dht)\n }\n\n /**\n * Get the message handler matching the passed in type.\n *\n * @param {number} type\n */\n function getMessageHandler (type) {\n // @ts-ignore ts does not aknowledge number as an index type\n return handlers[type]\n }\n\n return getMessageHandler\n}\n","'use strict'\n\nconst { Record } = require('libp2p-record')\n\nconst errcode = require('err-code')\n\nconst Message = require('../../message')\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:get-value')\n\n /**\n * Process `GetValue` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n * @returns {Promise}\n */\n async function getValue (peerId, msg) {\n const key = msg.key\n\n log('key: %b', key)\n\n if (!key || key.length === 0) {\n throw errcode(new Error('Invalid key'), 'ERR_INVALID_KEY')\n }\n\n const response = new Message(Message.TYPES.GET_VALUE, key, msg.clusterLevel)\n\n if (utils.isPublicKeyKey(key)) {\n log('is public key')\n const idFromKey = utils.fromPublicKeyKey(key)\n let id\n\n if (dht._isSelf(idFromKey)) {\n id = dht.peerId\n } else {\n const peerData = dht.peerStore.get(idFromKey)\n id = peerData && peerData.id\n }\n\n if (id && id.pubKey) {\n log('returning found public key')\n response.record = new Record(key, id.pubKey.bytes)\n return response\n }\n }\n\n const [record, closer] = await Promise.all([\n dht._checkLocalDatastore(key),\n dht._betterPeersToQuery(msg, peerId)\n ])\n\n if (record) {\n log('got record')\n response.record = record\n }\n\n if (closer.length > 0) {\n log('got closer %s', closer.length)\n response.closerPeers = closer\n }\n\n return response\n }\n\n return getValue\n}\n","'use strict'\n\nconst utils = require('../../utils')\nconst errcode = require('err-code')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../../message')} Message\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:put-value')\n\n /**\n * Process `PutValue` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function putValue (peerId, msg) {\n const key = msg.key\n log('key: %b', key)\n\n const record = msg.record\n\n if (!record) {\n const errMsg = `Empty record from: ${peerId.toB58String()}`\n\n log.error(errMsg)\n throw errcode(new Error(errMsg), 'ERR_EMPTY_RECORD')\n }\n\n await dht._verifyRecordLocally(record)\n\n record.timeReceived = new Date()\n const recordKey = utils.bufferToKey(record.key)\n await dht.datastore.put(recordKey, record.serialize())\n\n dht.onPut(record, peerId)\n\n return msg\n }\n\n return putValue\n}\n","'use strict'\n\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\nconst Message = require('../../message')\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:find-node')\n\n /**\n * Process `FindNode` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function findNode (peerId, msg) {\n log('start')\n\n let closer\n if (uint8ArrayEquals(msg.key, dht.peerId.id)) {\n closer = [{\n id: dht.peerId,\n multiaddrs: dht.libp2p.multiaddrs\n }]\n } else {\n closer = await dht._betterPeersToQuery(msg, peerId)\n }\n\n const response = new Message(msg.type, new Uint8Array(0), msg.clusterLevel)\n\n if (closer.length > 0) {\n response.closerPeers = closer\n } else {\n log('handle FindNode %s: could not find anything', peerId.toB58String())\n }\n\n return response\n }\n\n return findNode\n}\n","'use strict'\n\nconst { CID } = require('multiformats/cid')\nconst errcode = require('err-code')\n\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../../message')} Message\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:add-provider')\n /**\n * Process `AddProvider` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function addProvider (peerId, msg) { // eslint-disable-line require-await\n log('start')\n\n if (!msg.key || msg.key.length === 0) {\n throw errcode(new Error('Missing key'), 'ERR_MISSING_KEY')\n }\n\n /** @type {CID} */\n let cid\n try {\n cid = CID.decode(msg.key)\n } catch (err) {\n const errMsg = `Invalid CID: ${err.message}`\n throw errcode(new Error(errMsg), 'ERR_INVALID_CID')\n }\n\n msg.providerPeers.forEach((pi) => {\n // Ignore providers not from the originator\n if (!pi.id.isEqual(peerId)) {\n log('invalid provider peer %s from %s', pi.id.toB58String(), peerId.toB58String())\n return\n }\n\n if (pi.multiaddrs.length < 1) {\n log('no valid addresses for provider %s. Ignore', peerId.toB58String())\n return\n }\n\n log('received provider %s for %s (addrs %s)', peerId.toB58String(), cid.toString(), pi.multiaddrs.map((m) => m.toString()))\n\n if (!dht._isSelf(pi.id)) {\n // Add known address to peer store\n dht.peerStore.addressBook.add(pi.id, pi.multiaddrs)\n return dht.providers.addProvider(cid, pi.id)\n }\n })\n\n // Previous versions of the JS DHT sent erroneous providers in the\n // `providerPeers` field. In order to accommodate older clients that have\n // this bug, we fall back to assuming the originator is the provider if\n // we can't find any valid providers in the payload.\n // https://github.com/libp2p/js-libp2p-kad-dht/pull/127\n // https://github.com/libp2p/js-libp2p-kad-dht/issues/128\n return dht.providers.addProvider(cid, peerId)\n }\n\n return addProvider\n}\n","'use strict'\n\nconst { CID } = require('multiformats/cid')\nconst errcode = require('err-code')\n\nconst Message = require('../../message')\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:get-providers')\n\n /**\n * Process `GetProviders` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function getProviders (peerId, msg) {\n let cid\n try {\n cid = CID.decode(msg.key)\n } catch (err) {\n throw errcode(new Error(`Invalid CID: ${err.message}`), 'ERR_INVALID_CID')\n }\n\n log('%s', cid.toString())\n const dsKey = utils.bufferToKey(cid.bytes)\n\n const [has, peers, closer] = await Promise.all([\n dht.datastore.has(dsKey),\n dht.providers.getProviders(cid),\n dht._betterPeersToQuery(msg, peerId)\n ])\n\n const providerPeers = peers.map((peerId) => ({\n id: peerId,\n multiaddrs: []\n }))\n const closerPeers = closer.map((c) => ({\n id: c.id,\n multiaddrs: []\n }))\n\n if (has) {\n providerPeers.push({\n id: dht.peerId,\n multiaddrs: []\n })\n }\n\n const response = new Message(msg.type, msg.key, msg.clusterLevel)\n\n if (providerPeers.length > 0) {\n response.providerPeers = providerPeers\n }\n\n if (closerPeers.length > 0) {\n response.closerPeers = closerPeers\n }\n\n log('got %s providers %s closerPeers', providerPeers.length, closerPeers.length)\n return response\n }\n\n return getProviders\n}\n","'use strict'\n\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../../message')} Message\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:ping')\n\n /**\n * Process `Ping` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n function ping (peerId, msg) {\n log('from %s', peerId.toB58String())\n return msg\n }\n\n return ping\n}\n","'use strict'\n\nconst errcode = require('err-code')\nconst pTimeout = require('p-timeout')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst libp2pRecord = require('libp2p-record')\nconst c = require('../constants')\nconst Query = require('../query')\nconst utils = require('../utils')\nconst Record = libp2pRecord.Record\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../query').DHTQueryResult} DHTQueryResult\n */\n\n/**\n * @param {import('../')} dht\n */\nmodule.exports = (dht) => {\n /**\n * @param {Uint8Array} key\n * @param {Uint8Array} rec\n */\n const putLocal = async (key, rec) => { // eslint-disable-line require-await\n return dht.datastore.put(utils.bufferToKey(key), rec)\n }\n\n /**\n * Attempt to retrieve the value for the given key from\n * the local datastore.\n *\n * @param {Uint8Array} key\n */\n const getLocal = async (key) => {\n dht._log(`getLocal ${uint8ArrayToString(key, 'base32')}`)\n\n const raw = await dht.datastore.get(utils.bufferToKey(key))\n dht._log(`found ${uint8ArrayToString(key, 'base32')} in local datastore`)\n\n const rec = Record.deserialize(raw)\n\n await dht._verifyRecordLocally(rec)\n\n return rec\n }\n\n /**\n * Send the best record found to any peers that have an out of date record.\n *\n * @param {Uint8Array} key\n * @param {import('../query').DHTQueryValue[]} vals - values retrieved from the DHT\n * @param {Uint8Array} best - the best record that was found\n */\n const sendCorrectionRecord = async (key, vals, best) => {\n const fixupRec = await utils.createPutRecord(key, best)\n\n return Promise.all(vals.map(async (v) => {\n // no need to do anything\n if (uint8ArrayEquals(v.val, best)) {\n return\n }\n\n // correct ourself\n if (dht._isSelf(v.from)) {\n try {\n await dht._putLocal(key, fixupRec)\n } catch (err) {\n dht._log.error('Failed error correcting self', err)\n }\n return\n }\n\n // send correction\n try {\n await dht._putValueToPeer(key, fixupRec, v.from)\n } catch (err) {\n dht._log.error('Failed error correcting entry', err)\n }\n }))\n }\n\n return {\n /**\n * Store the given key/value pair locally, in the datastore.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} rec - encoded record\n */\n async _putLocal (key, rec) { // eslint-disable-line require-await\n return putLocal(key, rec)\n },\n\n /**\n * Store the given key/value pair in the DHT.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n * @param {object} [options] - put options\n * @param {number} [options.minPeers] - minimum number of peers required to successfully put (default: closestPeers.length)\n */\n async put (key, value, options = {}) {\n dht._log('PutValue %b', key)\n\n // create record in the dht format\n const record = await utils.createPutRecord(key, value)\n\n // store the record locally\n await putLocal(key, record)\n\n // put record to the closest peers\n let counterAll = 0\n let counterSuccess = 0\n\n await utils.mapParallel(dht.getClosestPeers(key, { shallow: true }), async (peer) => {\n try {\n counterAll += 1\n await dht._putValueToPeer(key, record, peer)\n counterSuccess += 1\n } catch (err) {\n dht._log.error('Failed to put to peer (%b): %s', peer.id, err)\n }\n })\n\n // verify if we were able to put to enough peers\n const minPeers = options.minPeers || counterAll // Ensure we have a default `minPeers`\n\n if (minPeers > counterSuccess) {\n const error = errcode(new Error(`Failed to put value to enough peers: ${counterSuccess}/${minPeers}`), 'ERR_NOT_ENOUGH_PUT_PEERS')\n dht._log.error(error)\n throw error\n }\n },\n\n /**\n * Get the value to the given key.\n * Times out after 1 minute by default.\n *\n * @param {Uint8Array} key\n * @param {object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n */\n async get (key, options = {}) {\n options.timeout = options.timeout || c.minute\n\n dht._log('_get %b', key)\n\n const vals = await dht.getMany(key, c.GET_MANY_RECORD_COUNT, options)\n const recs = vals.map((v) => v.val)\n let i = 0\n\n try {\n i = libp2pRecord.selection.bestRecord(dht.selectors, key, recs)\n } catch (err) {\n // Assume the first record if no selector available\n if (err.code !== 'ERR_NO_SELECTOR_FUNCTION_FOR_RECORD_KEY') {\n throw err\n }\n }\n\n const best = recs[i]\n dht._log('GetValue %b %s', key, best)\n\n if (!best) {\n throw errcode(new Error('best value was not found'), 'ERR_NOT_FOUND')\n }\n\n await sendCorrectionRecord(key, vals, best)\n\n return best\n },\n\n /**\n * Get the `n` values to the given key without sorting.\n *\n * @param {Uint8Array} key\n * @param {number} nvals\n * @param {object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n */\n async getMany (key, nvals, options = {}) {\n options.timeout = options.timeout || c.minute\n\n dht._log('getMany %b (%s)', key, nvals)\n\n const vals = []\n let localRec\n\n try {\n localRec = await getLocal(key)\n } catch (err) {\n if (nvals === 0) {\n throw err\n }\n }\n\n if (localRec) {\n vals.push({\n val: localRec.value,\n from: dht.peerId\n })\n }\n\n if (vals.length >= nvals) {\n return vals\n }\n\n const id = await utils.convertBuffer(key)\n const rtp = dht.routingTable.closestPeers(id, dht.kBucketSize)\n\n dht._log('peers in rt: %d', rtp.length)\n\n if (rtp.length === 0) {\n const errMsg = 'Failed to lookup key! No peers from routing table!'\n\n dht._log.error(errMsg)\n if (vals.length === 0) {\n throw errcode(new Error(errMsg), 'ERR_NO_PEERS_IN_ROUTING_TABLE')\n }\n return vals\n }\n\n const valsLength = vals.length\n\n /**\n * @param {number} pathIndex\n * @param {number} numPaths\n */\n function createQuery (pathIndex, numPaths) {\n // This function body runs once per disjoint path\n const pathSize = utils.pathSize(nvals - valsLength, numPaths)\n let queryResults = 0\n\n /**\n * Here we return the query function to use on this particular disjoint path\n *\n * @param {PeerId} peer\n */\n async function disjointPathQuery (peer) {\n let rec, peers, lookupErr\n try {\n const results = await dht._getValueOrPeers(peer, key)\n rec = results.record\n peers = results.peers\n } catch (err) {\n // If we have an invalid record we just want to continue and fetch a new one.\n if (err.code !== 'ERR_INVALID_RECORD') {\n throw err\n }\n lookupErr = err\n }\n\n /** @type {import('../query').QueryResult} */\n const res = {\n closerPeers: peers\n }\n\n if (rec && rec.value) {\n vals.push({\n val: rec.value,\n from: peer\n })\n\n queryResults++\n } else if (lookupErr) {\n vals.push({\n err: lookupErr,\n from: peer\n })\n\n queryResults++\n }\n\n // enough is enough\n if (queryResults >= pathSize) {\n res.pathComplete = true\n }\n\n return res\n }\n\n return disjointPathQuery\n }\n\n // we have peers, lets send the actual query to them\n const query = new Query(dht, key, createQuery)\n\n try {\n await pTimeout(query.run(rtp), options.timeout)\n } catch (err) {\n if (vals.length === 0) {\n throw err\n }\n } finally {\n query.stop()\n }\n\n return vals\n }\n }\n}\n","'use strict'\n\nconst { base58btc } = require('multiformats/bases/base58')\n\nconst utils = require('../utils')\nconst Run = require('./run')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {{from: PeerId, val: Uint8Array}} DHTQueryValue\n * @typedef {{from: PeerId, err: Error}} DHTQueryError\n * @typedef {DHTQueryValue | DHTQueryError} DHTQueryResult\n * @typedef {import('../').PeerData} PeerData\n *\n * @typedef {{ pathComplete?: boolean, queryComplete?: boolean, closerPeers?: PeerData[], peer?: PeerData, success?: boolean }} QueryResult\n */\n\n/**\n * User-supplied function to set up an individual disjoint path. Per-path\n * query state should be held in this function's closure.\n *\n * Accepts the numeric index from zero to numPaths - 1 and returns a function\n * to call on each peer in the query.\n *\n * @typedef {(pathIndex: number, numPaths: number) => QueryFunc } MakeQueryFunc\n */\n\n/**\n * Query function\n *\n * @typedef {(peer: PeerId) => Promise } QueryFunc\n */\n\n/**\n * Divide peers up into disjoint paths (subqueries). Any peer can only be used once over all paths.\n * Within each path, query peers from closest to farthest away.\n */\nclass Query {\n /**\n * Create a new query. The makePath function is called once per disjoint path, so that per-path\n * variables can be created in that scope. makePath then returns the actual query function (queryFunc) to\n * use when on that path.\n *\n * @param {import('../index')} dht - DHT instance\n * @param {Uint8Array} key\n * @param {MakeQueryFunc} makePath - Called to set up each disjoint path. Must return the query function.\n */\n constructor (dht, key, makePath) {\n this.dht = dht\n this.key = key\n this.makePath = makePath\n this._log = utils.logger(this.dht.peerId, 'query:' + base58btc.baseEncode(key))\n\n this.running = false\n\n this._onStart = this._onStart.bind(this)\n this._onComplete = this._onComplete.bind(this)\n }\n\n /**\n * Run this query, start with the given list of peers first.\n *\n * @param {PeerId[]} peers\n */\n async run (peers) { // eslint-disable-line require-await\n if (!this.dht._queryManager.running) {\n this._log.error('Attempt to run query after shutdown')\n return { finalSet: new Set(), paths: [] }\n }\n\n if (peers.length === 0) {\n this._log.error('Running query with no peers')\n return { finalSet: new Set(), paths: [] }\n }\n\n this._run = new Run(this)\n\n this._log(`query running with K=${this.dht.kBucketSize}, A=${this.dht.concurrency}, D=${Math.min(this.dht.disjointPaths, peers.length)}`)\n this._run.once('start', this._onStart)\n this._run.once('complete', this._onComplete)\n\n return this._run.execute(peers)\n }\n\n /**\n * Called when the run starts.\n */\n _onStart () {\n this.running = true\n this._startTime = Date.now()\n this._log('query:start')\n\n // Register this query so we can stop it if the DHT stops\n this.dht._queryManager.queryStarted(this)\n }\n\n /**\n * Called when the run completes (even if there's an error).\n */\n _onComplete () {\n // Ensure worker queues for all paths are stopped at the end of the query\n this.stop()\n }\n\n /**\n * Stop the query.\n */\n stop () {\n this._log(`query:done in ${Date.now() - (this._startTime || 0)}ms`)\n\n if (this._run) {\n this._log(`${this._run.errors.length} of ${this._run.peersSeen.size} peers errored (${this._run.errors.length / this._run.peersSeen.size * 100}% fail rate)`)\n }\n\n if (!this.running) {\n return\n }\n\n this.running = false\n\n if (this._run) {\n this._run.removeListener('start', this._onStart)\n this._run.removeListener('complete', this._onComplete)\n this._run.stop()\n }\n\n this.dht._queryManager.queryCompleted(this)\n }\n}\n\nmodule.exports = Query\n","'use strict'\n\nconst PeerDistanceList = require('../peer-list/peer-distance-list')\nconst EventEmitter = require('events')\n\nconst Path = require('./path')\nconst WorkerQueue = require('./worker-queue')\nconst utils = require('../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * Manages a single run of the query.\n */\nclass Run extends EventEmitter {\n /**\n * Creates a Run.\n *\n * @param {import('./index')} query\n */\n constructor (query) {\n super()\n\n this.query = query\n\n this.running = false\n\n /** @type {WorkerQueue[]} */\n this.workers = []\n\n // The peers that have been queried (including error responses)\n this.peersSeen = new Set()\n\n // The errors received when querying peers\n /** @type {Error[]} */\n this.errors = []\n\n // The closest K peers that have been queried successfully\n // (this member is initialized when the worker queues start)\n /** @type {PeerDistanceList | null} */\n this.peersQueried = null\n }\n\n /**\n * Stop all the workers\n */\n stop () {\n if (!this.running) {\n return\n }\n\n this.running = false\n for (const worker of this.workers) {\n worker.stop()\n }\n }\n\n /**\n * Execute the run with the given initial set of peers.\n *\n * @param {PeerId[]} peers\n */\n async execute (peers) {\n /** @type {import('./path')[]} */\n const paths = [] // array of states per disjoint path\n\n // Create disjoint paths\n const numPaths = Math.min(this.query.dht.disjointPaths, peers.length)\n for (let i = 0; i < numPaths; i++) {\n paths.push(new Path(this, this.query.makePath(i, numPaths)))\n }\n\n // Assign peers to paths round-robin style\n peers.forEach((peer, i) => {\n paths[i % numPaths].addInitialPeer(peer)\n })\n\n // Execute the query along each disjoint path\n await this.executePaths(paths)\n\n const res = {\n // The closest K peers we were able to query successfully\n finalSet: new Set(this.peersQueried && this.peersQueried.peers),\n\n /** @type {import('./index').QueryResult[]} */\n paths: []\n }\n\n // Collect the results from each completed path\n for (const path of paths) {\n if (path.res && (path.res.pathComplete || path.res.queryComplete)) {\n path.res.success = true\n res.paths.push(path.res)\n }\n }\n\n return res\n }\n\n /**\n * Execute all paths through the DHT.\n *\n * @param {Array} paths\n * @returns {Promise}\n */\n async executePaths (paths) {\n this.running = true\n\n this.emit('start')\n try {\n await Promise.all(paths.map(path => path.execute()))\n } finally {\n // Ensure all workers are stopped\n this.stop()\n // Completed the Run\n this.emit('complete')\n }\n\n // If all queries errored out, something is seriously wrong, so callback\n // with an error\n if (this.errors.length === this.peersSeen.size) {\n throw this.errors[0]\n }\n }\n\n /**\n * Initialize the list of queried peers, then start a worker queue for the\n * given path.\n *\n * @param {Path} path\n * @returns {Promise}\n */\n async workerQueue (path) {\n await this.init()\n await this.startWorker(path)\n }\n\n /**\n * Create and start a worker queue for a particular path.\n *\n * @param {Path} path\n * @returns {Promise}\n */\n async startWorker (path) {\n const worker = new WorkerQueue(this.query.dht, this, path, this.query._log)\n this.workers.push(worker)\n await worker.execute()\n }\n\n /**\n * Initialize the list of closest peers we've queried - this is shared by all\n * paths in the run.\n *\n * @returns {Promise}\n */\n async init () {\n if (this.peersQueried) {\n return\n }\n\n // We only want to initialize the PeerDistanceList once for the run\n if (this.peersQueriedPromise) {\n await this.peersQueriedPromise\n return\n }\n\n // This promise is temporarily stored so that others may await its completion\n this.peersQueriedPromise = (async () => {\n const dhtKey = await utils.convertBuffer(this.query.key)\n this.peersQueried = new PeerDistanceList(dhtKey, this.query.dht.kBucketSize)\n })()\n\n // After PeerDistanceList is initialized, clean up\n await this.peersQueriedPromise\n delete this.peersQueriedPromise\n }\n\n /**\n * If we've queried K peers, and the remaining peers in the given `worker`'s queue\n * are all further from the key than the peers we've already queried, then we should\n * stop querying on that `worker`.\n *\n * @param {WorkerQueue} worker\n * @returns {Promise}\n */\n async continueQuerying (worker) {\n // If we haven't queried K peers yet, keep going\n if (this.peersQueried && this.peersQueried.length < this.peersQueried.capacity) {\n return true\n }\n\n // Get all the peers that are currently being queried.\n // Note that this function gets called right after a peer has been popped\n // off the head of the closest peers queue so it will include that peer.\n const running = Array.from(worker.queuedPeerIds)\n\n // Check if any of the peers that are currently being queried are closer\n // to the key than the peers we've already queried\n const someCloser = this.peersQueried && await this.peersQueried.anyCloser(running)\n\n // Some are closer, the worker should keep going\n if (someCloser) {\n return true\n }\n\n // None are closer, the worker can stop\n return false\n }\n}\n\nmodule.exports = Run\n","'use strict'\n\nconst utils = require('../utils')\nconst pMap = require('p-map')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { compare: uint8ArrayCompare } = require('uint8arrays/compare')\nconst { xor: uint8ArrayXor } = require('uint8arrays/xor')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../').PeerData} PeerData\n */\n\n/**\n * Maintains a list of peerIds sorted by distance from a DHT key.\n */\nclass PeerDistanceList {\n /**\n * Creates a new PeerDistanceList.\n *\n * @param {Uint8Array} originDhtKey - the DHT key from which distance is calculated\n * @param {number} capacity - the maximum size of the list\n */\n constructor (originDhtKey, capacity) {\n this.originDhtKey = originDhtKey\n this.capacity = capacity\n\n /** @type {{ peerId: PeerId, distance: Uint8Array }[]} */\n this.peerDistances = []\n }\n\n /**\n * The length of the list\n */\n get length () {\n return this.peerDistances.length\n }\n\n /**\n * The peerIds in the list, in order of distance from the origin key\n */\n get peers () {\n return this.peerDistances.map(pd => pd.peerId)\n }\n\n /**\n * Add a peerId to the list.\n *\n * @param {PeerId} peerId\n */\n async add (peerId) {\n if (this.peerDistances.find(pd => uint8ArrayEquals(pd.peerId.id, peerId.id))) {\n return\n }\n\n const dhtKey = await utils.convertPeerId(peerId)\n const el = {\n peerId,\n distance: uint8ArrayXor(this.originDhtKey, dhtKey)\n }\n\n this.peerDistances.push(el)\n this.peerDistances.sort((a, b) => uint8ArrayCompare(a.distance, b.distance))\n this.peerDistances = this.peerDistances.slice(0, this.capacity)\n }\n\n /**\n * Indicates whether any of the peerIds passed as a parameter are closer\n * to the origin key than the furthest peerId in the PeerDistanceList.\n *\n * @param {PeerId[]} peerIds\n */\n async anyCloser (peerIds) {\n if (!peerIds.length) {\n return false\n }\n\n if (!this.length) {\n return true\n }\n\n const dhtKeys = await pMap(peerIds, (peerId) => utils.convertPeerId(peerId))\n const furthestDistance = this.peerDistances[this.peerDistances.length - 1].distance\n\n for (const dhtKey of dhtKeys) {\n const keyDistance = uint8ArrayXor(this.originDhtKey, dhtKey)\n\n if (uint8ArrayCompare(keyDistance, furthestDistance) < 0) {\n return true\n }\n }\n\n return false\n }\n}\n\nmodule.exports = PeerDistanceList\n","'use strict'\n\nconst PeerQueue = require('../peer-list/peer-queue')\nconst utils = require('../utils')\n\n// TODO: Temporary until parallel dial in Switch have a proper\n// timeout. Requires async/await refactor of transports and\n// dial abort logic. This gives us 30s to complete the `queryFunc`.\n// This should help reduce the high end call times of queries\nconst QUERY_FUNC_TIMEOUT = 30e3\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * Manages a single Path through the DHT.\n */\nclass Path {\n /**\n * Creates a Path.\n *\n * @param {import('./run')} run\n * @param {import('./index').QueryFunc} queryFunc\n */\n constructor (run, queryFunc) {\n this.run = run\n this.queryFunc = utils.withTimeout(queryFunc, QUERY_FUNC_TIMEOUT)\n if (!this.queryFunc) throw new Error('Path requires a `queryFn` to be specified')\n if (typeof this.queryFunc !== 'function') throw new Error('Path expected `queryFn` to be a function. Got ' + typeof this.queryFunc)\n\n /** @type {PeerId[]} */\n this.initialPeers = []\n\n /** @type {PeerQueue | null} */\n this.peersToQuery = null\n\n /** @type {import('./index').QueryResult | null} */\n this.res = null\n }\n\n /**\n * Add a peer to the set of peers that are used to intialize the path.\n *\n * @param {PeerId} peer\n */\n addInitialPeer (peer) {\n this.initialPeers.push(peer)\n }\n\n /**\n * Execute the path\n */\n async execute () {\n // Create a queue of peers ordered by distance from the key\n const queue = await PeerQueue.fromKey(this.run.query.key)\n // Add initial peers to the queue\n this.peersToQuery = queue\n await Promise.all(this.initialPeers.map(peer => this.addPeerToQuery(peer)))\n await this.run.workerQueue(this)\n }\n\n /**\n * Add a peer to the peers to be queried.\n *\n * @param {PeerId} peer\n */\n async addPeerToQuery (peer) {\n // Don't add self\n if (this.run.query.dht._isSelf(peer)) {\n return\n }\n\n // The paths must be disjoint, meaning that no two paths in the Query may\n // traverse the same peer\n if (this.run.peersSeen.has(peer.toB58String())) {\n return\n }\n\n if (this.peersToQuery) {\n await this.peersToQuery.enqueue(peer)\n }\n }\n}\n\nmodule.exports = Path\n","'use strict'\n\n// @ts-ignore\nconst Heap = require('heap')\nconst { xor: uint8ArrayXor } = require('uint8arrays/xor')\nconst debug = require('debug')\n\nconst utils = require('../utils')\n\nconst log = debug('libp2p:dht:peer-queue')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * PeerQueue is a heap that sorts its entries (PeerIds) by their\n * xor distance to the inital provided key.\n */\nclass PeerQueue {\n /**\n * Create from a given peer id.\n *\n * @param {PeerId} id\n * @returns {Promise}\n */\n static async fromPeerId (id) {\n const key = await utils.convertPeerId(id)\n\n return new PeerQueue(key)\n }\n\n /**\n * Create from a given Uint8Array.\n *\n * @param {Uint8Array} keyBuffer\n * @returns {Promise}\n */\n static async fromKey (keyBuffer) {\n const key = await utils.convertBuffer(keyBuffer)\n\n return new PeerQueue(key)\n }\n\n /**\n * Create a new PeerQueue.\n *\n * @param {Uint8Array} from - The sha2-256 encoded peer id\n */\n constructor (from) {\n log('create: %b', from)\n this.from = from\n this.heap = new Heap(utils.xorCompare)\n }\n\n /**\n * Add a new PeerId to the queue.\n *\n * @param {PeerId} id\n */\n async enqueue (id) {\n log('enqueue %s', id.toB58String())\n const key = await utils.convertPeerId(id)\n\n const el = {\n id: id,\n distance: uint8ArrayXor(this.from, key)\n }\n\n this.heap.push(el)\n }\n\n /**\n * Returns the closest peer to the `from` peer.\n *\n * @returns {PeerId}\n */\n dequeue () {\n const el = this.heap.pop()\n log('dequeue %s', el.id.toB58String())\n return el.id\n }\n\n get length () {\n return this.heap.size()\n }\n}\n\nmodule.exports = PeerQueue\n","module.exports = require('./lib/heap');\n","// Generated by CoffeeScript 1.8.0\n(function() {\n var Heap, defaultCmp, floor, heapify, heappop, heappush, heappushpop, heapreplace, insort, min, nlargest, nsmallest, updateItem, _siftdown, _siftup;\n\n floor = Math.floor, min = Math.min;\n\n\n /*\n Default comparison function to be used\n */\n\n defaultCmp = function(x, y) {\n if (x < y) {\n return -1;\n }\n if (x > y) {\n return 1;\n }\n return 0;\n };\n\n\n /*\n Insert item x in list a, and keep it sorted assuming a is sorted.\n \n If x is already in a, insert it to the right of the rightmost x.\n \n Optional args lo (default 0) and hi (default a.length) bound the slice\n of a to be searched.\n */\n\n insort = function(a, x, lo, hi, cmp) {\n var mid;\n if (lo == null) {\n lo = 0;\n }\n if (cmp == null) {\n cmp = defaultCmp;\n }\n if (lo < 0) {\n throw new Error('lo must be non-negative');\n }\n if (hi == null) {\n hi = a.length;\n }\n while (lo < hi) {\n mid = floor((lo + hi) / 2);\n if (cmp(x, a[mid]) < 0) {\n hi = mid;\n } else {\n lo = mid + 1;\n }\n }\n return ([].splice.apply(a, [lo, lo - lo].concat(x)), x);\n };\n\n\n /*\n Push item onto heap, maintaining the heap invariant.\n */\n\n heappush = function(array, item, cmp) {\n if (cmp == null) {\n cmp = defaultCmp;\n }\n array.push(item);\n return _siftdown(array, 0, array.length - 1, cmp);\n };\n\n\n /*\n Pop the smallest item off the heap, maintaining the heap invariant.\n */\n\n heappop = function(array, cmp) {\n var lastelt, returnitem;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n lastelt = array.pop();\n if (array.length) {\n returnitem = array[0];\n array[0] = lastelt;\n _siftup(array, 0, cmp);\n } else {\n returnitem = lastelt;\n }\n return returnitem;\n };\n\n\n /*\n Pop and return the current smallest value, and add the new item.\n \n This is more efficient than heappop() followed by heappush(), and can be\n more appropriate when using a fixed size heap. Note that the value\n returned may be larger than item! That constrains reasonable use of\n this routine unless written as part of a conditional replacement:\n if item > array[0]\n item = heapreplace(array, item)\n */\n\n heapreplace = function(array, item, cmp) {\n var returnitem;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n returnitem = array[0];\n array[0] = item;\n _siftup(array, 0, cmp);\n return returnitem;\n };\n\n\n /*\n Fast version of a heappush followed by a heappop.\n */\n\n heappushpop = function(array, item, cmp) {\n var _ref;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n if (array.length && cmp(array[0], item) < 0) {\n _ref = [array[0], item], item = _ref[0], array[0] = _ref[1];\n _siftup(array, 0, cmp);\n }\n return item;\n };\n\n\n /*\n Transform list into a heap, in-place, in O(array.length) time.\n */\n\n heapify = function(array, cmp) {\n var i, _i, _j, _len, _ref, _ref1, _results, _results1;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n _ref1 = (function() {\n _results1 = [];\n for (var _j = 0, _ref = floor(array.length / 2); 0 <= _ref ? _j < _ref : _j > _ref; 0 <= _ref ? _j++ : _j--){ _results1.push(_j); }\n return _results1;\n }).apply(this).reverse();\n _results = [];\n for (_i = 0, _len = _ref1.length; _i < _len; _i++) {\n i = _ref1[_i];\n _results.push(_siftup(array, i, cmp));\n }\n return _results;\n };\n\n\n /*\n Update the position of the given item in the heap.\n This function should be called every time the item is being modified.\n */\n\n updateItem = function(array, item, cmp) {\n var pos;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n pos = array.indexOf(item);\n if (pos === -1) {\n return;\n }\n _siftdown(array, 0, pos, cmp);\n return _siftup(array, pos, cmp);\n };\n\n\n /*\n Find the n largest elements in a dataset.\n */\n\n nlargest = function(array, n, cmp) {\n var elem, result, _i, _len, _ref;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n result = array.slice(0, n);\n if (!result.length) {\n return result;\n }\n heapify(result, cmp);\n _ref = array.slice(n);\n for (_i = 0, _len = _ref.length; _i < _len; _i++) {\n elem = _ref[_i];\n heappushpop(result, elem, cmp);\n }\n return result.sort(cmp).reverse();\n };\n\n\n /*\n Find the n smallest elements in a dataset.\n */\n\n nsmallest = function(array, n, cmp) {\n var elem, i, los, result, _i, _j, _len, _ref, _ref1, _results;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n if (n * 10 <= array.length) {\n result = array.slice(0, n).sort(cmp);\n if (!result.length) {\n return result;\n }\n los = result[result.length - 1];\n _ref = array.slice(n);\n for (_i = 0, _len = _ref.length; _i < _len; _i++) {\n elem = _ref[_i];\n if (cmp(elem, los) < 0) {\n insort(result, elem, 0, null, cmp);\n result.pop();\n los = result[result.length - 1];\n }\n }\n return result;\n }\n heapify(array, cmp);\n _results = [];\n for (i = _j = 0, _ref1 = min(n, array.length); 0 <= _ref1 ? _j < _ref1 : _j > _ref1; i = 0 <= _ref1 ? ++_j : --_j) {\n _results.push(heappop(array, cmp));\n }\n return _results;\n };\n\n _siftdown = function(array, startpos, pos, cmp) {\n var newitem, parent, parentpos;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n newitem = array[pos];\n while (pos > startpos) {\n parentpos = (pos - 1) >> 1;\n parent = array[parentpos];\n if (cmp(newitem, parent) < 0) {\n array[pos] = parent;\n pos = parentpos;\n continue;\n }\n break;\n }\n return array[pos] = newitem;\n };\n\n _siftup = function(array, pos, cmp) {\n var childpos, endpos, newitem, rightpos, startpos;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n endpos = array.length;\n startpos = pos;\n newitem = array[pos];\n childpos = 2 * pos + 1;\n while (childpos < endpos) {\n rightpos = childpos + 1;\n if (rightpos < endpos && !(cmp(array[childpos], array[rightpos]) < 0)) {\n childpos = rightpos;\n }\n array[pos] = array[childpos];\n pos = childpos;\n childpos = 2 * pos + 1;\n }\n array[pos] = newitem;\n return _siftdown(array, startpos, pos, cmp);\n };\n\n Heap = (function() {\n Heap.push = heappush;\n\n Heap.pop = heappop;\n\n Heap.replace = heapreplace;\n\n Heap.pushpop = heappushpop;\n\n Heap.heapify = heapify;\n\n Heap.updateItem = updateItem;\n\n Heap.nlargest = nlargest;\n\n Heap.nsmallest = nsmallest;\n\n function Heap(cmp) {\n this.cmp = cmp != null ? cmp : defaultCmp;\n this.nodes = [];\n }\n\n Heap.prototype.push = function(x) {\n return heappush(this.nodes, x, this.cmp);\n };\n\n Heap.prototype.pop = function() {\n return heappop(this.nodes, this.cmp);\n };\n\n Heap.prototype.peek = function() {\n return this.nodes[0];\n };\n\n Heap.prototype.contains = function(x) {\n return this.nodes.indexOf(x) !== -1;\n };\n\n Heap.prototype.replace = function(x) {\n return heapreplace(this.nodes, x, this.cmp);\n };\n\n Heap.prototype.pushpop = function(x) {\n return heappushpop(this.nodes, x, this.cmp);\n };\n\n Heap.prototype.heapify = function() {\n return heapify(this.nodes, this.cmp);\n };\n\n Heap.prototype.updateItem = function(x) {\n return updateItem(this.nodes, x, this.cmp);\n };\n\n Heap.prototype.clear = function() {\n return this.nodes = [];\n };\n\n Heap.prototype.empty = function() {\n return this.nodes.length === 0;\n };\n\n Heap.prototype.size = function() {\n return this.nodes.length;\n };\n\n Heap.prototype.clone = function() {\n var heap;\n heap = new Heap();\n heap.nodes = this.nodes.slice(0);\n return heap;\n };\n\n Heap.prototype.toArray = function() {\n return this.nodes.slice(0);\n };\n\n Heap.prototype.insert = Heap.prototype.push;\n\n Heap.prototype.top = Heap.prototype.peek;\n\n Heap.prototype.front = Heap.prototype.peek;\n\n Heap.prototype.has = Heap.prototype.contains;\n\n Heap.prototype.copy = Heap.prototype.clone;\n\n return Heap;\n\n })();\n\n (function(root, factory) {\n if (typeof define === 'function' && define.amd) {\n return define([], factory);\n } else if (typeof exports === 'object') {\n return module.exports = factory();\n } else {\n return root.Heap = factory();\n }\n })(this, function() {\n return Heap;\n });\n\n}).call(this);\n","'use strict'\n\nconst { default: Queue } = require('p-queue')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\nclass WorkerQueue {\n /**\n * Creates a new WorkerQueue.\n *\n * @param {import('../index')} dht\n * @param {import('./run')} run\n * @param {import('./path')} path\n * @param {Function & {error: Function}} log\n */\n constructor (dht, run, path, log) {\n this.dht = dht\n this.run = run\n this.path = path\n this.log = log\n\n this.concurrency = this.dht.concurrency\n this.queue = this.setupQueue()\n // a container for resolve/reject functions that will be populated\n // when execute() is called\n\n /** @type {{ resolve: (result?: any) => void, reject: (err: Error) => void} | null} */\n this.execution = null\n\n /** @type {Set} */\n this.queuedPeerIds = new Set()\n }\n\n /**\n * Create the underlying async queue.\n *\n * @returns {Queue}\n */\n setupQueue () {\n const q = new Queue({\n concurrency: this.concurrency\n })\n\n // When all peers in the queue have been processed, stop the worker\n q.on('idle', () => {\n if (this.path.peersToQuery && !this.path.peersToQuery.length) {\n this.log('queue:drain')\n this.stop()\n }\n })\n\n // When a space opens up in the queue, add some more peers\n q.on('next', () => {\n if (!this.running) {\n return\n }\n\n if (q.pending < this.concurrency) {\n this.fill()\n }\n })\n\n return q\n }\n\n /**\n * Stop the worker, optionally providing an error to pass to the worker's\n * callback.\n *\n * @param {Error} [err]\n */\n stop (err) {\n if (!this.running) {\n return\n }\n\n this.running = false\n this.queue.clear()\n this.log('worker:stop, %d workers still running', this.run.workers.filter(w => w.running).length)\n\n if (this.execution) {\n if (err) {\n this.execution.reject(err)\n } else {\n this.execution.resolve()\n }\n }\n }\n\n /**\n * Use the queue from async to keep `concurrency` amount items running\n * per path.\n *\n * @returns {Promise}\n */\n async execute () {\n this.running = true\n // store the promise resolution functions to be resolved at end of queue\n this.execution = null\n const execPromise = new Promise((resolve, reject) => {\n this.execution = {\n resolve, reject\n }\n })\n // start queue\n this.fill()\n // await completion\n await execPromise\n }\n\n /**\n * Add peers to the worker queue until there are enough to satisfy the\n * worker queue concurrency.\n * Note that we don't want to take any more than those required to satisfy\n * concurrency from the peers-to-query queue, because we always want to\n * query the closest peers to the key first, and new peers are continuously\n * being added to the peers-to-query queue.\n */\n fill () {\n if (!this.path.peersToQuery) {\n return\n }\n\n // Note:\n // - queue.pending: number of items that are currently running\n // - queue.size: the number of items that are waiting to be run\n while (this.queue.pending + this.queue.size < this.concurrency && this.path.peersToQuery.length > 0) {\n const peer = this.path.peersToQuery.dequeue()\n\n // store the peer id so we can potentially abort early\n this.queuedPeerIds.add(peer)\n\n this.queue.add(\n () => {\n return this.processNext(peer)\n .catch(err => {\n this.log.error('queue', err)\n this.stop(err)\n })\n .finally(() => {\n this.queuedPeerIds.delete(peer)\n })\n }\n )\n }\n }\n\n /**\n * Process the next peer in the queue\n *\n * @param {PeerId} peer\n */\n async processNext (peer) {\n if (!this.running) {\n return\n }\n\n // The paths must be disjoint, meaning that no two paths in the Query may\n // traverse the same peer\n if (this.run.peersSeen.has(peer.toB58String())) {\n return\n }\n\n // Check if we've queried enough peers already\n let continueQuerying, continueQueryingError\n try {\n continueQuerying = await this.run.continueQuerying(this)\n } catch (err) {\n continueQueryingError = err\n }\n\n // Abort and ignore any error if we're no longer running\n if (!this.running) {\n return\n }\n\n if (continueQueryingError) {\n throw continueQueryingError\n }\n\n // No peer we're querying is closer, stop the queue\n // This will cause queries that may potentially result in\n // closer nodes to be ended, but it reduces overall query time\n if (!continueQuerying) {\n this.stop()\n return\n }\n\n // Check if another path has queried this peer in the mean time\n if (this.run.peersSeen.has(peer.toB58String())) {\n return\n }\n this.run.peersSeen.add(peer.toB58String())\n\n // Execute the query on the next peer\n this.log('queue:work')\n let state, execError\n try {\n state = await this.execQuery(peer)\n } catch (err) {\n execError = err\n }\n\n // Abort and ignore any error if we're no longer running\n if (!this.running) {\n return\n }\n\n this.log('queue:work:done', execError, state)\n\n if (execError) {\n throw execError\n }\n\n // If query is complete, stop all workers.\n // Note: run.stop() calls stop() on all the workers, which kills the\n // queue and resolves execution\n if (state && state.queryComplete) {\n this.log('query:complete')\n this.run.stop()\n return\n }\n\n // If path is complete, just stop this worker.\n // Note: this.stop() kills the queue and resolves execution\n if (state && state.pathComplete) {\n this.stop()\n }\n }\n\n /**\n * Execute a query on the next peer.\n *\n * @param {PeerId} peer\n */\n async execQuery (peer) {\n let res, queryError\n try {\n res = await this.path.queryFunc(peer)\n } catch (err) {\n queryError = err\n }\n\n // Abort and ignore any error if we're no longer running\n if (!this.running) {\n return\n }\n\n if (queryError) {\n this.run.errors.push(queryError)\n return\n }\n\n // Add the peer to the closest peers we have successfully queried\n this.run.peersQueried && await this.run.peersQueried.add(peer)\n\n if (!res) {\n return\n }\n\n // If the query indicates that this path or the whole query is complete\n // set the path result and bail out\n if (res.pathComplete || res.queryComplete) {\n this.path.res = res\n\n return {\n pathComplete: res.pathComplete,\n queryComplete: res.queryComplete\n }\n }\n\n // If there are closer peers to query, add them to the queue\n if (res.closerPeers && res.closerPeers.length > 0) {\n /**\n * @param {import('../').PeerData} closer\n */\n const queryCloser = async (closer) => {\n // don't add ourselves\n if (this.dht._isSelf(closer.id)) {\n return\n }\n\n this.dht._peerDiscovered(closer.id, closer.multiaddrs)\n await this.path.addPeerToQuery(closer.id)\n }\n\n await Promise.all(res.closerPeers.map(queryCloser))\n }\n }\n}\n\nmodule.exports = WorkerQueue\n","'use strict'\n\nconst errcode = require('err-code')\nconst pTimeout = require('p-timeout')\n\nconst c = require('../constants')\nconst LimitedPeerList = require('../peer-list/limited-peer-list')\nconst Message = require('../message')\nconst Query = require('../query')\nconst utils = require('../utils')\n\n/**\n * @typedef {import('multiformats/cid').CID} CID\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @param {import('../')} dht\n */\nmodule.exports = (dht) => {\n /**\n * Check for providers from a single node.\n *\n * @param {PeerId} peer\n * @param {CID} key\n *\n * @private\n */\n const findProvidersSingle = async (peer, key) => { // eslint-disable-line require-await\n const msg = new Message(Message.TYPES.GET_PROVIDERS, key.bytes, 0)\n return dht.network.sendRequest(peer, msg)\n }\n\n return {\n /**\n * Announce to the network that we can provide the value for a given key\n *\n * @param {CID} key\n */\n async provide (key) {\n dht._log(`provide: ${key}`)\n\n /** @type {Error[]} */\n const errors = []\n\n // Add peer as provider\n await dht.providers.addProvider(key, dht.peerId)\n\n const multiaddrs = dht.libp2p ? dht.libp2p.multiaddrs : []\n const msg = new Message(Message.TYPES.ADD_PROVIDER, key.bytes, 0)\n msg.providerPeers = [{\n id: dht.peerId,\n multiaddrs\n }]\n\n /**\n * @param {PeerId} peer\n */\n async function mapPeer (peer) {\n dht._log(`putProvider ${key} to ${peer.toB58String()}`)\n try {\n await dht.network.sendMessage(peer, msg)\n } catch (err) {\n errors.push(err)\n }\n }\n\n // Notify closest peers\n await utils.mapParallel(dht.getClosestPeers(key.bytes), mapPeer)\n\n if (errors.length) {\n // TODO:\n // This should be infrequent. This means a peer we previously connected\n // to failed to exchange the provide message. If getClosestPeers was an\n // iterator, we could continue to pull until we announce to kBucketSize peers.\n throw errcode(new Error(`Failed to provide to ${errors.length} of ${dht.kBucketSize} peers`), 'ERR_SOME_PROVIDES_FAILED', { errors })\n }\n },\n\n /**\n * Search the dht for up to `K` providers of the given CID.\n *\n * @param {CID} key\n * @param {Object} [options] - findProviders options\n * @param {number} [options.timeout=60000] - how long the query should maximally run, in milliseconds\n * @param {number} [options.maxNumProviders=5] - maximum number of providers to find\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * findProviders (key, options = { timeout: 60000, maxNumProviders: 5 }) {\n const providerTimeout = options.timeout || c.minute\n const n = options.maxNumProviders || c.K\n\n dht._log(`findProviders ${key}`)\n\n const out = new LimitedPeerList(n)\n const provs = await dht.providers.getProviders(key)\n\n provs\n .forEach(id => {\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peerData = dht.peerStore.get(id)\n\n if (peerData) {\n out.push({\n id: peerData.id,\n multiaddrs: peerData.addresses\n .map((address) => address.multiaddr)\n })\n } else {\n out.push({\n id,\n multiaddrs: []\n })\n }\n })\n\n // All done\n if (out.length >= n) {\n // yield values\n for (const pData of out.toArray()) {\n yield pData\n }\n return\n }\n\n // need more, query the network\n /** @type {LimitedPeerList[]} */\n const paths = []\n\n /**\n *\n * @param {number} pathIndex\n * @param {number} numPaths\n */\n function makePath (pathIndex, numPaths) {\n // This function body runs once per disjoint path\n const pathSize = utils.pathSize(n - out.length, numPaths)\n const pathProviders = new LimitedPeerList(pathSize)\n paths.push(pathProviders)\n\n /**\n * The query function to use on this particular disjoint path\n *\n * @param {PeerId} peer\n */\n async function queryDisjointPath (peer) {\n const msg = await findProvidersSingle(peer, key)\n const provs = msg.providerPeers\n dht._log(`Found ${provs.length} provider entries for ${key}`)\n\n provs.forEach((prov) => {\n pathProviders.push({\n ...prov\n })\n })\n\n // hooray we have all that we want\n if (pathProviders.length >= pathSize) {\n return { pathComplete: true }\n }\n\n // it looks like we want some more\n return { closerPeers: msg.closerPeers }\n }\n\n return queryDisjointPath\n }\n\n const query = new Query(dht, key.bytes, makePath)\n const peers = dht.routingTable.closestPeers(key.bytes, dht.kBucketSize)\n\n try {\n await pTimeout(\n query.run(peers),\n providerTimeout\n )\n } catch (err) {\n if (err.name !== pTimeout.TimeoutError.name) {\n throw err\n }\n } finally {\n query.stop()\n }\n\n // combine peers from each path\n paths.forEach((path) => {\n path.toArray().forEach((peer) => {\n out.push(peer)\n })\n })\n\n for (const pData of out.toArray()) {\n yield pData\n }\n }\n }\n}\n","'use strict'\n\nconst PeerList = require('.')\n\n/**\n * @typedef {import('../').PeerData} PeerData\n */\n\n/**\n * Like PeerList but with a length restriction.\n */\nclass LimitedPeerList extends PeerList {\n /**\n * Create a new limited peer list.\n *\n * @param {number} limit\n */\n constructor (limit) {\n super()\n this.limit = limit\n }\n\n /**\n * Add a PeerData if it fits in the list\n *\n * @param {PeerData} peerData\n */\n push (peerData) {\n if (this.length < this.limit) {\n return super.push(peerData)\n }\n\n return false\n }\n}\n\nmodule.exports = LimitedPeerList\n","'use strict'\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../').PeerData} PeerData\n */\n\n/**\n * A list of unique peers.\n */\nclass PeerList {\n constructor () {\n /** @type {PeerData[]} */\n this.list = []\n }\n\n /**\n * Add a new peer. Returns `true` if it was a new one\n *\n * @param {PeerData} peerData\n */\n push (peerData) {\n if (!this.has(peerData.id)) {\n this.list.push(peerData)\n\n return true\n }\n\n return false\n }\n\n /**\n * Check if this PeerData is already in here.\n *\n * @param {PeerId} peerId\n */\n has (peerId) {\n const match = this.list.find((i) => i.id.equals(peerId))\n return Boolean(match)\n }\n\n /**\n * Get the list as an array.\n */\n toArray () {\n return this.list.slice()\n }\n\n /**\n * Remove the last element\n */\n pop () {\n return this.list.pop()\n }\n\n /**\n * The length of the list\n */\n get length () {\n return this.list.length\n }\n}\n\nmodule.exports = PeerList\n","'use strict'\n\nconst errcode = require('err-code')\nconst pTimeout = require('p-timeout')\n\nconst PeerId = require('peer-id')\nconst crypto = require('libp2p-crypto')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst c = require('../constants')\nconst Message = require('../message')\nconst Query = require('../query')\n\nconst utils = require('../utils')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @param {import('../index')} dht\n */\nmodule.exports = (dht) => {\n /**\n * Look if we are connected to a peer with the given id.\n * Returns its id and addresses, if found, otherwise `undefined`.\n *\n * @param {PeerId} peer\n */\n const findPeerLocal = async (peer) => {\n dht._log(`findPeerLocal ${peer.toB58String()}`)\n const p = await dht.routingTable.find(peer)\n\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peerData = p && dht.peerStore.get(p)\n\n if (peerData) {\n return {\n id: peerData.id,\n multiaddrs: peerData.addresses.map((address) => address.multiaddr)\n }\n }\n }\n\n /**\n * Get a value via rpc call for the given parameters.\n *\n * @param {PeerId} peer\n * @param {Uint8Array} key\n * @returns {Promise}\n * @private\n */\n const getValueSingle = async (peer, key) => { // eslint-disable-line require-await\n const msg = new Message(Message.TYPES.GET_VALUE, key, 0)\n return dht.network.sendRequest(peer, msg)\n }\n\n /**\n * Find close peers for a given peer\n *\n * @param {Uint8Array} key\n * @param {PeerId} peer\n * @returns {Promise>}\n * @private\n */\n\n const closerPeersSingle = async (key, peer) => {\n dht._log(`closerPeersSingle ${uint8ArrayToString(key, 'base32')} from ${peer.toB58String()}`)\n const msg = await dht.peerRouting._findPeerSingle(peer, new PeerId(key))\n\n return msg.closerPeers\n .filter((peerData) => !dht._isSelf(peerData.id))\n .map((peerData) => {\n dht.peerStore.addressBook.add(peerData.id, peerData.multiaddrs)\n\n return peerData\n })\n }\n\n /**\n * Get the public key directly from a node.\n *\n * @param {PeerId} peer\n */\n const getPublicKeyFromNode = async (peer) => {\n const pkKey = utils.keyForPublicKey(peer)\n const msg = await getValueSingle(peer, pkKey)\n\n if (!msg.record || !msg.record.value) {\n throw errcode(new Error(`Node not responding with its public key: ${peer.toB58String()}`), 'ERR_INVALID_RECORD')\n }\n\n const recPeer = await PeerId.createFromPubKey(msg.record.value)\n\n // compare hashes of the pub key\n if (!recPeer.equals(peer)) {\n throw errcode(new Error('public key does not match id'), 'ERR_PUBLIC_KEY_DOES_NOT_MATCH_ID')\n }\n\n return recPeer.pubKey\n }\n\n return {\n /**\n * Ask peer `peer` if they know where the peer with id `target` is.\n *\n * @param {PeerId} peer\n * @param {PeerId} target\n * @returns {Promise}\n * @private\n */\n async _findPeerSingle (peer, target) { // eslint-disable-line require-await\n dht._log('findPeerSingle %s', peer.toB58String())\n const msg = new Message(Message.TYPES.FIND_NODE, target.id, 0)\n\n return dht.network.sendRequest(peer, msg)\n },\n\n /**\n * Search for a peer with the given ID.\n *\n * @param {PeerId} id\n * @param {Object} [options] - findPeer options\n * @param {number} [options.timeout=60000] - how long the query should maximally run, in milliseconds\n * @returns {Promise<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async findPeer (id, options = { timeout: 60000 }) {\n options.timeout = options.timeout || c.minute\n dht._log('findPeer %s', id.toB58String())\n\n // Try to find locally\n const pi = await findPeerLocal(id)\n\n // already got it\n if (pi != null) {\n dht._log('found local')\n return pi\n }\n\n const key = await utils.convertPeerId(id)\n const peers = dht.routingTable.closestPeers(key, dht.kBucketSize)\n\n if (peers.length === 0) {\n throw errcode(new Error('Peer lookup failed'), 'ERR_LOOKUP_FAILED')\n }\n\n // sanity check\n const match = peers.find((p) => p.isEqual(id))\n if (match) {\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peer = dht.peerStore.get(id)\n\n if (peer) {\n dht._log('found in peerStore')\n return {\n id: peer.id,\n multiaddrs: peer.addresses.map((address) => address.multiaddr)\n }\n }\n }\n\n // query the network\n const query = new Query(dht, id.id, () => {\n /**\n * There is no distinction between the disjoint paths, so there are no per-path\n * variables in dht scope. Just return the actual query function.\n *\n * @param {PeerId} peer\n */\n const queryFn = async (peer) => {\n const msg = await this._findPeerSingle(peer, id)\n const match = msg.closerPeers.find((p) => p.id.isEqual(id))\n\n // found it\n if (match) {\n return {\n peer: match,\n queryComplete: true\n }\n }\n\n return {\n closerPeers: msg.closerPeers\n }\n }\n\n return queryFn\n })\n\n let result\n try {\n result = await pTimeout(query.run(peers), options.timeout)\n } finally {\n query.stop()\n }\n\n let success = false\n result.paths.forEach((result) => {\n if (result.success && result.peer) {\n success = true\n dht.peerStore.addressBook.add(result.peer.id, result.peer.multiaddrs)\n }\n })\n dht._log('findPeer %s: %s', id.toB58String(), success)\n\n if (!success) {\n throw errcode(new Error('No peer found'), 'ERR_NOT_FOUND')\n }\n\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peerData = dht.peerStore.get(id)\n\n if (!peerData) {\n throw errcode(new Error('No peer found in peer store'), 'ERR_NOT_FOUND')\n }\n\n return {\n id: peerData.id,\n multiaddrs: peerData.addresses.map((address) => address.multiaddr)\n }\n },\n\n /**\n * Kademlia 'node lookup' operation.\n *\n * @param {Uint8Array} key\n * @param {Object} [options]\n * @param {boolean} [options.shallow=false] - shallow query\n * @returns {AsyncIterable}\n */\n async * getClosestPeers (key, options = { shallow: false }) {\n dht._log('getClosestPeers to %b', key)\n\n const id = await utils.convertBuffer(key)\n const tablePeers = dht.routingTable.closestPeers(id, dht.kBucketSize)\n\n const q = new Query(dht, key, () => {\n // There is no distinction between the disjoint paths,\n // so there are no per-path variables in dht scope.\n // Just return the actual query function.\n return async (peer) => {\n const closer = await closerPeersSingle(key, peer)\n\n return {\n closerPeers: closer,\n pathComplete: options.shallow ? true : undefined\n }\n }\n })\n\n const res = await q.run(tablePeers)\n if (!res || !res.finalSet) {\n return []\n }\n\n const sorted = await utils.sortClosestPeers(Array.from(res.finalSet), id)\n\n for (const pId of sorted.slice(0, dht.kBucketSize)) {\n yield pId\n }\n },\n\n /**\n * Get the public key for the given peer id.\n *\n * @param {PeerId} peer\n */\n async getPublicKey (peer) {\n dht._log('getPublicKey %s', peer.toB58String())\n\n // local check\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peerData = dht.peerStore.get(peer)\n\n if (peerData && peerData.id.pubKey) {\n dht._log('getPublicKey: found local copy')\n return peerData.id.pubKey\n }\n\n // try the node directly\n let pk\n\n try {\n pk = await getPublicKeyFromNode(peer)\n } catch (err) {\n // try dht directly\n const pkKey = utils.keyForPublicKey(peer)\n const value = await dht.get(pkKey)\n pk = crypto.keys.unmarshalPublicKey(value)\n }\n\n const peerId = new PeerId(peer.id, undefined, pk)\n const addrs = ((peerData && peerData.addresses) || []).map((address) => address.multiaddr)\n dht.peerStore.addressBook.add(peerId, addrs)\n dht.peerStore.keyBook.set(peerId, pk)\n\n return pk\n }\n }\n}\n","'use strict'\n\nconst cache = require('hashlru')\n// @ts-ignore\nconst varint = require('varint')\nconst PeerId = require('peer-id')\nconst { Key } = require('interface-datastore/key')\nconst { default: Queue } = require('p-queue')\nconst c = require('./constants')\nconst utils = require('./utils')\n\n/**\n * @typedef {import('multiformats/cid').CID} CID\n * @typedef {import('interface-datastore').Datastore} Datastore\n */\n\n/**\n * This class manages known providers.\n * A provider is a peer that we know to have the content for a given CID.\n *\n * Every `cleanupInterval` providers are checked if they\n * are still valid, i.e. younger than the `provideValidity`.\n * If they are not, they are deleted.\n *\n * To ensure the list survives restarts of the daemon,\n * providers are stored in the datastore, but to ensure\n * access is fast there is an LRU cache in front of that.\n */\nclass Providers {\n /**\n * @param {Datastore} datastore\n * @param {PeerId} [self]\n * @param {number} [cacheSize=256]\n */\n constructor (datastore, self, cacheSize) {\n this.datastore = datastore\n\n this._log = utils.logger(self, 'providers')\n\n /**\n * How often invalid records are cleaned. (in seconds)\n *\n * @type {number}\n */\n this.cleanupInterval = c.PROVIDERS_CLEANUP_INTERVAL\n\n /**\n * How long is a provider valid for. (in seconds)\n *\n * @type {number}\n */\n this.provideValidity = c.PROVIDERS_VALIDITY\n\n /**\n * LRU cache size\n *\n * @type {number}\n */\n this.lruCacheSize = cacheSize || c.PROVIDERS_LRU_CACHE_SIZE\n\n // @ts-ignore hashlru types are wrong\n this.providers = cache(this.lruCacheSize)\n\n this.syncQueue = new Queue({ concurrency: 1 })\n }\n\n /**\n * Start the provider cleanup service\n */\n start () {\n if (this._started) {\n return\n }\n\n this._started = true\n\n this._cleaner = setInterval(\n () => this._cleanup(),\n this.cleanupInterval\n )\n }\n\n /**\n * Release any resources.\n */\n stop () {\n this._started = false\n\n if (this._cleaner) {\n clearInterval(this._cleaner)\n this._cleaner = null\n }\n }\n\n /**\n * Check all providers if they are still valid, and if not delete them.\n *\n * @returns {Promise}\n * @private\n */\n _cleanup () {\n return this.syncQueue.add(async () => {\n this._log('start cleanup')\n const start = Date.now()\n\n let count = 0\n let deleteCount = 0\n const deleted = new Map()\n const batch = this.datastore.batch()\n\n // Get all provider entries from the datastore\n const query = this.datastore.query({ prefix: c.PROVIDERS_KEY_PREFIX })\n for await (const entry of query) {\n try {\n // Add a delete to the batch for each expired entry\n const { cid, peerId } = parseProviderKey(entry.key)\n const time = readTime(entry.value)\n const now = Date.now()\n const delta = now - time\n const expired = delta > this.provideValidity\n this._log('comparing: %d - %d = %d > %d %s',\n now, time, delta, this.provideValidity, expired ? '(expired)' : '')\n if (expired) {\n deleteCount++\n batch.delete(entry.key)\n const peers = deleted.get(cid) || new Set()\n peers.add(peerId)\n deleted.set(cid, peers)\n }\n count++\n } catch (err) {\n this._log.error(err.message)\n }\n }\n this._log('deleting %d / %d entries', deleteCount, count)\n\n // Commit the deletes to the datastore\n if (deleted.size) {\n await batch.commit()\n }\n\n // Clear expired entries from the cache\n for (const [cid, peers] of deleted) {\n const key = makeProviderKey(cid)\n const provs = this.providers.get(key)\n if (provs) {\n for (const peerId of peers) {\n provs.delete(peerId)\n }\n if (provs.size === 0) {\n this.providers.remove(key)\n } else {\n this.providers.set(key, provs)\n }\n }\n }\n\n this._log('Cleanup successful (%dms)', Date.now() - start)\n })\n }\n\n /**\n * Get the currently known provider peer ids for a given CID.\n *\n * @param {CID} cid\n * @returns {Promise>}\n *\n * @private\n */\n async _getProvidersMap (cid) {\n const cacheKey = makeProviderKey(cid)\n let provs = this.providers.get(cacheKey)\n if (!provs) {\n provs = await loadProviders(this.datastore, cid)\n this.providers.set(cacheKey, provs)\n }\n return provs\n }\n\n /**\n * Add a new provider for the given CID.\n *\n * @param {CID} cid\n * @param {PeerId} provider\n * @returns {Promise}\n */\n async addProvider (cid, provider) { // eslint-disable-line require-await\n return this.syncQueue.add(async () => {\n this._log('addProvider %s', cid.toString())\n const provs = await this._getProvidersMap(cid)\n\n this._log('loaded %s provs', provs.size)\n const now = new Date()\n provs.set(utils.encodeBase32(provider.id), now)\n\n const dsKey = makeProviderKey(cid)\n this.providers.set(dsKey, provs)\n return writeProviderEntry(this.datastore, cid, provider, now)\n })\n }\n\n /**\n * Get a list of providers for the given CID.\n *\n * @param {CID} cid\n * @returns {Promise>}\n */\n async getProviders (cid) { // eslint-disable-line require-await\n return this.syncQueue.add(async () => {\n this._log('getProviders %s', cid.toString())\n const provs = await this._getProvidersMap(cid)\n return [...provs.keys()].map((base32PeerId) => {\n return new PeerId(utils.decodeBase32(base32PeerId))\n })\n })\n }\n}\n\n/**\n * Encode the given key its matching datastore key.\n *\n * @param {CID|string} cid - cid or base32 encoded string\n * @returns {string}\n *\n * @private\n */\nfunction makeProviderKey (cid) {\n cid = typeof cid === 'string' ? cid : utils.encodeBase32(cid.bytes)\n return c.PROVIDERS_KEY_PREFIX + cid\n}\n\n/**\n * Write a provider into the given store.\n *\n * @param {Datastore} store\n * @param {CID} cid\n * @param {PeerId} peer\n * @param {Date} time\n */\nasync function writeProviderEntry (store, cid, peer, time) { // eslint-disable-line require-await\n const dsKey = [\n makeProviderKey(cid),\n '/',\n utils.encodeBase32(peer.id)\n ].join('')\n\n const key = new Key(dsKey)\n const buffer = Uint8Array.from(varint.encode(time.getTime()))\n return store.put(key, buffer)\n}\n\n/**\n * Parse the CID and provider peer id from the key\n *\n * @param {import('interface-datastore/key').Key} key\n */\nfunction parseProviderKey (key) {\n const parts = key.toString().split('/')\n if (parts.length !== 4) {\n throw new Error('incorrectly formatted provider entry key in datastore: ' + key)\n }\n\n return {\n cid: parts[2],\n peerId: parts[3]\n }\n}\n\n/**\n * Load providers for the given CID from the store.\n *\n * @param {Datastore} store\n * @param {CID} cid\n * @returns {Promise>}\n *\n * @private\n */\nasync function loadProviders (store, cid) {\n const providers = new Map()\n const query = store.query({ prefix: makeProviderKey(cid) })\n for await (const entry of query) {\n const { peerId } = parseProviderKey(entry.key)\n providers.set(peerId, readTime(entry.value))\n }\n return providers\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction readTime (buf) {\n return varint.decode(buf)\n}\n\nmodule.exports = Providers\n","'use strict'\n\n/**\n * @typedef {import('./query')} Query\n */\n\n/**\n * Keeps track of all running queries.\n */\nclass QueryManager {\n /**\n * Creates a new QueryManager.\n */\n constructor () {\n this.queries = new Set()\n this.running = false\n }\n\n /**\n * Called when a query is started.\n *\n * @param {Query} query\n */\n queryStarted (query) {\n this.queries.add(query)\n }\n\n /**\n * Called when a query completes.\n *\n * @param {Query} query\n */\n queryCompleted (query) {\n this.queries.delete(query)\n }\n\n /**\n * Starts the query manager.\n */\n start () {\n this.running = true\n }\n\n /**\n * Stops all queries.\n */\n stop () {\n this.running = false\n for (const query of this.queries) {\n query.stop()\n }\n this.queries.clear()\n }\n}\n\nmodule.exports = QueryManager\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipns = require('ipns');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\n\nconst validator = { func: (key, record) => ipns__namespace.validator.validate(record, key) };\nfunction selector(_k, records) {\n return ipns__namespace.validator.select(records[0], records[1]);\n}\n\nexports.selector = selector;\nexports.validator = validator;\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\nconst mafmt = require('mafmt')\nconst { EventEmitter } = require('events')\nconst debug = require('debug')\n\nconst log = Object.assign(debug('libp2p:bootstrap'), {\n error: debug('libp2p:bootstrap:error')\n})\n\n/**\n * Emits 'peer' events on a regular interval for each peer in the provided list.\n */\nclass Bootstrap extends EventEmitter {\n /**\n * Constructs a new Bootstrap.\n *\n * @param {Object} options\n * @param {Array} options.list - the list of peer addresses in multi-address format\n * @param {number} [options.interval = 10000] - the interval between emitting addresses in milliseconds\n *\n */\n constructor (options = { list: [] }) {\n if (!options.list || !options.list.length) {\n throw new Error('Bootstrap requires a list of peer addresses')\n }\n super()\n\n this._list = options.list\n this._interval = options.interval || 10000\n this._timer = null\n }\n\n /**\n * Start emitting events.\n */\n start () {\n if (this._timer) {\n return\n }\n\n this._timer = setInterval(() => this._discoverBootstrapPeers(), this._interval)\n log('Starting bootstrap node discovery')\n this._discoverBootstrapPeers()\n }\n\n /**\n * Emit each address in the list as a PeerInfo.\n */\n _discoverBootstrapPeers () {\n if (!this._timer) {\n return\n }\n\n this._list.forEach((candidate) => {\n if (!mafmt.P2P.matches(candidate)) {\n return log.error('Invalid multiaddr')\n }\n\n const ma = new Multiaddr(candidate)\n const peerIdStr = ma.getPeerId()\n\n if (!peerIdStr) {\n log.error('Invalid bootstrap multiaddr without peer id')\n return\n }\n\n const peerId = PeerId.createFromB58String(peerIdStr)\n\n try {\n this.emit('peer', {\n id: peerId,\n multiaddrs: [ma]\n })\n } catch (err) {\n log.error('Invalid bootstrap peer id', err)\n }\n })\n }\n\n /**\n * Stop emitting events.\n */\n stop () {\n if (this._timer) clearInterval(this._timer)\n this._timer = null\n }\n}\n\nexports = module.exports = Bootstrap\nexports.tag = 'bootstrap'\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p'), {\n error: debug('libp2p:err')\n})\nconst { EventEmitter } = require('events')\n\nconst errCode = require('err-code')\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\n\nconst PeerRouting = require('./peer-routing')\nconst ContentRouting = require('./content-routing')\nconst getPeer = require('./get-peer')\nconst { validate: validateConfig } = require('./config')\nconst { codes, messages } = require('./errors')\n\nconst AddressManager = require('./address-manager')\nconst ConnectionManager = require('./connection-manager')\nconst Circuit = require('./circuit/transport')\nconst Relay = require('./circuit')\nconst Dialer = require('./dialer')\nconst Keychain = require('./keychain')\nconst Metrics = require('./metrics')\nconst TransportManager = require('./transport-manager')\nconst Upgrader = require('./upgrader')\nconst PeerStore = require('./peer-store')\nconst PubsubAdapter = require('./pubsub-adapter')\nconst PersistentPeerStore = require('./peer-store/persistent')\nconst Registrar = require('./registrar')\nconst ping = require('./ping')\nconst IdentifyService = require('./identify')\nconst NatManager = require('./nat-manager')\nconst { updateSelfPeerRecord } = require('./record/utils')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('libp2p-interfaces/src/transport/types').TransportFactory} TransportFactory\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxerFactory} MuxerFactory\n * @typedef {import('libp2p-interfaces/src/content-routing/types').ContentRouting} ContentRoutingModule\n * @typedef {import('libp2p-interfaces/src/peer-discovery/types').PeerDiscoveryFactory} PeerDiscoveryFactory\n * @typedef {import('libp2p-interfaces/src/peer-routing/types').PeerRouting} PeerRoutingModule\n * @typedef {import('libp2p-interfaces/src/crypto/types').Crypto} Crypto\n * @typedef {import('libp2p-interfaces/src/pubsub')} Pubsub\n * @typedef {import('libp2p-interfaces/src/pubsub').PubsubOptions} PubsubOptions\n * @typedef {import('interface-datastore').Datastore} Datastore\n * @typedef {import('./pnet')} Protector\n */\n\n/**\n * @typedef {Object} HandlerProps\n * @property {Connection} connection\n * @property {MuxedStream} stream\n * @property {string} protocol\n *\n * @typedef {Object} RandomWalkOptions\n * @property {boolean} [enabled = false]\n * @property {number} [queriesPerPeriod = 1]\n * @property {number} [interval = 300e3]\n * @property {number} [timeout = 10e3]\n *\n * @typedef {Object} DhtOptions\n * @property {boolean} [enabled = false]\n * @property {number} [kBucketSize = 20]\n * @property {RandomWalkOptions} [randomWalk]\n * @property {boolean} [clientMode]\n * @property {import('libp2p-interfaces/src/types').DhtSelectors} [selectors]\n * @property {import('libp2p-interfaces/src/types').DhtValidators} [validators]\n *\n * @typedef {Object} KeychainOptions\n * @property {Datastore} [datastore]\n *\n * @typedef {Object} PeerStoreOptions\n * @property {boolean} persistence\n *\n * @typedef {Object} PubsubLocalOptions\n * @property {boolean} enabled\n *\n * @typedef {Object} MetricsOptions\n * @property {boolean} enabled\n *\n * @typedef {Object} RelayOptions\n * @property {boolean} [enabled = true]\n * @property {import('./circuit').RelayAdvertiseOptions} [advertise]\n * @property {import('./circuit').HopOptions} [hop]\n * @property {import('./circuit').AutoRelayOptions} [autoRelay]\n *\n * @typedef {Object} Libp2pConfig\n * @property {DhtOptions} [dht] dht module options\n * @property {import('./nat-manager').NatManagerOptions} [nat]\n * @property {Record} [peerDiscovery]\n * @property {PubsubLocalOptions & PubsubOptions} [pubsub] pubsub module options\n * @property {RelayOptions} [relay]\n * @property {Record} [transport] transport options indexed by transport key\n *\n * @typedef {Object} Libp2pModules\n * @property {TransportFactory[]} transport\n * @property {MuxerFactory[]} streamMuxer\n * @property {Crypto[]} connEncryption\n * @property {PeerDiscoveryFactory[]} [peerDiscovery]\n * @property {PeerRoutingModule[]} [peerRouting]\n * @property {ContentRoutingModule[]} [contentRouting]\n * @property {Object} [dht]\n * @property {{new(...args: any[]): Pubsub}} [pubsub]\n * @property {Protector} [connProtector]\n *\n * @typedef {Object} Libp2pOptions\n * @property {Libp2pModules} modules libp2p modules to use\n * @property {import('./address-manager').AddressManagerOptions} [addresses]\n * @property {import('./connection-manager').ConnectionManagerOptions} [connectionManager]\n * @property {Datastore} [datastore]\n * @property {import('./dialer').DialerOptions} [dialer]\n * @property {import('./identify/index').HostProperties} [host] libp2p host\n * @property {KeychainOptions & import('./keychain/index').KeychainOptions} [keychain]\n * @property {MetricsOptions & import('./metrics').MetricsOptions} [metrics]\n * @property {import('./peer-routing').PeerRoutingOptions} [peerRouting]\n * @property {PeerStoreOptions & import('./peer-store/persistent').PersistentPeerStoreOptions} [peerStore]\n * @property {import('./transport-manager').TransportManagerOptions} [transportManager]\n * @property {Libp2pConfig} [config]\n *\n * @typedef {Object} constructorOptions\n * @property {PeerId} peerId\n *\n * @typedef {Object} CreateOptions\n * @property {PeerId} [peerId]\n *\n * @extends {EventEmitter}\n * @fires Libp2p#error Emitted when an error occurs\n * @fires Libp2p#peer:discovery Emitted when a peer is discovered\n */\nclass Libp2p extends EventEmitter {\n /**\n * Like `new Libp2p(options)` except it will create a `PeerId`\n * instance if one is not provided in options.\n *\n * @param {Libp2pOptions & CreateOptions} options - Libp2p configuration options\n * @returns {Promise}\n */\n static async create (options) {\n if (options.peerId) {\n // @ts-ignore 'Libp2pOptions & CreateOptions' is not assignable to 'Libp2pOptions & constructorOptions'\n return new Libp2p(options)\n }\n\n const peerId = await PeerId.create()\n\n options.peerId = peerId\n // @ts-ignore 'Libp2pOptions & CreateOptions' is not assignable to 'Libp2pOptions & constructorOptions'\n return new Libp2p(options)\n }\n\n /**\n * Libp2p node.\n *\n * @class\n * @param {Libp2pOptions & constructorOptions} _options\n */\n constructor (_options) {\n super()\n // validateConfig will ensure the config is correct,\n // and add default values where appropriate\n this._options = validateConfig(_options)\n\n /** @type {PeerId} */\n this.peerId = this._options.peerId\n this.datastore = this._options.datastore\n\n this.peerStore = (this.datastore && this._options.peerStore.persistence)\n ? new PersistentPeerStore({\n peerId: this.peerId,\n datastore: this.datastore,\n ...this._options.peerStore\n })\n : new PeerStore({ peerId: this.peerId })\n\n // Addresses {listen, announce, noAnnounce}\n this.addresses = this._options.addresses\n this.addressManager = new AddressManager(this.peerId, this._options.addresses)\n\n // when addresses change, update our peer record\n this.addressManager.on('change:addresses', () => {\n updateSelfPeerRecord(this).catch(err => {\n log.error('Error updating self peer record', err)\n })\n })\n\n this._modules = this._options.modules\n this._config = this._options.config\n this._transport = [] // Transport instances/references\n this._discovery = new Map() // Discovery service instances/references\n\n // Create the Connection Manager\n this.connectionManager = new ConnectionManager(this, {\n autoDial: this._config.peerDiscovery.autoDial,\n ...this._options.connectionManager\n })\n\n // Create Metrics\n if (this._options.metrics.enabled) {\n this.metrics = new Metrics({\n ...this._options.metrics,\n connectionManager: this.connectionManager\n })\n }\n\n // Create keychain\n if (this._options.keychain && this._options.keychain.datastore) {\n log('creating keychain')\n\n const keychainOpts = Keychain.generateOptions()\n\n this.keychain = new Keychain(this._options.keychain.datastore, {\n ...keychainOpts,\n ...this._options.keychain\n })\n\n log('keychain constructed')\n }\n\n // Setup the Upgrader\n this.upgrader = new Upgrader({\n localPeer: this.peerId,\n metrics: this.metrics,\n onConnection: (connection) => this.connectionManager.onConnect(connection),\n onConnectionEnd: (connection) => this.connectionManager.onDisconnect(connection)\n })\n\n // Setup the transport manager\n this.transportManager = new TransportManager({\n libp2p: this,\n upgrader: this.upgrader,\n faultTolerance: this._options.transportManager.faultTolerance\n })\n\n // Create the Nat Manager\n this.natManager = new NatManager({\n peerId: this.peerId,\n addressManager: this.addressManager,\n transportManager: this.transportManager,\n // @ts-ignore Nat typedef is not understood as Object\n ...this._options.config.nat\n })\n\n // Create the Registrar\n this.registrar = new Registrar({\n peerStore: this.peerStore,\n connectionManager: this.connectionManager\n })\n\n this.handle = this.handle.bind(this)\n this.registrar.handle = this.handle\n\n // Attach crypto channels\n if (!this._modules.connEncryption || !this._modules.connEncryption.length) {\n throw errCode(new Error(messages.CONN_ENCRYPTION_REQUIRED), codes.CONN_ENCRYPTION_REQUIRED)\n }\n const cryptos = this._modules.connEncryption\n cryptos.forEach((crypto) => {\n this.upgrader.cryptos.set(crypto.protocol, crypto)\n })\n\n this.dialer = new Dialer({\n transportManager: this.transportManager,\n peerStore: this.peerStore,\n ...this._options.dialer\n })\n\n this._modules.transport.forEach((Transport) => {\n const key = Transport.prototype[Symbol.toStringTag]\n const transportOptions = this._config.transport[key]\n this.transportManager.add(key, Transport, transportOptions)\n })\n\n if (this._config.relay.enabled) {\n // @ts-ignore Circuit prototype\n this.transportManager.add(Circuit.prototype[Symbol.toStringTag], Circuit)\n this.relay = new Relay(this)\n }\n\n // Attach stream multiplexers\n if (this._modules.streamMuxer) {\n const muxers = this._modules.streamMuxer\n muxers.forEach((muxer) => {\n this.upgrader.muxers.set(muxer.multicodec, muxer)\n })\n\n // Add the identify service since we can multiplex\n this.identifyService = new IdentifyService({ libp2p: this })\n this.handle(Object.values(IdentifyService.getProtocolStr(this)), this.identifyService.handleMessage)\n }\n\n // Attach private network protector\n if (this._modules.connProtector) {\n this.upgrader.protector = this._modules.connProtector\n } else if (globalThis.process !== undefined && globalThis.process.env && globalThis.process.env.LIBP2P_FORCE_PNET) { // eslint-disable-line no-undef\n throw new Error('Private network is enforced, but no protector was provided')\n }\n\n // dht provided components (peerRouting, contentRouting, dht)\n if (this._modules.dht) {\n const DHT = this._modules.dht\n // @ts-ignore Object is not constructable\n this._dht = new DHT({\n libp2p: this,\n dialer: this.dialer,\n peerId: this.peerId,\n peerStore: this.peerStore,\n registrar: this.registrar,\n datastore: this.datastore,\n ...this._config.dht\n })\n }\n\n // Create pubsub if provided\n if (this._modules.pubsub) {\n const Pubsub = this._modules.pubsub\n // using pubsub adapter with *DEPRECATED* handlers functionality\n /** @type {Pubsub} */\n this.pubsub = PubsubAdapter(Pubsub, this, this._config.pubsub)\n }\n\n // Attach remaining APIs\n // peer and content routing will automatically get modules from _modules and _dht\n this.peerRouting = new PeerRouting(this)\n this.contentRouting = new ContentRouting(this)\n\n // Mount default protocols\n ping.mount(this)\n\n this._onDiscoveryPeer = this._onDiscoveryPeer.bind(this)\n }\n\n /**\n * Overrides EventEmitter.emit to conditionally emit errors\n * if there is a handler. If not, errors will be logged.\n *\n * @param {string} eventName\n * @param {...any} args\n * @returns {boolean}\n */\n emit (eventName, ...args) {\n // TODO: do we still need this?\n // @ts-ignore _events does not exist in libp2p\n if (eventName === 'error' && !this._events.error) {\n log.error(args)\n return false\n } else {\n return super.emit(eventName, ...args)\n }\n }\n\n /**\n * Starts the libp2p node and all its subsystems\n *\n * @returns {Promise}\n */\n async start () {\n log('libp2p is starting')\n\n try {\n await this._onStarting()\n await this._onDidStart()\n log('libp2p has started')\n } catch (err) {\n this.emit('error', err)\n log.error('An error occurred starting libp2p', err)\n await this.stop()\n throw err\n }\n }\n\n /**\n * Stop the libp2p node by closing its listeners and open connections\n *\n * @async\n * @returns {Promise}\n */\n async stop () {\n log('libp2p is stopping')\n\n try {\n this._isStarted = false\n\n this.relay && this.relay.stop()\n this.peerRouting.stop()\n\n for (const service of this._discovery.values()) {\n service.removeListener('peer', this._onDiscoveryPeer)\n }\n\n await Promise.all(Array.from(this._discovery.values(), s => s.stop()))\n\n this._discovery = new Map()\n\n await this.peerStore.stop()\n await this.connectionManager.stop()\n\n await Promise.all([\n this.pubsub && this.pubsub.stop(),\n this._dht && this._dht.stop(),\n this.metrics && this.metrics.stop()\n ])\n\n await this.natManager.stop()\n await this.transportManager.close()\n\n ping.unmount(this)\n this.dialer.destroy()\n } catch (err) {\n if (err) {\n log.error(err)\n this.emit('error', err)\n }\n }\n log('libp2p has stopped')\n }\n\n /**\n * Load keychain keys from the datastore.\n * Imports the private key as 'self', if needed.\n *\n * @async\n * @returns {Promise}\n */\n async loadKeychain () {\n if (!this.keychain) {\n return\n }\n\n try {\n await this.keychain.findKeyByName('self')\n } catch (err) {\n await this.keychain.importPeer('self', this.peerId)\n }\n }\n\n isStarted () {\n return this._isStarted\n }\n\n /**\n * Gets a Map of the current connections. The keys are the stringified\n * `PeerId` of the peer. The value is an array of Connections to that peer.\n *\n * @returns {Map}\n */\n get connections () {\n return this.connectionManager.connections\n }\n\n /**\n * Dials to the provided peer. If successful, the known metadata of the\n * peer will be added to the nodes `peerStore`\n *\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @param {object} [options]\n * @param {AbortSignal} [options.signal]\n * @returns {Promise}\n */\n dial (peer, options) {\n return this._dial(peer, options)\n }\n\n /**\n * Dials to the provided peer and tries to handshake with the given protocols in order.\n * If successful, the known metadata of the peer will be added to the nodes `peerStore`,\n * and the `MuxedStream` will be returned together with the successful negotiated protocol.\n *\n * @async\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @param {string[]|string} protocols\n * @param {object} [options]\n * @param {AbortSignal} [options.signal]\n */\n async dialProtocol (peer, protocols, options) {\n if (!protocols || !protocols.length) {\n throw errCode(new Error('no protocols were provided to open a stream'), codes.ERR_INVALID_PROTOCOLS_FOR_STREAM)\n }\n\n const connection = await this._dial(peer, options)\n return connection.newStream(protocols)\n }\n\n /**\n * @async\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @param {object} [options]\n * @returns {Promise}\n */\n async _dial (peer, options) {\n const { id, multiaddrs } = getPeer(peer)\n\n if (id.equals(this.peerId)) {\n throw errCode(new Error('Cannot dial self'), codes.ERR_DIALED_SELF)\n }\n\n let connection = this.connectionManager.get(id)\n\n if (!connection) {\n connection = await this.dialer.connectToPeer(peer, options)\n } else if (multiaddrs) {\n this.peerStore.addressBook.add(id, multiaddrs)\n }\n\n return connection\n }\n\n /**\n * Get a deduplicated list of peer advertising multiaddrs by concatenating\n * the listen addresses used by transports with any configured\n * announce addresses as well as observed addresses reported by peers.\n *\n * If Announce addrs are specified, configured listen addresses will be\n * ignored though observed addresses will still be included.\n *\n * @returns {Multiaddr[]}\n */\n get multiaddrs () {\n let addrs = this.addressManager.getAnnounceAddrs().map(ma => ma.toString())\n\n if (!addrs.length) {\n // no configured announce addrs, add configured listen addresses\n addrs = this.transportManager.getAddrs().map(ma => ma.toString())\n }\n\n addrs = addrs.concat(this.addressManager.getObservedAddrs().map(ma => ma.toString()))\n\n const announceFilter = this._options.addresses.announceFilter\n\n // dedupe multiaddrs\n const addrSet = new Set(addrs)\n\n // Create advertising list\n return announceFilter(Array.from(addrSet).map(str => new Multiaddr(str)))\n }\n\n /**\n * Disconnects all connections to the given `peer`\n *\n * @param {PeerId|Multiaddr|string} peer - the peer to close connections to\n * @returns {Promise}\n */\n async hangUp (peer) {\n const { id } = getPeer(peer)\n\n const connections = this.connectionManager.connections.get(id.toB58String())\n\n if (!connections) {\n return\n }\n\n await Promise.all(\n connections.map(connection => {\n return connection.close()\n })\n )\n }\n\n /**\n * Pings the given peer in order to obtain the operation latency.\n *\n * @param {PeerId|Multiaddr|string} peer - The peer to ping\n * @returns {Promise}\n */\n ping (peer) {\n const { id, multiaddrs } = getPeer(peer)\n\n // If received multiaddr, ping it\n if (multiaddrs) {\n return ping(this, multiaddrs[0])\n }\n\n return ping(this, id)\n }\n\n /**\n * Registers the `handler` for each protocol\n *\n * @param {string[]|string} protocols\n * @param {(props: HandlerProps) => void} handler\n */\n handle (protocols, handler) {\n protocols = Array.isArray(protocols) ? protocols : [protocols]\n protocols.forEach(protocol => {\n this.upgrader.protocols.set(protocol, handler)\n })\n\n // Add new protocols to self protocols in the Protobook\n this.peerStore.protoBook.add(this.peerId, protocols)\n }\n\n /**\n * Removes the handler for each protocol. The protocol\n * will no longer be supported on streams.\n *\n * @param {string[]|string} protocols\n */\n unhandle (protocols) {\n protocols = Array.isArray(protocols) ? protocols : [protocols]\n protocols.forEach(protocol => {\n this.upgrader.protocols.delete(protocol)\n })\n\n // Remove protocols from self protocols in the Protobook\n this.peerStore.protoBook.remove(this.peerId, protocols)\n }\n\n async _onStarting () {\n // Listen on the provided transports for the provided addresses\n const addrs = this.addressManager.getListenAddrs()\n await this.transportManager.listen(addrs)\n\n // Manage your NATs\n this.natManager.start()\n\n // Start PeerStore\n await this.peerStore.start()\n\n if (this._config.pubsub.enabled) {\n this.pubsub && this.pubsub.start()\n }\n\n // DHT subsystem\n if (this._config.dht.enabled) {\n this._dht && this._dht.start()\n\n // TODO: this should be modified once random-walk is used as\n // the other discovery modules\n this._dht.on('peer', this._onDiscoveryPeer)\n }\n\n // Start metrics if present\n this.metrics && this.metrics.start()\n }\n\n /**\n * Called when libp2p has started and before it returns\n *\n * @private\n */\n async _onDidStart () {\n this._isStarted = true\n\n this.peerStore.on('peer', peerId => {\n this.emit('peer:discovery', peerId)\n this._maybeConnect(peerId)\n })\n\n // Once we start, emit any peers we may have already discovered\n // TODO: this should be removed, as we already discovered these peers in the past\n for (const peer of this.peerStore.peers.values()) {\n this.emit('peer:discovery', peer.id)\n }\n\n this.connectionManager.start()\n\n // Peer discovery\n await this._setupPeerDiscovery()\n\n // Relay\n this.relay && this.relay.start()\n\n this.peerRouting.start()\n }\n\n /**\n * Called whenever peer discovery services emit `peer` events.\n * Known peers may be emitted.\n *\n * @private\n * @param {{ id: PeerId, multiaddrs: Multiaddr[], protocols: string[] }} peer\n */\n _onDiscoveryPeer (peer) {\n if (peer.id.toB58String() === this.peerId.toB58String()) {\n log.error(new Error(codes.ERR_DISCOVERED_SELF))\n return\n }\n\n peer.multiaddrs && this.peerStore.addressBook.add(peer.id, peer.multiaddrs)\n peer.protocols && this.peerStore.protoBook.set(peer.id, peer.protocols)\n }\n\n /**\n * Will dial to the given `peerId` if the current number of\n * connected peers is less than the configured `ConnectionManager`\n * minConnections.\n *\n * @private\n * @param {PeerId} peerId\n */\n async _maybeConnect (peerId) {\n // If auto dialing is on and we have no connection to the peer, check if we should dial\n if (this._config.peerDiscovery.autoDial === true && !this.connectionManager.get(peerId)) {\n const minConnections = this._options.connectionManager.minConnections || 0\n if (minConnections > this.connectionManager.size) {\n log('connecting to discovered peer %s', peerId.toB58String())\n try {\n await this.dialer.connectToPeer(peerId)\n } catch (err) {\n log.error(`could not connect to discovered peer ${peerId.toB58String()} with ${err}`)\n }\n }\n }\n }\n\n /**\n * Initializes and starts peer discovery services\n *\n * @async\n * @private\n */\n async _setupPeerDiscovery () {\n /**\n * @param {PeerDiscoveryFactory} DiscoveryService\n */\n const setupService = (DiscoveryService) => {\n let config = {\n enabled: true // on by default\n }\n\n if (DiscoveryService.tag &&\n this._config.peerDiscovery &&\n this._config.peerDiscovery[DiscoveryService.tag]) {\n // @ts-ignore PeerDiscovery not understood as an Object for spread\n config = { ...config, ...this._config.peerDiscovery[DiscoveryService.tag] }\n }\n\n if (config.enabled &&\n !this._discovery.has(DiscoveryService.tag)) { // not already added\n let discoveryService\n\n if (typeof DiscoveryService === 'function') {\n // @ts-ignore DiscoveryService has no constructor type inferred\n discoveryService = new DiscoveryService(Object.assign({}, config, {\n peerId: this.peerId,\n libp2p: this\n }))\n } else {\n discoveryService = DiscoveryService\n }\n\n discoveryService.on('peer', this._onDiscoveryPeer)\n this._discovery.set(DiscoveryService.tag, discoveryService)\n }\n }\n\n // Discovery modules\n for (const DiscoveryService of this._modules.peerDiscovery || []) {\n setupService(DiscoveryService)\n }\n\n // Transport modules with discovery\n for (const Transport of this.transportManager.getTransports()) {\n // @ts-ignore Transport interface does not include discovery\n if (Transport.discovery) {\n // @ts-ignore Transport interface does not include discovery\n setupService(Transport.discovery)\n }\n }\n\n await Promise.all(Array.from(this._discovery.values(), d => d.start()))\n }\n}\n\nmodule.exports = Libp2p\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-routing'), {\n error: debug('libp2p:peer-routing:err')\n})\nconst errCode = require('err-code')\nconst {\n storeAddresses,\n uniquePeers,\n requirePeers\n} = require('./content-routing/utils')\n\nconst merge = require('it-merge')\nconst { pipe } = require('it-pipe')\nconst first = require('it-first')\nconst drain = require('it-drain')\nconst filter = require('it-filter')\nconst {\n setDelayedInterval,\n clearDelayedInterval\n// @ts-ignore module with no types\n} = require('set-delayed-interval')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('libp2p-interfaces/src/peer-routing/types').PeerRouting} PeerRoutingModule\n */\n\n/**\n * @typedef {Object} RefreshManagerOptions\n * @property {boolean} [enabled = true] - Whether to enable the Refresh manager\n * @property {number} [bootDelay = 6e5] - Boot delay to start the Refresh Manager (in ms)\n * @property {number} [interval = 10e3] - Interval between each Refresh Manager run (in ms)\n *\n * @typedef {Object} PeerRoutingOptions\n * @property {RefreshManagerOptions} [refreshManager]\n */\n\nclass PeerRouting {\n /**\n * @class\n * @param {import('./')} libp2p\n */\n constructor (libp2p) {\n this._peerId = libp2p.peerId\n this._peerStore = libp2p.peerStore\n /** @type {PeerRoutingModule[]} */\n this._routers = libp2p._modules.peerRouting || []\n\n // If we have the dht, add it to the available peer routers\n if (libp2p._dht && libp2p._config.dht.enabled) {\n this._routers.push(libp2p._dht)\n }\n\n this._refreshManagerOptions = libp2p._options.peerRouting.refreshManager\n\n this._findClosestPeersTask = this._findClosestPeersTask.bind(this)\n }\n\n /**\n * Start peer routing service.\n */\n start () {\n if (!this._routers.length || this._timeoutId || !this._refreshManagerOptions.enabled) {\n return\n }\n\n this._timeoutId = setDelayedInterval(\n this._findClosestPeersTask, this._refreshManagerOptions.interval, this._refreshManagerOptions.bootDelay\n )\n }\n\n /**\n * Recurrent task to find closest peers and add their addresses to the Address Book.\n */\n async _findClosestPeersTask () {\n try {\n // nb getClosestPeers adds the addresses to the address book\n await drain(this.getClosestPeers(this._peerId.id))\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Stop peer routing service.\n */\n stop () {\n clearDelayedInterval(this._timeoutId)\n }\n\n /**\n * Iterates over all peer routers in parallel to find the given peer.\n *\n * @param {PeerId} id - The id of the peer to find\n * @param {object} [options]\n * @param {number} [options.timeout] - How long the query should run\n * @returns {Promise<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async findPeer (id, options) { // eslint-disable-line require-await\n if (!this._routers.length) {\n throw errCode(new Error('No peer routers available'), 'NO_ROUTERS_AVAILABLE')\n }\n\n if (id.toB58String() === this._peerId.toB58String()) {\n throw errCode(new Error('Should not try to find self'), 'ERR_FIND_SELF')\n }\n\n const output = await pipe(\n merge(\n ...this._routers.map(router => [router.findPeer(id, options)])\n ),\n (source) => filter(source, Boolean),\n // @ts-ignore findPeer resolves a Promise\n (source) => storeAddresses(source, this._peerStore),\n (source) => first(source)\n )\n\n if (output) {\n return output\n }\n\n throw errCode(new Error('not found'), 'NOT_FOUND')\n }\n\n /**\n * Attempt to find the closest peers on the network to the given key.\n *\n * @param {Uint8Array} key - A CID like key\n * @param {Object} [options]\n * @param {number} [options.timeout=30e3] - How long the query can take.\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * getClosestPeers (key, options = { timeout: 30e3 }) {\n if (!this._routers.length) {\n throw errCode(new Error('No peer routers available'), 'NO_ROUTERS_AVAILABLE')\n }\n\n yield * pipe(\n merge(\n ...this._routers.map(router => router.getClosestPeers(key, options))\n ),\n (source) => storeAddresses(source, this._peerStore),\n (source) => uniquePeers(source),\n (source) => requirePeers(source)\n )\n }\n}\n\nmodule.exports = PeerRouting\n","'use strict'\n\nconst errCode = require('err-code')\nconst filter = require('it-filter')\nconst map = require('it-map')\nconst take = require('it-take')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * Store the multiaddrs from every peer in the passed peer store\n *\n * @param {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} source\n * @param {import('../peer-store')} peerStore\n */\nfunction storeAddresses (source, peerStore) {\n return map(source, (peer) => {\n // ensure we have the addresses for a given peer\n peerStore.addressBook.add(peer.id, peer.multiaddrs)\n\n return peer\n })\n}\n\n/**\n * Filter peers by unique peer id\n *\n * @param {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} source\n */\nfunction uniquePeers (source) {\n /** @type Set */\n const seen = new Set()\n\n return filter(source, (peer) => {\n // dedupe by peer id\n if (seen.has(peer.id.toString())) {\n return false\n }\n\n seen.add(peer.id.toString())\n\n return true\n })\n}\n\n/**\n * Require at least `min` peers to be yielded from `source`\n *\n * @param {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} source\n * @param {number} min\n */\nasync function * requirePeers (source, min = 1) {\n let seen = 0\n\n for await (const peer of source) {\n seen++\n\n yield peer\n }\n\n if (seen < min) {\n throw errCode(new Error('not found'), 'NOT_FOUND')\n }\n}\n\n/**\n * If `max` is passed, only take that number of peers from the source\n * otherwise take all the peers\n *\n * @param {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} source\n * @param {number} [max]\n */\nfunction maybeLimitSource (source, max) {\n if (max) {\n return take(source, max)\n }\n\n return source\n}\n\nmodule.exports = {\n storeAddresses,\n uniquePeers,\n requirePeers,\n maybeLimitSource\n}\n","'use strict'\n\nconst intervals = new Map()\n\nconst _generateId = () => `${Date.now()}:${Math.floor(Math.random() * 1000000)}`\n\n/**\n * Run a given task each {interval} ms\n *\n * @param {() => Promise} task\n * @param {number} interval\n * @param {string} id\n */\nasync function _runPeriodically (task, interval, id) {\n while (intervals.get(id)) {\n try {\n await task()\n } catch (err) {\n // Throw global context error if handler throws\n setTimeout(() => { throw err }, 1)\n break\n }\n\n if (!intervals.get(id)) {\n break\n }\n\n await new Promise(resolve => {\n const _timeout = setTimeout(resolve, interval)\n\n intervals.set(id, _timeout)\n })\n }\n}\n\n/**\n * Asynchronous setInterval that is properly delayed using promises and can be delayed on boot.\n *\n * @param {() => Promise} task\n * @param {number} interval\n * @param {number} [delay = interval]\n * @returns {string}\n */\nfunction setDelayedInterval (task, interval, delay) {\n delay = delay || interval\n\n const id = _generateId()\n const _timeout = setTimeout(() => {\n _runPeriodically(task, interval, id)\n }, delay)\n\n intervals.set(id, _timeout)\n\n return id\n}\n\n/**\n * Clear delayed interval.\n *\n * @param {string} id\n */\nfunction clearDelayedInterval (id) {\n const _timeout = intervals.get(id)\n\n if (_timeout) {\n clearTimeout(_timeout)\n intervals.delete(id)\n }\n}\n\nmodule.exports = {\n setDelayedInterval,\n clearDelayedInterval\n}\n","'use strict'\n\nconst errCode = require('err-code')\nconst { messages, codes } = require('../errors')\nconst {\n storeAddresses,\n uniquePeers,\n requirePeers,\n maybeLimitSource\n} = require('./utils')\n\nconst merge = require('it-merge')\nconst { pipe } = require('it-pipe')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('multiformats/cid').CID} CID\n * @typedef {import('libp2p-interfaces/src/content-routing/types').ContentRouting} ContentRoutingModule\n */\n\n/**\n * @typedef {Object} GetData\n * @property {PeerId} from\n * @property {Uint8Array} val\n */\n\nclass ContentRouting {\n /**\n * @class\n * @param {import('..')} libp2p\n */\n constructor (libp2p) {\n this.libp2p = libp2p\n /** @type {ContentRoutingModule[]} */\n this.routers = libp2p._modules.contentRouting || []\n this.dht = libp2p._dht\n\n // If we have the dht, add it to the available content routers\n if (this.dht && libp2p._config.dht.enabled) {\n this.routers.push(this.dht)\n }\n }\n\n /**\n * Iterates over all content routers in parallel to find providers of the given key.\n *\n * @param {CID} key - The CID key of the content to find\n * @param {object} [options]\n * @param {number} [options.timeout] - How long the query should run\n * @param {number} [options.maxNumProviders] - maximum number of providers to find\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * findProviders (key, options = {}) {\n if (!this.routers.length) {\n throw errCode(new Error('No content this.routers available'), 'NO_ROUTERS_AVAILABLE')\n }\n\n yield * pipe(\n merge(\n ...this.routers.map(router => router.findProviders(key, options))\n ),\n (source) => storeAddresses(source, this.libp2p.peerStore),\n (source) => uniquePeers(source),\n (source) => maybeLimitSource(source, options.maxNumProviders),\n (source) => requirePeers(source)\n )\n }\n\n /**\n * Iterates over all content routers in parallel to notify it is\n * a provider of the given key.\n *\n * @param {CID} key - The CID key of the content to find\n * @returns {Promise}\n */\n async provide (key) {\n if (!this.routers.length) {\n throw errCode(new Error('No content routers available'), 'NO_ROUTERS_AVAILABLE')\n }\n\n await Promise.all(this.routers.map((router) => router.provide(key)))\n }\n\n /**\n * Store the given key/value pair in the DHT.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n * @param {Object} [options] - put options\n * @param {number} [options.minPeers] - minimum number of peers required to successfully put\n * @returns {Promise}\n */\n put (key, value, options) {\n if (!this.libp2p.isStarted() || !this.dht.isStarted) {\n throw errCode(new Error(messages.NOT_STARTED_YET), codes.DHT_NOT_STARTED)\n }\n\n return this.dht.put(key, value, options)\n }\n\n /**\n * Get the value to the given key.\n * Times out after 1 minute by default.\n *\n * @param {Uint8Array} key\n * @param {Object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n * @returns {Promise}\n */\n get (key, options) {\n if (!this.libp2p.isStarted() || !this.dht.isStarted) {\n throw errCode(new Error(messages.NOT_STARTED_YET), codes.DHT_NOT_STARTED)\n }\n\n return this.dht.get(key, options)\n }\n\n /**\n * Get the `n` values to the given key without sorting.\n *\n * @param {Uint8Array} key\n * @param {number} nVals\n * @param {Object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n * @returns {Promise}\n */\n async getMany (key, nVals, options) { // eslint-disable-line require-await\n if (!this.libp2p.isStarted() || !this.dht.isStarted) {\n throw errCode(new Error(messages.NOT_STARTED_YET), codes.DHT_NOT_STARTED)\n }\n\n return this.dht.getMany(key, nVals, options)\n }\n}\n\nmodule.exports = ContentRouting\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\nconst errCode = require('err-code')\n\nconst { codes } = require('./errors')\n\n/**\n * Converts the given `peer` to a `Peer` object.\n * If a multiaddr is received, the addressBook is updated.\n *\n * @param {PeerId|Multiaddr|string} peer\n * @returns {{ id: PeerId, multiaddrs: Multiaddr[]|undefined }}\n */\nfunction getPeer (peer) {\n if (typeof peer === 'string') {\n peer = new Multiaddr(peer)\n }\n\n let addr\n if (Multiaddr.isMultiaddr(peer)) {\n addr = peer\n const idStr = peer.getPeerId()\n\n if (!idStr) {\n throw errCode(\n new Error(`${peer} does not have a valid peer type`),\n codes.ERR_INVALID_MULTIADDR\n )\n }\n\n try {\n peer = PeerId.createFromB58String(idStr)\n } catch (err) {\n throw errCode(\n new Error(`${peer} is not a valid peer type`),\n codes.ERR_INVALID_MULTIADDR\n )\n }\n }\n\n return {\n id: peer,\n multiaddrs: addr ? [addr] : undefined\n }\n}\n\nmodule.exports = getPeer\n","'use strict'\n\nconst mergeOptions = require('merge-options')\n// @ts-ignore no types in multiaddr path\nconst { dnsaddrResolver } = require('multiaddr/src/resolvers')\n\nconst Constants = require('./constants')\nconst { AGENT_VERSION } = require('./identify/consts')\nconst RelayConstants = require('./circuit/constants')\n\nconst { publicAddressesFirst } = require('libp2p-utils/src/address-sort')\nconst { FaultTolerance } = require('./transport-manager')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('.').Libp2pOptions} Libp2pOptions\n * @typedef {import('.').constructorOptions} constructorOptions\n */\n\nconst DefaultConfig = {\n addresses: {\n listen: [],\n announce: [],\n noAnnounce: [],\n announceFilter: (/** @type {Multiaddr[]} */ multiaddrs) => multiaddrs\n },\n connectionManager: {\n minConnections: 25\n },\n transportManager: {\n faultTolerance: FaultTolerance.FATAL_ALL\n },\n dialer: {\n maxParallelDials: Constants.MAX_PARALLEL_DIALS,\n maxDialsPerPeer: Constants.MAX_PER_PEER_DIALS,\n dialTimeout: Constants.DIAL_TIMEOUT,\n resolvers: {\n dnsaddr: dnsaddrResolver\n },\n addressSorter: publicAddressesFirst\n },\n host: {\n agentVersion: AGENT_VERSION\n },\n metrics: {\n enabled: false\n },\n peerStore: {\n persistence: false,\n threshold: 5\n },\n peerRouting: {\n refreshManager: {\n enabled: true,\n interval: 6e5,\n bootDelay: 10e3\n }\n },\n config: {\n protocolPrefix: 'ipfs',\n dht: {\n enabled: false,\n kBucketSize: 20,\n randomWalk: {\n enabled: false, // disabled waiting for https://github.com/libp2p/js-libp2p-kad-dht/issues/86\n queriesPerPeriod: 1,\n interval: 300e3,\n timeout: 10e3\n }\n },\n nat: {\n enabled: true,\n ttl: 7200,\n keepAlive: true,\n gateway: null,\n externalIp: null,\n pmp: {\n enabled: false\n }\n },\n peerDiscovery: {\n autoDial: true\n },\n pubsub: {\n enabled: true\n },\n relay: {\n enabled: true,\n advertise: {\n bootDelay: RelayConstants.ADVERTISE_BOOT_DELAY,\n enabled: false,\n ttl: RelayConstants.ADVERTISE_TTL\n },\n hop: {\n enabled: false,\n active: false\n },\n autoRelay: {\n enabled: false,\n maxListeners: 2\n }\n },\n transport: {}\n }\n}\n\n/**\n * @param {Libp2pOptions} opts\n * @returns {DefaultConfig & Libp2pOptions & constructorOptions}\n */\nmodule.exports.validate = (opts) => {\n /** @type {DefaultConfig & Libp2pOptions & constructorOptions} */\n const resultingOptions = mergeOptions(DefaultConfig, opts)\n\n if (resultingOptions.modules.transport.length < 1) throw new Error(\"'options.modules.transport' must contain at least 1 transport\")\n\n return resultingOptions\n}\n","'use strict'\n\nconst protocols = require('../protocols-table')\n\nconst { code: dnsaddrCode } = protocols('dnsaddr')\n\n/**\n * @typedef {import('..').Multiaddr} Multiaddr\n */\n\n/**\n * Resolver for dnsaddr addresses.\n *\n * @param {Multiaddr} addr\n * @returns {Promise}\n */\nasync function dnsaddrResolver (addr) {\n const Resolver = require('./dns')\n const resolver = new Resolver()\n\n const peerId = addr.getPeerId()\n const [, hostname] = addr.stringTuples().find(([proto]) => proto === dnsaddrCode) || []\n\n const records = await resolver.resolveTxt(`_dnsaddr.${hostname}`)\n let addresses = records.flat().map((a) => a.split('=')[1])\n\n if (peerId) {\n addresses = addresses.filter((entry) => entry.includes(peerId))\n }\n\n return addresses\n}\n\nmodule.exports = {\n dnsaddrResolver\n}\n","'use strict'\n\n/** @type {import('dns').promises.Resolver} */\n// @ts-ignore - has no types\nconst dns = require('dns-over-http-resolver')\n\nmodule.exports = dns\n","'use strict'\nconst debug = require('debug')\nconst log = debug('dns-over-http-resolver')\nlog.error = debug('dns-over-http-resolver:error')\n\nconst Receptacle = require('receptacle')\n\nconst utils = require('./utils')\n\n/**\n * DNS over HTTP resolver.\n * Uses a list of servers to resolve DNS records with HTTP requests.\n */\nclass Resolver {\n /**\n * @class\n * @param {object} [properties]\n * @param {number} [properties.maxCache = 100] - maximum number of cached dns records.\n */\n constructor ({ maxCache = 100 } = {}) {\n this._cache = new Receptacle({ max: maxCache })\n this._servers = [\n 'https://cloudflare-dns.com/dns-query',\n 'https://dns.google/resolve'\n ]\n }\n\n /**\n * Get an array of the IP addresses currently configured for DNS resolution.\n * These addresses are formatted according to RFC 5952. It can include a custom port.\n *\n * @returns {Array}\n */\n getServers () {\n return this._servers\n }\n\n /**\n * Get a shuffled array of the IP addresses currently configured for DNS resolution.\n * These addresses are formatted according to RFC 5952. It can include a custom port.\n *\n * @returns {Array}\n */\n _getShuffledServers () {\n const newServers = [].concat(this._servers)\n\n for (let i = newServers.length - 1; i > 0; i--) {\n const j = Math.floor(Math.random() * i)\n const temp = newServers[i]\n newServers[i] = newServers[j]\n newServers[j] = temp\n }\n\n return newServers\n }\n\n /**\n * Sets the IP address and port of servers to be used when performing DNS resolution.\n *\n * @param {Array} servers - array of RFC 5952 formatted addresses.\n */\n setServers (servers) {\n this._servers = servers\n }\n\n /**\n * Uses the DNS protocol to resolve the given host name into the appropriate DNS record.\n *\n * @param {string} hostname - host name to resolve.\n * @param {string} [rrType = 'A'] - resource record type.\n * @returns {Promise<*>}\n */\n resolve (hostname, rrType = 'A') {\n switch (rrType) {\n case 'A':\n return this.resolve4(hostname)\n case 'AAAA':\n return this.resolve6(hostname)\n case 'TXT':\n return this.resolveTxt(hostname)\n default:\n throw new Error(`${rrType} is not supported`)\n }\n }\n\n /**\n * Uses the DNS protocol to resolve the given host name into IPv4 addresses.\n *\n * @param {string} hostname - host name to resolve.\n * @returns {Promise>}\n */\n async resolve4 (hostname) {\n const recordType = 'A'\n const cached = this._cache.get(utils.getCacheKey(hostname, recordType))\n if (cached) {\n return cached\n }\n\n for (const server of this._getShuffledServers()) {\n try {\n const response = await utils.fetch(utils.buildResource({\n serverResolver: server,\n hostname,\n recordType\n }))\n\n const d = await response.json()\n const data = d.Answer.map(a => a.data)\n const ttl = Math.min(d.Answer.map(a => a.TTL))\n\n this._cache.set(utils.getCacheKey(hostname, recordType), data, { ttl })\n\n return data\n } catch (err) {\n log.error(`${server} could not resolve ${hostname} record ${recordType}`)\n }\n }\n\n throw new Error(`Could not resolve ${hostname} record ${recordType}`)\n }\n\n /**\n * Uses the DNS protocol to resolve the given host name into IPv6 addresses.\n *\n * @param {string} hostname - host name to resolve.\n * @returns {Promise>}\n */\n async resolve6 (hostname) {\n const recordType = 'AAAA'\n const cached = this._cache.get(utils.getCacheKey(hostname, recordType))\n if (cached) {\n return cached\n }\n\n for (const server of this._getShuffledServers()) {\n try {\n const response = await utils.fetch(utils.buildResource({\n serverResolver: server,\n hostname,\n recordType\n }))\n\n const d = await response.json()\n const data = d.Answer.map(a => a.data)\n const ttl = Math.min(d.Answer.map(a => a.TTL))\n\n this._cache.set(utils.getCacheKey(hostname, recordType), data, { ttl })\n\n return data\n } catch (err) {\n log.error(`${server} could not resolve ${hostname} record ${recordType}`)\n }\n }\n\n throw new Error(`Could not resolve ${hostname} record ${recordType}`)\n }\n\n /**\n * Uses the DNS protocol to resolve the given host name into a Text record.\n *\n * @param {string} hostname - host name to resolve.\n * @returns {Promise>>}\n */\n async resolveTxt (hostname) {\n const recordType = 'TXT'\n const cached = this._cache.get(utils.getCacheKey(hostname, recordType))\n if (cached) {\n return cached\n }\n\n for (const server of this._getShuffledServers()) {\n try {\n const response = await utils.fetch(utils.buildResource({\n serverResolver: server,\n hostname,\n recordType\n }))\n\n const d = await response.json()\n const data = d.Answer.map(a => [a.data.replace(/['\"]+/g, '')])\n const ttl = Math.min(d.Answer.map(a => a.TTL))\n\n this._cache.set(utils.getCacheKey(hostname, recordType), data, { ttl })\n\n return data\n } catch (err) {\n log.error(`${server} could not resolve ${hostname} record ${recordType}`)\n }\n }\n\n throw new Error(`Could not resolve ${hostname} record ${recordType}`)\n }\n}\n\nResolver.Resolver = Resolver\nmodule.exports = Resolver\n","'use strict'\n\nmodule.exports = Receptacle\nvar toMS = require('ms')\nvar cache = Receptacle.prototype\nvar counter = new Date() % 1e9\n\nfunction getUID () { return (Math.random() * 1e9 >>> 0) + (counter++) }\n\n/**\n * Creates a cache with a maximum key size.\n *\n * @constructor\n * @param {Object} options\n * @param {Number} [options.max=Infinity] the maximum number of keys allowed in the cache (lru).\n * @param {Array} [options.items=[]] the default items in the cache.\n */\nfunction Receptacle (options) {\n options = options || {}\n this.id = options.id || getUID()\n this.max = options.max || Infinity\n this.items = options.items || []\n this._lookup = {}\n this.size = this.items.length\n this.lastModified = new Date(options.lastModified || new Date())\n\n // Setup initial timers and indexes for the cache.\n for (var item, ttl, i = this.items.length; i--;) {\n item = this.items[i]\n ttl = new Date(item.expires) - new Date()\n this._lookup[item.key] = item\n if (ttl > 0) this.expire(item.key, ttl)\n else if (ttl <= 0) this.delete(item.key)\n }\n}\n\n/**\n * Tests if a key is currently in the cache.\n * Does not check if slot is empty.\n *\n * @param {String} key - the key to retrieve from the cache.\n * @return {Boolean}\n */\ncache.has = function (key) {\n return key in this._lookup\n}\n\n/**\n * Retrieves a key from the cache and marks it as recently used.\n *\n * @param {String} key - the key to retrieve from the cache.\n * @return {*}\n */\ncache.get = function (key) {\n if (!this.has(key)) return null\n var record = this._lookup[key]\n // Update expiry for \"refresh\" keys\n if (record.refresh) this.expire(key, record.refresh)\n // Move to front of the line.\n this.items.splice(this.items.indexOf(record), 1)\n this.items.push(record)\n return record.value\n}\n\n/**\n * Retrieves user meta data for a cached item.\n *\n * @param {String} key - the key to retrieve meta data from the cache.\n * @return {*}\n */\ncache.meta = function (key) {\n if (!this.has(key)) return null\n var record = this._lookup[key]\n if (!('meta' in record)) return null\n return record.meta\n}\n\n/**\n * Puts a key into the cache with an optional expiry time.\n *\n * @param {String} key - the key for the value in the cache.\n * @param {*} value - the value to place at the key.\n * @param {Number} [options.ttl] - a time after which the key will be removed.\n * @return {Receptacle}\n */\ncache.set = function (key, value, options) {\n var oldRecord = this._lookup[key]\n var record = this._lookup[key] = { key: key, value: value }\n // Mark cache as modified.\n this.lastModified = new Date()\n\n if (oldRecord) {\n // Replace an old key.\n clearTimeout(oldRecord.timeout)\n this.items.splice(this.items.indexOf(oldRecord), 1, record)\n } else {\n // Remove least used item if needed.\n if (this.size >= this.max) this.delete(this.items[0].key)\n // Add a new key.\n this.items.push(record)\n this.size++\n }\n\n if (options) {\n // Setup key expiry.\n if ('ttl' in options) this.expire(key, options.ttl)\n // Store user options in the record.\n if ('meta' in options) record.meta = options.meta\n // Mark a auto refresh key.\n if (options.refresh) record.refresh = options.ttl\n }\n\n return this\n}\n\n/**\n * Deletes an item from the cache.\n *\n * @param {String} key - the key to remove.\n * @return {Receptacle}\n */\ncache.delete = function (key) {\n var record = this._lookup[key]\n if (!record) return false\n this.lastModified = new Date()\n this.items.splice(this.items.indexOf(record), 1)\n clearTimeout(record.timeout)\n delete this._lookup[key]\n this.size--\n return this\n}\n\n/**\n * Utility to register a key that will be removed after some time.\n *\n * @param {String} key - the key to remove.\n * @param {Number} [ms] - the timeout before removal.\n * @return {Receptacle}\n */\ncache.expire = function (key, ttl) {\n var ms = ttl || 0\n var record = this._lookup[key]\n if (!record) return this\n if (typeof ms === 'string') ms = toMS(ttl)\n if (typeof ms !== 'number') throw new TypeError('Expiration time must be a string or number.')\n clearTimeout(record.timeout)\n record.timeout = setTimeout(this.delete.bind(this, record.key), ms)\n record.expires = Number(new Date()) + ms\n return this\n}\n\n/**\n * Deletes all items from the cache.\n * @return {Receptacle}\n */\ncache.clear = function () {\n for (var i = this.items.length; i--;) this.delete(this.items[i].key)\n return this\n}\n\n/**\n * Fixes serialization issues in polyfilled environments.\n * Ensures non-cyclical serialized object.\n */\ncache.toJSON = function () {\n var items = new Array(this.items.length)\n var item\n for (var i = items.length; i--;) {\n item = this.items[i]\n items[i] = {\n key: item.key,\n meta: item.meta,\n value: item.value,\n expires: item.expires,\n refresh: item.refresh\n }\n }\n\n return {\n id: this.id,\n max: isFinite(this.max) ? this.max : undefined,\n lastModified: this.lastModified,\n items: items\n }\n}\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function (val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","'use strict'\n\nconst { default: nativeFetch, Headers } = require('native-fetch')\n\n/**\n * Build fetch resource for request.\n *\n * @param {object} properties\n * @param {string} properties.serverResolver\n * @param {string} properties.hostname\n * @param {string} properties.recordType\n * @returns {string}\n */\nfunction buildResource ({ serverResolver, hostname, recordType }) {\n return `${serverResolver}?name=${hostname}&type=${recordType}`\n}\n\n/**\n * Use fetch to find the record.\n *\n * @param {object} resource\n * @returns {Promise}\n */\nfunction fetch (resource) {\n return nativeFetch(resource, {\n headers: new Headers({\n accept: 'application/dns-json'\n })\n })\n}\n\n/**\n * Creates cache key composed by recordType and hostname.\n *\n * @param {string} hostname\n * @param {string} recordType\n * @returns {string}\n */\nfunction getCacheKey (hostname, recordType) {\n return `${recordType}_${hostname}`\n}\n\nmodule.exports = {\n buildResource,\n fetch,\n getCacheKey\n}\n","'use strict'\n\nmodule.exports = {\n DIAL_TIMEOUT: 30e3, // How long in ms a dial attempt is allowed to take\n MAX_PARALLEL_DIALS: 100, // Maximum allowed concurrent dials\n MAX_PER_PEER_DIALS: 4, // Allowed parallel dials per DialRequest\n MAX_ADDRS_TO_DIAL: 25, // Maximum number of allowed addresses to attempt to dial\n METRICS: {\n computeThrottleMaxQueueSize: 1000,\n computeThrottleTimeout: 2000,\n movingAverageIntervals: [\n 60 * 1000, // 1 minute\n 5 * 60 * 1000, // 5 minutes\n 15 * 60 * 1000 // 15 minutes\n ],\n maxOldPeersRetention: 50\n }\n}\n","'use strict'\n\n// @ts-ignore file not listed within the file list of projects\nconst libp2pVersion = require('../../package.json').version\n\nmodule.exports.PROTOCOL_VERSION = 'ipfs/0.1.0' // deprecated\nmodule.exports.AGENT_VERSION = `js-libp2p/${libp2pVersion}`\nmodule.exports.MULTICODEC_IDENTIFY = '/ipfs/id/1.0.0' // deprecated\nmodule.exports.MULTICODEC_IDENTIFY_PUSH = '/ipfs/id/push/1.0.0' // deprecated\n\nmodule.exports.IDENTIFY_PROTOCOL_VERSION = '0.1.0'\nmodule.exports.MULTICODEC_IDENTIFY_PROTOCOL_NAME = 'id'\nmodule.exports.MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME = 'id/push'\nmodule.exports.MULTICODEC_IDENTIFY_PROTOCOL_VERSION = '1.0.0'\nmodule.exports.MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION = '1.0.0'\n","{\n \"name\": \"libp2p\",\n \"version\": \"0.33.0\",\n \"description\": \"JavaScript implementation of libp2p, a modular peer to peer network stack\",\n \"leadMaintainer\": \"Jacob Heun \",\n \"main\": \"src/index.js\",\n \"types\": \"dist/src/index.d.ts\",\n \"typesVersions\": {\n \"*\": {\n \"src/*\": [\n \"dist/src/*\",\n \"dist/src/*/index\"\n ]\n }\n },\n \"files\": [\n \"dist\",\n \"src\"\n ],\n \"scripts\": {\n \"lint\": \"aegir lint\",\n \"build\": \"aegir build\",\n \"build:proto\": \"npm run build:proto:circuit && npm run build:proto:identify && npm run build:proto:plaintext && npm run build:proto:address-book && npm run build:proto:proto-book && npm run build:proto:peer-record && npm run build:proto:envelope\",\n \"build:proto:circuit\": \"pbjs -t static-module -w commonjs -r libp2p-circuit --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/circuit/protocol/index.js ./src/circuit/protocol/index.proto\",\n \"build:proto:identify\": \"pbjs -t static-module -w commonjs -r libp2p-identify --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/identify/message.js ./src/identify/message.proto\",\n \"build:proto:plaintext\": \"pbjs -t static-module -w commonjs -r libp2p-plaintext --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/insecure/proto.js ./src/insecure/proto.proto\",\n \"build:proto:address-book\": \"pbjs -t static-module -w commonjs -r libp2p-address-book --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/peer-store/persistent/pb/address-book.js ./src/peer-store/persistent/pb/address-book.proto\",\n \"build:proto:proto-book\": \"pbjs -t static-module -w commonjs -r libp2p-proto-book --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/peer-store/persistent/pb/proto-book.js ./src/peer-store/persistent/pb/proto-book.proto\",\n \"build:proto:peer-record\": \"pbjs -t static-module -w commonjs -r libp2p-peer-record --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/record/peer-record/peer-record.js ./src/record/peer-record/peer-record.proto\",\n \"build:proto:envelope\": \"pbjs -t static-module -w commonjs -r libp2p-envelope --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/record/envelope/envelope.js ./src/record/envelope/envelope.proto\",\n \"build:proto-types\": \"npm run build:proto-types:circuit && npm run build:proto-types:identify && npm run build:proto-types:plaintext && npm run build:proto-types:address-book && npm run build:proto-types:proto-book && npm run build:proto-types:peer-record && npm run build:proto-types:envelope\",\n \"build:proto-types:circuit\": \"pbts -o src/circuit/protocol/index.d.ts src/circuit/protocol/index.js\",\n \"build:proto-types:identify\": \"pbts -o src/identify/message.d.ts src/identify/message.js\",\n \"build:proto-types:plaintext\": \"pbts -o src/insecure/proto.d.ts src/insecure/proto.js\",\n \"build:proto-types:address-book\": \"pbts -o src/peer-store/persistent/pb/address-book.d.ts src/peer-store/persistent/pb/address-book.js\",\n \"build:proto-types:proto-book\": \"pbts -o src/peer-store/persistent/pb/proto-book.d.ts src/peer-store/persistent/pb/proto-book.js\",\n \"build:proto-types:peer-record\": \"pbts -o src/record/peer-record/peer-record.d.ts src/record/peer-record/peer-record.js\",\n \"build:proto-types:envelope\": \"pbts -o src/record/envelope/envelope.d.ts src/record/envelope/envelope.js\",\n \"test\": \"aegir test\",\n \"test:ts\": \"aegir build --no-bundle && npm run test --prefix test/ts-use\",\n \"test:node\": \"aegir test -t node -f \\\"./test/**/*.{node,spec}.js\\\"\",\n \"test:browser\": \"aegir test -t browser\",\n \"test:examples\": \"cd examples && npm run test:all\",\n \"prepare\": \"aegir build --no-bundle\",\n \"release\": \"aegir release -t node -t browser\",\n \"release-minor\": \"aegir release --type minor -t node -t browser\",\n \"release-major\": \"aegir release --type major -t node -t browser\",\n \"coverage\": \"nyc --reporter=text --reporter=lcov npm run test:node\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/libp2p/js-libp2p.git\"\n },\n \"keywords\": [\n \"libp2p\",\n \"network\",\n \"p2p\",\n \"peer\",\n \"peer-to-peer\",\n \"IPFS\"\n ],\n \"bugs\": {\n \"url\": \"https://github.com/libp2p/js-libp2p/issues\"\n },\n \"homepage\": \"https://libp2p.io\",\n \"license\": \"MIT\",\n \"engines\": {\n \"node\": \">=14.0.0\"\n },\n \"browser\": {\n \"@motrix/nat-api\": false\n },\n \"eslintConfig\": {\n \"extends\": \"ipfs\",\n \"ignorePatterns\": [\n \"!.aegir.js\",\n \"test/ts-use\"\n ]\n },\n \"dependencies\": {\n \"abortable-iterator\": \"^3.0.0\",\n \"@motrix/nat-api\": \"^0.3.1\",\n \"@vascosantos/moving-average\": \"^1.1.0\",\n \"abort-controller\": \"^3.0.0\",\n \"aggregate-error\": \"^3.1.0\",\n \"any-signal\": \"^2.1.1\",\n \"bignumber.js\": \"^9.0.1\",\n \"class-is\": \"^1.1.0\",\n \"debug\": \"^4.3.1\",\n \"err-code\": \"^3.0.0\",\n \"es6-promisify\": \"^7.0.0\",\n \"events\": \"^3.3.0\",\n \"hashlru\": \"^2.3.0\",\n \"interface-datastore\": \"^6.0.2\",\n \"it-all\": \"^1.0.4\",\n \"it-buffer\": \"^0.1.2\",\n \"it-drain\": \"^1.0.3\",\n \"it-filter\": \"^1.0.1\",\n \"it-first\": \"^1.0.4\",\n \"it-handshake\": \"^2.0.0\",\n \"it-length-prefixed\": \"^5.0.2\",\n \"it-map\": \"^1.0.4\",\n \"it-merge\": \"^1.0.0\",\n \"it-pipe\": \"^1.1.0\",\n \"it-take\": \"^1.0.0\",\n \"libp2p-crypto\": \"^0.19.4\",\n \"libp2p-interfaces\": \"^1.0.0\",\n \"libp2p-utils\": \"^0.4.0\",\n \"mafmt\": \"^10.0.0\",\n \"merge-options\": \"^3.0.4\",\n \"multiaddr\": \"^10.0.0\",\n \"multiformats\": \"^9.0.0\",\n \"multistream-select\": \"^2.0.0\",\n \"mutable-proxy\": \"^1.0.0\",\n \"node-forge\": \"^0.10.0\",\n \"p-any\": \"^3.0.0\",\n \"p-fifo\": \"^1.0.0\",\n \"p-retry\": \"^4.4.0\",\n \"p-settle\": \"^4.1.1\",\n \"peer-id\": \"^0.15.0\",\n \"private-ip\": \"^2.1.0\",\n \"protobufjs\": \"^6.10.2\",\n \"retimer\": \"^3.0.0\",\n \"sanitize-filename\": \"^1.6.3\",\n \"set-delayed-interval\": \"^1.0.0\",\n \"streaming-iterables\": \"^6.0.0\",\n \"timeout-abort-controller\": \"^1.1.1\",\n \"uint8arrays\": \"^3.0.0\",\n \"varint\": \"^6.0.0\",\n \"wherearewe\": \"^1.0.0\",\n \"xsalsa20\": \"^1.1.0\"\n },\n \"devDependencies\": {\n \"@chainsafe/libp2p-noise\": \"^4.0.0\",\n \"@nodeutils/defaults-deep\": \"^1.1.0\",\n \"@types/es6-promisify\": \"^6.0.0\",\n \"@types/node\": \"^16.0.1\",\n \"@types/node-forge\": \"^0.10.1\",\n \"@types/varint\": \"^6.0.0\",\n \"aegir\": \"^33.1.1\",\n \"buffer\": \"^6.0.3\",\n \"datastore-core\": \"^6.0.7\",\n \"delay\": \"^5.0.0\",\n \"interop-libp2p\": \"^0.4.0\",\n \"into-stream\": \"^7.0.0\",\n \"ipfs-http-client\": \"^52.0.2\",\n \"it-concat\": \"^2.0.0\",\n \"it-pair\": \"^1.0.0\",\n \"it-pushable\": \"^1.4.0\",\n \"libp2p\": \".\",\n \"libp2p-bootstrap\": \"^0.13.0\",\n \"libp2p-delegated-content-routing\": \"^0.11.0\",\n \"libp2p-delegated-peer-routing\": \"^0.10.0\",\n \"libp2p-floodsub\": \"^0.27.0\",\n \"libp2p-gossipsub\": \"^0.11.0\",\n \"libp2p-interfaces-compliance-tests\": \"^1.0.0\",\n \"libp2p-kad-dht\": \"^0.24.2\",\n \"libp2p-mdns\": \"^0.17.0\",\n \"libp2p-mplex\": \"^0.10.1\",\n \"libp2p-tcp\": \"^0.17.0\",\n \"libp2p-webrtc-star\": \"^0.23.0\",\n \"libp2p-websockets\": \"^0.16.0\",\n \"nock\": \"^13.0.3\",\n \"p-defer\": \"^3.0.0\",\n \"p-times\": \"^3.0.0\",\n \"p-wait-for\": \"^3.2.0\",\n \"rimraf\": \"^3.0.2\",\n \"sinon\": \"^11.1.1\",\n \"util\": \"^0.12.3\"\n },\n \"contributors\": [\n \"Vasco Santos \",\n \"David Dias \",\n \"Jacob Heun \",\n \"Alex Potsides \",\n \"Alan Shaw \",\n \"Cayman \",\n \"Pedro Teixeira \",\n \"Friedel Ziegelmayer \",\n \"Maciej Krüger \",\n \"Hugo Dias \",\n \"Chris Dostert \",\n \"dirkmc \",\n \"Volker Mische \",\n \"zeim839 <50573884+zeim839@users.noreply.github.com>\",\n \"Richard Littauer \",\n \"a1300 \",\n \"Ryan Bell \",\n \"ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ \",\n \"Franck Royer \",\n \"Thomas Eizinger \",\n \"Giovanni T. Parra \",\n \"acolytec3 <17355484+acolytec3@users.noreply.github.com>\",\n \"Elven \",\n \"Andrew Nesbitt \",\n \"Samlior \",\n \"Didrik Nordström \",\n \"RasmusErik Voel Jensen \",\n \"Robert Kiel \",\n \"Smite Chow \",\n \"Soeren \",\n \"Sönke Hahn \",\n \"TJKoury \",\n \"Tiago Alves \",\n \"XiaoZhang \",\n \"Yusef Napora \",\n \"Zane Starr \",\n \"ebinks \",\n \"Aditya Bose <13054902+adbose@users.noreply.github.com>\",\n \"isan_rivkin \",\n \"mayerwin \",\n \"mcclure \",\n \"phillmac \",\n \"robertkiel \",\n \"shresthagrawal <34920931+shresthagrawal@users.noreply.github.com>\",\n \"swedneck <40505480+swedneck@users.noreply.github.com>\",\n \"greenSnot \",\n \"Aleksei \",\n \"Bernd Strehl \",\n \"Chris Bratlien \",\n \"Cindy Wu \",\n \"Daijiro Wachi \",\n \"Diogo Silva \",\n \"Dmitriy Ryajov \",\n \"Ethan Lam \",\n \"Fei Liu \",\n \"Felipe Martins \",\n \"Florian-Merle \",\n \"Francis Gulotta \",\n \"Guy Sviry <32539816+guysv@users.noreply.github.com>\",\n \"Henrique Dias \",\n \"Irakli Gozalishvili \",\n \"Joel Gustafson \",\n \"John Rees \",\n \"João Santos \",\n \"Julien Bouquillon \",\n \"Kevin Kwok \",\n \"Kevin Lacker \",\n \"Lars Gierth \",\n \"Leask Wong \",\n \"Marcin Tojek \",\n \"Michael Burns <5170+mburns@users.noreply.github.com>\",\n \"Miguel Mota \",\n \"Nuno Nogueira \",\n \"Philipp Muens \"\n ]\n}\n","'use strict'\n\nconst minute = 60 * 1000\n\nmodule.exports = {\n ADVERTISE_BOOT_DELAY: 15 * minute, // Delay before HOP relay service is advertised on the network\n ADVERTISE_TTL: 30 * minute, // Delay Between HOP relay service advertisements on the network\n CIRCUIT_PROTO_CODE: 290, // Multicodec code\n HOP_METADATA_KEY: 'hop_relay', // PeerStore metadaBook key for HOP relay service\n HOP_METADATA_VALUE: 'true', // PeerStore metadaBook value for HOP relay service\n RELAY_RENDEZVOUS_NS: '/libp2p/relay' // Relay HOP relay service namespace for discovery\n}\n","'use strict'\n\nconst isPrivate = require('./multiaddr/is-private')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @typedef {Object} Address\n * @property {Multiaddr} multiaddr peer multiaddr.\n * @property {boolean} isCertified obtained from a signed peer record.\n */\n\n/**\n * Compare function for array.sort().\n * This sort aims to move the private adresses to the end of the array.\n * In case of equality, a certified address will come first.\n *\n * @param {Address} a\n * @param {Address} b\n * @returns {number}\n */\nfunction addressesPublicFirstCompareFunction (a, b) {\n const isAPrivate = isPrivate(a.multiaddr)\n const isBPrivate = isPrivate(b.multiaddr)\n\n if (isAPrivate && !isBPrivate) {\n return 1\n } else if (!isAPrivate && isBPrivate) {\n return -1\n }\n // Check certified?\n if (a.isCertified && !b.isCertified) {\n return -1\n } else if (!a.isCertified && b.isCertified) {\n return 1\n }\n\n return 0\n}\n\n/**\n * Sort given addresses by putting public addresses first.\n * In case of equality, a certified address will come first.\n *\n * @param {Array
} addresses\n * @returns {Array
}\n */\nfunction publicAddressesFirst (addresses) {\n return [...addresses].sort(addressesPublicFirstCompareFunction)\n}\n\nmodule.exports.publicAddressesFirst = publicAddressesFirst\n","'use strict'\n\n// @ts-ignore private-ip does not publish types\nconst isIpPrivate = require('private-ip')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * Check if a given multiaddr has a private address.\n *\n * @param {Multiaddr} ma\n * @returns {boolean}\n */\nfunction isPrivate (ma) {\n const { address } = ma.nodeAddress()\n\n return isIpPrivate(address)\n}\n\nmodule.exports = isPrivate\n","'use strict'\n\nmodule.exports = require('./lib').default\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst netmask_1 = require(\"netmask\");\nconst ip_regex_1 = __importDefault(require(\"ip-regex\"));\nconst is_ip_1 = __importDefault(require(\"is-ip\"));\nconst ipaddr_js_1 = require(\"ipaddr.js\");\nconst PRIVATE_IP_RANGES = [\n '0.0.0.0/8',\n '10.0.0.0/8',\n '100.64.0.0/10',\n '127.0.0.0/8',\n '169.254.0.0/16',\n '172.16.0.0/12',\n '192.0.0.0/24',\n '192.0.0.0/29',\n '192.0.0.8/32',\n '192.0.0.9/32',\n '192.0.0.10/32',\n '192.0.0.170/32',\n '192.0.0.171/32',\n '192.0.2.0/24',\n '192.31.196.0/24',\n '192.52.193.0/24',\n '192.88.99.0/24',\n '192.168.0.0/16',\n '192.175.48.0/24',\n '198.18.0.0/15',\n '198.51.100.0/24',\n '203.0.113.0/24',\n '240.0.0.0/4',\n '255.255.255.255/32'\n];\nconst NETMASK_RANGES = PRIVATE_IP_RANGES.map(ip_range => new netmask_1.Netmask(ip_range));\nfunction ipv4_check(ip_addr) {\n for (let r of NETMASK_RANGES) {\n if (r.contains(ip_addr))\n return true;\n }\n return false;\n}\nfunction ipv6_check(ip_addr) {\n return /^::$/.test(ip_addr) ||\n /^::1$/.test(ip_addr) ||\n /^::f{4}:([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/.test(ip_addr) ||\n /^::f{4}:0.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/.test(ip_addr) ||\n /^64:ff9b::([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/.test(ip_addr) ||\n /^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^f[c-d]([0-9a-fA-F]{2,2}):/i.test(ip_addr) ||\n /^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(ip_addr) ||\n /^ff([0-9a-fA-F]{2,2}):/i.test(ip_addr);\n}\nexports.default = (ip) => {\n if (ipaddr_js_1.isValid(ip)) {\n const parsed = ipaddr_js_1.parse(ip);\n if (parsed.kind() === 'ipv4')\n return ipv4_check(parsed.toNormalizedString());\n else if (parsed.kind() === 'ipv6')\n return ipv6_check(ip);\n }\n else if (is_ip_1.default(ip) && ip_regex_1.default.v6().test(ip))\n return ipv6_check(ip);\n return undefined;\n};\n","// Generated by CoffeeScript 1.12.7\n(function() {\n var Netmask, atob, chr, chr0, chrA, chra, ip2long, long2ip;\n\n long2ip = function(long) {\n var a, b, c, d;\n a = (long & (0xff << 24)) >>> 24;\n b = (long & (0xff << 16)) >>> 16;\n c = (long & (0xff << 8)) >>> 8;\n d = long & 0xff;\n return [a, b, c, d].join('.');\n };\n\n ip2long = function(ip) {\n var b, c, i, j, n, ref;\n b = [];\n for (i = j = 0; j <= 3; i = ++j) {\n if (ip.length === 0) {\n break;\n }\n if (i > 0) {\n if (ip[0] !== '.') {\n throw new Error('Invalid IP');\n }\n ip = ip.substring(1);\n }\n ref = atob(ip), n = ref[0], c = ref[1];\n ip = ip.substring(c);\n b.push(n);\n }\n if (ip.length !== 0) {\n throw new Error('Invalid IP');\n }\n switch (b.length) {\n case 1:\n if (b[0] > 0xFFFFFFFF) {\n throw new Error('Invalid IP');\n }\n return b[0] >>> 0;\n case 2:\n if (b[0] > 0xFF || b[1] > 0xFFFFFF) {\n throw new Error('Invalid IP');\n }\n return (b[0] << 24 | b[1]) >>> 0;\n case 3:\n if (b[0] > 0xFF || b[1] > 0xFF || b[2] > 0xFFFF) {\n throw new Error('Invalid IP');\n }\n return (b[0] << 24 | b[1] << 16 | b[2]) >>> 0;\n case 4:\n if (b[0] > 0xFF || b[1] > 0xFF || b[2] > 0xFF || b[3] > 0xFF) {\n throw new Error('Invalid IP');\n }\n return (b[0] << 24 | b[1] << 16 | b[2] << 8 | b[3]) >>> 0;\n default:\n throw new Error('Invalid IP');\n }\n };\n\n chr = function(b) {\n return b.charCodeAt(0);\n };\n\n chr0 = chr('0');\n\n chra = chr('a');\n\n chrA = chr('A');\n\n atob = function(s) {\n var base, dmax, i, n, start;\n n = 0;\n base = 10;\n dmax = '9';\n i = 0;\n if (s.length > 1 && s[i] === '0') {\n if (s[i + 1] === 'x' || s[i + 1] === 'X') {\n i += 2;\n base = 16;\n } else if ('0' <= s[i + 1] && s[i + 1] <= '9') {\n i++;\n base = 8;\n dmax = '7';\n }\n }\n start = i;\n while (i < s.length) {\n if ('0' <= s[i] && s[i] <= dmax) {\n n = (n * base + (chr(s[i]) - chr0)) >>> 0;\n } else if (base === 16) {\n if ('a' <= s[i] && s[i] <= 'f') {\n n = (n * base + (10 + chr(s[i]) - chra)) >>> 0;\n } else if ('A' <= s[i] && s[i] <= 'F') {\n n = (n * base + (10 + chr(s[i]) - chrA)) >>> 0;\n } else {\n break;\n }\n } else {\n break;\n }\n if (n > 0xFFFFFFFF) {\n throw new Error('too large');\n }\n i++;\n }\n if (i === start) {\n throw new Error('empty octet');\n }\n return [n, i];\n };\n\n Netmask = (function() {\n function Netmask(net, mask) {\n var error, i, j, ref;\n if (typeof net !== 'string') {\n throw new Error(\"Missing `net' parameter\");\n }\n if (!mask) {\n ref = net.split('/', 2), net = ref[0], mask = ref[1];\n }\n if (!mask) {\n mask = 32;\n }\n if (typeof mask === 'string' && mask.indexOf('.') > -1) {\n try {\n this.maskLong = ip2long(mask);\n } catch (error1) {\n error = error1;\n throw new Error(\"Invalid mask: \" + mask);\n }\n for (i = j = 32; j >= 0; i = --j) {\n if (this.maskLong === (0xffffffff << (32 - i)) >>> 0) {\n this.bitmask = i;\n break;\n }\n }\n } else if (mask || mask === 0) {\n this.bitmask = parseInt(mask, 10);\n this.maskLong = 0;\n if (this.bitmask > 0) {\n this.maskLong = (0xffffffff << (32 - this.bitmask)) >>> 0;\n }\n } else {\n throw new Error(\"Invalid mask: empty\");\n }\n try {\n this.netLong = (ip2long(net) & this.maskLong) >>> 0;\n } catch (error1) {\n error = error1;\n throw new Error(\"Invalid net address: \" + net);\n }\n if (!(this.bitmask <= 32)) {\n throw new Error(\"Invalid mask for ip4: \" + mask);\n }\n this.size = Math.pow(2, 32 - this.bitmask);\n this.base = long2ip(this.netLong);\n this.mask = long2ip(this.maskLong);\n this.hostmask = long2ip(~this.maskLong);\n this.first = this.bitmask <= 30 ? long2ip(this.netLong + 1) : this.base;\n this.last = this.bitmask <= 30 ? long2ip(this.netLong + this.size - 2) : long2ip(this.netLong + this.size - 1);\n this.broadcast = this.bitmask <= 30 ? long2ip(this.netLong + this.size - 1) : void 0;\n }\n\n Netmask.prototype.contains = function(ip) {\n if (typeof ip === 'string' && (ip.indexOf('/') > 0 || ip.split('.').length !== 4)) {\n ip = new Netmask(ip);\n }\n if (ip instanceof Netmask) {\n return this.contains(ip.base) && this.contains(ip.broadcast || ip.last);\n } else {\n return (ip2long(ip) & this.maskLong) >>> 0 === (this.netLong & this.maskLong) >>> 0;\n }\n };\n\n Netmask.prototype.next = function(count) {\n if (count == null) {\n count = 1;\n }\n return new Netmask(long2ip(this.netLong + (this.size * count)), this.mask);\n };\n\n Netmask.prototype.forEach = function(fn) {\n var index, lastLong, long;\n long = ip2long(this.first);\n lastLong = ip2long(this.last);\n index = 0;\n while (long <= lastLong) {\n fn(long2ip(long), long, index);\n index++;\n long++;\n }\n };\n\n Netmask.prototype.toString = function() {\n return this.base + \"/\" + this.bitmask;\n };\n\n return Netmask;\n\n })();\n\n exports.ip2long = ip2long;\n\n exports.long2ip = long2ip;\n\n exports.Netmask = Netmask;\n\n}).call(this);\n","(function (root) {\n 'use strict';\n // A list of regular expressions that match arbitrary IPv4 addresses,\n // for which a number of weird notations exist.\n // Note that an address like 0010.0xa5.1.1 is considered legal.\n const ipv4Part = '(0?\\\\d+|0x[a-f0-9]+)';\n const ipv4Regexes = {\n fourOctet: new RegExp(`^${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}$`, 'i'),\n threeOctet: new RegExp(`^${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}$`, 'i'),\n twoOctet: new RegExp(`^${ipv4Part}\\\\.${ipv4Part}$`, 'i'),\n longValue: new RegExp(`^${ipv4Part}$`, 'i')\n };\n\n // Regular Expression for checking Octal numbers\n const octalRegex = new RegExp(`^0[0-7]+$`, 'i');\n const hexRegex = new RegExp(`^0x[a-f0-9]+$`, 'i');\n\n const zoneIndex = '%[0-9a-z]{1,}';\n\n // IPv6-matching regular expressions.\n // For IPv6, the task is simpler: it is enough to match the colon-delimited\n // hexadecimal IPv6 and a transitional variant with dotted-decimal IPv4 at\n // the end.\n const ipv6Part = '(?:[0-9a-f]+::?)+';\n const ipv6Regexes = {\n zoneIndex: new RegExp(zoneIndex, 'i'),\n 'native': new RegExp(`^(::)?(${ipv6Part})?([0-9a-f]+)?(::)?(${zoneIndex})?$`, 'i'),\n deprecatedTransitional: new RegExp(`^(?:::)(${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}(${zoneIndex})?)$`, 'i'),\n transitional: new RegExp(`^((?:${ipv6Part})|(?:::)(?:${ipv6Part})?)${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}(${zoneIndex})?$`, 'i')\n };\n\n // Expand :: in an IPv6 address or address part consisting of `parts` groups.\n function expandIPv6 (string, parts) {\n // More than one '::' means invalid adddress\n if (string.indexOf('::') !== string.lastIndexOf('::')) {\n return null;\n }\n\n let colonCount = 0;\n let lastColon = -1;\n let zoneId = (string.match(ipv6Regexes.zoneIndex) || [])[0];\n let replacement, replacementCount;\n\n // Remove zone index and save it for later\n if (zoneId) {\n zoneId = zoneId.substring(1);\n string = string.replace(/%.+$/, '');\n }\n\n // How many parts do we already have?\n while ((lastColon = string.indexOf(':', lastColon + 1)) >= 0) {\n colonCount++;\n }\n\n // 0::0 is two parts more than ::\n if (string.substr(0, 2) === '::') {\n colonCount--;\n }\n\n if (string.substr(-2, 2) === '::') {\n colonCount--;\n }\n\n // The following loop would hang if colonCount > parts\n if (colonCount > parts) {\n return null;\n }\n\n // replacement = ':' + '0:' * (parts - colonCount)\n replacementCount = parts - colonCount;\n replacement = ':';\n while (replacementCount--) {\n replacement += '0:';\n }\n\n // Insert the missing zeroes\n string = string.replace('::', replacement);\n\n // Trim any garbage which may be hanging around if :: was at the edge in\n // the source strin\n if (string[0] === ':') {\n string = string.slice(1);\n }\n\n if (string[string.length - 1] === ':') {\n string = string.slice(0, -1);\n }\n\n parts = (function () {\n const ref = string.split(':');\n const results = [];\n\n for (let i = 0; i < ref.length; i++) {\n results.push(parseInt(ref[i], 16));\n }\n\n return results;\n })();\n\n return {\n parts: parts,\n zoneId: zoneId\n };\n }\n\n // A generic CIDR (Classless Inter-Domain Routing) RFC1518 range matcher.\n function matchCIDR (first, second, partSize, cidrBits) {\n if (first.length !== second.length) {\n throw new Error('ipaddr: cannot match CIDR for objects with different lengths');\n }\n\n let part = 0;\n let shift;\n\n while (cidrBits > 0) {\n shift = partSize - cidrBits;\n if (shift < 0) {\n shift = 0;\n }\n\n if (first[part] >> shift !== second[part] >> shift) {\n return false;\n }\n\n cidrBits -= partSize;\n part += 1;\n }\n\n return true;\n }\n\n function parseIntAuto (string) {\n // Hexadedimal base 16 (0x#)\n if (hexRegex.test(string)) {\n return parseInt(string, 16);\n }\n // While octal representation is discouraged by ECMAScript 3\n // and forbidden by ECMAScript 5, we silently allow it to\n // work only if the rest of the string has numbers less than 8.\n if (string[0] === '0' && !isNaN(parseInt(string[1], 10))) {\n if (octalRegex.test(string)) {\n return parseInt(string, 8);\n }\n throw new Error(`ipaddr: cannot parse ${string} as octal`);\n }\n // Always include the base 10 radix!\n return parseInt(string, 10);\n }\n\n function padPart (part, length) {\n while (part.length < length) {\n part = `0${part}`;\n }\n\n return part;\n }\n\n const ipaddr = {};\n\n // An IPv4 address (RFC791).\n ipaddr.IPv4 = (function () {\n // Constructs a new IPv4 address from an array of four octets\n // in network order (MSB first)\n // Verifies the input.\n function IPv4 (octets) {\n if (octets.length !== 4) {\n throw new Error('ipaddr: ipv4 octet count should be 4');\n }\n\n let i, octet;\n\n for (i = 0; i < octets.length; i++) {\n octet = octets[i];\n if (!((0 <= octet && octet <= 255))) {\n throw new Error('ipaddr: ipv4 octet should fit in 8 bits');\n }\n }\n\n this.octets = octets;\n }\n\n // Special IPv4 address ranges.\n // See also https://en.wikipedia.org/wiki/Reserved_IP_addresses\n IPv4.prototype.SpecialRanges = {\n unspecified: [[new IPv4([0, 0, 0, 0]), 8]],\n broadcast: [[new IPv4([255, 255, 255, 255]), 32]],\n // RFC3171\n multicast: [[new IPv4([224, 0, 0, 0]), 4]],\n // RFC3927\n linkLocal: [[new IPv4([169, 254, 0, 0]), 16]],\n // RFC5735\n loopback: [[new IPv4([127, 0, 0, 0]), 8]],\n // RFC6598\n carrierGradeNat: [[new IPv4([100, 64, 0, 0]), 10]],\n // RFC1918\n 'private': [\n [new IPv4([10, 0, 0, 0]), 8],\n [new IPv4([172, 16, 0, 0]), 12],\n [new IPv4([192, 168, 0, 0]), 16]\n ],\n // Reserved and testing-only ranges; RFCs 5735, 5737, 2544, 1700\n reserved: [\n [new IPv4([192, 0, 0, 0]), 24],\n [new IPv4([192, 0, 2, 0]), 24],\n [new IPv4([192, 88, 99, 0]), 24],\n [new IPv4([198, 51, 100, 0]), 24],\n [new IPv4([203, 0, 113, 0]), 24],\n [new IPv4([240, 0, 0, 0]), 4]\n ]\n };\n\n // The 'kind' method exists on both IPv4 and IPv6 classes.\n IPv4.prototype.kind = function () {\n return 'ipv4';\n };\n\n // Checks if this address matches other one within given CIDR range.\n IPv4.prototype.match = function (other, cidrRange) {\n let ref;\n if (cidrRange === undefined) {\n ref = other;\n other = ref[0];\n cidrRange = ref[1];\n }\n\n if (other.kind() !== 'ipv4') {\n throw new Error('ipaddr: cannot match ipv4 address with non-ipv4 one');\n }\n\n return matchCIDR(this.octets, other.octets, 8, cidrRange);\n };\n\n // returns a number of leading ones in IPv4 address, making sure that\n // the rest is a solid sequence of 0's (valid netmask)\n // returns either the CIDR length or null if mask is not valid\n IPv4.prototype.prefixLengthFromSubnetMask = function () {\n let cidr = 0;\n // non-zero encountered stop scanning for zeroes\n let stop = false;\n // number of zeroes in octet\n const zerotable = {\n 0: 8,\n 128: 7,\n 192: 6,\n 224: 5,\n 240: 4,\n 248: 3,\n 252: 2,\n 254: 1,\n 255: 0\n };\n let i, octet, zeros;\n\n for (i = 3; i >= 0; i -= 1) {\n octet = this.octets[i];\n if (octet in zerotable) {\n zeros = zerotable[octet];\n if (stop && zeros !== 0) {\n return null;\n }\n\n if (zeros !== 8) {\n stop = true;\n }\n\n cidr += zeros;\n } else {\n return null;\n }\n }\n\n return 32 - cidr;\n };\n\n // Checks if the address corresponds to one of the special ranges.\n IPv4.prototype.range = function () {\n return ipaddr.subnetMatch(this, this.SpecialRanges);\n };\n\n // Returns an array of byte-sized values in network order (MSB first)\n IPv4.prototype.toByteArray = function () {\n return this.octets.slice(0);\n };\n\n // Converts this IPv4 address to an IPv4-mapped IPv6 address.\n IPv4.prototype.toIPv4MappedAddress = function () {\n return ipaddr.IPv6.parse(`::ffff:${this.toString()}`);\n };\n\n // Symmetrical method strictly for aligning with the IPv6 methods.\n IPv4.prototype.toNormalizedString = function () {\n return this.toString();\n };\n\n // Returns the address in convenient, decimal-dotted format.\n IPv4.prototype.toString = function () {\n return this.octets.join('.');\n };\n\n return IPv4;\n })();\n\n // A utility function to return broadcast address given the IPv4 interface and prefix length in CIDR notation\n ipaddr.IPv4.broadcastAddressFromCIDR = function (string) {\n\n try {\n const cidr = this.parseCIDR(string);\n const ipInterfaceOctets = cidr[0].toByteArray();\n const subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();\n const octets = [];\n let i = 0;\n while (i < 4) {\n // Broadcast address is bitwise OR between ip interface and inverted mask\n octets.push(parseInt(ipInterfaceOctets[i], 10) | parseInt(subnetMaskOctets[i], 10) ^ 255);\n i++;\n }\n\n return new this(octets);\n } catch (e) {\n throw new Error('ipaddr: the address does not have IPv4 CIDR format');\n }\n };\n\n // Checks if a given string is formatted like IPv4 address.\n ipaddr.IPv4.isIPv4 = function (string) {\n return this.parser(string) !== null;\n };\n\n // Checks if a given string is a valid IPv4 address.\n ipaddr.IPv4.isValid = function (string) {\n try {\n new this(this.parser(string));\n return true;\n } catch (e) {\n return false;\n }\n };\n\n // Checks if a given string is a full four-part IPv4 Address.\n ipaddr.IPv4.isValidFourPartDecimal = function (string) {\n if (ipaddr.IPv4.isValid(string) && string.match(/^(0|[1-9]\\d*)(\\.(0|[1-9]\\d*)){3}$/)) {\n return true;\n } else {\n return false;\n }\n };\n\n // A utility function to return network address given the IPv4 interface and prefix length in CIDR notation\n ipaddr.IPv4.networkAddressFromCIDR = function (string) {\n let cidr, i, ipInterfaceOctets, octets, subnetMaskOctets;\n\n try {\n cidr = this.parseCIDR(string);\n ipInterfaceOctets = cidr[0].toByteArray();\n subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();\n octets = [];\n i = 0;\n while (i < 4) {\n // Network address is bitwise AND between ip interface and mask\n octets.push(parseInt(ipInterfaceOctets[i], 10) & parseInt(subnetMaskOctets[i], 10));\n i++;\n }\n\n return new this(octets);\n } catch (e) {\n throw new Error('ipaddr: the address does not have IPv4 CIDR format');\n }\n };\n\n // Tries to parse and validate a string with IPv4 address.\n // Throws an error if it fails.\n ipaddr.IPv4.parse = function (string) {\n const parts = this.parser(string);\n\n if (parts === null) {\n throw new Error('ipaddr: string is not formatted like an IPv4 Address');\n }\n\n return new this(parts);\n };\n\n // Parses the string as an IPv4 Address with CIDR Notation.\n ipaddr.IPv4.parseCIDR = function (string) {\n let match;\n\n if ((match = string.match(/^(.+)\\/(\\d+)$/))) {\n const maskLength = parseInt(match[2]);\n if (maskLength >= 0 && maskLength <= 32) {\n const parsed = [this.parse(match[1]), maskLength];\n Object.defineProperty(parsed, 'toString', {\n value: function () {\n return this.join('/');\n }\n });\n return parsed;\n }\n }\n\n throw new Error('ipaddr: string is not formatted like an IPv4 CIDR range');\n };\n\n // Classful variants (like a.b, where a is an octet, and b is a 24-bit\n // value representing last three octets; this corresponds to a class C\n // address) are omitted due to classless nature of modern Internet.\n ipaddr.IPv4.parser = function (string) {\n let match, part, value;\n\n // parseInt recognizes all that octal & hexadecimal weirdness for us\n if ((match = string.match(ipv4Regexes.fourOctet))) {\n return (function () {\n const ref = match.slice(1, 6);\n const results = [];\n\n for (let i = 0; i < ref.length; i++) {\n part = ref[i];\n results.push(parseIntAuto(part));\n }\n\n return results;\n })();\n } else if ((match = string.match(ipv4Regexes.longValue))) {\n value = parseIntAuto(match[1]);\n if (value > 0xffffffff || value < 0) {\n throw new Error('ipaddr: address outside defined range');\n }\n\n return ((function () {\n const results = [];\n let shift;\n\n for (shift = 0; shift <= 24; shift += 8) {\n results.push((value >> shift) & 0xff);\n }\n\n return results;\n })()).reverse();\n } else if ((match = string.match(ipv4Regexes.twoOctet))) {\n return (function () {\n const ref = match.slice(1, 4);\n const results = [];\n\n value = parseIntAuto(ref[1]);\n if (value > 0xffffff || value < 0) {\n throw new Error('ipaddr: address outside defined range');\n }\n\n results.push(parseIntAuto(ref[0]));\n results.push((value >> 16) & 0xff);\n results.push((value >> 8) & 0xff);\n results.push( value & 0xff);\n\n return results;\n })();\n } else if ((match = string.match(ipv4Regexes.threeOctet))) {\n return (function () {\n const ref = match.slice(1, 5);\n const results = [];\n\n value = parseIntAuto(ref[2]);\n if (value > 0xffff || value < 0) {\n throw new Error('ipaddr: address outside defined range');\n }\n\n results.push(parseIntAuto(ref[0]));\n results.push(parseIntAuto(ref[1]));\n results.push((value >> 8) & 0xff);\n results.push( value & 0xff);\n\n return results;\n })();\n } else {\n return null;\n }\n };\n\n // A utility function to return subnet mask in IPv4 format given the prefix length\n ipaddr.IPv4.subnetMaskFromPrefixLength = function (prefix) {\n prefix = parseInt(prefix);\n if (prefix < 0 || prefix > 32) {\n throw new Error('ipaddr: invalid IPv4 prefix length');\n }\n\n const octets = [0, 0, 0, 0];\n let j = 0;\n const filledOctetCount = Math.floor(prefix / 8);\n\n while (j < filledOctetCount) {\n octets[j] = 255;\n j++;\n }\n\n if (filledOctetCount < 4) {\n octets[filledOctetCount] = Math.pow(2, prefix % 8) - 1 << 8 - (prefix % 8);\n }\n\n return new this(octets);\n };\n\n // An IPv6 address (RFC2460)\n ipaddr.IPv6 = (function () {\n // Constructs an IPv6 address from an array of eight 16 - bit parts\n // or sixteen 8 - bit parts in network order(MSB first).\n // Throws an error if the input is invalid.\n function IPv6 (parts, zoneId) {\n let i, part;\n\n if (parts.length === 16) {\n this.parts = [];\n for (i = 0; i <= 14; i += 2) {\n this.parts.push((parts[i] << 8) | parts[i + 1]);\n }\n } else if (parts.length === 8) {\n this.parts = parts;\n } else {\n throw new Error('ipaddr: ipv6 part count should be 8 or 16');\n }\n\n for (i = 0; i < this.parts.length; i++) {\n part = this.parts[i];\n if (!((0 <= part && part <= 0xffff))) {\n throw new Error('ipaddr: ipv6 part should fit in 16 bits');\n }\n }\n\n if (zoneId) {\n this.zoneId = zoneId;\n }\n }\n\n // Special IPv6 ranges\n IPv6.prototype.SpecialRanges = {\n // RFC4291, here and after\n unspecified: [new IPv6([0, 0, 0, 0, 0, 0, 0, 0]), 128],\n linkLocal: [new IPv6([0xfe80, 0, 0, 0, 0, 0, 0, 0]), 10],\n multicast: [new IPv6([0xff00, 0, 0, 0, 0, 0, 0, 0]), 8],\n loopback: [new IPv6([0, 0, 0, 0, 0, 0, 0, 1]), 128],\n uniqueLocal: [new IPv6([0xfc00, 0, 0, 0, 0, 0, 0, 0]), 7],\n ipv4Mapped: [new IPv6([0, 0, 0, 0, 0, 0xffff, 0, 0]), 96],\n // RFC6145\n rfc6145: [new IPv6([0, 0, 0, 0, 0xffff, 0, 0, 0]), 96],\n // RFC6052\n rfc6052: [new IPv6([0x64, 0xff9b, 0, 0, 0, 0, 0, 0]), 96],\n // RFC3056\n '6to4': [new IPv6([0x2002, 0, 0, 0, 0, 0, 0, 0]), 16],\n // RFC6052, RFC6146\n teredo: [new IPv6([0x2001, 0, 0, 0, 0, 0, 0, 0]), 32],\n // RFC4291\n reserved: [[new IPv6([0x2001, 0xdb8, 0, 0, 0, 0, 0, 0]), 32]]\n };\n\n // Checks if this address is an IPv4-mapped IPv6 address.\n IPv6.prototype.isIPv4MappedAddress = function () {\n return this.range() === 'ipv4Mapped';\n };\n\n // The 'kind' method exists on both IPv4 and IPv6 classes.\n IPv6.prototype.kind = function () {\n return 'ipv6';\n };\n\n // Checks if this address matches other one within given CIDR range.\n IPv6.prototype.match = function (other, cidrRange) {\n let ref;\n\n if (cidrRange === undefined) {\n ref = other;\n other = ref[0];\n cidrRange = ref[1];\n }\n\n if (other.kind() !== 'ipv6') {\n throw new Error('ipaddr: cannot match ipv6 address with non-ipv6 one');\n }\n\n return matchCIDR(this.parts, other.parts, 16, cidrRange);\n };\n\n // returns a number of leading ones in IPv6 address, making sure that\n // the rest is a solid sequence of 0's (valid netmask)\n // returns either the CIDR length or null if mask is not valid\n IPv6.prototype.prefixLengthFromSubnetMask = function () {\n let cidr = 0;\n // non-zero encountered stop scanning for zeroes\n let stop = false;\n // number of zeroes in octet\n const zerotable = {\n 0: 16,\n 32768: 15,\n 49152: 14,\n 57344: 13,\n 61440: 12,\n 63488: 11,\n 64512: 10,\n 65024: 9,\n 65280: 8,\n 65408: 7,\n 65472: 6,\n 65504: 5,\n 65520: 4,\n 65528: 3,\n 65532: 2,\n 65534: 1,\n 65535: 0\n };\n let part, zeros;\n\n for (let i = 7; i >= 0; i -= 1) {\n part = this.parts[i];\n if (part in zerotable) {\n zeros = zerotable[part];\n if (stop && zeros !== 0) {\n return null;\n }\n\n if (zeros !== 16) {\n stop = true;\n }\n\n cidr += zeros;\n } else {\n return null;\n }\n }\n\n return 128 - cidr;\n };\n\n\n // Checks if the address corresponds to one of the special ranges.\n IPv6.prototype.range = function () {\n return ipaddr.subnetMatch(this, this.SpecialRanges);\n };\n\n // Returns an array of byte-sized values in network order (MSB first)\n IPv6.prototype.toByteArray = function () {\n let part;\n const bytes = [];\n const ref = this.parts;\n for (let i = 0; i < ref.length; i++) {\n part = ref[i];\n bytes.push(part >> 8);\n bytes.push(part & 0xff);\n }\n\n return bytes;\n };\n\n // Returns the address in expanded format with all zeroes included, like\n // 2001:0db8:0008:0066:0000:0000:0000:0001\n IPv6.prototype.toFixedLengthString = function () {\n const addr = ((function () {\n const results = [];\n for (let i = 0; i < this.parts.length; i++) {\n results.push(padPart(this.parts[i].toString(16), 4));\n }\n\n return results;\n }).call(this)).join(':');\n\n let suffix = '';\n\n if (this.zoneId) {\n suffix = `%${this.zoneId}`;\n }\n\n return addr + suffix;\n };\n\n // Converts this address to IPv4 address if it is an IPv4-mapped IPv6 address.\n // Throws an error otherwise.\n IPv6.prototype.toIPv4Address = function () {\n if (!this.isIPv4MappedAddress()) {\n throw new Error('ipaddr: trying to convert a generic ipv6 address to ipv4');\n }\n\n const ref = this.parts.slice(-2);\n const high = ref[0];\n const low = ref[1];\n\n return new ipaddr.IPv4([high >> 8, high & 0xff, low >> 8, low & 0xff]);\n };\n\n // Returns the address in expanded format with all zeroes included, like\n // 2001:db8:8:66:0:0:0:1\n //\n // Deprecated: use toFixedLengthString() instead.\n IPv6.prototype.toNormalizedString = function () {\n const addr = ((function () {\n const results = [];\n\n for (let i = 0; i < this.parts.length; i++) {\n results.push(this.parts[i].toString(16));\n }\n\n return results;\n }).call(this)).join(':');\n\n let suffix = '';\n\n if (this.zoneId) {\n suffix = `%${this.zoneId}`;\n }\n\n return addr + suffix;\n };\n\n // Returns the address in compact, human-readable format like\n // 2001:db8:8:66::1\n // in line with RFC 5952 (see https://tools.ietf.org/html/rfc5952#section-4)\n IPv6.prototype.toRFC5952String = function () {\n const regex = /((^|:)(0(:|$)){2,})/g;\n const string = this.toNormalizedString();\n let bestMatchIndex = 0;\n let bestMatchLength = -1;\n let match;\n\n while ((match = regex.exec(string))) {\n if (match[0].length > bestMatchLength) {\n bestMatchIndex = match.index;\n bestMatchLength = match[0].length;\n }\n }\n\n if (bestMatchLength < 0) {\n return string;\n }\n\n return `${string.substring(0, bestMatchIndex)}::${string.substring(bestMatchIndex + bestMatchLength)}`;\n };\n\n // Returns the address in compact, human-readable format like\n // 2001:db8:8:66::1\n //\n // Deprecated: use toRFC5952String() instead.\n IPv6.prototype.toString = function () {\n // Replace the first sequence of 1 or more '0' parts with '::'\n return this.toNormalizedString().replace(/((^|:)(0(:|$))+)/, '::');\n };\n\n return IPv6;\n\n })();\n\n // A utility function to return broadcast address given the IPv6 interface and prefix length in CIDR notation\n ipaddr.IPv6.broadcastAddressFromCIDR = function (string) {\n try {\n const cidr = this.parseCIDR(string);\n const ipInterfaceOctets = cidr[0].toByteArray();\n const subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();\n const octets = [];\n let i = 0;\n while (i < 16) {\n // Broadcast address is bitwise OR between ip interface and inverted mask\n octets.push(parseInt(ipInterfaceOctets[i], 10) | parseInt(subnetMaskOctets[i], 10) ^ 255);\n i++;\n }\n\n return new this(octets);\n } catch (e) {\n throw new Error(`ipaddr: the address does not have IPv6 CIDR format (${e})`);\n }\n };\n\n // Checks if a given string is formatted like IPv6 address.\n ipaddr.IPv6.isIPv6 = function (string) {\n return this.parser(string) !== null;\n };\n\n // Checks to see if string is a valid IPv6 Address\n ipaddr.IPv6.isValid = function (string) {\n\n // Since IPv6.isValid is always called first, this shortcut\n // provides a substantial performance gain.\n if (typeof string === 'string' && string.indexOf(':') === -1) {\n return false;\n }\n\n try {\n const addr = this.parser(string);\n new this(addr.parts, addr.zoneId);\n return true;\n } catch (e) {\n return false;\n }\n };\n\n // A utility function to return network address given the IPv6 interface and prefix length in CIDR notation\n ipaddr.IPv6.networkAddressFromCIDR = function (string) {\n let cidr, i, ipInterfaceOctets, octets, subnetMaskOctets;\n\n try {\n cidr = this.parseCIDR(string);\n ipInterfaceOctets = cidr[0].toByteArray();\n subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();\n octets = [];\n i = 0;\n while (i < 16) {\n // Network address is bitwise AND between ip interface and mask\n octets.push(parseInt(ipInterfaceOctets[i], 10) & parseInt(subnetMaskOctets[i], 10));\n i++;\n }\n\n return new this(octets);\n } catch (e) {\n throw new Error(`ipaddr: the address does not have IPv6 CIDR format (${e})`);\n }\n };\n\n // Tries to parse and validate a string with IPv6 address.\n // Throws an error if it fails.\n ipaddr.IPv6.parse = function (string) {\n const addr = this.parser(string);\n\n if (addr.parts === null) {\n throw new Error('ipaddr: string is not formatted like an IPv6 Address');\n }\n\n return new this(addr.parts, addr.zoneId);\n };\n\n ipaddr.IPv6.parseCIDR = function (string) {\n let maskLength, match, parsed;\n\n if ((match = string.match(/^(.+)\\/(\\d+)$/))) {\n maskLength = parseInt(match[2]);\n if (maskLength >= 0 && maskLength <= 128) {\n parsed = [this.parse(match[1]), maskLength];\n Object.defineProperty(parsed, 'toString', {\n value: function () {\n return this.join('/');\n }\n });\n return parsed;\n }\n }\n\n throw new Error('ipaddr: string is not formatted like an IPv6 CIDR range');\n };\n\n // Parse an IPv6 address.\n ipaddr.IPv6.parser = function (string) {\n let addr, i, match, octet, octets, zoneId;\n\n if ((match = string.match(ipv6Regexes.deprecatedTransitional))) {\n return this.parser(`::ffff:${match[1]}`);\n }\n if (ipv6Regexes.native.test(string)) {\n return expandIPv6(string, 8);\n }\n if ((match = string.match(ipv6Regexes.transitional))) {\n zoneId = match[6] || '';\n addr = expandIPv6(match[1].slice(0, -1) + zoneId, 6);\n if (addr.parts) {\n octets = [\n parseInt(match[2]),\n parseInt(match[3]),\n parseInt(match[4]),\n parseInt(match[5])\n ];\n for (i = 0; i < octets.length; i++) {\n octet = octets[i];\n if (!((0 <= octet && octet <= 255))) {\n return null;\n }\n }\n\n addr.parts.push(octets[0] << 8 | octets[1]);\n addr.parts.push(octets[2] << 8 | octets[3]);\n return {\n parts: addr.parts,\n zoneId: addr.zoneId\n };\n }\n }\n\n return null;\n };\n\n // A utility function to return subnet mask in IPv6 format given the prefix length\n ipaddr.IPv6.subnetMaskFromPrefixLength = function (prefix) {\n prefix = parseInt(prefix);\n if (prefix < 0 || prefix > 128) {\n throw new Error('ipaddr: invalid IPv6 prefix length');\n }\n\n const octets = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];\n let j = 0;\n const filledOctetCount = Math.floor(prefix / 8);\n\n while (j < filledOctetCount) {\n octets[j] = 255;\n j++;\n }\n\n if (filledOctetCount < 16) {\n octets[filledOctetCount] = Math.pow(2, prefix % 8) - 1 << 8 - (prefix % 8);\n }\n\n return new this(octets);\n };\n\n // Try to parse an array in network order (MSB first) for IPv4 and IPv6\n ipaddr.fromByteArray = function (bytes) {\n const length = bytes.length;\n\n if (length === 4) {\n return new ipaddr.IPv4(bytes);\n } else if (length === 16) {\n return new ipaddr.IPv6(bytes);\n } else {\n throw new Error('ipaddr: the binary input is neither an IPv6 nor IPv4 address');\n }\n };\n\n // Checks if the address is valid IP address\n ipaddr.isValid = function (string) {\n return ipaddr.IPv6.isValid(string) || ipaddr.IPv4.isValid(string);\n };\n\n\n // Attempts to parse an IP Address, first through IPv6 then IPv4.\n // Throws an error if it could not be parsed.\n ipaddr.parse = function (string) {\n if (ipaddr.IPv6.isValid(string)) {\n return ipaddr.IPv6.parse(string);\n } else if (ipaddr.IPv4.isValid(string)) {\n return ipaddr.IPv4.parse(string);\n } else {\n throw new Error('ipaddr: the address has neither IPv6 nor IPv4 format');\n }\n };\n\n // Attempt to parse CIDR notation, first through IPv6 then IPv4.\n // Throws an error if it could not be parsed.\n ipaddr.parseCIDR = function (string) {\n try {\n return ipaddr.IPv6.parseCIDR(string);\n } catch (e) {\n try {\n return ipaddr.IPv4.parseCIDR(string);\n } catch (e2) {\n throw new Error('ipaddr: the address has neither IPv6 nor IPv4 CIDR format');\n }\n }\n };\n\n // Parse an address and return plain IPv4 address if it is an IPv4-mapped address\n ipaddr.process = function (string) {\n const addr = this.parse(string);\n\n if (addr.kind() === 'ipv6' && addr.isIPv4MappedAddress()) {\n return addr.toIPv4Address();\n } else {\n return addr;\n }\n };\n\n // An utility function to ease named range matching. See examples below.\n // rangeList can contain both IPv4 and IPv6 subnet entries and will not throw errors\n // on matching IPv4 addresses to IPv6 ranges or vice versa.\n ipaddr.subnetMatch = function (address, rangeList, defaultName) {\n let i, rangeName, rangeSubnets, subnet;\n\n if (defaultName === undefined || defaultName === null) {\n defaultName = 'unicast';\n }\n\n for (rangeName in rangeList) {\n if (Object.prototype.hasOwnProperty.call(rangeList, rangeName)) {\n rangeSubnets = rangeList[rangeName];\n // ECMA5 Array.isArray isn't available everywhere\n if (rangeSubnets[0] && !(rangeSubnets[0] instanceof Array)) {\n rangeSubnets = [rangeSubnets];\n }\n\n for (i = 0; i < rangeSubnets.length; i++) {\n subnet = rangeSubnets[i];\n if (address.kind() === subnet[0].kind() && address.match.apply(address, subnet)) {\n return rangeName;\n }\n }\n }\n }\n\n return defaultName;\n };\n\n // Export for both the CommonJS and browser-like environment\n if (typeof module !== 'undefined' && module.exports) {\n module.exports = ipaddr;\n\n } else {\n root.ipaddr = ipaddr;\n }\n\n}(this));\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:transports'), {\n error: debug('libp2p:transports:err')\n})\n\nconst pSettle = require('p-settle')\nconst { codes } = require('./errors')\nconst errCode = require('err-code')\n\nconst { updateSelfPeerRecord } = require('./record/utils')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/transport/types').TransportFactory} TransportFactory\n * @typedef {import('libp2p-interfaces/src/transport/types').Transport} Transport\n *\n * @typedef {Object} TransportManagerProperties\n * @property {import('./')} libp2p\n * @property {import('./upgrader')} upgrader\n *\n * @typedef {Object} TransportManagerOptions\n * @property {number} [faultTolerance = FAULT_TOLERANCE.FATAL_ALL] - Address listen error tolerance.\n */\n\nclass TransportManager {\n /**\n * @class\n * @param {TransportManagerProperties & TransportManagerOptions} options\n */\n constructor ({ libp2p, upgrader, faultTolerance = FAULT_TOLERANCE.FATAL_ALL }) {\n this.libp2p = libp2p\n this.upgrader = upgrader\n /** @type {Map} */\n this._transports = new Map()\n this._listeners = new Map()\n this._listenerOptions = new Map()\n this.faultTolerance = faultTolerance\n }\n\n /**\n * Adds a `Transport` to the manager\n *\n * @param {string} key\n * @param {TransportFactory} Transport\n * @param {*} transportOptions - Additional options to pass to the transport\n * @returns {void}\n */\n add (key, Transport, transportOptions = {}) {\n log('adding %s', key)\n if (!key) {\n throw errCode(new Error(`Transport must have a valid key, was given '${key}'`), codes.ERR_INVALID_KEY)\n }\n if (this._transports.has(key)) {\n throw errCode(new Error('There is already a transport with this key'), codes.ERR_DUPLICATE_TRANSPORT)\n }\n\n const transport = new Transport({\n ...transportOptions,\n libp2p: this.libp2p,\n upgrader: this.upgrader\n })\n\n this._transports.set(key, transport)\n this._listenerOptions.set(key, transportOptions.listenerOptions || {})\n if (!this._listeners.has(key)) {\n this._listeners.set(key, [])\n }\n }\n\n /**\n * Stops all listeners\n *\n * @async\n */\n async close () {\n const tasks = []\n for (const [key, listeners] of this._listeners) {\n log('closing listeners for %s', key)\n while (listeners.length) {\n const listener = listeners.pop()\n listener.removeAllListeners('listening')\n listener.removeAllListeners('close')\n tasks.push(listener.close())\n }\n }\n\n await Promise.all(tasks)\n log('all listeners closed')\n for (const key of this._listeners.keys()) {\n this._listeners.set(key, [])\n }\n }\n\n /**\n * Dials the given Multiaddr over it's supported transport\n *\n * @param {Multiaddr} ma\n * @param {*} options\n * @returns {Promise}\n */\n async dial (ma, options) {\n const transport = this.transportForMultiaddr(ma)\n if (!transport) {\n throw errCode(new Error(`No transport available for address ${String(ma)}`), codes.ERR_TRANSPORT_UNAVAILABLE)\n }\n\n try {\n return await transport.dial(ma, options)\n } catch (err) {\n if (!err.code) err.code = codes.ERR_TRANSPORT_DIAL_FAILED\n throw err\n }\n }\n\n /**\n * Returns all Multiaddr's the listeners are using\n *\n * @returns {Multiaddr[]}\n */\n getAddrs () {\n /** @type {Multiaddr[]} */\n let addrs = []\n for (const listeners of this._listeners.values()) {\n for (const listener of listeners) {\n addrs = [...addrs, ...listener.getAddrs()]\n }\n }\n return addrs\n }\n\n /**\n * Returns all the transports instances.\n *\n * @returns {IterableIterator}\n */\n getTransports () {\n return this._transports.values()\n }\n\n /**\n * Finds a transport that matches the given Multiaddr\n *\n * @param {Multiaddr} ma\n * @returns {Transport|null}\n */\n transportForMultiaddr (ma) {\n for (const transport of this._transports.values()) {\n const addrs = transport.filter([ma])\n if (addrs.length) return transport\n }\n return null\n }\n\n /**\n * Starts listeners for each listen Multiaddr.\n *\n * @async\n * @param {Multiaddr[]} addrs - addresses to attempt to listen on\n */\n async listen (addrs) {\n if (!addrs || addrs.length === 0) {\n log('no addresses were provided for listening, this node is dial only')\n return\n }\n\n const couldNotListen = []\n for (const [key, transport] of this._transports.entries()) {\n const supportedAddrs = transport.filter(addrs)\n const tasks = []\n\n // For each supported multiaddr, create a listener\n for (const addr of supportedAddrs) {\n log('creating listener for %s on %s', key, addr)\n const listener = transport.createListener(this._listenerOptions.get(key))\n this._listeners.get(key).push(listener)\n\n // Track listen/close events\n listener.on('listening', () => updateSelfPeerRecord(this.libp2p))\n listener.on('close', () => updateSelfPeerRecord(this.libp2p))\n\n // We need to attempt to listen on everything\n tasks.push(listener.listen(addr))\n }\n\n // Keep track of transports we had no addresses for\n if (tasks.length === 0) {\n couldNotListen.push(key)\n continue\n }\n\n const results = await pSettle(tasks)\n // If we are listening on at least 1 address, succeed.\n // TODO: we should look at adding a retry (`p-retry`) here to better support\n // listening on remote addresses as they may be offline. We could then potentially\n // just wait for any (`p-any`) listener to succeed on each transport before returning\n const isListening = results.find(r => r.isFulfilled === true)\n if (!isListening && this.faultTolerance !== FAULT_TOLERANCE.NO_FATAL) {\n throw errCode(new Error(`Transport (${key}) could not listen on any available address`), codes.ERR_NO_VALID_ADDRESSES)\n }\n }\n\n // If no transports were able to listen, throw an error. This likely\n // means we were given addresses we do not have transports for\n if (couldNotListen.length === this._transports.size) {\n const message = `no valid addresses were provided for transports [${couldNotListen}]`\n if (this.faultTolerance === FAULT_TOLERANCE.FATAL_ALL) {\n throw errCode(new Error(message), codes.ERR_NO_VALID_ADDRESSES)\n }\n log(`libp2p in dial mode only: ${message}`)\n }\n }\n\n /**\n * Removes the given transport from the manager.\n * If a transport has any running listeners, they will be closed.\n *\n * @async\n * @param {string} key\n */\n async remove (key) {\n log('removing %s', key)\n if (this._listeners.has(key)) {\n // Close any running listeners\n for (const listener of this._listeners.get(key)) {\n listener.removeAllListeners('listening')\n listener.removeAllListeners('close')\n await listener.close()\n }\n }\n\n this._transports.delete(key)\n this._listeners.delete(key)\n }\n\n /**\n * Removes all transports from the manager.\n * If any listeners are running, they will be closed.\n *\n * @async\n */\n async removeAll () {\n const tasks = []\n for (const key of this._transports.keys()) {\n tasks.push(this.remove(key))\n }\n\n await Promise.all(tasks)\n }\n}\n\n/**\n * Enum Transport Manager Fault Tolerance values.\n * FATAL_ALL should be used for failing in any listen circumstance.\n * NO_FATAL should be used for not failing when not listening.\n *\n * @readonly\n * @enum {number}\n */\nconst FAULT_TOLERANCE = {\n FATAL_ALL: 0,\n NO_FATAL: 1\n}\n\nTransportManager.FaultTolerance = FAULT_TOLERANCE\n\nmodule.exports = TransportManager\n","'use strict';\nconst pReflect = require('p-reflect');\nconst pLimit = require('p-limit');\n\nmodule.exports = async (array, options = {}) => {\n\tconst {concurrency = Infinity} = options;\n\tconst limit = pLimit(concurrency);\n\n\treturn Promise.all(array.map(element => {\n\t\tif (element && typeof element.then === 'function') { // eslint-disable-line promise/prefer-await-to-then\n\t\t\treturn pReflect(element);\n\t\t}\n\n\t\tif (typeof element === 'function') {\n\t\t\treturn pReflect(limit(() => element()));\n\t\t}\n\n\t\treturn pReflect(Promise.resolve(element));\n\t}));\n};\n","'use strict';\n\nconst pReflect = async promise => {\n\ttry {\n\t\tconst value = await promise;\n\t\treturn {\n\t\t\tisFulfilled: true,\n\t\t\tisRejected: false,\n\t\t\tvalue\n\t\t};\n\t} catch (error) {\n\t\treturn {\n\t\t\tisFulfilled: false,\n\t\t\tisRejected: true,\n\t\t\treason: error\n\t\t};\n\t}\n};\n\nmodule.exports = pReflect;\n// TODO: Remove this for the next major release\nmodule.exports.default = pReflect;\n","'use strict';\nconst pTry = require('p-try');\n\nconst pLimit = concurrency => {\n\tif (!((Number.isInteger(concurrency) || concurrency === Infinity) && concurrency > 0)) {\n\t\treturn Promise.reject(new TypeError('Expected `concurrency` to be a number from 1 and up'));\n\t}\n\n\tconst queue = [];\n\tlet activeCount = 0;\n\n\tconst next = () => {\n\t\tactiveCount--;\n\n\t\tif (queue.length > 0) {\n\t\t\tqueue.shift()();\n\t\t}\n\t};\n\n\tconst run = (fn, resolve, ...args) => {\n\t\tactiveCount++;\n\n\t\tconst result = pTry(fn, ...args);\n\n\t\tresolve(result);\n\n\t\tresult.then(next, next);\n\t};\n\n\tconst enqueue = (fn, resolve, ...args) => {\n\t\tif (activeCount < concurrency) {\n\t\t\trun(fn, resolve, ...args);\n\t\t} else {\n\t\t\tqueue.push(run.bind(null, fn, resolve, ...args));\n\t\t}\n\t};\n\n\tconst generator = (fn, ...args) => new Promise(resolve => enqueue(fn, resolve, ...args));\n\tObject.defineProperties(generator, {\n\t\tactiveCount: {\n\t\t\tget: () => activeCount\n\t\t},\n\t\tpendingCount: {\n\t\t\tget: () => queue.length\n\t\t},\n\t\tclearQueue: {\n\t\t\tvalue: () => {\n\t\t\t\tqueue.length = 0;\n\t\t\t}\n\t\t}\n\t});\n\n\treturn generator;\n};\n\nmodule.exports = pLimit;\nmodule.exports.default = pLimit;\n","'use strict';\n\nconst pTry = (fn, ...arguments_) => new Promise(resolve => {\n\tresolve(fn(...arguments_));\n});\n\nmodule.exports = pTry;\n// TODO: remove this in the next major version\nmodule.exports.default = pTry;\n","'use strict'\n\nconst Envelope = require('./envelope')\nconst PeerRecord = require('./peer-record')\n\n/**\n * @typedef {import('../')} Libp2p\n */\n\n/**\n * Create (or update if existing) self peer record and store it in the AddressBook.\n *\n * @param {Libp2p} libp2p\n * @returns {Promise}\n */\nasync function updateSelfPeerRecord (libp2p) {\n const peerRecord = new PeerRecord({\n peerId: libp2p.peerId,\n multiaddrs: libp2p.multiaddrs\n })\n const envelope = await Envelope.seal(peerRecord, libp2p.peerId)\n libp2p.peerStore.addressBook.consumePeerRecord(envelope)\n}\n\nmodule.exports.updateSelfPeerRecord = updateSelfPeerRecord\n","'use strict'\n\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\nconst arrayEquals = require('libp2p-utils/src/array-equals')\n\nconst { PeerRecord: Protobuf } = require('./peer-record')\nconst {\n ENVELOPE_DOMAIN_PEER_RECORD,\n ENVELOPE_PAYLOAD_TYPE_PEER_RECORD\n} = require('./consts')\n\n/**\n * @typedef {import('../../peer-store/address-book.js').Address} Address\n * @typedef {import('libp2p-interfaces/src/record/types').Record} Record\n */\n\n/**\n * @implements {Record}\n */\nclass PeerRecord {\n /**\n * The PeerRecord is used for distributing peer routing records across the network.\n * It contains the peer's reachable listen addresses.\n *\n * @class\n * @param {Object} params\n * @param {PeerId} params.peerId\n * @param {Multiaddr[]} params.multiaddrs - addresses of the associated peer.\n * @param {number} [params.seqNumber] - monotonically-increasing sequence counter that's used to order PeerRecords in time.\n */\n constructor ({ peerId, multiaddrs = [], seqNumber = Date.now() }) {\n this.domain = ENVELOPE_DOMAIN_PEER_RECORD\n this.codec = ENVELOPE_PAYLOAD_TYPE_PEER_RECORD\n\n this.peerId = peerId\n this.multiaddrs = multiaddrs\n this.seqNumber = seqNumber\n\n // Cache\n this._marshal = undefined\n }\n\n /**\n * Marshal a record to be used in an envelope.\n *\n * @returns {Uint8Array}\n */\n marshal () {\n if (this._marshal) {\n return this._marshal\n }\n\n this._marshal = Protobuf.encode({\n peerId: this.peerId.toBytes(),\n seq: this.seqNumber,\n addresses: this.multiaddrs.map((m) => ({\n multiaddr: m.bytes\n }))\n }).finish()\n\n return this._marshal\n }\n\n /**\n * Returns true if `this` record equals the `other`.\n *\n * @param {unknown} other\n * @returns {boolean}\n */\n equals (other) {\n if (!(other instanceof PeerRecord)) {\n return false\n }\n\n // Validate PeerId\n if (!this.peerId.equals(other.peerId)) {\n return false\n }\n\n // Validate seqNumber\n if (this.seqNumber !== other.seqNumber) {\n return false\n }\n\n // Validate multiaddrs\n if (!arrayEquals(this.multiaddrs, other.multiaddrs)) {\n return false\n }\n\n return true\n }\n}\n\n/**\n * Unmarshal Peer Record Protobuf.\n *\n * @param {Uint8Array} buf - marshaled peer record.\n * @returns {PeerRecord}\n */\nPeerRecord.createFromProtobuf = (buf) => {\n const peerRecord = Protobuf.decode(buf)\n\n const peerId = PeerId.createFromBytes(peerRecord.peerId)\n const multiaddrs = (peerRecord.addresses || []).map((a) => new Multiaddr(a.multiaddr))\n const seqNumber = Number(peerRecord.seq)\n\n return new PeerRecord({ peerId, multiaddrs, seqNumber })\n}\n\nPeerRecord.DOMAIN = ENVELOPE_DOMAIN_PEER_RECORD\n\nmodule.exports = PeerRecord\n","'use strict'\n\n/**\n * Verify if two arrays of non primitive types with the \"equals\" function are equal.\n * Compatible with multiaddr, peer-id and others.\n *\n * @param {Array<*>} a\n * @param {Array<*>} b\n * @returns {boolean}\n */\nfunction arrayEquals (a, b) {\n return a.length === b.length && b.sort() && a.sort().every((item, index) => b[index].equals(item))\n}\n\nmodule.exports = arrayEquals\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-peer-record\"] || ($protobuf.roots[\"libp2p-peer-record\"] = {});\n\n$root.PeerRecord = (function() {\n\n /**\n * Properties of a PeerRecord.\n * @exports IPeerRecord\n * @interface IPeerRecord\n * @property {Uint8Array|null} [peerId] PeerRecord peerId\n * @property {number|null} [seq] PeerRecord seq\n * @property {Array.|null} [addresses] PeerRecord addresses\n */\n\n /**\n * Constructs a new PeerRecord.\n * @exports PeerRecord\n * @classdesc Represents a PeerRecord.\n * @implements IPeerRecord\n * @constructor\n * @param {IPeerRecord=} [p] Properties to set\n */\n function PeerRecord(p) {\n this.addresses = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * PeerRecord peerId.\n * @member {Uint8Array} peerId\n * @memberof PeerRecord\n * @instance\n */\n PeerRecord.prototype.peerId = $util.newBuffer([]);\n\n /**\n * PeerRecord seq.\n * @member {number} seq\n * @memberof PeerRecord\n * @instance\n */\n PeerRecord.prototype.seq = $util.Long ? $util.Long.fromBits(0,0,true) : 0;\n\n /**\n * PeerRecord addresses.\n * @member {Array.} addresses\n * @memberof PeerRecord\n * @instance\n */\n PeerRecord.prototype.addresses = $util.emptyArray;\n\n /**\n * Encodes the specified PeerRecord message. Does not implicitly {@link PeerRecord.verify|verify} messages.\n * @function encode\n * @memberof PeerRecord\n * @static\n * @param {IPeerRecord} m PeerRecord message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PeerRecord.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.peerId != null && Object.hasOwnProperty.call(m, \"peerId\"))\n w.uint32(10).bytes(m.peerId);\n if (m.seq != null && Object.hasOwnProperty.call(m, \"seq\"))\n w.uint32(16).uint64(m.seq);\n if (m.addresses != null && m.addresses.length) {\n for (var i = 0; i < m.addresses.length; ++i)\n $root.PeerRecord.AddressInfo.encode(m.addresses[i], w.uint32(26).fork()).ldelim();\n }\n return w;\n };\n\n /**\n * Decodes a PeerRecord message from the specified reader or buffer.\n * @function decode\n * @memberof PeerRecord\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PeerRecord} PeerRecord\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PeerRecord.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PeerRecord();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.peerId = r.bytes();\n break;\n case 2:\n m.seq = r.uint64();\n break;\n case 3:\n if (!(m.addresses && m.addresses.length))\n m.addresses = [];\n m.addresses.push($root.PeerRecord.AddressInfo.decode(r, r.uint32()));\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a PeerRecord message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PeerRecord\n * @static\n * @param {Object.} d Plain object\n * @returns {PeerRecord} PeerRecord\n */\n PeerRecord.fromObject = function fromObject(d) {\n if (d instanceof $root.PeerRecord)\n return d;\n var m = new $root.PeerRecord();\n if (d.peerId != null) {\n if (typeof d.peerId === \"string\")\n $util.base64.decode(d.peerId, m.peerId = $util.newBuffer($util.base64.length(d.peerId)), 0);\n else if (d.peerId.length)\n m.peerId = d.peerId;\n }\n if (d.seq != null) {\n if ($util.Long)\n (m.seq = $util.Long.fromValue(d.seq)).unsigned = true;\n else if (typeof d.seq === \"string\")\n m.seq = parseInt(d.seq, 10);\n else if (typeof d.seq === \"number\")\n m.seq = d.seq;\n else if (typeof d.seq === \"object\")\n m.seq = new $util.LongBits(d.seq.low >>> 0, d.seq.high >>> 0).toNumber(true);\n }\n if (d.addresses) {\n if (!Array.isArray(d.addresses))\n throw TypeError(\".PeerRecord.addresses: array expected\");\n m.addresses = [];\n for (var i = 0; i < d.addresses.length; ++i) {\n if (typeof d.addresses[i] !== \"object\")\n throw TypeError(\".PeerRecord.addresses: object expected\");\n m.addresses[i] = $root.PeerRecord.AddressInfo.fromObject(d.addresses[i]);\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a PeerRecord message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PeerRecord\n * @static\n * @param {PeerRecord} m PeerRecord\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n PeerRecord.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.addresses = [];\n }\n if (o.defaults) {\n if (o.bytes === String)\n d.peerId = \"\";\n else {\n d.peerId = [];\n if (o.bytes !== Array)\n d.peerId = $util.newBuffer(d.peerId);\n }\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.seq = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.seq = o.longs === String ? \"0\" : 0;\n }\n if (m.peerId != null && m.hasOwnProperty(\"peerId\")) {\n d.peerId = o.bytes === String ? $util.base64.encode(m.peerId, 0, m.peerId.length) : o.bytes === Array ? Array.prototype.slice.call(m.peerId) : m.peerId;\n }\n if (m.seq != null && m.hasOwnProperty(\"seq\")) {\n if (typeof m.seq === \"number\")\n d.seq = o.longs === String ? String(m.seq) : m.seq;\n else\n d.seq = o.longs === String ? $util.Long.prototype.toString.call(m.seq) : o.longs === Number ? new $util.LongBits(m.seq.low >>> 0, m.seq.high >>> 0).toNumber(true) : m.seq;\n }\n if (m.addresses && m.addresses.length) {\n d.addresses = [];\n for (var j = 0; j < m.addresses.length; ++j) {\n d.addresses[j] = $root.PeerRecord.AddressInfo.toObject(m.addresses[j], o);\n }\n }\n return d;\n };\n\n /**\n * Converts this PeerRecord to JSON.\n * @function toJSON\n * @memberof PeerRecord\n * @instance\n * @returns {Object.} JSON object\n */\n PeerRecord.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n PeerRecord.AddressInfo = (function() {\n\n /**\n * Properties of an AddressInfo.\n * @memberof PeerRecord\n * @interface IAddressInfo\n * @property {Uint8Array|null} [multiaddr] AddressInfo multiaddr\n */\n\n /**\n * Constructs a new AddressInfo.\n * @memberof PeerRecord\n * @classdesc Represents an AddressInfo.\n * @implements IAddressInfo\n * @constructor\n * @param {PeerRecord.IAddressInfo=} [p] Properties to set\n */\n function AddressInfo(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * AddressInfo multiaddr.\n * @member {Uint8Array} multiaddr\n * @memberof PeerRecord.AddressInfo\n * @instance\n */\n AddressInfo.prototype.multiaddr = $util.newBuffer([]);\n\n /**\n * Encodes the specified AddressInfo message. Does not implicitly {@link PeerRecord.AddressInfo.verify|verify} messages.\n * @function encode\n * @memberof PeerRecord.AddressInfo\n * @static\n * @param {PeerRecord.IAddressInfo} m AddressInfo message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n AddressInfo.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.multiaddr != null && Object.hasOwnProperty.call(m, \"multiaddr\"))\n w.uint32(10).bytes(m.multiaddr);\n return w;\n };\n\n /**\n * Decodes an AddressInfo message from the specified reader or buffer.\n * @function decode\n * @memberof PeerRecord.AddressInfo\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PeerRecord.AddressInfo} AddressInfo\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n AddressInfo.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PeerRecord.AddressInfo();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.multiaddr = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an AddressInfo message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PeerRecord.AddressInfo\n * @static\n * @param {Object.} d Plain object\n * @returns {PeerRecord.AddressInfo} AddressInfo\n */\n AddressInfo.fromObject = function fromObject(d) {\n if (d instanceof $root.PeerRecord.AddressInfo)\n return d;\n var m = new $root.PeerRecord.AddressInfo();\n if (d.multiaddr != null) {\n if (typeof d.multiaddr === \"string\")\n $util.base64.decode(d.multiaddr, m.multiaddr = $util.newBuffer($util.base64.length(d.multiaddr)), 0);\n else if (d.multiaddr.length)\n m.multiaddr = d.multiaddr;\n }\n return m;\n };\n\n /**\n * Creates a plain object from an AddressInfo message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PeerRecord.AddressInfo\n * @static\n * @param {PeerRecord.AddressInfo} m AddressInfo\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n AddressInfo.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.multiaddr = \"\";\n else {\n d.multiaddr = [];\n if (o.bytes !== Array)\n d.multiaddr = $util.newBuffer(d.multiaddr);\n }\n }\n if (m.multiaddr != null && m.hasOwnProperty(\"multiaddr\")) {\n d.multiaddr = o.bytes === String ? $util.base64.encode(m.multiaddr, 0, m.multiaddr.length) : o.bytes === Array ? Array.prototype.slice.call(m.multiaddr) : m.multiaddr;\n }\n return d;\n };\n\n /**\n * Converts this AddressInfo to JSON.\n * @function toJSON\n * @memberof PeerRecord.AddressInfo\n * @instance\n * @returns {Object.} JSON object\n */\n AddressInfo.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return AddressInfo;\n })();\n\n return PeerRecord;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\n// The domain string used for peer records contained in a Envelope.\nconst domain = 'libp2p-peer-record'\n\n// The type hint used to identify peer records in a Envelope.\n// Defined in https://github.com/multiformats/multicodec/blob/master/table.csv\n// with name \"libp2p-peer-record\"\nconst payloadType = Uint8Array.from([3, 1])\n\nmodule.exports = {\n ENVELOPE_DOMAIN_PEER_RECORD: domain,\n ENVELOPE_PAYLOAD_TYPE_PEER_RECORD: payloadType\n}\n","'use strict'\n\nconst { EventEmitter } = require('events')\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\n\n/**\n * @typedef {Object} AddressManagerOptions\n * @property {string[]} [listen = []] - list of multiaddrs string representation to listen.\n * @property {string[]} [announce = []] - list of multiaddrs string representation to announce.\n */\n\n/**\n * @fires AddressManager#change:addresses Emitted when a addresses change.\n */\nclass AddressManager extends EventEmitter {\n /**\n * Responsible for managing the peer addresses.\n * Peers can specify their listen and announce addresses.\n * The listen addresses will be used by the libp2p transports to listen for new connections,\n * while the announce addresses will be used for the peer addresses' to other peers in the network.\n *\n * @class\n * @param {PeerId} peerId - The Peer ID of the node\n * @param {object} [options]\n * @param {Array} [options.listen = []] - list of multiaddrs string representation to listen.\n * @param {Array} [options.announce = []] - list of multiaddrs string representation to announce.\n */\n constructor (peerId, { listen = [], announce = [] } = {}) {\n super()\n\n this.peerId = peerId\n this.listen = new Set(listen.map(ma => ma.toString()))\n this.announce = new Set(announce.map(ma => ma.toString()))\n this.observed = new Set()\n }\n\n /**\n * Get peer listen multiaddrs.\n *\n * @returns {Multiaddr[]}\n */\n getListenAddrs () {\n return Array.from(this.listen).map((a) => new Multiaddr(a))\n }\n\n /**\n * Get peer announcing multiaddrs.\n *\n * @returns {Multiaddr[]}\n */\n getAnnounceAddrs () {\n return Array.from(this.announce).map((a) => new Multiaddr(a))\n }\n\n /**\n * Get observed multiaddrs.\n *\n * @returns {Array}\n */\n getObservedAddrs () {\n return Array.from(this.observed).map((a) => new Multiaddr(a))\n }\n\n /**\n * Add peer observed addresses\n *\n * @param {string | Multiaddr} addr\n */\n addObservedAddr (addr) {\n let ma = new Multiaddr(addr)\n const remotePeer = ma.getPeerId()\n\n // strip our peer id if it has been passed\n if (remotePeer) {\n const remotePeerId = PeerId.createFromB58String(remotePeer)\n\n // use same encoding for comparison\n if (remotePeerId.equals(this.peerId)) {\n ma = ma.decapsulate(new Multiaddr(`/p2p/${this.peerId}`))\n }\n }\n\n const addrString = ma.toString()\n\n // do not trigger the change:addresses event if we already know about this address\n if (this.observed.has(addrString)) {\n return\n }\n\n this.observed.add(addrString)\n this.emit('change:addresses')\n }\n}\n\nmodule.exports = AddressManager\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:connection-manager'), {\n error: debug('libp2p:connection-manager:err')\n})\n\nconst errcode = require('err-code')\nconst mergeOptions = require('merge-options')\nconst LatencyMonitor = require('./latency-monitor')\n// @ts-ignore retimer does not have types\nconst retimer = require('retimer')\n\nconst { EventEmitter } = require('events')\n\nconst PeerId = require('peer-id')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\nconst defaultOptions = {\n maxConnections: Infinity,\n minConnections: 0,\n maxData: Infinity,\n maxSentData: Infinity,\n maxReceivedData: Infinity,\n maxEventLoopDelay: Infinity,\n pollInterval: 2000,\n autoDialInterval: 10000,\n movingAverageInterval: 60000,\n defaultPeerValue: 1\n}\n\n/**\n * @typedef {import('../')} Libp2p\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n */\n\n/**\n * @typedef {Object} ConnectionManagerOptions\n * @property {number} [maxConnections = Infinity] - The maximum number of connections allowed.\n * @property {number} [minConnections = 0] - The minimum number of connections to avoid pruning.\n * @property {number} [maxData = Infinity] - The max data (in and out), per average interval to allow.\n * @property {number} [maxSentData = Infinity] - The max outgoing data, per average interval to allow.\n * @property {number} [maxReceivedData = Infinity] - The max incoming data, per average interval to allow.\n * @property {number} [maxEventLoopDelay = Infinity] - The upper limit the event loop can take to run.\n * @property {number} [pollInterval = 2000] - How often, in milliseconds, metrics and latency should be checked.\n * @property {number} [movingAverageInterval = 60000] - How often, in milliseconds, to compute averages.\n * @property {number} [defaultPeerValue = 1] - The value of the peer.\n * @property {boolean} [autoDial = true] - Should preemptively guarantee connections are above the low watermark.\n * @property {number} [autoDialInterval = 10000] - How often, in milliseconds, it should preemptively guarantee connections are above the low watermark.\n */\n\n/**\n *\n * @fires ConnectionManager#peer:connect Emitted when a new peer is connected.\n * @fires ConnectionManager#peer:disconnect Emitted when a peer is disconnected.\n */\nclass ConnectionManager extends EventEmitter {\n /**\n * Responsible for managing known connections.\n *\n * @class\n * @param {Libp2p} libp2p\n * @param {ConnectionManagerOptions} options\n */\n constructor (libp2p, options = {}) {\n super()\n\n this._libp2p = libp2p\n this._peerId = libp2p.peerId.toB58String()\n\n this._options = mergeOptions.call({ ignoreUndefined: true }, defaultOptions, options)\n if (this._options.maxConnections < this._options.minConnections) {\n throw errcode(new Error('Connection Manager maxConnections must be greater than minConnections'), ERR_INVALID_PARAMETERS)\n }\n\n log('options: %j', this._options)\n\n /**\n * Map of peer identifiers to their peer value for pruning connections.\n *\n * @type {Map}\n */\n this._peerValues = new Map()\n\n /**\n * Map of connections per peer\n *\n * @type {Map}\n */\n this.connections = new Map()\n\n this._started = false\n this._timer = null\n this._autoDialTimeout = null\n this._checkMetrics = this._checkMetrics.bind(this)\n this._autoDial = this._autoDial.bind(this)\n\n this._latencyMonitor = new LatencyMonitor({\n latencyCheckIntervalMs: this._options.pollInterval,\n dataEmitIntervalMs: this._options.pollInterval\n })\n }\n\n /**\n * Get current number of open connections.\n */\n get size () {\n return Array.from(this.connections.values())\n .reduce((accumulator, value) => accumulator + value.length, 0)\n }\n\n /**\n * Starts the Connection Manager. If Metrics are not enabled on libp2p\n * only event loop and connection limits will be monitored.\n */\n start () {\n if (this._libp2p.metrics) {\n this._timer = this._timer || retimer(this._checkMetrics, this._options.pollInterval)\n }\n\n // latency monitor\n this._latencyMonitor.start()\n this._onLatencyMeasure = this._onLatencyMeasure.bind(this)\n this._latencyMonitor.on('data', this._onLatencyMeasure)\n\n this._started = true\n log('started')\n\n this._options.autoDial && this._autoDial()\n }\n\n /**\n * Stops the Connection Manager\n *\n * @async\n */\n async stop () {\n this._autoDialTimeout && this._autoDialTimeout.clear()\n this._timer && this._timer.clear()\n\n this._latencyMonitor.removeListener('data', this._onLatencyMeasure)\n this._latencyMonitor.stop()\n\n this._started = false\n await this._close()\n log('stopped')\n }\n\n /**\n * Cleans up the connections\n *\n * @async\n */\n async _close () {\n // Close all connections we're tracking\n const tasks = []\n for (const connectionList of this.connections.values()) {\n for (const connection of connectionList) {\n tasks.push(connection.close())\n }\n }\n\n await Promise.all(tasks)\n this.connections.clear()\n }\n\n /**\n * Sets the value of the given peer. Peers with lower values\n * will be disconnected first.\n *\n * @param {PeerId} peerId\n * @param {number} value - A number between 0 and 1\n * @returns {void}\n */\n setPeerValue (peerId, value) {\n if (value < 0 || value > 1) {\n throw new Error('value should be a number between 0 and 1')\n }\n this._peerValues.set(peerId.toB58String(), value)\n }\n\n /**\n * Checks the libp2p metrics to determine if any values have exceeded\n * the configured maximums.\n *\n * @private\n */\n _checkMetrics () {\n if (this._libp2p.metrics) {\n const movingAverages = this._libp2p.metrics.global.movingAverages\n // @ts-ignore moving averages object types\n const received = movingAverages.dataReceived[this._options.movingAverageInterval].movingAverage()\n this._checkMaxLimit('maxReceivedData', received)\n // @ts-ignore moving averages object types\n const sent = movingAverages.dataSent[this._options.movingAverageInterval].movingAverage()\n this._checkMaxLimit('maxSentData', sent)\n const total = received + sent\n this._checkMaxLimit('maxData', total)\n log('metrics update', total)\n this._timer = retimer(this._checkMetrics, this._options.pollInterval)\n }\n }\n\n /**\n * Tracks the incoming connection and check the connection limit\n *\n * @param {Connection} connection\n * @returns {void}\n */\n onConnect (connection) {\n const peerId = connection.remotePeer\n const peerIdStr = peerId.toB58String()\n const storedConn = this.connections.get(peerIdStr)\n\n this.emit('peer:connect', connection)\n if (storedConn) {\n storedConn.push(connection)\n } else {\n this.connections.set(peerIdStr, [connection])\n }\n\n this._libp2p.peerStore.keyBook.set(peerId, peerId.pubKey)\n\n if (!this._peerValues.has(peerIdStr)) {\n this._peerValues.set(peerIdStr, this._options.defaultPeerValue)\n }\n\n this._checkMaxLimit('maxConnections', this.size)\n }\n\n /**\n * Removes the connection from tracking\n *\n * @param {Connection} connection\n * @returns {void}\n */\n onDisconnect (connection) {\n const peerId = connection.remotePeer.toB58String()\n let storedConn = this.connections.get(peerId)\n\n if (storedConn && storedConn.length > 1) {\n storedConn = storedConn.filter((conn) => conn.id !== connection.id)\n this.connections.set(peerId, storedConn)\n } else if (storedConn) {\n this.connections.delete(peerId)\n this._peerValues.delete(connection.remotePeer.toB58String())\n this.emit('peer:disconnect', connection)\n }\n }\n\n /**\n * Get a connection with a peer.\n *\n * @param {PeerId} peerId\n * @returns {Connection|null}\n */\n get (peerId) {\n const connections = this.getAll(peerId)\n if (connections.length) {\n return connections[0]\n }\n return null\n }\n\n /**\n * Get all open connections with a peer.\n *\n * @param {PeerId} peerId\n * @returns {Connection[]}\n */\n getAll (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const connections = this.connections.get(id)\n\n // Return all open connections\n if (connections) {\n return connections.filter(connection => connection.stat.status === 'open')\n }\n return []\n }\n\n /**\n * If the event loop is slow, maybe close a connection\n *\n * @private\n * @param {*} summary - The LatencyMonitor summary\n */\n _onLatencyMeasure (summary) {\n this._checkMaxLimit('maxEventLoopDelay', summary.avgMs)\n }\n\n /**\n * If the `value` of `name` has exceeded its limit, maybe close a connection\n *\n * @private\n * @param {string} name - The name of the field to check limits for\n * @param {number} value - The current value of the field\n */\n _checkMaxLimit (name, value) {\n const limit = this._options[name]\n log('checking limit of %s. current value: %d of %d', name, value, limit)\n if (value > limit) {\n log('%s: limit exceeded: %s, %d', this._peerId, name, value)\n this._maybeDisconnectOne()\n }\n }\n\n /**\n * Proactively tries to connect to known peers stored in the PeerStore.\n * It will keep the number of connections below the upper limit and sort\n * the peers to connect based on wether we know their keys and protocols.\n *\n * @async\n * @private\n */\n async _autoDial () {\n const minConnections = this._options.minConnections\n\n // Already has enough connections\n if (this.size >= minConnections) {\n this._autoDialTimeout = retimer(this._autoDial, this._options.autoDialInterval)\n return\n }\n\n // Sort peers on wether we know protocols of public keys for them\n const peers = Array.from(this._libp2p.peerStore.peers.values())\n .sort((a, b) => {\n if (b.protocols && b.protocols.length && (!a.protocols || !a.protocols.length)) {\n return 1\n } else if (b.id.pubKey && !a.id.pubKey) {\n return 1\n }\n return -1\n })\n\n for (let i = 0; i < peers.length && this.size < minConnections; i++) {\n if (!this.get(peers[i].id)) {\n log('connecting to a peerStore stored peer %s', peers[i].id.toB58String())\n try {\n await this._libp2p.dialer.connectToPeer(peers[i].id)\n\n // Connection Manager was stopped\n if (!this._started) {\n return\n }\n } catch (err) {\n log.error('could not connect to peerStore stored peer', err)\n }\n }\n }\n\n this._autoDialTimeout = retimer(this._autoDial, this._options.autoDialInterval)\n }\n\n /**\n * If we have more connections than our maximum, close a connection\n * to the lowest valued peer.\n *\n * @private\n */\n _maybeDisconnectOne () {\n if (this._options.minConnections < this.connections.size) {\n const peerValues = Array.from(new Map([...this._peerValues.entries()].sort((a, b) => a[1] - b[1])))\n log('%s: sorted peer values: %j', this._peerId, peerValues)\n const disconnectPeer = peerValues[0]\n if (disconnectPeer) {\n const peerId = disconnectPeer[0]\n log('%s: lowest value peer is %s', this._peerId, peerId)\n log('%s: closing a connection to %j', this._peerId, peerId)\n for (const connections of this.connections.values()) {\n if (connections[0].remotePeer.toB58String() === peerId) {\n connections[0].close()\n break\n }\n }\n }\n }\n }\n}\n\nmodule.exports = ConnectionManager\n","// @ts-nocheck\n'use strict'\n\n/**\n * This code is based on `latency-monitor` (https://github.com/mlucool/latency-monitor) by `mlucool` (https://github.com/mlucool), available under Apache License 2.0 (https://github.com/mlucool/latency-monitor/blob/master/LICENSE)\n */\n\nconst { EventEmitter } = require('events')\nconst VisibilityChangeEmitter = require('./visibility-change-emitter')\nconst debug = require('debug')('latency-monitor:LatencyMonitor')\n\n/**\n * @typedef {Object} SummaryObject\n * @property {number} events How many events were called\n * @property {number} minMS What was the min time for a cb to be called\n * @property {number} maxMS What was the max time for a cb to be called\n * @property {number} avgMs What was the average time for a cb to be called\n * @property {number} lengthMs How long this interval was in ms\n *\n * @typedef {Object} LatencyMonitorOptions\n * @property {number} [latencyCheckIntervalMs=500] - How often to add a latency check event (ms)\n * @property {number} [dataEmitIntervalMs=5000] - How often to summarize latency check events. null or 0 disables event firing\n * @property {Function} [asyncTestFn] - What cb-style async function to use\n * @property {number} [latencyRandomPercentage=5] - What percent (+/-) of latencyCheckIntervalMs should we randomly use? This helps avoid alignment to other events.\n */\n\n/**\n * A class to monitor latency of any async function which works in a browser or node. This works by periodically calling\n * the asyncTestFn and timing how long it takes the callback to be called. It can also periodically emit stats about this.\n * This can be disabled and stats can be pulled via setting dataEmitIntervalMs = 0.\n *\n * @extends {EventEmitter}\n *\n * The default implementation is an event loop latency monitor. This works by firing periodic events into the event loop\n * and timing how long it takes to get back.\n *\n * @example\n * const monitor = new LatencyMonitor();\n * monitor.on('data', (summary) => console.log('Event Loop Latency: %O', summary));\n *\n * @example\n * const monitor = new LatencyMonitor({latencyCheckIntervalMs: 1000, dataEmitIntervalMs: 60000, asyncTestFn:ping});\n * monitor.on('data', (summary) => console.log('Ping Pong Latency: %O', summary));\n */\nclass LatencyMonitor extends EventEmitter {\n /**\n * @class\n * @param {LatencyMonitorOptions} [options]\n */\n constructor ({ latencyCheckIntervalMs, dataEmitIntervalMs, asyncTestFn, latencyRandomPercentage } = {}) {\n super()\n const that = this\n\n // 0 isn't valid here, so its ok to use ||\n that.latencyCheckIntervalMs = latencyCheckIntervalMs || 500 // 0.5s\n that.latencyRandomPercentage = latencyRandomPercentage || 10\n that._latecyCheckMultiply = 2 * (that.latencyRandomPercentage / 100.0) * that.latencyCheckIntervalMs\n that._latecyCheckSubtract = that._latecyCheckMultiply / 2\n\n that.dataEmitIntervalMs = (dataEmitIntervalMs === null || dataEmitIntervalMs === 0)\n ? undefined\n : dataEmitIntervalMs || 5 * 1000 // 5s\n debug('latencyCheckIntervalMs: %s dataEmitIntervalMs: %s',\n that.latencyCheckIntervalMs, that.dataEmitIntervalMs)\n if (that.dataEmitIntervalMs) {\n debug('Expecting ~%s events per summary', that.latencyCheckIntervalMs / that.dataEmitIntervalMs)\n } else {\n debug('Not emitting summaries')\n }\n\n that.asyncTestFn = asyncTestFn // If there is no asyncFn, we measure latency\n }\n\n start () {\n // If process: use high resolution timer\n if (globalThis.process && globalThis.process.hrtime) { // eslint-disable-line no-undef\n debug('Using process.hrtime for timing')\n this.now = globalThis.process.hrtime // eslint-disable-line no-undef\n this.getDeltaMS = (startTime) => {\n const hrtime = this.now(startTime)\n return (hrtime[0] * 1000) + (hrtime[1] / 1000000)\n }\n // Let's try for a timer that only monotonically increases\n } else if (typeof window !== 'undefined' && window.performance && window.performance.now) {\n debug('Using performance.now for timing')\n this.now = window.performance.now.bind(window.performance)\n this.getDeltaMS = (startTime) => Math.round(this.now() - startTime)\n } else {\n debug('Using Date.now for timing')\n this.now = Date.now\n this.getDeltaMS = (startTime) => this.now() - startTime\n }\n\n this._latencyData = this._initLatencyData()\n\n // We check for isBrowser because of browsers set max rates of timeouts when a page is hidden,\n // so we fall back to another library\n // See: http://stackoverflow.com/questions/6032429/chrome-timeouts-interval-suspended-in-background-tabs\n if (isBrowser()) {\n this._visibilityChangeEmitter = new VisibilityChangeEmitter()\n\n this._visibilityChangeEmitter.on('visibilityChange', (pageInFocus) => {\n if (pageInFocus) {\n this._startTimers()\n } else {\n this._emitSummary()\n this._stopTimers()\n }\n })\n }\n\n if (!this._visibilityChangeEmitter || this._visibilityChangeEmitter.isVisible()) {\n this._startTimers()\n }\n }\n\n stop () {\n this._stopTimers()\n }\n\n /**\n * Start internal timers\n *\n * @private\n */\n _startTimers () {\n // Timer already started, ignore this\n if (this._checkLatencyID) {\n return\n }\n this._checkLatency()\n if (this.dataEmitIntervalMs) {\n this._emitIntervalID = setInterval(() => this._emitSummary(), this.dataEmitIntervalMs)\n if (typeof this._emitIntervalID.unref === 'function') {\n this._emitIntervalID.unref() // Doesn't block exit\n }\n }\n }\n\n /**\n * Stop internal timers\n *\n * @private\n */\n _stopTimers () {\n if (this._checkLatencyID) {\n clearTimeout(this._checkLatencyID)\n this._checkLatencyID = undefined\n }\n if (this._emitIntervalID) {\n clearInterval(this._emitIntervalID)\n this._emitIntervalID = undefined\n }\n }\n\n /**\n * Emit summary only if there were events. It might not have any events if it was forced via a page hidden/show\n *\n * @private\n */\n _emitSummary () {\n const summary = this.getSummary()\n if (summary.events > 0) {\n this.emit('data', summary)\n }\n }\n\n /**\n * Calling this function will end the collection period. If a timing event was already fired and somewhere in the queue,\n * it will not count for this time period\n *\n * @returns {SummaryObject}\n */\n getSummary () {\n // We might want to adjust for the number of expected events\n // Example: first 1 event it comes back, then such a long blocker that the next emit check comes\n // Then this fires - looks like no latency!!\n const latency = {\n events: this._latencyData.events,\n minMs: this._latencyData.minMs,\n maxMs: this._latencyData.maxMs,\n avgMs: this._latencyData.events\n ? this._latencyData.totalMs / this._latencyData.events\n : Number.POSITIVE_INFINITY,\n lengthMs: this.getDeltaMS(this._latencyData.startTime)\n }\n this._latencyData = this._initLatencyData() // Clear\n\n debug('Summary: %O', latency)\n return latency\n }\n\n /**\n * Randomly calls an async fn every roughly latencyCheckIntervalMs (plus some randomness). If no async fn is found,\n * it will simply report on event loop latency.\n *\n * @private\n */\n _checkLatency () {\n const that = this\n // Randomness is needed to avoid alignment by accident to regular things in the event loop\n const randomness = (Math.random() * that._latecyCheckMultiply) - that._latecyCheckSubtract\n\n // We use this to ensure that in case some overlap somehow, we don't take the wrong startTime/offset\n const localData = {\n deltaOffset: Math.ceil(that.latencyCheckIntervalMs + randomness),\n startTime: that.now()\n }\n\n const cb = () => {\n // We are already stopped, ignore this datapoint\n if (!this._checkLatencyID) {\n return\n }\n const deltaMS = that.getDeltaMS(localData.startTime) - localData.deltaOffset\n that._checkLatency() // Start again ASAP\n\n // Add the data point. If this gets complex, refactor it\n that._latencyData.events++\n that._latencyData.minMs = Math.min(that._latencyData.minMs, deltaMS)\n that._latencyData.maxMs = Math.max(that._latencyData.maxMs, deltaMS)\n that._latencyData.totalMs += deltaMS\n debug('MS: %s Data: %O', deltaMS, that._latencyData)\n }\n debug('localData: %O', localData)\n\n this._checkLatencyID = setTimeout(() => {\n // This gets rid of including event loop\n if (that.asyncTestFn) {\n // Clear timing related things\n localData.deltaOffset = 0\n localData.startTime = that.now()\n that.asyncTestFn(cb)\n } else {\n // setTimeout is not more accurate than 1ms, so this will ensure positive numbers. Add 1 to emitted data to remove.\n // This is not the best, but for now it'll be just fine. This isn't meant to be sub ms accurate.\n localData.deltaOffset -= 1\n // If there is no function to test, we mean check latency which is a special case that is really cb => cb()\n // We avoid that for the few extra function all overheads. Also, we want to keep the timers different\n cb()\n }\n }, localData.deltaOffset)\n\n if (typeof this._checkLatencyID.unref === 'function') {\n this._checkLatencyID.unref() // Doesn't block exit\n }\n }\n\n _initLatencyData () {\n return {\n startTime: this.now(),\n minMs: Number.POSITIVE_INFINITY,\n maxMs: Number.NEGATIVE_INFINITY,\n events: 0,\n totalMs: 0\n }\n }\n}\n\nfunction isBrowser () {\n return typeof window !== 'undefined'\n}\n\nmodule.exports = LatencyMonitor\n","// @ts-nocheck\n/* global document */\n\n/**\n * This code is based on `latency-monitor` (https://github.com/mlucool/latency-monitor) by `mlucool` (https://github.com/mlucool), available under Apache License 2.0 (https://github.com/mlucool/latency-monitor/blob/master/LICENSE)\n */\n'use strict'\n\nconst { EventEmitter } = require('events')\n\nconst debug = require('debug')('latency-monitor:VisibilityChangeEmitter')\n\n/**\n * Listen to page visibility change events (i.e. when the page is focused / blurred) by an event emitter.\n *\n * Warning: This does not work on all browsers, but should work on all modern browsers\n *\n * @example\n *\n * const myVisibilityEmitter = new VisibilityChangeEmitter();\n *\n * myVisibilityEmitter.on('visibilityChange', (pageInFocus) => {\n * if ( pageInFocus ){\n * // Page is in focus\n * console.log('In focus');\n * }\n * else {\n * // Page is blurred\n * console.log('Out of focus');\n * }\n * });\n * // To access the visibility state directly, call:\n * console.log('Am I focused now? ' + myVisibilityEmitter.isVisible());\n */\nclass VisibilityChangeEmitter extends EventEmitter {\n /**\n * Creates a VisibilityChangeEmitter\n *\n * @class\n */\n constructor () {\n super()\n if (typeof document === 'undefined') {\n debug('This is not a browser, no \"document\" found. Stopping.')\n return\n }\n this._initializeVisibilityVarNames()\n this._addVisibilityChangeListener()\n }\n\n /**\n * document.hidden and document.visibilityChange are the two variables we need to check for;\n * Since these variables are named differently in different browsers, this function sets\n * the appropriate name based on the browser being used. Once executed, tha actual names of\n * document.hidden and document.visibilityChange are found in this._hidden and this._visibilityChange\n * respectively\n *\n * @private\n */\n _initializeVisibilityVarNames () {\n let hidden\n let visibilityChange\n if (typeof document.hidden !== 'undefined') { // Opera 12.10 and Firefox 18 and later support\n hidden = 'hidden'\n visibilityChange = 'visibilitychange'\n } else if (typeof document.mozHidden !== 'undefined') {\n hidden = 'mozHidden'\n visibilityChange = 'mozvisibilitychange'\n } else if (typeof document.msHidden !== 'undefined') {\n hidden = 'msHidden'\n visibilityChange = 'msvisibilitychange'\n } else if (typeof document.webkitHidden !== 'undefined') {\n hidden = 'webkitHidden'\n visibilityChange = 'webkitvisibilitychange'\n }\n this._hidden = hidden\n this._visibilityChange = visibilityChange\n }\n\n /**\n * Adds an event listener on the document that listens to changes in document.visibilityChange\n * (or whatever name by which the visibilityChange variable is known in the browser)\n *\n * @private\n */\n _addVisibilityChangeListener () {\n if (typeof document.addEventListener === 'undefined' ||\n typeof document[this._hidden] === 'undefined') {\n debug('Checking page visibility requires a browser that supports the Page Visibility API.')\n } else {\n // Handle page visibility change\n document.addEventListener(this._visibilityChange, this._handleVisibilityChange.bind(this), false)\n }\n }\n\n /**\n * The function returns ```true``` if the page is visible or ```false``` if the page is not visible and\n * ```undefined``` if the page visibility API is not supported by the browser.\n *\n * @returns {boolean | void} whether the page is now visible or not (undefined is unknown)\n */\n isVisible () {\n if (this._hidden === undefined || document[this._hidden] === undefined) {\n return undefined\n }\n\n return !document[this._hidden]\n }\n\n /**\n * The function that is called when document.visibilityChange has changed\n * It emits an event called visibilityChange and sends the value of document.hidden as a\n * parameter\n *\n * @private\n */\n _handleVisibilityChange () {\n const visible = !document[this._hidden]\n debug(visible ? 'Page Visible' : 'Page Hidden')\n // Emit the event\n this.emit('visibilityChange', visible)\n }\n}\n\nmodule.exports = VisibilityChangeEmitter\n","'use strict'\n\nconst getTime = require('./time')\n\nclass Retimer {\n constructor (callback, timeout, args) {\n const that = this\n\n this._started = getTime()\n this._rescheduled = 0\n this._scheduled = timeout\n this._args = args\n this._triggered = false\n\n this._timerWrapper = () => {\n if (that._rescheduled > 0) {\n that._scheduled = that._rescheduled - (getTime() - that._started)\n that._schedule(that._scheduled)\n } else {\n that._triggered = true\n callback.apply(null, that._args)\n }\n }\n\n this._timer = setTimeout(this._timerWrapper, timeout)\n }\n\n reschedule (timeout) {\n if (!timeout) {\n timeout = this._scheduled\n }\n const now = getTime()\n if ((now + timeout) - (this._started + this._scheduled) < 0) {\n clearTimeout(this._timer)\n this._schedule(timeout)\n } else if (!this._triggered) {\n this._started = now\n this._rescheduled = timeout\n } else {\n this._schedule(timeout)\n }\n }\n\n _schedule (timeout) {\n this._triggered = false\n this._started = getTime()\n this._rescheduled = 0\n this._scheduled = timeout\n this._timer = setTimeout(this._timerWrapper, timeout)\n }\n\n clear () {\n clearTimeout(this._timer)\n }\n}\n\nfunction retimer () {\n if (typeof arguments[0] !== 'function') {\n throw new Error('callback needed')\n }\n\n if (typeof arguments[1] !== 'number') {\n throw new Error('timeout needed')\n }\n\n let args\n\n if (arguments.length > 0) {\n args = new Array(arguments.length - 2)\n\n /* eslint-disable no-var */\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 2]\n }\n }\n\n return new Retimer(arguments[0], arguments[1], args)\n}\n\nmodule.exports = retimer\n","'use strict'\n\nmodule.exports = function getTime () {\n return Date.now()\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:circuit'), {\n error: debug('libp2p:circuit:err')\n})\n\nconst errCode = require('err-code')\nconst mafmt = require('mafmt')\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\nconst { CircuitRelay: CircuitPB } = require('./protocol')\nconst { codes } = require('../errors')\n\nconst toConnection = require('libp2p-utils/src/stream-to-ma-conn')\n\nconst { relay: multicodec } = require('./multicodec')\nconst createListener = require('./listener')\nconst { handleCanHop, handleHop, hop } = require('./circuit/hop')\nconst { handleStop } = require('./circuit/stop')\nconst StreamHandler = require('./circuit/stream-handler')\n\nconst transportSymbol = Symbol.for('@libp2p/js-libp2p-circuit/circuit')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\nclass Circuit {\n /**\n * Creates an instance of the Circuit Transport.\n *\n * @class\n * @param {object} options\n * @param {import('../')} options.libp2p\n * @param {import('../upgrader')} options.upgrader\n */\n constructor ({ libp2p, upgrader }) {\n this._dialer = libp2p.dialer\n this._registrar = libp2p.registrar\n this._connectionManager = libp2p.connectionManager\n this._upgrader = upgrader\n this._options = libp2p._config.relay\n this._libp2p = libp2p\n this.peerId = libp2p.peerId\n\n this._registrar.handle(multicodec, this._onProtocol.bind(this))\n }\n\n /**\n * @param {Object} props\n * @param {Connection} props.connection\n * @param {MuxedStream} props.stream\n */\n async _onProtocol ({ connection, stream }) {\n /** @type {import('./circuit/stream-handler')} */\n const streamHandler = new StreamHandler({ stream })\n const request = await streamHandler.read()\n\n if (!request) {\n return\n }\n\n const circuit = this\n let virtualConnection\n\n switch (request.type) {\n case CircuitPB.Type.CAN_HOP: {\n log('received CAN_HOP request from %s', connection.remotePeer.toB58String())\n await handleCanHop({ circuit, connection, streamHandler })\n break\n }\n case CircuitPB.Type.HOP: {\n log('received HOP request from %s', connection.remotePeer.toB58String())\n virtualConnection = await handleHop({\n connection,\n request,\n streamHandler,\n circuit\n })\n break\n }\n case CircuitPB.Type.STOP: {\n log('received STOP request from %s', connection.remotePeer.toB58String())\n virtualConnection = await handleStop({\n connection,\n request,\n streamHandler\n })\n break\n }\n default: {\n log('Request of type %s not supported', request.type)\n }\n }\n\n if (virtualConnection) {\n // @ts-ignore dst peer will not be undefined\n const remoteAddr = new Multiaddr(request.dstPeer.addrs[0])\n // @ts-ignore src peer will not be undefined\n const localAddr = new Multiaddr(request.srcPeer.addrs[0])\n const maConn = toConnection({\n stream: virtualConnection,\n remoteAddr,\n localAddr\n })\n const type = request.type === CircuitPB.Type.HOP ? 'relay' : 'inbound'\n log('new %s connection %s', type, maConn.remoteAddr)\n\n const conn = await this._upgrader.upgradeInbound(maConn)\n log('%s connection %s upgraded', type, maConn.remoteAddr)\n this.handler && this.handler(conn)\n }\n }\n\n /**\n * Dial a peer over a relay\n *\n * @param {Multiaddr} ma - the multiaddr of the peer to dial\n * @param {Object} options - dial options\n * @param {AbortSignal} [options.signal] - An optional abort signal\n * @returns {Promise} - the connection\n */\n async dial (ma, options) {\n // Check the multiaddr to see if it contains a relay and a destination peer\n const addrs = ma.toString().split('/p2p-circuit')\n const relayAddr = new Multiaddr(addrs[0])\n const destinationAddr = new Multiaddr(addrs[addrs.length - 1])\n const relayId = relayAddr.getPeerId()\n const destinationId = destinationAddr.getPeerId()\n\n if (!relayId || !destinationId) {\n const errMsg = 'Circuit relay dial failed as addresses did not have peer id'\n log.error(errMsg)\n throw errCode(new Error(errMsg), codes.ERR_RELAYED_DIAL)\n }\n\n const relayPeer = PeerId.createFromB58String(relayId)\n const destinationPeer = PeerId.createFromB58String(destinationId)\n\n let disconnectOnFailure = false\n let relayConnection = this._connectionManager.get(relayPeer)\n if (!relayConnection) {\n relayConnection = await this._dialer.connectToPeer(relayAddr, options)\n disconnectOnFailure = true\n }\n\n try {\n const virtualConnection = await hop({\n connection: relayConnection,\n request: {\n type: CircuitPB.Type.HOP,\n srcPeer: {\n id: this.peerId.toBytes(),\n addrs: this._libp2p.multiaddrs.map(addr => addr.bytes)\n },\n dstPeer: {\n id: destinationPeer.toBytes(),\n addrs: [new Multiaddr(destinationAddr).bytes]\n }\n }\n })\n\n const localAddr = relayAddr.encapsulate(`/p2p-circuit/p2p/${this.peerId.toB58String()}`)\n const maConn = toConnection({\n stream: virtualConnection,\n remoteAddr: ma,\n localAddr\n })\n log('new outbound connection %s', maConn.remoteAddr)\n\n return this._upgrader.upgradeOutbound(maConn)\n } catch (err) {\n log.error('Circuit relay dial failed', err)\n disconnectOnFailure && await relayConnection.close()\n throw err\n }\n }\n\n /**\n * Create a listener\n *\n * @param {any} options\n * @param {Function} handler\n * @returns {import('libp2p-interfaces/src/transport/types').Listener}\n */\n createListener (options, handler) {\n if (typeof options === 'function') {\n handler = options\n options = {}\n }\n\n // Called on successful HOP and STOP requests\n this.handler = handler\n\n return createListener(this._libp2p)\n }\n\n /**\n * Filter check for all Multiaddrs that this transport can dial on\n *\n * @param {Multiaddr[]} multiaddrs\n * @returns {Multiaddr[]}\n */\n filter (multiaddrs) {\n multiaddrs = Array.isArray(multiaddrs) ? multiaddrs : [multiaddrs]\n\n return multiaddrs.filter((ma) => {\n return mafmt.Circuit.matches(ma)\n })\n }\n\n get [Symbol.toStringTag] () {\n return 'Circuit'\n }\n\n /**\n * Checks if the given value is a Transport instance.\n *\n * @param {any} other\n * @returns {other is Transport}\n */\n static isTransport (other) {\n return Boolean(other && other[transportSymbol])\n }\n}\n\nmodule.exports = Circuit\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-circuit\"] || ($protobuf.roots[\"libp2p-circuit\"] = {});\n\n$root.CircuitRelay = (function() {\n\n /**\n * Properties of a CircuitRelay.\n * @exports ICircuitRelay\n * @interface ICircuitRelay\n * @property {CircuitRelay.Type|null} [type] CircuitRelay type\n * @property {CircuitRelay.IPeer|null} [srcPeer] CircuitRelay srcPeer\n * @property {CircuitRelay.IPeer|null} [dstPeer] CircuitRelay dstPeer\n * @property {CircuitRelay.Status|null} [code] CircuitRelay code\n */\n\n /**\n * Constructs a new CircuitRelay.\n * @exports CircuitRelay\n * @classdesc Represents a CircuitRelay.\n * @implements ICircuitRelay\n * @constructor\n * @param {ICircuitRelay=} [p] Properties to set\n */\n function CircuitRelay(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * CircuitRelay type.\n * @member {CircuitRelay.Type} type\n * @memberof CircuitRelay\n * @instance\n */\n CircuitRelay.prototype.type = 1;\n\n /**\n * CircuitRelay srcPeer.\n * @member {CircuitRelay.IPeer|null|undefined} srcPeer\n * @memberof CircuitRelay\n * @instance\n */\n CircuitRelay.prototype.srcPeer = null;\n\n /**\n * CircuitRelay dstPeer.\n * @member {CircuitRelay.IPeer|null|undefined} dstPeer\n * @memberof CircuitRelay\n * @instance\n */\n CircuitRelay.prototype.dstPeer = null;\n\n /**\n * CircuitRelay code.\n * @member {CircuitRelay.Status} code\n * @memberof CircuitRelay\n * @instance\n */\n CircuitRelay.prototype.code = 100;\n\n /**\n * Encodes the specified CircuitRelay message. Does not implicitly {@link CircuitRelay.verify|verify} messages.\n * @function encode\n * @memberof CircuitRelay\n * @static\n * @param {ICircuitRelay} m CircuitRelay message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n CircuitRelay.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.type != null && Object.hasOwnProperty.call(m, \"type\"))\n w.uint32(8).int32(m.type);\n if (m.srcPeer != null && Object.hasOwnProperty.call(m, \"srcPeer\"))\n $root.CircuitRelay.Peer.encode(m.srcPeer, w.uint32(18).fork()).ldelim();\n if (m.dstPeer != null && Object.hasOwnProperty.call(m, \"dstPeer\"))\n $root.CircuitRelay.Peer.encode(m.dstPeer, w.uint32(26).fork()).ldelim();\n if (m.code != null && Object.hasOwnProperty.call(m, \"code\"))\n w.uint32(32).int32(m.code);\n return w;\n };\n\n /**\n * Decodes a CircuitRelay message from the specified reader or buffer.\n * @function decode\n * @memberof CircuitRelay\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {CircuitRelay} CircuitRelay\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n CircuitRelay.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.CircuitRelay();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.type = r.int32();\n break;\n case 2:\n m.srcPeer = $root.CircuitRelay.Peer.decode(r, r.uint32());\n break;\n case 3:\n m.dstPeer = $root.CircuitRelay.Peer.decode(r, r.uint32());\n break;\n case 4:\n m.code = r.int32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a CircuitRelay message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof CircuitRelay\n * @static\n * @param {Object.} d Plain object\n * @returns {CircuitRelay} CircuitRelay\n */\n CircuitRelay.fromObject = function fromObject(d) {\n if (d instanceof $root.CircuitRelay)\n return d;\n var m = new $root.CircuitRelay();\n switch (d.type) {\n case \"HOP\":\n case 1:\n m.type = 1;\n break;\n case \"STOP\":\n case 2:\n m.type = 2;\n break;\n case \"STATUS\":\n case 3:\n m.type = 3;\n break;\n case \"CAN_HOP\":\n case 4:\n m.type = 4;\n break;\n }\n if (d.srcPeer != null) {\n if (typeof d.srcPeer !== \"object\")\n throw TypeError(\".CircuitRelay.srcPeer: object expected\");\n m.srcPeer = $root.CircuitRelay.Peer.fromObject(d.srcPeer);\n }\n if (d.dstPeer != null) {\n if (typeof d.dstPeer !== \"object\")\n throw TypeError(\".CircuitRelay.dstPeer: object expected\");\n m.dstPeer = $root.CircuitRelay.Peer.fromObject(d.dstPeer);\n }\n switch (d.code) {\n case \"SUCCESS\":\n case 100:\n m.code = 100;\n break;\n case \"HOP_SRC_ADDR_TOO_LONG\":\n case 220:\n m.code = 220;\n break;\n case \"HOP_DST_ADDR_TOO_LONG\":\n case 221:\n m.code = 221;\n break;\n case \"HOP_SRC_MULTIADDR_INVALID\":\n case 250:\n m.code = 250;\n break;\n case \"HOP_DST_MULTIADDR_INVALID\":\n case 251:\n m.code = 251;\n break;\n case \"HOP_NO_CONN_TO_DST\":\n case 260:\n m.code = 260;\n break;\n case \"HOP_CANT_DIAL_DST\":\n case 261:\n m.code = 261;\n break;\n case \"HOP_CANT_OPEN_DST_STREAM\":\n case 262:\n m.code = 262;\n break;\n case \"HOP_CANT_SPEAK_RELAY\":\n case 270:\n m.code = 270;\n break;\n case \"HOP_CANT_RELAY_TO_SELF\":\n case 280:\n m.code = 280;\n break;\n case \"STOP_SRC_ADDR_TOO_LONG\":\n case 320:\n m.code = 320;\n break;\n case \"STOP_DST_ADDR_TOO_LONG\":\n case 321:\n m.code = 321;\n break;\n case \"STOP_SRC_MULTIADDR_INVALID\":\n case 350:\n m.code = 350;\n break;\n case \"STOP_DST_MULTIADDR_INVALID\":\n case 351:\n m.code = 351;\n break;\n case \"STOP_RELAY_REFUSED\":\n case 390:\n m.code = 390;\n break;\n case \"MALFORMED_MESSAGE\":\n case 400:\n m.code = 400;\n break;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a CircuitRelay message. Also converts values to other types if specified.\n * @function toObject\n * @memberof CircuitRelay\n * @static\n * @param {CircuitRelay} m CircuitRelay\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n CircuitRelay.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.type = o.enums === String ? \"HOP\" : 1;\n d.srcPeer = null;\n d.dstPeer = null;\n d.code = o.enums === String ? \"SUCCESS\" : 100;\n }\n if (m.type != null && m.hasOwnProperty(\"type\")) {\n d.type = o.enums === String ? $root.CircuitRelay.Type[m.type] : m.type;\n }\n if (m.srcPeer != null && m.hasOwnProperty(\"srcPeer\")) {\n d.srcPeer = $root.CircuitRelay.Peer.toObject(m.srcPeer, o);\n }\n if (m.dstPeer != null && m.hasOwnProperty(\"dstPeer\")) {\n d.dstPeer = $root.CircuitRelay.Peer.toObject(m.dstPeer, o);\n }\n if (m.code != null && m.hasOwnProperty(\"code\")) {\n d.code = o.enums === String ? $root.CircuitRelay.Status[m.code] : m.code;\n }\n return d;\n };\n\n /**\n * Converts this CircuitRelay to JSON.\n * @function toJSON\n * @memberof CircuitRelay\n * @instance\n * @returns {Object.} JSON object\n */\n CircuitRelay.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n /**\n * Status enum.\n * @name CircuitRelay.Status\n * @enum {number}\n * @property {number} SUCCESS=100 SUCCESS value\n * @property {number} HOP_SRC_ADDR_TOO_LONG=220 HOP_SRC_ADDR_TOO_LONG value\n * @property {number} HOP_DST_ADDR_TOO_LONG=221 HOP_DST_ADDR_TOO_LONG value\n * @property {number} HOP_SRC_MULTIADDR_INVALID=250 HOP_SRC_MULTIADDR_INVALID value\n * @property {number} HOP_DST_MULTIADDR_INVALID=251 HOP_DST_MULTIADDR_INVALID value\n * @property {number} HOP_NO_CONN_TO_DST=260 HOP_NO_CONN_TO_DST value\n * @property {number} HOP_CANT_DIAL_DST=261 HOP_CANT_DIAL_DST value\n * @property {number} HOP_CANT_OPEN_DST_STREAM=262 HOP_CANT_OPEN_DST_STREAM value\n * @property {number} HOP_CANT_SPEAK_RELAY=270 HOP_CANT_SPEAK_RELAY value\n * @property {number} HOP_CANT_RELAY_TO_SELF=280 HOP_CANT_RELAY_TO_SELF value\n * @property {number} STOP_SRC_ADDR_TOO_LONG=320 STOP_SRC_ADDR_TOO_LONG value\n * @property {number} STOP_DST_ADDR_TOO_LONG=321 STOP_DST_ADDR_TOO_LONG value\n * @property {number} STOP_SRC_MULTIADDR_INVALID=350 STOP_SRC_MULTIADDR_INVALID value\n * @property {number} STOP_DST_MULTIADDR_INVALID=351 STOP_DST_MULTIADDR_INVALID value\n * @property {number} STOP_RELAY_REFUSED=390 STOP_RELAY_REFUSED value\n * @property {number} MALFORMED_MESSAGE=400 MALFORMED_MESSAGE value\n */\n CircuitRelay.Status = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[100] = \"SUCCESS\"] = 100;\n values[valuesById[220] = \"HOP_SRC_ADDR_TOO_LONG\"] = 220;\n values[valuesById[221] = \"HOP_DST_ADDR_TOO_LONG\"] = 221;\n values[valuesById[250] = \"HOP_SRC_MULTIADDR_INVALID\"] = 250;\n values[valuesById[251] = \"HOP_DST_MULTIADDR_INVALID\"] = 251;\n values[valuesById[260] = \"HOP_NO_CONN_TO_DST\"] = 260;\n values[valuesById[261] = \"HOP_CANT_DIAL_DST\"] = 261;\n values[valuesById[262] = \"HOP_CANT_OPEN_DST_STREAM\"] = 262;\n values[valuesById[270] = \"HOP_CANT_SPEAK_RELAY\"] = 270;\n values[valuesById[280] = \"HOP_CANT_RELAY_TO_SELF\"] = 280;\n values[valuesById[320] = \"STOP_SRC_ADDR_TOO_LONG\"] = 320;\n values[valuesById[321] = \"STOP_DST_ADDR_TOO_LONG\"] = 321;\n values[valuesById[350] = \"STOP_SRC_MULTIADDR_INVALID\"] = 350;\n values[valuesById[351] = \"STOP_DST_MULTIADDR_INVALID\"] = 351;\n values[valuesById[390] = \"STOP_RELAY_REFUSED\"] = 390;\n values[valuesById[400] = \"MALFORMED_MESSAGE\"] = 400;\n return values;\n })();\n\n /**\n * Type enum.\n * @name CircuitRelay.Type\n * @enum {number}\n * @property {number} HOP=1 HOP value\n * @property {number} STOP=2 STOP value\n * @property {number} STATUS=3 STATUS value\n * @property {number} CAN_HOP=4 CAN_HOP value\n */\n CircuitRelay.Type = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[1] = \"HOP\"] = 1;\n values[valuesById[2] = \"STOP\"] = 2;\n values[valuesById[3] = \"STATUS\"] = 3;\n values[valuesById[4] = \"CAN_HOP\"] = 4;\n return values;\n })();\n\n CircuitRelay.Peer = (function() {\n\n /**\n * Properties of a Peer.\n * @memberof CircuitRelay\n * @interface IPeer\n * @property {Uint8Array} id Peer id\n * @property {Array.|null} [addrs] Peer addrs\n */\n\n /**\n * Constructs a new Peer.\n * @memberof CircuitRelay\n * @classdesc Represents a Peer.\n * @implements IPeer\n * @constructor\n * @param {CircuitRelay.IPeer=} [p] Properties to set\n */\n function Peer(p) {\n this.addrs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Peer id.\n * @member {Uint8Array} id\n * @memberof CircuitRelay.Peer\n * @instance\n */\n Peer.prototype.id = $util.newBuffer([]);\n\n /**\n * Peer addrs.\n * @member {Array.} addrs\n * @memberof CircuitRelay.Peer\n * @instance\n */\n Peer.prototype.addrs = $util.emptyArray;\n\n /**\n * Encodes the specified Peer message. Does not implicitly {@link CircuitRelay.Peer.verify|verify} messages.\n * @function encode\n * @memberof CircuitRelay.Peer\n * @static\n * @param {CircuitRelay.IPeer} m Peer message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Peer.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(10).bytes(m.id);\n if (m.addrs != null && m.addrs.length) {\n for (var i = 0; i < m.addrs.length; ++i)\n w.uint32(18).bytes(m.addrs[i]);\n }\n return w;\n };\n\n /**\n * Decodes a Peer message from the specified reader or buffer.\n * @function decode\n * @memberof CircuitRelay.Peer\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {CircuitRelay.Peer} Peer\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Peer.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.CircuitRelay.Peer();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.id = r.bytes();\n break;\n case 2:\n if (!(m.addrs && m.addrs.length))\n m.addrs = [];\n m.addrs.push(r.bytes());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty(\"id\"))\n throw $util.ProtocolError(\"missing required 'id'\", { instance: m });\n return m;\n };\n\n /**\n * Creates a Peer message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof CircuitRelay.Peer\n * @static\n * @param {Object.} d Plain object\n * @returns {CircuitRelay.Peer} Peer\n */\n Peer.fromObject = function fromObject(d) {\n if (d instanceof $root.CircuitRelay.Peer)\n return d;\n var m = new $root.CircuitRelay.Peer();\n if (d.id != null) {\n if (typeof d.id === \"string\")\n $util.base64.decode(d.id, m.id = $util.newBuffer($util.base64.length(d.id)), 0);\n else if (d.id.length)\n m.id = d.id;\n }\n if (d.addrs) {\n if (!Array.isArray(d.addrs))\n throw TypeError(\".CircuitRelay.Peer.addrs: array expected\");\n m.addrs = [];\n for (var i = 0; i < d.addrs.length; ++i) {\n if (typeof d.addrs[i] === \"string\")\n $util.base64.decode(d.addrs[i], m.addrs[i] = $util.newBuffer($util.base64.length(d.addrs[i])), 0);\n else if (d.addrs[i].length)\n m.addrs[i] = d.addrs[i];\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Peer message. Also converts values to other types if specified.\n * @function toObject\n * @memberof CircuitRelay.Peer\n * @static\n * @param {CircuitRelay.Peer} m Peer\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Peer.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.addrs = [];\n }\n if (o.defaults) {\n if (o.bytes === String)\n d.id = \"\";\n else {\n d.id = [];\n if (o.bytes !== Array)\n d.id = $util.newBuffer(d.id);\n }\n }\n if (m.id != null && m.hasOwnProperty(\"id\")) {\n d.id = o.bytes === String ? $util.base64.encode(m.id, 0, m.id.length) : o.bytes === Array ? Array.prototype.slice.call(m.id) : m.id;\n }\n if (m.addrs && m.addrs.length) {\n d.addrs = [];\n for (var j = 0; j < m.addrs.length; ++j) {\n d.addrs[j] = o.bytes === String ? $util.base64.encode(m.addrs[j], 0, m.addrs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.addrs[j]) : m.addrs[j];\n }\n }\n return d;\n };\n\n /**\n * Converts this Peer to JSON.\n * @function toJSON\n * @memberof CircuitRelay.Peer\n * @instance\n * @returns {Object.} JSON object\n */\n Peer.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Peer;\n })();\n\n return CircuitRelay;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst { source: abortable } = require('abortable-iterator')\nconst debug = require('debug')\nconst log = debug('libp2p:stream:converter')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n *\n * @typedef {Object} Timeline\n * @property {number} open - connection opening timestamp.\n * @property {number} [upgraded] - connection upgraded timestamp.\n * @property {number} [close]\n */\n\n/**\n * Convert a duplex iterable into a MultiaddrConnection.\n * https://github.com/libp2p/interface-transport#multiaddrconnection\n *\n * @param {object} streamProperties\n * @param {MuxedStream} streamProperties.stream\n * @param {Multiaddr} streamProperties.remoteAddr\n * @param {Multiaddr} streamProperties.localAddr\n * @param {object} [options]\n * @param {AbortSignal} [options.signal]\n * @returns {import('libp2p-interfaces/src/transport/types').MultiaddrConnection}\n */\nfunction streamToMaConnection ({ stream, remoteAddr, localAddr }, options = {}) {\n const { sink, source } = stream\n const maConn = {\n /**\n * @param {Uint8Array} source\n */\n async sink (source) {\n if (options.signal) {\n // @ts-ignore ts infers source template will be a number\n source = abortable(source, options.signal)\n }\n\n try {\n await sink(source)\n } catch (err) {\n // If aborted we can safely ignore\n if (err.type !== 'aborted') {\n // If the source errored the socket will already have been destroyed by\n // toIterable.duplex(). If the socket errored it will already be\n // destroyed. There's nothing to do here except log the error & return.\n log(err)\n }\n }\n close()\n },\n source: options.signal ? abortable(source, options.signal) : source,\n conn: stream,\n localAddr,\n remoteAddr,\n /** @type {Timeline} */\n timeline: { open: Date.now(), close: undefined },\n close () {\n sink(new Uint8Array(0))\n return close()\n }\n }\n\n function close () {\n if (!maConn.timeline.close) {\n maConn.timeline.close = Date.now()\n }\n return Promise.resolve()\n }\n\n return maConn\n}\n\nmodule.exports = streamToMaConnection\n","'use strict'\n\nmodule.exports = {\n relay: '/libp2p/circuit/relay/0.1.0'\n}\n","'use strict'\n\nconst { EventEmitter } = require('events')\nconst { Multiaddr } = require('multiaddr')\n\n/**\n * @typedef {import('libp2p-interfaces/src/transport/types').Listener} Listener\n */\n\n/**\n * @param {import('../')} libp2p\n * @returns {Listener} a transport listener\n */\nmodule.exports = (libp2p) => {\n const listeningAddrs = new Map()\n\n /**\n * Add swarm handler and listen for incoming connections\n *\n * @param {Multiaddr} addr\n * @returns {Promise}\n */\n async function listen (addr) {\n const addrString = String(addr).split('/p2p-circuit').find(a => a !== '')\n\n const relayConn = await libp2p.dial(new Multiaddr(addrString))\n const relayedAddr = relayConn.remoteAddr.encapsulate('/p2p-circuit')\n\n listeningAddrs.set(relayConn.remotePeer.toB58String(), relayedAddr)\n listener.emit('listening')\n }\n\n /**\n * Get fixed up multiaddrs\n *\n * NOTE: This method will grab the peers multiaddrs and expand them such that:\n *\n * a) If it's an existing /p2p-circuit address for a specific relay i.e.\n * `/ip4/0.0.0.0/tcp/0/ipfs/QmRelay/p2p-circuit` this method will expand the\n * address to `/ip4/0.0.0.0/tcp/0/ipfs/QmRelay/p2p-circuit/ipfs/QmPeer` where\n * `QmPeer` is this peers id\n * b) If it's not a /p2p-circuit address, it will encapsulate the address as a /p2p-circuit\n * addr, such when dialing over a relay with this address, it will create the circuit using\n * the encapsulated transport address. This is useful when for example, a peer should only\n * be dialed over TCP rather than any other transport\n *\n * @returns {Multiaddr[]}\n */\n function getAddrs () {\n const addrs = []\n for (const addr of listeningAddrs.values()) {\n addrs.push(addr)\n }\n return addrs\n }\n\n /** @type Listener */\n const listener = Object.assign(new EventEmitter(), {\n close: () => Promise.resolve(),\n listen,\n getAddrs\n })\n\n // Remove listeningAddrs when a peer disconnects\n libp2p.connectionManager.on('peer:disconnect', (connection) => {\n const deleted = listeningAddrs.delete(connection.remotePeer.toB58String())\n\n if (deleted) {\n // Announce listen addresses change\n listener.emit('close')\n }\n })\n\n return listener\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:circuit:hop'), {\n error: debug('libp2p:circuit:hop:err')\n})\nconst errCode = require('err-code')\n\nconst PeerId = require('peer-id')\nconst { validateAddrs } = require('./utils')\nconst StreamHandler = require('./stream-handler')\nconst { CircuitRelay: CircuitPB } = require('../protocol')\nconst { pipe } = require('it-pipe')\nconst { codes: Errors } = require('../../errors')\n\nconst { stop } = require('./stop')\n\nconst multicodec = require('./../multicodec')\n\n/**\n * @typedef {import('../protocol').ICircuitRelay} ICircuitRelay\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('../transport')} Transport\n */\n\n/**\n * @typedef {Object} HopRequest\n * @property {Connection} connection\n * @property {ICircuitRelay} request\n * @property {StreamHandler} streamHandler\n * @property {Transport} circuit\n */\n\n/**\n * @param {HopRequest} options\n * @returns {Promise}\n */\nasync function handleHop ({\n connection,\n request,\n streamHandler,\n circuit\n}) {\n // Ensure hop is enabled\n if (!circuit._options.hop.enabled) {\n log('HOP request received but we are not acting as a relay')\n return streamHandler.end({\n type: CircuitPB.Type.STATUS,\n code: CircuitPB.Status.HOP_CANT_SPEAK_RELAY\n })\n }\n\n // Validate the HOP request has the required input\n try {\n validateAddrs(request, streamHandler)\n } catch (err) {\n return log.error('invalid hop request via peer %s', connection.remotePeer.toB58String(), err)\n }\n\n if (!request.dstPeer) {\n log('HOP request received but we do not receive a dstPeer')\n return\n }\n\n // Get the connection to the destination (stop) peer\n const destinationPeer = new PeerId(request.dstPeer.id)\n\n const destinationConnection = circuit._connectionManager.get(destinationPeer)\n if (!destinationConnection && !circuit._options.hop.active) {\n log('HOP request received but we are not connected to the destination peer')\n return streamHandler.end({\n type: CircuitPB.Type.STATUS,\n code: CircuitPB.Status.HOP_NO_CONN_TO_DST\n })\n }\n\n // TODO: Handle being an active relay\n if (!destinationConnection) {\n return\n }\n\n // Handle the incoming HOP request by performing a STOP request\n const stopRequest = {\n type: CircuitPB.Type.STOP,\n dstPeer: request.dstPeer,\n srcPeer: request.srcPeer\n }\n\n let destinationStream\n try {\n destinationStream = await stop({\n connection: destinationConnection,\n request: stopRequest\n })\n } catch (err) {\n return log.error(err)\n }\n\n log('hop request from %s is valid', connection.remotePeer.toB58String())\n streamHandler.write({\n type: CircuitPB.Type.STATUS,\n code: CircuitPB.Status.SUCCESS\n })\n const sourceStream = streamHandler.rest()\n\n // Short circuit the two streams to create the relayed connection\n return pipe(\n sourceStream,\n destinationStream,\n sourceStream\n )\n}\n\n/**\n * Performs a HOP request to a relay peer, to request a connection to another\n * peer. A new, virtual, connection will be created between the two via the relay.\n *\n * @param {object} options\n * @param {Connection} options.connection - Connection to the relay\n * @param {ICircuitRelay} options.request\n * @returns {Promise}\n */\nasync function hop ({\n connection,\n request\n}) {\n // Create a new stream to the relay\n const { stream } = await connection.newStream([multicodec.relay])\n // Send the HOP request\n const streamHandler = new StreamHandler({ stream })\n streamHandler.write(request)\n\n const response = await streamHandler.read()\n\n if (!response) {\n throw errCode(new Error('HOP request had no response'), Errors.ERR_HOP_REQUEST_FAILED)\n }\n\n if (response.code === CircuitPB.Status.SUCCESS) {\n log('hop request was successful')\n return streamHandler.rest()\n }\n\n log('hop request failed with code %d, closing stream', response.code)\n streamHandler.close()\n throw errCode(new Error(`HOP request failed with code ${response.code}`), Errors.ERR_HOP_REQUEST_FAILED)\n}\n\n/**\n * Performs a CAN_HOP request to a relay peer, in order to understand its capabilities.\n *\n * @param {object} options\n * @param {Connection} options.connection - Connection to the relay\n * @returns {Promise}\n */\nasync function canHop ({\n connection\n}) {\n // Create a new stream to the relay\n const { stream } = await connection.newStream([multicodec.relay])\n // Send the HOP request\n const streamHandler = new StreamHandler({ stream })\n streamHandler.write({\n type: CircuitPB.Type.CAN_HOP\n })\n\n const response = await streamHandler.read()\n await streamHandler.close()\n\n if (!response || response.code !== CircuitPB.Status.SUCCESS) {\n return false\n }\n\n return true\n}\n\n/**\n * Creates an unencoded CAN_HOP response based on the Circuits configuration\n *\n * @param {Object} options\n * @param {Connection} options.connection\n * @param {StreamHandler} options.streamHandler\n * @param {Transport} options.circuit\n * @private\n */\nfunction handleCanHop ({\n connection,\n streamHandler,\n circuit\n}) {\n const canHop = circuit._options.hop.enabled\n log('can hop (%s) request from %s', canHop, connection.remotePeer.toB58String())\n streamHandler.end({\n type: CircuitPB.Type.STATUS,\n code: canHop ? CircuitPB.Status.SUCCESS : CircuitPB.Status.HOP_CANT_SPEAK_RELAY\n })\n}\n\nmodule.exports = {\n handleHop,\n hop,\n canHop,\n handleCanHop\n}\n","'use strict'\n\nconst { Multiaddr } = require('multiaddr')\nconst { CircuitRelay } = require('../protocol')\n\n/**\n * @typedef {import('./stream-handler')} StreamHandler\n * @typedef {import('../protocol').ICircuitRelay} ICircuitRelay\n */\n\n/**\n * Write a response\n *\n * @param {StreamHandler} streamHandler\n * @param {import('../protocol').CircuitRelay.Status} status\n */\nfunction writeResponse (streamHandler, status) {\n streamHandler.write({\n type: CircuitRelay.Type.STATUS,\n code: status\n })\n}\n\n/**\n * Validate incomming HOP/STOP message\n *\n * @param {ICircuitRelay} msg - A CircuitRelay unencoded protobuf message\n * @param {StreamHandler} streamHandler\n */\nfunction validateAddrs (msg, streamHandler) {\n try {\n if (msg.dstPeer && msg.dstPeer.addrs) {\n msg.dstPeer.addrs.forEach((addr) => {\n return new Multiaddr(addr)\n })\n }\n } catch (err) {\n writeResponse(streamHandler, msg.type === CircuitRelay.Type.HOP\n ? CircuitRelay.Status.HOP_DST_MULTIADDR_INVALID\n : CircuitRelay.Status.STOP_DST_MULTIADDR_INVALID)\n throw err\n }\n\n try {\n if (msg.srcPeer && msg.srcPeer.addrs) {\n msg.srcPeer.addrs.forEach((addr) => {\n return new Multiaddr(addr)\n })\n }\n } catch (err) {\n writeResponse(streamHandler, msg.type === CircuitRelay.Type.HOP\n ? CircuitRelay.Status.HOP_SRC_MULTIADDR_INVALID\n : CircuitRelay.Status.STOP_SRC_MULTIADDR_INVALID)\n throw err\n }\n}\n\nmodule.exports = {\n validateAddrs\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:circuit:stream-handler'), {\n error: debug('libp2p:circuit:stream-handler:err')\n})\n\nconst lp = require('it-length-prefixed')\n// @ts-ignore it-handshake does not export types\nconst handshake = require('it-handshake')\nconst { CircuitRelay } = require('../protocol')\n\n/**\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('../protocol').ICircuitRelay} ICircuitRelay\n */\n\nclass StreamHandler {\n /**\n * Create a stream handler for connection\n *\n * @class\n * @param {object} options\n * @param {MuxedStream} options.stream - A duplex iterable\n * @param {number} [options.maxLength = 4096] - max bytes length of message\n */\n constructor ({ stream, maxLength = 4096 }) {\n this.stream = stream\n\n this.shake = handshake(this.stream)\n // @ts-ignore options are not optional\n this.decoder = lp.decode.fromReader(this.shake.reader, { maxDataLength: maxLength })\n }\n\n /**\n * Read and decode message\n *\n * @async\n */\n async read () {\n const msg = await this.decoder.next()\n if (msg.value) {\n const value = CircuitRelay.decode(msg.value.slice())\n log('read message type', value.type)\n return value\n }\n\n log('read received no value, closing stream')\n // End the stream, we didn't get data\n this.close()\n }\n\n /**\n * Encode and write array of buffers\n *\n * @param {ICircuitRelay} msg - An unencoded CircuitRelay protobuf message\n * @returns {void}\n */\n write (msg) {\n log('write message type %s', msg.type)\n // @ts-ignore lp.encode expects type type 'Buffer | BufferList', not 'Uint8Array'\n this.shake.write(lp.encode.single(CircuitRelay.encode(msg).finish()))\n }\n\n /**\n * Return the handshake rest stream and invalidate handler\n *\n * @returns {*} A duplex iterable\n */\n rest () {\n this.shake.rest()\n return this.shake.stream\n }\n\n /**\n * @param {ICircuitRelay} msg - An unencoded CircuitRelay protobuf message\n */\n end (msg) {\n this.write(msg)\n this.close()\n }\n\n /**\n * Close the stream\n *\n * @returns {void}\n */\n close () {\n log('closing the stream')\n this.rest().sink([])\n }\n}\n\nmodule.exports = StreamHandler\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:circuit:stop'), {\n error: debug('libp2p:circuit:stop:err')\n})\n\nconst { CircuitRelay: CircuitPB } = require('../protocol')\nconst multicodec = require('../multicodec')\nconst StreamHandler = require('./stream-handler')\nconst { validateAddrs } = require('./utils')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('../protocol').ICircuitRelay} ICircuitRelay\n */\n\n/**\n * Handles incoming STOP requests\n *\n * @private\n * @param {Object} options\n * @param {Connection} options.connection\n * @param {ICircuitRelay} options.request - The CircuitRelay protobuf request (unencoded)\n * @param {StreamHandler} options.streamHandler\n * @returns {Promise|void} Resolves a duplex iterable\n */\nmodule.exports.handleStop = function handleStop ({\n connection,\n request,\n streamHandler\n}) {\n // Validate the STOP request has the required input\n try {\n validateAddrs(request, streamHandler)\n } catch (err) {\n return log.error('invalid stop request via peer %s', connection.remotePeer.toB58String(), err)\n }\n\n // The request is valid\n log('stop request is valid')\n streamHandler.write({\n type: CircuitPB.Type.STATUS,\n code: CircuitPB.Status.SUCCESS\n })\n return streamHandler.rest()\n}\n\n/**\n * Creates a STOP request\n *\n * @private\n * @param {Object} options\n * @param {Connection} options.connection\n * @param {ICircuitRelay} options.request - The CircuitRelay protobuf request (unencoded)\n * @returns {Promise} Resolves a duplex iterable\n */\nmodule.exports.stop = async function stop ({\n connection,\n request\n}) {\n const { stream } = await connection.newStream([multicodec.relay])\n log('starting stop request to %s', connection.remotePeer.toB58String())\n const streamHandler = new StreamHandler({ stream })\n\n streamHandler.write(request)\n const response = await streamHandler.read()\n\n if (!response) {\n return streamHandler.close()\n }\n\n if (response.code === CircuitPB.Status.SUCCESS) {\n log('stop request to %s was successful', connection.remotePeer.toB58String())\n return streamHandler.rest()\n }\n\n log('stop request failed with code %d', response.code)\n streamHandler.close()\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:relay'), {\n error: debug('libp2p:relay:err')\n})\n\nconst {\n setDelayedInterval,\n clearDelayedInterval\n// @ts-ignore set-delayed-interval does not export types\n} = require('set-delayed-interval')\n\nconst AutoRelay = require('./auto-relay')\nconst { namespaceToCid } = require('./utils')\nconst {\n RELAY_RENDEZVOUS_NS\n} = require('./constants')\n\n/**\n * @typedef {import('../')} Libp2p\n *\n * @typedef {Object} RelayAdvertiseOptions\n * @property {number} [bootDelay = ADVERTISE_BOOT_DELAY]\n * @property {boolean} [enabled = true]\n * @property {number} [ttl = ADVERTISE_TTL]\n *\n * @typedef {Object} HopOptions\n * @property {boolean} [enabled = false]\n * @property {boolean} [active = false]\n *\n * @typedef {Object} AutoRelayOptions\n * @property {number} [maxListeners = 2] - maximum number of relays to listen.\n * @property {boolean} [enabled = false]\n */\n\nclass Relay {\n /**\n * Creates an instance of Relay.\n *\n * @class\n * @param {Libp2p} libp2p\n */\n constructor (libp2p) {\n this._libp2p = libp2p\n this._options = {\n ...libp2p._config.relay\n }\n\n // Create autoRelay if enabled\n this._autoRelay = this._options.autoRelay.enabled && new AutoRelay({ libp2p, ...this._options.autoRelay })\n\n this._advertiseService = this._advertiseService.bind(this)\n }\n\n /**\n * Start Relay service.\n *\n * @returns {void}\n */\n start () {\n // Advertise service if HOP enabled\n const canHop = this._options.hop.enabled\n\n if (canHop && this._options.advertise.enabled) {\n this._timeout = setDelayedInterval(\n this._advertiseService, this._options.advertise.ttl, this._options.advertise.bootDelay\n )\n }\n }\n\n /**\n * Stop Relay service.\n *\n * @returns {void}\n */\n stop () {\n clearDelayedInterval(this._timeout)\n }\n\n /**\n * Advertise hop relay service in the network.\n *\n * @returns {Promise}\n */\n async _advertiseService () {\n try {\n const cid = await namespaceToCid(RELAY_RENDEZVOUS_NS)\n await this._libp2p.contentRouting.provide(cid)\n } catch (err) {\n if (err.code === 'NO_ROUTERS_AVAILABLE') {\n log.error('a content router, such as a DHT, must be provided in order to advertise the relay service', err)\n // Stop the advertise\n this.stop()\n } else {\n log.error(err)\n }\n }\n }\n}\n\nmodule.exports = Relay\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:auto-relay'), {\n error: debug('libp2p:auto-relay:err')\n})\n\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\n\nconst { relay: multicodec } = require('./multicodec')\nconst { canHop } = require('./circuit/hop')\nconst { namespaceToCid } = require('./utils')\nconst {\n CIRCUIT_PROTO_CODE,\n HOP_METADATA_KEY,\n HOP_METADATA_VALUE,\n RELAY_RENDEZVOUS_NS\n} = require('./constants')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('../peer-store/address-book').Address} Address\n */\n\n/**\n * @typedef {Object} AutoRelayProperties\n * @property {import('../')} libp2p\n *\n * @typedef {Object} AutoRelayOptions\n * @property {number} [maxListeners = 1] - maximum number of relays to listen.\n * @property {(error: Error, msg?: string) => {}} [onError]\n */\n\nclass AutoRelay {\n /**\n * Creates an instance of AutoRelay.\n *\n * @class\n * @param {AutoRelayProperties & AutoRelayOptions} props\n */\n constructor ({ libp2p, maxListeners = 1, onError }) {\n this._libp2p = libp2p\n this._peerId = libp2p.peerId\n this._peerStore = libp2p.peerStore\n this._connectionManager = libp2p.connectionManager\n this._transportManager = libp2p.transportManager\n this._addressSorter = libp2p.dialer.addressSorter\n\n this.maxListeners = maxListeners\n\n /**\n * @type {Set}\n */\n this._listenRelays = new Set()\n\n this._onProtocolChange = this._onProtocolChange.bind(this)\n this._onPeerDisconnected = this._onPeerDisconnected.bind(this)\n\n this._peerStore.on('change:protocols', this._onProtocolChange)\n this._connectionManager.on('peer:disconnect', this._onPeerDisconnected)\n\n /**\n * @param {Error} error\n * @param {string} [msg]\n */\n this._onError = (error, msg) => {\n log.error(msg || error)\n onError && onError(error, msg)\n }\n }\n\n /**\n * Check if a peer supports the relay protocol.\n * If the protocol is not supported, check if it was supported before and remove it as a listen relay.\n * If the protocol is supported, check if the peer supports **HOP** and add it as a listener if\n * inside the threshold.\n *\n * @param {Object} props\n * @param {PeerId} props.peerId\n * @param {string[]} props.protocols\n * @returns {Promise}\n */\n async _onProtocolChange ({ peerId, protocols }) {\n const id = peerId.toB58String()\n\n // Check if it has the protocol\n const hasProtocol = protocols.find(protocol => protocol === multicodec)\n\n // If no protocol, check if we were keeping the peer before as a listenRelay\n if (!hasProtocol && this._listenRelays.has(id)) {\n this._removeListenRelay(id)\n return\n } else if (!hasProtocol || this._listenRelays.has(id)) {\n return\n }\n\n // If protocol, check if can hop, store info in the metadataBook and listen on it\n try {\n const connection = this._connectionManager.get(peerId)\n if (!connection) {\n return\n }\n\n // Do not hop on a relayed connection\n if (connection.remoteAddr.protoCodes().includes(CIRCUIT_PROTO_CODE)) {\n log(`relayed connection to ${id} will not be used to hop on`)\n return\n }\n\n const supportsHop = await canHop({ connection })\n\n if (supportsHop) {\n this._peerStore.metadataBook.set(peerId, HOP_METADATA_KEY, uint8ArrayFromString(HOP_METADATA_VALUE))\n await this._addListenRelay(connection, id)\n }\n } catch (err) {\n this._onError(err)\n }\n }\n\n /**\n * Peer disconnects.\n *\n * @param {Connection} connection - connection to the peer\n * @returns {void}\n */\n _onPeerDisconnected (connection) {\n const peerId = connection.remotePeer\n const id = peerId.toB58String()\n\n // Not listening on this relay\n if (!this._listenRelays.has(id)) {\n return\n }\n\n this._removeListenRelay(id)\n }\n\n /**\n * Attempt to listen on the given relay connection.\n *\n * @private\n * @param {Connection} connection - connection to the peer\n * @param {string} id - peer identifier string\n * @returns {Promise}\n */\n async _addListenRelay (connection, id) {\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n\n // Get peer known addresses and sort them per public addresses first\n const remoteAddrs = this._peerStore.addressBook.getMultiaddrsForPeer(\n connection.remotePeer, this._addressSorter\n )\n\n if (!remoteAddrs || !remoteAddrs.length) {\n return\n }\n\n const listenAddr = `${remoteAddrs[0].toString()}/p2p-circuit`\n this._listenRelays.add(id)\n\n // Attempt to listen on relay\n try {\n await this._transportManager.listen([new Multiaddr(listenAddr)])\n // Announce multiaddrs will update on listen success by TransportManager event being triggered\n } catch (err) {\n this._onError(err)\n this._listenRelays.delete(id)\n }\n }\n\n /**\n * Remove listen relay.\n *\n * @private\n * @param {string} id - peer identifier string.\n * @returns {void}\n */\n _removeListenRelay (id) {\n if (this._listenRelays.delete(id)) {\n // TODO: this should be responsibility of the connMgr\n this._listenOnAvailableHopRelays([id])\n }\n }\n\n /**\n * Try to listen on available hop relay connections.\n * The following order will happen while we do not have enough relays.\n * 1. Check the metadata store for known relays, try to listen on the ones we are already connected.\n * 2. Dial and try to listen on the peers we know that support hop but are not connected.\n * 3. Search the network.\n *\n * @param {string[]} [peersToIgnore]\n * @returns {Promise}\n */\n async _listenOnAvailableHopRelays (peersToIgnore = []) {\n // TODO: The peer redial issue on disconnect should be handled by connection gating\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n\n const knownHopsToDial = []\n\n // Check if we have known hop peers to use and attempt to listen on the already connected\n for (const [id, metadataMap] of this._peerStore.metadataBook.data.entries()) {\n // Continue to next if listening on this or peer to ignore\n if (this._listenRelays.has(id) || peersToIgnore.includes(id)) {\n continue\n }\n\n const supportsHop = metadataMap.get(HOP_METADATA_KEY)\n\n // Continue to next if it does not support Hop\n if (!supportsHop || uint8ArrayToString(supportsHop) !== HOP_METADATA_VALUE) {\n continue\n }\n\n const peerId = PeerId.createFromB58String(id)\n const connection = this._connectionManager.get(peerId)\n\n // If not connected, store for possible later use.\n if (!connection) {\n knownHopsToDial.push(peerId)\n continue\n }\n\n await this._addListenRelay(connection, id)\n\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n }\n\n // Try to listen on known peers that are not connected\n for (const peerId of knownHopsToDial) {\n await this._tryToListenOnRelay(peerId)\n\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n }\n\n // Try to find relays to hop on the network\n try {\n const cid = await namespaceToCid(RELAY_RENDEZVOUS_NS)\n for await (const provider of this._libp2p.contentRouting.findProviders(cid)) {\n if (!provider.multiaddrs.length) {\n continue\n }\n\n const peerId = provider.id\n this._peerStore.addressBook.add(peerId, provider.multiaddrs)\n\n await this._tryToListenOnRelay(peerId)\n\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n }\n } catch (err) {\n this._onError(err)\n }\n }\n\n /**\n * @param {PeerId} peerId\n */\n async _tryToListenOnRelay (peerId) {\n try {\n const connection = await this._libp2p.dial(peerId)\n await this._addListenRelay(connection, peerId.toB58String())\n } catch (err) {\n this._onError(err, `could not connect and listen on known hop relay ${peerId.toB58String()}`)\n }\n }\n}\n\nmodule.exports = AutoRelay\n","'use strict'\n\nconst { CID } = require('multiformats/cid')\nconst { sha256 } = require('multiformats/hashes/sha2')\n\n/**\n * Convert a namespace string into a cid.\n *\n * @param {string} namespace\n * @returns {Promise}\n */\nmodule.exports.namespaceToCid = async (namespace) => {\n const bytes = new TextEncoder().encode(namespace)\n const hash = await sha256.digest(bytes)\n\n return CID.createV0(hash)\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:dialer'), {\n error: debug('libp2p:dialer:err')\n})\nconst errCode = require('err-code')\nconst { Multiaddr } = require('multiaddr')\n// @ts-ignore timeout-abourt-controles does not export types\nconst TimeoutController = require('timeout-abort-controller')\nconst { AbortError } = require('abortable-iterator')\nconst { anySignal } = require('any-signal')\n\nconst DialRequest = require('./dial-request')\nconst { publicAddressesFirst } = require('libp2p-utils/src/address-sort')\nconst getPeer = require('../get-peer')\n\nconst { codes } = require('../errors')\nconst {\n DIAL_TIMEOUT,\n MAX_PARALLEL_DIALS,\n MAX_PER_PEER_DIALS,\n MAX_ADDRS_TO_DIAL\n} = require('../constants')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../peer-store')} PeerStore\n * @typedef {import('../peer-store/address-book').Address} Address\n * @typedef {import('../transport-manager')} TransportManager\n */\n\n/**\n * @typedef {Object} DialerProperties\n * @property {PeerStore} peerStore\n * @property {TransportManager} transportManager\n *\n * @typedef {(addr:Multiaddr) => Promise} Resolver\n *\n * @typedef {Object} DialerOptions\n * @property {(addresses: Address[]) => Address[]} [options.addressSorter = publicAddressesFirst] - Sort the known addresses of a peer before trying to dial.\n * @property {number} [maxParallelDials = MAX_PARALLEL_DIALS] - Number of max concurrent dials.\n * @property {number} [maxAddrsToDial = MAX_ADDRS_TO_DIAL] - Number of max addresses to dial for a given peer.\n * @property {number} [maxDialsPerPeer = MAX_PER_PEER_DIALS] - Number of max concurrent dials per peer.\n * @property {number} [dialTimeout = DIAL_TIMEOUT] - How long a dial attempt is allowed to take.\n * @property {Record} [resolvers = {}] - multiaddr resolvers to use when dialing\n *\n * @typedef DialTarget\n * @property {string} id\n * @property {Multiaddr[]} addrs\n *\n * @typedef PendingDial\n * @property {DialRequest} dialRequest\n * @property {TimeoutController} controller\n * @property {Promise} promise\n * @property {function():void} destroy\n */\n\nclass Dialer {\n /**\n * @class\n * @param {DialerProperties & DialerOptions} options\n */\n constructor ({\n transportManager,\n peerStore,\n addressSorter = publicAddressesFirst,\n maxParallelDials = MAX_PARALLEL_DIALS,\n maxAddrsToDial = MAX_ADDRS_TO_DIAL,\n dialTimeout = DIAL_TIMEOUT,\n maxDialsPerPeer = MAX_PER_PEER_DIALS,\n resolvers = {}\n }) {\n this.transportManager = transportManager\n this.peerStore = peerStore\n this.addressSorter = addressSorter\n this.maxParallelDials = maxParallelDials\n this.maxAddrsToDial = maxAddrsToDial\n this.timeout = dialTimeout\n this.maxDialsPerPeer = maxDialsPerPeer\n this.tokens = [...new Array(maxParallelDials)].map((_, index) => index)\n this._pendingDials = new Map()\n this._pendingDialTargets = new Map()\n\n for (const [key, value] of Object.entries(resolvers)) {\n Multiaddr.resolvers.set(key, value)\n }\n }\n\n /**\n * Clears any pending dials\n */\n destroy () {\n for (const dial of this._pendingDials.values()) {\n try {\n dial.controller.abort()\n } catch (err) {\n log.error(err)\n }\n }\n this._pendingDials.clear()\n\n for (const pendingTarget of this._pendingDialTargets.values()) {\n pendingTarget.reject(new AbortError('Dialer was destroyed'))\n }\n this._pendingDialTargets.clear()\n }\n\n /**\n * Connects to a given `peer` by dialing all of its known addresses.\n * The dial to the first address that is successfully able to upgrade a connection\n * will be used.\n *\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - An AbortController signal\n * @returns {Promise}\n */\n async connectToPeer (peer, options = {}) {\n const dialTarget = await this._createCancellableDialTarget(peer)\n\n if (!dialTarget.addrs.length) {\n throw errCode(new Error('The dial request has no valid addresses'), codes.ERR_NO_VALID_ADDRESSES)\n }\n const pendingDial = this._pendingDials.get(dialTarget.id) || this._createPendingDial(dialTarget, options)\n\n try {\n const connection = await pendingDial.promise\n log('dial succeeded to %s', dialTarget.id)\n return connection\n } catch (err) {\n // Error is a timeout\n if (pendingDial.controller.signal.aborted) {\n err.code = codes.ERR_TIMEOUT\n }\n log.error(err)\n throw err\n } finally {\n pendingDial.destroy()\n }\n }\n\n /**\n * Connects to a given `peer` by dialing all of its known addresses.\n * The dial to the first address that is successfully able to upgrade a connection\n * will be used.\n *\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @returns {Promise}\n */\n async _createCancellableDialTarget (peer) {\n // Make dial target promise cancellable\n const id = `${(parseInt(String(Math.random() * 1e9), 10)).toString() + Date.now()}`\n const cancellablePromise = new Promise((resolve, reject) => {\n this._pendingDialTargets.set(id, { resolve, reject })\n })\n\n const dialTarget = await Promise.race([\n this._createDialTarget(peer),\n cancellablePromise\n ])\n\n this._pendingDialTargets.delete(id)\n\n return dialTarget\n }\n\n /**\n * Creates a DialTarget. The DialTarget is used to create and track\n * the DialRequest to a given peer.\n * If a multiaddr is received it should be the first address attempted.\n * Multiaddrs not supported by the available transports will be filtered out.\n *\n * @private\n * @param {PeerId|Multiaddr|string} peer - A PeerId or Multiaddr\n * @returns {Promise}\n */\n async _createDialTarget (peer) {\n const { id, multiaddrs } = getPeer(peer)\n\n if (multiaddrs) {\n this.peerStore.addressBook.add(id, multiaddrs)\n }\n\n let knownAddrs = this.peerStore.addressBook.getMultiaddrsForPeer(id, this.addressSorter) || []\n\n // If received a multiaddr to dial, it should be the first to use\n // But, if we know other multiaddrs for the peer, we should try them too.\n if (Multiaddr.isMultiaddr(peer)) {\n knownAddrs = knownAddrs.filter((addr) => !peer.equals(addr))\n knownAddrs.unshift(peer)\n }\n\n /** @type {Multiaddr[]} */\n const addrs = []\n for (const a of knownAddrs) {\n const resolvedAddrs = await this._resolve(a)\n resolvedAddrs.forEach(ra => addrs.push(ra))\n }\n\n // Multiaddrs not supported by the available transports will be filtered out.\n const supportedAddrs = addrs.filter(a => this.transportManager.transportForMultiaddr(a))\n\n if (supportedAddrs.length > this.maxAddrsToDial) {\n this.peerStore.delete(id)\n throw errCode(new Error('dial with more addresses than allowed'), codes.ERR_TOO_MANY_ADDRESSES)\n }\n\n return {\n id: id.toB58String(),\n addrs: supportedAddrs\n }\n }\n\n /**\n * Creates a PendingDial that wraps the underlying DialRequest\n *\n * @private\n * @param {DialTarget} dialTarget\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - An AbortController signal\n * @returns {PendingDial}\n */\n _createPendingDial (dialTarget, options = {}) {\n /**\n * @param {Multiaddr} addr\n * @param {{ signal: { aborted: any; }; }} options\n */\n const dialAction = (addr, options) => {\n if (options.signal.aborted) throw errCode(new Error('already aborted'), codes.ERR_ALREADY_ABORTED)\n return this.transportManager.dial(addr, options)\n }\n\n const dialRequest = new DialRequest({\n addrs: dialTarget.addrs,\n dialAction,\n dialer: this\n })\n\n // Combine the timeout signal and options.signal, if provided\n const timeoutController = new TimeoutController(this.timeout)\n const signals = [timeoutController.signal]\n options.signal && signals.push(options.signal)\n const signal = anySignal(signals)\n\n const pendingDial = {\n dialRequest,\n controller: timeoutController,\n promise: dialRequest.run({ ...options, signal }),\n destroy: () => {\n timeoutController.clear()\n this._pendingDials.delete(dialTarget.id)\n }\n }\n this._pendingDials.set(dialTarget.id, pendingDial)\n return pendingDial\n }\n\n /**\n * @param {number} num\n */\n getTokens (num) {\n const total = Math.min(num, this.maxDialsPerPeer, this.tokens.length)\n const tokens = this.tokens.splice(0, total)\n log('%d tokens request, returning %d, %d remaining', num, total, this.tokens.length)\n return tokens\n }\n\n /**\n * @param {number} token\n */\n releaseToken (token) {\n // Guard against duplicate releases\n if (this.tokens.indexOf(token) > -1) return\n log('token %d released', token)\n this.tokens.push(token)\n }\n\n /**\n * Resolve multiaddr recursively.\n *\n * @param {Multiaddr} ma\n * @returns {Promise}\n */\n async _resolve (ma) {\n // TODO: recursive logic should live in multiaddr once dns4/dns6 support is in place\n // Now only supporting resolve for dnsaddr\n const resolvableProto = ma.protoNames().includes('dnsaddr')\n\n // Multiaddr is not resolvable? End recursion!\n if (!resolvableProto) {\n return [ma]\n }\n\n const resolvedMultiaddrs = await this._resolveRecord(ma)\n const recursiveMultiaddrs = await Promise.all(resolvedMultiaddrs.map((nm) => {\n return this._resolve(nm)\n }))\n\n const addrs = recursiveMultiaddrs.flat()\n return addrs.reduce((array, newM) => {\n if (!array.find(m => m.equals(newM))) {\n array.push(newM)\n }\n return array\n }, /** @type {Multiaddr[]} */([]))\n }\n\n /**\n * Resolve a given multiaddr. If this fails, an empty array will be returned\n *\n * @param {Multiaddr} ma\n * @returns {Promise}\n */\n async _resolveRecord (ma) {\n try {\n ma = new Multiaddr(ma.toString()) // Use current multiaddr module\n const multiaddrs = await ma.resolve()\n return multiaddrs\n } catch (_) {\n log.error(`multiaddr ${ma} could not be resolved`)\n return []\n }\n }\n}\n\nmodule.exports = Dialer\n","'use strict'\n\nconst errCode = require('err-code')\nconst AbortController = require('abort-controller').default\nconst { anySignal } = require('any-signal')\n// @ts-ignore p-fifo does not export types\nconst FIFO = require('p-fifo')\nconst pAny = require('p-any')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('./')} Dialer\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @typedef {Object} DialOptions\n * @property {AbortSignal} signal\n *\n * @typedef {Object} DialRequestOptions\n * @property {Multiaddr[]} addrs\n * @property {(m: Multiaddr, options: DialOptions) => Promise} dialAction\n * @property {Dialer} dialer\n */\n\nclass DialRequest {\n /**\n * Manages running the `dialAction` on multiple provided `addrs` in parallel\n * up to a maximum determined by the number of tokens returned\n * from `dialer.getTokens`. Once a DialRequest is created, it can be\n * started using `DialRequest.run(options)`. Once a single dial has succeeded,\n * all other dials in the request will be cancelled.\n *\n * @class\n * @param {DialRequestOptions} options\n */\n constructor ({\n addrs,\n dialAction,\n dialer\n }) {\n this.addrs = addrs\n this.dialer = dialer\n this.dialAction = dialAction\n }\n\n /**\n * @async\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - An AbortController signal\n * @returns {Promise}\n */\n async run (options = {}) {\n const tokens = this.dialer.getTokens(this.addrs.length)\n // If no tokens are available, throw\n if (tokens.length < 1) {\n throw errCode(new Error('No dial tokens available'), 'ERR_NO_DIAL_TOKENS')\n }\n\n const tokenHolder = new FIFO()\n tokens.forEach(token => tokenHolder.push(token))\n const dialAbortControllers = this.addrs.map(() => new AbortController())\n let completedDials = 0\n\n try {\n return await pAny(this.addrs.map(async (addr, i) => {\n const token = await tokenHolder.shift() // get token\n let conn\n try {\n const signal = dialAbortControllers[i].signal\n conn = await this.dialAction(addr, { ...options, signal: options.signal ? anySignal([signal, options.signal]) : signal })\n // Remove the successful AbortController so it is not aborted\n dialAbortControllers.splice(i, 1)\n } finally {\n completedDials++\n // If we have more or equal dials remaining than tokens, recycle the token, otherwise release it\n if (this.addrs.length - completedDials >= tokens.length) {\n tokenHolder.push(token)\n } else {\n this.dialer.releaseToken(tokens.splice(tokens.indexOf(token), 1)[0])\n }\n }\n\n return conn\n }))\n } finally {\n dialAbortControllers.map(c => c.abort()) // success/failure happened, abort everything else\n tokens.forEach(token => this.dialer.releaseToken(token)) // release tokens back to the dialer\n }\n }\n}\n\nmodule.exports = DialRequest\n","const Fifo = require('fast-fifo')\nconst defer = require('p-defer')\n\nmodule.exports = class PFifo {\n constructor () {\n this._buffer = new Fifo()\n this._waitingConsumers = new Fifo()\n }\n\n push (chunk) {\n const { promise, resolve } = defer()\n this._buffer.push({ chunk, resolve })\n this._consume()\n return promise\n }\n\n _consume () {\n while (!this._waitingConsumers.isEmpty() && !this._buffer.isEmpty()) {\n const nextConsumer = this._waitingConsumers.shift()\n const nextChunk = this._buffer.shift()\n nextConsumer.resolve(nextChunk.chunk)\n nextChunk.resolve()\n }\n }\n\n shift () {\n const { promise, resolve } = defer()\n this._waitingConsumers.push({ resolve })\n this._consume()\n return promise\n }\n\n isEmpty () {\n return this._buffer.isEmpty()\n }\n}\n","'use strict';\nconst pSome = require('p-some');\nconst PCancelable = require('p-cancelable');\n\nmodule.exports = (iterable, options) => {\n\tconst anyCancelable = pSome(iterable, {...options, count: 1});\n\n\treturn PCancelable.fn(async onCancel => {\n\t\tonCancel(() => {\n\t\t\tanyCancelable.cancel();\n\t\t});\n\n\t\tconst [value] = await anyCancelable;\n\t\treturn value;\n\t})();\n};\n\nmodule.exports.AggregateError = pSome.AggregateError;\n","'use strict';\nconst AggregateError = require('aggregate-error');\nconst PCancelable = require('p-cancelable');\n\nclass FilterError extends Error { }\n\nconst pSome = (iterable, options) => new PCancelable((resolve, reject, onCancel) => {\n\tconst {\n\t\tcount,\n\t\tfilter = () => true\n\t} = options;\n\n\tif (!Number.isFinite(count)) {\n\t\treject(new TypeError(`Expected a finite number, got ${typeof options.count}`));\n\t\treturn;\n\t}\n\n\tconst values = [];\n\tconst errors = [];\n\tlet elementCount = 0;\n\tlet isSettled = false;\n\n\tconst completed = new Set();\n\tconst maybeSettle = () => {\n\t\tif (values.length === count) {\n\t\t\tresolve(values);\n\t\t\tisSettled = true;\n\t\t}\n\n\t\tif (elementCount - errors.length < count) {\n\t\t\treject(new AggregateError(errors));\n\t\t\tisSettled = true;\n\t\t}\n\n\t\treturn isSettled;\n\t};\n\n\tconst cancelPending = () => {\n\t\tfor (const promise of iterable) {\n\t\t\tif (!completed.has(promise) && typeof promise.cancel === 'function') {\n\t\t\t\tpromise.cancel();\n\t\t\t}\n\t\t}\n\t};\n\n\tonCancel(cancelPending);\n\n\tfor (const element of iterable) {\n\t\telementCount++;\n\n\t\t(async () => {\n\t\t\ttry {\n\t\t\t\tconst value = await element;\n\n\t\t\t\tif (isSettled) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (!filter(value)) {\n\t\t\t\t\tthrow new FilterError('Value does not satisfy filter');\n\t\t\t\t}\n\n\t\t\t\tvalues.push(value);\n\t\t\t} catch (error) {\n\t\t\t\terrors.push(error);\n\t\t\t} finally {\n\t\t\t\tcompleted.add(element);\n\n\t\t\t\tif (!isSettled && maybeSettle()) {\n\t\t\t\t\tcancelPending();\n\t\t\t\t}\n\t\t\t}\n\t\t})();\n\t}\n\n\tif (count > elementCount) {\n\t\treject(new RangeError(`Expected input to contain at least ${options.count} items, but contains ${elementCount} items`));\n\t\tcancelPending();\n\t}\n});\n\nmodule.exports = pSome;\nmodule.exports.AggregateError = AggregateError;\nmodule.exports.FilterError = FilterError;\n","'use strict';\n\nclass CancelError extends Error {\n\tconstructor(reason) {\n\t\tsuper(reason || 'Promise was canceled');\n\t\tthis.name = 'CancelError';\n\t}\n\n\tget isCanceled() {\n\t\treturn true;\n\t}\n}\n\nclass PCancelable {\n\tstatic fn(userFn) {\n\t\treturn (...arguments_) => {\n\t\t\treturn new PCancelable((resolve, reject, onCancel) => {\n\t\t\t\targuments_.push(onCancel);\n\t\t\t\t// eslint-disable-next-line promise/prefer-await-to-then\n\t\t\t\tuserFn(...arguments_).then(resolve, reject);\n\t\t\t});\n\t\t};\n\t}\n\n\tconstructor(executor) {\n\t\tthis._cancelHandlers = [];\n\t\tthis._isPending = true;\n\t\tthis._isCanceled = false;\n\t\tthis._rejectOnCancel = true;\n\n\t\tthis._promise = new Promise((resolve, reject) => {\n\t\t\tthis._reject = reject;\n\n\t\t\tconst onResolve = value => {\n\t\t\t\tif (!this._isCanceled || !onCancel.shouldReject) {\n\t\t\t\t\tthis._isPending = false;\n\t\t\t\t\tresolve(value);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tconst onReject = error => {\n\t\t\t\tthis._isPending = false;\n\t\t\t\treject(error);\n\t\t\t};\n\n\t\t\tconst onCancel = handler => {\n\t\t\t\tif (!this._isPending) {\n\t\t\t\t\tthrow new Error('The `onCancel` handler was attached after the promise settled.');\n\t\t\t\t}\n\n\t\t\t\tthis._cancelHandlers.push(handler);\n\t\t\t};\n\n\t\t\tObject.defineProperties(onCancel, {\n\t\t\t\tshouldReject: {\n\t\t\t\t\tget: () => this._rejectOnCancel,\n\t\t\t\t\tset: boolean => {\n\t\t\t\t\t\tthis._rejectOnCancel = boolean;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\n\t\t\treturn executor(onResolve, onReject, onCancel);\n\t\t});\n\t}\n\n\tthen(onFulfilled, onRejected) {\n\t\t// eslint-disable-next-line promise/prefer-await-to-then\n\t\treturn this._promise.then(onFulfilled, onRejected);\n\t}\n\n\tcatch(onRejected) {\n\t\treturn this._promise.catch(onRejected);\n\t}\n\n\tfinally(onFinally) {\n\t\treturn this._promise.finally(onFinally);\n\t}\n\n\tcancel(reason) {\n\t\tif (!this._isPending || this._isCanceled) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis._isCanceled = true;\n\n\t\tif (this._cancelHandlers.length > 0) {\n\t\t\ttry {\n\t\t\t\tfor (const handler of this._cancelHandlers) {\n\t\t\t\t\thandler();\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tthis._reject(error);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tif (this._rejectOnCancel) {\n\t\t\tthis._reject(new CancelError(reason));\n\t\t}\n\t}\n\n\tget isCanceled() {\n\t\treturn this._isCanceled;\n\t}\n}\n\nObject.setPrototypeOf(PCancelable.prototype, Promise.prototype);\n\nmodule.exports = PCancelable;\nmodule.exports.CancelError = CancelError;\n","/* eslint max-nested-callbacks: [\"error\", 5] */\n'use strict'\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:keychain'), {\n error: debug('libp2p:keychain:err')\n})\nconst sanitize = require('sanitize-filename')\nconst mergeOptions = require('merge-options')\nconst crypto = require('libp2p-crypto')\nconst { Key } = require('interface-datastore/key')\nconst CMS = require('./cms')\nconst errcode = require('err-code')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\n// @ts-ignore node-forge sha512 types not exported\nrequire('node-forge/lib/sha512')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('interface-datastore').Datastore} Datastore\n */\n\n/**\n * @typedef {Object} DekOptions\n * @property {string} hash\n * @property {string} salt\n * @property {number} iterationCount\n * @property {number} keyLength\n *\n * @typedef {Object} KeychainOptions\n * @property {string} [pass]\n * @property {DekOptions} [dek]\n */\n\n/**\n * Information about a key.\n *\n * @typedef {Object} KeyInfo\n * @property {string} id - The universally unique key id.\n * @property {string} name - The local key name.\n */\n\nconst keyPrefix = '/pkcs8/'\nconst infoPrefix = '/info/'\nconst privates = new WeakMap()\n\n// NIST SP 800-132\nconst NIST = {\n minKeyLength: 112 / 8,\n minSaltLength: 128 / 8,\n minIterationCount: 1000\n}\n\nconst defaultOptions = {\n // See https://cryptosense.com/parametesr-choice-for-pbkdf2/\n dek: {\n keyLength: 512 / 8,\n iterationCount: 10000,\n salt: 'you should override this value with a crypto secure random number',\n hash: 'sha2-512'\n }\n}\n\n/**\n * @param {string} name\n */\nfunction validateKeyName (name) {\n if (!name) return false\n if (typeof name !== 'string') return false\n return name === sanitize(name.trim())\n}\n\n/**\n * Throws an error after a delay\n *\n * This assumes than an error indicates that the keychain is under attack. Delay returning an\n * error to make brute force attacks harder.\n *\n * @param {string|Error} err - The error\n * @returns {Promise}\n * @private\n */\nasync function throwDelayed (err) {\n const min = 200\n const max = 1000\n const delay = Math.random() * (max - min) + min\n\n await new Promise(resolve => setTimeout(resolve, delay))\n throw err\n}\n\n/**\n * Converts a key name into a datastore name.\n *\n * @param {string} name\n * @returns {Key}\n * @private\n */\nfunction DsName (name) {\n return new Key(keyPrefix + name)\n}\n\n/**\n * Converts a key name into a datastore info name.\n *\n * @param {string} name\n * @returns {Key}\n * @private\n */\nfunction DsInfoName (name) {\n return new Key(infoPrefix + name)\n}\n\n/**\n * Manages the lifecycle of a key. Keys are encrypted at rest using PKCS #8.\n *\n * A key in the store has two entries\n * - '/info/*key-name*', contains the KeyInfo for the key\n * - '/pkcs8/*key-name*', contains the PKCS #8 for the key\n *\n */\nclass Keychain {\n /**\n * Creates a new instance of a key chain.\n *\n * @param {Datastore} store - where the key are.\n * @param {KeychainOptions} options\n * @class\n */\n constructor (store, options) {\n if (!store) {\n throw new Error('store is required')\n }\n this.store = store\n\n this.opts = mergeOptions(defaultOptions, options)\n\n // Enforce NIST SP 800-132\n if (this.opts.pass && this.opts.pass.length < 20) {\n throw new Error('pass must be least 20 characters')\n }\n if (this.opts.dek.keyLength < NIST.minKeyLength) {\n throw new Error(`dek.keyLength must be least ${NIST.minKeyLength} bytes`)\n }\n if (this.opts.dek.salt.length < NIST.minSaltLength) {\n throw new Error(`dek.saltLength must be least ${NIST.minSaltLength} bytes`)\n }\n if (this.opts.dek.iterationCount < NIST.minIterationCount) {\n throw new Error(`dek.iterationCount must be least ${NIST.minIterationCount}`)\n }\n\n const dek = this.opts.pass\n ? crypto.pbkdf2(\n this.opts.pass,\n this.opts.dek.salt,\n this.opts.dek.iterationCount,\n this.opts.dek.keyLength,\n this.opts.dek.hash)\n : ''\n\n privates.set(this, { dek })\n }\n\n /**\n * Gets an object that can encrypt/decrypt protected data\n * using the Cryptographic Message Syntax (CMS).\n *\n * CMS describes an encapsulation syntax for data protection. It\n * is used to digitally sign, digest, authenticate, or encrypt\n * arbitrary message content.\n *\n * @returns {CMS}\n */\n get cms () {\n return new CMS(this, privates.get(this).dek)\n }\n\n /**\n * Generates the options for a keychain. A random salt is produced.\n *\n * @returns {Object}\n */\n static generateOptions () {\n const options = Object.assign({}, defaultOptions)\n const saltLength = Math.ceil(NIST.minSaltLength / 3) * 3 // no base64 padding\n options.dek.salt = uint8ArrayToString(crypto.randomBytes(saltLength), 'base64')\n return options\n }\n\n /**\n * Gets an object that can encrypt/decrypt protected data.\n * The default options for a keychain.\n *\n * @returns {Object}\n */\n static get options () {\n return defaultOptions\n }\n\n /**\n * Create a new key.\n *\n * @param {string} name - The local key name; cannot already exist.\n * @param {string} type - One of the key types; 'rsa'.\n * @param {number} [size = 2048] - The key size in bits. Used for rsa keys only.\n * @returns {Promise}\n */\n async createKey (name, type, size = 2048) {\n const self = this\n\n if (!validateKeyName(name) || name === 'self') {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n\n if (typeof type !== 'string') {\n return throwDelayed(errcode(new Error(`Invalid key type '${type}'`), 'ERR_INVALID_KEY_TYPE'))\n }\n\n const dsname = DsName(name)\n const exists = await self.store.has(dsname)\n if (exists) return throwDelayed(errcode(new Error(`Key '${name}' already exists`), 'ERR_KEY_ALREADY_EXISTS'))\n\n switch (type.toLowerCase()) {\n case 'rsa':\n if (!Number.isSafeInteger(size) || size < 2048) {\n return throwDelayed(errcode(new Error(`Invalid RSA key size ${size}`), 'ERR_INVALID_KEY_SIZE'))\n }\n break\n default:\n break\n }\n\n let keyInfo\n try {\n // @ts-ignore Differences between several crypto return types need to be fixed in libp2p-crypto\n const keypair = await crypto.keys.generateKeyPair(type, size)\n const kid = await keypair.id()\n /** @type {string} */\n const dek = privates.get(this).dek\n const pem = await keypair.export(dek)\n keyInfo = {\n name: name,\n id: kid\n }\n const batch = self.store.batch()\n batch.put(dsname, uint8ArrayFromString(pem))\n batch.put(DsInfoName(name), uint8ArrayFromString(JSON.stringify(keyInfo)))\n\n await batch.commit()\n } catch (err) {\n return throwDelayed(err)\n }\n\n return keyInfo\n }\n\n /**\n * List all the keys.\n *\n * @returns {Promise}\n */\n async listKeys () {\n const self = this\n const query = {\n prefix: infoPrefix\n }\n\n const info = []\n for await (const value of self.store.query(query)) {\n info.push(JSON.parse(uint8ArrayToString(value.value)))\n }\n\n return info\n }\n\n /**\n * Find a key by it's id.\n *\n * @param {string} id - The universally unique key identifier.\n * @returns {Promise}\n */\n async findKeyById (id) {\n try {\n const keys = await this.listKeys()\n return keys.find((k) => k.id === id)\n } catch (err) {\n return throwDelayed(err)\n }\n }\n\n /**\n * Find a key by it's name.\n *\n * @param {string} name - The local key name.\n * @returns {Promise}\n */\n async findKeyByName (name) {\n if (!validateKeyName(name)) {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n\n const dsname = DsInfoName(name)\n try {\n const res = await this.store.get(dsname)\n return JSON.parse(uint8ArrayToString(res))\n } catch (err) {\n return throwDelayed(errcode(new Error(`Key '${name}' does not exist. ${err.message}`), 'ERR_KEY_NOT_FOUND'))\n }\n }\n\n /**\n * Remove an existing key.\n *\n * @param {string} name - The local key name; must already exist.\n * @returns {Promise}\n */\n async removeKey (name) {\n const self = this\n if (!validateKeyName(name) || name === 'self') {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n const dsname = DsName(name)\n const keyInfo = await self.findKeyByName(name)\n const batch = self.store.batch()\n batch.delete(dsname)\n batch.delete(DsInfoName(name))\n await batch.commit()\n return keyInfo\n }\n\n /**\n * Rename a key\n *\n * @param {string} oldName - The old local key name; must already exist.\n * @param {string} newName - The new local key name; must not already exist.\n * @returns {Promise}\n */\n async renameKey (oldName, newName) {\n const self = this\n if (!validateKeyName(oldName) || oldName === 'self') {\n return throwDelayed(errcode(new Error(`Invalid old key name '${oldName}'`), 'ERR_OLD_KEY_NAME_INVALID'))\n }\n if (!validateKeyName(newName) || newName === 'self') {\n return throwDelayed(errcode(new Error(`Invalid new key name '${newName}'`), 'ERR_NEW_KEY_NAME_INVALID'))\n }\n const oldDsname = DsName(oldName)\n const newDsname = DsName(newName)\n const oldInfoName = DsInfoName(oldName)\n const newInfoName = DsInfoName(newName)\n\n const exists = await self.store.has(newDsname)\n if (exists) return throwDelayed(errcode(new Error(`Key '${newName}' already exists`), 'ERR_KEY_ALREADY_EXISTS'))\n\n try {\n const pem = await self.store.get(oldDsname)\n const res = await self.store.get(oldInfoName)\n\n const keyInfo = JSON.parse(uint8ArrayToString(res))\n keyInfo.name = newName\n const batch = self.store.batch()\n batch.put(newDsname, pem)\n batch.put(newInfoName, uint8ArrayFromString(JSON.stringify(keyInfo)))\n batch.delete(oldDsname)\n batch.delete(oldInfoName)\n await batch.commit()\n return keyInfo\n } catch (err) {\n return throwDelayed(err)\n }\n }\n\n /**\n * Export an existing key as a PEM encrypted PKCS #8 string\n *\n * @param {string} name - The local key name; must already exist.\n * @param {string} password - The password\n * @returns {Promise}\n */\n async exportKey (name, password) {\n if (!validateKeyName(name)) {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n if (!password) {\n return throwDelayed(errcode(new Error('Password is required'), 'ERR_PASSWORD_REQUIRED'))\n }\n\n const dsname = DsName(name)\n try {\n const res = await this.store.get(dsname)\n const pem = uint8ArrayToString(res)\n /** @type {string} */\n const dek = privates.get(this).dek\n const privateKey = await crypto.keys.import(pem, dek)\n return privateKey.export(password)\n } catch (err) {\n return throwDelayed(err)\n }\n }\n\n /**\n * Import a new key from a PEM encoded PKCS #8 string\n *\n * @param {string} name - The local key name; must not already exist.\n * @param {string} pem - The PEM encoded PKCS #8 string\n * @param {string} password - The password.\n * @returns {Promise}\n */\n async importKey (name, pem, password) {\n const self = this\n if (!validateKeyName(name) || name === 'self') {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n if (!pem) {\n return throwDelayed(errcode(new Error('PEM encoded key is required'), 'ERR_PEM_REQUIRED'))\n }\n const dsname = DsName(name)\n const exists = await self.store.has(dsname)\n if (exists) return throwDelayed(errcode(new Error(`Key '${name}' already exists`), 'ERR_KEY_ALREADY_EXISTS'))\n\n let privateKey\n try {\n privateKey = await crypto.keys.import(pem, password)\n } catch (err) {\n return throwDelayed(errcode(new Error('Cannot read the key, most likely the password is wrong'), 'ERR_CANNOT_READ_KEY'))\n }\n\n let kid\n try {\n kid = await privateKey.id()\n /** @type {string} */\n const dek = privates.get(this).dek\n pem = await privateKey.export(dek)\n } catch (err) {\n return throwDelayed(err)\n }\n\n const keyInfo = {\n name: name,\n id: kid\n }\n const batch = self.store.batch()\n batch.put(dsname, uint8ArrayFromString(pem))\n batch.put(DsInfoName(name), uint8ArrayFromString(JSON.stringify(keyInfo)))\n await batch.commit()\n\n return keyInfo\n }\n\n /**\n * Import a peer key\n *\n * @param {string} name - The local key name; must not already exist.\n * @param {PeerId} peer - The PEM encoded PKCS #8 string\n * @returns {Promise}\n */\n async importPeer (name, peer) {\n const self = this\n if (!validateKeyName(name)) {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n if (!peer || !peer.privKey) {\n return throwDelayed(errcode(new Error('Peer.privKey is required'), 'ERR_MISSING_PRIVATE_KEY'))\n }\n\n const privateKey = peer.privKey\n const dsname = DsName(name)\n const exists = await self.store.has(dsname)\n if (exists) return throwDelayed(errcode(new Error(`Key '${name}' already exists`), 'ERR_KEY_ALREADY_EXISTS'))\n\n try {\n const kid = await privateKey.id()\n /** @type {string} */\n const dek = privates.get(this).dek\n const pem = await privateKey.export(dek)\n const keyInfo = {\n name: name,\n id: kid\n }\n const batch = self.store.batch()\n batch.put(dsname, uint8ArrayFromString(pem))\n batch.put(DsInfoName(name), uint8ArrayFromString(JSON.stringify(keyInfo)))\n await batch.commit()\n return keyInfo\n } catch (err) {\n return throwDelayed(err)\n }\n }\n\n /**\n * Gets the private key as PEM encoded PKCS #8 string.\n *\n * @param {string} name\n * @returns {Promise}\n */\n async _getPrivateKey (name) {\n if (!validateKeyName(name)) {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n\n try {\n const dsname = DsName(name)\n const res = await this.store.get(dsname)\n return uint8ArrayToString(res)\n } catch (err) {\n return throwDelayed(errcode(new Error(`Key '${name}' does not exist. ${err.message}`), 'ERR_KEY_NOT_FOUND'))\n }\n }\n\n /**\n * Rotate keychain password and re-encrypt all assosciated keys\n *\n * @param {string} oldPass - The old local keychain password\n * @param {string} newPass - The new local keychain password\n */\n async rotateKeychainPass (oldPass, newPass) {\n if (typeof oldPass !== 'string') {\n return throwDelayed(errcode(new Error(`Invalid old pass type '${typeof oldPass}'`), 'ERR_INVALID_OLD_PASS_TYPE'))\n }\n if (typeof newPass !== 'string') {\n return throwDelayed(errcode(new Error(`Invalid new pass type '${typeof newPass}'`), 'ERR_INVALID_NEW_PASS_TYPE'))\n }\n if (newPass.length < 20) {\n return throwDelayed(errcode(new Error(`Invalid pass length ${newPass.length}`), 'ERR_INVALID_PASS_LENGTH'))\n }\n log('recreating keychain')\n const oldDek = privates.get(this).dek\n this.opts.pass = newPass\n const newDek = newPass\n ? crypto.pbkdf2(\n newPass,\n this.opts.dek.salt,\n this.opts.dek.iterationCount,\n this.opts.dek.keyLength,\n this.opts.dek.hash)\n : ''\n privates.set(this, { dek: newDek })\n const keys = await this.listKeys()\n for (const key of keys) {\n const res = await this.store.get(DsName(key.name))\n const pem = uint8ArrayToString(res)\n const privateKey = await crypto.keys.import(pem, oldDek)\n const password = newDek.toString()\n const keyAsPEM = await privateKey.export(password)\n\n // Update stored key\n const batch = this.store.batch()\n const keyInfo = {\n name: key.name,\n id: key.id\n }\n batch.put(DsName(key.name), uint8ArrayFromString(keyAsPEM))\n batch.put(DsInfoName(key.name), uint8ArrayFromString(JSON.stringify(keyInfo)))\n await batch.commit()\n }\n log('keychain reconstructed')\n }\n}\n\nmodule.exports = Keychain\n","/*jshint node:true*/\n'use strict';\n\n/**\n * Replaces characters in strings that are illegal/unsafe for filenames.\n * Unsafe characters are either removed or replaced by a substitute set\n * in the optional `options` object.\n *\n * Illegal Characters on Various Operating Systems\n * / ? < > \\ : * | \"\n * https://kb.acronis.com/content/39790\n *\n * Unicode Control codes\n * C0 0x00-0x1f & C1 (0x80-0x9f)\n * http://en.wikipedia.org/wiki/C0_and_C1_control_codes\n *\n * Reserved filenames on Unix-based systems (\".\", \"..\")\n * Reserved filenames in Windows (\"CON\", \"PRN\", \"AUX\", \"NUL\", \"COM1\",\n * \"COM2\", \"COM3\", \"COM4\", \"COM5\", \"COM6\", \"COM7\", \"COM8\", \"COM9\",\n * \"LPT1\", \"LPT2\", \"LPT3\", \"LPT4\", \"LPT5\", \"LPT6\", \"LPT7\", \"LPT8\", and\n * \"LPT9\") case-insesitively and with or without filename extensions.\n *\n * Capped at 255 characters in length.\n * http://unix.stackexchange.com/questions/32795/what-is-the-maximum-allowed-filename-and-folder-size-with-ecryptfs\n *\n * @param {String} input Original filename\n * @param {Object} options {replacement: String | Function }\n * @return {String} Sanitized filename\n */\n\nvar truncate = require(\"truncate-utf8-bytes\");\n\nvar illegalRe = /[\\/\\?<>\\\\:\\*\\|\"]/g;\nvar controlRe = /[\\x00-\\x1f\\x80-\\x9f]/g;\nvar reservedRe = /^\\.+$/;\nvar windowsReservedRe = /^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\\..*)?$/i;\nvar windowsTrailingRe = /[\\. ]+$/;\n\nfunction sanitize(input, replacement) {\n if (typeof input !== 'string') {\n throw new Error('Input must be string');\n }\n var sanitized = input\n .replace(illegalRe, replacement)\n .replace(controlRe, replacement)\n .replace(reservedRe, replacement)\n .replace(windowsReservedRe, replacement)\n .replace(windowsTrailingRe, replacement);\n return truncate(sanitized, 255);\n}\n\nmodule.exports = function (input, options) {\n var replacement = (options && options.replacement) || '';\n var output = sanitize(input, replacement);\n if (replacement === '') {\n return output;\n }\n return sanitize(output, '');\n};\n","'use strict';\n\nvar truncate = require(\"./lib/truncate\");\nvar getLength = require(\"utf8-byte-length/browser\");\nmodule.exports = truncate.bind(null, getLength);\n","'use strict';\n\nfunction isHighSurrogate(codePoint) {\n return codePoint >= 0xd800 && codePoint <= 0xdbff;\n}\n\nfunction isLowSurrogate(codePoint) {\n return codePoint >= 0xdc00 && codePoint <= 0xdfff;\n}\n\n// Truncate string by size in bytes\nmodule.exports = function truncate(getLength, string, byteLength) {\n if (typeof string !== \"string\") {\n throw new Error(\"Input must be string\");\n }\n\n var charLength = string.length;\n var curByteLength = 0;\n var codePoint;\n var segment;\n\n for (var i = 0; i < charLength; i += 1) {\n codePoint = string.charCodeAt(i);\n segment = string[i];\n\n if (isHighSurrogate(codePoint) && isLowSurrogate(string.charCodeAt(i + 1))) {\n i += 1;\n segment += string[i];\n }\n\n curByteLength += getLength(segment);\n\n if (curByteLength === byteLength) {\n return string.slice(0, i + 1);\n }\n else if (curByteLength > byteLength) {\n return string.slice(0, i - segment.length + 1);\n }\n }\n\n return string;\n};\n\n","'use strict';\n\nfunction isHighSurrogate(codePoint) {\n return codePoint >= 0xd800 && codePoint <= 0xdbff;\n}\n\nfunction isLowSurrogate(codePoint) {\n return codePoint >= 0xdc00 && codePoint <= 0xdfff;\n}\n\n// Truncate string by size in bytes\nmodule.exports = function getByteLength(string) {\n if (typeof string !== \"string\") {\n throw new Error(\"Input must be string\");\n }\n\n var charLength = string.length;\n var byteLength = 0;\n var codePoint = null;\n var prevCodePoint = null;\n for (var i = 0; i < charLength; i++) {\n codePoint = string.charCodeAt(i);\n // handle 4-byte non-BMP chars\n // low surrogate\n if (isLowSurrogate(codePoint)) {\n // when parsing previous hi-surrogate, 3 is added to byteLength\n if (prevCodePoint != null && isHighSurrogate(prevCodePoint)) {\n byteLength += 1;\n }\n else {\n byteLength += 3;\n }\n }\n else if (codePoint <= 0x7f ) {\n byteLength += 1;\n }\n else if (codePoint >= 0x80 && codePoint <= 0x7ff) {\n byteLength += 2;\n }\n else if (codePoint >= 0x800 && codePoint <= 0xffff) {\n byteLength += 3;\n }\n prevCodePoint = codePoint;\n }\n\n return byteLength;\n};\n","'use strict'\n\n// @ts-ignore node-forge types not exported\nrequire('node-forge/lib/pkcs7')\n// @ts-ignore node-forge types not exported\nrequire('node-forge/lib/pbe')\n// @ts-ignore node-forge types not exported\nconst forge = require('node-forge/lib/forge')\nconst { certificateForKey, findAsync } = require('./util')\nconst errcode = require('err-code')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst privates = new WeakMap()\n\n/**\n * Cryptographic Message Syntax (aka PKCS #7)\n *\n * CMS describes an encapsulation syntax for data protection. It\n * is used to digitally sign, digest, authenticate, or encrypt\n * arbitrary message content.\n *\n * See RFC 5652 for all the details.\n */\nclass CMS {\n /**\n * Creates a new instance with a keychain\n *\n * @param {import('./index')} keychain - the available keys\n * @param {string} dek\n */\n constructor (keychain, dek) {\n if (!keychain) {\n throw errcode(new Error('keychain is required'), 'ERR_KEYCHAIN_REQUIRED')\n }\n\n this.keychain = keychain\n privates.set(this, { dek })\n }\n\n /**\n * Creates some protected data.\n *\n * The output Uint8Array contains the PKCS #7 message in DER.\n *\n * @param {string} name - The local key name.\n * @param {Uint8Array} plain - The data to encrypt.\n * @returns {Promise}\n */\n async encrypt (name, plain) {\n if (!(plain instanceof Uint8Array)) {\n throw errcode(new Error('Plain data must be a Uint8Array'), 'ERR_INVALID_PARAMS')\n }\n\n const key = await this.keychain.findKeyByName(name)\n const pem = await this.keychain._getPrivateKey(name)\n /** @type {string} */\n const dek = privates.get(this).dek\n const privateKey = forge.pki.decryptRsaPrivateKey(pem, dek)\n const certificate = await certificateForKey(key, privateKey)\n\n // create a p7 enveloped message\n const p7 = forge.pkcs7.createEnvelopedData()\n p7.addRecipient(certificate)\n p7.content = forge.util.createBuffer(plain)\n p7.encrypt()\n\n // convert message to DER\n const der = forge.asn1.toDer(p7.toAsn1()).getBytes()\n return uint8ArrayFromString(der, 'ascii')\n }\n\n /**\n * Reads some protected data.\n *\n * The keychain must contain one of the keys used to encrypt the data. If none of the keys\n * exists, an Error is returned with the property 'missingKeys'. It is array of key ids.\n *\n * @param {Uint8Array} cmsData - The CMS encrypted data to decrypt.\n * @returns {Promise}\n */\n async decrypt (cmsData) {\n if (!(cmsData instanceof Uint8Array)) {\n throw errcode(new Error('CMS data is required'), 'ERR_INVALID_PARAMS')\n }\n\n let cms\n try {\n const buf = forge.util.createBuffer(uint8ArrayToString(cmsData, 'ascii'))\n const obj = forge.asn1.fromDer(buf)\n // @ts-ignore not defined\n cms = forge.pkcs7.messageFromAsn1(obj)\n } catch (err) {\n throw errcode(new Error('Invalid CMS: ' + err.message), 'ERR_INVALID_CMS')\n }\n\n // Find a recipient whose key we hold. We only deal with recipient certs\n // issued by ipfs (O=ipfs).\n const recipients = cms.recipients\n // @ts-ignore cms types not defined\n .filter(r => r.issuer.find(a => a.shortName === 'O' && a.value === 'ipfs'))\n // @ts-ignore cms types not defined\n .filter(r => r.issuer.find(a => a.shortName === 'CN'))\n // @ts-ignore cms types not defined\n .map(r => {\n return {\n recipient: r,\n // @ts-ignore cms types not defined\n keyId: r.issuer.find(a => a.shortName === 'CN').value\n }\n })\n\n const r = await findAsync(recipients, async (recipient) => {\n try {\n const key = await this.keychain.findKeyById(recipient.keyId)\n if (key) return true\n } catch (err) {\n return false\n }\n return false\n })\n\n if (!r) {\n // @ts-ignore cms types not defined\n const missingKeys = recipients.map(r => r.keyId)\n throw errcode(new Error('Decryption needs one of the key(s): ' + missingKeys.join(', ')), 'ERR_MISSING_KEYS', {\n missingKeys\n })\n }\n\n const key = await this.keychain.findKeyById(r.keyId)\n\n if (!key) {\n throw errcode(new Error('No key available to decrypto'), 'ERR_NO_KEY')\n }\n\n const pem = await this.keychain._getPrivateKey(key.name)\n const dek = privates.get(this).dek\n const privateKey = forge.pki.decryptRsaPrivateKey(pem, dek)\n cms.decrypt(r.recipient, privateKey)\n return uint8ArrayFromString(cms.content.getBytes(), 'ascii')\n }\n}\n\nmodule.exports = CMS\n","/**\n * Javascript implementation of PKCS#7 v1.5.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl \n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n *\n * Currently this implementation only supports ContentType of EnvelopedData,\n * EncryptedData, or SignedData at the root level. The top level elements may\n * contain only a ContentInfo of ContentType Data, i.e. plain data. Further\n * nesting is not (yet) supported.\n *\n * The Forge validators for PKCS #7's ASN.1 structures are available from\n * a separate file pkcs7asn1.js, since those are referenced from other\n * PKCS standards like PKCS #12.\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./oids');\nrequire('./pem');\nrequire('./pkcs7asn1');\nrequire('./random');\nrequire('./util');\nrequire('./x509');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7 = module.exports = forge.pkcs7 = forge.pkcs7 || {};\n\n/**\n * Converts a PKCS#7 message from PEM format.\n *\n * @param pem the PEM-formatted PKCS#7 message.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'PKCS7') {\n var error = new Error('Could not convert PKCS#7 message from PEM; PEM ' +\n 'header type is not \"PKCS#7\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert PKCS#7 message from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body);\n\n return p7.messageFromAsn1(obj);\n};\n\n/**\n * Converts a PKCS#7 message to PEM format.\n *\n * @param msg The PKCS#7 message object\n * @param maxline The maximum characters per line, defaults to 64.\n *\n * @return The PEM-formatted PKCS#7 message.\n */\np7.messageToPem = function(msg, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var pemObj = {\n type: 'PKCS7',\n body: asn1.toDer(msg.toAsn1()).getBytes()\n };\n return forge.pem.encode(pemObj, {maxline: maxline});\n};\n\n/**\n * Converts a PKCS#7 message from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a ContentInfo.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromAsn1 = function(obj) {\n // validate root level ContentInfo and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.contentInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 message. ' +\n 'ASN.1 object is not an PKCS#7 ContentInfo.');\n error.errors = errors;\n throw error;\n }\n\n var contentType = asn1.derToOid(capture.contentType);\n var msg;\n\n switch(contentType) {\n case forge.pki.oids.envelopedData:\n msg = p7.createEnvelopedData();\n break;\n\n case forge.pki.oids.encryptedData:\n msg = p7.createEncryptedData();\n break;\n\n case forge.pki.oids.signedData:\n msg = p7.createSignedData();\n break;\n\n default:\n throw new Error('Cannot read PKCS#7 message. ContentType with OID ' +\n contentType + ' is not (yet) supported.');\n }\n\n msg.fromAsn1(capture.content.value[0]);\n return msg;\n};\n\np7.createSignedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.signedData,\n version: 1,\n certificates: [],\n crls: [],\n // TODO: add json-formatted signer stuff here?\n signers: [],\n // populated during sign()\n digestAlgorithmIdentifiers: [],\n contentInfo: null,\n signerInfos: [],\n\n fromAsn1: function(obj) {\n // validate SignedData content block and capture data.\n _fromAsn1(msg, obj, p7.asn1.signedDataValidator);\n msg.certificates = [];\n msg.crls = [];\n msg.digestAlgorithmIdentifiers = [];\n msg.contentInfo = null;\n msg.signerInfos = [];\n\n if(msg.rawCapture.certificates) {\n var certs = msg.rawCapture.certificates.value;\n for(var i = 0; i < certs.length; ++i) {\n msg.certificates.push(forge.pki.certificateFromAsn1(certs[i]));\n }\n }\n\n // TODO: parse crls\n },\n\n toAsn1: function() {\n // degenerate case with no content\n if(!msg.contentInfo) {\n msg.sign();\n }\n\n var certs = [];\n for(var i = 0; i < msg.certificates.length; ++i) {\n certs.push(forge.pki.certificateToAsn1(msg.certificates[i]));\n }\n\n var crls = [];\n // TODO: implement CRLs\n\n // [0] SignedData\n var signedData = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(msg.version).getBytes()),\n // DigestAlgorithmIdentifiers\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n msg.digestAlgorithmIdentifiers),\n // ContentInfo\n msg.contentInfo\n ])\n ]);\n if(certs.length > 0) {\n // [0] IMPLICIT ExtendedCertificatesAndCertificates OPTIONAL\n signedData.value[0].value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, certs));\n }\n if(crls.length > 0) {\n // [1] IMPLICIT CertificateRevocationLists OPTIONAL\n signedData.value[0].value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, crls));\n }\n // SignerInfos\n signedData.value[0].value.push(\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n msg.signerInfos));\n\n // ContentInfo\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(msg.type).getBytes()),\n // [0] SignedData\n signedData\n ]);\n },\n\n /**\n * Add (another) entity to list of signers.\n *\n * Note: If authenticatedAttributes are provided, then, per RFC 2315,\n * they must include at least two attributes: content type and\n * message digest. The message digest attribute value will be\n * auto-calculated during signing and will be ignored if provided.\n *\n * Here's an example of providing these two attributes:\n *\n * forge.pkcs7.createSignedData();\n * p7.addSigner({\n * issuer: cert.issuer.attributes,\n * serialNumber: cert.serialNumber,\n * key: privateKey,\n * digestAlgorithm: forge.pki.oids.sha1,\n * authenticatedAttributes: [{\n * type: forge.pki.oids.contentType,\n * value: forge.pki.oids.data\n * }, {\n * type: forge.pki.oids.messageDigest\n * }]\n * });\n *\n * TODO: Support [subjectKeyIdentifier] as signer's ID.\n *\n * @param signer the signer information:\n * key the signer's private key.\n * [certificate] a certificate containing the public key\n * associated with the signer's private key; use this option as\n * an alternative to specifying signer.issuer and\n * signer.serialNumber.\n * [issuer] the issuer attributes (eg: cert.issuer.attributes).\n * [serialNumber] the signer's certificate's serial number in\n * hexadecimal (eg: cert.serialNumber).\n * [digestAlgorithm] the message digest OID, as a string, to use\n * (eg: forge.pki.oids.sha1).\n * [authenticatedAttributes] an optional array of attributes\n * to also sign along with the content.\n */\n addSigner: function(signer) {\n var issuer = signer.issuer;\n var serialNumber = signer.serialNumber;\n if(signer.certificate) {\n var cert = signer.certificate;\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n issuer = cert.issuer.attributes;\n serialNumber = cert.serialNumber;\n }\n var key = signer.key;\n if(!key) {\n throw new Error(\n 'Could not add PKCS#7 signer; no private key specified.');\n }\n if(typeof key === 'string') {\n key = forge.pki.privateKeyFromPem(key);\n }\n\n // ensure OID known for digest algorithm\n var digestAlgorithm = signer.digestAlgorithm || forge.pki.oids.sha1;\n switch(digestAlgorithm) {\n case forge.pki.oids.sha1:\n case forge.pki.oids.sha256:\n case forge.pki.oids.sha384:\n case forge.pki.oids.sha512:\n case forge.pki.oids.md5:\n break;\n default:\n throw new Error(\n 'Could not add PKCS#7 signer; unknown message digest algorithm: ' +\n digestAlgorithm);\n }\n\n // if authenticatedAttributes is present, then the attributes\n // must contain at least PKCS #9 content-type and message-digest\n var authenticatedAttributes = signer.authenticatedAttributes || [];\n if(authenticatedAttributes.length > 0) {\n var contentType = false;\n var messageDigest = false;\n for(var i = 0; i < authenticatedAttributes.length; ++i) {\n var attr = authenticatedAttributes[i];\n if(!contentType && attr.type === forge.pki.oids.contentType) {\n contentType = true;\n if(messageDigest) {\n break;\n }\n continue;\n }\n if(!messageDigest && attr.type === forge.pki.oids.messageDigest) {\n messageDigest = true;\n if(contentType) {\n break;\n }\n continue;\n }\n }\n\n if(!contentType || !messageDigest) {\n throw new Error('Invalid signer.authenticatedAttributes. If ' +\n 'signer.authenticatedAttributes is specified, then it must ' +\n 'contain at least two attributes, PKCS #9 content-type and ' +\n 'PKCS #9 message-digest.');\n }\n }\n\n msg.signers.push({\n key: key,\n version: 1,\n issuer: issuer,\n serialNumber: serialNumber,\n digestAlgorithm: digestAlgorithm,\n signatureAlgorithm: forge.pki.oids.rsaEncryption,\n signature: null,\n authenticatedAttributes: authenticatedAttributes,\n unauthenticatedAttributes: []\n });\n },\n\n /**\n * Signs the content.\n * @param options Options to apply when signing:\n * [detached] boolean. If signing should be done in detached mode. Defaults to false.\n */\n sign: function(options) {\n options = options || {};\n // auto-generate content info\n if(typeof msg.content !== 'object' || msg.contentInfo === null) {\n // use Data ContentInfo\n msg.contentInfo = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(forge.pki.oids.data).getBytes())\n ]);\n\n // add actual content, if present\n if('content' in msg) {\n var content;\n if(msg.content instanceof forge.util.ByteBuffer) {\n content = msg.content.bytes();\n } else if(typeof msg.content === 'string') {\n content = forge.util.encodeUtf8(msg.content);\n }\n\n if (options.detached) {\n msg.detachedContent = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, content);\n } else {\n msg.contentInfo.value.push(\n // [0] EXPLICIT content\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n content)\n ]));\n }\n }\n }\n\n // no signers, return early (degenerate case for certificate container)\n if(msg.signers.length === 0) {\n return;\n }\n\n // generate digest algorithm identifiers\n var mds = addDigestAlgorithmIds();\n\n // generate signerInfos\n addSignerInfos(mds);\n },\n\n verify: function() {\n throw new Error('PKCS#7 signature verification not yet implemented.');\n },\n\n /**\n * Add a certificate.\n *\n * @param cert the certificate to add.\n */\n addCertificate: function(cert) {\n // convert from PEM\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n msg.certificates.push(cert);\n },\n\n /**\n * Add a certificate revokation list.\n *\n * @param crl the certificate revokation list to add.\n */\n addCertificateRevokationList: function(crl) {\n throw new Error('PKCS#7 CRL support not yet implemented.');\n }\n };\n return msg;\n\n function addDigestAlgorithmIds() {\n var mds = {};\n\n for(var i = 0; i < msg.signers.length; ++i) {\n var signer = msg.signers[i];\n var oid = signer.digestAlgorithm;\n if(!(oid in mds)) {\n // content digest\n mds[oid] = forge.md[forge.pki.oids[oid]].create();\n }\n if(signer.authenticatedAttributes.length === 0) {\n // no custom attributes to digest; use content message digest\n signer.md = mds[oid];\n } else {\n // custom attributes to be digested; use own message digest\n // TODO: optimize to just copy message digest state if that\n // feature is ever supported with message digests\n signer.md = forge.md[forge.pki.oids[oid]].create();\n }\n }\n\n // add unique digest algorithm identifiers\n msg.digestAlgorithmIdentifiers = [];\n for(var oid in mds) {\n msg.digestAlgorithmIdentifiers.push(\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oid).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n }\n\n return mds;\n }\n\n function addSignerInfos(mds) {\n var content;\n\n if (msg.detachedContent) {\n // Signature has been made in detached mode.\n content = msg.detachedContent;\n } else {\n // Note: ContentInfo is a SEQUENCE with 2 values, second value is\n // the content field and is optional for a ContentInfo but required here\n // since signers are present\n // get ContentInfo content\n content = msg.contentInfo.value[1];\n // skip [0] EXPLICIT content wrapper\n content = content.value[0];\n }\n\n if(!content) {\n throw new Error(\n 'Could not sign PKCS#7 message; there is no content to sign.');\n }\n\n // get ContentInfo content type\n var contentType = asn1.derToOid(msg.contentInfo.value[0].value);\n\n // serialize content\n var bytes = asn1.toDer(content);\n\n // skip identifier and length per RFC 2315 9.3\n // skip identifier (1 byte)\n bytes.getByte();\n // read and discard length bytes\n asn1.getBerValueLength(bytes);\n bytes = bytes.getBytes();\n\n // digest content DER value bytes\n for(var oid in mds) {\n mds[oid].start().update(bytes);\n }\n\n // sign content\n var signingTime = new Date();\n for(var i = 0; i < msg.signers.length; ++i) {\n var signer = msg.signers[i];\n\n if(signer.authenticatedAttributes.length === 0) {\n // if ContentInfo content type is not \"Data\", then\n // authenticatedAttributes must be present per RFC 2315\n if(contentType !== forge.pki.oids.data) {\n throw new Error(\n 'Invalid signer; authenticatedAttributes must be present ' +\n 'when the ContentInfo content type is not PKCS#7 Data.');\n }\n } else {\n // process authenticated attributes\n // [0] IMPLICIT\n signer.authenticatedAttributesAsn1 = asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n\n // per RFC 2315, attributes are to be digested using a SET container\n // not the above [0] IMPLICIT container\n var attrsAsn1 = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SET, true, []);\n\n for(var ai = 0; ai < signer.authenticatedAttributes.length; ++ai) {\n var attr = signer.authenticatedAttributes[ai];\n if(attr.type === forge.pki.oids.messageDigest) {\n // use content message digest as value\n attr.value = mds[signer.digestAlgorithm].digest();\n } else if(attr.type === forge.pki.oids.signingTime) {\n // auto-populate signing time if not already set\n if(!attr.value) {\n attr.value = signingTime;\n }\n }\n\n // convert to ASN.1 and push onto Attributes SET (for signing) and\n // onto authenticatedAttributesAsn1 to complete SignedData ASN.1\n // TODO: optimize away duplication\n attrsAsn1.value.push(_attributeToAsn1(attr));\n signer.authenticatedAttributesAsn1.value.push(_attributeToAsn1(attr));\n }\n\n // DER-serialize and digest SET OF attributes only\n bytes = asn1.toDer(attrsAsn1).getBytes();\n signer.md.start().update(bytes);\n }\n\n // sign digest\n signer.signature = signer.key.sign(signer.md, 'RSASSA-PKCS1-V1_5');\n }\n\n // add signer info\n msg.signerInfos = _signersToAsn1(msg.signers);\n }\n};\n\n/**\n * Creates an empty PKCS#7 message of type EncryptedData.\n *\n * @return the message.\n */\np7.createEncryptedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.encryptedData,\n version: 0,\n encryptedContent: {\n algorithm: forge.pki.oids['aes256-CBC']\n },\n\n /**\n * Reads an EncryptedData content block (in ASN.1 format)\n *\n * @param obj The ASN.1 representation of the EncryptedData content block\n */\n fromAsn1: function(obj) {\n // Validate EncryptedData content block and capture data.\n _fromAsn1(msg, obj, p7.asn1.encryptedDataValidator);\n },\n\n /**\n * Decrypt encrypted content\n *\n * @param key The (symmetric) key as a byte buffer\n */\n decrypt: function(key) {\n if(key !== undefined) {\n msg.encryptedContent.key = key;\n }\n _decryptContent(msg);\n }\n };\n return msg;\n};\n\n/**\n * Creates an empty PKCS#7 message of type EnvelopedData.\n *\n * @return the message.\n */\np7.createEnvelopedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.envelopedData,\n version: 0,\n recipients: [],\n encryptedContent: {\n algorithm: forge.pki.oids['aes256-CBC']\n },\n\n /**\n * Reads an EnvelopedData content block (in ASN.1 format)\n *\n * @param obj the ASN.1 representation of the EnvelopedData content block.\n */\n fromAsn1: function(obj) {\n // validate EnvelopedData content block and capture data\n var capture = _fromAsn1(msg, obj, p7.asn1.envelopedDataValidator);\n msg.recipients = _recipientsFromAsn1(capture.recipientInfos.value);\n },\n\n toAsn1: function() {\n // ContentInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(msg.type).getBytes()),\n // [0] EnvelopedData\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(msg.version).getBytes()),\n // RecipientInfos\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n _recipientsToAsn1(msg.recipients)),\n // EncryptedContentInfo\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true,\n _encryptedContentToAsn1(msg.encryptedContent))\n ])\n ])\n ]);\n },\n\n /**\n * Find recipient by X.509 certificate's issuer.\n *\n * @param cert the certificate with the issuer to look for.\n *\n * @return the recipient object.\n */\n findRecipient: function(cert) {\n var sAttr = cert.issuer.attributes;\n\n for(var i = 0; i < msg.recipients.length; ++i) {\n var r = msg.recipients[i];\n var rAttr = r.issuer;\n\n if(r.serialNumber !== cert.serialNumber) {\n continue;\n }\n\n if(rAttr.length !== sAttr.length) {\n continue;\n }\n\n var match = true;\n for(var j = 0; j < sAttr.length; ++j) {\n if(rAttr[j].type !== sAttr[j].type ||\n rAttr[j].value !== sAttr[j].value) {\n match = false;\n break;\n }\n }\n\n if(match) {\n return r;\n }\n }\n\n return null;\n },\n\n /**\n * Decrypt enveloped content\n *\n * @param recipient The recipient object related to the private key\n * @param privKey The (RSA) private key object\n */\n decrypt: function(recipient, privKey) {\n if(msg.encryptedContent.key === undefined && recipient !== undefined &&\n privKey !== undefined) {\n switch(recipient.encryptedContent.algorithm) {\n case forge.pki.oids.rsaEncryption:\n case forge.pki.oids.desCBC:\n var key = privKey.decrypt(recipient.encryptedContent.content);\n msg.encryptedContent.key = forge.util.createBuffer(key);\n break;\n\n default:\n throw new Error('Unsupported asymmetric cipher, ' +\n 'OID ' + recipient.encryptedContent.algorithm);\n }\n }\n\n _decryptContent(msg);\n },\n\n /**\n * Add (another) entity to list of recipients.\n *\n * @param cert The certificate of the entity to add.\n */\n addRecipient: function(cert) {\n msg.recipients.push({\n version: 0,\n issuer: cert.issuer.attributes,\n serialNumber: cert.serialNumber,\n encryptedContent: {\n // We simply assume rsaEncryption here, since forge.pki only\n // supports RSA so far. If the PKI module supports other\n // ciphers one day, we need to modify this one as well.\n algorithm: forge.pki.oids.rsaEncryption,\n key: cert.publicKey\n }\n });\n },\n\n /**\n * Encrypt enveloped content.\n *\n * This function supports two optional arguments, cipher and key, which\n * can be used to influence symmetric encryption. Unless cipher is\n * provided, the cipher specified in encryptedContent.algorithm is used\n * (defaults to AES-256-CBC). If no key is provided, encryptedContent.key\n * is (re-)used. If that one's not set, a random key will be generated\n * automatically.\n *\n * @param [key] The key to be used for symmetric encryption.\n * @param [cipher] The OID of the symmetric cipher to use.\n */\n encrypt: function(key, cipher) {\n // Part 1: Symmetric encryption\n if(msg.encryptedContent.content === undefined) {\n cipher = cipher || msg.encryptedContent.algorithm;\n key = key || msg.encryptedContent.key;\n\n var keyLen, ivLen, ciphFn;\n switch(cipher) {\n case forge.pki.oids['aes128-CBC']:\n keyLen = 16;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['aes192-CBC']:\n keyLen = 24;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['aes256-CBC']:\n keyLen = 32;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['des-EDE3-CBC']:\n keyLen = 24;\n ivLen = 8;\n ciphFn = forge.des.createEncryptionCipher;\n break;\n\n default:\n throw new Error('Unsupported symmetric cipher, OID ' + cipher);\n }\n\n if(key === undefined) {\n key = forge.util.createBuffer(forge.random.getBytes(keyLen));\n } else if(key.length() != keyLen) {\n throw new Error('Symmetric key has wrong length; ' +\n 'got ' + key.length() + ' bytes, expected ' + keyLen + '.');\n }\n\n // Keep a copy of the key & IV in the object, so the caller can\n // use it for whatever reason.\n msg.encryptedContent.algorithm = cipher;\n msg.encryptedContent.key = key;\n msg.encryptedContent.parameter = forge.util.createBuffer(\n forge.random.getBytes(ivLen));\n\n var ciph = ciphFn(key);\n ciph.start(msg.encryptedContent.parameter.copy());\n ciph.update(msg.content);\n\n // The finish function does PKCS#7 padding by default, therefore\n // no action required by us.\n if(!ciph.finish()) {\n throw new Error('Symmetric encryption failed.');\n }\n\n msg.encryptedContent.content = ciph.output;\n }\n\n // Part 2: asymmetric encryption for each recipient\n for(var i = 0; i < msg.recipients.length; ++i) {\n var recipient = msg.recipients[i];\n\n // Nothing to do, encryption already done.\n if(recipient.encryptedContent.content !== undefined) {\n continue;\n }\n\n switch(recipient.encryptedContent.algorithm) {\n case forge.pki.oids.rsaEncryption:\n recipient.encryptedContent.content =\n recipient.encryptedContent.key.encrypt(\n msg.encryptedContent.key.data);\n break;\n\n default:\n throw new Error('Unsupported asymmetric cipher, OID ' +\n recipient.encryptedContent.algorithm);\n }\n }\n }\n };\n return msg;\n};\n\n/**\n * Converts a single recipient from an ASN.1 object.\n *\n * @param obj the ASN.1 RecipientInfo.\n *\n * @return the recipient object.\n */\nfunction _recipientFromAsn1(obj) {\n // validate EnvelopedData content block and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.recipientInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 RecipientInfo. ' +\n 'ASN.1 object is not an PKCS#7 RecipientInfo.');\n error.errors = errors;\n throw error;\n }\n\n return {\n version: capture.version.charCodeAt(0),\n issuer: forge.pki.RDNAttributesAsArray(capture.issuer),\n serialNumber: forge.util.createBuffer(capture.serial).toHex(),\n encryptedContent: {\n algorithm: asn1.derToOid(capture.encAlgorithm),\n parameter: capture.encParameter.value,\n content: capture.encKey\n }\n };\n}\n\n/**\n * Converts a single recipient object to an ASN.1 object.\n *\n * @param obj the recipient object.\n *\n * @return the ASN.1 RecipientInfo.\n */\nfunction _recipientToAsn1(obj) {\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(obj.version).getBytes()),\n // IssuerAndSerialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Name\n forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),\n // Serial\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(obj.serialNumber))\n ]),\n // KeyEncryptionAlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.encryptedContent.algorithm).getBytes()),\n // Parameter, force NULL, only RSA supported for now.\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // EncryptedKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n obj.encryptedContent.content)\n ]);\n}\n\n/**\n * Map a set of RecipientInfo ASN.1 objects to recipient objects.\n *\n * @param infos an array of ASN.1 representations RecipientInfo (i.e. SET OF).\n *\n * @return an array of recipient objects.\n */\nfunction _recipientsFromAsn1(infos) {\n var ret = [];\n for(var i = 0; i < infos.length; ++i) {\n ret.push(_recipientFromAsn1(infos[i]));\n }\n return ret;\n}\n\n/**\n * Map an array of recipient objects to ASN.1 RecipientInfo objects.\n *\n * @param recipients an array of recipientInfo objects.\n *\n * @return an array of ASN.1 RecipientInfos.\n */\nfunction _recipientsToAsn1(recipients) {\n var ret = [];\n for(var i = 0; i < recipients.length; ++i) {\n ret.push(_recipientToAsn1(recipients[i]));\n }\n return ret;\n}\n\n/**\n * Converts a single signer from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a SignerInfo.\n *\n * @return the signer object.\n */\nfunction _signerFromAsn1(obj) {\n // validate EnvelopedData content block and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.signerInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 SignerInfo. ' +\n 'ASN.1 object is not an PKCS#7 SignerInfo.');\n error.errors = errors;\n throw error;\n }\n\n var rval = {\n version: capture.version.charCodeAt(0),\n issuer: forge.pki.RDNAttributesAsArray(capture.issuer),\n serialNumber: forge.util.createBuffer(capture.serial).toHex(),\n digestAlgorithm: asn1.derToOid(capture.digestAlgorithm),\n signatureAlgorithm: asn1.derToOid(capture.signatureAlgorithm),\n signature: capture.signature,\n authenticatedAttributes: [],\n unauthenticatedAttributes: []\n };\n\n // TODO: convert attributes\n var authenticatedAttributes = capture.authenticatedAttributes || [];\n var unauthenticatedAttributes = capture.unauthenticatedAttributes || [];\n\n return rval;\n}\n\n/**\n * Converts a single signerInfo object to an ASN.1 object.\n *\n * @param obj the signerInfo object.\n *\n * @return the ASN.1 representation of a SignerInfo.\n */\nfunction _signerToAsn1(obj) {\n // SignerInfo\n var rval = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(obj.version).getBytes()),\n // issuerAndSerialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // name\n forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),\n // serial\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(obj.serialNumber))\n ]),\n // digestAlgorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.digestAlgorithm).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ]);\n\n // authenticatedAttributes (OPTIONAL)\n if(obj.authenticatedAttributesAsn1) {\n // add ASN.1 previously generated during signing\n rval.value.push(obj.authenticatedAttributesAsn1);\n }\n\n // digestEncryptionAlgorithm\n rval.value.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.signatureAlgorithm).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n\n // encryptedDigest\n rval.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, obj.signature));\n\n // unauthenticatedAttributes (OPTIONAL)\n if(obj.unauthenticatedAttributes.length > 0) {\n // [1] IMPLICIT\n var attrsAsn1 = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, []);\n for(var i = 0; i < obj.unauthenticatedAttributes.length; ++i) {\n var attr = obj.unauthenticatedAttributes[i];\n attrsAsn1.values.push(_attributeToAsn1(attr));\n }\n rval.value.push(attrsAsn1);\n }\n\n return rval;\n}\n\n/**\n * Map a set of SignerInfo ASN.1 objects to an array of signer objects.\n *\n * @param signerInfoAsn1s an array of ASN.1 SignerInfos (i.e. SET OF).\n *\n * @return an array of signers objects.\n */\nfunction _signersFromAsn1(signerInfoAsn1s) {\n var ret = [];\n for(var i = 0; i < signerInfoAsn1s.length; ++i) {\n ret.push(_signerFromAsn1(signerInfoAsn1s[i]));\n }\n return ret;\n}\n\n/**\n * Map an array of signer objects to ASN.1 objects.\n *\n * @param signers an array of signer objects.\n *\n * @return an array of ASN.1 SignerInfos.\n */\nfunction _signersToAsn1(signers) {\n var ret = [];\n for(var i = 0; i < signers.length; ++i) {\n ret.push(_signerToAsn1(signers[i]));\n }\n return ret;\n}\n\n/**\n * Convert an attribute object to an ASN.1 Attribute.\n *\n * @param attr the attribute object.\n *\n * @return the ASN.1 Attribute.\n */\nfunction _attributeToAsn1(attr) {\n var value;\n\n // TODO: generalize to support more attributes\n if(attr.type === forge.pki.oids.contentType) {\n value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.value).getBytes());\n } else if(attr.type === forge.pki.oids.messageDigest) {\n value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n attr.value.bytes());\n } else if(attr.type === forge.pki.oids.signingTime) {\n /* Note per RFC 2985: Dates between 1 January 1950 and 31 December 2049\n (inclusive) MUST be encoded as UTCTime. Any dates with year values\n before 1950 or after 2049 MUST be encoded as GeneralizedTime. [Further,]\n UTCTime values MUST be expressed in Greenwich Mean Time (Zulu) and MUST\n include seconds (i.e., times are YYMMDDHHMMSSZ), even where the\n number of seconds is zero. Midnight (GMT) must be represented as\n \"YYMMDD000000Z\". */\n // TODO: make these module-level constants\n var jan_1_1950 = new Date('1950-01-01T00:00:00Z');\n var jan_1_2050 = new Date('2050-01-01T00:00:00Z');\n var date = attr.value;\n if(typeof date === 'string') {\n // try to parse date\n var timestamp = Date.parse(date);\n if(!isNaN(timestamp)) {\n date = new Date(timestamp);\n } else if(date.length === 13) {\n // YYMMDDHHMMSSZ (13 chars for UTCTime)\n date = asn1.utcTimeToDate(date);\n } else {\n // assume generalized time\n date = asn1.generalizedTimeToDate(date);\n }\n }\n\n if(date >= jan_1_1950 && date < jan_1_2050) {\n value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.UTCTIME, false,\n asn1.dateToUtcTime(date));\n } else {\n value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.GENERALIZEDTIME, false,\n asn1.dateToGeneralizedTime(date));\n }\n }\n\n // TODO: expose as common API call\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n // AttributeValue\n value\n ])\n ]);\n}\n\n/**\n * Map messages encrypted content to ASN.1 objects.\n *\n * @param ec The encryptedContent object of the message.\n *\n * @return ASN.1 representation of the encryptedContent object (SEQUENCE).\n */\nfunction _encryptedContentToAsn1(ec) {\n return [\n // ContentType, always Data for the moment\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(forge.pki.oids.data).getBytes()),\n // ContentEncryptionAlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(ec.algorithm).getBytes()),\n // Parameters (IV)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n ec.parameter.getBytes())\n ]),\n // [0] EncryptedContent\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n ec.content.getBytes())\n ])\n ];\n}\n\n/**\n * Reads the \"common part\" of an PKCS#7 content block (in ASN.1 format)\n *\n * This function reads the \"common part\" of the PKCS#7 content blocks\n * EncryptedData and EnvelopedData, i.e. version number and symmetrically\n * encrypted content block.\n *\n * The result of the ASN.1 validate and capture process is returned\n * to allow the caller to extract further data, e.g. the list of recipients\n * in case of a EnvelopedData object.\n *\n * @param msg the PKCS#7 object to read the data to.\n * @param obj the ASN.1 representation of the content block.\n * @param validator the ASN.1 structure validator object to use.\n *\n * @return the value map captured by validator object.\n */\nfunction _fromAsn1(msg, obj, validator) {\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, validator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 message. ' +\n 'ASN.1 object is not a supported PKCS#7 message.');\n error.errors = error;\n throw error;\n }\n\n // Check contentType, so far we only support (raw) Data.\n var contentType = asn1.derToOid(capture.contentType);\n if(contentType !== forge.pki.oids.data) {\n throw new Error('Unsupported PKCS#7 message. ' +\n 'Only wrapped ContentType Data supported.');\n }\n\n if(capture.encryptedContent) {\n var content = '';\n if(forge.util.isArray(capture.encryptedContent)) {\n for(var i = 0; i < capture.encryptedContent.length; ++i) {\n if(capture.encryptedContent[i].type !== asn1.Type.OCTETSTRING) {\n throw new Error('Malformed PKCS#7 message, expecting encrypted ' +\n 'content constructed of only OCTET STRING objects.');\n }\n content += capture.encryptedContent[i].value;\n }\n } else {\n content = capture.encryptedContent;\n }\n msg.encryptedContent = {\n algorithm: asn1.derToOid(capture.encAlgorithm),\n parameter: forge.util.createBuffer(capture.encParameter.value),\n content: forge.util.createBuffer(content)\n };\n }\n\n if(capture.content) {\n var content = '';\n if(forge.util.isArray(capture.content)) {\n for(var i = 0; i < capture.content.length; ++i) {\n if(capture.content[i].type !== asn1.Type.OCTETSTRING) {\n throw new Error('Malformed PKCS#7 message, expecting ' +\n 'content constructed of only OCTET STRING objects.');\n }\n content += capture.content[i].value;\n }\n } else {\n content = capture.content;\n }\n msg.content = forge.util.createBuffer(content);\n }\n\n msg.version = capture.version.charCodeAt(0);\n msg.rawCapture = capture;\n\n return capture;\n}\n\n/**\n * Decrypt the symmetrically encrypted content block of the PKCS#7 message.\n *\n * Decryption is skipped in case the PKCS#7 message object already has a\n * (decrypted) content attribute. The algorithm, key and cipher parameters\n * (probably the iv) are taken from the encryptedContent attribute of the\n * message object.\n *\n * @param The PKCS#7 message object.\n */\nfunction _decryptContent(msg) {\n if(msg.encryptedContent.key === undefined) {\n throw new Error('Symmetric key not available.');\n }\n\n if(msg.content === undefined) {\n var ciph;\n\n switch(msg.encryptedContent.algorithm) {\n case forge.pki.oids['aes128-CBC']:\n case forge.pki.oids['aes192-CBC']:\n case forge.pki.oids['aes256-CBC']:\n ciph = forge.aes.createDecryptionCipher(msg.encryptedContent.key);\n break;\n\n case forge.pki.oids['desCBC']:\n case forge.pki.oids['des-EDE3-CBC']:\n ciph = forge.des.createDecryptionCipher(msg.encryptedContent.key);\n break;\n\n default:\n throw new Error('Unsupported symmetric cipher, OID ' +\n msg.encryptedContent.algorithm);\n }\n ciph.start(msg.encryptedContent.parameter);\n ciph.update(msg.encryptedContent.content);\n\n if(!ciph.finish()) {\n throw new Error('Symmetric decryption failed.');\n }\n\n msg.content = ciph.output;\n }\n}\n","/**\n * Javascript implementation of ASN.1 validators for PKCS#7 v1.5.\n *\n * @author Dave Longley\n * @author Stefan Siegl\n *\n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl \n *\n * The ASN.1 representation of PKCS#7 is as follows\n * (see RFC #2315 for details, http://www.ietf.org/rfc/rfc2315.txt):\n *\n * A PKCS#7 message consists of a ContentInfo on root level, which may\n * contain any number of further ContentInfo nested into it.\n *\n * ContentInfo ::= SEQUENCE {\n * contentType ContentType,\n * content [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL\n * }\n *\n * ContentType ::= OBJECT IDENTIFIER\n *\n * EnvelopedData ::= SEQUENCE {\n * version Version,\n * recipientInfos RecipientInfos,\n * encryptedContentInfo EncryptedContentInfo\n * }\n *\n * EncryptedData ::= SEQUENCE {\n * version Version,\n * encryptedContentInfo EncryptedContentInfo\n * }\n *\n * id-signedData OBJECT IDENTIFIER ::= { iso(1) member-body(2)\n * us(840) rsadsi(113549) pkcs(1) pkcs7(7) 2 }\n *\n * SignedData ::= SEQUENCE {\n * version INTEGER,\n * digestAlgorithms DigestAlgorithmIdentifiers,\n * contentInfo ContentInfo,\n * certificates [0] IMPLICIT Certificates OPTIONAL,\n * crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,\n * signerInfos SignerInfos\n * }\n *\n * SignerInfos ::= SET OF SignerInfo\n *\n * SignerInfo ::= SEQUENCE {\n * version Version,\n * issuerAndSerialNumber IssuerAndSerialNumber,\n * digestAlgorithm DigestAlgorithmIdentifier,\n * authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,\n * digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,\n * encryptedDigest EncryptedDigest,\n * unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL\n * }\n *\n * EncryptedDigest ::= OCTET STRING\n *\n * Attributes ::= SET OF Attribute\n *\n * Attribute ::= SEQUENCE {\n * attrType OBJECT IDENTIFIER,\n * attrValues SET OF AttributeValue\n * }\n *\n * AttributeValue ::= ANY\n *\n * Version ::= INTEGER\n *\n * RecipientInfos ::= SET OF RecipientInfo\n *\n * EncryptedContentInfo ::= SEQUENCE {\n * contentType ContentType,\n * contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,\n * encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL\n * }\n *\n * ContentEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of AES and DES3, there is only one,\n * the IV.\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * EncryptedContent ::= OCTET STRING\n *\n * RecipientInfo ::= SEQUENCE {\n * version Version,\n * issuerAndSerialNumber IssuerAndSerialNumber,\n * keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,\n * encryptedKey EncryptedKey\n * }\n *\n * IssuerAndSerialNumber ::= SEQUENCE {\n * issuer Name,\n * serialNumber CertificateSerialNumber\n * }\n *\n * CertificateSerialNumber ::= INTEGER\n *\n * KeyEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * EncryptedKey ::= OCTET STRING\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./util');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7v = module.exports = forge.pkcs7asn1 = forge.pkcs7asn1 || {};\nforge.pkcs7 = forge.pkcs7 || {};\nforge.pkcs7.asn1 = p7v;\n\nvar contentInfoValidator = {\n name: 'ContentInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'ContentInfo.ContentType',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'contentType'\n }, {\n name: 'ContentInfo.content',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n captureAsn1: 'content'\n }]\n};\np7v.contentInfoValidator = contentInfoValidator;\n\nvar encryptedContentInfoValidator = {\n name: 'EncryptedContentInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedContentInfo.contentType',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'contentType'\n }, {\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encAlgorithm'\n }, {\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n captureAsn1: 'encParameter'\n }]\n }, {\n name: 'EncryptedContentInfo.encryptedContent',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n /* The PKCS#7 structure output by OpenSSL somewhat differs from what\n * other implementations do generate.\n *\n * OpenSSL generates a structure like this:\n * SEQUENCE {\n * ...\n * [0]\n * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n * ...\n * }\n *\n * Whereas other implementations (and this PKCS#7 module) generate:\n * SEQUENCE {\n * ...\n * [0] {\n * OCTET STRING\n * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n * ...\n * }\n * }\n *\n * In order to support both, we just capture the context specific\n * field here. The OCTET STRING bit is removed below.\n */\n capture: 'encryptedContent',\n captureAsn1: 'encryptedContentAsn1'\n }]\n};\n\np7v.envelopedDataValidator = {\n name: 'EnvelopedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EnvelopedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'EnvelopedData.RecipientInfos',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n captureAsn1: 'recipientInfos'\n }].concat(encryptedContentInfoValidator)\n};\n\np7v.encryptedDataValidator = {\n name: 'EncryptedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }].concat(encryptedContentInfoValidator)\n};\n\nvar signerValidator = {\n name: 'SignerInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false\n }, {\n name: 'SignerInfo.issuerAndSerialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.issuerAndSerialNumber.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'issuer'\n }, {\n name: 'SignerInfo.issuerAndSerialNumber.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'serial'\n }]\n }, {\n name: 'SignerInfo.digestAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.digestAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'digestAlgorithm'\n }, {\n name: 'SignerInfo.digestAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n constructed: false,\n captureAsn1: 'digestParameter',\n optional: true\n }]\n }, {\n name: 'SignerInfo.authenticatedAttributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n capture: 'authenticatedAttributes'\n }, {\n name: 'SignerInfo.digestEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n capture: 'signatureAlgorithm'\n }, {\n name: 'SignerInfo.encryptedDigest',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'signature'\n }, {\n name: 'SignerInfo.unauthenticatedAttributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n optional: true,\n capture: 'unauthenticatedAttributes'\n }]\n};\n\np7v.signedDataValidator = {\n name: 'SignedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'SignedData.DigestAlgorithms',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n captureAsn1: 'digestAlgorithms'\n },\n contentInfoValidator,\n {\n name: 'SignedData.Certificates',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n optional: true,\n captureAsn1: 'certificates'\n }, {\n name: 'SignedData.CertificateRevocationLists',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n optional: true,\n captureAsn1: 'crls'\n }, {\n name: 'SignedData.SignerInfos',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n capture: 'signerInfos',\n optional: true,\n value: [signerValidator]\n }]\n};\n\np7v.recipientInfoValidator = {\n name: 'RecipientInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'RecipientInfo.issuerAndSerial',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.issuerAndSerial.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'issuer'\n }, {\n name: 'RecipientInfo.issuerAndSerial.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'serial'\n }]\n }, {\n name: 'RecipientInfo.keyEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.keyEncryptionAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encAlgorithm'\n }, {\n name: 'RecipientInfo.keyEncryptionAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n constructed: false,\n captureAsn1: 'encParameter'\n }]\n }, {\n name: 'RecipientInfo.encryptedKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encKey'\n }]\n};\n","/**\n * Javascript implementation of X.509 and related components (such as\n * Certification Signing Requests) of a Public Key Infrastructure.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n *\n * The ASN.1 representation of an X.509v3 certificate is as follows\n * (see RFC 2459):\n *\n * Certificate ::= SEQUENCE {\n * tbsCertificate TBSCertificate,\n * signatureAlgorithm AlgorithmIdentifier,\n * signatureValue BIT STRING\n * }\n *\n * TBSCertificate ::= SEQUENCE {\n * version [0] EXPLICIT Version DEFAULT v1,\n * serialNumber CertificateSerialNumber,\n * signature AlgorithmIdentifier,\n * issuer Name,\n * validity Validity,\n * subject Name,\n * subjectPublicKeyInfo SubjectPublicKeyInfo,\n * issuerUniqueID [1] IMPLICIT UniqueIdentifier OPTIONAL,\n * -- If present, version shall be v2 or v3\n * subjectUniqueID [2] IMPLICIT UniqueIdentifier OPTIONAL,\n * -- If present, version shall be v2 or v3\n * extensions [3] EXPLICIT Extensions OPTIONAL\n * -- If present, version shall be v3\n * }\n *\n * Version ::= INTEGER { v1(0), v2(1), v3(2) }\n *\n * CertificateSerialNumber ::= INTEGER\n *\n * Name ::= CHOICE {\n * // only one possible choice for now\n * RDNSequence\n * }\n *\n * RDNSequence ::= SEQUENCE OF RelativeDistinguishedName\n *\n * RelativeDistinguishedName ::= SET OF AttributeTypeAndValue\n *\n * AttributeTypeAndValue ::= SEQUENCE {\n * type AttributeType,\n * value AttributeValue\n * }\n * AttributeType ::= OBJECT IDENTIFIER\n * AttributeValue ::= ANY DEFINED BY AttributeType\n *\n * Validity ::= SEQUENCE {\n * notBefore Time,\n * notAfter Time\n * }\n *\n * Time ::= CHOICE {\n * utcTime UTCTime,\n * generalTime GeneralizedTime\n * }\n *\n * UniqueIdentifier ::= BIT STRING\n *\n * SubjectPublicKeyInfo ::= SEQUENCE {\n * algorithm AlgorithmIdentifier,\n * subjectPublicKey BIT STRING\n * }\n *\n * Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension\n *\n * Extension ::= SEQUENCE {\n * extnID OBJECT IDENTIFIER,\n * critical BOOLEAN DEFAULT FALSE,\n * extnValue OCTET STRING\n * }\n *\n * The only key algorithm currently supported for PKI is RSA.\n *\n * RSASSA-PSS signatures are described in RFC 3447 and RFC 4055.\n *\n * PKCS#10 v1.7 describes certificate signing requests:\n *\n * CertificationRequestInfo:\n *\n * CertificationRequestInfo ::= SEQUENCE {\n * version INTEGER { v1(0) } (v1,...),\n * subject Name,\n * subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},\n * attributes [0] Attributes{{ CRIAttributes }}\n * }\n *\n * Attributes { ATTRIBUTE:IOSet } ::= SET OF Attribute{{ IOSet }}\n *\n * CRIAttributes ATTRIBUTE ::= {\n * ... -- add any locally defined attributes here -- }\n *\n * Attribute { ATTRIBUTE:IOSet } ::= SEQUENCE {\n * type ATTRIBUTE.&id({IOSet}),\n * values SET SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{@type})\n * }\n *\n * CertificationRequest ::= SEQUENCE {\n * certificationRequestInfo CertificationRequestInfo,\n * signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},\n * signature BIT STRING\n * }\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./md');\nrequire('./mgf');\nrequire('./oids');\nrequire('./pem');\nrequire('./pss');\nrequire('./rsa');\nrequire('./util');\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n/* Public Key Infrastructure (PKI) implementation. */\nvar pki = module.exports = forge.pki = forge.pki || {};\nvar oids = pki.oids;\n\n// short name OID mappings\nvar _shortNames = {};\n_shortNames['CN'] = oids['commonName'];\n_shortNames['commonName'] = 'CN';\n_shortNames['C'] = oids['countryName'];\n_shortNames['countryName'] = 'C';\n_shortNames['L'] = oids['localityName'];\n_shortNames['localityName'] = 'L';\n_shortNames['ST'] = oids['stateOrProvinceName'];\n_shortNames['stateOrProvinceName'] = 'ST';\n_shortNames['O'] = oids['organizationName'];\n_shortNames['organizationName'] = 'O';\n_shortNames['OU'] = oids['organizationalUnitName'];\n_shortNames['organizationalUnitName'] = 'OU';\n_shortNames['E'] = oids['emailAddress'];\n_shortNames['emailAddress'] = 'E';\n\n// validator for an SubjectPublicKeyInfo structure\n// Note: Currently only works with an RSA public key\nvar publicKeyValidator = forge.pki.rsa.publicKeyValidator;\n\n// validator for an X.509v3 certificate\nvar x509CertificateValidator = {\n name: 'Certificate',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'Certificate.TBSCertificate',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'tbsCertificate',\n value: [{\n name: 'Certificate.TBSCertificate.version',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n value: [{\n name: 'Certificate.TBSCertificate.version.integer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'certVersion'\n }]\n }, {\n name: 'Certificate.TBSCertificate.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'certSerialNumber'\n }, {\n name: 'Certificate.TBSCertificate.signature',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'Certificate.TBSCertificate.signature.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'certinfoSignatureOid'\n }, {\n name: 'Certificate.TBSCertificate.signature.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: 'certinfoSignatureParams'\n }]\n }, {\n name: 'Certificate.TBSCertificate.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certIssuer'\n }, {\n name: 'Certificate.TBSCertificate.validity',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n // Note: UTC and generalized times may both appear so the capture\n // names are based on their detected order, the names used below\n // are only for the common case, which validity time really means\n // \"notBefore\" and which means \"notAfter\" will be determined by order\n value: [{\n // notBefore (Time) (UTC time case)\n name: 'Certificate.TBSCertificate.validity.notBefore (utc)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.UTCTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity1UTCTime'\n }, {\n // notBefore (Time) (generalized time case)\n name: 'Certificate.TBSCertificate.validity.notBefore (generalized)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.GENERALIZEDTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity2GeneralizedTime'\n }, {\n // notAfter (Time) (only UTC time is supported)\n name: 'Certificate.TBSCertificate.validity.notAfter (utc)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.UTCTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity3UTCTime'\n }, {\n // notAfter (Time) (only UTC time is supported)\n name: 'Certificate.TBSCertificate.validity.notAfter (generalized)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.GENERALIZEDTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity4GeneralizedTime'\n }]\n }, {\n // Name (subject) (RDNSequence)\n name: 'Certificate.TBSCertificate.subject',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certSubject'\n },\n // SubjectPublicKeyInfo\n publicKeyValidator,\n {\n // issuerUniqueID (optional)\n name: 'Certificate.TBSCertificate.issuerUniqueID',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n optional: true,\n value: [{\n name: 'Certificate.TBSCertificate.issuerUniqueID.id',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n // TODO: support arbitrary bit length ids\n captureBitStringValue: 'certIssuerUniqueId'\n }]\n }, {\n // subjectUniqueID (optional)\n name: 'Certificate.TBSCertificate.subjectUniqueID',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 2,\n constructed: true,\n optional: true,\n value: [{\n name: 'Certificate.TBSCertificate.subjectUniqueID.id',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n // TODO: support arbitrary bit length ids\n captureBitStringValue: 'certSubjectUniqueId'\n }]\n }, {\n // Extensions (optional)\n name: 'Certificate.TBSCertificate.extensions',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 3,\n constructed: true,\n captureAsn1: 'certExtensions',\n optional: true\n }]\n }, {\n // AlgorithmIdentifier (signature algorithm)\n name: 'Certificate.signatureAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // algorithm\n name: 'Certificate.signatureAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'certSignatureOid'\n }, {\n name: 'Certificate.TBSCertificate.signature.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: 'certSignatureParams'\n }]\n }, {\n // SignatureValue\n name: 'Certificate.signatureValue',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n captureBitStringValue: 'certSignature'\n }]\n};\n\nvar rsassaPssParameterValidator = {\n name: 'rsapss',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'rsapss.hashAlgorithm',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n value: [{\n name: 'rsapss.hashAlgorithm.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.SEQUENCE,\n constructed: true,\n optional: true,\n value: [{\n name: 'rsapss.hashAlgorithm.AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'hashOid'\n /* parameter block omitted, for SHA1 NULL anyhow. */\n }]\n }]\n }, {\n name: 'rsapss.maskGenAlgorithm',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n value: [{\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.SEQUENCE,\n constructed: true,\n optional: true,\n value: [{\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'maskGenOid'\n }, {\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier.params',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier.params.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'maskGenHashOid'\n /* parameter block omitted, for SHA1 NULL anyhow. */\n }]\n }]\n }]\n }, {\n name: 'rsapss.saltLength',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 2,\n optional: true,\n value: [{\n name: 'rsapss.saltLength.saltLength',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.INTEGER,\n constructed: false,\n capture: 'saltLength'\n }]\n }, {\n name: 'rsapss.trailerField',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 3,\n optional: true,\n value: [{\n name: 'rsapss.trailer.trailer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.INTEGER,\n constructed: false,\n capture: 'trailer'\n }]\n }]\n};\n\n// validator for a CertificationRequestInfo structure\nvar certificationRequestInfoValidator = {\n name: 'CertificationRequestInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certificationRequestInfo',\n value: [{\n name: 'CertificationRequestInfo.integer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'certificationRequestInfoVersion'\n }, {\n // Name (subject) (RDNSequence)\n name: 'CertificationRequestInfo.subject',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certificationRequestInfoSubject'\n },\n // SubjectPublicKeyInfo\n publicKeyValidator,\n {\n name: 'CertificationRequestInfo.attributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n capture: 'certificationRequestInfoAttributes',\n value: [{\n name: 'CertificationRequestInfo.attributes',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'CertificationRequestInfo.attributes.type',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false\n }, {\n name: 'CertificationRequestInfo.attributes.value',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true\n }]\n }]\n }]\n};\n\n// validator for a CertificationRequest structure\nvar certificationRequestValidator = {\n name: 'CertificationRequest',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'csr',\n value: [\n certificationRequestInfoValidator, {\n // AlgorithmIdentifier (signature algorithm)\n name: 'CertificationRequest.signatureAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // algorithm\n name: 'CertificationRequest.signatureAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'csrSignatureOid'\n }, {\n name: 'CertificationRequest.signatureAlgorithm.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: 'csrSignatureParams'\n }]\n }, {\n // signature\n name: 'CertificationRequest.signature',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n captureBitStringValue: 'csrSignature'\n }\n ]\n};\n\n/**\n * Converts an RDNSequence of ASN.1 DER-encoded RelativeDistinguishedName\n * sets into an array with objects that have type and value properties.\n *\n * @param rdn the RDNSequence to convert.\n * @param md a message digest to append type and value to if provided.\n */\npki.RDNAttributesAsArray = function(rdn, md) {\n var rval = [];\n\n // each value in 'rdn' in is a SET of RelativeDistinguishedName\n var set, attr, obj;\n for(var si = 0; si < rdn.value.length; ++si) {\n // get the RelativeDistinguishedName set\n set = rdn.value[si];\n\n // each value in the SET is an AttributeTypeAndValue sequence\n // containing first a type (an OID) and second a value (defined by\n // the OID)\n for(var i = 0; i < set.value.length; ++i) {\n obj = {};\n attr = set.value[i];\n obj.type = asn1.derToOid(attr.value[0].value);\n obj.value = attr.value[1].value;\n obj.valueTagClass = attr.value[1].type;\n // if the OID is known, get its name and short name\n if(obj.type in oids) {\n obj.name = oids[obj.type];\n if(obj.name in _shortNames) {\n obj.shortName = _shortNames[obj.name];\n }\n }\n if(md) {\n md.update(obj.type);\n md.update(obj.value);\n }\n rval.push(obj);\n }\n }\n\n return rval;\n};\n\n/**\n * Converts ASN.1 CRIAttributes into an array with objects that have type and\n * value properties.\n *\n * @param attributes the CRIAttributes to convert.\n */\npki.CRIAttributesAsArray = function(attributes) {\n var rval = [];\n\n // each value in 'attributes' in is a SEQUENCE with an OID and a SET\n for(var si = 0; si < attributes.length; ++si) {\n // get the attribute sequence\n var seq = attributes[si];\n\n // each value in the SEQUENCE containing first a type (an OID) and\n // second a set of values (defined by the OID)\n var type = asn1.derToOid(seq.value[0].value);\n var values = seq.value[1].value;\n for(var vi = 0; vi < values.length; ++vi) {\n var obj = {};\n obj.type = type;\n obj.value = values[vi].value;\n obj.valueTagClass = values[vi].type;\n // if the OID is known, get its name and short name\n if(obj.type in oids) {\n obj.name = oids[obj.type];\n if(obj.name in _shortNames) {\n obj.shortName = _shortNames[obj.name];\n }\n }\n // parse extensions\n if(obj.type === oids.extensionRequest) {\n obj.extensions = [];\n for(var ei = 0; ei < obj.value.length; ++ei) {\n obj.extensions.push(pki.certificateExtensionFromAsn1(obj.value[ei]));\n }\n }\n rval.push(obj);\n }\n }\n\n return rval;\n};\n\n/**\n * Gets an issuer or subject attribute from its name, type, or short name.\n *\n * @param obj the issuer or subject object.\n * @param options a short name string or an object with:\n * shortName the short name for the attribute.\n * name the name for the attribute.\n * type the type for the attribute.\n *\n * @return the attribute.\n */\nfunction _getAttribute(obj, options) {\n if(typeof options === 'string') {\n options = {shortName: options};\n }\n\n var rval = null;\n var attr;\n for(var i = 0; rval === null && i < obj.attributes.length; ++i) {\n attr = obj.attributes[i];\n if(options.type && options.type === attr.type) {\n rval = attr;\n } else if(options.name && options.name === attr.name) {\n rval = attr;\n } else if(options.shortName && options.shortName === attr.shortName) {\n rval = attr;\n }\n }\n return rval;\n}\n\n/**\n * Converts signature parameters from ASN.1 structure.\n *\n * Currently only RSASSA-PSS supported. The PKCS#1 v1.5 signature scheme had\n * no parameters.\n *\n * RSASSA-PSS-params ::= SEQUENCE {\n * hashAlgorithm [0] HashAlgorithm DEFAULT\n * sha1Identifier,\n * maskGenAlgorithm [1] MaskGenAlgorithm DEFAULT\n * mgf1SHA1Identifier,\n * saltLength [2] INTEGER DEFAULT 20,\n * trailerField [3] INTEGER DEFAULT 1\n * }\n *\n * HashAlgorithm ::= AlgorithmIdentifier\n *\n * MaskGenAlgorithm ::= AlgorithmIdentifier\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * @param oid The OID specifying the signature algorithm\n * @param obj The ASN.1 structure holding the parameters\n * @param fillDefaults Whether to use return default values where omitted\n * @return signature parameter object\n */\nvar _readSignatureParameters = function(oid, obj, fillDefaults) {\n var params = {};\n\n if(oid !== oids['RSASSA-PSS']) {\n return params;\n }\n\n if(fillDefaults) {\n params = {\n hash: {\n algorithmOid: oids['sha1']\n },\n mgf: {\n algorithmOid: oids['mgf1'],\n hash: {\n algorithmOid: oids['sha1']\n }\n },\n saltLength: 20\n };\n }\n\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, rsassaPssParameterValidator, capture, errors)) {\n var error = new Error('Cannot read RSASSA-PSS parameter block.');\n error.errors = errors;\n throw error;\n }\n\n if(capture.hashOid !== undefined) {\n params.hash = params.hash || {};\n params.hash.algorithmOid = asn1.derToOid(capture.hashOid);\n }\n\n if(capture.maskGenOid !== undefined) {\n params.mgf = params.mgf || {};\n params.mgf.algorithmOid = asn1.derToOid(capture.maskGenOid);\n params.mgf.hash = params.mgf.hash || {};\n params.mgf.hash.algorithmOid = asn1.derToOid(capture.maskGenHashOid);\n }\n\n if(capture.saltLength !== undefined) {\n params.saltLength = capture.saltLength.charCodeAt(0);\n }\n\n return params;\n};\n\n/**\n * Converts an X.509 certificate from PEM format.\n *\n * Note: If the certificate is to be verified then compute hash should\n * be set to true. This will scan the TBSCertificate part of the ASN.1\n * object while it is converted so it doesn't need to be converted back\n * to ASN.1-DER-encoding later.\n *\n * @param pem the PEM-formatted certificate.\n * @param computeHash true to compute the hash for verification.\n * @param strict true to be strict when checking ASN.1 value lengths, false to\n * allow truncated values (default: true).\n *\n * @return the certificate.\n */\npki.certificateFromPem = function(pem, computeHash, strict) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'CERTIFICATE' &&\n msg.type !== 'X509 CERTIFICATE' &&\n msg.type !== 'TRUSTED CERTIFICATE') {\n var error = new Error(\n 'Could not convert certificate from PEM; PEM header type ' +\n 'is not \"CERTIFICATE\", \"X509 CERTIFICATE\", or \"TRUSTED CERTIFICATE\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error(\n 'Could not convert certificate from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body, strict);\n\n return pki.certificateFromAsn1(obj, computeHash);\n};\n\n/**\n * Converts an X.509 certificate to PEM format.\n *\n * @param cert the certificate.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted certificate.\n */\npki.certificateToPem = function(cert, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'CERTIFICATE',\n body: asn1.toDer(pki.certificateToAsn1(cert)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts an RSA public key from PEM format.\n *\n * @param pem the PEM-formatted public key.\n *\n * @return the public key.\n */\npki.publicKeyFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'PUBLIC KEY' && msg.type !== 'RSA PUBLIC KEY') {\n var error = new Error('Could not convert public key from PEM; PEM header ' +\n 'type is not \"PUBLIC KEY\" or \"RSA PUBLIC KEY\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert public key from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body);\n\n return pki.publicKeyFromAsn1(obj);\n};\n\n/**\n * Converts an RSA public key to PEM format (using a SubjectPublicKeyInfo).\n *\n * @param key the public key.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted public key.\n */\npki.publicKeyToPem = function(key, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'PUBLIC KEY',\n body: asn1.toDer(pki.publicKeyToAsn1(key)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts an RSA public key to PEM format (using an RSAPublicKey).\n *\n * @param key the public key.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted public key.\n */\npki.publicKeyToRSAPublicKeyPem = function(key, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'RSA PUBLIC KEY',\n body: asn1.toDer(pki.publicKeyToRSAPublicKey(key)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Gets a fingerprint for the given public key.\n *\n * @param options the options to use.\n * [md] the message digest object to use (defaults to forge.md.sha1).\n * [type] the type of fingerprint, such as 'RSAPublicKey',\n * 'SubjectPublicKeyInfo' (defaults to 'RSAPublicKey').\n * [encoding] an alternative output encoding, such as 'hex'\n * (defaults to none, outputs a byte buffer).\n * [delimiter] the delimiter to use between bytes for 'hex' encoded\n * output, eg: ':' (defaults to none).\n *\n * @return the fingerprint as a byte buffer or other encoding based on options.\n */\npki.getPublicKeyFingerprint = function(key, options) {\n options = options || {};\n var md = options.md || forge.md.sha1.create();\n var type = options.type || 'RSAPublicKey';\n\n var bytes;\n switch(type) {\n case 'RSAPublicKey':\n bytes = asn1.toDer(pki.publicKeyToRSAPublicKey(key)).getBytes();\n break;\n case 'SubjectPublicKeyInfo':\n bytes = asn1.toDer(pki.publicKeyToAsn1(key)).getBytes();\n break;\n default:\n throw new Error('Unknown fingerprint type \"' + options.type + '\".');\n }\n\n // hash public key bytes\n md.start();\n md.update(bytes);\n var digest = md.digest();\n if(options.encoding === 'hex') {\n var hex = digest.toHex();\n if(options.delimiter) {\n return hex.match(/.{2}/g).join(options.delimiter);\n }\n return hex;\n } else if(options.encoding === 'binary') {\n return digest.getBytes();\n } else if(options.encoding) {\n throw new Error('Unknown encoding \"' + options.encoding + '\".');\n }\n return digest;\n};\n\n/**\n * Converts a PKCS#10 certification request (CSR) from PEM format.\n *\n * Note: If the certification request is to be verified then compute hash\n * should be set to true. This will scan the CertificationRequestInfo part of\n * the ASN.1 object while it is converted so it doesn't need to be converted\n * back to ASN.1-DER-encoding later.\n *\n * @param pem the PEM-formatted certificate.\n * @param computeHash true to compute the hash for verification.\n * @param strict true to be strict when checking ASN.1 value lengths, false to\n * allow truncated values (default: true).\n *\n * @return the certification request (CSR).\n */\npki.certificationRequestFromPem = function(pem, computeHash, strict) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'CERTIFICATE REQUEST') {\n var error = new Error('Could not convert certification request from PEM; ' +\n 'PEM header type is not \"CERTIFICATE REQUEST\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert certification request from PEM; ' +\n 'PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body, strict);\n\n return pki.certificationRequestFromAsn1(obj, computeHash);\n};\n\n/**\n * Converts a PKCS#10 certification request (CSR) to PEM format.\n *\n * @param csr the certification request.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted certification request.\n */\npki.certificationRequestToPem = function(csr, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'CERTIFICATE REQUEST',\n body: asn1.toDer(pki.certificationRequestToAsn1(csr)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Creates an empty X.509v3 RSA certificate.\n *\n * @return the certificate.\n */\npki.createCertificate = function() {\n var cert = {};\n cert.version = 0x02;\n cert.serialNumber = '00';\n cert.signatureOid = null;\n cert.signature = null;\n cert.siginfo = {};\n cert.siginfo.algorithmOid = null;\n cert.validity = {};\n cert.validity.notBefore = new Date();\n cert.validity.notAfter = new Date();\n\n cert.issuer = {};\n cert.issuer.getField = function(sn) {\n return _getAttribute(cert.issuer, sn);\n };\n cert.issuer.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.issuer.attributes.push(attr);\n };\n cert.issuer.attributes = [];\n cert.issuer.hash = null;\n\n cert.subject = {};\n cert.subject.getField = function(sn) {\n return _getAttribute(cert.subject, sn);\n };\n cert.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.subject.attributes.push(attr);\n };\n cert.subject.attributes = [];\n cert.subject.hash = null;\n\n cert.extensions = [];\n cert.publicKey = null;\n cert.md = null;\n\n /**\n * Sets the subject of this certificate.\n *\n * @param attrs the array of subject attributes to use.\n * @param uniqueId an optional a unique ID to use.\n */\n cert.setSubject = function(attrs, uniqueId) {\n // set new attributes, clear hash\n _fillMissingFields(attrs);\n cert.subject.attributes = attrs;\n delete cert.subject.uniqueId;\n if(uniqueId) {\n // TODO: support arbitrary bit length ids\n cert.subject.uniqueId = uniqueId;\n }\n cert.subject.hash = null;\n };\n\n /**\n * Sets the issuer of this certificate.\n *\n * @param attrs the array of issuer attributes to use.\n * @param uniqueId an optional a unique ID to use.\n */\n cert.setIssuer = function(attrs, uniqueId) {\n // set new attributes, clear hash\n _fillMissingFields(attrs);\n cert.issuer.attributes = attrs;\n delete cert.issuer.uniqueId;\n if(uniqueId) {\n // TODO: support arbitrary bit length ids\n cert.issuer.uniqueId = uniqueId;\n }\n cert.issuer.hash = null;\n };\n\n /**\n * Sets the extensions of this certificate.\n *\n * @param exts the array of extensions to use.\n */\n cert.setExtensions = function(exts) {\n for(var i = 0; i < exts.length; ++i) {\n _fillMissingExtensionFields(exts[i], {cert: cert});\n }\n // set new extensions\n cert.extensions = exts;\n };\n\n /**\n * Gets an extension by its name or id.\n *\n * @param options the name to use or an object with:\n * name the name to use.\n * id the id to use.\n *\n * @return the extension or null if not found.\n */\n cert.getExtension = function(options) {\n if(typeof options === 'string') {\n options = {name: options};\n }\n\n var rval = null;\n var ext;\n for(var i = 0; rval === null && i < cert.extensions.length; ++i) {\n ext = cert.extensions[i];\n if(options.id && ext.id === options.id) {\n rval = ext;\n } else if(options.name && ext.name === options.name) {\n rval = ext;\n }\n }\n return rval;\n };\n\n /**\n * Signs this certificate using the given private key.\n *\n * @param key the private key to sign with.\n * @param md the message digest object to use (defaults to forge.md.sha1).\n */\n cert.sign = function(key, md) {\n // TODO: get signature OID from private key\n cert.md = md || forge.md.sha1.create();\n var algorithmOid = oids[cert.md.algorithm + 'WithRSAEncryption'];\n if(!algorithmOid) {\n var error = new Error('Could not compute certificate digest. ' +\n 'Unknown message digest algorithm OID.');\n error.algorithm = cert.md.algorithm;\n throw error;\n }\n cert.signatureOid = cert.siginfo.algorithmOid = algorithmOid;\n\n // get TBSCertificate, convert to DER\n cert.tbsCertificate = pki.getTBSCertificate(cert);\n var bytes = asn1.toDer(cert.tbsCertificate);\n\n // digest and sign\n cert.md.update(bytes.getBytes());\n cert.signature = key.sign(cert.md);\n };\n\n /**\n * Attempts verify the signature on the passed certificate using this\n * certificate's public key.\n *\n * @param child the certificate to verify.\n *\n * @return true if verified, false if not.\n */\n cert.verify = function(child) {\n var rval = false;\n\n if(!cert.issued(child)) {\n var issuer = child.issuer;\n var subject = cert.subject;\n var error = new Error(\n 'The parent certificate did not issue the given child ' +\n 'certificate; the child certificate\\'s issuer does not match the ' +\n 'parent\\'s subject.');\n error.expectedIssuer = issuer.attributes;\n error.actualIssuer = subject.attributes;\n throw error;\n }\n\n var md = child.md;\n if(md === null) {\n // check signature OID for supported signature types\n if(child.signatureOid in oids) {\n var oid = oids[child.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n md = forge.md.sha256.create();\n break;\n }\n }\n if(md === null) {\n var error = new Error('Could not compute certificate digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = child.signatureOid;\n throw error;\n }\n\n // produce DER formatted TBSCertificate and digest it\n var tbsCertificate = child.tbsCertificate || pki.getTBSCertificate(child);\n var bytes = asn1.toDer(tbsCertificate);\n md.update(bytes.getBytes());\n }\n\n if(md !== null) {\n var scheme;\n\n switch(child.signatureOid) {\n case oids.sha1WithRSAEncryption:\n scheme = undefined; /* use PKCS#1 v1.5 padding scheme */\n break;\n case oids['RSASSA-PSS']:\n var hash, mgf;\n\n /* initialize mgf */\n hash = oids[child.signatureParameters.mgf.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported MGF hash function.');\n error.oid = child.signatureParameters.mgf.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n mgf = oids[child.signatureParameters.mgf.algorithmOid];\n if(mgf === undefined || forge.mgf[mgf] === undefined) {\n var error = new Error('Unsupported MGF function.');\n error.oid = child.signatureParameters.mgf.algorithmOid;\n error.name = mgf;\n throw error;\n }\n\n mgf = forge.mgf[mgf].create(forge.md[hash].create());\n\n /* initialize hash function */\n hash = oids[child.signatureParameters.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n throw {\n message: 'Unsupported RSASSA-PSS hash function.',\n oid: child.signatureParameters.hash.algorithmOid,\n name: hash\n };\n }\n\n scheme = forge.pss.create(forge.md[hash].create(), mgf,\n child.signatureParameters.saltLength);\n break;\n }\n\n // verify signature on cert using public key\n rval = cert.publicKey.verify(\n md.digest().getBytes(), child.signature, scheme);\n }\n\n return rval;\n };\n\n /**\n * Returns true if this certificate's issuer matches the passed\n * certificate's subject. Note that no signature check is performed.\n *\n * @param parent the certificate to check.\n *\n * @return true if this certificate's issuer matches the passed certificate's\n * subject.\n */\n cert.isIssuer = function(parent) {\n var rval = false;\n\n var i = cert.issuer;\n var s = parent.subject;\n\n // compare hashes if present\n if(i.hash && s.hash) {\n rval = (i.hash === s.hash);\n } else if(i.attributes.length === s.attributes.length) {\n // all attributes are the same so issuer matches subject\n rval = true;\n var iattr, sattr;\n for(var n = 0; rval && n < i.attributes.length; ++n) {\n iattr = i.attributes[n];\n sattr = s.attributes[n];\n if(iattr.type !== sattr.type || iattr.value !== sattr.value) {\n // attribute mismatch\n rval = false;\n }\n }\n }\n\n return rval;\n };\n\n /**\n * Returns true if this certificate's subject matches the issuer of the\n * given certificate). Note that not signature check is performed.\n *\n * @param child the certificate to check.\n *\n * @return true if this certificate's subject matches the passed\n * certificate's issuer.\n */\n cert.issued = function(child) {\n return child.isIssuer(cert);\n };\n\n /**\n * Generates the subjectKeyIdentifier for this certificate as byte buffer.\n *\n * @return the subjectKeyIdentifier for this certificate as byte buffer.\n */\n cert.generateSubjectKeyIdentifier = function() {\n /* See: 4.2.1.2 section of the the RFC3280, keyIdentifier is either:\n\n (1) The keyIdentifier is composed of the 160-bit SHA-1 hash of the\n value of the BIT STRING subjectPublicKey (excluding the tag,\n length, and number of unused bits).\n\n (2) The keyIdentifier is composed of a four bit type field with\n the value 0100 followed by the least significant 60 bits of the\n SHA-1 hash of the value of the BIT STRING subjectPublicKey\n (excluding the tag, length, and number of unused bit string bits).\n */\n\n // skipping the tag, length, and number of unused bits is the same\n // as just using the RSAPublicKey (for RSA keys, which are the\n // only ones supported)\n return pki.getPublicKeyFingerprint(cert.publicKey, {type: 'RSAPublicKey'});\n };\n\n /**\n * Verifies the subjectKeyIdentifier extension value for this certificate\n * against its public key. If no extension is found, false will be\n * returned.\n *\n * @return true if verified, false if not.\n */\n cert.verifySubjectKeyIdentifier = function() {\n var oid = oids['subjectKeyIdentifier'];\n for(var i = 0; i < cert.extensions.length; ++i) {\n var ext = cert.extensions[i];\n if(ext.id === oid) {\n var ski = cert.generateSubjectKeyIdentifier().getBytes();\n return (forge.util.hexToBytes(ext.subjectKeyIdentifier) === ski);\n }\n }\n return false;\n };\n\n return cert;\n};\n\n/**\n * Converts an X.509v3 RSA certificate from an ASN.1 object.\n *\n * Note: If the certificate is to be verified then compute hash should\n * be set to true. There is currently no implementation for converting\n * a certificate back to ASN.1 so the TBSCertificate part of the ASN.1\n * object needs to be scanned before the cert object is created.\n *\n * @param obj the asn1 representation of an X.509v3 RSA certificate.\n * @param computeHash true to compute the hash for verification.\n *\n * @return the certificate.\n */\npki.certificateFromAsn1 = function(obj, computeHash) {\n // validate certificate and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, x509CertificateValidator, capture, errors)) {\n var error = new Error('Cannot read X.509 certificate. ' +\n 'ASN.1 object is not an X509v3 Certificate.');\n error.errors = errors;\n throw error;\n }\n\n // get oid\n var oid = asn1.derToOid(capture.publicKeyOid);\n if(oid !== pki.oids.rsaEncryption) {\n throw new Error('Cannot read public key. OID is not RSA.');\n }\n\n // create certificate\n var cert = pki.createCertificate();\n cert.version = capture.certVersion ?\n capture.certVersion.charCodeAt(0) : 0;\n var serial = forge.util.createBuffer(capture.certSerialNumber);\n cert.serialNumber = serial.toHex();\n cert.signatureOid = forge.asn1.derToOid(capture.certSignatureOid);\n cert.signatureParameters = _readSignatureParameters(\n cert.signatureOid, capture.certSignatureParams, true);\n cert.siginfo.algorithmOid = forge.asn1.derToOid(capture.certinfoSignatureOid);\n cert.siginfo.parameters = _readSignatureParameters(cert.siginfo.algorithmOid,\n capture.certinfoSignatureParams, false);\n cert.signature = capture.certSignature;\n\n var validity = [];\n if(capture.certValidity1UTCTime !== undefined) {\n validity.push(asn1.utcTimeToDate(capture.certValidity1UTCTime));\n }\n if(capture.certValidity2GeneralizedTime !== undefined) {\n validity.push(asn1.generalizedTimeToDate(\n capture.certValidity2GeneralizedTime));\n }\n if(capture.certValidity3UTCTime !== undefined) {\n validity.push(asn1.utcTimeToDate(capture.certValidity3UTCTime));\n }\n if(capture.certValidity4GeneralizedTime !== undefined) {\n validity.push(asn1.generalizedTimeToDate(\n capture.certValidity4GeneralizedTime));\n }\n if(validity.length > 2) {\n throw new Error('Cannot read notBefore/notAfter validity times; more ' +\n 'than two times were provided in the certificate.');\n }\n if(validity.length < 2) {\n throw new Error('Cannot read notBefore/notAfter validity times; they ' +\n 'were not provided as either UTCTime or GeneralizedTime.');\n }\n cert.validity.notBefore = validity[0];\n cert.validity.notAfter = validity[1];\n\n // keep TBSCertificate to preserve signature when exporting\n cert.tbsCertificate = capture.tbsCertificate;\n\n if(computeHash) {\n // check signature OID for supported signature types\n cert.md = null;\n if(cert.signatureOid in oids) {\n var oid = oids[cert.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n cert.md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n cert.md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n cert.md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n cert.md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n cert.md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n cert.md = forge.md.sha256.create();\n break;\n }\n }\n if(cert.md === null) {\n var error = new Error('Could not compute certificate digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = cert.signatureOid;\n throw error;\n }\n\n // produce DER formatted TBSCertificate and digest it\n var bytes = asn1.toDer(cert.tbsCertificate);\n cert.md.update(bytes.getBytes());\n }\n\n // handle issuer, build issuer message digest\n var imd = forge.md.sha1.create();\n cert.issuer.getField = function(sn) {\n return _getAttribute(cert.issuer, sn);\n };\n cert.issuer.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.issuer.attributes.push(attr);\n };\n cert.issuer.attributes = pki.RDNAttributesAsArray(capture.certIssuer, imd);\n if(capture.certIssuerUniqueId) {\n cert.issuer.uniqueId = capture.certIssuerUniqueId;\n }\n cert.issuer.hash = imd.digest().toHex();\n\n // handle subject, build subject message digest\n var smd = forge.md.sha1.create();\n cert.subject.getField = function(sn) {\n return _getAttribute(cert.subject, sn);\n };\n cert.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.subject.attributes.push(attr);\n };\n cert.subject.attributes = pki.RDNAttributesAsArray(capture.certSubject, smd);\n if(capture.certSubjectUniqueId) {\n cert.subject.uniqueId = capture.certSubjectUniqueId;\n }\n cert.subject.hash = smd.digest().toHex();\n\n // handle extensions\n if(capture.certExtensions) {\n cert.extensions = pki.certificateExtensionsFromAsn1(capture.certExtensions);\n } else {\n cert.extensions = [];\n }\n\n // convert RSA public key from ASN.1\n cert.publicKey = pki.publicKeyFromAsn1(capture.subjectPublicKeyInfo);\n\n return cert;\n};\n\n/**\n * Converts an ASN.1 extensions object (with extension sequences as its\n * values) into an array of extension objects with types and values.\n *\n * Supported extensions:\n *\n * id-ce-keyUsage OBJECT IDENTIFIER ::= { id-ce 15 }\n * KeyUsage ::= BIT STRING {\n * digitalSignature (0),\n * nonRepudiation (1),\n * keyEncipherment (2),\n * dataEncipherment (3),\n * keyAgreement (4),\n * keyCertSign (5),\n * cRLSign (6),\n * encipherOnly (7),\n * decipherOnly (8)\n * }\n *\n * id-ce-basicConstraints OBJECT IDENTIFIER ::= { id-ce 19 }\n * BasicConstraints ::= SEQUENCE {\n * cA BOOLEAN DEFAULT FALSE,\n * pathLenConstraint INTEGER (0..MAX) OPTIONAL\n * }\n *\n * subjectAltName EXTENSION ::= {\n * SYNTAX GeneralNames\n * IDENTIFIED BY id-ce-subjectAltName\n * }\n *\n * GeneralNames ::= SEQUENCE SIZE (1..MAX) OF GeneralName\n *\n * GeneralName ::= CHOICE {\n * otherName [0] INSTANCE OF OTHER-NAME,\n * rfc822Name [1] IA5String,\n * dNSName [2] IA5String,\n * x400Address [3] ORAddress,\n * directoryName [4] Name,\n * ediPartyName [5] EDIPartyName,\n * uniformResourceIdentifier [6] IA5String,\n * IPAddress [7] OCTET STRING,\n * registeredID [8] OBJECT IDENTIFIER\n * }\n *\n * OTHER-NAME ::= TYPE-IDENTIFIER\n *\n * EDIPartyName ::= SEQUENCE {\n * nameAssigner [0] DirectoryString {ub-name} OPTIONAL,\n * partyName [1] DirectoryString {ub-name}\n * }\n *\n * @param exts the extensions ASN.1 with extension sequences to parse.\n *\n * @return the array.\n */\npki.certificateExtensionsFromAsn1 = function(exts) {\n var rval = [];\n for(var i = 0; i < exts.value.length; ++i) {\n // get extension sequence\n var extseq = exts.value[i];\n for(var ei = 0; ei < extseq.value.length; ++ei) {\n rval.push(pki.certificateExtensionFromAsn1(extseq.value[ei]));\n }\n }\n\n return rval;\n};\n\n/**\n * Parses a single certificate extension from ASN.1.\n *\n * @param ext the extension in ASN.1 format.\n *\n * @return the parsed extension as an object.\n */\npki.certificateExtensionFromAsn1 = function(ext) {\n // an extension has:\n // [0] extnID OBJECT IDENTIFIER\n // [1] critical BOOLEAN DEFAULT FALSE\n // [2] extnValue OCTET STRING\n var e = {};\n e.id = asn1.derToOid(ext.value[0].value);\n e.critical = false;\n if(ext.value[1].type === asn1.Type.BOOLEAN) {\n e.critical = (ext.value[1].value.charCodeAt(0) !== 0x00);\n e.value = ext.value[2].value;\n } else {\n e.value = ext.value[1].value;\n }\n // if the oid is known, get its name\n if(e.id in oids) {\n e.name = oids[e.id];\n\n // handle key usage\n if(e.name === 'keyUsage') {\n // get value as BIT STRING\n var ev = asn1.fromDer(e.value);\n var b2 = 0x00;\n var b3 = 0x00;\n if(ev.value.length > 1) {\n // skip first byte, just indicates unused bits which\n // will be padded with 0s anyway\n // get bytes with flag bits\n b2 = ev.value.charCodeAt(1);\n b3 = ev.value.length > 2 ? ev.value.charCodeAt(2) : 0;\n }\n // set flags\n e.digitalSignature = (b2 & 0x80) === 0x80;\n e.nonRepudiation = (b2 & 0x40) === 0x40;\n e.keyEncipherment = (b2 & 0x20) === 0x20;\n e.dataEncipherment = (b2 & 0x10) === 0x10;\n e.keyAgreement = (b2 & 0x08) === 0x08;\n e.keyCertSign = (b2 & 0x04) === 0x04;\n e.cRLSign = (b2 & 0x02) === 0x02;\n e.encipherOnly = (b2 & 0x01) === 0x01;\n e.decipherOnly = (b3 & 0x80) === 0x80;\n } else if(e.name === 'basicConstraints') {\n // handle basic constraints\n // get value as SEQUENCE\n var ev = asn1.fromDer(e.value);\n // get cA BOOLEAN flag (defaults to false)\n if(ev.value.length > 0 && ev.value[0].type === asn1.Type.BOOLEAN) {\n e.cA = (ev.value[0].value.charCodeAt(0) !== 0x00);\n } else {\n e.cA = false;\n }\n // get path length constraint\n var value = null;\n if(ev.value.length > 0 && ev.value[0].type === asn1.Type.INTEGER) {\n value = ev.value[0].value;\n } else if(ev.value.length > 1) {\n value = ev.value[1].value;\n }\n if(value !== null) {\n e.pathLenConstraint = asn1.derToInteger(value);\n }\n } else if(e.name === 'extKeyUsage') {\n // handle extKeyUsage\n // value is a SEQUENCE of OIDs\n var ev = asn1.fromDer(e.value);\n for(var vi = 0; vi < ev.value.length; ++vi) {\n var oid = asn1.derToOid(ev.value[vi].value);\n if(oid in oids) {\n e[oids[oid]] = true;\n } else {\n e[oid] = true;\n }\n }\n } else if(e.name === 'nsCertType') {\n // handle nsCertType\n // get value as BIT STRING\n var ev = asn1.fromDer(e.value);\n var b2 = 0x00;\n if(ev.value.length > 1) {\n // skip first byte, just indicates unused bits which\n // will be padded with 0s anyway\n // get bytes with flag bits\n b2 = ev.value.charCodeAt(1);\n }\n // set flags\n e.client = (b2 & 0x80) === 0x80;\n e.server = (b2 & 0x40) === 0x40;\n e.email = (b2 & 0x20) === 0x20;\n e.objsign = (b2 & 0x10) === 0x10;\n e.reserved = (b2 & 0x08) === 0x08;\n e.sslCA = (b2 & 0x04) === 0x04;\n e.emailCA = (b2 & 0x02) === 0x02;\n e.objCA = (b2 & 0x01) === 0x01;\n } else if(\n e.name === 'subjectAltName' ||\n e.name === 'issuerAltName') {\n // handle subjectAltName/issuerAltName\n e.altNames = [];\n\n // ev is a SYNTAX SEQUENCE\n var gn;\n var ev = asn1.fromDer(e.value);\n for(var n = 0; n < ev.value.length; ++n) {\n // get GeneralName\n gn = ev.value[n];\n\n var altName = {\n type: gn.type,\n value: gn.value\n };\n e.altNames.push(altName);\n\n // Note: Support for types 1,2,6,7,8\n switch(gn.type) {\n // rfc822Name\n case 1:\n // dNSName\n case 2:\n // uniformResourceIdentifier (URI)\n case 6:\n break;\n // IPAddress\n case 7:\n // convert to IPv4/IPv6 string representation\n altName.ip = forge.util.bytesToIP(gn.value);\n break;\n // registeredID\n case 8:\n altName.oid = asn1.derToOid(gn.value);\n break;\n default:\n // unsupported\n }\n }\n } else if(e.name === 'subjectKeyIdentifier') {\n // value is an OCTETSTRING w/the hash of the key-type specific\n // public key structure (eg: RSAPublicKey)\n var ev = asn1.fromDer(e.value);\n e.subjectKeyIdentifier = forge.util.bytesToHex(ev.value);\n }\n }\n return e;\n};\n\n/**\n * Converts a PKCS#10 certification request (CSR) from an ASN.1 object.\n *\n * Note: If the certification request is to be verified then compute hash\n * should be set to true. There is currently no implementation for converting\n * a certificate back to ASN.1 so the CertificationRequestInfo part of the\n * ASN.1 object needs to be scanned before the csr object is created.\n *\n * @param obj the asn1 representation of a PKCS#10 certification request (CSR).\n * @param computeHash true to compute the hash for verification.\n *\n * @return the certification request (CSR).\n */\npki.certificationRequestFromAsn1 = function(obj, computeHash) {\n // validate certification request and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, certificationRequestValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#10 certificate request. ' +\n 'ASN.1 object is not a PKCS#10 CertificationRequest.');\n error.errors = errors;\n throw error;\n }\n\n // get oid\n var oid = asn1.derToOid(capture.publicKeyOid);\n if(oid !== pki.oids.rsaEncryption) {\n throw new Error('Cannot read public key. OID is not RSA.');\n }\n\n // create certification request\n var csr = pki.createCertificationRequest();\n csr.version = capture.csrVersion ? capture.csrVersion.charCodeAt(0) : 0;\n csr.signatureOid = forge.asn1.derToOid(capture.csrSignatureOid);\n csr.signatureParameters = _readSignatureParameters(\n csr.signatureOid, capture.csrSignatureParams, true);\n csr.siginfo.algorithmOid = forge.asn1.derToOid(capture.csrSignatureOid);\n csr.siginfo.parameters = _readSignatureParameters(\n csr.siginfo.algorithmOid, capture.csrSignatureParams, false);\n csr.signature = capture.csrSignature;\n\n // keep CertificationRequestInfo to preserve signature when exporting\n csr.certificationRequestInfo = capture.certificationRequestInfo;\n\n if(computeHash) {\n // check signature OID for supported signature types\n csr.md = null;\n if(csr.signatureOid in oids) {\n var oid = oids[csr.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n csr.md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n csr.md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n csr.md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n csr.md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n csr.md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n csr.md = forge.md.sha256.create();\n break;\n }\n }\n if(csr.md === null) {\n var error = new Error('Could not compute certification request digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = csr.signatureOid;\n throw error;\n }\n\n // produce DER formatted CertificationRequestInfo and digest it\n var bytes = asn1.toDer(csr.certificationRequestInfo);\n csr.md.update(bytes.getBytes());\n }\n\n // handle subject, build subject message digest\n var smd = forge.md.sha1.create();\n csr.subject.getField = function(sn) {\n return _getAttribute(csr.subject, sn);\n };\n csr.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n csr.subject.attributes.push(attr);\n };\n csr.subject.attributes = pki.RDNAttributesAsArray(\n capture.certificationRequestInfoSubject, smd);\n csr.subject.hash = smd.digest().toHex();\n\n // convert RSA public key from ASN.1\n csr.publicKey = pki.publicKeyFromAsn1(capture.subjectPublicKeyInfo);\n\n // convert attributes from ASN.1\n csr.getAttribute = function(sn) {\n return _getAttribute(csr, sn);\n };\n csr.addAttribute = function(attr) {\n _fillMissingFields([attr]);\n csr.attributes.push(attr);\n };\n csr.attributes = pki.CRIAttributesAsArray(\n capture.certificationRequestInfoAttributes || []);\n\n return csr;\n};\n\n/**\n * Creates an empty certification request (a CSR or certificate signing\n * request). Once created, its public key and attributes can be set and then\n * it can be signed.\n *\n * @return the empty certification request.\n */\npki.createCertificationRequest = function() {\n var csr = {};\n csr.version = 0x00;\n csr.signatureOid = null;\n csr.signature = null;\n csr.siginfo = {};\n csr.siginfo.algorithmOid = null;\n\n csr.subject = {};\n csr.subject.getField = function(sn) {\n return _getAttribute(csr.subject, sn);\n };\n csr.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n csr.subject.attributes.push(attr);\n };\n csr.subject.attributes = [];\n csr.subject.hash = null;\n\n csr.publicKey = null;\n csr.attributes = [];\n csr.getAttribute = function(sn) {\n return _getAttribute(csr, sn);\n };\n csr.addAttribute = function(attr) {\n _fillMissingFields([attr]);\n csr.attributes.push(attr);\n };\n csr.md = null;\n\n /**\n * Sets the subject of this certification request.\n *\n * @param attrs the array of subject attributes to use.\n */\n csr.setSubject = function(attrs) {\n // set new attributes\n _fillMissingFields(attrs);\n csr.subject.attributes = attrs;\n csr.subject.hash = null;\n };\n\n /**\n * Sets the attributes of this certification request.\n *\n * @param attrs the array of attributes to use.\n */\n csr.setAttributes = function(attrs) {\n // set new attributes\n _fillMissingFields(attrs);\n csr.attributes = attrs;\n };\n\n /**\n * Signs this certification request using the given private key.\n *\n * @param key the private key to sign with.\n * @param md the message digest object to use (defaults to forge.md.sha1).\n */\n csr.sign = function(key, md) {\n // TODO: get signature OID from private key\n csr.md = md || forge.md.sha1.create();\n var algorithmOid = oids[csr.md.algorithm + 'WithRSAEncryption'];\n if(!algorithmOid) {\n var error = new Error('Could not compute certification request digest. ' +\n 'Unknown message digest algorithm OID.');\n error.algorithm = csr.md.algorithm;\n throw error;\n }\n csr.signatureOid = csr.siginfo.algorithmOid = algorithmOid;\n\n // get CertificationRequestInfo, convert to DER\n csr.certificationRequestInfo = pki.getCertificationRequestInfo(csr);\n var bytes = asn1.toDer(csr.certificationRequestInfo);\n\n // digest and sign\n csr.md.update(bytes.getBytes());\n csr.signature = key.sign(csr.md);\n };\n\n /**\n * Attempts verify the signature on the passed certification request using\n * its public key.\n *\n * A CSR that has been exported to a file in PEM format can be verified using\n * OpenSSL using this command:\n *\n * openssl req -in -verify -noout -text\n *\n * @return true if verified, false if not.\n */\n csr.verify = function() {\n var rval = false;\n\n var md = csr.md;\n if(md === null) {\n // check signature OID for supported signature types\n if(csr.signatureOid in oids) {\n // TODO: create DRY `OID to md` function\n var oid = oids[csr.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n md = forge.md.sha256.create();\n break;\n }\n }\n if(md === null) {\n var error = new Error(\n 'Could not compute certification request digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = csr.signatureOid;\n throw error;\n }\n\n // produce DER formatted CertificationRequestInfo and digest it\n var cri = csr.certificationRequestInfo ||\n pki.getCertificationRequestInfo(csr);\n var bytes = asn1.toDer(cri);\n md.update(bytes.getBytes());\n }\n\n if(md !== null) {\n var scheme;\n\n switch(csr.signatureOid) {\n case oids.sha1WithRSAEncryption:\n /* use PKCS#1 v1.5 padding scheme */\n break;\n case oids['RSASSA-PSS']:\n var hash, mgf;\n\n /* initialize mgf */\n hash = oids[csr.signatureParameters.mgf.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported MGF hash function.');\n error.oid = csr.signatureParameters.mgf.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n mgf = oids[csr.signatureParameters.mgf.algorithmOid];\n if(mgf === undefined || forge.mgf[mgf] === undefined) {\n var error = new Error('Unsupported MGF function.');\n error.oid = csr.signatureParameters.mgf.algorithmOid;\n error.name = mgf;\n throw error;\n }\n\n mgf = forge.mgf[mgf].create(forge.md[hash].create());\n\n /* initialize hash function */\n hash = oids[csr.signatureParameters.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported RSASSA-PSS hash function.');\n error.oid = csr.signatureParameters.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n scheme = forge.pss.create(forge.md[hash].create(), mgf,\n csr.signatureParameters.saltLength);\n break;\n }\n\n // verify signature on csr using its public key\n rval = csr.publicKey.verify(\n md.digest().getBytes(), csr.signature, scheme);\n }\n\n return rval;\n };\n\n return csr;\n};\n\n/**\n * Converts an X.509 subject or issuer to an ASN.1 RDNSequence.\n *\n * @param obj the subject or issuer (distinguished name).\n *\n * @return the ASN.1 RDNSequence.\n */\nfunction _dnToAsn1(obj) {\n // create an empty RDNSequence\n var rval = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n // iterate over attributes\n var attr, set;\n var attrs = obj.attributes;\n for(var i = 0; i < attrs.length; ++i) {\n attr = attrs[i];\n var value = attr.value;\n\n // reuse tag class for attribute value if available\n var valueTagClass = asn1.Type.PRINTABLESTRING;\n if('valueTagClass' in attr) {\n valueTagClass = attr.valueTagClass;\n\n if(valueTagClass === asn1.Type.UTF8) {\n value = forge.util.encodeUtf8(value);\n }\n // FIXME: handle more encodings\n }\n\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n set = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n // AttributeValue\n asn1.create(asn1.Class.UNIVERSAL, valueTagClass, false, value)\n ])\n ]);\n rval.value.push(set);\n }\n\n return rval;\n}\n\n/**\n * Gets all printable attributes (typically of an issuer or subject) in a\n * simplified JSON format for display.\n *\n * @param attrs the attributes.\n *\n * @return the JSON for display.\n */\nfunction _getAttributesAsJson(attrs) {\n var rval = {};\n for(var i = 0; i < attrs.length; ++i) {\n var attr = attrs[i];\n if(attr.shortName && (\n attr.valueTagClass === asn1.Type.UTF8 ||\n attr.valueTagClass === asn1.Type.PRINTABLESTRING ||\n attr.valueTagClass === asn1.Type.IA5STRING)) {\n var value = attr.value;\n if(attr.valueTagClass === asn1.Type.UTF8) {\n value = forge.util.encodeUtf8(attr.value);\n }\n if(!(attr.shortName in rval)) {\n rval[attr.shortName] = value;\n } else if(forge.util.isArray(rval[attr.shortName])) {\n rval[attr.shortName].push(value);\n } else {\n rval[attr.shortName] = [rval[attr.shortName], value];\n }\n }\n }\n return rval;\n}\n\n/**\n * Fills in missing fields in attributes.\n *\n * @param attrs the attributes to fill missing fields in.\n */\nfunction _fillMissingFields(attrs) {\n var attr;\n for(var i = 0; i < attrs.length; ++i) {\n attr = attrs[i];\n\n // populate missing name\n if(typeof attr.name === 'undefined') {\n if(attr.type && attr.type in pki.oids) {\n attr.name = pki.oids[attr.type];\n } else if(attr.shortName && attr.shortName in _shortNames) {\n attr.name = pki.oids[_shortNames[attr.shortName]];\n }\n }\n\n // populate missing type (OID)\n if(typeof attr.type === 'undefined') {\n if(attr.name && attr.name in pki.oids) {\n attr.type = pki.oids[attr.name];\n } else {\n var error = new Error('Attribute type not specified.');\n error.attribute = attr;\n throw error;\n }\n }\n\n // populate missing shortname\n if(typeof attr.shortName === 'undefined') {\n if(attr.name && attr.name in _shortNames) {\n attr.shortName = _shortNames[attr.name];\n }\n }\n\n // convert extensions to value\n if(attr.type === oids.extensionRequest) {\n attr.valueConstructed = true;\n attr.valueTagClass = asn1.Type.SEQUENCE;\n if(!attr.value && attr.extensions) {\n attr.value = [];\n for(var ei = 0; ei < attr.extensions.length; ++ei) {\n attr.value.push(pki.certificateExtensionToAsn1(\n _fillMissingExtensionFields(attr.extensions[ei])));\n }\n }\n }\n\n if(typeof attr.value === 'undefined') {\n var error = new Error('Attribute value not specified.');\n error.attribute = attr;\n throw error;\n }\n }\n}\n\n/**\n * Fills in missing fields in certificate extensions.\n *\n * @param e the extension.\n * @param [options] the options to use.\n * [cert] the certificate the extensions are for.\n *\n * @return the extension.\n */\nfunction _fillMissingExtensionFields(e, options) {\n options = options || {};\n\n // populate missing name\n if(typeof e.name === 'undefined') {\n if(e.id && e.id in pki.oids) {\n e.name = pki.oids[e.id];\n }\n }\n\n // populate missing id\n if(typeof e.id === 'undefined') {\n if(e.name && e.name in pki.oids) {\n e.id = pki.oids[e.name];\n } else {\n var error = new Error('Extension ID not specified.');\n error.extension = e;\n throw error;\n }\n }\n\n if(typeof e.value !== 'undefined') {\n return e;\n }\n\n // handle missing value:\n\n // value is a BIT STRING\n if(e.name === 'keyUsage') {\n // build flags\n var unused = 0;\n var b2 = 0x00;\n var b3 = 0x00;\n if(e.digitalSignature) {\n b2 |= 0x80;\n unused = 7;\n }\n if(e.nonRepudiation) {\n b2 |= 0x40;\n unused = 6;\n }\n if(e.keyEncipherment) {\n b2 |= 0x20;\n unused = 5;\n }\n if(e.dataEncipherment) {\n b2 |= 0x10;\n unused = 4;\n }\n if(e.keyAgreement) {\n b2 |= 0x08;\n unused = 3;\n }\n if(e.keyCertSign) {\n b2 |= 0x04;\n unused = 2;\n }\n if(e.cRLSign) {\n b2 |= 0x02;\n unused = 1;\n }\n if(e.encipherOnly) {\n b2 |= 0x01;\n unused = 0;\n }\n if(e.decipherOnly) {\n b3 |= 0x80;\n unused = 7;\n }\n\n // create bit string\n var value = String.fromCharCode(unused);\n if(b3 !== 0) {\n value += String.fromCharCode(b2) + String.fromCharCode(b3);\n } else if(b2 !== 0) {\n value += String.fromCharCode(b2);\n }\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false, value);\n } else if(e.name === 'basicConstraints') {\n // basicConstraints is a SEQUENCE\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n // cA BOOLEAN flag defaults to false\n if(e.cA) {\n e.value.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BOOLEAN, false,\n String.fromCharCode(0xFF)));\n }\n if('pathLenConstraint' in e) {\n e.value.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(e.pathLenConstraint).getBytes()));\n }\n } else if(e.name === 'extKeyUsage') {\n // extKeyUsage is a SEQUENCE of OIDs\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var seq = e.value.value;\n for(var key in e) {\n if(e[key] !== true) {\n continue;\n }\n // key is name in OID map\n if(key in oids) {\n seq.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID,\n false, asn1.oidToDer(oids[key]).getBytes()));\n } else if(key.indexOf('.') !== -1) {\n // assume key is an OID\n seq.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID,\n false, asn1.oidToDer(key).getBytes()));\n }\n }\n } else if(e.name === 'nsCertType') {\n // nsCertType is a BIT STRING\n // build flags\n var unused = 0;\n var b2 = 0x00;\n\n if(e.client) {\n b2 |= 0x80;\n unused = 7;\n }\n if(e.server) {\n b2 |= 0x40;\n unused = 6;\n }\n if(e.email) {\n b2 |= 0x20;\n unused = 5;\n }\n if(e.objsign) {\n b2 |= 0x10;\n unused = 4;\n }\n if(e.reserved) {\n b2 |= 0x08;\n unused = 3;\n }\n if(e.sslCA) {\n b2 |= 0x04;\n unused = 2;\n }\n if(e.emailCA) {\n b2 |= 0x02;\n unused = 1;\n }\n if(e.objCA) {\n b2 |= 0x01;\n unused = 0;\n }\n\n // create bit string\n var value = String.fromCharCode(unused);\n if(b2 !== 0) {\n value += String.fromCharCode(b2);\n }\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false, value);\n } else if(e.name === 'subjectAltName' || e.name === 'issuerAltName') {\n // SYNTAX SEQUENCE\n e.value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n var altName;\n for(var n = 0; n < e.altNames.length; ++n) {\n altName = e.altNames[n];\n var value = altName.value;\n // handle IP\n if(altName.type === 7 && altName.ip) {\n value = forge.util.bytesFromIP(altName.ip);\n if(value === null) {\n var error = new Error(\n 'Extension \"ip\" value is not a valid IPv4 or IPv6 address.');\n error.extension = e;\n throw error;\n }\n } else if(altName.type === 8) {\n // handle OID\n if(altName.oid) {\n value = asn1.oidToDer(asn1.oidToDer(altName.oid));\n } else {\n // deprecated ... convert value to OID\n value = asn1.oidToDer(value);\n }\n }\n e.value.value.push(asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, altName.type, false,\n value));\n }\n } else if(e.name === 'nsComment' && options.cert) {\n // sanity check value is ASCII (req'd) and not too big\n if(!(/^[\\x00-\\x7F]*$/.test(e.comment)) ||\n (e.comment.length < 1) || (e.comment.length > 128)) {\n throw new Error('Invalid \"nsComment\" content.');\n }\n // IA5STRING opaque comment\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.IA5STRING, false, e.comment);\n } else if(e.name === 'subjectKeyIdentifier' && options.cert) {\n var ski = options.cert.generateSubjectKeyIdentifier();\n e.subjectKeyIdentifier = ski.toHex();\n // OCTETSTRING w/digest\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, ski.getBytes());\n } else if(e.name === 'authorityKeyIdentifier' && options.cert) {\n // SYNTAX SEQUENCE\n e.value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var seq = e.value.value;\n\n if(e.keyIdentifier) {\n var keyIdentifier = (e.keyIdentifier === true ?\n options.cert.generateSubjectKeyIdentifier().getBytes() :\n e.keyIdentifier);\n seq.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, false, keyIdentifier));\n }\n\n if(e.authorityCertIssuer) {\n var authorityCertIssuer = [\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 4, true, [\n _dnToAsn1(e.authorityCertIssuer === true ?\n options.cert.issuer : e.authorityCertIssuer)\n ])\n ];\n seq.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, authorityCertIssuer));\n }\n\n if(e.serialNumber) {\n var serialNumber = forge.util.hexToBytes(e.serialNumber === true ?\n options.cert.serialNumber : e.serialNumber);\n seq.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 2, false, serialNumber));\n }\n } else if(e.name === 'cRLDistributionPoints') {\n e.value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var seq = e.value.value;\n\n // Create sub SEQUENCE of DistributionPointName\n var subSeq = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n // Create fullName CHOICE\n var fullNameGeneralNames = asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n var altName;\n for(var n = 0; n < e.altNames.length; ++n) {\n altName = e.altNames[n];\n var value = altName.value;\n // handle IP\n if(altName.type === 7 && altName.ip) {\n value = forge.util.bytesFromIP(altName.ip);\n if(value === null) {\n var error = new Error(\n 'Extension \"ip\" value is not a valid IPv4 or IPv6 address.');\n error.extension = e;\n throw error;\n }\n } else if(altName.type === 8) {\n // handle OID\n if(altName.oid) {\n value = asn1.oidToDer(asn1.oidToDer(altName.oid));\n } else {\n // deprecated ... convert value to OID\n value = asn1.oidToDer(value);\n }\n }\n fullNameGeneralNames.value.push(asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, altName.type, false,\n value));\n }\n\n // Add to the parent SEQUENCE\n subSeq.value.push(asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, [fullNameGeneralNames]));\n seq.push(subSeq);\n }\n\n // ensure value has been defined by now\n if(typeof e.value === 'undefined') {\n var error = new Error('Extension value not specified.');\n error.extension = e;\n throw error;\n }\n\n return e;\n}\n\n/**\n * Convert signature parameters object to ASN.1\n *\n * @param {String} oid Signature algorithm OID\n * @param params The signature parametrs object\n * @return ASN.1 object representing signature parameters\n */\nfunction _signatureParametersToAsn1(oid, params) {\n switch(oid) {\n case oids['RSASSA-PSS']:\n var parts = [];\n\n if(params.hash.algorithmOid !== undefined) {\n parts.push(asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(params.hash.algorithmOid).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ]));\n }\n\n if(params.mgf.algorithmOid !== undefined) {\n parts.push(asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(params.mgf.algorithmOid).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(params.mgf.hash.algorithmOid).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ])\n ]));\n }\n\n if(params.saltLength !== undefined) {\n parts.push(asn1.create(asn1.Class.CONTEXT_SPECIFIC, 2, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(params.saltLength).getBytes())\n ]));\n }\n\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, parts);\n\n default:\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '');\n }\n}\n\n/**\n * Converts a certification request's attributes to an ASN.1 set of\n * CRIAttributes.\n *\n * @param csr certification request.\n *\n * @return the ASN.1 set of CRIAttributes.\n */\nfunction _CRIAttributesToAsn1(csr) {\n // create an empty context-specific container\n var rval = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n\n // no attributes, return empty container\n if(csr.attributes.length === 0) {\n return rval;\n }\n\n // each attribute has a sequence with a type and a set of values\n var attrs = csr.attributes;\n for(var i = 0; i < attrs.length; ++i) {\n var attr = attrs[i];\n var value = attr.value;\n\n // reuse tag class for attribute value if available\n var valueTagClass = asn1.Type.UTF8;\n if('valueTagClass' in attr) {\n valueTagClass = attr.valueTagClass;\n }\n if(valueTagClass === asn1.Type.UTF8) {\n value = forge.util.encodeUtf8(value);\n }\n var valueConstructed = false;\n if('valueConstructed' in attr) {\n valueConstructed = attr.valueConstructed;\n }\n // FIXME: handle more encodings\n\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n var seq = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n // AttributeValue\n asn1.create(\n asn1.Class.UNIVERSAL, valueTagClass, valueConstructed, value)\n ])\n ]);\n rval.value.push(seq);\n }\n\n return rval;\n}\n\nvar jan_1_1950 = new Date('1950-01-01T00:00:00Z');\nvar jan_1_2050 = new Date('2050-01-01T00:00:00Z');\n\n/**\n * Converts a Date object to ASN.1\n * Handles the different format before and after 1st January 2050\n *\n * @param date date object.\n *\n * @return the ASN.1 object representing the date.\n */\nfunction _dateToAsn1(date) {\n if(date >= jan_1_1950 && date < jan_1_2050) {\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.UTCTIME, false,\n asn1.dateToUtcTime(date));\n } else {\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.GENERALIZEDTIME, false,\n asn1.dateToGeneralizedTime(date));\n }\n}\n\n/**\n * Gets the ASN.1 TBSCertificate part of an X.509v3 certificate.\n *\n * @param cert the certificate.\n *\n * @return the asn1 TBSCertificate.\n */\npki.getTBSCertificate = function(cert) {\n // TBSCertificate\n var notBefore = _dateToAsn1(cert.validity.notBefore);\n var notAfter = _dateToAsn1(cert.validity.notAfter);\n var tbs = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n // integer\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(cert.version).getBytes())\n ]),\n // serialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(cert.serialNumber)),\n // signature\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(cert.siginfo.algorithmOid).getBytes()),\n // parameters\n _signatureParametersToAsn1(\n cert.siginfo.algorithmOid, cert.siginfo.parameters)\n ]),\n // issuer\n _dnToAsn1(cert.issuer),\n // validity\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n notBefore,\n notAfter\n ]),\n // subject\n _dnToAsn1(cert.subject),\n // SubjectPublicKeyInfo\n pki.publicKeyToAsn1(cert.publicKey)\n ]);\n\n if(cert.issuer.uniqueId) {\n // issuerUniqueID (optional)\n tbs.value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n // TODO: support arbitrary bit length ids\n String.fromCharCode(0x00) +\n cert.issuer.uniqueId\n )\n ])\n );\n }\n if(cert.subject.uniqueId) {\n // subjectUniqueID (optional)\n tbs.value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 2, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n // TODO: support arbitrary bit length ids\n String.fromCharCode(0x00) +\n cert.subject.uniqueId\n )\n ])\n );\n }\n\n if(cert.extensions.length > 0) {\n // extensions (optional)\n tbs.value.push(pki.certificateExtensionsToAsn1(cert.extensions));\n }\n\n return tbs;\n};\n\n/**\n * Gets the ASN.1 CertificationRequestInfo part of a\n * PKCS#10 CertificationRequest.\n *\n * @param csr the certification request.\n *\n * @return the asn1 CertificationRequestInfo.\n */\npki.getCertificationRequestInfo = function(csr) {\n // CertificationRequestInfo\n var cri = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(csr.version).getBytes()),\n // subject\n _dnToAsn1(csr.subject),\n // SubjectPublicKeyInfo\n pki.publicKeyToAsn1(csr.publicKey),\n // attributes\n _CRIAttributesToAsn1(csr)\n ]);\n\n return cri;\n};\n\n/**\n * Converts a DistinguishedName (subject or issuer) to an ASN.1 object.\n *\n * @param dn the DistinguishedName.\n *\n * @return the asn1 representation of a DistinguishedName.\n */\npki.distinguishedNameToAsn1 = function(dn) {\n return _dnToAsn1(dn);\n};\n\n/**\n * Converts an X.509v3 RSA certificate to an ASN.1 object.\n *\n * @param cert the certificate.\n *\n * @return the asn1 representation of an X.509v3 RSA certificate.\n */\npki.certificateToAsn1 = function(cert) {\n // prefer cached TBSCertificate over generating one\n var tbsCertificate = cert.tbsCertificate || pki.getTBSCertificate(cert);\n\n // Certificate\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // TBSCertificate\n tbsCertificate,\n // AlgorithmIdentifier (signature algorithm)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(cert.signatureOid).getBytes()),\n // parameters\n _signatureParametersToAsn1(cert.signatureOid, cert.signatureParameters)\n ]),\n // SignatureValue\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n String.fromCharCode(0x00) + cert.signature)\n ]);\n};\n\n/**\n * Converts X.509v3 certificate extensions to ASN.1.\n *\n * @param exts the extensions to convert.\n *\n * @return the extensions in ASN.1 format.\n */\npki.certificateExtensionsToAsn1 = function(exts) {\n // create top-level extension container\n var rval = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 3, true, []);\n\n // create extension sequence (stores a sequence for each extension)\n var seq = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n rval.value.push(seq);\n\n for(var i = 0; i < exts.length; ++i) {\n seq.value.push(pki.certificateExtensionToAsn1(exts[i]));\n }\n\n return rval;\n};\n\n/**\n * Converts a single certificate extension to ASN.1.\n *\n * @param ext the extension to convert.\n *\n * @return the extension in ASN.1 format.\n */\npki.certificateExtensionToAsn1 = function(ext) {\n // create a sequence for each extension\n var extseq = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n // extnID (OID)\n extseq.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(ext.id).getBytes()));\n\n // critical defaults to false\n if(ext.critical) {\n // critical BOOLEAN DEFAULT FALSE\n extseq.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BOOLEAN, false,\n String.fromCharCode(0xFF)));\n }\n\n var value = ext.value;\n if(typeof ext.value !== 'string') {\n // value is asn.1\n value = asn1.toDer(value).getBytes();\n }\n\n // extnValue (OCTET STRING)\n extseq.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, value));\n\n return extseq;\n};\n\n/**\n * Converts a PKCS#10 certification request to an ASN.1 object.\n *\n * @param csr the certification request.\n *\n * @return the asn1 representation of a certification request.\n */\npki.certificationRequestToAsn1 = function(csr) {\n // prefer cached CertificationRequestInfo over generating one\n var cri = csr.certificationRequestInfo ||\n pki.getCertificationRequestInfo(csr);\n\n // Certificate\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // CertificationRequestInfo\n cri,\n // AlgorithmIdentifier (signature algorithm)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(csr.signatureOid).getBytes()),\n // parameters\n _signatureParametersToAsn1(csr.signatureOid, csr.signatureParameters)\n ]),\n // signature\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n String.fromCharCode(0x00) + csr.signature)\n ]);\n};\n\n/**\n * Creates a CA store.\n *\n * @param certs an optional array of certificate objects or PEM-formatted\n * certificate strings to add to the CA store.\n *\n * @return the CA store.\n */\npki.createCaStore = function(certs) {\n // create CA store\n var caStore = {\n // stored certificates\n certs: {}\n };\n\n /**\n * Gets the certificate that issued the passed certificate or its\n * 'parent'.\n *\n * @param cert the certificate to get the parent for.\n *\n * @return the parent certificate or null if none was found.\n */\n caStore.getIssuer = function(cert) {\n var rval = getBySubject(cert.issuer);\n\n // see if there are multiple matches\n /*if(forge.util.isArray(rval)) {\n // TODO: resolve multiple matches by checking\n // authorityKey/subjectKey/issuerUniqueID/other identifiers, etc.\n // FIXME: or alternatively do authority key mapping\n // if possible (X.509v1 certs can't work?)\n throw new Error('Resolving multiple issuer matches not implemented yet.');\n }*/\n\n return rval;\n };\n\n /**\n * Adds a trusted certificate to the store.\n *\n * @param cert the certificate to add as a trusted certificate (either a\n * pki.certificate object or a PEM-formatted certificate).\n */\n caStore.addCertificate = function(cert) {\n // convert from pem if necessary\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n\n ensureSubjectHasHash(cert.subject);\n\n if(!caStore.hasCertificate(cert)) { // avoid duplicate certificates in store\n if(cert.subject.hash in caStore.certs) {\n // subject hash already exists, append to array\n var tmp = caStore.certs[cert.subject.hash];\n if(!forge.util.isArray(tmp)) {\n tmp = [tmp];\n }\n tmp.push(cert);\n caStore.certs[cert.subject.hash] = tmp;\n } else {\n caStore.certs[cert.subject.hash] = cert;\n }\n }\n };\n\n /**\n * Checks to see if the given certificate is in the store.\n *\n * @param cert the certificate to check (either a pki.certificate or a\n * PEM-formatted certificate).\n *\n * @return true if the certificate is in the store, false if not.\n */\n caStore.hasCertificate = function(cert) {\n // convert from pem if necessary\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n\n var match = getBySubject(cert.subject);\n if(!match) {\n return false;\n }\n if(!forge.util.isArray(match)) {\n match = [match];\n }\n // compare DER-encoding of certificates\n var der1 = asn1.toDer(pki.certificateToAsn1(cert)).getBytes();\n for(var i = 0; i < match.length; ++i) {\n var der2 = asn1.toDer(pki.certificateToAsn1(match[i])).getBytes();\n if(der1 === der2) {\n return true;\n }\n }\n return false;\n };\n\n /**\n * Lists all of the certificates kept in the store.\n *\n * @return an array of all of the pki.certificate objects in the store.\n */\n caStore.listAllCertificates = function() {\n var certList = [];\n\n for(var hash in caStore.certs) {\n if(caStore.certs.hasOwnProperty(hash)) {\n var value = caStore.certs[hash];\n if(!forge.util.isArray(value)) {\n certList.push(value);\n } else {\n for(var i = 0; i < value.length; ++i) {\n certList.push(value[i]);\n }\n }\n }\n }\n\n return certList;\n };\n\n /**\n * Removes a certificate from the store.\n *\n * @param cert the certificate to remove (either a pki.certificate or a\n * PEM-formatted certificate).\n *\n * @return the certificate that was removed or null if the certificate\n * wasn't in store.\n */\n caStore.removeCertificate = function(cert) {\n var result;\n\n // convert from pem if necessary\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n ensureSubjectHasHash(cert.subject);\n if(!caStore.hasCertificate(cert)) {\n return null;\n }\n\n var match = getBySubject(cert.subject);\n\n if(!forge.util.isArray(match)) {\n result = caStore.certs[cert.subject.hash];\n delete caStore.certs[cert.subject.hash];\n return result;\n }\n\n // compare DER-encoding of certificates\n var der1 = asn1.toDer(pki.certificateToAsn1(cert)).getBytes();\n for(var i = 0; i < match.length; ++i) {\n var der2 = asn1.toDer(pki.certificateToAsn1(match[i])).getBytes();\n if(der1 === der2) {\n result = match[i];\n match.splice(i, 1);\n }\n }\n if(match.length === 0) {\n delete caStore.certs[cert.subject.hash];\n }\n\n return result;\n };\n\n function getBySubject(subject) {\n ensureSubjectHasHash(subject);\n return caStore.certs[subject.hash] || null;\n }\n\n function ensureSubjectHasHash(subject) {\n // produce subject hash if it doesn't exist\n if(!subject.hash) {\n var md = forge.md.sha1.create();\n subject.attributes = pki.RDNAttributesAsArray(_dnToAsn1(subject), md);\n subject.hash = md.digest().toHex();\n }\n }\n\n // auto-add passed in certs\n if(certs) {\n // parse PEM-formatted certificates as necessary\n for(var i = 0; i < certs.length; ++i) {\n var cert = certs[i];\n caStore.addCertificate(cert);\n }\n }\n\n return caStore;\n};\n\n/**\n * Certificate verification errors, based on TLS.\n */\npki.certificateError = {\n bad_certificate: 'forge.pki.BadCertificate',\n unsupported_certificate: 'forge.pki.UnsupportedCertificate',\n certificate_revoked: 'forge.pki.CertificateRevoked',\n certificate_expired: 'forge.pki.CertificateExpired',\n certificate_unknown: 'forge.pki.CertificateUnknown',\n unknown_ca: 'forge.pki.UnknownCertificateAuthority'\n};\n\n/**\n * Verifies a certificate chain against the given Certificate Authority store\n * with an optional custom verify callback.\n *\n * @param caStore a certificate store to verify against.\n * @param chain the certificate chain to verify, with the root or highest\n * authority at the end (an array of certificates).\n * @param options a callback to be called for every certificate in the chain or\n * an object with:\n * verify a callback to be called for every certificate in the\n * chain\n * validityCheckDate the date against which the certificate\n * validity period should be checked. Pass null to not check\n * the validity period. By default, the current date is used.\n *\n * The verify callback has the following signature:\n *\n * verified - Set to true if certificate was verified, otherwise the\n * pki.certificateError for why the certificate failed.\n * depth - The current index in the chain, where 0 is the end point's cert.\n * certs - The certificate chain, *NOTE* an empty chain indicates an anonymous\n * end point.\n *\n * The function returns true on success and on failure either the appropriate\n * pki.certificateError or an object with 'error' set to the appropriate\n * pki.certificateError and 'message' set to a custom error message.\n *\n * @return true if successful, error thrown if not.\n */\npki.verifyCertificateChain = function(caStore, chain, options) {\n /* From: RFC3280 - Internet X.509 Public Key Infrastructure Certificate\n Section 6: Certification Path Validation\n See inline parentheticals related to this particular implementation.\n\n The primary goal of path validation is to verify the binding between\n a subject distinguished name or a subject alternative name and subject\n public key, as represented in the end entity certificate, based on the\n public key of the trust anchor. This requires obtaining a sequence of\n certificates that support that binding. That sequence should be provided\n in the passed 'chain'. The trust anchor should be in the given CA\n store. The 'end entity' certificate is the certificate provided by the\n end point (typically a server) and is the first in the chain.\n\n To meet this goal, the path validation process verifies, among other\n things, that a prospective certification path (a sequence of n\n certificates or a 'chain') satisfies the following conditions:\n\n (a) for all x in {1, ..., n-1}, the subject of certificate x is\n the issuer of certificate x+1;\n\n (b) certificate 1 is issued by the trust anchor;\n\n (c) certificate n is the certificate to be validated; and\n\n (d) for all x in {1, ..., n}, the certificate was valid at the\n time in question.\n\n Note that here 'n' is index 0 in the chain and 1 is the last certificate\n in the chain and it must be signed by a certificate in the connection's\n CA store.\n\n The path validation process also determines the set of certificate\n policies that are valid for this path, based on the certificate policies\n extension, policy mapping extension, policy constraints extension, and\n inhibit any-policy extension.\n\n Note: Policy mapping extension not supported (Not Required).\n\n Note: If the certificate has an unsupported critical extension, then it\n must be rejected.\n\n Note: A certificate is self-issued if the DNs that appear in the subject\n and issuer fields are identical and are not empty.\n\n The path validation algorithm assumes the following seven inputs are\n provided to the path processing logic. What this specific implementation\n will use is provided parenthetically:\n\n (a) a prospective certification path of length n (the 'chain')\n (b) the current date/time: ('now').\n (c) user-initial-policy-set: A set of certificate policy identifiers\n naming the policies that are acceptable to the certificate user.\n The user-initial-policy-set contains the special value any-policy\n if the user is not concerned about certificate policy\n (Not implemented. Any policy is accepted).\n (d) trust anchor information, describing a CA that serves as a trust\n anchor for the certification path. The trust anchor information\n includes:\n\n (1) the trusted issuer name,\n (2) the trusted public key algorithm,\n (3) the trusted public key, and\n (4) optionally, the trusted public key parameters associated\n with the public key.\n\n (Trust anchors are provided via certificates in the CA store).\n\n The trust anchor information may be provided to the path processing\n procedure in the form of a self-signed certificate. The trusted anchor\n information is trusted because it was delivered to the path processing\n procedure by some trustworthy out-of-band procedure. If the trusted\n public key algorithm requires parameters, then the parameters are\n provided along with the trusted public key (No parameters used in this\n implementation).\n\n (e) initial-policy-mapping-inhibit, which indicates if policy mapping is\n allowed in the certification path.\n (Not implemented, no policy checking)\n\n (f) initial-explicit-policy, which indicates if the path must be valid\n for at least one of the certificate policies in the user-initial-\n policy-set.\n (Not implemented, no policy checking)\n\n (g) initial-any-policy-inhibit, which indicates whether the\n anyPolicy OID should be processed if it is included in a\n certificate.\n (Not implemented, so any policy is valid provided that it is\n not marked as critical) */\n\n /* Basic Path Processing:\n\n For each certificate in the 'chain', the following is checked:\n\n 1. The certificate validity period includes the current time.\n 2. The certificate was signed by its parent (where the parent is either\n the next in the chain or from the CA store). Allow processing to\n continue to the next step if no parent is found but the certificate is\n in the CA store.\n 3. TODO: The certificate has not been revoked.\n 4. The certificate issuer name matches the parent's subject name.\n 5. TODO: If the certificate is self-issued and not the final certificate\n in the chain, skip this step, otherwise verify that the subject name\n is within one of the permitted subtrees of X.500 distinguished names\n and that each of the alternative names in the subjectAltName extension\n (critical or non-critical) is within one of the permitted subtrees for\n that name type.\n 6. TODO: If the certificate is self-issued and not the final certificate\n in the chain, skip this step, otherwise verify that the subject name\n is not within one of the excluded subtrees for X.500 distinguished\n names and none of the subjectAltName extension names are excluded for\n that name type.\n 7. The other steps in the algorithm for basic path processing involve\n handling the policy extension which is not presently supported in this\n implementation. Instead, if a critical policy extension is found, the\n certificate is rejected as not supported.\n 8. If the certificate is not the first or if its the only certificate in\n the chain (having no parent from the CA store or is self-signed) and it\n has a critical key usage extension, verify that the keyCertSign bit is\n set. If the key usage extension exists, verify that the basic\n constraints extension exists. If the basic constraints extension exists,\n verify that the cA flag is set. If pathLenConstraint is set, ensure that\n the number of certificates that precede in the chain (come earlier\n in the chain as implemented below), excluding the very first in the\n chain (typically the end-entity one), isn't greater than the\n pathLenConstraint. This constraint limits the number of intermediate\n CAs that may appear below a CA before only end-entity certificates\n may be issued. */\n\n // if a verify callback is passed as the third parameter, package it within\n // the options object. This is to support a legacy function signature that\n // expected the verify callback as the third parameter.\n if(typeof options === 'function') {\n options = {verify: options};\n }\n options = options || {};\n\n // copy cert chain references to another array to protect against changes\n // in verify callback\n chain = chain.slice(0);\n var certs = chain.slice(0);\n\n var validityCheckDate = options.validityCheckDate;\n // if no validityCheckDate is specified, default to the current date. Make\n // sure to maintain the value null because it indicates that the validity\n // period should not be checked.\n if(typeof validityCheckDate === 'undefined') {\n validityCheckDate = new Date();\n }\n\n // verify each cert in the chain using its parent, where the parent\n // is either the next in the chain or from the CA store\n var first = true;\n var error = null;\n var depth = 0;\n do {\n var cert = chain.shift();\n var parent = null;\n var selfSigned = false;\n\n if(validityCheckDate) {\n // 1. check valid time\n if(validityCheckDate < cert.validity.notBefore ||\n validityCheckDate > cert.validity.notAfter) {\n error = {\n message: 'Certificate is not valid yet or has expired.',\n error: pki.certificateError.certificate_expired,\n notBefore: cert.validity.notBefore,\n notAfter: cert.validity.notAfter,\n // TODO: we might want to reconsider renaming 'now' to\n // 'validityCheckDate' should this API be changed in the future.\n now: validityCheckDate\n };\n }\n }\n\n // 2. verify with parent from chain or CA store\n if(error === null) {\n parent = chain[0] || caStore.getIssuer(cert);\n if(parent === null) {\n // check for self-signed cert\n if(cert.isIssuer(cert)) {\n selfSigned = true;\n parent = cert;\n }\n }\n\n if(parent) {\n // FIXME: current CA store implementation might have multiple\n // certificates where the issuer can't be determined from the\n // certificate (happens rarely with, eg: old certificates) so normalize\n // by always putting parents into an array\n // TODO: there's may be an extreme degenerate case currently uncovered\n // where an old intermediate certificate seems to have a matching parent\n // but none of the parents actually verify ... but the intermediate\n // is in the CA and it should pass this check; needs investigation\n var parents = parent;\n if(!forge.util.isArray(parents)) {\n parents = [parents];\n }\n\n // try to verify with each possible parent (typically only one)\n var verified = false;\n while(!verified && parents.length > 0) {\n parent = parents.shift();\n try {\n verified = parent.verify(cert);\n } catch(ex) {\n // failure to verify, don't care why, try next one\n }\n }\n\n if(!verified) {\n error = {\n message: 'Certificate signature is invalid.',\n error: pki.certificateError.bad_certificate\n };\n }\n }\n\n if(error === null && (!parent || selfSigned) &&\n !caStore.hasCertificate(cert)) {\n // no parent issuer and certificate itself is not trusted\n error = {\n message: 'Certificate is not trusted.',\n error: pki.certificateError.unknown_ca\n };\n }\n }\n\n // TODO: 3. check revoked\n\n // 4. check for matching issuer/subject\n if(error === null && parent && !cert.isIssuer(parent)) {\n // parent is not issuer\n error = {\n message: 'Certificate issuer is invalid.',\n error: pki.certificateError.bad_certificate\n };\n }\n\n // 5. TODO: check names with permitted names tree\n\n // 6. TODO: check names against excluded names tree\n\n // 7. check for unsupported critical extensions\n if(error === null) {\n // supported extensions\n var se = {\n keyUsage: true,\n basicConstraints: true\n };\n for(var i = 0; error === null && i < cert.extensions.length; ++i) {\n var ext = cert.extensions[i];\n if(ext.critical && !(ext.name in se)) {\n error = {\n message:\n 'Certificate has an unsupported critical extension.',\n error: pki.certificateError.unsupported_certificate\n };\n }\n }\n }\n\n // 8. check for CA if cert is not first or is the only certificate\n // remaining in chain with no parent or is self-signed\n if(error === null &&\n (!first || (chain.length === 0 && (!parent || selfSigned)))) {\n // first check keyUsage extension and then basic constraints\n var bcExt = cert.getExtension('basicConstraints');\n var keyUsageExt = cert.getExtension('keyUsage');\n if(keyUsageExt !== null) {\n // keyCertSign must be true and there must be a basic\n // constraints extension\n if(!keyUsageExt.keyCertSign || bcExt === null) {\n // bad certificate\n error = {\n message:\n 'Certificate keyUsage or basicConstraints conflict ' +\n 'or indicate that the certificate is not a CA. ' +\n 'If the certificate is the only one in the chain or ' +\n 'isn\\'t the first then the certificate must be a ' +\n 'valid CA.',\n error: pki.certificateError.bad_certificate\n };\n }\n }\n // basic constraints cA flag must be set\n if(error === null && bcExt !== null && !bcExt.cA) {\n // bad certificate\n error = {\n message:\n 'Certificate basicConstraints indicates the certificate ' +\n 'is not a CA.',\n error: pki.certificateError.bad_certificate\n };\n }\n // if error is not null and keyUsage is available, then we know it\n // has keyCertSign and there is a basic constraints extension too,\n // which means we can check pathLenConstraint (if it exists)\n if(error === null && keyUsageExt !== null &&\n 'pathLenConstraint' in bcExt) {\n // pathLen is the maximum # of intermediate CA certs that can be\n // found between the current certificate and the end-entity (depth 0)\n // certificate; this number does not include the end-entity (depth 0,\n // last in the chain) even if it happens to be a CA certificate itself\n var pathLen = depth - 1;\n if(pathLen > bcExt.pathLenConstraint) {\n // pathLenConstraint violated, bad certificate\n error = {\n message:\n 'Certificate basicConstraints pathLenConstraint violated.',\n error: pki.certificateError.bad_certificate\n };\n }\n }\n }\n\n // call application callback\n var vfd = (error === null) ? true : error.error;\n var ret = options.verify ? options.verify(vfd, depth, certs) : vfd;\n if(ret === true) {\n // clear any set error\n error = null;\n } else {\n // if passed basic tests, set default message and alert\n if(vfd === true) {\n error = {\n message: 'The application rejected the certificate.',\n error: pki.certificateError.bad_certificate\n };\n }\n\n // check for custom error info\n if(ret || ret === 0) {\n // set custom message and error\n if(typeof ret === 'object' && !forge.util.isArray(ret)) {\n if(ret.message) {\n error.message = ret.message;\n }\n if(ret.error) {\n error.error = ret.error;\n }\n } else if(typeof ret === 'string') {\n // set custom error\n error.error = ret;\n }\n }\n\n // throw error\n throw error;\n }\n\n // no longer first cert in chain\n first = false;\n ++depth;\n } while(chain.length > 0);\n\n return true;\n};\n","/**\n * Node.js module for Forge mask generation functions.\n *\n * @author Stefan Siegl\n *\n * Copyright 2012 Stefan Siegl \n */\nvar forge = require('./forge');\nrequire('./mgf1');\n\nmodule.exports = forge.mgf = forge.mgf || {};\nforge.mgf.mgf1 = forge.mgf1;\n","/**\n * Javascript implementation of mask generation function MGF1.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl \n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nforge.mgf = forge.mgf || {};\nvar mgf1 = module.exports = forge.mgf.mgf1 = forge.mgf1 = forge.mgf1 || {};\n\n/**\n * Creates a MGF1 mask generation function object.\n *\n * @param md the message digest API to use (eg: forge.md.sha1.create()).\n *\n * @return a mask generation function object.\n */\nmgf1.create = function(md) {\n var mgf = {\n /**\n * Generate mask of specified length.\n *\n * @param {String} seed The seed for mask generation.\n * @param maskLen Number of bytes to generate.\n * @return {String} The generated mask.\n */\n generate: function(seed, maskLen) {\n /* 2. Let T be the empty octet string. */\n var t = new forge.util.ByteBuffer();\n\n /* 3. For counter from 0 to ceil(maskLen / hLen), do the following: */\n var len = Math.ceil(maskLen / md.digestLength);\n for(var i = 0; i < len; i++) {\n /* a. Convert counter to an octet string C of length 4 octets */\n var c = new forge.util.ByteBuffer();\n c.putInt32(i);\n\n /* b. Concatenate the hash of the seed mgfSeed and C to the octet\n * string T: */\n md.start();\n md.update(seed + c.getBytes());\n t.putBuffer(md.digest());\n }\n\n /* Output the leading maskLen octets of T as the octet string mask. */\n t.truncate(t.length() - maskLen);\n return t.getBytes();\n }\n };\n\n return mgf;\n};\n","/**\n * Javascript implementation of PKCS#1 PSS signature padding.\n *\n * @author Stefan Siegl\n *\n * Copyright (c) 2012 Stefan Siegl \n */\nvar forge = require('./forge');\nrequire('./random');\nrequire('./util');\n\n// shortcut for PSS API\nvar pss = module.exports = forge.pss = forge.pss || {};\n\n/**\n * Creates a PSS signature scheme object.\n *\n * There are several ways to provide a salt for encoding:\n *\n * 1. Specify the saltLength only and the built-in PRNG will generate it.\n * 2. Specify the saltLength and a custom PRNG with 'getBytesSync' defined that\n * will be used.\n * 3. Specify the salt itself as a forge.util.ByteBuffer.\n *\n * @param options the options to use:\n * md the message digest object to use, a forge md instance.\n * mgf the mask generation function to use, a forge mgf instance.\n * [saltLength] the length of the salt in octets.\n * [prng] the pseudo-random number generator to use to produce a salt.\n * [salt] the salt to use when encoding.\n *\n * @return a signature scheme object.\n */\npss.create = function(options) {\n // backwards compatibility w/legacy args: hash, mgf, sLen\n if(arguments.length === 3) {\n options = {\n md: arguments[0],\n mgf: arguments[1],\n saltLength: arguments[2]\n };\n }\n\n var hash = options.md;\n var mgf = options.mgf;\n var hLen = hash.digestLength;\n\n var salt_ = options.salt || null;\n if(typeof salt_ === 'string') {\n // assume binary-encoded string\n salt_ = forge.util.createBuffer(salt_);\n }\n\n var sLen;\n if('saltLength' in options) {\n sLen = options.saltLength;\n } else if(salt_ !== null) {\n sLen = salt_.length();\n } else {\n throw new Error('Salt length not specified or specific salt not given.');\n }\n\n if(salt_ !== null && salt_.length() !== sLen) {\n throw new Error('Given salt length does not match length of given salt.');\n }\n\n var prng = options.prng || forge.random;\n\n var pssobj = {};\n\n /**\n * Encodes a PSS signature.\n *\n * This function implements EMSA-PSS-ENCODE as per RFC 3447, section 9.1.1.\n *\n * @param md the message digest object with the hash to sign.\n * @param modsBits the length of the RSA modulus in bits.\n *\n * @return the encoded message as a binary-encoded string of length\n * ceil((modBits - 1) / 8).\n */\n pssobj.encode = function(md, modBits) {\n var i;\n var emBits = modBits - 1;\n var emLen = Math.ceil(emBits / 8);\n\n /* 2. Let mHash = Hash(M), an octet string of length hLen. */\n var mHash = md.digest().getBytes();\n\n /* 3. If emLen < hLen + sLen + 2, output \"encoding error\" and stop. */\n if(emLen < hLen + sLen + 2) {\n throw new Error('Message is too long to encrypt.');\n }\n\n /* 4. Generate a random octet string salt of length sLen; if sLen = 0,\n * then salt is the empty string. */\n var salt;\n if(salt_ === null) {\n salt = prng.getBytesSync(sLen);\n } else {\n salt = salt_.bytes();\n }\n\n /* 5. Let M' = (0x)00 00 00 00 00 00 00 00 || mHash || salt; */\n var m_ = new forge.util.ByteBuffer();\n m_.fillWithByte(0, 8);\n m_.putBytes(mHash);\n m_.putBytes(salt);\n\n /* 6. Let H = Hash(M'), an octet string of length hLen. */\n hash.start();\n hash.update(m_.getBytes());\n var h = hash.digest().getBytes();\n\n /* 7. Generate an octet string PS consisting of emLen - sLen - hLen - 2\n * zero octets. The length of PS may be 0. */\n var ps = new forge.util.ByteBuffer();\n ps.fillWithByte(0, emLen - sLen - hLen - 2);\n\n /* 8. Let DB = PS || 0x01 || salt; DB is an octet string of length\n * emLen - hLen - 1. */\n ps.putByte(0x01);\n ps.putBytes(salt);\n var db = ps.getBytes();\n\n /* 9. Let dbMask = MGF(H, emLen - hLen - 1). */\n var maskLen = emLen - hLen - 1;\n var dbMask = mgf.generate(h, maskLen);\n\n /* 10. Let maskedDB = DB \\xor dbMask. */\n var maskedDB = '';\n for(i = 0; i < maskLen; i++) {\n maskedDB += String.fromCharCode(db.charCodeAt(i) ^ dbMask.charCodeAt(i));\n }\n\n /* 11. Set the leftmost 8emLen - emBits bits of the leftmost octet in\n * maskedDB to zero. */\n var mask = (0xFF00 >> (8 * emLen - emBits)) & 0xFF;\n maskedDB = String.fromCharCode(maskedDB.charCodeAt(0) & ~mask) +\n maskedDB.substr(1);\n\n /* 12. Let EM = maskedDB || H || 0xbc.\n * 13. Output EM. */\n return maskedDB + h + String.fromCharCode(0xbc);\n };\n\n /**\n * Verifies a PSS signature.\n *\n * This function implements EMSA-PSS-VERIFY as per RFC 3447, section 9.1.2.\n *\n * @param mHash the message digest hash, as a binary-encoded string, to\n * compare against the signature.\n * @param em the encoded message, as a binary-encoded string\n * (RSA decryption result).\n * @param modsBits the length of the RSA modulus in bits.\n *\n * @return true if the signature was verified, false if not.\n */\n pssobj.verify = function(mHash, em, modBits) {\n var i;\n var emBits = modBits - 1;\n var emLen = Math.ceil(emBits / 8);\n\n /* c. Convert the message representative m to an encoded message EM\n * of length emLen = ceil((modBits - 1) / 8) octets, where modBits\n * is the length in bits of the RSA modulus n */\n em = em.substr(-emLen);\n\n /* 3. If emLen < hLen + sLen + 2, output \"inconsistent\" and stop. */\n if(emLen < hLen + sLen + 2) {\n throw new Error('Inconsistent parameters to PSS signature verification.');\n }\n\n /* 4. If the rightmost octet of EM does not have hexadecimal value\n * 0xbc, output \"inconsistent\" and stop. */\n if(em.charCodeAt(emLen - 1) !== 0xbc) {\n throw new Error('Encoded message does not end in 0xBC.');\n }\n\n /* 5. Let maskedDB be the leftmost emLen - hLen - 1 octets of EM, and\n * let H be the next hLen octets. */\n var maskLen = emLen - hLen - 1;\n var maskedDB = em.substr(0, maskLen);\n var h = em.substr(maskLen, hLen);\n\n /* 6. If the leftmost 8emLen - emBits bits of the leftmost octet in\n * maskedDB are not all equal to zero, output \"inconsistent\" and stop. */\n var mask = (0xFF00 >> (8 * emLen - emBits)) & 0xFF;\n if((maskedDB.charCodeAt(0) & mask) !== 0) {\n throw new Error('Bits beyond keysize not zero as expected.');\n }\n\n /* 7. Let dbMask = MGF(H, emLen - hLen - 1). */\n var dbMask = mgf.generate(h, maskLen);\n\n /* 8. Let DB = maskedDB \\xor dbMask. */\n var db = '';\n for(i = 0; i < maskLen; i++) {\n db += String.fromCharCode(maskedDB.charCodeAt(i) ^ dbMask.charCodeAt(i));\n }\n\n /* 9. Set the leftmost 8emLen - emBits bits of the leftmost octet\n * in DB to zero. */\n db = String.fromCharCode(db.charCodeAt(0) & ~mask) + db.substr(1);\n\n /* 10. If the emLen - hLen - sLen - 2 leftmost octets of DB are not zero\n * or if the octet at position emLen - hLen - sLen - 1 (the leftmost\n * position is \"position 1\") does not have hexadecimal value 0x01,\n * output \"inconsistent\" and stop. */\n var checkLen = emLen - hLen - sLen - 2;\n for(i = 0; i < checkLen; i++) {\n if(db.charCodeAt(i) !== 0x00) {\n throw new Error('Leftmost octets not zero as expected');\n }\n }\n\n if(db.charCodeAt(checkLen) !== 0x01) {\n throw new Error('Inconsistent PSS signature, 0x01 marker not found');\n }\n\n /* 11. Let salt be the last sLen octets of DB. */\n var salt = db.substr(-sLen);\n\n /* 12. Let M' = (0x)00 00 00 00 00 00 00 00 || mHash || salt */\n var m_ = new forge.util.ByteBuffer();\n m_.fillWithByte(0, 8);\n m_.putBytes(mHash);\n m_.putBytes(salt);\n\n /* 13. Let H' = Hash(M'), an octet string of length hLen. */\n hash.start();\n hash.update(m_.getBytes());\n var h_ = hash.digest().getBytes();\n\n /* 14. If H = H', output \"consistent.\" Otherwise, output \"inconsistent.\" */\n return h === h_;\n };\n\n return pssobj;\n};\n","// @ts-nocheck\n'use strict'\n\nrequire('node-forge/lib/x509')\nconst forge = require('node-forge/lib/forge')\nconst pki = forge.pki\n\n/**\n * Gets a self-signed X.509 certificate for the key.\n *\n * The output Uint8Array contains the PKCS #7 message in DER.\n *\n * TODO: move to libp2p-crypto package\n *\n * @param {KeyInfo} key - The id and name of the key\n * @param {RsaPrivateKey} privateKey - The naked key\n * @returns {Uint8Array}\n */\nconst certificateForKey = (key, privateKey) => {\n const publicKey = pki.setRsaPublicKey(privateKey.n, privateKey.e)\n const cert = pki.createCertificate()\n cert.publicKey = publicKey\n cert.serialNumber = '01'\n cert.validity.notBefore = new Date()\n cert.validity.notAfter = new Date()\n cert.validity.notAfter.setFullYear(cert.validity.notBefore.getFullYear() + 10)\n const attrs = [{\n name: 'organizationName',\n value: 'ipfs'\n }, {\n shortName: 'OU',\n value: 'keystore'\n }, {\n name: 'commonName',\n value: key.id\n }]\n cert.setSubject(attrs)\n cert.setIssuer(attrs)\n cert.setExtensions([{\n name: 'basicConstraints',\n cA: true\n }, {\n name: 'keyUsage',\n keyCertSign: true,\n digitalSignature: true,\n nonRepudiation: true,\n keyEncipherment: true,\n dataEncipherment: true\n }, {\n name: 'extKeyUsage',\n serverAuth: true,\n clientAuth: true,\n codeSigning: true,\n emailProtection: true,\n timeStamping: true\n }, {\n name: 'nsCertType',\n client: true,\n server: true,\n email: true,\n objsign: true,\n sslCA: true,\n emailCA: true,\n objCA: true\n }])\n // self-sign certificate\n cert.sign(privateKey)\n\n return cert\n}\n\n/**\n * Finds the first item in a collection that is matched in the\n * `asyncCompare` function.\n *\n * `asyncCompare` is an async function that must\n * resolve to either `true` or `false`.\n *\n * @param {Array} array\n * @param {function(*)} asyncCompare - An async function that returns a boolean\n */\nasync function findAsync (array, asyncCompare) {\n const promises = array.map(asyncCompare)\n const results = await Promise.all(promises)\n const index = results.findIndex(result => result)\n return array[index]\n}\n\nmodule.exports = {\n certificateForKey,\n findAsync\n}\n","// @ts-nocheck\n'use strict'\n\nconst mergeOptions = require('merge-options')\nconst { pipe } = require('it-pipe')\nconst { tap } = require('streaming-iterables')\nconst oldPeerLRU = require('./old-peers')\nconst { METRICS: defaultOptions } = require('../constants')\nconst Stats = require('./stats')\n\nconst initialCounters = [\n 'dataReceived',\n 'dataSent'\n]\n\nconst directionToEvent = {\n in: 'dataReceived',\n out: 'dataSent'\n}\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('libp2p-interfaces/src/transport/types').MultiaddrConnection} MultiaddrConnection\n */\n\n/**\n * @typedef MetricsProperties\n * @property {import('../connection-manager')} connectionManager\n *\n * @typedef MetricsOptions\n * @property {number} [computeThrottleMaxQueueSize = defaultOptions.computeThrottleMaxQueueSize]\n * @property {number} [computeThrottleTimeout = defaultOptions.computeThrottleTimeout]\n * @property {number[]} [movingAverageIntervals = defaultOptions.movingAverageIntervals]\n * @property {number} [maxOldPeersRetention = defaultOptions.maxOldPeersRetention]\n */\n\nclass Metrics {\n /**\n * @class\n * @param {MetricsProperties & MetricsOptions} options\n */\n constructor (options) {\n this._options = mergeOptions(defaultOptions, options)\n this._globalStats = new Stats(initialCounters, this._options)\n this._peerStats = new Map()\n this._protocolStats = new Map()\n this._oldPeers = oldPeerLRU(this._options.maxOldPeersRetention)\n this._running = false\n this._onMessage = this._onMessage.bind(this)\n this._connectionManager = options.connectionManager\n this._connectionManager.on('peer:disconnect', (connection) => {\n this.onPeerDisconnected(connection.remotePeer)\n })\n }\n\n /**\n * Must be called for stats to saved. Any data pushed for tracking\n * will be ignored.\n */\n start () {\n this._running = true\n }\n\n /**\n * Stops all averages timers and prevents new data from being tracked.\n * Once `stop` is called, `start` must be called to resume stats tracking.\n */\n stop () {\n this._running = false\n this._globalStats.stop()\n for (const stats of this._peerStats.values()) {\n stats.stop()\n }\n for (const stats of this._protocolStats.values()) {\n stats.stop()\n }\n }\n\n /**\n * Gets the global `Stats` object\n *\n * @returns {Stats}\n */\n get global () {\n return this._globalStats\n }\n\n /**\n * Returns a list of `PeerId` strings currently being tracked\n *\n * @returns {string[]}\n */\n get peers () {\n return Array.from(this._peerStats.keys())\n }\n\n /**\n * Returns the `Stats` object for the given `PeerId` whether it\n * is a live peer, or in the disconnected peer LRU cache.\n *\n * @param {PeerId} peerId\n * @returns {Stats}\n */\n forPeer (peerId) {\n const idString = peerId.toB58String()\n return this._peerStats.get(idString) || this._oldPeers.get(idString)\n }\n\n /**\n * Returns a list of all protocol strings currently being tracked.\n *\n * @returns {string[]}\n */\n get protocols () {\n return Array.from(this._protocolStats.keys())\n }\n\n /**\n * Returns the `Stats` object for the given `protocol`.\n *\n * @param {string} protocol\n * @returns {Stats}\n */\n forProtocol (protocol) {\n return this._protocolStats.get(protocol)\n }\n\n /**\n * Should be called when all connections to a given peer\n * have closed. The `Stats` collection for the peer will\n * be stopped and moved to an LRU for temporary retention.\n *\n * @param {PeerId} peerId\n */\n onPeerDisconnected (peerId) {\n const idString = peerId.toB58String()\n const peerStats = this._peerStats.get(idString)\n if (peerStats) {\n peerStats.stop()\n this._peerStats.delete(idString)\n this._oldPeers.set(idString, peerStats)\n }\n }\n\n /**\n * Takes the metadata for a message and tracks it in the\n * appropriate categories. If the protocol is present, protocol\n * stats will also be tracked.\n *\n * @private\n * @param {object} params\n * @param {PeerId} params.remotePeer - Remote peer\n * @param {string} [params.protocol] - Protocol string the stream is running\n * @param {string} params.direction - One of ['in','out']\n * @param {number} params.dataLength - Size of the message\n * @returns {void}\n */\n _onMessage ({ remotePeer, protocol, direction, dataLength }) {\n if (!this._running) return\n\n const key = directionToEvent[direction]\n\n let peerStats = this.forPeer(remotePeer)\n if (!peerStats) {\n peerStats = new Stats(initialCounters, this._options)\n this._peerStats.set(remotePeer.toB58String(), peerStats)\n }\n\n // Peer and global stats\n peerStats.push(key, dataLength)\n this._globalStats.push(key, dataLength)\n\n // Protocol specific stats\n if (protocol) {\n let protocolStats = this.forProtocol(protocol)\n if (!protocolStats) {\n protocolStats = new Stats(initialCounters, this._options)\n this._protocolStats.set(protocol, protocolStats)\n }\n protocolStats.push(key, dataLength)\n }\n }\n\n /**\n * Replaces the `PeerId` string with the given `peerId`.\n * If stats are already being tracked for the given `peerId`, the\n * placeholder stats will be merged with the existing stats.\n *\n * @param {PeerId} placeholder - A peerId string\n * @param {PeerId} peerId\n * @returns {void}\n */\n updatePlaceholder (placeholder, peerId) {\n if (!this._running) return\n const placeholderStats = this.forPeer(placeholder)\n const peerIdString = peerId.toB58String()\n const existingStats = this.forPeer(peerId)\n let mergedStats = placeholderStats\n\n // If we already have stats, merge the two\n if (existingStats) {\n // If existing, merge\n mergedStats = Metrics.mergeStats(existingStats, mergedStats)\n // Attempt to delete from the old peers list just in case it was tracked there\n this._oldPeers.delete(peerIdString)\n }\n\n this._peerStats.delete(placeholder.toB58String())\n this._peerStats.set(peerIdString, mergedStats)\n mergedStats.start()\n }\n\n /**\n * Tracks data running through a given Duplex Iterable `stream`. If\n * the `peerId` is not provided, a placeholder string will be created and\n * returned. This allows lazy tracking of a peer when the peer is not yet known.\n * When the `PeerId` is known, `Metrics.updatePlaceholder` should be called\n * with the placeholder string returned from here, and the known `PeerId`.\n *\n * @param {Object} options\n * @param {MultiaddrConnection} options.stream - A duplex iterable stream\n * @param {PeerId} [options.remotePeer] - The id of the remote peer that's connected\n * @param {string} [options.protocol] - The protocol the stream is running\n * @returns {MultiaddrConnection} The peerId string or placeholder string\n */\n trackStream ({ stream, remotePeer, protocol }) {\n const metrics = this\n const _source = stream.source\n stream.source = tap(chunk => metrics._onMessage({\n remotePeer,\n protocol,\n direction: 'in',\n dataLength: chunk.length\n }))(_source)\n\n const _sink = stream.sink\n stream.sink = source => {\n return pipe(\n source,\n tap(chunk => metrics._onMessage({\n remotePeer,\n protocol,\n direction: 'out',\n dataLength: chunk.length\n })),\n _sink\n )\n }\n\n return stream\n }\n\n /**\n * Merges `other` into `target`. `target` will be modified\n * and returned.\n *\n * @param {Stats} target\n * @param {Stats} other\n * @returns {Stats}\n */\n static mergeStats (target, other) {\n target.stop()\n other.stop()\n\n // Merge queues\n target._queue = [...target._queue, ...other._queue]\n\n // TODO: how to merge moving averages?\n return target\n }\n}\n\nmodule.exports = Metrics\n","'use strict'\n\nconst LRU = require('hashlru')\n\n/**\n * Creates and returns a Least Recently Used Cache\n *\n * @param {number} maxSize\n * @returns {any}\n */\nmodule.exports = (maxSize) => {\n // @ts-ignore LRU expression is not callable\n const patched = LRU(maxSize)\n patched.delete = patched.remove\n return patched\n}\n","// @ts-nocheck\n'use strict'\n\nconst { EventEmitter } = require('events')\nconst { BigNumber: Big } = require('bignumber.js')\nconst MovingAverage = require('@vascosantos/moving-average')\nconst retimer = require('retimer')\n\n/**\n * @typedef {import('@vascosantos/moving-average').IMovingAverage} IMovingAverage\n */\n\nclass Stats extends EventEmitter {\n /**\n * A queue based manager for stat processing\n *\n * @class\n * @param {string[]} initialCounters\n * @param {any} options\n */\n constructor (initialCounters, options) {\n super()\n\n this._options = options\n this._queue = []\n\n /** @type {{ dataReceived: Big, dataSent: Big }} */\n this._stats = {\n dataReceived: Big(0),\n dataSent: Big(0)\n }\n\n this._frequencyLastTime = Date.now()\n this._frequencyAccumulators = {}\n\n /** @type {{ dataReceived: IMovingAverage[], dataSent: IMovingAverage[] }} */\n this._movingAverages = {}\n\n this._update = this._update.bind(this)\n\n const intervals = this._options.movingAverageIntervals\n\n for (let i = 0; i < initialCounters.length; i++) {\n const key = initialCounters[i]\n this._stats[key] = Big(0)\n this._movingAverages[key] = {}\n for (let k = 0; k < intervals.length; k++) {\n const interval = intervals[k]\n const ma = this._movingAverages[key][interval] = MovingAverage(interval)\n ma.push(this._frequencyLastTime, 0)\n }\n }\n }\n\n /**\n * Initializes the internal timer if there are items in the queue. This\n * should only need to be called if `Stats.stop` was previously called, as\n * `Stats.push` will also start the processing.\n *\n * @returns {void}\n */\n start () {\n if (this._queue.length) {\n this._resetComputeTimeout()\n }\n }\n\n /**\n * Stops processing and computing of stats by clearing the internal\n * timer.\n *\n * @returns {void}\n */\n stop () {\n if (this._timeout) {\n this._timeout.clear()\n this._timeout = null\n }\n }\n\n /**\n * Returns a clone of the current stats.\n */\n get snapshot () {\n return Object.assign({}, this._stats)\n }\n\n /**\n * Returns a clone of the internal movingAverages\n */\n get movingAverages () {\n return Object.assign({}, this._movingAverages)\n }\n\n /**\n * Returns a plain JSON object of the stats\n *\n * @returns {*}\n */\n toJSON () {\n const snapshot = this.snapshot\n const movingAverages = this.movingAverages\n const data = {\n dataReceived: snapshot.dataReceived.toString(),\n dataSent: snapshot.dataSent.toString(),\n movingAverages: {}\n }\n\n const counters = Object.keys(movingAverages)\n for (const key of counters) {\n data.movingAverages[key] = {}\n for (const interval of Object.keys(movingAverages[key])) {\n data.movingAverages[key][interval] = movingAverages[key][interval].movingAverage()\n }\n }\n\n return data\n }\n\n /**\n * Pushes the given operation data to the queue, along with the\n * current Timestamp, then resets the update timer.\n *\n * @param {string} counter\n * @param {number} inc\n * @returns {void}\n */\n push (counter, inc) {\n this._queue.push([counter, inc, Date.now()])\n this._resetComputeTimeout()\n }\n\n /**\n * Resets the timeout for triggering updates.\n *\n * @private\n * @returns {void}\n */\n _resetComputeTimeout () {\n this._timeout = retimer(this._update, this._nextTimeout())\n }\n\n /**\n * Calculates and returns the timeout for the next update based on\n * the urgency of the update.\n *\n * @private\n * @returns {number}\n */\n _nextTimeout () {\n // calculate the need for an update, depending on the queue length\n const urgency = this._queue.length / this._options.computeThrottleMaxQueueSize\n const timeout = Math.max(this._options.computeThrottleTimeout * (1 - urgency), 0)\n return timeout\n }\n\n /**\n * If there are items in the queue, they will will be processed and\n * the frequency for all items will be updated based on the Timestamp\n * of the last item in the queue. The `update` event will also be emitted\n * with the latest stats.\n *\n * If there are no items in the queue, no action is taken.\n *\n * @private\n * @returns {void}\n */\n _update () {\n this._timeout = null\n if (this._queue.length) {\n let last\n for (last of this._queue) {\n this._applyOp(last)\n }\n this._queue = []\n\n this._updateFrequency(last[2]) // contains timestamp of last op\n\n this.emit('update', this._stats)\n }\n }\n\n /**\n * For each key in the stats, the frequency and moving averages\n * will be updated via Stats._updateFrequencyFor based on the time\n * difference between calls to this method.\n *\n * @private\n * @param {Timestamp} latestTime\n * @returns {void}\n */\n _updateFrequency (latestTime) {\n const timeDiff = latestTime - this._frequencyLastTime\n\n Object.keys(this._stats).forEach((key) => {\n this._updateFrequencyFor(key, timeDiff, latestTime)\n })\n\n this._frequencyLastTime = latestTime\n }\n\n /**\n * Updates the `movingAverages` for the given `key` and also\n * resets the `frequencyAccumulator` for the `key`.\n *\n * @private\n * @param {string} key\n * @param {number} timeDiffMS - Time in milliseconds\n * @param {Timestamp} latestTime - Time in ticks\n * @returns {void}\n */\n _updateFrequencyFor (key, timeDiffMS, latestTime) {\n const count = this._frequencyAccumulators[key] || 0\n this._frequencyAccumulators[key] = 0\n // if `timeDiff` is zero, `hz` becomes Infinity, so we fallback to 1ms\n const safeTimeDiff = timeDiffMS || 1\n const hz = (count / safeTimeDiff) * 1000\n\n let movingAverages = this._movingAverages[key]\n if (!movingAverages) {\n movingAverages = this._movingAverages[key] = {}\n }\n\n const intervals = this._options.movingAverageIntervals\n\n for (let i = 0; i < intervals.length; i++) {\n const movingAverageInterval = intervals[i]\n let movingAverage = movingAverages[movingAverageInterval]\n if (!movingAverage) {\n movingAverage = movingAverages[movingAverageInterval] = MovingAverage(movingAverageInterval)\n }\n movingAverage.push(latestTime, hz)\n }\n }\n\n /**\n * For the given operation, `op`, the stats and `frequencyAccumulator`\n * will be updated or initialized if they don't already exist.\n *\n * @private\n * @param {{string, number}[]} op\n * @throws {InvalidNumber}\n * @returns {void}\n */\n _applyOp (op) {\n const key = op[0]\n const inc = op[1]\n\n if (typeof inc !== 'number') {\n throw new Error(`invalid increment number: ${inc}`)\n }\n\n let n\n\n if (!Object.prototype.hasOwnProperty.call(this._stats, key)) {\n n = this._stats[key] = Big(0)\n } else {\n n = this._stats[key]\n }\n this._stats[key] = n.plus(inc)\n\n if (!this._frequencyAccumulators[key]) {\n this._frequencyAccumulators[key] = 0\n }\n this._frequencyAccumulators[key] += inc\n }\n}\n\nmodule.exports = Stats\n",";(function (globalObject) {\r\n 'use strict';\r\n\r\n/*\r\n * bignumber.js v9.0.1\r\n * A JavaScript library for arbitrary-precision arithmetic.\r\n * https://github.com/MikeMcl/bignumber.js\r\n * Copyright (c) 2020 Michael Mclaughlin \r\n * MIT Licensed.\r\n *\r\n * BigNumber.prototype methods | BigNumber methods\r\n * |\r\n * absoluteValue abs | clone\r\n * comparedTo | config set\r\n * decimalPlaces dp | DECIMAL_PLACES\r\n * dividedBy div | ROUNDING_MODE\r\n * dividedToIntegerBy idiv | EXPONENTIAL_AT\r\n * exponentiatedBy pow | RANGE\r\n * integerValue | CRYPTO\r\n * isEqualTo eq | MODULO_MODE\r\n * isFinite | POW_PRECISION\r\n * isGreaterThan gt | FORMAT\r\n * isGreaterThanOrEqualTo gte | ALPHABET\r\n * isInteger | isBigNumber\r\n * isLessThan lt | maximum max\r\n * isLessThanOrEqualTo lte | minimum min\r\n * isNaN | random\r\n * isNegative | sum\r\n * isPositive |\r\n * isZero |\r\n * minus |\r\n * modulo mod |\r\n * multipliedBy times |\r\n * negated |\r\n * plus |\r\n * precision sd |\r\n * shiftedBy |\r\n * squareRoot sqrt |\r\n * toExponential |\r\n * toFixed |\r\n * toFormat |\r\n * toFraction |\r\n * toJSON |\r\n * toNumber |\r\n * toPrecision |\r\n * toString |\r\n * valueOf |\r\n *\r\n */\r\n\r\n\r\n var BigNumber,\r\n isNumeric = /^-?(?:\\d+(?:\\.\\d*)?|\\.\\d+)(?:e[+-]?\\d+)?$/i,\r\n mathceil = Math.ceil,\r\n mathfloor = Math.floor,\r\n\r\n bignumberError = '[BigNumber Error] ',\r\n tooManyDigits = bignumberError + 'Number primitive has more than 15 significant digits: ',\r\n\r\n BASE = 1e14,\r\n LOG_BASE = 14,\r\n MAX_SAFE_INTEGER = 0x1fffffffffffff, // 2^53 - 1\r\n // MAX_INT32 = 0x7fffffff, // 2^31 - 1\r\n POWS_TEN = [1, 10, 100, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9, 1e10, 1e11, 1e12, 1e13],\r\n SQRT_BASE = 1e7,\r\n\r\n // EDITABLE\r\n // The limit on the value of DECIMAL_PLACES, TO_EXP_NEG, TO_EXP_POS, MIN_EXP, MAX_EXP, and\r\n // the arguments to toExponential, toFixed, toFormat, and toPrecision.\r\n MAX = 1E9; // 0 to MAX_INT32\r\n\r\n\r\n /*\r\n * Create and return a BigNumber constructor.\r\n */\r\n function clone(configObject) {\r\n var div, convertBase, parseNumeric,\r\n P = BigNumber.prototype = { constructor: BigNumber, toString: null, valueOf: null },\r\n ONE = new BigNumber(1),\r\n\r\n\r\n //----------------------------- EDITABLE CONFIG DEFAULTS -------------------------------\r\n\r\n\r\n // The default values below must be integers within the inclusive ranges stated.\r\n // The values can also be changed at run-time using BigNumber.set.\r\n\r\n // The maximum number of decimal places for operations involving division.\r\n DECIMAL_PLACES = 20, // 0 to MAX\r\n\r\n // The rounding mode used when rounding to the above decimal places, and when using\r\n // toExponential, toFixed, toFormat and toPrecision, and round (default value).\r\n // UP 0 Away from zero.\r\n // DOWN 1 Towards zero.\r\n // CEIL 2 Towards +Infinity.\r\n // FLOOR 3 Towards -Infinity.\r\n // HALF_UP 4 Towards nearest neighbour. If equidistant, up.\r\n // HALF_DOWN 5 Towards nearest neighbour. If equidistant, down.\r\n // HALF_EVEN 6 Towards nearest neighbour. If equidistant, towards even neighbour.\r\n // HALF_CEIL 7 Towards nearest neighbour. If equidistant, towards +Infinity.\r\n // HALF_FLOOR 8 Towards nearest neighbour. If equidistant, towards -Infinity.\r\n ROUNDING_MODE = 4, // 0 to 8\r\n\r\n // EXPONENTIAL_AT : [TO_EXP_NEG , TO_EXP_POS]\r\n\r\n // The exponent value at and beneath which toString returns exponential notation.\r\n // Number type: -7\r\n TO_EXP_NEG = -7, // 0 to -MAX\r\n\r\n // The exponent value at and above which toString returns exponential notation.\r\n // Number type: 21\r\n TO_EXP_POS = 21, // 0 to MAX\r\n\r\n // RANGE : [MIN_EXP, MAX_EXP]\r\n\r\n // The minimum exponent value, beneath which underflow to zero occurs.\r\n // Number type: -324 (5e-324)\r\n MIN_EXP = -1e7, // -1 to -MAX\r\n\r\n // The maximum exponent value, above which overflow to Infinity occurs.\r\n // Number type: 308 (1.7976931348623157e+308)\r\n // For MAX_EXP > 1e7, e.g. new BigNumber('1e100000000').plus(1) may be slow.\r\n MAX_EXP = 1e7, // 1 to MAX\r\n\r\n // Whether to use cryptographically-secure random number generation, if available.\r\n CRYPTO = false, // true or false\r\n\r\n // The modulo mode used when calculating the modulus: a mod n.\r\n // The quotient (q = a / n) is calculated according to the corresponding rounding mode.\r\n // The remainder (r) is calculated as: r = a - n * q.\r\n //\r\n // UP 0 The remainder is positive if the dividend is negative, else is negative.\r\n // DOWN 1 The remainder has the same sign as the dividend.\r\n // This modulo mode is commonly known as 'truncated division' and is\r\n // equivalent to (a % n) in JavaScript.\r\n // FLOOR 3 The remainder has the same sign as the divisor (Python %).\r\n // HALF_EVEN 6 This modulo mode implements the IEEE 754 remainder function.\r\n // EUCLID 9 Euclidian division. q = sign(n) * floor(a / abs(n)).\r\n // The remainder is always positive.\r\n //\r\n // The truncated division, floored division, Euclidian division and IEEE 754 remainder\r\n // modes are commonly used for the modulus operation.\r\n // Although the other rounding modes can also be used, they may not give useful results.\r\n MODULO_MODE = 1, // 0 to 9\r\n\r\n // The maximum number of significant digits of the result of the exponentiatedBy operation.\r\n // If POW_PRECISION is 0, there will be unlimited significant digits.\r\n POW_PRECISION = 0, // 0 to MAX\r\n\r\n // The format specification used by the BigNumber.prototype.toFormat method.\r\n FORMAT = {\r\n prefix: '',\r\n groupSize: 3,\r\n secondaryGroupSize: 0,\r\n groupSeparator: ',',\r\n decimalSeparator: '.',\r\n fractionGroupSize: 0,\r\n fractionGroupSeparator: '\\xA0', // non-breaking space\r\n suffix: ''\r\n },\r\n\r\n // The alphabet used for base conversion. It must be at least 2 characters long, with no '+',\r\n // '-', '.', whitespace, or repeated character.\r\n // '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ$_'\r\n ALPHABET = '0123456789abcdefghijklmnopqrstuvwxyz';\r\n\r\n\r\n //------------------------------------------------------------------------------------------\r\n\r\n\r\n // CONSTRUCTOR\r\n\r\n\r\n /*\r\n * The BigNumber constructor and exported function.\r\n * Create and return a new instance of a BigNumber object.\r\n *\r\n * v {number|string|BigNumber} A numeric value.\r\n * [b] {number} The base of v. Integer, 2 to ALPHABET.length inclusive.\r\n */\r\n function BigNumber(v, b) {\r\n var alphabet, c, caseChanged, e, i, isNum, len, str,\r\n x = this;\r\n\r\n // Enable constructor call without `new`.\r\n if (!(x instanceof BigNumber)) return new BigNumber(v, b);\r\n\r\n if (b == null) {\r\n\r\n if (v && v._isBigNumber === true) {\r\n x.s = v.s;\r\n\r\n if (!v.c || v.e > MAX_EXP) {\r\n x.c = x.e = null;\r\n } else if (v.e < MIN_EXP) {\r\n x.c = [x.e = 0];\r\n } else {\r\n x.e = v.e;\r\n x.c = v.c.slice();\r\n }\r\n\r\n return;\r\n }\r\n\r\n if ((isNum = typeof v == 'number') && v * 0 == 0) {\r\n\r\n // Use `1 / n` to handle minus zero also.\r\n x.s = 1 / v < 0 ? (v = -v, -1) : 1;\r\n\r\n // Fast path for integers, where n < 2147483648 (2**31).\r\n if (v === ~~v) {\r\n for (e = 0, i = v; i >= 10; i /= 10, e++);\r\n\r\n if (e > MAX_EXP) {\r\n x.c = x.e = null;\r\n } else {\r\n x.e = e;\r\n x.c = [v];\r\n }\r\n\r\n return;\r\n }\r\n\r\n str = String(v);\r\n } else {\r\n\r\n if (!isNumeric.test(str = String(v))) return parseNumeric(x, str, isNum);\r\n\r\n x.s = str.charCodeAt(0) == 45 ? (str = str.slice(1), -1) : 1;\r\n }\r\n\r\n // Decimal point?\r\n if ((e = str.indexOf('.')) > -1) str = str.replace('.', '');\r\n\r\n // Exponential form?\r\n if ((i = str.search(/e/i)) > 0) {\r\n\r\n // Determine exponent.\r\n if (e < 0) e = i;\r\n e += +str.slice(i + 1);\r\n str = str.substring(0, i);\r\n } else if (e < 0) {\r\n\r\n // Integer.\r\n e = str.length;\r\n }\r\n\r\n } else {\r\n\r\n // '[BigNumber Error] Base {not a primitive number|not an integer|out of range}: {b}'\r\n intCheck(b, 2, ALPHABET.length, 'Base');\r\n\r\n // Allow exponential notation to be used with base 10 argument, while\r\n // also rounding to DECIMAL_PLACES as with other bases.\r\n if (b == 10) {\r\n x = new BigNumber(v);\r\n return round(x, DECIMAL_PLACES + x.e + 1, ROUNDING_MODE);\r\n }\r\n\r\n str = String(v);\r\n\r\n if (isNum = typeof v == 'number') {\r\n\r\n // Avoid potential interpretation of Infinity and NaN as base 44+ values.\r\n if (v * 0 != 0) return parseNumeric(x, str, isNum, b);\r\n\r\n x.s = 1 / v < 0 ? (str = str.slice(1), -1) : 1;\r\n\r\n // '[BigNumber Error] Number primitive has more than 15 significant digits: {n}'\r\n if (BigNumber.DEBUG && str.replace(/^0\\.0*|\\./, '').length > 15) {\r\n throw Error\r\n (tooManyDigits + v);\r\n }\r\n } else {\r\n x.s = str.charCodeAt(0) === 45 ? (str = str.slice(1), -1) : 1;\r\n }\r\n\r\n alphabet = ALPHABET.slice(0, b);\r\n e = i = 0;\r\n\r\n // Check that str is a valid base b number.\r\n // Don't use RegExp, so alphabet can contain special characters.\r\n for (len = str.length; i < len; i++) {\r\n if (alphabet.indexOf(c = str.charAt(i)) < 0) {\r\n if (c == '.') {\r\n\r\n // If '.' is not the first character and it has not be found before.\r\n if (i > e) {\r\n e = len;\r\n continue;\r\n }\r\n } else if (!caseChanged) {\r\n\r\n // Allow e.g. hexadecimal 'FF' as well as 'ff'.\r\n if (str == str.toUpperCase() && (str = str.toLowerCase()) ||\r\n str == str.toLowerCase() && (str = str.toUpperCase())) {\r\n caseChanged = true;\r\n i = -1;\r\n e = 0;\r\n continue;\r\n }\r\n }\r\n\r\n return parseNumeric(x, String(v), isNum, b);\r\n }\r\n }\r\n\r\n // Prevent later check for length on converted number.\r\n isNum = false;\r\n str = convertBase(str, b, 10, x.s);\r\n\r\n // Decimal point?\r\n if ((e = str.indexOf('.')) > -1) str = str.replace('.', '');\r\n else e = str.length;\r\n }\r\n\r\n // Determine leading zeros.\r\n for (i = 0; str.charCodeAt(i) === 48; i++);\r\n\r\n // Determine trailing zeros.\r\n for (len = str.length; str.charCodeAt(--len) === 48;);\r\n\r\n if (str = str.slice(i, ++len)) {\r\n len -= i;\r\n\r\n // '[BigNumber Error] Number primitive has more than 15 significant digits: {n}'\r\n if (isNum && BigNumber.DEBUG &&\r\n len > 15 && (v > MAX_SAFE_INTEGER || v !== mathfloor(v))) {\r\n throw Error\r\n (tooManyDigits + (x.s * v));\r\n }\r\n\r\n // Overflow?\r\n if ((e = e - i - 1) > MAX_EXP) {\r\n\r\n // Infinity.\r\n x.c = x.e = null;\r\n\r\n // Underflow?\r\n } else if (e < MIN_EXP) {\r\n\r\n // Zero.\r\n x.c = [x.e = 0];\r\n } else {\r\n x.e = e;\r\n x.c = [];\r\n\r\n // Transform base\r\n\r\n // e is the base 10 exponent.\r\n // i is where to slice str to get the first element of the coefficient array.\r\n i = (e + 1) % LOG_BASE;\r\n if (e < 0) i += LOG_BASE; // i < 1\r\n\r\n if (i < len) {\r\n if (i) x.c.push(+str.slice(0, i));\r\n\r\n for (len -= LOG_BASE; i < len;) {\r\n x.c.push(+str.slice(i, i += LOG_BASE));\r\n }\r\n\r\n i = LOG_BASE - (str = str.slice(i)).length;\r\n } else {\r\n i -= len;\r\n }\r\n\r\n for (; i--; str += '0');\r\n x.c.push(+str);\r\n }\r\n } else {\r\n\r\n // Zero.\r\n x.c = [x.e = 0];\r\n }\r\n }\r\n\r\n\r\n // CONSTRUCTOR PROPERTIES\r\n\r\n\r\n BigNumber.clone = clone;\r\n\r\n BigNumber.ROUND_UP = 0;\r\n BigNumber.ROUND_DOWN = 1;\r\n BigNumber.ROUND_CEIL = 2;\r\n BigNumber.ROUND_FLOOR = 3;\r\n BigNumber.ROUND_HALF_UP = 4;\r\n BigNumber.ROUND_HALF_DOWN = 5;\r\n BigNumber.ROUND_HALF_EVEN = 6;\r\n BigNumber.ROUND_HALF_CEIL = 7;\r\n BigNumber.ROUND_HALF_FLOOR = 8;\r\n BigNumber.EUCLID = 9;\r\n\r\n\r\n /*\r\n * Configure infrequently-changing library-wide settings.\r\n *\r\n * Accept an object with the following optional properties (if the value of a property is\r\n * a number, it must be an integer within the inclusive range stated):\r\n *\r\n * DECIMAL_PLACES {number} 0 to MAX\r\n * ROUNDING_MODE {number} 0 to 8\r\n * EXPONENTIAL_AT {number|number[]} -MAX to MAX or [-MAX to 0, 0 to MAX]\r\n * RANGE {number|number[]} -MAX to MAX (not zero) or [-MAX to -1, 1 to MAX]\r\n * CRYPTO {boolean} true or false\r\n * MODULO_MODE {number} 0 to 9\r\n * POW_PRECISION {number} 0 to MAX\r\n * ALPHABET {string} A string of two or more unique characters which does\r\n * not contain '.'.\r\n * FORMAT {object} An object with some of the following properties:\r\n * prefix {string}\r\n * groupSize {number}\r\n * secondaryGroupSize {number}\r\n * groupSeparator {string}\r\n * decimalSeparator {string}\r\n * fractionGroupSize {number}\r\n * fractionGroupSeparator {string}\r\n * suffix {string}\r\n *\r\n * (The values assigned to the above FORMAT object properties are not checked for validity.)\r\n *\r\n * E.g.\r\n * BigNumber.config({ DECIMAL_PLACES : 20, ROUNDING_MODE : 4 })\r\n *\r\n * Ignore properties/parameters set to null or undefined, except for ALPHABET.\r\n *\r\n * Return an object with the properties current values.\r\n */\r\n BigNumber.config = BigNumber.set = function (obj) {\r\n var p, v;\r\n\r\n if (obj != null) {\r\n\r\n if (typeof obj == 'object') {\r\n\r\n // DECIMAL_PLACES {number} Integer, 0 to MAX inclusive.\r\n // '[BigNumber Error] DECIMAL_PLACES {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'DECIMAL_PLACES')) {\r\n v = obj[p];\r\n intCheck(v, 0, MAX, p);\r\n DECIMAL_PLACES = v;\r\n }\r\n\r\n // ROUNDING_MODE {number} Integer, 0 to 8 inclusive.\r\n // '[BigNumber Error] ROUNDING_MODE {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'ROUNDING_MODE')) {\r\n v = obj[p];\r\n intCheck(v, 0, 8, p);\r\n ROUNDING_MODE = v;\r\n }\r\n\r\n // EXPONENTIAL_AT {number|number[]}\r\n // Integer, -MAX to MAX inclusive or\r\n // [integer -MAX to 0 inclusive, 0 to MAX inclusive].\r\n // '[BigNumber Error] EXPONENTIAL_AT {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'EXPONENTIAL_AT')) {\r\n v = obj[p];\r\n if (v && v.pop) {\r\n intCheck(v[0], -MAX, 0, p);\r\n intCheck(v[1], 0, MAX, p);\r\n TO_EXP_NEG = v[0];\r\n TO_EXP_POS = v[1];\r\n } else {\r\n intCheck(v, -MAX, MAX, p);\r\n TO_EXP_NEG = -(TO_EXP_POS = v < 0 ? -v : v);\r\n }\r\n }\r\n\r\n // RANGE {number|number[]} Non-zero integer, -MAX to MAX inclusive or\r\n // [integer -MAX to -1 inclusive, integer 1 to MAX inclusive].\r\n // '[BigNumber Error] RANGE {not a primitive number|not an integer|out of range|cannot be zero}: {v}'\r\n if (obj.hasOwnProperty(p = 'RANGE')) {\r\n v = obj[p];\r\n if (v && v.pop) {\r\n intCheck(v[0], -MAX, -1, p);\r\n intCheck(v[1], 1, MAX, p);\r\n MIN_EXP = v[0];\r\n MAX_EXP = v[1];\r\n } else {\r\n intCheck(v, -MAX, MAX, p);\r\n if (v) {\r\n MIN_EXP = -(MAX_EXP = v < 0 ? -v : v);\r\n } else {\r\n throw Error\r\n (bignumberError + p + ' cannot be zero: ' + v);\r\n }\r\n }\r\n }\r\n\r\n // CRYPTO {boolean} true or false.\r\n // '[BigNumber Error] CRYPTO not true or false: {v}'\r\n // '[BigNumber Error] crypto unavailable'\r\n if (obj.hasOwnProperty(p = 'CRYPTO')) {\r\n v = obj[p];\r\n if (v === !!v) {\r\n if (v) {\r\n if (typeof crypto != 'undefined' && crypto &&\r\n (crypto.getRandomValues || crypto.randomBytes)) {\r\n CRYPTO = v;\r\n } else {\r\n CRYPTO = !v;\r\n throw Error\r\n (bignumberError + 'crypto unavailable');\r\n }\r\n } else {\r\n CRYPTO = v;\r\n }\r\n } else {\r\n throw Error\r\n (bignumberError + p + ' not true or false: ' + v);\r\n }\r\n }\r\n\r\n // MODULO_MODE {number} Integer, 0 to 9 inclusive.\r\n // '[BigNumber Error] MODULO_MODE {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'MODULO_MODE')) {\r\n v = obj[p];\r\n intCheck(v, 0, 9, p);\r\n MODULO_MODE = v;\r\n }\r\n\r\n // POW_PRECISION {number} Integer, 0 to MAX inclusive.\r\n // '[BigNumber Error] POW_PRECISION {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'POW_PRECISION')) {\r\n v = obj[p];\r\n intCheck(v, 0, MAX, p);\r\n POW_PRECISION = v;\r\n }\r\n\r\n // FORMAT {object}\r\n // '[BigNumber Error] FORMAT not an object: {v}'\r\n if (obj.hasOwnProperty(p = 'FORMAT')) {\r\n v = obj[p];\r\n if (typeof v == 'object') FORMAT = v;\r\n else throw Error\r\n (bignumberError + p + ' not an object: ' + v);\r\n }\r\n\r\n // ALPHABET {string}\r\n // '[BigNumber Error] ALPHABET invalid: {v}'\r\n if (obj.hasOwnProperty(p = 'ALPHABET')) {\r\n v = obj[p];\r\n\r\n // Disallow if less than two characters,\r\n // or if it contains '+', '-', '.', whitespace, or a repeated character.\r\n if (typeof v == 'string' && !/^.?$|[+\\-.\\s]|(.).*\\1/.test(v)) {\r\n ALPHABET = v;\r\n } else {\r\n throw Error\r\n (bignumberError + p + ' invalid: ' + v);\r\n }\r\n }\r\n\r\n } else {\r\n\r\n // '[BigNumber Error] Object expected: {v}'\r\n throw Error\r\n (bignumberError + 'Object expected: ' + obj);\r\n }\r\n }\r\n\r\n return {\r\n DECIMAL_PLACES: DECIMAL_PLACES,\r\n ROUNDING_MODE: ROUNDING_MODE,\r\n EXPONENTIAL_AT: [TO_EXP_NEG, TO_EXP_POS],\r\n RANGE: [MIN_EXP, MAX_EXP],\r\n CRYPTO: CRYPTO,\r\n MODULO_MODE: MODULO_MODE,\r\n POW_PRECISION: POW_PRECISION,\r\n FORMAT: FORMAT,\r\n ALPHABET: ALPHABET\r\n };\r\n };\r\n\r\n\r\n /*\r\n * Return true if v is a BigNumber instance, otherwise return false.\r\n *\r\n * If BigNumber.DEBUG is true, throw if a BigNumber instance is not well-formed.\r\n *\r\n * v {any}\r\n *\r\n * '[BigNumber Error] Invalid BigNumber: {v}'\r\n */\r\n BigNumber.isBigNumber = function (v) {\r\n if (!v || v._isBigNumber !== true) return false;\r\n if (!BigNumber.DEBUG) return true;\r\n\r\n var i, n,\r\n c = v.c,\r\n e = v.e,\r\n s = v.s;\r\n\r\n out: if ({}.toString.call(c) == '[object Array]') {\r\n\r\n if ((s === 1 || s === -1) && e >= -MAX && e <= MAX && e === mathfloor(e)) {\r\n\r\n // If the first element is zero, the BigNumber value must be zero.\r\n if (c[0] === 0) {\r\n if (e === 0 && c.length === 1) return true;\r\n break out;\r\n }\r\n\r\n // Calculate number of digits that c[0] should have, based on the exponent.\r\n i = (e + 1) % LOG_BASE;\r\n if (i < 1) i += LOG_BASE;\r\n\r\n // Calculate number of digits of c[0].\r\n //if (Math.ceil(Math.log(c[0] + 1) / Math.LN10) == i) {\r\n if (String(c[0]).length == i) {\r\n\r\n for (i = 0; i < c.length; i++) {\r\n n = c[i];\r\n if (n < 0 || n >= BASE || n !== mathfloor(n)) break out;\r\n }\r\n\r\n // Last element cannot be zero, unless it is the only element.\r\n if (n !== 0) return true;\r\n }\r\n }\r\n\r\n // Infinity/NaN\r\n } else if (c === null && e === null && (s === null || s === 1 || s === -1)) {\r\n return true;\r\n }\r\n\r\n throw Error\r\n (bignumberError + 'Invalid BigNumber: ' + v);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the maximum of the arguments.\r\n *\r\n * arguments {number|string|BigNumber}\r\n */\r\n BigNumber.maximum = BigNumber.max = function () {\r\n return maxOrMin(arguments, P.lt);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the minimum of the arguments.\r\n *\r\n * arguments {number|string|BigNumber}\r\n */\r\n BigNumber.minimum = BigNumber.min = function () {\r\n return maxOrMin(arguments, P.gt);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber with a random value equal to or greater than 0 and less than 1,\r\n * and with dp, or DECIMAL_PLACES if dp is omitted, decimal places (or less if trailing\r\n * zeros are produced).\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp}'\r\n * '[BigNumber Error] crypto unavailable'\r\n */\r\n BigNumber.random = (function () {\r\n var pow2_53 = 0x20000000000000;\r\n\r\n // Return a 53 bit integer n, where 0 <= n < 9007199254740992.\r\n // Check if Math.random() produces more than 32 bits of randomness.\r\n // If it does, assume at least 53 bits are produced, otherwise assume at least 30 bits.\r\n // 0x40000000 is 2^30, 0x800000 is 2^23, 0x1fffff is 2^21 - 1.\r\n var random53bitInt = (Math.random() * pow2_53) & 0x1fffff\r\n ? function () { return mathfloor(Math.random() * pow2_53); }\r\n : function () { return ((Math.random() * 0x40000000 | 0) * 0x800000) +\r\n (Math.random() * 0x800000 | 0); };\r\n\r\n return function (dp) {\r\n var a, b, e, k, v,\r\n i = 0,\r\n c = [],\r\n rand = new BigNumber(ONE);\r\n\r\n if (dp == null) dp = DECIMAL_PLACES;\r\n else intCheck(dp, 0, MAX);\r\n\r\n k = mathceil(dp / LOG_BASE);\r\n\r\n if (CRYPTO) {\r\n\r\n // Browsers supporting crypto.getRandomValues.\r\n if (crypto.getRandomValues) {\r\n\r\n a = crypto.getRandomValues(new Uint32Array(k *= 2));\r\n\r\n for (; i < k;) {\r\n\r\n // 53 bits:\r\n // ((Math.pow(2, 32) - 1) * Math.pow(2, 21)).toString(2)\r\n // 11111 11111111 11111111 11111111 11100000 00000000 00000000\r\n // ((Math.pow(2, 32) - 1) >>> 11).toString(2)\r\n // 11111 11111111 11111111\r\n // 0x20000 is 2^21.\r\n v = a[i] * 0x20000 + (a[i + 1] >>> 11);\r\n\r\n // Rejection sampling:\r\n // 0 <= v < 9007199254740992\r\n // Probability that v >= 9e15, is\r\n // 7199254740992 / 9007199254740992 ~= 0.0008, i.e. 1 in 1251\r\n if (v >= 9e15) {\r\n b = crypto.getRandomValues(new Uint32Array(2));\r\n a[i] = b[0];\r\n a[i + 1] = b[1];\r\n } else {\r\n\r\n // 0 <= v <= 8999999999999999\r\n // 0 <= (v % 1e14) <= 99999999999999\r\n c.push(v % 1e14);\r\n i += 2;\r\n }\r\n }\r\n i = k / 2;\r\n\r\n // Node.js supporting crypto.randomBytes.\r\n } else if (crypto.randomBytes) {\r\n\r\n // buffer\r\n a = crypto.randomBytes(k *= 7);\r\n\r\n for (; i < k;) {\r\n\r\n // 0x1000000000000 is 2^48, 0x10000000000 is 2^40\r\n // 0x100000000 is 2^32, 0x1000000 is 2^24\r\n // 11111 11111111 11111111 11111111 11111111 11111111 11111111\r\n // 0 <= v < 9007199254740992\r\n v = ((a[i] & 31) * 0x1000000000000) + (a[i + 1] * 0x10000000000) +\r\n (a[i + 2] * 0x100000000) + (a[i + 3] * 0x1000000) +\r\n (a[i + 4] << 16) + (a[i + 5] << 8) + a[i + 6];\r\n\r\n if (v >= 9e15) {\r\n crypto.randomBytes(7).copy(a, i);\r\n } else {\r\n\r\n // 0 <= (v % 1e14) <= 99999999999999\r\n c.push(v % 1e14);\r\n i += 7;\r\n }\r\n }\r\n i = k / 7;\r\n } else {\r\n CRYPTO = false;\r\n throw Error\r\n (bignumberError + 'crypto unavailable');\r\n }\r\n }\r\n\r\n // Use Math.random.\r\n if (!CRYPTO) {\r\n\r\n for (; i < k;) {\r\n v = random53bitInt();\r\n if (v < 9e15) c[i++] = v % 1e14;\r\n }\r\n }\r\n\r\n k = c[--i];\r\n dp %= LOG_BASE;\r\n\r\n // Convert trailing digits to zeros according to dp.\r\n if (k && dp) {\r\n v = POWS_TEN[LOG_BASE - dp];\r\n c[i] = mathfloor(k / v) * v;\r\n }\r\n\r\n // Remove trailing elements which are zero.\r\n for (; c[i] === 0; c.pop(), i--);\r\n\r\n // Zero?\r\n if (i < 0) {\r\n c = [e = 0];\r\n } else {\r\n\r\n // Remove leading elements which are zero and adjust exponent accordingly.\r\n for (e = -1 ; c[0] === 0; c.splice(0, 1), e -= LOG_BASE);\r\n\r\n // Count the digits of the first element of c to determine leading zeros, and...\r\n for (i = 1, v = c[0]; v >= 10; v /= 10, i++);\r\n\r\n // adjust the exponent accordingly.\r\n if (i < LOG_BASE) e -= LOG_BASE - i;\r\n }\r\n\r\n rand.e = e;\r\n rand.c = c;\r\n return rand;\r\n };\r\n })();\r\n\r\n\r\n /*\r\n * Return a BigNumber whose value is the sum of the arguments.\r\n *\r\n * arguments {number|string|BigNumber}\r\n */\r\n BigNumber.sum = function () {\r\n var i = 1,\r\n args = arguments,\r\n sum = new BigNumber(args[0]);\r\n for (; i < args.length;) sum = sum.plus(args[i++]);\r\n return sum;\r\n };\r\n\r\n\r\n // PRIVATE FUNCTIONS\r\n\r\n\r\n // Called by BigNumber and BigNumber.prototype.toString.\r\n convertBase = (function () {\r\n var decimal = '0123456789';\r\n\r\n /*\r\n * Convert string of baseIn to an array of numbers of baseOut.\r\n * Eg. toBaseOut('255', 10, 16) returns [15, 15].\r\n * Eg. toBaseOut('ff', 16, 10) returns [2, 5, 5].\r\n */\r\n function toBaseOut(str, baseIn, baseOut, alphabet) {\r\n var j,\r\n arr = [0],\r\n arrL,\r\n i = 0,\r\n len = str.length;\r\n\r\n for (; i < len;) {\r\n for (arrL = arr.length; arrL--; arr[arrL] *= baseIn);\r\n\r\n arr[0] += alphabet.indexOf(str.charAt(i++));\r\n\r\n for (j = 0; j < arr.length; j++) {\r\n\r\n if (arr[j] > baseOut - 1) {\r\n if (arr[j + 1] == null) arr[j + 1] = 0;\r\n arr[j + 1] += arr[j] / baseOut | 0;\r\n arr[j] %= baseOut;\r\n }\r\n }\r\n }\r\n\r\n return arr.reverse();\r\n }\r\n\r\n // Convert a numeric string of baseIn to a numeric string of baseOut.\r\n // If the caller is toString, we are converting from base 10 to baseOut.\r\n // If the caller is BigNumber, we are converting from baseIn to base 10.\r\n return function (str, baseIn, baseOut, sign, callerIsToString) {\r\n var alphabet, d, e, k, r, x, xc, y,\r\n i = str.indexOf('.'),\r\n dp = DECIMAL_PLACES,\r\n rm = ROUNDING_MODE;\r\n\r\n // Non-integer.\r\n if (i >= 0) {\r\n k = POW_PRECISION;\r\n\r\n // Unlimited precision.\r\n POW_PRECISION = 0;\r\n str = str.replace('.', '');\r\n y = new BigNumber(baseIn);\r\n x = y.pow(str.length - i);\r\n POW_PRECISION = k;\r\n\r\n // Convert str as if an integer, then restore the fraction part by dividing the\r\n // result by its base raised to a power.\r\n\r\n y.c = toBaseOut(toFixedPoint(coeffToString(x.c), x.e, '0'),\r\n 10, baseOut, decimal);\r\n y.e = y.c.length;\r\n }\r\n\r\n // Convert the number as integer.\r\n\r\n xc = toBaseOut(str, baseIn, baseOut, callerIsToString\r\n ? (alphabet = ALPHABET, decimal)\r\n : (alphabet = decimal, ALPHABET));\r\n\r\n // xc now represents str as an integer and converted to baseOut. e is the exponent.\r\n e = k = xc.length;\r\n\r\n // Remove trailing zeros.\r\n for (; xc[--k] == 0; xc.pop());\r\n\r\n // Zero?\r\n if (!xc[0]) return alphabet.charAt(0);\r\n\r\n // Does str represent an integer? If so, no need for the division.\r\n if (i < 0) {\r\n --e;\r\n } else {\r\n x.c = xc;\r\n x.e = e;\r\n\r\n // The sign is needed for correct rounding.\r\n x.s = sign;\r\n x = div(x, y, dp, rm, baseOut);\r\n xc = x.c;\r\n r = x.r;\r\n e = x.e;\r\n }\r\n\r\n // xc now represents str converted to baseOut.\r\n\r\n // THe index of the rounding digit.\r\n d = e + dp + 1;\r\n\r\n // The rounding digit: the digit to the right of the digit that may be rounded up.\r\n i = xc[d];\r\n\r\n // Look at the rounding digits and mode to determine whether to round up.\r\n\r\n k = baseOut / 2;\r\n r = r || d < 0 || xc[d + 1] != null;\r\n\r\n r = rm < 4 ? (i != null || r) && (rm == 0 || rm == (x.s < 0 ? 3 : 2))\r\n : i > k || i == k &&(rm == 4 || r || rm == 6 && xc[d - 1] & 1 ||\r\n rm == (x.s < 0 ? 8 : 7));\r\n\r\n // If the index of the rounding digit is not greater than zero, or xc represents\r\n // zero, then the result of the base conversion is zero or, if rounding up, a value\r\n // such as 0.00001.\r\n if (d < 1 || !xc[0]) {\r\n\r\n // 1^-dp or 0\r\n str = r ? toFixedPoint(alphabet.charAt(1), -dp, alphabet.charAt(0)) : alphabet.charAt(0);\r\n } else {\r\n\r\n // Truncate xc to the required number of decimal places.\r\n xc.length = d;\r\n\r\n // Round up?\r\n if (r) {\r\n\r\n // Rounding up may mean the previous digit has to be rounded up and so on.\r\n for (--baseOut; ++xc[--d] > baseOut;) {\r\n xc[d] = 0;\r\n\r\n if (!d) {\r\n ++e;\r\n xc = [1].concat(xc);\r\n }\r\n }\r\n }\r\n\r\n // Determine trailing zeros.\r\n for (k = xc.length; !xc[--k];);\r\n\r\n // E.g. [4, 11, 15] becomes 4bf.\r\n for (i = 0, str = ''; i <= k; str += alphabet.charAt(xc[i++]));\r\n\r\n // Add leading zeros, decimal point and trailing zeros as required.\r\n str = toFixedPoint(str, e, alphabet.charAt(0));\r\n }\r\n\r\n // The caller will add the sign.\r\n return str;\r\n };\r\n })();\r\n\r\n\r\n // Perform division in the specified base. Called by div and convertBase.\r\n div = (function () {\r\n\r\n // Assume non-zero x and k.\r\n function multiply(x, k, base) {\r\n var m, temp, xlo, xhi,\r\n carry = 0,\r\n i = x.length,\r\n klo = k % SQRT_BASE,\r\n khi = k / SQRT_BASE | 0;\r\n\r\n for (x = x.slice(); i--;) {\r\n xlo = x[i] % SQRT_BASE;\r\n xhi = x[i] / SQRT_BASE | 0;\r\n m = khi * xlo + xhi * klo;\r\n temp = klo * xlo + ((m % SQRT_BASE) * SQRT_BASE) + carry;\r\n carry = (temp / base | 0) + (m / SQRT_BASE | 0) + khi * xhi;\r\n x[i] = temp % base;\r\n }\r\n\r\n if (carry) x = [carry].concat(x);\r\n\r\n return x;\r\n }\r\n\r\n function compare(a, b, aL, bL) {\r\n var i, cmp;\r\n\r\n if (aL != bL) {\r\n cmp = aL > bL ? 1 : -1;\r\n } else {\r\n\r\n for (i = cmp = 0; i < aL; i++) {\r\n\r\n if (a[i] != b[i]) {\r\n cmp = a[i] > b[i] ? 1 : -1;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return cmp;\r\n }\r\n\r\n function subtract(a, b, aL, base) {\r\n var i = 0;\r\n\r\n // Subtract b from a.\r\n for (; aL--;) {\r\n a[aL] -= i;\r\n i = a[aL] < b[aL] ? 1 : 0;\r\n a[aL] = i * base + a[aL] - b[aL];\r\n }\r\n\r\n // Remove leading zeros.\r\n for (; !a[0] && a.length > 1; a.splice(0, 1));\r\n }\r\n\r\n // x: dividend, y: divisor.\r\n return function (x, y, dp, rm, base) {\r\n var cmp, e, i, more, n, prod, prodL, q, qc, rem, remL, rem0, xi, xL, yc0,\r\n yL, yz,\r\n s = x.s == y.s ? 1 : -1,\r\n xc = x.c,\r\n yc = y.c;\r\n\r\n // Either NaN, Infinity or 0?\r\n if (!xc || !xc[0] || !yc || !yc[0]) {\r\n\r\n return new BigNumber(\r\n\r\n // Return NaN if either NaN, or both Infinity or 0.\r\n !x.s || !y.s || (xc ? yc && xc[0] == yc[0] : !yc) ? NaN :\r\n\r\n // Return ±0 if x is ±0 or y is ±Infinity, or return ±Infinity as y is ±0.\r\n xc && xc[0] == 0 || !yc ? s * 0 : s / 0\r\n );\r\n }\r\n\r\n q = new BigNumber(s);\r\n qc = q.c = [];\r\n e = x.e - y.e;\r\n s = dp + e + 1;\r\n\r\n if (!base) {\r\n base = BASE;\r\n e = bitFloor(x.e / LOG_BASE) - bitFloor(y.e / LOG_BASE);\r\n s = s / LOG_BASE | 0;\r\n }\r\n\r\n // Result exponent may be one less then the current value of e.\r\n // The coefficients of the BigNumbers from convertBase may have trailing zeros.\r\n for (i = 0; yc[i] == (xc[i] || 0); i++);\r\n\r\n if (yc[i] > (xc[i] || 0)) e--;\r\n\r\n if (s < 0) {\r\n qc.push(1);\r\n more = true;\r\n } else {\r\n xL = xc.length;\r\n yL = yc.length;\r\n i = 0;\r\n s += 2;\r\n\r\n // Normalise xc and yc so highest order digit of yc is >= base / 2.\r\n\r\n n = mathfloor(base / (yc[0] + 1));\r\n\r\n // Not necessary, but to handle odd bases where yc[0] == (base / 2) - 1.\r\n // if (n > 1 || n++ == 1 && yc[0] < base / 2) {\r\n if (n > 1) {\r\n yc = multiply(yc, n, base);\r\n xc = multiply(xc, n, base);\r\n yL = yc.length;\r\n xL = xc.length;\r\n }\r\n\r\n xi = yL;\r\n rem = xc.slice(0, yL);\r\n remL = rem.length;\r\n\r\n // Add zeros to make remainder as long as divisor.\r\n for (; remL < yL; rem[remL++] = 0);\r\n yz = yc.slice();\r\n yz = [0].concat(yz);\r\n yc0 = yc[0];\r\n if (yc[1] >= base / 2) yc0++;\r\n // Not necessary, but to prevent trial digit n > base, when using base 3.\r\n // else if (base == 3 && yc0 == 1) yc0 = 1 + 1e-15;\r\n\r\n do {\r\n n = 0;\r\n\r\n // Compare divisor and remainder.\r\n cmp = compare(yc, rem, yL, remL);\r\n\r\n // If divisor < remainder.\r\n if (cmp < 0) {\r\n\r\n // Calculate trial digit, n.\r\n\r\n rem0 = rem[0];\r\n if (yL != remL) rem0 = rem0 * base + (rem[1] || 0);\r\n\r\n // n is how many times the divisor goes into the current remainder.\r\n n = mathfloor(rem0 / yc0);\r\n\r\n // Algorithm:\r\n // product = divisor multiplied by trial digit (n).\r\n // Compare product and remainder.\r\n // If product is greater than remainder:\r\n // Subtract divisor from product, decrement trial digit.\r\n // Subtract product from remainder.\r\n // If product was less than remainder at the last compare:\r\n // Compare new remainder and divisor.\r\n // If remainder is greater than divisor:\r\n // Subtract divisor from remainder, increment trial digit.\r\n\r\n if (n > 1) {\r\n\r\n // n may be > base only when base is 3.\r\n if (n >= base) n = base - 1;\r\n\r\n // product = divisor * trial digit.\r\n prod = multiply(yc, n, base);\r\n prodL = prod.length;\r\n remL = rem.length;\r\n\r\n // Compare product and remainder.\r\n // If product > remainder then trial digit n too high.\r\n // n is 1 too high about 5% of the time, and is not known to have\r\n // ever been more than 1 too high.\r\n while (compare(prod, rem, prodL, remL) == 1) {\r\n n--;\r\n\r\n // Subtract divisor from product.\r\n subtract(prod, yL < prodL ? yz : yc, prodL, base);\r\n prodL = prod.length;\r\n cmp = 1;\r\n }\r\n } else {\r\n\r\n // n is 0 or 1, cmp is -1.\r\n // If n is 0, there is no need to compare yc and rem again below,\r\n // so change cmp to 1 to avoid it.\r\n // If n is 1, leave cmp as -1, so yc and rem are compared again.\r\n if (n == 0) {\r\n\r\n // divisor < remainder, so n must be at least 1.\r\n cmp = n = 1;\r\n }\r\n\r\n // product = divisor\r\n prod = yc.slice();\r\n prodL = prod.length;\r\n }\r\n\r\n if (prodL < remL) prod = [0].concat(prod);\r\n\r\n // Subtract product from remainder.\r\n subtract(rem, prod, remL, base);\r\n remL = rem.length;\r\n\r\n // If product was < remainder.\r\n if (cmp == -1) {\r\n\r\n // Compare divisor and new remainder.\r\n // If divisor < new remainder, subtract divisor from remainder.\r\n // Trial digit n too low.\r\n // n is 1 too low about 5% of the time, and very rarely 2 too low.\r\n while (compare(yc, rem, yL, remL) < 1) {\r\n n++;\r\n\r\n // Subtract divisor from remainder.\r\n subtract(rem, yL < remL ? yz : yc, remL, base);\r\n remL = rem.length;\r\n }\r\n }\r\n } else if (cmp === 0) {\r\n n++;\r\n rem = [0];\r\n } // else cmp === 1 and n will be 0\r\n\r\n // Add the next digit, n, to the result array.\r\n qc[i++] = n;\r\n\r\n // Update the remainder.\r\n if (rem[0]) {\r\n rem[remL++] = xc[xi] || 0;\r\n } else {\r\n rem = [xc[xi]];\r\n remL = 1;\r\n }\r\n } while ((xi++ < xL || rem[0] != null) && s--);\r\n\r\n more = rem[0] != null;\r\n\r\n // Leading zero?\r\n if (!qc[0]) qc.splice(0, 1);\r\n }\r\n\r\n if (base == BASE) {\r\n\r\n // To calculate q.e, first get the number of digits of qc[0].\r\n for (i = 1, s = qc[0]; s >= 10; s /= 10, i++);\r\n\r\n round(q, dp + (q.e = i + e * LOG_BASE - 1) + 1, rm, more);\r\n\r\n // Caller is convertBase.\r\n } else {\r\n q.e = e;\r\n q.r = +more;\r\n }\r\n\r\n return q;\r\n };\r\n })();\r\n\r\n\r\n /*\r\n * Return a string representing the value of BigNumber n in fixed-point or exponential\r\n * notation rounded to the specified decimal places or significant digits.\r\n *\r\n * n: a BigNumber.\r\n * i: the index of the last digit required (i.e. the digit that may be rounded up).\r\n * rm: the rounding mode.\r\n * id: 1 (toExponential) or 2 (toPrecision).\r\n */\r\n function format(n, i, rm, id) {\r\n var c0, e, ne, len, str;\r\n\r\n if (rm == null) rm = ROUNDING_MODE;\r\n else intCheck(rm, 0, 8);\r\n\r\n if (!n.c) return n.toString();\r\n\r\n c0 = n.c[0];\r\n ne = n.e;\r\n\r\n if (i == null) {\r\n str = coeffToString(n.c);\r\n str = id == 1 || id == 2 && (ne <= TO_EXP_NEG || ne >= TO_EXP_POS)\r\n ? toExponential(str, ne)\r\n : toFixedPoint(str, ne, '0');\r\n } else {\r\n n = round(new BigNumber(n), i, rm);\r\n\r\n // n.e may have changed if the value was rounded up.\r\n e = n.e;\r\n\r\n str = coeffToString(n.c);\r\n len = str.length;\r\n\r\n // toPrecision returns exponential notation if the number of significant digits\r\n // specified is less than the number of digits necessary to represent the integer\r\n // part of the value in fixed-point notation.\r\n\r\n // Exponential notation.\r\n if (id == 1 || id == 2 && (i <= e || e <= TO_EXP_NEG)) {\r\n\r\n // Append zeros?\r\n for (; len < i; str += '0', len++);\r\n str = toExponential(str, e);\r\n\r\n // Fixed-point notation.\r\n } else {\r\n i -= ne;\r\n str = toFixedPoint(str, e, '0');\r\n\r\n // Append zeros?\r\n if (e + 1 > len) {\r\n if (--i > 0) for (str += '.'; i--; str += '0');\r\n } else {\r\n i += e - len;\r\n if (i > 0) {\r\n if (e + 1 == len) str += '.';\r\n for (; i--; str += '0');\r\n }\r\n }\r\n }\r\n }\r\n\r\n return n.s < 0 && c0 ? '-' + str : str;\r\n }\r\n\r\n\r\n // Handle BigNumber.max and BigNumber.min.\r\n function maxOrMin(args, method) {\r\n var n,\r\n i = 1,\r\n m = new BigNumber(args[0]);\r\n\r\n for (; i < args.length; i++) {\r\n n = new BigNumber(args[i]);\r\n\r\n // If any number is NaN, return NaN.\r\n if (!n.s) {\r\n m = n;\r\n break;\r\n } else if (method.call(m, n)) {\r\n m = n;\r\n }\r\n }\r\n\r\n return m;\r\n }\r\n\r\n\r\n /*\r\n * Strip trailing zeros, calculate base 10 exponent and check against MIN_EXP and MAX_EXP.\r\n * Called by minus, plus and times.\r\n */\r\n function normalise(n, c, e) {\r\n var i = 1,\r\n j = c.length;\r\n\r\n // Remove trailing zeros.\r\n for (; !c[--j]; c.pop());\r\n\r\n // Calculate the base 10 exponent. First get the number of digits of c[0].\r\n for (j = c[0]; j >= 10; j /= 10, i++);\r\n\r\n // Overflow?\r\n if ((e = i + e * LOG_BASE - 1) > MAX_EXP) {\r\n\r\n // Infinity.\r\n n.c = n.e = null;\r\n\r\n // Underflow?\r\n } else if (e < MIN_EXP) {\r\n\r\n // Zero.\r\n n.c = [n.e = 0];\r\n } else {\r\n n.e = e;\r\n n.c = c;\r\n }\r\n\r\n return n;\r\n }\r\n\r\n\r\n // Handle values that fail the validity test in BigNumber.\r\n parseNumeric = (function () {\r\n var basePrefix = /^(-?)0([xbo])(?=\\w[\\w.]*$)/i,\r\n dotAfter = /^([^.]+)\\.$/,\r\n dotBefore = /^\\.([^.]+)$/,\r\n isInfinityOrNaN = /^-?(Infinity|NaN)$/,\r\n whitespaceOrPlus = /^\\s*\\+(?=[\\w.])|^\\s+|\\s+$/g;\r\n\r\n return function (x, str, isNum, b) {\r\n var base,\r\n s = isNum ? str : str.replace(whitespaceOrPlus, '');\r\n\r\n // No exception on ±Infinity or NaN.\r\n if (isInfinityOrNaN.test(s)) {\r\n x.s = isNaN(s) ? null : s < 0 ? -1 : 1;\r\n } else {\r\n if (!isNum) {\r\n\r\n // basePrefix = /^(-?)0([xbo])(?=\\w[\\w.]*$)/i\r\n s = s.replace(basePrefix, function (m, p1, p2) {\r\n base = (p2 = p2.toLowerCase()) == 'x' ? 16 : p2 == 'b' ? 2 : 8;\r\n return !b || b == base ? p1 : m;\r\n });\r\n\r\n if (b) {\r\n base = b;\r\n\r\n // E.g. '1.' to '1', '.1' to '0.1'\r\n s = s.replace(dotAfter, '$1').replace(dotBefore, '0.$1');\r\n }\r\n\r\n if (str != s) return new BigNumber(s, base);\r\n }\r\n\r\n // '[BigNumber Error] Not a number: {n}'\r\n // '[BigNumber Error] Not a base {b} number: {n}'\r\n if (BigNumber.DEBUG) {\r\n throw Error\r\n (bignumberError + 'Not a' + (b ? ' base ' + b : '') + ' number: ' + str);\r\n }\r\n\r\n // NaN\r\n x.s = null;\r\n }\r\n\r\n x.c = x.e = null;\r\n }\r\n })();\r\n\r\n\r\n /*\r\n * Round x to sd significant digits using rounding mode rm. Check for over/under-flow.\r\n * If r is truthy, it is known that there are more digits after the rounding digit.\r\n */\r\n function round(x, sd, rm, r) {\r\n var d, i, j, k, n, ni, rd,\r\n xc = x.c,\r\n pows10 = POWS_TEN;\r\n\r\n // if x is not Infinity or NaN...\r\n if (xc) {\r\n\r\n // rd is the rounding digit, i.e. the digit after the digit that may be rounded up.\r\n // n is a base 1e14 number, the value of the element of array x.c containing rd.\r\n // ni is the index of n within x.c.\r\n // d is the number of digits of n.\r\n // i is the index of rd within n including leading zeros.\r\n // j is the actual index of rd within n (if < 0, rd is a leading zero).\r\n out: {\r\n\r\n // Get the number of digits of the first element of xc.\r\n for (d = 1, k = xc[0]; k >= 10; k /= 10, d++);\r\n i = sd - d;\r\n\r\n // If the rounding digit is in the first element of xc...\r\n if (i < 0) {\r\n i += LOG_BASE;\r\n j = sd;\r\n n = xc[ni = 0];\r\n\r\n // Get the rounding digit at index j of n.\r\n rd = n / pows10[d - j - 1] % 10 | 0;\r\n } else {\r\n ni = mathceil((i + 1) / LOG_BASE);\r\n\r\n if (ni >= xc.length) {\r\n\r\n if (r) {\r\n\r\n // Needed by sqrt.\r\n for (; xc.length <= ni; xc.push(0));\r\n n = rd = 0;\r\n d = 1;\r\n i %= LOG_BASE;\r\n j = i - LOG_BASE + 1;\r\n } else {\r\n break out;\r\n }\r\n } else {\r\n n = k = xc[ni];\r\n\r\n // Get the number of digits of n.\r\n for (d = 1; k >= 10; k /= 10, d++);\r\n\r\n // Get the index of rd within n.\r\n i %= LOG_BASE;\r\n\r\n // Get the index of rd within n, adjusted for leading zeros.\r\n // The number of leading zeros of n is given by LOG_BASE - d.\r\n j = i - LOG_BASE + d;\r\n\r\n // Get the rounding digit at index j of n.\r\n rd = j < 0 ? 0 : n / pows10[d - j - 1] % 10 | 0;\r\n }\r\n }\r\n\r\n r = r || sd < 0 ||\r\n\r\n // Are there any non-zero digits after the rounding digit?\r\n // The expression n % pows10[d - j - 1] returns all digits of n to the right\r\n // of the digit at j, e.g. if n is 908714 and j is 2, the expression gives 714.\r\n xc[ni + 1] != null || (j < 0 ? n : n % pows10[d - j - 1]);\r\n\r\n r = rm < 4\r\n ? (rd || r) && (rm == 0 || rm == (x.s < 0 ? 3 : 2))\r\n : rd > 5 || rd == 5 && (rm == 4 || r || rm == 6 &&\r\n\r\n // Check whether the digit to the left of the rounding digit is odd.\r\n ((i > 0 ? j > 0 ? n / pows10[d - j] : 0 : xc[ni - 1]) % 10) & 1 ||\r\n rm == (x.s < 0 ? 8 : 7));\r\n\r\n if (sd < 1 || !xc[0]) {\r\n xc.length = 0;\r\n\r\n if (r) {\r\n\r\n // Convert sd to decimal places.\r\n sd -= x.e + 1;\r\n\r\n // 1, 0.1, 0.01, 0.001, 0.0001 etc.\r\n xc[0] = pows10[(LOG_BASE - sd % LOG_BASE) % LOG_BASE];\r\n x.e = -sd || 0;\r\n } else {\r\n\r\n // Zero.\r\n xc[0] = x.e = 0;\r\n }\r\n\r\n return x;\r\n }\r\n\r\n // Remove excess digits.\r\n if (i == 0) {\r\n xc.length = ni;\r\n k = 1;\r\n ni--;\r\n } else {\r\n xc.length = ni + 1;\r\n k = pows10[LOG_BASE - i];\r\n\r\n // E.g. 56700 becomes 56000 if 7 is the rounding digit.\r\n // j > 0 means i > number of leading zeros of n.\r\n xc[ni] = j > 0 ? mathfloor(n / pows10[d - j] % pows10[j]) * k : 0;\r\n }\r\n\r\n // Round up?\r\n if (r) {\r\n\r\n for (; ;) {\r\n\r\n // If the digit to be rounded up is in the first element of xc...\r\n if (ni == 0) {\r\n\r\n // i will be the length of xc[0] before k is added.\r\n for (i = 1, j = xc[0]; j >= 10; j /= 10, i++);\r\n j = xc[0] += k;\r\n for (k = 1; j >= 10; j /= 10, k++);\r\n\r\n // if i != k the length has increased.\r\n if (i != k) {\r\n x.e++;\r\n if (xc[0] == BASE) xc[0] = 1;\r\n }\r\n\r\n break;\r\n } else {\r\n xc[ni] += k;\r\n if (xc[ni] != BASE) break;\r\n xc[ni--] = 0;\r\n k = 1;\r\n }\r\n }\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (i = xc.length; xc[--i] === 0; xc.pop());\r\n }\r\n\r\n // Overflow? Infinity.\r\n if (x.e > MAX_EXP) {\r\n x.c = x.e = null;\r\n\r\n // Underflow? Zero.\r\n } else if (x.e < MIN_EXP) {\r\n x.c = [x.e = 0];\r\n }\r\n }\r\n\r\n return x;\r\n }\r\n\r\n\r\n function valueOf(n) {\r\n var str,\r\n e = n.e;\r\n\r\n if (e === null) return n.toString();\r\n\r\n str = coeffToString(n.c);\r\n\r\n str = e <= TO_EXP_NEG || e >= TO_EXP_POS\r\n ? toExponential(str, e)\r\n : toFixedPoint(str, e, '0');\r\n\r\n return n.s < 0 ? '-' + str : str;\r\n }\r\n\r\n\r\n // PROTOTYPE/INSTANCE METHODS\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the absolute value of this BigNumber.\r\n */\r\n P.absoluteValue = P.abs = function () {\r\n var x = new BigNumber(this);\r\n if (x.s < 0) x.s = 1;\r\n return x;\r\n };\r\n\r\n\r\n /*\r\n * Return\r\n * 1 if the value of this BigNumber is greater than the value of BigNumber(y, b),\r\n * -1 if the value of this BigNumber is less than the value of BigNumber(y, b),\r\n * 0 if they have the same value,\r\n * or null if the value of either is NaN.\r\n */\r\n P.comparedTo = function (y, b) {\r\n return compare(this, new BigNumber(y, b));\r\n };\r\n\r\n\r\n /*\r\n * If dp is undefined or null or true or false, return the number of decimal places of the\r\n * value of this BigNumber, or null if the value of this BigNumber is ±Infinity or NaN.\r\n *\r\n * Otherwise, if dp is a number, return a new BigNumber whose value is the value of this\r\n * BigNumber rounded to a maximum of dp decimal places using rounding mode rm, or\r\n * ROUNDING_MODE if rm is omitted.\r\n *\r\n * [dp] {number} Decimal places: integer, 0 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp|rm}'\r\n */\r\n P.decimalPlaces = P.dp = function (dp, rm) {\r\n var c, n, v,\r\n x = this;\r\n\r\n if (dp != null) {\r\n intCheck(dp, 0, MAX);\r\n if (rm == null) rm = ROUNDING_MODE;\r\n else intCheck(rm, 0, 8);\r\n\r\n return round(new BigNumber(x), dp + x.e + 1, rm);\r\n }\r\n\r\n if (!(c = x.c)) return null;\r\n n = ((v = c.length - 1) - bitFloor(this.e / LOG_BASE)) * LOG_BASE;\r\n\r\n // Subtract the number of trailing zeros of the last number.\r\n if (v = c[v]) for (; v % 10 == 0; v /= 10, n--);\r\n if (n < 0) n = 0;\r\n\r\n return n;\r\n };\r\n\r\n\r\n /*\r\n * n / 0 = I\r\n * n / N = N\r\n * n / I = 0\r\n * 0 / n = 0\r\n * 0 / 0 = N\r\n * 0 / N = N\r\n * 0 / I = 0\r\n * N / n = N\r\n * N / 0 = N\r\n * N / N = N\r\n * N / I = N\r\n * I / n = I\r\n * I / 0 = I\r\n * I / N = N\r\n * I / I = N\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber divided by the value of\r\n * BigNumber(y, b), rounded according to DECIMAL_PLACES and ROUNDING_MODE.\r\n */\r\n P.dividedBy = P.div = function (y, b) {\r\n return div(this, new BigNumber(y, b), DECIMAL_PLACES, ROUNDING_MODE);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the integer part of dividing the value of this\r\n * BigNumber by the value of BigNumber(y, b).\r\n */\r\n P.dividedToIntegerBy = P.idiv = function (y, b) {\r\n return div(this, new BigNumber(y, b), 0, 1);\r\n };\r\n\r\n\r\n /*\r\n * Return a BigNumber whose value is the value of this BigNumber exponentiated by n.\r\n *\r\n * If m is present, return the result modulo m.\r\n * If n is negative round according to DECIMAL_PLACES and ROUNDING_MODE.\r\n * If POW_PRECISION is non-zero and m is not present, round to POW_PRECISION using ROUNDING_MODE.\r\n *\r\n * The modular power operation works efficiently when x, n, and m are integers, otherwise it\r\n * is equivalent to calculating x.exponentiatedBy(n).modulo(m) with a POW_PRECISION of 0.\r\n *\r\n * n {number|string|BigNumber} The exponent. An integer.\r\n * [m] {number|string|BigNumber} The modulus.\r\n *\r\n * '[BigNumber Error] Exponent not an integer: {n}'\r\n */\r\n P.exponentiatedBy = P.pow = function (n, m) {\r\n var half, isModExp, i, k, more, nIsBig, nIsNeg, nIsOdd, y,\r\n x = this;\r\n\r\n n = new BigNumber(n);\r\n\r\n // Allow NaN and ±Infinity, but not other non-integers.\r\n if (n.c && !n.isInteger()) {\r\n throw Error\r\n (bignumberError + 'Exponent not an integer: ' + valueOf(n));\r\n }\r\n\r\n if (m != null) m = new BigNumber(m);\r\n\r\n // Exponent of MAX_SAFE_INTEGER is 15.\r\n nIsBig = n.e > 14;\r\n\r\n // If x is NaN, ±Infinity, ±0 or ±1, or n is ±Infinity, NaN or ±0.\r\n if (!x.c || !x.c[0] || x.c[0] == 1 && !x.e && x.c.length == 1 || !n.c || !n.c[0]) {\r\n\r\n // The sign of the result of pow when x is negative depends on the evenness of n.\r\n // If +n overflows to ±Infinity, the evenness of n would be not be known.\r\n y = new BigNumber(Math.pow(+valueOf(x), nIsBig ? 2 - isOdd(n) : +valueOf(n)));\r\n return m ? y.mod(m) : y;\r\n }\r\n\r\n nIsNeg = n.s < 0;\r\n\r\n if (m) {\r\n\r\n // x % m returns NaN if abs(m) is zero, or m is NaN.\r\n if (m.c ? !m.c[0] : !m.s) return new BigNumber(NaN);\r\n\r\n isModExp = !nIsNeg && x.isInteger() && m.isInteger();\r\n\r\n if (isModExp) x = x.mod(m);\r\n\r\n // Overflow to ±Infinity: >=2**1e10 or >=1.0000024**1e15.\r\n // Underflow to ±0: <=0.79**1e10 or <=0.9999975**1e15.\r\n } else if (n.e > 9 && (x.e > 0 || x.e < -1 || (x.e == 0\r\n // [1, 240000000]\r\n ? x.c[0] > 1 || nIsBig && x.c[1] >= 24e7\r\n // [80000000000000] [99999750000000]\r\n : x.c[0] < 8e13 || nIsBig && x.c[0] <= 9999975e7))) {\r\n\r\n // If x is negative and n is odd, k = -0, else k = 0.\r\n k = x.s < 0 && isOdd(n) ? -0 : 0;\r\n\r\n // If x >= 1, k = ±Infinity.\r\n if (x.e > -1) k = 1 / k;\r\n\r\n // If n is negative return ±0, else return ±Infinity.\r\n return new BigNumber(nIsNeg ? 1 / k : k);\r\n\r\n } else if (POW_PRECISION) {\r\n\r\n // Truncating each coefficient array to a length of k after each multiplication\r\n // equates to truncating significant digits to POW_PRECISION + [28, 41],\r\n // i.e. there will be a minimum of 28 guard digits retained.\r\n k = mathceil(POW_PRECISION / LOG_BASE + 2);\r\n }\r\n\r\n if (nIsBig) {\r\n half = new BigNumber(0.5);\r\n if (nIsNeg) n.s = 1;\r\n nIsOdd = isOdd(n);\r\n } else {\r\n i = Math.abs(+valueOf(n));\r\n nIsOdd = i % 2;\r\n }\r\n\r\n y = new BigNumber(ONE);\r\n\r\n // Performs 54 loop iterations for n of 9007199254740991.\r\n for (; ;) {\r\n\r\n if (nIsOdd) {\r\n y = y.times(x);\r\n if (!y.c) break;\r\n\r\n if (k) {\r\n if (y.c.length > k) y.c.length = k;\r\n } else if (isModExp) {\r\n y = y.mod(m); //y = y.minus(div(y, m, 0, MODULO_MODE).times(m));\r\n }\r\n }\r\n\r\n if (i) {\r\n i = mathfloor(i / 2);\r\n if (i === 0) break;\r\n nIsOdd = i % 2;\r\n } else {\r\n n = n.times(half);\r\n round(n, n.e + 1, 1);\r\n\r\n if (n.e > 14) {\r\n nIsOdd = isOdd(n);\r\n } else {\r\n i = +valueOf(n);\r\n if (i === 0) break;\r\n nIsOdd = i % 2;\r\n }\r\n }\r\n\r\n x = x.times(x);\r\n\r\n if (k) {\r\n if (x.c && x.c.length > k) x.c.length = k;\r\n } else if (isModExp) {\r\n x = x.mod(m); //x = x.minus(div(x, m, 0, MODULO_MODE).times(m));\r\n }\r\n }\r\n\r\n if (isModExp) return y;\r\n if (nIsNeg) y = ONE.div(y);\r\n\r\n return m ? y.mod(m) : k ? round(y, POW_PRECISION, ROUNDING_MODE, more) : y;\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the value of this BigNumber rounded to an integer\r\n * using rounding mode rm, or ROUNDING_MODE if rm is omitted.\r\n *\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {rm}'\r\n */\r\n P.integerValue = function (rm) {\r\n var n = new BigNumber(this);\r\n if (rm == null) rm = ROUNDING_MODE;\r\n else intCheck(rm, 0, 8);\r\n return round(n, n.e + 1, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is equal to the value of BigNumber(y, b),\r\n * otherwise return false.\r\n */\r\n P.isEqualTo = P.eq = function (y, b) {\r\n return compare(this, new BigNumber(y, b)) === 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is a finite number, otherwise return false.\r\n */\r\n P.isFinite = function () {\r\n return !!this.c;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is greater than the value of BigNumber(y, b),\r\n * otherwise return false.\r\n */\r\n P.isGreaterThan = P.gt = function (y, b) {\r\n return compare(this, new BigNumber(y, b)) > 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is greater than or equal to the value of\r\n * BigNumber(y, b), otherwise return false.\r\n */\r\n P.isGreaterThanOrEqualTo = P.gte = function (y, b) {\r\n return (b = compare(this, new BigNumber(y, b))) === 1 || b === 0;\r\n\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is an integer, otherwise return false.\r\n */\r\n P.isInteger = function () {\r\n return !!this.c && bitFloor(this.e / LOG_BASE) > this.c.length - 2;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is less than the value of BigNumber(y, b),\r\n * otherwise return false.\r\n */\r\n P.isLessThan = P.lt = function (y, b) {\r\n return compare(this, new BigNumber(y, b)) < 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is less than or equal to the value of\r\n * BigNumber(y, b), otherwise return false.\r\n */\r\n P.isLessThanOrEqualTo = P.lte = function (y, b) {\r\n return (b = compare(this, new BigNumber(y, b))) === -1 || b === 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is NaN, otherwise return false.\r\n */\r\n P.isNaN = function () {\r\n return !this.s;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is negative, otherwise return false.\r\n */\r\n P.isNegative = function () {\r\n return this.s < 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is positive, otherwise return false.\r\n */\r\n P.isPositive = function () {\r\n return this.s > 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is 0 or -0, otherwise return false.\r\n */\r\n P.isZero = function () {\r\n return !!this.c && this.c[0] == 0;\r\n };\r\n\r\n\r\n /*\r\n * n - 0 = n\r\n * n - N = N\r\n * n - I = -I\r\n * 0 - n = -n\r\n * 0 - 0 = 0\r\n * 0 - N = N\r\n * 0 - I = -I\r\n * N - n = N\r\n * N - 0 = N\r\n * N - N = N\r\n * N - I = N\r\n * I - n = I\r\n * I - 0 = I\r\n * I - N = N\r\n * I - I = N\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber minus the value of\r\n * BigNumber(y, b).\r\n */\r\n P.minus = function (y, b) {\r\n var i, j, t, xLTy,\r\n x = this,\r\n a = x.s;\r\n\r\n y = new BigNumber(y, b);\r\n b = y.s;\r\n\r\n // Either NaN?\r\n if (!a || !b) return new BigNumber(NaN);\r\n\r\n // Signs differ?\r\n if (a != b) {\r\n y.s = -b;\r\n return x.plus(y);\r\n }\r\n\r\n var xe = x.e / LOG_BASE,\r\n ye = y.e / LOG_BASE,\r\n xc = x.c,\r\n yc = y.c;\r\n\r\n if (!xe || !ye) {\r\n\r\n // Either Infinity?\r\n if (!xc || !yc) return xc ? (y.s = -b, y) : new BigNumber(yc ? x : NaN);\r\n\r\n // Either zero?\r\n if (!xc[0] || !yc[0]) {\r\n\r\n // Return y if y is non-zero, x if x is non-zero, or zero if both are zero.\r\n return yc[0] ? (y.s = -b, y) : new BigNumber(xc[0] ? x :\r\n\r\n // IEEE 754 (2008) 6.3: n - n = -0 when rounding to -Infinity\r\n ROUNDING_MODE == 3 ? -0 : 0);\r\n }\r\n }\r\n\r\n xe = bitFloor(xe);\r\n ye = bitFloor(ye);\r\n xc = xc.slice();\r\n\r\n // Determine which is the bigger number.\r\n if (a = xe - ye) {\r\n\r\n if (xLTy = a < 0) {\r\n a = -a;\r\n t = xc;\r\n } else {\r\n ye = xe;\r\n t = yc;\r\n }\r\n\r\n t.reverse();\r\n\r\n // Prepend zeros to equalise exponents.\r\n for (b = a; b--; t.push(0));\r\n t.reverse();\r\n } else {\r\n\r\n // Exponents equal. Check digit by digit.\r\n j = (xLTy = (a = xc.length) < (b = yc.length)) ? a : b;\r\n\r\n for (a = b = 0; b < j; b++) {\r\n\r\n if (xc[b] != yc[b]) {\r\n xLTy = xc[b] < yc[b];\r\n break;\r\n }\r\n }\r\n }\r\n\r\n // x < y? Point xc to the array of the bigger number.\r\n if (xLTy) t = xc, xc = yc, yc = t, y.s = -y.s;\r\n\r\n b = (j = yc.length) - (i = xc.length);\r\n\r\n // Append zeros to xc if shorter.\r\n // No need to add zeros to yc if shorter as subtract only needs to start at yc.length.\r\n if (b > 0) for (; b--; xc[i++] = 0);\r\n b = BASE - 1;\r\n\r\n // Subtract yc from xc.\r\n for (; j > a;) {\r\n\r\n if (xc[--j] < yc[j]) {\r\n for (i = j; i && !xc[--i]; xc[i] = b);\r\n --xc[i];\r\n xc[j] += BASE;\r\n }\r\n\r\n xc[j] -= yc[j];\r\n }\r\n\r\n // Remove leading zeros and adjust exponent accordingly.\r\n for (; xc[0] == 0; xc.splice(0, 1), --ye);\r\n\r\n // Zero?\r\n if (!xc[0]) {\r\n\r\n // Following IEEE 754 (2008) 6.3,\r\n // n - n = +0 but n - n = -0 when rounding towards -Infinity.\r\n y.s = ROUNDING_MODE == 3 ? -1 : 1;\r\n y.c = [y.e = 0];\r\n return y;\r\n }\r\n\r\n // No need to check for Infinity as +x - +y != Infinity && -x - -y != Infinity\r\n // for finite x and y.\r\n return normalise(y, xc, ye);\r\n };\r\n\r\n\r\n /*\r\n * n % 0 = N\r\n * n % N = N\r\n * n % I = n\r\n * 0 % n = 0\r\n * -0 % n = -0\r\n * 0 % 0 = N\r\n * 0 % N = N\r\n * 0 % I = 0\r\n * N % n = N\r\n * N % 0 = N\r\n * N % N = N\r\n * N % I = N\r\n * I % n = N\r\n * I % 0 = N\r\n * I % N = N\r\n * I % I = N\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber modulo the value of\r\n * BigNumber(y, b). The result depends on the value of MODULO_MODE.\r\n */\r\n P.modulo = P.mod = function (y, b) {\r\n var q, s,\r\n x = this;\r\n\r\n y = new BigNumber(y, b);\r\n\r\n // Return NaN if x is Infinity or NaN, or y is NaN or zero.\r\n if (!x.c || !y.s || y.c && !y.c[0]) {\r\n return new BigNumber(NaN);\r\n\r\n // Return x if y is Infinity or x is zero.\r\n } else if (!y.c || x.c && !x.c[0]) {\r\n return new BigNumber(x);\r\n }\r\n\r\n if (MODULO_MODE == 9) {\r\n\r\n // Euclidian division: q = sign(y) * floor(x / abs(y))\r\n // r = x - qy where 0 <= r < abs(y)\r\n s = y.s;\r\n y.s = 1;\r\n q = div(x, y, 0, 3);\r\n y.s = s;\r\n q.s *= s;\r\n } else {\r\n q = div(x, y, 0, MODULO_MODE);\r\n }\r\n\r\n y = x.minus(q.times(y));\r\n\r\n // To match JavaScript %, ensure sign of zero is sign of dividend.\r\n if (!y.c[0] && MODULO_MODE == 1) y.s = x.s;\r\n\r\n return y;\r\n };\r\n\r\n\r\n /*\r\n * n * 0 = 0\r\n * n * N = N\r\n * n * I = I\r\n * 0 * n = 0\r\n * 0 * 0 = 0\r\n * 0 * N = N\r\n * 0 * I = N\r\n * N * n = N\r\n * N * 0 = N\r\n * N * N = N\r\n * N * I = N\r\n * I * n = I\r\n * I * 0 = N\r\n * I * N = N\r\n * I * I = I\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber multiplied by the value\r\n * of BigNumber(y, b).\r\n */\r\n P.multipliedBy = P.times = function (y, b) {\r\n var c, e, i, j, k, m, xcL, xlo, xhi, ycL, ylo, yhi, zc,\r\n base, sqrtBase,\r\n x = this,\r\n xc = x.c,\r\n yc = (y = new BigNumber(y, b)).c;\r\n\r\n // Either NaN, ±Infinity or ±0?\r\n if (!xc || !yc || !xc[0] || !yc[0]) {\r\n\r\n // Return NaN if either is NaN, or one is 0 and the other is Infinity.\r\n if (!x.s || !y.s || xc && !xc[0] && !yc || yc && !yc[0] && !xc) {\r\n y.c = y.e = y.s = null;\r\n } else {\r\n y.s *= x.s;\r\n\r\n // Return ±Infinity if either is ±Infinity.\r\n if (!xc || !yc) {\r\n y.c = y.e = null;\r\n\r\n // Return ±0 if either is ±0.\r\n } else {\r\n y.c = [0];\r\n y.e = 0;\r\n }\r\n }\r\n\r\n return y;\r\n }\r\n\r\n e = bitFloor(x.e / LOG_BASE) + bitFloor(y.e / LOG_BASE);\r\n y.s *= x.s;\r\n xcL = xc.length;\r\n ycL = yc.length;\r\n\r\n // Ensure xc points to longer array and xcL to its length.\r\n if (xcL < ycL) zc = xc, xc = yc, yc = zc, i = xcL, xcL = ycL, ycL = i;\r\n\r\n // Initialise the result array with zeros.\r\n for (i = xcL + ycL, zc = []; i--; zc.push(0));\r\n\r\n base = BASE;\r\n sqrtBase = SQRT_BASE;\r\n\r\n for (i = ycL; --i >= 0;) {\r\n c = 0;\r\n ylo = yc[i] % sqrtBase;\r\n yhi = yc[i] / sqrtBase | 0;\r\n\r\n for (k = xcL, j = i + k; j > i;) {\r\n xlo = xc[--k] % sqrtBase;\r\n xhi = xc[k] / sqrtBase | 0;\r\n m = yhi * xlo + xhi * ylo;\r\n xlo = ylo * xlo + ((m % sqrtBase) * sqrtBase) + zc[j] + c;\r\n c = (xlo / base | 0) + (m / sqrtBase | 0) + yhi * xhi;\r\n zc[j--] = xlo % base;\r\n }\r\n\r\n zc[j] = c;\r\n }\r\n\r\n if (c) {\r\n ++e;\r\n } else {\r\n zc.splice(0, 1);\r\n }\r\n\r\n return normalise(y, zc, e);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the value of this BigNumber negated,\r\n * i.e. multiplied by -1.\r\n */\r\n P.negated = function () {\r\n var x = new BigNumber(this);\r\n x.s = -x.s || null;\r\n return x;\r\n };\r\n\r\n\r\n /*\r\n * n + 0 = n\r\n * n + N = N\r\n * n + I = I\r\n * 0 + n = n\r\n * 0 + 0 = 0\r\n * 0 + N = N\r\n * 0 + I = I\r\n * N + n = N\r\n * N + 0 = N\r\n * N + N = N\r\n * N + I = N\r\n * I + n = I\r\n * I + 0 = I\r\n * I + N = N\r\n * I + I = I\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber plus the value of\r\n * BigNumber(y, b).\r\n */\r\n P.plus = function (y, b) {\r\n var t,\r\n x = this,\r\n a = x.s;\r\n\r\n y = new BigNumber(y, b);\r\n b = y.s;\r\n\r\n // Either NaN?\r\n if (!a || !b) return new BigNumber(NaN);\r\n\r\n // Signs differ?\r\n if (a != b) {\r\n y.s = -b;\r\n return x.minus(y);\r\n }\r\n\r\n var xe = x.e / LOG_BASE,\r\n ye = y.e / LOG_BASE,\r\n xc = x.c,\r\n yc = y.c;\r\n\r\n if (!xe || !ye) {\r\n\r\n // Return ±Infinity if either ±Infinity.\r\n if (!xc || !yc) return new BigNumber(a / 0);\r\n\r\n // Either zero?\r\n // Return y if y is non-zero, x if x is non-zero, or zero if both are zero.\r\n if (!xc[0] || !yc[0]) return yc[0] ? y : new BigNumber(xc[0] ? x : a * 0);\r\n }\r\n\r\n xe = bitFloor(xe);\r\n ye = bitFloor(ye);\r\n xc = xc.slice();\r\n\r\n // Prepend zeros to equalise exponents. Faster to use reverse then do unshifts.\r\n if (a = xe - ye) {\r\n if (a > 0) {\r\n ye = xe;\r\n t = yc;\r\n } else {\r\n a = -a;\r\n t = xc;\r\n }\r\n\r\n t.reverse();\r\n for (; a--; t.push(0));\r\n t.reverse();\r\n }\r\n\r\n a = xc.length;\r\n b = yc.length;\r\n\r\n // Point xc to the longer array, and b to the shorter length.\r\n if (a - b < 0) t = yc, yc = xc, xc = t, b = a;\r\n\r\n // Only start adding at yc.length - 1 as the further digits of xc can be ignored.\r\n for (a = 0; b;) {\r\n a = (xc[--b] = xc[b] + yc[b] + a) / BASE | 0;\r\n xc[b] = BASE === xc[b] ? 0 : xc[b] % BASE;\r\n }\r\n\r\n if (a) {\r\n xc = [a].concat(xc);\r\n ++ye;\r\n }\r\n\r\n // No need to check for zero, as +x + +y != 0 && -x + -y != 0\r\n // ye = MAX_EXP + 1 possible\r\n return normalise(y, xc, ye);\r\n };\r\n\r\n\r\n /*\r\n * If sd is undefined or null or true or false, return the number of significant digits of\r\n * the value of this BigNumber, or null if the value of this BigNumber is ±Infinity or NaN.\r\n * If sd is true include integer-part trailing zeros in the count.\r\n *\r\n * Otherwise, if sd is a number, return a new BigNumber whose value is the value of this\r\n * BigNumber rounded to a maximum of sd significant digits using rounding mode rm, or\r\n * ROUNDING_MODE if rm is omitted.\r\n *\r\n * sd {number|boolean} number: significant digits: integer, 1 to MAX inclusive.\r\n * boolean: whether to count integer-part trailing zeros: true or false.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {sd|rm}'\r\n */\r\n P.precision = P.sd = function (sd, rm) {\r\n var c, n, v,\r\n x = this;\r\n\r\n if (sd != null && sd !== !!sd) {\r\n intCheck(sd, 1, MAX);\r\n if (rm == null) rm = ROUNDING_MODE;\r\n else intCheck(rm, 0, 8);\r\n\r\n return round(new BigNumber(x), sd, rm);\r\n }\r\n\r\n if (!(c = x.c)) return null;\r\n v = c.length - 1;\r\n n = v * LOG_BASE + 1;\r\n\r\n if (v = c[v]) {\r\n\r\n // Subtract the number of trailing zeros of the last element.\r\n for (; v % 10 == 0; v /= 10, n--);\r\n\r\n // Add the number of digits of the first element.\r\n for (v = c[0]; v >= 10; v /= 10, n++);\r\n }\r\n\r\n if (sd && x.e + 1 > n) n = x.e + 1;\r\n\r\n return n;\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the value of this BigNumber shifted by k places\r\n * (powers of 10). Shift to the right if n > 0, and to the left if n < 0.\r\n *\r\n * k {number} Integer, -MAX_SAFE_INTEGER to MAX_SAFE_INTEGER inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {k}'\r\n */\r\n P.shiftedBy = function (k) {\r\n intCheck(k, -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER);\r\n return this.times('1e' + k);\r\n };\r\n\r\n\r\n /*\r\n * sqrt(-n) = N\r\n * sqrt(N) = N\r\n * sqrt(-I) = N\r\n * sqrt(I) = I\r\n * sqrt(0) = 0\r\n * sqrt(-0) = -0\r\n *\r\n * Return a new BigNumber whose value is the square root of the value of this BigNumber,\r\n * rounded according to DECIMAL_PLACES and ROUNDING_MODE.\r\n */\r\n P.squareRoot = P.sqrt = function () {\r\n var m, n, r, rep, t,\r\n x = this,\r\n c = x.c,\r\n s = x.s,\r\n e = x.e,\r\n dp = DECIMAL_PLACES + 4,\r\n half = new BigNumber('0.5');\r\n\r\n // Negative/NaN/Infinity/zero?\r\n if (s !== 1 || !c || !c[0]) {\r\n return new BigNumber(!s || s < 0 && (!c || c[0]) ? NaN : c ? x : 1 / 0);\r\n }\r\n\r\n // Initial estimate.\r\n s = Math.sqrt(+valueOf(x));\r\n\r\n // Math.sqrt underflow/overflow?\r\n // Pass x to Math.sqrt as integer, then adjust the exponent of the result.\r\n if (s == 0 || s == 1 / 0) {\r\n n = coeffToString(c);\r\n if ((n.length + e) % 2 == 0) n += '0';\r\n s = Math.sqrt(+n);\r\n e = bitFloor((e + 1) / 2) - (e < 0 || e % 2);\r\n\r\n if (s == 1 / 0) {\r\n n = '5e' + e;\r\n } else {\r\n n = s.toExponential();\r\n n = n.slice(0, n.indexOf('e') + 1) + e;\r\n }\r\n\r\n r = new BigNumber(n);\r\n } else {\r\n r = new BigNumber(s + '');\r\n }\r\n\r\n // Check for zero.\r\n // r could be zero if MIN_EXP is changed after the this value was created.\r\n // This would cause a division by zero (x/t) and hence Infinity below, which would cause\r\n // coeffToString to throw.\r\n if (r.c[0]) {\r\n e = r.e;\r\n s = e + dp;\r\n if (s < 3) s = 0;\r\n\r\n // Newton-Raphson iteration.\r\n for (; ;) {\r\n t = r;\r\n r = half.times(t.plus(div(x, t, dp, 1)));\r\n\r\n if (coeffToString(t.c).slice(0, s) === (n = coeffToString(r.c)).slice(0, s)) {\r\n\r\n // The exponent of r may here be one less than the final result exponent,\r\n // e.g 0.0009999 (e-4) --> 0.001 (e-3), so adjust s so the rounding digits\r\n // are indexed correctly.\r\n if (r.e < e) --s;\r\n n = n.slice(s - 3, s + 1);\r\n\r\n // The 4th rounding digit may be in error by -1 so if the 4 rounding digits\r\n // are 9999 or 4999 (i.e. approaching a rounding boundary) continue the\r\n // iteration.\r\n if (n == '9999' || !rep && n == '4999') {\r\n\r\n // On the first iteration only, check to see if rounding up gives the\r\n // exact result as the nines may infinitely repeat.\r\n if (!rep) {\r\n round(t, t.e + DECIMAL_PLACES + 2, 0);\r\n\r\n if (t.times(t).eq(x)) {\r\n r = t;\r\n break;\r\n }\r\n }\r\n\r\n dp += 4;\r\n s += 4;\r\n rep = 1;\r\n } else {\r\n\r\n // If rounding digits are null, 0{0,4} or 50{0,3}, check for exact\r\n // result. If not, then there are further digits and m will be truthy.\r\n if (!+n || !+n.slice(1) && n.charAt(0) == '5') {\r\n\r\n // Truncate to the first rounding digit.\r\n round(r, r.e + DECIMAL_PLACES + 2, 1);\r\n m = !r.times(r).eq(x);\r\n }\r\n\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n\r\n return round(r, r.e + DECIMAL_PLACES + 1, ROUNDING_MODE, m);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber in exponential notation and\r\n * rounded using ROUNDING_MODE to dp fixed decimal places.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp|rm}'\r\n */\r\n P.toExponential = function (dp, rm) {\r\n if (dp != null) {\r\n intCheck(dp, 0, MAX);\r\n dp++;\r\n }\r\n return format(this, dp, rm, 1);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber in fixed-point notation rounding\r\n * to dp fixed decimal places using rounding mode rm, or ROUNDING_MODE if rm is omitted.\r\n *\r\n * Note: as with JavaScript's number type, (-0).toFixed(0) is '0',\r\n * but e.g. (-0.00001).toFixed(0) is '-0'.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp|rm}'\r\n */\r\n P.toFixed = function (dp, rm) {\r\n if (dp != null) {\r\n intCheck(dp, 0, MAX);\r\n dp = dp + this.e + 1;\r\n }\r\n return format(this, dp, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber in fixed-point notation rounded\r\n * using rm or ROUNDING_MODE to dp decimal places, and formatted according to the properties\r\n * of the format or FORMAT object (see BigNumber.set).\r\n *\r\n * The formatting object may contain some or all of the properties shown below.\r\n *\r\n * FORMAT = {\r\n * prefix: '',\r\n * groupSize: 3,\r\n * secondaryGroupSize: 0,\r\n * groupSeparator: ',',\r\n * decimalSeparator: '.',\r\n * fractionGroupSize: 0,\r\n * fractionGroupSeparator: '\\xA0', // non-breaking space\r\n * suffix: ''\r\n * };\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n * [format] {object} Formatting options. See FORMAT pbject above.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp|rm}'\r\n * '[BigNumber Error] Argument not an object: {format}'\r\n */\r\n P.toFormat = function (dp, rm, format) {\r\n var str,\r\n x = this;\r\n\r\n if (format == null) {\r\n if (dp != null && rm && typeof rm == 'object') {\r\n format = rm;\r\n rm = null;\r\n } else if (dp && typeof dp == 'object') {\r\n format = dp;\r\n dp = rm = null;\r\n } else {\r\n format = FORMAT;\r\n }\r\n } else if (typeof format != 'object') {\r\n throw Error\r\n (bignumberError + 'Argument not an object: ' + format);\r\n }\r\n\r\n str = x.toFixed(dp, rm);\r\n\r\n if (x.c) {\r\n var i,\r\n arr = str.split('.'),\r\n g1 = +format.groupSize,\r\n g2 = +format.secondaryGroupSize,\r\n groupSeparator = format.groupSeparator || '',\r\n intPart = arr[0],\r\n fractionPart = arr[1],\r\n isNeg = x.s < 0,\r\n intDigits = isNeg ? intPart.slice(1) : intPart,\r\n len = intDigits.length;\r\n\r\n if (g2) i = g1, g1 = g2, g2 = i, len -= i;\r\n\r\n if (g1 > 0 && len > 0) {\r\n i = len % g1 || g1;\r\n intPart = intDigits.substr(0, i);\r\n for (; i < len; i += g1) intPart += groupSeparator + intDigits.substr(i, g1);\r\n if (g2 > 0) intPart += groupSeparator + intDigits.slice(i);\r\n if (isNeg) intPart = '-' + intPart;\r\n }\r\n\r\n str = fractionPart\r\n ? intPart + (format.decimalSeparator || '') + ((g2 = +format.fractionGroupSize)\r\n ? fractionPart.replace(new RegExp('\\\\d{' + g2 + '}\\\\B', 'g'),\r\n '$&' + (format.fractionGroupSeparator || ''))\r\n : fractionPart)\r\n : intPart;\r\n }\r\n\r\n return (format.prefix || '') + str + (format.suffix || '');\r\n };\r\n\r\n\r\n /*\r\n * Return an array of two BigNumbers representing the value of this BigNumber as a simple\r\n * fraction with an integer numerator and an integer denominator.\r\n * The denominator will be a positive non-zero value less than or equal to the specified\r\n * maximum denominator. If a maximum denominator is not specified, the denominator will be\r\n * the lowest value necessary to represent the number exactly.\r\n *\r\n * [md] {number|string|BigNumber} Integer >= 1, or Infinity. The maximum denominator.\r\n *\r\n * '[BigNumber Error] Argument {not an integer|out of range} : {md}'\r\n */\r\n P.toFraction = function (md) {\r\n var d, d0, d1, d2, e, exp, n, n0, n1, q, r, s,\r\n x = this,\r\n xc = x.c;\r\n\r\n if (md != null) {\r\n n = new BigNumber(md);\r\n\r\n // Throw if md is less than one or is not an integer, unless it is Infinity.\r\n if (!n.isInteger() && (n.c || n.s !== 1) || n.lt(ONE)) {\r\n throw Error\r\n (bignumberError + 'Argument ' +\r\n (n.isInteger() ? 'out of range: ' : 'not an integer: ') + valueOf(n));\r\n }\r\n }\r\n\r\n if (!xc) return new BigNumber(x);\r\n\r\n d = new BigNumber(ONE);\r\n n1 = d0 = new BigNumber(ONE);\r\n d1 = n0 = new BigNumber(ONE);\r\n s = coeffToString(xc);\r\n\r\n // Determine initial denominator.\r\n // d is a power of 10 and the minimum max denominator that specifies the value exactly.\r\n e = d.e = s.length - x.e - 1;\r\n d.c[0] = POWS_TEN[(exp = e % LOG_BASE) < 0 ? LOG_BASE + exp : exp];\r\n md = !md || n.comparedTo(d) > 0 ? (e > 0 ? d : n1) : n;\r\n\r\n exp = MAX_EXP;\r\n MAX_EXP = 1 / 0;\r\n n = new BigNumber(s);\r\n\r\n // n0 = d1 = 0\r\n n0.c[0] = 0;\r\n\r\n for (; ;) {\r\n q = div(n, d, 0, 1);\r\n d2 = d0.plus(q.times(d1));\r\n if (d2.comparedTo(md) == 1) break;\r\n d0 = d1;\r\n d1 = d2;\r\n n1 = n0.plus(q.times(d2 = n1));\r\n n0 = d2;\r\n d = n.minus(q.times(d2 = d));\r\n n = d2;\r\n }\r\n\r\n d2 = div(md.minus(d0), d1, 0, 1);\r\n n0 = n0.plus(d2.times(n1));\r\n d0 = d0.plus(d2.times(d1));\r\n n0.s = n1.s = x.s;\r\n e = e * 2;\r\n\r\n // Determine which fraction is closer to x, n0/d0 or n1/d1\r\n r = div(n1, d1, e, ROUNDING_MODE).minus(x).abs().comparedTo(\r\n div(n0, d0, e, ROUNDING_MODE).minus(x).abs()) < 1 ? [n1, d1] : [n0, d0];\r\n\r\n MAX_EXP = exp;\r\n\r\n return r;\r\n };\r\n\r\n\r\n /*\r\n * Return the value of this BigNumber converted to a number primitive.\r\n */\r\n P.toNumber = function () {\r\n return +valueOf(this);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber rounded to sd significant digits\r\n * using rounding mode rm or ROUNDING_MODE. If sd is less than the number of digits\r\n * necessary to represent the integer part of the value in fixed-point notation, then use\r\n * exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {sd|rm}'\r\n */\r\n P.toPrecision = function (sd, rm) {\r\n if (sd != null) intCheck(sd, 1, MAX);\r\n return format(this, sd, rm, 2);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber in base b, or base 10 if b is\r\n * omitted. If a base is specified, including base 10, round according to DECIMAL_PLACES and\r\n * ROUNDING_MODE. If a base is not specified, and this BigNumber has a positive exponent\r\n * that is equal to or greater than TO_EXP_POS, or a negative exponent equal to or less than\r\n * TO_EXP_NEG, return exponential notation.\r\n *\r\n * [b] {number} Integer, 2 to ALPHABET.length inclusive.\r\n *\r\n * '[BigNumber Error] Base {not a primitive number|not an integer|out of range}: {b}'\r\n */\r\n P.toString = function (b) {\r\n var str,\r\n n = this,\r\n s = n.s,\r\n e = n.e;\r\n\r\n // Infinity or NaN?\r\n if (e === null) {\r\n if (s) {\r\n str = 'Infinity';\r\n if (s < 0) str = '-' + str;\r\n } else {\r\n str = 'NaN';\r\n }\r\n } else {\r\n if (b == null) {\r\n str = e <= TO_EXP_NEG || e >= TO_EXP_POS\r\n ? toExponential(coeffToString(n.c), e)\r\n : toFixedPoint(coeffToString(n.c), e, '0');\r\n } else if (b === 10) {\r\n n = round(new BigNumber(n), DECIMAL_PLACES + e + 1, ROUNDING_MODE);\r\n str = toFixedPoint(coeffToString(n.c), n.e, '0');\r\n } else {\r\n intCheck(b, 2, ALPHABET.length, 'Base');\r\n str = convertBase(toFixedPoint(coeffToString(n.c), e, '0'), 10, b, s, true);\r\n }\r\n\r\n if (s < 0 && n.c[0]) str = '-' + str;\r\n }\r\n\r\n return str;\r\n };\r\n\r\n\r\n /*\r\n * Return as toString, but do not accept a base argument, and include the minus sign for\r\n * negative zero.\r\n */\r\n P.valueOf = P.toJSON = function () {\r\n return valueOf(this);\r\n };\r\n\r\n\r\n P._isBigNumber = true;\r\n\r\n if (configObject != null) BigNumber.set(configObject);\r\n\r\n return BigNumber;\r\n }\r\n\r\n\r\n // PRIVATE HELPER FUNCTIONS\r\n\r\n // These functions don't need access to variables,\r\n // e.g. DECIMAL_PLACES, in the scope of the `clone` function above.\r\n\r\n\r\n function bitFloor(n) {\r\n var i = n | 0;\r\n return n > 0 || n === i ? i : i - 1;\r\n }\r\n\r\n\r\n // Return a coefficient array as a string of base 10 digits.\r\n function coeffToString(a) {\r\n var s, z,\r\n i = 1,\r\n j = a.length,\r\n r = a[0] + '';\r\n\r\n for (; i < j;) {\r\n s = a[i++] + '';\r\n z = LOG_BASE - s.length;\r\n for (; z--; s = '0' + s);\r\n r += s;\r\n }\r\n\r\n // Determine trailing zeros.\r\n for (j = r.length; r.charCodeAt(--j) === 48;);\r\n\r\n return r.slice(0, j + 1 || 1);\r\n }\r\n\r\n\r\n // Compare the value of BigNumbers x and y.\r\n function compare(x, y) {\r\n var a, b,\r\n xc = x.c,\r\n yc = y.c,\r\n i = x.s,\r\n j = y.s,\r\n k = x.e,\r\n l = y.e;\r\n\r\n // Either NaN?\r\n if (!i || !j) return null;\r\n\r\n a = xc && !xc[0];\r\n b = yc && !yc[0];\r\n\r\n // Either zero?\r\n if (a || b) return a ? b ? 0 : -j : i;\r\n\r\n // Signs differ?\r\n if (i != j) return i;\r\n\r\n a = i < 0;\r\n b = k == l;\r\n\r\n // Either Infinity?\r\n if (!xc || !yc) return b ? 0 : !xc ^ a ? 1 : -1;\r\n\r\n // Compare exponents.\r\n if (!b) return k > l ^ a ? 1 : -1;\r\n\r\n j = (k = xc.length) < (l = yc.length) ? k : l;\r\n\r\n // Compare digit by digit.\r\n for (i = 0; i < j; i++) if (xc[i] != yc[i]) return xc[i] > yc[i] ^ a ? 1 : -1;\r\n\r\n // Compare lengths.\r\n return k == l ? 0 : k > l ^ a ? 1 : -1;\r\n }\r\n\r\n\r\n /*\r\n * Check that n is a primitive number, an integer, and in range, otherwise throw.\r\n */\r\n function intCheck(n, min, max, name) {\r\n if (n < min || n > max || n !== mathfloor(n)) {\r\n throw Error\r\n (bignumberError + (name || 'Argument') + (typeof n == 'number'\r\n ? n < min || n > max ? ' out of range: ' : ' not an integer: '\r\n : ' not a primitive number: ') + String(n));\r\n }\r\n }\r\n\r\n\r\n // Assumes finite n.\r\n function isOdd(n) {\r\n var k = n.c.length - 1;\r\n return bitFloor(n.e / LOG_BASE) == k && n.c[k] % 2 != 0;\r\n }\r\n\r\n\r\n function toExponential(str, e) {\r\n return (str.length > 1 ? str.charAt(0) + '.' + str.slice(1) : str) +\r\n (e < 0 ? 'e' : 'e+') + e;\r\n }\r\n\r\n\r\n function toFixedPoint(str, e, z) {\r\n var len, zs;\r\n\r\n // Negative exponent?\r\n if (e < 0) {\r\n\r\n // Prepend zeros.\r\n for (zs = z + '.'; ++e; zs += z);\r\n str = zs + str;\r\n\r\n // Positive exponent\r\n } else {\r\n len = str.length;\r\n\r\n // Append zeros.\r\n if (++e > len) {\r\n for (zs = z, e -= len; --e; zs += z);\r\n str += zs;\r\n } else if (e < len) {\r\n str = str.slice(0, e) + '.' + str.slice(e);\r\n }\r\n }\r\n\r\n return str;\r\n }\r\n\r\n\r\n // EXPORT\r\n\r\n\r\n BigNumber = clone();\r\n BigNumber['default'] = BigNumber.BigNumber = BigNumber;\r\n\r\n // AMD.\r\n if (typeof define == 'function' && define.amd) {\r\n define(function () { return BigNumber; });\r\n\r\n // Node.js and other environments that support module.exports.\r\n } else if (typeof module != 'undefined' && module.exports) {\r\n module.exports = BigNumber;\r\n\r\n // Browser.\r\n } else {\r\n if (!globalObject) {\r\n globalObject = typeof self != 'undefined' && self ? self : window;\r\n }\r\n\r\n globalObject.BigNumber = BigNumber;\r\n }\r\n})(this);\r\n","'use strict'\n\nconst exp = Math.exp\n\nexports =\nmodule.exports =\nfunction MovingAverage (timespan) {\n if (typeof timespan !== 'number') { throw new Error('must provide a timespan to the moving average constructor') }\n\n if (timespan <= 0) { throw new Error('must provide a timespan > 0 to the moving average constructor') }\n\n let ma // moving average\n let v = 0 // variance\n let d = 0 // deviation\n let f = 0 // forecast\n\n let previousTime\n\n let ret = {}\n\n function alpha (t, pt) {\n return 1 - (exp(-(t - pt) / timespan))\n }\n\n ret.push =\n function push (time, value) {\n if (previousTime) {\n // calculate moving average\n const a = alpha(time, previousTime)\n const diff = value - ma\n const incr = a * diff\n ma = a * value + (1 - a) * ma\n // calculate variance & deviation\n v = (1 - a) * (v + diff * incr)\n d = Math.sqrt(v)\n // calculate forecast\n f = ma + a * diff\n } else {\n ma = value\n }\n previousTime = time\n }\n\n // Exponential Moving Average\n\n ret.movingAverage =\n function movingAverage () {\n return ma\n }\n\n // Variance\n ret.variance =\n function variance () {\n return v\n }\n\n ret.deviation =\n function deviation () {\n return d\n }\n\n ret.forecast =\n function forecast () {\n return f\n }\n\n return ret\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:upgrader'), {\n error: debug('libp2p:upgrader:err')\n})\nconst errCode = require('err-code')\n// @ts-ignore multistream-select does not export types\nconst Multistream = require('multistream-select')\nconst { Connection } = require('libp2p-interfaces/src/connection')\nconst PeerId = require('peer-id')\nconst { pipe } = require('it-pipe')\n// @ts-ignore mutable-proxy does not export types\nconst mutableProxy = require('mutable-proxy')\n\nconst { codes } = require('./errors')\n\n/**\n * @typedef {import('libp2p-interfaces/src/transport/types').MultiaddrConnection} MultiaddrConnection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxerFactory} MuxerFactory\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').Muxer} Muxer\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('libp2p-interfaces/src/crypto/types').Crypto} Crypto\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @typedef CryptoResult\n * @property {MultiaddrConnection} conn A duplex iterable\n * @property {PeerId} remotePeer\n * @property {string} protocol\n */\n\nclass Upgrader {\n /**\n * @param {object} options\n * @param {PeerId} options.localPeer\n * @param {import('./metrics')} [options.metrics]\n * @param {Map} [options.cryptos]\n * @param {Map} [options.muxers]\n * @param {(connection: Connection) => void} options.onConnection - Called when a connection is upgraded\n * @param {(connection: Connection) => void} options.onConnectionEnd\n */\n constructor ({\n localPeer,\n metrics,\n cryptos = new Map(),\n muxers = new Map(),\n onConnectionEnd = () => {},\n onConnection = () => {}\n }) {\n this.localPeer = localPeer\n this.metrics = metrics\n this.cryptos = cryptos\n this.muxers = muxers\n /** @type {import(\"./pnet\") | null} */\n this.protector = null\n this.protocols = new Map()\n this.onConnection = onConnection\n this.onConnectionEnd = onConnectionEnd\n }\n\n /**\n * Upgrades an inbound connection\n *\n * @async\n * @param {MultiaddrConnection} maConn\n * @returns {Promise}\n */\n async upgradeInbound (maConn) {\n let encryptedConn\n let remotePeer\n let upgradedConn\n let Muxer\n let cryptoProtocol\n let setPeer\n let proxyPeer\n\n if (this.metrics) {\n ({ setTarget: setPeer, proxy: proxyPeer } = mutableProxy())\n const idString = (Math.random() * 1e9).toString(36) + Date.now()\n setPeer({ toB58String: () => idString })\n maConn = this.metrics.trackStream({ stream: maConn, remotePeer: proxyPeer })\n }\n\n log('Starting the inbound connection upgrade')\n\n // Protect\n let protectedConn = maConn\n if (this.protector) {\n protectedConn = await this.protector.protect(maConn)\n }\n\n try {\n // Encrypt the connection\n ({\n conn: encryptedConn,\n remotePeer,\n protocol: cryptoProtocol\n } = await this._encryptInbound(this.localPeer, protectedConn, this.cryptos))\n\n // Multiplex the connection\n if (this.muxers.size) {\n ({ stream: upgradedConn, Muxer } = await this._multiplexInbound(encryptedConn, this.muxers))\n } else {\n upgradedConn = encryptedConn\n }\n } catch (err) {\n log.error('Failed to upgrade inbound connection', err)\n await maConn.close(err)\n throw err\n }\n\n if (this.metrics) {\n this.metrics.updatePlaceholder(proxyPeer, remotePeer)\n setPeer(remotePeer)\n }\n\n log('Successfully upgraded inbound connection')\n\n return this._createConnection({\n cryptoProtocol,\n direction: 'inbound',\n maConn,\n upgradedConn,\n Muxer,\n remotePeer\n })\n }\n\n /**\n * Upgrades an outbound connection\n *\n * @async\n * @param {MultiaddrConnection} maConn\n * @returns {Promise}\n */\n async upgradeOutbound (maConn) {\n const idStr = maConn.remoteAddr.getPeerId()\n if (!idStr) {\n throw errCode(new Error('outbound connection must have a peer id'), codes.ERR_INVALID_MULTIADDR)\n }\n\n const remotePeerId = PeerId.createFromB58String(idStr)\n\n let encryptedConn\n let remotePeer\n let upgradedConn\n let cryptoProtocol\n let Muxer\n let setPeer\n let proxyPeer\n\n if (this.metrics) {\n ({ setTarget: setPeer, proxy: proxyPeer } = mutableProxy())\n const idString = (Math.random() * 1e9).toString(36) + Date.now()\n setPeer({ toB58String: () => idString })\n maConn = this.metrics.trackStream({ stream: maConn, remotePeer: proxyPeer })\n }\n\n log('Starting the outbound connection upgrade')\n\n // Protect\n let protectedConn = maConn\n if (this.protector) {\n protectedConn = await this.protector.protect(maConn)\n }\n\n try {\n // Encrypt the connection\n ({\n conn: encryptedConn,\n remotePeer,\n protocol: cryptoProtocol\n } = await this._encryptOutbound(this.localPeer, protectedConn, remotePeerId, this.cryptos))\n\n // Multiplex the connection\n if (this.muxers.size) {\n ({ stream: upgradedConn, Muxer } = await this._multiplexOutbound(encryptedConn, this.muxers))\n } else {\n upgradedConn = encryptedConn\n }\n } catch (err) {\n log.error('Failed to upgrade outbound connection', err)\n await maConn.close(err)\n throw err\n }\n\n if (this.metrics) {\n this.metrics.updatePlaceholder(proxyPeer, remotePeer)\n setPeer(remotePeer)\n }\n\n log('Successfully upgraded outbound connection')\n\n return this._createConnection({\n cryptoProtocol,\n direction: 'outbound',\n maConn,\n upgradedConn,\n Muxer,\n remotePeer\n })\n }\n\n /**\n * A convenience method for generating a new `Connection`\n *\n * @private\n * @param {object} options\n * @param {string} options.cryptoProtocol - The crypto protocol that was negotiated\n * @param {'inbound' | 'outbound'} options.direction - One of ['inbound', 'outbound']\n * @param {MultiaddrConnection} options.maConn - The transport layer connection\n * @param {MuxedStream | MultiaddrConnection} options.upgradedConn - A duplex connection returned from multiplexer and/or crypto selection\n * @param {MuxerFactory} [options.Muxer] - The muxer to be used for muxing\n * @param {PeerId} options.remotePeer - The peer the connection is with\n * @returns {Connection}\n */\n _createConnection ({\n cryptoProtocol,\n direction,\n maConn,\n upgradedConn,\n Muxer,\n remotePeer\n }) {\n /** @type {import(\"libp2p-interfaces/src/stream-muxer/types\").Muxer} */\n let muxer\n /** @type {import(\"libp2p-interfaces/src/connection/connection\").CreatedMuxedStream | undefined} */\n let newStream\n /** @type {Connection} */\n let connection // eslint-disable-line prefer-const\n\n if (Muxer) {\n // Create the muxer\n muxer = new Muxer({\n // Run anytime a remote stream is created\n onStream: async muxedStream => {\n if (!connection) return\n const mss = new Multistream.Listener(muxedStream)\n try {\n const { stream, protocol } = await mss.handle(Array.from(this.protocols.keys()))\n log('%s: incoming stream opened on %s', direction, protocol)\n if (this.metrics) this.metrics.trackStream({ stream, remotePeer, protocol })\n connection.addStream(muxedStream, { protocol })\n this._onStream({ connection, stream: { ...muxedStream, ...stream }, protocol })\n } catch (err) {\n log.error(err)\n }\n },\n // Run anytime a stream closes\n onStreamEnd: muxedStream => {\n connection.removeStream(muxedStream.id)\n }\n })\n\n newStream = async (protocols) => {\n log('%s: starting new stream on %s', direction, protocols)\n const muxedStream = muxer.newStream()\n const mss = new Multistream.Dialer(muxedStream)\n try {\n const { stream, protocol } = await mss.select(protocols)\n if (this.metrics) this.metrics.trackStream({ stream, remotePeer, protocol })\n return { stream: { ...muxedStream, ...stream }, protocol }\n } catch (err) {\n log.error('could not create new stream', err)\n throw errCode(err, codes.ERR_UNSUPPORTED_PROTOCOL)\n }\n }\n\n // Pipe all data through the muxer\n pipe(upgradedConn, muxer, upgradedConn).catch(log.error)\n }\n\n const _timeline = maConn.timeline\n maConn.timeline = new Proxy(_timeline, {\n set: (...args) => {\n if (connection && args[1] === 'close' && args[2] && !_timeline.close) {\n // Wait for close to finish before notifying of the closure\n (async () => {\n try {\n if (connection.stat.status === 'open') {\n await connection.close()\n }\n } catch (err) {\n log.error(err)\n } finally {\n this.onConnectionEnd(connection)\n }\n })()\n }\n\n return Reflect.set(...args)\n }\n })\n maConn.timeline.upgraded = Date.now()\n\n const errConnectionNotMultiplexed = () => {\n throw errCode(new Error('connection is not multiplexed'), 'ERR_CONNECTION_NOT_MULTIPLEXED')\n }\n\n // Create the connection\n connection = new Connection({\n localAddr: maConn.localAddr,\n remoteAddr: maConn.remoteAddr,\n localPeer: this.localPeer,\n remotePeer: remotePeer,\n stat: {\n direction,\n // @ts-ignore\n timeline: maConn.timeline,\n multiplexer: Muxer && Muxer.multicodec,\n encryption: cryptoProtocol\n },\n newStream: newStream || errConnectionNotMultiplexed,\n getStreams: () => muxer ? muxer.streams : errConnectionNotMultiplexed(),\n close: async () => {\n await maConn.close()\n // Ensure remaining streams are aborted\n if (muxer) {\n muxer.streams.map(stream => stream.abort())\n }\n }\n })\n\n this.onConnection(connection)\n\n return connection\n }\n\n /**\n * Routes incoming streams to the correct handler\n *\n * @private\n * @param {object} options\n * @param {Connection} options.connection - The connection the stream belongs to\n * @param {MuxedStream} options.stream\n * @param {string} options.protocol\n */\n _onStream ({ connection, stream, protocol }) {\n const handler = this.protocols.get(protocol)\n handler({ connection, stream, protocol })\n }\n\n /**\n * Attempts to encrypt the incoming `connection` with the provided `cryptos`.\n *\n * @private\n * @async\n * @param {PeerId} localPeer - The initiators PeerId\n * @param {*} connection\n * @param {Map} cryptos\n * @returns {Promise} An encrypted connection, remote peer `PeerId` and the protocol of the `Crypto` used\n */\n async _encryptInbound (localPeer, connection, cryptos) {\n const mss = new Multistream.Listener(connection)\n const protocols = Array.from(cryptos.keys())\n log('handling inbound crypto protocol selection', protocols)\n\n try {\n const { stream, protocol } = await mss.handle(protocols)\n const crypto = cryptos.get(protocol)\n log('encrypting inbound connection...')\n\n if (!crypto) {\n throw new Error(`no crypto module found for ${protocol}`)\n }\n\n return {\n ...await crypto.secureInbound(localPeer, stream),\n protocol\n }\n } catch (err) {\n throw errCode(err, codes.ERR_ENCRYPTION_FAILED)\n }\n }\n\n /**\n * Attempts to encrypt the given `connection` with the provided `cryptos`.\n * The first `Crypto` module to succeed will be used\n *\n * @private\n * @async\n * @param {PeerId} localPeer - The initiators PeerId\n * @param {MultiaddrConnection} connection\n * @param {PeerId} remotePeerId\n * @param {Map} cryptos\n * @returns {Promise} An encrypted connection, remote peer `PeerId` and the protocol of the `Crypto` used\n */\n async _encryptOutbound (localPeer, connection, remotePeerId, cryptos) {\n const mss = new Multistream.Dialer(connection)\n const protocols = Array.from(cryptos.keys())\n log('selecting outbound crypto protocol', protocols)\n\n try {\n const { stream, protocol } = await mss.select(protocols)\n const crypto = cryptos.get(protocol)\n log('encrypting outbound connection to %j', remotePeerId)\n\n if (!crypto) {\n throw new Error(`no crypto module found for ${protocol}`)\n }\n\n return {\n ...await crypto.secureOutbound(localPeer, stream, remotePeerId),\n protocol\n }\n } catch (err) {\n throw errCode(err, codes.ERR_ENCRYPTION_FAILED)\n }\n }\n\n /**\n * Selects one of the given muxers via multistream-select. That\n * muxer will be used for all future streams on the connection.\n *\n * @private\n * @async\n * @param {MultiaddrConnection} connection - A basic duplex connection to multiplex\n * @param {Map} muxers - The muxers to attempt multiplexing with\n * @returns {Promise<{ stream: MuxedStream, Muxer?: MuxerFactory}>} A muxed connection\n */\n async _multiplexOutbound (connection, muxers) {\n const dialer = new Multistream.Dialer(connection)\n const protocols = Array.from(muxers.keys())\n log('outbound selecting muxer %s', protocols)\n try {\n const { stream, protocol } = await dialer.select(protocols)\n log('%s selected as muxer protocol', protocol)\n const Muxer = muxers.get(protocol)\n return { stream, Muxer }\n } catch (err) {\n throw errCode(err, codes.ERR_MUXER_UNAVAILABLE)\n }\n }\n\n /**\n * Registers support for one of the given muxers via multistream-select. The\n * selected muxer will be used for all future streams on the connection.\n *\n * @private\n * @async\n * @param {MultiaddrConnection} connection - A basic duplex connection to multiplex\n * @param {Map} muxers - The muxers to attempt multiplexing with\n * @returns {Promise<{ stream: MuxedStream, Muxer?: MuxerFactory}>} A muxed connection\n */\n async _multiplexInbound (connection, muxers) {\n const listener = new Multistream.Listener(connection)\n const protocols = Array.from(muxers.keys())\n log('inbound handling muxers %s', protocols)\n try {\n const { stream, protocol } = await listener.handle(protocols)\n const Muxer = muxers.get(protocol)\n return { stream, Muxer }\n } catch (err) {\n throw errCode(err, codes.ERR_MUXER_UNAVAILABLE)\n }\n }\n}\n\nmodule.exports = Upgrader\n","'use strict'\n\nconst select = require('./select')\nconst handle = require('./handle')\nconst ls = require('./ls')\nconst { PROTOCOL_ID } = require('./constants')\n\nexports.PROTOCOL_ID = PROTOCOL_ID\n\nclass MultistreamSelect {\n constructor (stream) {\n this._stream = stream\n this._shaken = false\n }\n\n // Perform the multistream-select handshake\n async _handshake () {\n if (this._shaken) return\n const { stream } = await select(this._stream, PROTOCOL_ID)\n this._stream = stream\n this._shaken = true\n }\n}\n\nclass Dialer extends MultistreamSelect {\n select (protocols) {\n return select(this._stream, protocols, this._shaken ? null : PROTOCOL_ID)\n }\n\n async ls () {\n await this._handshake()\n const { stream, protocols } = await ls(this._stream)\n this._stream = stream\n return protocols\n }\n}\n\nexports.Dialer = Dialer\n\nclass Listener extends MultistreamSelect {\n handle (protocols) {\n return handle(this._stream, protocols)\n }\n}\n\nexports.Listener = Listener\n","'use strict'\n\nconst log = require('debug')('mss:select')\nconst errCode = require('err-code')\nconst multistream = require('./multistream')\nconst handshake = require('it-handshake')\n\nmodule.exports = async (stream, protocols, protocolId) => {\n protocols = Array.isArray(protocols) ? [...protocols] : [protocols]\n const { reader, writer, rest, stream: shakeStream } = handshake(stream)\n\n const protocol = protocols.shift()\n if (protocolId) {\n log('select: write [\"%s\", \"%s\"]', protocolId, protocol)\n multistream.writeAll(writer, [protocolId, protocol])\n } else {\n log('select: write \"%s\"', protocol)\n multistream.write(writer, protocol)\n }\n\n let response = (await multistream.read(reader)).toString()\n log('select: read \"%s\"', response)\n\n // Read the protocol response if we got the protocolId in return\n if (response === protocolId) {\n response = (await multistream.read(reader)).toString()\n log('select: read \"%s\"', response)\n }\n\n // We're done\n if (response === protocol) {\n rest()\n return { stream: shakeStream, protocol }\n }\n\n // We haven't gotten a valid ack, try the other protocols\n for (const protocol of protocols) {\n log('select: write \"%s\"', protocol)\n multistream.write(writer, protocol)\n const response = (await multistream.read(reader)).toString()\n log('select: read \"%s\" for \"%s\"', response, protocol)\n\n if (response === protocol) {\n rest() // End our writer so others can start writing to stream\n return { stream: shakeStream, protocol }\n }\n }\n\n rest()\n throw errCode(new Error('protocol selection failed'), 'ERR_UNSUPPORTED_PROTOCOL')\n}\n","'use strict'\n\nconst BufferList = require('bl/BufferList')\nconst lp = require('it-length-prefixed')\nconst pipe = require('it-pipe')\nconst errCode = require('err-code')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst first = require('it-first')\n\nconst NewLine = uint8ArrayFromString('\\n')\n\nexports.encode = buffer => lp.encode.single(new BufferList([buffer, NewLine]))\n\n// `write` encodes and writes a single buffer\nexports.write = (writer, buffer) => writer.push(exports.encode(buffer))\n\n// `writeAll` behaves like `write`, except it encodes an array of items as a single write\nexports.writeAll = (writer, buffers) => {\n writer.push(buffers.reduce((bl, buffer) => bl.append(exports.encode(buffer)), new BufferList()))\n}\n\nexports.read = async reader => {\n let byteLength = 1 // Read single byte chunks until the length is known\n const varByteSource = { // No return impl - we want the reader to remain readable\n [Symbol.asyncIterator] () { return this },\n next: () => reader.next(byteLength)\n }\n\n // Once the length has been parsed, read chunk for that length\n const onLength = l => { byteLength = l }\n const buf = await pipe(varByteSource, lp.decode({ onLength }), first)\n\n if (buf.get(buf.length - 1) !== NewLine[0]) {\n throw errCode(new Error('missing newline'), 'ERR_INVALID_MULTISTREAM_SELECT_MESSAGE')\n }\n\n return buf.shallowSlice(0, -1) // Remove newline\n}\n","'use strict'\n\nconst log = require('debug')('mss:handle')\nconst BufferList = require('bl/BufferList')\nconst multistream = require('./multistream')\nconst handshake = require('it-handshake')\nconst { PROTOCOL_ID } = require('./constants')\n\nmodule.exports = async (stream, protocols) => {\n protocols = Array.isArray(protocols) ? protocols : [protocols]\n const { writer, reader, rest, stream: shakeStream } = handshake(stream)\n\n while (true) {\n const protocol = (await multistream.read(reader)).toString()\n log('read \"%s\"', protocol)\n\n if (protocol === PROTOCOL_ID) {\n log('respond with \"%s\" for \"%s\"', PROTOCOL_ID, protocol)\n multistream.write(writer, PROTOCOL_ID)\n continue\n }\n\n if (protocols.includes(protocol)) {\n multistream.write(writer, protocol)\n log('respond with \"%s\" for \"%s\"', protocol, protocol)\n rest()\n return { stream: shakeStream, protocol }\n }\n\n if (protocol === 'ls') {\n // \\n\\n\\n\n multistream.write(writer, new BufferList(\n protocols.map(p => multistream.encode(p))\n ))\n log('respond with \"%s\" for %s', protocols, protocol)\n continue\n }\n\n multistream.write(writer, 'na')\n log('respond with \"na\" for \"%s\"', protocol)\n }\n}\n","'use strict'\n\nexports.PROTOCOL_ID = '/multistream/1.0.0'\n","'use strict'\n\nconst Reader = require('it-reader')\nconst log = require('debug')('it-multistream-select:ls')\nconst multistream = require('./multistream')\nconst handshake = require('it-handshake')\nconst lp = require('it-length-prefixed')\nconst pipe = require('it-pipe')\n\nmodule.exports = async stream => {\n const { reader, writer, rest, stream: shakeStream } = handshake(stream)\n\n log('write \"ls\"')\n multistream.write(writer, 'ls')\n rest()\n\n // Next message from remote will be (e.g. for 2 protocols):\n // \\n\\n\n const res = await multistream.read(reader)\n\n // After reading response we have:\n // \\n\\n\n const protocolsReader = Reader([res])\n const protocols = []\n\n // Decode each of the protocols from the reader\n await pipe(\n protocolsReader,\n lp.decode(),\n async source => {\n for await (const protocol of source) {\n // Remove the newline\n protocols.push(protocol.shallowSlice(0, -1).toString())\n }\n }\n )\n\n return { stream: shakeStream, protocols }\n}\n","'use strict'\n\nexports.Connection = require('./connection')\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\nconst errCode = require('err-code')\nconst { OPEN, CLOSING, CLOSED } = require('./status')\n\nconst connectionSymbol = Symbol.for('@libp2p/interface-connection/connection')\n\n/**\n * @typedef {import('../stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('./status').Status} Status\n */\n\n/**\n * @typedef {Object} Timeline\n * @property {number} open - connection opening timestamp.\n * @property {number} [upgraded] - connection upgraded timestamp.\n * @property {number} [close]\n *\n * @typedef {Object} ConectionStat\n * @property {'inbound' | 'outbound'} direction - connection establishment direction\n * @property {Timeline} timeline - connection relevant events timestamp.\n * @property {string} [multiplexer] - connection multiplexing identifier.\n * @property {string} [encryption] - connection encryption method identifier.\n *\n * @typedef {(protocols: string|string[]) => Promise<{stream: MuxedStream, protocol: string}>} CreatedMuxedStream\n *\n * @typedef {Object} ConnectionOptions\n * @property {Multiaddr} [localAddr] - local multiaddr of the connection if known.\n * @property {Multiaddr} remoteAddr - remote multiaddr of the connection.\n * @property {PeerId} localPeer - local peer-id.\n * @property {PeerId} remotePeer - remote peer-id.\n * @property {CreatedMuxedStream} newStream - new stream muxer function.\n * @property {() => Promise} close - close raw connection function.\n * @property {() => MuxedStream[]} getStreams - get streams from muxer function.\n * @property {ConectionStat} stat - metadata of the connection.\n *\n * @typedef {Object} StreamData\n * @property {string} protocol - the protocol used by the stream\n * @property {Object} [metadata] - metadata of the stream\n */\n\n/**\n * An implementation of the js-libp2p connection.\n * Any libp2p transport should use an upgrader to return this connection.\n */\nclass Connection {\n /**\n * An implementation of the js-libp2p connection.\n * Any libp2p transport should use an upgrader to return this connection.\n *\n * @class\n * @param {ConnectionOptions} options\n */\n constructor ({ localAddr, remoteAddr, localPeer, remotePeer, newStream, close, getStreams, stat }) {\n validateArgs(localAddr, localPeer, remotePeer, newStream, close, getStreams, stat)\n\n /**\n * Connection identifier.\n */\n this.id = (parseInt(String(Math.random() * 1e9))).toString(36) + Date.now()\n\n /**\n * Observed multiaddr of the local peer\n */\n this.localAddr = localAddr\n\n /**\n * Observed multiaddr of the remote peer\n */\n this.remoteAddr = remoteAddr\n\n /**\n * Local peer id.\n */\n this.localPeer = localPeer\n\n /**\n * Remote peer id.\n */\n this.remotePeer = remotePeer\n\n /**\n * Connection metadata.\n *\n * @type {ConectionStat & {status: Status}}\n */\n this._stat = {\n ...stat,\n status: OPEN\n }\n\n /**\n * Reference to the new stream function of the multiplexer\n */\n this._newStream = newStream\n\n /**\n * Reference to the close function of the raw connection\n */\n this._close = close\n\n /**\n * Reference to the getStreams function of the muxer\n */\n this._getStreams = getStreams\n\n /**\n * Connection streams registry\n */\n this.registry = new Map()\n\n /**\n * User provided tags\n *\n * @type {string[]}\n */\n this.tags = []\n }\n\n get [Symbol.toStringTag] () {\n return 'Connection'\n }\n\n get [connectionSymbol] () {\n return true\n }\n\n /**\n * Checks if the given value is a `Connection` instance.\n *\n * @param {any} other\n * @returns {other is Connection}\n */\n static isConnection (other) {\n return Boolean(other && other[connectionSymbol])\n }\n\n /**\n * Get connection metadata\n *\n * @this {Connection}\n */\n get stat () {\n return this._stat\n }\n\n /**\n * Get all the streams of the muxer.\n *\n * @this {Connection}\n */\n get streams () {\n return this._getStreams()\n }\n\n /**\n * Create a new stream from this connection\n *\n * @param {string|string[]} protocols - intended protocol for the stream\n * @returns {Promise<{stream: MuxedStream, protocol: string}>} with muxed+multistream-selected stream and selected protocol\n */\n async newStream (protocols) {\n if (this.stat.status === CLOSING) {\n throw errCode(new Error('the connection is being closed'), 'ERR_CONNECTION_BEING_CLOSED')\n }\n\n if (this.stat.status === CLOSED) {\n throw errCode(new Error('the connection is closed'), 'ERR_CONNECTION_CLOSED')\n }\n\n if (!Array.isArray(protocols)) protocols = [protocols]\n\n const { stream, protocol } = await this._newStream(protocols)\n\n this.addStream(stream, { protocol })\n\n return {\n stream,\n protocol\n }\n }\n\n /**\n * Add a stream when it is opened to the registry.\n *\n * @param {MuxedStream} muxedStream - a muxed stream\n * @param {StreamData} data - the stream data to be registered\n * @returns {void}\n */\n addStream (muxedStream, { protocol, metadata = {} }) {\n // Add metadata for the stream\n this.registry.set(muxedStream.id, {\n protocol,\n ...metadata\n })\n }\n\n /**\n * Remove stream registry after it is closed.\n *\n * @param {string} id - identifier of the stream\n */\n removeStream (id) {\n this.registry.delete(id)\n }\n\n /**\n * Close the connection.\n *\n * @returns {Promise}\n */\n async close () {\n if (this.stat.status === CLOSED) {\n return\n }\n\n if (this._closing) {\n return this._closing\n }\n\n this.stat.status = CLOSING\n\n // Close raw connection\n this._closing = await this._close()\n\n this._stat.timeline.close = Date.now()\n this.stat.status = CLOSED\n }\n}\n\nmodule.exports = Connection\n\n/**\n * @param {Multiaddr|undefined} localAddr\n * @param {PeerId} localPeer\n * @param {PeerId} remotePeer\n * @param {(protocols: string | string[]) => Promise<{ stream: import(\"../stream-muxer/types\").MuxedStream; protocol: string; }>} newStream\n * @param {() => Promise} close\n * @param {() => import(\"../stream-muxer/types\").MuxedStream[]} getStreams\n * @param {{ direction: any; timeline: any; multiplexer?: string | undefined; encryption?: string | undefined; }} stat\n */\nfunction validateArgs (localAddr, localPeer, remotePeer, newStream, close, getStreams, stat) {\n if (localAddr && !Multiaddr.isMultiaddr(localAddr)) {\n throw errCode(new Error('localAddr must be an instance of multiaddr'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!PeerId.isPeerId(localPeer)) {\n throw errCode(new Error('localPeer must be an instance of peer-id'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!PeerId.isPeerId(remotePeer)) {\n throw errCode(new Error('remotePeer must be an instance of peer-id'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (typeof newStream !== 'function') {\n throw errCode(new Error('new stream must be a function'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (typeof close !== 'function') {\n throw errCode(new Error('close must be a function'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (typeof getStreams !== 'function') {\n throw errCode(new Error('getStreams must be a function'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!stat) {\n throw errCode(new Error('connection metadata object must be provided'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (stat.direction !== 'inbound' && stat.direction !== 'outbound') {\n throw errCode(new Error('direction must be \"inbound\" or \"outbound\"'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!stat.timeline) {\n throw errCode(new Error('connection timeline object must be provided in the stat object'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!stat.timeline.open) {\n throw errCode(new Error('connection open timestamp must be provided'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!stat.timeline.upgraded) {\n throw errCode(new Error('connection upgraded timestamp must be provided'), 'ERR_INVALID_PARAMETERS')\n }\n}\n","'use strict'\n\nconst STATUS = {\n OPEN: /** @type {'open'} */('open'),\n CLOSING: /** @type {'closing'} */('closing'),\n CLOSED: /** @type {'closed'} */('closed')\n}\nmodule.exports = STATUS\n\n/**\n * @typedef {STATUS[keyof STATUS]} Status\n */\n","'use strict';\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nmodule.exports = function mutableProxyFactory(defaultTarget) {\n var mutableHandler = void 0;\n var mutableTarget = void 0;\n\n function setTarget(target) {\n if (!(target instanceof Object)) {\n throw new Error('Target \"' + target + '\" is not an object');\n }\n mutableTarget = target;\n }\n\n function setHandler(handler) {\n Object.keys(handler).forEach(function (key) {\n var value = handler[key];\n\n if (typeof value !== 'function') {\n throw new Error('Trap \"' + key + ': ' + value + '\" is not a function');\n }\n\n if (!Reflect[key]) {\n throw new Error('Trap \"' + key + ': ' + value + '\" is not a valid trap');\n }\n });\n mutableHandler = handler;\n }\n setTarget(function () {});\n\n if (defaultTarget) {\n setTarget(defaultTarget);\n }\n setHandler(Reflect);\n\n // Dynamically forward all the traps to the associated methods on the mutable handler\n var handler = new Proxy({}, {\n get: function get(target, property) {\n return function () {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return mutableHandler[property].apply(null, [mutableTarget].concat(_toConsumableArray(args.slice(1))));\n };\n }\n });\n\n return {\n setTarget: setTarget,\n setHandler: setHandler,\n getTarget: function getTarget() {\n return mutableTarget;\n },\n getHandler: function getHandler() {\n return mutableHandler;\n },\n\n proxy: new Proxy(mutableTarget, handler)\n };\n};","'use strict'\n\nconst errcode = require('err-code')\n\nconst { EventEmitter } = require('events')\nconst PeerId = require('peer-id')\n\nconst AddressBook = require('./address-book')\nconst KeyBook = require('./key-book')\nconst MetadataBook = require('./metadata-book')\nconst ProtoBook = require('./proto-book')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @typedef {import('./address-book').Address} Address\n */\n\n/**\n * @extends {EventEmitter}\n *\n * @fires PeerStore#peer Emitted when a new peer is added.\n * @fires PeerStore#change:protocols Emitted when a known peer supports a different set of protocols.\n * @fires PeerStore#change:multiaddrs Emitted when a known peer has a different set of multiaddrs.\n * @fires PeerStore#change:pubkey Emitted emitted when a peer's public key is known.\n * @fires PeerStore#change:metadata Emitted when the known metadata of a peer change.\n */\nclass PeerStore extends EventEmitter {\n /**\n * Peer object\n *\n * @typedef {Object} Peer\n * @property {PeerId} id peer's peer-id instance.\n * @property {Address[]} addresses peer's addresses containing its multiaddrs and metadata.\n * @property {string[]} protocols peer's supported protocols.\n * @property {Map|undefined} metadata peer's metadata map.\n */\n\n /**\n * Responsible for managing known peers, as well as their addresses, protocols and metadata.\n *\n * @param {object} options\n * @param {PeerId} options.peerId\n * @class\n */\n constructor ({ peerId }) {\n super()\n\n this._peerId = peerId\n\n /**\n * AddressBook containing a map of peerIdStr to Address.\n */\n this.addressBook = new AddressBook(this)\n\n /**\n * KeyBook containing a map of peerIdStr to their PeerId with public keys.\n */\n this.keyBook = new KeyBook(this)\n\n /**\n * MetadataBook containing a map of peerIdStr to their metadata Map.\n */\n this.metadataBook = new MetadataBook(this)\n\n /**\n * ProtoBook containing a map of peerIdStr to supported protocols.\n */\n this.protoBook = new ProtoBook(this)\n }\n\n /**\n * Start the PeerStore.\n */\n start () {}\n\n /**\n * Stop the PeerStore.\n */\n stop () {}\n\n /**\n * Get all the stored information of every peer known.\n *\n * @returns {Map}\n */\n get peers () {\n const storedPeers = new Set([\n ...this.addressBook.data.keys(),\n ...this.keyBook.data.keys(),\n ...this.protoBook.data.keys(),\n ...this.metadataBook.data.keys()\n ])\n\n // Remove self peer if present\n this._peerId && storedPeers.delete(this._peerId.toB58String())\n\n const peersData = new Map()\n storedPeers.forEach((idStr) => {\n peersData.set(idStr, this.get(PeerId.createFromB58String(idStr)))\n })\n\n return peersData\n }\n\n /**\n * Delete the information of the given peer in every book.\n *\n * @param {PeerId} peerId\n * @returns {boolean} true if found and removed\n */\n delete (peerId) {\n const addressesDeleted = this.addressBook.delete(peerId)\n const keyDeleted = this.keyBook.delete(peerId)\n const protocolsDeleted = this.protoBook.delete(peerId)\n const metadataDeleted = this.metadataBook.delete(peerId)\n\n return addressesDeleted || keyDeleted || protocolsDeleted || metadataDeleted\n }\n\n /**\n * Get the stored information of a given peer.\n *\n * @param {PeerId} peerId\n * @returns {Peer|undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const id = this.keyBook.data.get(peerId.toB58String())\n const addresses = this.addressBook.get(peerId)\n const metadata = this.metadataBook.get(peerId)\n const protocols = this.protoBook.get(peerId)\n\n if (!id && !addresses && !metadata && !protocols) {\n return undefined\n }\n\n return {\n id: id || peerId,\n addresses: addresses || [],\n protocols: protocols || [],\n metadata: metadata\n }\n }\n}\n\nmodule.exports = PeerStore\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-store:address-book'), {\n error: debug('libp2p:peer-store:address-book:err')\n})\nconst errcode = require('err-code')\n\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\n\nconst Book = require('./book')\nconst PeerRecord = require('../record/peer-record')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\nconst Envelope = require('../record/envelope')\n\n/**\n * @typedef {import('./')} PeerStore\n */\n\n/**\n * @typedef {Object} Address\n * @property {Multiaddr} multiaddr peer multiaddr.\n * @property {boolean} isCertified obtained from a signed peer record.\n *\n * @typedef {Object} CertifiedRecord\n * @property {Uint8Array} raw raw envelope.\n * @property {number} seqNumber seq counter.\n *\n * @typedef {Object} Entry\n * @property {Address[]} addresses peer Addresses.\n * @property {CertifiedRecord} record certified peer record.\n */\n\n/**\n * @extends {Book}\n */\nclass AddressBook extends Book {\n /**\n * The AddressBook is responsible for keeping the known multiaddrs of a peer.\n *\n * @class\n * @param {PeerStore} peerStore\n */\n constructor (peerStore) {\n /**\n * PeerStore Event emitter, used by the AddressBook to emit:\n * \"peer\" - emitted when a peer is discovered by the node.\n * \"change:multiaddrs\" - emitted when the known multiaddrs of a peer change.\n */\n super({\n peerStore,\n eventName: 'change:multiaddrs',\n eventProperty: 'multiaddrs',\n eventTransformer: (data) => {\n if (!data.addresses) {\n return []\n }\n return data.addresses.map((/** @type {Address} */ address) => address.multiaddr)\n }\n })\n\n /**\n * Map known peers to their known Address Entries.\n *\n * @type {Map}\n */\n this.data = new Map()\n }\n\n /**\n * ConsumePeerRecord adds addresses from a signed peer record contained in a record envelope.\n * This will return a boolean that indicates if the record was successfully processed and added\n * into the AddressBook.\n *\n * @param {Envelope} envelope\n * @returns {boolean}\n */\n consumePeerRecord (envelope) {\n let peerRecord\n try {\n peerRecord = PeerRecord.createFromProtobuf(envelope.payload)\n } catch (err) {\n log.error('invalid peer record received')\n return false\n }\n\n // Verify peerId\n if (!peerRecord.peerId.equals(envelope.peerId)) {\n log('signing key does not match PeerId in the PeerRecord')\n return false\n }\n\n // ensure the record has multiaddrs\n if (!peerRecord.multiaddrs || !peerRecord.multiaddrs.length) {\n return false\n }\n\n const peerId = peerRecord.peerId\n const id = peerId.toB58String()\n const entry = this.data.get(id) || { record: undefined }\n const storedRecord = entry.record\n\n // ensure seq is greater than, or equal to, the last received\n if (storedRecord && storedRecord.seqNumber >= peerRecord.seqNumber) {\n return false\n }\n\n const addresses = this._toAddresses(peerRecord.multiaddrs, true)\n\n // Replace unsigned addresses by the new ones from the record\n // TODO: Once we have ttls for the addresses, we should merge these in.\n this._setData(peerId, {\n addresses,\n record: {\n raw: envelope.marshal(),\n seqNumber: peerRecord.seqNumber\n }\n })\n log(`stored provided peer record for ${id}`)\n\n return true\n }\n\n /**\n * Get the raw Envelope for a peer. Returns\n * undefined if no Envelope is found.\n *\n * @param {PeerId} peerId\n * @returns {Uint8Array|undefined}\n */\n getRawEnvelope (peerId) {\n const entry = this.data.get(peerId.toB58String())\n\n if (!entry || !entry.record || !entry.record.raw) {\n return undefined\n }\n\n return entry.record.raw\n }\n\n /**\n * Get an Envelope containing a PeerRecord for the given peer.\n * Returns undefined if no record exists.\n *\n * @param {PeerId} peerId\n * @returns {Promise|undefined}\n */\n getPeerRecord (peerId) {\n const raw = this.getRawEnvelope(peerId)\n\n if (!raw) {\n return undefined\n }\n\n return Envelope.createFromProtobuf(raw)\n }\n\n /**\n * Set known multiaddrs of a provided peer.\n * This will replace previously stored multiaddrs, if available.\n * Replacing stored multiaddrs might result in losing obtained certified addresses.\n * If you are not sure, it's recommended to use `add` instead.\n *\n * @override\n * @param {PeerId} peerId\n * @param {Multiaddr[]} multiaddrs\n * @returns {AddressBook}\n */\n set (peerId, multiaddrs) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const addresses = this._toAddresses(multiaddrs)\n\n // Not replace multiaddrs\n if (!addresses.length) {\n return this\n }\n\n const id = peerId.toB58String()\n const entry = this.data.get(id)\n\n // Already knows the peer\n if (entry && entry.addresses && entry.addresses.length === addresses.length) {\n const intersection = entry.addresses.filter((addr) => addresses.some((newAddr) => addr.multiaddr.equals(newAddr.multiaddr)))\n\n // Are new addresses equal to the old ones?\n // If yes, no changes needed!\n if (intersection.length === entry.addresses.length) {\n log(`the addresses provided to store are equal to the already stored for ${id}`)\n return this\n }\n }\n\n this._setData(peerId, {\n addresses,\n record: entry && entry.record\n })\n log(`stored provided multiaddrs for ${id}`)\n\n // Notify the existance of a new peer\n if (!entry) {\n this._ps.emit('peer', peerId)\n }\n\n return this\n }\n\n /**\n * Add known addresses of a provided peer.\n * If the peer is not known, it is set with the given addresses.\n *\n * @param {PeerId} peerId\n * @param {Multiaddr[]} multiaddrs\n * @returns {AddressBook}\n */\n add (peerId, multiaddrs) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const addresses = this._toAddresses(multiaddrs)\n const id = peerId.toB58String()\n\n // No addresses to be added\n if (!addresses.length) {\n return this\n }\n\n const entry = this.data.get(id)\n\n if (entry && entry.addresses) {\n // Add recorded uniquely to the new array (Union)\n entry.addresses.forEach((addr) => {\n if (!addresses.find(r => r.multiaddr.equals(addr.multiaddr))) {\n addresses.push(addr)\n }\n })\n\n // If the recorded length is equal to the new after the unique union\n // The content is the same, no need to update.\n if (entry.addresses.length === addresses.length) {\n log(`the addresses provided to store are already stored for ${id}`)\n return this\n }\n }\n\n this._setData(peerId, {\n addresses,\n record: entry && entry.record\n })\n\n log(`added provided multiaddrs for ${id}`)\n\n // Notify the existance of a new peer\n if (!(entry && entry.addresses)) {\n this._ps.emit('peer', peerId)\n }\n\n return this\n }\n\n /**\n * Get the known data of a provided peer.\n *\n * @override\n * @param {PeerId} peerId\n * @returns {Address[]|undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const entry = this.data.get(peerId.toB58String())\n\n return entry && entry.addresses ? [...entry.addresses] : undefined\n }\n\n /**\n * Transforms received multiaddrs into Address.\n *\n * @private\n * @param {Multiaddr[]} multiaddrs\n * @param {boolean} [isCertified]\n * @returns {Address[]}\n */\n _toAddresses (multiaddrs, isCertified = false) {\n if (!multiaddrs) {\n log.error('multiaddrs must be provided to store data')\n throw errcode(new Error('multiaddrs must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n // create Address for each address\n /** @type {Address[]} */\n const addresses = []\n multiaddrs.forEach((addr) => {\n if (!Multiaddr.isMultiaddr(addr)) {\n log.error(`multiaddr ${addr} must be an instance of multiaddr`)\n throw errcode(new Error(`multiaddr ${addr} must be an instance of multiaddr`), ERR_INVALID_PARAMETERS)\n }\n\n // Guarantee no replicates\n if (!addresses.find((a) => a.multiaddr.equals(addr))) {\n addresses.push({\n multiaddr: addr,\n isCertified\n })\n }\n })\n\n return addresses\n }\n\n /**\n * Get the known multiaddrs for a given peer. All returned multiaddrs\n * will include the encapsulated `PeerId` of the peer.\n * Returns `undefined` if there are no known multiaddrs for the given peer.\n *\n * @param {PeerId} peerId\n * @param {(addresses: Address[]) => Address[]} [addressSorter]\n * @returns {Multiaddr[]|undefined}\n */\n getMultiaddrsForPeer (peerId, addressSorter = (ms) => ms) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const entry = this.data.get(peerId.toB58String())\n if (!entry || !entry.addresses) {\n return undefined\n }\n\n return addressSorter(\n entry.addresses || []\n ).map((address) => {\n const multiaddr = address.multiaddr\n\n const idString = multiaddr.getPeerId()\n if (idString && idString === peerId.toB58String()) return multiaddr\n\n return multiaddr.encapsulate(`/p2p/${peerId.toB58String()}`)\n })\n }\n}\n\nmodule.exports = AddressBook\n","'use strict'\n\nconst errcode = require('err-code')\nconst PeerId = require('peer-id')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @param {any} data\n */\nconst passthrough = data => data\n\n/**\n * @typedef {import('./')} PeerStore\n */\n\nclass Book {\n /**\n * The Book is the skeleton for the PeerStore books.\n *\n * @class\n * @param {Object} properties\n * @param {PeerStore} properties.peerStore - PeerStore instance.\n * @param {string} properties.eventName - Name of the event to emit by the PeerStore.\n * @param {string} properties.eventProperty - Name of the property to emit by the PeerStore.\n * @param {(data: any) => any[]} [properties.eventTransformer] - Transformer function of the provided data for being emitted.\n */\n constructor ({ peerStore, eventName, eventProperty, eventTransformer = passthrough }) {\n this._ps = peerStore\n this.eventName = eventName\n this.eventProperty = eventProperty\n this.eventTransformer = eventTransformer\n\n /**\n * Map known peers to their data.\n *\n * @type {Map}\n */\n this.data = new Map()\n }\n\n /**\n * Set known data of a provided peer.\n *\n * @param {PeerId} peerId\n * @param {any[]|any} data\n */\n set (peerId, data) {\n throw errcode(new Error('set must be implemented by the subclass'), 'ERR_NOT_IMPLEMENTED')\n }\n\n /**\n * Set data into the datastructure, persistence and emit it using the provided transformers.\n *\n * @protected\n * @param {PeerId} peerId - peerId of the data to store\n * @param {any} data - data to store.\n * @param {Object} [options] - storing options.\n * @param {boolean} [options.emit = true] - emit the provided data.\n * @returns {void}\n */\n _setData (peerId, data, { emit = true } = {}) {\n const b58key = peerId.toB58String()\n\n // Store data in memory\n this.data.set(b58key, data)\n\n // Emit event\n emit && this._emit(peerId, data)\n }\n\n /**\n * Emit data.\n *\n * @protected\n * @param {PeerId} peerId\n * @param {any} [data]\n */\n _emit (peerId, data) {\n this._ps.emit(this.eventName, {\n peerId,\n [this.eventProperty]: this.eventTransformer(data)\n })\n }\n\n /**\n * Get the known data of a provided peer.\n * Returns `undefined` if there is no available data for the given peer.\n *\n * @param {PeerId} peerId\n * @returns {any[]|any|undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const rec = this.data.get(peerId.toB58String())\n\n // @ts-ignore\n return rec ? [...rec] : undefined\n }\n\n /**\n * Deletes the provided peer from the book.\n *\n * @param {PeerId} peerId\n * @returns {boolean}\n */\n delete (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!this.data.delete(peerId.toB58String())) {\n return false\n }\n\n this._emit(peerId, [])\n\n return true\n }\n}\n\nmodule.exports = Book\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-store:key-book'), {\n error: debug('libp2p:peer-store:key-book:err')\n})\nconst errcode = require('err-code')\n\nconst PeerId = require('peer-id')\n\nconst Book = require('./book')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @typedef {import('./')} PeerStore\n * @typedef {import('libp2p-crypto').PublicKey} PublicKey\n */\n\n/**\n * @extends {Book}\n */\nclass KeyBook extends Book {\n /**\n * The KeyBook is responsible for keeping the known public keys of a peer.\n *\n * @class\n * @param {PeerStore} peerStore\n */\n constructor (peerStore) {\n super({\n peerStore,\n eventName: 'change:pubkey',\n eventProperty: 'pubkey',\n eventTransformer: (data) => data.pubKey\n })\n\n /**\n * Map known peers to their known Public Key.\n *\n * @type {Map}\n */\n this.data = new Map()\n }\n\n /**\n * Set the Peer public key.\n *\n * @override\n * @param {PeerId} peerId\n * @param {PublicKey} publicKey\n * @returns {KeyBook}\n */\n set (peerId, publicKey) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const recPeerId = this.data.get(id)\n\n // If no record available, and this is valid\n if (!recPeerId && publicKey) {\n // This might be unecessary, but we want to store the PeerId\n // to avoid an async operation when reconstructing the PeerId\n peerId.pubKey = publicKey\n\n this._setData(peerId, peerId)\n log(`stored provided public key for ${id}`)\n }\n\n return this\n }\n\n /**\n * Get Public key of the given PeerId, if stored.\n *\n * @override\n * @param {PeerId} peerId\n * @returns {PublicKey | undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const rec = this.data.get(peerId.toB58String())\n\n return rec ? rec.pubKey : undefined\n }\n}\n\nmodule.exports = KeyBook\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-store:proto-book'), {\n error: debug('libp2p:peer-store:proto-book:err')\n})\nconst errcode = require('err-code')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\nconst PeerId = require('peer-id')\n\nconst Book = require('./book')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @typedef {import('./')} PeerStore\n */\n\n/**\n * @extends {Book}\n *\n * @fires MetadataBook#change:metadata\n */\nclass MetadataBook extends Book {\n /**\n * The MetadataBook is responsible for keeping the known supported\n * protocols of a peer.\n *\n * @class\n * @param {PeerStore} peerStore\n */\n constructor (peerStore) {\n /**\n * PeerStore Event emitter, used by the MetadataBook to emit:\n * \"change:metadata\" - emitted when the known metadata of a peer change.\n */\n super({\n peerStore,\n eventName: 'change:metadata',\n eventProperty: 'metadata'\n })\n\n /**\n * Map known peers to their known protocols.\n *\n * @type {Map>}\n */\n this.data = new Map()\n }\n\n /**\n * Set metadata key and value of a provided peer.\n *\n * @override\n * @param {PeerId} peerId\n * @param {string} key - metadata key\n * @param {Uint8Array} value - metadata value\n * @returns {MetadataBook}\n */\n // @ts-ignore override with more then the parameters expected in Book\n set (peerId, key, value) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (typeof key !== 'string' || !(value instanceof Uint8Array)) {\n log.error('valid key and value must be provided to store data')\n throw errcode(new Error('valid key and value must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n this._setValue(peerId, key, value)\n\n return this\n }\n\n /**\n * Set data into the datastructure\n *\n * @override\n * @param {PeerId} peerId\n * @param {string} key\n * @param {Uint8Array} value\n */\n _setValue (peerId, key, value, { emit = true } = {}) {\n const id = peerId.toB58String()\n const rec = this.data.get(id) || new Map()\n const recMap = rec.get(key)\n\n // Already exists and is equal\n if (recMap && uint8ArrayEquals(value, recMap)) {\n log(`the metadata provided to store is equal to the already stored for ${id} on ${key}`)\n return\n }\n\n rec.set(key, value)\n this.data.set(id, rec)\n\n emit && this._emit(peerId, key)\n }\n\n /**\n * Get the known data of a provided peer.\n *\n * @param {PeerId} peerId\n * @returns {Map|undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n return this.data.get(peerId.toB58String())\n }\n\n /**\n * Get specific metadata value, if it exists\n *\n * @param {PeerId} peerId\n * @param {string} key\n * @returns {Uint8Array | undefined}\n */\n getValue (peerId, key) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const rec = this.data.get(peerId.toB58String())\n return rec && rec.get(key)\n }\n\n /**\n * Deletes the provided peer from the book.\n *\n * @param {PeerId} peerId\n * @returns {boolean}\n */\n delete (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!this.data.delete(peerId.toB58String())) {\n return false\n }\n\n this._emit(peerId)\n\n return true\n }\n\n /**\n * Deletes the provided peer metadata key from the book.\n *\n * @param {PeerId} peerId\n * @param {string} key\n * @returns {boolean}\n */\n deleteValue (peerId, key) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const rec = this.data.get(peerId.toB58String())\n\n if (!rec || !rec.delete(key)) {\n return false\n }\n\n this._emit(peerId, key)\n\n return true\n }\n}\n\nmodule.exports = MetadataBook\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-store:proto-book'), {\n error: debug('libp2p:peer-store:proto-book:err')\n})\nconst errcode = require('err-code')\nconst PeerId = require('peer-id')\n\nconst Book = require('./book')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @typedef {import('./')} PeerStore\n */\n\n/**\n * @extends {Book}\n *\n * @fires ProtoBook#change:protocols\n */\nclass ProtoBook extends Book {\n /**\n * The ProtoBook is responsible for keeping the known supported\n * protocols of a peer.\n *\n * @class\n * @param {PeerStore} peerStore\n */\n constructor (peerStore) {\n /**\n * PeerStore Event emitter, used by the ProtoBook to emit:\n * \"change:protocols\" - emitted when the known protocols of a peer change.\n */\n super({\n peerStore,\n eventName: 'change:protocols',\n eventProperty: 'protocols',\n eventTransformer: (data) => Array.from(data)\n })\n\n /**\n * Map known peers to their known protocols.\n *\n * @type {Map>}\n */\n this.data = new Map()\n }\n\n /**\n * Set known protocols of a provided peer.\n * If the peer was not known before, it will be added.\n *\n * @override\n * @param {PeerId} peerId\n * @param {string[]} protocols\n * @returns {ProtoBook}\n */\n set (peerId, protocols) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!protocols) {\n log.error('protocols must be provided to store data')\n throw errcode(new Error('protocols must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const recSet = this.data.get(id)\n const newSet = new Set(protocols)\n\n /**\n * @param {Set} a\n * @param {Set} b\n */\n const isSetEqual = (a, b) => a.size === b.size && [...a].every(value => b.has(value))\n\n // Already knows the peer and the recorded protocols are the same?\n // If yes, no changes needed!\n if (recSet && isSetEqual(recSet, newSet)) {\n log(`the protocols provided to store are equal to the already stored for ${id}`)\n return this\n }\n\n this._setData(peerId, newSet)\n log(`stored provided protocols for ${id}`)\n\n return this\n }\n\n /**\n * Adds known protocols of a provided peer.\n * If the peer was not known before, it will be added.\n *\n * @param {PeerId} peerId\n * @param {string[]} protocols\n * @returns {ProtoBook}\n */\n add (peerId, protocols) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!protocols) {\n log.error('protocols must be provided to store data')\n throw errcode(new Error('protocols must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const recSet = this.data.get(id) || new Set()\n const newSet = new Set([...recSet, ...protocols]) // Set Union\n\n // Any new protocol added?\n if (recSet.size === newSet.size) {\n log(`the protocols provided to store are already stored for ${id}`)\n return this\n }\n\n this._setData(peerId, newSet)\n log(`added provided protocols for ${id}`)\n\n return this\n }\n\n /**\n * Removes known protocols of a provided peer.\n * If the protocols did not exist before, nothing will be done.\n *\n * @param {PeerId} peerId\n * @param {string[]} protocols\n * @returns {ProtoBook}\n */\n remove (peerId, protocols) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!protocols) {\n log.error('protocols must be provided to store data')\n throw errcode(new Error('protocols must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const recSet = this.data.get(id)\n\n if (recSet) {\n const newSet = new Set([\n ...recSet\n ].filter((p) => !protocols.includes(p)))\n\n // Any protocol removed?\n if (recSet.size === newSet.size) {\n return this\n }\n\n this._setData(peerId, newSet)\n log(`removed provided protocols for ${id}`)\n }\n\n return this\n }\n}\n\nmodule.exports = ProtoBook\n","'use strict'\n\n// Pubsub adapter to keep API with handlers while not removed.\n/**\n * @typedef {import('libp2p-interfaces/src/pubsub').InMessage} InMessage\n * @typedef {import('libp2p-interfaces/src/pubsub')} PubsubRouter\n */\n\n/**\n * @param {{new(...args: any[]): PubsubRouter}} PubsubRouter\n * @param {import('.')} libp2p\n * @param {{ enabled: boolean; } & import(\".\").PubsubLocalOptions & import(\"libp2p-interfaces/src/pubsub\").PubsubOptions} options\n */\nfunction pubsubAdapter (PubsubRouter, libp2p, options) {\n /** @type {PubsubRouter & { _subscribeAdapter: PubsubRouter['subscribe'], _unsubscribeAdapter: PubsubRouter['unsubscribe'] }} */\n // @ts-ignore we set the extra _subscribeAdapter and _unsubscribeAdapter properties afterwards\n const pubsub = new PubsubRouter(libp2p, options)\n pubsub._subscribeAdapter = pubsub.subscribe\n pubsub._unsubscribeAdapter = pubsub.unsubscribe\n\n /**\n * Subscribes to a given topic.\n *\n * @override\n * @param {string} topic\n * @param {(msg: InMessage) => void} [handler]\n * @returns {void}\n */\n function subscribe (topic, handler) {\n // Bind provided handler\n handler && pubsub.on(topic, handler)\n pubsub._subscribeAdapter(topic)\n }\n\n /**\n * Unsubscribe from the given topic.\n *\n * @override\n * @param {string} topic\n * @param {(msg: InMessage) => void} [handler]\n * @returns {void}\n */\n function unsubscribe (topic, handler) {\n if (!handler) {\n pubsub.removeAllListeners(topic)\n } else {\n pubsub.removeListener(topic, handler)\n }\n\n if (pubsub.listenerCount(topic) === 0) {\n pubsub._unsubscribeAdapter(topic)\n }\n }\n\n pubsub.subscribe = subscribe\n pubsub.unsubscribe = unsubscribe\n\n return pubsub\n}\n\nmodule.exports = pubsubAdapter\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:persistent-peer-store'), {\n error: debug('libp2p:persistent-peer-store:err')\n})\nconst { Key } = require('interface-datastore/key')\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\nconst { base32 } = require('multiformats/bases/base32')\n\nconst PeerStore = require('..')\n\nconst {\n NAMESPACE_ADDRESS,\n NAMESPACE_COMMON,\n NAMESPACE_KEYS,\n NAMESPACE_METADATA,\n NAMESPACE_PROTOCOL\n} = require('./consts')\n\nconst { Addresses } = require('./pb/address-book')\nconst { Protocols } = require('./pb/proto-book')\n\n/**\n * @typedef {import('interface-datastore').Batch} Batch\n * @typedef {import('../address-book.js').Address} Address\n */\n\n/**\n * @typedef {Object} PersistentPeerStoreProperties\n * @property {PeerId} peerId\n * @property {import('interface-datastore').Datastore} datastore\n *\n * @typedef {Object} PersistentPeerStoreOptions\n * @property {number} [threshold = 5] - Number of dirty peers allowed before commit data.\n */\n\n/**\n * Responsible for managing the persistence of data in the PeerStore.\n */\nclass PersistentPeerStore extends PeerStore {\n /**\n * @class\n * @param {PersistentPeerStoreProperties & PersistentPeerStoreOptions} properties\n */\n constructor ({ peerId, datastore, threshold = 5 }) {\n super({ peerId })\n\n /**\n * Backend datastore used to persist data.\n */\n this._datastore = datastore\n\n /**\n * Peers modified after the latest data persisted.\n */\n this._dirtyPeers = new Set()\n\n /**\n * Peers metadata changed mapping peer identifers to metadata changed.\n *\n * @type {Map>}\n */\n this._dirtyMetadata = new Map()\n\n this.threshold = threshold\n this._addDirtyPeer = this._addDirtyPeer.bind(this)\n }\n\n /**\n * Start Persistent PeerStore.\n *\n * @returns {Promise}\n */\n async start () {\n log('PeerStore is starting')\n\n // Handlers for dirty peers\n this.on('change:protocols', this._addDirtyPeer)\n this.on('change:multiaddrs', this._addDirtyPeer)\n this.on('change:pubkey', this._addDirtyPeerKey)\n this.on('change:metadata', this._addDirtyPeerMetadata)\n\n // Load data\n for await (const entry of this._datastore.query({ prefix: NAMESPACE_COMMON })) {\n await this._processDatastoreEntry(entry)\n }\n\n log('PeerStore started')\n }\n\n /**\n * Stop Persistent PeerStore.\n *\n * @returns {Promise}\n */\n async stop () {\n log('PeerStore is stopping')\n this.removeAllListeners()\n await this._commitData()\n log('PeerStore stopped')\n }\n\n /**\n * Add modified peer to the dirty set\n *\n * @private\n * @param {Object} params\n * @param {PeerId} params.peerId\n */\n _addDirtyPeer ({ peerId }) {\n const peerIdstr = peerId.toB58String()\n\n log('add dirty peer', peerIdstr)\n this._dirtyPeers.add(peerIdstr)\n\n if (this._dirtyPeers.size >= this.threshold) {\n // Commit current data\n this._commitData().catch(err => {\n log.error('error committing data', err)\n })\n }\n }\n\n /**\n * Add modified peer key to the dirty set\n *\n * @private\n * @param {Object} params\n * @param {PeerId} params.peerId\n */\n _addDirtyPeerKey ({ peerId }) {\n // Not add if inline key available\n if (peerId.hasInlinePublicKey()) {\n return\n }\n\n const peerIdstr = peerId.toB58String()\n\n log('add dirty peer key', peerIdstr)\n this._dirtyPeers.add(peerIdstr)\n\n if (this._dirtyPeers.size >= this.threshold) {\n // Commit current data\n this._commitData().catch(err => {\n log.error('error committing data', err)\n })\n }\n }\n\n /**\n * Add modified metadata peer to the set.\n *\n * @private\n * @param {Object} params\n * @param {PeerId} params.peerId\n * @param {string} params.metadata\n */\n _addDirtyPeerMetadata ({ peerId, metadata }) {\n const peerIdstr = peerId.toB58String()\n\n log('add dirty metadata peer', peerIdstr)\n this._dirtyPeers.add(peerIdstr)\n\n // Add dirty metadata key\n const mData = this._dirtyMetadata.get(peerIdstr) || new Set()\n mData.add(metadata)\n this._dirtyMetadata.set(peerIdstr, mData)\n\n if (this._dirtyPeers.size >= this.threshold) {\n // Commit current data\n this._commitData().catch(err => {\n log.error('error committing data', err)\n })\n }\n }\n\n /**\n * Add all the peers current data to a datastore batch and commit it.\n *\n * @private\n * @returns {Promise}\n */\n async _commitData () {\n const commitPeers = Array.from(this._dirtyPeers)\n\n if (!commitPeers.length) {\n return\n }\n\n // Clear Dirty Peers set\n this._dirtyPeers.clear()\n\n log('create batch commit')\n const batch = this._datastore.batch()\n for (const peerIdStr of commitPeers) {\n // PeerId\n const peerId = this.keyBook.data.get(peerIdStr) || PeerId.createFromB58String(peerIdStr)\n\n // Address Book\n this._batchAddressBook(peerId, batch)\n\n // Key Book\n !peerId.hasInlinePublicKey() && this._batchKeyBook(peerId, batch)\n\n // Metadata Book\n this._batchMetadataBook(peerId, batch)\n\n // Proto Book\n this._batchProtoBook(peerId, batch)\n }\n\n await batch.commit()\n log('batch committed')\n }\n\n /**\n * Add address book data of the peer to the batch.\n *\n * @private\n * @param {PeerId} peerId\n * @param {Batch} batch\n */\n _batchAddressBook (peerId, batch) {\n const b32key = peerId.toString()\n const key = new Key(`${NAMESPACE_ADDRESS}${b32key}`)\n\n const entry = this.addressBook.data.get(peerId.toB58String())\n\n try {\n // Deleted from the book\n if (!entry) {\n batch.delete(key)\n return\n }\n\n const encodedData = Addresses.encode({\n addrs: entry.addresses.map((address) => ({\n multiaddr: address.multiaddr.bytes,\n isCertified: address.isCertified\n })),\n certifiedRecord: entry.record\n ? {\n seq: entry.record.seqNumber,\n raw: entry.record.raw\n }\n : undefined\n }).finish()\n\n batch.put(key, encodedData)\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Add Key book data of the peer to the batch.\n *\n * @private\n * @param {PeerId} peerId\n * @param {Batch} batch\n */\n _batchKeyBook (peerId, batch) {\n const b32key = peerId.toString()\n const key = new Key(`${NAMESPACE_KEYS}${b32key}`)\n\n try {\n // Deleted from the book\n if (!peerId.pubKey) {\n batch.delete(key)\n return\n }\n\n const encodedData = peerId.marshalPubKey()\n\n batch.put(key, encodedData)\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Add metadata book data of the peer to the batch.\n *\n * @private\n * @param {PeerId} peerId\n * @param {Batch} batch\n */\n _batchMetadataBook (peerId, batch) {\n const b32key = peerId.toString()\n const dirtyMetada = this._dirtyMetadata.get(peerId.toB58String()) || []\n\n try {\n dirtyMetada.forEach((/** @type {string} */ dirtyKey) => {\n const key = new Key(`${NAMESPACE_METADATA}${b32key}/${dirtyKey}`)\n const dirtyValue = this.metadataBook.getValue(peerId, dirtyKey)\n\n if (dirtyValue) {\n batch.put(key, dirtyValue)\n } else {\n batch.delete(key)\n }\n })\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Add proto book data of the peer to the batch.\n *\n * @private\n * @param {PeerId} peerId\n * @param {Batch} batch\n */\n _batchProtoBook (peerId, batch) {\n const b32key = peerId.toString()\n const key = new Key(`${NAMESPACE_PROTOCOL}${b32key}`)\n\n const protocols = this.protoBook.get(peerId)\n\n try {\n // Deleted from the book\n if (!protocols) {\n batch.delete(key)\n return\n }\n\n const encodedData = Protocols.encode({ protocols }).finish()\n\n batch.put(key, encodedData)\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Process datastore entry and add its data to the correct book.\n *\n * @private\n * @param {Object} params\n * @param {Key} params.key - datastore key\n * @param {Uint8Array} params.value - datastore value stored\n * @returns {Promise}\n */\n async _processDatastoreEntry ({ key, value }) {\n try {\n const keyParts = key.toString().split('/')\n const peerId = PeerId.createFromBytes(base32.decode(keyParts[3]))\n\n let decoded\n switch (keyParts[2]) {\n case 'addrs':\n decoded = Addresses.decode(value)\n\n // @ts-ignore protected function\n this.addressBook._setData(\n peerId,\n {\n addresses: decoded.addrs.map((address) => ({\n multiaddr: new Multiaddr(address.multiaddr),\n isCertified: Boolean(address.isCertified)\n })),\n record: decoded.certifiedRecord\n ? {\n raw: decoded.certifiedRecord.raw,\n seqNumber: decoded.certifiedRecord.seq\n }\n : undefined\n },\n { emit: false })\n break\n case 'keys':\n decoded = await PeerId.createFromPubKey(value)\n\n // @ts-ignore protected function\n this.keyBook._setData(\n decoded,\n decoded,\n { emit: false })\n break\n case 'metadata':\n this.metadataBook._setValue(\n peerId,\n keyParts[4],\n value,\n { emit: false })\n break\n case 'protos':\n decoded = Protocols.decode(value)\n\n // @ts-ignore protected function\n this.protoBook._setData(\n peerId,\n new Set(decoded.protocols),\n { emit: false })\n break\n default:\n log('invalid data persisted for: ', key.toString())\n }\n } catch (err) {\n log.error(err)\n }\n }\n}\n\nmodule.exports = PersistentPeerStore\n","'use strict'\n\nmodule.exports.NAMESPACE_COMMON = '/peers/'\n\n// /peers/protos/\nmodule.exports.NAMESPACE_ADDRESS = '/peers/addrs/'\n\n// /peers/keys/\nmodule.exports.NAMESPACE_KEYS = '/peers/keys/'\n\n// /peers/metadata//\nmodule.exports.NAMESPACE_METADATA = '/peers/metadata/'\n\n// /peers/addrs/\nmodule.exports.NAMESPACE_PROTOCOL = '/peers/protos/'\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-address-book\"] || ($protobuf.roots[\"libp2p-address-book\"] = {});\n\n$root.Addresses = (function() {\n\n /**\n * Properties of an Addresses.\n * @exports IAddresses\n * @interface IAddresses\n * @property {Array.|null} [addrs] Addresses addrs\n * @property {Addresses.ICertifiedRecord|null} [certifiedRecord] Addresses certifiedRecord\n */\n\n /**\n * Constructs a new Addresses.\n * @exports Addresses\n * @classdesc Represents an Addresses.\n * @implements IAddresses\n * @constructor\n * @param {IAddresses=} [p] Properties to set\n */\n function Addresses(p) {\n this.addrs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Addresses addrs.\n * @member {Array.} addrs\n * @memberof Addresses\n * @instance\n */\n Addresses.prototype.addrs = $util.emptyArray;\n\n /**\n * Addresses certifiedRecord.\n * @member {Addresses.ICertifiedRecord|null|undefined} certifiedRecord\n * @memberof Addresses\n * @instance\n */\n Addresses.prototype.certifiedRecord = null;\n\n /**\n * Encodes the specified Addresses message. Does not implicitly {@link Addresses.verify|verify} messages.\n * @function encode\n * @memberof Addresses\n * @static\n * @param {IAddresses} m Addresses message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Addresses.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.addrs != null && m.addrs.length) {\n for (var i = 0; i < m.addrs.length; ++i)\n $root.Addresses.Address.encode(m.addrs[i], w.uint32(10).fork()).ldelim();\n }\n if (m.certifiedRecord != null && Object.hasOwnProperty.call(m, \"certifiedRecord\"))\n $root.Addresses.CertifiedRecord.encode(m.certifiedRecord, w.uint32(18).fork()).ldelim();\n return w;\n };\n\n /**\n * Decodes an Addresses message from the specified reader or buffer.\n * @function decode\n * @memberof Addresses\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Addresses} Addresses\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Addresses.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Addresses();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.addrs && m.addrs.length))\n m.addrs = [];\n m.addrs.push($root.Addresses.Address.decode(r, r.uint32()));\n break;\n case 2:\n m.certifiedRecord = $root.Addresses.CertifiedRecord.decode(r, r.uint32());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an Addresses message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Addresses\n * @static\n * @param {Object.} d Plain object\n * @returns {Addresses} Addresses\n */\n Addresses.fromObject = function fromObject(d) {\n if (d instanceof $root.Addresses)\n return d;\n var m = new $root.Addresses();\n if (d.addrs) {\n if (!Array.isArray(d.addrs))\n throw TypeError(\".Addresses.addrs: array expected\");\n m.addrs = [];\n for (var i = 0; i < d.addrs.length; ++i) {\n if (typeof d.addrs[i] !== \"object\")\n throw TypeError(\".Addresses.addrs: object expected\");\n m.addrs[i] = $root.Addresses.Address.fromObject(d.addrs[i]);\n }\n }\n if (d.certifiedRecord != null) {\n if (typeof d.certifiedRecord !== \"object\")\n throw TypeError(\".Addresses.certifiedRecord: object expected\");\n m.certifiedRecord = $root.Addresses.CertifiedRecord.fromObject(d.certifiedRecord);\n }\n return m;\n };\n\n /**\n * Creates a plain object from an Addresses message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Addresses\n * @static\n * @param {Addresses} m Addresses\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Addresses.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.addrs = [];\n }\n if (o.defaults) {\n d.certifiedRecord = null;\n }\n if (m.addrs && m.addrs.length) {\n d.addrs = [];\n for (var j = 0; j < m.addrs.length; ++j) {\n d.addrs[j] = $root.Addresses.Address.toObject(m.addrs[j], o);\n }\n }\n if (m.certifiedRecord != null && m.hasOwnProperty(\"certifiedRecord\")) {\n d.certifiedRecord = $root.Addresses.CertifiedRecord.toObject(m.certifiedRecord, o);\n }\n return d;\n };\n\n /**\n * Converts this Addresses to JSON.\n * @function toJSON\n * @memberof Addresses\n * @instance\n * @returns {Object.} JSON object\n */\n Addresses.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n Addresses.Address = (function() {\n\n /**\n * Properties of an Address.\n * @memberof Addresses\n * @interface IAddress\n * @property {Uint8Array|null} [multiaddr] Address multiaddr\n * @property {boolean|null} [isCertified] Address isCertified\n */\n\n /**\n * Constructs a new Address.\n * @memberof Addresses\n * @classdesc Represents an Address.\n * @implements IAddress\n * @constructor\n * @param {Addresses.IAddress=} [p] Properties to set\n */\n function Address(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Address multiaddr.\n * @member {Uint8Array} multiaddr\n * @memberof Addresses.Address\n * @instance\n */\n Address.prototype.multiaddr = $util.newBuffer([]);\n\n /**\n * Address isCertified.\n * @member {boolean} isCertified\n * @memberof Addresses.Address\n * @instance\n */\n Address.prototype.isCertified = false;\n\n /**\n * Encodes the specified Address message. Does not implicitly {@link Addresses.Address.verify|verify} messages.\n * @function encode\n * @memberof Addresses.Address\n * @static\n * @param {Addresses.IAddress} m Address message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Address.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.multiaddr != null && Object.hasOwnProperty.call(m, \"multiaddr\"))\n w.uint32(10).bytes(m.multiaddr);\n if (m.isCertified != null && Object.hasOwnProperty.call(m, \"isCertified\"))\n w.uint32(16).bool(m.isCertified);\n return w;\n };\n\n /**\n * Decodes an Address message from the specified reader or buffer.\n * @function decode\n * @memberof Addresses.Address\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Addresses.Address} Address\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Address.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Addresses.Address();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.multiaddr = r.bytes();\n break;\n case 2:\n m.isCertified = r.bool();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an Address message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Addresses.Address\n * @static\n * @param {Object.} d Plain object\n * @returns {Addresses.Address} Address\n */\n Address.fromObject = function fromObject(d) {\n if (d instanceof $root.Addresses.Address)\n return d;\n var m = new $root.Addresses.Address();\n if (d.multiaddr != null) {\n if (typeof d.multiaddr === \"string\")\n $util.base64.decode(d.multiaddr, m.multiaddr = $util.newBuffer($util.base64.length(d.multiaddr)), 0);\n else if (d.multiaddr.length)\n m.multiaddr = d.multiaddr;\n }\n if (d.isCertified != null) {\n m.isCertified = Boolean(d.isCertified);\n }\n return m;\n };\n\n /**\n * Creates a plain object from an Address message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Addresses.Address\n * @static\n * @param {Addresses.Address} m Address\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Address.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.multiaddr = \"\";\n else {\n d.multiaddr = [];\n if (o.bytes !== Array)\n d.multiaddr = $util.newBuffer(d.multiaddr);\n }\n d.isCertified = false;\n }\n if (m.multiaddr != null && m.hasOwnProperty(\"multiaddr\")) {\n d.multiaddr = o.bytes === String ? $util.base64.encode(m.multiaddr, 0, m.multiaddr.length) : o.bytes === Array ? Array.prototype.slice.call(m.multiaddr) : m.multiaddr;\n }\n if (m.isCertified != null && m.hasOwnProperty(\"isCertified\")) {\n d.isCertified = m.isCertified;\n }\n return d;\n };\n\n /**\n * Converts this Address to JSON.\n * @function toJSON\n * @memberof Addresses.Address\n * @instance\n * @returns {Object.} JSON object\n */\n Address.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Address;\n })();\n\n Addresses.CertifiedRecord = (function() {\n\n /**\n * Properties of a CertifiedRecord.\n * @memberof Addresses\n * @interface ICertifiedRecord\n * @property {number|null} [seq] CertifiedRecord seq\n * @property {Uint8Array|null} [raw] CertifiedRecord raw\n */\n\n /**\n * Constructs a new CertifiedRecord.\n * @memberof Addresses\n * @classdesc Represents a CertifiedRecord.\n * @implements ICertifiedRecord\n * @constructor\n * @param {Addresses.ICertifiedRecord=} [p] Properties to set\n */\n function CertifiedRecord(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * CertifiedRecord seq.\n * @member {number} seq\n * @memberof Addresses.CertifiedRecord\n * @instance\n */\n CertifiedRecord.prototype.seq = $util.Long ? $util.Long.fromBits(0,0,true) : 0;\n\n /**\n * CertifiedRecord raw.\n * @member {Uint8Array} raw\n * @memberof Addresses.CertifiedRecord\n * @instance\n */\n CertifiedRecord.prototype.raw = $util.newBuffer([]);\n\n /**\n * Encodes the specified CertifiedRecord message. Does not implicitly {@link Addresses.CertifiedRecord.verify|verify} messages.\n * @function encode\n * @memberof Addresses.CertifiedRecord\n * @static\n * @param {Addresses.ICertifiedRecord} m CertifiedRecord message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n CertifiedRecord.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.seq != null && Object.hasOwnProperty.call(m, \"seq\"))\n w.uint32(8).uint64(m.seq);\n if (m.raw != null && Object.hasOwnProperty.call(m, \"raw\"))\n w.uint32(18).bytes(m.raw);\n return w;\n };\n\n /**\n * Decodes a CertifiedRecord message from the specified reader or buffer.\n * @function decode\n * @memberof Addresses.CertifiedRecord\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Addresses.CertifiedRecord} CertifiedRecord\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n CertifiedRecord.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Addresses.CertifiedRecord();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.seq = r.uint64();\n break;\n case 2:\n m.raw = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a CertifiedRecord message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Addresses.CertifiedRecord\n * @static\n * @param {Object.} d Plain object\n * @returns {Addresses.CertifiedRecord} CertifiedRecord\n */\n CertifiedRecord.fromObject = function fromObject(d) {\n if (d instanceof $root.Addresses.CertifiedRecord)\n return d;\n var m = new $root.Addresses.CertifiedRecord();\n if (d.seq != null) {\n if ($util.Long)\n (m.seq = $util.Long.fromValue(d.seq)).unsigned = true;\n else if (typeof d.seq === \"string\")\n m.seq = parseInt(d.seq, 10);\n else if (typeof d.seq === \"number\")\n m.seq = d.seq;\n else if (typeof d.seq === \"object\")\n m.seq = new $util.LongBits(d.seq.low >>> 0, d.seq.high >>> 0).toNumber(true);\n }\n if (d.raw != null) {\n if (typeof d.raw === \"string\")\n $util.base64.decode(d.raw, m.raw = $util.newBuffer($util.base64.length(d.raw)), 0);\n else if (d.raw.length)\n m.raw = d.raw;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a CertifiedRecord message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Addresses.CertifiedRecord\n * @static\n * @param {Addresses.CertifiedRecord} m CertifiedRecord\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n CertifiedRecord.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.seq = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.seq = o.longs === String ? \"0\" : 0;\n if (o.bytes === String)\n d.raw = \"\";\n else {\n d.raw = [];\n if (o.bytes !== Array)\n d.raw = $util.newBuffer(d.raw);\n }\n }\n if (m.seq != null && m.hasOwnProperty(\"seq\")) {\n if (typeof m.seq === \"number\")\n d.seq = o.longs === String ? String(m.seq) : m.seq;\n else\n d.seq = o.longs === String ? $util.Long.prototype.toString.call(m.seq) : o.longs === Number ? new $util.LongBits(m.seq.low >>> 0, m.seq.high >>> 0).toNumber(true) : m.seq;\n }\n if (m.raw != null && m.hasOwnProperty(\"raw\")) {\n d.raw = o.bytes === String ? $util.base64.encode(m.raw, 0, m.raw.length) : o.bytes === Array ? Array.prototype.slice.call(m.raw) : m.raw;\n }\n return d;\n };\n\n /**\n * Converts this CertifiedRecord to JSON.\n * @function toJSON\n * @memberof Addresses.CertifiedRecord\n * @instance\n * @returns {Object.} JSON object\n */\n CertifiedRecord.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return CertifiedRecord;\n })();\n\n return Addresses;\n})();\n\nmodule.exports = $root;\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-proto-book\"] || ($protobuf.roots[\"libp2p-proto-book\"] = {});\n\n$root.Protocols = (function() {\n\n /**\n * Properties of a Protocols.\n * @exports IProtocols\n * @interface IProtocols\n * @property {Array.|null} [protocols] Protocols protocols\n */\n\n /**\n * Constructs a new Protocols.\n * @exports Protocols\n * @classdesc Represents a Protocols.\n * @implements IProtocols\n * @constructor\n * @param {IProtocols=} [p] Properties to set\n */\n function Protocols(p) {\n this.protocols = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Protocols protocols.\n * @member {Array.} protocols\n * @memberof Protocols\n * @instance\n */\n Protocols.prototype.protocols = $util.emptyArray;\n\n /**\n * Encodes the specified Protocols message. Does not implicitly {@link Protocols.verify|verify} messages.\n * @function encode\n * @memberof Protocols\n * @static\n * @param {IProtocols} m Protocols message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Protocols.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.protocols != null && m.protocols.length) {\n for (var i = 0; i < m.protocols.length; ++i)\n w.uint32(10).string(m.protocols[i]);\n }\n return w;\n };\n\n /**\n * Decodes a Protocols message from the specified reader or buffer.\n * @function decode\n * @memberof Protocols\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Protocols} Protocols\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Protocols.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Protocols();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.protocols && m.protocols.length))\n m.protocols = [];\n m.protocols.push(r.string());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Protocols message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Protocols\n * @static\n * @param {Object.} d Plain object\n * @returns {Protocols} Protocols\n */\n Protocols.fromObject = function fromObject(d) {\n if (d instanceof $root.Protocols)\n return d;\n var m = new $root.Protocols();\n if (d.protocols) {\n if (!Array.isArray(d.protocols))\n throw TypeError(\".Protocols.protocols: array expected\");\n m.protocols = [];\n for (var i = 0; i < d.protocols.length; ++i) {\n m.protocols[i] = String(d.protocols[i]);\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Protocols message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Protocols\n * @static\n * @param {Protocols} m Protocols\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Protocols.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.protocols = [];\n }\n if (m.protocols && m.protocols.length) {\n d.protocols = [];\n for (var j = 0; j < m.protocols.length; ++j) {\n d.protocols[j] = m.protocols[j];\n }\n }\n return d;\n };\n\n /**\n * Converts this Protocols to JSON.\n * @function toJSON\n * @memberof Protocols\n * @instance\n * @returns {Object.} JSON object\n */\n Protocols.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Protocols;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:registrar'), {\n error: debug('libp2p:registrar:err')\n})\nconst errcode = require('err-code')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('./errors')\nconst Topology = require('libp2p-interfaces/src/topology')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('./peer-store')} PeerStore\n * @typedef {import('./connection-manager')} ConnectionManager\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('./').HandlerProps} HandlerProps\n */\n\n/**\n *\n */\n\n/**\n * Responsible for notifying registered protocols of events in the network.\n */\nclass Registrar {\n /**\n * @param {Object} props\n * @param {PeerStore} props.peerStore\n * @param {ConnectionManager} props.connectionManager\n * @class\n */\n constructor ({ peerStore, connectionManager }) {\n // Used on topology to listen for protocol changes\n this.peerStore = peerStore\n\n this.connectionManager = connectionManager\n\n /**\n * Map of topologies\n *\n * @type {Map}\n */\n this.topologies = new Map()\n\n /** @type {(protocols: string[]|string, handler: (props: HandlerProps) => void) => void} */\n // @ts-ignore handle is not optional\n this._handle = undefined\n\n this._onDisconnect = this._onDisconnect.bind(this)\n this.connectionManager.on('peer:disconnect', this._onDisconnect)\n }\n\n /**\n * @returns {(protocols: string[]|string, handler: (props: HandlerProps) => void) => void}\n */\n get handle () {\n return this._handle\n }\n\n /**\n * @param {(protocols: string[]|string, handler: (props: HandlerProps) => void) => void} handle\n */\n set handle (handle) {\n this._handle = handle\n }\n\n /**\n * Get a connection with a peer.\n *\n * @param {PeerId} peerId\n * @returns {Connection | null}\n */\n getConnection (peerId) {\n return this.connectionManager.get(peerId)\n }\n\n /**\n * Register handlers for a set of multicodecs given\n *\n * @param {Topology} topology - protocol topology\n * @returns {string} registrar identifier\n */\n register (topology) {\n if (!Topology.isTopology(topology)) {\n log.error('topology must be an instance of interfaces/topology')\n throw errcode(new Error('topology must be an instance of interfaces/topology'), ERR_INVALID_PARAMETERS)\n }\n\n // Create topology\n const id = (Math.random() * 1e9).toString(36) + Date.now()\n\n this.topologies.set(id, topology)\n\n // Set registrar\n topology.registrar = this\n\n return id\n }\n\n /**\n * Unregister topology.\n *\n * @param {string} id - registrar identifier\n * @returns {boolean} unregistered successfully\n */\n unregister (id) {\n return this.topologies.delete(id)\n }\n\n /**\n * Remove a disconnected peer from the record\n *\n * @param {Connection} connection\n * @returns {void}\n */\n _onDisconnect (connection) {\n for (const [, topology] of this.topologies) {\n topology.disconnect(connection.remotePeer)\n }\n }\n}\n\nmodule.exports = Registrar\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:ping'), {\n error: debug('libp2p:ping:err')\n})\nconst errCode = require('err-code')\n\nconst crypto = require('libp2p-crypto')\nconst { pipe } = require('it-pipe')\n// @ts-ignore it-buffer has no types exported\nconst { toBuffer } = require('it-buffer')\nconst { collect, take } = require('streaming-iterables')\nconst { equals } = require('uint8arrays/equals')\n\nconst { PROTOCOL_NAME, PING_LENGTH, PROTOCOL_VERSION } = require('./constants')\n\n/**\n * @typedef {import('../')} Libp2p\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\n/**\n * Ping a given peer and wait for its response, getting the operation latency.\n *\n * @param {Libp2p} node\n * @param {PeerId|Multiaddr} peer\n * @returns {Promise}\n */\nasync function ping (node, peer) {\n const protocol = `/${node._config.protocolPrefix}/${PROTOCOL_NAME}/${PROTOCOL_VERSION}`\n // @ts-ignore multiaddr might not have toB58String\n log('dialing %s to %s', protocol, peer.toB58String ? peer.toB58String() : peer)\n\n const connection = await node.dial(peer)\n const { stream } = await connection.newStream(protocol)\n\n const start = Date.now()\n const data = crypto.randomBytes(PING_LENGTH)\n\n const [result] = await pipe(\n [data],\n stream,\n (/** @type {MuxedStream} */ stream) => take(1, stream),\n toBuffer,\n collect\n )\n const end = Date.now()\n\n if (!equals(data, result)) {\n throw errCode(new Error('Received wrong ping ack'), 'ERR_WRONG_PING_ACK')\n }\n\n return end - start\n}\n\n/**\n * Subscribe ping protocol handler.\n *\n * @param {Libp2p} node\n */\nfunction mount (node) {\n node.handle(`/${node._config.protocolPrefix}/${PROTOCOL_NAME}/${PROTOCOL_VERSION}`, ({ stream }) => pipe(stream, stream))\n}\n\n/**\n * Unsubscribe ping protocol handler.\n *\n * @param {Libp2p} node\n */\nfunction unmount (node) {\n node.unhandle(`/${node._config.protocolPrefix}/${PROTOCOL_NAME}/${PROTOCOL_VERSION}`)\n}\n\nexports = module.exports = ping\nexports.mount = mount\nexports.unmount = unmount\n","'use strict'\n\nmodule.exports = {\n PROTOCOL: '/ipfs/ping/1.0.0', // deprecated\n PING_LENGTH: 32,\n PROTOCOL_VERSION: '1.0.0',\n PROTOCOL_NAME: 'ping'\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:identify'), {\n error: debug('libp2p:identify:err')\n})\nconst errCode = require('err-code')\nconst lp = require('it-length-prefixed')\nconst { pipe } = require('it-pipe')\nconst { collect, take, consume } = require('streaming-iterables')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\n// @ts-ignore it-buffer does not have types\nconst { toBuffer } = require('it-buffer')\n\nconst Message = require('./message')\n\nconst Envelope = require('../record/envelope')\nconst PeerRecord = require('../record/peer-record')\n\nconst {\n MULTICODEC_IDENTIFY,\n MULTICODEC_IDENTIFY_PUSH,\n IDENTIFY_PROTOCOL_VERSION,\n MULTICODEC_IDENTIFY_PROTOCOL_NAME,\n MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME,\n MULTICODEC_IDENTIFY_PROTOCOL_VERSION,\n MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION\n} = require('./consts')\n\nconst { codes } = require('../errors')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\n/**\n * @typedef {Object} HostProperties\n * @property {string} agentVersion\n */\n\nclass IdentifyService {\n /**\n * @param {import('../')} libp2p\n */\n static getProtocolStr (libp2p) {\n return {\n identifyProtocolStr: `/${libp2p._config.protocolPrefix}/${MULTICODEC_IDENTIFY_PROTOCOL_NAME}/${MULTICODEC_IDENTIFY_PROTOCOL_VERSION}`,\n identifyPushProtocolStr: `/${libp2p._config.protocolPrefix}/${MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME}/${MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION}`\n }\n }\n\n /**\n * @class\n * @param {Object} options\n * @param {import('../')} options.libp2p\n */\n constructor ({ libp2p }) {\n this._libp2p = libp2p\n this.peerStore = libp2p.peerStore\n this.addressManager = libp2p.addressManager\n this.connectionManager = libp2p.connectionManager\n this.peerId = libp2p.peerId\n\n this.handleMessage = this.handleMessage.bind(this)\n\n const protocolStr = IdentifyService.getProtocolStr(libp2p)\n this.identifyProtocolStr = protocolStr.identifyProtocolStr\n this.identifyPushProtocolStr = protocolStr.identifyPushProtocolStr\n\n // Store self host metadata\n this._host = {\n protocolVersion: `${libp2p._config.protocolPrefix}/${IDENTIFY_PROTOCOL_VERSION}`,\n ...libp2p._options.host\n }\n\n this.peerStore.metadataBook.set(this.peerId, 'AgentVersion', uint8ArrayFromString(this._host.agentVersion))\n this.peerStore.metadataBook.set(this.peerId, 'ProtocolVersion', uint8ArrayFromString(this._host.protocolVersion))\n // When a new connection happens, trigger identify\n this.connectionManager.on('peer:connect', (connection) => {\n this.identify(connection).catch(log.error)\n })\n\n // When self multiaddrs change, trigger identify-push\n this.peerStore.on('change:multiaddrs', ({ peerId }) => {\n if (peerId.toString() === this.peerId.toString()) {\n this.pushToPeerStore()\n }\n })\n\n // When self protocols change, trigger identify-push\n this.peerStore.on('change:protocols', ({ peerId }) => {\n if (peerId.toString() === this.peerId.toString()) {\n this.pushToPeerStore()\n }\n })\n }\n\n /**\n * Send an Identify Push update to the list of connections\n *\n * @param {Connection[]} connections\n * @returns {Promise}\n */\n async push (connections) {\n const signedPeerRecord = await this.peerStore.addressBook.getRawEnvelope(this.peerId)\n const listenAddrs = this._libp2p.multiaddrs.map((ma) => ma.bytes)\n const protocols = this.peerStore.protoBook.get(this.peerId) || []\n\n const pushes = connections.map(async connection => {\n try {\n const { stream } = await connection.newStream(this.identifyPushProtocolStr)\n\n await pipe(\n [Message.Identify.encode({\n listenAddrs,\n signedPeerRecord,\n protocols\n }).finish()],\n lp.encode(),\n stream,\n consume\n )\n } catch (err) {\n // Just log errors\n log.error('could not push identify update to peer', err)\n }\n })\n\n return Promise.all(pushes)\n }\n\n /**\n * Calls `push` for all peers in the `peerStore` that are connected\n *\n * @returns {void}\n */\n pushToPeerStore () {\n // Do not try to push if libp2p node is not running\n if (!this._libp2p.isStarted()) {\n return\n }\n\n const connections = []\n let connection\n for (const peer of this.peerStore.peers.values()) {\n if (peer.protocols.includes(this.identifyPushProtocolStr) && (connection = this.connectionManager.get(peer.id))) {\n connections.push(connection)\n }\n }\n\n this.push(connections)\n }\n\n /**\n * Requests the `Identify` message from peer associated with the given `connection`.\n * If the identified peer does not match the `PeerId` associated with the connection,\n * an error will be thrown.\n *\n * @async\n * @param {Connection} connection\n * @returns {Promise}\n */\n async identify (connection) {\n const { stream } = await connection.newStream(this.identifyProtocolStr)\n const [data] = await pipe(\n [],\n stream,\n lp.decode(),\n take(1),\n toBuffer,\n collect\n )\n\n if (!data) {\n throw errCode(new Error('No data could be retrieved'), codes.ERR_CONNECTION_ENDED)\n }\n\n let message\n try {\n message = Message.Identify.decode(data)\n } catch (err) {\n throw errCode(err, codes.ERR_INVALID_MESSAGE)\n }\n\n const {\n publicKey,\n listenAddrs,\n protocols,\n observedAddr,\n signedPeerRecord\n } = message\n\n const id = await PeerId.createFromPubKey(publicKey)\n\n if (connection.remotePeer.toB58String() !== id.toB58String()) {\n throw errCode(new Error('identified peer does not match the expected peer'), codes.ERR_INVALID_PEER)\n }\n\n // Get the observedAddr if there is one\n const cleanObservedAddr = IdentifyService.getCleanMultiaddr(observedAddr)\n\n try {\n const envelope = await Envelope.openAndCertify(signedPeerRecord, PeerRecord.DOMAIN)\n if (this.peerStore.addressBook.consumePeerRecord(envelope)) {\n this.peerStore.protoBook.set(id, protocols)\n this.peerStore.metadataBook.set(id, 'AgentVersion', uint8ArrayFromString(message.agentVersion))\n this.peerStore.metadataBook.set(id, 'ProtocolVersion', uint8ArrayFromString(message.protocolVersion))\n return\n }\n } catch (err) {\n log('received invalid envelope, discard it and fallback to listenAddrs is available', err)\n }\n\n // LEGACY: Update peers data in PeerStore\n try {\n this.peerStore.addressBook.set(id, listenAddrs.map((addr) => new Multiaddr(addr)))\n } catch (err) {\n log.error('received invalid addrs', err)\n }\n\n this.peerStore.protoBook.set(id, protocols)\n this.peerStore.metadataBook.set(id, 'AgentVersion', uint8ArrayFromString(message.agentVersion))\n this.peerStore.metadataBook.set(id, 'ProtocolVersion', uint8ArrayFromString(message.protocolVersion))\n\n // TODO: Add and score our observed addr\n log('received observed address of %s', cleanObservedAddr)\n // this.addressManager.addObservedAddr(observedAddr)\n }\n\n /**\n * A handler to register with Libp2p to process identify messages.\n *\n * @param {Object} options\n * @param {Connection} options.connection\n * @param {MuxedStream} options.stream\n * @param {string} options.protocol\n * @returns {Promise|undefined}\n */\n handleMessage ({ connection, stream, protocol }) {\n switch (protocol) {\n case this.identifyProtocolStr:\n return this._handleIdentify({ connection, stream })\n case this.identifyPushProtocolStr:\n return this._handlePush({ connection, stream })\n default:\n log.error('cannot handle unknown protocol %s', protocol)\n }\n }\n\n /**\n * Sends the `Identify` response with the Signed Peer Record\n * to the requesting peer over the given `connection`\n *\n * @private\n * @param {Object} options\n * @param {MuxedStream} options.stream\n * @param {Connection} options.connection\n * @returns {Promise}\n */\n async _handleIdentify ({ connection, stream }) {\n let publicKey = new Uint8Array(0)\n if (this.peerId.pubKey) {\n publicKey = this.peerId.pubKey.bytes\n }\n\n const signedPeerRecord = await this.peerStore.addressBook.getRawEnvelope(this.peerId)\n const protocols = this.peerStore.protoBook.get(this.peerId) || []\n\n const message = Message.Identify.encode({\n protocolVersion: this._host.protocolVersion,\n agentVersion: this._host.agentVersion,\n publicKey,\n listenAddrs: this._libp2p.multiaddrs.map((ma) => ma.bytes),\n signedPeerRecord,\n observedAddr: connection.remoteAddr.bytes,\n protocols\n }).finish()\n\n try {\n await pipe(\n [message],\n lp.encode(),\n stream,\n consume\n )\n } catch (err) {\n log.error('could not respond to identify request', err)\n }\n }\n\n /**\n * Reads the Identify Push message from the given `connection`\n *\n * @private\n * @param {object} options\n * @param {MuxedStream} options.stream\n * @param {Connection} options.connection\n * @returns {Promise}\n */\n async _handlePush ({ connection, stream }) {\n let message\n try {\n const [data] = await pipe(\n [],\n stream,\n lp.decode(),\n take(1),\n toBuffer,\n collect\n )\n message = Message.Identify.decode(data)\n } catch (err) {\n return log.error('received invalid message', err)\n }\n\n const id = connection.remotePeer\n\n try {\n const envelope = await Envelope.openAndCertify(message.signedPeerRecord, PeerRecord.DOMAIN)\n if (this.peerStore.addressBook.consumePeerRecord(envelope)) {\n this.peerStore.protoBook.set(id, message.protocols)\n return\n }\n } catch (err) {\n log('received invalid envelope, discard it and fallback to listenAddrs is available', err)\n }\n\n // LEGACY: Update peers data in PeerStore\n try {\n this.peerStore.addressBook.set(id,\n message.listenAddrs.map((addr) => new Multiaddr(addr)))\n } catch (err) {\n log.error('received invalid addrs', err)\n }\n\n // Update the protocols\n this.peerStore.protoBook.set(id, message.protocols)\n }\n\n /**\n * Takes the `addr` and converts it to a Multiaddr if possible\n *\n * @param {Uint8Array | string} addr\n * @returns {Multiaddr|null}\n */\n static getCleanMultiaddr (addr) {\n if (addr && addr.length > 0) {\n try {\n return new Multiaddr(addr)\n } catch (_) {\n return null\n }\n }\n return null\n }\n}\n\n/**\n * The protocols the IdentifyService supports\n *\n * @property multicodecs\n */\nconst multicodecs = {\n IDENTIFY: MULTICODEC_IDENTIFY,\n IDENTIFY_PUSH: MULTICODEC_IDENTIFY_PUSH\n}\n\nIdentifyService.multicodecs = multicodecs\nIdentifyService.Messsage = Message\n\nmodule.exports = IdentifyService\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-identify\"] || ($protobuf.roots[\"libp2p-identify\"] = {});\n\n$root.Identify = (function() {\n\n /**\n * Properties of an Identify.\n * @exports IIdentify\n * @interface IIdentify\n * @property {string|null} [protocolVersion] Identify protocolVersion\n * @property {string|null} [agentVersion] Identify agentVersion\n * @property {Uint8Array|null} [publicKey] Identify publicKey\n * @property {Array.|null} [listenAddrs] Identify listenAddrs\n * @property {Uint8Array|null} [observedAddr] Identify observedAddr\n * @property {Array.|null} [protocols] Identify protocols\n * @property {Uint8Array|null} [signedPeerRecord] Identify signedPeerRecord\n */\n\n /**\n * Constructs a new Identify.\n * @exports Identify\n * @classdesc Represents an Identify.\n * @implements IIdentify\n * @constructor\n * @param {IIdentify=} [p] Properties to set\n */\n function Identify(p) {\n this.listenAddrs = [];\n this.protocols = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Identify protocolVersion.\n * @member {string} protocolVersion\n * @memberof Identify\n * @instance\n */\n Identify.prototype.protocolVersion = \"\";\n\n /**\n * Identify agentVersion.\n * @member {string} agentVersion\n * @memberof Identify\n * @instance\n */\n Identify.prototype.agentVersion = \"\";\n\n /**\n * Identify publicKey.\n * @member {Uint8Array} publicKey\n * @memberof Identify\n * @instance\n */\n Identify.prototype.publicKey = $util.newBuffer([]);\n\n /**\n * Identify listenAddrs.\n * @member {Array.} listenAddrs\n * @memberof Identify\n * @instance\n */\n Identify.prototype.listenAddrs = $util.emptyArray;\n\n /**\n * Identify observedAddr.\n * @member {Uint8Array} observedAddr\n * @memberof Identify\n * @instance\n */\n Identify.prototype.observedAddr = $util.newBuffer([]);\n\n /**\n * Identify protocols.\n * @member {Array.} protocols\n * @memberof Identify\n * @instance\n */\n Identify.prototype.protocols = $util.emptyArray;\n\n /**\n * Identify signedPeerRecord.\n * @member {Uint8Array} signedPeerRecord\n * @memberof Identify\n * @instance\n */\n Identify.prototype.signedPeerRecord = $util.newBuffer([]);\n\n /**\n * Encodes the specified Identify message. Does not implicitly {@link Identify.verify|verify} messages.\n * @function encode\n * @memberof Identify\n * @static\n * @param {IIdentify} m Identify message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Identify.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.publicKey != null && Object.hasOwnProperty.call(m, \"publicKey\"))\n w.uint32(10).bytes(m.publicKey);\n if (m.listenAddrs != null && m.listenAddrs.length) {\n for (var i = 0; i < m.listenAddrs.length; ++i)\n w.uint32(18).bytes(m.listenAddrs[i]);\n }\n if (m.protocols != null && m.protocols.length) {\n for (var i = 0; i < m.protocols.length; ++i)\n w.uint32(26).string(m.protocols[i]);\n }\n if (m.observedAddr != null && Object.hasOwnProperty.call(m, \"observedAddr\"))\n w.uint32(34).bytes(m.observedAddr);\n if (m.protocolVersion != null && Object.hasOwnProperty.call(m, \"protocolVersion\"))\n w.uint32(42).string(m.protocolVersion);\n if (m.agentVersion != null && Object.hasOwnProperty.call(m, \"agentVersion\"))\n w.uint32(50).string(m.agentVersion);\n if (m.signedPeerRecord != null && Object.hasOwnProperty.call(m, \"signedPeerRecord\"))\n w.uint32(66).bytes(m.signedPeerRecord);\n return w;\n };\n\n /**\n * Decodes an Identify message from the specified reader or buffer.\n * @function decode\n * @memberof Identify\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Identify} Identify\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Identify.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Identify();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 5:\n m.protocolVersion = r.string();\n break;\n case 6:\n m.agentVersion = r.string();\n break;\n case 1:\n m.publicKey = r.bytes();\n break;\n case 2:\n if (!(m.listenAddrs && m.listenAddrs.length))\n m.listenAddrs = [];\n m.listenAddrs.push(r.bytes());\n break;\n case 4:\n m.observedAddr = r.bytes();\n break;\n case 3:\n if (!(m.protocols && m.protocols.length))\n m.protocols = [];\n m.protocols.push(r.string());\n break;\n case 8:\n m.signedPeerRecord = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an Identify message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Identify\n * @static\n * @param {Object.} d Plain object\n * @returns {Identify} Identify\n */\n Identify.fromObject = function fromObject(d) {\n if (d instanceof $root.Identify)\n return d;\n var m = new $root.Identify();\n if (d.protocolVersion != null) {\n m.protocolVersion = String(d.protocolVersion);\n }\n if (d.agentVersion != null) {\n m.agentVersion = String(d.agentVersion);\n }\n if (d.publicKey != null) {\n if (typeof d.publicKey === \"string\")\n $util.base64.decode(d.publicKey, m.publicKey = $util.newBuffer($util.base64.length(d.publicKey)), 0);\n else if (d.publicKey.length)\n m.publicKey = d.publicKey;\n }\n if (d.listenAddrs) {\n if (!Array.isArray(d.listenAddrs))\n throw TypeError(\".Identify.listenAddrs: array expected\");\n m.listenAddrs = [];\n for (var i = 0; i < d.listenAddrs.length; ++i) {\n if (typeof d.listenAddrs[i] === \"string\")\n $util.base64.decode(d.listenAddrs[i], m.listenAddrs[i] = $util.newBuffer($util.base64.length(d.listenAddrs[i])), 0);\n else if (d.listenAddrs[i].length)\n m.listenAddrs[i] = d.listenAddrs[i];\n }\n }\n if (d.observedAddr != null) {\n if (typeof d.observedAddr === \"string\")\n $util.base64.decode(d.observedAddr, m.observedAddr = $util.newBuffer($util.base64.length(d.observedAddr)), 0);\n else if (d.observedAddr.length)\n m.observedAddr = d.observedAddr;\n }\n if (d.protocols) {\n if (!Array.isArray(d.protocols))\n throw TypeError(\".Identify.protocols: array expected\");\n m.protocols = [];\n for (var i = 0; i < d.protocols.length; ++i) {\n m.protocols[i] = String(d.protocols[i]);\n }\n }\n if (d.signedPeerRecord != null) {\n if (typeof d.signedPeerRecord === \"string\")\n $util.base64.decode(d.signedPeerRecord, m.signedPeerRecord = $util.newBuffer($util.base64.length(d.signedPeerRecord)), 0);\n else if (d.signedPeerRecord.length)\n m.signedPeerRecord = d.signedPeerRecord;\n }\n return m;\n };\n\n /**\n * Creates a plain object from an Identify message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Identify\n * @static\n * @param {Identify} m Identify\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.} Plain object\n */\n Identify.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.listenAddrs = [];\n d.protocols = [];\n }\n if (o.defaults) {\n if (o.bytes === String)\n d.publicKey = \"\";\n else {\n d.publicKey = [];\n if (o.bytes !== Array)\n d.publicKey = $util.newBuffer(d.publicKey);\n }\n if (o.bytes === String)\n d.observedAddr = \"\";\n else {\n d.observedAddr = [];\n if (o.bytes !== Array)\n d.observedAddr = $util.newBuffer(d.observedAddr);\n }\n d.protocolVersion = \"\";\n d.agentVersion = \"\";\n if (o.bytes === String)\n d.signedPeerRecord = \"\";\n else {\n d.signedPeerRecord = [];\n if (o.bytes !== Array)\n d.signedPeerRecord = $util.newBuffer(d.signedPeerRecord);\n }\n }\n if (m.publicKey != null && m.hasOwnProperty(\"publicKey\")) {\n d.publicKey = o.bytes === String ? $util.base64.encode(m.publicKey, 0, m.publicKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.publicKey) : m.publicKey;\n }\n if (m.listenAddrs && m.listenAddrs.length) {\n d.listenAddrs = [];\n for (var j = 0; j < m.listenAddrs.length; ++j) {\n d.listenAddrs[j] = o.bytes === String ? $util.base64.encode(m.listenAddrs[j], 0, m.listenAddrs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.listenAddrs[j]) : m.listenAddrs[j];\n }\n }\n if (m.protocols && m.protocols.length) {\n d.protocols = [];\n for (var j = 0; j < m.protocols.length; ++j) {\n d.protocols[j] = m.protocols[j];\n }\n }\n if (m.observedAddr != null && m.hasOwnProperty(\"observedAddr\")) {\n d.observedAddr = o.bytes === String ? $util.base64.encode(m.observedAddr, 0, m.observedAddr.length) : o.bytes === Array ? Array.prototype.slice.call(m.observedAddr) : m.observedAddr;\n }\n if (m.protocolVersion != null && m.hasOwnProperty(\"protocolVersion\")) {\n d.protocolVersion = m.protocolVersion;\n }\n if (m.agentVersion != null && m.hasOwnProperty(\"agentVersion\")) {\n d.agentVersion = m.agentVersion;\n }\n if (m.signedPeerRecord != null && m.hasOwnProperty(\"signedPeerRecord\")) {\n d.signedPeerRecord = o.bytes === String ? $util.base64.encode(m.signedPeerRecord, 0, m.signedPeerRecord.length) : o.bytes === Array ? Array.prototype.slice.call(m.signedPeerRecord) : m.signedPeerRecord;\n }\n return d;\n };\n\n /**\n * Converts this Identify to JSON.\n * @function toJSON\n * @memberof Identify\n * @instance\n * @returns {Object.} JSON object\n */\n Identify.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Identify;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\n// @ts-ignore nat-api does not export types\nconst NatAPI = require('@motrix/nat-api')\nconst debug = require('debug')\nconst { promisify } = require('es6-promisify')\nconst { Multiaddr } = require('multiaddr')\nconst log = Object.assign(debug('libp2p:nat'), {\n error: debug('libp2p:nat:err')\n})\nconst { isBrowser } = require('wherearewe')\nconst retry = require('p-retry')\n// @ts-ignore private-api does not export types\nconst isPrivateIp = require('private-ip')\nconst pkg = require('../package.json')\nconst errcode = require('err-code')\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('./errors')\nconst isLoopback = require('libp2p-utils/src/multiaddr/is-loopback')\n\nconst DEFAULT_TTL = 7200\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('./transport-manager')} TransportManager\n * @typedef {import('./address-manager')} AddressManager\n */\n\n/**\n * @typedef {Object} NatManagerProperties\n * @property {PeerId} peerId - The peer ID of the current node\n * @property {TransportManager} transportManager - A transport manager\n * @property {AddressManager} addressManager - An address manager\n *\n * @typedef {Object} NatManagerOptions\n * @property {boolean} enabled - Whether to enable the NAT manager\n * @property {string} [externalIp] - Pass a value to use instead of auto-detection\n * @property {string} [description] - A string value to use for the port mapping description on the gateway\n * @property {number} [ttl = DEFAULT_TTL] - How long UPnP port mappings should last for in seconds (minimum 1200)\n * @property {boolean} [keepAlive] - Whether to automatically refresh UPnP port mappings when their TTL is reached\n * @property {string} [gateway] - Pass a value to use instead of auto-detection\n * @property {object} [pmp] - PMP options\n * @property {boolean} [pmp.enabled] - Whether to enable PMP as well as UPnP\n */\n\nfunction highPort (min = 1024, max = 65535) {\n return Math.floor(Math.random() * (max - min + 1) + min)\n}\n\nclass NatManager {\n /**\n * @class\n * @param {NatManagerProperties & NatManagerOptions} options\n */\n constructor ({ peerId, addressManager, transportManager, ...options }) {\n this._peerId = peerId\n this._addressManager = addressManager\n this._transportManager = transportManager\n\n this._enabled = options.enabled\n this._externalIp = options.externalIp\n this._options = {\n description: options.description || `${pkg.name}@${pkg.version} ${this._peerId}`,\n ttl: options.ttl || DEFAULT_TTL,\n autoUpdate: options.keepAlive || true,\n gateway: options.gateway,\n enablePMP: Boolean(options.pmp && options.pmp.enabled)\n }\n\n if (this._options.ttl < DEFAULT_TTL) {\n throw errcode(new Error(`NatManager ttl should be at least ${DEFAULT_TTL} seconds`), ERR_INVALID_PARAMETERS)\n }\n }\n\n /**\n * Starts the NAT manager\n */\n start () {\n if (isBrowser || !this._enabled) {\n return\n }\n\n // done async to not slow down startup\n this._start().catch((err) => {\n // hole punching errors are non-fatal\n log.error(err)\n })\n }\n\n async _start () {\n const addrs = this._transportManager.getAddrs()\n\n for (const addr of addrs) {\n // try to open uPnP ports for each thin waist address\n const { family, host, port, transport } = addr.toOptions()\n\n if (!addr.isThinWaistAddress() || transport !== 'tcp') {\n // only bare tcp addresses\n // eslint-disable-next-line no-continue\n continue\n }\n\n if (isLoopback(addr)) {\n // eslint-disable-next-line no-continue\n continue\n }\n\n if (family !== 4) {\n // ignore ipv6\n // eslint-disable-next-line no-continue\n continue\n }\n\n const client = this._getClient()\n const publicIp = this._externalIp || await client.externalIp()\n\n if (isPrivateIp(publicIp)) {\n throw new Error(`${publicIp} is private - please set config.nat.externalIp to an externally routable IP or ensure you are not behind a double NAT`)\n }\n\n const publicPort = highPort()\n\n log(`opening uPnP connection from ${publicIp}:${publicPort} to ${host}:${port}`)\n\n await client.map({\n publicPort,\n privatePort: port,\n protocol: transport.toUpperCase()\n })\n\n this._addressManager.addObservedAddr(Multiaddr.fromNodeAddress({\n family: 4,\n address: publicIp,\n port: publicPort\n }, transport))\n }\n }\n\n _getClient () {\n if (this._client) {\n return this._client\n }\n\n const client = new NatAPI(this._options)\n\n /** @type {(...any: any) => any} */\n const map = promisify(client.map.bind(client))\n /** @type {(...any: any) => any} */\n const destroy = promisify(client.destroy.bind(client))\n /** @type {(...any: any) => any} */\n const externalIp = promisify(client.externalIp.bind(client))\n\n // these are all network operations so add a retry\n this._client = {\n /**\n * @param {...any} args\n * @returns {Promise}\n */\n map: (...args) => retry(() => map(...args), { onFailedAttempt: log.error, unref: true }),\n\n /**\n * @param {...any} args\n * @returns {Promise}\n */\n destroy: (...args) => retry(() => destroy(...args), { onFailedAttempt: log.error, unref: true }),\n\n /**\n * @param {...any} args\n * @returns {Promise}\n */\n externalIp: (...args) => retry(() => externalIp(...args), { onFailedAttempt: log.error, unref: true })\n }\n\n return this._client\n }\n\n /**\n * Stops the NAT manager\n *\n * @async\n */\n async stop () {\n if (isBrowser || !this._client) {\n return\n }\n\n try {\n await this._client.destroy()\n this._client = null\n } catch (err) {\n log.error(err)\n }\n }\n}\n\nmodule.exports = NatManager\n","var customArgumentsToken=\"__ES6-PROMISIFY--CUSTOM-ARGUMENTS__\";export function promisify(a){if(\"function\"!=typeof a)throw new TypeError(\"Argument to promisify must be a function\");var b=a[customArgumentsToken],c=promisify.Promise||Promise;if(\"function\"!=typeof c)throw new Error(\"No Promise implementation found; do you need a polyfill?\");return function(){for(var d=arguments.length,e=Array(d),f=0;f{e.push(function(a){if(a)return d(a);for(var e=arguments.length,f=Array(1{var d=b[c];d&&(h[d]=a)}),c(h)}),a.apply(this,e)})}}promisify.argumentNames=\"__ES6-PROMISIFY--CUSTOM-ARGUMENTS__\",promisify.Promise=void 0;\n","'use strict'\n\n/** @type {() => boolean} */\n// @ts-ignore\nconst isElectron = require('is-electron')\n\nconst IS_ENV_WITH_DOM = typeof window === 'object' && typeof document === 'object' && document.nodeType === 9\n\nconst IS_ELECTRON = isElectron()\nconst IS_BROWSER = IS_ENV_WITH_DOM && !IS_ELECTRON\nconst IS_ELECTRON_MAIN = IS_ELECTRON && !IS_ENV_WITH_DOM\nconst IS_ELECTRON_RENDERER = IS_ELECTRON && IS_ENV_WITH_DOM\nconst IS_NODE = typeof require === 'function' && typeof process !== 'undefined' && typeof process.release !== 'undefined' && process.release.name === 'node' && !IS_ELECTRON\n// @ts-ignore\n// eslint-disable-next-line no-undef\nconst IS_WEBWORKER = typeof importScripts === 'function' && typeof self !== 'undefined' && typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope\nconst IS_TEST = typeof process !== 'undefined' && typeof process.env !== 'undefined' && process.env.NODE_ENV === 'test'\n\nmodule.exports = {\n isTest: IS_TEST,\n isElectron: IS_ELECTRON,\n isElectronMain: IS_ELECTRON_MAIN,\n isElectronRenderer: IS_ELECTRON_RENDERER,\n isNode: IS_NODE,\n /**\n * Detects browser main thread **NOT** web worker or service worker\n */\n isBrowser: IS_BROWSER,\n isWebWorker: IS_WEBWORKER,\n isEnvWithDom: IS_ENV_WITH_DOM\n}\n","'use strict';\nconst retry = require('retry');\n\nconst networkErrorMsgs = [\n\t'Failed to fetch', // Chrome\n\t'NetworkError when attempting to fetch resource.', // Firefox\n\t'The Internet connection appears to be offline.', // Safari\n\t'Network request failed' // `cross-fetch`\n];\n\nclass AbortError extends Error {\n\tconstructor(message) {\n\t\tsuper();\n\n\t\tif (message instanceof Error) {\n\t\t\tthis.originalError = message;\n\t\t\t({message} = message);\n\t\t} else {\n\t\t\tthis.originalError = new Error(message);\n\t\t\tthis.originalError.stack = this.stack;\n\t\t}\n\n\t\tthis.name = 'AbortError';\n\t\tthis.message = message;\n\t}\n}\n\nconst decorateErrorWithCounts = (error, attemptNumber, options) => {\n\t// Minus 1 from attemptNumber because the first attempt does not count as a retry\n\tconst retriesLeft = options.retries - (attemptNumber - 1);\n\n\terror.attemptNumber = attemptNumber;\n\terror.retriesLeft = retriesLeft;\n\treturn error;\n};\n\nconst isNetworkError = errorMessage => networkErrorMsgs.includes(errorMessage);\n\nconst pRetry = (input, options) => new Promise((resolve, reject) => {\n\toptions = {\n\t\tonFailedAttempt: () => {},\n\t\tretries: 10,\n\t\t...options\n\t};\n\n\tconst operation = retry.operation(options);\n\n\toperation.attempt(async attemptNumber => {\n\t\ttry {\n\t\t\tresolve(await input(attemptNumber));\n\t\t} catch (error) {\n\t\t\tif (!(error instanceof Error)) {\n\t\t\t\treject(new TypeError(`Non-error was thrown: \"${error}\". You should only throw errors.`));\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (error instanceof AbortError) {\n\t\t\t\toperation.stop();\n\t\t\t\treject(error.originalError);\n\t\t\t} else if (error instanceof TypeError && !isNetworkError(error.message)) {\n\t\t\t\toperation.stop();\n\t\t\t\treject(error);\n\t\t\t} else {\n\t\t\t\tdecorateErrorWithCounts(error, attemptNumber, options);\n\n\t\t\t\ttry {\n\t\t\t\t\tawait options.onFailedAttempt(error);\n\t\t\t\t} catch (error) {\n\t\t\t\t\treject(error);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (!operation.retry(error)) {\n\t\t\t\t\treject(operation.mainError());\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n});\n\nmodule.exports = pRetry;\n// TODO: remove this in the next major version\nmodule.exports.default = pRetry;\n\nmodule.exports.AbortError = AbortError;\n","module.exports = require('./lib/retry');","var RetryOperation = require('./retry_operation');\n\nexports.operation = function(options) {\n var timeouts = exports.timeouts(options);\n return new RetryOperation(timeouts, {\n forever: options && (options.forever || options.retries === Infinity),\n unref: options && options.unref,\n maxRetryTime: options && options.maxRetryTime\n });\n};\n\nexports.timeouts = function(options) {\n if (options instanceof Array) {\n return [].concat(options);\n }\n\n var opts = {\n retries: 10,\n factor: 2,\n minTimeout: 1 * 1000,\n maxTimeout: Infinity,\n randomize: false\n };\n for (var key in options) {\n opts[key] = options[key];\n }\n\n if (opts.minTimeout > opts.maxTimeout) {\n throw new Error('minTimeout is greater than maxTimeout');\n }\n\n var timeouts = [];\n for (var i = 0; i < opts.retries; i++) {\n timeouts.push(this.createTimeout(i, opts));\n }\n\n if (options && options.forever && !timeouts.length) {\n timeouts.push(this.createTimeout(i, opts));\n }\n\n // sort the array numerically ascending\n timeouts.sort(function(a,b) {\n return a - b;\n });\n\n return timeouts;\n};\n\nexports.createTimeout = function(attempt, opts) {\n var random = (opts.randomize)\n ? (Math.random() + 1)\n : 1;\n\n var timeout = Math.round(random * Math.max(opts.minTimeout, 1) * Math.pow(opts.factor, attempt));\n timeout = Math.min(timeout, opts.maxTimeout);\n\n return timeout;\n};\n\nexports.wrap = function(obj, options, methods) {\n if (options instanceof Array) {\n methods = options;\n options = null;\n }\n\n if (!methods) {\n methods = [];\n for (var key in obj) {\n if (typeof obj[key] === 'function') {\n methods.push(key);\n }\n }\n }\n\n for (var i = 0; i < methods.length; i++) {\n var method = methods[i];\n var original = obj[method];\n\n obj[method] = function retryWrapper(original) {\n var op = exports.operation(options);\n var args = Array.prototype.slice.call(arguments, 1);\n var callback = args.pop();\n\n args.push(function(err) {\n if (op.retry(err)) {\n return;\n }\n if (err) {\n arguments[0] = op.mainError();\n }\n callback.apply(this, arguments);\n });\n\n op.attempt(function() {\n original.apply(obj, args);\n });\n }.bind(obj, original);\n obj[method].options = options;\n }\n};\n","function RetryOperation(timeouts, options) {\n // Compatibility for the old (timeouts, retryForever) signature\n if (typeof options === 'boolean') {\n options = { forever: options };\n }\n\n this._originalTimeouts = JSON.parse(JSON.stringify(timeouts));\n this._timeouts = timeouts;\n this._options = options || {};\n this._maxRetryTime = options && options.maxRetryTime || Infinity;\n this._fn = null;\n this._errors = [];\n this._attempts = 1;\n this._operationTimeout = null;\n this._operationTimeoutCb = null;\n this._timeout = null;\n this._operationStart = null;\n this._timer = null;\n\n if (this._options.forever) {\n this._cachedTimeouts = this._timeouts.slice(0);\n }\n}\nmodule.exports = RetryOperation;\n\nRetryOperation.prototype.reset = function() {\n this._attempts = 1;\n this._timeouts = this._originalTimeouts.slice(0);\n}\n\nRetryOperation.prototype.stop = function() {\n if (this._timeout) {\n clearTimeout(this._timeout);\n }\n if (this._timer) {\n clearTimeout(this._timer);\n }\n\n this._timeouts = [];\n this._cachedTimeouts = null;\n};\n\nRetryOperation.prototype.retry = function(err) {\n if (this._timeout) {\n clearTimeout(this._timeout);\n }\n\n if (!err) {\n return false;\n }\n var currentTime = new Date().getTime();\n if (err && currentTime - this._operationStart >= this._maxRetryTime) {\n this._errors.push(err);\n this._errors.unshift(new Error('RetryOperation timeout occurred'));\n return false;\n }\n\n this._errors.push(err);\n\n var timeout = this._timeouts.shift();\n if (timeout === undefined) {\n if (this._cachedTimeouts) {\n // retry forever, only keep last error\n this._errors.splice(0, this._errors.length - 1);\n timeout = this._cachedTimeouts.slice(-1);\n } else {\n return false;\n }\n }\n\n var self = this;\n this._timer = setTimeout(function() {\n self._attempts++;\n\n if (self._operationTimeoutCb) {\n self._timeout = setTimeout(function() {\n self._operationTimeoutCb(self._attempts);\n }, self._operationTimeout);\n\n if (self._options.unref) {\n self._timeout.unref();\n }\n }\n\n self._fn(self._attempts);\n }, timeout);\n\n if (this._options.unref) {\n this._timer.unref();\n }\n\n return true;\n};\n\nRetryOperation.prototype.attempt = function(fn, timeoutOps) {\n this._fn = fn;\n\n if (timeoutOps) {\n if (timeoutOps.timeout) {\n this._operationTimeout = timeoutOps.timeout;\n }\n if (timeoutOps.cb) {\n this._operationTimeoutCb = timeoutOps.cb;\n }\n }\n\n var self = this;\n if (this._operationTimeoutCb) {\n this._timeout = setTimeout(function() {\n self._operationTimeoutCb();\n }, self._operationTimeout);\n }\n\n this._operationStart = new Date().getTime();\n\n this._fn(this._attempts);\n};\n\nRetryOperation.prototype.try = function(fn) {\n console.log('Using RetryOperation.try() is deprecated');\n this.attempt(fn);\n};\n\nRetryOperation.prototype.start = function(fn) {\n console.log('Using RetryOperation.start() is deprecated');\n this.attempt(fn);\n};\n\nRetryOperation.prototype.start = RetryOperation.prototype.try;\n\nRetryOperation.prototype.errors = function() {\n return this._errors;\n};\n\nRetryOperation.prototype.attempts = function() {\n return this._attempts;\n};\n\nRetryOperation.prototype.mainError = function() {\n if (this._errors.length === 0) {\n return null;\n }\n\n var counts = {};\n var mainError = null;\n var mainErrorCount = 0;\n\n for (var i = 0; i < this._errors.length; i++) {\n var error = this._errors[i];\n var message = error.message;\n var count = (counts[message] || 0) + 1;\n\n counts[message] = count;\n\n if (count >= mainErrorCount) {\n mainError = error;\n mainErrorCount = count;\n }\n }\n\n return mainError;\n};\n","'use strict'\n\n// @ts-ignore is-loopback-addr does not publish types\nconst isLoopbackAddr = require('is-loopback-addr')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * Check if a given multiaddr is a loopback address.\n *\n * @param {Multiaddr} ma\n * @returns {boolean}\n */\nfunction isLoopback (ma) {\n const { address } = ma.nodeAddress()\n\n return isLoopbackAddr(address)\n}\n\nmodule.exports = isLoopback\n","'use strict'\n\n/**\n * Check if a given ip address is a loopback address\n *\n * @param {string} ip - ip address to check\n * @returns {boolean}\n */\nfunction isLoopbackAddr (ip) {\n return /^127\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/i.test(ip) ||\n /^::1$/.test(ip)\n}\n\nmodule.exports = isLoopbackAddr\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsBitswap = require('ipfs-bitswap');\nvar libp2p = require('./libp2p.js');\nvar multiaddr = require('multiaddr');\nvar errCode = require('err-code');\nvar blockStorage = require('../block-storage.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nclass Network {\n constructor(peerId, libp2p, bitswap, repo, blockstore) {\n this.peerId = peerId;\n this.libp2p = libp2p;\n this.bitswap = bitswap;\n this.repo = repo;\n this.blockstore = blockstore;\n }\n static async start({peerId, repo, print, options}) {\n if (repo.closed) {\n await repo.open();\n }\n const config = await repo.config.getAll();\n const libp2p$1 = await libp2p.createLibp2p({\n options,\n repo,\n peerId,\n multiaddrs: readAddrs(peerId, config),\n config,\n keychainConfig: undefined\n });\n if (libp2p$1.keychain) {\n await libp2p$1.loadKeychain();\n }\n await libp2p$1.start();\n for (const ma of libp2p$1.multiaddrs) {\n print(`Swarm listening on ${ ma }/p2p/${ peerId.toB58String() }`);\n }\n const bitswap = ipfsBitswap.createBitswap(libp2p$1, repo.blocks, { statsEnabled: true });\n await bitswap.start();\n const blockstore = new blockStorage.BlockStorage(repo.blocks, bitswap);\n repo.blocks = blockstore;\n repo.pins.blockstore = blockstore;\n return new Network(peerId, libp2p$1, bitswap, repo, blockstore);\n }\n static async stop(network) {\n network.repo.blocks = network.blockstore.unwrap();\n network.repo.pins.blockstore = network.blockstore.unwrap();\n await Promise.all([\n network.bitswap.stop(),\n network.libp2p.stop()\n ]);\n }\n}\nconst readAddrs = (peerId, config) => {\n const peerIdStr = peerId.toB58String();\n const addrs = [];\n const swarm = config.Addresses && config.Addresses.Swarm || [];\n for (const addr of swarm) {\n let ma = new multiaddr.Multiaddr(addr);\n if (ma.protoCodes().includes(WEBSOCKET_STAR_PROTO_CODE)) {\n throw errCode__default['default'](new Error('websocket-star swarm addresses are not supported. See https://github.com/ipfs/js-ipfs/issues/2779'), 'ERR_WEBSOCKET_STAR_SWARM_ADDR_NOT_SUPPORTED');\n }\n const maId = ma.getPeerId();\n if (maId && maId !== peerIdStr) {\n ma = ma.encapsulate(`/p2p/${ peerIdStr }`);\n }\n addrs.push(ma);\n }\n return addrs;\n};\nconst WEBSOCKET_STAR_PROTO_CODE = 479;\n\nexports.Network = Network;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bitswap = require('./bitswap.js');\n\nconst createBitswap = (libp2p, blockstore, options = {}) => {\n return new bitswap.Bitswap(libp2p, blockstore, options);\n};\n\nexports.createBitswap = createBitswap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index$3 = require('./want-manager/index.js');\nvar network = require('./network.js');\nvar index$2 = require('./decision-engine/index.js');\nvar notifications = require('./notifications.js');\nvar index = require('./utils/index.js');\nvar index$1 = require('./stats/index.js');\nvar nativeAbortController = require('native-abort-controller');\nvar anySignal = require('any-signal');\nvar base = require('blockstore-core/base');\nvar cid = require('multiformats/cid');\n\nconst defaultOptions = {\n statsEnabled: false,\n statsComputeThrottleTimeout: 1000,\n statsComputeThrottleMaxQueueSize: 1000\n};\nconst statsKeys = [\n 'blocksReceived',\n 'dataReceived',\n 'dupBlksReceived',\n 'dupDataReceived',\n 'blocksSent',\n 'dataSent',\n 'providesBufferLength',\n 'wantListLength',\n 'peerCount'\n];\nclass Bitswap extends base.BaseBlockstore {\n constructor(libp2p, blockstore, options = {}) {\n super();\n this._libp2p = libp2p;\n this._log = index.logger(this.peerId);\n this._options = Object.assign({}, defaultOptions, options);\n this._stats = new index$1.Stats(statsKeys, {\n enabled: this._options.statsEnabled,\n computeThrottleTimeout: this._options.statsComputeThrottleTimeout,\n computeThrottleMaxQueueSize: this._options.statsComputeThrottleMaxQueueSize\n });\n this.network = new network.Network(libp2p, this, this._stats, { hashLoader: options.hashLoader });\n this.blockstore = blockstore;\n this.engine = new index$2.DecisionEngine(this.peerId, blockstore, this.network, this._stats);\n this.wm = new index$3.WantManager(this.peerId, this.network, this._stats);\n this.notifications = new notifications.Notifications(this.peerId);\n this.started = false;\n }\n isStarted() {\n return this.started;\n }\n get peerId() {\n return this._libp2p.peerId;\n }\n async _receiveMessage(peerId, incoming) {\n try {\n await this.engine.messageReceived(peerId, incoming);\n } catch (err) {\n this._log('failed to receive message', incoming);\n }\n if (incoming.blocks.size === 0) {\n return;\n }\n const received = [];\n for (const [cidStr, data] of incoming.blocks.entries()) {\n const cid$1 = cid.CID.parse(cidStr);\n received.push({\n wasWanted: this.wm.wantlist.contains(cid$1),\n cid: cid$1,\n data\n });\n }\n this.wm.cancelWants(received.filter(({wasWanted}) => wasWanted).map(({cid}) => cid));\n await Promise.all(received.map(({cid, wasWanted, data}) => this._handleReceivedBlock(peerId, cid, data, wasWanted)));\n }\n async _handleReceivedBlock(peerId, cid, data, wasWanted) {\n this._log('received block');\n const has = await this.blockstore.has(cid);\n this._updateReceiveCounters(peerId.toB58String(), cid, data, has);\n if (!wasWanted) {\n return;\n }\n await this.put(cid, data);\n }\n _updateReceiveCounters(peerIdStr, cid, data, exists) {\n this._stats.push(peerIdStr, 'blocksReceived', 1);\n this._stats.push(peerIdStr, 'dataReceived', data.length);\n if (exists) {\n this._stats.push(peerIdStr, 'dupBlksReceived', 1);\n this._stats.push(peerIdStr, 'dupDataReceived', data.length);\n }\n }\n _receiveError(err) {\n this._log.error('ReceiveError: %s', err.message);\n }\n _onPeerConnected(peerId) {\n this.wm.connected(peerId);\n }\n _onPeerDisconnected(peerId) {\n this.wm.disconnected(peerId);\n this.engine.peerDisconnected(peerId);\n this._stats.disconnected(peerId);\n }\n enableStats() {\n this._stats.enable();\n }\n disableStats() {\n this._stats.disable();\n }\n wantlistForPeer(peerId, _options) {\n return this.engine.wantlistForPeer(peerId);\n }\n ledgerForPeer(peerId) {\n return this.engine.ledgerForPeer(peerId);\n }\n async get(cid, options = {}) {\n const fetchFromNetwork = (cid, options) => {\n this.wm.wantBlocks([cid], options);\n return this.notifications.wantBlock(cid, options);\n };\n let promptedNetwork = false;\n const loadOrFetchFromNetwork = async (cid, options) => {\n try {\n const block = await this.blockstore.get(cid, options);\n return block;\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n if (!promptedNetwork) {\n promptedNetwork = true;\n this.network.findAndConnect(cid).catch(err => this._log.error(err));\n }\n return fetchFromNetwork(cid, options);\n }\n };\n const controller = new nativeAbortController.AbortController();\n const signal = options.signal ? anySignal.anySignal([\n options.signal,\n controller.signal\n ]) : controller.signal;\n const block = await Promise.race([\n this.notifications.wantBlock(cid, { signal }),\n loadOrFetchFromNetwork(cid, { signal })\n ]);\n controller.abort();\n return block;\n }\n async *getMany(cids, options = {}) {\n for await (const cid of cids) {\n yield this.get(cid, options);\n }\n }\n unwant(cids) {\n const cidsArray = Array.isArray(cids) ? cids : [cids];\n this.wm.unwantBlocks(cidsArray);\n cidsArray.forEach(cid => this.notifications.unwantBlock(cid));\n }\n cancelWants(cids) {\n this.wm.cancelWants(Array.isArray(cids) ? cids : [cids]);\n }\n async put(cid, block, _options) {\n await this.blockstore.put(cid, block);\n this._sendHaveBlockNotifications(cid, block);\n }\n async *putMany(source, options) {\n for await (const {key, value} of this.blockstore.putMany(source, options)) {\n this._sendHaveBlockNotifications(key, value);\n yield {\n key,\n value\n };\n }\n }\n _sendHaveBlockNotifications(cid, data) {\n this.notifications.hasBlock(cid, data);\n this.engine.receivedBlocks([{\n cid,\n data\n }]);\n this.network.provide(cid).catch(err => {\n this._log.error('Failed to provide: %s', err.message);\n });\n }\n getWantlist() {\n return this.wm.wantlist.entries();\n }\n peers() {\n return this.engine.peers();\n }\n stat() {\n return this._stats;\n }\n start() {\n this.wm.start();\n this.network.start();\n this.engine.start();\n this.started = true;\n }\n stop() {\n this._stats.stop();\n this.wm.stop();\n this.network.stop();\n this.engine.stop();\n this.started = false;\n }\n unwrap() {\n return this.blockstore;\n }\n}\n\nexports.Bitswap = Bitswap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index$2 = require('../message/index.js');\nvar index = require('../wantlist/index.js');\nvar constants = require('../constants.js');\nvar msgQueue = require('./msg-queue.js');\nvar index$1 = require('../utils/index.js');\nvar base58 = require('multiformats/bases/base58');\n\nclass WantManager {\n constructor(peerId, network, stats) {\n this.peers = new Map();\n this.wantlist = new index.Wantlist(stats);\n this.network = network;\n this._stats = stats;\n this._peerId = peerId;\n this._log = index$1.logger(peerId, 'want');\n }\n _addEntries(cids, cancel, force) {\n const entries = cids.map((cid, i) => {\n return new index$2.BitswapMessage.Entry(cid, constants.kMaxPriority - i, index$2.BitswapMessage.WantType.Block, cancel);\n });\n entries.forEach(e => {\n if (e.cancel) {\n if (force) {\n this.wantlist.removeForce(e.cid.toString(base58.base58btc));\n } else {\n this.wantlist.remove(e.cid);\n }\n } else {\n this._log('adding to wl');\n this.wantlist.add(e.cid, e.priority);\n }\n });\n for (const p of this.peers.values()) {\n p.addEntries(entries);\n }\n }\n _startPeerHandler(peerId) {\n let mq = this.peers.get(peerId.toB58String());\n if (mq) {\n mq.refcnt++;\n return;\n }\n mq = new msgQueue.MsgQueue(this._peerId, peerId, this.network);\n const fullwantlist = new index$2.BitswapMessage(true);\n for (const entry of this.wantlist.entries()) {\n fullwantlist.addEntry(entry[1].cid, entry[1].priority);\n }\n mq.addMessage(fullwantlist);\n this.peers.set(peerId.toB58String(), mq);\n return mq;\n }\n _stopPeerHandler(peerId) {\n const mq = this.peers.get(peerId.toB58String());\n if (!mq) {\n return;\n }\n mq.refcnt--;\n if (mq.refcnt > 0) {\n return;\n }\n this.peers.delete(peerId.toB58String());\n }\n wantBlocks(cids, options = {}) {\n this._addEntries(cids, false);\n if (options && options.signal) {\n options.signal.addEventListener('abort', () => {\n this.cancelWants(cids);\n });\n }\n }\n unwantBlocks(cids) {\n this._log('unwant blocks: %s', cids.length);\n this._addEntries(cids, true, true);\n }\n cancelWants(cids) {\n this._log('cancel wants: %s', cids.length);\n this._addEntries(cids, true);\n }\n connectedPeers() {\n return Array.from(this.peers.keys());\n }\n connected(peerId) {\n this._startPeerHandler(peerId);\n }\n disconnected(peerId) {\n this._stopPeerHandler(peerId);\n }\n start() {\n }\n stop() {\n this.peers.forEach(mq => this.disconnected(mq.peerId));\n }\n}\n\nexports.WantManager = WantManager;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar sha2 = require('multiformats/hashes/sha2');\nvar base58 = require('multiformats/bases/base58');\nvar vd = require('varint-decoder');\nvar varintEncoder = require('../utils/varint-encoder.js');\nvar index = require('../utils/index.js');\nvar message = require('./message.js');\nvar entry = require('./entry.js');\nvar errcode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar vd__default = /*#__PURE__*/_interopDefaultLegacy(vd);\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\n\nclass BitswapMessage {\n constructor(full) {\n this.full = full;\n this.wantlist = new Map();\n this.blocks = new Map();\n this.blockPresences = new Map();\n this.pendingBytes = 0;\n }\n get empty() {\n return this.blocks.size === 0 && this.wantlist.size === 0 && this.blockPresences.size === 0;\n }\n addEntry(cid, priority, wantType, cancel, sendDontHave) {\n if (wantType == null) {\n wantType = BitswapMessage.WantType.Block;\n }\n const cidStr = cid.toString(base58.base58btc);\n const entry$1 = this.wantlist.get(cidStr);\n if (entry$1) {\n if (entry$1.wantType === wantType) {\n entry$1.priority = priority;\n }\n if (cancel) {\n entry$1.cancel = Boolean(cancel);\n }\n if (sendDontHave) {\n entry$1.sendDontHave = Boolean(sendDontHave);\n }\n if (wantType === BitswapMessage.WantType.Block && entry$1.wantType === BitswapMessage.WantType.Have) {\n entry$1.wantType = wantType;\n }\n } else {\n this.wantlist.set(cidStr, new entry.BitswapMessageEntry(cid, priority, wantType, cancel, sendDontHave));\n }\n }\n addBlock(cid, block) {\n const cidStr = cid.toString(base58.base58btc);\n this.blocks.set(cidStr, block);\n }\n addHave(cid) {\n const cidStr = cid.toString(base58.base58btc);\n if (!this.blockPresences.has(cidStr)) {\n this.blockPresences.set(cidStr, BitswapMessage.BlockPresenceType.Have);\n }\n }\n addDontHave(cid) {\n const cidStr = cid.toString(base58.base58btc);\n if (!this.blockPresences.has(cidStr)) {\n this.blockPresences.set(cidStr, BitswapMessage.BlockPresenceType.DontHave);\n }\n }\n cancel(cid) {\n const cidStr = cid.toString(base58.base58btc);\n this.wantlist.delete(cidStr);\n this.addEntry(cid, 0, BitswapMessage.WantType.Block, true, false);\n }\n setPendingBytes(size) {\n this.pendingBytes = size;\n }\n serializeToBitswap100() {\n const msg = {\n wantlist: {\n entries: Array.from(this.wantlist.values()).map(entry => {\n return {\n block: entry.cid.bytes,\n priority: Number(entry.priority),\n cancel: Boolean(entry.cancel)\n };\n }),\n full: this.full ? true : undefined\n },\n blocks: Array.from(this.blocks.values())\n };\n return message.Message.encode(msg).finish();\n }\n serializeToBitswap110() {\n const msg = {\n wantlist: {\n entries: Array.from(this.wantlist.values()).map(entry => {\n return {\n block: entry.cid.bytes,\n priority: Number(entry.priority),\n wantType: entry.wantType,\n cancel: Boolean(entry.cancel),\n sendDontHave: Boolean(entry.sendDontHave)\n };\n }),\n full: this.full ? true : undefined\n },\n blockPresences: [],\n payload: [],\n pendingBytes: this.pendingBytes\n };\n for (const [cidStr, data] of this.blocks.entries()) {\n const cid$1 = cid.CID.parse(cidStr);\n const version = cid$1.version;\n const codec = cid$1.code;\n const multihash = cid$1.multihash.code;\n const digestLength = cid$1.multihash.digest.length;\n const prefix = varintEncoder([\n version,\n codec,\n multihash,\n digestLength\n ]);\n msg.payload.push(new message.Message.Block({\n prefix,\n data\n }));\n }\n for (const [cidStr, bpType] of this.blockPresences) {\n msg.blockPresences.push(new message.Message.BlockPresence({\n cid: cid.CID.parse(cidStr).bytes,\n type: bpType\n }));\n }\n if (this.pendingBytes > 0) {\n msg.pendingBytes = this.pendingBytes;\n }\n return message.Message.encode(msg).finish();\n }\n equals(other) {\n if (this.full !== other.full || this.pendingBytes !== other.pendingBytes || !index.isMapEqual(this.wantlist, other.wantlist) || !index.isMapEqual(this.blocks, other.blocks) || !index.isMapEqual(this.blockPresences, other.blockPresences)) {\n return false;\n }\n return true;\n }\n get [Symbol.toStringTag]() {\n const list = Array.from(this.wantlist.keys());\n const blocks = Array.from(this.blocks.keys());\n return `BitswapMessage `;\n }\n}\nBitswapMessage.deserialize = async (raw, hashLoader) => {\n const decoded = message.Message.decode(raw);\n const isFull = decoded.wantlist && decoded.wantlist.full || false;\n const msg = new BitswapMessage(isFull);\n if (decoded.wantlist && decoded.wantlist.entries) {\n decoded.wantlist.entries.forEach(entry => {\n if (!entry.block) {\n return;\n }\n const cid$1 = cid.CID.decode(entry.block);\n msg.addEntry(cid$1, entry.priority || 0, entry.wantType, Boolean(entry.cancel), Boolean(entry.sendDontHave));\n });\n }\n if (decoded.blockPresences) {\n decoded.blockPresences.forEach(blockPresence => {\n if (!blockPresence.cid) {\n return;\n }\n const cid$1 = cid.CID.decode(blockPresence.cid);\n if (blockPresence.type === BitswapMessage.BlockPresenceType.Have) {\n msg.addHave(cid$1);\n } else {\n msg.addDontHave(cid$1);\n }\n });\n }\n if (decoded.blocks.length > 0) {\n await Promise.all(decoded.blocks.map(async b => {\n const hash = await sha2.sha256.digest(b);\n const cid$1 = cid.CID.createV0(hash);\n msg.addBlock(cid$1, b);\n }));\n return msg;\n }\n if (decoded.payload.length > 0) {\n await Promise.all(decoded.payload.map(async p => {\n if (!p.prefix || !p.data) {\n return;\n }\n const values = vd__default[\"default\"](p.prefix);\n const cidVersion = values[0];\n const multicodec = values[1];\n const hashAlg = values[2];\n const hasher = hashAlg === sha2.sha256.code ? sha2.sha256 : hashLoader && await hashLoader.getHasher(hashAlg);\n if (!hasher) {\n throw errcode__default[\"default\"](new Error('Unknown hash algorithm'), 'ERR_UNKNOWN_HASH_ALG');\n }\n const hash = await hasher.digest(p.data);\n const cid$1 = cid.CID.create(cidVersion, multicodec, hash);\n msg.addBlock(cid$1, p.data);\n }));\n msg.setPendingBytes(decoded.pendingBytes);\n return msg;\n }\n return msg;\n};\nBitswapMessage.blockPresenceSize = cid => {\n return cid.bytes.length + 1;\n};\nBitswapMessage.Entry = entry.BitswapMessageEntry;\nBitswapMessage.WantType = {\n Block: message.Message.Wantlist.WantType.Block,\n Have: message.Message.Wantlist.WantType.Have\n};\nBitswapMessage.BlockPresenceType = {\n Have: message.Message.BlockPresenceType.Have,\n DontHave: message.Message.BlockPresenceType.DontHave\n};\n\nexports.BitswapMessage = BitswapMessage;\n","'use strict'\n\nconst varint = require('varint')\n\nmodule.exports = (buf) => {\n if (!(buf instanceof Uint8Array)) {\n throw new Error('arg needs to be a Uint8Array')\n }\n\n const result = []\n\n while (buf.length > 0) {\n const num = varint.decode(buf)\n result.push(num)\n buf = buf.slice(varint.decode.bytes)\n }\n\n return result\n}\n","module.exports = {\n encode: require('./encode.js')\n , decode: require('./decode.js')\n , encodingLength: require('./length.js')\n}\n","module.exports = encode\n\nvar MSB = 0x80\n , REST = 0x7F\n , MSBALL = ~REST\n , INT = Math.pow(2, 31)\n\nfunction encode(num, out, offset) {\n out = out || []\n offset = offset || 0\n var oldOffset = offset\n\n while(num >= INT) {\n out[offset++] = (num & 0xFF) | MSB\n num /= 128\n }\n while(num & MSBALL) {\n out[offset++] = (num & 0xFF) | MSB\n num >>>= 7\n }\n out[offset] = num | 0\n \n encode.bytes = offset - oldOffset + 1\n \n return out\n}\n","module.exports = read\n\nvar MSB = 0x80\n , REST = 0x7F\n\nfunction read(buf, offset) {\n var res = 0\n , offset = offset || 0\n , shift = 0\n , counter = offset\n , b\n , l = buf.length\n\n do {\n if (counter >= l) {\n read.bytes = 0\n throw new RangeError('Could not decode varint')\n }\n b = buf[counter++]\n res += shift < 28\n ? (b & REST) << shift\n : (b & REST) * Math.pow(2, shift)\n shift += 7\n } while (b >= MSB)\n\n read.bytes = counter - offset\n\n return res\n}\n","\nvar N1 = Math.pow(2, 7)\nvar N2 = Math.pow(2, 14)\nvar N3 = Math.pow(2, 21)\nvar N4 = Math.pow(2, 28)\nvar N5 = Math.pow(2, 35)\nvar N6 = Math.pow(2, 42)\nvar N7 = Math.pow(2, 49)\nvar N8 = Math.pow(2, 56)\nvar N9 = Math.pow(2, 63)\n\nmodule.exports = function (value) {\n return (\n value < N1 ? 1\n : value < N2 ? 2\n : value < N3 ? 3\n : value < N4 ? 4\n : value < N5 ? 5\n : value < N6 ? 6\n : value < N7 ? 7\n : value < N8 ? 8\n : value < N9 ? 9\n : 10\n )\n}\n","'use strict';\n\nvar varint = require('varint');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar varint__namespace = /*#__PURE__*/_interopNamespace(varint);\n\nfunction varintEncoder(buf) {\n let out = new Uint8Array(buf.reduce((acc, curr) => {\n return acc + varint__namespace.default.encodingLength(curr);\n }, 0));\n let offset = 0;\n for (const num of buf) {\n out = varint__namespace.encode(num, out, offset);\n offset += varint__namespace.default.encodingLength(num);\n }\n return out;\n}\n\nmodule.exports = varintEncoder;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar equals = require('uint8arrays/equals');\nvar entry = require('../message/entry.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst logger = (id, subsystem) => {\n const name = ['bitswap'];\n if (subsystem) {\n name.push(subsystem);\n }\n if (id) {\n name.push(`${ id.toB58String().slice(0, 8) }`);\n }\n return Object.assign(debug__default[\"default\"](name.join(':')), { error: debug__default[\"default\"](name.concat(['error']).join(':')) });\n};\nconst includesWith = (pred, x, list) => {\n let idx = 0;\n const len = list.length;\n while (idx < len) {\n if (pred(x, list[idx])) {\n return true;\n }\n idx += 1;\n }\n return false;\n};\nconst uniqWith = (pred, list) => {\n let idx = 0;\n const len = list.length;\n const result = [];\n let item;\n while (idx < len) {\n item = list[idx];\n if (!includesWith(pred, item, result)) {\n result[result.length] = item;\n }\n idx += 1;\n }\n return result;\n};\nconst groupBy = (pred, list) => {\n return list.reduce((acc, v) => {\n const k = pred(v);\n if (acc[k]) {\n acc[k].push(v);\n } else {\n acc[k] = [v];\n }\n return acc;\n }, {});\n};\nconst pullAllWith = (pred, list, values) => {\n return list.filter(i => {\n return !includesWith(pred, i, values);\n });\n};\nconst sortBy = (fn, list) => {\n return Array.prototype.slice.call(list, 0).sort((a, b) => {\n const aa = fn(a);\n const bb = fn(b);\n return aa < bb ? -1 : aa > bb ? 1 : 0;\n });\n};\nconst isMapEqual = (a, b) => {\n if (a.size !== b.size) {\n return false;\n }\n for (const [key, valueA] of a) {\n const valueB = b.get(key);\n if (valueB === undefined) {\n return false;\n }\n if (valueA instanceof Uint8Array && valueB instanceof Uint8Array && !equals.equals(valueA, valueB)) {\n return false;\n }\n if (valueA instanceof entry.BitswapMessageEntry && valueB instanceof entry.BitswapMessageEntry && !valueA.equals(valueB)) {\n return false;\n }\n }\n return true;\n};\n\nexports.groupBy = groupBy;\nexports.includesWith = includesWith;\nexports.isMapEqual = isMapEqual;\nexports.logger = logger;\nexports.pullAllWith = pullAllWith;\nexports.sortBy = sortBy;\nexports.uniqWith = uniqWith;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('../wantlist/index.js');\nvar base58 = require('multiformats/bases/base58');\n\nconst WantlistEntry = index.Wantlist.Entry;\nclass BitswapMessageEntry {\n constructor(cid, priority, wantType, cancel, sendDontHave) {\n this.entry = new WantlistEntry(cid, priority, wantType);\n this.cancel = Boolean(cancel);\n this.sendDontHave = Boolean(sendDontHave);\n }\n get cid() {\n return this.entry.cid;\n }\n set cid(cid) {\n this.entry.cid = cid;\n }\n get priority() {\n return this.entry.priority;\n }\n set priority(val) {\n this.entry.priority = val;\n }\n get wantType() {\n return this.entry.wantType;\n }\n set wantType(val) {\n this.entry.wantType = val;\n }\n get [Symbol.toStringTag]() {\n const cidStr = this.cid.toString(base58.base58btc);\n return `BitswapMessageEntry ${ cidStr } `;\n }\n equals(other) {\n return this.cancel === other.cancel && this.sendDontHave === other.sendDontHave && this.wantType === other.wantType && this.entry.equals(other.entry);\n }\n}\n\nexports.BitswapMessageEntry = BitswapMessageEntry;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar entry = require('./entry.js');\nvar base58 = require('multiformats/bases/base58');\nvar message = require('../message/message.js');\n\nconst WantType = {\n Block: message.Message.Wantlist.WantType.Block,\n Have: message.Message.Wantlist.WantType.Have\n};\nconst sortBy = (fn, list) => {\n return Array.prototype.slice.call(list, 0).sort((a, b) => {\n const aa = fn(a);\n const bb = fn(b);\n return aa < bb ? -1 : aa > bb ? 1 : 0;\n });\n};\nclass Wantlist {\n constructor(stats) {\n this.set = new Map();\n this._stats = stats;\n }\n get length() {\n return this.set.size;\n }\n add(cid, priority, wantType) {\n const cidStr = cid.toString(base58.base58btc);\n const entry$1 = this.set.get(cidStr);\n if (entry$1) {\n entry$1.inc();\n entry$1.priority = priority;\n if (entry$1.wantType === WantType.Have && wantType === WantType.Block) {\n entry$1.wantType = wantType;\n }\n } else {\n this.set.set(cidStr, new entry.WantListEntry(cid, priority, wantType));\n if (this._stats) {\n this._stats.push(null, 'wantListSize', 1);\n }\n }\n }\n remove(cid) {\n const cidStr = cid.toString(base58.base58btc);\n const entry = this.set.get(cidStr);\n if (!entry) {\n return;\n }\n entry.dec();\n if (entry.hasRefs()) {\n return;\n }\n this.set.delete(cidStr);\n if (this._stats) {\n this._stats.push(null, 'wantListSize', -1);\n }\n }\n removeForce(cidStr) {\n if (this.set.has(cidStr)) {\n this.set.delete(cidStr);\n }\n }\n forEach(fn) {\n return this.set.forEach(fn);\n }\n entries() {\n return this.set.entries();\n }\n sortedEntries() {\n return new Map(sortBy(o => o[1].key, Array.from(this.set.entries())));\n }\n contains(cid) {\n const cidStr = cid.toString(base58.base58btc);\n return this.set.has(cidStr);\n }\n get(cid) {\n const cidStr = cid.toString(base58.base58btc);\n return this.set.get(cidStr);\n }\n}\nWantlist.Entry = entry.WantListEntry;\n\nexports.Wantlist = Wantlist;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base58 = require('multiformats/bases/base58');\n\nclass WantListEntry {\n constructor(cid, priority, wantType) {\n this._refCounter = 1;\n this.cid = cid;\n this.priority = priority || 1;\n this.wantType = wantType;\n }\n inc() {\n this._refCounter += 1;\n }\n dec() {\n this._refCounter = Math.max(0, this._refCounter - 1);\n }\n hasRefs() {\n return this._refCounter > 0;\n }\n get [Symbol.toStringTag]() {\n const cidStr = this.cid.toString(base58.base58btc);\n return `WantlistEntry `;\n }\n equals(other) {\n return this._refCounter === other._refCounter && this.cid.equals(other.cid) && this.priority === other.priority && this.wantType === other.wantType;\n }\n}\n\nexports.WantListEntry = WantListEntry;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar $protobuf = require('protobufjs/minimal.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar $protobuf__default = /*#__PURE__*/_interopDefaultLegacy($protobuf);\n\nconst $Reader = $protobuf__default[\"default\"].Reader, $Writer = $protobuf__default[\"default\"].Writer, $util = $protobuf__default[\"default\"].util;\nconst $root = $protobuf__default[\"default\"].roots['ipfs-bitswap'] || ($protobuf__default[\"default\"].roots['ipfs-bitswap'] = {});\nconst Message = $root.Message = (() => {\n function Message(p) {\n this.blocks = [];\n this.payload = [];\n this.blockPresences = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Message.prototype.wantlist = null;\n Message.prototype.blocks = $util.emptyArray;\n Message.prototype.payload = $util.emptyArray;\n Message.prototype.blockPresences = $util.emptyArray;\n Message.prototype.pendingBytes = 0;\n Message.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.wantlist != null && Object.hasOwnProperty.call(m, 'wantlist'))\n $root.Message.Wantlist.encode(m.wantlist, w.uint32(10).fork()).ldelim();\n if (m.blocks != null && m.blocks.length) {\n for (var i = 0; i < m.blocks.length; ++i)\n w.uint32(18).bytes(m.blocks[i]);\n }\n if (m.payload != null && m.payload.length) {\n for (var i = 0; i < m.payload.length; ++i)\n $root.Message.Block.encode(m.payload[i], w.uint32(26).fork()).ldelim();\n }\n if (m.blockPresences != null && m.blockPresences.length) {\n for (var i = 0; i < m.blockPresences.length; ++i)\n $root.Message.BlockPresence.encode(m.blockPresences[i], w.uint32(34).fork()).ldelim();\n }\n if (m.pendingBytes != null && Object.hasOwnProperty.call(m, 'pendingBytes'))\n w.uint32(40).int32(m.pendingBytes);\n return w;\n };\n Message.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.wantlist = $root.Message.Wantlist.decode(r, r.uint32());\n break;\n case 2:\n if (!(m.blocks && m.blocks.length))\n m.blocks = [];\n m.blocks.push(r.bytes());\n break;\n case 3:\n if (!(m.payload && m.payload.length))\n m.payload = [];\n m.payload.push($root.Message.Block.decode(r, r.uint32()));\n break;\n case 4:\n if (!(m.blockPresences && m.blockPresences.length))\n m.blockPresences = [];\n m.blockPresences.push($root.Message.BlockPresence.decode(r, r.uint32()));\n break;\n case 5:\n m.pendingBytes = r.int32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Message.fromObject = function fromObject(d) {\n if (d instanceof $root.Message)\n return d;\n var m = new $root.Message();\n if (d.wantlist != null) {\n if (typeof d.wantlist !== 'object')\n throw TypeError('.Message.wantlist: object expected');\n m.wantlist = $root.Message.Wantlist.fromObject(d.wantlist);\n }\n if (d.blocks) {\n if (!Array.isArray(d.blocks))\n throw TypeError('.Message.blocks: array expected');\n m.blocks = [];\n for (var i = 0; i < d.blocks.length; ++i) {\n if (typeof d.blocks[i] === 'string')\n $util.base64.decode(d.blocks[i], m.blocks[i] = $util.newBuffer($util.base64.length(d.blocks[i])), 0);\n else if (d.blocks[i].length)\n m.blocks[i] = d.blocks[i];\n }\n }\n if (d.payload) {\n if (!Array.isArray(d.payload))\n throw TypeError('.Message.payload: array expected');\n m.payload = [];\n for (var i = 0; i < d.payload.length; ++i) {\n if (typeof d.payload[i] !== 'object')\n throw TypeError('.Message.payload: object expected');\n m.payload[i] = $root.Message.Block.fromObject(d.payload[i]);\n }\n }\n if (d.blockPresences) {\n if (!Array.isArray(d.blockPresences))\n throw TypeError('.Message.blockPresences: array expected');\n m.blockPresences = [];\n for (var i = 0; i < d.blockPresences.length; ++i) {\n if (typeof d.blockPresences[i] !== 'object')\n throw TypeError('.Message.blockPresences: object expected');\n m.blockPresences[i] = $root.Message.BlockPresence.fromObject(d.blockPresences[i]);\n }\n }\n if (d.pendingBytes != null) {\n m.pendingBytes = d.pendingBytes | 0;\n }\n return m;\n };\n Message.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.blocks = [];\n d.payload = [];\n d.blockPresences = [];\n }\n if (o.defaults) {\n d.wantlist = null;\n d.pendingBytes = 0;\n }\n if (m.wantlist != null && m.hasOwnProperty('wantlist')) {\n d.wantlist = $root.Message.Wantlist.toObject(m.wantlist, o);\n }\n if (m.blocks && m.blocks.length) {\n d.blocks = [];\n for (var j = 0; j < m.blocks.length; ++j) {\n d.blocks[j] = o.bytes === String ? $util.base64.encode(m.blocks[j], 0, m.blocks[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.blocks[j]) : m.blocks[j];\n }\n }\n if (m.payload && m.payload.length) {\n d.payload = [];\n for (var j = 0; j < m.payload.length; ++j) {\n d.payload[j] = $root.Message.Block.toObject(m.payload[j], o);\n }\n }\n if (m.blockPresences && m.blockPresences.length) {\n d.blockPresences = [];\n for (var j = 0; j < m.blockPresences.length; ++j) {\n d.blockPresences[j] = $root.Message.BlockPresence.toObject(m.blockPresences[j], o);\n }\n }\n if (m.pendingBytes != null && m.hasOwnProperty('pendingBytes')) {\n d.pendingBytes = m.pendingBytes;\n }\n return d;\n };\n Message.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n Message.Wantlist = function () {\n function Wantlist(p) {\n this.entries = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Wantlist.prototype.entries = $util.emptyArray;\n Wantlist.prototype.full = false;\n Wantlist.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.entries != null && m.entries.length) {\n for (var i = 0; i < m.entries.length; ++i)\n $root.Message.Wantlist.Entry.encode(m.entries[i], w.uint32(10).fork()).ldelim();\n }\n if (m.full != null && Object.hasOwnProperty.call(m, 'full'))\n w.uint32(16).bool(m.full);\n return w;\n };\n Wantlist.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.Wantlist();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.entries && m.entries.length))\n m.entries = [];\n m.entries.push($root.Message.Wantlist.Entry.decode(r, r.uint32()));\n break;\n case 2:\n m.full = r.bool();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Wantlist.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.Wantlist)\n return d;\n var m = new $root.Message.Wantlist();\n if (d.entries) {\n if (!Array.isArray(d.entries))\n throw TypeError('.Message.Wantlist.entries: array expected');\n m.entries = [];\n for (var i = 0; i < d.entries.length; ++i) {\n if (typeof d.entries[i] !== 'object')\n throw TypeError('.Message.Wantlist.entries: object expected');\n m.entries[i] = $root.Message.Wantlist.Entry.fromObject(d.entries[i]);\n }\n }\n if (d.full != null) {\n m.full = Boolean(d.full);\n }\n return m;\n };\n Wantlist.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.entries = [];\n }\n if (o.defaults) {\n d.full = false;\n }\n if (m.entries && m.entries.length) {\n d.entries = [];\n for (var j = 0; j < m.entries.length; ++j) {\n d.entries[j] = $root.Message.Wantlist.Entry.toObject(m.entries[j], o);\n }\n }\n if (m.full != null && m.hasOwnProperty('full')) {\n d.full = m.full;\n }\n return d;\n };\n Wantlist.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n Wantlist.WantType = function () {\n const valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = 'Block'] = 0;\n values[valuesById[1] = 'Have'] = 1;\n return values;\n }();\n Wantlist.Entry = function () {\n function Entry(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Entry.prototype.block = $util.newBuffer([]);\n Entry.prototype.priority = 0;\n Entry.prototype.cancel = false;\n Entry.prototype.wantType = 0;\n Entry.prototype.sendDontHave = false;\n Entry.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.block != null && Object.hasOwnProperty.call(m, 'block'))\n w.uint32(10).bytes(m.block);\n if (m.priority != null && Object.hasOwnProperty.call(m, 'priority'))\n w.uint32(16).int32(m.priority);\n if (m.cancel != null && Object.hasOwnProperty.call(m, 'cancel'))\n w.uint32(24).bool(m.cancel);\n if (m.wantType != null && Object.hasOwnProperty.call(m, 'wantType'))\n w.uint32(32).int32(m.wantType);\n if (m.sendDontHave != null && Object.hasOwnProperty.call(m, 'sendDontHave'))\n w.uint32(40).bool(m.sendDontHave);\n return w;\n };\n Entry.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.Wantlist.Entry();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.block = r.bytes();\n break;\n case 2:\n m.priority = r.int32();\n break;\n case 3:\n m.cancel = r.bool();\n break;\n case 4:\n m.wantType = r.int32();\n break;\n case 5:\n m.sendDontHave = r.bool();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Entry.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.Wantlist.Entry)\n return d;\n var m = new $root.Message.Wantlist.Entry();\n if (d.block != null) {\n if (typeof d.block === 'string')\n $util.base64.decode(d.block, m.block = $util.newBuffer($util.base64.length(d.block)), 0);\n else if (d.block.length)\n m.block = d.block;\n }\n if (d.priority != null) {\n m.priority = d.priority | 0;\n }\n if (d.cancel != null) {\n m.cancel = Boolean(d.cancel);\n }\n switch (d.wantType) {\n case 'Block':\n case 0:\n m.wantType = 0;\n break;\n case 'Have':\n case 1:\n m.wantType = 1;\n break;\n }\n if (d.sendDontHave != null) {\n m.sendDontHave = Boolean(d.sendDontHave);\n }\n return m;\n };\n Entry.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.block = '';\n else {\n d.block = [];\n if (o.bytes !== Array)\n d.block = $util.newBuffer(d.block);\n }\n d.priority = 0;\n d.cancel = false;\n d.wantType = o.enums === String ? 'Block' : 0;\n d.sendDontHave = false;\n }\n if (m.block != null && m.hasOwnProperty('block')) {\n d.block = o.bytes === String ? $util.base64.encode(m.block, 0, m.block.length) : o.bytes === Array ? Array.prototype.slice.call(m.block) : m.block;\n }\n if (m.priority != null && m.hasOwnProperty('priority')) {\n d.priority = m.priority;\n }\n if (m.cancel != null && m.hasOwnProperty('cancel')) {\n d.cancel = m.cancel;\n }\n if (m.wantType != null && m.hasOwnProperty('wantType')) {\n d.wantType = o.enums === String ? $root.Message.Wantlist.WantType[m.wantType] : m.wantType;\n }\n if (m.sendDontHave != null && m.hasOwnProperty('sendDontHave')) {\n d.sendDontHave = m.sendDontHave;\n }\n return d;\n };\n Entry.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n return Entry;\n }();\n return Wantlist;\n }();\n Message.Block = function () {\n function Block(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Block.prototype.prefix = $util.newBuffer([]);\n Block.prototype.data = $util.newBuffer([]);\n Block.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.prefix != null && Object.hasOwnProperty.call(m, 'prefix'))\n w.uint32(10).bytes(m.prefix);\n if (m.data != null && Object.hasOwnProperty.call(m, 'data'))\n w.uint32(18).bytes(m.data);\n return w;\n };\n Block.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.Block();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.prefix = r.bytes();\n break;\n case 2:\n m.data = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Block.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.Block)\n return d;\n var m = new $root.Message.Block();\n if (d.prefix != null) {\n if (typeof d.prefix === 'string')\n $util.base64.decode(d.prefix, m.prefix = $util.newBuffer($util.base64.length(d.prefix)), 0);\n else if (d.prefix.length)\n m.prefix = d.prefix;\n }\n if (d.data != null) {\n if (typeof d.data === 'string')\n $util.base64.decode(d.data, m.data = $util.newBuffer($util.base64.length(d.data)), 0);\n else if (d.data.length)\n m.data = d.data;\n }\n return m;\n };\n Block.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.prefix = '';\n else {\n d.prefix = [];\n if (o.bytes !== Array)\n d.prefix = $util.newBuffer(d.prefix);\n }\n if (o.bytes === String)\n d.data = '';\n else {\n d.data = [];\n if (o.bytes !== Array)\n d.data = $util.newBuffer(d.data);\n }\n }\n if (m.prefix != null && m.hasOwnProperty('prefix')) {\n d.prefix = o.bytes === String ? $util.base64.encode(m.prefix, 0, m.prefix.length) : o.bytes === Array ? Array.prototype.slice.call(m.prefix) : m.prefix;\n }\n if (m.data != null && m.hasOwnProperty('data')) {\n d.data = o.bytes === String ? $util.base64.encode(m.data, 0, m.data.length) : o.bytes === Array ? Array.prototype.slice.call(m.data) : m.data;\n }\n return d;\n };\n Block.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n return Block;\n }();\n Message.BlockPresenceType = function () {\n const valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = 'Have'] = 0;\n values[valuesById[1] = 'DontHave'] = 1;\n return values;\n }();\n Message.BlockPresence = function () {\n function BlockPresence(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n BlockPresence.prototype.cid = $util.newBuffer([]);\n BlockPresence.prototype.type = 0;\n BlockPresence.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.cid != null && Object.hasOwnProperty.call(m, 'cid'))\n w.uint32(10).bytes(m.cid);\n if (m.type != null && Object.hasOwnProperty.call(m, 'type'))\n w.uint32(16).int32(m.type);\n return w;\n };\n BlockPresence.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.BlockPresence();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.cid = r.bytes();\n break;\n case 2:\n m.type = r.int32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n BlockPresence.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.BlockPresence)\n return d;\n var m = new $root.Message.BlockPresence();\n if (d.cid != null) {\n if (typeof d.cid === 'string')\n $util.base64.decode(d.cid, m.cid = $util.newBuffer($util.base64.length(d.cid)), 0);\n else if (d.cid.length)\n m.cid = d.cid;\n }\n switch (d.type) {\n case 'Have':\n case 0:\n m.type = 0;\n break;\n case 'DontHave':\n case 1:\n m.type = 1;\n break;\n }\n return m;\n };\n BlockPresence.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.cid = '';\n else {\n d.cid = [];\n if (o.bytes !== Array)\n d.cid = $util.newBuffer(d.cid);\n }\n d.type = o.enums === String ? 'Have' : 0;\n }\n if (m.cid != null && m.hasOwnProperty('cid')) {\n d.cid = o.bytes === String ? $util.base64.encode(m.cid, 0, m.cid.length) : o.bytes === Array ? Array.prototype.slice.call(m.cid) : m.cid;\n }\n if (m.type != null && m.hasOwnProperty('type')) {\n d.type = o.enums === String ? $root.Message.BlockPresenceType[m.type] : m.type;\n }\n return d;\n };\n BlockPresence.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n return BlockPresence;\n }();\n return Message;\n})();\n\nexports.Message = Message;\nexports[\"default\"] = $root;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst SECOND = 1000;\nconst maxProvidersPerRequest = 3;\nconst providerRequestTimeout = 10 * SECOND;\nconst hasBlockTimeout = 15 * SECOND;\nconst provideTimeout = 15 * SECOND;\nconst kMaxPriority = Math.pow(2, 31) - 1;\nconst maxListeners = 1000;\nconst wantlistSendDebounceMs = 1;\n\nexports.hasBlockTimeout = hasBlockTimeout;\nexports.kMaxPriority = kMaxPriority;\nexports.maxListeners = maxListeners;\nexports.maxProvidersPerRequest = maxProvidersPerRequest;\nexports.provideTimeout = provideTimeout;\nexports.providerRequestTimeout = providerRequestTimeout;\nexports.wantlistSendDebounceMs = wantlistSendDebounceMs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debounce = require('just-debounce-it');\nvar index$1 = require('../message/index.js');\nvar index = require('../utils/index.js');\nvar constants = require('../constants.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debounce__default = /*#__PURE__*/_interopDefaultLegacy(debounce);\n\nclass MsgQueue {\n constructor(selfPeerId, otherPeerId, network) {\n this.peerId = otherPeerId;\n this.network = network;\n this.refcnt = 1;\n this._entries = [];\n this._log = index.logger(selfPeerId, 'msgqueue');\n this.sendEntries = debounce__default[\"default\"](this._sendEntries.bind(this), constants.wantlistSendDebounceMs);\n }\n addMessage(msg) {\n if (msg.empty) {\n return;\n }\n this.send(msg);\n }\n addEntries(entries) {\n this._entries = this._entries.concat(entries);\n this.sendEntries();\n }\n _sendEntries() {\n if (!this._entries.length) {\n return;\n }\n const msg = new index$1.BitswapMessage(false);\n this._entries.forEach(entry => {\n if (entry.cancel) {\n msg.cancel(entry.cid);\n } else {\n msg.addEntry(entry.cid, entry.priority);\n }\n });\n this._entries = [];\n this.addMessage(msg);\n }\n async send(msg) {\n try {\n await this.network.connectTo(this.peerId);\n } catch (err) {\n this._log.error('cant connect to peer %s: %s', this.peerId.toB58String(), err.message);\n return;\n }\n this._log('sending message to peer %s', this.peerId.toB58String());\n this.network.sendMessage(this.peerId, msg).catch(err => {\n this._log.error('send error: %s', err.message);\n });\n }\n}\n\nexports.MsgQueue = MsgQueue;\n","module.exports = debounce;\n\nfunction debounce(fn, wait, callFirst) {\n var timeout = null;\n var debouncedFn = null;\n\n var clear = function() {\n if (timeout) {\n clearTimeout(timeout);\n\n debouncedFn = null;\n timeout = null;\n }\n };\n\n var flush = function() {\n var call = debouncedFn;\n clear();\n\n if (call) {\n call();\n }\n };\n\n var debounceWrapper = function() {\n if (!wait) {\n return fn.apply(this, arguments);\n }\n\n var context = this;\n var args = arguments;\n var callNow = callFirst && !timeout;\n clear();\n\n debouncedFn = function() {\n fn.apply(context, args);\n };\n\n timeout = setTimeout(function() {\n timeout = null;\n\n if (!callNow) {\n var call = debouncedFn;\n debouncedFn = null;\n\n return call();\n }\n }, wait);\n\n if (callNow) {\n return debouncedFn();\n }\n };\n\n debounceWrapper.cancel = clear;\n debounceWrapper.flush = flush;\n\n return debounceWrapper;\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar lp = require('it-length-prefixed');\nvar itPipe = require('it-pipe');\nvar MulticodecTopology = require('libp2p-interfaces/src/topology/multicodec-topology.js');\nvar index$1 = require('./message/index.js');\nvar constants = require('./constants.js');\nvar index = require('./utils/index.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar lp__default = /*#__PURE__*/_interopDefaultLegacy(lp);\nvar MulticodecTopology__default = /*#__PURE__*/_interopDefaultLegacy(MulticodecTopology);\n\nconst BITSWAP100 = '/ipfs/bitswap/1.0.0';\nconst BITSWAP110 = '/ipfs/bitswap/1.1.0';\nconst BITSWAP120 = '/ipfs/bitswap/1.2.0';\nclass Network {\n constructor(libp2p, bitswap, stats, options = {}) {\n this._log = index.logger(libp2p.peerId, 'network');\n this._libp2p = libp2p;\n this._bitswap = bitswap;\n this._protocols = [BITSWAP100];\n if (!options.b100Only) {\n this._protocols.unshift(BITSWAP110);\n this._protocols.unshift(BITSWAP120);\n }\n this._stats = stats;\n this._running = false;\n this._onPeerConnect = this._onPeerConnect.bind(this);\n this._onPeerDisconnect = this._onPeerDisconnect.bind(this);\n this._onConnection = this._onConnection.bind(this);\n this._hashLoader = options.hashLoader;\n }\n start() {\n this._running = true;\n this._libp2p.handle(this._protocols, this._onConnection);\n const topology = new MulticodecTopology__default[\"default\"]({\n multicodecs: this._protocols,\n handlers: {\n onConnect: this._onPeerConnect,\n onDisconnect: this._onPeerDisconnect\n }\n });\n this._registrarId = this._libp2p.registrar.register(topology);\n for (const peer of this._libp2p.peerStore.peers.values()) {\n const conn = this._libp2p.connectionManager.get(peer.id);\n conn && this._onPeerConnect(conn.remotePeer);\n }\n }\n stop() {\n this._running = false;\n this._libp2p.unhandle(this._protocols);\n if (this._registrarId != null) {\n this._libp2p.registrar.unregister(this._registrarId);\n }\n }\n async _onConnection({protocol, stream, connection}) {\n if (!this._running) {\n return;\n }\n this._log('incoming new bitswap %s connection from %s', protocol, connection.remotePeer.toB58String());\n try {\n await itPipe.pipe(stream, lp__default[\"default\"].decode(), async source => {\n for await (const data of source) {\n try {\n const message = await index$1.BitswapMessage.deserialize(data.slice(), this._hashLoader);\n await this._bitswap._receiveMessage(connection.remotePeer, message);\n } catch (err) {\n this._bitswap._receiveError(err);\n break;\n }\n }\n });\n } catch (err) {\n this._log(err);\n }\n }\n _onPeerConnect(peerId) {\n this._bitswap._onPeerConnected(peerId);\n }\n _onPeerDisconnect(peerId) {\n this._bitswap._onPeerDisconnected(peerId);\n }\n findProviders(cid, maxProviders, options = {}) {\n return this._libp2p.contentRouting.findProviders(cid, {\n timeout: constants.providerRequestTimeout,\n maxNumProviders: maxProviders\n });\n }\n async findAndConnect(cid, options) {\n const connectAttempts = [];\n for await (const provider of this.findProviders(cid, constants.maxProvidersPerRequest, options)) {\n this._log(`connecting to provider ${ provider.id }`);\n connectAttempts.push(this.connectTo(provider.id, options).catch(err => {\n this._log.error(err);\n }));\n }\n await Promise.all(connectAttempts);\n }\n async provide(cid, options) {\n await this._libp2p.contentRouting.provide(cid, options);\n }\n async sendMessage(peer, msg) {\n if (!this._running)\n throw new Error('network isn\\'t running');\n const stringId = peer.toB58String();\n this._log('sendMessage to %s', stringId, msg);\n const connection = await this._libp2p.dial(peer);\n const {stream, protocol} = await connection.newStream([\n BITSWAP120,\n BITSWAP110,\n BITSWAP100\n ]);\n let serialized;\n switch (protocol) {\n case BITSWAP100:\n serialized = msg.serializeToBitswap100();\n break;\n case BITSWAP110:\n case BITSWAP120:\n serialized = msg.serializeToBitswap110();\n break;\n default:\n throw new Error('Unknown protocol: ' + protocol);\n }\n writeMessage(stream, serialized, this._log);\n this._updateSentStats(peer, msg.blocks);\n }\n async connectTo(peer, options) {\n if (!this._running) {\n throw new Error('network isn\\'t running');\n }\n return this._libp2p.dial(peer, options);\n }\n _updateSentStats(peer, blocks) {\n const peerId = peer.toB58String();\n if (this._stats) {\n for (const block of blocks.values()) {\n this._stats.push(peerId, 'dataSent', block.length);\n }\n this._stats.push(peerId, 'blocksSent', blocks.size);\n }\n }\n}\nasync function writeMessage(stream, msg, log) {\n try {\n await itPipe.pipe([msg], lp__default[\"default\"].encode(), stream);\n } catch (err) {\n log(err);\n }\n}\n\nexports.Network = Network;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar base58 = require('multiformats/bases/base58');\nvar index = require('../message/index.js');\nvar index$2 = require('../wantlist/index.js');\nvar ledger = require('./ledger.js');\nvar reqQueue = require('./req-queue.js');\nvar taskMerger = require('./task-merger.js');\nvar index$1 = require('../utils/index.js');\n\nconst WantType = index.BitswapMessage.WantType;\nconst TARGET_MESSAGE_SIZE = 16 * 1024;\nconst MAX_SIZE_REPLACE_HAS_WITH_BLOCK = 1024;\nclass DecisionEngine {\n constructor(peerId, blockstore, network, stats, opts = {}) {\n this._log = index$1.logger(peerId, 'engine');\n this.blockstore = blockstore;\n this.network = network;\n this._stats = stats;\n this._opts = this._processOpts(opts);\n this.ledgerMap = new Map();\n this._running = false;\n this._requestQueue = new reqQueue.RequestQueue(taskMerger.TaskMerger);\n }\n _processOpts(opts) {\n return {\n maxSizeReplaceHasWithBlock: MAX_SIZE_REPLACE_HAS_WITH_BLOCK,\n targetMessageSize: TARGET_MESSAGE_SIZE,\n ...opts\n };\n }\n _scheduleProcessTasks() {\n setTimeout(() => {\n this._processTasks();\n });\n }\n async _processTasks() {\n if (!this._running) {\n return;\n }\n const {peerId, tasks, pendingSize} = this._requestQueue.popTasks(this._opts.targetMessageSize);\n if (tasks.length === 0) {\n return;\n }\n const msg = new index.BitswapMessage(false);\n msg.setPendingBytes(pendingSize);\n const blockCids = [];\n const blockTasks = new Map();\n for (const task of tasks) {\n const cid$1 = cid.CID.parse(task.topic);\n if (task.data.haveBlock) {\n if (task.data.isWantBlock) {\n blockCids.push(cid$1);\n blockTasks.set(task.topic, task.data);\n } else {\n msg.addHave(cid$1);\n }\n } else {\n msg.addDontHave(cid$1);\n }\n }\n const blocks = await this._getBlocks(blockCids);\n for (const [topic, taskData] of blockTasks) {\n const cid$1 = cid.CID.parse(topic);\n const blk = blocks.get(topic);\n if (blk) {\n msg.addBlock(cid$1, blk);\n } else {\n if (taskData.sendDontHave) {\n msg.addDontHave(cid$1);\n }\n }\n }\n if (msg.empty) {\n peerId && this._requestQueue.tasksDone(peerId, tasks);\n this._scheduleProcessTasks();\n return;\n }\n try {\n peerId && await this.network.sendMessage(peerId, msg);\n for (const [cidStr, block] of blocks.entries()) {\n peerId && this.messageSent(peerId, cid.CID.parse(cidStr), block);\n }\n } catch (err) {\n this._log.error(err);\n }\n peerId && this._requestQueue.tasksDone(peerId, tasks);\n this._scheduleProcessTasks();\n }\n wantlistForPeer(peerId) {\n const peerIdStr = peerId.toB58String();\n const ledger = this.ledgerMap.get(peerIdStr);\n return ledger ? ledger.wantlist.sortedEntries() : new Map();\n }\n ledgerForPeer(peerId) {\n const peerIdStr = peerId.toB58String();\n const ledger = this.ledgerMap.get(peerIdStr);\n if (!ledger) {\n return null;\n }\n return {\n peer: ledger.partner,\n value: ledger.debtRatio(),\n sent: ledger.accounting.bytesSent,\n recv: ledger.accounting.bytesRecv,\n exchanged: ledger.exchangeCount\n };\n }\n peers() {\n return Array.from(this.ledgerMap.values()).map(l => l.partner);\n }\n receivedBlocks(blocks) {\n if (!blocks.length) {\n return;\n }\n for (const ledger of this.ledgerMap.values()) {\n for (const block of blocks) {\n const want = ledger.wantlistContains(block.cid);\n if (!want) {\n continue;\n }\n const blockSize = block.data.length;\n const isWantBlock = this._sendAsBlock(want.wantType, blockSize);\n let entrySize = blockSize;\n if (!isWantBlock) {\n entrySize = index.BitswapMessage.blockPresenceSize(want.cid);\n }\n this._requestQueue.pushTasks(ledger.partner, [{\n topic: want.cid.toString(base58.base58btc),\n priority: want.priority,\n size: entrySize,\n data: {\n blockSize,\n isWantBlock,\n haveBlock: true,\n sendDontHave: false\n }\n }]);\n }\n }\n this._scheduleProcessTasks();\n }\n async messageReceived(peerId, msg) {\n const ledger = this._findOrCreate(peerId);\n if (msg.empty) {\n return;\n }\n if (msg.full) {\n ledger.wantlist = new index$2.Wantlist();\n }\n this._updateBlockAccounting(msg.blocks, ledger);\n if (msg.wantlist.size === 0) {\n this._scheduleProcessTasks();\n return;\n }\n const cancels = [];\n const wants = [];\n msg.wantlist.forEach(entry => {\n if (entry.cancel) {\n ledger.cancelWant(entry.cid);\n cancels.push(entry.cid);\n } else {\n ledger.wants(entry.cid, entry.priority, entry.wantType);\n wants.push(entry);\n }\n });\n this._cancelWants(peerId, cancels);\n await this._addWants(peerId, wants);\n this._scheduleProcessTasks();\n }\n _cancelWants(peerId, cids) {\n for (const c of cids) {\n this._requestQueue.remove(c.toString(base58.base58btc), peerId);\n }\n }\n async _addWants(peerId, wants) {\n const blockSizes = await this._getBlockSizes(wants.map(w => w.cid));\n const tasks = [];\n for (const want of wants) {\n const id = want.cid.toString(base58.base58btc);\n const blockSize = blockSizes.get(id);\n if (blockSize == null) {\n if (want.sendDontHave) {\n tasks.push({\n topic: id,\n priority: want.priority,\n size: index.BitswapMessage.blockPresenceSize(want.cid),\n data: {\n isWantBlock: want.wantType === WantType.Block,\n blockSize: 0,\n haveBlock: false,\n sendDontHave: want.sendDontHave\n }\n });\n }\n } else {\n const isWantBlock = this._sendAsBlock(want.wantType, blockSize);\n let entrySize = blockSize;\n if (!isWantBlock) {\n entrySize = index.BitswapMessage.blockPresenceSize(want.cid);\n }\n tasks.push({\n topic: id,\n priority: want.priority,\n size: entrySize,\n data: {\n isWantBlock,\n blockSize,\n haveBlock: true,\n sendDontHave: want.sendDontHave\n }\n });\n }\n this._requestQueue.pushTasks(peerId, tasks);\n }\n }\n _sendAsBlock(wantType, blockSize) {\n return wantType === WantType.Block || blockSize <= this._opts.maxSizeReplaceHasWithBlock;\n }\n async _getBlockSizes(cids) {\n const blocks = await this._getBlocks(cids);\n return new Map([...blocks].map(([k, v]) => [\n k,\n v.length\n ]));\n }\n async _getBlocks(cids) {\n const res = new Map();\n await Promise.all(cids.map(async cid => {\n try {\n const block = await this.blockstore.get(cid);\n res.set(cid.toString(base58.base58btc), block);\n } catch (e) {\n if (e.code !== 'ERR_NOT_FOUND') {\n this._log.error('failed to query blockstore for %s: %s', cid, e);\n }\n }\n }));\n return res;\n }\n _updateBlockAccounting(blocksMap, ledger) {\n for (const block of blocksMap.values()) {\n this._log('got block (%s bytes)', block.length);\n ledger.receivedBytes(block.length);\n }\n }\n messageSent(peerId, cid, block) {\n const ledger = this._findOrCreate(peerId);\n ledger.sentBytes(block.length);\n ledger.wantlist.remove(cid);\n }\n numBytesSentTo(peerId) {\n return this._findOrCreate(peerId).accounting.bytesSent;\n }\n numBytesReceivedFrom(peerId) {\n return this._findOrCreate(peerId).accounting.bytesRecv;\n }\n peerDisconnected(_peerId) {\n }\n _findOrCreate(peerId) {\n const peerIdStr = peerId.toB58String();\n const ledger$1 = this.ledgerMap.get(peerIdStr);\n if (ledger$1) {\n return ledger$1;\n }\n const l = new ledger.Ledger(peerId);\n this.ledgerMap.set(peerIdStr, l);\n if (this._stats) {\n this._stats.push(peerIdStr, 'peerCount', 1);\n }\n return l;\n }\n start() {\n this._running = true;\n }\n stop() {\n this._running = false;\n }\n}\n\nexports.DecisionEngine = DecisionEngine;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('../wantlist/index.js');\n\nclass Ledger {\n constructor(peerId) {\n this.partner = peerId;\n this.wantlist = new index.Wantlist();\n this.exchangeCount = 0;\n this.sentToPeer = new Map();\n this.accounting = {\n bytesSent: 0,\n bytesRecv: 0\n };\n }\n sentBytes(n) {\n this.exchangeCount++;\n this.lastExchange = new Date().getTime();\n this.accounting.bytesSent += n;\n }\n receivedBytes(n) {\n this.exchangeCount++;\n this.lastExchange = new Date().getTime();\n this.accounting.bytesRecv += n;\n }\n wants(cid, priority, wantType) {\n this.wantlist.add(cid, priority, wantType);\n }\n cancelWant(cid) {\n this.wantlist.remove(cid);\n }\n wantlistContains(cid) {\n return this.wantlist.get(cid);\n }\n debtRatio() {\n return this.accounting.bytesSent / (this.accounting.bytesRecv + 1);\n }\n}\n\nexports.Ledger = Ledger;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar sortedMap = require('../utils/sorted-map.js');\n\nconst DefaultTaskMerger = {\n hasNewInfo() {\n return false;\n },\n merge() {\n }\n};\nclass RequestQueue {\n constructor(taskMerger = DefaultTaskMerger) {\n this._taskMerger = taskMerger;\n this._byPeer = new sortedMap.SortedMap([], PeerTasks.compare);\n }\n pushTasks(peerId, tasks) {\n let peerTasks = this._byPeer.get(peerId.toB58String());\n if (!peerTasks) {\n peerTasks = new PeerTasks(peerId, this._taskMerger);\n }\n peerTasks.pushTasks(tasks);\n this._byPeer.set(peerId.toB58String(), peerTasks);\n }\n popTasks(targetMinBytes) {\n const peerTasks = this._head();\n if (peerTasks === undefined) {\n return {\n tasks: [],\n pendingSize: 0\n };\n }\n const {tasks, pendingSize} = peerTasks.popTasks(targetMinBytes);\n if (tasks.length === 0) {\n return {\n tasks,\n pendingSize\n };\n }\n const peerId = peerTasks.peerId;\n if (peerTasks.isIdle()) {\n this._byPeer.delete(peerId.toB58String());\n } else {\n this._byPeer.update(0);\n }\n return {\n peerId,\n tasks,\n pendingSize\n };\n }\n _head() {\n if (this._byPeer.size === 0) {\n return undefined;\n }\n for (const [, v] of this._byPeer) {\n return v;\n }\n return undefined;\n }\n remove(topic, peerId) {\n const peerTasks = this._byPeer.get(peerId.toB58String());\n peerTasks && peerTasks.remove(topic);\n }\n tasksDone(peerId, tasks) {\n const peerTasks = this._byPeer.get(peerId.toB58String());\n if (!peerTasks) {\n return;\n }\n const i = this._byPeer.indexOf(peerId.toB58String());\n for (const task of tasks) {\n peerTasks.taskDone(task);\n }\n this._byPeer.update(i);\n }\n}\nclass PeerTasks {\n constructor(peerId, taskMerger) {\n this.peerId = peerId;\n this._taskMerger = taskMerger;\n this._activeTotalSize = 0;\n this._pending = new PendingTasks();\n this._active = new Set();\n }\n pushTasks(tasks) {\n for (const t of tasks) {\n this._pushTask(t);\n }\n }\n _pushTask(task) {\n if (!this._taskHasMoreInfoThanActiveTasks(task)) {\n return;\n }\n const existingTask = this._pending.get(task.topic);\n if (existingTask) {\n if (task.priority > existingTask.priority) {\n this._pending.updatePriority(task.topic, task.priority);\n }\n this._taskMerger.merge(task, existingTask);\n return;\n }\n this._pending.add(task);\n }\n _taskHasMoreInfoThanActiveTasks(task) {\n const tasksWithTopic = [];\n for (const activeTask of this._active) {\n if (activeTask.topic === task.topic) {\n tasksWithTopic.push(activeTask);\n }\n }\n if (tasksWithTopic.length === 0) {\n return true;\n }\n return this._taskMerger.hasNewInfo(task, tasksWithTopic);\n }\n popTasks(targetMinBytes) {\n let size = 0;\n const tasks = [];\n const pendingTasks = this._pending.tasks();\n for (let i = 0; i < pendingTasks.length && size < targetMinBytes; i++) {\n const task = pendingTasks[i];\n tasks.push(task);\n size += task.size;\n this._pending.delete(task.topic);\n this._activeTotalSize += task.size;\n this._active.add(task);\n }\n return {\n tasks,\n pendingSize: this._pending.totalSize\n };\n }\n taskDone(task) {\n if (this._active.has(task)) {\n this._activeTotalSize -= task.size;\n this._active.delete(task);\n }\n }\n remove(topic) {\n this._pending.delete(topic);\n }\n isIdle() {\n return this._pending.length === 0 && this._active.size === 0;\n }\n static compare(a, b) {\n if (a[1]._pending.length === 0) {\n return 1;\n }\n if (b[1]._pending.length === 0) {\n return -1;\n }\n if (a[1]._activeTotalSize === b[1]._activeTotalSize) {\n return b[1]._pending.length - a[1]._pending.length;\n }\n return a[1]._activeTotalSize - b[1]._activeTotalSize;\n }\n}\nclass PendingTasks {\n constructor() {\n this._tasks = new sortedMap.SortedMap([], this._compare);\n }\n get length() {\n return this._tasks.size;\n }\n get totalSize() {\n return [...this._tasks.values()].reduce((a, t) => a + t.task.size, 0);\n }\n get(topic) {\n return (this._tasks.get(topic) || {}).task;\n }\n add(task) {\n this._tasks.set(task.topic, {\n created: Date.now(),\n task\n });\n }\n delete(topic) {\n this._tasks.delete(topic);\n }\n tasks() {\n return [...this._tasks.values()].map(i => i.task);\n }\n updatePriority(topic, priority) {\n const obj = this._tasks.get(topic);\n if (!obj) {\n return;\n }\n const i = this._tasks.indexOf(topic);\n obj.task.priority = priority;\n this._tasks.update(i);\n }\n _compare(a, b) {\n if (a[1].task.priority === b[1].task.priority) {\n return a[1].created - b[1].created;\n }\n return b[1].task.priority - a[1].task.priority;\n }\n}\n\nexports.RequestQueue = RequestQueue;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass SortedMap extends Map {\n constructor(entries, cmp) {\n super();\n this._cmp = cmp || this._defaultSort;\n this._keys = [];\n for (const [k, v] of entries || []) {\n this.set(k, v);\n }\n }\n update(i) {\n if (i < 0 || i >= this._keys.length) {\n return;\n }\n const k = this._keys[i];\n this._keys.splice(i, 1);\n const newIdx = this._find(k);\n this._keys.splice(newIdx, 0, k);\n }\n set(k, v) {\n if (this.has(k)) {\n const i = this.indexOf(k);\n this._keys.splice(i, 1);\n }\n super.set(k, v);\n const i = this._find(k);\n this._keys.splice(i, 0, k);\n return this;\n }\n clear() {\n super.clear();\n this._keys = [];\n }\n delete(k) {\n if (!this.has(k)) {\n return false;\n }\n const i = this.indexOf(k);\n this._keys.splice(i, 1);\n return super.delete(k);\n }\n indexOf(k) {\n if (!this.has(k)) {\n return -1;\n }\n const i = this._find(k);\n if (this._keys[i] === k) {\n return i;\n }\n for (let j = 1; j < this._keys.length; j++) {\n if (this._keys[i + j] === k)\n return i + j;\n if (this._keys[i - j] === k)\n return i - j;\n }\n return -1;\n }\n _find(k) {\n let lower = 0;\n let upper = this._keys.length;\n while (lower < upper) {\n const pivot = lower + upper >>> 1;\n const cmp = this._kCmp(this._keys[pivot], k);\n if (cmp < 0) {\n lower = pivot + 1;\n } else if (cmp > 0) {\n upper = pivot;\n } else {\n return pivot;\n }\n }\n return lower;\n }\n *keys() {\n for (const k of this._keys) {\n yield k;\n }\n return undefined;\n }\n *values() {\n for (const k of this._keys) {\n yield this.get(k);\n }\n return undefined;\n }\n *entries() {\n for (const k of this._keys) {\n yield [\n k,\n this.get(k)\n ];\n }\n return undefined;\n }\n *[Symbol.iterator]() {\n yield* this.entries();\n }\n forEach(cb, thisArg) {\n if (!cb) {\n return;\n }\n for (const k of this._keys) {\n cb.apply(thisArg, [[\n k,\n this.get(k)\n ]]);\n }\n }\n _defaultSort(a, b) {\n if (a[0] < b[0])\n return -1;\n if (b[0] < a[0])\n return 1;\n return 0;\n }\n _kCmp(a, b) {\n return this._cmp([\n a,\n this.get(a)\n ], [\n b,\n this.get(b)\n ]);\n }\n}\n\nexports.SortedMap = SortedMap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst TaskMerger = {\n hasNewInfo(task, tasksWithTopic) {\n let haveBlock = false;\n let isWantBlock = false;\n for (const existing of tasksWithTopic) {\n if (existing.data.haveBlock) {\n haveBlock = true;\n }\n if (existing.data.isWantBlock) {\n isWantBlock = true;\n }\n }\n if (!isWantBlock && task.data.isWantBlock) {\n return true;\n }\n if (!haveBlock && task.data.haveBlock) {\n return true;\n }\n return false;\n },\n merge(newTask, existingTask) {\n const taskData = newTask.data;\n const existingData = existingTask.data;\n if (!existingData.haveBlock && taskData.haveBlock) {\n existingData.haveBlock = taskData.haveBlock;\n existingData.blockSize = taskData.blockSize;\n }\n if (!existingData.isWantBlock && taskData.isWantBlock) {\n existingData.isWantBlock = true;\n if (!existingData.haveBlock || taskData.haveBlock) {\n existingData.haveBlock = taskData.haveBlock;\n existingTask.size = newTask.size;\n }\n }\n if (existingData.isWantBlock && existingData.haveBlock) {\n existingTask.size = existingData.blockSize;\n }\n }\n};\n\nexports.TaskMerger = TaskMerger;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar events = require('events');\nvar toString = require('uint8arrays/to-string');\nvar constants = require('./constants.js');\nvar index = require('./utils/index.js');\n\nconst unwantEvent = cid => `unwant:${ toString.toString(cid.multihash.bytes, 'base64') }`;\nconst blockEvent = cid => `block:${ toString.toString(cid.multihash.bytes, 'base64') }`;\nclass Notifications extends events.EventEmitter {\n constructor(peerId) {\n super();\n this.setMaxListeners(constants.maxListeners);\n this._log = index.logger(peerId, 'notif');\n }\n hasBlock(cid, block) {\n const event = blockEvent(cid);\n this._log(event);\n this.emit(event, block);\n }\n wantBlock(cid, options = {}) {\n if (!cid) {\n throw new Error('Not a valid cid');\n }\n const blockEvt = blockEvent(cid);\n const unwantEvt = unwantEvent(cid);\n this._log(`wantBlock:${ cid }`);\n return new Promise((resolve, reject) => {\n const onUnwant = () => {\n this.removeListener(blockEvt, onBlock);\n reject(new Error(`Block for ${ cid } unwanted`));\n };\n const onBlock = data => {\n this.removeListener(unwantEvt, onUnwant);\n resolve(data);\n };\n this.once(unwantEvt, onUnwant);\n this.once(blockEvt, onBlock);\n if (options && options.signal) {\n options.signal.addEventListener('abort', () => {\n this.removeListener(blockEvt, onBlock);\n this.removeListener(unwantEvt, onUnwant);\n reject(new Error(`Want for ${ cid } aborted`));\n });\n }\n });\n }\n unwantBlock(cid) {\n const event = unwantEvent(cid);\n this._log(event);\n this.emit(event);\n }\n}\n\nexports.Notifications = Notifications;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar events = require('events');\nvar stat = require('./stat.js');\n\nconst defaultOptions = {\n enabled: false,\n computeThrottleTimeout: 1000,\n computeThrottleMaxQueueSize: 1000,\n movingAverageIntervals: [\n 60 * 1000,\n 5 * 60 * 1000,\n 15 * 60 * 1000\n ]\n};\nclass Stats extends events.EventEmitter {\n constructor(initialCounters = [], _options = defaultOptions) {\n super();\n const options = Object.assign({}, defaultOptions, _options);\n if (typeof options.computeThrottleTimeout !== 'number') {\n throw new Error('need computeThrottleTimeout');\n }\n if (typeof options.computeThrottleMaxQueueSize !== 'number') {\n throw new Error('need computeThrottleMaxQueueSize');\n }\n this._initialCounters = initialCounters;\n this._options = options;\n this._enabled = this._options.enabled;\n this._global = new stat.Stat(initialCounters, options);\n this._global.on('update', stats => this.emit('update', stats));\n this._peers = new Map();\n }\n enable() {\n this._enabled = true;\n this._options.enabled = true;\n this._global.enable();\n }\n disable() {\n this._enabled = false;\n this._options.enabled = false;\n this._global.disable();\n }\n stop() {\n this._enabled = false;\n this._global.stop();\n for (const peerStat of this._peers) {\n peerStat[1].stop();\n }\n }\n get snapshot() {\n return this._global.snapshot;\n }\n get movingAverages() {\n return this._global.movingAverages;\n }\n forPeer(peerId) {\n const peerIdStr = typeof peerId !== 'string' && peerId.toB58String ? peerId.toB58String() : `${ peerId }`;\n return this._peers.get(peerIdStr);\n }\n push(peer, counter, inc) {\n if (this._enabled) {\n this._global.push(counter, inc);\n if (peer) {\n let peerStats = this._peers.get(peer);\n if (!peerStats) {\n peerStats = new stat.Stat(this._initialCounters, this._options);\n this._peers.set(peer, peerStats);\n }\n peerStats.push(counter, inc);\n }\n }\n }\n disconnected(peer) {\n const peerId = peer.toB58String();\n const peerStats = this._peers.get(peerId);\n if (peerStats) {\n peerStats.stop();\n this._peers.delete(peerId);\n }\n }\n}\n\nexports.Stats = Stats;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar events = require('events');\nvar MovingAverage = require('@vascosantos/moving-average');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar MovingAverage__default = /*#__PURE__*/_interopDefaultLegacy(MovingAverage);\n\nclass Stat extends events.EventEmitter {\n constructor(initialCounters, options) {\n super();\n this._options = options;\n this._queue = [];\n this._stats = {};\n this._frequencyLastTime = Date.now();\n this._frequencyAccumulators = {};\n this._movingAverages = {};\n this._update = this._update.bind(this);\n initialCounters.forEach(key => {\n this._stats[key] = BigInt(0);\n this._movingAverages[key] = {};\n this._options.movingAverageIntervals.forEach(interval => {\n const ma = this._movingAverages[key][interval] = MovingAverage__default[\"default\"](interval);\n ma.push(this._frequencyLastTime, 0);\n });\n });\n this._enabled = this._options.enabled;\n }\n enable() {\n this._enabled = true;\n }\n disable() {\n this._disabled = true;\n }\n stop() {\n if (this._timeout) {\n clearTimeout(this._timeout);\n }\n }\n get snapshot() {\n return Object.assign({}, this._stats);\n }\n get movingAverages() {\n return Object.assign({}, this._movingAverages);\n }\n push(counter, inc) {\n if (this._enabled) {\n this._queue.push([\n counter,\n inc,\n Date.now()\n ]);\n this._resetComputeTimeout();\n }\n }\n _resetComputeTimeout() {\n if (this._timeout) {\n clearTimeout(this._timeout);\n }\n this._timeout = setTimeout(this._update, this._nextTimeout());\n }\n _nextTimeout() {\n const urgency = this._queue.length / this._options.computeThrottleMaxQueueSize;\n return Math.max(this._options.computeThrottleTimeout * (1 - urgency), 0);\n }\n _update() {\n this._timeout = null;\n if (this._queue.length) {\n let last;\n while (this._queue.length) {\n const op = last = this._queue.shift();\n op && this._applyOp(op);\n }\n last && this._updateFrequency(last[2]);\n this.emit('update', this._stats);\n }\n }\n _updateFrequency(latestTime) {\n const timeDiff = latestTime - this._frequencyLastTime;\n if (timeDiff) {\n Object.keys(this._stats).forEach(key => {\n this._updateFrequencyFor(key, timeDiff, latestTime);\n });\n }\n this._frequencyLastTime = latestTime;\n }\n _updateFrequencyFor(key, timeDiffMS, latestTime) {\n const count = this._frequencyAccumulators[key] || 0;\n this._frequencyAccumulators[key] = 0;\n const hz = count / timeDiffMS * 1000;\n let movingAverages = this._movingAverages[key];\n if (!movingAverages) {\n movingAverages = this._movingAverages[key] = {};\n }\n this._options.movingAverageIntervals.forEach(movingAverageInterval => {\n let movingAverage = movingAverages[movingAverageInterval];\n if (!movingAverage) {\n movingAverage = movingAverages[movingAverageInterval] = MovingAverage__default[\"default\"](movingAverageInterval);\n }\n movingAverage.push(latestTime, hz);\n });\n }\n _applyOp(op) {\n const key = op[0];\n const inc = op[1];\n if (typeof inc !== 'number') {\n throw new Error(`invalid increment number: ${ inc }`);\n }\n if (!Object.prototype.hasOwnProperty.call(this._stats, key)) {\n this._stats[key] = BigInt(0);\n }\n this._stats[key] = BigInt(this._stats[key]) + BigInt(inc);\n if (!this._frequencyAccumulators[key]) {\n this._frequencyAccumulators[key] = 0;\n }\n this._frequencyAccumulators[key] += inc;\n }\n}\n\nexports.Stat = Stat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar blockstoreCore = require('blockstore-core');\nvar merge = require('it-merge');\nvar pushable = require('it-pushable');\nvar filter = require('it-filter');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar merge__default = /*#__PURE__*/_interopDefaultLegacy(merge);\nvar pushable__default = /*#__PURE__*/_interopDefaultLegacy(pushable);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\n\nclass BlockStorage extends blockstoreCore.BaseBlockstore {\n constructor(blockstore, bitswap) {\n super();\n this.child = blockstore;\n this.bitswap = bitswap;\n }\n open() {\n return this.child.open();\n }\n close() {\n return this.child.close();\n }\n unwrap() {\n return this.child;\n }\n async put(cid, block, options = {}) {\n if (await this.has(cid)) {\n return;\n }\n if (this.bitswap.isStarted()) {\n await this.bitswap.put(cid, block, options);\n } else {\n await this.child.put(cid, block, options);\n }\n }\n async *putMany(blocks, options = {}) {\n const missingBlocks = filter__default['default'](blocks, async ({key}) => {\n return !await this.has(key);\n });\n if (this.bitswap.isStarted()) {\n yield* this.bitswap.putMany(missingBlocks, options);\n } else {\n yield* this.child.putMany(missingBlocks, options);\n }\n }\n async get(cid, options = {}) {\n if (!await this.has(cid) && this.bitswap.isStarted()) {\n return this.bitswap.get(cid, options);\n } else {\n return this.child.get(cid, options);\n }\n }\n async *getMany(cids, options = {}) {\n const getFromBitswap = pushable__default['default']();\n const getFromChild = pushable__default['default']();\n Promise.resolve().then(async () => {\n for await (const cid of cids) {\n if (!await this.has(cid) && this.bitswap.isStarted()) {\n getFromBitswap.push(cid);\n } else {\n getFromChild.push(cid);\n }\n }\n getFromBitswap.end();\n getFromChild.end();\n });\n yield* merge__default['default'](this.bitswap.getMany(getFromBitswap, options), this.child.getMany(getFromChild, options));\n }\n async delete(cid, options) {\n await this.child.delete(cid, options);\n }\n async *deleteMany(cids, options) {\n yield* this.child.deleteMany(cids, options);\n }\n async has(cid, options = {}) {\n return this.child.has(cid, options);\n }\n async *query(q, options = {}) {\n yield* this.child.query(q, options);\n }\n async *queryKeys(q, options = {}) {\n yield* this.child.queryKeys(q, options);\n }\n}\n\nexports.BlockStorage = BlockStorage;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('./errors.js');\nvar base = require('./base.js');\nvar memory = require('./memory.js');\n\nconst Errors = { ...errors };\n\nexports.BaseBlockstore = base.BaseBlockstore;\nexports.MemoryBlockstore = memory.MemoryBlockstore;\nexports.Errors = Errors;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction notFoundError(err) {\n err = err || new Error('Not Found');\n return errCode__default['default'](err, 'ERR_NOT_FOUND');\n}\nfunction abortedError(err) {\n err = err || new Error('Aborted');\n return errCode__default['default'](err, 'ERR_ABORTED');\n}\n\nexports.abortedError = abortedError;\nexports.notFoundError = notFoundError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar base32 = require('multiformats/bases/base32');\nvar raw = require('multiformats/codecs/raw');\nvar cid = require('multiformats/cid');\nvar Digest = require('multiformats/hashes/digest');\nvar errors = require('./errors.js');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\n\nclass MemoryBlockstore extends base.BaseBlockstore {\n constructor() {\n super();\n this.data = {};\n }\n open() {\n return Promise.resolve();\n }\n close() {\n return Promise.resolve();\n }\n async put(key, val) {\n this.data[base32.base32.encode(key.multihash.bytes)] = val;\n }\n async get(key) {\n const exists = await this.has(key);\n if (!exists)\n throw errors.notFoundError();\n return this.data[base32.base32.encode(key.multihash.bytes)];\n }\n async has(key) {\n return this.data[base32.base32.encode(key.multihash.bytes)] !== undefined;\n }\n async delete(key) {\n delete this.data[base32.base32.encode(key.multihash.bytes)];\n }\n async *_all() {\n yield* Object.entries(this.data).map(([key, value]) => ({\n key: cid.CID.createV1(raw__namespace.code, Digest__namespace.decode(base32.base32.decode(key))),\n value\n }));\n }\n async *_allKeys() {\n yield* Object.entries(this.data).map(([key]) => cid.CID.createV1(raw__namespace.code, Digest__namespace.decode(base32.base32.decode(key))));\n }\n}\n\nexports.MemoryBlockstore = MemoryBlockstore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addrs = require('./addrs.js');\nvar connect = require('./connect.js');\nvar disconnect = require('./disconnect.js');\nvar localAddrs = require('./local-addrs.js');\nvar peers = require('./peers.js');\n\nclass SwarmAPI {\n constructor({network}) {\n this.addrs = addrs.createAddrs({ network });\n this.connect = connect.createConnect({ network });\n this.disconnect = disconnect.createDisconnect({ network });\n this.localAddrs = localAddrs.createLocalAddrs({ network });\n this.peers = peers.createPeers({ network });\n }\n}\n\nexports.SwarmAPI = SwarmAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createAddrs({network}) {\n async function addrs(options = {}) {\n const peers = [];\n const {libp2p} = await network.use(options);\n for (const [peerId, peer] of libp2p.peerStore.peers.entries()) {\n peers.push({\n id: peerId,\n addrs: peer.addresses.map(mi => mi.multiaddr)\n });\n }\n return peers;\n }\n return withTimeoutOption.withTimeoutOption(addrs);\n}\n\nexports.createAddrs = createAddrs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createConnect({network}) {\n async function connect(addr, options = {}) {\n const {libp2p} = await network.use(options);\n await libp2p.dial(addr, options);\n }\n return withTimeoutOption.withTimeoutOption(connect);\n}\n\nexports.createConnect = createConnect;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createDisconnect({network}) {\n async function disconnect(addr, options = {}) {\n const {libp2p} = await network.use(options);\n await libp2p.hangUp(addr);\n }\n return withTimeoutOption.withTimeoutOption(disconnect);\n}\n\nexports.createDisconnect = createDisconnect;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createLocalAddrs({network}) {\n async function localAddrs(options = {}) {\n const {libp2p} = await network.use(options);\n return libp2p.multiaddrs;\n }\n return withTimeoutOption.withTimeoutOption(localAddrs);\n}\n\nexports.createLocalAddrs = createLocalAddrs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createPeers({network}) {\n async function peers(options = {}) {\n const {libp2p} = await network.use(options);\n const peers = [];\n for (const [peerId, connections] of libp2p.connections) {\n for (const connection of connections) {\n const peer = {\n addr: connection.remoteAddr,\n peer: peerId\n };\n if (options.verbose || options.direction) {\n peer.direction = connection.stat.direction;\n }\n if (options.verbose) {\n peer.muxer = connection.stat.multiplexer;\n peer.latency = 'n/a';\n peer.streams = [];\n }\n peers.push(peer);\n }\n }\n return peers;\n }\n return withTimeoutOption.withTimeoutOption(peers);\n}\n\nexports.createPeers = createPeers;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\n\nconst basePacket = {\n success: true,\n time: 0,\n text: ''\n};\nfunction createPing({network}) {\n async function* ping(peerId, options = {}) {\n const {libp2p} = await network.use();\n options.count = options.count || 10;\n const peer = PeerId__default['default'].createFromB58String(peerId);\n const storedPeer = libp2p.peerStore.get(peer);\n let id = storedPeer && storedPeer.id;\n if (!id) {\n yield {\n ...basePacket,\n text: `Looking up peer ${ peerId }`\n };\n const remotePeer = await libp2p.peerRouting.findPeer(peer);\n id = remotePeer && remotePeer.id;\n }\n if (!id) {\n throw new Error('Peer was not found');\n }\n yield {\n ...basePacket,\n text: `PING ${ id.toB58String() }`\n };\n let packetCount = 0;\n let totalTime = 0;\n for (let i = 0; i < options.count; i++) {\n try {\n const time = await libp2p.ping(id);\n totalTime += time;\n packetCount++;\n yield {\n ...basePacket,\n time\n };\n } catch (err) {\n yield {\n ...basePacket,\n success: false,\n text: err.toString()\n };\n }\n }\n if (packetCount) {\n const average = totalTime / packetCount;\n yield {\n ...basePacket,\n text: `Average latency: ${ average }ms`\n };\n }\n }\n return withTimeoutOption.withTimeoutOption(ping);\n}\n\nexports.createPing = createPing;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar errCode = require('err-code');\nvar errors = require('../errors.js');\nvar get = require('dlv');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar get__default = /*#__PURE__*/_interopDefaultLegacy(get);\n\nfunction createDht({network, repo}) {\n const {get, put, findProvs, findPeer, provide, query} = {\n async get(key, options = {}) {\n const {libp2p} = await use(network, options);\n return libp2p._dht.get(key, options);\n },\n async *put(key, value, options) {\n const {libp2p} = await use(network, options);\n yield* libp2p._dht.put(key, value);\n },\n async *findProvs(cid, options = { numProviders: 20 }) {\n const {libp2p} = await use(network, options);\n for await (const peer of libp2p._dht.findProviders(cid, {\n maxNumProviders: options.numProviders,\n signal: options.signal\n })) {\n yield {\n id: peer.id.toB58String(),\n addrs: peer.addrs\n };\n }\n },\n async findPeer(peerId, options) {\n const {libp2p} = await use(network, options);\n const peer = await libp2p._dht.findPeer(PeerId__default['default'].parse(peerId));\n return {\n id: peer.id.toB58String(),\n addrs: peer.multiaddrs\n };\n },\n async *provide(cids, options = { recursive: false }) {\n const {libp2p} = await use(network, options);\n const cidArr = Array.isArray(cids) ? cids : [cids];\n const hasCids = await Promise.all(cidArr.map(cid => repo.blocks.has(cid)));\n const hasAll = hasCids.every(has => has);\n if (!hasAll) {\n throw errCode__default['default'](new Error('block(s) not found locally, cannot provide'), 'ERR_BLOCK_NOT_FOUND');\n }\n if (options.recursive) {\n throw errCode__default['default'](new Error('not implemented yet'), 'ERR_NOT_IMPLEMENTED_YET');\n }\n for (const cid of cidArr) {\n yield libp2p._dht.provide(cid);\n }\n },\n async *query(peerId, options) {\n const {libp2p} = await use(network, options);\n for await (const closerPeerId of libp2p._dht.getClosestPeers(PeerId__default['default'].parse(peerId).toBytes())) {\n yield {\n id: closerPeerId.toB58String(),\n addrs: []\n };\n }\n }\n };\n return {\n get: withTimeoutOption.withTimeoutOption(get),\n put: withTimeoutOption.withTimeoutOption(put),\n findProvs: withTimeoutOption.withTimeoutOption(findProvs),\n findPeer: withTimeoutOption.withTimeoutOption(findPeer),\n provide: withTimeoutOption.withTimeoutOption(provide),\n query: withTimeoutOption.withTimeoutOption(query)\n };\n}\nconst use = async (network, options) => {\n const net = await network.use(options);\n if (get__default['default'](net.libp2p, '_config.dht.enabled', false)) {\n return net;\n } else {\n throw new errors.NotEnabledError('dht not enabled');\n }\n};\n\nexports.createDht = createDht;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar errCode = require('err-code');\nvar errors = require('../errors.js');\nvar get = require('dlv');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar get__default = /*#__PURE__*/_interopDefaultLegacy(get);\n\nfunction createPubsub({network, config}) {\n const isEnabled = get__default['default'](config || {}, 'Pubsub.Enabled', true);\n return {\n subscribe: isEnabled ? withTimeoutOption.withTimeoutOption(subscribe) : notEnabled,\n unsubscribe: isEnabled ? withTimeoutOption.withTimeoutOption(unsubscribe) : notEnabled,\n publish: isEnabled ? withTimeoutOption.withTimeoutOption(publish) : notEnabled,\n ls: isEnabled ? withTimeoutOption.withTimeoutOption(ls) : notEnabled,\n peers: isEnabled ? withTimeoutOption.withTimeoutOption(peers) : notEnabled\n };\n async function subscribe(topic, handler, options = {}) {\n const {libp2p} = await network.use(options);\n return libp2p.pubsub.subscribe(topic, handler, options);\n }\n async function unsubscribe(topic, handler, options = {}) {\n const {libp2p} = await network.use(options);\n libp2p.pubsub.unsubscribe(topic, handler, options);\n }\n async function publish(topic, data, options = {}) {\n const {libp2p} = await network.use(options);\n if (!data) {\n throw errCode__default['default'](new Error('argument \"data\" is required'), 'ERR_ARG_REQUIRED');\n }\n await libp2p.pubsub.publish(topic, data);\n }\n async function ls(options = {}) {\n const {libp2p} = await network.use(options);\n return libp2p.pubsub.getTopics();\n }\n async function peers(topic, options = {}) {\n const {libp2p} = await network.use(options);\n return libp2p.pubsub.getSubscribers(topic);\n }\n}\nconst notEnabled = async () => {\n throw new errors.NotEnabledError('pubsub not enabled');\n};\n\nexports.createPubsub = createPubsub;\n","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Hls\"] = factory();\n\telse\n\t\troot[\"Hls\"] = factory();\n})(this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/dist/\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/hls.ts\");\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","// see https://tools.ietf.org/html/rfc1808\n\n(function (root) {\n var URL_REGEX = /^((?:[a-zA-Z0-9+\\-.]+:)?)(\\/\\/[^\\/?#]*)?((?:[^\\/?#]*\\/)*[^;?#]*)?(;[^?#]*)?(\\?[^#]*)?(#.*)?$/;\n var FIRST_SEGMENT_REGEX = /^([^\\/?#]*)(.*)$/;\n var SLASH_DOT_REGEX = /(?:\\/|^)\\.(?=\\/)/g;\n var SLASH_DOT_DOT_REGEX = /(?:\\/|^)\\.\\.\\/(?!\\.\\.\\/)[^\\/]*(?=\\/)/g;\n\n var URLToolkit = {\n // If opts.alwaysNormalize is true then the path will always be normalized even when it starts with / or //\n // E.g\n // With opts.alwaysNormalize = false (default, spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/f/../g\n // With opts.alwaysNormalize = true (not spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/g\n buildAbsoluteURL: function (baseURL, relativeURL, opts) {\n opts = opts || {};\n // remove any remaining space and CRLF\n baseURL = baseURL.trim();\n relativeURL = relativeURL.trim();\n if (!relativeURL) {\n // 2a) If the embedded URL is entirely empty, it inherits the\n // entire base URL (i.e., is set equal to the base URL)\n // and we are done.\n if (!opts.alwaysNormalize) {\n return baseURL;\n }\n var basePartsForNormalise = URLToolkit.parseURL(baseURL);\n if (!basePartsForNormalise) {\n throw new Error('Error trying to parse base URL.');\n }\n basePartsForNormalise.path = URLToolkit.normalizePath(\n basePartsForNormalise.path\n );\n return URLToolkit.buildURLFromParts(basePartsForNormalise);\n }\n var relativeParts = URLToolkit.parseURL(relativeURL);\n if (!relativeParts) {\n throw new Error('Error trying to parse relative URL.');\n }\n if (relativeParts.scheme) {\n // 2b) If the embedded URL starts with a scheme name, it is\n // interpreted as an absolute URL and we are done.\n if (!opts.alwaysNormalize) {\n return relativeURL;\n }\n relativeParts.path = URLToolkit.normalizePath(relativeParts.path);\n return URLToolkit.buildURLFromParts(relativeParts);\n }\n var baseParts = URLToolkit.parseURL(baseURL);\n if (!baseParts) {\n throw new Error('Error trying to parse base URL.');\n }\n if (!baseParts.netLoc && baseParts.path && baseParts.path[0] !== '/') {\n // If netLoc missing and path doesn't start with '/', assume everthing before the first '/' is the netLoc\n // This causes 'example.com/a' to be handled as '//example.com/a' instead of '/example.com/a'\n var pathParts = FIRST_SEGMENT_REGEX.exec(baseParts.path);\n baseParts.netLoc = pathParts[1];\n baseParts.path = pathParts[2];\n }\n if (baseParts.netLoc && !baseParts.path) {\n baseParts.path = '/';\n }\n var builtParts = {\n // 2c) Otherwise, the embedded URL inherits the scheme of\n // the base URL.\n scheme: baseParts.scheme,\n netLoc: relativeParts.netLoc,\n path: null,\n params: relativeParts.params,\n query: relativeParts.query,\n fragment: relativeParts.fragment,\n };\n if (!relativeParts.netLoc) {\n // 3) If the embedded URL's is non-empty, we skip to\n // Step 7. Otherwise, the embedded URL inherits the \n // (if any) of the base URL.\n builtParts.netLoc = baseParts.netLoc;\n // 4) If the embedded URL path is preceded by a slash \"/\", the\n // path is not relative and we skip to Step 7.\n if (relativeParts.path[0] !== '/') {\n if (!relativeParts.path) {\n // 5) If the embedded URL path is empty (and not preceded by a\n // slash), then the embedded URL inherits the base URL path\n builtParts.path = baseParts.path;\n // 5a) if the embedded URL's is non-empty, we skip to\n // step 7; otherwise, it inherits the of the base\n // URL (if any) and\n if (!relativeParts.params) {\n builtParts.params = baseParts.params;\n // 5b) if the embedded URL's is non-empty, we skip to\n // step 7; otherwise, it inherits the of the base\n // URL (if any) and we skip to step 7.\n if (!relativeParts.query) {\n builtParts.query = baseParts.query;\n }\n }\n } else {\n // 6) The last segment of the base URL's path (anything\n // following the rightmost slash \"/\", or the entire path if no\n // slash is present) is removed and the embedded URL's path is\n // appended in its place.\n var baseURLPath = baseParts.path;\n var newPath =\n baseURLPath.substring(0, baseURLPath.lastIndexOf('/') + 1) +\n relativeParts.path;\n builtParts.path = URLToolkit.normalizePath(newPath);\n }\n }\n }\n if (builtParts.path === null) {\n builtParts.path = opts.alwaysNormalize\n ? URLToolkit.normalizePath(relativeParts.path)\n : relativeParts.path;\n }\n return URLToolkit.buildURLFromParts(builtParts);\n },\n parseURL: function (url) {\n var parts = URL_REGEX.exec(url);\n if (!parts) {\n return null;\n }\n return {\n scheme: parts[1] || '',\n netLoc: parts[2] || '',\n path: parts[3] || '',\n params: parts[4] || '',\n query: parts[5] || '',\n fragment: parts[6] || '',\n };\n },\n normalizePath: function (path) {\n // The following operations are\n // then applied, in order, to the new path:\n // 6a) All occurrences of \"./\", where \".\" is a complete path\n // segment, are removed.\n // 6b) If the path ends with \".\" as a complete path segment,\n // that \".\" is removed.\n path = path.split('').reverse().join('').replace(SLASH_DOT_REGEX, '');\n // 6c) All occurrences of \"/../\", where is a\n // complete path segment not equal to \"..\", are removed.\n // Removal of these path segments is performed iteratively,\n // removing the leftmost matching pattern on each iteration,\n // until no matching pattern remains.\n // 6d) If the path ends with \"/..\", where is a\n // complete path segment not equal to \"..\", that\n // \"/..\" is removed.\n while (\n path.length !== (path = path.replace(SLASH_DOT_DOT_REGEX, '')).length\n ) {}\n return path.split('').reverse().join('');\n },\n buildURLFromParts: function (parts) {\n return (\n parts.scheme +\n parts.netLoc +\n parts.path +\n parts.params +\n parts.query +\n parts.fragment\n );\n },\n };\n\n if (typeof exports === 'object' && typeof module === 'object')\n module.exports = URLToolkit;\n else if (typeof define === 'function' && define.amd)\n define([], function () {\n return URLToolkit;\n });\n else if (typeof exports === 'object') exports['URLToolkit'] = URLToolkit;\n else root['URLToolkit'] = URLToolkit;\n})(this);\n","function webpackBootstrapFunc (modules) {\n/******/ // The module cache\n/******/ var installedModules = {};\n\n/******/ // The require function\n/******/ function __webpack_require__(moduleId) {\n\n/******/ // Check if module is in cache\n/******/ if(installedModules[moduleId])\n/******/ return installedModules[moduleId].exports;\n\n/******/ // Create a new module (and put it into the cache)\n/******/ var module = installedModules[moduleId] = {\n/******/ i: moduleId,\n/******/ l: false,\n/******/ exports: {}\n/******/ };\n\n/******/ // Execute the module function\n/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n/******/ // Flag the module as loaded\n/******/ module.l = true;\n\n/******/ // Return the exports of the module\n/******/ return module.exports;\n/******/ }\n\n/******/ // expose the modules object (__webpack_modules__)\n/******/ __webpack_require__.m = modules;\n\n/******/ // expose the module cache\n/******/ __webpack_require__.c = installedModules;\n\n/******/ // identity function for calling harmony imports with the correct context\n/******/ __webpack_require__.i = function(value) { return value; };\n\n/******/ // define getter function for harmony exports\n/******/ __webpack_require__.d = function(exports, name, getter) {\n/******/ if(!__webpack_require__.o(exports, name)) {\n/******/ Object.defineProperty(exports, name, {\n/******/ configurable: false,\n/******/ enumerable: true,\n/******/ get: getter\n/******/ });\n/******/ }\n/******/ };\n\n/******/ // define __esModule on exports\n/******/ __webpack_require__.r = function(exports) {\n/******/ Object.defineProperty(exports, '__esModule', { value: true });\n/******/ };\n\n/******/ // getDefaultExport function for compatibility with non-harmony modules\n/******/ __webpack_require__.n = function(module) {\n/******/ var getter = module && module.__esModule ?\n/******/ function getDefault() { return module['default']; } :\n/******/ function getModuleExports() { return module; };\n/******/ __webpack_require__.d(getter, 'a', getter);\n/******/ return getter;\n/******/ };\n\n/******/ // Object.prototype.hasOwnProperty.call\n/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n/******/ // __webpack_public_path__\n/******/ __webpack_require__.p = \"/\";\n\n/******/ // on error function for async loading\n/******/ __webpack_require__.oe = function(err) { console.error(err); throw err; };\n\n var f = __webpack_require__(__webpack_require__.s = ENTRY_MODULE)\n return f.default || f // try to call default if defined to also support babel esmodule exports\n}\n\nvar moduleNameReqExp = '[\\\\.|\\\\-|\\\\+|\\\\w|\\/|@]+'\nvar dependencyRegExp = '\\\\(\\\\s*(\\/\\\\*.*?\\\\*\\/)?\\\\s*.*?(' + moduleNameReqExp + ').*?\\\\)' // additional chars when output.pathinfo is true\n\n// http://stackoverflow.com/a/2593661/130442\nfunction quoteRegExp (str) {\n return (str + '').replace(/[.?*+^$[\\]\\\\(){}|-]/g, '\\\\$&')\n}\n\nfunction isNumeric(n) {\n return !isNaN(1 * n); // 1 * n converts integers, integers as string (\"123\"), 1e3 and \"1e3\" to integers and strings to NaN\n}\n\nfunction getModuleDependencies (sources, module, queueName) {\n var retval = {}\n retval[queueName] = []\n\n var fnString = module.toString()\n var wrapperSignature = fnString.match(/^function\\s?\\w*\\(\\w+,\\s*\\w+,\\s*(\\w+)\\)/)\n if (!wrapperSignature) return retval\n var webpackRequireName = wrapperSignature[1]\n\n // main bundle deps\n var re = new RegExp('(\\\\\\\\n|\\\\W)' + quoteRegExp(webpackRequireName) + dependencyRegExp, 'g')\n var match\n while ((match = re.exec(fnString))) {\n if (match[3] === 'dll-reference') continue\n retval[queueName].push(match[3])\n }\n\n // dll deps\n re = new RegExp('\\\\(' + quoteRegExp(webpackRequireName) + '\\\\(\"(dll-reference\\\\s(' + moduleNameReqExp + '))\"\\\\)\\\\)' + dependencyRegExp, 'g')\n while ((match = re.exec(fnString))) {\n if (!sources[match[2]]) {\n retval[queueName].push(match[1])\n sources[match[2]] = __webpack_require__(match[1]).m\n }\n retval[match[2]] = retval[match[2]] || []\n retval[match[2]].push(match[4])\n }\n\n // convert 1e3 back to 1000 - this can be important after uglify-js converted 1000 to 1e3\n var keys = Object.keys(retval);\n for (var i = 0; i < keys.length; i++) {\n for (var j = 0; j < retval[keys[i]].length; j++) {\n if (isNumeric(retval[keys[i]][j])) {\n retval[keys[i]][j] = 1 * retval[keys[i]][j];\n }\n }\n }\n\n return retval\n}\n\nfunction hasValuesInQueues (queues) {\n var keys = Object.keys(queues)\n return keys.reduce(function (hasValues, key) {\n return hasValues || queues[key].length > 0\n }, false)\n}\n\nfunction getRequiredModules (sources, moduleId) {\n var modulesQueue = {\n main: [moduleId]\n }\n var requiredModules = {\n main: []\n }\n var seenModules = {\n main: {}\n }\n\n while (hasValuesInQueues(modulesQueue)) {\n var queues = Object.keys(modulesQueue)\n for (var i = 0; i < queues.length; i++) {\n var queueName = queues[i]\n var queue = modulesQueue[queueName]\n var moduleToCheck = queue.pop()\n seenModules[queueName] = seenModules[queueName] || {}\n if (seenModules[queueName][moduleToCheck] || !sources[queueName][moduleToCheck]) continue\n seenModules[queueName][moduleToCheck] = true\n requiredModules[queueName] = requiredModules[queueName] || []\n requiredModules[queueName].push(moduleToCheck)\n var newModules = getModuleDependencies(sources, sources[queueName][moduleToCheck], queueName)\n var newModulesKeys = Object.keys(newModules)\n for (var j = 0; j < newModulesKeys.length; j++) {\n modulesQueue[newModulesKeys[j]] = modulesQueue[newModulesKeys[j]] || []\n modulesQueue[newModulesKeys[j]] = modulesQueue[newModulesKeys[j]].concat(newModules[newModulesKeys[j]])\n }\n }\n }\n\n return requiredModules\n}\n\nmodule.exports = function (moduleId, options) {\n options = options || {}\n var sources = {\n main: __webpack_modules__\n }\n\n var requiredModules = options.all ? { main: Object.keys(sources.main) } : getRequiredModules(sources, moduleId)\n\n var src = ''\n\n Object.keys(requiredModules).filter(function (m) { return m !== 'main' }).forEach(function (module) {\n var entryModule = 0\n while (requiredModules[module][entryModule]) {\n entryModule++\n }\n requiredModules[module].push(entryModule)\n sources[module][entryModule] = '(function(module, exports, __webpack_require__) { module.exports = __webpack_require__; })'\n src = src + 'var ' + module + ' = (' + webpackBootstrapFunc.toString().replace('ENTRY_MODULE', JSON.stringify(entryModule)) + ')({' + requiredModules[module].map(function (id) { return '' + JSON.stringify(id) + ': ' + sources[module][id].toString() }).join(',') + '});\\n'\n })\n\n src = src + 'new ((' + webpackBootstrapFunc.toString().replace('ENTRY_MODULE', JSON.stringify(moduleId)) + ')({' + requiredModules.main.map(function (id) { return '' + JSON.stringify(id) + ': ' + sources.main[id].toString() }).join(',') + '}))(self);'\n\n var blob = new window.Blob([src], { type: 'text/javascript' })\n if (options.bare) { return blob }\n\n var URL = window.URL || window.webkitURL || window.mozURL || window.msURL\n\n var workerUrl = URL.createObjectURL(blob)\n var worker = new window.Worker(workerUrl)\n worker.objectURL = workerUrl\n\n return worker\n}\n","export default class AESCrypto {\n constructor (subtle, iv) {\n this.subtle = subtle;\n this.aesIV = iv;\n }\n\n decrypt (data, key) {\n return this.subtle.decrypt({ name: 'AES-CBC', iv: this.aesIV }, key, data);\n }\n}\n","class FastAESKey {\n constructor (subtle, key) {\n this.subtle = subtle;\n this.key = key;\n }\n\n expandKey () {\n return this.subtle.importKey('raw', this.key, { name: 'AES-CBC' }, false, ['encrypt', 'decrypt']);\n }\n}\n\nexport default FastAESKey;\n","// PKCS7\nexport function removePadding (buffer) {\n const outputBytes = buffer.byteLength;\n const paddingBytes = outputBytes && (new DataView(buffer)).getUint8(outputBytes - 1);\n if (paddingBytes) {\n return buffer.slice(0, outputBytes - paddingBytes);\n } else {\n return buffer;\n }\n}\n\nclass AESDecryptor {\n constructor () {\n // Static after running initTable\n this.rcon = [0x0, 0x1, 0x2, 0x4, 0x8, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36];\n this.subMix = [new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256)];\n this.invSubMix = [new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256)];\n this.sBox = new Uint32Array(256);\n this.invSBox = new Uint32Array(256);\n\n // Changes during runtime\n this.key = new Uint32Array(0);\n\n this.initTable();\n }\n\n // Using view.getUint32() also swaps the byte order.\n uint8ArrayToUint32Array_ (arrayBuffer) {\n let view = new DataView(arrayBuffer);\n let newArray = new Uint32Array(4);\n for (let i = 0; i < 4; i++) {\n newArray[i] = view.getUint32(i * 4);\n }\n\n return newArray;\n }\n\n initTable () {\n let sBox = this.sBox;\n let invSBox = this.invSBox;\n let subMix = this.subMix;\n let subMix0 = subMix[0];\n let subMix1 = subMix[1];\n let subMix2 = subMix[2];\n let subMix3 = subMix[3];\n let invSubMix = this.invSubMix;\n let invSubMix0 = invSubMix[0];\n let invSubMix1 = invSubMix[1];\n let invSubMix2 = invSubMix[2];\n let invSubMix3 = invSubMix[3];\n\n let d = new Uint32Array(256);\n let x = 0;\n let xi = 0;\n let i = 0;\n for (i = 0; i < 256; i++) {\n if (i < 128) {\n d[i] = i << 1;\n } else {\n d[i] = (i << 1) ^ 0x11b;\n }\n }\n\n for (i = 0; i < 256; i++) {\n let sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4);\n sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63;\n sBox[x] = sx;\n invSBox[sx] = x;\n\n // Compute multiplication\n let x2 = d[x];\n let x4 = d[x2];\n let x8 = d[x4];\n\n // Compute sub/invSub bytes, mix columns tables\n let t = (d[sx] * 0x101) ^ (sx * 0x1010100);\n subMix0[x] = (t << 24) | (t >>> 8);\n subMix1[x] = (t << 16) | (t >>> 16);\n subMix2[x] = (t << 8) | (t >>> 24);\n subMix3[x] = t;\n\n // Compute inv sub bytes, inv mix columns tables\n t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100);\n invSubMix0[sx] = (t << 24) | (t >>> 8);\n invSubMix1[sx] = (t << 16) | (t >>> 16);\n invSubMix2[sx] = (t << 8) | (t >>> 24);\n invSubMix3[sx] = t;\n\n // Compute next counter\n if (!x) {\n x = xi = 1;\n } else {\n x = x2 ^ d[d[d[x8 ^ x2]]];\n xi ^= d[d[xi]];\n }\n }\n }\n\n expandKey (keyBuffer) {\n // convert keyBuffer to Uint32Array\n let key = this.uint8ArrayToUint32Array_(keyBuffer);\n let sameKey = true;\n let offset = 0;\n\n while (offset < key.length && sameKey) {\n sameKey = (key[offset] === this.key[offset]);\n offset++;\n }\n\n if (sameKey) {\n return;\n }\n\n this.key = key;\n let keySize = this.keySize = key.length;\n\n if (keySize !== 4 && keySize !== 6 && keySize !== 8) {\n throw new Error('Invalid aes key size=' + keySize);\n }\n\n let ksRows = this.ksRows = (keySize + 6 + 1) * 4;\n let ksRow;\n let invKsRow;\n\n let keySchedule = this.keySchedule = new Uint32Array(ksRows);\n let invKeySchedule = this.invKeySchedule = new Uint32Array(ksRows);\n let sbox = this.sBox;\n let rcon = this.rcon;\n\n let invSubMix = this.invSubMix;\n let invSubMix0 = invSubMix[0];\n let invSubMix1 = invSubMix[1];\n let invSubMix2 = invSubMix[2];\n let invSubMix3 = invSubMix[3];\n\n let prev;\n let t;\n\n for (ksRow = 0; ksRow < ksRows; ksRow++) {\n if (ksRow < keySize) {\n prev = keySchedule[ksRow] = key[ksRow];\n continue;\n }\n t = prev;\n\n if (ksRow % keySize === 0) {\n // Rot word\n t = (t << 8) | (t >>> 24);\n\n // Sub word\n t = (sbox[t >>> 24] << 24) | (sbox[(t >>> 16) & 0xff] << 16) | (sbox[(t >>> 8) & 0xff] << 8) | sbox[t & 0xff];\n\n // Mix Rcon\n t ^= rcon[(ksRow / keySize) | 0] << 24;\n } else if (keySize > 6 && ksRow % keySize === 4) {\n // Sub word\n t = (sbox[t >>> 24] << 24) | (sbox[(t >>> 16) & 0xff] << 16) | (sbox[(t >>> 8) & 0xff] << 8) | sbox[t & 0xff];\n }\n\n keySchedule[ksRow] = prev = (keySchedule[ksRow - keySize] ^ t) >>> 0;\n }\n\n for (invKsRow = 0; invKsRow < ksRows; invKsRow++) {\n ksRow = ksRows - invKsRow;\n if (invKsRow & 3) {\n t = keySchedule[ksRow];\n } else {\n t = keySchedule[ksRow - 4];\n }\n\n if (invKsRow < 4 || ksRow <= 4) {\n invKeySchedule[invKsRow] = t;\n } else {\n invKeySchedule[invKsRow] = invSubMix0[sbox[t >>> 24]] ^ invSubMix1[sbox[(t >>> 16) & 0xff]] ^ invSubMix2[sbox[(t >>> 8) & 0xff]] ^ invSubMix3[sbox[t & 0xff]];\n }\n\n invKeySchedule[invKsRow] = invKeySchedule[invKsRow] >>> 0;\n }\n }\n\n // Adding this as a method greatly improves performance.\n networkToHostOrderSwap (word) {\n return (word << 24) | ((word & 0xff00) << 8) | ((word & 0xff0000) >> 8) | (word >>> 24);\n }\n\n decrypt (inputArrayBuffer, offset, aesIV, removePKCS7Padding) {\n let nRounds = this.keySize + 6;\n let invKeySchedule = this.invKeySchedule;\n let invSBOX = this.invSBox;\n\n let invSubMix = this.invSubMix;\n let invSubMix0 = invSubMix[0];\n let invSubMix1 = invSubMix[1];\n let invSubMix2 = invSubMix[2];\n let invSubMix3 = invSubMix[3];\n\n let initVector = this.uint8ArrayToUint32Array_(aesIV);\n let initVector0 = initVector[0];\n let initVector1 = initVector[1];\n let initVector2 = initVector[2];\n let initVector3 = initVector[3];\n\n let inputInt32 = new Int32Array(inputArrayBuffer);\n let outputInt32 = new Int32Array(inputInt32.length);\n\n let t0, t1, t2, t3;\n let s0, s1, s2, s3;\n let inputWords0, inputWords1, inputWords2, inputWords3;\n\n let ksRow, i;\n let swapWord = this.networkToHostOrderSwap;\n\n while (offset < inputInt32.length) {\n inputWords0 = swapWord(inputInt32[offset]);\n inputWords1 = swapWord(inputInt32[offset + 1]);\n inputWords2 = swapWord(inputInt32[offset + 2]);\n inputWords3 = swapWord(inputInt32[offset + 3]);\n\n s0 = inputWords0 ^ invKeySchedule[0];\n s1 = inputWords3 ^ invKeySchedule[1];\n s2 = inputWords2 ^ invKeySchedule[2];\n s3 = inputWords1 ^ invKeySchedule[3];\n\n ksRow = 4;\n\n // Iterate through the rounds of decryption\n for (i = 1; i < nRounds; i++) {\n t0 = invSubMix0[s0 >>> 24] ^ invSubMix1[(s1 >> 16) & 0xff] ^ invSubMix2[(s2 >> 8) & 0xff] ^ invSubMix3[s3 & 0xff] ^ invKeySchedule[ksRow];\n t1 = invSubMix0[s1 >>> 24] ^ invSubMix1[(s2 >> 16) & 0xff] ^ invSubMix2[(s3 >> 8) & 0xff] ^ invSubMix3[s0 & 0xff] ^ invKeySchedule[ksRow + 1];\n t2 = invSubMix0[s2 >>> 24] ^ invSubMix1[(s3 >> 16) & 0xff] ^ invSubMix2[(s0 >> 8) & 0xff] ^ invSubMix3[s1 & 0xff] ^ invKeySchedule[ksRow + 2];\n t3 = invSubMix0[s3 >>> 24] ^ invSubMix1[(s0 >> 16) & 0xff] ^ invSubMix2[(s1 >> 8) & 0xff] ^ invSubMix3[s2 & 0xff] ^ invKeySchedule[ksRow + 3];\n // Update state\n s0 = t0;\n s1 = t1;\n s2 = t2;\n s3 = t3;\n\n ksRow = ksRow + 4;\n }\n\n // Shift rows, sub bytes, add round key\n t0 = ((invSBOX[s0 >>> 24] << 24) ^ (invSBOX[(s1 >> 16) & 0xff] << 16) ^ (invSBOX[(s2 >> 8) & 0xff] << 8) ^ invSBOX[s3 & 0xff]) ^ invKeySchedule[ksRow];\n t1 = ((invSBOX[s1 >>> 24] << 24) ^ (invSBOX[(s2 >> 16) & 0xff] << 16) ^ (invSBOX[(s3 >> 8) & 0xff] << 8) ^ invSBOX[s0 & 0xff]) ^ invKeySchedule[ksRow + 1];\n t2 = ((invSBOX[s2 >>> 24] << 24) ^ (invSBOX[(s3 >> 16) & 0xff] << 16) ^ (invSBOX[(s0 >> 8) & 0xff] << 8) ^ invSBOX[s1 & 0xff]) ^ invKeySchedule[ksRow + 2];\n t3 = ((invSBOX[s3 >>> 24] << 24) ^ (invSBOX[(s0 >> 16) & 0xff] << 16) ^ (invSBOX[(s1 >> 8) & 0xff] << 8) ^ invSBOX[s2 & 0xff]) ^ invKeySchedule[ksRow + 3];\n ksRow = ksRow + 3;\n\n // Write\n outputInt32[offset] = swapWord(t0 ^ initVector0);\n outputInt32[offset + 1] = swapWord(t3 ^ initVector1);\n outputInt32[offset + 2] = swapWord(t2 ^ initVector2);\n outputInt32[offset + 3] = swapWord(t1 ^ initVector3);\n\n // reset initVector to last 4 unsigned int\n initVector0 = inputWords0;\n initVector1 = inputWords1;\n initVector2 = inputWords2;\n initVector3 = inputWords3;\n\n offset = offset + 4;\n }\n\n return removePKCS7Padding ? removePadding(outputInt32.buffer) : outputInt32.buffer;\n }\n\n destroy () {\n this.key = undefined;\n this.keySize = undefined;\n this.ksRows = undefined;\n\n this.sBox = undefined;\n this.invSBox = undefined;\n this.subMix = undefined;\n this.invSubMix = undefined;\n this.keySchedule = undefined;\n this.invKeySchedule = undefined;\n\n this.rcon = undefined;\n }\n}\n\nexport default AESDecryptor;\n","import AESCrypto from './aes-crypto';\nimport FastAESKey from './fast-aes-key';\nimport AESDecryptor from './aes-decryptor';\n\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\n\nimport Event from '../events';\n\nimport { getSelfScope } from '../utils/get-self-scope';\n\n// see https://stackoverflow.com/a/11237259/589493\nconst global = getSelfScope(); // safeguard for code that might run both on worker and main thread\n\nclass Decrypter {\n constructor (observer, config, { removePKCS7Padding = true } = {}) {\n this.logEnabled = true;\n this.observer = observer;\n this.config = config;\n this.removePKCS7Padding = removePKCS7Padding;\n // built in decryptor expects PKCS7 padding\n if (removePKCS7Padding) {\n try {\n const browserCrypto = global.crypto;\n if (browserCrypto) {\n this.subtle = browserCrypto.subtle || browserCrypto.webkitSubtle;\n }\n } catch (e) {}\n }\n this.disableWebCrypto = !this.subtle;\n }\n\n isSync () {\n return (this.disableWebCrypto && this.config.enableSoftwareAES);\n }\n\n decrypt (data, key, iv, callback) {\n if (this.disableWebCrypto && this.config.enableSoftwareAES) {\n if (this.logEnabled) {\n logger.log('JS AES decrypt');\n this.logEnabled = false;\n }\n let decryptor = this.decryptor;\n if (!decryptor) {\n this.decryptor = decryptor = new AESDecryptor();\n }\n\n decryptor.expandKey(key);\n callback(decryptor.decrypt(data, 0, iv, this.removePKCS7Padding));\n } else {\n if (this.logEnabled) {\n logger.log('WebCrypto AES decrypt');\n this.logEnabled = false;\n }\n const subtle = this.subtle;\n if (this.key !== key) {\n this.key = key;\n this.fastAesKey = new FastAESKey(subtle, key);\n }\n\n this.fastAesKey.expandKey()\n .then((aesKey) => {\n // decrypt using web crypto\n let crypto = new AESCrypto(subtle, iv);\n crypto.decrypt(data, aesKey)\n .catch((err) => {\n this.onWebCryptoError(err, data, key, iv, callback);\n })\n .then((result) => {\n callback(result);\n });\n })\n .catch((err) => {\n this.onWebCryptoError(err, data, key, iv, callback);\n });\n }\n }\n\n onWebCryptoError (err, data, key, iv, callback) {\n if (this.config.enableSoftwareAES) {\n logger.log('WebCrypto Error, disable WebCrypto API');\n this.disableWebCrypto = true;\n this.logEnabled = true;\n this.decrypt(data, key, iv, callback);\n } else {\n logger.error(`decrypting error : ${err.message}`);\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_DECRYPT_ERROR, fatal: true, reason: err.message });\n }\n }\n\n destroy () {\n let decryptor = this.decryptor;\n if (decryptor) {\n decryptor.destroy();\n this.decryptor = undefined;\n }\n }\n}\n\nexport default Decrypter;\n","/**\n * ADTS parser helper\n * @link https://wiki.multimedia.cx/index.php?title=ADTS\n */\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\n\nimport Event from '../events';\n\nimport { getSelfScope } from '../utils/get-self-scope';\n\nexport function getAudioConfig (observer, data, offset, audioCodec) {\n let adtsObjectType, // :int\n adtsSampleingIndex, // :int\n adtsExtensionSampleingIndex, // :int\n adtsChanelConfig, // :int\n config,\n userAgent = navigator.userAgent.toLowerCase(),\n manifestCodec = audioCodec,\n adtsSampleingRates = [\n 96000, 88200,\n 64000, 48000,\n 44100, 32000,\n 24000, 22050,\n 16000, 12000,\n 11025, 8000,\n 7350];\n // byte 2\n adtsObjectType = ((data[offset + 2] & 0xC0) >>> 6) + 1;\n adtsSampleingIndex = ((data[offset + 2] & 0x3C) >>> 2);\n if (adtsSampleingIndex > adtsSampleingRates.length - 1) {\n observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: true, reason: `invalid ADTS sampling index:${adtsSampleingIndex}` });\n return;\n }\n adtsChanelConfig = ((data[offset + 2] & 0x01) << 2);\n // byte 3\n adtsChanelConfig |= ((data[offset + 3] & 0xC0) >>> 6);\n logger.log(`manifest codec:${audioCodec},ADTS data:type:${adtsObjectType},sampleingIndex:${adtsSampleingIndex}[${adtsSampleingRates[adtsSampleingIndex]}Hz],channelConfig:${adtsChanelConfig}`);\n // firefox: freq less than 24kHz = AAC SBR (HE-AAC)\n if (/firefox/i.test(userAgent)) {\n if (adtsSampleingIndex >= 6) {\n adtsObjectType = 5;\n config = new Array(4);\n // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n // there is a factor 2 between frame sample rate and output sample rate\n // multiply frequency by 2 (see table below, equivalent to substract 3)\n adtsExtensionSampleingIndex = adtsSampleingIndex - 3;\n } else {\n adtsObjectType = 2;\n config = new Array(2);\n adtsExtensionSampleingIndex = adtsSampleingIndex;\n }\n // Android : always use AAC\n } else if (userAgent.indexOf('android') !== -1) {\n adtsObjectType = 2;\n config = new Array(2);\n adtsExtensionSampleingIndex = adtsSampleingIndex;\n } else {\n /* for other browsers (Chrome/Vivaldi/Opera ...)\n always force audio type to be HE-AAC SBR, as some browsers do not support audio codec switch properly (like Chrome ...)\n */\n adtsObjectType = 5;\n config = new Array(4);\n // if (manifest codec is HE-AAC or HE-AACv2) OR (manifest codec not specified AND frequency less than 24kHz)\n if ((audioCodec && ((audioCodec.indexOf('mp4a.40.29') !== -1) ||\n (audioCodec.indexOf('mp4a.40.5') !== -1))) ||\n (!audioCodec && adtsSampleingIndex >= 6)) {\n // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n // there is a factor 2 between frame sample rate and output sample rate\n // multiply frequency by 2 (see table below, equivalent to substract 3)\n adtsExtensionSampleingIndex = adtsSampleingIndex - 3;\n } else {\n // if (manifest codec is AAC) AND (frequency less than 24kHz AND nb channel is 1) OR (manifest codec not specified and mono audio)\n // Chrome fails to play back with low frequency AAC LC mono when initialized with HE-AAC. This is not a problem with stereo.\n if (audioCodec && audioCodec.indexOf('mp4a.40.2') !== -1 && ((adtsSampleingIndex >= 6 && adtsChanelConfig === 1) ||\n /vivaldi/i.test(userAgent)) ||\n (!audioCodec && adtsChanelConfig === 1)) {\n adtsObjectType = 2;\n config = new Array(2);\n }\n adtsExtensionSampleingIndex = adtsSampleingIndex;\n }\n }\n /* refer to http://wiki.multimedia.cx/index.php?title=MPEG-4_Audio#Audio_Specific_Config\n ISO 14496-3 (AAC).pdf - Table 1.13 — Syntax of AudioSpecificConfig()\n Audio Profile / Audio Object Type\n 0: Null\n 1: AAC Main\n 2: AAC LC (Low Complexity)\n 3: AAC SSR (Scalable Sample Rate)\n 4: AAC LTP (Long Term Prediction)\n 5: SBR (Spectral Band Replication)\n 6: AAC Scalable\n sampling freq\n 0: 96000 Hz\n 1: 88200 Hz\n 2: 64000 Hz\n 3: 48000 Hz\n 4: 44100 Hz\n 5: 32000 Hz\n 6: 24000 Hz\n 7: 22050 Hz\n 8: 16000 Hz\n 9: 12000 Hz\n 10: 11025 Hz\n 11: 8000 Hz\n 12: 7350 Hz\n 13: Reserved\n 14: Reserved\n 15: frequency is written explictly\n Channel Configurations\n These are the channel configurations:\n 0: Defined in AOT Specifc Config\n 1: 1 channel: front-center\n 2: 2 channels: front-left, front-right\n */\n // audioObjectType = profile => profile, the MPEG-4 Audio Object Type minus 1\n config[0] = adtsObjectType << 3;\n // samplingFrequencyIndex\n config[0] |= (adtsSampleingIndex & 0x0E) >> 1;\n config[1] |= (adtsSampleingIndex & 0x01) << 7;\n // channelConfiguration\n config[1] |= adtsChanelConfig << 3;\n if (adtsObjectType === 5) {\n // adtsExtensionSampleingIndex\n config[1] |= (adtsExtensionSampleingIndex & 0x0E) >> 1;\n config[2] = (adtsExtensionSampleingIndex & 0x01) << 7;\n // adtsObjectType (force to 2, chrome is checking that object type is less than 5 ???\n // https://chromium.googlesource.com/chromium/src.git/+/master/media/formats/mp4/aac.cc\n config[2] |= 2 << 2;\n config[3] = 0;\n }\n return { config: config, samplerate: adtsSampleingRates[adtsSampleingIndex], channelCount: adtsChanelConfig, codec: ('mp4a.40.' + adtsObjectType), manifestCodec: manifestCodec };\n}\n\nexport function isHeaderPattern (data, offset) {\n return data[offset] === 0xff && (data[offset + 1] & 0xf6) === 0xf0;\n}\n\nexport function getHeaderLength (data, offset) {\n return (data[offset + 1] & 0x01 ? 7 : 9);\n}\n\nexport function getFullFrameLength (data, offset) {\n return ((data[offset + 3] & 0x03) << 11) |\n (data[offset + 4] << 3) |\n ((data[offset + 5] & 0xE0) >>> 5);\n}\n\nexport function isHeader (data, offset) {\n // Look for ADTS header | 1111 1111 | 1111 X00X | where X can be either 0 or 1\n // Layer bits (position 14 and 15) in header should be always 0 for ADTS\n // More info https://wiki.multimedia.cx/index.php?title=ADTS\n if (offset + 1 < data.length && isHeaderPattern(data, offset)) {\n return true;\n }\n\n return false;\n}\n\nexport function probe (data, offset) {\n // same as isHeader but we also check that ADTS frame follows last ADTS frame\n // or end of data is reached\n if (isHeader(data, offset)) {\n // ADTS header Length\n let headerLength = getHeaderLength(data, offset);\n if (offset + headerLength >= data.length) {\n return false;\n }\n // ADTS frame Length\n let frameLength = getFullFrameLength(data, offset);\n if (frameLength <= headerLength) {\n return false;\n }\n\n let newOffset = offset + frameLength;\n if (newOffset === data.length || (newOffset + 1 < data.length && isHeaderPattern(data, newOffset))) {\n return true;\n }\n }\n return false;\n}\n\nexport function initTrackConfig (track, observer, data, offset, audioCodec) {\n if (!track.samplerate) {\n let config = getAudioConfig(observer, data, offset, audioCodec);\n track.config = config.config;\n track.samplerate = config.samplerate;\n track.channelCount = config.channelCount;\n track.codec = config.codec;\n track.manifestCodec = config.manifestCodec;\n logger.log(`parsed codec:${track.codec},rate:${config.samplerate},nb channel:${config.channelCount}`);\n }\n}\n\nexport function getFrameDuration (samplerate) {\n return 1024 * 90000 / samplerate;\n}\n\nexport function parseFrameHeader (data, offset, pts, frameIndex, frameDuration) {\n let headerLength, frameLength, stamp;\n let length = data.length;\n\n // The protection skip bit tells us if we have 2 bytes of CRC data at the end of the ADTS header\n headerLength = getHeaderLength(data, offset);\n // retrieve frame size\n frameLength = getFullFrameLength(data, offset);\n frameLength -= headerLength;\n\n if ((frameLength > 0) && ((offset + headerLength + frameLength) <= length)) {\n stamp = pts + frameIndex * frameDuration;\n // logger.log(`AAC frame, offset/length/total/pts:${offset+headerLength}/${frameLength}/${data.byteLength}/${(stamp/90).toFixed(0)}`);\n return { headerLength, frameLength, stamp };\n }\n\n return undefined;\n}\n\nexport function appendFrame (track, data, offset, pts, frameIndex) {\n let frameDuration = getFrameDuration(track.samplerate);\n let header = parseFrameHeader(data, offset, pts, frameIndex, frameDuration);\n if (header) {\n let stamp = header.stamp;\n let headerLength = header.headerLength;\n let frameLength = header.frameLength;\n\n // logger.log(`AAC frame, offset/length/total/pts:${offset+headerLength}/${frameLength}/${data.byteLength}/${(stamp/90).toFixed(0)}`);\n let aacSample = {\n unit: data.subarray(offset + headerLength, offset + headerLength + frameLength),\n pts: stamp,\n dts: stamp\n };\n\n track.samples.push(aacSample);\n return { sample: aacSample, length: frameLength + headerLength };\n }\n\n return undefined;\n}\n","/**\n * AAC demuxer\n */\nimport * as ADTS from './adts';\nimport { logger } from '../utils/logger';\nimport ID3 from '../demux/id3';\n\nclass AACDemuxer {\n constructor (observer, remuxer, config) {\n this.observer = observer;\n this.config = config;\n this.remuxer = remuxer;\n }\n\n resetInitSegment (initSegment, audioCodec, videoCodec, duration) {\n this._audioTrack = { container: 'audio/adts', type: 'audio', id: 0, sequenceNumber: 0, isAAC: true, samples: [], len: 0, manifestCodec: audioCodec, duration: duration, inputTimeScale: 90000 };\n }\n\n resetTimeStamp () {\n }\n\n static probe (data) {\n if (!data) {\n return false;\n }\n\n // Check for the ADTS sync word\n // Look for ADTS header | 1111 1111 | 1111 X00X | where X can be either 0 or 1\n // Layer bits (position 14 and 15) in header should be always 0 for ADTS\n // More info https://wiki.multimedia.cx/index.php?title=ADTS\n const id3Data = ID3.getID3Data(data, 0) || [];\n let offset = id3Data.length;\n\n for (let length = data.length; offset < length; offset++) {\n if (ADTS.probe(data, offset)) {\n logger.log('ADTS sync word found !');\n return true;\n }\n }\n return false;\n }\n\n // feed incoming data to the front of the parsing pipeline\n append (data, timeOffset, contiguous, accurateTimeOffset) {\n let track = this._audioTrack;\n let id3Data = ID3.getID3Data(data, 0) || [];\n let timestamp = ID3.getTimeStamp(id3Data);\n let pts = Number.isFinite(timestamp) ? timestamp * 90 : timeOffset * 90000;\n let frameIndex = 0;\n let stamp = pts;\n let length = data.length;\n let offset = id3Data.length;\n\n let id3Samples = [{ pts: stamp, dts: stamp, data: id3Data }];\n\n while (offset < length - 1) {\n if (ADTS.isHeader(data, offset) && (offset + 5) < length) {\n ADTS.initTrackConfig(track, this.observer, data, offset, track.manifestCodec);\n let frame = ADTS.appendFrame(track, data, offset, pts, frameIndex);\n if (frame) {\n offset += frame.length;\n stamp = frame.sample.pts;\n frameIndex++;\n } else {\n logger.log('Unable to parse AAC frame');\n break;\n }\n } else if (ID3.isHeader(data, offset)) {\n id3Data = ID3.getID3Data(data, offset);\n id3Samples.push({ pts: stamp, dts: stamp, data: id3Data });\n offset += id3Data.length;\n } else {\n // nothing found, keep looking\n offset++;\n }\n }\n\n this.remuxer.remux(track,\n { samples: [] },\n { samples: id3Samples, inputTimeScale: 90000 },\n { samples: [] },\n timeOffset,\n contiguous,\n accurateTimeOffset);\n }\n\n destroy () {\n }\n}\n\nexport default AACDemuxer;\n","/**\n * MPEG parser helper\n */\n\nconst MpegAudio = {\n\n BitratesMap: [\n 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448,\n 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384,\n 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320,\n 32, 48, 56, 64, 80, 96, 112, 128, 144, 160, 176, 192, 224, 256,\n 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160],\n\n SamplingRateMap: [44100, 48000, 32000, 22050, 24000, 16000, 11025, 12000, 8000],\n\n SamplesCoefficients: [\n // MPEG 2.5\n [\n 0, // Reserved\n 72, // Layer3\n 144, // Layer2\n 12 // Layer1\n ],\n // Reserved\n [\n 0, // Reserved\n 0, // Layer3\n 0, // Layer2\n 0 // Layer1\n ],\n // MPEG 2\n [\n 0, // Reserved\n 72, // Layer3\n 144, // Layer2\n 12 // Layer1\n ],\n // MPEG 1\n [\n 0, // Reserved\n 144, // Layer3\n 144, // Layer2\n 12 // Layer1\n ]\n ],\n\n BytesInSlot: [\n 0, // Reserved\n 1, // Layer3\n 1, // Layer2\n 4 // Layer1\n ],\n\n appendFrame: function (track, data, offset, pts, frameIndex) {\n // Using http://www.datavoyage.com/mpgscript/mpeghdr.htm as a reference\n if (offset + 24 > data.length) {\n return undefined;\n }\n\n let header = this.parseHeader(data, offset);\n if (header && offset + header.frameLength <= data.length) {\n let frameDuration = header.samplesPerFrame * 90000 / header.sampleRate;\n let stamp = pts + frameIndex * frameDuration;\n let sample = { unit: data.subarray(offset, offset + header.frameLength), pts: stamp, dts: stamp };\n\n track.config = [];\n track.channelCount = header.channelCount;\n track.samplerate = header.sampleRate;\n track.samples.push(sample);\n\n return { sample, length: header.frameLength };\n }\n\n return undefined;\n },\n\n parseHeader: function (data, offset) {\n let headerB = (data[offset + 1] >> 3) & 3;\n let headerC = (data[offset + 1] >> 1) & 3;\n let headerE = (data[offset + 2] >> 4) & 15;\n let headerF = (data[offset + 2] >> 2) & 3;\n let headerG = (data[offset + 2] >> 1) & 1;\n if (headerB !== 1 && headerE !== 0 && headerE !== 15 && headerF !== 3) {\n let columnInBitrates = headerB === 3 ? (3 - headerC) : (headerC === 3 ? 3 : 4);\n let bitRate = MpegAudio.BitratesMap[columnInBitrates * 14 + headerE - 1] * 1000;\n let columnInSampleRates = headerB === 3 ? 0 : headerB === 2 ? 1 : 2;\n let sampleRate = MpegAudio.SamplingRateMap[columnInSampleRates * 3 + headerF];\n let channelCount = data[offset + 3] >> 6 === 3 ? 1 : 2; // If bits of channel mode are `11` then it is a single channel (Mono)\n let sampleCoefficient = MpegAudio.SamplesCoefficients[headerB][headerC];\n let bytesInSlot = MpegAudio.BytesInSlot[headerC];\n let samplesPerFrame = sampleCoefficient * 8 * bytesInSlot;\n let frameLength = parseInt(sampleCoefficient * bitRate / sampleRate + headerG, 10) * bytesInSlot;\n\n return { sampleRate, channelCount, frameLength, samplesPerFrame };\n }\n\n return undefined;\n },\n\n isHeaderPattern: function (data, offset) {\n return data[offset] === 0xff && (data[offset + 1] & 0xe0) === 0xe0 && (data[offset + 1] & 0x06) !== 0x00;\n },\n\n isHeader: function (data, offset) {\n // Look for MPEG header | 1111 1111 | 111X XYZX | where X can be either 0 or 1 and Y or Z should be 1\n // Layer bits (position 14 and 15) in header should be always different from 0 (Layer I or Layer II or Layer III)\n // More info http://www.mp3-tech.org/programmer/frame_header.html\n if (offset + 1 < data.length && this.isHeaderPattern(data, offset)) {\n return true;\n }\n\n return false;\n },\n\n probe: function (data, offset) {\n // same as isHeader but we also check that MPEG frame follows last MPEG frame\n // or end of data is reached\n if (offset + 1 < data.length && this.isHeaderPattern(data, offset)) {\n // MPEG header Length\n let headerLength = 4;\n // MPEG frame Length\n let header = this.parseHeader(data, offset);\n let frameLength = headerLength;\n if (header && header.frameLength) {\n frameLength = header.frameLength;\n }\n\n let newOffset = offset + frameLength;\n if (newOffset === data.length || (newOffset + 1 < data.length && this.isHeaderPattern(data, newOffset))) {\n return true;\n }\n }\n return false;\n }\n};\n\nexport default MpegAudio;\n","/**\n * Parser for exponential Golomb codes, a variable-bitwidth number encoding scheme used by h264.\n*/\n\nimport { logger } from '../utils/logger';\n\nclass ExpGolomb {\n constructor (data) {\n this.data = data;\n // the number of bytes left to examine in this.data\n this.bytesAvailable = data.byteLength;\n // the current word being examined\n this.word = 0; // :uint\n // the number of bits left to examine in the current word\n this.bitsAvailable = 0; // :uint\n }\n\n // ():void\n loadWord () {\n let\n data = this.data,\n bytesAvailable = this.bytesAvailable,\n position = data.byteLength - bytesAvailable,\n workingBytes = new Uint8Array(4),\n availableBytes = Math.min(4, bytesAvailable);\n if (availableBytes === 0) {\n throw new Error('no bytes available');\n }\n\n workingBytes.set(data.subarray(position, position + availableBytes));\n this.word = new DataView(workingBytes.buffer).getUint32(0);\n // track the amount of this.data that has been processed\n this.bitsAvailable = availableBytes * 8;\n this.bytesAvailable -= availableBytes;\n }\n\n // (count:int):void\n skipBits (count) {\n let skipBytes; // :int\n if (this.bitsAvailable > count) {\n this.word <<= count;\n this.bitsAvailable -= count;\n } else {\n count -= this.bitsAvailable;\n skipBytes = count >> 3;\n count -= (skipBytes >> 3);\n this.bytesAvailable -= skipBytes;\n this.loadWord();\n this.word <<= count;\n this.bitsAvailable -= count;\n }\n }\n\n // (size:int):uint\n readBits (size) {\n let\n bits = Math.min(this.bitsAvailable, size), // :uint\n valu = this.word >>> (32 - bits); // :uint\n if (size > 32) {\n logger.error('Cannot read more than 32 bits at a time');\n }\n\n this.bitsAvailable -= bits;\n if (this.bitsAvailable > 0) {\n this.word <<= bits;\n } else if (this.bytesAvailable > 0) {\n this.loadWord();\n }\n\n bits = size - bits;\n if (bits > 0 && this.bitsAvailable) {\n return valu << bits | this.readBits(bits);\n } else {\n return valu;\n }\n }\n\n // ():uint\n skipLZ () {\n let leadingZeroCount; // :uint\n for (leadingZeroCount = 0; leadingZeroCount < this.bitsAvailable; ++leadingZeroCount) {\n if ((this.word & (0x80000000 >>> leadingZeroCount)) !== 0) {\n // the first bit of working word is 1\n this.word <<= leadingZeroCount;\n this.bitsAvailable -= leadingZeroCount;\n return leadingZeroCount;\n }\n }\n // we exhausted word and still have not found a 1\n this.loadWord();\n return leadingZeroCount + this.skipLZ();\n }\n\n // ():void\n skipUEG () {\n this.skipBits(1 + this.skipLZ());\n }\n\n // ():void\n skipEG () {\n this.skipBits(1 + this.skipLZ());\n }\n\n // ():uint\n readUEG () {\n let clz = this.skipLZ(); // :uint\n return this.readBits(clz + 1) - 1;\n }\n\n // ():int\n readEG () {\n let valu = this.readUEG(); // :int\n if (0x01 & valu) {\n // the number is odd if the low order bit is set\n return (1 + valu) >>> 1; // add 1 to make it even, and divide by 2\n } else {\n return -1 * (valu >>> 1); // divide by two then make it negative\n }\n }\n\n // Some convenience functions\n // :Boolean\n readBoolean () {\n return this.readBits(1) === 1;\n }\n\n // ():int\n readUByte () {\n return this.readBits(8);\n }\n\n // ():int\n readUShort () {\n return this.readBits(16);\n }\n // ():int\n readUInt () {\n return this.readBits(32);\n }\n\n /**\n * Advance the ExpGolomb decoder past a scaling list. The scaling\n * list is optionally transmitted as part of a sequence parameter\n * set and is not relevant to transmuxing.\n * @param count {number} the number of entries in this scaling list\n * @see Recommendation ITU-T H.264, Section 7.3.2.1.1.1\n */\n skipScalingList (count) {\n let\n lastScale = 8,\n nextScale = 8,\n j,\n deltaScale;\n for (j = 0; j < count; j++) {\n if (nextScale !== 0) {\n deltaScale = this.readEG();\n nextScale = (lastScale + deltaScale + 256) % 256;\n }\n lastScale = (nextScale === 0) ? lastScale : nextScale;\n }\n }\n\n /**\n * Read a sequence parameter set and return some interesting video\n * properties. A sequence parameter set is the H264 metadata that\n * describes the properties of upcoming video frames.\n * @param data {Uint8Array} the bytes of a sequence parameter set\n * @return {object} an object with configuration parsed from the\n * sequence parameter set, including the dimensions of the\n * associated video frames.\n */\n readSPS () {\n let\n frameCropLeftOffset = 0,\n frameCropRightOffset = 0,\n frameCropTopOffset = 0,\n frameCropBottomOffset = 0,\n profileIdc, profileCompat, levelIdc,\n numRefFramesInPicOrderCntCycle, picWidthInMbsMinus1,\n picHeightInMapUnitsMinus1,\n frameMbsOnlyFlag,\n scalingListCount,\n i,\n readUByte = this.readUByte.bind(this),\n readBits = this.readBits.bind(this),\n readUEG = this.readUEG.bind(this),\n readBoolean = this.readBoolean.bind(this),\n skipBits = this.skipBits.bind(this),\n skipEG = this.skipEG.bind(this),\n skipUEG = this.skipUEG.bind(this),\n skipScalingList = this.skipScalingList.bind(this);\n\n readUByte();\n profileIdc = readUByte(); // profile_idc\n profileCompat = readBits(5); // constraint_set[0-4]_flag, u(5)\n skipBits(3); // reserved_zero_3bits u(3),\n levelIdc = readUByte(); // level_idc u(8)\n skipUEG(); // seq_parameter_set_id\n // some profiles have more optional data we don't need\n if (profileIdc === 100 ||\n profileIdc === 110 ||\n profileIdc === 122 ||\n profileIdc === 244 ||\n profileIdc === 44 ||\n profileIdc === 83 ||\n profileIdc === 86 ||\n profileIdc === 118 ||\n profileIdc === 128) {\n let chromaFormatIdc = readUEG();\n if (chromaFormatIdc === 3) {\n skipBits(1);\n } // separate_colour_plane_flag\n\n skipUEG(); // bit_depth_luma_minus8\n skipUEG(); // bit_depth_chroma_minus8\n skipBits(1); // qpprime_y_zero_transform_bypass_flag\n if (readBoolean()) { // seq_scaling_matrix_present_flag\n scalingListCount = (chromaFormatIdc !== 3) ? 8 : 12;\n for (i = 0; i < scalingListCount; i++) {\n if (readBoolean()) { // seq_scaling_list_present_flag[ i ]\n if (i < 6) {\n skipScalingList(16);\n } else {\n skipScalingList(64);\n }\n }\n }\n }\n }\n skipUEG(); // log2_max_frame_num_minus4\n let picOrderCntType = readUEG();\n if (picOrderCntType === 0) {\n readUEG(); // log2_max_pic_order_cnt_lsb_minus4\n } else if (picOrderCntType === 1) {\n skipBits(1); // delta_pic_order_always_zero_flag\n skipEG(); // offset_for_non_ref_pic\n skipEG(); // offset_for_top_to_bottom_field\n numRefFramesInPicOrderCntCycle = readUEG();\n for (i = 0; i < numRefFramesInPicOrderCntCycle; i++) {\n skipEG();\n } // offset_for_ref_frame[ i ]\n }\n skipUEG(); // max_num_ref_frames\n skipBits(1); // gaps_in_frame_num_value_allowed_flag\n picWidthInMbsMinus1 = readUEG();\n picHeightInMapUnitsMinus1 = readUEG();\n frameMbsOnlyFlag = readBits(1);\n if (frameMbsOnlyFlag === 0) {\n skipBits(1);\n } // mb_adaptive_frame_field_flag\n\n skipBits(1); // direct_8x8_inference_flag\n if (readBoolean()) { // frame_cropping_flag\n frameCropLeftOffset = readUEG();\n frameCropRightOffset = readUEG();\n frameCropTopOffset = readUEG();\n frameCropBottomOffset = readUEG();\n }\n let pixelRatio = [1, 1];\n if (readBoolean()) {\n // vui_parameters_present_flag\n if (readBoolean()) {\n // aspect_ratio_info_present_flag\n const aspectRatioIdc = readUByte();\n switch (aspectRatioIdc) {\n case 1: pixelRatio = [1, 1]; break;\n case 2: pixelRatio = [12, 11]; break;\n case 3: pixelRatio = [10, 11]; break;\n case 4: pixelRatio = [16, 11]; break;\n case 5: pixelRatio = [40, 33]; break;\n case 6: pixelRatio = [24, 11]; break;\n case 7: pixelRatio = [20, 11]; break;\n case 8: pixelRatio = [32, 11]; break;\n case 9: pixelRatio = [80, 33]; break;\n case 10: pixelRatio = [18, 11]; break;\n case 11: pixelRatio = [15, 11]; break;\n case 12: pixelRatio = [64, 33]; break;\n case 13: pixelRatio = [160, 99]; break;\n case 14: pixelRatio = [4, 3]; break;\n case 15: pixelRatio = [3, 2]; break;\n case 16: pixelRatio = [2, 1]; break;\n case 255: {\n pixelRatio = [readUByte() << 8 | readUByte(), readUByte() << 8 | readUByte()];\n break;\n }\n }\n }\n }\n return {\n width: Math.ceil((((picWidthInMbsMinus1 + 1) * 16) - frameCropLeftOffset * 2 - frameCropRightOffset * 2)),\n height: ((2 - frameMbsOnlyFlag) * (picHeightInMapUnitsMinus1 + 1) * 16) - ((frameMbsOnlyFlag ? 2 : 4) * (frameCropTopOffset + frameCropBottomOffset)),\n pixelRatio: pixelRatio\n };\n }\n\n readSliceType () {\n // skip NALu type\n this.readUByte();\n // discard first_mb_in_slice\n this.readUEG();\n // return slice_type\n return this.readUEG();\n }\n}\n\nexport default ExpGolomb;\n","/**\n * SAMPLE-AES decrypter\n*/\n\nimport Decrypter from '../crypt/decrypter';\n\nclass SampleAesDecrypter {\n constructor (observer, config, decryptdata, discardEPB) {\n this.decryptdata = decryptdata;\n this.discardEPB = discardEPB;\n this.decrypter = new Decrypter(observer, config, { removePKCS7Padding: false });\n }\n\n decryptBuffer (encryptedData, callback) {\n this.decrypter.decrypt(encryptedData, this.decryptdata.key.buffer, this.decryptdata.iv.buffer, callback);\n }\n\n // AAC - encrypt all full 16 bytes blocks starting from offset 16\n decryptAacSample (samples, sampleIndex, callback, sync) {\n let curUnit = samples[sampleIndex].unit;\n let encryptedData = curUnit.subarray(16, curUnit.length - curUnit.length % 16);\n let encryptedBuffer = encryptedData.buffer.slice(\n encryptedData.byteOffset,\n encryptedData.byteOffset + encryptedData.length);\n\n let localthis = this;\n this.decryptBuffer(encryptedBuffer, function (decryptedData) {\n decryptedData = new Uint8Array(decryptedData);\n curUnit.set(decryptedData, 16);\n\n if (!sync) {\n localthis.decryptAacSamples(samples, sampleIndex + 1, callback);\n }\n });\n }\n\n decryptAacSamples (samples, sampleIndex, callback) {\n for (;; sampleIndex++) {\n if (sampleIndex >= samples.length) {\n callback();\n return;\n }\n\n if (samples[sampleIndex].unit.length < 32) {\n continue;\n }\n\n let sync = this.decrypter.isSync();\n\n this.decryptAacSample(samples, sampleIndex, callback, sync);\n\n if (!sync) {\n return;\n }\n }\n }\n\n // AVC - encrypt one 16 bytes block out of ten, starting from offset 32\n getAvcEncryptedData (decodedData) {\n let encryptedDataLen = Math.floor((decodedData.length - 48) / 160) * 16 + 16;\n let encryptedData = new Int8Array(encryptedDataLen);\n let outputPos = 0;\n for (let inputPos = 32; inputPos <= decodedData.length - 16; inputPos += 160, outputPos += 16) {\n encryptedData.set(decodedData.subarray(inputPos, inputPos + 16), outputPos);\n }\n\n return encryptedData;\n }\n\n getAvcDecryptedUnit (decodedData, decryptedData) {\n decryptedData = new Uint8Array(decryptedData);\n let inputPos = 0;\n for (let outputPos = 32; outputPos <= decodedData.length - 16; outputPos += 160, inputPos += 16) {\n decodedData.set(decryptedData.subarray(inputPos, inputPos + 16), outputPos);\n }\n\n return decodedData;\n }\n\n decryptAvcSample (samples, sampleIndex, unitIndex, callback, curUnit, sync) {\n let decodedData = this.discardEPB(curUnit.data);\n let encryptedData = this.getAvcEncryptedData(decodedData);\n let localthis = this;\n\n this.decryptBuffer(encryptedData.buffer, function (decryptedData) {\n curUnit.data = localthis.getAvcDecryptedUnit(decodedData, decryptedData);\n\n if (!sync) {\n localthis.decryptAvcSamples(samples, sampleIndex, unitIndex + 1, callback);\n }\n });\n }\n\n decryptAvcSamples (samples, sampleIndex, unitIndex, callback) {\n for (;; sampleIndex++, unitIndex = 0) {\n if (sampleIndex >= samples.length) {\n callback();\n return;\n }\n\n let curUnits = samples[sampleIndex].units;\n for (;; unitIndex++) {\n if (unitIndex >= curUnits.length) {\n break;\n }\n\n let curUnit = curUnits[unitIndex];\n if (curUnit.data.length <= 48 || (curUnit.type !== 1 && curUnit.type !== 5)) {\n continue;\n }\n\n let sync = this.decrypter.isSync();\n\n this.decryptAvcSample(samples, sampleIndex, unitIndex, callback, curUnit, sync);\n\n if (!sync) {\n return;\n }\n }\n }\n }\n}\n\nexport default SampleAesDecrypter;\n","/**\n * highly optimized TS demuxer:\n * parse PAT, PMT\n * extract PES packet from audio and video PIDs\n * extract AVC/H264 NAL units and AAC/ADTS samples from PES packet\n * trigger the remuxer upon parsing completion\n * it also tries to workaround as best as it can audio codec switch (HE-AAC to AAC and vice versa), without having to restart the MediaSource.\n * it also controls the remuxing process :\n * upon discontinuity or level switch detection, it will also notifies the remuxer so that it can reset its state.\n*/\n\nimport * as ADTS from './adts';\nimport MpegAudio from './mpegaudio';\nimport Event from '../events';\nimport ExpGolomb from './exp-golomb';\nimport SampleAesDecrypter from './sample-aes';\n// import Hex from '../utils/hex';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { utf8ArrayToStr } from './id3';\n\n// We are using fixed track IDs for driving the MP4 remuxer\n// instead of following the TS PIDs.\n// There is no reason not to do this and some browsers/SourceBuffer-demuxers\n// may not like if there are TrackID \"switches\"\n// See https://github.com/video-dev/hls.js/issues/1331\n// Here we are mapping our internal track types to constant MP4 track IDs\n// With MSE currently one can only have one track of each, and we are muxing\n// whatever video/audio rendition in them.\nconst RemuxerTrackIdConfig = {\n video: 1,\n audio: 2,\n id3: 3,\n text: 4\n};\n\nclass TSDemuxer {\n constructor (observer, remuxer, config, typeSupported) {\n this.observer = observer;\n this.config = config;\n this.typeSupported = typeSupported;\n this.remuxer = remuxer;\n this.sampleAes = null;\n this.pmtUnknownTypes = {};\n }\n\n setDecryptData (decryptdata) {\n if ((decryptdata != null) && (decryptdata.key != null) && (decryptdata.method === 'SAMPLE-AES')) {\n this.sampleAes = new SampleAesDecrypter(this.observer, this.config, decryptdata, this.discardEPB);\n } else {\n this.sampleAes = null;\n }\n }\n\n static probe (data) {\n const syncOffset = TSDemuxer._syncOffset(data);\n if (syncOffset < 0) {\n return false;\n } else {\n if (syncOffset) {\n logger.warn(`MPEG2-TS detected but first sync word found @ offset ${syncOffset}, junk ahead ?`);\n }\n\n return true;\n }\n }\n\n static _syncOffset (data) {\n // scan 1000 first bytes\n const scanwindow = Math.min(1000, data.length - 3 * 188);\n let i = 0;\n while (i < scanwindow) {\n // a TS fragment should contain at least 3 TS packets, a PAT, a PMT, and one PID, each starting with 0x47\n if (data[i] === 0x47 && data[i + 188] === 0x47 && data[i + 2 * 188] === 0x47) {\n return i;\n } else {\n i++;\n }\n }\n return -1;\n }\n\n /**\n * Creates a track model internal to demuxer used to drive remuxing input\n *\n * @param {string} type 'audio' | 'video' | 'id3' | 'text'\n * @param {number} duration\n * @return {object} TSDemuxer's internal track model\n */\n static createTrack (type, duration) {\n return {\n container: type === 'video' || type === 'audio' ? 'video/mp2t' : undefined,\n type,\n id: RemuxerTrackIdConfig[type],\n pid: -1,\n inputTimeScale: 90000,\n sequenceNumber: 0,\n samples: [],\n dropped: type === 'video' ? 0 : undefined,\n isAAC: type === 'audio' ? true : undefined,\n duration: type === 'audio' ? duration : undefined\n };\n }\n\n /**\n * Initializes a new init segment on the demuxer/remuxer interface. Needed for discontinuities/track-switches (or at stream start)\n * Resets all internal track instances of the demuxer.\n *\n * @override Implements generic demuxing/remuxing interface (see DemuxerInline)\n * @param {object} initSegment\n * @param {string} audioCodec\n * @param {string} videoCodec\n * @param {number} duration (in TS timescale = 90kHz)\n */\n resetInitSegment (initSegment, audioCodec, videoCodec, duration) {\n this.pmtParsed = false;\n this._pmtId = -1;\n this.pmtUnknownTypes = {};\n\n this._avcTrack = TSDemuxer.createTrack('video', duration);\n this._audioTrack = TSDemuxer.createTrack('audio', duration);\n this._id3Track = TSDemuxer.createTrack('id3', duration);\n this._txtTrack = TSDemuxer.createTrack('text', duration);\n\n // flush any partial content\n this.aacOverFlow = null;\n this.aacLastPTS = null;\n this.avcSample = null;\n this.audioCodec = audioCodec;\n this.videoCodec = videoCodec;\n this._duration = duration;\n }\n\n /**\n *\n * @override\n */\n resetTimeStamp () {}\n\n // feed incoming data to the front of the parsing pipeline\n append (data, timeOffset, contiguous, accurateTimeOffset) {\n let start, len = data.length, stt, pid, atf, offset, pes,\n unknownPIDs = false;\n this.pmtUnknownTypes = {};\n this.contiguous = contiguous;\n let pmtParsed = this.pmtParsed,\n avcTrack = this._avcTrack,\n audioTrack = this._audioTrack,\n id3Track = this._id3Track,\n avcId = avcTrack.pid,\n audioId = audioTrack.pid,\n id3Id = id3Track.pid,\n pmtId = this._pmtId,\n avcData = avcTrack.pesData,\n audioData = audioTrack.pesData,\n id3Data = id3Track.pesData,\n parsePAT = this._parsePAT,\n parsePMT = this._parsePMT.bind(this),\n parsePES = this._parsePES,\n parseAVCPES = this._parseAVCPES.bind(this),\n parseAACPES = this._parseAACPES.bind(this),\n parseMPEGPES = this._parseMPEGPES.bind(this),\n parseID3PES = this._parseID3PES.bind(this);\n\n const syncOffset = TSDemuxer._syncOffset(data);\n\n // don't parse last TS packet if incomplete\n len -= (len + syncOffset) % 188;\n\n // loop through TS packets\n for (start = syncOffset; start < len; start += 188) {\n if (data[start] === 0x47) {\n stt = !!(data[start + 1] & 0x40);\n // pid is a 13-bit field starting at the last bit of TS[1]\n pid = ((data[start + 1] & 0x1f) << 8) + data[start + 2];\n atf = (data[start + 3] & 0x30) >> 4;\n // if an adaption field is present, its length is specified by the fifth byte of the TS packet header.\n if (atf > 1) {\n offset = start + 5 + data[start + 4];\n // continue if there is only adaptation field\n if (offset === (start + 188)) {\n continue;\n }\n } else {\n offset = start + 4;\n }\n switch (pid) {\n case avcId:\n if (stt) {\n if (avcData && (pes = parsePES(avcData))) {\n parseAVCPES(pes, false);\n }\n\n avcData = { data: [], size: 0 };\n }\n if (avcData) {\n avcData.data.push(data.subarray(offset, start + 188));\n avcData.size += start + 188 - offset;\n }\n break;\n case audioId:\n if (stt) {\n if (audioData && (pes = parsePES(audioData))) {\n if (audioTrack.isAAC) {\n parseAACPES(pes);\n } else {\n parseMPEGPES(pes);\n }\n }\n audioData = { data: [], size: 0 };\n }\n if (audioData) {\n audioData.data.push(data.subarray(offset, start + 188));\n audioData.size += start + 188 - offset;\n }\n break;\n case id3Id:\n if (stt) {\n if (id3Data && (pes = parsePES(id3Data))) {\n parseID3PES(pes);\n }\n\n id3Data = { data: [], size: 0 };\n }\n if (id3Data) {\n id3Data.data.push(data.subarray(offset, start + 188));\n id3Data.size += start + 188 - offset;\n }\n break;\n case 0:\n if (stt) {\n offset += data[offset] + 1;\n }\n\n pmtId = this._pmtId = parsePAT(data, offset);\n break;\n case pmtId:\n if (stt) {\n offset += data[offset] + 1;\n }\n\n let parsedPIDs = parsePMT(data, offset, this.typeSupported.mpeg === true || this.typeSupported.mp3 === true, this.sampleAes != null);\n\n // only update track id if track PID found while parsing PMT\n // this is to avoid resetting the PID to -1 in case\n // track PID transiently disappears from the stream\n // this could happen in case of transient missing audio samples for example\n // NOTE this is only the PID of the track as found in TS,\n // but we are not using this for MP4 track IDs.\n avcId = parsedPIDs.avc;\n if (avcId > 0) {\n avcTrack.pid = avcId;\n }\n\n audioId = parsedPIDs.audio;\n if (audioId > 0) {\n audioTrack.pid = audioId;\n audioTrack.isAAC = parsedPIDs.isAAC;\n }\n id3Id = parsedPIDs.id3;\n if (id3Id > 0) {\n id3Track.pid = id3Id;\n }\n\n if (unknownPIDs && !pmtParsed) {\n logger.log('reparse from beginning');\n unknownPIDs = false;\n // we set it to -188, the += 188 in the for loop will reset start to 0\n start = syncOffset - 188;\n }\n pmtParsed = this.pmtParsed = true;\n break;\n case 17:\n case 0x1fff:\n break;\n default:\n unknownPIDs = true;\n break;\n }\n } else {\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: false, reason: 'TS packet did not start with 0x47' });\n }\n }\n // try to parse last PES packets\n if (avcData && (pes = parsePES(avcData))) {\n parseAVCPES(pes, true);\n avcTrack.pesData = null;\n } else {\n // either avcData null or PES truncated, keep it for next frag parsing\n avcTrack.pesData = avcData;\n }\n\n if (audioData && (pes = parsePES(audioData))) {\n if (audioTrack.isAAC) {\n parseAACPES(pes);\n } else {\n parseMPEGPES(pes);\n }\n\n audioTrack.pesData = null;\n } else {\n if (audioData && audioData.size) {\n logger.log('last AAC PES packet truncated,might overlap between fragments');\n }\n\n // either audioData null or PES truncated, keep it for next frag parsing\n audioTrack.pesData = audioData;\n }\n\n if (id3Data && (pes = parsePES(id3Data))) {\n parseID3PES(pes);\n id3Track.pesData = null;\n } else {\n // either id3Data null or PES truncated, keep it for next frag parsing\n id3Track.pesData = id3Data;\n }\n\n if (this.sampleAes == null) {\n this.remuxer.remux(audioTrack, avcTrack, id3Track, this._txtTrack, timeOffset, contiguous, accurateTimeOffset);\n } else {\n this.decryptAndRemux(audioTrack, avcTrack, id3Track, this._txtTrack, timeOffset, contiguous, accurateTimeOffset);\n }\n }\n\n decryptAndRemux (audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset) {\n if (audioTrack.samples && audioTrack.isAAC) {\n let localthis = this;\n this.sampleAes.decryptAacSamples(audioTrack.samples, 0, function () {\n localthis.decryptAndRemuxAvc(audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset);\n });\n } else {\n this.decryptAndRemuxAvc(audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset);\n }\n }\n\n decryptAndRemuxAvc (audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset) {\n if (videoTrack.samples) {\n let localthis = this;\n this.sampleAes.decryptAvcSamples(videoTrack.samples, 0, 0, function () {\n localthis.remuxer.remux(audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset);\n });\n } else {\n this.remuxer.remux(audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset);\n }\n }\n\n destroy () {\n this._initPTS = this._initDTS = undefined;\n this._duration = 0;\n }\n\n _parsePAT (data, offset) {\n // skip the PSI header and parse the first PMT entry\n return (data[offset + 10] & 0x1F) << 8 | data[offset + 11];\n // logger.log('PMT PID:' + this._pmtId);\n }\n\n _trackUnknownPmt (type, logLevel, message) {\n // Only log unknown and unsupported stream types once per append or stream (by resetting this.pmtUnknownTypes)\n // For more information on elementary stream types see:\n // https://en.wikipedia.org/wiki/Program-specific_information#Elementary_stream_types\n const result = this.pmtUnknownTypes[type] || 0;\n if (result === 0) {\n this.pmtUnknownTypes[type] = 0;\n logLevel.call(logger, message);\n }\n this.pmtUnknownTypes[type]++;\n return result;\n }\n\n _parsePMT (data, offset, mpegSupported, isSampleAes) {\n let sectionLength, tableEnd, programInfoLength, pid, result = { audio: -1, avc: -1, id3: -1, isAAC: true };\n sectionLength = (data[offset + 1] & 0x0f) << 8 | data[offset + 2];\n tableEnd = offset + 3 + sectionLength - 4;\n // to determine where the table is, we have to figure out how\n // long the program info descriptors are\n programInfoLength = (data[offset + 10] & 0x0f) << 8 | data[offset + 11];\n // advance the offset to the first entry in the mapping table\n offset += 12 + programInfoLength;\n while (offset < tableEnd) {\n pid = (data[offset + 1] & 0x1F) << 8 | data[offset + 2];\n switch (data[offset]) {\n case 0xcf: // SAMPLE-AES AAC\n if (!isSampleAes) {\n this._trackUnknownPmt(data[offset], logger.warn, 'ADTS AAC with AES-128-CBC frame encryption found in unencrypted stream');\n break;\n }\n /* falls through */\n\n // ISO/IEC 13818-7 ADTS AAC (MPEG-2 lower bit-rate audio)\n case 0x0f:\n // logger.log('AAC PID:' + pid);\n if (result.audio === -1) {\n result.audio = pid;\n }\n\n break;\n\n // Packetized metadata (ID3)\n case 0x15:\n // logger.log('ID3 PID:' + pid);\n if (result.id3 === -1) {\n result.id3 = pid;\n }\n\n break;\n\n case 0xdb: // SAMPLE-AES AVC\n if (!isSampleAes) {\n this._trackUnknownPmt(data[offset], logger.warn, 'H.264 with AES-128-CBC slice encryption found in unencrypted stream');\n break;\n }\n /* falls through */\n\n // ITU-T Rec. H.264 and ISO/IEC 14496-10 (lower bit-rate video)\n case 0x1b:\n // logger.log('AVC PID:' + pid);\n if (result.avc === -1) {\n result.avc = pid;\n }\n\n break;\n\n // ISO/IEC 11172-3 (MPEG-1 audio)\n // or ISO/IEC 13818-3 (MPEG-2 halved sample rate audio)\n case 0x03:\n case 0x04:\n // logger.log('MPEG PID:' + pid);\n if (!mpegSupported) {\n this._trackUnknownPmt(data[offset], logger.warn, 'MPEG audio found, not supported in this browser');\n } else if (result.audio === -1) {\n result.audio = pid;\n result.isAAC = false;\n }\n break;\n\n case 0x24:\n this._trackUnknownPmt(data[offset], logger.warn, 'Unsupported HEVC stream type found');\n break;\n\n default:\n this._trackUnknownPmt(data[offset], logger.log, 'Unknown stream type:' + data[offset]);\n break;\n }\n // move to the next table entry\n // skip past the elementary stream descriptors, if present\n offset += ((data[offset + 3] & 0x0F) << 8 | data[offset + 4]) + 5;\n }\n return result;\n }\n\n _parsePES (stream) {\n let i = 0, frag, pesFlags, pesPrefix, pesLen, pesHdrLen, pesData, pesPts, pesDts, payloadStartOffset, data = stream.data;\n // safety check\n if (!stream || stream.size === 0) {\n return null;\n }\n\n // we might need up to 19 bytes to read PES header\n // if first chunk of data is less than 19 bytes, let's merge it with following ones until we get 19 bytes\n // usually only one merge is needed (and this is rare ...)\n while (data[0].length < 19 && data.length > 1) {\n let newData = new Uint8Array(data[0].length + data[1].length);\n newData.set(data[0]);\n newData.set(data[1], data[0].length);\n data[0] = newData;\n data.splice(1, 1);\n }\n // retrieve PTS/DTS from first fragment\n frag = data[0];\n pesPrefix = (frag[0] << 16) + (frag[1] << 8) + frag[2];\n if (pesPrefix === 1) {\n pesLen = (frag[4] << 8) + frag[5];\n // if PES parsed length is not zero and greater than total received length, stop parsing. PES might be truncated\n // minus 6 : PES header size\n if (pesLen && pesLen > stream.size - 6) {\n return null;\n }\n\n pesFlags = frag[7];\n if (pesFlags & 0xC0) {\n /* PES header described here : http://dvd.sourceforge.net/dvdinfo/pes-hdr.html\n as PTS / DTS is 33 bit we cannot use bitwise operator in JS,\n as Bitwise operators treat their operands as a sequence of 32 bits */\n pesPts = (frag[9] & 0x0E) * 536870912 +// 1 << 29\n (frag[10] & 0xFF) * 4194304 +// 1 << 22\n (frag[11] & 0xFE) * 16384 +// 1 << 14\n (frag[12] & 0xFF) * 128 +// 1 << 7\n (frag[13] & 0xFE) / 2;\n\n if (pesFlags & 0x40) {\n pesDts = (frag[14] & 0x0E) * 536870912 +// 1 << 29\n (frag[15] & 0xFF) * 4194304 +// 1 << 22\n (frag[16] & 0xFE) * 16384 +// 1 << 14\n (frag[17] & 0xFF) * 128 +// 1 << 7\n (frag[18] & 0xFE) / 2;\n\n if (pesPts - pesDts > 60 * 90000) {\n logger.warn(`${Math.round((pesPts - pesDts) / 90000)}s delta between PTS and DTS, align them`);\n pesPts = pesDts;\n }\n } else {\n pesDts = pesPts;\n }\n }\n pesHdrLen = frag[8];\n // 9 bytes : 6 bytes for PES header + 3 bytes for PES extension\n payloadStartOffset = pesHdrLen + 9;\n\n if (stream.size <= payloadStartOffset) {\n return null;\n }\n stream.size -= payloadStartOffset;\n // reassemble PES packet\n pesData = new Uint8Array(stream.size);\n for (let j = 0, dataLen = data.length; j < dataLen; j++) {\n frag = data[j];\n let len = frag.byteLength;\n if (payloadStartOffset) {\n if (payloadStartOffset > len) {\n // trim full frag if PES header bigger than frag\n payloadStartOffset -= len;\n continue;\n } else {\n // trim partial frag if PES header smaller than frag\n frag = frag.subarray(payloadStartOffset);\n len -= payloadStartOffset;\n payloadStartOffset = 0;\n }\n }\n pesData.set(frag, i);\n i += len;\n }\n if (pesLen) {\n // payload size : remove PES header + PES extension\n pesLen -= pesHdrLen + 3;\n }\n return { data: pesData, pts: pesPts, dts: pesDts, len: pesLen };\n } else {\n return null;\n }\n }\n\n pushAccesUnit (avcSample, avcTrack) {\n if (avcSample.units.length && avcSample.frame) {\n const samples = avcTrack.samples;\n const nbSamples = samples.length;\n // if sample does not have PTS/DTS, patch with last sample PTS/DTS\n if (isNaN(avcSample.pts)) {\n if (nbSamples) {\n const lastSample = samples[nbSamples - 1];\n avcSample.pts = lastSample.pts;\n avcSample.dts = lastSample.dts;\n } else {\n // dropping samples, no timestamp found\n avcTrack.dropped++;\n return;\n }\n }\n // only push AVC sample if starting with a keyframe is not mandatory OR\n // if keyframe already found in this fragment OR\n // keyframe found in last fragment (track.sps) AND\n // samples already appended (we already found a keyframe in this fragment) OR fragment is contiguous\n if (!this.config.forceKeyFrameOnDiscontinuity ||\n avcSample.key === true ||\n (avcTrack.sps && (nbSamples || this.contiguous))) {\n avcSample.id = nbSamples;\n samples.push(avcSample);\n } else {\n // dropped samples, track it\n avcTrack.dropped++;\n }\n }\n if (avcSample.debug.length) {\n logger.log(avcSample.pts + '/' + avcSample.dts + ':' + avcSample.debug);\n }\n }\n\n _parseAVCPES (pes, last) {\n // logger.log('parse new PES');\n let track = this._avcTrack,\n units = this._parseAVCNALu(pes.data),\n debug = false,\n expGolombDecoder,\n avcSample = this.avcSample,\n push,\n spsfound = false,\n i,\n pushAccesUnit = this.pushAccesUnit.bind(this),\n createAVCSample = function (key, pts, dts, debug) {\n return { key: key, pts: pts, dts: dts, units: [], debug: debug };\n };\n // free pes.data to save up some memory\n pes.data = null;\n\n // if new NAL units found and last sample still there, let's push ...\n // this helps parsing streams with missing AUD (only do this if AUD never found)\n if (avcSample && units.length && !track.audFound) {\n pushAccesUnit(avcSample, track);\n avcSample = this.avcSample = createAVCSample(false, pes.pts, pes.dts, '');\n }\n\n units.forEach(unit => {\n switch (unit.type) {\n // NDR\n case 1:\n push = true;\n if (!avcSample) {\n avcSample = this.avcSample = createAVCSample(true, pes.pts, pes.dts, '');\n }\n\n if (debug) {\n avcSample.debug += 'NDR ';\n }\n\n avcSample.frame = true;\n let data = unit.data;\n // only check slice type to detect KF in case SPS found in same packet (any keyframe is preceded by SPS ...)\n if (spsfound && data.length > 4) {\n // retrieve slice type by parsing beginning of NAL unit (follow H264 spec, slice_header definition) to detect keyframe embedded in NDR\n let sliceType = new ExpGolomb(data).readSliceType();\n // 2 : I slice, 4 : SI slice, 7 : I slice, 9: SI slice\n // SI slice : A slice that is coded using intra prediction only and using quantisation of the prediction samples.\n // An SI slice can be coded such that its decoded samples can be constructed identically to an SP slice.\n // I slice: A slice that is not an SI slice that is decoded using intra prediction only.\n // if (sliceType === 2 || sliceType === 7) {\n if (sliceType === 2 || sliceType === 4 || sliceType === 7 || sliceType === 9) {\n avcSample.key = true;\n }\n }\n break;\n // IDR\n case 5:\n push = true;\n // handle PES not starting with AUD\n if (!avcSample) {\n avcSample = this.avcSample = createAVCSample(true, pes.pts, pes.dts, '');\n }\n\n if (debug) {\n avcSample.debug += 'IDR ';\n }\n\n avcSample.key = true;\n avcSample.frame = true;\n break;\n // SEI\n case 6:\n push = true;\n if (debug && avcSample) {\n avcSample.debug += 'SEI ';\n }\n\n expGolombDecoder = new ExpGolomb(this.discardEPB(unit.data));\n\n // skip frameType\n expGolombDecoder.readUByte();\n\n var payloadType = 0;\n var payloadSize = 0;\n var endOfCaptions = false;\n var b = 0;\n\n while (!endOfCaptions && expGolombDecoder.bytesAvailable > 1) {\n payloadType = 0;\n do {\n b = expGolombDecoder.readUByte();\n payloadType += b;\n } while (b === 0xFF);\n\n // Parse payload size.\n payloadSize = 0;\n do {\n b = expGolombDecoder.readUByte();\n payloadSize += b;\n } while (b === 0xFF);\n\n // TODO: there can be more than one payload in an SEI packet...\n // TODO: need to read type and size in a while loop to get them all\n if (payloadType === 4 && expGolombDecoder.bytesAvailable !== 0) {\n endOfCaptions = true;\n\n let countryCode = expGolombDecoder.readUByte();\n\n if (countryCode === 181) {\n let providerCode = expGolombDecoder.readUShort();\n\n if (providerCode === 49) {\n let userStructure = expGolombDecoder.readUInt();\n\n if (userStructure === 0x47413934) {\n let userDataType = expGolombDecoder.readUByte();\n\n // Raw CEA-608 bytes wrapped in CEA-708 packet\n if (userDataType === 3) {\n let firstByte = expGolombDecoder.readUByte();\n let secondByte = expGolombDecoder.readUByte();\n\n let totalCCs = 31 & firstByte;\n let byteArray = [firstByte, secondByte];\n\n for (i = 0; i < totalCCs; i++) {\n // 3 bytes per CC\n byteArray.push(expGolombDecoder.readUByte());\n byteArray.push(expGolombDecoder.readUByte());\n byteArray.push(expGolombDecoder.readUByte());\n }\n\n this._insertSampleInOrder(this._txtTrack.samples, { type: 3, pts: pes.pts, bytes: byteArray });\n }\n }\n }\n }\n } else if (payloadType === 5 && expGolombDecoder.bytesAvailable !== 0) {\n endOfCaptions = true;\n\n if (payloadSize > 16) {\n const uuidStrArray = [];\n for (i = 0; i < 16; i++) {\n uuidStrArray.push(expGolombDecoder.readUByte().toString(16));\n\n if (i === 3 || i === 5 || i === 7 || i === 9) {\n uuidStrArray.push('-');\n }\n }\n const length = payloadSize - 16;\n const userDataPayloadBytes = new Uint8Array(length);\n for (i = 0; i < length; i++) {\n userDataPayloadBytes[i] = expGolombDecoder.readUByte();\n }\n\n this._insertSampleInOrder(this._txtTrack.samples, {\n pts: pes.pts,\n payloadType: payloadType,\n uuid: uuidStrArray.join(''),\n userDataBytes: userDataPayloadBytes,\n userData: utf8ArrayToStr(userDataPayloadBytes.buffer)\n });\n }\n } else if (payloadSize < expGolombDecoder.bytesAvailable) {\n for (i = 0; i < payloadSize; i++) {\n expGolombDecoder.readUByte();\n }\n }\n }\n break;\n // SPS\n case 7:\n push = true;\n spsfound = true;\n if (debug && avcSample) {\n avcSample.debug += 'SPS ';\n }\n\n if (!track.sps) {\n expGolombDecoder = new ExpGolomb(unit.data);\n let config = expGolombDecoder.readSPS();\n track.width = config.width;\n track.height = config.height;\n track.pixelRatio = config.pixelRatio;\n track.sps = [unit.data];\n track.duration = this._duration;\n let codecarray = unit.data.subarray(1, 4);\n let codecstring = 'avc1.';\n for (i = 0; i < 3; i++) {\n let h = codecarray[i].toString(16);\n if (h.length < 2) {\n h = '0' + h;\n }\n\n codecstring += h;\n }\n track.codec = codecstring;\n }\n break;\n // PPS\n case 8:\n push = true;\n if (debug && avcSample) {\n avcSample.debug += 'PPS ';\n }\n\n if (!track.pps) {\n track.pps = [unit.data];\n }\n\n break;\n // AUD\n case 9:\n push = false;\n track.audFound = true;\n if (avcSample) {\n pushAccesUnit(avcSample, track);\n }\n\n avcSample = this.avcSample = createAVCSample(false, pes.pts, pes.dts, debug ? 'AUD ' : '');\n break;\n // Filler Data\n case 12:\n push = false;\n break;\n default:\n push = false;\n if (avcSample) {\n avcSample.debug += 'unknown NAL ' + unit.type + ' ';\n }\n\n break;\n }\n if (avcSample && push) {\n let units = avcSample.units;\n units.push(unit);\n }\n });\n // if last PES packet, push samples\n if (last && avcSample) {\n pushAccesUnit(avcSample, track);\n this.avcSample = null;\n }\n }\n\n _insertSampleInOrder (arr, data) {\n let len = arr.length;\n if (len > 0) {\n if (data.pts >= arr[len - 1].pts) {\n arr.push(data);\n } else {\n for (let pos = len - 1; pos >= 0; pos--) {\n if (data.pts < arr[pos].pts) {\n arr.splice(pos, 0, data);\n break;\n }\n }\n }\n } else {\n arr.push(data);\n }\n }\n\n _getLastNalUnit () {\n let avcSample = this.avcSample, lastUnit;\n // try to fallback to previous sample if current one is empty\n if (!avcSample || avcSample.units.length === 0) {\n let track = this._avcTrack, samples = track.samples;\n avcSample = samples[samples.length - 1];\n }\n if (avcSample) {\n let units = avcSample.units;\n lastUnit = units[units.length - 1];\n }\n return lastUnit;\n }\n\n _parseAVCNALu (array) {\n let i = 0, len = array.byteLength, value, overflow, track = this._avcTrack, state = track.naluState || 0, lastState = state;\n let units = [], unit, unitType, lastUnitStart = -1, lastUnitType;\n // logger.log('PES:' + Hex.hexDump(array));\n\n if (state === -1) {\n // special use case where we found 3 or 4-byte start codes exactly at the end of previous PES packet\n lastUnitStart = 0;\n // NALu type is value read from offset 0\n lastUnitType = array[0] & 0x1f;\n state = 0;\n i = 1;\n }\n\n while (i < len) {\n value = array[i++];\n // optimization. state 0 and 1 are the predominant case. let's handle them outside of the switch/case\n if (!state) {\n state = value ? 0 : 1;\n continue;\n }\n if (state === 1) {\n state = value ? 0 : 2;\n continue;\n }\n // here we have state either equal to 2 or 3\n if (!value) {\n state = 3;\n } else if (value === 1) {\n if (lastUnitStart >= 0) {\n unit = { data: array.subarray(lastUnitStart, i - state - 1), type: lastUnitType };\n // logger.log('pushing NALU, type/size:' + unit.type + '/' + unit.data.byteLength);\n units.push(unit);\n } else {\n // lastUnitStart is undefined => this is the first start code found in this PES packet\n // first check if start code delimiter is overlapping between 2 PES packets,\n // ie it started in last packet (lastState not zero)\n // and ended at the beginning of this PES packet (i <= 4 - lastState)\n let lastUnit = this._getLastNalUnit();\n if (lastUnit) {\n if (lastState && (i <= 4 - lastState)) {\n // start delimiter overlapping between PES packets\n // strip start delimiter bytes from the end of last NAL unit\n // check if lastUnit had a state different from zero\n if (lastUnit.state) {\n // strip last bytes\n lastUnit.data = lastUnit.data.subarray(0, lastUnit.data.byteLength - lastState);\n }\n }\n // If NAL units are not starting right at the beginning of the PES packet, push preceding data into previous NAL unit.\n overflow = i - state - 1;\n if (overflow > 0) {\n // logger.log('first NALU found with overflow:' + overflow);\n let tmp = new Uint8Array(lastUnit.data.byteLength + overflow);\n tmp.set(lastUnit.data, 0);\n tmp.set(array.subarray(0, overflow), lastUnit.data.byteLength);\n lastUnit.data = tmp;\n }\n }\n }\n // check if we can read unit type\n if (i < len) {\n unitType = array[i] & 0x1f;\n // logger.log('find NALU @ offset:' + i + ',type:' + unitType);\n lastUnitStart = i;\n lastUnitType = unitType;\n state = 0;\n } else {\n // not enough byte to read unit type. let's read it on next PES parsing\n state = -1;\n }\n } else {\n state = 0;\n }\n }\n if (lastUnitStart >= 0 && state >= 0) {\n unit = { data: array.subarray(lastUnitStart, len), type: lastUnitType, state: state };\n units.push(unit);\n // logger.log('pushing NALU, type/size/state:' + unit.type + '/' + unit.data.byteLength + '/' + state);\n }\n // no NALu found\n if (units.length === 0) {\n // append pes.data to previous NAL unit\n let lastUnit = this._getLastNalUnit();\n if (lastUnit) {\n let tmp = new Uint8Array(lastUnit.data.byteLength + array.byteLength);\n tmp.set(lastUnit.data, 0);\n tmp.set(array, lastUnit.data.byteLength);\n lastUnit.data = tmp;\n }\n }\n track.naluState = state;\n return units;\n }\n\n /**\n * remove Emulation Prevention bytes from a RBSP\n */\n discardEPB (data) {\n let length = data.byteLength,\n EPBPositions = [],\n i = 1,\n newLength, newData;\n\n // Find all `Emulation Prevention Bytes`\n while (i < length - 2) {\n if (data[i] === 0 &&\n data[i + 1] === 0 &&\n data[i + 2] === 0x03) {\n EPBPositions.push(i + 2);\n i += 2;\n } else {\n i++;\n }\n }\n\n // If no Emulation Prevention Bytes were found just return the original\n // array\n if (EPBPositions.length === 0) {\n return data;\n }\n\n // Create a new array to hold the NAL unit data\n newLength = length - EPBPositions.length;\n newData = new Uint8Array(newLength);\n let sourceIndex = 0;\n\n for (i = 0; i < newLength; sourceIndex++, i++) {\n if (sourceIndex === EPBPositions[0]) {\n // Skip this byte\n sourceIndex++;\n // Remove this position index\n EPBPositions.shift();\n }\n newData[i] = data[sourceIndex];\n }\n return newData;\n }\n\n _parseAACPES (pes) {\n let track = this._audioTrack,\n data = pes.data,\n pts = pes.pts,\n startOffset = 0,\n aacOverFlow = this.aacOverFlow,\n aacLastPTS = this.aacLastPTS,\n frameDuration, frameIndex, offset, stamp, len;\n if (aacOverFlow) {\n let tmp = new Uint8Array(aacOverFlow.byteLength + data.byteLength);\n tmp.set(aacOverFlow, 0);\n tmp.set(data, aacOverFlow.byteLength);\n // logger.log(`AAC: append overflowing ${aacOverFlow.byteLength} bytes to beginning of new PES`);\n data = tmp;\n }\n // look for ADTS header (0xFFFx)\n for (offset = startOffset, len = data.length; offset < len - 1; offset++) {\n if (ADTS.isHeader(data, offset)) {\n break;\n }\n }\n // if ADTS header does not start straight from the beginning of the PES payload, raise an error\n if (offset) {\n let reason, fatal;\n if (offset < len - 1) {\n reason = `AAC PES did not start with ADTS header,offset:${offset}`;\n fatal = false;\n } else {\n reason = 'no ADTS header found in AAC PES';\n fatal = true;\n }\n logger.warn(`parsing error:${reason}`);\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: fatal, reason: reason });\n if (fatal) {\n return;\n }\n }\n\n ADTS.initTrackConfig(track, this.observer, data, offset, this.audioCodec);\n frameIndex = 0;\n frameDuration = ADTS.getFrameDuration(track.samplerate);\n\n // if last AAC frame is overflowing, we should ensure timestamps are contiguous:\n // first sample PTS should be equal to last sample PTS + frameDuration\n if (aacOverFlow && aacLastPTS) {\n let newPTS = aacLastPTS + frameDuration;\n if (Math.abs(newPTS - pts) > 1) {\n logger.log(`AAC: align PTS for overlapping frames by ${Math.round((newPTS - pts) / 90)}`);\n pts = newPTS;\n }\n }\n\n // scan for aac samples\n while (offset < len) {\n if (ADTS.isHeader(data, offset)) {\n if ((offset + 5) < len) {\n const frame = ADTS.appendFrame(track, data, offset, pts, frameIndex);\n if (frame) {\n offset += frame.length;\n stamp = frame.sample.pts;\n frameIndex++;\n continue;\n }\n }\n // We are at an ADTS header, but do not have enough data for a frame\n // Remaining data will be added to aacOverFlow\n break;\n } else {\n // nothing found, keep looking\n offset++;\n }\n }\n\n if (offset < len) {\n aacOverFlow = data.subarray(offset, len);\n // logger.log(`AAC: overflow detected:${len-offset}`);\n } else {\n aacOverFlow = null;\n }\n\n this.aacOverFlow = aacOverFlow;\n this.aacLastPTS = stamp;\n }\n\n _parseMPEGPES (pes) {\n let data = pes.data;\n let length = data.length;\n let frameIndex = 0;\n let offset = 0;\n let pts = pes.pts;\n\n while (offset < length) {\n if (MpegAudio.isHeader(data, offset)) {\n let frame = MpegAudio.appendFrame(this._audioTrack, data, offset, pts, frameIndex);\n if (frame) {\n offset += frame.length;\n frameIndex++;\n } else {\n // logger.log('Unable to parse Mpeg audio frame');\n break;\n }\n } else {\n // nothing found, keep looking\n offset++;\n }\n }\n }\n\n _parseID3PES (pes) {\n this._id3Track.samples.push(pes);\n }\n}\n\nexport default TSDemuxer;\n","/**\n * MP3 demuxer\n */\nimport ID3 from '../demux/id3';\nimport { logger } from '../utils/logger';\nimport MpegAudio from './mpegaudio';\n\nclass MP3Demuxer {\n constructor (observer, remuxer, config) {\n this.observer = observer;\n this.config = config;\n this.remuxer = remuxer;\n }\n\n resetInitSegment (initSegment, audioCodec, videoCodec, duration) {\n this._audioTrack = { container: 'audio/mpeg', type: 'audio', id: -1, sequenceNumber: 0, isAAC: false, samples: [], len: 0, manifestCodec: audioCodec, duration: duration, inputTimeScale: 90000 };\n }\n\n resetTimeStamp () {\n }\n\n static probe (data) {\n // check if data contains ID3 timestamp and MPEG sync word\n let offset, length;\n let id3Data = ID3.getID3Data(data, 0);\n if (id3Data && ID3.getTimeStamp(id3Data) !== undefined) {\n // Look for MPEG header | 1111 1111 | 111X XYZX | where X can be either 0 or 1 and Y or Z should be 1\n // Layer bits (position 14 and 15) in header should be always different from 0 (Layer I or Layer II or Layer III)\n // More info http://www.mp3-tech.org/programmer/frame_header.html\n for (offset = id3Data.length, length = Math.min(data.length - 1, offset + 100); offset < length; offset++) {\n if (MpegAudio.probe(data, offset)) {\n logger.log('MPEG Audio sync word found !');\n return true;\n }\n }\n }\n return false;\n }\n\n // feed incoming data to the front of the parsing pipeline\n append (data, timeOffset, contiguous, accurateTimeOffset) {\n let id3Data = ID3.getID3Data(data, 0) || [];\n let timestamp = ID3.getTimeStamp(id3Data);\n let pts = timestamp !== undefined ? 90 * timestamp : timeOffset * 90000;\n let offset = id3Data.length;\n let length = data.length;\n let frameIndex = 0, stamp = 0;\n let track = this._audioTrack;\n\n let id3Samples = [{ pts: pts, dts: pts, data: id3Data }];\n\n while (offset < length) {\n if (MpegAudio.isHeader(data, offset)) {\n let frame = MpegAudio.appendFrame(track, data, offset, pts, frameIndex);\n if (frame) {\n offset += frame.length;\n stamp = frame.sample.pts;\n frameIndex++;\n } else {\n // logger.log('Unable to parse Mpeg audio frame');\n break;\n }\n } else if (ID3.isHeader(data, offset)) {\n id3Data = ID3.getID3Data(data, offset);\n id3Samples.push({ pts: stamp, dts: stamp, data: id3Data });\n offset += id3Data.length;\n } else {\n // nothing found, keep looking\n offset++;\n }\n }\n\n this.remuxer.remux(track,\n { samples: [] },\n { samples: id3Samples, inputTimeScale: 90000 },\n { samples: [] },\n timeOffset,\n contiguous,\n accurateTimeOffset);\n }\n\n destroy () {\n }\n}\n\nexport default MP3Demuxer;\n","/**\n * AAC helper\n */\n\nclass AAC {\n static getSilentFrame (codec, channelCount) {\n switch (codec) {\n case 'mp4a.40.2':\n if (channelCount === 1) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x23, 0x80]);\n } else if (channelCount === 2) {\n return new Uint8Array([0x21, 0x00, 0x49, 0x90, 0x02, 0x19, 0x00, 0x23, 0x80]);\n } else if (channelCount === 3) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x8e]);\n } else if (channelCount === 4) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x80, 0x2c, 0x80, 0x08, 0x02, 0x38]);\n } else if (channelCount === 5) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x82, 0x30, 0x04, 0x99, 0x00, 0x21, 0x90, 0x02, 0x38]);\n } else if (channelCount === 6) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x82, 0x30, 0x04, 0x99, 0x00, 0x21, 0x90, 0x02, 0x00, 0xb2, 0x00, 0x20, 0x08, 0xe0]);\n }\n\n break;\n // handle HE-AAC below (mp4a.40.5 / mp4a.40.29)\n default:\n if (channelCount === 1) {\n // ffmpeg -y -f lavfi -i \"aevalsrc=0:d=0.05\" -c:a libfdk_aac -profile:a aac_he -b:a 4k output.aac && hexdump -v -e '16/1 \"0x%x,\" \"\\n\"' -v output.aac\n return new Uint8Array([0x1, 0x40, 0x22, 0x80, 0xa3, 0x4e, 0xe6, 0x80, 0xba, 0x8, 0x0, 0x0, 0x0, 0x1c, 0x6, 0xf1, 0xc1, 0xa, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5e]);\n } else if (channelCount === 2) {\n // ffmpeg -y -f lavfi -i \"aevalsrc=0|0:d=0.05\" -c:a libfdk_aac -profile:a aac_he_v2 -b:a 4k output.aac && hexdump -v -e '16/1 \"0x%x,\" \"\\n\"' -v output.aac\n return new Uint8Array([0x1, 0x40, 0x22, 0x80, 0xa3, 0x5e, 0xe6, 0x80, 0xba, 0x8, 0x0, 0x0, 0x0, 0x0, 0x95, 0x0, 0x6, 0xf1, 0xa1, 0xa, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5e]);\n } else if (channelCount === 3) {\n // ffmpeg -y -f lavfi -i \"aevalsrc=0|0|0:d=0.05\" -c:a libfdk_aac -profile:a aac_he_v2 -b:a 4k output.aac && hexdump -v -e '16/1 \"0x%x,\" \"\\n\"' -v output.aac\n return new Uint8Array([0x1, 0x40, 0x22, 0x80, 0xa3, 0x5e, 0xe6, 0x80, 0xba, 0x8, 0x0, 0x0, 0x0, 0x0, 0x95, 0x0, 0x6, 0xf1, 0xa1, 0xa, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5e]);\n }\n break;\n }\n return null;\n }\n}\n\nexport default AAC;\n","/**\n * Generate MP4 Box\n*/\n\nconst UINT32_MAX = Math.pow(2, 32) - 1;\n\nclass MP4 {\n static init () {\n MP4.types = {\n avc1: [], // codingname\n avcC: [],\n btrt: [],\n dinf: [],\n dref: [],\n esds: [],\n ftyp: [],\n hdlr: [],\n mdat: [],\n mdhd: [],\n mdia: [],\n mfhd: [],\n minf: [],\n moof: [],\n moov: [],\n mp4a: [],\n '.mp3': [],\n mvex: [],\n mvhd: [],\n pasp: [],\n sdtp: [],\n stbl: [],\n stco: [],\n stsc: [],\n stsd: [],\n stsz: [],\n stts: [],\n tfdt: [],\n tfhd: [],\n traf: [],\n trak: [],\n trun: [],\n trex: [],\n tkhd: [],\n vmhd: [],\n smhd: []\n };\n\n let i;\n for (i in MP4.types) {\n if (MP4.types.hasOwnProperty(i)) {\n MP4.types[i] = [\n i.charCodeAt(0),\n i.charCodeAt(1),\n i.charCodeAt(2),\n i.charCodeAt(3)\n ];\n }\n }\n\n let videoHdlr = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x76, 0x69, 0x64, 0x65, // handler_type: 'vide'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x56, 0x69, 0x64, 0x65,\n 0x6f, 0x48, 0x61, 0x6e,\n 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'VideoHandler'\n ]);\n\n let audioHdlr = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x73, 0x6f, 0x75, 0x6e, // handler_type: 'soun'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x53, 0x6f, 0x75, 0x6e,\n 0x64, 0x48, 0x61, 0x6e,\n 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'SoundHandler'\n ]);\n\n MP4.HDLR_TYPES = {\n 'video': videoHdlr,\n 'audio': audioHdlr\n };\n\n let dref = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01, // entry_count\n 0x00, 0x00, 0x00, 0x0c, // entry_size\n 0x75, 0x72, 0x6c, 0x20, // 'url' type\n 0x00, // version 0\n 0x00, 0x00, 0x01 // entry_flags\n ]);\n\n let stco = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00 // entry_count\n ]);\n\n MP4.STTS = MP4.STSC = MP4.STCO = stco;\n\n MP4.STSZ = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // sample_size\n 0x00, 0x00, 0x00, 0x00 // sample_count\n ]);\n MP4.VMHD = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x01, // flags\n 0x00, 0x00, // graphicsmode\n 0x00, 0x00,\n 0x00, 0x00,\n 0x00, 0x00 // opcolor\n ]);\n MP4.SMHD = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, // balance\n 0x00, 0x00 // reserved\n ]);\n\n MP4.STSD = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01]);// entry_count\n\n let majorBrand = new Uint8Array([105, 115, 111, 109]); // isom\n let avc1Brand = new Uint8Array([97, 118, 99, 49]); // avc1\n let minorVersion = new Uint8Array([0, 0, 0, 1]);\n\n MP4.FTYP = MP4.box(MP4.types.ftyp, majorBrand, minorVersion, majorBrand, avc1Brand);\n MP4.DINF = MP4.box(MP4.types.dinf, MP4.box(MP4.types.dref, dref));\n }\n\n static box (type) {\n let\n payload = Array.prototype.slice.call(arguments, 1),\n size = 8,\n i = payload.length,\n len = i,\n result;\n // calculate the total size we need to allocate\n while (i--) {\n size += payload[i].byteLength;\n }\n\n result = new Uint8Array(size);\n result[0] = (size >> 24) & 0xff;\n result[1] = (size >> 16) & 0xff;\n result[2] = (size >> 8) & 0xff;\n result[3] = size & 0xff;\n result.set(type, 4);\n // copy the payload into the result\n for (i = 0, size = 8; i < len; i++) {\n // copy payload[i] array @ offset size\n result.set(payload[i], size);\n size += payload[i].byteLength;\n }\n return result;\n }\n\n static hdlr (type) {\n return MP4.box(MP4.types.hdlr, MP4.HDLR_TYPES[type]);\n }\n\n static mdat (data) {\n return MP4.box(MP4.types.mdat, data);\n }\n\n static mdhd (timescale, duration) {\n duration *= timescale;\n const upperWordDuration = Math.floor(duration / (UINT32_MAX + 1));\n const lowerWordDuration = Math.floor(duration % (UINT32_MAX + 1));\n return MP4.box(MP4.types.mdhd, new Uint8Array([\n 0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, // modification_time\n (timescale >> 24) & 0xFF,\n (timescale >> 16) & 0xFF,\n (timescale >> 8) & 0xFF,\n timescale & 0xFF, // timescale\n (upperWordDuration >> 24),\n (upperWordDuration >> 16) & 0xFF,\n (upperWordDuration >> 8) & 0xFF,\n upperWordDuration & 0xFF,\n (lowerWordDuration >> 24),\n (lowerWordDuration >> 16) & 0xFF,\n (lowerWordDuration >> 8) & 0xFF,\n lowerWordDuration & 0xFF,\n 0x55, 0xc4, // 'und' language (undetermined)\n 0x00, 0x00\n ]));\n }\n\n static mdia (track) {\n return MP4.box(MP4.types.mdia, MP4.mdhd(track.timescale, track.duration), MP4.hdlr(track.type), MP4.minf(track));\n }\n\n static mfhd (sequenceNumber) {\n return MP4.box(MP4.types.mfhd, new Uint8Array([\n 0x00,\n 0x00, 0x00, 0x00, // flags\n (sequenceNumber >> 24),\n (sequenceNumber >> 16) & 0xFF,\n (sequenceNumber >> 8) & 0xFF,\n sequenceNumber & 0xFF // sequence_number\n ]));\n }\n\n static minf (track) {\n if (track.type === 'audio') {\n return MP4.box(MP4.types.minf, MP4.box(MP4.types.smhd, MP4.SMHD), MP4.DINF, MP4.stbl(track));\n } else {\n return MP4.box(MP4.types.minf, MP4.box(MP4.types.vmhd, MP4.VMHD), MP4.DINF, MP4.stbl(track));\n }\n }\n\n static moof (sn, baseMediaDecodeTime, track) {\n return MP4.box(MP4.types.moof, MP4.mfhd(sn), MP4.traf(track, baseMediaDecodeTime));\n }\n /**\n * @param tracks... (optional) {array} the tracks associated with this movie\n */\n static moov (tracks) {\n let\n i = tracks.length,\n boxes = [];\n\n while (i--) {\n boxes[i] = MP4.trak(tracks[i]);\n }\n\n return MP4.box.apply(null, [MP4.types.moov, MP4.mvhd(tracks[0].timescale, tracks[0].duration)].concat(boxes).concat(MP4.mvex(tracks)));\n }\n\n static mvex (tracks) {\n let\n i = tracks.length,\n boxes = [];\n\n while (i--) {\n boxes[i] = MP4.trex(tracks[i]);\n }\n\n return MP4.box.apply(null, [MP4.types.mvex].concat(boxes));\n }\n\n static mvhd (timescale, duration) {\n duration *= timescale;\n const upperWordDuration = Math.floor(duration / (UINT32_MAX + 1));\n const lowerWordDuration = Math.floor(duration % (UINT32_MAX + 1));\n let\n bytes = new Uint8Array([\n 0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, // modification_time\n (timescale >> 24) & 0xFF,\n (timescale >> 16) & 0xFF,\n (timescale >> 8) & 0xFF,\n timescale & 0xFF, // timescale\n (upperWordDuration >> 24),\n (upperWordDuration >> 16) & 0xFF,\n (upperWordDuration >> 8) & 0xFF,\n upperWordDuration & 0xFF,\n (lowerWordDuration >> 24),\n (lowerWordDuration >> 16) & 0xFF,\n (lowerWordDuration >> 8) & 0xFF,\n lowerWordDuration & 0xFF,\n 0x00, 0x01, 0x00, 0x00, // 1.0 rate\n 0x01, 0x00, // 1.0 volume\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0xff, 0xff, 0xff, 0xff // next_track_ID\n ]);\n return MP4.box(MP4.types.mvhd, bytes);\n }\n\n static sdtp (track) {\n let\n samples = track.samples || [],\n bytes = new Uint8Array(4 + samples.length),\n flags,\n i;\n // leave the full box header (4 bytes) all zero\n // write the sample table\n for (i = 0; i < samples.length; i++) {\n flags = samples[i].flags;\n bytes[i + 4] = (flags.dependsOn << 4) |\n (flags.isDependedOn << 2) |\n (flags.hasRedundancy);\n }\n\n return MP4.box(MP4.types.sdtp, bytes);\n }\n\n static stbl (track) {\n return MP4.box(MP4.types.stbl, MP4.stsd(track), MP4.box(MP4.types.stts, MP4.STTS), MP4.box(MP4.types.stsc, MP4.STSC), MP4.box(MP4.types.stsz, MP4.STSZ), MP4.box(MP4.types.stco, MP4.STCO));\n }\n\n static avc1 (track) {\n let sps = [], pps = [], i, data, len;\n // assemble the SPSs\n\n for (i = 0; i < track.sps.length; i++) {\n data = track.sps[i];\n len = data.byteLength;\n sps.push((len >>> 8) & 0xFF);\n sps.push((len & 0xFF));\n\n // SPS\n sps = sps.concat(Array.prototype.slice.call(data));\n }\n\n // assemble the PPSs\n for (i = 0; i < track.pps.length; i++) {\n data = track.pps[i];\n len = data.byteLength;\n pps.push((len >>> 8) & 0xFF);\n pps.push((len & 0xFF));\n\n pps = pps.concat(Array.prototype.slice.call(data));\n }\n\n let avcc = MP4.box(MP4.types.avcC, new Uint8Array([\n 0x01, // version\n sps[3], // profile\n sps[4], // profile compat\n sps[5], // level\n 0xfc | 3, // lengthSizeMinusOne, hard-coded to 4 bytes\n 0xE0 | track.sps.length // 3bit reserved (111) + numOfSequenceParameterSets\n ].concat(sps).concat([\n track.pps.length // numOfPictureParameterSets\n ]).concat(pps))), // \"PPS\"\n width = track.width,\n height = track.height,\n hSpacing = track.pixelRatio[0],\n vSpacing = track.pixelRatio[1];\n\n return MP4.box(MP4.types.avc1, new Uint8Array([\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, // pre_defined\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n (width >> 8) & 0xFF,\n width & 0xff, // width\n (height >> 8) & 0xFF,\n height & 0xff, // height\n 0x00, 0x48, 0x00, 0x00, // horizresolution\n 0x00, 0x48, 0x00, 0x00, // vertresolution\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // frame_count\n 0x12,\n 0x64, 0x61, 0x69, 0x6C, // dailymotion/hls.js\n 0x79, 0x6D, 0x6F, 0x74,\n 0x69, 0x6F, 0x6E, 0x2F,\n 0x68, 0x6C, 0x73, 0x2E,\n 0x6A, 0x73, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, // compressorname\n 0x00, 0x18, // depth = 24\n 0x11, 0x11]), // pre_defined = -1\n avcc,\n MP4.box(MP4.types.btrt, new Uint8Array([\n 0x00, 0x1c, 0x9c, 0x80, // bufferSizeDB\n 0x00, 0x2d, 0xc6, 0xc0, // maxBitrate\n 0x00, 0x2d, 0xc6, 0xc0])), // avgBitrate\n MP4.box(MP4.types.pasp, new Uint8Array([\n (hSpacing >> 24), // hSpacing\n (hSpacing >> 16) & 0xFF,\n (hSpacing >> 8) & 0xFF,\n hSpacing & 0xFF,\n (vSpacing >> 24), // vSpacing\n (vSpacing >> 16) & 0xFF,\n (vSpacing >> 8) & 0xFF,\n vSpacing & 0xFF]))\n );\n }\n\n static esds (track) {\n let configlen = track.config.length;\n return new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n\n 0x03, // descriptor_type\n 0x17 + configlen, // length\n 0x00, 0x01, // es_id\n 0x00, // stream_priority\n\n 0x04, // descriptor_type\n 0x0f + configlen, // length\n 0x40, // codec : mpeg4_audio\n 0x15, // stream_type\n 0x00, 0x00, 0x00, // buffer_size\n 0x00, 0x00, 0x00, 0x00, // maxBitrate\n 0x00, 0x00, 0x00, 0x00, // avgBitrate\n\n 0x05 // descriptor_type\n ].concat([configlen]).concat(track.config).concat([0x06, 0x01, 0x02])); // GASpecificConfig)); // length + audio config descriptor\n }\n\n static mp4a (track) {\n let samplerate = track.samplerate;\n return MP4.box(MP4.types.mp4a, new Uint8Array([\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, track.channelCount, // channelcount\n 0x00, 0x10, // sampleSize:16bits\n 0x00, 0x00, 0x00, 0x00, // reserved2\n (samplerate >> 8) & 0xFF,\n samplerate & 0xff, //\n 0x00, 0x00]),\n MP4.box(MP4.types.esds, MP4.esds(track)));\n }\n\n static mp3 (track) {\n let samplerate = track.samplerate;\n return MP4.box(MP4.types['.mp3'], new Uint8Array([\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, track.channelCount, // channelcount\n 0x00, 0x10, // sampleSize:16bits\n 0x00, 0x00, 0x00, 0x00, // reserved2\n (samplerate >> 8) & 0xFF,\n samplerate & 0xff, //\n 0x00, 0x00]));\n }\n\n static stsd (track) {\n if (track.type === 'audio') {\n if (!track.isAAC && track.codec === 'mp3') {\n return MP4.box(MP4.types.stsd, MP4.STSD, MP4.mp3(track));\n }\n\n return MP4.box(MP4.types.stsd, MP4.STSD, MP4.mp4a(track));\n } else {\n return MP4.box(MP4.types.stsd, MP4.STSD, MP4.avc1(track));\n }\n }\n\n static tkhd (track) {\n let id = track.id,\n duration = track.duration * track.timescale,\n width = track.width,\n height = track.height,\n upperWordDuration = Math.floor(duration / (UINT32_MAX + 1)),\n lowerWordDuration = Math.floor(duration % (UINT32_MAX + 1));\n return MP4.box(MP4.types.tkhd, new Uint8Array([\n 0x01, // version 1\n 0x00, 0x00, 0x07, // flags\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, // modification_time\n (id >> 24) & 0xFF,\n (id >> 16) & 0xFF,\n (id >> 8) & 0xFF,\n id & 0xFF, // track_ID\n 0x00, 0x00, 0x00, 0x00, // reserved\n (upperWordDuration >> 24),\n (upperWordDuration >> 16) & 0xFF,\n (upperWordDuration >> 8) & 0xFF,\n upperWordDuration & 0xFF,\n (lowerWordDuration >> 24),\n (lowerWordDuration >> 16) & 0xFF,\n (lowerWordDuration >> 8) & 0xFF,\n lowerWordDuration & 0xFF,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, // layer\n 0x00, 0x00, // alternate_group\n 0x00, 0x00, // non-audio track volume\n 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n (width >> 8) & 0xFF,\n width & 0xFF,\n 0x00, 0x00, // width\n (height >> 8) & 0xFF,\n height & 0xFF,\n 0x00, 0x00 // height\n ]));\n }\n\n static traf (track, baseMediaDecodeTime) {\n let sampleDependencyTable = MP4.sdtp(track),\n id = track.id,\n upperWordBaseMediaDecodeTime = Math.floor(baseMediaDecodeTime / (UINT32_MAX + 1)),\n lowerWordBaseMediaDecodeTime = Math.floor(baseMediaDecodeTime % (UINT32_MAX + 1));\n return MP4.box(MP4.types.traf,\n MP4.box(MP4.types.tfhd, new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n (id >> 24),\n (id >> 16) & 0XFF,\n (id >> 8) & 0XFF,\n (id & 0xFF) // track_ID\n ])),\n MP4.box(MP4.types.tfdt, new Uint8Array([\n 0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n (upperWordBaseMediaDecodeTime >> 24),\n (upperWordBaseMediaDecodeTime >> 16) & 0XFF,\n (upperWordBaseMediaDecodeTime >> 8) & 0XFF,\n (upperWordBaseMediaDecodeTime & 0xFF),\n (lowerWordBaseMediaDecodeTime >> 24),\n (lowerWordBaseMediaDecodeTime >> 16) & 0XFF,\n (lowerWordBaseMediaDecodeTime >> 8) & 0XFF,\n (lowerWordBaseMediaDecodeTime & 0xFF)\n ])),\n MP4.trun(track,\n sampleDependencyTable.length +\n 16 + // tfhd\n 20 + // tfdt\n 8 + // traf header\n 16 + // mfhd\n 8 + // moof header\n 8), // mdat header\n sampleDependencyTable);\n }\n\n /**\n * Generate a track box.\n * @param track {object} a track definition\n * @return {Uint8Array} the track box\n */\n static trak (track) {\n track.duration = track.duration || 0xffffffff;\n return MP4.box(MP4.types.trak, MP4.tkhd(track), MP4.mdia(track));\n }\n\n static trex (track) {\n let id = track.id;\n return MP4.box(MP4.types.trex, new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n (id >> 24),\n (id >> 16) & 0XFF,\n (id >> 8) & 0XFF,\n (id & 0xFF), // track_ID\n 0x00, 0x00, 0x00, 0x01, // default_sample_description_index\n 0x00, 0x00, 0x00, 0x00, // default_sample_duration\n 0x00, 0x00, 0x00, 0x00, // default_sample_size\n 0x00, 0x01, 0x00, 0x01 // default_sample_flags\n ]));\n }\n\n static trun (track, offset) {\n let samples = track.samples || [],\n len = samples.length,\n arraylen = 12 + (16 * len),\n array = new Uint8Array(arraylen),\n i, sample, duration, size, flags, cts;\n offset += 8 + arraylen;\n array.set([\n 0x00, // version 0\n 0x00, 0x0f, 0x01, // flags\n (len >>> 24) & 0xFF,\n (len >>> 16) & 0xFF,\n (len >>> 8) & 0xFF,\n len & 0xFF, // sample_count\n (offset >>> 24) & 0xFF,\n (offset >>> 16) & 0xFF,\n (offset >>> 8) & 0xFF,\n offset & 0xFF // data_offset\n ], 0);\n for (i = 0; i < len; i++) {\n sample = samples[i];\n duration = sample.duration;\n size = sample.size;\n flags = sample.flags;\n cts = sample.cts;\n array.set([\n (duration >>> 24) & 0xFF,\n (duration >>> 16) & 0xFF,\n (duration >>> 8) & 0xFF,\n duration & 0xFF, // sample_duration\n (size >>> 24) & 0xFF,\n (size >>> 16) & 0xFF,\n (size >>> 8) & 0xFF,\n size & 0xFF, // sample_size\n (flags.isLeading << 2) | flags.dependsOn,\n (flags.isDependedOn << 6) |\n (flags.hasRedundancy << 4) |\n (flags.paddingValue << 1) |\n flags.isNonSync,\n flags.degradPrio & 0xF0 << 8,\n flags.degradPrio & 0x0F, // sample_flags\n (cts >>> 24) & 0xFF,\n (cts >>> 16) & 0xFF,\n (cts >>> 8) & 0xFF,\n cts & 0xFF // sample_composition_time_offset\n ], 12 + 16 * i);\n }\n return MP4.box(MP4.types.trun, array);\n }\n\n static initSegment (tracks) {\n if (!MP4.types) {\n MP4.init();\n }\n\n let movie = MP4.moov(tracks), result;\n result = new Uint8Array(MP4.FTYP.byteLength + movie.byteLength);\n result.set(MP4.FTYP);\n result.set(movie, MP4.FTYP.byteLength);\n return result;\n }\n}\n\nexport default MP4;\n","const MPEG_TS_CLOCK_FREQ_HZ = 90000;\n\nexport function toTimescaleFromScale (value, destScale: number, srcScale: number = 1, round: boolean = false): number {\n return toTimescaleFromBase(value, destScale, 1 / srcScale);\n}\n\nexport function toTimescaleFromBase (value, destScale: number, srcBase: number = 1, round: boolean = false): number {\n const result = value * destScale * srcBase; // equivalent to `(value * scale) / (1 / base)`\n return round ? Math.round(result) : result;\n}\n\nexport function toMsFromMpegTsClock (value: number, round: boolean = false): number {\n return toTimescaleFromBase(value, 1000, 1 / MPEG_TS_CLOCK_FREQ_HZ, round);\n}\n\nexport function toMpegTsClockFromTimescale (value: number, srcScale: number = 1): number {\n return toTimescaleFromBase(value, MPEG_TS_CLOCK_FREQ_HZ, 1 / srcScale);\n}\n","/**\n * fMP4 remuxer\n*/\n\nimport AAC from './aac-helper';\nimport MP4 from './mp4-generator';\n\nimport Event from '../events';\nimport { ErrorTypes, ErrorDetails } from '../errors';\n\nimport { toMsFromMpegTsClock, toMpegTsClockFromTimescale } from '../utils/timescale-conversion';\n\nimport { logger } from '../utils/logger';\n\nconst MAX_SILENT_FRAME_DURATION_90KHZ = toMpegTsClockFromTimescale(10);\nconst PTS_DTS_SHIFT_TOLERANCE_90KHZ = toMpegTsClockFromTimescale(0.2);\n\nlet chromeVersion = null;\n\nclass MP4Remuxer {\n constructor (observer, config, typeSupported, vendor) {\n this.observer = observer;\n this.config = config;\n this.typeSupported = typeSupported;\n this.ISGenerated = false;\n if (chromeVersion === null) {\n const result = navigator.userAgent.match(/Chrome\\/(\\d+)/i);\n chromeVersion = result ? parseInt(result[1]) : 0;\n }\n }\n\n destroy () {\n }\n\n resetTimeStamp (defaultTimeStamp) {\n this._initPTS = this._initDTS = defaultTimeStamp;\n }\n\n resetInitSegment () {\n this.ISGenerated = false;\n }\n\n getVideoStartPts (videoSamples) {\n let rolloverDetected = false;\n const startPTS = videoSamples.reduce((minPTS, sample) => {\n const delta = sample.pts - minPTS;\n if (delta < -4294967296) { // 2^32, see PTSNormalize for reasoning, but we're hitting a rollover here, and we don't want that to impact the timeOffset calculation\n rolloverDetected = true;\n return PTSNormalize(minPTS, sample.pts);\n } else if (delta > 0) {\n return minPTS;\n } else {\n return sample.pts;\n }\n }, videoSamples[0].pts);\n if (rolloverDetected) {\n logger.debug('PTS rollover detected');\n }\n return startPTS;\n }\n\n remux (audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset) {\n // generate Init Segment if needed\n if (!this.ISGenerated) {\n this.generateIS(audioTrack, videoTrack, timeOffset);\n }\n\n if (this.ISGenerated) {\n const nbAudioSamples = audioTrack.samples.length;\n const nbVideoSamples = videoTrack.samples.length;\n let audioTimeOffset = timeOffset;\n let videoTimeOffset = timeOffset;\n if (nbAudioSamples && nbVideoSamples) {\n // timeOffset is expected to be the offset of the first timestamp of this fragment (first DTS)\n // if first audio DTS is not aligned with first video DTS then we need to take that into account\n // when providing timeOffset to remuxAudio / remuxVideo. if we don't do that, there might be a permanent / small\n // drift between audio and video streams\n const startPTS = this.getVideoStartPts(videoTrack.samples);\n const tsDelta = PTSNormalize(audioTrack.samples[0].pts, startPTS) - startPTS;\n const audiovideoTimestampDelta = tsDelta / videoTrack.inputTimeScale;\n audioTimeOffset += Math.max(0, audiovideoTimestampDelta);\n videoTimeOffset += Math.max(0, -audiovideoTimestampDelta);\n }\n // Purposefully remuxing audio before video, so that remuxVideo can use nextAudioPts, which is\n // calculated in remuxAudio.\n // logger.log('nb AAC samples:' + audioTrack.samples.length);\n if (nbAudioSamples) {\n // if initSegment was generated without video samples, regenerate it again\n if (!audioTrack.timescale) {\n logger.warn('regenerate InitSegment as audio detected');\n this.generateIS(audioTrack, videoTrack, timeOffset);\n }\n let audioData = this.remuxAudio(audioTrack, audioTimeOffset, contiguous, accurateTimeOffset);\n // logger.log('nb AVC samples:' + videoTrack.samples.length);\n if (nbVideoSamples) {\n let audioTrackLength;\n if (audioData) {\n audioTrackLength = audioData.endPTS - audioData.startPTS;\n }\n\n // if initSegment was generated without video samples, regenerate it again\n if (!videoTrack.timescale) {\n logger.warn('regenerate InitSegment as video detected');\n this.generateIS(audioTrack, videoTrack, timeOffset);\n }\n this.remuxVideo(videoTrack, videoTimeOffset, contiguous, audioTrackLength);\n }\n } else {\n // logger.log('nb AVC samples:' + videoTrack.samples.length);\n if (nbVideoSamples) {\n let videoData = this.remuxVideo(videoTrack, videoTimeOffset, contiguous, 0, accurateTimeOffset);\n if (videoData && audioTrack.codec) {\n this.remuxEmptyAudio(audioTrack, audioTimeOffset, contiguous, videoData);\n }\n }\n }\n }\n // logger.log('nb ID3 samples:' + audioTrack.samples.length);\n if (id3Track.samples.length) {\n this.remuxID3(id3Track, timeOffset);\n }\n\n // logger.log('nb ID3 samples:' + audioTrack.samples.length);\n if (textTrack.samples.length) {\n this.remuxText(textTrack, timeOffset);\n }\n\n // notify end of parsing\n this.observer.trigger(Event.FRAG_PARSED);\n }\n\n generateIS (audioTrack, videoTrack, timeOffset) {\n let observer = this.observer,\n audioSamples = audioTrack.samples,\n videoSamples = videoTrack.samples,\n typeSupported = this.typeSupported,\n container = 'audio/mp4',\n tracks = {},\n data = { tracks },\n computePTSDTS = (this._initPTS === undefined),\n initPTS, initDTS;\n\n if (computePTSDTS) {\n initPTS = initDTS = Infinity;\n }\n\n if (audioTrack.config && audioSamples.length) {\n // let's use audio sampling rate as MP4 time scale.\n // rationale is that there is a integer nb of audio frames per audio sample (1024 for AAC)\n // using audio sampling rate here helps having an integer MP4 frame duration\n // this avoids potential rounding issue and AV sync issue\n audioTrack.timescale = audioTrack.samplerate;\n logger.log(`audio sampling rate : ${audioTrack.samplerate}`);\n if (!audioTrack.isAAC) {\n if (typeSupported.mpeg) { // Chrome and Safari\n container = 'audio/mpeg';\n audioTrack.codec = '';\n } else if (typeSupported.mp3) { // Firefox\n audioTrack.codec = 'mp3';\n }\n }\n tracks.audio = {\n container: container,\n codec: audioTrack.codec,\n initSegment: !audioTrack.isAAC && typeSupported.mpeg ? new Uint8Array() : MP4.initSegment([audioTrack]),\n metadata: {\n channelCount: audioTrack.channelCount\n }\n };\n if (computePTSDTS) {\n // remember first PTS of this demuxing context. for audio, PTS = DTS\n initPTS = initDTS = audioSamples[0].pts - Math.round(audioTrack.inputTimeScale * timeOffset);\n }\n }\n\n if (videoTrack.sps && videoTrack.pps && videoSamples.length) {\n // let's use input time scale as MP4 video timescale\n // we use input time scale straight away to avoid rounding issues on frame duration / cts computation\n const inputTimeScale = videoTrack.inputTimeScale;\n videoTrack.timescale = inputTimeScale;\n tracks.video = {\n container: 'video/mp4',\n codec: videoTrack.codec,\n initSegment: MP4.initSegment([videoTrack]),\n metadata: {\n width: videoTrack.width,\n height: videoTrack.height\n }\n };\n if (computePTSDTS) {\n const startPTS = this.getVideoStartPts(videoSamples);\n const startOffset = Math.round(inputTimeScale * timeOffset);\n initDTS = Math.min(initDTS, PTSNormalize(videoSamples[0].dts, startPTS) - startOffset);\n initPTS = Math.min(initPTS, startPTS - startOffset);\n this.observer.trigger(Event.INIT_PTS_FOUND, { initPTS });\n }\n } else if (computePTSDTS && tracks.audio) {\n // initPTS found for audio-only stream with main and alt audio\n this.observer.trigger(Event.INIT_PTS_FOUND, { initPTS });\n }\n\n if (Object.keys(tracks).length) {\n observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT, data);\n this.ISGenerated = true;\n if (computePTSDTS) {\n this._initPTS = initPTS;\n this._initDTS = initDTS;\n }\n } else {\n observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: false, reason: 'no audio/video samples found' });\n }\n }\n\n remuxVideo (track, timeOffset, contiguous, audioTrackLength) {\n const timeScale = track.timescale;\n const inputSamples = track.samples;\n const outputSamples = [];\n const nbSamples = inputSamples.length;\n const initPTS = this._initPTS;\n\n let offset = 8;\n let mp4SampleDuration;\n let mdat;\n let moof;\n let firstDTS;\n let lastDTS;\n let minPTS = Number.POSITIVE_INFINITY;\n let maxPTS = Number.NEGATIVE_INFINITY;\n let ptsDtsShift = 0;\n let sortSamples = false;\n\n // if parsed fragment is contiguous with last one, let's use last DTS value as reference\n let nextAvcDts = this.nextAvcDts;\n\n if (nbSamples === 0) {\n return;\n }\n\n if (!contiguous) {\n const pts = timeOffset * timeScale;\n const cts = inputSamples[0].pts - PTSNormalize(inputSamples[0].dts, inputSamples[0].pts);\n // if not contiguous, let's use target timeOffset\n nextAvcDts = pts - cts;\n }\n\n // PTS is coded on 33bits, and can loop from -2^32 to 2^32\n // PTSNormalize will make PTS/DTS value monotonic, we use last known DTS value as reference value\n for (let i = 0; i < nbSamples; i++) {\n const sample = inputSamples[i];\n sample.pts = PTSNormalize(sample.pts - initPTS, nextAvcDts);\n sample.dts = PTSNormalize(sample.dts - initPTS, nextAvcDts);\n if (sample.dts > sample.pts) {\n ptsDtsShift = Math.max(Math.min(ptsDtsShift, sample.pts - sample.dts), -1 * PTS_DTS_SHIFT_TOLERANCE_90KHZ);\n }\n if (sample.dts < inputSamples[i > 0 ? i - 1 : i].dts) {\n sortSamples = true;\n }\n }\n\n // sort video samples by DTS then PTS then demux id order\n if (sortSamples) {\n inputSamples.sort(function (a, b) {\n const deltadts = a.dts - b.dts;\n const deltapts = a.pts - b.pts;\n return deltadts || (deltapts || (a.id - b.id));\n });\n }\n\n // Get first/last DTS\n firstDTS = inputSamples[0].dts;\n lastDTS = inputSamples[nbSamples - 1].dts;\n\n // on Safari let's signal the same sample duration for all samples\n // sample duration (as expected by trun MP4 boxes), should be the delta between sample DTS\n // set this constant duration as being the avg delta between consecutive DTS.\n const averageSampleDuration = Math.round((lastDTS - firstDTS) / (nbSamples - 1));\n\n // handle broken streams with PTS < DTS, tolerance up 0.2 seconds\n if (ptsDtsShift < 0) {\n if (ptsDtsShift < averageSampleDuration * -2) {\n // Fix for \"CNN special report, with CC\" in test-streams (including Safari browser)\n // With large PTS < DTS errors such as this, we want to correct CTS while maintaining increasing DTS values\n logger.warn(`PTS < DTS detected in video samples, offsetting DTS from PTS by ${toMsFromMpegTsClock(-averageSampleDuration, true)} ms`);\n let lastDts = ptsDtsShift;\n for (let i = 0; i < nbSamples; i++) {\n inputSamples[i].dts = lastDts = Math.max(lastDts, inputSamples[i].pts - averageSampleDuration);\n inputSamples[i].pts = Math.max(lastDts, inputSamples[i].pts);\n }\n } else {\n // Fix for \"Custom IV with bad PTS DTS\" in test-streams\n // With smaller PTS < DTS errors we can simply move all DTS back. This increases CTS without causing buffer gaps or decode errors in Safari\n logger.warn(`PTS < DTS detected in video samples, shifting DTS by ${toMsFromMpegTsClock(ptsDtsShift, true)} ms to overcome this issue`);\n for (let i = 0; i < nbSamples; i++) {\n inputSamples[i].dts = inputSamples[i].dts + ptsDtsShift;\n }\n }\n firstDTS = inputSamples[0].dts;\n lastDTS = inputSamples[nbSamples - 1].dts;\n }\n\n // if fragment are contiguous, detect hole/overlapping between fragments\n if (contiguous) {\n // check timestamp continuity across consecutive fragments (this is to remove inter-fragment gap/hole)\n const delta = firstDTS - nextAvcDts;\n const foundHole = delta > averageSampleDuration;\n const foundOverlap = delta < -1;\n if (foundHole || foundOverlap) {\n if (foundHole) {\n logger.warn(`AVC: ${toMsFromMpegTsClock(delta, true)} ms (${delta}dts) hole between fragments detected, filling it`);\n } else {\n logger.warn(`AVC: ${toMsFromMpegTsClock(-delta, true)} ms (${delta}dts) overlapping between fragments detected`);\n }\n firstDTS = nextAvcDts;\n const firstPTS = inputSamples[0].pts - delta;\n inputSamples[0].dts = firstDTS;\n inputSamples[0].pts = firstPTS;\n logger.log(`Video: First PTS/DTS adjusted: ${toMsFromMpegTsClock(firstPTS, true)}/${toMsFromMpegTsClock(firstDTS, true)}, delta: ${toMsFromMpegTsClock(delta, true)} ms`);\n }\n }\n\n if (chromeVersion && chromeVersion < 75) {\n firstDTS = Math.max(0, firstDTS);\n }\n let nbNalu = 0;\n let naluLen = 0;\n for (let i = 0; i < nbSamples; i++) {\n // compute total/avc sample length and nb of NAL units\n const sample = inputSamples[i];\n const units = sample.units;\n const nbUnits = units.length;\n let sampleLen = 0;\n for (let j = 0; j < nbUnits; j++) {\n sampleLen += units[j].data.length;\n }\n\n naluLen += sampleLen;\n nbNalu += nbUnits;\n sample.length = sampleLen;\n\n // normalize PTS/DTS\n // ensure sample monotonic DTS\n sample.dts = Math.max(sample.dts, firstDTS);\n // ensure that computed value is greater or equal than sample DTS\n sample.pts = Math.max(sample.pts, sample.dts, 0);\n minPTS = Math.min(sample.pts, minPTS);\n maxPTS = Math.max(sample.pts, maxPTS);\n }\n lastDTS = inputSamples[nbSamples - 1].dts;\n\n /* concatenate the video data and construct the mdat in place\n (need 8 more bytes to fill length and mpdat type) */\n let mdatSize = naluLen + (4 * nbNalu) + 8;\n try {\n mdat = new Uint8Array(mdatSize);\n } catch (err) {\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MUX_ERROR, details: ErrorDetails.REMUX_ALLOC_ERROR, fatal: false, bytes: mdatSize, reason: `fail allocating video mdat ${mdatSize}` });\n return;\n }\n let view = new DataView(mdat.buffer);\n view.setUint32(0, mdatSize);\n mdat.set(MP4.types.mdat, 4);\n\n for (let i = 0; i < nbSamples; i++) {\n const avcSample = inputSamples[i];\n const avcSampleUnits = avcSample.units;\n let mp4SampleLength = 0;\n let compositionTimeOffset;\n // convert NALU bitstream to MP4 format (prepend NALU with size field)\n for (let j = 0, nbUnits = avcSampleUnits.length; j < nbUnits; j++) {\n const unit = avcSampleUnits[j];\n const unitData = unit.data;\n const unitDataLen = unit.data.byteLength;\n view.setUint32(offset, unitDataLen);\n offset += 4;\n mdat.set(unitData, offset);\n offset += unitDataLen;\n mp4SampleLength += 4 + unitDataLen;\n }\n\n // expected sample duration is the Decoding Timestamp diff of consecutive samples\n if (i < nbSamples - 1) {\n mp4SampleDuration = inputSamples[i + 1].dts - avcSample.dts;\n } else {\n const config = this.config;\n const lastFrameDuration = avcSample.dts - inputSamples[i > 0 ? i - 1 : i].dts;\n if (config.stretchShortVideoTrack) {\n // In some cases, a segment's audio track duration may exceed the video track duration.\n // Since we've already remuxed audio, and we know how long the audio track is, we look to\n // see if the delta to the next segment is longer than maxBufferHole.\n // If so, playback would potentially get stuck, so we artificially inflate\n // the duration of the last frame to minimize any potential gap between segments.\n const maxBufferHole = config.maxBufferHole;\n const gapTolerance = Math.floor(maxBufferHole * timeScale);\n const deltaToFrameEnd = (audioTrackLength ? minPTS + audioTrackLength * timeScale : this.nextAudioPts) - avcSample.pts;\n if (deltaToFrameEnd > gapTolerance) {\n // We subtract lastFrameDuration from deltaToFrameEnd to try to prevent any video\n // frame overlap. maxBufferHole should be >> lastFrameDuration anyway.\n mp4SampleDuration = deltaToFrameEnd - lastFrameDuration;\n if (mp4SampleDuration < 0) {\n mp4SampleDuration = lastFrameDuration;\n }\n\n logger.log(`It is approximately ${toMsFromMpegTsClock(deltaToFrameEnd, false)} ms to the next segment; using duration ${toMsFromMpegTsClock(mp4SampleDuration, false)} ms for the last video frame.`);\n } else {\n mp4SampleDuration = lastFrameDuration;\n }\n } else {\n mp4SampleDuration = lastFrameDuration;\n }\n }\n compositionTimeOffset = Math.round(avcSample.pts - avcSample.dts);\n\n // console.log('PTS/DTS/initDTS/normPTS/normDTS/relative PTS : ${avcSample.pts}/${avcSample.dts}/${initDTS}/${ptsnorm}/${dtsnorm}/${(avcSample.pts/4294967296).toFixed(3)}');\n outputSamples.push({\n size: mp4SampleLength,\n // constant duration\n duration: mp4SampleDuration,\n cts: compositionTimeOffset,\n flags: {\n isLeading: 0,\n isDependedOn: 0,\n hasRedundancy: 0,\n degradPrio: 0,\n dependsOn: avcSample.key ? 2 : 1,\n isNonSync: avcSample.key ? 0 : 1\n }\n });\n }\n // next AVC sample DTS should be equal to last sample DTS + last sample duration (in PES timescale)\n this.nextAvcDts = lastDTS + mp4SampleDuration;\n const dropped = track.dropped;\n track.nbNalu = 0;\n track.dropped = 0;\n if (outputSamples.length && navigator.userAgent.toLowerCase().indexOf('chrome') > -1) {\n const flags = outputSamples[0].flags;\n // chrome workaround, mark first sample as being a Random Access Point to avoid sourcebuffer append issue\n // https://code.google.com/p/chromium/issues/detail?id=229412\n flags.dependsOn = 2;\n flags.isNonSync = 0;\n }\n track.samples = outputSamples;\n moof = MP4.moof(track.sequenceNumber++, firstDTS, track);\n track.samples = [];\n\n const data = {\n data1: moof,\n data2: mdat,\n startPTS: minPTS / timeScale,\n endPTS: (maxPTS + mp4SampleDuration) / timeScale,\n startDTS: firstDTS / timeScale,\n endDTS: this.nextAvcDts / timeScale,\n type: 'video',\n hasAudio: false,\n hasVideo: true,\n nb: outputSamples.length,\n dropped: dropped\n };\n this.observer.trigger(Event.FRAG_PARSING_DATA, data);\n return data;\n }\n\n remuxAudio (track, timeOffset, contiguous, accurateTimeOffset) {\n const inputTimeScale = track.inputTimeScale;\n const mp4timeScale = track.timescale;\n const scaleFactor = inputTimeScale / mp4timeScale;\n const mp4SampleDuration = track.isAAC ? 1024 : 1152;\n const inputSampleDuration = mp4SampleDuration * scaleFactor;\n const initPTS = this._initPTS;\n const rawMPEG = !track.isAAC && this.typeSupported.mpeg;\n\n let mp4Sample;\n let fillFrame;\n let mdat;\n let moof;\n let firstPTS;\n let lastPTS;\n let offset = (rawMPEG ? 0 : 8);\n let inputSamples = track.samples;\n let outputSamples = [];\n let nextAudioPts = this.nextAudioPts;\n\n // for audio samples, also consider consecutive fragments as being contiguous (even if a level switch occurs),\n // for sake of clarity:\n // consecutive fragments are frags with\n // - less than 100ms gaps between new time offset (if accurate) and next expected PTS OR\n // - less than 20 audio frames distance\n // contiguous fragments are consecutive fragments from same quality level (same level, new SN = old SN + 1)\n // this helps ensuring audio continuity\n // and this also avoids audio glitches/cut when switching quality, or reporting wrong duration on first audio frame\n contiguous |= (inputSamples.length && nextAudioPts &&\n ((accurateTimeOffset && Math.abs(timeOffset - nextAudioPts / inputTimeScale) < 0.1) ||\n Math.abs((inputSamples[0].pts - nextAudioPts - initPTS)) < 20 * inputSampleDuration)\n );\n\n // compute normalized PTS\n inputSamples.forEach(function (sample) {\n sample.pts = sample.dts = PTSNormalize(sample.pts - initPTS, timeOffset * inputTimeScale);\n });\n\n // filter out sample with negative PTS that are not playable anyway\n // if we don't remove these negative samples, they will shift all audio samples forward.\n // leading to audio overlap between current / next fragment\n inputSamples = inputSamples.filter((sample) => sample.pts >= 0);\n\n // in case all samples have negative PTS, and have been filtered out, return now\n if (inputSamples.length === 0) {\n return;\n }\n\n if (!contiguous) {\n if (!accurateTimeOffset) {\n // if frag are mot contiguous and if we cant trust time offset, let's use first sample PTS as next audio PTS\n nextAudioPts = inputSamples[0].pts;\n } else {\n // if timeOffset is accurate, let's use it as predicted next audio PTS\n nextAudioPts = Math.max(0, timeOffset * inputTimeScale);\n }\n }\n\n // If the audio track is missing samples, the frames seem to get \"left-shifted\" within the\n // resulting mp4 segment, causing sync issues and leaving gaps at the end of the audio segment.\n // In an effort to prevent this from happening, we inject frames here where there are gaps.\n // When possible, we inject a silent frame; when that's not possible, we duplicate the last\n // frame.\n\n if (track.isAAC) {\n const maxAudioFramesDrift = this.config.maxAudioFramesDrift;\n for (let i = 0, nextPts = nextAudioPts; i < inputSamples.length;) {\n // First, let's see how far off this frame is from where we expect it to be\n const sample = inputSamples[i];\n let pts = sample.pts;\n let delta = pts - nextPts;\n\n // If we're overlapping by more than a duration, drop this sample\n if (delta <= -maxAudioFramesDrift * inputSampleDuration) {\n if (contiguous || i > 0) {\n logger.warn(`Dropping 1 audio frame @ ${toMsFromMpegTsClock(nextPts, true) / 1000}s due to ${toMsFromMpegTsClock(delta, true)} ms overlap.`);\n inputSamples.splice(i, 1);\n // Don't touch nextPtsNorm or i\n } else {\n // When changing qualities we can't trust that audio has been appended up to nextAudioPts\n // Warn about the overlap but do not drop samples as that can introduce buffer gaps\n logger.warn(`Audio frame @ ${toMsFromMpegTsClock(pts, true) / 1000}s overlaps nextAudioPts by ${toMsFromMpegTsClock(delta, true)} ms.`);\n nextPts = pts + inputSampleDuration;\n i++;\n }\n } // eslint-disable-line brace-style\n\n // Insert missing frames if:\n // 1: We're more than maxAudioFramesDrift frame away\n // 2: Not more than MAX_SILENT_FRAME_DURATION away\n // 3: currentTime (aka nextPtsNorm) is not 0\n else if (delta >= maxAudioFramesDrift * inputSampleDuration && delta < MAX_SILENT_FRAME_DURATION_90KHZ && nextPts) {\n let missing = Math.round(delta / inputSampleDuration);\n logger.warn(`Injecting ${missing} audio frames @ ${toMsFromMpegTsClock(nextPts, true) / 1000}s due to ${toMsFromMpegTsClock(delta, true)} ms gap.`);\n for (let j = 0; j < missing; j++) {\n let newStamp = Math.max(nextPts, 0);\n fillFrame = AAC.getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n if (!fillFrame) {\n logger.log('Unable to get silent frame for given audio codec; duplicating last frame instead.');\n fillFrame = sample.unit.subarray();\n }\n inputSamples.splice(i, 0, { unit: fillFrame, pts: newStamp, dts: newStamp });\n nextPts += inputSampleDuration;\n i++;\n }\n\n // Adjust sample to next expected pts\n sample.pts = sample.dts = nextPts;\n nextPts += inputSampleDuration;\n i++;\n } else {\n // Otherwise, just adjust pts\n if (Math.abs(delta) > (0.1 * inputSampleDuration)) {\n // logger.log(`Invalid frame delta ${Math.round(delta + inputSampleDuration)} at PTS ${Math.round(pts / 90)} (should be ${Math.round(inputSampleDuration)}).`);\n }\n sample.pts = sample.dts = nextPts;\n nextPts += inputSampleDuration;\n i++;\n }\n }\n }\n\n // compute mdat size, as we eventually filtered/added some samples\n let nbSamples = inputSamples.length;\n let mdatSize = 0;\n while (nbSamples--) {\n mdatSize += inputSamples[nbSamples].unit.byteLength;\n }\n\n for (let j = 0, nbSamples = inputSamples.length; j < nbSamples; j++) {\n let audioSample = inputSamples[j];\n let unit = audioSample.unit;\n let pts = audioSample.pts;\n\n // logger.log(`Audio/PTS:${toMsFromMpegTsClock(pts, true)}`);\n // if not first sample\n\n if (lastPTS !== undefined && mp4Sample) {\n mp4Sample.duration = Math.round((pts - lastPTS) / scaleFactor);\n } else {\n let delta = pts - nextAudioPts;\n let numMissingFrames = 0;\n\n // if fragment are contiguous, detect hole/overlapping between fragments\n // contiguous fragments are consecutive fragments from same quality level (same level, new SN = old SN + 1)\n if (contiguous && track.isAAC) {\n // log delta\n if (delta) {\n if (delta > 0 && delta < MAX_SILENT_FRAME_DURATION_90KHZ) {\n // Q: why do we have to round here, shouldn't this always result in an integer if timestamps are correct,\n // and if not, shouldn't we actually Math.ceil() instead?\n numMissingFrames = Math.round((pts - nextAudioPts) / inputSampleDuration);\n\n logger.log(`${toMsFromMpegTsClock(delta, true)} ms hole between AAC samples detected,filling it`);\n if (numMissingFrames > 0) {\n fillFrame = AAC.getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n if (!fillFrame) {\n fillFrame = unit.subarray();\n }\n\n mdatSize += numMissingFrames * fillFrame.length;\n }\n // if we have frame overlap, overlapping for more than half a frame duraion\n } else if (delta < -12) {\n // drop overlapping audio frames... browser will deal with it\n logger.log(`drop overlapping AAC sample, expected/parsed/delta: ${toMsFromMpegTsClock(nextAudioPts, true)} ms / ${toMsFromMpegTsClock(pts, true)} ms / ${toMsFromMpegTsClock(-delta, true)} ms`);\n mdatSize -= unit.byteLength;\n continue;\n }\n // set PTS/DTS to expected PTS/DTS\n pts = nextAudioPts;\n }\n }\n // remember first PTS of our audioSamples\n firstPTS = pts;\n if (mdatSize > 0) {\n mdatSize += offset;\n try {\n mdat = new Uint8Array(mdatSize);\n } catch (err) {\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MUX_ERROR, details: ErrorDetails.REMUX_ALLOC_ERROR, fatal: false, bytes: mdatSize, reason: `fail allocating audio mdat ${mdatSize}` });\n return;\n }\n if (!rawMPEG) {\n const view = new DataView(mdat.buffer);\n view.setUint32(0, mdatSize);\n mdat.set(MP4.types.mdat, 4);\n }\n } else {\n // no audio samples\n return;\n }\n for (let i = 0; i < numMissingFrames; i++) {\n fillFrame = AAC.getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n if (!fillFrame) {\n logger.log('Unable to get silent frame for given audio codec; duplicating this frame instead.');\n fillFrame = unit.subarray();\n }\n mdat.set(fillFrame, offset);\n offset += fillFrame.byteLength;\n mp4Sample = {\n size: fillFrame.byteLength,\n cts: 0,\n duration: 1024,\n flags: {\n isLeading: 0,\n isDependedOn: 0,\n hasRedundancy: 0,\n degradPrio: 0,\n dependsOn: 1\n }\n };\n outputSamples.push(mp4Sample);\n }\n }\n mdat.set(unit, offset);\n let unitLen = unit.byteLength;\n offset += unitLen;\n // console.log('PTS/DTS/initDTS/normPTS/normDTS/relative PTS : ${audioSample.pts}/${audioSample.dts}/${initDTS}/${ptsnorm}/${dtsnorm}/${(audioSample.pts/4294967296).toFixed(3)}');\n mp4Sample = {\n size: unitLen,\n cts: 0,\n duration: 0,\n flags: {\n isLeading: 0,\n isDependedOn: 0,\n hasRedundancy: 0,\n degradPrio: 0,\n dependsOn: 1\n }\n };\n outputSamples.push(mp4Sample);\n lastPTS = pts;\n }\n let lastSampleDuration = 0;\n nbSamples = outputSamples.length;\n // set last sample duration as being identical to previous sample\n if (nbSamples >= 2) {\n lastSampleDuration = outputSamples[nbSamples - 2].duration;\n mp4Sample.duration = lastSampleDuration;\n }\n if (nbSamples) {\n // next audio sample PTS should be equal to last sample PTS + duration\n this.nextAudioPts = nextAudioPts = lastPTS + scaleFactor * lastSampleDuration;\n // logger.log('Audio/PTS/PTSend:' + audioSample.pts.toFixed(0) + '/' + this.nextAacDts.toFixed(0));\n track.samples = outputSamples;\n if (rawMPEG) {\n moof = new Uint8Array();\n } else {\n moof = MP4.moof(track.sequenceNumber++, firstPTS / scaleFactor, track);\n }\n\n track.samples = [];\n const start = firstPTS / inputTimeScale;\n const end = nextAudioPts / inputTimeScale;\n const audioData = {\n data1: moof,\n data2: mdat,\n startPTS: start,\n endPTS: end,\n startDTS: start,\n endDTS: end,\n type: 'audio',\n hasAudio: true,\n hasVideo: false,\n nb: nbSamples\n };\n this.observer.trigger(Event.FRAG_PARSING_DATA, audioData);\n return audioData;\n }\n return null;\n }\n\n remuxEmptyAudio (track, timeOffset, contiguous, videoData) {\n let inputTimeScale = track.inputTimeScale;\n let mp4timeScale = track.samplerate ? track.samplerate : inputTimeScale;\n let scaleFactor = inputTimeScale / mp4timeScale;\n let nextAudioPts = this.nextAudioPts;\n\n // sync with video's timestamp\n let startDTS = (nextAudioPts !== undefined ? nextAudioPts : videoData.startDTS * inputTimeScale) + this._initDTS;\n let endDTS = videoData.endDTS * inputTimeScale + this._initDTS;\n // one sample's duration value\n let sampleDuration = 1024;\n let frameDuration = scaleFactor * sampleDuration;\n\n // samples count of this segment's duration\n let nbSamples = Math.ceil((endDTS - startDTS) / frameDuration);\n\n // silent frame\n let silentFrame = AAC.getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n\n logger.warn('remux empty Audio');\n // Can't remux if we can't generate a silent frame...\n if (!silentFrame) {\n logger.trace('Unable to remuxEmptyAudio since we were unable to get a silent frame for given audio codec!');\n return;\n }\n\n let samples = [];\n for (let i = 0; i < nbSamples; i++) {\n let stamp = startDTS + i * frameDuration;\n samples.push({ unit: silentFrame, pts: stamp, dts: stamp });\n }\n track.samples = samples;\n\n this.remuxAudio(track, timeOffset, contiguous);\n }\n\n remuxID3 (track, timeOffset) {\n const length = track.samples.length;\n if (!length) {\n return;\n }\n const inputTimeScale = track.inputTimeScale;\n const initPTS = this._initPTS;\n const initDTS = this._initDTS;\n // consume samples\n for (let index = 0; index < length; index++) {\n const sample = track.samples[index];\n // setting id3 pts, dts to relative time\n // using this._initPTS and this._initDTS to calculate relative time\n sample.pts = PTSNormalize(sample.pts - initPTS, timeOffset * inputTimeScale) / inputTimeScale;\n sample.dts = PTSNormalize(sample.dts - initDTS, timeOffset * inputTimeScale) / inputTimeScale;\n }\n this.observer.trigger(Event.FRAG_PARSING_METADATA, {\n samples: track.samples\n });\n\n track.samples = [];\n }\n\n remuxText (track, timeOffset) {\n const length = track.samples.length;\n const inputTimeScale = track.inputTimeScale;\n const initPTS = this._initPTS;\n // consume samples\n if (length) {\n for (let index = 0; index < length; index++) {\n const sample = track.samples[index];\n // setting text pts, dts to relative time\n // using this._initPTS and this._initDTS to calculate relative time\n sample.pts = PTSNormalize(sample.pts - initPTS, timeOffset * inputTimeScale) / inputTimeScale;\n }\n track.samples.sort(function (a, b) {\n return (a.pts - b.pts);\n });\n this.observer.trigger(Event.FRAG_PARSING_USERDATA, {\n samples: track.samples\n });\n }\n\n track.samples = [];\n }\n}\n\nfunction PTSNormalize (value, reference) {\n let offset;\n if (reference === undefined) {\n return value;\n }\n\n if (reference < value) {\n // - 2^33\n offset = -8589934592;\n } else {\n // + 2^33\n offset = 8589934592;\n }\n /* PTS is 33bit (from 0 to 2^33 -1)\n if diff between value and reference is bigger than half of the amplitude (2^32) then it means that\n PTS looping occured. fill the gap */\n while (Math.abs(value - reference) > 4294967296) {\n value += offset;\n }\n\n return value;\n}\n\nexport default MP4Remuxer;\n","/**\n *\n * inline demuxer: probe fragments and instantiate\n * appropriate demuxer depending on content type (TSDemuxer, AACDemuxer, ...)\n *\n */\n\nimport Event from '../events';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport Decrypter from '../crypt/decrypter';\nimport AACDemuxer from '../demux/aacdemuxer';\nimport MP4Demuxer from '../demux/mp4demuxer';\nimport TSDemuxer from '../demux/tsdemuxer';\nimport MP3Demuxer from '../demux/mp3demuxer';\nimport MP4Remuxer from '../remux/mp4-remuxer';\nimport PassThroughRemuxer from '../remux/passthrough-remuxer';\n\nimport { getSelfScope } from '../utils/get-self-scope';\nimport { logger } from '../utils/logger';\n\n// see https://stackoverflow.com/a/11237259/589493\nconst global = getSelfScope(); // safeguard for code that might run both on worker and main thread\n\nlet now;\n// performance.now() not available on WebWorker, at least on Safari Desktop\ntry {\n now = global.performance.now.bind(global.performance);\n} catch (err) {\n logger.debug('Unable to use Performance API on this environment');\n now = global.Date.now;\n}\n\nclass DemuxerInline {\n constructor (observer, typeSupported, config, vendor) {\n this.observer = observer;\n this.typeSupported = typeSupported;\n this.config = config;\n this.vendor = vendor;\n }\n\n destroy () {\n let demuxer = this.demuxer;\n if (demuxer) {\n demuxer.destroy();\n }\n }\n\n push (data, decryptdata, initSegment, audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS) {\n if ((data.byteLength > 0) && (decryptdata != null) && (decryptdata.key != null) && (decryptdata.method === 'AES-128')) {\n let decrypter = this.decrypter;\n if (decrypter == null) {\n decrypter = this.decrypter = new Decrypter(this.observer, this.config);\n }\n\n const startTime = now();\n decrypter.decrypt(data, decryptdata.key.buffer, decryptdata.iv.buffer, (decryptedData) => {\n const endTime = now();\n this.observer.trigger(Event.FRAG_DECRYPTED, { stats: { tstart: startTime, tdecrypt: endTime } });\n this.pushDecrypted(new Uint8Array(decryptedData), decryptdata, new Uint8Array(initSegment), audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS);\n });\n } else {\n this.pushDecrypted(new Uint8Array(data), decryptdata, new Uint8Array(initSegment), audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS);\n }\n }\n\n pushDecrypted (data, decryptdata, initSegment, audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS) {\n let demuxer = this.demuxer;\n let remuxer = this.remuxer;\n if (!demuxer ||\n // in case of continuity change, or track switch\n // we might switch from content type (AAC container to TS container, or TS to fmp4 for example)\n (discontinuity || trackSwitch)) {\n const observer = this.observer;\n const typeSupported = this.typeSupported;\n const config = this.config;\n // probing order is TS/MP4/AAC/MP3\n const muxConfig = [\n { demux: TSDemuxer, remux: MP4Remuxer },\n { demux: MP4Demuxer, remux: PassThroughRemuxer },\n { demux: AACDemuxer, remux: MP4Remuxer },\n { demux: MP3Demuxer, remux: MP4Remuxer }\n ];\n\n // probe for content type\n let mux;\n for (let i = 0, len = muxConfig.length; i < len; i++) {\n mux = muxConfig[i];\n if (mux.demux.probe(data)) {\n break;\n }\n }\n if (!mux) {\n observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: true, reason: 'no demux matching with content found' });\n return;\n }\n // so let's check that current remuxer and demuxer are still valid\n if (!remuxer || !(remuxer instanceof mux.remux)) {\n remuxer = new mux.remux(observer, config, typeSupported, this.vendor);\n }\n if (!demuxer || !(demuxer instanceof mux.demux)) {\n demuxer = new mux.demux(observer, remuxer, config, typeSupported);\n this.probe = mux.demux.probe;\n }\n this.demuxer = demuxer;\n this.remuxer = remuxer;\n }\n\n if (discontinuity || trackSwitch) {\n demuxer.resetInitSegment(initSegment, audioCodec, videoCodec, duration);\n remuxer.resetInitSegment();\n }\n if (discontinuity) {\n demuxer.resetTimeStamp(defaultInitPTS);\n remuxer.resetTimeStamp(defaultInitPTS);\n }\n if (typeof demuxer.setDecryptData === 'function') {\n demuxer.setDecryptData(decryptdata);\n }\n\n demuxer.append(data, timeOffset, contiguous, accurateTimeOffset);\n }\n}\n\nexport default DemuxerInline;\n","/**\n * passthrough remuxer\n*/\nimport Event from '../events';\n\nclass PassThroughRemuxer {\n constructor (observer) {\n this.observer = observer;\n }\n\n destroy () {\n }\n\n resetTimeStamp () {\n }\n\n resetInitSegment () {\n }\n\n remux (audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset, rawData) {\n let observer = this.observer;\n let streamType = '';\n if (audioTrack) {\n streamType += 'audio';\n }\n\n if (videoTrack) {\n streamType += 'video';\n }\n\n observer.trigger(Event.FRAG_PARSING_DATA, {\n data1: rawData,\n startPTS: timeOffset,\n startDTS: timeOffset,\n type: streamType,\n hasAudio: !!audioTrack,\n hasVideo: !!videoTrack,\n nb: 1,\n dropped: 0\n });\n // notify end of parsing\n observer.trigger(Event.FRAG_PARSED);\n }\n}\n\nexport default PassThroughRemuxer;\n","/* demuxer web worker.\n * - listen to worker message, and trigger DemuxerInline upon reception of Fragments.\n * - provides MP4 Boxes back to main thread using [transferable objects](https://developers.google.com/web/updates/2011/12/Transferable-Objects-Lightning-Fast) in order to minimize message passing overhead.\n */\n\nimport DemuxerInline from '../demux/demuxer-inline';\nimport Event from '../events';\nimport { enableLogs } from '../utils/logger';\n\nimport { EventEmitter } from 'eventemitter3';\n\nlet DemuxerWorker = function (self) {\n // observer setup\n let observer = new EventEmitter();\n observer.trigger = function trigger (event, ...data) {\n observer.emit(event, event, ...data);\n };\n\n observer.off = function off (event, ...data) {\n observer.removeListener(event, ...data);\n };\n\n let forwardMessage = function (ev, data) {\n self.postMessage({ event: ev, data: data });\n };\n\n self.addEventListener('message', function (ev) {\n let data = ev.data;\n // console.log('demuxer cmd:' + data.cmd);\n switch (data.cmd) {\n case 'init':\n const config = JSON.parse(data.config);\n self.demuxer = new DemuxerInline(observer, data.typeSupported, config, data.vendor);\n\n enableLogs(config.debug);\n\n // signal end of worker init\n forwardMessage('init', null);\n break;\n case 'demux':\n self.demuxer.push(data.data, data.decryptdata, data.initSegment, data.audioCodec, data.videoCodec, data.timeOffset, data.discontinuity, data.trackSwitch, data.contiguous, data.duration, data.accurateTimeOffset, data.defaultInitPTS);\n break;\n default:\n break;\n }\n });\n\n // forward events to main thread\n observer.on(Event.FRAG_DECRYPTED, forwardMessage);\n observer.on(Event.FRAG_PARSING_INIT_SEGMENT, forwardMessage);\n observer.on(Event.FRAG_PARSED, forwardMessage);\n observer.on(Event.ERROR, forwardMessage);\n observer.on(Event.FRAG_PARSING_METADATA, forwardMessage);\n observer.on(Event.FRAG_PARSING_USERDATA, forwardMessage);\n observer.on(Event.INIT_PTS_FOUND, forwardMessage);\n\n // special case for FRAG_PARSING_DATA: pass data1/data2 as transferable object (no copy)\n observer.on(Event.FRAG_PARSING_DATA, function (ev, data) {\n let transferable = [];\n let message = { event: ev, data: data };\n if (data.data1) {\n message.data1 = data.data1.buffer;\n transferable.push(data.data1.buffer);\n delete data.data1;\n }\n if (data.data2) {\n message.data2 = data.data2.buffer;\n transferable.push(data.data2.buffer);\n delete data.data2;\n }\n self.postMessage(message, transferable);\n });\n};\n\nexport default DemuxerWorker;\n","import { getSelfScope } from '../utils/get-self-scope';\n\n/**\n * ID3 parser\n */\nclass ID3 {\n /**\n * Returns true if an ID3 header can be found at offset in data\n * @param {Uint8Array} data - The data to search in\n * @param {number} offset - The offset at which to start searching\n * @return {boolean} - True if an ID3 header is found\n */\n static isHeader (data, offset) {\n /*\n * http://id3.org/id3v2.3.0\n * [0] = 'I'\n * [1] = 'D'\n * [2] = '3'\n * [3,4] = {Version}\n * [5] = {Flags}\n * [6-9] = {ID3 Size}\n *\n * An ID3v2 tag can be detected with the following pattern:\n * $49 44 33 yy yy xx zz zz zz zz\n * Where yy is less than $FF, xx is the 'flags' byte and zz is less than $80\n */\n if (offset + 10 <= data.length) {\n // look for 'ID3' identifier\n if (data[offset] === 0x49 && data[offset + 1] === 0x44 && data[offset + 2] === 0x33) {\n // check version is within range\n if (data[offset + 3] < 0xFF && data[offset + 4] < 0xFF) {\n // check size is within range\n if (data[offset + 6] < 0x80 && data[offset + 7] < 0x80 && data[offset + 8] < 0x80 && data[offset + 9] < 0x80) {\n return true;\n }\n }\n }\n }\n\n return false;\n }\n\n /**\n * Returns true if an ID3 footer can be found at offset in data\n * @param {Uint8Array} data - The data to search in\n * @param {number} offset - The offset at which to start searching\n * @return {boolean} - True if an ID3 footer is found\n */\n static isFooter (data, offset) {\n /*\n * The footer is a copy of the header, but with a different identifier\n */\n if (offset + 10 <= data.length) {\n // look for '3DI' identifier\n if (data[offset] === 0x33 && data[offset + 1] === 0x44 && data[offset + 2] === 0x49) {\n // check version is within range\n if (data[offset + 3] < 0xFF && data[offset + 4] < 0xFF) {\n // check size is within range\n if (data[offset + 6] < 0x80 && data[offset + 7] < 0x80 && data[offset + 8] < 0x80 && data[offset + 9] < 0x80) {\n return true;\n }\n }\n }\n }\n\n return false;\n }\n\n /**\n * Returns any adjacent ID3 tags found in data starting at offset, as one block of data\n * @param {Uint8Array} data - The data to search in\n * @param {number} offset - The offset at which to start searching\n * @return {Uint8Array} - The block of data containing any ID3 tags found\n */\n static getID3Data (data, offset) {\n const front = offset;\n let length = 0;\n\n while (ID3.isHeader(data, offset)) {\n // ID3 header is 10 bytes\n length += 10;\n\n const size = ID3._readSize(data, offset + 6);\n length += size;\n\n if (ID3.isFooter(data, offset + 10)) {\n // ID3 footer is 10 bytes\n length += 10;\n }\n\n offset += length;\n }\n\n if (length > 0) {\n return data.subarray(front, front + length);\n }\n\n return undefined;\n }\n\n static _readSize (data, offset) {\n let size = 0;\n size = ((data[offset] & 0x7f) << 21);\n size |= ((data[offset + 1] & 0x7f) << 14);\n size |= ((data[offset + 2] & 0x7f) << 7);\n size |= (data[offset + 3] & 0x7f);\n return size;\n }\n\n /**\n * Searches for the Elementary Stream timestamp found in the ID3 data chunk\n * @param {Uint8Array} data - Block of data containing one or more ID3 tags\n * @return {number} - The timestamp\n */\n static getTimeStamp (data) {\n const frames = ID3.getID3Frames(data);\n for (let i = 0; i < frames.length; i++) {\n const frame = frames[i];\n if (ID3.isTimeStampFrame(frame)) {\n return ID3._readTimeStamp(frame);\n }\n }\n\n return undefined;\n }\n\n /**\n * Returns true if the ID3 frame is an Elementary Stream timestamp frame\n * @param {ID3 frame} frame\n */\n static isTimeStampFrame (frame) {\n return (frame && frame.key === 'PRIV' && frame.info === 'com.apple.streaming.transportStreamTimestamp');\n }\n\n static _getFrameData (data) {\n /*\n Frame ID $xx xx xx xx (four characters)\n Size $xx xx xx xx\n Flags $xx xx\n */\n const type = String.fromCharCode(data[0], data[1], data[2], data[3]);\n const size = ID3._readSize(data, 4);\n\n // skip frame id, size, and flags\n let offset = 10;\n\n return { type, size, data: data.subarray(offset, offset + size) };\n }\n\n /**\n * Returns an array of ID3 frames found in all the ID3 tags in the id3Data\n * @param {Uint8Array} id3Data - The ID3 data containing one or more ID3 tags\n * @return {ID3 frame[]} - Array of ID3 frame objects\n */\n static getID3Frames (id3Data) {\n let offset = 0;\n const frames = [];\n\n while (ID3.isHeader(id3Data, offset)) {\n const size = ID3._readSize(id3Data, offset + 6);\n // skip past ID3 header\n offset += 10;\n const end = offset + size;\n // loop through frames in the ID3 tag\n while (offset + 8 < end) {\n const frameData = ID3._getFrameData(id3Data.subarray(offset));\n const frame = ID3._decodeFrame(frameData);\n if (frame) {\n frames.push(frame);\n }\n\n // skip frame header and frame data\n offset += frameData.size + 10;\n }\n\n if (ID3.isFooter(id3Data, offset)) {\n offset += 10;\n }\n }\n\n return frames;\n }\n\n static _decodeFrame (frame) {\n if (frame.type === 'PRIV') {\n return ID3._decodePrivFrame(frame);\n } else if (frame.type[0] === 'W') {\n return ID3._decodeURLFrame(frame);\n }\n\n return ID3._decodeTextFrame(frame);\n }\n\n static _readTimeStamp (timeStampFrame) {\n if (timeStampFrame.data.byteLength === 8) {\n const data = new Uint8Array(timeStampFrame.data);\n // timestamp is 33 bit expressed as a big-endian eight-octet number,\n // with the upper 31 bits set to zero.\n const pts33Bit = data[3] & 0x1;\n let timestamp = (data[4] << 23) +\n (data[5] << 15) +\n (data[6] << 7) +\n data[7];\n timestamp /= 45;\n\n if (pts33Bit) {\n timestamp += 47721858.84;\n } // 2^32 / 90\n\n return Math.round(timestamp);\n }\n\n return undefined;\n }\n\n static _decodePrivFrame (frame) {\n /*\n Format: \\0\n */\n if (frame.size < 2) {\n return undefined;\n }\n\n const owner = ID3._utf8ArrayToStr(frame.data, true);\n const privateData = new Uint8Array(frame.data.subarray(owner.length + 1));\n\n return { key: frame.type, info: owner, data: privateData.buffer };\n }\n\n static _decodeTextFrame (frame) {\n if (frame.size < 2) {\n return undefined;\n }\n\n if (frame.type === 'TXXX') {\n /*\n Format:\n [0] = {Text Encoding}\n [1-?] = {Description}\\0{Value}\n */\n let index = 1;\n const description = ID3._utf8ArrayToStr(frame.data.subarray(index), true);\n\n index += description.length + 1;\n const value = ID3._utf8ArrayToStr(frame.data.subarray(index));\n\n return { key: frame.type, info: description, data: value };\n } else {\n /*\n Format:\n [0] = {Text Encoding}\n [1-?] = {Value}\n */\n const text = ID3._utf8ArrayToStr(frame.data.subarray(1));\n return { key: frame.type, data: text };\n }\n }\n\n static _decodeURLFrame (frame) {\n if (frame.type === 'WXXX') {\n /*\n Format:\n [0] = {Text Encoding}\n [1-?] = {Description}\\0{URL}\n */\n if (frame.size < 2) {\n return undefined;\n }\n\n let index = 1;\n const description = ID3._utf8ArrayToStr(frame.data.subarray(index), true);\n\n index += description.length + 1;\n const value = ID3._utf8ArrayToStr(frame.data.subarray(index));\n\n return { key: frame.type, info: description, data: value };\n } else {\n /*\n Format:\n [0-?] = {URL}\n */\n const url = ID3._utf8ArrayToStr(frame.data);\n return { key: frame.type, data: url };\n }\n }\n\n // http://stackoverflow.com/questions/8936984/uint8array-to-string-in-javascript/22373197\n // http://www.onicos.com/staff/iz/amuse/javascript/expert/utf.txt\n /* utf.js - UTF-8 <=> UTF-16 convertion\n *\n * Copyright (C) 1999 Masanao Izumo \n * Version: 1.0\n * LastModified: Dec 25 1999\n * This library is free. You can redistribute it and/or modify it.\n */\n static _utf8ArrayToStr (array, exitOnNull = false) {\n const decoder = getTextDecoder();\n if (decoder) {\n const decoded = decoder.decode(array);\n\n if (exitOnNull) {\n // grab up to the first null\n const idx = decoded.indexOf('\\0');\n return idx !== -1 ? decoded.substring(0, idx) : decoded;\n }\n\n // remove any null characters\n return decoded.replace(/\\0/g, '');\n }\n\n const len = array.length;\n let c;\n let char2;\n let char3;\n let out = '';\n let i = 0;\n while (i < len) {\n c = array[i++];\n if (c === 0x00 && exitOnNull) {\n return out;\n } else if (c === 0x00 || c === 0x03) {\n // If the character is 3 (END_OF_TEXT) or 0 (NULL) then skip it\n continue;\n }\n switch (c >> 4) {\n case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7:\n // 0xxxxxxx\n out += String.fromCharCode(c);\n break;\n case 12: case 13:\n // 110x xxxx 10xx xxxx\n char2 = array[i++];\n out += String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F));\n break;\n case 14:\n // 1110 xxxx 10xx xxxx 10xx xxxx\n char2 = array[i++];\n char3 = array[i++];\n out += String.fromCharCode(((c & 0x0F) << 12) |\n ((char2 & 0x3F) << 6) |\n ((char3 & 0x3F) << 0));\n break;\n default:\n }\n }\n return out;\n }\n}\n\nlet decoder;\n\nfunction getTextDecoder () {\n const global = getSelfScope(); // safeguard for code that might run both on worker and main thread\n if (!decoder && typeof global.TextDecoder !== 'undefined') {\n decoder = new global.TextDecoder('utf-8');\n }\n\n return decoder;\n}\n\nconst utf8ArrayToStr = ID3._utf8ArrayToStr;\n\nexport default ID3;\n\nexport { utf8ArrayToStr };\n","/**\n * MP4 demuxer\n */\nimport { logger } from '../utils/logger';\nimport Event from '../events';\n\nconst UINT32_MAX = Math.pow(2, 32) - 1;\n\nclass MP4Demuxer {\n constructor (observer, remuxer) {\n this.observer = observer;\n this.remuxer = remuxer;\n }\n\n resetTimeStamp (initPTS) {\n this.initPTS = initPTS;\n }\n\n resetInitSegment (initSegment, audioCodec, videoCodec, duration) {\n // jshint unused:false\n if (initSegment && initSegment.byteLength) {\n const initData = this.initData = MP4Demuxer.parseInitSegment(initSegment);\n\n // default audio codec if nothing specified\n // TODO : extract that from initsegment\n if (audioCodec == null) {\n audioCodec = 'mp4a.40.5';\n }\n\n if (videoCodec == null) {\n videoCodec = 'avc1.42e01e';\n }\n\n const tracks = {};\n if (initData.audio && initData.video) {\n tracks.audiovideo = { container: 'video/mp4', codec: audioCodec + ',' + videoCodec, initSegment: duration ? initSegment : null };\n } else {\n if (initData.audio) {\n tracks.audio = { container: 'audio/mp4', codec: audioCodec, initSegment: duration ? initSegment : null };\n }\n\n if (initData.video) {\n tracks.video = { container: 'video/mp4', codec: videoCodec, initSegment: duration ? initSegment : null };\n }\n }\n this.observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT, { tracks });\n } else {\n if (audioCodec) {\n this.audioCodec = audioCodec;\n }\n\n if (videoCodec) {\n this.videoCodec = videoCodec;\n }\n }\n }\n\n static probe (data) {\n // ensure we find a moof box in the first 16 kB\n return MP4Demuxer.findBox({ data: data, start: 0, end: Math.min(data.length, 16384) }, ['moof']).length > 0;\n }\n\n static bin2str (buffer) {\n return String.fromCharCode.apply(null, buffer);\n }\n\n static readUint16 (buffer, offset) {\n if (buffer.data) {\n offset += buffer.start;\n buffer = buffer.data;\n }\n\n const val = buffer[offset] << 8 |\n buffer[offset + 1];\n\n return val < 0 ? 65536 + val : val;\n }\n\n static readUint32 (buffer, offset) {\n if (buffer.data) {\n offset += buffer.start;\n buffer = buffer.data;\n }\n\n const val = buffer[offset] << 24 |\n buffer[offset + 1] << 16 |\n buffer[offset + 2] << 8 |\n buffer[offset + 3];\n return val < 0 ? 4294967296 + val : val;\n }\n\n static writeUint32 (buffer, offset, value) {\n if (buffer.data) {\n offset += buffer.start;\n buffer = buffer.data;\n }\n buffer[offset] = value >> 24;\n buffer[offset + 1] = (value >> 16) & 0xff;\n buffer[offset + 2] = (value >> 8) & 0xff;\n buffer[offset + 3] = value & 0xff;\n }\n\n // Find the data for a box specified by its path\n static findBox (data, path) {\n let results = [],\n i, size, type, end, subresults, start, endbox;\n\n if (data.data) {\n start = data.start;\n end = data.end;\n data = data.data;\n } else {\n start = 0;\n end = data.byteLength;\n }\n\n if (!path.length) {\n // short-circuit the search for empty paths\n return null;\n }\n\n for (i = start; i < end;) {\n size = MP4Demuxer.readUint32(data, i);\n type = MP4Demuxer.bin2str(data.subarray(i + 4, i + 8));\n endbox = size > 1 ? i + size : end;\n\n if (type === path[0]) {\n if (path.length === 1) {\n // this is the end of the path and we've found the box we were\n // looking for\n results.push({ data: data, start: i + 8, end: endbox });\n } else {\n // recursively search for the next box along the path\n subresults = MP4Demuxer.findBox({ data: data, start: i + 8, end: endbox }, path.slice(1));\n if (subresults.length) {\n results = results.concat(subresults);\n }\n }\n }\n i = endbox;\n }\n\n // we've finished searching all of data\n return results;\n }\n\n static parseSegmentIndex (initSegment) {\n const moov = MP4Demuxer.findBox(initSegment, ['moov'])[0];\n const moovEndOffset = moov ? moov.end : null; // we need this in case we need to chop of garbage of the end of current data\n\n let index = 0;\n let sidx = MP4Demuxer.findBox(initSegment, ['sidx']);\n let references;\n\n if (!sidx || !sidx[0]) {\n return null;\n }\n\n references = [];\n sidx = sidx[0];\n\n const version = sidx.data[0];\n\n // set initial offset, we skip the reference ID (not needed)\n index = version === 0 ? 8 : 16;\n\n const timescale = MP4Demuxer.readUint32(sidx, index);\n index += 4;\n\n // TODO: parse earliestPresentationTime and firstOffset\n // usually zero in our case\n let earliestPresentationTime = 0;\n let firstOffset = 0;\n\n if (version === 0) {\n index += 8;\n } else {\n index += 16;\n }\n\n // skip reserved\n index += 2;\n\n let startByte = sidx.end + firstOffset;\n\n const referencesCount = MP4Demuxer.readUint16(sidx, index);\n index += 2;\n\n for (let i = 0; i < referencesCount; i++) {\n let referenceIndex = index;\n\n const referenceInfo = MP4Demuxer.readUint32(sidx, referenceIndex);\n referenceIndex += 4;\n\n const referenceSize = referenceInfo & 0x7FFFFFFF;\n const referenceType = (referenceInfo & 0x80000000) >>> 31;\n\n if (referenceType === 1) {\n console.warn('SIDX has hierarchical references (not supported)');\n return;\n }\n\n const subsegmentDuration = MP4Demuxer.readUint32(sidx, referenceIndex);\n referenceIndex += 4;\n\n references.push({\n referenceSize,\n subsegmentDuration, // unscaled\n info: {\n duration: subsegmentDuration / timescale,\n start: startByte,\n end: startByte + referenceSize - 1\n }\n });\n\n startByte += referenceSize;\n\n // Skipping 1 bit for |startsWithSap|, 3 bits for |sapType|, and 28 bits\n // for |sapDelta|.\n referenceIndex += 4;\n\n // skip to next ref\n index = referenceIndex;\n }\n\n return {\n earliestPresentationTime,\n timescale,\n version,\n referencesCount,\n references,\n moovEndOffset\n };\n }\n\n /**\n * Parses an MP4 initialization segment and extracts stream type and\n * timescale values for any declared tracks. Timescale values indicate the\n * number of clock ticks per second to assume for time-based values\n * elsewhere in the MP4.\n *\n * To determine the start time of an MP4, you need two pieces of\n * information: the timescale unit and the earliest base media decode\n * time. Multiple timescales can be specified within an MP4 but the\n * base media decode time is always expressed in the timescale from\n * the media header box for the track:\n * ```\n * moov > trak > mdia > mdhd.timescale\n * moov > trak > mdia > hdlr\n * ```\n * @param init {Uint8Array} the bytes of the init segment\n * @return {object} a hash of track type to timescale values or null if\n * the init segment is malformed.\n */\n static parseInitSegment (initSegment) {\n let result = [];\n let traks = MP4Demuxer.findBox(initSegment, ['moov', 'trak']);\n\n traks.forEach(trak => {\n const tkhd = MP4Demuxer.findBox(trak, ['tkhd'])[0];\n if (tkhd) {\n let version = tkhd.data[tkhd.start];\n let index = version === 0 ? 12 : 20;\n let trackId = MP4Demuxer.readUint32(tkhd, index);\n\n const mdhd = MP4Demuxer.findBox(trak, ['mdia', 'mdhd'])[0];\n if (mdhd) {\n version = mdhd.data[mdhd.start];\n index = version === 0 ? 12 : 20;\n const timescale = MP4Demuxer.readUint32(mdhd, index);\n\n const hdlr = MP4Demuxer.findBox(trak, ['mdia', 'hdlr'])[0];\n if (hdlr) {\n const hdlrType = MP4Demuxer.bin2str(hdlr.data.subarray(hdlr.start + 8, hdlr.start + 12));\n let type = { 'soun': 'audio', 'vide': 'video' }[hdlrType];\n if (type) {\n // extract codec info. TODO : parse codec details to be able to build MIME type\n let codecBox = MP4Demuxer.findBox(trak, ['mdia', 'minf', 'stbl', 'stsd']);\n if (codecBox.length) {\n codecBox = codecBox[0];\n let codecType = MP4Demuxer.bin2str(codecBox.data.subarray(codecBox.start + 12, codecBox.start + 16));\n logger.log(`MP4Demuxer:${type}:${codecType} found`);\n }\n result[trackId] = { timescale: timescale, type: type };\n result[type] = { timescale: timescale, id: trackId };\n }\n }\n }\n }\n });\n return result;\n }\n\n /**\n * Determine the base media decode start time, in seconds, for an MP4\n * fragment. If multiple fragments are specified, the earliest time is\n * returned.\n *\n * The base media decode time can be parsed from track fragment\n * metadata:\n * ```\n * moof > traf > tfdt.baseMediaDecodeTime\n * ```\n * It requires the timescale value from the mdhd to interpret.\n *\n * @param timescale {object} a hash of track ids to timescale values.\n * @return {number} the earliest base media decode start time for the\n * fragment, in seconds\n */\n static getStartDTS (initData, fragment) {\n let trafs, baseTimes, result;\n\n // we need info from two childrend of each track fragment box\n trafs = MP4Demuxer.findBox(fragment, ['moof', 'traf']);\n\n // determine the start times for each track\n baseTimes = [].concat.apply([], trafs.map(function (traf) {\n return MP4Demuxer.findBox(traf, ['tfhd']).map(function (tfhd) {\n let id, scale, baseTime;\n\n // get the track id from the tfhd\n id = MP4Demuxer.readUint32(tfhd, 4);\n // assume a 90kHz clock if no timescale was specified\n scale = initData[id].timescale || 90e3;\n\n // get the base media decode time from the tfdt\n baseTime = MP4Demuxer.findBox(traf, ['tfdt']).map(function (tfdt) {\n let version, result;\n\n version = tfdt.data[tfdt.start];\n result = MP4Demuxer.readUint32(tfdt, 4);\n if (version === 1) {\n result *= Math.pow(2, 32);\n\n result += MP4Demuxer.readUint32(tfdt, 8);\n }\n return result;\n })[0];\n // convert base time to seconds\n return baseTime / scale;\n });\n }));\n\n // return the minimum\n result = Math.min.apply(null, baseTimes);\n return isFinite(result) ? result : 0;\n }\n\n static offsetStartDTS (initData, fragment, timeOffset) {\n MP4Demuxer.findBox(fragment, ['moof', 'traf']).map(function (traf) {\n return MP4Demuxer.findBox(traf, ['tfhd']).map(function (tfhd) {\n // get the track id from the tfhd\n let id = MP4Demuxer.readUint32(tfhd, 4);\n // assume a 90kHz clock if no timescale was specified\n let timescale = initData[id].timescale || 90e3;\n\n // get the base media decode time from the tfdt\n MP4Demuxer.findBox(traf, ['tfdt']).map(function (tfdt) {\n let version = tfdt.data[tfdt.start];\n let baseMediaDecodeTime = MP4Demuxer.readUint32(tfdt, 4);\n if (version === 0) {\n MP4Demuxer.writeUint32(tfdt, 4, baseMediaDecodeTime - timeOffset * timescale);\n } else {\n baseMediaDecodeTime *= Math.pow(2, 32);\n baseMediaDecodeTime += MP4Demuxer.readUint32(tfdt, 8);\n baseMediaDecodeTime -= timeOffset * timescale;\n baseMediaDecodeTime = Math.max(baseMediaDecodeTime, 0);\n const upper = Math.floor(baseMediaDecodeTime / (UINT32_MAX + 1));\n const lower = Math.floor(baseMediaDecodeTime % (UINT32_MAX + 1));\n MP4Demuxer.writeUint32(tfdt, 4, upper);\n MP4Demuxer.writeUint32(tfdt, 8, lower);\n }\n });\n });\n });\n }\n\n // feed incoming data to the front of the parsing pipeline\n append (data, timeOffset, contiguous, accurateTimeOffset) {\n let initData = this.initData;\n if (!initData) {\n this.resetInitSegment(data, this.audioCodec, this.videoCodec, false);\n initData = this.initData;\n }\n let startDTS, initPTS = this.initPTS;\n if (initPTS === undefined) {\n let startDTS = MP4Demuxer.getStartDTS(initData, data);\n this.initPTS = initPTS = startDTS - timeOffset;\n this.observer.trigger(Event.INIT_PTS_FOUND, { initPTS: initPTS });\n }\n MP4Demuxer.offsetStartDTS(initData, data, initPTS);\n startDTS = MP4Demuxer.getStartDTS(initData, data);\n this.remuxer.remux(initData.audio, initData.video, null, null, startDTS, contiguous, accurateTimeOffset, data);\n }\n\n destroy () {}\n}\n\nexport default MP4Demuxer;\n","export enum ErrorTypes {\n // Identifier for a network error (loading error / timeout ...)\n NETWORK_ERROR = 'networkError',\n // Identifier for a media Error (video/parsing/mediasource error)\n MEDIA_ERROR = 'mediaError',\n // EME (encrypted media extensions) errors\n KEY_SYSTEM_ERROR = 'keySystemError',\n // Identifier for a mux Error (demuxing/remuxing)\n MUX_ERROR = 'muxError',\n // Identifier for all other errors\n OTHER_ERROR = 'otherError'\n}\n\n/**\n * @enum {ErrorDetails}\n * @typedef {string} ErrorDetail\n */\nexport enum ErrorDetails {\n KEY_SYSTEM_NO_KEYS = 'keySystemNoKeys',\n KEY_SYSTEM_NO_ACCESS = 'keySystemNoAccess',\n KEY_SYSTEM_NO_SESSION = 'keySystemNoSession',\n KEY_SYSTEM_LICENSE_REQUEST_FAILED = 'keySystemLicenseRequestFailed',\n KEY_SYSTEM_NO_INIT_DATA = 'keySystemNoInitData',\n // Identifier for a manifest load error - data: { url : faulty URL, response : { code: error code, text: error text }}\n MANIFEST_LOAD_ERROR = 'manifestLoadError',\n // Identifier for a manifest load timeout - data: { url : faulty URL, response : { code: error code, text: error text }}\n MANIFEST_LOAD_TIMEOUT = 'manifestLoadTimeOut',\n // Identifier for a manifest parsing error - data: { url : faulty URL, reason : error reason}\n MANIFEST_PARSING_ERROR = 'manifestParsingError',\n // Identifier for a manifest with only incompatible codecs error - data: { url : faulty URL, reason : error reason}\n MANIFEST_INCOMPATIBLE_CODECS_ERROR = 'manifestIncompatibleCodecsError',\n // Identifier for a level which contains no fragments - data: { url: faulty URL, reason: \"no fragments found in level\", level: index of the bad level }\n LEVEL_EMPTY_ERROR = 'levelEmptyError',\n // Identifier for a level load error - data: { url : faulty URL, response : { code: error code, text: error text }}\n LEVEL_LOAD_ERROR = 'levelLoadError',\n // Identifier for a level load timeout - data: { url : faulty URL, response : { code: error code, text: error text }}\n LEVEL_LOAD_TIMEOUT = 'levelLoadTimeOut',\n // Identifier for a level switch error - data: { level : faulty level Id, event : error description}\n LEVEL_SWITCH_ERROR = 'levelSwitchError',\n // Identifier for an audio track load error - data: { url : faulty URL, response : { code: error code, text: error text }}\n AUDIO_TRACK_LOAD_ERROR = 'audioTrackLoadError',\n // Identifier for an audio track load timeout - data: { url : faulty URL, response : { code: error code, text: error text }}\n AUDIO_TRACK_LOAD_TIMEOUT = 'audioTrackLoadTimeOut',\n // Identifier for fragment load error - data: { frag : fragment object, response : { code: error code, text: error text }}\n FRAG_LOAD_ERROR = 'fragLoadError',\n // Identifier for fragment load timeout error - data: { frag : fragment object}\n FRAG_LOAD_TIMEOUT = 'fragLoadTimeOut',\n // Identifier for a fragment decryption error event - data: {id : demuxer Id,frag: fragment object, reason : parsing error description }\n FRAG_DECRYPT_ERROR = 'fragDecryptError',\n // Identifier for a fragment parsing error event - data: { id : demuxer Id, reason : parsing error description }\n // will be renamed DEMUX_PARSING_ERROR and switched to MUX_ERROR in the next major release\n FRAG_PARSING_ERROR = 'fragParsingError',\n // Identifier for a remux alloc error event - data: { id : demuxer Id, frag : fragment object, bytes : nb of bytes on which allocation failed , reason : error text }\n REMUX_ALLOC_ERROR = 'remuxAllocError',\n // Identifier for decrypt key load error - data: { frag : fragment object, response : { code: error code, text: error text }}\n KEY_LOAD_ERROR = 'keyLoadError',\n // Identifier for decrypt key load timeout error - data: { frag : fragment object}\n KEY_LOAD_TIMEOUT = 'keyLoadTimeOut',\n // Triggered when an exception occurs while adding a sourceBuffer to MediaSource - data : { err : exception , mimeType : mimeType }\n BUFFER_ADD_CODEC_ERROR = 'bufferAddCodecError',\n // Identifier for a buffer append error - data: append error description\n BUFFER_APPEND_ERROR = 'bufferAppendError',\n // Identifier for a buffer appending error event - data: appending error description\n BUFFER_APPENDING_ERROR = 'bufferAppendingError',\n // Identifier for a buffer stalled error event\n BUFFER_STALLED_ERROR = 'bufferStalledError',\n // Identifier for a buffer full event\n BUFFER_FULL_ERROR = 'bufferFullError',\n // Identifier for a buffer seek over hole event\n BUFFER_SEEK_OVER_HOLE = 'bufferSeekOverHole',\n // Identifier for a buffer nudge on stall (playback is stuck although currentTime is in a buffered area)\n BUFFER_NUDGE_ON_STALL = 'bufferNudgeOnStall',\n // Identifier for an internal exception happening inside hls.js while handling an event\n INTERNAL_EXCEPTION = 'internalException'\n}\n","/**\n * @readonly\n * @enum {string}\n */\nconst HlsEvents = {\n // fired before MediaSource is attaching to media element - data: { media }\n MEDIA_ATTACHING: 'hlsMediaAttaching',\n // fired when MediaSource has been succesfully attached to media element - data: { }\n MEDIA_ATTACHED: 'hlsMediaAttached',\n // fired before detaching MediaSource from media element - data: { }\n MEDIA_DETACHING: 'hlsMediaDetaching',\n // fired when MediaSource has been detached from media element - data: { }\n MEDIA_DETACHED: 'hlsMediaDetached',\n // fired when we buffer is going to be reset - data: { }\n BUFFER_RESET: 'hlsBufferReset',\n // fired when we know about the codecs that we need buffers for to push into - data: {tracks : { container, codec, levelCodec, initSegment, metadata }}\n BUFFER_CODECS: 'hlsBufferCodecs',\n // fired when sourcebuffers have been created - data: { tracks : tracks }\n BUFFER_CREATED: 'hlsBufferCreated',\n // fired when we append a segment to the buffer - data: { segment: segment object }\n BUFFER_APPENDING: 'hlsBufferAppending',\n // fired when we are done with appending a media segment to the buffer - data : { parent : segment parent that triggered BUFFER_APPENDING, pending : nb of segments waiting for appending for this segment parent}\n BUFFER_APPENDED: 'hlsBufferAppended',\n // fired when the stream is finished and we want to notify the media buffer that there will be no more data - data: { }\n BUFFER_EOS: 'hlsBufferEos',\n // fired when the media buffer should be flushed - data { startOffset, endOffset }\n BUFFER_FLUSHING: 'hlsBufferFlushing',\n // fired when the media buffer has been flushed - data: { }\n BUFFER_FLUSHED: 'hlsBufferFlushed',\n // fired to signal that a manifest loading starts - data: { url : manifestURL}\n MANIFEST_LOADING: 'hlsManifestLoading',\n // fired after manifest has been loaded - data: { levels : [available quality levels], audioTracks : [ available audio tracks], url : manifestURL, stats : { trequest, tfirst, tload, mtime}}\n MANIFEST_LOADED: 'hlsManifestLoaded',\n // fired after manifest has been parsed - data: { levels : [available quality levels], firstLevel : index of first quality level appearing in Manifest}\n MANIFEST_PARSED: 'hlsManifestParsed',\n // fired when a level switch is requested - data: { level : id of new level }\n LEVEL_SWITCHING: 'hlsLevelSwitching',\n // fired when a level switch is effective - data: { level : id of new level }\n LEVEL_SWITCHED: 'hlsLevelSwitched',\n // fired when a level playlist loading starts - data: { url : level URL, level : id of level being loaded}\n LEVEL_LOADING: 'hlsLevelLoading',\n // fired when a level playlist loading finishes - data: { details : levelDetails object, level : id of loaded level, stats : { trequest, tfirst, tload, mtime} }\n LEVEL_LOADED: 'hlsLevelLoaded',\n // fired when a level's details have been updated based on previous details, after it has been loaded - data: { details : levelDetails object, level : id of updated level }\n LEVEL_UPDATED: 'hlsLevelUpdated',\n // fired when a level's PTS information has been updated after parsing a fragment - data: { details : levelDetails object, level : id of updated level, drift: PTS drift observed when parsing last fragment }\n LEVEL_PTS_UPDATED: 'hlsLevelPtsUpdated',\n // fired to notify that levels have changed after removing a level - data: { levels : [available quality levels] }\n LEVELS_UPDATED: 'hlsLevelsUpdated',\n // fired to notify that audio track lists has been updated - data: { audioTracks : audioTracks }\n AUDIO_TRACKS_UPDATED: 'hlsAudioTracksUpdated',\n // fired when an audio track switching is requested - data: { id : audio track id }\n AUDIO_TRACK_SWITCHING: 'hlsAudioTrackSwitching',\n // fired when an audio track switch actually occurs - data: { id : audio track id }\n AUDIO_TRACK_SWITCHED: 'hlsAudioTrackSwitched',\n // fired when an audio track loading starts - data: { url : audio track URL, id : audio track id }\n AUDIO_TRACK_LOADING: 'hlsAudioTrackLoading',\n // fired when an audio track loading finishes - data: { details : levelDetails object, id : audio track id, stats : { trequest, tfirst, tload, mtime } }\n AUDIO_TRACK_LOADED: 'hlsAudioTrackLoaded',\n // fired to notify that subtitle track lists has been updated - data: { subtitleTracks : subtitleTracks }\n SUBTITLE_TRACKS_UPDATED: 'hlsSubtitleTracksUpdated',\n // fired when an subtitle track switch occurs - data: { id : subtitle track id }\n SUBTITLE_TRACK_SWITCH: 'hlsSubtitleTrackSwitch',\n // fired when a subtitle track loading starts - data: { url : subtitle track URL, id : subtitle track id }\n SUBTITLE_TRACK_LOADING: 'hlsSubtitleTrackLoading',\n // fired when a subtitle track loading finishes - data: { details : levelDetails object, id : subtitle track id, stats : { trequest, tfirst, tload, mtime } }\n SUBTITLE_TRACK_LOADED: 'hlsSubtitleTrackLoaded',\n // fired when a subtitle fragment has been processed - data: { success : boolean, frag : the processed frag }\n SUBTITLE_FRAG_PROCESSED: 'hlsSubtitleFragProcessed',\n // fired when a set of VTTCues to be managed externally has been parsed - data: { type: string, track: string, cues: [ VTTCue ] }\n CUES_PARSED: 'hlsCuesParsed',\n // fired when a text track to be managed externally is found - data: { tracks: [ { label: string, kind: string, default: boolean } ] }\n NON_NATIVE_TEXT_TRACKS_FOUND: 'hlsNonNativeTextTracksFound',\n // fired when the first timestamp is found - data: { id : demuxer id, initPTS: initPTS, frag : fragment object }\n INIT_PTS_FOUND: 'hlsInitPtsFound',\n // fired when a fragment loading starts - data: { frag : fragment object }\n FRAG_LOADING: 'hlsFragLoading',\n // fired when a fragment loading is progressing - data: { frag : fragment object, { trequest, tfirst, loaded } }\n FRAG_LOAD_PROGRESS: 'hlsFragLoadProgress',\n // Identifier for fragment load aborting for emergency switch down - data: { frag : fragment object }\n FRAG_LOAD_EMERGENCY_ABORTED: 'hlsFragLoadEmergencyAborted',\n // fired when a fragment loading is completed - data: { frag : fragment object, payload : fragment payload, stats : { trequest, tfirst, tload, length } }\n FRAG_LOADED: 'hlsFragLoaded',\n // fired when a fragment has finished decrypting - data: { id : demuxer id, frag: fragment object, payload : fragment payload, stats : { tstart, tdecrypt } }\n FRAG_DECRYPTED: 'hlsFragDecrypted',\n // fired when Init Segment has been extracted from fragment - data: { id : demuxer id, frag: fragment object, moov : moov MP4 box, codecs : codecs found while parsing fragment }\n FRAG_PARSING_INIT_SEGMENT: 'hlsFragParsingInitSegment',\n // fired when parsing sei text is completed - data: { id : demuxer id, frag: fragment object, samples : [ sei samples pes ] }\n FRAG_PARSING_USERDATA: 'hlsFragParsingUserdata',\n // fired when parsing id3 is completed - data: { id : demuxer id, frag: fragment object, samples : [ id3 samples pes ] }\n FRAG_PARSING_METADATA: 'hlsFragParsingMetadata',\n // fired when data have been extracted from fragment - data: { id : demuxer id, frag: fragment object, data1 : moof MP4 box or TS fragments, data2 : mdat MP4 box or null}\n FRAG_PARSING_DATA: 'hlsFragParsingData',\n // fired when fragment parsing is completed - data: { id : demuxer id, frag: fragment object }\n FRAG_PARSED: 'hlsFragParsed',\n // fired when fragment remuxed MP4 boxes have all been appended into SourceBuffer - data: { id : demuxer id, frag : fragment object, stats : { trequest, tfirst, tload, tparsed, tbuffered, length, bwEstimate } }\n FRAG_BUFFERED: 'hlsFragBuffered',\n // fired when fragment matching with current media position is changing - data : { id : demuxer id, frag : fragment object }\n FRAG_CHANGED: 'hlsFragChanged',\n // Identifier for a FPS drop event - data: { curentDropped, currentDecoded, totalDroppedFrames }\n FPS_DROP: 'hlsFpsDrop',\n // triggered when FPS drop triggers auto level capping - data: { level, droppedlevel }\n FPS_DROP_LEVEL_CAPPING: 'hlsFpsDropLevelCapping',\n // Identifier for an error event - data: { type : error type, details : error details, fatal : if true, hls.js cannot/will not try to recover, if false, hls.js will try to recover,other error specific data }\n ERROR: 'hlsError',\n // fired when hls.js instance starts destroying. Different from MEDIA_DETACHED as one could want to detach and reattach a media to the instance of hls.js to handle mid-rolls for example - data: { }\n DESTROYING: 'hlsDestroying',\n // fired when a decrypt key loading starts - data: { frag : fragment object }\n KEY_LOADING: 'hlsKeyLoading',\n // fired when a decrypt key loading is completed - data: { frag : fragment object, payload : key payload, stats : { trequest, tfirst, tload, length } }\n KEY_LOADED: 'hlsKeyLoaded',\n // fired upon stream controller state transitions - data: { previousState, nextState }\n STREAM_STATE_TRANSITION: 'hlsStreamStateTransition',\n // fired when the live back buffer is reached defined by the liveBackBufferLength config option - data : { bufferEnd: number }\n LIVE_BACK_BUFFER_REACHED: 'hlsLiveBackBufferReached'\n};\n\nexport default HlsEvents;\n","import Level from '../loader/level';\n\nexport interface LoaderContext {\n // target URL\n url: string\n // loader response type (arraybuffer or default response type for playlist)\n responseType: string\n // start byte range offset\n rangeStart?: number\n // end byte range offset\n rangeEnd?: number\n // true if onProgress should report partial chunk of loaded content\n progressData?: boolean\n}\n\nexport interface LoaderConfiguration {\n // Max number of load retries\n maxRetry: number\n // Timeout after which `onTimeOut` callback will be triggered\n // (if loading is still not finished after that delay)\n timeout: number\n // Delay between an I/O error and following connection retry (ms).\n // This to avoid spamming the server\n retryDelay: number\n // max connection retry delay (ms)\n maxRetryDelay: number\n}\n\nexport interface LoaderResponse {\n url: string,\n // TODO(jstackhouse): SharedArrayBuffer, es2017 extension to TS\n data: string | ArrayBuffer\n}\n\nexport interface LoaderStats {\n // performance.now() just after load() has been called\n trequest: number\n // performance.now() of first received byte\n tfirst: number\n // performance.now() on load complete\n tload: number\n // performance.now() on parse completion\n tparsed: number\n // number of loaded bytes\n loaded: number\n // total number of bytes\n total: number\n}\n\ntype LoaderOnSuccess < T extends LoaderContext > = (\n response: LoaderResponse,\n stats: LoaderStats,\n context: T,\n networkDetails: any\n) => void;\n\ntype LoaderOnProgress < T extends LoaderContext > = (\n stats: LoaderStats,\n context: T,\n data: string | ArrayBuffer,\n networkDetails: any,\n) => void;\n\ntype LoaderOnError < T extends LoaderContext > = (\n error: {\n // error status code\n code: number,\n // error description\n text: string,\n },\n context: T,\n networkDetails: any,\n) => void;\n\ntype LoaderOnTimeout < T extends LoaderContext > = (\n stats: LoaderStats,\n context: T,\n) => void;\n\nexport interface LoaderCallbacks{\n onSuccess: LoaderOnSuccess,\n onError: LoaderOnError,\n onTimeout: LoaderOnTimeout,\n onProgress?: LoaderOnProgress,\n}\n\nexport interface Loader {\n destroy(): void\n abort(): void\n load(\n context: LoaderContext,\n config: LoaderConfiguration,\n callbacks: LoaderCallbacks,\n ): void\n\n context: T\n}\n\n/**\n * `type` property values for this loaders' context object\n * @enum\n *\n */\nexport enum PlaylistContextType {\n MANIFEST = 'manifest',\n LEVEL = 'level',\n AUDIO_TRACK = 'audioTrack',\n SUBTITLE_TRACK= 'subtitleTrack'\n}\n\n/**\n * @enum {string}\n */\nexport enum PlaylistLevelType {\n MAIN = 'main',\n AUDIO = 'audio',\n SUBTITLE = 'subtitle'\n}\n\nexport interface PlaylistLoaderContext extends LoaderContext {\n loader?: Loader\n\n type: PlaylistContextType\n // the level index to load\n level: number | null\n // TODO: what is id?\n id: number | null\n // defines if the loader is handling a sidx request for the playlist\n isSidxRequest?: boolean\n // internal reprsentation of a parsed m3u8 level playlist\n levelDetails?: Level\n}\n","/*\n*\n* All objects in the event handling chain should inherit from this class\n*\n*/\n\nimport { logger } from './utils/logger';\nimport { ErrorTypes, ErrorDetails } from './errors';\nimport Event from './events';\nimport Hls from './hls';\n\nconst FORBIDDEN_EVENT_NAMES = {\n 'hlsEventGeneric': true,\n 'hlsHandlerDestroying': true,\n 'hlsHandlerDestroyed': true\n};\n\nclass EventHandler {\n hls: Hls;\n handledEvents: any[];\n useGenericHandler: boolean;\n\n constructor (hls: Hls, ...events: any[]) {\n this.hls = hls;\n this.onEvent = this.onEvent.bind(this);\n this.handledEvents = events;\n this.useGenericHandler = true;\n\n this.registerListeners();\n }\n\n destroy () {\n this.onHandlerDestroying();\n this.unregisterListeners();\n this.onHandlerDestroyed();\n }\n\n protected onHandlerDestroying () {}\n protected onHandlerDestroyed () {}\n\n isEventHandler () {\n return typeof this.handledEvents === 'object' && this.handledEvents.length && typeof this.onEvent === 'function';\n }\n\n registerListeners () {\n if (this.isEventHandler()) {\n this.handledEvents.forEach(function (event) {\n if (FORBIDDEN_EVENT_NAMES[event]) {\n throw new Error('Forbidden event-name: ' + event);\n }\n\n this.hls.on(event, this.onEvent);\n }, this);\n }\n }\n\n unregisterListeners () {\n if (this.isEventHandler()) {\n this.handledEvents.forEach(function (event) {\n this.hls.off(event, this.onEvent);\n }, this);\n }\n }\n\n /**\n * arguments: event (string), data (any)\n */\n onEvent (event: string, data: any) {\n this.onEventGeneric(event, data);\n }\n\n onEventGeneric (event: string, data: any) {\n let eventToFunction = function (event: string, data: any) {\n let funcName = 'on' + event.replace('hls', '');\n if (typeof this[funcName] !== 'function') {\n throw new Error(`Event ${event} has no generic handler in this ${this.constructor.name} class (tried ${funcName})`);\n }\n\n return this[funcName].bind(this, data);\n };\n try {\n eventToFunction.call(this, event, data).call();\n } catch (err) {\n logger.error(`An internal error happened while handling event ${event}. Error message: \"${err.message}\". Here is a stacktrace:`, err);\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.OTHER_ERROR, details: ErrorDetails.INTERNAL_EXCEPTION, fatal: false, event: event, err: err });\n }\n }\n}\n\nexport default EventHandler;\n","import { buildAbsoluteURL } from 'url-toolkit';\n\nexport default class LevelKey {\n private _uri: string | null = null;\n\n public baseuri: string;\n public reluri: string;\n public method: string | null = null;\n public key: Uint8Array | null = null;\n public iv: Uint8Array | null = null;\n\n constructor (baseURI: string, relativeURI: string) {\n this.baseuri = baseURI;\n this.reluri = relativeURI;\n }\n\n get uri () {\n if (!this._uri && this.reluri) {\n this._uri = buildAbsoluteURL(this.baseuri, this.reluri, { alwaysNormalize: true });\n }\n\n return this._uri;\n }\n}\n","\nimport { buildAbsoluteURL } from 'url-toolkit';\nimport { logger } from '../utils/logger';\nimport LevelKey from './level-key';\nimport { PlaylistLevelType } from '../types/loader';\n\nexport enum ElementaryStreamTypes {\n AUDIO = 'audio',\n VIDEO = 'video',\n}\n\nexport default class Fragment {\n private _url: string | null = null;\n private _byteRange: number[] | null = null;\n private _decryptdata: LevelKey | null = null;\n\n // Holds the types of data this fragment supports\n private _elementaryStreams: Record = {\n [ElementaryStreamTypes.AUDIO]: false,\n [ElementaryStreamTypes.VIDEO]: false\n };\n\n // deltaPTS tracks the change in presentation timestamp between fragments\n public deltaPTS: number = 0;\n\n public rawProgramDateTime: string | null = null;\n public programDateTime: number | null = null;\n public title: string | null = null;\n public tagList: Array = [];\n\n // TODO: Move at least baseurl to constructor.\n // Currently we do a two-pass construction as use the Fragment class almost like a object for holding parsing state.\n // It may make more sense to just use a POJO to keep state during the parsing phase.\n // Have Fragment be the representation once we have a known state?\n // Something to think on.\n\n // Discontinuity Counter\n public cc!: number;\n\n public type!: PlaylistLevelType;\n // relurl is the portion of the URL that comes from inside the playlist.\n public relurl!: string;\n // baseurl is the URL to the playlist\n public baseurl!: string;\n // EXTINF has to be present for a m3u8 to be considered valid\n public duration!: number;\n // When this segment starts in the timeline\n public start!: number;\n // sn notates the sequence number for a segment, and if set to a string can be 'initSegment'\n public sn: number | 'initSegment' = 0;\n\n public urlId: number = 0;\n // level matches this fragment to a index playlist\n public level: number = 0;\n // levelkey is the EXT-X-KEY that applies to this segment for decryption\n // core difference from the private field _decryptdata is the lack of the initialized IV\n // _decryptdata will set the IV for this segment based on the segment number in the fragment\n public levelkey?: LevelKey;\n\n // TODO(typescript-xhrloader)\n public loader: any;\n\n // setByteRange converts a EXT-X-BYTERANGE attribute into a two element array\n setByteRange (value: string, previousFrag?: Fragment) {\n const params = value.split('@', 2);\n const byteRange: number[] = [];\n if (params.length === 1) {\n byteRange[0] = previousFrag ? previousFrag.byteRangeEndOffset : 0;\n } else {\n byteRange[0] = parseInt(params[1]);\n }\n byteRange[1] = parseInt(params[0]) + byteRange[0];\n this._byteRange = byteRange;\n }\n\n get url () {\n if (!this._url && this.relurl) {\n this._url = buildAbsoluteURL(this.baseurl, this.relurl, { alwaysNormalize: true });\n }\n\n return this._url;\n }\n\n set url (value) {\n this._url = value;\n }\n\n get byteRange (): number[] {\n if (!this._byteRange) {\n return [];\n }\n\n return this._byteRange;\n }\n\n /**\n * @type {number}\n */\n get byteRangeStartOffset () {\n return this.byteRange[0];\n }\n\n get byteRangeEndOffset () {\n return this.byteRange[1];\n }\n\n get decryptdata (): LevelKey | null {\n if (!this.levelkey && !this._decryptdata) {\n return null;\n }\n\n if (!this._decryptdata && this.levelkey) {\n let sn = this.sn;\n if (typeof sn !== 'number') {\n // We are fetching decryption data for a initialization segment\n // If the segment was encrypted with AES-128\n // It must have an IV defined. We cannot substitute the Segment Number in.\n if (this.levelkey && this.levelkey.method === 'AES-128' && !this.levelkey.iv) {\n logger.warn(`missing IV for initialization segment with method=\"${this.levelkey.method}\" - compliance issue`);\n }\n\n /*\n Be converted to a Number.\n 'initSegment' will become NaN.\n NaN, which when converted through ToInt32() -> +0.\n ---\n Explicitly set sn to resulting value from implicit conversions 'initSegment' values for IV generation.\n */\n sn = 0;\n }\n this._decryptdata = this.setDecryptDataFromLevelKey(this.levelkey, sn);\n }\n\n return this._decryptdata;\n }\n\n get endProgramDateTime () {\n if (this.programDateTime === null) {\n return null;\n }\n\n if (!Number.isFinite(this.programDateTime)) {\n return null;\n }\n\n let duration = !Number.isFinite(this.duration) ? 0 : this.duration;\n\n return this.programDateTime + (duration * 1000);\n }\n\n get encrypted () {\n return !!((this.decryptdata && this.decryptdata.uri !== null) && (this.decryptdata.key === null));\n }\n\n /**\n * @param {ElementaryStreamTypes} type\n */\n addElementaryStream (type: ElementaryStreamTypes) {\n this._elementaryStreams[type] = true;\n }\n\n /**\n * @param {ElementaryStreamTypes} type\n */\n hasElementaryStream (type: ElementaryStreamTypes) {\n return this._elementaryStreams[type] === true;\n }\n\n /**\n * Utility method for parseLevelPlaylist to create an initialization vector for a given segment\n * @param {number} segmentNumber - segment number to generate IV with\n * @returns {Uint8Array}\n */\n createInitializationVector (segmentNumber: number): Uint8Array {\n let uint8View = new Uint8Array(16);\n\n for (let i = 12; i < 16; i++) {\n uint8View[i] = (segmentNumber >> 8 * (15 - i)) & 0xff;\n }\n\n return uint8View;\n }\n\n /**\n * Utility method for parseLevelPlaylist to get a fragment's decryption data from the currently parsed encryption key data\n * @param levelkey - a playlist's encryption info\n * @param segmentNumber - the fragment's segment number\n * @returns {LevelKey} - an object to be applied as a fragment's decryptdata\n */\n setDecryptDataFromLevelKey (levelkey: LevelKey, segmentNumber: number): LevelKey {\n let decryptdata = levelkey;\n\n if (levelkey?.method && levelkey.uri && !levelkey.iv) {\n decryptdata = new LevelKey(levelkey.baseuri, levelkey.reluri);\n decryptdata.method = levelkey.method;\n decryptdata.iv = this.createInitializationVector(segmentNumber);\n }\n\n return decryptdata;\n }\n}\n","export default class Level {\n constructor (baseUrl) {\n // Please keep properties in alphabetical order\n this.endCC = 0;\n this.endSN = 0;\n this.fragments = [];\n this.initSegment = null;\n this.live = true;\n this.needSidxRanges = false;\n this.startCC = 0;\n this.startSN = 0;\n this.startTimeOffset = null;\n this.targetduration = 0;\n this.totalduration = 0;\n this.type = null;\n this.url = baseUrl;\n this.version = null;\n }\n\n get hasProgramDateTime () {\n return !!(this.fragments[0] && Number.isFinite(this.fragments[0].programDateTime));\n }\n}\n","const DECIMAL_RESOLUTION_REGEX = /^(\\d+)x(\\d+)$/; // eslint-disable-line no-useless-escape\nconst ATTR_LIST_REGEX = /\\s*(.+?)\\s*=((?:\\\".*?\\\")|.*?)(?:,|$)/g; // eslint-disable-line no-useless-escape\n\n// adapted from https://github.com/kanongil/node-m3u8parse/blob/master/attrlist.js\nclass AttrList {\n constructor (attrs) {\n if (typeof attrs === 'string') {\n attrs = AttrList.parseAttrList(attrs);\n }\n\n for (let attr in attrs) {\n if (attrs.hasOwnProperty(attr)) {\n this[attr] = attrs[attr];\n }\n }\n }\n\n decimalInteger (attrName) {\n const intValue = parseInt(this[attrName], 10);\n if (intValue > Number.MAX_SAFE_INTEGER) {\n return Infinity;\n }\n\n return intValue;\n }\n\n hexadecimalInteger (attrName) {\n if (this[attrName]) {\n let stringValue = (this[attrName] || '0x').slice(2);\n stringValue = ((stringValue.length & 1) ? '0' : '') + stringValue;\n\n const value = new Uint8Array(stringValue.length / 2);\n for (let i = 0; i < stringValue.length / 2; i++) {\n value[i] = parseInt(stringValue.slice(i * 2, i * 2 + 2), 16);\n }\n\n return value;\n } else {\n return null;\n }\n }\n\n hexadecimalIntegerAsNumber (attrName) {\n const intValue = parseInt(this[attrName], 16);\n if (intValue > Number.MAX_SAFE_INTEGER) {\n return Infinity;\n }\n\n return intValue;\n }\n\n decimalFloatingPoint (attrName) {\n return parseFloat(this[attrName]);\n }\n\n enumeratedString (attrName) {\n return this[attrName];\n }\n\n decimalResolution (attrName) {\n const res = DECIMAL_RESOLUTION_REGEX.exec(this[attrName]);\n if (res === null) {\n return undefined;\n }\n\n return {\n width: parseInt(res[1], 10),\n height: parseInt(res[2], 10)\n };\n }\n\n static parseAttrList (input) {\n let match, attrs = {};\n ATTR_LIST_REGEX.lastIndex = 0;\n while ((match = ATTR_LIST_REGEX.exec(input)) !== null) {\n let value = match[2], quote = '\"';\n\n if (value.indexOf(quote) === 0 &&\n value.lastIndexOf(quote) === (value.length - 1)) {\n value = value.slice(1, -1);\n }\n\n attrs[match[1]] = value;\n }\n return attrs;\n }\n}\n\nexport default AttrList;\n","// from http://mp4ra.org/codecs.html\nconst sampleEntryCodesISO = {\n audio: {\n 'a3ds': true,\n 'ac-3': true,\n 'ac-4': true,\n 'alac': true,\n 'alaw': true,\n 'dra1': true,\n 'dts+': true,\n 'dts-': true,\n 'dtsc': true,\n 'dtse': true,\n 'dtsh': true,\n 'ec-3': true,\n 'enca': true,\n 'g719': true,\n 'g726': true,\n 'm4ae': true,\n 'mha1': true,\n 'mha2': true,\n 'mhm1': true,\n 'mhm2': true,\n 'mlpa': true,\n 'mp4a': true,\n 'raw ': true,\n 'Opus': true,\n 'samr': true,\n 'sawb': true,\n 'sawp': true,\n 'sevc': true,\n 'sqcp': true,\n 'ssmv': true,\n 'twos': true,\n 'ulaw': true\n },\n video: {\n 'avc1': true,\n 'avc2': true,\n 'avc3': true,\n 'avc4': true,\n 'avcp': true,\n 'drac': true,\n 'dvav': true,\n 'dvhe': true,\n 'encv': true,\n 'hev1': true,\n 'hvc1': true,\n 'mjp2': true,\n 'mp4v': true,\n 'mvc1': true,\n 'mvc2': true,\n 'mvc3': true,\n 'mvc4': true,\n 'resv': true,\n 'rv60': true,\n 's263': true,\n 'svc1': true,\n 'svc2': true,\n 'vc-1': true,\n 'vp08': true,\n 'vp09': true\n }\n};\n\nexport type CodecType = 'audio' | 'video';\n\nfunction isCodecType (codec: string, type: CodecType): boolean {\n const typeCodes = sampleEntryCodesISO[type];\n return !!typeCodes && typeCodes[codec.slice(0, 4)] === true;\n}\n\nfunction isCodecSupportedInMp4 (codec: string, type: CodecType): boolean {\n return MediaSource.isTypeSupported(`${type || 'video'}/mp4;codecs=\"${codec}\"`);\n}\n\nexport { isCodecType, isCodecSupportedInMp4 };\n","import * as URLToolkit from 'url-toolkit';\n\nimport Fragment from './fragment';\nimport Level from './level';\nimport LevelKey from './level-key';\n\nimport AttrList from '../utils/attr-list';\nimport { logger } from '../utils/logger';\nimport { isCodecType, CodecType } from '../utils/codecs';\nimport { MediaPlaylist, AudioGroup, MediaPlaylistType } from '../types/media-playlist';\nimport { PlaylistLevelType } from '../types/loader';\n\n/**\n * M3U8 parser\n * @module\n */\n\n// https://regex101.com is your friend\nconst MASTER_PLAYLIST_REGEX = /(?:#EXT-X-STREAM-INF:([^\\n\\r]*)[\\r\\n]+([^\\r\\n]+)|#EXT-X-SESSION-DATA:([^\\n\\r]*)[\\r\\n]+)/g;\nconst MASTER_PLAYLIST_MEDIA_REGEX = /#EXT-X-MEDIA:(.*)/g;\n\nconst LEVEL_PLAYLIST_REGEX_FAST = new RegExp([\n /#EXTINF:\\s*(\\d*(?:\\.\\d+)?)(?:,(.*)\\s+)?/.source, // duration (#EXTINF:,), group 1 => duration, group 2 => title\n /|(?!#)([\\S+ ?]+)/.source, // segment URI, group 3 => the URI (note newline is not eaten)\n /|#EXT-X-BYTERANGE:*(.+)/.source, // next segment's byterange, group 4 => range spec (x@y)\n /|#EXT-X-PROGRAM-DATE-TIME:(.+)/.source, // next segment's program date/time group 5 => the datetime spec\n /|#.*/.source // All other non-segment oriented tags will match with all groups empty\n].join(''), 'g');\n\nconst LEVEL_PLAYLIST_REGEX_SLOW = /(?:(?:#(EXTM3U))|(?:#EXT-X-(PLAYLIST-TYPE):(.+))|(?:#EXT-X-(MEDIA-SEQUENCE): *(\\d+))|(?:#EXT-X-(TARGETDURATION): *(\\d+))|(?:#EXT-X-(KEY):(.+))|(?:#EXT-X-(START):(.+))|(?:#EXT-X-(ENDLIST))|(?:#EXT-X-(DISCONTINUITY-SEQ)UENCE:(\\d+))|(?:#EXT-X-(DIS)CONTINUITY))|(?:#EXT-X-(VERSION):(\\d+))|(?:#EXT-X-(MAP):(.+))|(?:(#)([^:]*):(.*))|(?:(#)(.*))(?:.*)\\r?\\n?/;\n\nconst MP4_REGEX_SUFFIX = /\\.(mp4|m4s|m4v|m4a)$/i;\n\nexport default class M3U8Parser {\n static findGroup (groups: Array<AudioGroup>, mediaGroupId: string): AudioGroup | undefined {\n for (let i = 0; i < groups.length; i++) {\n const group = groups[i];\n if (group.id === mediaGroupId) {\n return group;\n }\n }\n }\n\n static convertAVC1ToAVCOTI (codec) {\n let avcdata = codec.split('.');\n let result;\n if (avcdata.length > 2) {\n result = avcdata.shift() + '.';\n result += parseInt(avcdata.shift()).toString(16);\n result += ('000' + parseInt(avcdata.shift()).toString(16)).substr(-4);\n } else {\n result = codec;\n }\n return result;\n }\n\n static resolve (url, baseUrl) {\n return URLToolkit.buildAbsoluteURL(baseUrl, url, { alwaysNormalize: true });\n }\n\n static parseMasterPlaylist (string: string, baseurl: string) {\n // TODO(typescript-level)\n let levels: Array<any> = [];\n let sessionData: Record<string, AttrList> = {};\n let hasSessionData = false;\n MASTER_PLAYLIST_REGEX.lastIndex = 0;\n\n // TODO(typescript-level)\n function setCodecs (codecs: Array<string>, level: any) {\n ['video', 'audio'].forEach((type: CodecType) => {\n const filtered = codecs.filter((codec) => isCodecType(codec, type));\n if (filtered.length) {\n const preferred = filtered.filter((codec) => {\n return codec.lastIndexOf('avc1', 0) === 0 || codec.lastIndexOf('mp4a', 0) === 0;\n });\n level[`${type}Codec`] = preferred.length > 0 ? preferred[0] : filtered[0];\n\n // remove from list\n codecs = codecs.filter((codec) => filtered.indexOf(codec) === -1);\n }\n });\n\n level.unknownCodecs = codecs;\n }\n\n let result: RegExpExecArray | null;\n while ((result = MASTER_PLAYLIST_REGEX.exec(string)) != null) {\n if (result[1]) {\n // '#EXT-X-STREAM-INF' is found, parse level tag in group 1\n\n // TODO(typescript-level)\n const level: any = {};\n\n const attrs = level.attrs = new AttrList(result[1]);\n level.url = M3U8Parser.resolve(result[2], baseurl);\n\n const resolution = attrs.decimalResolution('RESOLUTION');\n if (resolution) {\n level.width = resolution.width;\n level.height = resolution.height;\n }\n level.bitrate = attrs.decimalInteger('AVERAGE-BANDWIDTH') || attrs.decimalInteger('BANDWIDTH');\n level.name = attrs.NAME;\n\n setCodecs([].concat((attrs.CODECS || '').split(/[ ,]+/)), level);\n\n if (level.videoCodec && level.videoCodec.indexOf('avc1') !== -1) {\n level.videoCodec = M3U8Parser.convertAVC1ToAVCOTI(level.videoCodec);\n }\n\n levels.push(level);\n } else if (result[3]) {\n // '#EXT-X-SESSION-DATA' is found, parse session data in group 3\n let sessionAttrs = new AttrList(result[3]);\n if (sessionAttrs['DATA-ID']) {\n hasSessionData = true;\n sessionData[sessionAttrs['DATA-ID']] = sessionAttrs;\n }\n }\n }\n return {\n levels,\n sessionData: hasSessionData ? sessionData : null\n };\n }\n\n static parseMasterPlaylistMedia (string: string, baseurl: string, type: MediaPlaylistType, audioGroups: Array<AudioGroup> = []): Array<MediaPlaylist> {\n let result: RegExpExecArray | null;\n let medias: Array<MediaPlaylist> = [];\n let id = 0;\n MASTER_PLAYLIST_MEDIA_REGEX.lastIndex = 0;\n while ((result = MASTER_PLAYLIST_MEDIA_REGEX.exec(string)) !== null) {\n const attrs = new AttrList(result[1]);\n if (attrs.TYPE === type) {\n const media: MediaPlaylist = {\n attrs,\n id: id++,\n groupId: attrs['GROUP-ID'],\n instreamId: attrs['INSTREAM-ID'],\n name: attrs.NAME || attrs.LANGUAGE,\n type,\n default: (attrs.DEFAULT === 'YES'),\n autoselect: (attrs.AUTOSELECT === 'YES'),\n forced: (attrs.FORCED === 'YES'),\n lang: attrs.LANGUAGE\n };\n\n if (attrs.URI) {\n media.url = M3U8Parser.resolve(attrs.URI, baseurl);\n }\n\n if (audioGroups.length) {\n // If there are audio groups signalled in the manifest, let's look for a matching codec string for this track\n const groupCodec = M3U8Parser.findGroup(audioGroups, media.groupId as string);\n\n // If we don't find the track signalled, lets use the first audio groups codec we have\n // Acting as a best guess\n media.audioCodec = groupCodec ? groupCodec.codec : audioGroups[0].codec;\n }\n\n medias.push(media);\n }\n }\n return medias;\n }\n\n static parseLevelPlaylist (string: string, baseurl: string, id: number, type: PlaylistLevelType, levelUrlId: number) {\n let currentSN = 0;\n let totalduration = 0;\n let level = new Level(baseurl);\n let discontinuityCounter = 0;\n let prevFrag: Fragment | null = null;\n let frag: Fragment | null = new Fragment();\n let result: RegExpExecArray | RegExpMatchArray | null;\n let i: number;\n let levelkey: LevelKey | undefined;\n\n let firstPdtIndex = null;\n\n LEVEL_PLAYLIST_REGEX_FAST.lastIndex = 0;\n\n while ((result = LEVEL_PLAYLIST_REGEX_FAST.exec(string)) !== null) {\n const duration = result[1];\n if (duration) { // INF\n frag.duration = parseFloat(duration);\n // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n const title = (' ' + result[2]).slice(1);\n frag.title = title || null;\n frag.tagList.push(title ? [ 'INF', duration, title ] : [ 'INF', duration ]);\n } else if (result[3]) { // url\n if (Number.isFinite(frag.duration)) {\n const sn = currentSN++;\n frag.type = type;\n frag.start = totalduration;\n if (levelkey) {\n frag.levelkey = levelkey;\n }\n frag.sn = sn;\n frag.level = id;\n frag.cc = discontinuityCounter;\n frag.urlId = levelUrlId;\n frag.baseurl = baseurl;\n // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n frag.relurl = (' ' + result[3]).slice(1);\n assignProgramDateTime(frag, prevFrag);\n\n level.fragments.push(frag);\n prevFrag = frag;\n totalduration += frag.duration;\n\n frag = new Fragment();\n }\n } else if (result[4]) { // X-BYTERANGE\n const data = (' ' + result[4]).slice(1);\n if (prevFrag) {\n frag.setByteRange(data, prevFrag);\n } else {\n frag.setByteRange(data);\n }\n } else if (result[5]) { // PROGRAM-DATE-TIME\n // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n frag.rawProgramDateTime = (' ' + result[5]).slice(1);\n frag.tagList.push(['PROGRAM-DATE-TIME', frag.rawProgramDateTime]);\n if (firstPdtIndex === null) {\n firstPdtIndex = level.fragments.length;\n }\n } else {\n result = result[0].match(LEVEL_PLAYLIST_REGEX_SLOW);\n if (!result) {\n logger.warn('No matches on slow regex match for level playlist!');\n continue;\n }\n for (i = 1; i < result.length; i++) {\n if (typeof result[i] !== 'undefined') {\n break;\n }\n }\n\n // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n const value1 = (' ' + result[i + 1]).slice(1);\n const value2 = (' ' + result[i + 2]).slice(1);\n\n switch (result[i]) {\n case '#':\n frag.tagList.push(value2 ? [ value1, value2 ] : [ value1 ]);\n break;\n case 'PLAYLIST-TYPE':\n level.type = value1.toUpperCase();\n break;\n case 'MEDIA-SEQUENCE':\n currentSN = level.startSN = parseInt(value1);\n break;\n case 'TARGETDURATION':\n level.targetduration = parseFloat(value1);\n break;\n case 'VERSION':\n level.version = parseInt(value1);\n break;\n case 'EXTM3U':\n break;\n case 'ENDLIST':\n level.live = false;\n break;\n case 'DIS':\n discontinuityCounter++;\n frag.tagList.push(['DIS']);\n break;\n case 'DISCONTINUITY-SEQ':\n discontinuityCounter = parseInt(value1);\n break;\n case 'KEY': {\n // https://tools.ietf.org/html/rfc8216#section-4.3.2.4\n const decryptparams = value1;\n const keyAttrs = new AttrList(decryptparams);\n const decryptmethod = keyAttrs.enumeratedString('METHOD');\n const decrypturi = keyAttrs.URI;\n const decryptiv = keyAttrs.hexadecimalInteger('IV');\n // From RFC: This attribute is OPTIONAL; its absence indicates an implicit value of \"identity\".\n const decryptkeyformat = keyAttrs.KEYFORMAT || 'identity';\n\n if (decryptkeyformat === 'com.apple.streamingkeydelivery') {\n logger.warn('Keyformat com.apple.streamingkeydelivery is not supported');\n continue;\n }\n\n if (decryptmethod) {\n levelkey = new LevelKey(baseurl, decrypturi);\n if ((decrypturi) && (['AES-128', 'SAMPLE-AES', 'SAMPLE-AES-CENC'].indexOf(decryptmethod) >= 0)) {\n levelkey.method = decryptmethod;\n levelkey.key = null;\n // Initialization Vector (IV)\n levelkey.iv = decryptiv;\n }\n }\n break;\n }\n case 'START': {\n const startAttrs = new AttrList(value1);\n const startTimeOffset = startAttrs.decimalFloatingPoint('TIME-OFFSET');\n // TIME-OFFSET can be 0\n if (Number.isFinite(startTimeOffset)) {\n level.startTimeOffset = startTimeOffset;\n }\n break;\n }\n case 'MAP': {\n const mapAttrs = new AttrList(value1);\n frag.relurl = mapAttrs.URI;\n if (mapAttrs.BYTERANGE) {\n frag.setByteRange(mapAttrs.BYTERANGE);\n }\n frag.baseurl = baseurl;\n frag.level = id;\n frag.type = type;\n frag.sn = 'initSegment';\n level.initSegment = frag;\n frag = new Fragment();\n frag.rawProgramDateTime = level.initSegment.rawProgramDateTime;\n break;\n }\n default:\n logger.warn(`line parsed but not handled: ${result}`);\n break;\n }\n }\n }\n frag = prevFrag;\n // logger.log('found ' + level.fragments.length + ' fragments');\n if (frag && !frag.relurl) {\n level.fragments.pop();\n totalduration -= frag.duration;\n }\n level.totalduration = totalduration;\n level.averagetargetduration = totalduration / level.fragments.length;\n level.endSN = currentSN - 1;\n level.startCC = level.fragments[0] ? level.fragments[0].cc : 0;\n level.endCC = discontinuityCounter;\n\n if (!level.initSegment && level.fragments.length) {\n // this is a bit lurky but HLS really has no other way to tell us\n // if the fragments are TS or MP4, except if we download them :/\n // but this is to be able to handle SIDX.\n if (level.fragments.every((frag) => MP4_REGEX_SUFFIX.test(frag.relurl))) {\n logger.warn('MP4 fragments found but no init segment (probably no MAP, incomplete M3U8), trying to fetch SIDX');\n\n frag = new Fragment();\n frag.relurl = level.fragments[0].relurl;\n frag.baseurl = baseurl;\n frag.level = id;\n frag.type = type;\n frag.sn = 'initSegment';\n\n level.initSegment = frag;\n level.needSidxRanges = true;\n }\n }\n\n /**\n * Backfill any missing PDT values\n \"If the first EXT-X-PROGRAM-DATE-TIME tag in a Playlist appears after\n one or more Media Segment URIs, the client SHOULD extrapolate\n backward from that tag (using EXTINF durations and/or media\n timestamps) to associate dates with those segments.\"\n * We have already extrapolated forward, but all fragments up to the first instance of PDT do not have their PDTs\n * computed.\n */\n if (firstPdtIndex) {\n backfillProgramDateTimes(level.fragments, firstPdtIndex);\n }\n\n return level;\n }\n}\n\nfunction backfillProgramDateTimes (fragments, startIndex) {\n let fragPrev = fragments[startIndex];\n for (let i = startIndex - 1; i >= 0; i--) {\n const frag = fragments[i];\n frag.programDateTime = fragPrev.programDateTime - (frag.duration * 1000);\n fragPrev = frag;\n }\n}\n\nfunction assignProgramDateTime (frag, prevFrag) {\n if (frag.rawProgramDateTime) {\n frag.programDateTime = Date.parse(frag.rawProgramDateTime);\n } else if (prevFrag?.programDateTime) {\n frag.programDateTime = prevFrag.endProgramDateTime;\n }\n\n if (!Number.isFinite(frag.programDateTime)) {\n frag.programDateTime = null;\n frag.rawProgramDateTime = null;\n }\n}\n","/**\n * PlaylistLoader - delegate for media manifest/playlist loading tasks. Takes care of parsing media to internal data-models.\n *\n * Once loaded, dispatches events with parsed data-models of manifest/levels/audio/subtitle tracks.\n *\n * Uses loader(s) set in config to do actual internal loading of resource tasks.\n *\n * @module\n *\n */\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport { Loader, PlaylistContextType, PlaylistLoaderContext, PlaylistLevelType, LoaderCallbacks, LoaderResponse, LoaderStats, LoaderConfiguration } from '../types/loader';\nimport MP4Demuxer from '../demux/mp4demuxer';\nimport M3U8Parser from './m3u8-parser';\nimport { AudioGroup } from '../types/media-playlist';\n\nconst { performance } = window;\n\n/**\n * @constructor\n */\nclass PlaylistLoader extends EventHandler {\n private loaders: Partial<Record<PlaylistContextType, Loader<PlaylistLoaderContext>>> = {};\n\n /**\n * @constructs\n * @param {Hls} hls\n */\n constructor (hls) {\n super(hls,\n Event.MANIFEST_LOADING,\n Event.LEVEL_LOADING,\n Event.AUDIO_TRACK_LOADING,\n Event.SUBTITLE_TRACK_LOADING);\n }\n\n /**\n * @param {PlaylistContextType} type\n * @returns {boolean}\n */\n static canHaveQualityLevels (type: PlaylistContextType): boolean {\n return (type !== PlaylistContextType.AUDIO_TRACK &&\n type !== PlaylistContextType.SUBTITLE_TRACK);\n }\n\n /**\n * Map context.type to LevelType\n * @param {PlaylistLoaderContext} context\n * @returns {LevelType}\n */\n static mapContextToLevelType (context: PlaylistLoaderContext): PlaylistLevelType {\n const { type } = context;\n\n switch (type) {\n case PlaylistContextType.AUDIO_TRACK:\n return PlaylistLevelType.AUDIO;\n case PlaylistContextType.SUBTITLE_TRACK:\n return PlaylistLevelType.SUBTITLE;\n default:\n return PlaylistLevelType.MAIN;\n }\n }\n\n static getResponseUrl (response: LoaderResponse, context: PlaylistLoaderContext): string {\n let url = response.url;\n // responseURL not supported on some browsers (it is used to detect URL redirection)\n // data-uri mode also not supported (but no need to detect redirection)\n if (url === undefined || url.indexOf('data:') === 0) {\n // fallback to initial URL\n url = context.url;\n }\n return url;\n }\n\n /**\n * Returns defaults or configured loader-type overloads (pLoader and loader config params)\n * Default loader is XHRLoader (see utils)\n * @param {PlaylistLoaderContext} context\n * @returns {Loader} or other compatible configured overload\n */\n createInternalLoader (context: PlaylistLoaderContext): Loader<PlaylistLoaderContext> {\n const config = this.hls.config;\n const PLoader = config.pLoader;\n const Loader = config.loader;\n // TODO(typescript-config): Verify once config is typed that InternalLoader always returns a Loader\n const InternalLoader = PLoader || Loader;\n\n const loader = new InternalLoader(config);\n\n // TODO - Do we really need to assign the instance or if the dep has been lost\n context.loader = loader;\n this.loaders[context.type] = loader;\n\n return loader;\n }\n\n getInternalLoader (context: PlaylistLoaderContext): Loader<PlaylistLoaderContext> | undefined {\n return this.loaders[context.type];\n }\n\n resetInternalLoader (contextType: PlaylistContextType) {\n if (this.loaders[contextType]) {\n delete this.loaders[contextType];\n }\n }\n\n /**\n * Call `destroy` on all internal loader instances mapped (one per context type)\n */\n destroyInternalLoaders () {\n for (let contextType in this.loaders) {\n let loader = this.loaders[contextType];\n if (loader) {\n loader.destroy();\n }\n\n this.resetInternalLoader(contextType as PlaylistContextType);\n }\n }\n\n destroy () {\n this.destroyInternalLoaders();\n\n super.destroy();\n }\n\n onManifestLoading (data: { url: string; }) {\n this.load({\n url: data.url,\n type: PlaylistContextType.MANIFEST,\n level: 0,\n id: null,\n responseType: 'text'\n });\n }\n\n onLevelLoading (data: { url: string; level: number | null; id: number | null; }) {\n this.load({\n url: data.url,\n type: PlaylistContextType.LEVEL,\n level: data.level,\n id: data.id,\n responseType: 'text'\n });\n }\n\n onAudioTrackLoading (data: { url: string; id: number | null; }) {\n this.load({\n url: data.url,\n type: PlaylistContextType.AUDIO_TRACK,\n level: null,\n id: data.id,\n responseType: 'text'\n });\n }\n\n onSubtitleTrackLoading (data: { url: string; id: number | null; }) {\n this.load({\n url: data.url,\n type: PlaylistContextType.SUBTITLE_TRACK,\n level: null,\n id: data.id,\n responseType: 'text'\n });\n }\n\n load (context: PlaylistLoaderContext): boolean {\n const config = this.hls.config;\n\n logger.debug(`Loading playlist of type ${context.type}, level: ${context.level}, id: ${context.id}`);\n\n // Check if a loader for this context already exists\n let loader = this.getInternalLoader(context);\n if (loader) {\n const loaderContext = loader.context;\n if (loaderContext && loaderContext.url === context.url) { // same URL can't overlap\n logger.trace('playlist request ongoing');\n return false;\n } else {\n logger.warn(`aborting previous loader for type: ${context.type}`);\n loader.abort();\n }\n }\n\n let maxRetry: number;\n let timeout: number;\n let retryDelay: number;\n let maxRetryDelay: number;\n\n // apply different configs for retries depending on\n // context (manifest, level, audio/subs playlist)\n switch (context.type) {\n case PlaylistContextType.MANIFEST:\n maxRetry = config.manifestLoadingMaxRetry;\n timeout = config.manifestLoadingTimeOut;\n retryDelay = config.manifestLoadingRetryDelay;\n maxRetryDelay = config.manifestLoadingMaxRetryTimeout;\n break;\n case PlaylistContextType.LEVEL:\n // Disable internal loader retry logic, since we are managing retries in Level Controller\n maxRetry = 0;\n maxRetryDelay = 0;\n retryDelay = 0;\n timeout = config.levelLoadingTimeOut;\n // TODO Introduce retry settings for audio-track and subtitle-track, it should not use level retry config\n break;\n default:\n maxRetry = config.levelLoadingMaxRetry;\n timeout = config.levelLoadingTimeOut;\n retryDelay = config.levelLoadingRetryDelay;\n maxRetryDelay = config.levelLoadingMaxRetryTimeout;\n break;\n }\n\n loader = this.createInternalLoader(context);\n\n const loaderConfig: LoaderConfiguration = {\n timeout,\n maxRetry,\n retryDelay,\n maxRetryDelay\n };\n\n const loaderCallbacks: LoaderCallbacks<PlaylistLoaderContext> = {\n onSuccess: this.loadsuccess.bind(this),\n onError: this.loaderror.bind(this),\n onTimeout: this.loadtimeout.bind(this)\n };\n\n logger.debug(`Calling internal loader delegate for URL: ${context.url}`);\n loader.load(context, loaderConfig, loaderCallbacks);\n\n return true;\n }\n\n loadsuccess (response: LoaderResponse, stats: LoaderStats, context: PlaylistLoaderContext, networkDetails: unknown = null) {\n if (context.isSidxRequest) {\n this._handleSidxRequest(response, context);\n this._handlePlaylistLoaded(response, stats, context, networkDetails);\n return;\n }\n\n this.resetInternalLoader(context.type);\n if (typeof response.data !== 'string') {\n throw new Error('expected responseType of \"text\" for PlaylistLoader');\n }\n\n const string = response.data;\n\n stats.tload = performance.now();\n // stats.mtime = new Date(target.getResponseHeader('Last-Modified'));\n\n // Validate if it is an M3U8 at all\n if (string.indexOf('#EXTM3U') !== 0) {\n this._handleManifestParsingError(response, context, 'no EXTM3U delimiter', networkDetails);\n return;\n }\n\n // Check if chunk-list or master. handle empty chunk list case (first EXTINF not signaled, but TARGETDURATION present)\n if (string.indexOf('#EXTINF:') > 0 || string.indexOf('#EXT-X-TARGETDURATION:') > 0) {\n this._handleTrackOrLevelPlaylist(response, stats, context, networkDetails);\n } else {\n this._handleMasterPlaylist(response, stats, context, networkDetails);\n }\n }\n\n loaderror (response: LoaderResponse, context: PlaylistLoaderContext, networkDetails = null) {\n this._handleNetworkError(context, networkDetails, false, response);\n }\n\n loadtimeout (stats: LoaderStats, context: PlaylistLoaderContext, networkDetails = null) {\n this._handleNetworkError(context, networkDetails, true);\n }\n\n // TODO(typescript-config): networkDetails can currently be a XHR or Fetch impl,\n // but with custom loaders it could be generic investigate this further when config is typed\n _handleMasterPlaylist (response: LoaderResponse, stats: LoaderStats, context: PlaylistLoaderContext, networkDetails: unknown) {\n const hls = this.hls;\n const string = response.data as string;\n\n const url = PlaylistLoader.getResponseUrl(response, context);\n const { levels, sessionData } = M3U8Parser.parseMasterPlaylist(string, url);\n if (!levels.length) {\n this._handleManifestParsingError(response, context, 'no level found in manifest', networkDetails);\n return;\n }\n\n // multi level playlist, parse level info\n const audioGroups: Array<AudioGroup> = levels.map(level => ({\n id: level.attrs.AUDIO,\n codec: level.audioCodec\n }));\n\n const audioTracks = M3U8Parser.parseMasterPlaylistMedia(string, url, 'AUDIO', audioGroups);\n const subtitles = M3U8Parser.parseMasterPlaylistMedia(string, url, 'SUBTITLES');\n const captions = M3U8Parser.parseMasterPlaylistMedia(string, url, 'CLOSED-CAPTIONS');\n\n if (audioTracks.length) {\n // check if we have found an audio track embedded in main playlist (audio track without URI attribute)\n let embeddedAudioFound = false;\n audioTracks.forEach(audioTrack => {\n if (!audioTrack.url) {\n embeddedAudioFound = true;\n }\n });\n\n // if no embedded audio track defined, but audio codec signaled in quality level,\n // we need to signal this main audio track this could happen with playlists with\n // alt audio rendition in which quality levels (main)\n // contains both audio+video. but with mixed audio track not signaled\n if (embeddedAudioFound === false && levels[0].audioCodec && !levels[0].attrs.AUDIO) {\n logger.log('audio codec signaled in quality level, but no embedded audio track signaled, create one');\n audioTracks.unshift({\n type: 'main',\n name: 'main',\n default: false,\n autoselect: false,\n forced: false,\n id: -1,\n attrs: {},\n url: ''\n });\n }\n }\n\n hls.trigger(Event.MANIFEST_LOADED, {\n levels,\n audioTracks,\n subtitles,\n captions,\n url,\n stats,\n networkDetails,\n sessionData\n });\n }\n\n _handleTrackOrLevelPlaylist (response: LoaderResponse, stats: LoaderStats, context: PlaylistLoaderContext, networkDetails: unknown) {\n const hls = this.hls;\n\n const { id, level, type } = context;\n\n const url = PlaylistLoader.getResponseUrl(response, context);\n\n // if the values are null, they will result in the else conditional\n const levelUrlId = Number.isFinite(id as number) ? id as number : 0;\n const levelId = Number.isFinite(level as number) ? level as number : levelUrlId;\n\n const levelType = PlaylistLoader.mapContextToLevelType(context);\n const levelDetails = M3U8Parser.parseLevelPlaylist(response.data as string, url, levelId, levelType, levelUrlId);\n\n // set stats on level structure\n // TODO(jstackhouse): why? mixing concerns, is it just treated as value bag?\n (levelDetails as any).tload = stats.tload;\n\n if (!levelDetails.fragments.length) {\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.NETWORK_ERROR,\n details: ErrorDetails.LEVEL_EMPTY_ERROR,\n fatal: false,\n url: url,\n reason: 'no fragments found in level',\n level: typeof context.level === 'number' ? context.level : undefined\n });\n return;\n }\n\n // We have done our first request (Manifest-type) and receive\n // not a master playlist but a chunk-list (track/level)\n // We fire the manifest-loaded event anyway with the parsed level-details\n // by creating a single-level structure for it.\n if (type === PlaylistContextType.MANIFEST) {\n const singleLevel = {\n url,\n details: levelDetails\n };\n\n hls.trigger(Event.MANIFEST_LOADED, {\n levels: [singleLevel],\n audioTracks: [],\n url,\n stats,\n networkDetails,\n sessionData: null\n });\n }\n\n // save parsing time\n stats.tparsed = performance.now();\n\n // in case we need SIDX ranges\n // return early after calling load for\n // the SIDX box.\n if (levelDetails.needSidxRanges) {\n const sidxUrl = levelDetails.initSegment.url;\n this.load({\n url: sidxUrl,\n isSidxRequest: true,\n type,\n level,\n levelDetails,\n id,\n rangeStart: 0,\n rangeEnd: 2048,\n responseType: 'arraybuffer'\n });\n return;\n }\n\n // extend the context with the new levelDetails property\n context.levelDetails = levelDetails;\n\n this._handlePlaylistLoaded(response, stats, context, networkDetails);\n }\n\n _handleSidxRequest (response: LoaderResponse, context: PlaylistLoaderContext) {\n if (typeof response.data === 'string') {\n throw new Error('sidx request must be made with responseType of array buffer');\n }\n\n const sidxInfo = MP4Demuxer.parseSegmentIndex(new Uint8Array(response.data));\n // if provided fragment does not contain sidx, early return\n if (!sidxInfo) {\n return;\n }\n const sidxReferences = sidxInfo.references;\n const levelDetails = context.levelDetails;\n sidxReferences.forEach((segmentRef, index) => {\n const segRefInfo = segmentRef.info;\n if (!levelDetails) {\n return;\n }\n const frag = levelDetails.fragments[index];\n if (frag.byteRange.length === 0) {\n frag.setByteRange(String(1 + segRefInfo.end - segRefInfo.start) + '@' + String(segRefInfo.start));\n }\n });\n\n if (levelDetails) {\n levelDetails.initSegment.setByteRange(String(sidxInfo.moovEndOffset) + '@0');\n }\n }\n\n _handleManifestParsingError (response: LoaderResponse, context: PlaylistLoaderContext, reason: string, networkDetails: unknown) {\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.NETWORK_ERROR,\n details: ErrorDetails.MANIFEST_PARSING_ERROR,\n fatal: true,\n url: response.url,\n reason,\n networkDetails\n });\n }\n\n _handleNetworkError (context: PlaylistLoaderContext, networkDetails: unknown, timeout: boolean = false, response: LoaderResponse | null = null) {\n logger.info(`A network error occured while loading a ${context.type}-type playlist`);\n\n let details;\n let fatal;\n\n const loader = this.getInternalLoader(context);\n\n switch (context.type) {\n case PlaylistContextType.MANIFEST:\n details = (timeout ? ErrorDetails.MANIFEST_LOAD_TIMEOUT : ErrorDetails.MANIFEST_LOAD_ERROR);\n fatal = true;\n break;\n case PlaylistContextType.LEVEL:\n details = (timeout ? ErrorDetails.LEVEL_LOAD_TIMEOUT : ErrorDetails.LEVEL_LOAD_ERROR);\n fatal = false;\n break;\n case PlaylistContextType.AUDIO_TRACK:\n details = (timeout ? ErrorDetails.AUDIO_TRACK_LOAD_TIMEOUT : ErrorDetails.AUDIO_TRACK_LOAD_ERROR);\n fatal = false;\n break;\n default:\n // details = ...?\n fatal = false;\n }\n\n if (loader) {\n loader.abort();\n this.resetInternalLoader(context.type);\n }\n\n // TODO(typescript-events): when error events are handled, type this\n let errorData: any = {\n type: ErrorTypes.NETWORK_ERROR,\n details,\n fatal,\n url: context.url,\n loader,\n context,\n networkDetails\n };\n\n if (response) {\n errorData.response = response;\n }\n\n this.hls.trigger(Event.ERROR, errorData);\n }\n\n _handlePlaylistLoaded (response: LoaderResponse, stats: LoaderStats, context: PlaylistLoaderContext, networkDetails: unknown) {\n const { type, level, id, levelDetails } = context;\n\n if (!levelDetails || !levelDetails.targetduration) {\n this._handleManifestParsingError(response, context, 'invalid target duration', networkDetails);\n return;\n }\n\n const canHaveLevels = PlaylistLoader.canHaveQualityLevels(context.type);\n if (canHaveLevels) {\n this.hls.trigger(Event.LEVEL_LOADED, {\n details: levelDetails,\n level: level || 0,\n id: id || 0,\n stats,\n networkDetails\n });\n } else {\n switch (type) {\n case PlaylistContextType.AUDIO_TRACK:\n this.hls.trigger(Event.AUDIO_TRACK_LOADED, {\n details: levelDetails,\n id,\n stats,\n networkDetails\n });\n break;\n case PlaylistContextType.SUBTITLE_TRACK:\n this.hls.trigger(Event.SUBTITLE_TRACK_LOADED, {\n details: levelDetails,\n id,\n stats,\n networkDetails\n });\n break;\n }\n }\n }\n}\n\nexport default PlaylistLoader;\n","/*\n * Fragment Loader\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\n\nclass FragmentLoader extends EventHandler {\n constructor (hls) {\n super(hls, Event.FRAG_LOADING);\n this.loaders = {};\n }\n\n destroy () {\n let loaders = this.loaders;\n for (let loaderName in loaders) {\n let loader = loaders[loaderName];\n if (loader) {\n loader.destroy();\n }\n }\n this.loaders = {};\n\n super.destroy();\n }\n\n onFragLoading (data) {\n const frag = data.frag,\n type = frag.type,\n loaders = this.loaders,\n config = this.hls.config,\n FragmentILoader = config.fLoader,\n DefaultILoader = config.loader;\n\n // reset fragment state\n frag.loaded = 0;\n\n let loader = loaders[type];\n if (loader) {\n logger.warn(`abort previous fragment loader for type: ${type}`);\n loader.abort();\n }\n\n loader = loaders[type] = frag.loader =\n config.fLoader ? new FragmentILoader(config) : new DefaultILoader(config);\n\n let loaderContext, loaderConfig, loaderCallbacks;\n\n loaderContext = { url: frag.url, frag: frag, responseType: 'arraybuffer', progressData: false };\n\n let start = frag.byteRangeStartOffset,\n end = frag.byteRangeEndOffset;\n\n if (Number.isFinite(start) && Number.isFinite(end)) {\n loaderContext.rangeStart = start;\n loaderContext.rangeEnd = end;\n }\n\n loaderConfig = {\n timeout: config.fragLoadingTimeOut,\n maxRetry: 0,\n retryDelay: 0,\n maxRetryDelay: config.fragLoadingMaxRetryTimeout\n };\n\n loaderCallbacks = {\n onSuccess: this.loadsuccess.bind(this),\n onError: this.loaderror.bind(this),\n onTimeout: this.loadtimeout.bind(this),\n onProgress: this.loadprogress.bind(this)\n };\n\n loader.load(loaderContext, loaderConfig, loaderCallbacks);\n }\n\n loadsuccess (response, stats, context, networkDetails = null) {\n let payload = response.data, frag = context.frag;\n // detach fragment loader on load success\n frag.loader = undefined;\n this.loaders[frag.type] = undefined;\n this.hls.trigger(Event.FRAG_LOADED, { payload: payload, frag: frag, stats: stats, networkDetails: networkDetails });\n }\n\n loaderror (response, context, networkDetails = null) {\n const frag = context.frag;\n let loader = frag.loader;\n if (loader) {\n loader.abort();\n }\n\n this.loaders[frag.type] = undefined;\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.NETWORK_ERROR, details: ErrorDetails.FRAG_LOAD_ERROR, fatal: false, frag: context.frag, response: response, networkDetails: networkDetails });\n }\n\n loadtimeout (stats, context, networkDetails = null) {\n const frag = context.frag;\n let loader = frag.loader;\n if (loader) {\n loader.abort();\n }\n\n this.loaders[frag.type] = undefined;\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.NETWORK_ERROR, details: ErrorDetails.FRAG_LOAD_TIMEOUT, fatal: false, frag: context.frag, networkDetails: networkDetails });\n }\n\n // data will be used for progressive parsing\n loadprogress (stats, context, data, networkDetails = null) { // jshint ignore:line\n let frag = context.frag;\n frag.loaded = stats.loaded;\n this.hls.trigger(Event.FRAG_LOAD_PROGRESS, { frag: frag, stats: stats, networkDetails: networkDetails });\n }\n}\n\nexport default FragmentLoader;\n","/*\n * Decrypt key Loader\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport Hls from '../hls';\nimport Fragment from './fragment';\nimport { LoaderStats, LoaderResponse, LoaderContext, LoaderConfiguration, LoaderCallbacks } from '../types/loader';\n\ninterface OnKeyLoadingPayload {\n frag: Fragment\n}\n\ninterface KeyLoaderContext extends LoaderContext {\n frag: Fragment\n}\n\nclass KeyLoader extends EventHandler {\n public loaders = {};\n public decryptkey: Uint8Array | null = null;\n public decrypturl: string | null = null;\n\n constructor (hls: Hls) {\n super(hls, Event.KEY_LOADING);\n }\n\n destroy (): void {\n for (const loaderName in this.loaders) {\n let loader = this.loaders[loaderName];\n if (loader) {\n loader.destroy();\n }\n }\n this.loaders = {};\n\n super.destroy();\n }\n\n onKeyLoading (data: OnKeyLoadingPayload) {\n const { frag } = data;\n const type = frag.type;\n const loader = this.loaders[type];\n if (!frag.decryptdata) {\n logger.warn('Missing decryption data on fragment in onKeyLoading');\n return;\n }\n\n // Load the key if the uri is different from previous one, or if the decrypt key has not yet been retrieved\n const uri = frag.decryptdata.uri;\n if (uri !== this.decrypturl || this.decryptkey === null) {\n let config = this.hls.config;\n if (loader) {\n logger.warn(`abort previous key loader for type:${type}`);\n loader.abort();\n }\n if (!uri) {\n logger.warn('key uri is falsy');\n return;\n }\n\n frag.loader = this.loaders[type] = new config.loader(config);\n this.decrypturl = uri;\n this.decryptkey = null;\n\n const loaderContext: KeyLoaderContext = {\n url: uri,\n frag: frag,\n responseType: 'arraybuffer'\n };\n\n // maxRetry is 0 so that instead of retrying the same key on the same variant multiple times,\n // key-loader will trigger an error and rely on stream-controller to handle retry logic.\n // this will also align retry logic with fragment-loader\n const loaderConfig: LoaderConfiguration = {\n timeout: config.fragLoadingTimeOut,\n maxRetry: 0,\n retryDelay: config.fragLoadingRetryDelay,\n maxRetryDelay: config.fragLoadingMaxRetryTimeout\n };\n\n const loaderCallbacks: LoaderCallbacks<KeyLoaderContext> = {\n onSuccess: this.loadsuccess.bind(this),\n onError: this.loaderror.bind(this),\n onTimeout: this.loadtimeout.bind(this)\n };\n\n frag.loader.load(loaderContext, loaderConfig, loaderCallbacks);\n } else if (this.decryptkey) {\n // Return the key if it's already been loaded\n frag.decryptdata.key = this.decryptkey;\n this.hls.trigger(Event.KEY_LOADED, { frag: frag });\n }\n }\n\n loadsuccess (response: LoaderResponse, stats: LoaderStats, context: KeyLoaderContext) {\n let frag = context.frag;\n if (!frag.decryptdata) {\n logger.error('after key load, decryptdata unset');\n return;\n }\n this.decryptkey = frag.decryptdata.key = new Uint8Array(response.data as ArrayBuffer);\n\n // detach fragment loader on load success\n frag.loader = undefined;\n delete this.loaders[frag.type];\n this.hls.trigger(Event.KEY_LOADED, { frag: frag });\n }\n\n loaderror (response: LoaderResponse, context: KeyLoaderContext) {\n let frag = context.frag;\n let loader = frag.loader;\n if (loader) {\n loader.abort();\n }\n\n delete this.loaders[frag.type];\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.NETWORK_ERROR, details: ErrorDetails.KEY_LOAD_ERROR, fatal: false, frag, response });\n }\n\n loadtimeout (stats: LoaderStats, context: KeyLoaderContext) {\n let frag = context.frag;\n let loader = frag.loader;\n if (loader) {\n loader.abort();\n }\n\n delete this.loaders[frag.type];\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.NETWORK_ERROR, details: ErrorDetails.KEY_LOAD_TIMEOUT, fatal: false, frag });\n }\n}\n\nexport default KeyLoader;\n","import EventHandler from '../event-handler';\nimport Event from '../events';\n\nexport const FragmentState = {\n NOT_LOADED: 'NOT_LOADED',\n APPENDING: 'APPENDING',\n PARTIAL: 'PARTIAL',\n OK: 'OK'\n};\n\nexport class FragmentTracker extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.BUFFER_APPENDED,\n Event.FRAG_BUFFERED,\n Event.FRAG_LOADED\n );\n\n this.bufferPadding = 0.2;\n\n this.fragments = Object.create(null);\n this.timeRanges = Object.create(null);\n\n this.config = hls.config;\n }\n\n destroy () {\n this.fragments = Object.create(null);\n this.timeRanges = Object.create(null);\n this.config = null;\n EventHandler.prototype.destroy.call(this);\n super.destroy();\n }\n\n /**\n * Return a Fragment that match the position and levelType.\n * If not found any Fragment, return null\n * @param {number} position\n * @param {LevelType} levelType\n * @returns {Fragment|null}\n */\n getBufferedFrag (position, levelType) {\n const fragments = this.fragments;\n const bufferedFrags = Object.keys(fragments).filter(key => {\n const fragmentEntity = fragments[key];\n if (fragmentEntity.body.type !== levelType) {\n return false;\n }\n\n if (!fragmentEntity.buffered) {\n return false;\n }\n\n const frag = fragmentEntity.body;\n return frag.startPTS <= position && position <= frag.endPTS;\n });\n if (bufferedFrags.length === 0) {\n return null;\n } else {\n // https://github.com/video-dev/hls.js/pull/1545#discussion_r166229566\n const bufferedFragKey = bufferedFrags.pop();\n return fragments[bufferedFragKey].body;\n }\n }\n\n /**\n * Partial fragments effected by coded frame eviction will be removed\n * The browser will unload parts of the buffer to free up memory for new buffer data\n * Fragments will need to be reloaded when the buffer is freed up, removing partial fragments will allow them to reload(since there might be parts that are still playable)\n * @param {String} elementaryStream The elementaryStream of media this is (eg. video/audio)\n * @param {TimeRanges} timeRange TimeRange object from a sourceBuffer\n */\n detectEvictedFragments (elementaryStream, timeRange) {\n // Check if any flagged fragments have been unloaded\n Object.keys(this.fragments).forEach(key => {\n const fragmentEntity = this.fragments[key];\n if (!fragmentEntity || !fragmentEntity.buffered) {\n return;\n }\n const esData = fragmentEntity.range[elementaryStream];\n if (!esData) {\n return;\n }\n const fragmentTimes = esData.time;\n for (let i = 0; i < fragmentTimes.length; i++) {\n const time = fragmentTimes[i];\n if (!this.isTimeBuffered(time.startPTS, time.endPTS, timeRange)) {\n // Unregister partial fragment as it needs to load again to be reused\n this.removeFragment(fragmentEntity.body);\n break;\n }\n }\n });\n }\n\n /**\n * Checks if the fragment passed in is loaded in the buffer properly\n * Partially loaded fragments will be registered as a partial fragment\n * @param {Object} fragment Check the fragment against all sourceBuffers loaded\n */\n detectPartialFragments (fragment) {\n let fragKey = this.getFragmentKey(fragment);\n let fragmentEntity = this.fragments[fragKey];\n if (fragmentEntity) {\n fragmentEntity.buffered = true;\n\n Object.keys(this.timeRanges).forEach(elementaryStream => {\n if (fragment.hasElementaryStream(elementaryStream)) {\n let timeRange = this.timeRanges[elementaryStream];\n // Check for malformed fragments\n // Gaps need to be calculated for each elementaryStream\n fragmentEntity.range[elementaryStream] = this.getBufferedTimes(fragment.startPTS, fragment.endPTS, timeRange);\n }\n });\n }\n }\n\n getBufferedTimes (startPTS, endPTS, timeRange) {\n let fragmentTimes = [];\n let startTime, endTime;\n let fragmentPartial = false;\n for (let i = 0; i < timeRange.length; i++) {\n startTime = timeRange.start(i) - this.bufferPadding;\n endTime = timeRange.end(i) + this.bufferPadding;\n if (startPTS >= startTime && endPTS <= endTime) {\n // Fragment is entirely contained in buffer\n // No need to check the other timeRange times since it's completely playable\n fragmentTimes.push({\n startPTS: Math.max(startPTS, timeRange.start(i)),\n endPTS: Math.min(endPTS, timeRange.end(i))\n });\n break;\n } else if (startPTS < endTime && endPTS > startTime) {\n // Check for intersection with buffer\n // Get playable sections of the fragment\n fragmentTimes.push({\n startPTS: Math.max(startPTS, timeRange.start(i)),\n endPTS: Math.min(endPTS, timeRange.end(i))\n });\n fragmentPartial = true;\n } else if (endPTS <= startTime) {\n // No need to check the rest of the timeRange as it is in order\n break;\n }\n }\n\n return {\n time: fragmentTimes,\n partial: fragmentPartial\n };\n }\n\n getFragmentKey (fragment) {\n return `${fragment.type}_${fragment.level}_${fragment.urlId}_${fragment.sn}`;\n }\n\n /**\n * Gets the partial fragment for a certain time\n * @param {Number} time\n * @returns {Object} fragment Returns a partial fragment at a time or null if there is no partial fragment\n */\n getPartialFragment (time) {\n let timePadding, startTime, endTime;\n let bestFragment = null;\n let bestOverlap = 0;\n Object.keys(this.fragments).forEach(key => {\n const fragmentEntity = this.fragments[key];\n if (this.isPartial(fragmentEntity)) {\n startTime = fragmentEntity.body.startPTS - this.bufferPadding;\n endTime = fragmentEntity.body.endPTS + this.bufferPadding;\n if (time >= startTime && time <= endTime) {\n // Use the fragment that has the most padding from start and end time\n timePadding = Math.min(time - startTime, endTime - time);\n if (bestOverlap <= timePadding) {\n bestFragment = fragmentEntity.body;\n bestOverlap = timePadding;\n }\n }\n }\n });\n return bestFragment;\n }\n\n /**\n * @param {Object} fragment The fragment to check\n * @returns {String} Returns the fragment state when a fragment never loaded or if it partially loaded\n */\n getState (fragment) {\n let fragKey = this.getFragmentKey(fragment);\n let fragmentEntity = this.fragments[fragKey];\n let state = FragmentState.NOT_LOADED;\n\n if (fragmentEntity !== undefined) {\n if (!fragmentEntity.buffered) {\n state = FragmentState.APPENDING;\n } else if (this.isPartial(fragmentEntity) === true) {\n state = FragmentState.PARTIAL;\n } else {\n state = FragmentState.OK;\n }\n }\n\n return state;\n }\n\n isPartial (fragmentEntity) {\n return fragmentEntity.buffered === true &&\n ((fragmentEntity.range.video !== undefined && fragmentEntity.range.video.partial === true) ||\n (fragmentEntity.range.audio !== undefined && fragmentEntity.range.audio.partial === true));\n }\n\n isTimeBuffered (startPTS, endPTS, timeRange) {\n let startTime, endTime;\n for (let i = 0; i < timeRange.length; i++) {\n startTime = timeRange.start(i) - this.bufferPadding;\n endTime = timeRange.end(i) + this.bufferPadding;\n if (startPTS >= startTime && endPTS <= endTime) {\n return true;\n }\n\n if (endPTS <= startTime) {\n // No need to check the rest of the timeRange as it is in order\n return false;\n }\n }\n\n return false;\n }\n\n /**\n * Fires when a fragment loading is completed\n */\n onFragLoaded (e) {\n const fragment = e.frag;\n // don't track initsegment (for which sn is not a number)\n // don't track frags used for bitrateTest, they're irrelevant.\n if (!Number.isFinite(fragment.sn) || fragment.bitrateTest) {\n return;\n }\n\n this.fragments[this.getFragmentKey(fragment)] = {\n body: fragment,\n range: Object.create(null),\n buffered: false\n };\n }\n\n /**\n * Fires when the buffer is updated\n */\n onBufferAppended (e) {\n // Store the latest timeRanges loaded in the buffer\n this.timeRanges = e.timeRanges;\n Object.keys(this.timeRanges).forEach(elementaryStream => {\n let timeRange = this.timeRanges[elementaryStream];\n this.detectEvictedFragments(elementaryStream, timeRange);\n });\n }\n\n /**\n * Fires after a fragment has been loaded into the source buffer\n */\n onFragBuffered (e) {\n this.detectPartialFragments(e.frag);\n }\n\n /**\n * Return true if fragment tracker has the fragment.\n * @param {Object} fragment\n * @returns {boolean}\n */\n hasFragment (fragment) {\n const fragKey = this.getFragmentKey(fragment);\n return this.fragments[fragKey] !== undefined;\n }\n\n /**\n * Remove a fragment from fragment tracker until it is loaded again\n * @param {Object} fragment The fragment to remove\n */\n removeFragment (fragment) {\n let fragKey = this.getFragmentKey(fragment);\n delete this.fragments[fragKey];\n }\n\n /**\n * Remove all fragments from fragment tracker.\n */\n removeAllFragments () {\n this.fragments = Object.create(null);\n }\n}\n","type BinarySearchComparison < T > = (candidate: T) => -1 | 0 | 1;\n\nconst BinarySearch = {\n\n /**\n * Searches for an item in an array which matches a certain condition.\n * This requires the condition to only match one item in the array,\n * and for the array to be ordered.\n *\n * @param {Array<T>} list The array to search.\n * @param {BinarySearchComparison<T>} comparisonFn\n * Called and provided a candidate item as the first argument.\n * Should return:\n * > -1 if the item should be located at a lower index than the provided item.\n * > 1 if the item should be located at a higher index than the provided item.\n * > 0 if the item is the item you're looking for.\n *\n * @return {T | null} The object if it is found or null otherwise.\n */\n search: function<T> (list: T[], comparisonFn: BinarySearchComparison<T>): T | null {\n let minIndex: number = 0;\n let maxIndex: number = list.length - 1;\n let currentIndex: number | null = null;\n let currentElement: T | null = null;\n\n while (minIndex <= maxIndex) {\n currentIndex = (minIndex + maxIndex) / 2 | 0;\n currentElement = list[currentIndex];\n\n let comparisonResult = comparisonFn(currentElement);\n if (comparisonResult > 0) {\n minIndex = currentIndex + 1;\n } else if (comparisonResult < 0) {\n maxIndex = currentIndex - 1;\n } else {\n return currentElement;\n }\n }\n\n return null;\n }\n};\n\nexport default BinarySearch;\n","/**\n * @module BufferHelper\n *\n * Providing methods dealing with buffer length retrieval for example.\n *\n * In general, a helper around HTML5 MediaElement TimeRanges gathered from `buffered` property.\n *\n * Also @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/buffered\n*/\n\ntype BufferTimeRange = {\n start: number\n end: number\n};\n\ntype Bufferable = {\n buffered: TimeRanges\n};\n\nexport class BufferHelper {\n /**\n * Return true if `media`'s buffered include `position`\n * @param {Bufferable} media\n * @param {number} position\n * @returns {boolean}\n */\n static isBuffered (media: Bufferable, position: number): boolean {\n try {\n if (media) {\n let buffered = media.buffered;\n for (let i = 0; i < buffered.length; i++) {\n if (position >= buffered.start(i) && position <= buffered.end(i)) {\n return true;\n }\n }\n }\n } catch (error) {\n // this is to catch\n // InvalidStateError: Failed to read the 'buffered' property from 'SourceBuffer':\n // This SourceBuffer has been removed from the parent media source\n }\n return false;\n }\n\n static bufferInfo (\n media: Bufferable,\n pos: number,\n maxHoleDuration: number\n ): {\n len: number,\n start: number,\n end: number,\n nextStart?: number,\n } {\n try {\n if (media) {\n let vbuffered = media.buffered;\n let buffered: BufferTimeRange[] = [];\n let i: number;\n for (i = 0; i < vbuffered.length; i++) {\n buffered.push({ start: vbuffered.start(i), end: vbuffered.end(i) });\n }\n\n return this.bufferedInfo(buffered, pos, maxHoleDuration);\n }\n } catch (error) {\n // this is to catch\n // InvalidStateError: Failed to read the 'buffered' property from 'SourceBuffer':\n // This SourceBuffer has been removed from the parent media source\n }\n return { len: 0, start: pos, end: pos, nextStart: undefined };\n }\n\n static bufferedInfo (\n buffered: BufferTimeRange[],\n pos: number,\n maxHoleDuration: number\n ): {\n len: number,\n start: number,\n end: number,\n nextStart?: number,\n } {\n // sort on buffer.start/smaller end (IE does not always return sorted buffered range)\n buffered.sort(function (a, b) {\n let diff = a.start - b.start;\n if (diff) {\n return diff;\n } else {\n return b.end - a.end;\n }\n });\n\n let buffered2: BufferTimeRange[] = [];\n if (maxHoleDuration) {\n // there might be some small holes between buffer time range\n // consider that holes smaller than maxHoleDuration are irrelevant and build another\n // buffer time range representations that discards those holes\n for (let i = 0; i < buffered.length; i++) {\n let buf2len = buffered2.length;\n if (buf2len) {\n let buf2end = buffered2[buf2len - 1].end;\n // if small hole (value between 0 or maxHoleDuration ) or overlapping (negative)\n if ((buffered[i].start - buf2end) < maxHoleDuration) {\n // merge overlapping time ranges\n // update lastRange.end only if smaller than item.end\n // e.g. [ 1, 15] with [ 2,8] => [ 1,15] (no need to modify lastRange.end)\n // whereas [ 1, 8] with [ 2,15] => [ 1,15] ( lastRange should switch from [1,8] to [1,15])\n if (buffered[i].end > buf2end) {\n buffered2[buf2len - 1].end = buffered[i].end;\n }\n } else {\n // big hole\n buffered2.push(buffered[i]);\n }\n } else {\n // first value\n buffered2.push(buffered[i]);\n }\n }\n } else {\n buffered2 = buffered;\n }\n\n let bufferLen = 0;\n\n // bufferStartNext can possibly be undefined based on the conditional logic below\n let bufferStartNext: number | undefined;\n\n // bufferStart and bufferEnd are buffer boundaries around current video position\n let bufferStart: number = pos;\n let bufferEnd: number = pos;\n for (let i = 0; i < buffered2.length; i++) {\n let start = buffered2[i].start,\n end = buffered2[i].end;\n // logger.log('buf start/end:' + buffered.start(i) + '/' + buffered.end(i));\n if ((pos + maxHoleDuration) >= start && pos < end) {\n // play position is inside this buffer TimeRange, retrieve end of buffer position and buffer length\n bufferStart = start;\n bufferEnd = end;\n bufferLen = bufferEnd - pos;\n } else if ((pos + maxHoleDuration) < start) {\n bufferStartNext = start;\n break;\n }\n }\n return { len: bufferLen, start: bufferStart, end: bufferEnd, nextStart: bufferStartNext };\n }\n}\n","/**\n * MediaSource helper\n */\n\nexport function getMediaSource (): typeof MediaSource | undefined {\n return (window as any).MediaSource || (window as any).WebKitMediaSource;\n}\n","import { EventEmitter } from 'eventemitter3';\n\n/**\n * Simple adapter sub-class of Nodejs-like EventEmitter.\n */\nexport class Observer extends EventEmitter {\n /**\n * We simply want to pass along the event-name itself\n * in every call to a handler, which is the purpose of our `trigger` method\n * extending the standard API.\n */\n trigger (event: string, ...data: Array<any>): void {\n this.emit(event, event, ...data);\n }\n}\n","import { EventEmitter } from 'eventemitter3';\nimport * as work from 'webworkify-webpack';\n\nimport Event from '../events';\nimport DemuxerInline from '../demux/demuxer-inline';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { getMediaSource } from '../utils/mediasource-helper';\nimport { getSelfScope } from '../utils/get-self-scope';\n\nimport { Observer } from '../observer';\n\n// see https://stackoverflow.com/a/11237259/589493\nconst global = getSelfScope(); // safeguard for code that might run both on worker and main thread\nconst MediaSource = getMediaSource() || { isTypeSupported: () => false };\n\nclass Demuxer {\n constructor (hls, id) {\n this.hls = hls;\n this.id = id;\n\n const observer = this.observer = new Observer();\n const config = hls.config;\n\n const forwardMessage = (ev, data) => {\n data = data || {};\n data.frag = this.frag;\n data.id = this.id;\n hls.trigger(ev, data);\n };\n\n // forward events to main thread\n observer.on(Event.FRAG_DECRYPTED, forwardMessage);\n observer.on(Event.FRAG_PARSING_INIT_SEGMENT, forwardMessage);\n observer.on(Event.FRAG_PARSING_DATA, forwardMessage);\n observer.on(Event.FRAG_PARSED, forwardMessage);\n observer.on(Event.ERROR, forwardMessage);\n observer.on(Event.FRAG_PARSING_METADATA, forwardMessage);\n observer.on(Event.FRAG_PARSING_USERDATA, forwardMessage);\n observer.on(Event.INIT_PTS_FOUND, forwardMessage);\n\n const typeSupported = {\n mp4: MediaSource.isTypeSupported('video/mp4'),\n mpeg: MediaSource.isTypeSupported('audio/mpeg'),\n mp3: MediaSource.isTypeSupported('audio/mp4; codecs=\"mp3\"')\n };\n // navigator.vendor is not always available in Web Worker\n // refer to https://developer.mozilla.org/en-US/docs/Web/API/WorkerGlobalScope/navigator\n const vendor = navigator.vendor;\n if (config.enableWorker && (typeof (Worker) !== 'undefined')) {\n logger.log('demuxing in webworker');\n let w;\n try {\n w = this.w = work(require.resolve('../demux/demuxer-worker.js'));\n this.onwmsg = this.onWorkerMessage.bind(this);\n w.addEventListener('message', this.onwmsg);\n w.onerror = function (event) {\n hls.trigger(Event.ERROR, { type: ErrorTypes.OTHER_ERROR, details: ErrorDetails.INTERNAL_EXCEPTION, fatal: true, event: 'demuxerWorker', err: { message: event.message + ' (' + event.filename + ':' + event.lineno + ')' } });\n };\n w.postMessage({ cmd: 'init', typeSupported: typeSupported, vendor: vendor, id: id, config: JSON.stringify(config) });\n } catch (err) {\n logger.warn('Error in worker:', err);\n logger.error('Error while initializing DemuxerWorker, fallback on DemuxerInline');\n if (w) {\n // revoke the Object URL that was used to create demuxer worker, so as not to leak it\n global.URL.revokeObjectURL(w.objectURL);\n }\n this.demuxer = new DemuxerInline(observer, typeSupported, config, vendor);\n this.w = undefined;\n }\n } else {\n this.demuxer = new DemuxerInline(observer, typeSupported, config, vendor);\n }\n }\n\n destroy () {\n let w = this.w;\n if (w) {\n w.removeEventListener('message', this.onwmsg);\n w.terminate();\n this.w = null;\n } else {\n let demuxer = this.demuxer;\n if (demuxer) {\n demuxer.destroy();\n this.demuxer = null;\n }\n }\n const observer = this.observer;\n if (observer) {\n observer.removeAllListeners();\n this.observer = null;\n }\n }\n\n push (data, initSegment, audioCodec, videoCodec, frag, duration, accurateTimeOffset, defaultInitPTS) {\n const w = this.w;\n const timeOffset = Number.isFinite(frag.startPTS) ? frag.startPTS : frag.start;\n const decryptdata = frag.decryptdata;\n const lastFrag = this.frag;\n const discontinuity = !(lastFrag && (frag.cc === lastFrag.cc));\n const trackSwitch = !(lastFrag && (frag.level === lastFrag.level));\n const nextSN = lastFrag && (frag.sn === (lastFrag.sn + 1));\n const contiguous = !trackSwitch && nextSN;\n if (discontinuity) {\n logger.log(`${this.id}:discontinuity detected`);\n }\n\n if (trackSwitch) {\n logger.log(`${this.id}:switch detected`);\n }\n\n this.frag = frag;\n if (w) {\n // post fragment payload as transferable objects for ArrayBuffer (no copy)\n w.postMessage({ cmd: 'demux', data, decryptdata, initSegment, audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS }, data instanceof ArrayBuffer ? [data] : []);\n } else {\n let demuxer = this.demuxer;\n if (demuxer) {\n demuxer.push(data, decryptdata, initSegment, audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS);\n }\n }\n }\n\n onWorkerMessage (ev) {\n let data = ev.data,\n hls = this.hls;\n switch (data.event) {\n case 'init':\n // revoke the Object URL that was used to create demuxer worker, so as not to leak it\n global.URL.revokeObjectURL(this.w.objectURL);\n break;\n // special case for FRAG_PARSING_DATA: data1 and data2 are transferable objects\n case Event.FRAG_PARSING_DATA:\n data.data.data1 = new Uint8Array(data.data1);\n if (data.data2) {\n data.data.data2 = new Uint8Array(data.data2);\n }\n\n /* falls through */\n default:\n data.data = data.data || {};\n data.data.frag = this.frag;\n data.data.id = this.id;\n hls.trigger(data.event, data.data);\n break;\n }\n }\n}\n\nexport default Demuxer;\n","/**\n * @module LevelHelper\n *\n * Providing methods dealing with playlist sliding and drift\n *\n * TODO: Create an actual `Level` class/model that deals with all this logic in an object-oriented-manner.\n *\n * */\n\nimport { logger } from '../utils/logger';\n\nexport function addGroupId (level, type, id) {\n switch (type) {\n case 'audio':\n if (!level.audioGroupIds) {\n level.audioGroupIds = [];\n }\n level.audioGroupIds.push(id);\n break;\n case 'text':\n if (!level.textGroupIds) {\n level.textGroupIds = [];\n }\n level.textGroupIds.push(id);\n break;\n }\n}\n\nexport function updatePTS (fragments, fromIdx, toIdx) {\n let fragFrom = fragments[fromIdx], fragTo = fragments[toIdx], fragToPTS = fragTo.startPTS;\n // if we know startPTS[toIdx]\n if (Number.isFinite(fragToPTS)) {\n // update fragment duration.\n // it helps to fix drifts between playlist reported duration and fragment real duration\n if (toIdx > fromIdx) {\n fragFrom.duration = fragToPTS - fragFrom.start;\n if (fragFrom.duration < 0) {\n logger.warn(`negative duration computed for frag ${fragFrom.sn},level ${fragFrom.level}, there should be some duration drift between playlist and fragment!`);\n }\n } else {\n fragTo.duration = fragFrom.start - fragToPTS;\n if (fragTo.duration < 0) {\n logger.warn(`negative duration computed for frag ${fragTo.sn},level ${fragTo.level}, there should be some duration drift between playlist and fragment!`);\n }\n }\n } else {\n // we dont know startPTS[toIdx]\n if (toIdx > fromIdx) {\n const contiguous = fragFrom.cc === fragTo.cc;\n fragTo.start = fragFrom.start + ((contiguous && fragFrom.minEndPTS) ? fragFrom.minEndPTS - fragFrom.start : fragFrom.duration);\n } else {\n fragTo.start = Math.max(fragFrom.start - fragTo.duration, 0);\n }\n }\n}\n\nexport function updateFragPTSDTS (details, frag, startPTS, endPTS, startDTS, endDTS) {\n // update frag PTS/DTS\n let maxStartPTS = startPTS;\n let minEndPTS = endPTS;\n if (Number.isFinite(frag.startPTS)) {\n // delta PTS between audio and video\n let deltaPTS = Math.abs(frag.startPTS - startPTS);\n if (!Number.isFinite(frag.deltaPTS)) {\n frag.deltaPTS = deltaPTS;\n } else {\n frag.deltaPTS = Math.max(deltaPTS, frag.deltaPTS);\n }\n\n maxStartPTS = Math.max(startPTS, frag.startPTS);\n startPTS = Math.min(startPTS, frag.startPTS);\n minEndPTS = Math.min(endPTS, frag.endPTS);\n endPTS = Math.max(endPTS, frag.endPTS);\n startDTS = Math.min(startDTS, frag.startDTS);\n endDTS = Math.max(endDTS, frag.endDTS);\n }\n\n const drift = startPTS - frag.start;\n frag.start = frag.startPTS = startPTS;\n frag.maxStartPTS = maxStartPTS;\n frag.endPTS = endPTS;\n frag.minEndPTS = minEndPTS;\n frag.startDTS = startDTS;\n frag.endDTS = endDTS;\n frag.duration = endPTS - startPTS;\n\n const sn = frag.sn;\n // exit if sn out of range\n if (!details || sn < details.startSN || sn > details.endSN) {\n return 0;\n }\n\n let fragIdx, fragments, i;\n fragIdx = sn - details.startSN;\n fragments = details.fragments;\n // update frag reference in fragments array\n // rationale is that fragments array might not contain this frag object.\n // this will happen if playlist has been refreshed between frag loading and call to updateFragPTSDTS()\n // if we don't update frag, we won't be able to propagate PTS info on the playlist\n // resulting in invalid sliding computation\n fragments[fragIdx] = frag;\n // adjust fragment PTS/duration from seqnum-1 to frag 0\n for (i = fragIdx; i > 0; i--) {\n updatePTS(fragments, i, i - 1);\n }\n\n // adjust fragment PTS/duration from seqnum to last frag\n for (i = fragIdx; i < fragments.length - 1; i++) {\n updatePTS(fragments, i, i + 1);\n }\n\n details.PTSKnown = true;\n return drift;\n}\n\nexport function mergeDetails (oldDetails, newDetails) {\n // potentially retrieve cached initsegment\n if (newDetails.initSegment && oldDetails.initSegment) {\n newDetails.initSegment = oldDetails.initSegment;\n }\n\n // check if old/new playlists have fragments in common\n // loop through overlapping SN and update startPTS , cc, and duration if any found\n let ccOffset = 0;\n let PTSFrag;\n mapFragmentIntersection(oldDetails, newDetails, (oldFrag, newFrag) => {\n ccOffset = oldFrag.cc - newFrag.cc;\n if (Number.isFinite(oldFrag.startPTS)) {\n newFrag.start = newFrag.startPTS = oldFrag.startPTS;\n newFrag.endPTS = oldFrag.endPTS;\n newFrag.duration = oldFrag.duration;\n newFrag.backtracked = oldFrag.backtracked;\n newFrag.dropped = oldFrag.dropped;\n PTSFrag = newFrag;\n }\n // PTS is known when there are overlapping segments\n newDetails.PTSKnown = true;\n });\n\n if (!newDetails.PTSKnown) {\n return;\n }\n\n if (ccOffset) {\n logger.log('discontinuity sliding from playlist, take drift into account');\n const newFragments = newDetails.fragments;\n for (let i = 0; i < newFragments.length; i++) {\n newFragments[i].cc += ccOffset;\n }\n }\n\n // if at least one fragment contains PTS info, recompute PTS information for all fragments\n if (PTSFrag) {\n updateFragPTSDTS(newDetails, PTSFrag, PTSFrag.startPTS, PTSFrag.endPTS, PTSFrag.startDTS, PTSFrag.endDTS);\n } else {\n // ensure that delta is within oldFragments range\n // also adjust sliding in case delta is 0 (we could have old=[50-60] and new=old=[50-61])\n // in that case we also need to adjust start offset of all fragments\n adjustSliding(oldDetails, newDetails);\n }\n // if we are here, it means we have fragments overlapping between\n // old and new level. reliable PTS info is thus relying on old level\n newDetails.PTSKnown = oldDetails.PTSKnown;\n}\n\nexport function mergeSubtitlePlaylists (oldPlaylist, newPlaylist, referenceStart = 0) {\n let lastIndex = -1;\n mapFragmentIntersection(oldPlaylist, newPlaylist, (oldFrag, newFrag, index) => {\n newFrag.start = oldFrag.start;\n lastIndex = index;\n });\n\n const frags = newPlaylist.fragments;\n if (lastIndex < 0) {\n frags.forEach(frag => {\n frag.start += referenceStart;\n });\n return;\n }\n\n for (let i = lastIndex + 1; i < frags.length; i++) {\n frags[i].start = (frags[i - 1].start + frags[i - 1].duration);\n }\n}\n\nexport function mapFragmentIntersection (oldPlaylist, newPlaylist, intersectionFn) {\n if (!oldPlaylist || !newPlaylist) {\n return;\n }\n\n const start = Math.max(oldPlaylist.startSN, newPlaylist.startSN) - newPlaylist.startSN;\n const end = Math.min(oldPlaylist.endSN, newPlaylist.endSN) - newPlaylist.startSN;\n const delta = newPlaylist.startSN - oldPlaylist.startSN;\n\n for (let i = start; i <= end; i++) {\n const oldFrag = oldPlaylist.fragments[delta + i];\n const newFrag = newPlaylist.fragments[i];\n if (!oldFrag || !newFrag) {\n break;\n }\n intersectionFn(oldFrag, newFrag, i);\n }\n}\n\nexport function adjustSliding (oldPlaylist, newPlaylist) {\n const delta = newPlaylist.startSN - oldPlaylist.startSN;\n const oldFragments = oldPlaylist.fragments;\n const newFragments = newPlaylist.fragments;\n\n if (delta < 0 || delta > oldFragments.length) {\n return;\n }\n for (let i = 0; i < newFragments.length; i++) {\n newFragments[i].start += oldFragments[delta].start;\n }\n}\n\nexport function computeReloadInterval (currentPlaylist, newPlaylist, lastRequestTime) {\n let reloadInterval = 1000 * (newPlaylist.averagetargetduration ? newPlaylist.averagetargetduration : newPlaylist.targetduration);\n const minReloadInterval = reloadInterval / 2;\n if (currentPlaylist && newPlaylist.endSN === currentPlaylist.endSN) {\n // follow HLS Spec, If the client reloads a Playlist file and finds that it has not\n // changed then it MUST wait for a period of one-half the target\n // duration before retrying.\n reloadInterval = minReloadInterval;\n }\n\n if (lastRequestTime) {\n reloadInterval = Math.max(minReloadInterval, reloadInterval - (window.performance.now() - lastRequestTime));\n }\n // in any case, don't reload more than half of target duration\n return Math.round(reloadInterval);\n}\n","/**\n * TimeRanges to string helper\n */\n\nconst TimeRanges = {\n toString: function (r: TimeRanges) {\n let log = '';\n let len = r.length;\n for (let i = 0; i < len; i++) {\n log += '[' + r.start(i).toFixed(3) + ',' + r.end(i).toFixed(3) + ']';\n }\n\n return log;\n }\n};\n\nexport default TimeRanges;\n","import BinarySearch from './binary-search';\nimport { logger } from '../utils/logger';\n\nexport function findFirstFragWithCC (fragments, cc) {\n let firstFrag = null;\n\n for (let i = 0; i < fragments.length; i += 1) {\n const currentFrag = fragments[i];\n if (currentFrag && currentFrag.cc === cc) {\n firstFrag = currentFrag;\n break;\n }\n }\n\n return firstFrag;\n}\n\nexport function findFragWithCC (fragments, CC) {\n return BinarySearch.search(fragments, (candidate) => {\n if (candidate.cc < CC) {\n return 1;\n } else if (candidate.cc > CC) {\n return -1;\n } else {\n return 0;\n }\n });\n}\n\nexport function shouldAlignOnDiscontinuities (lastFrag, lastLevel, details) {\n let shouldAlign = false;\n if (lastLevel && lastLevel.details && details) {\n if (details.endCC > details.startCC || (lastFrag && lastFrag.cc < details.startCC)) {\n shouldAlign = true;\n }\n }\n return shouldAlign;\n}\n\n// Find the first frag in the previous level which matches the CC of the first frag of the new level\nexport function findDiscontinuousReferenceFrag (prevDetails, curDetails) {\n const prevFrags = prevDetails.fragments;\n const curFrags = curDetails.fragments;\n\n if (!curFrags.length || !prevFrags.length) {\n logger.log('No fragments to align');\n return;\n }\n\n const prevStartFrag = findFirstFragWithCC(prevFrags, curFrags[0].cc);\n\n if (!prevStartFrag || (prevStartFrag && !prevStartFrag.startPTS)) {\n logger.log('No frag in previous level to align on');\n return;\n }\n\n return prevStartFrag;\n}\n\nexport function adjustPts (sliding, details) {\n details.fragments.forEach((frag) => {\n if (frag) {\n let start = frag.start + sliding;\n frag.start = frag.startPTS = start;\n frag.endPTS = start + frag.duration;\n }\n });\n details.PTSKnown = true;\n}\n\n/**\n * Using the parameters of the last level, this function computes PTS' of the new fragments so that they form a\n * contiguous stream with the last fragments.\n * The PTS of a fragment lets Hls.js know where it fits into a stream - by knowing every PTS, we know which fragment to\n * download at any given time. PTS is normally computed when the fragment is demuxed, so taking this step saves us time\n * and an extra download.\n * @param lastFrag\n * @param lastLevel\n * @param details\n */\nexport function alignStream (lastFrag, lastLevel, details) {\n alignDiscontinuities(lastFrag, details, lastLevel);\n if (!details.PTSKnown && lastLevel) {\n // If the PTS wasn't figured out via discontinuity sequence that means there was no CC increase within the level.\n // Aligning via Program Date Time should therefore be reliable, since PDT should be the same within the same\n // discontinuity sequence.\n alignPDT(details, lastLevel.details);\n }\n}\n\n/**\n * Computes the PTS if a new level's fragments using the PTS of a fragment in the last level which shares the same\n * discontinuity sequence.\n * @param lastLevel - The details of the last loaded level\n * @param details - The details of the new level\n */\nexport function alignDiscontinuities (lastFrag, details, lastLevel) {\n if (shouldAlignOnDiscontinuities(lastFrag, lastLevel, details)) {\n const referenceFrag = findDiscontinuousReferenceFrag(lastLevel.details, details);\n if (referenceFrag) {\n logger.log('Adjusting PTS using last level due to CC increase within current level');\n adjustPts(referenceFrag.start, details);\n }\n }\n}\n\n/**\n * Computes the PTS of a new level's fragments using the difference in Program Date Time from the last level.\n * @param details - The details of the new level\n * @param lastDetails - The details of the last loaded level\n */\nexport function alignPDT (details, lastDetails) {\n if (lastDetails && lastDetails.fragments.length) {\n if (!details.hasProgramDateTime || !lastDetails.hasProgramDateTime) {\n return;\n }\n // if last level sliding is 1000 and its first frag PROGRAM-DATE-TIME is 2017-08-20 1:10:00 AM\n // and if new details first frag PROGRAM DATE-TIME is 2017-08-20 1:10:08 AM\n // then we can deduce that playlist B sliding is 1000+8 = 1008s\n let lastPDT = lastDetails.fragments[0].programDateTime;\n let newPDT = details.fragments[0].programDateTime;\n // date diff is in ms. frag.start is in seconds\n let sliding = (newPDT - lastPDT) / 1000 + lastDetails.fragments[0].start;\n if (Number.isFinite(sliding)) {\n logger.log(`adjusting PTS using programDateTime delta, sliding:${sliding.toFixed(3)}`);\n adjustPts(sliding, details);\n }\n }\n}\n","import BinarySearch from '../utils/binary-search';\nimport Fragment from '../loader/fragment';\n\n/**\n * Returns first fragment whose endPdt value exceeds the given PDT.\n * @param {Array<Fragment>} fragments - The array of candidate fragments\n * @param {number|null} [PDTValue = null] - The PDT value which must be exceeded\n * @param {number} [maxFragLookUpTolerance = 0] - The amount of time that a fragment's start/end can be within in order to be considered contiguous\n * @returns {*|null} fragment - The best matching fragment\n */\nexport function findFragmentByPDT (fragments: Array<Fragment>, PDTValue: number | null, maxFragLookUpTolerance: number): Fragment | null {\n if (PDTValue === null || !Array.isArray(fragments) || !fragments.length || !Number.isFinite(PDTValue)) {\n return null;\n }\n\n // if less than start\n const startPDT = fragments[0].programDateTime;\n if (PDTValue < (startPDT || 0)) {\n return null;\n }\n\n const endPDT = fragments[fragments.length - 1].endProgramDateTime;\n if (PDTValue >= (endPDT || 0)) {\n return null;\n }\n\n maxFragLookUpTolerance = maxFragLookUpTolerance || 0;\n for (let seg = 0; seg < fragments.length; ++seg) {\n let frag = fragments[seg];\n if (pdtWithinToleranceTest(PDTValue, maxFragLookUpTolerance, frag)) {\n return frag;\n }\n }\n\n return null;\n}\n\n/**\n * Finds a fragment based on the SN of the previous fragment; or based on the needs of the current buffer.\n * This method compensates for small buffer gaps by applying a tolerance to the start of any candidate fragment, thus\n * breaking any traps which would cause the same fragment to be continuously selected within a small range.\n * @param {*} fragPrevious - The last frag successfully appended\n * @param {Array<Fragment>} fragments - The array of candidate fragments\n * @param {number} [bufferEnd = 0] - The end of the contiguous buffered range the playhead is currently within\n * @param {number} maxFragLookUpTolerance - The amount of time that a fragment's start/end can be within in order to be considered contiguous\n * @returns {*} foundFrag - The best matching fragment\n */\nexport function findFragmentByPTS (fragPrevious: Fragment, fragments: Array<Fragment>, bufferEnd: number = 0, maxFragLookUpTolerance: number = 0): Fragment | null {\n let fragNext: Fragment | null = null;\n if (fragPrevious) {\n fragNext = fragments[fragPrevious.sn as number - (fragments[0].sn as number) + 1];\n } else if (bufferEnd === 0 && fragments[0].start === 0) {\n fragNext = fragments[0];\n }\n // Prefer the next fragment if it's within tolerance\n if (fragNext && fragmentWithinToleranceTest(bufferEnd, maxFragLookUpTolerance, fragNext) === 0) {\n return fragNext;\n }\n // We might be seeking past the tolerance so find the best match\n const foundFragment = BinarySearch.search(fragments, fragmentWithinToleranceTest.bind(null, bufferEnd, maxFragLookUpTolerance));\n if (foundFragment) {\n return foundFragment;\n }\n // If no match was found return the next fragment after fragPrevious, or null\n return fragNext;\n}\n\n/**\n * The test function used by the findFragmentBySn's BinarySearch to look for the best match to the current buffer conditions.\n * @param {*} candidate - The fragment to test\n * @param {number} [bufferEnd = 0] - The end of the current buffered range the playhead is currently within\n * @param {number} [maxFragLookUpTolerance = 0] - The amount of time that a fragment's start can be within in order to be considered contiguous\n * @returns {number} - 0 if it matches, 1 if too low, -1 if too high\n */\nexport function fragmentWithinToleranceTest (bufferEnd = 0, maxFragLookUpTolerance = 0, candidate: Fragment) {\n // offset should be within fragment boundary - config.maxFragLookUpTolerance\n // this is to cope with situations like\n // bufferEnd = 9.991\n // frag[Ø] : [0,10]\n // frag[1] : [10,20]\n // bufferEnd is within frag[0] range ... although what we are expecting is to return frag[1] here\n // frag start frag start+duration\n // |-----------------------------|\n // <---> <--->\n // ...--------><-----------------------------><---------....\n // previous frag matching fragment next frag\n // return -1 return 0 return 1\n // logger.log(`level/sn/start/end/bufEnd:${level}/${candidate.sn}/${candidate.start}/${(candidate.start+candidate.duration)}/${bufferEnd}`);\n // Set the lookup tolerance to be small enough to detect the current segment - ensures we don't skip over very small segments\n let candidateLookupTolerance = Math.min(maxFragLookUpTolerance, candidate.duration + (candidate.deltaPTS ? candidate.deltaPTS : 0));\n if (candidate.start + candidate.duration - candidateLookupTolerance <= bufferEnd) {\n return 1;\n } else if (candidate.start - candidateLookupTolerance > bufferEnd && candidate.start) {\n // if maxFragLookUpTolerance will have negative value then don't return -1 for first element\n return -1;\n }\n\n return 0;\n}\n\n/**\n * The test function used by the findFragmentByPdt's BinarySearch to look for the best match to the current buffer conditions.\n * This function tests the candidate's program date time values, as represented in Unix time\n * @param {*} candidate - The fragment to test\n * @param {number} [pdtBufferEnd = 0] - The Unix time representing the end of the current buffered range\n * @param {number} [maxFragLookUpTolerance = 0] - The amount of time that a fragment's start can be within in order to be considered contiguous\n * @returns {boolean} True if contiguous, false otherwise\n */\nexport function pdtWithinToleranceTest (pdtBufferEnd: number, maxFragLookUpTolerance: number, candidate: Fragment): boolean {\n let candidateLookupTolerance = Math.min(maxFragLookUpTolerance, candidate.duration + (candidate.deltaPTS ? candidate.deltaPTS : 0)) * 1000;\n\n // endProgramDateTime can be null, default to zero\n const endProgramDateTime = candidate.endProgramDateTime || 0;\n return endProgramDateTime - candidateLookupTolerance > pdtBufferEnd;\n}\n","import { BufferHelper } from '../utils/buffer-helper';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport Event from '../events';\nimport { logger } from '../utils/logger';\n\nexport const STALL_MINIMUM_DURATION_MS = 250;\nexport const MAX_START_GAP_JUMP = 2.0;\nexport const SKIP_BUFFER_HOLE_STEP_SECONDS = 0.1;\nexport const SKIP_BUFFER_RANGE_START = 0.05;\n\nexport default class GapController {\n constructor (config, media, fragmentTracker, hls) {\n this.config = config;\n this.media = media;\n this.fragmentTracker = fragmentTracker;\n this.hls = hls;\n this.nudgeRetry = 0;\n this.stallReported = false;\n this.stalled = null;\n this.moved = false;\n this.seeking = false;\n }\n\n /**\n * Checks if the playhead is stuck within a gap, and if so, attempts to free it.\n * A gap is an unbuffered range between two buffered ranges (or the start and the first buffered range).\n *\n * @param {number} lastCurrentTime Previously read playhead position\n */\n poll (lastCurrentTime) {\n const { config, media, stalled } = this;\n const { currentTime, seeking } = media;\n const seeked = this.seeking && !seeking;\n const beginSeek = !this.seeking && seeking;\n\n this.seeking = seeking;\n\n // The playhead is moving, no-op\n if (currentTime !== lastCurrentTime) {\n this.moved = true;\n if (stalled !== null) {\n // The playhead is now moving, but was previously stalled\n if (this.stallReported) {\n const stalledDuration = self.performance.now() - stalled;\n logger.warn(`playback not stuck anymore @${currentTime}, after ${Math.round(stalledDuration)}ms`);\n this.stallReported = false;\n }\n this.stalled = null;\n this.nudgeRetry = 0;\n }\n return;\n }\n\n // Clear stalled state when beginning or finishing seeking so that we don't report stalls coming out of a seek\n if (beginSeek || seeked) {\n this.stalled = null;\n }\n\n // The playhead should not be moving\n if (media.paused || media.ended || media.playbackRate === 0 || !media.buffered.length) {\n return;\n }\n\n const bufferInfo = BufferHelper.bufferInfo(media, currentTime, 0);\n const isBuffered = bufferInfo.len > 0;\n const nextStart = bufferInfo.nextStart || 0;\n\n // There is no playable buffer (waiting for buffer append)\n if (!isBuffered && !nextStart) {\n return;\n }\n\n if (seeking) {\n // Waiting for seeking in a buffered range to complete\n const hasEnoughBuffer = bufferInfo.len > MAX_START_GAP_JUMP;\n // Next buffered range is too far ahead to jump to while still seeking\n const noBufferGap = !nextStart ||\n (nextStart - currentTime > MAX_START_GAP_JUMP && !this.fragmentTracker.getPartialFragment(currentTime));\n if (hasEnoughBuffer || noBufferGap) {\n return;\n }\n // Reset moved state when seeking to a point in or before a gap\n this.moved = false;\n }\n\n // Skip start gaps if we haven't played, but the last poll detected the start of a stall\n // The addition poll gives the browser a chance to jump the gap for us\n if (!this.moved && this.stalled) {\n // Jump start gaps within jump threshold\n const startJump = Math.max(nextStart, bufferInfo.start || 0) - currentTime;\n if (startJump > 0 && startJump <= MAX_START_GAP_JUMP) {\n this._trySkipBufferHole(null);\n return;\n }\n }\n\n // Start tracking stall time\n const tnow = self.performance.now();\n if (stalled === null) {\n this.stalled = tnow;\n return;\n }\n\n const stalledDuration = tnow - stalled;\n if (!seeking && stalledDuration >= STALL_MINIMUM_DURATION_MS) {\n // Report stalling after trying to fix\n this._reportStall(bufferInfo.len);\n }\n\n const bufferedWithHoles = BufferHelper.bufferInfo(media, currentTime, config.maxBufferHole);\n this._tryFixBufferStall(bufferedWithHoles, stalledDuration);\n }\n\n /**\n * Detects and attempts to fix known buffer stalling issues.\n * @param bufferInfo - The properties of the current buffer.\n * @param stalledDurationMs - The amount of time Hls.js has been stalling for.\n * @private\n */\n _tryFixBufferStall (bufferInfo, stalledDurationMs) {\n const { config, fragmentTracker, media } = this;\n const currentTime = media.currentTime;\n\n const partial = fragmentTracker.getPartialFragment(currentTime);\n if (partial) {\n // Try to skip over the buffer hole caused by a partial fragment\n // This method isn't limited by the size of the gap between buffered ranges\n const targetTime = this._trySkipBufferHole(partial);\n // we return here in this case, meaning\n // the branch below only executes when we don't handle a partial fragment\n if (targetTime) {\n return;\n }\n }\n\n // if we haven't had to skip over a buffer hole of a partial fragment\n // we may just have to \"nudge\" the playlist as the browser decoding/rendering engine\n // needs to cross some sort of threshold covering all source-buffers content\n // to start playing properly.\n if (bufferInfo.len > config.maxBufferHole &&\n stalledDurationMs > config.highBufferWatchdogPeriod * 1000) {\n logger.warn('Trying to nudge playhead over buffer-hole');\n // Try to nudge currentTime over a buffer hole if we've been stalling for the configured amount of seconds\n // We only try to jump the hole if it's under the configured size\n // Reset stalled so to rearm watchdog timer\n this.stalled = null;\n this._tryNudgeBuffer();\n }\n }\n\n /**\n * Triggers a BUFFER_STALLED_ERROR event, but only once per stall period.\n * @param bufferLen - The playhead distance from the end of the current buffer segment.\n * @private\n */\n _reportStall (bufferLen) {\n const { hls, media, stallReported } = this;\n if (!stallReported) {\n // Report stalled error once\n this.stallReported = true;\n logger.warn(`Playback stalling at @${media.currentTime} due to low buffer (buffer=${bufferLen})`);\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.BUFFER_STALLED_ERROR,\n fatal: false,\n buffer: bufferLen\n });\n }\n }\n\n /**\n * Attempts to fix buffer stalls by jumping over known gaps caused by partial fragments\n * @param partial - The partial fragment found at the current time (where playback is stalling).\n * @private\n */\n _trySkipBufferHole (partial) {\n const { config, hls, media } = this;\n const currentTime = media.currentTime;\n let lastEndTime = 0;\n // Check if currentTime is between unbuffered regions of partial fragments\n for (let i = 0; i < media.buffered.length; i++) {\n const startTime = media.buffered.start(i);\n if (currentTime + config.maxBufferHole >= lastEndTime && currentTime < startTime) {\n const targetTime = Math.max(startTime + SKIP_BUFFER_RANGE_START, media.currentTime + SKIP_BUFFER_HOLE_STEP_SECONDS);\n logger.warn(`skipping hole, adjusting currentTime from ${currentTime} to ${targetTime}`);\n this.moved = true;\n this.stalled = null;\n media.currentTime = targetTime;\n if (partial) {\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.BUFFER_SEEK_OVER_HOLE,\n fatal: false,\n reason: `fragment loaded with buffer holes, seeking from ${currentTime} to ${targetTime}`,\n frag: partial\n });\n }\n return targetTime;\n }\n lastEndTime = media.buffered.end(i);\n }\n return 0;\n }\n\n /**\n * Attempts to fix buffer stalls by advancing the mediaElement's current time by a small amount.\n * @private\n */\n _tryNudgeBuffer () {\n const { config, hls, media } = this;\n const currentTime = media.currentTime;\n const nudgeRetry = (this.nudgeRetry || 0) + 1;\n this.nudgeRetry = nudgeRetry;\n\n if (nudgeRetry < config.nudgeMaxRetry) {\n const targetTime = currentTime + nudgeRetry * config.nudgeOffset;\n // playback stalled in buffered area ... let's nudge currentTime to try to overcome this\n logger.warn(`Nudging 'currentTime' from ${currentTime} to ${targetTime}`);\n media.currentTime = targetTime;\n\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.BUFFER_NUDGE_ON_STALL,\n fatal: false\n });\n } else {\n logger.error(`Playhead still not moving while enough data buffered @${currentTime} after ${config.nudgeMaxRetry} nudges`);\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.BUFFER_STALLED_ERROR,\n fatal: true\n });\n }\n }\n}\n","import EventHandler from './event-handler';\nimport Hls from './hls';\n\n/**\n * Sub-class specialization of EventHandler base class.\n *\n * TaskLoop allows to schedule a task function being called (optionnaly repeatedly) on the main loop,\n * scheduled asynchroneously, avoiding recursive calls in the same tick.\n *\n * The task itself is implemented in `doTick`. It can be requested and called for single execution\n * using the `tick` method.\n *\n * It will be assured that the task execution method (`tick`) only gets called once per main loop \"tick\",\n * no matter how often it gets requested for execution. Execution in further ticks will be scheduled accordingly.\n *\n * If further execution requests have already been scheduled on the next tick, it can be checked with `hasNextTick`,\n * and cancelled with `clearNextTick`.\n *\n * The task can be scheduled as an interval repeatedly with a period as parameter (see `setInterval`, `clearInterval`).\n *\n * Sub-classes need to implement the `doTick` method which will effectively have the task execution routine.\n *\n * Further explanations:\n *\n * The baseclass has a `tick` method that will schedule the doTick call. It may be called synchroneously\n * only for a stack-depth of one. On re-entrant calls, sub-sequent calls are scheduled for next main loop ticks.\n *\n * When the task execution (`tick` method) is called in re-entrant way this is detected and\n * we are limiting the task execution per call stack to exactly one, but scheduling/post-poning further\n * task processing on the next main loop iteration (also known as \"next tick\" in the Node/JS runtime lingo).\n */\n\nexport default class TaskLoop extends EventHandler {\n private readonly _boundTick: () => void;\n private _tickTimer: number | null = null;\n private _tickInterval: number | null = null;\n private _tickCallCount = 0;\n\n constructor (hls: Hls, ...events: string[]) {\n super(hls, ...events);\n this._boundTick = this.tick.bind(this);\n }\n\n /**\n * @override\n */\n protected onHandlerDestroying () {\n // clear all timers before unregistering from event bus\n this.clearNextTick();\n this.clearInterval();\n }\n\n /**\n * @returns {boolean}\n */\n public hasInterval (): boolean {\n return !!this._tickInterval;\n }\n\n /**\n * @returns {boolean}\n */\n public hasNextTick (): boolean {\n return !!this._tickTimer;\n }\n\n /**\n * @param {number} millis Interval time (ms)\n * @returns {boolean} True when interval has been scheduled, false when already scheduled (no effect)\n */\n public setInterval (millis: number): boolean {\n if (!this._tickInterval) {\n this._tickInterval = self.setInterval(this._boundTick, millis);\n return true;\n }\n return false;\n }\n\n /**\n * @returns {boolean} True when interval was cleared, false when none was set (no effect)\n */\n public clearInterval (): boolean {\n if (this._tickInterval) {\n self.clearInterval(this._tickInterval);\n this._tickInterval = null;\n return true;\n }\n return false;\n }\n\n /**\n * @returns {boolean} True when timeout was cleared, false when none was set (no effect)\n */\n public clearNextTick (): boolean {\n if (this._tickTimer) {\n self.clearTimeout(this._tickTimer);\n this._tickTimer = null;\n return true;\n }\n return false;\n }\n\n /**\n * Will call the subclass doTick implementation in this main loop tick\n * or in the next one (via setTimeout(,0)) in case it has already been called\n * in this tick (in case this is a re-entrant call).\n */\n public tick (): void {\n this._tickCallCount++;\n if (this._tickCallCount === 1) {\n this.doTick();\n // re-entrant call to tick from previous doTick call stack\n // -> schedule a call on the next main loop iteration to process this task processing request\n if (this._tickCallCount > 1) {\n // make sure only one timer exists at any time at max\n this.clearNextTick();\n this._tickTimer = self.setTimeout(this._boundTick, 0);\n }\n this._tickCallCount = 0;\n }\n }\n\n /**\n * For subclass to implement task logic\n * @abstract\n */\n protected doTick (): void {}\n}\n","import TaskLoop from '../task-loop';\nimport { FragmentState } from './fragment-tracker';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport { logger } from '../utils/logger';\n\nexport const State = {\n STOPPED: 'STOPPED',\n STARTING: 'STARTING',\n IDLE: 'IDLE',\n PAUSED: 'PAUSED',\n KEY_LOADING: 'KEY_LOADING',\n FRAG_LOADING: 'FRAG_LOADING',\n FRAG_LOADING_WAITING_RETRY: 'FRAG_LOADING_WAITING_RETRY',\n WAITING_TRACK: 'WAITING_TRACK',\n PARSING: 'PARSING',\n PARSED: 'PARSED',\n BUFFER_FLUSHING: 'BUFFER_FLUSHING',\n ENDED: 'ENDED',\n ERROR: 'ERROR',\n WAITING_INIT_PTS: 'WAITING_INIT_PTS',\n WAITING_LEVEL: 'WAITING_LEVEL'\n};\n\nexport default class BaseStreamController extends TaskLoop {\n doTick () {}\n\n startLoad () {}\n\n stopLoad () {\n let frag = this.fragCurrent;\n if (frag) {\n if (frag.loader) {\n frag.loader.abort();\n }\n this.fragmentTracker.removeFragment(frag);\n }\n if (this.demuxer) {\n this.demuxer.destroy();\n this.demuxer = null;\n }\n this.fragCurrent = null;\n this.fragPrevious = null;\n this.clearInterval();\n this.clearNextTick();\n this.state = State.STOPPED;\n }\n\n _streamEnded (bufferInfo, levelDetails) {\n const { fragCurrent, fragmentTracker } = this;\n // we just got done loading the final fragment and there is no other buffered range after ...\n // rationale is that in case there are any buffered ranges after, it means that there are unbuffered portion in between\n // so we should not switch to ENDED in that case, to be able to buffer them\n // dont switch to ENDED if we need to backtrack last fragment\n if (!levelDetails.live && fragCurrent && !fragCurrent.backtracked && fragCurrent.sn === levelDetails.endSN && !bufferInfo.nextStart) {\n const fragState = fragmentTracker.getState(fragCurrent);\n return fragState === FragmentState.PARTIAL || fragState === FragmentState.OK;\n }\n return false;\n }\n\n onMediaSeeking () {\n const { config, media, mediaBuffer, state } = this;\n const currentTime = media ? media.currentTime : null;\n const bufferInfo = BufferHelper.bufferInfo(mediaBuffer || media, currentTime, this.config.maxBufferHole);\n\n logger.log(`media seeking to ${Number.isFinite(currentTime) ? currentTime.toFixed(3) : currentTime}`);\n\n if (state === State.FRAG_LOADING) {\n let fragCurrent = this.fragCurrent;\n // check if we are seeking to a unbuffered area AND if frag loading is in progress\n if (bufferInfo.len === 0 && fragCurrent) {\n const tolerance = config.maxFragLookUpTolerance;\n const fragStartOffset = fragCurrent.start - tolerance;\n const fragEndOffset = fragCurrent.start + fragCurrent.duration + tolerance;\n // check if we seek position will be out of currently loaded frag range : if out cancel frag load, if in, don't do anything\n if (currentTime < fragStartOffset || currentTime > fragEndOffset) {\n if (fragCurrent.loader) {\n logger.log('seeking outside of buffer while fragment load in progress, cancel fragment load');\n fragCurrent.loader.abort();\n }\n this.fragCurrent = null;\n this.fragPrevious = null;\n // switch to IDLE state to load new fragment\n this.state = State.IDLE;\n } else {\n logger.log('seeking outside of buffer but within currently loaded fragment range');\n }\n }\n } else if (state === State.ENDED) {\n // if seeking to unbuffered area, clean up fragPrevious\n if (bufferInfo.len === 0) {\n this.fragPrevious = null;\n this.fragCurrent = null;\n }\n\n // switch to IDLE state to check for potential new fragment\n this.state = State.IDLE;\n }\n if (media) {\n this.lastCurrentTime = currentTime;\n }\n\n // in case seeking occurs although no media buffered, adjust startPosition and nextLoadPosition to seek target\n if (!this.loadedmetadata) {\n this.nextLoadPosition = this.startPosition = currentTime;\n }\n\n // tick to speed up processing\n this.tick();\n }\n\n onMediaEnded () {\n // reset startPosition and lastCurrentTime to restart playback @ stream beginning\n this.startPosition = this.lastCurrentTime = 0;\n }\n\n onHandlerDestroying () {\n this.stopLoad();\n super.onHandlerDestroying();\n }\n\n onHandlerDestroyed () {\n this.state = State.STOPPED;\n this.fragmentTracker = null;\n }\n\n computeLivePosition (sliding, levelDetails) {\n let targetLatency = this.config.liveSyncDuration !== undefined ? this.config.liveSyncDuration : this.config.liveSyncDurationCount * levelDetails.targetduration;\n return sliding + Math.max(0, levelDetails.totalduration - targetLatency);\n }\n}\n","/*\n * Stream Controller\n*/\n\nimport BinarySearch from '../utils/binary-search';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport Demuxer from '../demux/demuxer';\nimport Event from '../events';\nimport { FragmentState } from './fragment-tracker';\nimport { ElementaryStreamTypes } from '../loader/fragment';\nimport { PlaylistLevelType } from '../types/loader';\nimport * as LevelHelper from './level-helper';\nimport TimeRanges from '../utils/time-ranges';\nimport { ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport { alignStream } from '../utils/discontinuities';\nimport { findFragmentByPDT, findFragmentByPTS } from './fragment-finders';\nimport GapController, { MAX_START_GAP_JUMP } from './gap-controller';\nimport BaseStreamController, { State } from './base-stream-controller';\n\nconst TICK_INTERVAL = 100; // how often to tick in ms\n\nclass StreamController extends BaseStreamController {\n constructor (hls, fragmentTracker) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.MANIFEST_LOADING,\n Event.MANIFEST_PARSED,\n Event.LEVEL_LOADED,\n Event.LEVELS_UPDATED,\n Event.KEY_LOADED,\n Event.FRAG_LOADED,\n Event.FRAG_LOAD_EMERGENCY_ABORTED,\n Event.FRAG_PARSING_INIT_SEGMENT,\n Event.FRAG_PARSING_DATA,\n Event.FRAG_PARSED,\n Event.ERROR,\n Event.AUDIO_TRACK_SWITCHING,\n Event.AUDIO_TRACK_SWITCHED,\n Event.BUFFER_CREATED,\n Event.BUFFER_APPENDED,\n Event.BUFFER_FLUSHED);\n\n this.fragmentTracker = fragmentTracker;\n this.config = hls.config;\n this.audioCodecSwap = false;\n this._state = State.STOPPED;\n this.stallReported = false;\n this.gapController = null;\n this.altAudio = false;\n this.audioOnly = false;\n this.bitrateTest = false;\n }\n\n startLoad (startPosition) {\n if (this.levels) {\n let lastCurrentTime = this.lastCurrentTime, hls = this.hls;\n this.stopLoad();\n this.setInterval(TICK_INTERVAL);\n this.level = -1;\n this.fragLoadError = 0;\n if (!this.startFragRequested) {\n // determine load level\n let startLevel = hls.startLevel;\n if (startLevel === -1) {\n if (hls.config.testBandwidth) {\n // -1 : guess start Level by doing a bitrate test by loading first fragment of lowest quality level\n startLevel = 0;\n this.bitrateTest = true;\n } else {\n startLevel = hls.nextAutoLevel;\n }\n }\n // set new level to playlist loader : this will trigger start level load\n // hls.nextLoadLevel remains until it is set to a new value or until a new frag is successfully loaded\n this.level = hls.nextLoadLevel = startLevel;\n this.loadedmetadata = false;\n }\n // if startPosition undefined but lastCurrentTime set, set startPosition to last currentTime\n if (lastCurrentTime > 0 && startPosition === -1) {\n logger.log(`override startPosition with lastCurrentTime @${lastCurrentTime.toFixed(3)}`);\n startPosition = lastCurrentTime;\n }\n this.state = State.IDLE;\n this.nextLoadPosition = this.startPosition = this.lastCurrentTime = startPosition;\n this.tick();\n } else {\n this.forceStartLoad = true;\n this.state = State.STOPPED;\n }\n }\n\n stopLoad () {\n this.forceStartLoad = false;\n super.stopLoad();\n }\n\n doTick () {\n switch (this.state) {\n case State.BUFFER_FLUSHING:\n // in buffer flushing state, reset fragLoadError counter\n this.fragLoadError = 0;\n break;\n case State.IDLE:\n this._doTickIdle();\n break;\n case State.WAITING_LEVEL:\n var level = this.levels[this.level];\n // check if playlist is already loaded\n if (level && level.details) {\n this.state = State.IDLE;\n }\n\n break;\n case State.FRAG_LOADING_WAITING_RETRY:\n var now = window.performance.now();\n var retryDate = this.retryDate;\n // if current time is gt than retryDate, or if media seeking let's switch to IDLE state to retry loading\n if (!retryDate || (now >= retryDate) || (this.media && this.media.seeking)) {\n logger.log('mediaController: retryDate reached, switch back to IDLE state');\n this.state = State.IDLE;\n }\n break;\n case State.ERROR:\n case State.STOPPED:\n case State.FRAG_LOADING:\n case State.PARSING:\n case State.PARSED:\n case State.ENDED:\n break;\n default:\n break;\n }\n // check buffer\n this._checkBuffer();\n // check/update current fragment\n this._checkFragmentChanged();\n }\n\n // Ironically the \"idle\" state is the on we do the most logic in it seems ....\n // NOTE: Maybe we could rather schedule a check for buffer length after half of the currently\n // played segment, or on pause/play/seek instead of naively checking every 100ms?\n _doTickIdle () {\n const hls = this.hls,\n config = hls.config,\n media = this.media;\n\n // if start level not parsed yet OR\n // if video not attached AND start fragment already requested OR start frag prefetch disable\n // exit loop, as we either need more info (level not parsed) or we need media to be attached to load new fragment\n if (this.levelLastLoaded === undefined || (\n !media && (this.startFragRequested || !config.startFragPrefetch))) {\n return;\n }\n\n // If the \"main\" level is audio-only but we are loading an alternate track in the same group, do not load anything\n if (this.altAudio && this.audioOnly) {\n // Clear audio demuxer state so when switching back to main audio we're not still appending where we left off\n this.demuxer.frag = null;\n return;\n }\n\n // if we have not yet loaded any fragment, start loading from start position\n let pos;\n if (this.loadedmetadata) {\n pos = media.currentTime;\n } else {\n pos = this.nextLoadPosition;\n }\n\n // determine next load level\n let level = hls.nextLoadLevel,\n levelInfo = this.levels[level];\n\n if (!levelInfo) {\n return;\n }\n\n let levelBitrate = levelInfo.bitrate,\n maxBufLen;\n\n // compute max Buffer Length that we could get from this load level, based on level bitrate.\n if (levelBitrate) {\n maxBufLen = Math.max(8 * config.maxBufferSize / levelBitrate, config.maxBufferLength);\n } else {\n maxBufLen = config.maxBufferLength;\n }\n\n maxBufLen = Math.min(maxBufLen, config.maxMaxBufferLength);\n\n // determine next candidate fragment to be loaded, based on current position and end of buffer position\n // ensure up to `config.maxMaxBufferLength` of buffer upfront\n\n const maxBufferHole = pos < config.maxBufferHole ? Math.max(MAX_START_GAP_JUMP, config.maxBufferHole) : config.maxBufferHole;\n const bufferInfo = BufferHelper.bufferInfo(this.mediaBuffer ? this.mediaBuffer : media, pos, maxBufferHole);\n const bufferLen = bufferInfo.len;\n // Stay idle if we are still with buffer margins\n if (bufferLen >= maxBufLen) {\n return;\n }\n\n // if buffer length is less than maxBufLen try to load a new fragment ...\n logger.trace(`buffer length of ${bufferLen.toFixed(3)} is below max of ${maxBufLen.toFixed(3)}. checking for more payload ...`);\n\n // set next load level : this will trigger a playlist load if needed\n this.level = hls.nextLoadLevel = level;\n\n const levelDetails = levelInfo.details;\n // if level info not retrieved yet, switch state and wait for level retrieval\n // if live playlist, ensure that new playlist has been refreshed to avoid loading/try to load\n // a useless and outdated fragment (that might even introduce load error if it is already out of the live playlist)\n if (!levelDetails || (levelDetails.live && this.levelLastLoaded !== level)) {\n this.state = State.WAITING_LEVEL;\n return;\n }\n\n if (this._streamEnded(bufferInfo, levelDetails)) {\n const data = {};\n if (this.altAudio) {\n data.type = 'video';\n }\n\n this.hls.trigger(Event.BUFFER_EOS, data);\n this.state = State.ENDED;\n return;\n }\n // if we have the levelDetails for the selected variant, lets continue enrichen our stream (load keys/fragments or trigger EOS, etc..)\n this._fetchPayloadOrEos(pos, bufferInfo, levelDetails);\n }\n\n _fetchPayloadOrEos (pos, bufferInfo, levelDetails) {\n const fragPrevious = this.fragPrevious,\n level = this.level,\n fragments = levelDetails.fragments,\n fragLen = fragments.length;\n\n // empty playlist\n if (fragLen === 0) {\n return;\n }\n\n // find fragment index, contiguous with end of buffer position\n let start = fragments[0].start,\n end = fragments[fragLen - 1].start + fragments[fragLen - 1].duration,\n bufferEnd = bufferInfo.end,\n frag;\n\n if (levelDetails.initSegment && !levelDetails.initSegment.data) {\n frag = levelDetails.initSegment;\n } else {\n // in case of live playlist we need to ensure that requested position is not located before playlist start\n if (levelDetails.live) {\n let initialLiveManifestSize = this.config.initialLiveManifestSize;\n if (fragLen < initialLiveManifestSize) {\n logger.warn(`Can not start playback of a level, reason: not enough fragments ${fragLen} < ${initialLiveManifestSize}`);\n return;\n }\n\n frag = this._ensureFragmentAtLivePoint(levelDetails, bufferEnd, start, end, fragPrevious, fragments);\n // if it explicitely returns null don't load any fragment and exit function now\n if (frag === null) {\n return;\n }\n } else {\n // VoD playlist: if bufferEnd before start of playlist, load first fragment\n if (bufferEnd < start) {\n frag = fragments[0];\n }\n }\n }\n if (!frag) {\n frag = this._findFragment(start, fragPrevious, fragLen, fragments, bufferEnd, end, levelDetails);\n }\n\n if (frag) {\n if (frag.encrypted) {\n this._loadKey(frag, levelDetails);\n } else {\n this._loadFragment(frag, levelDetails, pos, bufferEnd);\n }\n }\n }\n\n _ensureFragmentAtLivePoint (levelDetails, bufferEnd, start, end, fragPrevious, fragments) {\n const config = this.hls.config, media = this.media;\n\n let frag;\n\n // check if requested position is within seekable boundaries :\n // logger.log(`start/pos/bufEnd/seeking:${start.toFixed(3)}/${pos.toFixed(3)}/${bufferEnd.toFixed(3)}/${this.media.seeking}`);\n let maxLatency = Infinity;\n\n if (config.liveMaxLatencyDuration !== undefined) {\n maxLatency = config.liveMaxLatencyDuration;\n } else if (Number.isFinite(config.liveMaxLatencyDurationCount)) {\n maxLatency = config.liveMaxLatencyDurationCount * levelDetails.targetduration;\n }\n\n if (bufferEnd < Math.max(start - config.maxFragLookUpTolerance, end - maxLatency)) {\n let liveSyncPosition = this.liveSyncPosition = this.computeLivePosition(start, levelDetails);\n bufferEnd = liveSyncPosition;\n if (media && !media.paused && media.readyState && media.duration > liveSyncPosition && liveSyncPosition > media.currentTime) {\n logger.log(`buffer end: ${bufferEnd.toFixed(3)} is located too far from the end of live sliding playlist, reset currentTime to : ${liveSyncPosition.toFixed(3)}`);\n media.currentTime = liveSyncPosition;\n }\n\n this.nextLoadPosition = liveSyncPosition;\n }\n\n // if end of buffer greater than live edge, don't load any fragment\n // this could happen if live playlist intermittently slides in the past.\n // level 1 loaded [182580161,182580167]\n // level 1 loaded [182580162,182580169]\n // Loading 182580168 of [182580162 ,182580169],level 1 ..\n // Loading 182580169 of [182580162 ,182580169],level 1 ..\n // level 1 loaded [182580162,182580168] <============= here we should have bufferEnd > end. in that case break to avoid reloading 182580168\n // level 1 loaded [182580164,182580171]\n //\n // don't return null in case media not loaded yet (readystate === 0)\n if (levelDetails.PTSKnown && bufferEnd > end && media && media.readyState) {\n return null;\n }\n\n if (this.startFragRequested && !levelDetails.PTSKnown) {\n /* we are switching level on live playlist, but we don't have any PTS info for that quality level ...\n try to load frag matching with next SN.\n even if SN are not synchronized between playlists, loading this frag will help us\n compute playlist sliding and find the right one after in case it was not the right consecutive one */\n if (fragPrevious) {\n if (levelDetails.hasProgramDateTime) {\n // Relies on PDT in order to switch bitrates (Support EXT-X-DISCONTINUITY without EXT-X-DISCONTINUITY-SEQUENCE)\n logger.log(`live playlist, switching playlist, load frag with same PDT: ${fragPrevious.programDateTime}`);\n frag = findFragmentByPDT(fragments, fragPrevious.endProgramDateTime, config.maxFragLookUpTolerance);\n } else {\n // Uses buffer and sequence number to calculate switch segment (required if using EXT-X-DISCONTINUITY-SEQUENCE)\n const targetSN = fragPrevious.sn + 1;\n if (targetSN >= levelDetails.startSN && targetSN <= levelDetails.endSN) {\n const fragNext = fragments[targetSN - levelDetails.startSN];\n if (fragPrevious.cc === fragNext.cc) {\n frag = fragNext;\n logger.log(`live playlist, switching playlist, load frag with next SN: ${frag.sn}`);\n }\n }\n // next frag SN not available (or not with same continuity counter)\n // look for a frag sharing the same CC\n if (!frag) {\n frag = BinarySearch.search(fragments, function (frag) {\n return fragPrevious.cc - frag.cc;\n });\n if (frag) {\n logger.log(`live playlist, switching playlist, load frag with same CC: ${frag.sn}`);\n }\n }\n }\n }\n }\n\n return frag;\n }\n\n _findFragment (start, fragPreviousLoad, fragmentIndexRange, fragments, bufferEnd, end, levelDetails) {\n const config = this.hls.config;\n let fragNextLoad;\n\n if (bufferEnd < end) {\n const lookupTolerance = (bufferEnd > end - config.maxFragLookUpTolerance) ? 0 : config.maxFragLookUpTolerance;\n // Remove the tolerance if it would put the bufferEnd past the actual end of stream\n // Uses buffer and sequence number to calculate switch segment (required if using EXT-X-DISCONTINUITY-SEQUENCE)\n fragNextLoad = findFragmentByPTS(fragPreviousLoad, fragments, bufferEnd, lookupTolerance);\n } else {\n // reach end of playlist\n fragNextLoad = fragments[fragmentIndexRange - 1];\n }\n\n if (fragNextLoad) {\n const curSNIdx = fragNextLoad.sn - levelDetails.startSN;\n const sameLevel = fragPreviousLoad && fragNextLoad.level === fragPreviousLoad.level;\n const prevSnFrag = fragments[curSNIdx - 1];\n const nextSnFrag = fragments[curSNIdx + 1];\n\n // logger.log('find SN matching with pos:' + bufferEnd + ':' + frag.sn);\n if (fragPreviousLoad && fragNextLoad.sn === fragPreviousLoad.sn) {\n if (sameLevel && !fragNextLoad.backtracked) {\n if (fragNextLoad.sn < levelDetails.endSN) {\n let deltaPTS = fragPreviousLoad.deltaPTS;\n // if there is a significant delta between audio and video, larger than max allowed hole,\n // and if previous remuxed fragment did not start with a keyframe. (fragPrevious.dropped)\n // let's try to load previous fragment again to get last keyframe\n // then we will reload again current fragment (that way we should be able to fill the buffer hole ...)\n if (deltaPTS && deltaPTS > config.maxBufferHole && fragPreviousLoad.dropped && curSNIdx) {\n fragNextLoad = prevSnFrag;\n logger.warn('Previous fragment was dropped with large PTS gap between audio and video. Maybe fragment is not starting with a keyframe? Loading previous one to try to overcome this');\n } else {\n fragNextLoad = nextSnFrag;\n if (this.fragmentTracker.getState(fragNextLoad) !== FragmentState.OK) {\n logger.log(`Re-loading fragment with SN: ${fragNextLoad.sn}`);\n }\n }\n } else {\n fragNextLoad = null;\n }\n } else if (fragNextLoad.backtracked) {\n // Only backtrack a max of 1 consecutive fragment to prevent sliding back too far when little or no frags start with keyframes\n if (nextSnFrag && nextSnFrag.backtracked) {\n logger.warn(`Already backtracked from fragment ${nextSnFrag.sn}, will not backtrack to fragment ${fragNextLoad.sn}. Loading fragment ${nextSnFrag.sn}`);\n fragNextLoad = nextSnFrag;\n } else {\n // If a fragment has dropped frames and it's in a same level/sequence, load the previous fragment to try and find the keyframe\n // Reset the dropped count now since it won't be reset until we parse the fragment again, which prevents infinite backtracking on the same segment\n logger.warn('Loaded fragment with dropped frames, backtracking 1 segment to find a keyframe');\n fragNextLoad.dropped = 0;\n if (prevSnFrag) {\n fragNextLoad = prevSnFrag;\n fragNextLoad.backtracked = true;\n } else if (curSNIdx) {\n // can't backtrack on very first fragment\n fragNextLoad = null;\n }\n }\n }\n }\n }\n\n return fragNextLoad;\n }\n\n _loadKey (frag, levelDetails) {\n logger.log(`Loading key for ${frag.sn} of [${levelDetails.startSN}-${levelDetails.endSN}], level ${this.level}`);\n this.state = State.KEY_LOADING;\n this.hls.trigger(Event.KEY_LOADING, { frag });\n }\n\n _loadFragment (frag, levelDetails, pos, bufferEnd) {\n // Check if fragment is not loaded\n let fragState = this.fragmentTracker.getState(frag);\n\n this.fragCurrent = frag;\n if (frag.sn !== 'initSegment') {\n this.startFragRequested = true;\n }\n // Don't update nextLoadPosition for fragments which are not buffered\n if (Number.isFinite(frag.sn) && !frag.bitrateTest) {\n this.nextLoadPosition = frag.start + frag.duration;\n }\n\n // Allow backtracked fragments to load\n if (frag.backtracked || fragState === FragmentState.NOT_LOADED || fragState === FragmentState.PARTIAL) {\n frag.autoLevel = this.hls.autoLevelEnabled;\n frag.bitrateTest = this.bitrateTest;\n\n logger.log(`Loading ${frag.sn} of [${levelDetails.startSN}-${levelDetails.endSN}], level ${this.level}, ${\n this.loadedmetadata ? 'currentTime' : 'nextLoadPosition'\n }: ${parseFloat(pos.toFixed(3))}, bufferEnd: ${parseFloat(bufferEnd.toFixed(3))}`);\n\n this.hls.trigger(Event.FRAG_LOADING, { frag });\n // lazy demuxer init, as this could take some time ... do it during frag loading\n if (!this.demuxer) {\n this.demuxer = new Demuxer(this.hls, 'main');\n }\n\n this.state = State.FRAG_LOADING;\n } else if (fragState === FragmentState.APPENDING) {\n // Lower the buffer size and try again\n if (this._reduceMaxBufferLength(frag.duration)) {\n this.fragmentTracker.removeFragment(frag);\n }\n }\n }\n\n set state (nextState) {\n if (this.state !== nextState) {\n const previousState = this.state;\n this._state = nextState;\n logger.log(`main stream-controller: ${previousState}->${nextState}`);\n this.hls.trigger(Event.STREAM_STATE_TRANSITION, { previousState, nextState });\n }\n }\n\n get state () {\n return this._state;\n }\n\n getBufferedFrag (position) {\n return this.fragmentTracker.getBufferedFrag(position, PlaylistLevelType.MAIN);\n }\n\n get currentLevel () {\n let media = this.media;\n if (media) {\n const frag = this.getBufferedFrag(media.currentTime);\n if (frag) {\n return frag.level;\n }\n }\n return -1;\n }\n\n get nextBufferedFrag () {\n let media = this.media;\n if (media) {\n // first get end range of current fragment\n return this.followingBufferedFrag(this.getBufferedFrag(media.currentTime));\n } else {\n return null;\n }\n }\n\n followingBufferedFrag (frag) {\n if (frag) {\n // try to get range of next fragment (500ms after this range)\n return this.getBufferedFrag(frag.endPTS + 0.5);\n }\n return null;\n }\n\n get nextLevel () {\n const frag = this.nextBufferedFrag;\n if (frag) {\n return frag.level;\n } else {\n return -1;\n }\n }\n\n _checkFragmentChanged () {\n let fragPlayingCurrent, currentTime, video = this.media;\n if (video && video.readyState && video.seeking === false) {\n currentTime = video.currentTime;\n /* if video element is in seeked state, currentTime can only increase.\n (assuming that playback rate is positive ...)\n As sometimes currentTime jumps back to zero after a\n media decode error, check this, to avoid seeking back to\n wrong position after a media decode error\n */\n if (currentTime > this.lastCurrentTime) {\n this.lastCurrentTime = currentTime;\n }\n\n if (BufferHelper.isBuffered(video, currentTime)) {\n fragPlayingCurrent = this.getBufferedFrag(currentTime);\n } else if (BufferHelper.isBuffered(video, currentTime + 0.1)) {\n /* ensure that FRAG_CHANGED event is triggered at startup,\n when first video frame is displayed and playback is paused.\n add a tolerance of 100ms, in case current position is not buffered,\n check if current pos+100ms is buffered and use that buffer range\n for FRAG_CHANGED event reporting */\n fragPlayingCurrent = this.getBufferedFrag(currentTime + 0.1);\n }\n if (fragPlayingCurrent) {\n let fragPlaying = fragPlayingCurrent;\n if (fragPlaying !== this.fragPlaying) {\n this.hls.trigger(Event.FRAG_CHANGED, { frag: fragPlaying });\n const fragPlayingLevel = fragPlaying.level;\n if (!this.fragPlaying || this.fragPlaying.level !== fragPlayingLevel) {\n this.hls.trigger(Event.LEVEL_SWITCHED, { level: fragPlayingLevel });\n }\n\n this.fragPlaying = fragPlaying;\n }\n }\n }\n }\n\n /*\n on immediate level switch :\n - pause playback if playing\n - cancel any pending load request\n - and trigger a buffer flush\n */\n immediateLevelSwitch () {\n logger.log('immediateLevelSwitch');\n if (!this.immediateSwitch) {\n this.immediateSwitch = true;\n let media = this.media, previouslyPaused;\n if (media) {\n previouslyPaused = media.paused;\n if (!previouslyPaused) {\n media.pause();\n }\n } else {\n // don't restart playback after instant level switch in case media not attached\n previouslyPaused = true;\n }\n this.previouslyPaused = previouslyPaused;\n }\n let fragCurrent = this.fragCurrent;\n if (fragCurrent && fragCurrent.loader) {\n fragCurrent.loader.abort();\n }\n\n this.fragCurrent = null;\n // flush everything\n this.flushMainBuffer(0, Number.POSITIVE_INFINITY);\n }\n\n /**\n * on immediate level switch end, after new fragment has been buffered:\n * - nudge video decoder by slightly adjusting video currentTime (if currentTime buffered)\n * - resume the playback if needed\n */\n immediateLevelSwitchEnd () {\n const media = this.media;\n if (media && media.buffered.length) {\n this.immediateSwitch = false;\n if (media.currentTime > 0 && BufferHelper.isBuffered(media, media.currentTime)) {\n // only nudge if currentTime is buffered\n media.currentTime -= 0.0001;\n }\n if (!this.previouslyPaused) {\n media.play();\n }\n }\n }\n\n /**\n * try to switch ASAP without breaking video playback:\n * in order to ensure smooth but quick level switching,\n * we need to find the next flushable buffer range\n * we should take into account new segment fetch time\n */\n nextLevelSwitch () {\n const media = this.media;\n // ensure that media is defined and that metadata are available (to retrieve currentTime)\n if (media && media.readyState) {\n let fetchdelay;\n const fragPlayingCurrent = this.getBufferedFrag(media.currentTime);\n if (fragPlayingCurrent && fragPlayingCurrent.startPTS > 1) {\n // flush buffer preceding current fragment (flush until current fragment start offset)\n // minus 1s to avoid video freezing, that could happen if we flush keyframe of current video ...\n this.flushMainBuffer(0, fragPlayingCurrent.startPTS - 1);\n }\n if (!media.paused) {\n // add a safety delay of 1s\n let nextLevelId = this.hls.nextLoadLevel, nextLevel = this.levels[nextLevelId], fragLastKbps = this.fragLastKbps;\n if (fragLastKbps && this.fragCurrent) {\n fetchdelay = this.fragCurrent.duration * nextLevel.bitrate / (1000 * fragLastKbps) + 1;\n } else {\n fetchdelay = 0;\n }\n } else {\n fetchdelay = 0;\n }\n // logger.log('fetchdelay:'+fetchdelay);\n // find buffer range that will be reached once new fragment will be fetched\n const bufferedFrag = this.getBufferedFrag(media.currentTime + fetchdelay);\n if (bufferedFrag) {\n // we can flush buffer range following this one without stalling playback\n const nextBufferedFrag = this.followingBufferedFrag(bufferedFrag);\n if (nextBufferedFrag) {\n // if we are here, we can also cancel any loading/demuxing in progress, as they are useless\n let fragCurrent = this.fragCurrent;\n if (fragCurrent && fragCurrent.loader) {\n fragCurrent.loader.abort();\n }\n\n this.fragCurrent = null;\n // start flush position is the start PTS of next buffered frag.\n // we use frag.naxStartPTS which is max(audio startPTS, video startPTS).\n // in case there is a small PTS Delta between audio and video, using maxStartPTS avoids flushing last samples from current fragment\n const startPts = Math.max(bufferedFrag.endPTS, nextBufferedFrag.maxStartPTS + Math.min(this.config.maxFragLookUpTolerance, nextBufferedFrag.duration));\n this.flushMainBuffer(startPts, Number.POSITIVE_INFINITY);\n }\n }\n }\n }\n\n flushMainBuffer (startOffset, endOffset) {\n this.state = State.BUFFER_FLUSHING;\n let flushScope = { startOffset: startOffset, endOffset: endOffset };\n // if alternate audio tracks are used, only flush video, otherwise flush everything\n if (this.altAudio) {\n flushScope.type = 'video';\n }\n\n this.hls.trigger(Event.BUFFER_FLUSHING, flushScope);\n }\n\n onMediaAttached (data) {\n let media = this.media = this.mediaBuffer = data.media;\n this.onvseeking = this.onMediaSeeking.bind(this);\n this.onvseeked = this.onMediaSeeked.bind(this);\n this.onvended = this.onMediaEnded.bind(this);\n media.addEventListener('seeking', this.onvseeking);\n media.addEventListener('seeked', this.onvseeked);\n media.addEventListener('ended', this.onvended);\n let config = this.config;\n if (this.levels && config.autoStartLoad) {\n this.hls.startLoad(config.startPosition);\n }\n\n this.gapController = new GapController(config, media, this.fragmentTracker, this.hls);\n }\n\n onMediaDetaching () {\n let media = this.media;\n if (media && media.ended) {\n logger.log('MSE detaching and video ended, reset startPosition');\n this.startPosition = this.lastCurrentTime = 0;\n }\n\n // reset fragment backtracked flag\n let levels = this.levels;\n if (levels) {\n levels.forEach(level => {\n if (level.details) {\n level.details.fragments.forEach(fragment => {\n fragment.backtracked = undefined;\n });\n }\n });\n }\n\n // remove video listeners\n if (media) {\n media.removeEventListener('seeking', this.onvseeking);\n media.removeEventListener('seeked', this.onvseeked);\n media.removeEventListener('ended', this.onvended);\n this.onvseeking = this.onvseeked = this.onvended = null;\n }\n\n this.fragmentTracker.removeAllFragments();\n this.media = this.mediaBuffer = null;\n this.loadedmetadata = false;\n this.stopLoad();\n }\n\n onMediaSeeked () {\n const media = this.media;\n const currentTime = media ? media.currentTime : undefined;\n if (Number.isFinite(currentTime)) {\n logger.log(`media seeked to ${currentTime.toFixed(3)}`);\n }\n\n // tick to speed up FRAGMENT_PLAYING triggering\n this.tick();\n }\n\n onManifestLoading () {\n // reset buffer on manifest loading\n logger.log('trigger BUFFER_RESET');\n this.hls.trigger(Event.BUFFER_RESET);\n this.fragmentTracker.removeAllFragments();\n this.stalled = false;\n this.startPosition = this.lastCurrentTime = 0;\n }\n\n onManifestParsed (data) {\n let aac = false, heaac = false, codec;\n data.levels.forEach(level => {\n // detect if we have different kind of audio codecs used amongst playlists\n codec = level.audioCodec;\n if (codec) {\n if (codec.indexOf('mp4a.40.2') !== -1) {\n aac = true;\n }\n\n if (codec.indexOf('mp4a.40.5') !== -1) {\n heaac = true;\n }\n }\n });\n this.audioCodecSwitch = (aac && heaac);\n if (this.audioCodecSwitch) {\n logger.log('both AAC/HE-AAC audio found in levels; declaring level codec as HE-AAC');\n }\n\n this.altAudio = data.altAudio;\n this.levels = data.levels;\n this.startFragRequested = false;\n let config = this.config;\n if (config.autoStartLoad || this.forceStartLoad) {\n this.hls.startLoad(config.startPosition);\n }\n }\n\n onLevelLoaded (data) {\n const newDetails = data.details;\n const newLevelId = data.level;\n const lastLevel = this.levels[this.levelLastLoaded];\n const curLevel = this.levels[newLevelId];\n const duration = newDetails.totalduration;\n let sliding = 0;\n\n logger.log(`level ${newLevelId} loaded [${newDetails.startSN},${newDetails.endSN}],duration:${duration}`);\n\n if (newDetails.live || (curLevel.details && curLevel.details.live)) {\n let curDetails = curLevel.details;\n if (curDetails && newDetails.fragments.length > 0) {\n // we already have details for that level, merge them\n LevelHelper.mergeDetails(curDetails, newDetails);\n sliding = newDetails.fragments[0].start;\n this.liveSyncPosition = this.computeLivePosition(sliding, curDetails);\n if (newDetails.PTSKnown && Number.isFinite(sliding)) {\n logger.log(`live playlist sliding:${sliding.toFixed(3)}`);\n } else {\n logger.log('live playlist - outdated PTS, unknown sliding');\n alignStream(this.fragPrevious, lastLevel, newDetails);\n }\n } else {\n logger.log('live playlist - first load, unknown sliding');\n newDetails.PTSKnown = false;\n alignStream(this.fragPrevious, lastLevel, newDetails);\n }\n } else {\n newDetails.PTSKnown = false;\n }\n // override level info\n curLevel.details = newDetails;\n this.levelLastLoaded = newLevelId;\n this.hls.trigger(Event.LEVEL_UPDATED, { details: newDetails, level: newLevelId });\n\n if (this.startFragRequested === false) {\n // compute start position if set to -1. use it straight away if value is defined\n if (this.startPosition === -1 || this.lastCurrentTime === -1) {\n // first, check if start time offset has been set in playlist, if yes, use this value\n let startTimeOffset = newDetails.startTimeOffset;\n if (Number.isFinite(startTimeOffset)) {\n if (startTimeOffset < 0) {\n logger.log(`negative start time offset ${startTimeOffset}, count from end of last fragment`);\n startTimeOffset = sliding + duration + startTimeOffset;\n }\n logger.log(`start time offset found in playlist, adjust startPosition to ${startTimeOffset}`);\n this.startPosition = startTimeOffset;\n } else {\n // if live playlist, set start position to be fragment N-this.config.liveSyncDurationCount (usually 3)\n if (newDetails.live) {\n this.startPosition = this.computeLivePosition(sliding, newDetails);\n logger.log(`configure startPosition to ${this.startPosition}`);\n } else {\n this.startPosition = 0;\n }\n }\n this.lastCurrentTime = this.startPosition;\n }\n this.nextLoadPosition = this.startPosition;\n }\n // only switch batck to IDLE state if we were waiting for level to start downloading a new fragment\n if (this.state === State.WAITING_LEVEL) {\n this.state = State.IDLE;\n }\n\n // trigger handler right now\n this.tick();\n }\n\n onKeyLoaded () {\n if (this.state === State.KEY_LOADING) {\n this.state = State.IDLE;\n this.tick();\n }\n }\n\n onFragLoaded (data) {\n const { fragCurrent, hls, levels, media } = this;\n const fragLoaded = data.frag;\n if (this.state === State.FRAG_LOADING &&\n fragCurrent &&\n fragLoaded.type === 'main' &&\n fragLoaded.level === fragCurrent.level &&\n fragLoaded.sn === fragCurrent.sn) {\n const stats = data.stats;\n const currentLevel = levels[fragCurrent.level];\n const details = currentLevel.details;\n // reset frag bitrate test in any case after frag loaded event\n // if this frag was loaded to perform a bitrate test AND if hls.nextLoadLevel is greater than 0\n // then this means that we should be able to load a fragment at a higher quality level\n this.bitrateTest = false;\n this.stats = stats;\n\n logger.log(`Loaded ${fragCurrent.sn} of [${details.startSN} ,${details.endSN}],level ${fragCurrent.level}`);\n if (fragLoaded.bitrateTest && hls.nextLoadLevel) {\n // switch back to IDLE state ... we just loaded a fragment to determine adequate start bitrate and initialize autoswitch algo\n this.state = State.IDLE;\n this.startFragRequested = false;\n stats.tparsed = stats.tbuffered = window.performance.now();\n hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: fragCurrent, id: 'main' });\n this.tick();\n } else if (fragLoaded.sn === 'initSegment') {\n this.state = State.IDLE;\n stats.tparsed = stats.tbuffered = window.performance.now();\n details.initSegment.data = data.payload;\n hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: fragCurrent, id: 'main' });\n this.tick();\n } else {\n logger.log(`Parsing ${fragCurrent.sn} of [${details.startSN} ,${details.endSN}],level ${fragCurrent.level}, cc ${fragCurrent.cc}`);\n this.state = State.PARSING;\n this.pendingBuffering = true;\n this.appended = false;\n\n // Bitrate test frags are not usually buffered so the fragment tracker ignores them. If Hls.js decides to buffer\n // it (and therefore ends up at this line), then the fragment tracker needs to be manually informed.\n if (fragLoaded.bitrateTest) {\n fragLoaded.bitrateTest = false;\n this.fragmentTracker.onFragLoaded({\n frag: fragLoaded\n });\n }\n\n // time Offset is accurate if level PTS is known, or if playlist is not sliding (not live) and if media is not seeking (this is to overcome potential timestamp drifts between playlists and fragments)\n const accurateTimeOffset = !(media && media.seeking) && (details.PTSKnown || !details.live);\n const initSegmentData = details.initSegment ? details.initSegment.data : [];\n const audioCodec = this._getAudioCodec(currentLevel);\n\n // transmux the MPEG-TS data to ISO-BMFF segments\n const demuxer = this.demuxer = this.demuxer || new Demuxer(this.hls, 'main');\n demuxer.push(\n data.payload,\n initSegmentData,\n audioCodec,\n currentLevel.videoCodec,\n fragCurrent,\n details.totalduration,\n accurateTimeOffset\n );\n }\n }\n this.fragLoadError = 0;\n }\n\n onFragParsingInitSegment (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n\n if (fragCurrent &&\n data.id === 'main' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n let tracks = data.tracks, trackName, track;\n\n this.audioOnly = tracks.audio && !tracks.video;\n\n // if audio track is expected to come from audio stream controller, discard any coming from main\n if (this.altAudio && !this.audioOnly) {\n delete tracks.audio;\n }\n\n // include levelCodec in audio and video tracks\n track = tracks.audio;\n if (track) {\n let audioCodec = this.levels[this.level].audioCodec,\n ua = navigator.userAgent.toLowerCase();\n if (audioCodec && this.audioCodecSwap) {\n logger.log('swapping playlist audio codec');\n if (audioCodec.indexOf('mp4a.40.5') !== -1) {\n audioCodec = 'mp4a.40.2';\n } else {\n audioCodec = 'mp4a.40.5';\n }\n }\n // in case AAC and HE-AAC audio codecs are signalled in manifest\n // force HE-AAC , as it seems that most browsers prefers that way,\n // except for mono streams OR on FF\n // these conditions might need to be reviewed ...\n if (this.audioCodecSwitch) {\n // don't force HE-AAC if mono stream\n if (track.metadata.channelCount !== 1 &&\n // don't force HE-AAC if firefox\n ua.indexOf('firefox') === -1) {\n audioCodec = 'mp4a.40.5';\n }\n }\n // HE-AAC is broken on Android, always signal audio codec as AAC even if variant manifest states otherwise\n if (ua.indexOf('android') !== -1 && track.container !== 'audio/mpeg') { // Exclude mpeg audio\n audioCodec = 'mp4a.40.2';\n logger.log(`Android: force audio codec to ${audioCodec}`);\n }\n track.levelCodec = audioCodec;\n track.id = data.id;\n }\n track = tracks.video;\n if (track) {\n track.levelCodec = this.levels[this.level].videoCodec;\n track.id = data.id;\n }\n this.hls.trigger(Event.BUFFER_CODECS, tracks);\n // loop through tracks that are going to be provided to bufferController\n for (trackName in tracks) {\n track = tracks[trackName];\n logger.log(`main track:${trackName},container:${track.container},codecs[level/parsed]=[${track.levelCodec}/${track.codec}]`);\n let initSegment = track.initSegment;\n if (initSegment) {\n this.appended = true;\n // arm pending Buffering flag before appending a segment\n this.pendingBuffering = true;\n this.hls.trigger(Event.BUFFER_APPENDING, { type: trackName, data: initSegment, parent: 'main', content: 'initSegment' });\n }\n }\n // trigger handler right now\n this.tick();\n }\n }\n\n onFragParsingData (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'main' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n !(data.type === 'audio' && this.altAudio) && // filter out main audio if audio track is loaded through audio stream controller\n this.state === State.PARSING) {\n let level = this.levels[this.level],\n frag = fragCurrent;\n if (!Number.isFinite(data.endPTS)) {\n data.endPTS = data.startPTS + fragCurrent.duration;\n data.endDTS = data.startDTS + fragCurrent.duration;\n }\n\n if (data.hasAudio === true) {\n frag.addElementaryStream(ElementaryStreamTypes.AUDIO);\n }\n\n if (data.hasVideo === true) {\n frag.addElementaryStream(ElementaryStreamTypes.VIDEO);\n }\n\n logger.log(`Parsed ${data.type},PTS:[${data.startPTS.toFixed(3)},${data.endPTS.toFixed(3)}],DTS:[${data.startDTS.toFixed(3)}/${data.endDTS.toFixed(3)}],nb:${data.nb},dropped:${data.dropped || 0}`);\n\n // Detect gaps in a fragment and try to fix it by finding a keyframe in the previous fragment (see _findFragments)\n if (data.type === 'video') {\n frag.dropped = data.dropped;\n if (frag.dropped) {\n if (!frag.backtracked) {\n const levelDetails = level.details;\n if (levelDetails && frag.sn === levelDetails.startSN) {\n logger.warn('missing video frame(s) on first frag, appending with gap', frag.sn);\n } else {\n logger.warn('missing video frame(s), backtracking fragment', frag.sn);\n // Return back to the IDLE state without appending to buffer\n // Causes findFragments to backtrack a segment and find the keyframe\n // Audio fragments arriving before video sets the nextLoadPosition, causing _findFragments to skip the backtracked fragment\n this.fragmentTracker.removeFragment(frag);\n frag.backtracked = true;\n this.nextLoadPosition = data.startPTS;\n this.state = State.IDLE;\n this.fragPrevious = frag;\n if (this.demuxer) {\n this.demuxer.destroy();\n this.demuxer = null;\n }\n this.tick();\n return;\n }\n } else {\n logger.warn('Already backtracked on this fragment, appending with the gap', frag.sn);\n }\n } else {\n // Only reset the backtracked flag if we've loaded the frag without any dropped frames\n frag.backtracked = false;\n }\n }\n\n let drift = LevelHelper.updateFragPTSDTS(level.details, frag, data.startPTS, data.endPTS, data.startDTS, data.endDTS),\n hls = this.hls;\n hls.trigger(Event.LEVEL_PTS_UPDATED, { details: level.details, level: this.level, drift: drift, type: data.type, start: data.startPTS, end: data.endPTS });\n // has remuxer dropped video frames located before first keyframe ?\n [data.data1, data.data2].forEach(buffer => {\n // only append in PARSING state (rationale is that an appending error could happen synchronously on first segment appending)\n // in that case it is useless to append following segments\n if (buffer && buffer.length && this.state === State.PARSING) {\n this.appended = true;\n // arm pending Buffering flag before appending a segment\n this.pendingBuffering = true;\n hls.trigger(Event.BUFFER_APPENDING, { type: data.type, data: buffer, parent: 'main', content: 'data' });\n }\n });\n // trigger handler right now\n this.tick();\n }\n }\n\n onFragParsed (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'main' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n this.stats.tparsed = window.performance.now();\n this.state = State.PARSED;\n this._checkAppendedParsed();\n }\n }\n\n onAudioTrackSwitching (data) {\n // if any URL found on new audio track, it is an alternate audio track\n const fromAltAudio = this.altAudio;\n const altAudio = !!data.url;\n const trackId = data.id;\n // if we switch on main audio, ensure that main fragment scheduling is synced with media.buffered\n // don't do anything if we switch to alt audio: audio stream controller is handling it.\n // we will just have to change buffer scheduling on audioTrackSwitched\n if (!altAudio) {\n if (this.mediaBuffer !== this.media) {\n logger.log('switching on main audio, use media.buffered to schedule main fragment loading');\n this.mediaBuffer = this.media;\n let fragCurrent = this.fragCurrent;\n // we need to refill audio buffer from main: cancel any frag loading to speed up audio switch\n if (fragCurrent.loader) {\n logger.log('switching to main audio track, cancel main fragment load');\n fragCurrent.loader.abort();\n }\n this.fragCurrent = null;\n this.fragPrevious = null;\n // destroy demuxer to force init segment generation (following audio switch)\n if (this.demuxer) {\n this.demuxer.destroy();\n this.demuxer = null;\n }\n // switch to IDLE state to load new fragment\n this.state = State.IDLE;\n }\n let hls = this.hls;\n // If switching from alt to main audio, flush all audio and trigger track switched\n if (fromAltAudio) {\n hls.trigger(Event.BUFFER_FLUSHING, {\n startOffset: 0,\n endOffset: Number.POSITIVE_INFINITY,\n type: 'audio'\n });\n }\n hls.trigger(Event.AUDIO_TRACK_SWITCHED, {\n id: trackId\n });\n }\n }\n\n onAudioTrackSwitched (data) {\n let trackId = data.id,\n altAudio = !!this.hls.audioTracks[trackId].url;\n if (altAudio) {\n let videoBuffer = this.videoBuffer;\n // if we switched on alternate audio, ensure that main fragment scheduling is synced with video sourcebuffer buffered\n if (videoBuffer && this.mediaBuffer !== videoBuffer) {\n logger.log('switching on alternate audio, use video.buffered to schedule main fragment loading');\n this.mediaBuffer = videoBuffer;\n }\n }\n this.altAudio = altAudio;\n this.tick();\n }\n\n onBufferCreated (data) {\n let tracks = data.tracks, mediaTrack, name, alternate = false;\n for (let type in tracks) {\n let track = tracks[type];\n if (track.id === 'main') {\n name = type;\n mediaTrack = track;\n // keep video source buffer reference\n if (type === 'video') {\n this.videoBuffer = tracks[type].buffer;\n }\n } else {\n alternate = true;\n }\n }\n if (alternate && mediaTrack) {\n logger.log(`alternate track found, use ${name}.buffered to schedule main fragment loading`);\n this.mediaBuffer = mediaTrack.buffer;\n } else {\n this.mediaBuffer = this.media;\n }\n }\n\n onBufferAppended (data) {\n if (data.parent === 'main') {\n const state = this.state;\n if (state === State.PARSING || state === State.PARSED) {\n // check if all buffers have been appended\n this.pendingBuffering = (data.pending > 0);\n this._checkAppendedParsed();\n }\n }\n }\n\n _checkAppendedParsed () {\n // trigger handler right now\n if (this.state === State.PARSED && (!this.appended || !this.pendingBuffering)) {\n const frag = this.fragCurrent;\n if (frag) {\n const media = this.mediaBuffer ? this.mediaBuffer : this.media;\n logger.log(`main buffered : ${TimeRanges.toString(media.buffered)}`);\n this.fragPrevious = frag;\n const stats = this.stats;\n stats.tbuffered = window.performance.now();\n // we should get rid of this.fragLastKbps\n this.fragLastKbps = Math.round(8 * stats.total / (stats.tbuffered - stats.tfirst));\n this.hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: frag, id: 'main' });\n this.state = State.IDLE;\n }\n // Do not tick when _seekToStartPos needs to be called as seeking to the start can fail on live streams at this point\n if (this.loadedmetadata || this.startPosition <= 0) {\n this.tick();\n }\n }\n }\n\n onError (data) {\n let frag = data.frag || this.fragCurrent;\n // don't handle frag error not related to main fragment\n if (frag && frag.type !== 'main') {\n return;\n }\n\n // 0.5 : tolerance needed as some browsers stalls playback before reaching buffered end\n let mediaBuffered = !!this.media && BufferHelper.isBuffered(this.media, this.media.currentTime) && BufferHelper.isBuffered(this.media, this.media.currentTime + 0.5);\n\n switch (data.details) {\n case ErrorDetails.FRAG_LOAD_ERROR:\n case ErrorDetails.FRAG_LOAD_TIMEOUT:\n case ErrorDetails.KEY_LOAD_ERROR:\n case ErrorDetails.KEY_LOAD_TIMEOUT:\n if (!data.fatal) {\n // keep retrying until the limit will be reached\n if ((this.fragLoadError + 1) <= this.config.fragLoadingMaxRetry) {\n // exponential backoff capped to config.fragLoadingMaxRetryTimeout\n let delay = Math.min(Math.pow(2, this.fragLoadError) * this.config.fragLoadingRetryDelay, this.config.fragLoadingMaxRetryTimeout);\n logger.warn(`mediaController: frag loading failed, retry in ${delay} ms`);\n this.retryDate = window.performance.now() + delay;\n // retry loading state\n // if loadedmetadata is not set, it means that we are emergency switch down on first frag\n // in that case, reset startFragRequested flag\n if (!this.loadedmetadata) {\n this.startFragRequested = false;\n this.nextLoadPosition = this.startPosition;\n }\n this.fragLoadError++;\n this.state = State.FRAG_LOADING_WAITING_RETRY;\n } else {\n logger.error(`mediaController: ${data.details} reaches max retry, redispatch as fatal ...`);\n // switch error to fatal\n data.fatal = true;\n this.state = State.ERROR;\n }\n }\n break;\n case ErrorDetails.LEVEL_LOAD_ERROR:\n case ErrorDetails.LEVEL_LOAD_TIMEOUT:\n if (this.state !== State.ERROR) {\n if (data.fatal) {\n // if fatal error, stop processing\n this.state = State.ERROR;\n logger.warn(`streamController: ${data.details},switch to ${this.state} state ...`);\n } else {\n // in case of non fatal error while loading level, if level controller is not retrying to load level , switch back to IDLE\n if (!data.levelRetry && this.state === State.WAITING_LEVEL) {\n this.state = State.IDLE;\n }\n }\n }\n break;\n case ErrorDetails.BUFFER_FULL_ERROR:\n // if in appending state\n if (data.parent === 'main' && (this.state === State.PARSING || this.state === State.PARSED)) {\n // reduce max buf len if current position is buffered\n if (mediaBuffered) {\n this._reduceMaxBufferLength(this.config.maxBufferLength);\n this.state = State.IDLE;\n } else {\n // current position is not buffered, but browser is still complaining about buffer full error\n // this happens on IE/Edge, refer to https://github.com/video-dev/hls.js/pull/708\n // in that case flush the whole buffer to recover\n logger.warn('buffer full error also media.currentTime is not buffered, flush everything');\n this.fragCurrent = null;\n // flush everything\n this.flushMainBuffer(0, Number.POSITIVE_INFINITY);\n }\n }\n break;\n default:\n break;\n }\n }\n\n _reduceMaxBufferLength (minLength) {\n let config = this.config;\n if (config.maxMaxBufferLength >= minLength) {\n // reduce max buffer length as it might be too high. we do this to avoid loop flushing ...\n config.maxMaxBufferLength /= 2;\n logger.warn(`main:reduce max buffer length to ${config.maxMaxBufferLength}s`);\n return true;\n }\n return false;\n }\n\n /**\n * Checks the health of the buffer and attempts to resolve playback stalls.\n * @private\n */\n _checkBuffer () {\n const { media } = this;\n if (!media || media.readyState === 0) {\n // Exit early if we don't have media or if the media hasn't bufferd anything yet (readyState 0)\n return;\n }\n\n const mediaBuffer = this.mediaBuffer ? this.mediaBuffer : media;\n const buffered = mediaBuffer.buffered;\n\n if (!this.loadedmetadata && buffered.length) {\n this.loadedmetadata = true;\n this._seekToStartPos();\n } else if (this.immediateSwitch) {\n this.immediateLevelSwitchEnd();\n } else {\n this.gapController.poll(this.lastCurrentTime, buffered);\n }\n }\n\n onFragLoadEmergencyAborted () {\n this.state = State.IDLE;\n // if loadedmetadata is not set, it means that we are emergency switch down on first frag\n // in that case, reset startFragRequested flag\n if (!this.loadedmetadata) {\n this.startFragRequested = false;\n this.nextLoadPosition = this.startPosition;\n }\n this.tick();\n }\n\n onBufferFlushed () {\n /* after successful buffer flushing, filter flushed fragments from bufferedFrags\n use mediaBuffered instead of media (so that we will check against video.buffered ranges in case of alt audio track)\n */\n const media = this.mediaBuffer ? this.mediaBuffer : this.media;\n if (media) {\n // filter fragments potentially evicted from buffer. this is to avoid memleak on live streams\n const elementaryStreamType = this.audioOnly ? ElementaryStreamTypes.AUDIO : ElementaryStreamTypes.VIDEO;\n this.fragmentTracker.detectEvictedFragments(elementaryStreamType, media.buffered);\n }\n // move to IDLE once flush complete. this should trigger new fragment loading\n this.state = State.IDLE;\n // reset reference to frag\n this.fragPrevious = null;\n }\n\n onLevelsUpdated (data) {\n this.levels = data.levels;\n }\n\n swapAudioCodec () {\n this.audioCodecSwap = !this.audioCodecSwap;\n }\n /**\n * Seeks to the set startPosition if not equal to the mediaElement's current time.\n * @private\n */\n _seekToStartPos () {\n const { media } = this;\n const currentTime = media.currentTime;\n let startPosition = this.startPosition;\n // only adjust currentTime if different from startPosition or if startPosition not buffered\n // at that stage, there should be only one buffered range, as we reach that code after first fragment has been buffered\n if (currentTime !== startPosition && startPosition >= 0) {\n if (media.seeking) {\n logger.log(`could not seek to ${startPosition}, already seeking at ${currentTime}`);\n return;\n }\n const bufferStart = media.buffered.length ? media.buffered.start(0) : 0;\n const delta = bufferStart - startPosition;\n if (delta > 0 && delta < this.config.maxBufferHole) {\n logger.log(`adjusting start position by ${delta} to match buffer start`);\n startPosition += delta;\n this.startPosition = startPosition;\n }\n logger.log(`seek to target start position ${startPosition} from current time ${currentTime}. ready state ${media.readyState}`);\n media.currentTime = startPosition;\n }\n }\n\n _getAudioCodec (currentLevel) {\n let audioCodec = this.config.defaultAudioCodec || currentLevel.audioCodec;\n if (this.audioCodecSwap) {\n logger.log('swapping playlist audio codec');\n if (audioCodec) {\n if (audioCodec.indexOf('mp4a.40.5') !== -1) {\n audioCodec = 'mp4a.40.2';\n } else {\n audioCodec = 'mp4a.40.5';\n }\n }\n }\n\n return audioCodec;\n }\n\n get liveSyncPosition () {\n return this._liveSyncPosition;\n }\n\n set liveSyncPosition (value) {\n this._liveSyncPosition = value;\n }\n}\nexport default StreamController;\n","/*\n * Level Controller\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { isCodecSupportedInMp4 } from '../utils/codecs';\nimport { addGroupId, computeReloadInterval } from './level-helper';\n\nlet chromeOrFirefox;\n\nexport default class LevelController extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.MANIFEST_LOADED,\n Event.LEVEL_LOADED,\n Event.AUDIO_TRACK_SWITCHED,\n Event.FRAG_LOADED,\n Event.ERROR);\n\n this.canload = false;\n this.currentLevelIndex = null;\n this.manualLevelIndex = -1;\n this.timer = null;\n\n chromeOrFirefox = /chrome|firefox/.test(navigator.userAgent.toLowerCase());\n }\n\n onHandlerDestroying () {\n this.clearTimer();\n this.manualLevelIndex = -1;\n }\n\n clearTimer () {\n if (this.timer !== null) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n }\n\n startLoad () {\n let levels = this._levels;\n\n this.canload = true;\n this.levelRetryCount = 0;\n\n // clean up live level details to force reload them, and reset load errors\n if (levels) {\n levels.forEach(level => {\n level.loadError = 0;\n const levelDetails = level.details;\n if (levelDetails && levelDetails.live) {\n level.details = undefined;\n }\n });\n }\n // speed up live playlist refresh if timer exists\n if (this.timer !== null) {\n this.loadLevel();\n }\n }\n\n stopLoad () {\n this.canload = false;\n }\n\n onManifestLoaded (data) {\n let levels = [];\n let audioTracks = [];\n let bitrateStart;\n let levelSet = {};\n let levelFromSet = null;\n let videoCodecFound = false;\n let audioCodecFound = false;\n\n // regroup redundant levels together\n data.levels.forEach(level => {\n const attributes = level.attrs;\n level.loadError = 0;\n level.fragmentError = false;\n\n videoCodecFound = videoCodecFound || !!level.videoCodec;\n audioCodecFound = audioCodecFound || !!level.audioCodec;\n\n // erase audio codec info if browser does not support mp4a.40.34.\n // demuxer will autodetect codec and fallback to mpeg/audio\n if (chromeOrFirefox && level.audioCodec && level.audioCodec.indexOf('mp4a.40.34') !== -1) {\n level.audioCodec = undefined;\n }\n\n levelFromSet = levelSet[level.bitrate]; // FIXME: we would also have to match the resolution here\n\n if (!levelFromSet) {\n level.url = [level.url];\n level.urlId = 0;\n levelSet[level.bitrate] = level;\n levels.push(level);\n } else {\n levelFromSet.url.push(level.url);\n }\n\n if (attributes) {\n if (attributes.AUDIO) {\n addGroupId(levelFromSet || level, 'audio', attributes.AUDIO);\n }\n if (attributes.SUBTITLES) {\n addGroupId(levelFromSet || level, 'text', attributes.SUBTITLES);\n }\n }\n });\n\n // remove audio-only level if we also have levels with audio+video codecs signalled\n if (videoCodecFound && audioCodecFound) {\n levels = levels.filter(({ videoCodec }) => !!videoCodec);\n }\n\n // only keep levels with supported audio/video codecs\n levels = levels.filter(({ audioCodec, videoCodec }) => {\n return (!audioCodec || isCodecSupportedInMp4(audioCodec, 'audio')) && (!videoCodec || isCodecSupportedInMp4(videoCodec, 'video'));\n });\n\n if (data.audioTracks) {\n audioTracks = data.audioTracks.filter(track => !track.audioCodec || isCodecSupportedInMp4(track.audioCodec, 'audio'));\n // Reassign id's after filtering since they're used as array indices\n audioTracks.forEach((track, index) => {\n track.id = index;\n });\n }\n\n if (levels.length > 0) {\n // start bitrate is the first bitrate of the manifest\n bitrateStart = levels[0].bitrate;\n // sort level on bitrate\n levels.sort((a, b) => a.bitrate - b.bitrate);\n this._levels = levels;\n // find index of first level in sorted levels\n for (let i = 0; i < levels.length; i++) {\n if (levels[i].bitrate === bitrateStart) {\n this._firstLevel = i;\n logger.log(`manifest loaded,${levels.length} level(s) found, first bitrate:${bitrateStart}`);\n break;\n }\n }\n\n // Audio is only alternate if manifest include a URI along with the audio group tag,\n // and this is not an audio-only stream where levels contain audio-only\n const audioOnly = audioCodecFound && !videoCodecFound;\n this.hls.trigger(Event.MANIFEST_PARSED, {\n levels,\n audioTracks,\n firstLevel: this._firstLevel,\n stats: data.stats,\n audio: audioCodecFound,\n video: videoCodecFound,\n altAudio: !audioOnly && audioTracks.some(t => !!t.url)\n });\n } else {\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.MANIFEST_INCOMPATIBLE_CODECS_ERROR,\n fatal: true,\n url: this.hls.url,\n reason: 'no level with compatible codecs found in manifest'\n });\n }\n }\n\n get levels () {\n return this._levels;\n }\n\n get level () {\n return this.currentLevelIndex;\n }\n\n set level (newLevel) {\n let levels = this._levels;\n if (levels) {\n newLevel = Math.min(newLevel, levels.length - 1);\n if (this.currentLevelIndex !== newLevel || !levels[newLevel].details) {\n this.setLevelInternal(newLevel);\n }\n }\n }\n\n setLevelInternal (newLevel) {\n const levels = this._levels;\n const hls = this.hls;\n // check if level idx is valid\n if (newLevel >= 0 && newLevel < levels.length) {\n // stopping live reloading timer if any\n this.clearTimer();\n if (this.currentLevelIndex !== newLevel) {\n logger.log(`switching to level ${newLevel}`);\n this.currentLevelIndex = newLevel;\n const levelProperties = levels[newLevel];\n levelProperties.level = newLevel;\n hls.trigger(Event.LEVEL_SWITCHING, levelProperties);\n }\n const level = levels[newLevel];\n const levelDetails = level.details;\n\n // check if we need to load playlist for this level\n if (!levelDetails || levelDetails.live) {\n // level not retrieved yet, or live playlist we need to (re)load it\n let urlId = level.urlId;\n hls.trigger(Event.LEVEL_LOADING, { url: level.url[urlId], level: newLevel, id: urlId });\n }\n } else {\n // invalid level id given, trigger error\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.OTHER_ERROR,\n details: ErrorDetails.LEVEL_SWITCH_ERROR,\n level: newLevel,\n fatal: false,\n reason: 'invalid level idx'\n });\n }\n }\n\n get manualLevel () {\n return this.manualLevelIndex;\n }\n\n set manualLevel (newLevel) {\n this.manualLevelIndex = newLevel;\n if (this._startLevel === undefined) {\n this._startLevel = newLevel;\n }\n\n if (newLevel !== -1) {\n this.level = newLevel;\n }\n }\n\n get firstLevel () {\n return this._firstLevel;\n }\n\n set firstLevel (newLevel) {\n this._firstLevel = newLevel;\n }\n\n get startLevel () {\n // hls.startLevel takes precedence over config.startLevel\n // if none of these values are defined, fallback on this._firstLevel (first quality level appearing in variant manifest)\n if (this._startLevel === undefined) {\n let configStartLevel = this.hls.config.startLevel;\n if (configStartLevel !== undefined) {\n return configStartLevel;\n } else {\n return this._firstLevel;\n }\n } else {\n return this._startLevel;\n }\n }\n\n set startLevel (newLevel) {\n this._startLevel = newLevel;\n }\n\n onError (data) {\n if (data.fatal) {\n if (data.type === ErrorTypes.NETWORK_ERROR) {\n this.clearTimer();\n }\n\n return;\n }\n\n let levelError = false, fragmentError = false;\n let levelIndex;\n\n // try to recover not fatal errors\n switch (data.details) {\n case ErrorDetails.FRAG_LOAD_ERROR:\n case ErrorDetails.FRAG_LOAD_TIMEOUT:\n case ErrorDetails.KEY_LOAD_ERROR:\n case ErrorDetails.KEY_LOAD_TIMEOUT:\n levelIndex = data.frag.level;\n fragmentError = true;\n break;\n case ErrorDetails.LEVEL_LOAD_ERROR:\n case ErrorDetails.LEVEL_LOAD_TIMEOUT:\n levelIndex = data.context.level;\n levelError = true;\n break;\n case ErrorDetails.REMUX_ALLOC_ERROR:\n levelIndex = data.level;\n levelError = true;\n break;\n }\n\n if (levelIndex !== undefined) {\n this.recoverLevel(data, levelIndex, levelError, fragmentError);\n }\n }\n\n /**\n * Switch to a redundant stream if any available.\n * If redundant stream is not available, emergency switch down if ABR mode is enabled.\n *\n * @param {Object} errorEvent\n * @param {Number} levelIndex current level index\n * @param {Boolean} levelError\n * @param {Boolean} fragmentError\n */\n // FIXME Find a better abstraction where fragment/level retry management is well decoupled\n recoverLevel (errorEvent, levelIndex, levelError, fragmentError) {\n let { config } = this.hls;\n let { details: errorDetails } = errorEvent;\n let level = this._levels[levelIndex];\n let redundantLevels, delay, nextLevel;\n\n level.loadError++;\n level.fragmentError = fragmentError;\n\n if (levelError) {\n if ((this.levelRetryCount + 1) <= config.levelLoadingMaxRetry) {\n // exponential backoff capped to max retry timeout\n delay = Math.min(Math.pow(2, this.levelRetryCount) * config.levelLoadingRetryDelay, config.levelLoadingMaxRetryTimeout);\n // Schedule level reload\n this.timer = setTimeout(() => this.loadLevel(), delay);\n // boolean used to inform stream controller not to switch back to IDLE on non fatal error\n errorEvent.levelRetry = true;\n this.levelRetryCount++;\n logger.warn(`level controller, ${errorDetails}, retry in ${delay} ms, current retry count is ${this.levelRetryCount}`);\n } else {\n logger.error(`level controller, cannot recover from ${errorDetails} error`);\n this.currentLevelIndex = null;\n // stopping live reloading timer if any\n this.clearTimer();\n // switch error to fatal\n errorEvent.fatal = true;\n return;\n }\n }\n\n // Try any redundant streams if available for both errors: level and fragment\n // If level.loadError reaches redundantLevels it means that we tried them all, no hope => let's switch down\n if (levelError || fragmentError) {\n redundantLevels = level.url.length;\n\n if (redundantLevels > 1 && level.loadError < redundantLevels) {\n level.urlId = (level.urlId + 1) % redundantLevels;\n level.details = undefined;\n\n logger.warn(`level controller, ${errorDetails} for level ${levelIndex}: switching to redundant URL-id ${level.urlId}`);\n\n // console.log('Current audio track group ID:', this.hls.audioTracks[this.hls.audioTrack].groupId);\n // console.log('New video quality level audio group id:', level.attrs.AUDIO);\n } else {\n // Search for available level\n if (this.manualLevelIndex === -1) {\n // When lowest level has been reached, let's start hunt from the top\n nextLevel = (levelIndex === 0) ? this._levels.length - 1 : levelIndex - 1;\n logger.warn(`level controller, ${errorDetails}: switch to ${nextLevel}`);\n this.hls.nextAutoLevel = this.currentLevelIndex = nextLevel;\n } else if (fragmentError) {\n // Allow fragment retry as long as configuration allows.\n // reset this._level so that another call to set level() will trigger again a frag load\n logger.warn(`level controller, ${errorDetails}: reload a fragment`);\n this.currentLevelIndex = null;\n }\n }\n }\n }\n\n // reset errors on the successful load of a fragment\n onFragLoaded ({ frag }) {\n if (frag !== undefined && frag.type === 'main') {\n const level = this._levels[frag.level];\n if (level !== undefined) {\n level.fragmentError = false;\n level.loadError = 0;\n this.levelRetryCount = 0;\n }\n }\n }\n\n onLevelLoaded (data) {\n const { level, details } = data;\n // only process level loaded events matching with expected level\n if (level !== this.currentLevelIndex) {\n return;\n }\n\n const curLevel = this._levels[level];\n // reset level load error counter on successful level loaded only if there is no issues with fragments\n if (!curLevel.fragmentError) {\n curLevel.loadError = 0;\n this.levelRetryCount = 0;\n }\n // if current playlist is a live playlist, arm a timer to reload it\n if (details.live) {\n const reloadInterval = computeReloadInterval(curLevel.details, details, data.stats.trequest);\n logger.log(`live playlist, reload in ${Math.round(reloadInterval)} ms`);\n this.timer = setTimeout(() => this.loadLevel(), reloadInterval);\n } else {\n this.clearTimer();\n }\n }\n\n onAudioTrackSwitched (data) {\n const audioGroupId = this.hls.audioTracks[data.id].groupId;\n\n const currentLevel = this.hls.levels[this.currentLevelIndex];\n if (!currentLevel) {\n return;\n }\n\n if (currentLevel.audioGroupIds) {\n let urlId = -1;\n\n for (let i = 0; i < currentLevel.audioGroupIds.length; i++) {\n if (currentLevel.audioGroupIds[i] === audioGroupId) {\n urlId = i;\n break;\n }\n }\n\n if (urlId !== currentLevel.urlId) {\n currentLevel.urlId = urlId;\n this.startLoad();\n }\n }\n }\n\n loadLevel () {\n logger.debug('call to loadLevel');\n\n if (this.currentLevelIndex !== null && this.canload) {\n const levelObject = this._levels[this.currentLevelIndex];\n\n if (typeof levelObject === 'object' &&\n levelObject.url.length > 0) {\n const level = this.currentLevelIndex;\n const id = levelObject.urlId;\n const url = levelObject.url[id];\n\n logger.log(`Attempt loading level index ${level} with URL-id ${id}`);\n\n // console.log('Current audio track group ID:', this.hls.audioTracks[this.hls.audioTrack].groupId);\n // console.log('New video quality level audio group id:', levelObject.attrs.AUDIO, level);\n\n this.hls.trigger(Event.LEVEL_LOADING, { url, level, id });\n }\n }\n }\n\n get nextLoadLevel () {\n if (this.manualLevelIndex !== -1) {\n return this.manualLevelIndex;\n } else {\n return this.hls.nextAutoLevel;\n }\n }\n\n set nextLoadLevel (nextLevel) {\n this.level = nextLevel;\n if (this.manualLevelIndex === -1) {\n this.hls.nextAutoLevel = nextLevel;\n }\n }\n\n removeLevel (levelIndex, urlId) {\n const levels = this.levels.filter((level, index) => {\n if (index !== levelIndex) {\n return true;\n }\n\n if (level.url.length > 1 && urlId !== undefined) {\n level.url = level.url.filter((url, id) => id !== urlId);\n level.urlId = 0;\n return true;\n }\n return false;\n }).map((level, index) => {\n const { details } = level;\n if (details && details.fragments) {\n details.fragments.forEach((fragment) => {\n fragment.level = index;\n });\n }\n return level;\n });\n\n this._levels = levels;\n\n this.hls.trigger(Event.LEVELS_UPDATED, { levels });\n }\n}\n","\nexport function sendAddTrackEvent (track: TextTrack, videoEl: HTMLMediaElement) {\n let event: Event;\n try {\n event = new Event('addtrack');\n } catch (err) {\n // for IE11\n event = document.createEvent('Event');\n event.initEvent('addtrack', false, false);\n }\n (event as any).track = track;\n videoEl.dispatchEvent(event);\n}\n\nexport function clearCurrentCues (track: TextTrack) {\n if (track?.cues) {\n while (track.cues.length > 0) {\n track.removeCue(track.cues[0]);\n }\n }\n}\n\n/**\n * Given a list of Cues, finds the closest cue matching the given time.\n * Modified verison of binary search O(log(n)).\n *\n * @export\n * @param {(TextTrackCueList | TextTrackCue[])} cues - List of cues.\n * @param {number} time - Target time, to find closest cue to.\n * @returns {TextTrackCue}\n */\nexport function getClosestCue (cues: TextTrackCueList | TextTrackCue[], time: number): TextTrackCue {\n // If the offset is less than the first element, the first element is the closest.\n if (time < cues[0].endTime) {\n return cues[0];\n }\n // If the offset is greater than the last cue, the last is the closest.\n if (time > cues[cues.length - 1].endTime) {\n return cues[cues.length - 1];\n }\n\n let left = 0;\n let right = cues.length - 1;\n\n while (left <= right) {\n const mid = Math.floor((right + left) / 2);\n\n if (time < cues[mid].endTime) {\n right = mid - 1;\n } else if (time > cues[mid].endTime) {\n left = mid + 1;\n } else {\n // If it's not lower or higher, it must be equal.\n return cues[mid];\n }\n }\n // At this point, left and right have swapped.\n // No direct match was found, left or right element must be the closest. Check which one has the smallest diff.\n return (cues[left].endTime - time) < (time - cues[right].endTime) ? cues[left] : cues[right];\n}\n","/*\n * id3 metadata track controller\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport ID3 from '../demux/id3';\nimport { sendAddTrackEvent, clearCurrentCues, getClosestCue } from '../utils/texttrack-utils';\n\nconst MIN_CUE_DURATION = 0.25;\n\nclass ID3TrackController extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.FRAG_PARSING_METADATA,\n Event.LIVE_BACK_BUFFER_REACHED\n );\n this.id3Track = undefined;\n this.media = undefined;\n }\n\n destroy () {\n EventHandler.prototype.destroy.call(this);\n }\n\n // Add ID3 metatadata text track.\n onMediaAttached (data) {\n this.media = data.media;\n if (!this.media) {\n\n }\n }\n\n onMediaDetaching () {\n clearCurrentCues(this.id3Track);\n this.id3Track = undefined;\n this.media = undefined;\n }\n\n getID3Track (textTracks) {\n for (let i = 0; i < textTracks.length; i++) {\n let textTrack = textTracks[i];\n if (textTrack.kind === 'metadata' && textTrack.label === 'id3') {\n // send 'addtrack' when reusing the textTrack for metadata,\n // same as what we do for captions\n sendAddTrackEvent(textTrack, this.media);\n\n return textTrack;\n }\n }\n return this.media.addTextTrack('metadata', 'id3');\n }\n\n onFragParsingMetadata (data) {\n const fragment = data.frag;\n const samples = data.samples;\n\n // create track dynamically\n if (!this.id3Track) {\n this.id3Track = this.getID3Track(this.media.textTracks);\n this.id3Track.mode = 'hidden';\n }\n\n // Attempt to recreate Safari functionality by creating\n // WebKitDataCue objects when available and store the decoded\n // ID3 data in the value property of the cue\n let Cue = window.WebKitDataCue || window.VTTCue || window.TextTrackCue;\n\n for (let i = 0; i < samples.length; i++) {\n const frames = ID3.getID3Frames(samples[i].data);\n if (frames) {\n // Ensure the pts is positive - sometimes it's reported as a small negative number\n let startTime = Math.max(samples[i].pts, 0);\n let endTime = i < samples.length - 1 ? samples[i + 1].pts : fragment.endPTS;\n if (!endTime) {\n endTime = fragment.start + fragment.duration;\n }\n\n const timeDiff = endTime - startTime;\n if (timeDiff <= 0) {\n endTime = startTime + MIN_CUE_DURATION;\n }\n\n for (let j = 0; j < frames.length; j++) {\n const frame = frames[j];\n // Safari doesn't put the timestamp frame in the TextTrack\n if (!ID3.isTimeStampFrame(frame)) {\n const cue = new Cue(startTime, endTime, '');\n cue.value = frame;\n this.id3Track.addCue(cue);\n }\n }\n }\n }\n }\n\n onLiveBackBufferReached ({ bufferEnd }) {\n const { id3Track } = this;\n if (!id3Track || !id3Track.cues || !id3Track.cues.length) {\n return;\n }\n const foundCue = getClosestCue(id3Track.cues, bufferEnd);\n if (!foundCue) {\n return;\n }\n while (id3Track.cues[0] !== foundCue) {\n id3Track.removeCue(id3Track.cues[0]);\n }\n }\n}\n\nexport default ID3TrackController;\n","/*\n * compute an Exponential Weighted moving average\n * - https://en.wikipedia.org/wiki/Moving_average#Exponential_moving_average\n * - heavily inspired from shaka-player\n */\n\nclass EWMA {\n private alpha_: number;\n private estimate_: number;\n private totalWeight_: number;\n\n // About half of the estimated value will be from the last |halfLife| samples by weight.\n constructor (halfLife: number) {\n // Larger values of alpha expire historical data more slowly.\n this.alpha_ = halfLife ? Math.exp(Math.log(0.5) / halfLife) : 0;\n this.estimate_ = 0;\n this.totalWeight_ = 0;\n }\n\n sample (weight: number, value: number) {\n let adjAlpha = Math.pow(this.alpha_, weight);\n this.estimate_ = value * (1 - adjAlpha) + adjAlpha * this.estimate_;\n this.totalWeight_ += weight;\n }\n\n getTotalWeight (): number {\n return this.totalWeight_;\n }\n\n getEstimate (): number {\n if (this.alpha_) {\n let zeroFactor = 1 - Math.pow(this.alpha_, this.totalWeight_);\n return this.estimate_ / zeroFactor;\n } else {\n return this.estimate_;\n }\n }\n}\n\nexport default EWMA;\n","/*\n * EWMA Bandwidth Estimator\n * - heavily inspired from shaka-player\n * Tracks bandwidth samples and estimates available bandwidth.\n * Based on the minimum of two exponentially-weighted moving averages with\n * different half-lives.\n */\n\nimport EWMA from '../utils/ewma';\n\nclass EwmaBandWidthEstimator {\n hls: any;\n\n private defaultEstimate_: number;\n private minWeight_: number;\n private minDelayMs_: number;\n private slow_: EWMA;\n private fast_: EWMA;\n\n // TODO(typescript-hls)\n constructor (hls: any, slow: number, fast: number, defaultEstimate: number) {\n this.hls = hls;\n this.defaultEstimate_ = defaultEstimate;\n this.minWeight_ = 0.001;\n this.minDelayMs_ = 50;\n this.slow_ = new EWMA(slow);\n this.fast_ = new EWMA(fast);\n }\n\n sample (durationMs: number, numBytes: number) {\n durationMs = Math.max(durationMs, this.minDelayMs_);\n let numBits = 8 * numBytes,\n // weight is duration in seconds\n durationS = durationMs / 1000,\n // value is bandwidth in bits/s\n bandwidthInBps = numBits / durationS;\n this.fast_.sample(durationS, bandwidthInBps);\n this.slow_.sample(durationS, bandwidthInBps);\n }\n\n canEstimate (): boolean {\n let fast = this.fast_;\n return (fast && fast.getTotalWeight() >= this.minWeight_);\n }\n\n getEstimate (): number {\n if (this.canEstimate()) {\n // console.log('slow estimate:'+ Math.round(this.slow_.getEstimate()));\n // console.log('fast estimate:'+ Math.round(this.fast_.getEstimate()));\n // Take the minimum of these two estimates. This should have the effect of\n // adapting down quickly, but up more slowly.\n return Math.min(this.fast_.getEstimate(), this.slow_.getEstimate());\n } else {\n return this.defaultEstimate_;\n }\n }\n\n destroy () {\n }\n}\nexport default EwmaBandWidthEstimator;\n","/*\n * simple ABR Controller\n * - compute next level based on last fragment bw heuristics\n * - implement an abandon rules triggered if we have less than 2 frag buffered and if computed bw shows that we risk buffer stalling\n */\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport { ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport EwmaBandWidthEstimator from '../utils/ewma-bandwidth-estimator';\n\nconst { performance } = window;\n\nclass AbrController extends EventHandler {\n constructor (hls) {\n super(hls, Event.FRAG_LOADING,\n Event.FRAG_LOADED,\n Event.FRAG_BUFFERED,\n Event.ERROR);\n this.lastLoadedFragLevel = 0;\n this._nextAutoLevel = -1;\n this.hls = hls;\n this.timer = null;\n this._bwEstimator = null;\n this.onCheck = this._abandonRulesCheck.bind(this);\n }\n\n destroy () {\n this.clearTimer();\n EventHandler.prototype.destroy.call(this);\n }\n\n onFragLoading (data) {\n const frag = data.frag;\n if (frag.type === 'main') {\n if (!this.timer) {\n this.fragCurrent = frag;\n this.timer = setInterval(this.onCheck, 100);\n }\n\n // lazy init of BwEstimator, rationale is that we use different params for Live/VoD\n // so we need to wait for stream manifest / playlist type to instantiate it.\n if (!this._bwEstimator) {\n const hls = this.hls;\n const config = hls.config;\n const level = frag.level;\n const isLive = hls.levels[level].details.live;\n\n let ewmaFast;\n let ewmaSlow;\n if (isLive) {\n ewmaFast = config.abrEwmaFastLive;\n ewmaSlow = config.abrEwmaSlowLive;\n } else {\n ewmaFast = config.abrEwmaFastVoD;\n ewmaSlow = config.abrEwmaSlowVoD;\n }\n this._bwEstimator = new EwmaBandWidthEstimator(hls, ewmaSlow, ewmaFast, config.abrEwmaDefaultEstimate);\n }\n }\n }\n\n _abandonRulesCheck () {\n /*\n monitor fragment retrieval time...\n we compute expected time of arrival of the complete fragment.\n we compare it to expected time of buffer starvation\n */\n const hls = this.hls;\n const video = hls.media;\n const frag = this.fragCurrent;\n\n if (!frag) {\n return;\n }\n\n const loader = frag.loader;\n\n // if loader has been destroyed or loading has been aborted, stop timer and return\n if (!loader || (loader.stats && loader.stats.aborted)) {\n logger.warn('frag loader destroy or aborted, disarm abandonRules');\n this.clearTimer();\n // reset forced auto level value so that next level will be selected\n this._nextAutoLevel = -1;\n return;\n }\n let stats = loader.stats;\n /* only monitor frag retrieval time if\n (video not paused OR first fragment being loaded(ready state === HAVE_NOTHING = 0)) AND autoswitching enabled AND not lowest level (=> means that we have several levels) */\n if (video && stats && ((!video.paused && (video.playbackRate !== 0)) || !video.readyState) && frag.autoLevel && frag.level) {\n const requestDelay = performance.now() - stats.trequest;\n const playbackRate = Math.abs(video.playbackRate);\n\n // monitor fragment load progress after half of expected fragment duration,to stabilize bitrate\n if (requestDelay > (500 * frag.duration / playbackRate)) {\n const levels = hls.levels;\n const loadRate = Math.max(1, stats.bw ? stats.bw / 8 : stats.loaded * 1000 / requestDelay); // byte/s; at least 1 byte/s to avoid division by zero\n\n // compute expected fragment length using frag duration and level bitrate. also ensure that expected len is gte than already loaded size\n const level = levels[frag.level];\n if (!level) {\n return;\n }\n const levelBitrate = level.realBitrate ? Math.max(level.realBitrate, level.bitrate) : level.bitrate;\n const expectedLen = stats.total ? stats.total : Math.max(stats.loaded, Math.round(frag.duration * levelBitrate / 8));\n const pos = video.currentTime;\n const fragLoadedDelay = (expectedLen - stats.loaded) / loadRate;\n const bufferStarvationDelay = (BufferHelper.bufferInfo(video, pos, hls.config.maxBufferHole).end - pos) / playbackRate;\n\n // consider emergency switch down only if we have less than 2 frag buffered AND\n // time to finish loading current fragment is bigger than buffer starvation delay\n // ie if we risk buffer starvation if bw does not increase quickly\n if ((bufferStarvationDelay < (2 * frag.duration / playbackRate)) && (fragLoadedDelay > bufferStarvationDelay)) {\n const minAutoLevel = hls.minAutoLevel;\n let fragLevelNextLoadedDelay;\n let nextLoadLevel;\n // lets iterate through lower level and try to find the biggest one that could avoid rebuffering\n // we start from current level - 1 and we step down , until we find a matching level\n for (nextLoadLevel = frag.level - 1; nextLoadLevel > minAutoLevel; nextLoadLevel--) {\n // compute time to load next fragment at lower level\n // 0.8 : consider only 80% of current bw to be conservative\n // 8 = bits per byte (bps/Bps)\n const levelNextBitrate = levels[nextLoadLevel].realBitrate\n ? Math.max(levels[nextLoadLevel].realBitrate, levels[nextLoadLevel].bitrate)\n : levels[nextLoadLevel].bitrate;\n\n const fragLevelNextLoadedDelay = frag.duration * levelNextBitrate / (8 * 0.8 * loadRate);\n\n if (fragLevelNextLoadedDelay < bufferStarvationDelay) {\n // we found a lower level that be rebuffering free with current estimated bw !\n break;\n }\n }\n // only emergency switch down if it takes less time to load new fragment at lowest level instead\n // of finishing loading current one ...\n if (fragLevelNextLoadedDelay < fragLoadedDelay) {\n logger.warn(`loading too slow, abort fragment loading and switch to level ${nextLoadLevel}:fragLoadedDelay[${nextLoadLevel}]<fragLoadedDelay[${frag.level - 1}];bufferStarvationDelay:${fragLevelNextLoadedDelay.toFixed(1)}<${fragLoadedDelay.toFixed(1)}:${bufferStarvationDelay.toFixed(1)}`);\n // force next load level in auto mode\n hls.nextLoadLevel = nextLoadLevel;\n // update bw estimate for this fragment before cancelling load (this will help reducing the bw)\n this._bwEstimator.sample(requestDelay, stats.loaded);\n // abort fragment loading\n loader.abort();\n // stop abandon rules timer\n this.clearTimer();\n hls.trigger(Event.FRAG_LOAD_EMERGENCY_ABORTED, { frag: frag, stats: stats });\n }\n }\n }\n }\n }\n\n onFragLoaded (data) {\n const frag = data.frag;\n if (frag.type === 'main' && Number.isFinite(frag.sn)) {\n // stop monitoring bw once frag loaded\n this.clearTimer();\n // store level id after successful fragment load\n this.lastLoadedFragLevel = frag.level;\n // reset forced auto level value so that next level will be selected\n this._nextAutoLevel = -1;\n\n // compute level average bitrate\n if (this.hls.config.abrMaxWithRealBitrate) {\n const level = this.hls.levels[frag.level];\n let loadedBytes = (level.loaded ? level.loaded.bytes : 0) + data.stats.loaded;\n let loadedDuration = (level.loaded ? level.loaded.duration : 0) + data.frag.duration;\n level.loaded = { bytes: loadedBytes, duration: loadedDuration };\n level.realBitrate = Math.round(8 * loadedBytes / loadedDuration);\n }\n // if fragment has been loaded to perform a bitrate test,\n if (data.frag.bitrateTest) {\n let stats = data.stats;\n stats.tparsed = stats.tbuffered = stats.tload;\n this.onFragBuffered(data);\n }\n }\n }\n\n onFragBuffered (data) {\n const stats = data.stats;\n const frag = data.frag;\n // only update stats on first frag buffering\n // if same frag is loaded multiple times, it might be in browser cache, and loaded quickly\n // and leading to wrong bw estimation\n // on bitrate test, also only update stats once (if tload = tbuffered == on FRAG_LOADED)\n if (stats.aborted !== true && frag.type === 'main' && Number.isFinite(frag.sn) && ((!frag.bitrateTest || stats.tload === stats.tbuffered))) {\n // use tparsed-trequest instead of tbuffered-trequest to compute fragLoadingProcessing; rationale is that buffer appending only happens once media is attached\n // in case we use config.startFragPrefetch while media is not attached yet, fragment might be parsed while media not attached yet, but it will only be buffered on media attached\n // as a consequence it could happen really late in the process. meaning that appending duration might appears huge ... leading to underestimated throughput estimation\n let fragLoadingProcessingMs = stats.tparsed - stats.trequest;\n logger.log(`latency/loading/parsing/append/kbps:${Math.round(stats.tfirst - stats.trequest)}/${Math.round(stats.tload - stats.tfirst)}/${Math.round(stats.tparsed - stats.tload)}/${Math.round(stats.tbuffered - stats.tparsed)}/${Math.round(8 * stats.loaded / (stats.tbuffered - stats.trequest))}`);\n this._bwEstimator.sample(fragLoadingProcessingMs, stats.loaded);\n stats.bwEstimate = this._bwEstimator.getEstimate();\n // if fragment has been loaded to perform a bitrate test, (hls.startLevel = -1), store bitrate test delay duration\n if (frag.bitrateTest) {\n this.bitrateTestDelay = fragLoadingProcessingMs / 1000;\n } else {\n this.bitrateTestDelay = 0;\n }\n }\n }\n\n onError (data) {\n // stop timer in case of frag loading error\n switch (data.details) {\n case ErrorDetails.FRAG_LOAD_ERROR:\n case ErrorDetails.FRAG_LOAD_TIMEOUT:\n this.clearTimer();\n break;\n default:\n break;\n }\n }\n\n clearTimer () {\n clearInterval(this.timer);\n this.timer = null;\n }\n\n // return next auto level\n get nextAutoLevel () {\n const forcedAutoLevel = this._nextAutoLevel;\n const bwEstimator = this._bwEstimator;\n // in case next auto level has been forced, and bw not available or not reliable, return forced value\n if (forcedAutoLevel !== -1 && (!bwEstimator || !bwEstimator.canEstimate())) {\n return forcedAutoLevel;\n }\n\n // compute next level using ABR logic\n let nextABRAutoLevel = this._nextABRAutoLevel;\n // if forced auto level has been defined, use it to cap ABR computed quality level\n if (forcedAutoLevel !== -1) {\n nextABRAutoLevel = Math.min(forcedAutoLevel, nextABRAutoLevel);\n }\n\n return nextABRAutoLevel;\n }\n get _nextABRAutoLevel () {\n let hls = this.hls;\n const { maxAutoLevel, levels, config, minAutoLevel } = hls;\n const video = hls.media;\n const currentLevel = this.lastLoadedFragLevel;\n const currentFragDuration = this.fragCurrent ? this.fragCurrent.duration : 0;\n const pos = (video ? video.currentTime : 0);\n\n // playbackRate is the absolute value of the playback rate; if video.playbackRate is 0, we use 1 to load as\n // if we're playing back at the normal rate.\n const playbackRate = ((video && (video.playbackRate !== 0)) ? Math.abs(video.playbackRate) : 1.0);\n const avgbw = this._bwEstimator ? this._bwEstimator.getEstimate() : config.abrEwmaDefaultEstimate;\n // bufferStarvationDelay is the wall-clock time left until the playback buffer is exhausted.\n const bufferStarvationDelay = (BufferHelper.bufferInfo(video, pos, config.maxBufferHole).end - pos) / playbackRate;\n\n // First, look to see if we can find a level matching with our avg bandwidth AND that could also guarantee no rebuffering at all\n let bestLevel = this._findBestLevel(currentLevel, currentFragDuration, avgbw, minAutoLevel, maxAutoLevel, bufferStarvationDelay, config.abrBandWidthFactor, config.abrBandWidthUpFactor, levels);\n if (bestLevel >= 0) {\n return bestLevel;\n } else {\n logger.trace('rebuffering expected to happen, lets try to find a quality level minimizing the rebuffering');\n // not possible to get rid of rebuffering ... let's try to find level that will guarantee less than maxStarvationDelay of rebuffering\n // if no matching level found, logic will return 0\n let maxStarvationDelay = currentFragDuration ? Math.min(currentFragDuration, config.maxStarvationDelay) : config.maxStarvationDelay;\n let bwFactor = config.abrBandWidthFactor;\n let bwUpFactor = config.abrBandWidthUpFactor;\n\n if (bufferStarvationDelay === 0) {\n // in case buffer is empty, let's check if previous fragment was loaded to perform a bitrate test\n let bitrateTestDelay = this.bitrateTestDelay;\n if (bitrateTestDelay) {\n // if it is the case, then we need to adjust our max starvation delay using maxLoadingDelay config value\n // max video loading delay used in automatic start level selection :\n // in that mode ABR controller will ensure that video loading time (ie the time to fetch the first fragment at lowest quality level +\n // the time to fetch the fragment at the appropriate quality level is less than ```maxLoadingDelay``` )\n // cap maxLoadingDelay and ensure it is not bigger 'than bitrate test' frag duration\n const maxLoadingDelay = currentFragDuration ? Math.min(currentFragDuration, config.maxLoadingDelay) : config.maxLoadingDelay;\n maxStarvationDelay = maxLoadingDelay - bitrateTestDelay;\n logger.trace(`bitrate test took ${Math.round(1000 * bitrateTestDelay)}ms, set first fragment max fetchDuration to ${Math.round(1000 * maxStarvationDelay)} ms`);\n // don't use conservative factor on bitrate test\n bwFactor = bwUpFactor = 1;\n }\n }\n bestLevel = this._findBestLevel(currentLevel, currentFragDuration, avgbw, minAutoLevel, maxAutoLevel, bufferStarvationDelay + maxStarvationDelay, bwFactor, bwUpFactor, levels);\n return Math.max(bestLevel, 0);\n }\n }\n\n _findBestLevel (currentLevel, currentFragDuration, currentBw, minAutoLevel, maxAutoLevel, maxFetchDuration, bwFactor, bwUpFactor, levels) {\n for (let i = maxAutoLevel; i >= minAutoLevel; i--) {\n let levelInfo = levels[i];\n\n if (!levelInfo) {\n continue;\n }\n\n const levelDetails = levelInfo.details;\n const avgDuration = levelDetails ? levelDetails.totalduration / levelDetails.fragments.length : currentFragDuration;\n const live = levelDetails ? levelDetails.live : false;\n\n let adjustedbw;\n // follow algorithm captured from stagefright :\n // https://android.googlesource.com/platform/frameworks/av/+/master/media/libstagefright/httplive/LiveSession.cpp\n // Pick the highest bandwidth stream below or equal to estimated bandwidth.\n // consider only 80% of the available bandwidth, but if we are switching up,\n // be even more conservative (70%) to avoid overestimating and immediately\n // switching back.\n if (i <= currentLevel) {\n adjustedbw = bwFactor * currentBw;\n } else {\n adjustedbw = bwUpFactor * currentBw;\n }\n\n const bitrate = levels[i].realBitrate ? Math.max(levels[i].realBitrate, levels[i].bitrate) : levels[i].bitrate;\n const fetchDuration = bitrate * avgDuration / adjustedbw;\n\n logger.trace(`level/adjustedbw/bitrate/avgDuration/maxFetchDuration/fetchDuration: ${i}/${Math.round(adjustedbw)}/${bitrate}/${avgDuration}/${maxFetchDuration}/${fetchDuration}`);\n // if adjusted bw is greater than level bitrate AND\n if (adjustedbw > bitrate &&\n // fragment fetchDuration unknown OR live stream OR fragment fetchDuration less than max allowed fetch duration, then this level matches\n // we don't account for max Fetch Duration for live streams, this is to avoid switching down when near the edge of live sliding window ...\n // special case to support startLevel = -1 (bitrateTest) on live streams : in that case we should not exit loop so that _findBestLevel will return -1\n (!fetchDuration || (live && !this.bitrateTestDelay) || fetchDuration < maxFetchDuration)) {\n // as we are looping from highest to lowest, this will return the best achievable quality level\n return i;\n }\n }\n // not enough time budget even with quality level 0 ... rebuffering might happen\n return -1;\n }\n\n set nextAutoLevel (nextLevel) {\n this._nextAutoLevel = nextLevel;\n }\n}\n\nexport default AbrController;\n","/*\n * Buffer Controller\n */\n\nimport Events from '../events';\nimport EventHandler from '../event-handler';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { getMediaSource } from '../utils/mediasource-helper';\n\nimport { TrackSet } from '../types/track';\nimport { Segment } from '../types/segment';\nimport { BufferControllerConfig } from '../config';\n\n// Add extension properties to SourceBuffers from the DOM API.\ntype ExtendedSourceBuffer = SourceBuffer & {\n ended?: boolean\n};\n\ntype SourceBufferName = 'video' | 'audio';\ntype SourceBuffers = Partial<Record<SourceBufferName, ExtendedSourceBuffer>>;\n\ninterface SourceBufferFlushRange {\n start: number;\n end: number;\n type: SourceBufferName\n}\n\nconst MediaSource = getMediaSource();\n\nclass BufferController extends EventHandler {\n // the value that we have set mediasource.duration to\n // (the actual duration may be tweaked slighly by the browser)\n private _msDuration: number | null = null;\n // the value that we want to set mediaSource.duration to\n private _levelDuration: number | null = null;\n // the target duration of the current media playlist\n private _levelTargetDuration: number = 10;\n // current stream state: true - for live broadcast, false - for VoD content\n private _live: boolean | null = null;\n // cache the self generated object url to detect hijack of video tag\n private _objectUrl: string | null = null;\n\n // signals that the sourceBuffers need to be flushed\n private _needsFlush: boolean = false;\n\n // signals that mediaSource should have endOfStream called\n private _needsEos: boolean = false;\n\n private config: BufferControllerConfig;\n\n // this is optional because this property is removed from the class sometimes\n public audioTimestampOffset?: number;\n\n // The number of BUFFER_CODEC events received before any sourceBuffers are created\n public bufferCodecEventsExpected: number = 0;\n\n // The total number of BUFFER_CODEC events received\n private _bufferCodecEventsTotal: number = 0;\n\n // A reference to the attached media element\n public media: HTMLMediaElement | null = null;\n\n // A reference to the active media source\n public mediaSource: MediaSource | null = null;\n\n // List of pending segments to be appended to source buffer\n public segments: Segment[] = [];\n\n public parent?: string;\n\n // A guard to see if we are currently appending to the source buffer\n public appending: boolean = false;\n\n // counters\n public appended: number = 0;\n public appendError: number = 0;\n public flushBufferCounter: number = 0;\n\n public tracks: TrackSet = {};\n public pendingTracks: TrackSet = {};\n public sourceBuffer: SourceBuffers = {};\n public flushRange: SourceBufferFlushRange[] = [];\n\n constructor (hls: any) {\n super(hls,\n Events.MEDIA_ATTACHING,\n Events.MEDIA_DETACHING,\n Events.MANIFEST_PARSED,\n Events.BUFFER_RESET,\n Events.BUFFER_APPENDING,\n Events.BUFFER_CODECS,\n Events.BUFFER_EOS,\n Events.BUFFER_FLUSHING,\n Events.LEVEL_PTS_UPDATED,\n Events.LEVEL_UPDATED);\n\n this.config = hls.config;\n }\n\n destroy () {\n EventHandler.prototype.destroy.call(this);\n }\n\n onLevelPtsUpdated (data: { type: SourceBufferName, start: number }) {\n let type = data.type;\n let audioTrack = this.tracks.audio;\n\n // Adjusting `SourceBuffer.timestampOffset` (desired point in the timeline where the next frames should be appended)\n // in Chrome browser when we detect MPEG audio container and time delta between level PTS and `SourceBuffer.timestampOffset`\n // is greater than 100ms (this is enough to handle seek for VOD or level change for LIVE videos). At the time of change we issue\n // `SourceBuffer.abort()` and adjusting `SourceBuffer.timestampOffset` if `SourceBuffer.updating` is false or awaiting `updateend`\n // event if SB is in updating state.\n // More info here: https://github.com/video-dev/hls.js/issues/332#issuecomment-257986486\n\n if (type === 'audio' && audioTrack && audioTrack.container === 'audio/mpeg') { // Chrome audio mp3 track\n let audioBuffer = this.sourceBuffer.audio;\n if (!audioBuffer) {\n throw Error('Level PTS Updated and source buffer for audio uninitalized');\n }\n\n let delta = Math.abs(audioBuffer.timestampOffset - data.start);\n\n // adjust timestamp offset if time delta is greater than 100ms\n if (delta > 0.1) {\n let updating = audioBuffer.updating;\n\n try {\n audioBuffer.abort();\n } catch (err) {\n logger.warn('can not abort audio buffer: ' + err);\n }\n\n if (!updating) {\n logger.warn('change mpeg audio timestamp offset from ' + audioBuffer.timestampOffset + ' to ' + data.start);\n audioBuffer.timestampOffset = data.start;\n } else {\n this.audioTimestampOffset = data.start;\n }\n }\n }\n }\n\n onManifestParsed (data: { altAudio: boolean, audio: boolean, video: boolean }) {\n // in case of alt audio (where all tracks have urls) 2 BUFFER_CODECS events will be triggered, one per stream controller\n // sourcebuffers will be created all at once when the expected nb of tracks will be reached\n // in case alt audio is not used, only one BUFFER_CODEC event will be fired from main stream controller\n // it will contain the expected nb of source buffers, no need to compute it\n let codecEvents: number = 2;\n if (data.audio && !data.video || !data.altAudio) {\n codecEvents = 1;\n }\n this.bufferCodecEventsExpected = this._bufferCodecEventsTotal = codecEvents;\n\n logger.log(`${this.bufferCodecEventsExpected} bufferCodec event(s) expected`);\n }\n\n onMediaAttaching (data: { media: HTMLMediaElement }) {\n let media = this.media = data.media;\n if (media && MediaSource) {\n // setup the media source\n let ms = this.mediaSource = new MediaSource();\n // Media Source listeners\n ms.addEventListener('sourceopen', this._onMediaSourceOpen);\n ms.addEventListener('sourceended', this._onMediaSourceEnded);\n ms.addEventListener('sourceclose', this._onMediaSourceClose);\n // link video and media Source\n media.src = window.URL.createObjectURL(ms);\n // cache the locally generated object url\n this._objectUrl = media.src;\n }\n }\n\n onMediaDetaching () {\n logger.log('media source detaching');\n let ms = this.mediaSource;\n if (ms) {\n if (ms.readyState === 'open') {\n try {\n // endOfStream could trigger exception if any sourcebuffer is in updating state\n // we don't really care about checking sourcebuffer state here,\n // as we are anyway detaching the MediaSource\n // let's just avoid this exception to propagate\n ms.endOfStream();\n } catch (err) {\n logger.warn(`onMediaDetaching:${err.message} while calling endOfStream`);\n }\n }\n ms.removeEventListener('sourceopen', this._onMediaSourceOpen);\n ms.removeEventListener('sourceended', this._onMediaSourceEnded);\n ms.removeEventListener('sourceclose', this._onMediaSourceClose);\n\n // Detach properly the MediaSource from the HTMLMediaElement as\n // suggested in https://github.com/w3c/media-source/issues/53.\n if (this.media) {\n if (this._objectUrl) {\n window.URL.revokeObjectURL(this._objectUrl);\n }\n\n // clean up video tag src only if it's our own url. some external libraries might\n // hijack the video tag and change its 'src' without destroying the Hls instance first\n if (this.media.src === this._objectUrl) {\n this.media.removeAttribute('src');\n this.media.load();\n } else {\n logger.warn('media.src was changed by a third party - skip cleanup');\n }\n }\n\n this.mediaSource = null;\n this.media = null;\n this._objectUrl = null;\n this.bufferCodecEventsExpected = this._bufferCodecEventsTotal;\n this.pendingTracks = {};\n this.tracks = {};\n this.sourceBuffer = {};\n this.flushRange = [];\n this.segments = [];\n this.appended = 0;\n }\n\n this.hls.trigger(Events.MEDIA_DETACHED);\n }\n\n checkPendingTracks () {\n let { bufferCodecEventsExpected, pendingTracks } = this;\n\n // Check if we've received all of the expected bufferCodec events. When none remain, create all the sourceBuffers at once.\n // This is important because the MSE spec allows implementations to throw QuotaExceededErrors if creating new sourceBuffers after\n // data has been appended to existing ones.\n // 2 tracks is the max (one for audio, one for video). If we've reach this max go ahead and create the buffers.\n const pendingTracksCount = Object.keys(pendingTracks).length;\n if ((pendingTracksCount && !bufferCodecEventsExpected) || pendingTracksCount === 2) {\n // ok, let's create them now !\n this.createSourceBuffers(pendingTracks);\n this.pendingTracks = {};\n // append any pending segments now !\n this.doAppending();\n }\n }\n\n private _onMediaSourceOpen = () => {\n logger.log('media source opened');\n this.hls.trigger(Events.MEDIA_ATTACHED, { media: this.media });\n let mediaSource = this.mediaSource;\n if (mediaSource) {\n // once received, don't listen anymore to sourceopen event\n mediaSource.removeEventListener('sourceopen', this._onMediaSourceOpen);\n }\n this.checkPendingTracks();\n }\n\n private _onMediaSourceClose = () => {\n logger.log('media source closed');\n }\n\n private _onMediaSourceEnded = () => {\n logger.log('media source ended');\n }\n\n private _onSBUpdateEnd = () => {\n // update timestampOffset\n if (this.audioTimestampOffset && this.sourceBuffer.audio) {\n let audioBuffer = this.sourceBuffer.audio;\n\n logger.warn(`change mpeg audio timestamp offset from ${audioBuffer.timestampOffset} to ${this.audioTimestampOffset}`);\n audioBuffer.timestampOffset = this.audioTimestampOffset;\n delete this.audioTimestampOffset;\n }\n\n if (this._needsFlush) {\n this.doFlush();\n }\n\n if (this._needsEos) {\n this.checkEos();\n }\n\n this.appending = false;\n let parent = this.parent;\n // count nb of pending segments waiting for appending on this sourcebuffer\n let pending = this.segments.reduce((counter, segment) => (segment.parent === parent) ? counter + 1 : counter, 0);\n\n // this.sourceBuffer is better to use than media.buffered as it is closer to the PTS data from the fragments\n const timeRanges: Partial<Record<SourceBufferName, TimeRanges>> = {};\n const sbSet = this.sourceBuffer;\n for (let streamType in sbSet) {\n const sb = sbSet[streamType as SourceBufferName];\n if (!sb) {\n throw Error(`handling source buffer update end error: source buffer for ${streamType} uninitilized and unable to update buffered TimeRanges.`);\n }\n timeRanges[streamType as SourceBufferName] = sb.buffered;\n }\n\n this.hls.trigger(Events.BUFFER_APPENDED, { parent, pending, timeRanges });\n // don't append in flushing mode\n if (!this._needsFlush) {\n this.doAppending();\n }\n\n this.updateMediaElementDuration();\n\n // appending goes first\n if (pending === 0) {\n this.flushLiveBackBuffer();\n }\n }\n\n private _onSBUpdateError = (event: Event) => {\n logger.error('sourceBuffer error:', event);\n // according to http://www.w3.org/TR/media-source/#sourcebuffer-append-error\n // this error might not always be fatal (it is fatal if decode error is set, in that case\n // it will be followed by a mediaElement error ...)\n this.hls.trigger(Events.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.BUFFER_APPENDING_ERROR, fatal: false });\n // we don't need to do more than that, as accordin to the spec, updateend will be fired just after\n }\n\n onBufferReset () {\n const sourceBuffer = this.sourceBuffer;\n for (let type in sourceBuffer) {\n const sb = sourceBuffer[type];\n try {\n if (sb) {\n if (this.mediaSource) {\n this.mediaSource.removeSourceBuffer(sb);\n }\n sb.removeEventListener('updateend', this._onSBUpdateEnd);\n sb.removeEventListener('error', this._onSBUpdateError);\n }\n } catch (err) {\n }\n }\n this.sourceBuffer = {};\n this.flushRange = [];\n this.segments = [];\n this.appended = 0;\n }\n\n onBufferCodecs (tracks: TrackSet) {\n // if source buffer(s) not created yet, appended buffer tracks in this.pendingTracks\n // if sourcebuffers already created, do nothing ...\n if (Object.keys(this.sourceBuffer).length) {\n return;\n }\n\n Object.keys(tracks).forEach(trackName => {\n this.pendingTracks[trackName] = tracks[trackName];\n });\n\n this.bufferCodecEventsExpected = Math.max(this.bufferCodecEventsExpected - 1, 0);\n if (this.mediaSource && this.mediaSource.readyState === 'open') {\n this.checkPendingTracks();\n }\n }\n\n createSourceBuffers (tracks: TrackSet) {\n const { sourceBuffer, mediaSource } = this;\n if (!mediaSource) {\n throw Error('createSourceBuffers called when mediaSource was null');\n }\n\n for (let trackName in tracks) {\n if (!sourceBuffer[trackName]) {\n let track = tracks[trackName as keyof TrackSet];\n if (!track) {\n throw Error(`source buffer exists for track ${trackName}, however track does not`);\n }\n // use levelCodec as first priority\n let codec = track.levelCodec || track.codec;\n let mimeType = `${track.container};codecs=${codec}`;\n logger.log(`creating sourceBuffer(${mimeType})`);\n try {\n let sb = sourceBuffer[trackName] = mediaSource.addSourceBuffer(mimeType);\n sb.addEventListener('updateend', this._onSBUpdateEnd);\n sb.addEventListener('error', this._onSBUpdateError);\n this.tracks[trackName] = {\n buffer: sb,\n codec: codec,\n id: track.id,\n container: track.container,\n levelCodec: track.levelCodec\n };\n } catch (err) {\n logger.error(`error while trying to add sourceBuffer:${err.message}`);\n this.hls.trigger(Events.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.BUFFER_ADD_CODEC_ERROR, fatal: false, err: err, mimeType: mimeType });\n }\n }\n }\n this.hls.trigger(Events.BUFFER_CREATED, { tracks: this.tracks });\n }\n\n onBufferAppending (data: Segment) {\n if (!this._needsFlush) {\n if (!this.segments) {\n this.segments = [ data ];\n } else {\n this.segments.push(data);\n }\n\n this.doAppending();\n }\n }\n\n // on BUFFER_EOS mark matching sourcebuffer(s) as ended and trigger checkEos()\n // an undefined data.type will mark all buffers as EOS.\n onBufferEos (data: { type?: SourceBufferName }) {\n for (const type in this.sourceBuffer) {\n if (!data.type || data.type === type) {\n const sb = this.sourceBuffer[type as SourceBufferName];\n if (sb && !sb.ended) {\n sb.ended = true;\n logger.log(`${type} sourceBuffer now EOS`);\n }\n }\n }\n\n this.checkEos();\n }\n\n // if all source buffers are marked as ended, signal endOfStream() to MediaSource.\n checkEos () {\n const { sourceBuffer, mediaSource } = this;\n if (!mediaSource || mediaSource.readyState !== 'open') {\n this._needsEos = false;\n return;\n }\n\n for (let type in sourceBuffer) {\n const sb = sourceBuffer[type as SourceBufferName];\n if (!sb) continue;\n\n if (!sb.ended) {\n return;\n }\n\n if (sb.updating) {\n this._needsEos = true;\n return;\n }\n }\n\n logger.log('all media data are available, signal endOfStream() to MediaSource and stop loading fragment');\n // Notify the media element that it now has all of the media data\n try {\n mediaSource.endOfStream();\n } catch (e) {\n logger.warn('exception while calling mediaSource.endOfStream()');\n }\n this._needsEos = false;\n }\n\n onBufferFlushing (data: { startOffset: number, endOffset: number, type?: SourceBufferName }) {\n if (data.type) {\n this.flushRange.push({ start: data.startOffset, end: data.endOffset, type: data.type });\n } else {\n this.flushRange.push({ start: data.startOffset, end: data.endOffset, type: 'video' });\n this.flushRange.push({ start: data.startOffset, end: data.endOffset, type: 'audio' });\n }\n\n // attempt flush immediately\n this.flushBufferCounter = 0;\n this.doFlush();\n }\n\n flushLiveBackBuffer () {\n // clear back buffer for live only\n if (!this._live) {\n return;\n }\n\n const liveBackBufferLength = this.config.liveBackBufferLength;\n if (!isFinite(liveBackBufferLength) || liveBackBufferLength < 0) {\n return;\n }\n\n if (!this.media) {\n logger.error('flushLiveBackBuffer called without attaching media');\n return;\n }\n\n const currentTime = this.media.currentTime;\n const sourceBuffer = this.sourceBuffer;\n const bufferTypes = Object.keys(sourceBuffer);\n const targetBackBufferPosition = currentTime - Math.max(liveBackBufferLength, this._levelTargetDuration);\n\n for (let index = bufferTypes.length - 1; index >= 0; index--) {\n const bufferType = bufferTypes[index];\n const sb = sourceBuffer[bufferType as SourceBufferName];\n if (sb) {\n const buffered = sb.buffered;\n // when target buffer start exceeds actual buffer start\n if (buffered.length > 0 && targetBackBufferPosition > buffered.start(0)) {\n // remove buffer up until current time minus minimum back buffer length (removing buffer too close to current\n // time will lead to playback freezing)\n // credits for level target duration - https://github.com/videojs/http-streaming/blob/3132933b6aa99ddefab29c10447624efd6fd6e52/src/segment-loader.js#L91\n if (this.removeBufferRange(bufferType, sb, 0, targetBackBufferPosition)) {\n this.hls.trigger(Events.LIVE_BACK_BUFFER_REACHED, { bufferEnd: targetBackBufferPosition });\n }\n }\n }\n }\n }\n\n onLevelUpdated ({ details }: { details: { totalduration: number, targetduration?: number, averagetargetduration?: number, live: boolean, fragments: any[] } }) {\n if (details.fragments.length > 0) {\n this._levelDuration = details.totalduration + details.fragments[0].start;\n this._levelTargetDuration = details.averagetargetduration || details.targetduration || 10;\n this._live = details.live;\n this.updateMediaElementDuration();\n }\n }\n\n /**\n * Update Media Source duration to current level duration or override to Infinity if configuration parameter\n * 'liveDurationInfinity` is set to `true`\n * More details: https://github.com/video-dev/hls.js/issues/355\n */\n updateMediaElementDuration () {\n let { config } = this;\n let duration: number;\n\n if (this._levelDuration === null ||\n !this.media ||\n !this.mediaSource ||\n !this.sourceBuffer ||\n this.media.readyState === 0 ||\n this.mediaSource.readyState !== 'open') {\n return;\n }\n\n for (let type in this.sourceBuffer) {\n const sb = this.sourceBuffer[type];\n if (sb && sb.updating === true) {\n // can't set duration whilst a buffer is updating\n return;\n }\n }\n\n duration = this.media.duration;\n // initialise to the value that the media source is reporting\n if (this._msDuration === null) {\n this._msDuration = this.mediaSource.duration;\n }\n\n if (this._live === true && config.liveDurationInfinity === true) {\n // Override duration to Infinity\n logger.log('Media Source duration is set to Infinity');\n this._msDuration = this.mediaSource.duration = Infinity;\n } else if ((this._levelDuration > this._msDuration && this._levelDuration > duration) || !Number.isFinite(duration)) {\n // levelDuration was the last value we set.\n // not using mediaSource.duration as the browser may tweak this value\n // only update Media Source duration if its value increase, this is to avoid\n // flushing already buffered portion when switching between quality level\n logger.log(`Updating Media Source duration to ${this._levelDuration.toFixed(3)}`);\n this._msDuration = this.mediaSource.duration = this._levelDuration;\n }\n }\n\n doFlush () {\n // loop through all buffer ranges to flush\n while (this.flushRange.length) {\n let range = this.flushRange[0];\n // flushBuffer will abort any buffer append in progress and flush Audio/Video Buffer\n if (this.flushBuffer(range.start, range.end, range.type)) {\n // range flushed, remove from flush array\n this.flushRange.shift();\n this.flushBufferCounter = 0;\n } else {\n this._needsFlush = true;\n // avoid looping, wait for SB update end to retrigger a flush\n return;\n }\n }\n if (this.flushRange.length === 0) {\n // everything flushed\n this._needsFlush = false;\n\n // let's recompute this.appended, which is used to avoid flush looping\n let appended = 0;\n let sourceBuffer = this.sourceBuffer;\n try {\n for (let type in sourceBuffer) {\n const sb = sourceBuffer[type];\n if (sb) {\n appended += sb.buffered.length;\n }\n }\n } catch (error) {\n // error could be thrown while accessing buffered, in case sourcebuffer has already been removed from MediaSource\n // this is harmess at this stage, catch this to avoid reporting an internal exception\n logger.error('error while accessing sourceBuffer.buffered');\n }\n this.appended = appended;\n this.hls.trigger(Events.BUFFER_FLUSHED);\n }\n }\n\n doAppending () {\n let { config, hls, segments, sourceBuffer } = this;\n if (!Object.keys(sourceBuffer).length) {\n // early exit if no source buffers have been initialized yet\n return;\n }\n\n if (!this.media || this.media.error) {\n this.segments = [];\n logger.error('trying to append although a media error occured, flush segment and abort');\n return;\n }\n\n if (this.appending) {\n // logger.log(`sb appending in progress`);\n return;\n }\n\n const segment = segments.shift();\n if (!segment) { // handle undefined shift\n return;\n }\n\n try {\n const sb = sourceBuffer[segment.type];\n if (!sb) {\n // in case we don't have any source buffer matching with this segment type,\n // it means that Mediasource fails to create sourcebuffer\n // discard this segment, and trigger update end\n this._onSBUpdateEnd();\n return;\n }\n\n if (sb.updating) {\n // if we are still updating the source buffer from the last segment, place this back at the front of the queue\n segments.unshift(segment);\n return;\n }\n\n // reset sourceBuffer ended flag before appending segment\n sb.ended = false;\n // logger.log(`appending ${segment.content} ${type} SB, size:${segment.data.length}, ${segment.parent}`);\n this.parent = segment.parent;\n sb.appendBuffer(segment.data);\n this.appendError = 0;\n this.appended++;\n this.appending = true;\n } catch (err) {\n // in case any error occured while appending, put back segment in segments table\n logger.error(`error while trying to append buffer:${err.message}`);\n segments.unshift(segment);\n let event = { type: ErrorTypes.MEDIA_ERROR, parent: segment.parent, details: '', fatal: false };\n if (err.code === 22) {\n // QuotaExceededError: http://www.w3.org/TR/html5/infrastructure.html#quotaexceedederror\n // let's stop appending any segments, and report BUFFER_FULL_ERROR error\n this.segments = [];\n event.details = ErrorDetails.BUFFER_FULL_ERROR;\n } else {\n this.appendError++;\n event.details = ErrorDetails.BUFFER_APPEND_ERROR;\n /* with UHD content, we could get loop of quota exceeded error until\n browser is able to evict some data from sourcebuffer. retrying help recovering this\n */\n if (this.appendError > config.appendErrorMaxRetry) {\n logger.log(`fail ${config.appendErrorMaxRetry} times to append segment in sourceBuffer`);\n this.segments = [];\n event.fatal = true;\n }\n }\n hls.trigger(Events.ERROR, event);\n }\n }\n\n /*\n flush specified buffered range,\n return true once range has been flushed.\n as sourceBuffer.remove() is asynchronous, flushBuffer will be retriggered on sourceBuffer update end\n */\n flushBuffer (startOffset: number, endOffset: number, sbType: SourceBufferName): boolean {\n const sourceBuffer = this.sourceBuffer;\n // exit if no sourceBuffers are initialized\n if (!Object.keys(sourceBuffer).length) {\n return true;\n }\n\n let currentTime: string = 'null';\n if (this.media) {\n currentTime = this.media.currentTime.toFixed(3);\n }\n logger.log(`flushBuffer,pos/start/end: ${currentTime}/${startOffset}/${endOffset}`);\n\n // safeguard to avoid infinite looping : don't try to flush more than the nb of appended segments\n if (this.flushBufferCounter >= this.appended) {\n logger.warn('abort flushing too many retries');\n return true;\n }\n\n const sb = sourceBuffer[sbType];\n // we are going to flush buffer, mark source buffer as 'not ended'\n if (sb) {\n sb.ended = false;\n if (!sb.updating) {\n if (this.removeBufferRange(sbType, sb, startOffset, endOffset)) {\n this.flushBufferCounter++;\n return false;\n }\n } else {\n logger.warn('cannot flush, sb updating in progress');\n return false;\n }\n }\n\n logger.log('buffer flushed');\n // everything flushed !\n return true;\n }\n\n /**\n * Removes first buffered range from provided source buffer that lies within given start and end offsets.\n *\n * @param {string} type Type of the source buffer, logging purposes only.\n * @param {SourceBuffer} sb Target SourceBuffer instance.\n * @param {number} startOffset\n * @param {number} endOffset\n *\n * @returns {boolean} True when source buffer remove requested.\n */\n removeBufferRange (type: string, sb: ExtendedSourceBuffer, startOffset: number, endOffset: number): boolean {\n try {\n for (let i = 0; i < sb.buffered.length; i++) {\n let bufStart = sb.buffered.start(i);\n let bufEnd = sb.buffered.end(i);\n let removeStart = Math.max(bufStart, startOffset);\n let removeEnd = Math.min(bufEnd, endOffset);\n\n /* sometimes sourcebuffer.remove() does not flush\n the exact expected time range.\n to avoid rounding issues/infinite loop,\n only flush buffer range of length greater than 500ms.\n */\n if (Math.min(removeEnd, bufEnd) - removeStart > 0.5) {\n let currentTime: string = 'null';\n if (this.media) {\n currentTime = this.media.currentTime.toString();\n }\n\n logger.log(`sb remove ${type} [${removeStart},${removeEnd}], of [${bufStart},${bufEnd}], pos:${currentTime}`);\n sb.remove(removeStart, removeEnd);\n return true;\n }\n }\n } catch (error) {\n logger.warn('removeBufferRange failed', error);\n }\n\n return false;\n }\n}\n\nexport default BufferController;\n","/*\n * cap stream level to media size dimension controller\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\n\nclass CapLevelController extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.FPS_DROP_LEVEL_CAPPING,\n Event.MEDIA_ATTACHING,\n Event.MANIFEST_PARSED,\n Event.LEVELS_UPDATED,\n Event.BUFFER_CODECS,\n Event.MEDIA_DETACHING);\n\n this.autoLevelCapping = Number.POSITIVE_INFINITY;\n this.firstLevel = null;\n this.levels = [];\n this.media = null;\n this.restrictedLevels = [];\n this.timer = null;\n this.clientRect = null;\n }\n\n destroy () {\n if (this.hls.config.capLevelToPlayerSize) {\n this.media = null;\n this.clientRect = null;\n this.stopCapping();\n }\n }\n\n onFpsDropLevelCapping (data) {\n // Don't add a restricted level more than once\n if (CapLevelController.isLevelAllowed(data.droppedLevel, this.restrictedLevels)) {\n this.restrictedLevels.push(data.droppedLevel);\n }\n }\n\n onMediaAttaching (data) {\n this.media = data.media instanceof window.HTMLVideoElement ? data.media : null;\n }\n\n onManifestParsed (data) {\n const hls = this.hls;\n this.restrictedLevels = [];\n this.levels = data.levels;\n this.firstLevel = data.firstLevel;\n if (hls.config.capLevelToPlayerSize && data.video) {\n // Start capping immediately if the manifest has signaled video codecs\n this.startCapping();\n }\n }\n\n // Only activate capping when playing a video stream; otherwise, multi-bitrate audio-only streams will be restricted\n // to the first level\n onBufferCodecs (data) {\n const hls = this.hls;\n if (hls.config.capLevelToPlayerSize && data.video) {\n // If the manifest did not signal a video codec capping has been deferred until we're certain video is present\n this.startCapping();\n }\n }\n\n onLevelsUpdated (data) {\n this.levels = data.levels;\n }\n\n onMediaDetaching () {\n this.stopCapping();\n }\n\n detectPlayerSize () {\n if (this.media) {\n let levelsLength = this.levels ? this.levels.length : 0;\n if (levelsLength) {\n const hls = this.hls;\n hls.autoLevelCapping = this.getMaxLevel(levelsLength - 1);\n if (hls.autoLevelCapping > this.autoLevelCapping) {\n // if auto level capping has a higher value for the previous one, flush the buffer using nextLevelSwitch\n // usually happen when the user go to the fullscreen mode.\n hls.streamController.nextLevelSwitch();\n }\n this.autoLevelCapping = hls.autoLevelCapping;\n }\n }\n }\n\n /*\n * returns level should be the one with the dimensions equal or greater than the media (player) dimensions (so the video will be downscaled)\n */\n getMaxLevel (capLevelIndex) {\n if (!this.levels) {\n return -1;\n }\n\n const validLevels = this.levels.filter((level, index) =>\n CapLevelController.isLevelAllowed(index, this.restrictedLevels) && index <= capLevelIndex\n );\n\n this.clientRect = null;\n return CapLevelController.getMaxLevelByMediaSize(validLevels, this.mediaWidth, this.mediaHeight);\n }\n\n startCapping () {\n if (this.timer) {\n // Don't reset capping if started twice; this can happen if the manifest signals a video codec\n return;\n }\n this.autoLevelCapping = Number.POSITIVE_INFINITY;\n this.hls.firstLevel = this.getMaxLevel(this.firstLevel);\n clearInterval(this.timer);\n this.timer = setInterval(this.detectPlayerSize.bind(this), 1000);\n this.detectPlayerSize();\n }\n\n stopCapping () {\n this.restrictedLevels = [];\n this.firstLevel = null;\n this.autoLevelCapping = Number.POSITIVE_INFINITY;\n if (this.timer) {\n this.timer = clearInterval(this.timer);\n this.timer = null;\n }\n }\n\n getDimensions () {\n if (this.clientRect) {\n return this.clientRect;\n }\n const media = this.media;\n const boundsRect = {\n width: 0,\n height: 0\n };\n\n if (media) {\n const clientRect = media.getBoundingClientRect();\n boundsRect.width = clientRect.width;\n boundsRect.height = clientRect.height;\n if (!boundsRect.width && !boundsRect.height) {\n // When the media element has no width or height (equivalent to not being in the DOM),\n // then use its width and height attributes (media.width, media.height)\n boundsRect.width = clientRect.right - clientRect.left || media.width || 0;\n boundsRect.height = clientRect.bottom - clientRect.top || media.height || 0;\n }\n }\n this.clientRect = boundsRect;\n return boundsRect;\n }\n\n get mediaWidth () {\n return this.getDimensions().width * CapLevelController.contentScaleFactor;\n }\n\n get mediaHeight () {\n return this.getDimensions().height * CapLevelController.contentScaleFactor;\n }\n\n static get contentScaleFactor () {\n let pixelRatio = 1;\n try {\n pixelRatio = window.devicePixelRatio;\n } catch (e) {}\n return pixelRatio;\n }\n\n static isLevelAllowed (level, restrictedLevels = []) {\n return restrictedLevels.indexOf(level) === -1;\n }\n\n static getMaxLevelByMediaSize (levels, width, height) {\n if (!levels || (levels && !levels.length)) {\n return -1;\n }\n\n // Levels can have the same dimensions but differing bandwidths - since levels are ordered, we can look to the next\n // to determine whether we've chosen the greatest bandwidth for the media's dimensions\n const atGreatestBandiwdth = (curLevel, nextLevel) => {\n if (!nextLevel) {\n return true;\n }\n\n return curLevel.width !== nextLevel.width || curLevel.height !== nextLevel.height;\n };\n\n // If we run through the loop without breaking, the media's dimensions are greater than every level, so default to\n // the max level\n let maxLevelIndex = levels.length - 1;\n\n for (let i = 0; i < levels.length; i += 1) {\n const level = levels[i];\n if ((level.width >= width || level.height >= height) && atGreatestBandiwdth(level, levels[i + 1])) {\n maxLevelIndex = i;\n break;\n }\n }\n\n return maxLevelIndex;\n }\n}\n\nexport default CapLevelController;\n","/*\n * FPS Controller\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { logger } from '../utils/logger';\n\nconst { performance } = window;\n\nclass FPSController extends EventHandler {\n constructor (hls) {\n super(hls, Event.MEDIA_ATTACHING);\n }\n\n destroy () {\n if (this.timer) {\n clearInterval(this.timer);\n }\n\n this.isVideoPlaybackQualityAvailable = false;\n }\n\n onMediaAttaching (data) {\n const config = this.hls.config;\n if (config.capLevelOnFPSDrop) {\n const video = this.video = data.media instanceof window.HTMLVideoElement ? data.media : null;\n if (typeof video.getVideoPlaybackQuality === 'function') {\n this.isVideoPlaybackQualityAvailable = true;\n }\n\n clearInterval(this.timer);\n this.timer = setInterval(this.checkFPSInterval.bind(this), config.fpsDroppedMonitoringPeriod);\n }\n }\n\n checkFPS (video, decodedFrames, droppedFrames) {\n let currentTime = performance.now();\n if (decodedFrames) {\n if (this.lastTime) {\n let currentPeriod = currentTime - this.lastTime,\n currentDropped = droppedFrames - this.lastDroppedFrames,\n currentDecoded = decodedFrames - this.lastDecodedFrames,\n droppedFPS = 1000 * currentDropped / currentPeriod,\n hls = this.hls;\n hls.trigger(Event.FPS_DROP, { currentDropped: currentDropped, currentDecoded: currentDecoded, totalDroppedFrames: droppedFrames });\n if (droppedFPS > 0) {\n // logger.log('checkFPS : droppedFPS/decodedFPS:' + droppedFPS/(1000 * currentDecoded / currentPeriod));\n if (currentDropped > hls.config.fpsDroppedMonitoringThreshold * currentDecoded) {\n let currentLevel = hls.currentLevel;\n logger.warn('drop FPS ratio greater than max allowed value for currentLevel: ' + currentLevel);\n if (currentLevel > 0 && (hls.autoLevelCapping === -1 || hls.autoLevelCapping >= currentLevel)) {\n currentLevel = currentLevel - 1;\n hls.trigger(Event.FPS_DROP_LEVEL_CAPPING, { level: currentLevel, droppedLevel: hls.currentLevel });\n hls.autoLevelCapping = currentLevel;\n hls.streamController.nextLevelSwitch();\n }\n }\n }\n }\n this.lastTime = currentTime;\n this.lastDroppedFrames = droppedFrames;\n this.lastDecodedFrames = decodedFrames;\n }\n }\n\n checkFPSInterval () {\n const video = this.video;\n if (video) {\n if (this.isVideoPlaybackQualityAvailable) {\n let videoPlaybackQuality = video.getVideoPlaybackQuality();\n this.checkFPS(video, videoPlaybackQuality.totalVideoFrames, videoPlaybackQuality.droppedVideoFrames);\n } else {\n this.checkFPS(video, video.webkitDecodedFrameCount, video.webkitDroppedFrameCount);\n }\n }\n }\n}\n\nexport default FPSController;\n","/**\n * XHR based logger\n*/\n\nimport { logger } from '../utils/logger';\n\nclass XhrLoader {\n constructor (config) {\n if (config && config.xhrSetup) {\n this.xhrSetup = config.xhrSetup;\n }\n }\n\n destroy () {\n this.abort();\n this.loader = null;\n }\n\n abort () {\n let loader = this.loader;\n if (loader && loader.readyState !== 4) {\n this.stats.aborted = true;\n loader.abort();\n }\n\n window.clearTimeout(this.requestTimeout);\n this.requestTimeout = null;\n window.clearTimeout(this.retryTimeout);\n this.retryTimeout = null;\n }\n\n load (context, config, callbacks) {\n this.context = context;\n this.config = config;\n this.callbacks = callbacks;\n this.stats = { trequest: window.performance.now(), retry: 0 };\n this.retryDelay = config.retryDelay;\n this.loadInternal();\n }\n\n loadInternal () {\n let xhr, context = this.context;\n xhr = this.loader = new window.XMLHttpRequest();\n\n let stats = this.stats;\n stats.tfirst = 0;\n stats.loaded = 0;\n const xhrSetup = this.xhrSetup;\n\n try {\n if (xhrSetup) {\n try {\n xhrSetup(xhr, context.url);\n } catch (e) {\n // fix xhrSetup: (xhr, url) => {xhr.setRequestHeader(\"Content-Language\", \"test\");}\n // not working, as xhr.setRequestHeader expects xhr.readyState === OPEN\n xhr.open('GET', context.url, true);\n xhrSetup(xhr, context.url);\n }\n }\n if (!xhr.readyState) {\n xhr.open('GET', context.url, true);\n }\n } catch (e) {\n // IE11 throws an exception on xhr.open if attempting to access an HTTP resource over HTTPS\n this.callbacks.onError({ code: xhr.status, text: e.message }, context, xhr);\n return;\n }\n\n if (context.rangeEnd) {\n xhr.setRequestHeader('Range', 'bytes=' + context.rangeStart + '-' + (context.rangeEnd - 1));\n }\n\n xhr.onreadystatechange = this.readystatechange.bind(this);\n xhr.onprogress = this.loadprogress.bind(this);\n xhr.responseType = context.responseType;\n\n // setup timeout before we perform request\n this.requestTimeout = window.setTimeout(this.loadtimeout.bind(this), this.config.timeout);\n xhr.send();\n }\n\n readystatechange (event) {\n let xhr = event.currentTarget,\n readyState = xhr.readyState,\n stats = this.stats,\n context = this.context,\n config = this.config;\n\n // don't proceed if xhr has been aborted\n if (stats.aborted) {\n return;\n }\n\n // >= HEADERS_RECEIVED\n if (readyState >= 2) {\n // clear xhr timeout and rearm it if readyState less than 4\n window.clearTimeout(this.requestTimeout);\n if (stats.tfirst === 0) {\n stats.tfirst = Math.max(window.performance.now(), stats.trequest);\n }\n\n if (readyState === 4) {\n let status = xhr.status;\n // http status between 200 to 299 are all successful\n if (status >= 200 && status < 300) {\n stats.tload = Math.max(stats.tfirst, window.performance.now());\n let data, len;\n if (context.responseType === 'arraybuffer') {\n data = xhr.response;\n len = data.byteLength;\n } else {\n data = xhr.responseText;\n len = data.length;\n }\n stats.loaded = stats.total = len;\n let response = { url: xhr.responseURL, data: data };\n this.callbacks.onSuccess(response, stats, context, xhr);\n } else {\n // if max nb of retries reached or if http status between 400 and 499 (such error cannot be recovered, retrying is useless), return error\n if (stats.retry >= config.maxRetry || (status >= 400 && status < 499)) {\n logger.error(`${status} while loading ${context.url}`);\n this.callbacks.onError({ code: status, text: xhr.statusText }, context, xhr);\n } else {\n // retry\n logger.warn(`${status} while loading ${context.url}, retrying in ${this.retryDelay}...`);\n // aborts and resets internal state\n this.destroy();\n // schedule retry\n this.retryTimeout = window.setTimeout(this.loadInternal.bind(this), this.retryDelay);\n // set exponential backoff\n this.retryDelay = Math.min(2 * this.retryDelay, config.maxRetryDelay);\n stats.retry++;\n }\n }\n } else {\n // readyState >= 2 AND readyState !==4 (readyState = HEADERS_RECEIVED || LOADING) rearm timeout as xhr not finished yet\n this.requestTimeout = window.setTimeout(this.loadtimeout.bind(this), config.timeout);\n }\n }\n }\n\n loadtimeout () {\n logger.warn(`timeout while loading ${this.context.url}`);\n this.callbacks.onTimeout(this.stats, this.context, null);\n }\n\n loadprogress (event) {\n let xhr = event.currentTarget,\n stats = this.stats;\n\n stats.loaded = event.loaded;\n if (event.lengthComputable) {\n stats.total = event.total;\n }\n\n let onProgress = this.callbacks.onProgress;\n if (onProgress) {\n // third arg is to provide on progress data\n onProgress(stats, this.context, null, xhr);\n }\n }\n}\n\nexport default XhrLoader;\n","import Event from '../events';\nimport TaskLoop from '../task-loop';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\n\n/**\n * @class AudioTrackController\n * @implements {EventHandler}\n *\n * Handles main manifest and audio-track metadata loaded,\n * owns and exposes the selectable audio-tracks data-models.\n *\n * Exposes internal interface to select available audio-tracks.\n *\n * Handles errors on loading audio-track playlists. Manages fallback mechanism\n * with redundants tracks (group-IDs).\n *\n * Handles level-loading and group-ID switches for video (fallback on video levels),\n * and eventually adapts the audio-track group-ID to match.\n *\n * @fires AUDIO_TRACK_LOADING\n * @fires AUDIO_TRACK_SWITCHING\n * @fires AUDIO_TRACKS_UPDATED\n * @fires ERROR\n *\n */\nclass AudioTrackController extends TaskLoop {\n constructor (hls) {\n super(hls,\n Event.MANIFEST_LOADING,\n Event.MANIFEST_PARSED,\n Event.AUDIO_TRACK_LOADED,\n Event.AUDIO_TRACK_SWITCHED,\n Event.LEVEL_LOADED,\n Event.ERROR\n );\n\n /**\n * @private\n * Currently selected index in `tracks`\n * @member {number} trackId\n */\n this._trackId = -1;\n\n /**\n * @private\n * If should select tracks according to default track attribute\n * @member {boolean} _selectDefaultTrack\n */\n this._selectDefaultTrack = true;\n\n /**\n * @public\n * All tracks available\n * @member {AudioTrack[]}\n */\n this.tracks = [];\n\n /**\n * @public\n * List of blacklisted audio track IDs (that have caused failure)\n * @member {number[]}\n */\n this.trackIdBlacklist = Object.create(null);\n\n /**\n * @public\n * The currently running group ID for audio\n * (we grab this on manifest-parsed and new level-loaded)\n * @member {string}\n */\n this.audioGroupId = null;\n }\n\n /**\n * Reset audio tracks on new manifest loading.\n */\n onManifestLoading () {\n this.tracks = [];\n this._trackId = -1;\n this._selectDefaultTrack = true;\n }\n\n /**\n * Store tracks data from manifest parsed data.\n *\n * Trigger AUDIO_TRACKS_UPDATED event.\n *\n * @param {*} data\n */\n onManifestParsed (data) {\n const tracks = this.tracks = data.audioTracks || [];\n this.hls.trigger(Event.AUDIO_TRACKS_UPDATED, { audioTracks: tracks });\n\n this._selectAudioGroup(this.hls.nextLoadLevel);\n }\n\n /**\n * Store track details of loaded track in our data-model.\n *\n * Set-up metadata update interval task for live-mode streams.\n *\n * @param {*} data\n */\n onAudioTrackLoaded (data) {\n if (data.id >= this.tracks.length) {\n logger.warn('Invalid audio track id:', data.id);\n return;\n }\n\n logger.log(`audioTrack ${data.id} loaded`);\n\n this.tracks[data.id].details = data.details;\n\n // check if current playlist is a live playlist\n // and if we have already our reload interval setup\n if (data.details.live && !this.hasInterval()) {\n // if live playlist we will have to reload it periodically\n // set reload period to playlist target duration\n const updatePeriodMs = data.details.targetduration * 1000;\n this.setInterval(updatePeriodMs);\n }\n\n if (!data.details.live && this.hasInterval()) {\n // playlist is not live and timer is scheduled: cancel it\n this.clearInterval();\n }\n }\n\n /**\n * Update the internal group ID to any audio-track we may have set manually\n * or because of a failure-handling fallback.\n *\n * Quality-levels should update to that group ID in this case.\n *\n * @param {*} data\n */\n onAudioTrackSwitched (data) {\n const audioGroupId = this.tracks[data.id].groupId;\n if (audioGroupId && (this.audioGroupId !== audioGroupId)) {\n this.audioGroupId = audioGroupId;\n }\n }\n\n /**\n * When a level gets loaded, if it has redundant audioGroupIds (in the same ordinality as it's redundant URLs)\n * we are setting our audio-group ID internally to the one set, if it is different from the group ID currently set.\n *\n * If group-ID got update, we re-select the appropriate audio-track with this group-ID matching the currently\n * selected one (based on NAME property).\n *\n * @param {*} data\n */\n onLevelLoaded (data) {\n this._selectAudioGroup(data.level);\n }\n\n /**\n * Handle network errors loading audio track manifests\n * and also pausing on any netwok errors.\n *\n * @param {ErrorEventData} data\n */\n onError (data) {\n // Only handle network errors\n if (data.type !== ErrorTypes.NETWORK_ERROR) {\n return;\n }\n\n // If fatal network error, cancel update task\n if (data.fatal) {\n this.clearInterval();\n }\n\n // If not an audio-track loading error don't handle further\n if (data.details !== ErrorDetails.AUDIO_TRACK_LOAD_ERROR) {\n return;\n }\n\n logger.warn('Network failure on audio-track id:', data.context.id);\n this._handleLoadError();\n }\n\n /**\n * @type {AudioTrack[]} Audio-track list we own\n */\n get audioTracks () {\n return this.tracks;\n }\n\n /**\n * @type {number} Index into audio-tracks list of currently selected track.\n */\n get audioTrack () {\n return this._trackId;\n }\n\n /**\n * Select current track by index\n */\n set audioTrack (newId) {\n this._setAudioTrack(newId);\n // If audio track is selected from API then don't choose from the manifest default track\n this._selectDefaultTrack = false;\n }\n\n /**\n * @private\n * @param {number} newId\n */\n _setAudioTrack (newId) {\n // noop on same audio track id as already set\n if (this._trackId === newId && this.tracks[this._trackId].details) {\n logger.debug('Same id as current audio-track passed, and track details available -> no-op');\n return;\n }\n\n // check if level idx is valid\n if (newId < 0 || newId >= this.tracks.length) {\n logger.warn('Invalid id passed to audio-track controller');\n return;\n }\n\n const audioTrack = this.tracks[newId];\n\n logger.log(`Now switching to audio-track index ${newId}`);\n\n // stopping live reloading timer if any\n this.clearInterval();\n this._trackId = newId;\n\n const { url, type, id } = audioTrack;\n this.hls.trigger(Event.AUDIO_TRACK_SWITCHING, { id, type, url });\n this._loadTrackDetailsIfNeeded(audioTrack);\n }\n\n /**\n * @override\n */\n doTick () {\n this._updateTrack(this._trackId);\n }\n\n /**\n * @param levelId\n * @private\n */\n _selectAudioGroup (levelId) {\n const levelInfo = this.hls.levels[levelId];\n\n if (!levelInfo || !levelInfo.audioGroupIds) {\n return;\n }\n\n const audioGroupId = levelInfo.audioGroupIds[levelInfo.urlId];\n if (this.audioGroupId !== audioGroupId) {\n this.audioGroupId = audioGroupId;\n this._selectInitialAudioTrack();\n }\n }\n\n /**\n * Select initial track\n * @private\n */\n _selectInitialAudioTrack () {\n let tracks = this.tracks;\n if (!tracks.length) {\n return;\n }\n\n const currentAudioTrack = this.tracks[this._trackId];\n\n let name = null;\n if (currentAudioTrack) {\n name = currentAudioTrack.name;\n }\n\n // Pre-select default tracks if there are any\n if (this._selectDefaultTrack) {\n const defaultTracks = tracks.filter((track) => track.default);\n if (defaultTracks.length) {\n tracks = defaultTracks;\n } else {\n logger.warn('No default audio tracks defined');\n }\n }\n\n let trackFound = false;\n\n const traverseTracks = () => {\n // Select track with right group ID\n tracks.forEach((track) => {\n if (trackFound) {\n return;\n }\n // We need to match the (pre-)selected group ID\n // and the NAME of the current track.\n if ((!this.audioGroupId || track.groupId === this.audioGroupId) &&\n (!name || name === track.name)) {\n // If there was a previous track try to stay with the same `NAME`.\n // It should be unique across tracks of same group, and consistent through redundant track groups.\n this._setAudioTrack(track.id);\n trackFound = true;\n }\n });\n };\n\n traverseTracks();\n\n if (!trackFound) {\n name = null;\n traverseTracks();\n }\n\n if (!trackFound) {\n logger.error(`No track found for running audio group-ID: ${this.audioGroupId}`);\n\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.AUDIO_TRACK_LOAD_ERROR,\n fatal: true\n });\n }\n }\n\n /**\n * @private\n * @param {AudioTrack} audioTrack\n * @returns {boolean}\n */\n _needsTrackLoading (audioTrack) {\n const { details, url } = audioTrack;\n\n if (!details || details.live) {\n // check if we face an audio track embedded in main playlist (audio track without URI attribute)\n return !!url;\n }\n\n return false;\n }\n\n /**\n * @private\n * @param {AudioTrack} audioTrack\n */\n _loadTrackDetailsIfNeeded (audioTrack) {\n if (this._needsTrackLoading(audioTrack)) {\n const { url, id } = audioTrack;\n // track not retrieved yet, or live playlist we need to (re)load it\n logger.log(`loading audio-track playlist for id: ${id}`);\n this.hls.trigger(Event.AUDIO_TRACK_LOADING, { url, id });\n }\n }\n\n /**\n * @private\n * @param {number} newId\n */\n _updateTrack (newId) {\n // check if level idx is valid\n if (newId < 0 || newId >= this.tracks.length) {\n return;\n }\n\n // stopping live reloading timer if any\n this.clearInterval();\n this._trackId = newId;\n logger.log(`trying to update audio-track ${newId}`);\n const audioTrack = this.tracks[newId];\n this._loadTrackDetailsIfNeeded(audioTrack);\n }\n\n /**\n * @private\n */\n _handleLoadError () {\n // First, let's black list current track id\n this.trackIdBlacklist[this._trackId] = true;\n\n // Let's try to fall back on a functional audio-track with the same group ID\n const previousId = this._trackId;\n const { name, language, groupId } = this.tracks[previousId];\n\n logger.warn(`Loading failed on audio track id: ${previousId}, group-id: ${groupId}, name/language: \"${name}\" / \"${language}\"`);\n\n // Find a non-blacklisted track ID with the same NAME\n // At least a track that is not blacklisted, thus on another group-ID.\n let newId = previousId;\n for (let i = 0; i < this.tracks.length; i++) {\n if (this.trackIdBlacklist[i]) {\n continue;\n }\n const newTrack = this.tracks[i];\n if (newTrack.name === name) {\n newId = i;\n break;\n }\n }\n\n if (newId === previousId) {\n logger.warn(`No fallback audio-track found for name/language: \"${name}\" / \"${language}\"`);\n return;\n }\n\n logger.log('Attempting audio-track fallback id:', newId, 'group-id:', this.tracks[newId].groupId);\n\n this._setAudioTrack(newId);\n }\n}\n\nexport default AudioTrackController;\n","/*\n * Audio Stream Controller\n*/\n\nimport BinarySearch from '../utils/binary-search';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport Demuxer from '../demux/demuxer';\nimport Event from '../events';\nimport * as LevelHelper from './level-helper';\nimport TimeRanges from '../utils/time-ranges';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport { findFragWithCC } from '../utils/discontinuities';\nimport { FragmentState } from './fragment-tracker';\nimport { ElementaryStreamTypes } from '../loader/fragment';\nimport BaseStreamController, { State } from './base-stream-controller';\nimport { MAX_START_GAP_JUMP } from './gap-controller';\nimport { fragmentWithinToleranceTest } from './fragment-finders';\n\nconst { performance } = window;\n\nconst TICK_INTERVAL = 100; // how often to tick in ms\n\nclass AudioStreamController extends BaseStreamController {\n constructor (hls, fragmentTracker) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.AUDIO_TRACKS_UPDATED,\n Event.AUDIO_TRACK_SWITCHING,\n Event.AUDIO_TRACK_LOADED,\n Event.KEY_LOADED,\n Event.FRAG_LOADED,\n Event.FRAG_PARSING_INIT_SEGMENT,\n Event.FRAG_PARSING_DATA,\n Event.FRAG_PARSED,\n Event.ERROR,\n Event.BUFFER_RESET,\n Event.BUFFER_CREATED,\n Event.BUFFER_APPENDED,\n Event.BUFFER_FLUSHED,\n Event.INIT_PTS_FOUND);\n this.fragmentTracker = fragmentTracker;\n this.config = hls.config;\n this.audioCodecSwap = false;\n this._state = State.STOPPED;\n this.initPTS = [];\n this.waitingFragment = null;\n this.videoTrackCC = null;\n this.waitingVideoCC = null;\n }\n\n // Signal that video PTS was found\n onInitPtsFound (data) {\n let demuxerId = data.id, cc = data.frag.cc, initPTS = data.initPTS;\n if (demuxerId === 'main') {\n // Always update the new INIT PTS\n // Can change due level switch\n this.initPTS[cc] = initPTS;\n this.videoTrackCC = cc;\n logger.log(`InitPTS for cc: ${cc} found from main: ${initPTS}`);\n\n // If we are waiting we need to demux/remux the waiting frag\n // With the new initPTS\n if (this.state === State.WAITING_INIT_PTS) {\n this.tick();\n }\n }\n }\n\n startLoad (startPosition) {\n if (this.tracks) {\n let lastCurrentTime = this.lastCurrentTime;\n this.stopLoad();\n this.setInterval(TICK_INTERVAL);\n this.fragLoadError = 0;\n if (lastCurrentTime > 0 && startPosition === -1) {\n logger.log(`audio:override startPosition with lastCurrentTime @${lastCurrentTime.toFixed(3)}`);\n this.state = State.IDLE;\n } else {\n this.lastCurrentTime = this.startPosition ? this.startPosition : startPosition;\n this.state = State.STARTING;\n }\n this.nextLoadPosition = this.startPosition = this.lastCurrentTime;\n this.tick();\n } else {\n this.startPosition = startPosition;\n this.state = State.STOPPED;\n }\n }\n\n set state (nextState) {\n if (this.state !== nextState) {\n const previousState = this.state;\n this._state = nextState;\n logger.log(`audio stream:${previousState}->${nextState}`);\n }\n }\n\n get state () {\n return this._state;\n }\n\n doTick () {\n let pos, track, trackDetails, hls = this.hls, config = hls.config;\n // logger.log('audioStream:' + this.state);\n switch (this.state) {\n case State.ERROR:\n // don't do anything in error state to avoid breaking further ...\n case State.PAUSED:\n // don't do anything in paused state either ...\n case State.BUFFER_FLUSHING:\n break;\n case State.STARTING:\n this.state = State.WAITING_TRACK;\n this.loadedmetadata = false;\n break;\n case State.IDLE:\n const tracks = this.tracks;\n // audio tracks not received => exit loop\n if (!tracks) {\n break;\n }\n\n // if video not attached AND\n // start fragment already requested OR start frag prefetch disable\n // exit loop\n // => if media not attached but start frag prefetch is enabled and start frag not requested yet, we will not exit loop\n if (!this.media &&\n (this.startFragRequested || !config.startFragPrefetch)) {\n break;\n }\n\n // determine next candidate fragment to be loaded, based on current position and\n // end of buffer position\n // if we have not yet loaded any fragment, start loading from start position\n if (this.loadedmetadata) {\n pos = this.media.currentTime;\n } else {\n pos = this.nextLoadPosition;\n if (pos === undefined) {\n break;\n }\n }\n let media = this.mediaBuffer ? this.mediaBuffer : this.media;\n const videoBuffer = this.videoBuffer ? this.videoBuffer : this.media;\n const maxBufferHole = pos < config.maxBufferHole ? Math.max(MAX_START_GAP_JUMP, config.maxBufferHole) : config.maxBufferHole;\n const bufferInfo = BufferHelper.bufferInfo(media, pos, maxBufferHole);\n const mainBufferInfo = BufferHelper.bufferInfo(videoBuffer, pos, maxBufferHole);\n const bufferLen = bufferInfo.len;\n let bufferEnd = bufferInfo.end;\n const fragPrevious = this.fragPrevious;\n // ensure we buffer at least config.maxBufferLength (default 30s) or config.maxMaxBufferLength (default: 600s)\n // whichever is smaller.\n // once we reach that threshold, don't buffer more than video (mainBufferInfo.len)\n const maxConfigBuffer = Math.min(config.maxBufferLength, config.maxMaxBufferLength);\n const maxBufLen = Math.max(maxConfigBuffer, mainBufferInfo.len);\n const audioSwitch = this.audioSwitch;\n const trackId = this.trackId;\n\n // if buffer length is less than maxBufLen try to load a new fragment\n if ((bufferLen < maxBufLen || audioSwitch) && trackId < tracks.length) {\n trackDetails = tracks[trackId].details;\n // if track info not retrieved yet, switch state and wait for track retrieval\n if (typeof trackDetails === 'undefined') {\n this.state = State.WAITING_TRACK;\n break;\n }\n\n if (!audioSwitch && this._streamEnded(bufferInfo, trackDetails)) {\n this.hls.trigger(Event.BUFFER_EOS, { type: 'audio' });\n this.state = State.ENDED;\n return;\n }\n\n // find fragment index, contiguous with end of buffer position\n let fragments = trackDetails.fragments,\n fragLen = fragments.length,\n start = fragments[0].start,\n end = fragments[fragLen - 1].start + fragments[fragLen - 1].duration,\n frag;\n\n // When switching audio track, reload audio as close as possible to currentTime\n if (audioSwitch) {\n if (trackDetails.live && !trackDetails.PTSKnown) {\n logger.log('switching audiotrack, live stream, unknown PTS,load first fragment');\n bufferEnd = 0;\n } else {\n bufferEnd = pos;\n // if currentTime (pos) is less than alt audio playlist start time, it means that alt audio is ahead of currentTime\n if (trackDetails.PTSKnown && pos < start) {\n // if everything is buffered from pos to start or if audio buffer upfront, let's seek to start\n if (bufferInfo.end > start || bufferInfo.nextStart) {\n logger.log('alt audio track ahead of main track, seek to start of alt audio track');\n this.media.currentTime = start + 0.05;\n } else {\n return;\n }\n }\n }\n }\n if (trackDetails.initSegment && !trackDetails.initSegment.data) {\n frag = trackDetails.initSegment;\n } // eslint-disable-line brace-style\n // if bufferEnd before start of playlist, load first fragment\n else if (bufferEnd <= start) {\n frag = fragments[0];\n if (this.videoTrackCC !== null && frag.cc !== this.videoTrackCC) {\n // Ensure we find a fragment which matches the continuity of the video track\n frag = findFragWithCC(fragments, this.videoTrackCC);\n }\n if (trackDetails.live && frag.loadIdx && frag.loadIdx === this.fragLoadIdx) {\n // we just loaded this first fragment, and we are still lagging behind the start of the live playlist\n // let's force seek to start\n const nextBuffered = bufferInfo.nextStart ? bufferInfo.nextStart : start;\n logger.log(`no alt audio available @currentTime:${this.media.currentTime}, seeking @${nextBuffered + 0.05}`);\n this.media.currentTime = nextBuffered + 0.05;\n return;\n }\n } else {\n let foundFrag;\n let maxFragLookUpTolerance = config.maxFragLookUpTolerance;\n const fragNext = fragPrevious ? fragments[fragPrevious.sn - fragments[0].sn + 1] : undefined;\n\n if (bufferEnd < end) {\n if (bufferEnd > end - maxFragLookUpTolerance) {\n maxFragLookUpTolerance = 0;\n }\n\n // Prefer the next fragment if it's within tolerance\n if (fragNext && !fragmentWithinToleranceTest(bufferEnd, maxFragLookUpTolerance, fragNext)) {\n foundFrag = fragNext;\n } else {\n foundFrag = BinarySearch.search(fragments, (frag) => fragmentWithinToleranceTest(bufferEnd, maxFragLookUpTolerance, frag));\n }\n } else {\n // reach end of playlist\n foundFrag = fragments[fragLen - 1];\n }\n if (foundFrag) {\n frag = foundFrag;\n start = foundFrag.start;\n // logger.log('find SN matching with pos:' + bufferEnd + ':' + frag.sn);\n if (fragPrevious && frag.level === fragPrevious.level && frag.sn === fragPrevious.sn) {\n if (frag.sn < trackDetails.endSN) {\n frag = fragments[frag.sn + 1 - trackDetails.startSN];\n if (this.fragmentTracker.getState(frag) !== FragmentState.OK) {\n logger.log(`SN just loaded, load next one: ${frag.sn}`);\n }\n } else {\n frag = null;\n }\n }\n }\n }\n if (frag) {\n // logger.log(' loading frag ' + i +',pos/bufEnd:' + pos.toFixed(3) + '/' + bufferEnd.toFixed(3));\n if (frag.encrypted) {\n logger.log(`Loading key for ${frag.sn} of [${trackDetails.startSN} ,${trackDetails.endSN}],track ${trackId}`);\n this.state = State.KEY_LOADING;\n hls.trigger(Event.KEY_LOADING, { frag: frag });\n } else {\n // only load if fragment is not loaded or if in audio switch\n // we force a frag loading in audio switch as fragment tracker might not have evicted previous frags in case of quick audio switch\n this.fragCurrent = frag;\n if (audioSwitch || this.fragmentTracker.getState(frag) === FragmentState.NOT_LOADED) {\n logger.log(`Loading ${frag.sn}, cc: ${frag.cc} of [${trackDetails.startSN} ,${trackDetails.endSN}],track ${trackId}, ${\n this.loadedmetadata ? 'currentTime' : 'nextLoadPosition'\n }: ${pos}, bufferEnd: ${bufferEnd.toFixed(3)}`);\n\n if (frag.sn !== 'initSegment') {\n this.startFragRequested = true;\n }\n if (Number.isFinite(frag.sn)) {\n this.nextLoadPosition = frag.start + frag.duration;\n }\n\n hls.trigger(Event.FRAG_LOADING, { frag });\n this.state = State.FRAG_LOADING;\n }\n }\n }\n }\n break;\n case State.WAITING_TRACK:\n track = this.tracks[this.trackId];\n // check if playlist is already loaded\n if (track && track.details) {\n this.state = State.IDLE;\n }\n\n break;\n case State.FRAG_LOADING_WAITING_RETRY:\n var now = performance.now();\n var retryDate = this.retryDate;\n media = this.media;\n var isSeeking = media && media.seeking;\n // if current time is gt than retryDate, or if media seeking let's switch to IDLE state to retry loading\n if (!retryDate || (now >= retryDate) || isSeeking) {\n logger.log('audioStreamController: retryDate reached, switch back to IDLE state');\n this.state = State.IDLE;\n }\n break;\n case State.WAITING_INIT_PTS:\n // Ensure we don't get stuck in the WAITING_INIT_PTS state if the waiting frag CC doesn't match any initPTS\n const waitingFrag = this.waitingFragment;\n if (waitingFrag) {\n const waitingFragCC = waitingFrag.frag.cc;\n if (this.initPTS[waitingFragCC] !== undefined) {\n this.waitingFragment = null;\n this.state = State.FRAG_LOADING;\n this.onFragLoaded(waitingFrag);\n } else if (this.videoTrackCC !== this.waitingVideoCC) {\n // Drop waiting fragment if videoTrackCC has changed since waitingFragment was set and initPTS was not found\n logger.log(`Waiting fragment cc (${waitingFragCC}) cancelled because video is at cc ${this.videoTrackCC}`);\n this.clearWaitingFragment();\n } else {\n // Drop waiting fragment if an earlier fragment is needed\n const bufferInfo = BufferHelper.bufferInfo(this.mediaBuffer, this.media.currentTime, config.maxBufferHole);\n const waitingFragmentAtPosition = fragmentWithinToleranceTest(bufferInfo.end, config.maxFragLookUpTolerance, waitingFrag.frag);\n if (waitingFragmentAtPosition < 0) {\n logger.log(`Waiting fragment cc (${waitingFragCC}) @ ${waitingFrag.frag.start} cancelled because another fragment at ${bufferInfo.end} is needed`);\n this.clearWaitingFragment();\n }\n }\n } else {\n this.state = State.IDLE;\n }\n\n break;\n case State.STOPPED:\n case State.FRAG_LOADING:\n case State.PARSING:\n case State.PARSED:\n case State.ENDED:\n break;\n default:\n break;\n }\n }\n\n clearWaitingFragment () {\n const waitingFrag = this.waitingFragment;\n if (waitingFrag) {\n this.fragmentTracker.removeFragment(waitingFrag.frag);\n this.waitingFragment = null;\n this.waitingVideoCC = null;\n this.state = State.IDLE;\n }\n }\n\n onMediaAttached (data) {\n let media = this.media = this.mediaBuffer = data.media;\n this.onvseeking = this.onMediaSeeking.bind(this);\n this.onvended = this.onMediaEnded.bind(this);\n media.addEventListener('seeking', this.onvseeking);\n media.addEventListener('ended', this.onvended);\n let config = this.config;\n if (this.tracks && config.autoStartLoad) {\n this.startLoad(config.startPosition);\n }\n }\n\n onMediaDetaching () {\n let media = this.media;\n if (media && media.ended) {\n logger.log('MSE detaching and video ended, reset startPosition');\n this.startPosition = this.lastCurrentTime = 0;\n }\n\n // remove video listeners\n if (media) {\n media.removeEventListener('seeking', this.onvseeking);\n media.removeEventListener('ended', this.onvended);\n this.onvseeking = this.onvseeked = this.onvended = null;\n }\n this.media = this.mediaBuffer = this.videoBuffer = null;\n this.loadedmetadata = false;\n this.fragmentTracker.removeAllFragments();\n this.stopLoad();\n }\n\n onAudioTracksUpdated (data) {\n logger.log('audio tracks updated');\n this.tracks = data.audioTracks;\n }\n\n onAudioTrackSwitching (data) {\n // if any URL found on new audio track, it is an alternate audio track\n let altAudio = !!data.url;\n this.trackId = data.id;\n\n this.fragCurrent = null;\n this.clearWaitingFragment();\n this.state = State.PAUSED;\n // destroy useless demuxer when switching audio to main\n if (!altAudio) {\n if (this.demuxer) {\n this.demuxer.destroy();\n this.demuxer = null;\n }\n } else {\n // switching to audio track, start timer if not already started\n this.setInterval(TICK_INTERVAL);\n }\n\n // should we switch tracks ?\n if (altAudio) {\n this.audioSwitch = true;\n // main audio track are handled by stream-controller, just do something if switching to alt audio track\n this.state = State.IDLE;\n }\n this.tick();\n }\n\n onAudioTrackLoaded (data) {\n let newDetails = data.details,\n trackId = data.id,\n track = this.tracks[trackId],\n curDetails = track.details,\n duration = newDetails.totalduration,\n sliding = 0;\n\n logger.log(`track ${trackId} loaded [${newDetails.startSN},${newDetails.endSN}],duration:${duration}`);\n\n if (newDetails.live || (curDetails && curDetails.live)) {\n if (curDetails && newDetails.fragments.length > 0) {\n // we already have details for that level, merge them\n LevelHelper.mergeDetails(curDetails, newDetails);\n sliding = newDetails.fragments[0].start;\n // TODO\n // this.liveSyncPosition = this.computeLivePosition(sliding, curDetails);\n if (newDetails.PTSKnown) {\n logger.log(`live audio playlist sliding:${sliding.toFixed(3)}`);\n } else {\n logger.log('live audio playlist - outdated PTS, unknown sliding');\n }\n } else {\n newDetails.PTSKnown = false;\n logger.log('live audio playlist - first load, unknown sliding');\n }\n } else {\n newDetails.PTSKnown = false;\n }\n track.details = newDetails;\n\n // compute start position\n if (!this.startFragRequested) {\n // compute start position if set to -1. use it straight away if value is defined\n if (this.startPosition === -1) {\n // first, check if start time offset has been set in playlist, if yes, use this value\n let startTimeOffset = newDetails.startTimeOffset;\n if (Number.isFinite(startTimeOffset)) {\n logger.log(`start time offset found in playlist, adjust startPosition to ${startTimeOffset}`);\n this.startPosition = startTimeOffset;\n } else {\n if (newDetails.live) {\n this.startPosition = this.computeLivePosition(sliding, newDetails);\n logger.log(`compute startPosition for audio-track to ${this.startPosition}`);\n } else {\n this.startPosition = 0;\n }\n }\n }\n this.nextLoadPosition = this.startPosition;\n }\n // only switch batck to IDLE state if we were waiting for track to start downloading a new fragment\n if (this.state === State.WAITING_TRACK) {\n this.state = State.IDLE;\n }\n\n // trigger handler right now\n this.tick();\n }\n\n onKeyLoaded () {\n if (this.state === State.KEY_LOADING) {\n this.state = State.IDLE;\n this.tick();\n }\n }\n\n onFragLoaded (data) {\n let fragCurrent = this.fragCurrent,\n fragLoaded = data.frag;\n if (this.state === State.FRAG_LOADING &&\n fragCurrent &&\n fragLoaded.type === 'audio' &&\n fragLoaded.level === fragCurrent.level &&\n fragLoaded.sn === fragCurrent.sn) {\n let track = this.tracks[this.trackId],\n details = track.details,\n duration = details.totalduration,\n trackId = fragCurrent.level,\n sn = fragCurrent.sn,\n cc = fragCurrent.cc,\n audioCodec = this.config.defaultAudioCodec || track.audioCodec || 'mp4a.40.2',\n stats = this.stats = data.stats;\n if (sn === 'initSegment') {\n this.state = State.IDLE;\n\n stats.tparsed = stats.tbuffered = performance.now();\n details.initSegment.data = data.payload;\n this.hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: fragCurrent, id: 'audio' });\n this.tick();\n } else {\n this.state = State.PARSING;\n // transmux the MPEG-TS data to ISO-BMFF segments\n this.appended = false;\n if (!this.demuxer) {\n this.demuxer = new Demuxer(this.hls, 'audio');\n }\n\n // Check if we have video initPTS\n // If not we need to wait for it\n let initPTS = this.initPTS[cc];\n let initSegmentData = details.initSegment ? details.initSegment.data : [];\n if (initPTS !== undefined) {\n this.pendingBuffering = true;\n logger.log(`Demuxing ${sn} of [${details.startSN} ,${details.endSN}],track ${trackId}`);\n // time Offset is accurate if level PTS is known, or if playlist is not sliding (not live)\n let accurateTimeOffset = false; // details.PTSKnown || !details.live;\n this.demuxer.push(data.payload, initSegmentData, audioCodec, null, fragCurrent, duration, accurateTimeOffset, initPTS);\n } else {\n logger.log(`Unknown video PTS for cc ${cc}, waiting for video PTS before demuxing audio frag ${sn} of [${details.startSN} ,${details.endSN}],track ${trackId}`);\n this.waitingFragment = data;\n this.waitingVideoCC = this.videoTrackCC;\n this.state = State.WAITING_INIT_PTS;\n }\n }\n }\n this.fragLoadError = 0;\n }\n\n onFragParsingInitSegment (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'audio' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n let tracks = data.tracks, track;\n\n // delete any video track found on audio demuxer\n if (tracks.video) {\n delete tracks.video;\n }\n\n // include levelCodec in audio and video tracks\n track = tracks.audio;\n if (track) {\n track.levelCodec = track.codec;\n track.id = data.id;\n this.hls.trigger(Event.BUFFER_CODECS, tracks);\n logger.log(`audio track:audio,container:${track.container},codecs[level/parsed]=[${track.levelCodec}/${track.codec}]`);\n let initSegment = track.initSegment;\n if (initSegment) {\n let appendObj = { type: 'audio', data: initSegment, parent: 'audio', content: 'initSegment' };\n if (this.audioSwitch) {\n this.pendingData = [appendObj];\n } else {\n this.appended = true;\n // arm pending Buffering flag before appending a segment\n this.pendingBuffering = true;\n this.hls.trigger(Event.BUFFER_APPENDING, appendObj);\n }\n }\n // trigger handler right now\n this.tick();\n }\n }\n }\n\n onFragParsingData (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'audio' &&\n data.type === 'audio' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n let trackId = this.trackId,\n track = this.tracks[trackId],\n hls = this.hls;\n\n if (!Number.isFinite(data.endPTS)) {\n data.endPTS = data.startPTS + fragCurrent.duration;\n data.endDTS = data.startDTS + fragCurrent.duration;\n }\n\n fragCurrent.addElementaryStream(ElementaryStreamTypes.AUDIO);\n\n logger.log(`parsed ${data.type},PTS:[${data.startPTS.toFixed(3)},${data.endPTS.toFixed(3)}],DTS:[${data.startDTS.toFixed(3)}/${data.endDTS.toFixed(3)}],nb:${data.nb}`);\n LevelHelper.updateFragPTSDTS(track.details, fragCurrent, data.startPTS, data.endPTS);\n\n const media = this.media;\n let appendOnBufferFlush = false;\n // Only flush audio from old audio tracks when PTS is known on new audio track\n if (this.audioSwitch) {\n if (media && media.readyState) {\n let currentTime = media.currentTime;\n logger.log('switching audio track : currentTime:' + currentTime);\n if (currentTime >= data.startPTS) {\n logger.log('switching audio track : flushing all audio');\n this.state = State.BUFFER_FLUSHING;\n hls.trigger(Event.BUFFER_FLUSHING, { startOffset: 0, endOffset: Number.POSITIVE_INFINITY, type: 'audio' });\n appendOnBufferFlush = true;\n // Lets announce that the initial audio track switch flush occur\n this.audioSwitch = false;\n hls.trigger(Event.AUDIO_TRACK_SWITCHED, { id: trackId });\n }\n } else {\n // Lets announce that the initial audio track switch flush occur\n this.audioSwitch = false;\n hls.trigger(Event.AUDIO_TRACK_SWITCHED, { id: trackId });\n }\n }\n\n let pendingData = this.pendingData;\n\n if (!pendingData) {\n logger.warn('Apparently attempt to enqueue media payload without codec initialization data upfront');\n hls.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: null, fatal: true });\n return;\n }\n\n if (!this.audioSwitch) {\n [data.data1, data.data2].forEach(buffer => {\n if (buffer && buffer.length) {\n pendingData.push({ type: data.type, data: buffer, parent: 'audio', content: 'data' });\n }\n });\n if (!appendOnBufferFlush && pendingData.length) {\n pendingData.forEach(appendObj => {\n // only append in PARSING state (rationale is that an appending error could happen synchronously on first segment appending)\n // in that case it is useless to append following segments\n if (this.state === State.PARSING) {\n // arm pending Buffering flag before appending a segment\n this.pendingBuffering = true;\n this.hls.trigger(Event.BUFFER_APPENDING, appendObj);\n }\n });\n this.pendingData = [];\n this.appended = true;\n }\n }\n // trigger handler right now\n this.tick();\n }\n }\n\n onFragParsed (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'audio' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n this.stats.tparsed = performance.now();\n this.state = State.PARSED;\n this._checkAppendedParsed();\n }\n }\n\n onBufferReset () {\n // reset reference to sourcebuffers\n this.mediaBuffer = this.videoBuffer = null;\n this.loadedmetadata = false;\n }\n\n onBufferCreated (data) {\n let audioTrack = data.tracks.audio;\n if (audioTrack) {\n this.mediaBuffer = audioTrack.buffer;\n this.loadedmetadata = true;\n }\n if (data.tracks.video) {\n this.videoBuffer = data.tracks.video.buffer;\n }\n }\n\n onBufferAppended (data) {\n if (data.parent === 'audio') {\n const state = this.state;\n if (state === State.PARSING || state === State.PARSED) {\n // check if all buffers have been appended\n this.pendingBuffering = (data.pending > 0);\n this._checkAppendedParsed();\n }\n }\n }\n\n _checkAppendedParsed () {\n // trigger handler right now\n if (this.state === State.PARSED && (!this.appended || !this.pendingBuffering)) {\n let frag = this.fragCurrent, stats = this.stats, hls = this.hls;\n if (frag) {\n this.fragPrevious = frag;\n stats.tbuffered = performance.now();\n hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: frag, id: 'audio' });\n let media = this.mediaBuffer ? this.mediaBuffer : this.media;\n if (media) {\n logger.log(`audio buffered : ${TimeRanges.toString(media.buffered)}`);\n }\n if (this.audioSwitch && this.appended) {\n this.audioSwitch = false;\n hls.trigger(Event.AUDIO_TRACK_SWITCHED, { id: this.trackId });\n }\n this.state = State.IDLE;\n }\n this.tick();\n }\n }\n\n onError (data) {\n let frag = data.frag;\n // don't handle frag error not related to audio fragment\n if (frag && frag.type !== 'audio') {\n return;\n }\n\n switch (data.details) {\n case ErrorDetails.FRAG_LOAD_ERROR:\n case ErrorDetails.FRAG_LOAD_TIMEOUT:\n const frag = data.frag;\n // don't handle frag error not related to audio fragment\n if (frag && frag.type !== 'audio') {\n break;\n }\n\n if (!data.fatal) {\n let loadError = this.fragLoadError;\n if (loadError) {\n loadError++;\n } else {\n loadError = 1;\n }\n\n const config = this.config;\n if (loadError <= config.fragLoadingMaxRetry) {\n this.fragLoadError = loadError;\n // exponential backoff capped to config.fragLoadingMaxRetryTimeout\n const delay = Math.min(Math.pow(2, loadError - 1) * config.fragLoadingRetryDelay, config.fragLoadingMaxRetryTimeout);\n logger.warn(`AudioStreamController: frag loading failed, retry in ${delay} ms`);\n this.retryDate = performance.now() + delay;\n // retry loading state\n this.state = State.FRAG_LOADING_WAITING_RETRY;\n } else {\n logger.error(`AudioStreamController: ${data.details} reaches max retry, redispatch as fatal ...`);\n // switch error to fatal\n data.fatal = true;\n this.state = State.ERROR;\n }\n }\n break;\n case ErrorDetails.AUDIO_TRACK_LOAD_ERROR:\n case ErrorDetails.AUDIO_TRACK_LOAD_TIMEOUT:\n case ErrorDetails.KEY_LOAD_ERROR:\n case ErrorDetails.KEY_LOAD_TIMEOUT:\n // when in ERROR state, don't switch back to IDLE state in case a non-fatal error is received\n if (this.state !== State.ERROR) {\n // if fatal error, stop processing, otherwise move to IDLE to retry loading\n this.state = data.fatal ? State.ERROR : State.IDLE;\n logger.warn(`AudioStreamController: ${data.details} while loading frag, now switching to ${this.state} state ...`);\n }\n break;\n case ErrorDetails.BUFFER_FULL_ERROR:\n // if in appending state\n if (data.parent === 'audio' && (this.state === State.PARSING || this.state === State.PARSED)) {\n const media = this.mediaBuffer,\n currentTime = this.media.currentTime,\n mediaBuffered = media && BufferHelper.isBuffered(media, currentTime) && BufferHelper.isBuffered(media, currentTime + 0.5);\n // reduce max buf len if current position is buffered\n if (mediaBuffered) {\n const config = this.config;\n if (config.maxMaxBufferLength >= config.maxBufferLength) {\n // reduce max buffer length as it might be too high. we do this to avoid loop flushing ...\n config.maxMaxBufferLength /= 2;\n logger.warn(`AudioStreamController: reduce max buffer length to ${config.maxMaxBufferLength}s`);\n }\n this.state = State.IDLE;\n } else {\n // current position is not buffered, but browser is still complaining about buffer full error\n // this happens on IE/Edge, refer to https://github.com/video-dev/hls.js/pull/708\n // in that case flush the whole audio buffer to recover\n logger.warn('AudioStreamController: buffer full error also media.currentTime is not buffered, flush audio buffer');\n this.fragCurrent = null;\n // flush everything\n this.state = State.BUFFER_FLUSHING;\n this.hls.trigger(Event.BUFFER_FLUSHING, { startOffset: 0, endOffset: Number.POSITIVE_INFINITY, type: 'audio' });\n }\n }\n break;\n default:\n break;\n }\n }\n\n onBufferFlushed () {\n let pendingData = this.pendingData;\n if (pendingData && pendingData.length) {\n logger.log('AudioStreamController: appending pending audio data after buffer flushed');\n pendingData.forEach(appendObj => {\n this.hls.trigger(Event.BUFFER_APPENDING, appendObj);\n });\n this.appended = true;\n this.pendingData = [];\n this.state = State.PARSED;\n } else {\n // move to IDLE once flush complete. this should trigger new fragment loading\n this.state = State.IDLE;\n // reset reference to frag\n this.fragPrevious = null;\n this.tick();\n }\n }\n}\nexport default AudioStreamController;\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport default (function () {\n if (typeof window !== 'undefined' && window.VTTCue) {\n return window.VTTCue;\n }\n\n let autoKeyword = 'auto';\n let directionSetting = {\n '': true,\n lr: true,\n rl: true\n };\n let alignSetting = {\n start: true,\n middle: true,\n end: true,\n left: true,\n right: true\n };\n\n function findDirectionSetting (value) {\n if (typeof value !== 'string') {\n return false;\n }\n\n let dir = directionSetting[value.toLowerCase()];\n return dir ? value.toLowerCase() : false;\n }\n\n function findAlignSetting (value) {\n if (typeof value !== 'string') {\n return false;\n }\n\n let align = alignSetting[value.toLowerCase()];\n return align ? value.toLowerCase() : false;\n }\n\n function extend (obj) {\n let i = 1;\n for (; i < arguments.length; i++) {\n let cobj = arguments[i];\n for (let p in cobj) {\n obj[p] = cobj[p];\n }\n }\n\n return obj;\n }\n\n function VTTCue (startTime, endTime, text) {\n let cue = this;\n let baseObj = {};\n\n baseObj.enumerable = true;\n\n /**\n * Shim implementation specific properties. These properties are not in\n * the spec.\n */\n\n // Lets us know when the VTTCue's data has changed in such a way that we need\n // to recompute its display state. This lets us compute its display state\n // lazily.\n cue.hasBeenReset = false;\n\n /**\n * VTTCue and TextTrackCue properties\n * http://dev.w3.org/html5/webvtt/#vttcue-interface\n */\n\n let _id = '';\n let _pauseOnExit = false;\n let _startTime = startTime;\n let _endTime = endTime;\n let _text = text;\n let _region = null;\n let _vertical = '';\n let _snapToLines = true;\n let _line = 'auto';\n let _lineAlign = 'start';\n let _position = 50;\n let _positionAlign = 'middle';\n let _size = 50;\n let _align = 'middle';\n\n Object.defineProperty(cue, 'id', extend({}, baseObj, {\n get: function () {\n return _id;\n },\n set: function (value) {\n _id = '' + value;\n }\n }));\n\n Object.defineProperty(cue, 'pauseOnExit', extend({}, baseObj, {\n get: function () {\n return _pauseOnExit;\n },\n set: function (value) {\n _pauseOnExit = !!value;\n }\n }));\n\n Object.defineProperty(cue, 'startTime', extend({}, baseObj, {\n get: function () {\n return _startTime;\n },\n set: function (value) {\n if (typeof value !== 'number') {\n throw new TypeError('Start time must be set to a number.');\n }\n\n _startTime = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'endTime', extend({}, baseObj, {\n get: function () {\n return _endTime;\n },\n set: function (value) {\n if (typeof value !== 'number') {\n throw new TypeError('End time must be set to a number.');\n }\n\n _endTime = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'text', extend({}, baseObj, {\n get: function () {\n return _text;\n },\n set: function (value) {\n _text = '' + value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'region', extend({}, baseObj, {\n get: function () {\n return _region;\n },\n set: function (value) {\n _region = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'vertical', extend({}, baseObj, {\n get: function () {\n return _vertical;\n },\n set: function (value) {\n let setting = findDirectionSetting(value);\n // Have to check for false because the setting an be an empty string.\n if (setting === false) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _vertical = setting;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'snapToLines', extend({}, baseObj, {\n get: function () {\n return _snapToLines;\n },\n set: function (value) {\n _snapToLines = !!value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'line', extend({}, baseObj, {\n get: function () {\n return _line;\n },\n set: function (value) {\n if (typeof value !== 'number' && value !== autoKeyword) {\n throw new SyntaxError('An invalid number or illegal string was specified.');\n }\n\n _line = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'lineAlign', extend({}, baseObj, {\n get: function () {\n return _lineAlign;\n },\n set: function (value) {\n let setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _lineAlign = setting;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'position', extend({}, baseObj, {\n get: function () {\n return _position;\n },\n set: function (value) {\n if (value < 0 || value > 100) {\n throw new Error('Position must be between 0 and 100.');\n }\n\n _position = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'positionAlign', extend({}, baseObj, {\n get: function () {\n return _positionAlign;\n },\n set: function (value) {\n let setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _positionAlign = setting;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'size', extend({}, baseObj, {\n get: function () {\n return _size;\n },\n set: function (value) {\n if (value < 0 || value > 100) {\n throw new Error('Size must be between 0 and 100.');\n }\n\n _size = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'align', extend({}, baseObj, {\n get: function () {\n return _align;\n },\n set: function (value) {\n let setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _align = setting;\n this.hasBeenReset = true;\n }\n }));\n\n /**\n * Other <track> spec defined properties\n */\n\n // http://www.whatwg.org/specs/web-apps/current-work/multipage/the-video-element.html#text-track-cue-display-state\n cue.displayState = void 0;\n }\n\n /**\n * VTTCue methods\n */\n\n VTTCue.prototype.getCueAsHTML = function () {\n // Assume WebVTT.convertCueToDOMTree is on the global.\n let WebVTT = window.WebVTT;\n return WebVTT.convertCueToDOMTree(window, this.text);\n };\n\n return VTTCue;\n})();\n","/*\n * Source: https://github.com/mozilla/vtt.js/blob/master/dist/vtt.js#L1716\n */\n\nimport VTTCue from './vttcue';\n\nconst StringDecoder = function StringDecoder () {\n return {\n decode: function (data) {\n if (!data) {\n return '';\n }\n\n if (typeof data !== 'string') {\n throw new Error('Error - expected string data.');\n }\n\n return decodeURIComponent(encodeURIComponent(data));\n }\n };\n};\n\nfunction VTTParser () {\n this.window = window;\n this.state = 'INITIAL';\n this.buffer = '';\n this.decoder = new StringDecoder();\n this.regionList = [];\n}\n\n// Try to parse input as a time stamp.\nfunction parseTimeStamp (input) {\n function computeSeconds (h, m, s, f) {\n return (h | 0) * 3600 + (m | 0) * 60 + (s | 0) + (f | 0) / 1000;\n }\n\n let m = input.match(/^(\\d+):(\\d{2})(:\\d{2})?\\.(\\d{3})/);\n if (!m) {\n return null;\n }\n\n if (m[3]) {\n // Timestamp takes the form of [hours]:[minutes]:[seconds].[milliseconds]\n return computeSeconds(m[1], m[2], m[3].replace(':', ''), m[4]);\n } else if (m[1] > 59) {\n // Timestamp takes the form of [hours]:[minutes].[milliseconds]\n // First position is hours as it's over 59.\n return computeSeconds(m[1], m[2], 0, m[4]);\n } else {\n // Timestamp takes the form of [minutes]:[seconds].[milliseconds]\n return computeSeconds(0, m[1], m[2], m[4]);\n }\n}\n\n// A settings object holds key/value pairs and will ignore anything but the first\n// assignment to a specific key.\nfunction Settings () {\n this.values = Object.create(null);\n}\n\nSettings.prototype = {\n // Only accept the first assignment to any key.\n set: function (k, v) {\n if (!this.get(k) && v !== '') {\n this.values[k] = v;\n }\n },\n // Return the value for a key, or a default value.\n // If 'defaultKey' is passed then 'dflt' is assumed to be an object with\n // a number of possible default values as properties where 'defaultKey' is\n // the key of the property that will be chosen; otherwise it's assumed to be\n // a single value.\n get: function (k, dflt, defaultKey) {\n if (defaultKey) {\n return this.has(k) ? this.values[k] : dflt[defaultKey];\n }\n\n return this.has(k) ? this.values[k] : dflt;\n },\n // Check whether we have a value for a key.\n has: function (k) {\n return k in this.values;\n },\n // Accept a setting if its one of the given alternatives.\n alt: function (k, v, a) {\n for (let n = 0; n < a.length; ++n) {\n if (v === a[n]) {\n this.set(k, v);\n break;\n }\n }\n },\n // Accept a setting if its a valid (signed) integer.\n integer: function (k, v) {\n if (/^-?\\d+$/.test(v)) { // integer\n this.set(k, parseInt(v, 10));\n }\n },\n // Accept a setting if its a valid percentage.\n percent: function (k, v) {\n let m;\n if ((m = v.match(/^([\\d]{1,3})(\\.[\\d]*)?%$/))) {\n v = parseFloat(v);\n if (v >= 0 && v <= 100) {\n this.set(k, v);\n return true;\n }\n }\n return false;\n }\n};\n\n// Helper function to parse input into groups separated by 'groupDelim', and\n// interprete each group as a key/value pair separated by 'keyValueDelim'.\nfunction parseOptions (input, callback, keyValueDelim, groupDelim) {\n let groups = groupDelim ? input.split(groupDelim) : [input];\n for (let i in groups) {\n if (typeof groups[i] !== 'string') {\n continue;\n }\n\n let kv = groups[i].split(keyValueDelim);\n if (kv.length !== 2) {\n continue;\n }\n\n let k = kv[0];\n let v = kv[1];\n callback(k, v);\n }\n}\n\nlet defaults = new VTTCue(0, 0, 0);\n// 'middle' was changed to 'center' in the spec: https://github.com/w3c/webvtt/pull/244\n// Safari doesn't yet support this change, but FF and Chrome do.\nlet center = defaults.align === 'middle' ? 'middle' : 'center';\n\nfunction parseCue (input, cue, regionList) {\n // Remember the original input if we need to throw an error.\n let oInput = input;\n // 4.1 WebVTT timestamp\n function consumeTimeStamp () {\n let ts = parseTimeStamp(input);\n if (ts === null) {\n throw new Error('Malformed timestamp: ' + oInput);\n }\n\n // Remove time stamp from input.\n input = input.replace(/^[^\\sa-zA-Z-]+/, '');\n return ts;\n }\n\n // 4.4.2 WebVTT cue settings\n function consumeCueSettings (input, cue) {\n let settings = new Settings();\n\n parseOptions(input, function (k, v) {\n switch (k) {\n case 'region':\n // Find the last region we parsed with the same region id.\n for (let i = regionList.length - 1; i >= 0; i--) {\n if (regionList[i].id === v) {\n settings.set(k, regionList[i].region);\n break;\n }\n }\n break;\n case 'vertical':\n settings.alt(k, v, ['rl', 'lr']);\n break;\n case 'line':\n var vals = v.split(','),\n vals0 = vals[0];\n settings.integer(k, vals0);\n if (settings.percent(k, vals0)) {\n settings.set('snapToLines', false);\n }\n\n settings.alt(k, vals0, ['auto']);\n if (vals.length === 2) {\n settings.alt('lineAlign', vals[1], ['start', center, 'end']);\n }\n\n break;\n case 'position':\n vals = v.split(',');\n settings.percent(k, vals[0]);\n if (vals.length === 2) {\n settings.alt('positionAlign', vals[1], ['start', center, 'end', 'line-left', 'line-right', 'auto']);\n }\n\n break;\n case 'size':\n settings.percent(k, v);\n break;\n case 'align':\n settings.alt(k, v, ['start', center, 'end', 'left', 'right']);\n break;\n }\n }, /:/, /\\s/);\n\n // Apply default values for any missing fields.\n cue.region = settings.get('region', null);\n cue.vertical = settings.get('vertical', '');\n let line = settings.get('line', 'auto');\n if (line === 'auto' && defaults.line === -1) {\n // set numeric line number for Safari\n line = -1;\n }\n cue.line = line;\n cue.lineAlign = settings.get('lineAlign', 'start');\n cue.snapToLines = settings.get('snapToLines', true);\n cue.size = settings.get('size', 100);\n cue.align = settings.get('align', center);\n let position = settings.get('position', 'auto');\n if (position === 'auto' && defaults.position === 50) {\n // set numeric position for Safari\n position = cue.align === 'start' || cue.align === 'left' ? 0 : cue.align === 'end' || cue.align === 'right' ? 100 : 50;\n }\n cue.position = position;\n }\n\n function skipWhitespace () {\n input = input.replace(/^\\s+/, '');\n }\n\n // 4.1 WebVTT cue timings.\n skipWhitespace();\n cue.startTime = consumeTimeStamp(); // (1) collect cue start time\n skipWhitespace();\n if (input.substr(0, 3) !== '-->') { // (3) next characters must match '-->'\n throw new Error('Malformed time stamp (time stamps must be separated by \\'-->\\'): ' +\n oInput);\n }\n input = input.substr(3);\n skipWhitespace();\n cue.endTime = consumeTimeStamp(); // (5) collect cue end time\n\n // 4.1 WebVTT cue settings list.\n skipWhitespace();\n consumeCueSettings(input, cue);\n}\n\nfunction fixLineBreaks (input) {\n return input.replace(/<br(?: \\/)?>/gi, '\\n');\n}\n\nVTTParser.prototype = {\n parse: function (data) {\n let self = this;\n\n // If there is no data then we won't decode it, but will just try to parse\n // whatever is in buffer already. This may occur in circumstances, for\n // example when flush() is called.\n if (data) {\n // Try to decode the data that we received.\n self.buffer += self.decoder.decode(data, { stream: true });\n }\n\n function collectNextLine () {\n let buffer = self.buffer;\n let pos = 0;\n\n buffer = fixLineBreaks(buffer);\n\n while (pos < buffer.length && buffer[pos] !== '\\r' && buffer[pos] !== '\\n') {\n ++pos;\n }\n\n let line = buffer.substr(0, pos);\n // Advance the buffer early in case we fail below.\n if (buffer[pos] === '\\r') {\n ++pos;\n }\n\n if (buffer[pos] === '\\n') {\n ++pos;\n }\n\n self.buffer = buffer.substr(pos);\n return line;\n }\n\n // 3.2 WebVTT metadata header syntax\n function parseHeader (input) {\n parseOptions(input, function (k, v) {\n switch (k) {\n case 'Region':\n // 3.3 WebVTT region metadata header syntax\n // console.log('parse region', v);\n // parseRegion(v);\n break;\n }\n }, /:/);\n }\n\n // 5.1 WebVTT file parsing.\n try {\n let line;\n if (self.state === 'INITIAL') {\n // We can't start parsing until we have the first line.\n if (!/\\r\\n|\\n/.test(self.buffer)) {\n return this;\n }\n\n line = collectNextLine();\n // strip of UTF-8 BOM if any\n // https://en.wikipedia.org/wiki/Byte_order_mark#UTF-8\n let m = line.match(/^()?WEBVTT([ \\t].*)?$/);\n if (!m || !m[0]) {\n throw new Error('Malformed WebVTT signature.');\n }\n\n self.state = 'HEADER';\n }\n\n let alreadyCollectedLine = false;\n while (self.buffer) {\n // We can't parse a line until we have the full line.\n if (!/\\r\\n|\\n/.test(self.buffer)) {\n return this;\n }\n\n if (!alreadyCollectedLine) {\n line = collectNextLine();\n } else {\n alreadyCollectedLine = false;\n }\n\n switch (self.state) {\n case 'HEADER':\n // 13-18 - Allow a header (metadata) under the WEBVTT line.\n if (/:/.test(line)) {\n parseHeader(line);\n } else if (!line) {\n // An empty line terminates the header and starts the body (cues).\n self.state = 'ID';\n }\n continue;\n case 'NOTE':\n // Ignore NOTE blocks.\n if (!line) {\n self.state = 'ID';\n }\n\n continue;\n case 'ID':\n // Check for the start of NOTE blocks.\n if (/^NOTE($|[ \\t])/.test(line)) {\n self.state = 'NOTE';\n break;\n }\n // 19-29 - Allow any number of line terminators, then initialize new cue values.\n if (!line) {\n continue;\n }\n\n self.cue = new VTTCue(0, 0, '');\n self.state = 'CUE';\n // 30-39 - Check if self line contains an optional identifier or timing data.\n if (line.indexOf('-->') === -1) {\n self.cue.id = line;\n continue;\n }\n // Process line as start of a cue.\n /* falls through */\n case 'CUE':\n // 40 - Collect cue timings and settings.\n try {\n parseCue(line, self.cue, self.regionList);\n } catch (e) {\n // In case of an error ignore rest of the cue.\n self.cue = null;\n self.state = 'BADCUE';\n continue;\n }\n self.state = 'CUETEXT';\n continue;\n case 'CUETEXT':\n var hasSubstring = line.indexOf('-->') !== -1;\n // 34 - If we have an empty line then report the cue.\n // 35 - If we have the special substring '-->' then report the cue,\n // but do not collect the line as we need to process the current\n // one as a new cue.\n if (!line || hasSubstring && (alreadyCollectedLine = true)) {\n // We are done parsing self cue.\n if (self.oncue) {\n self.oncue(self.cue);\n }\n\n self.cue = null;\n self.state = 'ID';\n continue;\n }\n if (self.cue.text) {\n self.cue.text += '\\n';\n }\n\n self.cue.text += line;\n continue;\n case 'BADCUE': // BADCUE\n // 54-62 - Collect and discard the remaining cue.\n if (!line) {\n self.state = 'ID';\n }\n\n continue;\n }\n }\n } catch (e) {\n // If we are currently parsing a cue, report what we have.\n if (self.state === 'CUETEXT' && self.cue && self.oncue) {\n self.oncue(self.cue);\n }\n\n self.cue = null;\n // Enter BADWEBVTT state if header was not parsed correctly otherwise\n // another exception occurred so enter BADCUE state.\n self.state = self.state === 'INITIAL' ? 'BADWEBVTT' : 'BADCUE';\n }\n return this;\n },\n flush: function () {\n let self = this;\n try {\n // Finish decoding the stream.\n self.buffer += self.decoder.decode();\n // Synthesize the end of the current cue or region.\n if (self.cue || self.state === 'HEADER') {\n self.buffer += '\\n\\n';\n self.parse();\n }\n // If we've flushed, parsed, and we're still on the INITIAL state then\n // that means we don't have enough of the stream to parse the first\n // line.\n if (self.state === 'INITIAL') {\n throw new Error('Malformed WebVTT signature.');\n }\n } catch (e) {\n throw e;\n }\n if (self.onflush) {\n self.onflush();\n }\n\n return this;\n }\n};\n\nexport { fixLineBreaks };\n\nexport default VTTParser;\n","import { fixLineBreaks } from './vttparser';\nimport { CaptionScreen, Row } from './cea-608-parser';\n\nexport interface CuesInterface {\n newCue (track: TextTrack | null, startTime: number, endTime: number, captionScreen: CaptionScreen): VTTCue[]\n}\n\ninterface VTTCue extends TextTrackCue {\n new(start: number, end: number, cueText: string): VTTCue\n line: number\n align: string\n position: number\n}\n\nexport function newCue (track: TextTrack | null, startTime: number, endTime: number, captionScreen: CaptionScreen): VTTCue[] {\n const result: VTTCue[] = [];\n let row: Row;\n // the type data states this is VTTCue, but it can potentially be a TextTrackCue on old browsers\n let cue: VTTCue;\n let indenting: boolean;\n let indent: number;\n let text: string;\n let VTTCue: VTTCue = (window as any).VTTCue as VTTCue || TextTrackCue;\n\n for (let r = 0; r < captionScreen.rows.length; r++) {\n row = captionScreen.rows[r];\n indenting = true;\n indent = 0;\n text = '';\n\n if (!row.isEmpty()) {\n for (let c = 0; c < row.chars.length; c++) {\n if (row.chars[c].uchar.match(/\\s/) && indenting) {\n indent++;\n } else {\n text += row.chars[c].uchar;\n indenting = false;\n }\n }\n // To be used for cleaning-up orphaned roll-up captions\n row.cueStartTime = startTime;\n\n // Give a slight bump to the endTime if it's equal to startTime to avoid a SyntaxError in IE\n if (startTime === endTime) {\n endTime += 0.0001;\n }\n\n cue = new VTTCue(startTime, endTime, fixLineBreaks(text.trim()));\n\n if (indent >= 16) {\n indent--;\n } else {\n indent++;\n }\n\n // VTTCue.line get's flakey when using controls, so let's now include line 13&14\n // also, drop line 1 since it's to close to the top\n if (navigator.userAgent.match(/Firefox\\//)) {\n cue.line = r + 1;\n } else {\n cue.line = (r > 7 ? r - 2 : r + 1);\n }\n\n cue.align = 'left';\n // Clamp the position between 0 and 100 - if out of these bounds, Firefox throws an exception and captions break\n cue.position = Math.max(0, Math.min(100, 100 * (indent / 32)));\n result.push(cue);\n if (track) {\n track.addCue(cue);\n }\n }\n }\n return result;\n}\n","import OutputFilter from './output-filter';\nimport { logger } from '../utils/logger';\n\n/**\n *\n * This code was ported from the dash.js project at:\n * https://github.com/Dash-Industry-Forum/dash.js/blob/development/externals/cea608-parser.js\n * https://github.com/Dash-Industry-Forum/dash.js/commit/8269b26a761e0853bb21d78780ed945144ecdd4d#diff-71bc295a2d6b6b7093a1d3290d53a4b2\n *\n * The original copyright appears below:\n *\n * The copyright in this software is being made available under the BSD License,\n * included below. This software may be subject to other third party and contributor\n * rights, including patent rights, and no such rights are granted under this license.\n *\n * Copyright (c) 2015-2016, DASH Industry Forum.\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without modification,\n * are permitted provided that the following conditions are met:\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * * Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the documentation and/or\n * other materials provided with the distribution.\n * 2. Neither the name of Dash Industry Forum nor the names of its\n * contributors may be used to endorse or promote products derived from this software\n * without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS AS IS AND ANY\n * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.\n * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,\n * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT\n * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,\n * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n * POSSIBILITY OF SUCH DAMAGE.\n */\n/**\n * Exceptions from regular ASCII. CodePoints are mapped to UTF-16 codes\n */\n\nconst specialCea608CharsCodes = {\n 0x2a: 0xe1, // lowercase a, acute accent\n 0x5c: 0xe9, // lowercase e, acute accent\n 0x5e: 0xed, // lowercase i, acute accent\n 0x5f: 0xf3, // lowercase o, acute accent\n 0x60: 0xfa, // lowercase u, acute accent\n 0x7b: 0xe7, // lowercase c with cedilla\n 0x7c: 0xf7, // division symbol\n 0x7d: 0xd1, // uppercase N tilde\n 0x7e: 0xf1, // lowercase n tilde\n 0x7f: 0x2588, // Full block\n // THIS BLOCK INCLUDES THE 16 EXTENDED (TWO-BYTE) LINE 21 CHARACTERS\n // THAT COME FROM HI BYTE=0x11 AND LOW BETWEEN 0x30 AND 0x3F\n // THIS MEANS THAT \\x50 MUST BE ADDED TO THE VALUES\n 0x80: 0xae, // Registered symbol (R)\n 0x81: 0xb0, // degree sign\n 0x82: 0xbd, // 1/2 symbol\n 0x83: 0xbf, // Inverted (open) question mark\n 0x84: 0x2122, // Trademark symbol (TM)\n 0x85: 0xa2, // Cents symbol\n 0x86: 0xa3, // Pounds sterling\n 0x87: 0x266a, // Music 8'th note\n 0x88: 0xe0, // lowercase a, grave accent\n 0x89: 0x20, // transparent space (regular)\n 0x8a: 0xe8, // lowercase e, grave accent\n 0x8b: 0xe2, // lowercase a, circumflex accent\n 0x8c: 0xea, // lowercase e, circumflex accent\n 0x8d: 0xee, // lowercase i, circumflex accent\n 0x8e: 0xf4, // lowercase o, circumflex accent\n 0x8f: 0xfb, // lowercase u, circumflex accent\n // THIS BLOCK INCLUDES THE 32 EXTENDED (TWO-BYTE) LINE 21 CHARACTERS\n // THAT COME FROM HI BYTE=0x12 AND LOW BETWEEN 0x20 AND 0x3F\n 0x90: 0xc1, // capital letter A with acute\n 0x91: 0xc9, // capital letter E with acute\n 0x92: 0xd3, // capital letter O with acute\n 0x93: 0xda, // capital letter U with acute\n 0x94: 0xdc, // capital letter U with diaresis\n 0x95: 0xfc, // lowercase letter U with diaeresis\n 0x96: 0x2018, // opening single quote\n 0x97: 0xa1, // inverted exclamation mark\n 0x98: 0x2a, // asterisk\n 0x99: 0x2019, // closing single quote\n 0x9a: 0x2501, // box drawings heavy horizontal\n 0x9b: 0xa9, // copyright sign\n 0x9c: 0x2120, // Service mark\n 0x9d: 0x2022, // (round) bullet\n 0x9e: 0x201c, // Left double quotation mark\n 0x9f: 0x201d, // Right double quotation mark\n 0xa0: 0xc0, // uppercase A, grave accent\n 0xa1: 0xc2, // uppercase A, circumflex\n 0xa2: 0xc7, // uppercase C with cedilla\n 0xa3: 0xc8, // uppercase E, grave accent\n 0xa4: 0xca, // uppercase E, circumflex\n 0xa5: 0xcb, // capital letter E with diaresis\n 0xa6: 0xeb, // lowercase letter e with diaresis\n 0xa7: 0xce, // uppercase I, circumflex\n 0xa8: 0xcf, // uppercase I, with diaresis\n 0xa9: 0xef, // lowercase i, with diaresis\n 0xaa: 0xd4, // uppercase O, circumflex\n 0xab: 0xd9, // uppercase U, grave accent\n 0xac: 0xf9, // lowercase u, grave accent\n 0xad: 0xdb, // uppercase U, circumflex\n 0xae: 0xab, // left-pointing double angle quotation mark\n 0xaf: 0xbb, // right-pointing double angle quotation mark\n // THIS BLOCK INCLUDES THE 32 EXTENDED (TWO-BYTE) LINE 21 CHARACTERS\n // THAT COME FROM HI BYTE=0x13 AND LOW BETWEEN 0x20 AND 0x3F\n 0xb0: 0xc3, // Uppercase A, tilde\n 0xb1: 0xe3, // Lowercase a, tilde\n 0xb2: 0xcd, // Uppercase I, acute accent\n 0xb3: 0xcc, // Uppercase I, grave accent\n 0xb4: 0xec, // Lowercase i, grave accent\n 0xb5: 0xd2, // Uppercase O, grave accent\n 0xb6: 0xf2, // Lowercase o, grave accent\n 0xb7: 0xd5, // Uppercase O, tilde\n 0xb8: 0xf5, // Lowercase o, tilde\n 0xb9: 0x7b, // Open curly brace\n 0xba: 0x7d, // Closing curly brace\n 0xbb: 0x5c, // Backslash\n 0xbc: 0x5e, // Caret\n 0xbd: 0x5f, // Underscore\n 0xbe: 0x7c, // Pipe (vertical line)\n 0xbf: 0x223c, // Tilde operator\n 0xc0: 0xc4, // Uppercase A, umlaut\n 0xc1: 0xe4, // Lowercase A, umlaut\n 0xc2: 0xd6, // Uppercase O, umlaut\n 0xc3: 0xf6, // Lowercase o, umlaut\n 0xc4: 0xdf, // Esszett (sharp S)\n 0xc5: 0xa5, // Yen symbol\n 0xc6: 0xa4, // Generic currency sign\n 0xc7: 0x2503, // Box drawings heavy vertical\n 0xc8: 0xc5, // Uppercase A, ring\n 0xc9: 0xe5, // Lowercase A, ring\n 0xca: 0xd8, // Uppercase O, stroke\n 0xcb: 0xf8, // Lowercase o, strok\n 0xcc: 0x250f, // Box drawings heavy down and right\n 0xcd: 0x2513, // Box drawings heavy down and left\n 0xce: 0x2517, // Box drawings heavy up and right\n 0xcf: 0x251b // Box drawings heavy up and left\n};\n\n/**\n * Utils\n */\nconst getCharForByte = function (byte: number) {\n let charCode = byte;\n if (specialCea608CharsCodes.hasOwnProperty(byte)) {\n charCode = specialCea608CharsCodes[byte];\n }\n\n return String.fromCharCode(charCode);\n};\n\nconst NR_ROWS = 15;\nconst NR_COLS = 100;\n// Tables to look up row from PAC data\nconst rowsLowCh1 = { 0x11: 1, 0x12: 3, 0x15: 5, 0x16: 7, 0x17: 9, 0x10: 11, 0x13: 12, 0x14: 14 };\nconst rowsHighCh1 = { 0x11: 2, 0x12: 4, 0x15: 6, 0x16: 8, 0x17: 10, 0x13: 13, 0x14: 15 };\nconst rowsLowCh2 = { 0x19: 1, 0x1A: 3, 0x1D: 5, 0x1E: 7, 0x1F: 9, 0x18: 11, 0x1B: 12, 0x1C: 14 };\nconst rowsHighCh2 = { 0x19: 2, 0x1A: 4, 0x1D: 6, 0x1E: 8, 0x1F: 10, 0x1B: 13, 0x1C: 15 };\n\nconst backgroundColors = ['white', 'green', 'blue', 'cyan', 'red', 'yellow', 'magenta', 'black', 'transparent'];\n\nenum VerboseLevel {\n ERROR = 0,\n TEXT = 1,\n WARNING = 2,\n INFO = 2,\n DEBUG = 3,\n DATA = 3,\n}\n\nclass CaptionsLogger {\n public time: number | null = null;\n public verboseLevel: VerboseLevel = VerboseLevel.ERROR;\n\n log (severity: VerboseLevel, msg: string): void {\n if (this.verboseLevel >= severity) {\n logger.log(`${this.time} [${severity}] ${msg}`);\n }\n }\n}\n\nconst numArrayToHexArray = function (numArray: number[]): string[] {\n const hexArray: string[] = [];\n for (let j = 0; j < numArray.length; j++) {\n hexArray.push(numArray[j].toString(16));\n }\n\n return hexArray;\n};\n\ntype PenStyles = {\n foreground: string | null,\n underline: boolean,\n italics: boolean,\n background: string,\n flash: boolean,\n};\n\nclass PenState {\n public foreground: string;\n public underline: boolean;\n public italics: boolean;\n public background: string;\n public flash: boolean;\n\n constructor (foreground?: string, underline?: boolean, italics?: boolean, background?: string, flash?: boolean) {\n this.foreground = foreground || 'white';\n this.underline = underline || false;\n this.italics = italics || false;\n this.background = background || 'black';\n this.flash = flash || false;\n }\n\n reset () {\n this.foreground = 'white';\n this.underline = false;\n this.italics = false;\n this.background = 'black';\n this.flash = false;\n }\n\n setStyles (styles: Partial<PenStyles>) {\n const attribs = ['foreground', 'underline', 'italics', 'background', 'flash'];\n for (let i = 0; i < attribs.length; i++) {\n const style = attribs[i];\n if (styles.hasOwnProperty(style)) {\n this[style] = styles[style];\n }\n }\n }\n\n isDefault () {\n return (this.foreground === 'white' && !this.underline && !this.italics &&\n this.background === 'black' && !this.flash);\n }\n\n equals (other: PenState) {\n return ((this.foreground === other.foreground) &&\n (this.underline === other.underline) &&\n (this.italics === other.italics) &&\n (this.background === other.background) &&\n (this.flash === other.flash));\n }\n\n copy (newPenState: PenState) {\n this.foreground = newPenState.foreground;\n this.underline = newPenState.underline;\n this.italics = newPenState.italics;\n this.background = newPenState.background;\n this.flash = newPenState.flash;\n }\n\n toString (): string {\n return ('color=' + this.foreground + ', underline=' + this.underline + ', italics=' + this.italics +\n ', background=' + this.background + ', flash=' + this.flash);\n }\n}\n\n/**\n * Unicode character with styling and background.\n * @constructor\n */\nclass StyledUnicodeChar {\n uchar: string;\n penState: PenState;\n\n constructor (uchar?: string, foreground?: string, underline?: boolean, italics?: boolean, background?: string, flash?: boolean) {\n this.uchar = uchar || ' '; // unicode character\n this.penState = new PenState(foreground, underline, italics, background, flash);\n }\n\n reset () {\n this.uchar = ' ';\n this.penState.reset();\n }\n\n setChar (uchar: string, newPenState: PenState) {\n this.uchar = uchar;\n this.penState.copy(newPenState);\n }\n\n setPenState (newPenState: PenState) {\n this.penState.copy(newPenState);\n }\n\n equals (other: StyledUnicodeChar) {\n return this.uchar === other.uchar && this.penState.equals(other.penState);\n }\n\n copy (newChar: StyledUnicodeChar) {\n this.uchar = newChar.uchar;\n this.penState.copy(newChar.penState);\n }\n\n isEmpty (): boolean {\n return this.uchar === ' ' && this.penState.isDefault();\n }\n}\n\n/**\n * CEA-608 row consisting of NR_COLS instances of StyledUnicodeChar.\n * @constructor\n */\nexport class Row {\n public chars: StyledUnicodeChar[];\n public pos: number;\n public currPenState: PenState;\n public cueStartTime?: number;\n logger: CaptionsLogger;\n\n constructor (logger: CaptionsLogger) {\n this.chars = [];\n for (let i = 0; i < NR_COLS; i++) {\n this.chars.push(new StyledUnicodeChar());\n }\n\n this.logger = logger;\n this.pos = 0;\n this.currPenState = new PenState();\n }\n\n equals (other: Row) {\n let equal = true;\n for (let i = 0; i < NR_COLS; i++) {\n if (!this.chars[i].equals(other.chars[i])) {\n equal = false;\n break;\n }\n }\n return equal;\n }\n\n copy (other: Row) {\n for (let i = 0; i < NR_COLS; i++) {\n this.chars[i].copy(other.chars[i]);\n }\n }\n\n isEmpty (): boolean {\n let empty = true;\n for (let i = 0; i < NR_COLS; i++) {\n if (!this.chars[i].isEmpty()) {\n empty = false;\n break;\n }\n }\n return empty;\n }\n\n /**\n * Set the cursor to a valid column.\n */\n setCursor (absPos: number) {\n if (this.pos !== absPos) {\n this.pos = absPos;\n }\n\n if (this.pos < 0) {\n this.logger.log(VerboseLevel.DEBUG, 'Negative cursor position ' + this.pos);\n this.pos = 0;\n } else if (this.pos > NR_COLS) {\n this.logger.log(VerboseLevel.DEBUG, 'Too large cursor position ' + this.pos);\n this.pos = NR_COLS;\n }\n }\n\n /**\n * Move the cursor relative to current position.\n */\n moveCursor (relPos: number) {\n const newPos = this.pos + relPos;\n if (relPos > 1) {\n for (let i = this.pos + 1; i < newPos + 1; i++) {\n this.chars[i].setPenState(this.currPenState);\n }\n }\n this.setCursor(newPos);\n }\n\n /**\n * Backspace, move one step back and clear character.\n */\n backSpace () {\n this.moveCursor(-1);\n this.chars[this.pos].setChar(' ', this.currPenState);\n }\n\n insertChar (byte: number) {\n if (byte >= 0x90) { // Extended char\n this.backSpace();\n }\n const char = getCharForByte(byte);\n if (this.pos >= NR_COLS) {\n this.logger.log(VerboseLevel.ERROR, 'Cannot insert ' + byte.toString(16) +\n ' (' + char + ') at position ' + this.pos + '. Skipping it!');\n return;\n }\n this.chars[this.pos].setChar(char, this.currPenState);\n this.moveCursor(1);\n }\n\n clearFromPos (startPos: number) {\n let i: number;\n for (i = startPos; i < NR_COLS; i++) {\n this.chars[i].reset();\n }\n }\n\n clear () {\n this.clearFromPos(0);\n this.pos = 0;\n this.currPenState.reset();\n }\n\n clearToEndOfRow () {\n this.clearFromPos(this.pos);\n }\n\n getTextString () {\n const chars: string[] = [];\n let empty = true;\n for (let i = 0; i < NR_COLS; i++) {\n const char = this.chars[i].uchar;\n if (char !== ' ') {\n empty = false;\n }\n\n chars.push(char);\n }\n if (empty) {\n return '';\n } else {\n return chars.join('');\n }\n }\n\n setPenStyles (styles: Partial<PenStyles>) {\n this.currPenState.setStyles(styles);\n const currChar = this.chars[this.pos];\n currChar.setPenState(this.currPenState);\n }\n}\n\n/**\n * Keep a CEA-608 screen of 32x15 styled characters\n * @constructor\n */\nexport class CaptionScreen {\n rows: Row[];\n currRow: number;\n nrRollUpRows: number | null;\n lastOutputScreen: CaptionScreen | null;\n logger: CaptionsLogger;\n\n constructor (logger: CaptionsLogger) {\n this.rows = [];\n for (let i = 0; i < NR_ROWS; i++) {\n this.rows.push(new Row(logger));\n } // Note that we use zero-based numbering (0-14)\n\n this.logger = logger;\n this.currRow = NR_ROWS - 1;\n this.nrRollUpRows = null;\n this.lastOutputScreen = null;\n this.reset();\n }\n\n reset () {\n for (let i = 0; i < NR_ROWS; i++) {\n this.rows[i].clear();\n }\n\n this.currRow = NR_ROWS - 1;\n }\n\n equals (other: CaptionScreen): boolean {\n let equal = true;\n for (let i = 0; i < NR_ROWS; i++) {\n if (!this.rows[i].equals(other.rows[i])) {\n equal = false;\n break;\n }\n }\n return equal;\n }\n\n copy (other: CaptionScreen) {\n for (let i = 0; i < NR_ROWS; i++) {\n this.rows[i].copy(other.rows[i]);\n }\n }\n\n isEmpty (): boolean {\n let empty = true;\n for (let i = 0; i < NR_ROWS; i++) {\n if (!this.rows[i].isEmpty()) {\n empty = false;\n break;\n }\n }\n return empty;\n }\n\n backSpace () {\n const row = this.rows[this.currRow];\n row.backSpace();\n }\n\n clearToEndOfRow () {\n const row = this.rows[this.currRow];\n row.clearToEndOfRow();\n }\n\n /**\n * Insert a character (without styling) in the current row.\n */\n insertChar (char: number) {\n const row = this.rows[this.currRow];\n row.insertChar(char);\n }\n\n setPen (styles: Partial<PenStyles>) {\n const row = this.rows[this.currRow];\n row.setPenStyles(styles);\n }\n\n moveCursor (relPos: number) {\n const row = this.rows[this.currRow];\n row.moveCursor(relPos);\n }\n\n setCursor (absPos: number) {\n this.logger.log(VerboseLevel.INFO, 'setCursor: ' + absPos);\n const row = this.rows[this.currRow];\n row.setCursor(absPos);\n }\n\n setPAC (pacData: PACData) {\n this.logger.log(VerboseLevel.INFO, 'pacData = ' + JSON.stringify(pacData));\n let newRow = pacData.row - 1;\n if (this.nrRollUpRows && newRow < this.nrRollUpRows - 1) {\n newRow = this.nrRollUpRows - 1;\n }\n\n // Make sure this only affects Roll-up Captions by checking this.nrRollUpRows\n if (this.nrRollUpRows && this.currRow !== newRow) {\n // clear all rows first\n for (let i = 0; i < NR_ROWS; i++) {\n this.rows[i].clear();\n }\n\n // Copy this.nrRollUpRows rows from lastOutputScreen and place it in the newRow location\n // topRowIndex - the start of rows to copy (inclusive index)\n const topRowIndex = this.currRow + 1 - (this.nrRollUpRows);\n // We only copy if the last position was already shown.\n // We use the cueStartTime value to check this.\n const lastOutputScreen = this.lastOutputScreen;\n if (lastOutputScreen) {\n const prevLineTime = lastOutputScreen.rows[topRowIndex].cueStartTime;\n const time = this.logger.time;\n if (prevLineTime && time !== null && prevLineTime < time) {\n for (let i = 0; i < this.nrRollUpRows; i++) {\n this.rows[newRow - this.nrRollUpRows + i + 1].copy(lastOutputScreen.rows[topRowIndex + i]);\n }\n }\n }\n }\n\n this.currRow = newRow;\n const row = this.rows[this.currRow];\n if (pacData.indent !== null) {\n const indent = pacData.indent;\n const prevPos = Math.max(indent - 1, 0);\n row.setCursor(pacData.indent);\n pacData.color = row.chars[prevPos].penState.foreground;\n }\n const styles: PenStyles = { foreground: pacData.color, underline: pacData.underline, italics: pacData.italics, background: 'black', flash: false };\n this.setPen(styles);\n }\n\n /**\n * Set background/extra foreground, but first do back_space, and then insert space (backwards compatibility).\n */\n setBkgData (bkgData: Partial<PenStyles>) {\n this.logger.log(VerboseLevel.INFO, 'bkgData = ' + JSON.stringify(bkgData));\n this.backSpace();\n this.setPen(bkgData);\n this.insertChar(0x20); // Space\n }\n\n setRollUpRows (nrRows: number | null) {\n this.nrRollUpRows = nrRows;\n }\n\n rollUp () {\n if (this.nrRollUpRows === null) {\n this.logger.log(VerboseLevel.DEBUG, 'roll_up but nrRollUpRows not set yet');\n return; // Not properly setup\n }\n this.logger.log(VerboseLevel.TEXT, this.getDisplayText());\n const topRowIndex = this.currRow + 1 - this.nrRollUpRows;\n const topRow = this.rows.splice(topRowIndex, 1)[0];\n topRow.clear();\n this.rows.splice(this.currRow, 0, topRow);\n this.logger.log(VerboseLevel.INFO, 'Rolling up');\n // this.logger.log(VerboseLevel.TEXT, this.get_display_text())\n }\n\n /**\n * Get all non-empty rows with as unicode text.\n */\n getDisplayText (asOneRow?: boolean) {\n asOneRow = asOneRow || false;\n const displayText: string[] = [];\n let text = '';\n let rowNr = -1;\n for (let i = 0; i < NR_ROWS; i++) {\n const rowText = this.rows[i].getTextString();\n if (rowText) {\n rowNr = i + 1;\n if (asOneRow) {\n displayText.push('Row ' + rowNr + ': \\'' + rowText + '\\'');\n } else {\n displayText.push(rowText.trim());\n }\n }\n }\n if (displayText.length > 0) {\n if (asOneRow) {\n text = '[' + displayText.join(' | ') + ']';\n } else {\n text = displayText.join('\\n');\n }\n }\n return text;\n }\n\n getTextAndFormat () {\n return this.rows;\n }\n}\n\n// var modes = ['MODE_ROLL-UP', 'MODE_POP-ON', 'MODE_PAINT-ON', 'MODE_TEXT'];\n\ntype CaptionModes = 'MODE_ROLL-UP' | 'MODE_POP-ON' | 'MODE_PAINT-ON' | 'MODE_TEXT' | null;\n\nclass Cea608Channel {\n chNr: number;\n outputFilter: OutputFilter;\n mode: CaptionModes;\n verbose: number;\n displayedMemory: CaptionScreen;\n nonDisplayedMemory: CaptionScreen;\n lastOutputScreen: CaptionScreen;\n currRollUpRow: Row;\n writeScreen: CaptionScreen;\n cueStartTime: number | null;\n logger: CaptionsLogger;\n\n constructor (channelNumber: number, outputFilter: OutputFilter, logger: CaptionsLogger) {\n this.chNr = channelNumber;\n this.outputFilter = outputFilter;\n this.mode = null;\n this.verbose = 0;\n this.displayedMemory = new CaptionScreen(logger);\n this.nonDisplayedMemory = new CaptionScreen(logger);\n this.lastOutputScreen = new CaptionScreen(logger);\n this.currRollUpRow = this.displayedMemory.rows[NR_ROWS - 1];\n this.writeScreen = this.displayedMemory;\n this.mode = null;\n this.cueStartTime = null; // Keeps track of where a cue started.\n this.logger = logger;\n }\n\n reset () {\n this.mode = null;\n this.displayedMemory.reset();\n this.nonDisplayedMemory.reset();\n this.lastOutputScreen.reset();\n this.outputFilter.reset();\n this.currRollUpRow = this.displayedMemory.rows[NR_ROWS - 1];\n this.writeScreen = this.displayedMemory;\n this.mode = null;\n this.cueStartTime = null;\n }\n\n getHandler (): OutputFilter {\n return this.outputFilter;\n }\n\n setHandler (newHandler: OutputFilter) {\n this.outputFilter = newHandler;\n }\n\n setPAC (pacData: PACData) {\n this.writeScreen.setPAC(pacData);\n }\n\n setBkgData (bkgData: Partial<PenStyles>) {\n this.writeScreen.setBkgData(bkgData);\n }\n\n setMode (newMode: CaptionModes) {\n if (newMode === this.mode) {\n return;\n }\n\n this.mode = newMode;\n this.logger.log(VerboseLevel.INFO, 'MODE=' + newMode);\n if (this.mode === 'MODE_POP-ON') {\n this.writeScreen = this.nonDisplayedMemory;\n } else {\n this.writeScreen = this.displayedMemory;\n this.writeScreen.reset();\n }\n if (this.mode !== 'MODE_ROLL-UP') {\n this.displayedMemory.nrRollUpRows = null;\n this.nonDisplayedMemory.nrRollUpRows = null;\n }\n this.mode = newMode;\n }\n\n insertChars (chars: number[]) {\n for (let i = 0; i < chars.length; i++) {\n this.writeScreen.insertChar(chars[i]);\n }\n\n const screen = this.writeScreen === this.displayedMemory ? 'DISP' : 'NON_DISP';\n this.logger.log(VerboseLevel.INFO, screen + ': ' + this.writeScreen.getDisplayText(true));\n if (this.mode === 'MODE_PAINT-ON' || this.mode === 'MODE_ROLL-UP') {\n this.logger.log(VerboseLevel.TEXT, 'DISPLAYED: ' + this.displayedMemory.getDisplayText(true));\n this.outputDataUpdate();\n }\n }\n\n ccRCL () { // Resume Caption Loading (switch mode to Pop On)\n this.logger.log(VerboseLevel.INFO, 'RCL - Resume Caption Loading');\n this.setMode('MODE_POP-ON');\n }\n\n ccBS () { // BackSpace\n this.logger.log(VerboseLevel.INFO, 'BS - BackSpace');\n if (this.mode === 'MODE_TEXT') {\n return;\n }\n\n this.writeScreen.backSpace();\n if (this.writeScreen === this.displayedMemory) {\n this.outputDataUpdate();\n }\n }\n\n ccAOF () { // Reserved (formerly Alarm Off)\n\n }\n\n ccAON () { // Reserved (formerly Alarm On)\n\n }\n\n ccDER () { // Delete to End of Row\n this.logger.log(VerboseLevel.INFO, 'DER- Delete to End of Row');\n this.writeScreen.clearToEndOfRow();\n this.outputDataUpdate();\n }\n\n ccRU (nrRows: number | null) { // Roll-Up Captions-2,3,or 4 Rows\n this.logger.log(VerboseLevel.INFO, 'RU(' + nrRows + ') - Roll Up');\n this.writeScreen = this.displayedMemory;\n this.setMode('MODE_ROLL-UP');\n this.writeScreen.setRollUpRows(nrRows);\n }\n\n ccFON () { // Flash On\n this.logger.log(VerboseLevel.INFO, 'FON - Flash On');\n this.writeScreen.setPen({ flash: true });\n }\n\n ccRDC () { // Resume Direct Captioning (switch mode to PaintOn)\n this.logger.log(VerboseLevel.INFO, 'RDC - Resume Direct Captioning');\n this.setMode('MODE_PAINT-ON');\n }\n\n ccTR () { // Text Restart in text mode (not supported, however)\n this.logger.log(VerboseLevel.INFO, 'TR');\n this.setMode('MODE_TEXT');\n }\n\n ccRTD () { // Resume Text Display in Text mode (not supported, however)\n this.logger.log(VerboseLevel.INFO, 'RTD');\n this.setMode('MODE_TEXT');\n }\n\n ccEDM () { // Erase Displayed Memory\n this.logger.log(VerboseLevel.INFO, 'EDM - Erase Displayed Memory');\n this.displayedMemory.reset();\n this.outputDataUpdate(true);\n }\n\n ccCR () { // Carriage Return\n this.logger.log(VerboseLevel.INFO, 'CR - Carriage Return');\n this.writeScreen.rollUp();\n this.outputDataUpdate(true);\n }\n\n ccENM () { // Erase Non-Displayed Memory\n this.logger.log(VerboseLevel.INFO, 'ENM - Erase Non-displayed Memory');\n this.nonDisplayedMemory.reset();\n }\n\n ccEOC () { // End of Caption (Flip Memories)\n this.logger.log(VerboseLevel.INFO, 'EOC - End Of Caption');\n if (this.mode === 'MODE_POP-ON') {\n const tmp = this.displayedMemory;\n this.displayedMemory = this.nonDisplayedMemory;\n this.nonDisplayedMemory = tmp;\n this.writeScreen = this.nonDisplayedMemory;\n this.logger.log(VerboseLevel.TEXT, 'DISP: ' + this.displayedMemory.getDisplayText());\n }\n this.outputDataUpdate(true);\n }\n\n ccTO (nrCols: number) { // Tab Offset 1,2, or 3 columns\n this.logger.log(VerboseLevel.INFO, 'TO(' + nrCols + ') - Tab Offset');\n this.writeScreen.moveCursor(nrCols);\n }\n\n ccMIDROW (secondByte: number) { // Parse MIDROW command\n const styles: Partial<PenStyles> = { flash: false };\n styles.underline = secondByte % 2 === 1;\n styles.italics = secondByte >= 0x2e;\n if (!styles.italics) {\n const colorIndex = Math.floor(secondByte / 2) - 0x10;\n const colors = ['white', 'green', 'blue', 'cyan', 'red', 'yellow', 'magenta'];\n styles.foreground = colors[colorIndex];\n } else {\n styles.foreground = 'white';\n }\n this.logger.log(VerboseLevel.INFO, 'MIDROW: ' + JSON.stringify(styles));\n this.writeScreen.setPen(styles);\n }\n\n outputDataUpdate (dispatch: boolean = false) {\n const time = this.logger.time;\n if (time === null) {\n return;\n }\n\n if (this.outputFilter) {\n if (this.cueStartTime === null && !this.displayedMemory.isEmpty()) { // Start of a new cue\n this.cueStartTime = time;\n } else {\n if (!this.displayedMemory.equals(this.lastOutputScreen)) {\n this.outputFilter.newCue(this.cueStartTime!, time, this.lastOutputScreen);\n if (dispatch && this.outputFilter.dispatchCue) {\n this.outputFilter.dispatchCue();\n }\n\n this.cueStartTime = this.displayedMemory.isEmpty() ? null : time;\n }\n }\n this.lastOutputScreen.copy(this.displayedMemory);\n }\n }\n\n cueSplitAtTime (t: number) {\n if (this.outputFilter) {\n if (!this.displayedMemory.isEmpty()) {\n if (this.outputFilter.newCue) {\n this.outputFilter.newCue(this.cueStartTime!, t, this.displayedMemory);\n }\n\n this.cueStartTime = t;\n }\n }\n }\n}\n\ninterface PACData {\n row: number;\n indent: number | null;\n color: string | null;\n underline: boolean;\n italics: boolean;\n}\n\ntype SupportedField = 1 | 3;\n\ntype Channels = 0 | 1 | 2; // Will be 1 or 2 when parsing captions\n\ntype CmdHistory = {\n a: number | null,\n b: number | null\n};\n\nclass Cea608Parser {\n channels: Array<Cea608Channel | null>;\n currentChannel: Channels = 0;\n cmdHistory: CmdHistory;\n logger: CaptionsLogger;\n\n constructor (field: SupportedField, out1: OutputFilter, out2: OutputFilter) {\n const logger = new CaptionsLogger();\n this.channels = [\n null,\n new Cea608Channel(field, out1, logger),\n new Cea608Channel(field + 1, out2, logger)\n ];\n this.cmdHistory = createCmdHistory();\n this.logger = logger;\n }\n\n getHandler (channel: number) {\n return (this.channels[channel] as Cea608Channel).getHandler();\n }\n\n setHandler (channel: number, newHandler: OutputFilter) {\n (this.channels[channel] as Cea608Channel).setHandler(newHandler);\n }\n\n /**\n * Add data for time t in forms of list of bytes (unsigned ints). The bytes are treated as pairs.\n */\n addData (time: number | null, byteList: number[]) {\n let cmdFound: boolean;\n let a: number;\n let b: number;\n let charsFound: number[] | boolean | null = false;\n\n this.logger.time = time;\n\n for (let i = 0; i < byteList.length; i += 2) {\n a = byteList[i] & 0x7f;\n b = byteList[i + 1] & 0x7f;\n if (a === 0 && b === 0) {\n continue;\n } else {\n this.logger.log(VerboseLevel.DATA, '[' + numArrayToHexArray([byteList[i], byteList[i + 1]]) + '] -> (' + numArrayToHexArray([a, b]) + ')');\n }\n\n cmdFound = this.parseCmd(a, b);\n\n if (!cmdFound) {\n cmdFound = this.parseMidrow(a, b);\n }\n\n if (!cmdFound) {\n cmdFound = this.parsePAC(a, b);\n }\n\n if (!cmdFound) {\n cmdFound = this.parseBackgroundAttributes(a, b);\n }\n\n if (!cmdFound) {\n charsFound = this.parseChars(a, b);\n if (charsFound) {\n const currChNr = this.currentChannel;\n if (currChNr && currChNr > 0) {\n const channel = this.channels[currChNr] as Cea608Channel;\n channel.insertChars(charsFound);\n } else {\n this.logger.log(VerboseLevel.WARNING, 'No channel found yet. TEXT-MODE?');\n }\n }\n }\n if (!cmdFound && !charsFound) {\n this.logger.log(VerboseLevel.WARNING, 'Couldn\\'t parse cleaned data ' + numArrayToHexArray([a, b]) +\n ' orig: ' + numArrayToHexArray([byteList[i], byteList[i + 1]]));\n }\n }\n }\n\n /**\n * Parse Command.\n * @returns {Boolean} Tells if a command was found\n */\n parseCmd (a: number, b: number) {\n const { cmdHistory } = this;\n const cond1 = (a === 0x14 || a === 0x1C || a === 0x15 || a === 0x1D) && (b >= 0x20 && b <= 0x2F);\n const cond2 = (a === 0x17 || a === 0x1F) && (b >= 0x21 && b <= 0x23);\n if (!(cond1 || cond2)) {\n return false;\n }\n\n if (hasCmdRepeated(a, b, cmdHistory)) {\n setLastCmd(null, null, cmdHistory);\n this.logger.log(VerboseLevel.DEBUG, 'Repeated command (' + numArrayToHexArray([a, b]) + ') is dropped');\n return true;\n }\n\n const chNr = (a === 0x14 || a === 0x15 || a === 0x17) ? 1 : 2;\n const channel = this.channels[chNr] as Cea608Channel;\n\n if (a === 0x14 || a === 0x15 || a === 0x1C || a === 0x1D) {\n if (b === 0x20) {\n channel.ccRCL();\n } else if (b === 0x21) {\n channel.ccBS();\n } else if (b === 0x22) {\n channel.ccAOF();\n } else if (b === 0x23) {\n channel.ccAON();\n } else if (b === 0x24) {\n channel.ccDER();\n } else if (b === 0x25) {\n channel.ccRU(2);\n } else if (b === 0x26) {\n channel.ccRU(3);\n } else if (b === 0x27) {\n channel.ccRU(4);\n } else if (b === 0x28) {\n channel.ccFON();\n } else if (b === 0x29) {\n channel.ccRDC();\n } else if (b === 0x2A) {\n channel.ccTR();\n } else if (b === 0x2B) {\n channel.ccRTD();\n } else if (b === 0x2C) {\n channel.ccEDM();\n } else if (b === 0x2D) {\n channel.ccCR();\n } else if (b === 0x2E) {\n channel.ccENM();\n } else if (b === 0x2F) {\n channel.ccEOC();\n }\n } else { // a == 0x17 || a == 0x1F\n channel.ccTO(b - 0x20);\n }\n setLastCmd(a, b, cmdHistory);\n this.currentChannel = chNr;\n return true;\n }\n\n /**\n * Parse midrow styling command\n * @returns {Boolean}\n */\n parseMidrow (a: number, b: number) {\n let chNr: number = 0;\n\n if (((a === 0x11) || (a === 0x19)) && b >= 0x20 && b <= 0x2f) {\n if (a === 0x11) {\n chNr = 1;\n } else {\n chNr = 2;\n }\n\n if (chNr !== this.currentChannel) {\n this.logger.log(VerboseLevel.ERROR, 'Mismatch channel in midrow parsing');\n return false;\n }\n const channel = this.channels[chNr];\n if (!channel) {\n return false;\n }\n channel.ccMIDROW(b);\n this.logger.log(VerboseLevel.DEBUG, 'MIDROW (' + numArrayToHexArray([a, b]) + ')');\n return true;\n }\n return false;\n }\n\n /**\n * Parse Preable Access Codes (Table 53).\n * @returns {Boolean} Tells if PAC found\n */\n parsePAC (a: number, b: number): boolean {\n let row: number;\n const cmdHistory = this.cmdHistory;\n\n const case1 = ((a >= 0x11 && a <= 0x17) || (a >= 0x19 && a <= 0x1F)) && (b >= 0x40 && b <= 0x7F);\n const case2 = (a === 0x10 || a === 0x18) && (b >= 0x40 && b <= 0x5F);\n if (!(case1 || case2)) {\n return false;\n }\n\n if (hasCmdRepeated(a, b, cmdHistory)) {\n setLastCmd(null, null, cmdHistory);\n return true; // Repeated commands are dropped (once)\n }\n\n const chNr: Channels = (a <= 0x17) ? 1 : 2;\n\n if (b >= 0x40 && b <= 0x5F) {\n row = (chNr === 1) ? rowsLowCh1[a] : rowsLowCh2[a];\n } else { // 0x60 <= b <= 0x7F\n row = (chNr === 1) ? rowsHighCh1[a] : rowsHighCh2[a];\n }\n const channel = this.channels[chNr];\n if (!channel) {\n return false;\n }\n channel.setPAC(this.interpretPAC(row, b));\n setLastCmd(a, b, cmdHistory);\n this.currentChannel = chNr;\n return true;\n }\n\n /**\n * Interpret the second byte of the pac, and return the information.\n * @returns {Object} pacData with style parameters.\n */\n interpretPAC (row: number, byte: number): PACData {\n let pacIndex = byte;\n const pacData: PACData = { color: null, italics: false, indent: null, underline: false, row: row };\n\n if (byte > 0x5F) {\n pacIndex = byte - 0x60;\n } else {\n pacIndex = byte - 0x40;\n }\n\n pacData.underline = (pacIndex & 1) === 1;\n if (pacIndex <= 0xd) {\n pacData.color = ['white', 'green', 'blue', 'cyan', 'red', 'yellow', 'magenta', 'white'][Math.floor(pacIndex / 2)];\n } else if (pacIndex <= 0xf) {\n pacData.italics = true;\n pacData.color = 'white';\n } else {\n pacData.indent = (Math.floor((pacIndex - 0x10) / 2)) * 4;\n }\n return pacData; // Note that row has zero offset. The spec uses 1.\n }\n\n /**\n * Parse characters.\n * @returns An array with 1 to 2 codes corresponding to chars, if found. null otherwise.\n */\n parseChars (a: number, b: number): number[] | null {\n let channelNr: Channels;\n let charCodes: number[] | null = null;\n let charCode1: number | null = null;\n\n if (a >= 0x19) {\n channelNr = 2;\n charCode1 = a - 8;\n } else {\n channelNr = 1;\n charCode1 = a;\n }\n if (charCode1 >= 0x11 && charCode1 <= 0x13) {\n // Special character\n let oneCode = b;\n if (charCode1 === 0x11) {\n oneCode = b + 0x50;\n } else if (charCode1 === 0x12) {\n oneCode = b + 0x70;\n } else {\n oneCode = b + 0x90;\n }\n\n this.logger.log(VerboseLevel.INFO, 'Special char \\'' + getCharForByte(oneCode) + '\\' in channel ' + channelNr);\n charCodes = [oneCode];\n } else if (a >= 0x20 && a <= 0x7f) {\n charCodes = (b === 0) ? [a] : [a, b];\n }\n if (charCodes) {\n const hexCodes = numArrayToHexArray(charCodes);\n this.logger.log(VerboseLevel.DEBUG, 'Char codes = ' + hexCodes.join(','));\n setLastCmd(a, b, this.cmdHistory);\n }\n return charCodes;\n }\n\n /**\n * Parse extended background attributes as well as new foreground color black.\n * @returns {Boolean} Tells if background attributes are found\n */\n parseBackgroundAttributes (a: number, b: number): boolean {\n const case1 = (a === 0x10 || a === 0x18) && (b >= 0x20 && b <= 0x2f);\n const case2 = (a === 0x17 || a === 0x1f) && (b >= 0x2d && b <= 0x2f);\n if (!(case1 || case2)) {\n return false;\n }\n let index: number;\n const bkgData: Partial<PenStyles> = {};\n if (a === 0x10 || a === 0x18) {\n index = Math.floor((b - 0x20) / 2);\n bkgData.background = backgroundColors[index];\n if (b % 2 === 1) {\n bkgData.background = bkgData.background + '_semi';\n }\n } else if (b === 0x2d) {\n bkgData.background = 'transparent';\n } else {\n bkgData.foreground = 'black';\n if (b === 0x2f) {\n bkgData.underline = true;\n }\n }\n const chNr: Channels = (a <= 0x17) ? 1 : 2;\n const channel: Cea608Channel = this.channels[chNr] as Cea608Channel;\n channel.setBkgData(bkgData);\n setLastCmd(a, b, this.cmdHistory);\n return true;\n }\n\n /**\n * Reset state of parser and its channels.\n */\n reset () {\n for (let i = 0; i < Object.keys(this.channels).length; i++) {\n const channel = this.channels[i];\n if (channel) {\n channel.reset();\n }\n }\n this.cmdHistory = createCmdHistory();\n }\n\n /**\n * Trigger the generation of a cue, and the start of a new one if displayScreens are not empty.\n */\n cueSplitAtTime (t: number) {\n for (let i = 0; i < this.channels.length; i++) {\n const channel = this.channels[i];\n if (channel) {\n channel.cueSplitAtTime(t);\n }\n }\n }\n}\n\nfunction setLastCmd (a: number | null, b: number | null, cmdHistory: CmdHistory) {\n cmdHistory.a = a;\n cmdHistory.b = b;\n}\n\nfunction hasCmdRepeated (a: number, b: number, cmdHistory: CmdHistory) {\n return cmdHistory.a === a && cmdHistory.b === b;\n}\n\nfunction createCmdHistory (): CmdHistory {\n return {\n a: null,\n b: null\n };\n}\n\nexport default Cea608Parser;\n","import { CaptionScreen } from './cea-608-parser';\nimport type TimelineController from '../controller/timeline-controller';\n\nexport default class OutputFilter {\n private timelineController: TimelineController;\n private cueRanges: Array<[number, number]> = [];\n private trackName: string;\n private startTime: number | null = null;\n private endTime: number | null = null;\n private screen: CaptionScreen | null = null;\n\n constructor (timelineController: TimelineController, trackName: string) {\n this.timelineController = timelineController;\n this.trackName = trackName;\n }\n\n dispatchCue () {\n if (this.startTime === null) {\n return;\n }\n\n this.timelineController.addCues(this.trackName, this.startTime, this.endTime as number, this.screen as CaptionScreen, this.cueRanges);\n this.startTime = null;\n }\n\n newCue (startTime: number, endTime: number, screen: CaptionScreen) {\n if (this.startTime === null || this.startTime > startTime) {\n this.startTime = startTime;\n }\n\n this.endTime = endTime;\n this.screen = screen;\n this.timelineController.createCaptionsTrack(this.trackName);\n }\n\n reset () {\n this.cueRanges = [];\n }\n}\n","import VTTParser from './vttparser';\nimport { utf8ArrayToStr } from '../demux/id3';\n\n// String.prototype.startsWith is not supported in IE11\nconst startsWith = function (inputString, searchString, position) {\n return inputString.substr(position || 0, searchString.length) === searchString;\n};\n\nconst cueString2millis = function (timeString) {\n let ts = parseInt(timeString.substr(-3));\n let secs = parseInt(timeString.substr(-6, 2));\n let mins = parseInt(timeString.substr(-9, 2));\n let hours = timeString.length > 9 ? parseInt(timeString.substr(0, timeString.indexOf(':'))) : 0;\n\n if (!Number.isFinite(ts) || !Number.isFinite(secs) || !Number.isFinite(mins) || !Number.isFinite(hours)) {\n throw Error(`Malformed X-TIMESTAMP-MAP: Local:${timeString}`);\n }\n\n ts += 1000 * secs;\n ts += 60 * 1000 * mins;\n ts += 60 * 60 * 1000 * hours;\n\n return ts;\n};\n\n// From https://github.com/darkskyapp/string-hash\nconst hash = function (text) {\n let hash = 5381;\n let i = text.length;\n while (i) {\n hash = (hash * 33) ^ text.charCodeAt(--i);\n }\n\n return (hash >>> 0).toString();\n};\n\nconst calculateOffset = function (vttCCs, cc, presentationTime) {\n let currCC = vttCCs[cc];\n let prevCC = vttCCs[currCC.prevCC];\n\n // This is the first discontinuity or cues have been processed since the last discontinuity\n // Offset = current discontinuity time\n if (!prevCC || (!prevCC.new && currCC.new)) {\n vttCCs.ccOffset = vttCCs.presentationOffset = currCC.start;\n currCC.new = false;\n return;\n }\n\n // There have been discontinuities since cues were last parsed.\n // Offset = time elapsed\n while (prevCC && prevCC.new) {\n vttCCs.ccOffset += currCC.start - prevCC.start;\n currCC.new = false;\n currCC = prevCC;\n prevCC = vttCCs[currCC.prevCC];\n }\n\n vttCCs.presentationOffset = presentationTime;\n};\n\nconst WebVTTParser = {\n parse: function (vttByteArray, syncPTS, vttCCs, cc, callBack, errorCallBack) {\n // Convert byteArray into string, replacing any somewhat exotic linefeeds with \"\\n\", then split on that character.\n let re = /\\r\\n|\\n\\r|\\n|\\r/g;\n // Uint8Array.prototype.reduce is not implemented in IE11\n let vttLines = utf8ArrayToStr(new Uint8Array(vttByteArray)).trim().replace(re, '\\n').split('\\n');\n\n let cueTime = '00:00.000';\n let mpegTs = 0;\n let localTime = 0;\n let presentationTime = 0;\n let cues = [];\n let parsingError;\n let inHeader = true;\n let timestampMap = false;\n // let VTTCue = VTTCue || window.TextTrackCue;\n\n // Create parser object using VTTCue with TextTrackCue fallback on certain browsers.\n let parser = new VTTParser();\n\n parser.oncue = function (cue) {\n // Adjust cue timing; clamp cues to start no earlier than - and drop cues that don't end after - 0 on timeline.\n let currCC = vttCCs[cc];\n let cueOffset = vttCCs.ccOffset;\n\n // Update offsets for new discontinuities\n if (currCC && currCC.new) {\n if (localTime !== undefined) {\n // When local time is provided, offset = discontinuity start time - local time\n cueOffset = vttCCs.ccOffset = currCC.start;\n } else {\n calculateOffset(vttCCs, cc, presentationTime);\n }\n }\n\n if (presentationTime) {\n // If we have MPEGTS, offset = presentation time + discontinuity offset\n cueOffset = presentationTime - vttCCs.presentationOffset;\n }\n\n if (timestampMap) {\n cue.startTime += cueOffset - localTime;\n cue.endTime += cueOffset - localTime;\n }\n\n // Create a unique hash id for a cue based on start/end times and text.\n // This helps timeline-controller to avoid showing repeated captions.\n cue.id = hash(cue.startTime.toString()) + hash(cue.endTime.toString()) + hash(cue.text);\n\n // Fix encoding of special characters. TODO: Test with all sorts of weird characters.\n cue.text = decodeURIComponent(encodeURIComponent(cue.text));\n if (cue.endTime > 0) {\n cues.push(cue);\n }\n };\n\n parser.onparsingerror = function (e) {\n parsingError = e;\n };\n\n parser.onflush = function () {\n if (parsingError && errorCallBack) {\n errorCallBack(parsingError);\n return;\n }\n callBack(cues);\n };\n\n // Go through contents line by line.\n vttLines.forEach(line => {\n if (inHeader) {\n // Look for X-TIMESTAMP-MAP in header.\n if (startsWith(line, 'X-TIMESTAMP-MAP=')) {\n // Once found, no more are allowed anyway, so stop searching.\n inHeader = false;\n timestampMap = true;\n // Extract LOCAL and MPEGTS.\n line.substr(16).split(',').forEach(timestamp => {\n if (startsWith(timestamp, 'LOCAL:')) {\n cueTime = timestamp.substr(6);\n } else if (startsWith(timestamp, 'MPEGTS:')) {\n mpegTs = parseInt(timestamp.substr(7));\n }\n });\n try {\n // Calculate subtitle offset in milliseconds.\n if (syncPTS + ((vttCCs[cc].start * 90000) || 0) < 0) {\n syncPTS += 8589934592;\n }\n // Adjust MPEGTS by sync PTS.\n mpegTs -= syncPTS;\n // Convert cue time to seconds\n localTime = cueString2millis(cueTime) / 1000;\n // Convert MPEGTS to seconds from 90kHz.\n presentationTime = mpegTs / 90000;\n } catch (e) {\n timestampMap = false;\n parsingError = e;\n }\n // Return without parsing X-TIMESTAMP-MAP line.\n return;\n } else if (line === '') {\n inHeader = false;\n }\n }\n // Parse line by default.\n parser.parse(line + '\\n');\n });\n\n parser.flush();\n }\n};\n\nexport default WebVTTParser;\n","import Event from '../events';\nimport EventHandler from '../event-handler';\nimport Cea608Parser, { CaptionScreen } from '../utils/cea-608-parser';\nimport OutputFilter from '../utils/output-filter';\nimport WebVTTParser from '../utils/webvtt-parser';\nimport { logger } from '../utils/logger';\nimport { sendAddTrackEvent, clearCurrentCues } from '../utils/texttrack-utils';\nimport Fragment from '../loader/fragment';\nimport { HlsConfig } from '../config';\nimport { CuesInterface } from '../utils/cues';\nimport { MediaPlaylist } from '../types/media-playlist';\n\ntype TrackProperties = {\n label: string,\n languageCode: string,\n media?: MediaPlaylist\n};\n\ntype NonNativeCaptionsTrack = {\n _id?: string,\n label: string,\n kind: string,\n default: boolean,\n closedCaptions?: MediaPlaylist,\n subtitleTrack?: MediaPlaylist\n};\n\ntype VTTCCs = {\n ccOffset: number,\n presentationOffset: number,\n [key: number]: {\n start: number,\n prevCC: number,\n new: boolean\n }\n};\n\nclass TimelineController extends EventHandler {\n private media: HTMLMediaElement | null = null;\n private config: HlsConfig;\n private enabled: boolean = true;\n private Cues: CuesInterface;\n private textTracks: Array<TextTrack> = [];\n private tracks: Array<MediaPlaylist> = [];\n private initPTS: Array<number> = [];\n private unparsedVttFrags: Array<{ frag: Fragment, payload: ArrayBuffer }> = [];\n private captionsTracks: Record<string, TextTrack> = {};\n private nonNativeCaptionsTracks: Record<string, NonNativeCaptionsTrack> = {};\n private captionsProperties: {\n textTrack1: TrackProperties\n textTrack2: TrackProperties\n textTrack3: TrackProperties\n textTrack4: TrackProperties\n };\n private readonly cea608Parser1!: Cea608Parser;\n private readonly cea608Parser2!: Cea608Parser;\n private lastSn: number = -1;\n private prevCC: number = -1;\n private vttCCs: VTTCCs = newVTTCCs();\n\n constructor (hls) {\n super(hls,\n Event.MEDIA_ATTACHING,\n Event.MEDIA_DETACHING,\n Event.FRAG_PARSING_USERDATA,\n Event.FRAG_DECRYPTED,\n Event.MANIFEST_LOADING,\n Event.MANIFEST_LOADED,\n Event.FRAG_LOADED,\n Event.INIT_PTS_FOUND);\n\n this.hls = hls;\n this.config = hls.config;\n this.Cues = hls.config.cueHandler;\n\n this.captionsProperties = {\n textTrack1: {\n label: this.config.captionsTextTrack1Label,\n languageCode: this.config.captionsTextTrack1LanguageCode\n },\n textTrack2: {\n label: this.config.captionsTextTrack2Label,\n languageCode: this.config.captionsTextTrack2LanguageCode\n },\n textTrack3: {\n label: this.config.captionsTextTrack3Label,\n languageCode: this.config.captionsTextTrack3LanguageCode\n },\n textTrack4: {\n label: this.config.captionsTextTrack4Label,\n languageCode: this.config.captionsTextTrack4LanguageCode\n }\n };\n\n if (this.config.enableCEA708Captions) {\n const channel1 = new OutputFilter(this, 'textTrack1');\n const channel2 = new OutputFilter(this, 'textTrack2');\n const channel3 = new OutputFilter(this, 'textTrack3');\n const channel4 = new OutputFilter(this, 'textTrack4');\n this.cea608Parser1 = new Cea608Parser(1, channel1, channel2);\n this.cea608Parser2 = new Cea608Parser(3, channel3, channel4);\n }\n }\n\n addCues (trackName: string, startTime: number, endTime: number, screen: CaptionScreen, cueRanges: Array<[number, number]>) {\n // skip cues which overlap more than 50% with previously parsed time ranges\n let merged = false;\n for (let i = cueRanges.length; i--;) {\n let cueRange = cueRanges[i];\n let overlap = intersection(cueRange[0], cueRange[1], startTime, endTime);\n if (overlap >= 0) {\n cueRange[0] = Math.min(cueRange[0], startTime);\n cueRange[1] = Math.max(cueRange[1], endTime);\n merged = true;\n if ((overlap / (endTime - startTime)) > 0.5) {\n return;\n }\n }\n }\n if (!merged) {\n cueRanges.push([startTime, endTime]);\n }\n\n if (this.config.renderTextTracksNatively) {\n this.Cues.newCue(this.captionsTracks[trackName], startTime, endTime, screen);\n } else {\n const cues = this.Cues.newCue(null, startTime, endTime, screen);\n this.hls.trigger(Event.CUES_PARSED, { type: 'captions', cues, track: trackName });\n }\n }\n\n // Triggered when an initial PTS is found; used for synchronisation of WebVTT.\n onInitPtsFound (data: { id: string, frag: Fragment, initPTS: number}) {\n const { frag, id, initPTS } = data;\n const { unparsedVttFrags } = this;\n if (id === 'main') {\n this.initPTS[frag.cc] = initPTS;\n }\n\n // Due to asynchronous processing, initial PTS may arrive later than the first VTT fragments are loaded.\n // Parse any unparsed fragments upon receiving the initial PTS.\n if (unparsedVttFrags.length) {\n this.unparsedVttFrags = [];\n unparsedVttFrags.forEach(frag => {\n this.onFragLoaded(frag);\n });\n }\n }\n\n getExistingTrack (trackName: string): TextTrack | null {\n const { media } = this;\n if (media) {\n for (let i = 0; i < media.textTracks.length; i++) {\n let textTrack = media.textTracks[i];\n if (textTrack[trackName]) {\n return textTrack;\n }\n }\n }\n return null;\n }\n\n createCaptionsTrack (trackName: string) {\n if (this.config.renderTextTracksNatively) {\n this.createNativeTrack(trackName);\n } else {\n this.createNonNativeTrack(trackName);\n }\n }\n\n createNativeTrack (trackName: string) {\n if (this.captionsTracks[trackName]) {\n return;\n }\n const { captionsProperties, captionsTracks, media } = this;\n const { label, languageCode } = captionsProperties[trackName];\n // Enable reuse of existing text track.\n const existingTrack = this.getExistingTrack(trackName);\n if (!existingTrack) {\n const textTrack = this.createTextTrack('captions', label, languageCode);\n if (textTrack) {\n // Set a special property on the track so we know it's managed by Hls.js\n textTrack[trackName] = true;\n captionsTracks[trackName] = textTrack;\n }\n } else {\n captionsTracks[trackName] = existingTrack;\n clearCurrentCues(captionsTracks[trackName]);\n sendAddTrackEvent(captionsTracks[trackName], media as HTMLMediaElement);\n }\n }\n\n createNonNativeTrack (trackName: string) {\n if (this.nonNativeCaptionsTracks[trackName]) {\n return;\n }\n // Create a list of a single track for the provider to consume\n const trackProperties: TrackProperties = this.captionsProperties[trackName];\n if (!trackProperties) {\n return;\n }\n const label = trackProperties.label as string;\n const track = {\n _id: trackName,\n label,\n kind: 'captions',\n default: trackProperties.media ? !!trackProperties.media.default : false,\n closedCaptions: trackProperties.media\n };\n this.nonNativeCaptionsTracks[trackName] = track;\n this.hls.trigger(Event.NON_NATIVE_TEXT_TRACKS_FOUND, { tracks: [track] });\n }\n createTextTrack (kind: TextTrackKind, label: string, lang?: string): TextTrack | undefined {\n const media = this.media;\n if (!media) {\n return;\n }\n return media.addTextTrack(kind, label, lang);\n }\n\n destroy () {\n super.destroy();\n }\n\n onMediaAttaching (data: { media: HTMLMediaElement }) {\n this.media = data.media;\n this._cleanTracks();\n }\n\n onMediaDetaching () {\n const { captionsTracks } = this;\n Object.keys(captionsTracks).forEach(trackName => {\n clearCurrentCues(captionsTracks[trackName]);\n delete captionsTracks[trackName];\n });\n this.nonNativeCaptionsTracks = {};\n }\n\n onManifestLoading () {\n this.lastSn = -1; // Detect discontiguity in fragment parsing\n this.prevCC = -1;\n this.vttCCs = newVTTCCs(); // Detect discontinuity in subtitle manifests\n this._cleanTracks();\n this.tracks = [];\n this.captionsTracks = {};\n this.nonNativeCaptionsTracks = {};\n }\n\n _cleanTracks () {\n // clear outdated subtitles\n const { media } = this;\n if (!media) {\n return;\n }\n const textTracks = media.textTracks;\n if (textTracks) {\n for (let i = 0; i < textTracks.length; i++) {\n clearCurrentCues(textTracks[i]);\n }\n }\n }\n\n onManifestLoaded (data: { subtitles: Array<MediaPlaylist>, captions: Array<MediaPlaylist> }) {\n this.textTracks = [];\n this.unparsedVttFrags = this.unparsedVttFrags || [];\n this.initPTS = [];\n if (this.cea608Parser1 && this.cea608Parser2) {\n this.cea608Parser1.reset();\n this.cea608Parser2.reset();\n }\n\n if (this.config.enableWebVTT) {\n const tracks = data.subtitles || [];\n const sameTracks = this.tracks && tracks && this.tracks.length === tracks.length;\n this.tracks = data.subtitles || [];\n\n if (this.config.renderTextTracksNatively) {\n const inUseTracks = this.media ? this.media.textTracks : [];\n\n this.tracks.forEach((track, index) => {\n let textTrack;\n if (index < inUseTracks.length) {\n let inUseTrack: TextTrack | null = null;\n\n for (let i = 0; i < inUseTracks.length; i++) {\n if (canReuseVttTextTrack(inUseTracks[i], track)) {\n inUseTrack = inUseTracks[i];\n break;\n }\n }\n\n // Reuse tracks with the same label, but do not reuse 608/708 tracks\n if (inUseTrack) {\n textTrack = inUseTrack;\n }\n }\n if (!textTrack) {\n textTrack = this.createTextTrack('subtitles', track.name, track.lang);\n }\n\n if (track.default) {\n textTrack.mode = this.hls.subtitleDisplay ? 'showing' : 'hidden';\n } else {\n textTrack.mode = 'disabled';\n }\n\n this.textTracks.push(textTrack);\n });\n } else if (!sameTracks && this.tracks && this.tracks.length) {\n // Create a list of tracks for the provider to consume\n const tracksList = this.tracks.map((track) => {\n return {\n label: track.name,\n kind: track.type.toLowerCase(),\n default: track.default,\n subtitleTrack: track\n };\n });\n this.hls.trigger(Event.NON_NATIVE_TEXT_TRACKS_FOUND, { tracks: tracksList });\n }\n }\n\n if (this.config.enableCEA708Captions && data.captions) {\n data.captions.forEach(captionsTrack => {\n const instreamIdMatch = /(?:CC|SERVICE)([1-4])/.exec(captionsTrack.instreamId as string);\n if (!instreamIdMatch) {\n return;\n }\n const trackName = `textTrack${instreamIdMatch[1]}`;\n const trackProperties: TrackProperties = this.captionsProperties[trackName];\n if (!trackProperties) {\n return;\n }\n trackProperties.label = captionsTrack.name;\n if (captionsTrack.lang) { // optional attribute\n trackProperties.languageCode = captionsTrack.lang;\n }\n trackProperties.media = captionsTrack;\n });\n }\n }\n\n onFragLoaded (data: { frag: Fragment, payload: ArrayBuffer }) {\n const { frag, payload } = data;\n const { cea608Parser1, cea608Parser2, initPTS, lastSn, unparsedVttFrags } = this;\n if (frag.type === 'main') {\n const sn = frag.sn;\n // if this frag isn't contiguous, clear the parser so cues with bad start/end times aren't added to the textTrack\n if (frag.sn !== lastSn + 1) {\n if (cea608Parser1 && cea608Parser2) {\n cea608Parser1.reset();\n cea608Parser2.reset();\n }\n }\n this.lastSn = sn as number;\n } // eslint-disable-line brace-style\n // If fragment is subtitle type, parse as WebVTT.\n else if (frag.type === 'subtitle') {\n if (payload.byteLength) {\n // We need an initial synchronisation PTS. Store fragments as long as none has arrived.\n if (!Number.isFinite(initPTS[frag.cc])) {\n unparsedVttFrags.push(data);\n if (initPTS.length) {\n // finish unsuccessfully, otherwise the subtitle-stream-controller could be blocked from loading new frags.\n this.hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: false, frag });\n }\n return;\n }\n\n let decryptData = frag.decryptdata;\n // If the subtitles are not encrypted, parse VTTs now. Otherwise, we need to wait.\n if ((decryptData == null) || (decryptData.key == null) || (decryptData.method !== 'AES-128')) {\n this._parseVTTs(frag, payload);\n }\n } else {\n // In case there is no payload, finish unsuccessfully.\n this.hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: false, frag });\n }\n }\n }\n\n _parseVTTs (frag: Fragment, payload: ArrayBuffer) {\n const { hls, prevCC, textTracks, vttCCs } = this;\n if (!vttCCs[frag.cc]) {\n vttCCs[frag.cc] = { start: frag.start, prevCC, new: true };\n this.prevCC = frag.cc;\n }\n // Parse the WebVTT file contents.\n WebVTTParser.parse(payload, this.initPTS[frag.cc], vttCCs, frag.cc, (cues) => {\n if (this.config.renderTextTracksNatively) {\n const currentTrack = textTracks[frag.level];\n // WebVTTParser.parse is an async method and if the currently selected text track mode is set to \"disabled\"\n // before parsing is done then don't try to access currentTrack.cues.getCueById as cues will be null\n // and trying to access getCueById method of cues will throw an exception\n // Because we check if the mode is diabled, we can force check `cues` below. They can't be null.\n if (currentTrack.mode === 'disabled') {\n hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: false, frag: frag });\n return;\n }\n\n // Add cues and trigger event with success true.\n cues.forEach(cue => {\n // Sometimes there are cue overlaps on segmented vtts so the same\n // cue can appear more than once in different vtt files.\n // This avoid showing duplicated cues with same timecode and text.\n if (!currentTrack.cues!.getCueById(cue.id)) {\n try {\n currentTrack.addCue(cue);\n if (!currentTrack.cues!.getCueById(cue.id)) {\n throw new Error(`addCue is failed for: ${cue}`);\n }\n } catch (err) {\n logger.debug(`Failed occurred on adding cues: ${err}`);\n const textTrackCue = new (window as any).TextTrackCue(cue.startTime, cue.endTime, cue.text);\n textTrackCue.id = cue.id;\n currentTrack.addCue(textTrackCue);\n }\n }\n });\n } else {\n let trackId = this.tracks[frag.level].default ? 'default' : 'subtitles' + frag.level;\n hls.trigger(Event.CUES_PARSED, { type: 'subtitles', cues: cues, track: trackId });\n }\n hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: true, frag: frag });\n },\n function (e) {\n // Something went wrong while parsing. Trigger event with success false.\n logger.log(`Failed to parse VTT cue: ${e}`);\n hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: false, frag: frag });\n });\n }\n\n onFragDecrypted (data: { frag: Fragment, payload: any}) {\n const { frag, payload } = data;\n if (frag.type === 'subtitle') {\n if (!Number.isFinite(this.initPTS[frag.cc])) {\n this.unparsedVttFrags.push(data);\n return;\n }\n\n this._parseVTTs(frag, payload);\n }\n }\n\n onFragParsingUserdata (data: { samples: Array<any> }) {\n const { cea608Parser1, cea608Parser2 } = this;\n if (!this.enabled || !(cea608Parser1 && cea608Parser2)) {\n return;\n }\n\n // If the event contains captions (found in the bytes property), push all bytes into the parser immediately\n // It will create the proper timestamps based on the PTS value\n for (let i = 0; i < data.samples.length; i++) {\n const ccBytes = data.samples[i].bytes;\n if (ccBytes) {\n const ccdatas = this.extractCea608Data(ccBytes);\n cea608Parser1.addData(data.samples[i].pts, ccdatas[0]);\n cea608Parser2.addData(data.samples[i].pts, ccdatas[1]);\n }\n }\n }\n\n extractCea608Data (byteArray: Uint8Array): number[][] {\n const count = byteArray[0] & 31;\n let position = 2;\n const actualCCBytes: number[][] = [[], []];\n\n for (let j = 0; j < count; j++) {\n const tmpByte = byteArray[position++];\n const ccbyte1 = 0x7F & byteArray[position++];\n const ccbyte2 = 0x7F & byteArray[position++];\n const ccValid = (4 & tmpByte) !== 0;\n const ccType = 3 & tmpByte;\n\n if (ccbyte1 === 0 && ccbyte2 === 0) {\n continue;\n }\n\n if (ccValid) {\n if (ccType === 0 || ccType === 1) {\n actualCCBytes[ccType].push(ccbyte1);\n actualCCBytes[ccType].push(ccbyte2);\n }\n }\n }\n return actualCCBytes;\n }\n}\n\nfunction canReuseVttTextTrack (inUseTrack, manifestTrack): boolean {\n return inUseTrack && inUseTrack.label === manifestTrack.name && !(inUseTrack.textTrack1 || inUseTrack.textTrack2);\n}\n\nfunction intersection (x1: number, x2: number, y1: number, y2: number): number {\n return Math.min(x2, y2) - Math.max(x1, y1);\n}\n\nfunction newVTTCCs (): VTTCCs {\n return {\n ccOffset: 0,\n presentationOffset: 0,\n 0: {\n start: 0,\n prevCC: -1,\n new: false\n }\n };\n}\n\nexport default TimelineController;\n","import Event from '../events';\nimport EventHandler from '../event-handler';\nimport { logger } from '../utils/logger';\nimport { computeReloadInterval } from './level-helper';\nimport { clearCurrentCues } from '../utils/texttrack-utils';\n\nclass SubtitleTrackController extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.MANIFEST_LOADED,\n Event.SUBTITLE_TRACK_LOADED);\n this.tracks = [];\n this.trackId = -1;\n this.media = null;\n this.stopped = true;\n\n /**\n * @member {boolean} subtitleDisplay Enable/disable subtitle display rendering\n */\n this.subtitleDisplay = true;\n\n /**\n * Keeps reference to a default track id when media has not been attached yet\n * @member {number}\n */\n this.queuedDefaultTrack = null;\n }\n\n destroy () {\n EventHandler.prototype.destroy.call(this);\n }\n\n // Listen for subtitle track change, then extract the current track ID.\n onMediaAttached (data) {\n this.media = data.media;\n if (!this.media) {\n return;\n }\n\n if (Number.isFinite(this.queuedDefaultTrack)) {\n this.subtitleTrack = this.queuedDefaultTrack;\n this.queuedDefaultTrack = null;\n }\n\n this.trackChangeListener = this._onTextTracksChanged.bind(this);\n\n this.useTextTrackPolling = !(this.media.textTracks && 'onchange' in this.media.textTracks);\n if (this.useTextTrackPolling) {\n this.subtitlePollingInterval = setInterval(() => {\n this.trackChangeListener();\n }, 500);\n } else {\n this.media.textTracks.addEventListener('change', this.trackChangeListener);\n }\n }\n\n onMediaDetaching () {\n if (!this.media) {\n return;\n }\n\n if (this.useTextTrackPolling) {\n clearInterval(this.subtitlePollingInterval);\n } else {\n this.media.textTracks.removeEventListener('change', this.trackChangeListener);\n }\n\n if (Number.isFinite(this.subtitleTrack)) {\n this.queuedDefaultTrack = this.subtitleTrack;\n }\n\n const textTracks = filterSubtitleTracks(this.media.textTracks);\n // Clear loaded cues on media detachment from tracks\n textTracks.forEach((track) => {\n clearCurrentCues(track);\n });\n // Disable all subtitle tracks before detachment so when reattached only tracks in that content are enabled.\n this.subtitleTrack = -1;\n this.media = null;\n }\n\n // Fired whenever a new manifest is loaded.\n onManifestLoaded (data) {\n let tracks = data.subtitles || [];\n this.tracks = tracks;\n this.hls.trigger(Event.SUBTITLE_TRACKS_UPDATED, { subtitleTracks: tracks });\n\n // loop through available subtitle tracks and autoselect default if needed\n // TODO: improve selection logic to handle forced, etc\n tracks.forEach(track => {\n if (track.default) {\n // setting this.subtitleTrack will trigger internal logic\n // if media has not been attached yet, it will fail\n // we keep a reference to the default track id\n // and we'll set subtitleTrack when onMediaAttached is triggered\n if (this.media) {\n this.subtitleTrack = track.id;\n } else {\n this.queuedDefaultTrack = track.id;\n }\n }\n });\n }\n\n onSubtitleTrackLoaded (data) {\n const { id, details } = data;\n const { trackId, tracks } = this;\n const currentTrack = tracks[trackId];\n if (id >= tracks.length || id !== trackId || !currentTrack || this.stopped) {\n this._clearReloadTimer();\n return;\n }\n\n logger.log(`subtitle track ${id} loaded`);\n if (details.live) {\n const reloadInterval = computeReloadInterval(currentTrack.details, details, data.stats.trequest);\n logger.log(`Reloading live subtitle playlist in ${reloadInterval}ms`);\n this.timer = setTimeout(() => {\n this._loadCurrentTrack();\n }, reloadInterval);\n } else {\n this._clearReloadTimer();\n }\n }\n\n startLoad () {\n this.stopped = false;\n this._loadCurrentTrack();\n }\n\n stopLoad () {\n this.stopped = true;\n this._clearReloadTimer();\n }\n\n /** get alternate subtitle tracks list from playlist **/\n get subtitleTracks () {\n return this.tracks;\n }\n\n /** get index of the selected subtitle track (index in subtitle track lists) **/\n get subtitleTrack () {\n return this.trackId;\n }\n\n /** select a subtitle track, based on its index in subtitle track lists**/\n set subtitleTrack (subtitleTrackId) {\n if (this.trackId !== subtitleTrackId) {\n this._toggleTrackModes(subtitleTrackId);\n this._setSubtitleTrackInternal(subtitleTrackId);\n }\n }\n\n _clearReloadTimer () {\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n }\n\n _loadCurrentTrack () {\n const { trackId, tracks, hls } = this;\n const currentTrack = tracks[trackId];\n if (trackId < 0 || !currentTrack || (currentTrack.details && !currentTrack.details.live)) {\n return;\n }\n logger.log(`Loading subtitle track ${trackId}`);\n hls.trigger(Event.SUBTITLE_TRACK_LOADING, { url: currentTrack.url, id: trackId });\n }\n\n /**\n * Disables the old subtitleTrack and sets current mode on the next subtitleTrack.\n * This operates on the DOM textTracks.\n * A value of -1 will disable all subtitle tracks.\n * @param newId - The id of the next track to enable\n * @private\n */\n _toggleTrackModes (newId) {\n const { media, subtitleDisplay, trackId } = this;\n if (!media) {\n return;\n }\n\n const textTracks = filterSubtitleTracks(media.textTracks);\n if (newId === -1) {\n [].slice.call(textTracks).forEach(track => {\n track.mode = 'disabled';\n });\n } else {\n const oldTrack = textTracks[trackId];\n if (oldTrack) {\n oldTrack.mode = 'disabled';\n }\n }\n\n const nextTrack = textTracks[newId];\n if (nextTrack) {\n nextTrack.mode = subtitleDisplay ? 'showing' : 'hidden';\n }\n }\n\n /**\n * This method is responsible for validating the subtitle index and periodically reloading if live.\n * Dispatches the SUBTITLE_TRACK_SWITCH event, which instructs the subtitle-stream-controller to load the selected track.\n * @param newId - The id of the subtitle track to activate.\n */\n _setSubtitleTrackInternal (newId) {\n const { hls, tracks } = this;\n if (!Number.isFinite(newId) || newId < -1 || newId >= tracks.length) {\n return;\n }\n\n this.trackId = newId;\n logger.log(`Switching to subtitle track ${newId}`);\n hls.trigger(Event.SUBTITLE_TRACK_SWITCH, { id: newId });\n this._loadCurrentTrack();\n }\n\n _onTextTracksChanged () {\n // Media is undefined when switching streams via loadSource()\n if (!this.media || !this.hls.config.renderTextTracksNatively) {\n return;\n }\n\n let trackId = -1;\n let tracks = filterSubtitleTracks(this.media.textTracks);\n for (let id = 0; id < tracks.length; id++) {\n if (tracks[id].mode === 'hidden') {\n // Do not break in case there is a following track with showing.\n trackId = id;\n } else if (tracks[id].mode === 'showing') {\n trackId = id;\n break;\n }\n }\n\n // Setting current subtitleTrack will invoke code.\n this.subtitleTrack = trackId;\n }\n}\n\nfunction filterSubtitleTracks (textTrackList) {\n let tracks = [];\n for (let i = 0; i < textTrackList.length; i++) {\n const track = textTrackList[i];\n // Edge adds a track without a label; we don't want to use it\n if (track.kind === 'subtitles' && track.label) {\n tracks.push(textTrackList[i]);\n }\n }\n return tracks;\n}\n\nexport default SubtitleTrackController;\n","/**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Navigator/requestMediaKeySystemAccess\n */\nexport enum KeySystems {\n WIDEVINE = 'com.widevine.alpha',\n PLAYREADY = 'com.microsoft.playready',\n}\n\nexport type MediaKeyFunc = (keySystem: KeySystems, supportedConfigurations: MediaKeySystemConfiguration[]) => Promise<MediaKeySystemAccess>;\nconst requestMediaKeySystemAccess = (function (): MediaKeyFunc | null {\n if (typeof window !== 'undefined' && window.navigator && window.navigator.requestMediaKeySystemAccess) {\n return window.navigator.requestMediaKeySystemAccess.bind(window.navigator);\n } else {\n return null;\n }\n})();\n\nexport {\n requestMediaKeySystemAccess\n};\n","/**\n * @class SubtitleStreamController\n */\n\nimport Event from '../events';\nimport { logger } from '../utils/logger';\nimport Decrypter from '../crypt/decrypter';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport { findFragmentByPDT, findFragmentByPTS } from './fragment-finders';\nimport { FragmentState } from './fragment-tracker';\nimport BaseStreamController, { State } from './base-stream-controller';\nimport { mergeSubtitlePlaylists } from './level-helper';\n\nconst { performance } = window;\nconst TICK_INTERVAL = 500; // how often to tick in ms\n\nexport class SubtitleStreamController extends BaseStreamController {\n constructor (hls, fragmentTracker) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.ERROR,\n Event.KEY_LOADED,\n Event.FRAG_LOADED,\n Event.SUBTITLE_TRACKS_UPDATED,\n Event.SUBTITLE_TRACK_SWITCH,\n Event.SUBTITLE_TRACK_LOADED,\n Event.SUBTITLE_FRAG_PROCESSED,\n Event.LEVEL_UPDATED);\n\n this.fragmentTracker = fragmentTracker;\n this.config = hls.config;\n this.state = State.STOPPED;\n this.tracks = [];\n this.tracksBuffered = [];\n this.currentTrackId = -1;\n this.decrypter = new Decrypter(hls, hls.config);\n // lastAVStart stores the time in seconds for the start time of a level load\n this.lastAVStart = 0;\n this._onMediaSeeking = this.onMediaSeeking.bind(this);\n }\n\n startLoad () {\n this.stopLoad();\n this.state = State.IDLE;\n\n // Check if we already have a track with necessary details to load fragments\n const currentTrack = this.tracks[this.currentTrackId];\n if (currentTrack && currentTrack.details) {\n this.setInterval(TICK_INTERVAL);\n this.tick();\n }\n }\n\n onSubtitleFragProcessed (data) {\n const { frag, success } = data;\n this.fragPrevious = frag;\n this.state = State.IDLE;\n if (!success) {\n return;\n }\n\n const buffered = this.tracksBuffered[this.currentTrackId];\n if (!buffered) {\n return;\n }\n\n // Create/update a buffered array matching the interface used by BufferHelper.bufferedInfo\n // so we can re-use the logic used to detect how much have been buffered\n let timeRange;\n const fragStart = frag.start;\n for (let i = 0; i < buffered.length; i++) {\n if (fragStart >= buffered[i].start && fragStart <= buffered[i].end) {\n timeRange = buffered[i];\n break;\n }\n }\n\n const fragEnd = frag.start + frag.duration;\n if (timeRange) {\n timeRange.end = fragEnd;\n } else {\n timeRange = {\n start: fragStart,\n end: fragEnd\n };\n buffered.push(timeRange);\n }\n }\n\n onMediaAttached ({ media }) {\n this.media = media;\n media.addEventListener('seeking', this._onMediaSeeking);\n this.state = State.IDLE;\n }\n\n onMediaDetaching () {\n if (!this.media) {\n return;\n }\n this.media.removeEventListener('seeking', this._onMediaSeeking);\n this.fragmentTracker.removeAllFragments();\n this.currentTrackId = -1;\n this.tracks.forEach((track) => {\n this.tracksBuffered[track.id] = [];\n });\n this.media = null;\n this.state = State.STOPPED;\n }\n\n // If something goes wrong, proceed to next frag, if we were processing one.\n onError (data) {\n let frag = data.frag;\n // don't handle error not related to subtitle fragment\n if (!frag || frag.type !== 'subtitle') {\n return;\n }\n\n if (this.fragCurrent && this.fragCurrent.loader) {\n this.fragCurrent.loader.abort();\n }\n\n this.state = State.IDLE;\n }\n\n // Got all new subtitle tracks.\n onSubtitleTracksUpdated (data) {\n logger.log('subtitle tracks updated');\n this.tracksBuffered = [];\n this.tracks = data.subtitleTracks;\n this.tracks.forEach((track) => {\n this.tracksBuffered[track.id] = [];\n });\n }\n\n onSubtitleTrackSwitch (data) {\n this.currentTrackId = data.id;\n\n if (!this.tracks || !this.tracks.length || this.currentTrackId === -1) {\n this.clearInterval();\n return;\n }\n\n // Check if track has the necessary details to load fragments\n const currentTrack = this.tracks[this.currentTrackId];\n if (currentTrack && currentTrack.details) {\n this.setInterval(TICK_INTERVAL);\n }\n }\n\n // Got a new set of subtitle fragments.\n onSubtitleTrackLoaded (data) {\n const { id, details } = data;\n const { currentTrackId, tracks } = this;\n const currentTrack = tracks[currentTrackId];\n if (id >= tracks.length || id !== currentTrackId || !currentTrack) {\n return;\n }\n\n if (details.live) {\n mergeSubtitlePlaylists(currentTrack.details, details, this.lastAVStart);\n }\n currentTrack.details = details;\n this.setInterval(TICK_INTERVAL);\n }\n\n onKeyLoaded () {\n if (this.state === State.KEY_LOADING) {\n this.state = State.IDLE;\n }\n }\n\n onFragLoaded (data) {\n const fragCurrent = this.fragCurrent;\n const decryptData = data.frag.decryptdata;\n const fragLoaded = data.frag;\n const hls = this.hls;\n\n if (this.state === State.FRAG_LOADING &&\n fragCurrent &&\n data.frag.type === 'subtitle' &&\n fragCurrent.sn === data.frag.sn) {\n // check to see if the payload needs to be decrypted\n if (data.payload.byteLength > 0 && (decryptData && decryptData.key && decryptData.method === 'AES-128')) {\n let startTime = performance.now();\n\n // decrypt the subtitles\n this.decrypter.decrypt(data.payload, decryptData.key.buffer, decryptData.iv.buffer, function (decryptedData) {\n let endTime = performance.now();\n hls.trigger(Event.FRAG_DECRYPTED, { frag: fragLoaded, payload: decryptedData, stats: { tstart: startTime, tdecrypt: endTime } });\n });\n }\n }\n }\n\n onLevelUpdated ({ details }) {\n const frags = details.fragments;\n this.lastAVStart = frags.length ? frags[0].start : 0;\n }\n\n doTick () {\n if (!this.media) {\n this.state = State.IDLE;\n return;\n }\n\n switch (this.state) {\n case State.IDLE: {\n const { config, currentTrackId, fragmentTracker, media, tracks } = this;\n if (!tracks || !tracks[currentTrackId] || !tracks[currentTrackId].details) {\n break;\n }\n\n const { maxBufferHole, maxFragLookUpTolerance } = config;\n const maxConfigBuffer = Math.min(config.maxBufferLength, config.maxMaxBufferLength);\n const bufferedInfo = BufferHelper.bufferedInfo(this._getBuffered(), media.currentTime, maxBufferHole);\n const { end: bufferEnd, len: bufferLen } = bufferedInfo;\n\n const trackDetails = tracks[currentTrackId].details;\n const fragments = trackDetails.fragments;\n const fragLen = fragments.length;\n const end = fragments[fragLen - 1].start + fragments[fragLen - 1].duration;\n\n if (bufferLen > maxConfigBuffer) {\n return;\n }\n\n let foundFrag;\n const fragPrevious = this.fragPrevious;\n if (bufferEnd < end) {\n if (fragPrevious && trackDetails.hasProgramDateTime) {\n foundFrag = findFragmentByPDT(fragments, fragPrevious.endProgramDateTime, maxFragLookUpTolerance);\n }\n if (!foundFrag) {\n foundFrag = findFragmentByPTS(fragPrevious, fragments, bufferEnd, maxFragLookUpTolerance);\n }\n } else {\n foundFrag = fragments[fragLen - 1];\n }\n\n if (foundFrag && foundFrag.encrypted) {\n logger.log(`Loading key for ${foundFrag.sn}`);\n this.state = State.KEY_LOADING;\n this.hls.trigger(Event.KEY_LOADING, { frag: foundFrag });\n } else if (foundFrag && fragmentTracker.getState(foundFrag) === FragmentState.NOT_LOADED) {\n // only load if fragment is not loaded\n this.fragCurrent = foundFrag;\n this.state = State.FRAG_LOADING;\n this.hls.trigger(Event.FRAG_LOADING, { frag: foundFrag });\n }\n }\n }\n }\n\n stopLoad () {\n this.lastAVStart = 0;\n this.fragPrevious = null;\n super.stopLoad();\n }\n\n _getBuffered () {\n return this.tracksBuffered[this.currentTrackId] || [];\n }\n\n onMediaSeeking () {\n if (this.fragCurrent) {\n const currentTime = this.media ? this.media.currentTime : 0;\n const tolerance = this.config.maxFragLookUpTolerance;\n const fragStartOffset = this.fragCurrent.start - tolerance;\n const fragEndOffset = this.fragCurrent.start + this.fragCurrent.duration + tolerance;\n\n // check if position will be out of currently loaded frag range after seeking : if out, cancel frag load, if in, don't do anything\n if (currentTime < fragStartOffset || currentTime > fragEndOffset) {\n if (this.fragCurrent.loader) {\n this.fragCurrent.loader.abort();\n }\n\n this.fragmentTracker.removeFragment(this.fragCurrent);\n this.fragCurrent = null;\n this.fragPrevious = null;\n\n // switch to IDLE state to load new fragment\n this.state = State.IDLE;\n\n // speed up things\n this.tick();\n }\n }\n }\n}\n","/**\n * @author Stephan Hesse <disparat@gmail.com> | <tchakabam@gmail.com>\n *\n * DRM support for Hls.js\n */\n\nimport EventHandler from '../event-handler';\nimport Event from '../events';\nimport { ErrorTypes, ErrorDetails } from '../errors';\n\nimport { logger } from '../utils/logger';\nimport { DRMSystemOptions, EMEControllerConfig } from '../config';\nimport { KeySystems, MediaKeyFunc } from '../utils/mediakeys-helper';\n\nconst MAX_LICENSE_REQUEST_FAILURES = 3;\n\n/**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/MediaKeySystemConfiguration\n * @param {Array<string>} audioCodecs List of required audio codecs to support\n * @param {Array<string>} videoCodecs List of required video codecs to support\n * @param {object} drmSystemOptions Optional parameters/requirements for the key-system\n * @returns {Array<MediaSystemConfiguration>} An array of supported configurations\n */\n\nconst createWidevineMediaKeySystemConfigurations = function (\n audioCodecs: string[],\n videoCodecs: string[],\n drmSystemOptions: DRMSystemOptions\n): MediaKeySystemConfiguration[] { /* jshint ignore:line */\n const baseConfig: MediaKeySystemConfiguration = {\n // initDataTypes: ['keyids', 'mp4'],\n // label: \"\",\n // persistentState: \"not-allowed\", // or \"required\" ?\n // distinctiveIdentifier: \"not-allowed\", // or \"required\" ?\n // sessionTypes: ['temporary'],\n audioCapabilities: [], // { contentType: 'audio/mp4; codecs=\"mp4a.40.2\"' }\n videoCapabilities: [] // { contentType: 'video/mp4; codecs=\"avc1.42E01E\"' }\n };\n\n audioCodecs.forEach((codec) => {\n baseConfig.audioCapabilities!.push({\n contentType: `audio/mp4; codecs=\"${codec}\"`,\n robustness: drmSystemOptions.audioRobustness || ''\n });\n });\n videoCodecs.forEach((codec) => {\n baseConfig.videoCapabilities!.push({\n contentType: `video/mp4; codecs=\"${codec}\"`,\n robustness: drmSystemOptions.videoRobustness || ''\n });\n });\n\n return [\n baseConfig\n ];\n};\n\n/**\n * The idea here is to handle key-system (and their respective platforms) specific configuration differences\n * in order to work with the local requestMediaKeySystemAccess method.\n *\n * We can also rule-out platform-related key-system support at this point by throwing an error.\n *\n * @param {string} keySystem Identifier for the key-system, see `KeySystems` enum\n * @param {Array<string>} audioCodecs List of required audio codecs to support\n * @param {Array<string>} videoCodecs List of required video codecs to support\n * @throws will throw an error if a unknown key system is passed\n * @returns {Array<MediaSystemConfiguration>} A non-empty Array of MediaKeySystemConfiguration objects\n */\nconst getSupportedMediaKeySystemConfigurations = function (\n keySystem: KeySystems,\n audioCodecs: string[],\n videoCodecs: string[],\n drmSystemOptions: DRMSystemOptions\n): MediaKeySystemConfiguration[] {\n switch (keySystem) {\n case KeySystems.WIDEVINE:\n return createWidevineMediaKeySystemConfigurations(audioCodecs, videoCodecs, drmSystemOptions);\n default:\n throw new Error(`Unknown key-system: ${keySystem}`);\n }\n};\n\ninterface MediaKeysListItem {\n mediaKeys?: MediaKeys,\n mediaKeysSession?: MediaKeySession,\n mediaKeysSessionInitialized: boolean;\n mediaKeySystemAccess: MediaKeySystemAccess;\n mediaKeySystemDomain: KeySystems;\n}\n\n/**\n * Controller to deal with encrypted media extensions (EME)\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Encrypted_Media_Extensions_API\n *\n * @class\n * @constructor\n */\nclass EMEController extends EventHandler {\n private _widevineLicenseUrl?: string;\n private _licenseXhrSetup?: (xhr: XMLHttpRequest, url: string) => void;\n private _emeEnabled: boolean;\n private _requestMediaKeySystemAccess: MediaKeyFunc | null;\n private _drmSystemOptions: DRMSystemOptions;\n\n private _config: EMEControllerConfig;\n private _mediaKeysList: MediaKeysListItem[] = [];\n private _media: HTMLMediaElement | null = null;\n private _hasSetMediaKeys: boolean = false;\n private _requestLicenseFailureCount: number = 0;\n\n private mediaKeysPromise: Promise<MediaKeys> | null = null;\n\n /**\n * @constructs\n * @param {Hls} hls Our Hls.js instance\n */\n constructor (hls) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHED,\n Event.MANIFEST_PARSED\n );\n this._config = hls.config;\n\n this._widevineLicenseUrl = this._config.widevineLicenseUrl;\n this._licenseXhrSetup = this._config.licenseXhrSetup;\n this._emeEnabled = this._config.emeEnabled;\n this._requestMediaKeySystemAccess = this._config.requestMediaKeySystemAccessFunc;\n this._drmSystemOptions = hls.config.drmSystemOptions;\n }\n\n /**\n * @param {string} keySystem Identifier for the key-system, see `KeySystems` enum\n * @returns {string} License server URL for key-system (if any configured, otherwise causes error)\n * @throws if a unsupported keysystem is passed\n */\n getLicenseServerUrl (keySystem: KeySystems): string {\n switch (keySystem) {\n case KeySystems.WIDEVINE:\n if (!this._widevineLicenseUrl) {\n break;\n }\n return this._widevineLicenseUrl;\n }\n\n throw new Error(`no license server URL configured for key-system \"${keySystem}\"`);\n }\n\n /**\n * Requests access object and adds it to our list upon success\n * @private\n * @param {string} keySystem System ID (see `KeySystems`)\n * @param {Array<string>} audioCodecs List of required audio codecs to support\n * @param {Array<string>} videoCodecs List of required video codecs to support\n * @throws When a unsupported KeySystem is passed\n */\n private _attemptKeySystemAccess (keySystem: KeySystems, audioCodecs: string[], videoCodecs: string[]) {\n // This can throw, but is caught in event handler callpath\n const mediaKeySystemConfigs = getSupportedMediaKeySystemConfigurations(keySystem, audioCodecs, videoCodecs, this._drmSystemOptions);\n\n logger.log('Requesting encrypted media key-system access');\n\n // expecting interface like window.navigator.requestMediaKeySystemAccess\n const keySystemAccessPromise = this.requestMediaKeySystemAccess(keySystem, mediaKeySystemConfigs);\n\n this.mediaKeysPromise = keySystemAccessPromise.then((mediaKeySystemAccess) =>\n this._onMediaKeySystemAccessObtained(keySystem, mediaKeySystemAccess));\n\n keySystemAccessPromise.catch((err) => {\n logger.error(`Failed to obtain key-system \"${keySystem}\" access:`, err);\n });\n }\n\n get requestMediaKeySystemAccess () {\n if (!this._requestMediaKeySystemAccess) {\n throw new Error('No requestMediaKeySystemAccess function configured');\n }\n\n return this._requestMediaKeySystemAccess;\n }\n\n /**\n * Handles obtaining access to a key-system\n * @private\n * @param {string} keySystem\n * @param {MediaKeySystemAccess} mediaKeySystemAccess https://developer.mozilla.org/en-US/docs/Web/API/MediaKeySystemAccess\n */\n private _onMediaKeySystemAccessObtained (keySystem: KeySystems, mediaKeySystemAccess: MediaKeySystemAccess): Promise<MediaKeys> {\n logger.log(`Access for key-system \"${keySystem}\" obtained`);\n\n const mediaKeysListItem: MediaKeysListItem = {\n mediaKeysSessionInitialized: false,\n mediaKeySystemAccess: mediaKeySystemAccess,\n mediaKeySystemDomain: keySystem\n };\n\n this._mediaKeysList.push(mediaKeysListItem);\n\n const mediaKeysPromise = Promise.resolve().then(() => mediaKeySystemAccess.createMediaKeys())\n .then((mediaKeys) => {\n mediaKeysListItem.mediaKeys = mediaKeys;\n\n logger.log(`Media-keys created for key-system \"${keySystem}\"`);\n\n this._onMediaKeysCreated();\n\n return mediaKeys;\n });\n\n mediaKeysPromise.catch((err) => {\n logger.error('Failed to create media-keys:', err);\n });\n\n return mediaKeysPromise;\n }\n\n /**\n * Handles key-creation (represents access to CDM). We are going to create key-sessions upon this\n * for all existing keys where no session exists yet.\n *\n * @private\n */\n private _onMediaKeysCreated () {\n // check for all key-list items if a session exists, otherwise, create one\n this._mediaKeysList.forEach((mediaKeysListItem) => {\n if (!mediaKeysListItem.mediaKeysSession) {\n // mediaKeys is definitely initialized here\n mediaKeysListItem.mediaKeysSession = mediaKeysListItem.mediaKeys!.createSession();\n this._onNewMediaKeySession(mediaKeysListItem.mediaKeysSession);\n }\n });\n }\n\n /**\n * @private\n * @param {*} keySession\n */\n private _onNewMediaKeySession (keySession: MediaKeySession) {\n logger.log(`New key-system session ${keySession.sessionId}`);\n\n keySession.addEventListener('message', (event: MediaKeyMessageEvent) => {\n this._onKeySessionMessage(keySession, event.message);\n }, false);\n }\n\n /**\n * @private\n * @param {MediaKeySession} keySession\n * @param {ArrayBuffer} message\n */\n private _onKeySessionMessage (keySession: MediaKeySession, message: ArrayBuffer) {\n logger.log('Got EME message event, creating license request');\n\n this._requestLicense(message, (data: ArrayBuffer) => {\n logger.log(`Received license data (length: ${data ? data.byteLength : data}), updating key-session`);\n keySession.update(data);\n });\n }\n\n /**\n * @private\n * @param e {MediaEncryptedEvent}\n */\n private _onMediaEncrypted = (e: MediaEncryptedEvent) => {\n logger.log(`Media is encrypted using \"${e.initDataType}\" init data type`);\n\n if (!this.mediaKeysPromise) {\n logger.error('Fatal: Media is encrypted but no CDM access or no keys have been requested');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_KEYS,\n fatal: true\n });\n return;\n }\n\n const finallySetKeyAndStartSession = (mediaKeys) => {\n if (!this._media) {\n return;\n }\n this._attemptSetMediaKeys(mediaKeys);\n this._generateRequestWithPreferredKeySession(e.initDataType, e.initData);\n };\n\n // Could use `Promise.finally` but some Promise polyfills are missing it\n this.mediaKeysPromise.then(finallySetKeyAndStartSession).catch(finallySetKeyAndStartSession);\n }\n\n /**\n * @private\n */\n private _attemptSetMediaKeys (mediaKeys?: MediaKeys) {\n if (!this._media) {\n throw new Error('Attempted to set mediaKeys without first attaching a media element');\n }\n\n if (!this._hasSetMediaKeys) {\n // FIXME: see if we can/want/need-to really to deal with several potential key-sessions?\n const keysListItem = this._mediaKeysList[0];\n if (!keysListItem || !keysListItem.mediaKeys) {\n logger.error('Fatal: Media is encrypted but no CDM access or no keys have been obtained yet');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_KEYS,\n fatal: true\n });\n return;\n }\n\n logger.log('Setting keys for encrypted media');\n\n this._media.setMediaKeys(keysListItem.mediaKeys);\n this._hasSetMediaKeys = true;\n }\n }\n\n /**\n * @private\n */\n private _generateRequestWithPreferredKeySession (initDataType: string, initData: ArrayBuffer | null) {\n // FIXME: see if we can/want/need-to really to deal with several potential key-sessions?\n const keysListItem = this._mediaKeysList[0];\n if (!keysListItem) {\n logger.error('Fatal: Media is encrypted but not any key-system access has been obtained yet');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_ACCESS,\n fatal: true\n });\n return;\n }\n\n if (keysListItem.mediaKeysSessionInitialized) {\n logger.warn('Key-Session already initialized but requested again');\n return;\n }\n\n const keySession = keysListItem.mediaKeysSession;\n if (!keySession) {\n logger.error('Fatal: Media is encrypted but no key-session existing');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_SESSION,\n fatal: true\n });\n return;\n }\n\n // initData is null if the media is not CORS-same-origin\n if (!initData) {\n logger.warn('Fatal: initData required for generating a key session is null');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_INIT_DATA,\n fatal: true\n });\n return;\n }\n\n logger.log(`Generating key-session request for \"${initDataType}\" init data type`);\n keysListItem.mediaKeysSessionInitialized = true;\n\n keySession.generateRequest(initDataType, initData)\n .then(() => {\n logger.debug('Key-session generation succeeded');\n })\n .catch((err) => {\n logger.error('Error generating key-session request:', err);\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_SESSION,\n fatal: false\n });\n });\n }\n\n /**\n * @private\n * @param {string} url License server URL\n * @param {ArrayBuffer} keyMessage Message data issued by key-system\n * @param {function} callback Called when XHR has succeeded\n * @returns {XMLHttpRequest} Unsent (but opened state) XHR object\n * @throws if XMLHttpRequest construction failed\n */\n private _createLicenseXhr (url: string, keyMessage: ArrayBuffer, callback: (data: ArrayBuffer) => void): XMLHttpRequest {\n const xhr = new XMLHttpRequest();\n const licenseXhrSetup = this._licenseXhrSetup;\n\n try {\n if (licenseXhrSetup) {\n try {\n licenseXhrSetup(xhr, url);\n } catch (e) {\n // let's try to open before running setup\n xhr.open('POST', url, true);\n licenseXhrSetup(xhr, url);\n }\n }\n // if licenseXhrSetup did not yet call open, let's do it now\n if (!xhr.readyState) {\n xhr.open('POST', url, true);\n }\n } catch (e) {\n // IE11 throws an exception on xhr.open if attempting to access an HTTP resource over HTTPS\n throw new Error(`issue setting up KeySystem license XHR ${e}`);\n }\n\n // Because we set responseType to ArrayBuffer here, callback is typed as handling only array buffers\n xhr.responseType = 'arraybuffer';\n xhr.onreadystatechange =\n this._onLicenseRequestReadyStageChange.bind(this, xhr, url, keyMessage, callback);\n return xhr;\n }\n\n /**\n * @private\n * @param {XMLHttpRequest} xhr\n * @param {string} url License server URL\n * @param {ArrayBuffer} keyMessage Message data issued by key-system\n * @param {function} callback Called when XHR has succeeded\n */\n private _onLicenseRequestReadyStageChange (xhr: XMLHttpRequest, url: string, keyMessage: ArrayBuffer, callback: (data: ArrayBuffer) => void) {\n switch (xhr.readyState) {\n case 4:\n if (xhr.status === 200) {\n this._requestLicenseFailureCount = 0;\n logger.log('License request succeeded');\n\n if (xhr.responseType !== 'arraybuffer') {\n logger.warn('xhr response type was not set to the expected arraybuffer for license request');\n }\n callback(xhr.response);\n } else {\n logger.error(`License Request XHR failed (${url}). Status: ${xhr.status} (${xhr.statusText})`);\n this._requestLicenseFailureCount++;\n if (this._requestLicenseFailureCount > MAX_LICENSE_REQUEST_FAILURES) {\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_LICENSE_REQUEST_FAILED,\n fatal: true\n });\n return;\n }\n\n const attemptsLeft = MAX_LICENSE_REQUEST_FAILURES - this._requestLicenseFailureCount + 1;\n logger.warn(`Retrying license request, ${attemptsLeft} attempts left`);\n this._requestLicense(keyMessage, callback);\n }\n break;\n }\n }\n\n /**\n * @private\n * @param {MediaKeysListItem} keysListItem\n * @param {ArrayBuffer} keyMessage\n * @returns {ArrayBuffer} Challenge data posted to license server\n * @throws if KeySystem is unsupported\n */\n private _generateLicenseRequestChallenge (keysListItem: MediaKeysListItem, keyMessage: ArrayBuffer): ArrayBuffer {\n switch (keysListItem.mediaKeySystemDomain) {\n // case KeySystems.PLAYREADY:\n // from https://github.com/MicrosoftEdge/Demos/blob/master/eme/scripts/demo.js\n /*\n if (this.licenseType !== this.LICENSE_TYPE_WIDEVINE) {\n // For PlayReady CDMs, we need to dig the Challenge out of the XML.\n var keyMessageXml = new DOMParser().parseFromString(String.fromCharCode.apply(null, new Uint16Array(keyMessage)), 'application/xml');\n if (keyMessageXml.getElementsByTagName('Challenge')[0]) {\n challenge = atob(keyMessageXml.getElementsByTagName('Challenge')[0].childNodes[0].nodeValue);\n } else {\n throw 'Cannot find <Challenge> in key message';\n }\n var headerNames = keyMessageXml.getElementsByTagName('name');\n var headerValues = keyMessageXml.getElementsByTagName('value');\n if (headerNames.length !== headerValues.length) {\n throw 'Mismatched header <name>/<value> pair in key message';\n }\n for (var i = 0; i < headerNames.length; i++) {\n xhr.setRequestHeader(headerNames[i].childNodes[0].nodeValue, headerValues[i].childNodes[0].nodeValue);\n }\n }\n break;\n */\n case KeySystems.WIDEVINE:\n // For Widevine CDMs, the challenge is the keyMessage.\n return keyMessage;\n }\n\n throw new Error(`unsupported key-system: ${keysListItem.mediaKeySystemDomain}`);\n }\n\n /**\n * @private\n * @param keyMessage\n * @param callback\n */\n private _requestLicense (keyMessage: ArrayBuffer, callback: (data: ArrayBuffer) => void) {\n logger.log('Requesting content license for key-system');\n\n const keysListItem = this._mediaKeysList[0];\n if (!keysListItem) {\n logger.error('Fatal error: Media is encrypted but no key-system access has been obtained yet');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_ACCESS,\n fatal: true\n });\n return;\n }\n\n try {\n const url = this.getLicenseServerUrl(keysListItem.mediaKeySystemDomain);\n const xhr = this._createLicenseXhr(url, keyMessage, callback);\n logger.log(`Sending license request to URL: ${url}`);\n const challenge = this._generateLicenseRequestChallenge(keysListItem, keyMessage);\n xhr.send(challenge);\n } catch (e) {\n logger.error(`Failure requesting DRM license: ${e}`);\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_LICENSE_REQUEST_FAILED,\n fatal: true\n });\n }\n }\n\n onMediaAttached (data: { media: HTMLMediaElement; }) {\n if (!this._emeEnabled) {\n return;\n }\n\n const media = data.media;\n\n // keep reference of media\n this._media = media;\n\n media.addEventListener('encrypted', this._onMediaEncrypted);\n }\n\n onMediaDetached () {\n const media = this._media;\n const mediaKeysList = this._mediaKeysList;\n if (!media) {\n return;\n }\n media.removeEventListener('encrypted', this._onMediaEncrypted);\n this._media = null;\n this._mediaKeysList = [];\n // Close all sessions and remove media keys from the video element.\n Promise.all(mediaKeysList.map((mediaKeysListItem) => {\n if (mediaKeysListItem.mediaKeysSession) {\n return mediaKeysListItem.mediaKeysSession.close().catch(() => {\n // Ignore errors when closing the sessions. Closing a session that\n // generated no key requests will throw an error.\n });\n }\n })).then(() => {\n return media.setMediaKeys(null);\n }).catch(() => {\n // Ignore any failures while removing media keys from the video element.\n });\n }\n\n // TODO: Use manifest types here when they are defined\n onManifestParsed (data: any) {\n if (!this._emeEnabled) {\n return;\n }\n\n const audioCodecs = data.levels.map((level) => level.audioCodec);\n const videoCodecs = data.levels.map((level) => level.videoCodec);\n\n this._attemptKeySystemAccess(KeySystems.WIDEVINE, audioCodecs, videoCodecs);\n }\n}\n\nexport default EMEController;\n","/**\n * HLS config\n */\n\nimport AbrController from './controller/abr-controller';\nimport BufferController from './controller/buffer-controller';\nimport CapLevelController from './controller/cap-level-controller';\nimport FPSController from './controller/fps-controller';\nimport XhrLoader from './utils/xhr-loader';\n// import FetchLoader from './utils/fetch-loader';\n\nimport AudioTrackController from './controller/audio-track-controller';\nimport AudioStreamController from './controller/audio-stream-controller';\n\nimport * as Cues from './utils/cues';\nimport TimelineController from './controller/timeline-controller';\nimport SubtitleTrackController from './controller/subtitle-track-controller';\nimport { SubtitleStreamController } from './controller/subtitle-stream-controller';\nimport EMEController from './controller/eme-controller';\nimport { requestMediaKeySystemAccess, MediaKeyFunc } from './utils/mediakeys-helper';\n\ntype ABRControllerConfig = {\n abrEwmaFastLive: number,\n abrEwmaSlowLive: number,\n abrEwmaFastVoD: number,\n abrEwmaSlowVoD: number,\n abrEwmaDefaultEstimate: number,\n abrBandWidthFactor: number,\n abrBandWidthUpFactor: number,\n abrMaxWithRealBitrate: boolean,\n maxStarvationDelay: number,\n maxLoadingDelay: number,\n};\n\nexport type BufferControllerConfig = {\n appendErrorMaxRetry: number,\n liveDurationInfinity: boolean,\n liveBackBufferLength: number,\n};\n\ntype CapLevelControllerConfig = {\n capLevelToPlayerSize: boolean\n};\n\nexport type DRMSystemOptions = {\n audioRobustness?: string,\n videoRobustness?: string,\n}\n\nexport type EMEControllerConfig = {\n licenseXhrSetup?: (xhr: XMLHttpRequest, url: string) => void,\n emeEnabled: boolean,\n widevineLicenseUrl?: string,\n drmSystemOptions: DRMSystemOptions,\n requestMediaKeySystemAccessFunc: MediaKeyFunc | null,\n};\n\ntype FragmentLoaderConfig = {\n fLoader: any, // TODO(typescript-loader): Once Loader is typed fill this in\n\n fragLoadingTimeOut: number,\n fragLoadingMaxRetry: number,\n fragLoadingRetryDelay: number,\n fragLoadingMaxRetryTimeout: number,\n};\n\ntype FPSControllerConfig = {\n capLevelOnFPSDrop: boolean,\n fpsDroppedMonitoringPeriod: number,\n fpsDroppedMonitoringThreshold: number,\n};\n\ntype LevelControllerConfig = {\n startLevel?: number\n};\n\ntype MP4RemuxerConfig = {\n stretchShortVideoTrack: boolean,\n maxAudioFramesDrift: number,\n};\n\ntype PlaylistLoaderConfig = {\n pLoader: any, // TODO(typescript-loader): Once Loader is typed fill this in\n\n manifestLoadingTimeOut: number,\n manifestLoadingMaxRetry: number,\n manifestLoadingRetryDelay: number,\n manifestLoadingMaxRetryTimeout: number,\n\n levelLoadingTimeOut: number,\n levelLoadingMaxRetry: number,\n levelLoadingRetryDelay: number,\n levelLoadingMaxRetryTimeout: number\n};\n\ntype StreamControllerConfig = {\n autoStartLoad: boolean,\n startPosition: number,\n defaultAudioCodec?: string,\n initialLiveManifestSize: number,\n maxBufferLength: number,\n maxBufferSize: number,\n maxBufferHole: number,\n\n lowBufferWatchdogPeriod: number,\n highBufferWatchdogPeriod: number,\n nudgeOffset: number,\n nudgeMaxRetry: number,\n maxFragLookUpTolerance: number,\n liveSyncDurationCount: number,\n liveMaxLatencyDurationCount: number,\n liveSyncDuration?: number,\n liveMaxLatencyDuration?: number,\n maxMaxBufferLength: number,\n\n startFragPrefetch: boolean,\n testBandwidth: boolean\n};\n\ntype TimelineControllerConfig = {\n cueHandler: Cues.CuesInterface,\n enableCEA708Captions: boolean,\n enableWebVTT: boolean,\n captionsTextTrack1Label: string,\n captionsTextTrack1LanguageCode: string,\n captionsTextTrack2Label: string,\n captionsTextTrack2LanguageCode: string,\n captionsTextTrack3Label: string,\n captionsTextTrack3LanguageCode: string,\n captionsTextTrack4Label: string,\n captionsTextTrack4LanguageCode: string,\n renderTextTracksNatively: boolean,\n};\n\ntype TSDemuxerConfig = {\n forceKeyFrameOnDiscontinuity: boolean,\n};\n\nexport type HlsConfig =\n {\n debug: boolean,\n enableWorker: boolean,\n enableSoftwareAES: boolean,\n minAutoBitrate: number,\n loader: any, // TODO(typescript-xhrloader): Type once XHR is done\n xhrSetup?: (xhr: XMLHttpRequest, url: string) => void,\n\n // Alt Audio\n audioStreamController?: any, // TODO(typescript-audiostreamcontroller): Type once file is done\n audioTrackController?: any, // TODO(typescript-audiotrackcontroller): Type once file is done\n // Subtitle\n subtitleStreamController?: any, // TODO(typescript-subtitlestreamcontroller): Type once file is done\n subtitleTrackController?: any, // TODO(typescript-subtitletrackcontroller): Type once file is done\n timelineController?: any, // TODO(typescript-timelinecontroller): Type once file is done\n // EME\n emeController?: typeof EMEController,\n\n abrController: any, // TODO(typescript-abrcontroller): Type once file is done\n bufferController: typeof BufferController,\n capLevelController: any, // TODO(typescript-caplevelcontroller): Type once file is done\n fpsController: any, // TODO(typescript-fpscontroller): Type once file is done\n } &\n ABRControllerConfig &\n BufferControllerConfig &\n CapLevelControllerConfig &\n EMEControllerConfig &\n FPSControllerConfig &\n FragmentLoaderConfig &\n LevelControllerConfig &\n MP4RemuxerConfig &\n PlaylistLoaderConfig &\n StreamControllerConfig &\n TimelineControllerConfig &\n TSDemuxerConfig;\n\n// If possible, keep hlsDefaultConfig shallow\n// It is cloned whenever a new Hls instance is created, by keeping the config\n// shallow the properties are cloned, and we don't end up manipulating the default\nexport const hlsDefaultConfig: HlsConfig = {\n autoStartLoad: true, // used by stream-controller\n startPosition: -1, // used by stream-controller\n defaultAudioCodec: void 0, // used by stream-controller\n debug: false, // used by logger\n capLevelOnFPSDrop: false, // used by fps-controller\n capLevelToPlayerSize: false, // used by cap-level-controller\n initialLiveManifestSize: 1, // used by stream-controller\n maxBufferLength: 30, // used by stream-controller\n maxBufferSize: 60 * 1000 * 1000, // used by stream-controller\n maxBufferHole: 0.5, // used by stream-controller\n\n lowBufferWatchdogPeriod: 0.5, // used by stream-controller\n highBufferWatchdogPeriod: 3, // used by stream-controller\n nudgeOffset: 0.1, // used by stream-controller\n nudgeMaxRetry: 3, // used by stream-controller\n maxFragLookUpTolerance: 0.25, // used by stream-controller\n liveSyncDurationCount: 3, // used by stream-controller\n liveMaxLatencyDurationCount: Infinity, // used by stream-controller\n liveSyncDuration: void 0, // used by stream-controller\n liveMaxLatencyDuration: void 0, // used by stream-controller\n liveDurationInfinity: false, // used by buffer-controller\n liveBackBufferLength: Infinity, // used by buffer-controller\n maxMaxBufferLength: 600, // used by stream-controller\n enableWorker: true, // used by demuxer\n enableSoftwareAES: true, // used by decrypter\n manifestLoadingTimeOut: 10000, // used by playlist-loader\n manifestLoadingMaxRetry: 1, // used by playlist-loader\n manifestLoadingRetryDelay: 1000, // used by playlist-loader\n manifestLoadingMaxRetryTimeout: 64000, // used by playlist-loader\n startLevel: void 0, // used by level-controller\n levelLoadingTimeOut: 10000, // used by playlist-loader\n levelLoadingMaxRetry: 4, // used by playlist-loader\n levelLoadingRetryDelay: 1000, // used by playlist-loader\n levelLoadingMaxRetryTimeout: 64000, // used by playlist-loader\n fragLoadingTimeOut: 20000, // used by fragment-loader\n fragLoadingMaxRetry: 6, // used by fragment-loader\n fragLoadingRetryDelay: 1000, // used by fragment-loader\n fragLoadingMaxRetryTimeout: 64000, // used by fragment-loader\n startFragPrefetch: false, // used by stream-controller\n fpsDroppedMonitoringPeriod: 5000, // used by fps-controller\n fpsDroppedMonitoringThreshold: 0.2, // used by fps-controller\n appendErrorMaxRetry: 3, // used by buffer-controller\n loader: XhrLoader,\n // loader: FetchLoader,\n fLoader: void 0, // used by fragment-loader\n pLoader: void 0, // used by playlist-loader\n xhrSetup: void 0, // used by xhr-loader\n licenseXhrSetup: void 0, // used by eme-controller\n // fetchSetup: void 0,\n abrController: AbrController,\n bufferController: BufferController,\n capLevelController: CapLevelController,\n fpsController: FPSController,\n stretchShortVideoTrack: false, // used by mp4-remuxer\n maxAudioFramesDrift: 1, // used by mp4-remuxer\n forceKeyFrameOnDiscontinuity: true, // used by ts-demuxer\n abrEwmaFastLive: 3, // used by abr-controller\n abrEwmaSlowLive: 9, // used by abr-controller\n abrEwmaFastVoD: 3, // used by abr-controller\n abrEwmaSlowVoD: 9, // used by abr-controller\n abrEwmaDefaultEstimate: 5e5, // 500 kbps // used by abr-controller\n abrBandWidthFactor: 0.95, // used by abr-controller\n abrBandWidthUpFactor: 0.7, // used by abr-controller\n abrMaxWithRealBitrate: false, // used by abr-controller\n maxStarvationDelay: 4, // used by abr-controller\n maxLoadingDelay: 4, // used by abr-controller\n minAutoBitrate: 0, // used by hls\n emeEnabled: false, // used by eme-controller\n widevineLicenseUrl: void 0, // used by eme-controller\n drmSystemOptions: {}, // used by eme-controller\n requestMediaKeySystemAccessFunc: requestMediaKeySystemAccess, // used by eme-controller\n testBandwidth: true,\n\n // Dynamic Modules\n ...timelineConfig(),\n subtitleStreamController: (__USE_SUBTITLES__) ? SubtitleStreamController : void 0,\n subtitleTrackController: (__USE_SUBTITLES__) ? SubtitleTrackController : void 0,\n timelineController: (__USE_SUBTITLES__) ? TimelineController : void 0,\n audioStreamController: (__USE_ALT_AUDIO__) ? AudioStreamController : void 0,\n audioTrackController: (__USE_ALT_AUDIO__) ? AudioTrackController : void 0,\n emeController: (__USE_EME_DRM__) ? EMEController : void 0\n};\n\nfunction timelineConfig (): TimelineControllerConfig {\n return {\n cueHandler: Cues, // used by timeline-controller\n enableCEA708Captions: __USE_SUBTITLES__, // used by timeline-controller\n enableWebVTT: __USE_SUBTITLES__, // used by timeline-controller\n captionsTextTrack1Label: 'English', // used by timeline-controller\n captionsTextTrack1LanguageCode: 'en', // used by timeline-controller\n captionsTextTrack2Label: 'Spanish', // used by timeline-controller\n captionsTextTrack2LanguageCode: 'es', // used by timeline-controller\n captionsTextTrack3Label: 'Unknown CC', // used by timeline-controller\n captionsTextTrack3LanguageCode: '', // used by timeline-controller\n captionsTextTrack4Label: 'Unknown CC', // used by timeline-controller\n captionsTextTrack4LanguageCode: '', // used by timeline-controller\n renderTextTracksNatively: true\n };\n}\n","import * as URLToolkit from 'url-toolkit';\n\nimport {\n ErrorTypes,\n ErrorDetails\n} from './errors';\n\nimport PlaylistLoader from './loader/playlist-loader';\nimport FragmentLoader from './loader/fragment-loader';\nimport KeyLoader from './loader/key-loader';\n\nimport { FragmentTracker } from './controller/fragment-tracker';\nimport StreamController from './controller/stream-controller';\nimport LevelController from './controller/level-controller';\nimport ID3TrackController from './controller/id3-track-controller';\n\nimport { isSupported } from './is-supported';\nimport { logger, enableLogs } from './utils/logger';\nimport { hlsDefaultConfig, HlsConfig } from './config';\n\nimport HlsEvents from './events';\n\nimport { Observer } from './observer';\n\n/**\n * @module Hls\n * @class\n * @constructor\n */\nexport default class Hls extends Observer {\n public static defaultConfig?: HlsConfig;\n public config: HlsConfig;\n\n private _autoLevelCapping: number;\n private abrController: any;\n private capLevelController: any;\n private levelController: LevelController;\n private streamController: StreamController;\n private networkControllers: any[];\n private audioTrackController: any;\n private subtitleTrackController: any;\n private emeController: any;\n private coreComponents: any[];\n private media: HTMLMediaElement | null = null;\n private url: string | null = null;\n\n /**\n * @type {string}\n */\n static get version (): string {\n return __VERSION__;\n }\n\n /**\n * @type {boolean}\n */\n static isSupported (): boolean {\n return isSupported();\n }\n\n /**\n * @type {HlsEvents}\n */\n static get Events () {\n return HlsEvents;\n }\n\n /**\n * @type {HlsErrorTypes}\n */\n static get ErrorTypes () {\n return ErrorTypes;\n }\n\n /**\n * @type {HlsErrorDetails}\n */\n static get ErrorDetails () {\n return ErrorDetails;\n }\n\n /**\n * @type {HlsConfig}\n */\n static get DefaultConfig (): HlsConfig {\n if (!Hls.defaultConfig) {\n return hlsDefaultConfig;\n }\n\n return Hls.defaultConfig;\n }\n\n /**\n * @type {HlsConfig}\n */\n static set DefaultConfig (defaultConfig: HlsConfig) {\n Hls.defaultConfig = defaultConfig;\n }\n\n /**\n * Creates an instance of an HLS client that can attach to exactly one `HTMLMediaElement`.\n *\n * @constructs Hls\n * @param {HlsConfig} config\n */\n constructor (userConfig: Partial<HlsConfig> = {}) {\n super();\n\n const defaultConfig = Hls.DefaultConfig;\n\n if ((userConfig.liveSyncDurationCount || userConfig.liveMaxLatencyDurationCount) && (userConfig.liveSyncDuration || userConfig.liveMaxLatencyDuration)) {\n throw new Error('Illegal hls.js config: don\\'t mix up liveSyncDurationCount/liveMaxLatencyDurationCount and liveSyncDuration/liveMaxLatencyDuration');\n }\n\n // Shallow clone\n this.config = {\n ...defaultConfig,\n ...userConfig\n };\n\n const { config } = this;\n\n if (config.liveMaxLatencyDurationCount !== void 0 && config.liveMaxLatencyDurationCount <= config.liveSyncDurationCount) {\n throw new Error('Illegal hls.js config: \"liveMaxLatencyDurationCount\" must be gt \"liveSyncDurationCount\"');\n }\n\n if (config.liveMaxLatencyDuration !== void 0 && (config.liveSyncDuration === void 0 || config.liveMaxLatencyDuration <= config.liveSyncDuration)) {\n throw new Error('Illegal hls.js config: \"liveMaxLatencyDuration\" must be gt \"liveSyncDuration\"');\n }\n\n enableLogs(config.debug);\n\n this._autoLevelCapping = -1;\n\n // core controllers and network loaders\n\n /**\n * @member {AbrController} abrController\n */\n const abrController = this.abrController = new config.abrController(this); // eslint-disable-line new-cap\n const bufferController = new config.bufferController(this); // eslint-disable-line new-cap\n const capLevelController = this.capLevelController = new config.capLevelController(this); // eslint-disable-line new-cap\n const fpsController = new config.fpsController(this); // eslint-disable-line new-cap\n const playListLoader = new PlaylistLoader(this);\n const fragmentLoader = new FragmentLoader(this);\n const keyLoader = new KeyLoader(this);\n const id3TrackController = new ID3TrackController(this);\n\n // network controllers\n\n /**\n * @member {LevelController} levelController\n */\n const levelController = this.levelController = new LevelController(this);\n\n // FIXME: FragmentTracker must be defined before StreamController because the order of event handling is important\n const fragmentTracker = new FragmentTracker(this);\n\n /**\n * @member {StreamController} streamController\n */\n const streamController = this.streamController = new StreamController(this, fragmentTracker);\n\n let networkControllers = [levelController, streamController];\n\n // optional audio stream controller\n /**\n * @var {ICoreComponent | Controller}\n */\n let Controller = config.audioStreamController;\n if (Controller) {\n networkControllers.push(new Controller(this, fragmentTracker));\n }\n\n /**\n * @member {INetworkController[]} networkControllers\n */\n this.networkControllers = networkControllers;\n\n /**\n * @var {ICoreComponent[]}\n */\n const coreComponents = [\n playListLoader,\n fragmentLoader,\n keyLoader,\n abrController,\n bufferController,\n capLevelController,\n fpsController,\n id3TrackController,\n fragmentTracker\n ];\n\n // optional audio track and subtitle controller\n Controller = config.audioTrackController;\n if (Controller) {\n const audioTrackController = new Controller(this);\n\n /**\n * @member {AudioTrackController} audioTrackController\n */\n this.audioTrackController = audioTrackController;\n coreComponents.push(audioTrackController);\n }\n\n Controller = config.subtitleTrackController;\n if (Controller) {\n const subtitleTrackController = new Controller(this);\n\n /**\n * @member {SubtitleTrackController} subtitleTrackController\n */\n this.subtitleTrackController = subtitleTrackController;\n networkControllers.push(subtitleTrackController);\n }\n\n Controller = config.emeController;\n if (Controller) {\n const emeController = new Controller(this);\n\n /**\n * @member {EMEController} emeController\n */\n this.emeController = emeController;\n coreComponents.push(emeController);\n }\n\n // optional subtitle controllers\n Controller = config.subtitleStreamController;\n if (Controller) {\n networkControllers.push(new Controller(this, fragmentTracker));\n }\n Controller = config.timelineController;\n if (Controller) {\n coreComponents.push(new Controller(this));\n }\n\n /**\n * @member {ICoreComponent[]}\n */\n this.coreComponents = coreComponents;\n }\n\n /**\n * Dispose of the instance\n */\n destroy () {\n logger.log('destroy');\n this.trigger(HlsEvents.DESTROYING);\n this.detachMedia();\n this.coreComponents.concat(this.networkControllers).forEach(component => {\n component.destroy();\n });\n this.url = null;\n this.removeAllListeners();\n this._autoLevelCapping = -1;\n }\n\n /**\n * Attach a media element\n * @param {HTMLMediaElement} media\n */\n attachMedia (media: HTMLMediaElement) {\n logger.log('attachMedia');\n this.media = media;\n this.trigger(HlsEvents.MEDIA_ATTACHING, { media: media });\n }\n\n /**\n * Detach from the media\n */\n detachMedia () {\n logger.log('detachMedia');\n this.trigger(HlsEvents.MEDIA_DETACHING);\n this.media = null;\n }\n\n /**\n * Set the source URL. Can be relative or absolute.\n * @param {string} url\n */\n loadSource (url: string) {\n url = URLToolkit.buildAbsoluteURL(window.location.href, url, { alwaysNormalize: true });\n logger.log(`loadSource:${url}`);\n this.url = url;\n // when attaching to a source URL, trigger a playlist load\n this.trigger(HlsEvents.MANIFEST_LOADING, { url: url });\n }\n\n /**\n * Start loading data from the stream source.\n * Depending on default config, client starts loading automatically when a source is set.\n *\n * @param {number} startPosition Set the start position to stream from\n * @default -1 None (from earliest point)\n */\n startLoad (startPosition: number = -1) {\n logger.log(`startLoad(${startPosition})`);\n this.networkControllers.forEach(controller => {\n controller.startLoad(startPosition);\n });\n }\n\n /**\n * Stop loading of any stream data.\n */\n stopLoad () {\n logger.log('stopLoad');\n this.networkControllers.forEach(controller => {\n controller.stopLoad();\n });\n }\n\n /**\n * Swap through possible audio codecs in the stream (for example to switch from stereo to 5.1)\n */\n swapAudioCodec () {\n logger.log('swapAudioCodec');\n this.streamController.swapAudioCodec();\n }\n\n /**\n * When the media-element fails, this allows to detach and then re-attach it\n * as one call (convenience method).\n *\n * Automatic recovery of media-errors by this process is configurable.\n */\n recoverMediaError () {\n logger.log('recoverMediaError');\n let media = this.media;\n this.detachMedia();\n if (media) {\n this.attachMedia(media);\n }\n }\n\n /**\n * Remove a loaded level from the list of levels, or a level url in from a list of redundant level urls.\n * This can be used to remove a rendition or playlist url that errors frequently from the list of levels that a user\n * or hls.js can choose from.\n *\n * @param levelIndex {number} The quality level index to of the level to remove\n * @param urlId {number} The quality level url index in the case that fallback levels are available. Defaults to 0.\n */\n removeLevel (levelIndex, urlId = 0) {\n this.levelController.removeLevel(levelIndex, urlId);\n }\n\n /**\n * @type {QualityLevel[]}\n */\n // todo(typescript-levelController)\n get levels (): any[] {\n return this.levelController.levels;\n }\n\n /**\n * Index of quality level currently played\n * @type {number}\n */\n get currentLevel (): number {\n return this.streamController.currentLevel;\n }\n\n /**\n * Set quality level index immediately .\n * This will flush the current buffer to replace the quality asap.\n * That means playback will interrupt at least shortly to re-buffer and re-sync eventually.\n * @param newLevel {number} -1 for automatic level selection\n */\n set currentLevel (newLevel: number) {\n logger.log(`set currentLevel:${newLevel}`);\n this.loadLevel = newLevel;\n this.streamController.immediateLevelSwitch();\n }\n\n /**\n * Index of next quality level loaded as scheduled by stream controller.\n * @type {number}\n */\n get nextLevel (): number {\n return this.streamController.nextLevel;\n }\n\n /**\n * Set quality level index for next loaded data.\n * This will switch the video quality asap, without interrupting playback.\n * May abort current loading of data, and flush parts of buffer (outside currently played fragment region).\n * @type {number} -1 for automatic level selection\n */\n set nextLevel (newLevel: number) {\n logger.log(`set nextLevel:${newLevel}`);\n this.levelController.manualLevel = newLevel;\n this.streamController.nextLevelSwitch();\n }\n\n /**\n * Return the quality level of the currently or last (of none is loaded currently) segment\n * @type {number}\n */\n get loadLevel (): number {\n return this.levelController.level;\n }\n\n /**\n * Set quality level index for next loaded data in a conservative way.\n * This will switch the quality without flushing, but interrupt current loading.\n * Thus the moment when the quality switch will appear in effect will only be after the already existing buffer.\n * @type {number} newLevel -1 for automatic level selection\n */\n set loadLevel (newLevel: number) {\n logger.log(`set loadLevel:${newLevel}`);\n this.levelController.manualLevel = newLevel;\n }\n\n /**\n * get next quality level loaded\n * @type {number}\n */\n get nextLoadLevel (): number {\n return this.levelController.nextLoadLevel;\n }\n\n /**\n * Set quality level of next loaded segment in a fully \"non-destructive\" way.\n * Same as `loadLevel` but will wait for next switch (until current loading is done).\n * @type {number} level\n */\n set nextLoadLevel (level: number) {\n this.levelController.nextLoadLevel = level;\n }\n\n /**\n * Return \"first level\": like a default level, if not set,\n * falls back to index of first level referenced in manifest\n * @type {number}\n */\n get firstLevel (): number {\n return Math.max(this.levelController.firstLevel, this.minAutoLevel);\n }\n\n /**\n * Sets \"first-level\", see getter.\n * @type {number}\n */\n set firstLevel (newLevel: number) {\n logger.log(`set firstLevel:${newLevel}`);\n this.levelController.firstLevel = newLevel;\n }\n\n /**\n * Return start level (level of first fragment that will be played back)\n * if not overrided by user, first level appearing in manifest will be used as start level\n * if -1 : automatic start level selection, playback will start from level matching download bandwidth\n * (determined from download of first segment)\n * @type {number}\n */\n get startLevel (): number {\n return this.levelController.startLevel;\n }\n\n /**\n * set start level (level of first fragment that will be played back)\n * if not overrided by user, first level appearing in manifest will be used as start level\n * if -1 : automatic start level selection, playback will start from level matching download bandwidth\n * (determined from download of first segment)\n * @type {number} newLevel\n */\n set startLevel (newLevel: number) {\n logger.log(`set startLevel:${newLevel}`);\n // if not in automatic start level detection, ensure startLevel is greater than minAutoLevel\n if (newLevel !== -1) {\n newLevel = Math.max(newLevel, this.minAutoLevel);\n }\n\n this.levelController.startLevel = newLevel;\n }\n\n /**\n * set dynamically set capLevelToPlayerSize against (`CapLevelController`)\n *\n * @type {boolean}\n */\n set capLevelToPlayerSize (shouldStartCapping: boolean) {\n const newCapLevelToPlayerSize = !!shouldStartCapping;\n\n if (newCapLevelToPlayerSize !== this.config.capLevelToPlayerSize) {\n if (newCapLevelToPlayerSize) {\n this.capLevelController.startCapping(); // If capping occurs, nextLevelSwitch will happen based on size.\n } else {\n this.capLevelController.stopCapping();\n this.autoLevelCapping = -1;\n this.streamController.nextLevelSwitch(); // Now we're uncapped, get the next level asap.\n }\n\n this.config.capLevelToPlayerSize = newCapLevelToPlayerSize;\n }\n }\n\n /**\n * Capping/max level value that should be used by automatic level selection algorithm (`ABRController`)\n * @type {number}\n */\n get autoLevelCapping (): number {\n return this._autoLevelCapping;\n }\n\n /**\n * get bandwidth estimate\n * @type {number}\n */\n get bandwidthEstimate (): number {\n const bwEstimator = this.abrController._bwEstimator;\n return bwEstimator ? bwEstimator.getEstimate() : NaN;\n }\n\n /**\n * Capping/max level value that should be used by automatic level selection algorithm (`ABRController`)\n * @type {number}\n */\n set autoLevelCapping (newLevel: number) {\n logger.log(`set autoLevelCapping:${newLevel}`);\n this._autoLevelCapping = newLevel;\n }\n\n /**\n * True when automatic level selection enabled\n * @type {boolean}\n */\n get autoLevelEnabled (): boolean {\n return (this.levelController.manualLevel === -1);\n }\n\n /**\n * Level set manually (if any)\n * @type {number}\n */\n get manualLevel (): number {\n return this.levelController.manualLevel;\n }\n\n /**\n * min level selectable in auto mode according to config.minAutoBitrate\n * @type {number}\n */\n get minAutoLevel (): number {\n const { levels, config: { minAutoBitrate } } = this;\n const len = levels ? levels.length : 0;\n\n for (let i = 0; i < len; i++) {\n const levelNextBitrate = levels[i].realBitrate\n ? Math.max(levels[i].realBitrate, levels[i].bitrate)\n : levels[i].bitrate;\n\n if (levelNextBitrate > minAutoBitrate) {\n return i;\n }\n }\n\n return 0;\n }\n\n /**\n * max level selectable in auto mode according to autoLevelCapping\n * @type {number}\n */\n get maxAutoLevel (): number {\n const { levels, autoLevelCapping } = this;\n\n let maxAutoLevel;\n if (autoLevelCapping === -1 && levels && levels.length) {\n maxAutoLevel = levels.length - 1;\n } else {\n maxAutoLevel = autoLevelCapping;\n }\n\n return maxAutoLevel;\n }\n\n /**\n * next automatically selected quality level\n * @type {number}\n */\n get nextAutoLevel (): number {\n // ensure next auto level is between min and max auto level\n return Math.min(Math.max(this.abrController.nextAutoLevel, this.minAutoLevel), this.maxAutoLevel);\n }\n\n /**\n * this setter is used to force next auto level.\n * this is useful to force a switch down in auto mode:\n * in case of load error on level N, hls.js can set nextAutoLevel to N-1 for example)\n * forced value is valid for one fragment. upon succesful frag loading at forced level,\n * this value will be resetted to -1 by ABR controller.\n * @type {number}\n */\n set nextAutoLevel (nextLevel: number) {\n this.abrController.nextAutoLevel = Math.max(this.minAutoLevel, nextLevel);\n }\n\n /**\n * @type {AudioTrack[]}\n */\n // todo(typescript-audioTrackController)\n get audioTracks (): any[] {\n const audioTrackController = this.audioTrackController;\n return audioTrackController ? audioTrackController.audioTracks : [];\n }\n\n /**\n * index of the selected audio track (index in audio track lists)\n * @type {number}\n */\n get audioTrack (): number {\n const audioTrackController = this.audioTrackController;\n return audioTrackController ? audioTrackController.audioTrack : -1;\n }\n\n /**\n * selects an audio track, based on its index in audio track lists\n * @type {number}\n */\n set audioTrack (audioTrackId: number) {\n const audioTrackController = this.audioTrackController;\n if (audioTrackController) {\n audioTrackController.audioTrack = audioTrackId;\n }\n }\n\n /**\n * @type {Seconds}\n */\n get liveSyncPosition (): number {\n return this.streamController.liveSyncPosition;\n }\n\n /**\n * get alternate subtitle tracks list from playlist\n * @type {SubtitleTrack[]}\n */\n // todo(typescript-subtitleTrackController)\n get subtitleTracks (): any[] {\n const subtitleTrackController = this.subtitleTrackController;\n return subtitleTrackController ? subtitleTrackController.subtitleTracks : [];\n }\n\n /**\n * index of the selected subtitle track (index in subtitle track lists)\n * @type {number}\n */\n get subtitleTrack (): number {\n const subtitleTrackController = this.subtitleTrackController;\n return subtitleTrackController ? subtitleTrackController.subtitleTrack : -1;\n }\n\n /**\n * select an subtitle track, based on its index in subtitle track lists\n * @type {number}\n */\n set subtitleTrack (subtitleTrackId: number) {\n const subtitleTrackController = this.subtitleTrackController;\n if (subtitleTrackController) {\n subtitleTrackController.subtitleTrack = subtitleTrackId;\n }\n }\n\n /**\n * @type {boolean}\n */\n get subtitleDisplay (): boolean {\n const subtitleTrackController = this.subtitleTrackController;\n return subtitleTrackController ? subtitleTrackController.subtitleDisplay : false;\n }\n\n /**\n * Enable/disable subtitle display rendering\n * @type {boolean}\n */\n set subtitleDisplay (value: boolean) {\n const subtitleTrackController = this.subtitleTrackController;\n if (subtitleTrackController) {\n subtitleTrackController.subtitleDisplay = value;\n }\n }\n}\n","import { getMediaSource } from './utils/mediasource-helper';\n\nexport function isSupported (): boolean {\n const mediaSource = getMediaSource();\n if (!mediaSource) {\n return false;\n }\n const sourceBuffer = self.SourceBuffer || (self as any).WebKitSourceBuffer as SourceBuffer;\n const isTypeSupported = mediaSource &&\n typeof mediaSource.isTypeSupported === 'function' &&\n mediaSource.isTypeSupported('video/mp4; codecs=\"avc1.42E01E,mp4a.40.2\"');\n\n // if SourceBuffer is exposed ensure its API is valid\n // safari and old version of Chrome doe not expose SourceBuffer globally so checking SourceBuffer.prototype is impossible\n const sourceBufferValidAPI = !sourceBuffer ||\n (sourceBuffer.prototype &&\n typeof sourceBuffer.prototype.appendBuffer === 'function' &&\n typeof sourceBuffer.prototype.remove === 'function');\n return !!isTypeSupported && !!sourceBufferValidAPI;\n}\n","export const isFiniteNumber = Number.isFinite || function (value) {\n return typeof value === 'number' && isFinite(value);\n};\n\nexport const MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER || 9007199254740991;\n","export function getSelfScope () {\n // see https://stackoverflow.com/a/11237259/589493\n if (typeof window === 'undefined') {\n /* eslint-disable-next-line no-undef */\n return self;\n } else {\n return window;\n }\n}\n","import { getSelfScope } from './get-self-scope';\n\nfunction noop (...args) {}\n\nconst fakeLogger = {\n trace: noop,\n debug: noop,\n log: noop,\n warn: noop,\n info: noop,\n error: noop\n};\n\nlet exportedLogger = fakeLogger;\n\n// let lastCallTime;\n// function formatMsgWithTimeInfo(type, msg) {\n// const now = Date.now();\n// const diff = lastCallTime ? '+' + (now - lastCallTime) : '0';\n// lastCallTime = now;\n// msg = (new Date(now)).toISOString() + ' | [' + type + '] > ' + msg + ' ( ' + diff + ' ms )';\n// return msg;\n// }\n\nfunction formatMsg (type, msg) {\n msg = '[' + type + '] > ' + msg;\n return msg;\n}\n\nconst global = getSelfScope();\n\nfunction consolePrintFn (type) {\n const func = global.console[type];\n if (func) {\n return function (...args) {\n if (args[0]) {\n args[0] = formatMsg(type, args[0]);\n }\n\n func.apply(global.console, args);\n };\n }\n return noop;\n}\n\nfunction exportLoggerFunctions (debugConfig, ...functions) {\n functions.forEach(function (type) {\n exportedLogger[type] = debugConfig[type] ? debugConfig[type].bind(debugConfig) : consolePrintFn(type);\n });\n}\n\nexport const enableLogs = function (debugConfig) {\n // check that console is available\n if ((global.console && debugConfig === true) || typeof debugConfig === 'object') {\n exportLoggerFunctions(debugConfig,\n // Remove out from list here to hard-disable a log-level\n // 'trace',\n 'debug',\n 'log',\n 'info',\n 'warn',\n 'error'\n );\n // Some browsers don't allow to use bind on console object anyway\n // fallback to default if needed\n try {\n exportedLogger.log();\n } catch (e) {\n exportedLogger = fakeLogger;\n }\n } else {\n exportedLogger = fakeLogger;\n }\n};\n\nexport const logger = exportedLogger;\n","'use strict'\r\n\r\nclass HlsjsIPFSLoader {\r\n constructor(config) {\r\n this._abortFlag = [ false ];\r\n this.ipfs = config.ipfs\r\n this.hash = config.ipfsHash\r\n if (config.debug === false) {\r\n this.debug = function() {}\r\n } else if (config.debug === true) {\r\n this.debug = console.log\r\n } else {\r\n this.debug = config.debug\r\n }\r\n if(config.m3u8provider) {\r\n this.m3u8provider = config.m3u8provider;\r\n } else {\r\n this.m3u8provider = null;\r\n }\r\n if(config.tsListProvider) {\r\n this.tsListProvider = config.tsListProvider;\r\n } else {\r\n this.tsListProvider = null;\r\n }\r\n }\r\n\r\n destroy() {\r\n }\r\n\r\n abort() {\r\n this._abortFlag[0] = true;\r\n }\r\n\r\n load(context, config, callbacks) {\r\n this.context = context\r\n this.config = config\r\n this.callbacks = callbacks\r\n this.stats = { trequest: performance.now(), retry: 0 }\r\n this.retryDelay = config.retryDelay\r\n this.loadInternal()\r\n }\r\n /**\r\n * Call this by getting the HLSIPFSLoader instance from hls.js hls.coreComponents[0].loaders.manifest.setM3U8Provider()\r\n * @param {function} provider\r\n */\r\n setM3U8Provider(provider) {\r\n this.m3u8provider = provider;\r\n }\r\n /**\r\n *\r\n * @param {function} provider\r\n */\r\n setTsListProvider(provider) {\r\n this.tsListProvider = provider;\r\n }\r\n\r\n loadInternal() {\r\n const { stats, context, callbacks } = this\r\n\r\n stats.tfirst = Math.max(performance.now(), stats.trequest)\r\n stats.loaded = 0\r\n\r\n //When using absolute path (https://example.com/index.html) vs https://example.com/\r\n const urlParts = window.location.href.split(\"/\")\r\n if(urlParts[urlParts.length - 1] !== \"\") {\r\n urlParts[urlParts.length - 1] = \"\"\r\n }\r\n const filename = context.url.replace(urlParts.join(\"/\"), \"\")\r\n\r\n const options = {}\r\n if (Number.isFinite(context.rangeStart)) {\r\n options.offset = context.rangeStart;\r\n if (Number.isFinite(context.rangeEnd)) {\r\n\t options.length = context.rangeEnd - context.rangeStart;\r\n }\r\n }\r\n\r\n if(filename.split(\".\")[1] === \"m3u8\" && this.m3u8provider !== null) {\r\n const res = this.m3u8provider();\r\n let data;\r\n if(Buffer.isBuffer(res)) {\r\n data = buf2str(res)\r\n } else {\r\n data = res;\r\n }\r\n const response = { url: context.url, data: data }\r\n callbacks.onSuccess(response, stats, context)\r\n return;\r\n }\r\n if(filename.split(\".\")[1] === \"m3u8\" && this.tsListProvider !== null) {\r\n var tslist = this.tsListProvider();\r\n var hash = tslist[filename];\r\n if(hash) {\r\n this.cat(hash).then(res => {\r\n let data;\r\n if(Buffer.isBuffer(res)) {\r\n data = buf2str(res)\r\n } else {\r\n data = res;\r\n }\r\n stats.loaded = stats.total = data.length\r\n stats.tload = Math.max(stats.tfirst, performance.now())\r\n const response = { url: context.url, data: data }\r\n callbacks.onSuccess(response, stats, context)\r\n });\r\n }\r\n return;\r\n }\r\n this._abortFlag[0] = false;\r\n getFile(this.ipfs, this.hash, filename, options, this.debug, this._abortFlag).then(res => {\r\n const data = (context.responseType === 'arraybuffer') ? res : buf2str(res)\r\n stats.loaded = stats.total = data.length\r\n stats.tload = Math.max(stats.tfirst, performance.now())\r\n const response = { url: context.url, data: data }\r\n callbacks.onSuccess(response, stats, context)\r\n }, console.error)\r\n }\r\n}\r\nasync function getFile(ipfs, rootHash, filename, options, debug, abortFlag) {\r\n debug(`Fetching hash for '${rootHash}/${filename}'`)\r\n const path = `${rootHash}/${filename}`\r\n try {\r\n return await cat(path, options, ipfs, debug, abortFlag)\r\n } catch(ex) {\r\n throw new Error(`File not found: ${rootHash}/${filename}`)\r\n }\r\n}\r\n\r\nfunction buf2str(buf) {\r\n return new TextDecoder().decode(buf)\r\n}\r\n\r\nasync function cat (cid, options, ipfs, debug, abortFlag) {\r\n const parts = []\r\n let length = 0, offset = 0\r\n\r\n for await (const buf of ipfs.cat(cid, options)) {\r\n parts.push(buf)\r\n length += buf.length\r\n if (abortFlag[0]) {\r\n debug('Cancel reading from ipfs')\r\n break\r\n }\r\n }\r\n\r\n const value = new Uint8Array(length)\r\n for (const buf of parts) {\r\n value.set(buf, offset)\r\n offset += buf.length\r\n }\r\n\r\n debug(`Received data for file '${cid}' size: ${value.length} in ${parts.length} blocks`)\r\n return value\r\n}\r\n\r\nexports = module.exports = HlsjsIPFSLoader\r\n"],"names":["_ipfsCore","require","_hlsJs","_hlsjsIpfsLoader","getUrlParameter","name","replace","results","RegExp","exec","location","search","decodeURIComponent","showStatus","message","hide","status","document","getElementById","classList","toggle","innerText","setBodyHeight","body","style","height","window","innerHeight","addEventListener","async","hash","source","title","time","video","background","menu","oncontextmenu","e","left","pageX","top","pageY","preventDefault","onclick","stopPropagation","url","encodeURIComponent","navigator","clipboard","writeText","Math","round","currentTime","setUpContextMenu","display","repoPath","random","node","create","repo","DefaultConfig","loader","_hlsjsIpfsLoaderDefault","default","debug","_hlsJsDefault","isSupported","hls","config","ipfs","ipfsHash","loadSource","attachMedia","on","Events","MANIFEST_PARSED","play","Object","defineProperty","exports","value","index","crypto$1","isIpfs","cid","multiaddr$1","PeerId$1","globSourceImport","urlSourceImport","_interopDefaultLegacy","crypto__default","isIpfs__default","PeerId__default","globSourceImport__default","urlSourceImport__default","crypto","isIPFS","CID","multiaddr","Multiaddr","PeerId","globSource","urlSource","mergeOpts","env_js","errCode","ipfsUnixfs","dagPB","dagCBOR","identity","basics","initAssets","errors","fromString","start","stop","dns","isOnline","resolve","ipns","index$2","index$4","local","index$6","index$7","index$1","root","version","id1","index$8","index$3","preload","mfsPreload","index$5","index$9","index$a","index$b","index$c","storage","network","service","index$d","ping","dht","pubsub","multicodecs","multihashes","multibases","_interopNamespace","__esModule","n","keys","forEach","k","d","getOwnPropertyDescriptor","get","enumerable","freeze","mergeOpts__default","debug__default","errCode__default","dagPB__namespace","dagCBOR__namespace","mergeOptions","bind","ignoreUndefined","log","IPFS","print","print1","storage1","codecs","options","options1","peerId","keychain","network$1","Service","Network","preload$1","createPreloader","dns$1","createDns","isOnline$1","createIsOnline","ipns$1","IPNSAPI","multihashHashers","values","hashes","ipld","hashers","hasher","push","this","Multihashes","loadHasher","multibaseCodecs","bases","base","Multibases","loadBase","pin","PinAPI","block","BlockAPI","NameAPI","resolve$1","createResolve","dag","DagAPI","refs","assign","createRefs","createLocal","add","addAll","cat","ls","RootAPI","EXPERIMENTAL","files","createFiles","mfsPreload$1","createMfsPreloader","createStart","createStop","createDht","createPubsub","id","createId","createVersion","bitswap","BitswapAPI","bootstrap","BootstrapAPI","createConfig","createPing","key","KeyAPI","object","ObjectAPI","RepoAPI","stats","StatsAPI","swarm","SwarmAPI","net","try","libp2p","undefined","notImplemented","Promise","reject","Error","commands","diag","cmds","sys","level","tail","mount","AlreadyInitializedError","initOptions","enabled","isTest","addresses","init","id2","code","encode","decode","blockCodecs","concat","codec","multicodecs$1","Multicodecs","loadCodec","silent","console","storage$1","Storage","getAll","startOffline","isNew","emptyRepo","buf","Data","UnixFS","type","marshal","Links","put","mhtype","format","addEmptyDir","initializeKeyspace","privKey","isOptionObject","hasOwnProperty","prototype","propertyIsEnumerable","writable","configurable","globalThis","defaultMergeOptions","concatArrays","getEnumerableOwnPropertyKeys","call","getOwnPropertySymbols","symbols","symbol","clone","Array","isArray","array","result","slice","cloneArray","getPrototypeOf","cloneOptionObject","mergeKeys","merged","merge","resultIndex","indices","length","String","filter","includes","module","_","option","TypeError","toString","isElectron","IS_ENV_WITH_DOM","nodeType","IS_ELECTRON","IS_BROWSER","IS_ELECTRON_MAIN","IS_ELECTRON_RENDERER","IS_NODE","process","release","IS_WEBWORKER","importScripts","self","WorkerGlobalScope","IS_TEST","env","IS_REACT_NATIVE","product","isElectronMain","isElectronRenderer","isNode","isBrowser","isWebWorker","isEnvWithDom","isReactNative","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","setTimeout","clearTimeout","e1","currentQueue","queue","draining","queueIndex","cleanUpNextTick","drainQueue","timeout","len","run","marker","runClearTimeout","Item","noop","nextTick","args","arguments","i","apply","browser","argv","versions","addListener","once","off","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","cwd","chdir","dir","umask","electron","userAgent","indexOf","formatArgs","useColors","namespace","humanize","diff","c","color","splice","lastC","match","save","namespaces","setItem","removeItem","error","load","r","getItem","__nwjs","toLowerCase","documentElement","WebkitAppearance","firebug","exception","table","parseInt","$1","localStorage","localstorage","destroy","warned","warn","colors","formatters","j","v","JSON","stringify","createDebug","prevTime","namespacesCache","enabledCache","enableOverride","curr","Number","Date","ms","prev","coerce","unshift","formatter","val","selectColor","extend","set","delimiter","newDebug","toNamespace","regexp","substring","stack","disable","names","map","skips","join","enable","split","substr","test","charCodeAt","abs","s","m","h","w","y","plural","msAbs","isPlural","str","parseFloat","parse","isFinite","long","fmtShort","obj","props","err","ErrClass","errcode","unixfs","errcode__default","PBData","types","dirTypes","DEFAULT_FILE_MODE","DEFAULT_DIRECTORY_MODE","parseMode","mode","parseMtime","input","mtime","secs","nsecs","Seconds","FractionalNanoseconds","getTime","floor","marshaled","decoded","toObject","defaults","arrays","longs","objects","data","Type","blockSizes","blocksizes","_originalMode","hashType","fanout","_mode","isDirectory","parsedMode","Boolean","addBlockSize","size1","removeBlockSize","fileSize","sum","size","DataType","Raw","Directory","File","Metadata","Symlink","HAMTShard","parsed","pbData","filesize","finish","$protobuf__default","$Reader","Reader","$Writer","Writer","$util","util","$root","roots","Data1","p","ks","newBuffer","Long","fromBits","emptyArray","uint32","int32","bytes","uint64","UnixTime","fork","ldelim","l","pos","t","c2","skipType","ProtocolError","instance","fromObject","base64","fromValue","unsigned","LongBits","low","high","toNumber","o","enums","toJSON","constructor","toJSONOptions","valuesById","UnixTime1","int64","fixed32","Metadata1","MimeType","string","protobuf","configure","_configure","BufferWriter","BufferReader","build","rpc","utf8","Op","fn","next","State","writer","head","states","Buffer","writeByte","VarintOp","writeVarint64","hi","lo","writeFixed32","alloc","pool","subarray","_push","fromNumber","sint32","bits","from","sint64","zzEncode","bool","sfixed32","fixed64","sfixed64","float","writeFloatLE","double","writeDoubleLE","writeBytes","isString","write","reset","BufferWriter_","dst","src","ifNotSet","newError","CustomError","properties","captureStackTrace","asPromise","EventEmitter","inquire","global","emptyObject","isInteger","isObject","isset","isSet","prop","utf8Write","_Buffer_from","_Buffer_allocUnsafe","sizeOrArray","Uint8Array","dcodeIO","key2Re","key32Re","key64Re","longToHash","toHash","zeroHash","longFromHash","fromHash","lcFirst","charAt","oneOfGetter","fieldNames","fieldMap","i1","oneOfSetter","json","encoding","allocUnsafe","ctx","params1","offset1","pending","params","offset","ceil","s64","b64","buffer","end","chunk","b","parts","fromCharCode","invalidEncoding","_listeners","evt","factory","Float32Array","f32","f8b","le","writeFloat_f32_cpy","writeFloat_f32_rev","readFloat_f32_cpy","readFloat_f32_rev","writeFloatBE","readFloatLE","readFloatBE","writeFloat_ieee754","writeUint","sign","isNaN","exponent","LN2","pow","readFloat_ieee754","readUint","uint","mantissa","NaN","Infinity","writeUintLE","writeUintBE","readUintLE","readUintBE","Float64Array","f64","writeDouble_f64_cpy","writeDouble_f64_rev","readDouble_f64_cpy","readDouble_f64_rev","writeDoubleBE","moduleName","mod","eval","c1","zero","zzDecode","toLong","mask","part0","part1","part2","writeStringBuffer","writeBytesBuffer","copy","byteLength","indexOutOfRange","reader","writeLength","RangeError","create_array","buffer1","isBuffer","readLongVarint","readFixed32_end","readFixed64","_slice","readDoubleLE","read","skip","wireType","BufferReader_","utf8Slice","min","rpcImpl","requestDelimited","responseDelimited","rpcCall","method","requestCtor","responseCtor","request","callback","response","err1","endedByRPC","pbDecode","pbEncode","createLink","createNode","prepare","validate","pbn","decodeNode","link","Hash","Name","Tsize","encodeNode","varint","digest","base58","base32","bytes3","version1","code3","multihash1","bytes1","multihash","byteOffset","asCID","_baseCache","Map","defineProperties","hidden","readonly","toV0","DAG_PB_CODE","SHA_256_CODE","createV0","toV1","digest$1","createV1","equals","other","base2","toStringV0","base58btc","encoder","toStringV1","toStringTag","Symbol","for","deprecate","IS_CID_DEPRECATION","cidSymbol","toBaseEncodedString","multibaseName","prefix","value1","encodeCID","version2","code1","digest1","digest2","code2","digest3","bytes2","remainder","decodeFirst","bytes$1","specs","inspectBytes","prefixSize","multihashSize","multihashBytes","digestBytes","digestSize","Digest","multihashCode","initialBytes","source1","base1","parseCIDtoBytes","decoder","cache","codeOffset","encodingLength","hashOffset","encodeTo","range","varint$1","int","target","encode_1","num","out","oldOffset","INT","res","shift","counter","N1","N2","N3","N4","N5","N6","N7","N8","N9","sizeOffset","digestOffset","a","empty","ArrayBuffer","isView","aa","bb","ii","fromHex","hex","hexes","TextEncoder","isBinary","toHex","reduce","byte","padStart","TextDecoder","baseX","alphabet","base58flickr","baseX$1","Encoder","name3","prefix3","baseEncode","Decoder","name1","prefix1","baseDecode","text1","or","ComposedDecoder","decoders","decoder1","input3","right","Codec","name2","prefix2","baseEncode1","baseDecode1","input1","input2","text","rfc4648","bitsPerChar","pad","encode1","codes","written","SyntaxError","decode1","_brrp__multiformats_scope_baseX","ALPHABET","BASE_MAP","x","xc","BASE","LEADER","FACTOR","iFACTOR","decodeUnsafe","psz","zeroes","b256","carry","it3","it4","vch","pbegin","pend","b58","it1","it2","repeat","base32upper","base32pad","base32padupper","base32hex","base32hexupper","base32hexpad","base32hexpadupper","base32z","textDecoder","decodeVarint","decodeBytes","byteLen","postOffset","decodeKey","wire","decodeLink","fieldNum","byts","links","linksBeforeData","textEncoder","maxInt32","encodeLink","isSafeInteger","encodeVarint","nameBytes","sizeLink","sov","len8tab","len64","sizeNode","cid1","pbNodeProperties","pbLinkProperties","linkComparator","abuf","bbuf","hasOnlyProperties","some","asLink","pbl","cid$1","sort","cborg","cborg__namespace","encodeOptions","float64","typeEncoders","Token","tag","number","decodeOptions","allowIndefinite","allowUndefined","allowNaN","allowInfinity","allowBigInt","strict","useMaps","tags","token","is","token1","bl","common","jump","byteUtils","_0uint","_1negint","_2bytes","_3string","_4array","_5map","_6tag","_7float","defaultEncodeOptions","mapSorter","e2","keyToken1","keyToken2","compare","major","tcmp","cborEncoders","compareTokens","quickEncodeToken","encodeUint","negint","encodeNegint","encodeBytes","encodeString","encodeArray","encodeMap","encodeTag","encodeFloat","buf1","Bl","Ref","obj3","parent","obj1","obj2","encodeErrPrefix","simpleTokens","null","true","false","emptyMap","_typ","_options","_refStack","bigint","BigInt","boolean","_obj","DataView","refStack","addBreakTokens","break","createCheck","entries","objectToTokens","typ","isMap","sortMapEntries","typ1","customTypeEncoder","tokens","typeEncoder","tokensToEncoded","encoders","encodeCustom","quickBytes","encodedSize","chunks","asU8A","toBytes","typeofs","objectTypeNames","typeOf","objectType","objectTypeName","getObjectType","terminal","majorEncoded","encodedLength","encodedBytes","chunkSize","cursor","maxCursor","_initReuseChunk","topChunk","chunkPos","useBuffer","utf8ToBytes","units","codePoint","leadSurrogate","firstByte","bytesPerSequence","secondByte","thirdByte","fourthByte","tempCodePoint","decodeCodePointsArray","codePoints","b1","b2","fromArray","arr","decodeErrPrefix","uintMinorPrefixBytes","assertEnoughData","need","invalidMinor","minor","errorer","msg","decodeUint8","decodeUint16","decodeUint32","decodeUint64","decodeNegint8","decodeNegint16","decodeNegint32","decodeNegint64","i2","decodeBytesCompact","decodeBytes8","decodeBytes16","decodeBytes32","decodeBytes64","i3","decodeStringCompact","decodeString8","decodeString16","decodeString32","decodeString64","i4","decodeArrayCompact","decodeArray8","decodeArray16","decodeArray32","decodeArray64","decodeArrayIndefinite","i5","decodeMapCompact","decodeMap8","decodeMap16","decodeMap32","decodeMap64","decodeMapIndefinite","i6","decodeTagCompact","decodeTag8","decodeTag16","decodeTag32","decodeTag64","i7","decodeUndefined","decodeFloat16","decodeFloat32","decodeFloat64","decodeBreak","quick","i8","i9","token$1","uintBoundaries","readUint8","readUint16","readUint32","readUint64","MAX_SAFE_INTEGER","encodeUintValue","nuint","buint","tok1","tok2","_minor","neg1b","pos1b","MIN_SAFE_INTEGER","toToken","tokenBytes","compareBytes","totLength","_data","_pos","createToken","success","encodeFloat16","readFloat16","ui8a1","encodeFloat32","readFloat32","inp","dataView","setFloat64","readFloat64","setUint16","setFloat32","valu32","getUint32","logicalExponent","ui8a","half","exp","mant","getFloat32","getFloat64","defaultDecodeOptions","Tokeniser","data1","done","byt","DONE","BREAK","tokensToObject","tokeniser","tokenToArray","tokenToMap","tagged","tokenizer","Hasher","base8","base10","base16","base36","sha2","identity$1","raw","base16upper","base36upper","base64pad","base64url","base64urlpad","sha","subtle","sha256","sha512","NotInitializedError","super","AlreadyInitializingError","message1","message2","NotStartedError","message3","AlreadyStartingError","message4","AlreadyStartedError","message5","NotEnabledError","message6","createCodec","string1","ascii","BASES","latin1","binary","all","startOnline","utils","state","activate","promise","ready","panic","service1","deactivate","state1","withTimeout","state2","options2","use","key1","withTimeoutOption","toCidAndPath","MFS_ROOT_KEY","Key","path","getCodec","blocks","lastCid","remainderPath","find","MFS_MAX_CHUNK_SIZE","MFS_MAX_LINKS","OFFLINE_ERROR","mapFile","file","output","normalizeCidPath","normalizePath","pathStr","resolvePath","ipfsPath","lastRemainderPath","startsWith","signal","mafmt","URL","uint8ArrayToString","pathGatewayPattern","pathPattern","subdomainGatewayPattern","fqdnWithTld","isCID","isMultiaddr","pattern","protocolMatch","hashMatch","formatted","convertToString","isIpns","ipnsId","hostname","ipfsSubdomain","ipnsSubdomain","subdomain","ipfsUrl","ipnsUrl","url1","path1","peerMultiaddr","P2P","matches","base32cid","isBase32EncodedMultibase","ipnsPath","urlOrPath","cidPath","protocols","inspect","uint8ArrayEquals","resolvers","addr7","fromBytes","bytesToString","toOptions","opts","family","host","transport","port","protos","protoCodes","sizeForAddr","protoNames","proto","tuples","bytesToTuples","stringTuples","tuplesToStringTuples","encapsulate","addr1","decapsulate","addr2","addrString","lastIndexOf","decapsulateCode","tuplesToBytes","getPeerId","tuple1","tuple","pop","peerIdStr","getPath","addr3","resolvableProto","resolvable","resolver","nodeAddress","address","isThinWaistAddress","addr4","static","addr5","ip","addr6","addr","convert","uint8ArrayConcat","stringToStringTuples","part","ParseError","cleanPath","stringTuplesToString","tup","protoFromTuple","stringTuplesToTuples","stringToBytes","validateBytes","trim","isValidBytes","uint8ArrayFromString","Convert","ip2bytes","ipString","isIP","port2bytes","bytes2port","getUint16","bytes2onion","addrBytes","portBytes","ipBuff","bytes2ip","bytes2str","bytes2mh","str2bytes","mh","mh2bytes","portBuf","onion2bytes","onion32bytes","isIp","isV4","v4","isV6","v6","buff","sections","v4Buffer","word","view","ipRegex","exact","includeBoundaries","v6seg","Protocols","V","lengthPrefixedVarSize","row","acc","DNS4","DNS6","DNSADDR","DNS","IP","TCP","and","UDP","UTP","QUIC","WebSockets","WebSocketsSecure","HTTP","HTTPS","WebRTCStar","WebSocketStar","WebRTCDirect","Reliable","Stardust","_P2P","_Circuit","CircuitRecursive","Circuit","makeMatchesFunction","partialMatch","arg","ma","pnames","URLWithLegacySupport","URLSearchParams","defaultBase","relative","protocol","pathname","auth","username","password","query","href","origin","searchParams","hash1","host1","hostname1","pathname1","port1","protocol1","search1","createObjectURL","o1","revokeObjectURL","userPass","protocolMap","defaultProtocol","urlParsed","nanoid","pathSepS","pathSepB","pathSep","clean","_buf","uint8Array","list","fill","less","key2","list1","list2","reverse","withNamespaces","baseNamespace","ns","namespaceType","namespaceValue","s1","endsWith","child","isAncestorOf","other1","isDecendantOf","other2","isTopLevel","customAlphabet","customRandom","_indexJs","getRandomValues","getRandom","step","toUpperCase","urlAlphabet","interopDefault","defineInteropFlag","exportAll","dest","export","destName","TimeoutController","anySignal","parseDuration","TimeoutController__default","parseDuration__default","optionsArgIndex","controller","fnRes","timeoutPromise","_resolve","TimeoutError","now","maybeThrowTimeoutError","aborted","abort","asyncIterator","it","race","clear","return","AbortController","retimer","_ms","_timer","setPrototypeOf","AbortSignal","Retimer","that","_started","_rescheduled","_scheduled","_args","timerWrapper","reschedule","signals","onAbort","removeEventListener","signal1","impl","durationRE","nanosecond","us","microsecond","millisecond","second","sec","minute","hour","hr","day","week","wk","month","year","yr","IPFS_PREFIX","close","domain","recursive","fqdnFixups","resolveDnslink","tlru","PQueue","PQueue__default","HTTP__default","TLRU","httpQueue","concurrency","Path","Message","fqdn1","opts1","fqdn","query1","nocache","has","hashlru__default","maxSize","lru","expire","remove","ttl","key3","max","_cache","update","p_timeout_1","priority_queue_1","timeoutError","_a","_b","_c","_d","_intervalCount","_intervalEnd","_pendingCount","_resolveEmpty","_resolveIdle","carryoverConcurrencyCount","intervalCap","interval","autoStart","queueClass","_carryoverConcurrencyCount","_isIntervalIgnored","_intervalCap","_interval","_queue","_queueClass","_timeout","_throwOnTimeout","throwOnTimeout","_isPaused","_doesIntervalAllowAnother","_doesConcurrentAllowAnother","_concurrency","_next","_tryToStartAnother","_resolvePromises","_onResumeInterval","_onInterval","_initializeIntervalIfNeeded","_timeoutId","_isIntervalPaused","_intervalId","delay","clearInterval","canInitializeInterval","job","dequeue","setInterval","_processQueue","newConcurrency","enqueue","operation","functions","function_","pause","existingResolve","sizeBy","options3","isPaused","milliseconds","EE","context","emitter","event","listener","_events","_eventsCount","clearEvent","__proto__","eventNames","events","handlers","ee","listenerCount","a1","a2","a3","a4","a5","prefixed","pFinally","pTimeout","fallback","timer","cancel","then","onFinally","lower_bound_1","element","priority","item","comparator","first","count","fetch","Request","Headers","HTTPError","throwHttpErrors","credentials","options7","resource6","headers","transformSearchParams","abortController","timedOut","timeoutID","after","ok","handleError","iterator","fromStream","ndjson","transform","post","resource1","resource2","resource3","options4","delete","resource4","options5","resource5","options6","stream","lines","isNodeReadableStream","iter","isWebReadableStream","getReader","releaseLock","isAsyncIterable","streamToAsyncIterator","resource","AbortError","Response","fetchWithStreaming","parseHeaders","line","ResponseWithURL","onUploadProgress","XMLHttpRequest","open","overrideMimeType","setRequestHeader","onabort","upload","onprogress","responseType","handleEvent","responseURL","statusText","getAllResponseHeaders","onerror","onload","ontimeout","send","fetchWithProgress","getGlobal","isStarted","resolvedPath","schema","rest","cidBase","getBase","parseBytes","b32","b36","cryptoKeys","withIs","PeerIdProto","baseDecoder","PeerIdWithIs","id3","privKey2","pubKey2","public","_id","_idB58String","_privKey","_pubKey","val1","privKey1","pubKey","unmarshalPublicKey","pubKey1","marshalPubKey","marshalPublicKey","marshalPrivKey","marshalPrivateKey","excludePriv","toPrint","pid","toB58String","maxRunes","toB64Opt","toHexString","_idCIDString","isEqual","isValid","hasInlinePublicKey","className","symbolName","computeDigest","computePeerId","keyType","generateKeyPair","createFromHexString","createFromBytes","validMulticodec","createFromCID","createFromB58String","createFromPubKey","createFromPrivKey","unmarshalPrivateKey","createFromJSON","rawPrivKey","rawPubKey","pub","privDigest","pubDigest","createFromProtobuf","isPeerId","keysPBM","forge","importer","supportedKeys","rsa","ed25519","secp256k1","ErrMissingSecp256K1","typeToKey","supported","PrivateKey","KeyType","RSA","unmarshalRsaPrivateKey","Ed25519","unmarshalEd25519PrivateKey","Secp256k1","unmarshalSecp256k1PrivateKey","keyStretcher","generateEphemeralKeyPair","generateKeyPairFromSeed","seed","PublicKey","unmarshalRsaPublicKey","unmarshalEd25519PublicKey","unmarshalSecp256k1PublicKey","import","encryptedKey","pki","decryptRsaPrivateKey","der","asn1","toDer","privateKeyToAsn1","getBytes","$protobuf","_checkBufferLength","remaining","available","requested","Class","UNIVERSAL","APPLICATION","CONTEXT_SPECIFIC","PRIVATE","NONE","BOOLEAN","INTEGER","BITSTRING","OCTETSTRING","NULL","OID","ODESC","EXTERNAL","REAL","ENUMERATED","EMBEDDED","UTF8","ROID","SEQUENCE","SET","PRINTABLESTRING","IA5STRING","UTCTIME","GENERALIZEDTIME","BMPSTRING","tagClass","constructed","tmp","composed","bitStringContents","original","excludeBitStringContents","equal","includeBitStringContents","getBerValueLength","getByte","getInt","_fromDer","depth","longFormBytes","_getValueLength","decodeBitStrings","savedRead","savedRemaining","unused","verbose","used","tc","ex","getInt16","asn1Options","fromDer","createBuffer","useBitStringContents","putBytes","putByte","putBuffer","putInt16","lenBytes","oidToDer","oid","last","valueBytes","derToOid","utcTimeToDate","utc","date","MM","DD","hh","mm","ss","setUTCFullYear","setUTCHours","setTime","generalizedTimeToDate","gentime","YYYY","fff","isUTC","setFullYear","setHours","dateToUtcTime","rval","getUTCFullYear","getUTCMonth","getUTCDate","getUTCHours","getUTCMinutes","getUTCSeconds","dateToGeneralizedTime","integerToDer","putSignedInt","integer","derToInteger","getSignedInt","capture","optional","captureAsn1","captureBitStringContents","captureBitStringValue","_nonLatinRegex","prettyPrint","indentation","indent","IA5String","subvalues","sub","oids","bytesToHex","decodeUtf8","usePureJavaScript","baseN","_checkBitsParam","ByteStringBuffer","isArrayBuffer","isArrayBufferView","_constructedStringLength","setImmediate","postMessage","callbacks","MutationObserver","attr","div","createElement","observe","attributes","oldSetImmediate","setAttribute","isNodejs","globalScope","ByteBuffer","_MAX_CONSTRUCTED_STRING_LENGTH","DataBuffer","readOffset","growSize","writeOffset","_optimizeConstructedString","isEmpty","fillWithByte","putString","encodeUtf8","putInt24","putInt32","putInt16Le","putInt24Le","putInt32Le","putInt","getInt24","getInt32","getInt16Le","getInt24Le","getInt32Le","at","setAt","compact","truncate","accommodate","amount","setUint8","Uint16Array","utf16","setInt16","setInt8","setInt32","getInt8","getUint8","fillString","xorBytes","s2","s3","hexToBytes","int32ToBytes","_base64","_base64Idx","_base58","encode64","maxline","chr1","chr2","chr3","decode64","enc1","enc2","enc3","enc4","unescape","escape","deflate","api","inflate","_setStorageObject","_getStorageObject","_setItem","_getItem","_removeItem","_clearItems","_callStorageFunction","func","idx","clearItems","parseUrl","regex","lastIndex","full","scheme","fullHost","_queryVariables","getQueryVariables","rval1","q","kvpairs","parseFragment","fragment","fp","fq","pathString","queryString","makeRequest","reqString","frag","req","getQuery","getQueryLast","_default","vals","makeLink","jQuery","qstr","param","re","argi","formatNumber","decimals","dec_point","thousands_sep","toFixed","formatSize","bytesFromIP","bytesFromIPv4","bytesFromIPv6","blanks","zeros","bytesToIP","bytesToIPv4","bytesToIPv6","zeroGroups","zeroMaxGroup","group","estimateCores","callback1","cores","hardwareConcurrency","Worker","Blob","blobUrl","st","et","sample","samples","numWorkers","avg1","avg","workers","worker","terminate","overlaps","r1","overlap","r2","_reverseAlphabets","digits","_encodeWithByteBuffer","_IN","_I_","BigInteger","jsbn","pbe","encryptedPrivateKeyValidator","PBES2AlgorithmsValidator","pkcs12PbeParamsValidator","md","prfOidToMessageDigest","prfOid","prfAlgorithm","prfAlgorithmToMessageDigest","algorithm","encryptPrivateKeyInfo","saltSize","dkLen","encryptionAlgorithm","encryptedData","salt","getBytesSync","countBytes","ivLen","encOid","cipherFn","aes","createEncryptionCipher","des","dk","pkcs5","pbkdf2","iv","cipher","createPbkdf2Params","saltBytes","generatePkcs12Key","decryptPrivateKeyInfo","encryptionOid","getCipher","encryptionParams","encrypted","encryptedPrivateKeyToPem","epki","pem","encryptedPrivateKeyFromPem","headerType","procType","encryptRsaPrivateKey","rsaKey","legacy","wrapRsaPrivateKey","opensslDeriveBytes","dekInfo","parameters","createDecryptionCipher","rc2","privateKeyFromAsn1","sha1","u","digestLength","blockLength","passBuf","D","Slen","S","Plen","P","I","B","Inew","getCipherForPBES2","getCipherForPKCS12PBE","supportedOids","kdfOid","kdfSalt","kdfIterationCount","encIv","dIvLen","iterations","startDecrypting","md5","digests","registerAlgorithm","Algorithm","startEncrypting","_createCipher","decrypt","initialize","blockSize","encrypt","inBlock","outBlock","_updateBlock","_w","_init","encryptOp","_expandKey","modes","ecb","cbc","cfb","ofb","ctr","gcm","sbox","isbox","rcon","mix","imix","xtime","e4","e8","sx","sx2","me","ime","ei","temp","iNk","Nk","m0","m1","m2","m3","wnew","wi","Nr","createDecipher","createCipher","algorithms","getAlgorithm","BlockCipher","_finish","_input","_op","_decrypt","unpad","overflow","afterFinish","transformIV","ints","inc32","from64To32","_ints","_inBlock","_outBlock","padding","_prev","_iv","_partialBlock","_partialOutput","_partialBytes","inputLength","partialBytes","_R","additionalData","_cipherLength","_tagLength","tagLength","_tag","_hashBlock","_hashSubkey","componentBits","_m","generateHashTable","ivLength","_j0","ghash","_aDataLength","_s","lengths","multiply","z_i","v_i","lsb","tableMultiply","z","x_i","ah","multiplier","perInt","shft","generateSubHashTable","mid","m_i","m_j","_keys","pc2bytes0","pc2bytes1","pc2bytes2","pc2bytes3","pc2bytes4","pc2bytes5","pc2bytes6","pc2bytes7","pc2bytes8","pc2bytes9","pc2bytes10","pc2bytes11","pc2bytes12","pc2bytes13","shifts","lefttmp","righttmp","_createKeys","spfunction1","spfunction2","spfunction3","spfunction4","spfunction5","spfunction6","spfunction7","spfunction8","looping","endloop","loopinc","right1","right2","pbkdf2Sync","hLen","prf","hmac","xor","u_c","u_c1","outer","inner","_key","_md","_ipadding","_opadding","keylen","getMac","foldHeader","header","insertSpace","candidate","insert","ltrim","contentDomain","rMessage","rHeader","rCRLF","li","nl","vi","prng_aes","_prng_aes_output","_prng_aes_buffer","spawnPrng","prng","generate","formatKey","formatSeed","increment","_ctx","_crypto","msCrypto","collectInt","_navBytes","collect","mousemove","clientX","clientY","keypress","charCode","createInstance","_initialized","_padding","_k","_state","messageLength","fullMessageLength","messageLengthSize","messageLength64","int32s","h0","h1","h2","h3","h4","h5","h6","h7","_update","finalBlock","t1","t2","s0","maj","f","g","_crypto1","plugin","reseeds","generated","keyBytes","md1","pools","_reseedSync","_seed","needed","seedFileSync","_2powK","seedBytes","defaultSeedFile","entropy","Uint32Array","QuotaExceededError","generateSync","seedFile","_reseed","randomBytes","registerWorker","piTable","rol","ror","expandKey","effKeyBits","L","T","T1","T8","TM","mixRound","mashRound","_output","K","R","runPlan","plan","ptr","GCD_30_DELTA","privateKeyValidator","rsaPrivateKeyValidator","rsaPublicKeyValidator","publicKeyValidator","emsaPkcs1v15encode","oidBytes","digestInfo","digestAlgorithm","_modPow","modPow","dP","subtract","ONE","dQ","qInv","modInverse","bitLength","compareTo","gcd","xp","xq","_encodePkcs1_v1_5","bt","eb","padByte","padNum","numZeros","padBytes","_decodePkcs1_v1_5","em","ml","_generateKeyPair","workLoad","workerScript","getPrime","pBits","qBits","prime","generateProbablePrime","p1","q1","phi","privateKey","setPrivateKey","publicKey","setPublicKey","_bnToBytes","_getMillerRabinTests","_detectNodeCrypto","_detectSubtleCrypto","_detectSubtleMsCrypto","_intToUint8Array","yhex","ed","expected","xhex","createKeyPairGenerationState","rng","nextBytes","eInt","pqState","fromInt","stepKeyPairGenerationState","THIRTY","deltaIdx","op_or","total","bits1","testBit","bitwiseTo","shiftLeft","dAddOffset","byteValue","isProbablePrime","modulusLength","publicExponent","publicKeyEncoding","privateKeyEncoding","priv","privateKeyFromPem","publicKeyFromPem","generateKey","pair","exportKey","pkcs8","setRsaPublicKey","genOp","oncomplete","exportOp","keypair","generateKeyPairSync","e3","schemeOptions","pkcs1","encode_rsa_oaep","signature","verify","d1","setRsaPrivateKey","d2","d3","decode_rsa_oaep","rsaEncryption","privateKeyModulus","privateKeyPublicExponent","privateKeyPrivateExponent","privateKeyPrime1","privateKeyPrime2","privateKeyExponent1","privateKeyExponent2","privateKeyCoefficient","privateKeyToRSAPrivateKey","publicKeyFromAsn1","publicKeyOid","rsaPublicKey","publicKeyModulus","publicKeyExponent","publicKeyToAsn1","publicKeyToSubjectPublicKeyInfo","publicKeyToRSAPublicKey","dbits","nbi","am3","xl","xh","am","appName","DB","DM","DV","FV","F1","F2","rr","vv","BI_RC","int2char","intAt","nbv","nbits","Classic","Montgomery","mp","invDigit","mpl","mph","um","mt2","op_and","op_xor","op_andnot","lbit","cbit","NullExp","nNop","Barrett","q3","dlShiftTo","mu","divide","revert","divRemTo","mulTo","multiplyTo","sqrTo","squareTo","ZERO","subTo","copyTo","u0","clamp","drShiftTo","fromRadix","mi","sh","lShiftTo","bs","cbs","bm","ds","rShiftTo","pm","pt","ts","nsh","ys","y0","yt","qd","isEven","negate","toRadix","km","modPowInt","multiplyUpperTo","multiplyLowerTo","lowprimes","lplim","signum","cs","intValue","dMultiply","op","changeBit","addTo","modInt","millerRabin","n1","getLowestSetBit","shiftRight","shortValue","toByteArray","andNot","not","bitCount","setBit","clearBit","flipBit","divideAndRemainder","k1","g2","is1","ac","rsa_mgf1","maskLength","label","mgf1Md","mgf1","keyLength","maxLength","lHash","PS","PS_length","seedLength","dbMask","maskedDB","seedMask","maskedSeed","expectedLength","db","lHashPrime","in_ps","is_0","error_mask","primeincFindPrimeWithoutWorkers","generateRandom","workerMessage","found","primeincFindPrimeWithWorkers","primeincFindPrime","mrTests","getMillerRabinTests","millerRabinTests","maxBlockTime","_primeinc","ciphers","webcrypto","nonceLength","saltLength","nonce","aesGcm","deriveParams","rawKey","importKey","cryptoKey","deriveKey","ciphertext","plaintext","win","nativeCrypto","pbm","exporter","RsaPublicKey","sig","hashAndVerify","jwkToPkix","RsaPrivateKey","_publicKey","genSecret","hashAndSign","jwkToPkcs1","jwk","pkixToJwk","pkcs1ToJwk","fromJwk","sha384","sha224","_states","_h","messageLength128","hlen","t1_hi","t1_lo","t2_hi","t2_lo","s0_hi","s0_lo","s1_hi","ch_hi","maj_hi","maj_lo","a_hi","a_lo","b_hi","b_lo","c_hi","c_lo","d_hi","d_lo","e_hi","e_lo","f_hi","f_lo","g_hi","g_lo","h_hi","h_lo","w2","w7","w15","w16","asn1Validator","NativeBuffer","messageToNativeBuffer","constants","PUBLIC_KEY_BYTE_LENGTH","PRIVATE_KEY_BYTE_LENGTH","SEED_BYTE_LENGTH","SIGN_BYTE_LENGTH","HASH_BYTE_LENGTH","pk","sk","gf","scalarbase","pack","crypto_sign_keypair","privateKeyOid","ed25519Oid","EdDSA25519","privateKeyBytes","publicKeyBytes","ed25519PublicKey","publicKeyFromPrivateKey","signedMsg","sm","smlen","modL","crypto_sign","chk","den","den2","den4","den6","set25519","gf1","unpack25519","M","Z","A","pow2523","neq25519","par25519","gf0","unpackneg","scalarmult","crypto_verify_32","crypto_sign_open","D2","X","Y","msgLen","cswap","sel25519","tx","ty","zi","inv25519","pack25519","car25519","xi","yi","vn","t0","t3","t4","t5","t6","t7","t8","t9","t10","t11","t12","t13","t14","t15","t16","t17","t18","t19","t20","t21","t22","t23","t24","t25","t26","t27","t28","t29","t30","b0","b3","b4","b5","b6","b7","b8","b9","b10","b11","b12","b13","b14","b15","jwKey","kty","jwk2pub","jwk2priv","convertKey","handle","fkey","fomsg","msg1","msg2","MAX_BYTES","bigIntegerToUintBase64url","base64urlToBigInteger","dp","dq","qi","alg","kid","base64urlToBuffer","Ed25519PublicKey","key4","ensureKey","publicKeyLength","Ed25519PrivateKey","publicKey1","privateKeyLength","generateKeyFromSeed","keysProtobuf","Secp256k1PublicKey","validatePublicKey","compressPublicKey","Secp256k1PrivateKey","computePublicKey","validatePrivateKey","privateKeyVerify","ecdsaSign","signatureExport","signatureImport","ecdsaVerify","publicKeyVerify","publicKeyConvert","decompressPublicKey","publicKeyCreate","assert","cond","isUint8Array","isCompressed","toTypeString","getAssertedOutput","contextRandomize","seckey","privateKeyNegate","privateKeyTweakAdd","tweak","privateKeyTweakMul","pubkey","compressed","publicKeyNegate","publicKeyCombine","pubkeys","publicKeyTweakAdd","publicKeyTweakMul","signatureNormalize","outputlen","msg32","noncefn","recid","ecdsaRecover","ecdh","hashfn","xbuf","ybuf","ec","EC","ecparams","curve","BN","loadPublicKey","cmp","toRed","red","redSqr","redIMul","redIAdd","redSqrt","isOdd","redNeg","keyPair","loadCompressedPublicKey","x3","redISub","isZero","loadUncompressedPublicKey","savePublicKey","point","bn","umod","toArrayLike","iadd","isub","tweaked","imul","keyFromPrivate","getPublic","pairs","isInfinity","mul","nh","sigR","sigS","lenR","posR","lenS","posS","_noncefn","canonical","pers","recoveryParam","sigObj","sigr","sigs","recoverPubKey","scalar","getX","toArray","getY","elliptic","rand","curves","eddsa","minAssert","minUtils","zero2","getNAF","naf","ws","andln","isubn","iushrn","getJSF","k2","jsf","m8","cmpn","u1","u2","m14","m24","cachedProperty","computer","intFromLE","inherits","ctor","superCtor","super_","TempCtor","endian","isBN","negative","words","wordSize","parseHex4Bits","parseHexByte","lowerBound","parseBase","_initNumber","_initArray","_parseHex","_parseBase","strip","limbLen","limbPow","imuln","_iaddn","_expand","_normSign","groupSizes","groupBases","smallMulTo","ncarry","rword","maxJ","groupSize","groupBase","modn","idivn","ret","toBuffer","ArrayType","reqLength","littleEndian","clz32","_countBits","_zeroBits","zeroBits","toTwos","width","inotn","iaddn","fromTwos","testn","notn","ineg","isNeg","neg","iuor","ior","uor","iuand","iand","uand","iuxor","ixor","uxor","bytesNeeded","bitsLeft","setn","bit","wbit","comb10MulTo","a0","al0","ah0","al1","ah1","al2","ah2","al3","ah3","al4","ah4","al5","ah5","a6","al6","ah6","a7","al7","ah7","a8","al8","ah8","a9","al9","ah9","bl0","bh0","bl1","bh1","bl2","bh2","bl3","bh3","bl4","bh4","bl5","bh5","bl6","bh6","bl7","bh7","bl8","bh8","bl9","bh9","w0","w1","w3","w4","w5","w6","w8","w9","w10","w11","w12","w13","w14","w17","w18","jumboMulTo","FFTM","mulp","hncarry","bigMulTo","makeRBT","N","revBin","rb","permute","rbt","rws","iws","rtws","itws","rtwdf","cos","PI","itwdf","sin","rtwdf_","itwdf_","ie","ro","io","rx","guessLen13b","odd","conjugate","normalize13b","convert13b","stub","ph","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","muln","sqr","isqr","toBitArray","iushln","carryMask","newCarry","ishln","hint","extended","maskedWords","ishrn","shln","ushln","shrn","ushrn","imaskn","maskn","addn","subn","iabs","_ishlnsubmul","_wordDiv","bhi","qj","divmod","positive","divn","divRound","dm","egcd","C","yp","im","jm","_invmp","x1","x2","delta","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","eq","Red","convertTo","_forceRed","fromRed","convertFrom","forceRed","redAdd","redSub","redShl","shl","redMul","_verify2","_verify1","redISqr","sqrt","redInvm","redPow","primes","k256","p224","p192","p25519","MPrime","_tmp","K256","P224","P192","P25519","_prime","Mont","imod","rinv","minv","ireduce","rlen","imulK","_strip","outLen","mod3","one","nOne","lpow","inv","wnd","current","currentLen","mont","enc","Rand","_rand","short","edwards","BaseCurve","conf","two","pointFromJSON","gRed","_wnafT1","_wnafT2","_wnafT3","_wnafT4","_bitLength","adjustCount","redN","_maxwellTrick","BasePoint","precomputed","_fixedNafMul","doubles","_getDoubles","nafW","repr","jpoint","mixedAdd","points","toP","_wnafMul","nafPoints","_getNAFPoints","dblp","_wnafMulAdd","defW","coeffs","jacobianResult","wndWidth","comb","toJ","ja","jb","decodePoint","pointFromX","encodeCompressed","_encode","precompute","power","beta","_getBeta","_hasDoubles","dbl","Base","ShortCurve","tinv","zeroA","threeA","endo","_getEndomorphism","_endoWnafT1","_endoWnafT2","Point","isRed","inf","JPoint","zOne","lambda","betas","_getEndoRoots","lambdas","basis","vec","_getEndoBasis","ntinv","prevR","aprxSqrt","y1","y2","len1","_endoSplit","v1","v2","p2","q2","ax","rhs","_endoWnafMulAdd","npoints","ncoeffs","fromJSON","pre","endoMul","obj2point","nx","ny","ys1","dyinv","mulAdd","jmulAdd","_precompute","zinv","zinv2","ay","pz2","z2","nz","jx","jy","jz","jz4","jyd","jx2","jyd2","jyd4","dny","_zeroDbl","_threeDbl","_dbl","xx","yy","yyyy","yyyy8","c8","gamma","alpha","beta4","beta8","ggamma8","jy2","jxd4","jyd8","trpl","zz","yyu4","kbase","z3","pz3","eqXToP","zs","MontCurve","a24","normalize","diffAdd","da","cb","jumlAdd","EdwardsCurve","twisted","mOneA","dd","oneC","_mulA","_mulC","lhs","pointFromY","_extDbl","nt","_projDbl","_extAdd","_projAdd","curve1","PresetCurve","defineCurve","ripemd","ripemd160","isSurrogatePair","htonl","zero8","toHex32","join32","split32","rotr32","rotl32","sum32","sum32_3","sum32_4","sum32_5","sum64","al","bh","sum64_hi","sum64_lo","sum64_4_hi","ch","cl","dh","dl","sum64_4_lo","sum64_5_hi","eh","el","sum64_5_lo","rotr64_hi","rotr64_lo","shr64_hi","shr64_lo","BlockHash","pendingTotal","outSize","hmacStrength","padLength","_delta8","_delta32","_pad","_digest","shaCommon","ft_1","sha1_K","SHA1","W","ch32","maj32","p32","s0_256","s1_256","g0_256","g1_256","SHA256","SHA224","sha256_K","T2","SHA512","SHA384","sha512_K","ch64_hi","yh","yl","zh","ch64_lo","zl","maj64_hi","maj64_lo","s0_512_hi","s0_512_lo","s1_512_hi","s1_512_lo","g0_512_hi","g0_512_lo","g1_512_hi","g1_512_lo","_prepareBlock","c0_hi","c0_lo","c1_hi","c1_lo","c2_hi","c2_lo","c3_hi","c3_lo","fh","fl","gh","gl","hl","c4_hi","c4_lo","T1_hi","T1_lo","T2_hi","T2_lo","RIPEMD160","Kh","E","Ah","Bh","Ch","Dh","Eh","rh","Hmac","HmacDRBG","KeyPair","Signature","fromPrivate","keyFromPublic","fromPublic","genKeyPair","drbg","persEnc","entropyEnc","ns2","_truncateToN","truncOnly","bkey","getPrivate","ns1","kp","kpX","sinv","isYOdd","isSecondKey","rInv","getKeyRecoveryParam","Q","Qprime","predResist","minEntropy","reseedInterval","nonceEnc","_hmac","kmac","reseed","addEnc","_importPrivate","privEnc","_importPublic","pubEnc","reason","derive","_importDER","Position","place","getLength","initial","octetLen","rmPadding","constructLength","octets","slen","toDER","backHalf","EDDSA","pointClass","secret","keyFromSecret","hashInt","messagePrefix","Rencoded","encodePoint","s_","pubBytes","makeSignature","SG","fromSecret","lastIx","normed","xIsOdd","encodeInt","decodeInt","isPoint","_secret","_pub","_pubBytes","privBytes","getSecret","_S","_Rencoded","_Sencoded","Sencoded","cipherMap","ivSize","keySize","Blowfish","cipherKeySize","cipherType","allowed","resultLength","todo","resultBuffer","createKey","cipherKey","macKey","hashTypes","generateEphmeralKeyPair","validateCurveType","namedCurve","genSharedKey","theirPub","forcePrivate","deriveBits","curveLengths","crv","ext","private","curveTypes","ClassIsWrapper","withoutNew","_this","rm","rmAll","addAll$1","createAddAll","createAdd","rmAll$1","createRmAll","createRm","createLs","remote","last__default","entry","normaliseInput","pinTypes","pinAdd","metadata","pins","isPinnedWithType","PinTypes","direct","pinRecursively","pinDirectly","lock","gcLock","readLock","toPin","indirect","paths","matched","pinned","recursiveKeys","indirectKeys","cid2","metadata1","directKeys","unpin","offlineDatastore","pass","offline","online","getIPNS","routing","OfflineDatastore","IPNS","datastore","repo1","peerId1","keychain1","createRouting","republisher","publish","lifetime","publisher","IpnsPublisher","IpnsRepublisher","IpnsResolver","defaultRecordLifetime","publishWithEOL","ttEol","Errors","ipns__namespace","ERR_NOT_FOUND","notFoundError","_routing","_datastore","record","_updateOrCreateRecord","_putRecordToRouting","errMsg","embedPublicKeyRecord","embedPublicKey","getIdKeys","_publishEntry","routingKey","_publishPublicKey","routingPubKey","key$1","asKey","entryData","key$11","checkRouting","dsVal","getLocalKey","_unmarshalData","unmarshal","value2","lifetime1","peerId2","getPublishedOptions","_getPublished","seqNumber","sequence","err2","err3","abortedError","dbDeleteFailedError","dbOpenFailedError","dbWriteFailedError","NanoDate","NanoDate__default","Digest__namespace","Long__default","ID_MULTIHASH_CODE","IPNS_PREFIX","namespaceLength","_create","seq","validityType","expirationDate","isoValidity","signatureV1","createCborData","sigData","ipnsEntryDataForV2Sig","validity","signatureV2","Value","Validity","ValidityType","Sequence","TTL","dataForSignature","validateCborDataMatchesPbData","ipnsEntryDataForV1Sig","ERR_SIGNATURE_VERIFICATION","IpnsEntry","EOL","validityDate","parseRFC3339","ERR_UNRECOGNIZED_FORMAT","ERR_IPNS_EXPIRED_RECORD","ERR_UNRECOGNIZED_VALIDITY","ERR_INVALID_RECORD_DATA","extractPublicKey","ERR_UNDEFINED_PARAMETER","ERR_INVALID_EMBEDDED_KEY","rawStdEncoding","ERR_SIGNATURE_CREATION","validityTypeBuffer","getValidityType","extractPublicKeyFromId","validator","marshalledData","receivedEntry","bufferId","select","dataA","dataB","entryA","entryB","entryAValidityDate","lifetimeNs","createWithExpiration","expiration","ttlMs","toDate","ttlNs","getNano","extractedPublicKey","ERR_PEER_ID_FROM_PUBLIC_KEY","ERR_PUBLIC_KEY_FROM_ID","pkBuffer","ipnsBuffer","pkKey","ipnsKey","Timestamp","SEC_DAY","YEAR_SLOT","DAY_SLOT","SEC_SLOT","MSEC_SLOT","MAX_MSEC","BIT32","DEC6","DEC9","ZERO9","trunc","fromDate","fromInt64BE","buildFromInt64","fromInt64LE","nano","UTC","fromTimeT","fromTime","addNano","getTimeT","getYear","newDate","format1","dt","H","pad2","getUTCMilliseconds","FMT_DAY","getUTCDay","FMT_MONTH","strftime","FMT_STRING","writeInt64BE","buildWriteInt64","writeInt64LE","F","changed","slot","pos0","pos1","pos2","pos3","posH","posL","checkRange","writeUint32","cipherMode","createCipheriv","decipher","createDecipheriv","cipher2","CIPHER_MODES","forgePbkdf2","forgeUtil","hashName","dek","wasm","WebAssembly","Instance","Module","isLong","__isLong__","INT_CACHE","UINT_CACHE","cachedObj","UZERO","TWO_PWR_64_DBL","MAX_UNSIGNED_VALUE","TWO_PWR_63_DBL","MIN_VALUE","MAX_VALUE","TWO_PWR_32_DBL","lowBits","highBits","radix","radixToPower","pow_dbl","TWO_PWR_16_DBL","TWO_PWR_24","UONE","NEG_ONE","LongPrototype","toInt","isNegative","radixLong","rem1","rem","remDiv","getHighBits","getHighBitsUnsigned","getLowBits","getLowBitsUnsigned","getNumBitsAbs","eqz","isPositive","notEquals","neq","ne","lessThan","comp","lessThanOrEqual","greaterThan","IpnsEntry1","rfc3339Matcher","toRFC3339","_publisher","_peerId","_keychain","_republishHandle","republishHandle","_task","_inflightTask","runPeriodically","period","firstRun","_republishEntries","initialBroadcastInterval","broadcastInterval","_republishEntry","listKeys","privateKey1","_getPreviousValue","notFound","Errors__namespace","nameSegments","_resolveName","ipnsEntry","_validateRecord","tiered","pubsubDatastore","get__default","ipnsStores","pubsubDs","localDatastore","IpnsPubsubDatastore","offlineDatastore$1","_dht","TieredDatastore","pushable","drain","pushable__default","drain__default","BaseDatastore","stores","store","pushables","putMany","catch","source2","deleteMany","batch","batches","commit","queryKeys","take","filter__default","take__default","puts","dels","options8","options9","_all","filters","orders","sortAll","limit","options10","_allKeys","all__default","replaceStartWith","matcher","iterable","sorter","items","FIFO","onEnd","onNext","ended","bufferNext","bufferError","writev","throw","_pushable","FixedFIFO","hwm","btm","def","undef","datastorePubsub","_subscriptions","_handleSubscriptionKey","_pubsubDs","PubsubDatastore","stringifiedTopic","subscriber","getSubscriptions","canceled","bufTopic","unsubscribe","interfaceDatastore","datastoreCore","subscriptionKeyFn","_pubsub","_validator","_handleSubscriptionKeyFn","_onMessage","keyToTopic","subscriptions","getTopics","_getLocal","subscribe","encodeBase32","topicIDs","topicToKey","_storeIfSubscriptionIsBetter","isBetter","_isBetter","_storeRecord","key5","records","key6","dsKey","currentRecord","_selectRecord","key7","shard$1","memory","keytransform","sharding","shard","MemoryDatastore","KeyTransformDatastore","ShardingDatastore","MountDatastore","NamespaceDatastore","shardReadme","PREFIX","SHARDING_FN","ShardBase","param1","Prefix","prefixLen","noslash","Suffix","suffixLen","noslash1","NextToLast","suffixLen1","noslash2","parseShardFun","readme","README_FN","readShardFun","getRaw","itPipe","map__default","pipe","invert","getMany","source3","rawPipe","fns","isIterable","isDuplex","sink","duplexPipelineFn","duplex","shardKey","shardReadmeKey","shard1","_convertKey","_invertKey","store1","shard2","store2","store3","hasShard","putRaw","diskShard","tq","merge__default","mounts","_lookup","mountpoint","batchMounts","lookup","qs","sources","topic","libp2pRecord","_repo","_routingKey","Record","serialize","deserialize","selection","PBRecord","timeReceived","prepareSerialize","fromDeserialized","recvtime","verifyRecord","validators","keyhash","publicKeyHash","bestRecord","selectors","selector","createPublish","PubSubAPI","utils$1","lookupKey","keyName","pubLifetime","isDomain","isDomain__default","appendRemainder","domainNameRegex","domainName","rootDot","lastChar","subs","createCancel","createState","createSubs","experimental","getPubsubRouting","ipnsPubsub","Format","edges","refsStream","resPath","maxDepth","unique","rootCid","uniqueOnly","seen","Set","traverseLevel","nextLevelDepth","isDagPb","getLinks","isDuplicate","objectStream","ref","formatLink","srcCid","dstCid","linkName","elementPath","getFullPath","wantlist","wantlistForPeer","unwant","stat","createWantlist","createWantlistForPeer","createUnwant","createStat","getWantlist","cids","snapshot","provideBufLen","providesBufferLength","blocksReceived","peers","dupBlksReceived","dupDataReceived","dataReceived","blocksSent","dataSent","createList","createClear","createReset","isValidMultiaddr","boostrappers","Bootstrap","localeCompare","Peers","mafmt__default","removed","getDefaultConfig","getDefaultConfig__default","Addresses","Swarm","Announce","NoAnnounce","API","Gateway","RPC","Delegates","Discovery","MDNS","Enabled","Interval","webRTCStar","Pubsub","ConnMgr","LowWater","HighWater","DisableNatPortMap","Routing","createGet","createPut","cidVersion","codecName","getHasher","parallel","parallel__default","writeLock","cleanCid","force","quiet","defer","ops","slotAvailable","sourceFinished","resultAvailable","task","deferred","ReflectOwnKeys","Reflect","ReflectApply","receiver","Function","ownKeys","getOwnPropertyNames","NumberIsNaN","errorListener","eventTargetAgnosticAddListener","handler","flags","addErrorHandlerIfEventEmitter","_maxListeners","defaultMaxListeners","checkListener","_getMaxListeners","_addListener","prepend","existing","warning","newListener","onceWrapper","fired","wrapFn","_onceWrap","wrapped","unwrap","evlistener","unwrapListeners","arrayClone","wrapListener","setMaxListeners","getMaxListeners","doError","er","position","originalListener","spliceOne","rawListeners","createCat","ipfsUnixfsImporter","isShardingEnabled","shardSplitThreshold","strategy","parseChunkerString","chunker","hashAlg","trickle","leafType","reduceSingleLeafToSelf","rawLeaves","totals","progress","prog","transformFile","wrapWithDirectory","transformFile1","maybePreloadFile","onlyHash","preloadFile","maybePinFile","isRootDir","pinFile","added","parallelBatch","treeBuilder","parallelBatch__default","blockstore","options$1","dagBuilder","treeBuilder$1","candidates","fileImportConcurrency","tasks","things","thing","murmur3","mergeOptions__default","defaultOptions","blockWriteConcurrency","minChunkSize","maxChunkSize","avgChunkSize","polynomial","maxChildrenPerNode","layerRepeat","hamtHashFn","murmur3128","hamtHashCode","hamtBucketBits","multiformats","mur__default","murmur332","fromNumberTo32BitBuf","x86","hash32","x64","hash128","library","inputValidation","_validBytes","_x86Multiply","_x86Rotl","_x86Fmix","_x64Add","_x64Multiply","_x64Rotl","_x64LeftShift","_x64Xor","_x64Fmix","k3","k4","c3","c4","murmurHash3","define","amd","_murmurHash3","noConflict","rabin","fixedSize","validateChunks","contentAsAsyncIterable","content","chunkValidator","dir$1","persist","dagPb","dagPb__namespace","rawCodec","flat","balanced","bufferImporter","rawCodec__namespace","dagBuilders","previous","bufferImporter$1","single","buildFileBatch","leaves","leaf","batch__default","reduceToParents","chunked","SubTree","iteration","currentDepth","children","maxChildren","isFull","_addNextNodeToParent","distantRelative","_findParent","nextNode","append","layer","_reduce","reduce1","node1","Root","layerRepeat1","addChild","reduce2","subTree","BufferList","rabinWasm","BufferList__default","sizepow","log2","buffers","sizes","fingerprint","consume","_bufs","_new","_offset","tot","_t","_reverseOffset","blOffset","dstStart","srcStart","srcEnd","bufoff","shallowSlice","startOffset","endOffset","duplicate","_appendBuffer","_isBufferList","blIndex","buffOffset","nativeSearchResult","revOffset","_match","searchOffset","methods","readDoubleBE","readInt32BE","readInt32LE","readUInt32BE","readUInt32LE","readInt16BE","readInt16LE","readUInt16BE","readUInt16LE","readInt8","readUInt8","readIntBE","readIntLE","readUIntBE","readUIntLE","isBufferList","ieee754","customInspectSymbol","SlowBuffer","INSPECT_MAX_BYTES","K_MAX_LENGTH","encodingOrOffset","isEncoding","byteLength1","actual","arrayView","isInstance","fromArrayBuffer","fromArrayLike","fromArrayView","SharedArrayBuffer","valueOf","checked","numberIsNaN","toPrimitive","assertSize","mustMatch","loweredCase","base64ToBytes","slowToString","hexSlice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","bidirectionalIndexOf","arrayIndexOf","indexSize","arrLength","valLength","foundIndex","hexWrite","strLen","blitBuffer","asciiWrite","byteArray","asciiToBytes","base64Write","ucs2Write","utf16leToBytes","fromByteArray","MAX_ARGUMENTS_LENGTH","kMaxLength","TYPED_ARRAY_SUPPORT","foo","typedArraySupport","poolSize","allocUnsafeSlow","_isBuffer","swap16","swap32","swap64","toLocaleString","thisStart","thisEnd","thisCopy","targetCopy","_arr","hexSliceLookupTable","checkOffset","checkInt","checkIEEE754","writeFloat","noAssert","writeDouble","newBuf","readUint16LE","readUint16BE","readUint32LE","readUint32BE","writeUIntLE","writeUIntBE","writeUint8","writeUInt8","writeUint16LE","writeUInt16LE","writeUint16BE","writeUInt16BE","writeUint32LE","writeUInt32LE","writeUint32BE","writeUInt32BE","writeIntLE","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","targetStart","copyWithin","INVALID_BASE64_RE","base64clean","i16","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","maxChunkLength","len2","encodeChunk","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","rt","Rabin","getRabin","windowSize","compiled","asModule","__retain","__release","__allocArray","__getInt32Array","Int32Array_ID","Uint8Array_ID","lengthsPtr","Int32Array","pointer","processed","instantiate","loadWebAssembly","imp","BIGINT","BigUint64Array","THIS","CHUNKSIZE","getStringImpl","U32","U16","preInstantiate","imports","baseModule","getString","mesg","colm","trace","postInstantiate","rawExports","retain","rttiBase","getInfo","getValueAlign","info","getView","alignLog2","signed","Int8Array","Int16Array","BigInt64Array","__getArrayView","align","getTypedArray","getTypedArrayView","bufPtr","__allocString","__getString","__getArray","__getArrayBuffer","__getInt8Array","__getInt8ArrayView","__getUint8Array","__getUint8ArrayView","__getUint8ClampedArray","Uint8ClampedArray","__getUint8ClampedArrayView","__getInt16Array","__getInt16ArrayView","__getUint16Array","__getUint16ArrayView","__getInt32ArrayView","__getUint32Array","__getUint32ArrayView","__getInt64Array","__getInt64ArrayView","__getUint64Array","__getUint64ArrayView","__getFloat32Array","__getFloat32ArrayView","__getFloat64Array","__getFloat64ArrayView","__instanceof","baseId","demangle","isResponse","instantiateStreaming","compile","arrayBuffer","setArgumentsLength","internalName","elem","classElem","wrap","thisValue","getter","setter","instantiateSync","currentLength","emitted","newBl","dirFlat","flatToShard","toPathComponents","addToTree","tree","pathElems","currentPath","pathElem","dirty","parentKey","flushAndYield","flush","unwrapped","eachChildSeries","_children","childCount","directChildrenCount","onlyChild","dirSharded","threshold","newDir","oldDir","convertToShard","dir1","hamtSharding","bucket","shardRoot","childrenSize","labelPrefix","Bucket","subShard","flushedDir","bitField","tableSize","_bucket","createHAMT","hashFn","leafCount","childrenCount","eachLeafSeries","blockstore1","wrapHash","bucketOptions","SparseArray","posAtParent","_popCount","_parent","_posAtParent","_findNewBucketAndPos","_putAt","_findChild","_findPlace","_at","_delAt","compactArray","asyncTransform","asyncMap1","asyncReduce1","asyncTransformBucket","mapNode","reduceNodes","hashValue","existingChild","_putObjectAt","newPlace","unset","_level","exists","untake","nodes","asyncMap","asyncReduce","mappedChildren","popCountReduce","popCount","_v","sortInternal","valueOnly","_bitArrays","_length","_changedLength","_changedData","_internalPositionFor","_unsetInternalPos","_unsetBit","needsSort","_setBit","_setInternalPos","index1","index2","_sortData","iterator1","mapped","reducer","initialValue","finder","index3","noCreate","bytePos","_bytePosFor","bitPos","index4","noCreate1","targetLength","index5","index6","index7","randomIndex","newByte","pendingBitsForResultingByte","pendingBitsForNewByte","resultingByte","usingBits","ConsumableBuffer","InfiniteHash","_value","_hashFn","_depth","_availableBits","_currentBufferIndex","_buffers","pendingBits","_produceMoreBits","availableBits","availableForUntake","totalBits","START_MASKS","STOP_MASKS","byteBitsToInt","maskFor","_currentBytePos","_currentBitPos","_haveBits","taking","normaliseContent","normalise","browserStreamToIt","blobToIt","itPeekable","browserStreamToIt__default","blobToIt__default","itPeekable__default","isBytes","isBlob","isReadableStream","peekable","peek","toAsyncGenerator","preventCancel","browserReadableStreamToIt","blob","isFileObject","toFileObject","_readableState","parseRabinString","parseChunkSize","sizeStr","ipfsUnixfsExporter","pathComponents","cidAndRest","toResolve","walkPath","entryPath","startingDepth","recurse","dagCbor","raw$1","dagCbor$1","dagCbor__namespace","raw__namespace","findCidInShard","directory","hamtShardedDirectory","contentExporters","symlink","linkCid","link1","findLinkCid","nextName","toPrefix","findShardCid","rootBucket","hamtDepth","lastBucket","bucketPath","toBucketPath","entryPrefix","entryName","extractDataFromBlock","validateOffsetAndLength","emitBytes","streamPosition","childStart","childLink","childEnd","blockStart","requestedStart","requestedEnd","blockEnd","listDirectory","subObject","subPath","subObjectCid","mh__namespace","itTar","Pako","Pako__default","toBuffer__default","compressionLevel","ipfsPathOrCid","compress","archive","gzip","extract","LteReader","discardPadding","getPadding","highWaterMark","gnuLongPath","gnuLongLinkPath","paxGlobal","pax","headerBytes","filenameEncoding","gnuLongPathBytes","decodeLongPath","gnuLongLinkPathBytes","paxGlobalBytes","decodePax","paxBytes","linkname","linkpath","bytesRemaining","bodyConsumed","firstChunk","nextLte","ZERO_OFFSET","USTAR_MAGIC","GNU_MAGIC","GNU_VER","MAGIC_OFFSET","decodeOct","parse256","defaultValue","decodeStr","keyIndex","typeflag","uid","gid","flag","toType","uname","gname","devmajor","devminor","cksum","VERSION_OFFSET","lteReader","nextValue","S_IFMT","S_IFBLK","S_IFCHR","S_IFDIR","S_IFIFO","S_IFLNK","DMODE","FMODE","END_OF_TAR","modeToType","encoded","paxHeader","encodePax","newHeader","RTLD_LAZY","RTLD_NOW","RTLD_GLOBAL","RTLD_LOCAL","RTLD_DEEPBIND","E2BIG","EACCES","EADDRINUSE","EADDRNOTAVAIL","EAFNOSUPPORT","EAGAIN","EALREADY","EBADF","EBADMSG","EBUSY","ECANCELED","ECHILD","ECONNABORTED","ECONNREFUSED","ECONNRESET","EDEADLK","EDESTADDRREQ","EDOM","EDQUOT","EEXIST","EFAULT","EFBIG","EHOSTUNREACH","EIDRM","EILSEQ","EINPROGRESS","EINTR","EINVAL","EIO","EISCONN","EISDIR","ELOOP","EMFILE","EMLINK","EMSGSIZE","EMULTIHOP","ENAMETOOLONG","ENETDOWN","ENETRESET","ENETUNREACH","ENFILE","ENOBUFS","ENODATA","ENODEV","ENOENT","ENOEXEC","ENOLCK","ENOLINK","ENOMEM","ENOMSG","ENOPROTOOPT","ENOSPC","ENOSR","ENOSTR","ENOSYS","ENOTCONN","ENOTDIR","ENOTEMPTY","ENOTSOCK","ENOTSUP","ENOTTY","ENXIO","EOPNOTSUPP","EOVERFLOW","EPERM","EPIPE","EPROTO","EPROTONOSUPPORT","EPROTOTYPE","ERANGE","EROFS","ESPIPE","ESRCH","ESTALE","ETIME","ETIMEDOUT","ETXTBSY","EWOULDBLOCK","EXDEV","PRIORITY_LOW","PRIORITY_BELOW_NORMAL","PRIORITY_NORMAL","PRIORITY_ABOVE_NORMAL","PRIORITY_HIGH","PRIORITY_HIGHEST","SIGHUP","SIGINT","SIGQUIT","SIGILL","SIGTRAP","SIGABRT","SIGIOT","SIGBUS","SIGFPE","SIGKILL","SIGUSR1","SIGSEGV","SIGUSR2","SIGPIPE","SIGALRM","SIGTERM","SIGCHLD","SIGSTKFLT","SIGCONT","SIGSTOP","SIGTSTP","SIGTTIN","SIGTTOU","SIGURG","SIGXCPU","SIGXFSZ","SIGVTALRM","SIGPROF","SIGWINCH","SIGIO","SIGPOLL","SIGPWR","SIGSYS","SIGUNUSED","UV_FS_SYMLINK_DIR","UV_FS_SYMLINK_JUNCTION","O_RDONLY","O_WRONLY","O_RDWR","UV_DIRENT_UNKNOWN","UV_DIRENT_FILE","UV_DIRENT_DIR","UV_DIRENT_LINK","UV_DIRENT_FIFO","UV_DIRENT_SOCKET","UV_DIRENT_CHAR","UV_DIRENT_BLOCK","S_IFREG","S_IFSOCK","O_CREAT","O_EXCL","UV_FS_O_FILEMAP","O_NOCTTY","O_TRUNC","O_APPEND","O_DIRECTORY","O_NOATIME","O_NOFOLLOW","O_SYNC","O_DSYNC","O_DIRECT","O_NONBLOCK","S_IRWXU","S_IRUSR","S_IWUSR","S_IXUSR","S_IRWXG","S_IRGRP","S_IWGRP","S_IXGRP","S_IRWXO","S_IROTH","S_IWOTH","S_IXOTH","F_OK","R_OK","W_OK","X_OK","UV_FS_COPYFILE_EXCL","COPYFILE_EXCL","UV_FS_COPYFILE_FICLONE","COPYFILE_FICLONE","UV_FS_COPYFILE_FICLONE_FORCE","COPYFILE_FICLONE_FORCE","OPENSSL_VERSION_NUMBER","SSL_OP_ALL","SSL_OP_ALLOW_NO_DHE_KEX","SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION","SSL_OP_CIPHER_SERVER_PREFERENCE","SSL_OP_CISCO_ANYCONNECT","SSL_OP_COOKIE_EXCHANGE","SSL_OP_CRYPTOPRO_TLSEXT_BUG","SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS","SSL_OP_EPHEMERAL_RSA","SSL_OP_LEGACY_SERVER_CONNECT","SSL_OP_MICROSOFT_BIG_SSLV3_BUFFER","SSL_OP_MICROSOFT_SESS_ID_BUG","SSL_OP_MSIE_SSLV2_RSA_PADDING","SSL_OP_NETSCAPE_CA_DN_BUG","SSL_OP_NETSCAPE_CHALLENGE_BUG","SSL_OP_NETSCAPE_DEMO_CIPHER_CHANGE_BUG","SSL_OP_NETSCAPE_REUSE_CIPHER_CHANGE_BUG","SSL_OP_NO_COMPRESSION","SSL_OP_NO_ENCRYPT_THEN_MAC","SSL_OP_NO_QUERY_MTU","SSL_OP_NO_RENEGOTIATION","SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION","SSL_OP_NO_SSLv2","SSL_OP_NO_SSLv3","SSL_OP_NO_TICKET","SSL_OP_NO_TLSv1","SSL_OP_NO_TLSv1_1","SSL_OP_NO_TLSv1_2","SSL_OP_NO_TLSv1_3","SSL_OP_PKCS1_CHECK_1","SSL_OP_PKCS1_CHECK_2","SSL_OP_PRIORITIZE_CHACHA","SSL_OP_SINGLE_DH_USE","SSL_OP_SINGLE_ECDH_USE","SSL_OP_SSLEAY_080_CLIENT_DH_BUG","SSL_OP_SSLREF2_REUSE_CERT_TYPE_BUG","SSL_OP_TLS_BLOCK_PADDING_BUG","SSL_OP_TLS_D5_BUG","SSL_OP_TLS_ROLLBACK_BUG","ENGINE_METHOD_RSA","ENGINE_METHOD_DSA","ENGINE_METHOD_DH","ENGINE_METHOD_RAND","ENGINE_METHOD_EC","ENGINE_METHOD_CIPHERS","ENGINE_METHOD_DIGESTS","ENGINE_METHOD_PKEY_METHS","ENGINE_METHOD_PKEY_ASN1_METHS","ENGINE_METHOD_ALL","ENGINE_METHOD_NONE","DH_CHECK_P_NOT_SAFE_PRIME","DH_CHECK_P_NOT_PRIME","DH_UNABLE_TO_CHECK_GENERATOR","DH_NOT_SUITABLE_GENERATOR","ALPN_ENABLED","RSA_PKCS1_PADDING","RSA_SSLV23_PADDING","RSA_NO_PADDING","RSA_PKCS1_OAEP_PADDING","RSA_X931_PADDING","RSA_PKCS1_PSS_PADDING","RSA_PSS_SALTLEN_DIGEST","RSA_PSS_SALTLEN_MAX_SIGN","RSA_PSS_SALTLEN_AUTO","defaultCoreCipherList","TLS1_VERSION","TLS1_1_VERSION","TLS1_2_VERSION","TLS1_3_VERSION","POINT_CONVERSION_COMPRESSED","POINT_CONVERSION_UNCOMPRESSED","POINT_CONVERSION_HYBRID","TypeDefault","USTAR_VER","MASK","encodeOct","addLength","toTypeflag","pako","TYPED_OK","_has","shrinkBuf","fnTyped","arraySet","src_offs","dest_offs","flattenChunks","fnUntyped","setTyped","Buf8","Buf16","Buf32","zlib_deflate","strings","ZStream","Deflate","windowBits","memLevel","to","opt","strm","avail_out","deflateInit2","deflateSetHeader","dictionary","dict","string2buf","deflateSetDictionary","_dict_set","deflator","next_in","avail_in","next_out","onData","buf2binstring","deflateEnd","deflateRaw","configuration_table","trees","adler32","crc32","Z_STREAM_ERROR","MAX_MATCH","MIN_LOOKAHEAD","HCRC_STATE","BUSY_STATE","FINISH_STATE","errorCode","rank","flush_pending","pending_buf","pending_out","total_out","flush_block_only","_tr_flush_block","block_start","strstart","put_byte","putShortMSB","longest_match","cur_match","chain_length","max_chain_length","scan","best_len","prev_length","nice_match","w_size","_win","wmask","w_mask","strend","scan_end1","scan_end","good_match","lookahead","match_start","fill_window","more","_w_size","window_size","hash_size","adler","total_in","ins_h","hash_shift","hash_mask","deflate_fast","hash_head","bflush","match_length","_tr_tally","max_lazy_match","MIN_MATCH","last_lit","deflate_slow","max_insert","prev_match","match_available","Config","good_length","max_lazy","nice_length","max_chain","DeflateState","pending_buf_size","gzhead","gzindex","last_flush","w_bits","hash_bits","dyn_ltree","HEAP_SIZE","dyn_dtree","bl_tree","l_desc","d_desc","bl_desc","bl_count","MAX_BITS","heap","heap_len","heap_max","l_buf","lit_bufsize","d_buf","opt_len","static_len","bi_buf","bi_valid","deflateResetKeep","data_type","_tr_init","deflateReset","max_block_size","max_start","deflateInit","old_flush","beg","hcrc","extra","comment","os","bstate","deflate_huff","deflate_rle","_tr_align","_tr_stored_block","avail","tmpDict","dictLength","deflateInfo","LITERALS","L_CODES","D_CODES","extra_lbits","extra_dbits","extra_blbits","bl_order","static_ltree","static_dtree","_dist_code","_length_code","base_length","static_l_desc","static_d_desc","static_bl_desc","base_dist","StaticTreeDesc","static_tree","extra_bits","extra_base","elems","max_length","has_stree","TreeDesc","dyn_tree","stat_desc","max_code","d_code","dist","put_short","send_bits","send_code","bi_reverse","gen_codes","next_code","init_block","END_BLOCK","bi_windup","smaller","_n2","_m2","pqdownheap","compress_block","ltree","dtree","lc","lx","build_tree","desc","stree","xbits","gen_bitlen","scan_tree","curlen","prevlen","nextlen","max_count","min_count","REP_3_6","REPZ_3_10","REPZ_11_138","send_tree","static_init_done","stored_len","copy_block","LENGTH_CODES","tr_static_init","opt_lenb","static_lenb","max_blindex","black_mask","detect_data_type","BL_CODES","build_bl_tree","lcodes","dcodes","blcodes","send_all_trees","STATIC_TREES","bi_flush","crcTable","makeTable","crc","STR_APPLY_OK","STR_APPLY_UIA_OK","__","__1","_utf8len","m_pos","str_len","buf_len","binstring2buf","buf2string","c_len","utf16buf","utf8border","zlib_inflate","GZheader","Inflate","inflateInit2","Z_OK","inflateGetHeader","inflateSetDictionary","inflator","next_out_utf8","utf8str","allowBufError","Z_FINISH","Z_NO_FLUSH","Z_NEED_DICT","Z_BUF_ERROR","Z_STREAM_END","Z_SYNC_FLUSH","inflateEnd","inflateRaw","ungzip","inflate_fast","inflate_table","TYPE","BAD","zswap32","InflateState","havedict","dmax","check","wbits","wsize","whave","wnext","hold","lencode","distcode","lenbits","distbits","ncode","nlen","ndist","have","work","lendyn","distdyn","sane","back","was","inflateResetKeep","inflateReset","inflateReset2","lenfix","distfix","virgin","fixedtables","sym","updatewindow","inflateInit","_in","_out","from_source","here_bits","here_op","here_val","last_bits","last_op","last_val","here","hbuf","order","inf_leave","xflags","extra_len","inflateInfo","s_window","lcode","dcode","lmask","dmask","dolen","dodist","MAXBITS","lbase","lext","dbase","dext","lens_index","table_index","incr","drop","huff","base_index","offs","extra_index","Z_PARTIAL_FLUSH","Z_FULL_FLUSH","Z_BLOCK","Z_TREES","Z_ERRNO","Z_DATA_ERROR","Z_NO_COMPRESSION","Z_BEST_SPEED","Z_BEST_COMPRESSION","Z_DEFAULT_COMPRESSION","Z_FILTERED","Z_HUFFMAN_ONLY","Z_RLE","Z_FIXED","Z_DEFAULT_STRATEGY","Z_BINARY","Z_TEXT","Z_UNKNOWN","Z_DEFLATED","legacyPath","repoVersion","ipfsCore","interfaceIpfsCore","agentVersion","protocolVersion","peerStore","keyBook","addressBook","getMultiaddrsForPeer","multiaddrs","protoBook","upgrader","metadataBook","getValue","idStr","profiles","listProfiles","description","profileName","dryRun","profile","oldCfg","newCfg","Identity","PrivKey","updated","set__default","server","defaultConfig","lowpower","prototypeCheck","propsArg","lastProp","thisProp","_export","_import","createExport","createImport","block1","writer1","json__namespace","NO_LINKS_CODECS","traverseWrite","b58Cid","createUnsafe","getBlock","writer$1","CarWriter","Block","asBlock","maybeValue","iteratorChannel","roots3","encoder1","_encoder","_mutex","setRoots","_ended","writeBlock","roots1","_roots","_root","toRoots","encodeWriter","CarWriterOut","roots2","bytesReader","readHeader","createHeader","_iterator","_iterating","iw","createEncoder","__browser","varint__default","varintBytes","chunkQueue","drainer1","drainerResolver","outWait","outWaitResolver","makeDrainer","drainer","CIDV0_BYTES","readVarint","upTo","seek","exactly","readCid","codeLength","mhLength","readMultihash","readBlockHead","readBlock","readBlockIndex","blockOffset","chunkReader","readChunk","currentChunk","bufa","asyncIterableReader","asyncIterable","createDecoder","headerPromise","first__default","localResolve","importCar","CarBlockIterator","fromIterable","getRoots","abortOptions","cars","car","pinRoots","pinErrorMsg","CarIteratorBase","_version","_iterable","_decoded","asyncIterable2","CarCIDIterator","asyncIterable1","decodeIterator","decoder$1","dagNode","toUri","shuffle","nativeAbortController","hashlru","toUri__default","shuffle__default","stopped","requests","apiUris","fallbackApiUris","uri","reduceValue","Reducers","ip4","ip6","tcp","assumeHttp","explicitPort","tcpUri","udp","dnsaddr","dns4","dns6","p2p","http","https","wss","parts1","newIndex","timeoutId","preloadMfs","nextRootCid","createLock","chmod","cp","mkdir","mv","touch","readOperations","writeOperations","createChmod","createCp","createFlush","createMkdir","createMv","createTouch","unwrappedOperations","createWrite","createRead","mfs","operations","repoOwner","constructorOptions","createMfs","withPreload","mortice__default","mutex","singleProcess","Queue","mutexes","implementation","createReleaseable","createMutex","isWorker","masterQueue","readQueue","localReadQueue","readPromise","onIdle","finally","script","Impl","WORKER_REQUEST_READ_LOCK","WORKER_RELEASE_READ_LOCK","MASTER_GRANT_READ_LOCK","WORKER_REQUEST_WRITE_LOCK","WORKER_RELEASE_WRITE_LOCK","MASTER_GRANT_WRITE_LOCK","cluster","handleWorkerLockRequest","masterEvent","requestType","releaseType","grantType","requestEvent","identifier","releaseEventListener","releaseEvent","makeWorkerLockRequest","isMaster","observer","event1","responseEvent","observable","dispatchEvent","timeoutMillis","toMfsPath","withLocal","statters","cumulativeSize","sizeLocal","withLocality","mfsPath","exportPath","withMfsRoot","loadMfsRoot","entryType","mfsDirectory","toTrail","addLink","updateTree","updateMfsRoot","parseSymbolicMode","originalMode","references","operator","modification","calculateModification","ugo","calculateUGO","calculateSpecial","calculateMode","strMode","updatedBlock","updatedCid","trail","parentCid","parentBlock","parentNode","newRootCid","fsEntry","hamtUtils","convertToShardedDirectory","createShard","addToDirectory","parentLinks","addToShardedDirectory","addFileToShardedDirectory","newLink","updateHamtDirectory","recreateInitialHamtLevel","DirSharded","segment","recreateHamtLevel","nextSegment","addLinksToHamtBucket","positionInBucket","meta","hamtConstants","Dir","blockstore2","props1","parentBucket","positionAtParent","contents","generatePath","fileName","rootNode","currentBucket","parents","destination","copyToFile","destinationTrail","addSourceToParent","copyToDirectory","childName","sourceBlock","missing","destinationIsDirectory","parentFolder","destinationPath","destinationName","emptyDir","subPathComponents","removeLink","removePath","removeFromDirectory","removeFromShardedDirectory","del","updateShard","positions","nodeLink","newName","updateShardParent","oldName","settings","toAsyncIterator","updateOrImport","parentExists","updatedPath","asyncZeroes","limitAsyncStreamBytes","countBytesStreamed","catAsyncIterators","bytesWritten","_asyncZeroes","notify","wrote","FileReader","handleLoad","ev","readAsArrayBuffer","toOutput","gen","rename","createGen","createRename","createInfo","DEFAULT_KEY_TYPE","findKeyByName","renameKey","overwrite","removeKey","createData","createLinks","new","createNew","patch","ObjectPatchAPI","get$1","findLinks","template","linkLength","NumLinks","BlockSize","LinksSize","DataSize","CumulativeSize","appendData","rmLink","setData","createAddLink","createAppendData","createRmLink","createSetData","put$1","newData","linkRef","gc","createGc","setApiAddr","apiAddr","mfsRootCid","numObjects","repoSize","storageMax","_checkInitialized","bw","stat$1","createBw","getBandwidthStats","metrics","peer","forPeer","forProtocol","totalIn","totalOut","rateIn","rateOut","movingAverages","integerValue","movingAverage","poll","repo2","profiles1","errors$1","print2","repoAutoMigrate","inputRepo","onMigrationProgress","repo$1","createRepo","autoMigrate","loadRepo","closed","configureRepo","ERR_REPO_NOT_INITIALIZED","allowNew","initRepo","decodePeerId","initPeerId","peerIdToIdentity","PeerID","applyProfiles","keychainConfig","libp2p$1","createLibp2p","loadKeychain","DEK","mergeConfigs","Keychain","changes","config1","profiles$1","ipfsRepo","datastoreLevel","blockstoreDatastoreAdapter","codeOrName","LevelDatastore","BlockstoreDatastoreAdapter","repoLock","MemoryLock","_get","migrator","spec1","idstore","defaultDatastore","pinManager","pinnedBlockstore","mortice","_get__default","migrator__namespace","bytes__default","noLimit","Repo","loadCodec1","backends2","pinstore","PinManager","pinnedBlockstore$1","createPinnedBlockstore","createIdStore","spec","_config","_openRoot","Datastore","Spec","mounting","shardFunc","buildDatastoreSpec","ERR_REPO_ALREADY_OPEN","_lockfile","_openLock","_isAutoMigrationEnabled","InvalidRepoVersionError","_migrate","_closeLock","lockfile","ERR_REPO_ALREADY_CLOSED","_storageMaxStat","_blockStat","getSize","autoMigrateConfig","NotFoundError","toVersion","backends1","ignoreLock","onProgress","migrate","backends","getLatestMigrationVersion","migrations","verifyAvailableMigrations","fromVersion","checkReversibility","migrationCounter","migration","NonReversibleMigrationError","InvalidValueError","getCurrentRepoVersion","getVersion","migrations1","repoOptions","isDryRun","RequiredParameterError","wrapBackends","currentVersion","progressCallback","percent","lastSuccessfullyMigratedVersion","setVersion","reversedMigrationArray","lastSuccessfullyRevertedVersion","emptyMigration","defaultMigrations","mhd","length__default","mhd__namespace","keyToMultihash","multihashStr","keyToCid","keyFunction","blockCount","newKey","cbor","pinSet","cbor__namespace","pinsToDatastore","PIN_DS_KEY","pinRootBuf","pinRoot","pinCount","loadSet","cidToKey","pinsToDAG","recursivePins","directPins","storeSet","pin1","fnv1a","fnv1a__default","PinSet","walkItems","pbh","rootData","hdrLength","vBytes","hdrSlice","linkHash","EMPTY_KEY","storeItems","storePins","pbHeader","DEFAULT_FANOUT","headerBuf","fanoutLinks","MAX_ITEMS","rootLinks","bins1","bins","setUint32","encodedKey","bin","storeChild","binIdx","ipfs1","keysToBinary","findLevelJs","withEach","keysToStrings","datastores","backend","migrated","_deserializeKey","_deserializeValue","handleNext","handleEnd","transaction","loop","onsuccess","CONFIG_KEY","VERSION_KEY","hasWithFallback","levelJs","wrapStore","originalGet","originalHas","getWithFallback","isRepoInitialized","NotInitializedRepoError","MissingRepoOptionsError","versionCheck","configCheck","formatThousandsRegExp","formatDecimalsRegExp","kb","mb","gb","tb","pb","parseRegExp","mag","thousandsSeparator","unitSeparator","decimalPlaces","fixedDecimals","unit","floatValue","versionKey","LockExistsError","_set","_set__default","configKey","setQueue","configStore","encodedValue","_maybeDoSet","_saveAll","sortKeys","sortKeys__default","specKey","deep","isPlainObject","object1","seenInput","seenOutput","deepSortArray","seenIndex","newValue","apiFile","extractContents","isIdentity","extracted","lockFile","LOCKS","locked","sync","compression","cid6","walkDag","cid3","fetchCompleteDag","entry1","entry2","childCid","cid4","findChild","cid5","block$1","invalidPinTypeErr","ensureNotPinned","markedSet","mfsSource","pinsSource","createMarkedSet","blockKeys","blocksCount","removedBlocksCount","removeBlock","deleteUnmarkedBlocks","Level","sort__default","Level__default","database","_initDb","valueEncoding","_query","iteratorOpts","keyAsBuffer","levelup","leveldown","DeferredLevelDOWN","IteratorStream","Batch","supports","catering","getCallback","getOptions","WriteError","ReadError","OpenError","InitializationError","LevelUP","_db","deferredOpen","openCallback","promises","streams","additionalMethods","maybeError","isOperational","fromCallback","isOpen","_isOpening","isClosed","readStream","createReadStream","keyStream","createKeyStream","valueStream","createValueStream","_nextTick","getOwnPropertyDescriptors","descriptors","formatRegExp","isNull","noDeprecation","throwDeprecation","traceDeprecation","debugs","debugEnvRegex","stylize","stylizeNoColor","isBoolean","showHidden","_extend","isUndefined","customInspect","stylizeWithColor","formatValue","styleType","styles","recurseTimes","isFunction","primitive","simple","isNumber","formatPrimitive","visibleKeys","arrayToHash","isError","formatError","isRegExp","isDate","braces","toUTCString","formatProperty","formatArray","numLinesEst","cur","reduceToSingleString","ar","objectToString","debuglog","bold","italic","underline","inverse","white","grey","black","blue","cyan","green","magenta","yellow","special","isNullOrUndefined","isSymbol","isNativeError","isPrimitive","months","timestamp","getHours","getMinutes","getSeconds","getDate","getMonth","kCustomPromisifiedSymbol","callbackifyOnRejected","newReason","promisify","promiseResolve","promiseReject","custom","callbackify","callbackified","maybeCb","rej","isArgumentsObject","isGeneratorFunction","whichTypedArray","isTypedArray","uncurryThis","BigIntSupported","SymbolSupported","ObjectToString","numberValue","stringValue","booleanValue","bigIntValue","symbolValue","checkBoxedPrimitive","prototypeValueOf","isMapToString","isSetToString","isWeakMapToString","isWeakSetToString","isArrayBufferToString","working","isDataViewToString","isDataView","isPromise","isUint8ClampedArray","isUint16Array","isUint32Array","isInt8Array","isInt16Array","isInt32Array","isFloat32Array","isFloat64Array","isBigInt64Array","isBigUint64Array","WeakMap","isWeakMap","WeakSet","isWeakSet","SharedArrayBufferCopy","isSharedArrayBufferToString","isSharedArrayBuffer","isNumberObject","isStringObject","isBooleanObject","isBigIntObject","isSymbolObject","isAsyncFunction","isMapIterator","isSetIterator","isGeneratorObject","isWebAssemblyCompiledModule","isBoxedPrimitive","isAnyArrayBuffer","hasToStringTag","$toString","callBound","isStandardArguments","isLegacyArguments","callee","supportsStandardArguments","hasSymbols","symObj","syms","descriptor","GetIntrinsic","callBind","$indexOf","allowMissing","intrinsic","$SyntaxError","$Function","$TypeError","getEvalledConstructor","expressionSyntax","$gOPD","throwTypeError","ThrowTypeError","calleeThrows","gOPDthrows","getProto","needsEval","TypedArray","INTRINSICS","AggregateError","Atomics","decodeURI","encodeURI","EvalError","FinalizationRegistry","Proxy","ReferenceError","URIError","WeakRef","doEval1","doEval","LEGACY_ALIASES","hasOwn","$concat","$spliceApply","$replace","$strSlice","rePropName","reEscapeChar","stringToPath","quote","subString","getBaseIntrinsic","alias","intrinsicName","intrinsicBaseName","intrinsicRealName","skipFurtherCaching","isOwn","origSymbol","hasSymbolSham","ERROR_MESSAGE","toStr","funcType","bound","binder","boundLength","boundArgs","Empty","$apply","$call","$reflectApply","$defineProperty","$max","originalFunction","applyBind","GeneratorFunction","fnToStr","isFnRegex","generatorFunc","getGeneratorFunc","availableTypedArrays","typedArrays","$slice","toStrTags","gOPD","typedArray","superProto","tryTypedArrays","foundName","possibleNames","anyTrue","AbstractLevelDOWN","DeferredIterator","DeferredChainedBatch","deferrables","optionalDeferrables","kInnerDb","kOperations","kPromise","method1","implement","_open","onopen","setDb","_close","_isOperational","AbstractIterator","AbstractChainedBatch","rangeOptions","manifest","cleanRangeOptions","isRangeOption","_serializeKey","oldStatus","createIfMissing","errorIfExists","_checkKey","asBuffer","serialized","_getMany","_checkValue","_serializeValue","_put","_del","_chainedBatch","valueErr","_batch","_clear","valueAsBuffer","emptyOptions","_setupIteratorOptions","maybeObject","manifests","bufferKeys","snapshots","permanence","keyIterator","valueIterator","iteratorNextv","iteratorAll","idempotentOpen","passiveOpen","encodings","queueTick","fromPromise","queueMicrotask","_nexting","_seek","_end","kv","_operations","_written","_checkWritten","_write","kOptions","kIterator","Readable","ReadStream","objectMode","_read","destroyed","_destroy","Stream","Writable","Duplex","Transform","PassThrough","finished","pipeline","ReadableState","EElistenerCount","OurUint8Array","_uint8ArrayToBuffer","_isUint8Array","debugUtil","StringDecoder","createReadableStreamAsyncIterator","destroyImpl","_require","getHighWaterMark","_require$codes","ERR_INVALID_ARG_TYPE","ERR_STREAM_PUSH_AFTER_EOF","ERR_METHOD_NOT_IMPLEMENTED","ERR_STREAM_UNSHIFT_AFTER_END_EVENT","errorOrDestroy","kProxyEvents","readableObjectMode","pipes","pipesCount","flowing","endEmitted","reading","needReadable","emittedReadable","readableListening","resumeScheduled","paused","emitClose","autoDestroy","defaultEncoding","awaitDrain","readingMore","readable","readableAddChunk","addToFront","skipChunkCheck","onEofChunk","chunkInvalid","addChunk","maybeReadMore","emitReadable","_undestroy","undestroy","setEncoding","MAX_HWM","computeNewHighWaterMark","howMuchToRead","emitReadable_","flow","maybeReadMore_","pipeOnDrain","updateReadableListening","resume","nReadingNextTick","resume_","fromList","endReadable","endReadableNT","wState","_writableState","xs","nOrig","doRead","pipeOpts","endFn","stdout","stderr","onend","unpipe","onunpipe","unpipeInfo","hasUnpiped","onclose","onfinish","ondrain","ondata","cleanedUp","needDrain","dests","_fromList","enumerableOnly","_defineProperty","_defineProperties","Constructor","_classCallCheck","protoProps","staticProps","hasStrings","_getString","_getBuffer","nb","_objectSpread","emitErrorAndCloseNT","emitErrorNT","emitCloseNT","readableDestroyed","writableDestroyed","errorEmitted","ending","finalCalled","prefinished","rState","ERR_INVALID_OPT_VALUE","duplexKey","highWaterMarkFrom","createErrorType","NodeError1","_Base","subClass","superClass","NodeError","arg1","arg2","arg3","getMessage","oneOf","determiner","this_len","objectKeys","keys1","allowHalfOpen","onEndNT","getBuffer","CorkedRequest","onCorkedFinish","WritableState","internalUtil","realHasInstance","ERR_MULTIPLE_CALLBACK","ERR_STREAM_CANNOT_PIPE","ERR_STREAM_DESTROYED","ERR_STREAM_NULL_VALUES","ERR_STREAM_WRITE_AFTER_END","ERR_UNKNOWN_ENCODING","nop","writableObjectMode","noDecode","decodeStrings","writing","corked","bufferProcessing","onwrite","writecb","writelen","bufferedRequest","lastBufferedRequest","pendingcb","bufferedRequestCount","corkedRequestsFree","_writev","final","_final","writeAfterEnd","validChunk","decodeChunk","writeOrBuffer","isBuf","newChunk","doWrite","onwriteError","finishMaybe","onwriteStateUpdate","needFinish","clearBuffer","afterWrite","onwriteDrain","holder","allBuffers","callFinal","prefinish","endWritable","corkReq","hasInstance","cork","uncork","setDefaultEncoding","nenc","retried","_normalizeEncoding","normalizeEncoding","utf16Text","utf16End","fillLast","utf8FillLast","base64Text","base64End","simpleWrite","simpleEnd","lastNeed","lastTotal","utf8CheckByte","utf8CheckExtraBytes","utf8CheckIncomplete","copyProps","SafeBuffer","_Object$setPrototypeO","kLastResolve","kLastReject","kError","kEnded","kLastPromise","kHandlePromise","kStream","createIterResult","readAndResolve","onReadable","AsyncIteratorPrototype","ReadableStreamAsyncIteratorPrototype","lastPromise","wrapForNext","_this2","_Object$create","ERR_STREAM_PREMATURE_CLOSE","eos","called","_len","onlegacyfinish","writableEnded","readableEnded","onrequest","setHeader","isRequest","ERR_TRANSFORM_ALREADY_TRANSFORMING","ERR_TRANSFORM_WITH_LENGTH_0","afterTransform","_transformState","transforming","writechunk","rs","needTransform","writeencoding","_transform","_flush","ERR_MISSING_ARGS","destroyer","popCallback","destroys","createError","Proto","Err","cause","LevelUPError","EncodingError","rangeMethods","encodeKey","keyEncoding","Iterator","encodeLtgt","datum","encodeValue","decodeValue","encodeBatch","_encoding","_keyEncoding","batchOpts","_valueEncoding","ltgt","createStreamDecoder","none","bufferEncodings","support","createKeyRange","DEFAULT_PREFIX","indexedDB","onupgradeneeded","objectStoreNames","contains","createObjectStore","objectStore","await","keyRange","upgrade","batchOptions","each","deleteDatabase","isErrored","isSync","result1","_limit","_count","_callback","_completed","_aborted","_error","_transaction","_values","_keyAsBuffer","_valueAsBuffer","createIterator","openCursor","onItem","onComplete","continue","maybeNext","lower","upper","upperBound","lowerOpen","lowerBoundExclusive","upperOpen","upperBoundExclusive","IDBKeyRange","isDef","hasKey","lowerBoundKey","lowerBoundInclusive","upperBoundInclusive","upperBoundKey","startInclusive","endInclusive","toLtgt","_range","lb","ub","ta2str","ta","ta2buf","ab2str","ab","str2bin","openKeyCursor","direction","convertPrefix","firstChar","BaseBlockstore","convertQuery","cids1","libp2pPubsubRouters","DelegatedPeerRouter","DelegatedContentRouter","ipfsHttpClient","Libp2p","DelegatedPeerRouter__default","DelegatedContentRouter__default","bootstrap__default","Libp2p__default","libp2pOptions","libp2pDefaults","modules","router","routers","getPubsubRouter","contentRouting","peerRouting","peerDiscovery","mdns","relay","hop","active","clientMode","kBucketSize","nat","listen","announce","noAnnounce","connectionManager","maxConnections","minConnections","libp2pConfig","delegateHosts","delegateString","delegateAddr","delegateApiOptions","delegateHttpClient","getLibp2pOptions","gossipsub","__createBinding","__setModuleDefault","__importStar","__awaiter","thisArg","_arguments","generator","fulfilled","rejected","pubsub_1","message_cache_1","rpc_1","heartbeat_1","get_gossip_peers_1","utils_1","score_1","tracer_1","TimeCache","Envelope","Gossipsub","GossipsubIDv11","GossipsubIDv10","gossipIncoming","fallbackToFloodsub","floodPublish","doPX","directPeers","GossipsubD","Dlo","GossipsubDlo","Dhi","GossipsubDhi","Dscore","GossipsubDscore","Dout","GossipsubDout","Dlazy","GossipsubDlazy","heartbeatInterval","GossipsubHeartbeatInterval","fanoutTTL","GossipsubFanoutTTL","mcacheLength","GossipsubHistoryLength","mcacheGossip","GossipsubHistoryGossip","seenTTL","GossipsubSeenTTL","scoreParams","createPeerScoreParams","scoreThresholds","createPeerScoreThresholds","FloodsubID","debugName","addrs","seenCache","mesh","lastpub","gossip","control","peerhave","iasked","backoff","outbound","messageCache","MessageCache","getMsgId","heartbeat","Heartbeat","heartbeatTicks","gossipTracer","IWantTracer","_libp2p","score","PeerScore","_decodeRpc","_encodeRpc","rpc2","_addPeer","addPeer","registry","rvalue","_removePeer","peerStreams","peers1","removePeer","_processRpc","id9","peerStreams1","rpc1","_super","_processRpcControlMessage","controlMsg","iwant","ihave","_handleIHave","_handleIWant","prune","graft","_handleGraft","_handlePrune","outRpc","createGossipRpc","_sendRpc","_processRpcMessage","msgID","msgIdStr","messageIdToString","duplicateMessage","validateMessage","_acceptFrom","graylistThreshold","rejectMessage","gossipThreshold","GossipsubMaxIHaveMessages","GossipsubMaxIHaveLength","topicID","messageIDs","iask","iwantList","addPromise","id4","getForPeer","GossipsubGossipRetransmission","normalizeOutRpcMessage","id5","_now","peersInMesh","addPenalty","floodCutoff","GossipsubGraftFloodThreshold","GossipsubPruneBackoff","_addBackoff","_makePrune","id6","_doAddBackoff","acceptPXThreshold","_pxConnect","id7","topic2","id8","topic1","_applyIwantPenalties","getBrokenPromises","_clearBackoff","GossipsubPruneBackoffTicks","_directConnect","GossipsubDirectConnectTicks","toconnect","isWritable","_connect","peers2","GossipsubPrunePeers","pi","peerID","signedPeerRecord","envelope","openAndCertify","eid","consumePeerRecord","_directPeerInitial","GossipsubDirectConnectInitialDelay","id10","dialProtocol","topic6","topic3","leave","topic4","started","fanoutPeers","getGossipPeers","_sendGraft","topic5","meshPeers","_sendPrune","_publish","receivedFrom","deliverMessage","tosend","peersInTopic","topics","publishThreshold","id16","id11","topic7","id12","ctrl","_piggybackControl","_piggybackGossip","id13","outRpc1","tograft","toprune","id14","outRpc2","ihave1","_sendGraftPrune","noPX","pruning","id15","topics1","_emitGossip","topic8","exclude","getGossipIDs","peersToGossip","topicPeers","hasGossipProtocol","factor","GossipsubGossipFactor","peerMessageIDs","_pushGossip","peer1","controlIHaveMsgs","id17","topic9","px","xid","getRawEnvelope","multicodec","MulticodecTopology","PeerStreams","SignaturePolicy","signMessage","verifySignature","PubsubBaseProtocol","globalSignaturePolicy","StrictSign","canRelayMessage","emitSelf","messageProcessingConcurrency","ensureArray","registrar","ERR_INVALID_SIGNATURE_POLICY","topicValidators","_registrarId","_onIncomingStream","_onPeerConnected","_onPeerDisconnected","topology","onConnect","onDisconnect","register","unregister","connection","remotePeer","idB58Str","inboundStream","attachInboundStream","_processMessages","conn","newStream","attachOutboundStream","_sendSubscriptions","peerId3","stream1","rpcBytes","rpcMsg","idB58Str1","msgs","subOpt","_processRpcSubOpt","normalizeInRpcMessage","topicSet","_emitMessage","signaturePolicy","msgId","seqno","StrictNoSign","noSignMsgId","ERR_UNHANDLED_SIGNATURE_POLICY","ERR_UNEXPECTED_FROM","ERR_UNEXPECTED_SIGNATURE","ERR_UNEXPECTED_KEY","ERR_UNEXPECTED_SEQNO","ERR_MISSING_SIGNATURE","ERR_MISSING_SEQNO","ERR_INVALID_SIGNATURE","validatorFn","_buildMessage","randomSeqno","getSubscribers","msgObject","outMsg","Topology","multicodecTopologySymbol","_registrar","_onProtocolChange","_onPeerConnect","_updatePeers","peerDataIterable","getConnection","_onConnect","hadPeer","hasProtocol","_onDisconnect","peerData","topologySymbol","disconnect","SubOpts","$oneOfFields","oneofs","_subscribe","_topicID","_from","_seqno","_signature","lp","abortable","_rawOutboundStream","_rawInboundStream","_inboundAbortController","outboundStream","isReadable","returnOnAbort","_prevStream","shouldEmit","varintEncode","varintDecode","int32BEEncode","int32BEDecode","minPoolSize","encodeLength","lengthEncoder","poolOffset","MIN_POOL_SIZE","DEFAULT_POOL_SIZE","Varint","MAX_DATA_LENGTH","ReadModes","ReadHandlers","ReadModes_LENGTH","dataLength","lengthDecoder","maxLengthLength","maxDataLength","onLength","ReadModes_DATA","nextChunk","fromReader","varByteSource","MAX_LENGTH_LENGTH","getIterator","toAbortableSource","toMultiAbortableSource","nextAbortHandler","abortHandler","signal2","abortMessage","abortCode","signal3","aborter","isKnownAborter","toAbortableSink","toMultiAbortableSink","toMultiAbortableDuplex","anyMatch","bHas","maybeArray","SignPrefix","messagePublicKey","keyPeerId","history","msgIdFn","peertx","msgID1","msgIDs","__exportStar","constants_1","ERR_TOPIC_VALIDATOR_IGNORE","ERR_TOPIC_VALIDATOR_REJECT","TimeCacheDuration","GossipsubIWantFollowupTime","GossipsubOpportunisticGraftPeers","GossipsubOpportunisticGraftTicks","GossipsubConnectionTimeout","GossipsubMaxPendingConnections","GossipsubConnectors","GossipsubHeartbeatInitialDelay","to_string_1","$oneOfFields1","ControlMessage","_control","ControlIHave","ControlIWant","ControlGraft","ControlPrune","PeerInfo","_backoff","_peerID","_signedPeerRecord","_heartbeatTimer","_heartbeat","scores","getScore","prunePeer","graftPeer","ineed","peersArray","rotate","peersList","medianIndex","medianScore","opportunisticGraftThreshold","lastpb","validateTopicScoreParams","validatePeerScoreParams","createTopicScoreParams","defaultTopicScoreParams","defaultPeerScoreParams","topicWeight","ERR_INVALID_PEER_SCORE_PARAMS","timeInMeshQuantum","timeInMeshWeight","timeInMeshCap","firstMessageDeliveriesWeight","firstMessageDeliveriesDecay","firstMessageDeliveriesCap","meshMessageDeliveriesWeight","meshMessageDeliveriesDecay","meshMessageDeliveriesCap","meshMessageDeliveriesThreshold","meshMessageDeliveriesWindow","meshMessageDeliveriesActivation","meshFailurePenaltyWeight","meshFailurePenaltyDecay","invalidMessageDeliveriesWeight","invalidMessageDeliveriesDecay","topicScoreCap","appSpecificScore","appSpecificWeight","IPColocationFactorWeight","IPColocationFactorThreshold","IPColocationFactorWhitelist","behaviourPenaltyWeight","behaviourPenaltyDecay","decayInterval","decayToZero","retainScore","topicScoreParams","ERR_INVALID_PEER_SCORE_THRESHOLDS","validatePeerScoreThresholds","defaultPeerScoreThresholds","__importDefault","peer_score_params_1","peer_stats_1","compute_score_1","message_deliveries_1","peer_id_1","pubsubErrors","_connectionManager","peerStats","peerIPs","deliveryRecords","MessageDeliveries","_backgroundInterval","_refreshScores","_updateIPs","pstats","connected","tstats","tparams","firstMessageDeliveries","meshMessageDeliveries","meshFailurePenalty","invalidMessageDeliveries","inMesh","meshTime","graftTime","meshMessageDeliveriesActive","behaviourPenalty","_removeIPs","ips","computeScore","penalty","createPeerStats","_getIPs","_setIPs","deficit","ensureTopicStats","ensureRecord","_markFirstMessageDelivery","drec","DeliveryRecordStatus","unknown","valid","validated","_markDuplicateMessageDelivery","firstSeen","_markInvalidMessageDelivery","invalid","ignored","cap","validatedTime","remoteAddr","newIPs1","oldIPs","addNewIPs","xip","removeOldIPs","ip1","newIPs","createTopicStats","ps","topicStats","topicParams","topicScore","p5","peersInIP","numPeersInIP","surplus","p7","denque_1","DeliveryRecordStatus1","peekFront","Denque","_head","_tail","_capacity","capacity","_capacityMask","_list","_fromArray","peekAt","peekBack","_growArray","_shrinkArray","removeOne","del_count","arg_len","arguments_index","leng","_copyArray","fullCopy","newArray","msgIds","throttle","validity1","sweep","getTimeElapsed","FUNC_ERROR_TEXT","NAN","symbolTag","reTrim","reIsBadHex","reIsBinary","reIsOctal","freeParseInt","freeGlobal","freeSelf","objectProto","nativeMax","nativeMin","debounce","wait","lastArgs","lastThis","maxWait","timerId","lastCallTime","lastInvokeTime","leading","maxing","trailing","invokeFunc","leadingEdge","timerExpired","shouldInvoke","timeSinceLastCall","trailingEdge","remainingWait","debounced","isInvoking","isObjectLike","uint8arraysConcat","uint8arraysFromString","uint8arraysEquals","Protobuf","payloadType","payloadType1","payload","payload1","signature1","_marshal","domain1","signData","formatSignaturePayload","domainUint8Array","domainLength","payloadTypeLength","payloadLength","envelopeData","seal","ERR_SIGNATURE_NOT_VALID","messages","NOT_STARTED_YET","DHT_DISABLED","CONN_ENCRYPTION_REQUIRED","PUBSUB_NOT_STARTED","DHT_NOT_STARTED","ERR_INVALID_PROTOCOLS_FOR_STREAM","ERR_CONNECTION_ENDED","ERR_CONNECTION_FAILED","ERR_NODE_NOT_STARTED","ERR_ALREADY_ABORTED","ERR_TOO_MANY_ADDRESSES","ERR_NO_VALID_ADDRESSES","ERR_RELAYED_DIAL","ERR_DIALED_SELF","ERR_DISCOVERED_SELF","ERR_DUPLICATE_TRANSPORT","ERR_ENCRYPTION_FAILED","ERR_HOP_REQUEST_FAILED","ERR_INVALID_KEY","ERR_INVALID_MESSAGE","ERR_INVALID_PARAMETERS","ERR_INVALID_PEER","ERR_MUXER_UNAVAILABLE","ERR_TIMEOUT","ERR_TRANSPORT_UNAVAILABLE","ERR_TRANSPORT_DIAL_FAILED","ERR_UNSUPPORTED_PROTOCOL","ERR_INVALID_MULTIADDR","client","_client","_httpQueue","getEndpointConfig","findPeer","keyStr","onStart","onFinish","responses","_httpQueueRefs","providers","findProvs","numProviders","provide","index$e","index$f","index$g","index$h","urlSource_js","urlSource_js__default","id$1","multibases$1","multihashes$1","createBitswap","createBlock","createBootstrap","createCommands","createDag","createDiag","createGetEndpointConfig","createLog","createMount","createName","createObject","createPin","createStats","createSwarm","LOAD_BASE","_basesByName","_basesByPrefix","_loadBase","addBase","removeBase","nameOrPrefix","listBases","LOAD_CODEC","_codecsByName","_codecsByCode","_loadCodec","addCodec","removeCodec","codec1","listCodecs","LOAD_HASHER","_hashersByName","_hashersByCode","_loadHasher","addHasher","removeHasher","hasher1","listHashers","toUrlSearchParams","Keys","core","Client","toUrlString","getAgent","getAgent__default","DEFAULT_PROTOCOL","DEFAULT_HOST","DEFAULT_PORT","errorHandler","KEBAB_REGEX","kebabCase","agent","apiPath","Agent","keepAlive","maxSockets","normalizeOptions","multiAddrToUri__default","modeToString","mtimeNsecs","urlSearchParams","ProvideBufLen","Wantlist","BlocksReceived","DataReceived","BlocksSent","DataSent","DupBlksReceived","DupDataReceived","toCoreInterface","multipartRequest","abortSignal","normaliseInput_browser","formData","FormData","fileSuffix","fieldName","normaliseContent_browser","itToBlob","Size","createGetAll","createSet","createReplace","createProfiles","createApply","OldCfg","NewCfg","objectToCamel","caps","camelObj","encodeParam","Cid","PinErrorMsg","inputEnc","RemPath","createFindPeer","createFindProvs","createProvide","createQuery","responseTypes","FinalPeer","Responses","ID","Addrs","AddingPeer","DialingPeer","PeerResponse","Provider","QueryError","SendingQuery","Extra","cidArr","createCmds","createNet","createSys","sourceArr","objectToCamelWithMetadata","Entries","toIterable__default","WithLocality","streamChannels","createLevel","createTail","subsystem","Strings","createPatch","dataEncoding","dagPut","dLink","createRemote","Pins","createService","encodeAddParams","decodePin","encodeService","Status","origins","encodeQuery","endpoint","encodeEndpoint","decodeStat","Pinning","Pinned","Queued","Failed","PinCount","queued","pinning","failed","decodeRemoteService","ApiEndpoint","Stat","RemoteServices","subscriptionTracker","subscriptionTracker$1","SubscriptionTracker","createPeers","createSubscribe","createUnsubscribe","isAbortError","subsTracker","fail","ffWorkaround","onMessage","onError","readMessages","_subs","topicSubs","handler1","unsubs","argsArr","res1","NumObjects","RepoSize","RepoPath","Version","StorageMax","TotalIn","TotalOut","RateIn","RateOut","connect","localAddrs","createAddrs","createConnect","createDisconnect","createLocalAddrs","Addr","Peer","muxer","Muxer","latency","Latency","Streams","Direction","progressFn","createProgressHandler","createOnUploadProgress","loaded","mapLink","Mode","Mtime","MtimeNsecs","Objects","readURLContent","WS","Multiplex","libp2pNoise","KadDHT","GossipSub","WS__default","WebRTCStar__default","Multiplex__default","KadDHT__default","GossipSub__default","dialer","maxParallelDials","maxDialsPerPeer","dialTimeout","streamMuxer","connEncryption","NOISE","autoDial","randomWalk","persistence","pDefer","createListener","toConnection","_upgrader","_filter","socket","maConn","upgradeOutbound","ma1","cOpts","errorPromise","errfn","rawSocket","dnsWss","WebSocket","wsurl","websocket","remoteAddress","binaryType","EventIterator","connError","readyState","cleanUp","cont","onOpen","event_iterator_1","evOptions","EventQueue","pullQueue","pushQueue","eventHandlers","isStopped","resolution","placeholder","highWater","error1","rejection","removeCallback","lowWaterMark","lowWater","closeOnEnd","wasClean","cleanup","handleOpen","handleErr","CLOSE_TIMEOUT","toMultiaddr","localAddr","localAddress","localPort","remotePort","timeline","CODE_P2P","CODE_CIRCUIT","CODE_TCP","CODE_WS","CODE_WSS","Address4","Address6","ERR_INVALID_IP_PARAMETER","ERR_INVALID_PORT_PARAMETER","ERR_INVALID_IP","is4","to4","correctForm","_ipv4","_ipv6","_addressError","parcelHelpers","_common","_constants","_jsbn","_sprintfJs","groups","GROUPS","parsedAddress","parsedSubnet","subnet","subnetMask","isCorrect","BITS","isInSubnet","RE_SUBNET_STRING","AddressError","addressMinusSuffix","address1","address2","RE_ADDRESS","padded","arpaFormAddress","sprintf","toGroup6","bigInteger","_startAddress","startAddress","fromBigInteger","startAddressExclusive","adjust","_endAddress","endAddress","endAddressExclusive","fromInteger","getBitsBase2","binaryZeroPad","reverseForm","reversed","omitSuffix","isMulticast","groupForV6","segments","defaultBits","parseMessage","inBrowser","rng_state","rng_pool","rng_pptr","rng_seed_time","rng_psize","square","ua","appVersion","z1","rng_get_byte","Arcfour","SecureRandom","ba","not_string","not_bool","not_type","not_primitive","numeric_arg","not_json","modulo","key_access","index_access","sprintf_format","sprintf_parse","vsprintf","fmt","parse_tree","pad_character","pad_length","is_positive","tree_length","param_no","precision","toExponential","toPrecision","pad_char","sprintf_cache","_fmt","arg_names","field_list","replacement_field","field_match","_constants1","_helpers","_regularExpressions","condition","spanLeadingZeroes4","paddedHex","octet","unsignByte","optionalGroups","zone","RE_ZONE_STRING","RE_URL_WITH_PORT","RE_URL","address4","mask6","insertIndex","microsoftTranscription","possibleSubnets","subnetSize","subnetPowers","addCommas","getScope","scope","SCOPES","getBits","getType","TYPES","start1","end1","getBitsBase16","start2","end2","getBitsPastSubnet","characters","canonicalForm","zeroCounter","zeroLengths","correct","parse4in6","address3","parsedAddress4","badCharacters","RE_BAD_CHARACTERS","badAddress","RE_BAD_ADDRESS","halves","elidedGroups","elisionBegin","elisionEnd","decimal","to4in6","infix","inspectTeredo","udpPort","server4","client4","flagsBase2","coneNat","reserved","groupIndividual","universalLocal","microsoft","inspect6to4","gateway","to6to4","addr6to4","toUnsignedByteArray","fromUnsignedByteArray","BYTE_MAX","isCanonical","isLinkLocal","isTeredo","is6to4","isLoopback","optionalPort","formFunction","simpleGroup","classes","regularExpressionString","substringSearch","address6","simpleRegularExpression","possibleElisions","regularExpression","substringSearch1","spanAllZeroes","spanAll","spanLeadingZeroes","spanLeadingZeroesSimple","addressString","groupPossibilities","padGroup","ADDRESS_BOUNDARY","possibilities","zeroIndexes","zeroIndex","elision","moreLeft","moreRight","cancelablePromise","customTimers","testMa","dnsWsOrWss","SimplePeer","supportsWebRTCDataChannels","webrtcSupport","cleanMultiaddr","cleanUrlSIO","sioOptions","transports","wrtc","sigReferences","discovery","_isStarted","_peerDiscovered","ma2","rawConn","spOptions","initiator","intentId","sio","sioClient","channel","onTimeout","srcMultiaddr","signallingAddr","dstMultiaddr","offer","answer","maStr","getBrowserRTC","randombytes","MAX_BUFFERED_AMOUNT","filterTrickle","sdp","_debug","channelName","channelConfig","negotiated","offerOptions","answerOptions","sdpTransform","allowHalfTrickle","iceCompleteTimeout","_connected","remoteFamily","localFamily","_wrtc","_pcReady","_channelReady","_iceComplete","_iceCompleteTimer","_channel","_pendingCandidates","_isNegotiating","_batchedNegotiation","_queuedNegotiation","_sendersAwaitingStable","_senderMap","_firstStable","_closingInterval","_remoteTracks","_remoteStreams","_chunk","_cb","_pc","RTCPeerConnection","_isReactNativeWebrtc","_peerConnectionId","oniceconnectionstatechange","_onIceStateChange","onicegatheringstatechange","onconnectionstatechange","_onConnectionStateChange","onsignalingstatechange","_onSignalingStateChange","onicecandidate","_onIceCandidate","_setupData","createDataChannel","ondatachannel","addStream","ontrack","_onTrack","_needsNegotiation","_onFinishBound","_onFinish","bufferSize","bufferedAmount","renegotiate","transceiverRequest","addTransceiver","kind","remoteDescription","_addIceCandidate","setRemoteDescription","RTCSessionDescription","_createAnswer","iceCandidateObj","RTCIceCandidate","addIceCandidate","getTracks","track","addTrack","track2","stream2","submap","sender","replaceTrack","oldTrack","newTrack","stream3","removeTrack","track1","stream4","removeStream","stream5","negotiate","_createOffer","cb3","onmessage","bufferedAmountLowThreshold","_onChannelMessage","onbufferedamountlow","_onChannelBufferedAmountLow","_onChannelOpen","_onChannelClose","isClosing","chunk1","cb1","destroySoon","_startIceCompleteTimeout","createOffer","sendOffer","localDescription","setLocalDescription","_requestMissingTransceivers","getTransceivers","transceiver","createAnswer","sendAnswer","connectionState","iceConnectionState","iceGatheringState","_maybeReady","getStats","cb2","flattenValues","report","reports","_connecting","findCandidatePair","remoteCandidates","localCandidates","candidatePairs","foundSelectedCandidatePair","setSelectedCandidatePair","selectedCandidatePair","localCandidateId","ipAddress","portNumber","googLocalAddress","remoteCandidateId","googRemoteAddress","selectedCandidatePairId","googActiveConnection","selected","unref","signalingState","sdpMLineIndex","sdpMid","event2","event3","eventStream","remoteStream","WEBRTC_SUPPORT","iceServers","urls","sdpSemantics","mozRTCPeerConnection","webkitRTCPeerConnection","mozRTCSessionDescription","webkitRTCSessionDescription","mozRTCIceCandidate","webkitRTCIceCandidate","MAX_UINT32","oldBrowser","supportsFileReader","supportsWebRTC","mediaDevices","listeningAddr","signallingUrl","__connections","__spChannels","__pendingIntents","localPeer","pendings","pendingOffer","upgradeInbound","untrackConn","trackConn","getAddrs","_socketIoParser","_managerJs","Manager","_urlJs","_socketJs","sameNamespace","forceNew","multiplex","queryKey","_parseuri","loc","_parseuriDefault","authority","ipv6uri","pathNames","regx","$0","$2","_engineIoClient","_onJs","_backo2","_componentEmitter","Emitter","nsps","reconnection","reconnectionAttempts","reconnectionDelay","reconnectionDelayMax","randomizationFactor","_backo2Default","jitter","_readyState","_parser","parser","_autoConnect","autoConnect","_reconnection","_reconnectionAttempts","_reconnectionDelay","setMin","v3","_randomizationFactor","setJitter","_reconnectionDelayMax","setMax","v5","maybeReconnectOnOpen","_reconnecting","attempts","reconnect","engine","Socket","skipReconnect","openSubDestroy","errorSub","emitReserved","setTimeoutFn","autoUnref","fn1","onping","ondecoded","packet","nsp","_packet","packet1","encodedPackets","subDestroy","duration","onreconnect","attempt","_transportJs","_utilJs","_parseqs","_engineIoParser","secure","writeBuffer","prevBufferLen","withCredentials","timestampParam","rememberUpgrade","rejectUnauthorized","perMessageDeflate","transportOptions","closeOnBeforeunload","_parseqsDefault","upgrades","pingInterval","pingTimeout","pingTimeoutTimer","offlineEventListener","onClose","createTransport","sid","priorWebsocketSuccess","setTransport","onDrain","onPacket","probe","onTransportOpen","upgrading","freezeTransport","onTransportClose","onupgrade","onHandshake","resetPingTimeout","sendPacket","filterUpgrades","clearTimeoutFn","fn2","cleanupAndClose","waitForUpgrade","filteredUpgrades","_pollingXhrJs","polling","XHR","_xmlhttprequestJs","_globalThisJs","_pollingJs","hasXHR2","_xmlhttprequestJsDefault","xdomain","Polling","isSSL","xd","forceBase64","supportsBinary","doPoll","pollXhr","opts2","pick","xscheme","xhr","extraHeaders","setDisableHeaderCheck","requestTimeout","onreadystatechange","onLoad","requestsCount","onSuccess","fromError","responseText","attachEvent","unloadHandler","terminationEvent","_globalThisJsDefault","_hasCors","_hasCorsDefault","installTimerFunctions","NATIVE_SET_TIMEOUT","NATIVE_CLEAR_TIMEOUT","useNativeTimers","mixin","_callbacks","hasListeners","_yeast","Transport","doOpen","onPause","doClose","packets","timestampRequests","_yeastDefault","encodedQuery","decodePacket","encodePayload","decodePayload","_encodePacketJs","_decodePacketJs","SEPARATOR","encodedPacket","encodedPayload","decodedPacket","_decodePacketJsDefault","_commonsJs","withNativeBlob","withNativeArrayBuffer","encodeBlobAsBase64","fileReader","readAsDataURL","PACKET_TYPES","PACKET_TYPES_REVERSE","ERROR_PACKET","_base64Arraybuffer","decodeBase64Packet","mapBinary","chars","arraybuffer","encoded1","encoded2","encoded3","encoded4","bufferLength","yeast","qry","_websocketConstructorJs","usingBrowserWebSocket","defaultBinaryType","addEventListeners","_socket","lastPacket","MozWebSocket","RESERVED_EVENTS","connect_error","disconnecting","disconnected","receiveBuffer","sendBuffer","ids","acks","subEvents","onpacket","args2","args1","PacketType","EVENT","ack","_registerAckCallback","isTransportWritable","volatile","packet4","CONNECT","onconnect","BINARY_EVENT","onevent","ACK","BINARY_ACK","onack","DISCONNECT","ondisconnect","CONNECT_ERROR","packet2","emitEvent","args3","_anyListeners","sent","packet3","emitBuffered","onAny","prependAny","listener1","offAny","listener2","listenersAny","PacketType1","_binaryJs","_isBinaryJs","hasBinary","encodeAsString","encodeAsBinary","attachments","deconstruction","deconstructPacket","decodeString","reconstructor","BinaryReconstructor","takeBinaryData","str1","tryParse","isPayloadValid","finishedReconstruction","reconPack","binData","reconstructPacket","packetData","_deconstructPacket","_placeholder","_reconstructPacket","withNativeFile","Backoff","deviation","toIterable","toWebrtcMultiaddr","maybeEndSource","errCb","closeCb","closeHandler","finishCb","finishHandler","drainCb","drainHandler","toDuplex","sinkError","toSink","toSource","maStrSplit","tcpProto","wsProto","tcpPort","isName","tuppleIPFS","tupple","Coder","restrictSize","MessageTypes","MessageTypeNames","createStream","Mplex","onStream","_streamId","_streams","initiators","receivers","_createSink","_createSource","onStreamEnd","_newStream","_newReceiverStream","maxMsgSize","_handleIncoming","type1","NEW_STREAM","MESSAGE_INITIATOR","MESSAGE_RECEIVER","CLOSE_INITIATOR","CLOSE_RECEIVER","RESET_INITIATOR","RESET_RECEIVER","POOL_SIZE","_pool","_poolOffset","_buffer","_bufferProxy","_headerInfo","_decodeHeader","MAX_MSG_SIZE","checkSize","InitiatorMessageTypes","MESSAGE","CLOSE","RESET","ReceiverMessageTypes","ERR_MPLEX_STREAM_RESET","resetController","Types","externalId","endErr","sourceEnded","sinkEnded","onSinkEnd","noise_1","Noise","x25519","buffer_1","it_pb_rpc_1","duplex_1","it_buffer_1","it_pipe_1","it_length_prefixed_1","handshake_xx_1","handshake_ik_1","handshake_xx_fallback_1","encoder_1","crypto_1","keycache_1","logger_1","staticNoiseKey","earlyData","prologue","useNoisePipes","staticKeys","secretKey","generateKeypair","wrappedConnection","uint16BEEncode","uint16BEDecode","NOISE_MSG_MAX_LENGTH_BYTES","handshake","performHandshake","isInitiator","createSecureConnection","remoteEarlyData","localPeer1","connection1","remotePeer1","getPayload","tryIK","KeyCache","performXXHandshake","ikHandshake","IKHandshake","performIKHandshake","ephemeralKeys","getLocalEphemeralKeys","performXXFallbackHandshake","initialMsg","XXFallbackHandshake","propose","exchange","logger","params2","XXHandshake","getRemoteStaticKey","stage0","stage1","connection2","handshake1","user","encryptStream","decryptStream","random_1","wipe_1","PUBLIC_KEY_LENGTH","SECRET_KEY_LENGTH","SHARED_KEY_LENGTH","_9","_121665","scalarMult","x32","x16","scalarMultBase","wipe","sharedKey","mySecretKey","theirPublicKey","rejectZero","system_1","binary_1","defaultRandomSource","SystemRandomSource","randomUint32","ALPHANUMERIC","randomString","charset","charsLen","maxByte","randomByte","randomStringForEntropy","browser_1","node_1","SystemRandomSource1","isAvailable","_source","BrowserRandomSource","NodeRandomSource","BrowserRandomSource1","isInstantiated","browserCrypto","NodeRandomSource1","nodeCrypto","int_1","writeUint64BE","writeUint64LE","readInt64BE","readUint64BE","readInt64LE","readUint64LE","readFloat32BE","readFloat32LE","readFloat64BE","readFloat64LE","writeFloat32BE","writeFloat32LE","writeFloat64BE","writeFloat64LE","rotl","rotr","Shake","shake","lpReader","isDone","readLP","readPB","writeLP","writePB","sourcePromise","sinkErr","sinkPromise","Pair","onSource","toList","xx_1","staticKeypair","XX","session","initSession","logLocalStaticKeys","hs","messageBuffer","sendMessage","encode0","logLocalEphemeralKeys","receivedMessageBuffer","decode0","recvMessage","logRemoteEphemeralKey","logRemoteStaticKey","decodedPayload","getPeerIdFromPayload","verifySignedPayload","setRemoteEarlyData","encode2","decode2","logCipherState","getCS","encryptWithAd","session1","decryptWithAd","session2","encryption","cs1","cs2","abstract_handshake_1","AbstractHandshake","initializeInitiator","psk","initializeSymmetric","mixHash","initializeResponder","prologue1","rs1","psk1","writeMessageA","encryptAndHash","writeMessageB","hs1","mixKey","spk","writeMessageC","hs2","payload2","createEmptyKey","readMessageA","hs3","isValidPublicKey","decryptAndHash","readMessageB","hs4","valid1","valid2","readMessageC","hs5","prologue2","mc","ephemeral","resultingBuffer","writeMessageRegular","resultingPlaintext","resultingValid","hkdf_1","sha256_1","libp2p_crypto_1","payload_1","equals_1","NoiseHandshakePayloadProto","NoiseHandshakePayload","createHandshakePayload","libp2pPublicKey","signedPayload","payloadInit","identityKey","identitySig","signPayload","getHandshakePayload","staticPublicKey","earlyDataPayload","noiseStaticKey","publicKeyProtobuf","generatedPeerId","isValidPeerId","generatedPayload","getHkdf","ck","ikm","okmU8Array","HKDF","expand","okm","hmac_1","HKDF1","_counter","_hash","_info","HMAC","_bufpos","_fillBuffer","hash_1","constant_time_1","HMAC1","_finished","_inner","_outer","isSerializableHash","_innerKeyedState","saveState","_outerKeyedState","restoreState","cleanSavedState","savedState","subject","resultIfOne","resultIfZero","lessOrEqual","DIGEST_LENGTH","BLOCK_SIZE","SHA2561","_temp","_bufferLength","_bytesHashed","_initState","dataPos","hashBlocks","bytesHashed","bitLenHi","bitLenLo","encodeDelimited","decodeDelimited","chacha20poly1305_1","MIN_NONCE","ad","setNonce","incrementNonce","ad1","isEmptyKey","cs3","nonceToBytes","n2","ad2","plaintext1","encryptedMessage","ChaCha20Poly1305","plaintext2","n3","ad3","ciphertext1","ss1","ciphertext2","derivedU8","derived","ss2","getHash","ss3","tempK","initializeKey","protocolName","protocolNameBytes","hashProtocolName","protocolName1","ss4","tempk1","tempk2","cs4","readMessageRegular","cs5","chacha_1","poly1305_1","KEY_LENGTH","NONCE_LENGTH","TAG_LENGTH","ZEROS","ChaCha20Poly13051","associatedData","authKey","streamXOR","_authenticate","sealed","calculatedTag","tagOut","Poly1305","j0","j1","j2","j3","j4","j5","j6","j7","j8","j9","j10","j11","j12","j13","j14","j15","x0","x4","x5","x6","x7","x8","x9","x10","x11","x12","x13","x14","x15","nonceInplaceCounterLength","nc","counterLength","incrementCounter","Poly13051","_r","_leftover","_fin","_blocks","mpos","hibit","h8","h9","r0","r3","r4","r5","r6","r7","r8","r9","d0","d4","d5","d6","d7","d8","d9","mac","macpos","want","oneTimeAuth","debug_1","keyLogger","DUMP_SESSION_KEYS","NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG","ik_1","errors_1","remoteStaticKey","ik","IK","receivedMsg","FailedIKError","rs2","chunkBuffer","decrypted","resetStorage","RoutingTable","contentFetching","Providers","QueryManager","protocolPrefix","forceProtocolLegacy","ALPHA","onPut","onRemove","PROTOCOL_DHT","_clientMode","disjointPaths","routingTable","_log","_queryManager","_running","nvals","bufferToKey","maxNumProviders","findProviders","shallow","getClosestPeers","getPublicKey","convertBuffer","closestPeers","_nearestPeersToQuery","closer","_isSelf","key8","rawRecord","MAX_RECORD_AGE","key9","rec","PUT_VALUE","resp","sendRequest","key10","_getValueSingle","closerPeers","_verifyRecordOnline","peer2","key11","GET_VALUE","record1","KBuck","uint8ArrayXor","GENERATED_PREFIXES","refreshInterval","_kBucketSize","_refreshInterval","numberOfNodesPerKBucket","numberOfNodesToPing","commonPrefixLengthRefreshedAt","_refreshTable","_onPing","localNodeId","convertPeerId","_refreshTimeoutId","prefixLength","_maxCommonPrefix","refreshCpls","_getTrackedCommonPrefixLengthsForRefresh","getFullYear","lastRefresh","_refreshCommonPrefixLength","_numPeersForCpl","lastCpl","cpl","force1","_generateRandomPeerId","maxCommonPrefix","dates","targetCommonPrefixLength","randomUint16","_makePeerId","localKadId","randomPrefix","targetCommonPrefixLength1","localPrefix","keyPrefix","keyBuffer","keyView","_prefixLengths","distance","leadingZeros","oldContacts","newContact","oldest","closest","closestPeer","arrayEquals","array1","array2","ensureInt8","KBucket","arbiter","contacts","dontSplit","incumbent","vectorClock","firstId","secondId","contact","bitIndex","_determineNode","_indexOf","_split","detNode","bytesDescribedByBitIndex","bitIndexWithinByte","node2","bitIndex1","node3","contact1","uint8ArrayCompare","pMap","keyForPublicKey","isPublicKeyKey","fromPublicKeyKey","decodeBase32","sortClosestPeers","xorCompare","pathSize","resultsWanted","numPaths","createPutRecord","asyncFn","mapParallel","mapper","stopOnError","isRejected","isIterableDone","resolvingCount","currentIndex","nextItem","indentString","cleanStack","_errors","includeEmptyLines","extractPathRegex","pathRegex","homeDir","homedir","pretty","pathMatches","PROVIDERS_KEY_PREFIX","PROVIDERS_LRU_CACHE_SIZE","PROVIDERS_VALIDITY","PROVIDERS_CLEANUP_INTERVAL","READ_MESSAGE_TIMEOUT","GET_MANY_RECORD_COUNT","readMessageTimeout","_rpc","isConnected","_add","msg4","connectToPeer","_writeReadMessage","to1","_writeMessage","writeReadMessage","msg3","flatMap","flatTransform","flatten","parallelFlatMap","parallelMap","parallelMerge","tap","writeToStream","curriedIterable","dataBatch","_syncBatch","resolveFunc","rejectFunc","resultQueue","fillQueue","readDeferred","fulfillReadQueue","asyncIterableIterator","valueQueue","syncBuffer","_collect","iterables","itr","_concat","_syncConcat","_consume","filterFunc","maybeItr","_map","_flatTransform","inflightCount","lastError","itrValue","asyncVal","mapAndQueue","curriedFunc","onceReadable","_fromStream","nextVal","firstFn","previousFn","transformError","_parallelMap","inputs","concurrentWork","valueCb","notifyError","notifyDone","queueNext","curriedStart","taken","_take","_syncTake","_asyncTap","addTime","seconds","nanoseconds","hrtime","_asyncTime","_syncTime","_writeToStream","notifyDrain","getMessageHandler","handleMessage","desMessage","MESSAGE_TYPE","MessageType","CONNECTION_TYPE","ConnectionType","_clusterLevelRaw","providerPeers","clusterLevel","level1","clusterLevelRaw","toPbPeer","dec","fromPbPeer","CONNECTED","CONNECTION_TYPES","author","_author","_timeReceived","_type","_record","_connection","FIND_NODE","ADD_PROVIDER","GET_PROVIDERS","PING","idFromKey","_checkLocalDatastore","_betterPeersToQuery","_verifyRecordLocally","recordKey","addProvider","getProviders","Query","putLocal","counterAll","counterSuccess","_putValueToPeer","minPeers","recs","best","fixupRec","_putLocal","sendCorrectionRecord","localRec","getLocal","rtp","valsLength","pathIndex","queryResults","lookupErr","_getValueOrPeers","pathComplete","Run","makePath","running","_onStart","_onComplete","finalSet","_run","execute","_startTime","queryStarted","peersSeen","queryCompleted","PeerDistanceList","WorkerQueue","peersQueried","addInitialPeer","executePaths","queryComplete","startWorker","peersQueriedPromise","dhtKey","queuedPeerIds","anyCloser","originDhtKey","peerDistances","pd","peerIds","dhtKeys","furthestDistance","keyDistance","PeerQueue","queryFunc","initialPeers","peersToQuery","fromKey","addPeerToQuery","workerQueue","Heap","Heap1","defaultCmp","heapify","heappop","heappush","heappushpop","heapreplace","insort","nlargest","nsmallest","updateItem","_siftdown","_siftup","lastelt","returnitem","_ref","_i","_ref1","_results","_results1","_j","los","startpos","newitem","parentpos","childpos","endpos","rightpos","pushpop","front","setupQueue","execution","execPromise","processNext","continueQuerying","continueQueryingError","execError","execQuery","queryError","queryCloser","LimitedPeerList","providerTimeout","pData","pathProviders","findProvidersSingle","provs","prov","PeerList","getPublicKeyFromNode","getValueSingle","recPeer","findPeerLocal","_findPeerSingle","tablePeers","closerPeersSingle","sorted","pId","makeProviderKey","parseProviderKey","readTime","cacheSize","cleanupInterval","provideValidity","lruCacheSize","syncQueue","_cleaner","_cleanup","deleteCount","deleted","expired","cacheKey","loadProviders","provider","_getProvidersMap","writeProviderEntry","base32PeerId","queries","_discoverBootstrapPeers","PeerRouting","ContentRouting","getPeer","validateConfig","AddressManager","ConnectionManager","Relay","Dialer","Metrics","TransportManager","Upgrader","PeerStore","PubsubAdapter","PersistentPeerStore","Registrar","IdentifyService","NatManager","updateSelfPeerRecord","addressManager","_modules","_transport","_discovery","keychainOpts","generateOptions","onConnection","onConnectionEnd","transportManager","faultTolerance","natManager","cryptos","muxers","identifyService","getProtocolStr","connProtector","protector","LIBP2P_FORCE_PNET","DHT","_onDiscoveryPeer","eventName","_onStarting","_onDidStart","unmount","importPeer","connections","dial","_dial","getAnnounceAddrs","getObservedAddrs","announceFilter","addrSet","peer3","peer4","protocols1","unhandle","protocols2","getListenAddrs","_maybeConnect","_setupPeerDiscovery","peer5","setupService","DiscoveryService","discoveryService","DiscoveryService1","getTransports","storeAddresses","uniquePeers","requirePeers","setDelayedInterval","clearDelayedInterval","_peerStore","_routers","_refreshManagerOptions","refreshManager","_findClosestPeersTask","bootDelay","maybeLimitSource","intervals","_runPeriodically","nVals","dnsaddrResolver","Constants","AGENT_VERSION","RelayConstants","publicAddressesFirst","FaultTolerance","FATAL_ALL","MAX_PARALLEL_DIALS","MAX_PER_PEER_DIALS","DIAL_TIMEOUT","addressSorter","queriesPerPeriod","externalIp","pmp","advertise","ADVERTISE_BOOT_DELAY","ADVERTISE_TTL","autoRelay","maxListeners","resultingOptions","dnsaddrCode","resolveTxt","Receptacle","Resolver","maxCache","_servers","getServers","_getShuffledServers","newServers","setServers","servers","rrType","resolve4","resolve6","recordType","cached","getCacheKey","buildResource","serverResolver","Answer","hostname2","hostname3","toMS","lastModified","expires","refresh","oldRecord","nativeFetch","accept","MAX_ADDRS_TO_DIAL","METRICS","computeThrottleMaxQueueSize","computeThrottleTimeout","movingAverageIntervals","maxOldPeersRetention","libp2pVersion","PROTOCOL_VERSION","MULTICODEC_IDENTIFY","MULTICODEC_IDENTIFY_PUSH","IDENTIFY_PROTOCOL_VERSION","MULTICODEC_IDENTIFY_PROTOCOL_NAME","MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME","MULTICODEC_IDENTIFY_PROTOCOL_VERSION","MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION","CIRCUIT_PROTO_CODE","HOP_METADATA_KEY","HOP_METADATA_VALUE","RELAY_RENDEZVOUS_NS","isPrivate","addressesPublicFirstCompareFunction","isAPrivate","isBPrivate","isCertified","isIpPrivate","netmask_1","ip_regex_1","is_ip_1","ipaddr_js_1","NETMASK_RANGES","ip_range","Netmask","ipv6_check","ip_addr","ipv4_check","toNormalizedString","Netmask1","atob","chr","chr0","chrA","chra","ip2long","long2ip","maskLong","bitmask","netLong","hostmask","broadcast","lastLong","ipv4Part","ipv4Regexes","fourOctet","threeOctet","twoOctet","longValue","octalRegex","hexRegex","zoneIndex","ipv6Part","ipv6Regexes","native","deprecatedTransitional","transitional","expandIPv6","replacement","replacementCount","colonCount","lastColon","zoneId","matchCIDR","partSize","cidrBits","parseIntAuto","padPart","ipaddr","IPv4","SpecialRanges","unspecified","multicast","linkLocal","loopback","carrierGradeNat","cidrRange","prefixLengthFromSubnetMask","cidr","zerotable","subnetMatch","toIPv4MappedAddress","IPv6","broadcastAddressFromCIDR","parseCIDR","ipInterfaceOctets","subnetMaskOctets","subnetMaskFromPrefixLength","isIPv4","isValidFourPartDecimal","networkAddressFromCIDR","filledOctetCount","uniqueLocal","ipv4Mapped","rfc6145","rfc6052","teredo","isIPv4MappedAddress","toFixedLengthString","suffix","toIPv4Address","toRFC5952String","bestMatchIndex","bestMatchLength","isIPv6","rangeList","defaultName","rangeName","rangeSubnets","pSettle","FAULT_TOLERANCE","_transports","_listenerOptions","listenerOptions","transportForMultiaddr","couldNotListen","supportedAddrs","isFulfilled","NO_FATAL","pReflect","pLimit","pTry","activeCount","pendingCount","clearQueue","arguments_","PeerRecord","peerRecord","ENVELOPE_DOMAIN_PEER_RECORD","ENVELOPE_PAYLOAD_TYPE_PEER_RECORD","multiaddrs1","seqNumber1","DOMAIN","every","AddressInfo","observed","addObservedAddr","LatencyMonitor","maxData","maxSentData","maxReceivedData","maxEventLoopDelay","pollInterval","autoDialInterval","movingAverageInterval","defaultPeerValue","_peerValues","_autoDialTimeout","_checkMetrics","_autoDial","_latencyMonitor","latencyCheckIntervalMs","dataEmitIntervalMs","accumulator","_onLatencyMeasure","connectionList","setPeerValue","received","_checkMaxLimit","storedConn","summary","avgMs","_maybeDisconnectOne","peerValues","disconnectPeer","VisibilityChangeEmitter","asyncTestFn","latencyRandomPercentage","_latecyCheckMultiply","_latecyCheckSubtract","getDeltaMS","startTime","performance","_latencyData","_initLatencyData","_visibilityChangeEmitter","pageInFocus","_startTimers","_emitSummary","_stopTimers","isVisible","_checkLatencyID","_checkLatency","_emitIntervalID","getSummary","minMs","maxMs","totalMs","POSITIVE_INFINITY","lengthMs","randomness","localData","deltaOffset","deltaMS","NEGATIVE_INFINITY","_initializeVisibilityVarNames","_addVisibilityChangeListener","visibilityChange","mozHidden","msHidden","webkitHidden","_hidden","_visibilityChange","_handleVisibilityChange","visible","_triggered","_timerWrapper","_schedule","timeout1","timeout2","CircuitRelay","CircuitPB","handleCanHop","handleHop","handleStop","StreamHandler","transportSymbol","_dialer","_onProtocol","streamHandler","circuit","virtualConnection","CAN_HOP","HOP","STOP","dstPeer","srcPeer","relayAddr","destinationAddr","relayId","destinationId","relayPeer","destinationPeer","disconnectOnFailure","relayConnection","listeningAddrs","relayConn","relayedAddr","validateAddrs","STATUS","HOP_CANT_SPEAK_RELAY","destinationConnection","HOP_NO_CONN_TO_DST","stopRequest","destinationStream","SUCCESS","sourceStream","canHop","writeResponse","HOP_DST_MULTIADDR_INVALID","STOP_DST_MULTIADDR_INVALID","HOP_SRC_MULTIADDR_INVALID","STOP_SRC_MULTIADDR_INVALID","AutoRelay","namespaceToCid","_autoRelay","_advertiseService","_transportManager","_addressSorter","_listenRelays","_onError","_addListenRelay","_removeListenRelay","remoteAddrs","listenAddr","_listenOnAvailableHopRelays","peersToIgnore","knownHopsToDial","metadataMap","supportsHop","_tryToListenOnRelay","DialRequest","maxAddrsToDial","_pendingDials","_pendingDialTargets","pendingTarget","dialTarget","_createCancellableDialTarget","pendingDial","_createPendingDial","cancellablePromise","_createDialTarget","knownAddrs","ra","dialRequest","dialAction","timeoutController","getTokens","releaseToken","resolvedMultiaddrs","_resolveRecord","nm","newM","pAny","tokenHolder","dialAbortControllers","completedDials","Fifo","_waitingConsumers","nextConsumer","pSome","PCancelable","anyCancelable","onCancel","FilterError","elementCount","isSettled","completed","cancelPending","CancelError","isCanceled","userFn","executor","_cancelHandlers","_isPending","_isCanceled","_rejectOnCancel","_promise","_reject","shouldReject","onFulfilled","onRejected","onRejected1","reason1","sanitize","CMS","infoPrefix","privates","NIST","iterationCount","validateKeyName","throwDelayed","DsName","DsInfoName","cms","dsname","keyInfo","oldDsname","newDsname","oldInfoName","newInfoName","name4","password1","name5","name6","oldPass","newPass","oldDek","newDek","keyAsPEM","illegalRe","controlRe","reservedRe","windowsReservedRe","windowsTrailingRe","sanitized","isHighSurrogate","isLowSurrogate","charLength","curByteLength","prevCodePoint","certificateForKey","findAsync","plain","_getPrivateKey","certificate","pkcs7","createEnvelopedData","addRecipient","toAsn1","cmsData","messageFromAsn1","recipients","issuer","shortName","recipient","keyId","findKeyById","missingKeys","_recipientFromAsn1","recipientInfoValidator","RDNAttributesAsArray","serialNumber","serial","encryptedContent","encAlgorithm","parameter","encParameter","encKey","_recipientsToAsn1","distinguishedNameToAsn1","_signerToAsn1","authenticatedAttributesAsn1","signatureAlgorithm","unauthenticatedAttributes","attrsAsn1","_attributeToAsn1","contentType","messageDigest","signingTime","jan_1_1950","jan_1_2050","_fromAsn1","rawCapture","_decryptContent","ciph","messageFromPem","messageToPem","pemObj","contentInfoValidator","envelopedData","createEncryptedData","signedData","createSignedData","fromAsn1","certificates","crls","signers","digestAlgorithmIdentifiers","contentInfo","signerInfos","signedDataValidator","certs","certificateFromAsn1","certificateToAsn1","addSigner","signer","cert","certificateFromPem","authenticatedAttributes","detached","detachedContent","mds","ai","_signersToAsn1","addSignerInfos","addDigestAlgorithmIds","addCertificate","addCertificateRevokationList","crl","encryptedDataValidator","envelopedDataValidator","infos","_recipientsFromAsn1","recipientInfos","findRecipient","sAttr","rAttr","desCBC","keyLen","ciphFn","p7v","pkcs7asn1","encryptedContentInfoValidator","signerValidator","_shortNames","x509CertificateValidator","rsassaPssParameterValidator","certificationRequestInfoValidator","certificationRequestValidator","_getAttribute","rdn","si","valueTagClass","CRIAttributesAsArray","extensionRequest","extensions","certificateExtensionFromAsn1","_readSignatureParameters","fillDefaults","algorithmOid","mgf","hashOid","maskGenOid","maskGenHashOid","_dnToAsn1","attrs","_fillMissingFields","attribute","valueConstructed","certificateExtensionToAsn1","_fillMissingExtensionFields","extension","digitalSignature","nonRepudiation","keyEncipherment","dataEncipherment","keyAgreement","keyCertSign","cRLSign","encipherOnly","decipherOnly","cA","pathLenConstraint","email","objsign","sslCA","emailCA","objCA","altNames","altName","ski","generateSubjectKeyIdentifier","subjectKeyIdentifier","keyIdentifier","authorityCertIssuer","subSeq","fullNameGeneralNames","_signatureParametersToAsn1","_CRIAttributesToAsn1","csr","computeHash","certificateToPem","publicKeyToPem","publicKeyToRSAPublicKeyPem","getPublicKeyFingerprint","certificationRequestFromPem","certificationRequestFromAsn1","certificationRequestToPem","certificationRequestToAsn1","createCertificate","siginfo","notBefore","notAfter","getField","sn","addField","setSubject","uniqueId","setIssuer","setExtensions","exts","getExtension","signatureOid","tbsCertificate","getTBSCertificate","issued","expectedIssuer","actualIssuer","sha1WithRSAEncryption","signatureParameters","pss","isIssuer","iattr","sattr","verifySubjectKeyIdentifier","certVersion","certSerialNumber","certSignatureOid","certSignatureParams","certinfoSignatureOid","certinfoSignatureParams","certSignature","certValidity1UTCTime","certValidity2GeneralizedTime","certValidity3UTCTime","certValidity4GeneralizedTime","imd","certIssuer","certIssuerUniqueId","smd","certSubject","certSubjectUniqueId","certExtensions","certificateExtensionsFromAsn1","subjectPublicKeyInfo","extseq","critical","gn","createCertificationRequest","csrVersion","csrSignatureOid","csrSignatureParams","csrSignature","certificationRequestInfo","certificationRequestInfoSubject","getAttribute","addAttribute","certificationRequestInfoAttributes","setAttributes","getCertificationRequestInfo","cri","_dateToAsn1","tbs","certificateExtensionsToAsn1","dn","createCaStore","caStore","getBySubject","ensureSubjectHasHash","getIssuer","hasCertificate","der1","listAllCertificates","certList","removeCertificate","cert1","certificateError","bad_certificate","unsupported_certificate","certificate_revoked","certificate_expired","certificate_unknown","unknown_ca","verifyCertificateChain","chain","validityCheckDate","selfSigned","verified","se","keyUsage","basicConstraints","bcExt","keyUsageExt","vfd","maskLen","sLen","salt_","pssobj","modBits","emBits","emLen","mHash","m_","checkLen","serverAuth","clientAuth","codeSigning","emailProtection","timeStamping","asyncCompare","findIndex","oldPeerLRU","Stats","initialCounters","directionToEvent","in","_globalStats","_peerStats","_protocolStats","_oldPeers","onPeerDisconnected","stats1","idString","protocolStats","updatePlaceholder","placeholderStats","peerIdString","existingStats","mergedStats","mergeStats","trackStream","protocol2","_sink","LRU","patched","BigNumber","Big","MovingAverage","_stats","_frequencyLastTime","_frequencyAccumulators","_movingAverages","_resetComputeTimeout","counters","inc","_nextTimeout","urgency","_applyOp","_updateFrequency","latestTime","timeDiff","_updateFrequencyFor","timeDiffMS","latestTime1","hz","plus","globalObject","BigNumber1","isNumeric","mathceil","mathfloor","bignumberError","tooManyDigits","LOG_BASE","configObject","convertBase","parseNumeric","dotAfter","dotBefore","isInfinityOrNaN","whitespaceOrPlus","caseChanged","isNum","_isBigNumber","MAX_EXP","MIN_EXP","intCheck","DECIMAL_PLACES","ROUNDING_MODE","DEBUG","TO_EXP_NEG","TO_EXP_POS","toFixedPoint","c0","sd","ni","rd","pows10","POWS_TEN","coeffToString","MAX","CRYPTO","MODULO_MODE","POW_PRECISION","FORMAT","maximum","maxOrMin","minimum","pow2_53","random53bitInt","toBaseOut","baseIn","baseOut","arrL","callerIsToString","klo","SQRT_BASE","khi","xhi","aL","bL","prod","prodL","qc","remL","rem0","xL","yc0","yL","yz","yc","bitFloor","basePrefix","compare1","idiv","exponentiatedBy","isModExp","nIsBig","nIsNeg","nIsOdd","times","xLTy","xe","ye","minus","xcL","xlo","ycL","ylo","yhi","zc","sqrtBase","timespan","previousTime","variance","forecast","Multistream","Connection","mutableProxy","encryptedConn","upgradedConn","cryptoProtocol","setPeer","proxyPeer","setTarget","proxy","protectedConn","protect","_encryptInbound","_multiplexInbound","_createConnection","maConn1","remotePeerId","_encryptOutbound","_multiplexOutbound","maConn2","muxedStream","mss","Listener","_onStream","_timeline","upgraded","errConnectionNotMultiplexed","multiplexer","getStreams","cryptos1","secureInbound","localPeer2","cryptos2","secureOutbound","connection3","muxers1","connection4","muxers2","PROTOCOL_ID","MultistreamSelect","_stream","_shaken","_handshake","multistream","protocolId","shakeStream","writeAll","NewLine","protocolsReader","OPEN","CLOSING","CLOSED","connectionSymbol","localAddr1","newStream1","close1","getStreams1","stat1","validateArgs","_stat","_getStreams","_closing","_toConsumableArray","arr2","defaultTarget","mutableHandler","mutableTarget","setHandler","property","getTarget","getHandler","AddressBook","KeyBook","MetadataBook","ProtoBook","storedPeers","peersData","addressesDeleted","keyDeleted","protocolsDeleted","metadataDeleted","Book","eventProperty","eventTransformer","storedRecord","_toAddresses","_setData","getPeerRecord","newAddr","_ps","peerId4","multiaddrs2","peerId5","passthrough","b58key","_emit","data2","_setValue","recMap","deleteValue","recSet","newSet","PubsubRouter","_subscribeAdapter","_unsubscribeAdapter","NAMESPACE_ADDRESS","NAMESPACE_COMMON","NAMESPACE_KEYS","NAMESPACE_METADATA","NAMESPACE_PROTOCOL","_dirtyPeers","_dirtyMetadata","_addDirtyPeer","_addDirtyPeerKey","_addDirtyPeerMetadata","_processDatastoreEntry","_commitData","peerIdstr","mData","commitPeers","_batchAddressBook","_batchKeyBook","_batchMetadataBook","_batchProtoBook","b32key","encodedData","certifiedRecord","batch1","peerId6","batch2","dirtyMetada","dirtyKey","dirtyValue","peerId7","batch3","keyParts","Address","CertifiedRecord","topologies","_handle","isTopology","PROTOCOL_NAME","PING_LENGTH","PROTOCOL","identifyProtocolStr","identifyPushProtocolStr","libp2p1","protocolStr","_host","identify","pushToPeerStore","listenAddrs","pushes","Identify","observedAddr","cleanObservedAddr","getCleanMultiaddr","_handleIdentify","_handlePush","err4","IDENTIFY","IDENTIFY_PUSH","Messsage","NatAPI","retry","isPrivateIp","pkg","DEFAULT_TTL","highPort","_addressManager","_enabled","_externalIp","autoUpdate","enablePMP","_start","_getClient","publicIp","publicPort","privatePort","fromNodeAddress","onFailedAttempt","f1","argumentNames","networkErrorMsgs","originalError","pRetry","retries","attemptNumber","errorMessage","retriesLeft","decorateErrorWithCounts","mainError","RetryOperation","timeouts","forever","maxRetryTime","minTimeout","maxTimeout","randomize","createTimeout","original1","_originalTimeouts","_timeouts","_maxRetryTime","_fn","_attempts","_operationTimeout","_operationTimeoutCb","_operationStart","_cachedTimeouts","timeoutOps","counts","mainErrorCount","isLoopbackAddr","ipfsBitswap","blockStorage","readAddrs","statsEnabled","BlockStorage","WEBSOCKET_STAR_PROTO_CODE","maId","Bitswap","notifications","statsComputeThrottleTimeout","statsComputeThrottleMaxQueueSize","statsKeys","hashLoader","DecisionEngine","wm","WantManager","Notifications","incoming","messageReceived","cidStr","wasWanted","cancelWants","_handleReceivedBlock","_updateReceiveCounters","_receiveError","peerDisconnected","enableStats","disableStats","ledgerForPeer","fetchFromNetwork","wantBlocks","wantBlock","promptedNetwork","findAndConnect","loadOrFetchFromNetwork","cidsArray","unwantBlocks","unwantBlock","cids2","_options1","_sendHaveBlockNotifications","data3","hasBlock","receivedBlocks","msgQueue","_addEntries","BitswapMessage","Entry","kMaxPriority","WantType","removeForce","addEntries","_startPeerHandler","mq","refcnt","MsgQueue","fullwantlist","addEntry","addMessage","_stopPeerHandler","cids3","connectedPeers","vd","varintEncoder","vd__default","blockPresences","pendingBytes","wantType","sendDontHave","entry$1","Have","BitswapMessageEntry","addBlock","addHave","BlockPresenceType","addDontHave","DontHave","setPendingBytes","serializeToBitswap100","serializeToBitswap110","cidStr1","bpType","BlockPresence","isMapEqual","blockPresence","blockPresenceSize","varint__namespace","includesWith","pred","groupBy","valueA","valueB","pullAllWith","sortBy","uniqWith","WantlistEntry","WantListEntry","hasRefs","sortedEntries","_refCounter","Message1","hasBlockTimeout","maxProvidersPerRequest","provideTimeout","providerRequestTimeout","wantlistSendDebounceMs","debounce__default","selfPeerId","otherPeerId","_entries","sendEntries","_sendEntries","connectTo","callFirst","debouncedFn","debounceWrapper","callNow","lp__default","MulticodecTopology__default","BITSWAP100","BITSWAP110","BITSWAP120","_bitswap","_protocols","b100Only","_onPeerDisconnect","_onConnection","_hashLoader","_receiveMessage","maxProviders","connectAttempts","stringId","writeMessage","_updateSentStats","ledger","reqQueue","taskMerger","_opts","_processOpts","ledgerMap","_requestQueue","RequestQueue","TaskMerger","maxSizeReplaceHasWithBlock","targetMessageSize","_scheduleProcessTasks","_processTasks","pendingSize","popTasks","blockCids","blockTasks","haveBlock","isWantBlock","_getBlocks","taskData","blk","tasksDone","messageSent","partner","debtRatio","accounting","bytesSent","recv","bytesRecv","exchanged","exchangeCount","wantlistContains","_sendAsBlock","entrySize","pushTasks","_findOrCreate","_updateBlockAccounting","cancels","wants","cancelWant","_cancelWants","_addWants","_getBlockSizes","blocksMap","ledger1","receivedBytes","sentBytes","numBytesSentTo","numBytesReceivedFrom","peerId8","peerId9","ledger$1","Ledger","sentToPeer","lastExchange","sortedMap","DefaultTaskMerger","hasNewInfo","PeerTasks","taskMerger1","_taskMerger","_activeTotalSize","_pending","PendingTasks","_active","tasks2","_pushTask","_taskHasMoreInfoThanActiveTasks","existingTask","updatePriority","task1","tasksWithTopic","activeTask","targetMinBytes1","pendingTasks","totalSize","taskDone","task2","isIdle","_tasks","SortedMap","_compare","task3","created","_byPeer","peerTasks","targetMinBytes","tasks1","_cmp","_defaultSort","newIdx","_find","pivot","_kCmp","newTask","existingData","unwantEvent","blockEvent","blockEvt","unwantEvt","onUnwant","onBlock","_initialCounters","_global","_peers","peerStat","MovingAverage__default","_disabled","blockstoreCore","missingBlocks","getFromBitswap","getFromChild","MemoryBlockstore","hangUp","basePacket","storedPeer","packetCount","totalTime","average","get1","closerPeerId","notEnabled","isEnabled","installedModules","__webpack_require__","moduleId","URL_REGEX","FIRST_SEGMENT_REGEX","SLASH_DOT_REGEX","SLASH_DOT_DOT_REGEX","URLToolkit","buildAbsoluteURL","baseURL","relativeURL","alwaysNormalize","basePartsForNormalise","parseURL","buildURLFromParts","relativeParts","baseParts","netLoc","pathParts","builtParts","baseURLPath","newPath","webpackBootstrapFunc","oe","ENTRY_MODULE","moduleNameReqExp","dependencyRegExp","quoteRegExp","getModuleDependencies","queueName","retval","fnString","wrapperSignature","webpackRequireName","__webpack_require__1","hasValuesInQueues","queues","hasValues","module1","main","requiredModules","modulesQueue","seenModules","moduleToCheck","newModules","newModulesKeys","getRequiredModules","entryModule","bare","workerUrl","webkitURL","mozURL","msURL","objectURL","AESCrypto","aesIV","FastAESKey","AESDecryptor","subMix","invSubMix","sBox","invSBox","initTable","uint8ArrayToUint32Array_","subMix0","subMix1","subMix2","subMix3","invSubMix0","invSubMix1","invSubMix2","invSubMix3","sameKey","ksRow","invKsRow","ksRows","keySchedule","invKeySchedule","networkToHostOrderSwap","inputArrayBuffer","removePKCS7Padding","inputWords0","inputWords1","inputWords2","inputWords3","outputBytes","paddingBytes","nRounds","invSBOX","initVector","initVector0","initVector1","initVector2","initVector3","inputInt32","outputInt32","swapWord","getSelfScope","Decrypter","_ref$removePKCS7Paddi","logEnabled","webkitSubtle","disableWebCrypto","enableSoftwareAES","decryptor","fastAesKey","aesKey","onWebCryptoError","trigger","Event","ERROR","ErrorTypes","MEDIA_ERROR","details","ErrorDetails","FRAG_DECRYPT_ERROR","fatal","isHeaderPattern","getHeaderLength","getFullFrameLength","isHeader","headerLength","frameLength","newOffset","initTrackConfig","audioCodec","samplerate","adtsObjectType","adtsSampleingIndex","adtsExtensionSampleingIndex","adtsChanelConfig","manifestCodec","adtsSampleingRates","channelCount","FRAG_PARSING_ERROR","getAudioConfig","getFrameDuration","appendFrame","pts","frameIndex","frameDuration","stamp","parseFrameHeader","aacSample","dts","AACDemuxer","remuxer","resetInitSegment","initSegment","videoCodec","_audioTrack","container","sequenceNumber","isAAC","inputTimeScale","resetTimeStamp","ID3","getID3Data","ADTS","timeOffset","contiguous","accurateTimeOffset","id3Data","getTimeStamp","id3Samples","frame","remux","MpegAudio","BitratesMap","SamplingRateMap","SamplesCoefficients","BytesInSlot","parseHeader","samplesPerFrame","sampleRate","headerB","headerC","headerE","headerF","headerG","columnInBitrates","bitRate","columnInSampleRates","sampleCoefficient","bytesInSlot","ExpGolomb","bytesAvailable","bitsAvailable","loadWord","workingBytes","availableBytes","skipBits","skipBytes","readBits","valu","skipLZ","leadingZeroCount","skipUEG","skipEG","readUEG","clz","readEG","readBoolean","readUByte","readUShort","readUInt","skipScalingList","lastScale","nextScale","readSPS","profileIdc","numRefFramesInPicOrderCntCycle","picWidthInMbsMinus1","picHeightInMapUnitsMinus1","frameMbsOnlyFlag","scalingListCount","frameCropLeftOffset","frameCropRightOffset","frameCropTopOffset","frameCropBottomOffset","chromaFormatIdc","picOrderCntType","pixelRatio","readSliceType","SampleAesDecrypter","decryptdata","discardEPB","decrypter","decryptBuffer","decryptAacSample","sampleIndex","curUnit","encryptedBuffer","localthis","decryptedData","decryptAacSamples","getAvcEncryptedData","decodedData","encryptedDataLen","outputPos","inputPos","getAvcDecryptedUnit","decryptAvcSample","unitIndex","decryptAvcSamples","curUnits","RemuxerTrackIdConfig","audio","TSDemuxer","typeSupported","sampleAes","pmtUnknownTypes","setDecryptData","syncOffset","_syncOffset","scanwindow","createTrack","dropped","pmtParsed","_pmtId","_avcTrack","_id3Track","_txtTrack","aacOverFlow","aacLastPTS","avcSample","_duration","stt","pes","unknownPIDs","avcTrack","audioTrack","id3Track","avcId","audioId","id3Id","pmtId","avcData","pesData","audioData","parsePAT","_parsePAT","parsePMT","_parsePMT","parsePES","_parsePES","parseAVCPES","_parseAVCPES","parseAACPES","_parseAACPES","parseMPEGPES","_parseMPEGPES","parseID3PES","_parseID3PES","parsedPIDs","mpeg","mp3","avc","decryptAndRemux","videoTrack","textTrack","decryptAndRemuxAvc","_initPTS","_initDTS","_trackUnknownPmt","logLevel","mpegSupported","isSampleAes","tableEnd","pesFlags","pesLen","pesHdrLen","pesPts","pesDts","payloadStartOffset","dataLen","pushAccesUnit","nbSamples","lastSample","forceKeyFrameOnDiscontinuity","sps","expGolombDecoder","_parseAVCNALu","spsfound","createAVCSample","audFound","sliceType","payloadSize","endOfCaptions","totalCCs","_insertSampleInOrder","uuidStrArray","userDataPayloadBytes","uuid","userDataBytes","userData","utf8ArrayToStr","codecarray","codecstring","pps","_getLastNalUnit","lastUnit","lastUnitType","naluState","lastState","lastUnitStart","newLength","EPBPositions","sourceIndex","newPTS","MP3Demuxer","AAC","getSilentFrame","UINT32_MAX","MP4","avc1","avcC","btrt","dinf","dref","esds","ftyp","hdlr","mdat","mdhd","mdia","mfhd","minf","moof","moov","mp4a","mvex","mvhd","pasp","sdtp","stbl","stco","stsc","stsd","stsz","stts","tfdt","tfhd","traf","trak","trun","trex","tkhd","vmhd","smhd","videoHdlr","audioHdlr","HDLR_TYPES","STTS","STSC","STCO","STSZ","VMHD","SMHD","STSD","majorBrand","avc1Brand","minorVersion","FTYP","box","DINF","timescale","upperWordDuration","lowerWordDuration","baseMediaDecodeTime","tracks","boxes","dependsOn","isDependedOn","hasRedundancy","avcc","hSpacing","vSpacing","configlen","sampleDependencyTable","upperWordBaseMediaDecodeTime","lowerWordBaseMediaDecodeTime","cts","arraylen","isLeading","paddingValue","isNonSync","degradPrio","movie","toTimescaleFromBase","destScale","srcBase","toMsFromMpegTsClock","toMpegTsClockFromTimescale","srcScale","MAX_SILENT_FRAME_DURATION_90KHZ","PTS_DTS_SHIFT_TOLERANCE_90KHZ","chromeVersion","PTSNormalize","reference","MP4Remuxer","vendor","ISGenerated","defaultTimeStamp","getVideoStartPts","videoSamples","rolloverDetected","startPTS","minPTS","generateIS","nbAudioSamples","nbVideoSamples","audioTimeOffset","videoTimeOffset","audiovideoTimestampDelta","audioTrackLength","remuxAudio","endPTS","remuxVideo","videoData","remuxEmptyAudio","remuxID3","remuxText","FRAG_PARSED","initPTS","initDTS","audioSamples","computePTSDTS","INIT_PTS_FOUND","FRAG_PARSING_INIT_SEGMENT","mp4SampleDuration","firstDTS","lastDTS","timeScale","inputSamples","outputSamples","maxPTS","ptsDtsShift","sortSamples","nextAvcDts","deltadts","deltapts","averageSampleDuration","lastDts","foundHole","firstPTS","nbNalu","naluLen","nbUnits","sampleLen","mdatSize","MUX_ERROR","REMUX_ALLOC_ERROR","compositionTimeOffset","avcSampleUnits","mp4SampleLength","unitData","unitDataLen","lastFrameDuration","stretchShortVideoTrack","maxBufferHole","gapTolerance","deltaToFrameEnd","nextAudioPts","startDTS","endDTS","hasAudio","hasVideo","FRAG_PARSING_DATA","mp4Sample","fillFrame","lastPTS","mp4timeScale","scaleFactor","inputSampleDuration","rawMPEG","maxAudioFramesDrift","nextPts","newStamp","audioSample","numMissingFrames","unitLen","lastSampleDuration","silentFrame","FRAG_PARSING_METADATA","FRAG_PARSING_USERDATA","PassThroughRemuxer","rawData","streamType","DemuxerInline","demuxer","discontinuity","trackSwitch","defaultInitPTS","endTime","FRAG_DECRYPTED","tstart","tdecrypt","pushDecrypted","mux","muxConfig","demux","MP4Demuxer","__webpack_exports__","_demux_demuxer_inline__WEBPACK_IMPORTED_MODULE_0__","_events__WEBPACK_IMPORTED_MODULE_1__","_utils_logger__WEBPACK_IMPORTED_MODULE_2__","eventemitter3__WEBPACK_IMPORTED_MODULE_3__","DemuxerWorker","_len2","_key2","forwardMessage","cmd","enableLogs","transferable","_utils_get_self_scope__WEBPACK_IMPORTED_MODULE_0__","isFooter","_readSize","frames","getID3Frames","isTimeStampFrame","_readTimeStamp","_getFrameData","frameData","_decodeFrame","_decodePrivFrame","_decodeURLFrame","_decodeTextFrame","timeStampFrame","pts33Bit","owner","_utf8ArrayToStr","privateData","exitOnNull","getTextDecoder","char2","char3","_utils_logger__WEBPACK_IMPORTED_MODULE_0__","initData","parseInitSegment","audiovideo","findBox","bin2str","subresults","endbox","parseSegmentIndex","moovEndOffset","sidx","startByte","referencesCount","referenceIndex","referenceInfo","referenceSize","subsegmentDuration","earliestPresentationTime","trackId","soun","vide","codecBox","codecType","getStartDTS","trafs","baseTimes","scale","offsetStartDTS","ErrorTypes1","ErrorDetails1","HlsEvents","MEDIA_ATTACHING","MEDIA_ATTACHED","MEDIA_DETACHING","MEDIA_DETACHED","BUFFER_RESET","BUFFER_CODECS","BUFFER_CREATED","BUFFER_APPENDING","BUFFER_APPENDED","BUFFER_EOS","BUFFER_FLUSHING","BUFFER_FLUSHED","MANIFEST_LOADING","MANIFEST_LOADED","LEVEL_SWITCHING","LEVEL_SWITCHED","LEVEL_LOADING","LEVEL_LOADED","LEVEL_UPDATED","LEVEL_PTS_UPDATED","LEVELS_UPDATED","AUDIO_TRACKS_UPDATED","AUDIO_TRACK_SWITCHING","AUDIO_TRACK_SWITCHED","AUDIO_TRACK_LOADING","AUDIO_TRACK_LOADED","SUBTITLE_TRACKS_UPDATED","SUBTITLE_TRACK_SWITCH","SUBTITLE_TRACK_LOADING","SUBTITLE_TRACK_LOADED","SUBTITLE_FRAG_PROCESSED","CUES_PARSED","NON_NATIVE_TEXT_TRACKS_FOUND","FRAG_LOADING","FRAG_LOAD_PROGRESS","FRAG_LOAD_EMERGENCY_ABORTED","FRAG_LOADED","FRAG_BUFFERED","FRAG_CHANGED","FPS_DROP","FPS_DROP_LEVEL_CAPPING","DESTROYING","KEY_LOADING","KEY_LOADED","STREAM_STATE_TRANSITION","LIVE_BACK_BUFFER_REACHED","PlaylistContextType","PlaylistLevelType","FORBIDDEN_EVENT_NAMES","hlsEventGeneric","hlsHandlerDestroying","hlsHandlerDestroyed","EventHandler","handledEvents","useGenericHandler","onEvent","registerListeners","onHandlerDestroying","unregisterListeners","onHandlerDestroyed","isEventHandler","onEventGeneric","funcName","OTHER_ERROR","INTERNAL_EXCEPTION","LevelKey","ElementaryStreamTypes","baseURI","relativeURI","_uri","baseuri","reluri","Fragment","_url","_byteRange","_decryptdata","_elementaryStreams","AUDIO","VIDEO","deltaPTS","rawProgramDateTime","programDateTime","tagList","cc","relurl","baseurl","urlId","levelkey","setByteRange","previousFrag","byteRange","byteRangeEndOffset","addElementaryStream","hasElementaryStream","createInitializationVector","segmentNumber","uint8View","setDecryptDataFromLevelKey","baseUrl","endCC","endSN","fragments","live","needSidxRanges","startCC","startSN","startTimeOffset","targetduration","totalduration","DECIMAL_RESOLUTION_REGEX","ATTR_LIST_REGEX","AttrList","parseAttrList","decimalInteger","attrName","hexadecimalInteger","hexadecimalIntegerAsNumber","decimalFloatingPoint","enumeratedString","decimalResolution","sampleEntryCodesISO","a3ds","alac","alaw","dra1","dtsc","dtse","dtsh","enca","g719","g726","m4ae","mha1","mha2","mhm1","mhm2","mlpa","Opus","samr","sawb","sawp","sevc","sqcp","ssmv","twos","ulaw","avc2","avc3","avc4","avcp","drac","dvav","dvhe","encv","hev1","hvc1","mjp2","mp4v","mvc1","mvc2","mvc3","mvc4","resv","rv60","s263","svc1","svc2","vp08","vp09","isCodecSupportedInMp4","MediaSource","isTypeSupported","MASTER_PLAYLIST_REGEX","MASTER_PLAYLIST_MEDIA_REGEX","LEVEL_PLAYLIST_REGEX_FAST","LEVEL_PLAYLIST_REGEX_SLOW","MP4_REGEX_SUFFIX","M3U8Parser","findGroup","mediaGroupId","convertAVC1ToAVCOTI","avcdata","parseMasterPlaylist","levels","sessionData","hasSessionData","setCodecs","filtered","typeCodes","isCodecType","preferred","unknownCodecs","bitrate","NAME","CODECS","sessionAttrs","parseMasterPlaylistMedia","audioGroups","medias","media","groupId","instreamId","LANGUAGE","DEFAULT","autoselect","AUTOSELECT","forced","FORCED","lang","URI","groupCodec","parseLevelPlaylist","levelUrlId","currentSN","discontinuityCounter","prevFrag","firstPdtIndex","assignProgramDateTime","keyAttrs","decryptmethod","decrypturi","decryptiv","KEYFORMAT","mapAttrs","BYTERANGE","averagetargetduration","startIndex","fragPrev","backfillProgramDateTimes","endProgramDateTime","PlaylistLoader","_EventHandler","loaders","canHaveQualityLevels","AUDIO_TRACK","SUBTITLE_TRACK","mapContextToLevelType","SUBTITLE","MAIN","getResponseUrl","createInternalLoader","PLoader","pLoader","Loader","getInternalLoader","resetInternalLoader","contextType","destroyInternalLoaders","onManifestLoading","MANIFEST","onLevelLoading","LEVEL","onAudioTrackLoading","onSubtitleTrackLoading","maxRetry","retryDelay","maxRetryDelay","loaderContext","manifestLoadingMaxRetry","manifestLoadingTimeOut","manifestLoadingRetryDelay","manifestLoadingMaxRetryTimeout","levelLoadingTimeOut","levelLoadingMaxRetry","levelLoadingRetryDelay","levelLoadingMaxRetryTimeout","loaderConfig","loaderCallbacks","loadsuccess","loaderror","loadtimeout","networkDetails","isSidxRequest","_handleSidxRequest","_handlePlaylistLoaded","tload","_handleTrackOrLevelPlaylist","_handleMasterPlaylist","_handleManifestParsingError","_handleNetworkError","_M3U8Parser$parseMast","audioTracks","subtitles","captions","embeddedAudioFound","levelId","levelType","levelDetails","singleLevel","tparsed","sidxUrl","rangeStart","rangeEnd","NETWORK_ERROR","LEVEL_EMPTY_ERROR","sidxInfo","sidxReferences","segmentRef","segRefInfo","MANIFEST_PARSING_ERROR","MANIFEST_LOAD_TIMEOUT","MANIFEST_LOAD_ERROR","LEVEL_LOAD_TIMEOUT","LEVEL_LOAD_ERROR","AUDIO_TRACK_LOAD_TIMEOUT","AUDIO_TRACK_LOAD_ERROR","errorData","FragmentLoader","loaderName","onFragLoading","FragmentILoader","fLoader","DefaultILoader","progressData","byteRangeStartOffset","fragLoadingTimeOut","fragLoadingMaxRetryTimeout","loadprogress","FRAG_LOAD_ERROR","FRAG_LOAD_TIMEOUT","KeyLoader","decryptkey","decrypturl","onKeyLoading","fragLoadingRetryDelay","KEY_LOAD_ERROR","KEY_LOAD_TIMEOUT","FragmentState","FragmentTracker","bufferPadding","timeRanges","_proto","getBufferedFrag","bufferedFrags","fragmentEntity","buffered","bufferedFragKey","detectEvictedFragments","elementaryStream","timeRange","esData","fragmentTimes","isTimeBuffered","removeFragment","detectPartialFragments","_this3","fragKey","getFragmentKey","getBufferedTimes","fragmentPartial","partial","getPartialFragment","timePadding","_this4","bestFragment","bestOverlap","isPartial","getState","onFragLoaded","bitrateTest","onBufferAppended","_this5","onFragBuffered","hasFragment","removeAllFragments","BinarySearch","comparisonFn","minIndex","maxIndex","currentElement","comparisonResult","BufferHelper","isBuffered","bufferInfo","maxHoleDuration","vbuffered","bufferedInfo","nextStart","buffered2","buf2len","buf2end","bufferStartNext","bufferLen","bufferStart","bufferEnd","getMediaSource","WebKitMediaSource","Observer","_EventEmitter","Demuxer","mp4","enableWorker","onwmsg","onWorkerMessage","filename","lineno","lastFrag","nextSN","addGroupId","audioGroupIds","textGroupIds","updatePTS","fromIdx","toIdx","fragFrom","fragTo","fragToPTS","minEndPTS","updateFragPTSDTS","maxStartPTS","drift","fragIdx","PTSKnown","mergeDetails","oldDetails","newDetails","PTSFrag","ccOffset","mapFragmentIntersection","oldFrag","newFrag","backtracked","newFragments","oldPlaylist","newPlaylist","oldFragments","adjustSliding","intersectionFn","computeReloadInterval","currentPlaylist","lastRequestTime","reloadInterval","minReloadInterval","TimeRanges","adjustPts","sliding","alignStream","lastLevel","shouldAlign","shouldAlignOnDiscontinuities","referenceFrag","prevDetails","curDetails","prevFrags","curFrags","prevStartFrag","firstFrag","currentFrag","findFirstFragWithCC","findDiscontinuousReferenceFrag","alignDiscontinuities","lastDetails","hasProgramDateTime","lastPDT","alignPDT","findFragmentByPDT","PDTValue","maxFragLookUpTolerance","seg","pdtWithinToleranceTest","findFragmentByPTS","fragPrevious","fragNext","fragmentWithinToleranceTest","foundFragment","candidateLookupTolerance","pdtBufferEnd","GapController","fragmentTracker","nudgeRetry","stallReported","stalled","moved","seeking","lastCurrentTime","seeked","beginSeek","playbackRate","hasEnoughBuffer","noBufferGap","startJump","_trySkipBufferHole","tnow","stalledDuration","_reportStall","bufferedWithHoles","_tryFixBufferStall","stalledDurationMs","highBufferWatchdogPeriod","_tryNudgeBuffer","BUFFER_STALLED_ERROR","lastEndTime","targetTime","BUFFER_SEEK_OVER_HOLE","nudgeMaxRetry","nudgeOffset","BUFFER_NUDGE_ON_STALL","TaskLoop","_boundTick","_tickTimer","_tickInterval","_tickCallCount","tick","_assertThisInitialized","clearNextTick","hasInterval","hasNextTick","millis","doTick","BaseStreamController","startLoad","stopLoad","fragCurrent","_streamEnded","fragState","onMediaSeeking","mediaBuffer","tolerance","fragStartOffset","fragEndOffset","loadedmetadata","nextLoadPosition","startPosition","onMediaEnded","_TaskLoop","computeLivePosition","targetLatency","liveSyncDuration","liveSyncDurationCount","chromeOrFirefox","StreamController","_BaseStreamController","audioCodecSwap","gapController","altAudio","audioOnly","fragLoadError","startFragRequested","startLevel","testBandwidth","nextAutoLevel","nextLoadLevel","forceStartLoad","_doTickIdle","retryDate","_checkBuffer","_checkFragmentChanged","levelLastLoaded","startFragPrefetch","levelInfo","maxBufLen","levelBitrate","maxBufferSize","maxBufferLength","maxMaxBufferLength","_fetchPayloadOrEos","fragLen","initialLiveManifestSize","_ensureFragmentAtLivePoint","_findFragment","_loadKey","_loadFragment","maxLatency","liveMaxLatencyDuration","liveMaxLatencyDurationCount","liveSyncPosition","targetSN","fragPreviousLoad","fragmentIndexRange","fragNextLoad","curSNIdx","sameLevel","prevSnFrag","nextSnFrag","autoLevel","autoLevelEnabled","_reduceMaxBufferLength","followingBufferedFrag","fragPlayingCurrent","fragPlaying","fragPlayingLevel","immediateLevelSwitch","immediateSwitch","previouslyPaused","flushMainBuffer","immediateLevelSwitchEnd","nextLevelSwitch","fetchdelay","nextLevelId","nextLevel","fragLastKbps","bufferedFrag","nextBufferedFrag","startPts","flushScope","onMediaAttached","onvseeking","onvseeked","onMediaSeeked","onvended","autoStartLoad","onMediaDetaching","onManifestParsed","aac","heaac","audioCodecSwitch","onLevelLoaded","newLevelId","curLevel","LevelHelper","onKeyLoaded","fragLoaded","currentLevel","tbuffered","pendingBuffering","appended","initSegmentData","_getAudioCodec","onFragParsingInitSegment","fragNew","trackName","levelCodec","onFragParsingData","onFragParsed","_checkAppendedParsed","onAudioTrackSwitching","fromAltAudio","onAudioTrackSwitched","videoBuffer","onBufferCreated","mediaTrack","alternate","tfirst","mediaBuffered","fragLoadingMaxRetry","levelRetry","BUFFER_FULL_ERROR","minLength","_seekToStartPos","onFragLoadEmergencyAborted","onBufferFlushed","elementaryStreamType","onLevelsUpdated","swapAudioCodec","defaultAudioCodec","nextState","previousState","_liveSyncPosition","LevelController","canload","currentLevelIndex","manualLevelIndex","clearTimer","_levels","levelRetryCount","loadError","loadLevel","onManifestLoaded","bitrateStart","levelSet","levelFromSet","videoCodecFound","audioCodecFound","fragmentError","SUBTITLES","_ref2","_firstLevel","firstLevel","MANIFEST_INCOMPATIBLE_CODECS_ERROR","setLevelInternal","newLevel","levelProperties","LEVEL_SWITCH_ERROR","levelIndex","levelError","recoverLevel","errorEvent","redundantLevels","errorDetails","_ref3","trequest","audioGroupId","levelObject","removeLevel","_startLevel","configStartLevel","sendAddTrackEvent","videoEl","createEvent","initEvent","clearCurrentCues","cues","removeCue","ID3TrackController","getID3Track","textTracks","addTextTrack","onFragParsingMetadata","Cue","WebKitDataCue","VTTCue","TextTrackCue","cue","addCue","onLiveBackBufferReached","foundCue","getClosestCue","EWMA","halfLife","alpha_","estimate_","totalWeight_","weight","adjAlpha","getTotalWeight","getEstimate","zeroFactor","EwmaBandWidthEstimator","slow","fast","defaultEstimate","defaultEstimate_","minWeight_","minDelayMs_","slow_","fast_","durationMs","numBytes","durationS","bandwidthInBps","canEstimate","AbrController","lastLoadedFragLevel","_nextAutoLevel","_bwEstimator","onCheck","_abandonRulesCheck","abr_controller_assertThisInitialized","ewmaFast","ewmaSlow","abrEwmaFastLive","abrEwmaSlowLive","abrEwmaFastVoD","abrEwmaSlowVoD","abrEwmaDefaultEstimate","requestDelay","loadRate","realBitrate","expectedLen","fragLoadedDelay","bufferStarvationDelay","fragLevelNextLoadedDelay","minAutoLevel","levelNextBitrate","abrMaxWithRealBitrate","loadedBytes","loadedDuration","fragLoadingProcessingMs","bwEstimate","bitrateTestDelay","_findBestLevel","currentFragDuration","currentBw","maxAutoLevel","maxFetchDuration","bwFactor","bwUpFactor","avgDuration","adjustedbw","fetchDuration","forcedAutoLevel","bwEstimator","nextABRAutoLevel","_nextABRAutoLevel","avgbw","bestLevel","abrBandWidthFactor","abrBandWidthUpFactor","maxStarvationDelay","maxLoadingDelay","BufferController","_msDuration","_levelDuration","_levelTargetDuration","_live","_objectUrl","_needsFlush","_needsEos","audioTimestampOffset","bufferCodecEventsExpected","_bufferCodecEventsTotal","mediaSource","appending","appendError","flushBufferCounter","pendingTracks","sourceBuffer","flushRange","_onMediaSourceOpen","checkPendingTracks","_onMediaSourceClose","_onMediaSourceEnded","_onSBUpdateEnd","audioBuffer","timestampOffset","doFlush","checkEos","sbSet","sb","doAppending","updateMediaElementDuration","flushLiveBackBuffer","_onSBUpdateError","BUFFER_APPENDING_ERROR","onLevelPtsUpdated","updating","codecEvents","onMediaAttaching","endOfStream","removeAttribute","pendingTracksCount","createSourceBuffers","onBufferReset","removeSourceBuffer","onBufferCodecs","mimeType","addSourceBuffer","BUFFER_ADD_CODEC_ERROR","onBufferAppending","onBufferEos","onBufferFlushing","liveBackBufferLength","bufferTypes","targetBackBufferPosition","bufferType","removeBufferRange","onLevelUpdated","liveDurationInfinity","flushBuffer","appendBuffer","BUFFER_APPEND_ERROR","appendErrorMaxRetry","sbType","bufStart","bufEnd","removeStart","removeEnd","CapLevelController","autoLevelCapping","restrictedLevels","clientRect","capLevelToPlayerSize","stopCapping","onFpsDropLevelCapping","isLevelAllowed","droppedLevel","HTMLVideoElement","startCapping","detectPlayerSize","levelsLength","getMaxLevel","streamController","capLevelIndex","validLevels","getMaxLevelByMediaSize","mediaWidth","mediaHeight","getDimensions","boundsRect","getBoundingClientRect","bottom","maxLevelIndex","devicePixelRatio","contentScaleFactor","FPSController","isVideoPlaybackQualityAvailable","capLevelOnFPSDrop","getVideoPlaybackQuality","checkFPSInterval","fpsDroppedMonitoringPeriod","checkFPS","decodedFrames","droppedFrames","lastTime","currentPeriod","currentDropped","lastDroppedFrames","currentDecoded","lastDecodedFrames","droppedFPS","totalDroppedFrames","fpsDroppedMonitoringThreshold","videoPlaybackQuality","totalVideoFrames","droppedVideoFrames","webkitDecodedFrameCount","webkitDroppedFrameCount","XhrLoader","xhrSetup","retryTimeout","loadInternal","readystatechange","currentTarget","lengthComputable","AudioTrackController","_trackId","_selectDefaultTrack","trackIdBlacklist","_selectAudioGroup","onAudioTrackLoaded","updatePeriodMs","_handleLoadError","_setAudioTrack","newId","_loadTrackDetailsIfNeeded","_updateTrack","_selectInitialAudioTrack","currentAudioTrack","defaultTracks","trackFound","traverseTracks","_needsTrackLoading","previousId","_this$tracks$previous","language","AudioStreamController","waitingFragment","videoTrackCC","waitingVideoCC","onInitPtsFound","demuxerId","trackDetails","mainBufferInfo","maxConfigBuffer","audioSwitch","CC","findFragWithCC","loadIdx","fragLoadIdx","nextBuffered","foundFrag","isSeeking","waitingFrag","waitingFragCC","clearWaitingFragment","onAudioTracksUpdated","appendObj","pendingData","appendOnBufferFlush","vttcue","directionSetting","lr","rl","alignSetting","middle","findAlignSetting","cobj","baseObj","hasBeenReset","_pauseOnExit","_endTime","_text","_region","_vertical","_snapToLines","_line","_lineAlign","_position","_positionAlign","_size","_align","setting","findDirectionSetting","displayState","getCueAsHTML","WebVTT","convertCueToDOMTree","VTTParser","regionList","Settings","parseOptions","keyValueDelim","groupDelim","dflt","defaultKey","alt","center","parseCue","oInput","consumeTimeStamp","computeSeconds","parseTimeStamp","skipWhitespace","region","vals0","vertical","lineAlign","snapToLines","consumeCueSettings","fixLineBreaks","collectNextLine","alreadyCollectedLine","hasSubstring","oncue","onflush","newCue","captionScreen","indenting","rows","uchar","cueStartTime","VerboseLevel","specialCea608CharsCodes","getCharForByte","NR_ROWS","NR_COLS","rowsLowCh1","rowsHighCh1","rowsLowCh2","rowsHighCh2","backgroundColors","CaptionsLogger","verboseLevel","severity","numArrayToHexArray","numArray","hexArray","PenState","foreground","italics","flash","setStyles","attribs","isDefault","newPenState","StyledUnicodeChar","penState","setChar","setPenState","newChar","Row","currPenState","_proto4","setCursor","absPos","moveCursor","relPos","newPos","backSpace","insertChar","char","clearFromPos","startPos","clearToEndOfRow","getTextString","setPenStyles","CaptionScreen","currRow","nrRollUpRows","lastOutputScreen","_proto5","setPen","INFO","setPAC","pacData","newRow","topRowIndex","prevLineTime","prevPos","setBkgData","bkgData","setRollUpRows","nrRows","rollUp","TEXT","getDisplayText","topRow","asOneRow","displayText","rowNr","rowText","getTextAndFormat","Cea608Channel","channelNumber","outputFilter","chNr","displayedMemory","nonDisplayedMemory","currRollUpRow","writeScreen","newHandler","setMode","newMode","insertChars","screen","outputDataUpdate","ccRCL","ccBS","ccAOF","ccAON","ccDER","ccRU","ccFON","ccRDC","ccTR","ccRTD","ccEDM","ccCR","ccENM","ccEOC","ccTO","nrCols","ccMIDROW","colorIndex","dispatch","dispatchCue","cueSplitAtTime","setLastCmd","cmdHistory","hasCmdRepeated","Cea608Parser","field","out1","out2","channels","currentChannel","addData","byteList","cmdFound","charsFound","DATA","parseCmd","parseMidrow","parsePAC","parseBackgroundAttributes","parseChars","currChNr","WARNING","interpretPAC","pacIndex","channelNr","charCodes","charCode1","oneCode","hexCodes","OutputFilter","timelineController","cueRanges","addCues","createCaptionsTrack","inputString","searchString","WebVTTParser","vttByteArray","syncPTS","vttCCs","callBack","errorCallBack","parsingError","vttLines","cueTime","mpegTs","localTime","presentationTime","inHeader","timestampMap","currCC","cueOffset","prevCC","presentationOffset","calculateOffset","onparsingerror","timeString","mins","hours","cueString2millis","canReuseVttTextTrack","inUseTrack","manifestTrack","textTrack1","textTrack2","TimelineController","Cues","unparsedVttFrags","captionsTracks","nonNativeCaptionsTracks","captionsProperties","cea608Parser1","cea608Parser2","lastSn","cueHandler","captionsTextTrack1Label","languageCode","captionsTextTrack1LanguageCode","captionsTextTrack2Label","captionsTextTrack2LanguageCode","textTrack3","captionsTextTrack3Label","captionsTextTrack3LanguageCode","textTrack4","captionsTextTrack4Label","captionsTextTrack4LanguageCode","enableCEA708Captions","channel1","timeline_controller_assertThisInitialized","channel2","channel3","channel4","cueRange","renderTextTracksNatively","getExistingTrack","createNativeTrack","createNonNativeTrack","_captionsProperties$t","existingTrack","createTextTrack","trackProperties","closedCaptions","_cleanTracks","enableWebVTT","sameTracks","inUseTracks","subtitleDisplay","tracksList","subtitleTrack","captionsTrack","instreamIdMatch","decryptData","_parseVTTs","currentTrack","getCueById","textTrackCue","onFragDecrypted","onFragParsingUserdata","ccBytes","ccdatas","extractCea608Data","actualCCBytes","tmpByte","ccbyte1","ccbyte2","ccType","filterSubtitleTracks","textTrackList","SubtitleTrackController","KeySystems","queuedDefaultTrack","trackChangeListener","_onTextTracksChanged","useTextTrackPolling","subtitlePollingInterval","subtitleTracks","onSubtitleTrackLoaded","_clearReloadTimer","_loadCurrentTrack","_toggleTrackModes","nextTrack","_setSubtitleTrackInternal","subtitleTrackId","SubtitleStreamController","tracksBuffered","currentTrackId","lastAVStart","_onMediaSeeking","subtitle_stream_controller_assertThisInitialized","onSubtitleFragProcessed","fragStart","fragEnd","onSubtitleTracksUpdated","onSubtitleTrackSwitch","referenceStart","frags","mergeSubtitlePlaylists","_getBuffered","requestMediaKeySystemAccess","EMEController","_widevineLicenseUrl","_licenseXhrSetup","_emeEnabled","_requestMediaKeySystemAccess","_drmSystemOptions","_mediaKeysList","_media","_hasSetMediaKeys","_requestLicenseFailureCount","mediaKeysPromise","_onMediaEncrypted","initDataType","KEY_SYSTEM_ERROR","KEY_SYSTEM_NO_KEYS","finallySetKeyAndStartSession","mediaKeys","_attemptSetMediaKeys","_generateRequestWithPreferredKeySession","widevineLicenseUrl","licenseXhrSetup","emeEnabled","requestMediaKeySystemAccessFunc","drmSystemOptions","getLicenseServerUrl","keySystem","WIDEVINE","_attemptKeySystemAccess","audioCodecs","videoCodecs","mediaKeySystemConfigs","baseConfig","audioCapabilities","videoCapabilities","robustness","audioRobustness","videoRobustness","createWidevineMediaKeySystemConfigurations","getSupportedMediaKeySystemConfigurations","keySystemAccessPromise","mediaKeySystemAccess","_onMediaKeySystemAccessObtained","mediaKeysListItem","mediaKeysSessionInitialized","mediaKeySystemDomain","createMediaKeys","_onMediaKeysCreated","mediaKeysSession","createSession","_onNewMediaKeySession","keySession","sessionId","_onKeySessionMessage","_requestLicense","keysListItem","setMediaKeys","_this6","KEY_SYSTEM_NO_ACCESS","KEY_SYSTEM_NO_SESSION","KEY_SYSTEM_NO_INIT_DATA","generateRequest","_createLicenseXhr","keyMessage","_onLicenseRequestReadyStageChange","KEY_SYSTEM_LICENSE_REQUEST_FAILED","attemptsLeft","_generateLicenseRequestChallenge","challenge","onMediaDetached","mediaKeysList","hlsDefaultConfig","lowBufferWatchdogPeriod","abrController","bufferController","capLevelController","fpsController","minAutoBitrate","__USE_SUBTITLES__","subtitleStreamController","subtitleTrackController","audioStreamController","audioTrackController","emeController","Hls","userConfig","_Observer","_autoLevelCapping","levelController","networkControllers","coreComponents","hls_objectSpread","hls_assertThisInitialized","playListLoader","fragmentLoader","keyLoader","id3TrackController","Controller","SourceBuffer","WebKitSourceBuffer","sourceBufferValidAPI","__VERSION__","detachMedia","component","recoverMediaError","manualLevel","shouldStartCapping","newCapLevelToPlayerSize","audioTrackId","isFiniteNumber","_get_self_scope__WEBPACK_IMPORTED_MODULE_0__","fakeLogger","exportedLogger","formatMsg","consolePrintFn","debugConfig","exportLoggerFunctions","buf2str","_abortFlag","m3u8provider","tsListProvider","setM3U8Provider","provider1","urlParts","rootHash","abortFlag"],"version":3,"file":"index.ed2f3c79.js.map"} \ No newline at end of file +{"mappings":"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BA20B,EAAava,EAAO2H,EAAQ1P,GAEnC,MAAMnP,EADN6e,GAAU+S,EAAIziB,QAEPA,GAhFS,YAiFd+H,EAAM2H,KAAgB,IAAJ1P,EAAU,IAC5BA,GAAK,SAEAA,GAAK,KACV+H,EAAM2H,KAAgB,IAAJ1P,EAAU,IAC5BA,KAAO,EAGT,OADA+H,EAAM2H,GAAU1P,EACTnP,WAEA4xB,EAAI/C,GAIX,OAHIA,EAAI,GAAM,GACZA,IAEKn4B,KAAKkd,gBAECib,GACb,IAAI/xB,EAAI,EACJ+xB,GAAKyC,IACPzC,EAAIn4B,KAAKkd,MAAMib,EAAIyC,GACnBx0B,EAAI,IAEF+xB,GAAK,QACPA,KAAO,GACP/xB,GAAK,IAEH+xB,GAAK,MACPA,KAAO,EACP/xB,GAAK,GAEP,OAAOA,EAAI+0B,EAAQhD,GAhBAiD,CAAMjD,GAAK,GAAK,GAkBrC,MAAMgD,EAAU,CACd,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,GAGFt5B,EAAQgtB,oBAxVYtuB,GAClB,MAAMme,WAkCUne,GAChB,IAAI6F,EAAI,EACR,GAAI7F,EAAKuO,KAAM,CACb,MAAM+R,EAAItgB,EAAKuO,KAAKuC,OACpBjL,GAAK,EAAIya,EAAIqa,EAAIra,GAEnB,GAAItgB,EAAK2O,MACP,IAAK,MAAMuf,KAAQluB,EAAK2O,MAAO,CAC7B,MAAM2R,EAAIoa,EAASxM,GACnBroB,GAAK,EAAIya,EAAIqa,EAAIra,GAGrB,OAAOza,EA9CMi1B,CAAS96B,GAChBigB,EAAQ,IAAIkG,WAAWhI,GAC7B,IAAI1J,EAAI0J,EAOR,GANIne,EAAKuO,OACPkG,GAAKzU,EAAKuO,KAAKuC,OACfmP,EAAM5G,IAAIrZ,EAAKuO,KAAMkG,GACrBA,EAAI+lB,EAAava,EAAOxL,EAAGzU,EAAKuO,KAAKuC,QAAU,EAC/CmP,EAAMxL,GAAK,IAETzU,EAAK2O,MACP,IAAK,IAAInN,EAAQxB,EAAK2O,MAAMmC,OAAS,EAAGtP,GAAS,EAAGA,IAAS,CAC3D,MAAM2c,EAAOmc,EAAWt6B,E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CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,kEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,sEAINxT,IAAK,CACHyR,IAAK,EACL+B,OAAQ,CACN,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,iEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,mEAEF,C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E,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,EAAE,EAAE,GAAG,GAAG,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,GAAG,IAAI,IAAI,EAAE,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,IAAI,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,GAAG,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,IAAI,GAAG,IAAI,IAAI,GAAG,IAAI,IAAI,EAAE,IAAI,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,IAAI,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,GAAG,EAAE,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,EAA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","sources":["src/index.js","node_modules/ipfs-core/cjs/src/index.js","node_modules/ipfs-core/cjs/src/components/index.js","node_modules/merge-options/index.js","node_modules/is-plain-obj/index.js","node_modules/ipfs-utils/src/env.js","node_modules/process/browser.js","node_modules/is-electron/index.js","node_modules/debug/src/browser.js","node_modules/debug/src/common.js","node_modules/debug/node_modules/ms/index.js","node_modules/err-code/index.js","node_modules/ipfs-unixfs/cjs/src/index.js","node_modules/ipfs-unixfs/cjs/src/unixfs.js","node_modules/protobufjs/minimal.js","node_modules/protobufjs/src/index-minimal.js","node_modules/protobufjs/src/writer.js","node_modules/protobufjs/src/util/minimal.js","node_modules/@protobufjs/aspromise/index.js","node_modules/@protobufjs/base64/index.js","node_modules/@protobufjs/eventemitter/index.js","node_modules/@protobufjs/float/index.js","node_modules/@protobufjs/inquire/index.js","node_modules/@protobufjs/utf8/index.js","node_modules/@protobufjs/pool/index.js","node_modules/protobufjs/src/util/longbits.js","node_modules/protobufjs/src/writer_buffer.js","node_modules/protobufjs/src/reader.js","node_modules/protobufjs/src/reader_buffer.js","node_modules/protobufjs/src/rpc.js","node_modules/protobufjs/src/rpc/service.js","node_modules/protobufjs/src/roots.js","node_modules/@ipld/dag-pb/cjs/src/index.js","node_modules/multiformats/cjs/src/cid.js","node_modules/multiformats/cjs/src/varint.js","node_modules/multiformats/cjs/vendor/varint.js","node_modules/multiformats/cjs/src/hashes/digest.js","node_modules/multiformats/cjs/src/bytes.js","node_modules/multiformats/cjs/src/bases/base58.js","node_modules/multiformats/cjs/src/bases/base.js","node_modules/multiformats/cjs/vendor/base-x.js","node_modules/multiformats/cjs/src/bases/base32.js","node_modules/@ipld/dag-pb/cjs/src/pb-decode.js","node_modules/@ipld/dag-pb/cjs/src/pb-encode.js","node_modules/@ipld/dag-pb/cjs/src/util.js","node_modules/@ipld/dag-cbor/cjs/index.js","node_modules/cborg/cjs/cborg.js","node_modules/cborg/cjs/lib/encode.js","node_modules/cborg/cjs/lib/is.js","node_modules/cborg/cjs/lib/token.js","node_modules/cborg/cjs/lib/bl.js","node_modules/cborg/cjs/lib/byte-utils.js","node_modules/cborg/cjs/lib/common.js","node_modules/cborg/cjs/lib/jump.js","node_modules/cborg/cjs/lib/0uint.js","node_modules/cborg/cjs/lib/1negint.js","node_modules/cborg/cjs/lib/2bytes.js","node_modules/cborg/cjs/lib/3string.js","node_modules/cborg/cjs/lib/4array.js","node_modules/cborg/cjs/lib/5map.js","node_modules/cborg/cjs/lib/6tag.js","node_modules/cborg/cjs/lib/7float.js","node_modules/cborg/cjs/lib/decode.js","node_modules/multiformats/cjs/src/hashes/identity.js","node_modules/multiformats/cjs/src/hashes/hasher.js","node_modules/multiformats/cjs/src/basics.js","node_modules/multiformats/cjs/src/bases/identity.js","node_modules/multiformats/cjs/src/bases/base2.js","node_modules/multiformats/cjs/src/bases/base8.js","node_modules/multiformats/cjs/src/bases/base10.js","node_modules/multiformats/cjs/src/bases/base16.js","node_modules/multiformats/cjs/src/bases/base36.js","node_modules/multiformats/cjs/src/bases/base64.js","node_modules/multiformats/cjs/src/hashes/sha2-browser.js","node_modules/multiformats/cjs/src/codecs/raw.js","node_modules/multiformats/cjs/src/codecs/json.js","node_modules/multiformats/cjs/src/index.js","node_modules/ipfs-core-config/cjs/src/init-assets.browser.js","node_modules/ipfs-core/cjs/src/errors.js","node_modules/uint8arrays/cjs/src/from-string.js","node_modules/uint8arrays/cjs/src/util/bases.js","node_modules/ipfs-core/cjs/src/components/start.js","node_modules/ipfs-core/cjs/src/utils/service.js","node_modules/ipfs-core/cjs/src/utils.js","node_modules/is-ipfs/src/index.js","node_modules/multiaddr/src/index.js","node_modules/multiaddr/src/codec.js","node_modules/multiaddr/src/convert.js","node_modules/multiaddr/src/ip.js","node_modules/is-ip/index.js","node_modules/ip-regex/index.js","node_modules/uint8arrays/cjs/src/to-string.js","node_modules/multiaddr/src/protocols-table.js","node_modules/varint/index.js","node_modules/varint/encode.js","node_modules/varint/decode.js","node_modules/varint/length.js","node_modules/uint8arrays/cjs/src/concat.js","node_modules/uint8arrays/cjs/src/equals.js","node_modules/mafmt/src/index.js","node_modules/iso-url/index.js","node_modules/iso-url/src/url-browser.js","node_modules/iso-url/src/relative.js","node_modules/interface-datastore/cjs/src/key.js","node_modules/nanoid/index.browser.js","node_modules/nanoid/url-alphabet/index.js","node_modules/@parcel/transformer-js/src/esmodule-helpers.js","node_modules/ipfs-core-utils/cjs/src/with-timeout-option.js","node_modules/timeout-abort-controller/index.js","node_modules/abort-controller/browser.js","node_modules/timeout-abort-controller/node_modules/retimer/retimer.js","node_modules/timeout-abort-controller/node_modules/retimer/time-browser.js","node_modules/any-signal/index.js","node_modules/native-abort-controller/src/index.js","node_modules/parse-duration/index.mjs","node_modules/ipfs-core-utils/cjs/src/errors.js","node_modules/ipfs-core-utils/cjs/src/to-cid-and-path.js","node_modules/ipfs-core/cjs/src/components/stop.js","node_modules/ipfs-core/cjs/src/components/dns.js","node_modules/ipfs-core-config/cjs/src/dns.browser.js","node_modules/ipfs-core-config/cjs/src/utils/tlru.js","node_modules/hashlru/index.js","node_modules/p-queue/dist/index.js","node_modules/eventemitter3/index.js","node_modules/p-queue/node_modules/p-timeout/index.js","node_modules/p-finally/index.js","node_modules/p-queue/dist/priority-queue.js","node_modules/p-queue/dist/lower-bound.js","node_modules/ipfs-utils/src/http.js","node_modules/ipfs-utils/src/http/fetch.browser.js","node_modules/ipfs-utils/src/http/error.js","node_modules/ipfs-utils/src/fetch.js","node_modules/native-fetch/src/index.js","node_modules/node-fetch/browser.js","node_modules/ipfs-core/cjs/src/components/is-online.js","node_modules/ipfs-core/cjs/src/components/resolve.js","node_modules/peer-id/src/index.js","node_modules/libp2p-crypto/src/keys/index.js","node_modules/libp2p-crypto/src/keys/keys.js","node_modules/node-forge/lib/asn1.js","node_modules/node-forge/lib/forge.js","node_modules/node-forge/lib/util.js","node_modules/node-forge/lib/baseN.js","node_modules/node-forge/lib/oids.js","node_modules/node-forge/lib/pbe.js","node_modules/node-forge/lib/aes.js","node_modules/node-forge/lib/cipher.js","node_modules/node-forge/lib/cipherModes.js","node_modules/node-forge/lib/des.js","node_modules/node-forge/lib/md.js","node_modules/node-forge/lib/pbkdf2.js","node_modules/node-forge/lib/hmac.js","node_modules/node-forge/lib/pem.js","node_modules/node-forge/lib/random.js","node_modules/node-forge/lib/sha256.js","node_modules/node-forge/lib/prng.js","node_modules/node-forge/lib/rc2.js","node_modules/node-forge/lib/rsa.js","node_modules/node-forge/lib/jsbn.js","node_modules/node-forge/lib/pkcs1.js","node_modules/node-forge/lib/sha1.js","node_modules/node-forge/lib/prime.js","node_modules/libp2p-crypto/src/keys/importer.js","node_modules/libp2p-crypto/src/ciphers/aes-gcm.browser.js","node_modules/libp2p-crypto/src/webcrypto.js","node_modules/libp2p-crypto/src/keys/rsa-class.js","node_modules/node-forge/lib/sha512.js","node_modules/node-forge/lib/ed25519.js","node_modules/node-forge/lib/asn1-validator.js","node_modules/libp2p-crypto/src/keys/rsa-browser.js","node_modules/libp2p-crypto/src/random-bytes.js","node_modules/iso-random-stream/src/random.browser.js","node_modules/libp2p-crypto/src/keys/rsa-utils.js","node_modules/libp2p-crypto/src/util.js","node_modules/libp2p-crypto/src/keys/jwk2pem.js","node_modules/libp2p-crypto/src/keys/exporter.js","node_modules/libp2p-crypto/src/keys/ed25519-class.js","node_modules/libp2p-crypto/src/keys/ed25519.js","node_modules/libp2p-crypto/src/keys/secp256k1-class.js","node_modules/libp2p-crypto/src/keys/secp256k1.js","node_modules/secp256k1/elliptic.js","node_modules/secp256k1/lib/index.js","node_modules/secp256k1/lib/elliptic.js","node_modules/elliptic/lib/elliptic.js","node_modules/elliptic/package.json","node_modules/elliptic/lib/elliptic/utils.js","node_modules/elliptic/node_modules/bn.js/lib/bn.js","node_modules/minimalistic-assert/index.js","node_modules/minimalistic-crypto-utils/lib/utils.js","node_modules/brorand/index.js","node_modules/elliptic/lib/elliptic/curve/index.js","node_modules/elliptic/lib/elliptic/curve/base.js","node_modules/elliptic/lib/elliptic/curve/short.js","node_modules/inherits/inherits_browser.js","node_modules/elliptic/lib/elliptic/curve/mont.js","node_modules/elliptic/lib/elliptic/curve/edwards.js","node_modules/elliptic/lib/elliptic/curves.js","node_modules/hash.js/lib/hash.js","node_modules/hash.js/lib/hash/utils.js","node_modules/hash.js/lib/hash/common.js","node_modules/hash.js/lib/hash/sha.js","node_modules/hash.js/lib/hash/sha/1.js","node_modules/hash.js/lib/hash/sha/common.js","node_modules/hash.js/lib/hash/sha/224.js","node_modules/hash.js/lib/hash/sha/256.js","node_modules/hash.js/lib/hash/sha/384.js","node_modules/hash.js/lib/hash/sha/512.js","node_modules/hash.js/lib/hash/ripemd.js","node_modules/hash.js/lib/hash/hmac.js","node_modules/elliptic/lib/elliptic/precomputed/secp256k1.js","node_modules/elliptic/lib/elliptic/ec/index.js","node_modules/hmac-drbg/lib/hmac-drbg.js","node_modules/elliptic/lib/elliptic/ec/key.js","node_modules/elliptic/lib/elliptic/ec/signature.js","node_modules/elliptic/lib/elliptic/eddsa/index.js","node_modules/elliptic/lib/elliptic/eddsa/key.js","node_modules/elliptic/lib/elliptic/eddsa/signature.js","node_modules/libp2p-crypto/src/keys/key-stretcher.js","node_modules/libp2p-crypto/src/hmac/index-browser.js","node_modules/libp2p-crypto/src/hmac/lengths.js","node_modules/libp2p-crypto/src/keys/ephemeral-keys.js","node_modules/libp2p-crypto/src/keys/ecdh-browser.js","node_modules/libp2p-crypto/src/keys/validate-curve-type.js","node_modules/class-is/index.js","node_modules/peer-id/src/proto.js","node_modules/ipfs-core/cjs/src/components/pin/index.js","node_modules/ipfs-core/cjs/src/components/pin/add.js","node_modules/it-last/index.js","node_modules/ipfs-core/cjs/src/components/pin/add-all.js","node_modules/ipfs-core-utils/cjs/src/pins/normalise-input.js","node_modules/ipfs-repo/cjs/src/pin-types.js","node_modules/ipfs-core/cjs/src/components/pin/ls.js","node_modules/ipfs-core/cjs/src/components/pin/rm.js","node_modules/ipfs-core/cjs/src/components/pin/rm-all.js","node_modules/ipfs-core/cjs/src/components/ipns.js","node_modules/ipfs-core/cjs/src/ipns/index.js","node_modules/ipfs-core/cjs/src/ipns/publisher.js","node_modules/datastore-core/cjs/src/errors.js","node_modules/ipns/cjs/src/index.js","node_modules/timestamp-nano/timestamp.js","node_modules/libp2p-crypto/src/index.js","node_modules/libp2p-crypto/src/aes/index.js","node_modules/libp2p-crypto/src/aes/ciphers-browser.js","node_modules/libp2p-crypto/src/aes/cipher-mode.js","node_modules/libp2p-crypto/src/pbkdf2.js","node_modules/long/src/long.js","node_modules/ipns/cjs/src/pb/ipns.js","node_modules/ipns/cjs/src/utils.js","node_modules/ipns/cjs/src/errors.js","node_modules/ipfs-core/cjs/src/ipns/republisher.js","node_modules/ipfs-core/cjs/src/ipns/resolver.js","node_modules/ipfs-core/cjs/src/utils/tlru.js","node_modules/ipfs-core/cjs/src/ipns/routing/config.js","node_modules/datastore-core/cjs/src/tiered.js","node_modules/datastore-core/cjs/src/base.js","node_modules/datastore-core/cjs/src/utils.js","node_modules/it-all/index.js","node_modules/it-drain/index.js","node_modules/it-filter/index.js","node_modules/it-take/index.js","node_modules/it-pushable/index.js","node_modules/fast-fifo/index.js","node_modules/fast-fifo/fixed-size.js","node_modules/dlv/index.js","node_modules/ipfs-core/cjs/src/ipns/routing/pubsub-datastore.js","node_modules/datastore-pubsub/cjs/src/index.js","node_modules/interface-datastore/index.js","node_modules/interface-datastore/cjs/src/index.js","node_modules/datastore-core/cjs/src/index.js","node_modules/datastore-core/cjs/src/shard.js","node_modules/datastore-core/cjs/src/shard-readme.js","node_modules/datastore-core/cjs/src/memory.js","node_modules/datastore-core/cjs/src/keytransform.js","node_modules/it-map/index.js","node_modules/it-pipe/index.js","node_modules/datastore-core/cjs/src/sharding.js","node_modules/datastore-core/cjs/src/mount.js","node_modules/it-merge/index.js","node_modules/datastore-core/cjs/src/namespace.js","node_modules/datastore-pubsub/cjs/src/utils.js","node_modules/ipfs-core/cjs/src/ipns/routing/offline-datastore.js","node_modules/libp2p-record/src/index.js","node_modules/libp2p-record/src/record/index.js","node_modules/libp2p-record/src/record/record.js","node_modules/libp2p-record/src/utils.js","node_modules/libp2p-record/src/validator.js","node_modules/libp2p-record/src/validators/index.js","node_modules/libp2p-record/src/validators/public-key.js","node_modules/libp2p-record/src/selection.js","node_modules/libp2p-record/src/selectors/index.js","node_modules/libp2p-record/src/selectors/public-key.js","node_modules/ipfs-core/cjs/src/components/name/index.js","node_modules/ipfs-core/cjs/src/components/name/publish.js","node_modules/ipfs-core/cjs/src/components/name/utils.js","node_modules/ipfs-core/cjs/src/components/name/resolve.js","node_modules/is-domain-name/index.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/index.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/cancel.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/utils.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/state.js","node_modules/ipfs-core/cjs/src/components/name/pubsub/subs.js","node_modules/ipfs-core/cjs/src/components/refs/index.js","node_modules/ipfs-core/cjs/src/components/refs/local.js","node_modules/ipfs-core/cjs/src/components/bitswap/index.js","node_modules/ipfs-core/cjs/src/components/bitswap/wantlist.js","node_modules/ipfs-core/cjs/src/components/bitswap/wantlist-for-peer.js","node_modules/ipfs-core/cjs/src/components/bitswap/unwant.js","node_modules/ipfs-core/cjs/src/components/bitswap/stat.js","node_modules/ipfs-core/cjs/src/components/bootstrap/index.js","node_modules/ipfs-core/cjs/src/components/bootstrap/add.js","node_modules/ipfs-core/cjs/src/components/bootstrap/utils.js","node_modules/ipfs-core/cjs/src/components/bootstrap/clear.js","node_modules/ipfs-core/cjs/src/components/bootstrap/list.js","node_modules/ipfs-core/cjs/src/components/bootstrap/reset.js","node_modules/ipfs-core-config/cjs/src/config.browser.js","node_modules/ipfs-core/cjs/src/components/bootstrap/rm.js","node_modules/ipfs-core/cjs/src/components/block/index.js","node_modules/ipfs-core/cjs/src/components/block/get.js","node_modules/ipfs-core/cjs/src/components/block/put.js","node_modules/ipfs-core/cjs/src/components/block/rm.js","node_modules/it-parallel/index.js","node_modules/p-defer/index.js","node_modules/events/events.js","node_modules/ipfs-core/cjs/src/components/block/utils.js","node_modules/ipfs-core/cjs/src/components/block/stat.js","node_modules/ipfs-core/cjs/src/components/root.js","node_modules/ipfs-core/cjs/src/components/add.js","node_modules/ipfs-core/cjs/src/components/add-all/index.js","node_modules/ipfs-unixfs-importer/cjs/src/index.js","node_modules/it-parallel-batch/index.js","node_modules/it-batch/index.js","node_modules/ipfs-unixfs-importer/cjs/src/options.js","node_modules/@multiformats/murmur3/cjs/index.js","node_modules/murmurhash3js-revisited/index.js","node_modules/murmurhash3js-revisited/lib/murmurHash3js.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/index.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/dir.js","node_modules/ipfs-unixfs-importer/cjs/src/utils/persist.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/index.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/flat.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/balanced.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/trickle.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/file/buffer-importer.js","node_modules/ipfs-unixfs-importer/cjs/src/chunker/rabin.js","node_modules/bl/BufferList.js","node_modules/@parcel/node-libs-browser/node_modules/buffer/index.js","node_modules/base64-js/index.js","node_modules/ieee754/index.js","node_modules/rabin-wasm/src/index.js","node_modules/rabin-wasm/src/rabin.js","node_modules/rabin-wasm/dist/rabin-wasm.js","node_modules/@assemblyscript/loader/index.js","node_modules/ipfs-unixfs-importer/cjs/src/chunker/fixed-size.js","node_modules/ipfs-unixfs-importer/cjs/src/dag-builder/validate-chunks.js","node_modules/ipfs-unixfs-importer/cjs/src/tree-builder.js","node_modules/ipfs-unixfs-importer/cjs/src/dir-flat.js","node_modules/ipfs-unixfs-importer/cjs/src/dir.js","node_modules/ipfs-unixfs-importer/cjs/src/flat-to-shard.js","node_modules/ipfs-unixfs-importer/cjs/src/dir-sharded.js","node_modules/hamt-sharding/src/index.js","node_modules/hamt-sharding/src/bucket.js","node_modules/sparse-array/index.js","node_modules/hamt-sharding/src/consumable-hash.js","node_modules/hamt-sharding/src/consumable-buffer.js","node_modules/ipfs-unixfs-importer/cjs/src/utils/to-path-components.js","node_modules/ipfs-core-utils/cjs/src/files/normalise-input.js","node_modules/ipfs-core-utils/cjs/src/files/normalise-content.js","node_modules/browser-readablestream-to-it/index.js","node_modules/blob-to-it/index.js","node_modules/it-peekable/index.js","node_modules/ipfs-core-utils/cjs/src/files/utils.js","node_modules/ipfs-core-utils/cjs/src/files/normalise.js","node_modules/ipfs-core/cjs/src/components/add-all/utils.js","node_modules/ipfs-core/cjs/src/components/cat.js","node_modules/ipfs-unixfs-exporter/cjs/src/index.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/index.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/unixfs-v1/index.js","node_modules/ipfs-unixfs-exporter/cjs/src/utils/find-cid-in-shard.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/unixfs-v1/content/file.js","node_modules/ipfs-unixfs-exporter/cjs/src/utils/extract-data-from-block.js","node_modules/ipfs-unixfs-exporter/cjs/src/utils/validate-offset-and-length.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/unixfs-v1/content/directory.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/unixfs-v1/content/hamt-sharded-directory.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/raw.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/dag-cbor.js","node_modules/ipfs-unixfs-exporter/cjs/src/resolvers/identity.js","node_modules/ipfs-core/cjs/src/components/get.js","node_modules/it-tar/index.js","node_modules/it-tar/extract.js","node_modules/it-tar/extract-headers.js","node_modules/it-tar/lte-reader.js","node_modules/it-reader/index.js","node_modules/it-tar/pack.js","node_modules/iso-constants/index.browser.js","node_modules/it-concat/index.js","node_modules/it-tar/pack-headers.js","node_modules/pako/index.js","node_modules/pako/lib/utils/common.js","node_modules/pako/lib/deflate.js","node_modules/pako/lib/zlib/deflate.js","node_modules/pako/lib/zlib/trees.js","node_modules/pako/lib/zlib/adler32.js","node_modules/pako/lib/zlib/crc32.js","node_modules/pako/lib/zlib/messages.js","node_modules/pako/lib/utils/strings.js","node_modules/pako/lib/zlib/zstream.js","node_modules/pako/lib/inflate.js","node_modules/pako/lib/zlib/inflate.js","node_modules/pako/lib/zlib/inffast.js","node_modules/pako/lib/zlib/inftrees.js","node_modules/pako/lib/zlib/constants.js","node_modules/pako/lib/zlib/gzheader.js","node_modules/it-to-buffer/index.js","node_modules/ipfs-core/cjs/src/components/ls.js","node_modules/ipfs-core/cjs/src/components/version.js","node_modules/ipfs-core/cjs/src/version.js","node_modules/ipfs-core/cjs/src/components/id.js","node_modules/ipfs-core/cjs/src/components/config/index.js","node_modules/ipfs-core/cjs/src/components/config/profiles.js","node_modules/just-safe-set/index.js","node_modules/ipfs-core/cjs/src/components/dag/index.js","node_modules/ipfs-core/cjs/src/components/dag/export.js","node_modules/multiformats/cjs/src/block.js","node_modules/@ipld/car/cjs/lib/writer-browser.js","node_modules/@ipld/car/cjs/lib/encoder.js","node_modules/@ipld/car/cjs/lib/iterator-channel.js","node_modules/@ipld/car/cjs/lib/decoder.js","node_modules/ipfs-core/cjs/src/components/dag/get.js","node_modules/it-first/index.js","node_modules/ipfs-core/cjs/src/components/dag/import.js","node_modules/@ipld/car/cjs/lib/iterator.js","node_modules/ipfs-core/cjs/src/components/dag/put.js","node_modules/ipfs-core/cjs/src/components/dag/resolve.js","node_modules/ipfs-core/cjs/src/preload.js","node_modules/multiaddr-to-uri/index.js","node_modules/array-shuffle/index.js","node_modules/ipfs-core-config/cjs/src/preload.browser.js","node_modules/ipfs-core/cjs/src/mfs-preload.js","node_modules/ipfs-core/cjs/src/components/files/index.js","node_modules/ipfs-core/cjs/src/components/files/utils/create-lock.js","node_modules/mortice/lib/index.js","node_modules/mortice/lib/node.js","node_modules/mortice/lib/constants.js","node_modules/mortice/lib/browser.js","node_modules/observable-webworkers/lib/index.js","node_modules/promise-timeout/index.js","node_modules/ipfs-core/cjs/src/components/files/stat.js","node_modules/ipfs-core/cjs/src/components/files/utils/to-mfs-path.js","node_modules/ipfs-core/cjs/src/components/files/utils/with-mfs-root.js","node_modules/ipfs-core/cjs/src/components/files/utils/to-path-components.js","node_modules/ipfs-core/cjs/src/components/files/chmod.js","node_modules/ipfs-core/cjs/src/components/files/utils/to-trail.js","node_modules/ipfs-core/cjs/src/components/files/utils/add-link.js","node_modules/ipfs-core/cjs/src/components/files/utils/dir-sharded.js","node_modules/ipfs-core/cjs/src/components/files/utils/persist.js","node_modules/ipfs-core/cjs/src/components/files/utils/hamt-constants.js","node_modules/ipfs-core/cjs/src/components/files/utils/hamt-utils.js","node_modules/ipfs-core/cjs/src/components/files/utils/update-tree.js","node_modules/ipfs-core/cjs/src/components/files/utils/update-mfs-root.js","node_modules/ipfs-core/cjs/src/components/files/cp.js","node_modules/ipfs-core/cjs/src/components/files/mkdir.js","node_modules/ipfs-core/cjs/src/components/files/utils/create-node.js","node_modules/ipfs-core/cjs/src/components/files/rm.js","node_modules/ipfs-core/cjs/src/components/files/utils/remove-link.js","node_modules/ipfs-core/cjs/src/components/files/flush.js","node_modules/ipfs-core/cjs/src/components/files/mv.js","node_modules/ipfs-core/cjs/src/components/files/touch.js","node_modules/ipfs-core/cjs/src/components/files/read.js","node_modules/ipfs-core/cjs/src/components/files/write.js","node_modules/ipfs-core/cjs/src/components/files/utils/to-async-iterator.js","node_modules/ipfs-core/cjs/src/components/files/ls.js","node_modules/ipfs-core/cjs/src/components/key/index.js","node_modules/ipfs-core/cjs/src/components/key/export.js","node_modules/ipfs-core/cjs/src/components/key/gen.js","node_modules/ipfs-core/cjs/src/components/key/import.js","node_modules/ipfs-core/cjs/src/components/key/info.js","node_modules/ipfs-core/cjs/src/components/key/list.js","node_modules/ipfs-core/cjs/src/components/key/rename.js","node_modules/ipfs-core/cjs/src/components/key/rm.js","node_modules/ipfs-core/cjs/src/components/object/index.js","node_modules/ipfs-core/cjs/src/components/object/data.js","node_modules/ipfs-core/cjs/src/components/object/get.js","node_modules/ipfs-core/cjs/src/components/object/links.js","node_modules/ipfs-core/cjs/src/components/object/new.js","node_modules/ipfs-core/cjs/src/components/object/put.js","node_modules/ipfs-core/cjs/src/components/object/stat.js","node_modules/ipfs-core/cjs/src/components/object/patch/index.js","node_modules/ipfs-core/cjs/src/components/object/patch/add-link.js","node_modules/ipfs-core/cjs/src/components/object/patch/append-data.js","node_modules/ipfs-core/cjs/src/components/object/patch/rm-link.js","node_modules/ipfs-core/cjs/src/components/object/patch/set-data.js","node_modules/ipfs-core/cjs/src/components/repo/index.js","node_modules/ipfs-core/cjs/src/components/repo/gc.js","node_modules/ipfs-core/cjs/src/components/repo/stat.js","node_modules/ipfs-core/cjs/src/components/repo/version.js","node_modules/ipfs-repo/cjs/src/constants.js","node_modules/ipfs-core/cjs/src/components/stats/index.js","node_modules/ipfs-core/cjs/src/components/stats/bw.js","node_modules/ipfs-core/cjs/src/components/storage.js","node_modules/ipfs-core-config/cjs/src/repo.browser.js","node_modules/ipfs-repo/cjs/src/index.js","node_modules/just-safe-get/index.js","node_modules/ipfs-repo-migrations/cjs/src/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-8/index.js","node_modules/it-length/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-9/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-9/pin-set.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-9/pin.js","node_modules/fnv1a/index.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-9/utils.js","node_modules/uint8arrays/cjs/src/compare.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-10/index.js","node_modules/ipfs-repo-migrations/cjs/src/utils.js","node_modules/ipfs-repo-migrations/cjs/migrations/migration-11/index.js","node_modules/ipfs-repo-migrations/cjs/src/repo/version.js","node_modules/ipfs-repo-migrations/cjs/src/repo/init.js","node_modules/ipfs-repo-migrations/cjs/src/errors.js","node_modules/bytes/index.js","node_modules/ipfs-repo/cjs/src/version.js","node_modules/ipfs-repo/cjs/src/utils/level.js","node_modules/ipfs-repo/cjs/src/errors.js","node_modules/ipfs-repo/cjs/src/config.js","node_modules/ipfs-repo/cjs/src/spec.js","node_modules/sort-keys/index.js","node_modules/ipfs-repo/cjs/src/api-addr.js","node_modules/ipfs-repo/cjs/src/idstore.js","node_modules/ipfs-repo/cjs/src/default-options.js","node_modules/ipfs-repo/cjs/src/locks/memory.js","node_modules/ipfs-repo/cjs/src/default-datastore.js","node_modules/ipfs-repo/cjs/src/pin-manager.js","node_modules/ipfs-repo/cjs/src/utils/blockstore.js","node_modules/ipfs-repo/cjs/src/utils/walk-dag.js","node_modules/ipfs-repo/cjs/src/pinned-blockstore.js","node_modules/ipfs-repo/cjs/src/gc.js","node_modules/datastore-level/cjs/src/index.js","node_modules/it-sort/index.js","node_modules/level/browser.js","node_modules/level-packager/level-packager.js","node_modules/levelup/lib/levelup.js","node_modules/util/util.js","node_modules/util/support/types.js","node_modules/is-arguments/index.js","node_modules/has-tostringtag/shams.js","node_modules/has-symbols/shams.js","node_modules/call-bind/callBound.js","node_modules/get-intrinsic/index.js","node_modules/has-symbols/index.js","node_modules/function-bind/index.js","node_modules/function-bind/implementation.js","node_modules/has/src/index.js","node_modules/call-bind/index.js","node_modules/is-generator-function/index.js","node_modules/which-typed-array/index.js","node_modules/foreach/index.js","node_modules/available-typed-arrays/index.js","node_modules/es-abstract/helpers/getOwnPropertyDescriptor.js","node_modules/is-typed-array/index.js","node_modules/util/support/isBufferBrowser.js","node_modules/deferred-leveldown/deferred-leveldown.js","node_modules/abstract-leveldown/index.js","node_modules/abstract-leveldown/abstract-leveldown.js","node_modules/level-supports/index.js","node_modules/is-buffer/index.js","node_modules/catering/index.js","node_modules/queue-tick/queue-microtask.js","node_modules/abstract-leveldown/abstract-iterator.js","node_modules/abstract-leveldown/next-tick-browser.js","node_modules/queue-microtask/index.js","node_modules/abstract-leveldown/abstract-chained-batch.js","node_modules/abstract-leveldown/lib/common.js","node_modules/deferred-leveldown/deferred-iterator.js","node_modules/deferred-leveldown/util.js","node_modules/deferred-leveldown/deferred-chained-batch.js","node_modules/level-iterator-stream/index.js","node_modules/readable-stream/readable-browser.js","node_modules/readable-stream/lib/_stream_readable.js","node_modules/readable-stream/lib/internal/streams/stream-browser.js","node_modules/readable-stream/lib/internal/streams/buffer_list.js","node_modules/readable-stream/lib/internal/streams/destroy.js","node_modules/readable-stream/lib/internal/streams/state.js","node_modules/readable-stream/errors-browser.js","node_modules/readable-stream/lib/_stream_duplex.js","node_modules/readable-stream/lib/_stream_writable.js","node_modules/util-deprecate/browser.js","node_modules/string_decoder/lib/string_decoder.js","node_modules/string_decoder/node_modules/safe-buffer/index.js","node_modules/readable-stream/lib/internal/streams/async_iterator.js","node_modules/readable-stream/lib/internal/streams/end-of-stream.js","node_modules/readable-stream/lib/internal/streams/from-browser.js","node_modules/readable-stream/lib/_stream_transform.js","node_modules/readable-stream/lib/_stream_passthrough.js","node_modules/readable-stream/lib/internal/streams/pipeline.js","node_modules/levelup/lib/batch.js","node_modules/level-errors/errors.js","node_modules/levelup/lib/common.js","node_modules/levelup/lib/next-tick-browser.js","node_modules/encoding-down/index.js","node_modules/level-codec/index.js","node_modules/level-codec/lib/encodings.js","node_modules/level-js/index.js","node_modules/run-parallel-limit/index.js","node_modules/level-js/iterator.js","node_modules/level-js/util/key-range.js","node_modules/ltgt/index.js","node_modules/level-js/util/deserialize.js","node_modules/level-js/util/serialize.js","node_modules/level-js/util/support.js","node_modules/level-js/util/clear.js","node_modules/blockstore-datastore-adapter/cjs/src/index.js","node_modules/blockstore-core/cjs/src/base.js","node_modules/ipfs-core/cjs/src/components/libp2p.js","node_modules/ipfs-core-config/cjs/src/libp2p-pubsub-routers.browser.js","node_modules/libp2p-gossipsub/src/index.js","node_modules/libp2p-interfaces/src/pubsub/index.js","node_modules/libp2p-interfaces/src/topology/multicodec-topology.js","node_modules/libp2p-interfaces/src/topology/index.js","node_modules/libp2p-interfaces/src/pubsub/errors.js","node_modules/libp2p-interfaces/src/pubsub/message/rpc.js","node_modules/libp2p-interfaces/src/pubsub/peer-streams.js","node_modules/it-length-prefixed/src/index.js","node_modules/it-length-prefixed/src/encode.js","node_modules/it-length-prefixed/src/varint-encode.js","node_modules/it-length-prefixed/src/decode.js","node_modules/it-length-prefixed/src/varint-decode.js","node_modules/it-length-prefixed/src/int32BE-encode.js","node_modules/it-length-prefixed/src/int32BE-decode.js","node_modules/abortable-iterator/index.js","node_modules/get-iterator/index.js","node_modules/abortable-iterator/AbortError.js","node_modules/libp2p-interfaces/src/pubsub/signature-policy.js","node_modules/libp2p-interfaces/src/pubsub/utils.js","node_modules/libp2p-interfaces/src/pubsub/message/sign.js","node_modules/libp2p-gossipsub/src/message-cache.js","node_modules/libp2p-gossipsub/src/utils/index.js","node_modules/libp2p-gossipsub/src/utils/create-gossip-rpc.js","node_modules/libp2p-gossipsub/src/utils/shuffle.js","node_modules/libp2p-gossipsub/src/utils/has-gossip-protocol.js","node_modules/libp2p-gossipsub/src/constants.js","node_modules/libp2p-gossipsub/src/utils/messageIdToString.js","node_modules/libp2p-gossipsub/src/message/rpc.js","node_modules/libp2p-gossipsub/src/heartbeat.js","node_modules/libp2p-gossipsub/src/get-gossip-peers.js","node_modules/libp2p-gossipsub/src/score/index.js","node_modules/libp2p-gossipsub/src/score/peer-score-params.js","node_modules/libp2p-gossipsub/src/score/constants.js","node_modules/libp2p-gossipsub/src/score/peer-score-thresholds.js","node_modules/libp2p-gossipsub/src/score/peer-score.js","node_modules/libp2p-gossipsub/src/score/peer-stats.js","node_modules/libp2p-gossipsub/src/score/compute-score.js","node_modules/libp2p-gossipsub/src/score/message-deliveries.js","node_modules/denque/index.js","node_modules/libp2p-gossipsub/src/tracer.js","node_modules/time-cache/src/index.js","node_modules/lodash.throttle/index.js","node_modules/libp2p/src/record/envelope/index.js","node_modules/libp2p/src/errors.js","node_modules/libp2p/src/record/envelope/envelope.js","node_modules/libp2p-delegated-peer-routing/src/index.js","node_modules/libp2p-delegated-content-routing/src/index.js","node_modules/ipfs-http-client/cjs/src/index.js","node_modules/ipfs-core-utils/cjs/src/multibases.js","node_modules/ipfs-core-utils/cjs/src/multicodecs.js","node_modules/ipfs-core-utils/cjs/src/multihashes.js","node_modules/ipfs-http-client/cjs/src/bitswap/index.js","node_modules/ipfs-http-client/cjs/src/bitswap/wantlist.js","node_modules/ipfs-http-client/cjs/src/lib/configure.js","node_modules/ipfs-http-client/cjs/src/lib/core.js","node_modules/ipfs-core-utils/cjs/src/to-url-string.js","node_modules/ipfs-core-utils/cjs/src/agent.browser.js","node_modules/ipfs-http-client/cjs/src/lib/to-url-search-params.js","node_modules/ipfs-http-client/cjs/src/lib/mode-to-string.js","node_modules/ipfs-http-client/cjs/src/lib/parse-mtime.js","node_modules/ipfs-http-client/cjs/src/bitswap/wantlist-for-peer.js","node_modules/ipfs-http-client/cjs/src/bitswap/stat.js","node_modules/ipfs-http-client/cjs/src/bitswap/unwant.js","node_modules/ipfs-http-client/cjs/src/block/index.js","node_modules/ipfs-http-client/cjs/src/block/get.js","node_modules/ipfs-http-client/cjs/src/block/put.js","node_modules/ipfs-core-utils/cjs/src/multipart-request.browser.js","node_modules/ipfs-core-utils/cjs/src/files/normalise-input.browser.js","node_modules/ipfs-core-utils/cjs/src/files/normalise-content.browser.js","node_modules/ipfs-core-utils/cjs/src/mode-to-string.js","node_modules/ipfs-http-client/cjs/src/lib/abort-signal.js","node_modules/ipfs-http-client/cjs/src/block/rm.js","node_modules/ipfs-http-client/cjs/src/block/stat.js","node_modules/ipfs-http-client/cjs/src/bootstrap/index.js","node_modules/ipfs-http-client/cjs/src/bootstrap/add.js","node_modules/ipfs-http-client/cjs/src/bootstrap/clear.js","node_modules/ipfs-http-client/cjs/src/bootstrap/list.js","node_modules/ipfs-http-client/cjs/src/bootstrap/reset.js","node_modules/ipfs-http-client/cjs/src/bootstrap/rm.js","node_modules/ipfs-http-client/cjs/src/config/index.js","node_modules/ipfs-http-client/cjs/src/config/profiles/index.js","node_modules/ipfs-http-client/cjs/src/config/profiles/apply.js","node_modules/ipfs-http-client/cjs/src/config/profiles/list.js","node_modules/ipfs-http-client/cjs/src/lib/object-to-camel.js","node_modules/ipfs-http-client/cjs/src/config/get.js","node_modules/ipfs-http-client/cjs/src/config/get-all.js","node_modules/ipfs-http-client/cjs/src/config/replace.js","node_modules/ipfs-http-client/cjs/src/config/set.js","node_modules/ipfs-http-client/cjs/src/dag/index.js","node_modules/ipfs-http-client/cjs/src/dag/export.js","node_modules/ipfs-http-client/cjs/src/dag/get.js","node_modules/ipfs-http-client/cjs/src/lib/resolve.js","node_modules/ipfs-http-client/cjs/src/dag/import.js","node_modules/ipfs-http-client/cjs/src/dag/put.js","node_modules/ipfs-http-client/cjs/src/dag/resolve.js","node_modules/ipfs-http-client/cjs/src/dht/index.js","node_modules/ipfs-http-client/cjs/src/dht/find-peer.js","node_modules/ipfs-http-client/cjs/src/dht/response-types.js","node_modules/ipfs-http-client/cjs/src/dht/find-provs.js","node_modules/ipfs-http-client/cjs/src/dht/get.js","node_modules/ipfs-http-client/cjs/src/dht/provide.js","node_modules/ipfs-http-client/cjs/src/dht/put.js","node_modules/ipfs-http-client/cjs/src/dht/query.js","node_modules/ipfs-http-client/cjs/src/diag/index.js","node_modules/ipfs-http-client/cjs/src/diag/cmds.js","node_modules/ipfs-http-client/cjs/src/diag/net.js","node_modules/ipfs-http-client/cjs/src/diag/sys.js","node_modules/ipfs-http-client/cjs/src/files/index.js","node_modules/ipfs-http-client/cjs/src/files/chmod.js","node_modules/ipfs-http-client/cjs/src/files/cp.js","node_modules/ipfs-http-client/cjs/src/files/flush.js","node_modules/ipfs-http-client/cjs/src/files/ls.js","node_modules/ipfs-http-client/cjs/src/lib/object-to-camel-with-metadata.js","node_modules/ipfs-http-client/cjs/src/files/mkdir.js","node_modules/ipfs-http-client/cjs/src/files/mv.js","node_modules/ipfs-http-client/cjs/src/files/read.js","node_modules/stream-to-it/source.js","node_modules/ipfs-http-client/cjs/src/files/rm.js","node_modules/ipfs-http-client/cjs/src/files/stat.js","node_modules/ipfs-http-client/cjs/src/files/touch.js","node_modules/ipfs-http-client/cjs/src/files/write.js","node_modules/ipfs-http-client/cjs/src/key/index.js","node_modules/ipfs-http-client/cjs/src/key/export.js","node_modules/ipfs-http-client/cjs/src/key/gen.js","node_modules/ipfs-http-client/cjs/src/key/import.js","node_modules/ipfs-http-client/cjs/src/key/info.js","node_modules/ipfs-http-client/cjs/src/key/list.js","node_modules/ipfs-http-client/cjs/src/key/rename.js","node_modules/ipfs-http-client/cjs/src/key/rm.js","node_modules/ipfs-http-client/cjs/src/log/index.js","node_modules/ipfs-http-client/cjs/src/log/level.js","node_modules/ipfs-http-client/cjs/src/log/ls.js","node_modules/ipfs-http-client/cjs/src/log/tail.js","node_modules/ipfs-http-client/cjs/src/name/index.js","node_modules/ipfs-http-client/cjs/src/name/publish.js","node_modules/ipfs-http-client/cjs/src/name/resolve.js","node_modules/ipfs-http-client/cjs/src/name/pubsub/index.js","node_modules/ipfs-http-client/cjs/src/name/pubsub/cancel.js","node_modules/ipfs-http-client/cjs/src/name/pubsub/state.js","node_modules/ipfs-http-client/cjs/src/name/pubsub/subs.js","node_modules/ipfs-http-client/cjs/src/object/index.js","node_modules/ipfs-http-client/cjs/src/object/data.js","node_modules/ipfs-http-client/cjs/src/object/get.js","node_modules/ipfs-http-client/cjs/src/object/links.js","node_modules/ipfs-http-client/cjs/src/object/new.js","node_modules/ipfs-http-client/cjs/src/object/put.js","node_modules/ipfs-http-client/cjs/src/object/stat.js","node_modules/ipfs-http-client/cjs/src/object/patch/index.js","node_modules/ipfs-http-client/cjs/src/object/patch/add-link.js","node_modules/ipfs-http-client/cjs/src/object/patch/append-data.js","node_modules/ipfs-http-client/cjs/src/object/patch/rm-link.js","node_modules/ipfs-http-client/cjs/src/object/patch/set-data.js","node_modules/ipfs-http-client/cjs/src/pin/index.js","node_modules/ipfs-http-client/cjs/src/pin/add-all.js","node_modules/ipfs-http-client/cjs/src/pin/add.js","node_modules/ipfs-http-client/cjs/src/pin/ls.js","node_modules/ipfs-http-client/cjs/src/pin/rm-all.js","node_modules/ipfs-http-client/cjs/src/pin/rm.js","node_modules/ipfs-http-client/cjs/src/pin/remote/index.js","node_modules/ipfs-http-client/cjs/src/pin/remote/add.js","node_modules/ipfs-http-client/cjs/src/pin/remote/utils.js","node_modules/ipfs-http-client/cjs/src/pin/remote/ls.js","node_modules/ipfs-http-client/cjs/src/pin/remote/rm.js","node_modules/ipfs-http-client/cjs/src/pin/remote/rm-all.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/index.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/add.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/utils.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/ls.js","node_modules/ipfs-http-client/cjs/src/pin/remote/service/rm.js","node_modules/ipfs-http-client/cjs/src/pubsub/index.js","node_modules/ipfs-http-client/cjs/src/pubsub/ls.js","node_modules/ipfs-http-client/cjs/src/pubsub/peers.js","node_modules/ipfs-http-client/cjs/src/pubsub/publish.js","node_modules/ipfs-http-client/cjs/src/pubsub/subscribe.js","node_modules/ipfs-http-client/cjs/src/pubsub/unsubscribe.js","node_modules/ipfs-http-client/cjs/src/pubsub/subscription-tracker.js","node_modules/ipfs-http-client/cjs/src/refs/index.js","node_modules/ipfs-http-client/cjs/src/refs/local.js","node_modules/ipfs-http-client/cjs/src/repo/index.js","node_modules/ipfs-http-client/cjs/src/repo/gc.js","node_modules/ipfs-http-client/cjs/src/repo/stat.js","node_modules/ipfs-http-client/cjs/src/repo/version.js","node_modules/ipfs-http-client/cjs/src/stats/index.js","node_modules/ipfs-http-client/cjs/src/stats/bw.js","node_modules/ipfs-http-client/cjs/src/swarm/index.js","node_modules/ipfs-http-client/cjs/src/swarm/addrs.js","node_modules/ipfs-http-client/cjs/src/swarm/connect.js","node_modules/ipfs-http-client/cjs/src/swarm/disconnect.js","node_modules/ipfs-http-client/cjs/src/swarm/local-addrs.js","node_modules/ipfs-http-client/cjs/src/swarm/peers.js","node_modules/ipfs-http-client/cjs/src/add.js","node_modules/ipfs-http-client/cjs/src/add-all.js","node_modules/ipfs-http-client/cjs/src/cat.js","node_modules/ipfs-http-client/cjs/src/commands.js","node_modules/ipfs-http-client/cjs/src/dns.js","node_modules/ipfs-http-client/cjs/src/get-endpoint-config.js","node_modules/ipfs-http-client/cjs/src/get.js","node_modules/ipfs-http-client/cjs/src/id.js","node_modules/ipfs-http-client/cjs/src/is-online.js","node_modules/ipfs-http-client/cjs/src/ls.js","node_modules/ipfs-http-client/cjs/src/mount.js","node_modules/ipfs-http-client/cjs/src/ping.js","node_modules/ipfs-http-client/cjs/src/resolve.js","node_modules/ipfs-http-client/cjs/src/start.js","node_modules/ipfs-http-client/cjs/src/stop.js","node_modules/ipfs-http-client/cjs/src/version.js","node_modules/ipfs-utils/src/files/url-source.js","node_modules/ipfs-core-config/cjs/src/libp2p.browser.js","node_modules/libp2p-websockets/src/index.js","node_modules/it-ws/client.js","node_modules/it-ws/web-socket.js","node_modules/it-ws/duplex.js","node_modules/it-ws/source.js","node_modules/event-iterator/lib/dom.js","node_modules/event-iterator/lib/event-iterator.js","node_modules/it-ws/sink.js","node_modules/it-ws/ready.js","node_modules/it-ws/ws-url.js","node_modules/libp2p-websockets/src/listener.browser.js","node_modules/libp2p-websockets/src/socket-to-conn.js","node_modules/libp2p-websockets/src/constants.js","node_modules/libp2p-utils/src/ip-port-to-multiaddr.js","node_modules/ip-address/ip-address.ts","node_modules/ip-address/lib/ipv4.ts","node_modules/ip-address/lib/common.ts","node_modules/ip-address/lib/v4/constants.ts","node_modules/ip-address/lib/address-error.ts","node_modules/jsbn/index.js","node_modules/sprintf-js/src/sprintf.js","node_modules/ip-address/lib/ipv6.ts","node_modules/ip-address/lib/v6/constants.ts","node_modules/ip-address/lib/v6/helpers.ts","node_modules/ip-address/lib/v6/regular-expressions.ts","node_modules/p-timeout/index.js","node_modules/libp2p-websockets/src/filters.js","node_modules/libp2p-webrtc-star/src/index.js","node_modules/libp2p-webrtc-peer/index.js","node_modules/get-browser-rtc/index.js","node_modules/randombytes/browser.js","node_modules/safe-buffer/index.js","node_modules/libp2p-webrtc-peer/node_modules/err-code/index.js","node_modules/ipfs-utils/src/supports.js","node_modules/libp2p-webrtc-star/src/constants.js","node_modules/libp2p-webrtc-star/src/listener.js","node_modules/socket.io-client/build/esm/index.js","node_modules/socket.io-client/build/esm/url.js","node_modules/parseuri/index.js","node_modules/socket.io-client/build/esm/manager.js","node_modules/engine.io-client/build/esm/index.js","node_modules/engine.io-client/build/esm/socket.js","node_modules/engine.io-client/build/esm/transports/index.js","node_modules/engine.io-client/build/esm/transports/polling-xhr.js","node_modules/engine.io-client/build/esm/transports/xmlhttprequest.browser.js","node_modules/has-cors/index.js","node_modules/engine.io-client/build/esm/globalThis.browser.js","node_modules/engine.io-client/build/esm/util.js","node_modules/@socket.io/component-emitter/index.js","node_modules/engine.io-client/build/esm/transports/polling.js","node_modules/engine.io-client/build/esm/transport.js","node_modules/engine.io-parser/build/esm/index.js","node_modules/engine.io-parser/build/esm/encodePacket.browser.js","node_modules/engine.io-parser/build/esm/commons.js","node_modules/engine.io-parser/build/esm/decodePacket.browser.js","node_modules/src/index.ts","node_modules/yeast/index.js","node_modules/parseqs/index.js","node_modules/engine.io-client/build/esm/transports/websocket.js","node_modules/engine.io-client/build/esm/transports/websocket-constructor.browser.js","node_modules/socket.io-client/build/esm/socket.js","node_modules/socket.io-parser/build/esm/index.js","node_modules/socket.io-parser/build/esm/binary.js","node_modules/socket.io-parser/build/esm/is-binary.js","node_modules/socket.io-client/build/esm/on.js","node_modules/backo2/index.js","node_modules/libp2p-webrtc-star/src/socket-to-conn.js","node_modules/stream-to-it/index.js","node_modules/stream-to-it/sink.js","node_modules/stream-to-it/transform.js","node_modules/stream-to-it/duplex.js","node_modules/libp2p-webrtc-star/src/utils.js","node_modules/libp2p-mplex/src/index.js","node_modules/libp2p-mplex/src/mplex.js","node_modules/libp2p-mplex/src/coder/index.js","node_modules/libp2p-mplex/src/coder/encode.browser.js","node_modules/libp2p-mplex/src/coder/decode.js","node_modules/libp2p-mplex/src/restrict-size.js","node_modules/libp2p-mplex/src/message-types.js","node_modules/libp2p-mplex/src/stream.js","node_modules/@chainsafe/libp2p-noise/src/index.ts","node_modules/@chainsafe/libp2p-noise/src/noise.ts","node_modules/@stablelib/x25519/x25519.ts","node_modules/@stablelib/random/random.ts","node_modules/@stablelib/random/source/system.ts","node_modules/@stablelib/random/source/browser.ts","node_modules/@stablelib/random/source/node.ts","node_modules/@stablelib/wipe/wipe.ts","node_modules/@stablelib/binary/binary.ts","node_modules/@stablelib/int/int.ts","node_modules/it-pb-rpc/src/index.js","node_modules/it-handshake/src/index.js","node_modules/it-pair/duplex.js","node_modules/it-pair/index.js","node_modules/it-buffer/index.js","node_modules/@chainsafe/libp2p-noise/src/handshake-xx.ts","node_modules/@chainsafe/libp2p-noise/src/handshakes/xx.ts","node_modules/@chainsafe/libp2p-noise/src/utils.ts","node_modules/@stablelib/hkdf/hkdf.ts","node_modules/@stablelib/hmac/hmac.ts","node_modules/@stablelib/hash/hash.ts","node_modules/@stablelib/constant-time/constant-time.ts","node_modules/@stablelib/sha256/sha256.ts","node_modules/@chainsafe/libp2p-noise/src/proto/payload.js","node_modules/@chainsafe/libp2p-noise/src/handshakes/abstract-handshake.ts","node_modules/@stablelib/chacha20poly1305/chacha20poly1305.ts","node_modules/@stablelib/chacha/chacha.ts","node_modules/@stablelib/poly1305/poly1305.ts","node_modules/@chainsafe/libp2p-noise/src/logger.ts","node_modules/@chainsafe/libp2p-noise/src/constants.ts","node_modules/@chainsafe/libp2p-noise/src/encoder.ts","node_modules/@chainsafe/libp2p-noise/src/handshake-ik.ts","node_modules/@chainsafe/libp2p-noise/src/handshakes/ik.ts","node_modules/@chainsafe/libp2p-noise/src/errors.ts","node_modules/@chainsafe/libp2p-noise/src/handshake-xx-fallback.ts","node_modules/@chainsafe/libp2p-noise/src/crypto.ts","node_modules/@chainsafe/libp2p-noise/src/keycache.ts","node_modules/libp2p-kad-dht/src/index.js","node_modules/libp2p-kad-dht/src/routing-table/index.js","node_modules/k-bucket/index.js","node_modules/uint8arrays/cjs/src/xor.js","node_modules/libp2p-kad-dht/src/routing-table/generated-prefix-list-browser.json","node_modules/libp2p-kad-dht/src/utils.js","node_modules/p-map/index.js","node_modules/aggregate-error/index.js","node_modules/indent-string/index.js","node_modules/clean-stack/index.js","node_modules/libp2p-kad-dht/src/constants.js","node_modules/libp2p-kad-dht/src/network.js","node_modules/streaming-iterables/dist/index.mjs","node_modules/libp2p-kad-dht/src/rpc/index.js","node_modules/libp2p-kad-dht/src/message/index.js","node_modules/libp2p-kad-dht/src/message/dht.js","node_modules/libp2p-kad-dht/src/rpc/handlers/index.js","node_modules/libp2p-kad-dht/src/rpc/handlers/get-value.js","node_modules/libp2p-kad-dht/src/rpc/handlers/put-value.js","node_modules/libp2p-kad-dht/src/rpc/handlers/find-node.js","node_modules/libp2p-kad-dht/src/rpc/handlers/add-provider.js","node_modules/libp2p-kad-dht/src/rpc/handlers/get-providers.js","node_modules/libp2p-kad-dht/src/rpc/handlers/ping.js","node_modules/libp2p-kad-dht/src/content-fetching/index.js","node_modules/libp2p-kad-dht/src/query/index.js","node_modules/libp2p-kad-dht/src/query/run.js","node_modules/libp2p-kad-dht/src/peer-list/peer-distance-list.js","node_modules/libp2p-kad-dht/src/query/path.js","node_modules/libp2p-kad-dht/src/peer-list/peer-queue.js","node_modules/heap/index.js","node_modules/heap/lib/heap.js","node_modules/libp2p-kad-dht/src/query/worker-queue.js","node_modules/libp2p-kad-dht/src/content-routing/index.js","node_modules/libp2p-kad-dht/src/peer-list/limited-peer-list.js","node_modules/libp2p-kad-dht/src/peer-list/index.js","node_modules/libp2p-kad-dht/src/peer-routing/index.js","node_modules/libp2p-kad-dht/src/providers.js","node_modules/libp2p-kad-dht/src/query-manager.js","node_modules/ipfs-core-config/cjs/src/utils/ipns.js","node_modules/libp2p-bootstrap/src/index.js","node_modules/libp2p/src/index.js","node_modules/libp2p/src/peer-routing.js","node_modules/libp2p/src/content-routing/utils.js","node_modules/set-delayed-interval/src/index.js","node_modules/libp2p/src/content-routing/index.js","node_modules/libp2p/src/get-peer.js","node_modules/libp2p/src/config.js","node_modules/multiaddr/src/resolvers/index.js","node_modules/multiaddr/src/resolvers/dns.browser.js","node_modules/dns-over-http-resolver/src/index.js","node_modules/receptacle/index.js","node_modules/ms/index.js","node_modules/dns-over-http-resolver/src/utils.js","node_modules/libp2p/src/constants.js","node_modules/libp2p/src/identify/consts.js","node_modules/libp2p/package.json","node_modules/libp2p/src/circuit/constants.js","node_modules/libp2p-utils/src/address-sort.js","node_modules/libp2p-utils/src/multiaddr/is-private.js","node_modules/private-ip/index.js","node_modules/private-ip/lib/index.js","node_modules/netmask/lib/netmask.js","node_modules/ipaddr.js/lib/ipaddr.js","node_modules/libp2p/src/transport-manager.js","node_modules/p-settle/index.js","node_modules/p-reflect/index.js","node_modules/p-limit/index.js","node_modules/p-try/index.js","node_modules/libp2p/src/record/utils.js","node_modules/libp2p/src/record/peer-record/index.js","node_modules/libp2p-utils/src/array-equals.js","node_modules/libp2p/src/record/peer-record/peer-record.js","node_modules/libp2p/src/record/peer-record/consts.js","node_modules/libp2p/src/address-manager/index.js","node_modules/libp2p/src/connection-manager/index.js","node_modules/libp2p/src/connection-manager/latency-monitor.js","node_modules/libp2p/src/connection-manager/visibility-change-emitter.js","node_modules/retimer/retimer.js","node_modules/retimer/time-browser.js","node_modules/libp2p/src/circuit/transport.js","node_modules/libp2p/src/circuit/protocol/index.js","node_modules/libp2p-utils/src/stream-to-ma-conn.js","node_modules/libp2p/src/circuit/multicodec.js","node_modules/libp2p/src/circuit/listener.js","node_modules/libp2p/src/circuit/circuit/hop.js","node_modules/libp2p/src/circuit/circuit/utils.js","node_modules/libp2p/src/circuit/circuit/stream-handler.js","node_modules/libp2p/src/circuit/circuit/stop.js","node_modules/libp2p/src/circuit/index.js","node_modules/libp2p/src/circuit/auto-relay.js","node_modules/libp2p/src/circuit/utils.js","node_modules/libp2p/src/dialer/index.js","node_modules/libp2p/src/dialer/dial-request.js","node_modules/p-fifo/index.js","node_modules/p-any/index.js","node_modules/p-some/index.js","node_modules/p-cancelable/index.js","node_modules/libp2p/src/keychain/index.js","node_modules/sanitize-filename/index.js","node_modules/truncate-utf8-bytes/browser.js","node_modules/truncate-utf8-bytes/lib/truncate.js","node_modules/utf8-byte-length/browser.js","node_modules/libp2p/src/keychain/cms.js","node_modules/node-forge/lib/pkcs7.js","node_modules/node-forge/lib/pkcs7asn1.js","node_modules/node-forge/lib/x509.js","node_modules/node-forge/lib/mgf.js","node_modules/node-forge/lib/mgf1.js","node_modules/node-forge/lib/pss.js","node_modules/libp2p/src/keychain/util.js","node_modules/libp2p/src/metrics/index.js","node_modules/libp2p/src/metrics/old-peers.js","node_modules/libp2p/src/metrics/stats.js","node_modules/bignumber.js/bignumber.js","node_modules/@vascosantos/moving-average/index.js","node_modules/libp2p/src/upgrader.js","node_modules/multistream-select/src/index.js","node_modules/multistream-select/src/select.js","node_modules/multistream-select/src/multistream.js","node_modules/multistream-select/src/handle.js","node_modules/multistream-select/src/constants.js","node_modules/multistream-select/src/ls.js","node_modules/libp2p-interfaces/src/connection/index.js","node_modules/libp2p-interfaces/src/connection/connection.js","node_modules/libp2p-interfaces/src/connection/status.js","node_modules/mutable-proxy/build/index.js","node_modules/libp2p/src/peer-store/index.js","node_modules/libp2p/src/peer-store/address-book.js","node_modules/libp2p/src/peer-store/book.js","node_modules/libp2p/src/peer-store/key-book.js","node_modules/libp2p/src/peer-store/metadata-book.js","node_modules/libp2p/src/peer-store/proto-book.js","node_modules/libp2p/src/pubsub-adapter.js","node_modules/libp2p/src/peer-store/persistent/index.js","node_modules/libp2p/src/peer-store/persistent/consts.js","node_modules/libp2p/src/peer-store/persistent/pb/address-book.js","node_modules/libp2p/src/peer-store/persistent/pb/proto-book.js","node_modules/libp2p/src/registrar.js","node_modules/libp2p/src/ping/index.js","node_modules/libp2p/src/ping/constants.js","node_modules/libp2p/src/identify/index.js","node_modules/libp2p/src/identify/message.js","node_modules/libp2p/src/nat-manager.js","node_modules/es6-promisify/dist/promisify.mjs","node_modules/wherearewe/src/index.js","node_modules/p-retry/index.js","node_modules/retry/index.js","node_modules/retry/lib/retry.js","node_modules/retry/lib/retry_operation.js","node_modules/libp2p-utils/src/multiaddr/is-loopback.js","node_modules/is-loopback-addr/index.js","node_modules/ipfs-core/cjs/src/components/network.js","node_modules/ipfs-bitswap/cjs/src/index.js","node_modules/ipfs-bitswap/cjs/src/bitswap.js","node_modules/ipfs-bitswap/cjs/src/want-manager/index.js","node_modules/ipfs-bitswap/cjs/src/message/index.js","node_modules/varint-decoder/src/index.js","node_modules/varint-decoder/node_modules/varint/index.js","node_modules/varint-decoder/node_modules/varint/encode.js","node_modules/varint-decoder/node_modules/varint/decode.js","node_modules/varint-decoder/node_modules/varint/length.js","node_modules/ipfs-bitswap/cjs/src/utils/varint-encoder.js","node_modules/ipfs-bitswap/cjs/src/utils/index.js","node_modules/ipfs-bitswap/cjs/src/message/entry.js","node_modules/ipfs-bitswap/cjs/src/wantlist/index.js","node_modules/ipfs-bitswap/cjs/src/wantlist/entry.js","node_modules/ipfs-bitswap/cjs/src/message/message.js","node_modules/ipfs-bitswap/cjs/src/constants.js","node_modules/ipfs-bitswap/cjs/src/want-manager/msg-queue.js","node_modules/just-debounce-it/index.js","node_modules/ipfs-bitswap/cjs/src/network.js","node_modules/ipfs-bitswap/cjs/src/decision-engine/index.js","node_modules/ipfs-bitswap/cjs/src/decision-engine/ledger.js","node_modules/ipfs-bitswap/cjs/src/decision-engine/req-queue.js","node_modules/ipfs-bitswap/cjs/src/utils/sorted-map.js","node_modules/ipfs-bitswap/cjs/src/decision-engine/task-merger.js","node_modules/ipfs-bitswap/cjs/src/notifications.js","node_modules/ipfs-bitswap/cjs/src/stats/index.js","node_modules/ipfs-bitswap/cjs/src/stats/stat.js","node_modules/ipfs-core/cjs/src/block-storage.js","node_modules/blockstore-core/cjs/src/index.js","node_modules/blockstore-core/cjs/src/errors.js","node_modules/blockstore-core/cjs/src/memory.js","node_modules/ipfs-core/cjs/src/components/swarm/index.js","node_modules/ipfs-core/cjs/src/components/swarm/addrs.js","node_modules/ipfs-core/cjs/src/components/swarm/connect.js","node_modules/ipfs-core/cjs/src/components/swarm/disconnect.js","node_modules/ipfs-core/cjs/src/components/swarm/local-addrs.js","node_modules/ipfs-core/cjs/src/components/swarm/peers.js","node_modules/ipfs-core/cjs/src/components/ping.js","node_modules/ipfs-core/cjs/src/components/dht.js","node_modules/ipfs-core/cjs/src/components/pubsub.js","node_modules/hls.js/dist/webpack:/Hls/webpack/universalModuleDefinition","node_modules/hls.js/dist/webpack:/Hls/webpack/bootstrap","node_modules/hls.js/dist/webpack:/Hls/node_modules/eventemitter3/index.js","node_modules/hls.js/dist/webpack:/Hls/node_modules/url-toolkit/src/url-toolkit.js","node_modules/hls.js/dist/webpack:/Hls/node_modules/webworkify-webpack/index.js","node_modules/hls.js/dist/webpack:/Hls/src/crypt/aes-crypto.js","node_modules/hls.js/dist/webpack:/Hls/src/crypt/fast-aes-key.js","node_modules/hls.js/dist/webpack:/Hls/src/crypt/aes-decryptor.js","node_modules/hls.js/dist/webpack:/Hls/src/crypt/decrypter.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/adts.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/aacdemuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/mpegaudio.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/exp-golomb.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/sample-aes.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/tsdemuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/mp3demuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/remux/aac-helper.js","node_modules/hls.js/dist/webpack:/Hls/src/remux/mp4-generator.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/timescale-conversion.ts","node_modules/hls.js/dist/webpack:/Hls/src/remux/mp4-remuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/demuxer-inline.js","node_modules/hls.js/dist/webpack:/Hls/src/remux/passthrough-remuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/demuxer-worker.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/id3.js","node_modules/hls.js/dist/webpack:/Hls/src/demux/mp4demuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/errors.ts","node_modules/hls.js/dist/webpack:/Hls/src/events.js","node_modules/hls.js/dist/webpack:/Hls/src/types/loader.ts","node_modules/hls.js/dist/webpack:/Hls/src/event-handler.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/level-key.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/fragment.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/level.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/attr-list.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/codecs.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/m3u8-parser.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/playlist-loader.ts","node_modules/hls.js/dist/webpack:/Hls/src/loader/fragment-loader.js","node_modules/hls.js/dist/webpack:/Hls/src/loader/key-loader.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/fragment-tracker.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/binary-search.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/buffer-helper.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/mediasource-helper.ts","node_modules/hls.js/dist/webpack:/Hls/src/observer.ts","node_modules/hls.js/dist/webpack:/Hls/src/demux/demuxer.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/level-helper.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/time-ranges.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/discontinuities.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/fragment-finders.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/gap-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/task-loop.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/base-stream-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/stream-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/level-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/texttrack-utils.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/id3-track-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/ewma.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/ewma-bandwidth-estimator.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/abr-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/buffer-controller.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/cap-level-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/fps-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/xhr-loader.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/audio-track-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/audio-stream-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/vttcue.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/vttparser.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/cues.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/cea-608-parser.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/output-filter.ts","node_modules/hls.js/dist/webpack:/Hls/src/utils/webvtt-parser.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/timeline-controller.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/subtitle-track-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/mediakeys-helper.ts","node_modules/hls.js/dist/webpack:/Hls/src/controller/subtitle-stream-controller.js","node_modules/hls.js/dist/webpack:/Hls/src/controller/eme-controller.ts","node_modules/hls.js/dist/webpack:/Hls/src/config.ts","node_modules/hls.js/dist/webpack:/Hls/src/hls.ts","node_modules/hls.js/dist/webpack:/Hls/src/is-supported.ts","node_modules/hls.js/dist/webpack:/Hls/src/polyfills/number.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/get-self-scope.js","node_modules/hls.js/dist/webpack:/Hls/src/utils/logger.js","node_modules/hlsjs-ipfs-loader/src/index.js"],"sourcesContent":["'use strict'\n\nimport { create } from 'ipfs-core'\nimport Hls from 'hls.js'\nimport HlsjsIpfsLoader from 'hlsjs-ipfs-loader'\n\ndocument.addEventListener('DOMContentLoaded', async () => {\n const hash = getUrlParameter('hash')\n const source = getUrlParameter('source')\n const title = getUrlParameter('title')\n const time = getUrlParameter('time')\n setUpContextMenu() // todo move back inside if(hash)\n if (title) {\n document.title = title\n }\n if (hash) {\n document.getElementById('help').style.display = 'none'\n setBodyHeight()\n window.addEventListener('resize', setBodyHeight)\n const video = document.getElementById('video')\n video.style.display = 'block'\n const repoPath = 'ipfs-' + Math.random()\n showStatus('Connecting to IPFS')\n const node = await create({ repo: repoPath })\n showStatus('Connected')\n Hls.DefaultConfig.loader = HlsjsIpfsLoader\n Hls.DefaultConfig.debug = false\n if (Hls.isSupported()) {\n const hls = new Hls()\n hls.config.ipfs = node\n hls.config.ipfsHash = hash\n showStatus('Video loading')\n hls.loadSource(source || 'master.m3u8')\n hls.attachMedia(video)\n hls.on(Hls.Events.MANIFEST_PARSED, () => {\n showStatus('Video loaded', true)\n if (time) {\n video.currentTime = time\n }\n video.play()\n })\n }\n }\n\n function setUpContextMenu() {\n const video = document.getElementById('video')\n const background = document.getElementById('contextBackground')\n const menu = document.getElementById('contextMenu')\n video.oncontextmenu = e => {\n background.classList.toggle('is-hidden')\n menu.style.left = e.pageX + 'px'\n menu.style.top = e.pageY + 'px'\n e.preventDefault()\n }\n background.onclick = e => {\n e.stopPropagation()\n background.classList.toggle('is-hidden')\n }\n const url = `http://ipfsvideo.cc?hash=${\n hash\n }${\n (title && '&title=' + encodeURIComponent(title))||''\n }${\n (source && '&source=' + encodeURIComponent(source))||''\n }`\n document.getElementById('contextMenu-url').onclick = e => {\n navigator.clipboard.writeText(url)\n }\n document.getElementById('contextMenu-urlWithTime').onclick = e => {\n navigator.clipboard.writeText(`${url}&time=${Math.round(video.currentTime)}`)\n }\n }\n})\n\nfunction getUrlParameter(name) {\n name = name.replace(/[\\[]/, '\\\\[').replace(/[\\]]/, '\\\\]')\n var regex = new RegExp('[\\\\?&]' + name + '=([^&#]*)')\n var results = regex.exec(location.search)\n return results === null ? null : decodeURIComponent(results[1].replace(/\\+/g, ' '))\n}\n\nfunction showStatus(message, hide = false) {\n const status = document.getElementById('status')\n status.classList.toggle('is-hiding', hide)\n status.innerText = message\n}\n\nfunction setBodyHeight() {\n document.body.style.height = window.innerHeight + 'px'\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('./components/index.js');\nvar crypto$1 = require('libp2p-crypto');\nvar isIpfs = require('is-ipfs');\nvar cid = require('multiformats/cid');\nvar multiaddr$1 = require('multiaddr');\nvar PeerId$1 = require('peer-id');\nvar globSourceImport = require('ipfs-utils/src/files/glob-source.js');\nvar urlSourceImport = require('ipfs-utils/src/files/url-source.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar crypto__default = /*#__PURE__*/_interopDefaultLegacy(crypto$1);\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId$1);\nvar globSourceImport__default = /*#__PURE__*/_interopDefaultLegacy(globSourceImport);\nvar urlSourceImport__default = /*#__PURE__*/_interopDefaultLegacy(urlSourceImport);\n\nconst create = index.create;\nconst crypto = crypto__default['default'];\nconst isIPFS = isIpfs__default['default'];\nconst CID = cid.CID;\nconst multiaddr = multiaddr$1.Multiaddr;\nconst PeerId = PeerId__default['default'];\nconst globSource = globSourceImport__default['default'];\nconst urlSource = urlSourceImport__default['default'];\n\nexports.CID = CID;\nexports.PeerId = PeerId;\nexports.create = create;\nexports.crypto = crypto;\nexports.globSource = globSource;\nexports.isIPFS = isIPFS;\nexports.multiaddr = multiaddr;\nexports.urlSource = urlSource;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mergeOpts = require('merge-options');\nvar env_js = require('ipfs-utils/src/env.js');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dagPB = require('@ipld/dag-pb');\nvar dagCBOR = require('@ipld/dag-cbor');\nvar identity = require('multiformats/hashes/identity');\nvar basics = require('multiformats/basics');\nvar initAssets = require('ipfs-core-config/init-assets');\nvar errors = require('../errors.js');\nvar fromString = require('uint8arrays/from-string');\nvar start = require('./start.js');\nvar stop = require('./stop.js');\nvar dns = require('./dns.js');\nvar isOnline = require('./is-online.js');\nvar resolve = require('./resolve.js');\nvar index = require('./pin/index.js');\nvar ipns = require('./ipns.js');\nvar index$2 = require('./name/index.js');\nvar index$4 = require('./refs/index.js');\nvar local = require('./refs/local.js');\nvar index$6 = require('./bitswap/index.js');\nvar index$7 = require('./bootstrap/index.js');\nvar index$1 = require('./block/index.js');\nvar root = require('./root.js');\nvar version = require('./version.js');\nvar id = require('./id.js');\nvar index$8 = require('./config/index.js');\nvar index$3 = require('./dag/index.js');\nvar preload = require('../preload.js');\nvar mfsPreload = require('../mfs-preload.js');\nvar index$5 = require('./files/index.js');\nvar index$9 = require('./key/index.js');\nvar index$a = require('./object/index.js');\nvar index$b = require('./repo/index.js');\nvar index$c = require('./stats/index.js');\nvar storage = require('./storage.js');\nvar network = require('./network.js');\nvar service = require('../utils/service.js');\nvar index$d = require('./swarm/index.js');\nvar ping = require('./ping.js');\nvar dht = require('./dht.js');\nvar pubsub = require('./pubsub.js');\nvar multicodecs = require('ipfs-core-utils/multicodecs');\nvar multihashes = require('ipfs-core-utils/multihashes');\nvar multibases = require('ipfs-core-utils/multibases');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar dagCBOR__namespace = /*#__PURE__*/_interopNamespace(dagCBOR);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs');\nclass IPFS {\n constructor({print, storage, codecs, options}) {\n const {peerId, repo, keychain} = storage;\n const network$1 = service.Service.create(network.Network);\n const preload$1 = preload.createPreloader(options.preload);\n const dns$1 = dns.createDns();\n const isOnline$1 = isOnline.createIsOnline({ network: network$1 });\n const ipns$1 = new ipns.IPNSAPI(options);\n const multihashHashers = Object.values(basics.hashes);\n (options.ipld && options.ipld.hashers ? options.ipld.hashers : []).forEach(hasher => multihashHashers.push(hasher));\n this.hashers = new multihashes.Multihashes({\n hashers: multihashHashers,\n loadHasher: options.ipld && options.ipld.loadHasher\n });\n const multibaseCodecs = Object.values(basics.bases);\n (options.ipld && options.ipld.bases ? options.ipld.bases : []).forEach(base => multibaseCodecs.push(base));\n this.bases = new multibases.Multibases({\n bases: multibaseCodecs,\n loadBase: options.ipld && options.ipld.loadBase\n });\n const pin = new index.PinAPI({\n repo,\n codecs\n });\n const block = new index$1.BlockAPI({\n codecs,\n hashers: this.hashers,\n preload: preload$1,\n repo\n });\n const name = new index$2.NameAPI({\n dns: dns$1,\n ipns: ipns$1,\n repo,\n codecs,\n peerId,\n isOnline: isOnline$1,\n keychain,\n options\n });\n const resolve$1 = resolve.createResolve({\n repo,\n codecs,\n bases: this.bases,\n name\n });\n const dag = new index$3.DagAPI({\n repo,\n codecs,\n hashers: this.hashers,\n preload: preload$1\n });\n const refs = Object.assign(index$4.createRefs({\n repo,\n codecs,\n resolve: resolve$1,\n preload: preload$1\n }), { local: local.createLocal({ repo: storage.repo }) });\n const {add, addAll, cat, get, ls} = new root.RootAPI({\n preload: preload$1,\n repo,\n options: options.EXPERIMENTAL\n });\n const files = index$5.createFiles({\n repo,\n preload: preload$1,\n hashers: this.hashers,\n options\n });\n const mfsPreload$1 = mfsPreload.createMfsPreloader({\n files,\n preload: preload$1,\n options: options.preload\n });\n this.preload = preload$1;\n this.name = name;\n this.ipns = ipns$1;\n this.pin = pin;\n this.resolve = resolve$1;\n this.block = block;\n this.refs = refs;\n this.start = start.createStart({\n network: network$1,\n peerId,\n repo,\n preload: preload$1,\n ipns: ipns$1,\n mfsPreload: mfsPreload$1,\n print,\n keychain,\n options\n });\n this.stop = stop.createStop({\n network: network$1,\n preload: preload$1,\n mfsPreload: mfsPreload$1,\n ipns: ipns$1,\n repo\n });\n this.dht = dht.createDht({\n network: network$1,\n repo\n });\n this.pubsub = pubsub.createPubsub({\n network: network$1,\n config: options.config\n });\n this.dns = dns$1;\n this.isOnline = isOnline$1;\n this.id = id.createId({\n network: network$1,\n peerId\n });\n this.version = version.createVersion({ repo });\n this.bitswap = new index$6.BitswapAPI({ network: network$1 });\n this.bootstrap = new index$7.BootstrapAPI({ repo });\n this.config = index$8.createConfig({ repo });\n this.ping = ping.createPing({ network: network$1 });\n this.add = add;\n this.addAll = addAll;\n this.cat = cat;\n this.get = get;\n this.ls = ls;\n this.dag = dag;\n this.files = files;\n this.key = new index$9.KeyAPI({ keychain });\n this.object = new index$a.ObjectAPI({\n preload: preload$1,\n codecs,\n repo\n });\n this.repo = new index$b.RepoAPI({\n repo,\n hashers: this.hashers\n });\n this.stats = new index$c.StatsAPI({\n repo,\n network: network$1\n });\n this.swarm = new index$d.SwarmAPI({ network: network$1 });\n Object.defineProperty(this, 'libp2p', {\n get() {\n const net = network$1.try();\n return net ? net.libp2p : undefined;\n }\n });\n const notImplemented = () => Promise.reject(errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED'));\n const notImplementedIter = async function* () {\n throw errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED');\n };\n this.commands = notImplemented;\n this.diag = {\n cmds: notImplemented,\n net: notImplemented,\n sys: notImplemented\n };\n this.log = {\n level: notImplemented,\n ls: notImplemented,\n tail: notImplementedIter\n };\n this.mount = notImplemented;\n this.codecs = codecs;\n }\n async init() {\n throw new errors.AlreadyInitializedError();\n }\n}\nconst addEmptyDir = async ipfs => {\n const buf = dagPB__namespace.encode({\n Data: new ipfsUnixfs.UnixFS({ type: 'directory' }).marshal(),\n Links: []\n });\n const cid = await ipfs.block.put(buf, {\n mhtype: 'sha2-256',\n format: 'dag-pb'\n });\n await ipfs.pin.add(cid);\n return cid;\n};\nconst getDefaultOptions = () => ({\n start: true,\n EXPERIMENTAL: {},\n preload: {\n enabled: !env_js.isTest,\n addresses: [\n '/dns4/node0.preload.ipfs.io/https',\n '/dns4/node1.preload.ipfs.io/https',\n '/dns4/node2.preload.ipfs.io/https',\n '/dns4/node3.preload.ipfs.io/https'\n ]\n }\n});\nasync function create(options = {}) {\n options = mergeOptions(getDefaultOptions(), options);\n const initOptions = options.init || {};\n const id = {\n name: identity.identity.name,\n code: identity.identity.code,\n encode: id => id,\n decode: id => id\n };\n const blockCodecs = Object.values(basics.codecs);\n [\n dagPB__namespace,\n dagCBOR__namespace,\n id\n ].concat(options.ipld && options.ipld.codecs || []).forEach(codec => blockCodecs.push(codec));\n const multicodecs$1 = new multicodecs.Multicodecs({\n codecs: blockCodecs,\n loadCodec: options.ipld && options.ipld.loadCodec\n });\n const print = options.silent ? log : console.log;\n const storage$1 = await storage.Storage.start(print, multicodecs$1, options);\n const config = await storage$1.repo.config.getAll();\n const ipfs = new IPFS({\n storage: storage$1,\n print,\n codecs: multicodecs$1,\n options: {\n ...options,\n config\n }\n });\n await ipfs.preload.start();\n ipfs.ipns.startOffline(storage$1);\n if (storage$1.isNew && !initOptions.emptyRepo) {\n const cid = await addEmptyDir(ipfs);\n log('adding default assets');\n await initAssets.initAssets({\n addAll: ipfs.addAll,\n print\n });\n log('initializing IPNS keyspace');\n await ipfs.ipns.initializeKeyspace(storage$1.peerId.privKey, fromString.fromString(`/ipfs/${ cid }`));\n }\n if (options.start !== false) {\n await ipfs.start();\n }\n return ipfs;\n}\n\nexports.create = create;\n","'use strict';\nconst isOptionObject = require('is-plain-obj');\n\nconst {hasOwnProperty} = Object.prototype;\nconst {propertyIsEnumerable} = Object;\nconst defineProperty = (object, name, value) => Object.defineProperty(object, name, {\n\tvalue,\n\twritable: true,\n\tenumerable: true,\n\tconfigurable: true\n});\n\nconst globalThis = this;\nconst defaultMergeOptions = {\n\tconcatArrays: false,\n\tignoreUndefined: false\n};\n\nconst getEnumerableOwnPropertyKeys = value => {\n\tconst keys = [];\n\n\tfor (const key in value) {\n\t\tif (hasOwnProperty.call(value, key)) {\n\t\t\tkeys.push(key);\n\t\t}\n\t}\n\n\t/* istanbul ignore else */\n\tif (Object.getOwnPropertySymbols) {\n\t\tconst symbols = Object.getOwnPropertySymbols(value);\n\n\t\tfor (const symbol of symbols) {\n\t\t\tif (propertyIsEnumerable.call(value, symbol)) {\n\t\t\t\tkeys.push(symbol);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn keys;\n};\n\nfunction clone(value) {\n\tif (Array.isArray(value)) {\n\t\treturn cloneArray(value);\n\t}\n\n\tif (isOptionObject(value)) {\n\t\treturn cloneOptionObject(value);\n\t}\n\n\treturn value;\n}\n\nfunction cloneArray(array) {\n\tconst result = array.slice(0, 0);\n\n\tgetEnumerableOwnPropertyKeys(array).forEach(key => {\n\t\tdefineProperty(result, key, clone(array[key]));\n\t});\n\n\treturn result;\n}\n\nfunction cloneOptionObject(object) {\n\tconst result = Object.getPrototypeOf(object) === null ? Object.create(null) : {};\n\n\tgetEnumerableOwnPropertyKeys(object).forEach(key => {\n\t\tdefineProperty(result, key, clone(object[key]));\n\t});\n\n\treturn result;\n}\n\n/**\n * @param {*} merged already cloned\n * @param {*} source something to merge\n * @param {string[]} keys keys to merge\n * @param {Object} config Config Object\n * @returns {*} cloned Object\n */\nconst mergeKeys = (merged, source, keys, config) => {\n\tkeys.forEach(key => {\n\t\tif (typeof source[key] === 'undefined' && config.ignoreUndefined) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Do not recurse into prototype chain of merged\n\t\tif (key in merged && merged[key] !== Object.getPrototypeOf(merged)) {\n\t\t\tdefineProperty(merged, key, merge(merged[key], source[key], config));\n\t\t} else {\n\t\t\tdefineProperty(merged, key, clone(source[key]));\n\t\t}\n\t});\n\n\treturn merged;\n};\n\n/**\n * @param {*} merged already cloned\n * @param {*} source something to merge\n * @param {Object} config Config Object\n * @returns {*} cloned Object\n *\n * see [Array.prototype.concat ( ...arguments )](http://www.ecma-international.org/ecma-262/6.0/#sec-array.prototype.concat)\n */\nconst concatArrays = (merged, source, config) => {\n\tlet result = merged.slice(0, 0);\n\tlet resultIndex = 0;\n\n\t[merged, source].forEach(array => {\n\t\tconst indices = [];\n\n\t\t// `result.concat(array)` with cloning\n\t\tfor (let k = 0; k < array.length; k++) {\n\t\t\tif (!hasOwnProperty.call(array, k)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tindices.push(String(k));\n\n\t\t\tif (array === merged) {\n\t\t\t\t// Already cloned\n\t\t\t\tdefineProperty(result, resultIndex++, array[k]);\n\t\t\t} else {\n\t\t\t\tdefineProperty(result, resultIndex++, clone(array[k]));\n\t\t\t}\n\t\t}\n\n\t\t// Merge non-index keys\n\t\tresult = mergeKeys(result, array, getEnumerableOwnPropertyKeys(array).filter(key => !indices.includes(key)), config);\n\t});\n\n\treturn result;\n};\n\n/**\n * @param {*} merged already cloned\n * @param {*} source something to merge\n * @param {Object} config Config Object\n * @returns {*} cloned Object\n */\nfunction merge(merged, source, config) {\n\tif (config.concatArrays && Array.isArray(merged) && Array.isArray(source)) {\n\t\treturn concatArrays(merged, source, config);\n\t}\n\n\tif (!isOptionObject(source) || !isOptionObject(merged)) {\n\t\treturn clone(source);\n\t}\n\n\treturn mergeKeys(merged, source, getEnumerableOwnPropertyKeys(source), config);\n}\n\nmodule.exports = function (...options) {\n\tconst config = merge(clone(defaultMergeOptions), (this !== globalThis && this) || {}, defaultMergeOptions);\n\tlet merged = {_: {}};\n\n\tfor (const option of options) {\n\t\tif (option === undefined) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (!isOptionObject(option)) {\n\t\t\tthrow new TypeError('`' + option + '` is not an Option Object');\n\t\t}\n\n\t\tmerged = merge(merged, {_: option}, config);\n\t}\n\n\treturn merged._;\n};\n","'use strict';\n\nmodule.exports = value => {\n\tif (Object.prototype.toString.call(value) !== '[object Object]') {\n\t\treturn false;\n\t}\n\n\tconst prototype = Object.getPrototypeOf(value);\n\treturn prototype === null || prototype === Object.prototype;\n};\n","'use strict'\nconst isElectron = require('is-electron')\n\nconst IS_ENV_WITH_DOM = typeof window === 'object' && typeof document === 'object' && document.nodeType === 9\n// @ts-ignore\nconst IS_ELECTRON = isElectron()\nconst IS_BROWSER = IS_ENV_WITH_DOM && !IS_ELECTRON\nconst IS_ELECTRON_MAIN = IS_ELECTRON && !IS_ENV_WITH_DOM\nconst IS_ELECTRON_RENDERER = IS_ELECTRON && IS_ENV_WITH_DOM\nconst IS_NODE = typeof require === 'function' && typeof process !== 'undefined' && typeof process.release !== 'undefined' && process.release.name === 'node' && !IS_ELECTRON\n// @ts-ignore - we either ignore worker scope or dom scope\nconst IS_WEBWORKER = typeof importScripts === 'function' && typeof self !== 'undefined' && typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope\nconst IS_TEST = typeof process !== 'undefined' && typeof process.env !== 'undefined' && process.env.NODE_ENV === 'test'\nconst IS_REACT_NATIVE = typeof navigator !== 'undefined' && navigator.product === 'ReactNative'\n\nmodule.exports = {\n isTest: IS_TEST,\n isElectron: IS_ELECTRON,\n isElectronMain: IS_ELECTRON_MAIN,\n isElectronRenderer: IS_ELECTRON_RENDERER,\n isNode: IS_NODE,\n /**\n * Detects browser main thread **NOT** web worker or service worker\n */\n isBrowser: IS_BROWSER,\n isWebWorker: IS_WEBWORKER,\n isEnvWithDom: IS_ENV_WITH_DOM,\n isReactNative: IS_REACT_NATIVE\n}\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","// https://github.com/electron/electron/issues/2288\nfunction isElectron() {\n // Renderer process\n if (typeof window !== 'undefined' && typeof window.process === 'object' && window.process.type === 'renderer') {\n return true;\n }\n\n // Main process\n if (typeof process !== 'undefined' && typeof process.versions === 'object' && !!process.versions.electron) {\n return true;\n }\n\n // Detect the user agent when the `nodeIntegration` option is set to false\n if (typeof navigator === 'object' && typeof navigator.userAgent === 'string' && navigator.userAgent.indexOf('Electron') >= 0) {\n return true;\n }\n\n return false;\n}\n\nmodule.exports = isElectron;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) && parseInt(RegExp.$1, 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tlet i;\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n\t\tconst len = split.length;\n\n\t\tfor (i = 0; i < len; i++) {\n\t\t\tif (!split[i]) {\n\t\t\t\t// ignore empty strings\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tnamespaces = split[i].replace(/\\*/g, '.*?');\n\n\t\t\tif (namespaces[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(new RegExp('^' + namespaces.substr(1) + '$'));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(new RegExp('^' + namespaces + '$'));\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names.map(toNamespace),\n\t\t\t...createDebug.skips.map(toNamespace).map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tif (name[name.length - 1] === '*') {\n\t\t\treturn true;\n\t\t}\n\n\t\tlet i;\n\t\tlet len;\n\n\t\tfor (i = 0, len = createDebug.skips.length; i < len; i++) {\n\t\t\tif (createDebug.skips[i].test(name)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (i = 0, len = createDebug.names.length; i < len; i++) {\n\t\t\tif (createDebug.names[i].test(name)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Convert regexp to namespace\n\t*\n\t* @param {RegExp} regxep\n\t* @return {String} namespace\n\t* @api private\n\t*/\n\tfunction toNamespace(regexp) {\n\t\treturn regexp.toString()\n\t\t\t.substring(2, regexp.toString().length - 2)\n\t\t\t.replace(/\\.\\*\\?$/, '*');\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function(val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","'use strict';\n\n/**\n * @typedef {{ [key: string]: any }} Extensions\n * @typedef {Error} Err\n * @property {string} message\n */\n\n/**\n *\n * @param {Error} obj\n * @param {Extensions} props\n * @returns {Error & Extensions}\n */\nfunction assign(obj, props) {\n for (const key in props) {\n Object.defineProperty(obj, key, {\n value: props[key],\n enumerable: true,\n configurable: true,\n });\n }\n\n return obj;\n}\n\n/**\n *\n * @param {any} err - An Error\n * @param {string|Extensions} code - A string code or props to set on the error\n * @param {Extensions} [props] - Props to set on the error\n * @returns {Error & Extensions}\n */\nfunction createError(err, code, props) {\n if (!err || typeof err === 'string') {\n throw new TypeError('Please pass an Error to err-code');\n }\n\n if (!props) {\n props = {};\n }\n\n if (typeof code === 'object') {\n props = code;\n code = '';\n }\n\n if (code) {\n props.code = code;\n }\n\n try {\n return assign(err, props);\n } catch (_) {\n props.message = err.message;\n props.stack = err.stack;\n\n const ErrClass = function () {};\n\n ErrClass.prototype = Object.create(Object.getPrototypeOf(err));\n\n // @ts-ignore\n const output = assign(new ErrClass(), props);\n\n return output;\n }\n}\n\nmodule.exports = createError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errcode = require('err-code');\nvar unixfs = require('./unixfs.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\n\nconst PBData = unixfs.Data;\nconst types = [\n 'raw',\n 'directory',\n 'file',\n 'metadata',\n 'symlink',\n 'hamt-sharded-directory'\n];\nconst dirTypes = [\n 'directory',\n 'hamt-sharded-directory'\n];\nconst DEFAULT_FILE_MODE = parseInt('0644', 8);\nconst DEFAULT_DIRECTORY_MODE = parseInt('0755', 8);\nfunction parseMode(mode) {\n if (mode == null) {\n return undefined;\n }\n if (typeof mode === 'number') {\n return mode & 4095;\n }\n mode = mode.toString();\n if (mode.substring(0, 1) === '0') {\n return parseInt(mode, 8) & 4095;\n }\n return parseInt(mode, 10) & 4095;\n}\nfunction parseMtime(input) {\n if (input == null) {\n return undefined;\n }\n let mtime;\n if (input.secs != null) {\n mtime = {\n secs: input.secs,\n nsecs: input.nsecs\n };\n }\n if (input.Seconds != null) {\n mtime = {\n secs: input.Seconds,\n nsecs: input.FractionalNanoseconds\n };\n }\n if (Array.isArray(input)) {\n mtime = {\n secs: input[0],\n nsecs: input[1]\n };\n }\n if (input instanceof Date) {\n const ms = input.getTime();\n const secs = Math.floor(ms / 1000);\n mtime = {\n secs: secs,\n nsecs: (ms - secs * 1000) * 1000\n };\n }\n if (!Object.prototype.hasOwnProperty.call(mtime, 'secs')) {\n return undefined;\n }\n if (mtime != null && mtime.nsecs != null && (mtime.nsecs < 0 || mtime.nsecs > 999999999)) {\n throw errcode__default['default'](new Error('mtime-nsecs must be within the range [0,999999999]'), 'ERR_INVALID_MTIME_NSECS');\n }\n return mtime;\n}\nclass UnixFS {\n static unmarshal(marshaled) {\n const message = PBData.decode(marshaled);\n const decoded = PBData.toObject(message, {\n defaults: false,\n arrays: true,\n longs: Number,\n objects: false\n });\n const data = new UnixFS({\n type: types[decoded.Type],\n data: decoded.Data,\n blockSizes: decoded.blocksizes,\n mode: decoded.mode,\n mtime: decoded.mtime ? {\n secs: decoded.mtime.Seconds,\n nsecs: decoded.mtime.FractionalNanoseconds\n } : undefined\n });\n data._originalMode = decoded.mode || 0;\n return data;\n }\n constructor(options = { type: 'file' }) {\n const {type, data, blockSizes, hashType, fanout, mtime, mode} = options;\n if (type && !types.includes(type)) {\n throw errcode__default['default'](new Error('Type: ' + type + ' is not valid'), 'ERR_INVALID_TYPE');\n }\n this.type = type || 'file';\n this.data = data;\n this.hashType = hashType;\n this.fanout = fanout;\n this.blockSizes = blockSizes || [];\n this._originalMode = 0;\n this.mode = parseMode(mode);\n if (mtime) {\n this.mtime = parseMtime(mtime);\n if (this.mtime && !this.mtime.nsecs) {\n this.mtime.nsecs = 0;\n }\n }\n }\n set mode(mode) {\n this._mode = this.isDirectory() ? DEFAULT_DIRECTORY_MODE : DEFAULT_FILE_MODE;\n const parsedMode = parseMode(mode);\n if (parsedMode !== undefined) {\n this._mode = parsedMode;\n }\n }\n get mode() {\n return this._mode;\n }\n isDirectory() {\n return Boolean(this.type && dirTypes.includes(this.type));\n }\n addBlockSize(size) {\n this.blockSizes.push(size);\n }\n removeBlockSize(index) {\n this.blockSizes.splice(index, 1);\n }\n fileSize() {\n if (this.isDirectory()) {\n return 0;\n }\n let sum = 0;\n this.blockSizes.forEach(size => {\n sum += size;\n });\n if (this.data) {\n sum += this.data.length;\n }\n return sum;\n }\n marshal() {\n let type;\n switch (this.type) {\n case 'raw':\n type = PBData.DataType.Raw;\n break;\n case 'directory':\n type = PBData.DataType.Directory;\n break;\n case 'file':\n type = PBData.DataType.File;\n break;\n case 'metadata':\n type = PBData.DataType.Metadata;\n break;\n case 'symlink':\n type = PBData.DataType.Symlink;\n break;\n case 'hamt-sharded-directory':\n type = PBData.DataType.HAMTShard;\n break;\n default:\n throw errcode__default['default'](new Error('Type: ' + type + ' is not valid'), 'ERR_INVALID_TYPE');\n }\n let data = this.data;\n if (!this.data || !this.data.length) {\n data = undefined;\n }\n let mode;\n if (this.mode != null) {\n mode = this._originalMode & 4294963200 | (parseMode(this.mode) || 0);\n if (mode === DEFAULT_FILE_MODE && !this.isDirectory()) {\n mode = undefined;\n }\n if (mode === DEFAULT_DIRECTORY_MODE && this.isDirectory()) {\n mode = undefined;\n }\n }\n let mtime;\n if (this.mtime != null) {\n const parsed = parseMtime(this.mtime);\n if (parsed) {\n mtime = {\n Seconds: parsed.secs,\n FractionalNanoseconds: parsed.nsecs\n };\n if (mtime.FractionalNanoseconds === 0) {\n delete mtime.FractionalNanoseconds;\n }\n }\n }\n const pbData = {\n Type: type,\n Data: data,\n filesize: this.isDirectory() ? undefined : this.fileSize(),\n blocksizes: this.blockSizes,\n hashType: this.hashType,\n fanout: this.fanout,\n mode,\n mtime\n };\n return PBData.encode(pbData).finish();\n }\n}\n\nexports.UnixFS = UnixFS;\nexports.parseMode = parseMode;\nexports.parseMtime = parseMtime;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar $protobuf = require('protobufjs/minimal.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar $protobuf__default = /*#__PURE__*/_interopDefaultLegacy($protobuf);\n\nconst $Reader = $protobuf__default['default'].Reader, $Writer = $protobuf__default['default'].Writer, $util = $protobuf__default['default'].util;\nconst $root = $protobuf__default['default'].roots['ipfs-unixfs'] || ($protobuf__default['default'].roots['ipfs-unixfs'] = {});\nconst Data = $root.Data = (() => {\n function Data(p) {\n this.blocksizes = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Data.prototype.Type = 0;\n Data.prototype.Data = $util.newBuffer([]);\n Data.prototype.filesize = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n Data.prototype.blocksizes = $util.emptyArray;\n Data.prototype.hashType = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n Data.prototype.fanout = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n Data.prototype.mode = 0;\n Data.prototype.mtime = null;\n Data.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(8).int32(m.Type);\n if (m.Data != null && Object.hasOwnProperty.call(m, 'Data'))\n w.uint32(18).bytes(m.Data);\n if (m.filesize != null && Object.hasOwnProperty.call(m, 'filesize'))\n w.uint32(24).uint64(m.filesize);\n if (m.blocksizes != null && m.blocksizes.length) {\n for (var i = 0; i < m.blocksizes.length; ++i)\n w.uint32(32).uint64(m.blocksizes[i]);\n }\n if (m.hashType != null && Object.hasOwnProperty.call(m, 'hashType'))\n w.uint32(40).uint64(m.hashType);\n if (m.fanout != null && Object.hasOwnProperty.call(m, 'fanout'))\n w.uint32(48).uint64(m.fanout);\n if (m.mode != null && Object.hasOwnProperty.call(m, 'mode'))\n w.uint32(56).uint32(m.mode);\n if (m.mtime != null && Object.hasOwnProperty.call(m, 'mtime'))\n $root.UnixTime.encode(m.mtime, w.uint32(66).fork()).ldelim();\n return w;\n };\n Data.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Data();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.Type = r.int32();\n break;\n case 2:\n m.Data = r.bytes();\n break;\n case 3:\n m.filesize = r.uint64();\n break;\n case 4:\n if (!(m.blocksizes && m.blocksizes.length))\n m.blocksizes = [];\n if ((t & 7) === 2) {\n var c2 = r.uint32() + r.pos;\n while (r.pos < c2)\n m.blocksizes.push(r.uint64());\n } else\n m.blocksizes.push(r.uint64());\n break;\n case 5:\n m.hashType = r.uint64();\n break;\n case 6:\n m.fanout = r.uint64();\n break;\n case 7:\n m.mode = r.uint32();\n break;\n case 8:\n m.mtime = $root.UnixTime.decode(r, r.uint32());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty('Type'))\n throw $util.ProtocolError('missing required \\'Type\\'', { instance: m });\n return m;\n };\n Data.fromObject = function fromObject(d) {\n if (d instanceof $root.Data)\n return d;\n var m = new $root.Data();\n switch (d.Type) {\n case 'Raw':\n case 0:\n m.Type = 0;\n break;\n case 'Directory':\n case 1:\n m.Type = 1;\n break;\n case 'File':\n case 2:\n m.Type = 2;\n break;\n case 'Metadata':\n case 3:\n m.Type = 3;\n break;\n case 'Symlink':\n case 4:\n m.Type = 4;\n break;\n case 'HAMTShard':\n case 5:\n m.Type = 5;\n break;\n }\n if (d.Data != null) {\n if (typeof d.Data === 'string')\n $util.base64.decode(d.Data, m.Data = $util.newBuffer($util.base64.length(d.Data)), 0);\n else if (d.Data.length)\n m.Data = d.Data;\n }\n if (d.filesize != null) {\n if ($util.Long)\n (m.filesize = $util.Long.fromValue(d.filesize)).unsigned = true;\n else if (typeof d.filesize === 'string')\n m.filesize = parseInt(d.filesize, 10);\n else if (typeof d.filesize === 'number')\n m.filesize = d.filesize;\n else if (typeof d.filesize === 'object')\n m.filesize = new $util.LongBits(d.filesize.low >>> 0, d.filesize.high >>> 0).toNumber(true);\n }\n if (d.blocksizes) {\n if (!Array.isArray(d.blocksizes))\n throw TypeError('.Data.blocksizes: array expected');\n m.blocksizes = [];\n for (var i = 0; i < d.blocksizes.length; ++i) {\n if ($util.Long)\n (m.blocksizes[i] = $util.Long.fromValue(d.blocksizes[i])).unsigned = true;\n else if (typeof d.blocksizes[i] === 'string')\n m.blocksizes[i] = parseInt(d.blocksizes[i], 10);\n else if (typeof d.blocksizes[i] === 'number')\n m.blocksizes[i] = d.blocksizes[i];\n else if (typeof d.blocksizes[i] === 'object')\n m.blocksizes[i] = new $util.LongBits(d.blocksizes[i].low >>> 0, d.blocksizes[i].high >>> 0).toNumber(true);\n }\n }\n if (d.hashType != null) {\n if ($util.Long)\n (m.hashType = $util.Long.fromValue(d.hashType)).unsigned = true;\n else if (typeof d.hashType === 'string')\n m.hashType = parseInt(d.hashType, 10);\n else if (typeof d.hashType === 'number')\n m.hashType = d.hashType;\n else if (typeof d.hashType === 'object')\n m.hashType = new $util.LongBits(d.hashType.low >>> 0, d.hashType.high >>> 0).toNumber(true);\n }\n if (d.fanout != null) {\n if ($util.Long)\n (m.fanout = $util.Long.fromValue(d.fanout)).unsigned = true;\n else if (typeof d.fanout === 'string')\n m.fanout = parseInt(d.fanout, 10);\n else if (typeof d.fanout === 'number')\n m.fanout = d.fanout;\n else if (typeof d.fanout === 'object')\n m.fanout = new $util.LongBits(d.fanout.low >>> 0, d.fanout.high >>> 0).toNumber(true);\n }\n if (d.mode != null) {\n m.mode = d.mode >>> 0;\n }\n if (d.mtime != null) {\n if (typeof d.mtime !== 'object')\n throw TypeError('.Data.mtime: object expected');\n m.mtime = $root.UnixTime.fromObject(d.mtime);\n }\n return m;\n };\n Data.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.blocksizes = [];\n }\n if (o.defaults) {\n d.Type = o.enums === String ? 'Raw' : 0;\n if (o.bytes === String)\n d.Data = '';\n else {\n d.Data = [];\n if (o.bytes !== Array)\n d.Data = $util.newBuffer(d.Data);\n }\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.filesize = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.filesize = o.longs === String ? '0' : 0;\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.hashType = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.hashType = o.longs === String ? '0' : 0;\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.fanout = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.fanout = o.longs === String ? '0' : 0;\n d.mode = 0;\n d.mtime = null;\n }\n if (m.Type != null && m.hasOwnProperty('Type')) {\n d.Type = o.enums === String ? $root.Data.DataType[m.Type] : m.Type;\n }\n if (m.Data != null && m.hasOwnProperty('Data')) {\n d.Data = o.bytes === String ? $util.base64.encode(m.Data, 0, m.Data.length) : o.bytes === Array ? Array.prototype.slice.call(m.Data) : m.Data;\n }\n if (m.filesize != null && m.hasOwnProperty('filesize')) {\n if (typeof m.filesize === 'number')\n d.filesize = o.longs === String ? String(m.filesize) : m.filesize;\n else\n d.filesize = o.longs === String ? $util.Long.prototype.toString.call(m.filesize) : o.longs === Number ? new $util.LongBits(m.filesize.low >>> 0, m.filesize.high >>> 0).toNumber(true) : m.filesize;\n }\n if (m.blocksizes && m.blocksizes.length) {\n d.blocksizes = [];\n for (var j = 0; j < m.blocksizes.length; ++j) {\n if (typeof m.blocksizes[j] === 'number')\n d.blocksizes[j] = o.longs === String ? String(m.blocksizes[j]) : m.blocksizes[j];\n else\n d.blocksizes[j] = o.longs === String ? $util.Long.prototype.toString.call(m.blocksizes[j]) : o.longs === Number ? new $util.LongBits(m.blocksizes[j].low >>> 0, m.blocksizes[j].high >>> 0).toNumber(true) : m.blocksizes[j];\n }\n }\n if (m.hashType != null && m.hasOwnProperty('hashType')) {\n if (typeof m.hashType === 'number')\n d.hashType = o.longs === String ? String(m.hashType) : m.hashType;\n else\n d.hashType = o.longs === String ? $util.Long.prototype.toString.call(m.hashType) : o.longs === Number ? new $util.LongBits(m.hashType.low >>> 0, m.hashType.high >>> 0).toNumber(true) : m.hashType;\n }\n if (m.fanout != null && m.hasOwnProperty('fanout')) {\n if (typeof m.fanout === 'number')\n d.fanout = o.longs === String ? String(m.fanout) : m.fanout;\n else\n d.fanout = o.longs === String ? $util.Long.prototype.toString.call(m.fanout) : o.longs === Number ? new $util.LongBits(m.fanout.low >>> 0, m.fanout.high >>> 0).toNumber(true) : m.fanout;\n }\n if (m.mode != null && m.hasOwnProperty('mode')) {\n d.mode = m.mode;\n }\n if (m.mtime != null && m.hasOwnProperty('mtime')) {\n d.mtime = $root.UnixTime.toObject(m.mtime, o);\n }\n return d;\n };\n Data.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default['default'].util.toJSONOptions);\n };\n Data.DataType = function () {\n const valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = 'Raw'] = 0;\n values[valuesById[1] = 'Directory'] = 1;\n values[valuesById[2] = 'File'] = 2;\n values[valuesById[3] = 'Metadata'] = 3;\n values[valuesById[4] = 'Symlink'] = 4;\n values[valuesById[5] = 'HAMTShard'] = 5;\n return values;\n }();\n return Data;\n})();\nconst UnixTime = $root.UnixTime = (() => {\n function UnixTime(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n UnixTime.prototype.Seconds = $util.Long ? $util.Long.fromBits(0, 0, false) : 0;\n UnixTime.prototype.FractionalNanoseconds = 0;\n UnixTime.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(8).int64(m.Seconds);\n if (m.FractionalNanoseconds != null && Object.hasOwnProperty.call(m, 'FractionalNanoseconds'))\n w.uint32(21).fixed32(m.FractionalNanoseconds);\n return w;\n };\n UnixTime.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.UnixTime();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.Seconds = r.int64();\n break;\n case 2:\n m.FractionalNanoseconds = r.fixed32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty('Seconds'))\n throw $util.ProtocolError('missing required \\'Seconds\\'', { instance: m });\n return m;\n };\n UnixTime.fromObject = function fromObject(d) {\n if (d instanceof $root.UnixTime)\n return d;\n var m = new $root.UnixTime();\n if (d.Seconds != null) {\n if ($util.Long)\n (m.Seconds = $util.Long.fromValue(d.Seconds)).unsigned = false;\n else if (typeof d.Seconds === 'string')\n m.Seconds = parseInt(d.Seconds, 10);\n else if (typeof d.Seconds === 'number')\n m.Seconds = d.Seconds;\n else if (typeof d.Seconds === 'object')\n m.Seconds = new $util.LongBits(d.Seconds.low >>> 0, d.Seconds.high >>> 0).toNumber();\n }\n if (d.FractionalNanoseconds != null) {\n m.FractionalNanoseconds = d.FractionalNanoseconds >>> 0;\n }\n return m;\n };\n UnixTime.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if ($util.Long) {\n var n = new $util.Long(0, 0, false);\n d.Seconds = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.Seconds = o.longs === String ? '0' : 0;\n d.FractionalNanoseconds = 0;\n }\n if (m.Seconds != null && m.hasOwnProperty('Seconds')) {\n if (typeof m.Seconds === 'number')\n d.Seconds = o.longs === String ? String(m.Seconds) : m.Seconds;\n else\n d.Seconds = o.longs === String ? $util.Long.prototype.toString.call(m.Seconds) : o.longs === Number ? new $util.LongBits(m.Seconds.low >>> 0, m.Seconds.high >>> 0).toNumber() : m.Seconds;\n }\n if (m.FractionalNanoseconds != null && m.hasOwnProperty('FractionalNanoseconds')) {\n d.FractionalNanoseconds = m.FractionalNanoseconds;\n }\n return d;\n };\n UnixTime.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default['default'].util.toJSONOptions);\n };\n return UnixTime;\n})();\nconst Metadata = $root.Metadata = (() => {\n function Metadata(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Metadata.prototype.MimeType = '';\n Metadata.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.MimeType != null && Object.hasOwnProperty.call(m, 'MimeType'))\n w.uint32(10).string(m.MimeType);\n return w;\n };\n Metadata.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Metadata();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.MimeType = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Metadata.fromObject = function fromObject(d) {\n if (d instanceof $root.Metadata)\n return d;\n var m = new $root.Metadata();\n if (d.MimeType != null) {\n m.MimeType = String(d.MimeType);\n }\n return m;\n };\n Metadata.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.MimeType = '';\n }\n if (m.MimeType != null && m.hasOwnProperty('MimeType')) {\n d.MimeType = m.MimeType;\n }\n return d;\n };\n Metadata.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default['default'].util.toJSONOptions);\n };\n return Metadata;\n})();\n\nexports.Data = Data;\nexports.Metadata = Metadata;\nexports.UnixTime = UnixTime;\nexports['default'] = $root;\n","// minimal library entry point.\n\n\"use strict\";\nmodule.exports = require(\"./src/index-minimal\");\n","\"use strict\";\nvar protobuf = exports;\n\n/**\n * Build type, one of `\"full\"`, `\"light\"` or `\"minimal\"`.\n * @name build\n * @type {string}\n * @const\n */\nprotobuf.build = \"minimal\";\n\n// Serialization\nprotobuf.Writer = require(\"./writer\");\nprotobuf.BufferWriter = require(\"./writer_buffer\");\nprotobuf.Reader = require(\"./reader\");\nprotobuf.BufferReader = require(\"./reader_buffer\");\n\n// Utility\nprotobuf.util = require(\"./util/minimal\");\nprotobuf.rpc = require(\"./rpc\");\nprotobuf.roots = require(\"./roots\");\nprotobuf.configure = configure;\n\n/* istanbul ignore next */\n/**\n * Reconfigures the library according to the environment.\n * @returns {undefined}\n */\nfunction configure() {\n protobuf.util._configure();\n protobuf.Writer._configure(protobuf.BufferWriter);\n protobuf.Reader._configure(protobuf.BufferReader);\n}\n\n// Set up buffer utility according to the environment\nconfigure();\n","\"use strict\";\nmodule.exports = Writer;\n\nvar util = require(\"./util/minimal\");\n\nvar BufferWriter; // cyclic\n\nvar LongBits = util.LongBits,\n base64 = util.base64,\n utf8 = util.utf8;\n\n/**\n * Constructs a new writer operation instance.\n * @classdesc Scheduled writer operation.\n * @constructor\n * @param {function(*, Uint8Array, number)} fn Function to call\n * @param {number} len Value byte length\n * @param {*} val Value to write\n * @ignore\n */\nfunction Op(fn, len, val) {\n\n /**\n * Function to call.\n * @type {function(Uint8Array, number, *)}\n */\n this.fn = fn;\n\n /**\n * Value byte length.\n * @type {number}\n */\n this.len = len;\n\n /**\n * Next operation.\n * @type {Writer.Op|undefined}\n */\n this.next = undefined;\n\n /**\n * Value to write.\n * @type {*}\n */\n this.val = val; // type varies\n}\n\n/* istanbul ignore next */\nfunction noop() {} // eslint-disable-line no-empty-function\n\n/**\n * Constructs a new writer state instance.\n * @classdesc Copied writer state.\n * @memberof Writer\n * @constructor\n * @param {Writer} writer Writer to copy state from\n * @ignore\n */\nfunction State(writer) {\n\n /**\n * Current head.\n * @type {Writer.Op}\n */\n this.head = writer.head;\n\n /**\n * Current tail.\n * @type {Writer.Op}\n */\n this.tail = writer.tail;\n\n /**\n * Current buffer length.\n * @type {number}\n */\n this.len = writer.len;\n\n /**\n * Next state.\n * @type {State|null}\n */\n this.next = writer.states;\n}\n\n/**\n * Constructs a new writer instance.\n * @classdesc Wire format writer using `Uint8Array` if available, otherwise `Array`.\n * @constructor\n */\nfunction Writer() {\n\n /**\n * Current length.\n * @type {number}\n */\n this.len = 0;\n\n /**\n * Operations head.\n * @type {Object}\n */\n this.head = new Op(noop, 0, 0);\n\n /**\n * Operations tail\n * @type {Object}\n */\n this.tail = this.head;\n\n /**\n * Linked forked states.\n * @type {Object|null}\n */\n this.states = null;\n\n // When a value is written, the writer calculates its byte length and puts it into a linked\n // list of operations to perform when finish() is called. This both allows us to allocate\n // buffers of the exact required size and reduces the amount of work we have to do compared\n // to first calculating over objects and then encoding over objects. In our case, the encoding\n // part is just a linked list walk calling operations with already prepared values.\n}\n\nvar create = function create() {\n return util.Buffer\n ? function create_buffer_setup() {\n return (Writer.create = function create_buffer() {\n return new BufferWriter();\n })();\n }\n /* istanbul ignore next */\n : function create_array() {\n return new Writer();\n };\n};\n\n/**\n * Creates a new writer.\n * @function\n * @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer}\n */\nWriter.create = create();\n\n/**\n * Allocates a buffer of the specified size.\n * @param {number} size Buffer size\n * @returns {Uint8Array} Buffer\n */\nWriter.alloc = function alloc(size) {\n return new util.Array(size);\n};\n\n// Use Uint8Array buffer pool in the browser, just like node does with buffers\n/* istanbul ignore else */\nif (util.Array !== Array)\n Writer.alloc = util.pool(Writer.alloc, util.Array.prototype.subarray);\n\n/**\n * Pushes a new operation to the queue.\n * @param {function(Uint8Array, number, *)} fn Function to call\n * @param {number} len Value byte length\n * @param {number} val Value to write\n * @returns {Writer} `this`\n * @private\n */\nWriter.prototype._push = function push(fn, len, val) {\n this.tail = this.tail.next = new Op(fn, len, val);\n this.len += len;\n return this;\n};\n\nfunction writeByte(val, buf, pos) {\n buf[pos] = val & 255;\n}\n\nfunction writeVarint32(val, buf, pos) {\n while (val > 127) {\n buf[pos++] = val & 127 | 128;\n val >>>= 7;\n }\n buf[pos] = val;\n}\n\n/**\n * Constructs a new varint writer operation instance.\n * @classdesc Scheduled varint writer operation.\n * @extends Op\n * @constructor\n * @param {number} len Value byte length\n * @param {number} val Value to write\n * @ignore\n */\nfunction VarintOp(len, val) {\n this.len = len;\n this.next = undefined;\n this.val = val;\n}\n\nVarintOp.prototype = Object.create(Op.prototype);\nVarintOp.prototype.fn = writeVarint32;\n\n/**\n * Writes an unsigned 32 bit value as a varint.\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.uint32 = function write_uint32(value) {\n // here, the call to this.push has been inlined and a varint specific Op subclass is used.\n // uint32 is by far the most frequently used operation and benefits significantly from this.\n this.len += (this.tail = this.tail.next = new VarintOp(\n (value = value >>> 0)\n < 128 ? 1\n : value < 16384 ? 2\n : value < 2097152 ? 3\n : value < 268435456 ? 4\n : 5,\n value)).len;\n return this;\n};\n\n/**\n * Writes a signed 32 bit value as a varint.\n * @function\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.int32 = function write_int32(value) {\n return value < 0\n ? this._push(writeVarint64, 10, LongBits.fromNumber(value)) // 10 bytes per spec\n : this.uint32(value);\n};\n\n/**\n * Writes a 32 bit value as a varint, zig-zag encoded.\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.sint32 = function write_sint32(value) {\n return this.uint32((value << 1 ^ value >> 31) >>> 0);\n};\n\nfunction writeVarint64(val, buf, pos) {\n while (val.hi) {\n buf[pos++] = val.lo & 127 | 128;\n val.lo = (val.lo >>> 7 | val.hi << 25) >>> 0;\n val.hi >>>= 7;\n }\n while (val.lo > 127) {\n buf[pos++] = val.lo & 127 | 128;\n val.lo = val.lo >>> 7;\n }\n buf[pos++] = val.lo;\n}\n\n/**\n * Writes an unsigned 64 bit value as a varint.\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.uint64 = function write_uint64(value) {\n var bits = LongBits.from(value);\n return this._push(writeVarint64, bits.length(), bits);\n};\n\n/**\n * Writes a signed 64 bit value as a varint.\n * @function\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.int64 = Writer.prototype.uint64;\n\n/**\n * Writes a signed 64 bit value as a varint, zig-zag encoded.\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.sint64 = function write_sint64(value) {\n var bits = LongBits.from(value).zzEncode();\n return this._push(writeVarint64, bits.length(), bits);\n};\n\n/**\n * Writes a boolish value as a varint.\n * @param {boolean} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.bool = function write_bool(value) {\n return this._push(writeByte, 1, value ? 1 : 0);\n};\n\nfunction writeFixed32(val, buf, pos) {\n buf[pos ] = val & 255;\n buf[pos + 1] = val >>> 8 & 255;\n buf[pos + 2] = val >>> 16 & 255;\n buf[pos + 3] = val >>> 24;\n}\n\n/**\n * Writes an unsigned 32 bit value as fixed 32 bits.\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.fixed32 = function write_fixed32(value) {\n return this._push(writeFixed32, 4, value >>> 0);\n};\n\n/**\n * Writes a signed 32 bit value as fixed 32 bits.\n * @function\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.sfixed32 = Writer.prototype.fixed32;\n\n/**\n * Writes an unsigned 64 bit value as fixed 64 bits.\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.fixed64 = function write_fixed64(value) {\n var bits = LongBits.from(value);\n return this._push(writeFixed32, 4, bits.lo)._push(writeFixed32, 4, bits.hi);\n};\n\n/**\n * Writes a signed 64 bit value as fixed 64 bits.\n * @function\n * @param {Long|number|string} value Value to write\n * @returns {Writer} `this`\n * @throws {TypeError} If `value` is a string and no long library is present.\n */\nWriter.prototype.sfixed64 = Writer.prototype.fixed64;\n\n/**\n * Writes a float (32 bit).\n * @function\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.float = function write_float(value) {\n return this._push(util.float.writeFloatLE, 4, value);\n};\n\n/**\n * Writes a double (64 bit float).\n * @function\n * @param {number} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.double = function write_double(value) {\n return this._push(util.float.writeDoubleLE, 8, value);\n};\n\nvar writeBytes = util.Array.prototype.set\n ? function writeBytes_set(val, buf, pos) {\n buf.set(val, pos); // also works for plain array values\n }\n /* istanbul ignore next */\n : function writeBytes_for(val, buf, pos) {\n for (var i = 0; i < val.length; ++i)\n buf[pos + i] = val[i];\n };\n\n/**\n * Writes a sequence of bytes.\n * @param {Uint8Array|string} value Buffer or base64 encoded string to write\n * @returns {Writer} `this`\n */\nWriter.prototype.bytes = function write_bytes(value) {\n var len = value.length >>> 0;\n if (!len)\n return this._push(writeByte, 1, 0);\n if (util.isString(value)) {\n var buf = Writer.alloc(len = base64.length(value));\n base64.decode(value, buf, 0);\n value = buf;\n }\n return this.uint32(len)._push(writeBytes, len, value);\n};\n\n/**\n * Writes a string.\n * @param {string} value Value to write\n * @returns {Writer} `this`\n */\nWriter.prototype.string = function write_string(value) {\n var len = utf8.length(value);\n return len\n ? this.uint32(len)._push(utf8.write, len, value)\n : this._push(writeByte, 1, 0);\n};\n\n/**\n * Forks this writer's state by pushing it to a stack.\n * Calling {@link Writer#reset|reset} or {@link Writer#ldelim|ldelim} resets the writer to the previous state.\n * @returns {Writer} `this`\n */\nWriter.prototype.fork = function fork() {\n this.states = new State(this);\n this.head = this.tail = new Op(noop, 0, 0);\n this.len = 0;\n return this;\n};\n\n/**\n * Resets this instance to the last state.\n * @returns {Writer} `this`\n */\nWriter.prototype.reset = function reset() {\n if (this.states) {\n this.head = this.states.head;\n this.tail = this.states.tail;\n this.len = this.states.len;\n this.states = this.states.next;\n } else {\n this.head = this.tail = new Op(noop, 0, 0);\n this.len = 0;\n }\n return this;\n};\n\n/**\n * Resets to the last state and appends the fork state's current write length as a varint followed by its operations.\n * @returns {Writer} `this`\n */\nWriter.prototype.ldelim = function ldelim() {\n var head = this.head,\n tail = this.tail,\n len = this.len;\n this.reset().uint32(len);\n if (len) {\n this.tail.next = head.next; // skip noop\n this.tail = tail;\n this.len += len;\n }\n return this;\n};\n\n/**\n * Finishes the write operation.\n * @returns {Uint8Array} Finished buffer\n */\nWriter.prototype.finish = function finish() {\n var head = this.head.next, // skip noop\n buf = this.constructor.alloc(this.len),\n pos = 0;\n while (head) {\n head.fn(head.val, buf, pos);\n pos += head.len;\n head = head.next;\n }\n // this.head = this.tail = null;\n return buf;\n};\n\nWriter._configure = function(BufferWriter_) {\n BufferWriter = BufferWriter_;\n Writer.create = create();\n BufferWriter._configure();\n};\n","\"use strict\";\nvar util = exports;\n\n// used to return a Promise where callback is omitted\nutil.asPromise = require(\"@protobufjs/aspromise\");\n\n// converts to / from base64 encoded strings\nutil.base64 = require(\"@protobufjs/base64\");\n\n// base class of rpc.Service\nutil.EventEmitter = require(\"@protobufjs/eventemitter\");\n\n// float handling accross browsers\nutil.float = require(\"@protobufjs/float\");\n\n// requires modules optionally and hides the call from bundlers\nutil.inquire = require(\"@protobufjs/inquire\");\n\n// converts to / from utf8 encoded strings\nutil.utf8 = require(\"@protobufjs/utf8\");\n\n// provides a node-like buffer pool in the browser\nutil.pool = require(\"@protobufjs/pool\");\n\n// utility to work with the low and high bits of a 64 bit value\nutil.LongBits = require(\"./longbits\");\n\n/**\n * Whether running within node or not.\n * @memberof util\n * @type {boolean}\n */\nutil.isNode = Boolean(typeof global !== \"undefined\"\n && global\n && global.process\n && global.process.versions\n && global.process.versions.node);\n\n/**\n * Global object reference.\n * @memberof util\n * @type {Object}\n */\nutil.global = util.isNode && global\n || typeof window !== \"undefined\" && window\n || typeof self !== \"undefined\" && self\n || this; // eslint-disable-line no-invalid-this\n\n/**\n * An immuable empty array.\n * @memberof util\n * @type {Array.<*>}\n * @const\n */\nutil.emptyArray = Object.freeze ? Object.freeze([]) : /* istanbul ignore next */ []; // used on prototypes\n\n/**\n * An immutable empty object.\n * @type {Object}\n * @const\n */\nutil.emptyObject = Object.freeze ? Object.freeze({}) : /* istanbul ignore next */ {}; // used on prototypes\n\n/**\n * Tests if the specified value is an integer.\n * @function\n * @param {*} value Value to test\n * @returns {boolean} `true` if the value is an integer\n */\nutil.isInteger = Number.isInteger || /* istanbul ignore next */ function isInteger(value) {\n return typeof value === \"number\" && isFinite(value) && Math.floor(value) === value;\n};\n\n/**\n * Tests if the specified value is a string.\n * @param {*} value Value to test\n * @returns {boolean} `true` if the value is a string\n */\nutil.isString = function isString(value) {\n return typeof value === \"string\" || value instanceof String;\n};\n\n/**\n * Tests if the specified value is a non-null object.\n * @param {*} value Value to test\n * @returns {boolean} `true` if the value is a non-null object\n */\nutil.isObject = function isObject(value) {\n return value && typeof value === \"object\";\n};\n\n/**\n * Checks if a property on a message is considered to be present.\n * This is an alias of {@link util.isSet}.\n * @function\n * @param {Object} obj Plain object or message instance\n * @param {string} prop Property name\n * @returns {boolean} `true` if considered to be present, otherwise `false`\n */\nutil.isset =\n\n/**\n * Checks if a property on a message is considered to be present.\n * @param {Object} obj Plain object or message instance\n * @param {string} prop Property name\n * @returns {boolean} `true` if considered to be present, otherwise `false`\n */\nutil.isSet = function isSet(obj, prop) {\n var value = obj[prop];\n if (value != null && obj.hasOwnProperty(prop)) // eslint-disable-line eqeqeq, no-prototype-builtins\n return typeof value !== \"object\" || (Array.isArray(value) ? value.length : Object.keys(value).length) > 0;\n return false;\n};\n\n/**\n * Any compatible Buffer instance.\n * This is a minimal stand-alone definition of a Buffer instance. The actual type is that exported by node's typings.\n * @interface Buffer\n * @extends Uint8Array\n */\n\n/**\n * Node's Buffer class if available.\n * @type {Constructor<Buffer>}\n */\nutil.Buffer = (function() {\n try {\n var Buffer = util.inquire(\"buffer\").Buffer;\n // refuse to use non-node buffers if not explicitly assigned (perf reasons):\n return Buffer.prototype.utf8Write ? Buffer : /* istanbul ignore next */ null;\n } catch (e) {\n /* istanbul ignore next */\n return null;\n }\n})();\n\n// Internal alias of or polyfull for Buffer.from.\nutil._Buffer_from = null;\n\n// Internal alias of or polyfill for Buffer.allocUnsafe.\nutil._Buffer_allocUnsafe = null;\n\n/**\n * Creates a new buffer of whatever type supported by the environment.\n * @param {number|number[]} [sizeOrArray=0] Buffer size or number array\n * @returns {Uint8Array|Buffer} Buffer\n */\nutil.newBuffer = function newBuffer(sizeOrArray) {\n /* istanbul ignore next */\n return typeof sizeOrArray === \"number\"\n ? util.Buffer\n ? util._Buffer_allocUnsafe(sizeOrArray)\n : new util.Array(sizeOrArray)\n : util.Buffer\n ? util._Buffer_from(sizeOrArray)\n : typeof Uint8Array === \"undefined\"\n ? sizeOrArray\n : new Uint8Array(sizeOrArray);\n};\n\n/**\n * Array implementation used in the browser. `Uint8Array` if supported, otherwise `Array`.\n * @type {Constructor<Uint8Array>}\n */\nutil.Array = typeof Uint8Array !== \"undefined\" ? Uint8Array /* istanbul ignore next */ : Array;\n\n/**\n * Any compatible Long instance.\n * This is a minimal stand-alone definition of a Long instance. The actual type is that exported by long.js.\n * @interface Long\n * @property {number} low Low bits\n * @property {number} high High bits\n * @property {boolean} unsigned Whether unsigned or not\n */\n\n/**\n * Long.js's Long class if available.\n * @type {Constructor<Long>}\n */\nutil.Long = /* istanbul ignore next */ util.global.dcodeIO && /* istanbul ignore next */ util.global.dcodeIO.Long\n || /* istanbul ignore next */ util.global.Long\n || util.inquire(\"long\");\n\n/**\n * Regular expression used to verify 2 bit (`bool`) map keys.\n * @type {RegExp}\n * @const\n */\nutil.key2Re = /^true|false|0|1$/;\n\n/**\n * Regular expression used to verify 32 bit (`int32` etc.) map keys.\n * @type {RegExp}\n * @const\n */\nutil.key32Re = /^-?(?:0|[1-9][0-9]*)$/;\n\n/**\n * Regular expression used to verify 64 bit (`int64` etc.) map keys.\n * @type {RegExp}\n * @const\n */\nutil.key64Re = /^(?:[\\\\x00-\\\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;\n\n/**\n * Converts a number or long to an 8 characters long hash string.\n * @param {Long|number} value Value to convert\n * @returns {string} Hash\n */\nutil.longToHash = function longToHash(value) {\n return value\n ? util.LongBits.from(value).toHash()\n : util.LongBits.zeroHash;\n};\n\n/**\n * Converts an 8 characters long hash string to a long or number.\n * @param {string} hash Hash\n * @param {boolean} [unsigned=false] Whether unsigned or not\n * @returns {Long|number} Original value\n */\nutil.longFromHash = function longFromHash(hash, unsigned) {\n var bits = util.LongBits.fromHash(hash);\n if (util.Long)\n return util.Long.fromBits(bits.lo, bits.hi, unsigned);\n return bits.toNumber(Boolean(unsigned));\n};\n\n/**\n * Merges the properties of the source object into the destination object.\n * @memberof util\n * @param {Object.<string,*>} dst Destination object\n * @param {Object.<string,*>} src Source object\n * @param {boolean} [ifNotSet=false] Merges only if the key is not already set\n * @returns {Object.<string,*>} Destination object\n */\nfunction merge(dst, src, ifNotSet) { // used by converters\n for (var keys = Object.keys(src), i = 0; i < keys.length; ++i)\n if (dst[keys[i]] === undefined || !ifNotSet)\n dst[keys[i]] = src[keys[i]];\n return dst;\n}\n\nutil.merge = merge;\n\n/**\n * Converts the first character of a string to lower case.\n * @param {string} str String to convert\n * @returns {string} Converted string\n */\nutil.lcFirst = function lcFirst(str) {\n return str.charAt(0).toLowerCase() + str.substring(1);\n};\n\n/**\n * Creates a custom error constructor.\n * @memberof util\n * @param {string} name Error name\n * @returns {Constructor<Error>} Custom error constructor\n */\nfunction newError(name) {\n\n function CustomError(message, properties) {\n\n if (!(this instanceof CustomError))\n return new CustomError(message, properties);\n\n // Error.call(this, message);\n // ^ just returns a new error instance because the ctor can be called as a function\n\n Object.defineProperty(this, \"message\", { get: function() { return message; } });\n\n /* istanbul ignore next */\n if (Error.captureStackTrace) // node\n Error.captureStackTrace(this, CustomError);\n else\n Object.defineProperty(this, \"stack\", { value: new Error().stack || \"\" });\n\n if (properties)\n merge(this, properties);\n }\n\n (CustomError.prototype = Object.create(Error.prototype)).constructor = CustomError;\n\n Object.defineProperty(CustomError.prototype, \"name\", { get: function() { return name; } });\n\n CustomError.prototype.toString = function toString() {\n return this.name + \": \" + this.message;\n };\n\n return CustomError;\n}\n\nutil.newError = newError;\n\n/**\n * Constructs a new protocol error.\n * @classdesc Error subclass indicating a protocol specifc error.\n * @memberof util\n * @extends Error\n * @template T extends Message<T>\n * @constructor\n * @param {string} message Error message\n * @param {Object.<string,*>} [properties] Additional properties\n * @example\n * try {\n * MyMessage.decode(someBuffer); // throws if required fields are missing\n * } catch (e) {\n * if (e instanceof ProtocolError && e.instance)\n * console.log(\"decoded so far: \" + JSON.stringify(e.instance));\n * }\n */\nutil.ProtocolError = newError(\"ProtocolError\");\n\n/**\n * So far decoded message instance.\n * @name util.ProtocolError#instance\n * @type {Message<T>}\n */\n\n/**\n * A OneOf getter as returned by {@link util.oneOfGetter}.\n * @typedef OneOfGetter\n * @type {function}\n * @returns {string|undefined} Set field name, if any\n */\n\n/**\n * Builds a getter for a oneof's present field name.\n * @param {string[]} fieldNames Field names\n * @returns {OneOfGetter} Unbound getter\n */\nutil.oneOfGetter = function getOneOf(fieldNames) {\n var fieldMap = {};\n for (var i = 0; i < fieldNames.length; ++i)\n fieldMap[fieldNames[i]] = 1;\n\n /**\n * @returns {string|undefined} Set field name, if any\n * @this Object\n * @ignore\n */\n return function() { // eslint-disable-line consistent-return\n for (var keys = Object.keys(this), i = keys.length - 1; i > -1; --i)\n if (fieldMap[keys[i]] === 1 && this[keys[i]] !== undefined && this[keys[i]] !== null)\n return keys[i];\n };\n};\n\n/**\n * A OneOf setter as returned by {@link util.oneOfSetter}.\n * @typedef OneOfSetter\n * @type {function}\n * @param {string|undefined} value Field name\n * @returns {undefined}\n */\n\n/**\n * Builds a setter for a oneof's present field name.\n * @param {string[]} fieldNames Field names\n * @returns {OneOfSetter} Unbound setter\n */\nutil.oneOfSetter = function setOneOf(fieldNames) {\n\n /**\n * @param {string} name Field name\n * @returns {undefined}\n * @this Object\n * @ignore\n */\n return function(name) {\n for (var i = 0; i < fieldNames.length; ++i)\n if (fieldNames[i] !== name)\n delete this[fieldNames[i]];\n };\n};\n\n/**\n * Default conversion options used for {@link Message#toJSON} implementations.\n *\n * These options are close to proto3's JSON mapping with the exception that internal types like Any are handled just like messages. More precisely:\n *\n * - Longs become strings\n * - Enums become string keys\n * - Bytes become base64 encoded strings\n * - (Sub-)Messages become plain objects\n * - Maps become plain objects with all string keys\n * - Repeated fields become arrays\n * - NaN and Infinity for float and double fields become strings\n *\n * @type {IConversionOptions}\n * @see https://developers.google.com/protocol-buffers/docs/proto3?hl=en#json\n */\nutil.toJSONOptions = {\n longs: String,\n enums: String,\n bytes: String,\n json: true\n};\n\n// Sets up buffer utility according to the environment (called in index-minimal)\nutil._configure = function() {\n var Buffer = util.Buffer;\n /* istanbul ignore if */\n if (!Buffer) {\n util._Buffer_from = util._Buffer_allocUnsafe = null;\n return;\n }\n // because node 4.x buffers are incompatible & immutable\n // see: https://github.com/dcodeIO/protobuf.js/pull/665\n util._Buffer_from = Buffer.from !== Uint8Array.from && Buffer.from ||\n /* istanbul ignore next */\n function Buffer_from(value, encoding) {\n return new Buffer(value, encoding);\n };\n util._Buffer_allocUnsafe = Buffer.allocUnsafe ||\n /* istanbul ignore next */\n function Buffer_allocUnsafe(size) {\n return new Buffer(size);\n };\n};\n","\"use strict\";\r\nmodule.exports = asPromise;\r\n\r\n/**\r\n * Callback as used by {@link util.asPromise}.\r\n * @typedef asPromiseCallback\r\n * @type {function}\r\n * @param {Error|null} error Error, if any\r\n * @param {...*} params Additional arguments\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Returns a promise from a node-style callback function.\r\n * @memberof util\r\n * @param {asPromiseCallback} fn Function to call\r\n * @param {*} ctx Function context\r\n * @param {...*} params Function arguments\r\n * @returns {Promise<*>} Promisified function\r\n */\r\nfunction asPromise(fn, ctx/*, varargs */) {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0,\r\n index = 2,\r\n pending = true;\r\n while (index < arguments.length)\r\n params[offset++] = arguments[index++];\r\n return new Promise(function executor(resolve, reject) {\r\n params[offset] = function callback(err/*, varargs */) {\r\n if (pending) {\r\n pending = false;\r\n if (err)\r\n reject(err);\r\n else {\r\n var params = new Array(arguments.length - 1),\r\n offset = 0;\r\n while (offset < params.length)\r\n params[offset++] = arguments[offset];\r\n resolve.apply(null, params);\r\n }\r\n }\r\n };\r\n try {\r\n fn.apply(ctx || null, params);\r\n } catch (err) {\r\n if (pending) {\r\n pending = false;\r\n reject(err);\r\n }\r\n }\r\n });\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal base64 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar base64 = exports;\r\n\r\n/**\r\n * Calculates the byte length of a base64 encoded string.\r\n * @param {string} string Base64 encoded string\r\n * @returns {number} Byte length\r\n */\r\nbase64.length = function length(string) {\r\n var p = string.length;\r\n if (!p)\r\n return 0;\r\n var n = 0;\r\n while (--p % 4 > 1 && string.charAt(p) === \"=\")\r\n ++n;\r\n return Math.ceil(string.length * 3) / 4 - n;\r\n};\r\n\r\n// Base64 encoding table\r\nvar b64 = new Array(64);\r\n\r\n// Base64 decoding table\r\nvar s64 = new Array(123);\r\n\r\n// 65..90, 97..122, 48..57, 43, 47\r\nfor (var i = 0; i < 64;)\r\n s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++;\r\n\r\n/**\r\n * Encodes a buffer to a base64 encoded string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} Base64 encoded string\r\n */\r\nbase64.encode = function encode(buffer, start, end) {\r\n var parts = null,\r\n chunk = [];\r\n var i = 0, // output index\r\n j = 0, // goto index\r\n t; // temporary\r\n while (start < end) {\r\n var b = buffer[start++];\r\n switch (j) {\r\n case 0:\r\n chunk[i++] = b64[b >> 2];\r\n t = (b & 3) << 4;\r\n j = 1;\r\n break;\r\n case 1:\r\n chunk[i++] = b64[t | b >> 4];\r\n t = (b & 15) << 2;\r\n j = 2;\r\n break;\r\n case 2:\r\n chunk[i++] = b64[t | b >> 6];\r\n chunk[i++] = b64[b & 63];\r\n j = 0;\r\n break;\r\n }\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (j) {\r\n chunk[i++] = b64[t];\r\n chunk[i++] = 61;\r\n if (j === 1)\r\n chunk[i++] = 61;\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\nvar invalidEncoding = \"invalid encoding\";\r\n\r\n/**\r\n * Decodes a base64 encoded string to a buffer.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Number of bytes written\r\n * @throws {Error} If encoding is invalid\r\n */\r\nbase64.decode = function decode(string, buffer, offset) {\r\n var start = offset;\r\n var j = 0, // goto index\r\n t; // temporary\r\n for (var i = 0; i < string.length;) {\r\n var c = string.charCodeAt(i++);\r\n if (c === 61 && j > 1)\r\n break;\r\n if ((c = s64[c]) === undefined)\r\n throw Error(invalidEncoding);\r\n switch (j) {\r\n case 0:\r\n t = c;\r\n j = 1;\r\n break;\r\n case 1:\r\n buffer[offset++] = t << 2 | (c & 48) >> 4;\r\n t = c;\r\n j = 2;\r\n break;\r\n case 2:\r\n buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2;\r\n t = c;\r\n j = 3;\r\n break;\r\n case 3:\r\n buffer[offset++] = (t & 3) << 6 | c;\r\n j = 0;\r\n break;\r\n }\r\n }\r\n if (j === 1)\r\n throw Error(invalidEncoding);\r\n return offset - start;\r\n};\r\n\r\n/**\r\n * Tests if the specified string appears to be base64 encoded.\r\n * @param {string} string String to test\r\n * @returns {boolean} `true` if probably base64 encoded, otherwise false\r\n */\r\nbase64.test = function test(string) {\r\n return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(string);\r\n};\r\n","\"use strict\";\r\nmodule.exports = EventEmitter;\r\n\r\n/**\r\n * Constructs a new event emitter instance.\r\n * @classdesc A minimal event emitter.\r\n * @memberof util\r\n * @constructor\r\n */\r\nfunction EventEmitter() {\r\n\r\n /**\r\n * Registered listeners.\r\n * @type {Object.<string,*>}\r\n * @private\r\n */\r\n this._listeners = {};\r\n}\r\n\r\n/**\r\n * Registers an event listener.\r\n * @param {string} evt Event name\r\n * @param {function} fn Listener\r\n * @param {*} [ctx] Listener context\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.on = function on(evt, fn, ctx) {\r\n (this._listeners[evt] || (this._listeners[evt] = [])).push({\r\n fn : fn,\r\n ctx : ctx || this\r\n });\r\n return this;\r\n};\r\n\r\n/**\r\n * Removes an event listener or any matching listeners if arguments are omitted.\r\n * @param {string} [evt] Event name. Removes all listeners if omitted.\r\n * @param {function} [fn] Listener to remove. Removes all listeners of `evt` if omitted.\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.off = function off(evt, fn) {\r\n if (evt === undefined)\r\n this._listeners = {};\r\n else {\r\n if (fn === undefined)\r\n this._listeners[evt] = [];\r\n else {\r\n var listeners = this._listeners[evt];\r\n for (var i = 0; i < listeners.length;)\r\n if (listeners[i].fn === fn)\r\n listeners.splice(i, 1);\r\n else\r\n ++i;\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Emits an event by calling its listeners with the specified arguments.\r\n * @param {string} evt Event name\r\n * @param {...*} args Arguments\r\n * @returns {util.EventEmitter} `this`\r\n */\r\nEventEmitter.prototype.emit = function emit(evt) {\r\n var listeners = this._listeners[evt];\r\n if (listeners) {\r\n var args = [],\r\n i = 1;\r\n for (; i < arguments.length;)\r\n args.push(arguments[i++]);\r\n for (i = 0; i < listeners.length;)\r\n listeners[i].fn.apply(listeners[i++].ctx, args);\r\n }\r\n return this;\r\n};\r\n","\"use strict\";\r\n\r\nmodule.exports = factory(factory);\r\n\r\n/**\r\n * Reads / writes floats / doubles from / to buffers.\r\n * @name util.float\r\n * @namespace\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using little endian byte order.\r\n * @name util.float.writeFloatLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 32 bit float to a buffer using big endian byte order.\r\n * @name util.float.writeFloatBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using little endian byte order.\r\n * @name util.float.readFloatLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 32 bit float from a buffer using big endian byte order.\r\n * @name util.float.readFloatBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using little endian byte order.\r\n * @name util.float.writeDoubleLE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Writes a 64 bit double to a buffer using big endian byte order.\r\n * @name util.float.writeDoubleBE\r\n * @function\r\n * @param {number} val Value to write\r\n * @param {Uint8Array} buf Target buffer\r\n * @param {number} pos Target buffer offset\r\n * @returns {undefined}\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using little endian byte order.\r\n * @name util.float.readDoubleLE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n/**\r\n * Reads a 64 bit double from a buffer using big endian byte order.\r\n * @name util.float.readDoubleBE\r\n * @function\r\n * @param {Uint8Array} buf Source buffer\r\n * @param {number} pos Source buffer offset\r\n * @returns {number} Value read\r\n */\r\n\r\n// Factory function for the purpose of node-based testing in modified global environments\r\nfunction factory(exports) {\r\n\r\n // float: typed array\r\n if (typeof Float32Array !== \"undefined\") (function() {\r\n\r\n var f32 = new Float32Array([ -0 ]),\r\n f8b = new Uint8Array(f32.buffer),\r\n le = f8b[3] === 128;\r\n\r\n function writeFloat_f32_cpy(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n }\r\n\r\n function writeFloat_f32_rev(val, buf, pos) {\r\n f32[0] = val;\r\n buf[pos ] = f8b[3];\r\n buf[pos + 1] = f8b[2];\r\n buf[pos + 2] = f8b[1];\r\n buf[pos + 3] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeFloatLE = le ? writeFloat_f32_cpy : writeFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.writeFloatBE = le ? writeFloat_f32_rev : writeFloat_f32_cpy;\r\n\r\n function readFloat_f32_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n function readFloat_f32_rev(buf, pos) {\r\n f8b[3] = buf[pos ];\r\n f8b[2] = buf[pos + 1];\r\n f8b[1] = buf[pos + 2];\r\n f8b[0] = buf[pos + 3];\r\n return f32[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readFloatLE = le ? readFloat_f32_cpy : readFloat_f32_rev;\r\n /* istanbul ignore next */\r\n exports.readFloatBE = le ? readFloat_f32_rev : readFloat_f32_cpy;\r\n\r\n // float: ieee754\r\n })(); else (function() {\r\n\r\n function writeFloat_ieee754(writeUint, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0)\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos);\r\n else if (isNaN(val))\r\n writeUint(2143289344, buf, pos);\r\n else if (val > 3.4028234663852886e+38) // +-Infinity\r\n writeUint((sign << 31 | 2139095040) >>> 0, buf, pos);\r\n else if (val < 1.1754943508222875e-38) // denormal\r\n writeUint((sign << 31 | Math.round(val / 1.401298464324817e-45)) >>> 0, buf, pos);\r\n else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2),\r\n mantissa = Math.round(val * Math.pow(2, -exponent) * 8388608) & 8388607;\r\n writeUint((sign << 31 | exponent + 127 << 23 | mantissa) >>> 0, buf, pos);\r\n }\r\n }\r\n\r\n exports.writeFloatLE = writeFloat_ieee754.bind(null, writeUintLE);\r\n exports.writeFloatBE = writeFloat_ieee754.bind(null, writeUintBE);\r\n\r\n function readFloat_ieee754(readUint, buf, pos) {\r\n var uint = readUint(buf, pos),\r\n sign = (uint >> 31) * 2 + 1,\r\n exponent = uint >>> 23 & 255,\r\n mantissa = uint & 8388607;\r\n return exponent === 255\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 1.401298464324817e-45 * mantissa\r\n : sign * Math.pow(2, exponent - 150) * (mantissa + 8388608);\r\n }\r\n\r\n exports.readFloatLE = readFloat_ieee754.bind(null, readUintLE);\r\n exports.readFloatBE = readFloat_ieee754.bind(null, readUintBE);\r\n\r\n })();\r\n\r\n // double: typed array\r\n if (typeof Float64Array !== \"undefined\") (function() {\r\n\r\n var f64 = new Float64Array([-0]),\r\n f8b = new Uint8Array(f64.buffer),\r\n le = f8b[7] === 128;\r\n\r\n function writeDouble_f64_cpy(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[0];\r\n buf[pos + 1] = f8b[1];\r\n buf[pos + 2] = f8b[2];\r\n buf[pos + 3] = f8b[3];\r\n buf[pos + 4] = f8b[4];\r\n buf[pos + 5] = f8b[5];\r\n buf[pos + 6] = f8b[6];\r\n buf[pos + 7] = f8b[7];\r\n }\r\n\r\n function writeDouble_f64_rev(val, buf, pos) {\r\n f64[0] = val;\r\n buf[pos ] = f8b[7];\r\n buf[pos + 1] = f8b[6];\r\n buf[pos + 2] = f8b[5];\r\n buf[pos + 3] = f8b[4];\r\n buf[pos + 4] = f8b[3];\r\n buf[pos + 5] = f8b[2];\r\n buf[pos + 6] = f8b[1];\r\n buf[pos + 7] = f8b[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.writeDoubleLE = le ? writeDouble_f64_cpy : writeDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.writeDoubleBE = le ? writeDouble_f64_rev : writeDouble_f64_cpy;\r\n\r\n function readDouble_f64_cpy(buf, pos) {\r\n f8b[0] = buf[pos ];\r\n f8b[1] = buf[pos + 1];\r\n f8b[2] = buf[pos + 2];\r\n f8b[3] = buf[pos + 3];\r\n f8b[4] = buf[pos + 4];\r\n f8b[5] = buf[pos + 5];\r\n f8b[6] = buf[pos + 6];\r\n f8b[7] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n function readDouble_f64_rev(buf, pos) {\r\n f8b[7] = buf[pos ];\r\n f8b[6] = buf[pos + 1];\r\n f8b[5] = buf[pos + 2];\r\n f8b[4] = buf[pos + 3];\r\n f8b[3] = buf[pos + 4];\r\n f8b[2] = buf[pos + 5];\r\n f8b[1] = buf[pos + 6];\r\n f8b[0] = buf[pos + 7];\r\n return f64[0];\r\n }\r\n\r\n /* istanbul ignore next */\r\n exports.readDoubleLE = le ? readDouble_f64_cpy : readDouble_f64_rev;\r\n /* istanbul ignore next */\r\n exports.readDoubleBE = le ? readDouble_f64_rev : readDouble_f64_cpy;\r\n\r\n // double: ieee754\r\n })(); else (function() {\r\n\r\n function writeDouble_ieee754(writeUint, off0, off1, val, buf, pos) {\r\n var sign = val < 0 ? 1 : 0;\r\n if (sign)\r\n val = -val;\r\n if (val === 0) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(1 / val > 0 ? /* positive */ 0 : /* negative 0 */ 2147483648, buf, pos + off1);\r\n } else if (isNaN(val)) {\r\n writeUint(0, buf, pos + off0);\r\n writeUint(2146959360, buf, pos + off1);\r\n } else if (val > 1.7976931348623157e+308) { // +-Infinity\r\n writeUint(0, buf, pos + off0);\r\n writeUint((sign << 31 | 2146435072) >>> 0, buf, pos + off1);\r\n } else {\r\n var mantissa;\r\n if (val < 2.2250738585072014e-308) { // denormal\r\n mantissa = val / 5e-324;\r\n writeUint(mantissa >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | mantissa / 4294967296) >>> 0, buf, pos + off1);\r\n } else {\r\n var exponent = Math.floor(Math.log(val) / Math.LN2);\r\n if (exponent === 1024)\r\n exponent = 1023;\r\n mantissa = val * Math.pow(2, -exponent);\r\n writeUint(mantissa * 4503599627370496 >>> 0, buf, pos + off0);\r\n writeUint((sign << 31 | exponent + 1023 << 20 | mantissa * 1048576 & 1048575) >>> 0, buf, pos + off1);\r\n }\r\n }\r\n }\r\n\r\n exports.writeDoubleLE = writeDouble_ieee754.bind(null, writeUintLE, 0, 4);\r\n exports.writeDoubleBE = writeDouble_ieee754.bind(null, writeUintBE, 4, 0);\r\n\r\n function readDouble_ieee754(readUint, off0, off1, buf, pos) {\r\n var lo = readUint(buf, pos + off0),\r\n hi = readUint(buf, pos + off1);\r\n var sign = (hi >> 31) * 2 + 1,\r\n exponent = hi >>> 20 & 2047,\r\n mantissa = 4294967296 * (hi & 1048575) + lo;\r\n return exponent === 2047\r\n ? mantissa\r\n ? NaN\r\n : sign * Infinity\r\n : exponent === 0 // denormal\r\n ? sign * 5e-324 * mantissa\r\n : sign * Math.pow(2, exponent - 1075) * (mantissa + 4503599627370496);\r\n }\r\n\r\n exports.readDoubleLE = readDouble_ieee754.bind(null, readUintLE, 0, 4);\r\n exports.readDoubleBE = readDouble_ieee754.bind(null, readUintBE, 4, 0);\r\n\r\n })();\r\n\r\n return exports;\r\n}\r\n\r\n// uint helpers\r\n\r\nfunction writeUintLE(val, buf, pos) {\r\n buf[pos ] = val & 255;\r\n buf[pos + 1] = val >>> 8 & 255;\r\n buf[pos + 2] = val >>> 16 & 255;\r\n buf[pos + 3] = val >>> 24;\r\n}\r\n\r\nfunction writeUintBE(val, buf, pos) {\r\n buf[pos ] = val >>> 24;\r\n buf[pos + 1] = val >>> 16 & 255;\r\n buf[pos + 2] = val >>> 8 & 255;\r\n buf[pos + 3] = val & 255;\r\n}\r\n\r\nfunction readUintLE(buf, pos) {\r\n return (buf[pos ]\r\n | buf[pos + 1] << 8\r\n | buf[pos + 2] << 16\r\n | buf[pos + 3] << 24) >>> 0;\r\n}\r\n\r\nfunction readUintBE(buf, pos) {\r\n return (buf[pos ] << 24\r\n | buf[pos + 1] << 16\r\n | buf[pos + 2] << 8\r\n | buf[pos + 3]) >>> 0;\r\n}\r\n","\"use strict\";\r\nmodule.exports = inquire;\r\n\r\n/**\r\n * Requires a module only if available.\r\n * @memberof util\r\n * @param {string} moduleName Module to require\r\n * @returns {?Object} Required module if available and not empty, otherwise `null`\r\n */\r\nfunction inquire(moduleName) {\r\n try {\r\n var mod = eval(\"quire\".replace(/^/,\"re\"))(moduleName); // eslint-disable-line no-eval\r\n if (mod && (mod.length || Object.keys(mod).length))\r\n return mod;\r\n } catch (e) {} // eslint-disable-line no-empty\r\n return null;\r\n}\r\n","\"use strict\";\r\n\r\n/**\r\n * A minimal UTF8 implementation for number arrays.\r\n * @memberof util\r\n * @namespace\r\n */\r\nvar utf8 = exports;\r\n\r\n/**\r\n * Calculates the UTF8 byte length of a string.\r\n * @param {string} string String\r\n * @returns {number} Byte length\r\n */\r\nutf8.length = function utf8_length(string) {\r\n var len = 0,\r\n c = 0;\r\n for (var i = 0; i < string.length; ++i) {\r\n c = string.charCodeAt(i);\r\n if (c < 128)\r\n len += 1;\r\n else if (c < 2048)\r\n len += 2;\r\n else if ((c & 0xFC00) === 0xD800 && (string.charCodeAt(i + 1) & 0xFC00) === 0xDC00) {\r\n ++i;\r\n len += 4;\r\n } else\r\n len += 3;\r\n }\r\n return len;\r\n};\r\n\r\n/**\r\n * Reads UTF8 bytes as a string.\r\n * @param {Uint8Array} buffer Source buffer\r\n * @param {number} start Source start\r\n * @param {number} end Source end\r\n * @returns {string} String read\r\n */\r\nutf8.read = function utf8_read(buffer, start, end) {\r\n var len = end - start;\r\n if (len < 1)\r\n return \"\";\r\n var parts = null,\r\n chunk = [],\r\n i = 0, // char offset\r\n t; // temporary\r\n while (start < end) {\r\n t = buffer[start++];\r\n if (t < 128)\r\n chunk[i++] = t;\r\n else if (t > 191 && t < 224)\r\n chunk[i++] = (t & 31) << 6 | buffer[start++] & 63;\r\n else if (t > 239 && t < 365) {\r\n t = ((t & 7) << 18 | (buffer[start++] & 63) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63) - 0x10000;\r\n chunk[i++] = 0xD800 + (t >> 10);\r\n chunk[i++] = 0xDC00 + (t & 1023);\r\n } else\r\n chunk[i++] = (t & 15) << 12 | (buffer[start++] & 63) << 6 | buffer[start++] & 63;\r\n if (i > 8191) {\r\n (parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));\r\n i = 0;\r\n }\r\n }\r\n if (parts) {\r\n if (i)\r\n parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));\r\n return parts.join(\"\");\r\n }\r\n return String.fromCharCode.apply(String, chunk.slice(0, i));\r\n};\r\n\r\n/**\r\n * Writes a string as UTF8 bytes.\r\n * @param {string} string Source string\r\n * @param {Uint8Array} buffer Destination buffer\r\n * @param {number} offset Destination offset\r\n * @returns {number} Bytes written\r\n */\r\nutf8.write = function utf8_write(string, buffer, offset) {\r\n var start = offset,\r\n c1, // character 1\r\n c2; // character 2\r\n for (var i = 0; i < string.length; ++i) {\r\n c1 = string.charCodeAt(i);\r\n if (c1 < 128) {\r\n buffer[offset++] = c1;\r\n } else if (c1 < 2048) {\r\n buffer[offset++] = c1 >> 6 | 192;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else if ((c1 & 0xFC00) === 0xD800 && ((c2 = string.charCodeAt(i + 1)) & 0xFC00) === 0xDC00) {\r\n c1 = 0x10000 + ((c1 & 0x03FF) << 10) + (c2 & 0x03FF);\r\n ++i;\r\n buffer[offset++] = c1 >> 18 | 240;\r\n buffer[offset++] = c1 >> 12 & 63 | 128;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n } else {\r\n buffer[offset++] = c1 >> 12 | 224;\r\n buffer[offset++] = c1 >> 6 & 63 | 128;\r\n buffer[offset++] = c1 & 63 | 128;\r\n }\r\n }\r\n return offset - start;\r\n};\r\n","\"use strict\";\r\nmodule.exports = pool;\r\n\r\n/**\r\n * An allocator as used by {@link util.pool}.\r\n * @typedef PoolAllocator\r\n * @type {function}\r\n * @param {number} size Buffer size\r\n * @returns {Uint8Array} Buffer\r\n */\r\n\r\n/**\r\n * A slicer as used by {@link util.pool}.\r\n * @typedef PoolSlicer\r\n * @type {function}\r\n * @param {number} start Start offset\r\n * @param {number} end End offset\r\n * @returns {Uint8Array} Buffer slice\r\n * @this {Uint8Array}\r\n */\r\n\r\n/**\r\n * A general purpose buffer pool.\r\n * @memberof util\r\n * @function\r\n * @param {PoolAllocator} alloc Allocator\r\n * @param {PoolSlicer} slice Slicer\r\n * @param {number} [size=8192] Slab size\r\n * @returns {PoolAllocator} Pooled allocator\r\n */\r\nfunction pool(alloc, slice, size) {\r\n var SIZE = size || 8192;\r\n var MAX = SIZE >>> 1;\r\n var slab = null;\r\n var offset = SIZE;\r\n return function pool_alloc(size) {\r\n if (size < 1 || size > MAX)\r\n return alloc(size);\r\n if (offset + size > SIZE) {\r\n slab = alloc(SIZE);\r\n offset = 0;\r\n }\r\n var buf = slice.call(slab, offset, offset += size);\r\n if (offset & 7) // align to 32 bit\r\n offset = (offset | 7) + 1;\r\n return buf;\r\n };\r\n}\r\n","\"use strict\";\nmodule.exports = LongBits;\n\nvar util = require(\"../util/minimal\");\n\n/**\n * Constructs new long bits.\n * @classdesc Helper class for working with the low and high bits of a 64 bit value.\n * @memberof util\n * @constructor\n * @param {number} lo Low 32 bits, unsigned\n * @param {number} hi High 32 bits, unsigned\n */\nfunction LongBits(lo, hi) {\n\n // note that the casts below are theoretically unnecessary as of today, but older statically\n // generated converter code might still call the ctor with signed 32bits. kept for compat.\n\n /**\n * Low bits.\n * @type {number}\n */\n this.lo = lo >>> 0;\n\n /**\n * High bits.\n * @type {number}\n */\n this.hi = hi >>> 0;\n}\n\n/**\n * Zero bits.\n * @memberof util.LongBits\n * @type {util.LongBits}\n */\nvar zero = LongBits.zero = new LongBits(0, 0);\n\nzero.toNumber = function() { return 0; };\nzero.zzEncode = zero.zzDecode = function() { return this; };\nzero.length = function() { return 1; };\n\n/**\n * Zero hash.\n * @memberof util.LongBits\n * @type {string}\n */\nvar zeroHash = LongBits.zeroHash = \"\\0\\0\\0\\0\\0\\0\\0\\0\";\n\n/**\n * Constructs new long bits from the specified number.\n * @param {number} value Value\n * @returns {util.LongBits} Instance\n */\nLongBits.fromNumber = function fromNumber(value) {\n if (value === 0)\n return zero;\n var sign = value < 0;\n if (sign)\n value = -value;\n var lo = value >>> 0,\n hi = (value - lo) / 4294967296 >>> 0;\n if (sign) {\n hi = ~hi >>> 0;\n lo = ~lo >>> 0;\n if (++lo > 4294967295) {\n lo = 0;\n if (++hi > 4294967295)\n hi = 0;\n }\n }\n return new LongBits(lo, hi);\n};\n\n/**\n * Constructs new long bits from a number, long or string.\n * @param {Long|number|string} value Value\n * @returns {util.LongBits} Instance\n */\nLongBits.from = function from(value) {\n if (typeof value === \"number\")\n return LongBits.fromNumber(value);\n if (util.isString(value)) {\n /* istanbul ignore else */\n if (util.Long)\n value = util.Long.fromString(value);\n else\n return LongBits.fromNumber(parseInt(value, 10));\n }\n return value.low || value.high ? new LongBits(value.low >>> 0, value.high >>> 0) : zero;\n};\n\n/**\n * Converts this long bits to a possibly unsafe JavaScript number.\n * @param {boolean} [unsigned=false] Whether unsigned or not\n * @returns {number} Possibly unsafe number\n */\nLongBits.prototype.toNumber = function toNumber(unsigned) {\n if (!unsigned && this.hi >>> 31) {\n var lo = ~this.lo + 1 >>> 0,\n hi = ~this.hi >>> 0;\n if (!lo)\n hi = hi + 1 >>> 0;\n return -(lo + hi * 4294967296);\n }\n return this.lo + this.hi * 4294967296;\n};\n\n/**\n * Converts this long bits to a long.\n * @param {boolean} [unsigned=false] Whether unsigned or not\n * @returns {Long} Long\n */\nLongBits.prototype.toLong = function toLong(unsigned) {\n return util.Long\n ? new util.Long(this.lo | 0, this.hi | 0, Boolean(unsigned))\n /* istanbul ignore next */\n : { low: this.lo | 0, high: this.hi | 0, unsigned: Boolean(unsigned) };\n};\n\nvar charCodeAt = String.prototype.charCodeAt;\n\n/**\n * Constructs new long bits from the specified 8 characters long hash.\n * @param {string} hash Hash\n * @returns {util.LongBits} Bits\n */\nLongBits.fromHash = function fromHash(hash) {\n if (hash === zeroHash)\n return zero;\n return new LongBits(\n ( charCodeAt.call(hash, 0)\n | charCodeAt.call(hash, 1) << 8\n | charCodeAt.call(hash, 2) << 16\n | charCodeAt.call(hash, 3) << 24) >>> 0\n ,\n ( charCodeAt.call(hash, 4)\n | charCodeAt.call(hash, 5) << 8\n | charCodeAt.call(hash, 6) << 16\n | charCodeAt.call(hash, 7) << 24) >>> 0\n );\n};\n\n/**\n * Converts this long bits to a 8 characters long hash.\n * @returns {string} Hash\n */\nLongBits.prototype.toHash = function toHash() {\n return String.fromCharCode(\n this.lo & 255,\n this.lo >>> 8 & 255,\n this.lo >>> 16 & 255,\n this.lo >>> 24 ,\n this.hi & 255,\n this.hi >>> 8 & 255,\n this.hi >>> 16 & 255,\n this.hi >>> 24\n );\n};\n\n/**\n * Zig-zag encodes this long bits.\n * @returns {util.LongBits} `this`\n */\nLongBits.prototype.zzEncode = function zzEncode() {\n var mask = this.hi >> 31;\n this.hi = ((this.hi << 1 | this.lo >>> 31) ^ mask) >>> 0;\n this.lo = ( this.lo << 1 ^ mask) >>> 0;\n return this;\n};\n\n/**\n * Zig-zag decodes this long bits.\n * @returns {util.LongBits} `this`\n */\nLongBits.prototype.zzDecode = function zzDecode() {\n var mask = -(this.lo & 1);\n this.lo = ((this.lo >>> 1 | this.hi << 31) ^ mask) >>> 0;\n this.hi = ( this.hi >>> 1 ^ mask) >>> 0;\n return this;\n};\n\n/**\n * Calculates the length of this longbits when encoded as a varint.\n * @returns {number} Length\n */\nLongBits.prototype.length = function length() {\n var part0 = this.lo,\n part1 = (this.lo >>> 28 | this.hi << 4) >>> 0,\n part2 = this.hi >>> 24;\n return part2 === 0\n ? part1 === 0\n ? part0 < 16384\n ? part0 < 128 ? 1 : 2\n : part0 < 2097152 ? 3 : 4\n : part1 < 16384\n ? part1 < 128 ? 5 : 6\n : part1 < 2097152 ? 7 : 8\n : part2 < 128 ? 9 : 10;\n};\n","\"use strict\";\nmodule.exports = BufferWriter;\n\n// extends Writer\nvar Writer = require(\"./writer\");\n(BufferWriter.prototype = Object.create(Writer.prototype)).constructor = BufferWriter;\n\nvar util = require(\"./util/minimal\");\n\n/**\n * Constructs a new buffer writer instance.\n * @classdesc Wire format writer using node buffers.\n * @extends Writer\n * @constructor\n */\nfunction BufferWriter() {\n Writer.call(this);\n}\n\nBufferWriter._configure = function () {\n /**\n * Allocates a buffer of the specified size.\n * @function\n * @param {number} size Buffer size\n * @returns {Buffer} Buffer\n */\n BufferWriter.alloc = util._Buffer_allocUnsafe;\n\n BufferWriter.writeBytesBuffer = util.Buffer && util.Buffer.prototype instanceof Uint8Array && util.Buffer.prototype.set.name === \"set\"\n ? function writeBytesBuffer_set(val, buf, pos) {\n buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)\n // also works for plain array values\n }\n /* istanbul ignore next */\n : function writeBytesBuffer_copy(val, buf, pos) {\n if (val.copy) // Buffer values\n val.copy(buf, pos, 0, val.length);\n else for (var i = 0; i < val.length;) // plain array values\n buf[pos++] = val[i++];\n };\n};\n\n\n/**\n * @override\n */\nBufferWriter.prototype.bytes = function write_bytes_buffer(value) {\n if (util.isString(value))\n value = util._Buffer_from(value, \"base64\");\n var len = value.length >>> 0;\n this.uint32(len);\n if (len)\n this._push(BufferWriter.writeBytesBuffer, len, value);\n return this;\n};\n\nfunction writeStringBuffer(val, buf, pos) {\n if (val.length < 40) // plain js is faster for short strings (probably due to redundant assertions)\n util.utf8.write(val, buf, pos);\n else if (buf.utf8Write)\n buf.utf8Write(val, pos);\n else\n buf.write(val, pos);\n}\n\n/**\n * @override\n */\nBufferWriter.prototype.string = function write_string_buffer(value) {\n var len = util.Buffer.byteLength(value);\n this.uint32(len);\n if (len)\n this._push(writeStringBuffer, len, value);\n return this;\n};\n\n\n/**\n * Finishes the write operation.\n * @name BufferWriter#finish\n * @function\n * @returns {Buffer} Finished buffer\n */\n\nBufferWriter._configure();\n","\"use strict\";\nmodule.exports = Reader;\n\nvar util = require(\"./util/minimal\");\n\nvar BufferReader; // cyclic\n\nvar LongBits = util.LongBits,\n utf8 = util.utf8;\n\n/* istanbul ignore next */\nfunction indexOutOfRange(reader, writeLength) {\n return RangeError(\"index out of range: \" + reader.pos + \" + \" + (writeLength || 1) + \" > \" + reader.len);\n}\n\n/**\n * Constructs a new reader instance using the specified buffer.\n * @classdesc Wire format reader using `Uint8Array` if available, otherwise `Array`.\n * @constructor\n * @param {Uint8Array} buffer Buffer to read from\n */\nfunction Reader(buffer) {\n\n /**\n * Read buffer.\n * @type {Uint8Array}\n */\n this.buf = buffer;\n\n /**\n * Read buffer position.\n * @type {number}\n */\n this.pos = 0;\n\n /**\n * Read buffer length.\n * @type {number}\n */\n this.len = buffer.length;\n}\n\nvar create_array = typeof Uint8Array !== \"undefined\"\n ? function create_typed_array(buffer) {\n if (buffer instanceof Uint8Array || Array.isArray(buffer))\n return new Reader(buffer);\n throw Error(\"illegal buffer\");\n }\n /* istanbul ignore next */\n : function create_array(buffer) {\n if (Array.isArray(buffer))\n return new Reader(buffer);\n throw Error(\"illegal buffer\");\n };\n\nvar create = function create() {\n return util.Buffer\n ? function create_buffer_setup(buffer) {\n return (Reader.create = function create_buffer(buffer) {\n return util.Buffer.isBuffer(buffer)\n ? new BufferReader(buffer)\n /* istanbul ignore next */\n : create_array(buffer);\n })(buffer);\n }\n /* istanbul ignore next */\n : create_array;\n};\n\n/**\n * Creates a new reader using the specified buffer.\n * @function\n * @param {Uint8Array|Buffer} buffer Buffer to read from\n * @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader}\n * @throws {Error} If `buffer` is not a valid buffer\n */\nReader.create = create();\n\nReader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice;\n\n/**\n * Reads a varint as an unsigned 32 bit value.\n * @function\n * @returns {number} Value read\n */\nReader.prototype.uint32 = (function read_uint32_setup() {\n var value = 4294967295; // optimizer type-hint, tends to deopt otherwise (?!)\n return function read_uint32() {\n value = ( this.buf[this.pos] & 127 ) >>> 0; if (this.buf[this.pos++] < 128) return value;\n value = (value | (this.buf[this.pos] & 127) << 7) >>> 0; if (this.buf[this.pos++] < 128) return value;\n value = (value | (this.buf[this.pos] & 127) << 14) >>> 0; if (this.buf[this.pos++] < 128) return value;\n value = (value | (this.buf[this.pos] & 127) << 21) >>> 0; if (this.buf[this.pos++] < 128) return value;\n value = (value | (this.buf[this.pos] & 15) << 28) >>> 0; if (this.buf[this.pos++] < 128) return value;\n\n /* istanbul ignore if */\n if ((this.pos += 5) > this.len) {\n this.pos = this.len;\n throw indexOutOfRange(this, 10);\n }\n return value;\n };\n})();\n\n/**\n * Reads a varint as a signed 32 bit value.\n * @returns {number} Value read\n */\nReader.prototype.int32 = function read_int32() {\n return this.uint32() | 0;\n};\n\n/**\n * Reads a zig-zag encoded varint as a signed 32 bit value.\n * @returns {number} Value read\n */\nReader.prototype.sint32 = function read_sint32() {\n var value = this.uint32();\n return value >>> 1 ^ -(value & 1) | 0;\n};\n\n/* eslint-disable no-invalid-this */\n\nfunction readLongVarint() {\n // tends to deopt with local vars for octet etc.\n var bits = new LongBits(0, 0);\n var i = 0;\n if (this.len - this.pos > 4) { // fast route (lo)\n for (; i < 4; ++i) {\n // 1st..4th\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n }\n // 5th\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << 28) >>> 0;\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) >> 4) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n i = 0;\n } else {\n for (; i < 3; ++i) {\n /* istanbul ignore if */\n if (this.pos >= this.len)\n throw indexOutOfRange(this);\n // 1st..3th\n bits.lo = (bits.lo | (this.buf[this.pos] & 127) << i * 7) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n }\n // 4th\n bits.lo = (bits.lo | (this.buf[this.pos++] & 127) << i * 7) >>> 0;\n return bits;\n }\n if (this.len - this.pos > 4) { // fast route (hi)\n for (; i < 5; ++i) {\n // 6th..10th\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n }\n } else {\n for (; i < 5; ++i) {\n /* istanbul ignore if */\n if (this.pos >= this.len)\n throw indexOutOfRange(this);\n // 6th..10th\n bits.hi = (bits.hi | (this.buf[this.pos] & 127) << i * 7 + 3) >>> 0;\n if (this.buf[this.pos++] < 128)\n return bits;\n }\n }\n /* istanbul ignore next */\n throw Error(\"invalid varint encoding\");\n}\n\n/* eslint-enable no-invalid-this */\n\n/**\n * Reads a varint as a signed 64 bit value.\n * @name Reader#int64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads a varint as an unsigned 64 bit value.\n * @name Reader#uint64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads a zig-zag encoded varint as a signed 64 bit value.\n * @name Reader#sint64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads a varint as a boolean.\n * @returns {boolean} Value read\n */\nReader.prototype.bool = function read_bool() {\n return this.uint32() !== 0;\n};\n\nfunction readFixed32_end(buf, end) { // note that this uses `end`, not `pos`\n return (buf[end - 4]\n | buf[end - 3] << 8\n | buf[end - 2] << 16\n | buf[end - 1] << 24) >>> 0;\n}\n\n/**\n * Reads fixed 32 bits as an unsigned 32 bit integer.\n * @returns {number} Value read\n */\nReader.prototype.fixed32 = function read_fixed32() {\n\n /* istanbul ignore if */\n if (this.pos + 4 > this.len)\n throw indexOutOfRange(this, 4);\n\n return readFixed32_end(this.buf, this.pos += 4);\n};\n\n/**\n * Reads fixed 32 bits as a signed 32 bit integer.\n * @returns {number} Value read\n */\nReader.prototype.sfixed32 = function read_sfixed32() {\n\n /* istanbul ignore if */\n if (this.pos + 4 > this.len)\n throw indexOutOfRange(this, 4);\n\n return readFixed32_end(this.buf, this.pos += 4) | 0;\n};\n\n/* eslint-disable no-invalid-this */\n\nfunction readFixed64(/* this: Reader */) {\n\n /* istanbul ignore if */\n if (this.pos + 8 > this.len)\n throw indexOutOfRange(this, 8);\n\n return new LongBits(readFixed32_end(this.buf, this.pos += 4), readFixed32_end(this.buf, this.pos += 4));\n}\n\n/* eslint-enable no-invalid-this */\n\n/**\n * Reads fixed 64 bits.\n * @name Reader#fixed64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads zig-zag encoded fixed 64 bits.\n * @name Reader#sfixed64\n * @function\n * @returns {Long} Value read\n */\n\n/**\n * Reads a float (32 bit) as a number.\n * @function\n * @returns {number} Value read\n */\nReader.prototype.float = function read_float() {\n\n /* istanbul ignore if */\n if (this.pos + 4 > this.len)\n throw indexOutOfRange(this, 4);\n\n var value = util.float.readFloatLE(this.buf, this.pos);\n this.pos += 4;\n return value;\n};\n\n/**\n * Reads a double (64 bit float) as a number.\n * @function\n * @returns {number} Value read\n */\nReader.prototype.double = function read_double() {\n\n /* istanbul ignore if */\n if (this.pos + 8 > this.len)\n throw indexOutOfRange(this, 4);\n\n var value = util.float.readDoubleLE(this.buf, this.pos);\n this.pos += 8;\n return value;\n};\n\n/**\n * Reads a sequence of bytes preceeded by its length as a varint.\n * @returns {Uint8Array} Value read\n */\nReader.prototype.bytes = function read_bytes() {\n var length = this.uint32(),\n start = this.pos,\n end = this.pos + length;\n\n /* istanbul ignore if */\n if (end > this.len)\n throw indexOutOfRange(this, length);\n\n this.pos += length;\n if (Array.isArray(this.buf)) // plain array\n return this.buf.slice(start, end);\n return start === end // fix for IE 10/Win8 and others' subarray returning array of size 1\n ? new this.buf.constructor(0)\n : this._slice.call(this.buf, start, end);\n};\n\n/**\n * Reads a string preceeded by its byte length as a varint.\n * @returns {string} Value read\n */\nReader.prototype.string = function read_string() {\n var bytes = this.bytes();\n return utf8.read(bytes, 0, bytes.length);\n};\n\n/**\n * Skips the specified number of bytes if specified, otherwise skips a varint.\n * @param {number} [length] Length if known, otherwise a varint is assumed\n * @returns {Reader} `this`\n */\nReader.prototype.skip = function skip(length) {\n if (typeof length === \"number\") {\n /* istanbul ignore if */\n if (this.pos + length > this.len)\n throw indexOutOfRange(this, length);\n this.pos += length;\n } else {\n do {\n /* istanbul ignore if */\n if (this.pos >= this.len)\n throw indexOutOfRange(this);\n } while (this.buf[this.pos++] & 128);\n }\n return this;\n};\n\n/**\n * Skips the next element of the specified wire type.\n * @param {number} wireType Wire type received\n * @returns {Reader} `this`\n */\nReader.prototype.skipType = function(wireType) {\n switch (wireType) {\n case 0:\n this.skip();\n break;\n case 1:\n this.skip(8);\n break;\n case 2:\n this.skip(this.uint32());\n break;\n case 3:\n while ((wireType = this.uint32() & 7) !== 4) {\n this.skipType(wireType);\n }\n break;\n case 5:\n this.skip(4);\n break;\n\n /* istanbul ignore next */\n default:\n throw Error(\"invalid wire type \" + wireType + \" at offset \" + this.pos);\n }\n return this;\n};\n\nReader._configure = function(BufferReader_) {\n BufferReader = BufferReader_;\n Reader.create = create();\n BufferReader._configure();\n\n var fn = util.Long ? \"toLong\" : /* istanbul ignore next */ \"toNumber\";\n util.merge(Reader.prototype, {\n\n int64: function read_int64() {\n return readLongVarint.call(this)[fn](false);\n },\n\n uint64: function read_uint64() {\n return readLongVarint.call(this)[fn](true);\n },\n\n sint64: function read_sint64() {\n return readLongVarint.call(this).zzDecode()[fn](false);\n },\n\n fixed64: function read_fixed64() {\n return readFixed64.call(this)[fn](true);\n },\n\n sfixed64: function read_sfixed64() {\n return readFixed64.call(this)[fn](false);\n }\n\n });\n};\n","\"use strict\";\nmodule.exports = BufferReader;\n\n// extends Reader\nvar Reader = require(\"./reader\");\n(BufferReader.prototype = Object.create(Reader.prototype)).constructor = BufferReader;\n\nvar util = require(\"./util/minimal\");\n\n/**\n * Constructs a new buffer reader instance.\n * @classdesc Wire format reader using node buffers.\n * @extends Reader\n * @constructor\n * @param {Buffer} buffer Buffer to read from\n */\nfunction BufferReader(buffer) {\n Reader.call(this, buffer);\n\n /**\n * Read buffer.\n * @name BufferReader#buf\n * @type {Buffer}\n */\n}\n\nBufferReader._configure = function () {\n /* istanbul ignore else */\n if (util.Buffer)\n BufferReader.prototype._slice = util.Buffer.prototype.slice;\n};\n\n\n/**\n * @override\n */\nBufferReader.prototype.string = function read_string_buffer() {\n var len = this.uint32(); // modifies pos\n return this.buf.utf8Slice\n ? this.buf.utf8Slice(this.pos, this.pos = Math.min(this.pos + len, this.len))\n : this.buf.toString(\"utf-8\", this.pos, this.pos = Math.min(this.pos + len, this.len));\n};\n\n/**\n * Reads a sequence of bytes preceeded by its length as a varint.\n * @name BufferReader#bytes\n * @function\n * @returns {Buffer} Value read\n */\n\nBufferReader._configure();\n","\"use strict\";\n\n/**\n * Streaming RPC helpers.\n * @namespace\n */\nvar rpc = exports;\n\n/**\n * RPC implementation passed to {@link Service#create} performing a service request on network level, i.e. by utilizing http requests or websockets.\n * @typedef RPCImpl\n * @type {function}\n * @param {Method|rpc.ServiceMethod<Message<{}>,Message<{}>>} method Reflected or static method being called\n * @param {Uint8Array} requestData Request data\n * @param {RPCImplCallback} callback Callback function\n * @returns {undefined}\n * @example\n * function rpcImpl(method, requestData, callback) {\n * if (protobuf.util.lcFirst(method.name) !== \"myMethod\") // compatible with static code\n * throw Error(\"no such method\");\n * asynchronouslyObtainAResponse(requestData, function(err, responseData) {\n * callback(err, responseData);\n * });\n * }\n */\n\n/**\n * Node-style callback as used by {@link RPCImpl}.\n * @typedef RPCImplCallback\n * @type {function}\n * @param {Error|null} error Error, if any, otherwise `null`\n * @param {Uint8Array|null} [response] Response data or `null` to signal end of stream, if there hasn't been an error\n * @returns {undefined}\n */\n\nrpc.Service = require(\"./rpc/service\");\n","\"use strict\";\nmodule.exports = Service;\n\nvar util = require(\"../util/minimal\");\n\n// Extends EventEmitter\n(Service.prototype = Object.create(util.EventEmitter.prototype)).constructor = Service;\n\n/**\n * A service method callback as used by {@link rpc.ServiceMethod|ServiceMethod}.\n *\n * Differs from {@link RPCImplCallback} in that it is an actual callback of a service method which may not return `response = null`.\n * @typedef rpc.ServiceMethodCallback\n * @template TRes extends Message<TRes>\n * @type {function}\n * @param {Error|null} error Error, if any\n * @param {TRes} [response] Response message\n * @returns {undefined}\n */\n\n/**\n * A service method part of a {@link rpc.Service} as created by {@link Service.create}.\n * @typedef rpc.ServiceMethod\n * @template TReq extends Message<TReq>\n * @template TRes extends Message<TRes>\n * @type {function}\n * @param {TReq|Properties<TReq>} request Request message or plain object\n * @param {rpc.ServiceMethodCallback<TRes>} [callback] Node-style callback called with the error, if any, and the response message\n * @returns {Promise<Message<TRes>>} Promise if `callback` has been omitted, otherwise `undefined`\n */\n\n/**\n * Constructs a new RPC service instance.\n * @classdesc An RPC service as returned by {@link Service#create}.\n * @exports rpc.Service\n * @extends util.EventEmitter\n * @constructor\n * @param {RPCImpl} rpcImpl RPC implementation\n * @param {boolean} [requestDelimited=false] Whether requests are length-delimited\n * @param {boolean} [responseDelimited=false] Whether responses are length-delimited\n */\nfunction Service(rpcImpl, requestDelimited, responseDelimited) {\n\n if (typeof rpcImpl !== \"function\")\n throw TypeError(\"rpcImpl must be a function\");\n\n util.EventEmitter.call(this);\n\n /**\n * RPC implementation. Becomes `null` once the service is ended.\n * @type {RPCImpl|null}\n */\n this.rpcImpl = rpcImpl;\n\n /**\n * Whether requests are length-delimited.\n * @type {boolean}\n */\n this.requestDelimited = Boolean(requestDelimited);\n\n /**\n * Whether responses are length-delimited.\n * @type {boolean}\n */\n this.responseDelimited = Boolean(responseDelimited);\n}\n\n/**\n * Calls a service method through {@link rpc.Service#rpcImpl|rpcImpl}.\n * @param {Method|rpc.ServiceMethod<TReq,TRes>} method Reflected or static method\n * @param {Constructor<TReq>} requestCtor Request constructor\n * @param {Constructor<TRes>} responseCtor Response constructor\n * @param {TReq|Properties<TReq>} request Request message or plain object\n * @param {rpc.ServiceMethodCallback<TRes>} callback Service callback\n * @returns {undefined}\n * @template TReq extends Message<TReq>\n * @template TRes extends Message<TRes>\n */\nService.prototype.rpcCall = function rpcCall(method, requestCtor, responseCtor, request, callback) {\n\n if (!request)\n throw TypeError(\"request must be specified\");\n\n var self = this;\n if (!callback)\n return util.asPromise(rpcCall, self, method, requestCtor, responseCtor, request);\n\n if (!self.rpcImpl) {\n setTimeout(function() { callback(Error(\"already ended\")); }, 0);\n return undefined;\n }\n\n try {\n return self.rpcImpl(\n method,\n requestCtor[self.requestDelimited ? \"encodeDelimited\" : \"encode\"](request).finish(),\n function rpcCallback(err, response) {\n\n if (err) {\n self.emit(\"error\", err, method);\n return callback(err);\n }\n\n if (response === null) {\n self.end(/* endedByRPC */ true);\n return undefined;\n }\n\n if (!(response instanceof responseCtor)) {\n try {\n response = responseCtor[self.responseDelimited ? \"decodeDelimited\" : \"decode\"](response);\n } catch (err) {\n self.emit(\"error\", err, method);\n return callback(err);\n }\n }\n\n self.emit(\"data\", response, method);\n return callback(null, response);\n }\n );\n } catch (err) {\n self.emit(\"error\", err, method);\n setTimeout(function() { callback(err); }, 0);\n return undefined;\n }\n};\n\n/**\n * Ends this service and emits the `end` event.\n * @param {boolean} [endedByRPC=false] Whether the service has been ended by the RPC implementation.\n * @returns {rpc.Service} `this`\n */\nService.prototype.end = function end(endedByRPC) {\n if (this.rpcImpl) {\n if (!endedByRPC) // signal end to rpcImpl\n this.rpcImpl(null, null, null);\n this.rpcImpl = null;\n this.emit(\"end\").off();\n }\n return this;\n};\n","\"use strict\";\nmodule.exports = {};\n\n/**\n * Named roots.\n * This is where pbjs stores generated structures (the option `-r, --root` specifies a name).\n * Can also be used manually to make roots available accross modules.\n * @name roots\n * @type {Object.<string,Root>}\n * @example\n * // pbjs -r myroot -o compiled.js ...\n *\n * // in another module:\n * require(\"./compiled.js\");\n *\n * // in any subsequent module:\n * var root = protobuf.roots[\"myroot\"];\n */\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar pbDecode = require('./pb-decode.js');\nvar pbEncode = require('./pb-encode.js');\nvar util = require('./util.js');\n\nconst name = 'dag-pb';\nconst code = 112;\nfunction encode(node) {\n util.validate(node);\n const pbn = {};\n if (node.Links) {\n pbn.Links = node.Links.map(l => {\n const link = {};\n if (l.Hash) {\n link.Hash = l.Hash.bytes;\n }\n if (l.Name !== undefined) {\n link.Name = l.Name;\n }\n if (l.Tsize !== undefined) {\n link.Tsize = l.Tsize;\n }\n return link;\n });\n }\n if (node.Data) {\n pbn.Data = node.Data;\n }\n return pbEncode.encodeNode(pbn);\n}\nfunction decode(bytes) {\n const pbn = pbDecode.decodeNode(bytes);\n const node = {};\n if (pbn.Data) {\n node.Data = pbn.Data;\n }\n if (pbn.Links) {\n node.Links = pbn.Links.map(l => {\n const link = {};\n try {\n link.Hash = cid.CID.decode(l.Hash);\n } catch (e) {\n }\n if (!link.Hash) {\n throw new Error('Invalid Hash field found in link, expected CID');\n }\n if (l.Name !== undefined) {\n link.Name = l.Name;\n }\n if (l.Tsize !== undefined) {\n link.Tsize = l.Tsize;\n }\n return link;\n });\n }\n return node;\n}\n\nexports.createLink = util.createLink;\nexports.createNode = util.createNode;\nexports.prepare = util.prepare;\nexports.validate = util.validate;\nexports.code = code;\nexports.decode = decode;\nexports.encode = encode;\nexports.name = name;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar varint = require('./varint.js');\nvar digest = require('./hashes/digest.js');\nvar base58 = require('./bases/base58.js');\nvar base32 = require('./bases/base32.js');\nvar bytes = require('./bytes.js');\n\nclass CID {\n constructor(version, code, multihash, bytes) {\n this.code = code;\n this.version = version;\n this.multihash = multihash;\n this.bytes = bytes;\n this.byteOffset = bytes.byteOffset;\n this.byteLength = bytes.byteLength;\n this.asCID = this;\n this._baseCache = new Map();\n Object.defineProperties(this, {\n byteOffset: hidden,\n byteLength: hidden,\n code: readonly,\n version: readonly,\n multihash: readonly,\n bytes: readonly,\n _baseCache: hidden,\n asCID: hidden\n });\n }\n toV0() {\n switch (this.version) {\n case 0: {\n return this;\n }\n default: {\n const {code, multihash} = this;\n if (code !== DAG_PB_CODE) {\n throw new Error('Cannot convert a non dag-pb CID to CIDv0');\n }\n if (multihash.code !== SHA_256_CODE) {\n throw new Error('Cannot convert non sha2-256 multihash CID to CIDv0');\n }\n return CID.createV0(multihash);\n }\n }\n }\n toV1() {\n switch (this.version) {\n case 0: {\n const {code, digest: digest$1} = this.multihash;\n const multihash = digest.create(code, digest$1);\n return CID.createV1(this.code, multihash);\n }\n case 1: {\n return this;\n }\n default: {\n throw Error(`Can not convert CID version ${ this.version } to version 0. This is a bug please report`);\n }\n }\n }\n equals(other) {\n return other && this.code === other.code && this.version === other.version && digest.equals(this.multihash, other.multihash);\n }\n toString(base) {\n const {bytes, version, _baseCache} = this;\n switch (version) {\n case 0:\n return toStringV0(bytes, _baseCache, base || base58.base58btc.encoder);\n default:\n return toStringV1(bytes, _baseCache, base || base32.base32.encoder);\n }\n }\n toJSON() {\n return {\n code: this.code,\n version: this.version,\n hash: this.multihash.bytes\n };\n }\n get [Symbol.toStringTag]() {\n return 'CID';\n }\n [Symbol.for('nodejs.util.inspect.custom')]() {\n return 'CID(' + this.toString() + ')';\n }\n static isCID(value) {\n deprecate(/^0\\.0/, IS_CID_DEPRECATION);\n return !!(value && (value[cidSymbol] || value.asCID === value));\n }\n get toBaseEncodedString() {\n throw new Error('Deprecated, use .toString()');\n }\n get codec() {\n throw new Error('\"codec\" property is deprecated, use integer \"code\" property instead');\n }\n get buffer() {\n throw new Error('Deprecated .buffer property, use .bytes to get Uint8Array instead');\n }\n get multibaseName() {\n throw new Error('\"multibaseName\" property is deprecated');\n }\n get prefix() {\n throw new Error('\"prefix\" property is deprecated');\n }\n static asCID(value) {\n if (value instanceof CID) {\n return value;\n } else if (value != null && value.asCID === value) {\n const {version, code, multihash, bytes} = value;\n return new CID(version, code, multihash, bytes || encodeCID(version, code, multihash.bytes));\n } else if (value != null && value[cidSymbol] === true) {\n const {version, multihash, code} = value;\n const digest$1 = digest.decode(multihash);\n return CID.create(version, code, digest$1);\n } else {\n return null;\n }\n }\n static create(version, code, digest) {\n if (typeof code !== 'number') {\n throw new Error('String codecs are no longer supported');\n }\n switch (version) {\n case 0: {\n if (code !== DAG_PB_CODE) {\n throw new Error(`Version 0 CID must use dag-pb (code: ${ DAG_PB_CODE }) block encoding`);\n } else {\n return new CID(version, code, digest, digest.bytes);\n }\n }\n case 1: {\n const bytes = encodeCID(version, code, digest.bytes);\n return new CID(version, code, digest, bytes);\n }\n default: {\n throw new Error('Invalid version');\n }\n }\n }\n static createV0(digest) {\n return CID.create(0, DAG_PB_CODE, digest);\n }\n static createV1(code, digest) {\n return CID.create(1, code, digest);\n }\n static decode(bytes) {\n const [cid, remainder] = CID.decodeFirst(bytes);\n if (remainder.length) {\n throw new Error('Incorrect length');\n }\n return cid;\n }\n static decodeFirst(bytes$1) {\n const specs = CID.inspectBytes(bytes$1);\n const prefixSize = specs.size - specs.multihashSize;\n const multihashBytes = bytes.coerce(bytes$1.subarray(prefixSize, prefixSize + specs.multihashSize));\n if (multihashBytes.byteLength !== specs.multihashSize) {\n throw new Error('Incorrect length');\n }\n const digestBytes = multihashBytes.subarray(specs.multihashSize - specs.digestSize);\n const digest$1 = new digest.Digest(specs.multihashCode, specs.digestSize, digestBytes, multihashBytes);\n const cid = specs.version === 0 ? CID.createV0(digest$1) : CID.createV1(specs.codec, digest$1);\n return [\n cid,\n bytes$1.subarray(specs.size)\n ];\n }\n static inspectBytes(initialBytes) {\n let offset = 0;\n const next = () => {\n const [i, length] = varint.decode(initialBytes.subarray(offset));\n offset += length;\n return i;\n };\n let version = next();\n let codec = DAG_PB_CODE;\n if (version === 18) {\n version = 0;\n offset = 0;\n } else if (version === 1) {\n codec = next();\n }\n if (version !== 0 && version !== 1) {\n throw new RangeError(`Invalid CID version ${ version }`);\n }\n const prefixSize = offset;\n const multihashCode = next();\n const digestSize = next();\n const size = offset + digestSize;\n const multihashSize = size - prefixSize;\n return {\n version,\n codec,\n multihashCode,\n digestSize,\n multihashSize,\n size\n };\n }\n static parse(source, base) {\n const [prefix, bytes] = parseCIDtoBytes(source, base);\n const cid = CID.decode(bytes);\n cid._baseCache.set(prefix, source);\n return cid;\n }\n}\nconst parseCIDtoBytes = (source, base) => {\n switch (source[0]) {\n case 'Q': {\n const decoder = base || base58.base58btc;\n return [\n base58.base58btc.prefix,\n decoder.decode(`${ base58.base58btc.prefix }${ source }`)\n ];\n }\n case base58.base58btc.prefix: {\n const decoder = base || base58.base58btc;\n return [\n base58.base58btc.prefix,\n decoder.decode(source)\n ];\n }\n case base32.base32.prefix: {\n const decoder = base || base32.base32;\n return [\n base32.base32.prefix,\n decoder.decode(source)\n ];\n }\n default: {\n if (base == null) {\n throw Error('To parse non base32 or base58btc encoded CID multibase decoder must be provided');\n }\n return [\n source[0],\n base.decode(source)\n ];\n }\n }\n};\nconst toStringV0 = (bytes, cache, base) => {\n const {prefix} = base;\n if (prefix !== base58.base58btc.prefix) {\n throw Error(`Cannot string encode V0 in ${ base.name } encoding`);\n }\n const cid = cache.get(prefix);\n if (cid == null) {\n const cid = base.encode(bytes).slice(1);\n cache.set(prefix, cid);\n return cid;\n } else {\n return cid;\n }\n};\nconst toStringV1 = (bytes, cache, base) => {\n const {prefix} = base;\n const cid = cache.get(prefix);\n if (cid == null) {\n const cid = base.encode(bytes);\n cache.set(prefix, cid);\n return cid;\n } else {\n return cid;\n }\n};\nconst DAG_PB_CODE = 112;\nconst SHA_256_CODE = 18;\nconst encodeCID = (version, code, multihash) => {\n const codeOffset = varint.encodingLength(version);\n const hashOffset = codeOffset + varint.encodingLength(code);\n const bytes = new Uint8Array(hashOffset + multihash.byteLength);\n varint.encodeTo(version, bytes, 0);\n varint.encodeTo(code, bytes, codeOffset);\n bytes.set(multihash, hashOffset);\n return bytes;\n};\nconst cidSymbol = Symbol.for('@ipld/js-cid/CID');\nconst readonly = {\n writable: false,\n configurable: false,\n enumerable: true\n};\nconst hidden = {\n writable: false,\n enumerable: false,\n configurable: false\n};\nconst version = '0.0.0-dev';\nconst deprecate = (range, message) => {\n if (range.test(version)) {\n console.warn(message);\n } else {\n throw new Error(message);\n }\n};\nconst IS_CID_DEPRECATION = `CID.isCID(v) is deprecated and will be removed in the next major release.\nFollowing code pattern:\n\nif (CID.isCID(value)) {\n doSomethingWithCID(value)\n}\n\nIs replaced with:\n\nconst cid = CID.asCID(value)\nif (cid) {\n // Make sure to use cid instead of value\n doSomethingWithCID(cid)\n}\n`;\n\nexports.CID = CID;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar varint$1 = require('../vendor/varint.js');\n\nconst decode = data => {\n const code = varint$1.decode(data);\n return [\n code,\n varint$1.decode.bytes\n ];\n};\nconst encodeTo = (int, target, offset = 0) => {\n varint$1.encode(int, target, offset);\n return target;\n};\nconst encodingLength = int => {\n return varint$1.encodingLength(int);\n};\n\nexports.decode = decode;\nexports.encodeTo = encodeTo;\nexports.encodingLength = encodingLength;\n","'use strict';\n\nvar encode_1 = encode;\nvar MSB = 128, REST = 127, MSBALL = ~REST, INT = Math.pow(2, 31);\nfunction encode(num, out, offset) {\n out = out || [];\n offset = offset || 0;\n var oldOffset = offset;\n while (num >= INT) {\n out[offset++] = num & 255 | MSB;\n num /= 128;\n }\n while (num & MSBALL) {\n out[offset++] = num & 255 | MSB;\n num >>>= 7;\n }\n out[offset] = num | 0;\n encode.bytes = offset - oldOffset + 1;\n return out;\n}\nvar decode = read;\nvar MSB$1 = 128, REST$1 = 127;\nfunction read(buf, offset) {\n var res = 0, offset = offset || 0, shift = 0, counter = offset, b, l = buf.length;\n do {\n if (counter >= l) {\n read.bytes = 0;\n throw new RangeError('Could not decode varint');\n }\n b = buf[counter++];\n res += shift < 28 ? (b & REST$1) << shift : (b & REST$1) * Math.pow(2, shift);\n shift += 7;\n } while (b >= MSB$1);\n read.bytes = counter - offset;\n return res;\n}\nvar N1 = Math.pow(2, 7);\nvar N2 = Math.pow(2, 14);\nvar N3 = Math.pow(2, 21);\nvar N4 = Math.pow(2, 28);\nvar N5 = Math.pow(2, 35);\nvar N6 = Math.pow(2, 42);\nvar N7 = Math.pow(2, 49);\nvar N8 = Math.pow(2, 56);\nvar N9 = Math.pow(2, 63);\nvar length = function (value) {\n return value < N1 ? 1 : value < N2 ? 2 : value < N3 ? 3 : value < N4 ? 4 : value < N5 ? 5 : value < N6 ? 6 : value < N7 ? 7 : value < N8 ? 8 : value < N9 ? 9 : 10;\n};\nvar varint = {\n encode: encode_1,\n decode: decode,\n encodingLength: length\n};\nvar _brrp_varint = varint;\nvar varint$1 = _brrp_varint;\n\nmodule.exports = varint$1;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bytes = require('../bytes.js');\nvar varint = require('../varint.js');\n\nconst create = (code, digest) => {\n const size = digest.byteLength;\n const sizeOffset = varint.encodingLength(code);\n const digestOffset = sizeOffset + varint.encodingLength(size);\n const bytes = new Uint8Array(digestOffset + size);\n varint.encodeTo(code, bytes, 0);\n varint.encodeTo(size, bytes, sizeOffset);\n bytes.set(digest, digestOffset);\n return new Digest(code, size, digest, bytes);\n};\nconst decode = multihash => {\n const bytes$1 = bytes.coerce(multihash);\n const [code, sizeOffset] = varint.decode(bytes$1);\n const [size, digestOffset] = varint.decode(bytes$1.subarray(sizeOffset));\n const digest = bytes$1.subarray(sizeOffset + digestOffset);\n if (digest.byteLength !== size) {\n throw new Error('Incorrect length');\n }\n return new Digest(code, size, digest, bytes$1);\n};\nconst equals = (a, b) => {\n if (a === b) {\n return true;\n } else {\n return a.code === b.code && a.size === b.size && bytes.equals(a.bytes, b.bytes);\n }\n};\nclass Digest {\n constructor(code, size, digest, bytes) {\n this.code = code;\n this.size = size;\n this.digest = digest;\n this.bytes = bytes;\n }\n}\n\nexports.Digest = Digest;\nexports.create = create;\nexports.decode = decode;\nexports.equals = equals;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst empty = new Uint8Array(0);\nconst toHex = d => d.reduce((hex, byte) => hex + byte.toString(16).padStart(2, '0'), '');\nconst fromHex = hex => {\n const hexes = hex.match(/../g);\n return hexes ? new Uint8Array(hexes.map(b => parseInt(b, 16))) : empty;\n};\nconst equals = (aa, bb) => {\n if (aa === bb)\n return true;\n if (aa.byteLength !== bb.byteLength) {\n return false;\n }\n for (let ii = 0; ii < aa.byteLength; ii++) {\n if (aa[ii] !== bb[ii]) {\n return false;\n }\n }\n return true;\n};\nconst coerce = o => {\n if (o instanceof Uint8Array && o.constructor.name === 'Uint8Array')\n return o;\n if (o instanceof ArrayBuffer)\n return new Uint8Array(o);\n if (ArrayBuffer.isView(o)) {\n return new Uint8Array(o.buffer, o.byteOffset, o.byteLength);\n }\n throw new Error('Unknown type, must be binary type');\n};\nconst isBinary = o => o instanceof ArrayBuffer || ArrayBuffer.isView(o);\nconst fromString = str => new TextEncoder().encode(str);\nconst toString = b => new TextDecoder().decode(b);\n\nexports.coerce = coerce;\nexports.empty = empty;\nexports.equals = equals;\nexports.fromHex = fromHex;\nexports.fromString = fromString;\nexports.isBinary = isBinary;\nexports.toHex = toHex;\nexports.toString = toString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base58btc = base.baseX({\n name: 'base58btc',\n prefix: 'z',\n alphabet: '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz'\n});\nconst base58flickr = base.baseX({\n name: 'base58flickr',\n prefix: 'Z',\n alphabet: '123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ'\n});\n\nexports.base58btc = base58btc;\nexports.base58flickr = base58flickr;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar baseX$1 = require('../../vendor/base-x.js');\nvar bytes = require('../bytes.js');\n\nclass Encoder {\n constructor(name, prefix, baseEncode) {\n this.name = name;\n this.prefix = prefix;\n this.baseEncode = baseEncode;\n }\n encode(bytes) {\n if (bytes instanceof Uint8Array) {\n return `${ this.prefix }${ this.baseEncode(bytes) }`;\n } else {\n throw Error('Unknown type, must be binary type');\n }\n }\n}\nclass Decoder {\n constructor(name, prefix, baseDecode) {\n this.name = name;\n this.prefix = prefix;\n this.baseDecode = baseDecode;\n }\n decode(text) {\n if (typeof text === 'string') {\n switch (text[0]) {\n case this.prefix: {\n return this.baseDecode(text.slice(1));\n }\n default: {\n throw Error(`Unable to decode multibase string ${ JSON.stringify(text) }, ${ this.name } decoder only supports inputs prefixed with ${ this.prefix }`);\n }\n }\n } else {\n throw Error('Can only multibase decode strings');\n }\n }\n or(decoder) {\n return or(this, decoder);\n }\n}\nclass ComposedDecoder {\n constructor(decoders) {\n this.decoders = decoders;\n }\n or(decoder) {\n return or(this, decoder);\n }\n decode(input) {\n const prefix = input[0];\n const decoder = this.decoders[prefix];\n if (decoder) {\n return decoder.decode(input);\n } else {\n throw RangeError(`Unable to decode multibase string ${ JSON.stringify(input) }, only inputs prefixed with ${ Object.keys(this.decoders) } are supported`);\n }\n }\n}\nconst or = (left, right) => new ComposedDecoder({\n ...left.decoders || { [left.prefix]: left },\n ...right.decoders || { [right.prefix]: right }\n});\nclass Codec {\n constructor(name, prefix, baseEncode, baseDecode) {\n this.name = name;\n this.prefix = prefix;\n this.baseEncode = baseEncode;\n this.baseDecode = baseDecode;\n this.encoder = new Encoder(name, prefix, baseEncode);\n this.decoder = new Decoder(name, prefix, baseDecode);\n }\n encode(input) {\n return this.encoder.encode(input);\n }\n decode(input) {\n return this.decoder.decode(input);\n }\n}\nconst from = ({name, prefix, encode, decode}) => new Codec(name, prefix, encode, decode);\nconst baseX = ({prefix, name, alphabet}) => {\n const {encode, decode} = baseX$1(alphabet, name);\n return from({\n prefix,\n name,\n encode,\n decode: text => bytes.coerce(decode(text))\n });\n};\nconst decode = (string, alphabet, bitsPerChar, name) => {\n const codes = {};\n for (let i = 0; i < alphabet.length; ++i) {\n codes[alphabet[i]] = i;\n }\n let end = string.length;\n while (string[end - 1] === '=') {\n --end;\n }\n const out = new Uint8Array(end * bitsPerChar / 8 | 0);\n let bits = 0;\n let buffer = 0;\n let written = 0;\n for (let i = 0; i < end; ++i) {\n const value = codes[string[i]];\n if (value === undefined) {\n throw new SyntaxError(`Non-${ name } character`);\n }\n buffer = buffer << bitsPerChar | value;\n bits += bitsPerChar;\n if (bits >= 8) {\n bits -= 8;\n out[written++] = 255 & buffer >> bits;\n }\n }\n if (bits >= bitsPerChar || 255 & buffer << 8 - bits) {\n throw new SyntaxError('Unexpected end of data');\n }\n return out;\n};\nconst encode = (data, alphabet, bitsPerChar) => {\n const pad = alphabet[alphabet.length - 1] === '=';\n const mask = (1 << bitsPerChar) - 1;\n let out = '';\n let bits = 0;\n let buffer = 0;\n for (let i = 0; i < data.length; ++i) {\n buffer = buffer << 8 | data[i];\n bits += 8;\n while (bits > bitsPerChar) {\n bits -= bitsPerChar;\n out += alphabet[mask & buffer >> bits];\n }\n }\n if (bits) {\n out += alphabet[mask & buffer << bitsPerChar - bits];\n }\n if (pad) {\n while (out.length * bitsPerChar & 7) {\n out += '=';\n }\n }\n return out;\n};\nconst rfc4648 = ({name, prefix, bitsPerChar, alphabet}) => {\n return from({\n prefix,\n name,\n encode(input) {\n return encode(input, alphabet, bitsPerChar);\n },\n decode(input) {\n return decode(input, alphabet, bitsPerChar, name);\n }\n });\n};\n\nexports.Codec = Codec;\nexports.baseX = baseX;\nexports.from = from;\nexports.or = or;\nexports.rfc4648 = rfc4648;\n","'use strict';\n\nfunction base(ALPHABET, name) {\n if (ALPHABET.length >= 255) {\n throw new TypeError('Alphabet too long');\n }\n var BASE_MAP = new Uint8Array(256);\n for (var j = 0; j < BASE_MAP.length; j++) {\n BASE_MAP[j] = 255;\n }\n for (var i = 0; i < ALPHABET.length; i++) {\n var x = ALPHABET.charAt(i);\n var xc = x.charCodeAt(0);\n if (BASE_MAP[xc] !== 255) {\n throw new TypeError(x + ' is ambiguous');\n }\n BASE_MAP[xc] = i;\n }\n var BASE = ALPHABET.length;\n var LEADER = ALPHABET.charAt(0);\n var FACTOR = Math.log(BASE) / Math.log(256);\n var iFACTOR = Math.log(256) / Math.log(BASE);\n function encode(source) {\n if (source instanceof Uint8Array);\n else if (ArrayBuffer.isView(source)) {\n source = new Uint8Array(source.buffer, source.byteOffset, source.byteLength);\n } else if (Array.isArray(source)) {\n source = Uint8Array.from(source);\n }\n if (!(source instanceof Uint8Array)) {\n throw new TypeError('Expected Uint8Array');\n }\n if (source.length === 0) {\n return '';\n }\n var zeroes = 0;\n var length = 0;\n var pbegin = 0;\n var pend = source.length;\n while (pbegin !== pend && source[pbegin] === 0) {\n pbegin++;\n zeroes++;\n }\n var size = (pend - pbegin) * iFACTOR + 1 >>> 0;\n var b58 = new Uint8Array(size);\n while (pbegin !== pend) {\n var carry = source[pbegin];\n var i = 0;\n for (var it1 = size - 1; (carry !== 0 || i < length) && it1 !== -1; it1--, i++) {\n carry += 256 * b58[it1] >>> 0;\n b58[it1] = carry % BASE >>> 0;\n carry = carry / BASE >>> 0;\n }\n if (carry !== 0) {\n throw new Error('Non-zero carry');\n }\n length = i;\n pbegin++;\n }\n var it2 = size - length;\n while (it2 !== size && b58[it2] === 0) {\n it2++;\n }\n var str = LEADER.repeat(zeroes);\n for (; it2 < size; ++it2) {\n str += ALPHABET.charAt(b58[it2]);\n }\n return str;\n }\n function decodeUnsafe(source) {\n if (typeof source !== 'string') {\n throw new TypeError('Expected String');\n }\n if (source.length === 0) {\n return new Uint8Array();\n }\n var psz = 0;\n if (source[psz] === ' ') {\n return;\n }\n var zeroes = 0;\n var length = 0;\n while (source[psz] === LEADER) {\n zeroes++;\n psz++;\n }\n var size = (source.length - psz) * FACTOR + 1 >>> 0;\n var b256 = new Uint8Array(size);\n while (source[psz]) {\n var carry = BASE_MAP[source.charCodeAt(psz)];\n if (carry === 255) {\n return;\n }\n var i = 0;\n for (var it3 = size - 1; (carry !== 0 || i < length) && it3 !== -1; it3--, i++) {\n carry += BASE * b256[it3] >>> 0;\n b256[it3] = carry % 256 >>> 0;\n carry = carry / 256 >>> 0;\n }\n if (carry !== 0) {\n throw new Error('Non-zero carry');\n }\n length = i;\n psz++;\n }\n if (source[psz] === ' ') {\n return;\n }\n var it4 = size - length;\n while (it4 !== size && b256[it4] === 0) {\n it4++;\n }\n var vch = new Uint8Array(zeroes + (size - it4));\n var j = zeroes;\n while (it4 !== size) {\n vch[j++] = b256[it4++];\n }\n return vch;\n }\n function decode(string) {\n var buffer = decodeUnsafe(string);\n if (buffer) {\n return buffer;\n }\n throw new Error(`Non-${ name } character`);\n }\n return {\n encode: encode,\n decodeUnsafe: decodeUnsafe,\n decode: decode\n };\n}\nvar src = base;\nvar _brrp__multiformats_scope_baseX = src;\n\nmodule.exports = _brrp__multiformats_scope_baseX;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base32 = base.rfc4648({\n prefix: 'b',\n name: 'base32',\n alphabet: 'abcdefghijklmnopqrstuvwxyz234567',\n bitsPerChar: 5\n});\nconst base32upper = base.rfc4648({\n prefix: 'B',\n name: 'base32upper',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZ234567',\n bitsPerChar: 5\n});\nconst base32pad = base.rfc4648({\n prefix: 'c',\n name: 'base32pad',\n alphabet: 'abcdefghijklmnopqrstuvwxyz234567=',\n bitsPerChar: 5\n});\nconst base32padupper = base.rfc4648({\n prefix: 'C',\n name: 'base32padupper',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=',\n bitsPerChar: 5\n});\nconst base32hex = base.rfc4648({\n prefix: 'v',\n name: 'base32hex',\n alphabet: '0123456789abcdefghijklmnopqrstuv',\n bitsPerChar: 5\n});\nconst base32hexupper = base.rfc4648({\n prefix: 'V',\n name: 'base32hexupper',\n alphabet: '0123456789ABCDEFGHIJKLMNOPQRSTUV',\n bitsPerChar: 5\n});\nconst base32hexpad = base.rfc4648({\n prefix: 't',\n name: 'base32hexpad',\n alphabet: '0123456789abcdefghijklmnopqrstuv=',\n bitsPerChar: 5\n});\nconst base32hexpadupper = base.rfc4648({\n prefix: 'T',\n name: 'base32hexpadupper',\n alphabet: '0123456789ABCDEFGHIJKLMNOPQRSTUV=',\n bitsPerChar: 5\n});\nconst base32z = base.rfc4648({\n prefix: 'h',\n name: 'base32z',\n alphabet: 'ybndrfg8ejkmcpqxot1uwisza345h769',\n bitsPerChar: 5\n});\n\nexports.base32 = base32;\nexports.base32hex = base32hex;\nexports.base32hexpad = base32hexpad;\nexports.base32hexpadupper = base32hexpadupper;\nexports.base32hexupper = base32hexupper;\nexports.base32pad = base32pad;\nexports.base32padupper = base32padupper;\nexports.base32upper = base32upper;\nexports.base32z = base32z;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst textDecoder = new TextDecoder();\nfunction decodeVarint(bytes, offset) {\n let v = 0;\n for (let shift = 0;; shift += 7) {\n if (shift >= 64) {\n throw new Error('protobuf: varint overflow');\n }\n if (offset >= bytes.length) {\n throw new Error('protobuf: unexpected end of data');\n }\n const b = bytes[offset++];\n v += shift < 28 ? (b & 127) << shift : (b & 127) * 2 ** shift;\n if (b < 128) {\n break;\n }\n }\n return [\n v,\n offset\n ];\n}\nfunction decodeBytes(bytes, offset) {\n let byteLen;\n [byteLen, offset] = decodeVarint(bytes, offset);\n const postOffset = offset + byteLen;\n if (byteLen < 0 || postOffset < 0) {\n throw new Error('protobuf: invalid length');\n }\n if (postOffset > bytes.length) {\n throw new Error('protobuf: unexpected end of data');\n }\n return [\n bytes.subarray(offset, postOffset),\n postOffset\n ];\n}\nfunction decodeKey(bytes, index) {\n let wire;\n [wire, index] = decodeVarint(bytes, index);\n return [\n wire & 7,\n wire >> 3,\n index\n ];\n}\nfunction decodeLink(bytes) {\n const link = {};\n const l = bytes.length;\n let index = 0;\n while (index < l) {\n let wireType, fieldNum;\n [wireType, fieldNum, index] = decodeKey(bytes, index);\n if (fieldNum === 1) {\n if (link.Hash) {\n throw new Error('protobuf: (PBLink) duplicate Hash section');\n }\n if (wireType !== 2) {\n throw new Error(`protobuf: (PBLink) wrong wireType (${ wireType }) for Hash`);\n }\n if (link.Name !== undefined) {\n throw new Error('protobuf: (PBLink) invalid order, found Name before Hash');\n }\n if (link.Tsize !== undefined) {\n throw new Error('protobuf: (PBLink) invalid order, found Tsize before Hash');\n }\n ;\n [link.Hash, index] = decodeBytes(bytes, index);\n } else if (fieldNum === 2) {\n if (link.Name !== undefined) {\n throw new Error('protobuf: (PBLink) duplicate Name section');\n }\n if (wireType !== 2) {\n throw new Error(`protobuf: (PBLink) wrong wireType (${ wireType }) for Name`);\n }\n if (link.Tsize !== undefined) {\n throw new Error('protobuf: (PBLink) invalid order, found Tsize before Name');\n }\n let byts;\n [byts, index] = decodeBytes(bytes, index);\n link.Name = textDecoder.decode(byts);\n } else if (fieldNum === 3) {\n if (link.Tsize !== undefined) {\n throw new Error('protobuf: (PBLink) duplicate Tsize section');\n }\n if (wireType !== 0) {\n throw new Error(`protobuf: (PBLink) wrong wireType (${ wireType }) for Tsize`);\n }\n ;\n [link.Tsize, index] = decodeVarint(bytes, index);\n } else {\n throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${ fieldNum }`);\n }\n }\n if (index > l) {\n throw new Error('protobuf: (PBLink) unexpected end of data');\n }\n return link;\n}\nfunction decodeNode(bytes) {\n const l = bytes.length;\n let index = 0;\n let links;\n let linksBeforeData = false;\n let data;\n while (index < l) {\n let wireType, fieldNum;\n [wireType, fieldNum, index] = decodeKey(bytes, index);\n if (wireType !== 2) {\n throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${ wireType }`);\n }\n if (fieldNum === 1) {\n if (data) {\n throw new Error('protobuf: (PBNode) duplicate Data section');\n }\n ;\n [data, index] = decodeBytes(bytes, index);\n if (links) {\n linksBeforeData = true;\n }\n } else if (fieldNum === 2) {\n if (linksBeforeData) {\n throw new Error('protobuf: (PBNode) duplicate Links section');\n } else if (!links) {\n links = [];\n }\n let byts;\n [byts, index] = decodeBytes(bytes, index);\n links.push(decodeLink(byts));\n } else {\n throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${ fieldNum }`);\n }\n }\n if (index > l) {\n throw new Error('protobuf: (PBNode) unexpected end of data');\n }\n const node = {};\n if (data) {\n node.Data = data;\n }\n node.Links = links || [];\n return node;\n}\n\nexports.decodeNode = decodeNode;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst textEncoder = new TextEncoder();\nconst maxInt32 = 2 ** 32;\nconst maxUInt32 = 2 ** 31;\nfunction encodeLink(link, bytes) {\n let i = bytes.length;\n if (typeof link.Tsize === 'number') {\n if (link.Tsize < 0) {\n throw new Error('Tsize cannot be negative');\n }\n if (!Number.isSafeInteger(link.Tsize)) {\n throw new Error('Tsize too large for encoding');\n }\n i = encodeVarint(bytes, i, link.Tsize) - 1;\n bytes[i] = 24;\n }\n if (typeof link.Name === 'string') {\n const nameBytes = textEncoder.encode(link.Name);\n i -= nameBytes.length;\n bytes.set(nameBytes, i);\n i = encodeVarint(bytes, i, nameBytes.length) - 1;\n bytes[i] = 18;\n }\n if (link.Hash) {\n i -= link.Hash.length;\n bytes.set(link.Hash, i);\n i = encodeVarint(bytes, i, link.Hash.length) - 1;\n bytes[i] = 10;\n }\n return bytes.length - i;\n}\nfunction encodeNode(node) {\n const size = sizeNode(node);\n const bytes = new Uint8Array(size);\n let i = size;\n if (node.Data) {\n i -= node.Data.length;\n bytes.set(node.Data, i);\n i = encodeVarint(bytes, i, node.Data.length) - 1;\n bytes[i] = 10;\n }\n if (node.Links) {\n for (let index = node.Links.length - 1; index >= 0; index--) {\n const size = encodeLink(node.Links[index], bytes.subarray(0, i));\n i -= size;\n i = encodeVarint(bytes, i, size) - 1;\n bytes[i] = 18;\n }\n }\n return bytes;\n}\nfunction sizeLink(link) {\n let n = 0;\n if (link.Hash) {\n const l = link.Hash.length;\n n += 1 + l + sov(l);\n }\n if (typeof link.Name === 'string') {\n const l = textEncoder.encode(link.Name).length;\n n += 1 + l + sov(l);\n }\n if (typeof link.Tsize === 'number') {\n n += 1 + sov(link.Tsize);\n }\n return n;\n}\nfunction sizeNode(node) {\n let n = 0;\n if (node.Data) {\n const l = node.Data.length;\n n += 1 + l + sov(l);\n }\n if (node.Links) {\n for (const link of node.Links) {\n const l = sizeLink(link);\n n += 1 + l + sov(l);\n }\n }\n return n;\n}\nfunction encodeVarint(bytes, offset, v) {\n offset -= sov(v);\n const base = offset;\n while (v >= maxUInt32) {\n bytes[offset++] = v & 127 | 128;\n v /= 128;\n }\n while (v >= 128) {\n bytes[offset++] = v & 127 | 128;\n v >>>= 7;\n }\n bytes[offset] = v;\n return base;\n}\nfunction sov(x) {\n if (x % 2 === 0) {\n x++;\n }\n return Math.floor((len64(x) + 6) / 7);\n}\nfunction len64(x) {\n let n = 0;\n if (x >= maxInt32) {\n x = Math.floor(x / maxInt32);\n n = 32;\n }\n if (x >= 1 << 16) {\n x >>>= 16;\n n += 16;\n }\n if (x >= 1 << 8) {\n x >>>= 8;\n n += 8;\n }\n return n + len8tab[x];\n}\nconst len8tab = [\n 0,\n 1,\n 2,\n 2,\n 3,\n 3,\n 3,\n 3,\n 4,\n 4,\n 4,\n 4,\n 4,\n 4,\n 4,\n 4,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 5,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 6,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 7,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8,\n 8\n];\n\nexports.encodeNode = encodeNode;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\n\nconst pbNodeProperties = [\n 'Data',\n 'Links'\n];\nconst pbLinkProperties = [\n 'Hash',\n 'Name',\n 'Tsize'\n];\nconst textEncoder = new TextEncoder();\nfunction linkComparator(a, b) {\n if (a === b) {\n return 0;\n }\n const abuf = a.Name ? textEncoder.encode(a.Name) : [];\n const bbuf = b.Name ? textEncoder.encode(b.Name) : [];\n let x = abuf.length;\n let y = bbuf.length;\n for (let i = 0, len = Math.min(x, y); i < len; ++i) {\n if (abuf[i] !== bbuf[i]) {\n x = abuf[i];\n y = bbuf[i];\n break;\n }\n }\n return x < y ? -1 : y < x ? 1 : 0;\n}\nfunction hasOnlyProperties(node, properties) {\n return !Object.keys(node).some(p => !properties.includes(p));\n}\nfunction asLink(link) {\n if (typeof link.asCID === 'object') {\n const Hash = cid.CID.asCID(link);\n if (!Hash) {\n throw new TypeError('Invalid DAG-PB form');\n }\n return { Hash };\n }\n if (typeof link !== 'object' || Array.isArray(link)) {\n throw new TypeError('Invalid DAG-PB form');\n }\n const pbl = {};\n if (link.Hash) {\n let cid$1 = cid.CID.asCID(link.Hash);\n try {\n if (!cid$1) {\n if (typeof link.Hash === 'string') {\n cid$1 = cid.CID.parse(link.Hash);\n } else if (link.Hash instanceof Uint8Array) {\n cid$1 = cid.CID.decode(link.Hash);\n }\n }\n } catch (e) {\n throw new TypeError(`Invalid DAG-PB form: ${ e.message }`);\n }\n if (cid$1) {\n pbl.Hash = cid$1;\n }\n }\n if (!pbl.Hash) {\n throw new TypeError('Invalid DAG-PB form');\n }\n if (typeof link.Name === 'string') {\n pbl.Name = link.Name;\n }\n if (typeof link.Tsize === 'number') {\n pbl.Tsize = link.Tsize;\n }\n return pbl;\n}\nfunction prepare(node) {\n if (node instanceof Uint8Array || typeof node === 'string') {\n node = { Data: node };\n }\n if (typeof node !== 'object' || Array.isArray(node)) {\n throw new TypeError('Invalid DAG-PB form');\n }\n const pbn = {};\n if (node.Data !== undefined) {\n if (typeof node.Data === 'string') {\n pbn.Data = textEncoder.encode(node.Data);\n } else if (node.Data instanceof Uint8Array) {\n pbn.Data = node.Data;\n } else {\n throw new TypeError('Invalid DAG-PB form');\n }\n }\n if (node.Links !== undefined) {\n if (Array.isArray(node.Links)) {\n pbn.Links = node.Links.map(asLink);\n pbn.Links.sort(linkComparator);\n } else {\n throw new TypeError('Invalid DAG-PB form');\n }\n } else {\n pbn.Links = [];\n }\n return pbn;\n}\nfunction validate(node) {\n if (!node || typeof node !== 'object' || Array.isArray(node)) {\n throw new TypeError('Invalid DAG-PB form');\n }\n if (!hasOnlyProperties(node, pbNodeProperties)) {\n throw new TypeError('Invalid DAG-PB form (extraneous properties)');\n }\n if (node.Data !== undefined && !(node.Data instanceof Uint8Array)) {\n throw new TypeError('Invalid DAG-PB form (Data must be a Uint8Array)');\n }\n if (!Array.isArray(node.Links)) {\n throw new TypeError('Invalid DAG-PB form (Links must be an array)');\n }\n for (let i = 0; i < node.Links.length; i++) {\n const link = node.Links[i];\n if (!link || typeof link !== 'object' || Array.isArray(link)) {\n throw new TypeError('Invalid DAG-PB form (bad link object)');\n }\n if (!hasOnlyProperties(link, pbLinkProperties)) {\n throw new TypeError('Invalid DAG-PB form (extraneous properties on link object)');\n }\n if (!link.Hash) {\n throw new TypeError('Invalid DAG-PB form (link must have a Hash)');\n }\n if (link.Hash.asCID !== link.Hash) {\n throw new TypeError('Invalid DAG-PB form (link Hash must be a CID)');\n }\n if (link.Name !== undefined && typeof link.Name !== 'string') {\n throw new TypeError('Invalid DAG-PB form (link Name must be a string)');\n }\n if (link.Tsize !== undefined && (typeof link.Tsize !== 'number' || link.Tsize % 1 !== 0)) {\n throw new TypeError('Invalid DAG-PB form (link Tsize must be an integer)');\n }\n if (i > 0 && linkComparator(link, node.Links[i - 1]) === -1) {\n throw new TypeError('Invalid DAG-PB form (links must be sorted by Name bytes)');\n }\n }\n}\nfunction createNode(data, links = []) {\n return prepare({\n Data: data,\n Links: links\n });\n}\nfunction createLink(name, size, cid) {\n return asLink({\n Hash: cid,\n Name: name,\n Tsize: size\n });\n}\n\nexports.createLink = createLink;\nexports.createNode = createNode;\nexports.prepare = prepare;\nexports.validate = validate;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cborg = require('cborg');\nvar cid = require('multiformats/cid');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar cborg__namespace = /*#__PURE__*/_interopNamespace(cborg);\n\nconst CID_CBOR_TAG = 42;\nfunction cidEncoder(obj) {\n if (obj.asCID !== obj) {\n return null;\n }\n const cid$1 = cid.CID.asCID(obj);\n if (!cid$1) {\n return null;\n }\n const bytes = new Uint8Array(cid$1.bytes.byteLength + 1);\n bytes.set(cid$1.bytes, 1);\n return [\n new cborg__namespace.Token(cborg__namespace.Type.tag, CID_CBOR_TAG),\n new cborg__namespace.Token(cborg__namespace.Type.bytes, bytes)\n ];\n}\nfunction undefinedEncoder() {\n throw new Error('`undefined` is not supported by the IPLD Data Model and cannot be encoded');\n}\nfunction numberEncoder(num) {\n if (Number.isNaN(num)) {\n throw new Error('`NaN` is not supported by the IPLD Data Model and cannot be encoded');\n }\n if (num === Infinity || num === -Infinity) {\n throw new Error('`Infinity` and `-Infinity` is not supported by the IPLD Data Model and cannot be encoded');\n }\n return null;\n}\nconst encodeOptions = {\n float64: true,\n typeEncoders: {\n Object: cidEncoder,\n undefined: undefinedEncoder,\n number: numberEncoder\n }\n};\nfunction cidDecoder(bytes) {\n if (bytes[0] !== 0) {\n throw new Error('Invalid CID for CBOR tag 42; expected leading 0x00');\n }\n return cid.CID.decode(bytes.subarray(1));\n}\nconst decodeOptions = {\n allowIndefinite: false,\n allowUndefined: false,\n allowNaN: false,\n allowInfinity: false,\n allowBigInt: true,\n strict: true,\n useMaps: false,\n tags: []\n};\ndecodeOptions.tags[CID_CBOR_TAG] = cidDecoder;\nconst name = 'dag-cbor';\nconst code = 113;\nconst encode = node => cborg__namespace.encode(node, encodeOptions);\nconst decode = data => cborg__namespace.decode(data, decodeOptions);\n\nexports.code = code;\nexports.decode = decode;\nexports.encode = encode;\nexports.name = name;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar encode = require('./lib/encode.js');\nvar decode = require('./lib/decode.js');\nvar token = require('./lib/token.js');\n\n\n\nexports.encode = encode.encode;\nexports.decode = decode.decode;\nexports.Token = token.Token;\nexports.Type = token.Type;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar is = require('./is.js');\nvar token = require('./token.js');\nvar bl = require('./bl.js');\nvar common = require('./common.js');\nvar jump = require('./jump.js');\nvar byteUtils = require('./byte-utils.js');\nvar _0uint = require('./0uint.js');\nvar _1negint = require('./1negint.js');\nvar _2bytes = require('./2bytes.js');\nvar _3string = require('./3string.js');\nvar _4array = require('./4array.js');\nvar _5map = require('./5map.js');\nvar _6tag = require('./6tag.js');\nvar _7float = require('./7float.js');\n\nconst defaultEncodeOptions = {\n float64: false,\n mapSorter,\n quickEncodeToken: jump.quickEncodeToken\n};\nconst cborEncoders = [];\ncborEncoders[token.Type.uint.major] = _0uint.encodeUint;\ncborEncoders[token.Type.negint.major] = _1negint.encodeNegint;\ncborEncoders[token.Type.bytes.major] = _2bytes.encodeBytes;\ncborEncoders[token.Type.string.major] = _3string.encodeString;\ncborEncoders[token.Type.array.major] = _4array.encodeArray;\ncborEncoders[token.Type.map.major] = _5map.encodeMap;\ncborEncoders[token.Type.tag.major] = _6tag.encodeTag;\ncborEncoders[token.Type.float.major] = _7float.encodeFloat;\nconst buf = new bl.Bl();\nclass Ref {\n constructor(obj, parent) {\n this.obj = obj;\n this.parent = parent;\n }\n includes(obj) {\n let p = this;\n do {\n if (p.obj === obj) {\n return true;\n }\n } while (p = p.parent);\n return false;\n }\n static createCheck(stack, obj) {\n if (stack && stack.includes(obj)) {\n throw new Error(`${ common.encodeErrPrefix } object contains circular references`);\n }\n return new Ref(obj, stack);\n }\n}\nconst simpleTokens = {\n null: new token.Token(token.Type.null, null),\n undefined: new token.Token(token.Type.undefined, undefined),\n true: new token.Token(token.Type.true, true),\n false: new token.Token(token.Type.false, false),\n emptyArray: new token.Token(token.Type.array, 0),\n emptyMap: new token.Token(token.Type.map, 0)\n};\nconst typeEncoders = {\n number(obj, _typ, _options, _refStack) {\n if (!Number.isInteger(obj) || !Number.isSafeInteger(obj)) {\n return new token.Token(token.Type.float, obj);\n } else if (obj >= 0) {\n return new token.Token(token.Type.uint, obj);\n } else {\n return new token.Token(token.Type.negint, obj);\n }\n },\n bigint(obj, _typ, _options, _refStack) {\n if (obj >= BigInt(0)) {\n return new token.Token(token.Type.uint, obj);\n } else {\n return new token.Token(token.Type.negint, obj);\n }\n },\n Uint8Array(obj, _typ, _options, _refStack) {\n return new token.Token(token.Type.bytes, obj);\n },\n string(obj, _typ, _options, _refStack) {\n return new token.Token(token.Type.string, obj);\n },\n boolean(obj, _typ, _options, _refStack) {\n return obj ? simpleTokens.true : simpleTokens.false;\n },\n null(_obj, _typ, _options, _refStack) {\n return simpleTokens.null;\n },\n undefined(_obj, _typ, _options, _refStack) {\n return simpleTokens.undefined;\n },\n ArrayBuffer(obj, _typ, _options, _refStack) {\n return new token.Token(token.Type.bytes, new Uint8Array(obj));\n },\n DataView(obj, _typ, _options, _refStack) {\n return new token.Token(token.Type.bytes, new Uint8Array(obj.buffer, obj.byteOffset, obj.byteLength));\n },\n Array(obj, _typ, options, refStack) {\n if (!obj.length) {\n if (options.addBreakTokens === true) {\n return [\n simpleTokens.emptyArray,\n new token.Token(token.Type.break)\n ];\n }\n return simpleTokens.emptyArray;\n }\n refStack = Ref.createCheck(refStack, obj);\n const entries = [];\n let i = 0;\n for (const e of obj) {\n entries[i++] = objectToTokens(e, options, refStack);\n }\n if (options.addBreakTokens) {\n return [\n new token.Token(token.Type.array, obj.length),\n entries,\n new token.Token(token.Type.break)\n ];\n }\n return [\n new token.Token(token.Type.array, obj.length),\n entries\n ];\n },\n Object(obj, typ, options, refStack) {\n const isMap = typ !== 'Object';\n const keys = isMap ? obj.keys() : Object.keys(obj);\n const length = isMap ? obj.size : keys.length;\n if (!length) {\n if (options.addBreakTokens === true) {\n return [\n simpleTokens.emptyMap,\n new token.Token(token.Type.break)\n ];\n }\n return simpleTokens.emptyMap;\n }\n refStack = Ref.createCheck(refStack, obj);\n const entries = [];\n let i = 0;\n for (const key of keys) {\n entries[i++] = [\n objectToTokens(key, options, refStack),\n objectToTokens(isMap ? obj.get(key) : obj[key], options, refStack)\n ];\n }\n sortMapEntries(entries, options);\n if (options.addBreakTokens) {\n return [\n new token.Token(token.Type.map, length),\n entries,\n new token.Token(token.Type.break)\n ];\n }\n return [\n new token.Token(token.Type.map, length),\n entries\n ];\n }\n};\ntypeEncoders.Map = typeEncoders.Object;\ntypeEncoders.Buffer = typeEncoders.Uint8Array;\nfor (const typ of 'Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64'.split(' ')) {\n typeEncoders[`${ typ }Array`] = typeEncoders.DataView;\n}\nfunction objectToTokens(obj, options = {}, refStack) {\n const typ = is.is(obj);\n const customTypeEncoder = options && options.typeEncoders && options.typeEncoders[typ] || typeEncoders[typ];\n if (typeof customTypeEncoder === 'function') {\n const tokens = customTypeEncoder(obj, typ, options, refStack);\n if (tokens != null) {\n return tokens;\n }\n }\n const typeEncoder = typeEncoders[typ];\n if (!typeEncoder) {\n throw new Error(`${ common.encodeErrPrefix } unsupported type: ${ typ }`);\n }\n return typeEncoder(obj, typ, options, refStack);\n}\nfunction sortMapEntries(entries, options) {\n if (options.mapSorter) {\n entries.sort(options.mapSorter);\n }\n}\nfunction mapSorter(e1, e2) {\n const keyToken1 = Array.isArray(e1[0]) ? e1[0][0] : e1[0];\n const keyToken2 = Array.isArray(e2[0]) ? e2[0][0] : e2[0];\n if (keyToken1.type !== keyToken2.type) {\n return keyToken1.type.compare(keyToken2.type);\n }\n const major = keyToken1.type.major;\n const tcmp = cborEncoders[major].compareTokens(keyToken1, keyToken2);\n if (tcmp === 0) {\n console.warn('WARNING: complex key types used, CBOR key sorting guarantees are gone');\n }\n return tcmp;\n}\nfunction tokensToEncoded(buf, tokens, encoders, options) {\n if (Array.isArray(tokens)) {\n for (const token of tokens) {\n tokensToEncoded(buf, token, encoders, options);\n }\n } else {\n encoders[tokens.type.major](buf, tokens, options);\n }\n}\nfunction encodeCustom(data, encoders, options) {\n const tokens = objectToTokens(data, options);\n if (!Array.isArray(tokens) && options.quickEncodeToken) {\n const quickBytes = options.quickEncodeToken(tokens);\n if (quickBytes) {\n return quickBytes;\n }\n const encoder = encoders[tokens.type.major];\n if (encoder.encodedSize) {\n const size = encoder.encodedSize(tokens, options);\n const buf = new bl.Bl(size);\n encoder(buf, tokens, options);\n if (buf.chunks.length !== 1) {\n throw new Error(`Unexpected error: pre-calculated length for ${ tokens } was wrong`);\n }\n return byteUtils.asU8A(buf.chunks[0]);\n }\n }\n tokensToEncoded(buf, tokens, encoders, options);\n return buf.toBytes(true);\n}\nfunction encode(data, options) {\n options = Object.assign({}, defaultEncodeOptions, options);\n return encodeCustom(data, cborEncoders, options);\n}\n\nexports.Ref = Ref;\nexports.encode = encode;\nexports.encodeCustom = encodeCustom;\nexports.objectToTokens = objectToTokens;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst typeofs = [\n 'string',\n 'number',\n 'bigint',\n 'symbol'\n];\nconst objectTypeNames = [\n 'Function',\n 'Generator',\n 'AsyncGenerator',\n 'GeneratorFunction',\n 'AsyncGeneratorFunction',\n 'AsyncFunction',\n 'Observable',\n 'Array',\n 'Buffer',\n 'Object',\n 'RegExp',\n 'Date',\n 'Error',\n 'Map',\n 'Set',\n 'WeakMap',\n 'WeakSet',\n 'ArrayBuffer',\n 'SharedArrayBuffer',\n 'DataView',\n 'Promise',\n 'URL',\n 'HTMLElement',\n 'Int8Array',\n 'Uint8Array',\n 'Uint8ClampedArray',\n 'Int16Array',\n 'Uint16Array',\n 'Int32Array',\n 'Uint32Array',\n 'Float32Array',\n 'Float64Array',\n 'BigInt64Array',\n 'BigUint64Array'\n];\nfunction is(value) {\n if (value === null) {\n return 'null';\n }\n if (value === undefined) {\n return 'undefined';\n }\n if (value === true || value === false) {\n return 'boolean';\n }\n const typeOf = typeof value;\n if (typeofs.includes(typeOf)) {\n return typeOf;\n }\n if (typeOf === 'function') {\n return 'Function';\n }\n if (Array.isArray(value)) {\n return 'Array';\n }\n if (isBuffer(value)) {\n return 'Buffer';\n }\n const objectType = getObjectType(value);\n if (objectType) {\n return objectType;\n }\n return 'Object';\n}\nfunction isBuffer(value) {\n return value && value.constructor && value.constructor.isBuffer && value.constructor.isBuffer.call(null, value);\n}\nfunction getObjectType(value) {\n const objectTypeName = Object.prototype.toString.call(value).slice(8, -1);\n if (objectTypeNames.includes(objectTypeName)) {\n return objectTypeName;\n }\n return undefined;\n}\n\nexports.is = is;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass Type {\n constructor(major, name, terminal) {\n this.major = major;\n this.majorEncoded = major << 5;\n this.name = name;\n this.terminal = terminal;\n }\n toString() {\n return `Type[${ this.major }].${ this.name }`;\n }\n compare(typ) {\n return this.major < typ.major ? -1 : this.major > typ.major ? 1 : 0;\n }\n}\nType.uint = new Type(0, 'uint', true);\nType.negint = new Type(1, 'negint', true);\nType.bytes = new Type(2, 'bytes', true);\nType.string = new Type(3, 'string', true);\nType.array = new Type(4, 'array', false);\nType.map = new Type(5, 'map', false);\nType.tag = new Type(6, 'tag', false);\nType.float = new Type(7, 'float', true);\nType.false = new Type(7, 'false', true);\nType.true = new Type(7, 'true', true);\nType.null = new Type(7, 'null', true);\nType.undefined = new Type(7, 'undefined', true);\nType.break = new Type(7, 'break', true);\nclass Token {\n constructor(type, value, encodedLength) {\n this.type = type;\n this.value = value;\n this.encodedLength = encodedLength;\n this.encodedBytes = undefined;\n }\n toString() {\n return `Token[${ this.type }].${ this.value }`;\n }\n}\n\nexports.Token = Token;\nexports.Type = Type;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar byteUtils = require('./byte-utils.js');\n\nconst defaultChunkSize = 256;\nclass Bl {\n constructor(chunkSize = defaultChunkSize) {\n this.chunkSize = chunkSize;\n this.cursor = 0;\n this.maxCursor = -1;\n this.chunks = [];\n this._initReuseChunk = null;\n }\n reset() {\n this.chunks = [];\n this.cursor = 0;\n this.maxCursor = -1;\n if (this._initReuseChunk !== null) {\n this.chunks.push(this._initReuseChunk);\n this.maxCursor = this._initReuseChunk.length - 1;\n }\n }\n push(bytes) {\n let topChunk = this.chunks[this.chunks.length - 1];\n const newMax = this.cursor + bytes.length;\n if (newMax <= this.maxCursor + 1) {\n const chunkPos = topChunk.length - (this.maxCursor - this.cursor) - 1;\n topChunk.set(bytes, chunkPos);\n } else {\n if (topChunk) {\n const chunkPos = topChunk.length - (this.maxCursor - this.cursor) - 1;\n if (chunkPos < topChunk.length) {\n this.chunks[this.chunks.length - 1] = topChunk.subarray(0, chunkPos);\n this.maxCursor = this.cursor - 1;\n }\n }\n if (bytes.length < 64 && bytes.length < this.chunkSize) {\n topChunk = byteUtils.alloc(this.chunkSize);\n this.chunks.push(topChunk);\n this.maxCursor += topChunk.length;\n if (this._initReuseChunk === null) {\n this._initReuseChunk = topChunk;\n }\n topChunk.set(bytes, 0);\n } else {\n this.chunks.push(bytes);\n this.maxCursor += bytes.length;\n }\n }\n this.cursor += bytes.length;\n }\n toBytes(reset = false) {\n let byts;\n if (this.chunks.length === 1) {\n const chunk = this.chunks[0];\n if (reset && this.cursor > chunk.length / 2) {\n byts = this.cursor === chunk.length ? chunk : chunk.subarray(0, this.cursor);\n this._initReuseChunk = null;\n this.chunks = [];\n } else {\n byts = byteUtils.slice(chunk, 0, this.cursor);\n }\n } else {\n byts = byteUtils.concat(this.chunks, this.cursor);\n }\n if (reset) {\n this.reset();\n }\n return byts;\n }\n}\n\nexports.Bl = Bl;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst useBuffer = globalThis.process && !globalThis.process.browser && globalThis.Buffer && typeof globalThis.Buffer.isBuffer === 'function';\nconst textDecoder = new TextDecoder();\nconst textEncoder = new TextEncoder();\nfunction isBuffer(buf) {\n return useBuffer && globalThis.Buffer.isBuffer(buf);\n}\nfunction asU8A(buf) {\n if (!(buf instanceof Uint8Array)) {\n return Uint8Array.from(buf);\n }\n return isBuffer(buf) ? new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength) : buf;\n}\nconst toString = useBuffer ? (bytes, start, end) => {\n return end - start > 64 ? globalThis.Buffer.from(bytes.subarray(start, end)).toString('utf8') : utf8Slice(bytes, start, end);\n} : (bytes, start, end) => {\n return end - start > 64 ? textDecoder.decode(bytes.subarray(start, end)) : utf8Slice(bytes, start, end);\n};\nconst fromString = useBuffer ? string => {\n return string.length > 64 ? globalThis.Buffer.from(string) : utf8ToBytes(string);\n} : string => {\n return string.length > 64 ? textEncoder.encode(string) : utf8ToBytes(string);\n};\nconst fromArray = arr => {\n return Uint8Array.from(arr);\n};\nconst slice = useBuffer ? (bytes, start, end) => {\n if (isBuffer(bytes)) {\n return new Uint8Array(bytes.subarray(start, end));\n }\n return bytes.slice(start, end);\n} : (bytes, start, end) => {\n return bytes.slice(start, end);\n};\nconst concat = useBuffer ? (chunks, length) => {\n chunks = chunks.map(c => c instanceof Uint8Array ? c : globalThis.Buffer.from(c));\n return asU8A(globalThis.Buffer.concat(chunks, length));\n} : (chunks, length) => {\n const out = new Uint8Array(length);\n let off = 0;\n for (let b of chunks) {\n if (off + b.length > out.length) {\n b = b.subarray(0, out.length - off);\n }\n out.set(b, off);\n off += b.length;\n }\n return out;\n};\nconst alloc = useBuffer ? size => {\n return globalThis.Buffer.allocUnsafe(size);\n} : size => {\n return new Uint8Array(size);\n};\nconst toHex = useBuffer ? d => {\n if (typeof d === 'string') {\n return d;\n }\n return globalThis.Buffer.from(toBytes(d)).toString('hex');\n} : d => {\n if (typeof d === 'string') {\n return d;\n }\n return Array.prototype.reduce.call(toBytes(d), (p, c) => `${ p }${ c.toString(16).padStart(2, '0') }`, '');\n};\nconst fromHex = useBuffer ? hex => {\n if (hex instanceof Uint8Array) {\n return hex;\n }\n return globalThis.Buffer.from(hex, 'hex');\n} : hex => {\n if (hex instanceof Uint8Array) {\n return hex;\n }\n if (!hex.length) {\n return new Uint8Array(0);\n }\n return new Uint8Array(hex.split('').map((c, i, d) => i % 2 === 0 ? `0x${ c }${ d[i + 1] }` : '').filter(Boolean).map(e => parseInt(e, 16)));\n};\nfunction toBytes(obj) {\n if (obj instanceof Uint8Array && obj.constructor.name === 'Uint8Array') {\n return obj;\n }\n if (obj instanceof ArrayBuffer) {\n return new Uint8Array(obj);\n }\n if (ArrayBuffer.isView(obj)) {\n return new Uint8Array(obj.buffer, obj.byteOffset, obj.byteLength);\n }\n throw new Error('Unknown type, must be binary type');\n}\nfunction compare(b1, b2) {\n if (isBuffer(b1) && isBuffer(b2)) {\n return b1.compare(b2);\n }\n for (let i = 0; i < b1.length; i++) {\n if (b1[i] === b2[i]) {\n continue;\n }\n return b1[i] < b2[i] ? -1 : 1;\n }\n return 0;\n}\nfunction utf8ToBytes(string, units = Infinity) {\n let codePoint;\n const length = string.length;\n let leadSurrogate = null;\n const bytes = [];\n for (let i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i);\n if (codePoint > 55295 && codePoint < 57344) {\n if (!leadSurrogate) {\n if (codePoint > 56319) {\n if ((units -= 3) > -1)\n bytes.push(239, 191, 189);\n continue;\n } else if (i + 1 === length) {\n if ((units -= 3) > -1)\n bytes.push(239, 191, 189);\n continue;\n }\n leadSurrogate = codePoint;\n continue;\n }\n if (codePoint < 56320) {\n if ((units -= 3) > -1)\n bytes.push(239, 191, 189);\n leadSurrogate = codePoint;\n continue;\n }\n codePoint = (leadSurrogate - 55296 << 10 | codePoint - 56320) + 65536;\n } else if (leadSurrogate) {\n if ((units -= 3) > -1)\n bytes.push(239, 191, 189);\n }\n leadSurrogate = null;\n if (codePoint < 128) {\n if ((units -= 1) < 0)\n break;\n bytes.push(codePoint);\n } else if (codePoint < 2048) {\n if ((units -= 2) < 0)\n break;\n bytes.push(codePoint >> 6 | 192, codePoint & 63 | 128);\n } else if (codePoint < 65536) {\n if ((units -= 3) < 0)\n break;\n bytes.push(codePoint >> 12 | 224, codePoint >> 6 & 63 | 128, codePoint & 63 | 128);\n } else if (codePoint < 1114112) {\n if ((units -= 4) < 0)\n break;\n bytes.push(codePoint >> 18 | 240, codePoint >> 12 & 63 | 128, codePoint >> 6 & 63 | 128, codePoint & 63 | 128);\n } else {\n throw new Error('Invalid code point');\n }\n }\n return bytes;\n}\nfunction utf8Slice(buf, offset, end) {\n const res = [];\n while (offset < end) {\n const firstByte = buf[offset];\n let codePoint = null;\n let bytesPerSequence = firstByte > 239 ? 4 : firstByte > 223 ? 3 : firstByte > 191 ? 2 : 1;\n if (offset + bytesPerSequence <= end) {\n let secondByte, thirdByte, fourthByte, tempCodePoint;\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 128) {\n codePoint = firstByte;\n }\n break;\n case 2:\n secondByte = buf[offset + 1];\n if ((secondByte & 192) === 128) {\n tempCodePoint = (firstByte & 31) << 6 | secondByte & 63;\n if (tempCodePoint > 127) {\n codePoint = tempCodePoint;\n }\n }\n break;\n case 3:\n secondByte = buf[offset + 1];\n thirdByte = buf[offset + 2];\n if ((secondByte & 192) === 128 && (thirdByte & 192) === 128) {\n tempCodePoint = (firstByte & 15) << 12 | (secondByte & 63) << 6 | thirdByte & 63;\n if (tempCodePoint > 2047 && (tempCodePoint < 55296 || tempCodePoint > 57343)) {\n codePoint = tempCodePoint;\n }\n }\n break;\n case 4:\n secondByte = buf[offset + 1];\n thirdByte = buf[offset + 2];\n fourthByte = buf[offset + 3];\n if ((secondByte & 192) === 128 && (thirdByte & 192) === 128 && (fourthByte & 192) === 128) {\n tempCodePoint = (firstByte & 15) << 18 | (secondByte & 63) << 12 | (thirdByte & 63) << 6 | fourthByte & 63;\n if (tempCodePoint > 65535 && tempCodePoint < 1114112) {\n codePoint = tempCodePoint;\n }\n }\n }\n }\n if (codePoint === null) {\n codePoint = 65533;\n bytesPerSequence = 1;\n } else if (codePoint > 65535) {\n codePoint -= 65536;\n res.push(codePoint >>> 10 & 1023 | 55296);\n codePoint = 56320 | codePoint & 1023;\n }\n res.push(codePoint);\n offset += bytesPerSequence;\n }\n return decodeCodePointsArray(res);\n}\nconst MAX_ARGUMENTS_LENGTH = 4096;\nfunction decodeCodePointsArray(codePoints) {\n const len = codePoints.length;\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints);\n }\n let res = '';\n let i = 0;\n while (i < len) {\n res += String.fromCharCode.apply(String, codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH));\n }\n return res;\n}\n\nexports.alloc = alloc;\nexports.asU8A = asU8A;\nexports.compare = compare;\nexports.concat = concat;\nexports.decodeCodePointsArray = decodeCodePointsArray;\nexports.fromArray = fromArray;\nexports.fromHex = fromHex;\nexports.fromString = fromString;\nexports.slice = slice;\nexports.toHex = toHex;\nexports.toString = toString;\nexports.useBuffer = useBuffer;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst decodeErrPrefix = 'CBOR decode error:';\nconst encodeErrPrefix = 'CBOR encode error:';\nconst uintMinorPrefixBytes = [];\nuintMinorPrefixBytes[23] = 1;\nuintMinorPrefixBytes[24] = 2;\nuintMinorPrefixBytes[25] = 3;\nuintMinorPrefixBytes[26] = 5;\nuintMinorPrefixBytes[27] = 9;\nfunction assertEnoughData(data, pos, need) {\n if (data.length - pos < need) {\n throw new Error(`${ decodeErrPrefix } not enough data for type`);\n }\n}\n\nexports.assertEnoughData = assertEnoughData;\nexports.decodeErrPrefix = decodeErrPrefix;\nexports.encodeErrPrefix = encodeErrPrefix;\nexports.uintMinorPrefixBytes = uintMinorPrefixBytes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\nvar _1negint = require('./1negint.js');\nvar _2bytes = require('./2bytes.js');\nvar _3string = require('./3string.js');\nvar _4array = require('./4array.js');\nvar _5map = require('./5map.js');\nvar _6tag = require('./6tag.js');\nvar _7float = require('./7float.js');\nvar common = require('./common.js');\nvar byteUtils = require('./byte-utils.js');\n\nfunction invalidMinor(data, pos, minor) {\n throw new Error(`${ common.decodeErrPrefix } encountered invalid minor (${ minor }) for major ${ data[pos] >>> 5 }`);\n}\nfunction errorer(msg) {\n return () => {\n throw new Error(`${ common.decodeErrPrefix } ${ msg }`);\n };\n}\nconst jump = [];\nfor (let i = 0; i <= 23; i++) {\n jump[i] = invalidMinor;\n}\njump[24] = _0uint.decodeUint8;\njump[25] = _0uint.decodeUint16;\njump[26] = _0uint.decodeUint32;\njump[27] = _0uint.decodeUint64;\njump[28] = invalidMinor;\njump[29] = invalidMinor;\njump[30] = invalidMinor;\njump[31] = invalidMinor;\nfor (let i = 32; i <= 55; i++) {\n jump[i] = invalidMinor;\n}\njump[56] = _1negint.decodeNegint8;\njump[57] = _1negint.decodeNegint16;\njump[58] = _1negint.decodeNegint32;\njump[59] = _1negint.decodeNegint64;\njump[60] = invalidMinor;\njump[61] = invalidMinor;\njump[62] = invalidMinor;\njump[63] = invalidMinor;\nfor (let i = 64; i <= 87; i++) {\n jump[i] = _2bytes.decodeBytesCompact;\n}\njump[88] = _2bytes.decodeBytes8;\njump[89] = _2bytes.decodeBytes16;\njump[90] = _2bytes.decodeBytes32;\njump[91] = _2bytes.decodeBytes64;\njump[92] = invalidMinor;\njump[93] = invalidMinor;\njump[94] = invalidMinor;\njump[95] = errorer('indefinite length bytes/strings are not supported');\nfor (let i = 96; i <= 119; i++) {\n jump[i] = _3string.decodeStringCompact;\n}\njump[120] = _3string.decodeString8;\njump[121] = _3string.decodeString16;\njump[122] = _3string.decodeString32;\njump[123] = _3string.decodeString64;\njump[124] = invalidMinor;\njump[125] = invalidMinor;\njump[126] = invalidMinor;\njump[127] = errorer('indefinite length bytes/strings are not supported');\nfor (let i = 128; i <= 151; i++) {\n jump[i] = _4array.decodeArrayCompact;\n}\njump[152] = _4array.decodeArray8;\njump[153] = _4array.decodeArray16;\njump[154] = _4array.decodeArray32;\njump[155] = _4array.decodeArray64;\njump[156] = invalidMinor;\njump[157] = invalidMinor;\njump[158] = invalidMinor;\njump[159] = _4array.decodeArrayIndefinite;\nfor (let i = 160; i <= 183; i++) {\n jump[i] = _5map.decodeMapCompact;\n}\njump[184] = _5map.decodeMap8;\njump[185] = _5map.decodeMap16;\njump[186] = _5map.decodeMap32;\njump[187] = _5map.decodeMap64;\njump[188] = invalidMinor;\njump[189] = invalidMinor;\njump[190] = invalidMinor;\njump[191] = _5map.decodeMapIndefinite;\nfor (let i = 192; i <= 215; i++) {\n jump[i] = _6tag.decodeTagCompact;\n}\njump[216] = _6tag.decodeTag8;\njump[217] = _6tag.decodeTag16;\njump[218] = _6tag.decodeTag32;\njump[219] = _6tag.decodeTag64;\njump[220] = invalidMinor;\njump[221] = invalidMinor;\njump[222] = invalidMinor;\njump[223] = invalidMinor;\nfor (let i = 224; i <= 243; i++) {\n jump[i] = errorer('simple values are not supported');\n}\njump[244] = invalidMinor;\njump[245] = invalidMinor;\njump[246] = invalidMinor;\njump[247] = _7float.decodeUndefined;\njump[248] = errorer('simple values are not supported');\njump[249] = _7float.decodeFloat16;\njump[250] = _7float.decodeFloat32;\njump[251] = _7float.decodeFloat64;\njump[252] = invalidMinor;\njump[253] = invalidMinor;\njump[254] = invalidMinor;\njump[255] = _7float.decodeBreak;\nconst quick = [];\nfor (let i = 0; i < 24; i++) {\n quick[i] = new token.Token(token.Type.uint, i, 1);\n}\nfor (let i = -1; i >= -24; i--) {\n quick[31 - i] = new token.Token(token.Type.negint, i, 1);\n}\nquick[64] = new token.Token(token.Type.bytes, new Uint8Array(0), 1);\nquick[96] = new token.Token(token.Type.string, '', 1);\nquick[128] = new token.Token(token.Type.array, 0, 1);\nquick[160] = new token.Token(token.Type.map, 0, 1);\nquick[244] = new token.Token(token.Type.false, false, 1);\nquick[245] = new token.Token(token.Type.true, true, 1);\nquick[246] = new token.Token(token.Type.null, null, 1);\nfunction quickEncodeToken(token$1) {\n switch (token$1.type) {\n case token.Type.false:\n return byteUtils.fromArray([244]);\n case token.Type.true:\n return byteUtils.fromArray([245]);\n case token.Type.null:\n return byteUtils.fromArray([246]);\n case token.Type.bytes:\n if (!token$1.value.length) {\n return byteUtils.fromArray([64]);\n }\n return;\n case token.Type.string:\n if (token$1.value === '') {\n return byteUtils.fromArray([96]);\n }\n return;\n case token.Type.array:\n if (token$1.value === 0) {\n return byteUtils.fromArray([128]);\n }\n return;\n case token.Type.map:\n if (token$1.value === 0) {\n return byteUtils.fromArray([160]);\n }\n return;\n case token.Type.uint:\n if (token$1.value < 24) {\n return byteUtils.fromArray([Number(token$1.value)]);\n }\n return;\n case token.Type.negint:\n if (token$1.value >= -24) {\n return byteUtils.fromArray([31 - Number(token$1.value)]);\n }\n }\n}\n\nexports.jump = jump;\nexports.quick = quick;\nexports.quickEncodeToken = quickEncodeToken;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar common = require('./common.js');\n\nconst uintBoundaries = [\n 24,\n 256,\n 65536,\n 4294967296,\n BigInt('18446744073709551616')\n];\nfunction readUint8(data, offset, options) {\n common.assertEnoughData(data, offset, 1);\n const value = data[offset];\n if (options.strict === true && value < uintBoundaries[0]) {\n throw new Error(`${ common.decodeErrPrefix } integer encoded in more bytes than necessary (strict decode)`);\n }\n return value;\n}\nfunction readUint16(data, offset, options) {\n common.assertEnoughData(data, offset, 2);\n const value = data[offset] << 8 | data[offset + 1];\n if (options.strict === true && value < uintBoundaries[1]) {\n throw new Error(`${ common.decodeErrPrefix } integer encoded in more bytes than necessary (strict decode)`);\n }\n return value;\n}\nfunction readUint32(data, offset, options) {\n common.assertEnoughData(data, offset, 4);\n const value = data[offset] * 16777216 + (data[offset + 1] << 16) + (data[offset + 2] << 8) + data[offset + 3];\n if (options.strict === true && value < uintBoundaries[2]) {\n throw new Error(`${ common.decodeErrPrefix } integer encoded in more bytes than necessary (strict decode)`);\n }\n return value;\n}\nfunction readUint64(data, offset, options) {\n common.assertEnoughData(data, offset, 8);\n const hi = data[offset] * 16777216 + (data[offset + 1] << 16) + (data[offset + 2] << 8) + data[offset + 3];\n const lo = data[offset + 4] * 16777216 + (data[offset + 5] << 16) + (data[offset + 6] << 8) + data[offset + 7];\n const value = (BigInt(hi) << BigInt(32)) + BigInt(lo);\n if (options.strict === true && value < uintBoundaries[3]) {\n throw new Error(`${ common.decodeErrPrefix } integer encoded in more bytes than necessary (strict decode)`);\n }\n if (value <= Number.MAX_SAFE_INTEGER) {\n return Number(value);\n }\n if (options.allowBigInt === true) {\n return value;\n }\n throw new Error(`${ common.decodeErrPrefix } integers outside of the safe integer range are not supported`);\n}\nfunction decodeUint8(data, pos, _minor, options) {\n return new token.Token(token.Type.uint, readUint8(data, pos + 1, options), 2);\n}\nfunction decodeUint16(data, pos, _minor, options) {\n return new token.Token(token.Type.uint, readUint16(data, pos + 1, options), 3);\n}\nfunction decodeUint32(data, pos, _minor, options) {\n return new token.Token(token.Type.uint, readUint32(data, pos + 1, options), 5);\n}\nfunction decodeUint64(data, pos, _minor, options) {\n return new token.Token(token.Type.uint, readUint64(data, pos + 1, options), 9);\n}\nfunction encodeUint(buf, token) {\n return encodeUintValue(buf, 0, token.value);\n}\nfunction encodeUintValue(buf, major, uint) {\n if (uint < uintBoundaries[0]) {\n const nuint = Number(uint);\n buf.push([major | nuint]);\n } else if (uint < uintBoundaries[1]) {\n const nuint = Number(uint);\n buf.push([\n major | 24,\n nuint\n ]);\n } else if (uint < uintBoundaries[2]) {\n const nuint = Number(uint);\n buf.push([\n major | 25,\n nuint >>> 8,\n nuint & 255\n ]);\n } else if (uint < uintBoundaries[3]) {\n const nuint = Number(uint);\n buf.push([\n major | 26,\n nuint >>> 24 & 255,\n nuint >>> 16 & 255,\n nuint >>> 8 & 255,\n nuint & 255\n ]);\n } else {\n const buint = BigInt(uint);\n if (buint < uintBoundaries[4]) {\n const set = [\n major | 27,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0\n ];\n let lo = Number(buint & BigInt(4294967295));\n let hi = Number(buint >> BigInt(32) & BigInt(4294967295));\n set[8] = lo & 255;\n lo = lo >> 8;\n set[7] = lo & 255;\n lo = lo >> 8;\n set[6] = lo & 255;\n lo = lo >> 8;\n set[5] = lo & 255;\n set[4] = hi & 255;\n hi = hi >> 8;\n set[3] = hi & 255;\n hi = hi >> 8;\n set[2] = hi & 255;\n hi = hi >> 8;\n set[1] = hi & 255;\n buf.push(set);\n } else {\n throw new Error(`${ common.decodeErrPrefix } encountered BigInt larger than allowable range`);\n }\n }\n}\nencodeUint.encodedSize = function encodedSize(token) {\n return encodeUintValue.encodedSize(token.value);\n};\nencodeUintValue.encodedSize = function encodedSize(uint) {\n if (uint < uintBoundaries[0]) {\n return 1;\n }\n if (uint < uintBoundaries[1]) {\n return 2;\n }\n if (uint < uintBoundaries[2]) {\n return 3;\n }\n if (uint < uintBoundaries[3]) {\n return 5;\n }\n return 9;\n};\nencodeUint.compareTokens = function compareTokens(tok1, tok2) {\n return tok1.value < tok2.value ? -1 : tok1.value > tok2.value ? 1 : 0;\n};\n\nexports.decodeUint16 = decodeUint16;\nexports.decodeUint32 = decodeUint32;\nexports.decodeUint64 = decodeUint64;\nexports.decodeUint8 = decodeUint8;\nexports.encodeUint = encodeUint;\nexports.encodeUintValue = encodeUintValue;\nexports.readUint16 = readUint16;\nexports.readUint32 = readUint32;\nexports.readUint64 = readUint64;\nexports.readUint8 = readUint8;\nexports.uintBoundaries = uintBoundaries;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\nvar common = require('./common.js');\n\nfunction decodeNegint8(data, pos, _minor, options) {\n return new token.Token(token.Type.negint, -1 - _0uint.readUint8(data, pos + 1, options), 2);\n}\nfunction decodeNegint16(data, pos, _minor, options) {\n return new token.Token(token.Type.negint, -1 - _0uint.readUint16(data, pos + 1, options), 3);\n}\nfunction decodeNegint32(data, pos, _minor, options) {\n return new token.Token(token.Type.negint, -1 - _0uint.readUint32(data, pos + 1, options), 5);\n}\nconst neg1b = BigInt(-1);\nconst pos1b = BigInt(1);\nfunction decodeNegint64(data, pos, _minor, options) {\n const int = _0uint.readUint64(data, pos + 1, options);\n if (typeof int !== 'bigint') {\n const value = -1 - int;\n if (value >= Number.MIN_SAFE_INTEGER) {\n return new token.Token(token.Type.negint, value, 9);\n }\n }\n if (options.allowBigInt !== true) {\n throw new Error(`${ common.decodeErrPrefix } integers outside of the safe integer range are not supported`);\n }\n return new token.Token(token.Type.negint, neg1b - BigInt(int), 9);\n}\nfunction encodeNegint(buf, token) {\n const negint = token.value;\n const unsigned = typeof negint === 'bigint' ? negint * neg1b - pos1b : negint * -1 - 1;\n _0uint.encodeUintValue(buf, token.type.majorEncoded, unsigned);\n}\nencodeNegint.encodedSize = function encodedSize(token) {\n const negint = token.value;\n const unsigned = typeof negint === 'bigint' ? negint * neg1b - pos1b : negint * -1 - 1;\n if (unsigned < _0uint.uintBoundaries[0]) {\n return 1;\n }\n if (unsigned < _0uint.uintBoundaries[1]) {\n return 2;\n }\n if (unsigned < _0uint.uintBoundaries[2]) {\n return 3;\n }\n if (unsigned < _0uint.uintBoundaries[3]) {\n return 5;\n }\n return 9;\n};\nencodeNegint.compareTokens = function compareTokens(tok1, tok2) {\n return tok1.value < tok2.value ? 1 : tok1.value > tok2.value ? -1 : 0;\n};\n\nexports.decodeNegint16 = decodeNegint16;\nexports.decodeNegint32 = decodeNegint32;\nexports.decodeNegint64 = decodeNegint64;\nexports.decodeNegint8 = decodeNegint8;\nexports.encodeNegint = encodeNegint;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar common = require('./common.js');\nvar _0uint = require('./0uint.js');\nvar byteUtils = require('./byte-utils.js');\n\nfunction toToken(data, pos, prefix, length) {\n common.assertEnoughData(data, pos, prefix + length);\n const buf = byteUtils.slice(data, pos + prefix, pos + prefix + length);\n return new token.Token(token.Type.bytes, buf, prefix + length);\n}\nfunction decodeBytesCompact(data, pos, minor, _options) {\n return toToken(data, pos, 1, minor);\n}\nfunction decodeBytes8(data, pos, _minor, options) {\n return toToken(data, pos, 2, _0uint.readUint8(data, pos + 1, options));\n}\nfunction decodeBytes16(data, pos, _minor, options) {\n return toToken(data, pos, 3, _0uint.readUint16(data, pos + 1, options));\n}\nfunction decodeBytes32(data, pos, _minor, options) {\n return toToken(data, pos, 5, _0uint.readUint32(data, pos + 1, options));\n}\nfunction decodeBytes64(data, pos, _minor, options) {\n const l = _0uint.readUint64(data, pos + 1, options);\n if (typeof l === 'bigint') {\n throw new Error(`${ common.decodeErrPrefix } 64-bit integer bytes lengths not supported`);\n }\n return toToken(data, pos, 9, l);\n}\nfunction tokenBytes(token$1) {\n if (token$1.encodedBytes === undefined) {\n token$1.encodedBytes = token$1.type === token.Type.string ? byteUtils.fromString(token$1.value) : token$1.value;\n }\n return token$1.encodedBytes;\n}\nfunction encodeBytes(buf, token) {\n const bytes = tokenBytes(token);\n _0uint.encodeUintValue(buf, token.type.majorEncoded, bytes.length);\n buf.push(bytes);\n}\nencodeBytes.encodedSize = function encodedSize(token) {\n const bytes = tokenBytes(token);\n return _0uint.encodeUintValue.encodedSize(bytes.length) + bytes.length;\n};\nencodeBytes.compareTokens = function compareTokens(tok1, tok2) {\n return compareBytes(tokenBytes(tok1), tokenBytes(tok2));\n};\nfunction compareBytes(b1, b2) {\n return b1.length < b2.length ? -1 : b1.length > b2.length ? 1 : byteUtils.compare(b1, b2);\n}\n\nexports.compareBytes = compareBytes;\nexports.decodeBytes16 = decodeBytes16;\nexports.decodeBytes32 = decodeBytes32;\nexports.decodeBytes64 = decodeBytes64;\nexports.decodeBytes8 = decodeBytes8;\nexports.decodeBytesCompact = decodeBytesCompact;\nexports.encodeBytes = encodeBytes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar common = require('./common.js');\nvar _0uint = require('./0uint.js');\nvar _2bytes = require('./2bytes.js');\nvar byteUtils = require('./byte-utils.js');\n\nfunction toToken(data, pos, prefix, length) {\n const totLength = prefix + length;\n common.assertEnoughData(data, pos, totLength);\n return new token.Token(token.Type.string, byteUtils.toString(data, pos + prefix, pos + totLength), totLength);\n}\nfunction decodeStringCompact(data, pos, minor, _options) {\n return toToken(data, pos, 1, minor);\n}\nfunction decodeString8(data, pos, _minor, options) {\n return toToken(data, pos, 2, _0uint.readUint8(data, pos + 1, options));\n}\nfunction decodeString16(data, pos, _minor, options) {\n return toToken(data, pos, 3, _0uint.readUint16(data, pos + 1, options));\n}\nfunction decodeString32(data, pos, _minor, options) {\n return toToken(data, pos, 5, _0uint.readUint32(data, pos + 1, options));\n}\nfunction decodeString64(data, pos, _minor, options) {\n const l = _0uint.readUint64(data, pos + 1, options);\n if (typeof l === 'bigint') {\n throw new Error(`${ common.decodeErrPrefix } 64-bit integer string lengths not supported`);\n }\n return toToken(data, pos, 9, l);\n}\nconst encodeString = _2bytes.encodeBytes;\n\nexports.decodeString16 = decodeString16;\nexports.decodeString32 = decodeString32;\nexports.decodeString64 = decodeString64;\nexports.decodeString8 = decodeString8;\nexports.decodeStringCompact = decodeStringCompact;\nexports.encodeString = encodeString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\nvar common = require('./common.js');\n\nfunction toToken(_data, _pos, prefix, length) {\n return new token.Token(token.Type.array, length, prefix);\n}\nfunction decodeArrayCompact(data, pos, minor, _options) {\n return toToken(data, pos, 1, minor);\n}\nfunction decodeArray8(data, pos, _minor, options) {\n return toToken(data, pos, 2, _0uint.readUint8(data, pos + 1, options));\n}\nfunction decodeArray16(data, pos, _minor, options) {\n return toToken(data, pos, 3, _0uint.readUint16(data, pos + 1, options));\n}\nfunction decodeArray32(data, pos, _minor, options) {\n return toToken(data, pos, 5, _0uint.readUint32(data, pos + 1, options));\n}\nfunction decodeArray64(data, pos, _minor, options) {\n const l = _0uint.readUint64(data, pos + 1, options);\n if (typeof l === 'bigint') {\n throw new Error(`${ common.decodeErrPrefix } 64-bit integer array lengths not supported`);\n }\n return toToken(data, pos, 9, l);\n}\nfunction decodeArrayIndefinite(data, pos, _minor, options) {\n if (options.allowIndefinite === false) {\n throw new Error(`${ common.decodeErrPrefix } indefinite length items not allowed`);\n }\n return toToken(data, pos, 1, Infinity);\n}\nfunction encodeArray(buf, token$1) {\n _0uint.encodeUintValue(buf, token.Type.array.majorEncoded, token$1.value);\n}\nencodeArray.compareTokens = _0uint.encodeUint.compareTokens;\n\nexports.decodeArray16 = decodeArray16;\nexports.decodeArray32 = decodeArray32;\nexports.decodeArray64 = decodeArray64;\nexports.decodeArray8 = decodeArray8;\nexports.decodeArrayCompact = decodeArrayCompact;\nexports.decodeArrayIndefinite = decodeArrayIndefinite;\nexports.encodeArray = encodeArray;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\nvar common = require('./common.js');\n\nfunction toToken(_data, _pos, prefix, length) {\n return new token.Token(token.Type.map, length, prefix);\n}\nfunction decodeMapCompact(data, pos, minor, _options) {\n return toToken(data, pos, 1, minor);\n}\nfunction decodeMap8(data, pos, _minor, options) {\n return toToken(data, pos, 2, _0uint.readUint8(data, pos + 1, options));\n}\nfunction decodeMap16(data, pos, _minor, options) {\n return toToken(data, pos, 3, _0uint.readUint16(data, pos + 1, options));\n}\nfunction decodeMap32(data, pos, _minor, options) {\n return toToken(data, pos, 5, _0uint.readUint32(data, pos + 1, options));\n}\nfunction decodeMap64(data, pos, _minor, options) {\n const l = _0uint.readUint64(data, pos + 1, options);\n if (typeof l === 'bigint') {\n throw new Error(`${ common.decodeErrPrefix } 64-bit integer map lengths not supported`);\n }\n return toToken(data, pos, 9, l);\n}\nfunction decodeMapIndefinite(data, pos, _minor, options) {\n if (options.allowIndefinite === false) {\n throw new Error(`${ common.decodeErrPrefix } indefinite length items not allowed`);\n }\n return toToken(data, pos, 1, Infinity);\n}\nfunction encodeMap(buf, token$1) {\n _0uint.encodeUintValue(buf, token.Type.map.majorEncoded, token$1.value);\n}\nencodeMap.compareTokens = _0uint.encodeUint.compareTokens;\n\nexports.decodeMap16 = decodeMap16;\nexports.decodeMap32 = decodeMap32;\nexports.decodeMap64 = decodeMap64;\nexports.decodeMap8 = decodeMap8;\nexports.decodeMapCompact = decodeMapCompact;\nexports.decodeMapIndefinite = decodeMapIndefinite;\nexports.encodeMap = encodeMap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar _0uint = require('./0uint.js');\n\nfunction decodeTagCompact(_data, _pos, minor, _options) {\n return new token.Token(token.Type.tag, minor, 1);\n}\nfunction decodeTag8(data, pos, _minor, options) {\n return new token.Token(token.Type.tag, _0uint.readUint8(data, pos + 1, options), 2);\n}\nfunction decodeTag16(data, pos, _minor, options) {\n return new token.Token(token.Type.tag, _0uint.readUint16(data, pos + 1, options), 3);\n}\nfunction decodeTag32(data, pos, _minor, options) {\n return new token.Token(token.Type.tag, _0uint.readUint32(data, pos + 1, options), 5);\n}\nfunction decodeTag64(data, pos, _minor, options) {\n return new token.Token(token.Type.tag, _0uint.readUint64(data, pos + 1, options), 9);\n}\nfunction encodeTag(buf, token$1) {\n _0uint.encodeUintValue(buf, token.Type.tag.majorEncoded, token$1.value);\n}\nencodeTag.compareTokens = _0uint.encodeUint.compareTokens;\n\nexports.decodeTag16 = decodeTag16;\nexports.decodeTag32 = decodeTag32;\nexports.decodeTag64 = decodeTag64;\nexports.decodeTag8 = decodeTag8;\nexports.decodeTagCompact = decodeTagCompact;\nexports.encodeTag = encodeTag;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar token = require('./token.js');\nvar common = require('./common.js');\nvar _0uint = require('./0uint.js');\n\nconst MINOR_FALSE = 20;\nconst MINOR_TRUE = 21;\nconst MINOR_NULL = 22;\nconst MINOR_UNDEFINED = 23;\nfunction decodeUndefined(_data, _pos, _minor, options) {\n if (options.allowUndefined === false) {\n throw new Error(`${ common.decodeErrPrefix } undefined values are not supported`);\n }\n return new token.Token(token.Type.undefined, undefined, 1);\n}\nfunction decodeBreak(_data, _pos, _minor, options) {\n if (options.allowIndefinite === false) {\n throw new Error(`${ common.decodeErrPrefix } indefinite length items not allowed`);\n }\n return new token.Token(token.Type.break, undefined, 1);\n}\nfunction createToken(value, bytes, options) {\n if (options) {\n if (options.allowNaN === false && Number.isNaN(value)) {\n throw new Error(`${ common.decodeErrPrefix } NaN values are not supported`);\n }\n if (options.allowInfinity === false && (value === Infinity || value === -Infinity)) {\n throw new Error(`${ common.decodeErrPrefix } Infinity values are not supported`);\n }\n }\n return new token.Token(token.Type.float, value, bytes);\n}\nfunction decodeFloat16(data, pos, _minor, options) {\n return createToken(readFloat16(data, pos + 1), 3, options);\n}\nfunction decodeFloat32(data, pos, _minor, options) {\n return createToken(readFloat32(data, pos + 1), 5, options);\n}\nfunction decodeFloat64(data, pos, _minor, options) {\n return createToken(readFloat64(data, pos + 1), 9, options);\n}\nfunction encodeFloat(buf, token$1, options) {\n const float = token$1.value;\n if (float === false) {\n buf.push([token.Type.float.majorEncoded | MINOR_FALSE]);\n } else if (float === true) {\n buf.push([token.Type.float.majorEncoded | MINOR_TRUE]);\n } else if (float === null) {\n buf.push([token.Type.float.majorEncoded | MINOR_NULL]);\n } else if (float === undefined) {\n buf.push([token.Type.float.majorEncoded | MINOR_UNDEFINED]);\n } else {\n let decoded;\n let success = false;\n if (!options || options.float64 !== true) {\n encodeFloat16(float);\n decoded = readFloat16(ui8a, 1);\n if (float === decoded || Number.isNaN(float)) {\n ui8a[0] = 249;\n buf.push(ui8a.slice(0, 3));\n success = true;\n } else {\n encodeFloat32(float);\n decoded = readFloat32(ui8a, 1);\n if (float === decoded) {\n ui8a[0] = 250;\n buf.push(ui8a.slice(0, 5));\n success = true;\n }\n }\n }\n if (!success) {\n encodeFloat64(float);\n decoded = readFloat64(ui8a, 1);\n ui8a[0] = 251;\n buf.push(ui8a.slice(0, 9));\n }\n }\n}\nencodeFloat.encodedSize = function encodedSize(token, options) {\n const float = token.value;\n if (float === false || float === true || float === null || float === undefined) {\n return 1;\n }\n let decoded;\n if (!options || options.float64 !== true) {\n encodeFloat16(float);\n decoded = readFloat16(ui8a, 1);\n if (float === decoded || Number.isNaN(float)) {\n return 3;\n }\n encodeFloat32(float);\n decoded = readFloat32(ui8a, 1);\n if (float === decoded) {\n return 5;\n }\n }\n return 9;\n};\nconst buffer = new ArrayBuffer(9);\nconst dataView = new DataView(buffer, 1);\nconst ui8a = new Uint8Array(buffer, 0);\nfunction encodeFloat16(inp) {\n if (inp === Infinity) {\n dataView.setUint16(0, 31744, false);\n } else if (inp === -Infinity) {\n dataView.setUint16(0, 64512, false);\n } else if (Number.isNaN(inp)) {\n dataView.setUint16(0, 32256, false);\n } else {\n dataView.setFloat32(0, inp);\n const valu32 = dataView.getUint32(0);\n const exponent = (valu32 & 2139095040) >> 23;\n const mantissa = valu32 & 8388607;\n if (exponent === 255) {\n dataView.setUint16(0, 31744, false);\n } else if (exponent === 0) {\n dataView.setUint16(0, (inp & 2147483648) >> 16 | mantissa >> 13, false);\n } else {\n const logicalExponent = exponent - 127;\n if (logicalExponent < -24) {\n dataView.setUint16(0, 0);\n } else if (logicalExponent < -14) {\n dataView.setUint16(0, (valu32 & 2147483648) >> 16 | 1 << 24 + logicalExponent, false);\n } else {\n dataView.setUint16(0, (valu32 & 2147483648) >> 16 | logicalExponent + 15 << 10 | mantissa >> 13, false);\n }\n }\n }\n}\nfunction readFloat16(ui8a, pos) {\n if (ui8a.length - pos < 2) {\n throw new Error(`${ common.decodeErrPrefix } not enough data for float16`);\n }\n const half = (ui8a[pos] << 8) + ui8a[pos + 1];\n if (half === 31744) {\n return Infinity;\n }\n if (half === 64512) {\n return -Infinity;\n }\n if (half === 32256) {\n return NaN;\n }\n const exp = half >> 10 & 31;\n const mant = half & 1023;\n let val;\n if (exp === 0) {\n val = mant * 2 ** -24;\n } else if (exp !== 31) {\n val = (mant + 1024) * 2 ** (exp - 25);\n } else {\n val = mant === 0 ? Infinity : NaN;\n }\n return half & 32768 ? -val : val;\n}\nfunction encodeFloat32(inp) {\n dataView.setFloat32(0, inp, false);\n}\nfunction readFloat32(ui8a, pos) {\n if (ui8a.length - pos < 4) {\n throw new Error(`${ common.decodeErrPrefix } not enough data for float32`);\n }\n const offset = (ui8a.byteOffset || 0) + pos;\n return new DataView(ui8a.buffer, offset, 4).getFloat32(0, false);\n}\nfunction encodeFloat64(inp) {\n dataView.setFloat64(0, inp, false);\n}\nfunction readFloat64(ui8a, pos) {\n if (ui8a.length - pos < 8) {\n throw new Error(`${ common.decodeErrPrefix } not enough data for float64`);\n }\n const offset = (ui8a.byteOffset || 0) + pos;\n return new DataView(ui8a.buffer, offset, 8).getFloat64(0, false);\n}\nencodeFloat.compareTokens = _0uint.encodeUint.compareTokens;\n\nexports.decodeBreak = decodeBreak;\nexports.decodeFloat16 = decodeFloat16;\nexports.decodeFloat32 = decodeFloat32;\nexports.decodeFloat64 = decodeFloat64;\nexports.decodeUndefined = decodeUndefined;\nexports.encodeFloat = encodeFloat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar common = require('./common.js');\nvar token = require('./token.js');\nvar jump = require('./jump.js');\n\nconst defaultDecodeOptions = {\n strict: false,\n allowIndefinite: true,\n allowUndefined: true,\n allowBigInt: true\n};\nclass Tokeniser {\n constructor(data, options = {}) {\n this.pos = 0;\n this.data = data;\n this.options = options;\n }\n done() {\n return this.pos >= this.data.length;\n }\n next() {\n const byt = this.data[this.pos];\n let token = jump.quick[byt];\n if (token === undefined) {\n const decoder = jump.jump[byt];\n if (!decoder) {\n throw new Error(`${ common.decodeErrPrefix } no decoder for major type ${ byt >>> 5 } (byte 0x${ byt.toString(16).padStart(2, '0') })`);\n }\n const minor = byt & 31;\n token = decoder(this.data, this.pos, minor, this.options);\n }\n this.pos += token.encodedLength;\n return token;\n }\n}\nconst DONE = Symbol.for('DONE');\nconst BREAK = Symbol.for('BREAK');\nfunction tokenToArray(token, tokeniser, options) {\n const arr = [];\n for (let i = 0; i < token.value; i++) {\n const value = tokensToObject(tokeniser, options);\n if (value === BREAK) {\n if (token.value === Infinity) {\n break;\n }\n throw new Error(`${ common.decodeErrPrefix } got unexpected break to lengthed array`);\n }\n if (value === DONE) {\n throw new Error(`${ common.decodeErrPrefix } found array but not enough entries (got ${ i }, expected ${ token.value })`);\n }\n arr[i] = value;\n }\n return arr;\n}\nfunction tokenToMap(token, tokeniser, options) {\n const useMaps = options.useMaps === true;\n const obj = useMaps ? undefined : {};\n const m = useMaps ? new Map() : undefined;\n for (let i = 0; i < token.value; i++) {\n const key = tokensToObject(tokeniser, options);\n if (key === BREAK) {\n if (token.value === Infinity) {\n break;\n }\n throw new Error(`${ common.decodeErrPrefix } got unexpected break to lengthed map`);\n }\n if (key === DONE) {\n throw new Error(`${ common.decodeErrPrefix } found map but not enough entries (got ${ i } [no key], expected ${ token.value })`);\n }\n if (useMaps !== true && typeof key !== 'string') {\n throw new Error(`${ common.decodeErrPrefix } non-string keys not supported (got ${ typeof key })`);\n }\n const value = tokensToObject(tokeniser, options);\n if (value === DONE) {\n throw new Error(`${ common.decodeErrPrefix } found map but not enough entries (got ${ i } [no value], expected ${ token.value })`);\n }\n if (useMaps) {\n m.set(key, value);\n } else {\n obj[key] = value;\n }\n }\n return useMaps ? m : obj;\n}\nfunction tokensToObject(tokeniser, options) {\n if (tokeniser.done()) {\n return DONE;\n }\n const token$1 = tokeniser.next();\n if (token$1.type === token.Type.break) {\n return BREAK;\n }\n if (token$1.type.terminal) {\n return token$1.value;\n }\n if (token$1.type === token.Type.array) {\n return tokenToArray(token$1, tokeniser, options);\n }\n if (token$1.type === token.Type.map) {\n return tokenToMap(token$1, tokeniser, options);\n }\n if (token$1.type === token.Type.tag) {\n if (options.tags && typeof options.tags[token$1.value] === 'function') {\n const tagged = tokensToObject(tokeniser, options);\n return options.tags[token$1.value](tagged);\n }\n throw new Error(`${ common.decodeErrPrefix } tag not supported (${ token$1.value })`);\n }\n throw new Error('unsupported');\n}\nfunction decode(data, options) {\n if (!(data instanceof Uint8Array)) {\n throw new Error(`${ common.decodeErrPrefix } data to decode must be a Uint8Array`);\n }\n options = Object.assign({}, defaultDecodeOptions, options);\n const tokeniser = options.tokenizer || new Tokeniser(data, options);\n const decoded = tokensToObject(tokeniser, options);\n if (decoded === DONE) {\n throw new Error(`${ common.decodeErrPrefix } did not find any content to decode`);\n }\n if (decoded === BREAK) {\n throw new Error(`${ common.decodeErrPrefix } got unexpected break`);\n }\n if (!tokeniser.done()) {\n throw new Error(`${ common.decodeErrPrefix } too many terminals, data makes no sense`);\n }\n return decoded;\n}\n\nexports.Tokeniser = Tokeniser;\nexports.decode = decode;\nexports.tokensToObject = tokensToObject;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hasher = require('./hasher.js');\nvar bytes = require('../bytes.js');\n\nconst identity = hasher.from({\n name: 'identity',\n code: 0,\n encode: input => bytes.coerce(input)\n});\n\nexports.identity = identity;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar digest = require('./digest.js');\n\nconst from = ({name, code, encode}) => new Hasher(name, code, encode);\nclass Hasher {\n constructor(name, code, encode) {\n this.name = name;\n this.code = code;\n this.encode = encode;\n }\n async digest(input) {\n if (input instanceof Uint8Array) {\n const digest$1 = await this.encode(input);\n return digest.create(this.code, digest$1);\n } else {\n throw Error('Unknown type, must be binary type');\n }\n }\n}\n\nexports.Hasher = Hasher;\nexports.from = from;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar identity = require('./bases/identity.js');\nvar base2 = require('./bases/base2.js');\nvar base8 = require('./bases/base8.js');\nvar base10 = require('./bases/base10.js');\nvar base16 = require('./bases/base16.js');\nvar base32 = require('./bases/base32.js');\nvar base36 = require('./bases/base36.js');\nvar base58 = require('./bases/base58.js');\nvar base64 = require('./bases/base64.js');\nvar sha2 = require('./hashes/sha2.js');\nvar identity$1 = require('./hashes/identity.js');\nvar raw = require('./codecs/raw.js');\nvar json = require('./codecs/json.js');\nrequire('./index.js');\nvar cid = require('./cid.js');\nvar hasher = require('./hashes/hasher.js');\nvar digest = require('./hashes/digest.js');\nvar varint = require('./varint.js');\nvar bytes = require('./bytes.js');\n\nconst bases = {\n ...identity,\n ...base2,\n ...base8,\n ...base10,\n ...base16,\n ...base32,\n ...base36,\n ...base58,\n ...base64\n};\nconst hashes = {\n ...sha2,\n ...identity$1\n};\nconst codecs = {\n raw,\n json\n};\n\nexports.CID = cid.CID;\nexports.hasher = hasher;\nexports.digest = digest;\nexports.varint = varint;\nexports.bytes = bytes;\nexports.bases = bases;\nexports.codecs = codecs;\nexports.hashes = hashes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar bytes = require('../bytes.js');\n\nconst identity = base.from({\n prefix: '\\0',\n name: 'identity',\n encode: buf => bytes.toString(buf),\n decode: str => bytes.fromString(str)\n});\n\nexports.identity = identity;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base2 = base.rfc4648({\n prefix: '0',\n name: 'base2',\n alphabet: '01',\n bitsPerChar: 1\n});\n\nexports.base2 = base2;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base8 = base.rfc4648({\n prefix: '7',\n name: 'base8',\n alphabet: '01234567',\n bitsPerChar: 3\n});\n\nexports.base8 = base8;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base10 = base.baseX({\n prefix: '9',\n name: 'base10',\n alphabet: '0123456789'\n});\n\nexports.base10 = base10;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base16 = base.rfc4648({\n prefix: 'f',\n name: 'base16',\n alphabet: '0123456789abcdef',\n bitsPerChar: 4\n});\nconst base16upper = base.rfc4648({\n prefix: 'F',\n name: 'base16upper',\n alphabet: '0123456789ABCDEF',\n bitsPerChar: 4\n});\n\nexports.base16 = base16;\nexports.base16upper = base16upper;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base36 = base.baseX({\n prefix: 'k',\n name: 'base36',\n alphabet: '0123456789abcdefghijklmnopqrstuvwxyz'\n});\nconst base36upper = base.baseX({\n prefix: 'K',\n name: 'base36upper',\n alphabet: '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'\n});\n\nexports.base36 = base36;\nexports.base36upper = base36upper;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\n\nconst base64 = base.rfc4648({\n prefix: 'm',\n name: 'base64',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',\n bitsPerChar: 6\n});\nconst base64pad = base.rfc4648({\n prefix: 'M',\n name: 'base64pad',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=',\n bitsPerChar: 6\n});\nconst base64url = base.rfc4648({\n prefix: 'u',\n name: 'base64url',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_',\n bitsPerChar: 6\n});\nconst base64urlpad = base.rfc4648({\n prefix: 'U',\n name: 'base64urlpad',\n alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=',\n bitsPerChar: 6\n});\n\nexports.base64 = base64;\nexports.base64pad = base64pad;\nexports.base64url = base64url;\nexports.base64urlpad = base64urlpad;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hasher = require('./hasher.js');\n\nconst sha = name => async data => new Uint8Array(await crypto.subtle.digest(name, data));\nconst sha256 = hasher.from({\n name: 'sha2-256',\n code: 18,\n encode: sha('SHA-256')\n});\nconst sha512 = hasher.from({\n name: 'sha2-512',\n code: 19,\n encode: sha('SHA-512')\n});\n\nexports.sha256 = sha256;\nexports.sha512 = sha512;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bytes = require('../bytes.js');\n\nconst name = 'raw';\nconst code = 85;\nconst encode = node => bytes.coerce(node);\nconst decode = data => bytes.coerce(data);\n\nexports.code = code;\nexports.decode = decode;\nexports.encode = encode;\nexports.name = name;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst textEncoder = new TextEncoder();\nconst textDecoder = new TextDecoder();\nconst name = 'json';\nconst code = 512;\nconst encode = node => textEncoder.encode(JSON.stringify(node));\nconst decode = data => JSON.parse(textDecoder.decode(data));\n\nexports.code = code;\nexports.decode = decode;\nexports.encode = encode;\nexports.name = name;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('./cid.js');\nvar varint = require('./varint.js');\nvar bytes = require('./bytes.js');\nvar hasher = require('./hashes/hasher.js');\nvar digest = require('./hashes/digest.js');\n\n\n\nexports.CID = cid.CID;\nexports.varint = varint;\nexports.bytes = bytes;\nexports.hasher = hasher;\nexports.digest = digest;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction initAssets() {\n}\n\nexports.initAssets = initAssets;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass NotInitializedError extends Error {\n constructor(message = 'not initialized') {\n super(message);\n this.name = 'NotInitializedError';\n this.code = NotInitializedError.code;\n }\n}\nNotInitializedError.code = 'ERR_NOT_INITIALIZED';\nclass AlreadyInitializingError extends Error {\n constructor(message = 'cannot initialize an initializing node') {\n super(message);\n this.name = 'AlreadyInitializingError';\n this.code = AlreadyInitializedError.code;\n }\n}\nAlreadyInitializingError.code = 'ERR_ALREADY_INITIALIZING';\nclass AlreadyInitializedError extends Error {\n constructor(message = 'cannot re-initialize an initialized node') {\n super(message);\n this.name = 'AlreadyInitializedError';\n this.code = AlreadyInitializedError.code;\n }\n}\nAlreadyInitializedError.code = 'ERR_ALREADY_INITIALIZED';\nclass NotStartedError extends Error {\n constructor(message = 'not started') {\n super(message);\n this.name = 'NotStartedError';\n this.code = NotStartedError.code;\n }\n}\nNotStartedError.code = 'ERR_NOT_STARTED';\nclass AlreadyStartingError extends Error {\n constructor(message = 'cannot start, already startin') {\n super(message);\n this.name = 'AlreadyStartingError';\n this.code = AlreadyStartingError.code;\n }\n}\nAlreadyStartingError.code = 'ERR_ALREADY_STARTING';\nclass AlreadyStartedError extends Error {\n constructor(message = 'cannot start, already started') {\n super(message);\n this.name = 'AlreadyStartedError';\n this.code = AlreadyStartedError.code;\n }\n}\nAlreadyStartedError.code = 'ERR_ALREADY_STARTED';\nclass NotEnabledError extends Error {\n constructor(message = 'not enabled') {\n super(message);\n this.name = 'NotEnabledError';\n this.code = NotEnabledError.code;\n }\n}\nNotEnabledError.code = 'ERR_NOT_ENABLED';\n\nexports.AlreadyInitializedError = AlreadyInitializedError;\nexports.AlreadyInitializingError = AlreadyInitializingError;\nexports.AlreadyStartedError = AlreadyStartedError;\nexports.AlreadyStartingError = AlreadyStartingError;\nexports.NotEnabledError = NotEnabledError;\nexports.NotInitializedError = NotInitializedError;\nexports.NotStartedError = NotStartedError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bases = require('./util/bases.js');\n\nfunction fromString(string, encoding = 'utf8') {\n const base = bases[encoding];\n if (!base) {\n throw new Error(`Unsupported encoding \"${ encoding }\"`);\n }\n return base.decoder.decode(`${ base.prefix }${ string }`);\n}\n\nexports.fromString = fromString;\n","'use strict';\n\nvar basics = require('multiformats/basics');\n\nfunction createCodec(name, prefix, encode, decode) {\n return {\n name,\n prefix,\n encoder: {\n name,\n prefix,\n encode\n },\n decoder: { decode }\n };\n}\nconst string = createCodec('utf8', 'u', buf => {\n const decoder = new TextDecoder('utf8');\n return 'u' + decoder.decode(buf);\n}, str => {\n const encoder = new TextEncoder();\n return encoder.encode(str.substring(1));\n});\nconst ascii = createCodec('ascii', 'a', buf => {\n let string = 'a';\n for (let i = 0; i < buf.length; i++) {\n string += String.fromCharCode(buf[i]);\n }\n return string;\n}, str => {\n str = str.substring(1);\n const buf = new Uint8Array(str.length);\n for (let i = 0; i < str.length; i++) {\n buf[i] = str.charCodeAt(i);\n }\n return buf;\n});\nconst BASES = {\n utf8: string,\n 'utf-8': string,\n hex: basics.bases.base16,\n latin1: ascii,\n ascii: ascii,\n binary: ascii,\n ...basics.bases\n};\n\nmodule.exports = BASES;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar service = require('../utils/service.js');\n\nfunction createStart({network, preload, peerId, keychain, repo, ipns, mfsPreload, print, options}) {\n const start = async () => {\n const {libp2p} = await service.Service.start(network, {\n peerId,\n repo,\n print,\n options\n });\n await Promise.all([\n ipns.startOnline({\n keychain,\n libp2p,\n peerId,\n repo\n }),\n preload.start(),\n mfsPreload.start()\n ]);\n };\n return start;\n}\n\nexports.createStart = createStart;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('../errors.js');\nvar utils = require('../utils.js');\n\nclass Service {\n static create({start, stop}) {\n return new Service(start, stop);\n }\n static async start(service, options) {\n const {state, activate} = service;\n switch (state.status) {\n case 'stopped': {\n try {\n const promise = activate(options);\n service.state = {\n status: 'starting',\n ready: promise\n };\n const result = await promise;\n service.state = {\n status: 'started',\n value: result\n };\n return result;\n } catch (error) {\n service.state = { status: 'stopped' };\n throw error;\n }\n }\n case 'starting': {\n throw new errors.AlreadyStartingError();\n }\n case 'started': {\n throw new errors.AlreadyStartedError();\n }\n case 'stopping': {\n await state.ready;\n return await Service.start(service, options);\n }\n default: {\n return Service.panic(service);\n }\n }\n }\n static async stop(service) {\n const {state, deactivate} = service;\n switch (state.status) {\n case 'stopped': {\n break;\n }\n case 'starting': {\n try {\n await state.ready;\n } catch (_) {\n }\n return await Service.stop(service);\n }\n case 'stopping': {\n return await state.ready;\n }\n case 'started': {\n if (deactivate) {\n await deactivate(state.value);\n }\n service.state = { status: 'stopped' };\n break;\n }\n default: {\n Service.panic(state);\n }\n }\n }\n static try({state}) {\n switch (state.status) {\n case 'started':\n return state.value;\n default:\n return null;\n }\n }\n static async use({state}, options) {\n switch (state.status) {\n case 'started':\n return state.value;\n case 'starting':\n return await utils.withTimeout(state.ready, options);\n default:\n throw new errors.NotStartedError();\n }\n }\n static panic({state}) {\n const status = JSON.stringify({ status: state.status });\n throw RangeError(`Service in invalid state ${ status }, should never happen if you see this please report a bug`);\n }\n constructor(activate, deactivate) {\n this.activate = activate;\n this.deactivate = deactivate;\n this.state = { status: 'stopped' };\n }\n async use(options) {\n return await Service.use(this, options);\n }\n try() {\n return Service.try(this);\n }\n}\n\nexports.Service = Service;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar isIpfs = require('is-ipfs');\nvar cid = require('multiformats/cid');\nvar key = require('interface-datastore/key');\nvar errCode = require('err-code');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar toCidAndPath = require('ipfs-core-utils/to-cid-and-path');\nvar dagPB = require('@ipld/dag-pb');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nconst ERR_BAD_PATH = 'ERR_BAD_PATH';\nconst OFFLINE_ERROR = 'This command must be run in online mode. Try running \\'ipfs daemon\\' first.';\nconst MFS_ROOT_KEY = new key.Key('/local/filesroot');\nconst MFS_MAX_CHUNK_SIZE = 262144;\nconst MFS_MAX_LINKS = 174;\nconst normalizePath = pathStr => {\n const cid$1 = cid.CID.asCID(pathStr);\n if (cid$1) {\n return `/ipfs/${ pathStr }`;\n }\n const str = pathStr.toString();\n try {\n return `/ipfs/${ cid.CID.parse(str) }`;\n } catch {\n }\n if (isIpfs__default['default'].path(str)) {\n return str;\n } else {\n throw errCode__default['default'](new Error(`invalid path: ${ pathStr }`), ERR_BAD_PATH);\n }\n};\nconst normalizeCidPath = path => {\n if (path instanceof Uint8Array) {\n return cid.CID.decode(path).toString();\n }\n path = path.toString();\n if (path.indexOf('/ipfs/') === 0) {\n path = path.substring('/ipfs/'.length);\n }\n if (path.charAt(path.length - 1) === '/') {\n path = path.substring(0, path.length - 1);\n }\n return path;\n};\nconst resolvePath = async function (repo, codecs, ipfsPath, options = {}) {\n const {cid: cid$1, path} = toCidAndPath.toCidAndPath(ipfsPath);\n if (path) {\n options.path = path;\n }\n let lastCid = cid$1;\n let lastRemainderPath = options.path || '';\n if (lastRemainderPath.startsWith('/')) {\n lastRemainderPath = lastRemainderPath.substring(1);\n }\n if (options.path) {\n try {\n for await (const {value, remainderPath} of resolve(cid$1, options.path, codecs, repo, { signal: options.signal })) {\n if (!cid.CID.asCID(value)) {\n break;\n }\n lastRemainderPath = remainderPath;\n lastCid = value;\n }\n } catch (err) {\n if (err.message.startsWith('Object has no property')) {\n err.message = `no link named \"${ lastRemainderPath.split('/')[0] }\" under ${ lastCid }`;\n err.code = 'ERR_NO_LINK';\n }\n throw err;\n }\n }\n return {\n cid: lastCid,\n remainderPath: lastRemainderPath || ''\n };\n};\nconst mapFile = file => {\n if (file.type !== 'file' && file.type !== 'directory' && file.type !== 'raw') {\n throw new Error(`Unknown node type '${ file.type }'`);\n }\n const output = {\n cid: file.cid,\n path: file.path,\n name: file.name,\n size: file.size,\n type: 'file'\n };\n if (file.type === 'directory') {\n output.type = 'dir';\n }\n if (file.type === 'file') {\n output.size = file.unixfs.fileSize();\n }\n if (file.type === 'file' || file.type === 'directory') {\n output.mode = file.unixfs.mode;\n if (file.unixfs.mtime !== undefined) {\n output.mtime = file.unixfs.mtime;\n }\n }\n return output;\n};\nconst withTimeout = withTimeoutOption.withTimeoutOption(async (promise, _options) => await promise);\nconst resolve = async function* (cid$1, path, codecs, repo, options) {\n const load = async cid => {\n const codec = await codecs.getCodec(cid.code);\n const block = await repo.blocks.get(cid, options);\n return codec.decode(block);\n };\n const parts = path.split('/').filter(Boolean);\n let value = await load(cid$1);\n let lastCid = cid$1;\n if (!parts.length) {\n yield {\n value,\n remainderPath: ''\n };\n }\n while (parts.length) {\n const key = parts.shift();\n if (!key) {\n throw errCode__default['default'](new Error(`Could not resolve path \"${ path }\"`), 'ERR_INVALID_PATH');\n }\n if (cid$1.code === dagPB__namespace.code && Array.isArray(value.Links)) {\n const link = value.Links.find(l => l.Name === key);\n if (link) {\n yield {\n value: link.Hash,\n remainderPath: parts.join('/')\n };\n value = await load(link.Hash);\n lastCid = link.Hash;\n continue;\n }\n }\n if (Object.prototype.hasOwnProperty.call(value, key)) {\n value = value[key];\n yield {\n value,\n remainderPath: parts.join('/')\n };\n } else {\n throw errCode__default['default'](new Error(`no link named \"${ key }\" under ${ lastCid }`), 'ERR_NO_LINK');\n }\n if (cid.CID.asCID(value)) {\n lastCid = value;\n value = await load(value);\n }\n }\n};\n\nexports.MFS_MAX_CHUNK_SIZE = MFS_MAX_CHUNK_SIZE;\nexports.MFS_MAX_LINKS = MFS_MAX_LINKS;\nexports.MFS_ROOT_KEY = MFS_ROOT_KEY;\nexports.OFFLINE_ERROR = OFFLINE_ERROR;\nexports.mapFile = mapFile;\nexports.normalizeCidPath = normalizeCidPath;\nexports.normalizePath = normalizePath;\nexports.resolve = resolve;\nexports.resolvePath = resolvePath;\nexports.withTimeout = withTimeout;\n","'use strict'\n\nconst { base58btc } = require('multiformats/bases/base58')\nconst { base32 } = require('multiformats/bases/base32')\nconst Digest = require('multiformats/hashes/digest')\nconst { Multiaddr } = require('multiaddr')\nconst mafmt = require('mafmt')\nconst { CID } = require('multiformats/cid')\nconst { URL } = require('iso-url')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst pathGatewayPattern = /^https?:\\/\\/[^/]+\\/(ip[fn]s)\\/([^/?#]+)/\nconst pathPattern = /^\\/(ip[fn]s)\\/([^/?#]+)/\nconst defaultProtocolMatch = 1\nconst defaultHashMath = 2\n\n// CID, libp2p-key or DNSLink\nconst subdomainGatewayPattern = /^https?:\\/\\/([^/]+)\\.(ip[fn]s)\\.[^/?]+/\nconst subdomainIdMatch = 1\nconst subdomainProtocolMatch = 2\n\n// Fully qualified domain name (FQDN) that has an explicit .tld suffix\nconst fqdnWithTld = /^(([a-z0-9]|[a-z0-9][a-z0-9-]*[a-z0-9])\\.)+([a-z0-9]|[a-z0-9][a-z0-9-]*[a-z0-9])$/\n\n/**\n * @param {*} hash\n */\nfunction isMultihash (hash) {\n const formatted = convertToString(hash)\n try {\n Digest.decode(base58btc.decode('z' + formatted))\n } catch {\n return false\n }\n\n return true\n}\n\n/**\n * @param {*} hash\n */\nfunction isBase32EncodedMultibase (hash) {\n try {\n base32.decode(hash)\n } catch {\n return false\n }\n\n return true\n}\n\n/**\n * @param {*} hash\n */\nfunction isCID (hash) {\n try {\n if (typeof hash === 'string') {\n return Boolean(CID.parse(hash))\n }\n\n if (hash instanceof Uint8Array) {\n return Boolean(CID.decode(hash))\n }\n\n return Boolean(CID.asCID(hash)) // eslint-disable-line no-new\n } catch (e) {\n return false\n }\n}\n\n/**\n * @param {*} input\n */\nfunction isMultiaddr (input) {\n if (!input) return false\n if (Multiaddr.isMultiaddr(input)) return true\n try {\n new Multiaddr(input) // eslint-disable-line no-new\n return true\n } catch (e) {\n return false\n }\n}\n\n/**\n * @param {string | Uint8Array | Multiaddr} input\n */\nfunction isPeerMultiaddr (input) {\n return isMultiaddr(input) && mafmt.P2P.matches(input)\n}\n\n/**\n * @param {string | Uint8Array} input\n * @param {RegExp | string} pattern\n * @param {number} [protocolMatch=1]\n * @param {number} [hashMatch=2]\n */\nfunction isIpfs (input, pattern, protocolMatch = defaultProtocolMatch, hashMatch = defaultHashMath) {\n const formatted = convertToString(input)\n if (!formatted) {\n return false\n }\n\n const match = formatted.match(pattern)\n if (!match) {\n return false\n }\n\n if (match[protocolMatch] !== 'ipfs') {\n return false\n }\n\n let hash = match[hashMatch]\n\n if (hash && pattern === subdomainGatewayPattern) {\n // when doing checks for subdomain context\n // ensure hash is case-insensitive\n // (browsers force-lowercase authority component anyway)\n hash = hash.toLowerCase()\n }\n\n return isCID(hash)\n}\n\n/**\n *\n * @param {string | Uint8Array} input\n * @param {string | RegExp} pattern\n * @param {number} [protocolMatch=1]\n * @param {number} [hashMatch=1]\n */\nfunction isIpns (input, pattern, protocolMatch = defaultProtocolMatch, hashMatch = defaultHashMath) {\n const formatted = convertToString(input)\n if (!formatted) {\n return false\n }\n const match = formatted.match(pattern)\n if (!match) {\n return false\n }\n\n if (match[protocolMatch] !== 'ipns') {\n return false\n }\n\n let ipnsId = match[hashMatch]\n\n if (ipnsId && pattern === subdomainGatewayPattern) {\n // when doing checks for subdomain context\n // ensure ipnsId is case-insensitive\n // (browsers force-lowercase authority compotent anyway)\n ipnsId = ipnsId.toLowerCase()\n // Check if it is cidv1\n if (isCID(ipnsId)) return true\n // Check if it looks like FQDN\n try {\n if (!ipnsId.includes('.') && ipnsId.includes('-')) {\n // name without tld, assuming its inlined into a single DNS label\n // (https://github.com/ipfs/in-web-browsers/issues/169)\n // en-wikipedia--on--ipfs-org → en.wikipedia-on-ipfs.org\n ipnsId = ipnsId.replace(/--/g, '@').replace(/-/g, '.').replace(/@/g, '-')\n }\n // URL implementation in web browsers forces lowercase of the hostname\n const { hostname } = new URL(`http://${ipnsId}`) // eslint-disable-line no-new\n // Check if potential FQDN has an explicit TLD\n return fqdnWithTld.test(hostname)\n } catch (e) {\n return false\n }\n }\n\n return true\n}\n\n/**\n * @param {any} input\n */\nfunction isString (input) {\n return typeof input === 'string'\n}\n\n/**\n * @param {Uint8Array | string} input\n */\nfunction convertToString (input) {\n if (input instanceof Uint8Array) {\n return uint8ArrayToString(input, 'base58btc')\n }\n\n if (isString(input)) {\n return input\n }\n\n return false\n}\n\n/**\n * @param {string | Uint8Array} url\n */\nconst ipfsSubdomain = (url) => isIpfs(url, subdomainGatewayPattern, subdomainProtocolMatch, subdomainIdMatch)\n/**\n * @param {string | Uint8Array} url\n */\nconst ipnsSubdomain = (url) => isIpns(url, subdomainGatewayPattern, subdomainProtocolMatch, subdomainIdMatch)\n/**\n * @param {string | Uint8Array} url\n */\nconst subdomain = (url) => ipfsSubdomain(url) || ipnsSubdomain(url)\n\n/**\n * @param {string | Uint8Array} url\n */\nconst ipfsUrl = (url) => isIpfs(url, pathGatewayPattern) || ipfsSubdomain(url)\n/**\n * @param {string | Uint8Array} url\n */\nconst ipnsUrl = (url) => isIpns(url, pathGatewayPattern) || ipnsSubdomain(url)\n/**\n * @param {string | Uint8Array} url\n */\nconst url = (url) => ipfsUrl(url) || ipnsUrl(url) || subdomain(url)\n\n/**\n * @param {string | Uint8Array} path\n */\nconst path = (path) => isIpfs(path, pathPattern) || isIpns(path, pathPattern)\n\nmodule.exports = {\n multihash: isMultihash,\n multiaddr: isMultiaddr,\n peerMultiaddr: isPeerMultiaddr,\n cid: isCID,\n /**\n * @param {CID | string | Uint8Array} cid\n */\n base32cid: (cid) => (isBase32EncodedMultibase(cid) && isCID(cid)),\n ipfsSubdomain,\n ipnsSubdomain,\n subdomain,\n subdomainGatewayPattern,\n ipfsUrl,\n ipnsUrl,\n url,\n pathGatewayPattern: pathGatewayPattern,\n /**\n * @param {string | Uint8Array} path\n */\n ipfsPath: (path) => isIpfs(path, pathPattern),\n /**\n * @param {string | Uint8Array} path\n */\n ipnsPath: (path) => isIpns(path, pathPattern),\n path,\n pathPattern,\n /**\n * @param {string | Uint8Array} x\n */\n urlOrPath: (x) => url(x) || path(x),\n /**\n * @param {string | Uint8Array | CID} path\n */\n cidPath: path => isString(path) && !isCID(path) && isIpfs(`/ipfs/${path}`, pathPattern)\n}\n","'use strict'\n\nconst codec = require('./codec')\nconst protocols = require('./protocols-table')\nconst varint = require('varint')\nconst { CID } = require('multiformats/cid')\nconst { base58btc } = require('multiformats/bases/base58')\nconst errCode = require('err-code')\nconst inspect = Symbol.for('nodejs.util.inspect.custom')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\n/**\n * @typedef {(addr: Multiaddr) => Promise<string[]>} Resolver\n * @typedef {string | Multiaddr | Uint8Array | null} MultiaddrInput\n * @typedef {import('./types').MultiaddrObject} MultiaddrObject\n * @typedef {import('./types').Protocol} Protocol\n */\n\n/** @type {Map<string, Resolver>} */\nconst resolvers = new Map()\nconst symbol = Symbol.for('@multiformats/js-multiaddr/multiaddr')\n\n/**\n * Creates a [multiaddr](https://github.com/multiformats/multiaddr) from\n * a Uint8Array, String or another Multiaddr instance\n * public key.\n *\n */\nclass Multiaddr {\n /**\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // <Multiaddr 047f000001060fa1 - /ip4/127.0.0.1/tcp/4001>\n * ```\n *\n * @param {MultiaddrInput} [addr] - If String or Uint8Array, needs to adhere to the address format of a [multiaddr](https://github.com/multiformats/multiaddr#string-format)\n */\n constructor (addr) {\n // default\n if (addr == null) {\n addr = ''\n }\n\n // Define symbol\n Object.defineProperty(this, symbol, { value: true })\n\n if (addr instanceof Uint8Array) {\n /** @type {Uint8Array} - The raw bytes representing this multiaddress */\n this.bytes = codec.fromBytes(addr)\n } else if (typeof addr === 'string') {\n if (addr.length > 0 && addr.charAt(0) !== '/') {\n throw new Error(`multiaddr \"${addr}\" must start with a \"/\"`)\n }\n this.bytes = codec.fromString(addr)\n } else if (Multiaddr.isMultiaddr(addr)) { // Multiaddr\n this.bytes = codec.fromBytes(addr.bytes) // validate + copy buffer\n } else {\n throw new Error('addr must be a string, Buffer, or another Multiaddr')\n }\n }\n\n /**\n * Returns Multiaddr as a String\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').toString()\n * // '/ip4/127.0.0.1/tcp/4001'\n * ```\n */\n toString () {\n return codec.bytesToString(this.bytes)\n }\n\n /**\n * Returns Multiaddr as a JSON encoded object\n *\n * @example\n * ```js\n * JSON.stringify(new Multiaddr('/ip4/127.0.0.1/tcp/4001'))\n * // '/ip4/127.0.0.1/tcp/4001'\n * ```\n */\n toJSON () {\n return this.toString()\n }\n\n /**\n * Returns Multiaddr as a convinient options object to be used with net.createConnection\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').toOptions()\n * // { family: 4, host: '127.0.0.1', transport: 'tcp', port: 4001 }\n * ```\n */\n toOptions () {\n /** @type {MultiaddrObject} */\n const opts = {}\n const parsed = this.toString().split('/')\n opts.family = parsed[1] === 'ip4' ? 4 : 6\n opts.host = parsed[2]\n opts.transport = parsed[3]\n opts.port = parseInt(parsed[4])\n return opts\n }\n\n /**\n * Returns the protocols the Multiaddr is defined with, as an array of objects, in\n * left-to-right order. Each object contains the protocol code, protocol name,\n * and the size of its address space in bits.\n * [See list of protocols](https://github.com/multiformats/multiaddr/blob/master/protocols.csv)\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').protos()\n * // [ { code: 4, size: 32, name: 'ip4' },\n * // { code: 6, size: 16, name: 'tcp' } ]\n * ```\n *\n * @returns {Protocol[]} protocols - All the protocols the address is composed of\n */\n protos () {\n return this.protoCodes().map(code => Object.assign({}, protocols(code)))\n }\n\n /**\n * Returns the codes of the protocols in left-to-right order.\n * [See list of protocols](https://github.com/multiformats/multiaddr/blob/master/protocols.csv)\n *\n * @example\n * ```js\n * Multiaddr('/ip4/127.0.0.1/tcp/4001').protoCodes()\n * // [ 4, 6 ]\n * ```\n *\n * @returns {number[]} protocol codes\n */\n protoCodes () {\n const codes = []\n const buf = this.bytes\n let i = 0\n while (i < buf.length) {\n const code = varint.decode(buf, i)\n const n = varint.decode.bytes\n\n const p = protocols(code)\n const size = codec.sizeForAddr(p, buf.slice(i + n))\n\n i += (size + n)\n codes.push(code)\n }\n\n return codes\n }\n\n /**\n * Returns the names of the protocols in left-to-right order.\n * [See list of protocols](https://github.com/multiformats/multiaddr/blob/master/protocols.csv)\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').protoNames()\n * // [ 'ip4', 'tcp' ]\n * ```\n *\n * @returns {string[]} protocol names\n */\n protoNames () {\n return this.protos().map(proto => proto.name)\n }\n\n /**\n * Returns a tuple of parts\n *\n * @example\n * ```js\n * new Multiaddr(\"/ip4/127.0.0.1/tcp/4001\").tuples()\n * // [ [ 4, <Buffer 7f 00 00 01> ], [ 6, <Buffer 0f a1> ] ]\n * ```\n */\n tuples () {\n return codec.bytesToTuples(this.bytes)\n }\n\n /**\n * Returns a tuple of string/number parts\n * - tuples[][0] = code of protocol\n * - tuples[][1] = contents of address\n *\n * @example\n * ```js\n * new Multiaddr(\"/ip4/127.0.0.1/tcp/4001\").stringTuples()\n * // [ [ 4, '127.0.0.1' ], [ 6, '4001' ] ]\n * ```\n */\n stringTuples () {\n const t = codec.bytesToTuples(this.bytes)\n return codec.tuplesToStringTuples(t)\n }\n\n /**\n * Encapsulates a Multiaddr in another Multiaddr\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080')\n * // <Multiaddr 0408080808060438 - /ip4/8.8.8.8/tcp/1080>\n *\n * const mh2 = new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // <Multiaddr 047f000001060fa1 - /ip4/127.0.0.1/tcp/4001>\n *\n * const mh3 = mh1.encapsulate(mh2)\n * // <Multiaddr 0408080808060438047f000001060fa1 - /ip4/8.8.8.8/tcp/1080/ip4/127.0.0.1/tcp/4001>\n *\n * mh3.toString()\n * // '/ip4/8.8.8.8/tcp/1080/ip4/127.0.0.1/tcp/4001'\n * ```\n *\n * @param {MultiaddrInput} addr - Multiaddr to add into this Multiaddr\n */\n encapsulate (addr) {\n addr = new Multiaddr(addr)\n return new Multiaddr(this.toString() + addr.toString())\n }\n\n /**\n * Decapsulates a Multiaddr from another Multiaddr\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080')\n * // <Multiaddr 0408080808060438 - /ip4/8.8.8.8/tcp/1080>\n *\n * const mh2 = new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // <Multiaddr 047f000001060fa1 - /ip4/127.0.0.1/tcp/4001>\n *\n * const mh3 = mh1.encapsulate(mh2)\n * // <Multiaddr 0408080808060438047f000001060fa1 - /ip4/8.8.8.8/tcp/1080/ip4/127.0.0.1/tcp/4001>\n *\n * mh3.decapsulate(mh2).toString()\n * // '/ip4/8.8.8.8/tcp/1080'\n * ```\n *\n * @param {Multiaddr | string} addr - Multiaddr to remove from this Multiaddr\n * @returns {Multiaddr}\n */\n decapsulate (addr) {\n const addrString = addr.toString()\n const s = this.toString()\n const i = s.lastIndexOf(addrString)\n if (i < 0) {\n throw new Error('Address ' + this + ' does not contain subaddress: ' + addr)\n }\n return new Multiaddr(s.slice(0, i))\n }\n\n /**\n * A more reliable version of `decapsulate` if you are targeting a\n * specific code, such as 421 (the `p2p` protocol code). The last index of the code\n * will be removed from the `Multiaddr`, and a new instance will be returned.\n * If the code is not present, the original `Multiaddr` is returned.\n *\n * @example\n * ```js\n * const addr = new Multiaddr('/ip4/0.0.0.0/tcp/8080/p2p/QmcgpsyWgH8Y8ajJz1Cu72KnS5uo2Aa2LpzU7kinSupNKC')\n * // <Multiaddr 0400... - /ip4/0.0.0.0/tcp/8080/p2p/QmcgpsyWgH8Y8ajJz1Cu72KnS5uo2Aa2LpzU7kinSupNKC>\n *\n * addr.decapsulateCode(421).toString()\n * // '/ip4/0.0.0.0/tcp/8080'\n *\n * new Multiaddr('/ip4/127.0.0.1/tcp/8080').decapsulateCode(421).toString()\n * // '/ip4/127.0.0.1/tcp/8080'\n * ```\n *\n * @param {number} code - The code of the protocol to decapsulate from this Multiaddr\n * @returns {Multiaddr}\n */\n decapsulateCode (code) {\n const tuples = this.tuples()\n for (let i = tuples.length - 1; i >= 0; i--) {\n if (tuples[i][0] === code) {\n return new Multiaddr(codec.tuplesToBytes(tuples.slice(0, i)))\n }\n }\n return this\n }\n\n /**\n * Extract the peerId if the multiaddr contains one\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080/ipfs/QmValidBase58string')\n * // <Multiaddr 0408080808060438 - /ip4/8.8.8.8/tcp/1080/ipfs/QmValidBase58string>\n *\n * // should return QmValidBase58string or null if the id is missing or invalid\n * const peerId = mh1.getPeerId()\n * ```\n *\n * @returns {string | null} peerId - The id of the peer or null if invalid or missing from the ma\n */\n getPeerId () {\n try {\n const tuples = this.stringTuples().filter((tuple) => {\n if (tuple[0] === protocols.names.ipfs.code) {\n return true\n }\n return false\n })\n\n // Get the last ipfs tuple ['ipfs', 'peerid string']\n const tuple = tuples.pop()\n if (tuple && tuple[1]) {\n const peerIdStr = tuple[1]\n\n // peer id is base58btc encoded string but not multibase encoded so add the `z`\n // prefix so we can validate that it is correctly encoded\n if (peerIdStr[0] === 'Q' || peerIdStr[0] === '1') {\n return uint8ArrayToString(base58btc.decode(`z${peerIdStr}`), 'base58btc')\n }\n\n // try to parse peer id as CID\n return uint8ArrayToString(CID.parse(peerIdStr).multihash.bytes, 'base58btc')\n }\n\n return null\n } catch (e) {\n return null\n }\n }\n\n /**\n * Extract the path if the multiaddr contains one\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080/unix/tmp/p2p.sock')\n * // <Multiaddr 0408080808060438 - /ip4/8.8.8.8/tcp/1080/unix/tmp/p2p.sock>\n *\n * // should return utf8 string or null if the id is missing or invalid\n * const path = mh1.getPath()\n * ```js\n *\n * @returns {string | null} path - The path of the multiaddr, or null if no path protocol is present\n */\n getPath () {\n let path = null\n try {\n path = this.stringTuples().filter((tuple) => {\n const proto = protocols(tuple[0])\n if (proto.path) {\n return true\n }\n return false\n })[0][1]\n\n if (!path) {\n path = null\n }\n } catch (e) {\n path = null\n }\n return path\n }\n\n /**\n * Checks if two Multiaddrs are the same\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/8.8.8.8/tcp/1080')\n * // <Multiaddr 0408080808060438 - /ip4/8.8.8.8/tcp/1080>\n *\n * const mh2 = new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // <Multiaddr 047f000001060fa1 - /ip4/127.0.0.1/tcp/4001>\n *\n * mh1.equals(mh1)\n * // true\n *\n * mh1.equals(mh2)\n * // false\n * ```\n *\n * @param {Multiaddr} addr\n * @returns {boolean}\n */\n equals (addr) {\n return uint8ArrayEquals(this.bytes, addr.bytes)\n }\n\n /**\n * Resolve multiaddr if containing resolvable hostname.\n *\n * @example\n * ```js\n * Multiaddr.resolvers.set('dnsaddr', resolverFunction)\n * const mh1 = new Multiaddr('/dnsaddr/bootstrap.libp2p.io/p2p/QmbLHAnMoJPWSCR5Zhtx6BHJX9KiKNN6tpvbUcqanj75Nb')\n * const resolvedMultiaddrs = await mh1.resolve()\n * // [\n * // <Multiaddr 04934b5353060fa1a503221220c10f9319dac35c270a6b74cd644cb3acfc1f6efc8c821f8eb282599fd1814f64 - /ip4/147.75.83.83/tcp/4001/p2p/QmbLHAnMoJPWSCR5Zhtx6BHJX9KiKNN6tpvbUcqanj75Nb>,\n * // <Multiaddr 04934b53530601bbde03a503221220c10f9319dac35c270a6b74cd644cb3acfc1f6efc8c821f8eb282599fd1814f64 - /ip4/147.75.83.83/tcp/443/wss/p2p/QmbLHAnMoJPWSCR5Zhtx6BHJX9KiKNN6tpvbUcqanj75Nb>,\n * // <Multiaddr 04934b535391020fa1cc03a503221220c10f9319dac35c270a6b74cd644cb3acfc1f6efc8c821f8eb282599fd1814f64 - /ip4/147.75.83.83/udp/4001/quic/p2p/QmbLHAnMoJPWSCR5Zhtx6BHJX9KiKNN6tpvbUcqanj75Nb>\n * // ]\n * ```\n *\n * @returns {Promise<Array<Multiaddr>>}\n */\n async resolve () {\n const resolvableProto = this.protos().find((p) => p.resolvable)\n\n // Multiaddr is not resolvable?\n if (!resolvableProto) {\n return [this]\n }\n\n const resolver = resolvers.get(resolvableProto.name)\n if (!resolver) {\n throw errCode(new Error(`no available resolver for ${resolvableProto.name}`), 'ERR_NO_AVAILABLE_RESOLVER')\n }\n\n const addresses = await resolver(this)\n return addresses.map((a) => new Multiaddr(a))\n }\n\n /**\n * Gets a Multiaddrs node-friendly address object. Note that protocol information\n * is left out: in Node (and most network systems) the protocol is unknowable\n * given only the address.\n *\n * Has to be a ThinWaist Address, otherwise throws error\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').nodeAddress()\n * // {family: 4, address: '127.0.0.1', port: 4001}\n * ```\n *\n * @returns {{family: 4 | 6, address: string, port: number}}\n * @throws {Error} Throws error if Multiaddr is not a Thin Waist address\n */\n nodeAddress () {\n const codes = this.protoCodes()\n const names = this.protoNames()\n const parts = this.toString().split('/').slice(1)\n\n if (parts.length < 4) {\n throw new Error('multiaddr must have a valid format: \"/{ip4, ip6, dns4, dns6}/{address}/{tcp, udp}/{port}\".')\n } else if (codes[0] !== 4 && codes[0] !== 41 && codes[0] !== 54 && codes[0] !== 55) {\n throw new Error(`no protocol with name: \"'${names[0]}'\". Must have a valid family name: \"{ip4, ip6, dns4, dns6}\".`)\n } else if (parts[2] !== 'tcp' && parts[2] !== 'udp') {\n throw new Error(`no protocol with name: \"'${names[1]}'\". Must have a valid transport protocol: \"{tcp, udp}\".`)\n }\n\n return {\n family: (codes[0] === 41 || codes[0] === 55) ? 6 : 4,\n address: parts[1],\n port: parseInt(parts[3]) // tcp or udp port\n }\n }\n\n /**\n * Returns if a Multiaddr is a Thin Waist address or not.\n *\n * Thin Waist is if a Multiaddr adheres to the standard combination of:\n *\n * `{IPv4, IPv6}/{TCP, UDP}`\n *\n * @example\n * ```js\n * const mh1 = new Multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // <Multiaddr 047f000001060fa1 - /ip4/127.0.0.1/tcp/4001>\n * const mh2 = new Multiaddr('/ip4/192.168.2.1/tcp/5001')\n * // <Multiaddr 04c0a80201061389 - /ip4/192.168.2.1/tcp/5001>\n * const mh3 = mh1.encapsulate(mh2)\n * // <Multiaddr 047f000001060fa104c0a80201061389 - /ip4/127.0.0.1/tcp/4001/ip4/192.168.2.1/tcp/5001>\n * const mh4 = new Multiaddr('/ip4/127.0.0.1/tcp/2000/wss/p2p-webrtc-star/p2p/QmcgpsyWgH8Y8ajJz1Cu72KnS5uo2Aa2LpzU7kinSooo2a')\n * // <Multiaddr 047f0000010607d0de039302a503221220d52ebb89d85b02a284948203a62ff28389c57c9f42beec4ec20db76a64835843 - /ip4/127.0.0.1/tcp/2000/wss/p2p-webrtc-star/p2p/QmcgpsyWgH8Y8ajJz1Cu72KnS5uo2Aa2LpzU7kinSooo2a>\n * mh1.isThinWaistAddress()\n * // true\n * mh2.isThinWaistAddress()\n * // true\n * mh3.isThinWaistAddress()\n * // false\n * mh4.isThinWaistAddress()\n * // false\n * ```\n *\n * @param {Multiaddr} [addr] - Defaults to using `this` instance\n */\n isThinWaistAddress (addr) {\n const protos = (addr || this).protos()\n\n if (protos.length !== 2) {\n return false\n }\n\n if (protos[0].code !== 4 && protos[0].code !== 41) {\n return false\n }\n if (protos[1].code !== 6 && protos[1].code !== 273) {\n return false\n }\n return true\n }\n\n /**\n * Creates a Multiaddr from a node-friendly address object\n *\n * @example\n * ```js\n * Multiaddr.fromNodeAddress({address: '127.0.0.1', port: '4001'}, 'tcp')\n * // <Multiaddr 047f000001060fa1 - /ip4/127.0.0.1/tcp/4001>\n * ```\n *\n * @param {{family: 4 | 6, address: string, port: number}} addr\n * @param {string} transport\n */\n static fromNodeAddress (addr, transport) {\n if (!addr) { throw new Error('requires node address object') }\n if (!transport) { throw new Error('requires transport protocol') }\n let ip\n switch (addr.family) {\n case 4:\n ip = 'ip4'\n break\n case 6:\n ip = 'ip6'\n break\n default:\n throw Error(`Invalid addr family. Got '${addr.family}' instead of 4 or 6`)\n }\n return new Multiaddr('/' + [ip, addr.address, transport, addr.port].join('/'))\n }\n\n /**\n * Returns if something is a Multiaddr that is a name\n *\n * @param {Multiaddr} addr\n * @returns {boolean} isName\n */\n static isName (addr) {\n if (!Multiaddr.isMultiaddr(addr)) {\n return false\n }\n\n // if a part of the multiaddr is resolvable, then return true\n return addr.protos().some((proto) => proto.resolvable)\n }\n\n /**\n * Check if object is a CID instance\n *\n * @param {any} value\n * @returns {value is Multiaddr}\n */\n static isMultiaddr (value) {\n return value instanceof Multiaddr || Boolean(value && value[symbol])\n }\n\n /**\n * Returns Multiaddr as a human-readable string.\n * For post Node.js v10.0.0.\n * https://nodejs.org/api/deprecations.html#deprecations_dep0079_custom_inspection_function_on_objects_via_inspect\n *\n * @example\n * ```js\n * console.log(new Multiaddr('/ip4/127.0.0.1/tcp/4001'))\n * // '<Multiaddr 047f000001060fa1 - /ip4/127.0.0.1/tcp/4001>'\n * ```\n *\n * @returns {string}\n */\n [inspect] () {\n return '<Multiaddr ' +\n uint8ArrayToString(this.bytes, 'base16') + ' - ' +\n codec.bytesToString(this.bytes) + '>'\n }\n\n /**\n * Returns Multiaddr as a human-readable string.\n * Fallback for pre Node.js v10.0.0.\n * https://nodejs.org/api/deprecations.html#deprecations_dep0079_custom_inspection_function_on_objects_via_inspect\n *\n * @example\n * ```js\n * new Multiaddr('/ip4/127.0.0.1/tcp/4001').inspect()\n * // '<Multiaddr 047f000001060fa1 - /ip4/127.0.0.1/tcp/4001>'\n * ```\n *\n * @returns {string}\n */\n inspect () {\n return '<Multiaddr ' +\n uint8ArrayToString(this.bytes, 'base16') + ' - ' +\n codec.bytesToString(this.bytes) + '>'\n }\n}\n\n/**\n * Object containing table, names and codes of all supported protocols.\n * To get the protocol values from a Multiaddr, you can use\n * [`.protos()`](#multiaddrprotos),\n * [`.protoCodes()`](#multiaddrprotocodes) or\n * [`.protoNames()`](#multiaddrprotonames)\n *\n * @returns {{table: Array, names: Object, codes: Object}}\n */\nMultiaddr.protocols = protocols\n\nMultiaddr.resolvers = resolvers\n\n/**\n * Static factory\n *\n * @param {MultiaddrInput} addr\n */\nfunction multiaddr (addr) {\n return new Multiaddr(addr)\n}\n\nmodule.exports = { Multiaddr, multiaddr, protocols, resolvers }\n","'use strict'\n\nconst convert = require('./convert')\nconst protocols = require('./protocols-table')\nconst varint = require('varint')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\n// export codec\nmodule.exports = {\n stringToStringTuples,\n stringTuplesToString,\n\n tuplesToStringTuples,\n stringTuplesToTuples,\n\n bytesToTuples,\n tuplesToBytes,\n\n bytesToString,\n stringToBytes,\n\n fromString,\n fromBytes,\n validateBytes,\n isValidBytes,\n cleanPath,\n\n ParseError,\n protoFromTuple,\n\n sizeForAddr\n}\n\n// string -> [[str name, str addr]... ]\n/**\n * @param {string} str\n */\nfunction stringToStringTuples (str) {\n const tuples = []\n const parts = str.split('/').slice(1) // skip first empty elem\n if (parts.length === 1 && parts[0] === '') {\n return []\n }\n\n for (let p = 0; p < parts.length; p++) {\n const part = parts[p]\n const proto = protocols(part)\n\n if (proto.size === 0) {\n tuples.push([part])\n continue\n }\n\n p++ // advance addr part\n if (p >= parts.length) {\n throw ParseError('invalid address: ' + str)\n }\n\n // if it's a path proto, take the rest\n if (proto.path) {\n tuples.push([\n part,\n // TODO: should we need to check each path part to see if it's a proto?\n // This would allow for other protocols to be added after a unix path,\n // however it would have issues if the path had a protocol name in the path\n cleanPath(parts.slice(p).join('/'))\n ])\n break\n }\n\n tuples.push([part, parts[p]])\n }\n\n return tuples\n}\n\n// [[str name, str addr]... ] -> string\n/**\n * @param {[number, string?][]} tuples\n */\nfunction stringTuplesToString (tuples) {\n /** @type {Array<string | undefined>} */\n const parts = []\n tuples.map((tup) => {\n const proto = protoFromTuple(tup)\n parts.push(proto.name)\n if (tup.length > 1) {\n parts.push(tup[1])\n }\n return null\n })\n\n return cleanPath(parts.join('/'))\n}\n\n// [[str name, str addr]... ] -> [[int code, Uint8Array]... ]\n/**\n * @param {Array<string[] | string >} tuples\n * @returns {[number , Uint8Array?][]}\n */\nfunction stringTuplesToTuples (tuples) {\n return tuples.map((tup) => {\n if (!Array.isArray(tup)) {\n tup = [tup]\n }\n const proto = protoFromTuple(tup)\n if (tup.length > 1) {\n return [proto.code, convert.toBytes(proto.code, tup[1])]\n }\n return [proto.code]\n })\n}\n\n/**\n * Convert tuples to string tuples\n *\n * [[int code, Uint8Array]... ] -> [[int code, str addr]... ]\n *\n * @param {Array<[number, Uint8Array?]>} tuples\n * @returns {Array<[number, string?]>}\n */\n\nfunction tuplesToStringTuples (tuples) {\n return tuples.map(tup => {\n const proto = protoFromTuple(tup)\n if (tup[1]) {\n return [proto.code, convert.toString(proto.code, tup[1])]\n }\n return [proto.code]\n })\n}\n\n// [[int code, Uint8Array ]... ] -> Uint8Array\n/**\n * @param {[number, Uint8Array?][]} tuples\n */\nfunction tuplesToBytes (tuples) {\n return fromBytes(uint8ArrayConcat(tuples.map((/** @type {any[]} */ tup) => {\n const proto = protoFromTuple(tup)\n let buf = Uint8Array.from(varint.encode(proto.code))\n\n if (tup.length > 1) {\n buf = uint8ArrayConcat([buf, tup[1]]) // add address buffer\n }\n\n return buf\n })))\n}\n\n/**\n * @param {import(\"./types\").Protocol} p\n * @param {Uint8Array | number[]} addr\n */\nfunction sizeForAddr (p, addr) {\n if (p.size > 0) {\n return p.size / 8\n } else if (p.size === 0) {\n return 0\n } else {\n const size = varint.decode(addr)\n return size + varint.decode.bytes\n }\n}\n\n/**\n *\n * @param {Uint8Array} buf\n * @returns {Array<[number, Uint8Array?]>}\n */\nfunction bytesToTuples (buf) {\n /** @type {Array<[number, Uint8Array?]>} */\n const tuples = []\n let i = 0\n while (i < buf.length) {\n const code = varint.decode(buf, i)\n const n = varint.decode.bytes\n\n const p = protocols(code)\n\n const size = sizeForAddr(p, buf.slice(i + n))\n\n if (size === 0) {\n tuples.push([code])\n i += n\n continue\n }\n\n const addr = buf.slice(i + n, i + n + size)\n\n i += (size + n)\n\n if (i > buf.length) { // did not end _exactly_ at buffer.length\n throw ParseError('Invalid address Uint8Array: ' + uint8ArrayToString(buf, 'base16'))\n }\n\n // ok, tuple seems good.\n tuples.push([code, addr])\n }\n\n return tuples\n}\n\n// Uint8Array -> String\n/**\n * @param {Uint8Array} buf\n */\nfunction bytesToString (buf) {\n const a = bytesToTuples(buf)\n const b = tuplesToStringTuples(a)\n return stringTuplesToString(b)\n}\n\n// String -> Uint8Array\n/**\n * @param {string} str\n */\nfunction stringToBytes (str) {\n str = cleanPath(str)\n const a = stringToStringTuples(str)\n const b = stringTuplesToTuples(a)\n\n return tuplesToBytes(b)\n}\n\n// String -> Uint8Array\n/**\n * @param {string} str\n */\nfunction fromString (str) {\n return stringToBytes(str)\n}\n\n// Uint8Array -> Uint8Array\n/**\n * @param {Uint8Array} buf\n */\nfunction fromBytes (buf) {\n const err = validateBytes(buf)\n if (err) throw err\n return Uint8Array.from(buf) // copy\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction validateBytes (buf) {\n try {\n bytesToTuples(buf) // try to parse. will throw if breaks\n } catch (err) {\n return err\n }\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction isValidBytes (buf) {\n return validateBytes(buf) === undefined\n}\n\n/**\n * @param {string} str\n */\nfunction cleanPath (str) {\n return '/' + str.trim().split('/').filter((/** @type {any} */ a) => a).join('/')\n}\n\n/**\n * @param {string} str\n */\nfunction ParseError (str) {\n return new Error('Error parsing address: ' + str)\n}\n\n/**\n * @param {any[]} tup\n */\nfunction protoFromTuple (tup) {\n const proto = protocols(tup[0])\n return proto\n}\n","'use strict'\n\nconst ip = require('./ip')\nconst protocols = require('./protocols-table')\nconst { CID } = require('multiformats/cid')\nconst { base32 } = require('multiformats/bases/base32')\nconst { base58btc } = require('multiformats/bases/base58')\nconst Digest = require('multiformats/hashes/digest')\nconst varint = require('varint')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\n\nmodule.exports = Convert\n\n// converts (serializes) addresses\n/**\n * @param {string} proto\n * @param {string | Uint8Array} a\n */\nfunction Convert (proto, a) {\n if (a instanceof Uint8Array) {\n return Convert.toString(proto, a)\n } else {\n return Convert.toBytes(proto, a)\n }\n}\n\n/**\n * Convert [code,Uint8Array] to string\n *\n * @param {number|string} proto\n * @param {Uint8Array} buf\n * @returns {string}\n */\nConvert.toString = function convertToString (proto, buf) {\n const protocol = protocols(proto)\n switch (protocol.code) {\n case 4: // ipv4\n case 41: // ipv6\n return bytes2ip(buf)\n\n case 6: // tcp\n case 273: // udp\n case 33: // dccp\n case 132: // sctp\n return bytes2port(buf).toString()\n\n case 53: // dns\n case 54: // dns4\n case 55: // dns6\n case 56: // dnsaddr\n case 400: // unix\n case 777: // memory\n return bytes2str(buf)\n\n case 421: // ipfs\n return bytes2mh(buf)\n case 444: // onion\n return bytes2onion(buf)\n case 445: // onion3\n return bytes2onion(buf)\n default:\n return uint8ArrayToString(buf, 'base16') // no clue. convert to hex\n }\n}\n\nConvert.toBytes = function convertToBytes (/** @type {string | number } */ proto, /** @type {string} */ str) {\n const protocol = protocols(proto)\n switch (protocol.code) {\n case 4: // ipv4\n return ip2bytes(str)\n case 41: // ipv6\n return ip2bytes(str)\n\n case 6: // tcp\n case 273: // udp\n case 33: // dccp\n case 132: // sctp\n return port2bytes(parseInt(str, 10))\n\n case 53: // dns\n case 54: // dns4\n case 55: // dns6\n case 56: // dnsaddr\n case 400: // unix\n case 777: // memory\n return str2bytes(str)\n\n case 421: // ipfs\n return mh2bytes(str)\n case 444: // onion\n return onion2bytes(str)\n case 445: // onion3\n return onion32bytes(str)\n default:\n return uint8ArrayFromString(str, 'base16') // no clue. convert from hex\n }\n}\n\n/**\n * @param {string} ipString\n */\nfunction ip2bytes (ipString) {\n if (!ip.isIP(ipString)) {\n throw new Error('invalid ip address')\n }\n return ip.toBytes(ipString)\n}\n\n/**\n * @param {Uint8Array} ipBuff\n */\nfunction bytes2ip (ipBuff) {\n const ipString = ip.toString(ipBuff)\n if (!ipString || !ip.isIP(ipString)) {\n throw new Error('invalid ip address')\n }\n return ipString\n}\n\n/**\n * @param {number} port\n */\nfunction port2bytes (port) {\n const buf = new ArrayBuffer(2)\n const view = new DataView(buf)\n view.setUint16(0, port)\n\n return new Uint8Array(buf)\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction bytes2port (buf) {\n const view = new DataView(buf.buffer)\n return view.getUint16(buf.byteOffset)\n}\n\n/**\n * @param {string} str\n */\nfunction str2bytes (str) {\n const buf = uint8ArrayFromString(str)\n const size = Uint8Array.from(varint.encode(buf.length))\n return uint8ArrayConcat([size, buf], size.length + buf.length)\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction bytes2str (buf) {\n const size = varint.decode(buf)\n buf = buf.slice(varint.decode.bytes)\n\n if (buf.length !== size) {\n throw new Error('inconsistent lengths')\n }\n\n return uint8ArrayToString(buf)\n}\n\n/**\n * @param {string} hash - base58btc string\n */\nfunction mh2bytes (hash) {\n let mh\n\n if (hash[0] === 'Q' || hash[0] === '1') {\n mh = Digest.decode(base58btc.decode(`z${hash}`)).bytes\n } else {\n mh = CID.parse(hash).multihash.bytes\n }\n\n // the address is a varint prefixed multihash string representation\n const size = Uint8Array.from(varint.encode(mh.length))\n return uint8ArrayConcat([size, mh], size.length + mh.length)\n}\n\n/**\n * Converts bytes to bas58btc string\n *\n * @param {Uint8Array} buf\n * @returns {string} base58btc string\n */\nfunction bytes2mh (buf) {\n const size = varint.decode(buf)\n const address = buf.slice(varint.decode.bytes)\n\n if (address.length !== size) {\n throw new Error('inconsistent lengths')\n }\n\n return uint8ArrayToString(address, 'base58btc')\n}\n\n/**\n * @param {string} str\n */\nfunction onion2bytes (str) {\n const addr = str.split(':')\n if (addr.length !== 2) {\n throw new Error('failed to parse onion addr: ' + addr + ' does not contain a port number')\n }\n if (addr[0].length !== 16) {\n throw new Error('failed to parse onion addr: ' + addr[0] + ' not a Tor onion address.')\n }\n\n // onion addresses do not include the multibase prefix, add it before decoding\n const buf = base32.decode('b' + addr[0])\n\n // onion port number\n const port = parseInt(addr[1], 10)\n if (port < 1 || port > 65536) {\n throw new Error('Port number is not in range(1, 65536)')\n }\n const portBuf = port2bytes(port)\n return uint8ArrayConcat([buf, portBuf], buf.length + portBuf.length)\n}\n\n/**\n * @param {string} str\n */\nfunction onion32bytes (str) {\n const addr = str.split(':')\n if (addr.length !== 2) {\n throw new Error('failed to parse onion addr: ' + addr + ' does not contain a port number')\n }\n if (addr[0].length !== 56) {\n throw new Error('failed to parse onion addr: ' + addr[0] + ' not a Tor onion3 address.')\n }\n // onion addresses do not include the multibase prefix, add it before decoding\n const buf = base32.decode('b' + addr[0])\n\n // onion port number\n const port = parseInt(addr[1], 10)\n if (port < 1 || port > 65536) {\n throw new Error('Port number is not in range(1, 65536)')\n }\n const portBuf = port2bytes(port)\n return uint8ArrayConcat([buf, portBuf], buf.length + portBuf.length)\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction bytes2onion (buf) {\n const addrBytes = buf.slice(0, buf.length - 2)\n const portBytes = buf.slice(buf.length - 2)\n const addr = uint8ArrayToString(addrBytes, 'base32')\n const port = bytes2port(portBytes)\n return addr + ':' + port\n}\n","'use strict'\n\nconst isIp = require('is-ip')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst isIP = isIp\nconst isV4 = isIp.v4\nconst isV6 = isIp.v6\n\n// Copied from https://github.com/indutny/node-ip/blob/master/lib/ip.js#L7\n// @ts-ignore - this is copied from the link above better to keep it the same\nconst toBytes = function (ip, buff, offset) {\n offset = ~~offset\n\n let result\n\n if (isV4(ip)) {\n result = buff || new Uint8Array(offset + 4)\n // @ts-ignore\n // eslint-disable-next-line array-callback-return\n ip.split(/\\./g).map(function (byte) {\n result[offset++] = parseInt(byte, 10) & 0xff\n })\n } else if (isV6(ip)) {\n const sections = ip.split(':', 8)\n\n let i\n for (i = 0; i < sections.length; i++) {\n const isv4 = isV4(sections[i])\n let v4Buffer\n\n if (isv4) {\n v4Buffer = toBytes(sections[i])\n sections[i] = uint8ArrayToString(v4Buffer.slice(0, 2), 'base16')\n }\n\n if (v4Buffer && ++i < 8) {\n sections.splice(i, 0, uint8ArrayToString(v4Buffer.slice(2, 4), 'base16'))\n }\n }\n\n if (sections[0] === '') {\n while (sections.length < 8) sections.unshift('0')\n } else if (sections[sections.length - 1] === '') {\n while (sections.length < 8) sections.push('0')\n } else if (sections.length < 8) {\n for (i = 0; i < sections.length && sections[i] !== ''; i++);\n const argv = [i, '1']\n for (i = 9 - sections.length; i > 0; i--) {\n argv.push('0')\n }\n sections.splice.apply(sections, argv)\n }\n\n result = buff || new Uint8Array(offset + 16)\n for (i = 0; i < sections.length; i++) {\n const word = parseInt(sections[i], 16)\n result[offset++] = (word >> 8) & 0xff\n result[offset++] = word & 0xff\n }\n }\n\n if (!result) {\n throw Error('Invalid ip address: ' + ip)\n }\n\n return result\n}\n\n// Copied from https://github.com/indutny/node-ip/blob/master/lib/ip.js#L63\n// @ts-ignore - this is copied from the link above better to keep it the same\nconst toString = function (buff, offset, length) {\n offset = ~~offset\n length = length || (buff.length - offset)\n\n const result = []\n let string\n const view = new DataView(buff.buffer)\n if (length === 4) {\n // IPv4\n for (let i = 0; i < length; i++) {\n result.push(buff[offset + i])\n }\n string = result.join('.')\n } else if (length === 16) {\n // IPv6\n for (let i = 0; i < length; i += 2) {\n result.push(view.getUint16(offset + i).toString(16))\n }\n string = result.join(':')\n string = string.replace(/(^|:)0(:0)*:0(:|$)/, '$1::$3')\n string = string.replace(/:{3,4}/, '::')\n }\n\n return string\n}\n\nmodule.exports = {\n isIP,\n isV4,\n isV6,\n toBytes,\n toString\n}\n","'use strict';\nconst ipRegex = require('ip-regex');\n\nconst isIp = string => ipRegex({exact: true}).test(string);\nisIp.v4 = string => ipRegex.v4({exact: true}).test(string);\nisIp.v6 = string => ipRegex.v6({exact: true}).test(string);\nisIp.version = string => isIp(string) ? (isIp.v4(string) ? 4 : 6) : undefined;\n\nmodule.exports = isIp;\n","'use strict';\n\nconst word = '[a-fA-F\\\\d:]';\nconst b = options => options && options.includeBoundaries ?\n\t`(?:(?<=\\\\s|^)(?=${word})|(?<=${word})(?=\\\\s|$))` :\n\t'';\n\nconst v4 = '(?:25[0-5]|2[0-4]\\\\d|1\\\\d\\\\d|[1-9]\\\\d|\\\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\\\d|1\\\\d\\\\d|[1-9]\\\\d|\\\\d)){3}';\n\nconst v6seg = '[a-fA-F\\\\d]{1,4}';\nconst v6 = `\n(?:\n(?:${v6seg}:){7}(?:${v6seg}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8\n(?:${v6seg}:){6}(?:${v4}|:${v6seg}|:)| // 1:2:3:4:5:6:: 1:2:3:4:5:6::8 1:2:3:4:5:6::8 1:2:3:4:5:6::1.2.3.4\n(?:${v6seg}:){5}(?::${v4}|(?::${v6seg}){1,2}|:)| // 1:2:3:4:5:: 1:2:3:4:5::7:8 1:2:3:4:5::8 1:2:3:4:5::7:1.2.3.4\n(?:${v6seg}:){4}(?:(?::${v6seg}){0,1}:${v4}|(?::${v6seg}){1,3}|:)| // 1:2:3:4:: 1:2:3:4::6:7:8 1:2:3:4::8 1:2:3:4::6:7:1.2.3.4\n(?:${v6seg}:){3}(?:(?::${v6seg}){0,2}:${v4}|(?::${v6seg}){1,4}|:)| // 1:2:3:: 1:2:3::5:6:7:8 1:2:3::8 1:2:3::5:6:7:1.2.3.4\n(?:${v6seg}:){2}(?:(?::${v6seg}){0,3}:${v4}|(?::${v6seg}){1,5}|:)| // 1:2:: 1:2::4:5:6:7:8 1:2::8 1:2::4:5:6:7:1.2.3.4\n(?:${v6seg}:){1}(?:(?::${v6seg}){0,4}:${v4}|(?::${v6seg}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4\n(?::(?:(?::${v6seg}){0,5}:${v4}|(?::${v6seg}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4\n)(?:%[0-9a-zA-Z]{1,})? // %eth0 %1\n`.replace(/\\s*\\/\\/.*$/gm, '').replace(/\\n/g, '').trim();\n\n// Pre-compile only the exact regexes because adding a global flag make regexes stateful\nconst v46Exact = new RegExp(`(?:^${v4}$)|(?:^${v6}$)`);\nconst v4exact = new RegExp(`^${v4}$`);\nconst v6exact = new RegExp(`^${v6}$`);\n\nconst ip = options => options && options.exact ?\n\tv46Exact :\n\tnew RegExp(`(?:${b(options)}${v4}${b(options)})|(?:${b(options)}${v6}${b(options)})`, 'g');\n\nip.v4 = options => options && options.exact ? v4exact : new RegExp(`${b(options)}${v4}${b(options)}`, 'g');\nip.v6 = options => options && options.exact ? v6exact : new RegExp(`${b(options)}${v6}${b(options)}`, 'g');\n\nmodule.exports = ip;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bases = require('./util/bases.js');\n\nfunction toString(array, encoding = 'utf8') {\n const base = bases[encoding];\n if (!base) {\n throw new Error(`Unsupported encoding \"${ encoding }\"`);\n }\n return base.encoder.encode(array).substring(1);\n}\n\nexports.toString = toString;\n","'use strict'\n/** @typedef {import(\"./types\").Protocol} Protocol */\n\n/**\n * Protocols\n *\n * @param {number | string} proto\n * @returns {Protocol}\n */\nfunction Protocols (proto) {\n if (typeof (proto) === 'number') {\n if (Protocols.codes[proto]) {\n return Protocols.codes[proto]\n }\n\n throw new Error('no protocol with code: ' + proto)\n } else if (typeof (proto) === 'string') {\n if (Protocols.names[proto]) {\n return Protocols.names[proto]\n }\n\n throw new Error('no protocol with name: ' + proto)\n }\n\n throw new Error('invalid protocol id type: ' + proto)\n}\n\nconst V = -1\nProtocols.lengthPrefixedVarSize = V\nProtocols.V = V\n\n/** @type {Array<[number, number, string, (string|boolean)?, string?]>} */\nProtocols.table = [\n [4, 32, 'ip4'],\n [6, 16, 'tcp'],\n [33, 16, 'dccp'],\n [41, 128, 'ip6'],\n [42, V, 'ip6zone'],\n [53, V, 'dns', 'resolvable'],\n [54, V, 'dns4', 'resolvable'],\n [55, V, 'dns6', 'resolvable'],\n [56, V, 'dnsaddr', 'resolvable'],\n [132, 16, 'sctp'],\n [273, 16, 'udp'],\n [275, 0, 'p2p-webrtc-star'],\n [276, 0, 'p2p-webrtc-direct'],\n [277, 0, 'p2p-stardust'],\n [290, 0, 'p2p-circuit'],\n [301, 0, 'udt'],\n [302, 0, 'utp'],\n [400, V, 'unix', false, 'path'],\n // `ipfs` is added before `p2p` for legacy support.\n // All text representations will default to `p2p`, but `ipfs` will\n // still be supported\n [421, V, 'ipfs'],\n // `p2p` is the preferred name for 421, and is now the default\n [421, V, 'p2p'],\n [443, 0, 'https'],\n [444, 96, 'onion'],\n [445, 296, 'onion3'],\n [446, V, 'garlic64'],\n [460, 0, 'quic'],\n [477, 0, 'ws'],\n [478, 0, 'wss'],\n [479, 0, 'p2p-websocket-star'],\n [480, 0, 'http'],\n [777, V, 'memory']\n]\n/** @type {Record<string,Protocol>} */\nProtocols.names = {}\n/** @type {Record<number,Protocol>} */\nProtocols.codes = {}\n\n// populate tables\nProtocols.table.map(row => {\n const proto = p.apply(null, row)\n Protocols.codes[proto.code] = proto\n Protocols.names[proto.name] = proto\n return null\n})\n\nProtocols.object = p\n\n/**\n *\n * Create a protocol\n *\n * @param {number} code\n * @param {number} size\n * @param {string} name\n * @param {any} [resolvable]\n * @param {any} [path]\n * @returns {Protocol}\n */\nfunction p (code, size, name, resolvable, path) {\n return {\n code,\n size,\n name,\n resolvable: Boolean(resolvable),\n path: Boolean(path)\n }\n}\n\nmodule.exports = Protocols\n","module.exports = {\n encode: require('./encode.js')\n , decode: require('./decode.js')\n , encodingLength: require('./length.js')\n}\n","module.exports = encode\n\nvar MSB = 0x80\n , REST = 0x7F\n , MSBALL = ~REST\n , INT = Math.pow(2, 31)\n\nfunction encode(num, out, offset) {\n if (Number.MAX_SAFE_INTEGER && num > Number.MAX_SAFE_INTEGER) {\n encode.bytes = 0\n throw new RangeError('Could not encode varint')\n }\n out = out || []\n offset = offset || 0\n var oldOffset = offset\n\n while(num >= INT) {\n out[offset++] = (num & 0xFF) | MSB\n num /= 128\n }\n while(num & MSBALL) {\n out[offset++] = (num & 0xFF) | MSB\n num >>>= 7\n }\n out[offset] = num | 0\n \n encode.bytes = offset - oldOffset + 1\n \n return out\n}\n","module.exports = read\n\nvar MSB = 0x80\n , REST = 0x7F\n\nfunction read(buf, offset) {\n var res = 0\n , offset = offset || 0\n , shift = 0\n , counter = offset\n , b\n , l = buf.length\n\n do {\n if (counter >= l || shift > 49) {\n read.bytes = 0\n throw new RangeError('Could not decode varint')\n }\n b = buf[counter++]\n res += shift < 28\n ? (b & REST) << shift\n : (b & REST) * Math.pow(2, shift)\n shift += 7\n } while (b >= MSB)\n\n read.bytes = counter - offset\n\n return res\n}\n","\nvar N1 = Math.pow(2, 7)\nvar N2 = Math.pow(2, 14)\nvar N3 = Math.pow(2, 21)\nvar N4 = Math.pow(2, 28)\nvar N5 = Math.pow(2, 35)\nvar N6 = Math.pow(2, 42)\nvar N7 = Math.pow(2, 49)\nvar N8 = Math.pow(2, 56)\nvar N9 = Math.pow(2, 63)\n\nmodule.exports = function (value) {\n return (\n value < N1 ? 1\n : value < N2 ? 2\n : value < N3 ? 3\n : value < N4 ? 4\n : value < N5 ? 5\n : value < N6 ? 6\n : value < N7 ? 7\n : value < N8 ? 8\n : value < N9 ? 9\n : 10\n )\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction concat(arrays, length) {\n if (!length) {\n length = arrays.reduce((acc, curr) => acc + curr.length, 0);\n }\n const output = new Uint8Array(length);\n let offset = 0;\n for (const arr of arrays) {\n output.set(arr, offset);\n offset += arr.length;\n }\n return output;\n}\n\nexports.concat = concat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction equals(a, b) {\n if (a === b) {\n return true;\n }\n if (a.byteLength !== b.byteLength) {\n return false;\n }\n for (let i = 0; i < a.byteLength; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n return true;\n}\n\nexports.equals = equals;\n","'use strict'\n\nconst { Multiaddr } = require('multiaddr')\n\n/**\n * @typedef {import('./types').MatchesFunction} MatchesFunction\n * @typedef {import('./types').PartialMatchesFunction} PartialMatchesFunction\n * @typedef {import('./types').Mafmt} Mafmt\n */\n\n/*\n * Valid combinations\n */\nconst DNS4 = base('dns4')\nconst DNS6 = base('dns6')\nconst DNSADDR = base('dnsaddr')\nconst DNS = or(\n base('dns'),\n DNSADDR,\n DNS4,\n DNS6\n)\n\nconst IP = or(base('ip4'), base('ip6'))\nconst TCP = or(\n and(IP, base('tcp')),\n and(DNS, base('tcp'))\n)\nconst UDP = and(IP, base('udp'))\nconst UTP = and(UDP, base('utp'))\n\nconst QUIC = and(UDP, base('quic'))\n\nconst WebSockets = or(\n and(TCP, base('ws')),\n and(DNS, base('ws'))\n)\n\nconst WebSocketsSecure = or(\n and(TCP, base('wss')),\n and(DNS, base('wss'))\n)\n\nconst HTTP = or(\n and(TCP, base('http')),\n and(IP, base('http')),\n and(DNS, base('http'))\n)\n\nconst HTTPS = or(\n and(TCP, base('https')),\n and(IP, base('https')),\n and(DNS, base('https'))\n)\n\nconst WebRTCStar = or(\n and(WebSockets, base('p2p-webrtc-star'), base('p2p')),\n and(WebSocketsSecure, base('p2p-webrtc-star'), base('p2p')),\n and(WebSockets, base('p2p-webrtc-star')),\n and(WebSocketsSecure, base('p2p-webrtc-star'))\n)\n\nconst WebSocketStar = or(\n and(WebSockets, base('p2p-websocket-star'), base('p2p')),\n and(WebSocketsSecure, base('p2p-websocket-star'), base('p2p')),\n and(WebSockets, base('p2p-websocket-star')),\n and(WebSocketsSecure, base('p2p-websocket-star'))\n)\n\nconst WebRTCDirect = or(\n and(HTTP, base('p2p-webrtc-direct'), base('p2p')),\n and(HTTPS, base('p2p-webrtc-direct'), base('p2p')),\n and(HTTP, base('p2p-webrtc-direct')),\n and(HTTPS, base('p2p-webrtc-direct'))\n)\n\nconst Reliable = or(\n WebSockets,\n WebSocketsSecure,\n HTTP,\n HTTPS,\n WebRTCStar,\n WebRTCDirect,\n TCP,\n UTP,\n QUIC,\n DNS\n)\n\n// Unlike ws-star, stardust can run over any transport thus removing the requirement for websockets (but don't even think about running a stardust server over webrtc-star ;) )\nconst Stardust = or(\n and(Reliable, base('p2p-stardust'), base('p2p')),\n and(Reliable, base('p2p-stardust'))\n)\n\nconst _P2P = or(\n and(Reliable, base('p2p')),\n WebRTCStar,\n WebRTCDirect,\n base('p2p')\n)\n\nconst _Circuit = or(\n and(_P2P, base('p2p-circuit'), _P2P),\n and(_P2P, base('p2p-circuit')),\n and(base('p2p-circuit'), _P2P),\n and(Reliable, base('p2p-circuit')),\n and(base('p2p-circuit'), Reliable),\n base('p2p-circuit')\n)\n\nconst CircuitRecursive = () => or(\n and(_Circuit, CircuitRecursive),\n _Circuit\n)\n\nconst Circuit = CircuitRecursive()\n\nconst P2P = or(\n and(Circuit, _P2P, Circuit),\n and(_P2P, Circuit),\n and(Circuit, _P2P),\n Circuit,\n _P2P\n)\n\nmodule.exports = {\n DNS,\n DNS4,\n DNS6,\n DNSADDR,\n IP,\n TCP,\n UDP,\n QUIC,\n UTP,\n HTTP,\n HTTPS,\n WebSockets,\n WebSocketsSecure,\n WebSocketStar,\n WebRTCStar,\n WebRTCDirect,\n Reliable,\n Stardust,\n Circuit,\n P2P,\n IPFS: P2P\n}\n\n/*\n * Validation funcs\n */\n\n/**\n * @param {PartialMatchesFunction} partialMatch\n */\nfunction makeMatchesFunction (partialMatch) {\n /**\n * @type {MatchesFunction}\n */\n function matches (a) {\n if (!Multiaddr.isMultiaddr(a)) {\n try {\n a = new Multiaddr(a)\n } catch (err) { // catch error\n return false // also if it's invalid it's propably not matching as well so return false\n }\n }\n const out = partialMatch(a.protoNames())\n if (out === null) {\n return false\n }\n\n if (out === true || out === false) {\n return out\n }\n\n return out.length === 0\n }\n\n return matches\n}\n\n/**\n * @param {Array<Mafmt | (() => Mafmt)>} args\n * @returns {Mafmt}\n */\nfunction and (...args) {\n /**\n * @type {PartialMatchesFunction}\n */\n function partialMatch (a) {\n if (a.length < args.length) {\n return null\n }\n\n /** @type {boolean | string[] | null} */\n let out = a\n\n args.some((arg) => {\n out = typeof arg === 'function'\n ? arg().partialMatch(a)\n : arg.partialMatch(a)\n\n if (Array.isArray(out)) {\n a = out\n }\n\n if (out === null) {\n return true\n }\n\n return false\n })\n\n return out\n }\n\n return {\n toString: function () { return '{ ' + args.join(' ') + ' }' },\n input: args,\n matches: makeMatchesFunction(partialMatch),\n partialMatch: partialMatch\n }\n}\n\n/**\n * @param {Array<Mafmt | (() => Mafmt)>} args\n * @returns {Mafmt}\n */\nfunction or (...args) {\n /**\n * @type {PartialMatchesFunction}\n */\n function partialMatch (a) {\n let out = null\n args.some((arg) => {\n const res = typeof arg === 'function'\n ? arg().partialMatch(a)\n : arg.partialMatch(a)\n if (res) {\n out = res\n return true\n }\n return false\n })\n\n return out\n }\n\n const result = {\n toString: function () { return '{ ' + args.join(' ') + ' }' },\n input: args,\n matches: makeMatchesFunction(partialMatch),\n partialMatch: partialMatch\n }\n\n return result\n}\n\n/**\n * @param {string} n\n * @returns {Mafmt}\n */\nfunction base (n) {\n const name = n\n\n /**\n * @type {MatchesFunction}\n */\n function matches (a) {\n let ma\n\n if (typeof a === 'string' || a instanceof Uint8Array) {\n try {\n ma = new Multiaddr(a)\n } catch (err) { // catch error\n return false // also if it's invalid it's probably not matching as well so return false\n }\n } else {\n ma = a\n }\n\n const pnames = ma.protoNames()\n if (pnames.length === 1 && pnames[0] === name) {\n return true\n }\n return false\n }\n\n /**\n * @type {PartialMatchesFunction}\n */\n function partialMatch (protos) {\n if (protos.length === 0) {\n return null\n }\n\n if (protos[0] === name) {\n return protos.slice(1)\n }\n return null\n }\n\n return {\n toString: function () { return name },\n matches: matches,\n partialMatch: partialMatch\n }\n}\n","'use strict'\n\nconst {\n URLWithLegacySupport,\n format,\n URLSearchParams,\n defaultBase\n} = require('./src/url')\nconst relative = require('./src/relative')\n\nmodule.exports = {\n URL: URLWithLegacySupport,\n URLSearchParams,\n format,\n relative,\n defaultBase\n}\n","'use strict'\n\nconst isReactNative =\n typeof navigator !== 'undefined' &&\n navigator.product === 'ReactNative'\n\nfunction getDefaultBase () {\n if (isReactNative) {\n return 'http://localhost'\n }\n // in some environments i.e. cloudflare workers location is not available\n if (!self.location) {\n return ''\n }\n\n return self.location.protocol + '//' + self.location.host\n}\n\nconst URL = self.URL\nconst defaultBase = getDefaultBase()\n\nclass URLWithLegacySupport {\n constructor (url = '', base = defaultBase) {\n this.super = new URL(url, base)\n this.path = this.pathname + this.search\n this.auth =\n this.username && this.password\n ? this.username + ':' + this.password\n : null\n\n this.query =\n this.search && this.search.startsWith('?')\n ? this.search.slice(1)\n : null\n }\n\n get hash () {\n return this.super.hash\n }\n\n get host () {\n return this.super.host\n }\n\n get hostname () {\n return this.super.hostname\n }\n\n get href () {\n return this.super.href\n }\n\n get origin () {\n return this.super.origin\n }\n\n get password () {\n return this.super.password\n }\n\n get pathname () {\n return this.super.pathname\n }\n\n get port () {\n return this.super.port\n }\n\n get protocol () {\n return this.super.protocol\n }\n\n get search () {\n return this.super.search\n }\n\n get searchParams () {\n return this.super.searchParams\n }\n\n get username () {\n return this.super.username\n }\n\n set hash (hash) {\n this.super.hash = hash\n }\n\n set host (host) {\n this.super.host = host\n }\n\n set hostname (hostname) {\n this.super.hostname = hostname\n }\n\n set href (href) {\n this.super.href = href\n }\n\n set password (password) {\n this.super.password = password\n }\n\n set pathname (pathname) {\n this.super.pathname = pathname\n }\n\n set port (port) {\n this.super.port = port\n }\n\n set protocol (protocol) {\n this.super.protocol = protocol\n }\n\n set search (search) {\n this.super.search = search\n }\n\n set username (username) {\n this.super.username = username\n }\n\n /**\n * @param {any} o\n */\n static createObjectURL (o) {\n return URL.createObjectURL(o)\n }\n\n /**\n * @param {string} o\n */\n static revokeObjectURL (o) {\n URL.revokeObjectURL(o)\n }\n\n toJSON () {\n return this.super.toJSON()\n }\n\n toString () {\n return this.super.toString()\n }\n\n format () {\n return this.toString()\n }\n}\n\n/**\n * @param {string | import('url').UrlObject} obj\n */\nfunction format (obj) {\n if (typeof obj === 'string') {\n const url = new URL(obj)\n\n return url.toString()\n }\n\n if (!(obj instanceof URL)) {\n const userPass =\n // @ts-ignore its not supported in node but we normalise\n obj.username && obj.password\n // @ts-ignore its not supported in node but we normalise\n ? `${obj.username}:${obj.password}@`\n : ''\n const auth = obj.auth ? obj.auth + '@' : ''\n const port = obj.port ? ':' + obj.port : ''\n const protocol = obj.protocol ? obj.protocol + '//' : ''\n const host = obj.host || ''\n const hostname = obj.hostname || ''\n const search = obj.search || (obj.query ? '?' + obj.query : '')\n const hash = obj.hash || ''\n const pathname = obj.pathname || ''\n // @ts-ignore - path is not supported in node but we normalise\n const path = obj.path || pathname + search\n\n return `${protocol}${userPass || auth}${\n host || hostname + port\n }${path}${hash}`\n }\n}\n\nmodule.exports = {\n URLWithLegacySupport,\n URLSearchParams: self.URLSearchParams,\n defaultBase,\n format\n}\n","'use strict'\n\nconst { URLWithLegacySupport, format } = require('./url')\n\n/**\n * @param {string | undefined} url\n * @param {any} [location]\n * @param {any} [protocolMap]\n * @param {any} [defaultProtocol]\n */\nmodule.exports = (url, location = {}, protocolMap = {}, defaultProtocol) => {\n let protocol = location.protocol\n ? location.protocol.replace(':', '')\n : 'http'\n\n // Check protocol map\n protocol = (protocolMap[protocol] || defaultProtocol || protocol) + ':'\n let urlParsed\n\n try {\n urlParsed = new URLWithLegacySupport(url)\n } catch (err) {\n urlParsed = {}\n }\n\n const base = Object.assign({}, location, {\n protocol: protocol || urlParsed.protocol,\n host: location.host || urlParsed.host\n })\n\n return new URLWithLegacySupport(url, format(base)).toString()\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar nanoid = require('nanoid');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\n\nconst pathSepS = '/';\nconst pathSepB = new TextEncoder().encode(pathSepS);\nconst pathSep = pathSepB[0];\nclass Key {\n constructor(s, clean) {\n if (typeof s === 'string') {\n this._buf = fromString.fromString(s);\n } else if (s instanceof Uint8Array) {\n this._buf = s;\n } else {\n throw new Error('Invalid key, should be String of Uint8Array');\n }\n if (clean == null) {\n clean = true;\n }\n if (clean) {\n this.clean();\n }\n if (this._buf.byteLength === 0 || this._buf[0] !== pathSep) {\n throw new Error('Invalid key');\n }\n }\n toString(encoding = 'utf8') {\n return toString.toString(this._buf, encoding);\n }\n uint8Array() {\n return this._buf;\n }\n get [Symbol.toStringTag]() {\n return `Key(${ this.toString() })`;\n }\n static withNamespaces(list) {\n return new Key(list.join(pathSepS));\n }\n static random() {\n return new Key(nanoid.nanoid().replace(/-/g, ''));\n }\n static asKey(other) {\n if (other instanceof Uint8Array || typeof other === 'string') {\n return new Key(other);\n }\n if (other.uint8Array) {\n return new Key(other.uint8Array());\n }\n return null;\n }\n clean() {\n if (!this._buf || this._buf.byteLength === 0) {\n this._buf = pathSepB;\n }\n if (this._buf[0] !== pathSep) {\n const bytes = new Uint8Array(this._buf.byteLength + 1);\n bytes.fill(pathSep, 0, 1);\n bytes.set(this._buf, 1);\n this._buf = bytes;\n }\n while (this._buf.byteLength > 1 && this._buf[this._buf.byteLength - 1] === pathSep) {\n this._buf = this._buf.subarray(0, -1);\n }\n }\n less(key) {\n const list1 = this.list();\n const list2 = key.list();\n for (let i = 0; i < list1.length; i++) {\n if (list2.length < i + 1) {\n return false;\n }\n const c1 = list1[i];\n const c2 = list2[i];\n if (c1 < c2) {\n return true;\n } else if (c1 > c2) {\n return false;\n }\n }\n return list1.length < list2.length;\n }\n reverse() {\n return Key.withNamespaces(this.list().slice().reverse());\n }\n namespaces() {\n return this.list();\n }\n baseNamespace() {\n const ns = this.namespaces();\n return ns[ns.length - 1];\n }\n list() {\n return this.toString().split(pathSepS).slice(1);\n }\n type() {\n return namespaceType(this.baseNamespace());\n }\n name() {\n return namespaceValue(this.baseNamespace());\n }\n instance(s) {\n return new Key(this.toString() + ':' + s);\n }\n path() {\n let p = this.parent().toString();\n if (!p.endsWith(pathSepS)) {\n p += pathSepS;\n }\n p += this.type();\n return new Key(p);\n }\n parent() {\n const list = this.list();\n if (list.length === 1) {\n return new Key(pathSepS);\n }\n return new Key(list.slice(0, -1).join(pathSepS));\n }\n child(key) {\n if (this.toString() === pathSepS) {\n return key;\n } else if (key.toString() === pathSepS) {\n return this;\n }\n return new Key(this.toString() + key.toString(), false);\n }\n isAncestorOf(other) {\n if (other.toString() === this.toString()) {\n return false;\n }\n return other.toString().startsWith(this.toString());\n }\n isDecendantOf(other) {\n if (other.toString() === this.toString()) {\n return false;\n }\n return this.toString().startsWith(other.toString());\n }\n isTopLevel() {\n return this.list().length === 1;\n }\n concat(...keys) {\n return Key.withNamespaces([\n ...this.namespaces(),\n ...flatten(keys.map(key => key.namespaces()))\n ]);\n }\n}\nfunction namespaceType(ns) {\n const parts = ns.split(':');\n if (parts.length < 2) {\n return '';\n }\n return parts.slice(0, -1).join(':');\n}\nfunction namespaceValue(ns) {\n const parts = ns.split(':');\n return parts[parts.length - 1];\n}\nfunction flatten(arr) {\n return [].concat(...arr);\n}\n\nexports.Key = Key;\n","import { urlAlphabet } from './url-alphabet/index.js'\nif (process.env.NODE_ENV !== 'production') {\n if (\n typeof navigator !== 'undefined' &&\n navigator.product === 'ReactNative' &&\n typeof crypto === 'undefined'\n ) {\n throw new Error(\n 'React Native does not have a built-in secure random generator. ' +\n 'If you don’t need unpredictable IDs use `nanoid/non-secure`. ' +\n 'For secure IDs, import `react-native-get-random-values` ' +\n 'before Nano ID.'\n )\n }\n if (typeof msCrypto !== 'undefined' && typeof crypto === 'undefined') {\n throw new Error(\n 'Import file with `if (!window.crypto) window.crypto = window.msCrypto`' +\n ' before importing Nano ID to fix IE 11 support'\n )\n }\n if (typeof crypto === 'undefined') {\n throw new Error(\n 'Your browser does not have secure random generator. ' +\n 'If you don’t need unpredictable IDs, you can use nanoid/non-secure.'\n )\n }\n}\nlet random = bytes => crypto.getRandomValues(new Uint8Array(bytes))\nlet customRandom = (alphabet, size, getRandom) => {\n let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1\n let step = -~((1.6 * mask * size) / alphabet.length)\n return () => {\n let id = ''\n while (true) {\n let bytes = getRandom(step)\n let j = step\n while (j--) {\n id += alphabet[bytes[j] & mask] || ''\n if (id.length === size) return id\n }\n }\n }\n}\nlet customAlphabet = (alphabet, size) => customRandom(alphabet, size, random)\nlet nanoid = (size = 21) => {\n let id = ''\n let bytes = crypto.getRandomValues(new Uint8Array(size))\n while (size--) {\n let byte = bytes[size] & 63\n if (byte < 36) {\n id += byte.toString(36)\n } else if (byte < 62) {\n id += (byte - 26).toString(36).toUpperCase()\n } else if (byte < 63) {\n id += '_'\n } else {\n id += '-'\n }\n }\n return id\n}\nexport { nanoid, customAlphabet, customRandom, urlAlphabet, random }\n","let urlAlphabet =\n 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'\nexport { urlAlphabet }\n","exports.interopDefault = function (a) {\n return a && a.__esModule ? a : {default: a};\n};\n\nexports.defineInteropFlag = function (a) {\n Object.defineProperty(a, '__esModule', {value: true});\n};\n\nexports.exportAll = function (source, dest) {\n Object.keys(source).forEach(function (key) {\n if (key === 'default' || key === '__esModule' || dest.hasOwnProperty(key)) {\n return;\n }\n\n Object.defineProperty(dest, key, {\n enumerable: true,\n get: function () {\n return source[key];\n },\n });\n });\n\n return dest;\n};\n\nexports.export = function (dest, destName, get) {\n Object.defineProperty(dest, destName, {\n enumerable: true,\n get: get,\n });\n};\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar TimeoutController = require('timeout-abort-controller');\nvar anySignal = require('any-signal');\nvar parseDuration = require('parse-duration');\nvar errors = require('./errors.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar TimeoutController__default = /*#__PURE__*/_interopDefaultLegacy(TimeoutController);\nvar parseDuration__default = /*#__PURE__*/_interopDefaultLegacy(parseDuration);\n\nfunction withTimeoutOption(fn, optionsArgIndex) {\n return (...args) => {\n const options = args[optionsArgIndex == null ? args.length - 1 : optionsArgIndex];\n if (!options || !options.timeout)\n return fn(...args);\n const timeout = typeof options.timeout === 'string' ? parseDuration__default['default'](options.timeout) : options.timeout;\n const controller = new TimeoutController__default['default'](timeout);\n options.signal = anySignal.anySignal([\n options.signal,\n controller.signal\n ]);\n const fnRes = fn(...args);\n const timeoutPromise = new Promise((_resolve, reject) => {\n controller.signal.addEventListener('abort', () => {\n reject(new errors.TimeoutError());\n });\n });\n const start = Date.now();\n const maybeThrowTimeoutError = () => {\n if (controller.signal.aborted) {\n throw new errors.TimeoutError();\n }\n const timeTaken = Date.now() - start;\n if (timeTaken > timeout) {\n controller.abort();\n throw new errors.TimeoutError();\n }\n };\n if (fnRes[Symbol.asyncIterator]) {\n return async function* () {\n const it = fnRes[Symbol.asyncIterator]();\n try {\n while (true) {\n const {value, done} = await Promise.race([\n it.next(),\n timeoutPromise\n ]);\n if (done) {\n break;\n }\n maybeThrowTimeoutError();\n yield value;\n }\n } catch (err) {\n maybeThrowTimeoutError();\n throw err;\n } finally {\n controller.clear();\n if (it.return) {\n it.return();\n }\n }\n }();\n }\n return (async () => {\n try {\n const res = await Promise.race([\n fnRes,\n timeoutPromise\n ]);\n maybeThrowTimeoutError();\n return res;\n } catch (err) {\n maybeThrowTimeoutError();\n throw err;\n } finally {\n controller.clear();\n }\n })();\n };\n}\n\nexports.withTimeoutOption = withTimeoutOption;\n","/* globals self, window */\n'use strict'\n\n// Get around https://github.com/mysticatea/abort-controller/pull/22\nconst { AbortController } =\n typeof self !== 'undefined' ? self\n : typeof window !== 'undefined' ? window\n /* otherwise */ : require('abort-controller')\n\nconst retimer = require('retimer')\n\nclass TimeoutController extends AbortController {\n /**\n * @constructor\n * @param {number} ms milliseconds\n */\n constructor (ms) {\n super()\n this._ms = ms\n this._timer = retimer(() => this.abort(), ms)\n // Patch for safari not supported extending built in classes\n Object.setPrototypeOf(this, TimeoutController.prototype)\n }\n\n /**\n * Aborts the controller and clears the timer\n */\n abort () {\n this._timer.clear()\n return super.abort()\n }\n\n /**\n * Clears the timer\n */\n clear () {\n this._timer.clear()\n }\n\n /**\n * Resets the timer\n */\n reset () {\n this._timer.clear()\n this._timer = retimer(() => this.abort(), this._ms)\n }\n}\n\nmodule.exports = TimeoutController\nmodule.exports.TimeoutController = TimeoutController\n","/*globals self, window */\n\"use strict\"\n\n/*eslint-disable @mysticatea/prettier */\nconst { AbortController, AbortSignal } =\n typeof self !== \"undefined\" ? self :\n typeof window !== \"undefined\" ? window :\n /* otherwise */ undefined\n/*eslint-enable @mysticatea/prettier */\n\nmodule.exports = AbortController\nmodule.exports.AbortSignal = AbortSignal\nmodule.exports.default = AbortController\n","'use strict'\n\nvar getTime = require('./time')\n\nfunction Retimer (callback, timeout, args) {\n var that = this\n\n this._started = getTime()\n this._rescheduled = 0\n this._scheduled = timeout\n this._args = args\n\n this._timer = setTimeout(timerWrapper, timeout)\n\n function timerWrapper () {\n if (that._rescheduled > 0) {\n that._scheduled = that._rescheduled - (getTime() - that._started)\n that._timer = setTimeout(timerWrapper, that._scheduled)\n that._rescheduled = 0\n } else {\n callback.apply(null, that._args)\n }\n }\n}\n\nRetimer.prototype.reschedule = function (timeout) {\n var now = getTime()\n if ((now + timeout) - (this._started + this._scheduled) < 0) {\n return false\n } else {\n this._started = now\n this._rescheduled = timeout\n return true\n }\n}\n\nRetimer.prototype.clear = function () {\n clearTimeout(this._timer)\n}\n\nfunction retimer () {\n if (typeof arguments[0] !== 'function') {\n throw new Error('callback needed')\n }\n\n if (typeof arguments[1] !== 'number') {\n throw new Error('timeout needed')\n }\n\n var args\n\n if (arguments.length > 0) {\n args = new Array(arguments.length - 2)\n\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 2]\n }\n }\n\n return new Retimer(arguments[0], arguments[1], args)\n}\n\nmodule.exports = retimer\n","'use strict'\n\nmodule.exports = function getTime () {\n return Date.now()\n}\n","const { AbortController } = require('native-abort-controller')\n\n/**\n * Takes an array of AbortSignals and returns a single signal.\n * If any signals are aborted, the returned signal will be aborted.\n * @param {Array<AbortSignal>} signals\n * @returns {AbortSignal}\n */\nfunction anySignal (signals) {\n const controller = new AbortController()\n\n function onAbort () {\n controller.abort()\n\n for (const signal of signals) {\n if (!signal || !signal.removeEventListener) continue\n signal.removeEventListener('abort', onAbort)\n }\n }\n\n for (const signal of signals) {\n if (!signal || !signal.addEventListener) continue\n if (signal.aborted) {\n onAbort()\n break\n }\n signal.addEventListener('abort', onAbort)\n }\n\n return controller.signal\n}\n\nmodule.exports = anySignal\nmodule.exports.anySignal = anySignal\n","'use strict'\n\nlet impl\n\nif (globalThis.AbortController && globalThis.AbortSignal) {\n impl = globalThis\n} else {\n impl = require('abort-controller')\n}\n\nmodule.exports.AbortSignal = impl.AbortSignal\nmodule.exports.AbortController = impl.AbortController\n","let durationRE = /(-?(?:\\d+\\.?\\d*|\\d*\\.?\\d+)(?:e[-+]?\\d+)?)\\s*([\\p{L}]*)/uig\r\n\r\n\r\n/**\r\n * conversion ratios\r\n */\r\n\r\nparse.nanosecond =\r\nparse.ns = 1 / 1e6\r\n\r\nparse['µs'] =\r\nparse['μs'] =\r\nparse.us =\r\nparse.microsecond = 1 / 1e3\r\n\r\nparse.millisecond =\r\nparse.ms =\r\nparse[''] = 1\r\n\r\nparse.second =\r\nparse.sec =\r\nparse.s = parse.ms * 1000\r\n\r\nparse.minute =\r\nparse.min =\r\nparse.m = parse.s * 60\r\n\r\nparse.hour =\r\nparse.hr =\r\nparse.h = parse.m * 60\r\n\r\nparse.day =\r\nparse.d = parse.h * 24\r\n\r\nparse.week =\r\nparse.wk =\r\nparse.w = parse.d * 7\r\n\r\nparse.month =\r\nparse.b =\r\nparse.d * (365.25 / 12)\r\n\r\nparse.year =\r\nparse.yr =\r\nparse.y = parse.d * 365.25\r\n\r\n/**\r\n * convert `str` to ms\r\n *\r\n * @param {String} str\r\n * @param {String} format\r\n * @return {Number}\r\n */\r\n\r\nfunction parse(str='', format='ms'){\r\n var result = null\r\n // ignore commas/placeholders\r\n str = (str+'').replace(/(\\d)[,_](\\d)/g, '$1$2')\r\n str.replace(durationRE, function(_, n, units){\r\n units = unitRatio(units)\r\n if (units) result = (result || 0) + parseFloat(n, 10) * units\r\n })\r\n\r\n return result && (result / (unitRatio(format) || 1))\r\n}\r\n\r\nfunction unitRatio(str) {\r\n return parse[str] || parse[str.toLowerCase().replace(/s$/, '')]\r\n}\r\n\r\nexport default parse\r\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass TimeoutError extends Error {\n constructor(message = 'request timed out') {\n super(message);\n this.name = 'TimeoutError';\n this.code = TimeoutError.code;\n }\n}\nTimeoutError.code = 'ERR_TIMEOUT';\n\nexports.TimeoutError = TimeoutError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst IPFS_PREFIX = '/ipfs/';\nfunction toCidAndPath(string) {\n if (string instanceof Uint8Array) {\n try {\n string = cid.CID.decode(string);\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_CID');\n }\n }\n let cid$1 = cid.CID.asCID(string);\n if (cid$1) {\n return {\n cid: cid$1,\n path: undefined\n };\n }\n string = string.toString();\n if (string.startsWith(IPFS_PREFIX)) {\n string = string.substring(IPFS_PREFIX.length);\n }\n const parts = string.split('/');\n let path;\n try {\n cid$1 = cid.CID.parse(parts.shift() || '');\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_CID');\n }\n if (parts.length) {\n path = `/${ parts.join('/') }`;\n }\n return {\n cid: cid$1,\n path\n };\n}\n\nexports.toCidAndPath = toCidAndPath;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar service = require('../utils/service.js');\n\nfunction createStop({network, preload, ipns, repo, mfsPreload}) {\n const stop = async () => {\n await Promise.all([\n preload.stop(),\n ipns.stop(),\n mfsPreload.stop(),\n service.Service.stop(network),\n repo.close()\n ]);\n };\n return stop;\n}\n\nexports.createStop = createStop;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dns = require('ipfs-core-config/dns');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction fqdnFixups(domain) {\n if (domain.endsWith('.eth')) {\n domain = domain.replace(/.eth$/, '.eth.link');\n }\n return domain;\n}\nfunction createDns() {\n const resolveDNS = async (domain, options = { recursive: true }) => {\n if (typeof domain !== 'string') {\n throw new Error('Invalid arguments, domain must be a string');\n }\n domain = fqdnFixups(domain);\n return dns.resolveDnslink(domain, options);\n };\n return withTimeoutOption.withTimeoutOption(resolveDNS);\n}\n\nexports.createDns = createDns;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar tlru = require('./utils/tlru.js');\nvar PQueue = require('p-queue');\nvar HTTP = require('ipfs-utils/src/http.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PQueue__default = /*#__PURE__*/_interopDefaultLegacy(PQueue);\nvar HTTP__default = /*#__PURE__*/_interopDefaultLegacy(HTTP);\n\nconst cache = new tlru.TLRU(1000);\nconst ttl = 60 * 1000;\nconst Queue = PQueue__default[\"default\"].default ? PQueue__default[\"default\"].default : PQueue__default[\"default\"];\nconst httpQueue = new Queue({ concurrency: 4 });\nconst ipfsPath = response => {\n if (response.Path)\n return response.Path;\n throw new Error(response.Message);\n};\nasync function resolveDnslink(fqdn, opts) {\n const resolve = async (fqdn, opts = {}) => {\n const searchParams = new URLSearchParams(opts);\n searchParams.set('arg', fqdn);\n const query = searchParams.toString();\n if (!opts.nocache && cache.has(query)) {\n const response = cache.get(query);\n return ipfsPath(response);\n }\n const response = await httpQueue.add(async () => {\n const res = await HTTP__default[\"default\"].get('https://ipfs.io/api/v0/dns', { searchParams });\n const query = new URL(res.url).search.slice(1);\n const json = await res.json();\n cache.set(query, json, ttl);\n return json;\n });\n return ipfsPath(response);\n };\n return resolve(fqdn, opts);\n}\n\nexports.resolveDnslink = resolveDnslink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hashlru = require('hashlru');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar hashlru__default = /*#__PURE__*/_interopDefaultLegacy(hashlru);\n\nclass TLRU {\n constructor(maxSize) {\n this.lru = hashlru__default[\"default\"](maxSize);\n }\n get(key) {\n const value = this.lru.get(key);\n if (value) {\n if (value.expire && value.expire < Date.now()) {\n this.lru.remove(key);\n return undefined;\n }\n return value.value;\n }\n return undefined;\n }\n set(key, value, ttl) {\n this.lru.set(key, {\n value,\n expire: Date.now() + ttl\n });\n }\n has(key) {\n const value = this.get(key);\n if (value) {\n return true;\n }\n return false;\n }\n remove(key) {\n this.lru.remove(key);\n }\n clear() {\n this.lru.clear();\n }\n}\n\nexports.TLRU = TLRU;\n","module.exports = function (max) {\n\n if (!max) throw Error('hashlru must have a max value, of type number, greater than 0')\n\n var size = 0, cache = Object.create(null), _cache = Object.create(null)\n\n function update (key, value) {\n cache[key] = value\n size ++\n if(size >= max) {\n size = 0\n _cache = cache\n cache = Object.create(null)\n }\n }\n\n return {\n has: function (key) {\n return cache[key] !== undefined || _cache[key] !== undefined\n },\n remove: function (key) {\n if(cache[key] !== undefined)\n cache[key] = undefined\n if(_cache[key] !== undefined)\n _cache[key] = undefined\n },\n get: function (key) {\n var v = cache[key]\n if(v !== undefined) return v\n if((v = _cache[key]) !== undefined) {\n update(key, v)\n return v\n }\n },\n set: function (key, value) {\n if(cache[key] !== undefined) cache[key] = value\n else update(key, value)\n },\n clear: function () {\n cache = Object.create(null)\n _cache = Object.create(null)\n }\n }\n}\n\n\n\n\n\n\n\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst EventEmitter = require(\"eventemitter3\");\nconst p_timeout_1 = require(\"p-timeout\");\nconst priority_queue_1 = require(\"./priority-queue\");\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nconst empty = () => { };\nconst timeoutError = new p_timeout_1.TimeoutError();\n/**\nPromise queue with concurrency control.\n*/\nclass PQueue extends EventEmitter {\n constructor(options) {\n var _a, _b, _c, _d;\n super();\n this._intervalCount = 0;\n this._intervalEnd = 0;\n this._pendingCount = 0;\n this._resolveEmpty = empty;\n this._resolveIdle = empty;\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\n options = Object.assign({ carryoverConcurrencyCount: false, intervalCap: Infinity, interval: 0, concurrency: Infinity, autoStart: true, queueClass: priority_queue_1.default }, options);\n if (!(typeof options.intervalCap === 'number' && options.intervalCap >= 1)) {\n throw new TypeError(`Expected \\`intervalCap\\` to be a number from 1 and up, got \\`${(_b = (_a = options.intervalCap) === null || _a === void 0 ? void 0 : _a.toString()) !== null && _b !== void 0 ? _b : ''}\\` (${typeof options.intervalCap})`);\n }\n if (options.interval === undefined || !(Number.isFinite(options.interval) && options.interval >= 0)) {\n throw new TypeError(`Expected \\`interval\\` to be a finite number >= 0, got \\`${(_d = (_c = options.interval) === null || _c === void 0 ? void 0 : _c.toString()) !== null && _d !== void 0 ? _d : ''}\\` (${typeof options.interval})`);\n }\n this._carryoverConcurrencyCount = options.carryoverConcurrencyCount;\n this._isIntervalIgnored = options.intervalCap === Infinity || options.interval === 0;\n this._intervalCap = options.intervalCap;\n this._interval = options.interval;\n this._queue = new options.queueClass();\n this._queueClass = options.queueClass;\n this.concurrency = options.concurrency;\n this._timeout = options.timeout;\n this._throwOnTimeout = options.throwOnTimeout === true;\n this._isPaused = options.autoStart === false;\n }\n get _doesIntervalAllowAnother() {\n return this._isIntervalIgnored || this._intervalCount < this._intervalCap;\n }\n get _doesConcurrentAllowAnother() {\n return this._pendingCount < this._concurrency;\n }\n _next() {\n this._pendingCount--;\n this._tryToStartAnother();\n this.emit('next');\n }\n _resolvePromises() {\n this._resolveEmpty();\n this._resolveEmpty = empty;\n if (this._pendingCount === 0) {\n this._resolveIdle();\n this._resolveIdle = empty;\n this.emit('idle');\n }\n }\n _onResumeInterval() {\n this._onInterval();\n this._initializeIntervalIfNeeded();\n this._timeoutId = undefined;\n }\n _isIntervalPaused() {\n const now = Date.now();\n if (this._intervalId === undefined) {\n const delay = this._intervalEnd - now;\n if (delay < 0) {\n // Act as the interval was done\n // We don't need to resume it here because it will be resumed on line 160\n this._intervalCount = (this._carryoverConcurrencyCount) ? this._pendingCount : 0;\n }\n else {\n // Act as the interval is pending\n if (this._timeoutId === undefined) {\n this._timeoutId = setTimeout(() => {\n this._onResumeInterval();\n }, delay);\n }\n return true;\n }\n }\n return false;\n }\n _tryToStartAnother() {\n if (this._queue.size === 0) {\n // We can clear the interval (\"pause\")\n // Because we can redo it later (\"resume\")\n if (this._intervalId) {\n clearInterval(this._intervalId);\n }\n this._intervalId = undefined;\n this._resolvePromises();\n return false;\n }\n if (!this._isPaused) {\n const canInitializeInterval = !this._isIntervalPaused();\n if (this._doesIntervalAllowAnother && this._doesConcurrentAllowAnother) {\n const job = this._queue.dequeue();\n if (!job) {\n return false;\n }\n this.emit('active');\n job();\n if (canInitializeInterval) {\n this._initializeIntervalIfNeeded();\n }\n return true;\n }\n }\n return false;\n }\n _initializeIntervalIfNeeded() {\n if (this._isIntervalIgnored || this._intervalId !== undefined) {\n return;\n }\n this._intervalId = setInterval(() => {\n this._onInterval();\n }, this._interval);\n this._intervalEnd = Date.now() + this._interval;\n }\n _onInterval() {\n if (this._intervalCount === 0 && this._pendingCount === 0 && this._intervalId) {\n clearInterval(this._intervalId);\n this._intervalId = undefined;\n }\n this._intervalCount = this._carryoverConcurrencyCount ? this._pendingCount : 0;\n this._processQueue();\n }\n /**\n Executes all queued functions until it reaches the limit.\n */\n _processQueue() {\n // eslint-disable-next-line no-empty\n while (this._tryToStartAnother()) { }\n }\n get concurrency() {\n return this._concurrency;\n }\n set concurrency(newConcurrency) {\n if (!(typeof newConcurrency === 'number' && newConcurrency >= 1)) {\n throw new TypeError(`Expected \\`concurrency\\` to be a number from 1 and up, got \\`${newConcurrency}\\` (${typeof newConcurrency})`);\n }\n this._concurrency = newConcurrency;\n this._processQueue();\n }\n /**\n Adds a sync or async task to the queue. Always returns a promise.\n */\n async add(fn, options = {}) {\n return new Promise((resolve, reject) => {\n const run = async () => {\n this._pendingCount++;\n this._intervalCount++;\n try {\n const operation = (this._timeout === undefined && options.timeout === undefined) ? fn() : p_timeout_1.default(Promise.resolve(fn()), (options.timeout === undefined ? this._timeout : options.timeout), () => {\n if (options.throwOnTimeout === undefined ? this._throwOnTimeout : options.throwOnTimeout) {\n reject(timeoutError);\n }\n return undefined;\n });\n resolve(await operation);\n }\n catch (error) {\n reject(error);\n }\n this._next();\n };\n this._queue.enqueue(run, options);\n this._tryToStartAnother();\n this.emit('add');\n });\n }\n /**\n Same as `.add()`, but accepts an array of sync or async functions.\n\n @returns A promise that resolves when all functions are resolved.\n */\n async addAll(functions, options) {\n return Promise.all(functions.map(async (function_) => this.add(function_, options)));\n }\n /**\n Start (or resume) executing enqueued tasks within concurrency limit. No need to call this if queue is not paused (via `options.autoStart = false` or by `.pause()` method.)\n */\n start() {\n if (!this._isPaused) {\n return this;\n }\n this._isPaused = false;\n this._processQueue();\n return this;\n }\n /**\n Put queue execution on hold.\n */\n pause() {\n this._isPaused = true;\n }\n /**\n Clear the queue.\n */\n clear() {\n this._queue = new this._queueClass();\n }\n /**\n Can be called multiple times. Useful if you for example add additional items at a later time.\n\n @returns A promise that settles when the queue becomes empty.\n */\n async onEmpty() {\n // Instantly resolve if the queue is empty\n if (this._queue.size === 0) {\n return;\n }\n return new Promise(resolve => {\n const existingResolve = this._resolveEmpty;\n this._resolveEmpty = () => {\n existingResolve();\n resolve();\n };\n });\n }\n /**\n The difference with `.onEmpty` is that `.onIdle` guarantees that all work from the queue has finished. `.onEmpty` merely signals that the queue is empty, but it could mean that some promises haven't completed yet.\n\n @returns A promise that settles when the queue becomes empty, and all promises have completed; `queue.size === 0 && queue.pending === 0`.\n */\n async onIdle() {\n // Instantly resolve if none pending and if nothing else is queued\n if (this._pendingCount === 0 && this._queue.size === 0) {\n return;\n }\n return new Promise(resolve => {\n const existingResolve = this._resolveIdle;\n this._resolveIdle = () => {\n existingResolve();\n resolve();\n };\n });\n }\n /**\n Size of the queue.\n */\n get size() {\n return this._queue.size;\n }\n /**\n Size of the queue, filtered by the given options.\n\n For example, this can be used to find the number of items remaining in the queue with a specific priority level.\n */\n sizeBy(options) {\n // eslint-disable-next-line unicorn/no-fn-reference-in-iterator\n return this._queue.filter(options).length;\n }\n /**\n Number of pending promises.\n */\n get pending() {\n return this._pendingCount;\n }\n /**\n Whether the queue is currently paused.\n */\n get isPaused() {\n return this._isPaused;\n }\n get timeout() {\n return this._timeout;\n }\n /**\n Set the timeout for future operations.\n */\n set timeout(milliseconds) {\n this._timeout = milliseconds;\n }\n}\nexports.default = PQueue;\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","'use strict';\n\nconst pFinally = require('p-finally');\n\nclass TimeoutError extends Error {\n\tconstructor(message) {\n\t\tsuper(message);\n\t\tthis.name = 'TimeoutError';\n\t}\n}\n\nconst pTimeout = (promise, milliseconds, fallback) => new Promise((resolve, reject) => {\n\tif (typeof milliseconds !== 'number' || milliseconds < 0) {\n\t\tthrow new TypeError('Expected `milliseconds` to be a positive number');\n\t}\n\n\tif (milliseconds === Infinity) {\n\t\tresolve(promise);\n\t\treturn;\n\t}\n\n\tconst timer = setTimeout(() => {\n\t\tif (typeof fallback === 'function') {\n\t\t\ttry {\n\t\t\t\tresolve(fallback());\n\t\t\t} catch (error) {\n\t\t\t\treject(error);\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst message = typeof fallback === 'string' ? fallback : `Promise timed out after ${milliseconds} milliseconds`;\n\t\tconst timeoutError = fallback instanceof Error ? fallback : new TimeoutError(message);\n\n\t\tif (typeof promise.cancel === 'function') {\n\t\t\tpromise.cancel();\n\t\t}\n\n\t\treject(timeoutError);\n\t}, milliseconds);\n\n\t// TODO: Use native `finally` keyword when targeting Node.js 10\n\tpFinally(\n\t\t// eslint-disable-next-line promise/prefer-await-to-then\n\t\tpromise.then(resolve, reject),\n\t\t() => {\n\t\t\tclearTimeout(timer);\n\t\t}\n\t);\n});\n\nmodule.exports = pTimeout;\n// TODO: Remove this for the next major release\nmodule.exports.default = pTimeout;\n\nmodule.exports.TimeoutError = TimeoutError;\n","'use strict';\nmodule.exports = (promise, onFinally) => {\n\tonFinally = onFinally || (() => {});\n\n\treturn promise.then(\n\t\tval => new Promise(resolve => {\n\t\t\tresolve(onFinally());\n\t\t}).then(() => val),\n\t\terr => new Promise(resolve => {\n\t\t\tresolve(onFinally());\n\t\t}).then(() => {\n\t\t\tthrow err;\n\t\t})\n\t);\n};\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst lower_bound_1 = require(\"./lower-bound\");\nclass PriorityQueue {\n constructor() {\n this._queue = [];\n }\n enqueue(run, options) {\n options = Object.assign({ priority: 0 }, options);\n const element = {\n priority: options.priority,\n run\n };\n if (this.size && this._queue[this.size - 1].priority >= options.priority) {\n this._queue.push(element);\n return;\n }\n const index = lower_bound_1.default(this._queue, element, (a, b) => b.priority - a.priority);\n this._queue.splice(index, 0, element);\n }\n dequeue() {\n const item = this._queue.shift();\n return item === null || item === void 0 ? void 0 : item.run;\n }\n filter(options) {\n return this._queue.filter((element) => element.priority === options.priority).map((element) => element.run);\n }\n get size() {\n return this._queue.length;\n }\n}\nexports.default = PriorityQueue;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// Port of lower_bound from https://en.cppreference.com/w/cpp/algorithm/lower_bound\n// Used to compute insertion index to keep queue sorted after insertion\nfunction lowerBound(array, value, comparator) {\n let first = 0;\n let count = array.length;\n while (count > 0) {\n const step = (count / 2) | 0;\n let it = first + step;\n if (comparator(array[it], value) <= 0) {\n first = ++it;\n count -= step + 1;\n }\n else {\n count = step;\n }\n }\n return first;\n}\nexports.default = lowerBound;\n","/* eslint-disable no-undef */\n'use strict'\n\nconst { fetch, Request, Headers } = require('./http/fetch')\nconst { TimeoutError, HTTPError } = require('./http/error')\nconst merge = require('merge-options').bind({ ignoreUndefined: true })\nconst { URL, URLSearchParams } = require('iso-url')\nconst { AbortController } = require('native-abort-controller')\nconst anySignal = require('any-signal')\n\n/**\n * @typedef {import('stream').Readable} NodeReadableStream\n * @typedef {import('./types').HTTPOptions} HTTPOptions\n * @typedef {import('./types').ExtendedResponse} ExtendedResponse\n */\n\n/**\n * @template TResponse\n * @param {Promise<TResponse>} promise\n * @param {number | undefined} ms\n * @param {AbortController} abortController\n * @returns {Promise<TResponse>}\n */\nconst timeout = (promise, ms, abortController) => {\n if (ms === undefined) {\n return promise\n }\n\n const start = Date.now()\n\n const timedOut = () => {\n const time = Date.now() - start\n\n return time >= ms\n }\n\n return new Promise((resolve, reject) => {\n const timeoutID = setTimeout(() => {\n if (timedOut()) {\n reject(new TimeoutError())\n abortController.abort()\n }\n }, ms)\n\n /**\n * @param {(value: any) => void } next\n */\n const after = (next) => {\n /**\n * @param {any} res\n */\n const fn = (res) => {\n clearTimeout(timeoutID)\n\n if (timedOut()) {\n reject(new TimeoutError())\n return\n }\n\n next(res)\n }\n return fn\n }\n\n promise\n .then(after(resolve), after(reject))\n })\n}\n\nconst defaults = {\n throwHttpErrors: true,\n credentials: 'same-origin'\n}\n\nclass HTTP {\n /**\n *\n * @param {HTTPOptions} options\n */\n constructor (options = {}) {\n /** @type {HTTPOptions} */\n this.opts = merge(defaults, options)\n }\n\n /**\n * Fetch\n *\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n * @returns {Promise<ExtendedResponse>}\n */\n async fetch (resource, options = {}) {\n /** @type {HTTPOptions} */\n const opts = merge(this.opts, options)\n const headers = new Headers(opts.headers)\n\n // validate resource type\n if (typeof resource !== 'string' && !(resource instanceof URL || resource instanceof Request)) {\n throw new TypeError('`resource` must be a string, URL, or Request')\n }\n\n const url = new URL(resource.toString(), opts.base)\n\n const {\n searchParams,\n transformSearchParams,\n json\n } = opts\n\n if (searchParams) {\n if (typeof transformSearchParams === 'function') {\n // @ts-ignore\n url.search = transformSearchParams(new URLSearchParams(opts.searchParams))\n } else {\n // @ts-ignore\n url.search = new URLSearchParams(opts.searchParams)\n }\n }\n\n if (json) {\n opts.body = JSON.stringify(opts.json)\n headers.set('content-type', 'application/json')\n }\n\n const abortController = new AbortController()\n // @ts-ignore\n const signal = anySignal([abortController.signal, opts.signal])\n\n const response = await timeout(\n fetch(\n url.toString(),\n {\n ...opts,\n signal,\n timeout: undefined,\n headers\n }\n ),\n opts.timeout,\n abortController\n )\n\n if (!response.ok && opts.throwHttpErrors) {\n if (opts.handleError) {\n await opts.handleError(response)\n }\n throw new HTTPError(response)\n }\n\n response.iterator = function () {\n return fromStream(response.body)\n }\n\n response.ndjson = async function * () {\n for await (const chunk of ndjson(response.iterator())) {\n if (options.transform) {\n yield options.transform(chunk)\n } else {\n yield chunk\n }\n }\n }\n\n return response\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n post (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'POST' })\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n get (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'GET' })\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n put (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'PUT' })\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n delete (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'DELETE' })\n }\n\n /**\n * @param {string | Request} resource\n * @param {HTTPOptions} options\n */\n options (resource, options = {}) {\n return this.fetch(resource, { ...options, method: 'OPTIONS' })\n }\n}\n\n/**\n * Parses NDJSON chunks from an iterator\n *\n * @param {AsyncIterable<Uint8Array>} source\n * @returns {AsyncIterable<any>}\n */\nconst ndjson = async function * (source) {\n const decoder = new TextDecoder()\n let buf = ''\n\n for await (const chunk of source) {\n buf += decoder.decode(chunk, { stream: true })\n const lines = buf.split(/\\r?\\n/)\n\n for (let i = 0; i < lines.length - 1; i++) {\n const l = lines[i].trim()\n if (l.length > 0) {\n yield JSON.parse(l)\n }\n }\n buf = lines[lines.length - 1]\n }\n buf += decoder.decode()\n buf = buf.trim()\n if (buf.length !== 0) {\n yield JSON.parse(buf)\n }\n}\n\n/**\n * Stream to AsyncIterable\n *\n * @template TChunk\n * @param {ReadableStream<TChunk> | NodeReadableStream | null} source\n * @returns {AsyncIterable<TChunk>}\n */\nconst fromStream = (source) => {\n // Workaround for https://github.com/node-fetch/node-fetch/issues/766\n if (isNodeReadableStream(source)) {\n const iter = source[Symbol.asyncIterator]()\n return {\n [Symbol.asyncIterator] () {\n return {\n next: iter.next.bind(iter),\n return (value) {\n source.destroy()\n if (typeof iter.return === 'function') {\n return iter.return()\n }\n return Promise.resolve({ done: true, value })\n }\n }\n }\n }\n }\n\n if (isWebReadableStream(source)) {\n const reader = source.getReader()\n return (async function * () {\n try {\n while (true) {\n // Read from the stream\n const { done, value } = await reader.read()\n // Exit if we're done\n if (done) return\n // Else yield the chunk\n if (value) {\n yield value\n }\n }\n } finally {\n reader.releaseLock()\n }\n })()\n }\n\n if (isAsyncIterable(source)) {\n return source\n }\n\n throw new TypeError('Body can\\'t be converted to AsyncIterable')\n}\n\n/**\n * Check if it's an AsyncIterable\n *\n * @template {unknown} TChunk\n * @template {any} Other\n * @param {Other|AsyncIterable<TChunk>} value\n * @returns {value is AsyncIterable<TChunk>}\n */\nconst isAsyncIterable = (value) => {\n return typeof value === 'object' &&\n value !== null &&\n typeof /** @type {any} */(value)[Symbol.asyncIterator] === 'function'\n}\n\n/**\n * Check for web readable stream\n *\n * @template {unknown} TChunk\n * @template {any} Other\n * @param {Other|ReadableStream<TChunk>} value\n * @returns {value is ReadableStream<TChunk>}\n */\nconst isWebReadableStream = (value) => {\n return value && typeof /** @type {any} */(value).getReader === 'function'\n}\n\n/**\n * @param {any} value\n * @returns {value is NodeReadableStream}\n */\nconst isNodeReadableStream = (value) =>\n Object.prototype.hasOwnProperty.call(value, 'readable') &&\n Object.prototype.hasOwnProperty.call(value, 'writable')\n\nHTTP.HTTPError = HTTPError\nHTTP.TimeoutError = TimeoutError\nHTTP.streamToAsyncIterator = fromStream\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.post = (resource, options) => new HTTP(options).post(resource, options)\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.get = (resource, options) => new HTTP(options).get(resource, options)\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.put = (resource, options) => new HTTP(options).put(resource, options)\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.delete = (resource, options) => new HTTP(options).delete(resource, options)\n\n/**\n * @param {string | Request} resource\n * @param {HTTPOptions} [options]\n */\nHTTP.options = (resource, options) => new HTTP(options).options(resource, options)\n\nmodule.exports = HTTP\n","'use strict'\n\nconst { TimeoutError, AbortError } = require('./error')\nconst { Response, Request, Headers, default: fetch } = require('../fetch')\n\n/**\n * @typedef {import('../types').FetchOptions} FetchOptions\n * @typedef {import('../types').ProgressFn} ProgressFn\n */\n\n/**\n * Fetch with progress\n *\n * @param {string | Request} url\n * @param {FetchOptions} [options]\n * @returns {Promise<ResponseWithURL>}\n */\nconst fetchWithProgress = (url, options = {}) => {\n const request = new XMLHttpRequest()\n request.open(options.method || 'GET', url.toString(), true)\n\n const { timeout, headers } = options\n\n if (timeout && timeout > 0 && timeout < Infinity) {\n request.timeout = timeout\n }\n\n if (options.overrideMimeType != null) {\n request.overrideMimeType(options.overrideMimeType)\n }\n\n if (headers) {\n for (const [name, value] of new Headers(headers)) {\n request.setRequestHeader(name, value)\n }\n }\n\n if (options.signal) {\n options.signal.onabort = () => request.abort()\n }\n\n if (options.onUploadProgress) {\n request.upload.onprogress = options.onUploadProgress\n }\n\n // Note: Need to use `arraybuffer` here instead of `blob` because `Blob`\n // instances coming from JSDOM are not compatible with `Response` from\n // node-fetch (which is the setup we get when testing with jest because\n // it uses JSDOM which does not provide a global fetch\n // https://github.com/jsdom/jsdom/issues/1724)\n request.responseType = 'arraybuffer'\n\n return new Promise((resolve, reject) => {\n /**\n * @param {Event} event\n */\n const handleEvent = (event) => {\n switch (event.type) {\n case 'error': {\n resolve(Response.error())\n break\n }\n case 'load': {\n resolve(\n new ResponseWithURL(request.responseURL, request.response, {\n status: request.status,\n statusText: request.statusText,\n headers: parseHeaders(request.getAllResponseHeaders())\n })\n )\n break\n }\n case 'timeout': {\n reject(new TimeoutError())\n break\n }\n case 'abort': {\n reject(new AbortError())\n break\n }\n default: {\n break\n }\n }\n }\n request.onerror = handleEvent\n request.onload = handleEvent\n request.ontimeout = handleEvent\n request.onabort = handleEvent\n\n // @ts-expect-error options.body can be a node readable stream, which isn't compatible with XHR, but this\n // file is a browser override so you won't get a node readable stream so ignore the error\n request.send(options.body)\n })\n}\n\nconst fetchWithStreaming = fetch\n\n/**\n * @param {string | Request} url\n * @param {FetchOptions} options\n */\nconst fetchWith = (url, options = {}) =>\n (options.onUploadProgress != null)\n ? fetchWithProgress(url, options)\n : fetchWithStreaming(url, options)\n\n/**\n * Parse Headers from a XMLHttpRequest\n *\n * @param {string} input\n * @returns {Headers}\n */\nconst parseHeaders = (input) => {\n const headers = new Headers()\n for (const line of input.trim().split(/[\\r\\n]+/)) {\n const index = line.indexOf(': ')\n if (index > 0) {\n headers.set(line.slice(0, index), line.slice(index + 1))\n }\n }\n\n return headers\n}\n\nclass ResponseWithURL extends Response {\n /**\n * @param {string} url\n * @param {BodyInit} body\n * @param {ResponseInit} options\n */\n constructor (url, body, options) {\n super(body, options)\n Object.defineProperty(this, 'url', { value: url })\n }\n}\n\nmodule.exports = {\n fetch: fetchWith,\n Request,\n Headers\n}\n","'use strict'\n\nclass TimeoutError extends Error {\n constructor (message = 'Request timed out') {\n super(message)\n this.name = 'TimeoutError'\n }\n}\nexports.TimeoutError = TimeoutError\n\nclass AbortError extends Error {\n constructor (message = 'The operation was aborted.') {\n super(message)\n this.name = 'AbortError'\n }\n}\nexports.AbortError = AbortError\n\nclass HTTPError extends Error {\n /**\n * @param {Response} response\n */\n constructor (response) {\n super(response.statusText)\n this.name = 'HTTPError'\n this.response = response\n }\n}\nexports.HTTPError = HTTPError\n","'use strict'\n\nconst { isElectronMain } = require('./env')\n\nif (isElectronMain) {\n module.exports = require('electron-fetch')\n} else {\n// use window.fetch if it is available, fall back to node-fetch if not\n module.exports = require('native-fetch')\n}\n","'use strict'\n\nif (globalThis.fetch && globalThis.Headers && globalThis.Request && globalThis.Response) {\n module.exports = {\n default: globalThis.fetch,\n Headers: globalThis.Headers,\n Request: globalThis.Request,\n Response: globalThis.Response\n }\n} else {\n module.exports = {\n default: require('node-fetch').default,\n Headers: require('node-fetch').Headers,\n Request: require('node-fetch').Request,\n Response: require('node-fetch').Response\n }\n}\n","\"use strict\";\n\n// ref: https://github.com/tc39/proposal-global\nvar getGlobal = function () {\n\t// the only reliable means to get the global object is\n\t// `Function('return this')()`\n\t// However, this causes CSP violations in Chrome apps.\n\tif (typeof self !== 'undefined') { return self; }\n\tif (typeof window !== 'undefined') { return window; }\n\tif (typeof global !== 'undefined') { return global; }\n\tthrow new Error('unable to locate global object');\n}\n\nvar global = getGlobal();\n\nmodule.exports = exports = global.fetch;\n\n// Needed for TypeScript and Webpack.\nif (global.fetch) {\n\texports.default = global.fetch.bind(global);\n}\n\nexports.Headers = global.Headers;\nexports.Request = global.Request;\nexports.Response = global.Response;","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction createIsOnline({network}) {\n return () => {\n const net = network.try();\n return net != null && Boolean(net.libp2p.isStarted());\n };\n}\n\nexports.createIsOnline = createIsOnline;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar isIpfs = require('is-ipfs');\nvar cid = require('multiformats/cid');\nvar PeerId = require('peer-id');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar utils = require('../utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\n\nfunction createResolve({repo, codecs, bases, name}) {\n async function resolve(path, opts = {}) {\n if (!isIpfs__default['default'].path(path)) {\n throw new Error('invalid argument ' + path);\n }\n if (isIpfs__default['default'].ipnsPath(path)) {\n for await (const resolvedPath of name.resolve(path, opts)) {\n path = resolvedPath;\n }\n }\n const [, schema, hash, ...rest] = path.split('/');\n const base = opts.cidBase ? await bases.getBase(opts.cidBase) : undefined;\n const bytes = parseBytes(hash);\n if (rest.length === 0) {\n const str = base ? base.encoder.encode(bytes) : hash;\n return `/${ schema }/${ str }`;\n }\n const cid$1 = cid.CID.decode(bytes);\n path = rest.join('/');\n const results = utils.resolve(cid$1, path, codecs, repo, opts);\n let value = cid$1;\n let remainderPath = path;\n for await (const result of results) {\n if (cid.CID.asCID(result.value)) {\n value = result.value;\n remainderPath = result.remainderPath;\n }\n }\n return `/ipfs/${ value.toString(base && base.encoder) }${ remainderPath ? '/' + remainderPath : '' }`;\n }\n return withTimeoutOption.withTimeoutOption(resolve);\n}\nfunction parseBytes(str) {\n try {\n return PeerId__default['default'].parse(str).toBytes();\n } catch {\n return cid.CID.parse(str).bytes;\n }\n}\n\nexports.createResolve = createResolve;\n","/*\n * Id is an object representation of a peer Id. a peer Id is a multihash\n */\n\n'use strict'\n\nconst { CID } = require('multiformats/cid')\nconst b32 = require('multiformats/bases/base32')\nconst b36 = require('multiformats/bases/base36')\nconst b58 = require('multiformats/bases/base58')\nconst b64 = require('multiformats/bases/base64')\nconst { base58btc } = require('multiformats/bases/base58')\nconst { base32 } = require('multiformats/bases/base32')\nconst { base16 } = require('multiformats/bases/base16')\nconst Digest = require('multiformats/hashes/digest')\nconst cryptoKeys = require('libp2p-crypto/src/keys')\nconst withIs = require('class-is')\nconst { PeerIdProto } = require('./proto')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { identity } = require('multiformats/hashes/identity')\n\nconst bases = {\n ...b32,\n ...b36,\n ...b58,\n ...b64\n}\nconst baseDecoder = Object.keys(bases).reduce(\n (acc, curr) => acc.or(bases[curr]),\n base32.decoder\n)\n\n// these values are from https://github.com/multiformats/multicodec/blob/master/table.csv\nconst DAG_PB_CODE = 0x70\nconst LIBP2P_KEY_CODE = 0x72\n\nclass PeerId {\n constructor (id, privKey, pubKey) {\n if (!(id instanceof Uint8Array)) {\n throw new Error('invalid id provided')\n }\n\n if (privKey && pubKey && !uint8ArrayEquals(privKey.public.bytes, pubKey.bytes)) {\n throw new Error('inconsistent arguments')\n }\n\n this._id = id\n this._idB58String = base58btc.encode(this.id).substring(1)\n this._privKey = privKey\n this._pubKey = pubKey\n }\n\n get id () {\n return this._id\n }\n\n set id (val) {\n throw new Error('Id is immutable')\n }\n\n get privKey () {\n return this._privKey\n }\n\n set privKey (privKey) {\n this._privKey = privKey\n }\n\n get pubKey () {\n if (this._pubKey) {\n return this._pubKey\n }\n\n if (this._privKey) {\n return this._privKey.public\n }\n\n try {\n const decoded = Digest.decode(this.id)\n\n if (decoded.code === identity.code) {\n this._pubKey = cryptoKeys.unmarshalPublicKey(decoded.digest)\n }\n } catch (_) {\n // Ignore, there is no valid public key\n }\n\n return this._pubKey\n }\n\n set pubKey (pubKey) {\n this._pubKey = pubKey\n }\n\n // Return the protobuf version of the public key, matching go ipfs formatting\n marshalPubKey () {\n if (this.pubKey) {\n return cryptoKeys.marshalPublicKey(this.pubKey)\n }\n }\n\n // Return the protobuf version of the private key, matching go ipfs formatting\n marshalPrivKey () {\n if (this.privKey) {\n return cryptoKeys.marshalPrivateKey(this.privKey)\n }\n }\n\n // Return the protobuf version of the peer-id\n marshal (excludePriv) {\n return PeerIdProto.encode({\n id: this.toBytes(),\n pubKey: this.marshalPubKey(),\n privKey: excludePriv ? null : this.marshalPrivKey()\n }).finish()\n }\n\n toPrint () {\n let pid = this.toB58String()\n // All sha256 nodes start with Qm\n // We can skip the Qm to make the peer.ID more useful\n if (pid.startsWith('Qm')) {\n pid = pid.slice(2)\n }\n let maxRunes = 6\n if (pid.length < maxRunes) {\n maxRunes = pid.length\n }\n\n return '<peer.ID ' + pid.substr(0, maxRunes) + '>'\n }\n\n // return the jsonified version of the key, matching the formatting\n // of go-ipfs for its config file\n toJSON () {\n return {\n id: this.toB58String(),\n privKey: toB64Opt(this.marshalPrivKey()),\n pubKey: toB64Opt(this.marshalPubKey())\n }\n }\n\n // encode/decode functions\n toHexString () {\n return base16.encode(this.id).substring(1)\n }\n\n toBytes () {\n return this.id\n }\n\n toB58String () {\n return this._idB58String\n }\n\n // return self-describing String representation\n // in default format from RFC 0001: https://github.com/libp2p/specs/pull/209\n toString () {\n if (!this._idCIDString) {\n const cid = CID.createV1(LIBP2P_KEY_CODE, Digest.decode(this.id))\n\n Object.defineProperty(this, '_idCIDString', {\n value: cid.toString(),\n enumerable: false\n })\n }\n return this._idCIDString\n }\n\n /**\n * Checks the equality of `this` peer against a given PeerId.\n *\n * @param {Uint8Array|PeerId} id\n * @returns {boolean}\n */\n equals (id) {\n if (id instanceof Uint8Array) {\n return uint8ArrayEquals(this.id, id)\n } else if (id.id) {\n return uint8ArrayEquals(this.id, id.id)\n } else {\n throw new Error('not valid Id')\n }\n }\n\n /**\n * Checks the equality of `this` peer against a given PeerId.\n *\n * @deprecated Use `.equals`\n * @param {Uint8Array|PeerId} id\n * @returns {boolean}\n */\n isEqual (id) {\n return this.equals(id)\n }\n\n /*\n * Check if this PeerId instance is valid (privKey -> pubKey -> Id)\n */\n isValid () {\n // TODO: needs better checking\n return Boolean(this.privKey &&\n this.privKey.public &&\n this.privKey.public.bytes &&\n this.pubKey.bytes instanceof Uint8Array &&\n uint8ArrayEquals(this.privKey.public.bytes, this.pubKey.bytes))\n }\n\n /**\n * Check if the PeerId has an inline public key.\n *\n * @returns {boolean}\n */\n hasInlinePublicKey () {\n try {\n const decoded = Digest.decode(this.id)\n\n if (decoded.code === identity.code) {\n return true\n }\n } catch (_) {\n // Ignore, there is no valid public key\n }\n\n return false\n }\n}\n\nconst PeerIdWithIs = withIs(PeerId, {\n className: 'PeerId',\n symbolName: '@libp2p/js-peer-id/PeerId'\n})\n\nexports = module.exports = PeerIdWithIs\n\nconst computeDigest = (pubKey) => {\n if (pubKey.bytes.length <= 42) {\n return Digest.create(identity.code, pubKey.bytes).bytes\n } else {\n return pubKey.hash()\n }\n}\n\nconst computePeerId = async (privKey, pubKey) => {\n const digest = await computeDigest(pubKey)\n return new PeerIdWithIs(digest, privKey, pubKey)\n}\n\n// generation\nexports.create = async (opts) => {\n opts = opts || {}\n opts.bits = opts.bits || 2048\n opts.keyType = opts.keyType || 'RSA'\n\n const key = await cryptoKeys.generateKeyPair(opts.keyType, opts.bits)\n return computePeerId(key, key.public)\n}\n\nexports.createFromHexString = (str) => {\n return new PeerIdWithIs(base16.decode('f' + str))\n}\n\nexports.createFromBytes = (buf) => {\n try {\n const cid = CID.decode(buf)\n\n if (!validMulticodec(cid)) {\n throw new Error('Supplied PeerID CID is invalid')\n }\n\n return exports.createFromCID(cid)\n } catch {\n const digest = Digest.decode(buf)\n\n if (digest.code !== identity.code) {\n throw new Error('Supplied PeerID CID is invalid')\n }\n\n return new PeerIdWithIs(buf)\n }\n}\n\nexports.createFromB58String = (str) => {\n return exports.createFromBytes(base58btc.decode('z' + str))\n}\n\nconst validMulticodec = (cid) => {\n // supported: 'libp2p-key' (CIDv1) and 'dag-pb' (CIDv0 converted to CIDv1)\n return cid.code === LIBP2P_KEY_CODE || cid.code === DAG_PB_CODE\n}\n\nexports.createFromCID = (cid) => {\n cid = CID.asCID(cid)\n\n if (!cid || !validMulticodec(cid)) {\n throw new Error('Supplied PeerID CID is invalid')\n }\n\n return new PeerIdWithIs(cid.multihash.bytes)\n}\n\n// Public Key input will be a Uint8Array\nexports.createFromPubKey = async (key) => {\n let buf = key\n\n if (typeof buf === 'string') {\n buf = uint8ArrayFromString(key, 'base64pad')\n }\n\n if (!(buf instanceof Uint8Array)) {\n throw new Error('Supplied key is neither a base64 string nor a Uint8Array')\n }\n\n const pubKey = await cryptoKeys.unmarshalPublicKey(buf)\n return computePeerId(undefined, pubKey)\n}\n\n// Private key input will be a string\nexports.createFromPrivKey = async (key) => {\n if (typeof key === 'string') {\n key = uint8ArrayFromString(key, 'base64pad')\n }\n\n if (!(key instanceof Uint8Array)) {\n throw new Error('Supplied key is neither a base64 string nor a Uint8Array')\n }\n\n const privKey = await cryptoKeys.unmarshalPrivateKey(key)\n return computePeerId(privKey, privKey.public)\n}\n\nexports.createFromJSON = async (obj) => {\n const id = base58btc.decode('z' + obj.id)\n const rawPrivKey = obj.privKey && uint8ArrayFromString(obj.privKey, 'base64pad')\n const rawPubKey = obj.pubKey && uint8ArrayFromString(obj.pubKey, 'base64pad')\n const pub = rawPubKey && await cryptoKeys.unmarshalPublicKey(rawPubKey)\n\n if (!rawPrivKey) {\n return new PeerIdWithIs(id, undefined, pub)\n }\n\n const privKey = await cryptoKeys.unmarshalPrivateKey(rawPrivKey)\n const privDigest = await computeDigest(privKey.public)\n\n let pubDigest\n\n if (pub) {\n pubDigest = await computeDigest(pub)\n }\n\n if (pub && !uint8ArrayEquals(privDigest, pubDigest)) {\n throw new Error('Public and private key do not match')\n }\n\n if (id && !uint8ArrayEquals(privDigest, id)) {\n throw new Error('Id and private key do not match')\n }\n\n return new PeerIdWithIs(id, privKey, pub)\n}\n\nexports.createFromProtobuf = async (buf) => {\n if (typeof buf === 'string') {\n buf = uint8ArrayFromString(buf, 'base16')\n }\n\n let { id, privKey, pubKey } = PeerIdProto.decode(buf)\n\n privKey = privKey ? await cryptoKeys.unmarshalPrivateKey(privKey) : false\n pubKey = pubKey ? await cryptoKeys.unmarshalPublicKey(pubKey) : false\n\n let pubDigest\n let privDigest\n\n if (privKey) {\n privDigest = await computeDigest(privKey.public)\n }\n\n if (pubKey) {\n pubDigest = await computeDigest(pubKey)\n }\n\n if (privKey) {\n if (pubKey) {\n if (!uint8ArrayEquals(privDigest, pubDigest)) {\n throw new Error('Public and private key do not match')\n }\n }\n return new PeerIdWithIs(privDigest, privKey, privKey.public)\n }\n\n // TODO: val id and pubDigest\n\n if (pubKey) {\n return new PeerIdWithIs(pubDigest, undefined, pubKey)\n }\n\n if (id) {\n return new PeerIdWithIs(id)\n }\n\n throw new Error('Protobuf did not contain any usable key material')\n}\n\nexports.parse = (str) => {\n if (str.charAt(0) === '1' || str.charAt(0) === 'Q') {\n // identity hash ed25519 key or sha2-256 hash of rsa public key\n // base58btc encoded either way\n str = `z${str}`\n }\n\n return exports.createFromBytes(baseDecoder.decode(str))\n}\n\nexports.isPeerId = (peerId) => {\n return Boolean(typeof peerId === 'object' &&\n peerId._id &&\n peerId._idB58String)\n}\n\nfunction toB64Opt (val) {\n if (val) {\n return uint8ArrayToString(val, 'base64pad')\n }\n}\n","'use strict'\n\nconst keysPBM = require('./keys')\nrequire('node-forge/lib/asn1')\nrequire('node-forge/lib/pbe')\nconst forge = require('node-forge/lib/forge')\nconst errcode = require('err-code')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\nconst importer = require('./importer')\n\nconst supportedKeys = {\n rsa: require('./rsa-class'),\n ed25519: require('./ed25519-class'),\n secp256k1: require('./secp256k1-class')(keysPBM, require('../random-bytes'))\n}\n\nconst ErrMissingSecp256K1 = {\n message: 'secp256k1 support requires libp2p-crypto-secp256k1 package',\n code: 'ERR_MISSING_PACKAGE'\n}\n\nfunction typeToKey (type) {\n const key = supportedKeys[type.toLowerCase()]\n if (!key) {\n const supported = Object.keys(supportedKeys).join(' / ')\n throw errcode(new Error(`invalid or unsupported key type ${type}. Must be ${supported}`), 'ERR_UNSUPPORTED_KEY_TYPE')\n }\n return key\n}\n\n// Generates a keypair of the given type and bitsize\nconst generateKeyPair = async (type, bits) => { // eslint-disable-line require-await\n return typeToKey(type).generateKeyPair(bits)\n}\n\n// Generates a keypair of the given type and bitsize\n// seed is a 32 byte uint8array\nconst generateKeyPairFromSeed = async (type, seed, bits) => { // eslint-disable-line require-await\n const key = typeToKey(type)\n if (type.toLowerCase() !== 'ed25519') {\n throw errcode(new Error('Seed key derivation is unimplemented for RSA or secp256k1'), 'ERR_UNSUPPORTED_KEY_DERIVATION_TYPE')\n }\n return key.generateKeyPairFromSeed(seed, bits)\n}\n\n// Converts a protobuf serialized public key into its\n// representative object\nconst unmarshalPublicKey = (buf) => {\n const decoded = keysPBM.PublicKey.decode(buf)\n const data = decoded.Data\n\n switch (decoded.Type) {\n case keysPBM.KeyType.RSA:\n return supportedKeys.rsa.unmarshalRsaPublicKey(data)\n case keysPBM.KeyType.Ed25519:\n return supportedKeys.ed25519.unmarshalEd25519PublicKey(data)\n case keysPBM.KeyType.Secp256k1:\n if (supportedKeys.secp256k1) {\n return supportedKeys.secp256k1.unmarshalSecp256k1PublicKey(data)\n } else {\n throw errcode(new Error(ErrMissingSecp256K1.message), ErrMissingSecp256K1.code)\n }\n default:\n typeToKey(decoded.Type) // throws because type is not supported\n }\n}\n\n// Converts a public key object into a protobuf serialized public key\nconst marshalPublicKey = (key, type) => {\n type = (type || 'rsa').toLowerCase()\n typeToKey(type) // check type\n return key.bytes\n}\n\n// Converts a protobuf serialized private key into its\n// representative object\nconst unmarshalPrivateKey = async (buf) => { // eslint-disable-line require-await\n const decoded = keysPBM.PrivateKey.decode(buf)\n const data = decoded.Data\n\n switch (decoded.Type) {\n case keysPBM.KeyType.RSA:\n return supportedKeys.rsa.unmarshalRsaPrivateKey(data)\n case keysPBM.KeyType.Ed25519:\n return supportedKeys.ed25519.unmarshalEd25519PrivateKey(data)\n case keysPBM.KeyType.Secp256k1:\n if (supportedKeys.secp256k1) {\n return supportedKeys.secp256k1.unmarshalSecp256k1PrivateKey(data)\n } else {\n throw errcode(new Error(ErrMissingSecp256K1.message), ErrMissingSecp256K1.code)\n }\n default:\n typeToKey(decoded.Type) // throws because type is not supported\n }\n}\n\n// Converts a private key object into a protobuf serialized private key\nconst marshalPrivateKey = (key, type) => {\n type = (type || 'rsa').toLowerCase()\n typeToKey(type) // check type\n return key.bytes\n}\n\n/**\n *\n * @param {string} encryptedKey\n * @param {string} password\n */\nconst importKey = async (encryptedKey, password) => { // eslint-disable-line require-await\n try {\n const key = await importer.import(encryptedKey, password)\n return unmarshalPrivateKey(key)\n } catch (_) {\n // Ignore and try the old pem decrypt\n }\n\n // Only rsa supports pem right now\n const key = forge.pki.decryptRsaPrivateKey(encryptedKey, password)\n if (key === null) {\n throw errcode(new Error('Cannot read the key, most likely the password is wrong or not a RSA key'), 'ERR_CANNOT_DECRYPT_PEM')\n }\n let der = forge.asn1.toDer(forge.pki.privateKeyToAsn1(key))\n der = uint8ArrayFromString(der.getBytes(), 'ascii')\n return supportedKeys.rsa.unmarshalRsaPrivateKey(der)\n}\n\nmodule.exports = {\n supportedKeys,\n keysPBM,\n keyStretcher: require('./key-stretcher'),\n generateEphemeralKeyPair: require('./ephemeral-keys'),\n generateKeyPair,\n generateKeyPairFromSeed,\n unmarshalPublicKey,\n marshalPublicKey,\n unmarshalPrivateKey,\n marshalPrivateKey,\n import: importKey\n}\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-crypto-keys\"] || ($protobuf.roots[\"libp2p-crypto-keys\"] = {});\n\n/**\n * KeyType enum.\n * @exports KeyType\n * @enum {number}\n * @property {number} RSA=0 RSA value\n * @property {number} Ed25519=1 Ed25519 value\n * @property {number} Secp256k1=2 Secp256k1 value\n */\n$root.KeyType = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = \"RSA\"] = 0;\n values[valuesById[1] = \"Ed25519\"] = 1;\n values[valuesById[2] = \"Secp256k1\"] = 2;\n return values;\n})();\n\n$root.PublicKey = (function() {\n\n /**\n * Properties of a PublicKey.\n * @exports IPublicKey\n * @interface IPublicKey\n * @property {KeyType} Type PublicKey Type\n * @property {Uint8Array} Data PublicKey Data\n */\n\n /**\n * Constructs a new PublicKey.\n * @exports PublicKey\n * @classdesc Represents a PublicKey.\n * @implements IPublicKey\n * @constructor\n * @param {IPublicKey=} [p] Properties to set\n */\n function PublicKey(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * PublicKey Type.\n * @member {KeyType} Type\n * @memberof PublicKey\n * @instance\n */\n PublicKey.prototype.Type = 0;\n\n /**\n * PublicKey Data.\n * @member {Uint8Array} Data\n * @memberof PublicKey\n * @instance\n */\n PublicKey.prototype.Data = $util.newBuffer([]);\n\n /**\n * Encodes the specified PublicKey message. Does not implicitly {@link PublicKey.verify|verify} messages.\n * @function encode\n * @memberof PublicKey\n * @static\n * @param {IPublicKey} m PublicKey message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PublicKey.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(8).int32(m.Type);\n w.uint32(18).bytes(m.Data);\n return w;\n };\n\n /**\n * Decodes a PublicKey message from the specified reader or buffer.\n * @function decode\n * @memberof PublicKey\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PublicKey} PublicKey\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PublicKey.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PublicKey();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.Type = r.int32();\n break;\n case 2:\n m.Data = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty(\"Type\"))\n throw $util.ProtocolError(\"missing required 'Type'\", { instance: m });\n if (!m.hasOwnProperty(\"Data\"))\n throw $util.ProtocolError(\"missing required 'Data'\", { instance: m });\n return m;\n };\n\n /**\n * Creates a PublicKey message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PublicKey\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {PublicKey} PublicKey\n */\n PublicKey.fromObject = function fromObject(d) {\n if (d instanceof $root.PublicKey)\n return d;\n var m = new $root.PublicKey();\n switch (d.Type) {\n case \"RSA\":\n case 0:\n m.Type = 0;\n break;\n case \"Ed25519\":\n case 1:\n m.Type = 1;\n break;\n case \"Secp256k1\":\n case 2:\n m.Type = 2;\n break;\n }\n if (d.Data != null) {\n if (typeof d.Data === \"string\")\n $util.base64.decode(d.Data, m.Data = $util.newBuffer($util.base64.length(d.Data)), 0);\n else if (d.Data.length)\n m.Data = d.Data;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a PublicKey message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PublicKey\n * @static\n * @param {PublicKey} m PublicKey\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n PublicKey.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.Type = o.enums === String ? \"RSA\" : 0;\n if (o.bytes === String)\n d.Data = \"\";\n else {\n d.Data = [];\n if (o.bytes !== Array)\n d.Data = $util.newBuffer(d.Data);\n }\n }\n if (m.Type != null && m.hasOwnProperty(\"Type\")) {\n d.Type = o.enums === String ? $root.KeyType[m.Type] : m.Type;\n }\n if (m.Data != null && m.hasOwnProperty(\"Data\")) {\n d.Data = o.bytes === String ? $util.base64.encode(m.Data, 0, m.Data.length) : o.bytes === Array ? Array.prototype.slice.call(m.Data) : m.Data;\n }\n return d;\n };\n\n /**\n * Converts this PublicKey to JSON.\n * @function toJSON\n * @memberof PublicKey\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n PublicKey.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return PublicKey;\n})();\n\n$root.PrivateKey = (function() {\n\n /**\n * Properties of a PrivateKey.\n * @exports IPrivateKey\n * @interface IPrivateKey\n * @property {KeyType} Type PrivateKey Type\n * @property {Uint8Array} Data PrivateKey Data\n */\n\n /**\n * Constructs a new PrivateKey.\n * @exports PrivateKey\n * @classdesc Represents a PrivateKey.\n * @implements IPrivateKey\n * @constructor\n * @param {IPrivateKey=} [p] Properties to set\n */\n function PrivateKey(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * PrivateKey Type.\n * @member {KeyType} Type\n * @memberof PrivateKey\n * @instance\n */\n PrivateKey.prototype.Type = 0;\n\n /**\n * PrivateKey Data.\n * @member {Uint8Array} Data\n * @memberof PrivateKey\n * @instance\n */\n PrivateKey.prototype.Data = $util.newBuffer([]);\n\n /**\n * Encodes the specified PrivateKey message. Does not implicitly {@link PrivateKey.verify|verify} messages.\n * @function encode\n * @memberof PrivateKey\n * @static\n * @param {IPrivateKey} m PrivateKey message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PrivateKey.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(8).int32(m.Type);\n w.uint32(18).bytes(m.Data);\n return w;\n };\n\n /**\n * Decodes a PrivateKey message from the specified reader or buffer.\n * @function decode\n * @memberof PrivateKey\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PrivateKey} PrivateKey\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PrivateKey.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PrivateKey();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.Type = r.int32();\n break;\n case 2:\n m.Data = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty(\"Type\"))\n throw $util.ProtocolError(\"missing required 'Type'\", { instance: m });\n if (!m.hasOwnProperty(\"Data\"))\n throw $util.ProtocolError(\"missing required 'Data'\", { instance: m });\n return m;\n };\n\n /**\n * Creates a PrivateKey message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PrivateKey\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {PrivateKey} PrivateKey\n */\n PrivateKey.fromObject = function fromObject(d) {\n if (d instanceof $root.PrivateKey)\n return d;\n var m = new $root.PrivateKey();\n switch (d.Type) {\n case \"RSA\":\n case 0:\n m.Type = 0;\n break;\n case \"Ed25519\":\n case 1:\n m.Type = 1;\n break;\n case \"Secp256k1\":\n case 2:\n m.Type = 2;\n break;\n }\n if (d.Data != null) {\n if (typeof d.Data === \"string\")\n $util.base64.decode(d.Data, m.Data = $util.newBuffer($util.base64.length(d.Data)), 0);\n else if (d.Data.length)\n m.Data = d.Data;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a PrivateKey message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PrivateKey\n * @static\n * @param {PrivateKey} m PrivateKey\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n PrivateKey.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.Type = o.enums === String ? \"RSA\" : 0;\n if (o.bytes === String)\n d.Data = \"\";\n else {\n d.Data = [];\n if (o.bytes !== Array)\n d.Data = $util.newBuffer(d.Data);\n }\n }\n if (m.Type != null && m.hasOwnProperty(\"Type\")) {\n d.Type = o.enums === String ? $root.KeyType[m.Type] : m.Type;\n }\n if (m.Data != null && m.hasOwnProperty(\"Data\")) {\n d.Data = o.bytes === String ? $util.base64.encode(m.Data, 0, m.Data.length) : o.bytes === Array ? Array.prototype.slice.call(m.Data) : m.Data;\n }\n return d;\n };\n\n /**\n * Converts this PrivateKey to JSON.\n * @function toJSON\n * @memberof PrivateKey\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n PrivateKey.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return PrivateKey;\n})();\n\nmodule.exports = $root;\n","/**\n * Javascript implementation of Abstract Syntax Notation Number One.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n *\n * An API for storing data using the Abstract Syntax Notation Number One\n * format using DER (Distinguished Encoding Rules) encoding. This encoding is\n * commonly used to store data for PKI, i.e. X.509 Certificates, and this\n * implementation exists for that purpose.\n *\n * Abstract Syntax Notation Number One (ASN.1) is used to define the abstract\n * syntax of information without restricting the way the information is encoded\n * for transmission. It provides a standard that allows for open systems\n * communication. ASN.1 defines the syntax of information data and a number of\n * simple data types as well as a notation for describing them and specifying\n * values for them.\n *\n * The RSA algorithm creates public and private keys that are often stored in\n * X.509 or PKCS#X formats -- which use ASN.1 (encoded in DER format). This\n * class provides the most basic functionality required to store and load DSA\n * keys that are encoded according to ASN.1.\n *\n * The most common binary encodings for ASN.1 are BER (Basic Encoding Rules)\n * and DER (Distinguished Encoding Rules). DER is just a subset of BER that\n * has stricter requirements for how data must be encoded.\n *\n * Each ASN.1 structure has a tag (a byte identifying the ASN.1 structure type)\n * and a byte array for the value of this ASN1 structure which may be data or a\n * list of ASN.1 structures.\n *\n * Each ASN.1 structure using BER is (Tag-Length-Value):\n *\n * | byte 0 | bytes X | bytes Y |\n * |--------|---------|----------\n * | tag | length | value |\n *\n * ASN.1 allows for tags to be of \"High-tag-number form\" which allows a tag to\n * be two or more octets, but that is not supported by this class. A tag is\n * only 1 byte. Bits 1-5 give the tag number (ie the data type within a\n * particular 'class'), 6 indicates whether or not the ASN.1 value is\n * constructed from other ASN.1 values, and bits 7 and 8 give the 'class'. If\n * bits 7 and 8 are both zero, the class is UNIVERSAL. If only bit 7 is set,\n * then the class is APPLICATION. If only bit 8 is set, then the class is\n * CONTEXT_SPECIFIC. If both bits 7 and 8 are set, then the class is PRIVATE.\n * The tag numbers for the data types for the class UNIVERSAL are listed below:\n *\n * UNIVERSAL 0 Reserved for use by the encoding rules\n * UNIVERSAL 1 Boolean type\n * UNIVERSAL 2 Integer type\n * UNIVERSAL 3 Bitstring type\n * UNIVERSAL 4 Octetstring type\n * UNIVERSAL 5 Null type\n * UNIVERSAL 6 Object identifier type\n * UNIVERSAL 7 Object descriptor type\n * UNIVERSAL 8 External type and Instance-of type\n * UNIVERSAL 9 Real type\n * UNIVERSAL 10 Enumerated type\n * UNIVERSAL 11 Embedded-pdv type\n * UNIVERSAL 12 UTF8String type\n * UNIVERSAL 13 Relative object identifier type\n * UNIVERSAL 14-15 Reserved for future editions\n * UNIVERSAL 16 Sequence and Sequence-of types\n * UNIVERSAL 17 Set and Set-of types\n * UNIVERSAL 18-22, 25-30 Character string types\n * UNIVERSAL 23-24 Time types\n *\n * The length of an ASN.1 structure is specified after the tag identifier.\n * There is a definite form and an indefinite form. The indefinite form may\n * be used if the encoding is constructed and not all immediately available.\n * The indefinite form is encoded using a length byte with only the 8th bit\n * set. The end of the constructed object is marked using end-of-contents\n * octets (two zero bytes).\n *\n * The definite form looks like this:\n *\n * The length may take up 1 or more bytes, it depends on the length of the\n * value of the ASN.1 structure. DER encoding requires that if the ASN.1\n * structure has a value that has a length greater than 127, more than 1 byte\n * will be used to store its length, otherwise just one byte will be used.\n * This is strict.\n *\n * In the case that the length of the ASN.1 value is less than 127, 1 octet\n * (byte) is used to store the \"short form\" length. The 8th bit has a value of\n * 0 indicating the length is \"short form\" and not \"long form\" and bits 7-1\n * give the length of the data. (The 8th bit is the left-most, most significant\n * bit: also known as big endian or network format).\n *\n * In the case that the length of the ASN.1 value is greater than 127, 2 to\n * 127 octets (bytes) are used to store the \"long form\" length. The first\n * byte's 8th bit is set to 1 to indicate the length is \"long form.\" Bits 7-1\n * give the number of additional octets. All following octets are in base 256\n * with the most significant digit first (typical big-endian binary unsigned\n * integer storage). So, for instance, if the length of a value was 257, the\n * first byte would be set to:\n *\n * 10000010 = 130 = 0x82.\n *\n * This indicates there are 2 octets (base 256) for the length. The second and\n * third bytes (the octets just mentioned) would store the length in base 256:\n *\n * octet 2: 00000001 = 1 * 256^1 = 256\n * octet 3: 00000001 = 1 * 256^0 = 1\n * total = 257\n *\n * The algorithm for converting a js integer value of 257 to base-256 is:\n *\n * var value = 257;\n * var bytes = [];\n * bytes[0] = (value >>> 8) & 0xFF; // most significant byte first\n * bytes[1] = value & 0xFF; // least significant byte last\n *\n * On the ASN.1 UNIVERSAL Object Identifier (OID) type:\n *\n * An OID can be written like: \"value1.value2.value3...valueN\"\n *\n * The DER encoding rules:\n *\n * The first byte has the value 40 * value1 + value2.\n * The following bytes, if any, encode the remaining values. Each value is\n * encoded in base 128, most significant digit first (big endian), with as\n * few digits as possible, and the most significant bit of each byte set\n * to 1 except the last in each value's encoding. For example: Given the\n * OID \"1.2.840.113549\", its DER encoding is (remember each byte except the\n * last one in each encoding is OR'd with 0x80):\n *\n * byte 1: 40 * 1 + 2 = 42 = 0x2A.\n * bytes 2-3: 128 * 6 + 72 = 840 = 6 72 = 6 72 = 0x0648 = 0x8648\n * bytes 4-6: 16384 * 6 + 128 * 119 + 13 = 6 119 13 = 0x06770D = 0x86F70D\n *\n * The final value is: 0x2A864886F70D.\n * The full OID (including ASN.1 tag and length of 6 bytes) is:\n * 0x06062A864886F70D\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./oids');\n\n/* ASN.1 API */\nvar asn1 = module.exports = forge.asn1 = forge.asn1 || {};\n\n/**\n * ASN.1 classes.\n */\nasn1.Class = {\n UNIVERSAL: 0x00,\n APPLICATION: 0x40,\n CONTEXT_SPECIFIC: 0x80,\n PRIVATE: 0xC0\n};\n\n/**\n * ASN.1 types. Not all types are supported by this implementation, only\n * those necessary to implement a simple PKI are implemented.\n */\nasn1.Type = {\n NONE: 0,\n BOOLEAN: 1,\n INTEGER: 2,\n BITSTRING: 3,\n OCTETSTRING: 4,\n NULL: 5,\n OID: 6,\n ODESC: 7,\n EXTERNAL: 8,\n REAL: 9,\n ENUMERATED: 10,\n EMBEDDED: 11,\n UTF8: 12,\n ROID: 13,\n SEQUENCE: 16,\n SET: 17,\n PRINTABLESTRING: 19,\n IA5STRING: 22,\n UTCTIME: 23,\n GENERALIZEDTIME: 24,\n BMPSTRING: 30\n};\n\n/**\n * Creates a new asn1 object.\n *\n * @param tagClass the tag class for the object.\n * @param type the data type (tag number) for the object.\n * @param constructed true if the asn1 object is in constructed form.\n * @param value the value for the object, if it is not constructed.\n * @param [options] the options to use:\n * [bitStringContents] the plain BIT STRING content including padding\n * byte.\n *\n * @return the asn1 object.\n */\nasn1.create = function(tagClass, type, constructed, value, options) {\n /* An asn1 object has a tagClass, a type, a constructed flag, and a\n value. The value's type depends on the constructed flag. If\n constructed, it will contain a list of other asn1 objects. If not,\n it will contain the ASN.1 value as an array of bytes formatted\n according to the ASN.1 data type. */\n\n // remove undefined values\n if(forge.util.isArray(value)) {\n var tmp = [];\n for(var i = 0; i < value.length; ++i) {\n if(value[i] !== undefined) {\n tmp.push(value[i]);\n }\n }\n value = tmp;\n }\n\n var obj = {\n tagClass: tagClass,\n type: type,\n constructed: constructed,\n composed: constructed || forge.util.isArray(value),\n value: value\n };\n if(options && 'bitStringContents' in options) {\n // TODO: copy byte buffer if it's a buffer not a string\n obj.bitStringContents = options.bitStringContents;\n // TODO: add readonly flag to avoid this overhead\n // save copy to detect changes\n obj.original = asn1.copy(obj);\n }\n return obj;\n};\n\n/**\n * Copies an asn1 object.\n *\n * @param obj the asn1 object.\n * @param [options] copy options:\n * [excludeBitStringContents] true to not copy bitStringContents\n *\n * @return the a copy of the asn1 object.\n */\nasn1.copy = function(obj, options) {\n var copy;\n\n if(forge.util.isArray(obj)) {\n copy = [];\n for(var i = 0; i < obj.length; ++i) {\n copy.push(asn1.copy(obj[i], options));\n }\n return copy;\n }\n\n if(typeof obj === 'string') {\n // TODO: copy byte buffer if it's a buffer not a string\n return obj;\n }\n\n copy = {\n tagClass: obj.tagClass,\n type: obj.type,\n constructed: obj.constructed,\n composed: obj.composed,\n value: asn1.copy(obj.value, options)\n };\n if(options && !options.excludeBitStringContents) {\n // TODO: copy byte buffer if it's a buffer not a string\n copy.bitStringContents = obj.bitStringContents;\n }\n return copy;\n};\n\n/**\n * Compares asn1 objects for equality.\n *\n * Note this function does not run in constant time.\n *\n * @param obj1 the first asn1 object.\n * @param obj2 the second asn1 object.\n * @param [options] compare options:\n * [includeBitStringContents] true to compare bitStringContents\n *\n * @return true if the asn1 objects are equal.\n */\nasn1.equals = function(obj1, obj2, options) {\n if(forge.util.isArray(obj1)) {\n if(!forge.util.isArray(obj2)) {\n return false;\n }\n if(obj1.length !== obj2.length) {\n return false;\n }\n for(var i = 0; i < obj1.length; ++i) {\n if(!asn1.equals(obj1[i], obj2[i])) {\n return false;\n }\n }\n return true;\n }\n\n if(typeof obj1 !== typeof obj2) {\n return false;\n }\n\n if(typeof obj1 === 'string') {\n return obj1 === obj2;\n }\n\n var equal = obj1.tagClass === obj2.tagClass &&\n obj1.type === obj2.type &&\n obj1.constructed === obj2.constructed &&\n obj1.composed === obj2.composed &&\n asn1.equals(obj1.value, obj2.value);\n if(options && options.includeBitStringContents) {\n equal = equal && (obj1.bitStringContents === obj2.bitStringContents);\n }\n\n return equal;\n};\n\n/**\n * Gets the length of a BER-encoded ASN.1 value.\n *\n * In case the length is not specified, undefined is returned.\n *\n * @param b the BER-encoded ASN.1 byte buffer, starting with the first\n * length byte.\n *\n * @return the length of the BER-encoded ASN.1 value or undefined.\n */\nasn1.getBerValueLength = function(b) {\n // TODO: move this function and related DER/BER functions to a der.js\n // file; better abstract ASN.1 away from der/ber.\n var b2 = b.getByte();\n if(b2 === 0x80) {\n return undefined;\n }\n\n // see if the length is \"short form\" or \"long form\" (bit 8 set)\n var length;\n var longForm = b2 & 0x80;\n if(!longForm) {\n // length is just the first byte\n length = b2;\n } else {\n // the number of bytes the length is specified in bits 7 through 1\n // and each length byte is in big-endian base-256\n length = b.getInt((b2 & 0x7F) << 3);\n }\n return length;\n};\n\n/**\n * Check if the byte buffer has enough bytes. Throws an Error if not.\n *\n * @param bytes the byte buffer to parse from.\n * @param remaining the bytes remaining in the current parsing state.\n * @param n the number of bytes the buffer must have.\n */\nfunction _checkBufferLength(bytes, remaining, n) {\n if(n > remaining) {\n var error = new Error('Too few bytes to parse DER.');\n error.available = bytes.length();\n error.remaining = remaining;\n error.requested = n;\n throw error;\n }\n}\n\n/**\n * Gets the length of a BER-encoded ASN.1 value.\n *\n * In case the length is not specified, undefined is returned.\n *\n * @param bytes the byte buffer to parse from.\n * @param remaining the bytes remaining in the current parsing state.\n *\n * @return the length of the BER-encoded ASN.1 value or undefined.\n */\nvar _getValueLength = function(bytes, remaining) {\n // TODO: move this function and related DER/BER functions to a der.js\n // file; better abstract ASN.1 away from der/ber.\n // fromDer already checked that this byte exists\n var b2 = bytes.getByte();\n remaining--;\n if(b2 === 0x80) {\n return undefined;\n }\n\n // see if the length is \"short form\" or \"long form\" (bit 8 set)\n var length;\n var longForm = b2 & 0x80;\n if(!longForm) {\n // length is just the first byte\n length = b2;\n } else {\n // the number of bytes the length is specified in bits 7 through 1\n // and each length byte is in big-endian base-256\n var longFormBytes = b2 & 0x7F;\n _checkBufferLength(bytes, remaining, longFormBytes);\n length = bytes.getInt(longFormBytes << 3);\n }\n // FIXME: this will only happen for 32 bit getInt with high bit set\n if(length < 0) {\n throw new Error('Negative length: ' + length);\n }\n return length;\n};\n\n/**\n * Parses an asn1 object from a byte buffer in DER format.\n *\n * @param bytes the byte buffer to parse from.\n * @param [strict] true to be strict when checking value lengths, false to\n * allow truncated values (default: true).\n * @param [options] object with options or boolean strict flag\n * [strict] true to be strict when checking value lengths, false to\n * allow truncated values (default: true).\n * [decodeBitStrings] true to attempt to decode the content of\n * BIT STRINGs (not OCTET STRINGs) using strict mode. Note that\n * without schema support to understand the data context this can\n * erroneously decode values that happen to be valid ASN.1. This\n * flag will be deprecated or removed as soon as schema support is\n * available. (default: true)\n *\n * @return the parsed asn1 object.\n */\nasn1.fromDer = function(bytes, options) {\n if(options === undefined) {\n options = {\n strict: true,\n decodeBitStrings: true\n };\n }\n if(typeof options === 'boolean') {\n options = {\n strict: options,\n decodeBitStrings: true\n };\n }\n if(!('strict' in options)) {\n options.strict = true;\n }\n if(!('decodeBitStrings' in options)) {\n options.decodeBitStrings = true;\n }\n\n // wrap in buffer if needed\n if(typeof bytes === 'string') {\n bytes = forge.util.createBuffer(bytes);\n }\n\n return _fromDer(bytes, bytes.length(), 0, options);\n};\n\n/**\n * Internal function to parse an asn1 object from a byte buffer in DER format.\n *\n * @param bytes the byte buffer to parse from.\n * @param remaining the number of bytes remaining for this chunk.\n * @param depth the current parsing depth.\n * @param options object with same options as fromDer().\n *\n * @return the parsed asn1 object.\n */\nfunction _fromDer(bytes, remaining, depth, options) {\n // temporary storage for consumption calculations\n var start;\n\n // minimum length for ASN.1 DER structure is 2\n _checkBufferLength(bytes, remaining, 2);\n\n // get the first byte\n var b1 = bytes.getByte();\n // consumed one byte\n remaining--;\n\n // get the tag class\n var tagClass = (b1 & 0xC0);\n\n // get the type (bits 1-5)\n var type = b1 & 0x1F;\n\n // get the variable value length and adjust remaining bytes\n start = bytes.length();\n var length = _getValueLength(bytes, remaining);\n remaining -= start - bytes.length();\n\n // ensure there are enough bytes to get the value\n if(length !== undefined && length > remaining) {\n if(options.strict) {\n var error = new Error('Too few bytes to read ASN.1 value.');\n error.available = bytes.length();\n error.remaining = remaining;\n error.requested = length;\n throw error;\n }\n // Note: be lenient with truncated values and use remaining state bytes\n length = remaining;\n }\n\n // value storage\n var value;\n // possible BIT STRING contents storage\n var bitStringContents;\n\n // constructed flag is bit 6 (32 = 0x20) of the first byte\n var constructed = ((b1 & 0x20) === 0x20);\n if(constructed) {\n // parse child asn1 objects from the value\n value = [];\n if(length === undefined) {\n // asn1 object of indefinite length, read until end tag\n for(;;) {\n _checkBufferLength(bytes, remaining, 2);\n if(bytes.bytes(2) === String.fromCharCode(0, 0)) {\n bytes.getBytes(2);\n remaining -= 2;\n break;\n }\n start = bytes.length();\n value.push(_fromDer(bytes, remaining, depth + 1, options));\n remaining -= start - bytes.length();\n }\n } else {\n // parsing asn1 object of definite length\n while(length > 0) {\n start = bytes.length();\n value.push(_fromDer(bytes, length, depth + 1, options));\n remaining -= start - bytes.length();\n length -= start - bytes.length();\n }\n }\n }\n\n // if a BIT STRING, save the contents including padding\n if(value === undefined && tagClass === asn1.Class.UNIVERSAL &&\n type === asn1.Type.BITSTRING) {\n bitStringContents = bytes.bytes(length);\n }\n\n // determine if a non-constructed value should be decoded as a composed\n // value that contains other ASN.1 objects. BIT STRINGs (and OCTET STRINGs)\n // can be used this way.\n if(value === undefined && options.decodeBitStrings &&\n tagClass === asn1.Class.UNIVERSAL &&\n // FIXME: OCTET STRINGs not yet supported here\n // .. other parts of forge expect to decode OCTET STRINGs manually\n (type === asn1.Type.BITSTRING /*|| type === asn1.Type.OCTETSTRING*/) &&\n length > 1) {\n // save read position\n var savedRead = bytes.read;\n var savedRemaining = remaining;\n var unused = 0;\n if(type === asn1.Type.BITSTRING) {\n /* The first octet gives the number of bits by which the length of the\n bit string is less than the next multiple of eight (this is called\n the \"number of unused bits\").\n\n The second and following octets give the value of the bit string\n converted to an octet string. */\n _checkBufferLength(bytes, remaining, 1);\n unused = bytes.getByte();\n remaining--;\n }\n // if all bits are used, maybe the BIT/OCTET STRING holds ASN.1 objs\n if(unused === 0) {\n try {\n // attempt to parse child asn1 object from the value\n // (stored in array to signal composed value)\n start = bytes.length();\n var subOptions = {\n // enforce strict mode to avoid parsing ASN.1 from plain data\n verbose: options.verbose,\n strict: true,\n decodeBitStrings: true\n };\n var composed = _fromDer(bytes, remaining, depth + 1, subOptions);\n var used = start - bytes.length();\n remaining -= used;\n if(type == asn1.Type.BITSTRING) {\n used++;\n }\n\n // if the data all decoded and the class indicates UNIVERSAL or\n // CONTEXT_SPECIFIC then assume we've got an encapsulated ASN.1 object\n var tc = composed.tagClass;\n if(used === length &&\n (tc === asn1.Class.UNIVERSAL || tc === asn1.Class.CONTEXT_SPECIFIC)) {\n value = [composed];\n }\n } catch(ex) {\n }\n }\n if(value === undefined) {\n // restore read position\n bytes.read = savedRead;\n remaining = savedRemaining;\n }\n }\n\n if(value === undefined) {\n // asn1 not constructed or composed, get raw value\n // TODO: do DER to OID conversion and vice-versa in .toDer?\n\n if(length === undefined) {\n if(options.strict) {\n throw new Error('Non-constructed ASN.1 object of indefinite length.');\n }\n // be lenient and use remaining state bytes\n length = remaining;\n }\n\n if(type === asn1.Type.BMPSTRING) {\n value = '';\n for(; length > 0; length -= 2) {\n _checkBufferLength(bytes, remaining, 2);\n value += String.fromCharCode(bytes.getInt16());\n remaining -= 2;\n }\n } else {\n value = bytes.getBytes(length);\n }\n }\n\n // add BIT STRING contents if available\n var asn1Options = bitStringContents === undefined ? null : {\n bitStringContents: bitStringContents\n };\n\n // create and return asn1 object\n return asn1.create(tagClass, type, constructed, value, asn1Options);\n}\n\n/**\n * Converts the given asn1 object to a buffer of bytes in DER format.\n *\n * @param asn1 the asn1 object to convert to bytes.\n *\n * @return the buffer of bytes.\n */\nasn1.toDer = function(obj) {\n var bytes = forge.util.createBuffer();\n\n // build the first byte\n var b1 = obj.tagClass | obj.type;\n\n // for storing the ASN.1 value\n var value = forge.util.createBuffer();\n\n // use BIT STRING contents if available and data not changed\n var useBitStringContents = false;\n if('bitStringContents' in obj) {\n useBitStringContents = true;\n if(obj.original) {\n useBitStringContents = asn1.equals(obj, obj.original);\n }\n }\n\n if(useBitStringContents) {\n value.putBytes(obj.bitStringContents);\n } else if(obj.composed) {\n // if composed, use each child asn1 object's DER bytes as value\n // turn on 6th bit (0x20 = 32) to indicate asn1 is constructed\n // from other asn1 objects\n if(obj.constructed) {\n b1 |= 0x20;\n } else {\n // type is a bit string, add unused bits of 0x00\n value.putByte(0x00);\n }\n\n // add all of the child DER bytes together\n for(var i = 0; i < obj.value.length; ++i) {\n if(obj.value[i] !== undefined) {\n value.putBuffer(asn1.toDer(obj.value[i]));\n }\n }\n } else {\n // use asn1.value directly\n if(obj.type === asn1.Type.BMPSTRING) {\n for(var i = 0; i < obj.value.length; ++i) {\n value.putInt16(obj.value.charCodeAt(i));\n }\n } else {\n // ensure integer is minimally-encoded\n // TODO: should all leading bytes be stripped vs just one?\n // .. ex '00 00 01' => '01'?\n if(obj.type === asn1.Type.INTEGER &&\n obj.value.length > 1 &&\n // leading 0x00 for positive integer\n ((obj.value.charCodeAt(0) === 0 &&\n (obj.value.charCodeAt(1) & 0x80) === 0) ||\n // leading 0xFF for negative integer\n (obj.value.charCodeAt(0) === 0xFF &&\n (obj.value.charCodeAt(1) & 0x80) === 0x80))) {\n value.putBytes(obj.value.substr(1));\n } else {\n value.putBytes(obj.value);\n }\n }\n }\n\n // add tag byte\n bytes.putByte(b1);\n\n // use \"short form\" encoding\n if(value.length() <= 127) {\n // one byte describes the length\n // bit 8 = 0 and bits 7-1 = length\n bytes.putByte(value.length() & 0x7F);\n } else {\n // use \"long form\" encoding\n // 2 to 127 bytes describe the length\n // first byte: bit 8 = 1 and bits 7-1 = # of additional bytes\n // other bytes: length in base 256, big-endian\n var len = value.length();\n var lenBytes = '';\n do {\n lenBytes += String.fromCharCode(len & 0xFF);\n len = len >>> 8;\n } while(len > 0);\n\n // set first byte to # bytes used to store the length and turn on\n // bit 8 to indicate long-form length is used\n bytes.putByte(lenBytes.length | 0x80);\n\n // concatenate length bytes in reverse since they were generated\n // little endian and we need big endian\n for(var i = lenBytes.length - 1; i >= 0; --i) {\n bytes.putByte(lenBytes.charCodeAt(i));\n }\n }\n\n // concatenate value bytes\n bytes.putBuffer(value);\n return bytes;\n};\n\n/**\n * Converts an OID dot-separated string to a byte buffer. The byte buffer\n * contains only the DER-encoded value, not any tag or length bytes.\n *\n * @param oid the OID dot-separated string.\n *\n * @return the byte buffer.\n */\nasn1.oidToDer = function(oid) {\n // split OID into individual values\n var values = oid.split('.');\n var bytes = forge.util.createBuffer();\n\n // first byte is 40 * value1 + value2\n bytes.putByte(40 * parseInt(values[0], 10) + parseInt(values[1], 10));\n // other bytes are each value in base 128 with 8th bit set except for\n // the last byte for each value\n var last, valueBytes, value, b;\n for(var i = 2; i < values.length; ++i) {\n // produce value bytes in reverse because we don't know how many\n // bytes it will take to store the value\n last = true;\n valueBytes = [];\n value = parseInt(values[i], 10);\n do {\n b = value & 0x7F;\n value = value >>> 7;\n // if value is not last, then turn on 8th bit\n if(!last) {\n b |= 0x80;\n }\n valueBytes.push(b);\n last = false;\n } while(value > 0);\n\n // add value bytes in reverse (needs to be in big endian)\n for(var n = valueBytes.length - 1; n >= 0; --n) {\n bytes.putByte(valueBytes[n]);\n }\n }\n\n return bytes;\n};\n\n/**\n * Converts a DER-encoded byte buffer to an OID dot-separated string. The\n * byte buffer should contain only the DER-encoded value, not any tag or\n * length bytes.\n *\n * @param bytes the byte buffer.\n *\n * @return the OID dot-separated string.\n */\nasn1.derToOid = function(bytes) {\n var oid;\n\n // wrap in buffer if needed\n if(typeof bytes === 'string') {\n bytes = forge.util.createBuffer(bytes);\n }\n\n // first byte is 40 * value1 + value2\n var b = bytes.getByte();\n oid = Math.floor(b / 40) + '.' + (b % 40);\n\n // other bytes are each value in base 128 with 8th bit set except for\n // the last byte for each value\n var value = 0;\n while(bytes.length() > 0) {\n b = bytes.getByte();\n value = value << 7;\n // not the last byte for the value\n if(b & 0x80) {\n value += b & 0x7F;\n } else {\n // last byte\n oid += '.' + (value + b);\n value = 0;\n }\n }\n\n return oid;\n};\n\n/**\n * Converts a UTCTime value to a date.\n *\n * Note: GeneralizedTime has 4 digits for the year and is used for X.509\n * dates past 2049. Parsing that structure hasn't been implemented yet.\n *\n * @param utc the UTCTime value to convert.\n *\n * @return the date.\n */\nasn1.utcTimeToDate = function(utc) {\n /* The following formats can be used:\n\n YYMMDDhhmmZ\n YYMMDDhhmm+hh'mm'\n YYMMDDhhmm-hh'mm'\n YYMMDDhhmmssZ\n YYMMDDhhmmss+hh'mm'\n YYMMDDhhmmss-hh'mm'\n\n Where:\n\n YY is the least significant two digits of the year\n MM is the month (01 to 12)\n DD is the day (01 to 31)\n hh is the hour (00 to 23)\n mm are the minutes (00 to 59)\n ss are the seconds (00 to 59)\n Z indicates that local time is GMT, + indicates that local time is\n later than GMT, and - indicates that local time is earlier than GMT\n hh' is the absolute value of the offset from GMT in hours\n mm' is the absolute value of the offset from GMT in minutes */\n var date = new Date();\n\n // if YY >= 50 use 19xx, if YY < 50 use 20xx\n var year = parseInt(utc.substr(0, 2), 10);\n year = (year >= 50) ? 1900 + year : 2000 + year;\n var MM = parseInt(utc.substr(2, 2), 10) - 1; // use 0-11 for month\n var DD = parseInt(utc.substr(4, 2), 10);\n var hh = parseInt(utc.substr(6, 2), 10);\n var mm = parseInt(utc.substr(8, 2), 10);\n var ss = 0;\n\n // not just YYMMDDhhmmZ\n if(utc.length > 11) {\n // get character after minutes\n var c = utc.charAt(10);\n var end = 10;\n\n // see if seconds are present\n if(c !== '+' && c !== '-') {\n // get seconds\n ss = parseInt(utc.substr(10, 2), 10);\n end += 2;\n }\n }\n\n // update date\n date.setUTCFullYear(year, MM, DD);\n date.setUTCHours(hh, mm, ss, 0);\n\n if(end) {\n // get +/- after end of time\n c = utc.charAt(end);\n if(c === '+' || c === '-') {\n // get hours+minutes offset\n var hhoffset = parseInt(utc.substr(end + 1, 2), 10);\n var mmoffset = parseInt(utc.substr(end + 4, 2), 10);\n\n // calculate offset in milliseconds\n var offset = hhoffset * 60 + mmoffset;\n offset *= 60000;\n\n // apply offset\n if(c === '+') {\n date.setTime(+date - offset);\n } else {\n date.setTime(+date + offset);\n }\n }\n }\n\n return date;\n};\n\n/**\n * Converts a GeneralizedTime value to a date.\n *\n * @param gentime the GeneralizedTime value to convert.\n *\n * @return the date.\n */\nasn1.generalizedTimeToDate = function(gentime) {\n /* The following formats can be used:\n\n YYYYMMDDHHMMSS\n YYYYMMDDHHMMSS.fff\n YYYYMMDDHHMMSSZ\n YYYYMMDDHHMMSS.fffZ\n YYYYMMDDHHMMSS+hh'mm'\n YYYYMMDDHHMMSS.fff+hh'mm'\n YYYYMMDDHHMMSS-hh'mm'\n YYYYMMDDHHMMSS.fff-hh'mm'\n\n Where:\n\n YYYY is the year\n MM is the month (01 to 12)\n DD is the day (01 to 31)\n hh is the hour (00 to 23)\n mm are the minutes (00 to 59)\n ss are the seconds (00 to 59)\n .fff is the second fraction, accurate to three decimal places\n Z indicates that local time is GMT, + indicates that local time is\n later than GMT, and - indicates that local time is earlier than GMT\n hh' is the absolute value of the offset from GMT in hours\n mm' is the absolute value of the offset from GMT in minutes */\n var date = new Date();\n\n var YYYY = parseInt(gentime.substr(0, 4), 10);\n var MM = parseInt(gentime.substr(4, 2), 10) - 1; // use 0-11 for month\n var DD = parseInt(gentime.substr(6, 2), 10);\n var hh = parseInt(gentime.substr(8, 2), 10);\n var mm = parseInt(gentime.substr(10, 2), 10);\n var ss = parseInt(gentime.substr(12, 2), 10);\n var fff = 0;\n var offset = 0;\n var isUTC = false;\n\n if(gentime.charAt(gentime.length - 1) === 'Z') {\n isUTC = true;\n }\n\n var end = gentime.length - 5, c = gentime.charAt(end);\n if(c === '+' || c === '-') {\n // get hours+minutes offset\n var hhoffset = parseInt(gentime.substr(end + 1, 2), 10);\n var mmoffset = parseInt(gentime.substr(end + 4, 2), 10);\n\n // calculate offset in milliseconds\n offset = hhoffset * 60 + mmoffset;\n offset *= 60000;\n\n // apply offset\n if(c === '+') {\n offset *= -1;\n }\n\n isUTC = true;\n }\n\n // check for second fraction\n if(gentime.charAt(14) === '.') {\n fff = parseFloat(gentime.substr(14), 10) * 1000;\n }\n\n if(isUTC) {\n date.setUTCFullYear(YYYY, MM, DD);\n date.setUTCHours(hh, mm, ss, fff);\n\n // apply offset\n date.setTime(+date + offset);\n } else {\n date.setFullYear(YYYY, MM, DD);\n date.setHours(hh, mm, ss, fff);\n }\n\n return date;\n};\n\n/**\n * Converts a date to a UTCTime value.\n *\n * Note: GeneralizedTime has 4 digits for the year and is used for X.509\n * dates past 2049. Converting to a GeneralizedTime hasn't been\n * implemented yet.\n *\n * @param date the date to convert.\n *\n * @return the UTCTime value.\n */\nasn1.dateToUtcTime = function(date) {\n // TODO: validate; currently assumes proper format\n if(typeof date === 'string') {\n return date;\n }\n\n var rval = '';\n\n // create format YYMMDDhhmmssZ\n var format = [];\n format.push(('' + date.getUTCFullYear()).substr(2));\n format.push('' + (date.getUTCMonth() + 1));\n format.push('' + date.getUTCDate());\n format.push('' + date.getUTCHours());\n format.push('' + date.getUTCMinutes());\n format.push('' + date.getUTCSeconds());\n\n // ensure 2 digits are used for each format entry\n for(var i = 0; i < format.length; ++i) {\n if(format[i].length < 2) {\n rval += '0';\n }\n rval += format[i];\n }\n rval += 'Z';\n\n return rval;\n};\n\n/**\n * Converts a date to a GeneralizedTime value.\n *\n * @param date the date to convert.\n *\n * @return the GeneralizedTime value as a string.\n */\nasn1.dateToGeneralizedTime = function(date) {\n // TODO: validate; currently assumes proper format\n if(typeof date === 'string') {\n return date;\n }\n\n var rval = '';\n\n // create format YYYYMMDDHHMMSSZ\n var format = [];\n format.push('' + date.getUTCFullYear());\n format.push('' + (date.getUTCMonth() + 1));\n format.push('' + date.getUTCDate());\n format.push('' + date.getUTCHours());\n format.push('' + date.getUTCMinutes());\n format.push('' + date.getUTCSeconds());\n\n // ensure 2 digits are used for each format entry\n for(var i = 0; i < format.length; ++i) {\n if(format[i].length < 2) {\n rval += '0';\n }\n rval += format[i];\n }\n rval += 'Z';\n\n return rval;\n};\n\n/**\n * Converts a javascript integer to a DER-encoded byte buffer to be used\n * as the value for an INTEGER type.\n *\n * @param x the integer.\n *\n * @return the byte buffer.\n */\nasn1.integerToDer = function(x) {\n var rval = forge.util.createBuffer();\n if(x >= -0x80 && x < 0x80) {\n return rval.putSignedInt(x, 8);\n }\n if(x >= -0x8000 && x < 0x8000) {\n return rval.putSignedInt(x, 16);\n }\n if(x >= -0x800000 && x < 0x800000) {\n return rval.putSignedInt(x, 24);\n }\n if(x >= -0x80000000 && x < 0x80000000) {\n return rval.putSignedInt(x, 32);\n }\n var error = new Error('Integer too large; max is 32-bits.');\n error.integer = x;\n throw error;\n};\n\n/**\n * Converts a DER-encoded byte buffer to a javascript integer. This is\n * typically used to decode the value of an INTEGER type.\n *\n * @param bytes the byte buffer.\n *\n * @return the integer.\n */\nasn1.derToInteger = function(bytes) {\n // wrap in buffer if needed\n if(typeof bytes === 'string') {\n bytes = forge.util.createBuffer(bytes);\n }\n\n var n = bytes.length() * 8;\n if(n > 32) {\n throw new Error('Integer too large; max is 32-bits.');\n }\n return bytes.getSignedInt(n);\n};\n\n/**\n * Validates that the given ASN.1 object is at least a super set of the\n * given ASN.1 structure. Only tag classes and types are checked. An\n * optional map may also be provided to capture ASN.1 values while the\n * structure is checked.\n *\n * To capture an ASN.1 value, set an object in the validator's 'capture'\n * parameter to the key to use in the capture map. To capture the full\n * ASN.1 object, specify 'captureAsn1'. To capture BIT STRING bytes, including\n * the leading unused bits counter byte, specify 'captureBitStringContents'.\n * To capture BIT STRING bytes, without the leading unused bits counter byte,\n * specify 'captureBitStringValue'.\n *\n * Objects in the validator may set a field 'optional' to true to indicate\n * that it isn't necessary to pass validation.\n *\n * @param obj the ASN.1 object to validate.\n * @param v the ASN.1 structure validator.\n * @param capture an optional map to capture values in.\n * @param errors an optional array for storing validation errors.\n *\n * @return true on success, false on failure.\n */\nasn1.validate = function(obj, v, capture, errors) {\n var rval = false;\n\n // ensure tag class and type are the same if specified\n if((obj.tagClass === v.tagClass || typeof(v.tagClass) === 'undefined') &&\n (obj.type === v.type || typeof(v.type) === 'undefined')) {\n // ensure constructed flag is the same if specified\n if(obj.constructed === v.constructed ||\n typeof(v.constructed) === 'undefined') {\n rval = true;\n\n // handle sub values\n if(v.value && forge.util.isArray(v.value)) {\n var j = 0;\n for(var i = 0; rval && i < v.value.length; ++i) {\n rval = v.value[i].optional || false;\n if(obj.value[j]) {\n rval = asn1.validate(obj.value[j], v.value[i], capture, errors);\n if(rval) {\n ++j;\n } else if(v.value[i].optional) {\n rval = true;\n }\n }\n if(!rval && errors) {\n errors.push(\n '[' + v.name + '] ' +\n 'Tag class \"' + v.tagClass + '\", type \"' +\n v.type + '\" expected value length \"' +\n v.value.length + '\", got \"' +\n obj.value.length + '\"');\n }\n }\n }\n\n if(rval && capture) {\n if(v.capture) {\n capture[v.capture] = obj.value;\n }\n if(v.captureAsn1) {\n capture[v.captureAsn1] = obj;\n }\n if(v.captureBitStringContents && 'bitStringContents' in obj) {\n capture[v.captureBitStringContents] = obj.bitStringContents;\n }\n if(v.captureBitStringValue && 'bitStringContents' in obj) {\n var value;\n if(obj.bitStringContents.length < 2) {\n capture[v.captureBitStringValue] = '';\n } else {\n // FIXME: support unused bits with data shifting\n var unused = obj.bitStringContents.charCodeAt(0);\n if(unused !== 0) {\n throw new Error(\n 'captureBitStringValue only supported for zero unused bits');\n }\n capture[v.captureBitStringValue] = obj.bitStringContents.slice(1);\n }\n }\n }\n } else if(errors) {\n errors.push(\n '[' + v.name + '] ' +\n 'Expected constructed \"' + v.constructed + '\", got \"' +\n obj.constructed + '\"');\n }\n } else if(errors) {\n if(obj.tagClass !== v.tagClass) {\n errors.push(\n '[' + v.name + '] ' +\n 'Expected tag class \"' + v.tagClass + '\", got \"' +\n obj.tagClass + '\"');\n }\n if(obj.type !== v.type) {\n errors.push(\n '[' + v.name + '] ' +\n 'Expected type \"' + v.type + '\", got \"' + obj.type + '\"');\n }\n }\n return rval;\n};\n\n// regex for testing for non-latin characters\nvar _nonLatinRegex = /[^\\\\u0000-\\\\u00ff]/;\n\n/**\n * Pretty prints an ASN.1 object to a string.\n *\n * @param obj the object to write out.\n * @param level the level in the tree.\n * @param indentation the indentation to use.\n *\n * @return the string.\n */\nasn1.prettyPrint = function(obj, level, indentation) {\n var rval = '';\n\n // set default level and indentation\n level = level || 0;\n indentation = indentation || 2;\n\n // start new line for deep levels\n if(level > 0) {\n rval += '\\n';\n }\n\n // create indent\n var indent = '';\n for(var i = 0; i < level * indentation; ++i) {\n indent += ' ';\n }\n\n // print class:type\n rval += indent + 'Tag: ';\n switch(obj.tagClass) {\n case asn1.Class.UNIVERSAL:\n rval += 'Universal:';\n break;\n case asn1.Class.APPLICATION:\n rval += 'Application:';\n break;\n case asn1.Class.CONTEXT_SPECIFIC:\n rval += 'Context-Specific:';\n break;\n case asn1.Class.PRIVATE:\n rval += 'Private:';\n break;\n }\n\n if(obj.tagClass === asn1.Class.UNIVERSAL) {\n rval += obj.type;\n\n // known types\n switch(obj.type) {\n case asn1.Type.NONE:\n rval += ' (None)';\n break;\n case asn1.Type.BOOLEAN:\n rval += ' (Boolean)';\n break;\n case asn1.Type.INTEGER:\n rval += ' (Integer)';\n break;\n case asn1.Type.BITSTRING:\n rval += ' (Bit string)';\n break;\n case asn1.Type.OCTETSTRING:\n rval += ' (Octet string)';\n break;\n case asn1.Type.NULL:\n rval += ' (Null)';\n break;\n case asn1.Type.OID:\n rval += ' (Object Identifier)';\n break;\n case asn1.Type.ODESC:\n rval += ' (Object Descriptor)';\n break;\n case asn1.Type.EXTERNAL:\n rval += ' (External or Instance of)';\n break;\n case asn1.Type.REAL:\n rval += ' (Real)';\n break;\n case asn1.Type.ENUMERATED:\n rval += ' (Enumerated)';\n break;\n case asn1.Type.EMBEDDED:\n rval += ' (Embedded PDV)';\n break;\n case asn1.Type.UTF8:\n rval += ' (UTF8)';\n break;\n case asn1.Type.ROID:\n rval += ' (Relative Object Identifier)';\n break;\n case asn1.Type.SEQUENCE:\n rval += ' (Sequence)';\n break;\n case asn1.Type.SET:\n rval += ' (Set)';\n break;\n case asn1.Type.PRINTABLESTRING:\n rval += ' (Printable String)';\n break;\n case asn1.Type.IA5String:\n rval += ' (IA5String (ASCII))';\n break;\n case asn1.Type.UTCTIME:\n rval += ' (UTC time)';\n break;\n case asn1.Type.GENERALIZEDTIME:\n rval += ' (Generalized time)';\n break;\n case asn1.Type.BMPSTRING:\n rval += ' (BMP String)';\n break;\n }\n } else {\n rval += obj.type;\n }\n\n rval += '\\n';\n rval += indent + 'Constructed: ' + obj.constructed + '\\n';\n\n if(obj.composed) {\n var subvalues = 0;\n var sub = '';\n for(var i = 0; i < obj.value.length; ++i) {\n if(obj.value[i] !== undefined) {\n subvalues += 1;\n sub += asn1.prettyPrint(obj.value[i], level + 1, indentation);\n if((i + 1) < obj.value.length) {\n sub += ',';\n }\n }\n }\n rval += indent + 'Sub values: ' + subvalues + sub;\n } else {\n rval += indent + 'Value: ';\n if(obj.type === asn1.Type.OID) {\n var oid = asn1.derToOid(obj.value);\n rval += oid;\n if(forge.pki && forge.pki.oids) {\n if(oid in forge.pki.oids) {\n rval += ' (' + forge.pki.oids[oid] + ') ';\n }\n }\n }\n if(obj.type === asn1.Type.INTEGER) {\n try {\n rval += asn1.derToInteger(obj.value);\n } catch(ex) {\n rval += '0x' + forge.util.bytesToHex(obj.value);\n }\n } else if(obj.type === asn1.Type.BITSTRING) {\n // TODO: shift bits as needed to display without padding\n if(obj.value.length > 1) {\n // remove unused bits field\n rval += '0x' + forge.util.bytesToHex(obj.value.slice(1));\n } else {\n rval += '(none)';\n }\n // show unused bit count\n if(obj.value.length > 0) {\n var unused = obj.value.charCodeAt(0);\n if(unused == 1) {\n rval += ' (1 unused bit shown)';\n } else if(unused > 1) {\n rval += ' (' + unused + ' unused bits shown)';\n }\n }\n } else if(obj.type === asn1.Type.OCTETSTRING) {\n if(!_nonLatinRegex.test(obj.value)) {\n rval += '(' + obj.value + ') ';\n }\n rval += '0x' + forge.util.bytesToHex(obj.value);\n } else if(obj.type === asn1.Type.UTF8) {\n rval += forge.util.decodeUtf8(obj.value);\n } else if(obj.type === asn1.Type.PRINTABLESTRING ||\n obj.type === asn1.Type.IA5String) {\n rval += obj.value;\n } else if(_nonLatinRegex.test(obj.value)) {\n rval += '0x' + forge.util.bytesToHex(obj.value);\n } else if(obj.value.length === 0) {\n rval += '[null]';\n } else {\n rval += obj.value;\n }\n }\n\n return rval;\n};\n","/**\n * Node.js module for Forge.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2016 Digital Bazaar, Inc.\n */\nmodule.exports = {\n // default options\n options: {\n usePureJavaScript: false\n }\n};\n","/**\n * Utility functions for web applications.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2018 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nvar baseN = require('./baseN');\n\n/* Utilities API */\nvar util = module.exports = forge.util = forge.util || {};\n\n// define setImmediate and nextTick\n(function() {\n // use native nextTick (unless we're in webpack)\n // webpack (or better node-libs-browser polyfill) sets process.browser.\n // this way we can detect webpack properly\n if(typeof process !== 'undefined' && process.nextTick && !process.browser) {\n util.nextTick = process.nextTick;\n if(typeof setImmediate === 'function') {\n util.setImmediate = setImmediate;\n } else {\n // polyfill setImmediate with nextTick, older versions of node\n // (those w/o setImmediate) won't totally starve IO\n util.setImmediate = util.nextTick;\n }\n return;\n }\n\n // polyfill nextTick with native setImmediate\n if(typeof setImmediate === 'function') {\n util.setImmediate = function() { return setImmediate.apply(undefined, arguments); };\n util.nextTick = function(callback) {\n return setImmediate(callback);\n };\n return;\n }\n\n /* Note: A polyfill upgrade pattern is used here to allow combining\n polyfills. For example, MutationObserver is fast, but blocks UI updates,\n so it needs to allow UI updates periodically, so it falls back on\n postMessage or setTimeout. */\n\n // polyfill with setTimeout\n util.setImmediate = function(callback) {\n setTimeout(callback, 0);\n };\n\n // upgrade polyfill to use postMessage\n if(typeof window !== 'undefined' &&\n typeof window.postMessage === 'function') {\n var msg = 'forge.setImmediate';\n var callbacks = [];\n util.setImmediate = function(callback) {\n callbacks.push(callback);\n // only send message when one hasn't been sent in\n // the current turn of the event loop\n if(callbacks.length === 1) {\n window.postMessage(msg, '*');\n }\n };\n function handler(event) {\n if(event.source === window && event.data === msg) {\n event.stopPropagation();\n var copy = callbacks.slice();\n callbacks.length = 0;\n copy.forEach(function(callback) {\n callback();\n });\n }\n }\n window.addEventListener('message', handler, true);\n }\n\n // upgrade polyfill to use MutationObserver\n if(typeof MutationObserver !== 'undefined') {\n // polyfill with MutationObserver\n var now = Date.now();\n var attr = true;\n var div = document.createElement('div');\n var callbacks = [];\n new MutationObserver(function() {\n var copy = callbacks.slice();\n callbacks.length = 0;\n copy.forEach(function(callback) {\n callback();\n });\n }).observe(div, {attributes: true});\n var oldSetImmediate = util.setImmediate;\n util.setImmediate = function(callback) {\n if(Date.now() - now > 15) {\n now = Date.now();\n oldSetImmediate(callback);\n } else {\n callbacks.push(callback);\n // only trigger observer when it hasn't been triggered in\n // the current turn of the event loop\n if(callbacks.length === 1) {\n div.setAttribute('a', attr = !attr);\n }\n }\n };\n }\n\n util.nextTick = util.setImmediate;\n})();\n\n// check if running under Node.js\nutil.isNodejs =\n typeof process !== 'undefined' && process.versions && process.versions.node;\n\n\n// 'self' will also work in Web Workers (instance of WorkerGlobalScope) while\n// it will point to `window` in the main thread.\n// To remain compatible with older browsers, we fall back to 'window' if 'self'\n// is not available.\nutil.globalScope = (function() {\n if(util.isNodejs) {\n return global;\n }\n\n return typeof self === 'undefined' ? window : self;\n})();\n\n// define isArray\nutil.isArray = Array.isArray || function(x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n};\n\n// define isArrayBuffer\nutil.isArrayBuffer = function(x) {\n return typeof ArrayBuffer !== 'undefined' && x instanceof ArrayBuffer;\n};\n\n// define isArrayBufferView\nutil.isArrayBufferView = function(x) {\n return x && util.isArrayBuffer(x.buffer) && x.byteLength !== undefined;\n};\n\n/**\n * Ensure a bits param is 8, 16, 24, or 32. Used to validate input for\n * algorithms where bit manipulation, JavaScript limitations, and/or algorithm\n * design only allow for byte operations of a limited size.\n *\n * @param n number of bits.\n *\n * Throw Error if n invalid.\n */\nfunction _checkBitsParam(n) {\n if(!(n === 8 || n === 16 || n === 24 || n === 32)) {\n throw new Error('Only 8, 16, 24, or 32 bits supported: ' + n);\n }\n}\n\n// TODO: set ByteBuffer to best available backing\nutil.ByteBuffer = ByteStringBuffer;\n\n/** Buffer w/BinaryString backing */\n\n/**\n * Constructor for a binary string backed byte buffer.\n *\n * @param [b] the bytes to wrap (either encoded as string, one byte per\n * character, or as an ArrayBuffer or Typed Array).\n */\nfunction ByteStringBuffer(b) {\n // TODO: update to match DataBuffer API\n\n // the data in this buffer\n this.data = '';\n // the pointer for reading from this buffer\n this.read = 0;\n\n if(typeof b === 'string') {\n this.data = b;\n } else if(util.isArrayBuffer(b) || util.isArrayBufferView(b)) {\n if(typeof Buffer !== 'undefined' && b instanceof Buffer) {\n this.data = b.toString('binary');\n } else {\n // convert native buffer to forge buffer\n // FIXME: support native buffers internally instead\n var arr = new Uint8Array(b);\n try {\n this.data = String.fromCharCode.apply(null, arr);\n } catch(e) {\n for(var i = 0; i < arr.length; ++i) {\n this.putByte(arr[i]);\n }\n }\n }\n } else if(b instanceof ByteStringBuffer ||\n (typeof b === 'object' && typeof b.data === 'string' &&\n typeof b.read === 'number')) {\n // copy existing buffer\n this.data = b.data;\n this.read = b.read;\n }\n\n // used for v8 optimization\n this._constructedStringLength = 0;\n}\nutil.ByteStringBuffer = ByteStringBuffer;\n\n/* Note: This is an optimization for V8-based browsers. When V8 concatenates\n a string, the strings are only joined logically using a \"cons string\" or\n \"constructed/concatenated string\". These containers keep references to one\n another and can result in very large memory usage. For example, if a 2MB\n string is constructed by concatenating 4 bytes together at a time, the\n memory usage will be ~44MB; so ~22x increase. The strings are only joined\n together when an operation requiring their joining takes place, such as\n substr(). This function is called when adding data to this buffer to ensure\n these types of strings are periodically joined to reduce the memory\n footprint. */\nvar _MAX_CONSTRUCTED_STRING_LENGTH = 4096;\nutil.ByteStringBuffer.prototype._optimizeConstructedString = function(x) {\n this._constructedStringLength += x;\n if(this._constructedStringLength > _MAX_CONSTRUCTED_STRING_LENGTH) {\n // this substr() should cause the constructed string to join\n this.data.substr(0, 1);\n this._constructedStringLength = 0;\n }\n};\n\n/**\n * Gets the number of bytes in this buffer.\n *\n * @return the number of bytes in this buffer.\n */\nutil.ByteStringBuffer.prototype.length = function() {\n return this.data.length - this.read;\n};\n\n/**\n * Gets whether or not this buffer is empty.\n *\n * @return true if this buffer is empty, false if not.\n */\nutil.ByteStringBuffer.prototype.isEmpty = function() {\n return this.length() <= 0;\n};\n\n/**\n * Puts a byte in this buffer.\n *\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putByte = function(b) {\n return this.putBytes(String.fromCharCode(b));\n};\n\n/**\n * Puts a byte in this buffer N times.\n *\n * @param b the byte to put.\n * @param n the number of bytes of value b to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.fillWithByte = function(b, n) {\n b = String.fromCharCode(b);\n var d = this.data;\n while(n > 0) {\n if(n & 1) {\n d += b;\n }\n n >>>= 1;\n if(n > 0) {\n b += b;\n }\n }\n this.data = d;\n this._optimizeConstructedString(n);\n return this;\n};\n\n/**\n * Puts bytes in this buffer.\n *\n * @param bytes the bytes (as a binary encoded string) to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putBytes = function(bytes) {\n this.data += bytes;\n this._optimizeConstructedString(bytes.length);\n return this;\n};\n\n/**\n * Puts a UTF-16 encoded string into this buffer.\n *\n * @param str the string to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putString = function(str) {\n return this.putBytes(util.encodeUtf8(str));\n};\n\n/**\n * Puts a 16-bit integer in this buffer in big-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt16 = function(i) {\n return this.putBytes(\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n/**\n * Puts a 24-bit integer in this buffer in big-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt24 = function(i) {\n return this.putBytes(\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n/**\n * Puts a 32-bit integer in this buffer in big-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt32 = function(i) {\n return this.putBytes(\n String.fromCharCode(i >> 24 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n/**\n * Puts a 16-bit integer in this buffer in little-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt16Le = function(i) {\n return this.putBytes(\n String.fromCharCode(i & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF));\n};\n\n/**\n * Puts a 24-bit integer in this buffer in little-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt24Le = function(i) {\n return this.putBytes(\n String.fromCharCode(i & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF));\n};\n\n/**\n * Puts a 32-bit integer in this buffer in little-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt32Le = function(i) {\n return this.putBytes(\n String.fromCharCode(i & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 24 & 0xFF));\n};\n\n/**\n * Puts an n-bit integer in this buffer in big-endian order.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt = function(i, n) {\n _checkBitsParam(n);\n var bytes = '';\n do {\n n -= 8;\n bytes += String.fromCharCode((i >> n) & 0xFF);\n } while(n > 0);\n return this.putBytes(bytes);\n};\n\n/**\n * Puts a signed n-bit integer in this buffer in big-endian order. Two's\n * complement representation is used.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putSignedInt = function(i, n) {\n // putInt checks n\n if(i < 0) {\n i += 2 << (n - 1);\n }\n return this.putInt(i, n);\n};\n\n/**\n * Puts the given buffer into this buffer.\n *\n * @param buffer the buffer to put into this one.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putBuffer = function(buffer) {\n return this.putBytes(buffer.getBytes());\n};\n\n/**\n * Gets a byte from this buffer and advances the read pointer by 1.\n *\n * @return the byte.\n */\nutil.ByteStringBuffer.prototype.getByte = function() {\n return this.data.charCodeAt(this.read++);\n};\n\n/**\n * Gets a uint16 from this buffer in big-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.ByteStringBuffer.prototype.getInt16 = function() {\n var rval = (\n this.data.charCodeAt(this.read) << 8 ^\n this.data.charCodeAt(this.read + 1));\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in big-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.ByteStringBuffer.prototype.getInt24 = function() {\n var rval = (\n this.data.charCodeAt(this.read) << 16 ^\n this.data.charCodeAt(this.read + 1) << 8 ^\n this.data.charCodeAt(this.read + 2));\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in big-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.ByteStringBuffer.prototype.getInt32 = function() {\n var rval = (\n this.data.charCodeAt(this.read) << 24 ^\n this.data.charCodeAt(this.read + 1) << 16 ^\n this.data.charCodeAt(this.read + 2) << 8 ^\n this.data.charCodeAt(this.read + 3));\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets a uint16 from this buffer in little-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.ByteStringBuffer.prototype.getInt16Le = function() {\n var rval = (\n this.data.charCodeAt(this.read) ^\n this.data.charCodeAt(this.read + 1) << 8);\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in little-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.ByteStringBuffer.prototype.getInt24Le = function() {\n var rval = (\n this.data.charCodeAt(this.read) ^\n this.data.charCodeAt(this.read + 1) << 8 ^\n this.data.charCodeAt(this.read + 2) << 16);\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in little-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.ByteStringBuffer.prototype.getInt32Le = function() {\n var rval = (\n this.data.charCodeAt(this.read) ^\n this.data.charCodeAt(this.read + 1) << 8 ^\n this.data.charCodeAt(this.read + 2) << 16 ^\n this.data.charCodeAt(this.read + 3) << 24);\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets an n-bit integer from this buffer in big-endian order and advances the\n * read pointer by ceil(n/8).\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.ByteStringBuffer.prototype.getInt = function(n) {\n _checkBitsParam(n);\n var rval = 0;\n do {\n // TODO: Use (rval * 0x100) if adding support for 33 to 53 bits.\n rval = (rval << 8) + this.data.charCodeAt(this.read++);\n n -= 8;\n } while(n > 0);\n return rval;\n};\n\n/**\n * Gets a signed n-bit integer from this buffer in big-endian order, using\n * two's complement, and advances the read pointer by n/8.\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.ByteStringBuffer.prototype.getSignedInt = function(n) {\n // getInt checks n\n var x = this.getInt(n);\n var max = 2 << (n - 2);\n if(x >= max) {\n x -= max << 1;\n }\n return x;\n};\n\n/**\n * Reads bytes out as a binary encoded string and clears them from the\n * buffer. Note that the resulting string is binary encoded (in node.js this\n * encoding is referred to as `binary`, it is *not* `utf8`).\n *\n * @param count the number of bytes to read, undefined or null for all.\n *\n * @return a binary encoded string of bytes.\n */\nutil.ByteStringBuffer.prototype.getBytes = function(count) {\n var rval;\n if(count) {\n // read count bytes\n count = Math.min(this.length(), count);\n rval = this.data.slice(this.read, this.read + count);\n this.read += count;\n } else if(count === 0) {\n rval = '';\n } else {\n // read all bytes, optimize to only copy when needed\n rval = (this.read === 0) ? this.data : this.data.slice(this.read);\n this.clear();\n }\n return rval;\n};\n\n/**\n * Gets a binary encoded string of the bytes from this buffer without\n * modifying the read pointer.\n *\n * @param count the number of bytes to get, omit to get all.\n *\n * @return a string full of binary encoded characters.\n */\nutil.ByteStringBuffer.prototype.bytes = function(count) {\n return (typeof(count) === 'undefined' ?\n this.data.slice(this.read) :\n this.data.slice(this.read, this.read + count));\n};\n\n/**\n * Gets a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n *\n * @return the byte.\n */\nutil.ByteStringBuffer.prototype.at = function(i) {\n return this.data.charCodeAt(this.read + i);\n};\n\n/**\n * Puts a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.setAt = function(i, b) {\n this.data = this.data.substr(0, this.read + i) +\n String.fromCharCode(b) +\n this.data.substr(this.read + i + 1);\n return this;\n};\n\n/**\n * Gets the last byte without modifying the read pointer.\n *\n * @return the last byte.\n */\nutil.ByteStringBuffer.prototype.last = function() {\n return this.data.charCodeAt(this.data.length - 1);\n};\n\n/**\n * Creates a copy of this buffer.\n *\n * @return the copy.\n */\nutil.ByteStringBuffer.prototype.copy = function() {\n var c = util.createBuffer(this.data);\n c.read = this.read;\n return c;\n};\n\n/**\n * Compacts this buffer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.compact = function() {\n if(this.read > 0) {\n this.data = this.data.slice(this.read);\n this.read = 0;\n }\n return this;\n};\n\n/**\n * Clears this buffer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.clear = function() {\n this.data = '';\n this.read = 0;\n return this;\n};\n\n/**\n * Shortens this buffer by triming bytes off of the end of this buffer.\n *\n * @param count the number of bytes to trim off.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.truncate = function(count) {\n var len = Math.max(0, this.length() - count);\n this.data = this.data.substr(this.read, len);\n this.read = 0;\n return this;\n};\n\n/**\n * Converts this buffer to a hexadecimal string.\n *\n * @return a hexadecimal string.\n */\nutil.ByteStringBuffer.prototype.toHex = function() {\n var rval = '';\n for(var i = this.read; i < this.data.length; ++i) {\n var b = this.data.charCodeAt(i);\n if(b < 16) {\n rval += '0';\n }\n rval += b.toString(16);\n }\n return rval;\n};\n\n/**\n * Converts this buffer to a UTF-16 string (standard JavaScript string).\n *\n * @return a UTF-16 string.\n */\nutil.ByteStringBuffer.prototype.toString = function() {\n return util.decodeUtf8(this.bytes());\n};\n\n/** End Buffer w/BinaryString backing */\n\n/** Buffer w/UInt8Array backing */\n\n/**\n * FIXME: Experimental. Do not use yet.\n *\n * Constructor for an ArrayBuffer-backed byte buffer.\n *\n * The buffer may be constructed from a string, an ArrayBuffer, DataView, or a\n * TypedArray.\n *\n * If a string is given, its encoding should be provided as an option,\n * otherwise it will default to 'binary'. A 'binary' string is encoded such\n * that each character is one byte in length and size.\n *\n * If an ArrayBuffer, DataView, or TypedArray is given, it will be used\n * *directly* without any copying. Note that, if a write to the buffer requires\n * more space, the buffer will allocate a new backing ArrayBuffer to\n * accommodate. The starting read and write offsets for the buffer may be\n * given as options.\n *\n * @param [b] the initial bytes for this buffer.\n * @param options the options to use:\n * [readOffset] the starting read offset to use (default: 0).\n * [writeOffset] the starting write offset to use (default: the\n * length of the first parameter).\n * [growSize] the minimum amount, in bytes, to grow the buffer by to\n * accommodate writes (default: 1024).\n * [encoding] the encoding ('binary', 'utf8', 'utf16', 'hex') for the\n * first parameter, if it is a string (default: 'binary').\n */\nfunction DataBuffer(b, options) {\n // default options\n options = options || {};\n\n // pointers for read from/write to buffer\n this.read = options.readOffset || 0;\n this.growSize = options.growSize || 1024;\n\n var isArrayBuffer = util.isArrayBuffer(b);\n var isArrayBufferView = util.isArrayBufferView(b);\n if(isArrayBuffer || isArrayBufferView) {\n // use ArrayBuffer directly\n if(isArrayBuffer) {\n this.data = new DataView(b);\n } else {\n // TODO: adjust read/write offset based on the type of view\n // or specify that this must be done in the options ... that the\n // offsets are byte-based\n this.data = new DataView(b.buffer, b.byteOffset, b.byteLength);\n }\n this.write = ('writeOffset' in options ?\n options.writeOffset : this.data.byteLength);\n return;\n }\n\n // initialize to empty array buffer and add any given bytes using putBytes\n this.data = new DataView(new ArrayBuffer(0));\n this.write = 0;\n\n if(b !== null && b !== undefined) {\n this.putBytes(b);\n }\n\n if('writeOffset' in options) {\n this.write = options.writeOffset;\n }\n}\nutil.DataBuffer = DataBuffer;\n\n/**\n * Gets the number of bytes in this buffer.\n *\n * @return the number of bytes in this buffer.\n */\nutil.DataBuffer.prototype.length = function() {\n return this.write - this.read;\n};\n\n/**\n * Gets whether or not this buffer is empty.\n *\n * @return true if this buffer is empty, false if not.\n */\nutil.DataBuffer.prototype.isEmpty = function() {\n return this.length() <= 0;\n};\n\n/**\n * Ensures this buffer has enough empty space to accommodate the given number\n * of bytes. An optional parameter may be given that indicates a minimum\n * amount to grow the buffer if necessary. If the parameter is not given,\n * the buffer will be grown by some previously-specified default amount\n * or heuristic.\n *\n * @param amount the number of bytes to accommodate.\n * @param [growSize] the minimum amount, in bytes, to grow the buffer by if\n * necessary.\n */\nutil.DataBuffer.prototype.accommodate = function(amount, growSize) {\n if(this.length() >= amount) {\n return this;\n }\n growSize = Math.max(growSize || this.growSize, amount);\n\n // grow buffer\n var src = new Uint8Array(\n this.data.buffer, this.data.byteOffset, this.data.byteLength);\n var dst = new Uint8Array(this.length() + growSize);\n dst.set(src);\n this.data = new DataView(dst.buffer);\n\n return this;\n};\n\n/**\n * Puts a byte in this buffer.\n *\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putByte = function(b) {\n this.accommodate(1);\n this.data.setUint8(this.write++, b);\n return this;\n};\n\n/**\n * Puts a byte in this buffer N times.\n *\n * @param b the byte to put.\n * @param n the number of bytes of value b to put.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.fillWithByte = function(b, n) {\n this.accommodate(n);\n for(var i = 0; i < n; ++i) {\n this.data.setUint8(b);\n }\n return this;\n};\n\n/**\n * Puts bytes in this buffer. The bytes may be given as a string, an\n * ArrayBuffer, a DataView, or a TypedArray.\n *\n * @param bytes the bytes to put.\n * @param [encoding] the encoding for the first parameter ('binary', 'utf8',\n * 'utf16', 'hex'), if it is a string (default: 'binary').\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putBytes = function(bytes, encoding) {\n if(util.isArrayBufferView(bytes)) {\n var src = new Uint8Array(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n var len = src.byteLength - src.byteOffset;\n this.accommodate(len);\n var dst = new Uint8Array(this.data.buffer, this.write);\n dst.set(src);\n this.write += len;\n return this;\n }\n\n if(util.isArrayBuffer(bytes)) {\n var src = new Uint8Array(bytes);\n this.accommodate(src.byteLength);\n var dst = new Uint8Array(this.data.buffer);\n dst.set(src, this.write);\n this.write += src.byteLength;\n return this;\n }\n\n // bytes is a util.DataBuffer or equivalent\n if(bytes instanceof util.DataBuffer ||\n (typeof bytes === 'object' &&\n typeof bytes.read === 'number' && typeof bytes.write === 'number' &&\n util.isArrayBufferView(bytes.data))) {\n var src = new Uint8Array(bytes.data.byteLength, bytes.read, bytes.length());\n this.accommodate(src.byteLength);\n var dst = new Uint8Array(bytes.data.byteLength, this.write);\n dst.set(src);\n this.write += src.byteLength;\n return this;\n }\n\n if(bytes instanceof util.ByteStringBuffer) {\n // copy binary string and process as the same as a string parameter below\n bytes = bytes.data;\n encoding = 'binary';\n }\n\n // string conversion\n encoding = encoding || 'binary';\n if(typeof bytes === 'string') {\n var view;\n\n // decode from string\n if(encoding === 'hex') {\n this.accommodate(Math.ceil(bytes.length / 2));\n view = new Uint8Array(this.data.buffer, this.write);\n this.write += util.binary.hex.decode(bytes, view, this.write);\n return this;\n }\n if(encoding === 'base64') {\n this.accommodate(Math.ceil(bytes.length / 4) * 3);\n view = new Uint8Array(this.data.buffer, this.write);\n this.write += util.binary.base64.decode(bytes, view, this.write);\n return this;\n }\n\n // encode text as UTF-8 bytes\n if(encoding === 'utf8') {\n // encode as UTF-8 then decode string as raw binary\n bytes = util.encodeUtf8(bytes);\n encoding = 'binary';\n }\n\n // decode string as raw binary\n if(encoding === 'binary' || encoding === 'raw') {\n // one byte per character\n this.accommodate(bytes.length);\n view = new Uint8Array(this.data.buffer, this.write);\n this.write += util.binary.raw.decode(view);\n return this;\n }\n\n // encode text as UTF-16 bytes\n if(encoding === 'utf16') {\n // two bytes per character\n this.accommodate(bytes.length * 2);\n view = new Uint16Array(this.data.buffer, this.write);\n this.write += util.text.utf16.encode(view);\n return this;\n }\n\n throw new Error('Invalid encoding: ' + encoding);\n }\n\n throw Error('Invalid parameter: ' + bytes);\n};\n\n/**\n * Puts the given buffer into this buffer.\n *\n * @param buffer the buffer to put into this one.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putBuffer = function(buffer) {\n this.putBytes(buffer);\n buffer.clear();\n return this;\n};\n\n/**\n * Puts a string into this buffer.\n *\n * @param str the string to put.\n * @param [encoding] the encoding for the string (default: 'utf16').\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putString = function(str) {\n return this.putBytes(str, 'utf16');\n};\n\n/**\n * Puts a 16-bit integer in this buffer in big-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt16 = function(i) {\n this.accommodate(2);\n this.data.setInt16(this.write, i);\n this.write += 2;\n return this;\n};\n\n/**\n * Puts a 24-bit integer in this buffer in big-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt24 = function(i) {\n this.accommodate(3);\n this.data.setInt16(this.write, i >> 8 & 0xFFFF);\n this.data.setInt8(this.write, i >> 16 & 0xFF);\n this.write += 3;\n return this;\n};\n\n/**\n * Puts a 32-bit integer in this buffer in big-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt32 = function(i) {\n this.accommodate(4);\n this.data.setInt32(this.write, i);\n this.write += 4;\n return this;\n};\n\n/**\n * Puts a 16-bit integer in this buffer in little-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt16Le = function(i) {\n this.accommodate(2);\n this.data.setInt16(this.write, i, true);\n this.write += 2;\n return this;\n};\n\n/**\n * Puts a 24-bit integer in this buffer in little-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt24Le = function(i) {\n this.accommodate(3);\n this.data.setInt8(this.write, i >> 16 & 0xFF);\n this.data.setInt16(this.write, i >> 8 & 0xFFFF, true);\n this.write += 3;\n return this;\n};\n\n/**\n * Puts a 32-bit integer in this buffer in little-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt32Le = function(i) {\n this.accommodate(4);\n this.data.setInt32(this.write, i, true);\n this.write += 4;\n return this;\n};\n\n/**\n * Puts an n-bit integer in this buffer in big-endian order.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt = function(i, n) {\n _checkBitsParam(n);\n this.accommodate(n / 8);\n do {\n n -= 8;\n this.data.setInt8(this.write++, (i >> n) & 0xFF);\n } while(n > 0);\n return this;\n};\n\n/**\n * Puts a signed n-bit integer in this buffer in big-endian order. Two's\n * complement representation is used.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putSignedInt = function(i, n) {\n _checkBitsParam(n);\n this.accommodate(n / 8);\n if(i < 0) {\n i += 2 << (n - 1);\n }\n return this.putInt(i, n);\n};\n\n/**\n * Gets a byte from this buffer and advances the read pointer by 1.\n *\n * @return the byte.\n */\nutil.DataBuffer.prototype.getByte = function() {\n return this.data.getInt8(this.read++);\n};\n\n/**\n * Gets a uint16 from this buffer in big-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.DataBuffer.prototype.getInt16 = function() {\n var rval = this.data.getInt16(this.read);\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in big-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.DataBuffer.prototype.getInt24 = function() {\n var rval = (\n this.data.getInt16(this.read) << 8 ^\n this.data.getInt8(this.read + 2));\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in big-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.DataBuffer.prototype.getInt32 = function() {\n var rval = this.data.getInt32(this.read);\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets a uint16 from this buffer in little-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.DataBuffer.prototype.getInt16Le = function() {\n var rval = this.data.getInt16(this.read, true);\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in little-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.DataBuffer.prototype.getInt24Le = function() {\n var rval = (\n this.data.getInt8(this.read) ^\n this.data.getInt16(this.read + 1, true) << 8);\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in little-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.DataBuffer.prototype.getInt32Le = function() {\n var rval = this.data.getInt32(this.read, true);\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets an n-bit integer from this buffer in big-endian order and advances the\n * read pointer by n/8.\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.DataBuffer.prototype.getInt = function(n) {\n _checkBitsParam(n);\n var rval = 0;\n do {\n // TODO: Use (rval * 0x100) if adding support for 33 to 53 bits.\n rval = (rval << 8) + this.data.getInt8(this.read++);\n n -= 8;\n } while(n > 0);\n return rval;\n};\n\n/**\n * Gets a signed n-bit integer from this buffer in big-endian order, using\n * two's complement, and advances the read pointer by n/8.\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.DataBuffer.prototype.getSignedInt = function(n) {\n // getInt checks n\n var x = this.getInt(n);\n var max = 2 << (n - 2);\n if(x >= max) {\n x -= max << 1;\n }\n return x;\n};\n\n/**\n * Reads bytes out as a binary encoded string and clears them from the\n * buffer.\n *\n * @param count the number of bytes to read, undefined or null for all.\n *\n * @return a binary encoded string of bytes.\n */\nutil.DataBuffer.prototype.getBytes = function(count) {\n // TODO: deprecate this method, it is poorly named and\n // this.toString('binary') replaces it\n // add a toTypedArray()/toArrayBuffer() function\n var rval;\n if(count) {\n // read count bytes\n count = Math.min(this.length(), count);\n rval = this.data.slice(this.read, this.read + count);\n this.read += count;\n } else if(count === 0) {\n rval = '';\n } else {\n // read all bytes, optimize to only copy when needed\n rval = (this.read === 0) ? this.data : this.data.slice(this.read);\n this.clear();\n }\n return rval;\n};\n\n/**\n * Gets a binary encoded string of the bytes from this buffer without\n * modifying the read pointer.\n *\n * @param count the number of bytes to get, omit to get all.\n *\n * @return a string full of binary encoded characters.\n */\nutil.DataBuffer.prototype.bytes = function(count) {\n // TODO: deprecate this method, it is poorly named, add \"getString()\"\n return (typeof(count) === 'undefined' ?\n this.data.slice(this.read) :\n this.data.slice(this.read, this.read + count));\n};\n\n/**\n * Gets a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n *\n * @return the byte.\n */\nutil.DataBuffer.prototype.at = function(i) {\n return this.data.getUint8(this.read + i);\n};\n\n/**\n * Puts a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.setAt = function(i, b) {\n this.data.setUint8(i, b);\n return this;\n};\n\n/**\n * Gets the last byte without modifying the read pointer.\n *\n * @return the last byte.\n */\nutil.DataBuffer.prototype.last = function() {\n return this.data.getUint8(this.write - 1);\n};\n\n/**\n * Creates a copy of this buffer.\n *\n * @return the copy.\n */\nutil.DataBuffer.prototype.copy = function() {\n return new util.DataBuffer(this);\n};\n\n/**\n * Compacts this buffer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.compact = function() {\n if(this.read > 0) {\n var src = new Uint8Array(this.data.buffer, this.read);\n var dst = new Uint8Array(src.byteLength);\n dst.set(src);\n this.data = new DataView(dst);\n this.write -= this.read;\n this.read = 0;\n }\n return this;\n};\n\n/**\n * Clears this buffer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.clear = function() {\n this.data = new DataView(new ArrayBuffer(0));\n this.read = this.write = 0;\n return this;\n};\n\n/**\n * Shortens this buffer by triming bytes off of the end of this buffer.\n *\n * @param count the number of bytes to trim off.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.truncate = function(count) {\n this.write = Math.max(0, this.length() - count);\n this.read = Math.min(this.read, this.write);\n return this;\n};\n\n/**\n * Converts this buffer to a hexadecimal string.\n *\n * @return a hexadecimal string.\n */\nutil.DataBuffer.prototype.toHex = function() {\n var rval = '';\n for(var i = this.read; i < this.data.byteLength; ++i) {\n var b = this.data.getUint8(i);\n if(b < 16) {\n rval += '0';\n }\n rval += b.toString(16);\n }\n return rval;\n};\n\n/**\n * Converts this buffer to a string, using the given encoding. If no\n * encoding is given, 'utf8' (UTF-8) is used.\n *\n * @param [encoding] the encoding to use: 'binary', 'utf8', 'utf16', 'hex',\n * 'base64' (default: 'utf8').\n *\n * @return a string representation of the bytes in this buffer.\n */\nutil.DataBuffer.prototype.toString = function(encoding) {\n var view = new Uint8Array(this.data, this.read, this.length());\n encoding = encoding || 'utf8';\n\n // encode to string\n if(encoding === 'binary' || encoding === 'raw') {\n return util.binary.raw.encode(view);\n }\n if(encoding === 'hex') {\n return util.binary.hex.encode(view);\n }\n if(encoding === 'base64') {\n return util.binary.base64.encode(view);\n }\n\n // decode to text\n if(encoding === 'utf8') {\n return util.text.utf8.decode(view);\n }\n if(encoding === 'utf16') {\n return util.text.utf16.decode(view);\n }\n\n throw new Error('Invalid encoding: ' + encoding);\n};\n\n/** End Buffer w/UInt8Array backing */\n\n/**\n * Creates a buffer that stores bytes. A value may be given to populate the\n * buffer with data. This value can either be string of encoded bytes or a\n * regular string of characters. When passing a string of binary encoded\n * bytes, the encoding `raw` should be given. This is also the default. When\n * passing a string of characters, the encoding `utf8` should be given.\n *\n * @param [input] a string with encoded bytes to store in the buffer.\n * @param [encoding] (default: 'raw', other: 'utf8').\n */\nutil.createBuffer = function(input, encoding) {\n // TODO: deprecate, use new ByteBuffer() instead\n encoding = encoding || 'raw';\n if(input !== undefined && encoding === 'utf8') {\n input = util.encodeUtf8(input);\n }\n return new util.ByteBuffer(input);\n};\n\n/**\n * Fills a string with a particular value. If you want the string to be a byte\n * string, pass in String.fromCharCode(theByte).\n *\n * @param c the character to fill the string with, use String.fromCharCode\n * to fill the string with a byte value.\n * @param n the number of characters of value c to fill with.\n *\n * @return the filled string.\n */\nutil.fillString = function(c, n) {\n var s = '';\n while(n > 0) {\n if(n & 1) {\n s += c;\n }\n n >>>= 1;\n if(n > 0) {\n c += c;\n }\n }\n return s;\n};\n\n/**\n * Performs a per byte XOR between two byte strings and returns the result as a\n * string of bytes.\n *\n * @param s1 first string of bytes.\n * @param s2 second string of bytes.\n * @param n the number of bytes to XOR.\n *\n * @return the XOR'd result.\n */\nutil.xorBytes = function(s1, s2, n) {\n var s3 = '';\n var b = '';\n var t = '';\n var i = 0;\n var c = 0;\n for(; n > 0; --n, ++i) {\n b = s1.charCodeAt(i) ^ s2.charCodeAt(i);\n if(c >= 10) {\n s3 += t;\n t = '';\n c = 0;\n }\n t += String.fromCharCode(b);\n ++c;\n }\n s3 += t;\n return s3;\n};\n\n/**\n * Converts a hex string into a 'binary' encoded string of bytes.\n *\n * @param hex the hexadecimal string to convert.\n *\n * @return the binary-encoded string of bytes.\n */\nutil.hexToBytes = function(hex) {\n // TODO: deprecate: \"Deprecated. Use util.binary.hex.decode instead.\"\n var rval = '';\n var i = 0;\n if(hex.length & 1 == 1) {\n // odd number of characters, convert first character alone\n i = 1;\n rval += String.fromCharCode(parseInt(hex[0], 16));\n }\n // convert 2 characters (1 byte) at a time\n for(; i < hex.length; i += 2) {\n rval += String.fromCharCode(parseInt(hex.substr(i, 2), 16));\n }\n return rval;\n};\n\n/**\n * Converts a 'binary' encoded string of bytes to hex.\n *\n * @param bytes the byte string to convert.\n *\n * @return the string of hexadecimal characters.\n */\nutil.bytesToHex = function(bytes) {\n // TODO: deprecate: \"Deprecated. Use util.binary.hex.encode instead.\"\n return util.createBuffer(bytes).toHex();\n};\n\n/**\n * Converts an 32-bit integer to 4-big-endian byte string.\n *\n * @param i the integer.\n *\n * @return the byte string.\n */\nutil.int32ToBytes = function(i) {\n return (\n String.fromCharCode(i >> 24 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n// base64 characters, reverse mapping\nvar _base64 =\n 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';\nvar _base64Idx = [\n/*43 -43 = 0*/\n/*'+', 1, 2, 3,'/' */\n 62, -1, -1, -1, 63,\n\n/*'0','1','2','3','4','5','6','7','8','9' */\n 52, 53, 54, 55, 56, 57, 58, 59, 60, 61,\n\n/*15, 16, 17,'=', 19, 20, 21 */\n -1, -1, -1, 64, -1, -1, -1,\n\n/*65 - 43 = 22*/\n/*'A','B','C','D','E','F','G','H','I','J','K','L','M', */\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,\n\n/*'N','O','P','Q','R','S','T','U','V','W','X','Y','Z' */\n 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25,\n\n/*91 - 43 = 48 */\n/*48, 49, 50, 51, 52, 53 */\n -1, -1, -1, -1, -1, -1,\n\n/*97 - 43 = 54*/\n/*'a','b','c','d','e','f','g','h','i','j','k','l','m' */\n 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,\n\n/*'n','o','p','q','r','s','t','u','v','w','x','y','z' */\n 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51\n];\n\n// base58 characters (Bitcoin alphabet)\nvar _base58 = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';\n\n/**\n * Base64 encodes a 'binary' encoded string of bytes.\n *\n * @param input the binary encoded string of bytes to base64-encode.\n * @param maxline the maximum number of encoded characters per line to use,\n * defaults to none.\n *\n * @return the base64-encoded output.\n */\nutil.encode64 = function(input, maxline) {\n // TODO: deprecate: \"Deprecated. Use util.binary.base64.encode instead.\"\n var line = '';\n var output = '';\n var chr1, chr2, chr3;\n var i = 0;\n while(i < input.length) {\n chr1 = input.charCodeAt(i++);\n chr2 = input.charCodeAt(i++);\n chr3 = input.charCodeAt(i++);\n\n // encode 4 character group\n line += _base64.charAt(chr1 >> 2);\n line += _base64.charAt(((chr1 & 3) << 4) | (chr2 >> 4));\n if(isNaN(chr2)) {\n line += '==';\n } else {\n line += _base64.charAt(((chr2 & 15) << 2) | (chr3 >> 6));\n line += isNaN(chr3) ? '=' : _base64.charAt(chr3 & 63);\n }\n\n if(maxline && line.length > maxline) {\n output += line.substr(0, maxline) + '\\r\\n';\n line = line.substr(maxline);\n }\n }\n output += line;\n return output;\n};\n\n/**\n * Base64 decodes a string into a 'binary' encoded string of bytes.\n *\n * @param input the base64-encoded input.\n *\n * @return the binary encoded string.\n */\nutil.decode64 = function(input) {\n // TODO: deprecate: \"Deprecated. Use util.binary.base64.decode instead.\"\n\n // remove all non-base64 characters\n input = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, '');\n\n var output = '';\n var enc1, enc2, enc3, enc4;\n var i = 0;\n\n while(i < input.length) {\n enc1 = _base64Idx[input.charCodeAt(i++) - 43];\n enc2 = _base64Idx[input.charCodeAt(i++) - 43];\n enc3 = _base64Idx[input.charCodeAt(i++) - 43];\n enc4 = _base64Idx[input.charCodeAt(i++) - 43];\n\n output += String.fromCharCode((enc1 << 2) | (enc2 >> 4));\n if(enc3 !== 64) {\n // decoded at least 2 bytes\n output += String.fromCharCode(((enc2 & 15) << 4) | (enc3 >> 2));\n if(enc4 !== 64) {\n // decoded 3 bytes\n output += String.fromCharCode(((enc3 & 3) << 6) | enc4);\n }\n }\n }\n\n return output;\n};\n\n/**\n * Encodes the given string of characters (a standard JavaScript\n * string) as a binary encoded string where the bytes represent\n * a UTF-8 encoded string of characters. Non-ASCII characters will be\n * encoded as multiple bytes according to UTF-8.\n *\n * @param str a standard string of characters to encode.\n *\n * @return the binary encoded string.\n */\nutil.encodeUtf8 = function(str) {\n return unescape(encodeURIComponent(str));\n};\n\n/**\n * Decodes a binary encoded string that contains bytes that\n * represent a UTF-8 encoded string of characters -- into a\n * string of characters (a standard JavaScript string).\n *\n * @param str the binary encoded string to decode.\n *\n * @return the resulting standard string of characters.\n */\nutil.decodeUtf8 = function(str) {\n return decodeURIComponent(escape(str));\n};\n\n// binary encoding/decoding tools\n// FIXME: Experimental. Do not use yet.\nutil.binary = {\n raw: {},\n hex: {},\n base64: {},\n base58: {},\n baseN : {\n encode: baseN.encode,\n decode: baseN.decode\n }\n};\n\n/**\n * Encodes a Uint8Array as a binary-encoded string. This encoding uses\n * a value between 0 and 255 for each character.\n *\n * @param bytes the Uint8Array to encode.\n *\n * @return the binary-encoded string.\n */\nutil.binary.raw.encode = function(bytes) {\n return String.fromCharCode.apply(null, bytes);\n};\n\n/**\n * Decodes a binary-encoded string to a Uint8Array. This encoding uses\n * a value between 0 and 255 for each character.\n *\n * @param str the binary-encoded string to decode.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.binary.raw.decode = function(str, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(str.length);\n }\n offset = offset || 0;\n var j = offset;\n for(var i = 0; i < str.length; ++i) {\n out[j++] = str.charCodeAt(i);\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Encodes a 'binary' string, ArrayBuffer, DataView, TypedArray, or\n * ByteBuffer as a string of hexadecimal characters.\n *\n * @param bytes the bytes to convert.\n *\n * @return the string of hexadecimal characters.\n */\nutil.binary.hex.encode = util.bytesToHex;\n\n/**\n * Decodes a hex-encoded string to a Uint8Array.\n *\n * @param hex the hexadecimal string to convert.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.binary.hex.decode = function(hex, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(Math.ceil(hex.length / 2));\n }\n offset = offset || 0;\n var i = 0, j = offset;\n if(hex.length & 1) {\n // odd number of characters, convert first character alone\n i = 1;\n out[j++] = parseInt(hex[0], 16);\n }\n // convert 2 characters (1 byte) at a time\n for(; i < hex.length; i += 2) {\n out[j++] = parseInt(hex.substr(i, 2), 16);\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Base64-encodes a Uint8Array.\n *\n * @param input the Uint8Array to encode.\n * @param maxline the maximum number of encoded characters per line to use,\n * defaults to none.\n *\n * @return the base64-encoded output string.\n */\nutil.binary.base64.encode = function(input, maxline) {\n var line = '';\n var output = '';\n var chr1, chr2, chr3;\n var i = 0;\n while(i < input.byteLength) {\n chr1 = input[i++];\n chr2 = input[i++];\n chr3 = input[i++];\n\n // encode 4 character group\n line += _base64.charAt(chr1 >> 2);\n line += _base64.charAt(((chr1 & 3) << 4) | (chr2 >> 4));\n if(isNaN(chr2)) {\n line += '==';\n } else {\n line += _base64.charAt(((chr2 & 15) << 2) | (chr3 >> 6));\n line += isNaN(chr3) ? '=' : _base64.charAt(chr3 & 63);\n }\n\n if(maxline && line.length > maxline) {\n output += line.substr(0, maxline) + '\\r\\n';\n line = line.substr(maxline);\n }\n }\n output += line;\n return output;\n};\n\n/**\n * Decodes a base64-encoded string to a Uint8Array.\n *\n * @param input the base64-encoded input string.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.binary.base64.decode = function(input, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(Math.ceil(input.length / 4) * 3);\n }\n\n // remove all non-base64 characters\n input = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, '');\n\n offset = offset || 0;\n var enc1, enc2, enc3, enc4;\n var i = 0, j = offset;\n\n while(i < input.length) {\n enc1 = _base64Idx[input.charCodeAt(i++) - 43];\n enc2 = _base64Idx[input.charCodeAt(i++) - 43];\n enc3 = _base64Idx[input.charCodeAt(i++) - 43];\n enc4 = _base64Idx[input.charCodeAt(i++) - 43];\n\n out[j++] = (enc1 << 2) | (enc2 >> 4);\n if(enc3 !== 64) {\n // decoded at least 2 bytes\n out[j++] = ((enc2 & 15) << 4) | (enc3 >> 2);\n if(enc4 !== 64) {\n // decoded 3 bytes\n out[j++] = ((enc3 & 3) << 6) | enc4;\n }\n }\n }\n\n // make sure result is the exact decoded length\n return output ? (j - offset) : out.subarray(0, j);\n};\n\n// add support for base58 encoding/decoding with Bitcoin alphabet\nutil.binary.base58.encode = function(input, maxline) {\n return util.binary.baseN.encode(input, _base58, maxline);\n};\nutil.binary.base58.decode = function(input, maxline) {\n return util.binary.baseN.decode(input, _base58, maxline);\n};\n\n// text encoding/decoding tools\n// FIXME: Experimental. Do not use yet.\nutil.text = {\n utf8: {},\n utf16: {}\n};\n\n/**\n * Encodes the given string as UTF-8 in a Uint8Array.\n *\n * @param str the string to encode.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.text.utf8.encode = function(str, output, offset) {\n str = util.encodeUtf8(str);\n var out = output;\n if(!out) {\n out = new Uint8Array(str.length);\n }\n offset = offset || 0;\n var j = offset;\n for(var i = 0; i < str.length; ++i) {\n out[j++] = str.charCodeAt(i);\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Decodes the UTF-8 contents from a Uint8Array.\n *\n * @param bytes the Uint8Array to decode.\n *\n * @return the resulting string.\n */\nutil.text.utf8.decode = function(bytes) {\n return util.decodeUtf8(String.fromCharCode.apply(null, bytes));\n};\n\n/**\n * Encodes the given string as UTF-16 in a Uint8Array.\n *\n * @param str the string to encode.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.text.utf16.encode = function(str, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(str.length * 2);\n }\n var view = new Uint16Array(out.buffer);\n offset = offset || 0;\n var j = offset;\n var k = offset;\n for(var i = 0; i < str.length; ++i) {\n view[k++] = str.charCodeAt(i);\n j += 2;\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Decodes the UTF-16 contents from a Uint8Array.\n *\n * @param bytes the Uint8Array to decode.\n *\n * @return the resulting string.\n */\nutil.text.utf16.decode = function(bytes) {\n return String.fromCharCode.apply(null, new Uint16Array(bytes.buffer));\n};\n\n/**\n * Deflates the given data using a flash interface.\n *\n * @param api the flash interface.\n * @param bytes the data.\n * @param raw true to return only raw deflate data, false to include zlib\n * header and trailer.\n *\n * @return the deflated data as a string.\n */\nutil.deflate = function(api, bytes, raw) {\n bytes = util.decode64(api.deflate(util.encode64(bytes)).rval);\n\n // strip zlib header and trailer if necessary\n if(raw) {\n // zlib header is 2 bytes (CMF,FLG) where FLG indicates that\n // there is a 4-byte DICT (alder-32) block before the data if\n // its 5th bit is set\n var start = 2;\n var flg = bytes.charCodeAt(1);\n if(flg & 0x20) {\n start = 6;\n }\n // zlib trailer is 4 bytes of adler-32\n bytes = bytes.substring(start, bytes.length - 4);\n }\n\n return bytes;\n};\n\n/**\n * Inflates the given data using a flash interface.\n *\n * @param api the flash interface.\n * @param bytes the data.\n * @param raw true if the incoming data has no zlib header or trailer and is\n * raw DEFLATE data.\n *\n * @return the inflated data as a string, null on error.\n */\nutil.inflate = function(api, bytes, raw) {\n // TODO: add zlib header and trailer if necessary/possible\n var rval = api.inflate(util.encode64(bytes)).rval;\n return (rval === null) ? null : util.decode64(rval);\n};\n\n/**\n * Sets a storage object.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param obj the storage object, null to remove.\n */\nvar _setStorageObject = function(api, id, obj) {\n if(!api) {\n throw new Error('WebStorage not available.');\n }\n\n var rval;\n if(obj === null) {\n rval = api.removeItem(id);\n } else {\n // json-encode and base64-encode object\n obj = util.encode64(JSON.stringify(obj));\n rval = api.setItem(id, obj);\n }\n\n // handle potential flash error\n if(typeof(rval) !== 'undefined' && rval.rval !== true) {\n var error = new Error(rval.error.message);\n error.id = rval.error.id;\n error.name = rval.error.name;\n throw error;\n }\n};\n\n/**\n * Gets a storage object.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n *\n * @return the storage object entry or null if none exists.\n */\nvar _getStorageObject = function(api, id) {\n if(!api) {\n throw new Error('WebStorage not available.');\n }\n\n // get the existing entry\n var rval = api.getItem(id);\n\n /* Note: We check api.init because we can't do (api == localStorage)\n on IE because of \"Class doesn't support Automation\" exception. Only\n the flash api has an init method so this works too, but we need a\n better solution in the future. */\n\n // flash returns item wrapped in an object, handle special case\n if(api.init) {\n if(rval.rval === null) {\n if(rval.error) {\n var error = new Error(rval.error.message);\n error.id = rval.error.id;\n error.name = rval.error.name;\n throw error;\n }\n // no error, but also no item\n rval = null;\n } else {\n rval = rval.rval;\n }\n }\n\n // handle decoding\n if(rval !== null) {\n // base64-decode and json-decode data\n rval = JSON.parse(util.decode64(rval));\n }\n\n return rval;\n};\n\n/**\n * Stores an item in local storage.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param data the data for the item (any javascript object/primitive).\n */\nvar _setItem = function(api, id, key, data) {\n // get storage object\n var obj = _getStorageObject(api, id);\n if(obj === null) {\n // create a new storage object\n obj = {};\n }\n // update key\n obj[key] = data;\n\n // set storage object\n _setStorageObject(api, id, obj);\n};\n\n/**\n * Gets an item from local storage.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n *\n * @return the item.\n */\nvar _getItem = function(api, id, key) {\n // get storage object\n var rval = _getStorageObject(api, id);\n if(rval !== null) {\n // return data at key\n rval = (key in rval) ? rval[key] : null;\n }\n\n return rval;\n};\n\n/**\n * Removes an item from local storage.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n */\nvar _removeItem = function(api, id, key) {\n // get storage object\n var obj = _getStorageObject(api, id);\n if(obj !== null && key in obj) {\n // remove key\n delete obj[key];\n\n // see if entry has no keys remaining\n var empty = true;\n for(var prop in obj) {\n empty = false;\n break;\n }\n if(empty) {\n // remove entry entirely if no keys are left\n obj = null;\n }\n\n // set storage object\n _setStorageObject(api, id, obj);\n }\n};\n\n/**\n * Clears the local disk storage identified by the given ID.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n */\nvar _clearItems = function(api, id) {\n _setStorageObject(api, id, null);\n};\n\n/**\n * Calls a storage function.\n *\n * @param func the function to call.\n * @param args the arguments for the function.\n * @param location the location argument.\n *\n * @return the return value from the function.\n */\nvar _callStorageFunction = function(func, args, location) {\n var rval = null;\n\n // default storage types\n if(typeof(location) === 'undefined') {\n location = ['web', 'flash'];\n }\n\n // apply storage types in order of preference\n var type;\n var done = false;\n var exception = null;\n for(var idx in location) {\n type = location[idx];\n try {\n if(type === 'flash' || type === 'both') {\n if(args[0] === null) {\n throw new Error('Flash local storage not available.');\n }\n rval = func.apply(this, args);\n done = (type === 'flash');\n }\n if(type === 'web' || type === 'both') {\n args[0] = localStorage;\n rval = func.apply(this, args);\n done = true;\n }\n } catch(ex) {\n exception = ex;\n }\n if(done) {\n break;\n }\n }\n\n if(!done) {\n throw exception;\n }\n\n return rval;\n};\n\n/**\n * Stores an item on local disk.\n *\n * The available types of local storage include 'flash', 'web', and 'both'.\n *\n * The type 'flash' refers to flash local storage (SharedObject). In order\n * to use flash local storage, the 'api' parameter must be valid. The type\n * 'web' refers to WebStorage, if supported by the browser. The type 'both'\n * refers to storing using both 'flash' and 'web', not just one or the\n * other.\n *\n * The location array should list the storage types to use in order of\n * preference:\n *\n * ['flash']: flash only storage\n * ['web']: web only storage\n * ['both']: try to store in both\n * ['flash','web']: store in flash first, but if not available, 'web'\n * ['web','flash']: store in web first, but if not available, 'flash'\n *\n * The location array defaults to: ['web', 'flash']\n *\n * @param api the flash interface, null to use only WebStorage.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param data the data for the item (any javascript object/primitive).\n * @param location an array with the preferred types of storage to use.\n */\nutil.setItem = function(api, id, key, data, location) {\n _callStorageFunction(_setItem, arguments, location);\n};\n\n/**\n * Gets an item on local disk.\n *\n * Set setItem() for details on storage types.\n *\n * @param api the flash interface, null to use only WebStorage.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param location an array with the preferred types of storage to use.\n *\n * @return the item.\n */\nutil.getItem = function(api, id, key, location) {\n return _callStorageFunction(_getItem, arguments, location);\n};\n\n/**\n * Removes an item on local disk.\n *\n * Set setItem() for details on storage types.\n *\n * @param api the flash interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param location an array with the preferred types of storage to use.\n */\nutil.removeItem = function(api, id, key, location) {\n _callStorageFunction(_removeItem, arguments, location);\n};\n\n/**\n * Clears the local disk storage identified by the given ID.\n *\n * Set setItem() for details on storage types.\n *\n * @param api the flash interface if flash is available.\n * @param id the storage ID to use.\n * @param location an array with the preferred types of storage to use.\n */\nutil.clearItems = function(api, id, location) {\n _callStorageFunction(_clearItems, arguments, location);\n};\n\n/**\n * Parses the scheme, host, and port from an http(s) url.\n *\n * @param str the url string.\n *\n * @return the parsed url object or null if the url is invalid.\n */\nutil.parseUrl = function(str) {\n // FIXME: this regex looks a bit broken\n var regex = /^(https?):\\/\\/([^:&^\\/]*):?(\\d*)(.*)$/g;\n regex.lastIndex = 0;\n var m = regex.exec(str);\n var url = (m === null) ? null : {\n full: str,\n scheme: m[1],\n host: m[2],\n port: m[3],\n path: m[4]\n };\n if(url) {\n url.fullHost = url.host;\n if(url.port) {\n if(url.port !== 80 && url.scheme === 'http') {\n url.fullHost += ':' + url.port;\n } else if(url.port !== 443 && url.scheme === 'https') {\n url.fullHost += ':' + url.port;\n }\n } else if(url.scheme === 'http') {\n url.port = 80;\n } else if(url.scheme === 'https') {\n url.port = 443;\n }\n url.full = url.scheme + '://' + url.fullHost;\n }\n return url;\n};\n\n/* Storage for query variables */\nvar _queryVariables = null;\n\n/**\n * Returns the window location query variables. Query is parsed on the first\n * call and the same object is returned on subsequent calls. The mapping\n * is from keys to an array of values. Parameters without values will have\n * an object key set but no value added to the value array. Values are\n * unescaped.\n *\n * ...?k1=v1&k2=v2:\n * {\n * \"k1\": [\"v1\"],\n * \"k2\": [\"v2\"]\n * }\n *\n * ...?k1=v1&k1=v2:\n * {\n * \"k1\": [\"v1\", \"v2\"]\n * }\n *\n * ...?k1=v1&k2:\n * {\n * \"k1\": [\"v1\"],\n * \"k2\": []\n * }\n *\n * ...?k1=v1&k1:\n * {\n * \"k1\": [\"v1\"]\n * }\n *\n * ...?k1&k1:\n * {\n * \"k1\": []\n * }\n *\n * @param query the query string to parse (optional, default to cached\n * results from parsing window location search query).\n *\n * @return object mapping keys to variables.\n */\nutil.getQueryVariables = function(query) {\n var parse = function(q) {\n var rval = {};\n var kvpairs = q.split('&');\n for(var i = 0; i < kvpairs.length; i++) {\n var pos = kvpairs[i].indexOf('=');\n var key;\n var val;\n if(pos > 0) {\n key = kvpairs[i].substring(0, pos);\n val = kvpairs[i].substring(pos + 1);\n } else {\n key = kvpairs[i];\n val = null;\n }\n if(!(key in rval)) {\n rval[key] = [];\n }\n // disallow overriding object prototype keys\n if(!(key in Object.prototype) && val !== null) {\n rval[key].push(unescape(val));\n }\n }\n return rval;\n };\n\n var rval;\n if(typeof(query) === 'undefined') {\n // set cached variables if needed\n if(_queryVariables === null) {\n if(typeof(window) !== 'undefined' && window.location && window.location.search) {\n // parse window search query\n _queryVariables = parse(window.location.search.substring(1));\n } else {\n // no query variables available\n _queryVariables = {};\n }\n }\n rval = _queryVariables;\n } else {\n // parse given query\n rval = parse(query);\n }\n return rval;\n};\n\n/**\n * Parses a fragment into a path and query. This method will take a URI\n * fragment and break it up as if it were the main URI. For example:\n * /bar/baz?a=1&b=2\n * results in:\n * {\n * path: [\"bar\", \"baz\"],\n * query: {\"k1\": [\"v1\"], \"k2\": [\"v2\"]}\n * }\n *\n * @return object with a path array and query object.\n */\nutil.parseFragment = function(fragment) {\n // default to whole fragment\n var fp = fragment;\n var fq = '';\n // split into path and query if possible at the first '?'\n var pos = fragment.indexOf('?');\n if(pos > 0) {\n fp = fragment.substring(0, pos);\n fq = fragment.substring(pos + 1);\n }\n // split path based on '/' and ignore first element if empty\n var path = fp.split('/');\n if(path.length > 0 && path[0] === '') {\n path.shift();\n }\n // convert query into object\n var query = (fq === '') ? {} : util.getQueryVariables(fq);\n\n return {\n pathString: fp,\n queryString: fq,\n path: path,\n query: query\n };\n};\n\n/**\n * Makes a request out of a URI-like request string. This is intended to\n * be used where a fragment id (after a URI '#') is parsed as a URI with\n * path and query parts. The string should have a path beginning and\n * delimited by '/' and optional query parameters following a '?'. The\n * query should be a standard URL set of key value pairs delimited by\n * '&'. For backwards compatibility the initial '/' on the path is not\n * required. The request object has the following API, (fully described\n * in the method code):\n * {\n * path: <the path string part>.\n * query: <the query string part>,\n * getPath(i): get part or all of the split path array,\n * getQuery(k, i): get part or all of a query key array,\n * getQueryLast(k, _default): get last element of a query key array.\n * }\n *\n * @return object with request parameters.\n */\nutil.makeRequest = function(reqString) {\n var frag = util.parseFragment(reqString);\n var req = {\n // full path string\n path: frag.pathString,\n // full query string\n query: frag.queryString,\n /**\n * Get path or element in path.\n *\n * @param i optional path index.\n *\n * @return path or part of path if i provided.\n */\n getPath: function(i) {\n return (typeof(i) === 'undefined') ? frag.path : frag.path[i];\n },\n /**\n * Get query, values for a key, or value for a key index.\n *\n * @param k optional query key.\n * @param i optional query key index.\n *\n * @return query, values for a key, or value for a key index.\n */\n getQuery: function(k, i) {\n var rval;\n if(typeof(k) === 'undefined') {\n rval = frag.query;\n } else {\n rval = frag.query[k];\n if(rval && typeof(i) !== 'undefined') {\n rval = rval[i];\n }\n }\n return rval;\n },\n getQueryLast: function(k, _default) {\n var rval;\n var vals = req.getQuery(k);\n if(vals) {\n rval = vals[vals.length - 1];\n } else {\n rval = _default;\n }\n return rval;\n }\n };\n return req;\n};\n\n/**\n * Makes a URI out of a path, an object with query parameters, and a\n * fragment. Uses jQuery.param() internally for query string creation.\n * If the path is an array, it will be joined with '/'.\n *\n * @param path string path or array of strings.\n * @param query object with query parameters. (optional)\n * @param fragment fragment string. (optional)\n *\n * @return string object with request parameters.\n */\nutil.makeLink = function(path, query, fragment) {\n // join path parts if needed\n path = jQuery.isArray(path) ? path.join('/') : path;\n\n var qstr = jQuery.param(query || {});\n fragment = fragment || '';\n return path +\n ((qstr.length > 0) ? ('?' + qstr) : '') +\n ((fragment.length > 0) ? ('#' + fragment) : '');\n};\n\n/**\n * Check if an object is empty.\n *\n * Taken from:\n * http://stackoverflow.com/questions/679915/how-do-i-test-for-an-empty-javascript-object-from-json/679937#679937\n *\n * @param object the object to check.\n */\nutil.isEmpty = function(obj) {\n for(var prop in obj) {\n if(obj.hasOwnProperty(prop)) {\n return false;\n }\n }\n return true;\n};\n\n/**\n * Format with simple printf-style interpolation.\n *\n * %%: literal '%'\n * %s,%o: convert next argument into a string.\n *\n * @param format the string to format.\n * @param ... arguments to interpolate into the format string.\n */\nutil.format = function(format) {\n var re = /%./g;\n // current match\n var match;\n // current part\n var part;\n // current arg index\n var argi = 0;\n // collected parts to recombine later\n var parts = [];\n // last index found\n var last = 0;\n // loop while matches remain\n while((match = re.exec(format))) {\n part = format.substring(last, re.lastIndex - 2);\n // don't add empty strings (ie, parts between %s%s)\n if(part.length > 0) {\n parts.push(part);\n }\n last = re.lastIndex;\n // switch on % code\n var code = match[0][1];\n switch(code) {\n case 's':\n case 'o':\n // check if enough arguments were given\n if(argi < arguments.length) {\n parts.push(arguments[argi++ + 1]);\n } else {\n parts.push('<?>');\n }\n break;\n // FIXME: do proper formating for numbers, etc\n //case 'f':\n //case 'd':\n case '%':\n parts.push('%');\n break;\n default:\n parts.push('<%' + code + '?>');\n }\n }\n // add trailing part of format string\n parts.push(format.substring(last));\n return parts.join('');\n};\n\n/**\n * Formats a number.\n *\n * http://snipplr.com/view/5945/javascript-numberformat--ported-from-php/\n */\nutil.formatNumber = function(number, decimals, dec_point, thousands_sep) {\n // http://kevin.vanzonneveld.net\n // + original by: Jonas Raoni Soares Silva (http://www.jsfromhell.com)\n // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)\n // + bugfix by: Michael White (http://crestidg.com)\n // + bugfix by: Benjamin Lupton\n // + bugfix by: Allan Jensen (http://www.winternet.no)\n // + revised by: Jonas Raoni Soares Silva (http://www.jsfromhell.com)\n // * example 1: number_format(1234.5678, 2, '.', '');\n // * returns 1: 1234.57\n\n var n = number, c = isNaN(decimals = Math.abs(decimals)) ? 2 : decimals;\n var d = dec_point === undefined ? ',' : dec_point;\n var t = thousands_sep === undefined ?\n '.' : thousands_sep, s = n < 0 ? '-' : '';\n var i = parseInt((n = Math.abs(+n || 0).toFixed(c)), 10) + '';\n var j = (i.length > 3) ? i.length % 3 : 0;\n return s + (j ? i.substr(0, j) + t : '') +\n i.substr(j).replace(/(\\d{3})(?=\\d)/g, '$1' + t) +\n (c ? d + Math.abs(n - i).toFixed(c).slice(2) : '');\n};\n\n/**\n * Formats a byte size.\n *\n * http://snipplr.com/view/5949/format-humanize-file-byte-size-presentation-in-javascript/\n */\nutil.formatSize = function(size) {\n if(size >= 1073741824) {\n size = util.formatNumber(size / 1073741824, 2, '.', '') + ' GiB';\n } else if(size >= 1048576) {\n size = util.formatNumber(size / 1048576, 2, '.', '') + ' MiB';\n } else if(size >= 1024) {\n size = util.formatNumber(size / 1024, 0) + ' KiB';\n } else {\n size = util.formatNumber(size, 0) + ' bytes';\n }\n return size;\n};\n\n/**\n * Converts an IPv4 or IPv6 string representation into bytes (in network order).\n *\n * @param ip the IPv4 or IPv6 address to convert.\n *\n * @return the 4-byte IPv6 or 16-byte IPv6 address or null if the address can't\n * be parsed.\n */\nutil.bytesFromIP = function(ip) {\n if(ip.indexOf('.') !== -1) {\n return util.bytesFromIPv4(ip);\n }\n if(ip.indexOf(':') !== -1) {\n return util.bytesFromIPv6(ip);\n }\n return null;\n};\n\n/**\n * Converts an IPv4 string representation into bytes (in network order).\n *\n * @param ip the IPv4 address to convert.\n *\n * @return the 4-byte address or null if the address can't be parsed.\n */\nutil.bytesFromIPv4 = function(ip) {\n ip = ip.split('.');\n if(ip.length !== 4) {\n return null;\n }\n var b = util.createBuffer();\n for(var i = 0; i < ip.length; ++i) {\n var num = parseInt(ip[i], 10);\n if(isNaN(num)) {\n return null;\n }\n b.putByte(num);\n }\n return b.getBytes();\n};\n\n/**\n * Converts an IPv6 string representation into bytes (in network order).\n *\n * @param ip the IPv6 address to convert.\n *\n * @return the 16-byte address or null if the address can't be parsed.\n */\nutil.bytesFromIPv6 = function(ip) {\n var blanks = 0;\n ip = ip.split(':').filter(function(e) {\n if(e.length === 0) ++blanks;\n return true;\n });\n var zeros = (8 - ip.length + blanks) * 2;\n var b = util.createBuffer();\n for(var i = 0; i < 8; ++i) {\n if(!ip[i] || ip[i].length === 0) {\n b.fillWithByte(0, zeros);\n zeros = 0;\n continue;\n }\n var bytes = util.hexToBytes(ip[i]);\n if(bytes.length < 2) {\n b.putByte(0);\n }\n b.putBytes(bytes);\n }\n return b.getBytes();\n};\n\n/**\n * Converts 4-bytes into an IPv4 string representation or 16-bytes into\n * an IPv6 string representation. The bytes must be in network order.\n *\n * @param bytes the bytes to convert.\n *\n * @return the IPv4 or IPv6 string representation if 4 or 16 bytes,\n * respectively, are given, otherwise null.\n */\nutil.bytesToIP = function(bytes) {\n if(bytes.length === 4) {\n return util.bytesToIPv4(bytes);\n }\n if(bytes.length === 16) {\n return util.bytesToIPv6(bytes);\n }\n return null;\n};\n\n/**\n * Converts 4-bytes into an IPv4 string representation. The bytes must be\n * in network order.\n *\n * @param bytes the bytes to convert.\n *\n * @return the IPv4 string representation or null for an invalid # of bytes.\n */\nutil.bytesToIPv4 = function(bytes) {\n if(bytes.length !== 4) {\n return null;\n }\n var ip = [];\n for(var i = 0; i < bytes.length; ++i) {\n ip.push(bytes.charCodeAt(i));\n }\n return ip.join('.');\n};\n\n/**\n * Converts 16-bytes into an IPv16 string representation. The bytes must be\n * in network order.\n *\n * @param bytes the bytes to convert.\n *\n * @return the IPv16 string representation or null for an invalid # of bytes.\n */\nutil.bytesToIPv6 = function(bytes) {\n if(bytes.length !== 16) {\n return null;\n }\n var ip = [];\n var zeroGroups = [];\n var zeroMaxGroup = 0;\n for(var i = 0; i < bytes.length; i += 2) {\n var hex = util.bytesToHex(bytes[i] + bytes[i + 1]);\n // canonicalize zero representation\n while(hex[0] === '0' && hex !== '0') {\n hex = hex.substr(1);\n }\n if(hex === '0') {\n var last = zeroGroups[zeroGroups.length - 1];\n var idx = ip.length;\n if(!last || idx !== last.end + 1) {\n zeroGroups.push({start: idx, end: idx});\n } else {\n last.end = idx;\n if((last.end - last.start) >\n (zeroGroups[zeroMaxGroup].end - zeroGroups[zeroMaxGroup].start)) {\n zeroMaxGroup = zeroGroups.length - 1;\n }\n }\n }\n ip.push(hex);\n }\n if(zeroGroups.length > 0) {\n var group = zeroGroups[zeroMaxGroup];\n // only shorten group of length > 0\n if(group.end - group.start > 0) {\n ip.splice(group.start, group.end - group.start + 1, '');\n if(group.start === 0) {\n ip.unshift('');\n }\n if(group.end === 7) {\n ip.push('');\n }\n }\n }\n return ip.join(':');\n};\n\n/**\n * Estimates the number of processes that can be run concurrently. If\n * creating Web Workers, keep in mind that the main JavaScript process needs\n * its own core.\n *\n * @param options the options to use:\n * update true to force an update (not use the cached value).\n * @param callback(err, max) called once the operation completes.\n */\nutil.estimateCores = function(options, callback) {\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n if('cores' in util && !options.update) {\n return callback(null, util.cores);\n }\n if(typeof navigator !== 'undefined' &&\n 'hardwareConcurrency' in navigator &&\n navigator.hardwareConcurrency > 0) {\n util.cores = navigator.hardwareConcurrency;\n return callback(null, util.cores);\n }\n if(typeof Worker === 'undefined') {\n // workers not available\n util.cores = 1;\n return callback(null, util.cores);\n }\n if(typeof Blob === 'undefined') {\n // can't estimate, default to 2\n util.cores = 2;\n return callback(null, util.cores);\n }\n\n // create worker concurrency estimation code as blob\n var blobUrl = URL.createObjectURL(new Blob(['(',\n function() {\n self.addEventListener('message', function(e) {\n // run worker for 4 ms\n var st = Date.now();\n var et = st + 4;\n while(Date.now() < et);\n self.postMessage({st: st, et: et});\n });\n }.toString(),\n ')()'], {type: 'application/javascript'}));\n\n // take 5 samples using 16 workers\n sample([], 5, 16);\n\n function sample(max, samples, numWorkers) {\n if(samples === 0) {\n // get overlap average\n var avg = Math.floor(max.reduce(function(avg, x) {\n return avg + x;\n }, 0) / max.length);\n util.cores = Math.max(1, avg);\n URL.revokeObjectURL(blobUrl);\n return callback(null, util.cores);\n }\n map(numWorkers, function(err, results) {\n max.push(reduce(numWorkers, results));\n sample(max, samples - 1, numWorkers);\n });\n }\n\n function map(numWorkers, callback) {\n var workers = [];\n var results = [];\n for(var i = 0; i < numWorkers; ++i) {\n var worker = new Worker(blobUrl);\n worker.addEventListener('message', function(e) {\n results.push(e.data);\n if(results.length === numWorkers) {\n for(var i = 0; i < numWorkers; ++i) {\n workers[i].terminate();\n }\n callback(null, results);\n }\n });\n workers.push(worker);\n }\n for(var i = 0; i < numWorkers; ++i) {\n workers[i].postMessage(i);\n }\n }\n\n function reduce(numWorkers, results) {\n // find overlapping time windows\n var overlaps = [];\n for(var n = 0; n < numWorkers; ++n) {\n var r1 = results[n];\n var overlap = overlaps[n] = [];\n for(var i = 0; i < numWorkers; ++i) {\n if(n === i) {\n continue;\n }\n var r2 = results[i];\n if((r1.st > r2.st && r1.st < r2.et) ||\n (r2.st > r1.st && r2.st < r1.et)) {\n overlap.push(i);\n }\n }\n }\n // get maximum overlaps ... don't include overlapping worker itself\n // as the main JS process was also being scheduled during the work and\n // would have to be subtracted from the estimate anyway\n return overlaps.reduce(function(max, overlap) {\n return Math.max(max, overlap.length);\n }, 0);\n }\n};\n","/**\n * Base-N/Base-X encoding/decoding functions.\n *\n * Original implementation from base-x:\n * https://github.com/cryptocoinjs/base-x\n *\n * Which is MIT licensed:\n *\n * The MIT License (MIT)\n *\n * Copyright base-x contributors (c) 2016\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER\n * DEALINGS IN THE SOFTWARE.\n */\nvar api = {};\nmodule.exports = api;\n\n// baseN alphabet indexes\nvar _reverseAlphabets = {};\n\n/**\n * BaseN-encodes a Uint8Array using the given alphabet.\n *\n * @param input the Uint8Array to encode.\n * @param maxline the maximum number of encoded characters per line to use,\n * defaults to none.\n *\n * @return the baseN-encoded output string.\n */\napi.encode = function(input, alphabet, maxline) {\n if(typeof alphabet !== 'string') {\n throw new TypeError('\"alphabet\" must be a string.');\n }\n if(maxline !== undefined && typeof maxline !== 'number') {\n throw new TypeError('\"maxline\" must be a number.');\n }\n\n var output = '';\n\n if(!(input instanceof Uint8Array)) {\n // assume forge byte buffer\n output = _encodeWithByteBuffer(input, alphabet);\n } else {\n var i = 0;\n var base = alphabet.length;\n var first = alphabet.charAt(0);\n var digits = [0];\n for(i = 0; i < input.length; ++i) {\n for(var j = 0, carry = input[i]; j < digits.length; ++j) {\n carry += digits[j] << 8;\n digits[j] = carry % base;\n carry = (carry / base) | 0;\n }\n\n while(carry > 0) {\n digits.push(carry % base);\n carry = (carry / base) | 0;\n }\n }\n\n // deal with leading zeros\n for(i = 0; input[i] === 0 && i < input.length - 1; ++i) {\n output += first;\n }\n // convert digits to a string\n for(i = digits.length - 1; i >= 0; --i) {\n output += alphabet[digits[i]];\n }\n }\n\n if(maxline) {\n var regex = new RegExp('.{1,' + maxline + '}', 'g');\n output = output.match(regex).join('\\r\\n');\n }\n\n return output;\n};\n\n/**\n * Decodes a baseN-encoded (using the given alphabet) string to a\n * Uint8Array.\n *\n * @param input the baseN-encoded input string.\n *\n * @return the Uint8Array.\n */\napi.decode = function(input, alphabet) {\n if(typeof input !== 'string') {\n throw new TypeError('\"input\" must be a string.');\n }\n if(typeof alphabet !== 'string') {\n throw new TypeError('\"alphabet\" must be a string.');\n }\n\n var table = _reverseAlphabets[alphabet];\n if(!table) {\n // compute reverse alphabet\n table = _reverseAlphabets[alphabet] = [];\n for(var i = 0; i < alphabet.length; ++i) {\n table[alphabet.charCodeAt(i)] = i;\n }\n }\n\n // remove whitespace characters\n input = input.replace(/\\s/g, '');\n\n var base = alphabet.length;\n var first = alphabet.charAt(0);\n var bytes = [0];\n for(var i = 0; i < input.length; i++) {\n var value = table[input.charCodeAt(i)];\n if(value === undefined) {\n return;\n }\n\n for(var j = 0, carry = value; j < bytes.length; ++j) {\n carry += bytes[j] * base;\n bytes[j] = carry & 0xff;\n carry >>= 8;\n }\n\n while(carry > 0) {\n bytes.push(carry & 0xff);\n carry >>= 8;\n }\n }\n\n // deal with leading zeros\n for(var k = 0; input[k] === first && k < input.length - 1; ++k) {\n bytes.push(0);\n }\n\n if(typeof Buffer !== 'undefined') {\n return Buffer.from(bytes.reverse());\n }\n\n return new Uint8Array(bytes.reverse());\n};\n\nfunction _encodeWithByteBuffer(input, alphabet) {\n var i = 0;\n var base = alphabet.length;\n var first = alphabet.charAt(0);\n var digits = [0];\n for(i = 0; i < input.length(); ++i) {\n for(var j = 0, carry = input.at(i); j < digits.length; ++j) {\n carry += digits[j] << 8;\n digits[j] = carry % base;\n carry = (carry / base) | 0;\n }\n\n while(carry > 0) {\n digits.push(carry % base);\n carry = (carry / base) | 0;\n }\n }\n\n var output = '';\n\n // deal with leading zeros\n for(i = 0; input.at(i) === 0 && i < input.length() - 1; ++i) {\n output += first;\n }\n // convert digits to a string\n for(i = digits.length - 1; i >= 0; --i) {\n output += alphabet[digits[i]];\n }\n\n return output;\n}\n","/**\n * Object IDs for ASN.1.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\n\nforge.pki = forge.pki || {};\nvar oids = module.exports = forge.pki.oids = forge.oids = forge.oids || {};\n\n// set id to name mapping and name to id mapping\nfunction _IN(id, name) {\n oids[id] = name;\n oids[name] = id;\n}\n// set id to name mapping only\nfunction _I_(id, name) {\n oids[id] = name;\n}\n\n// algorithm OIDs\n_IN('1.2.840.113549.1.1.1', 'rsaEncryption');\n// Note: md2 & md4 not implemented\n//_IN('1.2.840.113549.1.1.2', 'md2WithRSAEncryption');\n//_IN('1.2.840.113549.1.1.3', 'md4WithRSAEncryption');\n_IN('1.2.840.113549.1.1.4', 'md5WithRSAEncryption');\n_IN('1.2.840.113549.1.1.5', 'sha1WithRSAEncryption');\n_IN('1.2.840.113549.1.1.7', 'RSAES-OAEP');\n_IN('1.2.840.113549.1.1.8', 'mgf1');\n_IN('1.2.840.113549.1.1.9', 'pSpecified');\n_IN('1.2.840.113549.1.1.10', 'RSASSA-PSS');\n_IN('1.2.840.113549.1.1.11', 'sha256WithRSAEncryption');\n_IN('1.2.840.113549.1.1.12', 'sha384WithRSAEncryption');\n_IN('1.2.840.113549.1.1.13', 'sha512WithRSAEncryption');\n// Edwards-curve Digital Signature Algorithm (EdDSA) Ed25519\n_IN('1.3.101.112', 'EdDSA25519');\n\n_IN('1.2.840.10040.4.3', 'dsa-with-sha1');\n\n_IN('1.3.14.3.2.7', 'desCBC');\n\n_IN('1.3.14.3.2.26', 'sha1');\n_IN('2.16.840.1.101.3.4.2.1', 'sha256');\n_IN('2.16.840.1.101.3.4.2.2', 'sha384');\n_IN('2.16.840.1.101.3.4.2.3', 'sha512');\n_IN('1.2.840.113549.2.5', 'md5');\n\n// pkcs#7 content types\n_IN('1.2.840.113549.1.7.1', 'data');\n_IN('1.2.840.113549.1.7.2', 'signedData');\n_IN('1.2.840.113549.1.7.3', 'envelopedData');\n_IN('1.2.840.113549.1.7.4', 'signedAndEnvelopedData');\n_IN('1.2.840.113549.1.7.5', 'digestedData');\n_IN('1.2.840.113549.1.7.6', 'encryptedData');\n\n// pkcs#9 oids\n_IN('1.2.840.113549.1.9.1', 'emailAddress');\n_IN('1.2.840.113549.1.9.2', 'unstructuredName');\n_IN('1.2.840.113549.1.9.3', 'contentType');\n_IN('1.2.840.113549.1.9.4', 'messageDigest');\n_IN('1.2.840.113549.1.9.5', 'signingTime');\n_IN('1.2.840.113549.1.9.6', 'counterSignature');\n_IN('1.2.840.113549.1.9.7', 'challengePassword');\n_IN('1.2.840.113549.1.9.8', 'unstructuredAddress');\n_IN('1.2.840.113549.1.9.14', 'extensionRequest');\n\n_IN('1.2.840.113549.1.9.20', 'friendlyName');\n_IN('1.2.840.113549.1.9.21', 'localKeyId');\n_IN('1.2.840.113549.1.9.22.1', 'x509Certificate');\n\n// pkcs#12 safe bags\n_IN('1.2.840.113549.1.12.10.1.1', 'keyBag');\n_IN('1.2.840.113549.1.12.10.1.2', 'pkcs8ShroudedKeyBag');\n_IN('1.2.840.113549.1.12.10.1.3', 'certBag');\n_IN('1.2.840.113549.1.12.10.1.4', 'crlBag');\n_IN('1.2.840.113549.1.12.10.1.5', 'secretBag');\n_IN('1.2.840.113549.1.12.10.1.6', 'safeContentsBag');\n\n// password-based-encryption for pkcs#12\n_IN('1.2.840.113549.1.5.13', 'pkcs5PBES2');\n_IN('1.2.840.113549.1.5.12', 'pkcs5PBKDF2');\n\n_IN('1.2.840.113549.1.12.1.1', 'pbeWithSHAAnd128BitRC4');\n_IN('1.2.840.113549.1.12.1.2', 'pbeWithSHAAnd40BitRC4');\n_IN('1.2.840.113549.1.12.1.3', 'pbeWithSHAAnd3-KeyTripleDES-CBC');\n_IN('1.2.840.113549.1.12.1.4', 'pbeWithSHAAnd2-KeyTripleDES-CBC');\n_IN('1.2.840.113549.1.12.1.5', 'pbeWithSHAAnd128BitRC2-CBC');\n_IN('1.2.840.113549.1.12.1.6', 'pbewithSHAAnd40BitRC2-CBC');\n\n// hmac OIDs\n_IN('1.2.840.113549.2.7', 'hmacWithSHA1');\n_IN('1.2.840.113549.2.8', 'hmacWithSHA224');\n_IN('1.2.840.113549.2.9', 'hmacWithSHA256');\n_IN('1.2.840.113549.2.10', 'hmacWithSHA384');\n_IN('1.2.840.113549.2.11', 'hmacWithSHA512');\n\n// symmetric key algorithm oids\n_IN('1.2.840.113549.3.7', 'des-EDE3-CBC');\n_IN('2.16.840.1.101.3.4.1.2', 'aes128-CBC');\n_IN('2.16.840.1.101.3.4.1.22', 'aes192-CBC');\n_IN('2.16.840.1.101.3.4.1.42', 'aes256-CBC');\n\n// certificate issuer/subject OIDs\n_IN('2.5.4.3', 'commonName');\n_IN('2.5.4.5', 'serialName');\n_IN('2.5.4.6', 'countryName');\n_IN('2.5.4.7', 'localityName');\n_IN('2.5.4.8', 'stateOrProvinceName');\n_IN('2.5.4.9', 'streetAddress');\n_IN('2.5.4.10', 'organizationName');\n_IN('2.5.4.11', 'organizationalUnitName');\n_IN('2.5.4.13', 'description');\n_IN('2.5.4.15', 'businessCategory');\n_IN('2.5.4.17', 'postalCode');\n_IN('1.3.6.1.4.1.311.60.2.1.2', 'jurisdictionOfIncorporationStateOrProvinceName');\n_IN('1.3.6.1.4.1.311.60.2.1.3', 'jurisdictionOfIncorporationCountryName');\n\n// X.509 extension OIDs\n_IN('2.16.840.1.113730.1.1', 'nsCertType');\n_IN('2.16.840.1.113730.1.13', 'nsComment'); // deprecated in theory; still widely used\n_I_('2.5.29.1', 'authorityKeyIdentifier'); // deprecated, use .35\n_I_('2.5.29.2', 'keyAttributes'); // obsolete use .37 or .15\n_I_('2.5.29.3', 'certificatePolicies'); // deprecated, use .32\n_I_('2.5.29.4', 'keyUsageRestriction'); // obsolete use .37 or .15\n_I_('2.5.29.5', 'policyMapping'); // deprecated use .33\n_I_('2.5.29.6', 'subtreesConstraint'); // obsolete use .30\n_I_('2.5.29.7', 'subjectAltName'); // deprecated use .17\n_I_('2.5.29.8', 'issuerAltName'); // deprecated use .18\n_I_('2.5.29.9', 'subjectDirectoryAttributes');\n_I_('2.5.29.10', 'basicConstraints'); // deprecated use .19\n_I_('2.5.29.11', 'nameConstraints'); // deprecated use .30\n_I_('2.5.29.12', 'policyConstraints'); // deprecated use .36\n_I_('2.5.29.13', 'basicConstraints'); // deprecated use .19\n_IN('2.5.29.14', 'subjectKeyIdentifier');\n_IN('2.5.29.15', 'keyUsage');\n_I_('2.5.29.16', 'privateKeyUsagePeriod');\n_IN('2.5.29.17', 'subjectAltName');\n_IN('2.5.29.18', 'issuerAltName');\n_IN('2.5.29.19', 'basicConstraints');\n_I_('2.5.29.20', 'cRLNumber');\n_I_('2.5.29.21', 'cRLReason');\n_I_('2.5.29.22', 'expirationDate');\n_I_('2.5.29.23', 'instructionCode');\n_I_('2.5.29.24', 'invalidityDate');\n_I_('2.5.29.25', 'cRLDistributionPoints'); // deprecated use .31\n_I_('2.5.29.26', 'issuingDistributionPoint'); // deprecated use .28\n_I_('2.5.29.27', 'deltaCRLIndicator');\n_I_('2.5.29.28', 'issuingDistributionPoint');\n_I_('2.5.29.29', 'certificateIssuer');\n_I_('2.5.29.30', 'nameConstraints');\n_IN('2.5.29.31', 'cRLDistributionPoints');\n_IN('2.5.29.32', 'certificatePolicies');\n_I_('2.5.29.33', 'policyMappings');\n_I_('2.5.29.34', 'policyConstraints'); // deprecated use .36\n_IN('2.5.29.35', 'authorityKeyIdentifier');\n_I_('2.5.29.36', 'policyConstraints');\n_IN('2.5.29.37', 'extKeyUsage');\n_I_('2.5.29.46', 'freshestCRL');\n_I_('2.5.29.54', 'inhibitAnyPolicy');\n\n// extKeyUsage purposes\n_IN('1.3.6.1.4.1.11129.2.4.2', 'timestampList');\n_IN('1.3.6.1.5.5.7.1.1', 'authorityInfoAccess');\n_IN('1.3.6.1.5.5.7.3.1', 'serverAuth');\n_IN('1.3.6.1.5.5.7.3.2', 'clientAuth');\n_IN('1.3.6.1.5.5.7.3.3', 'codeSigning');\n_IN('1.3.6.1.5.5.7.3.4', 'emailProtection');\n_IN('1.3.6.1.5.5.7.3.8', 'timeStamping');\n","/**\n * Password-based encryption functions.\n *\n * @author Dave Longley\n * @author Stefan Siegl <stesie@brokenpipe.de>\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * An EncryptedPrivateKeyInfo:\n *\n * EncryptedPrivateKeyInfo ::= SEQUENCE {\n * encryptionAlgorithm EncryptionAlgorithmIdentifier,\n * encryptedData EncryptedData }\n *\n * EncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * EncryptedData ::= OCTET STRING\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./md');\nrequire('./oids');\nrequire('./pbkdf2');\nrequire('./pem');\nrequire('./random');\nrequire('./rc2');\nrequire('./rsa');\nrequire('./util');\n\nif(typeof BigInteger === 'undefined') {\n var BigInteger = forge.jsbn.BigInteger;\n}\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n/* Password-based encryption implementation. */\nvar pki = forge.pki = forge.pki || {};\nmodule.exports = pki.pbe = forge.pbe = forge.pbe || {};\nvar oids = pki.oids;\n\n// validator for an EncryptedPrivateKeyInfo structure\n// Note: Currently only works w/algorithm params\nvar encryptedPrivateKeyValidator = {\n name: 'EncryptedPrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedPrivateKeyInfo.encryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encryptionOid'\n }, {\n name: 'AlgorithmIdentifier.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'encryptionParams'\n }]\n }, {\n // encryptedData\n name: 'EncryptedPrivateKeyInfo.encryptedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encryptedData'\n }]\n};\n\n// validator for a PBES2Algorithms structure\n// Note: Currently only works w/PBKDF2 + AES encryption schemes\nvar PBES2AlgorithmsValidator = {\n name: 'PBES2Algorithms',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.keyDerivationFunc',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.keyDerivationFunc.oid',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'kdfOid'\n }, {\n name: 'PBES2Algorithms.params',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.params.salt',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'kdfSalt'\n }, {\n name: 'PBES2Algorithms.params.iterationCount',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'kdfIterationCount'\n }, {\n name: 'PBES2Algorithms.params.keyLength',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n optional: true,\n capture: 'keyLength'\n }, {\n // prf\n name: 'PBES2Algorithms.params.prf',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n value: [{\n name: 'PBES2Algorithms.params.prf.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'prfOid'\n }]\n }]\n }]\n }, {\n name: 'PBES2Algorithms.encryptionScheme',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.encryptionScheme.oid',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encOid'\n }, {\n name: 'PBES2Algorithms.encryptionScheme.iv',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encIv'\n }]\n }]\n};\n\nvar pkcs12PbeParamsValidator = {\n name: 'pkcs-12PbeParams',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'pkcs-12PbeParams.salt',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'salt'\n }, {\n name: 'pkcs-12PbeParams.iterations',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'iterations'\n }]\n};\n\n/**\n * Encrypts a ASN.1 PrivateKeyInfo object, producing an EncryptedPrivateKeyInfo.\n *\n * PBES2Algorithms ALGORITHM-IDENTIFIER ::=\n * { {PBES2-params IDENTIFIED BY id-PBES2}, ...}\n *\n * id-PBES2 OBJECT IDENTIFIER ::= {pkcs-5 13}\n *\n * PBES2-params ::= SEQUENCE {\n * keyDerivationFunc AlgorithmIdentifier {{PBES2-KDFs}},\n * encryptionScheme AlgorithmIdentifier {{PBES2-Encs}}\n * }\n *\n * PBES2-KDFs ALGORITHM-IDENTIFIER ::=\n * { {PBKDF2-params IDENTIFIED BY id-PBKDF2}, ... }\n *\n * PBES2-Encs ALGORITHM-IDENTIFIER ::= { ... }\n *\n * PBKDF2-params ::= SEQUENCE {\n * salt CHOICE {\n * specified OCTET STRING,\n * otherSource AlgorithmIdentifier {{PBKDF2-SaltSources}}\n * },\n * iterationCount INTEGER (1..MAX),\n * keyLength INTEGER (1..MAX) OPTIONAL,\n * prf AlgorithmIdentifier {{PBKDF2-PRFs}} DEFAULT algid-hmacWithSHA1\n * }\n *\n * @param obj the ASN.1 PrivateKeyInfo object.\n * @param password the password to encrypt with.\n * @param options:\n * algorithm the encryption algorithm to use\n * ('aes128', 'aes192', 'aes256', '3des'), defaults to 'aes128'.\n * count the iteration count to use.\n * saltSize the salt size to use.\n * prfAlgorithm the PRF message digest algorithm to use\n * ('sha1', 'sha224', 'sha256', 'sha384', 'sha512')\n *\n * @return the ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptPrivateKeyInfo = function(obj, password, options) {\n // set default options\n options = options || {};\n options.saltSize = options.saltSize || 8;\n options.count = options.count || 2048;\n options.algorithm = options.algorithm || 'aes128';\n options.prfAlgorithm = options.prfAlgorithm || 'sha1';\n\n // generate PBE params\n var salt = forge.random.getBytesSync(options.saltSize);\n var count = options.count;\n var countBytes = asn1.integerToDer(count);\n var dkLen;\n var encryptionAlgorithm;\n var encryptedData;\n if(options.algorithm.indexOf('aes') === 0 || options.algorithm === 'des') {\n // do PBES2\n var ivLen, encOid, cipherFn;\n switch(options.algorithm) {\n case 'aes128':\n dkLen = 16;\n ivLen = 16;\n encOid = oids['aes128-CBC'];\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes192':\n dkLen = 24;\n ivLen = 16;\n encOid = oids['aes192-CBC'];\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes256':\n dkLen = 32;\n ivLen = 16;\n encOid = oids['aes256-CBC'];\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'des':\n dkLen = 8;\n ivLen = 8;\n encOid = oids['desCBC'];\n cipherFn = forge.des.createEncryptionCipher;\n break;\n default:\n var error = new Error('Cannot encrypt private key. Unknown encryption algorithm.');\n error.algorithm = options.algorithm;\n throw error;\n }\n\n // get PRF message digest\n var prfAlgorithm = 'hmacWith' + options.prfAlgorithm.toUpperCase();\n var md = prfAlgorithmToMessageDigest(prfAlgorithm);\n\n // encrypt private key using pbe SHA-1 and AES/DES\n var dk = forge.pkcs5.pbkdf2(password, salt, count, dkLen, md);\n var iv = forge.random.getBytesSync(ivLen);\n var cipher = cipherFn(dk);\n cipher.start(iv);\n cipher.update(asn1.toDer(obj));\n cipher.finish();\n encryptedData = cipher.output.getBytes();\n\n // get PBKDF2-params\n var params = createPbkdf2Params(salt, countBytes, dkLen, prfAlgorithm);\n\n encryptionAlgorithm = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oids['pkcs5PBES2']).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // keyDerivationFunc\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oids['pkcs5PBKDF2']).getBytes()),\n // PBKDF2-params\n params\n ]),\n // encryptionScheme\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(encOid).getBytes()),\n // iv\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, iv)\n ])\n ])\n ]);\n } else if(options.algorithm === '3des') {\n // Do PKCS12 PBE\n dkLen = 24;\n\n var saltBytes = new forge.util.ByteBuffer(salt);\n var dk = pki.pbe.generatePkcs12Key(password, saltBytes, 1, count, dkLen);\n var iv = pki.pbe.generatePkcs12Key(password, saltBytes, 2, count, dkLen);\n var cipher = forge.des.createEncryptionCipher(dk);\n cipher.start(iv);\n cipher.update(asn1.toDer(obj));\n cipher.finish();\n encryptedData = cipher.output.getBytes();\n\n encryptionAlgorithm = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oids['pbeWithSHAAnd3-KeyTripleDES-CBC']).getBytes()),\n // pkcs-12PbeParams\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // salt\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, salt),\n // iteration count\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n countBytes.getBytes())\n ])\n ]);\n } else {\n var error = new Error('Cannot encrypt private key. Unknown encryption algorithm.');\n error.algorithm = options.algorithm;\n throw error;\n }\n\n // EncryptedPrivateKeyInfo\n var rval = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // encryptionAlgorithm\n encryptionAlgorithm,\n // encryptedData\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, encryptedData)\n ]);\n return rval;\n};\n\n/**\n * Decrypts a ASN.1 PrivateKeyInfo object.\n *\n * @param obj the ASN.1 EncryptedPrivateKeyInfo object.\n * @param password the password to decrypt with.\n *\n * @return the ASN.1 PrivateKeyInfo on success, null on failure.\n */\npki.decryptPrivateKeyInfo = function(obj, password) {\n var rval = null;\n\n // get PBE params\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, encryptedPrivateKeyValidator, capture, errors)) {\n var error = new Error('Cannot read encrypted private key. ' +\n 'ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n error.errors = errors;\n throw error;\n }\n\n // get cipher\n var oid = asn1.derToOid(capture.encryptionOid);\n var cipher = pki.pbe.getCipher(oid, capture.encryptionParams, password);\n\n // get encrypted data\n var encrypted = forge.util.createBuffer(capture.encryptedData);\n\n cipher.update(encrypted);\n if(cipher.finish()) {\n rval = asn1.fromDer(cipher.output);\n }\n\n return rval;\n};\n\n/**\n * Converts a EncryptedPrivateKeyInfo to PEM format.\n *\n * @param epki the EncryptedPrivateKeyInfo.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted encrypted private key.\n */\npki.encryptedPrivateKeyToPem = function(epki, maxline) {\n // convert to DER, then PEM-encode\n var msg = {\n type: 'ENCRYPTED PRIVATE KEY',\n body: asn1.toDer(epki).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts a PEM-encoded EncryptedPrivateKeyInfo to ASN.1 format. Decryption\n * is not performed.\n *\n * @param pem the EncryptedPrivateKeyInfo in PEM-format.\n *\n * @return the ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptedPrivateKeyFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'ENCRYPTED PRIVATE KEY') {\n var error = new Error('Could not convert encrypted private key from PEM; ' +\n 'PEM header type is \"ENCRYPTED PRIVATE KEY\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert encrypted private key from PEM; ' +\n 'PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n return asn1.fromDer(msg.body);\n};\n\n/**\n * Encrypts an RSA private key. By default, the key will be wrapped in\n * a PrivateKeyInfo and encrypted to produce a PKCS#8 EncryptedPrivateKeyInfo.\n * This is the standard, preferred way to encrypt a private key.\n *\n * To produce a non-standard PEM-encrypted private key that uses encapsulated\n * headers to indicate the encryption algorithm (old-style non-PKCS#8 OpenSSL\n * private key encryption), set the 'legacy' option to true. Note: Using this\n * option will cause the iteration count to be forced to 1.\n *\n * Note: The 'des' algorithm is supported, but it is not considered to be\n * secure because it only uses a single 56-bit key. If possible, it is highly\n * recommended that a different algorithm be used.\n *\n * @param rsaKey the RSA key to encrypt.\n * @param password the password to use.\n * @param options:\n * algorithm: the encryption algorithm to use\n * ('aes128', 'aes192', 'aes256', '3des', 'des').\n * count: the iteration count to use.\n * saltSize: the salt size to use.\n * legacy: output an old non-PKCS#8 PEM-encrypted+encapsulated\n * headers (DEK-Info) private key.\n *\n * @return the PEM-encoded ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptRsaPrivateKey = function(rsaKey, password, options) {\n // standard PKCS#8\n options = options || {};\n if(!options.legacy) {\n // encrypt PrivateKeyInfo\n var rval = pki.wrapRsaPrivateKey(pki.privateKeyToAsn1(rsaKey));\n rval = pki.encryptPrivateKeyInfo(rval, password, options);\n return pki.encryptedPrivateKeyToPem(rval);\n }\n\n // legacy non-PKCS#8\n var algorithm;\n var iv;\n var dkLen;\n var cipherFn;\n switch(options.algorithm) {\n case 'aes128':\n algorithm = 'AES-128-CBC';\n dkLen = 16;\n iv = forge.random.getBytesSync(16);\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes192':\n algorithm = 'AES-192-CBC';\n dkLen = 24;\n iv = forge.random.getBytesSync(16);\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes256':\n algorithm = 'AES-256-CBC';\n dkLen = 32;\n iv = forge.random.getBytesSync(16);\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case '3des':\n algorithm = 'DES-EDE3-CBC';\n dkLen = 24;\n iv = forge.random.getBytesSync(8);\n cipherFn = forge.des.createEncryptionCipher;\n break;\n case 'des':\n algorithm = 'DES-CBC';\n dkLen = 8;\n iv = forge.random.getBytesSync(8);\n cipherFn = forge.des.createEncryptionCipher;\n break;\n default:\n var error = new Error('Could not encrypt RSA private key; unsupported ' +\n 'encryption algorithm \"' + options.algorithm + '\".');\n error.algorithm = options.algorithm;\n throw error;\n }\n\n // encrypt private key using OpenSSL legacy key derivation\n var dk = forge.pbe.opensslDeriveBytes(password, iv.substr(0, 8), dkLen);\n var cipher = cipherFn(dk);\n cipher.start(iv);\n cipher.update(asn1.toDer(pki.privateKeyToAsn1(rsaKey)));\n cipher.finish();\n\n var msg = {\n type: 'RSA PRIVATE KEY',\n procType: {\n version: '4',\n type: 'ENCRYPTED'\n },\n dekInfo: {\n algorithm: algorithm,\n parameters: forge.util.bytesToHex(iv).toUpperCase()\n },\n body: cipher.output.getBytes()\n };\n return forge.pem.encode(msg);\n};\n\n/**\n * Decrypts an RSA private key.\n *\n * @param pem the PEM-formatted EncryptedPrivateKeyInfo to decrypt.\n * @param password the password to use.\n *\n * @return the RSA key on success, null on failure.\n */\npki.decryptRsaPrivateKey = function(pem, password) {\n var rval = null;\n\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'ENCRYPTED PRIVATE KEY' &&\n msg.type !== 'PRIVATE KEY' &&\n msg.type !== 'RSA PRIVATE KEY') {\n var error = new Error('Could not convert private key from PEM; PEM header type ' +\n 'is not \"ENCRYPTED PRIVATE KEY\", \"PRIVATE KEY\", or \"RSA PRIVATE KEY\".');\n error.headerType = error;\n throw error;\n }\n\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n var dkLen;\n var cipherFn;\n switch(msg.dekInfo.algorithm) {\n case 'DES-CBC':\n dkLen = 8;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n case 'DES-EDE3-CBC':\n dkLen = 24;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n case 'AES-128-CBC':\n dkLen = 16;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'AES-192-CBC':\n dkLen = 24;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'AES-256-CBC':\n dkLen = 32;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'RC2-40-CBC':\n dkLen = 5;\n cipherFn = function(key) {\n return forge.rc2.createDecryptionCipher(key, 40);\n };\n break;\n case 'RC2-64-CBC':\n dkLen = 8;\n cipherFn = function(key) {\n return forge.rc2.createDecryptionCipher(key, 64);\n };\n break;\n case 'RC2-128-CBC':\n dkLen = 16;\n cipherFn = function(key) {\n return forge.rc2.createDecryptionCipher(key, 128);\n };\n break;\n default:\n var error = new Error('Could not decrypt private key; unsupported ' +\n 'encryption algorithm \"' + msg.dekInfo.algorithm + '\".');\n error.algorithm = msg.dekInfo.algorithm;\n throw error;\n }\n\n // use OpenSSL legacy key derivation\n var iv = forge.util.hexToBytes(msg.dekInfo.parameters);\n var dk = forge.pbe.opensslDeriveBytes(password, iv.substr(0, 8), dkLen);\n var cipher = cipherFn(dk);\n cipher.start(iv);\n cipher.update(forge.util.createBuffer(msg.body));\n if(cipher.finish()) {\n rval = cipher.output.getBytes();\n } else {\n return rval;\n }\n } else {\n rval = msg.body;\n }\n\n if(msg.type === 'ENCRYPTED PRIVATE KEY') {\n rval = pki.decryptPrivateKeyInfo(asn1.fromDer(rval), password);\n } else {\n // decryption already performed above\n rval = asn1.fromDer(rval);\n }\n\n if(rval !== null) {\n rval = pki.privateKeyFromAsn1(rval);\n }\n\n return rval;\n};\n\n/**\n * Derives a PKCS#12 key.\n *\n * @param password the password to derive the key material from, null or\n * undefined for none.\n * @param salt the salt, as a ByteBuffer, to use.\n * @param id the PKCS#12 ID byte (1 = key material, 2 = IV, 3 = MAC).\n * @param iter the iteration count.\n * @param n the number of bytes to derive from the password.\n * @param md the message digest to use, defaults to SHA-1.\n *\n * @return a ByteBuffer with the bytes derived from the password.\n */\npki.pbe.generatePkcs12Key = function(password, salt, id, iter, n, md) {\n var j, l;\n\n if(typeof md === 'undefined' || md === null) {\n if(!('sha1' in forge.md)) {\n throw new Error('\"sha1\" hash algorithm unavailable.');\n }\n md = forge.md.sha1.create();\n }\n\n var u = md.digestLength;\n var v = md.blockLength;\n var result = new forge.util.ByteBuffer();\n\n /* Convert password to Unicode byte buffer + trailing 0-byte. */\n var passBuf = new forge.util.ByteBuffer();\n if(password !== null && password !== undefined) {\n for(l = 0; l < password.length; l++) {\n passBuf.putInt16(password.charCodeAt(l));\n }\n passBuf.putInt16(0);\n }\n\n /* Length of salt and password in BYTES. */\n var p = passBuf.length();\n var s = salt.length();\n\n /* 1. Construct a string, D (the \"diversifier\"), by concatenating\n v copies of ID. */\n var D = new forge.util.ByteBuffer();\n D.fillWithByte(id, v);\n\n /* 2. Concatenate copies of the salt together to create a string S of length\n v * ceil(s / v) bytes (the final copy of the salt may be trunacted\n to create S).\n Note that if the salt is the empty string, then so is S. */\n var Slen = v * Math.ceil(s / v);\n var S = new forge.util.ByteBuffer();\n for(l = 0; l < Slen; l++) {\n S.putByte(salt.at(l % s));\n }\n\n /* 3. Concatenate copies of the password together to create a string P of\n length v * ceil(p / v) bytes (the final copy of the password may be\n truncated to create P).\n Note that if the password is the empty string, then so is P. */\n var Plen = v * Math.ceil(p / v);\n var P = new forge.util.ByteBuffer();\n for(l = 0; l < Plen; l++) {\n P.putByte(passBuf.at(l % p));\n }\n\n /* 4. Set I=S||P to be the concatenation of S and P. */\n var I = S;\n I.putBuffer(P);\n\n /* 5. Set c=ceil(n / u). */\n var c = Math.ceil(n / u);\n\n /* 6. For i=1, 2, ..., c, do the following: */\n for(var i = 1; i <= c; i++) {\n /* a) Set Ai=H^r(D||I). (l.e. the rth hash of D||I, H(H(H(...H(D||I)))) */\n var buf = new forge.util.ByteBuffer();\n buf.putBytes(D.bytes());\n buf.putBytes(I.bytes());\n for(var round = 0; round < iter; round++) {\n md.start();\n md.update(buf.getBytes());\n buf = md.digest();\n }\n\n /* b) Concatenate copies of Ai to create a string B of length v bytes (the\n final copy of Ai may be truncated to create B). */\n var B = new forge.util.ByteBuffer();\n for(l = 0; l < v; l++) {\n B.putByte(buf.at(l % u));\n }\n\n /* c) Treating I as a concatenation I0, I1, ..., Ik-1 of v-byte blocks,\n where k=ceil(s / v) + ceil(p / v), modify I by setting\n Ij=(Ij+B+1) mod 2v for each j. */\n var k = Math.ceil(s / v) + Math.ceil(p / v);\n var Inew = new forge.util.ByteBuffer();\n for(j = 0; j < k; j++) {\n var chunk = new forge.util.ByteBuffer(I.getBytes(v));\n var x = 0x1ff;\n for(l = B.length() - 1; l >= 0; l--) {\n x = x >> 8;\n x += B.at(l) + chunk.at(l);\n chunk.setAt(l, x & 0xff);\n }\n Inew.putBuffer(chunk);\n }\n I = Inew;\n\n /* Add Ai to A. */\n result.putBuffer(buf);\n }\n\n result.truncate(result.length() - n);\n return result;\n};\n\n/**\n * Get new Forge cipher object instance.\n *\n * @param oid the OID (in string notation).\n * @param params the ASN.1 params object.\n * @param password the password to decrypt with.\n *\n * @return new cipher object instance.\n */\npki.pbe.getCipher = function(oid, params, password) {\n switch(oid) {\n case pki.oids['pkcs5PBES2']:\n return pki.pbe.getCipherForPBES2(oid, params, password);\n\n case pki.oids['pbeWithSHAAnd3-KeyTripleDES-CBC']:\n case pki.oids['pbewithSHAAnd40BitRC2-CBC']:\n return pki.pbe.getCipherForPKCS12PBE(oid, params, password);\n\n default:\n var error = new Error('Cannot read encrypted PBE data block. Unsupported OID.');\n error.oid = oid;\n error.supportedOids = [\n 'pkcs5PBES2',\n 'pbeWithSHAAnd3-KeyTripleDES-CBC',\n 'pbewithSHAAnd40BitRC2-CBC'\n ];\n throw error;\n }\n};\n\n/**\n * Get new Forge cipher object instance according to PBES2 params block.\n *\n * The returned cipher instance is already started using the IV\n * from PBES2 parameter block.\n *\n * @param oid the PKCS#5 PBKDF2 OID (in string notation).\n * @param params the ASN.1 PBES2-params object.\n * @param password the password to decrypt with.\n *\n * @return new cipher object instance.\n */\npki.pbe.getCipherForPBES2 = function(oid, params, password) {\n // get PBE params\n var capture = {};\n var errors = [];\n if(!asn1.validate(params, PBES2AlgorithmsValidator, capture, errors)) {\n var error = new Error('Cannot read password-based-encryption algorithm ' +\n 'parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n error.errors = errors;\n throw error;\n }\n\n // check oids\n oid = asn1.derToOid(capture.kdfOid);\n if(oid !== pki.oids['pkcs5PBKDF2']) {\n var error = new Error('Cannot read encrypted private key. ' +\n 'Unsupported key derivation function OID.');\n error.oid = oid;\n error.supportedOids = ['pkcs5PBKDF2'];\n throw error;\n }\n oid = asn1.derToOid(capture.encOid);\n if(oid !== pki.oids['aes128-CBC'] &&\n oid !== pki.oids['aes192-CBC'] &&\n oid !== pki.oids['aes256-CBC'] &&\n oid !== pki.oids['des-EDE3-CBC'] &&\n oid !== pki.oids['desCBC']) {\n var error = new Error('Cannot read encrypted private key. ' +\n 'Unsupported encryption scheme OID.');\n error.oid = oid;\n error.supportedOids = [\n 'aes128-CBC', 'aes192-CBC', 'aes256-CBC', 'des-EDE3-CBC', 'desCBC'];\n throw error;\n }\n\n // set PBE params\n var salt = capture.kdfSalt;\n var count = forge.util.createBuffer(capture.kdfIterationCount);\n count = count.getInt(count.length() << 3);\n var dkLen;\n var cipherFn;\n switch(pki.oids[oid]) {\n case 'aes128-CBC':\n dkLen = 16;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'aes192-CBC':\n dkLen = 24;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'aes256-CBC':\n dkLen = 32;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'des-EDE3-CBC':\n dkLen = 24;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n case 'desCBC':\n dkLen = 8;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n }\n\n // get PRF message digest\n var md = prfOidToMessageDigest(capture.prfOid);\n\n // decrypt private key using pbe with chosen PRF and AES/DES\n var dk = forge.pkcs5.pbkdf2(password, salt, count, dkLen, md);\n var iv = capture.encIv;\n var cipher = cipherFn(dk);\n cipher.start(iv);\n\n return cipher;\n};\n\n/**\n * Get new Forge cipher object instance for PKCS#12 PBE.\n *\n * The returned cipher instance is already started using the key & IV\n * derived from the provided password and PKCS#12 PBE salt.\n *\n * @param oid The PKCS#12 PBE OID (in string notation).\n * @param params The ASN.1 PKCS#12 PBE-params object.\n * @param password The password to decrypt with.\n *\n * @return the new cipher object instance.\n */\npki.pbe.getCipherForPKCS12PBE = function(oid, params, password) {\n // get PBE params\n var capture = {};\n var errors = [];\n if(!asn1.validate(params, pkcs12PbeParamsValidator, capture, errors)) {\n var error = new Error('Cannot read password-based-encryption algorithm ' +\n 'parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n error.errors = errors;\n throw error;\n }\n\n var salt = forge.util.createBuffer(capture.salt);\n var count = forge.util.createBuffer(capture.iterations);\n count = count.getInt(count.length() << 3);\n\n var dkLen, dIvLen, cipherFn;\n switch(oid) {\n case pki.oids['pbeWithSHAAnd3-KeyTripleDES-CBC']:\n dkLen = 24;\n dIvLen = 8;\n cipherFn = forge.des.startDecrypting;\n break;\n\n case pki.oids['pbewithSHAAnd40BitRC2-CBC']:\n dkLen = 5;\n dIvLen = 8;\n cipherFn = function(key, iv) {\n var cipher = forge.rc2.createDecryptionCipher(key, 40);\n cipher.start(iv, null);\n return cipher;\n };\n break;\n\n default:\n var error = new Error('Cannot read PKCS #12 PBE data block. Unsupported OID.');\n error.oid = oid;\n throw error;\n }\n\n // get PRF message digest\n var md = prfOidToMessageDigest(capture.prfOid);\n var key = pki.pbe.generatePkcs12Key(password, salt, 1, count, dkLen, md);\n md.start();\n var iv = pki.pbe.generatePkcs12Key(password, salt, 2, count, dIvLen, md);\n\n return cipherFn(key, iv);\n};\n\n/**\n * OpenSSL's legacy key derivation function.\n *\n * See: http://www.openssl.org/docs/crypto/EVP_BytesToKey.html\n *\n * @param password the password to derive the key from.\n * @param salt the salt to use, null for none.\n * @param dkLen the number of bytes needed for the derived key.\n * @param [options] the options to use:\n * [md] an optional message digest object to use.\n */\npki.pbe.opensslDeriveBytes = function(password, salt, dkLen, md) {\n if(typeof md === 'undefined' || md === null) {\n if(!('md5' in forge.md)) {\n throw new Error('\"md5\" hash algorithm unavailable.');\n }\n md = forge.md.md5.create();\n }\n if(salt === null) {\n salt = '';\n }\n var digests = [hash(md, password + salt)];\n for(var length = 16, i = 1; length < dkLen; ++i, length += 16) {\n digests.push(hash(md, digests[i - 1] + password + salt));\n }\n return digests.join('').substr(0, dkLen);\n};\n\nfunction hash(md, bytes) {\n return md.start().update(bytes).digest().getBytes();\n}\n\nfunction prfOidToMessageDigest(prfOid) {\n // get PRF algorithm, default to SHA-1\n var prfAlgorithm;\n if(!prfOid) {\n prfAlgorithm = 'hmacWithSHA1';\n } else {\n prfAlgorithm = pki.oids[asn1.derToOid(prfOid)];\n if(!prfAlgorithm) {\n var error = new Error('Unsupported PRF OID.');\n error.oid = prfOid;\n error.supported = [\n 'hmacWithSHA1', 'hmacWithSHA224', 'hmacWithSHA256', 'hmacWithSHA384',\n 'hmacWithSHA512'];\n throw error;\n }\n }\n return prfAlgorithmToMessageDigest(prfAlgorithm);\n}\n\nfunction prfAlgorithmToMessageDigest(prfAlgorithm) {\n var factory = forge.md;\n switch(prfAlgorithm) {\n case 'hmacWithSHA224':\n factory = forge.md.sha512;\n case 'hmacWithSHA1':\n case 'hmacWithSHA256':\n case 'hmacWithSHA384':\n case 'hmacWithSHA512':\n prfAlgorithm = prfAlgorithm.substr(8).toLowerCase();\n break;\n default:\n var error = new Error('Unsupported PRF algorithm.');\n error.algorithm = prfAlgorithm;\n error.supported = [\n 'hmacWithSHA1', 'hmacWithSHA224', 'hmacWithSHA256', 'hmacWithSHA384',\n 'hmacWithSHA512'];\n throw error;\n }\n if(!factory || !(prfAlgorithm in factory)) {\n throw new Error('Unknown hash algorithm: ' + prfAlgorithm);\n }\n return factory[prfAlgorithm].create();\n}\n\nfunction createPbkdf2Params(salt, countBytes, dkLen, prfAlgorithm) {\n var params = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // salt\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, salt),\n // iteration count\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n countBytes.getBytes())\n ]);\n // when PRF algorithm is not SHA-1 default, add key length and PRF algorithm\n if(prfAlgorithm !== 'hmacWithSHA1') {\n params.value.push(\n // key length\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(dkLen.toString(16))),\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids[prfAlgorithm]).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n }\n return params;\n}\n","/**\n * Advanced Encryption Standard (AES) implementation.\n *\n * This implementation is based on the public domain library 'jscrypto' which\n * was written by:\n *\n * Emily Stark (estark@stanford.edu)\n * Mike Hamburg (mhamburg@stanford.edu)\n * Dan Boneh (dabo@cs.stanford.edu)\n *\n * Parts of this code are based on the OpenSSL implementation of AES:\n * http://www.openssl.org\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./cipher');\nrequire('./cipherModes');\nrequire('./util');\n\n/* AES API */\nmodule.exports = forge.aes = forge.aes || {};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('AES-<mode>', key);\n * cipher.start({iv: iv});\n *\n * Creates an AES cipher object to encrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as a string of bytes, an array of bytes,\n * a byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.startEncrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: false,\n mode: mode\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('AES-<mode>', key);\n *\n * Creates an AES cipher object to encrypt data using the given symmetric key.\n *\n * The key may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.createEncryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: false,\n mode: mode\n });\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('AES-<mode>', key);\n * decipher.start({iv: iv});\n *\n * Creates an AES cipher object to decrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as a string of bytes, an array of bytes,\n * a byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.startDecrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: true,\n mode: mode\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('AES-<mode>', key);\n *\n * Creates an AES cipher object to decrypt data using the given symmetric key.\n *\n * The key may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.createDecryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: true,\n mode: mode\n });\n};\n\n/**\n * Creates a new AES cipher algorithm object.\n *\n * @param name the name of the algorithm.\n * @param mode the mode factory function.\n *\n * @return the AES algorithm object.\n */\nforge.aes.Algorithm = function(name, mode) {\n if(!init) {\n initialize();\n }\n var self = this;\n self.name = name;\n self.mode = new mode({\n blockSize: 16,\n cipher: {\n encrypt: function(inBlock, outBlock) {\n return _updateBlock(self._w, inBlock, outBlock, false);\n },\n decrypt: function(inBlock, outBlock) {\n return _updateBlock(self._w, inBlock, outBlock, true);\n }\n }\n });\n self._init = false;\n};\n\n/**\n * Initializes this AES algorithm by expanding its key.\n *\n * @param options the options to use.\n * key the key to use with this algorithm.\n * decrypt true if the algorithm should be initialized for decryption,\n * false for encryption.\n */\nforge.aes.Algorithm.prototype.initialize = function(options) {\n if(this._init) {\n return;\n }\n\n var key = options.key;\n var tmp;\n\n /* Note: The key may be a string of bytes, an array of bytes, a byte\n buffer, or an array of 32-bit integers. If the key is in bytes, then\n it must be 16, 24, or 32 bytes in length. If it is in 32-bit\n integers, it must be 4, 6, or 8 integers long. */\n\n if(typeof key === 'string' &&\n (key.length === 16 || key.length === 24 || key.length === 32)) {\n // convert key string into byte buffer\n key = forge.util.createBuffer(key);\n } else if(forge.util.isArray(key) &&\n (key.length === 16 || key.length === 24 || key.length === 32)) {\n // convert key integer array into byte buffer\n tmp = key;\n key = forge.util.createBuffer();\n for(var i = 0; i < tmp.length; ++i) {\n key.putByte(tmp[i]);\n }\n }\n\n // convert key byte buffer into 32-bit integer array\n if(!forge.util.isArray(key)) {\n tmp = key;\n key = [];\n\n // key lengths of 16, 24, 32 bytes allowed\n var len = tmp.length();\n if(len === 16 || len === 24 || len === 32) {\n len = len >>> 2;\n for(var i = 0; i < len; ++i) {\n key.push(tmp.getInt32());\n }\n }\n }\n\n // key must be an array of 32-bit integers by now\n if(!forge.util.isArray(key) ||\n !(key.length === 4 || key.length === 6 || key.length === 8)) {\n throw new Error('Invalid key parameter.');\n }\n\n // encryption operation is always used for these modes\n var mode = this.mode.name;\n var encryptOp = (['CFB', 'OFB', 'CTR', 'GCM'].indexOf(mode) !== -1);\n\n // do key expansion\n this._w = _expandKey(key, options.decrypt && !encryptOp);\n this._init = true;\n};\n\n/**\n * Expands a key. Typically only used for testing.\n *\n * @param key the symmetric key to expand, as an array of 32-bit words.\n * @param decrypt true to expand for decryption, false for encryption.\n *\n * @return the expanded key.\n */\nforge.aes._expandKey = function(key, decrypt) {\n if(!init) {\n initialize();\n }\n return _expandKey(key, decrypt);\n};\n\n/**\n * Updates a single block. Typically only used for testing.\n *\n * @param w the expanded key to use.\n * @param input an array of block-size 32-bit words.\n * @param output an array of block-size 32-bit words.\n * @param decrypt true to decrypt, false to encrypt.\n */\nforge.aes._updateBlock = _updateBlock;\n\n/** Register AES algorithms **/\n\nregisterAlgorithm('AES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('AES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('AES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('AES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('AES-CTR', forge.cipher.modes.ctr);\nregisterAlgorithm('AES-GCM', forge.cipher.modes.gcm);\n\nfunction registerAlgorithm(name, mode) {\n var factory = function() {\n return new forge.aes.Algorithm(name, mode);\n };\n forge.cipher.registerAlgorithm(name, factory);\n}\n\n/** AES implementation **/\n\nvar init = false; // not yet initialized\nvar Nb = 4; // number of words comprising the state (AES = 4)\nvar sbox; // non-linear substitution table used in key expansion\nvar isbox; // inversion of sbox\nvar rcon; // round constant word array\nvar mix; // mix-columns table\nvar imix; // inverse mix-columns table\n\n/**\n * Performs initialization, ie: precomputes tables to optimize for speed.\n *\n * One way to understand how AES works is to imagine that 'addition' and\n * 'multiplication' are interfaces that require certain mathematical\n * properties to hold true (ie: they are associative) but they might have\n * different implementations and produce different kinds of results ...\n * provided that their mathematical properties remain true. AES defines\n * its own methods of addition and multiplication but keeps some important\n * properties the same, ie: associativity and distributivity. The\n * explanation below tries to shed some light on how AES defines addition\n * and multiplication of bytes and 32-bit words in order to perform its\n * encryption and decryption algorithms.\n *\n * The basics:\n *\n * The AES algorithm views bytes as binary representations of polynomials\n * that have either 1 or 0 as the coefficients. It defines the addition\n * or subtraction of two bytes as the XOR operation. It also defines the\n * multiplication of two bytes as a finite field referred to as GF(2^8)\n * (Note: 'GF' means \"Galois Field\" which is a field that contains a finite\n * number of elements so GF(2^8) has 256 elements).\n *\n * This means that any two bytes can be represented as binary polynomials;\n * when they multiplied together and modularly reduced by an irreducible\n * polynomial of the 8th degree, the results are the field GF(2^8). The\n * specific irreducible polynomial that AES uses in hexadecimal is 0x11b.\n * This multiplication is associative with 0x01 as the identity:\n *\n * (b * 0x01 = GF(b, 0x01) = b).\n *\n * The operation GF(b, 0x02) can be performed at the byte level by left\n * shifting b once and then XOR'ing it (to perform the modular reduction)\n * with 0x11b if b is >= 128. Repeated application of the multiplication\n * of 0x02 can be used to implement the multiplication of any two bytes.\n *\n * For instance, multiplying 0x57 and 0x13, denoted as GF(0x57, 0x13), can\n * be performed by factoring 0x13 into 0x01, 0x02, and 0x10. Then these\n * factors can each be multiplied by 0x57 and then added together. To do\n * the multiplication, values for 0x57 multiplied by each of these 3 factors\n * can be precomputed and stored in a table. To add them, the values from\n * the table are XOR'd together.\n *\n * AES also defines addition and multiplication of words, that is 4-byte\n * numbers represented as polynomials of 3 degrees where the coefficients\n * are the values of the bytes.\n *\n * The word [a0, a1, a2, a3] is a polynomial a3x^3 + a2x^2 + a1x + a0.\n *\n * Addition is performed by XOR'ing like powers of x. Multiplication\n * is performed in two steps, the first is an algebriac expansion as\n * you would do normally (where addition is XOR). But the result is\n * a polynomial larger than 3 degrees and thus it cannot fit in a word. So\n * next the result is modularly reduced by an AES-specific polynomial of\n * degree 4 which will always produce a polynomial of less than 4 degrees\n * such that it will fit in a word. In AES, this polynomial is x^4 + 1.\n *\n * The modular product of two polynomials 'a' and 'b' is thus:\n *\n * d(x) = d3x^3 + d2x^2 + d1x + d0\n * with\n * d0 = GF(a0, b0) ^ GF(a3, b1) ^ GF(a2, b2) ^ GF(a1, b3)\n * d1 = GF(a1, b0) ^ GF(a0, b1) ^ GF(a3, b2) ^ GF(a2, b3)\n * d2 = GF(a2, b0) ^ GF(a1, b1) ^ GF(a0, b2) ^ GF(a3, b3)\n * d3 = GF(a3, b0) ^ GF(a2, b1) ^ GF(a1, b2) ^ GF(a0, b3)\n *\n * As a matrix:\n *\n * [d0] = [a0 a3 a2 a1][b0]\n * [d1] [a1 a0 a3 a2][b1]\n * [d2] [a2 a1 a0 a3][b2]\n * [d3] [a3 a2 a1 a0][b3]\n *\n * Special polynomials defined by AES (0x02 == {02}):\n * a(x) = {03}x^3 + {01}x^2 + {01}x + {02}\n * a^-1(x) = {0b}x^3 + {0d}x^2 + {09}x + {0e}.\n *\n * These polynomials are used in the MixColumns() and InverseMixColumns()\n * operations, respectively, to cause each element in the state to affect\n * the output (referred to as diffusing).\n *\n * RotWord() uses: a0 = a1 = a2 = {00} and a3 = {01}, which is the\n * polynomial x3.\n *\n * The ShiftRows() method modifies the last 3 rows in the state (where\n * the state is 4 words with 4 bytes per word) by shifting bytes cyclically.\n * The 1st byte in the second row is moved to the end of the row. The 1st\n * and 2nd bytes in the third row are moved to the end of the row. The 1st,\n * 2nd, and 3rd bytes are moved in the fourth row.\n *\n * More details on how AES arithmetic works:\n *\n * In the polynomial representation of binary numbers, XOR performs addition\n * and subtraction and multiplication in GF(2^8) denoted as GF(a, b)\n * corresponds with the multiplication of polynomials modulo an irreducible\n * polynomial of degree 8. In other words, for AES, GF(a, b) will multiply\n * polynomial 'a' with polynomial 'b' and then do a modular reduction by\n * an AES-specific irreducible polynomial of degree 8.\n *\n * A polynomial is irreducible if its only divisors are one and itself. For\n * the AES algorithm, this irreducible polynomial is:\n *\n * m(x) = x^8 + x^4 + x^3 + x + 1,\n *\n * or {01}{1b} in hexadecimal notation, where each coefficient is a bit:\n * 100011011 = 283 = 0x11b.\n *\n * For example, GF(0x57, 0x83) = 0xc1 because\n *\n * 0x57 = 87 = 01010111 = x^6 + x^4 + x^2 + x + 1\n * 0x85 = 131 = 10000101 = x^7 + x + 1\n *\n * (x^6 + x^4 + x^2 + x + 1) * (x^7 + x + 1)\n * = x^13 + x^11 + x^9 + x^8 + x^7 +\n * x^7 + x^5 + x^3 + x^2 + x +\n * x^6 + x^4 + x^2 + x + 1\n * = x^13 + x^11 + x^9 + x^8 + x^6 + x^5 + x^4 + x^3 + 1 = y\n * y modulo (x^8 + x^4 + x^3 + x + 1)\n * = x^7 + x^6 + 1.\n *\n * The modular reduction by m(x) guarantees the result will be a binary\n * polynomial of less than degree 8, so that it can fit in a byte.\n *\n * The operation to multiply a binary polynomial b with x (the polynomial\n * x in binary representation is 00000010) is:\n *\n * b_7x^8 + b_6x^7 + b_5x^6 + b_4x^5 + b_3x^4 + b_2x^3 + b_1x^2 + b_0x^1\n *\n * To get GF(b, x) we must reduce that by m(x). If b_7 is 0 (that is the\n * most significant bit is 0 in b) then the result is already reduced. If\n * it is 1, then we can reduce it by subtracting m(x) via an XOR.\n *\n * It follows that multiplication by x (00000010 or 0x02) can be implemented\n * by performing a left shift followed by a conditional bitwise XOR with\n * 0x1b. This operation on bytes is denoted by xtime(). Multiplication by\n * higher powers of x can be implemented by repeated application of xtime().\n *\n * By adding intermediate results, multiplication by any constant can be\n * implemented. For instance:\n *\n * GF(0x57, 0x13) = 0xfe because:\n *\n * xtime(b) = (b & 128) ? (b << 1 ^ 0x11b) : (b << 1)\n *\n * Note: We XOR with 0x11b instead of 0x1b because in javascript our\n * datatype for b can be larger than 1 byte, so a left shift will not\n * automatically eliminate bits that overflow a byte ... by XOR'ing the\n * overflow bit with 1 (the extra one from 0x11b) we zero it out.\n *\n * GF(0x57, 0x02) = xtime(0x57) = 0xae\n * GF(0x57, 0x04) = xtime(0xae) = 0x47\n * GF(0x57, 0x08) = xtime(0x47) = 0x8e\n * GF(0x57, 0x10) = xtime(0x8e) = 0x07\n *\n * GF(0x57, 0x13) = GF(0x57, (0x01 ^ 0x02 ^ 0x10))\n *\n * And by the distributive property (since XOR is addition and GF() is\n * multiplication):\n *\n * = GF(0x57, 0x01) ^ GF(0x57, 0x02) ^ GF(0x57, 0x10)\n * = 0x57 ^ 0xae ^ 0x07\n * = 0xfe.\n */\nfunction initialize() {\n init = true;\n\n /* Populate the Rcon table. These are the values given by\n [x^(i-1),{00},{00},{00}] where x^(i-1) are powers of x (and x = 0x02)\n in the field of GF(2^8), where i starts at 1.\n\n rcon[0] = [0x00, 0x00, 0x00, 0x00]\n rcon[1] = [0x01, 0x00, 0x00, 0x00] 2^(1-1) = 2^0 = 1\n rcon[2] = [0x02, 0x00, 0x00, 0x00] 2^(2-1) = 2^1 = 2\n ...\n rcon[9] = [0x1B, 0x00, 0x00, 0x00] 2^(9-1) = 2^8 = 0x1B\n rcon[10] = [0x36, 0x00, 0x00, 0x00] 2^(10-1) = 2^9 = 0x36\n\n We only store the first byte because it is the only one used.\n */\n rcon = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1B, 0x36];\n\n // compute xtime table which maps i onto GF(i, 0x02)\n var xtime = new Array(256);\n for(var i = 0; i < 128; ++i) {\n xtime[i] = i << 1;\n xtime[i + 128] = (i + 128) << 1 ^ 0x11B;\n }\n\n // compute all other tables\n sbox = new Array(256);\n isbox = new Array(256);\n mix = new Array(4);\n imix = new Array(4);\n for(var i = 0; i < 4; ++i) {\n mix[i] = new Array(256);\n imix[i] = new Array(256);\n }\n var e = 0, ei = 0, e2, e4, e8, sx, sx2, me, ime;\n for(var i = 0; i < 256; ++i) {\n /* We need to generate the SubBytes() sbox and isbox tables so that\n we can perform byte substitutions. This requires us to traverse\n all of the elements in GF, find their multiplicative inverses,\n and apply to each the following affine transformation:\n\n bi' = bi ^ b(i + 4) mod 8 ^ b(i + 5) mod 8 ^ b(i + 6) mod 8 ^\n b(i + 7) mod 8 ^ ci\n for 0 <= i < 8, where bi is the ith bit of the byte, and ci is the\n ith bit of a byte c with the value {63} or {01100011}.\n\n It is possible to traverse every possible value in a Galois field\n using what is referred to as a 'generator'. There are many\n generators (128 out of 256): 3,5,6,9,11,82 to name a few. To fully\n traverse GF we iterate 255 times, multiplying by our generator\n each time.\n\n On each iteration we can determine the multiplicative inverse for\n the current element.\n\n Suppose there is an element in GF 'e'. For a given generator 'g',\n e = g^x. The multiplicative inverse of e is g^(255 - x). It turns\n out that if use the inverse of a generator as another generator\n it will produce all of the corresponding multiplicative inverses\n at the same time. For this reason, we choose 5 as our inverse\n generator because it only requires 2 multiplies and 1 add and its\n inverse, 82, requires relatively few operations as well.\n\n In order to apply the affine transformation, the multiplicative\n inverse 'ei' of 'e' can be repeatedly XOR'd (4 times) with a\n bit-cycling of 'ei'. To do this 'ei' is first stored in 's' and\n 'x'. Then 's' is left shifted and the high bit of 's' is made the\n low bit. The resulting value is stored in 's'. Then 'x' is XOR'd\n with 's' and stored in 'x'. On each subsequent iteration the same\n operation is performed. When 4 iterations are complete, 'x' is\n XOR'd with 'c' (0x63) and the transformed value is stored in 'x'.\n For example:\n\n s = 01000001\n x = 01000001\n\n iteration 1: s = 10000010, x ^= s\n iteration 2: s = 00000101, x ^= s\n iteration 3: s = 00001010, x ^= s\n iteration 4: s = 00010100, x ^= s\n x ^= 0x63\n\n This can be done with a loop where s = (s << 1) | (s >> 7). However,\n it can also be done by using a single 16-bit (in this case 32-bit)\n number 'sx'. Since XOR is an associative operation, we can set 'sx'\n to 'ei' and then XOR it with 'sx' left-shifted 1,2,3, and 4 times.\n The most significant bits will flow into the high 8 bit positions\n and be correctly XOR'd with one another. All that remains will be\n to cycle the high 8 bits by XOR'ing them all with the lower 8 bits\n afterwards.\n\n At the same time we're populating sbox and isbox we can precompute\n the multiplication we'll need to do to do MixColumns() later.\n */\n\n // apply affine transformation\n sx = ei ^ (ei << 1) ^ (ei << 2) ^ (ei << 3) ^ (ei << 4);\n sx = (sx >> 8) ^ (sx & 255) ^ 0x63;\n\n // update tables\n sbox[e] = sx;\n isbox[sx] = e;\n\n /* Mixing columns is done using matrix multiplication. The columns\n that are to be mixed are each a single word in the current state.\n The state has Nb columns (4 columns). Therefore each column is a\n 4 byte word. So to mix the columns in a single column 'c' where\n its rows are r0, r1, r2, and r3, we use the following matrix\n multiplication:\n\n [2 3 1 1]*[r0,c]=[r'0,c]\n [1 2 3 1] [r1,c] [r'1,c]\n [1 1 2 3] [r2,c] [r'2,c]\n [3 1 1 2] [r3,c] [r'3,c]\n\n r0, r1, r2, and r3 are each 1 byte of one of the words in the\n state (a column). To do matrix multiplication for each mixed\n column c' we multiply the corresponding row from the left matrix\n with the corresponding column from the right matrix. In total, we\n get 4 equations:\n\n r0,c' = 2*r0,c + 3*r1,c + 1*r2,c + 1*r3,c\n r1,c' = 1*r0,c + 2*r1,c + 3*r2,c + 1*r3,c\n r2,c' = 1*r0,c + 1*r1,c + 2*r2,c + 3*r3,c\n r3,c' = 3*r0,c + 1*r1,c + 1*r2,c + 2*r3,c\n\n As usual, the multiplication is as previously defined and the\n addition is XOR. In order to optimize mixing columns we can store\n the multiplication results in tables. If you think of the whole\n column as a word (it might help to visualize by mentally rotating\n the equations above by counterclockwise 90 degrees) then you can\n see that it would be useful to map the multiplications performed on\n each byte (r0, r1, r2, r3) onto a word as well. For instance, we\n could map 2*r0,1*r0,1*r0,3*r0 onto a word by storing 2*r0 in the\n highest 8 bits and 3*r0 in the lowest 8 bits (with the other two\n respectively in the middle). This means that a table can be\n constructed that uses r0 as an index to the word. We can do the\n same with r1, r2, and r3, creating a total of 4 tables.\n\n To construct a full c', we can just look up each byte of c in\n their respective tables and XOR the results together.\n\n Also, to build each table we only have to calculate the word\n for 2,1,1,3 for every byte ... which we can do on each iteration\n of this loop since we will iterate over every byte. After we have\n calculated 2,1,1,3 we can get the results for the other tables\n by cycling the byte at the end to the beginning. For instance\n we can take the result of table 2,1,1,3 and produce table 3,2,1,1\n by moving the right most byte to the left most position just like\n how you can imagine the 3 moved out of 2,1,1,3 and to the front\n to produce 3,2,1,1.\n\n There is another optimization in that the same multiples of\n the current element we need in order to advance our generator\n to the next iteration can be reused in performing the 2,1,1,3\n calculation. We also calculate the inverse mix column tables,\n with e,9,d,b being the inverse of 2,1,1,3.\n\n When we're done, and we need to actually mix columns, the first\n byte of each state word should be put through mix[0] (2,1,1,3),\n the second through mix[1] (3,2,1,1) and so forth. Then they should\n be XOR'd together to produce the fully mixed column.\n */\n\n // calculate mix and imix table values\n sx2 = xtime[sx];\n e2 = xtime[e];\n e4 = xtime[e2];\n e8 = xtime[e4];\n me =\n (sx2 << 24) ^ // 2\n (sx << 16) ^ // 1\n (sx << 8) ^ // 1\n (sx ^ sx2); // 3\n ime =\n (e2 ^ e4 ^ e8) << 24 ^ // E (14)\n (e ^ e8) << 16 ^ // 9\n (e ^ e4 ^ e8) << 8 ^ // D (13)\n (e ^ e2 ^ e8); // B (11)\n // produce each of the mix tables by rotating the 2,1,1,3 value\n for(var n = 0; n < 4; ++n) {\n mix[n][e] = me;\n imix[n][sx] = ime;\n // cycle the right most byte to the left most position\n // ie: 2,1,1,3 becomes 3,2,1,1\n me = me << 24 | me >>> 8;\n ime = ime << 24 | ime >>> 8;\n }\n\n // get next element and inverse\n if(e === 0) {\n // 1 is the inverse of 1\n e = ei = 1;\n } else {\n // e = 2e + 2*2*2*(10e)) = multiply e by 82 (chosen generator)\n // ei = ei + 2*2*ei = multiply ei by 5 (inverse generator)\n e = e2 ^ xtime[xtime[xtime[e2 ^ e8]]];\n ei ^= xtime[xtime[ei]];\n }\n }\n}\n\n/**\n * Generates a key schedule using the AES key expansion algorithm.\n *\n * The AES algorithm takes the Cipher Key, K, and performs a Key Expansion\n * routine to generate a key schedule. The Key Expansion generates a total\n * of Nb*(Nr + 1) words: the algorithm requires an initial set of Nb words,\n * and each of the Nr rounds requires Nb words of key data. The resulting\n * key schedule consists of a linear array of 4-byte words, denoted [wi ],\n * with i in the range 0 <= i < Nb(Nr + 1).\n *\n * KeyExpansion(byte key[4*Nk], word w[Nb*(Nr+1)], Nk)\n * AES-128 (Nb=4, Nk=4, Nr=10)\n * AES-192 (Nb=4, Nk=6, Nr=12)\n * AES-256 (Nb=4, Nk=8, Nr=14)\n * Note: Nr=Nk+6.\n *\n * Nb is the number of columns (32-bit words) comprising the State (or\n * number of bytes in a block). For AES, Nb=4.\n *\n * @param key the key to schedule (as an array of 32-bit words).\n * @param decrypt true to modify the key schedule to decrypt, false not to.\n *\n * @return the generated key schedule.\n */\nfunction _expandKey(key, decrypt) {\n // copy the key's words to initialize the key schedule\n var w = key.slice(0);\n\n /* RotWord() will rotate a word, moving the first byte to the last\n byte's position (shifting the other bytes left).\n\n We will be getting the value of Rcon at i / Nk. 'i' will iterate\n from Nk to (Nb * Nr+1). Nk = 4 (4 byte key), Nb = 4 (4 words in\n a block), Nr = Nk + 6 (10). Therefore 'i' will iterate from\n 4 to 44 (exclusive). Each time we iterate 4 times, i / Nk will\n increase by 1. We use a counter iNk to keep track of this.\n */\n\n // go through the rounds expanding the key\n var temp, iNk = 1;\n var Nk = w.length;\n var Nr1 = Nk + 6 + 1;\n var end = Nb * Nr1;\n for(var i = Nk; i < end; ++i) {\n temp = w[i - 1];\n if(i % Nk === 0) {\n // temp = SubWord(RotWord(temp)) ^ Rcon[i / Nk]\n temp =\n sbox[temp >>> 16 & 255] << 24 ^\n sbox[temp >>> 8 & 255] << 16 ^\n sbox[temp & 255] << 8 ^\n sbox[temp >>> 24] ^ (rcon[iNk] << 24);\n iNk++;\n } else if(Nk > 6 && (i % Nk === 4)) {\n // temp = SubWord(temp)\n temp =\n sbox[temp >>> 24] << 24 ^\n sbox[temp >>> 16 & 255] << 16 ^\n sbox[temp >>> 8 & 255] << 8 ^\n sbox[temp & 255];\n }\n w[i] = w[i - Nk] ^ temp;\n }\n\n /* When we are updating a cipher block we always use the code path for\n encryption whether we are decrypting or not (to shorten code and\n simplify the generation of look up tables). However, because there\n are differences in the decryption algorithm, other than just swapping\n in different look up tables, we must transform our key schedule to\n account for these changes:\n\n 1. The decryption algorithm gets its key rounds in reverse order.\n 2. The decryption algorithm adds the round key before mixing columns\n instead of afterwards.\n\n We don't need to modify our key schedule to handle the first case,\n we can just traverse the key schedule in reverse order when decrypting.\n\n The second case requires a little work.\n\n The tables we built for performing rounds will take an input and then\n perform SubBytes() and MixColumns() or, for the decrypt version,\n InvSubBytes() and InvMixColumns(). But the decrypt algorithm requires\n us to AddRoundKey() before InvMixColumns(). This means we'll need to\n apply some transformations to the round key to inverse-mix its columns\n so they'll be correct for moving AddRoundKey() to after the state has\n had its columns inverse-mixed.\n\n To inverse-mix the columns of the state when we're decrypting we use a\n lookup table that will apply InvSubBytes() and InvMixColumns() at the\n same time. However, the round key's bytes are not inverse-substituted\n in the decryption algorithm. To get around this problem, we can first\n substitute the bytes in the round key so that when we apply the\n transformation via the InvSubBytes()+InvMixColumns() table, it will\n undo our substitution leaving us with the original value that we\n want -- and then inverse-mix that value.\n\n This change will correctly alter our key schedule so that we can XOR\n each round key with our already transformed decryption state. This\n allows us to use the same code path as the encryption algorithm.\n\n We make one more change to the decryption key. Since the decryption\n algorithm runs in reverse from the encryption algorithm, we reverse\n the order of the round keys to avoid having to iterate over the key\n schedule backwards when running the encryption algorithm later in\n decryption mode. In addition to reversing the order of the round keys,\n we also swap each round key's 2nd and 4th rows. See the comments\n section where rounds are performed for more details about why this is\n done. These changes are done inline with the other substitution\n described above.\n */\n if(decrypt) {\n var tmp;\n var m0 = imix[0];\n var m1 = imix[1];\n var m2 = imix[2];\n var m3 = imix[3];\n var wnew = w.slice(0);\n end = w.length;\n for(var i = 0, wi = end - Nb; i < end; i += Nb, wi -= Nb) {\n // do not sub the first or last round key (round keys are Nb\n // words) as no column mixing is performed before they are added,\n // but do change the key order\n if(i === 0 || i === (end - Nb)) {\n wnew[i] = w[wi];\n wnew[i + 1] = w[wi + 3];\n wnew[i + 2] = w[wi + 2];\n wnew[i + 3] = w[wi + 1];\n } else {\n // substitute each round key byte because the inverse-mix\n // table will inverse-substitute it (effectively cancel the\n // substitution because round key bytes aren't sub'd in\n // decryption mode) and swap indexes 3 and 1\n for(var n = 0; n < Nb; ++n) {\n tmp = w[wi + n];\n wnew[i + (3&-n)] =\n m0[sbox[tmp >>> 24]] ^\n m1[sbox[tmp >>> 16 & 255]] ^\n m2[sbox[tmp >>> 8 & 255]] ^\n m3[sbox[tmp & 255]];\n }\n }\n }\n w = wnew;\n }\n\n return w;\n}\n\n/**\n * Updates a single block (16 bytes) using AES. The update will either\n * encrypt or decrypt the block.\n *\n * @param w the key schedule.\n * @param input the input block (an array of 32-bit words).\n * @param output the updated output block.\n * @param decrypt true to decrypt the block, false to encrypt it.\n */\nfunction _updateBlock(w, input, output, decrypt) {\n /*\n Cipher(byte in[4*Nb], byte out[4*Nb], word w[Nb*(Nr+1)])\n begin\n byte state[4,Nb]\n state = in\n AddRoundKey(state, w[0, Nb-1])\n for round = 1 step 1 to Nr-1\n SubBytes(state)\n ShiftRows(state)\n MixColumns(state)\n AddRoundKey(state, w[round*Nb, (round+1)*Nb-1])\n end for\n SubBytes(state)\n ShiftRows(state)\n AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n out = state\n end\n\n InvCipher(byte in[4*Nb], byte out[4*Nb], word w[Nb*(Nr+1)])\n begin\n byte state[4,Nb]\n state = in\n AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n for round = Nr-1 step -1 downto 1\n InvShiftRows(state)\n InvSubBytes(state)\n AddRoundKey(state, w[round*Nb, (round+1)*Nb-1])\n InvMixColumns(state)\n end for\n InvShiftRows(state)\n InvSubBytes(state)\n AddRoundKey(state, w[0, Nb-1])\n out = state\n end\n */\n\n // Encrypt: AddRoundKey(state, w[0, Nb-1])\n // Decrypt: AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n var Nr = w.length / 4 - 1;\n var m0, m1, m2, m3, sub;\n if(decrypt) {\n m0 = imix[0];\n m1 = imix[1];\n m2 = imix[2];\n m3 = imix[3];\n sub = isbox;\n } else {\n m0 = mix[0];\n m1 = mix[1];\n m2 = mix[2];\n m3 = mix[3];\n sub = sbox;\n }\n var a, b, c, d, a2, b2, c2;\n a = input[0] ^ w[0];\n b = input[decrypt ? 3 : 1] ^ w[1];\n c = input[2] ^ w[2];\n d = input[decrypt ? 1 : 3] ^ w[3];\n var i = 3;\n\n /* In order to share code we follow the encryption algorithm when both\n encrypting and decrypting. To account for the changes required in the\n decryption algorithm, we use different lookup tables when decrypting\n and use a modified key schedule to account for the difference in the\n order of transformations applied when performing rounds. We also get\n key rounds in reverse order (relative to encryption). */\n for(var round = 1; round < Nr; ++round) {\n /* As described above, we'll be using table lookups to perform the\n column mixing. Each column is stored as a word in the state (the\n array 'input' has one column as a word at each index). In order to\n mix a column, we perform these transformations on each row in c,\n which is 1 byte in each word. The new column for c0 is c'0:\n\n m0 m1 m2 m3\n r0,c'0 = 2*r0,c0 + 3*r1,c0 + 1*r2,c0 + 1*r3,c0\n r1,c'0 = 1*r0,c0 + 2*r1,c0 + 3*r2,c0 + 1*r3,c0\n r2,c'0 = 1*r0,c0 + 1*r1,c0 + 2*r2,c0 + 3*r3,c0\n r3,c'0 = 3*r0,c0 + 1*r1,c0 + 1*r2,c0 + 2*r3,c0\n\n So using mix tables where c0 is a word with r0 being its upper\n 8 bits and r3 being its lower 8 bits:\n\n m0[c0 >> 24] will yield this word: [2*r0,1*r0,1*r0,3*r0]\n ...\n m3[c0 & 255] will yield this word: [1*r3,1*r3,3*r3,2*r3]\n\n Therefore to mix the columns in each word in the state we\n do the following (& 255 omitted for brevity):\n c'0,r0 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n c'0,r1 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n c'0,r2 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n c'0,r3 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n\n However, before mixing, the algorithm requires us to perform\n ShiftRows(). The ShiftRows() transformation cyclically shifts the\n last 3 rows of the state over different offsets. The first row\n (r = 0) is not shifted.\n\n s'_r,c = s_r,(c + shift(r, Nb) mod Nb\n for 0 < r < 4 and 0 <= c < Nb and\n shift(1, 4) = 1\n shift(2, 4) = 2\n shift(3, 4) = 3.\n\n This causes the first byte in r = 1 to be moved to the end of\n the row, the first 2 bytes in r = 2 to be moved to the end of\n the row, the first 3 bytes in r = 3 to be moved to the end of\n the row:\n\n r1: [c0 c1 c2 c3] => [c1 c2 c3 c0]\n r2: [c0 c1 c2 c3] [c2 c3 c0 c1]\n r3: [c0 c1 c2 c3] [c3 c0 c1 c2]\n\n We can make these substitutions inline with our column mixing to\n generate an updated set of equations to produce each word in the\n state (note the columns have changed positions):\n\n c0 c1 c2 c3 => c0 c1 c2 c3\n c0 c1 c2 c3 c1 c2 c3 c0 (cycled 1 byte)\n c0 c1 c2 c3 c2 c3 c0 c1 (cycled 2 bytes)\n c0 c1 c2 c3 c3 c0 c1 c2 (cycled 3 bytes)\n\n Therefore:\n\n c'0 = 2*r0,c0 + 3*r1,c1 + 1*r2,c2 + 1*r3,c3\n c'0 = 1*r0,c0 + 2*r1,c1 + 3*r2,c2 + 1*r3,c3\n c'0 = 1*r0,c0 + 1*r1,c1 + 2*r2,c2 + 3*r3,c3\n c'0 = 3*r0,c0 + 1*r1,c1 + 1*r2,c2 + 2*r3,c3\n\n c'1 = 2*r0,c1 + 3*r1,c2 + 1*r2,c3 + 1*r3,c0\n c'1 = 1*r0,c1 + 2*r1,c2 + 3*r2,c3 + 1*r3,c0\n c'1 = 1*r0,c1 + 1*r1,c2 + 2*r2,c3 + 3*r3,c0\n c'1 = 3*r0,c1 + 1*r1,c2 + 1*r2,c3 + 2*r3,c0\n\n ... and so forth for c'2 and c'3. The important distinction is\n that the columns are cycling, with c0 being used with the m0\n map when calculating c0, but c1 being used with the m0 map when\n calculating c1 ... and so forth.\n\n When performing the inverse we transform the mirror image and\n skip the bottom row, instead of the top one, and move upwards:\n\n c3 c2 c1 c0 => c0 c3 c2 c1 (cycled 3 bytes) *same as encryption\n c3 c2 c1 c0 c1 c0 c3 c2 (cycled 2 bytes)\n c3 c2 c1 c0 c2 c1 c0 c3 (cycled 1 byte) *same as encryption\n c3 c2 c1 c0 c3 c2 c1 c0\n\n If you compare the resulting matrices for ShiftRows()+MixColumns()\n and for InvShiftRows()+InvMixColumns() the 2nd and 4th columns are\n different (in encrypt mode vs. decrypt mode). So in order to use\n the same code to handle both encryption and decryption, we will\n need to do some mapping.\n\n If in encryption mode we let a=c0, b=c1, c=c2, d=c3, and r<N> be\n a row number in the state, then the resulting matrix in encryption\n mode for applying the above transformations would be:\n\n r1: a b c d\n r2: b c d a\n r3: c d a b\n r4: d a b c\n\n If we did the same in decryption mode we would get:\n\n r1: a d c b\n r2: b a d c\n r3: c b a d\n r4: d c b a\n\n If instead we swap d and b (set b=c3 and d=c1), then we get:\n\n r1: a b c d\n r2: d a b c\n r3: c d a b\n r4: b c d a\n\n Now the 1st and 3rd rows are the same as the encryption matrix. All\n we need to do then to make the mapping exactly the same is to swap\n the 2nd and 4th rows when in decryption mode. To do this without\n having to do it on each iteration, we swapped the 2nd and 4th rows\n in the decryption key schedule. We also have to do the swap above\n when we first pull in the input and when we set the final output. */\n a2 =\n m0[a >>> 24] ^\n m1[b >>> 16 & 255] ^\n m2[c >>> 8 & 255] ^\n m3[d & 255] ^ w[++i];\n b2 =\n m0[b >>> 24] ^\n m1[c >>> 16 & 255] ^\n m2[d >>> 8 & 255] ^\n m3[a & 255] ^ w[++i];\n c2 =\n m0[c >>> 24] ^\n m1[d >>> 16 & 255] ^\n m2[a >>> 8 & 255] ^\n m3[b & 255] ^ w[++i];\n d =\n m0[d >>> 24] ^\n m1[a >>> 16 & 255] ^\n m2[b >>> 8 & 255] ^\n m3[c & 255] ^ w[++i];\n a = a2;\n b = b2;\n c = c2;\n }\n\n /*\n Encrypt:\n SubBytes(state)\n ShiftRows(state)\n AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n\n Decrypt:\n InvShiftRows(state)\n InvSubBytes(state)\n AddRoundKey(state, w[0, Nb-1])\n */\n // Note: rows are shifted inline\n output[0] =\n (sub[a >>> 24] << 24) ^\n (sub[b >>> 16 & 255] << 16) ^\n (sub[c >>> 8 & 255] << 8) ^\n (sub[d & 255]) ^ w[++i];\n output[decrypt ? 3 : 1] =\n (sub[b >>> 24] << 24) ^\n (sub[c >>> 16 & 255] << 16) ^\n (sub[d >>> 8 & 255] << 8) ^\n (sub[a & 255]) ^ w[++i];\n output[2] =\n (sub[c >>> 24] << 24) ^\n (sub[d >>> 16 & 255] << 16) ^\n (sub[a >>> 8 & 255] << 8) ^\n (sub[b & 255]) ^ w[++i];\n output[decrypt ? 1 : 3] =\n (sub[d >>> 24] << 24) ^\n (sub[a >>> 16 & 255] << 16) ^\n (sub[b >>> 8 & 255] << 8) ^\n (sub[c & 255]) ^ w[++i];\n}\n\n/**\n * Deprecated. Instead, use:\n *\n * forge.cipher.createCipher('AES-<mode>', key);\n * forge.cipher.createDecipher('AES-<mode>', key);\n *\n * Creates a deprecated AES cipher object. This object's mode will default to\n * CBC (cipher-block-chaining).\n *\n * The key and iv may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param options the options to use.\n * key the symmetric key to use.\n * output the buffer to write to.\n * decrypt true for decryption, false for encryption.\n * mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nfunction _createCipher(options) {\n options = options || {};\n var mode = (options.mode || 'CBC').toUpperCase();\n var algorithm = 'AES-' + mode;\n\n var cipher;\n if(options.decrypt) {\n cipher = forge.cipher.createDecipher(algorithm, options.key);\n } else {\n cipher = forge.cipher.createCipher(algorithm, options.key);\n }\n\n // backwards compatible start API\n var start = cipher.start;\n cipher.start = function(iv, options) {\n // backwards compatibility: support second arg as output buffer\n var output = null;\n if(options instanceof forge.util.ByteBuffer) {\n output = options;\n options = {};\n }\n options = options || {};\n options.output = output;\n options.iv = iv;\n start.call(cipher, options);\n };\n\n return cipher;\n}\n","/**\n * Cipher base API.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nmodule.exports = forge.cipher = forge.cipher || {};\n\n// registered algorithms\nforge.cipher.algorithms = forge.cipher.algorithms || {};\n\n/**\n * Creates a cipher object that can be used to encrypt data using the given\n * algorithm and key. The algorithm may be provided as a string value for a\n * previously registered algorithm or it may be given as a cipher algorithm\n * API object.\n *\n * @param algorithm the algorithm to use, either a string or an algorithm API\n * object.\n * @param key the key to use, as a binary-encoded string of bytes or a\n * byte buffer.\n *\n * @return the cipher.\n */\nforge.cipher.createCipher = function(algorithm, key) {\n var api = algorithm;\n if(typeof api === 'string') {\n api = forge.cipher.getAlgorithm(api);\n if(api) {\n api = api();\n }\n }\n if(!api) {\n throw new Error('Unsupported algorithm: ' + algorithm);\n }\n\n // assume block cipher\n return new forge.cipher.BlockCipher({\n algorithm: api,\n key: key,\n decrypt: false\n });\n};\n\n/**\n * Creates a decipher object that can be used to decrypt data using the given\n * algorithm and key. The algorithm may be provided as a string value for a\n * previously registered algorithm or it may be given as a cipher algorithm\n * API object.\n *\n * @param algorithm the algorithm to use, either a string or an algorithm API\n * object.\n * @param key the key to use, as a binary-encoded string of bytes or a\n * byte buffer.\n *\n * @return the cipher.\n */\nforge.cipher.createDecipher = function(algorithm, key) {\n var api = algorithm;\n if(typeof api === 'string') {\n api = forge.cipher.getAlgorithm(api);\n if(api) {\n api = api();\n }\n }\n if(!api) {\n throw new Error('Unsupported algorithm: ' + algorithm);\n }\n\n // assume block cipher\n return new forge.cipher.BlockCipher({\n algorithm: api,\n key: key,\n decrypt: true\n });\n};\n\n/**\n * Registers an algorithm by name. If the name was already registered, the\n * algorithm API object will be overwritten.\n *\n * @param name the name of the algorithm.\n * @param algorithm the algorithm API object.\n */\nforge.cipher.registerAlgorithm = function(name, algorithm) {\n name = name.toUpperCase();\n forge.cipher.algorithms[name] = algorithm;\n};\n\n/**\n * Gets a registered algorithm by name.\n *\n * @param name the name of the algorithm.\n *\n * @return the algorithm, if found, null if not.\n */\nforge.cipher.getAlgorithm = function(name) {\n name = name.toUpperCase();\n if(name in forge.cipher.algorithms) {\n return forge.cipher.algorithms[name];\n }\n return null;\n};\n\nvar BlockCipher = forge.cipher.BlockCipher = function(options) {\n this.algorithm = options.algorithm;\n this.mode = this.algorithm.mode;\n this.blockSize = this.mode.blockSize;\n this._finish = false;\n this._input = null;\n this.output = null;\n this._op = options.decrypt ? this.mode.decrypt : this.mode.encrypt;\n this._decrypt = options.decrypt;\n this.algorithm.initialize(options);\n};\n\n/**\n * Starts or restarts the encryption or decryption process, whichever\n * was previously configured.\n *\n * For non-GCM mode, the IV may be a binary-encoded string of bytes, an array\n * of bytes, a byte buffer, or an array of 32-bit integers. If the IV is in\n * bytes, then it must be Nb (16) bytes in length. If the IV is given in as\n * 32-bit integers, then it must be 4 integers long.\n *\n * Note: an IV is not required or used in ECB mode.\n *\n * For GCM-mode, the IV must be given as a binary-encoded string of bytes or\n * a byte buffer. The number of bytes should be 12 (96 bits) as recommended\n * by NIST SP-800-38D but another length may be given.\n *\n * @param options the options to use:\n * iv the initialization vector to use as a binary-encoded string of\n * bytes, null to reuse the last ciphered block from a previous\n * update() (this \"residue\" method is for legacy support only).\n * additionalData additional authentication data as a binary-encoded\n * string of bytes, for 'GCM' mode, (default: none).\n * tagLength desired length of authentication tag, in bits, for\n * 'GCM' mode (0-128, default: 128).\n * tag the authentication tag to check if decrypting, as a\n * binary-encoded string of bytes.\n * output the output the buffer to write to, null to create one.\n */\nBlockCipher.prototype.start = function(options) {\n options = options || {};\n var opts = {};\n for(var key in options) {\n opts[key] = options[key];\n }\n opts.decrypt = this._decrypt;\n this._finish = false;\n this._input = forge.util.createBuffer();\n this.output = options.output || forge.util.createBuffer();\n this.mode.start(opts);\n};\n\n/**\n * Updates the next block according to the cipher mode.\n *\n * @param input the buffer to read from.\n */\nBlockCipher.prototype.update = function(input) {\n if(input) {\n // input given, so empty it into the input buffer\n this._input.putBuffer(input);\n }\n\n // do cipher operation until it needs more input and not finished\n while(!this._op.call(this.mode, this._input, this.output, this._finish) &&\n !this._finish) {}\n\n // free consumed memory from input buffer\n this._input.compact();\n};\n\n/**\n * Finishes encrypting or decrypting.\n *\n * @param pad a padding function to use in CBC mode, null for default,\n * signature(blockSize, buffer, decrypt).\n *\n * @return true if successful, false on error.\n */\nBlockCipher.prototype.finish = function(pad) {\n // backwards-compatibility w/deprecated padding API\n // Note: will overwrite padding functions even after another start() call\n if(pad && (this.mode.name === 'ECB' || this.mode.name === 'CBC')) {\n this.mode.pad = function(input) {\n return pad(this.blockSize, input, false);\n };\n this.mode.unpad = function(output) {\n return pad(this.blockSize, output, true);\n };\n }\n\n // build options for padding and afterFinish functions\n var options = {};\n options.decrypt = this._decrypt;\n\n // get # of bytes that won't fill a block\n options.overflow = this._input.length() % this.blockSize;\n\n if(!this._decrypt && this.mode.pad) {\n if(!this.mode.pad(this._input, options)) {\n return false;\n }\n }\n\n // do final update\n this._finish = true;\n this.update();\n\n if(this._decrypt && this.mode.unpad) {\n if(!this.mode.unpad(this.output, options)) {\n return false;\n }\n }\n\n if(this.mode.afterFinish) {\n if(!this.mode.afterFinish(this.output, options)) {\n return false;\n }\n }\n\n return true;\n};\n","/**\n * Supported cipher modes.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nforge.cipher = forge.cipher || {};\n\n// supported cipher modes\nvar modes = module.exports = forge.cipher.modes = forge.cipher.modes || {};\n\n/** Electronic codebook (ECB) (Don't use this; it's not secure) **/\n\nmodes.ecb = function(options) {\n options = options || {};\n this.name = 'ECB';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = new Array(this._ints);\n this._outBlock = new Array(this._ints);\n};\n\nmodes.ecb.prototype.start = function(options) {};\n\nmodes.ecb.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // write output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n};\n\nmodes.ecb.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n }\n\n // decrypt block\n this.cipher.decrypt(this._inBlock, this._outBlock);\n\n // write output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n};\n\nmodes.ecb.prototype.pad = function(input, options) {\n // add PKCS#7 padding to block (each pad byte is the\n // value of the number of pad bytes)\n var padding = (input.length() === this.blockSize ?\n this.blockSize : (this.blockSize - input.length()));\n input.fillWithByte(padding, padding);\n return true;\n};\n\nmodes.ecb.prototype.unpad = function(output, options) {\n // check for error: input data not a multiple of blockSize\n if(options.overflow > 0) {\n return false;\n }\n\n // ensure padding byte count is valid\n var len = output.length();\n var count = output.at(len - 1);\n if(count > (this.blockSize << 2)) {\n return false;\n }\n\n // trim off padding bytes\n output.truncate(count);\n return true;\n};\n\n/** Cipher-block Chaining (CBC) **/\n\nmodes.cbc = function(options) {\n options = options || {};\n this.name = 'CBC';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = new Array(this._ints);\n this._outBlock = new Array(this._ints);\n};\n\nmodes.cbc.prototype.start = function(options) {\n // Note: legacy support for using IV residue (has security flaws)\n // if IV is null, reuse block from previous processing\n if(options.iv === null) {\n // must have a previous block\n if(!this._prev) {\n throw new Error('Invalid IV parameter.');\n }\n this._iv = this._prev.slice(0);\n } else if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n } else {\n // save IV as \"previous\" block\n this._iv = transformIV(options.iv, this.blockSize);\n this._prev = this._iv.slice(0);\n }\n};\n\nmodes.cbc.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n // CBC XOR's IV (or previous block) with plaintext\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._prev[i] ^ input.getInt32();\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // write output, save previous block\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n this._prev = this._outBlock;\n};\n\nmodes.cbc.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n }\n\n // decrypt block\n this.cipher.decrypt(this._inBlock, this._outBlock);\n\n // write output, save previous ciphered block\n // CBC XOR's IV (or previous block) with ciphertext\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._prev[i] ^ this._outBlock[i]);\n }\n this._prev = this._inBlock.slice(0);\n};\n\nmodes.cbc.prototype.pad = function(input, options) {\n // add PKCS#7 padding to block (each pad byte is the\n // value of the number of pad bytes)\n var padding = (input.length() === this.blockSize ?\n this.blockSize : (this.blockSize - input.length()));\n input.fillWithByte(padding, padding);\n return true;\n};\n\nmodes.cbc.prototype.unpad = function(output, options) {\n // check for error: input data not a multiple of blockSize\n if(options.overflow > 0) {\n return false;\n }\n\n // ensure padding byte count is valid\n var len = output.length();\n var count = output.at(len - 1);\n if(count > (this.blockSize << 2)) {\n return false;\n }\n\n // trim off padding bytes\n output.truncate(count);\n return true;\n};\n\n/** Cipher feedback (CFB) **/\n\nmodes.cfb = function(options) {\n options = options || {};\n this.name = 'CFB';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = null;\n this._outBlock = new Array(this._ints);\n this._partialBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n};\n\nmodes.cfb.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // use IV as first input\n this._iv = transformIV(options.iv, this.blockSize);\n this._inBlock = this._iv.slice(0);\n this._partialBytes = 0;\n};\n\nmodes.cfb.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output, write input as output\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32() ^ this._outBlock[i];\n output.putInt32(this._inBlock[i]);\n }\n return;\n }\n\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output, write input as partial output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialBlock[i] = input.getInt32() ^ this._outBlock[i];\n this._partialOutput.putInt32(this._partialBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n } else {\n // block complete, update input block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._partialBlock[i];\n }\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n};\n\nmodes.cfb.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block (CFB always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output, write input as output\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n output.putInt32(this._inBlock[i] ^ this._outBlock[i]);\n }\n return;\n }\n\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output, write input as partial output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialBlock[i] = input.getInt32();\n this._partialOutput.putInt32(this._partialBlock[i] ^ this._outBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n } else {\n // block complete, update input block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._partialBlock[i];\n }\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n};\n\n/** Output feedback (OFB) **/\n\nmodes.ofb = function(options) {\n options = options || {};\n this.name = 'OFB';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = null;\n this._outBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n};\n\nmodes.ofb.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // use IV as first input\n this._iv = transformIV(options.iv, this.blockSize);\n this._inBlock = this._iv.slice(0);\n this._partialBytes = 0;\n};\n\nmodes.ofb.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(input.length() === 0) {\n return true;\n }\n\n // encrypt block (OFB always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output and update next input\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(input.getInt32() ^ this._outBlock[i]);\n this._inBlock[i] = this._outBlock[i];\n }\n return;\n }\n\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialOutput.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n } else {\n // block complete, update input block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._outBlock[i];\n }\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n};\n\nmodes.ofb.prototype.decrypt = modes.ofb.prototype.encrypt;\n\n/** Counter (CTR) **/\n\nmodes.ctr = function(options) {\n options = options || {};\n this.name = 'CTR';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = null;\n this._outBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n};\n\nmodes.ctr.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // use IV as first input\n this._iv = transformIV(options.iv, this.blockSize);\n this._inBlock = this._iv.slice(0);\n this._partialBytes = 0;\n};\n\nmodes.ctr.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block (CTR always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n } else {\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialOutput.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n }\n\n // block complete, increment counter (input block)\n inc32(this._inBlock);\n};\n\nmodes.ctr.prototype.decrypt = modes.ctr.prototype.encrypt;\n\n/** Galois/Counter Mode (GCM) **/\n\nmodes.gcm = function(options) {\n options = options || {};\n this.name = 'GCM';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = new Array(this._ints);\n this._outBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n\n // R is actually this value concatenated with 120 more zero bits, but\n // we only XOR against R so the other zeros have no effect -- we just\n // apply this value to the first integer in a block\n this._R = 0xE1000000;\n};\n\nmodes.gcm.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // ensure IV is a byte buffer\n var iv = forge.util.createBuffer(options.iv);\n\n // no ciphered data processed yet\n this._cipherLength = 0;\n\n // default additional data is none\n var additionalData;\n if('additionalData' in options) {\n additionalData = forge.util.createBuffer(options.additionalData);\n } else {\n additionalData = forge.util.createBuffer();\n }\n\n // default tag length is 128 bits\n if('tagLength' in options) {\n this._tagLength = options.tagLength;\n } else {\n this._tagLength = 128;\n }\n\n // if tag is given, ensure tag matches tag length\n this._tag = null;\n if(options.decrypt) {\n // save tag to check later\n this._tag = forge.util.createBuffer(options.tag).getBytes();\n if(this._tag.length !== (this._tagLength / 8)) {\n throw new Error('Authentication tag does not match tag length.');\n }\n }\n\n // create tmp storage for hash calculation\n this._hashBlock = new Array(this._ints);\n\n // no tag generated yet\n this.tag = null;\n\n // generate hash subkey\n // (apply block cipher to \"zero\" block)\n this._hashSubkey = new Array(this._ints);\n this.cipher.encrypt([0, 0, 0, 0], this._hashSubkey);\n\n // generate table M\n // use 4-bit tables (32 component decomposition of a 16 byte value)\n // 8-bit tables take more space and are known to have security\n // vulnerabilities (in native implementations)\n this.componentBits = 4;\n this._m = this.generateHashTable(this._hashSubkey, this.componentBits);\n\n // Note: support IV length different from 96 bits? (only supporting\n // 96 bits is recommended by NIST SP-800-38D)\n // generate J_0\n var ivLength = iv.length();\n if(ivLength === 12) {\n // 96-bit IV\n this._j0 = [iv.getInt32(), iv.getInt32(), iv.getInt32(), 1];\n } else {\n // IV is NOT 96-bits\n this._j0 = [0, 0, 0, 0];\n while(iv.length() > 0) {\n this._j0 = this.ghash(\n this._hashSubkey, this._j0,\n [iv.getInt32(), iv.getInt32(), iv.getInt32(), iv.getInt32()]);\n }\n this._j0 = this.ghash(\n this._hashSubkey, this._j0, [0, 0].concat(from64To32(ivLength * 8)));\n }\n\n // generate ICB (initial counter block)\n this._inBlock = this._j0.slice(0);\n inc32(this._inBlock);\n this._partialBytes = 0;\n\n // consume authentication data\n additionalData = forge.util.createBuffer(additionalData);\n // save additional data length as a BE 64-bit number\n this._aDataLength = from64To32(additionalData.length() * 8);\n // pad additional data to 128 bit (16 byte) block size\n var overflow = additionalData.length() % this.blockSize;\n if(overflow) {\n additionalData.fillWithByte(0, this.blockSize - overflow);\n }\n this._s = [0, 0, 0, 0];\n while(additionalData.length() > 0) {\n this._s = this.ghash(this._hashSubkey, this._s, [\n additionalData.getInt32(),\n additionalData.getInt32(),\n additionalData.getInt32(),\n additionalData.getInt32()\n ]);\n }\n};\n\nmodes.gcm.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i] ^= input.getInt32());\n }\n this._cipherLength += this.blockSize;\n } else {\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialOutput.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n\n if(partialBytes <= 0 || finish) {\n // handle overflow prior to hashing\n if(finish) {\n // get block overflow\n var overflow = inputLength % this.blockSize;\n this._cipherLength += overflow;\n // truncate for hash function\n this._partialOutput.truncate(this.blockSize - overflow);\n } else {\n this._cipherLength += this.blockSize;\n }\n\n // get output block for hashing\n for(var i = 0; i < this._ints; ++i) {\n this._outBlock[i] = this._partialOutput.getInt32();\n }\n this._partialOutput.read -= this.blockSize;\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n // block still incomplete, restore input buffer, get partial output,\n // and return early\n input.read -= this.blockSize;\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n }\n\n // update hash block S\n this._s = this.ghash(this._hashSubkey, this._s, this._outBlock);\n\n // increment counter (input block)\n inc32(this._inBlock);\n};\n\nmodes.gcm.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n var inputLength = input.length();\n if(inputLength < this.blockSize && !(finish && inputLength > 0)) {\n return true;\n }\n\n // encrypt block (GCM always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // increment counter (input block)\n inc32(this._inBlock);\n\n // update hash block S\n this._hashBlock[0] = input.getInt32();\n this._hashBlock[1] = input.getInt32();\n this._hashBlock[2] = input.getInt32();\n this._hashBlock[3] = input.getInt32();\n this._s = this.ghash(this._hashSubkey, this._s, this._hashBlock);\n\n // XOR hash input with output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i] ^ this._hashBlock[i]);\n }\n\n // increment cipher data length\n if(inputLength < this.blockSize) {\n this._cipherLength += inputLength % this.blockSize;\n } else {\n this._cipherLength += this.blockSize;\n }\n};\n\nmodes.gcm.prototype.afterFinish = function(output, options) {\n var rval = true;\n\n // handle overflow\n if(options.decrypt && options.overflow) {\n output.truncate(this.blockSize - options.overflow);\n }\n\n // handle authentication tag\n this.tag = forge.util.createBuffer();\n\n // concatenate additional data length with cipher length\n var lengths = this._aDataLength.concat(from64To32(this._cipherLength * 8));\n\n // include lengths in hash\n this._s = this.ghash(this._hashSubkey, this._s, lengths);\n\n // do GCTR(J_0, S)\n var tag = [];\n this.cipher.encrypt(this._j0, tag);\n for(var i = 0; i < this._ints; ++i) {\n this.tag.putInt32(this._s[i] ^ tag[i]);\n }\n\n // trim tag to length\n this.tag.truncate(this.tag.length() % (this._tagLength / 8));\n\n // check authentication tag\n if(options.decrypt && this.tag.bytes() !== this._tag) {\n rval = false;\n }\n\n return rval;\n};\n\n/**\n * See NIST SP-800-38D 6.3 (Algorithm 1). This function performs Galois\n * field multiplication. The field, GF(2^128), is defined by the polynomial:\n *\n * x^128 + x^7 + x^2 + x + 1\n *\n * Which is represented in little-endian binary form as: 11100001 (0xe1). When\n * the value of a coefficient is 1, a bit is set. The value R, is the\n * concatenation of this value and 120 zero bits, yielding a 128-bit value\n * which matches the block size.\n *\n * This function will multiply two elements (vectors of bytes), X and Y, in\n * the field GF(2^128). The result is initialized to zero. For each bit of\n * X (out of 128), x_i, if x_i is set, then the result is multiplied (XOR'd)\n * by the current value of Y. For each bit, the value of Y will be raised by\n * a power of x (multiplied by the polynomial x). This can be achieved by\n * shifting Y once to the right. If the current value of Y, prior to being\n * multiplied by x, has 0 as its LSB, then it is a 127th degree polynomial.\n * Otherwise, we must divide by R after shifting to find the remainder.\n *\n * @param x the first block to multiply by the second.\n * @param y the second block to multiply by the first.\n *\n * @return the block result of the multiplication.\n */\nmodes.gcm.prototype.multiply = function(x, y) {\n var z_i = [0, 0, 0, 0];\n var v_i = y.slice(0);\n\n // calculate Z_128 (block has 128 bits)\n for(var i = 0; i < 128; ++i) {\n // if x_i is 0, Z_{i+1} = Z_i (unchanged)\n // else Z_{i+1} = Z_i ^ V_i\n // get x_i by finding 32-bit int position, then left shift 1 by remainder\n var x_i = x[(i / 32) | 0] & (1 << (31 - i % 32));\n if(x_i) {\n z_i[0] ^= v_i[0];\n z_i[1] ^= v_i[1];\n z_i[2] ^= v_i[2];\n z_i[3] ^= v_i[3];\n }\n\n // if LSB(V_i) is 1, V_i = V_i >> 1\n // else V_i = (V_i >> 1) ^ R\n this.pow(v_i, v_i);\n }\n\n return z_i;\n};\n\nmodes.gcm.prototype.pow = function(x, out) {\n // if LSB(x) is 1, x = x >>> 1\n // else x = (x >>> 1) ^ R\n var lsb = x[3] & 1;\n\n // always do x >>> 1:\n // starting with the rightmost integer, shift each integer to the right\n // one bit, pulling in the bit from the integer to the left as its top\n // most bit (do this for the last 3 integers)\n for(var i = 3; i > 0; --i) {\n out[i] = (x[i] >>> 1) | ((x[i - 1] & 1) << 31);\n }\n // shift the first integer normally\n out[0] = x[0] >>> 1;\n\n // if lsb was not set, then polynomial had a degree of 127 and doesn't\n // need to divided; otherwise, XOR with R to find the remainder; we only\n // need to XOR the first integer since R technically ends w/120 zero bits\n if(lsb) {\n out[0] ^= this._R;\n }\n};\n\nmodes.gcm.prototype.tableMultiply = function(x) {\n // assumes 4-bit tables are used\n var z = [0, 0, 0, 0];\n for(var i = 0; i < 32; ++i) {\n var idx = (i / 8) | 0;\n var x_i = (x[idx] >>> ((7 - (i % 8)) * 4)) & 0xF;\n var ah = this._m[i][x_i];\n z[0] ^= ah[0];\n z[1] ^= ah[1];\n z[2] ^= ah[2];\n z[3] ^= ah[3];\n }\n return z;\n};\n\n/**\n * A continuing version of the GHASH algorithm that operates on a single\n * block. The hash block, last hash value (Ym) and the new block to hash\n * are given.\n *\n * @param h the hash block.\n * @param y the previous value for Ym, use [0, 0, 0, 0] for a new hash.\n * @param x the block to hash.\n *\n * @return the hashed value (Ym).\n */\nmodes.gcm.prototype.ghash = function(h, y, x) {\n y[0] ^= x[0];\n y[1] ^= x[1];\n y[2] ^= x[2];\n y[3] ^= x[3];\n return this.tableMultiply(y);\n //return this.multiply(y, h);\n};\n\n/**\n * Precomputes a table for multiplying against the hash subkey. This\n * mechanism provides a substantial speed increase over multiplication\n * performed without a table. The table-based multiplication this table is\n * for solves X * H by multiplying each component of X by H and then\n * composing the results together using XOR.\n *\n * This function can be used to generate tables with different bit sizes\n * for the components, however, this implementation assumes there are\n * 32 components of X (which is a 16 byte vector), therefore each component\n * takes 4-bits (so the table is constructed with bits=4).\n *\n * @param h the hash subkey.\n * @param bits the bit size for a component.\n */\nmodes.gcm.prototype.generateHashTable = function(h, bits) {\n // TODO: There are further optimizations that would use only the\n // first table M_0 (or some variant) along with a remainder table;\n // this can be explored in the future\n var multiplier = 8 / bits;\n var perInt = 4 * multiplier;\n var size = 16 * multiplier;\n var m = new Array(size);\n for(var i = 0; i < size; ++i) {\n var tmp = [0, 0, 0, 0];\n var idx = (i / perInt) | 0;\n var shft = ((perInt - 1 - (i % perInt)) * bits);\n tmp[idx] = (1 << (bits - 1)) << shft;\n m[i] = this.generateSubHashTable(this.multiply(tmp, h), bits);\n }\n return m;\n};\n\n/**\n * Generates a table for multiplying against the hash subkey for one\n * particular component (out of all possible component values).\n *\n * @param mid the pre-multiplied value for the middle key of the table.\n * @param bits the bit size for a component.\n */\nmodes.gcm.prototype.generateSubHashTable = function(mid, bits) {\n // compute the table quickly by minimizing the number of\n // POW operations -- they only need to be performed for powers of 2,\n // all other entries can be composed from those powers using XOR\n var size = 1 << bits;\n var half = size >>> 1;\n var m = new Array(size);\n m[half] = mid.slice(0);\n var i = half >>> 1;\n while(i > 0) {\n // raise m0[2 * i] and store in m0[i]\n this.pow(m[2 * i], m[i] = []);\n i >>= 1;\n }\n i = 2;\n while(i < half) {\n for(var j = 1; j < i; ++j) {\n var m_i = m[i];\n var m_j = m[j];\n m[i + j] = [\n m_i[0] ^ m_j[0],\n m_i[1] ^ m_j[1],\n m_i[2] ^ m_j[2],\n m_i[3] ^ m_j[3]\n ];\n }\n i *= 2;\n }\n m[0] = [0, 0, 0, 0];\n /* Note: We could avoid storing these by doing composition during multiply\n calculate top half using composition by speed is preferred. */\n for(i = half + 1; i < size; ++i) {\n var c = m[i ^ half];\n m[i] = [mid[0] ^ c[0], mid[1] ^ c[1], mid[2] ^ c[2], mid[3] ^ c[3]];\n }\n return m;\n};\n\n/** Utility functions */\n\nfunction transformIV(iv, blockSize) {\n if(typeof iv === 'string') {\n // convert iv string into byte buffer\n iv = forge.util.createBuffer(iv);\n }\n\n if(forge.util.isArray(iv) && iv.length > 4) {\n // convert iv byte array into byte buffer\n var tmp = iv;\n iv = forge.util.createBuffer();\n for(var i = 0; i < tmp.length; ++i) {\n iv.putByte(tmp[i]);\n }\n }\n\n if(iv.length() < blockSize) {\n throw new Error(\n 'Invalid IV length; got ' + iv.length() +\n ' bytes and expected ' + blockSize + ' bytes.');\n }\n\n if(!forge.util.isArray(iv)) {\n // convert iv byte buffer into 32-bit integer array\n var ints = [];\n var blocks = blockSize / 4;\n for(var i = 0; i < blocks; ++i) {\n ints.push(iv.getInt32());\n }\n iv = ints;\n }\n\n return iv;\n}\n\nfunction inc32(block) {\n // increment last 32 bits of block only\n block[block.length - 1] = (block[block.length - 1] + 1) & 0xFFFFFFFF;\n}\n\nfunction from64To32(num) {\n // convert 64-bit number to two BE Int32s\n return [(num / 0x100000000) | 0, num & 0xFFFFFFFF];\n}\n","/**\n * DES (Data Encryption Standard) implementation.\n *\n * This implementation supports DES as well as 3DES-EDE in ECB and CBC mode.\n * It is based on the BSD-licensed implementation by Paul Tero:\n *\n * Paul Tero, July 2001\n * http://www.tero.co.uk/des/\n *\n * Optimised for performance with large blocks by\n * Michael Hayworth, November 2001\n * http://www.netdealing.com\n *\n * THIS SOFTWARE IS PROVIDED \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT\n * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY\n * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF\n * SUCH DAMAGE.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2012-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./cipher');\nrequire('./cipherModes');\nrequire('./util');\n\n/* DES API */\nmodule.exports = forge.des = forge.des || {};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('DES-<mode>', key);\n * cipher.start({iv: iv});\n *\n * Creates an DES cipher object to encrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as binary-encoded strings of bytes or\n * byte buffers.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC' if IV is\n * given, 'ECB' if null).\n *\n * @return the cipher.\n */\nforge.des.startEncrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: false,\n mode: mode || (iv === null ? 'ECB' : 'CBC')\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('DES-<mode>', key);\n *\n * Creates an DES cipher object to encrypt data using the given symmetric key.\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.des.createEncryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: false,\n mode: mode\n });\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('DES-<mode>', key);\n * decipher.start({iv: iv});\n *\n * Creates an DES cipher object to decrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as binary-encoded strings of bytes or\n * byte buffers.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC' if IV is\n * given, 'ECB' if null).\n *\n * @return the cipher.\n */\nforge.des.startDecrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: true,\n mode: mode || (iv === null ? 'ECB' : 'CBC')\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('DES-<mode>', key);\n *\n * Creates an DES cipher object to decrypt data using the given symmetric key.\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.des.createDecryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: true,\n mode: mode\n });\n};\n\n/**\n * Creates a new DES cipher algorithm object.\n *\n * @param name the name of the algorithm.\n * @param mode the mode factory function.\n *\n * @return the DES algorithm object.\n */\nforge.des.Algorithm = function(name, mode) {\n var self = this;\n self.name = name;\n self.mode = new mode({\n blockSize: 8,\n cipher: {\n encrypt: function(inBlock, outBlock) {\n return _updateBlock(self._keys, inBlock, outBlock, false);\n },\n decrypt: function(inBlock, outBlock) {\n return _updateBlock(self._keys, inBlock, outBlock, true);\n }\n }\n });\n self._init = false;\n};\n\n/**\n * Initializes this DES algorithm by expanding its key.\n *\n * @param options the options to use.\n * key the key to use with this algorithm.\n * decrypt true if the algorithm should be initialized for decryption,\n * false for encryption.\n */\nforge.des.Algorithm.prototype.initialize = function(options) {\n if(this._init) {\n return;\n }\n\n var key = forge.util.createBuffer(options.key);\n if(this.name.indexOf('3DES') === 0) {\n if(key.length() !== 24) {\n throw new Error('Invalid Triple-DES key size: ' + key.length() * 8);\n }\n }\n\n // do key expansion to 16 or 48 subkeys (single or triple DES)\n this._keys = _createKeys(key);\n this._init = true;\n};\n\n/** Register DES algorithms **/\n\nregisterAlgorithm('DES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('DES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('DES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('DES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('DES-CTR', forge.cipher.modes.ctr);\n\nregisterAlgorithm('3DES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('3DES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('3DES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('3DES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('3DES-CTR', forge.cipher.modes.ctr);\n\nfunction registerAlgorithm(name, mode) {\n var factory = function() {\n return new forge.des.Algorithm(name, mode);\n };\n forge.cipher.registerAlgorithm(name, factory);\n}\n\n/** DES implementation **/\n\nvar spfunction1 = [0x1010400,0,0x10000,0x1010404,0x1010004,0x10404,0x4,0x10000,0x400,0x1010400,0x1010404,0x400,0x1000404,0x1010004,0x1000000,0x4,0x404,0x1000400,0x1000400,0x10400,0x10400,0x1010000,0x1010000,0x1000404,0x10004,0x1000004,0x1000004,0x10004,0,0x404,0x10404,0x1000000,0x10000,0x1010404,0x4,0x1010000,0x1010400,0x1000000,0x1000000,0x400,0x1010004,0x10000,0x10400,0x1000004,0x400,0x4,0x1000404,0x10404,0x1010404,0x10004,0x1010000,0x1000404,0x1000004,0x404,0x10404,0x1010400,0x404,0x1000400,0x1000400,0,0x10004,0x10400,0,0x1010004];\nvar spfunction2 = [-0x7fef7fe0,-0x7fff8000,0x8000,0x108020,0x100000,0x20,-0x7fefffe0,-0x7fff7fe0,-0x7fffffe0,-0x7fef7fe0,-0x7fef8000,-0x80000000,-0x7fff8000,0x100000,0x20,-0x7fefffe0,0x108000,0x100020,-0x7fff7fe0,0,-0x80000000,0x8000,0x108020,-0x7ff00000,0x100020,-0x7fffffe0,0,0x108000,0x8020,-0x7fef8000,-0x7ff00000,0x8020,0,0x108020,-0x7fefffe0,0x100000,-0x7fff7fe0,-0x7ff00000,-0x7fef8000,0x8000,-0x7ff00000,-0x7fff8000,0x20,-0x7fef7fe0,0x108020,0x20,0x8000,-0x80000000,0x8020,-0x7fef8000,0x100000,-0x7fffffe0,0x100020,-0x7fff7fe0,-0x7fffffe0,0x100020,0x108000,0,-0x7fff8000,0x8020,-0x80000000,-0x7fefffe0,-0x7fef7fe0,0x108000];\nvar spfunction3 = [0x208,0x8020200,0,0x8020008,0x8000200,0,0x20208,0x8000200,0x20008,0x8000008,0x8000008,0x20000,0x8020208,0x20008,0x8020000,0x208,0x8000000,0x8,0x8020200,0x200,0x20200,0x8020000,0x8020008,0x20208,0x8000208,0x20200,0x20000,0x8000208,0x8,0x8020208,0x200,0x8000000,0x8020200,0x8000000,0x20008,0x208,0x20000,0x8020200,0x8000200,0,0x200,0x20008,0x8020208,0x8000200,0x8000008,0x200,0,0x8020008,0x8000208,0x20000,0x8000000,0x8020208,0x8,0x20208,0x20200,0x8000008,0x8020000,0x8000208,0x208,0x8020000,0x20208,0x8,0x8020008,0x20200];\nvar spfunction4 = [0x802001,0x2081,0x2081,0x80,0x802080,0x800081,0x800001,0x2001,0,0x802000,0x802000,0x802081,0x81,0,0x800080,0x800001,0x1,0x2000,0x800000,0x802001,0x80,0x800000,0x2001,0x2080,0x800081,0x1,0x2080,0x800080,0x2000,0x802080,0x802081,0x81,0x800080,0x800001,0x802000,0x802081,0x81,0,0,0x802000,0x2080,0x800080,0x800081,0x1,0x802001,0x2081,0x2081,0x80,0x802081,0x81,0x1,0x2000,0x800001,0x2001,0x802080,0x800081,0x2001,0x2080,0x800000,0x802001,0x80,0x800000,0x2000,0x802080];\nvar spfunction5 = [0x100,0x2080100,0x2080000,0x42000100,0x80000,0x100,0x40000000,0x2080000,0x40080100,0x80000,0x2000100,0x40080100,0x42000100,0x42080000,0x80100,0x40000000,0x2000000,0x40080000,0x40080000,0,0x40000100,0x42080100,0x42080100,0x2000100,0x42080000,0x40000100,0,0x42000000,0x2080100,0x2000000,0x42000000,0x80100,0x80000,0x42000100,0x100,0x2000000,0x40000000,0x2080000,0x42000100,0x40080100,0x2000100,0x40000000,0x42080000,0x2080100,0x40080100,0x100,0x2000000,0x42080000,0x42080100,0x80100,0x42000000,0x42080100,0x2080000,0,0x40080000,0x42000000,0x80100,0x2000100,0x40000100,0x80000,0,0x40080000,0x2080100,0x40000100];\nvar spfunction6 = [0x20000010,0x20400000,0x4000,0x20404010,0x20400000,0x10,0x20404010,0x400000,0x20004000,0x404010,0x400000,0x20000010,0x400010,0x20004000,0x20000000,0x4010,0,0x400010,0x20004010,0x4000,0x404000,0x20004010,0x10,0x20400010,0x20400010,0,0x404010,0x20404000,0x4010,0x404000,0x20404000,0x20000000,0x20004000,0x10,0x20400010,0x404000,0x20404010,0x400000,0x4010,0x20000010,0x400000,0x20004000,0x20000000,0x4010,0x20000010,0x20404010,0x404000,0x20400000,0x404010,0x20404000,0,0x20400010,0x10,0x4000,0x20400000,0x404010,0x4000,0x400010,0x20004010,0,0x20404000,0x20000000,0x400010,0x20004010];\nvar spfunction7 = [0x200000,0x4200002,0x4000802,0,0x800,0x4000802,0x200802,0x4200800,0x4200802,0x200000,0,0x4000002,0x2,0x4000000,0x4200002,0x802,0x4000800,0x200802,0x200002,0x4000800,0x4000002,0x4200000,0x4200800,0x200002,0x4200000,0x800,0x802,0x4200802,0x200800,0x2,0x4000000,0x200800,0x4000000,0x200800,0x200000,0x4000802,0x4000802,0x4200002,0x4200002,0x2,0x200002,0x4000000,0x4000800,0x200000,0x4200800,0x802,0x200802,0x4200800,0x802,0x4000002,0x4200802,0x4200000,0x200800,0,0x2,0x4200802,0,0x200802,0x4200000,0x800,0x4000002,0x4000800,0x800,0x200002];\nvar spfunction8 = [0x10001040,0x1000,0x40000,0x10041040,0x10000000,0x10001040,0x40,0x10000000,0x40040,0x10040000,0x10041040,0x41000,0x10041000,0x41040,0x1000,0x40,0x10040000,0x10000040,0x10001000,0x1040,0x41000,0x40040,0x10040040,0x10041000,0x1040,0,0,0x10040040,0x10000040,0x10001000,0x41040,0x40000,0x41040,0x40000,0x10041000,0x1000,0x40,0x10040040,0x1000,0x41040,0x10001000,0x40,0x10000040,0x10040000,0x10040040,0x10000000,0x40000,0x10001040,0,0x10041040,0x40040,0x10000040,0x10040000,0x10001000,0x10001040,0,0x10041040,0x41000,0x41000,0x1040,0x1040,0x40040,0x10000000,0x10041000];\n\n/**\n * Create necessary sub keys.\n *\n * @param key the 64-bit or 192-bit key.\n *\n * @return the expanded keys.\n */\nfunction _createKeys(key) {\n var pc2bytes0 = [0,0x4,0x20000000,0x20000004,0x10000,0x10004,0x20010000,0x20010004,0x200,0x204,0x20000200,0x20000204,0x10200,0x10204,0x20010200,0x20010204],\n pc2bytes1 = [0,0x1,0x100000,0x100001,0x4000000,0x4000001,0x4100000,0x4100001,0x100,0x101,0x100100,0x100101,0x4000100,0x4000101,0x4100100,0x4100101],\n pc2bytes2 = [0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808,0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808],\n pc2bytes3 = [0,0x200000,0x8000000,0x8200000,0x2000,0x202000,0x8002000,0x8202000,0x20000,0x220000,0x8020000,0x8220000,0x22000,0x222000,0x8022000,0x8222000],\n pc2bytes4 = [0,0x40000,0x10,0x40010,0,0x40000,0x10,0x40010,0x1000,0x41000,0x1010,0x41010,0x1000,0x41000,0x1010,0x41010],\n pc2bytes5 = [0,0x400,0x20,0x420,0,0x400,0x20,0x420,0x2000000,0x2000400,0x2000020,0x2000420,0x2000000,0x2000400,0x2000020,0x2000420],\n pc2bytes6 = [0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002,0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002],\n pc2bytes7 = [0,0x10000,0x800,0x10800,0x20000000,0x20010000,0x20000800,0x20010800,0x20000,0x30000,0x20800,0x30800,0x20020000,0x20030000,0x20020800,0x20030800],\n pc2bytes8 = [0,0x40000,0,0x40000,0x2,0x40002,0x2,0x40002,0x2000000,0x2040000,0x2000000,0x2040000,0x2000002,0x2040002,0x2000002,0x2040002],\n pc2bytes9 = [0,0x10000000,0x8,0x10000008,0,0x10000000,0x8,0x10000008,0x400,0x10000400,0x408,0x10000408,0x400,0x10000400,0x408,0x10000408],\n pc2bytes10 = [0,0x20,0,0x20,0x100000,0x100020,0x100000,0x100020,0x2000,0x2020,0x2000,0x2020,0x102000,0x102020,0x102000,0x102020],\n pc2bytes11 = [0,0x1000000,0x200,0x1000200,0x200000,0x1200000,0x200200,0x1200200,0x4000000,0x5000000,0x4000200,0x5000200,0x4200000,0x5200000,0x4200200,0x5200200],\n pc2bytes12 = [0,0x1000,0x8000000,0x8001000,0x80000,0x81000,0x8080000,0x8081000,0x10,0x1010,0x8000010,0x8001010,0x80010,0x81010,0x8080010,0x8081010],\n pc2bytes13 = [0,0x4,0x100,0x104,0,0x4,0x100,0x104,0x1,0x5,0x101,0x105,0x1,0x5,0x101,0x105];\n\n // how many iterations (1 for des, 3 for triple des)\n // changed by Paul 16/6/2007 to use Triple DES for 9+ byte keys\n var iterations = key.length() > 8 ? 3 : 1;\n\n // stores the return keys\n var keys = [];\n\n // now define the left shifts which need to be done\n var shifts = [0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0];\n\n var n = 0, tmp;\n for(var j = 0; j < iterations; j++) {\n var left = key.getInt32();\n var right = key.getInt32();\n\n tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n right ^= tmp;\n left ^= (tmp << 4);\n\n tmp = ((right >>> -16) ^ left) & 0x0000ffff;\n left ^= tmp;\n right ^= (tmp << -16);\n\n tmp = ((left >>> 2) ^ right) & 0x33333333;\n right ^= tmp;\n left ^= (tmp << 2);\n\n tmp = ((right >>> -16) ^ left) & 0x0000ffff;\n left ^= tmp;\n right ^= (tmp << -16);\n\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n left ^= tmp;\n right ^= (tmp << 8);\n\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n // right needs to be shifted and OR'd with last four bits of left\n tmp = (left << 8) | ((right >>> 20) & 0x000000f0);\n\n // left needs to be put upside down\n left = ((right << 24) | ((right << 8) & 0xff0000) |\n ((right >>> 8) & 0xff00) | ((right >>> 24) & 0xf0));\n right = tmp;\n\n // now go through and perform these shifts on the left and right keys\n for(var i = 0; i < shifts.length; ++i) {\n //shift the keys either one or two bits to the left\n if(shifts[i]) {\n left = (left << 2) | (left >>> 26);\n right = (right << 2) | (right >>> 26);\n } else {\n left = (left << 1) | (left >>> 27);\n right = (right << 1) | (right >>> 27);\n }\n left &= -0xf;\n right &= -0xf;\n\n // now apply PC-2, in such a way that E is easier when encrypting or\n // decrypting this conversion will look like PC-2 except only the last 6\n // bits of each byte are used rather than 48 consecutive bits and the\n // order of lines will be according to how the S selection functions will\n // be applied: S2, S4, S6, S8, S1, S3, S5, S7\n var lefttmp = (\n pc2bytes0[left >>> 28] | pc2bytes1[(left >>> 24) & 0xf] |\n pc2bytes2[(left >>> 20) & 0xf] | pc2bytes3[(left >>> 16) & 0xf] |\n pc2bytes4[(left >>> 12) & 0xf] | pc2bytes5[(left >>> 8) & 0xf] |\n pc2bytes6[(left >>> 4) & 0xf]);\n var righttmp = (\n pc2bytes7[right >>> 28] | pc2bytes8[(right >>> 24) & 0xf] |\n pc2bytes9[(right >>> 20) & 0xf] | pc2bytes10[(right >>> 16) & 0xf] |\n pc2bytes11[(right >>> 12) & 0xf] | pc2bytes12[(right >>> 8) & 0xf] |\n pc2bytes13[(right >>> 4) & 0xf]);\n tmp = ((righttmp >>> 16) ^ lefttmp) & 0x0000ffff;\n keys[n++] = lefttmp ^ tmp;\n keys[n++] = righttmp ^ (tmp << 16);\n }\n }\n\n return keys;\n}\n\n/**\n * Updates a single block (1 byte) using DES. The update will either\n * encrypt or decrypt the block.\n *\n * @param keys the expanded keys.\n * @param input the input block (an array of 32-bit words).\n * @param output the updated output block.\n * @param decrypt true to decrypt the block, false to encrypt it.\n */\nfunction _updateBlock(keys, input, output, decrypt) {\n // set up loops for single or triple DES\n var iterations = keys.length === 32 ? 3 : 9;\n var looping;\n if(iterations === 3) {\n looping = decrypt ? [30, -2, -2] : [0, 32, 2];\n } else {\n looping = (decrypt ?\n [94, 62, -2, 32, 64, 2, 30, -2, -2] :\n [0, 32, 2, 62, 30, -2, 64, 96, 2]);\n }\n\n var tmp;\n\n var left = input[0];\n var right = input[1];\n\n // first each 64 bit chunk of the message must be permuted according to IP\n tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n right ^= tmp;\n left ^= (tmp << 4);\n\n tmp = ((left >>> 16) ^ right) & 0x0000ffff;\n right ^= tmp;\n left ^= (tmp << 16);\n\n tmp = ((right >>> 2) ^ left) & 0x33333333;\n left ^= tmp;\n right ^= (tmp << 2);\n\n tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n left ^= tmp;\n right ^= (tmp << 8);\n\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n // rotate left 1 bit\n left = ((left << 1) | (left >>> 31));\n right = ((right << 1) | (right >>> 31));\n\n for(var j = 0; j < iterations; j += 3) {\n var endloop = looping[j + 1];\n var loopinc = looping[j + 2];\n\n // now go through and perform the encryption or decryption\n for(var i = looping[j]; i != endloop; i += loopinc) {\n var right1 = right ^ keys[i];\n var right2 = ((right >>> 4) | (right << 28)) ^ keys[i + 1];\n\n // passing these bytes through the S selection functions\n tmp = left;\n left = right;\n right = tmp ^ (\n spfunction2[(right1 >>> 24) & 0x3f] |\n spfunction4[(right1 >>> 16) & 0x3f] |\n spfunction6[(right1 >>> 8) & 0x3f] |\n spfunction8[right1 & 0x3f] |\n spfunction1[(right2 >>> 24) & 0x3f] |\n spfunction3[(right2 >>> 16) & 0x3f] |\n spfunction5[(right2 >>> 8) & 0x3f] |\n spfunction7[right2 & 0x3f]);\n }\n // unreverse left and right\n tmp = left;\n left = right;\n right = tmp;\n }\n\n // rotate right 1 bit\n left = ((left >>> 1) | (left << 31));\n right = ((right >>> 1) | (right << 31));\n\n // now perform IP-1, which is IP in the opposite direction\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n left ^= tmp;\n right ^= (tmp << 8);\n\n tmp = ((right >>> 2) ^ left) & 0x33333333;\n left ^= tmp;\n right ^= (tmp << 2);\n\n tmp = ((left >>> 16) ^ right) & 0x0000ffff;\n right ^= tmp;\n left ^= (tmp << 16);\n\n tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n right ^= tmp;\n left ^= (tmp << 4);\n\n output[0] = left;\n output[1] = right;\n}\n\n/**\n * Deprecated. Instead, use:\n *\n * forge.cipher.createCipher('DES-<mode>', key);\n * forge.cipher.createDecipher('DES-<mode>', key);\n *\n * Creates a deprecated DES cipher object. This object's mode will default to\n * CBC (cipher-block-chaining).\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param options the options to use.\n * key the symmetric key to use (64 or 192 bits).\n * output the buffer to write to.\n * decrypt true for decryption, false for encryption.\n * mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nfunction _createCipher(options) {\n options = options || {};\n var mode = (options.mode || 'CBC').toUpperCase();\n var algorithm = 'DES-' + mode;\n\n var cipher;\n if(options.decrypt) {\n cipher = forge.cipher.createDecipher(algorithm, options.key);\n } else {\n cipher = forge.cipher.createCipher(algorithm, options.key);\n }\n\n // backwards compatible start API\n var start = cipher.start;\n cipher.start = function(iv, options) {\n // backwards compatibility: support second arg as output buffer\n var output = null;\n if(options instanceof forge.util.ByteBuffer) {\n output = options;\n options = {};\n }\n options = options || {};\n options.output = output;\n options.iv = iv;\n start.call(cipher, options);\n };\n\n return cipher;\n}\n","/**\n * Node.js module for Forge message digests.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2017 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\n\nmodule.exports = forge.md = forge.md || {};\nforge.md.algorithms = forge.md.algorithms || {};\n","/**\n * Password-Based Key-Derivation Function #2 implementation.\n *\n * See RFC 2898 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./hmac');\nrequire('./md');\nrequire('./util');\n\nvar pkcs5 = forge.pkcs5 = forge.pkcs5 || {};\n\nvar crypto;\nif(forge.util.isNodejs && !forge.options.usePureJavaScript) {\n crypto = require('crypto');\n}\n\n/**\n * Derives a key from a password.\n *\n * @param p the password as a binary-encoded string of bytes.\n * @param s the salt as a binary-encoded string of bytes.\n * @param c the iteration count, a positive integer.\n * @param dkLen the intended length, in bytes, of the derived key,\n * (max: 2^32 - 1) * hash length of the PRF.\n * @param [md] the message digest (or algorithm identifier as a string) to use\n * in the PRF, defaults to SHA-1.\n * @param [callback(err, key)] presence triggers asynchronous version, called\n * once the operation completes.\n *\n * @return the derived key, as a binary-encoded string of bytes, for the\n * synchronous version (if no callback is specified).\n */\nmodule.exports = forge.pbkdf2 = pkcs5.pbkdf2 = function(\n p, s, c, dkLen, md, callback) {\n if(typeof md === 'function') {\n callback = md;\n md = null;\n }\n\n // use native implementation if possible and not disabled, note that\n // some node versions only support SHA-1, others allow digest to be changed\n if(forge.util.isNodejs && !forge.options.usePureJavaScript &&\n crypto.pbkdf2 && (md === null || typeof md !== 'object') &&\n (crypto.pbkdf2Sync.length > 4 || (!md || md === 'sha1'))) {\n if(typeof md !== 'string') {\n // default prf to SHA-1\n md = 'sha1';\n }\n p = Buffer.from(p, 'binary');\n s = Buffer.from(s, 'binary');\n if(!callback) {\n if(crypto.pbkdf2Sync.length === 4) {\n return crypto.pbkdf2Sync(p, s, c, dkLen).toString('binary');\n }\n return crypto.pbkdf2Sync(p, s, c, dkLen, md).toString('binary');\n }\n if(crypto.pbkdf2Sync.length === 4) {\n return crypto.pbkdf2(p, s, c, dkLen, function(err, key) {\n if(err) {\n return callback(err);\n }\n callback(null, key.toString('binary'));\n });\n }\n return crypto.pbkdf2(p, s, c, dkLen, md, function(err, key) {\n if(err) {\n return callback(err);\n }\n callback(null, key.toString('binary'));\n });\n }\n\n if(typeof md === 'undefined' || md === null) {\n // default prf to SHA-1\n md = 'sha1';\n }\n if(typeof md === 'string') {\n if(!(md in forge.md.algorithms)) {\n throw new Error('Unknown hash algorithm: ' + md);\n }\n md = forge.md[md].create();\n }\n\n var hLen = md.digestLength;\n\n /* 1. If dkLen > (2^32 - 1) * hLen, output \"derived key too long\" and\n stop. */\n if(dkLen > (0xFFFFFFFF * hLen)) {\n var err = new Error('Derived key is too long.');\n if(callback) {\n return callback(err);\n }\n throw err;\n }\n\n /* 2. Let len be the number of hLen-octet blocks in the derived key,\n rounding up, and let r be the number of octets in the last\n block:\n\n len = CEIL(dkLen / hLen),\n r = dkLen - (len - 1) * hLen. */\n var len = Math.ceil(dkLen / hLen);\n var r = dkLen - (len - 1) * hLen;\n\n /* 3. For each block of the derived key apply the function F defined\n below to the password P, the salt S, the iteration count c, and\n the block index to compute the block:\n\n T_1 = F(P, S, c, 1),\n T_2 = F(P, S, c, 2),\n ...\n T_len = F(P, S, c, len),\n\n where the function F is defined as the exclusive-or sum of the\n first c iterates of the underlying pseudorandom function PRF\n applied to the password P and the concatenation of the salt S\n and the block index i:\n\n F(P, S, c, i) = u_1 XOR u_2 XOR ... XOR u_c\n\n where\n\n u_1 = PRF(P, S || INT(i)),\n u_2 = PRF(P, u_1),\n ...\n u_c = PRF(P, u_{c-1}).\n\n Here, INT(i) is a four-octet encoding of the integer i, most\n significant octet first. */\n var prf = forge.hmac.create();\n prf.start(md, p);\n var dk = '';\n var xor, u_c, u_c1;\n\n // sync version\n if(!callback) {\n for(var i = 1; i <= len; ++i) {\n // PRF(P, S || INT(i)) (first iteration)\n prf.start(null, null);\n prf.update(s);\n prf.update(forge.util.int32ToBytes(i));\n xor = u_c1 = prf.digest().getBytes();\n\n // PRF(P, u_{c-1}) (other iterations)\n for(var j = 2; j <= c; ++j) {\n prf.start(null, null);\n prf.update(u_c1);\n u_c = prf.digest().getBytes();\n // F(p, s, c, i)\n xor = forge.util.xorBytes(xor, u_c, hLen);\n u_c1 = u_c;\n }\n\n /* 4. Concatenate the blocks and extract the first dkLen octets to\n produce a derived key DK:\n\n DK = T_1 || T_2 || ... || T_len<0..r-1> */\n dk += (i < len) ? xor : xor.substr(0, r);\n }\n /* 5. Output the derived key DK. */\n return dk;\n }\n\n // async version\n var i = 1, j;\n function outer() {\n if(i > len) {\n // done\n return callback(null, dk);\n }\n\n // PRF(P, S || INT(i)) (first iteration)\n prf.start(null, null);\n prf.update(s);\n prf.update(forge.util.int32ToBytes(i));\n xor = u_c1 = prf.digest().getBytes();\n\n // PRF(P, u_{c-1}) (other iterations)\n j = 2;\n inner();\n }\n\n function inner() {\n if(j <= c) {\n prf.start(null, null);\n prf.update(u_c1);\n u_c = prf.digest().getBytes();\n // F(p, s, c, i)\n xor = forge.util.xorBytes(xor, u_c, hLen);\n u_c1 = u_c;\n ++j;\n return forge.util.setImmediate(inner);\n }\n\n /* 4. Concatenate the blocks and extract the first dkLen octets to\n produce a derived key DK:\n\n DK = T_1 || T_2 || ... || T_len<0..r-1> */\n dk += (i < len) ? xor : xor.substr(0, r);\n\n ++i;\n outer();\n }\n\n outer();\n};\n","/**\n * Hash-based Message Authentication Code implementation. Requires a message\n * digest object that can be obtained, for example, from forge.md.sha1 or\n * forge.md.md5.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2012 Digital Bazaar, Inc. All rights reserved.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\n/* HMAC API */\nvar hmac = module.exports = forge.hmac = forge.hmac || {};\n\n/**\n * Creates an HMAC object that uses the given message digest object.\n *\n * @return an HMAC object.\n */\nhmac.create = function() {\n // the hmac key to use\n var _key = null;\n\n // the message digest to use\n var _md = null;\n\n // the inner padding\n var _ipadding = null;\n\n // the outer padding\n var _opadding = null;\n\n // hmac context\n var ctx = {};\n\n /**\n * Starts or restarts the HMAC with the given key and message digest.\n *\n * @param md the message digest to use, null to reuse the previous one,\n * a string to use builtin 'sha1', 'md5', 'sha256'.\n * @param key the key to use as a string, array of bytes, byte buffer,\n * or null to reuse the previous key.\n */\n ctx.start = function(md, key) {\n if(md !== null) {\n if(typeof md === 'string') {\n // create builtin message digest\n md = md.toLowerCase();\n if(md in forge.md.algorithms) {\n _md = forge.md.algorithms[md].create();\n } else {\n throw new Error('Unknown hash algorithm \"' + md + '\"');\n }\n } else {\n // store message digest\n _md = md;\n }\n }\n\n if(key === null) {\n // reuse previous key\n key = _key;\n } else {\n if(typeof key === 'string') {\n // convert string into byte buffer\n key = forge.util.createBuffer(key);\n } else if(forge.util.isArray(key)) {\n // convert byte array into byte buffer\n var tmp = key;\n key = forge.util.createBuffer();\n for(var i = 0; i < tmp.length; ++i) {\n key.putByte(tmp[i]);\n }\n }\n\n // if key is longer than blocksize, hash it\n var keylen = key.length();\n if(keylen > _md.blockLength) {\n _md.start();\n _md.update(key.bytes());\n key = _md.digest();\n }\n\n // mix key into inner and outer padding\n // ipadding = [0x36 * blocksize] ^ key\n // opadding = [0x5C * blocksize] ^ key\n _ipadding = forge.util.createBuffer();\n _opadding = forge.util.createBuffer();\n keylen = key.length();\n for(var i = 0; i < keylen; ++i) {\n var tmp = key.at(i);\n _ipadding.putByte(0x36 ^ tmp);\n _opadding.putByte(0x5C ^ tmp);\n }\n\n // if key is shorter than blocksize, add additional padding\n if(keylen < _md.blockLength) {\n var tmp = _md.blockLength - keylen;\n for(var i = 0; i < tmp; ++i) {\n _ipadding.putByte(0x36);\n _opadding.putByte(0x5C);\n }\n }\n _key = key;\n _ipadding = _ipadding.bytes();\n _opadding = _opadding.bytes();\n }\n\n // digest is done like so: hash(opadding | hash(ipadding | message))\n\n // prepare to do inner hash\n // hash(ipadding | message)\n _md.start();\n _md.update(_ipadding);\n };\n\n /**\n * Updates the HMAC with the given message bytes.\n *\n * @param bytes the bytes to update with.\n */\n ctx.update = function(bytes) {\n _md.update(bytes);\n };\n\n /**\n * Produces the Message Authentication Code (MAC).\n *\n * @return a byte buffer containing the digest value.\n */\n ctx.getMac = function() {\n // digest is done like so: hash(opadding | hash(ipadding | message))\n // here we do the outer hashing\n var inner = _md.digest().bytes();\n _md.start();\n _md.update(_opadding);\n _md.update(inner);\n return _md.digest();\n };\n // alias for getMac\n ctx.digest = ctx.getMac;\n\n return ctx;\n};\n","/**\n * Javascript implementation of basic PEM (Privacy Enhanced Mail) algorithms.\n *\n * See: RFC 1421.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2013-2014 Digital Bazaar, Inc.\n *\n * A Forge PEM object has the following fields:\n *\n * type: identifies the type of message (eg: \"RSA PRIVATE KEY\").\n *\n * procType: identifies the type of processing performed on the message,\n * it has two subfields: version and type, eg: 4,ENCRYPTED.\n *\n * contentDomain: identifies the type of content in the message, typically\n * only uses the value: \"RFC822\".\n *\n * dekInfo: identifies the message encryption algorithm and mode and includes\n * any parameters for the algorithm, it has two subfields: algorithm and\n * parameters, eg: DES-CBC,F8143EDE5960C597.\n *\n * headers: contains all other PEM encapsulated headers -- where order is\n * significant (for pairing data like recipient ID + key info).\n *\n * body: the binary-encoded body.\n */\nvar forge = require('./forge');\nrequire('./util');\n\n// shortcut for pem API\nvar pem = module.exports = forge.pem = forge.pem || {};\n\n/**\n * Encodes (serializes) the given PEM object.\n *\n * @param msg the PEM message object to encode.\n * @param options the options to use:\n * maxline the maximum characters per line for the body, (default: 64).\n *\n * @return the PEM-formatted string.\n */\npem.encode = function(msg, options) {\n options = options || {};\n var rval = '-----BEGIN ' + msg.type + '-----\\r\\n';\n\n // encode special headers\n var header;\n if(msg.procType) {\n header = {\n name: 'Proc-Type',\n values: [String(msg.procType.version), msg.procType.type]\n };\n rval += foldHeader(header);\n }\n if(msg.contentDomain) {\n header = {name: 'Content-Domain', values: [msg.contentDomain]};\n rval += foldHeader(header);\n }\n if(msg.dekInfo) {\n header = {name: 'DEK-Info', values: [msg.dekInfo.algorithm]};\n if(msg.dekInfo.parameters) {\n header.values.push(msg.dekInfo.parameters);\n }\n rval += foldHeader(header);\n }\n\n if(msg.headers) {\n // encode all other headers\n for(var i = 0; i < msg.headers.length; ++i) {\n rval += foldHeader(msg.headers[i]);\n }\n }\n\n // terminate header\n if(msg.procType) {\n rval += '\\r\\n';\n }\n\n // add body\n rval += forge.util.encode64(msg.body, options.maxline || 64) + '\\r\\n';\n\n rval += '-----END ' + msg.type + '-----\\r\\n';\n return rval;\n};\n\n/**\n * Decodes (deserializes) all PEM messages found in the given string.\n *\n * @param str the PEM-formatted string to decode.\n *\n * @return the PEM message objects in an array.\n */\npem.decode = function(str) {\n var rval = [];\n\n // split string into PEM messages (be lenient w/EOF on BEGIN line)\n var rMessage = /\\s*-----BEGIN ([A-Z0-9- ]+)-----\\r?\\n?([\\x21-\\x7e\\s]+?(?:\\r?\\n\\r?\\n))?([:A-Za-z0-9+\\/=\\s]+?)-----END \\1-----/g;\n var rHeader = /([\\x21-\\x7e]+):\\s*([\\x21-\\x7e\\s^:]+)/;\n var rCRLF = /\\r?\\n/;\n var match;\n while(true) {\n match = rMessage.exec(str);\n if(!match) {\n break;\n }\n\n var msg = {\n type: match[1],\n procType: null,\n contentDomain: null,\n dekInfo: null,\n headers: [],\n body: forge.util.decode64(match[3])\n };\n rval.push(msg);\n\n // no headers\n if(!match[2]) {\n continue;\n }\n\n // parse headers\n var lines = match[2].split(rCRLF);\n var li = 0;\n while(match && li < lines.length) {\n // get line, trim any rhs whitespace\n var line = lines[li].replace(/\\s+$/, '');\n\n // RFC2822 unfold any following folded lines\n for(var nl = li + 1; nl < lines.length; ++nl) {\n var next = lines[nl];\n if(!/\\s/.test(next[0])) {\n break;\n }\n line += next;\n li = nl;\n }\n\n // parse header\n match = line.match(rHeader);\n if(match) {\n var header = {name: match[1], values: []};\n var values = match[2].split(',');\n for(var vi = 0; vi < values.length; ++vi) {\n header.values.push(ltrim(values[vi]));\n }\n\n // Proc-Type must be the first header\n if(!msg.procType) {\n if(header.name !== 'Proc-Type') {\n throw new Error('Invalid PEM formatted message. The first ' +\n 'encapsulated header must be \"Proc-Type\".');\n } else if(header.values.length !== 2) {\n throw new Error('Invalid PEM formatted message. The \"Proc-Type\" ' +\n 'header must have two subfields.');\n }\n msg.procType = {version: values[0], type: values[1]};\n } else if(!msg.contentDomain && header.name === 'Content-Domain') {\n // special-case Content-Domain\n msg.contentDomain = values[0] || '';\n } else if(!msg.dekInfo && header.name === 'DEK-Info') {\n // special-case DEK-Info\n if(header.values.length === 0) {\n throw new Error('Invalid PEM formatted message. The \"DEK-Info\" ' +\n 'header must have at least one subfield.');\n }\n msg.dekInfo = {algorithm: values[0], parameters: values[1] || null};\n } else {\n msg.headers.push(header);\n }\n }\n\n ++li;\n }\n\n if(msg.procType === 'ENCRYPTED' && !msg.dekInfo) {\n throw new Error('Invalid PEM formatted message. The \"DEK-Info\" ' +\n 'header must be present if \"Proc-Type\" is \"ENCRYPTED\".');\n }\n }\n\n if(rval.length === 0) {\n throw new Error('Invalid PEM formatted message.');\n }\n\n return rval;\n};\n\nfunction foldHeader(header) {\n var rval = header.name + ': ';\n\n // ensure values with CRLF are folded\n var values = [];\n var insertSpace = function(match, $1) {\n return ' ' + $1;\n };\n for(var i = 0; i < header.values.length; ++i) {\n values.push(header.values[i].replace(/^(\\S+\\r\\n)/, insertSpace));\n }\n rval += values.join(',') + '\\r\\n';\n\n // do folding\n var length = 0;\n var candidate = -1;\n for(var i = 0; i < rval.length; ++i, ++length) {\n if(length > 65 && candidate !== -1) {\n var insert = rval[candidate];\n if(insert === ',') {\n ++candidate;\n rval = rval.substr(0, candidate) + '\\r\\n ' + rval.substr(candidate);\n } else {\n rval = rval.substr(0, candidate) +\n '\\r\\n' + insert + rval.substr(candidate + 1);\n }\n length = (i - candidate - 1);\n candidate = -1;\n ++i;\n } else if(rval[i] === ' ' || rval[i] === '\\t' || rval[i] === ',') {\n candidate = i;\n }\n }\n\n return rval;\n}\n\nfunction ltrim(str) {\n return str.replace(/^\\s+/, '');\n}\n","/**\n * An API for getting cryptographically-secure random bytes. The bytes are\n * generated using the Fortuna algorithm devised by Bruce Schneier and\n * Niels Ferguson.\n *\n * Getting strong random bytes is not yet easy to do in javascript. The only\n * truish random entropy that can be collected is from the mouse, keyboard, or\n * from timing with respect to page loads, etc. This generator makes a poor\n * attempt at providing random bytes when those sources haven't yet provided\n * enough entropy to initially seed or to reseed the PRNG.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2009-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./sha256');\nrequire('./prng');\nrequire('./util');\n\n(function() {\n\n// forge.random already defined\nif(forge.random && forge.random.getBytes) {\n module.exports = forge.random;\n return;\n}\n\n(function(jQuery) {\n\n// the default prng plugin, uses AES-128\nvar prng_aes = {};\nvar _prng_aes_output = new Array(4);\nvar _prng_aes_buffer = forge.util.createBuffer();\nprng_aes.formatKey = function(key) {\n // convert the key into 32-bit integers\n var tmp = forge.util.createBuffer(key);\n key = new Array(4);\n key[0] = tmp.getInt32();\n key[1] = tmp.getInt32();\n key[2] = tmp.getInt32();\n key[3] = tmp.getInt32();\n\n // return the expanded key\n return forge.aes._expandKey(key, false);\n};\nprng_aes.formatSeed = function(seed) {\n // convert seed into 32-bit integers\n var tmp = forge.util.createBuffer(seed);\n seed = new Array(4);\n seed[0] = tmp.getInt32();\n seed[1] = tmp.getInt32();\n seed[2] = tmp.getInt32();\n seed[3] = tmp.getInt32();\n return seed;\n};\nprng_aes.cipher = function(key, seed) {\n forge.aes._updateBlock(key, seed, _prng_aes_output, false);\n _prng_aes_buffer.putInt32(_prng_aes_output[0]);\n _prng_aes_buffer.putInt32(_prng_aes_output[1]);\n _prng_aes_buffer.putInt32(_prng_aes_output[2]);\n _prng_aes_buffer.putInt32(_prng_aes_output[3]);\n return _prng_aes_buffer.getBytes();\n};\nprng_aes.increment = function(seed) {\n // FIXME: do we care about carry or signed issues?\n ++seed[3];\n return seed;\n};\nprng_aes.md = forge.md.sha256;\n\n/**\n * Creates a new PRNG.\n */\nfunction spawnPrng() {\n var ctx = forge.prng.create(prng_aes);\n\n /**\n * Gets random bytes. If a native secure crypto API is unavailable, this\n * method tries to make the bytes more unpredictable by drawing from data that\n * can be collected from the user of the browser, eg: mouse movement.\n *\n * If a callback is given, this method will be called asynchronously.\n *\n * @param count the number of random bytes to get.\n * @param [callback(err, bytes)] called once the operation completes.\n *\n * @return the random bytes in a string.\n */\n ctx.getBytes = function(count, callback) {\n return ctx.generate(count, callback);\n };\n\n /**\n * Gets random bytes asynchronously. If a native secure crypto API is\n * unavailable, this method tries to make the bytes more unpredictable by\n * drawing from data that can be collected from the user of the browser,\n * eg: mouse movement.\n *\n * @param count the number of random bytes to get.\n *\n * @return the random bytes in a string.\n */\n ctx.getBytesSync = function(count) {\n return ctx.generate(count);\n };\n\n return ctx;\n}\n\n// create default prng context\nvar _ctx = spawnPrng();\n\n// add other sources of entropy only if window.crypto.getRandomValues is not\n// available -- otherwise this source will be automatically used by the prng\nvar getRandomValues = null;\nvar globalScope = forge.util.globalScope;\nvar _crypto = globalScope.crypto || globalScope.msCrypto;\nif(_crypto && _crypto.getRandomValues) {\n getRandomValues = function(arr) {\n return _crypto.getRandomValues(arr);\n };\n}\n\nif(forge.options.usePureJavaScript ||\n (!forge.util.isNodejs && !getRandomValues)) {\n // if this is a web worker, do not use weak entropy, instead register to\n // receive strong entropy asynchronously from the main thread\n if(typeof window === 'undefined' || window.document === undefined) {\n // FIXME:\n }\n\n // get load time entropy\n _ctx.collectInt(+new Date(), 32);\n\n // add some entropy from navigator object\n if(typeof(navigator) !== 'undefined') {\n var _navBytes = '';\n for(var key in navigator) {\n try {\n if(typeof(navigator[key]) == 'string') {\n _navBytes += navigator[key];\n }\n } catch(e) {\n /* Some navigator keys might not be accessible, e.g. the geolocation\n attribute throws an exception if touched in Mozilla chrome://\n context.\n\n Silently ignore this and just don't use this as a source of\n entropy. */\n }\n }\n _ctx.collect(_navBytes);\n _navBytes = null;\n }\n\n // add mouse and keyboard collectors if jquery is available\n if(jQuery) {\n // set up mouse entropy capture\n jQuery().mousemove(function(e) {\n // add mouse coords\n _ctx.collectInt(e.clientX, 16);\n _ctx.collectInt(e.clientY, 16);\n });\n\n // set up keyboard entropy capture\n jQuery().keypress(function(e) {\n _ctx.collectInt(e.charCode, 8);\n });\n }\n}\n\n/* Random API */\nif(!forge.random) {\n forge.random = _ctx;\n} else {\n // extend forge.random with _ctx\n for(var key in _ctx) {\n forge.random[key] = _ctx[key];\n }\n}\n\n// expose spawn PRNG\nforge.random.createInstance = spawnPrng;\n\nmodule.exports = forge.random;\n\n})(typeof(jQuery) !== 'undefined' ? jQuery : null);\n\n})();\n","/**\n * Secure Hash Algorithm with 256-bit digest (SHA-256) implementation.\n *\n * See FIPS 180-2 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha256 = module.exports = forge.sha256 = forge.sha256 || {};\nforge.md.sha256 = forge.md.algorithms.sha256 = sha256;\n\n/**\n * Creates a SHA-256 message digest object.\n *\n * @return a message digest object.\n */\nsha256.create = function() {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n // SHA-256 state contains eight 32-bit integers\n var _state = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for word storage\n var _w = new Array(64);\n\n // message digest object\n var md = {\n algorithm: 'sha256',\n blockLength: 64,\n digestLength: 32,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 8\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength64 for backwards-compatibility)\n md.fullMessageLength = md.messageLength64 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _state = {\n h0: 0x6A09E667,\n h1: 0xBB67AE85,\n h2: 0x3C6EF372,\n h3: 0xA54FF53A,\n h4: 0x510E527F,\n h5: 0x9B05688C,\n h6: 0x1F83D9AB,\n h7: 0x5BE0CD19\n };\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = ((len[1] / 0x100000000) >>> 0);\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_state, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate SHA-256 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 448 mod 512. In other words,\n the data to be digested must be a multiple of 512 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 8 bytes (64\n bits), that means that the last segment of the data must have 56 bytes\n (448 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 448 mod 512 because\n 512 - 128 = 448.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 448 mod 512, then 512 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in big-endian order; since length\n // is stored in bytes we multiply by 8 and add carry from next int\n var next, carry;\n var bits = md.fullMessageLength[0] * 8;\n for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n next = md.fullMessageLength[i + 1] * 8;\n carry = (next / 0x100000000) >>> 0;\n bits += carry;\n finalBlock.putInt32(bits >>> 0);\n bits = next >>> 0;\n }\n finalBlock.putInt32(bits);\n\n var s2 = {\n h0: _state.h0,\n h1: _state.h1,\n h2: _state.h2,\n h3: _state.h3,\n h4: _state.h4,\n h5: _state.h5,\n h6: _state.h6,\n h7: _state.h7\n };\n _update(s2, _w, finalBlock);\n var rval = forge.util.createBuffer();\n rval.putInt32(s2.h0);\n rval.putInt32(s2.h1);\n rval.putInt32(s2.h2);\n rval.putInt32(s2.h3);\n rval.putInt32(s2.h4);\n rval.putInt32(s2.h5);\n rval.putInt32(s2.h6);\n rval.putInt32(s2.h7);\n return rval;\n };\n\n return md;\n};\n\n// sha-256 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n// table of constants\nvar _k = null;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 64);\n\n // create K table for SHA-256\n _k = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2];\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates a SHA-256 state with the given byte buffer.\n *\n * @param s the SHA-256 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (64 byte) chunks\n var t1, t2, s0, s1, ch, maj, i, a, b, c, d, e, f, g, h;\n var len = bytes.length();\n while(len >= 64) {\n // the w array will be populated with sixteen 32-bit big-endian words\n // and then extended into 64 32-bit words according to SHA-256\n for(i = 0; i < 16; ++i) {\n w[i] = bytes.getInt32();\n }\n for(; i < 64; ++i) {\n // XOR word 2 words ago rot right 17, rot right 19, shft right 10\n t1 = w[i - 2];\n t1 =\n ((t1 >>> 17) | (t1 << 15)) ^\n ((t1 >>> 19) | (t1 << 13)) ^\n (t1 >>> 10);\n // XOR word 15 words ago rot right 7, rot right 18, shft right 3\n t2 = w[i - 15];\n t2 =\n ((t2 >>> 7) | (t2 << 25)) ^\n ((t2 >>> 18) | (t2 << 14)) ^\n (t2 >>> 3);\n // sum(t1, word 7 ago, t2, word 16 ago) modulo 2^32\n w[i] = (t1 + w[i - 7] + t2 + w[i - 16]) | 0;\n }\n\n // initialize hash value for this chunk\n a = s.h0;\n b = s.h1;\n c = s.h2;\n d = s.h3;\n e = s.h4;\n f = s.h5;\n g = s.h6;\n h = s.h7;\n\n // round function\n for(i = 0; i < 64; ++i) {\n // Sum1(e)\n s1 =\n ((e >>> 6) | (e << 26)) ^\n ((e >>> 11) | (e << 21)) ^\n ((e >>> 25) | (e << 7));\n // Ch(e, f, g) (optimized the same way as SHA-1)\n ch = g ^ (e & (f ^ g));\n // Sum0(a)\n s0 =\n ((a >>> 2) | (a << 30)) ^\n ((a >>> 13) | (a << 19)) ^\n ((a >>> 22) | (a << 10));\n // Maj(a, b, c) (optimized the same way as SHA-1)\n maj = (a & b) | (c & (a ^ b));\n\n // main algorithm\n t1 = h + s1 + ch + _k[i] + w[i];\n t2 = s0 + maj;\n h = g;\n g = f;\n f = e;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n // can't truncate with `| 0`\n e = (d + t1) >>> 0;\n d = c;\n c = b;\n b = a;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n // can't truncate with `| 0`\n a = (t1 + t2) >>> 0;\n }\n\n // update hash state\n s.h0 = (s.h0 + a) | 0;\n s.h1 = (s.h1 + b) | 0;\n s.h2 = (s.h2 + c) | 0;\n s.h3 = (s.h3 + d) | 0;\n s.h4 = (s.h4 + e) | 0;\n s.h5 = (s.h5 + f) | 0;\n s.h6 = (s.h6 + g) | 0;\n s.h7 = (s.h7 + h) | 0;\n len -= 64;\n }\n}\n","/**\n * A javascript implementation of a cryptographically-secure\n * Pseudo Random Number Generator (PRNG). The Fortuna algorithm is followed\n * here though the use of SHA-256 is not enforced; when generating an\n * a PRNG context, the hashing algorithm and block cipher used for\n * the generator are specified via a plugin.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nvar _crypto = null;\nif(forge.util.isNodejs && !forge.options.usePureJavaScript &&\n !process.versions['node-webkit']) {\n _crypto = require('crypto');\n}\n\n/* PRNG API */\nvar prng = module.exports = forge.prng = forge.prng || {};\n\n/**\n * Creates a new PRNG context.\n *\n * A PRNG plugin must be passed in that will provide:\n *\n * 1. A function that initializes the key and seed of a PRNG context. It\n * will be given a 16 byte key and a 16 byte seed. Any key expansion\n * or transformation of the seed from a byte string into an array of\n * integers (or similar) should be performed.\n * 2. The cryptographic function used by the generator. It takes a key and\n * a seed.\n * 3. A seed increment function. It takes the seed and returns seed + 1.\n * 4. An api to create a message digest.\n *\n * For an example, see random.js.\n *\n * @param plugin the PRNG plugin to use.\n */\nprng.create = function(plugin) {\n var ctx = {\n plugin: plugin,\n key: null,\n seed: null,\n time: null,\n // number of reseeds so far\n reseeds: 0,\n // amount of data generated so far\n generated: 0,\n // no initial key bytes\n keyBytes: ''\n };\n\n // create 32 entropy pools (each is a message digest)\n var md = plugin.md;\n var pools = new Array(32);\n for(var i = 0; i < 32; ++i) {\n pools[i] = md.create();\n }\n ctx.pools = pools;\n\n // entropy pools are written to cyclically, starting at index 0\n ctx.pool = 0;\n\n /**\n * Generates random bytes. The bytes may be generated synchronously or\n * asynchronously. Web workers must use the asynchronous interface or\n * else the behavior is undefined.\n *\n * @param count the number of random bytes to generate.\n * @param [callback(err, bytes)] called once the operation completes.\n *\n * @return count random bytes as a string.\n */\n ctx.generate = function(count, callback) {\n // do synchronously\n if(!callback) {\n return ctx.generateSync(count);\n }\n\n // simple generator using counter-based CBC\n var cipher = ctx.plugin.cipher;\n var increment = ctx.plugin.increment;\n var formatKey = ctx.plugin.formatKey;\n var formatSeed = ctx.plugin.formatSeed;\n var b = forge.util.createBuffer();\n\n // paranoid deviation from Fortuna:\n // reset key for every request to protect previously\n // generated random bytes should the key be discovered;\n // there is no 100ms based reseeding because of this\n // forced reseed for every `generate` call\n ctx.key = null;\n\n generate();\n\n function generate(err) {\n if(err) {\n return callback(err);\n }\n\n // sufficient bytes generated\n if(b.length() >= count) {\n return callback(null, b.getBytes(count));\n }\n\n // if amount of data generated is greater than 1 MiB, trigger reseed\n if(ctx.generated > 0xfffff) {\n ctx.key = null;\n }\n\n if(ctx.key === null) {\n // prevent stack overflow\n return forge.util.nextTick(function() {\n _reseed(generate);\n });\n }\n\n // generate the random bytes\n var bytes = cipher(ctx.key, ctx.seed);\n ctx.generated += bytes.length;\n b.putBytes(bytes);\n\n // generate bytes for a new key and seed\n ctx.key = formatKey(cipher(ctx.key, increment(ctx.seed)));\n ctx.seed = formatSeed(cipher(ctx.key, ctx.seed));\n\n forge.util.setImmediate(generate);\n }\n };\n\n /**\n * Generates random bytes synchronously.\n *\n * @param count the number of random bytes to generate.\n *\n * @return count random bytes as a string.\n */\n ctx.generateSync = function(count) {\n // simple generator using counter-based CBC\n var cipher = ctx.plugin.cipher;\n var increment = ctx.plugin.increment;\n var formatKey = ctx.plugin.formatKey;\n var formatSeed = ctx.plugin.formatSeed;\n\n // paranoid deviation from Fortuna:\n // reset key for every request to protect previously\n // generated random bytes should the key be discovered;\n // there is no 100ms based reseeding because of this\n // forced reseed for every `generateSync` call\n ctx.key = null;\n\n var b = forge.util.createBuffer();\n while(b.length() < count) {\n // if amount of data generated is greater than 1 MiB, trigger reseed\n if(ctx.generated > 0xfffff) {\n ctx.key = null;\n }\n\n if(ctx.key === null) {\n _reseedSync();\n }\n\n // generate the random bytes\n var bytes = cipher(ctx.key, ctx.seed);\n ctx.generated += bytes.length;\n b.putBytes(bytes);\n\n // generate bytes for a new key and seed\n ctx.key = formatKey(cipher(ctx.key, increment(ctx.seed)));\n ctx.seed = formatSeed(cipher(ctx.key, ctx.seed));\n }\n\n return b.getBytes(count);\n };\n\n /**\n * Private function that asynchronously reseeds a generator.\n *\n * @param callback(err) called once the operation completes.\n */\n function _reseed(callback) {\n if(ctx.pools[0].messageLength >= 32) {\n _seed();\n return callback();\n }\n // not enough seed data...\n var needed = (32 - ctx.pools[0].messageLength) << 5;\n ctx.seedFile(needed, function(err, bytes) {\n if(err) {\n return callback(err);\n }\n ctx.collect(bytes);\n _seed();\n callback();\n });\n }\n\n /**\n * Private function that synchronously reseeds a generator.\n */\n function _reseedSync() {\n if(ctx.pools[0].messageLength >= 32) {\n return _seed();\n }\n // not enough seed data...\n var needed = (32 - ctx.pools[0].messageLength) << 5;\n ctx.collect(ctx.seedFileSync(needed));\n _seed();\n }\n\n /**\n * Private function that seeds a generator once enough bytes are available.\n */\n function _seed() {\n // update reseed count\n ctx.reseeds = (ctx.reseeds === 0xffffffff) ? 0 : ctx.reseeds + 1;\n\n // goal is to update `key` via:\n // key = hash(key + s)\n // where 's' is all collected entropy from selected pools, then...\n\n // create a plugin-based message digest\n var md = ctx.plugin.md.create();\n\n // consume current key bytes\n md.update(ctx.keyBytes);\n\n // digest the entropy of pools whose index k meet the\n // condition 'n mod 2^k == 0' where n is the number of reseeds\n var _2powK = 1;\n for(var k = 0; k < 32; ++k) {\n if(ctx.reseeds % _2powK === 0) {\n md.update(ctx.pools[k].digest().getBytes());\n ctx.pools[k].start();\n }\n _2powK = _2powK << 1;\n }\n\n // get digest for key bytes\n ctx.keyBytes = md.digest().getBytes();\n\n // paranoid deviation from Fortuna:\n // update `seed` via `seed = hash(key)`\n // instead of initializing to zero once and only\n // ever incrementing it\n md.start();\n md.update(ctx.keyBytes);\n var seedBytes = md.digest().getBytes();\n\n // update state\n ctx.key = ctx.plugin.formatKey(ctx.keyBytes);\n ctx.seed = ctx.plugin.formatSeed(seedBytes);\n ctx.generated = 0;\n }\n\n /**\n * The built-in default seedFile. This seedFile is used when entropy\n * is needed immediately.\n *\n * @param needed the number of bytes that are needed.\n *\n * @return the random bytes.\n */\n function defaultSeedFile(needed) {\n // use window.crypto.getRandomValues strong source of entropy if available\n var getRandomValues = null;\n var globalScope = forge.util.globalScope;\n var _crypto = globalScope.crypto || globalScope.msCrypto;\n if(_crypto && _crypto.getRandomValues) {\n getRandomValues = function(arr) {\n return _crypto.getRandomValues(arr);\n };\n }\n\n var b = forge.util.createBuffer();\n if(getRandomValues) {\n while(b.length() < needed) {\n // max byte length is 65536 before QuotaExceededError is thrown\n // http://www.w3.org/TR/WebCryptoAPI/#RandomSource-method-getRandomValues\n var count = Math.max(1, Math.min(needed - b.length(), 65536) / 4);\n var entropy = new Uint32Array(Math.floor(count));\n try {\n getRandomValues(entropy);\n for(var i = 0; i < entropy.length; ++i) {\n b.putInt32(entropy[i]);\n }\n } catch(e) {\n /* only ignore QuotaExceededError */\n if(!(typeof QuotaExceededError !== 'undefined' &&\n e instanceof QuotaExceededError)) {\n throw e;\n }\n }\n }\n }\n\n // be sad and add some weak random data\n if(b.length() < needed) {\n /* Draws from Park-Miller \"minimal standard\" 31 bit PRNG,\n implemented with David G. Carta's optimization: with 32 bit math\n and without division (Public Domain). */\n var hi, lo, next;\n var seed = Math.floor(Math.random() * 0x010000);\n while(b.length() < needed) {\n lo = 16807 * (seed & 0xFFFF);\n hi = 16807 * (seed >> 16);\n lo += (hi & 0x7FFF) << 16;\n lo += hi >> 15;\n lo = (lo & 0x7FFFFFFF) + (lo >> 31);\n seed = lo & 0xFFFFFFFF;\n\n // consume lower 3 bytes of seed\n for(var i = 0; i < 3; ++i) {\n // throw in more pseudo random\n next = seed >>> (i << 3);\n next ^= Math.floor(Math.random() * 0x0100);\n b.putByte(String.fromCharCode(next & 0xFF));\n }\n }\n }\n\n return b.getBytes(needed);\n }\n // initialize seed file APIs\n if(_crypto) {\n // use nodejs async API\n ctx.seedFile = function(needed, callback) {\n _crypto.randomBytes(needed, function(err, bytes) {\n if(err) {\n return callback(err);\n }\n callback(null, bytes.toString());\n });\n };\n // use nodejs sync API\n ctx.seedFileSync = function(needed) {\n return _crypto.randomBytes(needed).toString();\n };\n } else {\n ctx.seedFile = function(needed, callback) {\n try {\n callback(null, defaultSeedFile(needed));\n } catch(e) {\n callback(e);\n }\n };\n ctx.seedFileSync = defaultSeedFile;\n }\n\n /**\n * Adds entropy to a prng ctx's accumulator.\n *\n * @param bytes the bytes of entropy as a string.\n */\n ctx.collect = function(bytes) {\n // iterate over pools distributing entropy cyclically\n var count = bytes.length;\n for(var i = 0; i < count; ++i) {\n ctx.pools[ctx.pool].update(bytes.substr(i, 1));\n ctx.pool = (ctx.pool === 31) ? 0 : ctx.pool + 1;\n }\n };\n\n /**\n * Collects an integer of n bits.\n *\n * @param i the integer entropy.\n * @param n the number of bits in the integer.\n */\n ctx.collectInt = function(i, n) {\n var bytes = '';\n for(var x = 0; x < n; x += 8) {\n bytes += String.fromCharCode((i >> x) & 0xFF);\n }\n ctx.collect(bytes);\n };\n\n /**\n * Registers a Web Worker to receive immediate entropy from the main thread.\n * This method is required until Web Workers can access the native crypto\n * API. This method should be called twice for each created worker, once in\n * the main thread, and once in the worker itself.\n *\n * @param worker the worker to register.\n */\n ctx.registerWorker = function(worker) {\n // worker receives random bytes\n if(worker === self) {\n ctx.seedFile = function(needed, callback) {\n function listener(e) {\n var data = e.data;\n if(data.forge && data.forge.prng) {\n self.removeEventListener('message', listener);\n callback(data.forge.prng.err, data.forge.prng.bytes);\n }\n }\n self.addEventListener('message', listener);\n self.postMessage({forge: {prng: {needed: needed}}});\n };\n } else {\n // main thread sends random bytes upon request\n var listener = function(e) {\n var data = e.data;\n if(data.forge && data.forge.prng) {\n ctx.seedFile(data.forge.prng.needed, function(err, bytes) {\n worker.postMessage({forge: {prng: {err: err, bytes: bytes}}});\n });\n }\n };\n // TODO: do we need to remove the event listener when the worker dies?\n worker.addEventListener('message', listener);\n }\n };\n\n return ctx;\n};\n","/**\n * RC2 implementation.\n *\n * @author Stefan Siegl\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * Information on the RC2 cipher is available from RFC #2268,\n * http://www.ietf.org/rfc/rfc2268.txt\n */\nvar forge = require('./forge');\nrequire('./util');\n\nvar piTable = [\n 0xd9, 0x78, 0xf9, 0xc4, 0x19, 0xdd, 0xb5, 0xed, 0x28, 0xe9, 0xfd, 0x79, 0x4a, 0xa0, 0xd8, 0x9d,\n 0xc6, 0x7e, 0x37, 0x83, 0x2b, 0x76, 0x53, 0x8e, 0x62, 0x4c, 0x64, 0x88, 0x44, 0x8b, 0xfb, 0xa2,\n 0x17, 0x9a, 0x59, 0xf5, 0x87, 0xb3, 0x4f, 0x13, 0x61, 0x45, 0x6d, 0x8d, 0x09, 0x81, 0x7d, 0x32,\n 0xbd, 0x8f, 0x40, 0xeb, 0x86, 0xb7, 0x7b, 0x0b, 0xf0, 0x95, 0x21, 0x22, 0x5c, 0x6b, 0x4e, 0x82,\n 0x54, 0xd6, 0x65, 0x93, 0xce, 0x60, 0xb2, 0x1c, 0x73, 0x56, 0xc0, 0x14, 0xa7, 0x8c, 0xf1, 0xdc,\n 0x12, 0x75, 0xca, 0x1f, 0x3b, 0xbe, 0xe4, 0xd1, 0x42, 0x3d, 0xd4, 0x30, 0xa3, 0x3c, 0xb6, 0x26,\n 0x6f, 0xbf, 0x0e, 0xda, 0x46, 0x69, 0x07, 0x57, 0x27, 0xf2, 0x1d, 0x9b, 0xbc, 0x94, 0x43, 0x03,\n 0xf8, 0x11, 0xc7, 0xf6, 0x90, 0xef, 0x3e, 0xe7, 0x06, 0xc3, 0xd5, 0x2f, 0xc8, 0x66, 0x1e, 0xd7,\n 0x08, 0xe8, 0xea, 0xde, 0x80, 0x52, 0xee, 0xf7, 0x84, 0xaa, 0x72, 0xac, 0x35, 0x4d, 0x6a, 0x2a,\n 0x96, 0x1a, 0xd2, 0x71, 0x5a, 0x15, 0x49, 0x74, 0x4b, 0x9f, 0xd0, 0x5e, 0x04, 0x18, 0xa4, 0xec,\n 0xc2, 0xe0, 0x41, 0x6e, 0x0f, 0x51, 0xcb, 0xcc, 0x24, 0x91, 0xaf, 0x50, 0xa1, 0xf4, 0x70, 0x39,\n 0x99, 0x7c, 0x3a, 0x85, 0x23, 0xb8, 0xb4, 0x7a, 0xfc, 0x02, 0x36, 0x5b, 0x25, 0x55, 0x97, 0x31,\n 0x2d, 0x5d, 0xfa, 0x98, 0xe3, 0x8a, 0x92, 0xae, 0x05, 0xdf, 0x29, 0x10, 0x67, 0x6c, 0xba, 0xc9,\n 0xd3, 0x00, 0xe6, 0xcf, 0xe1, 0x9e, 0xa8, 0x2c, 0x63, 0x16, 0x01, 0x3f, 0x58, 0xe2, 0x89, 0xa9,\n 0x0d, 0x38, 0x34, 0x1b, 0xab, 0x33, 0xff, 0xb0, 0xbb, 0x48, 0x0c, 0x5f, 0xb9, 0xb1, 0xcd, 0x2e,\n 0xc5, 0xf3, 0xdb, 0x47, 0xe5, 0xa5, 0x9c, 0x77, 0x0a, 0xa6, 0x20, 0x68, 0xfe, 0x7f, 0xc1, 0xad\n];\n\nvar s = [1, 2, 3, 5];\n\n/**\n * Rotate a word left by given number of bits.\n *\n * Bits that are shifted out on the left are put back in on the right\n * hand side.\n *\n * @param word The word to shift left.\n * @param bits The number of bits to shift by.\n * @return The rotated word.\n */\nvar rol = function(word, bits) {\n return ((word << bits) & 0xffff) | ((word & 0xffff) >> (16 - bits));\n};\n\n/**\n * Rotate a word right by given number of bits.\n *\n * Bits that are shifted out on the right are put back in on the left\n * hand side.\n *\n * @param word The word to shift right.\n * @param bits The number of bits to shift by.\n * @return The rotated word.\n */\nvar ror = function(word, bits) {\n return ((word & 0xffff) >> bits) | ((word << (16 - bits)) & 0xffff);\n};\n\n/* RC2 API */\nmodule.exports = forge.rc2 = forge.rc2 || {};\n\n/**\n * Perform RC2 key expansion as per RFC #2268, section 2.\n *\n * @param key variable-length user key (between 1 and 128 bytes)\n * @param effKeyBits number of effective key bits (default: 128)\n * @return the expanded RC2 key (ByteBuffer of 128 bytes)\n */\nforge.rc2.expandKey = function(key, effKeyBits) {\n if(typeof key === 'string') {\n key = forge.util.createBuffer(key);\n }\n effKeyBits = effKeyBits || 128;\n\n /* introduce variables that match the names used in RFC #2268 */\n var L = key;\n var T = key.length();\n var T1 = effKeyBits;\n var T8 = Math.ceil(T1 / 8);\n var TM = 0xff >> (T1 & 0x07);\n var i;\n\n for(i = T; i < 128; i++) {\n L.putByte(piTable[(L.at(i - 1) + L.at(i - T)) & 0xff]);\n }\n\n L.setAt(128 - T8, piTable[L.at(128 - T8) & TM]);\n\n for(i = 127 - T8; i >= 0; i--) {\n L.setAt(i, piTable[L.at(i + 1) ^ L.at(i + T8)]);\n }\n\n return L;\n};\n\n/**\n * Creates a RC2 cipher object.\n *\n * @param key the symmetric key to use (as base for key generation).\n * @param bits the number of effective key bits.\n * @param encrypt false for decryption, true for encryption.\n *\n * @return the cipher.\n */\nvar createCipher = function(key, bits, encrypt) {\n var _finish = false, _input = null, _output = null, _iv = null;\n var mixRound, mashRound;\n var i, j, K = [];\n\n /* Expand key and fill into K[] Array */\n key = forge.rc2.expandKey(key, bits);\n for(i = 0; i < 64; i++) {\n K.push(key.getInt16Le());\n }\n\n if(encrypt) {\n /**\n * Perform one mixing round \"in place\".\n *\n * @param R Array of four words to perform mixing on.\n */\n mixRound = function(R) {\n for(i = 0; i < 4; i++) {\n R[i] += K[j] + (R[(i + 3) % 4] & R[(i + 2) % 4]) +\n ((~R[(i + 3) % 4]) & R[(i + 1) % 4]);\n R[i] = rol(R[i], s[i]);\n j++;\n }\n };\n\n /**\n * Perform one mashing round \"in place\".\n *\n * @param R Array of four words to perform mashing on.\n */\n mashRound = function(R) {\n for(i = 0; i < 4; i++) {\n R[i] += K[R[(i + 3) % 4] & 63];\n }\n };\n } else {\n /**\n * Perform one r-mixing round \"in place\".\n *\n * @param R Array of four words to perform mixing on.\n */\n mixRound = function(R) {\n for(i = 3; i >= 0; i--) {\n R[i] = ror(R[i], s[i]);\n R[i] -= K[j] + (R[(i + 3) % 4] & R[(i + 2) % 4]) +\n ((~R[(i + 3) % 4]) & R[(i + 1) % 4]);\n j--;\n }\n };\n\n /**\n * Perform one r-mashing round \"in place\".\n *\n * @param R Array of four words to perform mashing on.\n */\n mashRound = function(R) {\n for(i = 3; i >= 0; i--) {\n R[i] -= K[R[(i + 3) % 4] & 63];\n }\n };\n }\n\n /**\n * Run the specified cipher execution plan.\n *\n * This function takes four words from the input buffer, applies the IV on\n * it (if requested) and runs the provided execution plan.\n *\n * The plan must be put together in form of a array of arrays. Where the\n * outer one is simply a list of steps to perform and the inner one needs\n * to have two elements: the first one telling how many rounds to perform,\n * the second one telling what to do (i.e. the function to call).\n *\n * @param {Array} plan The plan to execute.\n */\n var runPlan = function(plan) {\n var R = [];\n\n /* Get data from input buffer and fill the four words into R */\n for(i = 0; i < 4; i++) {\n var val = _input.getInt16Le();\n\n if(_iv !== null) {\n if(encrypt) {\n /* We're encrypting, apply the IV first. */\n val ^= _iv.getInt16Le();\n } else {\n /* We're decryption, keep cipher text for next block. */\n _iv.putInt16Le(val);\n }\n }\n\n R.push(val & 0xffff);\n }\n\n /* Reset global \"j\" variable as per spec. */\n j = encrypt ? 0 : 63;\n\n /* Run execution plan. */\n for(var ptr = 0; ptr < plan.length; ptr++) {\n for(var ctr = 0; ctr < plan[ptr][0]; ctr++) {\n plan[ptr][1](R);\n }\n }\n\n /* Write back result to output buffer. */\n for(i = 0; i < 4; i++) {\n if(_iv !== null) {\n if(encrypt) {\n /* We're encrypting in CBC-mode, feed back encrypted bytes into\n IV buffer to carry it forward to next block. */\n _iv.putInt16Le(R[i]);\n } else {\n R[i] ^= _iv.getInt16Le();\n }\n }\n\n _output.putInt16Le(R[i]);\n }\n };\n\n /* Create cipher object */\n var cipher = null;\n cipher = {\n /**\n * Starts or restarts the encryption or decryption process, whichever\n * was previously configured.\n *\n * To use the cipher in CBC mode, iv may be given either as a string\n * of bytes, or as a byte buffer. For ECB mode, give null as iv.\n *\n * @param iv the initialization vector to use, null for ECB mode.\n * @param output the output the buffer to write to, null to create one.\n */\n start: function(iv, output) {\n if(iv) {\n /* CBC mode */\n if(typeof iv === 'string') {\n iv = forge.util.createBuffer(iv);\n }\n }\n\n _finish = false;\n _input = forge.util.createBuffer();\n _output = output || new forge.util.createBuffer();\n _iv = iv;\n\n cipher.output = _output;\n },\n\n /**\n * Updates the next block.\n *\n * @param input the buffer to read from.\n */\n update: function(input) {\n if(!_finish) {\n // not finishing, so fill the input buffer with more input\n _input.putBuffer(input);\n }\n\n while(_input.length() >= 8) {\n runPlan([\n [ 5, mixRound ],\n [ 1, mashRound ],\n [ 6, mixRound ],\n [ 1, mashRound ],\n [ 5, mixRound ]\n ]);\n }\n },\n\n /**\n * Finishes encrypting or decrypting.\n *\n * @param pad a padding function to use, null for PKCS#7 padding,\n * signature(blockSize, buffer, decrypt).\n *\n * @return true if successful, false on error.\n */\n finish: function(pad) {\n var rval = true;\n\n if(encrypt) {\n if(pad) {\n rval = pad(8, _input, !encrypt);\n } else {\n // add PKCS#7 padding to block (each pad byte is the\n // value of the number of pad bytes)\n var padding = (_input.length() === 8) ? 8 : (8 - _input.length());\n _input.fillWithByte(padding, padding);\n }\n }\n\n if(rval) {\n // do final update\n _finish = true;\n cipher.update();\n }\n\n if(!encrypt) {\n // check for error: input data not a multiple of block size\n rval = (_input.length() === 0);\n if(rval) {\n if(pad) {\n rval = pad(8, _output, !encrypt);\n } else {\n // ensure padding byte count is valid\n var len = _output.length();\n var count = _output.at(len - 1);\n\n if(count > len) {\n rval = false;\n } else {\n // trim off padding bytes\n _output.truncate(count);\n }\n }\n }\n }\n\n return rval;\n }\n };\n\n return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to encrypt data in ECB or CBC mode using the\n * given symmetric key. The output will be stored in the 'output' member\n * of the returned cipher.\n *\n * The key and iv may be given as a string of bytes or a byte buffer.\n * The cipher is initialized to use 128 effective key bits.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n *\n * @return the cipher.\n */\nforge.rc2.startEncrypting = function(key, iv, output) {\n var cipher = forge.rc2.createEncryptionCipher(key, 128);\n cipher.start(iv, output);\n return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to encrypt data in ECB or CBC mode using the\n * given symmetric key.\n *\n * The key may be given as a string of bytes or a byte buffer.\n *\n * To start encrypting call start() on the cipher with an iv and optional\n * output buffer.\n *\n * @param key the symmetric key to use.\n *\n * @return the cipher.\n */\nforge.rc2.createEncryptionCipher = function(key, bits) {\n return createCipher(key, bits, true);\n};\n\n/**\n * Creates an RC2 cipher object to decrypt data in ECB or CBC mode using the\n * given symmetric key. The output will be stored in the 'output' member\n * of the returned cipher.\n *\n * The key and iv may be given as a string of bytes or a byte buffer.\n * The cipher is initialized to use 128 effective key bits.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n *\n * @return the cipher.\n */\nforge.rc2.startDecrypting = function(key, iv, output) {\n var cipher = forge.rc2.createDecryptionCipher(key, 128);\n cipher.start(iv, output);\n return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to decrypt data in ECB or CBC mode using the\n * given symmetric key.\n *\n * The key may be given as a string of bytes or a byte buffer.\n *\n * To start decrypting call start() on the cipher with an iv and optional\n * output buffer.\n *\n * @param key the symmetric key to use.\n *\n * @return the cipher.\n */\nforge.rc2.createDecryptionCipher = function(key, bits) {\n return createCipher(key, bits, false);\n};\n","/**\n * Javascript implementation of basic RSA algorithms.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n *\n * The only algorithm currently supported for PKI is RSA.\n *\n * An RSA key is often stored in ASN.1 DER format. The SubjectPublicKeyInfo\n * ASN.1 structure is composed of an algorithm of type AlgorithmIdentifier\n * and a subjectPublicKey of type bit string.\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of RSA, there aren't any.\n *\n * SubjectPublicKeyInfo ::= SEQUENCE {\n * algorithm AlgorithmIdentifier,\n * subjectPublicKey BIT STRING\n * }\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * For an RSA public key, the subjectPublicKey is:\n *\n * RSAPublicKey ::= SEQUENCE {\n * modulus INTEGER, -- n\n * publicExponent INTEGER -- e\n * }\n *\n * PrivateKeyInfo ::= SEQUENCE {\n * version Version,\n * privateKeyAlgorithm PrivateKeyAlgorithmIdentifier,\n * privateKey PrivateKey,\n * attributes [0] IMPLICIT Attributes OPTIONAL\n * }\n *\n * Version ::= INTEGER\n * PrivateKeyAlgorithmIdentifier ::= AlgorithmIdentifier\n * PrivateKey ::= OCTET STRING\n * Attributes ::= SET OF Attribute\n *\n * An RSA private key as the following structure:\n *\n * RSAPrivateKey ::= SEQUENCE {\n * version Version,\n * modulus INTEGER, -- n\n * publicExponent INTEGER, -- e\n * privateExponent INTEGER, -- d\n * prime1 INTEGER, -- p\n * prime2 INTEGER, -- q\n * exponent1 INTEGER, -- d mod (p-1)\n * exponent2 INTEGER, -- d mod (q-1)\n * coefficient INTEGER -- (inverse of q) mod p\n * }\n *\n * Version ::= INTEGER\n *\n * The OID for the RSA key algorithm is: 1.2.840.113549.1.1.1\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./jsbn');\nrequire('./oids');\nrequire('./pkcs1');\nrequire('./prime');\nrequire('./random');\nrequire('./util');\n\nif(typeof BigInteger === 'undefined') {\n var BigInteger = forge.jsbn.BigInteger;\n}\n\nvar _crypto = forge.util.isNodejs ? require('crypto') : null;\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for util API\nvar util = forge.util;\n\n/*\n * RSA encryption and decryption, see RFC 2313.\n */\nforge.pki = forge.pki || {};\nmodule.exports = forge.pki.rsa = forge.rsa = forge.rsa || {};\nvar pki = forge.pki;\n\n// for finding primes, which are 30k+i for i = 1, 7, 11, 13, 17, 19, 23, 29\nvar GCD_30_DELTA = [6, 4, 2, 4, 2, 4, 6, 2];\n\n// validator for a PrivateKeyInfo structure\nvar privateKeyValidator = {\n // PrivateKeyInfo\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // Version (INTEGER)\n name: 'PrivateKeyInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyVersion'\n }, {\n // privateKeyAlgorithm\n name: 'PrivateKeyInfo.privateKeyAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'privateKeyOid'\n }]\n }, {\n // PrivateKey\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'privateKey'\n }]\n};\n\n// validator for an RSA private key\nvar rsaPrivateKeyValidator = {\n // RSAPrivateKey\n name: 'RSAPrivateKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // Version (INTEGER)\n name: 'RSAPrivateKey.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyVersion'\n }, {\n // modulus (n)\n name: 'RSAPrivateKey.modulus',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyModulus'\n }, {\n // publicExponent (e)\n name: 'RSAPrivateKey.publicExponent',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPublicExponent'\n }, {\n // privateExponent (d)\n name: 'RSAPrivateKey.privateExponent',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPrivateExponent'\n }, {\n // prime1 (p)\n name: 'RSAPrivateKey.prime1',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPrime1'\n }, {\n // prime2 (q)\n name: 'RSAPrivateKey.prime2',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPrime2'\n }, {\n // exponent1 (d mod (p-1))\n name: 'RSAPrivateKey.exponent1',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyExponent1'\n }, {\n // exponent2 (d mod (q-1))\n name: 'RSAPrivateKey.exponent2',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyExponent2'\n }, {\n // coefficient ((inverse of q) mod p)\n name: 'RSAPrivateKey.coefficient',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyCoefficient'\n }]\n};\n\n// validator for an RSA public key\nvar rsaPublicKeyValidator = {\n // RSAPublicKey\n name: 'RSAPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // modulus (n)\n name: 'RSAPublicKey.modulus',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'publicKeyModulus'\n }, {\n // publicExponent (e)\n name: 'RSAPublicKey.exponent',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'publicKeyExponent'\n }]\n};\n\n// validator for an SubjectPublicKeyInfo structure\n// Note: Currently only works with an RSA public key\nvar publicKeyValidator = forge.pki.rsa.publicKeyValidator = {\n name: 'SubjectPublicKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'subjectPublicKeyInfo',\n value: [{\n name: 'SubjectPublicKeyInfo.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'publicKeyOid'\n }]\n }, {\n // subjectPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n value: [{\n // RSAPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n captureAsn1: 'rsaPublicKey'\n }]\n }]\n};\n\n/**\n * Wrap digest in DigestInfo object.\n *\n * This function implements EMSA-PKCS1-v1_5-ENCODE as per RFC 3447.\n *\n * DigestInfo ::= SEQUENCE {\n * digestAlgorithm DigestAlgorithmIdentifier,\n * digest Digest\n * }\n *\n * DigestAlgorithmIdentifier ::= AlgorithmIdentifier\n * Digest ::= OCTET STRING\n *\n * @param md the message digest object with the hash to sign.\n *\n * @return the encoded message (ready for RSA encrytion)\n */\nvar emsaPkcs1v15encode = function(md) {\n // get the oid for the algorithm\n var oid;\n if(md.algorithm in pki.oids) {\n oid = pki.oids[md.algorithm];\n } else {\n var error = new Error('Unknown message digest algorithm.');\n error.algorithm = md.algorithm;\n throw error;\n }\n var oidBytes = asn1.oidToDer(oid).getBytes();\n\n // create the digest info\n var digestInfo = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var digestAlgorithm = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n digestAlgorithm.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OID, false, oidBytes));\n digestAlgorithm.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.NULL, false, ''));\n var digest = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING,\n false, md.digest().getBytes());\n digestInfo.value.push(digestAlgorithm);\n digestInfo.value.push(digest);\n\n // encode digest info\n return asn1.toDer(digestInfo).getBytes();\n};\n\n/**\n * Performs x^c mod n (RSA encryption or decryption operation).\n *\n * @param x the number to raise and mod.\n * @param key the key to use.\n * @param pub true if the key is public, false if private.\n *\n * @return the result of x^c mod n.\n */\nvar _modPow = function(x, key, pub) {\n if(pub) {\n return x.modPow(key.e, key.n);\n }\n\n if(!key.p || !key.q) {\n // allow calculation without CRT params (slow)\n return x.modPow(key.d, key.n);\n }\n\n // pre-compute dP, dQ, and qInv if necessary\n if(!key.dP) {\n key.dP = key.d.mod(key.p.subtract(BigInteger.ONE));\n }\n if(!key.dQ) {\n key.dQ = key.d.mod(key.q.subtract(BigInteger.ONE));\n }\n if(!key.qInv) {\n key.qInv = key.q.modInverse(key.p);\n }\n\n /* Chinese remainder theorem (CRT) states:\n\n Suppose n1, n2, ..., nk are positive integers which are pairwise\n coprime (n1 and n2 have no common factors other than 1). For any\n integers x1, x2, ..., xk there exists an integer x solving the\n system of simultaneous congruences (where ~= means modularly\n congruent so a ~= b mod n means a mod n = b mod n):\n\n x ~= x1 mod n1\n x ~= x2 mod n2\n ...\n x ~= xk mod nk\n\n This system of congruences has a single simultaneous solution x\n between 0 and n - 1. Furthermore, each xk solution and x itself\n is congruent modulo the product n = n1*n2*...*nk.\n So x1 mod n = x2 mod n = xk mod n = x mod n.\n\n The single simultaneous solution x can be solved with the following\n equation:\n\n x = sum(xi*ri*si) mod n where ri = n/ni and si = ri^-1 mod ni.\n\n Where x is less than n, xi = x mod ni.\n\n For RSA we are only concerned with k = 2. The modulus n = pq, where\n p and q are coprime. The RSA decryption algorithm is:\n\n y = x^d mod n\n\n Given the above:\n\n x1 = x^d mod p\n r1 = n/p = q\n s1 = q^-1 mod p\n x2 = x^d mod q\n r2 = n/q = p\n s2 = p^-1 mod q\n\n So y = (x1r1s1 + x2r2s2) mod n\n = ((x^d mod p)q(q^-1 mod p) + (x^d mod q)p(p^-1 mod q)) mod n\n\n According to Fermat's Little Theorem, if the modulus P is prime,\n for any integer A not evenly divisible by P, A^(P-1) ~= 1 mod P.\n Since A is not divisible by P it follows that if:\n N ~= M mod (P - 1), then A^N mod P = A^M mod P. Therefore:\n\n A^N mod P = A^(M mod (P - 1)) mod P. (The latter takes less effort\n to calculate). In order to calculate x^d mod p more quickly the\n exponent d mod (p - 1) is stored in the RSA private key (the same\n is done for x^d mod q). These values are referred to as dP and dQ\n respectively. Therefore we now have:\n\n y = ((x^dP mod p)q(q^-1 mod p) + (x^dQ mod q)p(p^-1 mod q)) mod n\n\n Since we'll be reducing x^dP by modulo p (same for q) we can also\n reduce x by p (and q respectively) before hand. Therefore, let\n\n xp = ((x mod p)^dP mod p), and\n xq = ((x mod q)^dQ mod q), yielding:\n\n y = (xp*q*(q^-1 mod p) + xq*p*(p^-1 mod q)) mod n\n\n This can be further reduced to a simple algorithm that only\n requires 1 inverse (the q inverse is used) to be used and stored.\n The algorithm is called Garner's algorithm. If qInv is the\n inverse of q, we simply calculate:\n\n y = (qInv*(xp - xq) mod p) * q + xq\n\n However, there are two further complications. First, we need to\n ensure that xp > xq to prevent signed BigIntegers from being used\n so we add p until this is true (since we will be mod'ing with\n p anyway). Then, there is a known timing attack on algorithms\n using the CRT. To mitigate this risk, \"cryptographic blinding\"\n should be used. This requires simply generating a random number r\n between 0 and n-1 and its inverse and multiplying x by r^e before\n calculating y and then multiplying y by r^-1 afterwards. Note that\n r must be coprime with n (gcd(r, n) === 1) in order to have an\n inverse.\n */\n\n // cryptographic blinding\n var r;\n do {\n r = new BigInteger(\n forge.util.bytesToHex(forge.random.getBytes(key.n.bitLength() / 8)),\n 16);\n } while(r.compareTo(key.n) >= 0 || !r.gcd(key.n).equals(BigInteger.ONE));\n x = x.multiply(r.modPow(key.e, key.n)).mod(key.n);\n\n // calculate xp and xq\n var xp = x.mod(key.p).modPow(key.dP, key.p);\n var xq = x.mod(key.q).modPow(key.dQ, key.q);\n\n // xp must be larger than xq to avoid signed bit usage\n while(xp.compareTo(xq) < 0) {\n xp = xp.add(key.p);\n }\n\n // do last step\n var y = xp.subtract(xq)\n .multiply(key.qInv).mod(key.p)\n .multiply(key.q).add(xq);\n\n // remove effect of random for cryptographic blinding\n y = y.multiply(r.modInverse(key.n)).mod(key.n);\n\n return y;\n};\n\n/**\n * NOTE: THIS METHOD IS DEPRECATED, use 'sign' on a private key object or\n * 'encrypt' on a public key object instead.\n *\n * Performs RSA encryption.\n *\n * The parameter bt controls whether to put padding bytes before the\n * message passed in. Set bt to either true or false to disable padding\n * completely (in order to handle e.g. EMSA-PSS encoding seperately before),\n * signaling whether the encryption operation is a public key operation\n * (i.e. encrypting data) or not, i.e. private key operation (data signing).\n *\n * For PKCS#1 v1.5 padding pass in the block type to use, i.e. either 0x01\n * (for signing) or 0x02 (for encryption). The key operation mode (private\n * or public) is derived from this flag in that case).\n *\n * @param m the message to encrypt as a byte string.\n * @param key the RSA key to use.\n * @param bt for PKCS#1 v1.5 padding, the block type to use\n * (0x01 for private key, 0x02 for public),\n * to disable padding: true = public key, false = private key.\n *\n * @return the encrypted bytes as a string.\n */\npki.rsa.encrypt = function(m, key, bt) {\n var pub = bt;\n var eb;\n\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n if(bt !== false && bt !== true) {\n // legacy, default to PKCS#1 v1.5 padding\n pub = (bt === 0x02);\n eb = _encodePkcs1_v1_5(m, key, bt);\n } else {\n eb = forge.util.createBuffer();\n eb.putBytes(m);\n }\n\n // load encryption block as big integer 'x'\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var x = new BigInteger(eb.toHex(), 16);\n\n // do RSA encryption\n var y = _modPow(x, key, pub);\n\n // convert y into the encrypted data byte string, if y is shorter in\n // bytes than k, then prepend zero bytes to fill up ed\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var yhex = y.toString(16);\n var ed = forge.util.createBuffer();\n var zeros = k - Math.ceil(yhex.length / 2);\n while(zeros > 0) {\n ed.putByte(0x00);\n --zeros;\n }\n ed.putBytes(forge.util.hexToBytes(yhex));\n return ed.getBytes();\n};\n\n/**\n * NOTE: THIS METHOD IS DEPRECATED, use 'decrypt' on a private key object or\n * 'verify' on a public key object instead.\n *\n * Performs RSA decryption.\n *\n * The parameter ml controls whether to apply PKCS#1 v1.5 padding\n * or not. Set ml = false to disable padding removal completely\n * (in order to handle e.g. EMSA-PSS later on) and simply pass back\n * the RSA encryption block.\n *\n * @param ed the encrypted data to decrypt in as a byte string.\n * @param key the RSA key to use.\n * @param pub true for a public key operation, false for private.\n * @param ml the message length, if known, false to disable padding.\n *\n * @return the decrypted message as a byte string.\n */\npki.rsa.decrypt = function(ed, key, pub, ml) {\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n // error if the length of the encrypted data ED is not k\n if(ed.length !== k) {\n var error = new Error('Encrypted message length is invalid.');\n error.length = ed.length;\n error.expected = k;\n throw error;\n }\n\n // convert encrypted data into a big integer\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var y = new BigInteger(forge.util.createBuffer(ed).toHex(), 16);\n\n // y must be less than the modulus or it wasn't the result of\n // a previous mod operation (encryption) using that modulus\n if(y.compareTo(key.n) >= 0) {\n throw new Error('Encrypted message is invalid.');\n }\n\n // do RSA decryption\n var x = _modPow(y, key, pub);\n\n // create the encryption block, if x is shorter in bytes than k, then\n // prepend zero bytes to fill up eb\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var xhex = x.toString(16);\n var eb = forge.util.createBuffer();\n var zeros = k - Math.ceil(xhex.length / 2);\n while(zeros > 0) {\n eb.putByte(0x00);\n --zeros;\n }\n eb.putBytes(forge.util.hexToBytes(xhex));\n\n if(ml !== false) {\n // legacy, default to PKCS#1 v1.5 padding\n return _decodePkcs1_v1_5(eb.getBytes(), key, pub);\n }\n\n // return message\n return eb.getBytes();\n};\n\n/**\n * Creates an RSA key-pair generation state object. It is used to allow\n * key-generation to be performed in steps. It also allows for a UI to\n * display progress updates.\n *\n * @param bits the size for the private key in bits, defaults to 2048.\n * @param e the public exponent to use, defaults to 65537 (0x10001).\n * @param [options] the options to use.\n * prng a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\".\n * algorithm the algorithm to use (default: 'PRIMEINC').\n *\n * @return the state object to use to generate the key-pair.\n */\npki.rsa.createKeyPairGenerationState = function(bits, e, options) {\n // TODO: migrate step-based prime generation code to forge.prime\n\n // set default bits\n if(typeof(bits) === 'string') {\n bits = parseInt(bits, 10);\n }\n bits = bits || 2048;\n\n // create prng with api that matches BigInteger secure random\n options = options || {};\n var prng = options.prng || forge.random;\n var rng = {\n // x is an array to fill with bytes\n nextBytes: function(x) {\n var b = prng.getBytesSync(x.length);\n for(var i = 0; i < x.length; ++i) {\n x[i] = b.charCodeAt(i);\n }\n }\n };\n\n var algorithm = options.algorithm || 'PRIMEINC';\n\n // create PRIMEINC algorithm state\n var rval;\n if(algorithm === 'PRIMEINC') {\n rval = {\n algorithm: algorithm,\n state: 0,\n bits: bits,\n rng: rng,\n eInt: e || 65537,\n e: new BigInteger(null),\n p: null,\n q: null,\n qBits: bits >> 1,\n pBits: bits - (bits >> 1),\n pqState: 0,\n num: null,\n keys: null\n };\n rval.e.fromInt(rval.eInt);\n } else {\n throw new Error('Invalid key generation algorithm: ' + algorithm);\n }\n\n return rval;\n};\n\n/**\n * Attempts to runs the key-generation algorithm for at most n seconds\n * (approximately) using the given state. When key-generation has completed,\n * the keys will be stored in state.keys.\n *\n * To use this function to update a UI while generating a key or to prevent\n * causing browser lockups/warnings, set \"n\" to a value other than 0. A\n * simple pattern for generating a key and showing a progress indicator is:\n *\n * var state = pki.rsa.createKeyPairGenerationState(2048);\n * var step = function() {\n * // step key-generation, run algorithm for 100 ms, repeat\n * if(!forge.pki.rsa.stepKeyPairGenerationState(state, 100)) {\n * setTimeout(step, 1);\n * } else {\n * // key-generation complete\n * // TODO: turn off progress indicator here\n * // TODO: use the generated key-pair in \"state.keys\"\n * }\n * };\n * // TODO: turn on progress indicator here\n * setTimeout(step, 0);\n *\n * @param state the state to use.\n * @param n the maximum number of milliseconds to run the algorithm for, 0\n * to run the algorithm to completion.\n *\n * @return true if the key-generation completed, false if not.\n */\npki.rsa.stepKeyPairGenerationState = function(state, n) {\n // set default algorithm if not set\n if(!('algorithm' in state)) {\n state.algorithm = 'PRIMEINC';\n }\n\n // TODO: migrate step-based prime generation code to forge.prime\n // TODO: abstract as PRIMEINC algorithm\n\n // do key generation (based on Tom Wu's rsa.js, see jsbn.js license)\n // with some minor optimizations and designed to run in steps\n\n // local state vars\n var THIRTY = new BigInteger(null);\n THIRTY.fromInt(30);\n var deltaIdx = 0;\n var op_or = function(x, y) {return x | y;};\n\n // keep stepping until time limit is reached or done\n var t1 = +new Date();\n var t2;\n var total = 0;\n while(state.keys === null && (n <= 0 || total < n)) {\n // generate p or q\n if(state.state === 0) {\n /* Note: All primes are of the form:\n\n 30k+i, for i < 30 and gcd(30, i)=1, where there are 8 values for i\n\n When we generate a random number, we always align it at 30k + 1. Each\n time the number is determined not to be prime we add to get to the\n next 'i', eg: if the number was at 30k + 1 we add 6. */\n var bits = (state.p === null) ? state.pBits : state.qBits;\n var bits1 = bits - 1;\n\n // get a random number\n if(state.pqState === 0) {\n state.num = new BigInteger(bits, state.rng);\n // force MSB set\n if(!state.num.testBit(bits1)) {\n state.num.bitwiseTo(\n BigInteger.ONE.shiftLeft(bits1), op_or, state.num);\n }\n // align number on 30k+1 boundary\n state.num.dAddOffset(31 - state.num.mod(THIRTY).byteValue(), 0);\n deltaIdx = 0;\n\n ++state.pqState;\n } else if(state.pqState === 1) {\n // try to make the number a prime\n if(state.num.bitLength() > bits) {\n // overflow, try again\n state.pqState = 0;\n // do primality test\n } else if(state.num.isProbablePrime(\n _getMillerRabinTests(state.num.bitLength()))) {\n ++state.pqState;\n } else {\n // get next potential prime\n state.num.dAddOffset(GCD_30_DELTA[deltaIdx++ % 8], 0);\n }\n } else if(state.pqState === 2) {\n // ensure number is coprime with e\n state.pqState =\n (state.num.subtract(BigInteger.ONE).gcd(state.e)\n .compareTo(BigInteger.ONE) === 0) ? 3 : 0;\n } else if(state.pqState === 3) {\n // store p or q\n state.pqState = 0;\n if(state.p === null) {\n state.p = state.num;\n } else {\n state.q = state.num;\n }\n\n // advance state if both p and q are ready\n if(state.p !== null && state.q !== null) {\n ++state.state;\n }\n state.num = null;\n }\n } else if(state.state === 1) {\n // ensure p is larger than q (swap them if not)\n if(state.p.compareTo(state.q) < 0) {\n state.num = state.p;\n state.p = state.q;\n state.q = state.num;\n }\n ++state.state;\n } else if(state.state === 2) {\n // compute phi: (p - 1)(q - 1) (Euler's totient function)\n state.p1 = state.p.subtract(BigInteger.ONE);\n state.q1 = state.q.subtract(BigInteger.ONE);\n state.phi = state.p1.multiply(state.q1);\n ++state.state;\n } else if(state.state === 3) {\n // ensure e and phi are coprime\n if(state.phi.gcd(state.e).compareTo(BigInteger.ONE) === 0) {\n // phi and e are coprime, advance\n ++state.state;\n } else {\n // phi and e aren't coprime, so generate a new p and q\n state.p = null;\n state.q = null;\n state.state = 0;\n }\n } else if(state.state === 4) {\n // create n, ensure n is has the right number of bits\n state.n = state.p.multiply(state.q);\n\n // ensure n is right number of bits\n if(state.n.bitLength() === state.bits) {\n // success, advance\n ++state.state;\n } else {\n // failed, get new q\n state.q = null;\n state.state = 0;\n }\n } else if(state.state === 5) {\n // set keys\n var d = state.e.modInverse(state.phi);\n state.keys = {\n privateKey: pki.rsa.setPrivateKey(\n state.n, state.e, d, state.p, state.q,\n d.mod(state.p1), d.mod(state.q1),\n state.q.modInverse(state.p)),\n publicKey: pki.rsa.setPublicKey(state.n, state.e)\n };\n }\n\n // update timing\n t2 = +new Date();\n total += t2 - t1;\n t1 = t2;\n }\n\n return state.keys !== null;\n};\n\n/**\n * Generates an RSA public-private key pair in a single call.\n *\n * To generate a key-pair in steps (to allow for progress updates and to\n * prevent blocking or warnings in slow browsers) then use the key-pair\n * generation state functions.\n *\n * To generate a key-pair asynchronously (either through web-workers, if\n * available, or by breaking up the work on the main thread), pass a\n * callback function.\n *\n * @param [bits] the size for the private key in bits, defaults to 2048.\n * @param [e] the public exponent to use, defaults to 65537.\n * @param [options] options for key-pair generation, if given then 'bits'\n * and 'e' must *not* be given:\n * bits the size for the private key in bits, (default: 2048).\n * e the public exponent to use, (default: 65537 (0x10001)).\n * workerScript the worker script URL.\n * workers the number of web workers (if supported) to use,\n * (default: 2).\n * workLoad the size of the work load, ie: number of possible prime\n * numbers for each web worker to check per work assignment,\n * (default: 100).\n * prng a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\". Disables use of native APIs.\n * algorithm the algorithm to use (default: 'PRIMEINC').\n * @param [callback(err, keypair)] called once the operation completes.\n *\n * @return an object with privateKey and publicKey properties.\n */\npki.rsa.generateKeyPair = function(bits, e, options, callback) {\n // (bits), (options), (callback)\n if(arguments.length === 1) {\n if(typeof bits === 'object') {\n options = bits;\n bits = undefined;\n } else if(typeof bits === 'function') {\n callback = bits;\n bits = undefined;\n }\n } else if(arguments.length === 2) {\n // (bits, e), (bits, options), (bits, callback), (options, callback)\n if(typeof bits === 'number') {\n if(typeof e === 'function') {\n callback = e;\n e = undefined;\n } else if(typeof e !== 'number') {\n options = e;\n e = undefined;\n }\n } else {\n options = bits;\n callback = e;\n bits = undefined;\n e = undefined;\n }\n } else if(arguments.length === 3) {\n // (bits, e, options), (bits, e, callback), (bits, options, callback)\n if(typeof e === 'number') {\n if(typeof options === 'function') {\n callback = options;\n options = undefined;\n }\n } else {\n callback = options;\n options = e;\n e = undefined;\n }\n }\n options = options || {};\n if(bits === undefined) {\n bits = options.bits || 2048;\n }\n if(e === undefined) {\n e = options.e || 0x10001;\n }\n\n // use native code if permitted, available, and parameters are acceptable\n if(!forge.options.usePureJavaScript && !options.prng &&\n bits >= 256 && bits <= 16384 && (e === 0x10001 || e === 3)) {\n if(callback) {\n // try native async\n if(_detectNodeCrypto('generateKeyPair')) {\n return _crypto.generateKeyPair('rsa', {\n modulusLength: bits,\n publicExponent: e,\n publicKeyEncoding: {\n type: 'spki',\n format: 'pem'\n },\n privateKeyEncoding: {\n type: 'pkcs8',\n format: 'pem'\n }\n }, function(err, pub, priv) {\n if(err) {\n return callback(err);\n }\n callback(null, {\n privateKey: pki.privateKeyFromPem(priv),\n publicKey: pki.publicKeyFromPem(pub)\n });\n });\n }\n if(_detectSubtleCrypto('generateKey') &&\n _detectSubtleCrypto('exportKey')) {\n // use standard native generateKey\n return util.globalScope.crypto.subtle.generateKey({\n name: 'RSASSA-PKCS1-v1_5',\n modulusLength: bits,\n publicExponent: _intToUint8Array(e),\n hash: {name: 'SHA-256'}\n }, true /* key can be exported*/, ['sign', 'verify'])\n .then(function(pair) {\n return util.globalScope.crypto.subtle.exportKey(\n 'pkcs8', pair.privateKey);\n // avoiding catch(function(err) {...}) to support IE <= 8\n }).then(undefined, function(err) {\n callback(err);\n }).then(function(pkcs8) {\n if(pkcs8) {\n var privateKey = pki.privateKeyFromAsn1(\n asn1.fromDer(forge.util.createBuffer(pkcs8)));\n callback(null, {\n privateKey: privateKey,\n publicKey: pki.setRsaPublicKey(privateKey.n, privateKey.e)\n });\n }\n });\n }\n if(_detectSubtleMsCrypto('generateKey') &&\n _detectSubtleMsCrypto('exportKey')) {\n var genOp = util.globalScope.msCrypto.subtle.generateKey({\n name: 'RSASSA-PKCS1-v1_5',\n modulusLength: bits,\n publicExponent: _intToUint8Array(e),\n hash: {name: 'SHA-256'}\n }, true /* key can be exported*/, ['sign', 'verify']);\n genOp.oncomplete = function(e) {\n var pair = e.target.result;\n var exportOp = util.globalScope.msCrypto.subtle.exportKey(\n 'pkcs8', pair.privateKey);\n exportOp.oncomplete = function(e) {\n var pkcs8 = e.target.result;\n var privateKey = pki.privateKeyFromAsn1(\n asn1.fromDer(forge.util.createBuffer(pkcs8)));\n callback(null, {\n privateKey: privateKey,\n publicKey: pki.setRsaPublicKey(privateKey.n, privateKey.e)\n });\n };\n exportOp.onerror = function(err) {\n callback(err);\n };\n };\n genOp.onerror = function(err) {\n callback(err);\n };\n return;\n }\n } else {\n // try native sync\n if(_detectNodeCrypto('generateKeyPairSync')) {\n var keypair = _crypto.generateKeyPairSync('rsa', {\n modulusLength: bits,\n publicExponent: e,\n publicKeyEncoding: {\n type: 'spki',\n format: 'pem'\n },\n privateKeyEncoding: {\n type: 'pkcs8',\n format: 'pem'\n }\n });\n return {\n privateKey: pki.privateKeyFromPem(keypair.privateKey),\n publicKey: pki.publicKeyFromPem(keypair.publicKey)\n };\n }\n }\n }\n\n // use JavaScript implementation\n var state = pki.rsa.createKeyPairGenerationState(bits, e, options);\n if(!callback) {\n pki.rsa.stepKeyPairGenerationState(state, 0);\n return state.keys;\n }\n _generateKeyPair(state, options, callback);\n};\n\n/**\n * Sets an RSA public key from BigIntegers modulus and exponent.\n *\n * @param n the modulus.\n * @param e the exponent.\n *\n * @return the public key.\n */\npki.setRsaPublicKey = pki.rsa.setPublicKey = function(n, e) {\n var key = {\n n: n,\n e: e\n };\n\n /**\n * Encrypts the given data with this public key. Newer applications\n * should use the 'RSA-OAEP' decryption scheme, 'RSAES-PKCS1-V1_5' is for\n * legacy applications.\n *\n * @param data the byte string to encrypt.\n * @param scheme the encryption scheme to use:\n * 'RSAES-PKCS1-V1_5' (default),\n * 'RSA-OAEP',\n * 'RAW', 'NONE', or null to perform raw RSA encryption,\n * an object with an 'encode' property set to a function\n * with the signature 'function(data, key)' that returns\n * a binary-encoded string representing the encoded data.\n * @param schemeOptions any scheme-specific options.\n *\n * @return the encrypted byte string.\n */\n key.encrypt = function(data, scheme, schemeOptions) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSAES-PKCS1-V1_5';\n }\n\n if(scheme === 'RSAES-PKCS1-V1_5') {\n scheme = {\n encode: function(m, key, pub) {\n return _encodePkcs1_v1_5(m, key, 0x02).getBytes();\n }\n };\n } else if(scheme === 'RSA-OAEP' || scheme === 'RSAES-OAEP') {\n scheme = {\n encode: function(m, key) {\n return forge.pkcs1.encode_rsa_oaep(key, m, schemeOptions);\n }\n };\n } else if(['RAW', 'NONE', 'NULL', null].indexOf(scheme) !== -1) {\n scheme = {encode: function(e) {return e;}};\n } else if(typeof scheme === 'string') {\n throw new Error('Unsupported encryption scheme: \"' + scheme + '\".');\n }\n\n // do scheme-based encoding then rsa encryption\n var e = scheme.encode(data, key, true);\n return pki.rsa.encrypt(e, key, true);\n };\n\n /**\n * Verifies the given signature against the given digest.\n *\n * PKCS#1 supports multiple (currently two) signature schemes:\n * RSASSA-PKCS1-V1_5 and RSASSA-PSS.\n *\n * By default this implementation uses the \"old scheme\", i.e.\n * RSASSA-PKCS1-V1_5, in which case once RSA-decrypted, the\n * signature is an OCTET STRING that holds a DigestInfo.\n *\n * DigestInfo ::= SEQUENCE {\n * digestAlgorithm DigestAlgorithmIdentifier,\n * digest Digest\n * }\n * DigestAlgorithmIdentifier ::= AlgorithmIdentifier\n * Digest ::= OCTET STRING\n *\n * To perform PSS signature verification, provide an instance\n * of Forge PSS object as the scheme parameter.\n *\n * @param digest the message digest hash to compare against the signature,\n * as a binary-encoded string.\n * @param signature the signature to verify, as a binary-encoded string.\n * @param scheme signature verification scheme to use:\n * 'RSASSA-PKCS1-V1_5' or undefined for RSASSA PKCS#1 v1.5,\n * a Forge PSS object for RSASSA-PSS,\n * 'NONE' or null for none, DigestInfo will not be expected, but\n * PKCS#1 v1.5 padding will still be used.\n *\n * @return true if the signature was verified, false if not.\n */\n key.verify = function(digest, signature, scheme) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSASSA-PKCS1-V1_5';\n }\n\n if(scheme === 'RSASSA-PKCS1-V1_5') {\n scheme = {\n verify: function(digest, d) {\n // remove padding\n d = _decodePkcs1_v1_5(d, key, true);\n // d is ASN.1 BER-encoded DigestInfo\n var obj = asn1.fromDer(d);\n // compare the given digest to the decrypted one\n return digest === obj.value[1].value;\n }\n };\n } else if(scheme === 'NONE' || scheme === 'NULL' || scheme === null) {\n scheme = {\n verify: function(digest, d) {\n // remove padding\n d = _decodePkcs1_v1_5(d, key, true);\n return digest === d;\n }\n };\n }\n\n // do rsa decryption w/o any decoding, then verify -- which does decoding\n var d = pki.rsa.decrypt(signature, key, true, false);\n return scheme.verify(digest, d, key.n.bitLength());\n };\n\n return key;\n};\n\n/**\n * Sets an RSA private key from BigIntegers modulus, exponent, primes,\n * prime exponents, and modular multiplicative inverse.\n *\n * @param n the modulus.\n * @param e the public exponent.\n * @param d the private exponent ((inverse of e) mod n).\n * @param p the first prime.\n * @param q the second prime.\n * @param dP exponent1 (d mod (p-1)).\n * @param dQ exponent2 (d mod (q-1)).\n * @param qInv ((inverse of q) mod p)\n *\n * @return the private key.\n */\npki.setRsaPrivateKey = pki.rsa.setPrivateKey = function(\n n, e, d, p, q, dP, dQ, qInv) {\n var key = {\n n: n,\n e: e,\n d: d,\n p: p,\n q: q,\n dP: dP,\n dQ: dQ,\n qInv: qInv\n };\n\n /**\n * Decrypts the given data with this private key. The decryption scheme\n * must match the one used to encrypt the data.\n *\n * @param data the byte string to decrypt.\n * @param scheme the decryption scheme to use:\n * 'RSAES-PKCS1-V1_5' (default),\n * 'RSA-OAEP',\n * 'RAW', 'NONE', or null to perform raw RSA decryption.\n * @param schemeOptions any scheme-specific options.\n *\n * @return the decrypted byte string.\n */\n key.decrypt = function(data, scheme, schemeOptions) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSAES-PKCS1-V1_5';\n }\n\n // do rsa decryption w/o any decoding\n var d = pki.rsa.decrypt(data, key, false, false);\n\n if(scheme === 'RSAES-PKCS1-V1_5') {\n scheme = {decode: _decodePkcs1_v1_5};\n } else if(scheme === 'RSA-OAEP' || scheme === 'RSAES-OAEP') {\n scheme = {\n decode: function(d, key) {\n return forge.pkcs1.decode_rsa_oaep(key, d, schemeOptions);\n }\n };\n } else if(['RAW', 'NONE', 'NULL', null].indexOf(scheme) !== -1) {\n scheme = {decode: function(d) {return d;}};\n } else {\n throw new Error('Unsupported encryption scheme: \"' + scheme + '\".');\n }\n\n // decode according to scheme\n return scheme.decode(d, key, false);\n };\n\n /**\n * Signs the given digest, producing a signature.\n *\n * PKCS#1 supports multiple (currently two) signature schemes:\n * RSASSA-PKCS1-V1_5 and RSASSA-PSS.\n *\n * By default this implementation uses the \"old scheme\", i.e.\n * RSASSA-PKCS1-V1_5. In order to generate a PSS signature, provide\n * an instance of Forge PSS object as the scheme parameter.\n *\n * @param md the message digest object with the hash to sign.\n * @param scheme the signature scheme to use:\n * 'RSASSA-PKCS1-V1_5' or undefined for RSASSA PKCS#1 v1.5,\n * a Forge PSS object for RSASSA-PSS,\n * 'NONE' or null for none, DigestInfo will not be used but\n * PKCS#1 v1.5 padding will still be used.\n *\n * @return the signature as a byte string.\n */\n key.sign = function(md, scheme) {\n /* Note: The internal implementation of RSA operations is being\n transitioned away from a PKCS#1 v1.5 hard-coded scheme. Some legacy\n code like the use of an encoding block identifier 'bt' will eventually\n be removed. */\n\n // private key operation\n var bt = false;\n\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n }\n\n if(scheme === undefined || scheme === 'RSASSA-PKCS1-V1_5') {\n scheme = {encode: emsaPkcs1v15encode};\n bt = 0x01;\n } else if(scheme === 'NONE' || scheme === 'NULL' || scheme === null) {\n scheme = {encode: function() {return md;}};\n bt = 0x01;\n }\n\n // encode and then encrypt\n var d = scheme.encode(md, key.n.bitLength());\n return pki.rsa.encrypt(d, key, bt);\n };\n\n return key;\n};\n\n/**\n * Wraps an RSAPrivateKey ASN.1 object in an ASN.1 PrivateKeyInfo object.\n *\n * @param rsaKey the ASN.1 RSAPrivateKey.\n *\n * @return the ASN.1 PrivateKeyInfo.\n */\npki.wrapRsaPrivateKey = function(rsaKey) {\n // PrivateKeyInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version (0)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(0).getBytes()),\n // privateKeyAlgorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.rsaEncryption).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // PrivateKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n asn1.toDer(rsaKey).getBytes())\n ]);\n};\n\n/**\n * Converts a private key from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a PrivateKeyInfo containing an\n * RSAPrivateKey or an RSAPrivateKey.\n *\n * @return the private key.\n */\npki.privateKeyFromAsn1 = function(obj) {\n // get PrivateKeyInfo\n var capture = {};\n var errors = [];\n if(asn1.validate(obj, privateKeyValidator, capture, errors)) {\n obj = asn1.fromDer(forge.util.createBuffer(capture.privateKey));\n }\n\n // get RSAPrivateKey\n capture = {};\n errors = [];\n if(!asn1.validate(obj, rsaPrivateKeyValidator, capture, errors)) {\n var error = new Error('Cannot read private key. ' +\n 'ASN.1 object does not contain an RSAPrivateKey.');\n error.errors = errors;\n throw error;\n }\n\n // Note: Version is currently ignored.\n // capture.privateKeyVersion\n // FIXME: inefficient, get a BigInteger that uses byte strings\n var n, e, d, p, q, dP, dQ, qInv;\n n = forge.util.createBuffer(capture.privateKeyModulus).toHex();\n e = forge.util.createBuffer(capture.privateKeyPublicExponent).toHex();\n d = forge.util.createBuffer(capture.privateKeyPrivateExponent).toHex();\n p = forge.util.createBuffer(capture.privateKeyPrime1).toHex();\n q = forge.util.createBuffer(capture.privateKeyPrime2).toHex();\n dP = forge.util.createBuffer(capture.privateKeyExponent1).toHex();\n dQ = forge.util.createBuffer(capture.privateKeyExponent2).toHex();\n qInv = forge.util.createBuffer(capture.privateKeyCoefficient).toHex();\n\n // set private key\n return pki.setRsaPrivateKey(\n new BigInteger(n, 16),\n new BigInteger(e, 16),\n new BigInteger(d, 16),\n new BigInteger(p, 16),\n new BigInteger(q, 16),\n new BigInteger(dP, 16),\n new BigInteger(dQ, 16),\n new BigInteger(qInv, 16));\n};\n\n/**\n * Converts a private key to an ASN.1 RSAPrivateKey.\n *\n * @param key the private key.\n *\n * @return the ASN.1 representation of an RSAPrivateKey.\n */\npki.privateKeyToAsn1 = pki.privateKeyToRSAPrivateKey = function(key) {\n // RSAPrivateKey\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version (0 = only 2 primes, 1 multiple primes)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(0).getBytes()),\n // modulus (n)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.n)),\n // publicExponent (e)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.e)),\n // privateExponent (d)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.d)),\n // privateKeyPrime1 (p)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.p)),\n // privateKeyPrime2 (q)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.q)),\n // privateKeyExponent1 (dP)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.dP)),\n // privateKeyExponent2 (dQ)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.dQ)),\n // coefficient (qInv)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.qInv))\n ]);\n};\n\n/**\n * Converts a public key from an ASN.1 SubjectPublicKeyInfo or RSAPublicKey.\n *\n * @param obj the asn1 representation of a SubjectPublicKeyInfo or RSAPublicKey.\n *\n * @return the public key.\n */\npki.publicKeyFromAsn1 = function(obj) {\n // get SubjectPublicKeyInfo\n var capture = {};\n var errors = [];\n if(asn1.validate(obj, publicKeyValidator, capture, errors)) {\n // get oid\n var oid = asn1.derToOid(capture.publicKeyOid);\n if(oid !== pki.oids.rsaEncryption) {\n var error = new Error('Cannot read public key. Unknown OID.');\n error.oid = oid;\n throw error;\n }\n obj = capture.rsaPublicKey;\n }\n\n // get RSA params\n errors = [];\n if(!asn1.validate(obj, rsaPublicKeyValidator, capture, errors)) {\n var error = new Error('Cannot read public key. ' +\n 'ASN.1 object does not contain an RSAPublicKey.');\n error.errors = errors;\n throw error;\n }\n\n // FIXME: inefficient, get a BigInteger that uses byte strings\n var n = forge.util.createBuffer(capture.publicKeyModulus).toHex();\n var e = forge.util.createBuffer(capture.publicKeyExponent).toHex();\n\n // set public key\n return pki.setRsaPublicKey(\n new BigInteger(n, 16),\n new BigInteger(e, 16));\n};\n\n/**\n * Converts a public key to an ASN.1 SubjectPublicKeyInfo.\n *\n * @param key the public key.\n *\n * @return the asn1 representation of a SubjectPublicKeyInfo.\n */\npki.publicKeyToAsn1 = pki.publicKeyToSubjectPublicKeyInfo = function(key) {\n // SubjectPublicKeyInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.rsaEncryption).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // subjectPublicKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false, [\n pki.publicKeyToRSAPublicKey(key)\n ])\n ]);\n};\n\n/**\n * Converts a public key to an ASN.1 RSAPublicKey.\n *\n * @param key the public key.\n *\n * @return the asn1 representation of a RSAPublicKey.\n */\npki.publicKeyToRSAPublicKey = function(key) {\n // RSAPublicKey\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // modulus (n)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.n)),\n // publicExponent (e)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.e))\n ]);\n};\n\n/**\n * Encodes a message using PKCS#1 v1.5 padding.\n *\n * @param m the message to encode.\n * @param key the RSA key to use.\n * @param bt the block type to use, i.e. either 0x01 (for signing) or 0x02\n * (for encryption).\n *\n * @return the padded byte buffer.\n */\nfunction _encodePkcs1_v1_5(m, key, bt) {\n var eb = forge.util.createBuffer();\n\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n /* use PKCS#1 v1.5 padding */\n if(m.length > (k - 11)) {\n var error = new Error('Message is too long for PKCS#1 v1.5 padding.');\n error.length = m.length;\n error.max = k - 11;\n throw error;\n }\n\n /* A block type BT, a padding string PS, and the data D shall be\n formatted into an octet string EB, the encryption block:\n\n EB = 00 || BT || PS || 00 || D\n\n The block type BT shall be a single octet indicating the structure of\n the encryption block. For this version of the document it shall have\n value 00, 01, or 02. For a private-key operation, the block type\n shall be 00 or 01. For a public-key operation, it shall be 02.\n\n The padding string PS shall consist of k-3-||D|| octets. For block\n type 00, the octets shall have value 00; for block type 01, they\n shall have value FF; and for block type 02, they shall be\n pseudorandomly generated and nonzero. This makes the length of the\n encryption block EB equal to k. */\n\n // build the encryption block\n eb.putByte(0x00);\n eb.putByte(bt);\n\n // create the padding\n var padNum = k - 3 - m.length;\n var padByte;\n // private key op\n if(bt === 0x00 || bt === 0x01) {\n padByte = (bt === 0x00) ? 0x00 : 0xFF;\n for(var i = 0; i < padNum; ++i) {\n eb.putByte(padByte);\n }\n } else {\n // public key op\n // pad with random non-zero values\n while(padNum > 0) {\n var numZeros = 0;\n var padBytes = forge.random.getBytes(padNum);\n for(var i = 0; i < padNum; ++i) {\n padByte = padBytes.charCodeAt(i);\n if(padByte === 0) {\n ++numZeros;\n } else {\n eb.putByte(padByte);\n }\n }\n padNum = numZeros;\n }\n }\n\n // zero followed by message\n eb.putByte(0x00);\n eb.putBytes(m);\n\n return eb;\n}\n\n/**\n * Decodes a message using PKCS#1 v1.5 padding.\n *\n * @param em the message to decode.\n * @param key the RSA key to use.\n * @param pub true if the key is a public key, false if it is private.\n * @param ml the message length, if specified.\n *\n * @return the decoded bytes.\n */\nfunction _decodePkcs1_v1_5(em, key, pub, ml) {\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n /* It is an error if any of the following conditions occurs:\n\n 1. The encryption block EB cannot be parsed unambiguously.\n 2. The padding string PS consists of fewer than eight octets\n or is inconsisent with the block type BT.\n 3. The decryption process is a public-key operation and the block\n type BT is not 00 or 01, or the decryption process is a\n private-key operation and the block type is not 02.\n */\n\n // parse the encryption block\n var eb = forge.util.createBuffer(em);\n var first = eb.getByte();\n var bt = eb.getByte();\n if(first !== 0x00 ||\n (pub && bt !== 0x00 && bt !== 0x01) ||\n (!pub && bt != 0x02) ||\n (pub && bt === 0x00 && typeof(ml) === 'undefined')) {\n throw new Error('Encryption block is invalid.');\n }\n\n var padNum = 0;\n if(bt === 0x00) {\n // check all padding bytes for 0x00\n padNum = k - 3 - ml;\n for(var i = 0; i < padNum; ++i) {\n if(eb.getByte() !== 0x00) {\n throw new Error('Encryption block is invalid.');\n }\n }\n } else if(bt === 0x01) {\n // find the first byte that isn't 0xFF, should be after all padding\n padNum = 0;\n while(eb.length() > 1) {\n if(eb.getByte() !== 0xFF) {\n --eb.read;\n break;\n }\n ++padNum;\n }\n } else if(bt === 0x02) {\n // look for 0x00 byte\n padNum = 0;\n while(eb.length() > 1) {\n if(eb.getByte() === 0x00) {\n --eb.read;\n break;\n }\n ++padNum;\n }\n }\n\n // zero must be 0x00 and padNum must be (k - 3 - message length)\n var zero = eb.getByte();\n if(zero !== 0x00 || padNum !== (k - 3 - eb.length())) {\n throw new Error('Encryption block is invalid.');\n }\n\n return eb.getBytes();\n}\n\n/**\n * Runs the key-generation algorithm asynchronously, either in the background\n * via Web Workers, or using the main thread and setImmediate.\n *\n * @param state the key-pair generation state.\n * @param [options] options for key-pair generation:\n * workerScript the worker script URL.\n * workers the number of web workers (if supported) to use,\n * (default: 2, -1 to use estimated cores minus one).\n * workLoad the size of the work load, ie: number of possible prime\n * numbers for each web worker to check per work assignment,\n * (default: 100).\n * @param callback(err, keypair) called once the operation completes.\n */\nfunction _generateKeyPair(state, options, callback) {\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n\n var opts = {\n algorithm: {\n name: options.algorithm || 'PRIMEINC',\n options: {\n workers: options.workers || 2,\n workLoad: options.workLoad || 100,\n workerScript: options.workerScript\n }\n }\n };\n if('prng' in options) {\n opts.prng = options.prng;\n }\n\n generate();\n\n function generate() {\n // find p and then q (done in series to simplify)\n getPrime(state.pBits, function(err, num) {\n if(err) {\n return callback(err);\n }\n state.p = num;\n if(state.q !== null) {\n return finish(err, state.q);\n }\n getPrime(state.qBits, finish);\n });\n }\n\n function getPrime(bits, callback) {\n forge.prime.generateProbablePrime(bits, opts, callback);\n }\n\n function finish(err, num) {\n if(err) {\n return callback(err);\n }\n\n // set q\n state.q = num;\n\n // ensure p is larger than q (swap them if not)\n if(state.p.compareTo(state.q) < 0) {\n var tmp = state.p;\n state.p = state.q;\n state.q = tmp;\n }\n\n // ensure p is coprime with e\n if(state.p.subtract(BigInteger.ONE).gcd(state.e)\n .compareTo(BigInteger.ONE) !== 0) {\n state.p = null;\n generate();\n return;\n }\n\n // ensure q is coprime with e\n if(state.q.subtract(BigInteger.ONE).gcd(state.e)\n .compareTo(BigInteger.ONE) !== 0) {\n state.q = null;\n getPrime(state.qBits, finish);\n return;\n }\n\n // compute phi: (p - 1)(q - 1) (Euler's totient function)\n state.p1 = state.p.subtract(BigInteger.ONE);\n state.q1 = state.q.subtract(BigInteger.ONE);\n state.phi = state.p1.multiply(state.q1);\n\n // ensure e and phi are coprime\n if(state.phi.gcd(state.e).compareTo(BigInteger.ONE) !== 0) {\n // phi and e aren't coprime, so generate a new p and q\n state.p = state.q = null;\n generate();\n return;\n }\n\n // create n, ensure n is has the right number of bits\n state.n = state.p.multiply(state.q);\n if(state.n.bitLength() !== state.bits) {\n // failed, get new q\n state.q = null;\n getPrime(state.qBits, finish);\n return;\n }\n\n // set keys\n var d = state.e.modInverse(state.phi);\n state.keys = {\n privateKey: pki.rsa.setPrivateKey(\n state.n, state.e, d, state.p, state.q,\n d.mod(state.p1), d.mod(state.q1),\n state.q.modInverse(state.p)),\n publicKey: pki.rsa.setPublicKey(state.n, state.e)\n };\n\n callback(null, state.keys);\n }\n}\n\n/**\n * Converts a positive BigInteger into 2's-complement big-endian bytes.\n *\n * @param b the big integer to convert.\n *\n * @return the bytes.\n */\nfunction _bnToBytes(b) {\n // prepend 0x00 if first byte >= 0x80\n var hex = b.toString(16);\n if(hex[0] >= '8') {\n hex = '00' + hex;\n }\n var bytes = forge.util.hexToBytes(hex);\n\n // ensure integer is minimally-encoded\n if(bytes.length > 1 &&\n // leading 0x00 for positive integer\n ((bytes.charCodeAt(0) === 0 &&\n (bytes.charCodeAt(1) & 0x80) === 0) ||\n // leading 0xFF for negative integer\n (bytes.charCodeAt(0) === 0xFF &&\n (bytes.charCodeAt(1) & 0x80) === 0x80))) {\n return bytes.substr(1);\n }\n return bytes;\n}\n\n/**\n * Returns the required number of Miller-Rabin tests to generate a\n * prime with an error probability of (1/2)^80.\n *\n * See Handbook of Applied Cryptography Chapter 4, Table 4.4.\n *\n * @param bits the bit size.\n *\n * @return the required number of iterations.\n */\nfunction _getMillerRabinTests(bits) {\n if(bits <= 100) return 27;\n if(bits <= 150) return 18;\n if(bits <= 200) return 15;\n if(bits <= 250) return 12;\n if(bits <= 300) return 9;\n if(bits <= 350) return 8;\n if(bits <= 400) return 7;\n if(bits <= 500) return 6;\n if(bits <= 600) return 5;\n if(bits <= 800) return 4;\n if(bits <= 1250) return 3;\n return 2;\n}\n\n/**\n * Performs feature detection on the Node crypto interface.\n *\n * @param fn the feature (function) to detect.\n *\n * @return true if detected, false if not.\n */\nfunction _detectNodeCrypto(fn) {\n return forge.util.isNodejs && typeof _crypto[fn] === 'function';\n}\n\n/**\n * Performs feature detection on the SubtleCrypto interface.\n *\n * @param fn the feature (function) to detect.\n *\n * @return true if detected, false if not.\n */\nfunction _detectSubtleCrypto(fn) {\n return (typeof util.globalScope !== 'undefined' &&\n typeof util.globalScope.crypto === 'object' &&\n typeof util.globalScope.crypto.subtle === 'object' &&\n typeof util.globalScope.crypto.subtle[fn] === 'function');\n}\n\n/**\n * Performs feature detection on the deprecated Microsoft Internet Explorer\n * outdated SubtleCrypto interface. This function should only be used after\n * checking for the modern, standard SubtleCrypto interface.\n *\n * @param fn the feature (function) to detect.\n *\n * @return true if detected, false if not.\n */\nfunction _detectSubtleMsCrypto(fn) {\n return (typeof util.globalScope !== 'undefined' &&\n typeof util.globalScope.msCrypto === 'object' &&\n typeof util.globalScope.msCrypto.subtle === 'object' &&\n typeof util.globalScope.msCrypto.subtle[fn] === 'function');\n}\n\nfunction _intToUint8Array(x) {\n var bytes = forge.util.hexToBytes(x.toString(16));\n var buffer = new Uint8Array(bytes.length);\n for(var i = 0; i < bytes.length; ++i) {\n buffer[i] = bytes.charCodeAt(i);\n }\n return buffer;\n}\n\nfunction _privateKeyFromJwk(jwk) {\n if(jwk.kty !== 'RSA') {\n throw new Error(\n 'Unsupported key algorithm \"' + jwk.kty + '\"; algorithm must be \"RSA\".');\n }\n return pki.setRsaPrivateKey(\n _base64ToBigInt(jwk.n),\n _base64ToBigInt(jwk.e),\n _base64ToBigInt(jwk.d),\n _base64ToBigInt(jwk.p),\n _base64ToBigInt(jwk.q),\n _base64ToBigInt(jwk.dp),\n _base64ToBigInt(jwk.dq),\n _base64ToBigInt(jwk.qi));\n}\n\nfunction _publicKeyFromJwk(jwk) {\n if(jwk.kty !== 'RSA') {\n throw new Error('Key algorithm must be \"RSA\".');\n }\n return pki.setRsaPublicKey(\n _base64ToBigInt(jwk.n),\n _base64ToBigInt(jwk.e));\n}\n\nfunction _base64ToBigInt(b64) {\n return new BigInteger(forge.util.bytesToHex(forge.util.decode64(b64)), 16);\n}\n","// Copyright (c) 2005 Tom Wu\n// All Rights Reserved.\n// See \"LICENSE\" for details.\n\n// Basic JavaScript BN library - subset useful for RSA encryption.\n\n/*\nLicensing (LICENSE)\n-------------------\n\nThis software is covered under the following copyright:\n*/\n/*\n * Copyright (c) 2003-2005 Tom Wu\n * All Rights Reserved.\n *\n * Permission is hereby granted, free of charge, to any person obtaining\n * a copy of this software and associated documentation files (the\n * \"Software\"), to deal in the Software without restriction, including\n * without limitation the rights to use, copy, modify, merge, publish,\n * distribute, sublicense, and/or sell copies of the Software, and to\n * permit persons to whom the Software is furnished to do so, subject to\n * the following conditions:\n *\n * The above copyright notice and this permission notice shall be\n * included in all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS-IS\" AND WITHOUT WARRANTY OF ANY KIND,\n * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY\n * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.\n *\n * IN NO EVENT SHALL TOM WU BE LIABLE FOR ANY SPECIAL, INCIDENTAL,\n * INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, OR ANY DAMAGES WHATSOEVER\n * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER OR NOT ADVISED OF\n * THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF LIABILITY, ARISING OUT\n * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n *\n * In addition, the following condition applies:\n *\n * All redistributions must retain an intact copy of this copyright notice\n * and disclaimer.\n */\n/*\nAddress all questions regarding this license to:\n\n Tom Wu\n tjw@cs.Stanford.EDU\n*/\nvar forge = require('./forge');\n\nmodule.exports = forge.jsbn = forge.jsbn || {};\n\n// Bits per digit\nvar dbits;\n\n// JavaScript engine analysis\nvar canary = 0xdeadbeefcafe;\nvar j_lm = ((canary&0xffffff)==0xefcafe);\n\n// (public) Constructor\nfunction BigInteger(a,b,c) {\n this.data = [];\n if(a != null)\n if(\"number\" == typeof a) this.fromNumber(a,b,c);\n else if(b == null && \"string\" != typeof a) this.fromString(a,256);\n else this.fromString(a,b);\n}\nforge.jsbn.BigInteger = BigInteger;\n\n// return new, unset BigInteger\nfunction nbi() { return new BigInteger(null); }\n\n// am: Compute w_j += (x*this_i), propagate carries,\n// c is initial carry, returns final carry.\n// c < 3*dvalue, x < 2*dvalue, this_i < dvalue\n// We need to select the fastest one that works in this environment.\n\n// am1: use a single mult and divide to get the high bits,\n// max digit bits should be 26 because\n// max internal value = 2*dvalue^2-2*dvalue (< 2^53)\nfunction am1(i,x,w,j,c,n) {\n while(--n >= 0) {\n var v = x*this.data[i++]+w.data[j]+c;\n c = Math.floor(v/0x4000000);\n w.data[j++] = v&0x3ffffff;\n }\n return c;\n}\n// am2 avoids a big mult-and-extract completely.\n// Max digit bits should be <= 30 because we do bitwise ops\n// on values up to 2*hdvalue^2-hdvalue-1 (< 2^31)\nfunction am2(i,x,w,j,c,n) {\n var xl = x&0x7fff, xh = x>>15;\n while(--n >= 0) {\n var l = this.data[i]&0x7fff;\n var h = this.data[i++]>>15;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x7fff)<<15)+w.data[j]+(c&0x3fffffff);\n c = (l>>>30)+(m>>>15)+xh*h+(c>>>30);\n w.data[j++] = l&0x3fffffff;\n }\n return c;\n}\n// Alternately, set max digit bits to 28 since some\n// browsers slow down when dealing with 32-bit numbers.\nfunction am3(i,x,w,j,c,n) {\n var xl = x&0x3fff, xh = x>>14;\n while(--n >= 0) {\n var l = this.data[i]&0x3fff;\n var h = this.data[i++]>>14;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x3fff)<<14)+w.data[j]+c;\n c = (l>>28)+(m>>14)+xh*h;\n w.data[j++] = l&0xfffffff;\n }\n return c;\n}\n\n// node.js (no browser)\nif(typeof(navigator) === 'undefined')\n{\n BigInteger.prototype.am = am3;\n dbits = 28;\n} else if(j_lm && (navigator.appName == \"Microsoft Internet Explorer\")) {\n BigInteger.prototype.am = am2;\n dbits = 30;\n} else if(j_lm && (navigator.appName != \"Netscape\")) {\n BigInteger.prototype.am = am1;\n dbits = 26;\n} else { // Mozilla/Netscape seems to prefer am3\n BigInteger.prototype.am = am3;\n dbits = 28;\n}\n\nBigInteger.prototype.DB = dbits;\nBigInteger.prototype.DM = ((1<<dbits)-1);\nBigInteger.prototype.DV = (1<<dbits);\n\nvar BI_FP = 52;\nBigInteger.prototype.FV = Math.pow(2,BI_FP);\nBigInteger.prototype.F1 = BI_FP-dbits;\nBigInteger.prototype.F2 = 2*dbits-BI_FP;\n\n// Digit conversions\nvar BI_RM = \"0123456789abcdefghijklmnopqrstuvwxyz\";\nvar BI_RC = new Array();\nvar rr,vv;\nrr = \"0\".charCodeAt(0);\nfor(vv = 0; vv <= 9; ++vv) BI_RC[rr++] = vv;\nrr = \"a\".charCodeAt(0);\nfor(vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv;\nrr = \"A\".charCodeAt(0);\nfor(vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv;\n\nfunction int2char(n) { return BI_RM.charAt(n); }\nfunction intAt(s,i) {\n var c = BI_RC[s.charCodeAt(i)];\n return (c==null)?-1:c;\n}\n\n// (protected) copy this to r\nfunction bnpCopyTo(r) {\n for(var i = this.t-1; i >= 0; --i) r.data[i] = this.data[i];\n r.t = this.t;\n r.s = this.s;\n}\n\n// (protected) set from integer value x, -DV <= x < DV\nfunction bnpFromInt(x) {\n this.t = 1;\n this.s = (x<0)?-1:0;\n if(x > 0) this.data[0] = x;\n else if(x < -1) this.data[0] = x+this.DV;\n else this.t = 0;\n}\n\n// return bigint initialized to value\nfunction nbv(i) { var r = nbi(); r.fromInt(i); return r; }\n\n// (protected) set from string and radix\nfunction bnpFromString(s,b) {\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 256) k = 8; // byte array\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else { this.fromRadix(s,b); return; }\n this.t = 0;\n this.s = 0;\n var i = s.length, mi = false, sh = 0;\n while(--i >= 0) {\n var x = (k==8)?s[i]&0xff:intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\") mi = true;\n continue;\n }\n mi = false;\n if(sh == 0)\n this.data[this.t++] = x;\n else if(sh+k > this.DB) {\n this.data[this.t-1] |= (x&((1<<(this.DB-sh))-1))<<sh;\n this.data[this.t++] = (x>>(this.DB-sh));\n } else\n this.data[this.t-1] |= x<<sh;\n sh += k;\n if(sh >= this.DB) sh -= this.DB;\n }\n if(k == 8 && (s[0]&0x80) != 0) {\n this.s = -1;\n if(sh > 0) this.data[this.t-1] |= ((1<<(this.DB-sh))-1)<<sh;\n }\n this.clamp();\n if(mi) BigInteger.ZERO.subTo(this,this);\n}\n\n// (protected) clamp off excess high words\nfunction bnpClamp() {\n var c = this.s&this.DM;\n while(this.t > 0 && this.data[this.t-1] == c) --this.t;\n}\n\n// (public) return string representation in given radix\nfunction bnToString(b) {\n if(this.s < 0) return \"-\"+this.negate().toString(b);\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else return this.toRadix(b);\n var km = (1<<k)-1, d, m = false, r = \"\", i = this.t;\n var p = this.DB-(i*this.DB)%k;\n if(i-- > 0) {\n if(p < this.DB && (d = this.data[i]>>p) > 0) { m = true; r = int2char(d); }\n while(i >= 0) {\n if(p < k) {\n d = (this.data[i]&((1<<p)-1))<<(k-p);\n d |= this.data[--i]>>(p+=this.DB-k);\n } else {\n d = (this.data[i]>>(p-=k))&km;\n if(p <= 0) { p += this.DB; --i; }\n }\n if(d > 0) m = true;\n if(m) r += int2char(d);\n }\n }\n return m?r:\"0\";\n}\n\n// (public) -this\nfunction bnNegate() { var r = nbi(); BigInteger.ZERO.subTo(this,r); return r; }\n\n// (public) |this|\nfunction bnAbs() { return (this.s<0)?this.negate():this; }\n\n// (public) return + if this > a, - if this < a, 0 if equal\nfunction bnCompareTo(a) {\n var r = this.s-a.s;\n if(r != 0) return r;\n var i = this.t;\n r = i-a.t;\n if(r != 0) return (this.s<0)?-r:r;\n while(--i >= 0) if((r=this.data[i]-a.data[i]) != 0) return r;\n return 0;\n}\n\n// returns bit length of the integer x\nfunction nbits(x) {\n var r = 1, t;\n if((t=x>>>16) != 0) { x = t; r += 16; }\n if((t=x>>8) != 0) { x = t; r += 8; }\n if((t=x>>4) != 0) { x = t; r += 4; }\n if((t=x>>2) != 0) { x = t; r += 2; }\n if((t=x>>1) != 0) { x = t; r += 1; }\n return r;\n}\n\n// (public) return the number of bits in \"this\"\nfunction bnBitLength() {\n if(this.t <= 0) return 0;\n return this.DB*(this.t-1)+nbits(this.data[this.t-1]^(this.s&this.DM));\n}\n\n// (protected) r = this << n*DB\nfunction bnpDLShiftTo(n,r) {\n var i;\n for(i = this.t-1; i >= 0; --i) r.data[i+n] = this.data[i];\n for(i = n-1; i >= 0; --i) r.data[i] = 0;\n r.t = this.t+n;\n r.s = this.s;\n}\n\n// (protected) r = this >> n*DB\nfunction bnpDRShiftTo(n,r) {\n for(var i = n; i < this.t; ++i) r.data[i-n] = this.data[i];\n r.t = Math.max(this.t-n,0);\n r.s = this.s;\n}\n\n// (protected) r = this << n\nfunction bnpLShiftTo(n,r) {\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<<cbs)-1;\n var ds = Math.floor(n/this.DB), c = (this.s<<bs)&this.DM, i;\n for(i = this.t-1; i >= 0; --i) {\n r.data[i+ds+1] = (this.data[i]>>cbs)|c;\n c = (this.data[i]&bm)<<bs;\n }\n for(i = ds-1; i >= 0; --i) r.data[i] = 0;\n r.data[ds] = c;\n r.t = this.t+ds+1;\n r.s = this.s;\n r.clamp();\n}\n\n// (protected) r = this >> n\nfunction bnpRShiftTo(n,r) {\n r.s = this.s;\n var ds = Math.floor(n/this.DB);\n if(ds >= this.t) { r.t = 0; return; }\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<<bs)-1;\n r.data[0] = this.data[ds]>>bs;\n for(var i = ds+1; i < this.t; ++i) {\n r.data[i-ds-1] |= (this.data[i]&bm)<<cbs;\n r.data[i-ds] = this.data[i]>>bs;\n }\n if(bs > 0) r.data[this.t-ds-1] |= (this.s&bm)<<cbs;\n r.t = this.t-ds;\n r.clamp();\n}\n\n// (protected) r = this - a\nfunction bnpSubTo(a,r) {\n var i = 0, c = 0, m = Math.min(a.t,this.t);\n while(i < m) {\n c += this.data[i]-a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n if(a.t < this.t) {\n c -= a.s;\n while(i < this.t) {\n c += this.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n } else {\n c += this.s;\n while(i < a.t) {\n c -= a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c -= a.s;\n }\n r.s = (c<0)?-1:0;\n if(c < -1) r.data[i++] = this.DV+c;\n else if(c > 0) r.data[i++] = c;\n r.t = i;\n r.clamp();\n}\n\n// (protected) r = this * a, r != this,a (HAC 14.12)\n// \"this\" should be the larger one if appropriate.\nfunction bnpMultiplyTo(a,r) {\n var x = this.abs(), y = a.abs();\n var i = x.t;\n r.t = i+y.t;\n while(--i >= 0) r.data[i] = 0;\n for(i = 0; i < y.t; ++i) r.data[i+x.t] = x.am(0,y.data[i],r,i,0,x.t);\n r.s = 0;\n r.clamp();\n if(this.s != a.s) BigInteger.ZERO.subTo(r,r);\n}\n\n// (protected) r = this^2, r != this (HAC 14.16)\nfunction bnpSquareTo(r) {\n var x = this.abs();\n var i = r.t = 2*x.t;\n while(--i >= 0) r.data[i] = 0;\n for(i = 0; i < x.t-1; ++i) {\n var c = x.am(i,x.data[i],r,2*i,0,1);\n if((r.data[i+x.t]+=x.am(i+1,2*x.data[i],r,2*i+1,c,x.t-i-1)) >= x.DV) {\n r.data[i+x.t] -= x.DV;\n r.data[i+x.t+1] = 1;\n }\n }\n if(r.t > 0) r.data[r.t-1] += x.am(i,x.data[i],r,2*i,0,1);\n r.s = 0;\n r.clamp();\n}\n\n// (protected) divide this by m, quotient and remainder to q, r (HAC 14.20)\n// r != q, this != m. q or r may be null.\nfunction bnpDivRemTo(m,q,r) {\n var pm = m.abs();\n if(pm.t <= 0) return;\n var pt = this.abs();\n if(pt.t < pm.t) {\n if(q != null) q.fromInt(0);\n if(r != null) this.copyTo(r);\n return;\n }\n if(r == null) r = nbi();\n var y = nbi(), ts = this.s, ms = m.s;\n var nsh = this.DB-nbits(pm.data[pm.t-1]);\t// normalize modulus\n if(nsh > 0) { pm.lShiftTo(nsh,y); pt.lShiftTo(nsh,r); } else { pm.copyTo(y); pt.copyTo(r); }\n var ys = y.t;\n var y0 = y.data[ys-1];\n if(y0 == 0) return;\n var yt = y0*(1<<this.F1)+((ys>1)?y.data[ys-2]>>this.F2:0);\n var d1 = this.FV/yt, d2 = (1<<this.F1)/yt, e = 1<<this.F2;\n var i = r.t, j = i-ys, t = (q==null)?nbi():q;\n y.dlShiftTo(j,t);\n if(r.compareTo(t) >= 0) {\n r.data[r.t++] = 1;\n r.subTo(t,r);\n }\n BigInteger.ONE.dlShiftTo(ys,t);\n t.subTo(y,y);\t// \"negative\" y so we can replace sub with am later\n while(y.t < ys) y.data[y.t++] = 0;\n while(--j >= 0) {\n // Estimate quotient digit\n var qd = (r.data[--i]==y0)?this.DM:Math.floor(r.data[i]*d1+(r.data[i-1]+e)*d2);\n if((r.data[i]+=y.am(0,qd,r,j,0,ys)) < qd) {\t// Try it out\n y.dlShiftTo(j,t);\n r.subTo(t,r);\n while(r.data[i] < --qd) r.subTo(t,r);\n }\n }\n if(q != null) {\n r.drShiftTo(ys,q);\n if(ts != ms) BigInteger.ZERO.subTo(q,q);\n }\n r.t = ys;\n r.clamp();\n if(nsh > 0) r.rShiftTo(nsh,r);\t// Denormalize remainder\n if(ts < 0) BigInteger.ZERO.subTo(r,r);\n}\n\n// (public) this mod a\nfunction bnMod(a) {\n var r = nbi();\n this.abs().divRemTo(a,null,r);\n if(this.s < 0 && r.compareTo(BigInteger.ZERO) > 0) a.subTo(r,r);\n return r;\n}\n\n// Modular reduction using \"classic\" algorithm\nfunction Classic(m) { this.m = m; }\nfunction cConvert(x) {\n if(x.s < 0 || x.compareTo(this.m) >= 0) return x.mod(this.m);\n else return x;\n}\nfunction cRevert(x) { return x; }\nfunction cReduce(x) { x.divRemTo(this.m,null,x); }\nfunction cMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\nfunction cSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\nClassic.prototype.convert = cConvert;\nClassic.prototype.revert = cRevert;\nClassic.prototype.reduce = cReduce;\nClassic.prototype.mulTo = cMulTo;\nClassic.prototype.sqrTo = cSqrTo;\n\n// (protected) return \"-1/this % 2^DB\"; useful for Mont. reduction\n// justification:\n// xy == 1 (mod m)\n// xy = 1+km\n// xy(2-xy) = (1+km)(1-km)\n// x[y(2-xy)] = 1-k^2m^2\n// x[y(2-xy)] == 1 (mod m^2)\n// if y is 1/x mod m, then y(2-xy) is 1/x mod m^2\n// should reduce x and y(2-xy) by m^2 at each step to keep size bounded.\n// JS multiply \"overflows\" differently from C/C++, so care is needed here.\nfunction bnpInvDigit() {\n if(this.t < 1) return 0;\n var x = this.data[0];\n if((x&1) == 0) return 0;\n var y = x&3;\t\t// y == 1/x mod 2^2\n y = (y*(2-(x&0xf)*y))&0xf;\t// y == 1/x mod 2^4\n y = (y*(2-(x&0xff)*y))&0xff;\t// y == 1/x mod 2^8\n y = (y*(2-(((x&0xffff)*y)&0xffff)))&0xffff;\t// y == 1/x mod 2^16\n // last step - calculate inverse mod DV directly;\n // assumes 16 < DB <= 32 and assumes ability to handle 48-bit ints\n y = (y*(2-x*y%this.DV))%this.DV;\t\t// y == 1/x mod 2^dbits\n // we really want the negative inverse, and -DV < y < DV\n return (y>0)?this.DV-y:-y;\n}\n\n// Montgomery reduction\nfunction Montgomery(m) {\n this.m = m;\n this.mp = m.invDigit();\n this.mpl = this.mp&0x7fff;\n this.mph = this.mp>>15;\n this.um = (1<<(m.DB-15))-1;\n this.mt2 = 2*m.t;\n}\n\n// xR mod m\nfunction montConvert(x) {\n var r = nbi();\n x.abs().dlShiftTo(this.m.t,r);\n r.divRemTo(this.m,null,r);\n if(x.s < 0 && r.compareTo(BigInteger.ZERO) > 0) this.m.subTo(r,r);\n return r;\n}\n\n// x/R mod m\nfunction montRevert(x) {\n var r = nbi();\n x.copyTo(r);\n this.reduce(r);\n return r;\n}\n\n// x = x/R mod m (HAC 14.32)\nfunction montReduce(x) {\n while(x.t <= this.mt2)\t// pad x so am has enough room later\n x.data[x.t++] = 0;\n for(var i = 0; i < this.m.t; ++i) {\n // faster way of calculating u0 = x.data[i]*mp mod DV\n var j = x.data[i]&0x7fff;\n var u0 = (j*this.mpl+(((j*this.mph+(x.data[i]>>15)*this.mpl)&this.um)<<15))&x.DM;\n // use am to combine the multiply-shift-add into one call\n j = i+this.m.t;\n x.data[j] += this.m.am(0,u0,x,i,0,this.m.t);\n // propagate carry\n while(x.data[j] >= x.DV) { x.data[j] -= x.DV; x.data[++j]++; }\n }\n x.clamp();\n x.drShiftTo(this.m.t,x);\n if(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n}\n\n// r = \"x^2/R mod m\"; x != r\nfunction montSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n// r = \"xy/R mod m\"; x,y != r\nfunction montMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\nMontgomery.prototype.convert = montConvert;\nMontgomery.prototype.revert = montRevert;\nMontgomery.prototype.reduce = montReduce;\nMontgomery.prototype.mulTo = montMulTo;\nMontgomery.prototype.sqrTo = montSqrTo;\n\n// (protected) true iff this is even\nfunction bnpIsEven() { return ((this.t>0)?(this.data[0]&1):this.s) == 0; }\n\n// (protected) this^e, e < 2^32, doing sqr and mul with \"r\" (HAC 14.79)\nfunction bnpExp(e,z) {\n if(e > 0xffffffff || e < 1) return BigInteger.ONE;\n var r = nbi(), r2 = nbi(), g = z.convert(this), i = nbits(e)-1;\n g.copyTo(r);\n while(--i >= 0) {\n z.sqrTo(r,r2);\n if((e&(1<<i)) > 0) z.mulTo(r2,g,r);\n else { var t = r; r = r2; r2 = t; }\n }\n return z.revert(r);\n}\n\n// (public) this^e % m, 0 <= e < 2^32\nfunction bnModPowInt(e,m) {\n var z;\n if(e < 256 || m.isEven()) z = new Classic(m); else z = new Montgomery(m);\n return this.exp(e,z);\n}\n\n// protected\nBigInteger.prototype.copyTo = bnpCopyTo;\nBigInteger.prototype.fromInt = bnpFromInt;\nBigInteger.prototype.fromString = bnpFromString;\nBigInteger.prototype.clamp = bnpClamp;\nBigInteger.prototype.dlShiftTo = bnpDLShiftTo;\nBigInteger.prototype.drShiftTo = bnpDRShiftTo;\nBigInteger.prototype.lShiftTo = bnpLShiftTo;\nBigInteger.prototype.rShiftTo = bnpRShiftTo;\nBigInteger.prototype.subTo = bnpSubTo;\nBigInteger.prototype.multiplyTo = bnpMultiplyTo;\nBigInteger.prototype.squareTo = bnpSquareTo;\nBigInteger.prototype.divRemTo = bnpDivRemTo;\nBigInteger.prototype.invDigit = bnpInvDigit;\nBigInteger.prototype.isEven = bnpIsEven;\nBigInteger.prototype.exp = bnpExp;\n\n// public\nBigInteger.prototype.toString = bnToString;\nBigInteger.prototype.negate = bnNegate;\nBigInteger.prototype.abs = bnAbs;\nBigInteger.prototype.compareTo = bnCompareTo;\nBigInteger.prototype.bitLength = bnBitLength;\nBigInteger.prototype.mod = bnMod;\nBigInteger.prototype.modPowInt = bnModPowInt;\n\n// \"constants\"\nBigInteger.ZERO = nbv(0);\nBigInteger.ONE = nbv(1);\n\n// jsbn2 lib\n\n//Copyright (c) 2005-2009 Tom Wu\n//All Rights Reserved.\n//See \"LICENSE\" for details (See jsbn.js for LICENSE).\n\n//Extended JavaScript BN functions, required for RSA private ops.\n\n//Version 1.1: new BigInteger(\"0\", 10) returns \"proper\" zero\n\n//(public)\nfunction bnClone() { var r = nbi(); this.copyTo(r); return r; }\n\n//(public) return value as integer\nfunction bnIntValue() {\nif(this.s < 0) {\n if(this.t == 1) return this.data[0]-this.DV;\n else if(this.t == 0) return -1;\n} else if(this.t == 1) return this.data[0];\nelse if(this.t == 0) return 0;\n// assumes 16 < DB < 32\nreturn ((this.data[1]&((1<<(32-this.DB))-1))<<this.DB)|this.data[0];\n}\n\n//(public) return value as byte\nfunction bnByteValue() { return (this.t==0)?this.s:(this.data[0]<<24)>>24; }\n\n//(public) return value as short (assumes DB>=16)\nfunction bnShortValue() { return (this.t==0)?this.s:(this.data[0]<<16)>>16; }\n\n//(protected) return x s.t. r^x < DV\nfunction bnpChunkSize(r) { return Math.floor(Math.LN2*this.DB/Math.log(r)); }\n\n//(public) 0 if this == 0, 1 if this > 0\nfunction bnSigNum() {\nif(this.s < 0) return -1;\nelse if(this.t <= 0 || (this.t == 1 && this.data[0] <= 0)) return 0;\nelse return 1;\n}\n\n//(protected) convert to radix string\nfunction bnpToRadix(b) {\nif(b == null) b = 10;\nif(this.signum() == 0 || b < 2 || b > 36) return \"0\";\nvar cs = this.chunkSize(b);\nvar a = Math.pow(b,cs);\nvar d = nbv(a), y = nbi(), z = nbi(), r = \"\";\nthis.divRemTo(d,y,z);\nwhile(y.signum() > 0) {\n r = (a+z.intValue()).toString(b).substr(1) + r;\n y.divRemTo(d,y,z);\n}\nreturn z.intValue().toString(b) + r;\n}\n\n//(protected) convert from radix string\nfunction bnpFromRadix(s,b) {\nthis.fromInt(0);\nif(b == null) b = 10;\nvar cs = this.chunkSize(b);\nvar d = Math.pow(b,cs), mi = false, j = 0, w = 0;\nfor(var i = 0; i < s.length; ++i) {\n var x = intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\" && this.signum() == 0) mi = true;\n continue;\n }\n w = b*w+x;\n if(++j >= cs) {\n this.dMultiply(d);\n this.dAddOffset(w,0);\n j = 0;\n w = 0;\n }\n}\nif(j > 0) {\n this.dMultiply(Math.pow(b,j));\n this.dAddOffset(w,0);\n}\nif(mi) BigInteger.ZERO.subTo(this,this);\n}\n\n//(protected) alternate constructor\nfunction bnpFromNumber(a,b,c) {\nif(\"number\" == typeof b) {\n // new BigInteger(int,int,RNG)\n if(a < 2) this.fromInt(1);\n else {\n this.fromNumber(a,c);\n if(!this.testBit(a-1)) // force MSB set\n this.bitwiseTo(BigInteger.ONE.shiftLeft(a-1),op_or,this);\n if(this.isEven()) this.dAddOffset(1,0); // force odd\n while(!this.isProbablePrime(b)) {\n this.dAddOffset(2,0);\n if(this.bitLength() > a) this.subTo(BigInteger.ONE.shiftLeft(a-1),this);\n }\n }\n} else {\n // new BigInteger(int,RNG)\n var x = new Array(), t = a&7;\n x.length = (a>>3)+1;\n b.nextBytes(x);\n if(t > 0) x[0] &= ((1<<t)-1); else x[0] = 0;\n this.fromString(x,256);\n}\n}\n\n//(public) convert to bigendian byte array\nfunction bnToByteArray() {\nvar i = this.t, r = new Array();\nr[0] = this.s;\nvar p = this.DB-(i*this.DB)%8, d, k = 0;\nif(i-- > 0) {\n if(p < this.DB && (d = this.data[i]>>p) != (this.s&this.DM)>>p)\n r[k++] = d|(this.s<<(this.DB-p));\n while(i >= 0) {\n if(p < 8) {\n d = (this.data[i]&((1<<p)-1))<<(8-p);\n d |= this.data[--i]>>(p+=this.DB-8);\n } else {\n d = (this.data[i]>>(p-=8))&0xff;\n if(p <= 0) { p += this.DB; --i; }\n }\n if((d&0x80) != 0) d |= -256;\n if(k == 0 && (this.s&0x80) != (d&0x80)) ++k;\n if(k > 0 || d != this.s) r[k++] = d;\n }\n}\nreturn r;\n}\n\nfunction bnEquals(a) { return(this.compareTo(a)==0); }\nfunction bnMin(a) { return(this.compareTo(a)<0)?this:a; }\nfunction bnMax(a) { return(this.compareTo(a)>0)?this:a; }\n\n//(protected) r = this op a (bitwise)\nfunction bnpBitwiseTo(a,op,r) {\nvar i, f, m = Math.min(a.t,this.t);\nfor(i = 0; i < m; ++i) r.data[i] = op(this.data[i],a.data[i]);\nif(a.t < this.t) {\n f = a.s&this.DM;\n for(i = m; i < this.t; ++i) r.data[i] = op(this.data[i],f);\n r.t = this.t;\n} else {\n f = this.s&this.DM;\n for(i = m; i < a.t; ++i) r.data[i] = op(f,a.data[i]);\n r.t = a.t;\n}\nr.s = op(this.s,a.s);\nr.clamp();\n}\n\n//(public) this & a\nfunction op_and(x,y) { return x&y; }\nfunction bnAnd(a) { var r = nbi(); this.bitwiseTo(a,op_and,r); return r; }\n\n//(public) this | a\nfunction op_or(x,y) { return x|y; }\nfunction bnOr(a) { var r = nbi(); this.bitwiseTo(a,op_or,r); return r; }\n\n//(public) this ^ a\nfunction op_xor(x,y) { return x^y; }\nfunction bnXor(a) { var r = nbi(); this.bitwiseTo(a,op_xor,r); return r; }\n\n//(public) this & ~a\nfunction op_andnot(x,y) { return x&~y; }\nfunction bnAndNot(a) { var r = nbi(); this.bitwiseTo(a,op_andnot,r); return r; }\n\n//(public) ~this\nfunction bnNot() {\nvar r = nbi();\nfor(var i = 0; i < this.t; ++i) r.data[i] = this.DM&~this.data[i];\nr.t = this.t;\nr.s = ~this.s;\nreturn r;\n}\n\n//(public) this << n\nfunction bnShiftLeft(n) {\nvar r = nbi();\nif(n < 0) this.rShiftTo(-n,r); else this.lShiftTo(n,r);\nreturn r;\n}\n\n//(public) this >> n\nfunction bnShiftRight(n) {\nvar r = nbi();\nif(n < 0) this.lShiftTo(-n,r); else this.rShiftTo(n,r);\nreturn r;\n}\n\n//return index of lowest 1-bit in x, x < 2^31\nfunction lbit(x) {\nif(x == 0) return -1;\nvar r = 0;\nif((x&0xffff) == 0) { x >>= 16; r += 16; }\nif((x&0xff) == 0) { x >>= 8; r += 8; }\nif((x&0xf) == 0) { x >>= 4; r += 4; }\nif((x&3) == 0) { x >>= 2; r += 2; }\nif((x&1) == 0) ++r;\nreturn r;\n}\n\n//(public) returns index of lowest 1-bit (or -1 if none)\nfunction bnGetLowestSetBit() {\nfor(var i = 0; i < this.t; ++i)\n if(this.data[i] != 0) return i*this.DB+lbit(this.data[i]);\nif(this.s < 0) return this.t*this.DB;\nreturn -1;\n}\n\n//return number of 1 bits in x\nfunction cbit(x) {\nvar r = 0;\nwhile(x != 0) { x &= x-1; ++r; }\nreturn r;\n}\n\n//(public) return number of set bits\nfunction bnBitCount() {\nvar r = 0, x = this.s&this.DM;\nfor(var i = 0; i < this.t; ++i) r += cbit(this.data[i]^x);\nreturn r;\n}\n\n//(public) true iff nth bit is set\nfunction bnTestBit(n) {\nvar j = Math.floor(n/this.DB);\nif(j >= this.t) return(this.s!=0);\nreturn((this.data[j]&(1<<(n%this.DB)))!=0);\n}\n\n//(protected) this op (1<<n)\nfunction bnpChangeBit(n,op) {\nvar r = BigInteger.ONE.shiftLeft(n);\nthis.bitwiseTo(r,op,r);\nreturn r;\n}\n\n//(public) this | (1<<n)\nfunction bnSetBit(n) { return this.changeBit(n,op_or); }\n\n//(public) this & ~(1<<n)\nfunction bnClearBit(n) { return this.changeBit(n,op_andnot); }\n\n//(public) this ^ (1<<n)\nfunction bnFlipBit(n) { return this.changeBit(n,op_xor); }\n\n//(protected) r = this + a\nfunction bnpAddTo(a,r) {\nvar i = 0, c = 0, m = Math.min(a.t,this.t);\nwhile(i < m) {\n c += this.data[i]+a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n}\nif(a.t < this.t) {\n c += a.s;\n while(i < this.t) {\n c += this.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n} else {\n c += this.s;\n while(i < a.t) {\n c += a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += a.s;\n}\nr.s = (c<0)?-1:0;\nif(c > 0) r.data[i++] = c;\nelse if(c < -1) r.data[i++] = this.DV+c;\nr.t = i;\nr.clamp();\n}\n\n//(public) this + a\nfunction bnAdd(a) { var r = nbi(); this.addTo(a,r); return r; }\n\n//(public) this - a\nfunction bnSubtract(a) { var r = nbi(); this.subTo(a,r); return r; }\n\n//(public) this * a\nfunction bnMultiply(a) { var r = nbi(); this.multiplyTo(a,r); return r; }\n\n//(public) this / a\nfunction bnDivide(a) { var r = nbi(); this.divRemTo(a,r,null); return r; }\n\n//(public) this % a\nfunction bnRemainder(a) { var r = nbi(); this.divRemTo(a,null,r); return r; }\n\n//(public) [this/a,this%a]\nfunction bnDivideAndRemainder(a) {\nvar q = nbi(), r = nbi();\nthis.divRemTo(a,q,r);\nreturn new Array(q,r);\n}\n\n//(protected) this *= n, this >= 0, 1 < n < DV\nfunction bnpDMultiply(n) {\nthis.data[this.t] = this.am(0,n-1,this,0,0,this.t);\n++this.t;\nthis.clamp();\n}\n\n//(protected) this += n << w words, this >= 0\nfunction bnpDAddOffset(n,w) {\nif(n == 0) return;\nwhile(this.t <= w) this.data[this.t++] = 0;\nthis.data[w] += n;\nwhile(this.data[w] >= this.DV) {\n this.data[w] -= this.DV;\n if(++w >= this.t) this.data[this.t++] = 0;\n ++this.data[w];\n}\n}\n\n//A \"null\" reducer\nfunction NullExp() {}\nfunction nNop(x) { return x; }\nfunction nMulTo(x,y,r) { x.multiplyTo(y,r); }\nfunction nSqrTo(x,r) { x.squareTo(r); }\n\nNullExp.prototype.convert = nNop;\nNullExp.prototype.revert = nNop;\nNullExp.prototype.mulTo = nMulTo;\nNullExp.prototype.sqrTo = nSqrTo;\n\n//(public) this^e\nfunction bnPow(e) { return this.exp(e,new NullExp()); }\n\n//(protected) r = lower n words of \"this * a\", a.t <= n\n//\"this\" should be the larger one if appropriate.\nfunction bnpMultiplyLowerTo(a,n,r) {\nvar i = Math.min(this.t+a.t,n);\nr.s = 0; // assumes a,this >= 0\nr.t = i;\nwhile(i > 0) r.data[--i] = 0;\nvar j;\nfor(j = r.t-this.t; i < j; ++i) r.data[i+this.t] = this.am(0,a.data[i],r,i,0,this.t);\nfor(j = Math.min(a.t,n); i < j; ++i) this.am(0,a.data[i],r,i,0,n-i);\nr.clamp();\n}\n\n//(protected) r = \"this * a\" without lower n words, n > 0\n//\"this\" should be the larger one if appropriate.\nfunction bnpMultiplyUpperTo(a,n,r) {\n--n;\nvar i = r.t = this.t+a.t-n;\nr.s = 0; // assumes a,this >= 0\nwhile(--i >= 0) r.data[i] = 0;\nfor(i = Math.max(n-this.t,0); i < a.t; ++i)\n r.data[this.t+i-n] = this.am(n-i,a.data[i],r,0,0,this.t+i-n);\nr.clamp();\nr.drShiftTo(1,r);\n}\n\n//Barrett modular reduction\nfunction Barrett(m) {\n// setup Barrett\nthis.r2 = nbi();\nthis.q3 = nbi();\nBigInteger.ONE.dlShiftTo(2*m.t,this.r2);\nthis.mu = this.r2.divide(m);\nthis.m = m;\n}\n\nfunction barrettConvert(x) {\nif(x.s < 0 || x.t > 2*this.m.t) return x.mod(this.m);\nelse if(x.compareTo(this.m) < 0) return x;\nelse { var r = nbi(); x.copyTo(r); this.reduce(r); return r; }\n}\n\nfunction barrettRevert(x) { return x; }\n\n//x = x mod m (HAC 14.42)\nfunction barrettReduce(x) {\nx.drShiftTo(this.m.t-1,this.r2);\nif(x.t > this.m.t+1) { x.t = this.m.t+1; x.clamp(); }\nthis.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3);\nthis.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);\nwhile(x.compareTo(this.r2) < 0) x.dAddOffset(1,this.m.t+1);\nx.subTo(this.r2,x);\nwhile(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n}\n\n//r = x^2 mod m; x != r\nfunction barrettSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n//r = x*y mod m; x,y != r\nfunction barrettMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\nBarrett.prototype.convert = barrettConvert;\nBarrett.prototype.revert = barrettRevert;\nBarrett.prototype.reduce = barrettReduce;\nBarrett.prototype.mulTo = barrettMulTo;\nBarrett.prototype.sqrTo = barrettSqrTo;\n\n//(public) this^e % m (HAC 14.85)\nfunction bnModPow(e,m) {\nvar i = e.bitLength(), k, r = nbv(1), z;\nif(i <= 0) return r;\nelse if(i < 18) k = 1;\nelse if(i < 48) k = 3;\nelse if(i < 144) k = 4;\nelse if(i < 768) k = 5;\nelse k = 6;\nif(i < 8)\n z = new Classic(m);\nelse if(m.isEven())\n z = new Barrett(m);\nelse\n z = new Montgomery(m);\n\n// precomputation\nvar g = new Array(), n = 3, k1 = k-1, km = (1<<k)-1;\ng[1] = z.convert(this);\nif(k > 1) {\n var g2 = nbi();\n z.sqrTo(g[1],g2);\n while(n <= km) {\n g[n] = nbi();\n z.mulTo(g2,g[n-2],g[n]);\n n += 2;\n }\n}\n\nvar j = e.t-1, w, is1 = true, r2 = nbi(), t;\ni = nbits(e.data[j])-1;\nwhile(j >= 0) {\n if(i >= k1) w = (e.data[j]>>(i-k1))&km;\n else {\n w = (e.data[j]&((1<<(i+1))-1))<<(k1-i);\n if(j > 0) w |= e.data[j-1]>>(this.DB+i-k1);\n }\n\n n = k;\n while((w&1) == 0) { w >>= 1; --n; }\n if((i -= n) < 0) { i += this.DB; --j; }\n if(is1) { // ret == 1, don't bother squaring or multiplying it\n g[w].copyTo(r);\n is1 = false;\n } else {\n while(n > 1) { z.sqrTo(r,r2); z.sqrTo(r2,r); n -= 2; }\n if(n > 0) z.sqrTo(r,r2); else { t = r; r = r2; r2 = t; }\n z.mulTo(r2,g[w],r);\n }\n\n while(j >= 0 && (e.data[j]&(1<<i)) == 0) {\n z.sqrTo(r,r2); t = r; r = r2; r2 = t;\n if(--i < 0) { i = this.DB-1; --j; }\n }\n}\nreturn z.revert(r);\n}\n\n//(public) gcd(this,a) (HAC 14.54)\nfunction bnGCD(a) {\nvar x = (this.s<0)?this.negate():this.clone();\nvar y = (a.s<0)?a.negate():a.clone();\nif(x.compareTo(y) < 0) { var t = x; x = y; y = t; }\nvar i = x.getLowestSetBit(), g = y.getLowestSetBit();\nif(g < 0) return x;\nif(i < g) g = i;\nif(g > 0) {\n x.rShiftTo(g,x);\n y.rShiftTo(g,y);\n}\nwhile(x.signum() > 0) {\n if((i = x.getLowestSetBit()) > 0) x.rShiftTo(i,x);\n if((i = y.getLowestSetBit()) > 0) y.rShiftTo(i,y);\n if(x.compareTo(y) >= 0) {\n x.subTo(y,x);\n x.rShiftTo(1,x);\n } else {\n y.subTo(x,y);\n y.rShiftTo(1,y);\n }\n}\nif(g > 0) y.lShiftTo(g,y);\nreturn y;\n}\n\n//(protected) this % n, n < 2^26\nfunction bnpModInt(n) {\nif(n <= 0) return 0;\nvar d = this.DV%n, r = (this.s<0)?n-1:0;\nif(this.t > 0)\n if(d == 0) r = this.data[0]%n;\n else for(var i = this.t-1; i >= 0; --i) r = (d*r+this.data[i])%n;\nreturn r;\n}\n\n//(public) 1/this % m (HAC 14.61)\nfunction bnModInverse(m) {\nvar ac = m.isEven();\nif((this.isEven() && ac) || m.signum() == 0) return BigInteger.ZERO;\nvar u = m.clone(), v = this.clone();\nvar a = nbv(1), b = nbv(0), c = nbv(0), d = nbv(1);\nwhile(u.signum() != 0) {\n while(u.isEven()) {\n u.rShiftTo(1,u);\n if(ac) {\n if(!a.isEven() || !b.isEven()) { a.addTo(this,a); b.subTo(m,b); }\n a.rShiftTo(1,a);\n } else if(!b.isEven()) b.subTo(m,b);\n b.rShiftTo(1,b);\n }\n while(v.isEven()) {\n v.rShiftTo(1,v);\n if(ac) {\n if(!c.isEven() || !d.isEven()) { c.addTo(this,c); d.subTo(m,d); }\n c.rShiftTo(1,c);\n } else if(!d.isEven()) d.subTo(m,d);\n d.rShiftTo(1,d);\n }\n if(u.compareTo(v) >= 0) {\n u.subTo(v,u);\n if(ac) a.subTo(c,a);\n b.subTo(d,b);\n } else {\n v.subTo(u,v);\n if(ac) c.subTo(a,c);\n d.subTo(b,d);\n }\n}\nif(v.compareTo(BigInteger.ONE) != 0) return BigInteger.ZERO;\nif(d.compareTo(m) >= 0) return d.subtract(m);\nif(d.signum() < 0) d.addTo(m,d); else return d;\nif(d.signum() < 0) return d.add(m); else return d;\n}\n\nvar lowprimes = [2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509];\nvar lplim = (1<<26)/lowprimes[lowprimes.length-1];\n\n//(public) test primality with certainty >= 1-.5^t\nfunction bnIsProbablePrime(t) {\nvar i, x = this.abs();\nif(x.t == 1 && x.data[0] <= lowprimes[lowprimes.length-1]) {\n for(i = 0; i < lowprimes.length; ++i)\n if(x.data[0] == lowprimes[i]) return true;\n return false;\n}\nif(x.isEven()) return false;\ni = 1;\nwhile(i < lowprimes.length) {\n var m = lowprimes[i], j = i+1;\n while(j < lowprimes.length && m < lplim) m *= lowprimes[j++];\n m = x.modInt(m);\n while(i < j) if(m%lowprimes[i++] == 0) return false;\n}\nreturn x.millerRabin(t);\n}\n\n//(protected) true if probably prime (HAC 4.24, Miller-Rabin)\nfunction bnpMillerRabin(t) {\nvar n1 = this.subtract(BigInteger.ONE);\nvar k = n1.getLowestSetBit();\nif(k <= 0) return false;\nvar r = n1.shiftRight(k);\nvar prng = bnGetPrng();\nvar a;\nfor(var i = 0; i < t; ++i) {\n // select witness 'a' at random from between 1 and n1\n do {\n a = new BigInteger(this.bitLength(), prng);\n }\n while(a.compareTo(BigInteger.ONE) <= 0 || a.compareTo(n1) >= 0);\n var y = a.modPow(r,this);\n if(y.compareTo(BigInteger.ONE) != 0 && y.compareTo(n1) != 0) {\n var j = 1;\n while(j++ < k && y.compareTo(n1) != 0) {\n y = y.modPowInt(2,this);\n if(y.compareTo(BigInteger.ONE) == 0) return false;\n }\n if(y.compareTo(n1) != 0) return false;\n }\n}\nreturn true;\n}\n\n// get pseudo random number generator\nfunction bnGetPrng() {\n // create prng with api that matches BigInteger secure random\n return {\n // x is an array to fill with bytes\n nextBytes: function(x) {\n for(var i = 0; i < x.length; ++i) {\n x[i] = Math.floor(Math.random() * 0x0100);\n }\n }\n };\n}\n\n//protected\nBigInteger.prototype.chunkSize = bnpChunkSize;\nBigInteger.prototype.toRadix = bnpToRadix;\nBigInteger.prototype.fromRadix = bnpFromRadix;\nBigInteger.prototype.fromNumber = bnpFromNumber;\nBigInteger.prototype.bitwiseTo = bnpBitwiseTo;\nBigInteger.prototype.changeBit = bnpChangeBit;\nBigInteger.prototype.addTo = bnpAddTo;\nBigInteger.prototype.dMultiply = bnpDMultiply;\nBigInteger.prototype.dAddOffset = bnpDAddOffset;\nBigInteger.prototype.multiplyLowerTo = bnpMultiplyLowerTo;\nBigInteger.prototype.multiplyUpperTo = bnpMultiplyUpperTo;\nBigInteger.prototype.modInt = bnpModInt;\nBigInteger.prototype.millerRabin = bnpMillerRabin;\n\n//public\nBigInteger.prototype.clone = bnClone;\nBigInteger.prototype.intValue = bnIntValue;\nBigInteger.prototype.byteValue = bnByteValue;\nBigInteger.prototype.shortValue = bnShortValue;\nBigInteger.prototype.signum = bnSigNum;\nBigInteger.prototype.toByteArray = bnToByteArray;\nBigInteger.prototype.equals = bnEquals;\nBigInteger.prototype.min = bnMin;\nBigInteger.prototype.max = bnMax;\nBigInteger.prototype.and = bnAnd;\nBigInteger.prototype.or = bnOr;\nBigInteger.prototype.xor = bnXor;\nBigInteger.prototype.andNot = bnAndNot;\nBigInteger.prototype.not = bnNot;\nBigInteger.prototype.shiftLeft = bnShiftLeft;\nBigInteger.prototype.shiftRight = bnShiftRight;\nBigInteger.prototype.getLowestSetBit = bnGetLowestSetBit;\nBigInteger.prototype.bitCount = bnBitCount;\nBigInteger.prototype.testBit = bnTestBit;\nBigInteger.prototype.setBit = bnSetBit;\nBigInteger.prototype.clearBit = bnClearBit;\nBigInteger.prototype.flipBit = bnFlipBit;\nBigInteger.prototype.add = bnAdd;\nBigInteger.prototype.subtract = bnSubtract;\nBigInteger.prototype.multiply = bnMultiply;\nBigInteger.prototype.divide = bnDivide;\nBigInteger.prototype.remainder = bnRemainder;\nBigInteger.prototype.divideAndRemainder = bnDivideAndRemainder;\nBigInteger.prototype.modPow = bnModPow;\nBigInteger.prototype.modInverse = bnModInverse;\nBigInteger.prototype.pow = bnPow;\nBigInteger.prototype.gcd = bnGCD;\nBigInteger.prototype.isProbablePrime = bnIsProbablePrime;\n\n//BigInteger interfaces not implemented in jsbn:\n\n//BigInteger(int signum, byte[] magnitude)\n//double doubleValue()\n//float floatValue()\n//int hashCode()\n//long longValue()\n//static BigInteger valueOf(long val)\n","/**\n * Partial implementation of PKCS#1 v2.2: RSA-OEAP\n *\n * Modified but based on the following MIT and BSD licensed code:\n *\n * https://github.com/kjur/jsjws/blob/master/rsa.js:\n *\n * The 'jsjws'(JSON Web Signature JavaScript Library) License\n *\n * Copyright (c) 2012 Kenji Urushima\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n *\n * http://webrsa.cvs.sourceforge.net/viewvc/webrsa/Client/RSAES-OAEP.js?content-type=text%2Fplain:\n *\n * RSAES-OAEP.js\n * $Id: RSAES-OAEP.js,v 1.1.1.1 2003/03/19 15:37:20 ellispritchard Exp $\n * JavaScript Implementation of PKCS #1 v2.1 RSA CRYPTOGRAPHY STANDARD (RSA Laboratories, June 14, 2002)\n * Copyright (C) Ellis Pritchard, Guardian Unlimited 2003.\n * Contact: ellis@nukinetics.com\n * Distributed under the BSD License.\n *\n * Official documentation: http://www.rsa.com/rsalabs/node.asp?id=2125\n *\n * @author Evan Jones (http://evanjones.ca/)\n * @author Dave Longley\n *\n * Copyright (c) 2013-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./random');\nrequire('./sha1');\n\n// shortcut for PKCS#1 API\nvar pkcs1 = module.exports = forge.pkcs1 = forge.pkcs1 || {};\n\n/**\n * Encode the given RSAES-OAEP message (M) using key, with optional label (L)\n * and seed.\n *\n * This method does not perform RSA encryption, it only encodes the message\n * using RSAES-OAEP.\n *\n * @param key the RSA key to use.\n * @param message the message to encode.\n * @param options the options to use:\n * label an optional label to use.\n * seed the seed to use.\n * md the message digest object to use, undefined for SHA-1.\n * mgf1 optional mgf1 parameters:\n * md the message digest object to use for MGF1.\n *\n * @return the encoded message bytes.\n */\npkcs1.encode_rsa_oaep = function(key, message, options) {\n // parse arguments\n var label;\n var seed;\n var md;\n var mgf1Md;\n // legacy args (label, seed, md)\n if(typeof options === 'string') {\n label = options;\n seed = arguments[3] || undefined;\n md = arguments[4] || undefined;\n } else if(options) {\n label = options.label || undefined;\n seed = options.seed || undefined;\n md = options.md || undefined;\n if(options.mgf1 && options.mgf1.md) {\n mgf1Md = options.mgf1.md;\n }\n }\n\n // default OAEP to SHA-1 message digest\n if(!md) {\n md = forge.md.sha1.create();\n } else {\n md.start();\n }\n\n // default MGF-1 to same as OAEP\n if(!mgf1Md) {\n mgf1Md = md;\n }\n\n // compute length in bytes and check output\n var keyLength = Math.ceil(key.n.bitLength() / 8);\n var maxLength = keyLength - 2 * md.digestLength - 2;\n if(message.length > maxLength) {\n var error = new Error('RSAES-OAEP input message length is too long.');\n error.length = message.length;\n error.maxLength = maxLength;\n throw error;\n }\n\n if(!label) {\n label = '';\n }\n md.update(label, 'raw');\n var lHash = md.digest();\n\n var PS = '';\n var PS_length = maxLength - message.length;\n for(var i = 0; i < PS_length; i++) {\n PS += '\\x00';\n }\n\n var DB = lHash.getBytes() + PS + '\\x01' + message;\n\n if(!seed) {\n seed = forge.random.getBytes(md.digestLength);\n } else if(seed.length !== md.digestLength) {\n var error = new Error('Invalid RSAES-OAEP seed. The seed length must ' +\n 'match the digest length.');\n error.seedLength = seed.length;\n error.digestLength = md.digestLength;\n throw error;\n }\n\n var dbMask = rsa_mgf1(seed, keyLength - md.digestLength - 1, mgf1Md);\n var maskedDB = forge.util.xorBytes(DB, dbMask, DB.length);\n\n var seedMask = rsa_mgf1(maskedDB, md.digestLength, mgf1Md);\n var maskedSeed = forge.util.xorBytes(seed, seedMask, seed.length);\n\n // return encoded message\n return '\\x00' + maskedSeed + maskedDB;\n};\n\n/**\n * Decode the given RSAES-OAEP encoded message (EM) using key, with optional\n * label (L).\n *\n * This method does not perform RSA decryption, it only decodes the message\n * using RSAES-OAEP.\n *\n * @param key the RSA key to use.\n * @param em the encoded message to decode.\n * @param options the options to use:\n * label an optional label to use.\n * md the message digest object to use for OAEP, undefined for SHA-1.\n * mgf1 optional mgf1 parameters:\n * md the message digest object to use for MGF1.\n *\n * @return the decoded message bytes.\n */\npkcs1.decode_rsa_oaep = function(key, em, options) {\n // parse args\n var label;\n var md;\n var mgf1Md;\n // legacy args\n if(typeof options === 'string') {\n label = options;\n md = arguments[3] || undefined;\n } else if(options) {\n label = options.label || undefined;\n md = options.md || undefined;\n if(options.mgf1 && options.mgf1.md) {\n mgf1Md = options.mgf1.md;\n }\n }\n\n // compute length in bytes\n var keyLength = Math.ceil(key.n.bitLength() / 8);\n\n if(em.length !== keyLength) {\n var error = new Error('RSAES-OAEP encoded message length is invalid.');\n error.length = em.length;\n error.expectedLength = keyLength;\n throw error;\n }\n\n // default OAEP to SHA-1 message digest\n if(md === undefined) {\n md = forge.md.sha1.create();\n } else {\n md.start();\n }\n\n // default MGF-1 to same as OAEP\n if(!mgf1Md) {\n mgf1Md = md;\n }\n\n if(keyLength < 2 * md.digestLength + 2) {\n throw new Error('RSAES-OAEP key is too short for the hash function.');\n }\n\n if(!label) {\n label = '';\n }\n md.update(label, 'raw');\n var lHash = md.digest().getBytes();\n\n // split the message into its parts\n var y = em.charAt(0);\n var maskedSeed = em.substring(1, md.digestLength + 1);\n var maskedDB = em.substring(1 + md.digestLength);\n\n var seedMask = rsa_mgf1(maskedDB, md.digestLength, mgf1Md);\n var seed = forge.util.xorBytes(maskedSeed, seedMask, maskedSeed.length);\n\n var dbMask = rsa_mgf1(seed, keyLength - md.digestLength - 1, mgf1Md);\n var db = forge.util.xorBytes(maskedDB, dbMask, maskedDB.length);\n\n var lHashPrime = db.substring(0, md.digestLength);\n\n // constant time check that all values match what is expected\n var error = (y !== '\\x00');\n\n // constant time check lHash vs lHashPrime\n for(var i = 0; i < md.digestLength; ++i) {\n error |= (lHash.charAt(i) !== lHashPrime.charAt(i));\n }\n\n // \"constant time\" find the 0x1 byte separating the padding (zeros) from the\n // message\n // TODO: It must be possible to do this in a better/smarter way?\n var in_ps = 1;\n var index = md.digestLength;\n for(var j = md.digestLength; j < db.length; j++) {\n var code = db.charCodeAt(j);\n\n var is_0 = (code & 0x1) ^ 0x1;\n\n // non-zero if not 0 or 1 in the ps section\n var error_mask = in_ps ? 0xfffe : 0x0000;\n error |= (code & error_mask);\n\n // latch in_ps to zero after we find 0x1\n in_ps = in_ps & is_0;\n index += in_ps;\n }\n\n if(error || db.charCodeAt(index) !== 0x1) {\n throw new Error('Invalid RSAES-OAEP padding.');\n }\n\n return db.substring(index + 1);\n};\n\nfunction rsa_mgf1(seed, maskLength, hash) {\n // default to SHA-1 message digest\n if(!hash) {\n hash = forge.md.sha1.create();\n }\n var t = '';\n var count = Math.ceil(maskLength / hash.digestLength);\n for(var i = 0; i < count; ++i) {\n var c = String.fromCharCode(\n (i >> 24) & 0xFF, (i >> 16) & 0xFF, (i >> 8) & 0xFF, i & 0xFF);\n hash.start();\n hash.update(seed + c);\n t += hash.digest().getBytes();\n }\n return t.substring(0, maskLength);\n}\n","/**\n * Secure Hash Algorithm with 160-bit digest (SHA-1) implementation.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha1 = module.exports = forge.sha1 = forge.sha1 || {};\nforge.md.sha1 = forge.md.algorithms.sha1 = sha1;\n\n/**\n * Creates a SHA-1 message digest object.\n *\n * @return a message digest object.\n */\nsha1.create = function() {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n // SHA-1 state contains five 32-bit integers\n var _state = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for word storage\n var _w = new Array(80);\n\n // message digest object\n var md = {\n algorithm: 'sha1',\n blockLength: 64,\n digestLength: 20,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 8\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength64 for backwards-compatibility)\n md.fullMessageLength = md.messageLength64 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _state = {\n h0: 0x67452301,\n h1: 0xEFCDAB89,\n h2: 0x98BADCFE,\n h3: 0x10325476,\n h4: 0xC3D2E1F0\n };\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = ((len[1] / 0x100000000) >>> 0);\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_state, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate SHA-1 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 448 mod 512. In other words,\n the data to be digested must be a multiple of 512 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 8 bytes (64\n bits), that means that the last segment of the data must have 56 bytes\n (448 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 448 mod 512 because\n 512 - 128 = 448.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 448 mod 512, then 512 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in big-endian order; since length\n // is stored in bytes we multiply by 8 and add carry from next int\n var next, carry;\n var bits = md.fullMessageLength[0] * 8;\n for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n next = md.fullMessageLength[i + 1] * 8;\n carry = (next / 0x100000000) >>> 0;\n bits += carry;\n finalBlock.putInt32(bits >>> 0);\n bits = next >>> 0;\n }\n finalBlock.putInt32(bits);\n\n var s2 = {\n h0: _state.h0,\n h1: _state.h1,\n h2: _state.h2,\n h3: _state.h3,\n h4: _state.h4\n };\n _update(s2, _w, finalBlock);\n var rval = forge.util.createBuffer();\n rval.putInt32(s2.h0);\n rval.putInt32(s2.h1);\n rval.putInt32(s2.h2);\n rval.putInt32(s2.h3);\n rval.putInt32(s2.h4);\n return rval;\n };\n\n return md;\n};\n\n// sha-1 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 64);\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates a SHA-1 state with the given byte buffer.\n *\n * @param s the SHA-1 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (64 byte) chunks\n var t, a, b, c, d, e, f, i;\n var len = bytes.length();\n while(len >= 64) {\n // the w array will be populated with sixteen 32-bit big-endian words\n // and then extended into 80 32-bit words according to SHA-1 algorithm\n // and for 32-79 using Max Locktyukhin's optimization\n\n // initialize hash value for this chunk\n a = s.h0;\n b = s.h1;\n c = s.h2;\n d = s.h3;\n e = s.h4;\n\n // round 1\n for(i = 0; i < 16; ++i) {\n t = bytes.getInt32();\n w[i] = t;\n f = d ^ (b & (c ^ d));\n t = ((a << 5) | (a >>> 27)) + f + e + 0x5A827999 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n for(; i < 20; ++i) {\n t = (w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16]);\n t = (t << 1) | (t >>> 31);\n w[i] = t;\n f = d ^ (b & (c ^ d));\n t = ((a << 5) | (a >>> 27)) + f + e + 0x5A827999 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n // round 2\n for(; i < 32; ++i) {\n t = (w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16]);\n t = (t << 1) | (t >>> 31);\n w[i] = t;\n f = b ^ c ^ d;\n t = ((a << 5) | (a >>> 27)) + f + e + 0x6ED9EBA1 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n for(; i < 40; ++i) {\n t = (w[i - 6] ^ w[i - 16] ^ w[i - 28] ^ w[i - 32]);\n t = (t << 2) | (t >>> 30);\n w[i] = t;\n f = b ^ c ^ d;\n t = ((a << 5) | (a >>> 27)) + f + e + 0x6ED9EBA1 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n // round 3\n for(; i < 60; ++i) {\n t = (w[i - 6] ^ w[i - 16] ^ w[i - 28] ^ w[i - 32]);\n t = (t << 2) | (t >>> 30);\n w[i] = t;\n f = (b & c) | (d & (b ^ c));\n t = ((a << 5) | (a >>> 27)) + f + e + 0x8F1BBCDC + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n // round 4\n for(; i < 80; ++i) {\n t = (w[i - 6] ^ w[i - 16] ^ w[i - 28] ^ w[i - 32]);\n t = (t << 2) | (t >>> 30);\n w[i] = t;\n f = b ^ c ^ d;\n t = ((a << 5) | (a >>> 27)) + f + e + 0xCA62C1D6 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n\n // update hash state\n s.h0 = (s.h0 + a) | 0;\n s.h1 = (s.h1 + b) | 0;\n s.h2 = (s.h2 + c) | 0;\n s.h3 = (s.h3 + d) | 0;\n s.h4 = (s.h4 + e) | 0;\n\n len -= 64;\n }\n}\n","/**\n * Prime number generation API.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./jsbn');\nrequire('./random');\n\n(function() {\n\n// forge.prime already defined\nif(forge.prime) {\n module.exports = forge.prime;\n return;\n}\n\n/* PRIME API */\nvar prime = module.exports = forge.prime = forge.prime || {};\n\nvar BigInteger = forge.jsbn.BigInteger;\n\n// primes are 30k+i for i = 1, 7, 11, 13, 17, 19, 23, 29\nvar GCD_30_DELTA = [6, 4, 2, 4, 2, 4, 6, 2];\nvar THIRTY = new BigInteger(null);\nTHIRTY.fromInt(30);\nvar op_or = function(x, y) {return x|y;};\n\n/**\n * Generates a random probable prime with the given number of bits.\n *\n * Alternative algorithms can be specified by name as a string or as an\n * object with custom options like so:\n *\n * {\n * name: 'PRIMEINC',\n * options: {\n * maxBlockTime: <the maximum amount of time to block the main\n * thread before allowing I/O other JS to run>,\n * millerRabinTests: <the number of miller-rabin tests to run>,\n * workerScript: <the worker script URL>,\n * workers: <the number of web workers (if supported) to use,\n * -1 to use estimated cores minus one>.\n * workLoad: the size of the work load, ie: number of possible prime\n * numbers for each web worker to check per work assignment,\n * (default: 100).\n * }\n * }\n *\n * @param bits the number of bits for the prime number.\n * @param options the options to use.\n * [algorithm] the algorithm to use (default: 'PRIMEINC').\n * [prng] a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\".\n *\n * @return callback(err, num) called once the operation completes.\n */\nprime.generateProbablePrime = function(bits, options, callback) {\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n\n // default to PRIMEINC algorithm\n var algorithm = options.algorithm || 'PRIMEINC';\n if(typeof algorithm === 'string') {\n algorithm = {name: algorithm};\n }\n algorithm.options = algorithm.options || {};\n\n // create prng with api that matches BigInteger secure random\n var prng = options.prng || forge.random;\n var rng = {\n // x is an array to fill with bytes\n nextBytes: function(x) {\n var b = prng.getBytesSync(x.length);\n for(var i = 0; i < x.length; ++i) {\n x[i] = b.charCodeAt(i);\n }\n }\n };\n\n if(algorithm.name === 'PRIMEINC') {\n return primeincFindPrime(bits, rng, algorithm.options, callback);\n }\n\n throw new Error('Invalid prime generation algorithm: ' + algorithm.name);\n};\n\nfunction primeincFindPrime(bits, rng, options, callback) {\n if('workers' in options) {\n return primeincFindPrimeWithWorkers(bits, rng, options, callback);\n }\n return primeincFindPrimeWithoutWorkers(bits, rng, options, callback);\n}\n\nfunction primeincFindPrimeWithoutWorkers(bits, rng, options, callback) {\n // initialize random number\n var num = generateRandom(bits, rng);\n\n /* Note: All primes are of the form 30k+i for i < 30 and gcd(30, i)=1. The\n number we are given is always aligned at 30k + 1. Each time the number is\n determined not to be prime we add to get to the next 'i', eg: if the number\n was at 30k + 1 we add 6. */\n var deltaIdx = 0;\n\n // get required number of MR tests\n var mrTests = getMillerRabinTests(num.bitLength());\n if('millerRabinTests' in options) {\n mrTests = options.millerRabinTests;\n }\n\n // find prime nearest to 'num' for maxBlockTime ms\n // 10 ms gives 5ms of leeway for other calculations before dropping\n // below 60fps (1000/60 == 16.67), but in reality, the number will\n // likely be higher due to an 'atomic' big int modPow\n var maxBlockTime = 10;\n if('maxBlockTime' in options) {\n maxBlockTime = options.maxBlockTime;\n }\n\n _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback);\n}\n\nfunction _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback) {\n var start = +new Date();\n do {\n // overflow, regenerate random number\n if(num.bitLength() > bits) {\n num = generateRandom(bits, rng);\n }\n // do primality test\n if(num.isProbablePrime(mrTests)) {\n return callback(null, num);\n }\n // get next potential prime\n num.dAddOffset(GCD_30_DELTA[deltaIdx++ % 8], 0);\n } while(maxBlockTime < 0 || (+new Date() - start < maxBlockTime));\n\n // keep trying later\n forge.util.setImmediate(function() {\n _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback);\n });\n}\n\n// NOTE: This algorithm is indeterminate in nature because workers\n// run in parallel looking at different segments of numbers. Even if this\n// algorithm is run twice with the same input from a predictable RNG, it\n// may produce different outputs.\nfunction primeincFindPrimeWithWorkers(bits, rng, options, callback) {\n // web workers unavailable\n if(typeof Worker === 'undefined') {\n return primeincFindPrimeWithoutWorkers(bits, rng, options, callback);\n }\n\n // initialize random number\n var num = generateRandom(bits, rng);\n\n // use web workers to generate keys\n var numWorkers = options.workers;\n var workLoad = options.workLoad || 100;\n var range = workLoad * 30 / 8;\n var workerScript = options.workerScript || 'forge/prime.worker.js';\n if(numWorkers === -1) {\n return forge.util.estimateCores(function(err, cores) {\n if(err) {\n // default to 2\n cores = 2;\n }\n numWorkers = cores - 1;\n generate();\n });\n }\n generate();\n\n function generate() {\n // require at least 1 worker\n numWorkers = Math.max(1, numWorkers);\n\n // TODO: consider optimizing by starting workers outside getPrime() ...\n // note that in order to clean up they will have to be made internally\n // asynchronous which may actually be slower\n\n // start workers immediately\n var workers = [];\n for(var i = 0; i < numWorkers; ++i) {\n // FIXME: fix path or use blob URLs\n workers[i] = new Worker(workerScript);\n }\n var running = numWorkers;\n\n // listen for requests from workers and assign ranges to find prime\n for(var i = 0; i < numWorkers; ++i) {\n workers[i].addEventListener('message', workerMessage);\n }\n\n /* Note: The distribution of random numbers is unknown. Therefore, each\n web worker is continuously allocated a range of numbers to check for a\n random number until one is found.\n\n Every 30 numbers will be checked just 8 times, because prime numbers\n have the form:\n\n 30k+i, for i < 30 and gcd(30, i)=1 (there are 8 values of i for this)\n\n Therefore, if we want a web worker to run N checks before asking for\n a new range of numbers, each range must contain N*30/8 numbers.\n\n For 100 checks (workLoad), this is a range of 375. */\n\n var found = false;\n function workerMessage(e) {\n // ignore message, prime already found\n if(found) {\n return;\n }\n\n --running;\n var data = e.data;\n if(data.found) {\n // terminate all workers\n for(var i = 0; i < workers.length; ++i) {\n workers[i].terminate();\n }\n found = true;\n return callback(null, new BigInteger(data.prime, 16));\n }\n\n // overflow, regenerate random number\n if(num.bitLength() > bits) {\n num = generateRandom(bits, rng);\n }\n\n // assign new range to check\n var hex = num.toString(16);\n\n // start prime search\n e.target.postMessage({\n hex: hex,\n workLoad: workLoad\n });\n\n num.dAddOffset(range, 0);\n }\n }\n}\n\n/**\n * Generates a random number using the given number of bits and RNG.\n *\n * @param bits the number of bits for the number.\n * @param rng the random number generator to use.\n *\n * @return the random number.\n */\nfunction generateRandom(bits, rng) {\n var num = new BigInteger(bits, rng);\n // force MSB set\n var bits1 = bits - 1;\n if(!num.testBit(bits1)) {\n num.bitwiseTo(BigInteger.ONE.shiftLeft(bits1), op_or, num);\n }\n // align number on 30k+1 boundary\n num.dAddOffset(31 - num.mod(THIRTY).byteValue(), 0);\n return num;\n}\n\n/**\n * Returns the required number of Miller-Rabin tests to generate a\n * prime with an error probability of (1/2)^80.\n *\n * See Handbook of Applied Cryptography Chapter 4, Table 4.4.\n *\n * @param bits the bit size.\n *\n * @return the required number of iterations.\n */\nfunction getMillerRabinTests(bits) {\n if(bits <= 100) return 27;\n if(bits <= 150) return 18;\n if(bits <= 200) return 15;\n if(bits <= 250) return 12;\n if(bits <= 300) return 9;\n if(bits <= 350) return 8;\n if(bits <= 400) return 7;\n if(bits <= 500) return 6;\n if(bits <= 600) return 5;\n if(bits <= 800) return 4;\n if(bits <= 1250) return 3;\n return 2;\n}\n\n})();\n","'use strict'\n\nconst { base64 } = require('multiformats/bases/base64')\nconst ciphers = require('../ciphers/aes-gcm')\n\nmodule.exports = {\n /**\n * Attempts to decrypt a base64 encoded PrivateKey string\n * with the given password. The privateKey must have been exported\n * using the same password and underlying cipher (aes-gcm)\n *\n * @param {string} privateKey - A base64 encoded encrypted key\n * @param {string} password\n * @returns {Promise<Uint8Array>} The private key protobuf\n */\n import: async function (privateKey, password) {\n const encryptedKey = base64.decode(privateKey)\n const cipher = ciphers.create()\n return await cipher.decrypt(encryptedKey, password)\n }\n}\n","'use strict'\n\nconst { concat } = require('uint8arrays/concat')\nconst { fromString } = require('uint8arrays/from-string')\n\nconst webcrypto = require('../webcrypto')\n\n// Based off of code from https://github.com/luke-park/SecureCompatibleEncryptionExamples\n\n/**\n *\n * @param {object} [options]\n * @param {string} [options.algorithm=AES-GCM]\n * @param {number} [options.nonceLength=12]\n * @param {number} [options.keyLength=16]\n * @param {string} [options.digest=sha256]\n * @param {number} [options.saltLength=16]\n * @param {number} [options.iterations=32767]\n * @returns {*}\n */\nfunction create ({\n algorithm = 'AES-GCM',\n nonceLength = 12,\n keyLength = 16,\n digest = 'SHA-256',\n saltLength = 16,\n iterations = 32767\n} = {}) {\n const crypto = webcrypto.get()\n keyLength *= 8 // Browser crypto uses bits instead of bytes\n\n /**\n * Uses the provided password to derive a pbkdf2 key. The key\n * will then be used to encrypt the data.\n *\n * @param {Uint8Array} data - The data to decrypt\n * @param {string} password - A plain password\n * @returns {Promise<Uint8Array>}\n */\n async function encrypt (data, password) { // eslint-disable-line require-await\n const salt = crypto.getRandomValues(new Uint8Array(saltLength))\n const nonce = crypto.getRandomValues(new Uint8Array(nonceLength))\n const aesGcm = { name: algorithm, iv: nonce }\n\n // Derive a key using PBKDF2.\n const deriveParams = { name: 'PBKDF2', salt, iterations, hash: { name: digest } }\n const rawKey = await crypto.subtle.importKey('raw', fromString(password), { name: 'PBKDF2' }, false, ['deriveKey', 'deriveBits'])\n const cryptoKey = await crypto.subtle.deriveKey(deriveParams, rawKey, { name: algorithm, length: keyLength }, true, ['encrypt'])\n\n // Encrypt the string.\n const ciphertext = await crypto.subtle.encrypt(aesGcm, cryptoKey, data)\n return concat([salt, aesGcm.iv, new Uint8Array(ciphertext)])\n }\n\n /**\n * Uses the provided password to derive a pbkdf2 key. The key\n * will then be used to decrypt the data. The options used to create\n * this decryption cipher must be the same as those used to create\n * the encryption cipher.\n *\n * @param {Uint8Array} data - The data to decrypt\n * @param {string} password - A plain password\n * @returns {Promise<Uint8Array>}\n */\n async function decrypt (data, password) {\n const salt = data.slice(0, saltLength)\n const nonce = data.slice(saltLength, saltLength + nonceLength)\n const ciphertext = data.slice(saltLength + nonceLength)\n const aesGcm = { name: algorithm, iv: nonce }\n\n // Derive the key using PBKDF2.\n const deriveParams = { name: 'PBKDF2', salt, iterations, hash: { name: digest } }\n const rawKey = await crypto.subtle.importKey('raw', fromString(password), { name: 'PBKDF2' }, false, ['deriveKey', 'deriveBits'])\n const cryptoKey = await crypto.subtle.deriveKey(deriveParams, rawKey, { name: algorithm, length: keyLength }, true, ['decrypt'])\n\n // Decrypt the string.\n const plaintext = await crypto.subtle.decrypt(aesGcm, cryptoKey, ciphertext)\n return new Uint8Array(plaintext)\n }\n\n return {\n encrypt,\n decrypt\n }\n}\n\nmodule.exports = {\n create\n}\n","/* eslint-env browser */\n\n'use strict'\n\n// Check native crypto exists and is enabled (In insecure context `self.crypto`\n// exists but `self.crypto.subtle` does not).\nexports.get = (win = self) => {\n const nativeCrypto = win.crypto || win.msCrypto\n\n if (!nativeCrypto || !nativeCrypto.subtle) {\n throw Object.assign(\n new Error(\n 'Missing Web Crypto API. ' +\n 'The most likely cause of this error is that this page is being accessed ' +\n 'from an insecure context (i.e. not HTTPS). For more information and ' +\n 'possible resolutions see ' +\n 'https://github.com/libp2p/js-libp2p-crypto/blob/master/README.md#web-crypto-api'\n ),\n { code: 'ERR_MISSING_WEB_CRYPTO' }\n )\n }\n\n return nativeCrypto\n}\n","'use strict'\n\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst errcode = require('err-code')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nrequire('node-forge/lib/sha512')\nrequire('node-forge/lib/ed25519')\nconst forge = require('node-forge/lib/forge')\n\nconst crypto = require('./rsa')\nconst pbm = require('./keys')\nconst exporter = require('./exporter')\n\nclass RsaPublicKey {\n constructor (key) {\n this._key = key\n }\n\n async verify (data, sig) { // eslint-disable-line require-await\n return crypto.hashAndVerify(this._key, sig, data)\n }\n\n marshal () {\n return crypto.utils.jwkToPkix(this._key)\n }\n\n get bytes () {\n return pbm.PublicKey.encode({\n Type: pbm.KeyType.RSA,\n Data: this.marshal()\n }).finish()\n }\n\n encrypt (bytes) {\n return crypto.encrypt(this._key, bytes)\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n}\n\nclass RsaPrivateKey {\n // key - Object of the jwk format\n // publicKey - Uint8Array of the spki format\n constructor (key, publicKey) {\n this._key = key\n this._publicKey = publicKey\n }\n\n genSecret () {\n return crypto.getRandomValues(16)\n }\n\n async sign (message) { // eslint-disable-line require-await\n return crypto.hashAndSign(this._key, message)\n }\n\n get public () {\n if (!this._publicKey) {\n throw errcode(new Error('public key not provided'), 'ERR_PUBKEY_NOT_PROVIDED')\n }\n\n return new RsaPublicKey(this._publicKey)\n }\n\n decrypt (bytes) {\n return crypto.decrypt(this._key, bytes)\n }\n\n marshal () {\n return crypto.utils.jwkToPkcs1(this._key)\n }\n\n get bytes () {\n return pbm.PrivateKey.encode({\n Type: pbm.KeyType.RSA,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n\n /**\n * Gets the ID of the key.\n *\n * The key id is the base58 encoding of the SHA-256 multihash of its public key.\n * The public key is a protobuf encoding containing a type and the DER encoding\n * of the PKCS SubjectPublicKeyInfo.\n *\n * @returns {Promise<string>}\n */\n async id () {\n const hash = await this.public.hash()\n return uint8ArrayToString(hash, 'base58btc')\n }\n\n /**\n * Exports the key into a password protected PEM format\n *\n * @param {string} password - The password to read the encrypted PEM\n * @param {string} [format=pkcs-8] - The format in which to export as\n */\n async export (password, format = 'pkcs-8') { // eslint-disable-line require-await\n if (format === 'pkcs-8') {\n const buffer = new forge.util.ByteBuffer(this.marshal())\n const asn1 = forge.asn1.fromDer(buffer)\n const privateKey = forge.pki.privateKeyFromAsn1(asn1)\n\n const options = {\n algorithm: 'aes256',\n count: 10000,\n saltSize: 128 / 8,\n prfAlgorithm: 'sha512'\n }\n return forge.pki.encryptRsaPrivateKey(privateKey, password, options)\n } else if (format === 'libp2p-key') {\n return exporter.export(this.bytes, password)\n } else {\n throw errcode(new Error(`export format '${format}' is not supported`), 'ERR_INVALID_EXPORT_FORMAT')\n }\n }\n}\n\nasync function unmarshalRsaPrivateKey (bytes) {\n const jwk = crypto.utils.pkcs1ToJwk(bytes)\n const keys = await crypto.unmarshalPrivateKey(jwk)\n return new RsaPrivateKey(keys.privateKey, keys.publicKey)\n}\n\nfunction unmarshalRsaPublicKey (bytes) {\n const jwk = crypto.utils.pkixToJwk(bytes)\n return new RsaPublicKey(jwk)\n}\n\nasync function fromJwk (jwk) {\n const keys = await crypto.unmarshalPrivateKey(jwk)\n return new RsaPrivateKey(keys.privateKey, keys.publicKey)\n}\n\nasync function generateKeyPair (bits) {\n const keys = await crypto.generateKey(bits)\n return new RsaPrivateKey(keys.privateKey, keys.publicKey)\n}\n\nmodule.exports = {\n RsaPublicKey,\n RsaPrivateKey,\n unmarshalRsaPublicKey,\n unmarshalRsaPrivateKey,\n generateKeyPair,\n fromJwk\n}\n","/**\n * Secure Hash Algorithm with a 1024-bit block size implementation.\n *\n * This includes: SHA-512, SHA-384, SHA-512/224, and SHA-512/256. For\n * SHA-256 (block size 512 bits), see sha256.js.\n *\n * See FIPS 180-4 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2014-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha512 = module.exports = forge.sha512 = forge.sha512 || {};\n\n// SHA-512\nforge.md.sha512 = forge.md.algorithms.sha512 = sha512;\n\n// SHA-384\nvar sha384 = forge.sha384 = forge.sha512.sha384 = forge.sha512.sha384 || {};\nsha384.create = function() {\n return sha512.create('SHA-384');\n};\nforge.md.sha384 = forge.md.algorithms.sha384 = sha384;\n\n// SHA-512/256\nforge.sha512.sha256 = forge.sha512.sha256 || {\n create: function() {\n return sha512.create('SHA-512/256');\n }\n};\nforge.md['sha512/256'] = forge.md.algorithms['sha512/256'] =\n forge.sha512.sha256;\n\n// SHA-512/224\nforge.sha512.sha224 = forge.sha512.sha224 || {\n create: function() {\n return sha512.create('SHA-512/224');\n }\n};\nforge.md['sha512/224'] = forge.md.algorithms['sha512/224'] =\n forge.sha512.sha224;\n\n/**\n * Creates a SHA-2 message digest object.\n *\n * @param algorithm the algorithm to use (SHA-512, SHA-384, SHA-512/224,\n * SHA-512/256).\n *\n * @return a message digest object.\n */\nsha512.create = function(algorithm) {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n if(typeof algorithm === 'undefined') {\n algorithm = 'SHA-512';\n }\n\n if(!(algorithm in _states)) {\n throw new Error('Invalid SHA-512 algorithm: ' + algorithm);\n }\n\n // SHA-512 state contains eight 64-bit integers (each as two 32-bit ints)\n var _state = _states[algorithm];\n var _h = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for 64-bit word storage\n var _w = new Array(80);\n for(var wi = 0; wi < 80; ++wi) {\n _w[wi] = new Array(2);\n }\n\n // determine digest length by algorithm name (default)\n var digestLength = 64;\n switch(algorithm) {\n case 'SHA-384':\n digestLength = 48;\n break;\n case 'SHA-512/256':\n digestLength = 32;\n break;\n case 'SHA-512/224':\n digestLength = 28;\n break;\n }\n\n // message digest object\n var md = {\n // SHA-512 => sha512\n algorithm: algorithm.replace('-', '').toLowerCase(),\n blockLength: 128,\n digestLength: digestLength,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 16\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength128 for backwards-compatibility)\n md.fullMessageLength = md.messageLength128 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _h = new Array(_state.length);\n for(var i = 0; i < _state.length; ++i) {\n _h[i] = _state[i].slice(0);\n }\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = ((len[1] / 0x100000000) >>> 0);\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_h, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate SHA-512 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 896 mod 1024. In other words,\n the data to be digested must be a multiple of 1024 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 16 bytes (128\n bits), that means that the last segment of the data must have 112 bytes\n (896 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 896 mod 1024 because\n 1024 - 128 = 896.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 896 mod 1024, then 1024 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in big-endian order; since length\n // is stored in bytes we multiply by 8 and add carry from next int\n var next, carry;\n var bits = md.fullMessageLength[0] * 8;\n for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n next = md.fullMessageLength[i + 1] * 8;\n carry = (next / 0x100000000) >>> 0;\n bits += carry;\n finalBlock.putInt32(bits >>> 0);\n bits = next >>> 0;\n }\n finalBlock.putInt32(bits);\n\n var h = new Array(_h.length);\n for(var i = 0; i < _h.length; ++i) {\n h[i] = _h[i].slice(0);\n }\n _update(h, _w, finalBlock);\n var rval = forge.util.createBuffer();\n var hlen;\n if(algorithm === 'SHA-512') {\n hlen = h.length;\n } else if(algorithm === 'SHA-384') {\n hlen = h.length - 2;\n } else {\n hlen = h.length - 4;\n }\n for(var i = 0; i < hlen; ++i) {\n rval.putInt32(h[i][0]);\n if(i !== hlen - 1 || algorithm !== 'SHA-512/224') {\n rval.putInt32(h[i][1]);\n }\n }\n return rval;\n };\n\n return md;\n};\n\n// sha-512 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n// table of constants\nvar _k = null;\n\n// initial hash states\nvar _states = null;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 128);\n\n // create K table for SHA-512\n _k = [\n [0x428a2f98, 0xd728ae22], [0x71374491, 0x23ef65cd],\n [0xb5c0fbcf, 0xec4d3b2f], [0xe9b5dba5, 0x8189dbbc],\n [0x3956c25b, 0xf348b538], [0x59f111f1, 0xb605d019],\n [0x923f82a4, 0xaf194f9b], [0xab1c5ed5, 0xda6d8118],\n [0xd807aa98, 0xa3030242], [0x12835b01, 0x45706fbe],\n [0x243185be, 0x4ee4b28c], [0x550c7dc3, 0xd5ffb4e2],\n [0x72be5d74, 0xf27b896f], [0x80deb1fe, 0x3b1696b1],\n [0x9bdc06a7, 0x25c71235], [0xc19bf174, 0xcf692694],\n [0xe49b69c1, 0x9ef14ad2], [0xefbe4786, 0x384f25e3],\n [0x0fc19dc6, 0x8b8cd5b5], [0x240ca1cc, 0x77ac9c65],\n [0x2de92c6f, 0x592b0275], [0x4a7484aa, 0x6ea6e483],\n [0x5cb0a9dc, 0xbd41fbd4], [0x76f988da, 0x831153b5],\n [0x983e5152, 0xee66dfab], [0xa831c66d, 0x2db43210],\n [0xb00327c8, 0x98fb213f], [0xbf597fc7, 0xbeef0ee4],\n [0xc6e00bf3, 0x3da88fc2], [0xd5a79147, 0x930aa725],\n [0x06ca6351, 0xe003826f], [0x14292967, 0x0a0e6e70],\n [0x27b70a85, 0x46d22ffc], [0x2e1b2138, 0x5c26c926],\n [0x4d2c6dfc, 0x5ac42aed], [0x53380d13, 0x9d95b3df],\n [0x650a7354, 0x8baf63de], [0x766a0abb, 0x3c77b2a8],\n [0x81c2c92e, 0x47edaee6], [0x92722c85, 0x1482353b],\n [0xa2bfe8a1, 0x4cf10364], [0xa81a664b, 0xbc423001],\n [0xc24b8b70, 0xd0f89791], [0xc76c51a3, 0x0654be30],\n [0xd192e819, 0xd6ef5218], [0xd6990624, 0x5565a910],\n [0xf40e3585, 0x5771202a], [0x106aa070, 0x32bbd1b8],\n [0x19a4c116, 0xb8d2d0c8], [0x1e376c08, 0x5141ab53],\n [0x2748774c, 0xdf8eeb99], [0x34b0bcb5, 0xe19b48a8],\n [0x391c0cb3, 0xc5c95a63], [0x4ed8aa4a, 0xe3418acb],\n [0x5b9cca4f, 0x7763e373], [0x682e6ff3, 0xd6b2b8a3],\n [0x748f82ee, 0x5defb2fc], [0x78a5636f, 0x43172f60],\n [0x84c87814, 0xa1f0ab72], [0x8cc70208, 0x1a6439ec],\n [0x90befffa, 0x23631e28], [0xa4506ceb, 0xde82bde9],\n [0xbef9a3f7, 0xb2c67915], [0xc67178f2, 0xe372532b],\n [0xca273ece, 0xea26619c], [0xd186b8c7, 0x21c0c207],\n [0xeada7dd6, 0xcde0eb1e], [0xf57d4f7f, 0xee6ed178],\n [0x06f067aa, 0x72176fba], [0x0a637dc5, 0xa2c898a6],\n [0x113f9804, 0xbef90dae], [0x1b710b35, 0x131c471b],\n [0x28db77f5, 0x23047d84], [0x32caab7b, 0x40c72493],\n [0x3c9ebe0a, 0x15c9bebc], [0x431d67c4, 0x9c100d4c],\n [0x4cc5d4be, 0xcb3e42b6], [0x597f299c, 0xfc657e2a],\n [0x5fcb6fab, 0x3ad6faec], [0x6c44198c, 0x4a475817]\n ];\n\n // initial hash states\n _states = {};\n _states['SHA-512'] = [\n [0x6a09e667, 0xf3bcc908],\n [0xbb67ae85, 0x84caa73b],\n [0x3c6ef372, 0xfe94f82b],\n [0xa54ff53a, 0x5f1d36f1],\n [0x510e527f, 0xade682d1],\n [0x9b05688c, 0x2b3e6c1f],\n [0x1f83d9ab, 0xfb41bd6b],\n [0x5be0cd19, 0x137e2179]\n ];\n _states['SHA-384'] = [\n [0xcbbb9d5d, 0xc1059ed8],\n [0x629a292a, 0x367cd507],\n [0x9159015a, 0x3070dd17],\n [0x152fecd8, 0xf70e5939],\n [0x67332667, 0xffc00b31],\n [0x8eb44a87, 0x68581511],\n [0xdb0c2e0d, 0x64f98fa7],\n [0x47b5481d, 0xbefa4fa4]\n ];\n _states['SHA-512/256'] = [\n [0x22312194, 0xFC2BF72C],\n [0x9F555FA3, 0xC84C64C2],\n [0x2393B86B, 0x6F53B151],\n [0x96387719, 0x5940EABD],\n [0x96283EE2, 0xA88EFFE3],\n [0xBE5E1E25, 0x53863992],\n [0x2B0199FC, 0x2C85B8AA],\n [0x0EB72DDC, 0x81C52CA2]\n ];\n _states['SHA-512/224'] = [\n [0x8C3D37C8, 0x19544DA2],\n [0x73E19966, 0x89DCD4D6],\n [0x1DFAB7AE, 0x32FF9C82],\n [0x679DD514, 0x582F9FCF],\n [0x0F6D2B69, 0x7BD44DA8],\n [0x77E36F73, 0x04C48942],\n [0x3F9D85A8, 0x6A1D36C8],\n [0x1112E6AD, 0x91D692A1]\n ];\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates a SHA-512 state with the given byte buffer.\n *\n * @param s the SHA-512 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (128 byte) chunks\n var t1_hi, t1_lo;\n var t2_hi, t2_lo;\n var s0_hi, s0_lo;\n var s1_hi, s1_lo;\n var ch_hi, ch_lo;\n var maj_hi, maj_lo;\n var a_hi, a_lo;\n var b_hi, b_lo;\n var c_hi, c_lo;\n var d_hi, d_lo;\n var e_hi, e_lo;\n var f_hi, f_lo;\n var g_hi, g_lo;\n var h_hi, h_lo;\n var i, hi, lo, w2, w7, w15, w16;\n var len = bytes.length();\n while(len >= 128) {\n // the w array will be populated with sixteen 64-bit big-endian words\n // and then extended into 64 64-bit words according to SHA-512\n for(i = 0; i < 16; ++i) {\n w[i][0] = bytes.getInt32() >>> 0;\n w[i][1] = bytes.getInt32() >>> 0;\n }\n for(; i < 80; ++i) {\n // for word 2 words ago: ROTR 19(x) ^ ROTR 61(x) ^ SHR 6(x)\n w2 = w[i - 2];\n hi = w2[0];\n lo = w2[1];\n\n // high bits\n t1_hi = (\n ((hi >>> 19) | (lo << 13)) ^ // ROTR 19\n ((lo >>> 29) | (hi << 3)) ^ // ROTR 61/(swap + ROTR 29)\n (hi >>> 6)) >>> 0; // SHR 6\n // low bits\n t1_lo = (\n ((hi << 13) | (lo >>> 19)) ^ // ROTR 19\n ((lo << 3) | (hi >>> 29)) ^ // ROTR 61/(swap + ROTR 29)\n ((hi << 26) | (lo >>> 6))) >>> 0; // SHR 6\n\n // for word 15 words ago: ROTR 1(x) ^ ROTR 8(x) ^ SHR 7(x)\n w15 = w[i - 15];\n hi = w15[0];\n lo = w15[1];\n\n // high bits\n t2_hi = (\n ((hi >>> 1) | (lo << 31)) ^ // ROTR 1\n ((hi >>> 8) | (lo << 24)) ^ // ROTR 8\n (hi >>> 7)) >>> 0; // SHR 7\n // low bits\n t2_lo = (\n ((hi << 31) | (lo >>> 1)) ^ // ROTR 1\n ((hi << 24) | (lo >>> 8)) ^ // ROTR 8\n ((hi << 25) | (lo >>> 7))) >>> 0; // SHR 7\n\n // sum(t1, word 7 ago, t2, word 16 ago) modulo 2^64 (carry lo overflow)\n w7 = w[i - 7];\n w16 = w[i - 16];\n lo = (t1_lo + w7[1] + t2_lo + w16[1]);\n w[i][0] = (t1_hi + w7[0] + t2_hi + w16[0] +\n ((lo / 0x100000000) >>> 0)) >>> 0;\n w[i][1] = lo >>> 0;\n }\n\n // initialize hash value for this chunk\n a_hi = s[0][0];\n a_lo = s[0][1];\n b_hi = s[1][0];\n b_lo = s[1][1];\n c_hi = s[2][0];\n c_lo = s[2][1];\n d_hi = s[3][0];\n d_lo = s[3][1];\n e_hi = s[4][0];\n e_lo = s[4][1];\n f_hi = s[5][0];\n f_lo = s[5][1];\n g_hi = s[6][0];\n g_lo = s[6][1];\n h_hi = s[7][0];\n h_lo = s[7][1];\n\n // round function\n for(i = 0; i < 80; ++i) {\n // Sum1(e) = ROTR 14(e) ^ ROTR 18(e) ^ ROTR 41(e)\n s1_hi = (\n ((e_hi >>> 14) | (e_lo << 18)) ^ // ROTR 14\n ((e_hi >>> 18) | (e_lo << 14)) ^ // ROTR 18\n ((e_lo >>> 9) | (e_hi << 23))) >>> 0; // ROTR 41/(swap + ROTR 9)\n s1_lo = (\n ((e_hi << 18) | (e_lo >>> 14)) ^ // ROTR 14\n ((e_hi << 14) | (e_lo >>> 18)) ^ // ROTR 18\n ((e_lo << 23) | (e_hi >>> 9))) >>> 0; // ROTR 41/(swap + ROTR 9)\n\n // Ch(e, f, g) (optimized the same way as SHA-1)\n ch_hi = (g_hi ^ (e_hi & (f_hi ^ g_hi))) >>> 0;\n ch_lo = (g_lo ^ (e_lo & (f_lo ^ g_lo))) >>> 0;\n\n // Sum0(a) = ROTR 28(a) ^ ROTR 34(a) ^ ROTR 39(a)\n s0_hi = (\n ((a_hi >>> 28) | (a_lo << 4)) ^ // ROTR 28\n ((a_lo >>> 2) | (a_hi << 30)) ^ // ROTR 34/(swap + ROTR 2)\n ((a_lo >>> 7) | (a_hi << 25))) >>> 0; // ROTR 39/(swap + ROTR 7)\n s0_lo = (\n ((a_hi << 4) | (a_lo >>> 28)) ^ // ROTR 28\n ((a_lo << 30) | (a_hi >>> 2)) ^ // ROTR 34/(swap + ROTR 2)\n ((a_lo << 25) | (a_hi >>> 7))) >>> 0; // ROTR 39/(swap + ROTR 7)\n\n // Maj(a, b, c) (optimized the same way as SHA-1)\n maj_hi = ((a_hi & b_hi) | (c_hi & (a_hi ^ b_hi))) >>> 0;\n maj_lo = ((a_lo & b_lo) | (c_lo & (a_lo ^ b_lo))) >>> 0;\n\n // main algorithm\n // t1 = (h + s1 + ch + _k[i] + _w[i]) modulo 2^64 (carry lo overflow)\n lo = (h_lo + s1_lo + ch_lo + _k[i][1] + w[i][1]);\n t1_hi = (h_hi + s1_hi + ch_hi + _k[i][0] + w[i][0] +\n ((lo / 0x100000000) >>> 0)) >>> 0;\n t1_lo = lo >>> 0;\n\n // t2 = s0 + maj modulo 2^64 (carry lo overflow)\n lo = s0_lo + maj_lo;\n t2_hi = (s0_hi + maj_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n t2_lo = lo >>> 0;\n\n h_hi = g_hi;\n h_lo = g_lo;\n\n g_hi = f_hi;\n g_lo = f_lo;\n\n f_hi = e_hi;\n f_lo = e_lo;\n\n // e = (d + t1) modulo 2^64 (carry lo overflow)\n lo = d_lo + t1_lo;\n e_hi = (d_hi + t1_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n e_lo = lo >>> 0;\n\n d_hi = c_hi;\n d_lo = c_lo;\n\n c_hi = b_hi;\n c_lo = b_lo;\n\n b_hi = a_hi;\n b_lo = a_lo;\n\n // a = (t1 + t2) modulo 2^64 (carry lo overflow)\n lo = t1_lo + t2_lo;\n a_hi = (t1_hi + t2_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n a_lo = lo >>> 0;\n }\n\n // update hash state (additional modulo 2^64)\n lo = s[0][1] + a_lo;\n s[0][0] = (s[0][0] + a_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[0][1] = lo >>> 0;\n\n lo = s[1][1] + b_lo;\n s[1][0] = (s[1][0] + b_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[1][1] = lo >>> 0;\n\n lo = s[2][1] + c_lo;\n s[2][0] = (s[2][0] + c_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[2][1] = lo >>> 0;\n\n lo = s[3][1] + d_lo;\n s[3][0] = (s[3][0] + d_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[3][1] = lo >>> 0;\n\n lo = s[4][1] + e_lo;\n s[4][0] = (s[4][0] + e_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[4][1] = lo >>> 0;\n\n lo = s[5][1] + f_lo;\n s[5][0] = (s[5][0] + f_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[5][1] = lo >>> 0;\n\n lo = s[6][1] + g_lo;\n s[6][0] = (s[6][0] + g_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[6][1] = lo >>> 0;\n\n lo = s[7][1] + h_lo;\n s[7][0] = (s[7][0] + h_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[7][1] = lo >>> 0;\n\n len -= 128;\n }\n}\n","/**\n * JavaScript implementation of Ed25519.\n *\n * Copyright (c) 2017-2019 Digital Bazaar, Inc.\n *\n * This implementation is based on the most excellent TweetNaCl which is\n * in the public domain. Many thanks to its contributors:\n *\n * https://github.com/dchest/tweetnacl-js\n */\nvar forge = require('./forge');\nrequire('./jsbn');\nrequire('./random');\nrequire('./sha512');\nrequire('./util');\nvar asn1Validator = require('./asn1-validator');\nvar publicKeyValidator = asn1Validator.publicKeyValidator;\nvar privateKeyValidator = asn1Validator.privateKeyValidator;\n\nif(typeof BigInteger === 'undefined') {\n var BigInteger = forge.jsbn.BigInteger;\n}\n\nvar ByteBuffer = forge.util.ByteBuffer;\nvar NativeBuffer = typeof Buffer === 'undefined' ? Uint8Array : Buffer;\n\n/*\n * Ed25519 algorithms, see RFC 8032:\n * https://tools.ietf.org/html/rfc8032\n */\nforge.pki = forge.pki || {};\nmodule.exports = forge.pki.ed25519 = forge.ed25519 = forge.ed25519 || {};\nvar ed25519 = forge.ed25519;\n\ned25519.constants = {};\ned25519.constants.PUBLIC_KEY_BYTE_LENGTH = 32;\ned25519.constants.PRIVATE_KEY_BYTE_LENGTH = 64;\ned25519.constants.SEED_BYTE_LENGTH = 32;\ned25519.constants.SIGN_BYTE_LENGTH = 64;\ned25519.constants.HASH_BYTE_LENGTH = 64;\n\ned25519.generateKeyPair = function(options) {\n options = options || {};\n var seed = options.seed;\n if(seed === undefined) {\n // generate seed\n seed = forge.random.getBytesSync(ed25519.constants.SEED_BYTE_LENGTH);\n } else if(typeof seed === 'string') {\n if(seed.length !== ed25519.constants.SEED_BYTE_LENGTH) {\n throw new TypeError(\n '\"seed\" must be ' + ed25519.constants.SEED_BYTE_LENGTH +\n ' bytes in length.');\n }\n } else if(!(seed instanceof Uint8Array)) {\n throw new TypeError(\n '\"seed\" must be a node.js Buffer, Uint8Array, or a binary string.');\n }\n\n seed = messageToNativeBuffer({message: seed, encoding: 'binary'});\n\n var pk = new NativeBuffer(ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n var sk = new NativeBuffer(ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n for(var i = 0; i < 32; ++i) {\n sk[i] = seed[i];\n }\n crypto_sign_keypair(pk, sk);\n return {publicKey: pk, privateKey: sk};\n};\n\n/**\n * Converts a private key from a RFC8410 ASN.1 encoding.\n *\n * @param obj - The asn1 representation of a private key.\n *\n * @returns {Object} keyInfo - The key information.\n * @returns {Buffer|Uint8Array} keyInfo.privateKeyBytes - 32 private key bytes.\n */\ned25519.privateKeyFromAsn1 = function(obj) {\n var capture = {};\n var errors = [];\n var valid = forge.asn1.validate(obj, privateKeyValidator, capture, errors);\n if(!valid) {\n var error = new Error('Invalid Key.');\n error.errors = errors;\n throw error;\n }\n var oid = forge.asn1.derToOid(capture.privateKeyOid);\n var ed25519Oid = forge.oids.EdDSA25519;\n if(oid !== ed25519Oid) {\n throw new Error('Invalid OID \"' + oid + '\"; OID must be \"' +\n ed25519Oid + '\".');\n }\n var privateKey = capture.privateKey;\n // manually extract the private key bytes from nested octet string, see FIXME:\n // https://github.com/digitalbazaar/forge/blob/master/lib/asn1.js#L542\n var privateKeyBytes = messageToNativeBuffer({\n message: forge.asn1.fromDer(privateKey).value,\n encoding: 'binary'\n });\n // TODO: RFC8410 specifies a format for encoding the public key bytes along\n // with the private key bytes. `publicKeyBytes` can be returned in the\n // future. https://tools.ietf.org/html/rfc8410#section-10.3\n return {privateKeyBytes: privateKeyBytes};\n};\n\n/**\n * Converts a public key from a RFC8410 ASN.1 encoding.\n *\n * @param obj - The asn1 representation of a public key.\n *\n * @return {Buffer|Uint8Array} - 32 public key bytes.\n */\ned25519.publicKeyFromAsn1 = function(obj) {\n // get SubjectPublicKeyInfo\n var capture = {};\n var errors = [];\n var valid = forge.asn1.validate(obj, publicKeyValidator, capture, errors);\n if(!valid) {\n var error = new Error('Invalid Key.');\n error.errors = errors;\n throw error;\n }\n var oid = forge.asn1.derToOid(capture.publicKeyOid);\n var ed25519Oid = forge.oids.EdDSA25519;\n if(oid !== ed25519Oid) {\n throw new Error('Invalid OID \"' + oid + '\"; OID must be \"' +\n ed25519Oid + '\".');\n }\n var publicKeyBytes = capture.ed25519PublicKey;\n if(publicKeyBytes.length !== ed25519.constants.PUBLIC_KEY_BYTE_LENGTH) {\n throw new Error('Key length is invalid.');\n }\n return messageToNativeBuffer({\n message: publicKeyBytes,\n encoding: 'binary'\n });\n};\n\ned25519.publicKeyFromPrivateKey = function(options) {\n options = options || {};\n var privateKey = messageToNativeBuffer({\n message: options.privateKey, encoding: 'binary'\n });\n if(privateKey.length !== ed25519.constants.PRIVATE_KEY_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.privateKey\" must have a byte length of ' +\n ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n }\n\n var pk = new NativeBuffer(ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n for(var i = 0; i < pk.length; ++i) {\n pk[i] = privateKey[32 + i];\n }\n return pk;\n};\n\ned25519.sign = function(options) {\n options = options || {};\n var msg = messageToNativeBuffer(options);\n var privateKey = messageToNativeBuffer({\n message: options.privateKey,\n encoding: 'binary'\n });\n if(privateKey.length === ed25519.constants.SEED_BYTE_LENGTH) {\n var keyPair = ed25519.generateKeyPair({seed: privateKey});\n privateKey = keyPair.privateKey;\n } else if(privateKey.length !== ed25519.constants.PRIVATE_KEY_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.privateKey\" must have a byte length of ' +\n ed25519.constants.SEED_BYTE_LENGTH + ' or ' +\n ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n }\n\n var signedMsg = new NativeBuffer(\n ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n crypto_sign(signedMsg, msg, msg.length, privateKey);\n\n var sig = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH);\n for(var i = 0; i < sig.length; ++i) {\n sig[i] = signedMsg[i];\n }\n return sig;\n};\n\ned25519.verify = function(options) {\n options = options || {};\n var msg = messageToNativeBuffer(options);\n if(options.signature === undefined) {\n throw new TypeError(\n '\"options.signature\" must be a node.js Buffer, a Uint8Array, a forge ' +\n 'ByteBuffer, or a binary string.');\n }\n var sig = messageToNativeBuffer({\n message: options.signature,\n encoding: 'binary'\n });\n if(sig.length !== ed25519.constants.SIGN_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.signature\" must have a byte length of ' +\n ed25519.constants.SIGN_BYTE_LENGTH);\n }\n var publicKey = messageToNativeBuffer({\n message: options.publicKey,\n encoding: 'binary'\n });\n if(publicKey.length !== ed25519.constants.PUBLIC_KEY_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.publicKey\" must have a byte length of ' +\n ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n }\n\n var sm = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n var m = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n var i;\n for(i = 0; i < ed25519.constants.SIGN_BYTE_LENGTH; ++i) {\n sm[i] = sig[i];\n }\n for(i = 0; i < msg.length; ++i) {\n sm[i + ed25519.constants.SIGN_BYTE_LENGTH] = msg[i];\n }\n return (crypto_sign_open(m, sm, sm.length, publicKey) >= 0);\n};\n\nfunction messageToNativeBuffer(options) {\n var message = options.message;\n if(message instanceof Uint8Array || message instanceof NativeBuffer) {\n return message;\n }\n\n var encoding = options.encoding;\n if(message === undefined) {\n if(options.md) {\n // TODO: more rigorous validation that `md` is a MessageDigest\n message = options.md.digest().getBytes();\n encoding = 'binary';\n } else {\n throw new TypeError('\"options.message\" or \"options.md\" not specified.');\n }\n }\n\n if(typeof message === 'string' && !encoding) {\n throw new TypeError('\"options.encoding\" must be \"binary\" or \"utf8\".');\n }\n\n if(typeof message === 'string') {\n if(typeof Buffer !== 'undefined') {\n return Buffer.from(message, encoding);\n }\n message = new ByteBuffer(message, encoding);\n } else if(!(message instanceof ByteBuffer)) {\n throw new TypeError(\n '\"options.message\" must be a node.js Buffer, a Uint8Array, a forge ' +\n 'ByteBuffer, or a string with \"options.encoding\" specifying its ' +\n 'encoding.');\n }\n\n // convert to native buffer\n var buffer = new NativeBuffer(message.length());\n for(var i = 0; i < buffer.length; ++i) {\n buffer[i] = message.at(i);\n }\n return buffer;\n}\n\nvar gf0 = gf();\nvar gf1 = gf([1]);\nvar D = gf([\n 0x78a3, 0x1359, 0x4dca, 0x75eb, 0xd8ab, 0x4141, 0x0a4d, 0x0070,\n 0xe898, 0x7779, 0x4079, 0x8cc7, 0xfe73, 0x2b6f, 0x6cee, 0x5203]);\nvar D2 = gf([\n 0xf159, 0x26b2, 0x9b94, 0xebd6, 0xb156, 0x8283, 0x149a, 0x00e0,\n 0xd130, 0xeef3, 0x80f2, 0x198e, 0xfce7, 0x56df, 0xd9dc, 0x2406]);\nvar X = gf([\n 0xd51a, 0x8f25, 0x2d60, 0xc956, 0xa7b2, 0x9525, 0xc760, 0x692c,\n 0xdc5c, 0xfdd6, 0xe231, 0xc0a4, 0x53fe, 0xcd6e, 0x36d3, 0x2169]);\nvar Y = gf([\n 0x6658, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666,\n 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666]);\nvar L = new Float64Array([\n 0xed, 0xd3, 0xf5, 0x5c, 0x1a, 0x63, 0x12, 0x58,\n 0xd6, 0x9c, 0xf7, 0xa2, 0xde, 0xf9, 0xde, 0x14,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x10]);\nvar I = gf([\n 0xa0b0, 0x4a0e, 0x1b27, 0xc4ee, 0xe478, 0xad2f, 0x1806, 0x2f43,\n 0xd7a7, 0x3dfb, 0x0099, 0x2b4d, 0xdf0b, 0x4fc1, 0x2480, 0x2b83]);\n\n// TODO: update forge buffer implementation to use `Buffer` or `Uint8Array`,\n// whichever is available, to improve performance\nfunction sha512(msg, msgLen) {\n // Note: `out` and `msg` are NativeBuffer\n var md = forge.md.sha512.create();\n var buffer = new ByteBuffer(msg);\n md.update(buffer.getBytes(msgLen), 'binary');\n var hash = md.digest().getBytes();\n if(typeof Buffer !== 'undefined') {\n return Buffer.from(hash, 'binary');\n }\n var out = new NativeBuffer(ed25519.constants.HASH_BYTE_LENGTH);\n for(var i = 0; i < 64; ++i) {\n out[i] = hash.charCodeAt(i);\n }\n return out;\n}\n\nfunction crypto_sign_keypair(pk, sk) {\n var p = [gf(), gf(), gf(), gf()];\n var i;\n\n var d = sha512(sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n\n scalarbase(p, d);\n pack(pk, p);\n\n for(i = 0; i < 32; ++i) {\n sk[i + 32] = pk[i];\n }\n return 0;\n}\n\n// Note: difference from C - smlen returned, not passed as argument.\nfunction crypto_sign(sm, m, n, sk) {\n var i, j, x = new Float64Array(64);\n var p = [gf(), gf(), gf(), gf()];\n\n var d = sha512(sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n\n var smlen = n + 64;\n for(i = 0; i < n; ++i) {\n sm[64 + i] = m[i];\n }\n for(i = 0; i < 32; ++i) {\n sm[32 + i] = d[32 + i];\n }\n\n var r = sha512(sm.subarray(32), n + 32);\n reduce(r);\n scalarbase(p, r);\n pack(sm, p);\n\n for(i = 32; i < 64; ++i) {\n sm[i] = sk[i];\n }\n var h = sha512(sm, n + 64);\n reduce(h);\n\n for(i = 32; i < 64; ++i) {\n x[i] = 0;\n }\n for(i = 0; i < 32; ++i) {\n x[i] = r[i];\n }\n for(i = 0; i < 32; ++i) {\n for(j = 0; j < 32; j++) {\n x[i + j] += h[i] * d[j];\n }\n }\n\n modL(sm.subarray(32), x);\n return smlen;\n}\n\nfunction crypto_sign_open(m, sm, n, pk) {\n var i, mlen;\n var t = new NativeBuffer(32);\n var p = [gf(), gf(), gf(), gf()],\n q = [gf(), gf(), gf(), gf()];\n\n mlen = -1;\n if(n < 64) {\n return -1;\n }\n\n if(unpackneg(q, pk)) {\n return -1;\n }\n\n for(i = 0; i < n; ++i) {\n m[i] = sm[i];\n }\n for(i = 0; i < 32; ++i) {\n m[i + 32] = pk[i];\n }\n var h = sha512(m, n);\n reduce(h);\n scalarmult(p, q, h);\n\n scalarbase(q, sm.subarray(32));\n add(p, q);\n pack(t, p);\n\n n -= 64;\n if(crypto_verify_32(sm, 0, t, 0)) {\n for(i = 0; i < n; ++i) {\n m[i] = 0;\n }\n return -1;\n }\n\n for(i = 0; i < n; ++i) {\n m[i] = sm[i + 64];\n }\n mlen = n;\n return mlen;\n}\n\nfunction modL(r, x) {\n var carry, i, j, k;\n for(i = 63; i >= 32; --i) {\n carry = 0;\n for(j = i - 32, k = i - 12; j < k; ++j) {\n x[j] += carry - 16 * x[i] * L[j - (i - 32)];\n carry = (x[j] + 128) >> 8;\n x[j] -= carry * 256;\n }\n x[j] += carry;\n x[i] = 0;\n }\n carry = 0;\n for(j = 0; j < 32; ++j) {\n x[j] += carry - (x[31] >> 4) * L[j];\n carry = x[j] >> 8;\n x[j] &= 255;\n }\n for(j = 0; j < 32; ++j) {\n x[j] -= carry * L[j];\n }\n for(i = 0; i < 32; ++i) {\n x[i + 1] += x[i] >> 8;\n r[i] = x[i] & 255;\n }\n}\n\nfunction reduce(r) {\n var x = new Float64Array(64);\n for(var i = 0; i < 64; ++i) {\n x[i] = r[i];\n r[i] = 0;\n }\n modL(r, x);\n}\n\nfunction add(p, q) {\n var a = gf(), b = gf(), c = gf(),\n d = gf(), e = gf(), f = gf(),\n g = gf(), h = gf(), t = gf();\n\n Z(a, p[1], p[0]);\n Z(t, q[1], q[0]);\n M(a, a, t);\n A(b, p[0], p[1]);\n A(t, q[0], q[1]);\n M(b, b, t);\n M(c, p[3], q[3]);\n M(c, c, D2);\n M(d, p[2], q[2]);\n A(d, d, d);\n Z(e, b, a);\n Z(f, d, c);\n A(g, d, c);\n A(h, b, a);\n\n M(p[0], e, f);\n M(p[1], h, g);\n M(p[2], g, f);\n M(p[3], e, h);\n}\n\nfunction cswap(p, q, b) {\n for(var i = 0; i < 4; ++i) {\n sel25519(p[i], q[i], b);\n }\n}\n\nfunction pack(r, p) {\n var tx = gf(), ty = gf(), zi = gf();\n inv25519(zi, p[2]);\n M(tx, p[0], zi);\n M(ty, p[1], zi);\n pack25519(r, ty);\n r[31] ^= par25519(tx) << 7;\n}\n\nfunction pack25519(o, n) {\n var i, j, b;\n var m = gf(), t = gf();\n for(i = 0; i < 16; ++i) {\n t[i] = n[i];\n }\n car25519(t);\n car25519(t);\n car25519(t);\n for(j = 0; j < 2; ++j) {\n m[0] = t[0] - 0xffed;\n for(i = 1; i < 15; ++i) {\n m[i] = t[i] - 0xffff - ((m[i - 1] >> 16) & 1);\n m[i-1] &= 0xffff;\n }\n m[15] = t[15] - 0x7fff - ((m[14] >> 16) & 1);\n b = (m[15] >> 16) & 1;\n m[14] &= 0xffff;\n sel25519(t, m, 1 - b);\n }\n for (i = 0; i < 16; i++) {\n o[2 * i] = t[i] & 0xff;\n o[2 * i + 1] = t[i] >> 8;\n }\n}\n\nfunction unpackneg(r, p) {\n var t = gf(), chk = gf(), num = gf(),\n den = gf(), den2 = gf(), den4 = gf(),\n den6 = gf();\n\n set25519(r[2], gf1);\n unpack25519(r[1], p);\n S(num, r[1]);\n M(den, num, D);\n Z(num, num, r[2]);\n A(den, r[2], den);\n\n S(den2, den);\n S(den4, den2);\n M(den6, den4, den2);\n M(t, den6, num);\n M(t, t, den);\n\n pow2523(t, t);\n M(t, t, num);\n M(t, t, den);\n M(t, t, den);\n M(r[0], t, den);\n\n S(chk, r[0]);\n M(chk, chk, den);\n if(neq25519(chk, num)) {\n M(r[0], r[0], I);\n }\n\n S(chk, r[0]);\n M(chk, chk, den);\n if(neq25519(chk, num)) {\n return -1;\n }\n\n if(par25519(r[0]) === (p[31] >> 7)) {\n Z(r[0], gf0, r[0]);\n }\n\n M(r[3], r[0], r[1]);\n return 0;\n}\n\nfunction unpack25519(o, n) {\n var i;\n for(i = 0; i < 16; ++i) {\n o[i] = n[2 * i] + (n[2 * i + 1] << 8);\n }\n o[15] &= 0x7fff;\n}\n\nfunction pow2523(o, i) {\n var c = gf();\n var a;\n for(a = 0; a < 16; ++a) {\n c[a] = i[a];\n }\n for(a = 250; a >= 0; --a) {\n S(c, c);\n if(a !== 1) {\n M(c, c, i);\n }\n }\n for(a = 0; a < 16; ++a) {\n o[a] = c[a];\n }\n}\n\nfunction neq25519(a, b) {\n var c = new NativeBuffer(32);\n var d = new NativeBuffer(32);\n pack25519(c, a);\n pack25519(d, b);\n return crypto_verify_32(c, 0, d, 0);\n}\n\nfunction crypto_verify_32(x, xi, y, yi) {\n return vn(x, xi, y, yi, 32);\n}\n\nfunction vn(x, xi, y, yi, n) {\n var i, d = 0;\n for(i = 0; i < n; ++i) {\n d |= x[xi + i] ^ y[yi + i];\n }\n return (1 & ((d - 1) >>> 8)) - 1;\n}\n\nfunction par25519(a) {\n var d = new NativeBuffer(32);\n pack25519(d, a);\n return d[0] & 1;\n}\n\nfunction scalarmult(p, q, s) {\n var b, i;\n set25519(p[0], gf0);\n set25519(p[1], gf1);\n set25519(p[2], gf1);\n set25519(p[3], gf0);\n for(i = 255; i >= 0; --i) {\n b = (s[(i / 8)|0] >> (i & 7)) & 1;\n cswap(p, q, b);\n add(q, p);\n add(p, p);\n cswap(p, q, b);\n }\n}\n\nfunction scalarbase(p, s) {\n var q = [gf(), gf(), gf(), gf()];\n set25519(q[0], X);\n set25519(q[1], Y);\n set25519(q[2], gf1);\n M(q[3], X, Y);\n scalarmult(p, q, s);\n}\n\nfunction set25519(r, a) {\n var i;\n for(i = 0; i < 16; i++) {\n r[i] = a[i] | 0;\n }\n}\n\nfunction inv25519(o, i) {\n var c = gf();\n var a;\n for(a = 0; a < 16; ++a) {\n c[a] = i[a];\n }\n for(a = 253; a >= 0; --a) {\n S(c, c);\n if(a !== 2 && a !== 4) {\n M(c, c, i);\n }\n }\n for(a = 0; a < 16; ++a) {\n o[a] = c[a];\n }\n}\n\nfunction car25519(o) {\n var i, v, c = 1;\n for(i = 0; i < 16; ++i) {\n v = o[i] + c + 65535;\n c = Math.floor(v / 65536);\n o[i] = v - c * 65536;\n }\n o[0] += c - 1 + 37 * (c - 1);\n}\n\nfunction sel25519(p, q, b) {\n var t, c = ~(b - 1);\n for(var i = 0; i < 16; ++i) {\n t = c & (p[i] ^ q[i]);\n p[i] ^= t;\n q[i] ^= t;\n }\n}\n\nfunction gf(init) {\n var i, r = new Float64Array(16);\n if(init) {\n for(i = 0; i < init.length; ++i) {\n r[i] = init[i];\n }\n }\n return r;\n}\n\nfunction A(o, a, b) {\n for(var i = 0; i < 16; ++i) {\n o[i] = a[i] + b[i];\n }\n}\n\nfunction Z(o, a, b) {\n for(var i = 0; i < 16; ++i) {\n o[i] = a[i] - b[i];\n }\n}\n\nfunction S(o, a) {\n M(o, a, a);\n}\n\nfunction M(o, a, b) {\n var v, c,\n t0 = 0, t1 = 0, t2 = 0, t3 = 0, t4 = 0, t5 = 0, t6 = 0, t7 = 0,\n t8 = 0, t9 = 0, t10 = 0, t11 = 0, t12 = 0, t13 = 0, t14 = 0, t15 = 0,\n t16 = 0, t17 = 0, t18 = 0, t19 = 0, t20 = 0, t21 = 0, t22 = 0, t23 = 0,\n t24 = 0, t25 = 0, t26 = 0, t27 = 0, t28 = 0, t29 = 0, t30 = 0,\n b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11],\n b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n\n v = a[0];\n t0 += v * b0;\n t1 += v * b1;\n t2 += v * b2;\n t3 += v * b3;\n t4 += v * b4;\n t5 += v * b5;\n t6 += v * b6;\n t7 += v * b7;\n t8 += v * b8;\n t9 += v * b9;\n t10 += v * b10;\n t11 += v * b11;\n t12 += v * b12;\n t13 += v * b13;\n t14 += v * b14;\n t15 += v * b15;\n v = a[1];\n t1 += v * b0;\n t2 += v * b1;\n t3 += v * b2;\n t4 += v * b3;\n t5 += v * b4;\n t6 += v * b5;\n t7 += v * b6;\n t8 += v * b7;\n t9 += v * b8;\n t10 += v * b9;\n t11 += v * b10;\n t12 += v * b11;\n t13 += v * b12;\n t14 += v * b13;\n t15 += v * b14;\n t16 += v * b15;\n v = a[2];\n t2 += v * b0;\n t3 += v * b1;\n t4 += v * b2;\n t5 += v * b3;\n t6 += v * b4;\n t7 += v * b5;\n t8 += v * b6;\n t9 += v * b7;\n t10 += v * b8;\n t11 += v * b9;\n t12 += v * b10;\n t13 += v * b11;\n t14 += v * b12;\n t15 += v * b13;\n t16 += v * b14;\n t17 += v * b15;\n v = a[3];\n t3 += v * b0;\n t4 += v * b1;\n t5 += v * b2;\n t6 += v * b3;\n t7 += v * b4;\n t8 += v * b5;\n t9 += v * b6;\n t10 += v * b7;\n t11 += v * b8;\n t12 += v * b9;\n t13 += v * b10;\n t14 += v * b11;\n t15 += v * b12;\n t16 += v * b13;\n t17 += v * b14;\n t18 += v * b15;\n v = a[4];\n t4 += v * b0;\n t5 += v * b1;\n t6 += v * b2;\n t7 += v * b3;\n t8 += v * b4;\n t9 += v * b5;\n t10 += v * b6;\n t11 += v * b7;\n t12 += v * b8;\n t13 += v * b9;\n t14 += v * b10;\n t15 += v * b11;\n t16 += v * b12;\n t17 += v * b13;\n t18 += v * b14;\n t19 += v * b15;\n v = a[5];\n t5 += v * b0;\n t6 += v * b1;\n t7 += v * b2;\n t8 += v * b3;\n t9 += v * b4;\n t10 += v * b5;\n t11 += v * b6;\n t12 += v * b7;\n t13 += v * b8;\n t14 += v * b9;\n t15 += v * b10;\n t16 += v * b11;\n t17 += v * b12;\n t18 += v * b13;\n t19 += v * b14;\n t20 += v * b15;\n v = a[6];\n t6 += v * b0;\n t7 += v * b1;\n t8 += v * b2;\n t9 += v * b3;\n t10 += v * b4;\n t11 += v * b5;\n t12 += v * b6;\n t13 += v * b7;\n t14 += v * b8;\n t15 += v * b9;\n t16 += v * b10;\n t17 += v * b11;\n t18 += v * b12;\n t19 += v * b13;\n t20 += v * b14;\n t21 += v * b15;\n v = a[7];\n t7 += v * b0;\n t8 += v * b1;\n t9 += v * b2;\n t10 += v * b3;\n t11 += v * b4;\n t12 += v * b5;\n t13 += v * b6;\n t14 += v * b7;\n t15 += v * b8;\n t16 += v * b9;\n t17 += v * b10;\n t18 += v * b11;\n t19 += v * b12;\n t20 += v * b13;\n t21 += v * b14;\n t22 += v * b15;\n v = a[8];\n t8 += v * b0;\n t9 += v * b1;\n t10 += v * b2;\n t11 += v * b3;\n t12 += v * b4;\n t13 += v * b5;\n t14 += v * b6;\n t15 += v * b7;\n t16 += v * b8;\n t17 += v * b9;\n t18 += v * b10;\n t19 += v * b11;\n t20 += v * b12;\n t21 += v * b13;\n t22 += v * b14;\n t23 += v * b15;\n v = a[9];\n t9 += v * b0;\n t10 += v * b1;\n t11 += v * b2;\n t12 += v * b3;\n t13 += v * b4;\n t14 += v * b5;\n t15 += v * b6;\n t16 += v * b7;\n t17 += v * b8;\n t18 += v * b9;\n t19 += v * b10;\n t20 += v * b11;\n t21 += v * b12;\n t22 += v * b13;\n t23 += v * b14;\n t24 += v * b15;\n v = a[10];\n t10 += v * b0;\n t11 += v * b1;\n t12 += v * b2;\n t13 += v * b3;\n t14 += v * b4;\n t15 += v * b5;\n t16 += v * b6;\n t17 += v * b7;\n t18 += v * b8;\n t19 += v * b9;\n t20 += v * b10;\n t21 += v * b11;\n t22 += v * b12;\n t23 += v * b13;\n t24 += v * b14;\n t25 += v * b15;\n v = a[11];\n t11 += v * b0;\n t12 += v * b1;\n t13 += v * b2;\n t14 += v * b3;\n t15 += v * b4;\n t16 += v * b5;\n t17 += v * b6;\n t18 += v * b7;\n t19 += v * b8;\n t20 += v * b9;\n t21 += v * b10;\n t22 += v * b11;\n t23 += v * b12;\n t24 += v * b13;\n t25 += v * b14;\n t26 += v * b15;\n v = a[12];\n t12 += v * b0;\n t13 += v * b1;\n t14 += v * b2;\n t15 += v * b3;\n t16 += v * b4;\n t17 += v * b5;\n t18 += v * b6;\n t19 += v * b7;\n t20 += v * b8;\n t21 += v * b9;\n t22 += v * b10;\n t23 += v * b11;\n t24 += v * b12;\n t25 += v * b13;\n t26 += v * b14;\n t27 += v * b15;\n v = a[13];\n t13 += v * b0;\n t14 += v * b1;\n t15 += v * b2;\n t16 += v * b3;\n t17 += v * b4;\n t18 += v * b5;\n t19 += v * b6;\n t20 += v * b7;\n t21 += v * b8;\n t22 += v * b9;\n t23 += v * b10;\n t24 += v * b11;\n t25 += v * b12;\n t26 += v * b13;\n t27 += v * b14;\n t28 += v * b15;\n v = a[14];\n t14 += v * b0;\n t15 += v * b1;\n t16 += v * b2;\n t17 += v * b3;\n t18 += v * b4;\n t19 += v * b5;\n t20 += v * b6;\n t21 += v * b7;\n t22 += v * b8;\n t23 += v * b9;\n t24 += v * b10;\n t25 += v * b11;\n t26 += v * b12;\n t27 += v * b13;\n t28 += v * b14;\n t29 += v * b15;\n v = a[15];\n t15 += v * b0;\n t16 += v * b1;\n t17 += v * b2;\n t18 += v * b3;\n t19 += v * b4;\n t20 += v * b5;\n t21 += v * b6;\n t22 += v * b7;\n t23 += v * b8;\n t24 += v * b9;\n t25 += v * b10;\n t26 += v * b11;\n t27 += v * b12;\n t28 += v * b13;\n t29 += v * b14;\n t30 += v * b15;\n\n t0 += 38 * t16;\n t1 += 38 * t17;\n t2 += 38 * t18;\n t3 += 38 * t19;\n t4 += 38 * t20;\n t5 += 38 * t21;\n t6 += 38 * t22;\n t7 += 38 * t23;\n t8 += 38 * t24;\n t9 += 38 * t25;\n t10 += 38 * t26;\n t11 += 38 * t27;\n t12 += 38 * t28;\n t13 += 38 * t29;\n t14 += 38 * t30;\n // t15 left as is\n\n // first car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c-1 + 37 * (c-1);\n\n // second car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c-1 + 37 * (c-1);\n\n o[ 0] = t0;\n o[ 1] = t1;\n o[ 2] = t2;\n o[ 3] = t3;\n o[ 4] = t4;\n o[ 5] = t5;\n o[ 6] = t6;\n o[ 7] = t7;\n o[ 8] = t8;\n o[ 9] = t9;\n o[10] = t10;\n o[11] = t11;\n o[12] = t12;\n o[13] = t13;\n o[14] = t14;\n o[15] = t15;\n}\n","/**\n * Copyright (c) 2019 Digital Bazaar, Inc.\n */\n\nvar forge = require('./forge');\nrequire('./asn1');\nvar asn1 = forge.asn1;\n\nexports.privateKeyValidator = {\n // PrivateKeyInfo\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // Version (INTEGER)\n name: 'PrivateKeyInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyVersion'\n }, {\n // privateKeyAlgorithm\n name: 'PrivateKeyInfo.privateKeyAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'privateKeyOid'\n }]\n }, {\n // PrivateKey\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'privateKey'\n }]\n};\n\nexports.publicKeyValidator = {\n name: 'SubjectPublicKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'subjectPublicKeyInfo',\n value: [{\n name: 'SubjectPublicKeyInfo.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'publicKeyOid'\n }]\n },\n // capture group for ed25519PublicKey\n {\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n composed: true,\n captureBitStringValue: 'ed25519PublicKey'\n }\n // FIXME: this is capture group for rsaPublicKey, use it in this API or\n // discard?\n /* {\n // subjectPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n value: [{\n // RSAPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n captureAsn1: 'rsaPublicKey'\n }]\n } */\n ]\n};\n","'use strict'\n\nconst webcrypto = require('../webcrypto')\nconst randomBytes = require('../random-bytes')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\nexports.utils = require('./rsa-utils')\n\nexports.generateKey = async function (bits) {\n const pair = await webcrypto.get().subtle.generateKey(\n {\n name: 'RSASSA-PKCS1-v1_5',\n modulusLength: bits,\n publicExponent: new Uint8Array([0x01, 0x00, 0x01]),\n hash: { name: 'SHA-256' }\n },\n true,\n ['sign', 'verify']\n )\n\n const keys = await exportKey(pair)\n\n return {\n privateKey: keys[0],\n publicKey: keys[1]\n }\n}\n\n// Takes a jwk key\nexports.unmarshalPrivateKey = async function (key) {\n const privateKey = await webcrypto.get().subtle.importKey(\n 'jwk',\n key,\n {\n name: 'RSASSA-PKCS1-v1_5',\n hash: { name: 'SHA-256' }\n },\n true,\n ['sign']\n )\n\n const pair = [\n privateKey,\n await derivePublicFromPrivate(key)\n ]\n\n const keys = await exportKey({\n privateKey: pair[0],\n publicKey: pair[1]\n })\n\n return {\n privateKey: keys[0],\n publicKey: keys[1]\n }\n}\n\nexports.getRandomValues = randomBytes\n\nexports.hashAndSign = async function (key, msg) {\n const privateKey = await webcrypto.get().subtle.importKey(\n 'jwk',\n key,\n {\n name: 'RSASSA-PKCS1-v1_5',\n hash: { name: 'SHA-256' }\n },\n false,\n ['sign']\n )\n\n const sig = await webcrypto.get().subtle.sign(\n { name: 'RSASSA-PKCS1-v1_5' },\n privateKey,\n Uint8Array.from(msg)\n )\n\n return new Uint8Array(sig, sig.byteOffset, sig.byteLength)\n}\n\nexports.hashAndVerify = async function (key, sig, msg) {\n const publicKey = await webcrypto.get().subtle.importKey(\n 'jwk',\n key,\n {\n name: 'RSASSA-PKCS1-v1_5',\n hash: { name: 'SHA-256' }\n },\n false,\n ['verify']\n )\n\n return webcrypto.get().subtle.verify(\n { name: 'RSASSA-PKCS1-v1_5' },\n publicKey,\n sig,\n msg\n )\n}\n\nfunction exportKey (pair) {\n return Promise.all([\n webcrypto.get().subtle.exportKey('jwk', pair.privateKey),\n webcrypto.get().subtle.exportKey('jwk', pair.publicKey)\n ])\n}\n\nfunction derivePublicFromPrivate (jwKey) {\n return webcrypto.get().subtle.importKey(\n 'jwk',\n {\n kty: jwKey.kty,\n n: jwKey.n,\n e: jwKey.e\n },\n {\n name: 'RSASSA-PKCS1-v1_5',\n hash: { name: 'SHA-256' }\n },\n true,\n ['verify']\n )\n}\n\n/*\n\nRSA encryption/decryption for the browser with webcrypto workarround\n\"bloody dark magic. webcrypto's why.\"\n\nExplanation:\n - Convert JWK to nodeForge\n - Convert msg Uint8Array to nodeForge buffer: ByteBuffer is a \"binary-string backed buffer\", so let's make our Uint8Array a binary string\n - Convert resulting nodeForge buffer to Uint8Array: it returns a binary string, turn that into a Uint8Array\n\n*/\n\nconst { jwk2pub, jwk2priv } = require('./jwk2pem')\n\nfunction convertKey (key, pub, msg, handle) {\n const fkey = pub ? jwk2pub(key) : jwk2priv(key)\n const fmsg = uint8ArrayToString(Uint8Array.from(msg), 'ascii')\n const fomsg = handle(fmsg, fkey)\n return uint8ArrayFromString(fomsg, 'ascii')\n}\n\nexports.encrypt = function (key, msg) {\n return convertKey(key, true, msg, (msg, key) => key.encrypt(msg))\n}\n\nexports.decrypt = function (key, msg) {\n return convertKey(key, false, msg, (msg, key) => key.decrypt(msg))\n}\n","'use strict'\nconst randomBytes = require('iso-random-stream/src/random')\nconst errcode = require('err-code')\n\nmodule.exports = function (length) {\n if (isNaN(length) || length <= 0) {\n throw errcode(new Error('random bytes length must be a Number bigger than 0'), 'ERR_INVALID_LENGTH')\n }\n return randomBytes(length)\n}\n","'use strict'\n\n// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nconst MAX_BYTES = 65536\n\n/**\n * @param {number} size\n */\nfunction randomBytes(size) {\n const bytes = new Uint8Array(size)\n let generated = 0\n\n if (size > 0) {\n // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) {\n while (generated < size) {\n if (generated + MAX_BYTES > size) {\n crypto.getRandomValues(\n bytes.subarray(generated, generated + (size - generated))\n )\n generated += size - generated\n } else {\n crypto.getRandomValues(\n bytes.subarray(generated, generated + MAX_BYTES)\n )\n generated += MAX_BYTES\n }\n }\n } else {\n crypto.getRandomValues(bytes)\n }\n }\n\n return bytes\n}\n\nmodule.exports = randomBytes\n","'use strict'\n\nrequire('node-forge/lib/asn1')\nrequire('node-forge/lib/rsa')\nconst forge = require('node-forge/lib/forge')\nconst { bigIntegerToUintBase64url, base64urlToBigInteger } = require('./../util')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\n// Convert a PKCS#1 in ASN1 DER format to a JWK key\nexports.pkcs1ToJwk = function (bytes) {\n const asn1 = forge.asn1.fromDer(uint8ArrayToString(bytes, 'ascii'))\n const privateKey = forge.pki.privateKeyFromAsn1(asn1)\n\n // https://tools.ietf.org/html/rfc7518#section-6.3.1\n return {\n kty: 'RSA',\n n: bigIntegerToUintBase64url(privateKey.n),\n e: bigIntegerToUintBase64url(privateKey.e),\n d: bigIntegerToUintBase64url(privateKey.d),\n p: bigIntegerToUintBase64url(privateKey.p),\n q: bigIntegerToUintBase64url(privateKey.q),\n dp: bigIntegerToUintBase64url(privateKey.dP),\n dq: bigIntegerToUintBase64url(privateKey.dQ),\n qi: bigIntegerToUintBase64url(privateKey.qInv),\n alg: 'RS256',\n kid: '2011-04-29'\n }\n}\n\n// Convert a JWK key into PKCS#1 in ASN1 DER format\nexports.jwkToPkcs1 = function (jwk) {\n const asn1 = forge.pki.privateKeyToAsn1({\n n: base64urlToBigInteger(jwk.n),\n e: base64urlToBigInteger(jwk.e),\n d: base64urlToBigInteger(jwk.d),\n p: base64urlToBigInteger(jwk.p),\n q: base64urlToBigInteger(jwk.q),\n dP: base64urlToBigInteger(jwk.dp),\n dQ: base64urlToBigInteger(jwk.dq),\n qInv: base64urlToBigInteger(jwk.qi)\n })\n\n return uint8ArrayFromString(forge.asn1.toDer(asn1).getBytes(), 'ascii')\n}\n\n// Convert a PKCIX in ASN1 DER format to a JWK key\nexports.pkixToJwk = function (bytes) {\n const asn1 = forge.asn1.fromDer(uint8ArrayToString(bytes, 'ascii'))\n const publicKey = forge.pki.publicKeyFromAsn1(asn1)\n\n return {\n kty: 'RSA',\n n: bigIntegerToUintBase64url(publicKey.n),\n e: bigIntegerToUintBase64url(publicKey.e),\n alg: 'RS256',\n kid: '2011-04-29'\n }\n}\n\n// Convert a JWK key to PKCIX in ASN1 DER format\nexports.jwkToPkix = function (jwk) {\n const asn1 = forge.pki.publicKeyToAsn1({\n n: base64urlToBigInteger(jwk.n),\n e: base64urlToBigInteger(jwk.e)\n })\n\n return uint8ArrayFromString(forge.asn1.toDer(asn1).getBytes(), 'ascii')\n}\n","'use strict'\n\nrequire('node-forge/lib/util')\nrequire('node-forge/lib/jsbn')\nconst forge = require('node-forge/lib/forge')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\n\nexports.bigIntegerToUintBase64url = (num, len) => {\n // Call `.abs()` to convert to unsigned\n let buf = Uint8Array.from(num.abs().toByteArray()) // toByteArray converts to big endian\n\n // toByteArray() gives us back a signed array, which will include a leading 0\n // byte if the most significant bit of the number is 1:\n // https://docs.microsoft.com/en-us/windows/win32/seccertenroll/about-integer\n // Our number will always be positive so we should remove the leading padding.\n buf = buf[0] === 0 ? buf.slice(1) : buf\n\n if (len != null) {\n if (buf.length > len) throw new Error('byte array longer than desired length')\n buf = uint8ArrayConcat([new Uint8Array(len - buf.length), buf])\n }\n\n return uint8ArrayToString(buf, 'base64url')\n}\n\n// Convert a base64url encoded string to a BigInteger\nexports.base64urlToBigInteger = str => {\n const buf = exports.base64urlToBuffer(str)\n return new forge.jsbn.BigInteger(uint8ArrayToString(buf, 'base16'), 16)\n}\n\nexports.base64urlToBuffer = (str, len) => {\n let buf = uint8ArrayFromString(str, 'base64urlpad')\n\n if (len != null) {\n if (buf.length > len) throw new Error('byte array longer than desired length')\n buf = uint8ArrayConcat([new Uint8Array(len - buf.length), buf])\n }\n\n return buf\n}\n","'use strict'\n\nrequire('node-forge/lib/rsa')\nconst forge = require('node-forge/lib/forge')\nconst { base64urlToBigInteger } = require('../util')\n\nfunction convert (key, types) {\n return types.map(t => base64urlToBigInteger(key[t]))\n}\n\nfunction jwk2priv (key) {\n return forge.pki.setRsaPrivateKey(...convert(key, ['n', 'e', 'd', 'p', 'q', 'dp', 'dq', 'qi']))\n}\n\nfunction jwk2pub (key) {\n return forge.pki.setRsaPublicKey(...convert(key, ['n', 'e']))\n}\n\nmodule.exports = {\n jwk2pub,\n jwk2priv\n}\n","'use strict'\n\nconst { base64 } = require('multiformats/bases/base64')\nconst ciphers = require('../ciphers/aes-gcm')\n\nmodule.exports = {\n /**\n * Exports the given PrivateKey as a base64 encoded string.\n * The PrivateKey is encrypted via a password derived PBKDF2 key\n * leveraging the aes-gcm cipher algorithm.\n *\n * @param {Uint8Array} privateKey - The PrivateKey protobuf\n * @param {string} password\n * @returns {Promise<string>} A base64 encoded string\n */\n export: async function (privateKey, password) {\n const cipher = ciphers.create()\n const encryptedKey = await cipher.encrypt(privateKey, password)\n return base64.encode(encryptedKey)\n }\n}\n","'use strict'\n\nconst errcode = require('err-code')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst { base58btc } = require('multiformats/bases/base58')\nconst { identity } = require('multiformats/hashes/identity')\nconst crypto = require('./ed25519')\nconst pbm = require('./keys')\nconst exporter = require('./exporter')\n\nclass Ed25519PublicKey {\n constructor (key) {\n this._key = ensureKey(key, crypto.publicKeyLength)\n }\n\n async verify (data, sig) { // eslint-disable-line require-await\n return crypto.hashAndVerify(this._key, sig, data)\n }\n\n marshal () {\n return this._key\n }\n\n get bytes () {\n return pbm.PublicKey.encode({\n Type: pbm.KeyType.Ed25519,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n}\n\nclass Ed25519PrivateKey {\n // key - 64 byte Uint8Array containing private key\n // publicKey - 32 byte Uint8Array containing public key\n constructor (key, publicKey) {\n this._key = ensureKey(key, crypto.privateKeyLength)\n this._publicKey = ensureKey(publicKey, crypto.publicKeyLength)\n }\n\n async sign (message) { // eslint-disable-line require-await\n return crypto.hashAndSign(this._key, message)\n }\n\n get public () {\n return new Ed25519PublicKey(this._publicKey)\n }\n\n marshal () {\n return this._key\n }\n\n get bytes () {\n return pbm.PrivateKey.encode({\n Type: pbm.KeyType.Ed25519,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n\n /**\n * Gets the ID of the key.\n *\n * The key id is the base58 encoding of the identity multihash containing its public key.\n * The public key is a protobuf encoding containing a type and the DER encoding\n * of the PKCS SubjectPublicKeyInfo.\n *\n * @returns {Promise<string>}\n */\n async id () {\n const encoding = await identity.digest(this.public.bytes)\n return base58btc.encode(encoding.bytes).substring(1)\n }\n\n /**\n * Exports the key into a password protected `format`\n *\n * @param {string} password - The password to encrypt the key\n * @param {string} [format=libp2p-key] - The format in which to export as\n * @returns {Promise<Uint8Array>} The encrypted private key\n */\n async export (password, format = 'libp2p-key') { // eslint-disable-line require-await\n if (format === 'libp2p-key') {\n return exporter.export(this.bytes, password)\n } else {\n throw errcode(new Error(`export format '${format}' is not supported`), 'ERR_INVALID_EXPORT_FORMAT')\n }\n }\n}\n\nfunction unmarshalEd25519PrivateKey (bytes) {\n // Try the old, redundant public key version\n if (bytes.length > crypto.privateKeyLength) {\n bytes = ensureKey(bytes, crypto.privateKeyLength + crypto.publicKeyLength)\n const privateKeyBytes = bytes.slice(0, crypto.privateKeyLength)\n const publicKeyBytes = bytes.slice(crypto.privateKeyLength, bytes.length)\n return new Ed25519PrivateKey(privateKeyBytes, publicKeyBytes)\n }\n\n bytes = ensureKey(bytes, crypto.privateKeyLength)\n const privateKeyBytes = bytes.slice(0, crypto.privateKeyLength)\n const publicKeyBytes = bytes.slice(crypto.publicKeyLength)\n return new Ed25519PrivateKey(privateKeyBytes, publicKeyBytes)\n}\n\nfunction unmarshalEd25519PublicKey (bytes) {\n bytes = ensureKey(bytes, crypto.publicKeyLength)\n return new Ed25519PublicKey(bytes)\n}\n\nasync function generateKeyPair () {\n const { privateKey, publicKey } = await crypto.generateKey()\n return new Ed25519PrivateKey(privateKey, publicKey)\n}\n\nasync function generateKeyPairFromSeed (seed) {\n const { privateKey, publicKey } = await crypto.generateKeyFromSeed(seed)\n return new Ed25519PrivateKey(privateKey, publicKey)\n}\n\nfunction ensureKey (key, length) {\n key = Uint8Array.from(key || [])\n if (key.length !== length) {\n throw errcode(new Error(`Key must be a Uint8Array of length ${length}, got ${key.length}`), 'ERR_INVALID_KEY_TYPE')\n }\n return key\n}\n\nmodule.exports = {\n Ed25519PublicKey,\n Ed25519PrivateKey,\n unmarshalEd25519PrivateKey,\n unmarshalEd25519PublicKey,\n generateKeyPair,\n generateKeyPairFromSeed\n}\n","'use strict'\n\nrequire('node-forge/lib/ed25519')\nconst forge = require('node-forge/lib/forge')\nexports.publicKeyLength = forge.pki.ed25519.constants.PUBLIC_KEY_BYTE_LENGTH\nexports.privateKeyLength = forge.pki.ed25519.constants.PRIVATE_KEY_BYTE_LENGTH\n\nexports.generateKey = async function () { // eslint-disable-line require-await\n return forge.pki.ed25519.generateKeyPair()\n}\n\n// seed should be a 32 byte uint8array\nexports.generateKeyFromSeed = async function (seed) { // eslint-disable-line require-await\n return forge.pki.ed25519.generateKeyPair({ seed })\n}\n\nexports.hashAndSign = async function (key, msg) { // eslint-disable-line require-await\n return forge.pki.ed25519.sign({ message: msg, privateKey: key })\n // return Uint8Array.from(nacl.sign.detached(msg, key))\n}\n\nexports.hashAndVerify = async function (key, sig, msg) { // eslint-disable-line require-await\n return forge.pki.ed25519.verify({ signature: sig, message: msg, publicKey: key })\n}\n","'use strict'\n\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst errcode = require('err-code')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst exporter = require('./exporter')\n\nmodule.exports = (keysProtobuf, randomBytes, crypto) => {\n crypto = crypto || require('./secp256k1')(randomBytes)\n\n class Secp256k1PublicKey {\n constructor (key) {\n crypto.validatePublicKey(key)\n this._key = key\n }\n\n verify (data, sig) {\n return crypto.hashAndVerify(this._key, sig, data)\n }\n\n marshal () {\n return crypto.compressPublicKey(this._key)\n }\n\n get bytes () {\n return keysProtobuf.PublicKey.encode({\n Type: keysProtobuf.KeyType.Secp256k1,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n }\n\n class Secp256k1PrivateKey {\n constructor (key, publicKey) {\n this._key = key\n this._publicKey = publicKey || crypto.computePublicKey(key)\n crypto.validatePrivateKey(this._key)\n crypto.validatePublicKey(this._publicKey)\n }\n\n sign (message) {\n return crypto.hashAndSign(this._key, message)\n }\n\n get public () {\n return new Secp256k1PublicKey(this._publicKey)\n }\n\n marshal () {\n return this._key\n }\n\n get bytes () {\n return keysProtobuf.PrivateKey.encode({\n Type: keysProtobuf.KeyType.Secp256k1,\n Data: this.marshal()\n }).finish()\n }\n\n equals (key) {\n return uint8ArrayEquals(this.bytes, key.bytes)\n }\n\n async hash () {\n const { bytes } = await sha256.digest(this.bytes)\n\n return bytes\n }\n\n /**\n * Gets the ID of the key.\n *\n * The key id is the base58 encoding of the SHA-256 multihash of its public key.\n * The public key is a protobuf encoding containing a type and the DER encoding\n * of the PKCS SubjectPublicKeyInfo.\n *\n * @returns {Promise<string>}\n */\n async id () {\n const hash = await this.public.hash()\n return uint8ArrayToString(hash, 'base58btc')\n }\n\n /**\n * Exports the key into a password protected `format`\n *\n * @param {string} password - The password to encrypt the key\n * @param {string} [format=libp2p-key] - The format in which to export as\n * @returns {Promise<string>} The encrypted private key\n */\n async export (password, format = 'libp2p-key') { // eslint-disable-line require-await\n if (format === 'libp2p-key') {\n return exporter.export(this.bytes, password)\n } else {\n throw errcode(new Error(`export format '${format}' is not supported`), 'ERR_INVALID_EXPORT_FORMAT')\n }\n }\n }\n\n function unmarshalSecp256k1PrivateKey (bytes) {\n return new Secp256k1PrivateKey(bytes)\n }\n\n function unmarshalSecp256k1PublicKey (bytes) {\n return new Secp256k1PublicKey(bytes)\n }\n\n async function generateKeyPair () {\n const privateKeyBytes = await crypto.generateKey()\n return new Secp256k1PrivateKey(privateKeyBytes)\n }\n\n return {\n Secp256k1PublicKey,\n Secp256k1PrivateKey,\n unmarshalSecp256k1PrivateKey,\n unmarshalSecp256k1PublicKey,\n generateKeyPair\n }\n}\n","'use strict'\n\nconst secp256k1 = require('secp256k1')\nconst { sha256 } = require('multiformats/hashes/sha2')\n\nmodule.exports = (randomBytes) => {\n const privateKeyLength = 32\n\n function generateKey () {\n let privateKey\n do {\n privateKey = randomBytes(32)\n } while (!secp256k1.privateKeyVerify(privateKey))\n return privateKey\n }\n\n async function hashAndSign (key, msg) {\n const { digest } = await sha256.digest(msg)\n const sig = secp256k1.ecdsaSign(digest, key)\n return secp256k1.signatureExport(sig.signature)\n }\n\n async function hashAndVerify (key, sig, msg) {\n const { digest } = await sha256.digest(msg)\n sig = secp256k1.signatureImport(sig)\n return secp256k1.ecdsaVerify(sig, digest, key)\n }\n\n function compressPublicKey (key) {\n if (!secp256k1.publicKeyVerify(key)) {\n throw new Error('Invalid public key')\n }\n return secp256k1.publicKeyConvert(key, true)\n }\n\n function decompressPublicKey (key) {\n return secp256k1.publicKeyConvert(key, false)\n }\n\n function validatePrivateKey (key) {\n if (!secp256k1.privateKeyVerify(key)) {\n throw new Error('Invalid private key')\n }\n }\n\n function validatePublicKey (key) {\n if (!secp256k1.publicKeyVerify(key)) {\n throw new Error('Invalid public key')\n }\n }\n\n function computePublicKey (privateKey) {\n validatePrivateKey(privateKey)\n return secp256k1.publicKeyCreate(privateKey)\n }\n\n return {\n generateKey,\n privateKeyLength,\n hashAndSign,\n hashAndVerify,\n compressPublicKey,\n decompressPublicKey,\n validatePrivateKey,\n validatePublicKey,\n computePublicKey\n }\n}\n","module.exports = require('./lib')(require('./lib/elliptic'))\n","const errors = {\n IMPOSSIBLE_CASE: 'Impossible case. Please create issue.',\n TWEAK_ADD:\n 'The tweak was out of range or the resulted private key is invalid',\n TWEAK_MUL: 'The tweak was out of range or equal to zero',\n CONTEXT_RANDOMIZE_UNKNOW: 'Unknow error on context randomization',\n SECKEY_INVALID: 'Private Key is invalid',\n PUBKEY_PARSE: 'Public Key could not be parsed',\n PUBKEY_SERIALIZE: 'Public Key serialization error',\n PUBKEY_COMBINE: 'The sum of the public keys is not valid',\n SIG_PARSE: 'Signature could not be parsed',\n SIGN: 'The nonce generation function failed, or the private key was invalid',\n RECOVER: 'Public key could not be recover',\n ECDH: 'Scalar was invalid (zero or overflow)'\n}\n\nfunction assert (cond, msg) {\n if (!cond) throw new Error(msg)\n}\n\nfunction isUint8Array (name, value, length) {\n assert(value instanceof Uint8Array, `Expected ${name} to be an Uint8Array`)\n\n if (length !== undefined) {\n if (Array.isArray(length)) {\n const numbers = length.join(', ')\n const msg = `Expected ${name} to be an Uint8Array with length [${numbers}]`\n assert(length.includes(value.length), msg)\n } else {\n const msg = `Expected ${name} to be an Uint8Array with length ${length}`\n assert(value.length === length, msg)\n }\n }\n}\n\nfunction isCompressed (value) {\n assert(toTypeString(value) === 'Boolean', 'Expected compressed to be a Boolean')\n}\n\nfunction getAssertedOutput (output = (len) => new Uint8Array(len), length) {\n if (typeof output === 'function') output = output(length)\n isUint8Array('output', output, length)\n return output\n}\n\nfunction toTypeString (value) {\n return Object.prototype.toString.call(value).slice(8, -1)\n}\n\nmodule.exports = (secp256k1) => {\n return {\n contextRandomize (seed) {\n assert(\n seed === null || seed instanceof Uint8Array,\n 'Expected seed to be an Uint8Array or null'\n )\n if (seed !== null) isUint8Array('seed', seed, 32)\n\n switch (secp256k1.contextRandomize(seed)) {\n case 1:\n throw new Error(errors.CONTEXT_RANDOMIZE_UNKNOW)\n }\n },\n\n privateKeyVerify (seckey) {\n isUint8Array('private key', seckey, 32)\n\n return secp256k1.privateKeyVerify(seckey) === 0\n },\n\n privateKeyNegate (seckey) {\n isUint8Array('private key', seckey, 32)\n\n switch (secp256k1.privateKeyNegate(seckey)) {\n case 0:\n return seckey\n case 1:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n privateKeyTweakAdd (seckey, tweak) {\n isUint8Array('private key', seckey, 32)\n isUint8Array('tweak', tweak, 32)\n\n switch (secp256k1.privateKeyTweakAdd(seckey, tweak)) {\n case 0:\n return seckey\n case 1:\n throw new Error(errors.TWEAK_ADD)\n }\n },\n\n privateKeyTweakMul (seckey, tweak) {\n isUint8Array('private key', seckey, 32)\n isUint8Array('tweak', tweak, 32)\n\n switch (secp256k1.privateKeyTweakMul(seckey, tweak)) {\n case 0:\n return seckey\n case 1:\n throw new Error(errors.TWEAK_MUL)\n }\n },\n\n publicKeyVerify (pubkey) {\n isUint8Array('public key', pubkey, [33, 65])\n\n return secp256k1.publicKeyVerify(pubkey) === 0\n },\n\n publicKeyCreate (seckey, compressed = true, output) {\n isUint8Array('private key', seckey, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyCreate(output, seckey)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.SECKEY_INVALID)\n case 2:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyConvert (pubkey, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyConvert(output, pubkey)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyNegate (pubkey, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyNegate(output, pubkey)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n case 3:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyCombine (pubkeys, compressed = true, output) {\n assert(Array.isArray(pubkeys), 'Expected public keys to be an Array')\n assert(pubkeys.length > 0, 'Expected public keys array will have more than zero items')\n for (const pubkey of pubkeys) {\n isUint8Array('public key', pubkey, [33, 65])\n }\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyCombine(output, pubkeys)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.PUBKEY_COMBINE)\n case 3:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyTweakAdd (pubkey, tweak, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isUint8Array('tweak', tweak, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyTweakAdd(output, pubkey, tweak)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.TWEAK_ADD)\n }\n },\n\n publicKeyTweakMul (pubkey, tweak, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isUint8Array('tweak', tweak, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyTweakMul(output, pubkey, tweak)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.TWEAK_MUL)\n }\n },\n\n signatureNormalize (sig) {\n isUint8Array('signature', sig, 64)\n\n switch (secp256k1.signatureNormalize(sig)) {\n case 0:\n return sig\n case 1:\n throw new Error(errors.SIG_PARSE)\n }\n },\n\n signatureExport (sig, output) {\n isUint8Array('signature', sig, 64)\n output = getAssertedOutput(output, 72)\n\n const obj = { output, outputlen: 72 }\n switch (secp256k1.signatureExport(obj, sig)) {\n case 0:\n return output.slice(0, obj.outputlen)\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n signatureImport (sig, output) {\n isUint8Array('signature', sig)\n output = getAssertedOutput(output, 64)\n\n switch (secp256k1.signatureImport(output, sig)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n ecdsaSign (msg32, seckey, options = {}, output) {\n isUint8Array('message', msg32, 32)\n isUint8Array('private key', seckey, 32)\n assert(toTypeString(options) === 'Object', 'Expected options to be an Object')\n if (options.data !== undefined) isUint8Array('options.data', options.data)\n if (options.noncefn !== undefined) assert(toTypeString(options.noncefn) === 'Function', 'Expected options.noncefn to be a Function')\n output = getAssertedOutput(output, 64)\n\n const obj = { signature: output, recid: null }\n switch (secp256k1.ecdsaSign(obj, msg32, seckey, options.data, options.noncefn)) {\n case 0:\n return obj\n case 1:\n throw new Error(errors.SIGN)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n ecdsaVerify (sig, msg32, pubkey) {\n isUint8Array('signature', sig, 64)\n isUint8Array('message', msg32, 32)\n isUint8Array('public key', pubkey, [33, 65])\n\n switch (secp256k1.ecdsaVerify(sig, msg32, pubkey)) {\n case 0:\n return true\n case 3:\n return false\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.PUBKEY_PARSE)\n }\n },\n\n ecdsaRecover (sig, recid, msg32, compressed = true, output) {\n isUint8Array('signature', sig, 64)\n assert(\n toTypeString(recid) === 'Number' &&\n recid >= 0 &&\n recid <= 3,\n 'Expected recovery id to be a Number within interval [0, 3]'\n )\n isUint8Array('message', msg32, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.ecdsaRecover(output, sig, recid, msg32)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.RECOVER)\n case 3:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n ecdh (pubkey, seckey, options = {}, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isUint8Array('private key', seckey, 32)\n assert(toTypeString(options) === 'Object', 'Expected options to be an Object')\n if (options.data !== undefined) isUint8Array('options.data', options.data)\n if (options.hashfn !== undefined) {\n assert(toTypeString(options.hashfn) === 'Function', 'Expected options.hashfn to be a Function')\n if (options.xbuf !== undefined) isUint8Array('options.xbuf', options.xbuf, 32)\n if (options.ybuf !== undefined) isUint8Array('options.ybuf', options.ybuf, 32)\n isUint8Array('output', output)\n } else {\n output = getAssertedOutput(output, 32)\n }\n\n switch (secp256k1.ecdh(output, pubkey, seckey, options.data, options.hashfn, options.xbuf, options.ybuf)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.ECDH)\n }\n }\n }\n}\n","const EC = require('elliptic').ec\n\nconst ec = new EC('secp256k1')\nconst ecparams = ec.curve\n\n// Hack, we can not use bn.js@5, while elliptic uses bn.js@4\n// See https://github.com/indutny/elliptic/issues/191#issuecomment-569888758\nconst BN = ecparams.n.constructor\n\nfunction loadCompressedPublicKey (first, xbuf) {\n let x = new BN(xbuf)\n\n // overflow\n if (x.cmp(ecparams.p) >= 0) return null\n x = x.toRed(ecparams.red)\n\n // compute corresponding Y\n let y = x.redSqr().redIMul(x).redIAdd(ecparams.b).redSqrt()\n if ((first === 0x03) !== y.isOdd()) y = y.redNeg()\n\n return ec.keyPair({ pub: { x: x, y: y } })\n}\n\nfunction loadUncompressedPublicKey (first, xbuf, ybuf) {\n let x = new BN(xbuf)\n let y = new BN(ybuf)\n\n // overflow\n if (x.cmp(ecparams.p) >= 0 || y.cmp(ecparams.p) >= 0) return null\n\n x = x.toRed(ecparams.red)\n y = y.toRed(ecparams.red)\n\n // is odd flag\n if ((first === 0x06 || first === 0x07) && y.isOdd() !== (first === 0x07)) return null\n\n // x*x*x + b = y*y\n const x3 = x.redSqr().redIMul(x)\n if (!y.redSqr().redISub(x3.redIAdd(ecparams.b)).isZero()) return null\n\n return ec.keyPair({ pub: { x: x, y: y } })\n}\n\nfunction loadPublicKey (pubkey) {\n // length should be validated in interface\n const first = pubkey[0]\n switch (first) {\n case 0x02:\n case 0x03:\n if (pubkey.length !== 33) return null\n return loadCompressedPublicKey(first, pubkey.subarray(1, 33))\n case 0x04:\n case 0x06:\n case 0x07:\n if (pubkey.length !== 65) return null\n return loadUncompressedPublicKey(first, pubkey.subarray(1, 33), pubkey.subarray(33, 65))\n default:\n return null\n }\n}\n\nfunction savePublicKey (output, point) {\n const pubkey = point.encode(null, output.length === 33)\n // Loop should be faster because we do not need create extra Uint8Array\n // output.set(new Uint8Array(pubkey))\n for (let i = 0; i < output.length; ++i) output[i] = pubkey[i]\n}\n\nmodule.exports = {\n contextRandomize () {\n return 0\n },\n\n privateKeyVerify (seckey) {\n const bn = new BN(seckey)\n return bn.cmp(ecparams.n) < 0 && !bn.isZero() ? 0 : 1\n },\n\n privateKeyNegate (seckey) {\n const bn = new BN(seckey)\n const negate = ecparams.n.sub(bn).umod(ecparams.n).toArrayLike(Uint8Array, 'be', 32)\n seckey.set(negate)\n return 0\n },\n\n privateKeyTweakAdd (seckey, tweak) {\n const bn = new BN(tweak)\n if (bn.cmp(ecparams.n) >= 0) return 1\n\n bn.iadd(new BN(seckey))\n if (bn.cmp(ecparams.n) >= 0) bn.isub(ecparams.n)\n if (bn.isZero()) return 1\n\n const tweaked = bn.toArrayLike(Uint8Array, 'be', 32)\n seckey.set(tweaked)\n\n return 0\n },\n\n privateKeyTweakMul (seckey, tweak) {\n let bn = new BN(tweak)\n if (bn.cmp(ecparams.n) >= 0 || bn.isZero()) return 1\n\n bn.imul(new BN(seckey))\n if (bn.cmp(ecparams.n) >= 0) bn = bn.umod(ecparams.n)\n\n const tweaked = bn.toArrayLike(Uint8Array, 'be', 32)\n seckey.set(tweaked)\n\n return 0\n },\n\n publicKeyVerify (pubkey) {\n const pair = loadPublicKey(pubkey)\n return pair === null ? 1 : 0\n },\n\n publicKeyCreate (output, seckey) {\n const bn = new BN(seckey)\n if (bn.cmp(ecparams.n) >= 0 || bn.isZero()) return 1\n\n const point = ec.keyFromPrivate(seckey).getPublic()\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyConvert (output, pubkey) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n const point = pair.getPublic()\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyNegate (output, pubkey) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n const point = pair.getPublic()\n point.y = point.y.redNeg()\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyCombine (output, pubkeys) {\n const pairs = new Array(pubkeys.length)\n for (let i = 0; i < pubkeys.length; ++i) {\n pairs[i] = loadPublicKey(pubkeys[i])\n if (pairs[i] === null) return 1\n }\n\n let point = pairs[0].getPublic()\n for (let i = 1; i < pairs.length; ++i) point = point.add(pairs[i].pub)\n if (point.isInfinity()) return 2\n\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyTweakAdd (output, pubkey, tweak) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n tweak = new BN(tweak)\n if (tweak.cmp(ecparams.n) >= 0) return 2\n\n const point = pair.getPublic().add(ecparams.g.mul(tweak))\n if (point.isInfinity()) return 2\n\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyTweakMul (output, pubkey, tweak) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n tweak = new BN(tweak)\n if (tweak.cmp(ecparams.n) >= 0 || tweak.isZero()) return 2\n\n const point = pair.getPublic().mul(tweak)\n savePublicKey(output, point)\n\n return 0\n },\n\n signatureNormalize (sig) {\n const r = new BN(sig.subarray(0, 32))\n const s = new BN(sig.subarray(32, 64))\n if (r.cmp(ecparams.n) >= 0 || s.cmp(ecparams.n) >= 0) return 1\n\n if (s.cmp(ec.nh) === 1) {\n sig.set(ecparams.n.sub(s).toArrayLike(Uint8Array, 'be', 32), 32)\n }\n\n return 0\n },\n\n // Copied 1-to-1 from https://github.com/bitcoinjs/bip66/blob/master/index.js\n // Adapted for Uint8Array instead Buffer\n signatureExport (obj, sig) {\n const sigR = sig.subarray(0, 32)\n const sigS = sig.subarray(32, 64)\n if (new BN(sigR).cmp(ecparams.n) >= 0) return 1\n if (new BN(sigS).cmp(ecparams.n) >= 0) return 1\n\n const { output } = obj\n\n // Prepare R\n let r = output.subarray(4, 4 + 33)\n r[0] = 0x00\n r.set(sigR, 1)\n\n let lenR = 33\n let posR = 0\n for (; lenR > 1 && r[posR] === 0x00 && !(r[posR + 1] & 0x80); --lenR, ++posR);\n\n r = r.subarray(posR)\n if (r[0] & 0x80) return 1\n if (lenR > 1 && (r[0] === 0x00) && !(r[1] & 0x80)) return 1\n\n // Prepare S\n let s = output.subarray(6 + 33, 6 + 33 + 33)\n s[0] = 0x00\n s.set(sigS, 1)\n\n let lenS = 33\n let posS = 0\n for (; lenS > 1 && s[posS] === 0x00 && !(s[posS + 1] & 0x80); --lenS, ++posS);\n\n s = s.subarray(posS)\n if (s[0] & 0x80) return 1\n if (lenS > 1 && (s[0] === 0x00) && !(s[1] & 0x80)) return 1\n\n // Set output length for return\n obj.outputlen = 6 + lenR + lenS\n\n // Output in specified format\n // 0x30 [total-length] 0x02 [R-length] [R] 0x02 [S-length] [S]\n output[0] = 0x30\n output[1] = obj.outputlen - 2\n output[2] = 0x02\n output[3] = r.length\n output.set(r, 4)\n output[4 + lenR] = 0x02\n output[5 + lenR] = s.length\n output.set(s, 6 + lenR)\n\n return 0\n },\n\n // Copied 1-to-1 from https://github.com/bitcoinjs/bip66/blob/master/index.js\n // Adapted for Uint8Array instead Buffer\n signatureImport (output, sig) {\n if (sig.length < 8) return 1\n if (sig.length > 72) return 1\n if (sig[0] !== 0x30) return 1\n if (sig[1] !== sig.length - 2) return 1\n if (sig[2] !== 0x02) return 1\n\n const lenR = sig[3]\n if (lenR === 0) return 1\n if (5 + lenR >= sig.length) return 1\n if (sig[4 + lenR] !== 0x02) return 1\n\n const lenS = sig[5 + lenR]\n if (lenS === 0) return 1\n if ((6 + lenR + lenS) !== sig.length) return 1\n\n if (sig[4] & 0x80) return 1\n if (lenR > 1 && (sig[4] === 0x00) && !(sig[5] & 0x80)) return 1\n\n if (sig[lenR + 6] & 0x80) return 1\n if (lenS > 1 && (sig[lenR + 6] === 0x00) && !(sig[lenR + 7] & 0x80)) return 1\n\n let sigR = sig.subarray(4, 4 + lenR)\n if (sigR.length === 33 && sigR[0] === 0x00) sigR = sigR.subarray(1)\n if (sigR.length > 32) return 1\n\n let sigS = sig.subarray(6 + lenR)\n if (sigS.length === 33 && sigS[0] === 0x00) sigS = sigS.slice(1)\n if (sigS.length > 32) throw new Error('S length is too long')\n\n let r = new BN(sigR)\n if (r.cmp(ecparams.n) >= 0) r = new BN(0)\n\n let s = new BN(sig.subarray(6 + lenR))\n if (s.cmp(ecparams.n) >= 0) s = new BN(0)\n\n output.set(r.toArrayLike(Uint8Array, 'be', 32), 0)\n output.set(s.toArrayLike(Uint8Array, 'be', 32), 32)\n\n return 0\n },\n\n ecdsaSign (obj, message, seckey, data, noncefn) {\n if (noncefn) {\n const _noncefn = noncefn\n noncefn = (counter) => {\n const nonce = _noncefn(message, seckey, null, data, counter)\n\n const isValid = nonce instanceof Uint8Array && nonce.length === 32\n if (!isValid) throw new Error('This is the way')\n\n return new BN(nonce)\n }\n }\n\n const d = new BN(seckey)\n if (d.cmp(ecparams.n) >= 0 || d.isZero()) return 1\n\n let sig\n try {\n sig = ec.sign(message, seckey, { canonical: true, k: noncefn, pers: data })\n } catch (err) {\n return 1\n }\n\n obj.signature.set(sig.r.toArrayLike(Uint8Array, 'be', 32), 0)\n obj.signature.set(sig.s.toArrayLike(Uint8Array, 'be', 32), 32)\n obj.recid = sig.recoveryParam\n\n return 0\n },\n\n ecdsaVerify (sig, msg32, pubkey) {\n const sigObj = { r: sig.subarray(0, 32), s: sig.subarray(32, 64) }\n\n const sigr = new BN(sigObj.r)\n const sigs = new BN(sigObj.s)\n if (sigr.cmp(ecparams.n) >= 0 || sigs.cmp(ecparams.n) >= 0) return 1\n if (sigs.cmp(ec.nh) === 1 || sigr.isZero() || sigs.isZero()) return 3\n\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 2\n\n const point = pair.getPublic()\n const isValid = ec.verify(msg32, sigObj, point)\n return isValid ? 0 : 3\n },\n\n ecdsaRecover (output, sig, recid, msg32) {\n const sigObj = { r: sig.slice(0, 32), s: sig.slice(32, 64) }\n\n const sigr = new BN(sigObj.r)\n const sigs = new BN(sigObj.s)\n if (sigr.cmp(ecparams.n) >= 0 || sigs.cmp(ecparams.n) >= 0) return 1\n\n if (sigr.isZero() || sigs.isZero()) return 2\n\n // Can throw `throw new Error('Unable to find sencond key candinate');`\n let point\n try {\n point = ec.recoverPubKey(msg32, sigObj, recid)\n } catch (err) {\n return 2\n }\n\n savePublicKey(output, point)\n\n return 0\n },\n\n ecdh (output, pubkey, seckey, data, hashfn, xbuf, ybuf) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n const scalar = new BN(seckey)\n if (scalar.cmp(ecparams.n) >= 0 || scalar.isZero()) return 2\n\n const point = pair.getPublic().mul(scalar)\n\n if (hashfn === undefined) {\n const data = point.encode(null, true)\n const sha256 = ec.hash().update(data).digest()\n for (let i = 0; i < 32; ++i) output[i] = sha256[i]\n } else {\n if (!xbuf) xbuf = new Uint8Array(32)\n const x = point.getX().toArray('be', 32)\n for (let i = 0; i < 32; ++i) xbuf[i] = x[i]\n\n if (!ybuf) ybuf = new Uint8Array(32)\n const y = point.getY().toArray('be', 32)\n for (let i = 0; i < 32; ++i) ybuf[i] = y[i]\n\n const hash = hashfn(xbuf, ybuf, data)\n\n const isValid = hash instanceof Uint8Array && hash.length === output.length\n if (!isValid) return 2\n\n output.set(hash)\n }\n\n return 0\n }\n}\n","'use strict';\n\nvar elliptic = exports;\n\nelliptic.version = require('../package.json').version;\nelliptic.utils = require('./elliptic/utils');\nelliptic.rand = require('brorand');\nelliptic.curve = require('./elliptic/curve');\nelliptic.curves = require('./elliptic/curves');\n\n// Protocols\nelliptic.ec = require('./elliptic/ec');\nelliptic.eddsa = require('./elliptic/eddsa');\n","{\n \"name\": \"elliptic\",\n \"version\": \"6.5.4\",\n \"description\": \"EC cryptography\",\n \"main\": \"lib/elliptic.js\",\n \"files\": [\n \"lib\"\n ],\n \"scripts\": {\n \"lint\": \"eslint lib test\",\n \"lint:fix\": \"npm run lint -- --fix\",\n \"unit\": \"istanbul test _mocha --reporter=spec test/index.js\",\n \"test\": \"npm run lint && npm run unit\",\n \"version\": \"grunt dist && git add dist/\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git@github.com:indutny/elliptic\"\n },\n \"keywords\": [\n \"EC\",\n \"Elliptic\",\n \"curve\",\n \"Cryptography\"\n ],\n \"author\": \"Fedor Indutny <fedor@indutny.com>\",\n \"license\": \"MIT\",\n \"bugs\": {\n \"url\": \"https://github.com/indutny/elliptic/issues\"\n },\n \"homepage\": \"https://github.com/indutny/elliptic\",\n \"devDependencies\": {\n \"brfs\": \"^2.0.2\",\n \"coveralls\": \"^3.1.0\",\n \"eslint\": \"^7.6.0\",\n \"grunt\": \"^1.2.1\",\n \"grunt-browserify\": \"^5.3.0\",\n \"grunt-cli\": \"^1.3.2\",\n \"grunt-contrib-connect\": \"^3.0.0\",\n \"grunt-contrib-copy\": \"^1.0.0\",\n \"grunt-contrib-uglify\": \"^5.0.0\",\n \"grunt-mocha-istanbul\": \"^5.0.2\",\n \"grunt-saucelabs\": \"^9.0.1\",\n \"istanbul\": \"^0.4.5\",\n \"mocha\": \"^8.0.1\"\n },\n \"dependencies\": {\n \"bn.js\": \"^4.11.9\",\n \"brorand\": \"^1.1.0\",\n \"hash.js\": \"^1.0.0\",\n \"hmac-drbg\": \"^1.0.1\",\n \"inherits\": \"^2.0.4\",\n \"minimalistic-assert\": \"^1.0.1\",\n \"minimalistic-crypto-utils\": \"^1.0.1\"\n }\n}\n","'use strict';\n\nvar utils = exports;\nvar BN = require('bn.js');\nvar minAssert = require('minimalistic-assert');\nvar minUtils = require('minimalistic-crypto-utils');\n\nutils.assert = minAssert;\nutils.toArray = minUtils.toArray;\nutils.zero2 = minUtils.zero2;\nutils.toHex = minUtils.toHex;\nutils.encode = minUtils.encode;\n\n// Represent num in a w-NAF form\nfunction getNAF(num, w, bits) {\n var naf = new Array(Math.max(num.bitLength(), bits) + 1);\n naf.fill(0);\n\n var ws = 1 << (w + 1);\n var k = num.clone();\n\n for (var i = 0; i < naf.length; i++) {\n var z;\n var mod = k.andln(ws - 1);\n if (k.isOdd()) {\n if (mod > (ws >> 1) - 1)\n z = (ws >> 1) - mod;\n else\n z = mod;\n k.isubn(z);\n } else {\n z = 0;\n }\n\n naf[i] = z;\n k.iushrn(1);\n }\n\n return naf;\n}\nutils.getNAF = getNAF;\n\n// Represent k1, k2 in a Joint Sparse Form\nfunction getJSF(k1, k2) {\n var jsf = [\n [],\n [],\n ];\n\n k1 = k1.clone();\n k2 = k2.clone();\n var d1 = 0;\n var d2 = 0;\n var m8;\n while (k1.cmpn(-d1) > 0 || k2.cmpn(-d2) > 0) {\n // First phase\n var m14 = (k1.andln(3) + d1) & 3;\n var m24 = (k2.andln(3) + d2) & 3;\n if (m14 === 3)\n m14 = -1;\n if (m24 === 3)\n m24 = -1;\n var u1;\n if ((m14 & 1) === 0) {\n u1 = 0;\n } else {\n m8 = (k1.andln(7) + d1) & 7;\n if ((m8 === 3 || m8 === 5) && m24 === 2)\n u1 = -m14;\n else\n u1 = m14;\n }\n jsf[0].push(u1);\n\n var u2;\n if ((m24 & 1) === 0) {\n u2 = 0;\n } else {\n m8 = (k2.andln(7) + d2) & 7;\n if ((m8 === 3 || m8 === 5) && m14 === 2)\n u2 = -m24;\n else\n u2 = m24;\n }\n jsf[1].push(u2);\n\n // Second phase\n if (2 * d1 === u1 + 1)\n d1 = 1 - d1;\n if (2 * d2 === u2 + 1)\n d2 = 1 - d2;\n k1.iushrn(1);\n k2.iushrn(1);\n }\n\n return jsf;\n}\nutils.getJSF = getJSF;\n\nfunction cachedProperty(obj, name, computer) {\n var key = '_' + name;\n obj.prototype[name] = function cachedProperty() {\n return this[key] !== undefined ? this[key] :\n this[key] = computer.call(this);\n };\n}\nutils.cachedProperty = cachedProperty;\n\nfunction parseBytes(bytes) {\n return typeof bytes === 'string' ? utils.toArray(bytes, 'hex') :\n bytes;\n}\nutils.parseBytes = parseBytes;\n\nfunction intFromLE(bytes) {\n return new BN(bytes, 'hex', 'le');\n}\nutils.intFromLE = intFromLE;\n\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '<BN-R: ' : '<BN: ') + this.toString(16) + '>';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","module.exports = assert;\n\nfunction assert(val, msg) {\n if (!val)\n throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n if (l != r)\n throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n","'use strict';\n\nvar utils = exports;\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg !== 'string') {\n for (var i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n return res;\n }\n if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (var i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n } else {\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n var hi = c >> 8;\n var lo = c & 0xff;\n if (hi)\n res.push(hi, lo);\n else\n res.push(lo);\n }\n }\n return res;\n}\nutils.toArray = toArray;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nutils.zero2 = zero2;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nutils.toHex = toHex;\n\nutils.encode = function encode(arr, enc) {\n if (enc === 'hex')\n return toHex(arr);\n else\n return arr;\n};\n","var r;\n\nmodule.exports = function rand(len) {\n if (!r)\n r = new Rand(null);\n\n return r.generate(len);\n};\n\nfunction Rand(rand) {\n this.rand = rand;\n}\nmodule.exports.Rand = Rand;\n\nRand.prototype.generate = function generate(len) {\n return this._rand(len);\n};\n\n// Emulate crypto API using randy\nRand.prototype._rand = function _rand(n) {\n if (this.rand.getBytes)\n return this.rand.getBytes(n);\n\n var res = new Uint8Array(n);\n for (var i = 0; i < res.length; i++)\n res[i] = this.rand.getByte();\n return res;\n};\n\nif (typeof self === 'object') {\n if (self.crypto && self.crypto.getRandomValues) {\n // Modern browsers\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.crypto.getRandomValues(arr);\n return arr;\n };\n } else if (self.msCrypto && self.msCrypto.getRandomValues) {\n // IE\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.msCrypto.getRandomValues(arr);\n return arr;\n };\n\n // Safari's WebWorkers do not have `crypto`\n } else if (typeof window === 'object') {\n // Old junk\n Rand.prototype._rand = function() {\n throw new Error('Not implemented yet');\n };\n }\n} else {\n // Node.js or Web worker with no crypto support\n try {\n var crypto = require('crypto');\n if (typeof crypto.randomBytes !== 'function')\n throw new Error('Not supported');\n\n Rand.prototype._rand = function _rand(n) {\n return crypto.randomBytes(n);\n };\n } catch (e) {\n }\n}\n","'use strict';\n\nvar curve = exports;\n\ncurve.base = require('./base');\ncurve.short = require('./short');\ncurve.mont = require('./mont');\ncurve.edwards = require('./edwards');\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar getNAF = utils.getNAF;\nvar getJSF = utils.getJSF;\nvar assert = utils.assert;\n\nfunction BaseCurve(type, conf) {\n this.type = type;\n this.p = new BN(conf.p, 16);\n\n // Use Montgomery, when there is no fast reduction for the prime\n this.red = conf.prime ? BN.red(conf.prime) : BN.mont(this.p);\n\n // Useful for many curves\n this.zero = new BN(0).toRed(this.red);\n this.one = new BN(1).toRed(this.red);\n this.two = new BN(2).toRed(this.red);\n\n // Curve configuration, optional\n this.n = conf.n && new BN(conf.n, 16);\n this.g = conf.g && this.pointFromJSON(conf.g, conf.gRed);\n\n // Temporary arrays\n this._wnafT1 = new Array(4);\n this._wnafT2 = new Array(4);\n this._wnafT3 = new Array(4);\n this._wnafT4 = new Array(4);\n\n this._bitLength = this.n ? this.n.bitLength() : 0;\n\n // Generalized Greg Maxwell's trick\n var adjustCount = this.n && this.p.div(this.n);\n if (!adjustCount || adjustCount.cmpn(100) > 0) {\n this.redN = null;\n } else {\n this._maxwellTrick = true;\n this.redN = this.n.toRed(this.red);\n }\n}\nmodule.exports = BaseCurve;\n\nBaseCurve.prototype.point = function point() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype.validate = function validate() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype._fixedNafMul = function _fixedNafMul(p, k) {\n assert(p.precomputed);\n var doubles = p._getDoubles();\n\n var naf = getNAF(k, 1, this._bitLength);\n var I = (1 << (doubles.step + 1)) - (doubles.step % 2 === 0 ? 2 : 1);\n I /= 3;\n\n // Translate into more windowed form\n var repr = [];\n var j;\n var nafW;\n for (j = 0; j < naf.length; j += doubles.step) {\n nafW = 0;\n for (var l = j + doubles.step - 1; l >= j; l--)\n nafW = (nafW << 1) + naf[l];\n repr.push(nafW);\n }\n\n var a = this.jpoint(null, null, null);\n var b = this.jpoint(null, null, null);\n for (var i = I; i > 0; i--) {\n for (j = 0; j < repr.length; j++) {\n nafW = repr[j];\n if (nafW === i)\n b = b.mixedAdd(doubles.points[j]);\n else if (nafW === -i)\n b = b.mixedAdd(doubles.points[j].neg());\n }\n a = a.add(b);\n }\n return a.toP();\n};\n\nBaseCurve.prototype._wnafMul = function _wnafMul(p, k) {\n var w = 4;\n\n // Precompute window\n var nafPoints = p._getNAFPoints(w);\n w = nafPoints.wnd;\n var wnd = nafPoints.points;\n\n // Get NAF form\n var naf = getNAF(k, w, this._bitLength);\n\n // Add `this`*(N+1) for every w-NAF index\n var acc = this.jpoint(null, null, null);\n for (var i = naf.length - 1; i >= 0; i--) {\n // Count zeroes\n for (var l = 0; i >= 0 && naf[i] === 0; i--)\n l++;\n if (i >= 0)\n l++;\n acc = acc.dblp(l);\n\n if (i < 0)\n break;\n var z = naf[i];\n assert(z !== 0);\n if (p.type === 'affine') {\n // J +- P\n if (z > 0)\n acc = acc.mixedAdd(wnd[(z - 1) >> 1]);\n else\n acc = acc.mixedAdd(wnd[(-z - 1) >> 1].neg());\n } else {\n // J +- J\n if (z > 0)\n acc = acc.add(wnd[(z - 1) >> 1]);\n else\n acc = acc.add(wnd[(-z - 1) >> 1].neg());\n }\n }\n return p.type === 'affine' ? acc.toP() : acc;\n};\n\nBaseCurve.prototype._wnafMulAdd = function _wnafMulAdd(defW,\n points,\n coeffs,\n len,\n jacobianResult) {\n var wndWidth = this._wnafT1;\n var wnd = this._wnafT2;\n var naf = this._wnafT3;\n\n // Fill all arrays\n var max = 0;\n var i;\n var j;\n var p;\n for (i = 0; i < len; i++) {\n p = points[i];\n var nafPoints = p._getNAFPoints(defW);\n wndWidth[i] = nafPoints.wnd;\n wnd[i] = nafPoints.points;\n }\n\n // Comb small window NAFs\n for (i = len - 1; i >= 1; i -= 2) {\n var a = i - 1;\n var b = i;\n if (wndWidth[a] !== 1 || wndWidth[b] !== 1) {\n naf[a] = getNAF(coeffs[a], wndWidth[a], this._bitLength);\n naf[b] = getNAF(coeffs[b], wndWidth[b], this._bitLength);\n max = Math.max(naf[a].length, max);\n max = Math.max(naf[b].length, max);\n continue;\n }\n\n var comb = [\n points[a], /* 1 */\n null, /* 3 */\n null, /* 5 */\n points[b], /* 7 */\n ];\n\n // Try to avoid Projective points, if possible\n if (points[a].y.cmp(points[b].y) === 0) {\n comb[1] = points[a].add(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n } else if (points[a].y.cmp(points[b].y.redNeg()) === 0) {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].add(points[b].neg());\n } else {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n }\n\n var index = [\n -3, /* -1 -1 */\n -1, /* -1 0 */\n -5, /* -1 1 */\n -7, /* 0 -1 */\n 0, /* 0 0 */\n 7, /* 0 1 */\n 5, /* 1 -1 */\n 1, /* 1 0 */\n 3, /* 1 1 */\n ];\n\n var jsf = getJSF(coeffs[a], coeffs[b]);\n max = Math.max(jsf[0].length, max);\n naf[a] = new Array(max);\n naf[b] = new Array(max);\n for (j = 0; j < max; j++) {\n var ja = jsf[0][j] | 0;\n var jb = jsf[1][j] | 0;\n\n naf[a][j] = index[(ja + 1) * 3 + (jb + 1)];\n naf[b][j] = 0;\n wnd[a] = comb;\n }\n }\n\n var acc = this.jpoint(null, null, null);\n var tmp = this._wnafT4;\n for (i = max; i >= 0; i--) {\n var k = 0;\n\n while (i >= 0) {\n var zero = true;\n for (j = 0; j < len; j++) {\n tmp[j] = naf[j][i] | 0;\n if (tmp[j] !== 0)\n zero = false;\n }\n if (!zero)\n break;\n k++;\n i--;\n }\n if (i >= 0)\n k++;\n acc = acc.dblp(k);\n if (i < 0)\n break;\n\n for (j = 0; j < len; j++) {\n var z = tmp[j];\n p;\n if (z === 0)\n continue;\n else if (z > 0)\n p = wnd[j][(z - 1) >> 1];\n else if (z < 0)\n p = wnd[j][(-z - 1) >> 1].neg();\n\n if (p.type === 'affine')\n acc = acc.mixedAdd(p);\n else\n acc = acc.add(p);\n }\n }\n // Zeroify references\n for (i = 0; i < len; i++)\n wnd[i] = null;\n\n if (jacobianResult)\n return acc;\n else\n return acc.toP();\n};\n\nfunction BasePoint(curve, type) {\n this.curve = curve;\n this.type = type;\n this.precomputed = null;\n}\nBaseCurve.BasePoint = BasePoint;\n\nBasePoint.prototype.eq = function eq(/*other*/) {\n throw new Error('Not implemented');\n};\n\nBasePoint.prototype.validate = function validate() {\n return this.curve.validate(this);\n};\n\nBaseCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n bytes = utils.toArray(bytes, enc);\n\n var len = this.p.byteLength();\n\n // uncompressed, hybrid-odd, hybrid-even\n if ((bytes[0] === 0x04 || bytes[0] === 0x06 || bytes[0] === 0x07) &&\n bytes.length - 1 === 2 * len) {\n if (bytes[0] === 0x06)\n assert(bytes[bytes.length - 1] % 2 === 0);\n else if (bytes[0] === 0x07)\n assert(bytes[bytes.length - 1] % 2 === 1);\n\n var res = this.point(bytes.slice(1, 1 + len),\n bytes.slice(1 + len, 1 + 2 * len));\n\n return res;\n } else if ((bytes[0] === 0x02 || bytes[0] === 0x03) &&\n bytes.length - 1 === len) {\n return this.pointFromX(bytes.slice(1, 1 + len), bytes[0] === 0x03);\n }\n throw new Error('Unknown point format');\n};\n\nBasePoint.prototype.encodeCompressed = function encodeCompressed(enc) {\n return this.encode(enc, true);\n};\n\nBasePoint.prototype._encode = function _encode(compact) {\n var len = this.curve.p.byteLength();\n var x = this.getX().toArray('be', len);\n\n if (compact)\n return [ this.getY().isEven() ? 0x02 : 0x03 ].concat(x);\n\n return [ 0x04 ].concat(x, this.getY().toArray('be', len));\n};\n\nBasePoint.prototype.encode = function encode(enc, compact) {\n return utils.encode(this._encode(compact), enc);\n};\n\nBasePoint.prototype.precompute = function precompute(power) {\n if (this.precomputed)\n return this;\n\n var precomputed = {\n doubles: null,\n naf: null,\n beta: null,\n };\n precomputed.naf = this._getNAFPoints(8);\n precomputed.doubles = this._getDoubles(4, power);\n precomputed.beta = this._getBeta();\n this.precomputed = precomputed;\n\n return this;\n};\n\nBasePoint.prototype._hasDoubles = function _hasDoubles(k) {\n if (!this.precomputed)\n return false;\n\n var doubles = this.precomputed.doubles;\n if (!doubles)\n return false;\n\n return doubles.points.length >= Math.ceil((k.bitLength() + 1) / doubles.step);\n};\n\nBasePoint.prototype._getDoubles = function _getDoubles(step, power) {\n if (this.precomputed && this.precomputed.doubles)\n return this.precomputed.doubles;\n\n var doubles = [ this ];\n var acc = this;\n for (var i = 0; i < power; i += step) {\n for (var j = 0; j < step; j++)\n acc = acc.dbl();\n doubles.push(acc);\n }\n return {\n step: step,\n points: doubles,\n };\n};\n\nBasePoint.prototype._getNAFPoints = function _getNAFPoints(wnd) {\n if (this.precomputed && this.precomputed.naf)\n return this.precomputed.naf;\n\n var res = [ this ];\n var max = (1 << wnd) - 1;\n var dbl = max === 1 ? null : this.dbl();\n for (var i = 1; i < max; i++)\n res[i] = res[i - 1].add(dbl);\n return {\n wnd: wnd,\n points: res,\n };\n};\n\nBasePoint.prototype._getBeta = function _getBeta() {\n return null;\n};\n\nBasePoint.prototype.dblp = function dblp(k) {\n var r = this;\n for (var i = 0; i < k; i++)\n r = r.dbl();\n return r;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction ShortCurve(conf) {\n Base.call(this, 'short', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.tinv = this.two.redInvm();\n\n this.zeroA = this.a.fromRed().cmpn(0) === 0;\n this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0;\n\n // If the curve is endomorphic, precalculate beta and lambda\n this.endo = this._getEndomorphism(conf);\n this._endoWnafT1 = new Array(4);\n this._endoWnafT2 = new Array(4);\n}\ninherits(ShortCurve, Base);\nmodule.exports = ShortCurve;\n\nShortCurve.prototype._getEndomorphism = function _getEndomorphism(conf) {\n // No efficient endomorphism\n if (!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1)\n return;\n\n // Compute beta and lambda, that lambda * P = (beta * Px; Py)\n var beta;\n var lambda;\n if (conf.beta) {\n beta = new BN(conf.beta, 16).toRed(this.red);\n } else {\n var betas = this._getEndoRoots(this.p);\n // Choose the smallest beta\n beta = betas[0].cmp(betas[1]) < 0 ? betas[0] : betas[1];\n beta = beta.toRed(this.red);\n }\n if (conf.lambda) {\n lambda = new BN(conf.lambda, 16);\n } else {\n // Choose the lambda that is matching selected beta\n var lambdas = this._getEndoRoots(this.n);\n if (this.g.mul(lambdas[0]).x.cmp(this.g.x.redMul(beta)) === 0) {\n lambda = lambdas[0];\n } else {\n lambda = lambdas[1];\n assert(this.g.mul(lambda).x.cmp(this.g.x.redMul(beta)) === 0);\n }\n }\n\n // Get basis vectors, used for balanced length-two representation\n var basis;\n if (conf.basis) {\n basis = conf.basis.map(function(vec) {\n return {\n a: new BN(vec.a, 16),\n b: new BN(vec.b, 16),\n };\n });\n } else {\n basis = this._getEndoBasis(lambda);\n }\n\n return {\n beta: beta,\n lambda: lambda,\n basis: basis,\n };\n};\n\nShortCurve.prototype._getEndoRoots = function _getEndoRoots(num) {\n // Find roots of for x^2 + x + 1 in F\n // Root = (-1 +- Sqrt(-3)) / 2\n //\n var red = num === this.p ? this.red : BN.mont(num);\n var tinv = new BN(2).toRed(red).redInvm();\n var ntinv = tinv.redNeg();\n\n var s = new BN(3).toRed(red).redNeg().redSqrt().redMul(tinv);\n\n var l1 = ntinv.redAdd(s).fromRed();\n var l2 = ntinv.redSub(s).fromRed();\n return [ l1, l2 ];\n};\n\nShortCurve.prototype._getEndoBasis = function _getEndoBasis(lambda) {\n // aprxSqrt >= sqrt(this.n)\n var aprxSqrt = this.n.ushrn(Math.floor(this.n.bitLength() / 2));\n\n // 3.74\n // Run EGCD, until r(L + 1) < aprxSqrt\n var u = lambda;\n var v = this.n.clone();\n var x1 = new BN(1);\n var y1 = new BN(0);\n var x2 = new BN(0);\n var y2 = new BN(1);\n\n // NOTE: all vectors are roots of: a + b * lambda = 0 (mod n)\n var a0;\n var b0;\n // First vector\n var a1;\n var b1;\n // Second vector\n var a2;\n var b2;\n\n var prevR;\n var i = 0;\n var r;\n var x;\n while (u.cmpn(0) !== 0) {\n var q = v.div(u);\n r = v.sub(q.mul(u));\n x = x2.sub(q.mul(x1));\n var y = y2.sub(q.mul(y1));\n\n if (!a1 && r.cmp(aprxSqrt) < 0) {\n a0 = prevR.neg();\n b0 = x1;\n a1 = r.neg();\n b1 = x;\n } else if (a1 && ++i === 2) {\n break;\n }\n prevR = r;\n\n v = u;\n u = r;\n x2 = x1;\n x1 = x;\n y2 = y1;\n y1 = y;\n }\n a2 = r.neg();\n b2 = x;\n\n var len1 = a1.sqr().add(b1.sqr());\n var len2 = a2.sqr().add(b2.sqr());\n if (len2.cmp(len1) >= 0) {\n a2 = a0;\n b2 = b0;\n }\n\n // Normalize signs\n if (a1.negative) {\n a1 = a1.neg();\n b1 = b1.neg();\n }\n if (a2.negative) {\n a2 = a2.neg();\n b2 = b2.neg();\n }\n\n return [\n { a: a1, b: b1 },\n { a: a2, b: b2 },\n ];\n};\n\nShortCurve.prototype._endoSplit = function _endoSplit(k) {\n var basis = this.endo.basis;\n var v1 = basis[0];\n var v2 = basis[1];\n\n var c1 = v2.b.mul(k).divRound(this.n);\n var c2 = v1.b.neg().mul(k).divRound(this.n);\n\n var p1 = c1.mul(v1.a);\n var p2 = c2.mul(v2.a);\n var q1 = c1.mul(v1.b);\n var q2 = c2.mul(v2.b);\n\n // Calculate answer\n var k1 = k.sub(p1).sub(p2);\n var k2 = q1.add(q2).neg();\n return { k1: k1, k2: k2 };\n};\n\nShortCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var y2 = x.redSqr().redMul(x).redIAdd(x.redMul(this.a)).redIAdd(this.b);\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n // XXX Is there any way to tell if the number is odd without converting it\n // to non-red form?\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nShortCurve.prototype.validate = function validate(point) {\n if (point.inf)\n return true;\n\n var x = point.x;\n var y = point.y;\n\n var ax = this.a.redMul(x);\n var rhs = x.redSqr().redMul(x).redIAdd(ax).redIAdd(this.b);\n return y.redSqr().redISub(rhs).cmpn(0) === 0;\n};\n\nShortCurve.prototype._endoWnafMulAdd =\n function _endoWnafMulAdd(points, coeffs, jacobianResult) {\n var npoints = this._endoWnafT1;\n var ncoeffs = this._endoWnafT2;\n for (var i = 0; i < points.length; i++) {\n var split = this._endoSplit(coeffs[i]);\n var p = points[i];\n var beta = p._getBeta();\n\n if (split.k1.negative) {\n split.k1.ineg();\n p = p.neg(true);\n }\n if (split.k2.negative) {\n split.k2.ineg();\n beta = beta.neg(true);\n }\n\n npoints[i * 2] = p;\n npoints[i * 2 + 1] = beta;\n ncoeffs[i * 2] = split.k1;\n ncoeffs[i * 2 + 1] = split.k2;\n }\n var res = this._wnafMulAdd(1, npoints, ncoeffs, i * 2, jacobianResult);\n\n // Clean-up references to points and coefficients\n for (var j = 0; j < i * 2; j++) {\n npoints[j] = null;\n ncoeffs[j] = null;\n }\n return res;\n };\n\nfunction Point(curve, x, y, isRed) {\n Base.BasePoint.call(this, curve, 'affine');\n if (x === null && y === null) {\n this.x = null;\n this.y = null;\n this.inf = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n // Force redgomery representation when loading from JSON\n if (isRed) {\n this.x.forceRed(this.curve.red);\n this.y.forceRed(this.curve.red);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n this.inf = false;\n }\n}\ninherits(Point, Base.BasePoint);\n\nShortCurve.prototype.point = function point(x, y, isRed) {\n return new Point(this, x, y, isRed);\n};\n\nShortCurve.prototype.pointFromJSON = function pointFromJSON(obj, red) {\n return Point.fromJSON(this, obj, red);\n};\n\nPoint.prototype._getBeta = function _getBeta() {\n if (!this.curve.endo)\n return;\n\n var pre = this.precomputed;\n if (pre && pre.beta)\n return pre.beta;\n\n var beta = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y);\n if (pre) {\n var curve = this.curve;\n var endoMul = function(p) {\n return curve.point(p.x.redMul(curve.endo.beta), p.y);\n };\n pre.beta = beta;\n beta.precomputed = {\n beta: null,\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(endoMul),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(endoMul),\n },\n };\n }\n return beta;\n};\n\nPoint.prototype.toJSON = function toJSON() {\n if (!this.precomputed)\n return [ this.x, this.y ];\n\n return [ this.x, this.y, this.precomputed && {\n doubles: this.precomputed.doubles && {\n step: this.precomputed.doubles.step,\n points: this.precomputed.doubles.points.slice(1),\n },\n naf: this.precomputed.naf && {\n wnd: this.precomputed.naf.wnd,\n points: this.precomputed.naf.points.slice(1),\n },\n } ];\n};\n\nPoint.fromJSON = function fromJSON(curve, obj, red) {\n if (typeof obj === 'string')\n obj = JSON.parse(obj);\n var res = curve.point(obj[0], obj[1], red);\n if (!obj[2])\n return res;\n\n function obj2point(obj) {\n return curve.point(obj[0], obj[1], red);\n }\n\n var pre = obj[2];\n res.precomputed = {\n beta: null,\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: [ res ].concat(pre.doubles.points.map(obj2point)),\n },\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: [ res ].concat(pre.naf.points.map(obj2point)),\n },\n };\n return res;\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '<EC Point Infinity>';\n return '<EC Point x: ' + this.x.fromRed().toString(16, 2) +\n ' y: ' + this.y.fromRed().toString(16, 2) + '>';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n return this.inf;\n};\n\nPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.inf)\n return p;\n\n // P + O = P\n if (p.inf)\n return this;\n\n // P + P = 2P\n if (this.eq(p))\n return this.dbl();\n\n // P + (-P) = O\n if (this.neg().eq(p))\n return this.curve.point(null, null);\n\n // P + Q = O\n if (this.x.cmp(p.x) === 0)\n return this.curve.point(null, null);\n\n var c = this.y.redSub(p.y);\n if (c.cmpn(0) !== 0)\n c = c.redMul(this.x.redSub(p.x).redInvm());\n var nx = c.redSqr().redISub(this.x).redISub(p.x);\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.inf)\n return this;\n\n // 2P = O\n var ys1 = this.y.redAdd(this.y);\n if (ys1.cmpn(0) === 0)\n return this.curve.point(null, null);\n\n var a = this.curve.a;\n\n var x2 = this.x.redSqr();\n var dyinv = ys1.redInvm();\n var c = x2.redAdd(x2).redIAdd(x2).redIAdd(a).redMul(dyinv);\n\n var nx = c.redSqr().redISub(this.x.redAdd(this.x));\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.getX = function getX() {\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n return this.y.fromRed();\n};\n\nPoint.prototype.mul = function mul(k) {\n k = new BN(k, 16);\n if (this.isInfinity())\n return this;\n else if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else if (this.curve.endo)\n return this.curve._endoWnafMulAdd([ this ], [ k ]);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs, true);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2, true);\n};\n\nPoint.prototype.eq = function eq(p) {\n return this === p ||\n this.inf === p.inf &&\n (this.inf || this.x.cmp(p.x) === 0 && this.y.cmp(p.y) === 0);\n};\n\nPoint.prototype.neg = function neg(_precompute) {\n if (this.inf)\n return this;\n\n var res = this.curve.point(this.x, this.y.redNeg());\n if (_precompute && this.precomputed) {\n var pre = this.precomputed;\n var negate = function(p) {\n return p.neg();\n };\n res.precomputed = {\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(negate),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(negate),\n },\n };\n }\n return res;\n};\n\nPoint.prototype.toJ = function toJ() {\n if (this.inf)\n return this.curve.jpoint(null, null, null);\n\n var res = this.curve.jpoint(this.x, this.y, this.curve.one);\n return res;\n};\n\nfunction JPoint(curve, x, y, z) {\n Base.BasePoint.call(this, curve, 'jacobian');\n if (x === null && y === null && z === null) {\n this.x = this.curve.one;\n this.y = this.curve.one;\n this.z = new BN(0);\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = new BN(z, 16);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n\n this.zOne = this.z === this.curve.one;\n}\ninherits(JPoint, Base.BasePoint);\n\nShortCurve.prototype.jpoint = function jpoint(x, y, z) {\n return new JPoint(this, x, y, z);\n};\n\nJPoint.prototype.toP = function toP() {\n if (this.isInfinity())\n return this.curve.point(null, null);\n\n var zinv = this.z.redInvm();\n var zinv2 = zinv.redSqr();\n var ax = this.x.redMul(zinv2);\n var ay = this.y.redMul(zinv2).redMul(zinv);\n\n return this.curve.point(ax, ay);\n};\n\nJPoint.prototype.neg = function neg() {\n return this.curve.jpoint(this.x, this.y.redNeg(), this.z);\n};\n\nJPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.isInfinity())\n return p;\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 12M + 4S + 7A\n var pz2 = p.z.redSqr();\n var z2 = this.z.redSqr();\n var u1 = this.x.redMul(pz2);\n var u2 = p.x.redMul(z2);\n var s1 = this.y.redMul(pz2.redMul(p.z));\n var s2 = p.y.redMul(z2.redMul(this.z));\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(p.z).redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mixedAdd = function mixedAdd(p) {\n // O + P = P\n if (this.isInfinity())\n return p.toJ();\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 8M + 3S + 7A\n var z2 = this.z.redSqr();\n var u1 = this.x;\n var u2 = p.x.redMul(z2);\n var s1 = this.y;\n var s2 = p.y.redMul(z2).redMul(this.z);\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.dblp = function dblp(pow) {\n if (pow === 0)\n return this;\n if (this.isInfinity())\n return this;\n if (!pow)\n return this.dbl();\n\n var i;\n if (this.curve.zeroA || this.curve.threeA) {\n var r = this;\n for (i = 0; i < pow; i++)\n r = r.dbl();\n return r;\n }\n\n // 1M + 2S + 1A + N * (4S + 5M + 8A)\n // N = 1 => 6M + 6S + 9A\n var a = this.curve.a;\n var tinv = this.curve.tinv;\n\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n // Reuse results\n var jyd = jy.redAdd(jy);\n for (i = 0; i < pow; i++) {\n var jx2 = jx.redSqr();\n var jyd2 = jyd.redSqr();\n var jyd4 = jyd2.redSqr();\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var t1 = jx.redMul(jyd2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n var dny = c.redMul(t2);\n dny = dny.redIAdd(dny).redISub(jyd4);\n var nz = jyd.redMul(jz);\n if (i + 1 < pow)\n jz4 = jz4.redMul(jyd4);\n\n jx = nx;\n jz = nz;\n jyd = dny;\n }\n\n return this.curve.jpoint(jx, jyd.redMul(tinv), jz);\n};\n\nJPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n if (this.curve.zeroA)\n return this._zeroDbl();\n else if (this.curve.threeA)\n return this._threeDbl();\n else\n return this._dbl();\n};\n\nJPoint.prototype._zeroDbl = function _zeroDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 14A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // T = M ^ 2 - 2*S\n var t = m.redSqr().redISub(s).redISub(s);\n\n // 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2*Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-dbl-2009-l\n // 2M + 5S + 13A\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = B^2\n var c = b.redSqr();\n // D = 2 * ((X1 + B)^2 - A - C)\n var d = this.x.redAdd(b).redSqr().redISub(a).redISub(c);\n d = d.redIAdd(d);\n // E = 3 * A\n var e = a.redAdd(a).redIAdd(a);\n // F = E^2\n var f = e.redSqr();\n\n // 8 * C\n var c8 = c.redIAdd(c);\n c8 = c8.redIAdd(c8);\n c8 = c8.redIAdd(c8);\n\n // X3 = F - 2 * D\n nx = f.redISub(d).redISub(d);\n // Y3 = E * (D - X3) - 8 * C\n ny = e.redMul(d.redISub(nx)).redISub(c8);\n // Z3 = 2 * Y1 * Z1\n nz = this.y.redMul(this.z);\n nz = nz.redIAdd(nz);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._threeDbl = function _threeDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 15A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a\n var m = xx.redAdd(xx).redIAdd(xx).redIAdd(this.curve.a);\n // T = M^2 - 2 * S\n var t = m.redSqr().redISub(s).redISub(s);\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2 * Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html#doubling-dbl-2001-b\n // 3M + 5S\n\n // delta = Z1^2\n var delta = this.z.redSqr();\n // gamma = Y1^2\n var gamma = this.y.redSqr();\n // beta = X1 * gamma\n var beta = this.x.redMul(gamma);\n // alpha = 3 * (X1 - delta) * (X1 + delta)\n var alpha = this.x.redSub(delta).redMul(this.x.redAdd(delta));\n alpha = alpha.redAdd(alpha).redIAdd(alpha);\n // X3 = alpha^2 - 8 * beta\n var beta4 = beta.redIAdd(beta);\n beta4 = beta4.redIAdd(beta4);\n var beta8 = beta4.redAdd(beta4);\n nx = alpha.redSqr().redISub(beta8);\n // Z3 = (Y1 + Z1)^2 - gamma - delta\n nz = this.y.redAdd(this.z).redSqr().redISub(gamma).redISub(delta);\n // Y3 = alpha * (4 * beta - X3) - 8 * gamma^2\n var ggamma8 = gamma.redSqr();\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ny = alpha.redMul(beta4.redISub(nx)).redISub(ggamma8);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._dbl = function _dbl() {\n var a = this.curve.a;\n\n // 4M + 6S + 10A\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n var jx2 = jx.redSqr();\n var jy2 = jy.redSqr();\n\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var jxd4 = jx.redAdd(jx);\n jxd4 = jxd4.redIAdd(jxd4);\n var t1 = jxd4.redMul(jy2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n\n var jyd8 = jy2.redSqr();\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n var ny = c.redMul(t2).redISub(jyd8);\n var nz = jy.redAdd(jy).redMul(jz);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.trpl = function trpl() {\n if (!this.curve.zeroA)\n return this.dbl().add(this);\n\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html#tripling-tpl-2007-bl\n // 5M + 10S + ...\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // ZZ = Z1^2\n var zz = this.z.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // M = 3 * XX + a * ZZ2; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // MM = M^2\n var mm = m.redSqr();\n // E = 6 * ((X1 + YY)^2 - XX - YYYY) - MM\n var e = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n e = e.redIAdd(e);\n e = e.redAdd(e).redIAdd(e);\n e = e.redISub(mm);\n // EE = E^2\n var ee = e.redSqr();\n // T = 16*YYYY\n var t = yyyy.redIAdd(yyyy);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n // U = (M + E)^2 - MM - EE - T\n var u = m.redIAdd(e).redSqr().redISub(mm).redISub(ee).redISub(t);\n // X3 = 4 * (X1 * EE - 4 * YY * U)\n var yyu4 = yy.redMul(u);\n yyu4 = yyu4.redIAdd(yyu4);\n yyu4 = yyu4.redIAdd(yyu4);\n var nx = this.x.redMul(ee).redISub(yyu4);\n nx = nx.redIAdd(nx);\n nx = nx.redIAdd(nx);\n // Y3 = 8 * Y1 * (U * (T - U) - E * EE)\n var ny = this.y.redMul(u.redMul(t.redISub(u)).redISub(e.redMul(ee)));\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n // Z3 = (Z1 + E)^2 - ZZ - EE\n var nz = this.z.redAdd(e).redSqr().redISub(zz).redISub(ee);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mul = function mul(k, kbase) {\n k = new BN(k, kbase);\n\n return this.curve._wnafMul(this, k);\n};\n\nJPoint.prototype.eq = function eq(p) {\n if (p.type === 'affine')\n return this.eq(p.toJ());\n\n if (this === p)\n return true;\n\n // x1 * z2^2 == x2 * z1^2\n var z2 = this.z.redSqr();\n var pz2 = p.z.redSqr();\n if (this.x.redMul(pz2).redISub(p.x.redMul(z2)).cmpn(0) !== 0)\n return false;\n\n // y1 * z2^3 == y2 * z1^3\n var z3 = z2.redMul(this.z);\n var pz3 = pz2.redMul(p.z);\n return this.y.redMul(pz3).redISub(p.y.redMul(z3)).cmpn(0) === 0;\n};\n\nJPoint.prototype.eqXToP = function eqXToP(x) {\n var zs = this.z.redSqr();\n var rx = x.toRed(this.curve.red).redMul(zs);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(zs);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\nJPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '<EC JPoint Infinity>';\n return '<EC JPoint x: ' + this.x.toString(16, 2) +\n ' y: ' + this.y.toString(16, 2) +\n ' z: ' + this.z.toString(16, 2) + '>';\n};\n\nJPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","'use strict';\n\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar utils = require('../utils');\n\nfunction MontCurve(conf) {\n Base.call(this, 'mont', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.i4 = new BN(4).toRed(this.red).redInvm();\n this.two = new BN(2).toRed(this.red);\n this.a24 = this.i4.redMul(this.a.redAdd(this.two));\n}\ninherits(MontCurve, Base);\nmodule.exports = MontCurve;\n\nMontCurve.prototype.validate = function validate(point) {\n var x = point.normalize().x;\n var x2 = x.redSqr();\n var rhs = x2.redMul(x).redAdd(x2.redMul(this.a)).redAdd(x);\n var y = rhs.redSqrt();\n\n return y.redSqr().cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, z) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && z === null) {\n this.x = this.curve.one;\n this.z = this.curve.zero;\n } else {\n this.x = new BN(x, 16);\n this.z = new BN(z, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n }\n}\ninherits(Point, Base.BasePoint);\n\nMontCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n return this.point(utils.toArray(bytes, enc), 1);\n};\n\nMontCurve.prototype.point = function point(x, z) {\n return new Point(this, x, z);\n};\n\nMontCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nPoint.prototype.precompute = function precompute() {\n // No-op\n};\n\nPoint.prototype._encode = function _encode() {\n return this.getX().toArray('be', this.curve.p.byteLength());\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1] || curve.one);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '<EC Point Infinity>';\n return '<EC Point x: ' + this.x.fromRed().toString(16, 2) +\n ' z: ' + this.z.fromRed().toString(16, 2) + '>';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n\nPoint.prototype.dbl = function dbl() {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#doubling-dbl-1987-m-3\n // 2M + 2S + 4A\n\n // A = X1 + Z1\n var a = this.x.redAdd(this.z);\n // AA = A^2\n var aa = a.redSqr();\n // B = X1 - Z1\n var b = this.x.redSub(this.z);\n // BB = B^2\n var bb = b.redSqr();\n // C = AA - BB\n var c = aa.redSub(bb);\n // X3 = AA * BB\n var nx = aa.redMul(bb);\n // Z3 = C * (BB + A24 * C)\n var nz = c.redMul(bb.redAdd(this.curve.a24.redMul(c)));\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.add = function add() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.diffAdd = function diffAdd(p, diff) {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#diffadd-dadd-1987-m-3\n // 4M + 2S + 6A\n\n // A = X2 + Z2\n var a = this.x.redAdd(this.z);\n // B = X2 - Z2\n var b = this.x.redSub(this.z);\n // C = X3 + Z3\n var c = p.x.redAdd(p.z);\n // D = X3 - Z3\n var d = p.x.redSub(p.z);\n // DA = D * A\n var da = d.redMul(a);\n // CB = C * B\n var cb = c.redMul(b);\n // X5 = Z1 * (DA + CB)^2\n var nx = diff.z.redMul(da.redAdd(cb).redSqr());\n // Z5 = X1 * (DA - CB)^2\n var nz = diff.x.redMul(da.redISub(cb).redSqr());\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.mul = function mul(k) {\n var t = k.clone();\n var a = this; // (N / 2) * Q + Q\n var b = this.curve.point(null, null); // (N / 2) * Q\n var c = this; // Q\n\n for (var bits = []; t.cmpn(0) !== 0; t.iushrn(1))\n bits.push(t.andln(1));\n\n for (var i = bits.length - 1; i >= 0; i--) {\n if (bits[i] === 0) {\n // N * Q + Q = ((N / 2) * Q + Q)) + (N / 2) * Q\n a = a.diffAdd(b, c);\n // N * Q = 2 * ((N / 2) * Q + Q))\n b = b.dbl();\n } else {\n // N * Q = ((N / 2) * Q + Q) + ((N / 2) * Q)\n b = a.diffAdd(b, c);\n // N * Q + Q = 2 * ((N / 2) * Q + Q)\n a = a.dbl();\n }\n }\n return b;\n};\n\nPoint.prototype.mulAdd = function mulAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.jumlAdd = function jumlAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.eq = function eq(other) {\n return this.getX().cmp(other.getX()) === 0;\n};\n\nPoint.prototype.normalize = function normalize() {\n this.x = this.x.redMul(this.z.redInvm());\n this.z = this.curve.one;\n return this;\n};\n\nPoint.prototype.getX = function getX() {\n // Normalize coordinates\n this.normalize();\n\n return this.x.fromRed();\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction EdwardsCurve(conf) {\n // NOTE: Important as we are creating point in Base.call()\n this.twisted = (conf.a | 0) !== 1;\n this.mOneA = this.twisted && (conf.a | 0) === -1;\n this.extended = this.mOneA;\n\n Base.call(this, 'edwards', conf);\n\n this.a = new BN(conf.a, 16).umod(this.red.m);\n this.a = this.a.toRed(this.red);\n this.c = new BN(conf.c, 16).toRed(this.red);\n this.c2 = this.c.redSqr();\n this.d = new BN(conf.d, 16).toRed(this.red);\n this.dd = this.d.redAdd(this.d);\n\n assert(!this.twisted || this.c.fromRed().cmpn(1) === 0);\n this.oneC = (conf.c | 0) === 1;\n}\ninherits(EdwardsCurve, Base);\nmodule.exports = EdwardsCurve;\n\nEdwardsCurve.prototype._mulA = function _mulA(num) {\n if (this.mOneA)\n return num.redNeg();\n else\n return this.a.redMul(num);\n};\n\nEdwardsCurve.prototype._mulC = function _mulC(num) {\n if (this.oneC)\n return num;\n else\n return this.c.redMul(num);\n};\n\n// Just for compatibility with Short curve\nEdwardsCurve.prototype.jpoint = function jpoint(x, y, z, t) {\n return this.point(x, y, z, t);\n};\n\nEdwardsCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var x2 = x.redSqr();\n var rhs = this.c2.redSub(this.a.redMul(x2));\n var lhs = this.one.redSub(this.c2.redMul(this.d).redMul(x2));\n\n var y2 = rhs.redMul(lhs.redInvm());\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.pointFromY = function pointFromY(y, odd) {\n y = new BN(y, 16);\n if (!y.red)\n y = y.toRed(this.red);\n\n // x^2 = (y^2 - c^2) / (c^2 d y^2 - a)\n var y2 = y.redSqr();\n var lhs = y2.redSub(this.c2);\n var rhs = y2.redMul(this.d).redMul(this.c2).redSub(this.a);\n var x2 = lhs.redMul(rhs.redInvm());\n\n if (x2.cmp(this.zero) === 0) {\n if (odd)\n throw new Error('invalid point');\n else\n return this.point(this.zero, y);\n }\n\n var x = x2.redSqrt();\n if (x.redSqr().redSub(x2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n if (x.fromRed().isOdd() !== odd)\n x = x.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.validate = function validate(point) {\n if (point.isInfinity())\n return true;\n\n // Curve: A * X^2 + Y^2 = C^2 * (1 + D * X^2 * Y^2)\n point.normalize();\n\n var x2 = point.x.redSqr();\n var y2 = point.y.redSqr();\n var lhs = x2.redMul(this.a).redAdd(y2);\n var rhs = this.c2.redMul(this.one.redAdd(this.d.redMul(x2).redMul(y2)));\n\n return lhs.cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, y, z, t) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && y === null && z === null) {\n this.x = this.curve.zero;\n this.y = this.curve.one;\n this.z = this.curve.one;\n this.t = this.curve.zero;\n this.zOne = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = z ? new BN(z, 16) : this.curve.one;\n this.t = t && new BN(t, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n if (this.t && !this.t.red)\n this.t = this.t.toRed(this.curve.red);\n this.zOne = this.z === this.curve.one;\n\n // Use extended coordinates\n if (this.curve.extended && !this.t) {\n this.t = this.x.redMul(this.y);\n if (!this.zOne)\n this.t = this.t.redMul(this.z.redInvm());\n }\n }\n}\ninherits(Point, Base.BasePoint);\n\nEdwardsCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nEdwardsCurve.prototype.point = function point(x, y, z, t) {\n return new Point(this, x, y, z, t);\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1], obj[2]);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '<EC Point Infinity>';\n return '<EC Point x: ' + this.x.fromRed().toString(16, 2) +\n ' y: ' + this.y.fromRed().toString(16, 2) +\n ' z: ' + this.z.fromRed().toString(16, 2) + '>';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.x.cmpn(0) === 0 &&\n (this.y.cmp(this.z) === 0 ||\n (this.zOne && this.y.cmp(this.curve.c) === 0));\n};\n\nPoint.prototype._extDbl = function _extDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #doubling-dbl-2008-hwcd\n // 4M + 4S\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = 2 * Z1^2\n var c = this.z.redSqr();\n c = c.redIAdd(c);\n // D = a * A\n var d = this.curve._mulA(a);\n // E = (X1 + Y1)^2 - A - B\n var e = this.x.redAdd(this.y).redSqr().redISub(a).redISub(b);\n // G = D + B\n var g = d.redAdd(b);\n // F = G - C\n var f = g.redSub(c);\n // H = D - B\n var h = d.redSub(b);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projDbl = function _projDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #doubling-dbl-2008-bbjlp\n // #doubling-dbl-2007-bl\n // and others\n // Generally 3M + 4S or 2M + 4S\n\n // B = (X1 + Y1)^2\n var b = this.x.redAdd(this.y).redSqr();\n // C = X1^2\n var c = this.x.redSqr();\n // D = Y1^2\n var d = this.y.redSqr();\n\n var nx;\n var ny;\n var nz;\n var e;\n var h;\n var j;\n if (this.curve.twisted) {\n // E = a * C\n e = this.curve._mulA(c);\n // F = E + D\n var f = e.redAdd(d);\n if (this.zOne) {\n // X3 = (B - C - D) * (F - 2)\n nx = b.redSub(c).redSub(d).redMul(f.redSub(this.curve.two));\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F^2 - 2 * F\n nz = f.redSqr().redSub(f).redSub(f);\n } else {\n // H = Z1^2\n h = this.z.redSqr();\n // J = F - 2 * H\n j = f.redSub(h).redISub(h);\n // X3 = (B-C-D)*J\n nx = b.redSub(c).redISub(d).redMul(j);\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F * J\n nz = f.redMul(j);\n }\n } else {\n // E = C + D\n e = c.redAdd(d);\n // H = (c * Z1)^2\n h = this.curve._mulC(this.z).redSqr();\n // J = E - 2 * H\n j = e.redSub(h).redSub(h);\n // X3 = c * (B - E) * J\n nx = this.curve._mulC(b.redISub(e)).redMul(j);\n // Y3 = c * E * (C - D)\n ny = this.curve._mulC(e).redMul(c.redISub(d));\n // Z3 = E * J\n nz = e.redMul(j);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n // Double in extended coordinates\n if (this.curve.extended)\n return this._extDbl();\n else\n return this._projDbl();\n};\n\nPoint.prototype._extAdd = function _extAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #addition-add-2008-hwcd-3\n // 8M\n\n // A = (Y1 - X1) * (Y2 - X2)\n var a = this.y.redSub(this.x).redMul(p.y.redSub(p.x));\n // B = (Y1 + X1) * (Y2 + X2)\n var b = this.y.redAdd(this.x).redMul(p.y.redAdd(p.x));\n // C = T1 * k * T2\n var c = this.t.redMul(this.curve.dd).redMul(p.t);\n // D = Z1 * 2 * Z2\n var d = this.z.redMul(p.z.redAdd(p.z));\n // E = B - A\n var e = b.redSub(a);\n // F = D - C\n var f = d.redSub(c);\n // G = D + C\n var g = d.redAdd(c);\n // H = B + A\n var h = b.redAdd(a);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projAdd = function _projAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #addition-add-2008-bbjlp\n // #addition-add-2007-bl\n // 10M + 1S\n\n // A = Z1 * Z2\n var a = this.z.redMul(p.z);\n // B = A^2\n var b = a.redSqr();\n // C = X1 * X2\n var c = this.x.redMul(p.x);\n // D = Y1 * Y2\n var d = this.y.redMul(p.y);\n // E = d * C * D\n var e = this.curve.d.redMul(c).redMul(d);\n // F = B - E\n var f = b.redSub(e);\n // G = B + E\n var g = b.redAdd(e);\n // X3 = A * F * ((X1 + Y1) * (X2 + Y2) - C - D)\n var tmp = this.x.redAdd(this.y).redMul(p.x.redAdd(p.y)).redISub(c).redISub(d);\n var nx = a.redMul(f).redMul(tmp);\n var ny;\n var nz;\n if (this.curve.twisted) {\n // Y3 = A * G * (D - a * C)\n ny = a.redMul(g).redMul(d.redSub(this.curve._mulA(c)));\n // Z3 = F * G\n nz = f.redMul(g);\n } else {\n // Y3 = A * G * (D - C)\n ny = a.redMul(g).redMul(d.redSub(c));\n // Z3 = c * F * G\n nz = this.curve._mulC(f).redMul(g);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.add = function add(p) {\n if (this.isInfinity())\n return p;\n if (p.isInfinity())\n return this;\n\n if (this.curve.extended)\n return this._extAdd(p);\n else\n return this._projAdd(p);\n};\n\nPoint.prototype.mul = function mul(k) {\n if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, false);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, true);\n};\n\nPoint.prototype.normalize = function normalize() {\n if (this.zOne)\n return this;\n\n // Normalize coordinates\n var zi = this.z.redInvm();\n this.x = this.x.redMul(zi);\n this.y = this.y.redMul(zi);\n if (this.t)\n this.t = this.t.redMul(zi);\n this.z = this.curve.one;\n this.zOne = true;\n return this;\n};\n\nPoint.prototype.neg = function neg() {\n return this.curve.point(this.x.redNeg(),\n this.y,\n this.z,\n this.t && this.t.redNeg());\n};\n\nPoint.prototype.getX = function getX() {\n this.normalize();\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n this.normalize();\n return this.y.fromRed();\n};\n\nPoint.prototype.eq = function eq(other) {\n return this === other ||\n this.getX().cmp(other.getX()) === 0 &&\n this.getY().cmp(other.getY()) === 0;\n};\n\nPoint.prototype.eqXToP = function eqXToP(x) {\n var rx = x.toRed(this.curve.red).redMul(this.z);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(this.z);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\n// Compatibility with BaseCurve\nPoint.prototype.toP = Point.prototype.normalize;\nPoint.prototype.mixedAdd = Point.prototype.add;\n","'use strict';\n\nvar curves = exports;\n\nvar hash = require('hash.js');\nvar curve = require('./curve');\nvar utils = require('./utils');\n\nvar assert = utils.assert;\n\nfunction PresetCurve(options) {\n if (options.type === 'short')\n this.curve = new curve.short(options);\n else if (options.type === 'edwards')\n this.curve = new curve.edwards(options);\n else\n this.curve = new curve.mont(options);\n this.g = this.curve.g;\n this.n = this.curve.n;\n this.hash = options.hash;\n\n assert(this.g.validate(), 'Invalid curve');\n assert(this.g.mul(this.n).isInfinity(), 'Invalid curve, G*N != O');\n}\ncurves.PresetCurve = PresetCurve;\n\nfunction defineCurve(name, options) {\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n get: function() {\n var curve = new PresetCurve(options);\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n value: curve,\n });\n return curve;\n },\n });\n}\n\ndefineCurve('p192', {\n type: 'short',\n prime: 'p192',\n p: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc',\n b: '64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1',\n n: 'ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831',\n hash: hash.sha256,\n gRed: false,\n g: [\n '188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012',\n '07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811',\n ],\n});\n\ndefineCurve('p224', {\n type: 'short',\n prime: 'p224',\n p: 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe',\n b: 'b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4',\n n: 'ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d',\n hash: hash.sha256,\n gRed: false,\n g: [\n 'b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21',\n 'bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34',\n ],\n});\n\ndefineCurve('p256', {\n type: 'short',\n prime: null,\n p: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff',\n a: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc',\n b: '5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b',\n n: 'ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551',\n hash: hash.sha256,\n gRed: false,\n g: [\n '6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296',\n '4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5',\n ],\n});\n\ndefineCurve('p384', {\n type: 'short',\n prime: null,\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 ffffffff',\n a: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 fffffffc',\n b: 'b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f ' +\n '5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef',\n n: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 ' +\n 'f4372ddf 581a0db2 48b0a77a ecec196a ccc52973',\n hash: hash.sha384,\n gRed: false,\n g: [\n 'aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 ' +\n '5502f25d bf55296c 3a545e38 72760ab7',\n '3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 ' +\n '0a60b1ce 1d7e819d 7a431d7c 90ea0e5f',\n ],\n});\n\ndefineCurve('p521', {\n type: 'short',\n prime: null,\n p: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff',\n a: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff fffffffc',\n b: '00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b ' +\n '99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd ' +\n '3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00',\n n: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 ' +\n 'f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409',\n hash: hash.sha512,\n gRed: false,\n g: [\n '000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 ' +\n '053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 ' +\n 'a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66',\n '00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 ' +\n '579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 ' +\n '3fad0761 353c7086 a272c240 88be9476 9fd16650',\n ],\n});\n\ndefineCurve('curve25519', {\n type: 'mont',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '76d06',\n b: '1',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '9',\n ],\n});\n\ndefineCurve('ed25519', {\n type: 'edwards',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '-1',\n c: '1',\n // -121665 * (121666^(-1)) (mod P)\n d: '52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a',\n\n // 4/5\n '6666666666666666666666666666666666666666666666666666666666666658',\n ],\n});\n\nvar pre;\ntry {\n pre = require('./precomputed/secp256k1');\n} catch (e) {\n pre = undefined;\n}\n\ndefineCurve('secp256k1', {\n type: 'short',\n prime: 'k256',\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f',\n a: '0',\n b: '7',\n n: 'ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141',\n h: '1',\n hash: hash.sha256,\n\n // Precomputed endomorphism\n beta: '7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee',\n lambda: '5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72',\n basis: [\n {\n a: '3086d221a7d46bcde86c90e49284eb15',\n b: '-e4437ed6010e88286f547fa90abfe4c3',\n },\n {\n a: '114ca50f7a8e2f3f657c1108d9d44cfd8',\n b: '3086d221a7d46bcde86c90e49284eb15',\n },\n ],\n\n gRed: false,\n g: [\n '79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',\n '483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',\n pre,\n ],\n});\n","var hash = exports;\n\nhash.utils = require('./hash/utils');\nhash.common = require('./hash/common');\nhash.sha = require('./hash/sha');\nhash.ripemd = require('./hash/ripemd');\nhash.hmac = require('./hash/hmac');\n\n// Proxy hash functions to the main object\nhash.sha1 = hash.sha.sha1;\nhash.sha256 = hash.sha.sha256;\nhash.sha224 = hash.sha.sha224;\nhash.sha384 = hash.sha.sha384;\nhash.sha512 = hash.sha.sha512;\nhash.ripemd160 = hash.ripemd.ripemd160;\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nexports.inherits = inherits;\n\nfunction isSurrogatePair(msg, i) {\n if ((msg.charCodeAt(i) & 0xFC00) !== 0xD800) {\n return false;\n }\n if (i < 0 || i + 1 >= msg.length) {\n return false;\n }\n return (msg.charCodeAt(i + 1) & 0xFC00) === 0xDC00;\n}\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg === 'string') {\n if (!enc) {\n // Inspired by stringToUtf8ByteArray() in closure-library by Google\n // https://github.com/google/closure-library/blob/8598d87242af59aac233270742c8984e2b2bdbe0/closure/goog/crypt/crypt.js#L117-L143\n // Apache License 2.0\n // https://github.com/google/closure-library/blob/master/LICENSE\n var p = 0;\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n if (c < 128) {\n res[p++] = c;\n } else if (c < 2048) {\n res[p++] = (c >> 6) | 192;\n res[p++] = (c & 63) | 128;\n } else if (isSurrogatePair(msg, i)) {\n c = 0x10000 + ((c & 0x03FF) << 10) + (msg.charCodeAt(++i) & 0x03FF);\n res[p++] = (c >> 18) | 240;\n res[p++] = ((c >> 12) & 63) | 128;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n } else {\n res[p++] = (c >> 12) | 224;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n }\n }\n } else if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n }\n } else {\n for (i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n }\n return res;\n}\nexports.toArray = toArray;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nexports.toHex = toHex;\n\nfunction htonl(w) {\n var res = (w >>> 24) |\n ((w >>> 8) & 0xff00) |\n ((w << 8) & 0xff0000) |\n ((w & 0xff) << 24);\n return res >>> 0;\n}\nexports.htonl = htonl;\n\nfunction toHex32(msg, endian) {\n var res = '';\n for (var i = 0; i < msg.length; i++) {\n var w = msg[i];\n if (endian === 'little')\n w = htonl(w);\n res += zero8(w.toString(16));\n }\n return res;\n}\nexports.toHex32 = toHex32;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nexports.zero2 = zero2;\n\nfunction zero8(word) {\n if (word.length === 7)\n return '0' + word;\n else if (word.length === 6)\n return '00' + word;\n else if (word.length === 5)\n return '000' + word;\n else if (word.length === 4)\n return '0000' + word;\n else if (word.length === 3)\n return '00000' + word;\n else if (word.length === 2)\n return '000000' + word;\n else if (word.length === 1)\n return '0000000' + word;\n else\n return word;\n}\nexports.zero8 = zero8;\n\nfunction join32(msg, start, end, endian) {\n var len = end - start;\n assert(len % 4 === 0);\n var res = new Array(len / 4);\n for (var i = 0, k = start; i < res.length; i++, k += 4) {\n var w;\n if (endian === 'big')\n w = (msg[k] << 24) | (msg[k + 1] << 16) | (msg[k + 2] << 8) | msg[k + 3];\n else\n w = (msg[k + 3] << 24) | (msg[k + 2] << 16) | (msg[k + 1] << 8) | msg[k];\n res[i] = w >>> 0;\n }\n return res;\n}\nexports.join32 = join32;\n\nfunction split32(msg, endian) {\n var res = new Array(msg.length * 4);\n for (var i = 0, k = 0; i < msg.length; i++, k += 4) {\n var m = msg[i];\n if (endian === 'big') {\n res[k] = m >>> 24;\n res[k + 1] = (m >>> 16) & 0xff;\n res[k + 2] = (m >>> 8) & 0xff;\n res[k + 3] = m & 0xff;\n } else {\n res[k + 3] = m >>> 24;\n res[k + 2] = (m >>> 16) & 0xff;\n res[k + 1] = (m >>> 8) & 0xff;\n res[k] = m & 0xff;\n }\n }\n return res;\n}\nexports.split32 = split32;\n\nfunction rotr32(w, b) {\n return (w >>> b) | (w << (32 - b));\n}\nexports.rotr32 = rotr32;\n\nfunction rotl32(w, b) {\n return (w << b) | (w >>> (32 - b));\n}\nexports.rotl32 = rotl32;\n\nfunction sum32(a, b) {\n return (a + b) >>> 0;\n}\nexports.sum32 = sum32;\n\nfunction sum32_3(a, b, c) {\n return (a + b + c) >>> 0;\n}\nexports.sum32_3 = sum32_3;\n\nfunction sum32_4(a, b, c, d) {\n return (a + b + c + d) >>> 0;\n}\nexports.sum32_4 = sum32_4;\n\nfunction sum32_5(a, b, c, d, e) {\n return (a + b + c + d + e) >>> 0;\n}\nexports.sum32_5 = sum32_5;\n\nfunction sum64(buf, pos, ah, al) {\n var bh = buf[pos];\n var bl = buf[pos + 1];\n\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n buf[pos] = hi >>> 0;\n buf[pos + 1] = lo;\n}\nexports.sum64 = sum64;\n\nfunction sum64_hi(ah, al, bh, bl) {\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n return hi >>> 0;\n}\nexports.sum64_hi = sum64_hi;\n\nfunction sum64_lo(ah, al, bh, bl) {\n var lo = al + bl;\n return lo >>> 0;\n}\nexports.sum64_lo = sum64_lo;\n\nfunction sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n\n var hi = ah + bh + ch + dh + carry;\n return hi >>> 0;\n}\nexports.sum64_4_hi = sum64_4_hi;\n\nfunction sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) {\n var lo = al + bl + cl + dl;\n return lo >>> 0;\n}\nexports.sum64_4_lo = sum64_4_lo;\n\nfunction sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n lo = (lo + el) >>> 0;\n carry += lo < el ? 1 : 0;\n\n var hi = ah + bh + ch + dh + eh + carry;\n return hi >>> 0;\n}\nexports.sum64_5_hi = sum64_5_hi;\n\nfunction sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var lo = al + bl + cl + dl + el;\n\n return lo >>> 0;\n}\nexports.sum64_5_lo = sum64_5_lo;\n\nfunction rotr64_hi(ah, al, num) {\n var r = (al << (32 - num)) | (ah >>> num);\n return r >>> 0;\n}\nexports.rotr64_hi = rotr64_hi;\n\nfunction rotr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.rotr64_lo = rotr64_lo;\n\nfunction shr64_hi(ah, al, num) {\n return ah >>> num;\n}\nexports.shr64_hi = shr64_hi;\n\nfunction shr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.shr64_lo = shr64_lo;\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction BlockHash() {\n this.pending = null;\n this.pendingTotal = 0;\n this.blockSize = this.constructor.blockSize;\n this.outSize = this.constructor.outSize;\n this.hmacStrength = this.constructor.hmacStrength;\n this.padLength = this.constructor.padLength / 8;\n this.endian = 'big';\n\n this._delta8 = this.blockSize / 8;\n this._delta32 = this.blockSize / 32;\n}\nexports.BlockHash = BlockHash;\n\nBlockHash.prototype.update = function update(msg, enc) {\n // Convert message to array, pad it, and join into 32bit blocks\n msg = utils.toArray(msg, enc);\n if (!this.pending)\n this.pending = msg;\n else\n this.pending = this.pending.concat(msg);\n this.pendingTotal += msg.length;\n\n // Enough data, try updating\n if (this.pending.length >= this._delta8) {\n msg = this.pending;\n\n // Process pending data in blocks\n var r = msg.length % this._delta8;\n this.pending = msg.slice(msg.length - r, msg.length);\n if (this.pending.length === 0)\n this.pending = null;\n\n msg = utils.join32(msg, 0, msg.length - r, this.endian);\n for (var i = 0; i < msg.length; i += this._delta32)\n this._update(msg, i, i + this._delta32);\n }\n\n return this;\n};\n\nBlockHash.prototype.digest = function digest(enc) {\n this.update(this._pad());\n assert(this.pending === null);\n\n return this._digest(enc);\n};\n\nBlockHash.prototype._pad = function pad() {\n var len = this.pendingTotal;\n var bytes = this._delta8;\n var k = bytes - ((len + this.padLength) % bytes);\n var res = new Array(k + this.padLength);\n res[0] = 0x80;\n for (var i = 1; i < k; i++)\n res[i] = 0;\n\n // Append length\n len <<= 3;\n if (this.endian === 'big') {\n for (var t = 8; t < this.padLength; t++)\n res[i++] = 0;\n\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = len & 0xff;\n } else {\n res[i++] = len & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n\n for (t = 8; t < this.padLength; t++)\n res[i++] = 0;\n }\n\n return res;\n};\n","'use strict';\n\nexports.sha1 = require('./sha/1');\nexports.sha224 = require('./sha/224');\nexports.sha256 = require('./sha/256');\nexports.sha384 = require('./sha/384');\nexports.sha512 = require('./sha/512');\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_5 = utils.sum32_5;\nvar ft_1 = shaCommon.ft_1;\nvar BlockHash = common.BlockHash;\n\nvar sha1_K = [\n 0x5A827999, 0x6ED9EBA1,\n 0x8F1BBCDC, 0xCA62C1D6\n];\n\nfunction SHA1() {\n if (!(this instanceof SHA1))\n return new SHA1();\n\n BlockHash.call(this);\n this.h = [\n 0x67452301, 0xefcdab89, 0x98badcfe,\n 0x10325476, 0xc3d2e1f0 ];\n this.W = new Array(80);\n}\n\nutils.inherits(SHA1, BlockHash);\nmodule.exports = SHA1;\n\nSHA1.blockSize = 512;\nSHA1.outSize = 160;\nSHA1.hmacStrength = 80;\nSHA1.padLength = 64;\n\nSHA1.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n\n for(; i < W.length; i++)\n W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n\n for (i = 0; i < W.length; i++) {\n var s = ~~(i / 20);\n var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]);\n e = d;\n d = c;\n c = rotl32(b, 30);\n b = a;\n a = t;\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n};\n\nSHA1.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar rotr32 = utils.rotr32;\n\nfunction ft_1(s, x, y, z) {\n if (s === 0)\n return ch32(x, y, z);\n if (s === 1 || s === 3)\n return p32(x, y, z);\n if (s === 2)\n return maj32(x, y, z);\n}\nexports.ft_1 = ft_1;\n\nfunction ch32(x, y, z) {\n return (x & y) ^ ((~x) & z);\n}\nexports.ch32 = ch32;\n\nfunction maj32(x, y, z) {\n return (x & y) ^ (x & z) ^ (y & z);\n}\nexports.maj32 = maj32;\n\nfunction p32(x, y, z) {\n return x ^ y ^ z;\n}\nexports.p32 = p32;\n\nfunction s0_256(x) {\n return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22);\n}\nexports.s0_256 = s0_256;\n\nfunction s1_256(x) {\n return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25);\n}\nexports.s1_256 = s1_256;\n\nfunction g0_256(x) {\n return rotr32(x, 7) ^ rotr32(x, 18) ^ (x >>> 3);\n}\nexports.g0_256 = g0_256;\n\nfunction g1_256(x) {\n return rotr32(x, 17) ^ rotr32(x, 19) ^ (x >>> 10);\n}\nexports.g1_256 = g1_256;\n","'use strict';\n\nvar utils = require('../utils');\nvar SHA256 = require('./256');\n\nfunction SHA224() {\n if (!(this instanceof SHA224))\n return new SHA224();\n\n SHA256.call(this);\n this.h = [\n 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 ];\n}\nutils.inherits(SHA224, SHA256);\nmodule.exports = SHA224;\n\nSHA224.blockSize = 512;\nSHA224.outSize = 224;\nSHA224.hmacStrength = 192;\nSHA224.padLength = 64;\n\nSHA224.prototype._digest = function digest(enc) {\n // Just truncate output\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 7), 'big');\n else\n return utils.split32(this.h.slice(0, 7), 'big');\n};\n\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\nvar assert = require('minimalistic-assert');\n\nvar sum32 = utils.sum32;\nvar sum32_4 = utils.sum32_4;\nvar sum32_5 = utils.sum32_5;\nvar ch32 = shaCommon.ch32;\nvar maj32 = shaCommon.maj32;\nvar s0_256 = shaCommon.s0_256;\nvar s1_256 = shaCommon.s1_256;\nvar g0_256 = shaCommon.g0_256;\nvar g1_256 = shaCommon.g1_256;\n\nvar BlockHash = common.BlockHash;\n\nvar sha256_K = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n];\n\nfunction SHA256() {\n if (!(this instanceof SHA256))\n return new SHA256();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a,\n 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19\n ];\n this.k = sha256_K;\n this.W = new Array(64);\n}\nutils.inherits(SHA256, BlockHash);\nmodule.exports = SHA256;\n\nSHA256.blockSize = 512;\nSHA256.outSize = 256;\nSHA256.hmacStrength = 192;\nSHA256.padLength = 64;\n\nSHA256.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i++)\n W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n var f = this.h[5];\n var g = this.h[6];\n var h = this.h[7];\n\n assert(this.k.length === W.length);\n for (i = 0; i < W.length; i++) {\n var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]);\n var T2 = sum32(s0_256(a), maj32(a, b, c));\n h = g;\n g = f;\n f = e;\n e = sum32(d, T1);\n d = c;\n c = b;\n b = a;\n a = sum32(T1, T2);\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n this.h[5] = sum32(this.h[5], f);\n this.h[6] = sum32(this.h[6], g);\n this.h[7] = sum32(this.h[7], h);\n};\n\nSHA256.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\n\nvar SHA512 = require('./512');\n\nfunction SHA384() {\n if (!(this instanceof SHA384))\n return new SHA384();\n\n SHA512.call(this);\n this.h = [\n 0xcbbb9d5d, 0xc1059ed8,\n 0x629a292a, 0x367cd507,\n 0x9159015a, 0x3070dd17,\n 0x152fecd8, 0xf70e5939,\n 0x67332667, 0xffc00b31,\n 0x8eb44a87, 0x68581511,\n 0xdb0c2e0d, 0x64f98fa7,\n 0x47b5481d, 0xbefa4fa4 ];\n}\nutils.inherits(SHA384, SHA512);\nmodule.exports = SHA384;\n\nSHA384.blockSize = 1024;\nSHA384.outSize = 384;\nSHA384.hmacStrength = 192;\nSHA384.padLength = 128;\n\nSHA384.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 12), 'big');\n else\n return utils.split32(this.h.slice(0, 12), 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar assert = require('minimalistic-assert');\n\nvar rotr64_hi = utils.rotr64_hi;\nvar rotr64_lo = utils.rotr64_lo;\nvar shr64_hi = utils.shr64_hi;\nvar shr64_lo = utils.shr64_lo;\nvar sum64 = utils.sum64;\nvar sum64_hi = utils.sum64_hi;\nvar sum64_lo = utils.sum64_lo;\nvar sum64_4_hi = utils.sum64_4_hi;\nvar sum64_4_lo = utils.sum64_4_lo;\nvar sum64_5_hi = utils.sum64_5_hi;\nvar sum64_5_lo = utils.sum64_5_lo;\n\nvar BlockHash = common.BlockHash;\n\nvar sha512_K = [\n 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n];\n\nfunction SHA512() {\n if (!(this instanceof SHA512))\n return new SHA512();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xf3bcc908,\n 0xbb67ae85, 0x84caa73b,\n 0x3c6ef372, 0xfe94f82b,\n 0xa54ff53a, 0x5f1d36f1,\n 0x510e527f, 0xade682d1,\n 0x9b05688c, 0x2b3e6c1f,\n 0x1f83d9ab, 0xfb41bd6b,\n 0x5be0cd19, 0x137e2179 ];\n this.k = sha512_K;\n this.W = new Array(160);\n}\nutils.inherits(SHA512, BlockHash);\nmodule.exports = SHA512;\n\nSHA512.blockSize = 1024;\nSHA512.outSize = 512;\nSHA512.hmacStrength = 192;\nSHA512.padLength = 128;\n\nSHA512.prototype._prepareBlock = function _prepareBlock(msg, start) {\n var W = this.W;\n\n // 32 x 32bit words\n for (var i = 0; i < 32; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i += 2) {\n var c0_hi = g1_512_hi(W[i - 4], W[i - 3]); // i - 2\n var c0_lo = g1_512_lo(W[i - 4], W[i - 3]);\n var c1_hi = W[i - 14]; // i - 7\n var c1_lo = W[i - 13];\n var c2_hi = g0_512_hi(W[i - 30], W[i - 29]); // i - 15\n var c2_lo = g0_512_lo(W[i - 30], W[i - 29]);\n var c3_hi = W[i - 32]; // i - 16\n var c3_lo = W[i - 31];\n\n W[i] = sum64_4_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n W[i + 1] = sum64_4_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n }\n};\n\nSHA512.prototype._update = function _update(msg, start) {\n this._prepareBlock(msg, start);\n\n var W = this.W;\n\n var ah = this.h[0];\n var al = this.h[1];\n var bh = this.h[2];\n var bl = this.h[3];\n var ch = this.h[4];\n var cl = this.h[5];\n var dh = this.h[6];\n var dl = this.h[7];\n var eh = this.h[8];\n var el = this.h[9];\n var fh = this.h[10];\n var fl = this.h[11];\n var gh = this.h[12];\n var gl = this.h[13];\n var hh = this.h[14];\n var hl = this.h[15];\n\n assert(this.k.length === W.length);\n for (var i = 0; i < W.length; i += 2) {\n var c0_hi = hh;\n var c0_lo = hl;\n var c1_hi = s1_512_hi(eh, el);\n var c1_lo = s1_512_lo(eh, el);\n var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl);\n var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl);\n var c3_hi = this.k[i];\n var c3_lo = this.k[i + 1];\n var c4_hi = W[i];\n var c4_lo = W[i + 1];\n\n var T1_hi = sum64_5_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n var T1_lo = sum64_5_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n\n c0_hi = s0_512_hi(ah, al);\n c0_lo = s0_512_lo(ah, al);\n c1_hi = maj64_hi(ah, al, bh, bl, ch, cl);\n c1_lo = maj64_lo(ah, al, bh, bl, ch, cl);\n\n var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo);\n var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo);\n\n hh = gh;\n hl = gl;\n\n gh = fh;\n gl = fl;\n\n fh = eh;\n fl = el;\n\n eh = sum64_hi(dh, dl, T1_hi, T1_lo);\n el = sum64_lo(dl, dl, T1_hi, T1_lo);\n\n dh = ch;\n dl = cl;\n\n ch = bh;\n cl = bl;\n\n bh = ah;\n bl = al;\n\n ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo);\n al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo);\n }\n\n sum64(this.h, 0, ah, al);\n sum64(this.h, 2, bh, bl);\n sum64(this.h, 4, ch, cl);\n sum64(this.h, 6, dh, dl);\n sum64(this.h, 8, eh, el);\n sum64(this.h, 10, fh, fl);\n sum64(this.h, 12, gh, gl);\n sum64(this.h, 14, hh, hl);\n};\n\nSHA512.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n\nfunction ch64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ ((~xh) & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction ch64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ ((~xl) & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ (xh & zh) ^ (yh & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ (xl & zl) ^ (yl & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 28);\n var c1_hi = rotr64_hi(xl, xh, 2); // 34\n var c2_hi = rotr64_hi(xl, xh, 7); // 39\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 28);\n var c1_lo = rotr64_lo(xl, xh, 2); // 34\n var c2_lo = rotr64_lo(xl, xh, 7); // 39\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 14);\n var c1_hi = rotr64_hi(xh, xl, 18);\n var c2_hi = rotr64_hi(xl, xh, 9); // 41\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 14);\n var c1_lo = rotr64_lo(xh, xl, 18);\n var c2_lo = rotr64_lo(xl, xh, 9); // 41\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 1);\n var c1_hi = rotr64_hi(xh, xl, 8);\n var c2_hi = shr64_hi(xh, xl, 7);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 1);\n var c1_lo = rotr64_lo(xh, xl, 8);\n var c2_lo = shr64_lo(xh, xl, 7);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 19);\n var c1_hi = rotr64_hi(xl, xh, 29); // 61\n var c2_hi = shr64_hi(xh, xl, 6);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 19);\n var c1_lo = rotr64_lo(xl, xh, 29); // 61\n var c2_lo = shr64_lo(xh, xl, 6);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n","'use strict';\n\nvar utils = require('./utils');\nvar common = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_3 = utils.sum32_3;\nvar sum32_4 = utils.sum32_4;\nvar BlockHash = common.BlockHash;\n\nfunction RIPEMD160() {\n if (!(this instanceof RIPEMD160))\n return new RIPEMD160();\n\n BlockHash.call(this);\n\n this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ];\n this.endian = 'little';\n}\nutils.inherits(RIPEMD160, BlockHash);\nexports.ripemd160 = RIPEMD160;\n\nRIPEMD160.blockSize = 512;\nRIPEMD160.outSize = 160;\nRIPEMD160.hmacStrength = 192;\nRIPEMD160.padLength = 64;\n\nRIPEMD160.prototype._update = function update(msg, start) {\n var A = this.h[0];\n var B = this.h[1];\n var C = this.h[2];\n var D = this.h[3];\n var E = this.h[4];\n var Ah = A;\n var Bh = B;\n var Ch = C;\n var Dh = D;\n var Eh = E;\n for (var j = 0; j < 80; j++) {\n var T = sum32(\n rotl32(\n sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)),\n s[j]),\n E);\n A = E;\n E = D;\n D = rotl32(C, 10);\n C = B;\n B = T;\n T = sum32(\n rotl32(\n sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)),\n sh[j]),\n Eh);\n Ah = Eh;\n Eh = Dh;\n Dh = rotl32(Ch, 10);\n Ch = Bh;\n Bh = T;\n }\n T = sum32_3(this.h[1], C, Dh);\n this.h[1] = sum32_3(this.h[2], D, Eh);\n this.h[2] = sum32_3(this.h[3], E, Ah);\n this.h[3] = sum32_3(this.h[4], A, Bh);\n this.h[4] = sum32_3(this.h[0], B, Ch);\n this.h[0] = T;\n};\n\nRIPEMD160.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'little');\n else\n return utils.split32(this.h, 'little');\n};\n\nfunction f(j, x, y, z) {\n if (j <= 15)\n return x ^ y ^ z;\n else if (j <= 31)\n return (x & y) | ((~x) & z);\n else if (j <= 47)\n return (x | (~y)) ^ z;\n else if (j <= 63)\n return (x & z) | (y & (~z));\n else\n return x ^ (y | (~z));\n}\n\nfunction K(j) {\n if (j <= 15)\n return 0x00000000;\n else if (j <= 31)\n return 0x5a827999;\n else if (j <= 47)\n return 0x6ed9eba1;\n else if (j <= 63)\n return 0x8f1bbcdc;\n else\n return 0xa953fd4e;\n}\n\nfunction Kh(j) {\n if (j <= 15)\n return 0x50a28be6;\n else if (j <= 31)\n return 0x5c4dd124;\n else if (j <= 47)\n return 0x6d703ef3;\n else if (j <= 63)\n return 0x7a6d76e9;\n else\n return 0x00000000;\n}\n\nvar r = [\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n];\n\nvar rh = [\n 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n];\n\nvar s = [\n 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n];\n\nvar sh = [\n 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n];\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction Hmac(hash, key, enc) {\n if (!(this instanceof Hmac))\n return new Hmac(hash, key, enc);\n this.Hash = hash;\n this.blockSize = hash.blockSize / 8;\n this.outSize = hash.outSize / 8;\n this.inner = null;\n this.outer = null;\n\n this._init(utils.toArray(key, enc));\n}\nmodule.exports = Hmac;\n\nHmac.prototype._init = function init(key) {\n // Shorten key, if needed\n if (key.length > this.blockSize)\n key = new this.Hash().update(key).digest();\n assert(key.length <= this.blockSize);\n\n // Add padding to key\n for (var i = key.length; i < this.blockSize; i++)\n key.push(0);\n\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x36;\n this.inner = new this.Hash().update(key);\n\n // 0x36 ^ 0x5c = 0x6a\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x6a;\n this.outer = new this.Hash().update(key);\n};\n\nHmac.prototype.update = function update(msg, enc) {\n this.inner.update(msg, enc);\n return this;\n};\n\nHmac.prototype.digest = function digest(enc) {\n this.outer.update(this.inner.digest());\n return this.outer.digest(enc);\n};\n","module.exports = {\n doubles: {\n step: 4,\n points: [\n [\n 'e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a',\n 'f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821',\n ],\n [\n '8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508',\n '11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf',\n ],\n [\n '175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739',\n 'd3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695',\n ],\n [\n '363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640',\n '4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9',\n ],\n [\n '8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c',\n '4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36',\n ],\n [\n '723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda',\n '96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f',\n ],\n [\n 'eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa',\n '5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999',\n ],\n [\n '100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0',\n 'cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09',\n ],\n [\n 'e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d',\n '9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d',\n ],\n [\n 'feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d',\n 'e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088',\n ],\n [\n 'da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1',\n '9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d',\n ],\n [\n '53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0',\n '5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8',\n ],\n [\n '8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047',\n '10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a',\n ],\n [\n '385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862',\n '283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453',\n ],\n [\n '6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7',\n '7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160',\n ],\n [\n '3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd',\n '56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0',\n ],\n [\n '85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83',\n '7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6',\n ],\n [\n '948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a',\n '53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589',\n ],\n [\n '6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8',\n 'bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17',\n ],\n [\n 'e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d',\n '4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda',\n ],\n [\n 'e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725',\n '7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd',\n ],\n [\n '213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754',\n '4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2',\n ],\n [\n '4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c',\n '17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6',\n ],\n [\n 'fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6',\n '6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f',\n ],\n [\n '76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39',\n 'c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01',\n ],\n [\n 'c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891',\n '893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3',\n ],\n [\n 'd895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b',\n 'febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f',\n ],\n [\n 'b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03',\n '2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7',\n ],\n [\n 'e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d',\n 'eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78',\n ],\n [\n 'a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070',\n '7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1',\n ],\n [\n '90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4',\n 'e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150',\n ],\n [\n '8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da',\n '662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82',\n ],\n [\n 'e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11',\n '1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc',\n ],\n [\n '8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e',\n 'efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b',\n ],\n [\n 'e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41',\n '2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51',\n ],\n [\n 'b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef',\n '67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45',\n ],\n [\n 'd68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8',\n 'db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120',\n ],\n [\n '324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d',\n '648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84',\n ],\n [\n '4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96',\n '35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d',\n ],\n [\n '9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd',\n 'ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d',\n ],\n [\n '6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5',\n '9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8',\n ],\n [\n 'a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266',\n '40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8',\n ],\n [\n '7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71',\n '34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac',\n ],\n [\n '928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac',\n 'c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f',\n ],\n [\n '85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751',\n '1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962',\n ],\n [\n 'ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e',\n '493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907',\n ],\n [\n '827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241',\n 'c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec',\n ],\n [\n 'eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3',\n 'be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d',\n ],\n [\n 'e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f',\n '4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414',\n ],\n [\n '1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19',\n 'aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd',\n ],\n [\n '146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be',\n 'b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0',\n ],\n [\n 'fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9',\n '6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811',\n ],\n [\n 'da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2',\n '8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1',\n ],\n [\n 'a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13',\n '7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c',\n ],\n [\n '174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c',\n 'ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73',\n ],\n [\n '959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba',\n '2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd',\n ],\n [\n 'd2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151',\n 'e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405',\n ],\n [\n '64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073',\n 'd99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589',\n ],\n [\n '8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458',\n '38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e',\n ],\n [\n '13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b',\n '69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27',\n ],\n [\n 'bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366',\n 'd3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1',\n ],\n [\n '8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa',\n '40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482',\n ],\n [\n '8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0',\n '620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945',\n ],\n [\n 'dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787',\n '7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573',\n ],\n [\n 'f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e',\n 'ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82',\n ],\n ],\n },\n naf: {\n wnd: 7,\n points: [\n [\n 'f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9',\n '388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672',\n ],\n [\n '2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4',\n 'd8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6',\n ],\n [\n '5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc',\n '6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da',\n ],\n [\n 'acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe',\n 'cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37',\n ],\n [\n '774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb',\n 'd984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b',\n ],\n [\n 'f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8',\n 'ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81',\n ],\n [\n 'd7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e',\n '581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58',\n ],\n [\n 'defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34',\n '4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77',\n ],\n [\n '2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c',\n '85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a',\n ],\n [\n '352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5',\n '321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c',\n ],\n [\n '2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f',\n '2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67',\n ],\n [\n '9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714',\n '73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402',\n ],\n [\n 'daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729',\n 'a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55',\n ],\n [\n 'c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db',\n '2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482',\n ],\n [\n '6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4',\n 'e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82',\n ],\n [\n '1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5',\n 'b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396',\n ],\n [\n '605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479',\n '2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49',\n ],\n [\n '62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d',\n '80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf',\n ],\n [\n '80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f',\n '1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a',\n ],\n [\n '7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb',\n 'd0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7',\n ],\n [\n 'd528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9',\n 'eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933',\n ],\n [\n '49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963',\n '758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a',\n ],\n [\n '77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74',\n '958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6',\n ],\n [\n 'f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530',\n 'e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37',\n ],\n [\n '463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b',\n '5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e',\n ],\n [\n 'f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247',\n 'cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6',\n ],\n [\n 'caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1',\n 'cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476',\n ],\n [\n '2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120',\n '4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40',\n ],\n [\n '7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435',\n '91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61',\n ],\n [\n '754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18',\n '673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683',\n ],\n [\n 'e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8',\n '59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5',\n ],\n [\n '186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb',\n '3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b',\n ],\n [\n 'df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f',\n '55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417',\n ],\n [\n '5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143',\n 'efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868',\n ],\n [\n '290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba',\n 'e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a',\n ],\n [\n 'af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45',\n 'f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6',\n ],\n [\n '766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a',\n '744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996',\n ],\n [\n '59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e',\n 'c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e',\n ],\n [\n 'f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8',\n 'e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d',\n ],\n [\n '7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c',\n '30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2',\n ],\n [\n '948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519',\n 'e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e',\n ],\n [\n '7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab',\n '100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437',\n ],\n [\n '3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca',\n 'ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311',\n ],\n [\n 'd3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf',\n '8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4',\n ],\n [\n '1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610',\n '68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575',\n ],\n [\n '733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4',\n 'f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d',\n ],\n [\n '15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c',\n 'd56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d',\n ],\n [\n 'a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940',\n 'edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629',\n ],\n [\n 'e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980',\n 'a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06',\n ],\n [\n '311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3',\n '66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374',\n ],\n [\n '34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf',\n '9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee',\n ],\n [\n 'f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63',\n '4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1',\n ],\n [\n 'd7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448',\n 'fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b',\n ],\n [\n '32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf',\n '5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661',\n ],\n [\n '7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5',\n '8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6',\n ],\n [\n 'ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6',\n '8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e',\n ],\n [\n '16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5',\n '5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d',\n ],\n [\n 'eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99',\n 'f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc',\n ],\n [\n '78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51',\n 'f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4',\n ],\n [\n '494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5',\n '42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c',\n ],\n [\n 'a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5',\n '204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b',\n ],\n [\n 'c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997',\n '4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913',\n ],\n [\n '841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881',\n '73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154',\n ],\n [\n '5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5',\n '39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865',\n ],\n [\n '36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66',\n 'd2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc',\n ],\n [\n '336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726',\n 'ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224',\n ],\n [\n '8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede',\n '6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e',\n ],\n [\n '1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94',\n '60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6',\n ],\n [\n '85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31',\n '3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511',\n ],\n [\n '29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51',\n 'b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b',\n ],\n [\n 'a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252',\n 'ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2',\n ],\n [\n '4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5',\n 'cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c',\n ],\n [\n 'd24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b',\n '6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3',\n ],\n [\n 'ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4',\n '322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d',\n ],\n [\n 'af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f',\n '6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700',\n ],\n [\n 'e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889',\n '2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4',\n ],\n [\n '591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246',\n 'b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196',\n ],\n [\n '11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984',\n '998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4',\n ],\n [\n '3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a',\n 'b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257',\n ],\n [\n 'cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030',\n 'bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13',\n ],\n [\n 'c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197',\n '6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096',\n ],\n [\n 'c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593',\n 'c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38',\n ],\n [\n 'a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef',\n '21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f',\n ],\n [\n '347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38',\n '60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448',\n ],\n [\n 'da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a',\n '49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a',\n ],\n [\n 'c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111',\n '5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4',\n ],\n [\n '4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502',\n '7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437',\n ],\n [\n '3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea',\n 'be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7',\n ],\n [\n 'cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26',\n '8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d',\n ],\n [\n 'b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986',\n '39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a',\n ],\n [\n 'd4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e',\n '62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54',\n ],\n [\n '48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4',\n '25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77',\n ],\n [\n 'dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda',\n 'ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517',\n ],\n [\n '6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859',\n 'cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10',\n ],\n [\n 'e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f',\n 'f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125',\n ],\n [\n 'eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c',\n '6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e',\n ],\n [\n '13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942',\n 'fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1',\n ],\n [\n 'ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a',\n '1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2',\n ],\n [\n 'b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80',\n '5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423',\n ],\n [\n 'ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d',\n '438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8',\n ],\n [\n '8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1',\n 'cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758',\n ],\n [\n '52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63',\n 'c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375',\n ],\n [\n 'e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352',\n '6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d',\n ],\n [\n '7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193',\n 'ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec',\n ],\n [\n '5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00',\n '9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0',\n ],\n [\n '32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58',\n 'ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c',\n ],\n [\n 'e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7',\n 'd3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4',\n ],\n [\n '8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8',\n 'c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f',\n ],\n [\n '4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e',\n '67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649',\n ],\n [\n '3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d',\n 'cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826',\n ],\n [\n '674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b',\n '299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5',\n ],\n [\n 'd32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f',\n 'f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87',\n ],\n [\n '30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6',\n '462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b',\n ],\n [\n 'be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297',\n '62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc',\n ],\n [\n '93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a',\n '7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c',\n ],\n [\n 'b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c',\n 'ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f',\n ],\n [\n 'd5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52',\n '4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a',\n ],\n [\n 'd3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb',\n 'bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46',\n ],\n [\n '463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065',\n 'bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f',\n ],\n [\n '7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917',\n '603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03',\n ],\n [\n '74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9',\n 'cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08',\n ],\n [\n '30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3',\n '553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8',\n ],\n [\n '9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57',\n '712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373',\n ],\n [\n '176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66',\n 'ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3',\n ],\n [\n '75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8',\n '9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8',\n ],\n [\n '809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721',\n '9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1',\n ],\n [\n '1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180',\n '4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9',\n ],\n ],\n },\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar HmacDRBG = require('hmac-drbg');\nvar utils = require('../utils');\nvar curves = require('../curves');\nvar rand = require('brorand');\nvar assert = utils.assert;\n\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EC(options) {\n if (!(this instanceof EC))\n return new EC(options);\n\n // Shortcut `elliptic.ec(curve-name)`\n if (typeof options === 'string') {\n assert(Object.prototype.hasOwnProperty.call(curves, options),\n 'Unknown curve ' + options);\n\n options = curves[options];\n }\n\n // Shortcut for `elliptic.ec(elliptic.curves.curveName)`\n if (options instanceof curves.PresetCurve)\n options = { curve: options };\n\n this.curve = options.curve.curve;\n this.n = this.curve.n;\n this.nh = this.n.ushrn(1);\n this.g = this.curve.g;\n\n // Point on curve\n this.g = options.curve.g;\n this.g.precompute(options.curve.n.bitLength() + 1);\n\n // Hash for function for DRBG\n this.hash = options.hash || options.curve.hash;\n}\nmodule.exports = EC;\n\nEC.prototype.keyPair = function keyPair(options) {\n return new KeyPair(this, options);\n};\n\nEC.prototype.keyFromPrivate = function keyFromPrivate(priv, enc) {\n return KeyPair.fromPrivate(this, priv, enc);\n};\n\nEC.prototype.keyFromPublic = function keyFromPublic(pub, enc) {\n return KeyPair.fromPublic(this, pub, enc);\n};\n\nEC.prototype.genKeyPair = function genKeyPair(options) {\n if (!options)\n options = {};\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n entropy: options.entropy || rand(this.hash.hmacStrength),\n entropyEnc: options.entropy && options.entropyEnc || 'utf8',\n nonce: this.n.toArray(),\n });\n\n var bytes = this.n.byteLength();\n var ns2 = this.n.sub(new BN(2));\n for (;;) {\n var priv = new BN(drbg.generate(bytes));\n if (priv.cmp(ns2) > 0)\n continue;\n\n priv.iaddn(1);\n return this.keyFromPrivate(priv);\n }\n};\n\nEC.prototype._truncateToN = function _truncateToN(msg, truncOnly) {\n var delta = msg.byteLength() * 8 - this.n.bitLength();\n if (delta > 0)\n msg = msg.ushrn(delta);\n if (!truncOnly && msg.cmp(this.n) >= 0)\n return msg.sub(this.n);\n else\n return msg;\n};\n\nEC.prototype.sign = function sign(msg, key, enc, options) {\n if (typeof enc === 'object') {\n options = enc;\n enc = null;\n }\n if (!options)\n options = {};\n\n key = this.keyFromPrivate(key, enc);\n msg = this._truncateToN(new BN(msg, 16));\n\n // Zero-extend key to provide enough entropy\n var bytes = this.n.byteLength();\n var bkey = key.getPrivate().toArray('be', bytes);\n\n // Zero-extend nonce to have the same byte size as N\n var nonce = msg.toArray('be', bytes);\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n entropy: bkey,\n nonce: nonce,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n });\n\n // Number of bytes to generate\n var ns1 = this.n.sub(new BN(1));\n\n for (var iter = 0; ; iter++) {\n var k = options.k ?\n options.k(iter) :\n new BN(drbg.generate(this.n.byteLength()));\n k = this._truncateToN(k, true);\n if (k.cmpn(1) <= 0 || k.cmp(ns1) >= 0)\n continue;\n\n var kp = this.g.mul(k);\n if (kp.isInfinity())\n continue;\n\n var kpX = kp.getX();\n var r = kpX.umod(this.n);\n if (r.cmpn(0) === 0)\n continue;\n\n var s = k.invm(this.n).mul(r.mul(key.getPrivate()).iadd(msg));\n s = s.umod(this.n);\n if (s.cmpn(0) === 0)\n continue;\n\n var recoveryParam = (kp.getY().isOdd() ? 1 : 0) |\n (kpX.cmp(r) !== 0 ? 2 : 0);\n\n // Use complement of `s`, if it is > `n / 2`\n if (options.canonical && s.cmp(this.nh) > 0) {\n s = this.n.sub(s);\n recoveryParam ^= 1;\n }\n\n return new Signature({ r: r, s: s, recoveryParam: recoveryParam });\n }\n};\n\nEC.prototype.verify = function verify(msg, signature, key, enc) {\n msg = this._truncateToN(new BN(msg, 16));\n key = this.keyFromPublic(key, enc);\n signature = new Signature(signature, 'hex');\n\n // Perform primitive values validation\n var r = signature.r;\n var s = signature.s;\n if (r.cmpn(1) < 0 || r.cmp(this.n) >= 0)\n return false;\n if (s.cmpn(1) < 0 || s.cmp(this.n) >= 0)\n return false;\n\n // Validate signature\n var sinv = s.invm(this.n);\n var u1 = sinv.mul(msg).umod(this.n);\n var u2 = sinv.mul(r).umod(this.n);\n var p;\n\n if (!this.curve._maxwellTrick) {\n p = this.g.mulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n return p.getX().umod(this.n).cmp(r) === 0;\n }\n\n // NOTE: Greg Maxwell's trick, inspired by:\n // https://git.io/vad3K\n\n p = this.g.jmulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n // Compare `p.x` of Jacobian point with `r`,\n // this will do `p.x == r * p.z^2` instead of multiplying `p.x` by the\n // inverse of `p.z^2`\n return p.eqXToP(r);\n};\n\nEC.prototype.recoverPubKey = function(msg, signature, j, enc) {\n assert((3 & j) === j, 'The recovery param is more than two bits');\n signature = new Signature(signature, enc);\n\n var n = this.n;\n var e = new BN(msg);\n var r = signature.r;\n var s = signature.s;\n\n // A set LSB signifies that the y-coordinate is odd\n var isYOdd = j & 1;\n var isSecondKey = j >> 1;\n if (r.cmp(this.curve.p.umod(this.curve.n)) >= 0 && isSecondKey)\n throw new Error('Unable to find sencond key candinate');\n\n // 1.1. Let x = r + jn.\n if (isSecondKey)\n r = this.curve.pointFromX(r.add(this.curve.n), isYOdd);\n else\n r = this.curve.pointFromX(r, isYOdd);\n\n var rInv = signature.r.invm(n);\n var s1 = n.sub(e).mul(rInv).umod(n);\n var s2 = s.mul(rInv).umod(n);\n\n // 1.6.1 Compute Q = r^-1 (sR - eG)\n // Q = r^-1 (sR + -eG)\n return this.g.mulAdd(s1, r, s2);\n};\n\nEC.prototype.getKeyRecoveryParam = function(e, signature, Q, enc) {\n signature = new Signature(signature, enc);\n if (signature.recoveryParam !== null)\n return signature.recoveryParam;\n\n for (var i = 0; i < 4; i++) {\n var Qprime;\n try {\n Qprime = this.recoverPubKey(e, signature, i);\n } catch (e) {\n continue;\n }\n\n if (Qprime.eq(Q))\n return i;\n }\n throw new Error('Unable to find valid recovery factor');\n};\n","'use strict';\n\nvar hash = require('hash.js');\nvar utils = require('minimalistic-crypto-utils');\nvar assert = require('minimalistic-assert');\n\nfunction HmacDRBG(options) {\n if (!(this instanceof HmacDRBG))\n return new HmacDRBG(options);\n this.hash = options.hash;\n this.predResist = !!options.predResist;\n\n this.outLen = this.hash.outSize;\n this.minEntropy = options.minEntropy || this.hash.hmacStrength;\n\n this._reseed = null;\n this.reseedInterval = null;\n this.K = null;\n this.V = null;\n\n var entropy = utils.toArray(options.entropy, options.entropyEnc || 'hex');\n var nonce = utils.toArray(options.nonce, options.nonceEnc || 'hex');\n var pers = utils.toArray(options.pers, options.persEnc || 'hex');\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n this._init(entropy, nonce, pers);\n}\nmodule.exports = HmacDRBG;\n\nHmacDRBG.prototype._init = function init(entropy, nonce, pers) {\n var seed = entropy.concat(nonce).concat(pers);\n\n this.K = new Array(this.outLen / 8);\n this.V = new Array(this.outLen / 8);\n for (var i = 0; i < this.V.length; i++) {\n this.K[i] = 0x00;\n this.V[i] = 0x01;\n }\n\n this._update(seed);\n this._reseed = 1;\n this.reseedInterval = 0x1000000000000; // 2^48\n};\n\nHmacDRBG.prototype._hmac = function hmac() {\n return new hash.hmac(this.hash, this.K);\n};\n\nHmacDRBG.prototype._update = function update(seed) {\n var kmac = this._hmac()\n .update(this.V)\n .update([ 0x00 ]);\n if (seed)\n kmac = kmac.update(seed);\n this.K = kmac.digest();\n this.V = this._hmac().update(this.V).digest();\n if (!seed)\n return;\n\n this.K = this._hmac()\n .update(this.V)\n .update([ 0x01 ])\n .update(seed)\n .digest();\n this.V = this._hmac().update(this.V).digest();\n};\n\nHmacDRBG.prototype.reseed = function reseed(entropy, entropyEnc, add, addEnc) {\n // Optional entropy enc\n if (typeof entropyEnc !== 'string') {\n addEnc = add;\n add = entropyEnc;\n entropyEnc = null;\n }\n\n entropy = utils.toArray(entropy, entropyEnc);\n add = utils.toArray(add, addEnc);\n\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n\n this._update(entropy.concat(add || []));\n this._reseed = 1;\n};\n\nHmacDRBG.prototype.generate = function generate(len, enc, add, addEnc) {\n if (this._reseed > this.reseedInterval)\n throw new Error('Reseed is required');\n\n // Optional encoding\n if (typeof enc !== 'string') {\n addEnc = add;\n add = enc;\n enc = null;\n }\n\n // Optional additional data\n if (add) {\n add = utils.toArray(add, addEnc || 'hex');\n this._update(add);\n }\n\n var temp = [];\n while (temp.length < len) {\n this.V = this._hmac().update(this.V).digest();\n temp = temp.concat(this.V);\n }\n\n var res = temp.slice(0, len);\n this._update(add);\n this._reseed++;\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction KeyPair(ec, options) {\n this.ec = ec;\n this.priv = null;\n this.pub = null;\n\n // KeyPair(ec, { priv: ..., pub: ... })\n if (options.priv)\n this._importPrivate(options.priv, options.privEnc);\n if (options.pub)\n this._importPublic(options.pub, options.pubEnc);\n}\nmodule.exports = KeyPair;\n\nKeyPair.fromPublic = function fromPublic(ec, pub, enc) {\n if (pub instanceof KeyPair)\n return pub;\n\n return new KeyPair(ec, {\n pub: pub,\n pubEnc: enc,\n });\n};\n\nKeyPair.fromPrivate = function fromPrivate(ec, priv, enc) {\n if (priv instanceof KeyPair)\n return priv;\n\n return new KeyPair(ec, {\n priv: priv,\n privEnc: enc,\n });\n};\n\nKeyPair.prototype.validate = function validate() {\n var pub = this.getPublic();\n\n if (pub.isInfinity())\n return { result: false, reason: 'Invalid public key' };\n if (!pub.validate())\n return { result: false, reason: 'Public key is not a point' };\n if (!pub.mul(this.ec.curve.n).isInfinity())\n return { result: false, reason: 'Public key * N != O' };\n\n return { result: true, reason: null };\n};\n\nKeyPair.prototype.getPublic = function getPublic(compact, enc) {\n // compact is optional argument\n if (typeof compact === 'string') {\n enc = compact;\n compact = null;\n }\n\n if (!this.pub)\n this.pub = this.ec.g.mul(this.priv);\n\n if (!enc)\n return this.pub;\n\n return this.pub.encode(enc, compact);\n};\n\nKeyPair.prototype.getPrivate = function getPrivate(enc) {\n if (enc === 'hex')\n return this.priv.toString(16, 2);\n else\n return this.priv;\n};\n\nKeyPair.prototype._importPrivate = function _importPrivate(key, enc) {\n this.priv = new BN(key, enc || 16);\n\n // Ensure that the priv won't be bigger than n, otherwise we may fail\n // in fixed multiplication method\n this.priv = this.priv.umod(this.ec.curve.n);\n};\n\nKeyPair.prototype._importPublic = function _importPublic(key, enc) {\n if (key.x || key.y) {\n // Montgomery points only have an `x` coordinate.\n // Weierstrass/Edwards points on the other hand have both `x` and\n // `y` coordinates.\n if (this.ec.curve.type === 'mont') {\n assert(key.x, 'Need x coordinate');\n } else if (this.ec.curve.type === 'short' ||\n this.ec.curve.type === 'edwards') {\n assert(key.x && key.y, 'Need both x and y coordinate');\n }\n this.pub = this.ec.curve.point(key.x, key.y);\n return;\n }\n this.pub = this.ec.curve.decodePoint(key, enc);\n};\n\n// ECDH\nKeyPair.prototype.derive = function derive(pub) {\n if(!pub.validate()) {\n assert(pub.validate(), 'public point not validated');\n }\n return pub.mul(this.priv).getX();\n};\n\n// ECDSA\nKeyPair.prototype.sign = function sign(msg, enc, options) {\n return this.ec.sign(msg, this, enc, options);\n};\n\nKeyPair.prototype.verify = function verify(msg, signature) {\n return this.ec.verify(msg, signature, this);\n};\n\nKeyPair.prototype.inspect = function inspect() {\n return '<Key priv: ' + (this.priv && this.priv.toString(16, 2)) +\n ' pub: ' + (this.pub && this.pub.inspect()) + ' >';\n};\n","'use strict';\n\nvar BN = require('bn.js');\n\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction Signature(options, enc) {\n if (options instanceof Signature)\n return options;\n\n if (this._importDER(options, enc))\n return;\n\n assert(options.r && options.s, 'Signature without r or s');\n this.r = new BN(options.r, 16);\n this.s = new BN(options.s, 16);\n if (options.recoveryParam === undefined)\n this.recoveryParam = null;\n else\n this.recoveryParam = options.recoveryParam;\n}\nmodule.exports = Signature;\n\nfunction Position() {\n this.place = 0;\n}\n\nfunction getLength(buf, p) {\n var initial = buf[p.place++];\n if (!(initial & 0x80)) {\n return initial;\n }\n var octetLen = initial & 0xf;\n\n // Indefinite length or overflow\n if (octetLen === 0 || octetLen > 4) {\n return false;\n }\n\n var val = 0;\n for (var i = 0, off = p.place; i < octetLen; i++, off++) {\n val <<= 8;\n val |= buf[off];\n val >>>= 0;\n }\n\n // Leading zeroes\n if (val <= 0x7f) {\n return false;\n }\n\n p.place = off;\n return val;\n}\n\nfunction rmPadding(buf) {\n var i = 0;\n var len = buf.length - 1;\n while (!buf[i] && !(buf[i + 1] & 0x80) && i < len) {\n i++;\n }\n if (i === 0) {\n return buf;\n }\n return buf.slice(i);\n}\n\nSignature.prototype._importDER = function _importDER(data, enc) {\n data = utils.toArray(data, enc);\n var p = new Position();\n if (data[p.place++] !== 0x30) {\n return false;\n }\n var len = getLength(data, p);\n if (len === false) {\n return false;\n }\n if ((len + p.place) !== data.length) {\n return false;\n }\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var rlen = getLength(data, p);\n if (rlen === false) {\n return false;\n }\n var r = data.slice(p.place, rlen + p.place);\n p.place += rlen;\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var slen = getLength(data, p);\n if (slen === false) {\n return false;\n }\n if (data.length !== slen + p.place) {\n return false;\n }\n var s = data.slice(p.place, slen + p.place);\n if (r[0] === 0) {\n if (r[1] & 0x80) {\n r = r.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n if (s[0] === 0) {\n if (s[1] & 0x80) {\n s = s.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n\n this.r = new BN(r);\n this.s = new BN(s);\n this.recoveryParam = null;\n\n return true;\n};\n\nfunction constructLength(arr, len) {\n if (len < 0x80) {\n arr.push(len);\n return;\n }\n var octets = 1 + (Math.log(len) / Math.LN2 >>> 3);\n arr.push(octets | 0x80);\n while (--octets) {\n arr.push((len >>> (octets << 3)) & 0xff);\n }\n arr.push(len);\n}\n\nSignature.prototype.toDER = function toDER(enc) {\n var r = this.r.toArray();\n var s = this.s.toArray();\n\n // Pad values\n if (r[0] & 0x80)\n r = [ 0 ].concat(r);\n // Pad values\n if (s[0] & 0x80)\n s = [ 0 ].concat(s);\n\n r = rmPadding(r);\n s = rmPadding(s);\n\n while (!s[0] && !(s[1] & 0x80)) {\n s = s.slice(1);\n }\n var arr = [ 0x02 ];\n constructLength(arr, r.length);\n arr = arr.concat(r);\n arr.push(0x02);\n constructLength(arr, s.length);\n var backHalf = arr.concat(s);\n var res = [ 0x30 ];\n constructLength(res, backHalf.length);\n res = res.concat(backHalf);\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar hash = require('hash.js');\nvar curves = require('../curves');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EDDSA(curve) {\n assert(curve === 'ed25519', 'only tested with ed25519 so far');\n\n if (!(this instanceof EDDSA))\n return new EDDSA(curve);\n\n curve = curves[curve].curve;\n this.curve = curve;\n this.g = curve.g;\n this.g.precompute(curve.n.bitLength() + 1);\n\n this.pointClass = curve.point().constructor;\n this.encodingLength = Math.ceil(curve.n.bitLength() / 8);\n this.hash = hash.sha512;\n}\n\nmodule.exports = EDDSA;\n\n/**\n* @param {Array|String} message - message bytes\n* @param {Array|String|KeyPair} secret - secret bytes or a keypair\n* @returns {Signature} - signature\n*/\nEDDSA.prototype.sign = function sign(message, secret) {\n message = parseBytes(message);\n var key = this.keyFromSecret(secret);\n var r = this.hashInt(key.messagePrefix(), message);\n var R = this.g.mul(r);\n var Rencoded = this.encodePoint(R);\n var s_ = this.hashInt(Rencoded, key.pubBytes(), message)\n .mul(key.priv());\n var S = r.add(s_).umod(this.curve.n);\n return this.makeSignature({ R: R, S: S, Rencoded: Rencoded });\n};\n\n/**\n* @param {Array} message - message bytes\n* @param {Array|String|Signature} sig - sig bytes\n* @param {Array|String|Point|KeyPair} pub - public key\n* @returns {Boolean} - true if public key matches sig of message\n*/\nEDDSA.prototype.verify = function verify(message, sig, pub) {\n message = parseBytes(message);\n sig = this.makeSignature(sig);\n var key = this.keyFromPublic(pub);\n var h = this.hashInt(sig.Rencoded(), key.pubBytes(), message);\n var SG = this.g.mul(sig.S());\n var RplusAh = sig.R().add(key.pub().mul(h));\n return RplusAh.eq(SG);\n};\n\nEDDSA.prototype.hashInt = function hashInt() {\n var hash = this.hash();\n for (var i = 0; i < arguments.length; i++)\n hash.update(arguments[i]);\n return utils.intFromLE(hash.digest()).umod(this.curve.n);\n};\n\nEDDSA.prototype.keyFromPublic = function keyFromPublic(pub) {\n return KeyPair.fromPublic(this, pub);\n};\n\nEDDSA.prototype.keyFromSecret = function keyFromSecret(secret) {\n return KeyPair.fromSecret(this, secret);\n};\n\nEDDSA.prototype.makeSignature = function makeSignature(sig) {\n if (sig instanceof Signature)\n return sig;\n return new Signature(this, sig);\n};\n\n/**\n* * https://tools.ietf.org/html/draft-josefsson-eddsa-ed25519-03#section-5.2\n*\n* EDDSA defines methods for encoding and decoding points and integers. These are\n* helper convenience methods, that pass along to utility functions implied\n* parameters.\n*\n*/\nEDDSA.prototype.encodePoint = function encodePoint(point) {\n var enc = point.getY().toArray('le', this.encodingLength);\n enc[this.encodingLength - 1] |= point.getX().isOdd() ? 0x80 : 0;\n return enc;\n};\n\nEDDSA.prototype.decodePoint = function decodePoint(bytes) {\n bytes = utils.parseBytes(bytes);\n\n var lastIx = bytes.length - 1;\n var normed = bytes.slice(0, lastIx).concat(bytes[lastIx] & ~0x80);\n var xIsOdd = (bytes[lastIx] & 0x80) !== 0;\n\n var y = utils.intFromLE(normed);\n return this.curve.pointFromY(y, xIsOdd);\n};\n\nEDDSA.prototype.encodeInt = function encodeInt(num) {\n return num.toArray('le', this.encodingLength);\n};\n\nEDDSA.prototype.decodeInt = function decodeInt(bytes) {\n return utils.intFromLE(bytes);\n};\n\nEDDSA.prototype.isPoint = function isPoint(val) {\n return val instanceof this.pointClass;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar cachedProperty = utils.cachedProperty;\n\n/**\n* @param {EDDSA} eddsa - instance\n* @param {Object} params - public/private key parameters\n*\n* @param {Array<Byte>} [params.secret] - secret seed bytes\n* @param {Point} [params.pub] - public key point (aka `A` in eddsa terms)\n* @param {Array<Byte>} [params.pub] - public key point encoded as bytes\n*\n*/\nfunction KeyPair(eddsa, params) {\n this.eddsa = eddsa;\n this._secret = parseBytes(params.secret);\n if (eddsa.isPoint(params.pub))\n this._pub = params.pub;\n else\n this._pubBytes = parseBytes(params.pub);\n}\n\nKeyPair.fromPublic = function fromPublic(eddsa, pub) {\n if (pub instanceof KeyPair)\n return pub;\n return new KeyPair(eddsa, { pub: pub });\n};\n\nKeyPair.fromSecret = function fromSecret(eddsa, secret) {\n if (secret instanceof KeyPair)\n return secret;\n return new KeyPair(eddsa, { secret: secret });\n};\n\nKeyPair.prototype.secret = function secret() {\n return this._secret;\n};\n\ncachedProperty(KeyPair, 'pubBytes', function pubBytes() {\n return this.eddsa.encodePoint(this.pub());\n});\n\ncachedProperty(KeyPair, 'pub', function pub() {\n if (this._pubBytes)\n return this.eddsa.decodePoint(this._pubBytes);\n return this.eddsa.g.mul(this.priv());\n});\n\ncachedProperty(KeyPair, 'privBytes', function privBytes() {\n var eddsa = this.eddsa;\n var hash = this.hash();\n var lastIx = eddsa.encodingLength - 1;\n\n var a = hash.slice(0, eddsa.encodingLength);\n a[0] &= 248;\n a[lastIx] &= 127;\n a[lastIx] |= 64;\n\n return a;\n});\n\ncachedProperty(KeyPair, 'priv', function priv() {\n return this.eddsa.decodeInt(this.privBytes());\n});\n\ncachedProperty(KeyPair, 'hash', function hash() {\n return this.eddsa.hash().update(this.secret()).digest();\n});\n\ncachedProperty(KeyPair, 'messagePrefix', function messagePrefix() {\n return this.hash().slice(this.eddsa.encodingLength);\n});\n\nKeyPair.prototype.sign = function sign(message) {\n assert(this._secret, 'KeyPair can only verify');\n return this.eddsa.sign(message, this);\n};\n\nKeyPair.prototype.verify = function verify(message, sig) {\n return this.eddsa.verify(message, sig, this);\n};\n\nKeyPair.prototype.getSecret = function getSecret(enc) {\n assert(this._secret, 'KeyPair is public only');\n return utils.encode(this.secret(), enc);\n};\n\nKeyPair.prototype.getPublic = function getPublic(enc) {\n return utils.encode(this.pubBytes(), enc);\n};\n\nmodule.exports = KeyPair;\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar cachedProperty = utils.cachedProperty;\nvar parseBytes = utils.parseBytes;\n\n/**\n* @param {EDDSA} eddsa - eddsa instance\n* @param {Array<Bytes>|Object} sig -\n* @param {Array<Bytes>|Point} [sig.R] - R point as Point or bytes\n* @param {Array<Bytes>|bn} [sig.S] - S scalar as bn or bytes\n* @param {Array<Bytes>} [sig.Rencoded] - R point encoded\n* @param {Array<Bytes>} [sig.Sencoded] - S scalar encoded\n*/\nfunction Signature(eddsa, sig) {\n this.eddsa = eddsa;\n\n if (typeof sig !== 'object')\n sig = parseBytes(sig);\n\n if (Array.isArray(sig)) {\n sig = {\n R: sig.slice(0, eddsa.encodingLength),\n S: sig.slice(eddsa.encodingLength),\n };\n }\n\n assert(sig.R && sig.S, 'Signature without R or S');\n\n if (eddsa.isPoint(sig.R))\n this._R = sig.R;\n if (sig.S instanceof BN)\n this._S = sig.S;\n\n this._Rencoded = Array.isArray(sig.R) ? sig.R : sig.Rencoded;\n this._Sencoded = Array.isArray(sig.S) ? sig.S : sig.Sencoded;\n}\n\ncachedProperty(Signature, 'S', function S() {\n return this.eddsa.decodeInt(this.Sencoded());\n});\n\ncachedProperty(Signature, 'R', function R() {\n return this.eddsa.decodePoint(this.Rencoded());\n});\n\ncachedProperty(Signature, 'Rencoded', function Rencoded() {\n return this.eddsa.encodePoint(this.R());\n});\n\ncachedProperty(Signature, 'Sencoded', function Sencoded() {\n return this.eddsa.encodeInt(this.S());\n});\n\nSignature.prototype.toBytes = function toBytes() {\n return this.Rencoded().concat(this.Sencoded());\n};\n\nSignature.prototype.toHex = function toHex() {\n return utils.encode(this.toBytes(), 'hex').toUpperCase();\n};\n\nmodule.exports = Signature;\n","'use strict'\n\nconst errcode = require('err-code')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst hmac = require('../hmac')\n\nconst cipherMap = {\n 'AES-128': {\n ivSize: 16,\n keySize: 16\n },\n 'AES-256': {\n ivSize: 16,\n keySize: 32\n },\n Blowfish: {\n ivSize: 8,\n cipherKeySize: 32\n }\n}\n\n// Generates a set of keys for each party by stretching the shared key.\n// (myIV, theirIV, myCipherKey, theirCipherKey, myMACKey, theirMACKey)\nmodule.exports = async (cipherType, hash, secret) => {\n const cipher = cipherMap[cipherType]\n\n if (!cipher) {\n const allowed = Object.keys(cipherMap).join(' / ')\n throw errcode(new Error(`unknown cipher type '${cipherType}'. Must be ${allowed}`), 'ERR_INVALID_CIPHER_TYPE')\n }\n\n if (!hash) {\n throw errcode(new Error('missing hash type'), 'ERR_MISSING_HASH_TYPE')\n }\n\n const cipherKeySize = cipher.keySize\n const ivSize = cipher.ivSize\n const hmacKeySize = 20\n const seed = uint8ArrayFromString('key expansion')\n const resultLength = 2 * (ivSize + cipherKeySize + hmacKeySize)\n\n const m = await hmac.create(hash, secret)\n let a = await m.digest(seed)\n\n const result = []\n let j = 0\n\n while (j < resultLength) {\n const b = await m.digest(uint8ArrayConcat([a, seed]))\n let todo = b.length\n\n if (j + todo > resultLength) {\n todo = resultLength - j\n }\n\n result.push(b)\n j += todo\n a = await m.digest(a)\n }\n\n const half = resultLength / 2\n const resultBuffer = uint8ArrayConcat(result)\n const r1 = resultBuffer.slice(0, half)\n const r2 = resultBuffer.slice(half, resultLength)\n\n const createKey = (res) => ({\n iv: res.slice(0, ivSize),\n cipherKey: res.slice(ivSize, ivSize + cipherKeySize),\n macKey: res.slice(ivSize + cipherKeySize)\n })\n\n return {\n k1: createKey(r1),\n k2: createKey(r2)\n }\n}\n","'use strict'\n\nconst webcrypto = require('../webcrypto')\nconst lengths = require('./lengths')\n\nconst hashTypes = {\n SHA1: 'SHA-1',\n SHA256: 'SHA-256',\n SHA512: 'SHA-512'\n}\n\nconst sign = async (key, data) => {\n const buf = await webcrypto.get().subtle.sign({ name: 'HMAC' }, key, data)\n return new Uint8Array(buf, buf.byteOffset, buf.byteLength)\n}\n\nexports.create = async function (hashType, secret) {\n const hash = hashTypes[hashType]\n\n const key = await webcrypto.get().subtle.importKey(\n 'raw',\n secret,\n {\n name: 'HMAC',\n hash: { name: hash }\n },\n false,\n ['sign']\n )\n\n return {\n async digest (data) { // eslint-disable-line require-await\n return sign(key, data)\n },\n length: lengths[hashType]\n }\n}\n","'use strict'\n\nmodule.exports = {\n SHA1: 20,\n SHA256: 32,\n SHA512: 64\n}\n","'use strict'\n\nconst ecdh = require('./ecdh')\n\n// Generates an ephemeral public key and returns a function that will compute\n// the shared secret key.\n//\n// Focuses only on ECDH now, but can be made more general in the future.\nmodule.exports = async (curve) => ecdh.generateEphmeralKeyPair(curve) // eslint-disable-line require-await\n","'use strict'\n\nconst errcode = require('err-code')\nconst webcrypto = require('../webcrypto')\nconst { base64urlToBuffer } = require('../util')\nconst validateCurveType = require('./validate-curve-type')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\nconst bits = {\n 'P-256': 256,\n 'P-384': 384,\n 'P-521': 521\n}\n\nexports.generateEphmeralKeyPair = async function (curve) {\n validateCurveType(Object.keys(bits), curve)\n const pair = await webcrypto.get().subtle.generateKey(\n {\n name: 'ECDH',\n namedCurve: curve\n },\n true,\n ['deriveBits']\n )\n\n // forcePrivate is used for testing only\n const genSharedKey = async (theirPub, forcePrivate) => {\n let privateKey\n\n if (forcePrivate) {\n privateKey = await webcrypto.get().subtle.importKey(\n 'jwk',\n unmarshalPrivateKey(curve, forcePrivate),\n {\n name: 'ECDH',\n namedCurve: curve\n },\n false,\n ['deriveBits']\n )\n } else {\n privateKey = pair.privateKey\n }\n\n const keys = [\n await webcrypto.get().subtle.importKey(\n 'jwk',\n unmarshalPublicKey(curve, theirPub),\n {\n name: 'ECDH',\n namedCurve: curve\n },\n false,\n []\n ),\n privateKey\n ]\n\n const buffer = await webcrypto.get().subtle.deriveBits(\n {\n name: 'ECDH',\n namedCurve: curve,\n public: keys[0]\n },\n keys[1],\n bits[curve]\n )\n\n return new Uint8Array(buffer, buffer.byteOffset, buffer.byteLength)\n }\n\n const publicKey = await webcrypto.get().subtle.exportKey('jwk', pair.publicKey)\n\n return {\n key: marshalPublicKey(publicKey),\n genSharedKey\n }\n}\n\nconst curveLengths = {\n 'P-256': 32,\n 'P-384': 48,\n 'P-521': 66\n}\n\n// Marshal converts a jwk encodec ECDH public key into the\n// form specified in section 4.3.6 of ANSI X9.62. (This is the format\n// go-ipfs uses)\nfunction marshalPublicKey (jwk) {\n const byteLen = curveLengths[jwk.crv]\n\n return uint8ArrayConcat([\n Uint8Array.from([4]), // uncompressed point\n base64urlToBuffer(jwk.x, byteLen),\n base64urlToBuffer(jwk.y, byteLen)\n ], 1 + byteLen * 2)\n}\n\n// Unmarshal converts a point, serialized by Marshal, into an jwk encoded key\nfunction unmarshalPublicKey (curve, key) {\n const byteLen = curveLengths[curve]\n\n if (uint8ArrayEquals(!key.slice(0, 1), Uint8Array.from([4]))) {\n throw errcode(new Error('Cannot unmarshal public key - invalid key format'), 'ERR_INVALID_KEY_FORMAT')\n }\n\n return {\n kty: 'EC',\n crv: curve,\n x: uint8ArrayToString(key.slice(1, byteLen + 1), 'base64url'),\n y: uint8ArrayToString(key.slice(1 + byteLen), 'base64url'),\n ext: true\n }\n}\n\nconst unmarshalPrivateKey = (curve, key) => ({\n ...unmarshalPublicKey(curve, key.public),\n d: uint8ArrayToString(key.private, 'base64url')\n})\n","'use strict'\n\nconst errcode = require('err-code')\n\nmodule.exports = function (curveTypes, type) {\n if (!curveTypes.includes(type)) {\n const names = curveTypes.join(' / ')\n throw errcode(new Error(`Unknown curve: ${type}. Must be ${names}`), 'ERR_INVALID_CURVE')\n }\n}\n","'use strict';\n\nfunction withIs(Class, { className, symbolName }) {\n const symbol = Symbol.for(symbolName);\n\n const ClassIsWrapper = {\n // The code below assigns the class wrapper to an object to trick\n // JavaScript engines to show the name of the extended class when\n // logging an instances.\n // We are assigning an anonymous class (class wrapper) to the object\n // with key `className` to keep the correct name.\n // If this is not supported it falls back to logging `ClassIsWrapper`.\n [className]: class extends Class {\n constructor(...args) {\n super(...args);\n Object.defineProperty(this, symbol, { value: true });\n }\n\n get [Symbol.toStringTag]() {\n return className;\n }\n },\n }[className];\n\n ClassIsWrapper[`is${className}`] = (obj) => !!(obj && obj[symbol]);\n\n return ClassIsWrapper;\n}\n\nfunction withIsProto(Class, { className, symbolName, withoutNew }) {\n const symbol = Symbol.for(symbolName);\n\n /* eslint-disable object-shorthand */\n const ClassIsWrapper = {\n [className]: function (...args) {\n if (withoutNew && !(this instanceof ClassIsWrapper)) {\n return new ClassIsWrapper(...args);\n }\n\n const _this = Class.call(this, ...args) || this;\n\n if (_this && !_this[symbol]) {\n Object.defineProperty(_this, symbol, { value: true });\n }\n\n return _this;\n },\n }[className];\n /* eslint-enable object-shorthand */\n\n ClassIsWrapper.prototype = Object.create(Class.prototype);\n ClassIsWrapper.prototype.constructor = ClassIsWrapper;\n\n Object.defineProperty(ClassIsWrapper.prototype, Symbol.toStringTag, {\n get() {\n return className;\n },\n });\n\n ClassIsWrapper[`is${className}`] = (obj) => !!(obj && obj[symbol]);\n\n return ClassIsWrapper;\n}\n\nmodule.exports = withIs;\nmodule.exports.proto = withIsProto;\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-peer-id\"] || ($protobuf.roots[\"libp2p-peer-id\"] = {});\n\n$root.PeerIdProto = (function() {\n\n /**\n * Properties of a PeerIdProto.\n * @exports IPeerIdProto\n * @interface IPeerIdProto\n * @property {Uint8Array} id PeerIdProto id\n * @property {Uint8Array|null} [pubKey] PeerIdProto pubKey\n * @property {Uint8Array|null} [privKey] PeerIdProto privKey\n */\n\n /**\n * Constructs a new PeerIdProto.\n * @exports PeerIdProto\n * @classdesc Represents a PeerIdProto.\n * @implements IPeerIdProto\n * @constructor\n * @param {IPeerIdProto=} [p] Properties to set\n */\n function PeerIdProto(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * PeerIdProto id.\n * @member {Uint8Array} id\n * @memberof PeerIdProto\n * @instance\n */\n PeerIdProto.prototype.id = $util.newBuffer([]);\n\n /**\n * PeerIdProto pubKey.\n * @member {Uint8Array} pubKey\n * @memberof PeerIdProto\n * @instance\n */\n PeerIdProto.prototype.pubKey = $util.newBuffer([]);\n\n /**\n * PeerIdProto privKey.\n * @member {Uint8Array} privKey\n * @memberof PeerIdProto\n * @instance\n */\n PeerIdProto.prototype.privKey = $util.newBuffer([]);\n\n /**\n * Encodes the specified PeerIdProto message. Does not implicitly {@link PeerIdProto.verify|verify} messages.\n * @function encode\n * @memberof PeerIdProto\n * @static\n * @param {IPeerIdProto} m PeerIdProto message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PeerIdProto.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(10).bytes(m.id);\n if (m.pubKey != null && Object.hasOwnProperty.call(m, \"pubKey\"))\n w.uint32(18).bytes(m.pubKey);\n if (m.privKey != null && Object.hasOwnProperty.call(m, \"privKey\"))\n w.uint32(26).bytes(m.privKey);\n return w;\n };\n\n /**\n * Decodes a PeerIdProto message from the specified reader or buffer.\n * @function decode\n * @memberof PeerIdProto\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PeerIdProto} PeerIdProto\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PeerIdProto.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PeerIdProto();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.id = r.bytes();\n break;\n case 2:\n m.pubKey = r.bytes();\n break;\n case 3:\n m.privKey = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty(\"id\"))\n throw $util.ProtocolError(\"missing required 'id'\", { instance: m });\n return m;\n };\n\n /**\n * Creates a PeerIdProto message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PeerIdProto\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {PeerIdProto} PeerIdProto\n */\n PeerIdProto.fromObject = function fromObject(d) {\n if (d instanceof $root.PeerIdProto)\n return d;\n var m = new $root.PeerIdProto();\n if (d.id != null) {\n if (typeof d.id === \"string\")\n $util.base64.decode(d.id, m.id = $util.newBuffer($util.base64.length(d.id)), 0);\n else if (d.id.length)\n m.id = d.id;\n }\n if (d.pubKey != null) {\n if (typeof d.pubKey === \"string\")\n $util.base64.decode(d.pubKey, m.pubKey = $util.newBuffer($util.base64.length(d.pubKey)), 0);\n else if (d.pubKey.length)\n m.pubKey = d.pubKey;\n }\n if (d.privKey != null) {\n if (typeof d.privKey === \"string\")\n $util.base64.decode(d.privKey, m.privKey = $util.newBuffer($util.base64.length(d.privKey)), 0);\n else if (d.privKey.length)\n m.privKey = d.privKey;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a PeerIdProto message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PeerIdProto\n * @static\n * @param {PeerIdProto} m PeerIdProto\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n PeerIdProto.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.id = \"\";\n else {\n d.id = [];\n if (o.bytes !== Array)\n d.id = $util.newBuffer(d.id);\n }\n if (o.bytes === String)\n d.pubKey = \"\";\n else {\n d.pubKey = [];\n if (o.bytes !== Array)\n d.pubKey = $util.newBuffer(d.pubKey);\n }\n if (o.bytes === String)\n d.privKey = \"\";\n else {\n d.privKey = [];\n if (o.bytes !== Array)\n d.privKey = $util.newBuffer(d.privKey);\n }\n }\n if (m.id != null && m.hasOwnProperty(\"id\")) {\n d.id = o.bytes === String ? $util.base64.encode(m.id, 0, m.id.length) : o.bytes === Array ? Array.prototype.slice.call(m.id) : m.id;\n }\n if (m.pubKey != null && m.hasOwnProperty(\"pubKey\")) {\n d.pubKey = o.bytes === String ? $util.base64.encode(m.pubKey, 0, m.pubKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.pubKey) : m.pubKey;\n }\n if (m.privKey != null && m.hasOwnProperty(\"privKey\")) {\n d.privKey = o.bytes === String ? $util.base64.encode(m.privKey, 0, m.privKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.privKey) : m.privKey;\n }\n return d;\n };\n\n /**\n * Converts this PeerIdProto to JSON.\n * @function toJSON\n * @memberof PeerIdProto\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n PeerIdProto.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return PeerIdProto;\n})();\n\nmodule.exports = $root;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar add = require('./add.js');\nvar addAll = require('./add-all.js');\nvar ls = require('./ls.js');\nvar rm = require('./rm.js');\nvar rmAll = require('./rm-all.js');\n\nclass PinAPI {\n constructor({codecs, repo}) {\n const addAll$1 = addAll.createAddAll({\n codecs,\n repo\n });\n this.addAll = addAll$1;\n this.add = add.createAdd({ addAll: addAll$1 });\n const rmAll$1 = rmAll.createRmAll({\n codecs,\n repo\n });\n this.rmAll = rmAll$1;\n this.rm = rm.createRm({ rmAll: rmAll$1 });\n this.ls = ls.createLs({\n codecs,\n repo\n });\n this.remote = {\n add: (cid, options = {}) => Promise.reject(new Error('Not implemented')),\n ls: async function* (query, options = {}) {\n return Promise.reject(new Error('Not implemented'));\n },\n rm: (query, options = {}) => Promise.reject(new Error('Not implemented')),\n rmAll: (query, options = {}) => Promise.reject(new Error('Not implemented')),\n service: {\n add: (name, credentials) => Promise.reject(new Error('Not implemented')),\n rm: (name, options = {}) => Promise.reject(new Error('Not implemented')),\n ls: (options = {}) => Promise.reject(new Error('Not implemented'))\n }\n };\n }\n}\n\nexports.PinAPI = PinAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar last = require('it-last');\nvar cid = require('multiformats/cid');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createAdd({addAll}) {\n return (path, options = {}) => {\n let iter;\n const cid$1 = cid.CID.asCID(path);\n if (cid$1) {\n iter = addAll([{\n cid: cid$1,\n ...options\n }], options);\n } else {\n iter = addAll([{\n path: path.toString(),\n ...options\n }], options);\n }\n return last__default['default'](iter);\n };\n}\n\nexports.createAdd = createAdd;\n","'use strict'\n\n/**\n * Returns the last item of an (async) iterable, unless empty, in which case\n * return `undefined`.\n *\n * @template T\n * @param {AsyncIterable<T>|Iterable<T>} source\n */\nconst last = async (source) => {\n let res\n\n for await (const entry of source) {\n res = entry\n }\n\n return res\n}\n\nmodule.exports = last\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar pinTypes = require('ipfs-repo/pin-types');\n\nfunction createAddAll({repo, codecs}) {\n async function* addAll(source, options = {}) {\n const pinAdd = async function* () {\n for await (const {path, recursive, metadata} of normaliseInput.normaliseInput(source)) {\n const {cid} = await utils.resolvePath(repo, codecs, path);\n const {reason} = await repo.pins.isPinnedWithType(cid, [\n pinTypes.PinTypes.recursive,\n pinTypes.PinTypes.direct\n ]);\n if (reason === 'recursive' && !recursive) {\n throw new Error(`${ cid } already pinned recursively`);\n }\n if (recursive) {\n await repo.pins.pinRecursively(cid, { metadata });\n } else {\n await repo.pins.pinDirectly(cid, { metadata });\n }\n yield cid;\n }\n };\n const lock = Boolean(options.lock);\n if (!lock) {\n yield* pinAdd();\n return;\n }\n const release = await repo.gcLock.readLock();\n try {\n yield* pinAdd();\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(addAll);\n}\n\nexports.createAddAll = createAddAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar cid = require('multiformats/cid');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nasync function* normaliseInput(input) {\n if (input === null || input === undefined) {\n throw errCode__default['default'](new Error(`Unexpected input: ${ input }`), 'ERR_UNEXPECTED_INPUT');\n }\n const cid$1 = cid.CID.asCID(input);\n if (cid$1) {\n yield toPin({ cid: cid$1 });\n return;\n }\n if (input instanceof String || typeof input === 'string') {\n yield toPin({ path: input });\n return;\n }\n if (input.cid != null || input.path != null) {\n return yield toPin(input);\n }\n if (Symbol.iterator in input) {\n const iterator = input[Symbol.iterator]();\n const first = iterator.next();\n if (first.done)\n return iterator;\n if (cid.CID.asCID(first.value) || first.value instanceof String || typeof first.value === 'string') {\n yield toPin({ cid: first.value });\n for (const cid of iterator) {\n yield toPin({ cid });\n }\n return;\n }\n if (first.value.cid != null || first.value.path != null) {\n yield toPin(first.value);\n for (const obj of iterator) {\n yield toPin(obj);\n }\n return;\n }\n throw errCode__default['default'](new Error('Unexpected input: ' + typeof input), 'ERR_UNEXPECTED_INPUT');\n }\n if (Symbol.asyncIterator in input) {\n const iterator = input[Symbol.asyncIterator]();\n const first = await iterator.next();\n if (first.done)\n return iterator;\n if (cid.CID.asCID(first.value) || first.value instanceof String || typeof first.value === 'string') {\n yield toPin({ cid: first.value });\n for await (const cid of iterator) {\n yield toPin({ cid });\n }\n return;\n }\n if (first.value.cid != null || first.value.path != null) {\n yield toPin(first.value);\n for await (const obj of iterator) {\n yield toPin(obj);\n }\n return;\n }\n throw errCode__default['default'](new Error('Unexpected input: ' + typeof input), 'ERR_UNEXPECTED_INPUT');\n }\n throw errCode__default['default'](new Error('Unexpected input: ' + typeof input), 'ERR_UNEXPECTED_INPUT');\n}\nfunction toPin(input) {\n const path = input.cid || `${ input.path }`;\n if (!path) {\n throw errCode__default['default'](new Error('Unexpected input: Please path either a CID or an IPFS path'), 'ERR_UNEXPECTED_INPUT');\n }\n const pin = {\n path,\n recursive: input.recursive !== false\n };\n if (input.metadata != null) {\n pin.metadata = input.metadata;\n }\n return pin;\n}\n\nexports.normaliseInput = normaliseInput;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst PinTypes = {\n direct: 'direct',\n recursive: 'recursive',\n indirect: 'indirect',\n all: 'all'\n};\n\nexports.PinTypes = PinTypes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar errCode = require('err-code');\nvar pinTypes = require('ipfs-repo/pin-types');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction toPin(type, cid, metadata) {\n const output = {\n type,\n cid\n };\n if (metadata) {\n output.metadata = metadata;\n }\n return output;\n}\nfunction createLs({repo, codecs}) {\n async function* ls(options = {}) {\n let type = pinTypes.PinTypes.all;\n if (options.type) {\n type = options.type;\n if (!Object.keys(pinTypes.PinTypes).includes(type)) {\n throw errCode__default['default'](new Error('Invalid pin type'), 'ERR_INVALID_PIN_TYPE');\n }\n }\n if (options.paths) {\n let matched = false;\n for await (const {path} of normaliseInput.normaliseInput(options.paths)) {\n const {cid} = await utils.resolvePath(repo, codecs, path);\n const {reason, pinned, parent, metadata} = await repo.pins.isPinnedWithType(cid, type);\n if (!pinned) {\n throw errCode__default['default'](new Error(`path '${ path }' is not pinned`), 'ERR_NOT_PINNED');\n }\n switch (reason) {\n case pinTypes.PinTypes.direct:\n case pinTypes.PinTypes.recursive:\n matched = true;\n yield toPin(reason, cid, metadata);\n break;\n default:\n matched = true;\n yield toPin(`${ pinTypes.PinTypes.indirect } through ${ parent }`, cid, metadata);\n }\n }\n if (!matched) {\n throw new Error('No match found');\n }\n return;\n }\n if (type === pinTypes.PinTypes.recursive || type === pinTypes.PinTypes.all) {\n for await (const {cid, metadata} of repo.pins.recursiveKeys()) {\n yield toPin(pinTypes.PinTypes.recursive, cid, metadata);\n }\n }\n if (type === pinTypes.PinTypes.indirect || type === pinTypes.PinTypes.all) {\n for await (const cid of repo.pins.indirectKeys(options)) {\n yield toPin(pinTypes.PinTypes.indirect, cid);\n }\n }\n if (type === pinTypes.PinTypes.direct || type === pinTypes.PinTypes.all) {\n for await (const {cid, metadata} of repo.pins.directKeys()) {\n yield toPin(pinTypes.PinTypes.direct, cid, metadata);\n }\n }\n }\n return withTimeoutOption.withTimeoutOption(ls);\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar last = require('it-last');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createRm({rmAll}) {\n async function rm(path, options = {}) {\n const cid = await last__default['default'](rmAll([{\n path,\n ...options\n }], options));\n if (!cid) {\n throw new Error('CID expected');\n }\n return cid;\n }\n return rm;\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar pinTypes = require('ipfs-repo/pin-types');\n\nfunction createRmAll({repo, codecs}) {\n async function* rmAll(source, _options = {}) {\n const release = await repo.gcLock.readLock();\n try {\n for await (const {path, recursive} of normaliseInput.normaliseInput(source)) {\n const {cid} = await utils.resolvePath(repo, codecs, path);\n const {pinned, reason} = await repo.pins.isPinnedWithType(cid, pinTypes.PinTypes.all);\n if (!pinned) {\n throw new Error(`${ cid } is not pinned`);\n }\n switch (reason) {\n case pinTypes.PinTypes.recursive:\n if (!recursive) {\n throw new Error(`${ cid } is pinned recursively`);\n }\n await repo.pins.unpin(cid);\n yield cid;\n break;\n case pinTypes.PinTypes.direct:\n await repo.pins.unpin(cid);\n yield cid;\n break;\n default:\n throw new Error(`${ cid } is pinned indirectly under ${ reason }`);\n }\n }\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(rmAll);\n}\n\nexports.createRmAll = createRmAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('../ipns/index.js');\nvar config = require('../ipns/routing/config.js');\nvar offlineDatastore = require('../ipns/routing/offline-datastore.js');\nvar errors = require('../errors.js');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:components:ipns');\nclass IPNSAPI {\n constructor(options = { pass: '' }) {\n this.options = options;\n this.offline = null;\n this.online = null;\n }\n getIPNS() {\n const ipns = this.online || this.offline;\n if (ipns) {\n return ipns;\n } else {\n throw new errors.NotInitializedError();\n }\n }\n get routing() {\n return this.getIPNS().routing;\n }\n startOffline({repo, peerId, keychain}) {\n if (this.offline != null) {\n throw new errors.AlreadyInitializedError();\n }\n log('initializing IPNS keyspace');\n const routing = new offlineDatastore.OfflineDatastore(repo);\n const ipns = new index.IPNS(routing, repo.datastore, peerId, keychain, this.options);\n this.offline = ipns;\n }\n async startOnline({libp2p, repo, peerId, keychain}) {\n if (this.online != null) {\n throw new errors.AlreadyInitializedError();\n }\n const routing = config.createRouting({\n libp2p,\n repo,\n peerId,\n options: this.options\n });\n const ipns = new index.IPNS(routing, repo.datastore, peerId, keychain, this.options);\n await ipns.republisher.start();\n this.online = ipns;\n }\n async stop() {\n const ipns = this.online;\n if (ipns) {\n await ipns.republisher.stop();\n this.online = null;\n }\n }\n publish(privKey, value, lifetime) {\n return this.getIPNS().publish(privKey, value, lifetime);\n }\n resolve(name, options) {\n return this.getIPNS().resolve(name, options);\n }\n initializeKeyspace(privKey, value) {\n return this.getIPNS().initializeKeyspace(privKey, value);\n }\n}\n\nexports.IPNSAPI = IPNSAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar publisher = require('./publisher.js');\nvar republisher = require('./republisher.js');\nvar resolver = require('./resolver.js');\nvar tlru = require('../utils/tlru.js');\nvar toString = require('uint8arrays/to-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns'), { error: debug__default['default']('ipfs:ipns:error') });\nconst defaultRecordTtl = 60 * 1000;\nclass IPNS {\n constructor(routing, datastore, peerId, keychain, options) {\n this.publisher = new publisher.IpnsPublisher(routing, datastore);\n this.republisher = new republisher.IpnsRepublisher(this.publisher, datastore, peerId, keychain, options);\n this.resolver = new resolver.IpnsResolver(routing);\n this.cache = new tlru.TLRU(1000);\n this.routing = routing;\n }\n async publish(privKey, value, lifetime = publisher.IpnsPublisher.defaultRecordLifetime) {\n try {\n const peerId = await PeerId.createFromPrivKey(privKey.bytes);\n await this.publisher.publishWithEOL(privKey, value, lifetime);\n log(`IPNS value ${ toString.toString(value, 'base32') } was published correctly`);\n const id = peerId.toB58String();\n const ttEol = parseFloat(lifetime);\n const ttl = ttEol < defaultRecordTtl ? ttEol : defaultRecordTtl;\n this.cache.set(id, value, ttl);\n log(`IPNS value ${ toString.toString(value, 'base32') } was cached correctly`);\n return {\n name: id,\n value: value\n };\n } catch (err) {\n log.error(err);\n throw err;\n }\n }\n async resolve(name, options = {}) {\n if (typeof name !== 'string') {\n throw errCode__default['default'](new Error('name received is not valid'), 'ERR_INVALID_NAME');\n }\n if (!options.nocache && !options.recursive) {\n const id = name.split('/')[2];\n const result = this.cache.get(id);\n if (result) {\n return result;\n }\n }\n try {\n const result = await this.resolver.resolve(name, options);\n log(`IPNS record from ${ name } was resolved correctly`);\n return result;\n } catch (err) {\n log.error(err);\n throw err;\n }\n }\n async initializeKeyspace(privKey, value) {\n return this.publish(privKey, value, publisher.IpnsPublisher.defaultRecordLifetime);\n }\n}\n\nexports.IPNS = IPNS;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar key = require('interface-datastore/key');\nvar Errors = require('datastore-core/errors');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar toString = require('uint8arrays/to-string');\nvar equals = require('uint8arrays/equals');\nvar ipns = require('ipns');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:publisher'), { error: debug__default['default']('ipfs:ipns:publisher:error') });\nconst ERR_NOT_FOUND = Errors.notFoundError().code;\nconst defaultRecordLifetime = 60 * 60 * 1000;\nclass IpnsPublisher {\n constructor(routing, datastore) {\n this._routing = routing;\n this._datastore = datastore;\n }\n async publishWithEOL(privKey, value, lifetime) {\n if (!privKey || !privKey.bytes) {\n throw errCode__default['default'](new Error('invalid private key'), 'ERR_INVALID_PRIVATE_KEY');\n }\n const peerId = await PeerId__default['default'].createFromPrivKey(privKey.bytes);\n const record = await this._updateOrCreateRecord(privKey, value, lifetime, peerId);\n return this._putRecordToRouting(record, peerId);\n }\n publish(privKey, value) {\n return this.publishWithEOL(privKey, value, defaultRecordLifetime);\n }\n async _putRecordToRouting(record, peerId) {\n if (!PeerId__default['default'].isPeerId(peerId)) {\n const errMsg = 'peerId received is not valid';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_PEER_ID');\n }\n const publicKey = peerId._pubKey;\n const embedPublicKeyRecord = await ipns__namespace.embedPublicKey(publicKey, record);\n const keys = ipns__namespace.getIdKeys(peerId.toBytes());\n await this._publishEntry(keys.routingKey, embedPublicKeyRecord || record);\n await this._publishPublicKey(keys.routingPubKey, publicKey);\n return embedPublicKeyRecord || record;\n }\n async _publishEntry(key$1, entry) {\n const k = key.Key.asKey(key$1);\n if (!k) {\n const errMsg = 'datastore key does not have a valid format';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_DATASTORE_KEY');\n }\n let entryData;\n try {\n entryData = ipns__namespace.marshal(entry);\n } catch (err) {\n log.error(err);\n throw err;\n }\n try {\n const res = await this._routing.put(k.uint8Array(), entryData);\n log(`ipns record for ${ toString.toString(k.uint8Array(), 'base64') } was stored in the routing`);\n return res;\n } catch (err) {\n const errMsg = `ipns record for ${ toString.toString(k.uint8Array(), 'base64') } could not be stored in the routing`;\n log.error(errMsg);\n log.error(err);\n throw errCode__default['default'](new Error(errMsg), 'ERR_PUTTING_TO_ROUTING');\n }\n }\n async _publishPublicKey(key$1, publicKey) {\n const k = key.Key.asKey(key$1);\n if (!k) {\n const errMsg = 'datastore key does not have a valid format';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_DATASTORE_KEY');\n }\n if (!publicKey || !publicKey.bytes) {\n const errMsg = 'one or more of the provided parameters are not defined';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_UNDEFINED_PARAMETER');\n }\n try {\n const res = await this._routing.put(k.uint8Array(), publicKey.bytes);\n log(`public key for ${ toString.toString(k.uint8Array(), 'base64') } was stored in the routing`);\n return res;\n } catch (err) {\n const errMsg = `public key for ${ toString.toString(k.uint8Array(), 'base64') } could not be stored in the routing`;\n log.error(errMsg);\n log.error(err);\n throw errCode__default['default'](new Error(errMsg), 'ERR_PUTTING_TO_ROUTING');\n }\n }\n async _getPublished(peerId, options = {}) {\n if (!PeerId__default['default'].isPeerId(peerId)) {\n const errMsg = 'peerId received is not valid';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_PEER_ID');\n }\n const checkRouting = options.checkRouting !== false;\n try {\n const dsVal = await this._datastore.get(ipns__namespace.getLocalKey(peerId.id));\n return this._unmarshalData(dsVal);\n } catch (err) {\n if (err.code !== ERR_NOT_FOUND) {\n const errMsg = `unexpected error getting the ipns record ${ peerId.id } from datastore`;\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_UNEXPECTED_DATASTORE_RESPONSE');\n }\n if (!checkRouting) {\n throw errCode__default['default'](err, 'ERR_NOT_FOUND_AND_CHECK_ROUTING_NOT_ENABLED');\n }\n try {\n const keys = ipns__namespace.getIdKeys(peerId.toBytes());\n const res = await this._routing.get(keys.routingKey.uint8Array());\n return this._unmarshalData(res);\n } catch (err) {\n log.error(err);\n throw err;\n }\n }\n }\n _unmarshalData(data) {\n try {\n return ipns__namespace.unmarshal(data);\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_RECORD_DATA');\n }\n }\n async _updateOrCreateRecord(privKey, value, lifetime, peerId) {\n if (!PeerId__default['default'].isPeerId(peerId)) {\n const errMsg = 'peerId received is not valid';\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_INVALID_PEER_ID');\n }\n const getPublishedOptions = { checkRouting: true };\n let record;\n try {\n record = await this._getPublished(peerId, getPublishedOptions);\n } catch (err) {\n if (err.code !== ERR_NOT_FOUND) {\n const errMsg = `unexpected error when determining the last published IPNS record for ${ peerId.id } ${ err.stack }`;\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_DETERMINING_PUBLISHED_RECORD');\n }\n }\n let seqNumber = 0;\n if (record && record.sequence !== undefined) {\n seqNumber = !equals.equals(record.value, value) ? BigInt(record.sequence) + BigInt(1) : BigInt(record.sequence);\n }\n let entryData;\n try {\n entryData = await ipns__namespace.create(privKey, value, seqNumber, lifetime);\n } catch (err) {\n const errMsg = `ipns record for ${ value } could not be created`;\n log.error(err);\n throw errCode__default['default'](new Error(errMsg), 'ERR_CREATING_IPNS_RECORD');\n }\n try {\n const data = ipns__namespace.marshal(entryData);\n await this._datastore.put(ipns__namespace.getLocalKey(peerId.id), data);\n log(`ipns record for ${ toString.toString(value, 'base32') } was stored in the datastore`);\n return entryData;\n } catch (err) {\n const errMsg = `ipns record for ${ value } could not be stored in the datastore`;\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_STORING_IN_DATASTORE');\n }\n }\n}\nIpnsPublisher.defaultRecordLifetime = defaultRecordLifetime;\n\nexports.IpnsPublisher = IpnsPublisher;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction dbOpenFailedError(err) {\n err = err || new Error('Cannot open database');\n return errCode__default['default'](err, 'ERR_DB_OPEN_FAILED');\n}\nfunction dbDeleteFailedError(err) {\n err = err || new Error('Delete failed');\n return errCode__default['default'](err, 'ERR_DB_DELETE_FAILED');\n}\nfunction dbWriteFailedError(err) {\n err = err || new Error('Write failed');\n return errCode__default['default'](err, 'ERR_DB_WRITE_FAILED');\n}\nfunction notFoundError(err) {\n err = err || new Error('Not Found');\n return errCode__default['default'](err, 'ERR_NOT_FOUND');\n}\nfunction abortedError(err) {\n err = err || new Error('Aborted');\n return errCode__default['default'](err, 'ERR_ABORTED');\n}\n\nexports.abortedError = abortedError;\nexports.dbDeleteFailedError = dbDeleteFailedError;\nexports.dbOpenFailedError = dbOpenFailedError;\nexports.dbWriteFailedError = dbWriteFailedError;\nexports.notFoundError = notFoundError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar NanoDate = require('timestamp-nano');\nvar key = require('interface-datastore/key');\nvar crypto = require('libp2p-crypto');\nvar PeerId = require('peer-id');\nvar Digest = require('multiformats/hashes/digest');\nvar identity = require('multiformats/hashes/identity');\nvar errCode = require('err-code');\nvar base32 = require('multiformats/bases/base32');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar concat = require('uint8arrays/concat');\nvar equals = require('uint8arrays/equals');\nvar cborg = require('cborg');\nvar Long = require('long');\nvar debug = require('debug');\nvar ipns = require('./pb/ipns.js');\nvar utils = require('./utils.js');\nvar errors = require('./errors.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar NanoDate__default = /*#__PURE__*/_interopDefaultLegacy(NanoDate);\nvar crypto__default = /*#__PURE__*/_interopDefaultLegacy(crypto);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar cborg__namespace = /*#__PURE__*/_interopNamespace(cborg);\nvar Long__default = /*#__PURE__*/_interopDefaultLegacy(Long);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('jsipns'), { error: debug__default['default']('jsipns:error') });\nconst ID_MULTIHASH_CODE = identity.identity.code;\nconst IPNS_PREFIX = fromString.fromString('/ipns/');\nconst namespace = '/ipns/';\nconst namespaceLength = namespace.length;\nconst create = (privateKey, value, seq, lifetime) => {\n const expirationDate = new NanoDate__default['default'](Date.now() + Number(lifetime));\n const validityType = ipns.IpnsEntry.ValidityType.EOL;\n const [ms, ns] = lifetime.toString().split('.');\n const lifetimeNs = BigInt(ms) * BigInt(100000) + BigInt(ns || 0);\n return _create(privateKey, value, seq, validityType, expirationDate, lifetimeNs);\n};\nconst createWithExpiration = (privateKey, value, seq, expiration) => {\n const expirationDate = NanoDate__default['default'].fromString(expiration);\n const validityType = ipns.IpnsEntry.ValidityType.EOL;\n const ttlMs = expirationDate.toDate().getTime() - Date.now();\n const ttlNs = BigInt(ttlMs) * BigInt(100000) + BigInt(expirationDate.getNano());\n return _create(privateKey, value, seq, validityType, expirationDate, ttlNs);\n};\nconst _create = async (privateKey, value, seq, validityType, expirationDate, ttl) => {\n seq = BigInt(seq);\n const isoValidity = fromString.fromString(expirationDate.toString());\n const signatureV1 = await sign(privateKey, value, validityType, isoValidity);\n const data = createCborData(value, isoValidity, validityType, seq, ttl);\n const sigData = ipnsEntryDataForV2Sig(data);\n const signatureV2 = await privateKey.sign(sigData);\n const entry = {\n value,\n signature: signatureV1,\n validityType: validityType,\n validity: isoValidity,\n sequence: seq,\n ttl,\n signatureV2,\n data\n };\n log(`ipns entry for ${ value } created`);\n return entry;\n};\nconst createCborData = (value, validity, validityType, sequence, ttl) => {\n const data = {\n Value: value,\n Validity: validity,\n ValidityType: validityType,\n Sequence: sequence,\n TTL: ttl\n };\n return cborg__namespace.encode(data);\n};\nconst validate = async (publicKey, entry) => {\n const {value, validityType, validity} = entry;\n let dataForSignature;\n let signature;\n if (entry.signatureV2 && entry.data) {\n signature = entry.signatureV2;\n dataForSignature = ipnsEntryDataForV2Sig(entry.data);\n validateCborDataMatchesPbData(entry);\n } else {\n signature = entry.signature;\n dataForSignature = ipnsEntryDataForV1Sig(value, validityType, validity);\n }\n let isValid;\n try {\n isValid = await publicKey.verify(dataForSignature, signature);\n } catch (err) {\n isValid = false;\n }\n if (!isValid) {\n log.error('record signature verification failed');\n throw errCode__default['default'](new Error('record signature verification failed'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (validityType === ipns.IpnsEntry.ValidityType.EOL) {\n let validityDate;\n try {\n validityDate = utils.parseRFC3339(toString.toString(validity));\n } catch (e) {\n log.error('unrecognized validity format (not an rfc3339 format)');\n throw errCode__default['default'](new Error('unrecognized validity format (not an rfc3339 format)'), errors.ERR_UNRECOGNIZED_FORMAT);\n }\n if (validityDate.getTime() < Date.now()) {\n log.error('record has expired');\n throw errCode__default['default'](new Error('record has expired'), errors.ERR_IPNS_EXPIRED_RECORD);\n }\n } else if (validityType) {\n log.error('unrecognized validity type');\n throw errCode__default['default'](new Error('unrecognized validity type'), errors.ERR_UNRECOGNIZED_VALIDITY);\n }\n log(`ipns entry for ${ value } is valid`);\n};\nconst validateCborDataMatchesPbData = entry => {\n if (!entry.data) {\n throw errCode__default['default'](new Error('Record data is missing'), errors.ERR_INVALID_RECORD_DATA);\n }\n const data = cborg__namespace.decode(entry.data);\n if (Number.isInteger(data.Sequence)) {\n data.Sequence = BigInt(data.Sequence);\n }\n if (Number.isInteger(data.TTL)) {\n data.TTL = BigInt(data.TTL);\n }\n if (!equals.equals(data.Value, entry.value)) {\n throw errCode__default['default'](new Error('Field \"value\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (!equals.equals(data.Validity, entry.validity)) {\n throw errCode__default['default'](new Error('Field \"validity\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (data.ValidityType !== entry.validityType) {\n throw errCode__default['default'](new Error('Field \"validityType\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (data.Sequence !== entry.sequence) {\n throw errCode__default['default'](new Error('Field \"sequence\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n if (data.TTL !== entry.ttl) {\n throw errCode__default['default'](new Error('Field \"ttl\" did not match between protobuf and CBOR'), errors.ERR_SIGNATURE_VERIFICATION);\n }\n};\nconst embedPublicKey = async (publicKey, entry) => {\n if (!publicKey || !publicKey.bytes || !entry) {\n const error = new Error('one or more of the provided parameters are not defined');\n log.error(error);\n throw errCode__default['default'](error, errors.ERR_UNDEFINED_PARAMETER);\n }\n let peerId;\n try {\n peerId = await PeerId__default['default'].createFromPubKey(publicKey.bytes);\n } catch (err) {\n throw errCode__default['default'](err, errors.ERR_PEER_ID_FROM_PUBLIC_KEY);\n }\n let extractedPublicKey;\n try {\n extractedPublicKey = extractPublicKeyFromId(peerId);\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](err, errors.ERR_PUBLIC_KEY_FROM_ID);\n }\n if (extractedPublicKey) {\n return null;\n }\n try {\n entry.pubKey = crypto__default['default'].keys.marshalPublicKey(publicKey);\n } catch (err) {\n log.error(err);\n throw err;\n }\n return entry;\n};\nconst extractPublicKey = async (peerId, entry) => {\n if (!entry || !peerId) {\n const error = new Error('one or more of the provided parameters are not defined');\n log.error(error);\n throw errCode__default['default'](error, errors.ERR_UNDEFINED_PARAMETER);\n }\n let pubKey;\n if (entry.pubKey) {\n try {\n pubKey = crypto__default['default'].keys.unmarshalPublicKey(entry.pubKey);\n } catch (err) {\n log.error(err);\n throw err;\n }\n const otherId = await PeerId__default['default'].createFromPubKey(entry.pubKey);\n if (!otherId.equals(peerId)) {\n throw errCode__default['default'](new Error('Embedded public key did not match PeerID'), errors.ERR_INVALID_EMBEDDED_KEY);\n }\n } else if (peerId.pubKey) {\n pubKey = peerId.pubKey;\n }\n if (pubKey) {\n return pubKey;\n }\n throw errCode__default['default'](new Error('no public key is available'), errors.ERR_UNDEFINED_PARAMETER);\n};\nconst rawStdEncoding = key => base32.base32upper.encode(key).slice(1);\nconst getLocalKey = key$1 => new key.Key(`/ipns/${ rawStdEncoding(key$1) }`);\nconst getIdKeys = pid => {\n const pkBuffer = fromString.fromString('/pk/');\n const ipnsBuffer = fromString.fromString('/ipns/');\n return {\n routingPubKey: new key.Key(concat.concat([\n pkBuffer,\n pid\n ]), false),\n pkKey: new key.Key(rawStdEncoding(concat.concat([\n pkBuffer,\n pid\n ]))),\n routingKey: new key.Key(concat.concat([\n ipnsBuffer,\n pid\n ]), false),\n ipnsKey: new key.Key(rawStdEncoding(concat.concat([\n ipnsBuffer,\n pid\n ])))\n };\n};\nconst sign = (privateKey, value, validityType, validity) => {\n try {\n const dataForSignature = ipnsEntryDataForV1Sig(value, validityType, validity);\n return privateKey.sign(dataForSignature);\n } catch (error) {\n log.error('record signature creation failed');\n throw errCode__default['default'](new Error('record signature creation failed: ' + error.message), errors.ERR_SIGNATURE_CREATION);\n }\n};\nconst getValidityType = validityType => {\n if (validityType.toString() === '0') {\n return 'EOL';\n }\n const error = new Error(`unrecognized validity type ${ validityType.toString() }`);\n log.error(error);\n throw errCode__default['default'](error, errors.ERR_UNRECOGNIZED_VALIDITY);\n};\nconst ipnsEntryDataForV1Sig = (value, validityType, validity) => {\n const validityTypeBuffer = fromString.fromString(getValidityType(validityType));\n return concat.concat([\n value,\n validity,\n validityTypeBuffer\n ]);\n};\nconst ipnsEntryDataForV2Sig = data => {\n const entryData = fromString.fromString('ipns-signature:');\n return concat.concat([\n entryData,\n data\n ]);\n};\nconst extractPublicKeyFromId = peerId => {\n const digest = Digest__namespace.decode(peerId.id);\n if (digest.code !== ID_MULTIHASH_CODE) {\n return null;\n }\n return crypto__default['default'].keys.unmarshalPublicKey(digest.digest);\n};\nconst marshal = obj => {\n return ipns.IpnsEntry.encode({\n ...obj,\n sequence: Long__default['default'].fromString(obj.sequence.toString()),\n ttl: obj.ttl == null ? undefined : Long__default['default'].fromString(obj.ttl.toString())\n }).finish();\n};\nconst unmarshal = buf => {\n const message = ipns.IpnsEntry.decode(buf);\n const object = ipns.IpnsEntry.toObject(message, {\n defaults: false,\n arrays: true,\n objects: false\n });\n return {\n value: object.value,\n signature: object.signature,\n validityType: object.validityType,\n validity: object.validity,\n sequence: Object.hasOwnProperty.call(object, 'sequence') ? BigInt(`${ object.sequence }`) : 0,\n pubKey: object.pubKey,\n ttl: Object.hasOwnProperty.call(object, 'ttl') ? BigInt(`${ object.ttl }`) : undefined,\n signatureV2: object.signatureV2,\n data: object.data\n };\n};\nconst validator = {\n validate: async (marshalledData, key) => {\n const receivedEntry = unmarshal(marshalledData);\n const bufferId = key.slice(IPNS_PREFIX.length);\n const peerId = PeerId__default['default'].createFromBytes(bufferId);\n const pubKey = await extractPublicKey(peerId, receivedEntry);\n await validate(pubKey, receivedEntry);\n },\n select: (dataA, dataB) => {\n const entryA = unmarshal(dataA);\n const entryB = unmarshal(dataB);\n if (entryA.signatureV2 && !entryB.signatureV2) {\n return 0;\n } else if (entryB.signatureV2 && !entryA.signatureV2) {\n return 1;\n }\n if (entryA.sequence > entryB.sequence) {\n return 0;\n } else if (entryA.sequence < entryB.sequence) {\n return 1;\n }\n const entryAValidityDate = utils.parseRFC3339(toString.toString(entryA.validity));\n const entryBValidityDate = utils.parseRFC3339(toString.toString(entryB.validity));\n return entryBValidityDate.getTime() > entryAValidityDate.getTime() ? 1 : 0;\n }\n};\n\nexports.create = create;\nexports.createWithExpiration = createWithExpiration;\nexports.embedPublicKey = embedPublicKey;\nexports.extractPublicKey = extractPublicKey;\nexports.getIdKeys = getIdKeys;\nexports.getLocalKey = getLocalKey;\nexports.marshal = marshal;\nexports.namespace = namespace;\nexports.namespaceLength = namespaceLength;\nexports.unmarshal = unmarshal;\nexports.validate = validate;\nexports.validator = validator;\n","/**\n * Timestamp for 64-bit time_t, nanosecond precision and strftime\n *\n * @author Yusuke Kawasaki\n * @license MIT\n * @see https://github.com/kawanet/timestamp-nano\n */\n\nvar Timestamp = (function() {\n if (\"undefined\" !== typeof module) module.exports = Timestamp;\n\n var SEC_DAY = 24 * 3600; // seconds per day\n var YEAR_SLOT = 3200; // years per slot\n var DAY_SLOT = (365 * 400 + 97) * YEAR_SLOT / 400; // days per slot\n var SEC_SLOT = SEC_DAY * DAY_SLOT; // seconds per slot\n var MSEC_SLOT = SEC_SLOT * 1000; // mseconds per slot\n\n // 15.9.1.1 Time Values and Time Range\n // The actual range of times supported by ECMAScript Date objects is\n // exactly –100,000,000 days to 100,000,000 days measured relative to\n // midnight at the beginning of 01 January, 1970 UTC.\n var MAX_MSEC = 1000 * 10000 * 10000 * SEC_DAY;\n\n var BIT24 = 0x1000000;\n var BIT32 = 0x10000 * 0x10000;\n var DEC6 = 1000 * 1000;\n var DEC9 = 1000 * 1000 * 1000;\n var ZERO9 = \"000000000\";\n\n var trunc = Math.trunc || Math_trunc;\n var P = Timestamp.prototype;\n\n // static methods\n Timestamp.fromDate = fromDate;\n Timestamp.fromInt64BE = buildFromInt64(0, 1, 2, 3, 0, 4);\n Timestamp.fromInt64LE = buildFromInt64(3, 2, 1, 0, 4, 0);\n Timestamp.fromString = fromString;\n Timestamp.fromTimeT = fromTimeT;\n\n // private properties\n P.year = 0; // Offset number for year precision\n P.time = 0; // Milliseconds from epoch\n P.nano = 0; // Offset number for nanosecond precision\n\n // instance methods\n P.addNano = addNano;\n P.getNano = getNano;\n P.getTimeT = getTimeT;\n P.getYear = getYear;\n P.toDate = toDate;\n P.toJSON = toJSON;\n P.toString = toString;\n P.writeInt64BE = buildWriteInt64(0, 1, 2, 3, 0, 4);\n P.writeInt64LE = buildWriteInt64(3, 2, 1, 0, 4, 0);\n\n var FMT_JSON = \"%Y-%m-%dT%H:%M:%S.%NZ\";\n\n var FMT_MONTH = [\n \"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"\n ];\n\n var FMT_DAY = [\n \"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"\n ];\n\n var FMT_STRING = {\n \"%\": \"%\",\n F: \"%Y-%m-%d\",\n n: \"\\n\",\n R: \"%H:%M\",\n T: \"%H:%M:%S\",\n t: \"\\t\",\n X: \"%T\",\n Z: \"GMT\",\n z: \"+0000\"\n };\n\n return Timestamp;\n\n function Timestamp(time, nano, year) {\n var ts = this;\n if (!(ts instanceof Timestamp)) return new Timestamp(time, nano, year);\n ts.time = +time || 0;\n ts.nano = +nano || 0;\n ts.year = +year || 0;\n normalize(ts);\n }\n\n function getYear() {\n var year = this.toDate().getUTCFullYear();\n return year + this.year;\n }\n\n function normalize(ts) {\n var year = ts.year;\n var time = ts.time;\n var nano = ts.nano;\n var changed;\n var slot;\n\n // normalize nano\n if (nano < 0 || DEC6 <= nano) {\n var n = Math.floor(nano / DEC6);\n nano -= n * DEC6;\n time += n;\n changed = 1;\n }\n\n var y = year % YEAR_SLOT;\n if (time < -MAX_MSEC || MAX_MSEC < time || y) {\n // shrink time into the minimal slot\n slot = trunc(time / MSEC_SLOT);\n if (slot) {\n year += slot * YEAR_SLOT;\n time -= slot * MSEC_SLOT;\n }\n\n // add year offset smaller than a slot\n var dt = newDate(time);\n dt.setUTCFullYear(y + dt.getUTCFullYear());\n year -= y;\n time = +dt;\n\n // use full range of 100 million days.\n slot = trunc(year / YEAR_SLOT);\n var total = time + slot * MSEC_SLOT;\n if (slot && -MAX_MSEC <= total && total <= MAX_MSEC) {\n year -= slot * YEAR_SLOT;\n time = total;\n }\n\n changed = 1;\n }\n\n if (changed) {\n ts.year = year;\n ts.time = time;\n ts.nano = nano;\n }\n\n return ts;\n }\n\n function toDate() {\n var ts = normalize(this);\n return newDate(ts.time);\n }\n\n function newDate(time) {\n var dt = new Date(0);\n dt.setTime(time);\n return dt;\n }\n\n function addNano(nano) {\n this.nano += +nano || 0;\n return this;\n }\n\n function getNano() {\n var ts = normalize(this);\n return ((ts.time % 1000) * DEC6 + (+ts.nano) + DEC9) % DEC9;\n }\n\n function fromString(string) {\n var time;\n var ts = new Timestamp();\n string += \"\";\n\n var array = string.replace(/^\\s*[+\\-]?\\d+/, function(match) {\n var year = +match;\n // Use only years around 1970 to avoid Date's terrible behavior:\n // 15.9.4.3 Date.UTC\n // If y is not NaN and 0 <= y <= 99, then let yr be 1900+y\n var y = 1970 + ((year - 1970) % 400);\n ts.year = year - y;\n return y;\n }).replace(/(?:Z|([+\\-]\\d{2}):?(\\d{2}))$/, function(match, hour, min) {\n // time zone\n if (hour < 0) min *= -1;\n time = ((+hour) * 60 + (+min)) * 60000;\n return \"\";\n }).replace(/\\.\\d+$/, function(match) {\n // nanoseconds\n ts.nano = +((match + ZERO9).substr(1, 9));\n return \"\";\n }).split(/\\D+/);\n\n if (array.length > 1) {\n array[1]--; // month starts from 0\n } else {\n array[1] = 0;\n }\n\n ts.time = time = Date.UTC.apply(Date, array) - (time || 0);\n\n if (isNaN(time)) {\n throw new TypeError(\"Invalid Date\");\n }\n\n return normalize(ts);\n }\n\n function fromDate(date) {\n return new Timestamp(+date);\n }\n\n function fromTimeT(time) {\n return fromTime(time, 0);\n }\n\n function fromTime(low, high) {\n high |= 0;\n high *= BIT32;\n low = +low || 0;\n\n // slot count\n var slot = trunc(high / SEC_SLOT) + trunc(low / SEC_SLOT);\n\n // seconds within slot\n var second = (high % SEC_SLOT) + (low % SEC_SLOT);\n\n // slot offset\n var offset = trunc(second / SEC_SLOT);\n if (offset) {\n slot += offset;\n second -= offset * SEC_SLOT;\n }\n\n return new Timestamp(second * 1000, 0, slot * YEAR_SLOT);\n }\n\n function getTimeT() {\n var ts = normalize(this);\n var time = Math.floor(ts.time / 1000);\n\n var year = ts.year;\n if (year) time += year * DAY_SLOT * SEC_DAY / YEAR_SLOT;\n\n // this may loose some bits over than 53 bit precision\n return time;\n }\n\n function toJSON() {\n return this.toString().replace(/0{1,6}Z$/, \"Z\");\n }\n\n function toString(format) {\n var ts = this;\n var dt = ts.toDate();\n var map = {\n H: H,\n L: L,\n M: M,\n N: N,\n S: S,\n Y: Y,\n a: a,\n b: b,\n d: d,\n e: e,\n m: m\n };\n\n return strftime(format || FMT_JSON);\n\n function strftime(format) {\n return format.replace(/%./g, function(match) {\n var m = match[1];\n var c = FMT_STRING[m];\n var f = map[m];\n return c ? strftime(c) : f ? f() : match;\n });\n }\n\n function Y() {\n var year = ts.getYear();\n if (year > 999999) {\n return \"+\" + year;\n } else if (year > 9999) {\n return \"+\" + pad(year, 6);\n } else if (year >= 0) {\n return pad(year, 4);\n } else if (year >= -999999) {\n return \"-\" + pad(-year, 6);\n } else {\n return year;\n }\n }\n\n function m() {\n return pad2(dt.getUTCMonth() + 1);\n }\n\n function d() {\n return pad2(dt.getUTCDate());\n }\n\n function e() {\n return padS(dt.getUTCDate());\n }\n\n function H() {\n return pad2(dt.getUTCHours());\n }\n\n function M() {\n return pad2(dt.getUTCMinutes());\n }\n\n function S() {\n return pad2(dt.getUTCSeconds());\n }\n\n function L() {\n return pad(dt.getUTCMilliseconds(), 3);\n }\n\n function N() {\n return pad(ts.getNano(), 9);\n }\n\n function a() {\n return FMT_DAY[dt.getUTCDay()];\n }\n\n function b() {\n return FMT_MONTH[dt.getUTCMonth()];\n }\n }\n\n function buildWriteInt64(pos0, pos1, pos2, pos3, posH, posL) {\n return writeInt64;\n\n function writeInt64(buffer, offset) {\n var ts = normalize(this);\n if (!buffer) buffer = new Array(8);\n checkRange(buffer, offset |= 0);\n\n var second = Math.floor(ts.time / 1000);\n var day = ts.year * (DAY_SLOT * SEC_DAY / YEAR_SLOT);\n var high = trunc(day / BIT32) + trunc(second / BIT32);\n var low = (day % BIT32) + (second % BIT32);\n\n // slot offset\n var slot = Math.floor(low / BIT32);\n if (slot) {\n high += slot;\n low -= slot * BIT32;\n }\n\n writeUint32(buffer, offset + posH, high);\n writeUint32(buffer, offset + posL, low);\n return buffer;\n }\n\n function writeUint32(buffer, offset, value) {\n buffer[offset + pos0] = (value >> 24) & 255;\n buffer[offset + pos1] = (value >> 16) & 255;\n buffer[offset + pos2] = (value >> 8) & 255;\n buffer[offset + pos3] = value & 255;\n }\n }\n\n function buildFromInt64(pos0, pos1, pos2, pos3, posH, posL) {\n return fromInt64;\n\n function fromInt64(buffer, offset) {\n checkRange(buffer, offset |= 0);\n var high = readUint32(buffer, offset + posH);\n var low = readUint32(buffer, offset + posL);\n return fromTime(low, high);\n }\n\n function readUint32(buffer, offset) {\n return (buffer[offset + pos0] * BIT24) +\n ((buffer[offset + pos1] << 16) |\n (buffer[offset + pos2] << 8) |\n buffer[offset + pos3]);\n }\n }\n\n function checkRange(buffer, offset) {\n var last = buffer && buffer.length;\n if (last == null) throw new TypeError(\"Invalid Buffer\");\n if (last < offset + 8) throw new RangeError(\"Out of range\");\n }\n\n function Math_trunc(x) {\n var n = x - x % 1;\n return n === 0 && (x < 0 || (x === 0 && (1 / x !== 1 / 0))) ? -0 : n;\n }\n\n function padS(v) {\n return (v > 9 ? \"\" : \" \") + (v | 0);\n }\n\n function pad2(v) {\n return (v > 9 ? \"\" : \"0\") + (v | 0);\n }\n\n function pad(v, len) {\n return (ZERO9 + (v | 0)).substr(-len);\n }\n})();\n","'use strict'\n\nconst hmac = require('./hmac')\nconst aes = require('./aes')\nconst keys = require('./keys')\n\nexports.aes = aes\nexports.hmac = hmac\nexports.keys = keys\nexports.randomBytes = require('./random-bytes')\nexports.pbkdf2 = require('./pbkdf2')\n","'use strict'\n\nconst ciphers = require('./ciphers')\nconst cipherMode = require('./cipher-mode')\n\nexports.create = async function (key, iv) { // eslint-disable-line require-await\n const mode = cipherMode(key)\n const cipher = ciphers.createCipheriv(mode, key, iv)\n const decipher = ciphers.createDecipheriv(mode, key, iv)\n\n const res = {\n async encrypt (data) { // eslint-disable-line require-await\n return cipher.update(data)\n },\n\n async decrypt (data) { // eslint-disable-line require-await\n return decipher.update(data)\n }\n }\n\n return res\n}\n","'use strict'\n\nrequire('node-forge/lib/aes')\nconst forge = require('node-forge/lib/forge')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\nmodule.exports = {\n createCipheriv: (mode, key, iv) => {\n const cipher2 = forge.cipher.createCipher('AES-CTR', uint8ArrayToString(key, 'ascii'))\n cipher2.start({ iv: uint8ArrayToString(iv, 'ascii') })\n return {\n update: (data) => {\n cipher2.update(forge.util.createBuffer(uint8ArrayToString(data, 'ascii')))\n return uint8ArrayFromString(cipher2.output.getBytes(), 'ascii')\n }\n }\n },\n createDecipheriv: (mode, key, iv) => {\n const cipher2 = forge.cipher.createDecipher('AES-CTR', uint8ArrayToString(key, 'ascii'))\n cipher2.start({ iv: uint8ArrayToString(iv, 'ascii') })\n return {\n update: (data) => {\n cipher2.update(forge.util.createBuffer(uint8ArrayToString(data, 'ascii')))\n return uint8ArrayFromString(cipher2.output.getBytes(), 'ascii')\n }\n }\n }\n}\n","'use strict'\n\nconst errcode = require('err-code')\n\nconst CIPHER_MODES = {\n 16: 'aes-128-ctr',\n 32: 'aes-256-ctr'\n}\n\nmodule.exports = function (key) {\n const mode = CIPHER_MODES[key.length]\n if (!mode) {\n const modes = Object.entries(CIPHER_MODES).map(([k, v]) => `${k} (${v})`).join(' / ')\n throw errcode(new Error(`Invalid key length ${key.length} bytes. Must be ${modes}`), 'ERR_INVALID_KEY_LENGTH')\n }\n return mode\n}\n","'use strict'\n\nconst forgePbkdf2 = require('node-forge/lib/pbkdf2')\nconst forgeUtil = require('node-forge/lib/util')\nconst errcode = require('err-code')\n\n/**\n * Maps an IPFS hash name to its node-forge equivalent.\n *\n * See https://github.com/multiformats/multihash/blob/master/hashtable.csv\n *\n * @private\n */\nconst hashName = {\n sha1: 'sha1',\n 'sha2-256': 'sha256',\n 'sha2-512': 'sha512'\n}\n\n/**\n * Computes the Password-Based Key Derivation Function 2.\n *\n * @param {string} password\n * @param {string} salt\n * @param {number} iterations\n * @param {number} keySize - (in bytes)\n * @param {string} hash - The hash name ('sha1', 'sha2-512, ...)\n * @returns {string} - A new password\n */\nfunction pbkdf2 (password, salt, iterations, keySize, hash) {\n const hasher = hashName[hash]\n if (!hasher) {\n const types = Object.keys(hashName).join(' / ')\n throw errcode(new Error(`Hash '${hash}' is unknown or not supported. Must be ${types}`), 'ERR_UNSUPPORTED_HASH_TYPE')\n }\n const dek = forgePbkdf2(\n password,\n salt,\n iterations,\n keySize,\n hasher)\n return forgeUtil.encode64(dek)\n}\n\nmodule.exports = pbkdf2\n","module.exports = Long;\r\n\r\n/**\r\n * wasm optimizations, to do native i64 multiplication and divide\r\n */\r\nvar wasm = null;\r\n\r\ntry {\r\n wasm = new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([\r\n 0, 97, 115, 109, 1, 0, 0, 0, 1, 13, 2, 96, 0, 1, 127, 96, 4, 127, 127, 127, 127, 1, 127, 3, 7, 6, 0, 1, 1, 1, 1, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 50, 6, 3, 109, 117, 108, 0, 1, 5, 100, 105, 118, 95, 115, 0, 2, 5, 100, 105, 118, 95, 117, 0, 3, 5, 114, 101, 109, 95, 115, 0, 4, 5, 114, 101, 109, 95, 117, 0, 5, 8, 103, 101, 116, 95, 104, 105, 103, 104, 0, 0, 10, 191, 1, 6, 4, 0, 35, 0, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 126, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 127, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 128, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 129, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 130, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11\r\n ])), {}).exports;\r\n} catch (e) {\r\n // no wasm support :(\r\n}\r\n\r\n/**\r\n * Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as *signed* integers.\r\n * See the from* functions below for more convenient ways of constructing Longs.\r\n * @exports Long\r\n * @class A Long class for representing a 64 bit two's-complement integer value.\r\n * @param {number} low The low (signed) 32 bits of the long\r\n * @param {number} high The high (signed) 32 bits of the long\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @constructor\r\n */\r\nfunction Long(low, high, unsigned) {\r\n\r\n /**\r\n * The low 32 bits as a signed value.\r\n * @type {number}\r\n */\r\n this.low = low | 0;\r\n\r\n /**\r\n * The high 32 bits as a signed value.\r\n * @type {number}\r\n */\r\n this.high = high | 0;\r\n\r\n /**\r\n * Whether unsigned or not.\r\n * @type {boolean}\r\n */\r\n this.unsigned = !!unsigned;\r\n}\r\n\r\n// The internal representation of a long is the two given signed, 32-bit values.\r\n// We use 32-bit pieces because these are the size of integers on which\r\n// Javascript performs bit-operations. For operations like addition and\r\n// multiplication, we split each number into 16 bit pieces, which can easily be\r\n// multiplied within Javascript's floating-point representation without overflow\r\n// or change in sign.\r\n//\r\n// In the algorithms below, we frequently reduce the negative case to the\r\n// positive case by negating the input(s) and then post-processing the result.\r\n// Note that we must ALWAYS check specially whether those values are MIN_VALUE\r\n// (-2^63) because -MIN_VALUE == MIN_VALUE (since 2^63 cannot be represented as\r\n// a positive number, it overflows back into a negative). Not handling this\r\n// case would often result in infinite recursion.\r\n//\r\n// Common constant values ZERO, ONE, NEG_ONE, etc. are defined below the from*\r\n// methods on which they depend.\r\n\r\n/**\r\n * An indicator used to reliably determine if an object is a Long or not.\r\n * @type {boolean}\r\n * @const\r\n * @private\r\n */\r\nLong.prototype.__isLong__;\r\n\r\nObject.defineProperty(Long.prototype, \"__isLong__\", { value: true });\r\n\r\n/**\r\n * @function\r\n * @param {*} obj Object\r\n * @returns {boolean}\r\n * @inner\r\n */\r\nfunction isLong(obj) {\r\n return (obj && obj[\"__isLong__\"]) === true;\r\n}\r\n\r\n/**\r\n * Tests if the specified object is a Long.\r\n * @function\r\n * @param {*} obj Object\r\n * @returns {boolean}\r\n */\r\nLong.isLong = isLong;\r\n\r\n/**\r\n * A cache of the Long representations of small integer values.\r\n * @type {!Object}\r\n * @inner\r\n */\r\nvar INT_CACHE = {};\r\n\r\n/**\r\n * A cache of the Long representations of small unsigned integer values.\r\n * @type {!Object}\r\n * @inner\r\n */\r\nvar UINT_CACHE = {};\r\n\r\n/**\r\n * @param {number} value\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromInt(value, unsigned) {\r\n var obj, cachedObj, cache;\r\n if (unsigned) {\r\n value >>>= 0;\r\n if (cache = (0 <= value && value < 256)) {\r\n cachedObj = UINT_CACHE[value];\r\n if (cachedObj)\r\n return cachedObj;\r\n }\r\n obj = fromBits(value, (value | 0) < 0 ? -1 : 0, true);\r\n if (cache)\r\n UINT_CACHE[value] = obj;\r\n return obj;\r\n } else {\r\n value |= 0;\r\n if (cache = (-128 <= value && value < 128)) {\r\n cachedObj = INT_CACHE[value];\r\n if (cachedObj)\r\n return cachedObj;\r\n }\r\n obj = fromBits(value, value < 0 ? -1 : 0, false);\r\n if (cache)\r\n INT_CACHE[value] = obj;\r\n return obj;\r\n }\r\n}\r\n\r\n/**\r\n * Returns a Long representing the given 32 bit integer value.\r\n * @function\r\n * @param {number} value The 32 bit integer in question\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromInt = fromInt;\r\n\r\n/**\r\n * @param {number} value\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromNumber(value, unsigned) {\r\n if (isNaN(value))\r\n return unsigned ? UZERO : ZERO;\r\n if (unsigned) {\r\n if (value < 0)\r\n return UZERO;\r\n if (value >= TWO_PWR_64_DBL)\r\n return MAX_UNSIGNED_VALUE;\r\n } else {\r\n if (value <= -TWO_PWR_63_DBL)\r\n return MIN_VALUE;\r\n if (value + 1 >= TWO_PWR_63_DBL)\r\n return MAX_VALUE;\r\n }\r\n if (value < 0)\r\n return fromNumber(-value, unsigned).neg();\r\n return fromBits((value % TWO_PWR_32_DBL) | 0, (value / TWO_PWR_32_DBL) | 0, unsigned);\r\n}\r\n\r\n/**\r\n * Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned.\r\n * @function\r\n * @param {number} value The number in question\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromNumber = fromNumber;\r\n\r\n/**\r\n * @param {number} lowBits\r\n * @param {number} highBits\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromBits(lowBits, highBits, unsigned) {\r\n return new Long(lowBits, highBits, unsigned);\r\n}\r\n\r\n/**\r\n * Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is\r\n * assumed to use 32 bits.\r\n * @function\r\n * @param {number} lowBits The low 32 bits\r\n * @param {number} highBits The high 32 bits\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromBits = fromBits;\r\n\r\n/**\r\n * @function\r\n * @param {number} base\r\n * @param {number} exponent\r\n * @returns {number}\r\n * @inner\r\n */\r\nvar pow_dbl = Math.pow; // Used 4 times (4*8 to 15+4)\r\n\r\n/**\r\n * @param {string} str\r\n * @param {(boolean|number)=} unsigned\r\n * @param {number=} radix\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromString(str, unsigned, radix) {\r\n if (str.length === 0)\r\n throw Error('empty string');\r\n if (str === \"NaN\" || str === \"Infinity\" || str === \"+Infinity\" || str === \"-Infinity\")\r\n return ZERO;\r\n if (typeof unsigned === 'number') {\r\n // For goog.math.long compatibility\r\n radix = unsigned,\r\n unsigned = false;\r\n } else {\r\n unsigned = !! unsigned;\r\n }\r\n radix = radix || 10;\r\n if (radix < 2 || 36 < radix)\r\n throw RangeError('radix');\r\n\r\n var p;\r\n if ((p = str.indexOf('-')) > 0)\r\n throw Error('interior hyphen');\r\n else if (p === 0) {\r\n return fromString(str.substring(1), unsigned, radix).neg();\r\n }\r\n\r\n // Do several (8) digits each time through the loop, so as to\r\n // minimize the calls to the very expensive emulated div.\r\n var radixToPower = fromNumber(pow_dbl(radix, 8));\r\n\r\n var result = ZERO;\r\n for (var i = 0; i < str.length; i += 8) {\r\n var size = Math.min(8, str.length - i),\r\n value = parseInt(str.substring(i, i + size), radix);\r\n if (size < 8) {\r\n var power = fromNumber(pow_dbl(radix, size));\r\n result = result.mul(power).add(fromNumber(value));\r\n } else {\r\n result = result.mul(radixToPower);\r\n result = result.add(fromNumber(value));\r\n }\r\n }\r\n result.unsigned = unsigned;\r\n return result;\r\n}\r\n\r\n/**\r\n * Returns a Long representation of the given string, written using the specified radix.\r\n * @function\r\n * @param {string} str The textual representation of the Long\r\n * @param {(boolean|number)=} unsigned Whether unsigned or not, defaults to signed\r\n * @param {number=} radix The radix in which the text is written (2-36), defaults to 10\r\n * @returns {!Long} The corresponding Long value\r\n */\r\nLong.fromString = fromString;\r\n\r\n/**\r\n * @function\r\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val\r\n * @param {boolean=} unsigned\r\n * @returns {!Long}\r\n * @inner\r\n */\r\nfunction fromValue(val, unsigned) {\r\n if (typeof val === 'number')\r\n return fromNumber(val, unsigned);\r\n if (typeof val === 'string')\r\n return fromString(val, unsigned);\r\n // Throws for non-objects, converts non-instanceof Long:\r\n return fromBits(val.low, val.high, typeof unsigned === 'boolean' ? unsigned : val.unsigned);\r\n}\r\n\r\n/**\r\n * Converts the specified value to a Long using the appropriate from* function for its type.\r\n * @function\r\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val Value\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {!Long}\r\n */\r\nLong.fromValue = fromValue;\r\n\r\n// NOTE: the compiler should inline these constant values below and then remove these variables, so there should be\r\n// no runtime penalty for these.\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_16_DBL = 1 << 16;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_24_DBL = 1 << 24;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_32_DBL = TWO_PWR_16_DBL * TWO_PWR_16_DBL;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_64_DBL = TWO_PWR_32_DBL * TWO_PWR_32_DBL;\r\n\r\n/**\r\n * @type {number}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_63_DBL = TWO_PWR_64_DBL / 2;\r\n\r\n/**\r\n * @type {!Long}\r\n * @const\r\n * @inner\r\n */\r\nvar TWO_PWR_24 = fromInt(TWO_PWR_24_DBL);\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar ZERO = fromInt(0);\r\n\r\n/**\r\n * Signed zero.\r\n * @type {!Long}\r\n */\r\nLong.ZERO = ZERO;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar UZERO = fromInt(0, true);\r\n\r\n/**\r\n * Unsigned zero.\r\n * @type {!Long}\r\n */\r\nLong.UZERO = UZERO;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar ONE = fromInt(1);\r\n\r\n/**\r\n * Signed one.\r\n * @type {!Long}\r\n */\r\nLong.ONE = ONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar UONE = fromInt(1, true);\r\n\r\n/**\r\n * Unsigned one.\r\n * @type {!Long}\r\n */\r\nLong.UONE = UONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar NEG_ONE = fromInt(-1);\r\n\r\n/**\r\n * Signed negative one.\r\n * @type {!Long}\r\n */\r\nLong.NEG_ONE = NEG_ONE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MAX_VALUE = fromBits(0xFFFFFFFF|0, 0x7FFFFFFF|0, false);\r\n\r\n/**\r\n * Maximum signed value.\r\n * @type {!Long}\r\n */\r\nLong.MAX_VALUE = MAX_VALUE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MAX_UNSIGNED_VALUE = fromBits(0xFFFFFFFF|0, 0xFFFFFFFF|0, true);\r\n\r\n/**\r\n * Maximum unsigned value.\r\n * @type {!Long}\r\n */\r\nLong.MAX_UNSIGNED_VALUE = MAX_UNSIGNED_VALUE;\r\n\r\n/**\r\n * @type {!Long}\r\n * @inner\r\n */\r\nvar MIN_VALUE = fromBits(0, 0x80000000|0, false);\r\n\r\n/**\r\n * Minimum signed value.\r\n * @type {!Long}\r\n */\r\nLong.MIN_VALUE = MIN_VALUE;\r\n\r\n/**\r\n * @alias Long.prototype\r\n * @inner\r\n */\r\nvar LongPrototype = Long.prototype;\r\n\r\n/**\r\n * Converts the Long to a 32 bit integer, assuming it is a 32 bit integer.\r\n * @returns {number}\r\n */\r\nLongPrototype.toInt = function toInt() {\r\n return this.unsigned ? this.low >>> 0 : this.low;\r\n};\r\n\r\n/**\r\n * Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa).\r\n * @returns {number}\r\n */\r\nLongPrototype.toNumber = function toNumber() {\r\n if (this.unsigned)\r\n return ((this.high >>> 0) * TWO_PWR_32_DBL) + (this.low >>> 0);\r\n return this.high * TWO_PWR_32_DBL + (this.low >>> 0);\r\n};\r\n\r\n/**\r\n * Converts the Long to a string written in the specified radix.\r\n * @param {number=} radix Radix (2-36), defaults to 10\r\n * @returns {string}\r\n * @override\r\n * @throws {RangeError} If `radix` is out of range\r\n */\r\nLongPrototype.toString = function toString(radix) {\r\n radix = radix || 10;\r\n if (radix < 2 || 36 < radix)\r\n throw RangeError('radix');\r\n if (this.isZero())\r\n return '0';\r\n if (this.isNegative()) { // Unsigned Longs are never negative\r\n if (this.eq(MIN_VALUE)) {\r\n // We need to change the Long value before it can be negated, so we remove\r\n // the bottom-most digit in this base and then recurse to do the rest.\r\n var radixLong = fromNumber(radix),\r\n div = this.div(radixLong),\r\n rem1 = div.mul(radixLong).sub(this);\r\n return div.toString(radix) + rem1.toInt().toString(radix);\r\n } else\r\n return '-' + this.neg().toString(radix);\r\n }\r\n\r\n // Do several (6) digits each time through the loop, so as to\r\n // minimize the calls to the very expensive emulated div.\r\n var radixToPower = fromNumber(pow_dbl(radix, 6), this.unsigned),\r\n rem = this;\r\n var result = '';\r\n while (true) {\r\n var remDiv = rem.div(radixToPower),\r\n intval = rem.sub(remDiv.mul(radixToPower)).toInt() >>> 0,\r\n digits = intval.toString(radix);\r\n rem = remDiv;\r\n if (rem.isZero())\r\n return digits + result;\r\n else {\r\n while (digits.length < 6)\r\n digits = '0' + digits;\r\n result = '' + digits + result;\r\n }\r\n }\r\n};\r\n\r\n/**\r\n * Gets the high 32 bits as a signed integer.\r\n * @returns {number} Signed high bits\r\n */\r\nLongPrototype.getHighBits = function getHighBits() {\r\n return this.high;\r\n};\r\n\r\n/**\r\n * Gets the high 32 bits as an unsigned integer.\r\n * @returns {number} Unsigned high bits\r\n */\r\nLongPrototype.getHighBitsUnsigned = function getHighBitsUnsigned() {\r\n return this.high >>> 0;\r\n};\r\n\r\n/**\r\n * Gets the low 32 bits as a signed integer.\r\n * @returns {number} Signed low bits\r\n */\r\nLongPrototype.getLowBits = function getLowBits() {\r\n return this.low;\r\n};\r\n\r\n/**\r\n * Gets the low 32 bits as an unsigned integer.\r\n * @returns {number} Unsigned low bits\r\n */\r\nLongPrototype.getLowBitsUnsigned = function getLowBitsUnsigned() {\r\n return this.low >>> 0;\r\n};\r\n\r\n/**\r\n * Gets the number of bits needed to represent the absolute value of this Long.\r\n * @returns {number}\r\n */\r\nLongPrototype.getNumBitsAbs = function getNumBitsAbs() {\r\n if (this.isNegative()) // Unsigned Longs are never negative\r\n return this.eq(MIN_VALUE) ? 64 : this.neg().getNumBitsAbs();\r\n var val = this.high != 0 ? this.high : this.low;\r\n for (var bit = 31; bit > 0; bit--)\r\n if ((val & (1 << bit)) != 0)\r\n break;\r\n return this.high != 0 ? bit + 33 : bit + 1;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals zero.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isZero = function isZero() {\r\n return this.high === 0 && this.low === 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals zero. This is an alias of {@link Long#isZero}.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.eqz = LongPrototype.isZero;\r\n\r\n/**\r\n * Tests if this Long's value is negative.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isNegative = function isNegative() {\r\n return !this.unsigned && this.high < 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is positive.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isPositive = function isPositive() {\r\n return this.unsigned || this.high >= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is odd.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isOdd = function isOdd() {\r\n return (this.low & 1) === 1;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is even.\r\n * @returns {boolean}\r\n */\r\nLongPrototype.isEven = function isEven() {\r\n return (this.low & 1) === 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.equals = function equals(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n if (this.unsigned !== other.unsigned && (this.high >>> 31) === 1 && (other.high >>> 31) === 1)\r\n return false;\r\n return this.high === other.high && this.low === other.low;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value equals the specified's. This is an alias of {@link Long#equals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.eq = LongPrototype.equals;\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.notEquals = function notEquals(other) {\r\n return !this.eq(/* validates */ other);\r\n};\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.neq = LongPrototype.notEquals;\r\n\r\n/**\r\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.ne = LongPrototype.notEquals;\r\n\r\n/**\r\n * Tests if this Long's value is less than the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lessThan = function lessThan(other) {\r\n return this.comp(/* validates */ other) < 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is less than the specified's. This is an alias of {@link Long#lessThan}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lt = LongPrototype.lessThan;\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lessThanOrEqual = function lessThanOrEqual(other) {\r\n return this.comp(/* validates */ other) <= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.lte = LongPrototype.lessThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.le = LongPrototype.lessThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is greater than the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.greaterThan = function greaterThan(other) {\r\n return this.comp(/* validates */ other) > 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is greater than the specified's. This is an alias of {@link Long#greaterThan}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.gt = LongPrototype.greaterThan;\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.greaterThanOrEqual = function greaterThanOrEqual(other) {\r\n return this.comp(/* validates */ other) >= 0;\r\n};\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.gte = LongPrototype.greaterThanOrEqual;\r\n\r\n/**\r\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {boolean}\r\n */\r\nLongPrototype.ge = LongPrototype.greaterThanOrEqual;\r\n\r\n/**\r\n * Compares this Long's value with the specified's.\r\n * @param {!Long|number|string} other Other value\r\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\r\n * if the given one is greater\r\n */\r\nLongPrototype.compare = function compare(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n if (this.eq(other))\r\n return 0;\r\n var thisNeg = this.isNegative(),\r\n otherNeg = other.isNegative();\r\n if (thisNeg && !otherNeg)\r\n return -1;\r\n if (!thisNeg && otherNeg)\r\n return 1;\r\n // At this point the sign bits are the same\r\n if (!this.unsigned)\r\n return this.sub(other).isNegative() ? -1 : 1;\r\n // Both are positive if at least one is unsigned\r\n return (other.high >>> 0) > (this.high >>> 0) || (other.high === this.high && (other.low >>> 0) > (this.low >>> 0)) ? -1 : 1;\r\n};\r\n\r\n/**\r\n * Compares this Long's value with the specified's. This is an alias of {@link Long#compare}.\r\n * @function\r\n * @param {!Long|number|string} other Other value\r\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\r\n * if the given one is greater\r\n */\r\nLongPrototype.comp = LongPrototype.compare;\r\n\r\n/**\r\n * Negates this Long's value.\r\n * @returns {!Long} Negated Long\r\n */\r\nLongPrototype.negate = function negate() {\r\n if (!this.unsigned && this.eq(MIN_VALUE))\r\n return MIN_VALUE;\r\n return this.not().add(ONE);\r\n};\r\n\r\n/**\r\n * Negates this Long's value. This is an alias of {@link Long#negate}.\r\n * @function\r\n * @returns {!Long} Negated Long\r\n */\r\nLongPrototype.neg = LongPrototype.negate;\r\n\r\n/**\r\n * Returns the sum of this and the specified Long.\r\n * @param {!Long|number|string} addend Addend\r\n * @returns {!Long} Sum\r\n */\r\nLongPrototype.add = function add(addend) {\r\n if (!isLong(addend))\r\n addend = fromValue(addend);\r\n\r\n // Divide each number into 4 chunks of 16 bits, and then sum the chunks.\r\n\r\n var a48 = this.high >>> 16;\r\n var a32 = this.high & 0xFFFF;\r\n var a16 = this.low >>> 16;\r\n var a00 = this.low & 0xFFFF;\r\n\r\n var b48 = addend.high >>> 16;\r\n var b32 = addend.high & 0xFFFF;\r\n var b16 = addend.low >>> 16;\r\n var b00 = addend.low & 0xFFFF;\r\n\r\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\r\n c00 += a00 + b00;\r\n c16 += c00 >>> 16;\r\n c00 &= 0xFFFF;\r\n c16 += a16 + b16;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c32 += a32 + b32;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c48 += a48 + b48;\r\n c48 &= 0xFFFF;\r\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the difference of this and the specified Long.\r\n * @param {!Long|number|string} subtrahend Subtrahend\r\n * @returns {!Long} Difference\r\n */\r\nLongPrototype.subtract = function subtract(subtrahend) {\r\n if (!isLong(subtrahend))\r\n subtrahend = fromValue(subtrahend);\r\n return this.add(subtrahend.neg());\r\n};\r\n\r\n/**\r\n * Returns the difference of this and the specified Long. This is an alias of {@link Long#subtract}.\r\n * @function\r\n * @param {!Long|number|string} subtrahend Subtrahend\r\n * @returns {!Long} Difference\r\n */\r\nLongPrototype.sub = LongPrototype.subtract;\r\n\r\n/**\r\n * Returns the product of this and the specified Long.\r\n * @param {!Long|number|string} multiplier Multiplier\r\n * @returns {!Long} Product\r\n */\r\nLongPrototype.multiply = function multiply(multiplier) {\r\n if (this.isZero())\r\n return ZERO;\r\n if (!isLong(multiplier))\r\n multiplier = fromValue(multiplier);\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n var low = wasm.mul(this.low,\r\n this.high,\r\n multiplier.low,\r\n multiplier.high);\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n if (multiplier.isZero())\r\n return ZERO;\r\n if (this.eq(MIN_VALUE))\r\n return multiplier.isOdd() ? MIN_VALUE : ZERO;\r\n if (multiplier.eq(MIN_VALUE))\r\n return this.isOdd() ? MIN_VALUE : ZERO;\r\n\r\n if (this.isNegative()) {\r\n if (multiplier.isNegative())\r\n return this.neg().mul(multiplier.neg());\r\n else\r\n return this.neg().mul(multiplier).neg();\r\n } else if (multiplier.isNegative())\r\n return this.mul(multiplier.neg()).neg();\r\n\r\n // If both longs are small, use float multiplication\r\n if (this.lt(TWO_PWR_24) && multiplier.lt(TWO_PWR_24))\r\n return fromNumber(this.toNumber() * multiplier.toNumber(), this.unsigned);\r\n\r\n // Divide each long into 4 chunks of 16 bits, and then add up 4x4 products.\r\n // We can skip products that would overflow.\r\n\r\n var a48 = this.high >>> 16;\r\n var a32 = this.high & 0xFFFF;\r\n var a16 = this.low >>> 16;\r\n var a00 = this.low & 0xFFFF;\r\n\r\n var b48 = multiplier.high >>> 16;\r\n var b32 = multiplier.high & 0xFFFF;\r\n var b16 = multiplier.low >>> 16;\r\n var b00 = multiplier.low & 0xFFFF;\r\n\r\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\r\n c00 += a00 * b00;\r\n c16 += c00 >>> 16;\r\n c00 &= 0xFFFF;\r\n c16 += a16 * b00;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c16 += a00 * b16;\r\n c32 += c16 >>> 16;\r\n c16 &= 0xFFFF;\r\n c32 += a32 * b00;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c32 += a16 * b16;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c32 += a00 * b32;\r\n c48 += c32 >>> 16;\r\n c32 &= 0xFFFF;\r\n c48 += a48 * b00 + a32 * b16 + a16 * b32 + a00 * b48;\r\n c48 &= 0xFFFF;\r\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the product of this and the specified Long. This is an alias of {@link Long#multiply}.\r\n * @function\r\n * @param {!Long|number|string} multiplier Multiplier\r\n * @returns {!Long} Product\r\n */\r\nLongPrototype.mul = LongPrototype.multiply;\r\n\r\n/**\r\n * Returns this Long divided by the specified. The result is signed if this Long is signed or\r\n * unsigned if this Long is unsigned.\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Quotient\r\n */\r\nLongPrototype.divide = function divide(divisor) {\r\n if (!isLong(divisor))\r\n divisor = fromValue(divisor);\r\n if (divisor.isZero())\r\n throw Error('division by zero');\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n // guard against signed division overflow: the largest\r\n // negative number / -1 would be 1 larger than the largest\r\n // positive number, due to two's complement.\r\n if (!this.unsigned &&\r\n this.high === -0x80000000 &&\r\n divisor.low === -1 && divisor.high === -1) {\r\n // be consistent with non-wasm code path\r\n return this;\r\n }\r\n var low = (this.unsigned ? wasm.div_u : wasm.div_s)(\r\n this.low,\r\n this.high,\r\n divisor.low,\r\n divisor.high\r\n );\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n if (this.isZero())\r\n return this.unsigned ? UZERO : ZERO;\r\n var approx, rem, res;\r\n if (!this.unsigned) {\r\n // This section is only relevant for signed longs and is derived from the\r\n // closure library as a whole.\r\n if (this.eq(MIN_VALUE)) {\r\n if (divisor.eq(ONE) || divisor.eq(NEG_ONE))\r\n return MIN_VALUE; // recall that -MIN_VALUE == MIN_VALUE\r\n else if (divisor.eq(MIN_VALUE))\r\n return ONE;\r\n else {\r\n // At this point, we have |other| >= 2, so |this/other| < |MIN_VALUE|.\r\n var halfThis = this.shr(1);\r\n approx = halfThis.div(divisor).shl(1);\r\n if (approx.eq(ZERO)) {\r\n return divisor.isNegative() ? ONE : NEG_ONE;\r\n } else {\r\n rem = this.sub(divisor.mul(approx));\r\n res = approx.add(rem.div(divisor));\r\n return res;\r\n }\r\n }\r\n } else if (divisor.eq(MIN_VALUE))\r\n return this.unsigned ? UZERO : ZERO;\r\n if (this.isNegative()) {\r\n if (divisor.isNegative())\r\n return this.neg().div(divisor.neg());\r\n return this.neg().div(divisor).neg();\r\n } else if (divisor.isNegative())\r\n return this.div(divisor.neg()).neg();\r\n res = ZERO;\r\n } else {\r\n // The algorithm below has not been made for unsigned longs. It's therefore\r\n // required to take special care of the MSB prior to running it.\r\n if (!divisor.unsigned)\r\n divisor = divisor.toUnsigned();\r\n if (divisor.gt(this))\r\n return UZERO;\r\n if (divisor.gt(this.shru(1))) // 15 >>> 1 = 7 ; with divisor = 8 ; true\r\n return UONE;\r\n res = UZERO;\r\n }\r\n\r\n // Repeat the following until the remainder is less than other: find a\r\n // floating-point that approximates remainder / other *from below*, add this\r\n // into the result, and subtract it from the remainder. It is critical that\r\n // the approximate value is less than or equal to the real value so that the\r\n // remainder never becomes negative.\r\n rem = this;\r\n while (rem.gte(divisor)) {\r\n // Approximate the result of division. This may be a little greater or\r\n // smaller than the actual value.\r\n approx = Math.max(1, Math.floor(rem.toNumber() / divisor.toNumber()));\r\n\r\n // We will tweak the approximate result by changing it in the 48-th digit or\r\n // the smallest non-fractional digit, whichever is larger.\r\n var log2 = Math.ceil(Math.log(approx) / Math.LN2),\r\n delta = (log2 <= 48) ? 1 : pow_dbl(2, log2 - 48),\r\n\r\n // Decrease the approximation until it is smaller than the remainder. Note\r\n // that if it is too large, the product overflows and is negative.\r\n approxRes = fromNumber(approx),\r\n approxRem = approxRes.mul(divisor);\r\n while (approxRem.isNegative() || approxRem.gt(rem)) {\r\n approx -= delta;\r\n approxRes = fromNumber(approx, this.unsigned);\r\n approxRem = approxRes.mul(divisor);\r\n }\r\n\r\n // We know the answer can't be zero... and actually, zero would cause\r\n // infinite recursion since we would make no progress.\r\n if (approxRes.isZero())\r\n approxRes = ONE;\r\n\r\n res = res.add(approxRes);\r\n rem = rem.sub(approxRem);\r\n }\r\n return res;\r\n};\r\n\r\n/**\r\n * Returns this Long divided by the specified. This is an alias of {@link Long#divide}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Quotient\r\n */\r\nLongPrototype.div = LongPrototype.divide;\r\n\r\n/**\r\n * Returns this Long modulo the specified.\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.modulo = function modulo(divisor) {\r\n if (!isLong(divisor))\r\n divisor = fromValue(divisor);\r\n\r\n // use wasm support if present\r\n if (wasm) {\r\n var low = (this.unsigned ? wasm.rem_u : wasm.rem_s)(\r\n this.low,\r\n this.high,\r\n divisor.low,\r\n divisor.high\r\n );\r\n return fromBits(low, wasm.get_high(), this.unsigned);\r\n }\r\n\r\n return this.sub(this.div(divisor).mul(divisor));\r\n};\r\n\r\n/**\r\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.mod = LongPrototype.modulo;\r\n\r\n/**\r\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\r\n * @function\r\n * @param {!Long|number|string} divisor Divisor\r\n * @returns {!Long} Remainder\r\n */\r\nLongPrototype.rem = LongPrototype.modulo;\r\n\r\n/**\r\n * Returns the bitwise NOT of this Long.\r\n * @returns {!Long}\r\n */\r\nLongPrototype.not = function not() {\r\n return fromBits(~this.low, ~this.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise AND of this Long and the specified.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.and = function and(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low & other.low, this.high & other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise OR of this Long and the specified.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.or = function or(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low | other.low, this.high | other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns the bitwise XOR of this Long and the given one.\r\n * @param {!Long|number|string} other Other Long\r\n * @returns {!Long}\r\n */\r\nLongPrototype.xor = function xor(other) {\r\n if (!isLong(other))\r\n other = fromValue(other);\r\n return fromBits(this.low ^ other.low, this.high ^ other.high, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits shifted to the left by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftLeft = function shiftLeft(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n if ((numBits &= 63) === 0)\r\n return this;\r\n else if (numBits < 32)\r\n return fromBits(this.low << numBits, (this.high << numBits) | (this.low >>> (32 - numBits)), this.unsigned);\r\n else\r\n return fromBits(0, this.low << (numBits - 32), this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits shifted to the left by the given amount. This is an alias of {@link Long#shiftLeft}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shl = LongPrototype.shiftLeft;\r\n\r\n/**\r\n * Returns this Long with bits arithmetically shifted to the right by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftRight = function shiftRight(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n if ((numBits &= 63) === 0)\r\n return this;\r\n else if (numBits < 32)\r\n return fromBits((this.low >>> numBits) | (this.high << (32 - numBits)), this.high >> numBits, this.unsigned);\r\n else\r\n return fromBits(this.high >> (numBits - 32), this.high >= 0 ? 0 : -1, this.unsigned);\r\n};\r\n\r\n/**\r\n * Returns this Long with bits arithmetically shifted to the right by the given amount. This is an alias of {@link Long#shiftRight}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shr = LongPrototype.shiftRight;\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount.\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shiftRightUnsigned = function shiftRightUnsigned(numBits) {\r\n if (isLong(numBits))\r\n numBits = numBits.toInt();\r\n numBits &= 63;\r\n if (numBits === 0)\r\n return this;\r\n else {\r\n var high = this.high;\r\n if (numBits < 32) {\r\n var low = this.low;\r\n return fromBits((low >>> numBits) | (high << (32 - numBits)), high >>> numBits, this.unsigned);\r\n } else if (numBits === 32)\r\n return fromBits(high, 0, this.unsigned);\r\n else\r\n return fromBits(high >>> (numBits - 32), 0, this.unsigned);\r\n }\r\n};\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shru = LongPrototype.shiftRightUnsigned;\r\n\r\n/**\r\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\r\n * @function\r\n * @param {number|!Long} numBits Number of bits\r\n * @returns {!Long} Shifted Long\r\n */\r\nLongPrototype.shr_u = LongPrototype.shiftRightUnsigned;\r\n\r\n/**\r\n * Converts this Long to signed.\r\n * @returns {!Long} Signed long\r\n */\r\nLongPrototype.toSigned = function toSigned() {\r\n if (!this.unsigned)\r\n return this;\r\n return fromBits(this.low, this.high, false);\r\n};\r\n\r\n/**\r\n * Converts this Long to unsigned.\r\n * @returns {!Long} Unsigned long\r\n */\r\nLongPrototype.toUnsigned = function toUnsigned() {\r\n if (this.unsigned)\r\n return this;\r\n return fromBits(this.low, this.high, true);\r\n};\r\n\r\n/**\r\n * Converts this Long to its byte representation.\r\n * @param {boolean=} le Whether little or big endian, defaults to big endian\r\n * @returns {!Array.<number>} Byte representation\r\n */\r\nLongPrototype.toBytes = function toBytes(le) {\r\n return le ? this.toBytesLE() : this.toBytesBE();\r\n};\r\n\r\n/**\r\n * Converts this Long to its little endian byte representation.\r\n * @returns {!Array.<number>} Little endian byte representation\r\n */\r\nLongPrototype.toBytesLE = function toBytesLE() {\r\n var hi = this.high,\r\n lo = this.low;\r\n return [\r\n lo & 0xff,\r\n lo >>> 8 & 0xff,\r\n lo >>> 16 & 0xff,\r\n lo >>> 24 ,\r\n hi & 0xff,\r\n hi >>> 8 & 0xff,\r\n hi >>> 16 & 0xff,\r\n hi >>> 24\r\n ];\r\n};\r\n\r\n/**\r\n * Converts this Long to its big endian byte representation.\r\n * @returns {!Array.<number>} Big endian byte representation\r\n */\r\nLongPrototype.toBytesBE = function toBytesBE() {\r\n var hi = this.high,\r\n lo = this.low;\r\n return [\r\n hi >>> 24 ,\r\n hi >>> 16 & 0xff,\r\n hi >>> 8 & 0xff,\r\n hi & 0xff,\r\n lo >>> 24 ,\r\n lo >>> 16 & 0xff,\r\n lo >>> 8 & 0xff,\r\n lo & 0xff\r\n ];\r\n};\r\n\r\n/**\r\n * Creates a Long from its byte representation.\r\n * @param {!Array.<number>} bytes Byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @param {boolean=} le Whether little or big endian, defaults to big endian\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytes = function fromBytes(bytes, unsigned, le) {\r\n return le ? Long.fromBytesLE(bytes, unsigned) : Long.fromBytesBE(bytes, unsigned);\r\n};\r\n\r\n/**\r\n * Creates a Long from its little endian byte representation.\r\n * @param {!Array.<number>} bytes Little endian byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytesLE = function fromBytesLE(bytes, unsigned) {\r\n return new Long(\r\n bytes[0] |\r\n bytes[1] << 8 |\r\n bytes[2] << 16 |\r\n bytes[3] << 24,\r\n bytes[4] |\r\n bytes[5] << 8 |\r\n bytes[6] << 16 |\r\n bytes[7] << 24,\r\n unsigned\r\n );\r\n};\r\n\r\n/**\r\n * Creates a Long from its big endian byte representation.\r\n * @param {!Array.<number>} bytes Big endian byte representation\r\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\r\n * @returns {Long} The corresponding Long value\r\n */\r\nLong.fromBytesBE = function fromBytesBE(bytes, unsigned) {\r\n return new Long(\r\n bytes[4] << 24 |\r\n bytes[5] << 16 |\r\n bytes[6] << 8 |\r\n bytes[7],\r\n bytes[0] << 24 |\r\n bytes[1] << 16 |\r\n bytes[2] << 8 |\r\n bytes[3],\r\n unsigned\r\n );\r\n};\r\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar $protobuf = require('protobufjs/minimal.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar $protobuf__default = /*#__PURE__*/_interopDefaultLegacy($protobuf);\n\nconst $Reader = $protobuf__default['default'].Reader, $Writer = $protobuf__default['default'].Writer, $util = $protobuf__default['default'].util;\nconst $root = $protobuf__default['default'].roots['ipfs-ipns'] || ($protobuf__default['default'].roots['ipfs-ipns'] = {});\nconst IpnsEntry = $root.IpnsEntry = (() => {\n function IpnsEntry(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n IpnsEntry.prototype.value = $util.newBuffer([]);\n IpnsEntry.prototype.signature = $util.newBuffer([]);\n IpnsEntry.prototype.validityType = 0;\n IpnsEntry.prototype.validity = $util.newBuffer([]);\n IpnsEntry.prototype.sequence = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n IpnsEntry.prototype.ttl = $util.Long ? $util.Long.fromBits(0, 0, true) : 0;\n IpnsEntry.prototype.pubKey = $util.newBuffer([]);\n IpnsEntry.prototype.signatureV2 = $util.newBuffer([]);\n IpnsEntry.prototype.data = $util.newBuffer([]);\n IpnsEntry.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.value != null && Object.hasOwnProperty.call(m, 'value'))\n w.uint32(10).bytes(m.value);\n if (m.signature != null && Object.hasOwnProperty.call(m, 'signature'))\n w.uint32(18).bytes(m.signature);\n if (m.validityType != null && Object.hasOwnProperty.call(m, 'validityType'))\n w.uint32(24).int32(m.validityType);\n if (m.validity != null && Object.hasOwnProperty.call(m, 'validity'))\n w.uint32(34).bytes(m.validity);\n if (m.sequence != null && Object.hasOwnProperty.call(m, 'sequence'))\n w.uint32(40).uint64(m.sequence);\n if (m.ttl != null && Object.hasOwnProperty.call(m, 'ttl'))\n w.uint32(48).uint64(m.ttl);\n if (m.pubKey != null && Object.hasOwnProperty.call(m, 'pubKey'))\n w.uint32(58).bytes(m.pubKey);\n if (m.signatureV2 != null && Object.hasOwnProperty.call(m, 'signatureV2'))\n w.uint32(66).bytes(m.signatureV2);\n if (m.data != null && Object.hasOwnProperty.call(m, 'data'))\n w.uint32(74).bytes(m.data);\n return w;\n };\n IpnsEntry.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.IpnsEntry();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.value = r.bytes();\n break;\n case 2:\n m.signature = r.bytes();\n break;\n case 3:\n m.validityType = r.int32();\n break;\n case 4:\n m.validity = r.bytes();\n break;\n case 5:\n m.sequence = r.uint64();\n break;\n case 6:\n m.ttl = r.uint64();\n break;\n case 7:\n m.pubKey = r.bytes();\n break;\n case 8:\n m.signatureV2 = r.bytes();\n break;\n case 9:\n m.data = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n IpnsEntry.fromObject = function fromObject(d) {\n if (d instanceof $root.IpnsEntry)\n return d;\n var m = new $root.IpnsEntry();\n if (d.value != null) {\n if (typeof d.value === 'string')\n $util.base64.decode(d.value, m.value = $util.newBuffer($util.base64.length(d.value)), 0);\n else if (d.value.length)\n m.value = d.value;\n }\n if (d.signature != null) {\n if (typeof d.signature === 'string')\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n switch (d.validityType) {\n case 'EOL':\n case 0:\n m.validityType = 0;\n break;\n }\n if (d.validity != null) {\n if (typeof d.validity === 'string')\n $util.base64.decode(d.validity, m.validity = $util.newBuffer($util.base64.length(d.validity)), 0);\n else if (d.validity.length)\n m.validity = d.validity;\n }\n if (d.sequence != null) {\n if ($util.Long)\n (m.sequence = $util.Long.fromValue(d.sequence)).unsigned = true;\n else if (typeof d.sequence === 'string')\n m.sequence = parseInt(d.sequence, 10);\n else if (typeof d.sequence === 'number')\n m.sequence = d.sequence;\n else if (typeof d.sequence === 'object')\n m.sequence = new $util.LongBits(d.sequence.low >>> 0, d.sequence.high >>> 0).toNumber(true);\n }\n if (d.ttl != null) {\n if ($util.Long)\n (m.ttl = $util.Long.fromValue(d.ttl)).unsigned = true;\n else if (typeof d.ttl === 'string')\n m.ttl = parseInt(d.ttl, 10);\n else if (typeof d.ttl === 'number')\n m.ttl = d.ttl;\n else if (typeof d.ttl === 'object')\n m.ttl = new $util.LongBits(d.ttl.low >>> 0, d.ttl.high >>> 0).toNumber(true);\n }\n if (d.pubKey != null) {\n if (typeof d.pubKey === 'string')\n $util.base64.decode(d.pubKey, m.pubKey = $util.newBuffer($util.base64.length(d.pubKey)), 0);\n else if (d.pubKey.length)\n m.pubKey = d.pubKey;\n }\n if (d.signatureV2 != null) {\n if (typeof d.signatureV2 === 'string')\n $util.base64.decode(d.signatureV2, m.signatureV2 = $util.newBuffer($util.base64.length(d.signatureV2)), 0);\n else if (d.signatureV2.length)\n m.signatureV2 = d.signatureV2;\n }\n if (d.data != null) {\n if (typeof d.data === 'string')\n $util.base64.decode(d.data, m.data = $util.newBuffer($util.base64.length(d.data)), 0);\n else if (d.data.length)\n m.data = d.data;\n }\n return m;\n };\n IpnsEntry.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.value = '';\n else {\n d.value = [];\n if (o.bytes !== Array)\n d.value = $util.newBuffer(d.value);\n }\n if (o.bytes === String)\n d.signature = '';\n else {\n d.signature = [];\n if (o.bytes !== Array)\n d.signature = $util.newBuffer(d.signature);\n }\n d.validityType = o.enums === String ? 'EOL' : 0;\n if (o.bytes === String)\n d.validity = '';\n else {\n d.validity = [];\n if (o.bytes !== Array)\n d.validity = $util.newBuffer(d.validity);\n }\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.sequence = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.sequence = o.longs === String ? '0' : 0;\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.ttl = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.ttl = o.longs === String ? '0' : 0;\n if (o.bytes === String)\n d.pubKey = '';\n else {\n d.pubKey = [];\n if (o.bytes !== Array)\n d.pubKey = $util.newBuffer(d.pubKey);\n }\n if (o.bytes === String)\n d.signatureV2 = '';\n else {\n d.signatureV2 = [];\n if (o.bytes !== Array)\n d.signatureV2 = $util.newBuffer(d.signatureV2);\n }\n if (o.bytes === String)\n d.data = '';\n else {\n d.data = [];\n if (o.bytes !== Array)\n d.data = $util.newBuffer(d.data);\n }\n }\n if (m.value != null && m.hasOwnProperty('value')) {\n d.value = o.bytes === String ? $util.base64.encode(m.value, 0, m.value.length) : o.bytes === Array ? Array.prototype.slice.call(m.value) : m.value;\n }\n if (m.signature != null && m.hasOwnProperty('signature')) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n }\n if (m.validityType != null && m.hasOwnProperty('validityType')) {\n d.validityType = o.enums === String ? $root.IpnsEntry.ValidityType[m.validityType] : m.validityType;\n }\n if (m.validity != null && m.hasOwnProperty('validity')) {\n d.validity = o.bytes === String ? $util.base64.encode(m.validity, 0, m.validity.length) : o.bytes === Array ? Array.prototype.slice.call(m.validity) : m.validity;\n }\n if (m.sequence != null && m.hasOwnProperty('sequence')) {\n if (typeof m.sequence === 'number')\n d.sequence = o.longs === String ? String(m.sequence) : m.sequence;\n else\n d.sequence = o.longs === String ? $util.Long.prototype.toString.call(m.sequence) : o.longs === Number ? new $util.LongBits(m.sequence.low >>> 0, m.sequence.high >>> 0).toNumber(true) : m.sequence;\n }\n if (m.ttl != null && m.hasOwnProperty('ttl')) {\n if (typeof m.ttl === 'number')\n d.ttl = o.longs === String ? String(m.ttl) : m.ttl;\n else\n d.ttl = o.longs === String ? $util.Long.prototype.toString.call(m.ttl) : o.longs === Number ? new $util.LongBits(m.ttl.low >>> 0, m.ttl.high >>> 0).toNumber(true) : m.ttl;\n }\n if (m.pubKey != null && m.hasOwnProperty('pubKey')) {\n d.pubKey = o.bytes === String ? $util.base64.encode(m.pubKey, 0, m.pubKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.pubKey) : m.pubKey;\n }\n if (m.signatureV2 != null && m.hasOwnProperty('signatureV2')) {\n d.signatureV2 = o.bytes === String ? $util.base64.encode(m.signatureV2, 0, m.signatureV2.length) : o.bytes === Array ? Array.prototype.slice.call(m.signatureV2) : m.signatureV2;\n }\n if (m.data != null && m.hasOwnProperty('data')) {\n d.data = o.bytes === String ? $util.base64.encode(m.data, 0, m.data.length) : o.bytes === Array ? Array.prototype.slice.call(m.data) : m.data;\n }\n return d;\n };\n IpnsEntry.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default['default'].util.toJSONOptions);\n };\n IpnsEntry.ValidityType = function () {\n const valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = 'EOL'] = 0;\n return values;\n }();\n return IpnsEntry;\n})();\n\nexports.IpnsEntry = IpnsEntry;\nexports['default'] = $root;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction toRFC3339(time) {\n const year = time.getUTCFullYear();\n const month = String(time.getUTCMonth() + 1).padStart(2, '0');\n const day = String(time.getUTCDate()).padStart(2, '0');\n const hour = String(time.getUTCHours()).padStart(2, '0');\n const minute = String(time.getUTCMinutes()).padStart(2, '0');\n const seconds = String(time.getUTCSeconds()).padStart(2, '0');\n const milliseconds = time.getUTCMilliseconds();\n const nanoseconds = milliseconds * 1000 * 1000;\n return `${ year }-${ month }-${ day }T${ hour }:${ minute }:${ seconds }.${ nanoseconds }Z`;\n}\nfunction parseRFC3339(time) {\n const rfc3339Matcher = new RegExp('(\\\\d{4})-(\\\\d{2})-(\\\\d{2})T' + '(\\\\d{2}):(\\\\d{2}):(\\\\d{2})' + '\\\\.(\\\\d+)Z');\n const m = String(time).trim().match(rfc3339Matcher);\n if (!m) {\n throw new Error('Invalid format');\n }\n const year = parseInt(m[1], 10);\n const month = parseInt(m[2], 10) - 1;\n const date = parseInt(m[3], 10);\n const hour = parseInt(m[4], 10);\n const minute = parseInt(m[5], 10);\n const second = parseInt(m[6], 10);\n const millisecond = parseInt(m[7].slice(0, -6), 10);\n return new Date(Date.UTC(year, month, date, hour, minute, second, millisecond));\n}\n\nexports.parseRFC3339 = parseRFC3339;\nexports.toRFC3339 = toRFC3339;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst ERR_IPNS_EXPIRED_RECORD = 'ERR_IPNS_EXPIRED_RECORD';\nconst ERR_UNRECOGNIZED_VALIDITY = 'ERR_UNRECOGNIZED_VALIDITY';\nconst ERR_SIGNATURE_CREATION = 'ERR_SIGNATURE_CREATION';\nconst ERR_SIGNATURE_VERIFICATION = 'ERR_SIGNATURE_VERIFICATION';\nconst ERR_UNRECOGNIZED_FORMAT = 'ERR_UNRECOGNIZED_FORMAT';\nconst ERR_PEER_ID_FROM_PUBLIC_KEY = 'ERR_PEER_ID_FROM_PUBLIC_KEY';\nconst ERR_PUBLIC_KEY_FROM_ID = 'ERR_PUBLIC_KEY_FROM_ID';\nconst ERR_UNDEFINED_PARAMETER = 'ERR_UNDEFINED_PARAMETER';\nconst ERR_INVALID_RECORD_DATA = 'ERR_INVALID_RECORD_DATA';\nconst ERR_INVALID_EMBEDDED_KEY = 'ERR_INVALID_EMBEDDED_KEY';\n\nexports.ERR_INVALID_EMBEDDED_KEY = ERR_INVALID_EMBEDDED_KEY;\nexports.ERR_INVALID_RECORD_DATA = ERR_INVALID_RECORD_DATA;\nexports.ERR_IPNS_EXPIRED_RECORD = ERR_IPNS_EXPIRED_RECORD;\nexports.ERR_PEER_ID_FROM_PUBLIC_KEY = ERR_PEER_ID_FROM_PUBLIC_KEY;\nexports.ERR_PUBLIC_KEY_FROM_ID = ERR_PUBLIC_KEY_FROM_ID;\nexports.ERR_SIGNATURE_CREATION = ERR_SIGNATURE_CREATION;\nexports.ERR_SIGNATURE_VERIFICATION = ERR_SIGNATURE_VERIFICATION;\nexports.ERR_UNDEFINED_PARAMETER = ERR_UNDEFINED_PARAMETER;\nexports.ERR_UNRECOGNIZED_FORMAT = ERR_UNRECOGNIZED_FORMAT;\nexports.ERR_UNRECOGNIZED_VALIDITY = ERR_UNRECOGNIZED_VALIDITY;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipns = require('ipns');\nvar crypto = require('libp2p-crypto');\nvar PeerId = require('peer-id');\nvar errCode = require('err-code');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\nvar crypto__default = /*#__PURE__*/_interopDefaultLegacy(crypto);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:republisher'), { error: debug__default['default']('ipfs:ipns:republisher:error') });\nconst minute = 60 * 1000;\nconst hour = 60 * minute;\nconst defaultBroadcastInterval = 4 * hour;\nconst defaultRecordLifetime = 24 * hour;\nclass IpnsRepublisher {\n constructor(publisher, datastore, peerId, keychain, options = { pass: '' }) {\n this._publisher = publisher;\n this._datastore = datastore;\n this._peerId = peerId;\n this._keychain = keychain;\n this._options = options;\n this._republishHandle = null;\n }\n async start() {\n if (this._republishHandle) {\n throw errCode__default['default'](new Error('republisher is already running'), 'ERR_REPUBLISH_ALREADY_RUNNING');\n }\n const republishHandle = {\n _task: null,\n _inflightTask: null,\n _timeoutId: null,\n runPeriodically: period => {\n republishHandle._timeoutId = setTimeout(async () => {\n republishHandle._timeoutId = null;\n try {\n republishHandle._inflightTask = republishHandle._task();\n await republishHandle._inflightTask;\n if (republishHandle._task) {\n republishHandle.runPeriodically(period);\n }\n } catch (err) {\n log.error(err);\n }\n }, period());\n },\n cancel: async () => {\n if (republishHandle._timeoutId != null) {\n clearTimeout(republishHandle._timeoutId);\n }\n republishHandle._task = null;\n await republishHandle._inflightTask;\n }\n };\n const {privKey} = this._peerId;\n const {pass} = this._options;\n let firstRun = true;\n republishHandle._task = () => this._republishEntries(privKey, pass);\n republishHandle.runPeriodically(() => {\n if (firstRun) {\n firstRun = false;\n return this._options.initialBroadcastInterval || minute;\n }\n return this._options.broadcastInterval || defaultBroadcastInterval;\n });\n this._republishHandle = republishHandle;\n }\n async stop() {\n const republishHandle = this._republishHandle;\n if (!republishHandle) {\n throw errCode__default['default'](new Error('republisher is not running'), 'ERR_REPUBLISH_NOT_RUNNING');\n }\n this._republishHandle = null;\n await republishHandle.cancel();\n }\n async _republishEntries(privateKey, pass) {\n try {\n await this._republishEntry(privateKey);\n } catch (err) {\n const errMsg = 'cannot republish entry for the node\\'s private key';\n log.error(errMsg);\n return;\n }\n if (pass) {\n try {\n const keys = await this._keychain.listKeys();\n for (const key of keys) {\n if (key.name === 'self') {\n continue;\n }\n const pem = await this._keychain.exportKey(key.name, pass);\n const privKey = await crypto__default['default'].keys.import(pem, pass);\n await this._republishEntry(privKey);\n }\n } catch (err) {\n log.error(err);\n }\n }\n }\n async _republishEntry(privateKey) {\n if (!privateKey || !privateKey.bytes) {\n throw errCode__default['default'](new Error('invalid private key'), 'ERR_INVALID_PRIVATE_KEY');\n }\n try {\n const peerId = await PeerId__default['default'].createFromPrivKey(privateKey.bytes);\n const value = await this._getPreviousValue(peerId);\n await this._publisher.publishWithEOL(privateKey, value, defaultRecordLifetime);\n } catch (err) {\n if (err.code === 'ERR_NO_ENTRY_FOUND') {\n return;\n }\n throw err;\n }\n }\n async _getPreviousValue(peerId) {\n if (!PeerId__default['default'].isPeerId(peerId)) {\n throw errCode__default['default'](new Error('invalid peer ID'), 'ERR_INVALID_PEER_ID');\n }\n try {\n const dsVal = await this._datastore.get(ipns__namespace.getLocalKey(peerId.id));\n if (!(dsVal instanceof Uint8Array)) {\n throw errCode__default['default'](new Error('found ipns record that we couldn\\'t process'), 'ERR_INVALID_IPNS_RECORD');\n }\n try {\n const record = ipns__namespace.unmarshal(dsVal);\n return record.value;\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](new Error('found ipns record that we couldn\\'t convert to a value'), 'ERR_INVALID_IPNS_RECORD');\n }\n } catch (err) {\n if (err && err.notFound) {\n throw errCode__default['default'](new Error(`no previous entry for record with id: ${ peerId.id }`), 'ERR_NO_ENTRY_FOUND');\n }\n throw err;\n }\n }\n}\n\nexports.IpnsRepublisher = IpnsRepublisher;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipns = require('ipns');\nvar PeerId = require('peer-id');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar toString = require('uint8arrays/to-string');\nvar Errors = require('datastore-core/errors');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar Errors__namespace = /*#__PURE__*/_interopNamespace(Errors);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:resolver'), { error: debug__default['default']('ipfs:ipns:resolver:error') });\nconst ERR_NOT_FOUND = Errors__namespace.notFoundError().code;\nconst defaultMaximumRecursiveDepth = 32;\nclass IpnsResolver {\n constructor(routing) {\n this._routing = routing;\n }\n async resolve(name, options = {}) {\n if (typeof name !== 'string') {\n throw errCode__default['default'](new Error('invalid name'), 'ERR_INVALID_NAME');\n }\n const recursive = options.recursive && options.recursive.toString() === 'true';\n const nameSegments = name.split('/');\n if (nameSegments.length !== 3 || nameSegments[0] !== '') {\n throw errCode__default['default'](new Error('invalid name'), 'ERR_INVALID_NAME');\n }\n const key = nameSegments[2];\n let depth = Infinity;\n if (recursive) {\n depth = defaultMaximumRecursiveDepth;\n }\n const res = await this.resolver(key, depth);\n log(`${ name } was locally resolved correctly`);\n return res;\n }\n async resolver(name, depth) {\n if (depth === 0) {\n const errMsg = `could not resolve name (recursion limit of ${ defaultMaximumRecursiveDepth } exceeded)`;\n log.error(errMsg);\n throw errCode__default['default'](new Error(errMsg), 'ERR_RESOLVE_RECURSION_LIMIT');\n }\n const res = await this._resolveName(name);\n const nameSegments = res.split('/');\n if (nameSegments[1] === 'ipfs' || !depth) {\n return res;\n }\n return this.resolver(nameSegments[2], depth - 1);\n }\n async _resolveName(name) {\n const peerId = PeerId__default['default'].parse(name);\n const {routingKey} = ipns__namespace.getIdKeys(peerId.toBytes());\n let record;\n try {\n record = await this._routing.get(routingKey.uint8Array());\n } catch (err) {\n log.error('could not get record from routing', err);\n if (err.code === ERR_NOT_FOUND) {\n throw errCode__default['default'](new Error(`record requested for ${ name } was not found in the network`), 'ERR_NO_RECORD_FOUND');\n }\n throw errCode__default['default'](new Error(`unexpected error getting the ipns record ${ peerId.toString() }`), 'ERR_UNEXPECTED_ERROR_GETTING_RECORD');\n }\n let ipnsEntry;\n try {\n ipnsEntry = ipns__namespace.unmarshal(record);\n } catch (err) {\n log.error('could not unmarshal record', err);\n throw errCode__default['default'](new Error('found ipns record that we couldn\\'t convert to a value'), 'ERR_INVALID_RECORD_RECEIVED');\n }\n return this._validateRecord(peerId, ipnsEntry);\n }\n async _validateRecord(peerId, ipnsEntry) {\n const pubKey = await ipns__namespace.extractPublicKey(peerId, ipnsEntry);\n await ipns__namespace.validate(pubKey, ipnsEntry);\n return toString.toString(ipnsEntry.value);\n }\n}\n\nexports.IpnsResolver = IpnsResolver;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hashlru = require('hashlru');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar hashlru__default = /*#__PURE__*/_interopDefaultLegacy(hashlru);\n\nclass TLRU {\n constructor(maxSize) {\n this.lru = hashlru__default['default'](maxSize);\n }\n get(key) {\n const value = this.lru.get(key);\n if (value) {\n if (value.expire && value.expire < Date.now()) {\n this.lru.remove(key);\n return undefined;\n }\n return value.value;\n }\n return undefined;\n }\n set(key, value, ttl) {\n this.lru.set(key, {\n value,\n expire: Date.now() + ttl\n });\n }\n has(key) {\n const value = this.get(key);\n if (value) {\n return true;\n }\n return false;\n }\n remove(key) {\n this.lru.remove(key);\n }\n clear() {\n this.lru.clear();\n }\n}\n\nexports.TLRU = TLRU;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar tiered = require('datastore-core/tiered');\nvar get = require('dlv');\nvar pubsubDatastore = require('./pubsub-datastore.js');\nvar offlineDatastore = require('./offline-datastore.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar get__default = /*#__PURE__*/_interopDefaultLegacy(get);\n\nfunction createRouting({libp2p, repo, peerId, options}) {\n const ipnsStores = [];\n let pubsubDs;\n if (get__default['default'](options, 'EXPERIMENTAL.ipnsPubsub', false)) {\n const pubsub = libp2p.pubsub;\n const localDatastore = repo.datastore;\n pubsubDs = new pubsubDatastore.IpnsPubsubDatastore(pubsub, localDatastore, peerId);\n ipnsStores.push(pubsubDs);\n }\n if (get__default['default'](options, 'offline') || !get__default['default'](options, 'libp2p.config.dht.enabled', false)) {\n const offlineDatastore$1 = new offlineDatastore.OfflineDatastore(repo);\n ipnsStores.push(offlineDatastore$1);\n } else {\n ipnsStores.push(libp2p._dht);\n }\n return new tiered.TieredDatastore(ipnsStores);\n}\n\nexports.createRouting = createRouting;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar errors = require('./errors.js');\nvar debug = require('debug');\nvar pushable = require('it-pushable');\nvar drain = require('it-drain');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar pushable__default = /*#__PURE__*/_interopDefaultLegacy(pushable);\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\n\nconst log = debug__default['default']('datastore:core:tiered');\nclass TieredDatastore extends base.BaseDatastore {\n constructor(stores) {\n super();\n this.stores = stores.slice();\n }\n async open() {\n try {\n await Promise.all(this.stores.map(store => store.open()));\n } catch (err) {\n throw errors.dbOpenFailedError();\n }\n }\n async put(key, value) {\n try {\n await Promise.all(this.stores.map(store => store.put(key, value)));\n } catch (err) {\n throw errors.dbWriteFailedError();\n }\n }\n async get(key, options) {\n for (const store of this.stores) {\n try {\n const res = await store.get(key, options);\n if (res)\n return res;\n } catch (err) {\n log(err);\n }\n }\n throw errors.notFoundError();\n }\n async has(key, options) {\n for (const s of this.stores) {\n if (await s.has(key, options)) {\n return true;\n }\n }\n return false;\n }\n async delete(key, options) {\n try {\n await Promise.all(this.stores.map(store => store.delete(key, options)));\n } catch (err) {\n throw errors.dbDeleteFailedError();\n }\n }\n async *putMany(source, options = {}) {\n let error;\n const pushables = this.stores.map(store => {\n const source = pushable__default['default']();\n drain__default['default'](store.putMany(source, options)).catch(err => {\n error = err;\n });\n return source;\n });\n try {\n for await (const pair of source) {\n if (error) {\n throw error;\n }\n pushables.forEach(p => p.push(pair));\n yield pair;\n }\n } finally {\n pushables.forEach(p => p.end());\n }\n }\n async *deleteMany(source, options = {}) {\n let error;\n const pushables = this.stores.map(store => {\n const source = pushable__default['default']();\n drain__default['default'](store.deleteMany(source, options)).catch(err => {\n error = err;\n });\n return source;\n });\n try {\n for await (const key of source) {\n if (error) {\n throw error;\n }\n pushables.forEach(p => p.push(key));\n yield key;\n }\n } finally {\n pushables.forEach(p => p.end());\n }\n }\n async close() {\n await Promise.all(this.stores.map(store => store.close()));\n }\n batch() {\n const batches = this.stores.map(store => store.batch());\n return {\n put: (key, value) => {\n batches.forEach(b => b.put(key, value));\n },\n delete: key => {\n batches.forEach(b => b.delete(key));\n },\n commit: async options => {\n for (const batch of batches) {\n await batch.commit(options);\n }\n }\n };\n }\n query(q, options) {\n return this.stores[this.stores.length - 1].query(q, options);\n }\n queryKeys(q, options) {\n return this.stores[this.stores.length - 1].queryKeys(q, options);\n }\n}\n\nexports.TieredDatastore = TieredDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar drain = require('it-drain');\nvar filter = require('it-filter');\nvar take = require('it-take');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar take__default = /*#__PURE__*/_interopDefaultLegacy(take);\n\nclass BaseDatastore {\n open() {\n return Promise.reject(new Error('.open is not implemented'));\n }\n close() {\n return Promise.reject(new Error('.close is not implemented'));\n }\n put(key, val, options) {\n return Promise.reject(new Error('.put is not implemented'));\n }\n get(key, options) {\n return Promise.reject(new Error('.get is not implemented'));\n }\n has(key, options) {\n return Promise.reject(new Error('.has is not implemented'));\n }\n delete(key, options) {\n return Promise.reject(new Error('.delete is not implemented'));\n }\n async *putMany(source, options = {}) {\n for await (const {key, value} of source) {\n await this.put(key, value, options);\n yield {\n key,\n value\n };\n }\n }\n async *getMany(source, options = {}) {\n for await (const key of source) {\n yield this.get(key, options);\n }\n }\n async *deleteMany(source, options = {}) {\n for await (const key of source) {\n await this.delete(key, options);\n yield key;\n }\n }\n batch() {\n let puts = [];\n let dels = [];\n return {\n put(key, value) {\n puts.push({\n key,\n value\n });\n },\n delete(key) {\n dels.push(key);\n },\n commit: async options => {\n await drain__default['default'](this.putMany(puts, options));\n puts = [];\n await drain__default['default'](this.deleteMany(dels, options));\n dels = [];\n }\n };\n }\n async *_all(q, options) {\n throw new Error('._all is not implemented');\n }\n async *_allKeys(q, options) {\n throw new Error('._allKeys is not implemented');\n }\n query(q, options) {\n let it = this._all(q, options);\n if (q.prefix != null) {\n it = filter__default['default'](it, e => e.key.toString().startsWith(q.prefix));\n }\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => utils.sortAll(it, f), it);\n }\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null) {\n it = take__default['default'](it, q.limit);\n }\n return it;\n }\n queryKeys(q, options) {\n let it = this._allKeys(q, options);\n if (q.prefix != null) {\n it = filter__default['default'](it, key => key.toString().startsWith(q.prefix));\n }\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => utils.sortAll(it, f), it);\n }\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null) {\n it = take__default['default'](it, q.limit);\n }\n return it;\n }\n}\n\nexports.BaseDatastore = BaseDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar all = require('it-all');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\n\nconst sortAll = (iterable, sorter) => {\n return async function* () {\n const values = await all__default['default'](iterable);\n yield* values.sort(sorter);\n }();\n};\nconst replaceStartWith = (s, r) => {\n const matcher = new RegExp('^' + r);\n return s.replace(matcher, '');\n};\n\nexports.replaceStartWith = replaceStartWith;\nexports.sortAll = sortAll;\n","'use strict'\n\n/**\n * Collects all values from an (async) iterable into an array and returns it.\n *\n * @template T\n * @param {AsyncIterable<T>|Iterable<T>} source\n */\nconst all = async (source) => {\n const arr = []\n\n for await (const entry of source) {\n arr.push(entry)\n }\n\n return arr\n}\n\nmodule.exports = all\n","'use strict'\n\n/**\n * Drains an (async) iterable discarding its' content and does not return\n * anything.\n *\n * @template T\n * @param {AsyncIterable<T>|Iterable<T>} source\n * @returns {Promise<void>}\n */\nconst drain = async (source) => {\n for await (const _ of source) { } // eslint-disable-line no-unused-vars,no-empty\n}\n\nmodule.exports = drain\n","'use strict'\n\n/**\n * Filters the passed (async) iterable by using the filter function\n *\n * @template T\n * @param {AsyncIterable<T>|Iterable<T>} source\n * @param {function(T):boolean|Promise<boolean>} fn\n */\nconst filter = async function * (source, fn) {\n for await (const entry of source) {\n if (await fn(entry)) {\n yield entry\n }\n }\n}\n\nmodule.exports = filter\n","'use strict'\n\n/**\n * Stop iteration after n items have been received.\n *\n * @template T\n * @param {AsyncIterable<T>|Iterable<T>} source\n * @param {number} limit\n * @returns {AsyncIterable<T>}\n */\nconst take = async function * (source, limit) {\n let items = 0\n\n if (limit < 1) {\n return\n }\n\n for await (const entry of source) {\n yield entry\n\n items++\n\n if (items === limit) {\n return\n }\n }\n}\n\nmodule.exports = take\n","const FIFO = require('fast-fifo')\n\nmodule.exports = (options) => {\n options = options || {}\n let onEnd\n\n if (typeof options === 'function') {\n onEnd = options\n options = {}\n } else {\n onEnd = options.onEnd\n }\n\n let buffer = new FIFO()\n let pushable, onNext, ended\n\n const waitNext = () => {\n if (!buffer.isEmpty()) {\n if (options.writev) {\n let next\n const values = []\n while (!buffer.isEmpty()) {\n next = buffer.shift()\n if (next.error) throw next.error\n values.push(next.value)\n }\n return { done: next.done, value: values }\n }\n\n const next = buffer.shift()\n if (next.error) throw next.error\n return next\n }\n\n if (ended) return { done: true }\n\n return new Promise((resolve, reject) => {\n onNext = next => {\n onNext = null\n if (next.error) {\n reject(next.error)\n } else {\n if (options.writev && !next.done) {\n resolve({ done: next.done, value: [next.value] })\n } else {\n resolve(next)\n }\n }\n return pushable\n }\n })\n }\n\n const bufferNext = next => {\n if (onNext) return onNext(next)\n buffer.push(next)\n return pushable\n }\n\n const bufferError = err => {\n buffer = new FIFO()\n if (onNext) return onNext({ error: err })\n buffer.push({ error: err })\n return pushable\n }\n\n const push = value => {\n if (ended) return pushable\n return bufferNext({ done: false, value })\n }\n const end = err => {\n if (ended) return pushable\n ended = true\n return err ? bufferError(err) : bufferNext({ done: true })\n }\n const _return = () => {\n buffer = new FIFO()\n end()\n return { done: true }\n }\n const _throw = err => {\n end(err)\n return { done: true }\n }\n\n pushable = {\n [Symbol.asyncIterator] () { return this },\n next: waitNext,\n return: _return,\n throw: _throw,\n push,\n end\n }\n\n if (!onEnd) return pushable\n\n const _pushable = pushable\n\n pushable = {\n [Symbol.asyncIterator] () { return this },\n next () {\n return _pushable.next()\n },\n throw (err) {\n _pushable.throw(err)\n if (onEnd) {\n onEnd(err)\n onEnd = null\n }\n return { done: true }\n },\n return () {\n _pushable.return()\n if (onEnd) {\n onEnd()\n onEnd = null\n }\n return { done: true }\n },\n push,\n end (err) {\n _pushable.end(err)\n if (onEnd) {\n onEnd(err)\n onEnd = null\n }\n return pushable\n }\n }\n\n return pushable\n}\n","const FixedFIFO = require('./fixed-size')\n\nmodule.exports = class FastFIFO {\n constructor (hwm) {\n this.hwm = hwm || 16\n this.head = new FixedFIFO(this.hwm)\n this.tail = this.head\n }\n\n push (val) {\n if (!this.head.push(val)) {\n const prev = this.head\n this.head = prev.next = new FixedFIFO(2 * this.head.buffer.length)\n this.head.push(val)\n }\n }\n\n shift () {\n const val = this.tail.shift()\n if (val === undefined && this.tail.next) {\n const next = this.tail.next\n this.tail.next = null\n this.tail = next\n return this.tail.shift()\n }\n return val\n }\n\n isEmpty () {\n return this.head.isEmpty()\n }\n}\n","module.exports = class FixedFIFO {\n constructor (hwm) {\n if (!(hwm > 0) || ((hwm - 1) & hwm) !== 0) throw new Error('Max size for a FixedFIFO should be a power of two')\n this.buffer = new Array(hwm)\n this.mask = hwm - 1\n this.top = 0\n this.btm = 0\n this.next = null\n }\n\n push (data) {\n if (this.buffer[this.top] !== undefined) return false\n this.buffer[this.top] = data\n this.top = (this.top + 1) & this.mask\n return true\n }\n\n shift () {\n const last = this.buffer[this.btm]\n if (last === undefined) return undefined\n this.buffer[this.btm] = undefined\n this.btm = (this.btm + 1) & this.mask\n return last\n }\n\n isEmpty () {\n return this.buffer[this.btm] === undefined\n }\n}\n","export default function dlv(obj, key, def, p, undef) {\n\tkey = key.split ? key.split('.') : key;\n\tfor (p = 0; p < key.length; p++) {\n\t\tobj = obj ? obj[key[p]] : undef;\n\t}\n\treturn obj === undef ? def : obj;\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipns = require('ipns');\nvar base58 = require('multiformats/bases/base58');\nvar datastorePubsub = require('datastore-pubsub');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar errCode = require('err-code');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:pubsub'), { error: debug__default['default']('ipfs:ipns:pubsub:error') });\nclass IpnsPubsubDatastore {\n constructor(pubsub, localDatastore, peerId) {\n this._subscriptions = {};\n this._handleSubscriptionKey = this._handleSubscriptionKey.bind(this);\n this._pubsubDs = new datastorePubsub.PubsubDatastore(pubsub, localDatastore, peerId, ipns__namespace.validator, this._handleSubscriptionKey);\n }\n put(key, value) {\n return this._pubsubDs.put(key, value);\n }\n async get(key) {\n let res;\n let err;\n try {\n res = await this._pubsubDs.get(key);\n } catch (e) {\n err = e;\n }\n const ns = key.slice(0, ipns__namespace.namespaceLength);\n if (toString.toString(ns) === ipns__namespace.namespace) {\n const stringifiedTopic = base58.base58btc.encode(key).substring(1);\n const id = base58.base58btc.encode(key.slice(ipns__namespace.namespaceLength)).substring(1);\n this._subscriptions[stringifiedTopic] = id;\n log(`subscribed to pubsub topic ${ stringifiedTopic }, id ${ id }`);\n }\n if (err) {\n throw err;\n }\n return res;\n }\n _handleSubscriptionKey(key) {\n if (key instanceof Uint8Array) {\n key = toString.toString(key, 'base58btc');\n }\n const subscriber = this._subscriptions[key];\n if (!subscriber) {\n throw errCode__default['default'](new Error(`key ${ key } does not correspond to a subscription`), 'ERR_INVALID_KEY');\n }\n let keys;\n try {\n keys = ipns__namespace.getIdKeys(fromString.fromString(subscriber, 'base58btc'));\n } catch (err) {\n log.error(err);\n throw err;\n }\n return keys.routingKey.uint8Array();\n }\n getSubscriptions() {\n const subscriptions = Object.values(this._subscriptions).filter(Boolean);\n return subscriptions.map(sub => `${ ipns__namespace.namespace }${ sub }`);\n }\n async cancel(name) {\n if (typeof name !== 'string') {\n throw errCode__default['default'](new Error('invalid subscription name'), 'ERR_INVALID_SUBSCRIPTION_NAME');\n }\n if (name.startsWith(ipns__namespace.namespace)) {\n name = name.substring(ipns__namespace.namespaceLength);\n }\n const stringifiedTopic = Object.keys(this._subscriptions).find(key => this._subscriptions[key] === name);\n if (!stringifiedTopic) {\n return { canceled: false };\n }\n const bufTopic = fromString.fromString(stringifiedTopic);\n this._pubsubDs.unsubscribe(bufTopic);\n delete this._subscriptions[stringifiedTopic];\n log(`unsubscribed pubsub ${ stringifiedTopic }: ${ name }`);\n return { canceled: true };\n }\n}\n\nexports.IpnsPubsubDatastore = IpnsPubsubDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar datastoreCore = require('datastore-core');\nvar utils = require('./utils.js');\nvar equals = require('uint8arrays/equals');\nvar errcode = require('err-code');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('datastore-pubsub:publisher'), { error: debug__default['default']('datastore-pubsub:publisher:error') });\nclass PubsubDatastore extends datastoreCore.BaseDatastore {\n constructor(pubsub, datastore, peerId, validator, subscriptionKeyFn) {\n super();\n if (!validator) {\n throw errcode__default['default'](new TypeError('missing validator'), 'ERR_INVALID_PARAMETERS');\n }\n if (typeof validator.validate !== 'function') {\n throw errcode__default['default'](new TypeError('missing validate function'), 'ERR_INVALID_PARAMETERS');\n }\n if (typeof validator.select !== 'function') {\n throw errcode__default['default'](new TypeError('missing select function'), 'ERR_INVALID_PARAMETERS');\n }\n if (subscriptionKeyFn && typeof subscriptionKeyFn !== 'function') {\n throw errcode__default['default'](new TypeError('invalid subscriptionKeyFn received'), 'ERR_INVALID_PARAMETERS');\n }\n this._pubsub = pubsub;\n this._datastore = datastore;\n this._peerId = peerId;\n this._validator = validator;\n this._handleSubscriptionKeyFn = subscriptionKeyFn;\n this._onMessage = this._onMessage.bind(this);\n }\n async put(key, val) {\n if (!(key instanceof Uint8Array)) {\n const errMsg = 'datastore key does not have a valid format';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_INVALID_DATASTORE_KEY');\n }\n if (!(val instanceof Uint8Array)) {\n const errMsg = 'received value is not a Uint8Array';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_INVALID_VALUE_RECEIVED');\n }\n const stringifiedTopic = utils.keyToTopic(key);\n log(`publish value for topic ${ stringifiedTopic }`);\n await this._pubsub.publish(stringifiedTopic, val);\n }\n async get(key) {\n if (!(key instanceof Uint8Array)) {\n const errMsg = 'datastore key does not have a valid format';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_INVALID_DATASTORE_KEY');\n }\n const stringifiedTopic = utils.keyToTopic(key);\n const subscriptions = await this._pubsub.getTopics();\n if (subscriptions && Array.isArray(subscriptions) && subscriptions.indexOf(stringifiedTopic) > -1) {\n return this._getLocal(key);\n }\n try {\n this._pubsub.on(stringifiedTopic, this._onMessage);\n await this._pubsub.subscribe(stringifiedTopic);\n } catch (err) {\n const errMsg = `cannot subscribe topic ${ stringifiedTopic }`;\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_SUBSCRIBING_TOPIC');\n }\n log(`subscribed values for key ${ stringifiedTopic }`);\n return this._getLocal(key);\n }\n unsubscribe(key) {\n const stringifiedTopic = utils.keyToTopic(key);\n this._pubsub.removeListener(stringifiedTopic, this._onMessage);\n return this._pubsub.unsubscribe(stringifiedTopic);\n }\n async _getLocal(key) {\n const routingKey = new interfaceDatastore.Key('/' + utils.encodeBase32(key), false);\n let dsVal;\n try {\n dsVal = await this._datastore.get(routingKey);\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n const errMsg = `unexpected error getting the ipns record for ${ routingKey.toString() }`;\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_UNEXPECTED_ERROR_GETTING_RECORD');\n }\n const errMsg = `local record requested was not found for ${ routingKey.toString() }`;\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_NOT_FOUND');\n }\n if (!(dsVal instanceof Uint8Array)) {\n const errMsg = 'found record that we couldn\\'t convert to a value';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_INVALID_RECORD_RECEIVED');\n }\n return dsVal;\n }\n async _onMessage(msg) {\n const {data, from, topicIDs} = msg;\n let key;\n try {\n key = utils.topicToKey(topicIDs[0]);\n } catch (err) {\n log.error(err);\n return;\n }\n log(`message received for topic ${ topicIDs[0] }`);\n if (from === this._peerId.toB58String()) {\n log('message discarded as it is from the same peer');\n return;\n }\n if (this._handleSubscriptionKeyFn) {\n let res;\n try {\n res = await this._handleSubscriptionKeyFn(key);\n } catch (err) {\n log.error('message discarded by the subscriptionKeyFn');\n return;\n }\n key = res;\n }\n try {\n await this._storeIfSubscriptionIsBetter(key, data);\n } catch (err) {\n log.error(err);\n }\n }\n async _storeIfSubscriptionIsBetter(key, data) {\n let isBetter = false;\n try {\n isBetter = await this._isBetter(key, data);\n } catch (err) {\n if (err.code !== 'ERR_NOT_VALID_RECORD') {\n throw err;\n }\n }\n if (isBetter) {\n await this._storeRecord(key, data);\n }\n }\n async _validateRecord(value, peerId) {\n return this._validator.validate(value, peerId);\n }\n async _selectRecord(key, records) {\n const res = await this._validator.select(key, records);\n return res === 0;\n }\n async _isBetter(key, val) {\n try {\n await this._validateRecord(val, key);\n } catch (err) {\n const errMsg = 'record received through pubsub is not valid';\n log.error(errMsg);\n throw errcode__default['default'](new Error(errMsg), 'ERR_NOT_VALID_RECORD');\n }\n const dsKey = new interfaceDatastore.Key(key);\n let currentRecord;\n try {\n currentRecord = await this._getLocal(dsKey.uint8Array());\n } catch (err) {\n return true;\n }\n if (equals.equals(currentRecord, val)) {\n return false;\n }\n return this._selectRecord(key, [\n currentRecord,\n val\n ]);\n }\n async _storeRecord(key, data) {\n const routingKey = new interfaceDatastore.Key('/' + utils.encodeBase32(key), false);\n await this._datastore.put(routingKey, data);\n log(`record for ${ utils.keyToTopic(key) } was stored in the datastore`);\n }\n}\n\nexports.PubsubDatastore = PubsubDatastore;\n","module.exports = require('./cjs/src/index.js')\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('./key.js');\n\n\n\nexports.Key = key.Key;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('./errors.js');\nvar shard$1 = require('./shard.js');\nvar base = require('./base.js');\nvar memory = require('./memory.js');\nvar keytransform = require('./keytransform.js');\nvar sharding = require('./sharding.js');\nvar mount = require('./mount.js');\nvar tiered = require('./tiered.js');\nvar namespace = require('./namespace.js');\n\nconst Errors = { ...errors };\nconst shard = { ...shard$1 };\n\nexports.BaseDatastore = base.BaseDatastore;\nexports.MemoryDatastore = memory.MemoryDatastore;\nexports.KeyTransformDatastore = keytransform.KeyTransformDatastore;\nexports.ShardingDatastore = sharding.ShardingDatastore;\nexports.MountDatastore = mount.MountDatastore;\nexports.TieredDatastore = tiered.TieredDatastore;\nexports.NamespaceDatastore = namespace.NamespaceDatastore;\nexports.Errors = Errors;\nexports.shard = shard;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar shardReadme = require('./shard-readme.js');\n\nconst PREFIX = '/repo/flatfs/shard/';\nconst SHARDING_FN = 'SHARDING';\nconst README_FN = '_README';\nclass ShardBase {\n constructor(param) {\n this.param = param;\n this.name = 'base';\n this._padding = '';\n }\n fun(s) {\n return 'implement me';\n }\n toString() {\n return `${ PREFIX }v1/${ this.name }/${ this.param }`;\n }\n}\nclass Prefix extends ShardBase {\n constructor(prefixLen) {\n super(prefixLen);\n this._padding = ''.padStart(prefixLen, '_');\n this.name = 'prefix';\n }\n fun(noslash) {\n return (noslash + this._padding).slice(0, this.param);\n }\n}\nclass Suffix extends ShardBase {\n constructor(suffixLen) {\n super(suffixLen);\n this._padding = ''.padStart(suffixLen, '_');\n this.name = 'suffix';\n }\n fun(noslash) {\n const s = this._padding + noslash;\n return s.slice(s.length - this.param);\n }\n}\nclass NextToLast extends ShardBase {\n constructor(suffixLen) {\n super(suffixLen);\n this._padding = ''.padStart(suffixLen + 1, '_');\n this.name = 'next-to-last';\n }\n fun(noslash) {\n const s = this._padding + noslash;\n const offset = s.length - this.param - 1;\n return s.slice(offset, offset + this.param);\n }\n}\nfunction parseShardFun(str) {\n str = str.trim();\n if (str.length === 0) {\n throw new Error('empty shard string');\n }\n if (!str.startsWith(PREFIX)) {\n throw new Error(`invalid or no path prefix: ${ str }`);\n }\n const parts = str.slice(PREFIX.length).split('/');\n const version = parts[0];\n if (version !== 'v1') {\n throw new Error(`expect 'v1' version, got '${ version }'`);\n }\n const name = parts[1];\n if (!parts[2]) {\n throw new Error('missing param');\n }\n const param = parseInt(parts[2], 10);\n switch (name) {\n case 'prefix':\n return new Prefix(param);\n case 'suffix':\n return new Suffix(param);\n case 'next-to-last':\n return new NextToLast(param);\n default:\n throw new Error(`unkown sharding function: ${ name }`);\n }\n}\nconst readShardFun = async (path, store) => {\n const key$1 = new key.Key(path).child(new key.Key(SHARDING_FN));\n const get = typeof store.getRaw === 'function' ? store.getRaw.bind(store) : store.get.bind(store);\n const res = await get(key$1);\n return parseShardFun(new TextDecoder().decode(res || '').trim());\n};\n\nexports.readme = shardReadme;\nexports.NextToLast = NextToLast;\nexports.PREFIX = PREFIX;\nexports.Prefix = Prefix;\nexports.README_FN = README_FN;\nexports.SHARDING_FN = SHARDING_FN;\nexports.ShardBase = ShardBase;\nexports.Suffix = Suffix;\nexports.parseShardFun = parseShardFun;\nexports.readShardFun = readShardFun;\n","'use strict';\n\nvar readme = `This is a repository of IPLD objects. Each IPLD object is in a single file,\nnamed <base32 encoding of cid>.data. Where <base32 encoding of cid> is the\n\"base32\" encoding of the CID (as specified in\nhttps://github.com/multiformats/multibase) without the 'B' prefix.\nAll the object files are placed in a tree of directories, based on a\nfunction of the CID. This is a form of sharding similar to\nthe objects directory in git repositories. Previously, we used\nprefixes, we now use the next-to-last two charters.\n func NextToLast(base32cid string) {\n nextToLastLen := 2\n offset := len(base32cid) - nextToLastLen - 1\n return str[offset : offset+nextToLastLen]\n }\nFor example, an object with a base58 CIDv1 of\n zb2rhYSxw4ZjuzgCnWSt19Q94ERaeFhu9uSqRgjSdx9bsgM6f\nhas a base32 CIDv1 of\n BAFKREIA22FLID5AJ2KU7URG47MDLROZIH6YF2KALU2PWEFPVI37YLKRSCA\nand will be placed at\n SC/AFKREIA22FLID5AJ2KU7URG47MDLROZIH6YF2KALU2PWEFPVI37YLKRSCA.data\nwith 'SC' being the last-to-next two characters and the 'B' at the\nbeginning of the CIDv1 string is the multibase prefix that is not\nstored in the filename.\n`;\n\nmodule.exports = readme;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar key = require('interface-datastore/key');\nvar errors = require('./errors.js');\n\nclass MemoryDatastore extends base.BaseDatastore {\n constructor() {\n super();\n this.data = {};\n }\n open() {\n return Promise.resolve();\n }\n close() {\n return Promise.resolve();\n }\n async put(key, val) {\n this.data[key.toString()] = val;\n }\n async get(key) {\n const exists = await this.has(key);\n if (!exists)\n throw errors.notFoundError();\n return this.data[key.toString()];\n }\n async has(key) {\n return this.data[key.toString()] !== undefined;\n }\n async delete(key) {\n delete this.data[key.toString()];\n }\n async *_all() {\n yield* Object.entries(this.data).map(([key$1, value]) => ({\n key: new key.Key(key$1),\n value\n }));\n }\n async *_allKeys() {\n yield* Object.entries(this.data).map(([key$1]) => new key.Key(key$1));\n }\n}\n\nexports.MemoryDatastore = MemoryDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar map = require('it-map');\nvar itPipe = require('it-pipe');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\n\nclass KeyTransformDatastore extends base.BaseDatastore {\n constructor(child, transform) {\n super();\n this.child = child;\n this.transform = transform;\n }\n open() {\n return this.child.open();\n }\n put(key, val, options) {\n return this.child.put(this.transform.convert(key), val, options);\n }\n get(key, options) {\n return this.child.get(this.transform.convert(key), options);\n }\n has(key, options) {\n return this.child.has(this.transform.convert(key), options);\n }\n delete(key, options) {\n return this.child.delete(this.transform.convert(key), options);\n }\n async *putMany(source, options = {}) {\n const transform = this.transform;\n const child = this.child;\n yield* itPipe.pipe(source, async function* (source) {\n yield* map__default['default'](source, ({key, value}) => ({\n key: transform.convert(key),\n value\n }));\n }, async function* (source) {\n yield* child.putMany(source, options);\n }, async function* (source) {\n yield* map__default['default'](source, ({key, value}) => ({\n key: transform.invert(key),\n value\n }));\n });\n }\n async *getMany(source, options = {}) {\n const transform = this.transform;\n const child = this.child;\n yield* itPipe.pipe(source, async function* (source) {\n yield* map__default['default'](source, key => transform.convert(key));\n }, async function* (source) {\n yield* child.getMany(source, options);\n });\n }\n async *deleteMany(source, options = {}) {\n const transform = this.transform;\n const child = this.child;\n yield* itPipe.pipe(source, async function* (source) {\n yield* map__default['default'](source, key => transform.convert(key));\n }, async function* (source) {\n yield* child.deleteMany(source, options);\n }, async function* (source) {\n yield* map__default['default'](source, key => transform.invert(key));\n });\n }\n batch() {\n const b = this.child.batch();\n return {\n put: (key, value) => {\n b.put(this.transform.convert(key), value);\n },\n delete: key => {\n b.delete(this.transform.convert(key));\n },\n commit: options => {\n return b.commit(options);\n }\n };\n }\n query(q, options) {\n return map__default['default'](this.child.query(q, options), ({key, value}) => {\n return {\n key: this.transform.invert(key),\n value\n };\n });\n }\n queryKeys(q, options) {\n return map__default['default'](this.child.queryKeys(q, options), key => {\n return this.transform.invert(key);\n });\n }\n close() {\n return this.child.close();\n }\n}\n\nexports.KeyTransformDatastore = KeyTransformDatastore;\n","'use strict'\n\n/**\n * Takes an (async) iterable and returns one with each item mapped by the passed\n * function.\n *\n * @template I,O\n * @param {AsyncIterable<I>|Iterable<I>} source\n * @param {function(I):O|Promise<O>} func\n * @returns {AsyncIterable<O>}\n */\nconst map = async function * (source, func) {\n for await (const val of source) {\n yield func(val)\n }\n}\n\nmodule.exports = map\n","const rawPipe = (...fns) => {\n let res\n while (fns.length) {\n res = fns.shift()(res)\n }\n return res\n}\n\nconst isIterable = obj => obj && (\n typeof obj[Symbol.asyncIterator] === 'function' ||\n typeof obj[Symbol.iterator] === 'function' ||\n typeof obj.next === 'function' // Probably, right?\n)\n\nconst isDuplex = obj => obj && typeof obj.sink === 'function' && isIterable(obj.source)\n\nconst duplexPipelineFn = duplex => source => {\n duplex.sink(source) // TODO: error on sink side is unhandled rejection - this is the same as pull streams\n return duplex.source\n}\n\nconst pipe = (...fns) => {\n // Duplex at start: wrap in function and return duplex source\n if (isDuplex(fns[0])) {\n const duplex = fns[0]\n fns[0] = () => duplex.source\n // Iterable at start: wrap in function\n } else if (isIterable(fns[0])) {\n const source = fns[0]\n fns[0] = () => source\n }\n\n if (fns.length > 1) {\n // Duplex at end: use duplex sink\n if (isDuplex(fns[fns.length - 1])) {\n fns[fns.length - 1] = fns[fns.length - 1].sink\n }\n }\n\n if (fns.length > 2) {\n // Duplex in the middle, consume source with duplex sink and return duplex source\n for (let i = 1; i < fns.length - 1; i++) {\n if (isDuplex(fns[i])) {\n fns[i] = duplexPipelineFn(fns[i])\n }\n }\n }\n\n return rawPipe(...fns)\n}\n\nmodule.exports = pipe\nmodule.exports.pipe = pipe\nmodule.exports.rawPipe = rawPipe\nmodule.exports.isIterable = isIterable\nmodule.exports.isDuplex = isDuplex\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar shard = require('./shard.js');\nvar base = require('./base.js');\nvar keytransform = require('./keytransform.js');\nvar errors = require('./errors.js');\nvar shardReadme = require('./shard-readme.js');\n\nconst shardKey = new interfaceDatastore.Key(shard.SHARDING_FN);\nconst shardReadmeKey = new interfaceDatastore.Key(shard.README_FN);\nclass ShardingDatastore extends base.BaseDatastore {\n constructor(store, shard) {\n super();\n this.child = new keytransform.KeyTransformDatastore(store, {\n convert: this._convertKey.bind(this),\n invert: this._invertKey.bind(this)\n });\n this.shard = shard;\n }\n async open() {\n await this.child.open();\n this.shard = await ShardingDatastore.create(this.child, this.shard);\n }\n _convertKey(key) {\n const s = key.toString();\n if (s === shardKey.toString() || s === shardReadmeKey.toString()) {\n return key;\n }\n const parent = new interfaceDatastore.Key(this.shard.fun(s));\n return parent.child(key);\n }\n _invertKey(key) {\n const s = key.toString();\n if (s === shardKey.toString() || s === shardReadmeKey.toString()) {\n return key;\n }\n return interfaceDatastore.Key.withNamespaces(key.list().slice(1));\n }\n static async createOrOpen(store, shard) {\n try {\n await ShardingDatastore.create(store, shard);\n } catch (err) {\n if (err && err.message !== 'datastore exists')\n throw err;\n }\n return ShardingDatastore.open(store);\n }\n static async open(store) {\n const shard$1 = await shard.readShardFun('/', store);\n return new ShardingDatastore(store, shard$1);\n }\n static async create(store, shard$1) {\n const hasShard = await store.has(shardKey);\n if (!hasShard && !shard$1) {\n throw errors.dbOpenFailedError(Error('Shard is required when datastore doesn\\'t have a shard key already.'));\n }\n if (!hasShard) {\n const put = typeof store.putRaw === 'function' ? store.putRaw.bind(store) : store.put.bind(store);\n await Promise.all([\n put(shardKey, new TextEncoder().encode(shard$1.toString() + '\\n')),\n put(shardReadmeKey, new TextEncoder().encode(shardReadme))\n ]);\n return shard$1;\n }\n const diskShard = await shard.readShardFun('/', store);\n const a = (diskShard || '').toString();\n const b = shard$1.toString();\n if (a !== b) {\n throw new Error(`specified fun ${ b } does not match repo shard fun ${ a }`);\n }\n return diskShard;\n }\n put(key, val, options) {\n return this.child.put(key, val, options);\n }\n get(key, options) {\n return this.child.get(key, options);\n }\n has(key, options) {\n return this.child.has(key, options);\n }\n delete(key, options) {\n return this.child.delete(key, options);\n }\n async *putMany(source, options = {}) {\n yield* this.child.putMany(source, options);\n }\n async *getMany(source, options = {}) {\n yield* this.child.getMany(source, options);\n }\n async *deleteMany(source, options = {}) {\n yield* this.child.deleteMany(source, options);\n }\n batch() {\n return this.child.batch();\n }\n query(q, options) {\n const tq = {\n offset: q.offset,\n limit: q.limit,\n orders: [],\n filters: [\n e => e.key.toString() !== shardKey.toString(),\n e => e.key.toString() !== shardReadmeKey.toString()\n ]\n };\n const {prefix} = q;\n if (prefix != null) {\n tq.filters.push(e => {\n return this._invertKey(e.key).toString().startsWith(prefix);\n });\n }\n if (q.filters != null) {\n const filters = q.filters.map(f => {\n const filter = ({key, value}) => {\n return f({\n key: this._invertKey(key),\n value\n });\n };\n return filter;\n });\n tq.filters = tq.filters.concat(filters);\n }\n if (q.orders != null) {\n tq.orders = q.orders.map(o => {\n const order = (a, b) => {\n return o({\n key: this._invertKey(a.key),\n value: a.value\n }, {\n key: this._invertKey(b.key),\n value: b.value\n });\n };\n return order;\n });\n }\n return this.child.query(tq, options);\n }\n queryKeys(q, options) {\n const tq = {\n offset: q.offset,\n limit: q.limit,\n orders: [],\n filters: [\n key => key.toString() !== shardKey.toString(),\n key => key.toString() !== shardReadmeKey.toString()\n ]\n };\n const {prefix} = q;\n if (prefix != null) {\n tq.filters.push(key => {\n return this._invertKey(key).toString().startsWith(prefix);\n });\n }\n if (q.filters != null) {\n const filters = q.filters.map(f => {\n const filter = key => {\n return f(this._invertKey(key));\n };\n return filter;\n });\n tq.filters = tq.filters.concat(filters);\n }\n if (q.orders != null) {\n tq.orders = q.orders.map(o => {\n const order = (a, b) => o(this._invertKey(a), this._invertKey(b));\n return order;\n });\n }\n return this.child.queryKeys(tq, options);\n }\n close() {\n return this.child.close();\n }\n}\n\nexports.ShardingDatastore = ShardingDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar filter = require('it-filter');\nvar take = require('it-take');\nvar merge = require('it-merge');\nvar base = require('./base.js');\nvar keytransform = require('./keytransform.js');\nvar errors = require('./errors.js');\nvar utils = require('./utils.js');\nvar key = require('interface-datastore/key');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar take__default = /*#__PURE__*/_interopDefaultLegacy(take);\nvar merge__default = /*#__PURE__*/_interopDefaultLegacy(merge);\n\nclass MountDatastore extends base.BaseDatastore {\n constructor(mounts) {\n super();\n this.mounts = mounts.slice();\n }\n async open() {\n await Promise.all(this.mounts.map(m => m.datastore.open()));\n }\n _lookup(key$1) {\n for (const mount of this.mounts) {\n if (mount.prefix.toString() === key$1.toString() || mount.prefix.isAncestorOf(key$1)) {\n const s = utils.replaceStartWith(key$1.toString(), mount.prefix.toString());\n return {\n datastore: mount.datastore,\n mountpoint: mount.prefix,\n rest: new key.Key(s)\n };\n }\n }\n }\n put(key, value, options) {\n const match = this._lookup(key);\n if (match == null) {\n throw errors.dbWriteFailedError(new Error('No datastore mounted for this key'));\n }\n return match.datastore.put(match.rest, value, options);\n }\n get(key, options) {\n const match = this._lookup(key);\n if (match == null) {\n throw errors.notFoundError(new Error('No datastore mounted for this key'));\n }\n return match.datastore.get(match.rest, options);\n }\n has(key, options) {\n const match = this._lookup(key);\n if (match == null) {\n return Promise.resolve(false);\n }\n return match.datastore.has(match.rest, options);\n }\n delete(key, options) {\n const match = this._lookup(key);\n if (match == null) {\n throw errors.dbDeleteFailedError(new Error('No datastore mounted for this key'));\n }\n return match.datastore.delete(match.rest, options);\n }\n async close() {\n await Promise.all(this.mounts.map(m => {\n return m.datastore.close();\n }));\n }\n batch() {\n const batchMounts = {};\n const lookup = key => {\n const match = this._lookup(key);\n if (match == null) {\n throw new Error('No datastore mounted for this key');\n }\n const m = match.mountpoint.toString();\n if (batchMounts[m] == null) {\n batchMounts[m] = match.datastore.batch();\n }\n return {\n batch: batchMounts[m],\n rest: match.rest\n };\n };\n return {\n put: (key, value) => {\n const match = lookup(key);\n match.batch.put(match.rest, value);\n },\n delete: key => {\n const match = lookup(key);\n match.batch.delete(match.rest);\n },\n commit: async options => {\n await Promise.all(Object.keys(batchMounts).map(p => batchMounts[p].commit(options)));\n }\n };\n }\n query(q, options) {\n const qs = this.mounts.map(m => {\n const ks = new keytransform.KeyTransformDatastore(m.datastore, {\n convert: key => {\n throw new Error('should never be called');\n },\n invert: key => {\n return m.prefix.child(key);\n }\n });\n let prefix;\n if (q.prefix != null) {\n prefix = utils.replaceStartWith(q.prefix, m.prefix.toString());\n }\n return ks.query({\n prefix: prefix,\n filters: q.filters\n }, options);\n });\n let it = merge__default['default'](...qs);\n if (q.filters)\n q.filters.forEach(f => {\n it = filter__default['default'](it, f);\n });\n if (q.orders)\n q.orders.forEach(o => {\n it = utils.sortAll(it, o);\n });\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null)\n it = take__default['default'](it, q.limit);\n return it;\n }\n queryKeys(q, options) {\n const qs = this.mounts.map(m => {\n const ks = new keytransform.KeyTransformDatastore(m.datastore, {\n convert: key => {\n throw new Error('should never be called');\n },\n invert: key => {\n return m.prefix.child(key);\n }\n });\n let prefix;\n if (q.prefix != null) {\n prefix = utils.replaceStartWith(q.prefix, m.prefix.toString());\n }\n return ks.queryKeys({\n prefix: prefix,\n filters: q.filters\n }, options);\n });\n let it = merge__default['default'](...qs);\n if (q.filters)\n q.filters.forEach(f => {\n it = filter__default['default'](it, f);\n });\n if (q.orders)\n q.orders.forEach(o => {\n it = utils.sortAll(it, o);\n });\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null)\n it = take__default['default'](it, q.limit);\n return it;\n }\n}\n\nexports.MountDatastore = MountDatastore;\n","'use strict'\n\nconst pushable = require('it-pushable')\n\n/**\n * Treat one or more iterables as a single iterable.\n *\n * Nb. sources are iterated over in parallel so the\n * order of emitted items is not guaranteed.\n *\n * @template T\n * @param {...AsyncIterable<T>|Iterable<T>} sources\n * @returns {AsyncIterable<T>}\n */\nconst merge = async function * (...sources) {\n const output = pushable()\n\n setTimeout(async () => {\n try {\n await Promise.all(\n sources.map(async (source) => {\n for await (const item of source) {\n output.push(item)\n }\n })\n )\n\n output.end()\n } catch (/** @type {any} */ err) {\n output.end(err)\n }\n }, 0)\n\n yield * output\n}\n\nmodule.exports = merge\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar keytransform = require('./keytransform.js');\n\nclass NamespaceDatastore extends keytransform.KeyTransformDatastore {\n constructor(child, prefix) {\n super(child, {\n convert(key) {\n return prefix.child(key);\n },\n invert(key) {\n if (prefix.toString() === '/') {\n return key;\n }\n if (!prefix.isAncestorOf(key)) {\n throw new Error(`Expected prefix: (${ prefix.toString() }) in key: ${ key.toString() }`);\n }\n return new interfaceDatastore.Key(key.toString().slice(prefix.toString().length), false);\n }\n });\n this.prefix = prefix;\n }\n query(q, options) {\n if (q.prefix && this.prefix.toString() !== '/') {\n return super.query(Object.assign({}, q, { prefix: this.prefix.child(new interfaceDatastore.Key(q.prefix)).toString() }));\n }\n return super.query(q, options);\n }\n queryKeys(q, options) {\n if (q.prefix && this.prefix.toString() !== '/') {\n return super.queryKeys(Object.assign({}, q, { prefix: this.prefix.child(new interfaceDatastore.Key(q.prefix)).toString() }));\n }\n return super.queryKeys(q, options);\n }\n}\n\nexports.NamespaceDatastore = NamespaceDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errcode = require('err-code');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\n\nconst namespace = '/record/';\nfunction encodeBase32(buf) {\n return toString.toString(buf, 'base32');\n}\nfunction keyToTopic(key) {\n if (typeof key === 'string' || key instanceof String) {\n key = fromString.fromString(key.toString());\n }\n const b64url = toString.toString(key, 'base64url');\n return `${ namespace }${ b64url }`;\n}\nfunction topicToKey(topic) {\n if (topic.substring(0, namespace.length) !== namespace) {\n throw errcode__default['default'](new Error('topic received is not from a record'), 'ERR_TOPIC_IS_NOT_FROM_RECORD_NAMESPACE');\n }\n const key = topic.substring(namespace.length);\n return fromString.fromString(key, 'base64url');\n}\n\nexports.encodeBase32 = encodeBase32;\nexports.keyToTopic = keyToTopic;\nexports.topicToKey = topicToKey;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar libp2pRecord = require('libp2p-record');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar toString = require('uint8arrays/to-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:ipns:offline-datastore'), { error: debug__default['default']('ipfs:ipns:offline-datastore:error') });\nclass OfflineDatastore {\n constructor(repo) {\n this._repo = repo;\n this.stores = [];\n }\n async put(key, value) {\n if (!(key instanceof Uint8Array)) {\n throw errCode__default['default'](new Error('Offline datastore key must be a Uint8Array'), 'ERR_INVALID_KEY');\n }\n if (!(value instanceof Uint8Array)) {\n throw errCode__default['default'](new Error('Offline datastore value must be a Uint8Array'), 'ERR_INVALID_VALUE');\n }\n let routingKey;\n try {\n routingKey = this._routingKey(key);\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](new Error('Not possible to generate the routing key'), 'ERR_GENERATING_ROUTING_KEY');\n }\n const record = new libp2pRecord.Record(key, value);\n return this._repo.datastore.put(routingKey, record.serialize());\n }\n async get(key) {\n if (!(key instanceof Uint8Array)) {\n throw errCode__default['default'](new Error('Offline datastore key must be a Uint8Array'), 'ERR_INVALID_KEY');\n }\n let routingKey;\n try {\n routingKey = this._routingKey(key);\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](new Error('Not possible to generate the routing key'), 'ERR_GENERATING_ROUTING_KEY');\n }\n const res = await this._repo.datastore.get(routingKey);\n let record;\n try {\n record = libp2pRecord.Record.deserialize(res);\n } catch (err) {\n log.error(err);\n throw err;\n }\n return record.value;\n }\n _routingKey(key$1) {\n return new key.Key('/' + toString.toString(key$1, 'base32upper'), false);\n }\n}\n\nexports.OfflineDatastore = OfflineDatastore;\n","'use strict'\n\nmodule.exports = {\n Record: require('./record'),\n validator: require('./validator'),\n selection: require('./selection')\n}\n","'use strict'\n\nconst {\n Record: PBRecord\n} = require('./record')\nconst utils = require('../utils')\n\n/**\n * @typedef {{ key: Uint8Array, value: Uint8Array, timeReceived: string }} ProtobufRecord\n */\n\nclass Record {\n /**\n * @param {Uint8Array} [key]\n * @param {Uint8Array} [value]\n * @param {Date} [timeReceived]\n */\n constructor (key, value, timeReceived) {\n if (!(key instanceof Uint8Array)) {\n throw new Error('key must be a Uint8Array')\n }\n\n if (!(value instanceof Uint8Array)) {\n throw new Error('value must be a Uint8Array')\n }\n\n this.key = key\n this.value = value\n this.timeReceived = timeReceived\n }\n\n serialize () {\n return PBRecord.encode(this.prepareSerialize()).finish()\n }\n\n /**\n * Return the object format ready to be given to the protobuf library.\n */\n prepareSerialize () {\n return {\n key: this.key,\n value: this.value,\n timeReceived: this.timeReceived && utils.toRFC3339(this.timeReceived)\n }\n }\n\n /**\n * Decode a protobuf encoded record.\n *\n * @param {Uint8Array} raw\n */\n static deserialize (raw) {\n const message = PBRecord.decode(raw)\n return Record.fromDeserialized(PBRecord.toObject(message, {\n defaults: false,\n arrays: true,\n longs: Number,\n objects: false\n }))\n }\n\n /**\n * Create a record from the raw object returned from the protobuf library.\n *\n * @param {{ [k: string]: any }} obj\n */\n static fromDeserialized (obj) {\n let recvtime\n if (obj.timeReceived) {\n recvtime = utils.parseRFC3339(obj.timeReceived)\n }\n\n const rec = new Record(\n obj.key, obj.value, recvtime\n )\n\n return rec\n }\n}\n\nmodule.exports = Record\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-record\"] || ($protobuf.roots[\"libp2p-record\"] = {});\n\n$root.Record = (function() {\n\n /**\n * Properties of a Record.\n * @exports IRecord\n * @interface IRecord\n * @property {Uint8Array|null} [key] Record key\n * @property {Uint8Array|null} [value] Record value\n * @property {string|null} [timeReceived] Record timeReceived\n */\n\n /**\n * Constructs a new Record.\n * @exports Record\n * @classdesc Represents a Record.\n * @implements IRecord\n * @constructor\n * @param {IRecord=} [p] Properties to set\n */\n function Record(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Record key.\n * @member {Uint8Array} key\n * @memberof Record\n * @instance\n */\n Record.prototype.key = $util.newBuffer([]);\n\n /**\n * Record value.\n * @member {Uint8Array} value\n * @memberof Record\n * @instance\n */\n Record.prototype.value = $util.newBuffer([]);\n\n /**\n * Record timeReceived.\n * @member {string} timeReceived\n * @memberof Record\n * @instance\n */\n Record.prototype.timeReceived = \"\";\n\n /**\n * Encodes the specified Record message. Does not implicitly {@link Record.verify|verify} messages.\n * @function encode\n * @memberof Record\n * @static\n * @param {IRecord} m Record message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Record.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(10).bytes(m.key);\n if (m.value != null && Object.hasOwnProperty.call(m, \"value\"))\n w.uint32(18).bytes(m.value);\n if (m.timeReceived != null && Object.hasOwnProperty.call(m, \"timeReceived\"))\n w.uint32(42).string(m.timeReceived);\n return w;\n };\n\n /**\n * Decodes a Record message from the specified reader or buffer.\n * @function decode\n * @memberof Record\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Record} Record\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Record.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Record();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.key = r.bytes();\n break;\n case 2:\n m.value = r.bytes();\n break;\n case 5:\n m.timeReceived = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Record message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Record\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Record} Record\n */\n Record.fromObject = function fromObject(d) {\n if (d instanceof $root.Record)\n return d;\n var m = new $root.Record();\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n if (d.value != null) {\n if (typeof d.value === \"string\")\n $util.base64.decode(d.value, m.value = $util.newBuffer($util.base64.length(d.value)), 0);\n else if (d.value.length)\n m.value = d.value;\n }\n if (d.timeReceived != null) {\n m.timeReceived = String(d.timeReceived);\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Record message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Record\n * @static\n * @param {Record} m Record\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Record.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.key = \"\";\n else {\n d.key = [];\n if (o.bytes !== Array)\n d.key = $util.newBuffer(d.key);\n }\n if (o.bytes === String)\n d.value = \"\";\n else {\n d.value = [];\n if (o.bytes !== Array)\n d.value = $util.newBuffer(d.value);\n }\n d.timeReceived = \"\";\n }\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n }\n if (m.value != null && m.hasOwnProperty(\"value\")) {\n d.value = o.bytes === String ? $util.base64.encode(m.value, 0, m.value.length) : o.bytes === Array ? Array.prototype.slice.call(m.value) : m.value;\n }\n if (m.timeReceived != null && m.hasOwnProperty(\"timeReceived\")) {\n d.timeReceived = m.timeReceived;\n }\n return d;\n };\n\n /**\n * Converts this Record to JSON.\n * @function toJSON\n * @memberof Record\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Record.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Record;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\n/**\n * Convert a JavaScript date into an `RFC3339Nano` formatted\n * string.\n *\n * @param {Date} time\n */\nmodule.exports.toRFC3339 = (time) => {\n const year = time.getUTCFullYear()\n const month = String(time.getUTCMonth() + 1).padStart(2, '0')\n const day = String(time.getUTCDate()).padStart(2, '0')\n const hour = String(time.getUTCHours()).padStart(2, '0')\n const minute = String(time.getUTCMinutes()).padStart(2, '0')\n const seconds = String(time.getUTCSeconds()).padStart(2, '0')\n const milliseconds = time.getUTCMilliseconds()\n const nanoseconds = milliseconds * 1000 * 1000\n\n return `${year}-${month}-${day}T${hour}:${minute}:${seconds}.${nanoseconds}Z`\n}\n\n/**\n * Parses a date string formatted as `RFC3339Nano` into a\n * JavaScript Date object.\n *\n * @param {string} time\n */\nmodule.exports.parseRFC3339 = (time) => {\n const rfc3339Matcher = new RegExp(\n // 2006-01-02T\n '(\\\\d{4})-(\\\\d{2})-(\\\\d{2})T' +\n // 15:04:05\n '(\\\\d{2}):(\\\\d{2}):(\\\\d{2})' +\n // .999999999Z\n '\\\\.(\\\\d+)Z'\n )\n const m = String(time).trim().match(rfc3339Matcher)\n\n if (!m) {\n throw new Error('Invalid format')\n }\n\n const year = parseInt(m[1], 10)\n const month = parseInt(m[2], 10) - 1\n const date = parseInt(m[3], 10)\n const hour = parseInt(m[4], 10)\n const minute = parseInt(m[5], 10)\n const second = parseInt(m[6], 10)\n const millisecond = parseInt(m[7].slice(0, -6), 10)\n\n return new Date(Date.UTC(year, month, date, hour, minute, second, millisecond))\n}\n","'use strict'\n\nconst errcode = require('err-code')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\n/**\n * @typedef {import('./record')} Record\n */\n\n/**\n * Checks a record and ensures it is still valid.\n * It runs the needed validators.\n * If verification fails the returned Promise will reject with the error.\n *\n * @param {import('libp2p-interfaces/src/types').DhtValidators} validators\n * @param {Record} record\n */\nconst verifyRecord = (validators, record) => {\n const key = record.key\n const keyString = uint8ArrayToString(key)\n const parts = keyString.split('/')\n\n if (parts.length < 3) {\n // No validator available\n return\n }\n\n const validator = validators[parts[1].toString()]\n\n if (!validator) {\n const errMsg = 'Invalid record keytype'\n\n throw errcode(new Error(errMsg), 'ERR_INVALID_RECORD_KEY_TYPE')\n }\n\n return validator.func(key, record.value)\n}\n\nmodule.exports = {\n verifyRecord: verifyRecord,\n validators: require('./validators')\n}\n","'use strict'\n\nmodule.exports = {\n pk: require('./public-key')\n}\n","'use strict'\n\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst errcode = require('err-code')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\n/**\n * Validator for public key records.\n * Verifies that the passed in record value is the PublicKey\n * that matches the passed in key.\n * If validation fails the returned Promise will reject with the error.\n *\n * @param {Uint8Array} key - A valid key is of the form `'/pk/<keymultihash>'`\n * @param {Uint8Array} publicKey - The public key to validate against (protobuf encoded).\n */\nconst validatePublicKeyRecord = async (key, publicKey) => {\n if (!(key instanceof Uint8Array)) {\n throw errcode(new Error('\"key\" must be a Uint8Array'), 'ERR_INVALID_RECORD_KEY_NOT_BUFFER')\n }\n\n if (key.byteLength < 5) {\n throw errcode(new Error('invalid public key record'), 'ERR_INVALID_RECORD_KEY_TOO_SHORT')\n }\n\n const prefix = uint8ArrayToString(key.subarray(0, 4))\n\n if (prefix !== '/pk/') {\n throw errcode(new Error('key was not prefixed with /pk/'), 'ERR_INVALID_RECORD_KEY_BAD_PREFIX')\n }\n\n const keyhash = key.slice(4)\n\n const publicKeyHash = await sha256.digest(publicKey)\n\n if (!uint8ArrayEquals(keyhash, publicKeyHash.bytes)) {\n throw errcode(new Error('public key does not match passed in key'), 'ERR_INVALID_RECORD_HASH_MISMATCH')\n }\n}\n\nmodule.exports = {\n func: validatePublicKeyRecord,\n sign: false\n}\n","'use strict'\n\nconst errcode = require('err-code')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\n/**\n * Select the best record out of the given records.\n *\n * @param {import('libp2p-interfaces/src/types').DhtSelectors} selectors\n * @param {Uint8Array} k\n * @param {Array<Uint8Array>} records\n */\nconst bestRecord = (selectors, k, records) => {\n if (records.length === 0) {\n const errMsg = 'No records given'\n\n throw errcode(new Error(errMsg), 'ERR_NO_RECORDS_RECEIVED')\n }\n\n const kStr = uint8ArrayToString(k)\n const parts = kStr.split('/')\n\n if (parts.length < 3) {\n const errMsg = 'Record key does not have a selector function'\n\n throw errcode(new Error(errMsg), 'ERR_NO_SELECTOR_FUNCTION_FOR_RECORD_KEY')\n }\n\n const selector = selectors[parts[1].toString()]\n\n if (!selector) {\n const errMsg = `Unrecognized key prefix: ${parts[1]}`\n\n throw errcode(new Error(errMsg), 'ERR_UNRECOGNIZED_KEY_PREFIX')\n }\n\n if (records.length === 1) {\n return 0\n }\n\n return selector(k, records)\n}\n\nmodule.exports = {\n bestRecord: bestRecord,\n selectors: require('./selectors')\n}\n","'use strict'\n\nmodule.exports = {\n pk: require('./public-key')\n}\n","'use strict'\n\n/**\n * Best record selector, for public key records.\n * Simply returns the first record, as all valid public key\n * records are equal.\n *\n * @param {Uint8Array} k\n * @param {Array<Uint8Array>} records\n */\nconst publicKeySelector = (k, records) => {\n return 0\n}\n\nmodule.exports = publicKeySelector\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar publish = require('./publish.js');\nvar resolve = require('./resolve.js');\nvar index = require('./pubsub/index.js');\n\nclass NameAPI {\n constructor({dns, ipns, repo, codecs, peerId, isOnline, keychain, options}) {\n this.publish = publish.createPublish({\n ipns,\n repo,\n codecs,\n peerId,\n isOnline,\n keychain\n });\n this.resolve = resolve.createResolve({\n dns,\n ipns,\n peerId,\n isOnline,\n options\n });\n this.pubsub = new index.PubSubAPI({\n ipns,\n options\n });\n }\n}\n\nexports.NameAPI = NameAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar parseDuration = require('parse-duration');\nvar crypto = require('libp2p-crypto');\nvar errCode = require('err-code');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar utils$1 = require('./utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar parseDuration__default = /*#__PURE__*/_interopDefaultLegacy(parseDuration);\nvar crypto__default = /*#__PURE__*/_interopDefaultLegacy(crypto);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst log = Object.assign(debug__default['default']('ipfs:name:publish'), { error: debug__default['default']('ipfs:name:publish:error') });\nfunction createPublish({ipns, repo, codecs, peerId, isOnline, keychain}) {\n const lookupKey = async keyName => {\n if (keyName === 'self') {\n return peerId.privKey;\n }\n try {\n const pem = await keychain.exportKey(keyName, 'temp');\n const privateKey = await crypto__default['default'].keys.import(pem, 'temp');\n return privateKey;\n } catch (err) {\n log.error(err);\n throw errCode__default['default'](err, 'ERR_CANNOT_GET_KEY');\n }\n };\n async function publish(value, options = {}) {\n const resolve = !(options.resolve === false);\n const lifetime = options.lifetime || '24h';\n const key = options.key || 'self';\n if (!isOnline()) {\n throw errCode__default['default'](new Error(utils.OFFLINE_ERROR), 'OFFLINE_ERROR');\n }\n try {\n value = utils.normalizePath(value);\n } catch (err) {\n log.error(err);\n throw err;\n }\n let pubLifetime = 0;\n try {\n pubLifetime = parseDuration__default['default'](lifetime) || 0;\n pubLifetime = parseFloat(pubLifetime.toFixed(6));\n } catch (err) {\n log.error(err);\n throw err;\n }\n const results = await Promise.all([\n lookupKey(key),\n resolve ? utils$1.resolvePath({\n ipns,\n repo,\n codecs\n }, value) : Promise.resolve()\n ]);\n const bytes = fromString.fromString(value);\n const result = await ipns.publish(results[0], bytes, pubLifetime);\n return {\n name: result.name,\n value: toString.toString(result.value)\n };\n }\n return withTimeoutOption.withTimeoutOption(publish);\n}\n\nexports.createPublish = createPublish;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar isIpfs = require('is-ipfs');\nvar toCidAndPath = require('ipfs-core-utils/to-cid-and-path');\nvar drain = require('it-drain');\nvar utils = require('../../utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\n\nasync function resolvePath({ipns, repo, codecs}, name, options) {\n if (isIpfs__default['default'].ipnsPath(name)) {\n return ipns.resolve(name);\n }\n const {cid, path} = toCidAndPath.toCidAndPath(name);\n await drain__default['default'](utils.resolve(cid, path || '', codecs, repo, options));\n}\n\nexports.resolvePath = resolvePath;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar mergeOpts = require('merge-options');\nvar cid = require('multiformats/cid');\nvar PeerId = require('peer-id');\nvar isDomain = require('is-domain-name');\nvar toString = require('uint8arrays/to-string');\nvar utils = require('../../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar isDomain__default = /*#__PURE__*/_interopDefaultLegacy(isDomain);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = Object.assign(debug__default['default']('ipfs:name:resolve'), { error: debug__default['default']('ipfs:name:resolve:error') });\nconst appendRemainder = (result, remainder) => remainder.length > 0 ? result + '/' + remainder.join('/') : result;\nfunction createResolve({\n dns,\n ipns,\n peerId,\n isOnline,\n options: {offline}\n}) {\n async function* resolve(name, options = {}) {\n options = mergeOptions({\n nocache: false,\n recursive: true\n }, options);\n if (offline && options && options.nocache) {\n throw errCode__default['default'](new Error('cannot specify both offline and nocache'), 'ERR_NOCACHE_AND_OFFLINE');\n }\n if (!name) {\n name = peerId.toB58String();\n }\n if (!name.startsWith('/ipns/')) {\n name = `/ipns/${ name }`;\n }\n const [namespace, hash, ...remainder] = name.slice(1).split('/');\n try {\n if (hash.substring(0, 1) === '1') {\n PeerId__default['default'].parse(hash);\n } else {\n cid.CID.parse(hash);\n }\n } catch (err) {\n if (isDomain__default['default'](hash)) {\n yield appendRemainder(await dns(hash, options), remainder);\n return;\n }\n log.error(err);\n throw errCode__default['default'](new Error('Invalid IPNS name'), 'ERR_IPNS_INVALID_NAME');\n }\n if (!isOnline() && !offline) {\n throw errCode__default['default'](new Error(utils.OFFLINE_ERROR), 'OFFLINE_ERROR');\n }\n const value = await ipns.resolve(`/${ namespace }/${ hash }`, options);\n yield appendRemainder(value instanceof Uint8Array ? toString.toString(value) : value, remainder);\n }\n return withTimeoutOption.withTimeoutOption(resolve);\n}\n\nexports.createResolve = createResolve;\n","'use strict'\n\n// Adapted from RFC 2181 (See section 11)\n//\n// The RFC defines a Domain Name to be at most 255 chars including seperators\n// between labels.\n// Subdomains are labels plus a seperator. A label is a string starting and\n// ending with an alphanum, with dashes allowed in the middle. It is between 1 and 63 chars.\n//\n// We make some assumptions below that go beyond the RFC. We assume the TLD\n// to be at least 2 chars. The regex also allows domains longer than 255 chars,\n// but allows at most 127 subdomains, as assuming a lower-bound of one char per\n// subdomain will yield 252, and adding a TLD of 2 chars sums to 254.\n/*\n(?: // Group 1: This is for subdomain, which is composed of a label and a seperator (length = [1, 63] + 1)\n [a-z0-9]\n (?:\n [a-z0-9\\-]{0,61} // Limited to 61 chars as we have at least two chars if we reach this group (61 + 2 = 63 which is the limit)\n [a-z0-9]\n )?\n \\. // Label seperator\n){0,126} // If we assume the lower-bound of 1 char labels, we can at most have 126 groups before approaching the total limit of 255 chars\n(?: // Group 2: Assume that the TLD is at least 2 chars (for sanity)\n [a-z0-9]\n [a-z0-9\\-]{0,61}\n [a-z0-9]\n)\n\\.? // Some consider a trailing dot to be considered valid as it signifies the root of the domain tree\n */\nvar domainNameRegex = /^(?:[a-z0-9](?:[a-z0-9\\-]{0,61}[a-z0-9])?\\.){0,126}(?:[a-z0-9](?:[a-z0-9\\-]{0,61}[a-z0-9]))\\.?$/i\n\n/**\n * Test whether a string is a valid domain name, optionally checking for a root dot as well\n * @param {String} domainName\n * @param {Boolean} rootDot Check for a root dot eg. 'example.com.'. Defaults to false\n * @return {Boolean}\n */\nmodule.exports = function isDomainName (domainName, rootDot) {\n if (rootDot == null) rootDot = false\n\n if (domainName.length < 2) return false\n if (domainName.length > 255) return false\n\n var lastChar = domainName[domainName.length - 1]\n if (rootDot) {\n if (lastChar !== '.') return false\n } else {\n if (lastChar === '.') return false\n }\n\n return domainNameRegex.test(domainName)\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cancel = require('./cancel.js');\nvar state = require('./state.js');\nvar subs = require('./subs.js');\n\nclass PubSubAPI {\n constructor({ipns, options}) {\n this.cancel = cancel.createCancel({\n ipns,\n options\n });\n this.state = state.createState({\n ipns,\n options\n });\n this.subs = subs.createSubs({\n ipns,\n options\n });\n }\n}\n\nexports.PubSubAPI = PubSubAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createCancel({ipns, options}) {\n const experimental = options.EXPERIMENTAL;\n async function cancel(name, options = {}) {\n const pubsub = utils.getPubsubRouting(ipns, experimental);\n return pubsub.cancel(name, options);\n }\n return withTimeoutOption.withTimeoutOption(cancel);\n}\n\nexports.createCancel = createCancel;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar pubsubDatastore = require('../../../ipns/routing/pubsub-datastore.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction getPubsubRouting(ipns, options) {\n if (!ipns || !(options && options.ipnsPubsub)) {\n throw errCode__default['default'](new Error('IPNS pubsub subsystem is not enabled'), 'ERR_IPNS_PUBSUB_NOT_ENABLED');\n }\n if (ipns.routing instanceof pubsubDatastore.IpnsPubsubDatastore) {\n return ipns.routing;\n }\n const pubsub = (ipns.routing.stores || []).find(s => s instanceof pubsubDatastore.IpnsPubsubDatastore);\n if (!pubsub) {\n throw errCode__default['default'](new Error('IPNS pubsub datastore not found'), 'ERR_PUBSUB_DATASTORE_NOT_FOUND');\n }\n return pubsub;\n}\n\nexports.getPubsubRouting = getPubsubRouting;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createState({ipns, options}) {\n const experimental = options.EXPERIMENTAL;\n async function state(_options = {}) {\n try {\n return { enabled: Boolean(utils.getPubsubRouting(ipns, experimental)) };\n } catch (err) {\n return { enabled: false };\n }\n }\n return withTimeoutOption.withTimeoutOption(state);\n}\n\nexports.createState = createState;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createSubs({ipns, options}) {\n const experimental = options.EXPERIMENTAL;\n async function subs(options = {}) {\n const pubsub = utils.getPubsubRouting(ipns, experimental);\n return pubsub.getSubscriptions(options);\n }\n return withTimeoutOption.withTimeoutOption(subs);\n}\n\nexports.createSubs = createSubs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar Errors = require('datastore-core/errors');\nvar toCidAndPath = require('ipfs-core-utils/to-cid-and-path');\nvar cid = require('multiformats/cid');\nvar TimeoutController = require('timeout-abort-controller');\nvar anySignal = require('any-signal');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar TimeoutController__default = /*#__PURE__*/_interopDefaultLegacy(TimeoutController);\n\nconst ERR_NOT_FOUND = Errors.notFoundError().code;\nconst Format = {\n default: '<dst>',\n edges: '<src> -> <dst>'\n};\nfunction createRefs({repo, codecs, resolve, preload}) {\n async function* refs(ipfsPath, options = {}) {\n if (options.maxDepth === 0) {\n return;\n }\n if (options.edges && options.format && options.format !== Format.default) {\n throw new Error('Cannot set edges to true and also specify format');\n }\n options.format = options.edges ? Format.edges : options.format;\n if (typeof options.maxDepth !== 'number') {\n options.maxDepth = options.recursive ? Infinity : 1;\n }\n if (options.timeout) {\n const controller = new TimeoutController__default['default'](options.timeout);\n options.signal = anySignal.anySignal([\n options.signal,\n controller.signal\n ]);\n }\n const rawPaths = Array.isArray(ipfsPath) ? ipfsPath : [ipfsPath];\n const paths = rawPaths.map(p => getFullPath(preload, p, options));\n for (const path of paths) {\n try {\n yield* refsStream(resolve, repo, codecs, path, options);\n } catch (err) {\n yield {\n ref: '',\n err: err.message\n };\n }\n }\n }\n return refs;\n}\nfunction getFullPath(preload, ipfsPath, options) {\n const {cid, path} = toCidAndPath.toCidAndPath(ipfsPath);\n if (options.preload !== false) {\n preload(cid);\n }\n return `/ipfs/${ cid }${ path || '' }`;\n}\nasync function* refsStream(resolve, repo, codecs, path, options) {\n const resPath = await resolve(path, options);\n const {cid} = toCidAndPath.toCidAndPath(resPath);\n const maxDepth = options.maxDepth != null ? options.maxDepth : Infinity;\n const unique = options.unique || false;\n for await (const obj of objectStream(repo, codecs, cid, maxDepth, unique, options)) {\n if (!obj.parent) {\n continue;\n }\n if (obj.isDuplicate) {\n continue;\n }\n yield { ref: formatLink(obj.parent.cid, obj.node.cid, obj.node.name, options.format) };\n }\n}\nfunction formatLink(srcCid, dstCid, linkName = '', format = Format.default) {\n let out = format.replace(/<src>/g, srcCid.toString());\n out = out.replace(/<dst>/g, dstCid.toString());\n out = out.replace(/<linkname>/g, linkName);\n return out;\n}\nasync function* objectStream(repo, codecs, rootCid, maxDepth, uniqueOnly, options) {\n const seen = new Set();\n async function* traverseLevel(parent, depth) {\n const nextLevelDepth = depth + 1;\n if (nextLevelDepth > maxDepth) {\n return;\n }\n try {\n for await (const link of getLinks(repo, codecs, parent.cid, options)) {\n yield {\n parent: parent,\n node: link,\n isDuplicate: uniqueOnly && seen.has(link.cid.toString())\n };\n if (uniqueOnly) {\n seen.add(link.cid.toString());\n }\n yield* traverseLevel(link, nextLevelDepth);\n }\n } catch (err) {\n if (err.code === ERR_NOT_FOUND) {\n err.message = `Could not find object with CID: ${ parent.cid }`;\n }\n throw err;\n }\n }\n yield* traverseLevel({ cid: rootCid }, 0);\n}\nasync function* getLinks(repo, codecs, cid, options) {\n const block = await repo.blocks.get(cid, options);\n const codec = await codecs.getCodec(cid.code);\n const value = codec.decode(block);\n const isDagPb = cid.code === dagPB__namespace.code;\n const base = [];\n for (const [name, cid] of links(value, base)) {\n if (isDagPb) {\n const match = name.match(/^Links\\/(\\d+)\\/Hash$/);\n if (match) {\n const index = Number(match[1]);\n if (index < value.Links.length) {\n yield {\n name: value.Links[index].Name,\n cid\n };\n continue;\n }\n }\n }\n yield {\n name,\n cid\n };\n }\n}\nconst links = function* (source, base) {\n if (source == null) {\n return;\n }\n if (source instanceof Uint8Array) {\n return;\n }\n for (const [key, value] of Object.entries(source)) {\n const path = [\n ...base,\n key\n ];\n if (value != null && typeof value === 'object') {\n if (Array.isArray(value)) {\n for (const [index, element] of value.entries()) {\n const elementPath = [\n ...path,\n index\n ];\n const cid$1 = cid.CID.asCID(element);\n if (cid$1) {\n yield [\n elementPath.join('/'),\n cid$1\n ];\n } else if (typeof element === 'object') {\n yield* links(element, elementPath);\n }\n }\n } else {\n const cid$1 = cid.CID.asCID(value);\n if (cid$1) {\n yield [\n path.join('/'),\n cid$1\n ];\n } else {\n yield* links(value, path);\n }\n }\n }\n }\n return [];\n};\n\nexports.Format = Format;\nexports.createRefs = createRefs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createLocal({repo}) {\n async function* refsLocal(options = {}) {\n for await (const cid of repo.blocks.queryKeys({}, { signal: options.signal })) {\n yield { ref: cid.toString() };\n }\n }\n return withTimeoutOption.withTimeoutOption(refsLocal);\n}\n\nexports.createLocal = createLocal;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar wantlist = require('./wantlist.js');\nvar wantlistForPeer = require('./wantlist-for-peer.js');\nvar unwant = require('./unwant.js');\nvar stat = require('./stat.js');\n\nclass BitswapAPI {\n constructor({network}) {\n this.wantlist = wantlist.createWantlist({ network });\n this.wantlistForPeer = wantlistForPeer.createWantlistForPeer({ network });\n this.unwant = unwant.createUnwant({ network });\n this.stat = stat.createStat({ network });\n }\n}\n\nexports.BitswapAPI = BitswapAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createWantlist({network}) {\n async function wantlist(options = {}) {\n const {bitswap} = await network.use(options);\n const list = bitswap.getWantlist();\n return Array.from(list).map(e => e[1].cid);\n }\n return withTimeoutOption.withTimeoutOption(wantlist);\n}\n\nexports.createWantlist = createWantlist;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\n\nfunction createWantlistForPeer({network}) {\n async function wantlistForPeer(peerId, options = {}) {\n const {bitswap} = await network.use(options);\n const list = bitswap.wantlistForPeer(PeerId__default['default'].createFromB58String(peerId));\n return Array.from(list).map(e => e[1].cid);\n }\n return withTimeoutOption.withTimeoutOption(wantlistForPeer);\n}\n\nexports.createWantlistForPeer = createWantlistForPeer;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createUnwant({network}) {\n async function unwant(cids, options = {}) {\n const {bitswap} = await network.use(options);\n if (!Array.isArray(cids)) {\n cids = [cids];\n }\n return bitswap.unwant(cids);\n }\n return withTimeoutOption.withTimeoutOption(unwant);\n}\n\nexports.createUnwant = createUnwant;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createStat({network}) {\n async function stat(options = {}) {\n const bitswap = (await network.use(options)).bitswap;\n const snapshot = bitswap.stat().snapshot;\n return {\n provideBufLen: parseInt(snapshot.providesBufferLength.toString()),\n blocksReceived: BigInt(snapshot.blocksReceived.toString()),\n wantlist: Array.from(bitswap.getWantlist()).map(e => e[1].cid),\n peers: bitswap.peers().map(id => id.toB58String()),\n dupBlksReceived: BigInt(snapshot.dupBlksReceived.toString()),\n dupDataReceived: BigInt(snapshot.dupDataReceived.toString()),\n dataReceived: BigInt(snapshot.dataReceived.toString()),\n blocksSent: BigInt(snapshot.blocksSent.toString()),\n dataSent: BigInt(snapshot.dataSent.toString())\n };\n }\n return withTimeoutOption.withTimeoutOption(stat);\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar add = require('./add.js');\nvar clear = require('./clear.js');\nvar list = require('./list.js');\nvar reset = require('./reset.js');\nvar rm = require('./rm.js');\n\nclass BootstrapAPI {\n constructor({repo}) {\n this.add = add.createAdd({ repo });\n this.list = list.createList({ repo });\n this.rm = rm.createRm({ repo });\n this.clear = clear.createClear({ repo });\n this.reset = reset.createReset({ repo });\n }\n}\n\nexports.BootstrapAPI = BootstrapAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createAdd({repo}) {\n async function add(multiaddr, options = {}) {\n if (!utils.isValidMultiaddr(multiaddr)) {\n throw new Error(`${ multiaddr } is not a valid Multiaddr`);\n }\n const config = await repo.config.getAll(options);\n const boostrappers = config.Bootstrap || [];\n boostrappers.push(multiaddr.toString());\n config.Bootstrap = Array.from(new Set(boostrappers)).sort((a, b) => a.localeCompare(b));\n await repo.config.replace(config);\n return { Peers: [multiaddr] };\n }\n return withTimeoutOption.withTimeoutOption(add);\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mafmt = require('mafmt');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mafmt__default = /*#__PURE__*/_interopDefaultLegacy(mafmt);\n\nfunction isValidMultiaddr(ma) {\n try {\n return mafmt__default['default'].IPFS.matches(ma);\n } catch (err) {\n return false;\n }\n}\n\nexports.isValidMultiaddr = isValidMultiaddr;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar multiaddr = require('multiaddr');\n\nfunction createClear({repo}) {\n async function clear(options = {}) {\n const config = await repo.config.getAll(options);\n const removed = config.Bootstrap || [];\n config.Bootstrap = [];\n await repo.config.replace(config);\n return { Peers: removed.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return withTimeoutOption.withTimeoutOption(clear);\n}\n\nexports.createClear = createClear;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar multiaddr = require('multiaddr');\n\nfunction createList({repo}) {\n async function list(options = {}) {\n const peers = await repo.config.get('Bootstrap', options);\n return { Peers: (peers || []).map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return withTimeoutOption.withTimeoutOption(list);\n}\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar getDefaultConfig = require('ipfs-core-config/config');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar multiaddr = require('multiaddr');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar getDefaultConfig__default = /*#__PURE__*/_interopDefaultLegacy(getDefaultConfig);\n\nfunction createReset({repo}) {\n async function reset(options = {}) {\n const config = await repo.config.getAll(options);\n config.Bootstrap = getDefaultConfig__default['default']().Bootstrap;\n await repo.config.replace(config);\n return { Peers: getDefaultConfig__default['default']().Bootstrap.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return withTimeoutOption.withTimeoutOption(reset);\n}\n\nexports.createReset = createReset;\n","'use strict';\n\nvar config_browser = () => ({\n Addresses: {\n Swarm: [],\n Announce: [],\n NoAnnounce: [],\n API: '',\n Gateway: '',\n RPC: '',\n Delegates: [\n '/dns4/node0.delegate.ipfs.io/tcp/443/https',\n '/dns4/node1.delegate.ipfs.io/tcp/443/https',\n '/dns4/node2.delegate.ipfs.io/tcp/443/https',\n '/dns4/node3.delegate.ipfs.io/tcp/443/https'\n ]\n },\n Discovery: {\n MDNS: {\n Enabled: false,\n Interval: 10\n },\n webRTCStar: { Enabled: true }\n },\n Bootstrap: [\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmNnooDu7bfjPFoTZYxMNLWUQJyrVwtbZg5gBMjTezGAJN',\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmbLHAnMoJPWSCR5Zhtx6BHJX9KiKNN6tpvbUcqanj75Nb',\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmZa1sAxajnQjVM8WjWXoMbmPd7NsWhfKsPkErzpm9wGkp',\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmQCU2EcMqAqQPR2i9bChDtGNJchTbq5TbXJJ16u19uLTa',\n '/dnsaddr/bootstrap.libp2p.io/p2p/QmcZf59bWwK5XFi76CZX8cbJ4BhTzzA3gU1ZjYZcYW3dwt',\n '/dns4/node0.preload.ipfs.io/tcp/443/wss/p2p/QmZMxNdpMkewiVZLMRxaNxUeZpDUb34pWjZ1kZvsd16Zic',\n '/dns4/node1.preload.ipfs.io/tcp/443/wss/p2p/Qmbut9Ywz9YEDrz8ySBSgWyJk41Uvm2QJPhwDJzJyGFsD6',\n '/dns4/node2.preload.ipfs.io/tcp/443/wss/p2p/QmV7gnbW5VTcJ3oyM2Xk1rdFBJ3kTkvxc87UFGsun29STS',\n '/dns4/node3.preload.ipfs.io/tcp/443/wss/p2p/QmY7JB6MQXhxHvq7dBDh4HpbH29v4yE9JRadAVpndvzySN'\n ],\n Pubsub: { Enabled: true },\n Swarm: {\n ConnMgr: {\n LowWater: 200,\n HighWater: 500\n },\n DisableNatPortMap: true\n },\n Routing: { Type: 'none' }\n});\n\nmodule.exports = config_browser;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createRm({repo}) {\n async function rm(multiaddr, options = {}) {\n if (!utils.isValidMultiaddr(multiaddr)) {\n throw new Error(`${ multiaddr } is not a valid Multiaddr`);\n }\n const config = await repo.config.getAll(options);\n config.Bootstrap = (config.Bootstrap || []).filter(ma => ma.toString() !== multiaddr.toString());\n await repo.config.replace(config);\n return { Peers: [multiaddr] };\n }\n return withTimeoutOption.withTimeoutOption(rm);\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar get = require('./get.js');\nvar put = require('./put.js');\nvar rm = require('./rm.js');\nvar stat = require('./stat.js');\n\nclass BlockAPI {\n constructor({codecs, hashers, preload, repo}) {\n this.get = get.createGet({\n preload,\n repo\n });\n this.put = put.createPut({\n codecs,\n hashers,\n preload,\n repo\n });\n this.rm = rm.createRm({ repo });\n this.stat = stat.createStat({\n preload,\n repo\n });\n }\n}\n\nexports.BlockAPI = BlockAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createGet({preload, repo}) {\n async function get(cid, options = {}) {\n if (options.preload !== false) {\n preload(cid);\n }\n return repo.blocks.get(cid, options);\n }\n return withTimeoutOption.withTimeoutOption(get);\n}\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createPut({codecs, hashers, repo, preload}) {\n async function put(block, options = {}) {\n const release = options.pin ? await repo.gcLock.readLock() : null;\n try {\n const cidVersion = options.version != null ? options.version : 0;\n const codecName = options.format || (cidVersion === 0 ? 'dag-pb' : 'raw');\n const hasher = await hashers.getHasher(options.mhtype || 'sha2-256');\n const hash = await hasher.digest(block);\n const codec = await codecs.getCodec(codecName);\n const cid$1 = cid.CID.create(cidVersion, codec.code, hash);\n await repo.blocks.put(cid$1, block, { signal: options.signal });\n if (options.preload !== false) {\n preload(cid$1);\n }\n if (options.pin === true) {\n await repo.pins.pinRecursively(cid$1, { signal: options.signal });\n }\n return cid$1;\n } finally {\n if (release) {\n release();\n }\n }\n }\n return withTimeoutOption.withTimeoutOption(put);\n}\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar parallel = require('it-parallel');\nvar map = require('it-map');\nvar filter = require('it-filter');\nvar itPipe = require('it-pipe');\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar parallel__default = /*#__PURE__*/_interopDefaultLegacy(parallel);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\n\nconst BLOCK_RM_CONCURRENCY = 8;\nfunction createRm({repo}) {\n async function* rm(cids, options = {}) {\n if (!Array.isArray(cids)) {\n cids = [cids];\n }\n const release = await repo.gcLock.writeLock();\n try {\n yield* itPipe.pipe(cids, source => map__default['default'](source, cid => {\n return async () => {\n cid = utils.cleanCid(cid);\n const result = { cid };\n try {\n const has = await repo.blocks.has(cid);\n if (!has) {\n throw errCode__default['default'](new Error('block not found'), 'ERR_BLOCK_NOT_FOUND');\n }\n await repo.blocks.delete(cid);\n } catch (err) {\n if (!options.force) {\n err.message = `cannot remove ${ cid }: ${ err.message }`;\n result.error = err;\n }\n }\n return result;\n };\n }), source => parallel__default['default'](source, BLOCK_RM_CONCURRENCY), source => filter__default['default'](source, () => !options.quiet));\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(rm);\n}\n\nexports.createRm = createRm;\n","'use strict'\n\nconst defer = require('p-defer')\nconst EventEmitter = require('events').EventEmitter\n\n/**\n * Takes an (async) iterator that emits promise-returning functions,\n * invokes them in parallel and emits the results as they become available but\n * in the same order as the input\n *\n * @template T\n * @param {Iterable<() => Promise<T>> | AsyncIterable<() => Promise<T>>} source\n * @param {number} [concurrency=1]\n * @returns {AsyncIterable<T>}\n */\nasync function * parallel (source, concurrency = 1) {\n if (concurrency < 1) {\n concurrency = 1\n }\n\n const emitter = new EventEmitter()\n\n /** @type {any[]} */\n const ops = []\n let slotAvailable = defer()\n let sourceFinished = false\n\n let resultAvailable = defer()\n\n emitter.on('task-complete', () => {\n resultAvailable.resolve()\n resultAvailable = defer()\n })\n\n Promise.resolve().then(async () => {\n try {\n for await (const task of source) {\n if (ops.length === concurrency) {\n await slotAvailable.promise\n }\n\n /**\n * @type {any}\n */\n const op = {\n done: false\n }\n ops.push(op)\n\n task()\n .then(result => {\n op.done = true\n op.ok = true\n op.value = result\n emitter.emit('task-complete')\n }, err => {\n op.done = true\n op.err = err\n emitter.emit('task-complete')\n })\n }\n\n sourceFinished = true\n } catch (err) {\n emitter.emit('task-complete')\n }\n })\n\n while (true) {\n await resultAvailable.promise\n\n while (ops.length && ops[0].done) {\n const op = ops[0]\n ops.shift()\n\n if (op.ok) {\n yield op.value\n } else {\n throw op.err\n }\n\n slotAvailable.resolve()\n slotAvailable = defer()\n }\n\n if (sourceFinished && ops.length === 0) {\n // not waiting for any results and no more tasks so we are done\n break\n }\n }\n}\n\nmodule.exports = parallel\n","'use strict';\n\nconst pDefer = () => {\n\tconst deferred = {};\n\n\tdeferred.promise = new Promise((resolve, reject) => {\n\t\tdeferred.resolve = resolve;\n\t\tdeferred.reject = reject;\n\t});\n\n\treturn deferred;\n};\n\nmodule.exports = pDefer;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n };\n\n eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n }\n });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\n\nfunction cleanCid(cid$1) {\n if (cid$1 instanceof Uint8Array) {\n return cid.CID.decode(cid$1);\n }\n return cid.CID.parse(cid$1.toString());\n}\n\nexports.cleanCid = cleanCid;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createStat({repo, preload}) {\n async function stat(cid, options = {}) {\n cid = utils.cleanCid(cid);\n if (options.preload !== false) {\n preload(cid);\n }\n const block = await repo.blocks.get(cid);\n return {\n cid,\n size: block.length\n };\n }\n return withTimeoutOption.withTimeoutOption(stat);\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar add = require('./add.js');\nvar index = require('./add-all/index.js');\nvar cat = require('./cat.js');\nvar get = require('./get.js');\nvar ls = require('./ls.js');\n\nclass RootAPI {\n constructor({preload, repo, options}) {\n const addAll = index.createAddAll({\n preload,\n repo,\n options\n });\n this.addAll = addAll;\n this.add = add.createAdd({ addAll });\n this.cat = cat.createCat({\n repo,\n preload\n });\n this.get = get.createGet({\n repo,\n preload\n });\n this.ls = ls.createLs({\n repo,\n preload\n });\n }\n}\n\nexports.RootAPI = RootAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar last = require('it-last');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createAdd({addAll}) {\n async function add(entry, options = {}) {\n const result = await last__default['default'](addAll(entry, options));\n if (result == null) {\n throw Error('Failed to add a file, if you see this please report a bug');\n }\n return result;\n }\n return add;\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsImporter = require('ipfs-unixfs-importer');\nvar normaliseInput = require('ipfs-core-utils/files/normalise-input');\nvar utils = require('./utils.js');\nvar itPipe = require('it-pipe');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar mergeOpts = require('merge-options');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nfunction createAddAll({repo, preload, options}) {\n const isShardingEnabled = options && options.sharding;\n async function* addAll(source, options = {}) {\n const opts = mergeOptions({\n shardSplitThreshold: isShardingEnabled ? 1000 : Infinity,\n strategy: 'balanced'\n }, options, { ...utils.parseChunkerString(options.chunker) });\n if (opts.hashAlg && opts.hashAlg !== 'sha2-256' && opts.cidVersion !== 1) {\n opts.cidVersion = 1;\n }\n if (opts.trickle) {\n opts.strategy = 'trickle';\n }\n if (opts.strategy === 'trickle') {\n opts.leafType = 'raw';\n opts.reduceSingleLeafToSelf = false;\n }\n if (opts.cidVersion > 0 && opts.rawLeaves === undefined) {\n opts.rawLeaves = true;\n }\n if (opts.hashAlg !== undefined && opts.rawLeaves === undefined) {\n opts.rawLeaves = true;\n }\n delete opts.trickle;\n const totals = {};\n if (opts.progress) {\n const prog = opts.progress;\n opts.progress = (bytes, path) => {\n if (!totals[path]) {\n totals[path] = 0;\n }\n totals[path] += bytes;\n prog(totals[path], path);\n };\n }\n const iterator = itPipe.pipe(normaliseInput.normaliseInput(source), source => ipfsUnixfsImporter.importer(source, repo.blocks, {\n ...opts,\n pin: false\n }), transformFile(opts), preloadFile(preload, opts), pinFile(repo, opts));\n const releaseLock = await repo.gcLock.readLock();\n try {\n for await (const added of iterator) {\n delete totals[added.path];\n yield added;\n }\n } finally {\n releaseLock();\n }\n }\n return withTimeoutOption.withTimeoutOption(addAll);\n}\nfunction transformFile(opts) {\n async function* transformFile(source) {\n for await (const file of source) {\n let cid = file.cid;\n if (opts.cidVersion === 1) {\n cid = cid.toV1();\n }\n let path = file.path ? file.path : cid.toString();\n if (opts.wrapWithDirectory && !file.path) {\n path = '';\n }\n yield {\n path,\n cid: cid,\n size: file.size,\n mode: file.unixfs && file.unixfs.mode,\n mtime: file.unixfs && file.unixfs.mtime\n };\n }\n }\n return transformFile;\n}\nfunction preloadFile(preload, opts) {\n async function* maybePreloadFile(source) {\n for await (const file of source) {\n const isRootFile = !file.path || opts.wrapWithDirectory ? file.path === '' : !file.path.includes('/');\n const shouldPreload = isRootFile && !opts.onlyHash && opts.preload !== false;\n if (shouldPreload) {\n preload(file.cid);\n }\n yield file;\n }\n }\n return maybePreloadFile;\n}\nfunction pinFile(repo, opts) {\n async function* maybePinFile(source) {\n for await (const file of source) {\n const isRootDir = !(file.path && file.path.includes('/'));\n const shouldPin = (opts.pin == null ? true : opts.pin) && isRootDir && !opts.onlyHash;\n if (shouldPin) {\n await repo.pins.pinRecursively(file.cid);\n }\n yield file;\n }\n }\n return maybePinFile;\n}\n\nexports.createAddAll = createAddAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar parallelBatch = require('it-parallel-batch');\nvar options = require('./options.js');\nvar index = require('./dag-builder/index.js');\nvar treeBuilder = require('./tree-builder.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar parallelBatch__default = /*#__PURE__*/_interopDefaultLegacy(parallelBatch);\n\nasync function* importer(source, blockstore, options$1 = {}) {\n const opts = options(options$1);\n let dagBuilder;\n if (typeof options$1.dagBuilder === 'function') {\n dagBuilder = options$1.dagBuilder;\n } else {\n dagBuilder = index;\n }\n let treeBuilder$1;\n if (typeof options$1.treeBuilder === 'function') {\n treeBuilder$1 = options$1.treeBuilder;\n } else {\n treeBuilder$1 = treeBuilder;\n }\n let candidates;\n if (Symbol.asyncIterator in source || Symbol.iterator in source) {\n candidates = source;\n } else {\n candidates = [source];\n }\n for await (const entry of treeBuilder$1(parallelBatch__default['default'](dagBuilder(candidates, blockstore, opts), opts.fileImportConcurrency), blockstore, opts)) {\n yield {\n cid: entry.cid,\n path: entry.path,\n unixfs: entry.unixfs,\n size: entry.size\n };\n }\n}\n\nexports.importer = importer;\n","'use strict'\n\nconst batch = require('it-batch')\n\n/**\n * @template T\n * @typedef {{ok:true, value:T}} Success\n */\n\n/**\n * @typedef {{ok:false, err:Error}} Failure\n */\n\n/**\n * Takes an (async) iterator that emits promise-returning functions,\n * invokes them in parallel and emits the results as they become available but\n * in the same order as the input\n *\n * @template T\n * @param {AsyncIterable<() => Promise<T>>} source\n * @param {number} [size=1]\n * @returns {AsyncIterable<T>}\n */\nasync function * parallelBatch (source, size = 1) {\n for await (const tasks of batch(source, size)) {\n /** @type {Promise<Success<T>|Failure>[]} */\n const things = tasks.map(\n /**\n * @param {() => Promise<T>} p\n */\n p => {\n return p().then(value => ({ ok: true, value }), err => ({ ok: false, err }))\n })\n\n for (let i = 0; i < things.length; i++) {\n const result = await things[i]\n\n if (result.ok) {\n yield result.value\n } else {\n throw result.err\n }\n }\n }\n}\n\nmodule.exports = parallelBatch\n","'use strict'\n\n/**\n * Takes an (async) iterable that emits things and returns an async iterable that\n * emits those things in fixed-sized batches.\n *\n * @template T\n * @param {AsyncIterable<T>|Iterable<T>} source\n * @param {number} [size=1]\n * @returns {AsyncIterable<T[]>}\n */\nasync function * batch (source, size = 1) {\n /** @type {T[]} */\n let things = []\n\n if (size < 1) {\n size = 1\n }\n\n for await (const thing of source) {\n things.push(thing)\n\n while (things.length >= size) {\n yield things.slice(0, size)\n\n things = things.slice(size)\n }\n }\n\n while (things.length) {\n yield things.slice(0, size)\n\n things = things.slice(size)\n }\n}\n\nmodule.exports = batch\n","'use strict';\n\nvar mergeOptions = require('merge-options');\nvar sha2 = require('multiformats/hashes/sha2');\nvar murmur3 = require('@multiformats/murmur3');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOptions__default = /*#__PURE__*/_interopDefaultLegacy(mergeOptions);\n\nasync function hamtHashFn(buf) {\n return (await murmur3.murmur3128.encode(buf)).slice(0, 8).reverse();\n}\nconst defaultOptions = {\n chunker: 'fixed',\n strategy: 'balanced',\n rawLeaves: false,\n onlyHash: false,\n reduceSingleLeafToSelf: true,\n hasher: sha2.sha256,\n leafType: 'file',\n cidVersion: 0,\n progress: () => () => {\n },\n shardSplitThreshold: 1000,\n fileImportConcurrency: 50,\n blockWriteConcurrency: 10,\n minChunkSize: 262144,\n maxChunkSize: 262144,\n avgChunkSize: 262144,\n window: 16,\n polynomial: 17437180132763652,\n maxChildrenPerNode: 174,\n layerRepeat: 4,\n wrapWithDirectory: false,\n recursive: false,\n hidden: false,\n timeout: undefined,\n hamtHashFn,\n hamtHashCode: 34,\n hamtBucketBits: 8\n};\nvar defaultOptions$1 = (options = {}) => {\n const defaults = mergeOptions__default['default'].bind({ ignoreUndefined: true });\n return defaults(defaultOptions, options);\n};\n\nmodule.exports = defaultOptions$1;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar hasher = require('multiformats/hashes/hasher');\nvar multiformats = require('multiformats');\nvar mur = require('murmurhash3js-revisited');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mur__default = /*#__PURE__*/_interopDefaultLegacy(mur);\n\nfunction fromNumberTo32BitBuf(number) {\n const bytes = new Array(4);\n for (let i = 0; i < 4; i++) {\n bytes[i] = number & 255;\n number = number >> 8;\n }\n return new Uint8Array(bytes);\n}\nconst murmur332 = hasher.from({\n name: 'murmur3-32',\n code: 35,\n encode: input => fromNumberTo32BitBuf(mur__default[\"default\"].x86.hash32(input))\n});\nconst murmur3128 = hasher.from({\n name: 'murmur3-128',\n code: 34,\n encode: input => multiformats.bytes.fromHex(mur__default[\"default\"].x64.hash128(input))\n});\n\nexports.murmur3128 = murmur3128;\nexports.murmur332 = murmur332;\n","module.exports = require('./lib/murmurHash3js');\n","/* jshint -W086: true */\n// +----------------------------------------------------------------------+\n// | murmurHash3js.js v3.0.1 // https://github.com/pid/murmurHash3js\n// | A javascript implementation of MurmurHash3's x86 hashing algorithms. |\n// |----------------------------------------------------------------------|\n// | Copyright (c) 2012-2015 Karan Lyons |\n// | https://github.com/karanlyons/murmurHash3.js/blob/c1778f75792abef7bdd74bc85d2d4e1a3d25cfe9/murmurHash3.js |\n// | Freely distributable under the MIT license. |\n// +----------------------------------------------------------------------+\n\n;(function (root, undefined) {\n 'use strict';\n\n // Create a local object that'll be exported or referenced globally.\n var library = {\n 'version': '3.0.0',\n 'x86': {},\n 'x64': {},\n 'inputValidation': true\n };\n\n // PRIVATE FUNCTIONS\n // -----------------\n\n function _validBytes(bytes) {\n // check the input is an array or a typed array\n if (!Array.isArray(bytes) && !ArrayBuffer.isView(bytes)) {\n return false;\n }\n\n // check all bytes are actually bytes\n for (var i = 0; i < bytes.length; i++) {\n if (!Number.isInteger(bytes[i]) || bytes[i] < 0 || bytes[i] > 255) {\n return false;\n }\n }\n return true;\n }\n\n function _x86Multiply(m, n) {\n //\n // Given two 32bit ints, returns the two multiplied together as a\n // 32bit int.\n //\n\n return ((m & 0xffff) * n) + ((((m >>> 16) * n) & 0xffff) << 16);\n }\n\n function _x86Rotl(m, n) {\n //\n // Given a 32bit int and an int representing a number of bit positions,\n // returns the 32bit int rotated left by that number of positions.\n //\n\n return (m << n) | (m >>> (32 - n));\n }\n\n function _x86Fmix(h) {\n //\n // Given a block, returns murmurHash3's final x86 mix of that block.\n //\n\n h ^= h >>> 16;\n h = _x86Multiply(h, 0x85ebca6b);\n h ^= h >>> 13;\n h = _x86Multiply(h, 0xc2b2ae35);\n h ^= h >>> 16;\n\n return h;\n }\n\n function _x64Add(m, n) {\n //\n // Given two 64bit ints (as an array of two 32bit ints) returns the two\n // added together as a 64bit int (as an array of two 32bit ints).\n //\n\n m = [m[0] >>> 16, m[0] & 0xffff, m[1] >>> 16, m[1] & 0xffff];\n n = [n[0] >>> 16, n[0] & 0xffff, n[1] >>> 16, n[1] & 0xffff];\n var o = [0, 0, 0, 0];\n\n o[3] += m[3] + n[3];\n o[2] += o[3] >>> 16;\n o[3] &= 0xffff;\n\n o[2] += m[2] + n[2];\n o[1] += o[2] >>> 16;\n o[2] &= 0xffff;\n\n o[1] += m[1] + n[1];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n\n o[0] += m[0] + n[0];\n o[0] &= 0xffff;\n\n return [(o[0] << 16) | o[1], (o[2] << 16) | o[3]];\n }\n\n function _x64Multiply(m, n) {\n //\n // Given two 64bit ints (as an array of two 32bit ints) returns the two\n // multiplied together as a 64bit int (as an array of two 32bit ints).\n //\n\n m = [m[0] >>> 16, m[0] & 0xffff, m[1] >>> 16, m[1] & 0xffff];\n n = [n[0] >>> 16, n[0] & 0xffff, n[1] >>> 16, n[1] & 0xffff];\n var o = [0, 0, 0, 0];\n\n o[3] += m[3] * n[3];\n o[2] += o[3] >>> 16;\n o[3] &= 0xffff;\n\n o[2] += m[2] * n[3];\n o[1] += o[2] >>> 16;\n o[2] &= 0xffff;\n\n o[2] += m[3] * n[2];\n o[1] += o[2] >>> 16;\n o[2] &= 0xffff;\n\n o[1] += m[1] * n[3];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n\n o[1] += m[2] * n[2];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n\n o[1] += m[3] * n[1];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n\n o[0] += (m[0] * n[3]) + (m[1] * n[2]) + (m[2] * n[1]) + (m[3] * n[0]);\n o[0] &= 0xffff;\n\n return [(o[0] << 16) | o[1], (o[2] << 16) | o[3]];\n }\n\n function _x64Rotl(m, n) {\n //\n // Given a 64bit int (as an array of two 32bit ints) and an int\n // representing a number of bit positions, returns the 64bit int (as an\n // array of two 32bit ints) rotated left by that number of positions.\n //\n\n n %= 64;\n\n if (n === 32) {\n return [m[1], m[0]];\n } else if (n < 32) {\n return [(m[0] << n) | (m[1] >>> (32 - n)), (m[1] << n) | (m[0] >>> (32 - n))];\n } else {\n n -= 32;\n return [(m[1] << n) | (m[0] >>> (32 - n)), (m[0] << n) | (m[1] >>> (32 - n))];\n }\n }\n\n function _x64LeftShift(m, n) {\n //\n // Given a 64bit int (as an array of two 32bit ints) and an int\n // representing a number of bit positions, returns the 64bit int (as an\n // array of two 32bit ints) shifted left by that number of positions.\n //\n\n n %= 64;\n\n if (n === 0) {\n return m;\n } else if (n < 32) {\n return [(m[0] << n) | (m[1] >>> (32 - n)), m[1] << n];\n } else {\n return [m[1] << (n - 32), 0];\n }\n }\n\n function _x64Xor(m, n) {\n //\n // Given two 64bit ints (as an array of two 32bit ints) returns the two\n // xored together as a 64bit int (as an array of two 32bit ints).\n //\n\n return [m[0] ^ n[0], m[1] ^ n[1]];\n }\n\n function _x64Fmix(h) {\n //\n // Given a block, returns murmurHash3's final x64 mix of that block.\n // (`[0, h[0] >>> 1]` is a 33 bit unsigned right shift. This is the\n // only place where we need to right shift 64bit ints.)\n //\n\n h = _x64Xor(h, [0, h[0] >>> 1]);\n h = _x64Multiply(h, [0xff51afd7, 0xed558ccd]);\n h = _x64Xor(h, [0, h[0] >>> 1]);\n h = _x64Multiply(h, [0xc4ceb9fe, 0x1a85ec53]);\n h = _x64Xor(h, [0, h[0] >>> 1]);\n\n return h;\n }\n\n // PUBLIC FUNCTIONS\n // ----------------\n\n library.x86.hash32 = function (bytes, seed) {\n //\n // Given a string and an optional seed as an int, returns a 32 bit hash\n // using the x86 flavor of MurmurHash3, as an unsigned int.\n //\n if (library.inputValidation && !_validBytes(bytes)) {\n return undefined;\n }\n seed = seed || 0;\n\n var remainder = bytes.length % 4;\n var blocks = bytes.length - remainder;\n\n var h1 = seed;\n\n var k1 = 0;\n\n var c1 = 0xcc9e2d51;\n var c2 = 0x1b873593;\n\n for (var i = 0; i < blocks; i = i + 4) {\n k1 = (bytes[i]) | (bytes[i + 1] << 8) | (bytes[i + 2] << 16) | (bytes[i + 3] << 24);\n\n k1 = _x86Multiply(k1, c1);\n k1 = _x86Rotl(k1, 15);\n k1 = _x86Multiply(k1, c2);\n\n h1 ^= k1;\n h1 = _x86Rotl(h1, 13);\n h1 = _x86Multiply(h1, 5) + 0xe6546b64;\n }\n\n k1 = 0;\n\n switch (remainder) {\n case 3:\n k1 ^= bytes[i + 2] << 16;\n\n case 2:\n k1 ^= bytes[i + 1] << 8;\n\n case 1:\n k1 ^= bytes[i];\n k1 = _x86Multiply(k1, c1);\n k1 = _x86Rotl(k1, 15);\n k1 = _x86Multiply(k1, c2);\n h1 ^= k1;\n }\n\n h1 ^= bytes.length;\n h1 = _x86Fmix(h1);\n\n return h1 >>> 0;\n };\n\n library.x86.hash128 = function (bytes, seed) {\n //\n // Given a string and an optional seed as an int, returns a 128 bit\n // hash using the x86 flavor of MurmurHash3, as an unsigned hex.\n //\n if (library.inputValidation && !_validBytes(bytes)) {\n return undefined;\n }\n\n seed = seed || 0;\n var remainder = bytes.length % 16;\n var blocks = bytes.length - remainder;\n\n var h1 = seed;\n var h2 = seed;\n var h3 = seed;\n var h4 = seed;\n\n var k1 = 0;\n var k2 = 0;\n var k3 = 0;\n var k4 = 0;\n\n var c1 = 0x239b961b;\n var c2 = 0xab0e9789;\n var c3 = 0x38b34ae5;\n var c4 = 0xa1e38b93;\n\n for (var i = 0; i < blocks; i = i + 16) {\n k1 = (bytes[i]) | (bytes[i + 1] << 8) | (bytes[i + 2] << 16) | (bytes[i + 3] << 24);\n k2 = (bytes[i + 4]) | (bytes[i + 5] << 8) | (bytes[i + 6] << 16) | (bytes[i + 7] << 24);\n k3 = (bytes[i + 8]) | (bytes[i + 9] << 8) | (bytes[i + 10] << 16) | (bytes[i + 11] << 24);\n k4 = (bytes[i + 12]) | (bytes[i + 13] << 8) | (bytes[i + 14] << 16) | (bytes[i + 15] << 24);\n\n k1 = _x86Multiply(k1, c1);\n k1 = _x86Rotl(k1, 15);\n k1 = _x86Multiply(k1, c2);\n h1 ^= k1;\n\n h1 = _x86Rotl(h1, 19);\n h1 += h2;\n h1 = _x86Multiply(h1, 5) + 0x561ccd1b;\n\n k2 = _x86Multiply(k2, c2);\n k2 = _x86Rotl(k2, 16);\n k2 = _x86Multiply(k2, c3);\n h2 ^= k2;\n\n h2 = _x86Rotl(h2, 17);\n h2 += h3;\n h2 = _x86Multiply(h2, 5) + 0x0bcaa747;\n\n k3 = _x86Multiply(k3, c3);\n k3 = _x86Rotl(k3, 17);\n k3 = _x86Multiply(k3, c4);\n h3 ^= k3;\n\n h3 = _x86Rotl(h3, 15);\n h3 += h4;\n h3 = _x86Multiply(h3, 5) + 0x96cd1c35;\n\n k4 = _x86Multiply(k4, c4);\n k4 = _x86Rotl(k4, 18);\n k4 = _x86Multiply(k4, c1);\n h4 ^= k4;\n\n h4 = _x86Rotl(h4, 13);\n h4 += h1;\n h4 = _x86Multiply(h4, 5) + 0x32ac3b17;\n }\n\n k1 = 0;\n k2 = 0;\n k3 = 0;\n k4 = 0;\n\n switch (remainder) {\n case 15:\n k4 ^= bytes[i + 14] << 16;\n\n case 14:\n k4 ^= bytes[i + 13] << 8;\n\n case 13:\n k4 ^= bytes[i + 12];\n k4 = _x86Multiply(k4, c4);\n k4 = _x86Rotl(k4, 18);\n k4 = _x86Multiply(k4, c1);\n h4 ^= k4;\n\n case 12:\n k3 ^= bytes[i + 11] << 24;\n\n case 11:\n k3 ^= bytes[i + 10] << 16;\n\n case 10:\n k3 ^= bytes[i + 9] << 8;\n\n case 9:\n k3 ^= bytes[i + 8];\n k3 = _x86Multiply(k3, c3);\n k3 = _x86Rotl(k3, 17);\n k3 = _x86Multiply(k3, c4);\n h3 ^= k3;\n\n case 8:\n k2 ^= bytes[i + 7] << 24;\n\n case 7:\n k2 ^= bytes[i + 6] << 16;\n\n case 6:\n k2 ^= bytes[i + 5] << 8;\n\n case 5:\n k2 ^= bytes[i + 4];\n k2 = _x86Multiply(k2, c2);\n k2 = _x86Rotl(k2, 16);\n k2 = _x86Multiply(k2, c3);\n h2 ^= k2;\n\n case 4:\n k1 ^= bytes[i + 3] << 24;\n\n case 3:\n k1 ^= bytes[i + 2] << 16;\n\n case 2:\n k1 ^= bytes[i + 1] << 8;\n\n case 1:\n k1 ^= bytes[i];\n k1 = _x86Multiply(k1, c1);\n k1 = _x86Rotl(k1, 15);\n k1 = _x86Multiply(k1, c2);\n h1 ^= k1;\n }\n\n h1 ^= bytes.length;\n h2 ^= bytes.length;\n h3 ^= bytes.length;\n h4 ^= bytes.length;\n\n h1 += h2;\n h1 += h3;\n h1 += h4;\n h2 += h1;\n h3 += h1;\n h4 += h1;\n\n h1 = _x86Fmix(h1);\n h2 = _x86Fmix(h2);\n h3 = _x86Fmix(h3);\n h4 = _x86Fmix(h4);\n\n h1 += h2;\n h1 += h3;\n h1 += h4;\n h2 += h1;\n h3 += h1;\n h4 += h1;\n\n return (\"00000000\" + (h1 >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h2 >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h3 >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h4 >>> 0).toString(16)).slice(-8);\n };\n\n library.x64.hash128 = function (bytes, seed) {\n //\n // Given a string and an optional seed as an int, returns a 128 bit\n // hash using the x64 flavor of MurmurHash3, as an unsigned hex.\n //\n if (library.inputValidation && !_validBytes(bytes)) {\n return undefined;\n }\n seed = seed || 0;\n\n var remainder = bytes.length % 16;\n var blocks = bytes.length - remainder;\n\n var h1 = [0, seed];\n var h2 = [0, seed];\n\n var k1 = [0, 0];\n var k2 = [0, 0];\n\n var c1 = [0x87c37b91, 0x114253d5];\n var c2 = [0x4cf5ad43, 0x2745937f];\n\n for (var i = 0; i < blocks; i = i + 16) {\n k1 = [(bytes[i + 4]) | (bytes[i + 5] << 8) | (bytes[i + 6] << 16) | (bytes[i + 7] << 24), (bytes[i]) |\n (bytes[i + 1] << 8) | (bytes[i + 2] << 16) | (bytes[i + 3] << 24)];\n k2 = [(bytes[i + 12]) | (bytes[i + 13] << 8) | (bytes[i + 14] << 16) | (bytes[i + 15] << 24), (bytes[i + 8]) |\n (bytes[i + 9] << 8) | (bytes[i + 10] << 16) | (bytes[i + 11] << 24)];\n\n k1 = _x64Multiply(k1, c1);\n k1 = _x64Rotl(k1, 31);\n k1 = _x64Multiply(k1, c2);\n h1 = _x64Xor(h1, k1);\n\n h1 = _x64Rotl(h1, 27);\n h1 = _x64Add(h1, h2);\n h1 = _x64Add(_x64Multiply(h1, [0, 5]), [0, 0x52dce729]);\n\n k2 = _x64Multiply(k2, c2);\n k2 = _x64Rotl(k2, 33);\n k2 = _x64Multiply(k2, c1);\n h2 = _x64Xor(h2, k2);\n\n h2 = _x64Rotl(h2, 31);\n h2 = _x64Add(h2, h1);\n h2 = _x64Add(_x64Multiply(h2, [0, 5]), [0, 0x38495ab5]);\n }\n\n k1 = [0, 0];\n k2 = [0, 0];\n\n switch (remainder) {\n case 15:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 14]], 48));\n\n case 14:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 13]], 40));\n\n case 13:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 12]], 32));\n\n case 12:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 11]], 24));\n\n case 11:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 10]], 16));\n\n case 10:\n k2 = _x64Xor(k2, _x64LeftShift([0, bytes[i + 9]], 8));\n\n case 9:\n k2 = _x64Xor(k2, [0, bytes[i + 8]]);\n k2 = _x64Multiply(k2, c2);\n k2 = _x64Rotl(k2, 33);\n k2 = _x64Multiply(k2, c1);\n h2 = _x64Xor(h2, k2);\n\n case 8:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 7]], 56));\n\n case 7:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 6]], 48));\n\n case 6:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 5]], 40));\n\n case 5:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 4]], 32));\n\n case 4:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 3]], 24));\n\n case 3:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 2]], 16));\n\n case 2:\n k1 = _x64Xor(k1, _x64LeftShift([0, bytes[i + 1]], 8));\n\n case 1:\n k1 = _x64Xor(k1, [0, bytes[i]]);\n k1 = _x64Multiply(k1, c1);\n k1 = _x64Rotl(k1, 31);\n k1 = _x64Multiply(k1, c2);\n h1 = _x64Xor(h1, k1);\n }\n\n h1 = _x64Xor(h1, [0, bytes.length]);\n h2 = _x64Xor(h2, [0, bytes.length]);\n\n h1 = _x64Add(h1, h2);\n h2 = _x64Add(h2, h1);\n\n h1 = _x64Fmix(h1);\n h2 = _x64Fmix(h2);\n\n h1 = _x64Add(h1, h2);\n h2 = _x64Add(h2, h1);\n\n return (\"00000000\" + (h1[0] >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h1[1] >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h2[0] >>> 0).toString(16)).slice(-8) + (\"00000000\" + (h2[1] >>> 0).toString(16)).slice(-8);\n };\n\n // INITIALIZATION\n // --------------\n\n // Export murmurHash3 for CommonJS, either as an AMD module or just as part\n // of the global object.\n if (typeof exports !== 'undefined') {\n\n if (typeof module !== 'undefined' && module.exports) {\n exports = module.exports = library;\n }\n\n exports.murmurHash3 = library;\n\n } else if (typeof define === 'function' && define.amd) {\n\n define([], function () {\n return library;\n });\n } else {\n\n // Use murmurHash3.noConflict to restore `murmurHash3` back to its\n // original value. Returns a reference to the library object, to allow\n // it to be used under a different name.\n library._murmurHash3 = root.murmurHash3;\n\n library.noConflict = function () {\n root.murmurHash3 = library._murmurHash3;\n library._murmurHash3 = undefined;\n library.noConflict = undefined;\n\n return library;\n };\n\n root.murmurHash3 = library;\n }\n})(this);\n","'use strict';\n\nvar dir = require('./dir.js');\nvar index = require('./file/index.js');\nvar errCode = require('err-code');\nvar rabin = require('../chunker/rabin.js');\nvar fixedSize = require('../chunker/fixed-size.js');\nvar validateChunks = require('./validate-chunks.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction isIterable(thing) {\n return Symbol.iterator in thing;\n}\nfunction isAsyncIterable(thing) {\n return Symbol.asyncIterator in thing;\n}\nfunction contentAsAsyncIterable(content) {\n try {\n if (content instanceof Uint8Array) {\n return async function* () {\n yield content;\n }();\n } else if (isIterable(content)) {\n return async function* () {\n yield* content;\n }();\n } else if (isAsyncIterable(content)) {\n return content;\n }\n } catch {\n throw errCode__default['default'](new Error('Content was invalid'), 'ERR_INVALID_CONTENT');\n }\n throw errCode__default['default'](new Error('Content was invalid'), 'ERR_INVALID_CONTENT');\n}\nasync function* dagBuilder(source, blockstore, options) {\n for await (const entry of source) {\n if (entry.path) {\n if (entry.path.substring(0, 2) === './') {\n options.wrapWithDirectory = true;\n }\n entry.path = entry.path.split('/').filter(path => path && path !== '.').join('/');\n }\n if (entry.content) {\n let chunker;\n if (typeof options.chunker === 'function') {\n chunker = options.chunker;\n } else if (options.chunker === 'rabin') {\n chunker = rabin;\n } else {\n chunker = fixedSize;\n }\n let chunkValidator;\n if (typeof options.chunkValidator === 'function') {\n chunkValidator = options.chunkValidator;\n } else {\n chunkValidator = validateChunks;\n }\n const file = {\n path: entry.path,\n mtime: entry.mtime,\n mode: entry.mode,\n content: chunker(chunkValidator(contentAsAsyncIterable(entry.content), options), options)\n };\n yield () => index(file, blockstore, options);\n } else if (entry.path) {\n const dir$1 = {\n path: entry.path,\n mtime: entry.mtime,\n mode: entry.mode\n };\n yield () => dir(dir$1, blockstore, options);\n } else {\n throw new Error('Import candidate must have content or path or both');\n }\n }\n}\n\nmodule.exports = dagBuilder;\n","'use strict';\n\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar persist = require('../utils/persist.js');\nvar dagPb = require('@ipld/dag-pb');\n\nconst dirBuilder = async (item, blockstore, options) => {\n const unixfs = new ipfsUnixfs.UnixFS({\n type: 'directory',\n mtime: item.mtime,\n mode: item.mode\n });\n const buffer = dagPb.encode(dagPb.prepare({ Data: unixfs.marshal() }));\n const cid = await persist(buffer, blockstore, options);\n const path = item.path;\n return {\n cid,\n path,\n unixfs,\n size: buffer.length\n };\n};\n\nmodule.exports = dirBuilder;\n","'use strict';\n\nvar cid = require('multiformats/cid');\nvar dagPb = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\n\nconst persist = async (buffer, blockstore, options) => {\n if (!options.codec) {\n options.codec = dagPb__namespace;\n }\n if (!options.hasher) {\n options.hasher = sha2.sha256;\n }\n if (options.cidVersion === undefined) {\n options.cidVersion = 1;\n }\n if (options.codec === dagPb__namespace && options.hasher !== sha2.sha256) {\n options.cidVersion = 1;\n }\n const multihash = await options.hasher.digest(buffer);\n const cid$1 = cid.CID.create(options.cidVersion, options.codec.code, multihash);\n if (!options.onlyHash) {\n await blockstore.put(cid$1, buffer, { signal: options.signal });\n }\n return cid$1;\n};\n\nmodule.exports = persist;\n","'use strict';\n\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar persist = require('../../utils/persist.js');\nvar dagPb = require('@ipld/dag-pb');\nvar parallelBatch = require('it-parallel-batch');\nvar rawCodec = require('multiformats/codecs/raw');\nvar flat = require('./flat.js');\nvar balanced = require('./balanced.js');\nvar trickle = require('./trickle.js');\nvar bufferImporter = require('./buffer-importer.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar parallelBatch__default = /*#__PURE__*/_interopDefaultLegacy(parallelBatch);\nvar rawCodec__namespace = /*#__PURE__*/_interopNamespace(rawCodec);\n\nconst dagBuilders = {\n flat: flat,\n balanced: balanced,\n trickle: trickle\n};\nasync function* buildFileBatch(file, blockstore, options) {\n let count = -1;\n let previous;\n let bufferImporter$1;\n if (typeof options.bufferImporter === 'function') {\n bufferImporter$1 = options.bufferImporter;\n } else {\n bufferImporter$1 = bufferImporter;\n }\n for await (const entry of parallelBatch__default['default'](bufferImporter$1(file, blockstore, options), options.blockWriteConcurrency)) {\n count++;\n if (count === 0) {\n previous = entry;\n continue;\n } else if (count === 1 && previous) {\n yield previous;\n previous = null;\n }\n yield entry;\n }\n if (previous) {\n previous.single = true;\n yield previous;\n }\n}\nconst reduce = (file, blockstore, options) => {\n async function reducer(leaves) {\n if (leaves.length === 1 && leaves[0].single && options.reduceSingleLeafToSelf) {\n const leaf = leaves[0];\n if (leaf.cid.code === rawCodec__namespace.code && (file.mtime !== undefined || file.mode !== undefined)) {\n let buffer = await blockstore.get(leaf.cid);\n leaf.unixfs = new ipfsUnixfs.UnixFS({\n type: 'file',\n mtime: file.mtime,\n mode: file.mode,\n data: buffer\n });\n buffer = dagPb.encode(dagPb.prepare({ Data: leaf.unixfs.marshal() }));\n leaf.cid = await persist(buffer, blockstore, {\n ...options,\n codec: dagPb__namespace,\n hasher: options.hasher,\n cidVersion: options.cidVersion\n });\n leaf.size = buffer.length;\n }\n return {\n cid: leaf.cid,\n path: file.path,\n unixfs: leaf.unixfs,\n size: leaf.size\n };\n }\n const f = new ipfsUnixfs.UnixFS({\n type: 'file',\n mtime: file.mtime,\n mode: file.mode\n });\n const links = leaves.filter(leaf => {\n if (leaf.cid.code === rawCodec__namespace.code && leaf.size) {\n return true;\n }\n if (leaf.unixfs && !leaf.unixfs.data && leaf.unixfs.fileSize()) {\n return true;\n }\n return Boolean(leaf.unixfs && leaf.unixfs.data && leaf.unixfs.data.length);\n }).map(leaf => {\n if (leaf.cid.code === rawCodec__namespace.code) {\n f.addBlockSize(leaf.size);\n return {\n Name: '',\n Tsize: leaf.size,\n Hash: leaf.cid\n };\n }\n if (!leaf.unixfs || !leaf.unixfs.data) {\n f.addBlockSize(leaf.unixfs && leaf.unixfs.fileSize() || 0);\n } else {\n f.addBlockSize(leaf.unixfs.data.length);\n }\n return {\n Name: '',\n Tsize: leaf.size,\n Hash: leaf.cid\n };\n });\n const node = {\n Data: f.marshal(),\n Links: links\n };\n const buffer = dagPb.encode(dagPb.prepare(node));\n const cid = await persist(buffer, blockstore, options);\n return {\n cid,\n path: file.path,\n unixfs: f,\n size: buffer.length + node.Links.reduce((acc, curr) => acc + curr.Tsize, 0)\n };\n }\n return reducer;\n};\nfunction fileBuilder(file, block, options) {\n const dagBuilder = dagBuilders[options.strategy];\n if (!dagBuilder) {\n throw errCode__default['default'](new Error(`Unknown importer build strategy name: ${ options.strategy }`), 'ERR_BAD_STRATEGY');\n }\n return dagBuilder(buildFileBatch(file, block, options), reduce(file, block, options), options);\n}\n\nmodule.exports = fileBuilder;\n","'use strict';\n\nvar all = require('it-all');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\n\nasync function flat(source, reduce) {\n return reduce(await all__default['default'](source));\n}\n\nmodule.exports = flat;\n","'use strict';\n\nvar batch = require('it-batch');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar batch__default = /*#__PURE__*/_interopDefaultLegacy(batch);\n\nfunction balanced(source, reduce, options) {\n return reduceToParents(source, reduce, options);\n}\nasync function reduceToParents(source, reduce, options) {\n const roots = [];\n for await (const chunked of batch__default['default'](source, options.maxChildrenPerNode)) {\n roots.push(await reduce(chunked));\n }\n if (roots.length > 1) {\n return reduceToParents(roots, reduce, options);\n }\n return roots[0];\n}\n\nmodule.exports = balanced;\n","'use strict';\n\nvar batch = require('it-batch');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar batch__default = /*#__PURE__*/_interopDefaultLegacy(batch);\n\nasync function trickleStream(source, reduce, options) {\n const root = new Root(options.layerRepeat);\n let iteration = 0;\n let maxDepth = 1;\n let subTree = root;\n for await (const layer of batch__default['default'](source, options.maxChildrenPerNode)) {\n if (subTree.isFull()) {\n if (subTree !== root) {\n root.addChild(await subTree.reduce(reduce));\n }\n if (iteration && iteration % options.layerRepeat === 0) {\n maxDepth++;\n }\n subTree = new SubTree(maxDepth, options.layerRepeat, iteration);\n iteration++;\n }\n subTree.append(layer);\n }\n if (subTree && subTree !== root) {\n root.addChild(await subTree.reduce(reduce));\n }\n return root.reduce(reduce);\n}\nclass SubTree {\n constructor(maxDepth, layerRepeat, iteration = 0) {\n this.maxDepth = maxDepth;\n this.layerRepeat = layerRepeat;\n this.currentDepth = 1;\n this.iteration = iteration;\n this.root = this.node = this.parent = {\n children: [],\n depth: this.currentDepth,\n maxDepth,\n maxChildren: (this.maxDepth - this.currentDepth) * this.layerRepeat\n };\n }\n isFull() {\n if (!this.root.data) {\n return false;\n }\n if (this.currentDepth < this.maxDepth && this.node.maxChildren) {\n this._addNextNodeToParent(this.node);\n return false;\n }\n const distantRelative = this._findParent(this.node, this.currentDepth);\n if (distantRelative) {\n this._addNextNodeToParent(distantRelative);\n return false;\n }\n return true;\n }\n _addNextNodeToParent(parent) {\n this.parent = parent;\n const nextNode = {\n children: [],\n depth: parent.depth + 1,\n parent,\n maxDepth: this.maxDepth,\n maxChildren: Math.floor(parent.children.length / this.layerRepeat) * this.layerRepeat\n };\n parent.children.push(nextNode);\n this.currentDepth = nextNode.depth;\n this.node = nextNode;\n }\n append(layer) {\n this.node.data = layer;\n }\n reduce(reduce) {\n return this._reduce(this.root, reduce);\n }\n async _reduce(node, reduce) {\n let children = [];\n if (node.children.length) {\n children = await Promise.all(node.children.filter(child => child.data).map(child => this._reduce(child, reduce)));\n }\n return reduce((node.data || []).concat(children));\n }\n _findParent(node, depth) {\n const parent = node.parent;\n if (!parent || parent.depth === 0) {\n return;\n }\n if (parent.children.length === parent.maxChildren || !parent.maxChildren) {\n return this._findParent(parent, depth);\n }\n return parent;\n }\n}\nclass Root extends SubTree {\n constructor(layerRepeat) {\n super(0, layerRepeat);\n this.root.depth = 0;\n this.currentDepth = 1;\n }\n addChild(child) {\n this.root.children.push(child);\n }\n reduce(reduce) {\n return reduce((this.root.data || []).concat(this.root.children));\n }\n}\n\nmodule.exports = trickleStream;\n","'use strict';\n\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar persist = require('../../utils/persist.js');\nvar dagPb = require('@ipld/dag-pb');\nvar rawCodec = require('multiformats/codecs/raw');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar rawCodec__namespace = /*#__PURE__*/_interopNamespace(rawCodec);\n\nasync function* bufferImporter(file, block, options) {\n for await (let buffer of file.content) {\n yield async () => {\n options.progress(buffer.length, file.path);\n let unixfs;\n const opts = {\n codec: dagPb__namespace,\n cidVersion: options.cidVersion,\n hasher: options.hasher,\n onlyHash: options.onlyHash\n };\n if (options.rawLeaves) {\n opts.codec = rawCodec__namespace;\n opts.cidVersion = 1;\n } else {\n unixfs = new ipfsUnixfs.UnixFS({\n type: options.leafType,\n data: buffer,\n mtime: file.mtime,\n mode: file.mode\n });\n buffer = dagPb__namespace.encode({\n Data: unixfs.marshal(),\n Links: []\n });\n }\n return {\n cid: await persist(buffer, block, opts),\n unixfs,\n size: buffer.length\n };\n };\n }\n}\n\nmodule.exports = bufferImporter;\n","'use strict';\n\nvar BufferList = require('bl/BufferList.js');\nvar rabinWasm = require('rabin-wasm');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar BufferList__default = /*#__PURE__*/_interopDefaultLegacy(BufferList);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nasync function* rabinChunker(source, options) {\n let min, max, avg;\n if (options.minChunkSize && options.maxChunkSize && options.avgChunkSize) {\n avg = options.avgChunkSize;\n min = options.minChunkSize;\n max = options.maxChunkSize;\n } else if (!options.avgChunkSize) {\n throw errCode__default['default'](new Error('please specify an average chunk size'), 'ERR_INVALID_AVG_CHUNK_SIZE');\n } else {\n avg = options.avgChunkSize;\n min = avg / 3;\n max = avg + avg / 2;\n }\n if (min < 16) {\n throw errCode__default['default'](new Error('rabin min must be greater than 16'), 'ERR_INVALID_MIN_CHUNK_SIZE');\n }\n if (max < min) {\n max = min;\n }\n if (avg < min) {\n avg = min;\n }\n const sizepow = Math.floor(Math.log2(avg));\n for await (const chunk of rabin(source, {\n min: min,\n max: max,\n bits: sizepow,\n window: options.window,\n polynomial: options.polynomial\n })) {\n yield chunk;\n }\n}\nasync function* rabin(source, options) {\n const r = await rabinWasm.create(options.bits, options.min, options.max, options.window);\n const buffers = new BufferList__default['default']();\n for await (const chunk of source) {\n buffers.append(chunk);\n const sizes = r.fingerprint(chunk);\n for (let i = 0; i < sizes.length; i++) {\n const size = sizes[i];\n const buf = buffers.slice(0, size);\n buffers.consume(size);\n yield buf;\n }\n }\n if (buffers.length) {\n yield buffers.slice(0);\n }\n}\n\nmodule.exports = rabinChunker;\n","'use strict'\n\nconst { Buffer } = require('buffer')\nconst symbol = Symbol.for('BufferList')\n\nfunction BufferList (buf) {\n if (!(this instanceof BufferList)) {\n return new BufferList(buf)\n }\n\n BufferList._init.call(this, buf)\n}\n\nBufferList._init = function _init (buf) {\n Object.defineProperty(this, symbol, { value: true })\n\n this._bufs = []\n this.length = 0\n\n if (buf) {\n this.append(buf)\n }\n}\n\nBufferList.prototype._new = function _new (buf) {\n return new BufferList(buf)\n}\n\nBufferList.prototype._offset = function _offset (offset) {\n if (offset === 0) {\n return [0, 0]\n }\n\n let tot = 0\n\n for (let i = 0; i < this._bufs.length; i++) {\n const _t = tot + this._bufs[i].length\n if (offset < _t || i === this._bufs.length - 1) {\n return [i, offset - tot]\n }\n tot = _t\n }\n}\n\nBufferList.prototype._reverseOffset = function (blOffset) {\n const bufferId = blOffset[0]\n let offset = blOffset[1]\n\n for (let i = 0; i < bufferId; i++) {\n offset += this._bufs[i].length\n }\n\n return offset\n}\n\nBufferList.prototype.get = function get (index) {\n if (index > this.length || index < 0) {\n return undefined\n }\n\n const offset = this._offset(index)\n\n return this._bufs[offset[0]][offset[1]]\n}\n\nBufferList.prototype.slice = function slice (start, end) {\n if (typeof start === 'number' && start < 0) {\n start += this.length\n }\n\n if (typeof end === 'number' && end < 0) {\n end += this.length\n }\n\n return this.copy(null, 0, start, end)\n}\n\nBufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) {\n if (typeof srcStart !== 'number' || srcStart < 0) {\n srcStart = 0\n }\n\n if (typeof srcEnd !== 'number' || srcEnd > this.length) {\n srcEnd = this.length\n }\n\n if (srcStart >= this.length) {\n return dst || Buffer.alloc(0)\n }\n\n if (srcEnd <= 0) {\n return dst || Buffer.alloc(0)\n }\n\n const copy = !!dst\n const off = this._offset(srcStart)\n const len = srcEnd - srcStart\n let bytes = len\n let bufoff = (copy && dstStart) || 0\n let start = off[1]\n\n // copy/slice everything\n if (srcStart === 0 && srcEnd === this.length) {\n if (!copy) {\n // slice, but full concat if multiple buffers\n return this._bufs.length === 1\n ? this._bufs[0]\n : Buffer.concat(this._bufs, this.length)\n }\n\n // copy, need to copy individual buffers\n for (let i = 0; i < this._bufs.length; i++) {\n this._bufs[i].copy(dst, bufoff)\n bufoff += this._bufs[i].length\n }\n\n return dst\n }\n\n // easy, cheap case where it's a subset of one of the buffers\n if (bytes <= this._bufs[off[0]].length - start) {\n return copy\n ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes)\n : this._bufs[off[0]].slice(start, start + bytes)\n }\n\n if (!copy) {\n // a slice, we need something to copy in to\n dst = Buffer.allocUnsafe(len)\n }\n\n for (let i = off[0]; i < this._bufs.length; i++) {\n const l = this._bufs[i].length - start\n\n if (bytes > l) {\n this._bufs[i].copy(dst, bufoff, start)\n bufoff += l\n } else {\n this._bufs[i].copy(dst, bufoff, start, start + bytes)\n bufoff += l\n break\n }\n\n bytes -= l\n\n if (start) {\n start = 0\n }\n }\n\n // safeguard so that we don't return uninitialized memory\n if (dst.length > bufoff) return dst.slice(0, bufoff)\n\n return dst\n}\n\nBufferList.prototype.shallowSlice = function shallowSlice (start, end) {\n start = start || 0\n end = typeof end !== 'number' ? this.length : end\n\n if (start < 0) {\n start += this.length\n }\n\n if (end < 0) {\n end += this.length\n }\n\n if (start === end) {\n return this._new()\n }\n\n const startOffset = this._offset(start)\n const endOffset = this._offset(end)\n const buffers = this._bufs.slice(startOffset[0], endOffset[0] + 1)\n\n if (endOffset[1] === 0) {\n buffers.pop()\n } else {\n buffers[buffers.length - 1] = buffers[buffers.length - 1].slice(0, endOffset[1])\n }\n\n if (startOffset[1] !== 0) {\n buffers[0] = buffers[0].slice(startOffset[1])\n }\n\n return this._new(buffers)\n}\n\nBufferList.prototype.toString = function toString (encoding, start, end) {\n return this.slice(start, end).toString(encoding)\n}\n\nBufferList.prototype.consume = function consume (bytes) {\n // first, normalize the argument, in accordance with how Buffer does it\n bytes = Math.trunc(bytes)\n // do nothing if not a positive number\n if (Number.isNaN(bytes) || bytes <= 0) return this\n\n while (this._bufs.length) {\n if (bytes >= this._bufs[0].length) {\n bytes -= this._bufs[0].length\n this.length -= this._bufs[0].length\n this._bufs.shift()\n } else {\n this._bufs[0] = this._bufs[0].slice(bytes)\n this.length -= bytes\n break\n }\n }\n\n return this\n}\n\nBufferList.prototype.duplicate = function duplicate () {\n const copy = this._new()\n\n for (let i = 0; i < this._bufs.length; i++) {\n copy.append(this._bufs[i])\n }\n\n return copy\n}\n\nBufferList.prototype.append = function append (buf) {\n if (buf == null) {\n return this\n }\n\n if (buf.buffer) {\n // append a view of the underlying ArrayBuffer\n this._appendBuffer(Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength))\n } else if (Array.isArray(buf)) {\n for (let i = 0; i < buf.length; i++) {\n this.append(buf[i])\n }\n } else if (this._isBufferList(buf)) {\n // unwrap argument into individual BufferLists\n for (let i = 0; i < buf._bufs.length; i++) {\n this.append(buf._bufs[i])\n }\n } else {\n // coerce number arguments to strings, since Buffer(number) does\n // uninitialized memory allocation\n if (typeof buf === 'number') {\n buf = buf.toString()\n }\n\n this._appendBuffer(Buffer.from(buf))\n }\n\n return this\n}\n\nBufferList.prototype._appendBuffer = function appendBuffer (buf) {\n this._bufs.push(buf)\n this.length += buf.length\n}\n\nBufferList.prototype.indexOf = function (search, offset, encoding) {\n if (encoding === undefined && typeof offset === 'string') {\n encoding = offset\n offset = undefined\n }\n\n if (typeof search === 'function' || Array.isArray(search)) {\n throw new TypeError('The \"value\" argument must be one of type string, Buffer, BufferList, or Uint8Array.')\n } else if (typeof search === 'number') {\n search = Buffer.from([search])\n } else if (typeof search === 'string') {\n search = Buffer.from(search, encoding)\n } else if (this._isBufferList(search)) {\n search = search.slice()\n } else if (Array.isArray(search.buffer)) {\n search = Buffer.from(search.buffer, search.byteOffset, search.byteLength)\n } else if (!Buffer.isBuffer(search)) {\n search = Buffer.from(search)\n }\n\n offset = Number(offset || 0)\n\n if (isNaN(offset)) {\n offset = 0\n }\n\n if (offset < 0) {\n offset = this.length + offset\n }\n\n if (offset < 0) {\n offset = 0\n }\n\n if (search.length === 0) {\n return offset > this.length ? this.length : offset\n }\n\n const blOffset = this._offset(offset)\n let blIndex = blOffset[0] // index of which internal buffer we're working on\n let buffOffset = blOffset[1] // offset of the internal buffer we're working on\n\n // scan over each buffer\n for (; blIndex < this._bufs.length; blIndex++) {\n const buff = this._bufs[blIndex]\n\n while (buffOffset < buff.length) {\n const availableWindow = buff.length - buffOffset\n\n if (availableWindow >= search.length) {\n const nativeSearchResult = buff.indexOf(search, buffOffset)\n\n if (nativeSearchResult !== -1) {\n return this._reverseOffset([blIndex, nativeSearchResult])\n }\n\n buffOffset = buff.length - search.length + 1 // end of native search window\n } else {\n const revOffset = this._reverseOffset([blIndex, buffOffset])\n\n if (this._match(revOffset, search)) {\n return revOffset\n }\n\n buffOffset++\n }\n }\n\n buffOffset = 0\n }\n\n return -1\n}\n\nBufferList.prototype._match = function (offset, search) {\n if (this.length - offset < search.length) {\n return false\n }\n\n for (let searchOffset = 0; searchOffset < search.length; searchOffset++) {\n if (this.get(offset + searchOffset) !== search[searchOffset]) {\n return false\n }\n }\n return true\n}\n\n;(function () {\n const methods = {\n readDoubleBE: 8,\n readDoubleLE: 8,\n readFloatBE: 4,\n readFloatLE: 4,\n readInt32BE: 4,\n readInt32LE: 4,\n readUInt32BE: 4,\n readUInt32LE: 4,\n readInt16BE: 2,\n readInt16LE: 2,\n readUInt16BE: 2,\n readUInt16LE: 2,\n readInt8: 1,\n readUInt8: 1,\n readIntBE: null,\n readIntLE: null,\n readUIntBE: null,\n readUIntLE: null\n }\n\n for (const m in methods) {\n (function (m) {\n if (methods[m] === null) {\n BufferList.prototype[m] = function (offset, byteLength) {\n return this.slice(offset, offset + byteLength)[m](0, byteLength)\n }\n } else {\n BufferList.prototype[m] = function (offset = 0) {\n return this.slice(offset, offset + methods[m])[m](0)\n }\n }\n }(m))\n }\n}())\n\n// Used internally by the class and also as an indicator of this object being\n// a `BufferList`. It's not possible to use `instanceof BufferList` in a browser\n// environment because there could be multiple different copies of the\n// BufferList class and some `BufferList`s might be `BufferList`s.\nBufferList.prototype._isBufferList = function _isBufferList (b) {\n return b instanceof BufferList || BufferList.isBufferList(b)\n}\n\nBufferList.isBufferList = function isBufferList (b) {\n return b != null && b[symbol]\n}\n\nmodule.exports = BufferList\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh <https://feross.org>\n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar customInspectSymbol =\n (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n : null\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nvar K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n var arr = new Uint8Array(1)\n var proto = { foo: function () { return 42 } }\n Object.setPrototypeOf(proto, Uint8Array.prototype)\n Object.setPrototypeOf(arr, proto)\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.buffer\n }\n})\n\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.byteOffset\n }\n})\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n }\n // Return an augmented `Uint8Array` instance\n var buf = new Uint8Array(length)\n Object.setPrototypeOf(buf, Buffer.prototype)\n return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError(\n 'The \"string\" argument must be of type string. Received type number'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value)\n }\n\n if (value == null) {\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n }\n\n if (isInstance(value, ArrayBuffer) ||\n (value && isInstance(value.buffer, ArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof SharedArrayBuffer !== 'undefined' &&\n (isInstance(value, SharedArrayBuffer) ||\n (value && isInstance(value.buffer, SharedArrayBuffer)))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'number') {\n throw new TypeError(\n 'The \"value\" argument must not be of type number. Received type number'\n )\n }\n\n var valueOf = value.valueOf && value.valueOf()\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length)\n }\n\n var b = fromObject(value)\n if (b) return b\n\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(\n value[Symbol.toPrimitive]('string'), encodingOrOffset, length\n )\n }\n\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype)\nObject.setPrototypeOf(Buffer, Uint8Array)\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number')\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpreted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n\n var length = byteLength(string, encoding) | 0\n var buf = createBuffer(length)\n\n var actual = buf.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n var buf = createBuffer(length)\n for (var i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayView (arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n var copy = new Uint8Array(arrayView)\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n }\n return fromArrayLike(arrayView)\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds')\n }\n\n var buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype)\n\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n var buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return b != null && b._isBuffer === true &&\n b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n}\n\nBuffer.compare = function compare (a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength)\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength)\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError(\n 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n )\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n Buffer.from(buf).copy(buffer, pos)\n } else {\n Uint8Array.prototype.set.call(\n buffer,\n buf,\n pos\n )\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n } else {\n buf.copy(buffer, pos)\n }\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n throw new TypeError(\n 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n 'Received type ' + typeof string\n )\n }\n\n var len = string.length\n var mustMatch = (arguments.length > 2 && arguments[2] === true)\n if (!mustMatch && len === 0) return 0\n\n // Use a for loop to avoid recursion\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) {\n return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n }\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n var length = this.length\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.toLocaleString = Buffer.prototype.toString\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n var str = ''\n var max = exports.INSPECT_MAX_BYTES\n str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim()\n if (this.length > max) str += ' ... '\n return '<Buffer ' + str + '>'\n}\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength)\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError(\n 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n 'Received type ' + (typeof target)\n )\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [val], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n var indexSize = 1\n var arrLength = arr.length\n var valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n var i\n if (dir) {\n var foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n var found = true\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n var remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n var strLen = string.length\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (numberIsNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0\n if (isFinite(length)) {\n length = length >>> 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n case 'latin1':\n case 'binary':\n return asciiWrite(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF)\n ? 4\n : (firstByte > 0xDF)\n ? 3\n : (firstByte > 0xBF)\n ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = ''\n var i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += hexSliceLookupTable[buf[i]]\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (var i = 0; i < bytes.length - 1; i += 2) {\n res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype)\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUintLE =\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUintBE =\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUint8 =\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUint16LE =\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUint16BE =\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUint32LE =\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUint32BE =\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var i = byteLength\n var mul = 1\n var val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUintLE =\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUintBE =\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUint8 =\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUint16LE =\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUint16BE =\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUint32LE =\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUint32BE =\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end)\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, end),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if ((encoding === 'utf8' && code < 128) ||\n encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n } else if (typeof val === 'boolean') {\n val = Number(val)\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : Buffer.from(val, encoding)\n var len = bytes.length\n if (len === 0) {\n throw new TypeError('The value \"' + val +\n '\" is invalid for argument \"value\"')\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0]\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n var c, hi, lo\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance (obj, type) {\n return obj instanceof type ||\n (obj != null && obj.constructor != null && obj.constructor.name != null &&\n obj.constructor.name === type.name)\n}\nfunction numberIsNaN (obj) {\n // For IE11 support\n return obj !== obj // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nvar hexSliceLookupTable = (function () {\n var alphabet = '0123456789abcdef'\n var table = new Array(256)\n for (var i = 0; i < 16; ++i) {\n var i16 = i * 16\n for (var j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j]\n }\n }\n return table\n})()\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","const Rabin = require('./rabin')\nconst getRabin = require('../dist/rabin-wasm.node.js')\n\nconst create = async (avg, min, max, windowSize, polynomial) => {\n const compiled = await getRabin()\n return new Rabin(compiled, avg, min, max, windowSize, polynomial)\n}\n\nmodule.exports = {\n Rabin,\n create\n}\n","/**\n * Rabin fingerprinting\n *\n * @class Rabin\n */\nclass Rabin {\n /**\n * Creates an instance of Rabin.\n * @param { import(\"./../dist/rabin-wasm\") } asModule\n * @param {number} [bits=12]\n * @param {number} [min=8 * 1024]\n * @param {number} [max=32 * 1024]\n * @param {number} polynomial\n * @memberof Rabin\n */\n constructor(asModule, bits = 12, min = 8 * 1024, max = 32 * 1024, windowSize = 64, polynomial) {\n this.bits = bits\n this.min = min\n this.max = max\n this.asModule = asModule\n this.rabin = new asModule.Rabin(bits, min, max, windowSize, polynomial)\n this.polynomial = polynomial\n }\n\n /**\n * Fingerprints the buffer\n *\n * @param {Uint8Array} buf\n * @returns {Array<number>}\n * @memberof Rabin\n */\n fingerprint(buf) {\n const {\n __retain,\n __release,\n __allocArray,\n __getInt32Array,\n Int32Array_ID,\n Uint8Array_ID\n } = this.asModule\n\n const lengths = new Int32Array(Math.ceil(buf.length/this.min))\n const lengthsPtr = __retain(__allocArray(Int32Array_ID, lengths))\n const pointer = __retain(__allocArray(Uint8Array_ID, buf))\n\n const out = this.rabin.fingerprint(pointer, lengthsPtr)\n const processed = __getInt32Array(out)\n\n __release(pointer)\n __release(lengthsPtr)\n\n const end = processed.indexOf(0);\n return end >= 0 ? processed.subarray(0, end) : processed;\n }\n}\n\nmodule.exports = Rabin","\nconst { instantiate } = require(\"@assemblyscript/loader\");\n\nloadWebAssembly.supported = typeof WebAssembly !== 'undefined'\n\nfunction loadWebAssembly (imp = {}) {\n if (!loadWebAssembly.supported) return null\n \n var wasm = new Uint8Array([0,97,115,109,1,0,0,0,1,78,14,96,2,127,126,0,96,1,127,1,126,96,2,127,127,0,96,1,127,1,127,96,1,127,0,96,2,127,127,1,127,96,3,127,127,127,1,127,96,0,0,96,3,127,127,127,0,96,0,1,127,96,4,127,127,127,127,0,96,5,127,127,127,127,127,1,127,96,1,126,1,127,96,2,126,126,1,126,2,13,1,3,101,110,118,5,97,98,111,114,116,0,10,3,54,53,2,2,8,9,3,5,2,8,6,5,3,4,2,6,9,12,13,2,5,11,3,2,3,2,3,2,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,6,7,7,4,4,5,3,1,0,1,6,47,9,127,1,65,0,11,127,1,65,0,11,127,0,65,3,11,127,0,65,4,11,127,1,65,0,11,127,1,65,0,11,127,1,65,0,11,127,0,65,240,2,11,127,0,65,6,11,7,240,5,41,6,109,101,109,111,114,121,2,0,7,95,95,97,108,108,111,99,0,10,8,95,95,114,101,116,97,105,110,0,11,9,95,95,114,101,108,101,97,115,101,0,12,9,95,95,99,111,108,108,101,99,116,0,51,11,95,95,114,116,116,105,95,98,97,115,101,3,7,13,73,110,116,51,50,65,114,114,97,121,95,73,68,3,2,13,85,105,110,116,56,65,114,114,97,121,95,73,68,3,3,6,100,101,103,114,101,101,0,16,3,109,111,100,0,17,5,82,97,98,105,110,3,8,16,82,97,98,105,110,35,103,101,116,58,119,105,110,100,111,119,0,21,16,82,97,98,105,110,35,115,101,116,58,119,105,110,100,111,119,0,22,21,82,97,98,105,110,35,103,101,116,58,119,105,110,100,111,119,95,115,105,122,101,0,23,21,82,97,98,105,110,35,115,101,116,58,119,105,110,100,111,119,95,115,105,122,101,0,24,14,82,97,98,105,110,35,103,101,116,58,119,112,111,115,0,25,14,82,97,98,105,110,35,115,101,116,58,119,112,111,115,0,26,15,82,97,98,105,110,35,103,101,116,58,99,111,117,110,116,0,27,15,82,97,98,105,110,35,115,101,116,58,99,111,117,110,116,0,28,13,82,97,98,105,110,35,103,101,116,58,112,111,115,0,29,13,82,97,98,105,110,35,115,101,116,58,112,111,115,0,30,15,82,97,98,105,110,35,103,101,116,58,115,116,97,114,116,0,31,15,82,97,98,105,110,35,115,101,116,58,115,116,97,114,116,0,32,16,82,97,98,105,110,35,103,101,116,58,100,105,103,101,115,116,0,33,16,82,97,98,105,110,35,115,101,116,58,100,105,103,101,115,116,0,34,21,82,97,98,105,110,35,103,101,116,58,99,104,117,110,107,95,115,116,97,114,116,0,35,21,82,97,98,105,110,35,115,101,116,58,99,104,117,110,107,95,115,116,97,114,116,0,36,22,82,97,98,105,110,35,103,101,116,58,99,104,117,110,107,95,108,101,110,103,116,104,0,37,22,82,97,98,105,110,35,115,101,116,58,99,104,117,110,107,95,108,101,110,103,116,104,0,38,31,82,97,98,105,110,35,103,101,116,58,99,104,117,110,107,95,99,117,116,95,102,105,110,103,101,114,112,114,105,110,116,0,39,31,82,97,98,105,110,35,115,101,116,58,99,104,117,110,107,95,99,117,116,95,102,105,110,103,101,114,112,114,105,110,116,0,40,20,82,97,98,105,110,35,103,101,116,58,112,111,108,121,110,111,109,105,97,108,0,41,20,82,97,98,105,110,35,115,101,116,58,112,111,108,121,110,111,109,105,97,108,0,42,17,82,97,98,105,110,35,103,101,116,58,109,105,110,115,105,122,101,0,43,17,82,97,98,105,110,35,115,101,116,58,109,105,110,115,105,122,101,0,44,17,82,97,98,105,110,35,103,101,116,58,109,97,120,115,105,122,101,0,45,17,82,97,98,105,110,35,115,101,116,58,109,97,120,115,105,122,101,0,46,14,82,97,98,105,110,35,103,101,116,58,109,97,115,107,0,47,14,82,97,98,105,110,35,115,101,116,58,109,97,115,107,0,48,17,82,97,98,105,110,35,99,111,110,115,116,114,117,99,116,111,114,0,20,17,82,97,98,105,110,35,102,105,110,103,101,114,112,114,105,110,116,0,49,8,1,50,10,165,31,53,199,1,1,4,127,32,1,40,2,0,65,124,113,34,2,65,128,2,73,4,127,32,2,65,4,118,33,4,65,0,5,32,2,65,31,32,2,103,107,34,3,65,4,107,118,65,16,115,33,4,32,3,65,7,107,11,33,3,32,1,40,2,20,33,2,32,1,40,2,16,34,5,4,64,32,5,32,2,54,2,20,11,32,2,4,64,32,2,32,5,54,2,16,11,32,1,32,0,32,4,32,3,65,4,116,106,65,2,116,106,40,2,96,70,4,64,32,0,32,4,32,3,65,4,116,106,65,2,116,106,32,2,54,2,96,32,2,69,4,64,32,0,32,3,65,2,116,106,32,0,32,3,65,2,116,106,40,2,4,65,1,32,4,116,65,127,115,113,34,1,54,2,4,32,1,69,4,64,32,0,32,0,40,2,0,65,1,32,3,116,65,127,115,113,54,2,0,11,11,11,11,226,2,1,6,127,32,1,40,2,0,33,3,32,1,65,16,106,32,1,40,2,0,65,124,113,106,34,4,40,2,0,34,5,65,1,113,4,64,32,3,65,124,113,65,16,106,32,5,65,124,113,106,34,2,65,240,255,255,255,3,73,4,64,32,0,32,4,16,1,32,1,32,2,32,3,65,3,113,114,34,3,54,2,0,32,1,65,16,106,32,1,40,2,0,65,124,113,106,34,4,40,2,0,33,5,11,11,32,3,65,2,113,4,64,32,1,65,4,107,40,2,0,34,2,40,2,0,34,6,65,124,113,65,16,106,32,3,65,124,113,106,34,7,65,240,255,255,255,3,73,4,64,32,0,32,2,16,1,32,2,32,7,32,6,65,3,113,114,34,3,54,2,0,32,2,33,1,11,11,32,4,32,5,65,2,114,54,2,0,32,4,65,4,107,32,1,54,2,0,32,0,32,3,65,124,113,34,2,65,128,2,73,4,127,32,2,65,4,118,33,4,65,0,5,32,2,65,31,32,2,103,107,34,2,65,4,107,118,65,16,115,33,4,32,2,65,7,107,11,34,3,65,4,116,32,4,106,65,2,116,106,40,2,96,33,2,32,1,65,0,54,2,16,32,1,32,2,54,2,20,32,2,4,64,32,2,32,1,54,2,16,11,32,0,32,4,32,3,65,4,116,106,65,2,116,106,32,1,54,2,96,32,0,32,0,40,2,0,65,1,32,3,116,114,54,2,0,32,0,32,3,65,2,116,106,32,0,32,3,65,2,116,106,40,2,4,65,1,32,4,116,114,54,2,4,11,119,1,1,127,32,2,2,127,32,0,40,2,160,12,34,2,4,64,32,2,32,1,65,16,107,70,4,64,32,2,40,2,0,33,3,32,1,65,16,107,33,1,11,11,32,1,11,107,34,2,65,48,73,4,64,15,11,32,1,32,3,65,2,113,32,2,65,32,107,65,1,114,114,54,2,0,32,1,65,0,54,2,16,32,1,65,0,54,2,20,32,1,32,2,106,65,16,107,34,2,65,2,54,2,0,32,0,32,2,54,2,160,12,32,0,32,1,16,2,11,155,1,1,3,127,35,0,34,0,69,4,64,65,1,63,0,34,0,74,4,127,65,1,32,0,107,64,0,65,0,72,5,65,0,11,4,64,0,11,65,176,3,34,0,65,0,54,2,0,65,208,15,65,0,54,2,0,3,64,32,1,65,23,73,4,64,32,1,65,2,116,65,176,3,106,65,0,54,2,4,65,0,33,2,3,64,32,2,65,16,73,4,64,32,1,65,4,116,32,2,106,65,2,116,65,176,3,106,65,0,54,2,96,32,2,65,1,106,33,2,12,1,11,11,32,1,65,1,106,33,1,12,1,11,11,65,176,3,65,224,15,63,0,65,16,116,16,3,65,176,3,36,0,11,32,0,11,45,0,32,0,65,240,255,255,255,3,79,4,64,65,32,65,224,0,65,201,3,65,29,16,0,0,11,32,0,65,15,106,65,112,113,34,0,65,16,32,0,65,16,75,27,11,169,1,1,1,127,32,0,32,1,65,128,2,73,4,127,32,1,65,4,118,33,1,65,0,5,32,1,65,248,255,255,255,1,73,4,64,32,1,65,1,65,27,32,1,103,107,116,106,65,1,107,33,1,11,32,1,65,31,32,1,103,107,34,2,65,4,107,118,65,16,115,33,1,32,2,65,7,107,11,34,2,65,2,116,106,40,2,4,65,127,32,1,116,113,34,1,4,127,32,0,32,1,104,32,2,65,4,116,106,65,2,116,106,40,2,96,5,32,0,40,2,0,65,127,32,2,65,1,106,116,113,34,1,4,127,32,0,32,0,32,1,104,34,0,65,2,116,106,40,2,4,104,32,0,65,4,116,106,65,2,116,106,40,2,96,5,65,0,11,11,11,111,1,1,127,63,0,34,2,32,1,65,248,255,255,255,1,73,4,127,32,1,65,1,65,27,32,1,103,107,116,65,1,107,106,5,32,1,11,65,16,32,0,40,2,160,12,32,2,65,16,116,65,16,107,71,116,106,65,255,255,3,106,65,128,128,124,113,65,16,118,34,1,32,2,32,1,74,27,64,0,65,0,72,4,64,32,1,64,0,65,0,72,4,64,0,11,11,32,0,32,2,65,16,116,63,0,65,16,116,16,3,11,113,1,2,127,32,1,40,2,0,34,3,65,124,113,32,2,107,34,4,65,32,79,4,64,32,1,32,2,32,3,65,2,113,114,54,2,0,32,2,32,1,65,16,106,106,34,1,32,4,65,16,107,65,1,114,54,2,0,32,0,32,1,16,2,5,32,1,32,3,65,126,113,54,2,0,32,1,65,16,106,32,1,40,2,0,65,124,113,106,32,1,65,16,106,32,1,40,2,0,65,124,113,106,40,2,0,65,125,113,54,2,0,11,11,91,1,2,127,32,0,32,1,16,5,34,4,16,6,34,3,69,4,64,65,1,36,1,65,0,36,1,32,0,32,4,16,6,34,3,69,4,64,32,0,32,4,16,7,32,0,32,4,16,6,33,3,11,11,32,3,65,0,54,2,4,32,3,32,2,54,2,8,32,3,32,1,54,2,12,32,0,32,3,16,1,32,0,32,3,32,4,16,8,32,3,11,13,0,16,4,32,0,32,1,16,9,65,16,106,11,33,1,1,127,32,0,65,172,3,75,4,64,32,0,65,16,107,34,1,32,1,40,2,4,65,1,106,54,2,4,11,32,0,11,18,0,32,0,65,172,3,75,4,64,32,0,65,16,107,16,52,11,11,140,3,1,1,127,2,64,32,1,69,13,0,32,0,65,0,58,0,0,32,0,32,1,106,65,1,107,65,0,58,0,0,32,1,65,2,77,13,0,32,0,65,1,106,65,0,58,0,0,32,0,65,2,106,65,0,58,0,0,32,0,32,1,106,34,2,65,2,107,65,0,58,0,0,32,2,65,3,107,65,0,58,0,0,32,1,65,6,77,13,0,32,0,65,3,106,65,0,58,0,0,32,0,32,1,106,65,4,107,65,0,58,0,0,32,1,65,8,77,13,0,32,1,65,0,32,0,107,65,3,113,34,1,107,33,2,32,0,32,1,106,34,0,65,0,54,2,0,32,0,32,2,65,124,113,34,1,106,65,4,107,65,0,54,2,0,32,1,65,8,77,13,0,32,0,65,4,106,65,0,54,2,0,32,0,65,8,106,65,0,54,2,0,32,0,32,1,106,34,2,65,12,107,65,0,54,2,0,32,2,65,8,107,65,0,54,2,0,32,1,65,24,77,13,0,32,0,65,12,106,65,0,54,2,0,32,0,65,16,106,65,0,54,2,0,32,0,65,20,106,65,0,54,2,0,32,0,65,24,106,65,0,54,2,0,32,0,32,1,106,34,2,65,28,107,65,0,54,2,0,32,2,65,24,107,65,0,54,2,0,32,2,65,20,107,65,0,54,2,0,32,2,65,16,107,65,0,54,2,0,32,0,32,0,65,4,113,65,24,106,34,2,106,33,0,32,1,32,2,107,33,1,3,64,32,1,65,32,79,4,64,32,0,66,0,55,3,0,32,0,65,8,106,66,0,55,3,0,32,0,65,16,106,66,0,55,3,0,32,0,65,24,106,66,0,55,3,0,32,1,65,32,107,33,1,32,0,65,32,106,33,0,12,1,11,11,11,11,178,1,1,3,127,32,1,65,240,255,255,255,3,32,2,118,75,4,64,65,144,1,65,192,1,65,23,65,56,16,0,0,11,32,1,32,2,116,34,3,65,0,16,10,34,2,32,3,16,13,32,0,69,4,64,65,12,65,2,16,10,34,0,65,172,3,75,4,64,32,0,65,16,107,34,1,32,1,40,2,4,65,1,106,54,2,4,11,11,32,0,65,0,54,2,0,32,0,65,0,54,2,4,32,0,65,0,54,2,8,32,2,34,1,32,0,40,2,0,34,4,71,4,64,32,1,65,172,3,75,4,64,32,1,65,16,107,34,5,32,5,40,2,4,65,1,106,54,2,4,11,32,4,16,12,11,32,0,32,1,54,2,0,32,0,32,2,54,2,4,32,0,32,3,54,2,8,32,0,11,46,1,2,127,65,12,65,5,16,10,34,0,65,172,3,75,4,64,32,0,65,16,107,34,1,32,1,40,2,4,65,1,106,54,2,4,11,32,0,65,128,2,65,3,16,14,11,9,0,65,63,32,0,121,167,107,11,49,1,2,127,65,63,32,1,121,167,107,33,2,3,64,65,63,32,0,121,167,107,32,2,107,34,3,65,0,78,4,64,32,0,32,1,32,3,172,134,133,33,0,12,1,11,11,32,0,11,40,0,32,1,32,0,40,2,8,79,4,64,65,128,2,65,192,2,65,163,1,65,44,16,0,0,11,32,1,32,0,40,2,4,106,65,0,58,0,0,11,38,0,32,1,32,0,40,2,8,79,4,64,65,128,2,65,192,2,65,152,1,65,44,16,0,0,11,32,1,32,0,40,2,4,106,45,0,0,11,254,5,2,1,127,4,126,32,0,69,4,64,65,232,0,65,6,16,10,34,0,65,172,3,75,4,64,32,0,65,16,107,34,5,32,5,40,2,4,65,1,106,54,2,4,11,11,32,0,65,0,54,2,0,32,0,65,0,54,2,4,32,0,65,0,54,2,8,32,0,66,0,55,3,16,32,0,66,0,55,3,24,32,0,66,0,55,3,32,32,0,66,0,55,3,40,32,0,66,0,55,3,48,32,0,66,0,55,3,56,32,0,66,0,55,3,64,32,0,66,0,55,3,72,32,0,66,0,55,3,80,32,0,66,0,55,3,88,32,0,66,0,55,3,96,32,0,32,2,173,55,3,80,32,0,32,3,173,55,3,88,65,12,65,4,16,10,34,2,65,172,3,75,4,64,32,2,65,16,107,34,3,32,3,40,2,4,65,1,106,54,2,4,11,32,2,32,4,65,0,16,14,33,2,32,0,40,2,0,16,12,32,0,32,2,54,2,0,32,0,32,4,54,2,4,32,0,66,1,32,1,173,134,66,1,125,55,3,96,32,0,66,243,130,183,218,216,230,232,30,55,3,72,35,4,69,4,64,65,0,33,2,3,64,32,2,65,128,2,72,4,64,32,2,65,255,1,113,173,33,6,32,0,41,3,72,34,7,33,8,65,63,32,7,121,167,107,33,1,3,64,65,63,32,6,121,167,107,32,1,107,34,3,65,0,78,4,64,32,6,32,8,32,3,172,134,133,33,6,12,1,11,11,65,0,33,4,3,64,32,4,32,0,40,2,4,65,1,107,72,4,64,32,6,66,8,134,33,6,32,0,41,3,72,34,7,33,8,65,63,32,7,121,167,107,33,1,3,64,65,63,32,6,121,167,107,32,1,107,34,3,65,0,78,4,64,32,6,32,8,32,3,172,134,133,33,6,12,1,11,11,32,4,65,1,106,33,4,12,1,11,11,35,6,40,2,4,32,2,65,3,116,106,32,6,55,3,0,32,2,65,1,106,33,2,12,1,11,11,65,63,32,0,41,3,72,121,167,107,172,33,7,65,0,33,2,3,64,32,2,65,128,2,72,4,64,35,5,33,1,32,2,172,32,7,134,34,8,33,6,65,63,32,0,41,3,72,34,9,121,167,107,33,3,3,64,65,63,32,6,121,167,107,32,3,107,34,4,65,0,78,4,64,32,6,32,9,32,4,172,134,133,33,6,12,1,11,11,32,1,40,2,4,32,2,65,3,116,106,32,6,32,8,132,55,3,0,32,2,65,1,106,33,2,12,1,11,11,65,1,36,4,11,32,0,66,0,55,3,24,32,0,66,0,55,3,32,65,0,33,2,3,64,32,2,32,0,40,2,4,72,4,64,32,0,40,2,0,32,2,16,18,32,2,65,1,106,33,2,12,1,11,11,32,0,66,0,55,3,40,32,0,65,0,54,2,8,32,0,66,0,55,3,16,32,0,66,0,55,3,40,32,0,40,2,0,32,0,40,2,8,16,19,33,1,32,0,40,2,8,32,0,40,2,0,40,2,4,106,65,1,58,0,0,32,0,32,0,41,3,40,35,6,40,2,4,32,1,65,3,116,106,41,3,0,133,55,3,40,32,0,32,0,40,2,8,65,1,106,32,0,40,2,4,111,54,2,8,32,0,35,5,40,2,4,32,0,41,3,40,34,6,66,45,136,167,65,3,116,106,41,3,0,32,6,66,8,134,66,1,132,133,55,3,40,32,0,11,38,1,1,127,32,0,40,2,0,34,0,65,172,3,75,4,64,32,0,65,16,107,34,1,32,1,40,2,4,65,1,106,54,2,4,11,32,0,11,55,1,2,127,32,1,32,0,40,2,0,34,2,71,4,64,32,1,65,172,3,75,4,64,32,1,65,16,107,34,3,32,3,40,2,4,65,1,106,54,2,4,11,32,2,16,12,11,32,0,32,1,54,2,0,11,7,0,32,0,40,2,4,11,9,0,32,0,32,1,54,2,4,11,7,0,32,0,40,2,8,11,9,0,32,0,32,1,54,2,8,11,7,0,32,0,41,3,16,11,9,0,32,0,32,1,55,3,16,11,7,0,32,0,41,3,24,11,9,0,32,0,32,1,55,3,24,11,7,0,32,0,41,3,32,11,9,0,32,0,32,1,55,3,32,11,7,0,32,0,41,3,40,11,9,0,32,0,32,1,55,3,40,11,7,0,32,0,41,3,48,11,9,0,32,0,32,1,55,3,48,11,7,0,32,0,41,3,56,11,9,0,32,0,32,1,55,3,56,11,7,0,32,0,41,3,64,11,9,0,32,0,32,1,55,3,64,11,7,0,32,0,41,3,72,11,9,0,32,0,32,1,55,3,72,11,7,0,32,0,41,3,80,11,9,0,32,0,32,1,55,3,80,11,7,0,32,0,41,3,88,11,9,0,32,0,32,1,55,3,88,11,7,0,32,0,41,3,96,11,9,0,32,0,32,1,55,3,96,11,172,4,2,5,127,1,126,32,2,65,172,3,75,4,64,32,2,65,16,107,34,4,32,4,40,2,4,65,1,106,54,2,4,11,32,2,33,4,65,0,33,2,32,1,40,2,8,33,5,32,1,40,2,4,33,6,3,64,2,127,65,0,33,3,3,64,32,3,32,5,72,4,64,32,3,32,6,106,45,0,0,33,1,32,0,40,2,0,32,0,40,2,8,16,19,33,7,32,0,40,2,8,32,0,40,2,0,40,2,4,106,32,1,58,0,0,32,0,32,0,41,3,40,35,6,40,2,4,32,7,65,3,116,106,41,3,0,133,55,3,40,32,0,32,0,40,2,8,65,1,106,32,0,40,2,4,111,54,2,8,32,0,35,5,40,2,4,32,0,41,3,40,34,8,66,45,136,167,65,3,116,106,41,3,0,32,1,173,32,8,66,8,134,132,133,55,3,40,32,0,32,0,41,3,16,66,1,124,55,3,16,32,0,32,0,41,3,24,66,1,124,55,3,24,32,0,41,3,16,32,0,41,3,80,90,4,127,32,0,41,3,40,32,0,41,3,96,131,80,5,65,0,11,4,127,65,1,5,32,0,41,3,16,32,0,41,3,88,90,11,4,64,32,0,32,0,41,3,32,55,3,48,32,0,32,0,41,3,16,55,3,56,32,0,32,0,41,3,40,55,3,64,65,0,33,1,3,64,32,1,32,0,40,2,4,72,4,64,32,0,40,2,0,32,1,16,18,32,1,65,1,106,33,1,12,1,11,11,32,0,66,0,55,3,40,32,0,65,0,54,2,8,32,0,66,0,55,3,16,32,0,66,0,55,3,40,32,0,40,2,0,32,0,40,2,8,16,19,33,1,32,0,40,2,8,32,0,40,2,0,40,2,4,106,65,1,58,0,0,32,0,32,0,41,3,40,35,6,40,2,4,32,1,65,3,116,106,41,3,0,133,55,3,40,32,0,32,0,40,2,8,65,1,106,32,0,40,2,4,111,54,2,8,32,0,35,5,40,2,4,32,0,41,3,40,34,8,66,45,136,167,65,3,116,106,41,3,0,32,8,66,8,134,66,1,132,133,55,3,40,32,3,65,1,106,12,3,11,32,3,65,1,106,33,3,12,1,11,11,65,127,11,34,1,65,0,78,4,64,32,5,32,1,107,33,5,32,1,32,6,106,33,6,32,2,34,1,65,1,106,33,2,32,4,40,2,4,32,1,65,2,116,106,32,0,41,3,56,62,2,0,12,1,11,11,32,4,11,10,0,16,15,36,5,16,15,36,6,11,3,0,1,11,73,1,2,127,32,0,40,2,4,34,1,65,255,255,255,255,0,113,34,2,65,1,70,4,64,32,0,65,16,106,16,53,32,0,32,0,40,2,0,65,1,114,54,2,0,35,0,32,0,16,2,5,32,0,32,2,65,1,107,32,1,65,128,128,128,128,127,113,114,54,2,4,11,11,58,0,2,64,2,64,2,64,32,0,65,8,107,40,2,0,14,7,0,0,1,1,1,1,1,2,11,15,11,32,0,40,2,0,34,0,4,64,32,0,65,172,3,79,4,64,32,0,65,16,107,16,52,11,11,15,11,0,11,11,137,3,7,0,65,16,11,55,40,0,0,0,1,0,0,0,1,0,0,0,40,0,0,0,97,0,108,0,108,0,111,0,99,0,97,0,116,0,105,0,111,0,110,0,32,0,116,0,111,0,111,0,32,0,108,0,97,0,114,0,103,0,101,0,65,208,0,11,45,30,0,0,0,1,0,0,0,1,0,0,0,30,0,0,0,126,0,108,0,105,0,98,0,47,0,114,0,116,0,47,0,116,0,108,0,115,0,102,0,46,0,116,0,115,0,65,128,1,11,43,28,0,0,0,1,0,0,0,1,0,0,0,28,0,0,0,73,0,110,0,118,0,97,0,108,0,105,0,100,0,32,0,108,0,101,0,110,0,103,0,116,0,104,0,65,176,1,11,53,38,0,0,0,1,0,0,0,1,0,0,0,38,0,0,0,126,0,108,0,105,0,98,0,47,0,97,0,114,0,114,0,97,0,121,0,98,0,117,0,102,0,102,0,101,0,114,0,46,0,116,0,115,0,65,240,1,11,51,36,0,0,0,1,0,0,0,1,0,0,0,36,0,0,0,73,0,110,0,100,0,101,0,120,0,32,0,111,0,117,0,116,0,32,0,111,0,102,0,32,0,114,0,97,0,110,0,103,0,101,0,65,176,2,11,51,36,0,0,0,1,0,0,0,1,0,0,0,36,0,0,0,126,0,108,0,105,0,98,0,47,0,116,0,121,0,112,0,101,0,100,0,97,0,114,0,114,0,97,0,121,0,46,0,116,0,115,0,65,240,2,11,53,7,0,0,0,16,0,0,0,0,0,0,0,16,0,0,0,0,0,0,0,16,0,0,0,0,0,0,0,145,4,0,0,2,0,0,0,49,0,0,0,2,0,0,0,17,1,0,0,2,0,0,0,16,0,34,16,115,111,117,114,99,101,77,97,112,112,105,110,103,85,82,76,16,46,47,114,97,98,105,110,46,119,97,115,109,46,109,97,112])\n // make it work async because browsers throw when a wasm module is bigger than 4kb and load sync\n return instantiate(new Response(new Blob([wasm], {type: 'application/wasm'})), imp)\n}\nmodule.exports = loadWebAssembly\n","\"use strict\";\n\n// Runtime header offsets\nconst ID_OFFSET = -8;\nconst SIZE_OFFSET = -4;\n\n// Runtime ids\nconst ARRAYBUFFER_ID = 0;\nconst STRING_ID = 1;\nconst ARRAYBUFFERVIEW_ID = 2;\n\n// Runtime type information\nconst ARRAYBUFFERVIEW = 1 << 0;\nconst ARRAY = 1 << 1;\nconst SET = 1 << 2;\nconst MAP = 1 << 3;\nconst VAL_ALIGN_OFFSET = 5;\nconst VAL_ALIGN = 1 << VAL_ALIGN_OFFSET;\nconst VAL_SIGNED = 1 << 10;\nconst VAL_FLOAT = 1 << 11;\nconst VAL_NULLABLE = 1 << 12;\nconst VAL_MANAGED = 1 << 13;\nconst KEY_ALIGN_OFFSET = 14;\nconst KEY_ALIGN = 1 << KEY_ALIGN_OFFSET;\nconst KEY_SIGNED = 1 << 19;\nconst KEY_FLOAT = 1 << 20;\nconst KEY_NULLABLE = 1 << 21;\nconst KEY_MANAGED = 1 << 22;\n\n// Array(BufferView) layout\nconst ARRAYBUFFERVIEW_BUFFER_OFFSET = 0;\nconst ARRAYBUFFERVIEW_DATASTART_OFFSET = 4;\nconst ARRAYBUFFERVIEW_DATALENGTH_OFFSET = 8;\nconst ARRAYBUFFERVIEW_SIZE = 12;\nconst ARRAY_LENGTH_OFFSET = 12;\nconst ARRAY_SIZE = 16;\n\nconst BIGINT = typeof BigUint64Array !== \"undefined\";\nconst THIS = Symbol();\nconst CHUNKSIZE = 1024;\n\n/** Gets a string from an U32 and an U16 view on a memory. */\nfunction getStringImpl(buffer, ptr) {\n const U32 = new Uint32Array(buffer);\n const U16 = new Uint16Array(buffer);\n var length = U32[(ptr + SIZE_OFFSET) >>> 2] >>> 1;\n var offset = ptr >>> 1;\n if (length <= CHUNKSIZE) return String.fromCharCode.apply(String, U16.subarray(offset, offset + length));\n const parts = [];\n do {\n const last = U16[offset + CHUNKSIZE - 1];\n const size = last >= 0xD800 && last < 0xDC00 ? CHUNKSIZE - 1 : CHUNKSIZE;\n parts.push(String.fromCharCode.apply(String, U16.subarray(offset, offset += size)));\n length -= size;\n } while (length > CHUNKSIZE);\n return parts.join(\"\") + String.fromCharCode.apply(String, U16.subarray(offset, offset + length));\n}\n\n/** Prepares the base module prior to instantiation. */\nfunction preInstantiate(imports) {\n const baseModule = {};\n\n function getString(memory, ptr) {\n if (!memory) return \"<yet unknown>\";\n return getStringImpl(memory.buffer, ptr);\n }\n\n // add common imports used by stdlib for convenience\n const env = (imports.env = imports.env || {});\n env.abort = env.abort || function abort(mesg, file, line, colm) {\n const memory = baseModule.memory || env.memory; // prefer exported, otherwise try imported\n throw Error(\"abort: \" + getString(memory, mesg) + \" at \" + getString(memory, file) + \":\" + line + \":\" + colm);\n }\n env.trace = env.trace || function trace(mesg, n) {\n const memory = baseModule.memory || env.memory;\n console.log(\"trace: \" + getString(memory, mesg) + (n ? \" \" : \"\") + Array.prototype.slice.call(arguments, 2, 2 + n).join(\", \"));\n }\n imports.Math = imports.Math || Math;\n imports.Date = imports.Date || Date;\n\n return baseModule;\n}\n\n/** Prepares the final module once instantiation is complete. */\nfunction postInstantiate(baseModule, instance) {\n const rawExports = instance.exports;\n const memory = rawExports.memory;\n const table = rawExports.table;\n const alloc = rawExports[\"__alloc\"];\n const retain = rawExports[\"__retain\"];\n const rttiBase = rawExports[\"__rtti_base\"] || ~0; // oob if not present\n\n /** Gets the runtime type info for the given id. */\n function getInfo(id) {\n const U32 = new Uint32Array(memory.buffer);\n const count = U32[rttiBase >>> 2];\n if ((id >>>= 0) >= count) throw Error(\"invalid id: \" + id);\n return U32[(rttiBase + 4 >>> 2) + id * 2];\n }\n\n /** Gets the runtime base id for the given id. */\n function getBase(id) {\n const U32 = new Uint32Array(memory.buffer);\n const count = U32[rttiBase >>> 2];\n if ((id >>>= 0) >= count) throw Error(\"invalid id: \" + id);\n return U32[(rttiBase + 4 >>> 2) + id * 2 + 1];\n }\n\n /** Gets the runtime alignment of a collection's values. */\n function getValueAlign(info) {\n return 31 - Math.clz32((info >>> VAL_ALIGN_OFFSET) & 31); // -1 if none\n }\n\n /** Gets the runtime alignment of a collection's keys. */\n function getKeyAlign(info) {\n return 31 - Math.clz32((info >>> KEY_ALIGN_OFFSET) & 31); // -1 if none\n }\n\n /** Allocates a new string in the module's memory and returns its retained pointer. */\n function __allocString(str) {\n const length = str.length;\n const ptr = alloc(length << 1, STRING_ID);\n const U16 = new Uint16Array(memory.buffer);\n for (var i = 0, p = ptr >>> 1; i < length; ++i) U16[p + i] = str.charCodeAt(i);\n return ptr;\n }\n\n baseModule.__allocString = __allocString;\n\n /** Reads a string from the module's memory by its pointer. */\n function __getString(ptr) {\n const buffer = memory.buffer;\n const id = new Uint32Array(buffer)[ptr + ID_OFFSET >>> 2];\n if (id !== STRING_ID) throw Error(\"not a string: \" + ptr);\n return getStringImpl(buffer, ptr);\n }\n\n baseModule.__getString = __getString;\n\n /** Gets the view matching the specified alignment, signedness and floatness. */\n function getView(alignLog2, signed, float) {\n const buffer = memory.buffer;\n if (float) {\n switch (alignLog2) {\n case 2: return new Float32Array(buffer);\n case 3: return new Float64Array(buffer);\n }\n } else {\n switch (alignLog2) {\n case 0: return new (signed ? Int8Array : Uint8Array)(buffer);\n case 1: return new (signed ? Int16Array : Uint16Array)(buffer);\n case 2: return new (signed ? Int32Array : Uint32Array)(buffer);\n case 3: return new (signed ? BigInt64Array : BigUint64Array)(buffer);\n }\n }\n throw Error(\"unsupported align: \" + alignLog2);\n }\n\n /** Allocates a new array in the module's memory and returns its retained pointer. */\n function __allocArray(id, values) {\n const info = getInfo(id);\n if (!(info & (ARRAYBUFFERVIEW | ARRAY))) throw Error(\"not an array: \" + id + \" @ \" + info);\n const align = getValueAlign(info);\n const length = values.length;\n const buf = alloc(length << align, ARRAYBUFFER_ID);\n const arr = alloc(info & ARRAY ? ARRAY_SIZE : ARRAYBUFFERVIEW_SIZE, id);\n const U32 = new Uint32Array(memory.buffer);\n U32[arr + ARRAYBUFFERVIEW_BUFFER_OFFSET >>> 2] = retain(buf);\n U32[arr + ARRAYBUFFERVIEW_DATASTART_OFFSET >>> 2] = buf;\n U32[arr + ARRAYBUFFERVIEW_DATALENGTH_OFFSET >>> 2] = length << align;\n if (info & ARRAY) U32[arr + ARRAY_LENGTH_OFFSET >>> 2] = length;\n const view = getView(align, info & VAL_SIGNED, info & VAL_FLOAT);\n if (info & VAL_MANAGED) {\n for (let i = 0; i < length; ++i) view[(buf >>> align) + i] = retain(values[i]);\n } else {\n view.set(values, buf >>> align);\n }\n return arr;\n }\n\n baseModule.__allocArray = __allocArray;\n\n /** Gets a live view on an array's values in the module's memory. Infers the array type from RTTI. */\n function __getArrayView(arr) {\n const U32 = new Uint32Array(memory.buffer);\n const id = U32[arr + ID_OFFSET >>> 2];\n const info = getInfo(id);\n if (!(info & ARRAYBUFFERVIEW)) throw Error(\"not an array: \" + id);\n const align = getValueAlign(info);\n var buf = U32[arr + ARRAYBUFFERVIEW_DATASTART_OFFSET >>> 2];\n const length = info & ARRAY\n ? U32[arr + ARRAY_LENGTH_OFFSET >>> 2]\n : U32[buf + SIZE_OFFSET >>> 2] >>> align;\n return getView(align, info & VAL_SIGNED, info & VAL_FLOAT)\n .subarray(buf >>>= align, buf + length);\n }\n\n baseModule.__getArrayView = __getArrayView;\n\n /** Copies an array's values from the module's memory. Infers the array type from RTTI. */\n function __getArray(arr) {\n const input = __getArrayView(arr);\n const len = input.length;\n const out = new Array(len);\n for (let i = 0; i < len; i++) out[i] = input[i];\n return out;\n }\n\n baseModule.__getArray = __getArray;\n\n /** Copies an ArrayBuffer's value from the module's memory. */\n function __getArrayBuffer(ptr) {\n const buffer = memory.buffer;\n const length = new Uint32Array(buffer)[ptr + SIZE_OFFSET >>> 2];\n return buffer.slice(ptr, ptr + length);\n }\n\n baseModule.__getArrayBuffer = __getArrayBuffer;\n\n /** Copies a typed array's values from the module's memory. */\n function getTypedArray(Type, alignLog2, ptr) {\n return new Type(getTypedArrayView(Type, alignLog2, ptr));\n }\n\n /** Gets a live view on a typed array's values in the module's memory. */\n function getTypedArrayView(Type, alignLog2, ptr) {\n const buffer = memory.buffer;\n const U32 = new Uint32Array(buffer);\n const bufPtr = U32[ptr + ARRAYBUFFERVIEW_DATASTART_OFFSET >>> 2];\n return new Type(buffer, bufPtr, U32[bufPtr + SIZE_OFFSET >>> 2] >>> alignLog2);\n }\n\n baseModule.__getInt8Array = getTypedArray.bind(null, Int8Array, 0);\n baseModule.__getInt8ArrayView = getTypedArrayView.bind(null, Int8Array, 0);\n baseModule.__getUint8Array = getTypedArray.bind(null, Uint8Array, 0);\n baseModule.__getUint8ArrayView = getTypedArrayView.bind(null, Uint8Array, 0);\n baseModule.__getUint8ClampedArray = getTypedArray.bind(null, Uint8ClampedArray, 0);\n baseModule.__getUint8ClampedArrayView = getTypedArrayView.bind(null, Uint8ClampedArray, 0);\n baseModule.__getInt16Array = getTypedArray.bind(null, Int16Array, 1);\n baseModule.__getInt16ArrayView = getTypedArrayView.bind(null, Int16Array, 1);\n baseModule.__getUint16Array = getTypedArray.bind(null, Uint16Array, 1);\n baseModule.__getUint16ArrayView = getTypedArrayView.bind(null, Uint16Array, 1);\n baseModule.__getInt32Array = getTypedArray.bind(null, Int32Array, 2);\n baseModule.__getInt32ArrayView = getTypedArrayView.bind(null, Int32Array, 2);\n baseModule.__getUint32Array = getTypedArray.bind(null, Uint32Array, 2);\n baseModule.__getUint32ArrayView = getTypedArrayView.bind(null, Uint32Array, 2);\n if (BIGINT) {\n baseModule.__getInt64Array = getTypedArray.bind(null, BigInt64Array, 3);\n baseModule.__getInt64ArrayView = getTypedArrayView.bind(null, BigInt64Array, 3);\n baseModule.__getUint64Array = getTypedArray.bind(null, BigUint64Array, 3);\n baseModule.__getUint64ArrayView = getTypedArrayView.bind(null, BigUint64Array, 3);\n }\n baseModule.__getFloat32Array = getTypedArray.bind(null, Float32Array, 2);\n baseModule.__getFloat32ArrayView = getTypedArrayView.bind(null, Float32Array, 2);\n baseModule.__getFloat64Array = getTypedArray.bind(null, Float64Array, 3);\n baseModule.__getFloat64ArrayView = getTypedArrayView.bind(null, Float64Array, 3);\n\n /** Tests whether an object is an instance of the class represented by the specified base id. */\n function __instanceof(ptr, baseId) {\n const U32 = new Uint32Array(memory.buffer);\n var id = U32[(ptr + ID_OFFSET) >>> 2];\n if (id <= U32[rttiBase >>> 2]) {\n do if (id == baseId) return true;\n while (id = getBase(id));\n }\n return false;\n }\n\n baseModule.__instanceof = __instanceof;\n\n // Pull basic exports to baseModule so code in preInstantiate can use them\n baseModule.memory = baseModule.memory || memory;\n baseModule.table = baseModule.table || table;\n\n // Demangle exports and provide the usual utility on the prototype\n return demangle(rawExports, baseModule);\n}\n\nfunction isResponse(o) {\n return typeof Response !== \"undefined\" && o instanceof Response;\n}\n\n/** Asynchronously instantiates an AssemblyScript module from anything that can be instantiated. */\nasync function instantiate(source, imports) {\n if (isResponse(source = await source)) return instantiateStreaming(source, imports);\n return postInstantiate(\n preInstantiate(imports || (imports = {})),\n await WebAssembly.instantiate(\n source instanceof WebAssembly.Module\n ? source\n : await WebAssembly.compile(source),\n imports\n )\n );\n}\n\nexports.instantiate = instantiate;\n\n/** Synchronously instantiates an AssemblyScript module from a WebAssembly.Module or binary buffer. */\nfunction instantiateSync(source, imports) {\n return postInstantiate(\n preInstantiate(imports || (imports = {})),\n new WebAssembly.Instance(\n source instanceof WebAssembly.Module\n ? source\n : new WebAssembly.Module(source),\n imports\n )\n )\n}\n\nexports.instantiateSync = instantiateSync;\n\n/** Asynchronously instantiates an AssemblyScript module from a response, i.e. as obtained by `fetch`. */\nasync function instantiateStreaming(source, imports) {\n if (!WebAssembly.instantiateStreaming) {\n return instantiate(\n isResponse(source = await source)\n ? source.arrayBuffer()\n : source,\n imports\n );\n }\n return postInstantiate(\n preInstantiate(imports || (imports = {})),\n (await WebAssembly.instantiateStreaming(source, imports)).instance\n );\n}\n\nexports.instantiateStreaming = instantiateStreaming;\n\n/** Demangles an AssemblyScript module's exports to a friendly object structure. */\nfunction demangle(exports, baseModule) {\n var module = baseModule ? Object.create(baseModule) : {};\n var setArgumentsLength = exports[\"__argumentsLength\"]\n ? function(length) { exports[\"__argumentsLength\"].value = length; }\n : exports[\"__setArgumentsLength\"] || exports[\"__setargc\"] || function() {};\n for (let internalName in exports) {\n if (!Object.prototype.hasOwnProperty.call(exports, internalName)) continue;\n const elem = exports[internalName];\n let parts = internalName.split(\".\");\n let curr = module;\n while (parts.length > 1) {\n let part = parts.shift();\n if (!Object.prototype.hasOwnProperty.call(curr, part)) curr[part] = {};\n curr = curr[part];\n }\n let name = parts[0];\n let hash = name.indexOf(\"#\");\n if (hash >= 0) {\n let className = name.substring(0, hash);\n let classElem = curr[className];\n if (typeof classElem === \"undefined\" || !classElem.prototype) {\n let ctor = function(...args) {\n return ctor.wrap(ctor.prototype.constructor(0, ...args));\n };\n ctor.prototype = {\n valueOf: function valueOf() {\n return this[THIS];\n }\n };\n ctor.wrap = function(thisValue) {\n return Object.create(ctor.prototype, { [THIS]: { value: thisValue, writable: false } });\n };\n if (classElem) Object.getOwnPropertyNames(classElem).forEach(name =>\n Object.defineProperty(ctor, name, Object.getOwnPropertyDescriptor(classElem, name))\n );\n curr[className] = ctor;\n }\n name = name.substring(hash + 1);\n curr = curr[className].prototype;\n if (/^(get|set):/.test(name)) {\n if (!Object.prototype.hasOwnProperty.call(curr, name = name.substring(4))) {\n let getter = exports[internalName.replace(\"set:\", \"get:\")];\n let setter = exports[internalName.replace(\"get:\", \"set:\")];\n Object.defineProperty(curr, name, {\n get: function() { return getter(this[THIS]); },\n set: function(value) { setter(this[THIS], value); },\n enumerable: true\n });\n }\n } else {\n if (name === 'constructor') {\n (curr[name] = (...args) => {\n setArgumentsLength(args.length);\n return elem(...args);\n }).original = elem;\n } else { // instance method\n (curr[name] = function(...args) { // !\n setArgumentsLength(args.length);\n return elem(this[THIS], ...args);\n }).original = elem;\n }\n }\n } else {\n if (/^(get|set):/.test(name)) {\n if (!Object.prototype.hasOwnProperty.call(curr, name = name.substring(4))) {\n Object.defineProperty(curr, name, {\n get: exports[internalName.replace(\"set:\", \"get:\")],\n set: exports[internalName.replace(\"get:\", \"set:\")],\n enumerable: true\n });\n }\n } else if (typeof elem === \"function\" && elem !== setArgumentsLength) {\n (curr[name] = (...args) => {\n setArgumentsLength(args.length);\n return elem(...args);\n }).original = elem;\n } else {\n curr[name] = elem;\n }\n }\n }\n return module;\n}\n\nexports.demangle = demangle;\n","'use strict';\n\nvar BufferList = require('bl/BufferList.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar BufferList__default = /*#__PURE__*/_interopDefaultLegacy(BufferList);\n\nasync function* fixedSizeChunker(source, options) {\n let bl = new BufferList__default['default']();\n let currentLength = 0;\n let emitted = false;\n const maxChunkSize = options.maxChunkSize;\n for await (const buffer of source) {\n bl.append(buffer);\n currentLength += buffer.length;\n while (currentLength >= maxChunkSize) {\n yield bl.slice(0, maxChunkSize);\n emitted = true;\n if (maxChunkSize === bl.length) {\n bl = new BufferList__default['default']();\n currentLength = 0;\n } else {\n const newBl = new BufferList__default['default']();\n newBl.append(bl.shallowSlice(maxChunkSize));\n bl = newBl;\n currentLength -= maxChunkSize;\n }\n }\n }\n if (!emitted || currentLength) {\n yield bl.slice(0, currentLength);\n }\n}\n\nmodule.exports = fixedSizeChunker;\n","'use strict';\n\nvar errCode = require('err-code');\nvar fromString = require('uint8arrays/from-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nasync function* validateChunks(source) {\n for await (const content of source) {\n if (content.length === undefined) {\n throw errCode__default['default'](new Error('Content was invalid'), 'ERR_INVALID_CONTENT');\n }\n if (typeof content === 'string' || content instanceof String) {\n yield fromString.fromString(content.toString());\n } else if (Array.isArray(content)) {\n yield Uint8Array.from(content);\n } else if (content instanceof Uint8Array) {\n yield content;\n } else {\n throw errCode__default['default'](new Error('Content was invalid'), 'ERR_INVALID_CONTENT');\n }\n }\n}\n\nmodule.exports = validateChunks;\n","'use strict';\n\nvar dirFlat = require('./dir-flat.js');\nvar flatToShard = require('./flat-to-shard.js');\nvar dir = require('./dir.js');\nvar toPathComponents = require('./utils/to-path-components.js');\n\nasync function addToTree(elem, tree, options) {\n const pathElems = toPathComponents(elem.path || '');\n const lastIndex = pathElems.length - 1;\n let parent = tree;\n let currentPath = '';\n for (let i = 0; i < pathElems.length; i++) {\n const pathElem = pathElems[i];\n currentPath += `${ currentPath ? '/' : '' }${ pathElem }`;\n const last = i === lastIndex;\n parent.dirty = true;\n parent.cid = undefined;\n parent.size = undefined;\n if (last) {\n await parent.put(pathElem, elem);\n tree = await flatToShard(null, parent, options.shardSplitThreshold, options);\n } else {\n let dir$1 = await parent.get(pathElem);\n if (!dir$1 || !(dir$1 instanceof dir)) {\n dir$1 = new dirFlat({\n root: false,\n dir: true,\n parent: parent,\n parentKey: pathElem,\n path: currentPath,\n dirty: true,\n flat: true,\n mtime: dir$1 && dir$1.unixfs && dir$1.unixfs.mtime,\n mode: dir$1 && dir$1.unixfs && dir$1.unixfs.mode\n }, options);\n }\n await parent.put(pathElem, dir$1);\n parent = dir$1;\n }\n }\n return tree;\n}\nasync function* flushAndYield(tree, blockstore) {\n if (!(tree instanceof dir)) {\n if (tree && tree.unixfs && tree.unixfs.isDirectory()) {\n yield tree;\n }\n return;\n }\n yield* tree.flush(blockstore);\n}\nasync function* treeBuilder(source, block, options) {\n let tree = new dirFlat({\n root: true,\n dir: true,\n path: '',\n dirty: true,\n flat: true\n }, options);\n for await (const entry of source) {\n if (!entry) {\n continue;\n }\n tree = await addToTree(entry, tree, options);\n if (!entry.unixfs || !entry.unixfs.isDirectory()) {\n yield entry;\n }\n }\n if (options.wrapWithDirectory) {\n yield* flushAndYield(tree, block);\n } else {\n for await (const unwrapped of tree.eachChildSeries()) {\n if (!unwrapped) {\n continue;\n }\n yield* flushAndYield(unwrapped.child, block);\n }\n }\n}\n\nmodule.exports = treeBuilder;\n","'use strict';\n\nvar dagPb = require('@ipld/dag-pb');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dir = require('./dir.js');\nvar persist = require('./utils/persist.js');\n\nclass DirFlat extends dir {\n constructor(props, options) {\n super(props, options);\n this._children = {};\n }\n async put(name, value) {\n this.cid = undefined;\n this.size = undefined;\n this._children[name] = value;\n }\n get(name) {\n return Promise.resolve(this._children[name]);\n }\n childCount() {\n return Object.keys(this._children).length;\n }\n directChildrenCount() {\n return this.childCount();\n }\n onlyChild() {\n return this._children[Object.keys(this._children)[0]];\n }\n async *eachChildSeries() {\n const keys = Object.keys(this._children);\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n yield {\n key: key,\n child: this._children[key]\n };\n }\n }\n async *flush(block) {\n const children = Object.keys(this._children);\n const links = [];\n for (let i = 0; i < children.length; i++) {\n let child = this._children[children[i]];\n if (child instanceof dir) {\n for await (const entry of child.flush(block)) {\n child = entry;\n yield child;\n }\n }\n if (child.size != null && child.cid) {\n links.push({\n Name: children[i],\n Tsize: child.size,\n Hash: child.cid\n });\n }\n }\n const unixfs = new ipfsUnixfs.UnixFS({\n type: 'directory',\n mtime: this.mtime,\n mode: this.mode\n });\n const node = {\n Data: unixfs.marshal(),\n Links: links\n };\n const buffer = dagPb.encode(dagPb.prepare(node));\n const cid = await persist(buffer, block, this.options);\n const size = buffer.length + node.Links.reduce((acc, curr) => acc + (curr.Tsize == null ? 0 : curr.Tsize), 0);\n this.cid = cid;\n this.size = size;\n yield {\n cid,\n unixfs,\n path: this.path,\n size\n };\n }\n}\n\nmodule.exports = DirFlat;\n","'use strict';\n\nclass Dir {\n constructor(props, options) {\n this.options = options || {};\n this.root = props.root;\n this.dir = props.dir;\n this.path = props.path;\n this.dirty = props.dirty;\n this.flat = props.flat;\n this.parent = props.parent;\n this.parentKey = props.parentKey;\n this.unixfs = props.unixfs;\n this.mode = props.mode;\n this.mtime = props.mtime;\n this.cid = undefined;\n this.size = undefined;\n }\n async put(name, value) {\n }\n get(name) {\n return Promise.resolve(this);\n }\n async *eachChildSeries() {\n }\n async *flush(blockstore) {\n }\n}\n\nmodule.exports = Dir;\n","'use strict';\n\nvar dirSharded = require('./dir-sharded.js');\nvar dirFlat = require('./dir-flat.js');\n\nasync function flatToShard(child, dir, threshold, options) {\n let newDir = dir;\n if (dir instanceof dirFlat && dir.directChildrenCount() >= threshold) {\n newDir = await convertToShard(dir, options);\n }\n const parent = newDir.parent;\n if (parent) {\n if (newDir !== dir) {\n if (child) {\n child.parent = newDir;\n }\n if (!newDir.parentKey) {\n throw new Error('No parent key found');\n }\n await parent.put(newDir.parentKey, newDir);\n }\n return flatToShard(newDir, parent, threshold, options);\n }\n return newDir;\n}\nasync function convertToShard(oldDir, options) {\n const newDir = new dirSharded({\n root: oldDir.root,\n dir: true,\n parent: oldDir.parent,\n parentKey: oldDir.parentKey,\n path: oldDir.path,\n dirty: oldDir.dirty,\n flat: false,\n mtime: oldDir.mtime,\n mode: oldDir.mode\n }, options);\n for await (const {key, child} of oldDir.eachChildSeries()) {\n await newDir.put(key, child);\n }\n return newDir;\n}\n\nmodule.exports = flatToShard;\n","'use strict';\n\nvar dagPb = require('@ipld/dag-pb');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dir = require('./dir.js');\nvar persist = require('./utils/persist.js');\nvar hamtSharding = require('hamt-sharding');\n\nclass DirSharded extends dir {\n constructor(props, options) {\n super(props, options);\n this._bucket = hamtSharding.createHAMT({\n hashFn: options.hamtHashFn,\n bits: options.hamtBucketBits\n });\n }\n async put(name, value) {\n await this._bucket.put(name, value);\n }\n get(name) {\n return this._bucket.get(name);\n }\n childCount() {\n return this._bucket.leafCount();\n }\n directChildrenCount() {\n return this._bucket.childrenCount();\n }\n onlyChild() {\n return this._bucket.onlyChild();\n }\n async *eachChildSeries() {\n for await (const {key, value} of this._bucket.eachLeafSeries()) {\n yield {\n key,\n child: value\n };\n }\n }\n async *flush(blockstore) {\n for await (const entry of flush(this._bucket, blockstore, this, this.options)) {\n yield {\n ...entry,\n path: this.path\n };\n }\n }\n}\nasync function* flush(bucket, blockstore, shardRoot, options) {\n const children = bucket._children;\n const links = [];\n let childrenSize = 0;\n for (let i = 0; i < children.length; i++) {\n const child = children.get(i);\n if (!child) {\n continue;\n }\n const labelPrefix = i.toString(16).toUpperCase().padStart(2, '0');\n if (child instanceof hamtSharding.Bucket) {\n let shard;\n for await (const subShard of await flush(child, blockstore, null, options)) {\n shard = subShard;\n }\n if (!shard) {\n throw new Error('Could not flush sharded directory, no subshard found');\n }\n links.push({\n Name: labelPrefix,\n Tsize: shard.size,\n Hash: shard.cid\n });\n childrenSize += shard.size;\n } else if (typeof child.value.flush === 'function') {\n const dir = child.value;\n let flushedDir;\n for await (const entry of dir.flush(blockstore)) {\n flushedDir = entry;\n yield flushedDir;\n }\n const label = labelPrefix + child.key;\n links.push({\n Name: label,\n Tsize: flushedDir.size,\n Hash: flushedDir.cid\n });\n childrenSize += flushedDir.size;\n } else {\n const value = child.value;\n if (!value.cid) {\n continue;\n }\n const label = labelPrefix + child.key;\n const size = value.size;\n links.push({\n Name: label,\n Tsize: size,\n Hash: value.cid\n });\n childrenSize += size;\n }\n }\n const data = Uint8Array.from(children.bitField().reverse());\n const dir = new ipfsUnixfs.UnixFS({\n type: 'hamt-sharded-directory',\n data,\n fanout: bucket.tableSize(),\n hashType: options.hamtHashCode,\n mtime: shardRoot && shardRoot.mtime,\n mode: shardRoot && shardRoot.mode\n });\n const node = {\n Data: dir.marshal(),\n Links: links\n };\n const buffer = dagPb.encode(dagPb.prepare(node));\n const cid = await persist(buffer, blockstore, options);\n const size = buffer.length + childrenSize;\n yield {\n cid,\n unixfs: dir,\n size\n };\n}\n\nmodule.exports = DirSharded;\n","'use strict'\n\nconst Bucket = require('./bucket')\nconst wrapHash = require('./consumable-hash')\n\n/**\n * @typedef {object} UserBucketOptions\n * @property {(value: Uint8Array) => Promise<Uint8Array>} hashFn\n * @property {number} [bits=8]\n */\n\n/**\n * @param {UserBucketOptions} options\n */\nfunction createHAMT (options) {\n if (!options || !options.hashFn) {\n throw new Error('please define an options.hashFn')\n }\n\n const bucketOptions = {\n bits: options.bits || 8,\n hash: wrapHash(options.hashFn)\n }\n\n return new Bucket(bucketOptions)\n}\n\nmodule.exports = {\n createHAMT,\n Bucket\n}\n","'use strict'\n\n// @ts-ignore\nconst SparseArray = require('sparse-array')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\n/**\n * @typedef {import('./consumable-hash').InfiniteHash} InfiniteHash\n * @typedef {import('../').UserBucketOptions} UserBucketOptions\n */\n\n/**\n * @template V\n * @typedef {object} BucketChild<V>\n * @property {string} key\n * @property {V} value\n * @property {InfiniteHash} hash\n */\n\n/**\n * @template B\n *\n * @typedef {object} SA<B>\n * @property {number} length\n * @property {() => B[]} compactArray\n * @property {(i: number) => B} get\n * @property {(i: number, value: B) => void} set\n * @property {<A> (fn: (acc: A, curr: B, index: number) => A, initial: A) => B} reduce\n * @property {(fn: (item: B) => boolean) => B | undefined} find\n * @property {() => number[]} bitField\n * @property {(i: number) => void} unset\n */\n\n/**\n * @template T\n *\n * @typedef {object} BucketPosition<T>\n * @property {Bucket<T>} bucket\n * @property {number} pos\n * @property {InfiniteHash} hash\n * @property {BucketChild<T>} [existingChild]\n */\n\n/**\n * @typedef {object} BucketOptions\n * @property {number} bits\n * @property {(value: Uint8Array | InfiniteHash) => InfiniteHash} hash\n */\n\n/**\n * @template T\n */\nclass Bucket {\n /**\n * @param {BucketOptions} options\n * @param {Bucket<T>} [parent]\n * @param {number} [posAtParent=0]\n */\n constructor (options, parent, posAtParent = 0) {\n this._options = options\n this._popCount = 0\n this._parent = parent\n this._posAtParent = posAtParent\n\n /** @type {SA<Bucket<T> | BucketChild<T>>} */\n this._children = new SparseArray()\n\n /** @type {string | null} */\n this.key = null\n }\n\n /**\n * @param {string} key\n * @param {T} value\n */\n async put (key, value) {\n const place = await this._findNewBucketAndPos(key)\n\n await place.bucket._putAt(place, key, value)\n }\n\n /**\n * @param {string} key\n */\n async get (key) {\n const child = await this._findChild(key)\n\n if (child) {\n return child.value\n }\n }\n\n /**\n * @param {string} key\n */\n async del (key) {\n const place = await this._findPlace(key)\n const child = place.bucket._at(place.pos)\n\n if (child && child.key === key) {\n place.bucket._delAt(place.pos)\n }\n }\n\n /**\n * @returns {number}\n */\n leafCount () {\n const children = this._children.compactArray()\n\n return children.reduce((acc, child) => {\n if (child instanceof Bucket) {\n return acc + child.leafCount()\n }\n\n return acc + 1\n }, 0)\n }\n\n childrenCount () {\n return this._children.length\n }\n\n onlyChild () {\n return this._children.get(0)\n }\n\n /**\n * @returns {Iterable<BucketChild<T>>}\n */\n * eachLeafSeries () {\n const children = this._children.compactArray()\n\n for (const child of children) {\n if (child instanceof Bucket) {\n yield * child.eachLeafSeries()\n } else {\n yield child\n }\n }\n\n // this is necessary because tsc requires a @return annotation as it\n // can't derive a return type due to the recursion, and eslint requires\n // a return statement when there is a @return annotation\n return []\n }\n\n /**\n * @param {(value: BucketChild<T>, index: number) => T} map\n * @param {(reduced: any) => any} reduce\n */\n serialize (map, reduce) {\n /** @type {T[]} */\n const acc = []\n // serialize to a custom non-sparse representation\n return reduce(this._children.reduce((acc, child, index) => {\n if (child) {\n if (child instanceof Bucket) {\n acc.push(child.serialize(map, reduce))\n } else {\n acc.push(map(child, index))\n }\n }\n return acc\n }, acc))\n }\n\n /**\n * @param {(value: BucketChild<T>) => Promise<T[]>} asyncMap\n * @param {(reduced: any) => Promise<any>} asyncReduce\n */\n asyncTransform (asyncMap, asyncReduce) {\n return asyncTransformBucket(this, asyncMap, asyncReduce)\n }\n\n toJSON () {\n return this.serialize(mapNode, reduceNodes)\n }\n\n prettyPrint () {\n return JSON.stringify(this.toJSON(), null, ' ')\n }\n\n tableSize () {\n return Math.pow(2, this._options.bits)\n }\n\n /**\n * @param {string} key\n * @returns {Promise<BucketChild<T> | undefined>}\n */\n async _findChild (key) {\n const result = await this._findPlace(key)\n const child = result.bucket._at(result.pos)\n\n if (child instanceof Bucket) {\n // should not be possible, this._findPlace should always\n // return a location for a child, not a bucket\n return undefined\n }\n\n if (child && child.key === key) {\n return child\n }\n }\n\n /**\n * @param {string | InfiniteHash} key\n * @returns {Promise<BucketPosition<T>>}\n */\n async _findPlace (key) {\n const hashValue = this._options.hash(typeof key === 'string' ? uint8ArrayFromString(key) : key)\n const index = await hashValue.take(this._options.bits)\n\n const child = this._children.get(index)\n\n if (child instanceof Bucket) {\n return child._findPlace(hashValue)\n }\n\n return {\n bucket: this,\n pos: index,\n hash: hashValue,\n existingChild: child\n }\n }\n\n /**\n * @param {string | InfiniteHash} key\n * @returns {Promise<BucketPosition<T>>}\n */\n async _findNewBucketAndPos (key) {\n const place = await this._findPlace(key)\n\n if (place.existingChild && place.existingChild.key !== key) {\n // conflict\n const bucket = new Bucket(this._options, place.bucket, place.pos)\n place.bucket._putObjectAt(place.pos, bucket)\n\n // put the previous value\n const newPlace = await bucket._findPlace(place.existingChild.hash)\n newPlace.bucket._putAt(newPlace, place.existingChild.key, place.existingChild.value)\n\n return bucket._findNewBucketAndPos(place.hash)\n }\n\n // no conflict, we found the place\n return place\n }\n\n /**\n * @param {BucketPosition<T>} place\n * @param {string} key\n * @param {T} value\n */\n _putAt (place, key, value) {\n this._putObjectAt(place.pos, {\n key: key,\n value: value,\n hash: place.hash\n })\n }\n\n /**\n * @param {number} pos\n * @param {Bucket<T> | BucketChild<T>} object\n */\n _putObjectAt (pos, object) {\n if (!this._children.get(pos)) {\n this._popCount++\n }\n this._children.set(pos, object)\n }\n\n /**\n * @param {number} pos\n */\n _delAt (pos) {\n if (pos === -1) {\n throw new Error('Invalid position')\n }\n\n if (this._children.get(pos)) {\n this._popCount--\n }\n this._children.unset(pos)\n this._level()\n }\n\n _level () {\n if (this._parent && this._popCount <= 1) {\n if (this._popCount === 1) {\n // remove myself from parent, replacing me with my only child\n const onlyChild = this._children.find(exists)\n\n if (onlyChild && !(onlyChild instanceof Bucket)) {\n const hash = onlyChild.hash\n hash.untake(this._options.bits)\n const place = {\n pos: this._posAtParent,\n hash: hash,\n bucket: this._parent\n }\n this._parent._putAt(place, onlyChild.key, onlyChild.value)\n }\n } else {\n this._parent._delAt(this._posAtParent)\n }\n }\n }\n\n /**\n * @param {number} index\n * @returns {BucketChild<T> | Bucket<T> | undefined}\n */\n _at (index) {\n return this._children.get(index)\n }\n}\n\n/**\n * @param {any} o\n */\nfunction exists (o) {\n return Boolean(o)\n}\n\n/**\n *\n * @param {*} node\n * @param {number} index\n */\nfunction mapNode (node, index) {\n return node.key\n}\n\n/**\n * @param {*} nodes\n */\nfunction reduceNodes (nodes) {\n return nodes\n}\n\n/**\n * @template T\n *\n * @param {Bucket<T>} bucket\n * @param {(value: BucketChild<T>) => Promise<T[]>} asyncMap\n * @param {(reduced: any) => Promise<any>} asyncReduce\n */\nasync function asyncTransformBucket (bucket, asyncMap, asyncReduce) {\n const output = []\n\n for (const child of bucket._children.compactArray()) {\n if (child instanceof Bucket) {\n await asyncTransformBucket(child, asyncMap, asyncReduce)\n } else {\n const mappedChildren = await asyncMap(child)\n\n output.push({\n bitField: bucket._children.bitField(),\n children: mappedChildren\n })\n }\n }\n\n return asyncReduce(output)\n}\n\nmodule.exports = Bucket\n","'use strict'\n\n// JS treats subjects of bitwise operators as SIGNED 32 bit numbers,\n// which means the maximum amount of bits we can store inside each byte\n// is 7..\nconst BITS_PER_BYTE = 7\n\nmodule.exports = class SparseArray {\n constructor () {\n this._bitArrays = []\n this._data = []\n this._length = 0\n this._changedLength = false\n this._changedData = false\n }\n\n set (index, value) {\n let pos = this._internalPositionFor(index, false)\n if (value === undefined) {\n // unsetting\n if (pos !== -1) {\n // remove item from bit array and array itself\n this._unsetInternalPos(pos)\n this._unsetBit(index)\n this._changedLength = true\n this._changedData = true\n }\n } else {\n let needsSort = false\n if (pos === -1) {\n pos = this._data.length\n this._setBit(index)\n this._changedData = true\n } else {\n needsSort = true\n }\n this._setInternalPos(pos, index, value, needsSort)\n this._changedLength = true\n }\n }\n\n unset (index) {\n this.set(index, undefined)\n }\n\n get (index) {\n this._sortData()\n const pos = this._internalPositionFor(index, true)\n if (pos === -1) {\n return undefined\n }\n return this._data[pos][1]\n }\n\n push (value) {\n this.set(this.length, value)\n return this.length\n }\n\n get length () {\n this._sortData()\n if (this._changedLength) {\n const last = this._data[this._data.length - 1]\n this._length = last ? last[0] + 1 : 0\n this._changedLength = false\n }\n return this._length\n }\n\n forEach (iterator) {\n let i = 0\n while(i < this.length) {\n iterator(this.get(i), i, this)\n i++\n }\n }\n\n map (iterator) {\n let i = 0\n let mapped = new Array(this.length)\n while(i < this.length) {\n mapped[i] = iterator(this.get(i), i, this)\n i++\n }\n return mapped\n }\n\n reduce (reducer, initialValue) {\n let i = 0\n let acc = initialValue\n while(i < this.length) {\n const value = this.get(i)\n acc = reducer(acc, value, i)\n i++\n }\n return acc\n }\n\n find (finder) {\n let i = 0, found, last\n while ((i < this.length) && !found) {\n last = this.get(i)\n found = finder(last)\n i++\n }\n return found ? last : undefined\n }\n\n _internalPositionFor (index, noCreate) {\n const bytePos = this._bytePosFor(index, noCreate)\n if (bytePos >= this._bitArrays.length) {\n return -1\n }\n const byte = this._bitArrays[bytePos]\n const bitPos = index - bytePos * BITS_PER_BYTE\n const exists = (byte & (1 << bitPos)) > 0\n if (!exists) {\n return -1\n }\n const previousPopCount = this._bitArrays.slice(0, bytePos).reduce(popCountReduce, 0)\n\n const mask = ~(0xffffffff << (bitPos + 1))\n const bytePopCount = popCount(byte & mask)\n const arrayPos = previousPopCount + bytePopCount - 1\n return arrayPos\n }\n\n _bytePosFor (index, noCreate) {\n const bytePos = Math.floor(index / BITS_PER_BYTE)\n const targetLength = bytePos + 1\n while (!noCreate && this._bitArrays.length < targetLength) {\n this._bitArrays.push(0)\n }\n return bytePos\n }\n\n _setBit (index) {\n const bytePos = this._bytePosFor(index, false)\n this._bitArrays[bytePos] |= (1 << (index - (bytePos * BITS_PER_BYTE)))\n }\n\n _unsetBit(index) {\n const bytePos = this._bytePosFor(index, false)\n this._bitArrays[bytePos] &= ~(1 << (index - (bytePos * BITS_PER_BYTE)))\n }\n\n _setInternalPos(pos, index, value, needsSort) {\n const data =this._data\n const elem = [index, value]\n if (needsSort) {\n this._sortData()\n data[pos] = elem\n } else {\n // new element. just shove it into the array\n // but be nice about where we shove it\n // in order to make sorting it later easier\n if (data.length) {\n if (data[data.length - 1][0] >= index) {\n data.push(elem)\n } else if (data[0][0] <= index) {\n data.unshift(elem)\n } else {\n const randomIndex = Math.round(data.length / 2)\n this._data = data.slice(0, randomIndex).concat(elem).concat(data.slice(randomIndex))\n }\n } else {\n this._data.push(elem)\n }\n this._changedData = true\n this._changedLength = true\n }\n }\n\n _unsetInternalPos (pos) {\n this._data.splice(pos, 1)\n }\n\n _sortData () {\n if (this._changedData) {\n this._data.sort(sortInternal)\n }\n\n this._changedData = false\n }\n\n bitField () {\n const bytes = []\n let pendingBitsForResultingByte = 8\n let pendingBitsForNewByte = 0\n let resultingByte = 0\n let newByte\n const pending = this._bitArrays.slice()\n while (pending.length || pendingBitsForNewByte) {\n if (pendingBitsForNewByte === 0) {\n newByte = pending.shift()\n pendingBitsForNewByte = 7\n }\n\n const usingBits = Math.min(pendingBitsForNewByte, pendingBitsForResultingByte)\n const mask = ~(0b11111111 << usingBits)\n const masked = newByte & mask\n resultingByte |= masked << (8 - pendingBitsForResultingByte)\n newByte = newByte >>> usingBits\n pendingBitsForNewByte -= usingBits\n pendingBitsForResultingByte -= usingBits\n\n if (!pendingBitsForResultingByte || (!pendingBitsForNewByte && !pending.length)) {\n bytes.push(resultingByte)\n resultingByte = 0\n pendingBitsForResultingByte = 8\n }\n }\n\n // remove trailing zeroes\n for(var i = bytes.length - 1; i > 0; i--) {\n const value = bytes[i]\n if (value === 0) {\n bytes.pop()\n } else {\n break\n }\n }\n\n return bytes\n }\n\n compactArray () {\n this._sortData()\n return this._data.map(valueOnly)\n }\n}\n\nfunction popCountReduce (count, byte) {\n return count + popCount(byte)\n}\n\nfunction popCount(_v) {\n let v = _v\n v = v - ((v >> 1) & 0x55555555) // reuse input as temporary\n v = (v & 0x33333333) + ((v >> 2) & 0x33333333) // temp\n return ((v + (v >> 4) & 0xF0F0F0F) * 0x1010101) >> 24\n}\n\nfunction sortInternal (a, b) {\n return a[0] - b[0]\n}\n\nfunction valueOnly (elem) {\n return elem[1]\n}","'use strict'\n\nconst ConsumableBuffer = require('./consumable-buffer')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\n\n/**\n * @param {(value: Uint8Array) => Promise<Uint8Array>} hashFn\n */\nfunction wrapHash (hashFn) {\n /**\n * @param {InfiniteHash | Uint8Array} value\n */\n function hashing (value) {\n if (value instanceof InfiniteHash) {\n // already a hash. return it\n return value\n } else {\n return new InfiniteHash(value, hashFn)\n }\n }\n\n return hashing\n}\n\nclass InfiniteHash {\n /**\n *\n * @param {Uint8Array} value\n * @param {(value: Uint8Array) => Promise<Uint8Array>} hashFn\n */\n constructor (value, hashFn) {\n if (!(value instanceof Uint8Array)) {\n throw new Error('can only hash Uint8Arrays')\n }\n\n this._value = value\n this._hashFn = hashFn\n this._depth = -1\n this._availableBits = 0\n this._currentBufferIndex = 0\n\n /** @type {ConsumableBuffer[]} */\n this._buffers = []\n }\n\n /**\n * @param {number} bits\n */\n async take (bits) {\n let pendingBits = bits\n\n while (this._availableBits < pendingBits) {\n await this._produceMoreBits()\n }\n\n let result = 0\n\n while (pendingBits > 0) {\n const hash = this._buffers[this._currentBufferIndex]\n const available = Math.min(hash.availableBits(), pendingBits)\n const took = hash.take(available)\n result = (result << available) + took\n pendingBits -= available\n this._availableBits -= available\n\n if (hash.availableBits() === 0) {\n this._currentBufferIndex++\n }\n }\n\n return result\n }\n\n /**\n * @param {number} bits\n */\n untake (bits) {\n let pendingBits = bits\n\n while (pendingBits > 0) {\n const hash = this._buffers[this._currentBufferIndex]\n const availableForUntake = Math.min(hash.totalBits() - hash.availableBits(), pendingBits)\n hash.untake(availableForUntake)\n pendingBits -= availableForUntake\n this._availableBits += availableForUntake\n\n if (this._currentBufferIndex > 0 && hash.totalBits() === hash.availableBits()) {\n this._depth--\n this._currentBufferIndex--\n }\n }\n }\n\n async _produceMoreBits () {\n this._depth++\n\n const value = this._depth ? uint8ArrayConcat([this._value, Uint8Array.from([this._depth])]) : this._value\n const hashValue = await this._hashFn(value)\n const buffer = new ConsumableBuffer(hashValue)\n\n this._buffers.push(buffer)\n this._availableBits += buffer.availableBits()\n }\n}\n\nmodule.exports = wrapHash\nmodule.exports.InfiniteHash = InfiniteHash\n","'use strict'\n\nconst START_MASKS = [\n 0b11111111,\n 0b11111110,\n 0b11111100,\n 0b11111000,\n 0b11110000,\n 0b11100000,\n 0b11000000,\n 0b10000000\n]\n\nconst STOP_MASKS = [\n 0b00000001,\n 0b00000011,\n 0b00000111,\n 0b00001111,\n 0b00011111,\n 0b00111111,\n 0b01111111,\n 0b11111111\n]\n\nmodule.exports = class ConsumableBuffer {\n /**\n * @param {Uint8Array} value\n */\n constructor (value) {\n this._value = value\n this._currentBytePos = value.length - 1\n this._currentBitPos = 7\n }\n\n availableBits () {\n return this._currentBitPos + 1 + this._currentBytePos * 8\n }\n\n totalBits () {\n return this._value.length * 8\n }\n\n /**\n * @param {number} bits\n */\n take (bits) {\n let pendingBits = bits\n let result = 0\n while (pendingBits && this._haveBits()) {\n const byte = this._value[this._currentBytePos]\n const availableBits = this._currentBitPos + 1\n const taking = Math.min(availableBits, pendingBits)\n const value = byteBitsToInt(byte, availableBits - taking, taking)\n result = (result << taking) + value\n\n pendingBits -= taking\n\n this._currentBitPos -= taking\n if (this._currentBitPos < 0) {\n this._currentBitPos = 7\n this._currentBytePos--\n }\n }\n\n return result\n }\n\n /**\n * @param {number} bits\n */\n untake (bits) {\n this._currentBitPos += bits\n while (this._currentBitPos > 7) {\n this._currentBitPos -= 8\n this._currentBytePos += 1\n }\n }\n\n _haveBits () {\n return this._currentBytePos >= 0\n }\n}\n\n/**\n * @param {number} byte\n * @param {number} start\n * @param {number} length\n */\nfunction byteBitsToInt (byte, start, length) {\n const mask = maskFor(start, length)\n return (byte & mask) >>> start\n}\n\n/**\n * @param {number} start\n * @param {number} length\n */\nfunction maskFor (start, length) {\n return START_MASKS[start] & STOP_MASKS[Math.min(length + start - 1, 7)]\n}\n","'use strict';\n\nconst toPathComponents = (path = '') => {\n return (path.trim().match(/([^\\\\^/]|\\\\\\/)+/g) || []).filter(Boolean);\n};\n\nmodule.exports = toPathComponents;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseContent = require('./normalise-content.js');\nvar normalise = require('./normalise.js');\n\nfunction normaliseInput(input) {\n return normalise.normalise(input, normaliseContent.normaliseContent);\n}\n\nexports.normaliseInput = normaliseInput;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar fromString = require('uint8arrays/from-string');\nvar browserStreamToIt = require('browser-readablestream-to-it');\nvar blobToIt = require('blob-to-it');\nvar itPeekable = require('it-peekable');\nvar all = require('it-all');\nvar map = require('it-map');\nvar utils = require('./utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar browserStreamToIt__default = /*#__PURE__*/_interopDefaultLegacy(browserStreamToIt);\nvar blobToIt__default = /*#__PURE__*/_interopDefaultLegacy(blobToIt);\nvar itPeekable__default = /*#__PURE__*/_interopDefaultLegacy(itPeekable);\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\n\nasync function normaliseContent(input) {\n return toAsyncGenerator(input);\n}\nasync function* toAsyncGenerator(input) {\n if (utils.isBytes(input)) {\n yield toBytes(input);\n return;\n }\n if (typeof input === 'string' || input instanceof String) {\n yield toBytes(input.toString());\n return;\n }\n if (utils.isBlob(input)) {\n yield* blobToIt__default['default'](input);\n return;\n }\n if (utils.isReadableStream(input)) {\n input = browserStreamToIt__default['default'](input);\n }\n if (Symbol.iterator in input || Symbol.asyncIterator in input) {\n const peekable = itPeekable__default['default'](input);\n const {value, done} = await peekable.peek();\n if (done) {\n yield* [];\n return;\n }\n peekable.push(value);\n if (Number.isInteger(value)) {\n yield Uint8Array.from(await all__default['default'](peekable));\n return;\n }\n if (utils.isBytes(value) || typeof value === 'string' || value instanceof String) {\n yield* map__default['default'](peekable, toBytes);\n return;\n }\n }\n throw errCode__default['default'](new Error(`Unexpected input: ${ input }`), 'ERR_UNEXPECTED_INPUT');\n}\nfunction toBytes(chunk) {\n if (chunk instanceof Uint8Array) {\n return chunk;\n }\n if (ArrayBuffer.isView(chunk)) {\n return new Uint8Array(chunk.buffer, chunk.byteOffset, chunk.byteLength);\n }\n if (chunk instanceof ArrayBuffer) {\n return new Uint8Array(chunk);\n }\n if (Array.isArray(chunk)) {\n return Uint8Array.from(chunk);\n }\n return fromString.fromString(chunk.toString());\n}\n\nexports.normaliseContent = normaliseContent;\n","'use strict'\n\n/**\n * Turns a browser readable stream into an async iterable. Async iteration over\n * returned iterable will lock give stream, preventing any other consumer from\n * acquiring a reader. The lock will be released if iteration loop is broken. To\n * prevent stream cancelling optional `{ preventCancel: true }` could be passed\n * as a second argument.\n * @template T\n * @param {ReadableStream<T>} stream\n * @param {Object} [options]\n * @param {boolean} [options.preventCancel=boolean]\n * @returns {AsyncIterable<T>}\n */\nasync function * browserReadableStreamToIt (stream, options = {}) {\n const reader = stream.getReader()\n\n try {\n while (true) {\n const result = await reader.read()\n\n if (result.done) {\n return\n }\n\n yield result.value\n }\n } finally {\n if (options.preventCancel !== true) {\n reader.cancel()\n }\n\n reader.releaseLock()\n }\n}\n\nmodule.exports = browserReadableStreamToIt\n","/* eslint-env browser */\n\n'use strict'\n\nconst browserReadableStreamToIt = require('browser-readablestream-to-it')\n\n/**\n * @param {Blob} blob\n * @returns {AsyncIterable<Uint8Array>}\n */\nfunction blobToIt (blob) {\n if (typeof blob.stream === 'function') {\n // @ts-ignore missing some properties\n return browserReadableStreamToIt(blob.stream())\n }\n\n // firefox < 69 does not support blob.stream()\n // @ts-ignore - response.body is optional, but in practice it's a stream.\n return browserReadableStreamToIt(new Response(blob).body)\n}\n\nmodule.exports = blobToIt\n","'use strict'\n\n/**\n * @template T\n * @typedef {Object} Peek\n * @property {() => IteratorResult<T, void>} peek\n */\n\n/**\n * @template T\n * @typedef {Object} AsyncPeek\n * @property {() => Promise<IteratorResult<T, void>>} peek\n */\n\n/**\n * @template T\n * @typedef {Object} Push\n * @property {(value:T) => void} push\n */\n\n/**\n * @template T\n * @typedef {Iterable<T> & Peek<T> & Push<T> & Iterator<T>} Peekable<T>\n */\n\n/**\n * @template T\n * @typedef {AsyncIterable<T> & AsyncPeek<T> & Push<T> & AsyncIterator<T>} AsyncPeekable<T>\n */\n\n/**\n * @template {Iterable<any> | AsyncIterable<any>} I\n * @param {I} iterable\n * @returns {I extends Iterable<infer T>\n * ? Peekable<T>\n * : I extends AsyncIterable<infer T>\n * ? AsyncPeekable<T>\n * : never\n * }\n */\nfunction peekableIterator (iterable) {\n // @ts-ignore\n const [iterator, symbol] = iterable[Symbol.asyncIterator]\n // @ts-ignore\n ? [iterable[Symbol.asyncIterator](), Symbol.asyncIterator]\n // @ts-ignore\n : [iterable[Symbol.iterator](), Symbol.iterator]\n\n /** @type {any[]} */\n const queue = []\n\n // @ts-ignore\n return {\n peek: () => {\n return iterator.next()\n },\n push: (value) => {\n queue.push(value)\n },\n next: () => {\n if (queue.length) {\n return {\n done: false,\n value: queue.shift()\n }\n }\n\n return iterator.next()\n },\n [symbol] () {\n return this\n }\n }\n}\n\nmodule.exports = peekableIterator\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction isBytes(obj) {\n return ArrayBuffer.isView(obj) || obj instanceof ArrayBuffer;\n}\nfunction isBlob(obj) {\n return obj.constructor && (obj.constructor.name === 'Blob' || obj.constructor.name === 'File') && typeof obj.stream === 'function';\n}\nfunction isFileObject(obj) {\n return typeof obj === 'object' && (obj.path || obj.content);\n}\nconst isReadableStream = value => value && typeof value.getReader === 'function';\n\nexports.isBlob = isBlob;\nexports.isBytes = isBytes;\nexports.isFileObject = isFileObject;\nexports.isReadableStream = isReadableStream;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar browserStreamToIt = require('browser-readablestream-to-it');\nvar itPeekable = require('it-peekable');\nvar map = require('it-map');\nvar utils = require('./utils.js');\nvar ipfsUnixfs = require('ipfs-unixfs');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar browserStreamToIt__default = /*#__PURE__*/_interopDefaultLegacy(browserStreamToIt);\nvar itPeekable__default = /*#__PURE__*/_interopDefaultLegacy(itPeekable);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\n\nasync function* normalise(input, normaliseContent) {\n if (input === null || input === undefined) {\n throw errCode__default['default'](new Error(`Unexpected input: ${ input }`), 'ERR_UNEXPECTED_INPUT');\n }\n if (typeof input === 'string' || input instanceof String) {\n yield toFileObject(input.toString(), normaliseContent);\n return;\n }\n if (utils.isBytes(input) || utils.isBlob(input)) {\n yield toFileObject(input, normaliseContent);\n return;\n }\n if (utils.isReadableStream(input)) {\n input = browserStreamToIt__default['default'](input);\n }\n if (Symbol.iterator in input || Symbol.asyncIterator in input) {\n const peekable = itPeekable__default['default'](input);\n const {value, done} = await peekable.peek();\n if (done) {\n yield* [];\n return;\n }\n peekable.push(value);\n if (Number.isInteger(value) || utils.isBytes(value)) {\n yield toFileObject(peekable, normaliseContent);\n return;\n }\n if (value._readableState) {\n yield* map__default['default'](peekable, value => toFileObject({ content: value }, normaliseContent));\n return;\n }\n if (utils.isFileObject(value) || utils.isBlob(value) || typeof value === 'string' || value instanceof String) {\n yield* map__default['default'](peekable, value => toFileObject(value, normaliseContent));\n return;\n }\n if (value[Symbol.iterator] || value[Symbol.asyncIterator] || utils.isReadableStream(value)) {\n yield* map__default['default'](peekable, value => toFileObject(value, normaliseContent));\n return;\n }\n }\n if (utils.isFileObject(input)) {\n yield toFileObject(input, normaliseContent);\n return;\n }\n throw errCode__default['default'](new Error('Unexpected input: ' + typeof input), 'ERR_UNEXPECTED_INPUT');\n}\nasync function toFileObject(input, normaliseContent) {\n const {path, mode, mtime, content} = input;\n const file = {\n path: path || '',\n mode: ipfsUnixfs.parseMode(mode),\n mtime: ipfsUnixfs.parseMtime(mtime)\n };\n if (content) {\n file.content = await normaliseContent(content);\n } else if (!path) {\n file.content = await normaliseContent(input);\n }\n return file;\n}\n\nexports.normalise = normalise;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst parseChunkerString = chunker => {\n if (!chunker) {\n return { chunker: 'fixed' };\n } else if (chunker.startsWith('size-')) {\n const sizeStr = chunker.split('-')[1];\n const size = parseInt(sizeStr);\n if (isNaN(size)) {\n throw new Error('Chunker parameter size must be an integer');\n }\n return {\n chunker: 'fixed',\n maxChunkSize: size\n };\n } else if (chunker.startsWith('rabin')) {\n return {\n chunker: 'rabin',\n ...parseRabinString(chunker)\n };\n } else {\n throw new Error(`Unrecognized chunker option: ${ chunker }`);\n }\n};\nconst parseRabinString = chunker => {\n const options = {};\n const parts = chunker.split('-');\n switch (parts.length) {\n case 1:\n options.avgChunkSize = 262144;\n break;\n case 2:\n options.avgChunkSize = parseChunkSize(parts[1], 'avg');\n break;\n case 4:\n options.minChunkSize = parseChunkSize(parts[1], 'min');\n options.avgChunkSize = parseChunkSize(parts[2], 'avg');\n options.maxChunkSize = parseChunkSize(parts[3], 'max');\n break;\n default:\n throw new Error('Incorrect chunker format (expected \"rabin\" \"rabin-[avg]\" or \"rabin-[min]-[avg]-[max]\"');\n }\n return options;\n};\nconst parseChunkSize = (str, name) => {\n const size = parseInt(str);\n if (isNaN(size)) {\n throw new Error(`Chunker parameter ${ name } must be an integer`);\n }\n return size;\n};\n\nexports.parseChunkSize = parseChunkSize;\nexports.parseChunkerString = parseChunkerString;\nexports.parseRabinString = parseRabinString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar utils = require('../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar cid = require('multiformats/cid');\n\nfunction createCat({repo, preload}) {\n async function* cat(ipfsPath, options = {}) {\n ipfsPath = utils.normalizeCidPath(ipfsPath);\n if (options.preload !== false) {\n const pathComponents = ipfsPath.split('/');\n preload(cid.CID.parse(pathComponents[0]));\n }\n const file = await ipfsUnixfsExporter.exporter(ipfsPath, repo.blocks, options);\n if (file.type === 'directory') {\n throw new Error('this dag node is a directory');\n }\n if (!file.content) {\n throw new Error('this dag node has no content');\n }\n yield* file.content(options);\n }\n return withTimeoutOption.withTimeoutOption(cat);\n}\n\nexports.createCat = createCat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar cid = require('multiformats/cid');\nvar index = require('./resolvers/index.js');\nvar last = require('it-last');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst toPathComponents = (path = '') => {\n return (path.trim().match(/([^\\\\^/]|\\\\\\/)+/g) || []).filter(Boolean);\n};\nconst cidAndRest = path => {\n if (path instanceof Uint8Array) {\n return {\n cid: cid.CID.decode(path),\n toResolve: []\n };\n }\n const cid$1 = cid.CID.asCID(path);\n if (cid$1) {\n return {\n cid: cid$1,\n toResolve: []\n };\n }\n if (typeof path === 'string') {\n if (path.indexOf('/ipfs/') === 0) {\n path = path.substring(6);\n }\n const output = toPathComponents(path);\n return {\n cid: cid.CID.parse(output[0]),\n toResolve: output.slice(1)\n };\n }\n throw errCode__default['default'](new Error(`Unknown path type ${ path }`), 'ERR_BAD_PATH');\n};\nasync function* walkPath(path, blockstore, options = {}) {\n let {cid, toResolve} = cidAndRest(path);\n let name = cid.toString();\n let entryPath = name;\n const startingDepth = toResolve.length;\n while (true) {\n const result = await index(cid, name, entryPath, toResolve, startingDepth, blockstore, options);\n if (!result.entry && !result.next) {\n throw errCode__default['default'](new Error(`Could not resolve ${ path }`), 'ERR_NOT_FOUND');\n }\n if (result.entry) {\n yield result.entry;\n }\n if (!result.next) {\n return;\n }\n toResolve = result.next.toResolve;\n cid = result.next.cid;\n name = result.next.name;\n entryPath = result.next.path;\n }\n}\nasync function exporter(path, blockstore, options = {}) {\n const result = await last__default['default'](walkPath(path, blockstore, options));\n if (!result) {\n throw errCode__default['default'](new Error(`Could not resolve ${ path }`), 'ERR_NOT_FOUND');\n }\n return result;\n}\nasync function* recursive(path, blockstore, options = {}) {\n const node = await exporter(path, blockstore, options);\n if (!node) {\n return;\n }\n yield node;\n if (node.type === 'directory') {\n for await (const child of recurse(node, options)) {\n yield child;\n }\n }\n async function* recurse(node, options) {\n for await (const file of node.content(options)) {\n yield file;\n if (file instanceof Uint8Array) {\n continue;\n }\n if (file.type === 'directory') {\n yield* recurse(file, options);\n }\n }\n }\n}\n\nexports.exporter = exporter;\nexports.recursive = recursive;\nexports.walkPath = walkPath;\n","'use strict';\n\nvar errCode = require('err-code');\nvar dagPb = require('@ipld/dag-pb');\nvar dagCbor = require('@ipld/dag-cbor');\nvar raw = require('multiformats/codecs/raw');\nvar identity = require('multiformats/hashes/identity');\nvar index = require('./unixfs-v1/index.js');\nvar raw$1 = require('./raw.js');\nvar dagCbor$1 = require('./dag-cbor.js');\nvar identity$1 = require('./identity.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar dagCbor__namespace = /*#__PURE__*/_interopNamespace(dagCbor);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\n\nconst resolvers = {\n [dagPb__namespace.code]: index,\n [raw__namespace.code]: raw$1,\n [dagCbor__namespace.code]: dagCbor$1,\n [identity.identity.code]: identity$1\n};\nfunction resolve(cid, name, path, toResolve, depth, blockstore, options) {\n const resolver = resolvers[cid.code];\n if (!resolver) {\n throw errCode__default['default'](new Error(`No resolver for code ${ cid.code }`), 'ERR_NO_RESOLVER');\n }\n return resolver(cid, name, path, toResolve, resolve, depth, blockstore, options);\n}\n\nmodule.exports = resolve;\n","'use strict';\n\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar findCidInShard = require('../../utils/find-cid-in-shard.js');\nvar dagPb = require('@ipld/dag-pb');\nvar file = require('./content/file.js');\nvar directory = require('./content/directory.js');\nvar hamtShardedDirectory = require('./content/hamt-sharded-directory.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst findLinkCid = (node, name) => {\n const link = node.Links.find(link => link.Name === name);\n return link && link.Hash;\n};\nconst contentExporters = {\n raw: file,\n file: file,\n directory: directory,\n 'hamt-sharded-directory': hamtShardedDirectory,\n metadata: (cid, node, unixfs, path, resolve, depth, blockstore) => {\n return () => [];\n },\n symlink: (cid, node, unixfs, path, resolve, depth, blockstore) => {\n return () => [];\n }\n};\nconst unixFsResolver = async (cid, name, path, toResolve, resolve, depth, blockstore, options) => {\n const block = await blockstore.get(cid, options);\n const node = dagPb.decode(block);\n let unixfs;\n let next;\n if (!name) {\n name = cid.toString();\n }\n if (node.Data == null) {\n throw errCode__default['default'](new Error('no data in PBNode'), 'ERR_NOT_UNIXFS');\n }\n try {\n unixfs = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_NOT_UNIXFS');\n }\n if (!path) {\n path = name;\n }\n if (toResolve.length) {\n let linkCid;\n if (unixfs && unixfs.type === 'hamt-sharded-directory') {\n linkCid = await findCidInShard(node, toResolve[0], blockstore);\n } else {\n linkCid = findLinkCid(node, toResolve[0]);\n }\n if (!linkCid) {\n throw errCode__default['default'](new Error('file does not exist'), 'ERR_NOT_FOUND');\n }\n const nextName = toResolve.shift();\n const nextPath = `${ path }/${ nextName }`;\n next = {\n cid: linkCid,\n toResolve,\n name: nextName || '',\n path: nextPath\n };\n }\n return {\n entry: {\n type: unixfs.isDirectory() ? 'directory' : 'file',\n name,\n path,\n cid,\n content: contentExporters[unixfs.type](cid, node, unixfs, path, resolve, depth, blockstore),\n unixfs,\n depth,\n node,\n size: unixfs.fileSize()\n },\n next\n };\n};\n\nmodule.exports = unixFsResolver;\n","'use strict';\n\nvar hamtSharding = require('hamt-sharding');\nvar dagPb = require('@ipld/dag-pb');\nvar murmur3 = require('@multiformats/murmur3');\n\nconst hashFn = async function (buf) {\n return (await murmur3.murmur3128.encode(buf)).slice(0, 8).reverse();\n};\nconst addLinksToHamtBucket = (links, bucket, rootBucket) => {\n return Promise.all(links.map(link => {\n if (link.Name == null) {\n throw new Error('Unexpected Link without a Name');\n }\n if (link.Name.length === 2) {\n const pos = parseInt(link.Name, 16);\n return bucket._putObjectAt(pos, new hamtSharding.Bucket({\n hash: rootBucket._options.hash,\n bits: rootBucket._options.bits\n }, bucket, pos));\n }\n return rootBucket.put(link.Name.substring(2), true);\n }));\n};\nconst toPrefix = position => {\n return position.toString(16).toUpperCase().padStart(2, '0').substring(0, 2);\n};\nconst toBucketPath = position => {\n let bucket = position.bucket;\n const path = [];\n while (bucket._parent) {\n path.push(bucket);\n bucket = bucket._parent;\n }\n path.push(bucket);\n return path.reverse();\n};\nconst findShardCid = async (node, name, blockstore, context, options) => {\n if (!context) {\n const rootBucket = hamtSharding.createHAMT({ hashFn });\n context = {\n rootBucket,\n hamtDepth: 1,\n lastBucket: rootBucket\n };\n }\n await addLinksToHamtBucket(node.Links, context.lastBucket, context.rootBucket);\n const position = await context.rootBucket._findNewBucketAndPos(name);\n let prefix = toPrefix(position.pos);\n const bucketPath = toBucketPath(position);\n if (bucketPath.length > context.hamtDepth) {\n context.lastBucket = bucketPath[context.hamtDepth];\n prefix = toPrefix(context.lastBucket._posAtParent);\n }\n const link = node.Links.find(link => {\n if (link.Name == null) {\n return false;\n }\n const entryPrefix = link.Name.substring(0, 2);\n const entryName = link.Name.substring(2);\n if (entryPrefix !== prefix) {\n return false;\n }\n if (entryName && entryName !== name) {\n return false;\n }\n return true;\n });\n if (!link) {\n return null;\n }\n if (link.Name != null && link.Name.substring(2) === name) {\n return link.Hash;\n }\n context.hamtDepth++;\n const block = await blockstore.get(link.Hash, options);\n node = dagPb.decode(block);\n return findShardCid(node, name, blockstore, context, options);\n};\n\nmodule.exports = findShardCid;\n","'use strict';\n\nvar extractDataFromBlock = require('../../../utils/extract-data-from-block.js');\nvar validateOffsetAndLength = require('../../../utils/validate-offset-and-length.js');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar errCode = require('err-code');\nvar dagPb = require('@ipld/dag-pb');\nvar dagCbor = require('@ipld/dag-cbor');\nvar raw = require('multiformats/codecs/raw');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar dagCbor__namespace = /*#__PURE__*/_interopNamespace(dagCbor);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\n\nasync function* emitBytes(blockstore, node, start, end, streamPosition = 0, options) {\n if (node instanceof Uint8Array) {\n const buf = extractDataFromBlock(node, streamPosition, start, end);\n if (buf.length) {\n yield buf;\n }\n streamPosition += buf.length;\n return streamPosition;\n }\n if (node.Data == null) {\n throw errCode__default['default'](new Error('no data in PBNode'), 'ERR_NOT_UNIXFS');\n }\n let file;\n try {\n file = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_NOT_UNIXFS');\n }\n if (file.data && file.data.length) {\n const buf = extractDataFromBlock(file.data, streamPosition, start, end);\n if (buf.length) {\n yield buf;\n }\n streamPosition += file.data.length;\n }\n let childStart = streamPosition;\n for (let i = 0; i < node.Links.length; i++) {\n const childLink = node.Links[i];\n const childEnd = streamPosition + file.blockSizes[i];\n if (start >= childStart && start < childEnd || end > childStart && end <= childEnd || start < childStart && end > childEnd) {\n const block = await blockstore.get(childLink.Hash, { signal: options.signal });\n let child;\n switch (childLink.Hash.code) {\n case dagPb__namespace.code:\n child = await dagPb__namespace.decode(block);\n break;\n case raw__namespace.code:\n child = block;\n break;\n case dagCbor__namespace.code:\n child = await dagCbor__namespace.decode(block);\n break;\n default:\n throw Error(`Unsupported codec: ${ childLink.Hash.code }`);\n }\n for await (const buf of emitBytes(blockstore, child, start, end, streamPosition, options)) {\n streamPosition += buf.length;\n yield buf;\n }\n }\n streamPosition = childEnd;\n childStart = childEnd + 1;\n }\n}\nconst fileContent = (cid, node, unixfs, path, resolve, depth, blockstore) => {\n function yieldFileContent(options = {}) {\n const fileSize = unixfs.fileSize();\n if (fileSize === undefined) {\n throw new Error('File was a directory');\n }\n const {offset, length} = validateOffsetAndLength(fileSize, options.offset, options.length);\n const start = offset;\n const end = offset + length;\n return emitBytes(blockstore, node, start, end, 0, options);\n }\n return yieldFileContent;\n};\n\nmodule.exports = fileContent;\n","'use strict';\n\nfunction extractDataFromBlock(block, blockStart, requestedStart, requestedEnd) {\n const blockLength = block.length;\n const blockEnd = blockStart + blockLength;\n if (requestedStart >= blockEnd || requestedEnd < blockStart) {\n return new Uint8Array(0);\n }\n if (requestedEnd >= blockStart && requestedEnd < blockEnd) {\n block = block.slice(0, requestedEnd - blockStart);\n }\n if (requestedStart >= blockStart && requestedStart < blockEnd) {\n block = block.slice(requestedStart - blockStart);\n }\n return block;\n}\n\nmodule.exports = extractDataFromBlock;\n","'use strict';\n\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst validateOffsetAndLength = (size, offset, length) => {\n if (!offset) {\n offset = 0;\n }\n if (offset < 0) {\n throw errCode__default['default'](new Error('Offset must be greater than or equal to 0'), 'ERR_INVALID_PARAMS');\n }\n if (offset > size) {\n throw errCode__default['default'](new Error('Offset must be less than the file size'), 'ERR_INVALID_PARAMS');\n }\n if (!length && length !== 0) {\n length = size - offset;\n }\n if (length < 0) {\n throw errCode__default['default'](new Error('Length must be greater than or equal to 0'), 'ERR_INVALID_PARAMS');\n }\n if (offset + length > size) {\n length = size - offset;\n }\n return {\n offset,\n length\n };\n};\n\nmodule.exports = validateOffsetAndLength;\n","'use strict';\n\nconst directoryContent = (cid, node, unixfs, path, resolve, depth, blockstore) => {\n async function* yieldDirectoryContent(options = {}) {\n const offset = options.offset || 0;\n const length = options.length || node.Links.length;\n const links = node.Links.slice(offset, length);\n for (const link of links) {\n const result = await resolve(link.Hash, link.Name || '', `${ path }/${ link.Name || '' }`, [], depth + 1, blockstore, options);\n if (result.entry) {\n yield result.entry;\n }\n }\n }\n return yieldDirectoryContent;\n};\n\nmodule.exports = directoryContent;\n","'use strict';\n\nvar dagPb = require('@ipld/dag-pb');\n\nconst hamtShardedDirectoryContent = (cid, node, unixfs, path, resolve, depth, blockstore) => {\n function yieldHamtDirectoryContent(options = {}) {\n return listDirectory(node, path, resolve, depth, blockstore, options);\n }\n return yieldHamtDirectoryContent;\n};\nasync function* listDirectory(node, path, resolve, depth, blockstore, options) {\n const links = node.Links;\n for (const link of links) {\n const name = link.Name != null ? link.Name.substring(2) : null;\n if (name) {\n const result = await resolve(link.Hash, name, `${ path }/${ name }`, [], depth + 1, blockstore, options);\n yield result.entry;\n } else {\n const block = await blockstore.get(link.Hash);\n node = dagPb.decode(block);\n for await (const file of listDirectory(node, path, resolve, depth, blockstore, options)) {\n yield file;\n }\n }\n }\n}\n\nmodule.exports = hamtShardedDirectoryContent;\n","'use strict';\n\nvar errCode = require('err-code');\nvar extractDataFromBlock = require('../utils/extract-data-from-block.js');\nvar validateOffsetAndLength = require('../utils/validate-offset-and-length.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst rawContent = node => {\n async function* contentGenerator(options = {}) {\n const {offset, length} = validateOffsetAndLength(node.length, options.offset, options.length);\n yield extractDataFromBlock(node, 0, offset, offset + length);\n }\n return contentGenerator;\n};\nconst resolve = async (cid, name, path, toResolve, resolve, depth, blockstore, options) => {\n if (toResolve.length) {\n throw errCode__default['default'](new Error(`No link named ${ path } found in raw node ${ cid }`), 'ERR_NOT_FOUND');\n }\n const block = await blockstore.get(cid, options);\n return {\n entry: {\n type: 'raw',\n name,\n path,\n cid,\n content: rawContent(block),\n depth,\n size: block.length,\n node: block\n }\n };\n};\n\nmodule.exports = resolve;\n","'use strict';\n\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\nvar dagCbor = require('@ipld/dag-cbor');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagCbor__namespace = /*#__PURE__*/_interopNamespace(dagCbor);\n\nconst resolve = async (cid$1, name, path, toResolve, resolve, depth, blockstore, options) => {\n const block = await blockstore.get(cid$1);\n const object = dagCbor__namespace.decode(block);\n let subObject = object;\n let subPath = path;\n while (toResolve.length) {\n const prop = toResolve[0];\n if (prop in subObject) {\n toResolve.shift();\n subPath = `${ subPath }/${ prop }`;\n const subObjectCid = cid.CID.asCID(subObject[prop]);\n if (subObjectCid) {\n return {\n entry: {\n type: 'object',\n name,\n path,\n cid: cid$1,\n node: block,\n depth,\n size: block.length,\n content: async function* () {\n yield object;\n }\n },\n next: {\n cid: subObjectCid,\n name: prop,\n path: subPath,\n toResolve\n }\n };\n }\n subObject = subObject[prop];\n } else {\n throw errCode__default['default'](new Error(`No property named ${ prop } found in cbor node ${ cid$1 }`), 'ERR_NO_PROP');\n }\n }\n return {\n entry: {\n type: 'object',\n name,\n path,\n cid: cid$1,\n node: block,\n depth,\n size: block.length,\n content: async function* () {\n yield object;\n }\n }\n };\n};\n\nmodule.exports = resolve;\n","'use strict';\n\nvar errCode = require('err-code');\nvar extractDataFromBlock = require('../utils/extract-data-from-block.js');\nvar validateOffsetAndLength = require('../utils/validate-offset-and-length.js');\nvar mh = require('multiformats/hashes/digest');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar mh__namespace = /*#__PURE__*/_interopNamespace(mh);\n\nconst rawContent = node => {\n async function* contentGenerator(options = {}) {\n const {offset, length} = validateOffsetAndLength(node.length, options.offset, options.length);\n yield extractDataFromBlock(node, 0, offset, offset + length);\n }\n return contentGenerator;\n};\nconst resolve = async (cid, name, path, toResolve, resolve, depth, blockstore, options) => {\n if (toResolve.length) {\n throw errCode__default['default'](new Error(`No link named ${ path } found in raw node ${ cid }`), 'ERR_NOT_FOUND');\n }\n const buf = await mh__namespace.decode(cid.multihash.bytes);\n return {\n entry: {\n type: 'identity',\n name,\n path,\n cid,\n content: rawContent(buf.digest),\n depth,\n size: buf.digest.length,\n node: buf.digest\n }\n };\n};\n\nmodule.exports = resolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar errCode = require('err-code');\nvar utils = require('../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar cid = require('multiformats/cid');\nvar itTar = require('it-tar');\nvar itPipe = require('it-pipe');\nvar Pako = require('pako');\nvar map = require('it-map');\nvar toBuffer = require('it-to-buffer');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar Pako__default = /*#__PURE__*/_interopDefaultLegacy(Pako);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar toBuffer__default = /*#__PURE__*/_interopDefaultLegacy(toBuffer);\n\nconst DEFAULT_COMPRESSION_LEVEL = 6;\nfunction createGet({repo, preload}) {\n async function* get(ipfsPath, options = {}) {\n if (options.compressionLevel < 0 || options.compressionLevel > 9) {\n throw errCode__default['default'](new Error('Compression level must be between 1 and 9'), 'ERR_INVALID_PARAMS');\n }\n if (options.preload !== false) {\n let pathComponents;\n try {\n pathComponents = utils.normalizeCidPath(ipfsPath).split('/');\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_PATH');\n }\n preload(cid.CID.parse(pathComponents[0]));\n }\n const ipfsPathOrCid = cid.CID.asCID(ipfsPath) || ipfsPath;\n const file = await ipfsUnixfsExporter.exporter(ipfsPathOrCid, repo.blocks, options);\n if (file.type === 'file' || file.type === 'raw') {\n const args = [];\n if (!options.compress || options.archive === true) {\n args.push([{\n header: {\n name: file.path,\n mode: file.type === 'file' && file.unixfs.mode,\n mtime: file.type === 'file' && file.unixfs.mtime ? new Date(file.unixfs.mtime.secs * 1000) : undefined,\n size: file.size,\n type: 'file'\n },\n body: file.content()\n }], itTar.pack(), source => map__default['default'](source, buf => buf.slice()));\n } else {\n args.push(file.content);\n }\n if (options.compress) {\n args.push(async function* (source) {\n const buf = await toBuffer__default['default'](source);\n yield Pako__default['default'].gzip(buf, { level: options.compressionLevel || DEFAULT_COMPRESSION_LEVEL });\n });\n }\n yield* itPipe.pipe(...args);\n return;\n }\n if (file.type === 'directory') {\n const args = [\n ipfsUnixfsExporter.recursive(ipfsPathOrCid, repo.blocks, options),\n async function* (source) {\n for await (const entry of source) {\n const output = {\n header: {\n name: entry.path,\n size: entry.size\n }\n };\n if (entry.type === 'file') {\n output.header.type = 'file';\n output.header.mode = entry.unixfs.mode != null ? entry.unixfs.mode : undefined;\n output.header.mtime = entry.unixfs.mtime ? new Date(entry.unixfs.mtime.secs * 1000) : undefined;\n output.body = entry.content();\n } else if (entry.type === 'raw') {\n output.header.type = 'file';\n output.body = entry.content();\n } else if (entry.type === 'directory') {\n output.header.type = 'directory';\n output.header.mode = entry.unixfs.mode != null ? entry.unixfs.mode : undefined;\n output.header.mtime = entry.unixfs.mtime ? new Date(entry.unixfs.mtime.secs * 1000) : undefined;\n } else {\n throw errCode__default['default'](new Error('Not a UnixFS node'), 'ERR_NOT_UNIXFS');\n }\n yield output;\n }\n },\n itTar.pack(),\n source => map__default['default'](source, buf => buf.slice())\n ];\n if (options.compress) {\n if (!options.archive) {\n throw errCode__default['default'](new Error('file is not regular'), 'ERR_INVALID_PATH');\n }\n if (options.compress) {\n args.push(async function* (source) {\n const buf = await toBuffer__default['default'](source);\n yield Pako__default['default'].gzip(buf, { level: options.compressionLevel || DEFAULT_COMPRESSION_LEVEL });\n });\n }\n }\n yield* itPipe.pipe(...args);\n return;\n }\n throw errCode__default['default'](new Error('Not a UnixFS node'), 'ERR_NOT_UNIXFS');\n }\n return withTimeoutOption.withTimeoutOption(get);\n}\n\nexports.createGet = createGet;\n","exports.extract = require('./extract')\nexports.pack = require('./pack')\n","const defer = require('p-defer')\nconst Headers = require('./extract-headers')\nconst LteReader = require('./lte-reader')\n\nfunction getPadding (size) {\n size &= 511\n return size && 512 - size\n}\n\nasync function discardPadding (reader, size) {\n const overflow = getPadding(size)\n if (overflow) await reader.next(overflow)\n}\n\nmodule.exports = options => {\n options = options || {}\n options.highWaterMark = options.highWaterMark || 1024 * 16\n\n return source => (async function * () {\n const reader = LteReader(source)\n let gnuLongPath, gnuLongLinkPath, paxGlobal, pax\n\n try {\n while (true) {\n let headerBytes\n try {\n const { done, value } = await reader.next(512)\n if (done) return\n headerBytes = value\n } catch (err) {\n // Is ok, this is the end of the stream!\n if (err.code === 'ERR_UNDER_READ') return\n throw err\n }\n\n const header = Headers.decode(headerBytes, options.filenameEncoding)\n if (!header) continue\n\n if (header.type === 'gnu-long-path') {\n const { done, value: gnuLongPathBytes } = await reader.next(header.size)\n if (done) return\n gnuLongPath = Headers.decodeLongPath(gnuLongPathBytes, options.filenameEncoding)\n await discardPadding(reader, header.size)\n continue\n }\n\n if (header.type === 'gnu-long-link-path') {\n const { done, value: gnuLongLinkPathBytes } = await reader.next(header.size)\n if (done) return\n gnuLongLinkPath = Headers.decodeLongPath(gnuLongLinkPathBytes, options.filenameEncoding)\n await discardPadding(reader, header.size)\n continue\n }\n\n if (header.type === 'pax-global-header') {\n const { done, value: paxGlobalBytes } = await reader.next(header.size)\n if (done) return\n paxGlobal = Headers.decodePax(paxGlobalBytes, options.filenameEncoding)\n await discardPadding(reader, header.size)\n continue\n }\n\n if (header.type === 'pax-header') {\n const { done, value: paxBytes } = await reader.next(header.size)\n if (done) return\n pax = Headers.decodePax(paxBytes, options.filenameEncoding)\n if (paxGlobal) pax = { ...paxGlobal, ...pax }\n await discardPadding(reader, header.size)\n continue\n }\n\n if (gnuLongPath) {\n header.name = gnuLongPath\n gnuLongPath = null\n }\n\n if (gnuLongLinkPath) {\n header.linkname = gnuLongLinkPath\n gnuLongLinkPath = null\n }\n\n if (pax) {\n if (pax.path) header.name = pax.path\n if (pax.linkpath) header.linkname = pax.linkpath\n if (pax.size) header.size = parseInt(pax.size, 10)\n header.pax = pax\n pax = null\n }\n\n if (!header.size || header.type === 'directory') {\n yield { header, body: (async function * () {})() }\n continue\n }\n\n let bytesRemaining = header.size\n const bodyConsumed = defer()\n\n // Prefetch the first chunk.\n // This allows us to stream entries for small files from the tar without\n // explicitly streaming the body of each.\n const firstChunk = await reader.nextLte(Math.min(bytesRemaining, options.highWaterMark))\n bytesRemaining -= firstChunk.value.length\n\n if (!bytesRemaining) bodyConsumed.resolve()\n\n const body = (async function * () {\n try {\n yield firstChunk.value\n\n while (bytesRemaining) {\n const { done, value } = await reader.nextLte(bytesRemaining)\n if (done) {\n bytesRemaining = 0\n return\n }\n bytesRemaining -= value.length\n yield value\n }\n } finally {\n bodyConsumed.resolve()\n }\n })()\n\n yield { header, body }\n\n // Wait for the body to be consumed\n await bodyConsumed.promise\n\n // Incase the body was not consumed entirely...\n if (bytesRemaining) {\n for await (const _ of body) {} // eslint-disable-line no-unused-vars,no-empty\n }\n\n await discardPadding(reader, header.size)\n }\n } finally {\n await reader.return()\n }\n })()\n}\n","const { Buffer } = require('buffer')\nconst BufferList = require('bl/BufferList')\n\nconst ZERO_OFFSET = '0'.charCodeAt(0)\nconst USTAR_MAGIC = Buffer.from('ustar\\x00', 'binary')\nconst GNU_MAGIC = Buffer.from('ustar\\x20', 'binary')\nconst GNU_VER = Buffer.from('\\x20\\x00', 'binary')\nconst MAGIC_OFFSET = 257\nconst VERSION_OFFSET = 263\n\nconst clamp = function (index, len, defaultValue) {\n if (typeof index !== 'number') return defaultValue\n index = ~~index // Coerce to integer.\n if (index >= len) return len\n if (index >= 0) return index\n index += len\n if (index >= 0) return index\n return 0\n}\n\nconst toType = function (flag) {\n switch (flag) {\n case 0:\n return 'file'\n case 1:\n return 'link'\n case 2:\n return 'symlink'\n case 3:\n return 'character-device'\n case 4:\n return 'block-device'\n case 5:\n return 'directory'\n case 6:\n return 'fifo'\n case 7:\n return 'contiguous-file'\n case 72:\n return 'pax-header'\n case 55:\n return 'pax-global-header'\n case 27:\n return 'gnu-long-link-path'\n case 28:\n case 30:\n return 'gnu-long-path'\n }\n\n return null\n}\n\nconst indexOf = function (block, num, offset, end) {\n for (; offset < end; offset++) {\n if (block.get(offset) === num) return offset\n }\n return end\n}\n\nconst cksum = function (block) {\n let sum = 8 * 32\n for (let i = 0; i < 148; i++) sum += block.get(i)\n for (let j = 156; j < 512; j++) sum += block.get(j)\n return sum\n}\n\n/* Copied from the node-tar repo and modified to meet\n * tar-stream coding standard.\n *\n * Source: https://github.com/npm/node-tar/blob/51b6627a1f357d2eb433e7378e5f05e83b7aa6cd/lib/header.js#L349\n */\nfunction parse256 (buf) {\n // first byte MUST be either 80 or FF\n // 80 for positive, FF for 2's comp\n let positive\n if (buf.get(0) === 0x80) positive = true\n else if (buf.get(0) === 0xFF) positive = false\n else return null\n\n // build up a base-256 tuple from the least sig to the highest\n let zero = false\n const tuple = []\n for (let i = buf.length - 1; i > 0; i--) {\n const byte = buf.get(i)\n if (positive) tuple.push(byte)\n else if (zero && byte === 0) tuple.push(0)\n else if (zero) {\n zero = false\n tuple.push(0x100 - byte)\n } else tuple.push(0xFF - byte)\n }\n\n let sum = 0\n const l = tuple.length\n for (let i = 0; i < l; i++) {\n sum += tuple[i] * Math.pow(256, i)\n }\n\n return positive ? sum : -1 * sum\n}\n\nconst decodeOct = function (val, offset, length) {\n val = val.shallowSlice(offset, offset + length)\n offset = 0\n\n // If prefixed with 0x80 then parse as a base-256 integer\n if (val.get(offset) & 0x80) {\n return parse256(val)\n } else {\n // Older versions of tar can prefix with spaces\n while (offset < val.length && val.get(offset) === 32) offset++\n const end = clamp(indexOf(val, 32, offset, val.length), val.length, val.length)\n while (offset < end && val.get(offset) === 0) offset++\n if (end === offset) return 0\n return parseInt(val.shallowSlice(offset, end).toString(), 8)\n }\n}\n\nconst decodeStr = function (val, offset, length, encoding) {\n return val.shallowSlice(offset, indexOf(val, 0, offset, offset + length)).toString(encoding)\n}\n\nexports.decodeLongPath = function (buf, encoding) {\n buf = BufferList.isBufferList(buf) ? buf : new BufferList(buf)\n return decodeStr(buf, 0, buf.length, encoding)\n}\n\nexports.decodePax = function (buf) {\n buf = BufferList.isBufferList(buf) ? buf : new BufferList(buf)\n const result = {}\n\n while (buf.length) {\n let i = 0\n while (i < buf.length && buf.get(i) !== 32) i++\n const len = parseInt(buf.shallowSlice(0, i).toString(), 10)\n if (!len) return result\n\n const b = buf.shallowSlice(i + 1, len - 1).toString()\n const keyIndex = b.indexOf('=')\n if (keyIndex === -1) return result\n result[b.slice(0, keyIndex)] = b.slice(keyIndex + 1)\n\n buf = buf.shallowSlice(len)\n }\n\n return result\n}\n\nexports.decode = function (buf, filenameEncoding) {\n buf = BufferList.isBufferList(buf) ? buf : new BufferList(buf)\n let typeflag = buf.get(156) === 0 ? 0 : buf.get(156) - ZERO_OFFSET\n\n let name = decodeStr(buf, 0, 100, filenameEncoding)\n const mode = decodeOct(buf, 100, 8)\n const uid = decodeOct(buf, 108, 8)\n const gid = decodeOct(buf, 116, 8)\n const size = decodeOct(buf, 124, 12)\n const mtime = decodeOct(buf, 136, 12)\n const type = toType(typeflag)\n const linkname = buf.get(157) === 0 ? null : decodeStr(buf, 157, 100, filenameEncoding)\n const uname = decodeStr(buf, 265, 32)\n const gname = decodeStr(buf, 297, 32)\n const devmajor = decodeOct(buf, 329, 8)\n const devminor = decodeOct(buf, 337, 8)\n\n const c = cksum(buf)\n\n // checksum is still initial value if header was null.\n if (c === 8 * 32) return null\n\n // valid checksum\n if (c !== decodeOct(buf, 148, 8)) throw new Error('Invalid tar header. Maybe the tar is corrupted or it needs to be gunzipped?')\n\n if (USTAR_MAGIC.compare(buf.slice(MAGIC_OFFSET, MAGIC_OFFSET + 6)) === 0) {\n // ustar (posix) format.\n // prepend prefix, if present.\n if (buf.get(345)) name = decodeStr(buf, 345, 155, filenameEncoding) + '/' + name\n } else if (GNU_MAGIC.compare(buf.slice(MAGIC_OFFSET, MAGIC_OFFSET + 6)) === 0 &&\n GNU_VER.compare(buf.slice(VERSION_OFFSET, VERSION_OFFSET + 2)) === 0) {\n // 'gnu'/'oldgnu' format. Similar to ustar, but has support for incremental and\n // multi-volume tarballs.\n } else {\n throw new Error('Invalid tar header: unknown format.')\n }\n\n // to support old tar versions that use trailing / to indicate dirs\n if (typeflag === 0 && name && name[name.length - 1] === '/') typeflag = 5\n\n return {\n name: name,\n mode: mode,\n uid: uid,\n gid: gid,\n size: size,\n mtime: new Date(1000 * mtime),\n type: type,\n linkname: linkname,\n uname: uname,\n gname: gname,\n devmajor: devmajor,\n devminor: devminor\n }\n}\n","const BufferList = require('bl/BufferList')\nconst Reader = require('it-reader')\n\nmodule.exports = function LteReader (source) {\n const reader = Reader(source)\n let overflow\n const lteReader = {\n [Symbol.asyncIterator]: () => lteReader,\n async next (bytes) {\n if (overflow) {\n let value\n if (bytes == null || overflow.length === bytes) {\n value = overflow\n overflow = null\n } else if (overflow.length > bytes) {\n value = overflow.shallowSlice(0, bytes)\n overflow = overflow.shallowSlice(bytes)\n } else if (overflow.length < bytes) {\n const { value: nextValue, done } = await reader.next(bytes - overflow.length)\n if (done) {\n throw Object.assign(\n new Error(`stream ended before ${bytes - overflow.length} bytes became available`),\n { code: 'ERR_UNDER_READ' }\n )\n }\n value = new BufferList([overflow, nextValue])\n overflow = null\n }\n return { value }\n }\n return reader.next(bytes)\n },\n async nextLte (bytes) {\n let { done, value } = await lteReader.next()\n if (done) return { done }\n if (value.length <= bytes) return { value }\n value = BufferList.isBufferList(value) ? value : new BufferList(value)\n if (overflow) {\n overflow.append(value.shallowSlice(bytes))\n } else {\n overflow = value.shallowSlice(bytes)\n }\n return { value: value.shallowSlice(0, bytes) }\n },\n return () {\n return reader.return()\n }\n }\n return lteReader\n}\n","const BufferList = require('bl/BufferList')\n\nmodule.exports = source => {\n const reader = (async function * () {\n let bytes = yield // Allows us to receive 8 when reader.next(8) is called\n let bl = new BufferList()\n\n for await (const chunk of source) {\n if (!bytes) {\n bytes = yield bl.append(chunk)\n bl = new BufferList()\n continue\n }\n\n bl.append(chunk)\n\n while (bl.length >= bytes) {\n const data = bl.shallowSlice(0, bytes)\n bl.consume(bytes)\n bytes = yield data\n\n // If we no longer want a specific byte length, we yield the rest now\n if (!bytes) {\n if (bl.length) {\n bytes = yield bl\n bl = new BufferList()\n }\n break // bytes is null and/or no more buffer to yield\n }\n }\n }\n\n // Consumer wants more bytes but the source has ended and our buffer\n // is not big enough to satisfy.\n if (bytes) {\n throw Object.assign(\n new Error(`stream ended before ${bytes} bytes became available`),\n { code: 'ERR_UNDER_READ', buffer: bl }\n )\n }\n })()\n\n reader.next()\n return reader\n}\n","const { Buffer } = require('buffer')\nconst BufferList = require('bl/BufferList')\nconst { S_IFMT, S_IFBLK, S_IFCHR, S_IFDIR, S_IFIFO, S_IFLNK } = require('iso-constants')\nconst concat = require('it-concat')\nconst Headers = require('./pack-headers')\n\nconst DMODE = parseInt('755', 8)\nconst FMODE = parseInt('644', 8)\n\nconst END_OF_TAR = Buffer.alloc(1024)\n\nfunction modeToType (mode) {\n switch (mode & S_IFMT) {\n case S_IFBLK: return 'block-device'\n case S_IFCHR: return 'character-device'\n case S_IFDIR: return 'directory'\n case S_IFIFO: return 'fifo'\n case S_IFLNK: return 'symlink'\n }\n return 'file'\n}\n\nfunction getPadding (size) {\n size &= 511\n if (size) return new BufferList(END_OF_TAR.slice(0, 512 - size))\n}\n\nfunction encode (header) {\n if (!header.pax) {\n const encoded = Headers.encode(header)\n if (encoded) return encoded\n }\n return encodePax(header)\n}\n\nfunction encodePax (header) {\n const paxHeader = Headers.encodePax({\n name: header.name,\n linkname: header.linkname,\n pax: header.pax\n })\n\n const newHeader = {\n name: 'PaxHeader',\n mode: header.mode,\n uid: header.uid,\n gid: header.gid,\n size: paxHeader.length,\n mtime: header.mtime,\n type: 'pax-header',\n linkname: header.linkname && 'PaxHeader',\n uname: header.uname,\n gname: header.gname,\n devmajor: header.devmajor,\n devminor: header.devminor\n }\n\n return new BufferList([\n Headers.encode(newHeader),\n paxHeader,\n getPadding(paxHeader.length),\n Headers.encode({ ...newHeader, size: header.size, type: header.type })\n ])\n}\n\nmodule.exports = () => async function * (source) {\n for await (let { header, body } of source) {\n if (!header.size || header.type === 'symlink') header.size = 0\n if (!header.type) header.type = modeToType(header.mode)\n if (!header.mode) header.mode = header.type === 'directory' ? DMODE : FMODE\n if (!header.uid) header.uid = 0\n if (!header.gid) header.gid = 0\n if (!header.mtime) header.mtime = new Date()\n\n if (typeof body === 'string') body = Buffer.from(body)\n\n if (Buffer.isBuffer(body) || BufferList.isBufferList(body)) {\n header.size = body.length\n yield new BufferList([encode(header), body, getPadding(header.size)])\n continue\n }\n\n if (header.type === 'symlink' && !header.linkname) {\n header.linkname = (await concat(body)).toString()\n yield encode(header)\n continue\n }\n\n yield encode(header)\n\n if (header.type !== 'file' && header.type !== 'contiguous-file') {\n continue\n }\n\n let written = 0\n for await (const chunk of body) {\n written += chunk.length\n yield BufferList.isBufferList(chunk) ? chunk : new BufferList(chunk)\n }\n\n if (written !== header.size) { // corrupting tar\n throw new Error('size mismatch')\n }\n\n const overflow = getPadding(header.size)\n if (overflow) yield overflow\n }\n\n yield new BufferList(END_OF_TAR)\n}\n","\n'use strict';\n\nmodule.exports = {\n 'RTLD_LAZY': 1,\n 'RTLD_NOW': 2,\n 'RTLD_GLOBAL': 256,\n 'RTLD_LOCAL': 0,\n 'RTLD_DEEPBIND': 8,\n 'E2BIG': 7,\n 'EACCES': 13,\n 'EADDRINUSE': 98,\n 'EADDRNOTAVAIL': 99,\n 'EAFNOSUPPORT': 97,\n 'EAGAIN': 11,\n 'EALREADY': 114,\n 'EBADF': 9,\n 'EBADMSG': 74,\n 'EBUSY': 16,\n 'ECANCELED': 125,\n 'ECHILD': 10,\n 'ECONNABORTED': 103,\n 'ECONNREFUSED': 111,\n 'ECONNRESET': 104,\n 'EDEADLK': 35,\n 'EDESTADDRREQ': 89,\n 'EDOM': 33,\n 'EDQUOT': 122,\n 'EEXIST': 17,\n 'EFAULT': 14,\n 'EFBIG': 27,\n 'EHOSTUNREACH': 113,\n 'EIDRM': 43,\n 'EILSEQ': 84,\n 'EINPROGRESS': 115,\n 'EINTR': 4,\n 'EINVAL': 22,\n 'EIO': 5,\n 'EISCONN': 106,\n 'EISDIR': 21,\n 'ELOOP': 40,\n 'EMFILE': 24,\n 'EMLINK': 31,\n 'EMSGSIZE': 90,\n 'EMULTIHOP': 72,\n 'ENAMETOOLONG': 36,\n 'ENETDOWN': 100,\n 'ENETRESET': 102,\n 'ENETUNREACH': 101,\n 'ENFILE': 23,\n 'ENOBUFS': 105,\n 'ENODATA': 61,\n 'ENODEV': 19,\n 'ENOENT': 2,\n 'ENOEXEC': 8,\n 'ENOLCK': 37,\n 'ENOLINK': 67,\n 'ENOMEM': 12,\n 'ENOMSG': 42,\n 'ENOPROTOOPT': 92,\n 'ENOSPC': 28,\n 'ENOSR': 63,\n 'ENOSTR': 60,\n 'ENOSYS': 38,\n 'ENOTCONN': 107,\n 'ENOTDIR': 20,\n 'ENOTEMPTY': 39,\n 'ENOTSOCK': 88,\n 'ENOTSUP': 95,\n 'ENOTTY': 25,\n 'ENXIO': 6,\n 'EOPNOTSUPP': 95,\n 'EOVERFLOW': 75,\n 'EPERM': 1,\n 'EPIPE': 32,\n 'EPROTO': 71,\n 'EPROTONOSUPPORT': 93,\n 'EPROTOTYPE': 91,\n 'ERANGE': 34,\n 'EROFS': 30,\n 'ESPIPE': 29,\n 'ESRCH': 3,\n 'ESTALE': 116,\n 'ETIME': 62,\n 'ETIMEDOUT': 110,\n 'ETXTBSY': 26,\n 'EWOULDBLOCK': 11,\n 'EXDEV': 18,\n 'PRIORITY_LOW': 19,\n 'PRIORITY_BELOW_NORMAL': 10,\n 'PRIORITY_NORMAL': 0,\n 'PRIORITY_ABOVE_NORMAL': -7,\n 'PRIORITY_HIGH': -14,\n 'PRIORITY_HIGHEST': -20,\n 'SIGHUP': 1,\n 'SIGINT': 2,\n 'SIGQUIT': 3,\n 'SIGILL': 4,\n 'SIGTRAP': 5,\n 'SIGABRT': 6,\n 'SIGIOT': 6,\n 'SIGBUS': 7,\n 'SIGFPE': 8,\n 'SIGKILL': 9,\n 'SIGUSR1': 10,\n 'SIGSEGV': 11,\n 'SIGUSR2': 12,\n 'SIGPIPE': 13,\n 'SIGALRM': 14,\n 'SIGTERM': 15,\n 'SIGCHLD': 17,\n 'SIGSTKFLT': 16,\n 'SIGCONT': 18,\n 'SIGSTOP': 19,\n 'SIGTSTP': 20,\n 'SIGTTIN': 21,\n 'SIGTTOU': 22,\n 'SIGURG': 23,\n 'SIGXCPU': 24,\n 'SIGXFSZ': 25,\n 'SIGVTALRM': 26,\n 'SIGPROF': 27,\n 'SIGWINCH': 28,\n 'SIGIO': 29,\n 'SIGPOLL': 29,\n 'SIGPWR': 30,\n 'SIGSYS': 31,\n 'SIGUNUSED': 31,\n 'UV_FS_SYMLINK_DIR': 1,\n 'UV_FS_SYMLINK_JUNCTION': 2,\n 'O_RDONLY': 0,\n 'O_WRONLY': 1,\n 'O_RDWR': 2,\n 'UV_DIRENT_UNKNOWN': 0,\n 'UV_DIRENT_FILE': 1,\n 'UV_DIRENT_DIR': 2,\n 'UV_DIRENT_LINK': 3,\n 'UV_DIRENT_FIFO': 4,\n 'UV_DIRENT_SOCKET': 5,\n 'UV_DIRENT_CHAR': 6,\n 'UV_DIRENT_BLOCK': 7,\n 'S_IFMT': 61440,\n 'S_IFREG': 32768,\n 'S_IFDIR': 16384,\n 'S_IFCHR': 8192,\n 'S_IFBLK': 24576,\n 'S_IFIFO': 4096,\n 'S_IFLNK': 40960,\n 'S_IFSOCK': 49152,\n 'O_CREAT': 64,\n 'O_EXCL': 128,\n 'UV_FS_O_FILEMAP': 0,\n 'O_NOCTTY': 256,\n 'O_TRUNC': 512,\n 'O_APPEND': 1024,\n 'O_DIRECTORY': 65536,\n 'O_NOATIME': 262144,\n 'O_NOFOLLOW': 131072,\n 'O_SYNC': 1052672,\n 'O_DSYNC': 4096,\n 'O_DIRECT': 16384,\n 'O_NONBLOCK': 2048,\n 'S_IRWXU': 448,\n 'S_IRUSR': 256,\n 'S_IWUSR': 128,\n 'S_IXUSR': 64,\n 'S_IRWXG': 56,\n 'S_IRGRP': 32,\n 'S_IWGRP': 16,\n 'S_IXGRP': 8,\n 'S_IRWXO': 7,\n 'S_IROTH': 4,\n 'S_IWOTH': 2,\n 'S_IXOTH': 1,\n 'F_OK': 0,\n 'R_OK': 4,\n 'W_OK': 2,\n 'X_OK': 1,\n 'UV_FS_COPYFILE_EXCL': 1,\n 'COPYFILE_EXCL': 1,\n 'UV_FS_COPYFILE_FICLONE': 2,\n 'COPYFILE_FICLONE': 2,\n 'UV_FS_COPYFILE_FICLONE_FORCE': 4,\n 'COPYFILE_FICLONE_FORCE': 4,\n 'OPENSSL_VERSION_NUMBER': 269488319,\n 'SSL_OP_ALL': 2147485780,\n 'SSL_OP_ALLOW_NO_DHE_KEX': 1024,\n 'SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION': 262144,\n 'SSL_OP_CIPHER_SERVER_PREFERENCE': 4194304,\n 'SSL_OP_CISCO_ANYCONNECT': 32768,\n 'SSL_OP_COOKIE_EXCHANGE': 8192,\n 'SSL_OP_CRYPTOPRO_TLSEXT_BUG': 2147483648,\n 'SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS': 2048,\n 'SSL_OP_EPHEMERAL_RSA': 0,\n 'SSL_OP_LEGACY_SERVER_CONNECT': 4,\n 'SSL_OP_MICROSOFT_BIG_SSLV3_BUFFER': 0,\n 'SSL_OP_MICROSOFT_SESS_ID_BUG': 0,\n 'SSL_OP_MSIE_SSLV2_RSA_PADDING': 0,\n 'SSL_OP_NETSCAPE_CA_DN_BUG': 0,\n 'SSL_OP_NETSCAPE_CHALLENGE_BUG': 0,\n 'SSL_OP_NETSCAPE_DEMO_CIPHER_CHANGE_BUG': 0,\n 'SSL_OP_NETSCAPE_REUSE_CIPHER_CHANGE_BUG': 0,\n 'SSL_OP_NO_COMPRESSION': 131072,\n 'SSL_OP_NO_ENCRYPT_THEN_MAC': 524288,\n 'SSL_OP_NO_QUERY_MTU': 4096,\n 'SSL_OP_NO_RENEGOTIATION': 1073741824,\n 'SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION': 65536,\n 'SSL_OP_NO_SSLv2': 0,\n 'SSL_OP_NO_SSLv3': 33554432,\n 'SSL_OP_NO_TICKET': 16384,\n 'SSL_OP_NO_TLSv1': 67108864,\n 'SSL_OP_NO_TLSv1_1': 268435456,\n 'SSL_OP_NO_TLSv1_2': 134217728,\n 'SSL_OP_NO_TLSv1_3': 536870912,\n 'SSL_OP_PKCS1_CHECK_1': 0,\n 'SSL_OP_PKCS1_CHECK_2': 0,\n 'SSL_OP_PRIORITIZE_CHACHA': 2097152,\n 'SSL_OP_SINGLE_DH_USE': 0,\n 'SSL_OP_SINGLE_ECDH_USE': 0,\n 'SSL_OP_SSLEAY_080_CLIENT_DH_BUG': 0,\n 'SSL_OP_SSLREF2_REUSE_CERT_TYPE_BUG': 0,\n 'SSL_OP_TLS_BLOCK_PADDING_BUG': 0,\n 'SSL_OP_TLS_D5_BUG': 0,\n 'SSL_OP_TLS_ROLLBACK_BUG': 8388608,\n 'ENGINE_METHOD_RSA': 1,\n 'ENGINE_METHOD_DSA': 2,\n 'ENGINE_METHOD_DH': 4,\n 'ENGINE_METHOD_RAND': 8,\n 'ENGINE_METHOD_EC': 2048,\n 'ENGINE_METHOD_CIPHERS': 64,\n 'ENGINE_METHOD_DIGESTS': 128,\n 'ENGINE_METHOD_PKEY_METHS': 512,\n 'ENGINE_METHOD_PKEY_ASN1_METHS': 1024,\n 'ENGINE_METHOD_ALL': 65535,\n 'ENGINE_METHOD_NONE': 0,\n 'DH_CHECK_P_NOT_SAFE_PRIME': 2,\n 'DH_CHECK_P_NOT_PRIME': 1,\n 'DH_UNABLE_TO_CHECK_GENERATOR': 4,\n 'DH_NOT_SUITABLE_GENERATOR': 8,\n 'ALPN_ENABLED': 1,\n 'RSA_PKCS1_PADDING': 1,\n 'RSA_SSLV23_PADDING': 2,\n 'RSA_NO_PADDING': 3,\n 'RSA_PKCS1_OAEP_PADDING': 4,\n 'RSA_X931_PADDING': 5,\n 'RSA_PKCS1_PSS_PADDING': 6,\n 'RSA_PSS_SALTLEN_DIGEST': -1,\n 'RSA_PSS_SALTLEN_MAX_SIGN': -2,\n 'RSA_PSS_SALTLEN_AUTO': -2,\n 'defaultCoreCipherList': 'TLS_AES_256_GCM_SHA384:TLS_CHACHA20_POLY1305_SHA256:TLS_AES_128_GCM_SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA384:DHE-RSA-AES256-SHA384:ECDHE-RSA-AES256-SHA256:DHE-RSA-AES256-SHA256:HIGH:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!SRP:!CAMELLIA',\n 'TLS1_VERSION': 769,\n 'TLS1_1_VERSION': 770,\n 'TLS1_2_VERSION': 771,\n 'TLS1_3_VERSION': 772,\n 'POINT_CONVERSION_COMPRESSED': 2,\n 'POINT_CONVERSION_UNCOMPRESSED': 4,\n 'POINT_CONVERSION_HYBRID': 6\n};\n\n","const BufferList = require('bl/BufferList')\n\nconst TypeDefault = {\n string: () => '',\n buffer: () => BufferList()\n}\n\nmodule.exports = async (source, options) => {\n options = options || {}\n\n if (options.type && !TypeDefault[options.type]) {\n throw new Error(`invalid type \"${options.type}\"`)\n }\n\n let res, type\n for await (const chunk of source) {\n if (!res) {\n type = options.type || (typeof chunk === 'string' ? 'string' : 'buffer')\n res = TypeDefault[type]()\n }\n\n if (type === 'string') {\n res += chunk\n } else {\n res.append(chunk)\n }\n }\n\n return res || TypeDefault[options.type || 'buffer']()\n}\n","const { Buffer } = require('buffer')\n\nconst alloc = Buffer.alloc\n\nconst ZEROS = '0000000000000000000'\nconst SEVENS = '7777777777777777777'\nconst ZERO_OFFSET = '0'.charCodeAt(0)\nconst USTAR_MAGIC = Buffer.from('ustar\\x00', 'binary')\nconst USTAR_VER = Buffer.from('00', 'binary')\nconst MASK = parseInt('7777', 8)\nconst MAGIC_OFFSET = 257\nconst VERSION_OFFSET = 263\n\nconst toTypeflag = function (flag) {\n switch (flag) {\n case 'file':\n return 0\n case 'link':\n return 1\n case 'symlink':\n return 2\n case 'character-device':\n return 3\n case 'block-device':\n return 4\n case 'directory':\n return 5\n case 'fifo':\n return 6\n case 'contiguous-file':\n return 7\n case 'pax-header':\n return 72\n }\n\n return 0\n}\n\nconst cksum = function (block) {\n let sum = 8 * 32\n for (let i = 0; i < 148; i++) sum += block[i]\n for (let j = 156; j < 512; j++) sum += block[j]\n return sum\n}\n\nconst encodeOct = function (val, n) {\n val = val.toString(8)\n if (val.length > n) return SEVENS.slice(0, n) + ' '\n else return ZEROS.slice(0, n - val.length) + val + ' '\n}\n\nconst addLength = function (str) {\n const len = Buffer.byteLength(str)\n let digits = Math.floor(Math.log(len) / Math.log(10)) + 1\n if (len + digits >= Math.pow(10, digits)) digits++\n\n return (len + digits) + str\n}\n\nexports.encodePax = function (opts) { // TODO: encode more stuff in pax\n let result = ''\n if (opts.name) result += addLength(' path=' + opts.name + '\\n')\n if (opts.linkname) result += addLength(' linkpath=' + opts.linkname + '\\n')\n const pax = opts.pax\n if (pax) {\n for (const key in pax) {\n result += addLength(' ' + key + '=' + pax[key] + '\\n')\n }\n }\n return Buffer.from(result)\n}\n\nexports.encode = function (opts) {\n const buf = alloc(512)\n let name = opts.name\n let prefix = ''\n\n if (opts.typeflag === 5 && name[name.length - 1] !== '/') name += '/'\n if (Buffer.byteLength(name) !== name.length) return null // utf-8\n\n while (Buffer.byteLength(name) > 100) {\n const i = name.indexOf('/')\n if (i === -1) return null\n prefix += prefix ? '/' + name.slice(0, i) : name.slice(0, i)\n name = name.slice(i + 1)\n }\n\n if (Buffer.byteLength(name) > 100 || Buffer.byteLength(prefix) > 155) return null\n if (opts.linkname && Buffer.byteLength(opts.linkname) > 100) return null\n\n buf.write(name)\n buf.write(encodeOct(opts.mode & MASK, 6), 100)\n buf.write(encodeOct(opts.uid, 6), 108)\n buf.write(encodeOct(opts.gid, 6), 116)\n buf.write(encodeOct(opts.size, 11), 124)\n buf.write(encodeOct((opts.mtime.getTime() / 1000) | 0, 11), 136)\n\n buf[156] = ZERO_OFFSET + toTypeflag(opts.type)\n\n if (opts.linkname) buf.write(opts.linkname, 157)\n\n USTAR_MAGIC.copy(buf, MAGIC_OFFSET)\n USTAR_VER.copy(buf, VERSION_OFFSET)\n if (opts.uname) buf.write(opts.uname, 265)\n if (opts.gname) buf.write(opts.gname, 297)\n buf.write(encodeOct(opts.devmajor || 0, 6), 329)\n buf.write(encodeOct(opts.devminor || 0, 6), 337)\n\n if (prefix) buf.write(prefix, 345)\n\n buf.write(encodeOct(cksum(buf), 6), 148)\n\n return buf\n}\n","// Top level file is just a mixin of submodules & constants\n'use strict';\n\nvar assign = require('./lib/utils/common').assign;\n\nvar deflate = require('./lib/deflate');\nvar inflate = require('./lib/inflate');\nvar constants = require('./lib/zlib/constants');\n\nvar pako = {};\n\nassign(pako, deflate, inflate, constants);\n\nmodule.exports = pako;\n","'use strict';\n\n\nvar TYPED_OK = (typeof Uint8Array !== 'undefined') &&\n (typeof Uint16Array !== 'undefined') &&\n (typeof Int32Array !== 'undefined');\n\nfunction _has(obj, key) {\n return Object.prototype.hasOwnProperty.call(obj, key);\n}\n\nexports.assign = function (obj /*from1, from2, from3, ...*/) {\n var sources = Array.prototype.slice.call(arguments, 1);\n while (sources.length) {\n var source = sources.shift();\n if (!source) { continue; }\n\n if (typeof source !== 'object') {\n throw new TypeError(source + 'must be non-object');\n }\n\n for (var p in source) {\n if (_has(source, p)) {\n obj[p] = source[p];\n }\n }\n }\n\n return obj;\n};\n\n\n// reduce buffer size, avoiding mem copy\nexports.shrinkBuf = function (buf, size) {\n if (buf.length === size) { return buf; }\n if (buf.subarray) { return buf.subarray(0, size); }\n buf.length = size;\n return buf;\n};\n\n\nvar fnTyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n if (src.subarray && dest.subarray) {\n dest.set(src.subarray(src_offs, src_offs + len), dest_offs);\n return;\n }\n // Fallback to ordinary array\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n var i, l, len, pos, chunk, result;\n\n // calculate data length\n len = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n len += chunks[i].length;\n }\n\n // join chunks\n result = new Uint8Array(len);\n pos = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n chunk = chunks[i];\n result.set(chunk, pos);\n pos += chunk.length;\n }\n\n return result;\n }\n};\n\nvar fnUntyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n return [].concat.apply([], chunks);\n }\n};\n\n\n// Enable/Disable typed arrays use, for testing\n//\nexports.setTyped = function (on) {\n if (on) {\n exports.Buf8 = Uint8Array;\n exports.Buf16 = Uint16Array;\n exports.Buf32 = Int32Array;\n exports.assign(exports, fnTyped);\n } else {\n exports.Buf8 = Array;\n exports.Buf16 = Array;\n exports.Buf32 = Array;\n exports.assign(exports, fnUntyped);\n }\n};\n\nexports.setTyped(TYPED_OK);\n","'use strict';\n\n\nvar zlib_deflate = require('./zlib/deflate');\nvar utils = require('./utils/common');\nvar strings = require('./utils/strings');\nvar msg = require('./zlib/messages');\nvar ZStream = require('./zlib/zstream');\n\nvar toString = Object.prototype.toString;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nvar Z_NO_FLUSH = 0;\nvar Z_FINISH = 4;\n\nvar Z_OK = 0;\nvar Z_STREAM_END = 1;\nvar Z_SYNC_FLUSH = 2;\n\nvar Z_DEFAULT_COMPRESSION = -1;\n\nvar Z_DEFAULT_STRATEGY = 0;\n\nvar Z_DEFLATED = 8;\n\n/* ===========================================================================*/\n\n\n/**\n * class Deflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[deflate]],\n * [[deflateRaw]] and [[gzip]].\n **/\n\n/* internal\n * Deflate.chunks -> Array\n *\n * Chunks of output data, if [[Deflate#onData]] not overridden.\n **/\n\n/**\n * Deflate.result -> Uint8Array|Array\n *\n * Compressed result, generated by default [[Deflate#onData]]\n * and [[Deflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Deflate#push]] with `Z_FINISH` / `true` param) or if you\n * push a chunk with explicit flush (call [[Deflate#push]] with\n * `Z_SYNC_FLUSH` param).\n **/\n\n/**\n * Deflate.err -> Number\n *\n * Error code after deflate finished. 0 (Z_OK) on success.\n * You will not need it in real life, because deflate errors\n * are possible only on wrong options or bad `onData` / `onEnd`\n * custom handlers.\n **/\n\n/**\n * Deflate.msg -> String\n *\n * Error message, if [[Deflate.err]] != 0\n **/\n\n\n/**\n * new Deflate(options)\n * - options (Object): zlib deflate options.\n *\n * Creates new deflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `level`\n * - `windowBits`\n * - `memLevel`\n * - `strategy`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw deflate\n * - `gzip` (Boolean) - create gzip wrapper\n * - `to` (String) - if equal to 'string', then result will be \"binary string\"\n * (each char code [0..255])\n * - `header` (Object) - custom header for gzip\n * - `text` (Boolean) - true if compressed data believed to be text\n * - `time` (Number) - modification time, unix timestamp\n * - `os` (Number) - operation system code\n * - `extra` (Array) - array of bytes with extra data (max 65536)\n * - `name` (String) - file name (binary string)\n * - `comment` (String) - comment (binary string)\n * - `hcrc` (Boolean) - true if header crc should be added\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * var deflate = new pako.Deflate({ level: 3});\n *\n * deflate.push(chunk1, false);\n * deflate.push(chunk2, true); // true -> last chunk\n *\n * if (deflate.err) { throw new Error(deflate.err); }\n *\n * console.log(deflate.result);\n * ```\n **/\nfunction Deflate(options) {\n if (!(this instanceof Deflate)) return new Deflate(options);\n\n this.options = utils.assign({\n level: Z_DEFAULT_COMPRESSION,\n method: Z_DEFLATED,\n chunkSize: 16384,\n windowBits: 15,\n memLevel: 8,\n strategy: Z_DEFAULT_STRATEGY,\n to: ''\n }, options || {});\n\n var opt = this.options;\n\n if (opt.raw && (opt.windowBits > 0)) {\n opt.windowBits = -opt.windowBits;\n }\n\n else if (opt.gzip && (opt.windowBits > 0) && (opt.windowBits < 16)) {\n opt.windowBits += 16;\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new ZStream();\n this.strm.avail_out = 0;\n\n var status = zlib_deflate.deflateInit2(\n this.strm,\n opt.level,\n opt.method,\n opt.windowBits,\n opt.memLevel,\n opt.strategy\n );\n\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n\n if (opt.header) {\n zlib_deflate.deflateSetHeader(this.strm, opt.header);\n }\n\n if (opt.dictionary) {\n var dict;\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n // If we need to compress text, change encoding to utf8.\n dict = strings.string2buf(opt.dictionary);\n } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n dict = new Uint8Array(opt.dictionary);\n } else {\n dict = opt.dictionary;\n }\n\n status = zlib_deflate.deflateSetDictionary(this.strm, dict);\n\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n\n this._dict_set = true;\n }\n}\n\n/**\n * Deflate#push(data[, mode]) -> Boolean\n * - data (Uint8Array|Array|ArrayBuffer|String): input data. Strings will be\n * converted to utf8 byte sequence.\n * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` means Z_FINISH.\n *\n * Sends input data to deflate pipe, generating [[Deflate#onData]] calls with\n * new compressed chunks. Returns `true` on success. The last data block must have\n * mode Z_FINISH (or `true`). That will flush internal pending buffers and call\n * [[Deflate#onEnd]]. For interim explicit flushes (without ending the stream) you\n * can use mode Z_SYNC_FLUSH, keeping the compression context.\n *\n * On fail call [[Deflate#onEnd]] with error code and return false.\n *\n * We strongly recommend to use `Uint8Array` on input for best speed (output\n * array format is detected automatically). Also, don't skip last param and always\n * use the same type in your code (boolean or number). That will improve JS speed.\n *\n * For regular `Array`-s make sure all elements are [0..255].\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nDeflate.prototype.push = function (data, mode) {\n var strm = this.strm;\n var chunkSize = this.options.chunkSize;\n var status, _mode;\n\n if (this.ended) { return false; }\n\n _mode = (mode === ~~mode) ? mode : ((mode === true) ? Z_FINISH : Z_NO_FLUSH);\n\n // Convert data if needed\n if (typeof data === 'string') {\n // If we need to compress text, change encoding to utf8.\n strm.input = strings.string2buf(data);\n } else if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n do {\n if (strm.avail_out === 0) {\n strm.output = new utils.Buf8(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n status = zlib_deflate.deflate(strm, _mode); /* no bad return value */\n\n if (status !== Z_STREAM_END && status !== Z_OK) {\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n if (strm.avail_out === 0 || (strm.avail_in === 0 && (_mode === Z_FINISH || _mode === Z_SYNC_FLUSH))) {\n if (this.options.to === 'string') {\n this.onData(strings.buf2binstring(utils.shrinkBuf(strm.output, strm.next_out)));\n } else {\n this.onData(utils.shrinkBuf(strm.output, strm.next_out));\n }\n }\n } while ((strm.avail_in > 0 || strm.avail_out === 0) && status !== Z_STREAM_END);\n\n // Finalize on the last chunk.\n if (_mode === Z_FINISH) {\n status = zlib_deflate.deflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === Z_OK;\n }\n\n // callback interim results if Z_SYNC_FLUSH.\n if (_mode === Z_SYNC_FLUSH) {\n this.onEnd(Z_OK);\n strm.avail_out = 0;\n return true;\n }\n\n return true;\n};\n\n\n/**\n * Deflate#onData(chunk) -> Void\n * - chunk (Uint8Array|Array|String): output data. Type of array depends\n * on js engine support. When string output requested, each chunk\n * will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nDeflate.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Deflate#onEnd(status) -> Void\n * - status (Number): deflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called once after you tell deflate that the input stream is\n * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)\n * or if an error happened. By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nDeflate.prototype.onEnd = function (status) {\n // On success - join\n if (status === Z_OK) {\n if (this.options.to === 'string') {\n this.result = this.chunks.join('');\n } else {\n this.result = utils.flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * deflate(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * Compress `data` with deflate algorithm and `options`.\n *\n * Supported options are:\n *\n * - level\n * - windowBits\n * - memLevel\n * - strategy\n * - dictionary\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be \"binary string\"\n * (each char code [0..255])\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , data = Uint8Array([1,2,3,4,5,6,7,8,9]);\n *\n * console.log(pako.deflate(data));\n * ```\n **/\nfunction deflate(input, options) {\n var deflator = new Deflate(options);\n\n deflator.push(input, true);\n\n // That will never happens, if you don't cheat with options :)\n if (deflator.err) { throw deflator.msg || msg[deflator.err]; }\n\n return deflator.result;\n}\n\n\n/**\n * deflateRaw(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction deflateRaw(input, options) {\n options = options || {};\n options.raw = true;\n return deflate(input, options);\n}\n\n\n/**\n * gzip(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but create gzip wrapper instead of\n * deflate one.\n **/\nfunction gzip(input, options) {\n options = options || {};\n options.gzip = true;\n return deflate(input, options);\n}\n\n\nexports.Deflate = Deflate;\nexports.deflate = deflate;\nexports.deflateRaw = deflateRaw;\nexports.gzip = gzip;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar utils = require('../utils/common');\nvar trees = require('./trees');\nvar adler32 = require('./adler32');\nvar crc32 = require('./crc32');\nvar msg = require('./messages');\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n/* Allowed flush values; see deflate() and inflate() below for details */\nvar Z_NO_FLUSH = 0;\nvar Z_PARTIAL_FLUSH = 1;\n//var Z_SYNC_FLUSH = 2;\nvar Z_FULL_FLUSH = 3;\nvar Z_FINISH = 4;\nvar Z_BLOCK = 5;\n//var Z_TREES = 6;\n\n\n/* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\nvar Z_OK = 0;\nvar Z_STREAM_END = 1;\n//var Z_NEED_DICT = 2;\n//var Z_ERRNO = -1;\nvar Z_STREAM_ERROR = -2;\nvar Z_DATA_ERROR = -3;\n//var Z_MEM_ERROR = -4;\nvar Z_BUF_ERROR = -5;\n//var Z_VERSION_ERROR = -6;\n\n\n/* compression levels */\n//var Z_NO_COMPRESSION = 0;\n//var Z_BEST_SPEED = 1;\n//var Z_BEST_COMPRESSION = 9;\nvar Z_DEFAULT_COMPRESSION = -1;\n\n\nvar Z_FILTERED = 1;\nvar Z_HUFFMAN_ONLY = 2;\nvar Z_RLE = 3;\nvar Z_FIXED = 4;\nvar Z_DEFAULT_STRATEGY = 0;\n\n/* Possible values of the data_type field (though see inflate()) */\n//var Z_BINARY = 0;\n//var Z_TEXT = 1;\n//var Z_ASCII = 1; // = Z_TEXT\nvar Z_UNKNOWN = 2;\n\n\n/* The deflate compression method */\nvar Z_DEFLATED = 8;\n\n/*============================================================================*/\n\n\nvar MAX_MEM_LEVEL = 9;\n/* Maximum value for memLevel in deflateInit2 */\nvar MAX_WBITS = 15;\n/* 32K LZ77 window */\nvar DEF_MEM_LEVEL = 8;\n\n\nvar LENGTH_CODES = 29;\n/* number of length codes, not counting the special END_BLOCK code */\nvar LITERALS = 256;\n/* number of literal bytes 0..255 */\nvar L_CODES = LITERALS + 1 + LENGTH_CODES;\n/* number of Literal or Length codes, including the END_BLOCK code */\nvar D_CODES = 30;\n/* number of distance codes */\nvar BL_CODES = 19;\n/* number of codes used to transfer the bit lengths */\nvar HEAP_SIZE = 2 * L_CODES + 1;\n/* maximum heap size */\nvar MAX_BITS = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nvar MIN_MATCH = 3;\nvar MAX_MATCH = 258;\nvar MIN_LOOKAHEAD = (MAX_MATCH + MIN_MATCH + 1);\n\nvar PRESET_DICT = 0x20;\n\nvar INIT_STATE = 42;\nvar EXTRA_STATE = 69;\nvar NAME_STATE = 73;\nvar COMMENT_STATE = 91;\nvar HCRC_STATE = 103;\nvar BUSY_STATE = 113;\nvar FINISH_STATE = 666;\n\nvar BS_NEED_MORE = 1; /* block not completed, need more input or more output */\nvar BS_BLOCK_DONE = 2; /* block flush performed */\nvar BS_FINISH_STARTED = 3; /* finish started, need only more output at next deflate */\nvar BS_FINISH_DONE = 4; /* finish done, accept no more input or output */\n\nvar OS_CODE = 0x03; // Unix :) . Don't detect, use this default.\n\nfunction err(strm, errorCode) {\n strm.msg = msg[errorCode];\n return errorCode;\n}\n\nfunction rank(f) {\n return ((f) << 1) - ((f) > 4 ? 9 : 0);\n}\n\nfunction zero(buf) { var len = buf.length; while (--len >= 0) { buf[len] = 0; } }\n\n\n/* =========================================================================\n * Flush as much pending output as possible. All deflate() output goes\n * through this function so some applications may wish to modify it\n * to avoid allocating a large strm->output buffer and copying into it.\n * (See also read_buf()).\n */\nfunction flush_pending(strm) {\n var s = strm.state;\n\n //_tr_flush_bits(s);\n var len = s.pending;\n if (len > strm.avail_out) {\n len = strm.avail_out;\n }\n if (len === 0) { return; }\n\n utils.arraySet(strm.output, s.pending_buf, s.pending_out, len, strm.next_out);\n strm.next_out += len;\n s.pending_out += len;\n strm.total_out += len;\n strm.avail_out -= len;\n s.pending -= len;\n if (s.pending === 0) {\n s.pending_out = 0;\n }\n}\n\n\nfunction flush_block_only(s, last) {\n trees._tr_flush_block(s, (s.block_start >= 0 ? s.block_start : -1), s.strstart - s.block_start, last);\n s.block_start = s.strstart;\n flush_pending(s.strm);\n}\n\n\nfunction put_byte(s, b) {\n s.pending_buf[s.pending++] = b;\n}\n\n\n/* =========================================================================\n * Put a short in the pending buffer. The 16-bit value is put in MSB order.\n * IN assertion: the stream state is correct and there is enough room in\n * pending_buf.\n */\nfunction putShortMSB(s, b) {\n// put_byte(s, (Byte)(b >> 8));\n// put_byte(s, (Byte)(b & 0xff));\n s.pending_buf[s.pending++] = (b >>> 8) & 0xff;\n s.pending_buf[s.pending++] = b & 0xff;\n}\n\n\n/* ===========================================================================\n * Read a new buffer from the current input stream, update the adler32\n * and total number of bytes read. All deflate() input goes through\n * this function so some applications may wish to modify it to avoid\n * allocating a large strm->input buffer and copying from it.\n * (See also flush_pending()).\n */\nfunction read_buf(strm, buf, start, size) {\n var len = strm.avail_in;\n\n if (len > size) { len = size; }\n if (len === 0) { return 0; }\n\n strm.avail_in -= len;\n\n // zmemcpy(buf, strm->next_in, len);\n utils.arraySet(buf, strm.input, strm.next_in, len, start);\n if (strm.state.wrap === 1) {\n strm.adler = adler32(strm.adler, buf, len, start);\n }\n\n else if (strm.state.wrap === 2) {\n strm.adler = crc32(strm.adler, buf, len, start);\n }\n\n strm.next_in += len;\n strm.total_in += len;\n\n return len;\n}\n\n\n/* ===========================================================================\n * Set match_start to the longest match starting at the given string and\n * return its length. Matches shorter or equal to prev_length are discarded,\n * in which case the result is equal to prev_length and match_start is\n * garbage.\n * IN assertions: cur_match is the head of the hash chain for the current\n * string (strstart) and its distance is <= MAX_DIST, and prev_length >= 1\n * OUT assertion: the match length is not greater than s->lookahead.\n */\nfunction longest_match(s, cur_match) {\n var chain_length = s.max_chain_length; /* max hash chain length */\n var scan = s.strstart; /* current string */\n var match; /* matched string */\n var len; /* length of current match */\n var best_len = s.prev_length; /* best match length so far */\n var nice_match = s.nice_match; /* stop if match long enough */\n var limit = (s.strstart > (s.w_size - MIN_LOOKAHEAD)) ?\n s.strstart - (s.w_size - MIN_LOOKAHEAD) : 0/*NIL*/;\n\n var _win = s.window; // shortcut\n\n var wmask = s.w_mask;\n var prev = s.prev;\n\n /* Stop when cur_match becomes <= limit. To simplify the code,\n * we prevent matches with the string of window index 0.\n */\n\n var strend = s.strstart + MAX_MATCH;\n var scan_end1 = _win[scan + best_len - 1];\n var scan_end = _win[scan + best_len];\n\n /* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16.\n * It is easy to get rid of this optimization if necessary.\n */\n // Assert(s->hash_bits >= 8 && MAX_MATCH == 258, \"Code too clever\");\n\n /* Do not waste too much time if we already have a good match: */\n if (s.prev_length >= s.good_match) {\n chain_length >>= 2;\n }\n /* Do not look for matches beyond the end of the input. This is necessary\n * to make deflate deterministic.\n */\n if (nice_match > s.lookahead) { nice_match = s.lookahead; }\n\n // Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, \"need lookahead\");\n\n do {\n // Assert(cur_match < s->strstart, \"no future\");\n match = cur_match;\n\n /* Skip to next match if the match length cannot increase\n * or if the match length is less than 2. Note that the checks below\n * for insufficient lookahead only occur occasionally for performance\n * reasons. Therefore uninitialized memory will be accessed, and\n * conditional jumps will be made that depend on those values.\n * However the length of the match is limited to the lookahead, so\n * the output of deflate is not affected by the uninitialized values.\n */\n\n if (_win[match + best_len] !== scan_end ||\n _win[match + best_len - 1] !== scan_end1 ||\n _win[match] !== _win[scan] ||\n _win[++match] !== _win[scan + 1]) {\n continue;\n }\n\n /* The check at best_len-1 can be removed because it will be made\n * again later. (This heuristic is not always a win.)\n * It is not necessary to compare scan[2] and match[2] since they\n * are always equal when the other bytes match, given that\n * the hash keys are equal and that HASH_BITS >= 8.\n */\n scan += 2;\n match++;\n // Assert(*scan == *match, \"match[2]?\");\n\n /* We check for insufficient lookahead only every 8th comparison;\n * the 256th check will be made at strstart+258.\n */\n do {\n /*jshint noempty:false*/\n } while (_win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n scan < strend);\n\n // Assert(scan <= s->window+(unsigned)(s->window_size-1), \"wild scan\");\n\n len = MAX_MATCH - (strend - scan);\n scan = strend - MAX_MATCH;\n\n if (len > best_len) {\n s.match_start = cur_match;\n best_len = len;\n if (len >= nice_match) {\n break;\n }\n scan_end1 = _win[scan + best_len - 1];\n scan_end = _win[scan + best_len];\n }\n } while ((cur_match = prev[cur_match & wmask]) > limit && --chain_length !== 0);\n\n if (best_len <= s.lookahead) {\n return best_len;\n }\n return s.lookahead;\n}\n\n\n/* ===========================================================================\n * Fill the window when the lookahead becomes insufficient.\n * Updates strstart and lookahead.\n *\n * IN assertion: lookahead < MIN_LOOKAHEAD\n * OUT assertions: strstart <= window_size-MIN_LOOKAHEAD\n * At least one byte has been read, or avail_in == 0; reads are\n * performed for at least two bytes (required for the zip translate_eol\n * option -- not supported here).\n */\nfunction fill_window(s) {\n var _w_size = s.w_size;\n var p, n, m, more, str;\n\n //Assert(s->lookahead < MIN_LOOKAHEAD, \"already enough lookahead\");\n\n do {\n more = s.window_size - s.lookahead - s.strstart;\n\n // JS ints have 32 bit, block below not needed\n /* Deal with !@#$% 64K limit: */\n //if (sizeof(int) <= 2) {\n // if (more == 0 && s->strstart == 0 && s->lookahead == 0) {\n // more = wsize;\n //\n // } else if (more == (unsigned)(-1)) {\n // /* Very unlikely, but possible on 16 bit machine if\n // * strstart == 0 && lookahead == 1 (input done a byte at time)\n // */\n // more--;\n // }\n //}\n\n\n /* If the window is almost full and there is insufficient lookahead,\n * move the upper half to the lower one to make room in the upper half.\n */\n if (s.strstart >= _w_size + (_w_size - MIN_LOOKAHEAD)) {\n\n utils.arraySet(s.window, s.window, _w_size, _w_size, 0);\n s.match_start -= _w_size;\n s.strstart -= _w_size;\n /* we now have strstart >= MAX_DIST */\n s.block_start -= _w_size;\n\n /* Slide the hash table (could be avoided with 32 bit values\n at the expense of memory usage). We slide even when level == 0\n to keep the hash table consistent if we switch back to level > 0\n later. (Using level 0 permanently is not an optimal usage of\n zlib, so we don't care about this pathological case.)\n */\n\n n = s.hash_size;\n p = n;\n do {\n m = s.head[--p];\n s.head[p] = (m >= _w_size ? m - _w_size : 0);\n } while (--n);\n\n n = _w_size;\n p = n;\n do {\n m = s.prev[--p];\n s.prev[p] = (m >= _w_size ? m - _w_size : 0);\n /* If n is not on any hash chain, prev[n] is garbage but\n * its value will never be used.\n */\n } while (--n);\n\n more += _w_size;\n }\n if (s.strm.avail_in === 0) {\n break;\n }\n\n /* If there was no sliding:\n * strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 &&\n * more == window_size - lookahead - strstart\n * => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1)\n * => more >= window_size - 2*WSIZE + 2\n * In the BIG_MEM or MMAP case (not yet supported),\n * window_size == input_size + MIN_LOOKAHEAD &&\n * strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD.\n * Otherwise, window_size == 2*WSIZE so more >= 2.\n * If there was sliding, more >= WSIZE. So in all cases, more >= 2.\n */\n //Assert(more >= 2, \"more < 2\");\n n = read_buf(s.strm, s.window, s.strstart + s.lookahead, more);\n s.lookahead += n;\n\n /* Initialize the hash value now that we have some input: */\n if (s.lookahead + s.insert >= MIN_MATCH) {\n str = s.strstart - s.insert;\n s.ins_h = s.window[str];\n\n /* UPDATE_HASH(s, s->ins_h, s->window[str + 1]); */\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[str + 1]) & s.hash_mask;\n//#if MIN_MATCH != 3\n// Call update_hash() MIN_MATCH-3 more times\n//#endif\n while (s.insert) {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask;\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = str;\n str++;\n s.insert--;\n if (s.lookahead + s.insert < MIN_MATCH) {\n break;\n }\n }\n }\n /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage,\n * but this is not important since only literal bytes will be emitted.\n */\n\n } while (s.lookahead < MIN_LOOKAHEAD && s.strm.avail_in !== 0);\n\n /* If the WIN_INIT bytes after the end of the current data have never been\n * written, then zero those bytes in order to avoid memory check reports of\n * the use of uninitialized (or uninitialised as Julian writes) bytes by\n * the longest match routines. Update the high water mark for the next\n * time through here. WIN_INIT is set to MAX_MATCH since the longest match\n * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead.\n */\n// if (s.high_water < s.window_size) {\n// var curr = s.strstart + s.lookahead;\n// var init = 0;\n//\n// if (s.high_water < curr) {\n// /* Previous high water mark below current data -- zero WIN_INIT\n// * bytes or up to end of window, whichever is less.\n// */\n// init = s.window_size - curr;\n// if (init > WIN_INIT)\n// init = WIN_INIT;\n// zmemzero(s->window + curr, (unsigned)init);\n// s->high_water = curr + init;\n// }\n// else if (s->high_water < (ulg)curr + WIN_INIT) {\n// /* High water mark at or above current data, but below current data\n// * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up\n// * to end of window, whichever is less.\n// */\n// init = (ulg)curr + WIN_INIT - s->high_water;\n// if (init > s->window_size - s->high_water)\n// init = s->window_size - s->high_water;\n// zmemzero(s->window + s->high_water, (unsigned)init);\n// s->high_water += init;\n// }\n// }\n//\n// Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD,\n// \"not enough room for search\");\n}\n\n/* ===========================================================================\n * Copy without compression as much as possible from the input stream, return\n * the current block state.\n * This function does not insert new strings in the dictionary since\n * uncompressible data is probably not useful. This function is used\n * only for the level=0 compression option.\n * NOTE: this function should be optimized to avoid extra copying from\n * window to pending_buf.\n */\nfunction deflate_stored(s, flush) {\n /* Stored blocks are limited to 0xffff bytes, pending_buf is limited\n * to pending_buf_size, and each stored block has a 5 byte header:\n */\n var max_block_size = 0xffff;\n\n if (max_block_size > s.pending_buf_size - 5) {\n max_block_size = s.pending_buf_size - 5;\n }\n\n /* Copy as much as possible from input to output: */\n for (;;) {\n /* Fill the window as much as possible: */\n if (s.lookahead <= 1) {\n\n //Assert(s->strstart < s->w_size+MAX_DIST(s) ||\n // s->block_start >= (long)s->w_size, \"slide too late\");\n// if (!(s.strstart < s.w_size + (s.w_size - MIN_LOOKAHEAD) ||\n// s.block_start >= s.w_size)) {\n// throw new Error(\"slide too late\");\n// }\n\n fill_window(s);\n if (s.lookahead === 0 && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n\n if (s.lookahead === 0) {\n break;\n }\n /* flush the current block */\n }\n //Assert(s->block_start >= 0L, \"block gone\");\n// if (s.block_start < 0) throw new Error(\"block gone\");\n\n s.strstart += s.lookahead;\n s.lookahead = 0;\n\n /* Emit a stored block if pending_buf will be full: */\n var max_start = s.block_start + max_block_size;\n\n if (s.strstart === 0 || s.strstart >= max_start) {\n /* strstart == 0 is possible when wraparound on 16-bit machine */\n s.lookahead = s.strstart - max_start;\n s.strstart = max_start;\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n\n\n }\n /* Flush if we may have to slide, otherwise block_start may become\n * negative and the data will be gone:\n */\n if (s.strstart - s.block_start >= (s.w_size - MIN_LOOKAHEAD)) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n\n s.insert = 0;\n\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n\n if (s.strstart > s.block_start) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n return BS_NEED_MORE;\n}\n\n/* ===========================================================================\n * Compress as much as possible from the input stream, return the current\n * block state.\n * This function does not perform lazy evaluation of matches and inserts\n * new strings in the dictionary only for unmatched strings or for short\n * matches. It is used only for the fast compression options.\n */\nfunction deflate_fast(s, flush) {\n var hash_head; /* head of the hash chain */\n var bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) {\n break; /* flush the current block */\n }\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n * At this point we have always match_length < MIN_MATCH\n */\n if (hash_head !== 0/*NIL*/ && ((s.strstart - hash_head) <= (s.w_size - MIN_LOOKAHEAD))) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n }\n if (s.match_length >= MIN_MATCH) {\n // check_match(s, s.strstart, s.match_start, s.match_length); // for debug only\n\n /*** _tr_tally_dist(s, s.strstart - s.match_start,\n s.match_length - MIN_MATCH, bflush); ***/\n bflush = trees._tr_tally(s, s.strstart - s.match_start, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n\n /* Insert new strings in the hash table only if the match length\n * is not too large. This saves time but degrades compression.\n */\n if (s.match_length <= s.max_lazy_match/*max_insert_length*/ && s.lookahead >= MIN_MATCH) {\n s.match_length--; /* string at strstart already in table */\n do {\n s.strstart++;\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n /* strstart never exceeds WSIZE-MAX_MATCH, so there are\n * always MIN_MATCH bytes ahead.\n */\n } while (--s.match_length !== 0);\n s.strstart++;\n } else\n {\n s.strstart += s.match_length;\n s.match_length = 0;\n s.ins_h = s.window[s.strstart];\n /* UPDATE_HASH(s, s.ins_h, s.window[s.strstart+1]); */\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + 1]) & s.hash_mask;\n\n//#if MIN_MATCH != 3\n// Call UPDATE_HASH() MIN_MATCH-3 more times\n//#endif\n /* If lookahead < MIN_MATCH, ins_h is garbage, but it does not\n * matter since it will be recomputed at next deflate call.\n */\n }\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s.window[s.strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = ((s.strstart < (MIN_MATCH - 1)) ? s.strstart : MIN_MATCH - 1);\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n}\n\n/* ===========================================================================\n * Same as above, but achieves better compression. We use a lazy\n * evaluation for matches: a match is finally adopted only if there is\n * no better match at the next window position.\n */\nfunction deflate_slow(s, flush) {\n var hash_head; /* head of hash chain */\n var bflush; /* set if current block must be flushed */\n\n var max_insert;\n\n /* Process the input block. */\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n */\n s.prev_length = s.match_length;\n s.prev_match = s.match_start;\n s.match_length = MIN_MATCH - 1;\n\n if (hash_head !== 0/*NIL*/ && s.prev_length < s.max_lazy_match &&\n s.strstart - hash_head <= (s.w_size - MIN_LOOKAHEAD)/*MAX_DIST(s)*/) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n\n if (s.match_length <= 5 &&\n (s.strategy === Z_FILTERED || (s.match_length === MIN_MATCH && s.strstart - s.match_start > 4096/*TOO_FAR*/))) {\n\n /* If prev_match is also MIN_MATCH, match_start is garbage\n * but we will ignore the current match anyway.\n */\n s.match_length = MIN_MATCH - 1;\n }\n }\n /* If there was a match at the previous step and the current\n * match is not better, output the previous match:\n */\n if (s.prev_length >= MIN_MATCH && s.match_length <= s.prev_length) {\n max_insert = s.strstart + s.lookahead - MIN_MATCH;\n /* Do not insert strings in hash table beyond this. */\n\n //check_match(s, s.strstart-1, s.prev_match, s.prev_length);\n\n /***_tr_tally_dist(s, s.strstart - 1 - s.prev_match,\n s.prev_length - MIN_MATCH, bflush);***/\n bflush = trees._tr_tally(s, s.strstart - 1 - s.prev_match, s.prev_length - MIN_MATCH);\n /* Insert in hash table all strings up to the end of the match.\n * strstart-1 and strstart are already inserted. If there is not\n * enough lookahead, the last two strings are not inserted in\n * the hash table.\n */\n s.lookahead -= s.prev_length - 1;\n s.prev_length -= 2;\n do {\n if (++s.strstart <= max_insert) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask;\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n } while (--s.prev_length !== 0);\n s.match_available = 0;\n s.match_length = MIN_MATCH - 1;\n s.strstart++;\n\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n } else if (s.match_available) {\n /* If there was no match at the previous position, output a\n * single literal. If there was a match but the current match\n * is longer, truncate the previous match to a single literal.\n */\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]);\n\n if (bflush) {\n /*** FLUSH_BLOCK_ONLY(s, 0) ***/\n flush_block_only(s, false);\n /***/\n }\n s.strstart++;\n s.lookahead--;\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n } else {\n /* There is no previous match to compare with, wait for\n * the next step to decide.\n */\n s.match_available = 1;\n s.strstart++;\n s.lookahead--;\n }\n }\n //Assert (flush != Z_NO_FLUSH, \"no flush?\");\n if (s.match_available) {\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]);\n\n s.match_available = 0;\n }\n s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1;\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n return BS_BLOCK_DONE;\n}\n\n\n/* ===========================================================================\n * For Z_RLE, simply look for runs of bytes, generate matches only of distance\n * one. Do not maintain a hash table. (It will be regenerated if this run of\n * deflate switches away from Z_RLE.)\n */\nfunction deflate_rle(s, flush) {\n var bflush; /* set if current block must be flushed */\n var prev; /* byte at distance one to match */\n var scan, strend; /* scan goes up to strend for length of run */\n\n var _win = s.window;\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the longest run, plus one for the unrolled loop.\n */\n if (s.lookahead <= MAX_MATCH) {\n fill_window(s);\n if (s.lookahead <= MAX_MATCH && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* See how many times the previous byte repeats */\n s.match_length = 0;\n if (s.lookahead >= MIN_MATCH && s.strstart > 0) {\n scan = s.strstart - 1;\n prev = _win[scan];\n if (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan]) {\n strend = s.strstart + MAX_MATCH;\n do {\n /*jshint noempty:false*/\n } while (prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n scan < strend);\n s.match_length = MAX_MATCH - (strend - scan);\n if (s.match_length > s.lookahead) {\n s.match_length = s.lookahead;\n }\n }\n //Assert(scan <= s->window+(uInt)(s->window_size-1), \"wild scan\");\n }\n\n /* Emit match if have run of MIN_MATCH or longer, else emit literal */\n if (s.match_length >= MIN_MATCH) {\n //check_match(s, s.strstart, s.strstart - 1, s.match_length);\n\n /*** _tr_tally_dist(s, 1, s.match_length - MIN_MATCH, bflush); ***/\n bflush = trees._tr_tally(s, 1, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n s.strstart += s.match_length;\n s.match_length = 0;\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n}\n\n/* ===========================================================================\n * For Z_HUFFMAN_ONLY, do not look for matches. Do not maintain a hash table.\n * (It will be regenerated if this run of deflate switches away from Huffman.)\n */\nfunction deflate_huff(s, flush) {\n var bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we have a literal to write. */\n if (s.lookahead === 0) {\n fill_window(s);\n if (s.lookahead === 0) {\n if (flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n break; /* flush the current block */\n }\n }\n\n /* Output a literal byte */\n s.match_length = 0;\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = trees._tr_tally(s, 0, s.window[s.strstart]);\n s.lookahead--;\n s.strstart++;\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n}\n\n/* Values for max_lazy_match, good_match and max_chain_length, depending on\n * the desired pack level (0..9). The values given below have been tuned to\n * exclude worst case performance for pathological files. Better values may be\n * found for specific files.\n */\nfunction Config(good_length, max_lazy, nice_length, max_chain, func) {\n this.good_length = good_length;\n this.max_lazy = max_lazy;\n this.nice_length = nice_length;\n this.max_chain = max_chain;\n this.func = func;\n}\n\nvar configuration_table;\n\nconfiguration_table = [\n /* good lazy nice chain */\n new Config(0, 0, 0, 0, deflate_stored), /* 0 store only */\n new Config(4, 4, 8, 4, deflate_fast), /* 1 max speed, no lazy matches */\n new Config(4, 5, 16, 8, deflate_fast), /* 2 */\n new Config(4, 6, 32, 32, deflate_fast), /* 3 */\n\n new Config(4, 4, 16, 16, deflate_slow), /* 4 lazy matches */\n new Config(8, 16, 32, 32, deflate_slow), /* 5 */\n new Config(8, 16, 128, 128, deflate_slow), /* 6 */\n new Config(8, 32, 128, 256, deflate_slow), /* 7 */\n new Config(32, 128, 258, 1024, deflate_slow), /* 8 */\n new Config(32, 258, 258, 4096, deflate_slow) /* 9 max compression */\n];\n\n\n/* ===========================================================================\n * Initialize the \"longest match\" routines for a new zlib stream\n */\nfunction lm_init(s) {\n s.window_size = 2 * s.w_size;\n\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n\n /* Set the default configuration parameters:\n */\n s.max_lazy_match = configuration_table[s.level].max_lazy;\n s.good_match = configuration_table[s.level].good_length;\n s.nice_match = configuration_table[s.level].nice_length;\n s.max_chain_length = configuration_table[s.level].max_chain;\n\n s.strstart = 0;\n s.block_start = 0;\n s.lookahead = 0;\n s.insert = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n s.ins_h = 0;\n}\n\n\nfunction DeflateState() {\n this.strm = null; /* pointer back to this zlib stream */\n this.status = 0; /* as the name implies */\n this.pending_buf = null; /* output still pending */\n this.pending_buf_size = 0; /* size of pending_buf */\n this.pending_out = 0; /* next pending byte to output to the stream */\n this.pending = 0; /* nb of bytes in the pending buffer */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.gzhead = null; /* gzip header information to write */\n this.gzindex = 0; /* where in extra, name, or comment */\n this.method = Z_DEFLATED; /* can only be DEFLATED */\n this.last_flush = -1; /* value of flush param for previous deflate call */\n\n this.w_size = 0; /* LZ77 window size (32K by default) */\n this.w_bits = 0; /* log2(w_size) (8..16) */\n this.w_mask = 0; /* w_size - 1 */\n\n this.window = null;\n /* Sliding window. Input bytes are read into the second half of the window,\n * and move to the first half later to keep a dictionary of at least wSize\n * bytes. With this organization, matches are limited to a distance of\n * wSize-MAX_MATCH bytes, but this ensures that IO is always\n * performed with a length multiple of the block size.\n */\n\n this.window_size = 0;\n /* Actual size of window: 2*wSize, except when the user input buffer\n * is directly used as sliding window.\n */\n\n this.prev = null;\n /* Link to older string with same hash index. To limit the size of this\n * array to 64K, this link is maintained only for the last 32K strings.\n * An index in this array is thus a window index modulo 32K.\n */\n\n this.head = null; /* Heads of the hash chains or NIL. */\n\n this.ins_h = 0; /* hash index of string to be inserted */\n this.hash_size = 0; /* number of elements in hash table */\n this.hash_bits = 0; /* log2(hash_size) */\n this.hash_mask = 0; /* hash_size-1 */\n\n this.hash_shift = 0;\n /* Number of bits by which ins_h must be shifted at each input\n * step. It must be such that after MIN_MATCH steps, the oldest\n * byte no longer takes part in the hash key, that is:\n * hash_shift * MIN_MATCH >= hash_bits\n */\n\n this.block_start = 0;\n /* Window position at the beginning of the current output block. Gets\n * negative when the window is moved backwards.\n */\n\n this.match_length = 0; /* length of best match */\n this.prev_match = 0; /* previous match */\n this.match_available = 0; /* set if previous match exists */\n this.strstart = 0; /* start of string to insert */\n this.match_start = 0; /* start of matching string */\n this.lookahead = 0; /* number of valid bytes ahead in window */\n\n this.prev_length = 0;\n /* Length of the best match at previous step. Matches not greater than this\n * are discarded. This is used in the lazy match evaluation.\n */\n\n this.max_chain_length = 0;\n /* To speed up deflation, hash chains are never searched beyond this\n * length. A higher limit improves compression ratio but degrades the\n * speed.\n */\n\n this.max_lazy_match = 0;\n /* Attempt to find a better match only when the current match is strictly\n * smaller than this value. This mechanism is used only for compression\n * levels >= 4.\n */\n // That's alias to max_lazy_match, don't use directly\n //this.max_insert_length = 0;\n /* Insert new strings in the hash table only if the match length is not\n * greater than this length. This saves time but degrades compression.\n * max_insert_length is used only for compression levels <= 3.\n */\n\n this.level = 0; /* compression level (1..9) */\n this.strategy = 0; /* favor or force Huffman coding*/\n\n this.good_match = 0;\n /* Use a faster search when the previous match is longer than this */\n\n this.nice_match = 0; /* Stop searching when current match exceeds this */\n\n /* used by trees.c: */\n\n /* Didn't use ct_data typedef below to suppress compiler warning */\n\n // struct ct_data_s dyn_ltree[HEAP_SIZE]; /* literal and length tree */\n // struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */\n // struct ct_data_s bl_tree[2*BL_CODES+1]; /* Huffman tree for bit lengths */\n\n // Use flat array of DOUBLE size, with interleaved fata,\n // because JS does not support effective\n this.dyn_ltree = new utils.Buf16(HEAP_SIZE * 2);\n this.dyn_dtree = new utils.Buf16((2 * D_CODES + 1) * 2);\n this.bl_tree = new utils.Buf16((2 * BL_CODES + 1) * 2);\n zero(this.dyn_ltree);\n zero(this.dyn_dtree);\n zero(this.bl_tree);\n\n this.l_desc = null; /* desc. for literal tree */\n this.d_desc = null; /* desc. for distance tree */\n this.bl_desc = null; /* desc. for bit length tree */\n\n //ush bl_count[MAX_BITS+1];\n this.bl_count = new utils.Buf16(MAX_BITS + 1);\n /* number of codes at each bit length for an optimal tree */\n\n //int heap[2*L_CODES+1]; /* heap used to build the Huffman trees */\n this.heap = new utils.Buf16(2 * L_CODES + 1); /* heap used to build the Huffman trees */\n zero(this.heap);\n\n this.heap_len = 0; /* number of elements in the heap */\n this.heap_max = 0; /* element of largest frequency */\n /* The sons of heap[n] are heap[2*n] and heap[2*n+1]. heap[0] is not used.\n * The same heap array is used to build all trees.\n */\n\n this.depth = new utils.Buf16(2 * L_CODES + 1); //uch depth[2*L_CODES+1];\n zero(this.depth);\n /* Depth of each subtree used as tie breaker for trees of equal frequency\n */\n\n this.l_buf = 0; /* buffer index for literals or lengths */\n\n this.lit_bufsize = 0;\n /* Size of match buffer for literals/lengths. There are 4 reasons for\n * limiting lit_bufsize to 64K:\n * - frequencies can be kept in 16 bit counters\n * - if compression is not successful for the first block, all input\n * data is still in the window so we can still emit a stored block even\n * when input comes from standard input. (This can also be done for\n * all blocks if lit_bufsize is not greater than 32K.)\n * - if compression is not successful for a file smaller than 64K, we can\n * even emit a stored file instead of a stored block (saving 5 bytes).\n * This is applicable only for zip (not gzip or zlib).\n * - creating new Huffman trees less frequently may not provide fast\n * adaptation to changes in the input data statistics. (Take for\n * example a binary file with poorly compressible code followed by\n * a highly compressible string table.) Smaller buffer sizes give\n * fast adaptation but have of course the overhead of transmitting\n * trees more frequently.\n * - I can't count above 4\n */\n\n this.last_lit = 0; /* running index in l_buf */\n\n this.d_buf = 0;\n /* Buffer index for distances. To simplify the code, d_buf and l_buf have\n * the same number of elements. To use different lengths, an extra flag\n * array would be necessary.\n */\n\n this.opt_len = 0; /* bit length of current block with optimal trees */\n this.static_len = 0; /* bit length of current block with static trees */\n this.matches = 0; /* number of string matches in current block */\n this.insert = 0; /* bytes at end of window left to insert */\n\n\n this.bi_buf = 0;\n /* Output buffer. bits are inserted starting at the bottom (least\n * significant bits).\n */\n this.bi_valid = 0;\n /* Number of valid bits in bi_buf. All bits above the last valid bit\n * are always zero.\n */\n\n // Used for window memory init. We safely ignore it for JS. That makes\n // sense only for pointers and memory check tools.\n //this.high_water = 0;\n /* High water mark offset in window for initialized bytes -- bytes above\n * this are set to zero in order to avoid memory check warnings when\n * longest match routines access bytes past the input. This is then\n * updated to the new high water mark.\n */\n}\n\n\nfunction deflateResetKeep(strm) {\n var s;\n\n if (!strm || !strm.state) {\n return err(strm, Z_STREAM_ERROR);\n }\n\n strm.total_in = strm.total_out = 0;\n strm.data_type = Z_UNKNOWN;\n\n s = strm.state;\n s.pending = 0;\n s.pending_out = 0;\n\n if (s.wrap < 0) {\n s.wrap = -s.wrap;\n /* was made negative by deflate(..., Z_FINISH); */\n }\n s.status = (s.wrap ? INIT_STATE : BUSY_STATE);\n strm.adler = (s.wrap === 2) ?\n 0 // crc32(0, Z_NULL, 0)\n :\n 1; // adler32(0, Z_NULL, 0)\n s.last_flush = Z_NO_FLUSH;\n trees._tr_init(s);\n return Z_OK;\n}\n\n\nfunction deflateReset(strm) {\n var ret = deflateResetKeep(strm);\n if (ret === Z_OK) {\n lm_init(strm.state);\n }\n return ret;\n}\n\n\nfunction deflateSetHeader(strm, head) {\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n if (strm.state.wrap !== 2) { return Z_STREAM_ERROR; }\n strm.state.gzhead = head;\n return Z_OK;\n}\n\n\nfunction deflateInit2(strm, level, method, windowBits, memLevel, strategy) {\n if (!strm) { // === Z_NULL\n return Z_STREAM_ERROR;\n }\n var wrap = 1;\n\n if (level === Z_DEFAULT_COMPRESSION) {\n level = 6;\n }\n\n if (windowBits < 0) { /* suppress zlib wrapper */\n wrap = 0;\n windowBits = -windowBits;\n }\n\n else if (windowBits > 15) {\n wrap = 2; /* write gzip wrapper instead */\n windowBits -= 16;\n }\n\n\n if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method !== Z_DEFLATED ||\n windowBits < 8 || windowBits > 15 || level < 0 || level > 9 ||\n strategy < 0 || strategy > Z_FIXED) {\n return err(strm, Z_STREAM_ERROR);\n }\n\n\n if (windowBits === 8) {\n windowBits = 9;\n }\n /* until 256-byte window bug fixed */\n\n var s = new DeflateState();\n\n strm.state = s;\n s.strm = strm;\n\n s.wrap = wrap;\n s.gzhead = null;\n s.w_bits = windowBits;\n s.w_size = 1 << s.w_bits;\n s.w_mask = s.w_size - 1;\n\n s.hash_bits = memLevel + 7;\n s.hash_size = 1 << s.hash_bits;\n s.hash_mask = s.hash_size - 1;\n s.hash_shift = ~~((s.hash_bits + MIN_MATCH - 1) / MIN_MATCH);\n\n s.window = new utils.Buf8(s.w_size * 2);\n s.head = new utils.Buf16(s.hash_size);\n s.prev = new utils.Buf16(s.w_size);\n\n // Don't need mem init magic for JS.\n //s.high_water = 0; /* nothing written to s->window yet */\n\n s.lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */\n\n s.pending_buf_size = s.lit_bufsize * 4;\n\n //overlay = (ushf *) ZALLOC(strm, s->lit_bufsize, sizeof(ush)+2);\n //s->pending_buf = (uchf *) overlay;\n s.pending_buf = new utils.Buf8(s.pending_buf_size);\n\n // It is offset from `s.pending_buf` (size is `s.lit_bufsize * 2`)\n //s->d_buf = overlay + s->lit_bufsize/sizeof(ush);\n s.d_buf = 1 * s.lit_bufsize;\n\n //s->l_buf = s->pending_buf + (1+sizeof(ush))*s->lit_bufsize;\n s.l_buf = (1 + 2) * s.lit_bufsize;\n\n s.level = level;\n s.strategy = strategy;\n s.method = method;\n\n return deflateReset(strm);\n}\n\nfunction deflateInit(strm, level) {\n return deflateInit2(strm, level, Z_DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY);\n}\n\n\nfunction deflate(strm, flush) {\n var old_flush, s;\n var beg, val; // for gzip header write only\n\n if (!strm || !strm.state ||\n flush > Z_BLOCK || flush < 0) {\n return strm ? err(strm, Z_STREAM_ERROR) : Z_STREAM_ERROR;\n }\n\n s = strm.state;\n\n if (!strm.output ||\n (!strm.input && strm.avail_in !== 0) ||\n (s.status === FINISH_STATE && flush !== Z_FINISH)) {\n return err(strm, (strm.avail_out === 0) ? Z_BUF_ERROR : Z_STREAM_ERROR);\n }\n\n s.strm = strm; /* just in case */\n old_flush = s.last_flush;\n s.last_flush = flush;\n\n /* Write the header */\n if (s.status === INIT_STATE) {\n\n if (s.wrap === 2) { // GZIP header\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n put_byte(s, 31);\n put_byte(s, 139);\n put_byte(s, 8);\n if (!s.gzhead) { // s->gzhead == Z_NULL\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, OS_CODE);\n s.status = BUSY_STATE;\n }\n else {\n put_byte(s, (s.gzhead.text ? 1 : 0) +\n (s.gzhead.hcrc ? 2 : 0) +\n (!s.gzhead.extra ? 0 : 4) +\n (!s.gzhead.name ? 0 : 8) +\n (!s.gzhead.comment ? 0 : 16)\n );\n put_byte(s, s.gzhead.time & 0xff);\n put_byte(s, (s.gzhead.time >> 8) & 0xff);\n put_byte(s, (s.gzhead.time >> 16) & 0xff);\n put_byte(s, (s.gzhead.time >> 24) & 0xff);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, s.gzhead.os & 0xff);\n if (s.gzhead.extra && s.gzhead.extra.length) {\n put_byte(s, s.gzhead.extra.length & 0xff);\n put_byte(s, (s.gzhead.extra.length >> 8) & 0xff);\n }\n if (s.gzhead.hcrc) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending, 0);\n }\n s.gzindex = 0;\n s.status = EXTRA_STATE;\n }\n }\n else // DEFLATE header\n {\n var header = (Z_DEFLATED + ((s.w_bits - 8) << 4)) << 8;\n var level_flags = -1;\n\n if (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2) {\n level_flags = 0;\n } else if (s.level < 6) {\n level_flags = 1;\n } else if (s.level === 6) {\n level_flags = 2;\n } else {\n level_flags = 3;\n }\n header |= (level_flags << 6);\n if (s.strstart !== 0) { header |= PRESET_DICT; }\n header += 31 - (header % 31);\n\n s.status = BUSY_STATE;\n putShortMSB(s, header);\n\n /* Save the adler32 of the preset dictionary: */\n if (s.strstart !== 0) {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n strm.adler = 1; // adler32(0L, Z_NULL, 0);\n }\n }\n\n//#ifdef GZIP\n if (s.status === EXTRA_STATE) {\n if (s.gzhead.extra/* != Z_NULL*/) {\n beg = s.pending; /* start of bytes to update crc */\n\n while (s.gzindex < (s.gzhead.extra.length & 0xffff)) {\n if (s.pending === s.pending_buf_size) {\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n flush_pending(strm);\n beg = s.pending;\n if (s.pending === s.pending_buf_size) {\n break;\n }\n }\n put_byte(s, s.gzhead.extra[s.gzindex] & 0xff);\n s.gzindex++;\n }\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n if (s.gzindex === s.gzhead.extra.length) {\n s.gzindex = 0;\n s.status = NAME_STATE;\n }\n }\n else {\n s.status = NAME_STATE;\n }\n }\n if (s.status === NAME_STATE) {\n if (s.gzhead.name/* != Z_NULL*/) {\n beg = s.pending; /* start of bytes to update crc */\n //int val;\n\n do {\n if (s.pending === s.pending_buf_size) {\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n flush_pending(strm);\n beg = s.pending;\n if (s.pending === s.pending_buf_size) {\n val = 1;\n break;\n }\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.name.length) {\n val = s.gzhead.name.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n if (val === 0) {\n s.gzindex = 0;\n s.status = COMMENT_STATE;\n }\n }\n else {\n s.status = COMMENT_STATE;\n }\n }\n if (s.status === COMMENT_STATE) {\n if (s.gzhead.comment/* != Z_NULL*/) {\n beg = s.pending; /* start of bytes to update crc */\n //int val;\n\n do {\n if (s.pending === s.pending_buf_size) {\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n flush_pending(strm);\n beg = s.pending;\n if (s.pending === s.pending_buf_size) {\n val = 1;\n break;\n }\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.comment.length) {\n val = s.gzhead.comment.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n if (val === 0) {\n s.status = HCRC_STATE;\n }\n }\n else {\n s.status = HCRC_STATE;\n }\n }\n if (s.status === HCRC_STATE) {\n if (s.gzhead.hcrc) {\n if (s.pending + 2 > s.pending_buf_size) {\n flush_pending(strm);\n }\n if (s.pending + 2 <= s.pending_buf_size) {\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n s.status = BUSY_STATE;\n }\n }\n else {\n s.status = BUSY_STATE;\n }\n }\n//#endif\n\n /* Flush as much pending output as possible */\n if (s.pending !== 0) {\n flush_pending(strm);\n if (strm.avail_out === 0) {\n /* Since avail_out is 0, deflate will be called again with\n * more output space, but possibly with both pending and\n * avail_in equal to zero. There won't be anything to do,\n * but this is not an error situation so make sure we\n * return OK instead of BUF_ERROR at next call of deflate:\n */\n s.last_flush = -1;\n return Z_OK;\n }\n\n /* Make sure there is something to do and avoid duplicate consecutive\n * flushes. For repeated and useless calls with Z_FINISH, we keep\n * returning Z_STREAM_END instead of Z_BUF_ERROR.\n */\n } else if (strm.avail_in === 0 && rank(flush) <= rank(old_flush) &&\n flush !== Z_FINISH) {\n return err(strm, Z_BUF_ERROR);\n }\n\n /* User must not provide more input after the first FINISH: */\n if (s.status === FINISH_STATE && strm.avail_in !== 0) {\n return err(strm, Z_BUF_ERROR);\n }\n\n /* Start a new block or continue the current one.\n */\n if (strm.avail_in !== 0 || s.lookahead !== 0 ||\n (flush !== Z_NO_FLUSH && s.status !== FINISH_STATE)) {\n var bstate = (s.strategy === Z_HUFFMAN_ONLY) ? deflate_huff(s, flush) :\n (s.strategy === Z_RLE ? deflate_rle(s, flush) :\n configuration_table[s.level].func(s, flush));\n\n if (bstate === BS_FINISH_STARTED || bstate === BS_FINISH_DONE) {\n s.status = FINISH_STATE;\n }\n if (bstate === BS_NEED_MORE || bstate === BS_FINISH_STARTED) {\n if (strm.avail_out === 0) {\n s.last_flush = -1;\n /* avoid BUF_ERROR next call, see above */\n }\n return Z_OK;\n /* If flush != Z_NO_FLUSH && avail_out == 0, the next call\n * of deflate should use the same flush parameter to make sure\n * that the flush is complete. So we don't have to output an\n * empty block here, this will be done at next call. This also\n * ensures that for a very small output buffer, we emit at most\n * one empty block.\n */\n }\n if (bstate === BS_BLOCK_DONE) {\n if (flush === Z_PARTIAL_FLUSH) {\n trees._tr_align(s);\n }\n else if (flush !== Z_BLOCK) { /* FULL_FLUSH or SYNC_FLUSH */\n\n trees._tr_stored_block(s, 0, 0, false);\n /* For a full flush, this empty block will be recognized\n * as a special marker by inflate_sync().\n */\n if (flush === Z_FULL_FLUSH) {\n /*** CLEAR_HASH(s); ***/ /* forget history */\n zero(s.head); // Fill with NIL (= 0);\n\n if (s.lookahead === 0) {\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n }\n }\n flush_pending(strm);\n if (strm.avail_out === 0) {\n s.last_flush = -1; /* avoid BUF_ERROR at next call, see above */\n return Z_OK;\n }\n }\n }\n //Assert(strm->avail_out > 0, \"bug2\");\n //if (strm.avail_out <= 0) { throw new Error(\"bug2\");}\n\n if (flush !== Z_FINISH) { return Z_OK; }\n if (s.wrap <= 0) { return Z_STREAM_END; }\n\n /* Write the trailer */\n if (s.wrap === 2) {\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n put_byte(s, (strm.adler >> 16) & 0xff);\n put_byte(s, (strm.adler >> 24) & 0xff);\n put_byte(s, strm.total_in & 0xff);\n put_byte(s, (strm.total_in >> 8) & 0xff);\n put_byte(s, (strm.total_in >> 16) & 0xff);\n put_byte(s, (strm.total_in >> 24) & 0xff);\n }\n else\n {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n\n flush_pending(strm);\n /* If avail_out is zero, the application will call deflate again\n * to flush the rest.\n */\n if (s.wrap > 0) { s.wrap = -s.wrap; }\n /* write the trailer only once! */\n return s.pending !== 0 ? Z_OK : Z_STREAM_END;\n}\n\nfunction deflateEnd(strm) {\n var status;\n\n if (!strm/*== Z_NULL*/ || !strm.state/*== Z_NULL*/) {\n return Z_STREAM_ERROR;\n }\n\n status = strm.state.status;\n if (status !== INIT_STATE &&\n status !== EXTRA_STATE &&\n status !== NAME_STATE &&\n status !== COMMENT_STATE &&\n status !== HCRC_STATE &&\n status !== BUSY_STATE &&\n status !== FINISH_STATE\n ) {\n return err(strm, Z_STREAM_ERROR);\n }\n\n strm.state = null;\n\n return status === BUSY_STATE ? err(strm, Z_DATA_ERROR) : Z_OK;\n}\n\n\n/* =========================================================================\n * Initializes the compression dictionary from the given byte\n * sequence without producing any compressed output.\n */\nfunction deflateSetDictionary(strm, dictionary) {\n var dictLength = dictionary.length;\n\n var s;\n var str, n;\n var wrap;\n var avail;\n var next;\n var input;\n var tmpDict;\n\n if (!strm/*== Z_NULL*/ || !strm.state/*== Z_NULL*/) {\n return Z_STREAM_ERROR;\n }\n\n s = strm.state;\n wrap = s.wrap;\n\n if (wrap === 2 || (wrap === 1 && s.status !== INIT_STATE) || s.lookahead) {\n return Z_STREAM_ERROR;\n }\n\n /* when using zlib wrappers, compute Adler-32 for provided dictionary */\n if (wrap === 1) {\n /* adler32(strm->adler, dictionary, dictLength); */\n strm.adler = adler32(strm.adler, dictionary, dictLength, 0);\n }\n\n s.wrap = 0; /* avoid computing Adler-32 in read_buf */\n\n /* if dictionary would fill window, just replace the history */\n if (dictLength >= s.w_size) {\n if (wrap === 0) { /* already empty otherwise */\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n /* use the tail */\n // dictionary = dictionary.slice(dictLength - s.w_size);\n tmpDict = new utils.Buf8(s.w_size);\n utils.arraySet(tmpDict, dictionary, dictLength - s.w_size, s.w_size, 0);\n dictionary = tmpDict;\n dictLength = s.w_size;\n }\n /* insert dictionary into window and hash */\n avail = strm.avail_in;\n next = strm.next_in;\n input = strm.input;\n strm.avail_in = dictLength;\n strm.next_in = 0;\n strm.input = dictionary;\n fill_window(s);\n while (s.lookahead >= MIN_MATCH) {\n str = s.strstart;\n n = s.lookahead - (MIN_MATCH - 1);\n do {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = ((s.ins_h << s.hash_shift) ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask;\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n\n s.head[s.ins_h] = str;\n str++;\n } while (--n);\n s.strstart = str;\n s.lookahead = MIN_MATCH - 1;\n fill_window(s);\n }\n s.strstart += s.lookahead;\n s.block_start = s.strstart;\n s.insert = s.lookahead;\n s.lookahead = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n strm.next_in = next;\n strm.input = input;\n strm.avail_in = avail;\n s.wrap = wrap;\n return Z_OK;\n}\n\n\nexports.deflateInit = deflateInit;\nexports.deflateInit2 = deflateInit2;\nexports.deflateReset = deflateReset;\nexports.deflateResetKeep = deflateResetKeep;\nexports.deflateSetHeader = deflateSetHeader;\nexports.deflate = deflate;\nexports.deflateEnd = deflateEnd;\nexports.deflateSetDictionary = deflateSetDictionary;\nexports.deflateInfo = 'pako deflate (from Nodeca project)';\n\n/* Not implemented\nexports.deflateBound = deflateBound;\nexports.deflateCopy = deflateCopy;\nexports.deflateParams = deflateParams;\nexports.deflatePending = deflatePending;\nexports.deflatePrime = deflatePrime;\nexports.deflateTune = deflateTune;\n*/\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n/* eslint-disable space-unary-ops */\n\nvar utils = require('../utils/common');\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n//var Z_FILTERED = 1;\n//var Z_HUFFMAN_ONLY = 2;\n//var Z_RLE = 3;\nvar Z_FIXED = 4;\n//var Z_DEFAULT_STRATEGY = 0;\n\n/* Possible values of the data_type field (though see inflate()) */\nvar Z_BINARY = 0;\nvar Z_TEXT = 1;\n//var Z_ASCII = 1; // = Z_TEXT\nvar Z_UNKNOWN = 2;\n\n/*============================================================================*/\n\n\nfunction zero(buf) { var len = buf.length; while (--len >= 0) { buf[len] = 0; } }\n\n// From zutil.h\n\nvar STORED_BLOCK = 0;\nvar STATIC_TREES = 1;\nvar DYN_TREES = 2;\n/* The three kinds of block type */\n\nvar MIN_MATCH = 3;\nvar MAX_MATCH = 258;\n/* The minimum and maximum match lengths */\n\n// From deflate.h\n/* ===========================================================================\n * Internal compression state.\n */\n\nvar LENGTH_CODES = 29;\n/* number of length codes, not counting the special END_BLOCK code */\n\nvar LITERALS = 256;\n/* number of literal bytes 0..255 */\n\nvar L_CODES = LITERALS + 1 + LENGTH_CODES;\n/* number of Literal or Length codes, including the END_BLOCK code */\n\nvar D_CODES = 30;\n/* number of distance codes */\n\nvar BL_CODES = 19;\n/* number of codes used to transfer the bit lengths */\n\nvar HEAP_SIZE = 2 * L_CODES + 1;\n/* maximum heap size */\n\nvar MAX_BITS = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nvar Buf_size = 16;\n/* size of bit buffer in bi_buf */\n\n\n/* ===========================================================================\n * Constants\n */\n\nvar MAX_BL_BITS = 7;\n/* Bit length codes must not exceed MAX_BL_BITS bits */\n\nvar END_BLOCK = 256;\n/* end of block literal code */\n\nvar REP_3_6 = 16;\n/* repeat previous bit length 3-6 times (2 bits of repeat count) */\n\nvar REPZ_3_10 = 17;\n/* repeat a zero length 3-10 times (3 bits of repeat count) */\n\nvar REPZ_11_138 = 18;\n/* repeat a zero length 11-138 times (7 bits of repeat count) */\n\n/* eslint-disable comma-spacing,array-bracket-spacing */\nvar extra_lbits = /* extra bits for each length code */\n [0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0];\n\nvar extra_dbits = /* extra bits for each distance code */\n [0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13];\n\nvar extra_blbits = /* extra bits for each bit length code */\n [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7];\n\nvar bl_order =\n [16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15];\n/* eslint-enable comma-spacing,array-bracket-spacing */\n\n/* The lengths of the bit length codes are sent in order of decreasing\n * probability, to avoid transmitting the lengths for unused bit length codes.\n */\n\n/* ===========================================================================\n * Local data. These are initialized only once.\n */\n\n// We pre-fill arrays with 0 to avoid uninitialized gaps\n\nvar DIST_CODE_LEN = 512; /* see definition of array dist_code below */\n\n// !!!! Use flat array instead of structure, Freq = i*2, Len = i*2+1\nvar static_ltree = new Array((L_CODES + 2) * 2);\nzero(static_ltree);\n/* The static literal tree. Since the bit lengths are imposed, there is no\n * need for the L_CODES extra codes used during heap construction. However\n * The codes 286 and 287 are needed to build a canonical tree (see _tr_init\n * below).\n */\n\nvar static_dtree = new Array(D_CODES * 2);\nzero(static_dtree);\n/* The static distance tree. (Actually a trivial tree since all codes use\n * 5 bits.)\n */\n\nvar _dist_code = new Array(DIST_CODE_LEN);\nzero(_dist_code);\n/* Distance codes. The first 256 values correspond to the distances\n * 3 .. 258, the last 256 values correspond to the top 8 bits of\n * the 15 bit distances.\n */\n\nvar _length_code = new Array(MAX_MATCH - MIN_MATCH + 1);\nzero(_length_code);\n/* length code for each normalized match length (0 == MIN_MATCH) */\n\nvar base_length = new Array(LENGTH_CODES);\nzero(base_length);\n/* First normalized length for each code (0 = MIN_MATCH) */\n\nvar base_dist = new Array(D_CODES);\nzero(base_dist);\n/* First normalized distance for each code (0 = distance of 1) */\n\n\nfunction StaticTreeDesc(static_tree, extra_bits, extra_base, elems, max_length) {\n\n this.static_tree = static_tree; /* static tree or NULL */\n this.extra_bits = extra_bits; /* extra bits for each code or NULL */\n this.extra_base = extra_base; /* base index for extra_bits */\n this.elems = elems; /* max number of elements in the tree */\n this.max_length = max_length; /* max bit length for the codes */\n\n // show if `static_tree` has data or dummy - needed for monomorphic objects\n this.has_stree = static_tree && static_tree.length;\n}\n\n\nvar static_l_desc;\nvar static_d_desc;\nvar static_bl_desc;\n\n\nfunction TreeDesc(dyn_tree, stat_desc) {\n this.dyn_tree = dyn_tree; /* the dynamic tree */\n this.max_code = 0; /* largest code with non zero frequency */\n this.stat_desc = stat_desc; /* the corresponding static tree */\n}\n\n\n\nfunction d_code(dist) {\n return dist < 256 ? _dist_code[dist] : _dist_code[256 + (dist >>> 7)];\n}\n\n\n/* ===========================================================================\n * Output a short LSB first on the stream.\n * IN assertion: there is enough room in pendingBuf.\n */\nfunction put_short(s, w) {\n// put_byte(s, (uch)((w) & 0xff));\n// put_byte(s, (uch)((ush)(w) >> 8));\n s.pending_buf[s.pending++] = (w) & 0xff;\n s.pending_buf[s.pending++] = (w >>> 8) & 0xff;\n}\n\n\n/* ===========================================================================\n * Send a value on a given number of bits.\n * IN assertion: length <= 16 and value fits in length bits.\n */\nfunction send_bits(s, value, length) {\n if (s.bi_valid > (Buf_size - length)) {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n put_short(s, s.bi_buf);\n s.bi_buf = value >> (Buf_size - s.bi_valid);\n s.bi_valid += length - Buf_size;\n } else {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n s.bi_valid += length;\n }\n}\n\n\nfunction send_code(s, c, tree) {\n send_bits(s, tree[c * 2]/*.Code*/, tree[c * 2 + 1]/*.Len*/);\n}\n\n\n/* ===========================================================================\n * Reverse the first len bits of a code, using straightforward code (a faster\n * method would use a table)\n * IN assertion: 1 <= len <= 15\n */\nfunction bi_reverse(code, len) {\n var res = 0;\n do {\n res |= code & 1;\n code >>>= 1;\n res <<= 1;\n } while (--len > 0);\n return res >>> 1;\n}\n\n\n/* ===========================================================================\n * Flush the bit buffer, keeping at most 7 bits in it.\n */\nfunction bi_flush(s) {\n if (s.bi_valid === 16) {\n put_short(s, s.bi_buf);\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n } else if (s.bi_valid >= 8) {\n s.pending_buf[s.pending++] = s.bi_buf & 0xff;\n s.bi_buf >>= 8;\n s.bi_valid -= 8;\n }\n}\n\n\n/* ===========================================================================\n * Compute the optimal bit lengths for a tree and update the total bit length\n * for the current block.\n * IN assertion: the fields freq and dad are set, heap[heap_max] and\n * above are the tree nodes sorted by increasing frequency.\n * OUT assertions: the field len is set to the optimal bit length, the\n * array bl_count contains the frequencies for each bit length.\n * The length opt_len is updated; static_len is also updated if stree is\n * not null.\n */\nfunction gen_bitlen(s, desc)\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n{\n var tree = desc.dyn_tree;\n var max_code = desc.max_code;\n var stree = desc.stat_desc.static_tree;\n var has_stree = desc.stat_desc.has_stree;\n var extra = desc.stat_desc.extra_bits;\n var base = desc.stat_desc.extra_base;\n var max_length = desc.stat_desc.max_length;\n var h; /* heap index */\n var n, m; /* iterate over the tree elements */\n var bits; /* bit length */\n var xbits; /* extra bits */\n var f; /* frequency */\n var overflow = 0; /* number of elements with bit length too large */\n\n for (bits = 0; bits <= MAX_BITS; bits++) {\n s.bl_count[bits] = 0;\n }\n\n /* In a first pass, compute the optimal bit lengths (which may\n * overflow in the case of the bit length tree).\n */\n tree[s.heap[s.heap_max] * 2 + 1]/*.Len*/ = 0; /* root of the heap */\n\n for (h = s.heap_max + 1; h < HEAP_SIZE; h++) {\n n = s.heap[h];\n bits = tree[tree[n * 2 + 1]/*.Dad*/ * 2 + 1]/*.Len*/ + 1;\n if (bits > max_length) {\n bits = max_length;\n overflow++;\n }\n tree[n * 2 + 1]/*.Len*/ = bits;\n /* We overwrite tree[n].Dad which is no longer needed */\n\n if (n > max_code) { continue; } /* not a leaf node */\n\n s.bl_count[bits]++;\n xbits = 0;\n if (n >= base) {\n xbits = extra[n - base];\n }\n f = tree[n * 2]/*.Freq*/;\n s.opt_len += f * (bits + xbits);\n if (has_stree) {\n s.static_len += f * (stree[n * 2 + 1]/*.Len*/ + xbits);\n }\n }\n if (overflow === 0) { return; }\n\n // Trace((stderr,\"\\nbit length overflow\\n\"));\n /* This happens for example on obj2 and pic of the Calgary corpus */\n\n /* Find the first bit length which could increase: */\n do {\n bits = max_length - 1;\n while (s.bl_count[bits] === 0) { bits--; }\n s.bl_count[bits]--; /* move one leaf down the tree */\n s.bl_count[bits + 1] += 2; /* move one overflow item as its brother */\n s.bl_count[max_length]--;\n /* The brother of the overflow item also moves one step up,\n * but this does not affect bl_count[max_length]\n */\n overflow -= 2;\n } while (overflow > 0);\n\n /* Now recompute all bit lengths, scanning in increasing frequency.\n * h is still equal to HEAP_SIZE. (It is simpler to reconstruct all\n * lengths instead of fixing only the wrong ones. This idea is taken\n * from 'ar' written by Haruhiko Okumura.)\n */\n for (bits = max_length; bits !== 0; bits--) {\n n = s.bl_count[bits];\n while (n !== 0) {\n m = s.heap[--h];\n if (m > max_code) { continue; }\n if (tree[m * 2 + 1]/*.Len*/ !== bits) {\n // Trace((stderr,\"code %d bits %d->%d\\n\", m, tree[m].Len, bits));\n s.opt_len += (bits - tree[m * 2 + 1]/*.Len*/) * tree[m * 2]/*.Freq*/;\n tree[m * 2 + 1]/*.Len*/ = bits;\n }\n n--;\n }\n }\n}\n\n\n/* ===========================================================================\n * Generate the codes for a given tree and bit counts (which need not be\n * optimal).\n * IN assertion: the array bl_count contains the bit length statistics for\n * the given tree and the field len is set for all tree elements.\n * OUT assertion: the field code is set for all tree elements of non\n * zero code length.\n */\nfunction gen_codes(tree, max_code, bl_count)\n// ct_data *tree; /* the tree to decorate */\n// int max_code; /* largest code with non zero frequency */\n// ushf *bl_count; /* number of codes at each bit length */\n{\n var next_code = new Array(MAX_BITS + 1); /* next code value for each bit length */\n var code = 0; /* running code value */\n var bits; /* bit index */\n var n; /* code index */\n\n /* The distribution counts are first used to generate the code values\n * without bit reversal.\n */\n for (bits = 1; bits <= MAX_BITS; bits++) {\n next_code[bits] = code = (code + bl_count[bits - 1]) << 1;\n }\n /* Check that the bit counts in bl_count are consistent. The last code\n * must be all ones.\n */\n //Assert (code + bl_count[MAX_BITS]-1 == (1<<MAX_BITS)-1,\n // \"inconsistent bit counts\");\n //Tracev((stderr,\"\\ngen_codes: max_code %d \", max_code));\n\n for (n = 0; n <= max_code; n++) {\n var len = tree[n * 2 + 1]/*.Len*/;\n if (len === 0) { continue; }\n /* Now reverse the bits */\n tree[n * 2]/*.Code*/ = bi_reverse(next_code[len]++, len);\n\n //Tracecv(tree != static_ltree, (stderr,\"\\nn %3d %c l %2d c %4x (%x) \",\n // n, (isgraph(n) ? n : ' '), len, tree[n].Code, next_code[len]-1));\n }\n}\n\n\n/* ===========================================================================\n * Initialize the various 'constant' tables.\n */\nfunction tr_static_init() {\n var n; /* iterates over tree elements */\n var bits; /* bit counter */\n var length; /* length value */\n var code; /* code value */\n var dist; /* distance index */\n var bl_count = new Array(MAX_BITS + 1);\n /* number of codes at each bit length for an optimal tree */\n\n // do check in _tr_init()\n //if (static_init_done) return;\n\n /* For some embedded targets, global variables are not initialized: */\n/*#ifdef NO_INIT_GLOBAL_POINTERS\n static_l_desc.static_tree = static_ltree;\n static_l_desc.extra_bits = extra_lbits;\n static_d_desc.static_tree = static_dtree;\n static_d_desc.extra_bits = extra_dbits;\n static_bl_desc.extra_bits = extra_blbits;\n#endif*/\n\n /* Initialize the mapping length (0..255) -> length code (0..28) */\n length = 0;\n for (code = 0; code < LENGTH_CODES - 1; code++) {\n base_length[code] = length;\n for (n = 0; n < (1 << extra_lbits[code]); n++) {\n _length_code[length++] = code;\n }\n }\n //Assert (length == 256, \"tr_static_init: length != 256\");\n /* Note that the length 255 (match length 258) can be represented\n * in two different ways: code 284 + 5 bits or code 285, so we\n * overwrite length_code[255] to use the best encoding:\n */\n _length_code[length - 1] = code;\n\n /* Initialize the mapping dist (0..32K) -> dist code (0..29) */\n dist = 0;\n for (code = 0; code < 16; code++) {\n base_dist[code] = dist;\n for (n = 0; n < (1 << extra_dbits[code]); n++) {\n _dist_code[dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: dist != 256\");\n dist >>= 7; /* from now on, all distances are divided by 128 */\n for (; code < D_CODES; code++) {\n base_dist[code] = dist << 7;\n for (n = 0; n < (1 << (extra_dbits[code] - 7)); n++) {\n _dist_code[256 + dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: 256+dist != 512\");\n\n /* Construct the codes of the static literal tree */\n for (bits = 0; bits <= MAX_BITS; bits++) {\n bl_count[bits] = 0;\n }\n\n n = 0;\n while (n <= 143) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n while (n <= 255) {\n static_ltree[n * 2 + 1]/*.Len*/ = 9;\n n++;\n bl_count[9]++;\n }\n while (n <= 279) {\n static_ltree[n * 2 + 1]/*.Len*/ = 7;\n n++;\n bl_count[7]++;\n }\n while (n <= 287) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n /* Codes 286 and 287 do not exist, but we must include them in the\n * tree construction to get a canonical Huffman tree (longest code\n * all ones)\n */\n gen_codes(static_ltree, L_CODES + 1, bl_count);\n\n /* The static distance tree is trivial: */\n for (n = 0; n < D_CODES; n++) {\n static_dtree[n * 2 + 1]/*.Len*/ = 5;\n static_dtree[n * 2]/*.Code*/ = bi_reverse(n, 5);\n }\n\n // Now data ready and we can init static trees\n static_l_desc = new StaticTreeDesc(static_ltree, extra_lbits, LITERALS + 1, L_CODES, MAX_BITS);\n static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0, D_CODES, MAX_BITS);\n static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0, BL_CODES, MAX_BL_BITS);\n\n //static_init_done = true;\n}\n\n\n/* ===========================================================================\n * Initialize a new block.\n */\nfunction init_block(s) {\n var n; /* iterates over tree elements */\n\n /* Initialize the trees. */\n for (n = 0; n < L_CODES; n++) { s.dyn_ltree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < D_CODES; n++) { s.dyn_dtree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < BL_CODES; n++) { s.bl_tree[n * 2]/*.Freq*/ = 0; }\n\n s.dyn_ltree[END_BLOCK * 2]/*.Freq*/ = 1;\n s.opt_len = s.static_len = 0;\n s.last_lit = s.matches = 0;\n}\n\n\n/* ===========================================================================\n * Flush the bit buffer and align the output on a byte boundary\n */\nfunction bi_windup(s)\n{\n if (s.bi_valid > 8) {\n put_short(s, s.bi_buf);\n } else if (s.bi_valid > 0) {\n //put_byte(s, (Byte)s->bi_buf);\n s.pending_buf[s.pending++] = s.bi_buf;\n }\n s.bi_buf = 0;\n s.bi_valid = 0;\n}\n\n/* ===========================================================================\n * Copy a stored block, storing first the length and its\n * one's complement if requested.\n */\nfunction copy_block(s, buf, len, header)\n//DeflateState *s;\n//charf *buf; /* the input data */\n//unsigned len; /* its length */\n//int header; /* true if block header must be written */\n{\n bi_windup(s); /* align on byte boundary */\n\n if (header) {\n put_short(s, len);\n put_short(s, ~len);\n }\n// while (len--) {\n// put_byte(s, *buf++);\n// }\n utils.arraySet(s.pending_buf, s.window, buf, len, s.pending);\n s.pending += len;\n}\n\n/* ===========================================================================\n * Compares to subtrees, using the tree depth as tie breaker when\n * the subtrees have equal frequency. This minimizes the worst case length.\n */\nfunction smaller(tree, n, m, depth) {\n var _n2 = n * 2;\n var _m2 = m * 2;\n return (tree[_n2]/*.Freq*/ < tree[_m2]/*.Freq*/ ||\n (tree[_n2]/*.Freq*/ === tree[_m2]/*.Freq*/ && depth[n] <= depth[m]));\n}\n\n/* ===========================================================================\n * Restore the heap property by moving down the tree starting at node k,\n * exchanging a node with the smallest of its two sons if necessary, stopping\n * when the heap property is re-established (each father smaller than its\n * two sons).\n */\nfunction pqdownheap(s, tree, k)\n// deflate_state *s;\n// ct_data *tree; /* the tree to restore */\n// int k; /* node to move down */\n{\n var v = s.heap[k];\n var j = k << 1; /* left son of k */\n while (j <= s.heap_len) {\n /* Set j to the smallest of the two sons: */\n if (j < s.heap_len &&\n smaller(tree, s.heap[j + 1], s.heap[j], s.depth)) {\n j++;\n }\n /* Exit if v is smaller than both sons */\n if (smaller(tree, v, s.heap[j], s.depth)) { break; }\n\n /* Exchange v with the smallest son */\n s.heap[k] = s.heap[j];\n k = j;\n\n /* And continue down the tree, setting j to the left son of k */\n j <<= 1;\n }\n s.heap[k] = v;\n}\n\n\n// inlined manually\n// var SMALLEST = 1;\n\n/* ===========================================================================\n * Send the block data compressed using the given Huffman trees\n */\nfunction compress_block(s, ltree, dtree)\n// deflate_state *s;\n// const ct_data *ltree; /* literal tree */\n// const ct_data *dtree; /* distance tree */\n{\n var dist; /* distance of matched string */\n var lc; /* match length or unmatched char (if dist == 0) */\n var lx = 0; /* running index in l_buf */\n var code; /* the code to send */\n var extra; /* number of extra bits to send */\n\n if (s.last_lit !== 0) {\n do {\n dist = (s.pending_buf[s.d_buf + lx * 2] << 8) | (s.pending_buf[s.d_buf + lx * 2 + 1]);\n lc = s.pending_buf[s.l_buf + lx];\n lx++;\n\n if (dist === 0) {\n send_code(s, lc, ltree); /* send a literal byte */\n //Tracecv(isgraph(lc), (stderr,\" '%c' \", lc));\n } else {\n /* Here, lc is the match length - MIN_MATCH */\n code = _length_code[lc];\n send_code(s, code + LITERALS + 1, ltree); /* send the length code */\n extra = extra_lbits[code];\n if (extra !== 0) {\n lc -= base_length[code];\n send_bits(s, lc, extra); /* send the extra length bits */\n }\n dist--; /* dist is now the match distance - 1 */\n code = d_code(dist);\n //Assert (code < D_CODES, \"bad d_code\");\n\n send_code(s, code, dtree); /* send the distance code */\n extra = extra_dbits[code];\n if (extra !== 0) {\n dist -= base_dist[code];\n send_bits(s, dist, extra); /* send the extra distance bits */\n }\n } /* literal or match pair ? */\n\n /* Check that the overlay between pending_buf and d_buf+l_buf is ok: */\n //Assert((uInt)(s->pending) < s->lit_bufsize + 2*lx,\n // \"pendingBuf overflow\");\n\n } while (lx < s.last_lit);\n }\n\n send_code(s, END_BLOCK, ltree);\n}\n\n\n/* ===========================================================================\n * Construct one Huffman tree and assigns the code bit strings and lengths.\n * Update the total bit length for the current block.\n * IN assertion: the field freq is set for all tree elements.\n * OUT assertions: the fields len and code are set to the optimal bit length\n * and corresponding code. The length opt_len is updated; static_len is\n * also updated if stree is not null. The field max_code is set.\n */\nfunction build_tree(s, desc)\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n{\n var tree = desc.dyn_tree;\n var stree = desc.stat_desc.static_tree;\n var has_stree = desc.stat_desc.has_stree;\n var elems = desc.stat_desc.elems;\n var n, m; /* iterate over heap elements */\n var max_code = -1; /* largest code with non zero frequency */\n var node; /* new node being created */\n\n /* Construct the initial heap, with least frequent element in\n * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1].\n * heap[0] is not used.\n */\n s.heap_len = 0;\n s.heap_max = HEAP_SIZE;\n\n for (n = 0; n < elems; n++) {\n if (tree[n * 2]/*.Freq*/ !== 0) {\n s.heap[++s.heap_len] = max_code = n;\n s.depth[n] = 0;\n\n } else {\n tree[n * 2 + 1]/*.Len*/ = 0;\n }\n }\n\n /* The pkzip format requires that at least one distance code exists,\n * and that at least one bit should be sent even if there is only one\n * possible code. So to avoid special checks later on we force at least\n * two codes of non zero frequency.\n */\n while (s.heap_len < 2) {\n node = s.heap[++s.heap_len] = (max_code < 2 ? ++max_code : 0);\n tree[node * 2]/*.Freq*/ = 1;\n s.depth[node] = 0;\n s.opt_len--;\n\n if (has_stree) {\n s.static_len -= stree[node * 2 + 1]/*.Len*/;\n }\n /* node is 0 or 1 so it does not have extra bits */\n }\n desc.max_code = max_code;\n\n /* The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree,\n * establish sub-heaps of increasing lengths:\n */\n for (n = (s.heap_len >> 1/*int /2*/); n >= 1; n--) { pqdownheap(s, tree, n); }\n\n /* Construct the Huffman tree by repeatedly combining the least two\n * frequent nodes.\n */\n node = elems; /* next internal node of the tree */\n do {\n //pqremove(s, tree, n); /* n = node of least frequency */\n /*** pqremove ***/\n n = s.heap[1/*SMALLEST*/];\n s.heap[1/*SMALLEST*/] = s.heap[s.heap_len--];\n pqdownheap(s, tree, 1/*SMALLEST*/);\n /***/\n\n m = s.heap[1/*SMALLEST*/]; /* m = node of next least frequency */\n\n s.heap[--s.heap_max] = n; /* keep the nodes sorted by frequency */\n s.heap[--s.heap_max] = m;\n\n /* Create a new node father of n and m */\n tree[node * 2]/*.Freq*/ = tree[n * 2]/*.Freq*/ + tree[m * 2]/*.Freq*/;\n s.depth[node] = (s.depth[n] >= s.depth[m] ? s.depth[n] : s.depth[m]) + 1;\n tree[n * 2 + 1]/*.Dad*/ = tree[m * 2 + 1]/*.Dad*/ = node;\n\n /* and insert the new node in the heap */\n s.heap[1/*SMALLEST*/] = node++;\n pqdownheap(s, tree, 1/*SMALLEST*/);\n\n } while (s.heap_len >= 2);\n\n s.heap[--s.heap_max] = s.heap[1/*SMALLEST*/];\n\n /* At this point, the fields freq and dad are set. We can now\n * generate the bit lengths.\n */\n gen_bitlen(s, desc);\n\n /* The field len is now set, we can generate the bit codes */\n gen_codes(tree, max_code, s.bl_count);\n}\n\n\n/* ===========================================================================\n * Scan a literal or distance tree to determine the frequencies of the codes\n * in the bit length tree.\n */\nfunction scan_tree(s, tree, max_code)\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n{\n var n; /* iterates over all tree elements */\n var prevlen = -1; /* last emitted length */\n var curlen; /* length of current code */\n\n var nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n var count = 0; /* repeat count of the current code */\n var max_count = 7; /* max repeat count */\n var min_count = 4; /* min repeat count */\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n tree[(max_code + 1) * 2 + 1]/*.Len*/ = 0xffff; /* guard */\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n s.bl_tree[curlen * 2]/*.Freq*/ += count;\n\n } else if (curlen !== 0) {\n\n if (curlen !== prevlen) { s.bl_tree[curlen * 2]/*.Freq*/++; }\n s.bl_tree[REP_3_6 * 2]/*.Freq*/++;\n\n } else if (count <= 10) {\n s.bl_tree[REPZ_3_10 * 2]/*.Freq*/++;\n\n } else {\n s.bl_tree[REPZ_11_138 * 2]/*.Freq*/++;\n }\n\n count = 0;\n prevlen = curlen;\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n}\n\n\n/* ===========================================================================\n * Send a literal or distance tree in compressed form, using the codes in\n * bl_tree.\n */\nfunction send_tree(s, tree, max_code)\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n{\n var n; /* iterates over all tree elements */\n var prevlen = -1; /* last emitted length */\n var curlen; /* length of current code */\n\n var nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n var count = 0; /* repeat count of the current code */\n var max_count = 7; /* max repeat count */\n var min_count = 4; /* min repeat count */\n\n /* tree[max_code+1].Len = -1; */ /* guard already set */\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n do { send_code(s, curlen, s.bl_tree); } while (--count !== 0);\n\n } else if (curlen !== 0) {\n if (curlen !== prevlen) {\n send_code(s, curlen, s.bl_tree);\n count--;\n }\n //Assert(count >= 3 && count <= 6, \" 3_6?\");\n send_code(s, REP_3_6, s.bl_tree);\n send_bits(s, count - 3, 2);\n\n } else if (count <= 10) {\n send_code(s, REPZ_3_10, s.bl_tree);\n send_bits(s, count - 3, 3);\n\n } else {\n send_code(s, REPZ_11_138, s.bl_tree);\n send_bits(s, count - 11, 7);\n }\n\n count = 0;\n prevlen = curlen;\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n}\n\n\n/* ===========================================================================\n * Construct the Huffman tree for the bit lengths and return the index in\n * bl_order of the last bit length code to send.\n */\nfunction build_bl_tree(s) {\n var max_blindex; /* index of last bit length code of non zero freq */\n\n /* Determine the bit length frequencies for literal and distance trees */\n scan_tree(s, s.dyn_ltree, s.l_desc.max_code);\n scan_tree(s, s.dyn_dtree, s.d_desc.max_code);\n\n /* Build the bit length tree: */\n build_tree(s, s.bl_desc);\n /* opt_len now includes the length of the tree representations, except\n * the lengths of the bit lengths codes and the 5+5+4 bits for the counts.\n */\n\n /* Determine the number of bit length codes to send. The pkzip format\n * requires that at least 4 bit length codes be sent. (appnote.txt says\n * 3 but the actual value used is 4.)\n */\n for (max_blindex = BL_CODES - 1; max_blindex >= 3; max_blindex--) {\n if (s.bl_tree[bl_order[max_blindex] * 2 + 1]/*.Len*/ !== 0) {\n break;\n }\n }\n /* Update opt_len to include the bit length tree and counts */\n s.opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4;\n //Tracev((stderr, \"\\ndyn trees: dyn %ld, stat %ld\",\n // s->opt_len, s->static_len));\n\n return max_blindex;\n}\n\n\n/* ===========================================================================\n * Send the header for a block using dynamic Huffman trees: the counts, the\n * lengths of the bit length codes, the literal tree and the distance tree.\n * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4.\n */\nfunction send_all_trees(s, lcodes, dcodes, blcodes)\n// deflate_state *s;\n// int lcodes, dcodes, blcodes; /* number of codes for each tree */\n{\n var rank; /* index in bl_order */\n\n //Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, \"not enough codes\");\n //Assert (lcodes <= L_CODES && dcodes <= D_CODES && blcodes <= BL_CODES,\n // \"too many codes\");\n //Tracev((stderr, \"\\nbl counts: \"));\n send_bits(s, lcodes - 257, 5); /* not +255 as stated in appnote.txt */\n send_bits(s, dcodes - 1, 5);\n send_bits(s, blcodes - 4, 4); /* not -3 as stated in appnote.txt */\n for (rank = 0; rank < blcodes; rank++) {\n //Tracev((stderr, \"\\nbl code %2d \", bl_order[rank]));\n send_bits(s, s.bl_tree[bl_order[rank] * 2 + 1]/*.Len*/, 3);\n }\n //Tracev((stderr, \"\\nbl tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_ltree, lcodes - 1); /* literal tree */\n //Tracev((stderr, \"\\nlit tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_dtree, dcodes - 1); /* distance tree */\n //Tracev((stderr, \"\\ndist tree: sent %ld\", s->bits_sent));\n}\n\n\n/* ===========================================================================\n * Check if the data type is TEXT or BINARY, using the following algorithm:\n * - TEXT if the two conditions below are satisfied:\n * a) There are no non-portable control characters belonging to the\n * \"black list\" (0..6, 14..25, 28..31).\n * b) There is at least one printable character belonging to the\n * \"white list\" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255).\n * - BINARY otherwise.\n * - The following partially-portable control characters form a\n * \"gray list\" that is ignored in this detection algorithm:\n * (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}).\n * IN assertion: the fields Freq of dyn_ltree are set.\n */\nfunction detect_data_type(s) {\n /* black_mask is the bit mask of black-listed bytes\n * set bits 0..6, 14..25, and 28..31\n * 0xf3ffc07f = binary 11110011111111111100000001111111\n */\n var black_mask = 0xf3ffc07f;\n var n;\n\n /* Check for non-textual (\"black-listed\") bytes. */\n for (n = 0; n <= 31; n++, black_mask >>>= 1) {\n if ((black_mask & 1) && (s.dyn_ltree[n * 2]/*.Freq*/ !== 0)) {\n return Z_BINARY;\n }\n }\n\n /* Check for textual (\"white-listed\") bytes. */\n if (s.dyn_ltree[9 * 2]/*.Freq*/ !== 0 || s.dyn_ltree[10 * 2]/*.Freq*/ !== 0 ||\n s.dyn_ltree[13 * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n for (n = 32; n < LITERALS; n++) {\n if (s.dyn_ltree[n * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n }\n\n /* There are no \"black-listed\" or \"white-listed\" bytes:\n * this stream either is empty or has tolerated (\"gray-listed\") bytes only.\n */\n return Z_BINARY;\n}\n\n\nvar static_init_done = false;\n\n/* ===========================================================================\n * Initialize the tree data structures for a new zlib stream.\n */\nfunction _tr_init(s)\n{\n\n if (!static_init_done) {\n tr_static_init();\n static_init_done = true;\n }\n\n s.l_desc = new TreeDesc(s.dyn_ltree, static_l_desc);\n s.d_desc = new TreeDesc(s.dyn_dtree, static_d_desc);\n s.bl_desc = new TreeDesc(s.bl_tree, static_bl_desc);\n\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n /* Initialize the first block of the first file: */\n init_block(s);\n}\n\n\n/* ===========================================================================\n * Send a stored block\n */\nfunction _tr_stored_block(s, buf, stored_len, last)\n//DeflateState *s;\n//charf *buf; /* input block */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n{\n send_bits(s, (STORED_BLOCK << 1) + (last ? 1 : 0), 3); /* send block type */\n copy_block(s, buf, stored_len, true); /* with header */\n}\n\n\n/* ===========================================================================\n * Send one empty static block to give enough lookahead for inflate.\n * This takes 10 bits, of which 7 may remain in the bit buffer.\n */\nfunction _tr_align(s) {\n send_bits(s, STATIC_TREES << 1, 3);\n send_code(s, END_BLOCK, static_ltree);\n bi_flush(s);\n}\n\n\n/* ===========================================================================\n * Determine the best encoding for the current block: dynamic trees, static\n * trees or store, and output the encoded block to the zip file.\n */\nfunction _tr_flush_block(s, buf, stored_len, last)\n//DeflateState *s;\n//charf *buf; /* input block, or NULL if too old */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n{\n var opt_lenb, static_lenb; /* opt_len and static_len in bytes */\n var max_blindex = 0; /* index of last bit length code of non zero freq */\n\n /* Build the Huffman trees unless a stored block is forced */\n if (s.level > 0) {\n\n /* Check if the file is binary or text */\n if (s.strm.data_type === Z_UNKNOWN) {\n s.strm.data_type = detect_data_type(s);\n }\n\n /* Construct the literal and distance trees */\n build_tree(s, s.l_desc);\n // Tracev((stderr, \"\\nlit data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n\n build_tree(s, s.d_desc);\n // Tracev((stderr, \"\\ndist data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n /* At this point, opt_len and static_len are the total bit lengths of\n * the compressed block data, excluding the tree representations.\n */\n\n /* Build the bit length tree for the above two trees, and get the index\n * in bl_order of the last bit length code to send.\n */\n max_blindex = build_bl_tree(s);\n\n /* Determine the best encoding. Compute the block lengths in bytes. */\n opt_lenb = (s.opt_len + 3 + 7) >>> 3;\n static_lenb = (s.static_len + 3 + 7) >>> 3;\n\n // Tracev((stderr, \"\\nopt %lu(%lu) stat %lu(%lu) stored %lu lit %u \",\n // opt_lenb, s->opt_len, static_lenb, s->static_len, stored_len,\n // s->last_lit));\n\n if (static_lenb <= opt_lenb) { opt_lenb = static_lenb; }\n\n } else {\n // Assert(buf != (char*)0, \"lost buf\");\n opt_lenb = static_lenb = stored_len + 5; /* force a stored block */\n }\n\n if ((stored_len + 4 <= opt_lenb) && (buf !== -1)) {\n /* 4: two words for the lengths */\n\n /* The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE.\n * Otherwise we can't have processed more than WSIZE input bytes since\n * the last block flush, because compression would have been\n * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to\n * transform a block into a stored block.\n */\n _tr_stored_block(s, buf, stored_len, last);\n\n } else if (s.strategy === Z_FIXED || static_lenb === opt_lenb) {\n\n send_bits(s, (STATIC_TREES << 1) + (last ? 1 : 0), 3);\n compress_block(s, static_ltree, static_dtree);\n\n } else {\n send_bits(s, (DYN_TREES << 1) + (last ? 1 : 0), 3);\n send_all_trees(s, s.l_desc.max_code + 1, s.d_desc.max_code + 1, max_blindex + 1);\n compress_block(s, s.dyn_ltree, s.dyn_dtree);\n }\n // Assert (s->compressed_len == s->bits_sent, \"bad compressed size\");\n /* The above check is made mod 2^32, for files larger than 512 MB\n * and uLong implemented on 32 bits.\n */\n init_block(s);\n\n if (last) {\n bi_windup(s);\n }\n // Tracev((stderr,\"\\ncomprlen %lu(%lu) \", s->compressed_len>>3,\n // s->compressed_len-7*last));\n}\n\n/* ===========================================================================\n * Save the match info and tally the frequency counts. Return true if\n * the current block must be flushed.\n */\nfunction _tr_tally(s, dist, lc)\n// deflate_state *s;\n// unsigned dist; /* distance of matched string */\n// unsigned lc; /* match length-MIN_MATCH or unmatched char (if dist==0) */\n{\n //var out_length, in_length, dcode;\n\n s.pending_buf[s.d_buf + s.last_lit * 2] = (dist >>> 8) & 0xff;\n s.pending_buf[s.d_buf + s.last_lit * 2 + 1] = dist & 0xff;\n\n s.pending_buf[s.l_buf + s.last_lit] = lc & 0xff;\n s.last_lit++;\n\n if (dist === 0) {\n /* lc is the unmatched char */\n s.dyn_ltree[lc * 2]/*.Freq*/++;\n } else {\n s.matches++;\n /* Here, lc is the match length - MIN_MATCH */\n dist--; /* dist = match distance - 1 */\n //Assert((ush)dist < (ush)MAX_DIST(s) &&\n // (ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) &&\n // (ush)d_code(dist) < (ush)D_CODES, \"_tr_tally: bad match\");\n\n s.dyn_ltree[(_length_code[lc] + LITERALS + 1) * 2]/*.Freq*/++;\n s.dyn_dtree[d_code(dist) * 2]/*.Freq*/++;\n }\n\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n\n//#ifdef TRUNCATE_BLOCK\n// /* Try to guess if it is profitable to stop the current block here */\n// if ((s.last_lit & 0x1fff) === 0 && s.level > 2) {\n// /* Compute an upper bound for the compressed length */\n// out_length = s.last_lit*8;\n// in_length = s.strstart - s.block_start;\n//\n// for (dcode = 0; dcode < D_CODES; dcode++) {\n// out_length += s.dyn_dtree[dcode*2]/*.Freq*/ * (5 + extra_dbits[dcode]);\n// }\n// out_length >>>= 3;\n// //Tracev((stderr,\"\\nlast_lit %u, in %ld, out ~%ld(%ld%%) \",\n// // s->last_lit, in_length, out_length,\n// // 100L - out_length*100L/in_length));\n// if (s.matches < (s.last_lit>>1)/*int /2*/ && out_length < (in_length>>1)/*int /2*/) {\n// return true;\n// }\n// }\n//#endif\n\n return (s.last_lit === s.lit_bufsize - 1);\n /* We avoid equality with lit_bufsize because of wraparound at 64K\n * on 16 bit machines and because stored blocks are restricted to\n * 64K-1 bytes.\n */\n}\n\nexports._tr_init = _tr_init;\nexports._tr_stored_block = _tr_stored_block;\nexports._tr_flush_block = _tr_flush_block;\nexports._tr_tally = _tr_tally;\nexports._tr_align = _tr_align;\n","'use strict';\n\n// Note: adler32 takes 12% for level 0 and 2% for level 6.\n// It isn't worth it to make additional optimizations as in original.\n// Small size is preferable.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction adler32(adler, buf, len, pos) {\n var s1 = (adler & 0xffff) |0,\n s2 = ((adler >>> 16) & 0xffff) |0,\n n = 0;\n\n while (len !== 0) {\n // Set limit ~ twice less than 5552, to keep\n // s2 in 31-bits, because we force signed ints.\n // in other case %= will fail.\n n = len > 2000 ? 2000 : len;\n len -= n;\n\n do {\n s1 = (s1 + buf[pos++]) |0;\n s2 = (s2 + s1) |0;\n } while (--n);\n\n s1 %= 65521;\n s2 %= 65521;\n }\n\n return (s1 | (s2 << 16)) |0;\n}\n\n\nmodule.exports = adler32;\n","'use strict';\n\n// Note: we can't get significant speed boost here.\n// So write code to minimize size - no pregenerated tables\n// and array tools dependencies.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// Use ordinary array, since untyped makes no boost here\nfunction makeTable() {\n var c, table = [];\n\n for (var n = 0; n < 256; n++) {\n c = n;\n for (var k = 0; k < 8; k++) {\n c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));\n }\n table[n] = c;\n }\n\n return table;\n}\n\n// Create table on load. Just 255 signed longs. Not a problem.\nvar crcTable = makeTable();\n\n\nfunction crc32(crc, buf, len, pos) {\n var t = crcTable,\n end = pos + len;\n\n crc ^= -1;\n\n for (var i = pos; i < end; i++) {\n crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];\n }\n\n return (crc ^ (-1)); // >>> 0;\n}\n\n\nmodule.exports = crc32;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nmodule.exports = {\n 2: 'need dictionary', /* Z_NEED_DICT 2 */\n 1: 'stream end', /* Z_STREAM_END 1 */\n 0: '', /* Z_OK 0 */\n '-1': 'file error', /* Z_ERRNO (-1) */\n '-2': 'stream error', /* Z_STREAM_ERROR (-2) */\n '-3': 'data error', /* Z_DATA_ERROR (-3) */\n '-4': 'insufficient memory', /* Z_MEM_ERROR (-4) */\n '-5': 'buffer error', /* Z_BUF_ERROR (-5) */\n '-6': 'incompatible version' /* Z_VERSION_ERROR (-6) */\n};\n","// String encode/decode helpers\n'use strict';\n\n\nvar utils = require('./common');\n\n\n// Quick check if we can use fast array to bin string conversion\n//\n// - apply(Array) can fail on Android 2.2\n// - apply(Uint8Array) can fail on iOS 5.1 Safari\n//\nvar STR_APPLY_OK = true;\nvar STR_APPLY_UIA_OK = true;\n\ntry { String.fromCharCode.apply(null, [ 0 ]); } catch (__) { STR_APPLY_OK = false; }\ntry { String.fromCharCode.apply(null, new Uint8Array(1)); } catch (__) { STR_APPLY_UIA_OK = false; }\n\n\n// Table with utf8 lengths (calculated by first byte of sequence)\n// Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,\n// because max possible codepoint is 0x10ffff\nvar _utf8len = new utils.Buf8(256);\nfor (var q = 0; q < 256; q++) {\n _utf8len[q] = (q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1);\n}\n_utf8len[254] = _utf8len[254] = 1; // Invalid sequence start\n\n\n// convert string to array (typed, when possible)\nexports.string2buf = function (str) {\n var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;\n\n // count binary size\n for (m_pos = 0; m_pos < str_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\n }\n\n // allocate buffer\n buf = new utils.Buf8(buf_len);\n\n // convert\n for (i = 0, m_pos = 0; i < buf_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n if (c < 0x80) {\n /* one byte */\n buf[i++] = c;\n } else if (c < 0x800) {\n /* two bytes */\n buf[i++] = 0xC0 | (c >>> 6);\n buf[i++] = 0x80 | (c & 0x3f);\n } else if (c < 0x10000) {\n /* three bytes */\n buf[i++] = 0xE0 | (c >>> 12);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n } else {\n /* four bytes */\n buf[i++] = 0xf0 | (c >>> 18);\n buf[i++] = 0x80 | (c >>> 12 & 0x3f);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n }\n\n return buf;\n};\n\n// Helper (used in 2 places)\nfunction buf2binstring(buf, len) {\n // On Chrome, the arguments in a function call that are allowed is `65534`.\n // If the length of the buffer is smaller than that, we can use this optimization,\n // otherwise we will take a slower path.\n if (len < 65534) {\n if ((buf.subarray && STR_APPLY_UIA_OK) || (!buf.subarray && STR_APPLY_OK)) {\n return String.fromCharCode.apply(null, utils.shrinkBuf(buf, len));\n }\n }\n\n var result = '';\n for (var i = 0; i < len; i++) {\n result += String.fromCharCode(buf[i]);\n }\n return result;\n}\n\n\n// Convert byte array to binary string\nexports.buf2binstring = function (buf) {\n return buf2binstring(buf, buf.length);\n};\n\n\n// Convert binary string (typed, when possible)\nexports.binstring2buf = function (str) {\n var buf = new utils.Buf8(str.length);\n for (var i = 0, len = buf.length; i < len; i++) {\n buf[i] = str.charCodeAt(i);\n }\n return buf;\n};\n\n\n// convert array to string\nexports.buf2string = function (buf, max) {\n var i, out, c, c_len;\n var len = max || buf.length;\n\n // Reserve max possible length (2 words per char)\n // NB: by unknown reasons, Array is significantly faster for\n // String.fromCharCode.apply than Uint16Array.\n var utf16buf = new Array(len * 2);\n\n for (out = 0, i = 0; i < len;) {\n c = buf[i++];\n // quick process ascii\n if (c < 0x80) { utf16buf[out++] = c; continue; }\n\n c_len = _utf8len[c];\n // skip 5 & 6 byte codes\n if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len - 1; continue; }\n\n // apply mask on first byte\n c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;\n // join the rest\n while (c_len > 1 && i < len) {\n c = (c << 6) | (buf[i++] & 0x3f);\n c_len--;\n }\n\n // terminated by end of string?\n if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }\n\n if (c < 0x10000) {\n utf16buf[out++] = c;\n } else {\n c -= 0x10000;\n utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);\n utf16buf[out++] = 0xdc00 | (c & 0x3ff);\n }\n }\n\n return buf2binstring(utf16buf, out);\n};\n\n\n// Calculate max possible position in utf8 buffer,\n// that will not break sequence. If that's not possible\n// - (very small limits) return max size as is.\n//\n// buf[] - utf8 bytes array\n// max - length limit (mandatory);\nexports.utf8border = function (buf, max) {\n var pos;\n\n max = max || buf.length;\n if (max > buf.length) { max = buf.length; }\n\n // go back from last position, until start of sequence found\n pos = max - 1;\n while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }\n\n // Very small and broken sequence,\n // return max, because we should return something anyway.\n if (pos < 0) { return max; }\n\n // If we came to start of buffer - that means buffer is too small,\n // return max too.\n if (pos === 0) { return max; }\n\n return (pos + _utf8len[buf[pos]] > max) ? pos : max;\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction ZStream() {\n /* next input byte */\n this.input = null; // JS specific, because we have no pointers\n this.next_in = 0;\n /* number of bytes available at input */\n this.avail_in = 0;\n /* total number of input bytes read so far */\n this.total_in = 0;\n /* next output byte should be put there */\n this.output = null; // JS specific, because we have no pointers\n this.next_out = 0;\n /* remaining free space at output */\n this.avail_out = 0;\n /* total number of bytes output so far */\n this.total_out = 0;\n /* last error message, NULL if no error */\n this.msg = ''/*Z_NULL*/;\n /* not visible by applications */\n this.state = null;\n /* best guess about the data type: binary or text */\n this.data_type = 2/*Z_UNKNOWN*/;\n /* adler32 value of the uncompressed data */\n this.adler = 0;\n}\n\nmodule.exports = ZStream;\n","'use strict';\n\n\nvar zlib_inflate = require('./zlib/inflate');\nvar utils = require('./utils/common');\nvar strings = require('./utils/strings');\nvar c = require('./zlib/constants');\nvar msg = require('./zlib/messages');\nvar ZStream = require('./zlib/zstream');\nvar GZheader = require('./zlib/gzheader');\n\nvar toString = Object.prototype.toString;\n\n/**\n * class Inflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[inflate]]\n * and [[inflateRaw]].\n **/\n\n/* internal\n * inflate.chunks -> Array\n *\n * Chunks of output data, if [[Inflate#onData]] not overridden.\n **/\n\n/**\n * Inflate.result -> Uint8Array|Array|String\n *\n * Uncompressed result, generated by default [[Inflate#onData]]\n * and [[Inflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Inflate#push]] with `Z_FINISH` / `true` param) or if you\n * push a chunk with explicit flush (call [[Inflate#push]] with\n * `Z_SYNC_FLUSH` param).\n **/\n\n/**\n * Inflate.err -> Number\n *\n * Error code after inflate finished. 0 (Z_OK) on success.\n * Should be checked if broken data possible.\n **/\n\n/**\n * Inflate.msg -> String\n *\n * Error message, if [[Inflate.err]] != 0\n **/\n\n\n/**\n * new Inflate(options)\n * - options (Object): zlib inflate options.\n *\n * Creates new inflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `windowBits`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw inflate\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n * By default, when no options set, autodetect deflate/gzip data format via\n * wrapper header.\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * var inflate = new pako.Inflate({ level: 3});\n *\n * inflate.push(chunk1, false);\n * inflate.push(chunk2, true); // true -> last chunk\n *\n * if (inflate.err) { throw new Error(inflate.err); }\n *\n * console.log(inflate.result);\n * ```\n **/\nfunction Inflate(options) {\n if (!(this instanceof Inflate)) return new Inflate(options);\n\n this.options = utils.assign({\n chunkSize: 16384,\n windowBits: 0,\n to: ''\n }, options || {});\n\n var opt = this.options;\n\n // Force window size for `raw` data, if not set directly,\n // because we have no header for autodetect.\n if (opt.raw && (opt.windowBits >= 0) && (opt.windowBits < 16)) {\n opt.windowBits = -opt.windowBits;\n if (opt.windowBits === 0) { opt.windowBits = -15; }\n }\n\n // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate\n if ((opt.windowBits >= 0) && (opt.windowBits < 16) &&\n !(options && options.windowBits)) {\n opt.windowBits += 32;\n }\n\n // Gzip header has no info about windows size, we can do autodetect only\n // for deflate. So, if window size not set, force it to max when gzip possible\n if ((opt.windowBits > 15) && (opt.windowBits < 48)) {\n // bit 3 (16) -> gzipped data\n // bit 4 (32) -> autodetect gzip/deflate\n if ((opt.windowBits & 15) === 0) {\n opt.windowBits |= 15;\n }\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new ZStream();\n this.strm.avail_out = 0;\n\n var status = zlib_inflate.inflateInit2(\n this.strm,\n opt.windowBits\n );\n\n if (status !== c.Z_OK) {\n throw new Error(msg[status]);\n }\n\n this.header = new GZheader();\n\n zlib_inflate.inflateGetHeader(this.strm, this.header);\n\n // Setup dictionary\n if (opt.dictionary) {\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n opt.dictionary = strings.string2buf(opt.dictionary);\n } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n opt.dictionary = new Uint8Array(opt.dictionary);\n }\n if (opt.raw) { //In raw mode we need to set the dictionary early\n status = zlib_inflate.inflateSetDictionary(this.strm, opt.dictionary);\n if (status !== c.Z_OK) {\n throw new Error(msg[status]);\n }\n }\n }\n}\n\n/**\n * Inflate#push(data[, mode]) -> Boolean\n * - data (Uint8Array|Array|ArrayBuffer|String): input data\n * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` means Z_FINISH.\n *\n * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with\n * new output chunks. Returns `true` on success. The last data block must have\n * mode Z_FINISH (or `true`). That will flush internal pending buffers and call\n * [[Inflate#onEnd]]. For interim explicit flushes (without ending the stream) you\n * can use mode Z_SYNC_FLUSH, keeping the decompression context.\n *\n * On fail call [[Inflate#onEnd]] with error code and return false.\n *\n * We strongly recommend to use `Uint8Array` on input for best speed (output\n * format is detected automatically). Also, don't skip last param and always\n * use the same type in your code (boolean or number). That will improve JS speed.\n *\n * For regular `Array`-s make sure all elements are [0..255].\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nInflate.prototype.push = function (data, mode) {\n var strm = this.strm;\n var chunkSize = this.options.chunkSize;\n var dictionary = this.options.dictionary;\n var status, _mode;\n var next_out_utf8, tail, utf8str;\n\n // Flag to properly process Z_BUF_ERROR on testing inflate call\n // when we check that all output data was flushed.\n var allowBufError = false;\n\n if (this.ended) { return false; }\n _mode = (mode === ~~mode) ? mode : ((mode === true) ? c.Z_FINISH : c.Z_NO_FLUSH);\n\n // Convert data if needed\n if (typeof data === 'string') {\n // Only binary strings can be decompressed on practice\n strm.input = strings.binstring2buf(data);\n } else if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n do {\n if (strm.avail_out === 0) {\n strm.output = new utils.Buf8(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n status = zlib_inflate.inflate(strm, c.Z_NO_FLUSH); /* no bad return value */\n\n if (status === c.Z_NEED_DICT && dictionary) {\n status = zlib_inflate.inflateSetDictionary(this.strm, dictionary);\n }\n\n if (status === c.Z_BUF_ERROR && allowBufError === true) {\n status = c.Z_OK;\n allowBufError = false;\n }\n\n if (status !== c.Z_STREAM_END && status !== c.Z_OK) {\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n\n if (strm.next_out) {\n if (strm.avail_out === 0 || status === c.Z_STREAM_END || (strm.avail_in === 0 && (_mode === c.Z_FINISH || _mode === c.Z_SYNC_FLUSH))) {\n\n if (this.options.to === 'string') {\n\n next_out_utf8 = strings.utf8border(strm.output, strm.next_out);\n\n tail = strm.next_out - next_out_utf8;\n utf8str = strings.buf2string(strm.output, next_out_utf8);\n\n // move tail\n strm.next_out = tail;\n strm.avail_out = chunkSize - tail;\n if (tail) { utils.arraySet(strm.output, strm.output, next_out_utf8, tail, 0); }\n\n this.onData(utf8str);\n\n } else {\n this.onData(utils.shrinkBuf(strm.output, strm.next_out));\n }\n }\n }\n\n // When no more input data, we should check that internal inflate buffers\n // are flushed. The only way to do it when avail_out = 0 - run one more\n // inflate pass. But if output data not exists, inflate return Z_BUF_ERROR.\n // Here we set flag to process this error properly.\n //\n // NOTE. Deflate does not return error in this case and does not needs such\n // logic.\n if (strm.avail_in === 0 && strm.avail_out === 0) {\n allowBufError = true;\n }\n\n } while ((strm.avail_in > 0 || strm.avail_out === 0) && status !== c.Z_STREAM_END);\n\n if (status === c.Z_STREAM_END) {\n _mode = c.Z_FINISH;\n }\n\n // Finalize on the last chunk.\n if (_mode === c.Z_FINISH) {\n status = zlib_inflate.inflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === c.Z_OK;\n }\n\n // callback interim results if Z_SYNC_FLUSH.\n if (_mode === c.Z_SYNC_FLUSH) {\n this.onEnd(c.Z_OK);\n strm.avail_out = 0;\n return true;\n }\n\n return true;\n};\n\n\n/**\n * Inflate#onData(chunk) -> Void\n * - chunk (Uint8Array|Array|String): output data. Type of array depends\n * on js engine support. When string output requested, each chunk\n * will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nInflate.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Inflate#onEnd(status) -> Void\n * - status (Number): inflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called either after you tell inflate that the input stream is\n * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)\n * or if an error happened. By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nInflate.prototype.onEnd = function (status) {\n // On success - join\n if (status === c.Z_OK) {\n if (this.options.to === 'string') {\n // Glue & convert here, until we teach pako to send\n // utf8 aligned strings to onData\n this.result = this.chunks.join('');\n } else {\n this.result = utils.flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * inflate(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Decompress `data` with inflate/ungzip and `options`. Autodetect\n * format via wrapper header by default. That's why we don't provide\n * separate `ungzip` method.\n *\n * Supported options are:\n *\n * - windowBits\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , input = pako.deflate([1,2,3,4,5,6,7,8,9])\n * , output;\n *\n * try {\n * output = pako.inflate(input);\n * } catch (err)\n * console.log(err);\n * }\n * ```\n **/\nfunction inflate(input, options) {\n var inflator = new Inflate(options);\n\n inflator.push(input, true);\n\n // That will never happens, if you don't cheat with options :)\n if (inflator.err) { throw inflator.msg || msg[inflator.err]; }\n\n return inflator.result;\n}\n\n\n/**\n * inflateRaw(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * The same as [[inflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction inflateRaw(input, options) {\n options = options || {};\n options.raw = true;\n return inflate(input, options);\n}\n\n\n/**\n * ungzip(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Just shortcut to [[inflate]], because it autodetects format\n * by header.content. Done for convenience.\n **/\n\n\nexports.Inflate = Inflate;\nexports.inflate = inflate;\nexports.inflateRaw = inflateRaw;\nexports.ungzip = inflate;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar utils = require('../utils/common');\nvar adler32 = require('./adler32');\nvar crc32 = require('./crc32');\nvar inflate_fast = require('./inffast');\nvar inflate_table = require('./inftrees');\n\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n/* Allowed flush values; see deflate() and inflate() below for details */\n//var Z_NO_FLUSH = 0;\n//var Z_PARTIAL_FLUSH = 1;\n//var Z_SYNC_FLUSH = 2;\n//var Z_FULL_FLUSH = 3;\nvar Z_FINISH = 4;\nvar Z_BLOCK = 5;\nvar Z_TREES = 6;\n\n\n/* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\nvar Z_OK = 0;\nvar Z_STREAM_END = 1;\nvar Z_NEED_DICT = 2;\n//var Z_ERRNO = -1;\nvar Z_STREAM_ERROR = -2;\nvar Z_DATA_ERROR = -3;\nvar Z_MEM_ERROR = -4;\nvar Z_BUF_ERROR = -5;\n//var Z_VERSION_ERROR = -6;\n\n/* The deflate compression method */\nvar Z_DEFLATED = 8;\n\n\n/* STATES ====================================================================*/\n/* ===========================================================================*/\n\n\nvar HEAD = 1; /* i: waiting for magic header */\nvar FLAGS = 2; /* i: waiting for method and flags (gzip) */\nvar TIME = 3; /* i: waiting for modification time (gzip) */\nvar OS = 4; /* i: waiting for extra flags and operating system (gzip) */\nvar EXLEN = 5; /* i: waiting for extra length (gzip) */\nvar EXTRA = 6; /* i: waiting for extra bytes (gzip) */\nvar NAME = 7; /* i: waiting for end of file name (gzip) */\nvar COMMENT = 8; /* i: waiting for end of comment (gzip) */\nvar HCRC = 9; /* i: waiting for header crc (gzip) */\nvar DICTID = 10; /* i: waiting for dictionary check value */\nvar DICT = 11; /* waiting for inflateSetDictionary() call */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\nvar TYPEDO = 13; /* i: same, but skip check to exit inflate on new block */\nvar STORED = 14; /* i: waiting for stored size (length and complement) */\nvar COPY_ = 15; /* i/o: same as COPY below, but only first time in */\nvar COPY = 16; /* i/o: waiting for input or output to copy stored block */\nvar TABLE = 17; /* i: waiting for dynamic block table lengths */\nvar LENLENS = 18; /* i: waiting for code length code lengths */\nvar CODELENS = 19; /* i: waiting for length/lit and distance code lengths */\nvar LEN_ = 20; /* i: same as LEN below, but only first time in */\nvar LEN = 21; /* i: waiting for length/lit/eob code */\nvar LENEXT = 22; /* i: waiting for length extra bits */\nvar DIST = 23; /* i: waiting for distance code */\nvar DISTEXT = 24; /* i: waiting for distance extra bits */\nvar MATCH = 25; /* o: waiting for output space to copy string */\nvar LIT = 26; /* o: waiting for output space to write literal */\nvar CHECK = 27; /* i: waiting for 32-bit check value */\nvar LENGTH = 28; /* i: waiting for 32-bit length (gzip) */\nvar DONE = 29; /* finished check, done -- remain here until reset */\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar MEM = 31; /* got an inflate() memory error -- remain here until reset */\nvar SYNC = 32; /* looking for synchronization bytes to restart inflate() */\n\n/* ===========================================================================*/\n\n\n\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nvar MAX_WBITS = 15;\n/* 32K LZ77 window */\nvar DEF_WBITS = MAX_WBITS;\n\n\nfunction zswap32(q) {\n return (((q >>> 24) & 0xff) +\n ((q >>> 8) & 0xff00) +\n ((q & 0xff00) << 8) +\n ((q & 0xff) << 24));\n}\n\n\nfunction InflateState() {\n this.mode = 0; /* current inflate mode */\n this.last = false; /* true if processing last block */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.havedict = false; /* true if dictionary provided */\n this.flags = 0; /* gzip header method and flags (0 if zlib) */\n this.dmax = 0; /* zlib header max distance (INFLATE_STRICT) */\n this.check = 0; /* protected copy of check value */\n this.total = 0; /* protected copy of output count */\n // TODO: may be {}\n this.head = null; /* where to save gzip header information */\n\n /* sliding window */\n this.wbits = 0; /* log base 2 of requested window size */\n this.wsize = 0; /* window size or zero if not using window */\n this.whave = 0; /* valid bytes in the window */\n this.wnext = 0; /* window write index */\n this.window = null; /* allocated sliding window, if needed */\n\n /* bit accumulator */\n this.hold = 0; /* input bit accumulator */\n this.bits = 0; /* number of bits in \"in\" */\n\n /* for string and stored block copying */\n this.length = 0; /* literal or length of data to copy */\n this.offset = 0; /* distance back to copy string from */\n\n /* for table and code decoding */\n this.extra = 0; /* extra bits needed */\n\n /* fixed and dynamic code tables */\n this.lencode = null; /* starting table for length/literal codes */\n this.distcode = null; /* starting table for distance codes */\n this.lenbits = 0; /* index bits for lencode */\n this.distbits = 0; /* index bits for distcode */\n\n /* dynamic table building */\n this.ncode = 0; /* number of code length code lengths */\n this.nlen = 0; /* number of length code lengths */\n this.ndist = 0; /* number of distance code lengths */\n this.have = 0; /* number of code lengths in lens[] */\n this.next = null; /* next available space in codes[] */\n\n this.lens = new utils.Buf16(320); /* temporary storage for code lengths */\n this.work = new utils.Buf16(288); /* work area for code table building */\n\n /*\n because we don't have pointers in js, we use lencode and distcode directly\n as buffers so we don't need codes\n */\n //this.codes = new utils.Buf32(ENOUGH); /* space for code tables */\n this.lendyn = null; /* dynamic table for length/literal codes (JS specific) */\n this.distdyn = null; /* dynamic table for distance codes (JS specific) */\n this.sane = 0; /* if false, allow invalid distance too far */\n this.back = 0; /* bits back of last unprocessed length/lit */\n this.was = 0; /* initial length of match */\n}\n\nfunction inflateResetKeep(strm) {\n var state;\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n strm.total_in = strm.total_out = state.total = 0;\n strm.msg = ''; /*Z_NULL*/\n if (state.wrap) { /* to support ill-conceived Java test suite */\n strm.adler = state.wrap & 1;\n }\n state.mode = HEAD;\n state.last = 0;\n state.havedict = 0;\n state.dmax = 32768;\n state.head = null/*Z_NULL*/;\n state.hold = 0;\n state.bits = 0;\n //state.lencode = state.distcode = state.next = state.codes;\n state.lencode = state.lendyn = new utils.Buf32(ENOUGH_LENS);\n state.distcode = state.distdyn = new utils.Buf32(ENOUGH_DISTS);\n\n state.sane = 1;\n state.back = -1;\n //Tracev((stderr, \"inflate: reset\\n\"));\n return Z_OK;\n}\n\nfunction inflateReset(strm) {\n var state;\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n state.wsize = 0;\n state.whave = 0;\n state.wnext = 0;\n return inflateResetKeep(strm);\n\n}\n\nfunction inflateReset2(strm, windowBits) {\n var wrap;\n var state;\n\n /* get the state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n\n /* extract wrap request from windowBits parameter */\n if (windowBits < 0) {\n wrap = 0;\n windowBits = -windowBits;\n }\n else {\n wrap = (windowBits >> 4) + 1;\n if (windowBits < 48) {\n windowBits &= 15;\n }\n }\n\n /* set number of window bits, free window if different */\n if (windowBits && (windowBits < 8 || windowBits > 15)) {\n return Z_STREAM_ERROR;\n }\n if (state.window !== null && state.wbits !== windowBits) {\n state.window = null;\n }\n\n /* update state and reset the rest of it */\n state.wrap = wrap;\n state.wbits = windowBits;\n return inflateReset(strm);\n}\n\nfunction inflateInit2(strm, windowBits) {\n var ret;\n var state;\n\n if (!strm) { return Z_STREAM_ERROR; }\n //strm.msg = Z_NULL; /* in case we return an error */\n\n state = new InflateState();\n\n //if (state === Z_NULL) return Z_MEM_ERROR;\n //Tracev((stderr, \"inflate: allocated\\n\"));\n strm.state = state;\n state.window = null/*Z_NULL*/;\n ret = inflateReset2(strm, windowBits);\n if (ret !== Z_OK) {\n strm.state = null/*Z_NULL*/;\n }\n return ret;\n}\n\nfunction inflateInit(strm) {\n return inflateInit2(strm, DEF_WBITS);\n}\n\n\n/*\n Return state with length and distance decoding tables and index sizes set to\n fixed code decoding. Normally this returns fixed tables from inffixed.h.\n If BUILDFIXED is defined, then instead this routine builds the tables the\n first time it's called, and returns those tables the first time and\n thereafter. This reduces the size of the code by about 2K bytes, in\n exchange for a little execution time. However, BUILDFIXED should not be\n used for threaded applications, since the rewriting of the tables and virgin\n may not be thread-safe.\n */\nvar virgin = true;\n\nvar lenfix, distfix; // We have no pointers in JS, so keep tables separate\n\nfunction fixedtables(state) {\n /* build fixed huffman tables if first call (may not be thread safe) */\n if (virgin) {\n var sym;\n\n lenfix = new utils.Buf32(512);\n distfix = new utils.Buf32(32);\n\n /* literal/length table */\n sym = 0;\n while (sym < 144) { state.lens[sym++] = 8; }\n while (sym < 256) { state.lens[sym++] = 9; }\n while (sym < 280) { state.lens[sym++] = 7; }\n while (sym < 288) { state.lens[sym++] = 8; }\n\n inflate_table(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });\n\n /* distance table */\n sym = 0;\n while (sym < 32) { state.lens[sym++] = 5; }\n\n inflate_table(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 });\n\n /* do this just once */\n virgin = false;\n }\n\n state.lencode = lenfix;\n state.lenbits = 9;\n state.distcode = distfix;\n state.distbits = 5;\n}\n\n\n/*\n Update the window with the last wsize (normally 32K) bytes written before\n returning. If window does not exist yet, create it. This is only called\n when a window is already in use, or when output has been written during this\n inflate call, but the end of the deflate stream has not been reached yet.\n It is also called to create a window for dictionary data when a dictionary\n is loaded.\n\n Providing output buffers larger than 32K to inflate() should provide a speed\n advantage, since only the last 32K of output is copied to the sliding window\n upon return from inflate(), and since all distances after the first 32K of\n output will fall in the output data, making match copies simpler and faster.\n The advantage may be dependent on the size of the processor's data caches.\n */\nfunction updatewindow(strm, src, end, copy) {\n var dist;\n var state = strm.state;\n\n /* if it hasn't been done already, allocate space for the window */\n if (state.window === null) {\n state.wsize = 1 << state.wbits;\n state.wnext = 0;\n state.whave = 0;\n\n state.window = new utils.Buf8(state.wsize);\n }\n\n /* copy state->wsize or less output bytes into the circular window */\n if (copy >= state.wsize) {\n utils.arraySet(state.window, src, end - state.wsize, state.wsize, 0);\n state.wnext = 0;\n state.whave = state.wsize;\n }\n else {\n dist = state.wsize - state.wnext;\n if (dist > copy) {\n dist = copy;\n }\n //zmemcpy(state->window + state->wnext, end - copy, dist);\n utils.arraySet(state.window, src, end - copy, dist, state.wnext);\n copy -= dist;\n if (copy) {\n //zmemcpy(state->window, end - copy, copy);\n utils.arraySet(state.window, src, end - copy, copy, 0);\n state.wnext = copy;\n state.whave = state.wsize;\n }\n else {\n state.wnext += dist;\n if (state.wnext === state.wsize) { state.wnext = 0; }\n if (state.whave < state.wsize) { state.whave += dist; }\n }\n }\n return 0;\n}\n\nfunction inflate(strm, flush) {\n var state;\n var input, output; // input/output buffers\n var next; /* next input INDEX */\n var put; /* next output INDEX */\n var have, left; /* available input and output */\n var hold; /* bit buffer */\n var bits; /* bits in bit buffer */\n var _in, _out; /* save starting available input and output */\n var copy; /* number of stored or match bytes to copy */\n var from; /* where to copy match bytes from */\n var from_source;\n var here = 0; /* current decoding table entry */\n var here_bits, here_op, here_val; // paked \"here\" denormalized (JS specific)\n //var last; /* parent table entry */\n var last_bits, last_op, last_val; // paked \"last\" denormalized (JS specific)\n var len; /* length to copy for repeats, bits to drop */\n var ret; /* return code */\n var hbuf = new utils.Buf8(4); /* buffer for gzip header crc calculation */\n var opts;\n\n var n; // temporary var for NEED_BITS\n\n var order = /* permutation of code lengths */\n [ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ];\n\n\n if (!strm || !strm.state || !strm.output ||\n (!strm.input && strm.avail_in !== 0)) {\n return Z_STREAM_ERROR;\n }\n\n state = strm.state;\n if (state.mode === TYPE) { state.mode = TYPEDO; } /* skip check */\n\n\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n _in = have;\n _out = left;\n ret = Z_OK;\n\n inf_leave: // goto emulation\n for (;;) {\n switch (state.mode) {\n case HEAD:\n if (state.wrap === 0) {\n state.mode = TYPEDO;\n break;\n }\n //=== NEEDBITS(16);\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 2) && hold === 0x8b1f) { /* gzip header */\n state.check = 0/*crc32(0L, Z_NULL, 0)*/;\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = FLAGS;\n break;\n }\n state.flags = 0; /* expect zlib header */\n if (state.head) {\n state.head.done = false;\n }\n if (!(state.wrap & 1) || /* check if zlib header allowed */\n (((hold & 0xff)/*BITS(8)*/ << 8) + (hold >> 8)) % 31) {\n strm.msg = 'incorrect header check';\n state.mode = BAD;\n break;\n }\n if ((hold & 0x0f)/*BITS(4)*/ !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n len = (hold & 0x0f)/*BITS(4)*/ + 8;\n if (state.wbits === 0) {\n state.wbits = len;\n }\n else if (len > state.wbits) {\n strm.msg = 'invalid window size';\n state.mode = BAD;\n break;\n }\n state.dmax = 1 << len;\n //Tracev((stderr, \"inflate: zlib header ok\\n\"));\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = hold & 0x200 ? DICTID : TYPE;\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n break;\n case FLAGS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.flags = hold;\n if ((state.flags & 0xff) !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n if (state.flags & 0xe000) {\n strm.msg = 'unknown header flags set';\n state.mode = BAD;\n break;\n }\n if (state.head) {\n state.head.text = ((hold >> 8) & 1);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = TIME;\n /* falls through */\n case TIME:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.time = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC4(state.check, hold)\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n hbuf[2] = (hold >>> 16) & 0xff;\n hbuf[3] = (hold >>> 24) & 0xff;\n state.check = crc32(state.check, hbuf, 4, 0);\n //===\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = OS;\n /* falls through */\n case OS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.xflags = (hold & 0xff);\n state.head.os = (hold >> 8);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = EXLEN;\n /* falls through */\n case EXLEN:\n if (state.flags & 0x0400) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length = hold;\n if (state.head) {\n state.head.extra_len = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n else if (state.head) {\n state.head.extra = null/*Z_NULL*/;\n }\n state.mode = EXTRA;\n /* falls through */\n case EXTRA:\n if (state.flags & 0x0400) {\n copy = state.length;\n if (copy > have) { copy = have; }\n if (copy) {\n if (state.head) {\n len = state.head.extra_len - state.length;\n if (!state.head.extra) {\n // Use untyped array for more convenient processing later\n state.head.extra = new Array(state.head.extra_len);\n }\n utils.arraySet(\n state.head.extra,\n input,\n next,\n // extra field is limited to 65536 bytes\n // - no need for additional size check\n copy,\n /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/\n len\n );\n //zmemcpy(state.head.extra + len, next,\n // len + copy > state.head.extra_max ?\n // state.head.extra_max - len : copy);\n }\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n state.length -= copy;\n }\n if (state.length) { break inf_leave; }\n }\n state.length = 0;\n state.mode = NAME;\n /* falls through */\n case NAME:\n if (state.flags & 0x0800) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n // TODO: 2 or 1 bytes?\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.name_max*/)) {\n state.head.name += String.fromCharCode(len);\n }\n } while (len && copy < have);\n\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.name = null;\n }\n state.length = 0;\n state.mode = COMMENT;\n /* falls through */\n case COMMENT:\n if (state.flags & 0x1000) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.comm_max*/)) {\n state.head.comment += String.fromCharCode(len);\n }\n } while (len && copy < have);\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.comment = null;\n }\n state.mode = HCRC;\n /* falls through */\n case HCRC:\n if (state.flags & 0x0200) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.check & 0xffff)) {\n strm.msg = 'header crc mismatch';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n if (state.head) {\n state.head.hcrc = ((state.flags >> 9) & 1);\n state.head.done = true;\n }\n strm.adler = state.check = 0;\n state.mode = TYPE;\n break;\n case DICTID:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n strm.adler = state.check = zswap32(hold);\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = DICT;\n /* falls through */\n case DICT:\n if (state.havedict === 0) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n return Z_NEED_DICT;\n }\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = TYPE;\n /* falls through */\n case TYPE:\n if (flush === Z_BLOCK || flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case TYPEDO:\n if (state.last) {\n //--- BYTEBITS() ---//\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n state.mode = CHECK;\n break;\n }\n //=== NEEDBITS(3); */\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.last = (hold & 0x01)/*BITS(1)*/;\n //--- DROPBITS(1) ---//\n hold >>>= 1;\n bits -= 1;\n //---//\n\n switch ((hold & 0x03)/*BITS(2)*/) {\n case 0: /* stored block */\n //Tracev((stderr, \"inflate: stored block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = STORED;\n break;\n case 1: /* fixed block */\n fixedtables(state);\n //Tracev((stderr, \"inflate: fixed codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = LEN_; /* decode codes */\n if (flush === Z_TREES) {\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break inf_leave;\n }\n break;\n case 2: /* dynamic block */\n //Tracev((stderr, \"inflate: dynamic codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = TABLE;\n break;\n case 3:\n strm.msg = 'invalid block type';\n state.mode = BAD;\n }\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break;\n case STORED:\n //--- BYTEBITS() ---// /* go to byte boundary */\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {\n strm.msg = 'invalid stored block lengths';\n state.mode = BAD;\n break;\n }\n state.length = hold & 0xffff;\n //Tracev((stderr, \"inflate: stored length %u\\n\",\n // state.length));\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = COPY_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case COPY_:\n state.mode = COPY;\n /* falls through */\n case COPY:\n copy = state.length;\n if (copy) {\n if (copy > have) { copy = have; }\n if (copy > left) { copy = left; }\n if (copy === 0) { break inf_leave; }\n //--- zmemcpy(put, next, copy); ---\n utils.arraySet(output, input, next, copy, put);\n //---//\n have -= copy;\n next += copy;\n left -= copy;\n put += copy;\n state.length -= copy;\n break;\n }\n //Tracev((stderr, \"inflate: stored end\\n\"));\n state.mode = TYPE;\n break;\n case TABLE:\n //=== NEEDBITS(14); */\n while (bits < 14) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.nlen = (hold & 0x1f)/*BITS(5)*/ + 257;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ndist = (hold & 0x1f)/*BITS(5)*/ + 1;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ncode = (hold & 0x0f)/*BITS(4)*/ + 4;\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n//#ifndef PKZIP_BUG_WORKAROUND\n if (state.nlen > 286 || state.ndist > 30) {\n strm.msg = 'too many length or distance symbols';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracev((stderr, \"inflate: table sizes ok\\n\"));\n state.have = 0;\n state.mode = LENLENS;\n /* falls through */\n case LENLENS:\n while (state.have < state.ncode) {\n //=== NEEDBITS(3);\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.lens[order[state.have++]] = (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n while (state.have < 19) {\n state.lens[order[state.have++]] = 0;\n }\n // We have separate tables & no pointers. 2 commented lines below not needed.\n //state.next = state.codes;\n //state.lencode = state.next;\n // Switch to use dynamic table\n state.lencode = state.lendyn;\n state.lenbits = 7;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);\n state.lenbits = opts.bits;\n\n if (ret) {\n strm.msg = 'invalid code lengths set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, \"inflate: code lengths ok\\n\"));\n state.have = 0;\n state.mode = CODELENS;\n /* falls through */\n case CODELENS:\n while (state.have < state.nlen + state.ndist) {\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)];/*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_val < 16) {\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.lens[state.have++] = here_val;\n }\n else {\n if (here_val === 16) {\n //=== NEEDBITS(here.bits + 2);\n n = here_bits + 2;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n if (state.have === 0) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n len = state.lens[state.have - 1];\n copy = 3 + (hold & 0x03);//BITS(2);\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n }\n else if (here_val === 17) {\n //=== NEEDBITS(here.bits + 3);\n n = here_bits + 3;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 3 + (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n else {\n //=== NEEDBITS(here.bits + 7);\n n = here_bits + 7;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 11 + (hold & 0x7f);//BITS(7);\n //--- DROPBITS(7) ---//\n hold >>>= 7;\n bits -= 7;\n //---//\n }\n if (state.have + copy > state.nlen + state.ndist) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n while (copy--) {\n state.lens[state.have++] = len;\n }\n }\n }\n\n /* handle error breaks in while */\n if (state.mode === BAD) { break; }\n\n /* check for end-of-block code (better have one) */\n if (state.lens[256] === 0) {\n strm.msg = 'invalid code -- missing end-of-block';\n state.mode = BAD;\n break;\n }\n\n /* build code tables -- note: do not change the lenbits or distbits\n values here (9 and 6) without reading the comments in inftrees.h\n concerning the ENOUGH constants, which depend on those values */\n state.lenbits = 9;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.lenbits = opts.bits;\n // state.lencode = state.next;\n\n if (ret) {\n strm.msg = 'invalid literal/lengths set';\n state.mode = BAD;\n break;\n }\n\n state.distbits = 6;\n //state.distcode.copy(state.codes);\n // Switch to use dynamic table\n state.distcode = state.distdyn;\n opts = { bits: state.distbits };\n ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.distbits = opts.bits;\n // state.distcode = state.next;\n\n if (ret) {\n strm.msg = 'invalid distances set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, 'inflate: codes ok\\n'));\n state.mode = LEN_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case LEN_:\n state.mode = LEN;\n /* falls through */\n case LEN:\n if (have >= 6 && left >= 258) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n inflate_fast(strm, _out);\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n if (state.mode === TYPE) {\n state.back = -1;\n }\n break;\n }\n state.back = 0;\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if (here_bits <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_op && (here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.lencode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n state.length = here_val;\n if (here_op === 0) {\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n state.mode = LIT;\n break;\n }\n if (here_op & 32) {\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.back = -1;\n state.mode = TYPE;\n break;\n }\n if (here_op & 64) {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break;\n }\n state.extra = here_op & 15;\n state.mode = LENEXT;\n /* falls through */\n case LENEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", state.length));\n state.was = state.length;\n state.mode = DIST;\n /* falls through */\n case DIST:\n for (;;) {\n here = state.distcode[hold & ((1 << state.distbits) - 1)];/*BITS(state.distbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if ((here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.distcode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n if (here_op & 64) {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break;\n }\n state.offset = here_val;\n state.extra = (here_op) & 15;\n state.mode = DISTEXT;\n /* falls through */\n case DISTEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.offset += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n//#ifdef INFLATE_STRICT\n if (state.offset > state.dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracevv((stderr, \"inflate: distance %u\\n\", state.offset));\n state.mode = MATCH;\n /* falls through */\n case MATCH:\n if (left === 0) { break inf_leave; }\n copy = _out - left;\n if (state.offset > copy) { /* copy from window */\n copy = state.offset - copy;\n if (copy > state.whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// Trace((stderr, \"inflate.c too far\\n\"));\n// copy -= state.whave;\n// if (copy > state.length) { copy = state.length; }\n// if (copy > left) { copy = left; }\n// left -= copy;\n// state.length -= copy;\n// do {\n// output[put++] = 0;\n// } while (--copy);\n// if (state.length === 0) { state.mode = LEN; }\n// break;\n//#endif\n }\n if (copy > state.wnext) {\n copy -= state.wnext;\n from = state.wsize - copy;\n }\n else {\n from = state.wnext - copy;\n }\n if (copy > state.length) { copy = state.length; }\n from_source = state.window;\n }\n else { /* copy from output */\n from_source = output;\n from = put - state.offset;\n copy = state.length;\n }\n if (copy > left) { copy = left; }\n left -= copy;\n state.length -= copy;\n do {\n output[put++] = from_source[from++];\n } while (--copy);\n if (state.length === 0) { state.mode = LEN; }\n break;\n case LIT:\n if (left === 0) { break inf_leave; }\n output[put++] = state.length;\n left--;\n state.mode = LEN;\n break;\n case CHECK:\n if (state.wrap) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n // Use '|' instead of '+' to make sure that result is signed\n hold |= input[next++] << bits;\n bits += 8;\n }\n //===//\n _out -= left;\n strm.total_out += _out;\n state.total += _out;\n if (_out) {\n strm.adler = state.check =\n /*UPDATE(state.check, put - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, put - _out) : adler32(state.check, output, _out, put - _out));\n\n }\n _out = left;\n // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too\n if ((state.flags ? hold : zswap32(hold)) !== state.check) {\n strm.msg = 'incorrect data check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: check matches trailer\\n\"));\n }\n state.mode = LENGTH;\n /* falls through */\n case LENGTH:\n if (state.wrap && state.flags) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.total & 0xffffffff)) {\n strm.msg = 'incorrect length check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: length matches trailer\\n\"));\n }\n state.mode = DONE;\n /* falls through */\n case DONE:\n ret = Z_STREAM_END;\n break inf_leave;\n case BAD:\n ret = Z_DATA_ERROR;\n break inf_leave;\n case MEM:\n return Z_MEM_ERROR;\n case SYNC:\n /* falls through */\n default:\n return Z_STREAM_ERROR;\n }\n }\n\n // inf_leave <- here is real place for \"goto inf_leave\", emulated via \"break inf_leave\"\n\n /*\n Return from inflate(), updating the total counts and the check value.\n If there was no progress during the inflate() call, return a buffer\n error. Call updatewindow() to create and/or update the window state.\n Note: a memory error from inflate() is non-recoverable.\n */\n\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n\n if (state.wsize || (_out !== strm.avail_out && state.mode < BAD &&\n (state.mode < CHECK || flush !== Z_FINISH))) {\n if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n }\n _in -= strm.avail_in;\n _out -= strm.avail_out;\n strm.total_in += _in;\n strm.total_out += _out;\n state.total += _out;\n if (state.wrap && _out) {\n strm.adler = state.check = /*UPDATE(state.check, strm.next_out - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, strm.next_out - _out) : adler32(state.check, output, _out, strm.next_out - _out));\n }\n strm.data_type = state.bits + (state.last ? 64 : 0) +\n (state.mode === TYPE ? 128 : 0) +\n (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);\n if (((_in === 0 && _out === 0) || flush === Z_FINISH) && ret === Z_OK) {\n ret = Z_BUF_ERROR;\n }\n return ret;\n}\n\nfunction inflateEnd(strm) {\n\n if (!strm || !strm.state /*|| strm->zfree == (free_func)0*/) {\n return Z_STREAM_ERROR;\n }\n\n var state = strm.state;\n if (state.window) {\n state.window = null;\n }\n strm.state = null;\n return Z_OK;\n}\n\nfunction inflateGetHeader(strm, head) {\n var state;\n\n /* check state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR; }\n\n /* save header structure */\n state.head = head;\n head.done = false;\n return Z_OK;\n}\n\nfunction inflateSetDictionary(strm, dictionary) {\n var dictLength = dictionary.length;\n\n var state;\n var dictid;\n var ret;\n\n /* check state */\n if (!strm /* == Z_NULL */ || !strm.state /* == Z_NULL */) { return Z_STREAM_ERROR; }\n state = strm.state;\n\n if (state.wrap !== 0 && state.mode !== DICT) {\n return Z_STREAM_ERROR;\n }\n\n /* check for correct dictionary identifier */\n if (state.mode === DICT) {\n dictid = 1; /* adler32(0, null, 0)*/\n /* dictid = adler32(dictid, dictionary, dictLength); */\n dictid = adler32(dictid, dictionary, dictLength, 0);\n if (dictid !== state.check) {\n return Z_DATA_ERROR;\n }\n }\n /* copy dictionary to window using updatewindow(), which will amend the\n existing dictionary if appropriate */\n ret = updatewindow(strm, dictionary, dictLength, dictLength);\n if (ret) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n state.havedict = 1;\n // Tracev((stderr, \"inflate: dictionary set\\n\"));\n return Z_OK;\n}\n\nexports.inflateReset = inflateReset;\nexports.inflateReset2 = inflateReset2;\nexports.inflateResetKeep = inflateResetKeep;\nexports.inflateInit = inflateInit;\nexports.inflateInit2 = inflateInit2;\nexports.inflate = inflate;\nexports.inflateEnd = inflateEnd;\nexports.inflateGetHeader = inflateGetHeader;\nexports.inflateSetDictionary = inflateSetDictionary;\nexports.inflateInfo = 'pako inflate (from Nodeca project)';\n\n/* Not implemented\nexports.inflateCopy = inflateCopy;\nexports.inflateGetDictionary = inflateGetDictionary;\nexports.inflateMark = inflateMark;\nexports.inflatePrime = inflatePrime;\nexports.inflateSync = inflateSync;\nexports.inflateSyncPoint = inflateSyncPoint;\nexports.inflateUndermine = inflateUndermine;\n*/\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// See state defs from inflate.js\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\n\n/*\n Decode literal, length, and distance codes and write out the resulting\n literal and match bytes until either not enough input or output is\n available, an end-of-block is encountered, or a data error is encountered.\n When large enough input and output buffers are supplied to inflate(), for\n example, a 16K input buffer and a 64K output buffer, more than 95% of the\n inflate execution time is spent in this routine.\n\n Entry assumptions:\n\n state.mode === LEN\n strm.avail_in >= 6\n strm.avail_out >= 258\n start >= strm.avail_out\n state.bits < 8\n\n On return, state.mode is one of:\n\n LEN -- ran out of enough output space or enough available input\n TYPE -- reached end of block code, inflate() to interpret next block\n BAD -- error in block data\n\n Notes:\n\n - The maximum input bits used by a length/distance pair is 15 bits for the\n length code, 5 bits for the length extra, 15 bits for the distance code,\n and 13 bits for the distance extra. This totals 48 bits, or six bytes.\n Therefore if strm.avail_in >= 6, then there is enough input to avoid\n checking for available input while decoding.\n\n - The maximum bytes that a single length/distance pair can output is 258\n bytes, which is the maximum length that can be coded. inflate_fast()\n requires strm.avail_out >= 258 for each loop to avoid checking for\n output space.\n */\nmodule.exports = function inflate_fast(strm, start) {\n var state;\n var _in; /* local strm.input */\n var last; /* have enough input while in < last */\n var _out; /* local strm.output */\n var beg; /* inflate()'s initial strm.output */\n var end; /* while out < end, enough space available */\n//#ifdef INFLATE_STRICT\n var dmax; /* maximum distance from zlib header */\n//#endif\n var wsize; /* window size or zero if not using window */\n var whave; /* valid bytes in the window */\n var wnext; /* window write index */\n // Use `s_window` instead `window`, avoid conflict with instrumentation tools\n var s_window; /* allocated sliding window, if wsize != 0 */\n var hold; /* local strm.hold */\n var bits; /* local strm.bits */\n var lcode; /* local strm.lencode */\n var dcode; /* local strm.distcode */\n var lmask; /* mask for first level of length codes */\n var dmask; /* mask for first level of distance codes */\n var here; /* retrieved table entry */\n var op; /* code bits, operation, extra bits, or */\n /* window position, window bytes to copy */\n var len; /* match length, unused bytes */\n var dist; /* match distance */\n var from; /* where to copy match from */\n var from_source;\n\n\n var input, output; // JS specific, because we have no pointers\n\n /* copy state to local variables */\n state = strm.state;\n //here = state.here;\n _in = strm.next_in;\n input = strm.input;\n last = _in + (strm.avail_in - 5);\n _out = strm.next_out;\n output = strm.output;\n beg = _out - (start - strm.avail_out);\n end = _out + (strm.avail_out - 257);\n//#ifdef INFLATE_STRICT\n dmax = state.dmax;\n//#endif\n wsize = state.wsize;\n whave = state.whave;\n wnext = state.wnext;\n s_window = state.window;\n hold = state.hold;\n bits = state.bits;\n lcode = state.lencode;\n dcode = state.distcode;\n lmask = (1 << state.lenbits) - 1;\n dmask = (1 << state.distbits) - 1;\n\n\n /* decode literals and length/distances until end-of-block or not enough\n input data or output space */\n\n top:\n do {\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n\n here = lcode[hold & lmask];\n\n dolen:\n for (;;) { // Goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n if (op === 0) { /* literal */\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n output[_out++] = here & 0xffff/*here.val*/;\n }\n else if (op & 16) { /* length base */\n len = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (op) {\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n len += hold & ((1 << op) - 1);\n hold >>>= op;\n bits -= op;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", len));\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n here = dcode[hold & dmask];\n\n dodist:\n for (;;) { // goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n\n if (op & 16) { /* distance base */\n dist = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n }\n dist += hold & ((1 << op) - 1);\n//#ifdef INFLATE_STRICT\n if (dist > dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n//#endif\n hold >>>= op;\n bits -= op;\n //Tracevv((stderr, \"inflate: distance %u\\n\", dist));\n op = _out - beg; /* max distance in output */\n if (dist > op) { /* see if copy from window */\n op = dist - op; /* distance back in window */\n if (op > whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// if (len <= op - whave) {\n// do {\n// output[_out++] = 0;\n// } while (--len);\n// continue top;\n// }\n// len -= op - whave;\n// do {\n// output[_out++] = 0;\n// } while (--op > whave);\n// if (op === 0) {\n// from = _out - dist;\n// do {\n// output[_out++] = output[from++];\n// } while (--len);\n// continue top;\n// }\n//#endif\n }\n from = 0; // window index\n from_source = s_window;\n if (wnext === 0) { /* very common case */\n from += wsize - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n else if (wnext < op) { /* wrap around window */\n from += wsize + wnext - op;\n op -= wnext;\n if (op < len) { /* some from end of window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = 0;\n if (wnext < len) { /* some from start of window */\n op = wnext;\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n }\n else { /* contiguous in window */\n from += wnext - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n while (len > 2) {\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n len -= 3;\n }\n if (len) {\n output[_out++] = from_source[from++];\n if (len > 1) {\n output[_out++] = from_source[from++];\n }\n }\n }\n else {\n from = _out - dist; /* copy direct from output */\n do { /* minimum length is three */\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n len -= 3;\n } while (len > 2);\n if (len) {\n output[_out++] = output[from++];\n if (len > 1) {\n output[_out++] = output[from++];\n }\n }\n }\n }\n else if ((op & 64) === 0) { /* 2nd level distance code */\n here = dcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dodist;\n }\n else {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n }\n else if ((op & 64) === 0) { /* 2nd level length code */\n here = lcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dolen;\n }\n else if (op & 32) { /* end-of-block */\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.mode = TYPE;\n break top;\n }\n else {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n } while (_in < last && _out < end);\n\n /* return unused bytes (on entry, bits < 8, so in won't go too far back) */\n len = bits >> 3;\n _in -= len;\n bits -= len << 3;\n hold &= (1 << bits) - 1;\n\n /* update state and return */\n strm.next_in = _in;\n strm.next_out = _out;\n strm.avail_in = (_in < last ? 5 + (last - _in) : 5 - (_in - last));\n strm.avail_out = (_out < end ? 257 + (end - _out) : 257 - (_out - end));\n state.hold = hold;\n state.bits = bits;\n return;\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar utils = require('../utils/common');\n\nvar MAXBITS = 15;\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\n\nvar lbase = [ /* Length codes 257..285 base */\n 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,\n 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0\n];\n\nvar lext = [ /* Length codes 257..285 extra */\n 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,\n 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78\n];\n\nvar dbase = [ /* Distance codes 0..29 base */\n 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,\n 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,\n 8193, 12289, 16385, 24577, 0, 0\n];\n\nvar dext = [ /* Distance codes 0..29 extra */\n 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,\n 23, 23, 24, 24, 25, 25, 26, 26, 27, 27,\n 28, 28, 29, 29, 64, 64\n];\n\nmodule.exports = function inflate_table(type, lens, lens_index, codes, table, table_index, work, opts)\n{\n var bits = opts.bits;\n //here = opts.here; /* table entry for duplication */\n\n var len = 0; /* a code's length in bits */\n var sym = 0; /* index of code symbols */\n var min = 0, max = 0; /* minimum and maximum code lengths */\n var root = 0; /* number of index bits for root table */\n var curr = 0; /* number of index bits for current table */\n var drop = 0; /* code bits to drop for sub-table */\n var left = 0; /* number of prefix codes available */\n var used = 0; /* code entries in table used */\n var huff = 0; /* Huffman code */\n var incr; /* for incrementing code, index */\n var fill; /* index for replicating entries */\n var low; /* low bits for current root entry */\n var mask; /* mask for low root bits */\n var next; /* next available space in table */\n var base = null; /* base value table to use */\n var base_index = 0;\n// var shoextra; /* extra bits table to use */\n var end; /* use base and extra for symbol > end */\n var count = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* number of codes of each length */\n var offs = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* offsets in table for each length */\n var extra = null;\n var extra_index = 0;\n\n var here_bits, here_op, here_val;\n\n /*\n Process a set of code lengths to create a canonical Huffman code. The\n code lengths are lens[0..codes-1]. Each length corresponds to the\n symbols 0..codes-1. The Huffman code is generated by first sorting the\n symbols by length from short to long, and retaining the symbol order\n for codes with equal lengths. Then the code starts with all zero bits\n for the first code of the shortest length, and the codes are integer\n increments for the same length, and zeros are appended as the length\n increases. For the deflate format, these bits are stored backwards\n from their more natural integer increment ordering, and so when the\n decoding tables are built in the large loop below, the integer codes\n are incremented backwards.\n\n This routine assumes, but does not check, that all of the entries in\n lens[] are in the range 0..MAXBITS. The caller must assure this.\n 1..MAXBITS is interpreted as that code length. zero means that that\n symbol does not occur in this code.\n\n The codes are sorted by computing a count of codes for each length,\n creating from that a table of starting indices for each length in the\n sorted table, and then entering the symbols in order in the sorted\n table. The sorted table is work[], with that space being provided by\n the caller.\n\n The length counts are used for other purposes as well, i.e. finding\n the minimum and maximum length codes, determining if there are any\n codes at all, checking for a valid set of lengths, and looking ahead\n at length counts to determine sub-table sizes when building the\n decoding tables.\n */\n\n /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */\n for (len = 0; len <= MAXBITS; len++) {\n count[len] = 0;\n }\n for (sym = 0; sym < codes; sym++) {\n count[lens[lens_index + sym]]++;\n }\n\n /* bound code lengths, force root to be within code lengths */\n root = bits;\n for (max = MAXBITS; max >= 1; max--) {\n if (count[max] !== 0) { break; }\n }\n if (root > max) {\n root = max;\n }\n if (max === 0) { /* no symbols to code at all */\n //table.op[opts.table_index] = 64; //here.op = (var char)64; /* invalid code marker */\n //table.bits[opts.table_index] = 1; //here.bits = (var char)1;\n //table.val[opts.table_index++] = 0; //here.val = (var short)0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n\n //table.op[opts.table_index] = 64;\n //table.bits[opts.table_index] = 1;\n //table.val[opts.table_index++] = 0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n opts.bits = 1;\n return 0; /* no symbols, but wait for decoding to report error */\n }\n for (min = 1; min < max; min++) {\n if (count[min] !== 0) { break; }\n }\n if (root < min) {\n root = min;\n }\n\n /* check for an over-subscribed or incomplete set of lengths */\n left = 1;\n for (len = 1; len <= MAXBITS; len++) {\n left <<= 1;\n left -= count[len];\n if (left < 0) {\n return -1;\n } /* over-subscribed */\n }\n if (left > 0 && (type === CODES || max !== 1)) {\n return -1; /* incomplete set */\n }\n\n /* generate offsets into symbol table for each length for sorting */\n offs[1] = 0;\n for (len = 1; len < MAXBITS; len++) {\n offs[len + 1] = offs[len] + count[len];\n }\n\n /* sort symbols by length, by symbol order within each length */\n for (sym = 0; sym < codes; sym++) {\n if (lens[lens_index + sym] !== 0) {\n work[offs[lens[lens_index + sym]]++] = sym;\n }\n }\n\n /*\n Create and fill in decoding tables. In this loop, the table being\n filled is at next and has curr index bits. The code being used is huff\n with length len. That code is converted to an index by dropping drop\n bits off of the bottom. For codes where len is less than drop + curr,\n those top drop + curr - len bits are incremented through all values to\n fill the table with replicated entries.\n\n root is the number of index bits for the root table. When len exceeds\n root, sub-tables are created pointed to by the root entry with an index\n of the low root bits of huff. This is saved in low to check for when a\n new sub-table should be started. drop is zero when the root table is\n being filled, and drop is root when sub-tables are being filled.\n\n When a new sub-table is needed, it is necessary to look ahead in the\n code lengths to determine what size sub-table is needed. The length\n counts are used for this, and so count[] is decremented as codes are\n entered in the tables.\n\n used keeps track of how many table entries have been allocated from the\n provided *table space. It is checked for LENS and DIST tables against\n the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in\n the initial root table size constants. See the comments in inftrees.h\n for more information.\n\n sym increments through all symbols, and the loop terminates when\n all codes of length max, i.e. all codes, have been processed. This\n routine permits incomplete codes, so another loop after this one fills\n in the rest of the decoding tables with invalid code markers.\n */\n\n /* set up for code type */\n // poor man optimization - use if-else instead of switch,\n // to avoid deopts in old v8\n if (type === CODES) {\n base = extra = work; /* dummy value--not used */\n end = 19;\n\n } else if (type === LENS) {\n base = lbase;\n base_index -= 257;\n extra = lext;\n extra_index -= 257;\n end = 256;\n\n } else { /* DISTS */\n base = dbase;\n extra = dext;\n end = -1;\n }\n\n /* initialize opts for loop */\n huff = 0; /* starting code */\n sym = 0; /* starting code symbol */\n len = min; /* starting code length */\n next = table_index; /* current table to fill in */\n curr = root; /* current table index bits */\n drop = 0; /* current bits to drop from code for index */\n low = -1; /* trigger new sub-table when len > root */\n used = 1 << root; /* use root table entries */\n mask = used - 1; /* mask for comparing low */\n\n /* check available table space */\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* process all codes and make table entries */\n for (;;) {\n /* create table entry */\n here_bits = len - drop;\n if (work[sym] < end) {\n here_op = 0;\n here_val = work[sym];\n }\n else if (work[sym] > end) {\n here_op = extra[extra_index + work[sym]];\n here_val = base[base_index + work[sym]];\n }\n else {\n here_op = 32 + 64; /* end of block */\n here_val = 0;\n }\n\n /* replicate for those indices with low len bits equal to huff */\n incr = 1 << (len - drop);\n fill = 1 << curr;\n min = fill; /* save offset to next table */\n do {\n fill -= incr;\n table[next + (huff >> drop) + fill] = (here_bits << 24) | (here_op << 16) | here_val |0;\n } while (fill !== 0);\n\n /* backwards increment the len-bit code huff */\n incr = 1 << (len - 1);\n while (huff & incr) {\n incr >>= 1;\n }\n if (incr !== 0) {\n huff &= incr - 1;\n huff += incr;\n } else {\n huff = 0;\n }\n\n /* go to next symbol, update count, len */\n sym++;\n if (--count[len] === 0) {\n if (len === max) { break; }\n len = lens[lens_index + work[sym]];\n }\n\n /* create new sub-table if needed */\n if (len > root && (huff & mask) !== low) {\n /* if first time, transition to sub-tables */\n if (drop === 0) {\n drop = root;\n }\n\n /* increment past last table */\n next += min; /* here min is 1 << curr */\n\n /* determine length of next table */\n curr = len - drop;\n left = 1 << curr;\n while (curr + drop < max) {\n left -= count[curr + drop];\n if (left <= 0) { break; }\n curr++;\n left <<= 1;\n }\n\n /* check for enough space */\n used += 1 << curr;\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* point entry in root table to sub-table */\n low = huff & mask;\n /*table.op[low] = curr;\n table.bits[low] = root;\n table.val[low] = next - opts.table_index;*/\n table[low] = (root << 24) | (curr << 16) | (next - table_index) |0;\n }\n }\n\n /* fill in remaining table entry if code is incomplete (guaranteed to have\n at most one remaining entry, since if the code is incomplete, the\n maximum code length that was allowed to get this far is one bit) */\n if (huff !== 0) {\n //table.op[next + huff] = 64; /* invalid code marker */\n //table.bits[next + huff] = len - drop;\n //table.val[next + huff] = 0;\n table[next + huff] = ((len - drop) << 24) | (64 << 16) |0;\n }\n\n /* set return parameters */\n //opts.table_index += used;\n opts.bits = root;\n return 0;\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nmodule.exports = {\n\n /* Allowed flush values; see deflate() and inflate() below for details */\n Z_NO_FLUSH: 0,\n Z_PARTIAL_FLUSH: 1,\n Z_SYNC_FLUSH: 2,\n Z_FULL_FLUSH: 3,\n Z_FINISH: 4,\n Z_BLOCK: 5,\n Z_TREES: 6,\n\n /* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\n Z_OK: 0,\n Z_STREAM_END: 1,\n Z_NEED_DICT: 2,\n Z_ERRNO: -1,\n Z_STREAM_ERROR: -2,\n Z_DATA_ERROR: -3,\n //Z_MEM_ERROR: -4,\n Z_BUF_ERROR: -5,\n //Z_VERSION_ERROR: -6,\n\n /* compression levels */\n Z_NO_COMPRESSION: 0,\n Z_BEST_SPEED: 1,\n Z_BEST_COMPRESSION: 9,\n Z_DEFAULT_COMPRESSION: -1,\n\n\n Z_FILTERED: 1,\n Z_HUFFMAN_ONLY: 2,\n Z_RLE: 3,\n Z_FIXED: 4,\n Z_DEFAULT_STRATEGY: 0,\n\n /* Possible values of the data_type field (though see inflate()) */\n Z_BINARY: 0,\n Z_TEXT: 1,\n //Z_ASCII: 1, // = Z_TEXT (deprecated)\n Z_UNKNOWN: 2,\n\n /* The deflate compression method */\n Z_DEFLATED: 8\n //Z_NULL: null // Use -1 or null inline, depending on var type\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction GZheader() {\n /* true if compressed data believed to be text */\n this.text = 0;\n /* modification time */\n this.time = 0;\n /* extra flags (not used when writing a gzip file) */\n this.xflags = 0;\n /* operating system */\n this.os = 0;\n /* pointer to extra field or Z_NULL if none */\n this.extra = null;\n /* extra field length (valid if extra != Z_NULL) */\n this.extra_len = 0; // Actually, we don't need it in JS,\n // but leave for few code modifications\n\n //\n // Setup limits is not necessary because in js we should not preallocate memory\n // for inflate use constant limit in 65536 bytes\n //\n\n /* space at extra (only when reading header) */\n // this.extra_max = 0;\n /* pointer to zero-terminated file name or Z_NULL */\n this.name = '';\n /* space at name (only when reading header) */\n // this.name_max = 0;\n /* pointer to zero-terminated comment or Z_NULL */\n this.comment = '';\n /* space at comment (only when reading header) */\n // this.comm_max = 0;\n /* true if there was or will be a header crc */\n this.hcrc = 0;\n /* true when done reading gzip header (not used when writing a gzip file) */\n this.done = false;\n}\n\nmodule.exports = GZheader;\n","'use strict'\n\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\n\n/**\n * Takes an (async) iterable that yields buffer-like-objects and concats them\n * into one buffer\n * @param {AsyncIterable<Uint8Array>|Iterable<Uint8Array>} stream\n */\nasync function toBuffer (stream) {\n let buffer = new Uint8Array(0)\n\n for await (const buf of stream) {\n buffer = uint8ArrayConcat([buffer, buf], buffer.length + buf.length)\n }\n\n return buffer\n}\n\nmodule.exports = toBuffer\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar errCode = require('err-code');\nvar utils = require('../utils.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar cid = require('multiformats/cid');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction createLs({repo, preload}) {\n async function* ls(ipfsPath, options = {}) {\n const legacyPath = utils.normalizeCidPath(ipfsPath);\n const pathComponents = legacyPath.split('/');\n if (options.preload !== false) {\n preload(cid.CID.parse(pathComponents[0]));\n }\n const ipfsPathOrCid = cid.CID.asCID(legacyPath) || legacyPath;\n const file = await ipfsUnixfsExporter.exporter(ipfsPathOrCid, repo.blocks, options);\n if (file.type === 'file') {\n yield utils.mapFile(file);\n return;\n }\n if (file.type === 'directory') {\n for await (const child of file.content()) {\n yield utils.mapFile(child);\n }\n return;\n }\n throw errCode__default['default'](new Error(`Unknown UnixFS type ${ file.type }`), 'ERR_UNKNOWN_UNIXFS_TYPE');\n }\n return withTimeoutOption.withTimeoutOption(ls);\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar version = require('../version.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createVersion({repo}) {\n async function version$1(_options = {}) {\n const repoVersion = await repo.version.get();\n return {\n version: version.ipfsCore,\n commit: version.commit,\n repo: `${ repoVersion }`,\n 'ipfs-core': version.ipfsCore,\n 'interface-ipfs-core': version.interfaceIpfsCore\n };\n }\n return withTimeoutOption.withTimeoutOption(version$1);\n}\n\nexports.createVersion = createVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst ipfsCore = '0.11.1';\nconst commit = '5ddd0c555cc6577ee15667f4ef4e7f3a3b17d04c';\nconst interfaceIpfsCore = '^0.151.1';\n\nexports.commit = commit;\nexports.interfaceIpfsCore = interfaceIpfsCore;\nexports.ipfsCore = ipfsCore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar version = require('../version.js');\nvar multiaddr = require('multiaddr');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar toString = require('uint8arrays/to-string');\nvar PeerId = require('peer-id');\nvar errors = require('../errors.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\n\nfunction createId({peerId, network}) {\n async function id(options = {}) {\n if (options.peerId === peerId.toB58String()) {\n delete options.peerId;\n }\n const net = network.try();\n if (!net) {\n if (options.peerId) {\n throw new errors.NotStartedError();\n }\n const idStr = peerId.toB58String();\n return {\n id: idStr,\n publicKey: toString.toString(peerId.pubKey.bytes, 'base64pad'),\n addresses: [],\n agentVersion: `js-ipfs/${ version.ipfsCore }`,\n protocolVersion: '9000',\n protocols: []\n };\n }\n const id = options.peerId ? PeerId__default['default'].createFromB58String(options.peerId.toString()) : peerId;\n const {libp2p} = net;\n const publicKey = options.peerId ? libp2p.peerStore.keyBook.get(id) : id.pubKey;\n const addresses = options.peerId ? libp2p.peerStore.addressBook.getMultiaddrsForPeer(id) : libp2p.multiaddrs;\n const protocols = options.peerId ? libp2p.peerStore.protoBook.get(id) : Array.from(libp2p.upgrader.protocols.keys());\n const agentVersion = toString.toString(libp2p.peerStore.metadataBook.getValue(id, 'AgentVersion') || new Uint8Array());\n const protocolVersion = toString.toString(libp2p.peerStore.metadataBook.getValue(id, 'ProtocolVersion') || new Uint8Array());\n const idStr = id.toB58String();\n return {\n id: idStr,\n publicKey: toString.toString(publicKey.bytes, 'base64pad'),\n addresses: (addresses || []).map(ma => {\n const str = ma.toString();\n if (str.endsWith(`/p2p/${ idStr }`)) {\n return str;\n }\n return `${ str }/p2p/${ idStr }`;\n }).sort().map(ma => new multiaddr.Multiaddr(ma)),\n agentVersion,\n protocolVersion,\n protocols: (protocols || []).sort()\n };\n }\n return withTimeoutOption.withTimeoutOption(id);\n}\n\nexports.createId = createId;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar debug = require('debug');\nvar profiles = require('./profiles.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:core:config');\nfunction createConfig({repo}) {\n return {\n getAll: withTimeoutOption.withTimeoutOption(getAll),\n get: withTimeoutOption.withTimeoutOption(get),\n set: withTimeoutOption.withTimeoutOption(set),\n replace: withTimeoutOption.withTimeoutOption(replace),\n profiles: {\n apply: withTimeoutOption.withTimeoutOption(applyProfile),\n list: withTimeoutOption.withTimeoutOption(listProfiles)\n }\n };\n async function getAll(options = {}) {\n return repo.config.getAll(options);\n }\n async function get(key, options) {\n if (!key) {\n return Promise.reject(new Error('key argument is required'));\n }\n return repo.config.get(key, options);\n }\n async function set(key, value, options) {\n return repo.config.set(key, value, options);\n }\n async function replace(value, options) {\n return repo.config.replace(value, options);\n }\n async function applyProfile(profileName, options = { dryRun: false }) {\n const {dryRun} = options;\n const profile = profiles.profiles[profileName];\n if (!profile) {\n throw new Error(`No profile with name '${ profileName }' exists`);\n }\n try {\n const oldCfg = await repo.config.getAll(options);\n let newCfg = JSON.parse(JSON.stringify(oldCfg));\n newCfg = profile.transform(newCfg);\n if (!dryRun) {\n await repo.config.replace(newCfg, options);\n }\n delete oldCfg.Identity.PrivKey;\n delete newCfg.Identity.PrivKey;\n return {\n original: oldCfg,\n updated: newCfg\n };\n } catch (err) {\n log(err);\n throw new Error(`Could not apply profile '${ profileName }' to config: ${ err.message }`);\n }\n }\n}\nasync function listProfiles(_options) {\n return Object.keys(profiles.profiles).map(name => ({\n name,\n description: profiles.profiles[name].description\n }));\n}\n\nexports.createConfig = createConfig;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar set = require('just-safe-set');\nvar getDefaultConfig = require('ipfs-core-config/config');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar set__default = /*#__PURE__*/_interopDefaultLegacy(set);\nvar getDefaultConfig__default = /*#__PURE__*/_interopDefaultLegacy(getDefaultConfig);\n\nconst profiles = {\n server: {\n description: 'Recommended for nodes with public IPv4 address (servers, VPSes, etc.), disables host and content discovery and UPnP in local networks.',\n transform: config => {\n set__default['default'](config, 'Discovery.MDNS.Enabled', false);\n set__default['default'](config, 'Discovery.webRTCStar.Enabled', false);\n config.Swarm = {\n ...config.Swarm || {},\n DisableNatPortMap: true\n };\n return config;\n }\n },\n 'local-discovery': {\n description: 'Sets default values to fields affected by `server` profile, enables discovery and UPnP in local networks.',\n transform: config => {\n set__default['default'](config, 'Discovery.MDNS.Enabled', true);\n set__default['default'](config, 'Discovery.webRTCStar.Enabled', true);\n set__default['default'](config, 'Swarm', {\n ...config.Swarm || {},\n DisableNatPortMap: false\n });\n return config;\n }\n },\n test: {\n description: 'Reduces external interference, useful for running ipfs in test environments. Note that with these settings node won\\'t be able to talk to the rest of the network without manual bootstrap.',\n transform: config => {\n const defaultConfig = getDefaultConfig__default['default']();\n set__default['default'](config, 'Addresses.API', defaultConfig.Addresses.API ? '/ip4/127.0.0.1/tcp/0' : '');\n set__default['default'](config, 'Addresses.Gateway', defaultConfig.Addresses.Gateway ? '/ip4/127.0.0.1/tcp/0' : '');\n set__default['default'](config, 'Addresses.Swarm', defaultConfig.Addresses.Swarm.length ? ['/ip4/127.0.0.1/tcp/0'] : []);\n set__default['default'](config, 'Addresses.Delegates', []);\n set__default['default'](config, 'Bootstrap', []);\n set__default['default'](config, 'Discovery.MDNS.Enabled', false);\n set__default['default'](config, 'Discovery.webRTCStar.Enabled', false);\n set__default['default'](config, 'Swarm', {\n ...config.Swarm || {},\n DisableNatPortMap: true\n });\n return config;\n }\n },\n 'default-networking': {\n description: 'Restores default network settings. Inverse profile of the `test` profile.',\n transform: config => {\n const defaultConfig = getDefaultConfig__default['default']();\n set__default['default'](config, 'Addresses.API', defaultConfig.Addresses.API);\n set__default['default'](config, 'Addresses.Gateway', defaultConfig.Addresses.Gateway);\n set__default['default'](config, 'Addresses.Swarm', defaultConfig.Addresses.Swarm);\n set__default['default'](config, 'Addresses.Delegates', defaultConfig.Addresses.Delegates);\n set__default['default'](config, 'Bootstrap', defaultConfig.Bootstrap);\n set__default['default'](config, 'Discovery.MDNS.Enabled', defaultConfig.Discovery.MDNS.Enabled);\n set__default['default'](config, 'Discovery.webRTCStar.Enabled', defaultConfig.Discovery.webRTCStar.Enabled);\n set__default['default'](config, 'Swarm', {\n ...config.Swarm || {},\n DisableNatPortMap: false\n });\n return config;\n }\n },\n lowpower: {\n description: 'Reduces daemon overhead on the system. May affect node functionality,performance of content discovery and data fetching may be degraded. Recommended for low power systems.',\n transform: config => {\n const Swarm = config.Swarm || {};\n const ConnMgr = Swarm.ConnMgr || {};\n ConnMgr.LowWater = 20;\n ConnMgr.HighWater = 40;\n Swarm.ConnMgr = ConnMgr;\n config.Swarm = Swarm;\n return config;\n }\n },\n 'default-power': {\n description: 'Inverse of \"lowpower\" profile.',\n transform: config => {\n const defaultConfig = getDefaultConfig__default['default']();\n config.Swarm = defaultConfig.Swarm;\n return config;\n }\n }\n};\n\nexports.profiles = profiles;\n","module.exports = set;\n\n/*\n var obj1 = {};\n set(obj1, 'a.aa.aaa', 4); // true\n obj1; // {a: {aa: {aaa: 4}}}\n\n var obj2 = {};\n set(obj2, ['a', 'aa', 'aaa'], 4); // true\n obj2; // {a: {aa: {aaa: 4}}}\n\n var obj3 = {a: {aa: {aaa: 2}}};\n set(obj3, 'a.aa.aaa', 3); // true\n obj3; // {a: {aa: {aaa: 3}}}\n\n // don't clobber existing\n var obj4 = {a: {aa: {aaa: 2}}};\n set(obj4, 'a.aa', {bbb: 7}); // false\n\n const obj5 = {a: {}};\n const sym = Symbol();\n set(obj5.a, sym, 7); // true\n obj5; // {a: {Symbol(): 7}}\n*/\n\nfunction set(obj, propsArg, value) {\n var props, lastProp;\n if (Array.isArray(propsArg)) {\n props = propsArg.slice(0);\n }\n if (typeof propsArg == 'string') {\n props = propsArg.split('.');\n }\n if (typeof propsArg == 'symbol') {\n props = [propsArg];\n }\n if (!Array.isArray(props)) {\n throw new Error('props arg must be an array, a string or a symbol');\n }\n lastProp = props.pop();\n if (!lastProp) {\n return false;\n }\n prototypeCheck(lastProp);\n var thisProp;\n while ((thisProp = props.shift())) {\n prototypeCheck(thisProp);\n if (typeof obj[thisProp] == 'undefined') {\n obj[thisProp] = {};\n }\n obj = obj[thisProp];\n if (!obj || typeof obj != 'object') {\n return false;\n }\n }\n obj[lastProp] = value;\n return true;\n}\n\nfunction prototypeCheck(prop) {\n if (prop === '__proto__' || prop === 'constructor' || prop === 'prototype') {\n throw new Error('setting of prototype values not supported');\n }\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _export = require('./export.js');\nvar get = require('./get.js');\nvar _import = require('./import.js');\nvar put = require('./put.js');\nvar resolve = require('./resolve.js');\n\nclass DagAPI {\n constructor({repo, codecs, hashers, preload}) {\n this.export = _export.createExport({\n repo,\n preload,\n codecs\n });\n this.get = get.createGet({\n codecs,\n repo,\n preload\n });\n this.import = _import.createImport({ repo });\n this.resolve = resolve.createResolve({\n repo,\n codecs,\n preload\n });\n this.put = put.createPut({\n repo,\n codecs,\n hashers,\n preload\n });\n }\n}\n\nexports.DagAPI = DagAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar block = require('multiformats/block');\nvar base58 = require('multiformats/bases/base58');\nvar writer = require('@ipld/car/writer');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar debug = require('debug');\nvar raw = require('multiformats/codecs/raw');\nvar json = require('multiformats/codecs/json');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar json__namespace = /*#__PURE__*/_interopNamespace(json);\n\nconst log = debug__default['default']('ipfs:components:dag:import');\nconst NO_LINKS_CODECS = [\n raw__namespace.code,\n json__namespace.code\n];\nfunction createExport({repo, preload, codecs}) {\n async function* dagExport(root, options = {}) {\n if (options.preload !== false) {\n preload(root);\n }\n const cid$1 = cid.CID.asCID(root);\n if (!cid$1) {\n throw new Error(`Unexpected error converting CID type: ${ root }`);\n }\n log(`Exporting ${ cid$1 } as car`);\n const {writer: writer$1, out} = await writer.CarWriter.create([cid$1]);\n let err = null;\n (async () => {\n try {\n await traverseWrite(repo, {\n signal: options.signal,\n timeout: options.timeout\n }, cid$1, writer$1, codecs);\n writer$1.close();\n } catch (e) {\n err = e;\n }\n })();\n for await (const chunk of out) {\n if (err) {\n break;\n }\n yield chunk;\n }\n if (err) {\n throw err;\n }\n }\n return withTimeoutOption.withTimeoutOption(dagExport);\n}\nasync function traverseWrite(repo, options, cid, writer, codecs, seen = new Set()) {\n const b58Cid = cid.toString(base58.base58btc);\n if (seen.has(b58Cid)) {\n return;\n }\n const block = await getBlock(repo, options, cid, codecs);\n log(`Adding block ${ cid } to car`);\n await writer.put(block);\n seen.add(b58Cid);\n for (const link of block.links) {\n await traverseWrite(repo, options, link, writer, codecs, seen);\n }\n}\nasync function getBlock(repo, options, cid, codecs) {\n const bytes = await repo.blocks.get(cid, options);\n let links = [];\n const codec = await codecs.getCodec(cid.code);\n if (codec) {\n const block$1 = block.createUnsafe({\n bytes,\n cid,\n codec\n });\n links = [...block$1.links()].map(l => l[1]);\n } else if (!NO_LINKS_CODECS.includes(cid.code)) {\n throw new Error(`Can't decode links in block with codec 0x${ cid.code.toString(16) } to form complete DAG`);\n }\n return {\n cid,\n bytes,\n links\n };\n}\n\nexports.createExport = createExport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nrequire('./index.js');\nvar cid = require('./cid.js');\nvar bytes = require('./bytes.js');\n\nconst readonly = ({enumerable = true, configurable = false} = {}) => ({\n enumerable,\n configurable,\n writable: false\n});\nconst links = function* (source, base) {\n if (source == null)\n return;\n if (source instanceof Uint8Array)\n return;\n for (const [key, value] of Object.entries(source)) {\n const path = [\n ...base,\n key\n ];\n if (value != null && typeof value === 'object') {\n if (Array.isArray(value)) {\n for (const [index, element] of value.entries()) {\n const elementPath = [\n ...path,\n index\n ];\n const cid$1 = cid.CID.asCID(element);\n if (cid$1) {\n yield [\n elementPath.join('/'),\n cid$1\n ];\n } else if (typeof element === 'object') {\n yield* links(element, elementPath);\n }\n }\n } else {\n const cid$1 = cid.CID.asCID(value);\n if (cid$1) {\n yield [\n path.join('/'),\n cid$1\n ];\n } else {\n yield* links(value, path);\n }\n }\n }\n }\n};\nconst tree = function* (source, base) {\n if (source == null)\n return;\n for (const [key, value] of Object.entries(source)) {\n const path = [\n ...base,\n key\n ];\n yield path.join('/');\n if (value != null && !(value instanceof Uint8Array) && typeof value === 'object' && !cid.CID.asCID(value)) {\n if (Array.isArray(value)) {\n for (const [index, element] of value.entries()) {\n const elementPath = [\n ...path,\n index\n ];\n yield elementPath.join('/');\n if (typeof element === 'object' && !cid.CID.asCID(element)) {\n yield* tree(element, elementPath);\n }\n }\n } else {\n yield* tree(value, path);\n }\n }\n }\n};\nconst get = (source, path) => {\n let node = source;\n for (const [index, key] of path.entries()) {\n node = node[key];\n if (node == null) {\n throw new Error(`Object has no property at ${ path.slice(0, index + 1).map(part => `[${ JSON.stringify(part) }]`).join('') }`);\n }\n const cid$1 = cid.CID.asCID(node);\n if (cid$1) {\n return {\n value: cid$1,\n remaining: path.slice(index + 1).join('/')\n };\n }\n }\n return { value: node };\n};\nclass Block {\n constructor({cid, bytes, value}) {\n if (!cid || !bytes || typeof value === 'undefined')\n throw new Error('Missing required argument');\n this.cid = cid;\n this.bytes = bytes;\n this.value = value;\n this.asBlock = this;\n Object.defineProperties(this, {\n cid: readonly(),\n bytes: readonly(),\n value: readonly(),\n asBlock: readonly()\n });\n }\n links() {\n return links(this.value, []);\n }\n tree() {\n return tree(this.value, []);\n }\n get(path = '/') {\n return get(this.value, path.split('/').filter(Boolean));\n }\n}\nconst encode = async ({value, codec, hasher}) => {\n if (typeof value === 'undefined')\n throw new Error('Missing required argument \"value\"');\n if (!codec || !hasher)\n throw new Error('Missing required argument: codec or hasher');\n const bytes = codec.encode(value);\n const hash = await hasher.digest(bytes);\n const cid$1 = cid.CID.create(1, codec.code, hash);\n return new Block({\n value,\n bytes,\n cid: cid$1\n });\n};\nconst decode = async ({bytes, codec, hasher}) => {\n if (!bytes)\n throw new Error('Missing required argument \"bytes\"');\n if (!codec || !hasher)\n throw new Error('Missing required argument: codec or hasher');\n const value = codec.decode(bytes);\n const hash = await hasher.digest(bytes);\n const cid$1 = cid.CID.create(1, codec.code, hash);\n return new Block({\n value,\n bytes,\n cid: cid$1\n });\n};\nconst createUnsafe = ({\n bytes,\n cid,\n value: maybeValue,\n codec\n}) => {\n const value = maybeValue !== undefined ? maybeValue : codec && codec.decode(bytes);\n if (value === undefined)\n throw new Error('Missing required argument, must either provide \"value\" or \"codec\"');\n return new Block({\n cid,\n bytes,\n value\n });\n};\nconst create = async ({bytes: bytes$1, cid, hasher, codec}) => {\n if (!bytes$1)\n throw new Error('Missing required argument \"bytes\"');\n if (!hasher)\n throw new Error('Missing required argument \"hasher\"');\n const value = codec.decode(bytes$1);\n const hash = await hasher.digest(bytes$1);\n if (!bytes.equals(cid.multihash.bytes, hash.bytes)) {\n throw new Error('CID hash does not match bytes');\n }\n return createUnsafe({\n bytes: bytes$1,\n cid,\n value,\n codec\n });\n};\n\nexports.Block = Block;\nexports.create = create;\nexports.createUnsafe = createUnsafe;\nexports.decode = decode;\nexports.encode = encode;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar encoder = require('./encoder.js');\nvar iteratorChannel = require('./iterator-channel.js');\nvar decoder = require('./decoder.js');\n\nclass CarWriter {\n constructor(roots, encoder) {\n this._encoder = encoder;\n this._mutex = encoder.setRoots(roots);\n this._ended = false;\n }\n async put(block) {\n if (!(block.bytes instanceof Uint8Array) || !block.cid) {\n throw new TypeError('Can only write {cid, bytes} objects');\n }\n if (this._ended) {\n throw new Error('Already closed');\n }\n const cid$1 = cid.CID.asCID(block.cid);\n if (!cid$1) {\n throw new TypeError('Can only write {cid, bytes} objects');\n }\n this._mutex = this._mutex.then(() => this._encoder.writeBlock({\n cid: cid$1,\n bytes: block.bytes\n }));\n return this._mutex;\n }\n async close() {\n if (this._ended) {\n throw new Error('Already closed');\n }\n await this._mutex;\n this._ended = true;\n return this._encoder.close();\n }\n static create(roots) {\n roots = toRoots(roots);\n const {encoder, iterator} = encodeWriter();\n const writer = new CarWriter(roots, encoder);\n const out = new CarWriterOut(iterator);\n return {\n writer,\n out\n };\n }\n static createAppender() {\n const {encoder, iterator} = encodeWriter();\n encoder.setRoots = () => Promise.resolve();\n const writer = new CarWriter([], encoder);\n const out = new CarWriterOut(iterator);\n return {\n writer,\n out\n };\n }\n static async updateRootsInBytes(bytes, roots) {\n const reader = decoder.bytesReader(bytes);\n await decoder.readHeader(reader);\n const newHeader = encoder.createHeader(roots);\n if (reader.pos !== newHeader.length) {\n throw new Error(`updateRoots() can only overwrite a header of the same length (old header is ${ reader.pos } bytes, new header is ${ newHeader.length } bytes)`);\n }\n bytes.set(newHeader, 0);\n return bytes;\n }\n}\nclass CarWriterOut {\n constructor(iterator) {\n this._iterator = iterator;\n }\n [Symbol.asyncIterator]() {\n if (this._iterating) {\n throw new Error('Multiple iterator not supported');\n }\n this._iterating = true;\n return this._iterator;\n }\n}\nfunction encodeWriter() {\n const iw = iteratorChannel.create();\n const {writer, iterator} = iw;\n const encoder$1 = encoder.createEncoder(writer);\n return {\n encoder: encoder$1,\n iterator\n };\n}\nfunction toRoots(roots) {\n if (roots === undefined) {\n return [];\n }\n if (!Array.isArray(roots)) {\n const cid$1 = cid.CID.asCID(roots);\n if (!cid$1) {\n throw new TypeError('roots must be a single CID or an array of CIDs');\n }\n return [cid$1];\n }\n const _roots = [];\n for (const root of roots) {\n const _root = cid.CID.asCID(root);\n if (!_root) {\n throw new TypeError('roots must be a single CID or an array of CIDs');\n }\n _roots.push(_root);\n }\n return _roots;\n}\nconst __browser = true;\n\nexports.CarWriter = CarWriter;\nexports.CarWriterOut = CarWriterOut;\nexports.__browser = __browser;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar varint = require('varint');\nvar dagCbor = require('@ipld/dag-cbor');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar varint__default = /*#__PURE__*/_interopDefaultLegacy(varint);\n\nfunction createHeader(roots) {\n const headerBytes = dagCbor.encode({\n version: 1,\n roots\n });\n const varintBytes = varint__default[\"default\"].encode(headerBytes.length);\n const header = new Uint8Array(varintBytes.length + headerBytes.length);\n header.set(varintBytes, 0);\n header.set(headerBytes, varintBytes.length);\n return header;\n}\nfunction createEncoder(writer) {\n return {\n async setRoots(roots) {\n const bytes = createHeader(roots);\n await writer.write(bytes);\n },\n async writeBlock(block) {\n const {cid, bytes} = block;\n await writer.write(new Uint8Array(varint__default[\"default\"].encode(cid.bytes.length + bytes.length)));\n await writer.write(cid.bytes);\n if (bytes.length) {\n await writer.write(bytes);\n }\n },\n async close() {\n return writer.end();\n }\n };\n}\n\nexports.createEncoder = createEncoder;\nexports.createHeader = createHeader;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction noop() {\n}\nfunction create() {\n const chunkQueue = [];\n let drainer = null;\n let drainerResolver = noop;\n let ended = false;\n let outWait = null;\n let outWaitResolver = noop;\n const makeDrainer = () => {\n if (!drainer) {\n drainer = new Promise(resolve => {\n drainerResolver = () => {\n drainer = null;\n drainerResolver = noop;\n resolve();\n };\n });\n }\n return drainer;\n };\n const writer = {\n write(chunk) {\n chunkQueue.push(chunk);\n const drainer = makeDrainer();\n outWaitResolver();\n return drainer;\n },\n async end() {\n ended = true;\n const drainer = makeDrainer();\n outWaitResolver();\n return drainer;\n }\n };\n const iterator = {\n async next() {\n const chunk = chunkQueue.shift();\n if (chunk) {\n if (chunkQueue.length === 0) {\n drainerResolver();\n }\n return {\n done: false,\n value: chunk\n };\n }\n if (ended) {\n drainerResolver();\n return {\n done: true,\n value: undefined\n };\n }\n if (!outWait) {\n outWait = new Promise(resolve => {\n outWaitResolver = () => {\n outWait = null;\n outWaitResolver = noop;\n return resolve(iterator.next());\n };\n });\n }\n return outWait;\n }\n };\n return {\n writer,\n iterator\n };\n}\n\nexports.create = create;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar varint = require('varint');\nvar cid = require('multiformats/cid');\nvar Digest = require('multiformats/hashes/digest');\nvar dagCbor = require('@ipld/dag-cbor');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar varint__default = /*#__PURE__*/_interopDefaultLegacy(varint);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\n\nconst CIDV0_BYTES = {\n SHA2_256: 18,\n LENGTH: 32,\n DAG_PB: 112\n};\nasync function readVarint(reader) {\n const bytes = await reader.upTo(8);\n const i = varint__default[\"default\"].decode(bytes);\n reader.seek(varint__default[\"default\"].decode.bytes);\n return i;\n}\nasync function readHeader(reader) {\n const length = await readVarint(reader);\n if (length === 0) {\n throw new Error('Invalid CAR header (zero length)');\n }\n const header = await reader.exactly(length);\n reader.seek(length);\n const block = dagCbor.decode(header);\n if (block == null || Array.isArray(block) || typeof block !== 'object') {\n throw new Error('Invalid CAR header format');\n }\n if (block.version !== 1) {\n if (typeof block.version === 'string') {\n throw new Error(`Invalid CAR version: \"${ block.version }\"`);\n }\n throw new Error(`Invalid CAR version: ${ block.version }`);\n }\n if (!Array.isArray(block.roots)) {\n throw new Error('Invalid CAR header format');\n }\n if (Object.keys(block).filter(p => p !== 'roots' && p !== 'version').length) {\n throw new Error('Invalid CAR header format');\n }\n return block;\n}\nasync function readMultihash(reader) {\n const bytes = await reader.upTo(8);\n varint__default[\"default\"].decode(bytes);\n const codeLength = varint__default[\"default\"].decode.bytes;\n const length = varint__default[\"default\"].decode(bytes.subarray(varint__default[\"default\"].decode.bytes));\n const lengthLength = varint__default[\"default\"].decode.bytes;\n const mhLength = codeLength + lengthLength + length;\n const multihash = await reader.exactly(mhLength);\n reader.seek(mhLength);\n return multihash;\n}\nasync function readCid(reader) {\n const first = await reader.exactly(2);\n if (first[0] === CIDV0_BYTES.SHA2_256 && first[1] === CIDV0_BYTES.LENGTH) {\n const bytes = await reader.exactly(34);\n reader.seek(34);\n const multihash = Digest__namespace.decode(bytes);\n return cid.CID.create(0, CIDV0_BYTES.DAG_PB, multihash);\n }\n const version = await readVarint(reader);\n if (version !== 1) {\n throw new Error(`Unexpected CID version (${ version })`);\n }\n const codec = await readVarint(reader);\n const bytes = await readMultihash(reader);\n const multihash = Digest__namespace.decode(bytes);\n return cid.CID.create(version, codec, multihash);\n}\nasync function readBlockHead(reader) {\n const start = reader.pos;\n let length = await readVarint(reader);\n if (length === 0) {\n throw new Error('Invalid CAR section (zero length)');\n }\n length += reader.pos - start;\n const cid = await readCid(reader);\n const blockLength = length - (reader.pos - start);\n return {\n cid,\n length,\n blockLength\n };\n}\nasync function readBlock(reader) {\n const {cid, blockLength} = await readBlockHead(reader);\n const bytes = await reader.exactly(blockLength);\n reader.seek(blockLength);\n return {\n bytes,\n cid\n };\n}\nasync function readBlockIndex(reader) {\n const offset = reader.pos;\n const {cid, length, blockLength} = await readBlockHead(reader);\n const index = {\n cid,\n length,\n blockLength,\n offset,\n blockOffset: reader.pos\n };\n reader.seek(index.blockLength);\n return index;\n}\nfunction createDecoder(reader) {\n const headerPromise = readHeader(reader);\n return {\n header: () => headerPromise,\n async *blocks() {\n await headerPromise;\n while ((await reader.upTo(8)).length > 0) {\n yield await readBlock(reader);\n }\n },\n async *blocksIndex() {\n await headerPromise;\n while ((await reader.upTo(8)).length > 0) {\n yield await readBlockIndex(reader);\n }\n }\n };\n}\nfunction bytesReader(bytes) {\n let pos = 0;\n return {\n async upTo(length) {\n return bytes.subarray(pos, pos + Math.min(length, bytes.length - pos));\n },\n async exactly(length) {\n if (length > bytes.length - pos) {\n throw new Error('Unexpected end of data');\n }\n return bytes.subarray(pos, pos + length);\n },\n seek(length) {\n pos += length;\n },\n get pos() {\n return pos;\n }\n };\n}\nfunction chunkReader(readChunk) {\n let pos = 0;\n let have = 0;\n let offset = 0;\n let currentChunk = new Uint8Array(0);\n const read = async length => {\n have = currentChunk.length - offset;\n const bufa = [currentChunk.subarray(offset)];\n while (have < length) {\n const chunk = await readChunk();\n if (chunk == null) {\n break;\n }\n if (have < 0) {\n if (chunk.length > have) {\n bufa.push(chunk.subarray(-have));\n }\n } else {\n bufa.push(chunk);\n }\n have += chunk.length;\n }\n currentChunk = new Uint8Array(bufa.reduce((p, c) => p + c.length, 0));\n let off = 0;\n for (const b of bufa) {\n currentChunk.set(b, off);\n off += b.length;\n }\n offset = 0;\n };\n return {\n async upTo(length) {\n if (currentChunk.length - offset < length) {\n await read(length);\n }\n return currentChunk.subarray(offset, offset + Math.min(currentChunk.length - offset, length));\n },\n async exactly(length) {\n if (currentChunk.length - offset < length) {\n await read(length);\n }\n if (currentChunk.length - offset < length) {\n throw new Error('Unexpected end of data');\n }\n return currentChunk.subarray(offset, offset + length);\n },\n seek(length) {\n pos += length;\n offset += length;\n },\n get pos() {\n return pos;\n }\n };\n}\nfunction asyncIterableReader(asyncIterable) {\n const iterator = asyncIterable[Symbol.asyncIterator]();\n async function readChunk() {\n const next = await iterator.next();\n if (next.done) {\n return null;\n }\n return next.value;\n }\n return chunkReader(readChunk);\n}\n\nexports.asyncIterableReader = asyncIterableReader;\nexports.bytesReader = bytesReader;\nexports.chunkReader = chunkReader;\nexports.createDecoder = createDecoder;\nexports.readHeader = readHeader;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar first = require('it-first');\nvar last = require('it-last');\nvar utils = require('../../utils.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar first__default = /*#__PURE__*/_interopDefaultLegacy(first);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction createGet({codecs, repo, preload}) {\n const get = async function get(cid, options = {}) {\n if (options.preload !== false) {\n preload(cid);\n }\n if (options.path) {\n const entry = options.localResolve ? await first__default['default'](utils.resolve(cid, options.path, codecs, repo, options)) : await last__default['default'](utils.resolve(cid, options.path, codecs, repo, options));\n const result = entry;\n if (!result) {\n throw errCode__default['default'](new Error('Not found'), 'ERR_NOT_FOUND');\n }\n return result;\n }\n const codec = await codecs.getCodec(cid.code);\n const block = await repo.blocks.get(cid, options);\n const node = codec.decode(block);\n return {\n value: node,\n remainderPath: ''\n };\n };\n return withTimeoutOption.withTimeoutOption(get);\n}\n\nexports.createGet = createGet;\n","'use strict'\n\n/**\n * Returns the first result from an (async) iterable, unless empty, in which\n * case returns `undefined`.\n *\n * @template T\n * @param {AsyncIterable<T>|Iterable<T>} source\n */\nconst first = async (source) => {\n for await (const entry of source) { // eslint-disable-line no-unreachable-loop\n return entry\n }\n\n return undefined\n}\n\nmodule.exports = first\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar iterator = require('@ipld/car/iterator');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar itPeekable = require('it-peekable');\nvar drain = require('it-drain');\nvar map = require('it-map');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar itPeekable__default = /*#__PURE__*/_interopDefaultLegacy(itPeekable);\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:components:dag:import');\nfunction createImport({repo}) {\n async function* dagImport(sources, options = {}) {\n const release = await repo.gcLock.readLock();\n try {\n const abortOptions = {\n signal: options.signal,\n timeout: options.timeout\n };\n const peekable = itPeekable__default['default'](sources);\n const {value, done} = await peekable.peek();\n if (done) {\n return;\n }\n if (value) {\n peekable.push(value);\n }\n let cars;\n if (value instanceof Uint8Array) {\n cars = [peekable];\n } else {\n cars = peekable;\n }\n for await (const car of cars) {\n const roots = await importCar(repo, abortOptions, car);\n if (options.pinRoots !== false) {\n for (const cid of roots) {\n let pinErrorMsg = '';\n try {\n if (await repo.blocks.has(cid)) {\n log(`Pinning root ${ cid }`);\n await repo.pins.pinRecursively(cid);\n } else {\n pinErrorMsg = 'blockstore: block not found';\n }\n } catch (err) {\n pinErrorMsg = err.message;\n }\n yield {\n root: {\n cid,\n pinErrorMsg\n }\n };\n }\n }\n }\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(dagImport);\n}\nasync function importCar(repo, options, source) {\n const reader = await iterator.CarBlockIterator.fromIterable(source);\n const roots = await reader.getRoots();\n await drain__default['default'](repo.blocks.putMany(map__default['default'](reader, ({\n cid: key,\n bytes: value\n }) => {\n log(`Import block ${ key }`);\n return {\n key,\n value\n };\n }), { signal: options.signal }));\n return roots;\n}\n\nexports.createImport = createImport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar decoder = require('./decoder.js');\n\nclass CarIteratorBase {\n constructor(version, roots, iterable) {\n this._version = version;\n this._roots = roots;\n this._iterable = iterable;\n this._decoded = false;\n }\n get version() {\n return this._version;\n }\n async getRoots() {\n return this._roots;\n }\n}\nclass CarBlockIterator extends CarIteratorBase {\n [Symbol.asyncIterator]() {\n if (this._decoded) {\n throw new Error('Cannot decode more than once');\n }\n if (!this._iterable) {\n throw new Error('Block iterable not found');\n }\n this._decoded = true;\n return this._iterable[Symbol.asyncIterator]();\n }\n static async fromBytes(bytes) {\n const {version, roots, iterator} = await fromBytes(bytes);\n return new CarBlockIterator(version, roots, iterator);\n }\n static async fromIterable(asyncIterable) {\n const {version, roots, iterator} = await fromIterable(asyncIterable);\n return new CarBlockIterator(version, roots, iterator);\n }\n}\nclass CarCIDIterator extends CarIteratorBase {\n [Symbol.asyncIterator]() {\n if (this._decoded) {\n throw new Error('Cannot decode more than once');\n }\n if (!this._iterable) {\n throw new Error('Block iterable not found');\n }\n this._decoded = true;\n const iterable = this._iterable[Symbol.asyncIterator]();\n return {\n async next() {\n const next = await iterable.next();\n if (next.done) {\n return next;\n }\n return {\n done: false,\n value: next.value.cid\n };\n }\n };\n }\n static async fromBytes(bytes) {\n const {version, roots, iterator} = await fromBytes(bytes);\n return new CarCIDIterator(version, roots, iterator);\n }\n static async fromIterable(asyncIterable) {\n const {version, roots, iterator} = await fromIterable(asyncIterable);\n return new CarCIDIterator(version, roots, iterator);\n }\n}\nasync function fromBytes(bytes) {\n if (!(bytes instanceof Uint8Array)) {\n throw new TypeError('fromBytes() requires a Uint8Array');\n }\n return decodeIterator(decoder.bytesReader(bytes));\n}\nasync function fromIterable(asyncIterable) {\n if (!asyncIterable || !(typeof asyncIterable[Symbol.asyncIterator] === 'function')) {\n throw new TypeError('fromIterable() requires an async iterable');\n }\n return decodeIterator(decoder.asyncIterableReader(asyncIterable));\n}\nasync function decodeIterator(reader) {\n const decoder$1 = decoder.createDecoder(reader);\n const {version, roots} = await decoder$1.header();\n return {\n version,\n roots,\n iterator: decoder$1.blocks()\n };\n}\n\nexports.CarBlockIterator = CarBlockIterator;\nexports.CarCIDIterator = CarCIDIterator;\nexports.CarIteratorBase = CarIteratorBase;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createPut({repo, codecs, hashers, preload}) {\n async function put(dagNode, options = {}) {\n const release = options.pin ? await repo.gcLock.readLock() : null;\n try {\n const codecName = options.format || 'dag-cbor';\n const cidVersion = options.version != null ? options.version : codecName === 'dag-pb' ? 0 : 1;\n const codec = await codecs.getCodec(codecName);\n if (!codec) {\n throw new Error(`Unknown codec ${ options.format }, please configure additional BlockCodecs for this IPFS instance`);\n }\n const hasher = await hashers.getHasher(options.hashAlg || 'sha2-256');\n if (!hasher) {\n throw new Error(`Unknown hash algorithm ${ options.hashAlg }, please configure additional MultihashHashers for this IPFS instance`);\n }\n const buf = codec.encode(dagNode);\n const hash = await hasher.digest(buf);\n const cid$1 = cid.CID.create(cidVersion, codec.code, hash);\n await repo.blocks.put(cid$1, buf, { signal: options.signal });\n if (options.pin) {\n await repo.pins.pinRecursively(cid$1);\n }\n if (options.preload !== false) {\n preload(cid$1);\n }\n return cid$1;\n } finally {\n if (release) {\n release();\n }\n }\n }\n return withTimeoutOption.withTimeoutOption(put);\n}\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar toCidAndPath = require('ipfs-core-utils/to-cid-and-path');\nvar utils = require('../../utils.js');\n\nfunction createResolve({repo, codecs, preload}) {\n async function dagResolve(ipfsPath, options = {}) {\n const {cid} = toCidAndPath.toCidAndPath(ipfsPath);\n if (options.preload !== false) {\n preload(cid);\n }\n return utils.resolvePath(repo, codecs, ipfsPath, options);\n }\n return withTimeoutOption.withTimeoutOption(dagResolve);\n}\n\nexports.createResolve = createResolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar toUri = require('multiaddr-to-uri');\nvar debug = require('debug');\nvar shuffle = require('array-shuffle');\nvar nativeAbortController = require('native-abort-controller');\nvar preload = require('ipfs-core-config/preload');\nvar hashlru = require('hashlru');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar toUri__default = /*#__PURE__*/_interopDefaultLegacy(toUri);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar shuffle__default = /*#__PURE__*/_interopDefaultLegacy(shuffle);\nvar hashlru__default = /*#__PURE__*/_interopDefaultLegacy(hashlru);\n\nconst log = Object.assign(debug__default['default']('ipfs:preload'), { error: debug__default['default']('ipfs:preload:error') });\nfunction createPreloader(options = {}) {\n options.enabled = Boolean(options.enabled);\n options.addresses = options.addresses || [];\n options.cache = options.cache || 1000;\n if (!options.enabled || !options.addresses.length) {\n log('preload disabled');\n const api = () => {\n };\n return Object.assign(api, {\n start: () => {\n },\n stop: () => {\n }\n });\n }\n let stopped = true;\n let requests = [];\n const apiUris = options.addresses.map(toUri__default['default']);\n const cache = hashlru__default['default'](options.cache);\n const api = async cid => {\n try {\n if (stopped) {\n throw new Error(`preload ${ cid } but preloader is not started`);\n }\n const path = cid.toString();\n if (cache.has(path)) {\n return;\n }\n cache.set(path, true);\n const fallbackApiUris = shuffle__default['default'](apiUris);\n let success = false;\n const now = Date.now();\n for (const uri of fallbackApiUris) {\n if (stopped)\n throw new Error(`preload aborted for ${ path }`);\n let controller;\n try {\n controller = new nativeAbortController.AbortController();\n requests = requests.concat(controller);\n await preload.preload(`${ uri }/api/v0/refs?r=true&arg=${ encodeURIComponent(path) }`, { signal: controller.signal });\n success = true;\n } catch (err) {\n if (err.type !== 'aborted')\n log.error(err);\n } finally {\n requests = requests.filter(r => r !== controller);\n }\n if (success)\n break;\n }\n log(`${ success ? '' : 'un' }successfully preloaded ${ path } in ${ Date.now() - now }ms`);\n } catch (err) {\n log.error(err);\n }\n };\n api.start = () => {\n stopped = false;\n };\n api.stop = () => {\n stopped = true;\n log(`aborting ${ requests.length } pending preload request(s)`);\n requests.forEach(r => r.abort());\n requests = [];\n };\n return api;\n}\n\nexports.createPreloader = createPreloader;\n","const { Multiaddr } = require('multiaddr')\n\nconst reduceValue = (_, v) => v\nconst tcpUri = (str, port, parts, opts) => {\n // return tcp when explicitly requested\n if (opts && opts.assumeHttp === false) return `tcp://${str}:${port}`\n // check if tcp is the last protocol in multiaddr\n let protocol = 'tcp'\n let explicitPort = `:${port}`\n const last = parts[parts.length - 1]\n if (last.protocol === 'tcp') {\n // assume http and produce clean urls\n protocol = port === '443' ? 'https' : 'http'\n explicitPort = port === '443' || port === '80' ? '' : explicitPort\n }\n return `${protocol}://${str}${explicitPort}`\n}\n\nconst Reducers = {\n ip4: reduceValue,\n ip6: (str, content, i, parts) => (\n parts.length === 1 && parts[0].protocol === 'ip6'\n ? content\n : `[${content}]`\n ),\n tcp: (str, content, i, parts, opts) => (\n parts.some(p => ['http', 'https', 'ws', 'wss'].includes(p.protocol))\n ? `${str}:${content}`\n : tcpUri(str, content, parts, opts)\n ),\n udp: (str, content) => `udp://${str}:${content}`,\n dnsaddr: reduceValue,\n dns4: reduceValue,\n dns6: reduceValue,\n ipfs: (str, content) => `${str}/ipfs/${content}`,\n p2p: (str, content) => `${str}/p2p/${content}`,\n http: str => `http://${str}`,\n https: str => `https://${str}`,\n ws: str => `ws://${str}`,\n wss: str => `wss://${str}`,\n 'p2p-websocket-star': str => `${str}/p2p-websocket-star`,\n 'p2p-webrtc-star': str => `${str}/p2p-webrtc-star`,\n 'p2p-webrtc-direct': str => `${str}/p2p-webrtc-direct`\n}\n\nmodule.exports = (multiaddr, opts) => {\n const ma = new Multiaddr(multiaddr)\n const parts = multiaddr.toString().split('/').slice(1)\n return ma\n .tuples()\n .map(tuple => ({\n protocol: parts.shift(),\n content: tuple[1] ? parts.shift() : null\n }))\n .reduce((str, part, i, parts) => {\n const reduce = Reducers[part.protocol]\n if (!reduce) throw new Error(`Unsupported protocol ${part.protocol}`)\n return reduce(str, part.content, i, parts, opts)\n }, '')\n}\n","'use strict';\n\nmodule.exports = array => {\n\tif (!Array.isArray(array)) {\n\t\tthrow new TypeError(`Expected an array, got ${typeof array}`);\n\t}\n\n\tarray = [...array];\n\n\tfor (let index = array.length - 1; index > 0; index--) {\n\t\tconst newIndex = Math.floor(Math.random() * (index + 1));\n\t\t[array[index], array[newIndex]] = [array[newIndex], array[index]];\n\t}\n\n\treturn array;\n};\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar HTTP = require('ipfs-utils/src/http.js');\nvar debug = require('debug');\nvar PQueue = require('p-queue');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar HTTP__default = /*#__PURE__*/_interopDefaultLegacy(HTTP);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar PQueue__default = /*#__PURE__*/_interopDefaultLegacy(PQueue);\n\nconst log = Object.assign(debug__default[\"default\"]('ipfs:preload'), { error: debug__default[\"default\"]('ipfs:preload:error') });\nconst Queue = PQueue__default[\"default\"].default ? PQueue__default[\"default\"].default : PQueue__default[\"default\"];\nconst httpQueue = new Queue({ concurrency: 4 });\nfunction preload(url, options = {}) {\n log(url);\n return httpQueue.add(async () => {\n const res = await HTTP__default[\"default\"].post(url, { signal: options.signal });\n const reader = res.body.getReader();\n try {\n while (true) {\n const {done} = await reader.read();\n if (done)\n return;\n }\n } finally {\n reader.releaseLock();\n }\n });\n}\n\nexports.preload = preload;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = Object.assign(debug__default['default']('ipfs:mfs-preload'), { error: debug__default['default']('ipfs:mfs-preload:error') });\nfunction createMfsPreloader({preload, files, options = {}}) {\n options.interval = options.interval || 30 * 1000;\n if (!options.enabled) {\n log('MFS preload disabled');\n const noop = async () => {\n };\n return {\n start: noop,\n stop: noop\n };\n }\n let rootCid = '';\n let timeoutId;\n const preloadMfs = async () => {\n try {\n const stats = await files.stat('/');\n const nextRootCid = stats.cid.toString();\n if (rootCid !== nextRootCid) {\n log(`preloading updated MFS root ${ rootCid } -> ${ stats.cid }`);\n await preload(stats.cid);\n rootCid = nextRootCid;\n }\n } catch (err) {\n log.error('failed to preload MFS root', err);\n } finally {\n timeoutId = setTimeout(preloadMfs, options.interval);\n }\n };\n return {\n async start() {\n const stats = await files.stat('/');\n rootCid = stats.cid.toString();\n log(`monitoring MFS root ${ stats.cid }`);\n timeoutId = setTimeout(preloadMfs, options.interval);\n },\n stop() {\n clearTimeout(timeoutId);\n }\n };\n}\n\nexports.createMfsPreloader = createMfsPreloader;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar createLock = require('./utils/create-lock.js');\nvar isIpfs = require('is-ipfs');\nvar stat = require('./stat.js');\nvar chmod = require('./chmod.js');\nvar cp = require('./cp.js');\nvar flush = require('./flush.js');\nvar mkdir = require('./mkdir.js');\nvar mv = require('./mv.js');\nvar rm = require('./rm.js');\nvar touch = require('./touch.js');\nvar read = require('./read.js');\nvar write = require('./write.js');\nvar ls = require('./ls.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar isIpfs__default = /*#__PURE__*/_interopDefaultLegacy(isIpfs);\n\nconst readOperations = { stat: stat.createStat };\nconst writeOperations = {\n chmod: chmod.createChmod,\n cp: cp.createCp,\n flush: flush.createFlush,\n mkdir: mkdir.createMkdir,\n mv: mv.createMv,\n rm: rm.createRm,\n touch: touch.createTouch\n};\nconst unwrappedOperations = {\n write: write.createWrite,\n read: read.createRead,\n ls: ls.createLs\n};\nconst wrap = ({options, mfs, operations, lock}) => {\n Object.keys(operations).forEach(key => {\n mfs[key] = lock(operations[key](options));\n });\n};\nconst defaultOptions = {\n repoOwner: true,\n repo: null\n};\nfunction createMfs(options) {\n const {repoOwner} = Object.assign({}, defaultOptions || {}, options);\n const lock = createLock.createLock(repoOwner);\n const readLock = operation => {\n return lock.readLock(operation);\n };\n const writeLock = operation => {\n return lock.writeLock(operation);\n };\n const mfs = {};\n wrap({\n options,\n mfs,\n operations: readOperations,\n lock: readLock\n });\n wrap({\n options,\n mfs,\n operations: writeOperations,\n lock: writeLock\n });\n Object.keys(unwrappedOperations).forEach(key => {\n mfs[key] = unwrappedOperations[key](options);\n });\n return mfs;\n}\nfunction createFiles({\n repo,\n preload,\n hashers,\n options: constructorOptions\n}) {\n const methods = createMfs({\n repo,\n repoOwner: Boolean(constructorOptions.repoOwner),\n hashers\n });\n const withPreload = fn => {\n const wrapped = (...args) => {\n const paths = args.filter(arg => isIpfs__default['default'].ipfsPath(arg) || isIpfs__default['default'].cid(arg));\n if (paths.length) {\n const options = args[args.length - 1];\n if (options && options.preload !== false) {\n paths.forEach(path => preload(path));\n }\n }\n return fn(...args);\n };\n return wrapped;\n };\n return {\n ...methods,\n chmod: methods.chmod,\n cp: withPreload(methods.cp),\n mkdir: methods.mkdir,\n stat: withPreload(methods.stat),\n rm: methods.rm,\n read: withPreload(methods.read),\n touch: methods.touch,\n write: methods.write,\n mv: withPreload(methods.mv),\n flush: methods.flush,\n ls: withPreload(async function* (...args) {\n for await (const file of methods.ls(...args)) {\n yield {\n ...file,\n size: file.size || 0\n };\n }\n })\n };\n}\n\nexports.createFiles = createFiles;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mortice = require('mortice');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mortice__default = /*#__PURE__*/_interopDefaultLegacy(mortice);\n\nlet lock;\nfunction createLock(repoOwner = false) {\n if (lock) {\n return lock;\n }\n const mutex = mortice__default['default']({ singleProcess: repoOwner });\n lock = {\n readLock: func => {\n return async (...args) => {\n const releaseLock = await mutex.readLock();\n try {\n return await func.apply(null, args);\n } finally {\n releaseLock();\n }\n };\n },\n writeLock: func => {\n return async (...args) => {\n const releaseLock = await mutex.writeLock();\n try {\n return await func.apply(null, args);\n } finally {\n releaseLock();\n }\n };\n }\n };\n return lock;\n}\n\nexports.createLock = createLock;\n","const node = require('./node')\nconst browser = require('./browser')\nconst { default: Queue } = require('p-queue')\nconst { timeout } = require('promise-timeout')\nconst observe = require('observable-webworkers')\n\nconst mutexes = {}\nlet implementation\n\nfunction createReleaseable (queue, options) {\n let res\n\n const p = new Promise((resolve) => {\n res = resolve\n })\n\n queue.add(() => timeout((() => {\n return new Promise((resolve) => {\n res(() => {\n resolve()\n })\n })\n })(), options.timeout))\n\n return p\n}\n\nconst createMutex = (name, options) => {\n if (implementation.isWorker) {\n return {\n readLock: implementation.readLock(name, options),\n writeLock: implementation.writeLock(name, options)\n }\n }\n\n const masterQueue = new Queue({ concurrency: 1 })\n let readQueue = null\n\n return {\n readLock: () => {\n // If there's already a read queue, just add the task to it\n if (readQueue) {\n return createReleaseable(readQueue, options)\n }\n\n // Create a new read queue\n readQueue = new Queue({\n concurrency: options.concurrency,\n autoStart: false\n })\n const localReadQueue = readQueue\n\n // Add the task to the read queue\n const readPromise = createReleaseable(readQueue, options)\n\n masterQueue.add(() => {\n // Start the task only once the master queue has completed processing\n // any previous tasks\n localReadQueue.start()\n\n // Once all the tasks in the read queue have completed, remove it so\n // that the next read lock will occur after any write locks that were\n // started in the interim\n return localReadQueue.onIdle()\n .then(() => {\n if (readQueue === localReadQueue) {\n readQueue = null\n }\n })\n })\n\n return readPromise\n },\n writeLock: () => {\n // Remove the read queue reference, so that any later read locks will be\n // added to a new queue that starts after this write lock has been\n // released\n readQueue = null\n\n return createReleaseable(masterQueue, options)\n }\n }\n}\n\nconst defaultOptions = {\n concurrency: Infinity,\n timeout: 84600000,\n global: global,\n singleProcess: false\n}\n\nmodule.exports = (name, options) => {\n if (!options) {\n options = {}\n }\n\n if (typeof name === 'object') {\n options = name\n name = 'lock'\n }\n\n if (!name) {\n name = 'lock'\n }\n\n options = Object.assign({}, defaultOptions, options)\n\n if (!implementation) {\n implementation = node(options) || browser(options)\n\n if (!implementation.isWorker) {\n // we are master, set up worker requests\n implementation.on('requestReadLock', (name, fn) => {\n if (!mutexes[name]) {\n return\n }\n\n mutexes[name].readLock()\n .then(release => fn().finally(() => release()))\n })\n\n implementation.on('requestWriteLock', async (name, fn) => {\n if (!mutexes[name]) {\n return\n }\n\n mutexes[name].writeLock()\n .then(release => fn().finally(() => release()))\n })\n }\n }\n\n if (!mutexes[name]) {\n mutexes[name] = createMutex(name, options)\n }\n\n return mutexes[name]\n}\n\nmodule.exports.Worker = function (script, Impl) {\n Impl = Impl || global.Worker\n let worker\n\n try {\n worker = new Impl(script)\n } catch (error) {\n if (error.message.includes('not a constructor')) {\n worker = Impl(script)\n }\n }\n\n if (!worker) {\n throw new Error('Could not create Worker from', Impl)\n }\n\n observe(worker)\n\n return worker\n}\n","const EventEmitter = require('events').EventEmitter\nconst { nanoid } = require('nanoid')\nconst {\n WORKER_REQUEST_READ_LOCK,\n WORKER_RELEASE_READ_LOCK,\n MASTER_GRANT_READ_LOCK,\n WORKER_REQUEST_WRITE_LOCK,\n WORKER_RELEASE_WRITE_LOCK,\n MASTER_GRANT_WRITE_LOCK\n} = require('./constants')\nlet cluster\n\nconst handleWorkerLockRequest = (emitter, masterEvent, requestType, releaseType, grantType) => {\n return (worker, requestEvent) => {\n if (requestEvent && requestEvent.type === requestType) {\n emitter.emit(masterEvent, requestEvent.name, () => {\n // grant lock to worker\n worker.send({\n type: grantType,\n name: requestEvent.name,\n identifier: requestEvent.identifier\n })\n\n // wait for worker to finish\n return new Promise((resolve) => {\n const releaseEventListener = (releaseEvent) => {\n if (releaseEvent && releaseEvent.type === releaseType && releaseEvent.identifier === requestEvent.identifier) {\n worker.removeListener('message', releaseEventListener)\n resolve()\n }\n }\n\n worker.on('message', releaseEventListener)\n })\n })\n }\n }\n}\n\nconst makeWorkerLockRequest = (name, requestType, grantType, releaseType) => {\n return () => {\n const id = nanoid()\n\n process.send({\n type: requestType,\n identifier: id,\n name\n })\n\n return new Promise((resolve) => {\n const listener = (event) => {\n if (event && event.type === grantType && event.identifier === id) {\n process.removeListener('message', listener)\n\n // grant lock\n resolve(() => {\n // release lock\n process.send({\n type: releaseType,\n identifier: id,\n name\n })\n })\n }\n }\n\n process.on('message', listener)\n })\n }\n}\n\nmodule.exports = (options) => {\n try {\n cluster = require('cluster')\n\n if (!Object.keys(cluster).length) {\n return\n }\n } catch (_) {\n return\n }\n\n if (cluster.isMaster || options.singleProcess) {\n const emitter = new EventEmitter()\n\n cluster.on('message', handleWorkerLockRequest(emitter, 'requestReadLock', WORKER_REQUEST_READ_LOCK, WORKER_RELEASE_READ_LOCK, MASTER_GRANT_READ_LOCK))\n cluster.on('message', handleWorkerLockRequest(emitter, 'requestWriteLock', WORKER_REQUEST_WRITE_LOCK, WORKER_RELEASE_WRITE_LOCK, MASTER_GRANT_WRITE_LOCK))\n\n return emitter\n }\n\n return {\n isWorker: true,\n readLock: (name) => makeWorkerLockRequest(name, WORKER_REQUEST_READ_LOCK, MASTER_GRANT_READ_LOCK, WORKER_RELEASE_READ_LOCK),\n writeLock: (name) => makeWorkerLockRequest(name, WORKER_REQUEST_WRITE_LOCK, MASTER_GRANT_WRITE_LOCK, WORKER_RELEASE_WRITE_LOCK)\n }\n}\n","\nmodule.exports = {\n WORKER_REQUEST_READ_LOCK: 'lock:worker:request-read',\n WORKER_RELEASE_READ_LOCK: 'lock:worker:release-read',\n MASTER_GRANT_READ_LOCK: 'lock:master:grant-read',\n\n WORKER_REQUEST_WRITE_LOCK: 'lock:worker:request-write',\n WORKER_RELEASE_WRITE_LOCK: 'lock:worker:release-write',\n MASTER_GRANT_WRITE_LOCK: 'lock:master:grant-write'\n}\n","const EventEmitter = require('events').EventEmitter\nconst { nanoid } = require('nanoid')\nconst {\n WORKER_REQUEST_READ_LOCK,\n WORKER_RELEASE_READ_LOCK,\n MASTER_GRANT_READ_LOCK,\n WORKER_REQUEST_WRITE_LOCK,\n WORKER_RELEASE_WRITE_LOCK,\n MASTER_GRANT_WRITE_LOCK\n} = require('./constants')\nconst observer = require('observable-webworkers')\n\nconst handleWorkerLockRequest = (emitter, masterEvent, requestType, releaseType, grantType) => {\n return (worker, event) => {\n if (!event || !event.data || event.data.type !== requestType) {\n return\n }\n\n const requestEvent = {\n type: event.data.type,\n name: event.data.name,\n identifier: event.data.identifier\n }\n\n emitter.emit(masterEvent, requestEvent.name, () => {\n // grant lock to worker\n worker.postMessage({\n type: grantType,\n name: requestEvent.name,\n identifier: requestEvent.identifier\n })\n\n // wait for worker to finish\n return new Promise((resolve) => {\n const releaseEventListener = (event) => {\n if (!event || !event.data) {\n return\n }\n\n const releaseEvent = {\n type: event.data.type,\n name: event.data.name,\n identifier: event.data.identifier\n }\n\n if (releaseEvent && releaseEvent.type === releaseType && releaseEvent.identifier === requestEvent.identifier) {\n worker.removeEventListener('message', releaseEventListener)\n resolve()\n }\n }\n\n worker.addEventListener('message', releaseEventListener)\n })\n })\n }\n}\n\nconst makeWorkerLockRequest = (name, requestType, grantType, releaseType) => {\n return () => {\n const id = nanoid()\n\n globalThis.postMessage({\n type: requestType,\n identifier: id,\n name\n })\n\n return new Promise((resolve) => {\n const listener = (event) => {\n if (!event || !event.data) {\n return\n }\n\n const responseEvent = {\n type: event.data.type,\n identifier: event.data.identifier\n }\n\n if (responseEvent && responseEvent.type === grantType && responseEvent.identifier === id) {\n globalThis.removeEventListener('message', listener)\n\n // grant lock\n resolve(() => {\n // release lock\n globalThis.postMessage({\n type: releaseType,\n identifier: id,\n name\n })\n })\n }\n }\n\n globalThis.addEventListener('message', listener)\n })\n }\n}\n\nconst defaultOptions = {\n singleProcess: false\n}\n\nmodule.exports = (options) => {\n options = Object.assign({}, defaultOptions, options)\n const isMaster = !!globalThis.document || options.singleProcess\n\n if (isMaster) {\n const emitter = new EventEmitter()\n\n observer.addEventListener('message', handleWorkerLockRequest(emitter, 'requestReadLock', WORKER_REQUEST_READ_LOCK, WORKER_RELEASE_READ_LOCK, MASTER_GRANT_READ_LOCK))\n observer.addEventListener('message', handleWorkerLockRequest(emitter, 'requestWriteLock', WORKER_REQUEST_WRITE_LOCK, WORKER_RELEASE_WRITE_LOCK, MASTER_GRANT_WRITE_LOCK))\n\n return emitter\n }\n\n return {\n isWorker: true,\n readLock: (name) => makeWorkerLockRequest(name, WORKER_REQUEST_READ_LOCK, MASTER_GRANT_READ_LOCK, WORKER_RELEASE_READ_LOCK),\n writeLock: (name) => makeWorkerLockRequest(name, WORKER_REQUEST_WRITE_LOCK, MASTER_GRANT_WRITE_LOCK, WORKER_RELEASE_WRITE_LOCK)\n }\n}\n","const events = {}\n\nconst observable = (worker) => {\n worker.addEventListener('message', (event) => {\n observable.dispatchEvent('message', worker, event)\n })\n\n if (worker.port) {\n worker.port.addEventListener('message', (event) => {\n observable.dispatchEvent('message', worker, event)\n })\n }\n}\n\nobservable.addEventListener = (type, fn) => {\n if (!events[type]) {\n events[type] = []\n }\n\n events[type].push(fn)\n}\n\nobservable.removeEventListener = (type, fn) => {\n if (!events[type]) {\n return\n }\n\n events[type] = events[type]\n .filter(listener => listener === fn)\n}\n\nobservable.dispatchEvent = function () {\n const args = Array.prototype.slice.call(arguments)\n const type = args.shift()\n\n if (!events[type]) {\n return\n }\n\n events[type].forEach(fn => fn.apply(null, args))\n}\n\nmodule.exports = observable\n","// Copyright (c) 2015-2017 David M. Lee, II\n'use strict';\n\n/**\n * Local reference to TimeoutError\n * @private\n */\nvar TimeoutError;\n\n/**\n * Rejects a promise with a {@link TimeoutError} if it does not settle within\n * the specified timeout.\n *\n * @param {Promise} promise The promise.\n * @param {number} timeoutMillis Number of milliseconds to wait on settling.\n * @returns {Promise} Either resolves/rejects with `promise`, or rejects with\n * `TimeoutError`, whichever settles first.\n */\nvar timeout = module.exports.timeout = function(promise, timeoutMillis) {\n var error = new TimeoutError(),\n timeout;\n\n return Promise.race([\n promise,\n new Promise(function(resolve, reject) {\n timeout = setTimeout(function() {\n reject(error);\n }, timeoutMillis);\n }),\n ]).then(function(v) {\n clearTimeout(timeout);\n return v;\n }, function(err) {\n clearTimeout(timeout);\n throw err;\n });\n};\n\n/**\n * Exception indicating that the timeout expired.\n */\nTimeoutError = module.exports.TimeoutError = function() {\n Error.call(this)\n this.stack = Error().stack\n this.message = 'Timeout';\n};\n\nTimeoutError.prototype = Object.create(Error.prototype);\nTimeoutError.prototype.name = \"TimeoutError\";\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mergeOpts = require('merge-options');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar dagPB = require('@ipld/dag-pb');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:stat');\nconst defaultOptions = { withLocal: false };\nfunction createStat(context) {\n async function mfsStat(path, options = {}) {\n options = mergeOptions(defaultOptions, options);\n log(`Fetching stats for ${ path }`);\n const {type, cid, mfsPath} = await toMfsPath.toMfsPath(context, path, options);\n const exportPath = type === 'ipfs' && cid ? cid : mfsPath;\n let file;\n try {\n file = await ipfsUnixfsExporter.exporter(exportPath, context.repo.blocks);\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n throw errCode__default['default'](new Error(`${ path } does not exist`), 'ERR_NOT_FOUND');\n }\n throw err;\n }\n if (!statters[file.type]) {\n throw new Error(`Cannot stat codec ${ file.cid.code }`);\n }\n return statters[file.type](file);\n }\n return withTimeoutOption.withTimeoutOption(mfsStat);\n}\nconst statters = {\n raw: file => {\n return {\n cid: file.cid,\n size: file.node.length,\n cumulativeSize: file.node.length,\n blocks: 0,\n type: 'file',\n local: undefined,\n sizeLocal: undefined,\n withLocality: false\n };\n },\n file: file => {\n const stat = {\n cid: file.cid,\n type: 'file',\n size: file.unixfs.fileSize(),\n cumulativeSize: dagPB__namespace.encode(file.node).length + (file.node.Links || []).reduce((acc, curr) => acc + (curr.Tsize || 0), 0),\n blocks: file.unixfs.blockSizes.length,\n local: undefined,\n sizeLocal: undefined,\n withLocality: false,\n mode: file.unixfs.mode\n };\n if (file.unixfs.mtime) {\n stat.mtime = file.unixfs.mtime;\n }\n return stat;\n },\n directory: file => {\n const stat = {\n cid: file.cid,\n type: 'directory',\n size: 0,\n cumulativeSize: dagPB__namespace.encode(file.node).length + (file.node.Links || []).reduce((acc, curr) => acc + (curr.Tsize || 0), 0),\n blocks: file.node.Links.length,\n local: undefined,\n sizeLocal: undefined,\n withLocality: false,\n mode: file.unixfs.mode\n };\n if (file.unixfs.mtime) {\n stat.mtime = file.unixfs.mtime;\n }\n return stat;\n },\n object: file => {\n return {\n cid: file.cid,\n size: file.node.length,\n cumulativeSize: file.node.length,\n type: 'file',\n blocks: 0,\n local: undefined,\n sizeLocal: undefined,\n withLocality: false\n };\n },\n identity: file => {\n return {\n cid: file.cid,\n size: file.node.length,\n cumulativeSize: file.node.length,\n blocks: 0,\n type: 'file',\n local: undefined,\n sizeLocal: undefined,\n withLocality: false\n };\n }\n};\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withMfsRoot = require('./with-mfs-root.js');\nvar toPathComponents = require('./to-path-components.js');\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar errCode = require('err-code');\nvar cid = require('multiformats/cid');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst IPFS_PREFIX = 'ipfs';\nconst toMfsPath = async (context, path, options) => {\n const root = await withMfsRoot.loadMfsRoot(context, options);\n let output = { entryType: 'file' };\n let ipfsPath = '';\n if (cid.CID.asCID(path)) {\n ipfsPath = `/ipfs/${ path }`;\n } else {\n ipfsPath = path.toString();\n }\n ipfsPath = ipfsPath.trim();\n ipfsPath = ipfsPath.replace(/(\\/\\/+)/g, '/');\n if (ipfsPath.endsWith('/') && ipfsPath.length > 1) {\n ipfsPath = ipfsPath.substring(0, ipfsPath.length - 1);\n }\n if (!ipfsPath) {\n throw errCode__default['default'](new Error('paths must not be empty'), 'ERR_NO_PATH');\n }\n if (ipfsPath.substring(0, 1) !== '/') {\n throw errCode__default['default'](new Error('paths must start with a leading slash'), 'ERR_INVALID_PATH');\n }\n if (ipfsPath.substring(ipfsPath.length - 1) === '/') {\n ipfsPath = ipfsPath.substring(0, ipfsPath.length - 1);\n }\n const pathComponents = toPathComponents.toPathComponents(ipfsPath);\n if (pathComponents[0] === IPFS_PREFIX) {\n let mfsDirectory;\n if (pathComponents.length === 2) {\n mfsDirectory = `/${ pathComponents.join('/') }`;\n } else {\n mfsDirectory = `/${ pathComponents.slice(0, pathComponents.length - 1).join('/') }`;\n }\n output = {\n type: 'ipfs',\n depth: pathComponents.length - 2,\n entryType: 'file',\n mfsPath: `/${ pathComponents.join('/') }`,\n mfsDirectory,\n parts: pathComponents,\n path: `/${ pathComponents.join('/') }`,\n name: pathComponents[pathComponents.length - 1]\n };\n } else {\n const mfsPath = `/${ IPFS_PREFIX }/${ root }${ pathComponents.length ? '/' + pathComponents.join('/') : '' }`;\n const mfsDirectory = `/${ IPFS_PREFIX }/${ root }/${ pathComponents.slice(0, pathComponents.length - 1).join('/') }`;\n output = {\n type: 'mfs',\n depth: pathComponents.length,\n entryType: 'file',\n mfsDirectory,\n mfsPath,\n parts: pathComponents,\n path: `/${ pathComponents.join('/') }`,\n name: pathComponents[pathComponents.length - 1]\n };\n }\n const cidPath = output.type === 'mfs' ? output.mfsPath : output.path;\n try {\n const res = await ipfsUnixfsExporter.exporter(cidPath, context.repo.blocks, options);\n output.cid = res.cid;\n output.mfsPath = `/ipfs/${ res.path }`;\n output.entryType = res.type;\n output.content = res.content;\n if ((output.entryType === 'file' || output.entryType === 'directory') && (res.type === 'file' || res.type === 'directory')) {\n output.unixfs = res.unixfs;\n }\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n }\n output.exists = Boolean(output.cid);\n return output;\n};\n\nexports.toMfsPath = toMfsPath;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dagPB = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar utils = require('../../../utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst log = debug__default['default']('ipfs:mfs:utils:with-mfs-root');\nasync function loadMfsRoot(context, options) {\n if (options && options.signal && options.signal.aborted) {\n throw errCode__default['default'](new Error('Request aborted'), 'ERR_ABORTED', { name: 'Aborted' });\n }\n await context.repo.datastore.open();\n let cid$1;\n try {\n const buf = await context.repo.datastore.get(utils.MFS_ROOT_KEY);\n cid$1 = cid.CID.decode(buf);\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n log('Creating new MFS root');\n const buf = dagPB__namespace.encode({\n Data: new ipfsUnixfs.UnixFS({ type: 'directory' }).marshal(),\n Links: []\n });\n const hash = await sha2.sha256.digest(buf);\n cid$1 = cid.CID.createV0(hash);\n await context.repo.blocks.put(cid$1, buf);\n if (options && options.signal && options.signal.aborted) {\n throw errCode__default['default'](new Error('Request aborted'), 'ERR_ABORTED', { name: 'Aborted' });\n }\n await context.repo.datastore.put(utils.MFS_ROOT_KEY, cid$1.bytes);\n }\n log(`Loaded MFS root /ipfs/${ cid$1 }`);\n return cid$1;\n}\n\nexports.loadMfsRoot = loadMfsRoot;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction toPathComponents(path = '') {\n return (path.trim().match(/([^\\\\^/]|\\\\\\/)+/g) || []).filter(Boolean);\n}\n\nexports.toPathComponents = toPathComponents;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mergeOpts = require('merge-options');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar toTrail = require('./utils/to-trail.js');\nvar addLink = require('./utils/add-link.js');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar itPipe = require('it-pipe');\nvar ipfsUnixfsImporter = require('ipfs-unixfs-importer');\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar last = require('it-last');\nvar cp = require('./cp.js');\nvar rm = require('./rm.js');\nvar persist = require('./utils/persist.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:touch');\nconst defaultOptions = {\n flush: true,\n shardSplitThreshold: 1000,\n hashAlg: 'sha2-256',\n cidVersion: 0,\n recursive: false\n};\nfunction calculateModification(mode, originalMode, isDirectory) {\n let modification = 0;\n if (mode.includes('x') || mode.includes('X') && (isDirectory || (originalMode & 1 || originalMode & 8 || originalMode & 64))) {\n modification += 1;\n }\n if (mode.includes('w')) {\n modification += 2;\n }\n if (mode.includes('r')) {\n modification += 4;\n }\n return modification;\n}\nfunction calculateUGO(references, modification) {\n let ugo = 0;\n if (references.includes('u')) {\n ugo += modification << 6;\n }\n if (references.includes('g')) {\n ugo += modification << 3;\n }\n if (references.includes('o')) {\n ugo += modification;\n }\n return ugo;\n}\nfunction calculateSpecial(references, mode, modification) {\n if (mode.includes('t')) {\n modification += parseInt('1000', 8);\n }\n if (mode.includes('s')) {\n if (references.includes('u')) {\n modification += parseInt('4000', 8);\n }\n if (references.includes('g')) {\n modification += parseInt('2000', 8);\n }\n }\n return modification;\n}\nfunction parseSymbolicMode(input, originalMode, isDirectory) {\n if (!originalMode) {\n originalMode = 0;\n }\n const match = input.match(/^(u?g?o?a?)(-?\\+?=?)?(r?w?x?X?s?t?)$/);\n if (!match) {\n throw new Error(`Invalid file mode: ${ input }`);\n }\n let [, references, operator, mode] = match;\n if (references === 'a' || !references) {\n references = 'ugo';\n }\n let modification = calculateModification(mode, originalMode, isDirectory);\n modification = calculateUGO(references, modification);\n modification = calculateSpecial(references, mode, modification);\n if (operator === '=') {\n if (references.includes('u')) {\n originalMode = originalMode & parseInt('7077', 8);\n originalMode = originalMode | modification;\n }\n if (references.includes('g')) {\n originalMode = originalMode & parseInt('7707', 8);\n originalMode = originalMode | modification;\n }\n if (references.includes('o')) {\n originalMode = originalMode & parseInt('7770', 8);\n originalMode = originalMode | modification;\n }\n return originalMode;\n }\n if (operator === '+') {\n return modification | originalMode;\n }\n if (operator === '-') {\n return modification ^ originalMode;\n }\n return originalMode;\n}\nfunction calculateMode(mode, metadata) {\n if (mode instanceof String || typeof mode === 'string') {\n const strMode = `${ mode }`;\n if (strMode.match(/^\\d+$/g)) {\n mode = parseInt(strMode, 8);\n } else {\n mode = 0 + strMode.split(',').reduce((curr, acc) => {\n return parseSymbolicMode(acc, curr, metadata.isDirectory());\n }, metadata.mode || 0);\n }\n }\n return mode;\n}\nfunction createChmod(context) {\n async function mfsChmod(path, mode, options = {}) {\n const opts = mergeOptions(defaultOptions, options);\n log(`Fetching stats for ${ path }`);\n const {cid: cid$1, mfsDirectory, name} = await toMfsPath.toMfsPath(context, path, opts);\n if (cid$1.code !== dagPB__namespace.code) {\n throw errCode__default['default'](new Error(`${ path } was not a UnixFS node`), 'ERR_NOT_UNIXFS');\n }\n if (opts.recursive) {\n const root = await itPipe.pipe(async function* () {\n for await (const entry of ipfsUnixfsExporter.recursive(cid$1, context.repo.blocks)) {\n if (entry.type !== 'file' && entry.type !== 'directory') {\n throw errCode__default['default'](new Error(`${ path } was not a UnixFS node`), 'ERR_NOT_UNIXFS');\n }\n entry.unixfs.mode = calculateMode(mode, entry.unixfs);\n const node = dagPB__namespace.prepare({\n Data: entry.unixfs.marshal(),\n Links: entry.node.Links\n });\n yield {\n path: entry.path,\n content: node\n };\n }\n }, source => ipfsUnixfsImporter.importer(source, context.repo.blocks, {\n ...opts,\n pin: false,\n dagBuilder: async function* (source, block, opts) {\n for await (const entry of source) {\n yield async function () {\n const node = entry.content;\n const buf = dagPB__namespace.encode(node);\n const cid = await persist.persist(buf, block, opts);\n if (!node.Data) {\n throw errCode__default['default'](new Error(`${ cid } had no data`), 'ERR_INVALID_NODE');\n }\n const unixfs = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n return {\n cid,\n size: buf.length,\n path: entry.path,\n unixfs\n };\n };\n }\n }\n }), nodes => last__default['default'](nodes));\n if (!root) {\n throw errCode__default['default'](new Error(`Could not chmod ${ path }`), 'ERR_COULD_NOT_CHMOD');\n }\n await rm.createRm(context)(path, opts);\n await cp.createCp(context)(`/ipfs/${ root.cid }`, path, opts);\n return;\n }\n const block = await context.repo.blocks.get(cid$1);\n const node = dagPB__namespace.decode(block);\n if (!node.Data) {\n throw errCode__default['default'](new Error(`${ cid$1 } had no data`), 'ERR_INVALID_NODE');\n }\n const metadata = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n metadata.mode = calculateMode(mode, metadata);\n const updatedBlock = dagPB__namespace.encode({\n Data: metadata.marshal(),\n Links: node.Links\n });\n const hashAlg = opts.hashAlg || defaultOptions.hashAlg;\n const hasher = await context.hashers.getHasher(hashAlg);\n const hash = await hasher.digest(updatedBlock);\n const updatedCid = cid.CID.create(opts.cidVersion, dagPB__namespace.code, hash);\n if (opts.flush) {\n await context.repo.blocks.put(updatedCid, updatedBlock);\n }\n const trail = await toTrail.toTrail(context, mfsDirectory);\n const parent = trail[trail.length - 1];\n const parentCid = cid.CID.decode(parent.cid.bytes);\n const parentBlock = await context.repo.blocks.get(parentCid);\n const parentNode = dagPB__namespace.decode(parentBlock);\n const result = await addLink.addLink(context, {\n parent: parentNode,\n name: name,\n cid: updatedCid,\n size: updatedBlock.length,\n flush: opts.flush,\n hashAlg,\n cidVersion: cid$1.version,\n shardSplitThreshold: Infinity\n });\n parent.cid = result.cid;\n const newRootCid = await updateTree.updateTree(context, trail, opts);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, opts);\n }\n return withTimeoutOption.withTimeoutOption(mfsChmod);\n}\n\nexports.createChmod = createChmod;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:mfs:utils:to-trail');\nasync function toTrail(context, path) {\n log(`Creating trail for path ${ path }`);\n const output = [];\n for await (const fsEntry of ipfsUnixfsExporter.walkPath(path, context.repo.blocks)) {\n output.push({\n name: fsEntry.name,\n cid: fsEntry.cid,\n size: fsEntry.size,\n type: fsEntry.type\n });\n }\n return output;\n}\n\nexports.toTrail = toTrail;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar debug = require('debug');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dirSharded = require('./dir-sharded.js');\nvar hamtUtils = require('./hamt-utils.js');\nvar errCode = require('err-code');\nvar last = require('it-last');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst log = debug__default['default']('ipfs:mfs:core:utils:add-link');\nasync function addLink(context, options) {\n let parent = options.parent;\n if (options.parentCid) {\n const parentCid = cid.CID.asCID(options.parentCid);\n if (parentCid === null) {\n throw errCode__default['default'](new Error('Invalid CID passed to addLink'), 'EINVALIDPARENTCID');\n }\n if (parentCid.code !== dagPB__namespace.code) {\n throw errCode__default['default'](new Error('Unsupported codec. Only DAG-PB is supported'), 'EINVALIDPARENTCID');\n }\n log(`Loading parent node ${ parentCid }`);\n const block = await context.repo.blocks.get(parentCid);\n parent = dagPB__namespace.decode(block);\n }\n if (!parent) {\n throw errCode__default['default'](new Error('No parent node or CID passed to addLink'), 'EINVALIDPARENT');\n }\n if (!options.cid) {\n throw errCode__default['default'](new Error('No child cid passed to addLink'), 'EINVALIDCHILDCID');\n }\n if (!options.name) {\n throw errCode__default['default'](new Error('No child name passed to addLink'), 'EINVALIDCHILDNAME');\n }\n if (!options.size && options.size !== 0) {\n throw errCode__default['default'](new Error('No child size passed to addLink'), 'EINVALIDCHILDSIZE');\n }\n if (!parent.Data) {\n throw errCode__default['default'](new Error('Parent node with no data passed to addLink'), 'ERR_INVALID_PARENT');\n }\n const meta = ipfsUnixfs.UnixFS.unmarshal(parent.Data);\n if (meta.type === 'hamt-sharded-directory') {\n log('Adding link to sharded directory');\n return addToShardedDirectory(context, {\n ...options,\n parent\n });\n }\n if (parent.Links.length >= options.shardSplitThreshold) {\n log('Converting directory to sharded directory');\n return convertToShardedDirectory(context, {\n ...options,\n parent,\n mtime: meta.mtime,\n mode: meta.mode\n });\n }\n log(`Adding ${ options.name } (${ options.cid }) to regular directory`);\n return addToDirectory(context, {\n ...options,\n parent\n });\n}\nconst convertToShardedDirectory = async (context, options) => {\n const result = await hamtUtils.createShard(context, options.parent.Links.map(link => ({\n name: link.Name || '',\n size: link.Tsize || 0,\n cid: link.Hash\n })).concat({\n name: options.name,\n size: options.size,\n cid: options.cid\n }), options);\n log(`Converted directory to sharded directory ${ result.cid }`);\n return result;\n};\nconst addToDirectory = async (context, options) => {\n const parentLinks = options.parent.Links.filter(link => {\n return link.Name !== options.name;\n });\n parentLinks.push({\n Name: options.name,\n Tsize: options.size,\n Hash: options.cid\n });\n if (!options.parent.Data) {\n throw errCode__default['default'](new Error('Parent node with no data passed to addToDirectory'), 'ERR_INVALID_PARENT');\n }\n const node = ipfsUnixfs.UnixFS.unmarshal(options.parent.Data);\n let data;\n if (node.mtime) {\n const ms = Date.now();\n const secs = Math.floor(ms / 1000);\n node.mtime = {\n secs: secs,\n nsecs: (ms - secs * 1000) * 1000\n };\n data = node.marshal();\n } else {\n data = options.parent.Data;\n }\n options.parent = dagPB__namespace.prepare({\n Data: data,\n Links: parentLinks\n });\n const hasher = await context.hashers.getHasher(options.hashAlg);\n const buf = dagPB__namespace.encode(options.parent);\n const hash = await hasher.digest(buf);\n const cid$1 = cid.CID.create(options.cidVersion, dagPB__namespace.code, hash);\n if (options.flush) {\n await context.repo.blocks.put(cid$1, buf);\n }\n return {\n node: options.parent,\n cid: cid$1,\n size: buf.length\n };\n};\nconst addToShardedDirectory = async (context, options) => {\n const {shard, path} = await addFileToShardedDirectory(context, options);\n const result = await last__default['default'](shard.flush(context.repo.blocks));\n if (!result) {\n throw new Error('No result from flushing shard');\n }\n const block = await context.repo.blocks.get(result.cid);\n const node = dagPB__namespace.decode(block);\n const parentLinks = options.parent.Links.filter(link => {\n return (link.Name || '').substring(0, 2) !== path[0].prefix;\n });\n const newLink = node.Links.find(link => (link.Name || '').substring(0, 2) === path[0].prefix);\n if (!newLink) {\n throw new Error(`No link found with prefix ${ path[0].prefix }`);\n }\n parentLinks.push(newLink);\n return hamtUtils.updateHamtDirectory(context, parentLinks, path[0].bucket, options);\n};\nconst addFileToShardedDirectory = async (context, options) => {\n const file = {\n name: options.name,\n cid: options.cid,\n size: options.size\n };\n if (!options.parent.Data) {\n throw errCode__default['default'](new Error('Parent node with no data passed to addFileToShardedDirectory'), 'ERR_INVALID_PARENT');\n }\n const rootBucket = await hamtUtils.recreateInitialHamtLevel(options.parent.Links);\n const node = ipfsUnixfs.UnixFS.unmarshal(options.parent.Data);\n const shard = new dirSharded.DirSharded({\n root: true,\n dir: true,\n parent: undefined,\n parentKey: undefined,\n path: '',\n dirty: true,\n flat: false,\n mode: node.mode\n }, options);\n shard._bucket = rootBucket;\n if (node.mtime) {\n shard.mtime = { secs: Math.round(Date.now() / 1000) };\n }\n const position = await rootBucket._findNewBucketAndPos(file.name);\n const path = toBucketPath(position);\n path[0].node = options.parent;\n let index = 0;\n while (index < path.length) {\n const segment = path[index];\n index++;\n const node = segment.node;\n if (!node) {\n throw new Error('Segment had no node');\n }\n const link = node.Links.find(link => (link.Name || '').substring(0, 2) === segment.prefix);\n if (!link) {\n log(`Link ${ segment.prefix }${ file.name } will be added`);\n index = path.length;\n break;\n }\n if (link.Name === `${ segment.prefix }${ file.name }`) {\n log(`Link ${ segment.prefix }${ file.name } will be replaced`);\n index = path.length;\n break;\n }\n if ((link.Name || '').length > 2) {\n log(`Link ${ link.Name } ${ link.Hash } will be replaced with a subshard`);\n index = path.length;\n break;\n }\n log(`Found subshard ${ segment.prefix }`);\n const block = await context.repo.blocks.get(link.Hash);\n const subShard = dagPB__namespace.decode(block);\n if (!path[index]) {\n log(`Loaded new subshard ${ segment.prefix }`);\n await hamtUtils.recreateHamtLevel(subShard.Links, rootBucket, segment.bucket, parseInt(segment.prefix, 16));\n const position = await rootBucket._findNewBucketAndPos(file.name);\n path.push({\n bucket: position.bucket,\n prefix: hamtUtils.toPrefix(position.pos),\n node: subShard\n });\n break;\n }\n const nextSegment = path[index];\n await hamtUtils.addLinksToHamtBucket(subShard.Links, nextSegment.bucket, rootBucket);\n nextSegment.node = subShard;\n }\n await shard._bucket.put(file.name, {\n size: file.size,\n cid: file.cid\n });\n return {\n shard,\n path\n };\n};\nconst toBucketPath = position => {\n const path = [{\n bucket: position.bucket,\n prefix: hamtUtils.toPrefix(position.pos)\n }];\n let bucket = position.bucket._parent;\n let positionInBucket = position.bucket._posAtParent;\n while (bucket) {\n path.push({\n bucket,\n prefix: hamtUtils.toPrefix(positionInBucket)\n });\n positionInBucket = bucket._posAtParent;\n bucket = bucket._parent;\n }\n path.reverse();\n return path;\n};\n\nexports.addLink = addLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar persist = require('./persist.js');\nvar hamtSharding = require('hamt-sharding');\nvar hamtConstants = require('./hamt-constants.js');\n\nclass Dir {\n constructor(props, options) {\n this.options = options || {};\n this.root = props.root;\n this.dir = props.dir;\n this.path = props.path;\n this.dirty = props.dirty;\n this.flat = props.flat;\n this.parent = props.parent;\n this.parentKey = props.parentKey;\n this.unixfs = props.unixfs;\n this.mode = props.mode;\n this.mtime = props.mtime;\n this.cid = undefined;\n this.size = undefined;\n }\n async put(name, value) {\n }\n get(name) {\n return Promise.resolve(this);\n }\n async *eachChildSeries() {\n }\n async *flush(blockstore) {\n }\n}\nclass DirSharded extends Dir {\n constructor(props, options) {\n super(props, options);\n this._bucket = hamtSharding.createHAMT({\n hashFn: hamtConstants.hamtHashFn,\n bits: hamtConstants.hamtBucketBits\n });\n }\n async put(name, value) {\n await this._bucket.put(name, value);\n }\n get(name) {\n return this._bucket.get(name);\n }\n childCount() {\n return this._bucket.leafCount();\n }\n directChildrenCount() {\n return this._bucket.childrenCount();\n }\n onlyChild() {\n return this._bucket.onlyChild();\n }\n async *eachChildSeries() {\n for await (const {key, value} of this._bucket.eachLeafSeries()) {\n yield {\n key,\n child: value\n };\n }\n }\n async *flush(blockstore) {\n yield* flush(this._bucket, blockstore, this, this.options);\n }\n}\nasync function* flush(bucket, blockstore, shardRoot, options) {\n const children = bucket._children;\n const links = [];\n let childrenSize = 0;\n for (let i = 0; i < children.length; i++) {\n const child = children.get(i);\n if (!child) {\n continue;\n }\n const labelPrefix = i.toString(16).toUpperCase().padStart(2, '0');\n if (child instanceof hamtSharding.Bucket) {\n let shard;\n for await (const subShard of await flush(child, blockstore, null, options)) {\n shard = subShard;\n }\n if (!shard) {\n throw new Error('Could not flush sharded directory, no subshard found');\n }\n links.push({\n Name: labelPrefix,\n Tsize: shard.size,\n Hash: shard.cid\n });\n childrenSize += shard.size;\n } else if (typeof child.value.flush === 'function') {\n const dir = child.value;\n let flushedDir;\n for await (const entry of dir.flush(blockstore)) {\n flushedDir = entry;\n yield flushedDir;\n }\n const label = labelPrefix + child.key;\n links.push({\n Name: label,\n Tsize: flushedDir.size,\n Hash: flushedDir.cid\n });\n childrenSize += flushedDir.size;\n } else {\n const value = child.value;\n if (!value.cid) {\n continue;\n }\n const label = labelPrefix + child.key;\n const size = value.size;\n links.push({\n Name: label,\n Tsize: size,\n Hash: value.cid\n });\n childrenSize += size;\n }\n }\n const data = Uint8Array.from(children.bitField().reverse());\n const dir = new ipfsUnixfs.UnixFS({\n type: 'hamt-sharded-directory',\n data,\n fanout: bucket.tableSize(),\n hashType: hamtConstants.hamtHashCode,\n mtime: shardRoot && shardRoot.mtime,\n mode: shardRoot && shardRoot.mode\n });\n const node = {\n Data: dir.marshal(),\n Links: links\n };\n const buffer = dagPB.encode(dagPB.prepare(node));\n const cid = await persist.persist(buffer, blockstore, options);\n const size = buffer.length + childrenSize;\n yield {\n cid,\n node,\n size\n };\n}\n\nexports.Dir = Dir;\nexports.DirSharded = DirSharded;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar dagPB = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nconst persist = async (buffer, blockstore, options) => {\n if (!options.codec) {\n options.codec = dagPB__namespace;\n }\n if (!options.hasher) {\n options.hasher = sha2.sha256;\n }\n if (options.cidVersion === undefined) {\n options.cidVersion = 1;\n }\n if (options.codec === dagPB__namespace && options.hasher !== sha2.sha256) {\n options.cidVersion = 1;\n }\n const multihash = await options.hasher.digest(buffer);\n const cid$1 = cid.CID.create(options.cidVersion, options.codec.code, multihash);\n if (!options.onlyHash) {\n await blockstore.put(cid$1, buffer, { signal: options.signal });\n }\n return cid$1;\n};\n\nexports.persist = persist;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar murmur3 = require('@multiformats/murmur3');\n\nconst hamtHashCode = murmur3.murmur3128.code;\nconst hamtBucketBits = 8;\nasync function hamtHashFn(buf) {\n return (await murmur3.murmur3128.encode(buf)).slice(0, 8).reverse();\n}\n\nexports.hamtBucketBits = hamtBucketBits;\nexports.hamtHashCode = hamtHashCode;\nexports.hamtHashFn = hamtHashFn;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar hamtSharding = require('hamt-sharding');\nvar dirSharded = require('./dir-sharded.js');\nvar debug = require('debug');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar last = require('it-last');\nvar cid = require('multiformats/cid');\nvar hamtConstants = require('./hamt-constants.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst log = debug__default['default']('ipfs:mfs:core:utils:hamt-utils');\nconst updateHamtDirectory = async (context, links, bucket, options) => {\n if (!options.parent.Data) {\n throw new Error('Could not update HAMT directory because parent had no data');\n }\n const data = Uint8Array.from(bucket._children.bitField().reverse());\n const node = ipfsUnixfs.UnixFS.unmarshal(options.parent.Data);\n const dir = new ipfsUnixfs.UnixFS({\n type: 'hamt-sharded-directory',\n data,\n fanout: bucket.tableSize(),\n hashType: hamtConstants.hamtHashCode,\n mode: node.mode,\n mtime: node.mtime\n });\n const hasher = await context.hashers.getHasher(options.hashAlg);\n const parent = {\n Data: dir.marshal(),\n Links: links.sort((a, b) => (a.Name || '').localeCompare(b.Name || ''))\n };\n const buf = dagPB__namespace.encode(parent);\n const hash = await hasher.digest(buf);\n const cid$1 = cid.CID.create(options.cidVersion, dagPB__namespace.code, hash);\n if (options.flush) {\n await context.repo.blocks.put(cid$1, buf);\n }\n return {\n node: parent,\n cid: cid$1,\n size: links.reduce((sum, link) => sum + (link.Tsize || 0), buf.length)\n };\n};\nconst recreateHamtLevel = async (links, rootBucket, parentBucket, positionAtParent) => {\n const bucket = new hamtSharding.Bucket({\n hash: rootBucket._options.hash,\n bits: rootBucket._options.bits\n }, parentBucket, positionAtParent);\n parentBucket._putObjectAt(positionAtParent, bucket);\n await addLinksToHamtBucket(links, bucket, rootBucket);\n return bucket;\n};\nconst recreateInitialHamtLevel = async links => {\n const bucket = hamtSharding.createHAMT({\n hashFn: hamtConstants.hamtHashFn,\n bits: hamtConstants.hamtBucketBits\n });\n await addLinksToHamtBucket(links, bucket, bucket);\n return bucket;\n};\nconst addLinksToHamtBucket = async (links, bucket, rootBucket) => {\n await Promise.all(links.map(link => {\n const linkName = link.Name || '';\n if (linkName.length === 2) {\n const pos = parseInt(linkName, 16);\n bucket._putObjectAt(pos, new hamtSharding.Bucket({\n hash: rootBucket._options.hash,\n bits: rootBucket._options.bits\n }, bucket, pos));\n return Promise.resolve();\n }\n return rootBucket.put(linkName.substring(2), {\n size: link.Tsize,\n cid: link.Hash\n });\n }));\n};\nconst toPrefix = position => {\n return position.toString(16).toUpperCase().padStart(2, '0').substring(0, 2);\n};\nconst generatePath = async (context, fileName, rootNode) => {\n const rootBucket = await recreateInitialHamtLevel(rootNode.Links);\n const position = await rootBucket._findNewBucketAndPos(fileName);\n const path = [{\n bucket: position.bucket,\n prefix: toPrefix(position.pos)\n }];\n let currentBucket = position.bucket;\n while (currentBucket !== rootBucket) {\n path.push({\n bucket: currentBucket,\n prefix: toPrefix(currentBucket._posAtParent)\n });\n currentBucket = currentBucket._parent;\n }\n path.reverse();\n path[0].node = rootNode;\n for (let i = 0; i < path.length; i++) {\n const segment = path[i];\n if (!segment.node) {\n throw new Error('Could not generate HAMT path');\n }\n const link = segment.node.Links.filter(link => (link.Name || '').substring(0, 2) === segment.prefix).pop();\n if (!link) {\n log(`Link ${ segment.prefix }${ fileName } will be added`);\n continue;\n }\n if (link.Name === `${ segment.prefix }${ fileName }`) {\n log(`Link ${ segment.prefix }${ fileName } will be replaced`);\n continue;\n }\n log(`Found subshard ${ segment.prefix }`);\n const block = await context.repo.blocks.get(link.Hash);\n const node = dagPB__namespace.decode(block);\n if (!path[i + 1]) {\n log(`Loaded new subshard ${ segment.prefix }`);\n await recreateHamtLevel(node.Links, rootBucket, segment.bucket, parseInt(segment.prefix, 16));\n const position = await rootBucket._findNewBucketAndPos(fileName);\n path.push({\n bucket: position.bucket,\n prefix: toPrefix(position.pos),\n node: node\n });\n continue;\n }\n const nextSegment = path[i + 1];\n await addLinksToHamtBucket(node.Links, nextSegment.bucket, rootBucket);\n nextSegment.node = node;\n }\n await rootBucket.put(fileName, true);\n path.reverse();\n return {\n rootBucket,\n path\n };\n};\nconst createShard = async (context, contents, options = {}) => {\n const shard = new dirSharded.DirSharded({\n root: true,\n dir: true,\n parent: undefined,\n parentKey: undefined,\n path: '',\n dirty: true,\n flat: false,\n mtime: options.mtime,\n mode: options.mode\n }, options);\n for (let i = 0; i < contents.length; i++) {\n await shard._bucket.put(contents[i].name, {\n size: contents[i].size,\n cid: contents[i].cid\n });\n }\n const res = await last__default['default'](shard.flush(context.repo.blocks));\n if (!res) {\n throw new Error('Flushing shard yielded no result');\n }\n return res;\n};\n\nexports.addLinksToHamtBucket = addLinksToHamtBucket;\nexports.createShard = createShard;\nexports.generatePath = generatePath;\nexports.recreateHamtLevel = recreateHamtLevel;\nexports.recreateInitialHamtLevel = recreateInitialHamtLevel;\nexports.toPrefix = toPrefix;\nexports.updateHamtDirectory = updateHamtDirectory;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar addLink = require('./add-link.js');\nvar dagPB = require('@ipld/dag-pb');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:mfs:utils:update-tree');\nconst defaultOptions = { shardSplitThreshold: 1000 };\nasync function updateTree(context, trail, options) {\n options = Object.assign({}, defaultOptions, options);\n log('Trail', trail);\n trail = trail.slice().reverse();\n let index = 0;\n let child;\n for await (const block of context.repo.blocks.getMany(trail.map(node => node.cid))) {\n const node = dagPB.decode(block);\n const cid = trail[index].cid;\n const name = trail[index].name;\n index++;\n if (!child) {\n child = {\n cid,\n name,\n size: block.length\n };\n continue;\n }\n const result = await addLink.addLink(context, {\n parent: node,\n name: child.name,\n cid: child.cid,\n size: child.size,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion\n });\n child = {\n cid: result.cid,\n name,\n size: result.size\n };\n }\n const {cid} = child;\n log(`Final CID ${ cid }`);\n return cid;\n}\n\nexports.updateTree = updateTree;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar utils = require('../../../utils.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst log = debug__default['default']('ipfs:mfs:utils:update-mfs-root');\nasync function updateMfsRoot(context, cid, options) {\n if (options && options.signal && options.signal.aborted) {\n throw errCode__default['default'](new Error('Request aborted'), 'ERR_ABORTED', { name: 'Aborted' });\n }\n log(`New MFS root will be ${ cid }`);\n await context.repo.datastore.put(utils.MFS_ROOT_KEY, cid.bytes);\n return cid;\n}\n\nexports.updateMfsRoot = updateMfsRoot;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mkdir = require('./mkdir.js');\nvar stat = require('./stat.js');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar addLink = require('./utils/add-link.js');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar mergeOpts = require('merge-options');\nvar toTrail = require('./utils/to-trail.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:cp');\nconst defaultOptions = {\n parents: false,\n flush: true,\n hashAlg: 'sha2-256',\n cidVersion: 0,\n shardSplitThreshold: 1000\n};\nfunction createCp(context) {\n async function mfsCp(from, to, opts = {}) {\n const options = mergeOptions(defaultOptions, opts);\n if (!Array.isArray(from)) {\n from = [from];\n }\n const sources = await Promise.all(from.map(path => toMfsPath.toMfsPath(context, path, options)));\n let destination = await toMfsPath.toMfsPath(context, to, options);\n if (!sources.length || !destination) {\n throw errCode__default['default'](new Error('Please supply at least one source'), 'ERR_INVALID_PARAMS');\n }\n const missing = sources.find(source => !source.exists);\n if (missing) {\n throw errCode__default['default'](new Error(`${ missing.path } does not exist`), 'ERR_INVALID_PARAMS');\n }\n const destinationIsDirectory = isDirectory(destination);\n if (destination.exists) {\n log('Destination exists');\n if (sources.length === 1 && !destinationIsDirectory) {\n throw errCode__default['default'](new Error('directory already has entry by that name'), 'ERR_ALREADY_EXISTS');\n }\n } else {\n log('Destination does not exist');\n if (sources.length > 1) {\n if (!options.parents) {\n throw errCode__default['default'](new Error('destination did not exist, pass -p to create intermediate directories'), 'ERR_INVALID_PARAMS');\n }\n await mkdir.createMkdir(context)(destination.path, options);\n destination = await toMfsPath.toMfsPath(context, destination.path, options);\n } else if (destination.parts.length > 1) {\n const parentFolder = `/${ destination.parts.slice(0, -1).join('/') }`;\n try {\n await stat.createStat(context)(parentFolder, options);\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n if (!options.parents) {\n throw errCode__default['default'](new Error('destination did not exist, pass -p to create intermediate directories'), 'ERR_INVALID_PARAMS');\n }\n await mkdir.createMkdir(context)(parentFolder, options);\n destination = await toMfsPath.toMfsPath(context, destination.path, options);\n }\n }\n }\n const destinationPath = isDirectory(destination) ? destination.mfsPath : destination.mfsDirectory;\n const trail = await toTrail.toTrail(context, destinationPath);\n if (sources.length === 1) {\n const source = sources.pop();\n if (!source) {\n throw errCode__default['default'](new Error('could not find source'), 'ERR_INVALID_PARAMS');\n }\n const destinationName = destinationIsDirectory ? source.name : destination.name;\n log(`Only one source, copying to destination ${ destinationIsDirectory ? 'directory' : 'file' } ${ destinationName }`);\n return copyToFile(context, source, destinationName, trail, options);\n }\n log('Multiple sources, wrapping in a directory');\n return copyToDirectory(context, sources, destination, trail, options);\n }\n return withTimeoutOption.withTimeoutOption(mfsCp);\n}\nconst isDirectory = destination => {\n return destination.unixfs && destination.unixfs.type && destination.unixfs.type.includes('directory');\n};\nconst copyToFile = async (context, source, destination, destinationTrail, options) => {\n let parent = destinationTrail.pop();\n if (!parent) {\n throw errCode__default['default'](new Error('destination had no parent'), 'ERR_INVALID_PARAMS');\n }\n parent = await addSourceToParent(context, source, destination, parent, options);\n destinationTrail.push(parent);\n const newRootCid = await updateTree.updateTree(context, destinationTrail, options);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, options);\n};\nconst copyToDirectory = async (context, sources, destination, destinationTrail, options) => {\n for (let i = 0; i < sources.length; i++) {\n const source = sources[i];\n destination = await addSourceToParent(context, source, source.name, destination, options);\n }\n destinationTrail[destinationTrail.length - 1] = destination;\n const newRootCid = await updateTree.updateTree(context, destinationTrail, options);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, options);\n};\nconst addSourceToParent = async (context, source, childName, parent, options) => {\n const sourceBlock = await context.repo.blocks.get(source.cid);\n const {node, cid, size} = await addLink.addLink(context, {\n parentCid: parent.cid,\n size: sourceBlock.length,\n cid: source.cid,\n name: childName,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold\n });\n parent.node = node;\n parent.cid = cid;\n parent.size = size;\n return parent;\n};\n\nexports.createCp = createCp;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar createNode = require('./utils/create-node.js');\nvar toPathComponents = require('./utils/to-path-components.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar updateTree = require('./utils/update-tree.js');\nvar addLink = require('./utils/add-link.js');\nvar withMfsRoot = require('./utils/with-mfs-root.js');\nvar mergeOpts = require('merge-options');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:mkdir');\nconst defaultOptions = {\n parents: false,\n hashAlg: 'sha2-256',\n cidVersion: 0,\n shardSplitThreshold: 1000,\n flush: true\n};\nfunction createMkdir(context) {\n async function mfsMkdir(path, options = {}) {\n const opts = mergeOptions(defaultOptions, options);\n if (!path) {\n throw new Error('no path given to Mkdir');\n }\n path = path.trim();\n if (path === '/') {\n if (opts.parents) {\n return;\n }\n throw errCode__default['default'](new Error('cannot create directory \\'/\\': Already exists'), 'ERR_INVALID_PATH');\n }\n if (path.substring(0, 1) !== '/') {\n throw errCode__default['default'](new Error('paths must start with a leading slash'), 'ERR_INVALID_PATH');\n }\n log(`Creating ${ path }`);\n const pathComponents = toPathComponents.toPathComponents(path);\n if (pathComponents[0] === 'ipfs') {\n throw errCode__default['default'](new Error('path cannot have the prefix \\'ipfs\\''), 'ERR_INVALID_PATH');\n }\n const root = await withMfsRoot.loadMfsRoot(context, opts);\n let parent;\n const trail = [];\n const emptyDir = await createNode.createNode(context, 'directory', opts);\n for (let i = 0; i <= pathComponents.length; i++) {\n const subPathComponents = pathComponents.slice(0, i);\n const subPath = `/ipfs/${ root }/${ subPathComponents.join('/') }`;\n try {\n parent = await ipfsUnixfsExporter.exporter(subPath, context.repo.blocks);\n if (parent.type !== 'file' && parent.type !== 'directory') {\n throw errCode__default['default'](new Error(`${ path } was not a UnixFS node`), 'ERR_NOT_UNIXFS');\n }\n if (i === pathComponents.length) {\n if (opts.parents) {\n return;\n }\n throw errCode__default['default'](new Error('file already exists'), 'ERR_ALREADY_EXISTS');\n }\n trail.push({\n name: parent.name,\n cid: parent.cid\n });\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n if (i < pathComponents.length && !opts.parents) {\n throw errCode__default['default'](new Error(`Intermediate directory path ${ subPath } does not exist, use the -p flag to create it`), 'ERR_NOT_FOUND');\n }\n await addEmptyDir(context, subPathComponents[subPathComponents.length - 1], emptyDir, trail[trail.length - 1], trail, opts);\n } else {\n throw err;\n }\n }\n }\n const newRootCid = await updateTree.updateTree(context, trail, opts);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, opts);\n }\n return withTimeoutOption.withTimeoutOption(mfsMkdir);\n}\nconst addEmptyDir = async (context, childName, emptyDir, parent, trail, options) => {\n log(`Adding empty dir called ${ childName } to ${ parent.cid }`);\n const result = await addLink.addLink(context, {\n parent: parent.node,\n parentCid: parent.cid,\n size: 0,\n cid: emptyDir.cid,\n name: childName,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold\n });\n trail[trail.length - 1].cid = result.cid;\n trail.push({\n name: childName,\n cid: emptyDir.cid\n });\n};\n\nexports.createMkdir = createMkdir;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nasync function createNode(context, type, options) {\n const metadata = new ipfsUnixfs.UnixFS({\n type,\n mode: options.mode,\n mtime: options.mtime\n });\n const hasher = await context.hashers.getHasher(options.hashAlg);\n const node = {\n Data: metadata.marshal(),\n Links: []\n };\n const buf = dagPB__namespace.encode(node);\n const hash = await hasher.digest(buf);\n const cid$1 = cid.CID.create(options.cidVersion, dagPB__namespace.code, hash);\n if (options.flush) {\n await context.repo.blocks.put(cid$1, buf);\n }\n return {\n cid: cid$1,\n node\n };\n}\n\nexports.createNode = createNode;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar removeLink = require('./utils/remove-link.js');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar toTrail = require('./utils/to-trail.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar mergeOpts = require('merge-options');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst defaultOptions = {\n recursive: false,\n cidVersion: 0,\n hashAlg: 'sha2-256',\n flush: true,\n shardSplitThreshold: 1000\n};\nfunction createRm(context) {\n async function mfsRm(paths, opts = {}) {\n const options = mergeOptions(defaultOptions, opts);\n if (!Array.isArray(paths)) {\n paths = [paths];\n }\n const sources = await Promise.all(paths.map(path => toMfsPath.toMfsPath(context, path, options)));\n if (!sources.length) {\n throw errCode__default['default'](new Error('Please supply at least one path to remove'), 'ERR_INVALID_PARAMS');\n }\n sources.forEach(source => {\n if (source.path === '/') {\n throw errCode__default['default'](new Error('Cannot delete root'), 'ERR_INVALID_PARAMS');\n }\n });\n for (const source of sources) {\n await removePath(context, source.path, options);\n }\n }\n return withTimeoutOption.withTimeoutOption(mfsRm);\n}\nconst removePath = async (context, path, options) => {\n const mfsPath = await toMfsPath.toMfsPath(context, path, options);\n const trail = await toTrail.toTrail(context, mfsPath.mfsPath);\n const child = trail[trail.length - 1];\n trail.pop();\n const parent = trail[trail.length - 1];\n if (!parent) {\n throw errCode__default['default'](new Error(`${ path } does not exist`), 'ERR_NOT_FOUND');\n }\n if (child.type === 'directory' && !options.recursive) {\n throw errCode__default['default'](new Error(`${ path } is a directory, use -r to remove directories`), 'ERR_WAS_DIR');\n }\n const {cid} = await removeLink.removeLink(context, {\n parentCid: parent.cid,\n name: child.name,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold\n });\n parent.cid = cid;\n const newRootCid = await updateTree.updateTree(context, trail, options);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, options);\n};\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar debug = require('debug');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar hamtUtils = require('./hamt-utils.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst log = debug__default['default']('ipfs:mfs:core:utils:remove-link');\nasync function removeLink(context, options) {\n let parent = options.parent;\n if (options.parentCid) {\n const parentCid = cid.CID.asCID(options.parentCid);\n if (parentCid === null) {\n throw errCode__default['default'](new Error('Invalid CID passed to removeLink'), 'EINVALIDPARENTCID');\n }\n log(`Loading parent node ${ parentCid }`);\n const block = await context.repo.blocks.get(parentCid);\n parent = dagPB__namespace.decode(block);\n }\n if (!parent) {\n throw errCode__default['default'](new Error('No parent node or CID passed to removeLink'), 'EINVALIDPARENT');\n }\n if (!options.name) {\n throw errCode__default['default'](new Error('No child name passed to removeLink'), 'EINVALIDCHILDNAME');\n }\n if (!parent.Data) {\n throw errCode__default['default'](new Error('Parent node had no data'), 'ERR_INVALID_NODE');\n }\n const meta = ipfsUnixfs.UnixFS.unmarshal(parent.Data);\n if (meta.type === 'hamt-sharded-directory') {\n log(`Removing ${ options.name } from sharded directory`);\n return removeFromShardedDirectory(context, {\n ...options,\n parent\n });\n }\n log(`Removing link ${ options.name } regular directory`);\n return removeFromDirectory(context, {\n ...options,\n parent\n });\n}\nconst removeFromDirectory = async (context, options) => {\n options.parent.Links = options.parent.Links.filter(link => {\n return link.Name !== options.name;\n });\n const parentBlock = await dagPB__namespace.encode(options.parent);\n const hasher = await context.hashers.getHasher(options.hashAlg);\n const hash = await hasher.digest(parentBlock);\n const parentCid = cid.CID.create(options.cidVersion, dagPB__namespace.code, hash);\n await context.repo.blocks.put(parentCid, parentBlock);\n log(`Updated regular directory ${ parentCid }`);\n return {\n node: options.parent,\n cid: parentCid\n };\n};\nconst removeFromShardedDirectory = async (context, options) => {\n const {rootBucket, path} = await hamtUtils.generatePath(context, options.name, options.parent);\n await rootBucket.del(options.name);\n const {node} = await updateShard(context, path, options.name, options);\n return hamtUtils.updateHamtDirectory(context, node.Links, rootBucket, options);\n};\nconst updateShard = async (context, positions, name, options) => {\n const last = positions.pop();\n if (!last) {\n throw errCode__default['default'](new Error('Could not find parent'), 'EINVALIDPARENT');\n }\n const {bucket, prefix, node} = last;\n if (!node) {\n throw errCode__default['default'](new Error('Could not find parent'), 'EINVALIDPARENT');\n }\n const link = node.Links.find(link => (link.Name || '').substring(0, 2) === prefix);\n if (!link) {\n throw errCode__default['default'](new Error(`No link found with prefix ${ prefix } for file ${ name }`), 'ERR_NOT_FOUND');\n }\n if (link.Name === `${ prefix }${ name }`) {\n log(`Removing existing link ${ link.Name }`);\n const links = node.Links.filter(nodeLink => {\n return nodeLink.Name !== link.Name;\n });\n await bucket.del(name);\n return hamtUtils.updateHamtDirectory(context, links, bucket, options);\n }\n log(`Descending into sub-shard ${ link.Name } for ${ prefix }${ name }`);\n const result = await updateShard(context, positions, name, options);\n let cid = result.cid;\n let size = result.size;\n let newName = prefix;\n if (result.node.Links.length === 1) {\n log(`Removing subshard for ${ prefix }`);\n const link = result.node.Links[0];\n newName = `${ prefix }${ (link.Name || '').substring(2) }`;\n cid = link.Hash;\n size = link.Tsize || 0;\n }\n log(`Updating shard ${ prefix } with name ${ newName }`);\n return updateShardParent(context, bucket, node, prefix, newName, size, cid, options);\n};\nconst updateShardParent = (context, bucket, parent, oldName, newName, size, cid, options) => {\n const parentLinks = parent.Links.filter(link => {\n return link.Name !== oldName;\n });\n parentLinks.push({\n Name: newName,\n Tsize: size,\n Hash: cid\n });\n return hamtUtils.updateHamtDirectory(context, parentLinks, bucket, options);\n};\n\nexports.removeLink = removeLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar stat = require('./stat.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar mergeOpts = require('merge-options');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst defaultOptions = {};\nfunction createFlush(context) {\n async function mfsFlush(path, options = {}) {\n options = mergeOptions(defaultOptions, options);\n const {cid} = await stat.createStat(context)(path, options);\n return cid;\n }\n return withTimeoutOption.withTimeoutOption(mfsFlush);\n}\n\nexports.createFlush = createFlush;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cp = require('./cp.js');\nvar rm = require('./rm.js');\nvar mergeOpts = require('merge-options');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst defaultOptions = {\n parents: false,\n flush: true,\n cidVersion: 0,\n hashAlg: 'sha2-256',\n shardSplitThreshold: 1000\n};\nfunction createMv(context) {\n async function mfsMv(from, to, options = {}) {\n const opts = mergeOptions(defaultOptions, options);\n await cp.createCp(context)(from, to, opts);\n await rm.createRm(context)(from, {\n ...opts,\n recursive: true\n });\n }\n return withTimeoutOption.withTimeoutOption(mfsMv);\n}\n\nexports.createMv = createMv;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar mergeOpts = require('merge-options');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar toTrail = require('./utils/to-trail.js');\nvar addLink = require('./utils/add-link.js');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:touch');\nconst defaultOptions = {\n flush: true,\n shardSplitThreshold: 1000,\n cidVersion: 0,\n hashAlg: 'sha2-256'\n};\nfunction createTouch(context) {\n async function mfsTouch(path, options = {}) {\n const settings = mergeOptions(defaultOptions, options);\n settings.mtime = settings.mtime || new Date();\n log(`Touching ${ path } mtime: ${ settings.mtime }`);\n const {cid: cid$1, mfsDirectory, name, exists} = await toMfsPath.toMfsPath(context, path, settings);\n const hashAlg = options.hashAlg || defaultOptions.hashAlg;\n const hasher = await context.hashers.getHasher(hashAlg);\n let updatedBlock;\n let updatedCid;\n let cidVersion = settings.cidVersion;\n if (!exists) {\n const metadata = new ipfsUnixfs.UnixFS({\n type: 'file',\n mtime: settings.mtime\n });\n updatedBlock = dagPB__namespace.encode({\n Data: metadata.marshal(),\n Links: []\n });\n const hash = await hasher.digest(updatedBlock);\n updatedCid = cid.CID.create(settings.cidVersion, dagPB__namespace.code, hash);\n if (settings.flush) {\n await context.repo.blocks.put(updatedCid, updatedBlock);\n }\n } else {\n if (cid$1.code !== dagPB__namespace.code) {\n throw errCode__default['default'](new Error(`${ path } was not a UnixFS node`), 'ERR_NOT_UNIXFS');\n }\n cidVersion = cid$1.version;\n const block = await context.repo.blocks.get(cid$1);\n const node = dagPB__namespace.decode(block);\n if (!node.Data) {\n throw errCode__default['default'](new Error(`${ path } had no data`), 'ERR_INVALID_NODE');\n }\n const metadata = ipfsUnixfs.UnixFS.unmarshal(node.Data);\n metadata.mtime = settings.mtime;\n updatedBlock = dagPB__namespace.encode({\n Data: metadata.marshal(),\n Links: node.Links\n });\n const hash = await hasher.digest(updatedBlock);\n updatedCid = cid.CID.create(settings.cidVersion, dagPB__namespace.code, hash);\n if (settings.flush) {\n await context.repo.blocks.put(updatedCid, updatedBlock);\n }\n }\n const trail = await toTrail.toTrail(context, mfsDirectory);\n const parent = trail[trail.length - 1];\n const parentCid = parent.cid;\n const parentBlock = await context.repo.blocks.get(parentCid);\n const parentNode = dagPB__namespace.decode(parentBlock);\n const result = await addLink.addLink(context, {\n parent: parentNode,\n name: name,\n cid: updatedCid,\n size: updatedBlock.length,\n flush: settings.flush,\n shardSplitThreshold: settings.shardSplitThreshold,\n hashAlg: settings.hashAlg,\n cidVersion\n });\n parent.cid = result.cid;\n const newRootCid = await updateTree.updateTree(context, trail, settings);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, settings);\n }\n return withTimeoutOption.withTimeoutOption(mfsTouch);\n}\n\nexports.createTouch = createTouch;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar mergeOpts = require('merge-options');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar errCode = require('err-code');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst defaultOptions = {\n offset: 0,\n length: Infinity\n};\nfunction createRead(context) {\n function mfsRead(path, options = {}) {\n options = mergeOptions(defaultOptions, options);\n return {\n [Symbol.asyncIterator]: async function* read() {\n const mfsPath = await toMfsPath.toMfsPath(context, path, options);\n const result = await ipfsUnixfsExporter.exporter(mfsPath.mfsPath, context.repo.blocks);\n if (result.type !== 'file') {\n throw errCode__default['default'](new Error(`${ path } was not a file`), 'ERR_NOT_FILE');\n }\n if (!result.content) {\n throw errCode__default['default'](new Error(`Could not load content stream from ${ path }`), 'ERR_NO_CONTENT');\n }\n for await (const buf of result.content({\n offset: options.offset,\n length: options.length\n })) {\n yield buf;\n }\n }\n };\n }\n return withTimeoutOption.withTimeoutOption(mfsRead);\n}\n\nexports.createRead = createRead;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar ipfsUnixfsImporter = require('ipfs-unixfs-importer');\nvar dagPB = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\nvar stat = require('./stat.js');\nvar mkdir = require('./mkdir.js');\nvar addLink = require('./utils/add-link.js');\nvar mergeOpts = require('merge-options');\nvar createLock = require('./utils/create-lock.js');\nvar toAsyncIterator = require('./utils/to-async-iterator.js');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar toPathComponents = require('./utils/to-path-components.js');\nvar toTrail = require('./utils/to-trail.js');\nvar updateTree = require('./utils/update-tree.js');\nvar updateMfsRoot = require('./utils/update-mfs-root.js');\nvar errCode = require('err-code');\nvar utils = require('../../utils.js');\nvar last = require('it-last');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar ipfsUnixfs = require('ipfs-unixfs');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:mfs:write');\nconst defaultOptions = {\n offset: 0,\n length: Infinity,\n create: false,\n truncate: false,\n rawLeaves: false,\n reduceSingleLeafToSelf: false,\n cidVersion: 0,\n hashAlg: 'sha2-256',\n parents: false,\n progress: (bytes, path) => {\n },\n strategy: 'trickle',\n flush: true,\n leafType: 'raw',\n shardSplitThreshold: 1000\n};\nfunction createWrite(context) {\n async function mfsWrite(path, content, opts = {}) {\n const options = mergeOptions(defaultOptions, opts);\n let source;\n let destination;\n let parent;\n log('Reading source, destination and parent');\n await createLock.createLock().readLock(async () => {\n source = await toAsyncIterator.toAsyncIterator(content);\n destination = await toMfsPath.toMfsPath(context, path, options);\n parent = await toMfsPath.toMfsPath(context, destination.mfsDirectory, options);\n })();\n log('Read source, destination and parent');\n if (!options.parents && !parent.exists) {\n throw errCode__default['default'](new Error('directory does not exist'), 'ERR_NO_EXIST');\n }\n if (source == null) {\n throw errCode__default['default'](new Error('could not create source'), 'ERR_NO_SOURCE');\n }\n if (destination == null) {\n throw errCode__default['default'](new Error('could not create destination'), 'ERR_NO_DESTINATION');\n }\n if (!options.create && !destination.exists) {\n throw errCode__default['default'](new Error('file does not exist'), 'ERR_NO_EXIST');\n }\n if (destination.entryType !== 'file') {\n throw errCode__default['default'](new Error('not a file'), 'ERR_NOT_A_FILE');\n }\n return updateOrImport(context, path, source, destination, options);\n }\n return withTimeoutOption.withTimeoutOption(mfsWrite);\n}\nconst updateOrImport = async (context, path, source, destination, options) => {\n const child = await write(context, source, destination, options);\n await createLock.createLock().writeLock(async () => {\n const pathComponents = toPathComponents.toPathComponents(path);\n const fileName = pathComponents.pop();\n if (fileName == null) {\n throw errCode__default['default'](new Error('source does not exist'), 'ERR_NO_EXIST');\n }\n let parentExists = false;\n try {\n await stat.createStat(context)(`/${ pathComponents.join('/') }`, options);\n parentExists = true;\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n }\n if (!parentExists) {\n await mkdir.createMkdir(context)(`/${ pathComponents.join('/') }`, options);\n }\n const updatedPath = await toMfsPath.toMfsPath(context, path, options);\n const trail = await toTrail.toTrail(context, updatedPath.mfsDirectory);\n const parent = trail[trail.length - 1];\n if (!parent) {\n throw errCode__default['default'](new Error('directory does not exist'), 'ERR_NO_EXIST');\n }\n if (!parent.type || !parent.type.includes('directory')) {\n throw errCode__default['default'](new Error(`cannot write to ${ parent.name }: Not a directory`), 'ERR_NOT_A_DIRECTORY');\n }\n const parentBlock = await context.repo.blocks.get(parent.cid);\n const parentNode = dagPB.decode(parentBlock);\n const result = await addLink.addLink(context, {\n parent: parentNode,\n name: fileName,\n cid: child.cid,\n size: child.size,\n flush: options.flush,\n shardSplitThreshold: options.shardSplitThreshold,\n hashAlg: options.hashAlg,\n cidVersion: options.cidVersion\n });\n parent.cid = result.cid;\n const newRootCid = await updateTree.updateTree(context, trail, options);\n await updateMfsRoot.updateMfsRoot(context, newRootCid, options);\n })();\n};\nconst write = async (context, source, destination, options) => {\n if (destination.exists) {\n log(`Overwriting file ${ destination.cid } offset ${ options.offset } length ${ options.length }`);\n } else {\n log(`Writing file offset ${ options.offset } length ${ options.length }`);\n }\n const sources = [];\n if (options.offset > 0) {\n if (destination.unixfs) {\n log(`Writing first ${ options.offset } bytes of original file`);\n sources.push(() => {\n return destination.content({\n offset: 0,\n length: options.offset\n });\n });\n if (destination.unixfs.fileSize() < options.offset) {\n const extra = options.offset - destination.unixfs.fileSize();\n log(`Writing zeros for extra ${ extra } bytes`);\n sources.push(asyncZeroes(extra));\n }\n } else {\n log(`Writing zeros for first ${ options.offset } bytes`);\n sources.push(asyncZeroes(options.offset));\n }\n }\n sources.push(limitAsyncStreamBytes(source, options.length));\n const content = countBytesStreamed(catAsyncIterators(sources), bytesWritten => {\n if (destination.unixfs && !options.truncate) {\n const fileSize = destination.unixfs.fileSize();\n if (fileSize > bytesWritten) {\n log(`Writing last ${ fileSize - bytesWritten } of ${ fileSize } bytes from original file starting at offset ${ bytesWritten }`);\n return destination.content({ offset: bytesWritten });\n } else {\n log('Not writing last bytes from original file');\n }\n }\n return {\n [Symbol.asyncIterator]: async function* () {\n }\n };\n });\n let mode;\n if (options.mode !== undefined && options.mode !== null) {\n mode = ipfsUnixfs.parseMode(options.mode);\n } else if (destination && destination.unixfs) {\n mode = destination.unixfs.mode;\n }\n let mtime;\n if (options.mtime != null) {\n mtime = ipfsUnixfs.parseMtime(options.mtime);\n } else if (destination && destination.unixfs) {\n mtime = destination.unixfs.mtime;\n }\n let hasher;\n switch (options.hashAlg) {\n case 'sha2-256':\n hasher = sha2.sha256;\n break;\n case 'sha2-512':\n hasher = sha2.sha512;\n break;\n default:\n throw new Error(`TODO vmx 2021-03-31: Proper error message for unsupported hash algorithms like ${ options.hashAlg }`);\n }\n const result = await last__default['default'](ipfsUnixfsImporter.importer([{\n content: content,\n mode,\n mtime\n }], context.repo.blocks, {\n progress: options.progress,\n hasher,\n cidVersion: options.cidVersion,\n strategy: options.strategy,\n rawLeaves: options.rawLeaves,\n reduceSingleLeafToSelf: options.reduceSingleLeafToSelf,\n leafType: options.leafType\n }));\n if (!result) {\n throw errCode__default['default'](new Error(`cannot write to ${ parent.name }`), 'ERR_COULD_NOT_WRITE');\n }\n log(`Wrote ${ result.cid }`);\n return {\n cid: result.cid,\n size: result.size\n };\n};\nconst limitAsyncStreamBytes = (stream, limit) => {\n return async function* _limitAsyncStreamBytes() {\n let emitted = 0;\n for await (const buf of stream) {\n emitted += buf.length;\n if (emitted > limit) {\n yield buf.slice(0, limit - emitted);\n return;\n }\n yield buf;\n }\n };\n};\nconst asyncZeroes = (count, chunkSize = utils.MFS_MAX_CHUNK_SIZE) => {\n const buf = new Uint8Array(chunkSize);\n async function* _asyncZeroes() {\n while (true) {\n yield buf.slice();\n }\n }\n return limitAsyncStreamBytes(_asyncZeroes(), count);\n};\nconst catAsyncIterators = async function* (sources) {\n for (let i = 0; i < sources.length; i++) {\n yield* sources[i]();\n }\n};\nconst countBytesStreamed = async function* (source, notify) {\n let wrote = 0;\n for await (const buf of source) {\n wrote += buf.length;\n yield buf;\n }\n for await (const buf of notify(wrote)) {\n wrote += buf.length;\n yield buf;\n }\n};\n\nexports.createWrite = createWrite;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar utils = require('../../../utils.js');\nvar fromString = require('uint8arrays/from-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:mfs:utils:to-async-iterator');\nfunction toAsyncIterator(content) {\n if (!content) {\n throw errCode__default['default'](new Error('paths must start with a leading slash'), 'ERR_INVALID_PATH');\n }\n if (typeof content === 'string' || content instanceof String) {\n log('Content was a string');\n content = fromString.fromString(content.toString());\n }\n if (content.length) {\n log('Content was array-like');\n return {\n [Symbol.asyncIterator]: function* bufferContent() {\n yield content;\n }\n };\n }\n if (content[Symbol.asyncIterator]) {\n log('Content was an async iterator');\n return content;\n }\n if (content[Symbol.iterator]) {\n log('Content was an iterator');\n return content;\n }\n if (global.Blob && content instanceof global.Blob) {\n log('Content was an HTML5 Blob');\n let index = 0;\n const iterator = {\n next: () => {\n if (index > content.size) {\n return { done: true };\n }\n return new Promise((resolve, reject) => {\n const chunk = content.slice(index, utils.MFS_MAX_CHUNK_SIZE);\n index += utils.MFS_MAX_CHUNK_SIZE;\n const reader = new global.FileReader();\n const handleLoad = ev => {\n reader.removeEventListener('loadend', handleLoad, false);\n if (ev.error) {\n return reject(ev.error);\n }\n resolve({\n done: false,\n value: new Uint8Array(reader.result)\n });\n };\n reader.addEventListener('loadend', handleLoad);\n reader.readAsArrayBuffer(chunk);\n });\n }\n };\n return {\n [Symbol.asyncIterator]: () => {\n return iterator;\n }\n };\n }\n throw errCode__default['default'](new Error(`Don't know how to convert ${ content } into an async iterator`), 'ERR_INVALID_PARAMS');\n}\n\nexports.toAsyncIterator = toAsyncIterator;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsUnixfsExporter = require('ipfs-unixfs-exporter');\nvar toMfsPath = require('./utils/to-mfs-path.js');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar map = require('it-map');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\n\nconst toOutput = fsEntry => {\n const output = {\n cid: fsEntry.cid,\n name: fsEntry.name,\n type: fsEntry.type === 'directory' ? 'directory' : 'file',\n size: fsEntry.size\n };\n if (fsEntry.type === 'file' || fsEntry.type === 'directory') {\n output.mode = fsEntry.unixfs.mode;\n output.mtime = fsEntry.unixfs.mtime;\n }\n return output;\n};\nfunction createLs(context) {\n async function* mfsLs(path, options = {}) {\n const mfsPath = await toMfsPath.toMfsPath(context, path, options);\n const fsEntry = await ipfsUnixfsExporter.exporter(mfsPath.mfsPath, context.repo.blocks);\n if (fsEntry.type === 'directory') {\n yield* map__default['default'](fsEntry.content(options), toOutput);\n return;\n }\n yield toOutput(fsEntry);\n }\n return withTimeoutOption.withTimeoutOption(mfsLs);\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _export = require('./export.js');\nvar gen = require('./gen.js');\nvar _import = require('./import.js');\nvar info = require('./info.js');\nvar list = require('./list.js');\nvar rename = require('./rename.js');\nvar rm = require('./rm.js');\n\nclass KeyAPI {\n constructor({keychain}) {\n this.gen = gen.createGen({ keychain });\n this.list = list.createList({ keychain });\n this.rm = rm.createRm({ keychain });\n this.rename = rename.createRename({ keychain });\n this.export = _export.createExport({ keychain });\n this.import = _import.createImport({ keychain });\n this.info = info.createInfo({ keychain });\n }\n}\n\nexports.KeyAPI = KeyAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createExport({keychain}) {\n const exportKey = (name, password) => keychain.exportKey(name, password);\n return withTimeoutOption.withTimeoutOption(exportKey);\n}\n\nexports.createExport = createExport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nconst DEFAULT_KEY_TYPE = 'ed25519';\nconst DEFAULT_KEY_SIZE = 2048;\nfunction createGen({keychain}) {\n const gen = (name, options = {\n type: DEFAULT_KEY_TYPE,\n size: DEFAULT_KEY_SIZE\n }) => {\n return keychain.createKey(name, options.type || DEFAULT_KEY_TYPE, options.size || DEFAULT_KEY_SIZE);\n };\n return withTimeoutOption.withTimeoutOption(gen);\n}\n\nexports.createGen = createGen;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createImport({keychain}) {\n const importKey = (name, pem, password) => {\n return keychain.importKey(name, pem, password);\n };\n return withTimeoutOption.withTimeoutOption(importKey);\n}\n\nexports.createImport = createImport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createInfo({keychain}) {\n const info = name => keychain.findKeyByName(name);\n return withTimeoutOption.withTimeoutOption(info);\n}\n\nexports.createInfo = createInfo;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createList({keychain}) {\n const list = () => keychain.listKeys();\n return withTimeoutOption.withTimeoutOption(list);\n}\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createRename({keychain}) {\n const rename = async (oldName, newName) => {\n const key = await keychain.renameKey(oldName, newName);\n return {\n was: oldName,\n now: key.name,\n id: key.id,\n overwrite: false\n };\n };\n return withTimeoutOption.withTimeoutOption(rename);\n}\n\nexports.createRename = createRename;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createRm({keychain}) {\n const rm = name => keychain.removeKey(name);\n return withTimeoutOption.withTimeoutOption(rm);\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar data = require('./data.js');\nvar get = require('./get.js');\nvar links = require('./links.js');\nvar _new = require('./new.js');\nvar put = require('./put.js');\nvar stat = require('./stat.js');\nvar index = require('./patch/index.js');\n\nclass ObjectAPI {\n constructor({repo, codecs, preload}) {\n this.data = data.createData({\n repo,\n preload\n });\n this.get = get.createGet({\n repo,\n preload\n });\n this.links = links.createLinks({\n repo,\n codecs\n });\n this.new = _new.createNew({\n repo,\n preload\n });\n this.put = put.createPut({\n repo,\n preload\n });\n this.stat = stat.createStat({\n repo,\n preload\n });\n this.patch = new index.ObjectPatchAPI({\n repo,\n preload\n });\n }\n}\n\nexports.ObjectAPI = ObjectAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('./get.js');\n\nfunction createData({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n async function data(multihash, options = {}) {\n const node = await get$1(multihash, options);\n return node.Data || new Uint8Array(0);\n }\n return withTimeoutOption.withTimeoutOption(data);\n}\n\nexports.createData = createData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nfunction createGet({repo, preload}) {\n async function get(cid, options = {}) {\n if (options.preload !== false) {\n preload(cid);\n }\n const block = await repo.blocks.get(cid, options);\n return dagPB__namespace.decode(block);\n }\n return withTimeoutOption.withTimeoutOption(get);\n}\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar dagCBOR = require('@ipld/dag-cbor');\nvar raw = require('multiformats/codecs/raw');\nvar cid = require('multiformats/cid');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar dagCBOR__namespace = /*#__PURE__*/_interopNamespace(dagCBOR);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\n\nfunction findLinks(node, links = []) {\n for (const key in node) {\n const val = node[key];\n if (key === '/' && Object.keys(node).length === 1) {\n try {\n links.push({\n Name: '',\n Tsize: 0,\n Hash: cid.CID.parse(val)\n });\n continue;\n } catch (_) {\n }\n }\n const cid$1 = cid.CID.asCID(val);\n if (cid$1) {\n links.push({\n Name: '',\n Tsize: 0,\n Hash: cid$1\n });\n continue;\n }\n if (Array.isArray(val)) {\n findLinks(val, links);\n }\n if (val && typeof val === 'object') {\n findLinks(val, links);\n }\n }\n return links;\n}\nfunction createLinks({repo, codecs}) {\n async function links(cid, options = {}) {\n const codec = await codecs.getCodec(cid.code);\n const block = await repo.blocks.get(cid, options);\n const node = codec.decode(block);\n if (cid.code === raw__namespace.code) {\n return [];\n }\n if (cid.code === dagPB__namespace.code) {\n return node.Links;\n }\n if (cid.code === dagCBOR__namespace.code) {\n return findLinks(node);\n }\n throw new Error(`Cannot resolve links from codec ${ cid.code }`);\n }\n return withTimeoutOption.withTimeoutOption(links);\n}\n\nexports.createLinks = createLinks;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar sha2 = require('multiformats/hashes/sha2');\nvar ipfsUnixfs = require('ipfs-unixfs');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar cid = require('multiformats/cid');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nfunction createNew({repo, preload}) {\n async function _new(options = {}) {\n let data;\n if (options.template) {\n if (options.template === 'unixfs-dir') {\n data = new ipfsUnixfs.UnixFS({ type: 'directory' }).marshal();\n } else {\n throw new Error('unknown template');\n }\n }\n const buf = dagPB__namespace.encode({\n Data: data,\n Links: []\n });\n const hash = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(hash);\n await repo.blocks.put(cid$1, buf, { signal: options.signal });\n if (options.preload !== false) {\n preload(cid$1);\n }\n return cid$1;\n }\n return withTimeoutOption.withTimeoutOption(_new);\n}\n\nexports.createNew = createNew;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar cid = require('multiformats/cid');\nvar sha2 = require('multiformats/hashes/sha2');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nfunction createPut({repo, preload}) {\n async function put(obj, options = {}) {\n const release = await repo.gcLock.readLock();\n try {\n const buf = dagPB__namespace.encode(obj);\n const hash = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(hash);\n await repo.blocks.put(cid$1, buf, { signal: options.signal });\n if (options.preload !== false) {\n preload(cid$1);\n }\n if (options.pin) {\n await repo.pins.pinRecursively(cid$1, { signal: options.signal });\n }\n return cid$1;\n } finally {\n release();\n }\n }\n return withTimeoutOption.withTimeoutOption(put);\n}\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar dagPB = require('@ipld/dag-pb');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('./get.js');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\n\nfunction createStat({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n async function stat(cid, options = {}) {\n const node = await get$1(cid, options);\n const serialized = dagPB__namespace.encode(node);\n const blockSize = serialized.length;\n const linkLength = node.Links.reduce((a, l) => a + (l.Tsize || 0), 0);\n return {\n Hash: cid,\n NumLinks: node.Links.length,\n BlockSize: blockSize,\n LinksSize: blockSize - (node.Data || []).length,\n DataSize: (node.Data || []).length,\n CumulativeSize: blockSize + linkLength\n };\n }\n return withTimeoutOption.withTimeoutOption(stat);\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addLink = require('./add-link.js');\nvar appendData = require('./append-data.js');\nvar rmLink = require('./rm-link.js');\nvar setData = require('./set-data.js');\n\nclass ObjectPatchAPI {\n constructor({repo, preload}) {\n this.addLink = addLink.createAddLink({\n repo,\n preload\n });\n this.appendData = appendData.createAppendData({\n repo,\n preload\n });\n this.rmLink = rmLink.createRmLink({\n repo,\n preload\n });\n this.setData = setData.createSetData({\n repo,\n preload\n });\n }\n}\n\nexports.ObjectPatchAPI = ObjectPatchAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('../get.js');\nvar put = require('../put.js');\n\nfunction createAddLink({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n const put$1 = put.createPut({\n repo,\n preload\n });\n async function addLink(cid, link, options = {}) {\n const node = await get$1(cid, options);\n return put$1({\n ...node,\n Links: node.Links.concat([link])\n }, options);\n }\n return withTimeoutOption.withTimeoutOption(addLink);\n}\n\nexports.createAddLink = createAddLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar concat = require('uint8arrays/concat');\nvar get = require('../get.js');\nvar put = require('../put.js');\n\nfunction createAppendData({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n const put$1 = put.createPut({\n repo,\n preload\n });\n async function appendData(cid, data, options = {}) {\n const node = await get$1(cid, options);\n const newData = concat.concat([\n node.Data || [],\n data\n ]);\n return put$1({\n ...node,\n Data: newData\n }, options);\n }\n return withTimeoutOption.withTimeoutOption(appendData);\n}\n\nexports.createAppendData = createAppendData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('../get.js');\nvar put = require('../put.js');\n\nfunction createRmLink({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n const put$1 = put.createPut({\n repo,\n preload\n });\n async function rmLink(multihash, linkRef, options = {}) {\n const node = await get$1(multihash, options);\n const name = (typeof linkRef === 'string' ? linkRef : linkRef.Name) || '';\n node.Links = node.Links.filter(l => l.Name !== name);\n return put$1(node, options);\n }\n return withTimeoutOption.withTimeoutOption(rmLink);\n}\n\nexports.createRmLink = createRmLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar get = require('../get.js');\nvar put = require('../put.js');\n\nfunction createSetData({repo, preload}) {\n const get$1 = get.createGet({\n repo,\n preload\n });\n const put$1 = put.createPut({\n repo,\n preload\n });\n async function setData(cid, data, options = {}) {\n const node = await get$1(cid, options);\n return put$1({\n ...node,\n Data: data\n }, options);\n }\n return withTimeoutOption.withTimeoutOption(setData);\n}\n\nexports.createSetData = createSetData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar gc = require('./gc.js');\nvar stat = require('./stat.js');\nvar version = require('./version.js');\n\nclass RepoAPI {\n constructor({repo, hashers}) {\n this.gc = gc.createGc({\n repo,\n hashers\n });\n this.stat = stat.createStat({ repo });\n this.version = version.createVersion({ repo });\n this.setApiAddr = addr => repo.apiAddr.set(addr);\n }\n}\n\nexports.RepoAPI = RepoAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar withMfsRoot = require('../files/utils/with-mfs-root.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs:repo:gc');\nfunction createGc({repo, hashers}) {\n async function* gc(options = {}) {\n const start = Date.now();\n let mfsRootCid;\n try {\n mfsRootCid = await withMfsRoot.loadMfsRoot({\n repo,\n hashers\n }, options);\n await repo.pins.pinRecursively(mfsRootCid);\n yield* repo.gc();\n } finally {\n if (mfsRootCid) {\n await repo.pins.unpin(mfsRootCid);\n }\n }\n log(`Complete (${ Date.now() - start }ms)`);\n }\n return withTimeoutOption.withTimeoutOption(gc);\n}\n\nexports.createGc = createGc;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createStat({repo}) {\n async function stat(options = {}) {\n const stats = await repo.stat();\n return {\n numObjects: BigInt(stats.numObjects.toString()),\n repoSize: BigInt(stats.repoSize.toString()),\n repoPath: stats.repoPath,\n version: `${ stats.version }`,\n storageMax: BigInt(stats.storageMax.toString())\n };\n }\n return withTimeoutOption.withTimeoutOption(stat);\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar constants = require('ipfs-repo/constants');\n\nfunction createVersion({repo}) {\n async function version(options = {}) {\n try {\n await repo._checkInitialized(options);\n } catch (err) {\n const match = [\n /Key not found in database \\[\\/version\\]/,\n /ENOENT/,\n /repo is not initialized yet/\n ].some(m => {\n return m.test(err.message);\n });\n if (match) {\n return constants.repoVersion;\n }\n throw err;\n }\n return repo.version.get();\n }\n return withTimeoutOption.withTimeoutOption(version);\n}\n\nexports.createVersion = createVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst repoVersion = 11;\n\nexports.repoVersion = repoVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bw = require('./bw.js');\nvar stat = require('../repo/stat.js');\nvar stat$1 = require('../bitswap/stat.js');\n\nclass StatsAPI {\n constructor({repo, network}) {\n this.repo = stat.createStat({ repo });\n this.bw = bw.createBw({ network });\n this.bitswap = stat$1.createStat({ network });\n }\n}\n\nexports.StatsAPI = StatsAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar parseDuration = require('parse-duration');\nvar errCode = require('err-code');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar parseDuration__default = /*#__PURE__*/_interopDefaultLegacy(parseDuration);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction getBandwidthStats(libp2p, opts) {\n let stats;\n if (!libp2p.metrics) {\n stats = undefined;\n } else if (opts.peer) {\n stats = libp2p.metrics.forPeer(opts.peer);\n } else if (opts.proto) {\n stats = libp2p.metrics.forProtocol(opts.proto);\n } else {\n stats = libp2p.metrics.global;\n }\n if (!stats) {\n return {\n totalIn: BigInt(0),\n totalOut: BigInt(0),\n rateIn: 0,\n rateOut: 0\n };\n }\n const {movingAverages, snapshot} = stats;\n return {\n totalIn: BigInt(snapshot.dataReceived.integerValue().toString()),\n totalOut: BigInt(snapshot.dataSent.integerValue().toString()),\n rateIn: movingAverages.dataReceived[60000].movingAverage() / 60,\n rateOut: movingAverages.dataSent[60000].movingAverage() / 60\n };\n}\nfunction createBw({network}) {\n const bw = async function* (options = {}) {\n const {libp2p} = await network.use(options);\n if (!options.poll) {\n yield getBandwidthStats(libp2p, options);\n return;\n }\n const interval = options.interval || 1000;\n let ms = -1;\n try {\n ms = typeof interval === 'string' ? parseDuration__default['default'](interval) || -1 : interval;\n if (!ms || ms < 0)\n throw new Error('invalid duration');\n } catch (err) {\n throw errCode__default['default'](err, 'ERR_INVALID_POLL_INTERVAL');\n }\n let timeoutId;\n try {\n while (true) {\n yield getBandwidthStats(libp2p, options);\n await new Promise(resolve => {\n timeoutId = setTimeout(resolve, ms);\n });\n }\n } finally {\n clearTimeout(timeoutId);\n }\n };\n return withTimeoutOption.withTimeoutOption(bw);\n}\n\nexports.createBw = createBw;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar repo = require('ipfs-core-config/repo');\nvar getDefaultConfig = require('ipfs-core-config/config');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar PeerId = require('peer-id');\nvar mergeOpts = require('merge-options');\nvar profiles = require('./config/profiles.js');\nvar errors$1 = require('../errors.js');\nvar libp2p = require('./libp2p.js');\nvar errors = require('ipfs-repo/errors');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar getDefaultConfig__default = /*#__PURE__*/_interopDefaultLegacy(getDefaultConfig);\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst log = debug__default['default']('ipfs:components:peer:storage');\nclass Storage {\n constructor(peerId, keychain, repo, print, isNew) {\n this.print = print;\n this.peerId = peerId;\n this.keychain = keychain;\n this.repo = repo;\n this.print = print;\n this.isNew = isNew;\n }\n static async start(print, codecs, options) {\n const {\n repoAutoMigrate,\n repo: inputRepo,\n onMigrationProgress\n } = options;\n const repo$1 = typeof inputRepo === 'string' || inputRepo == null ? repo.createRepo(print, codecs, {\n path: inputRepo,\n autoMigrate: repoAutoMigrate,\n onMigrationProgress: onMigrationProgress\n }) : inputRepo;\n const {peerId, keychain, isNew} = await loadRepo(print, repo$1, options);\n return new Storage(peerId, keychain, repo$1, print, isNew);\n }\n}\nconst loadRepo = async (print, repo, options) => {\n if (!repo.closed) {\n return {\n ...await configureRepo(repo, options),\n isNew: false\n };\n }\n try {\n await repo.open();\n return {\n ...await configureRepo(repo, options),\n isNew: false\n };\n } catch (err) {\n if (err.code !== errors.ERR_REPO_NOT_INITIALIZED) {\n throw err;\n }\n if (options.init && options.init.allowNew === false) {\n throw new errors$1.NotEnabledError('Initialization of new repos disabled by config, pass `config.init.isNew: true` to enable it');\n }\n return {\n ...await initRepo(print, repo, options),\n isNew: true\n };\n }\n};\nconst initRepo = async (print, repo, options) => {\n const initOptions = options.init || {};\n const exists = await repo.exists();\n log('repo exists?', exists);\n if (exists === true) {\n throw new Error('repo already exists');\n }\n const peerId = initOptions.privateKey ? await decodePeerId(initOptions.privateKey) : await initPeerId(print, initOptions);\n const identity = peerIdToIdentity(peerId);\n log('peer identity: %s', identity.PeerID);\n const config = {\n ...mergeOptions(applyProfiles(getDefaultConfig__default['default'](), initOptions.profiles), options.config),\n Identity: identity\n };\n await repo.init(config);\n await repo.open();\n log('repo opened');\n const keychainConfig = { pass: options.pass };\n try {\n keychainConfig.dek = await repo.config.get('Keychain.DEK');\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n }\n const libp2p$1 = await libp2p.createLibp2p({\n options: undefined,\n multiaddrs: undefined,\n peerId,\n repo,\n config,\n keychainConfig\n });\n if (libp2p$1.keychain && libp2p$1.keychain.opts) {\n await libp2p$1.loadKeychain();\n await repo.config.set('Keychain', { DEK: libp2p$1.keychain.opts.dek });\n }\n return {\n peerId,\n keychain: libp2p$1.keychain\n };\n};\nconst decodePeerId = peerId => {\n log('using user-supplied private-key');\n return typeof peerId === 'object' ? peerId : PeerId__default['default'].createFromPrivKey(fromString.fromString(peerId, 'base64pad'));\n};\nconst initPeerId = (print, {algorithm = 'Ed25519', bits = 2048}) => {\n print('generating %s keypair...', algorithm);\n return PeerId__default['default'].create({\n keyType: algorithm,\n bits\n });\n};\nconst peerIdToIdentity = peerId => ({\n PeerID: peerId.toB58String(),\n PrivKey: toString.toString(peerId.privKey.bytes, 'base64pad')\n});\nconst configureRepo = async (repo, options) => {\n const config = options.config;\n const profiles = options.init && options.init.profiles || [];\n const pass = options.pass;\n const original = await repo.config.getAll();\n const changed = mergeConfigs(applyProfiles(original, profiles), config);\n if (original !== changed) {\n await repo.config.replace(changed);\n }\n if (!changed.Identity || !changed.Identity.PrivKey) {\n throw new errors$1.NotInitializedError('No private key was found in the config, please intialize the repo');\n }\n const peerId = await PeerId__default['default'].createFromPrivKey(changed.Identity.PrivKey);\n const libp2p$1 = await libp2p.createLibp2p({\n options: undefined,\n multiaddrs: undefined,\n peerId,\n repo,\n config: changed,\n keychainConfig: {\n pass,\n ...changed.Keychain\n }\n });\n if (libp2p$1.keychain) {\n await libp2p$1.loadKeychain();\n }\n return {\n peerId,\n keychain: libp2p$1.keychain\n };\n};\nconst mergeConfigs = (config, changes) => changes ? mergeOptions(config, changes) : config;\nconst applyProfiles = (config, profiles$1) => {\n return (profiles$1 || []).reduce((config, name) => {\n const profile = profiles.profiles[name];\n if (!profile) {\n throw new Error(`Could not find profile with name '${ name }'`);\n }\n log('applying profile %s', name);\n return profile.transform(config);\n }, config);\n};\n\nexports.Storage = Storage;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsRepo = require('ipfs-repo');\nvar datastoreLevel = require('datastore-level');\nvar blockstoreDatastoreAdapter = require('blockstore-datastore-adapter');\nvar memory = require('ipfs-repo/locks/memory');\n\nfunction createRepo(print, codecs, options) {\n const repoPath = options.path || 'ipfs';\n return ipfsRepo.createRepo(repoPath, codeOrName => codecs.getCodec(codeOrName), {\n root: new datastoreLevel.LevelDatastore(repoPath, {\n prefix: '',\n version: 2\n }),\n blocks: new blockstoreDatastoreAdapter.BlockstoreDatastoreAdapter(new datastoreLevel.LevelDatastore(`${ repoPath }/blocks`, {\n prefix: '',\n version: 2\n })),\n datastore: new datastoreLevel.LevelDatastore(`${ repoPath }/datastore`, {\n prefix: '',\n version: 2\n }),\n keys: new datastoreLevel.LevelDatastore(`${ repoPath }/keys`, {\n prefix: '',\n version: 2\n }),\n pins: new datastoreLevel.LevelDatastore(`${ repoPath }/pins`, {\n prefix: '',\n version: 2\n })\n }, {\n autoMigrate: options.autoMigrate,\n onMigrationProgress: options.onMigrationProgress || print,\n repoLock: memory.MemoryLock\n });\n}\n\nexports.createRepo = createRepo;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _get = require('just-safe-get');\nvar debug = require('debug');\nvar errCode = require('err-code');\nvar migrator = require('ipfs-repo-migrations');\nvar bytes = require('bytes');\nvar merge = require('merge-options');\nvar constants = require('./constants.js');\nvar version = require('./version.js');\nvar config = require('./config.js');\nvar spec = require('./spec.js');\nvar apiAddr = require('./api-addr.js');\nvar idstore = require('./idstore.js');\nvar defaultOptions = require('./default-options.js');\nvar defaultDatastore = require('./default-datastore.js');\nvar errors = require('./errors.js');\nvar pinManager = require('./pin-manager.js');\nvar pinnedBlockstore = require('./pinned-blockstore.js');\nvar mortice = require('mortice');\nvar gc = require('./gc.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar _get__default = /*#__PURE__*/_interopDefaultLegacy(_get);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar migrator__namespace = /*#__PURE__*/_interopNamespace(migrator);\nvar bytes__default = /*#__PURE__*/_interopDefaultLegacy(bytes);\nvar merge__default = /*#__PURE__*/_interopDefaultLegacy(merge);\nvar mortice__default = /*#__PURE__*/_interopDefaultLegacy(mortice);\n\nconst log = debug__default[\"default\"]('ipfs:repo');\nconst noLimit = Number.MAX_SAFE_INTEGER;\nconst AUTO_MIGRATE_CONFIG_KEY = 'repoAutoMigrate';\nclass Repo {\n constructor(path, loadCodec, backends, options) {\n if (typeof path !== 'string') {\n throw new Error('missing repo path');\n }\n if (typeof loadCodec !== 'function') {\n throw new Error('missing codec loader');\n }\n this.options = merge__default[\"default\"](defaultOptions, options);\n this.closed = true;\n this.path = path;\n this.root = backends.root;\n this.datastore = backends.datastore;\n this.keys = backends.keys;\n const blockstore = backends.blocks;\n const pinstore = backends.pins;\n this.pins = new pinManager.PinManager({\n pinstore,\n blockstore,\n loadCodec\n });\n const pinnedBlockstore$1 = pinnedBlockstore.createPinnedBlockstore(this.pins, blockstore);\n this.blocks = idstore.createIdStore(pinnedBlockstore$1);\n this.version = version.version(this.root);\n this.config = config.config(this.root);\n this.spec = spec.spec(this.root);\n this.apiAddr = apiAddr.apiAddr(this.root);\n this.gcLock = mortice__default[\"default\"](path, { singleProcess: this.options.repoOwner !== false });\n this.gc = gc.gc({\n gcLock: this.gcLock,\n pins: this.pins,\n blockstore: this.blocks,\n root: this.root,\n loadCodec\n });\n }\n async init(config) {\n log('initializing at: %s', this.path);\n await this._openRoot();\n await this.config.replace(buildConfig(config));\n await this.spec.set(buildDatastoreSpec(config));\n await this.version.set(constants.repoVersion);\n }\n async isInitialized() {\n if (!this.closed) {\n return true;\n }\n try {\n await this._openRoot();\n await this._checkInitialized();\n await this.root.close();\n return true;\n } catch (err) {\n return false;\n }\n }\n async open() {\n if (!this.closed) {\n throw errCode__default[\"default\"](new Error('repo is already open'), errors.ERR_REPO_ALREADY_OPEN);\n }\n log('opening at: %s', this.path);\n try {\n await this._openRoot();\n await this._checkInitialized();\n this._lockfile = await this._openLock();\n log('acquired repo.lock');\n const isCompatible = await this.version.check(constants.repoVersion);\n if (!isCompatible) {\n if (await this._isAutoMigrationEnabled()) {\n await this._migrate(constants.repoVersion, {\n root: this.root,\n datastore: this.datastore,\n pins: this.pins.pinstore,\n blocks: this.pins.blockstore,\n keys: this.keys\n });\n } else {\n throw new errors.InvalidRepoVersionError('Incompatible repo versions. Automatic migrations disabled. Please migrate the repo manually.');\n }\n }\n log('creating datastore');\n await this.datastore.open();\n log('creating blocks');\n await this.blocks.open();\n log('creating keystore');\n await this.keys.open();\n log('creating pins');\n await this.pins.pinstore.open();\n this.closed = false;\n log('all opened');\n } catch (err) {\n if (this._lockfile) {\n try {\n await this._closeLock();\n this._lockfile = null;\n } catch (err2) {\n log('error removing lock', err2);\n }\n }\n throw err;\n }\n }\n async _openRoot() {\n try {\n await this.root.open();\n } catch (err) {\n if (err.message !== 'Already open') {\n throw err;\n }\n }\n }\n async _openLock() {\n const lockfile = await this.options.repoLock.lock(this.path);\n if (typeof lockfile.close !== 'function') {\n throw errCode__default[\"default\"](new Error('Locks must have a close method'), 'ERR_NO_CLOSE_FUNCTION');\n }\n return lockfile;\n }\n _closeLock() {\n return this._lockfile && this._lockfile.close();\n }\n async _checkInitialized() {\n log('init check');\n let config;\n try {\n [config] = await Promise.all([\n this.config.exists(),\n this.spec.exists(),\n this.version.exists()\n ]);\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n throw errCode__default[\"default\"](new Error('repo is not initialized yet'), errors.ERR_REPO_NOT_INITIALIZED, { path: this.path });\n }\n throw err;\n }\n if (!config) {\n throw errCode__default[\"default\"](new Error('repo is not initialized yet'), errors.ERR_REPO_NOT_INITIALIZED, { path: this.path });\n }\n }\n async close() {\n if (this.closed) {\n throw errCode__default[\"default\"](new Error('repo is already closed'), errors.ERR_REPO_ALREADY_CLOSED);\n }\n log('closing at: %s', this.path);\n try {\n await this.apiAddr.delete();\n } catch (err) {\n if (err.code !== errors.ERR_REPO_NOT_INITIALIZED && !err.message.startsWith('ENOENT')) {\n throw err;\n }\n }\n await Promise.all([\n this.root,\n this.blocks,\n this.keys,\n this.datastore,\n this.pins.pinstore\n ].map(store => store && store.close()));\n log('unlocking');\n this.closed = true;\n await this._closeLock();\n }\n exists() {\n return this.version.exists();\n }\n async stat() {\n if (this.datastore && this.keys) {\n const [storageMax, blocks, version, datastore, keys] = await Promise.all([\n this._storageMaxStat(),\n this._blockStat(),\n this.version.get(),\n getSize(this.datastore),\n getSize(this.keys)\n ]);\n const size = blocks.size + datastore + keys;\n return {\n repoPath: this.path,\n storageMax,\n version: version,\n numObjects: blocks.count,\n repoSize: size\n };\n }\n throw errCode__default[\"default\"](new Error('repo is not initialized yet'), errors.ERR_REPO_NOT_INITIALIZED, { path: this.path });\n }\n async _isAutoMigrationEnabled() {\n if (this.options.autoMigrate !== undefined) {\n return this.options.autoMigrate;\n }\n let autoMigrateConfig;\n try {\n autoMigrateConfig = await this.config.get(AUTO_MIGRATE_CONFIG_KEY);\n } catch (e) {\n if (e.code === errors.NotFoundError.code) {\n autoMigrateConfig = true;\n } else {\n throw e;\n }\n }\n return autoMigrateConfig;\n }\n async _migrate(toVersion, backends) {\n const currentRepoVersion = await this.version.get();\n if (currentRepoVersion > toVersion) {\n log(`reverting to version ${ toVersion }`);\n return migrator__namespace.revert(this.path, backends, this.options, toVersion, {\n ignoreLock: true,\n onProgress: this.options.onMigrationProgress\n });\n } else {\n log(`migrating to version ${ toVersion }`);\n return migrator__namespace.migrate(this.path, backends, this.options, toVersion, {\n ignoreLock: true,\n onProgress: this.options.onMigrationProgress\n });\n }\n }\n async _storageMaxStat() {\n try {\n const max = await this.config.get('Datastore.StorageMax');\n return BigInt(bytes__default[\"default\"](max));\n } catch (err) {\n return BigInt(noLimit);\n }\n }\n async _blockStat() {\n let count = BigInt(0);\n let size = BigInt(0);\n if (this.blocks) {\n for await (const {key, value} of this.blocks.query({})) {\n count += BigInt(1);\n size += BigInt(value.byteLength);\n size += BigInt(key.bytes.byteLength);\n }\n }\n return {\n count,\n size\n };\n }\n}\nasync function getSize(datastore) {\n let sum = BigInt(0);\n for await (const block of datastore.query({})) {\n sum += BigInt(block.value.byteLength);\n sum += BigInt(block.key.uint8Array().byteLength);\n }\n return sum;\n}\nfunction createRepo(path, loadCodec, backends, options) {\n return new Repo(path, loadCodec, backends, options);\n}\nfunction buildConfig(_config) {\n _config.Datastore = Object.assign({}, defaultDatastore, _get__default[\"default\"](_config, 'datastore'));\n return _config;\n}\nfunction buildDatastoreSpec(_config) {\n const spec = {\n ...defaultDatastore.Spec,\n ..._get__default[\"default\"](_config, 'Datastore.Spec')\n };\n return {\n type: spec.type,\n mounts: spec.mounts.map(mounting => ({\n mountpoint: mounting.mountpoint,\n type: mounting.child.type,\n path: mounting.child.path,\n shardFunc: mounting.child.shardFunc\n }))\n };\n}\n\nexports.createRepo = createRepo;\n","module.exports = get;\n\n/*\n const obj = {a: {aa: {aaa: 2}}, b: 4};\n\n get(obj, 'a.aa.aaa'); // 2\n get(obj, ['a', 'aa', 'aaa']); // 2\n\n get(obj, 'b.bb.bbb'); // undefined\n get(obj, ['b', 'bb', 'bbb']); // undefined\n\n get(obj.a, 'aa.aaa'); // 2\n get(obj.a, ['aa', 'aaa']); // 2\n\n get(obj.b, 'bb.bbb'); // undefined\n get(obj.b, ['bb', 'bbb']); // undefined\n\n get(obj.b, 'bb.bbb', 42); // 42\n get(obj.b, ['bb', 'bbb'], 42); // 42\n\n get(null, 'a'); // undefined\n get(undefined, ['a']); // undefined\n\n get(null, 'a', 42); // 42\n get(undefined, ['a'], 42); // 42\n\n const obj = {a: {}};\n const sym = Symbol();\n obj.a[sym] = 4;\n get(obj.a, sym); // 4\n*/\n\nfunction get(obj, propsArg, defaultValue) {\n if (!obj) {\n return defaultValue;\n }\n var props, prop;\n if (Array.isArray(propsArg)) {\n props = propsArg.slice(0);\n }\n if (typeof propsArg == 'string') {\n props = propsArg.split('.');\n }\n if (typeof propsArg == 'symbol') {\n props = [propsArg];\n }\n if (!Array.isArray(props)) {\n throw new Error('props arg must be an array, a string or a symbol');\n }\n while (props.length) {\n prop = props.shift();\n if (!obj) {\n return defaultValue;\n }\n obj = obj[prop];\n if (obj === undefined) {\n return defaultValue;\n }\n }\n return obj;\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('../migrations/index.js');\nvar version = require('./repo/version.js');\nvar errors$1 = require('./errors.js');\nvar utils = require('./utils.js');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:migrator');\nfunction getLatestMigrationVersion(migrations) {\n migrations = migrations || index;\n if (!Array.isArray(migrations) || migrations.length === 0) {\n return 0;\n }\n return migrations[migrations.length - 1].version;\n}\nasync function migrate(path, backends, repoOptions, toVersion, {ignoreLock = false, onProgress, isDryRun = false, migrations}) {\n migrations = migrations || index;\n if (!path) {\n throw new errors.RequiredParameterError('Path argument is required!');\n }\n if (!repoOptions) {\n throw new errors.RequiredParameterError('repoOptions argument is required!');\n }\n if (!toVersion) {\n throw new errors.RequiredParameterError('toVersion argument is required!');\n }\n if (!Number.isInteger(toVersion) || toVersion <= 0) {\n throw new errors.InvalidValueError('Version has to be positive integer!');\n }\n backends = utils.wrapBackends(backends);\n const currentVersion = await version.getVersion(backends);\n if (currentVersion === toVersion) {\n log('Nothing to migrate.');\n return;\n }\n if (currentVersion > toVersion) {\n throw new errors.InvalidValueError(`Current repo's version (${ currentVersion }) is higher then toVersion (${ toVersion }), you probably wanted to revert it?`);\n }\n verifyAvailableMigrations(migrations, currentVersion, toVersion);\n let lock;\n if (!isDryRun && !ignoreLock) {\n lock = await repoOptions.repoLock.lock(path);\n }\n try {\n for (const migration of migrations) {\n if (toVersion !== undefined && migration.version > toVersion) {\n break;\n }\n if (migration.version <= currentVersion) {\n continue;\n }\n log(`Migrating version ${ migration.version }`);\n try {\n if (!isDryRun) {\n let progressCallback = () => {\n };\n if (onProgress) {\n progressCallback = (percent, message) => onProgress(migration.version, percent.toFixed(2), message);\n }\n await migration.migrate(backends, progressCallback);\n }\n } catch (e) {\n const lastSuccessfullyMigratedVersion = migration.version - 1;\n log(`An exception was raised during execution of migration. Setting the repo's version to last successfully migrated version: ${ lastSuccessfullyMigratedVersion }`);\n await version.setVersion(lastSuccessfullyMigratedVersion, backends);\n throw new Error(`During migration to version ${ migration.version } exception was raised: ${ e.stack || e.message || e }`);\n }\n log(`Migrating to version ${ migration.version } finished`);\n }\n if (!isDryRun) {\n await version.setVersion(toVersion || getLatestMigrationVersion(migrations), backends);\n }\n log('Repo successfully migrated', toVersion !== undefined ? `to version ${ toVersion }!` : 'to latest version!');\n } finally {\n if (!isDryRun && !ignoreLock && lock) {\n await lock.close();\n }\n }\n}\nasync function revert(path, backends, repoOptions, toVersion, {ignoreLock = false, onProgress, isDryRun = false, migrations}) {\n migrations = migrations || index;\n if (!path) {\n throw new errors.RequiredParameterError('Path argument is required!');\n }\n if (!repoOptions) {\n throw new errors.RequiredParameterError('repoOptions argument is required!');\n }\n if (!toVersion) {\n throw new errors.RequiredParameterError('When reverting migrations, you have to specify to which version to revert!');\n }\n if (!Number.isInteger(toVersion) || toVersion <= 0) {\n throw new errors.InvalidValueError('Version has to be positive integer!');\n }\n backends = utils.wrapBackends(backends);\n const currentVersion = await version.getVersion(backends);\n if (currentVersion === toVersion) {\n log('Nothing to revert.');\n return;\n }\n if (currentVersion < toVersion) {\n throw new errors.InvalidValueError(`Current repo's version (${ currentVersion }) is lower then toVersion (${ toVersion }), you probably wanted to migrate it?`);\n }\n verifyAvailableMigrations(migrations, toVersion, currentVersion, true);\n let lock;\n if (!isDryRun && !ignoreLock) {\n lock = await repoOptions.repoLock.lock(path);\n }\n log(`Reverting from version ${ currentVersion } to ${ toVersion }`);\n try {\n const reversedMigrationArray = migrations.slice().reverse();\n for (const migration of reversedMigrationArray) {\n if (migration.version <= toVersion) {\n break;\n }\n if (migration.version > currentVersion) {\n continue;\n }\n log(`Reverting migration version ${ migration.version }`);\n try {\n if (!isDryRun) {\n let progressCallback = () => {\n };\n if (onProgress) {\n progressCallback = (percent, message) => onProgress(migration.version, percent.toFixed(2), message);\n }\n await migration.revert(backends, progressCallback);\n }\n } catch (e) {\n const lastSuccessfullyRevertedVersion = migration.version;\n log(`An exception was raised during execution of migration. Setting the repo's version to last successfully reverted version: ${ lastSuccessfullyRevertedVersion }`);\n await version.setVersion(lastSuccessfullyRevertedVersion, backends);\n e.message = `During reversion to version ${ migration.version } exception was raised: ${ e.message }`;\n throw e;\n }\n log(`Reverting to version ${ migration.version } finished`);\n }\n if (!isDryRun) {\n await version.setVersion(toVersion, backends);\n }\n log(`All migrations successfully reverted to version ${ toVersion }!`);\n } finally {\n if (!isDryRun && !ignoreLock && lock) {\n await lock.close();\n }\n }\n}\nfunction verifyAvailableMigrations(migrations, fromVersion, toVersion, checkReversibility = false) {\n let migrationCounter = 0;\n for (const migration of migrations) {\n if (migration.version > toVersion) {\n break;\n }\n if (migration.version > fromVersion) {\n if (checkReversibility && !migration.revert) {\n throw new errors.NonReversibleMigrationError(`It is not possible to revert to version ${ fromVersion } because migration version ${ migration.version } is not reversible. Cancelling reversion.`);\n }\n migrationCounter++;\n }\n }\n if (migrationCounter !== toVersion - fromVersion) {\n throw new errors.InvalidValueError(`The ipfs-repo-migrations package does not have all migration to migrate from version ${ fromVersion } to ${ toVersion }`);\n }\n}\nconst getCurrentRepoVersion = version.getVersion;\nconst errors = errors$1;\nconst migrations = index;\n\nexports.errors = errors;\nexports.getCurrentRepoVersion = getCurrentRepoVersion;\nexports.getLatestMigrationVersion = getLatestMigrationVersion;\nexports.migrate = migrate;\nexports.migrations = migrations;\nexports.revert = revert;\n","'use strict';\n\nvar index = require('./migration-8/index.js');\nvar index$1 = require('./migration-9/index.js');\nvar index$2 = require('./migration-10/index.js');\nvar index$3 = require('./migration-11/index.js');\n\nconst emptyMigration = {\n description: 'Empty migration.',\n migrate: () => {\n },\n revert: () => {\n },\n empty: true\n};\nvar defaultMigrations = [\n Object.assign({ version: 1 }, emptyMigration),\n Object.assign({ version: 2 }, emptyMigration),\n Object.assign({ version: 3 }, emptyMigration),\n Object.assign({ version: 4 }, emptyMigration),\n Object.assign({ version: 5 }, emptyMigration),\n Object.assign({ version: 6 }, emptyMigration),\n Object.assign({ version: 7 }, emptyMigration),\n index.migration,\n index$1.migration,\n index$2.migration,\n index$3.migration\n];\n\nmodule.exports = defaultMigrations;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar key = require('interface-datastore/key');\nvar debug = require('debug');\nvar length = require('it-length');\nvar base32 = require('multiformats/bases/base32');\nvar raw = require('multiformats/codecs/raw');\nvar mhd = require('multiformats/hashes/digest');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar length__default = /*#__PURE__*/_interopDefaultLegacy(length);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar mhd__namespace = /*#__PURE__*/_interopNamespace(mhd);\n\nconst log = debug__default[\"default\"]('ipfs:repo:migrator:migration-8');\nfunction unwrap(blockstore) {\n if (blockstore.child) {\n return unwrap(blockstore.child);\n }\n return blockstore;\n}\nfunction keyToMultihash(key$1) {\n try {\n const buf = base32.base32.decode(`b${ key$1.toString().toLowerCase().slice(1) }`);\n const multihash = cid.CID.decode(buf).multihash.bytes;\n const multihashStr = base32.base32.encode(multihash).slice(1).toUpperCase();\n return new key.Key(`/${ multihashStr }`, false);\n } catch (err) {\n return key$1;\n }\n}\nfunction keyToCid(key$1) {\n try {\n const buf = base32.base32.decode(`b${ key$1.toString().toLowerCase().slice(1) }`);\n const digest = mhd__namespace.decode(buf);\n const multihash = base32.base32.encode(cid.CID.createV1(raw__namespace.code, digest).bytes).slice(1);\n return new key.Key(`/${ multihash.toUpperCase() }`, false);\n } catch {\n return key$1;\n }\n}\nasync function process(backends, onProgress, keyFunction) {\n const blockstore = backends.blocks;\n await blockstore.open();\n const unwrapped = unwrap(blockstore);\n const blockCount = await length__default[\"default\"](unwrapped.queryKeys({\n filters: [key => {\n const newKey = keyFunction(key);\n return newKey.toString() !== key.toString();\n }]\n }));\n try {\n let counter = 0;\n for await (const block of unwrapped.query({})) {\n const newKey = keyFunction(block.key);\n if (newKey.toString() !== block.key.toString()) {\n counter += 1;\n log(`Migrating Block from ${ block.key } to ${ newKey }`, await unwrapped.has(block.key));\n await unwrapped.delete(block.key);\n await unwrapped.put(newKey, block.value);\n onProgress(counter / blockCount * 100, `Migrated Block from ${ block.key } to ${ newKey }`);\n }\n }\n } finally {\n await blockstore.close();\n }\n}\nconst migration = {\n version: 8,\n description: 'Transforms key names into base32 encoding and converts Block store to use bare multihashes encoded as base32',\n migrate: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, keyToMultihash);\n },\n revert: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, keyToCid);\n }\n};\n\nexports.migration = migration;\n","'use strict'\n\n/**\n * Consumes the passed iterator and returns the number of items it contained.\n *\n * @param {AsyncIterable<any> | Iterable<any>} iterator\n * @returns {Promise<number>}\n */\nconst length = async (iterator) => {\n let count = 0\n\n for await (const _ of iterator) { // eslint-disable-line no-unused-vars\n count++\n }\n\n return count\n}\n\nmodule.exports = length\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar dagPb = require('@ipld/dag-pb');\nvar cbor = require('cborg');\nvar pinSet = require('./pin-set.js');\nvar utils = require('./utils.js');\nvar length = require('it-length');\nvar sha2 = require('multiformats/hashes/sha2');\nvar mhd = require('multiformats/hashes/digest');\nvar base32 = require('multiformats/bases/base32');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\nvar cbor__namespace = /*#__PURE__*/_interopNamespace(cbor);\nvar length__default = /*#__PURE__*/_interopDefaultLegacy(length);\nvar mhd__namespace = /*#__PURE__*/_interopNamespace(mhd);\n\nasync function pinsToDatastore(blockstore, datastore, pinstore, onProgress) {\n if (!await datastore.has(utils.PIN_DS_KEY)) {\n return;\n }\n const mh = await datastore.get(utils.PIN_DS_KEY);\n const cid$1 = cid.CID.decode(mh);\n const pinRootBuf = await blockstore.get(cid$1);\n const pinRoot = dagPb__namespace.decode(pinRootBuf);\n let counter = 0;\n const pinCount = await length__default[\"default\"](pinSet.loadSet(blockstore, pinRoot, utils.PinTypes.recursive)) + await length__default[\"default\"](pinSet.loadSet(blockstore, pinRoot, utils.PinTypes.direct));\n for await (const cid of pinSet.loadSet(blockstore, pinRoot, utils.PinTypes.recursive)) {\n counter++;\n const pin = { depth: Infinity };\n if (cid.version !== 0) {\n pin.version = cid.version;\n }\n if (cid.code !== dagPb__namespace.code) {\n pin.codec = cid.code;\n }\n await pinstore.put(utils.cidToKey(cid), cbor__namespace.encode(pin));\n onProgress(counter / pinCount * 100, `Migrated recursive pin ${ cid }`);\n }\n for await (const cid of pinSet.loadSet(blockstore, pinRoot, utils.PinTypes.direct)) {\n counter++;\n const pin = { depth: 0 };\n if (cid.version !== 0) {\n pin.version = cid.version;\n }\n if (cid.code !== dagPb__namespace.code) {\n pin.codec = cid.code;\n }\n await pinstore.put(utils.cidToKey(cid), cbor__namespace.encode(pin));\n onProgress(counter / pinCount * 100, `Migrated direct pin ${ cid }`);\n }\n await blockstore.delete(cid$1);\n await datastore.delete(utils.PIN_DS_KEY);\n}\nasync function pinsToDAG(blockstore, datastore, pinstore, onProgress) {\n const recursivePins = [];\n const directPins = [];\n let counter = 0;\n const pinCount = await length__default[\"default\"](pinstore.queryKeys({}));\n for await (const {key, value} of pinstore.query({})) {\n counter++;\n const pin = cbor__namespace.decode(value);\n const cid$1 = cid.CID.create(pin.version || 0, pin.codec || dagPb__namespace.code, mhd__namespace.decode(base32.base32.decode('b' + key.toString().toLowerCase().split('/').pop())));\n if (pin.depth === 0) {\n onProgress(counter / pinCount * 100, `Reverted direct pin ${ cid$1 }`);\n directPins.push(cid$1);\n } else {\n onProgress(counter / pinCount * 100, `Reverted recursive pin ${ cid$1 }`);\n recursivePins.push(cid$1);\n }\n }\n onProgress(100, 'Updating pin root');\n const pinRoot = {\n Links: [\n await pinSet.storeSet(blockstore, utils.PinTypes.direct, directPins),\n await pinSet.storeSet(blockstore, utils.PinTypes.recursive, recursivePins)\n ]\n };\n const buf = dagPb__namespace.encode(pinRoot);\n const digest = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(digest);\n await blockstore.put(cid$1, buf);\n await datastore.put(utils.PIN_DS_KEY, cid$1.bytes);\n}\nasync function process(backends, onProgress, fn) {\n const blockstore = backends.blocks;\n const datastore = backends.datastore;\n const pinstore = backends.pins;\n await blockstore.open();\n await datastore.open();\n await pinstore.open();\n try {\n await fn(blockstore, datastore, pinstore, onProgress);\n } finally {\n await pinstore.close();\n await datastore.close();\n await blockstore.close();\n }\n}\nconst migration = {\n version: 9,\n description: 'Migrates pins to datastore',\n migrate: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, pinsToDatastore);\n },\n revert: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, pinsToDAG);\n }\n};\n\nexports.migration = migration;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar pin = require('./pin.js');\nvar fnv1a = require('fnv1a');\nvar varint = require('varint');\nvar dagPb = require('@ipld/dag-pb');\nvar utils = require('./utils.js');\nvar concat = require('uint8arrays/concat');\nvar compare = require('uint8arrays/compare');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\nvar sha2 = require('multiformats/hashes/sha2');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar fnv1a__default = /*#__PURE__*/_interopDefaultLegacy(fnv1a);\nvar varint__default = /*#__PURE__*/_interopDefaultLegacy(varint);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\n\nconst PinSet = pin.ipfs.pin.Set;\nfunction readHeader(rootNode) {\n const rootData = rootNode.Data;\n if (!rootData) {\n throw new Error('No data present');\n }\n const hdrLength = varint__default[\"default\"].decode(rootData);\n const vBytes = varint__default[\"default\"].decode.bytes;\n if (vBytes <= 0) {\n throw new Error('Invalid Set header length');\n }\n if (vBytes + hdrLength > rootData.length) {\n throw new Error('Impossibly large set header length');\n }\n const hdrSlice = rootData.slice(vBytes, hdrLength + vBytes);\n const header = PinSet.toObject(PinSet.decode(hdrSlice), {\n defaults: false,\n arrays: true,\n longs: Number,\n objects: false\n });\n if (header.version !== 1) {\n throw new Error(`Unsupported Set version: ${ header.version }`);\n }\n if (header.fanout > rootNode.Links.length) {\n throw new Error('Impossibly large fanout');\n }\n return {\n header: header,\n data: rootData.slice(hdrLength + vBytes)\n };\n}\nfunction hash(seed, key) {\n const buffer = new Uint8Array(4);\n const dataView = new DataView(buffer.buffer);\n dataView.setUint32(0, seed, true);\n const encodedKey = fromString.fromString(key.toString());\n const data = concat.concat([\n buffer,\n encodedKey\n ], buffer.byteLength + encodedKey.byteLength);\n return fnv1a__default[\"default\"](toString.toString(data));\n}\nasync function* walkItems(blockstore, node) {\n const pbh = readHeader(node);\n let idx = 0;\n for (const link of node.Links) {\n if (idx < pbh.header.fanout) {\n const linkHash = link.Hash;\n if (!utils.EMPTY_KEY.equals(linkHash)) {\n const buf = await blockstore.get(linkHash);\n const node = dagPb__namespace.decode(buf);\n yield* walkItems(blockstore, node);\n }\n } else {\n yield link.Hash;\n }\n idx++;\n }\n}\nasync function* loadSet(blockstore, rootNode, name) {\n const link = rootNode.Links.find(l => l.Name === name);\n if (!link) {\n throw new Error('No link found with name ' + name);\n }\n const buf = await blockstore.get(link.Hash);\n const node = dagPb__namespace.decode(buf);\n yield* walkItems(blockstore, node);\n}\nfunction storeItems(blockstore, items) {\n return storePins(items, 0);\n async function storePins(pins, depth) {\n const pbHeader = PinSet.encode({\n version: 1,\n fanout: utils.DEFAULT_FANOUT,\n seed: depth\n }).finish();\n const header = varint__default[\"default\"].encode(pbHeader.length);\n const headerBuf = concat.concat([\n header,\n pbHeader\n ]);\n const fanoutLinks = [];\n for (let i = 0; i < utils.DEFAULT_FANOUT; i++) {\n fanoutLinks.push({\n Name: '',\n Tsize: 1,\n Hash: utils.EMPTY_KEY\n });\n }\n if (pins.length <= utils.MAX_ITEMS) {\n const nodes = pins.map(item => {\n return {\n link: {\n Name: '',\n Tsize: 1,\n Hash: item.key\n },\n data: item.data || new Uint8Array()\n };\n }).sort((a, b) => {\n return compare.compare(a.link.Hash.bytes, b.link.Hash.bytes);\n });\n const rootLinks = fanoutLinks.concat(nodes.map(item => item.link));\n const rootData = concat.concat([\n headerBuf,\n ...nodes.map(item => item.data)\n ]);\n return {\n Data: rootData,\n Links: rootLinks\n };\n } else {\n const bins = pins.reduce((bins, pin) => {\n const n = hash(depth, pin.key) % utils.DEFAULT_FANOUT;\n bins[n] = n in bins ? bins[n].concat([pin]) : [pin];\n return bins;\n }, []);\n let idx = 0;\n for (const bin of bins) {\n const child = await storePins(bin, depth + 1);\n await storeChild(child, idx);\n idx++;\n }\n return {\n Data: headerBuf,\n Links: fanoutLinks\n };\n }\n async function storeChild(child, binIdx) {\n const buf = dagPb__namespace.encode(child);\n const digest = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(digest);\n await blockstore.put(cid$1, buf);\n const size = child.Links.reduce((acc, curr) => acc + (curr.Tsize || 0), 0) + buf.length;\n fanoutLinks[binIdx] = {\n Name: '',\n Tsize: size,\n Hash: cid$1\n };\n }\n }\n}\nasync function storeSet(blockstore, type, cids) {\n const rootNode = await storeItems(blockstore, cids.map(cid => {\n return { key: cid };\n }));\n const buf = dagPb__namespace.encode(rootNode);\n const digest = await sha2.sha256.digest(buf);\n const cid$1 = cid.CID.createV0(digest);\n await blockstore.put(cid$1, buf);\n const size = rootNode.Links.reduce((acc, curr) => acc + curr.Tsize, 0) + buf.length;\n return {\n Name: type,\n Tsize: size,\n Hash: cid$1\n };\n}\n\nexports.loadSet = loadSet;\nexports.storeSet = storeSet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar $protobuf = require('protobufjs/minimal.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar $protobuf__default = /*#__PURE__*/_interopDefaultLegacy($protobuf);\n\nconst $Reader = $protobuf__default[\"default\"].Reader, $Writer = $protobuf__default[\"default\"].Writer, $util = $protobuf__default[\"default\"].util;\nconst $root = $protobuf__default[\"default\"].roots['default'] || ($protobuf__default[\"default\"].roots['default'] = {});\nconst ipfs = $root.ipfs = (() => {\n const ipfs = {};\n ipfs.pin = function () {\n const pin = {};\n pin.Set = function () {\n function Set(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Set.prototype.version = 0;\n Set.prototype.fanout = 0;\n Set.prototype.seed = 0;\n Set.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.version != null && Object.hasOwnProperty.call(m, 'version'))\n w.uint32(8).uint32(m.version);\n if (m.fanout != null && Object.hasOwnProperty.call(m, 'fanout'))\n w.uint32(16).uint32(m.fanout);\n if (m.seed != null && Object.hasOwnProperty.call(m, 'seed'))\n w.uint32(29).fixed32(m.seed);\n return w;\n };\n Set.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.ipfs.pin.Set();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.version = r.uint32();\n break;\n case 2:\n m.fanout = r.uint32();\n break;\n case 3:\n m.seed = r.fixed32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Set.fromObject = function fromObject(d) {\n if (d instanceof $root.ipfs.pin.Set)\n return d;\n var m = new $root.ipfs.pin.Set();\n if (d.version != null) {\n m.version = d.version >>> 0;\n }\n if (d.fanout != null) {\n m.fanout = d.fanout >>> 0;\n }\n if (d.seed != null) {\n m.seed = d.seed >>> 0;\n }\n return m;\n };\n Set.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.version = 0;\n d.fanout = 0;\n d.seed = 0;\n }\n if (m.version != null && m.hasOwnProperty('version')) {\n d.version = m.version;\n }\n if (m.fanout != null && m.hasOwnProperty('fanout')) {\n d.fanout = m.fanout;\n }\n if (m.seed != null && m.hasOwnProperty('seed')) {\n d.seed = m.seed;\n }\n return d;\n };\n Set.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n return Set;\n }();\n return pin;\n }();\n return ipfs;\n})();\n\nexports[\"default\"] = $root;\nexports.ipfs = ipfs;\n","/**\n * Created by schwarzkopfb on 15/11/17.\n */\n\n/**\n * FNV-1a hash generation init value.\n * It's exposed, because this allows user to override it.\n *\n * @type {number}\n */\nhash.BASE = 0x811c9dc5\n\n/**\n * Generates 32 bit FNV-1a hash from the given string.\n * As explained here: http://isthe.com/chongo/tech/comp/fnv/\n *\n * @param s {string} String to generate hash from.\n * @returns {number} The result integer hash.\n */\nfunction hash(s) {\n var h = hash.BASE\n\n for (var i = 0, l = s.length; i < l; i++) {\n h ^= s.charCodeAt(i)\n h += (h << 1) + (h << 4) + (h << 7) + (h << 8) + (h << 24)\n }\n\n return h >>> 0\n}\n\nmodule.exports = hash\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar base32 = require('multiformats/bases/base32');\nvar cid = require('multiformats/cid');\n\nconst PIN_DS_KEY = new key.Key('/local/pins');\nconst DEFAULT_FANOUT = 256;\nconst MAX_ITEMS = 8192;\nconst EMPTY_KEY = cid.CID.parse('QmdfTbBqBPQ7VNxZEYEj14VmRuZBkqFbiwReogJgS1zR1n');\nconst PinTypes = {\n direct: 'direct',\n recursive: 'recursive'\n};\nfunction cidToKey(cid) {\n return new key.Key(`/${ base32.base32.encode(cid.multihash.bytes).toUpperCase().substring(1) }`);\n}\n\nexports.DEFAULT_FANOUT = DEFAULT_FANOUT;\nexports.EMPTY_KEY = EMPTY_KEY;\nexports.MAX_ITEMS = MAX_ITEMS;\nexports.PIN_DS_KEY = PIN_DS_KEY;\nexports.PinTypes = PinTypes;\nexports.cidToKey = cidToKey;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction compare(a, b) {\n for (let i = 0; i < a.byteLength; i++) {\n if (a[i] < b[i]) {\n return -1;\n }\n if (a[i] > b[i]) {\n return 1;\n }\n }\n if (a.byteLength > b.byteLength) {\n return 1;\n }\n if (a.byteLength < b.byteLength) {\n return -1;\n }\n return 0;\n}\n\nexports.compare = compare;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('../../src/utils.js');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\n\nasync function keysToBinary(name, store, onProgress = () => {\n}) {\n const db = utils.findLevelJs(store);\n if (!db) {\n onProgress(`${ name } did not need an upgrade`);\n return;\n }\n onProgress(`Upgrading ${ name }`);\n const upgrade = (key, value) => {\n return [\n {\n type: 'del',\n key: key\n },\n {\n type: 'put',\n key: fromString.fromString(key),\n value: value\n }\n ];\n };\n await withEach(db, upgrade);\n}\nasync function keysToStrings(name, store, onProgress = () => {\n}) {\n const db = utils.findLevelJs(store);\n if (!db) {\n onProgress(`${ name } did not need a downgrade`);\n return;\n }\n onProgress(`Downgrading ${ name }`);\n const downgrade = (key, value) => {\n return [\n {\n type: 'del',\n key: key\n },\n {\n type: 'put',\n key: toString.toString(key),\n value: value\n }\n ];\n };\n await withEach(db, downgrade);\n}\nfunction unwrap(store) {\n if (store.child) {\n return unwrap(store.child);\n }\n return store;\n}\nasync function process(backends, onProgress, fn) {\n const datastores = Object.entries(backends).map(([key, backend]) => ({\n key,\n backend: unwrap(backend)\n })).filter(({key, backend}) => backend.constructor.name === 'LevelDatastore').map(({key, backend}) => ({\n name: key,\n store: backend\n }));\n onProgress(0, `Migrating ${ datastores.length } dbs`);\n let migrated = 0;\n const progress = message => {\n onProgress(Math.round(migrated / datastores.length * 100), message);\n };\n for (const {name, store} of datastores) {\n await store.open();\n try {\n await fn(name, store, progress);\n } finally {\n migrated++;\n await store.close();\n }\n }\n onProgress(100, `Migrated ${ datastores.length } dbs`);\n}\nconst migration = {\n version: 10,\n description: 'Migrates datastore-level keys to binary',\n migrate: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, keysToBinary);\n },\n revert: (backends, onProgress = () => {\n }) => {\n return process(backends, onProgress, keysToStrings);\n }\n};\nfunction withEach(db, fn) {\n function batch(operations, next) {\n const store = db.store('readwrite');\n const transaction = store.transaction;\n let index = 0;\n let error;\n transaction.onabort = () => next(error || transaction.error || new Error('aborted by user'));\n transaction.oncomplete = () => next();\n function loop() {\n const op = operations[index++];\n const key = op.key;\n let req;\n try {\n req = op.type === 'del' ? store.delete(key) : store.put(op.value, key);\n } catch (err) {\n error = err;\n transaction.abort();\n return;\n }\n if (index < operations.length) {\n req.onsuccess = loop;\n }\n }\n loop();\n }\n return new Promise((resolve, reject) => {\n const it = db.iterator();\n const id = data => data;\n it._deserializeKey = it._deserializeValue = id;\n next();\n function next() {\n const handleNext = (err, key, value) => {\n if (err || key === undefined) {\n const handleEnd = err2 => {\n if (err2) {\n reject(err2);\n return;\n }\n resolve();\n };\n it.end(handleEnd);\n return;\n }\n batch(fn(key, value), next);\n };\n it.next(handleNext);\n }\n });\n}\n\nexports.migration = migration;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar errors = require('datastore-core/errors');\n\nconst CONFIG_KEY = new key.Key('/config');\nconst VERSION_KEY = new key.Key('/version');\nfunction findLevelJs(store) {\n let db = store;\n while (db.db || db.child) {\n db = db.db || db.child;\n if (db.type === 'level-js' || db.constructor.name === 'Level') {\n return db;\n }\n }\n}\nasync function hasWithFallback(key, has, store) {\n const result = await has(key);\n if (result) {\n return result;\n }\n const levelJs = findLevelJs(store);\n if (!levelJs) {\n return false;\n }\n return new Promise((resolve, reject) => {\n const req = levelJs.store('readonly').get(key.toString());\n req.transaction.onabort = () => {\n reject(req.transaction.error);\n };\n req.transaction.oncomplete = () => {\n resolve(Boolean(req.result));\n };\n });\n}\nasync function getWithFallback(key, get, has, store) {\n if (await has(key)) {\n return get(key);\n }\n const levelJs = findLevelJs(store);\n if (!levelJs) {\n throw errors.notFoundError();\n }\n return new Promise((resolve, reject) => {\n const req = levelJs.store('readonly').get(key.toString());\n req.transaction.onabort = () => {\n reject(req.transaction.error);\n };\n req.transaction.oncomplete = () => {\n if (req.result) {\n return resolve(req.result);\n }\n reject(errors.notFoundError());\n };\n });\n}\nfunction wrapStore(store) {\n const originalGet = store.get.bind(store);\n const originalHas = store.has.bind(store);\n store.get = key => getWithFallback(key, originalGet, originalHas, store);\n store.has = key => hasWithFallback(key, originalHas, store);\n return store;\n}\nfunction wrapBackends(backends) {\n return {\n ...backends,\n root: wrapStore(backends.root),\n datastore: wrapStore(backends.datastore),\n pins: wrapStore(backends.pins),\n keys: wrapStore(backends.keys)\n };\n}\n\nexports.CONFIG_KEY = CONFIG_KEY;\nexports.VERSION_KEY = VERSION_KEY;\nexports.findLevelJs = findLevelJs;\nexports.hasWithFallback = hasWithFallback;\nexports.wrapBackends = wrapBackends;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\n\nconst MFS_ROOT_KEY = new key.Key('/local/filesroot');\nasync function storeMfsRootInDatastore(backends, onProgress = () => {\n}) {\n onProgress(100, 'Migrating MFS root to repo datastore');\n await backends.root.open();\n await backends.datastore.open();\n if (await backends.root.has(MFS_ROOT_KEY)) {\n const root = await backends.root.get(MFS_ROOT_KEY);\n await backends.datastore.put(MFS_ROOT_KEY, root);\n await backends.root.delete(MFS_ROOT_KEY);\n }\n await backends.datastore.close();\n await backends.root.close();\n onProgress(100, 'Stored MFS root in repo datastore');\n}\nasync function storeMfsRootInRoot(backends, onProgress = () => {\n}) {\n onProgress(100, 'Migrating MFS root to repo root datastore');\n await backends.root.open();\n await backends.datastore.open();\n if (await backends.datastore.has(MFS_ROOT_KEY)) {\n const root = await backends.datastore.get(MFS_ROOT_KEY);\n await backends.root.put(MFS_ROOT_KEY, root);\n await backends.datastore.delete(MFS_ROOT_KEY);\n }\n await backends.datastore.close();\n await backends.root.close();\n onProgress(100, 'Stored MFS root in repo root datastore');\n}\nconst migration = {\n version: 11,\n description: 'Store mfs root in the datastore',\n migrate: storeMfsRootInDatastore,\n revert: storeMfsRootInRoot\n};\n\nexports.migration = migration;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar init = require('./init.js');\nvar errors = require('../errors.js');\nvar utils = require('../utils.js');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\n\nasync function getVersion(backends) {\n if (!await init.isRepoInitialized(backends)) {\n throw new errors.NotInitializedRepoError('Repo is not initialized!');\n }\n const store = backends.root;\n await store.open();\n try {\n return parseInt(toString.toString(await store.get(utils.VERSION_KEY)));\n } finally {\n await store.close();\n }\n}\nasync function setVersion(version, backends) {\n if (!backends) {\n throw new errors.MissingRepoOptionsError('Please pass repo options when trying to open a repo');\n }\n const store = backends.root;\n await store.open();\n await store.put(utils.VERSION_KEY, fromString.fromString(String(version)));\n await store.close();\n}\n\nexports.getVersion = getVersion;\nexports.setVersion = setVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar utils = require('../utils.js');\nvar errors = require('../errors.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:migrator:repo:init');\nasync function isRepoInitialized(backends) {\n if (!backends) {\n throw new errors.MissingRepoOptionsError('Please pass repo options when trying to open a repo');\n }\n const root = backends.root;\n try {\n await root.open();\n const versionCheck = await root.has(utils.VERSION_KEY);\n const configCheck = await root.has(utils.CONFIG_KEY);\n if (!versionCheck || !configCheck) {\n log(`Version entry present: ${ versionCheck }`);\n log(`Config entry present: ${ configCheck }`);\n return false;\n }\n return true;\n } catch (e) {\n log('While checking if repo is initialized error was thrown: ' + e.message);\n return false;\n } finally {\n if (root !== undefined) {\n try {\n await root.close();\n } catch {\n }\n }\n }\n}\n\nexports.isRepoInitialized = isRepoInitialized;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass NonReversibleMigrationError extends Error {\n constructor(message) {\n super(message);\n this.name = 'NonReversibleMigrationError';\n this.code = NonReversibleMigrationError.code;\n this.message = message;\n }\n}\nNonReversibleMigrationError.code = 'ERR_NON_REVERSIBLE_MIGRATION';\nclass NotInitializedRepoError extends Error {\n constructor(message) {\n super(message);\n this.name = 'NotInitializedRepoError';\n this.code = NotInitializedRepoError.code;\n this.message = message;\n }\n}\nNotInitializedRepoError.code = 'ERR_NOT_INITIALIZED_REPO';\nclass RequiredParameterError extends Error {\n constructor(message) {\n super(message);\n this.name = 'RequiredParameterError';\n this.code = RequiredParameterError.code;\n this.message = message;\n }\n}\nRequiredParameterError.code = 'ERR_REQUIRED_PARAMETER';\nclass InvalidValueError extends Error {\n constructor(message) {\n super(message);\n this.name = 'InvalidValueError';\n this.code = InvalidValueError.code;\n this.message = message;\n }\n}\nInvalidValueError.code = 'ERR_INVALID_VALUE';\nclass MissingRepoOptionsError extends Error {\n constructor(message) {\n super(message);\n this.name = 'MissingRepoOptionsError';\n this.code = MissingRepoOptionsError.code;\n this.message = message;\n }\n}\nMissingRepoOptionsError.code = 'ERR_MISSING_REPO_OPTIONS';\n\nexports.InvalidValueError = InvalidValueError;\nexports.MissingRepoOptionsError = MissingRepoOptionsError;\nexports.NonReversibleMigrationError = NonReversibleMigrationError;\nexports.NotInitializedRepoError = NotInitializedRepoError;\nexports.RequiredParameterError = RequiredParameterError;\n","/*!\n * bytes\n * Copyright(c) 2012-2014 TJ Holowaychuk\n * Copyright(c) 2015 Jed Watson\n * MIT Licensed\n */\n\n'use strict';\n\n/**\n * Module exports.\n * @public\n */\n\nmodule.exports = bytes;\nmodule.exports.format = format;\nmodule.exports.parse = parse;\n\n/**\n * Module variables.\n * @private\n */\n\nvar formatThousandsRegExp = /\\B(?=(\\d{3})+(?!\\d))/g;\n\nvar formatDecimalsRegExp = /(?:\\.0*|(\\.[^0]+)0+)$/;\n\nvar map = {\n b: 1,\n kb: 1 << 10,\n mb: 1 << 20,\n gb: 1 << 30,\n tb: Math.pow(1024, 4),\n pb: Math.pow(1024, 5),\n};\n\nvar parseRegExp = /^((-|\\+)?(\\d+(?:\\.\\d+)?)) *(kb|mb|gb|tb|pb)$/i;\n\n/**\n * Convert the given value in bytes into a string or parse to string to an integer in bytes.\n *\n * @param {string|number} value\n * @param {{\n * case: [string],\n * decimalPlaces: [number]\n * fixedDecimals: [boolean]\n * thousandsSeparator: [string]\n * unitSeparator: [string]\n * }} [options] bytes options.\n *\n * @returns {string|number|null}\n */\n\nfunction bytes(value, options) {\n if (typeof value === 'string') {\n return parse(value);\n }\n\n if (typeof value === 'number') {\n return format(value, options);\n }\n\n return null;\n}\n\n/**\n * Format the given value in bytes into a string.\n *\n * If the value is negative, it is kept as such. If it is a float,\n * it is rounded.\n *\n * @param {number} value\n * @param {object} [options]\n * @param {number} [options.decimalPlaces=2]\n * @param {number} [options.fixedDecimals=false]\n * @param {string} [options.thousandsSeparator=]\n * @param {string} [options.unit=]\n * @param {string} [options.unitSeparator=]\n *\n * @returns {string|null}\n * @public\n */\n\nfunction format(value, options) {\n if (!Number.isFinite(value)) {\n return null;\n }\n\n var mag = Math.abs(value);\n var thousandsSeparator = (options && options.thousandsSeparator) || '';\n var unitSeparator = (options && options.unitSeparator) || '';\n var decimalPlaces = (options && options.decimalPlaces !== undefined) ? options.decimalPlaces : 2;\n var fixedDecimals = Boolean(options && options.fixedDecimals);\n var unit = (options && options.unit) || '';\n\n if (!unit || !map[unit.toLowerCase()]) {\n if (mag >= map.pb) {\n unit = 'PB';\n } else if (mag >= map.tb) {\n unit = 'TB';\n } else if (mag >= map.gb) {\n unit = 'GB';\n } else if (mag >= map.mb) {\n unit = 'MB';\n } else if (mag >= map.kb) {\n unit = 'KB';\n } else {\n unit = 'B';\n }\n }\n\n var val = value / map[unit.toLowerCase()];\n var str = val.toFixed(decimalPlaces);\n\n if (!fixedDecimals) {\n str = str.replace(formatDecimalsRegExp, '$1');\n }\n\n if (thousandsSeparator) {\n str = str.split('.').map(function (s, i) {\n return i === 0\n ? s.replace(formatThousandsRegExp, thousandsSeparator)\n : s\n }).join('.');\n }\n\n return str + unitSeparator + unit;\n}\n\n/**\n * Parse the string value into an integer in bytes.\n *\n * If no unit is given, it is assumed the value is in bytes.\n *\n * @param {number|string} val\n *\n * @returns {number|null}\n * @public\n */\n\nfunction parse(val) {\n if (typeof val === 'number' && !isNaN(val)) {\n return val;\n }\n\n if (typeof val !== 'string') {\n return null;\n }\n\n // Test if the string passed is valid\n var results = parseRegExp.exec(val);\n var floatValue;\n var unit = 'b';\n\n if (!results) {\n // Nothing could be extracted from the given string\n floatValue = parseInt(val, 10);\n unit = 'b'\n } else {\n // Retrieve the value and the unit\n floatValue = parseFloat(results[1]);\n unit = results[4].toLowerCase();\n }\n\n return Math.floor(map[unit] * floatValue);\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar debug = require('debug');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\nvar level = require('./utils/level.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:version');\nconst versionKey = new key.Key('version');\nfunction version(store) {\n return {\n async exists() {\n return level.hasWithFallback(versionKey, store.has.bind(store), store);\n },\n async get() {\n const buf = await level.getWithFallback(versionKey, store.get.bind(store), store.has.bind(store), store);\n return parseInt(toString.toString(buf), 10);\n },\n set(version) {\n return store.put(versionKey, fromString.fromString(String(version)));\n },\n async check(expected) {\n const version = await this.get();\n log('comparing version: %s and %s', version, expected);\n const compatibleVersion = version === 6 && expected === 7 || expected === 6 && version === 7;\n return version === expected || compatibleVersion;\n }\n };\n}\n\nexports.version = version;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('../errors.js');\n\nasync function hasWithFallback(key, has, store) {\n const result = await has(key);\n if (result) {\n return result;\n }\n const levelJs = findLevelJs(store);\n if (!levelJs) {\n return false;\n }\n return new Promise((resolve, reject) => {\n const req = levelJs.store('readonly').get(key.toString());\n req.transaction.onabort = () => {\n reject(req.transaction.error);\n };\n req.transaction.oncomplete = () => {\n resolve(Boolean(req.result));\n };\n });\n}\nasync function getWithFallback(key, get, has, store) {\n if (await has(key)) {\n return get(key);\n }\n const levelJs = findLevelJs(store);\n if (!levelJs) {\n throw new errors.NotFoundError();\n }\n return new Promise((resolve, reject) => {\n const req = levelJs.store('readonly').get(key.toString());\n req.transaction.onabort = () => {\n reject(req.transaction.error);\n };\n req.transaction.oncomplete = () => {\n if (req.result) {\n return resolve(req.result);\n }\n reject(new errors.NotFoundError());\n };\n });\n}\nfunction findLevelJs(store) {\n let db = store;\n while (db.db || db.child) {\n db = db.db || db.child;\n if (db.type === 'level-js' || db.constructor.name === 'Level') {\n return db;\n }\n }\n}\n\nexports.getWithFallback = getWithFallback;\nexports.hasWithFallback = hasWithFallback;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass LockExistsError extends Error {\n constructor(message) {\n super(message);\n this.name = 'LockExistsError';\n this.code = LockExistsError.code;\n }\n}\nLockExistsError.code = 'ERR_LOCK_EXISTS';\nclass NotFoundError extends Error {\n constructor(message) {\n super(message);\n this.name = 'NotFoundError';\n this.code = NotFoundError.code;\n }\n}\nNotFoundError.code = 'ERR_NOT_FOUND';\nclass InvalidRepoVersionError extends Error {\n constructor(message) {\n super(message);\n this.name = 'InvalidRepoVersionError';\n this.code = InvalidRepoVersionError.code;\n }\n}\nInvalidRepoVersionError.code = 'ERR_INVALID_REPO_VERSION';\nconst ERR_REPO_NOT_INITIALIZED = 'ERR_REPO_NOT_INITIALIZED';\nconst ERR_REPO_ALREADY_OPEN = 'ERR_REPO_ALREADY_OPEN';\nconst ERR_REPO_ALREADY_CLOSED = 'ERR_REPO_ALREADY_CLOSED';\n\nexports.ERR_REPO_ALREADY_CLOSED = ERR_REPO_ALREADY_CLOSED;\nexports.ERR_REPO_ALREADY_OPEN = ERR_REPO_ALREADY_OPEN;\nexports.ERR_REPO_NOT_INITIALIZED = ERR_REPO_NOT_INITIALIZED;\nexports.InvalidRepoVersionError = InvalidRepoVersionError;\nexports.LockExistsError = LockExistsError;\nexports.NotFoundError = NotFoundError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar PQueue = require('p-queue');\nvar _get = require('just-safe-get');\nvar _set = require('just-safe-set');\nvar errCode = require('err-code');\nvar errors = require('./errors.js');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\nvar level = require('./utils/level.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PQueue__default = /*#__PURE__*/_interopDefaultLegacy(PQueue);\nvar _get__default = /*#__PURE__*/_interopDefaultLegacy(_get);\nvar _set__default = /*#__PURE__*/_interopDefaultLegacy(_set);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst Queue = PQueue__default[\"default\"].default ? PQueue__default[\"default\"].default : PQueue__default[\"default\"];\nconst configKey = new key.Key('config');\nfunction config(store) {\n const setQueue = new Queue({ concurrency: 1 });\n const configStore = {\n async getAll(options = {}) {\n const encodedValue = await level.getWithFallback(configKey, store.get.bind(store), store.has.bind(store), store);\n return JSON.parse(toString.toString(encodedValue));\n },\n async get(key, options = {}) {\n if (key == null) {\n throw new errors.NotFoundError(`Key ${ key } does not exist in config`);\n }\n const config = await this.getAll(options);\n const value = _get__default[\"default\"](config, key);\n if (value === undefined) {\n throw new errors.NotFoundError(`Key ${ key } does not exist in config`);\n }\n return value;\n },\n set(key, value, options = {}) {\n if (typeof key !== 'string' && !(key instanceof String)) {\n throw errCode__default[\"default\"](new Error('Invalid key type: ' + typeof key), 'ERR_INVALID_KEY');\n }\n if (value === undefined || value instanceof Uint8Array) {\n throw errCode__default[\"default\"](new Error('Invalid value type: ' + typeof value), 'ERR_INVALID_VALUE');\n }\n return setQueue.add(() => _maybeDoSet({\n key: key,\n value: value\n }, options.signal));\n },\n replace(value, options = {}) {\n if (!value || value instanceof Uint8Array) {\n throw errCode__default[\"default\"](new Error('Invalid value type: ' + typeof value), 'ERR_INVALID_VALUE');\n }\n return setQueue.add(() => _maybeDoSet({\n key: undefined,\n value: value\n }, options.signal));\n },\n async exists() {\n return level.hasWithFallback(configKey, store.has.bind(store), store);\n }\n };\n return configStore;\n async function _maybeDoSet(m, signal) {\n if (signal && signal.aborted) {\n return;\n }\n const key = m.key;\n const value = m.value;\n if (key) {\n const config = await configStore.getAll();\n if (typeof config === 'object' && config !== null) {\n _set__default[\"default\"](config, key, value);\n }\n return _saveAll(config);\n }\n return _saveAll(value);\n }\n function _saveAll(config) {\n const buf = fromString.fromString(JSON.stringify(config, null, 2));\n return store.put(configKey, buf);\n }\n}\n\nexports.config = config;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar sortKeys = require('sort-keys');\nvar toString = require('uint8arrays/to-string');\nvar fromString = require('uint8arrays/from-string');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar sortKeys__default = /*#__PURE__*/_interopDefaultLegacy(sortKeys);\n\nconst specKey = new interfaceDatastore.Key('datastore_spec');\nfunction spec(store) {\n return {\n exists() {\n return store.has(specKey);\n },\n async get() {\n const buf = await store.get(specKey);\n return JSON.parse(toString.toString(buf));\n },\n async set(spec) {\n return store.put(specKey, fromString.fromString(JSON.stringify(sortKeys__default[\"default\"](spec, { deep: true }))));\n }\n };\n}\n\nexports.spec = spec;\n","'use strict';\nconst isPlainObject = require('is-plain-obj');\n\nmodule.exports = (object, options = {}) => {\n\tif (!isPlainObject(object) && !Array.isArray(object)) {\n\t\tthrow new TypeError('Expected a plain object or array');\n\t}\n\n\tconst {deep} = options;\n\tconst seenInput = [];\n\tconst seenOutput = [];\n\n\tconst deepSortArray = array => {\n\t\tconst seenIndex = seenInput.indexOf(array);\n\n\t\tif (seenIndex !== -1) {\n\t\t\treturn seenOutput[seenIndex];\n\t\t}\n\n\t\tconst result = [];\n\t\tseenInput.push(array);\n\t\tseenOutput.push(result);\n\n\t\tresult.push(...array.map(item => {\n\t\t\tif (Array.isArray(item)) {\n\t\t\t\treturn deepSortArray(item);\n\t\t\t}\n\n\t\t\tif (isPlainObject(item)) {\n\t\t\t\treturn sortKeys(item);\n\t\t\t}\n\n\t\t\treturn item;\n\t\t}));\n\n\t\treturn result;\n\t};\n\n\tconst sortKeys = object => {\n\t\tconst seenIndex = seenInput.indexOf(object);\n\n\t\tif (seenIndex !== -1) {\n\t\t\treturn seenOutput[seenIndex];\n\t\t}\n\n\t\tconst result = {};\n\t\tconst keys = Object.keys(object).sort(options.compare);\n\n\t\tseenInput.push(object);\n\t\tseenOutput.push(result);\n\n\t\tfor (const key of keys) {\n\t\t\tconst value = object[key];\n\t\t\tlet newValue;\n\n\t\t\tif (deep && Array.isArray(value)) {\n\t\t\t\tnewValue = deepSortArray(value);\n\t\t\t} else {\n\t\t\t\tnewValue = deep && isPlainObject(value) ? sortKeys(value) : value;\n\t\t\t}\n\n\t\t\tObject.defineProperty(result, key, {\n\t\t\t\t...Object.getOwnPropertyDescriptor(object, key),\n\t\t\t\tvalue: newValue\n\t\t\t});\n\t\t}\n\n\t\treturn result;\n\t};\n\n\tif (Array.isArray(object)) {\n\t\treturn deep ? deepSortArray(object) : object.slice();\n\t}\n\n\treturn sortKeys(object);\n};\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar fromString = require('uint8arrays/from-string');\n\nconst apiFile = new key.Key('api');\nfunction apiAddr(store) {\n return {\n async get() {\n const value = await store.get(apiFile);\n return value && value.toString();\n },\n set(value) {\n return store.put(apiFile, fromString.fromString(value.toString()));\n },\n delete() {\n return store.delete(apiFile);\n }\n };\n}\n\nexports.apiAddr = apiAddr;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar filter = require('it-filter');\nvar pushable = require('it-pushable');\nvar drain = require('it-drain');\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\nvar identity = require('multiformats/hashes/identity');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar pushable__default = /*#__PURE__*/_interopDefaultLegacy(pushable);\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction createIdStore(store) {\n return {\n open() {\n return store.open();\n },\n close() {\n return store.close();\n },\n query(query, options) {\n return store.query(query, options);\n },\n queryKeys(query, options) {\n return store.queryKeys(query, options);\n },\n async get(cid, options) {\n const extracted = extractContents(cid);\n if (extracted.isIdentity) {\n return Promise.resolve(extracted.digest);\n }\n return store.get(cid, options);\n },\n async *getMany(cids, options) {\n for await (const cid of cids) {\n yield this.get(cid, options);\n }\n },\n async put(cid, buf, options) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return;\n }\n await store.put(cid, buf, options);\n },\n async *putMany(pairs, options) {\n const output = pushable__default[\"default\"]();\n const runner = globalThis.process && globalThis.process.nextTick ? globalThis.process.nextTick : globalThis.setImmediate || globalThis.setTimeout;\n runner(async () => {\n try {\n await drain__default[\"default\"](store.putMany(async function* () {\n for await (const {key, value} of pairs) {\n if (!extractContents(key).isIdentity) {\n yield {\n key,\n value\n };\n }\n output.push({\n key,\n value\n });\n }\n }()));\n output.end();\n } catch (err) {\n output.end(err);\n }\n });\n yield* output;\n },\n has(cid, options) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return Promise.resolve(true);\n }\n return store.has(cid, options);\n },\n delete(cid, options) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return Promise.resolve();\n }\n return store.delete(cid, options);\n },\n deleteMany(cids, options) {\n return store.deleteMany(filter__default[\"default\"](cids, cid => !extractContents(cid).isIdentity), options);\n },\n batch() {\n const batch = store.batch();\n return {\n put(cid, buf) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return;\n }\n batch.put(cid, buf);\n },\n delete(cid) {\n const {isIdentity} = extractContents(cid);\n if (isIdentity) {\n return;\n }\n batch.delete(cid);\n },\n commit: options => {\n return batch.commit(options);\n }\n };\n }\n };\n}\nfunction extractContents(k) {\n const cid$1 = cid.CID.asCID(k);\n if (cid$1 == null) {\n throw errCode__default[\"default\"](new Error('Not a valid cid'), 'ERR_INVALID_CID');\n }\n if (cid$1.multihash.code !== identity.identity.code) {\n return { isIdentity: false };\n }\n return {\n isIdentity: true,\n digest: cid$1.multihash.digest\n };\n}\n\nexports.createIdStore = createIdStore;\n","'use strict';\n\nvar memory = require('./locks/memory.js');\n\nvar defaultOptions = {\n autoMigrate: true,\n onMigrationProgress: () => {\n },\n repoOwner: true,\n repoLock: memory.MemoryLock\n};\n\nmodule.exports = defaultOptions;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('../errors.js');\nvar debug = require('debug');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:lock:memory');\nconst lockFile = 'repo.lock';\nconst LOCKS = {};\nasync function lock(dir) {\n const file = dir + '/' + lockFile;\n log('locking %s', file);\n if (LOCKS[file] === true) {\n throw new errors.LockExistsError(`Lock already being held for file: ${ file }`);\n }\n LOCKS[file] = true;\n const closer = {\n async close() {\n if (LOCKS[file]) {\n delete LOCKS[file];\n }\n }\n };\n return closer;\n}\nasync function locked(dir) {\n const file = dir + '/' + lockFile;\n log(`checking lock: ${ file }`);\n return Boolean(LOCKS[file]);\n}\nconst MemoryLock = {\n lock,\n locked\n};\n\nexports.MemoryLock = MemoryLock;\n","'use strict';\n\nvar defaultDatastore = {\n Spec: {\n type: 'mount',\n mounts: [\n {\n mountpoint: '/blocks',\n type: 'measure',\n prefix: 'flatfs.datastore',\n child: {\n type: 'flatfs',\n path: 'blocks',\n sync: true,\n shardFunc: '/repo/flatfs/shard/v1/next-to-last/2'\n }\n },\n {\n mountpoint: '/',\n type: 'measure',\n prefix: 'leveldb.datastore',\n child: {\n type: 'levelds',\n path: 'datastore',\n compression: 'none'\n }\n }\n ]\n }\n};\n\nmodule.exports = defaultDatastore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\nvar debug = require('debug');\nvar first = require('it-first');\nvar block = require('multiformats/block');\nvar cborg = require('cborg');\nvar dagPb = require('@ipld/dag-pb');\nvar blockstore = require('./utils/blockstore.js');\nvar walkDag = require('./utils/walk-dag.js');\nvar pinTypes = require('./pin-types.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar first__default = /*#__PURE__*/_interopDefaultLegacy(first);\nvar cborg__namespace = /*#__PURE__*/_interopNamespace(cborg);\nvar dagPb__namespace = /*#__PURE__*/_interopNamespace(dagPb);\n\nfunction invalidPinTypeErr(type) {\n const errMsg = `Invalid type '${ type }', must be one of {direct, indirect, recursive, all}`;\n return errCode__default[\"default\"](new Error(errMsg), 'ERR_INVALID_PIN_TYPE');\n}\nclass PinManager {\n constructor({pinstore, blockstore, loadCodec}) {\n this.pinstore = pinstore;\n this.blockstore = blockstore;\n this.loadCodec = loadCodec;\n this.log = debug__default[\"default\"]('ipfs:repo:pin');\n this.directPins = new Set();\n this.recursivePins = new Set();\n }\n async pinDirectly(cid, options = {}) {\n await this.blockstore.get(cid, options);\n const pin = { depth: 0 };\n if (cid.version !== 0) {\n pin.version = cid.version;\n }\n if (cid.code !== dagPb__namespace.code) {\n pin.codec = cid.code;\n }\n if (options.metadata) {\n pin.metadata = options.metadata;\n }\n return this.pinstore.put(blockstore.cidToKey(cid), cborg__namespace.encode(pin));\n }\n unpin(cid, options) {\n return this.pinstore.delete(blockstore.cidToKey(cid), options);\n }\n async pinRecursively(cid, options = {}) {\n await this.fetchCompleteDag(cid, options);\n const pin = { depth: Infinity };\n if (cid.version !== 0) {\n pin.version = cid.version;\n }\n if (cid.code !== dagPb__namespace.code) {\n pin.codec = cid.code;\n }\n if (options.metadata) {\n pin.metadata = options.metadata;\n }\n await this.pinstore.put(blockstore.cidToKey(cid), cborg__namespace.encode(pin));\n }\n async *directKeys(options) {\n for await (const entry of this.pinstore.query({\n filters: [entry => {\n const pin = cborg__namespace.decode(entry.value);\n return pin.depth === 0;\n }]\n })) {\n const pin = cborg__namespace.decode(entry.value);\n const version = pin.version || 0;\n const codec = pin.codec != null ? pin.codec : dagPb__namespace.code;\n const multihash = blockstore.keyToMultihash(entry.key);\n yield {\n cid: cid.CID.create(version, codec, multihash),\n metadata: pin.metadata\n };\n }\n }\n async *recursiveKeys(options) {\n for await (const entry of this.pinstore.query({\n filters: [entry => {\n const pin = cborg__namespace.decode(entry.value);\n return pin.depth === Infinity;\n }]\n })) {\n const pin = cborg__namespace.decode(entry.value);\n const version = pin.version || 0;\n const codec = pin.codec != null ? pin.codec : dagPb__namespace.code;\n const multihash = blockstore.keyToMultihash(entry.key);\n yield {\n cid: cid.CID.create(version, codec, multihash),\n metadata: pin.metadata\n };\n }\n }\n async *indirectKeys(options) {\n for await (const {cid} of this.recursiveKeys()) {\n for await (const childCid of walkDag.walkDag(cid, this.blockstore, this.loadCodec, options)) {\n const types = [pinTypes.PinTypes.recursive];\n const result = await this.isPinnedWithType(childCid, types);\n if (result.pinned) {\n continue;\n }\n yield childCid;\n }\n }\n }\n async isPinnedWithType(cid, types, options) {\n if (!Array.isArray(types)) {\n types = [types];\n }\n const all = types.includes(pinTypes.PinTypes.all);\n const direct = types.includes(pinTypes.PinTypes.direct);\n const recursive = types.includes(pinTypes.PinTypes.recursive);\n const indirect = types.includes(pinTypes.PinTypes.indirect);\n if (recursive || direct || all) {\n const result = await first__default[\"default\"](this.pinstore.query({\n prefix: blockstore.cidToKey(cid).toString(),\n filters: [entry => {\n if (all) {\n return true;\n }\n const pin = cborg__namespace.decode(entry.value);\n return types.includes(pin.depth === 0 ? pinTypes.PinTypes.direct : pinTypes.PinTypes.recursive);\n }],\n limit: 1\n }));\n if (result) {\n const pin = cborg__namespace.decode(result.value);\n return {\n cid,\n pinned: true,\n reason: pin.depth === 0 ? pinTypes.PinTypes.direct : pinTypes.PinTypes.recursive,\n metadata: pin.metadata\n };\n }\n }\n const self = this;\n async function* findChild(key, source) {\n for await (const {cid: parentCid} of source) {\n for await (const childCid of walkDag.walkDag(parentCid, self.blockstore, self.loadCodec)) {\n if (childCid.equals(key)) {\n yield parentCid;\n return;\n }\n }\n }\n }\n if (all || indirect) {\n const parentCid = await first__default[\"default\"](findChild(cid, this.recursiveKeys()));\n if (parentCid) {\n return {\n cid,\n pinned: true,\n reason: pinTypes.PinTypes.indirect,\n parent: parentCid\n };\n }\n }\n return {\n cid,\n pinned: false\n };\n }\n async fetchCompleteDag(cid, options) {\n const seen = new Set();\n const walkDag = async (cid, options) => {\n if (seen.has(cid.toString())) {\n return;\n }\n seen.add(cid.toString());\n const bytes = await this.blockstore.get(cid, options);\n const codec = await this.loadCodec(cid.code);\n const block$1 = block.createUnsafe({\n bytes,\n cid,\n codec\n });\n await Promise.all([...block$1.links()].map(([, childCid]) => walkDag(childCid, options)));\n };\n await walkDag(cid, options);\n }\n static checkPinType(type) {\n if (typeof type !== 'string' || !Object.keys(pinTypes.PinTypes).includes(type)) {\n throw invalidPinTypeErr(type);\n }\n return true;\n }\n}\n\nexports.PinManager = PinManager;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar key = require('interface-datastore/key');\nvar multiformats = require('multiformats');\nvar raw = require('multiformats/codecs/raw');\nvar errCode = require('err-code');\nvar base32 = require('multiformats/bases/base32');\nvar Digest = require('multiformats/hashes/digest');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\n\nfunction cidToKey(c) {\n const cid = multiformats.CID.asCID(c);\n if (cid == null) {\n throw errCode__default[\"default\"](new Error('Not a valid cid'), 'ERR_INVALID_CID');\n }\n const encoded = base32.base32.encode(cid.multihash.bytes);\n return new key.Key('/' + encoded.slice(1).toUpperCase(), false);\n}\nfunction keyToCid(key) {\n return multiformats.CID.createV1(raw__namespace.code, keyToMultihash(key));\n}\nfunction keyToMultihash(key) {\n return Digest__namespace.decode(base32.base32.decode(`b${ key.toString().toLowerCase().substring(1) }`));\n}\n\nexports.cidToKey = cidToKey;\nexports.keyToCid = keyToCid;\nexports.keyToMultihash = keyToMultihash;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar block = require('multiformats/block');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default[\"default\"]('ipfs:repo:utils:walk-dag');\nasync function* walkDag(cid, blockstore, loadCodec, options) {\n try {\n const bytes = await blockstore.get(cid, options);\n const codec = await loadCodec(cid.code);\n const block$1 = block.createUnsafe({\n bytes,\n cid,\n codec\n });\n for (const [, childCid] of block$1.links()) {\n yield childCid;\n yield* walkDag(childCid, blockstore, loadCodec, options);\n }\n } catch (err) {\n log('Could not walk DAG for CID', cid.toString(), err);\n throw err;\n }\n}\n\nexports.walkDag = walkDag;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar map = require('it-map');\nvar errCode = require('err-code');\nvar pinTypes = require('./pin-types.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction createPinnedBlockstore(pins, store) {\n return {\n open() {\n return store.open();\n },\n close() {\n return store.close();\n },\n query(query, options) {\n return store.query(query, options);\n },\n queryKeys(query, options) {\n return store.queryKeys(query, options);\n },\n async get(cid, options) {\n return store.get(cid, options);\n },\n async *getMany(cids, options) {\n yield* store.getMany(cids, options);\n },\n async put(cid, buf, options) {\n await store.put(cid, buf, options);\n },\n async *putMany(pairs, options) {\n yield* store.putMany(pairs, options);\n },\n has(cid, options) {\n return store.has(cid, options);\n },\n async delete(cid, options) {\n await ensureNotPinned(cid, pins);\n return store.delete(cid, options);\n },\n deleteMany(cids, options) {\n return store.deleteMany(map__default[\"default\"](cids, async cid => {\n await ensureNotPinned(cid, pins);\n return cid;\n }), options);\n },\n batch() {\n return store.batch();\n }\n };\n}\nasync function ensureNotPinned(cid, pins) {\n const {pinned, reason} = await pins.isPinnedWithType(cid, pinTypes.PinTypes.all);\n if (pinned) {\n throw errCode__default[\"default\"](new Error(`pinned: ${ reason }`), 'ERR_BLOCK_PINNED');\n }\n}\n\nexports.createPinnedBlockstore = createPinnedBlockstore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar debug = require('debug');\nvar errors = require('datastore-core/errors');\nvar parallelBatch = require('it-parallel-batch');\nvar itPipe = require('it-pipe');\nvar merge = require('it-merge');\nvar map = require('it-map');\nvar filter = require('it-filter');\nvar key = require('interface-datastore/key');\nvar base32 = require('multiformats/bases/base32');\nvar walkDag = require('./utils/walk-dag.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar parallelBatch__default = /*#__PURE__*/_interopDefaultLegacy(parallelBatch);\nvar merge__default = /*#__PURE__*/_interopDefaultLegacy(merge);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\n\nconst log = debug__default[\"default\"]('ipfs:repo:gc');\nconst ERR_NOT_FOUND = errors.notFoundError().code;\nconst BLOCK_RM_CONCURRENCY = 256;\nconst MFS_ROOT_KEY = new key.Key('/local/filesroot');\nfunction gc({gcLock, pins, blockstore, root, loadCodec}) {\n async function* gc() {\n const start = Date.now();\n log('Creating set of marked blocks');\n const release = await gcLock.writeLock();\n try {\n const markedSet = await createMarkedSet({\n pins,\n blockstore,\n root,\n loadCodec\n });\n const blockKeys = blockstore.queryKeys({});\n yield* deleteUnmarkedBlocks({ blockstore }, markedSet, blockKeys);\n log(`Complete (${ Date.now() - start }ms)`);\n } finally {\n release();\n }\n }\n return gc;\n}\nasync function createMarkedSet({pins, blockstore, loadCodec, root}) {\n const mfsSource = async function* () {\n let mh;\n try {\n mh = await root.get(MFS_ROOT_KEY);\n } catch (err) {\n if (err.code === ERR_NOT_FOUND) {\n log('No blocks in MFS');\n return;\n }\n throw err;\n }\n const rootCid = cid.CID.decode(mh);\n yield rootCid;\n yield* walkDag.walkDag(rootCid, blockstore, loadCodec);\n }();\n const pinsSource = merge__default[\"default\"](map__default[\"default\"](pins.recursiveKeys(), ({cid}) => cid), pins.indirectKeys(), map__default[\"default\"](pins.directKeys(), ({cid}) => cid), mfsSource);\n const output = new Set();\n for await (const cid of merge__default[\"default\"](pinsSource, mfsSource)) {\n output.add(base32.base32.encode(cid.multihash.bytes));\n }\n return output;\n}\nasync function* deleteUnmarkedBlocks({blockstore}, markedSet, blockKeys) {\n let blocksCount = 0;\n let removedBlocksCount = 0;\n const removeBlock = async cid => {\n return async function remove() {\n blocksCount++;\n try {\n const b32 = base32.base32.encode(cid.multihash.bytes);\n if (markedSet.has(b32)) {\n return null;\n }\n try {\n await blockstore.delete(cid);\n removedBlocksCount++;\n } catch (err) {\n return { err: new Error(`Could not delete block with CID ${ cid }: ${ err.message }`) };\n }\n return { cid };\n } catch (err) {\n const msg = `Could delete block with CID ${ cid }`;\n log(msg, err);\n return { err: new Error(msg + `: ${ err.message }`) };\n }\n };\n };\n yield* itPipe.pipe(parallelBatch__default[\"default\"](map__default[\"default\"](blockKeys, removeBlock), BLOCK_RM_CONCURRENCY), source => filter__default[\"default\"](source, Boolean));\n log(`Marked set has ${ markedSet.size } unique blocks. Blockstore has ${ blocksCount } blocks. ` + `Deleted ${ removedBlocksCount } blocks.`);\n}\n\nexports.gc = gc;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar interfaceDatastore = require('interface-datastore');\nvar datastoreCore = require('datastore-core');\nvar filter = require('it-filter');\nvar map = require('it-map');\nvar take = require('it-take');\nvar sort = require('it-sort');\nvar Level = require('level');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar map__default = /*#__PURE__*/_interopDefaultLegacy(map);\nvar take__default = /*#__PURE__*/_interopDefaultLegacy(take);\nvar sort__default = /*#__PURE__*/_interopDefaultLegacy(sort);\nvar Level__default = /*#__PURE__*/_interopDefaultLegacy(Level);\n\nclass LevelDatastore extends datastoreCore.BaseDatastore {\n constructor(path, opts) {\n super();\n this.path = path;\n this.opts = opts;\n if (opts && opts.db) {\n this.database = opts.db;\n delete opts.db;\n } else {\n this.database = Level__default['default'];\n }\n }\n _initDb() {\n return new Promise((resolve, reject) => {\n this.db = this.database(this.path, {\n ...this.opts,\n valueEncoding: 'binary',\n compression: false\n }, err => {\n if (err) {\n return reject(err);\n }\n resolve(this.db);\n });\n });\n }\n async open() {\n try {\n if (this.db) {\n await this.db.open();\n } else {\n this.db = await this._initDb();\n }\n } catch (err) {\n throw datastoreCore.Errors.dbOpenFailedError(err);\n }\n }\n async put(key, value) {\n try {\n await this.db.put(key.toString(), value);\n } catch (err) {\n throw datastoreCore.Errors.dbWriteFailedError(err);\n }\n }\n async get(key) {\n let data;\n try {\n data = await this.db.get(key.toString());\n } catch (err) {\n if (err.notFound)\n throw datastoreCore.Errors.notFoundError(err);\n throw datastoreCore.Errors.dbWriteFailedError(err);\n }\n return data;\n }\n async has(key) {\n try {\n await this.db.get(key.toString());\n } catch (err) {\n if (err.notFound)\n return false;\n throw err;\n }\n return true;\n }\n async delete(key) {\n try {\n await this.db.del(key.toString());\n } catch (err) {\n throw datastoreCore.Errors.dbDeleteFailedError(err);\n }\n }\n close() {\n return this.db && this.db.close();\n }\n batch() {\n const ops = [];\n return {\n put: (key, value) => {\n ops.push({\n type: 'put',\n key: key.toString(),\n value: value\n });\n },\n delete: key => {\n ops.push({\n type: 'del',\n key: key.toString()\n });\n },\n commit: () => {\n return this.db.batch(ops);\n }\n };\n }\n query(q) {\n let it = this._query({\n values: true,\n prefix: q.prefix\n });\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => sort__default['default'](it, f), it);\n }\n const {offset, limit} = q;\n if (offset) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= offset);\n }\n if (limit) {\n it = take__default['default'](it, limit);\n }\n return it;\n }\n queryKeys(q) {\n let it = map__default['default'](this._query({\n values: false,\n prefix: q.prefix\n }), ({key}) => key);\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => sort__default['default'](it, f), it);\n }\n const {offset, limit} = q;\n if (offset) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= offset);\n }\n if (limit) {\n it = take__default['default'](it, limit);\n }\n return it;\n }\n _query(opts) {\n const iteratorOpts = {\n keys: true,\n keyAsBuffer: true,\n values: opts.values\n };\n if (opts.prefix != null) {\n const prefix = opts.prefix.toString();\n iteratorOpts.gte = prefix;\n iteratorOpts.lt = prefix + 'ÿ';\n }\n return levelIteratorToIterator(this.db.iterator(iteratorOpts));\n }\n}\nfunction levelIteratorToIterator(li) {\n return {\n [Symbol.asyncIterator]() {\n return {\n next: () => new Promise((resolve, reject) => {\n li.next((err, key, value) => {\n if (err)\n return reject(err);\n if (key == null) {\n return li.end(err => {\n if (err)\n return reject(err);\n resolve({\n done: true,\n value: undefined\n });\n });\n }\n resolve({\n done: false,\n value: {\n key: new interfaceDatastore.Key(key, false),\n value\n }\n });\n });\n }),\n return: () => new Promise((resolve, reject) => {\n li.end(err => {\n if (err)\n return reject(err);\n resolve({\n done: true,\n value: undefined\n });\n });\n })\n };\n }\n };\n}\n\nexports.LevelDatastore = LevelDatastore;\n","'use strict'\n\nconst all = require('it-all')\n\n/**\n * Collects all values from an async iterator, sorts them\n * using the passed function and yields them\n *\n * @template T\n * @param {AsyncIterable<T> | Iterable<T>} source\n * @param {(a: T, b: T) => -1 | 0 | 1} sorter\n */\nconst sort = async function * (source, sorter) {\n const arr = await all(source)\n\n yield * arr.sort(sorter)\n}\n\nmodule.exports = sort\n","module.exports = require('level-packager')(require('level-js'))\n","'use strict'\n\nconst levelup = require('levelup')\nconst encode = require('encoding-down')\n\nfunction packager (leveldown) {\n function Level (location, options, callback) {\n if (typeof location === 'function') {\n callback = location\n } else if (typeof options === 'function') {\n callback = options\n }\n\n if (!isObject(options)) {\n options = isObject(location) ? location : {}\n }\n\n return levelup(encode(leveldown(location, options), options), options, callback)\n }\n\n function isObject (o) {\n return typeof o === 'object' && o !== null\n }\n\n for (const m of ['destroy', 'repair']) {\n if (typeof leveldown[m] === 'function') {\n Level[m] = function (...args) {\n leveldown[m](...args)\n }\n }\n }\n\n Level.errors = levelup.errors\n\n return Level\n}\n\nmodule.exports = packager\n","'use strict'\n\nconst EventEmitter = require('events').EventEmitter\nconst inherits = require('util').inherits\nconst DeferredLevelDOWN = require('deferred-leveldown')\nconst IteratorStream = require('level-iterator-stream')\nconst Batch = require('./batch')\nconst errors = require('level-errors')\nconst supports = require('level-supports')\nconst catering = require('catering')\nconst getCallback = require('./common').getCallback\nconst getOptions = require('./common').getOptions\n\n// TODO: after we drop node 10, also use queueMicrotask() in node\nconst nextTick = require('./next-tick')\n\nconst WriteError = errors.WriteError\nconst ReadError = errors.ReadError\nconst NotFoundError = errors.NotFoundError\nconst OpenError = errors.OpenError\nconst InitializationError = errors.InitializationError\n\nfunction LevelUP (db, options, callback) {\n if (!(this instanceof LevelUP)) {\n return new LevelUP(db, options, callback)\n }\n\n let error\n\n EventEmitter.call(this)\n this.setMaxListeners(Infinity)\n\n if (typeof options === 'function') {\n callback = options\n options = {}\n }\n\n options = options || {}\n\n if (!db || typeof db !== 'object') {\n error = new InitializationError('First argument must be an abstract-leveldown compliant store')\n if (typeof callback === 'function') {\n return nextTick(callback, error)\n }\n throw error\n }\n\n if (typeof db.status !== 'string') {\n throw new Error('.status required, old abstract-leveldown')\n }\n\n this.options = getOptions(options)\n this._db = db\n this.db = null\n this.open(callback || ((err) => {\n if (err) this.emit('error', err)\n }))\n\n // Create manifest based on deferred-leveldown's\n this.supports = supports(this.db.supports, {\n status: true,\n deferredOpen: true,\n openCallback: true,\n promises: true,\n streams: true\n })\n\n // Experimental: enrich levelup interface\n for (const method of Object.keys(this.supports.additionalMethods)) {\n if (this[method] != null) continue\n\n // Don't do this.db[method].bind() because this.db is dynamic.\n this[method] = function (...args) {\n return this.db[method](...args)\n }\n }\n}\n\nLevelUP.prototype.emit = EventEmitter.prototype.emit\nLevelUP.prototype.once = EventEmitter.prototype.once\ninherits(LevelUP, EventEmitter)\n\n// TODO: tests\nObject.defineProperty(LevelUP.prototype, 'status', {\n enumerable: true,\n get () {\n return this.db.status\n }\n})\n\n// TODO: tests\nLevelUP.prototype.isOperational = function () {\n return this.db.status === 'open' || this.db.status === 'opening'\n}\n\nLevelUP.prototype.open = function (opts, callback) {\n if (typeof opts === 'function') {\n callback = opts\n opts = null\n }\n\n callback = catering.fromCallback(callback)\n\n if (!opts) {\n opts = this.options\n }\n\n // 1) Don't check db.status until levelup has opened,\n // in order for levelup events to be consistent\n if (this.db && this.isOpen()) {\n nextTick(callback, null, this)\n return callback.promise\n }\n\n if (this.db && this._isOpening()) {\n this.once('open', () => { callback(null, this) })\n return callback.promise\n }\n\n // 2) Instead let deferred-leveldown handle already-open cases.\n // TODO: ideally though, levelup would have its own status\n this.db = new DeferredLevelDOWN(this._db)\n this.emit('opening')\n\n this.db.open(opts, (err) => {\n if (err) {\n return callback(new OpenError(err))\n }\n this.db = this._db\n callback(null, this)\n this.emit('open')\n this.emit('ready')\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.close = function (callback) {\n callback = catering.fromCallback(callback)\n\n if (this.isOpen()) {\n this.db.close((err, ...rest) => {\n this.emit('closed')\n callback(err, ...rest)\n })\n this.emit('closing')\n } else if (this.isClosed()) {\n nextTick(callback)\n } else if (this.db.status === 'closing') {\n this.once('closed', callback)\n } else if (this._isOpening()) {\n this.once('open', () => {\n this.close(callback)\n })\n }\n\n return callback.promise\n}\n\n// TODO: remove in future major\nLevelUP.prototype.isOpen = function () {\n return this.db.status === 'open'\n}\n\n// TODO: remove in future major\nLevelUP.prototype._isOpening = function () {\n return this.db.status === 'opening'\n}\n\n// TODO: remove in future major\nLevelUP.prototype.isClosed = function () {\n return (/^clos|new/).test(this.db.status)\n}\n\nLevelUP.prototype.get = function (key, options, callback) {\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n options = getOptions(options)\n\n this.db.get(key, options, function (err, value) {\n if (err) {\n if ((/notfound/i).test(err) || err.notFound) {\n err = new NotFoundError('Key not found in database [' + key + ']', err)\n } else {\n err = new ReadError(err)\n }\n return callback(err)\n }\n callback(null, value)\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.getMany = function (keys, options, callback) {\n return this.db.getMany(keys, options, callback)\n}\n\nLevelUP.prototype.put = function (key, value, options, callback) {\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n options = getOptions(options)\n\n this.db.put(key, value, options, (err) => {\n if (err) {\n return callback(new WriteError(err))\n }\n this.emit('put', key, value)\n callback()\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.del = function (key, options, callback) {\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n options = getOptions(options)\n\n this.db.del(key, options, (err) => {\n if (err) {\n return callback(new WriteError(err))\n }\n this.emit('del', key)\n callback()\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.batch = function (arr, options, callback) {\n if (!arguments.length) {\n return new Batch(this)\n }\n\n if (typeof arr === 'function') callback = arr\n else callback = getCallback(options, callback)\n\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n options = getOptions(options)\n\n this.db.batch(arr, options, (err) => {\n if (err) {\n return callback(new WriteError(err))\n }\n this.emit('batch', arr)\n callback()\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.iterator = function (options) {\n return this.db.iterator(options)\n}\n\nLevelUP.prototype.clear = function (options, callback) {\n callback = getCallback(options, callback)\n options = getOptions(options)\n callback = catering.fromCallback(callback)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n this.db.clear(options, (err) => {\n if (err) {\n return callback(new WriteError(err))\n }\n this.emit('clear', options)\n callback()\n })\n\n return callback.promise\n}\n\nLevelUP.prototype.readStream =\nLevelUP.prototype.createReadStream = function (options) {\n options = Object.assign({ keys: true, values: true }, options)\n if (typeof options.limit !== 'number') { options.limit = -1 }\n return new IteratorStream(this.db.iterator(options), options)\n}\n\nLevelUP.prototype.keyStream =\nLevelUP.prototype.createKeyStream = function (options) {\n return this.createReadStream(Object.assign({}, options, { keys: true, values: false }))\n}\n\nLevelUP.prototype.valueStream =\nLevelUP.prototype.createValueStream = function (options) {\n return this.createReadStream(Object.assign({}, options, { keys: false, values: true }))\n}\n\nLevelUP.prototype.toString = function () {\n return 'LevelUP'\n}\n\nLevelUP.prototype.type = 'levelup'\n\n// Expose nextTick for API parity with abstract-leveldown\nLevelUP.prototype._nextTick = nextTick\n\nfunction maybeError (db, callback) {\n if (!db.isOperational()) {\n nextTick(callback, new ReadError('Database is not open'))\n return true\n }\n\n return false\n}\n\nLevelUP.errors = errors\nmodule.exports = LevelUP\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors ||\n function getOwnPropertyDescriptors(obj) {\n var keys = Object.keys(obj);\n var descriptors = {};\n for (var i = 0; i < keys.length; i++) {\n descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);\n }\n return descriptors;\n };\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n if (!isString(f)) {\n var objects = [];\n for (var i = 0; i < arguments.length; i++) {\n objects.push(inspect(arguments[i]));\n }\n return objects.join(' ');\n }\n\n var i = 1;\n var args = arguments;\n var len = args.length;\n var str = String(f).replace(formatRegExp, function(x) {\n if (x === '%%') return '%';\n if (i >= len) return x;\n switch (x) {\n case '%s': return String(args[i++]);\n case '%d': return Number(args[i++]);\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n default:\n return x;\n }\n });\n for (var x = args[i]; i < len; x = args[++i]) {\n if (isNull(x) || !isObject(x)) {\n str += ' ' + x;\n } else {\n str += ' ' + inspect(x);\n }\n }\n return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n if (typeof process !== 'undefined' && process.noDeprecation === true) {\n return fn;\n }\n\n // Allow for deprecating things in the process of starting up.\n if (typeof process === 'undefined') {\n return function() {\n return exports.deprecate(fn, msg).apply(this, arguments);\n };\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (process.throwDeprecation) {\n throw new Error(msg);\n } else if (process.traceDeprecation) {\n console.trace(msg);\n } else {\n console.error(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnvRegex = /^$/;\n\nif (process.env.NODE_DEBUG) {\n var debugEnv = process.env.NODE_DEBUG;\n debugEnv = debugEnv.replace(/[|\\\\{}()[\\]^$+?.]/g, '\\\\$&')\n .replace(/\\*/g, '.*')\n .replace(/,/g, '$|^')\n .toUpperCase();\n debugEnvRegex = new RegExp('^' + debugEnv + '$', 'i');\n}\nexports.debuglog = function(set) {\n set = set.toUpperCase();\n if (!debugs[set]) {\n if (debugEnvRegex.test(set)) {\n var pid = process.pid;\n debugs[set] = function() {\n var msg = exports.format.apply(exports, arguments);\n console.error('%s %d: %s', set, pid, msg);\n };\n } else {\n debugs[set] = function() {};\n }\n }\n return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n // default options\n var ctx = {\n seen: [],\n stylize: stylizeNoColor\n };\n // legacy...\n if (arguments.length >= 3) ctx.depth = arguments[2];\n if (arguments.length >= 4) ctx.colors = arguments[3];\n if (isBoolean(opts)) {\n // legacy...\n ctx.showHidden = opts;\n } else if (opts) {\n // got an \"options\" object\n exports._extend(ctx, opts);\n }\n // set default options\n if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n if (isUndefined(ctx.depth)) ctx.depth = 2;\n if (isUndefined(ctx.colors)) ctx.colors = false;\n if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n if (ctx.colors) ctx.stylize = stylizeWithColor;\n return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n 'bold' : [1, 22],\n 'italic' : [3, 23],\n 'underline' : [4, 24],\n 'inverse' : [7, 27],\n 'white' : [37, 39],\n 'grey' : [90, 39],\n 'black' : [30, 39],\n 'blue' : [34, 39],\n 'cyan' : [36, 39],\n 'green' : [32, 39],\n 'magenta' : [35, 39],\n 'red' : [31, 39],\n 'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n 'special': 'cyan',\n 'number': 'yellow',\n 'boolean': 'yellow',\n 'undefined': 'grey',\n 'null': 'bold',\n 'string': 'green',\n 'date': 'magenta',\n // \"name\": intentionally not styling\n 'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n var style = inspect.styles[styleType];\n\n if (style) {\n return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n '\\u001b[' + inspect.colors[style][1] + 'm';\n } else {\n return str;\n }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n return str;\n}\n\n\nfunction arrayToHash(array) {\n var hash = {};\n\n array.forEach(function(val, idx) {\n hash[val] = true;\n });\n\n return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n // Provide a hook for user-specified inspect functions.\n // Check that value is an object with an inspect function on it\n if (ctx.customInspect &&\n value &&\n isFunction(value.inspect) &&\n // Filter out the util module, it's inspect function is special\n value.inspect !== exports.inspect &&\n // Also filter out any prototype objects using the circular check.\n !(value.constructor && value.constructor.prototype === value)) {\n var ret = value.inspect(recurseTimes, ctx);\n if (!isString(ret)) {\n ret = formatValue(ctx, ret, recurseTimes);\n }\n return ret;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n\n if (ctx.showHidden) {\n keys = Object.getOwnPropertyNames(value);\n }\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (isError(value)\n && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n\n var base = '', array = false, braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n\n ctx.seen.push(value);\n\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function(key) {\n return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n });\n }\n\n ctx.seen.pop();\n\n return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n if (isUndefined(value))\n return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n .replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"') + '\\'';\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value))\n return ctx.stylize('' + value, 'number');\n if (isBoolean(value))\n return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value))\n return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n String(i), true));\n } else {\n output.push('');\n }\n }\n keys.forEach(function(key) {\n if (!key.match(/^\\d+$/)) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n key, true));\n }\n });\n return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n').substr(2);\n } else {\n str = '\\n' + str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.substr(1, name.length - 2);\n name = ctx.stylize(name, 'name');\n } else {\n name = name.replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"')\n .replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n\n return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function(prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n\n if (length > 60) {\n return braces[0] +\n (base === '' ? '' : base + '\\n ') +\n ' ' +\n output.join(',\\n ') +\n ' ' +\n braces[1];\n }\n\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nexports.types = require('./support/types');\n\nfunction isArray(ar) {\n return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\nexports.types.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\nexports.types.isDate = isDate;\n\nfunction isError(e) {\n return isObject(e) &&\n (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\nexports.types.isNativeError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n 'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n var d = new Date();\n var time = [pad(d.getHours()),\n pad(d.getMinutes()),\n pad(d.getSeconds())].join(':');\n return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n * prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n // Don't do anything if add isn't an object\n if (!add || !isObject(add)) return origin;\n\n var keys = Object.keys(add);\n var i = keys.length;\n while (i--) {\n origin[keys[i]] = add[keys[i]];\n }\n return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nvar kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;\n\nexports.promisify = function promisify(original) {\n if (typeof original !== 'function')\n throw new TypeError('The \"original\" argument must be of type Function');\n\n if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {\n var fn = original[kCustomPromisifiedSymbol];\n if (typeof fn !== 'function') {\n throw new TypeError('The \"util.promisify.custom\" argument must be of type Function');\n }\n Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return fn;\n }\n\n function fn() {\n var promiseResolve, promiseReject;\n var promise = new Promise(function (resolve, reject) {\n promiseResolve = resolve;\n promiseReject = reject;\n });\n\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n args.push(function (err, value) {\n if (err) {\n promiseReject(err);\n } else {\n promiseResolve(value);\n }\n });\n\n try {\n original.apply(this, args);\n } catch (err) {\n promiseReject(err);\n }\n\n return promise;\n }\n\n Object.setPrototypeOf(fn, Object.getPrototypeOf(original));\n\n if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return Object.defineProperties(\n fn,\n getOwnPropertyDescriptors(original)\n );\n}\n\nexports.promisify.custom = kCustomPromisifiedSymbol\n\nfunction callbackifyOnRejected(reason, cb) {\n // `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).\n // Because `null` is a special error value in callbacks which means \"no error\n // occurred\", we error-wrap so the callback consumer can distinguish between\n // \"the promise rejected with null\" or \"the promise fulfilled with undefined\".\n if (!reason) {\n var newReason = new Error('Promise was rejected with a falsy value');\n newReason.reason = reason;\n reason = newReason;\n }\n return cb(reason);\n}\n\nfunction callbackify(original) {\n if (typeof original !== 'function') {\n throw new TypeError('The \"original\" argument must be of type Function');\n }\n\n // We DO NOT return the promise as it gives the user a false sense that\n // the promise is actually somehow related to the callback's execution\n // and that the callback throwing will reject the promise.\n function callbackified() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n\n var maybeCb = args.pop();\n if (typeof maybeCb !== 'function') {\n throw new TypeError('The last argument must be of type Function');\n }\n var self = this;\n var cb = function() {\n return maybeCb.apply(self, arguments);\n };\n // In true node style we process the callback on `nextTick` with all the\n // implications (stack, `uncaughtException`, `async_hooks`)\n original.apply(this, args)\n .then(function(ret) { process.nextTick(cb.bind(null, null, ret)) },\n function(rej) { process.nextTick(callbackifyOnRejected.bind(null, rej, cb)) });\n }\n\n Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));\n Object.defineProperties(callbackified,\n getOwnPropertyDescriptors(original));\n return callbackified;\n}\nexports.callbackify = callbackify;\n","// Currently in sync with Node.js lib/internal/util/types.js\n// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9\n\n'use strict';\n\nvar isArgumentsObject = require('is-arguments');\nvar isGeneratorFunction = require('is-generator-function');\nvar whichTypedArray = require('which-typed-array');\nvar isTypedArray = require('is-typed-array');\n\nfunction uncurryThis(f) {\n return f.call.bind(f);\n}\n\nvar BigIntSupported = typeof BigInt !== 'undefined';\nvar SymbolSupported = typeof Symbol !== 'undefined';\n\nvar ObjectToString = uncurryThis(Object.prototype.toString);\n\nvar numberValue = uncurryThis(Number.prototype.valueOf);\nvar stringValue = uncurryThis(String.prototype.valueOf);\nvar booleanValue = uncurryThis(Boolean.prototype.valueOf);\n\nif (BigIntSupported) {\n var bigIntValue = uncurryThis(BigInt.prototype.valueOf);\n}\n\nif (SymbolSupported) {\n var symbolValue = uncurryThis(Symbol.prototype.valueOf);\n}\n\nfunction checkBoxedPrimitive(value, prototypeValueOf) {\n if (typeof value !== 'object') {\n return false;\n }\n try {\n prototypeValueOf(value);\n return true;\n } catch(e) {\n return false;\n }\n}\n\nexports.isArgumentsObject = isArgumentsObject;\nexports.isGeneratorFunction = isGeneratorFunction;\nexports.isTypedArray = isTypedArray;\n\n// Taken from here and modified for better browser support\n// https://github.com/sindresorhus/p-is-promise/blob/cda35a513bda03f977ad5cde3a079d237e82d7ef/index.js\nfunction isPromise(input) {\n\treturn (\n\t\t(\n\t\t\ttypeof Promise !== 'undefined' &&\n\t\t\tinput instanceof Promise\n\t\t) ||\n\t\t(\n\t\t\tinput !== null &&\n\t\t\ttypeof input === 'object' &&\n\t\t\ttypeof input.then === 'function' &&\n\t\t\ttypeof input.catch === 'function'\n\t\t)\n\t);\n}\nexports.isPromise = isPromise;\n\nfunction isArrayBufferView(value) {\n if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView) {\n return ArrayBuffer.isView(value);\n }\n\n return (\n isTypedArray(value) ||\n isDataView(value)\n );\n}\nexports.isArrayBufferView = isArrayBufferView;\n\n\nfunction isUint8Array(value) {\n return whichTypedArray(value) === 'Uint8Array';\n}\nexports.isUint8Array = isUint8Array;\n\nfunction isUint8ClampedArray(value) {\n return whichTypedArray(value) === 'Uint8ClampedArray';\n}\nexports.isUint8ClampedArray = isUint8ClampedArray;\n\nfunction isUint16Array(value) {\n return whichTypedArray(value) === 'Uint16Array';\n}\nexports.isUint16Array = isUint16Array;\n\nfunction isUint32Array(value) {\n return whichTypedArray(value) === 'Uint32Array';\n}\nexports.isUint32Array = isUint32Array;\n\nfunction isInt8Array(value) {\n return whichTypedArray(value) === 'Int8Array';\n}\nexports.isInt8Array = isInt8Array;\n\nfunction isInt16Array(value) {\n return whichTypedArray(value) === 'Int16Array';\n}\nexports.isInt16Array = isInt16Array;\n\nfunction isInt32Array(value) {\n return whichTypedArray(value) === 'Int32Array';\n}\nexports.isInt32Array = isInt32Array;\n\nfunction isFloat32Array(value) {\n return whichTypedArray(value) === 'Float32Array';\n}\nexports.isFloat32Array = isFloat32Array;\n\nfunction isFloat64Array(value) {\n return whichTypedArray(value) === 'Float64Array';\n}\nexports.isFloat64Array = isFloat64Array;\n\nfunction isBigInt64Array(value) {\n return whichTypedArray(value) === 'BigInt64Array';\n}\nexports.isBigInt64Array = isBigInt64Array;\n\nfunction isBigUint64Array(value) {\n return whichTypedArray(value) === 'BigUint64Array';\n}\nexports.isBigUint64Array = isBigUint64Array;\n\nfunction isMapToString(value) {\n return ObjectToString(value) === '[object Map]';\n}\nisMapToString.working = (\n typeof Map !== 'undefined' &&\n isMapToString(new Map())\n);\n\nfunction isMap(value) {\n if (typeof Map === 'undefined') {\n return false;\n }\n\n return isMapToString.working\n ? isMapToString(value)\n : value instanceof Map;\n}\nexports.isMap = isMap;\n\nfunction isSetToString(value) {\n return ObjectToString(value) === '[object Set]';\n}\nisSetToString.working = (\n typeof Set !== 'undefined' &&\n isSetToString(new Set())\n);\nfunction isSet(value) {\n if (typeof Set === 'undefined') {\n return false;\n }\n\n return isSetToString.working\n ? isSetToString(value)\n : value instanceof Set;\n}\nexports.isSet = isSet;\n\nfunction isWeakMapToString(value) {\n return ObjectToString(value) === '[object WeakMap]';\n}\nisWeakMapToString.working = (\n typeof WeakMap !== 'undefined' &&\n isWeakMapToString(new WeakMap())\n);\nfunction isWeakMap(value) {\n if (typeof WeakMap === 'undefined') {\n return false;\n }\n\n return isWeakMapToString.working\n ? isWeakMapToString(value)\n : value instanceof WeakMap;\n}\nexports.isWeakMap = isWeakMap;\n\nfunction isWeakSetToString(value) {\n return ObjectToString(value) === '[object WeakSet]';\n}\nisWeakSetToString.working = (\n typeof WeakSet !== 'undefined' &&\n isWeakSetToString(new WeakSet())\n);\nfunction isWeakSet(value) {\n return isWeakSetToString(value);\n}\nexports.isWeakSet = isWeakSet;\n\nfunction isArrayBufferToString(value) {\n return ObjectToString(value) === '[object ArrayBuffer]';\n}\nisArrayBufferToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n isArrayBufferToString(new ArrayBuffer())\n);\nfunction isArrayBuffer(value) {\n if (typeof ArrayBuffer === 'undefined') {\n return false;\n }\n\n return isArrayBufferToString.working\n ? isArrayBufferToString(value)\n : value instanceof ArrayBuffer;\n}\nexports.isArrayBuffer = isArrayBuffer;\n\nfunction isDataViewToString(value) {\n return ObjectToString(value) === '[object DataView]';\n}\nisDataViewToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n typeof DataView !== 'undefined' &&\n isDataViewToString(new DataView(new ArrayBuffer(1), 0, 1))\n);\nfunction isDataView(value) {\n if (typeof DataView === 'undefined') {\n return false;\n }\n\n return isDataViewToString.working\n ? isDataViewToString(value)\n : value instanceof DataView;\n}\nexports.isDataView = isDataView;\n\n// Store a copy of SharedArrayBuffer in case it's deleted elsewhere\nvar SharedArrayBufferCopy = typeof SharedArrayBuffer !== 'undefined' ? SharedArrayBuffer : undefined;\nfunction isSharedArrayBufferToString(value) {\n return ObjectToString(value) === '[object SharedArrayBuffer]';\n}\nfunction isSharedArrayBuffer(value) {\n if (typeof SharedArrayBufferCopy === 'undefined') {\n return false;\n }\n\n if (typeof isSharedArrayBufferToString.working === 'undefined') {\n isSharedArrayBufferToString.working = isSharedArrayBufferToString(new SharedArrayBufferCopy());\n }\n\n return isSharedArrayBufferToString.working\n ? isSharedArrayBufferToString(value)\n : value instanceof SharedArrayBufferCopy;\n}\nexports.isSharedArrayBuffer = isSharedArrayBuffer;\n\nfunction isAsyncFunction(value) {\n return ObjectToString(value) === '[object AsyncFunction]';\n}\nexports.isAsyncFunction = isAsyncFunction;\n\nfunction isMapIterator(value) {\n return ObjectToString(value) === '[object Map Iterator]';\n}\nexports.isMapIterator = isMapIterator;\n\nfunction isSetIterator(value) {\n return ObjectToString(value) === '[object Set Iterator]';\n}\nexports.isSetIterator = isSetIterator;\n\nfunction isGeneratorObject(value) {\n return ObjectToString(value) === '[object Generator]';\n}\nexports.isGeneratorObject = isGeneratorObject;\n\nfunction isWebAssemblyCompiledModule(value) {\n return ObjectToString(value) === '[object WebAssembly.Module]';\n}\nexports.isWebAssemblyCompiledModule = isWebAssemblyCompiledModule;\n\nfunction isNumberObject(value) {\n return checkBoxedPrimitive(value, numberValue);\n}\nexports.isNumberObject = isNumberObject;\n\nfunction isStringObject(value) {\n return checkBoxedPrimitive(value, stringValue);\n}\nexports.isStringObject = isStringObject;\n\nfunction isBooleanObject(value) {\n return checkBoxedPrimitive(value, booleanValue);\n}\nexports.isBooleanObject = isBooleanObject;\n\nfunction isBigIntObject(value) {\n return BigIntSupported && checkBoxedPrimitive(value, bigIntValue);\n}\nexports.isBigIntObject = isBigIntObject;\n\nfunction isSymbolObject(value) {\n return SymbolSupported && checkBoxedPrimitive(value, symbolValue);\n}\nexports.isSymbolObject = isSymbolObject;\n\nfunction isBoxedPrimitive(value) {\n return (\n isNumberObject(value) ||\n isStringObject(value) ||\n isBooleanObject(value) ||\n isBigIntObject(value) ||\n isSymbolObject(value)\n );\n}\nexports.isBoxedPrimitive = isBoxedPrimitive;\n\nfunction isAnyArrayBuffer(value) {\n return typeof Uint8Array !== 'undefined' && (\n isArrayBuffer(value) ||\n isSharedArrayBuffer(value)\n );\n}\nexports.isAnyArrayBuffer = isAnyArrayBuffer;\n\n['isProxy', 'isExternal', 'isModuleNamespaceObject'].forEach(function(method) {\n Object.defineProperty(exports, method, {\n enumerable: false,\n value: function() {\n throw new Error(method + ' is not supported in userland');\n }\n });\n});\n","'use strict';\n\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar callBound = require('call-bind/callBound');\n\nvar $toString = callBound('Object.prototype.toString');\n\nvar isStandardArguments = function isArguments(value) {\n\tif (hasToStringTag && value && typeof value === 'object' && Symbol.toStringTag in value) {\n\t\treturn false;\n\t}\n\treturn $toString(value) === '[object Arguments]';\n};\n\nvar isLegacyArguments = function isArguments(value) {\n\tif (isStandardArguments(value)) {\n\t\treturn true;\n\t}\n\treturn value !== null &&\n\t\ttypeof value === 'object' &&\n\t\ttypeof value.length === 'number' &&\n\t\tvalue.length >= 0 &&\n\t\t$toString(value) !== '[object Array]' &&\n\t\t$toString(value.callee) === '[object Function]';\n};\n\nvar supportsStandardArguments = (function () {\n\treturn isStandardArguments(arguments);\n}());\n\nisStandardArguments.isLegacyArguments = isLegacyArguments; // for tests\n\nmodule.exports = supportsStandardArguments ? isStandardArguments : isLegacyArguments;\n","'use strict';\n\nvar hasSymbols = require('has-symbols/shams');\n\nmodule.exports = function hasToStringTagShams() {\n\treturn hasSymbols() && !!Symbol.toStringTag;\n};\n","'use strict';\n\n/* eslint complexity: [2, 18], max-statements: [2, 33] */\nmodule.exports = function hasSymbols() {\n\tif (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }\n\tif (typeof Symbol.iterator === 'symbol') { return true; }\n\n\tvar obj = {};\n\tvar sym = Symbol('test');\n\tvar symObj = Object(sym);\n\tif (typeof sym === 'string') { return false; }\n\n\tif (Object.prototype.toString.call(sym) !== '[object Symbol]') { return false; }\n\tif (Object.prototype.toString.call(symObj) !== '[object Symbol]') { return false; }\n\n\t// temp disabled per https://github.com/ljharb/object.assign/issues/17\n\t// if (sym instanceof Symbol) { return false; }\n\t// temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4\n\t// if (!(symObj instanceof Symbol)) { return false; }\n\n\t// if (typeof Symbol.prototype.toString !== 'function') { return false; }\n\t// if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; }\n\n\tvar symVal = 42;\n\tobj[sym] = symVal;\n\tfor (sym in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop\n\tif (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }\n\n\tif (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }\n\n\tvar syms = Object.getOwnPropertySymbols(obj);\n\tif (syms.length !== 1 || syms[0] !== sym) { return false; }\n\n\tif (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }\n\n\tif (typeof Object.getOwnPropertyDescriptor === 'function') {\n\t\tvar descriptor = Object.getOwnPropertyDescriptor(obj, sym);\n\t\tif (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }\n\t}\n\n\treturn true;\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar callBind = require('./');\n\nvar $indexOf = callBind(GetIntrinsic('String.prototype.indexOf'));\n\nmodule.exports = function callBoundIntrinsic(name, allowMissing) {\n\tvar intrinsic = GetIntrinsic(name, !!allowMissing);\n\tif (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) {\n\t\treturn callBind(intrinsic);\n\t}\n\treturn intrinsic;\n};\n","'use strict';\n\nvar undefined;\n\nvar $SyntaxError = SyntaxError;\nvar $Function = Function;\nvar $TypeError = TypeError;\n\n// eslint-disable-next-line consistent-return\nvar getEvalledConstructor = function (expressionSyntax) {\n\ttry {\n\t\treturn $Function('\"use strict\"; return (' + expressionSyntax + ').constructor;')();\n\t} catch (e) {}\n};\n\nvar $gOPD = Object.getOwnPropertyDescriptor;\nif ($gOPD) {\n\ttry {\n\t\t$gOPD({}, '');\n\t} catch (e) {\n\t\t$gOPD = null; // this is IE 8, which has a broken gOPD\n\t}\n}\n\nvar throwTypeError = function () {\n\tthrow new $TypeError();\n};\nvar ThrowTypeError = $gOPD\n\t? (function () {\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties\n\t\t\targuments.callee; // IE 8 does not throw here\n\t\t\treturn throwTypeError;\n\t\t} catch (calleeThrows) {\n\t\t\ttry {\n\t\t\t\t// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')\n\t\t\t\treturn $gOPD(arguments, 'callee').get;\n\t\t\t} catch (gOPDthrows) {\n\t\t\t\treturn throwTypeError;\n\t\t\t}\n\t\t}\n\t}())\n\t: throwTypeError;\n\nvar hasSymbols = require('has-symbols')();\n\nvar getProto = Object.getPrototypeOf || function (x) { return x.__proto__; }; // eslint-disable-line no-proto\n\nvar needsEval = {};\n\nvar TypedArray = typeof Uint8Array === 'undefined' ? undefined : getProto(Uint8Array);\n\nvar INTRINSICS = {\n\t'%AggregateError%': typeof AggregateError === 'undefined' ? undefined : AggregateError,\n\t'%Array%': Array,\n\t'%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer,\n\t'%ArrayIteratorPrototype%': hasSymbols ? getProto([][Symbol.iterator]()) : undefined,\n\t'%AsyncFromSyncIteratorPrototype%': undefined,\n\t'%AsyncFunction%': needsEval,\n\t'%AsyncGenerator%': needsEval,\n\t'%AsyncGeneratorFunction%': needsEval,\n\t'%AsyncIteratorPrototype%': needsEval,\n\t'%Atomics%': typeof Atomics === 'undefined' ? undefined : Atomics,\n\t'%BigInt%': typeof BigInt === 'undefined' ? undefined : BigInt,\n\t'%Boolean%': Boolean,\n\t'%DataView%': typeof DataView === 'undefined' ? undefined : DataView,\n\t'%Date%': Date,\n\t'%decodeURI%': decodeURI,\n\t'%decodeURIComponent%': decodeURIComponent,\n\t'%encodeURI%': encodeURI,\n\t'%encodeURIComponent%': encodeURIComponent,\n\t'%Error%': Error,\n\t'%eval%': eval, // eslint-disable-line no-eval\n\t'%EvalError%': EvalError,\n\t'%Float32Array%': typeof Float32Array === 'undefined' ? undefined : Float32Array,\n\t'%Float64Array%': typeof Float64Array === 'undefined' ? undefined : Float64Array,\n\t'%FinalizationRegistry%': typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry,\n\t'%Function%': $Function,\n\t'%GeneratorFunction%': needsEval,\n\t'%Int8Array%': typeof Int8Array === 'undefined' ? undefined : Int8Array,\n\t'%Int16Array%': typeof Int16Array === 'undefined' ? undefined : Int16Array,\n\t'%Int32Array%': typeof Int32Array === 'undefined' ? undefined : Int32Array,\n\t'%isFinite%': isFinite,\n\t'%isNaN%': isNaN,\n\t'%IteratorPrototype%': hasSymbols ? getProto(getProto([][Symbol.iterator]())) : undefined,\n\t'%JSON%': typeof JSON === 'object' ? JSON : undefined,\n\t'%Map%': typeof Map === 'undefined' ? undefined : Map,\n\t'%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols ? undefined : getProto(new Map()[Symbol.iterator]()),\n\t'%Math%': Math,\n\t'%Number%': Number,\n\t'%Object%': Object,\n\t'%parseFloat%': parseFloat,\n\t'%parseInt%': parseInt,\n\t'%Promise%': typeof Promise === 'undefined' ? undefined : Promise,\n\t'%Proxy%': typeof Proxy === 'undefined' ? undefined : Proxy,\n\t'%RangeError%': RangeError,\n\t'%ReferenceError%': ReferenceError,\n\t'%Reflect%': typeof Reflect === 'undefined' ? undefined : Reflect,\n\t'%RegExp%': RegExp,\n\t'%Set%': typeof Set === 'undefined' ? undefined : Set,\n\t'%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols ? undefined : getProto(new Set()[Symbol.iterator]()),\n\t'%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer,\n\t'%String%': String,\n\t'%StringIteratorPrototype%': hasSymbols ? getProto(''[Symbol.iterator]()) : undefined,\n\t'%Symbol%': hasSymbols ? Symbol : undefined,\n\t'%SyntaxError%': $SyntaxError,\n\t'%ThrowTypeError%': ThrowTypeError,\n\t'%TypedArray%': TypedArray,\n\t'%TypeError%': $TypeError,\n\t'%Uint8Array%': typeof Uint8Array === 'undefined' ? undefined : Uint8Array,\n\t'%Uint8ClampedArray%': typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray,\n\t'%Uint16Array%': typeof Uint16Array === 'undefined' ? undefined : Uint16Array,\n\t'%Uint32Array%': typeof Uint32Array === 'undefined' ? undefined : Uint32Array,\n\t'%URIError%': URIError,\n\t'%WeakMap%': typeof WeakMap === 'undefined' ? undefined : WeakMap,\n\t'%WeakRef%': typeof WeakRef === 'undefined' ? undefined : WeakRef,\n\t'%WeakSet%': typeof WeakSet === 'undefined' ? undefined : WeakSet\n};\n\nvar doEval = function doEval(name) {\n\tvar value;\n\tif (name === '%AsyncFunction%') {\n\t\tvalue = getEvalledConstructor('async function () {}');\n\t} else if (name === '%GeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('function* () {}');\n\t} else if (name === '%AsyncGeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('async function* () {}');\n\t} else if (name === '%AsyncGenerator%') {\n\t\tvar fn = doEval('%AsyncGeneratorFunction%');\n\t\tif (fn) {\n\t\t\tvalue = fn.prototype;\n\t\t}\n\t} else if (name === '%AsyncIteratorPrototype%') {\n\t\tvar gen = doEval('%AsyncGenerator%');\n\t\tif (gen) {\n\t\t\tvalue = getProto(gen.prototype);\n\t\t}\n\t}\n\n\tINTRINSICS[name] = value;\n\n\treturn value;\n};\n\nvar LEGACY_ALIASES = {\n\t'%ArrayBufferPrototype%': ['ArrayBuffer', 'prototype'],\n\t'%ArrayPrototype%': ['Array', 'prototype'],\n\t'%ArrayProto_entries%': ['Array', 'prototype', 'entries'],\n\t'%ArrayProto_forEach%': ['Array', 'prototype', 'forEach'],\n\t'%ArrayProto_keys%': ['Array', 'prototype', 'keys'],\n\t'%ArrayProto_values%': ['Array', 'prototype', 'values'],\n\t'%AsyncFunctionPrototype%': ['AsyncFunction', 'prototype'],\n\t'%AsyncGenerator%': ['AsyncGeneratorFunction', 'prototype'],\n\t'%AsyncGeneratorPrototype%': ['AsyncGeneratorFunction', 'prototype', 'prototype'],\n\t'%BooleanPrototype%': ['Boolean', 'prototype'],\n\t'%DataViewPrototype%': ['DataView', 'prototype'],\n\t'%DatePrototype%': ['Date', 'prototype'],\n\t'%ErrorPrototype%': ['Error', 'prototype'],\n\t'%EvalErrorPrototype%': ['EvalError', 'prototype'],\n\t'%Float32ArrayPrototype%': ['Float32Array', 'prototype'],\n\t'%Float64ArrayPrototype%': ['Float64Array', 'prototype'],\n\t'%FunctionPrototype%': ['Function', 'prototype'],\n\t'%Generator%': ['GeneratorFunction', 'prototype'],\n\t'%GeneratorPrototype%': ['GeneratorFunction', 'prototype', 'prototype'],\n\t'%Int8ArrayPrototype%': ['Int8Array', 'prototype'],\n\t'%Int16ArrayPrototype%': ['Int16Array', 'prototype'],\n\t'%Int32ArrayPrototype%': ['Int32Array', 'prototype'],\n\t'%JSONParse%': ['JSON', 'parse'],\n\t'%JSONStringify%': ['JSON', 'stringify'],\n\t'%MapPrototype%': ['Map', 'prototype'],\n\t'%NumberPrototype%': ['Number', 'prototype'],\n\t'%ObjectPrototype%': ['Object', 'prototype'],\n\t'%ObjProto_toString%': ['Object', 'prototype', 'toString'],\n\t'%ObjProto_valueOf%': ['Object', 'prototype', 'valueOf'],\n\t'%PromisePrototype%': ['Promise', 'prototype'],\n\t'%PromiseProto_then%': ['Promise', 'prototype', 'then'],\n\t'%Promise_all%': ['Promise', 'all'],\n\t'%Promise_reject%': ['Promise', 'reject'],\n\t'%Promise_resolve%': ['Promise', 'resolve'],\n\t'%RangeErrorPrototype%': ['RangeError', 'prototype'],\n\t'%ReferenceErrorPrototype%': ['ReferenceError', 'prototype'],\n\t'%RegExpPrototype%': ['RegExp', 'prototype'],\n\t'%SetPrototype%': ['Set', 'prototype'],\n\t'%SharedArrayBufferPrototype%': ['SharedArrayBuffer', 'prototype'],\n\t'%StringPrototype%': ['String', 'prototype'],\n\t'%SymbolPrototype%': ['Symbol', 'prototype'],\n\t'%SyntaxErrorPrototype%': ['SyntaxError', 'prototype'],\n\t'%TypedArrayPrototype%': ['TypedArray', 'prototype'],\n\t'%TypeErrorPrototype%': ['TypeError', 'prototype'],\n\t'%Uint8ArrayPrototype%': ['Uint8Array', 'prototype'],\n\t'%Uint8ClampedArrayPrototype%': ['Uint8ClampedArray', 'prototype'],\n\t'%Uint16ArrayPrototype%': ['Uint16Array', 'prototype'],\n\t'%Uint32ArrayPrototype%': ['Uint32Array', 'prototype'],\n\t'%URIErrorPrototype%': ['URIError', 'prototype'],\n\t'%WeakMapPrototype%': ['WeakMap', 'prototype'],\n\t'%WeakSetPrototype%': ['WeakSet', 'prototype']\n};\n\nvar bind = require('function-bind');\nvar hasOwn = require('has');\nvar $concat = bind.call(Function.call, Array.prototype.concat);\nvar $spliceApply = bind.call(Function.apply, Array.prototype.splice);\nvar $replace = bind.call(Function.call, String.prototype.replace);\nvar $strSlice = bind.call(Function.call, String.prototype.slice);\n\n/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */\nvar rePropName = /[^%.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|%$))/g;\nvar reEscapeChar = /\\\\(\\\\)?/g; /** Used to match backslashes in property paths. */\nvar stringToPath = function stringToPath(string) {\n\tvar first = $strSlice(string, 0, 1);\n\tvar last = $strSlice(string, -1);\n\tif (first === '%' && last !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected closing `%`');\n\t} else if (last === '%' && first !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected opening `%`');\n\t}\n\tvar result = [];\n\t$replace(string, rePropName, function (match, number, quote, subString) {\n\t\tresult[result.length] = quote ? $replace(subString, reEscapeChar, '$1') : number || match;\n\t});\n\treturn result;\n};\n/* end adaptation */\n\nvar getBaseIntrinsic = function getBaseIntrinsic(name, allowMissing) {\n\tvar intrinsicName = name;\n\tvar alias;\n\tif (hasOwn(LEGACY_ALIASES, intrinsicName)) {\n\t\talias = LEGACY_ALIASES[intrinsicName];\n\t\tintrinsicName = '%' + alias[0] + '%';\n\t}\n\n\tif (hasOwn(INTRINSICS, intrinsicName)) {\n\t\tvar value = INTRINSICS[intrinsicName];\n\t\tif (value === needsEval) {\n\t\t\tvalue = doEval(intrinsicName);\n\t\t}\n\t\tif (typeof value === 'undefined' && !allowMissing) {\n\t\t\tthrow new $TypeError('intrinsic ' + name + ' exists, but is not available. Please file an issue!');\n\t\t}\n\n\t\treturn {\n\t\t\talias: alias,\n\t\t\tname: intrinsicName,\n\t\t\tvalue: value\n\t\t};\n\t}\n\n\tthrow new $SyntaxError('intrinsic ' + name + ' does not exist!');\n};\n\nmodule.exports = function GetIntrinsic(name, allowMissing) {\n\tif (typeof name !== 'string' || name.length === 0) {\n\t\tthrow new $TypeError('intrinsic name must be a non-empty string');\n\t}\n\tif (arguments.length > 1 && typeof allowMissing !== 'boolean') {\n\t\tthrow new $TypeError('\"allowMissing\" argument must be a boolean');\n\t}\n\n\tvar parts = stringToPath(name);\n\tvar intrinsicBaseName = parts.length > 0 ? parts[0] : '';\n\n\tvar intrinsic = getBaseIntrinsic('%' + intrinsicBaseName + '%', allowMissing);\n\tvar intrinsicRealName = intrinsic.name;\n\tvar value = intrinsic.value;\n\tvar skipFurtherCaching = false;\n\n\tvar alias = intrinsic.alias;\n\tif (alias) {\n\t\tintrinsicBaseName = alias[0];\n\t\t$spliceApply(parts, $concat([0, 1], alias));\n\t}\n\n\tfor (var i = 1, isOwn = true; i < parts.length; i += 1) {\n\t\tvar part = parts[i];\n\t\tvar first = $strSlice(part, 0, 1);\n\t\tvar last = $strSlice(part, -1);\n\t\tif (\n\t\t\t(\n\t\t\t\t(first === '\"' || first === \"'\" || first === '`')\n\t\t\t\t|| (last === '\"' || last === \"'\" || last === '`')\n\t\t\t)\n\t\t\t&& first !== last\n\t\t) {\n\t\t\tthrow new $SyntaxError('property names with quotes must have matching quotes');\n\t\t}\n\t\tif (part === 'constructor' || !isOwn) {\n\t\t\tskipFurtherCaching = true;\n\t\t}\n\n\t\tintrinsicBaseName += '.' + part;\n\t\tintrinsicRealName = '%' + intrinsicBaseName + '%';\n\n\t\tif (hasOwn(INTRINSICS, intrinsicRealName)) {\n\t\t\tvalue = INTRINSICS[intrinsicRealName];\n\t\t} else if (value != null) {\n\t\t\tif (!(part in value)) {\n\t\t\t\tif (!allowMissing) {\n\t\t\t\t\tthrow new $TypeError('base intrinsic for ' + name + ' exists, but the property is not available.');\n\t\t\t\t}\n\t\t\t\treturn void undefined;\n\t\t\t}\n\t\t\tif ($gOPD && (i + 1) >= parts.length) {\n\t\t\t\tvar desc = $gOPD(value, part);\n\t\t\t\tisOwn = !!desc;\n\n\t\t\t\t// By convention, when a data property is converted to an accessor\n\t\t\t\t// property to emulate a data property that does not suffer from\n\t\t\t\t// the override mistake, that accessor's getter is marked with\n\t\t\t\t// an `originalValue` property. Here, when we detect this, we\n\t\t\t\t// uphold the illusion by pretending to see that original data\n\t\t\t\t// property, i.e., returning the value rather than the getter\n\t\t\t\t// itself.\n\t\t\t\tif (isOwn && 'get' in desc && !('originalValue' in desc.get)) {\n\t\t\t\t\tvalue = desc.get;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = value[part];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tisOwn = hasOwn(value, part);\n\t\t\t\tvalue = value[part];\n\t\t\t}\n\n\t\t\tif (isOwn && !skipFurtherCaching) {\n\t\t\t\tINTRINSICS[intrinsicRealName] = value;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n","'use strict';\n\nvar origSymbol = typeof Symbol !== 'undefined' && Symbol;\nvar hasSymbolSham = require('./shams');\n\nmodule.exports = function hasNativeSymbols() {\n\tif (typeof origSymbol !== 'function') { return false; }\n\tif (typeof Symbol !== 'function') { return false; }\n\tif (typeof origSymbol('foo') !== 'symbol') { return false; }\n\tif (typeof Symbol('bar') !== 'symbol') { return false; }\n\n\treturn hasSymbolSham();\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = Function.prototype.bind || implementation;\n","'use strict';\n\n/* eslint no-invalid-this: 1 */\n\nvar ERROR_MESSAGE = 'Function.prototype.bind called on incompatible ';\nvar slice = Array.prototype.slice;\nvar toStr = Object.prototype.toString;\nvar funcType = '[object Function]';\n\nmodule.exports = function bind(that) {\n var target = this;\n if (typeof target !== 'function' || toStr.call(target) !== funcType) {\n throw new TypeError(ERROR_MESSAGE + target);\n }\n var args = slice.call(arguments, 1);\n\n var bound;\n var binder = function () {\n if (this instanceof bound) {\n var result = target.apply(\n this,\n args.concat(slice.call(arguments))\n );\n if (Object(result) === result) {\n return result;\n }\n return this;\n } else {\n return target.apply(\n that,\n args.concat(slice.call(arguments))\n );\n }\n };\n\n var boundLength = Math.max(0, target.length - args.length);\n var boundArgs = [];\n for (var i = 0; i < boundLength; i++) {\n boundArgs.push('$' + i);\n }\n\n bound = Function('binder', 'return function (' + boundArgs.join(',') + '){ return binder.apply(this,arguments); }')(binder);\n\n if (target.prototype) {\n var Empty = function Empty() {};\n Empty.prototype = target.prototype;\n bound.prototype = new Empty();\n Empty.prototype = null;\n }\n\n return bound;\n};\n","'use strict';\n\nvar bind = require('function-bind');\n\nmodule.exports = bind.call(Function.call, Object.prototype.hasOwnProperty);\n","'use strict';\n\nvar bind = require('function-bind');\nvar GetIntrinsic = require('get-intrinsic');\n\nvar $apply = GetIntrinsic('%Function.prototype.apply%');\nvar $call = GetIntrinsic('%Function.prototype.call%');\nvar $reflectApply = GetIntrinsic('%Reflect.apply%', true) || bind.call($call, $apply);\n\nvar $gOPD = GetIntrinsic('%Object.getOwnPropertyDescriptor%', true);\nvar $defineProperty = GetIntrinsic('%Object.defineProperty%', true);\nvar $max = GetIntrinsic('%Math.max%');\n\nif ($defineProperty) {\n\ttry {\n\t\t$defineProperty({}, 'a', { value: 1 });\n\t} catch (e) {\n\t\t// IE 8 has a broken defineProperty\n\t\t$defineProperty = null;\n\t}\n}\n\nmodule.exports = function callBind(originalFunction) {\n\tvar func = $reflectApply(bind, $call, arguments);\n\tif ($gOPD && $defineProperty) {\n\t\tvar desc = $gOPD(func, 'length');\n\t\tif (desc.configurable) {\n\t\t\t// original length, plus the receiver, minus any additional arguments (after the receiver)\n\t\t\t$defineProperty(\n\t\t\t\tfunc,\n\t\t\t\t'length',\n\t\t\t\t{ value: 1 + $max(0, originalFunction.length - (arguments.length - 1)) }\n\t\t\t);\n\t\t}\n\t}\n\treturn func;\n};\n\nvar applyBind = function applyBind() {\n\treturn $reflectApply(bind, $apply, arguments);\n};\n\nif ($defineProperty) {\n\t$defineProperty(module.exports, 'apply', { value: applyBind });\n} else {\n\tmodule.exports.apply = applyBind;\n}\n","'use strict';\n\nvar toStr = Object.prototype.toString;\nvar fnToStr = Function.prototype.toString;\nvar isFnRegex = /^\\s*(?:function)?\\*/;\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar getProto = Object.getPrototypeOf;\nvar getGeneratorFunc = function () { // eslint-disable-line consistent-return\n\tif (!hasToStringTag) {\n\t\treturn false;\n\t}\n\ttry {\n\t\treturn Function('return function*() {}')();\n\t} catch (e) {\n\t}\n};\nvar GeneratorFunction;\n\nmodule.exports = function isGeneratorFunction(fn) {\n\tif (typeof fn !== 'function') {\n\t\treturn false;\n\t}\n\tif (isFnRegex.test(fnToStr.call(fn))) {\n\t\treturn true;\n\t}\n\tif (!hasToStringTag) {\n\t\tvar str = toStr.call(fn);\n\t\treturn str === '[object GeneratorFunction]';\n\t}\n\tif (!getProto) {\n\t\treturn false;\n\t}\n\tif (typeof GeneratorFunction === 'undefined') {\n\t\tvar generatorFunc = getGeneratorFunc();\n\t\tGeneratorFunction = generatorFunc ? getProto(generatorFunc) : false;\n\t}\n\treturn getProto(fn) === GeneratorFunction;\n};\n","'use strict';\n\nvar forEach = require('foreach');\nvar availableTypedArrays = require('available-typed-arrays');\nvar callBound = require('call-bind/callBound');\n\nvar $toString = callBound('Object.prototype.toString');\nvar hasToStringTag = require('has-tostringtag/shams')();\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\nvar typedArrays = availableTypedArrays();\n\nvar $slice = callBound('String.prototype.slice');\nvar toStrTags = {};\nvar gOPD = require('es-abstract/helpers/getOwnPropertyDescriptor');\nvar getPrototypeOf = Object.getPrototypeOf; // require('getprototypeof');\nif (hasToStringTag && gOPD && getPrototypeOf) {\n\tforEach(typedArrays, function (typedArray) {\n\t\tif (typeof g[typedArray] === 'function') {\n\t\t\tvar arr = new g[typedArray]();\n\t\t\tif (Symbol.toStringTag in arr) {\n\t\t\t\tvar proto = getPrototypeOf(arr);\n\t\t\t\tvar descriptor = gOPD(proto, Symbol.toStringTag);\n\t\t\t\tif (!descriptor) {\n\t\t\t\t\tvar superProto = getPrototypeOf(proto);\n\t\t\t\t\tdescriptor = gOPD(superProto, Symbol.toStringTag);\n\t\t\t\t}\n\t\t\t\ttoStrTags[typedArray] = descriptor.get;\n\t\t\t}\n\t\t}\n\t});\n}\n\nvar tryTypedArrays = function tryAllTypedArrays(value) {\n\tvar foundName = false;\n\tforEach(toStrTags, function (getter, typedArray) {\n\t\tif (!foundName) {\n\t\t\ttry {\n\t\t\t\tvar name = getter.call(value);\n\t\t\t\tif (name === typedArray) {\n\t\t\t\t\tfoundName = name;\n\t\t\t\t}\n\t\t\t} catch (e) {}\n\t\t}\n\t});\n\treturn foundName;\n};\n\nvar isTypedArray = require('is-typed-array');\n\nmodule.exports = function whichTypedArray(value) {\n\tif (!isTypedArray(value)) { return false; }\n\tif (!hasToStringTag || !(Symbol.toStringTag in value)) { return $slice($toString(value), 8, -1); }\n\treturn tryTypedArrays(value);\n};\n","\nvar hasOwn = Object.prototype.hasOwnProperty;\nvar toString = Object.prototype.toString;\n\nmodule.exports = function forEach (obj, fn, ctx) {\n if (toString.call(fn) !== '[object Function]') {\n throw new TypeError('iterator must be a function');\n }\n var l = obj.length;\n if (l === +l) {\n for (var i = 0; i < l; i++) {\n fn.call(ctx, obj[i], i, obj);\n }\n } else {\n for (var k in obj) {\n if (hasOwn.call(obj, k)) {\n fn.call(ctx, obj[k], k, obj);\n }\n }\n }\n};\n\n","'use strict';\n\nvar possibleNames = [\n\t'BigInt64Array',\n\t'BigUint64Array',\n\t'Float32Array',\n\t'Float64Array',\n\t'Int16Array',\n\t'Int32Array',\n\t'Int8Array',\n\t'Uint16Array',\n\t'Uint32Array',\n\t'Uint8Array',\n\t'Uint8ClampedArray'\n];\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\n\nmodule.exports = function availableTypedArrays() {\n\tvar out = [];\n\tfor (var i = 0; i < possibleNames.length; i++) {\n\t\tif (typeof g[possibleNames[i]] === 'function') {\n\t\t\tout[out.length] = possibleNames[i];\n\t\t}\n\t}\n\treturn out;\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar $gOPD = GetIntrinsic('%Object.getOwnPropertyDescriptor%', true);\nif ($gOPD) {\n\ttry {\n\t\t$gOPD([], 'length');\n\t} catch (e) {\n\t\t// IE 8 has a broken gOPD\n\t\t$gOPD = null;\n\t}\n}\n\nmodule.exports = $gOPD;\n","'use strict';\n\nvar forEach = require('foreach');\nvar availableTypedArrays = require('available-typed-arrays');\nvar callBound = require('call-bind/callBound');\n\nvar $toString = callBound('Object.prototype.toString');\nvar hasToStringTag = require('has-tostringtag/shams')();\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\nvar typedArrays = availableTypedArrays();\n\nvar $indexOf = callBound('Array.prototype.indexOf', true) || function indexOf(array, value) {\n\tfor (var i = 0; i < array.length; i += 1) {\n\t\tif (array[i] === value) {\n\t\t\treturn i;\n\t\t}\n\t}\n\treturn -1;\n};\nvar $slice = callBound('String.prototype.slice');\nvar toStrTags = {};\nvar gOPD = require('es-abstract/helpers/getOwnPropertyDescriptor');\nvar getPrototypeOf = Object.getPrototypeOf; // require('getprototypeof');\nif (hasToStringTag && gOPD && getPrototypeOf) {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tif (Symbol.toStringTag in arr) {\n\t\t\tvar proto = getPrototypeOf(arr);\n\t\t\tvar descriptor = gOPD(proto, Symbol.toStringTag);\n\t\t\tif (!descriptor) {\n\t\t\t\tvar superProto = getPrototypeOf(proto);\n\t\t\t\tdescriptor = gOPD(superProto, Symbol.toStringTag);\n\t\t\t}\n\t\t\ttoStrTags[typedArray] = descriptor.get;\n\t\t}\n\t});\n}\n\nvar tryTypedArrays = function tryAllTypedArrays(value) {\n\tvar anyTrue = false;\n\tforEach(toStrTags, function (getter, typedArray) {\n\t\tif (!anyTrue) {\n\t\t\ttry {\n\t\t\t\tanyTrue = getter.call(value) === typedArray;\n\t\t\t} catch (e) { /**/ }\n\t\t}\n\t});\n\treturn anyTrue;\n};\n\nmodule.exports = function isTypedArray(value) {\n\tif (!value || typeof value !== 'object') { return false; }\n\tif (!hasToStringTag || !(Symbol.toStringTag in value)) {\n\t\tvar tag = $slice($toString(value), 8, -1);\n\t\treturn $indexOf(typedArrays, tag) > -1;\n\t}\n\tif (!gOPD) { return false; }\n\treturn tryTypedArrays(value);\n};\n","module.exports = function isBuffer(arg) {\n return arg && typeof arg === 'object'\n && typeof arg.copy === 'function'\n && typeof arg.fill === 'function'\n && typeof arg.readUInt8 === 'function';\n}","'use strict'\n\nconst { AbstractLevelDOWN } = require('abstract-leveldown')\nconst inherits = require('inherits')\nconst DeferredIterator = require('./deferred-iterator')\nconst DeferredChainedBatch = require('./deferred-chained-batch')\nconst getCallback = require('./util').getCallback\n\nconst deferrables = ['put', 'get', 'getMany', 'del', 'batch', 'clear']\nconst optionalDeferrables = ['approximateSize', 'compactRange']\n\nconst kInnerDb = Symbol('innerDb')\nconst kOperations = Symbol('operations')\nconst kPromise = Symbol('promise')\n\nfunction DeferredLevelDOWN (db) {\n AbstractLevelDOWN.call(this, db.supports || {})\n\n // TODO (future major): remove this fallback; db must have manifest that\n // declares approximateSize and compactRange in additionalMethods.\n for (const m of optionalDeferrables) {\n if (typeof db[m] === 'function' && !this.supports.additionalMethods[m]) {\n this.supports.additionalMethods[m] = true\n }\n }\n\n this[kInnerDb] = db\n this[kOperations] = []\n\n implement(this)\n}\n\ninherits(DeferredLevelDOWN, AbstractLevelDOWN)\n\nDeferredLevelDOWN.prototype.type = 'deferred-leveldown'\n\n// Backwards compatibility for reachdown and subleveldown\nObject.defineProperty(DeferredLevelDOWN.prototype, '_db', {\n enumerable: true,\n get () {\n return this[kInnerDb]\n }\n})\n\nDeferredLevelDOWN.prototype._open = function (options, callback) {\n const onopen = (err) => {\n if (err || this[kInnerDb].status !== 'open') {\n // TODO: reject scheduled operations\n return callback(err || new Error('Database is not open'))\n }\n\n const operations = this[kOperations]\n this[kOperations] = []\n\n for (const op of operations) {\n if (op.iterator) {\n op.iterator.setDb(this[kInnerDb])\n } else {\n this[kInnerDb][op.method](...op.args)\n }\n }\n\n /* istanbul ignore if: assertion */\n if (this[kOperations].length > 0) {\n throw new Error('Did not expect further operations')\n }\n\n callback()\n }\n\n if (this[kInnerDb].status === 'new' || this[kInnerDb].status === 'closed') {\n this[kInnerDb].open(options, onopen)\n } else {\n this._nextTick(onopen)\n }\n}\n\nDeferredLevelDOWN.prototype._close = function (callback) {\n this[kInnerDb].close(callback)\n}\n\nDeferredLevelDOWN.prototype._isOperational = function () {\n return this.status === 'opening'\n}\n\nfunction implement (self) {\n const additionalMethods = Object.keys(self.supports.additionalMethods)\n\n for (const method of deferrables.concat(additionalMethods)) {\n // Override the public rather than private methods to cover cases where abstract-leveldown\n // has a fast-path like on db.batch([]) which bypasses _batch() because the array is empty.\n self[method] = function (...args) {\n if (method === 'batch' && args.length === 0) {\n return new DeferredChainedBatch(this)\n } else if (this.status === 'open') {\n return this[kInnerDb][method](...args)\n }\n\n const callback = getCallback(args, kPromise)\n\n if (this.status === 'opening') {\n this[kOperations].push({ method, args })\n } else {\n this._nextTick(callback, new Error('Database is not open'))\n }\n\n return callback[kPromise]\n }\n }\n\n self.iterator = function (options) {\n if (this.status === 'open') {\n return this[kInnerDb].iterator(options)\n } else if (this.status === 'opening') {\n const iterator = new DeferredIterator(this, options)\n this[kOperations].push({ iterator })\n return iterator\n } else {\n throw new Error('Database is not open')\n }\n }\n\n for (const method of deferrables.concat(['iterator'])) {\n self['_' + method] = function () {\n /* istanbul ignore next: assertion */\n throw new Error('Did not expect private method to be called: ' + method)\n }\n }\n}\n\nmodule.exports = DeferredLevelDOWN\nmodule.exports.DeferredIterator = DeferredIterator\n","'use strict'\n\nexports.AbstractLevelDOWN = require('./abstract-leveldown')\nexports.AbstractIterator = require('./abstract-iterator')\nexports.AbstractChainedBatch = require('./abstract-chained-batch')\n","'use strict'\n\nconst supports = require('level-supports')\nconst isBuffer = require('is-buffer')\nconst catering = require('catering')\nconst AbstractIterator = require('./abstract-iterator')\nconst AbstractChainedBatch = require('./abstract-chained-batch')\nconst getCallback = require('./lib/common').getCallback\nconst getOptions = require('./lib/common').getOptions\n\nconst hasOwnProperty = Object.prototype.hasOwnProperty\nconst rangeOptions = ['lt', 'lte', 'gt', 'gte']\n\nfunction AbstractLevelDOWN (manifest) {\n this.status = 'new'\n\n // TODO (next major): make this mandatory\n this.supports = supports(manifest, {\n status: true\n })\n}\n\nAbstractLevelDOWN.prototype.open = function (options, callback) {\n const oldStatus = this.status\n\n if (typeof options === 'function') callback = options\n\n if (typeof callback !== 'function') {\n throw new Error('open() requires a callback argument')\n }\n\n if (typeof options !== 'object' || options === null) options = {}\n\n options.createIfMissing = options.createIfMissing !== false\n options.errorIfExists = !!options.errorIfExists\n\n this.status = 'opening'\n this._open(options, (err) => {\n if (err) {\n this.status = oldStatus\n return callback(err)\n }\n this.status = 'open'\n callback()\n })\n}\n\nAbstractLevelDOWN.prototype._open = function (options, callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.close = function (callback) {\n const oldStatus = this.status\n\n if (typeof callback !== 'function') {\n throw new Error('close() requires a callback argument')\n }\n\n this.status = 'closing'\n this._close((err) => {\n if (err) {\n this.status = oldStatus\n return callback(err)\n }\n this.status = 'closed'\n callback()\n })\n}\n\nAbstractLevelDOWN.prototype._close = function (callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.get = function (key, options, callback) {\n if (typeof options === 'function') callback = options\n\n if (typeof callback !== 'function') {\n throw new Error('get() requires a callback argument')\n }\n\n const err = this._checkKey(key)\n if (err) return this._nextTick(callback, err)\n\n key = this._serializeKey(key)\n\n if (typeof options !== 'object' || options === null) options = {}\n\n options.asBuffer = options.asBuffer !== false\n\n this._get(key, options, callback)\n}\n\nAbstractLevelDOWN.prototype._get = function (key, options, callback) {\n this._nextTick(function () { callback(new Error('NotFound')) })\n}\n\nAbstractLevelDOWN.prototype.getMany = function (keys, options, callback) {\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n options = getOptions(options)\n\n if (maybeError(this, callback)) {\n return callback.promise\n }\n\n if (!Array.isArray(keys)) {\n this._nextTick(callback, new Error('getMany() requires an array argument'))\n return callback.promise\n }\n\n if (keys.length === 0) {\n this._nextTick(callback, null, [])\n return callback.promise\n }\n\n if (typeof options.asBuffer !== 'boolean') {\n options = { ...options, asBuffer: true }\n }\n\n const serialized = new Array(keys.length)\n\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i]\n const err = this._checkKey(key)\n\n if (err) {\n this._nextTick(callback, err)\n return callback.promise\n }\n\n serialized[i] = this._serializeKey(key)\n }\n\n this._getMany(serialized, options, callback)\n return callback.promise\n}\n\nAbstractLevelDOWN.prototype._getMany = function (keys, options, callback) {\n this._nextTick(callback, null, new Array(keys.length).fill(undefined))\n}\n\nAbstractLevelDOWN.prototype.put = function (key, value, options, callback) {\n if (typeof options === 'function') callback = options\n\n if (typeof callback !== 'function') {\n throw new Error('put() requires a callback argument')\n }\n\n const err = this._checkKey(key) || this._checkValue(value)\n if (err) return this._nextTick(callback, err)\n\n key = this._serializeKey(key)\n value = this._serializeValue(value)\n\n if (typeof options !== 'object' || options === null) options = {}\n\n this._put(key, value, options, callback)\n}\n\nAbstractLevelDOWN.prototype._put = function (key, value, options, callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.del = function (key, options, callback) {\n if (typeof options === 'function') callback = options\n\n if (typeof callback !== 'function') {\n throw new Error('del() requires a callback argument')\n }\n\n const err = this._checkKey(key)\n if (err) return this._nextTick(callback, err)\n\n key = this._serializeKey(key)\n\n if (typeof options !== 'object' || options === null) options = {}\n\n this._del(key, options, callback)\n}\n\nAbstractLevelDOWN.prototype._del = function (key, options, callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.batch = function (array, options, callback) {\n if (!arguments.length) return this._chainedBatch()\n\n if (typeof options === 'function') callback = options\n\n if (typeof array === 'function') callback = array\n\n if (typeof callback !== 'function') {\n throw new Error('batch(array) requires a callback argument')\n }\n\n if (!Array.isArray(array)) {\n return this._nextTick(callback, new Error('batch(array) requires an array argument'))\n }\n\n if (array.length === 0) {\n return this._nextTick(callback)\n }\n\n if (typeof options !== 'object' || options === null) options = {}\n\n const serialized = new Array(array.length)\n\n for (let i = 0; i < array.length; i++) {\n if (typeof array[i] !== 'object' || array[i] === null) {\n return this._nextTick(callback, new Error('batch(array) element must be an object and not `null`'))\n }\n\n const e = Object.assign({}, array[i])\n\n if (e.type !== 'put' && e.type !== 'del') {\n return this._nextTick(callback, new Error(\"`type` must be 'put' or 'del'\"))\n }\n\n const err = this._checkKey(e.key)\n if (err) return this._nextTick(callback, err)\n\n e.key = this._serializeKey(e.key)\n\n if (e.type === 'put') {\n const valueErr = this._checkValue(e.value)\n if (valueErr) return this._nextTick(callback, valueErr)\n\n e.value = this._serializeValue(e.value)\n }\n\n serialized[i] = e\n }\n\n this._batch(serialized, options, callback)\n}\n\nAbstractLevelDOWN.prototype._batch = function (array, options, callback) {\n this._nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.clear = function (options, callback) {\n if (typeof options === 'function') {\n callback = options\n } else if (typeof callback !== 'function') {\n throw new Error('clear() requires a callback argument')\n }\n\n options = cleanRangeOptions(this, options)\n options.reverse = !!options.reverse\n options.limit = 'limit' in options ? options.limit : -1\n\n this._clear(options, callback)\n}\n\nAbstractLevelDOWN.prototype._clear = function (options, callback) {\n // Avoid setupIteratorOptions, would serialize range options a second time.\n options.keys = true\n options.values = false\n options.keyAsBuffer = true\n options.valueAsBuffer = true\n\n const iterator = this._iterator(options)\n const emptyOptions = {}\n\n const next = (err) => {\n if (err) {\n return iterator.end(function () {\n callback(err)\n })\n }\n\n iterator.next((err, key) => {\n if (err) return next(err)\n if (key === undefined) return iterator.end(callback)\n\n // This could be optimized by using a batch, but the default _clear\n // is not meant to be fast. Implementations have more room to optimize\n // if they override _clear. Note: using _del bypasses key serialization.\n this._del(key, emptyOptions, next)\n })\n }\n\n next()\n}\n\nAbstractLevelDOWN.prototype._setupIteratorOptions = function (options) {\n options = cleanRangeOptions(this, options)\n\n options.reverse = !!options.reverse\n options.keys = options.keys !== false\n options.values = options.values !== false\n options.limit = 'limit' in options ? options.limit : -1\n options.keyAsBuffer = options.keyAsBuffer !== false\n options.valueAsBuffer = options.valueAsBuffer !== false\n\n return options\n}\n\nfunction cleanRangeOptions (db, options) {\n const result = {}\n\n for (const k in options) {\n if (!hasOwnProperty.call(options, k)) continue\n\n if (k === 'start' || k === 'end') {\n throw new Error('Legacy range options (\"start\" and \"end\") have been removed')\n }\n\n let opt = options[k]\n\n if (isRangeOption(k)) {\n // Note that we don't reject nullish and empty options here. While\n // those types are invalid as keys, they are valid as range options.\n opt = db._serializeKey(opt)\n }\n\n result[k] = opt\n }\n\n return result\n}\n\nfunction isRangeOption (k) {\n return rangeOptions.indexOf(k) !== -1\n}\n\nAbstractLevelDOWN.prototype.iterator = function (options) {\n if (typeof options !== 'object' || options === null) options = {}\n options = this._setupIteratorOptions(options)\n return this._iterator(options)\n}\n\nAbstractLevelDOWN.prototype._iterator = function (options) {\n return new AbstractIterator(this)\n}\n\nAbstractLevelDOWN.prototype._chainedBatch = function () {\n return new AbstractChainedBatch(this)\n}\n\nAbstractLevelDOWN.prototype._serializeKey = function (key) {\n return key\n}\n\nAbstractLevelDOWN.prototype._serializeValue = function (value) {\n return value\n}\n\nAbstractLevelDOWN.prototype._checkKey = function (key) {\n if (key === null || key === undefined) {\n return new Error('key cannot be `null` or `undefined`')\n } else if (isBuffer(key) && key.length === 0) { // TODO: replace with typed array check\n return new Error('key cannot be an empty Buffer')\n } else if (key === '') {\n return new Error('key cannot be an empty String')\n } else if (Array.isArray(key) && key.length === 0) {\n return new Error('key cannot be an empty Array')\n }\n}\n\nAbstractLevelDOWN.prototype._checkValue = function (value) {\n if (value === null || value === undefined) {\n return new Error('value cannot be `null` or `undefined`')\n }\n}\n\n// TODO: docs and tests\nAbstractLevelDOWN.prototype.isOperational = function () {\n return this.status === 'open' || this._isOperational()\n}\n\n// Implementation may accept operations in other states too\nAbstractLevelDOWN.prototype._isOperational = function () {\n return false\n}\n\n// Expose browser-compatible nextTick for dependents\n// TODO: rename _nextTick to _queueMicrotask\n// TODO: after we drop node 10, also use queueMicrotask in node\nAbstractLevelDOWN.prototype._nextTick = require('./next-tick')\n\nmodule.exports = AbstractLevelDOWN\n\nfunction maybeError (db, callback) {\n if (!db.isOperational()) {\n db._nextTick(callback, new Error('Database is not open'))\n return true\n }\n\n return false\n}\n","'use strict'\n\nmodule.exports = function supports (...manifests) {\n const manifest = manifests.reduce((acc, m) => Object.assign(acc, m), {})\n\n return Object.assign(manifest, {\n // Features of abstract-leveldown\n bufferKeys: manifest.bufferKeys || false,\n snapshots: manifest.snapshots || false,\n permanence: manifest.permanence || false,\n seek: manifest.seek || false,\n clear: manifest.clear || false,\n getMany: manifest.getMany || false,\n keyIterator: manifest.keyIterator || false,\n valueIterator: manifest.valueIterator || false,\n iteratorNextv: manifest.iteratorNextv || false,\n iteratorAll: manifest.iteratorAll || false,\n\n // Features of abstract-leveldown that levelup doesn't have\n status: manifest.status || false,\n idempotentOpen: manifest.idempotentOpen || false,\n passiveOpen: manifest.passiveOpen || false,\n serialize: manifest.serialize || false,\n\n // Features of disk-based implementations\n createIfMissing: manifest.createIfMissing || false,\n errorIfExists: manifest.errorIfExists || false,\n\n // Features of level(up) that abstract-leveldown doesn't have yet\n deferredOpen: manifest.deferredOpen || false,\n openCallback: manifest.openCallback || false,\n promises: manifest.promises || false,\n streams: manifest.streams || false,\n encodings: maybeObject(manifest.encodings),\n events: maybeObject(manifest.events),\n\n // Methods that are not part of abstract-leveldown or levelup\n additionalMethods: Object.assign({}, manifest.additionalMethods)\n })\n}\n\nfunction maybeObject (value) {\n return !value ? false : Object.assign({}, value)\n}\n","/*!\n * Determine if an object is a Buffer\n *\n * @author Feross Aboukhadijeh <https://feross.org>\n * @license MIT\n */\n\nmodule.exports = function isBuffer (obj) {\n return obj != null && obj.constructor != null &&\n typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n","'use strict'\n\nvar queueTick = require('queue-tick')\n\nexports.fromCallback = function (callback, symbol) {\n if (callback === undefined) {\n var promise = new Promise(function (resolve, reject) {\n callback = function (err, res) {\n if (err) reject(err)\n else resolve(res)\n }\n })\n\n callback[symbol !== undefined ? symbol : 'promise'] = promise\n } else if (typeof callback !== 'function') {\n throw new TypeError('Callback must be a function')\n }\n\n return callback\n}\n\nexports.fromPromise = function (promise, callback) {\n if (callback === undefined) return promise\n\n promise\n .then(function (res) { queueTick(() => callback(null, res)) })\n .catch(function (err) { queueTick(() => callback(err)) })\n}\n","module.exports = typeof queueMicrotask === 'function' ? queueMicrotask : (fn) => Promise.resolve().then(fn)\n","'use strict'\n\nfunction AbstractIterator (db) {\n if (typeof db !== 'object' || db === null) {\n throw new TypeError('First argument must be an abstract-leveldown compliant store')\n }\n\n this.db = db\n this._ended = false\n this._nexting = false\n}\n\nAbstractIterator.prototype.next = function (callback) {\n // In callback mode, we return `this`\n let ret = this\n\n if (callback === undefined) {\n ret = new Promise(function (resolve, reject) {\n callback = function (err, key, value) {\n if (err) reject(err)\n else if (key === undefined && value === undefined) resolve()\n else resolve([key, value])\n }\n })\n } else if (typeof callback !== 'function') {\n throw new Error('next() requires a callback argument')\n }\n\n if (this._ended) {\n this._nextTick(callback, new Error('cannot call next() after end()'))\n return ret\n }\n\n if (this._nexting) {\n this._nextTick(callback, new Error('cannot call next() before previous next() has completed'))\n return ret\n }\n\n this._nexting = true\n this._next((err, ...rest) => {\n this._nexting = false\n callback(err, ...rest)\n })\n\n return ret\n}\n\nAbstractIterator.prototype._next = function (callback) {\n this._nextTick(callback)\n}\n\nAbstractIterator.prototype.seek = function (target) {\n if (this._ended) {\n throw new Error('cannot call seek() after end()')\n }\n if (this._nexting) {\n throw new Error('cannot call seek() before next() has completed')\n }\n\n target = this.db._serializeKey(target)\n this._seek(target)\n}\n\nAbstractIterator.prototype._seek = function (target) {}\n\nAbstractIterator.prototype.end = function (callback) {\n let promise\n\n if (callback === undefined) {\n promise = new Promise(function (resolve, reject) {\n callback = function (err) {\n if (err) reject(err)\n else resolve()\n }\n })\n } else if (typeof callback !== 'function') {\n throw new Error('end() requires a callback argument')\n }\n\n if (this._ended) {\n this._nextTick(callback, new Error('end() already called on iterator'))\n return promise\n }\n\n this._ended = true\n this._end(callback)\n\n return promise\n}\n\nAbstractIterator.prototype._end = function (callback) {\n this._nextTick(callback)\n}\n\nAbstractIterator.prototype[Symbol.asyncIterator] = async function * () {\n try {\n let kv\n\n while ((kv = (await this.next())) !== undefined) {\n yield kv\n }\n } finally {\n if (!this._ended) await this.end()\n }\n}\n\n// Expose browser-compatible nextTick for dependents\nAbstractIterator.prototype._nextTick = require('./next-tick')\n\nmodule.exports = AbstractIterator\n","'use strict'\n\nconst queueMicrotask = require('queue-microtask')\n\nmodule.exports = function (fn, ...args) {\n if (args.length === 0) {\n queueMicrotask(fn)\n } else {\n queueMicrotask(() => fn(...args))\n }\n}\n","/*! queue-microtask. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */\nlet promise\n\nmodule.exports = typeof queueMicrotask === 'function'\n ? queueMicrotask.bind(typeof window !== 'undefined' ? window : global)\n // reuse resolved promise, and allocate it lazily\n : cb => (promise || (promise = Promise.resolve()))\n .then(cb)\n .catch(err => setTimeout(() => { throw err }, 0))\n","'use strict'\n\nconst emptyOptions = Object.freeze({})\n\nfunction AbstractChainedBatch (db) {\n if (typeof db !== 'object' || db === null) {\n throw new TypeError('First argument must be an abstract-leveldown compliant store')\n }\n\n this.db = db\n this._operations = []\n this._written = false\n}\n\nAbstractChainedBatch.prototype._checkWritten = function () {\n if (this._written) {\n throw new Error('write() already called on this batch')\n }\n}\n\nAbstractChainedBatch.prototype.put = function (key, value, options) {\n this._checkWritten()\n\n const err = this.db._checkKey(key) || this.db._checkValue(value)\n if (err) throw err\n\n key = this.db._serializeKey(key)\n value = this.db._serializeValue(value)\n\n this._put(key, value, options != null ? options : emptyOptions)\n\n return this\n}\n\nAbstractChainedBatch.prototype._put = function (key, value, options) {\n this._operations.push({ ...options, type: 'put', key, value })\n}\n\nAbstractChainedBatch.prototype.del = function (key, options) {\n this._checkWritten()\n\n const err = this.db._checkKey(key)\n if (err) throw err\n\n key = this.db._serializeKey(key)\n this._del(key, options != null ? options : emptyOptions)\n\n return this\n}\n\nAbstractChainedBatch.prototype._del = function (key, options) {\n this._operations.push({ ...options, type: 'del', key })\n}\n\nAbstractChainedBatch.prototype.clear = function () {\n this._checkWritten()\n this._clear()\n\n return this\n}\n\nAbstractChainedBatch.prototype._clear = function () {\n this._operations = []\n}\n\nAbstractChainedBatch.prototype.write = function (options, callback) {\n this._checkWritten()\n\n if (typeof options === 'function') {\n callback = options\n }\n if (typeof callback !== 'function') {\n throw new Error('write() requires a callback argument')\n }\n if (typeof options !== 'object' || options === null) {\n options = {}\n }\n\n this._written = true\n this._write(options, callback)\n}\n\nAbstractChainedBatch.prototype._write = function (options, callback) {\n this.db._batch(this._operations, options, callback)\n}\n\n// Expose browser-compatible nextTick for dependents\nAbstractChainedBatch.prototype._nextTick = require('./next-tick')\n\nmodule.exports = AbstractChainedBatch\n","'use strict'\n\nexports.getCallback = function (options, callback) {\n return typeof options === 'function' ? options : callback\n}\n\nexports.getOptions = function (options) {\n return typeof options === 'object' && options !== null ? options : {}\n}\n","'use strict'\n\nconst { AbstractIterator } = require('abstract-leveldown')\nconst inherits = require('inherits')\nconst getCallback = require('./util').getCallback\n\nconst kOptions = Symbol('options')\nconst kIterator = Symbol('iterator')\nconst kOperations = Symbol('operations')\nconst kPromise = Symbol('promise')\n\nfunction DeferredIterator (db, options) {\n AbstractIterator.call(this, db)\n\n this[kOptions] = options\n this[kIterator] = null\n this[kOperations] = []\n}\n\ninherits(DeferredIterator, AbstractIterator)\n\nDeferredIterator.prototype.setDb = function (db) {\n this[kIterator] = db.iterator(this[kOptions])\n\n for (const op of this[kOperations].splice(0, this[kOperations].length)) {\n this[kIterator][op.method](...op.args)\n }\n}\n\nDeferredIterator.prototype.next = function (...args) {\n if (this.db.status === 'open') {\n return this[kIterator].next(...args)\n }\n\n const callback = getCallback(args, kPromise, function map (key, value) {\n if (key === undefined && value === undefined) {\n return undefined\n } else {\n return [key, value]\n }\n })\n\n if (this.db.status === 'opening') {\n this[kOperations].push({ method: 'next', args })\n } else {\n this._nextTick(callback, new Error('Database is not open'))\n }\n\n return callback[kPromise] || this\n}\n\nDeferredIterator.prototype.seek = function (...args) {\n if (this.db.status === 'open') {\n this[kIterator].seek(...args)\n } else if (this.db.status === 'opening') {\n this[kOperations].push({ method: 'seek', args })\n } else {\n throw new Error('Database is not open')\n }\n}\n\nDeferredIterator.prototype.end = function (...args) {\n if (this.db.status === 'open') {\n return this[kIterator].end(...args)\n }\n\n const callback = getCallback(args, kPromise)\n\n if (this.db.status === 'opening') {\n this[kOperations].push({ method: 'end', args })\n } else {\n this._nextTick(callback, new Error('Database is not open'))\n }\n\n return callback[kPromise] || this\n}\n\nfor (const method of ['next', 'seek', 'end']) {\n DeferredIterator.prototype['_' + method] = function () {\n /* istanbul ignore next: assertion */\n throw new Error('Did not expect private method to be called: ' + method)\n }\n}\n\nmodule.exports = DeferredIterator\n","'use strict'\n\nexports.getCallback = function (args, symbol, map) {\n let callback = args[args.length - 1]\n\n if (typeof callback !== 'function') {\n const promise = new Promise((resolve, reject) => {\n args.push(callback = function (err, ...results) {\n if (err) reject(err)\n else resolve(map ? map(...results) : results[0])\n })\n })\n\n callback[symbol] = promise\n }\n\n return callback\n}\n","'use strict'\n\nconst { AbstractChainedBatch } = require('abstract-leveldown')\nconst kOperations = Symbol('operations')\n\nmodule.exports = class DeferredChainedBatch extends AbstractChainedBatch {\n constructor (db) {\n super(db)\n this[kOperations] = []\n }\n\n _put (key, value, options) {\n this[kOperations].push({ ...options, type: 'put', key, value })\n }\n\n _del (key, options) {\n this[kOperations].push({ ...options, type: 'del', key })\n }\n\n _clear () {\n this[kOperations] = []\n }\n\n _write (options, callback) {\n // AbstractChainedBatch would call _batch(), we call batch()\n this.db.batch(this[kOperations], options, callback)\n }\n}\n","'use strict'\n\nconst inherits = require('inherits')\nconst { Readable } = require('readable-stream')\n\nmodule.exports = ReadStream\ninherits(ReadStream, Readable)\n\nfunction ReadStream (iterator, options) {\n if (!(this instanceof ReadStream)) return new ReadStream(iterator, options)\n options = options || {}\n Readable.call(this, Object.assign({}, options, {\n objectMode: true\n }))\n this._iterator = iterator\n this._options = options\n this.on('end', this.destroy.bind(this, null, null))\n}\n\nReadStream.prototype._read = function () {\n if (this.destroyed) return\n\n this._iterator.next((err, key, value) => {\n if (this.destroyed) return\n if (err) return this.destroy(err)\n\n if (key === undefined && value === undefined) {\n this.push(null)\n } else if (this._options.keys !== false && this._options.values === false) {\n this.push(key)\n } else if (this._options.keys === false && this._options.values !== false) {\n this.push(value)\n } else {\n this.push({ key, value })\n }\n })\n}\n\nReadStream.prototype._destroy = function (err, callback) {\n this._iterator.end(function (err2) {\n callback(err || err2)\n })\n}\n","exports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = exports;\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\nexports.finished = require('./lib/internal/streams/end-of-stream.js');\nexports.pipeline = require('./lib/internal/streams/pipeline.js');\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n'use strict';\n\nmodule.exports = Readable;\n/*<replacement>*/\n\nvar Duplex;\n/*</replacement>*/\n\nReadable.ReadableState = ReadableState;\n/*<replacement>*/\n\nvar EE = require('events').EventEmitter;\n\nvar EElistenerCount = function EElistenerCount(emitter, type) {\n return emitter.listeners(type).length;\n};\n/*</replacement>*/\n\n/*<replacement>*/\n\n\nvar Stream = require('./internal/streams/stream');\n/*</replacement>*/\n\n\nvar Buffer = require('buffer').Buffer;\n\nvar OurUint8Array = global.Uint8Array || function () {};\n\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\n\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n/*<replacement>*/\n\n\nvar debugUtil = require('util');\n\nvar debug;\n\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function debug() {};\n}\n/*</replacement>*/\n\n\nvar BufferList = require('./internal/streams/buffer_list');\n\nvar destroyImpl = require('./internal/streams/destroy');\n\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\n\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT; // Lazy loaded to improve the startup performance.\n\n\nvar StringDecoder;\nvar createReadableStreamAsyncIterator;\nvar from;\n\nrequire('inherits')(Readable, Stream);\n\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\n\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn); // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\n\nfunction ReadableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {}; // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n\n this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex); // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false; // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n\n this.sync = true; // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n this.paused = true; // Should close be emitted on destroy. Defaults to true.\n\n this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'end' (and potentially 'finish')\n\n this.autoDestroy = !!options.autoDestroy; // has it been destroyed\n\n this.destroyed = false; // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n\n this.defaultEncoding = options.defaultEncoding || 'utf8'; // the number of writers that are awaiting a drain event in .pipe()s\n\n this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled\n\n this.readingMore = false;\n this.decoder = null;\n this.encoding = null;\n\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\n\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n if (!(this instanceof Readable)) return new Readable(options); // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5\n\n var isDuplex = this instanceof Duplex;\n this._readableState = new ReadableState(options, this, isDuplex); // legacy\n\n this.readable = true;\n\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n\n Stream.call(this);\n}\n\nObject.defineProperty(Readable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined) {\n return false;\n }\n\n return this._readableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n } // backward compatibility, the user is explicitly\n // managing destroyed\n\n\n this._readableState.destroyed = value;\n }\n});\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\n\nReadable.prototype._destroy = function (err, cb) {\n cb(err);\n}; // Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\n\n\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n}; // Unshift should *always* be something directly out of read()\n\n\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\n\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n debug('readableAddChunk', chunk);\n var state = stream._readableState;\n\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n\n if (er) {\n errorOrDestroy(stream, er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (addToFront) {\n if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());\n } else if (state.destroyed) {\n return false;\n } else {\n state.reading = false;\n\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n maybeReadMore(stream, state);\n }\n } // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n\n\n return !state.ended && (state.length < state.highWaterMark || state.length === 0);\n}\n\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n state.awaitDrain = 0;\n stream.emit('data', chunk);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n if (state.needReadable) emitReadable(stream);\n }\n\n maybeReadMore(stream, state);\n}\n\nfunction chunkInvalid(state, chunk) {\n var er;\n\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);\n }\n\n return er;\n}\n\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n}; // backwards compatibility.\n\n\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n var decoder = new StringDecoder(enc);\n this._readableState.decoder = decoder; // If setEncoding(null), decoder.encoding equals utf8\n\n this._readableState.encoding = this._readableState.decoder.encoding; // Iterate over current buffer to convert already stored Buffers:\n\n var p = this._readableState.buffer.head;\n var content = '';\n\n while (p !== null) {\n content += decoder.write(p.data);\n p = p.next;\n }\n\n this._readableState.buffer.clear();\n\n if (content !== '') this._readableState.buffer.push(content);\n this._readableState.length = content.length;\n return this;\n}; // Don't raise the hwm > 1GB\n\n\nvar MAX_HWM = 0x40000000;\n\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n\n return n;\n} // This function is designed to be inlinable, so please take care when making\n// changes to the function body.\n\n\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n } // If we're asking for more than the current hwm, then raise the hwm.\n\n\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n; // Don't have enough\n\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n\n return state.length;\n} // you can override either this method, or the async _read(n) below.\n\n\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n if (n !== 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n\n if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n\n n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up.\n\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n } // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n // if we need a readable event, then we need to do some reading.\n\n\n var doRead = state.needReadable;\n debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some\n\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n } // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n\n\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true; // if the length is currently zero, then we *need* a readable event.\n\n if (state.length === 0) state.needReadable = true; // call internal read method\n\n this._read(state.highWaterMark);\n\n state.sync = false; // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark;\n n = 0;\n } else {\n state.length -= n;\n state.awaitDrain = 0;\n }\n\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick.\n\n if (nOrig !== n && state.ended) endReadable(this);\n }\n\n if (ret !== null) this.emit('data', ret);\n return ret;\n};\n\nfunction onEofChunk(stream, state) {\n debug('onEofChunk');\n if (state.ended) return;\n\n if (state.decoder) {\n var chunk = state.decoder.end();\n\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n\n state.ended = true;\n\n if (state.sync) {\n // if we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call\n emitReadable(stream);\n } else {\n // emit 'readable' now to make sure it gets picked up.\n state.needReadable = false;\n\n if (!state.emittedReadable) {\n state.emittedReadable = true;\n emitReadable_(stream);\n }\n }\n} // Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\n\n\nfunction emitReadable(stream) {\n var state = stream._readableState;\n debug('emitReadable', state.needReadable, state.emittedReadable);\n state.needReadable = false;\n\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n process.nextTick(emitReadable_, stream);\n }\n}\n\nfunction emitReadable_(stream) {\n var state = stream._readableState;\n debug('emitReadable_', state.destroyed, state.length, state.ended);\n\n if (!state.destroyed && (state.length || state.ended)) {\n stream.emit('readable');\n state.emittedReadable = false;\n } // The stream needs another readable event if\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n\n\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;\n flow(stream);\n} // at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\n\n\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n process.nextTick(maybeReadMore_, stream, state);\n }\n}\n\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {\n var len = state.length;\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length) // didn't get any data, stop spinning.\n break;\n }\n\n state.readingMore = false;\n} // abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\n\n\nReadable.prototype._read = function (n) {\n errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));\n};\n\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n\n default:\n state.pipes.push(dest);\n break;\n }\n\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);\n dest.on('unpipe', onunpipe);\n\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n\n function onend() {\n debug('onend');\n dest.end();\n } // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n\n\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n var cleanedUp = false;\n\n function cleanup() {\n debug('cleanup'); // cleanup event handlers once the pipe is broken\n\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n cleanedUp = true; // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n\n src.on('data', ondata);\n\n function ondata(chunk) {\n debug('ondata');\n var ret = dest.write(chunk);\n debug('dest.write', ret);\n\n if (ret === false) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n }\n\n src.pause();\n }\n } // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n\n\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);\n } // Make sure our error handler is attached before userland ones.\n\n\n prependListener(dest, 'error', onerror); // Both close and finish should trigger unpipe, but only once.\n\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n\n dest.once('close', onclose);\n\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n\n dest.once('finish', onfinish);\n\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n } // tell the dest that it's being piped to\n\n\n dest.emit('pipe', src); // start the flow if it hasn't been started already.\n\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n\n return dest;\n};\n\nfunction pipeOnDrain(src) {\n return function pipeOnDrainFunctionResult() {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\n\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = {\n hasUnpiped: false\n }; // if we're not piping anywhere, then do nothing.\n\n if (state.pipesCount === 0) return this; // just one destination. most common case.\n\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n if (!dest) dest = state.pipes; // got a match.\n\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n } // slow case. multiple pipe destinations.\n\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n\n for (var i = 0; i < len; i++) {\n dests[i].emit('unpipe', this, {\n hasUnpiped: false\n });\n }\n\n return this;\n } // try to find the right one.\n\n\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n dest.emit('unpipe', this, unpipeInfo);\n return this;\n}; // set up data events if they are asked for\n// Ensure readable listeners eventually get something\n\n\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n var state = this._readableState;\n\n if (ev === 'data') {\n // update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0; // Try start flowing on next tick if stream isn't explicitly paused\n\n if (state.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.flowing = false;\n state.emittedReadable = false;\n debug('on readable', state.length, state.reading);\n\n if (state.length) {\n emitReadable(this);\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this);\n }\n }\n }\n\n return res;\n};\n\nReadable.prototype.addListener = Readable.prototype.on;\n\nReadable.prototype.removeListener = function (ev, fn) {\n var res = Stream.prototype.removeListener.call(this, ev, fn);\n\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n\n return res;\n};\n\nReadable.prototype.removeAllListeners = function (ev) {\n var res = Stream.prototype.removeAllListeners.apply(this, arguments);\n\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n\n return res;\n};\n\nfunction updateReadableListening(self) {\n var state = self._readableState;\n state.readableListening = self.listenerCount('readable') > 0;\n\n if (state.resumeScheduled && !state.paused) {\n // flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true; // crude way to check if we should resume\n } else if (self.listenerCount('data') > 0) {\n self.resume();\n }\n}\n\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n} // pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\n\n\nReadable.prototype.resume = function () {\n var state = this._readableState;\n\n if (!state.flowing) {\n debug('resume'); // we flow only if there is no one listening\n // for readable, but we still have to call\n // resume()\n\n state.flowing = !state.readableListening;\n resume(this, state);\n }\n\n state.paused = false;\n return this;\n};\n\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n process.nextTick(resume_, stream, state);\n }\n}\n\nfunction resume_(stream, state) {\n debug('resume', state.reading);\n\n if (!state.reading) {\n stream.read(0);\n }\n\n state.resumeScheduled = false;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\n\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n\n if (this._readableState.flowing !== false) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n\n this._readableState.paused = true;\n return this;\n};\n\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n\n while (state.flowing && stream.read() !== null) {\n ;\n }\n} // wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\n\n\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n\n var state = this._readableState;\n var paused = false;\n stream.on('end', function () {\n debug('wrapped end');\n\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n\n _this.push(null);\n });\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode\n\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\n var ret = _this.push(chunk);\n\n if (!ret) {\n paused = true;\n stream.pause();\n }\n }); // proxy all the other methods.\n // important when wrapping filters and duplexes.\n\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function methodWrap(method) {\n return function methodWrapReturnFunction() {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n } // proxy certain important events.\n\n\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n } // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n\n\n this._read = function (n) {\n debug('wrapped _read', n);\n\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n\n return this;\n};\n\nif (typeof Symbol === 'function') {\n Readable.prototype[Symbol.asyncIterator] = function () {\n if (createReadableStreamAsyncIterator === undefined) {\n createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');\n }\n\n return createReadableStreamAsyncIterator(this);\n };\n}\n\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.highWaterMark;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState && this._readableState.buffer;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableFlowing', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.flowing;\n },\n set: function set(state) {\n if (this._readableState) {\n this._readableState.flowing = state;\n }\n }\n}); // exposed for testing purposes only.\n\nReadable._fromList = fromList;\nObject.defineProperty(Readable.prototype, 'readableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.length;\n }\n}); // Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\n\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = state.buffer.consume(n, state.decoder);\n }\n return ret;\n}\n\nfunction endReadable(stream) {\n var state = stream._readableState;\n debug('endReadable', state.endEmitted);\n\n if (!state.endEmitted) {\n state.ended = true;\n process.nextTick(endReadableNT, state, stream);\n }\n}\n\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length); // Check that we didn't get one last unshift.\n\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well\n var wState = stream._writableState;\n\n if (!wState || wState.autoDestroy && wState.finished) {\n stream.destroy();\n }\n }\n }\n}\n\nif (typeof Symbol === 'function') {\n Readable.from = function (iterable, opts) {\n if (from === undefined) {\n from = require('./internal/streams/from');\n }\n\n return from(Readable, iterable, opts);\n };\n}\n\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n\n return -1;\n}","module.exports = require('events').EventEmitter;\n","'use strict';\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nvar _require = require('buffer'),\n Buffer = _require.Buffer;\n\nvar _require2 = require('util'),\n inspect = _require2.inspect;\n\nvar custom = inspect && inspect.custom || 'inspect';\n\nfunction copyBuffer(src, target, offset) {\n Buffer.prototype.copy.call(src, target, offset);\n}\n\nmodule.exports =\n/*#__PURE__*/\nfunction () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n\n _createClass(BufferList, [{\n key: \"push\",\n value: function push(v) {\n var entry = {\n data: v,\n next: null\n };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n }\n }, {\n key: \"unshift\",\n value: function unshift(v) {\n var entry = {\n data: v,\n next: this.head\n };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n }\n }, {\n key: \"shift\",\n value: function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.head = this.tail = null;\n this.length = 0;\n }\n }, {\n key: \"join\",\n value: function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n\n while (p = p.next) {\n ret += s + p.data;\n }\n\n return ret;\n }\n }, {\n key: \"concat\",\n value: function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n\n return ret;\n } // Consumes a specified amount of bytes or characters from the buffered data.\n\n }, {\n key: \"consume\",\n value: function consume(n, hasStrings) {\n var ret;\n\n if (n < this.head.data.length) {\n // `slice` is the same for buffers and strings.\n ret = this.head.data.slice(0, n);\n this.head.data = this.head.data.slice(n);\n } else if (n === this.head.data.length) {\n // First chunk is a perfect match.\n ret = this.shift();\n } else {\n // Result spans more than one buffer.\n ret = hasStrings ? this._getString(n) : this._getBuffer(n);\n }\n\n return ret;\n }\n }, {\n key: \"first\",\n value: function first() {\n return this.head.data;\n } // Consumes a specified amount of characters from the buffered data.\n\n }, {\n key: \"_getString\",\n value: function _getString(n) {\n var p = this.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = str.slice(nb);\n }\n\n break;\n }\n\n ++c;\n }\n\n this.length -= c;\n return ret;\n } // Consumes a specified amount of bytes from the buffered data.\n\n }, {\n key: \"_getBuffer\",\n value: function _getBuffer(n) {\n var ret = Buffer.allocUnsafe(n);\n var p = this.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = buf.slice(nb);\n }\n\n break;\n }\n\n ++c;\n }\n\n this.length -= c;\n return ret;\n } // Make sure the linked list only shows the minimal necessary information.\n\n }, {\n key: custom,\n value: function value(_, options) {\n return inspect(this, _objectSpread({}, options, {\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n }));\n }\n }]);\n\n return BufferList;\n}();","'use strict'; // undocumented cb() API, needed for core, not for public API\n\nfunction destroy(err, cb) {\n var _this = this;\n\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n process.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n process.nextTick(emitErrorNT, this, err);\n }\n }\n\n return this;\n } // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n } // if this is a duplex stream mark the writable part as destroyed as well\n\n\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n } else if (cb) {\n process.nextTick(emitCloseNT, _this);\n cb(err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n });\n\n return this;\n}\n\nfunction emitErrorAndCloseNT(self, err) {\n emitErrorNT(self, err);\n emitCloseNT(self);\n}\n\nfunction emitCloseNT(self) {\n if (self._writableState && !self._writableState.emitClose) return;\n if (self._readableState && !self._readableState.emitClose) return;\n self.emit('close');\n}\n\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\n\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\n\nfunction errorOrDestroy(stream, err) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n var rState = stream._readableState;\n var wState = stream._writableState;\n if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);\n}\n\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy,\n errorOrDestroy: errorOrDestroy\n};","'use strict';\n\nvar ERR_INVALID_OPT_VALUE = require('../../../errors').codes.ERR_INVALID_OPT_VALUE;\n\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;\n}\n\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);\n\n if (hwm != null) {\n if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {\n var name = isDuplex ? duplexKey : 'highWaterMark';\n throw new ERR_INVALID_OPT_VALUE(name, hwm);\n }\n\n return Math.floor(hwm);\n } // Default value\n\n\n return state.objectMode ? 16 : 16 * 1024;\n}\n\nmodule.exports = {\n getHighWaterMark: getHighWaterMark\n};","'use strict';\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar codes = {};\n\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n\n var NodeError =\n /*#__PURE__*/\n function (_Base) {\n _inheritsLoose(NodeError, _Base);\n\n function NodeError(arg1, arg2, arg3) {\n return _Base.call(this, getMessage(arg1, arg2, arg3)) || this;\n }\n\n return NodeError;\n }(Base);\n\n NodeError.prototype.name = Base.name;\n NodeError.prototype.code = code;\n codes[code] = NodeError;\n} // https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\n\n\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\n\n\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\n\n\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n\n return str.substring(this_len - search.length, this_len) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\n\n\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\n\ncreateErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {\n return 'The value \"' + value + '\" is invalid for option \"' + name + '\"';\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n var determiner;\n\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n\n var msg;\n\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n\n msg += \". Received type \".concat(typeof actual);\n return msg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');\ncreateErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {\n return 'The ' + name + ' method is not implemented';\n});\ncreateErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');\ncreateErrorType('ERR_STREAM_DESTROYED', function (name) {\n return 'Cannot call ' + name + ' after a stream was destroyed';\n});\ncreateErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');\ncreateErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');\ncreateErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');\ncreateErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);\ncreateErrorType('ERR_UNKNOWN_ENCODING', function (arg) {\n return 'Unknown encoding: ' + arg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');\nmodule.exports.codes = codes;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n'use strict';\n/*<replacement>*/\n\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n\n for (var key in obj) {\n keys.push(key);\n }\n\n return keys;\n};\n/*</replacement>*/\n\n\nmodule.exports = Duplex;\n\nvar Readable = require('./_stream_readable');\n\nvar Writable = require('./_stream_writable');\n\nrequire('inherits')(Duplex, Readable);\n\n{\n // Allow the keys array to be GC'ed.\n var keys = objectKeys(Writable.prototype);\n\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\n\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n Readable.call(this, options);\n Writable.call(this, options);\n this.allowHalfOpen = true;\n\n if (options) {\n if (options.readable === false) this.readable = false;\n if (options.writable === false) this.writable = false;\n\n if (options.allowHalfOpen === false) {\n this.allowHalfOpen = false;\n this.once('end', onend);\n }\n }\n}\n\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n}); // the no-half-open enforcer\n\nfunction onend() {\n // If the writable side ended, then we're ok.\n if (this._writableState.ended) return; // no more data can be written.\n // But allow more writes to happen in this tick.\n\n process.nextTick(onEndNT, this);\n}\n\nfunction onEndNT(self) {\n self.end();\n}\n\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n } // backward compatibility, the user is explicitly\n // managing destroyed\n\n\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n'use strict';\n\nmodule.exports = Writable;\n/* <replacement> */\n\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n} // It seems a linked list but it is not\n// there will be only 2 of these for each stream\n\n\nfunction CorkedRequest(state) {\n var _this = this;\n\n this.next = null;\n this.entry = null;\n\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* </replacement> */\n\n/*<replacement>*/\n\n\nvar Duplex;\n/*</replacement>*/\n\nWritable.WritableState = WritableState;\n/*<replacement>*/\n\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/*</replacement>*/\n\n/*<replacement>*/\n\nvar Stream = require('./internal/streams/stream');\n/*</replacement>*/\n\n\nvar Buffer = require('buffer').Buffer;\n\nvar OurUint8Array = global.Uint8Array || function () {};\n\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\n\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\nvar destroyImpl = require('./internal/streams/destroy');\n\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\n\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,\n ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;\n\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\n\nrequire('inherits')(Writable, Stream);\n\nfunction nop() {}\n\nfunction WritableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {}; // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n\n this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex); // if _final has been called\n\n this.finalCalled = false; // drain event flag.\n\n this.needDrain = false; // at the start of calling end()\n\n this.ending = false; // when end() has been called, and returned\n\n this.ended = false; // when 'finish' is emitted\n\n this.finished = false; // has it been destroyed\n\n this.destroyed = false; // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode; // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n\n this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n\n this.length = 0; // a flag to see when we're in the middle of a write.\n\n this.writing = false; // when true all writes will be buffered until .uncork() call\n\n this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n\n this.sync = true; // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n\n this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb)\n\n this.onwrite = function (er) {\n onwrite(stream, er);\n }; // the callback that the user supplies to write(chunk,encoding,cb)\n\n\n this.writecb = null; // the amount that is being written when _write is called.\n\n this.writelen = 0;\n this.bufferedRequest = null;\n this.lastBufferedRequest = null; // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n\n this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n\n this.prefinished = false; // True if the error was already emitted and should not be thrown again\n\n this.errorEmitted = false; // Should close be emitted on destroy. Defaults to true.\n\n this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'finish' (and potentially 'end')\n\n this.autoDestroy = !!options.autoDestroy; // count buffered requests\n\n this.bufferedRequestCount = 0; // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n\n this.corkedRequestsFree = new CorkedRequest(this);\n}\n\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n\n while (current) {\n out.push(current);\n current = current.next;\n }\n\n return out;\n};\n\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function writableStateBufferGetter() {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})(); // Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\n\n\nvar realHasInstance;\n\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function value(object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function realHasInstance(object) {\n return object instanceof this;\n };\n}\n\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex'); // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5\n\n var isDuplex = this instanceof Duplex;\n if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);\n this._writableState = new WritableState(options, this, isDuplex); // legacy.\n\n this.writable = true;\n\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n if (typeof options.writev === 'function') this._writev = options.writev;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n if (typeof options.final === 'function') this._final = options.final;\n }\n\n Stream.call(this);\n} // Otherwise people can pipe Writable streams, which is just wrong.\n\n\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());\n};\n\nfunction writeAfterEnd(stream, cb) {\n var er = new ERR_STREAM_WRITE_AFTER_END(); // TODO: defer error events consistently everywhere, not just the cb\n\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n} // Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\n\n\nfunction validChunk(stream, state, chunk, cb) {\n var er;\n\n if (chunk === null) {\n er = new ERR_STREAM_NULL_VALUES();\n } else if (typeof chunk !== 'string' && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);\n }\n\n if (er) {\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n return false;\n }\n\n return true;\n}\n\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n if (typeof cb !== 'function') cb = nop;\n if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n return ret;\n};\n\nWritable.prototype.cork = function () {\n this._writableState.corked++;\n};\n\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n\n if (state.corked) {\n state.corked--;\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\n\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\n\nObject.defineProperty(Writable.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\n\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n\n return chunk;\n}\n\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n}); // if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\n\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n\n var len = state.objectMode ? 1 : chunk.length;\n state.length += len;\n var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false.\n\n if (!ret) state.needDrain = true;\n\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n\n return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n process.nextTick(cb, er); // this can emit finish, and it will always happen\n // after error\n\n process.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er); // this can emit finish, but finish must\n // always follow error\n\n finishMaybe(stream, state);\n }\n}\n\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();\n onwriteStateUpdate(state);\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state) || stream.destroyed;\n\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n\n if (sync) {\n process.nextTick(afterWrite, stream, state, finished, cb);\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n} // Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\n\n\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n} // if there's something in the buffer waiting, then process it\n\n\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n var count = 0;\n var allBuffers = true;\n\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n\n buffer.allBuffers = allBuffers;\n doWrite(stream, state, true, state.length, buffer, '', holder.finish); // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n\n state.pendingcb++;\n state.lastBufferedRequest = null;\n\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--; // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n\n if (state.writing) {\n break;\n }\n }\n\n if (entry === null) state.lastBufferedRequest = null;\n }\n\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); // .end() fully uncorks\n\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n } // ignore unnecessary end() calls.\n\n\n if (!state.ending) endWritable(this, state, cb);\n return this;\n};\n\nObject.defineProperty(Writable.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\n\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\n\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n\n if (err) {\n errorOrDestroy(stream, err);\n }\n\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\n\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.pendingcb++;\n state.finalCalled = true;\n process.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\n\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n\n if (need) {\n prefinish(stream, state);\n\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well\n var rState = stream._readableState;\n\n if (!rState || rState.autoDestroy && rState.endEmitted) {\n stream.destroy();\n }\n }\n }\n }\n\n return need;\n}\n\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n\n if (cb) {\n if (state.finished) process.nextTick(cb);else stream.once('finish', cb);\n }\n\n state.ended = true;\n stream.writable = false;\n}\n\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n } // reuse the free corkReq.\n\n\n state.corkedRequestsFree.next = corkReq;\n}\n\nObject.defineProperty(Writable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._writableState === undefined) {\n return false;\n }\n\n return this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n } // backward compatibility, the user is explicitly\n // managing destroyed\n\n\n this._writableState.destroyed = value;\n }\n});\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\n\nWritable.prototype._destroy = function (err, cb) {\n cb(err);\n};","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/*<replacement>*/\n\nvar Buffer = require('safe-buffer').Buffer;\n/*</replacement>*/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':\n return true;\n default:\n return false;\n }\n};\n\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n};\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\n\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\n\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\n\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\n\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\n\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","/*! safe-buffer. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","'use strict';\n\nvar _Object$setPrototypeO;\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar finished = require('./end-of-stream');\n\nvar kLastResolve = Symbol('lastResolve');\nvar kLastReject = Symbol('lastReject');\nvar kError = Symbol('error');\nvar kEnded = Symbol('ended');\nvar kLastPromise = Symbol('lastPromise');\nvar kHandlePromise = Symbol('handlePromise');\nvar kStream = Symbol('stream');\n\nfunction createIterResult(value, done) {\n return {\n value: value,\n done: done\n };\n}\n\nfunction readAndResolve(iter) {\n var resolve = iter[kLastResolve];\n\n if (resolve !== null) {\n var data = iter[kStream].read(); // we defer if data is null\n // we can be expecting either 'end' or\n // 'error'\n\n if (data !== null) {\n iter[kLastPromise] = null;\n iter[kLastResolve] = null;\n iter[kLastReject] = null;\n resolve(createIterResult(data, false));\n }\n }\n}\n\nfunction onReadable(iter) {\n // we wait for the next tick, because it might\n // emit an error with process.nextTick\n process.nextTick(readAndResolve, iter);\n}\n\nfunction wrapForNext(lastPromise, iter) {\n return function (resolve, reject) {\n lastPromise.then(function () {\n if (iter[kEnded]) {\n resolve(createIterResult(undefined, true));\n return;\n }\n\n iter[kHandlePromise](resolve, reject);\n }, reject);\n };\n}\n\nvar AsyncIteratorPrototype = Object.getPrototypeOf(function () {});\nvar ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {\n get stream() {\n return this[kStream];\n },\n\n next: function next() {\n var _this = this;\n\n // if we have detected an error in the meanwhile\n // reject straight away\n var error = this[kError];\n\n if (error !== null) {\n return Promise.reject(error);\n }\n\n if (this[kEnded]) {\n return Promise.resolve(createIterResult(undefined, true));\n }\n\n if (this[kStream].destroyed) {\n // We need to defer via nextTick because if .destroy(err) is\n // called, the error will be emitted via nextTick, and\n // we cannot guarantee that there is no error lingering around\n // waiting to be emitted.\n return new Promise(function (resolve, reject) {\n process.nextTick(function () {\n if (_this[kError]) {\n reject(_this[kError]);\n } else {\n resolve(createIterResult(undefined, true));\n }\n });\n });\n } // if we have multiple next() calls\n // we will wait for the previous Promise to finish\n // this logic is optimized to support for await loops,\n // where next() is only called once at a time\n\n\n var lastPromise = this[kLastPromise];\n var promise;\n\n if (lastPromise) {\n promise = new Promise(wrapForNext(lastPromise, this));\n } else {\n // fast path needed to support multiple this.push()\n // without triggering the next() queue\n var data = this[kStream].read();\n\n if (data !== null) {\n return Promise.resolve(createIterResult(data, false));\n }\n\n promise = new Promise(this[kHandlePromise]);\n }\n\n this[kLastPromise] = promise;\n return promise;\n }\n}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {\n return this;\n}), _defineProperty(_Object$setPrototypeO, \"return\", function _return() {\n var _this2 = this;\n\n // destroy(err, cb) is a private API\n // we can guarantee we have that here, because we control the\n // Readable class this is attached to\n return new Promise(function (resolve, reject) {\n _this2[kStream].destroy(null, function (err) {\n if (err) {\n reject(err);\n return;\n }\n\n resolve(createIterResult(undefined, true));\n });\n });\n}), _Object$setPrototypeO), AsyncIteratorPrototype);\n\nvar createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {\n var _Object$create;\n\n var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {\n value: stream,\n writable: true\n }), _defineProperty(_Object$create, kLastResolve, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kLastReject, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kError, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kEnded, {\n value: stream._readableState.endEmitted,\n writable: true\n }), _defineProperty(_Object$create, kHandlePromise, {\n value: function value(resolve, reject) {\n var data = iterator[kStream].read();\n\n if (data) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(data, false));\n } else {\n iterator[kLastResolve] = resolve;\n iterator[kLastReject] = reject;\n }\n },\n writable: true\n }), _Object$create));\n iterator[kLastPromise] = null;\n finished(stream, function (err) {\n if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n var reject = iterator[kLastReject]; // reject if we are waiting for data in the Promise\n // returned by next() and store the error\n\n if (reject !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n reject(err);\n }\n\n iterator[kError] = err;\n return;\n }\n\n var resolve = iterator[kLastResolve];\n\n if (resolve !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(undefined, true));\n }\n\n iterator[kEnded] = true;\n });\n stream.on('readable', onReadable.bind(null, iterator));\n return iterator;\n};\n\nmodule.exports = createReadableStreamAsyncIterator;","// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n'use strict';\n\nvar ERR_STREAM_PREMATURE_CLOSE = require('../../../errors').codes.ERR_STREAM_PREMATURE_CLOSE;\n\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n callback.apply(this, args);\n };\n}\n\nfunction noop() {}\n\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\n\nfunction eos(stream, opts, callback) {\n if (typeof opts === 'function') return eos(stream, null, opts);\n if (!opts) opts = {};\n callback = once(callback || noop);\n var readable = opts.readable || opts.readable !== false && stream.readable;\n var writable = opts.writable || opts.writable !== false && stream.writable;\n\n var onlegacyfinish = function onlegacyfinish() {\n if (!stream.writable) onfinish();\n };\n\n var writableEnded = stream._writableState && stream._writableState.finished;\n\n var onfinish = function onfinish() {\n writable = false;\n writableEnded = true;\n if (!readable) callback.call(stream);\n };\n\n var readableEnded = stream._readableState && stream._readableState.endEmitted;\n\n var onend = function onend() {\n readable = false;\n readableEnded = true;\n if (!writable) callback.call(stream);\n };\n\n var onerror = function onerror(err) {\n callback.call(stream, err);\n };\n\n var onclose = function onclose() {\n var err;\n\n if (readable && !readableEnded) {\n if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n\n if (writable && !writableEnded) {\n if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n };\n\n var onrequest = function onrequest() {\n stream.req.on('finish', onfinish);\n };\n\n if (isRequest(stream)) {\n stream.on('complete', onfinish);\n stream.on('abort', onclose);\n if (stream.req) onrequest();else stream.on('request', onrequest);\n } else if (writable && !stream._writableState) {\n // legacy streams\n stream.on('end', onlegacyfinish);\n stream.on('close', onlegacyfinish);\n }\n\n stream.on('end', onend);\n stream.on('finish', onfinish);\n if (opts.error !== false) stream.on('error', onerror);\n stream.on('close', onclose);\n return function () {\n stream.removeListener('complete', onfinish);\n stream.removeListener('abort', onclose);\n stream.removeListener('request', onrequest);\n if (stream.req) stream.req.removeListener('finish', onfinish);\n stream.removeListener('end', onlegacyfinish);\n stream.removeListener('close', onlegacyfinish);\n stream.removeListener('finish', onfinish);\n stream.removeListener('end', onend);\n stream.removeListener('error', onerror);\n stream.removeListener('close', onclose);\n };\n}\n\nmodule.exports = eos;","module.exports = function () {\n throw new Error('Readable.from is not available in the browser')\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n'use strict';\n\nmodule.exports = Transform;\n\nvar _require$codes = require('../errors').codes,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,\n ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;\n\nvar Duplex = require('./_stream_duplex');\n\nrequire('inherits')(Transform, Duplex);\n\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n var cb = ts.writecb;\n\n if (cb === null) {\n return this.emit('error', new ERR_MULTIPLE_CALLBACK());\n }\n\n ts.writechunk = null;\n ts.writecb = null;\n if (data != null) // single equals check for both `null` and `undefined`\n this.push(data);\n cb(er);\n var rs = this._readableState;\n rs.reading = false;\n\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\n\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n Duplex.call(this, options);\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n }; // start out asking for a readable event once data is transformed.\n\n this._readableState.needReadable = true; // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n\n this._readableState.sync = false;\n\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n if (typeof options.flush === 'function') this._flush = options.flush;\n } // When the writable side finishes, then flush out anything remaining.\n\n\n this.on('prefinish', prefinish);\n}\n\nfunction prefinish() {\n var _this = this;\n\n if (typeof this._flush === 'function' && !this._readableState.destroyed) {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\n\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n}; // This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\n\n\nTransform.prototype._transform = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));\n};\n\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n}; // Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\n\n\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n\n if (ts.writechunk !== null && !ts.transforming) {\n ts.transforming = true;\n\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\n\nTransform.prototype._destroy = function (err, cb) {\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n });\n};\n\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n if (data != null) // single equals check for both `null` and `undefined`\n stream.push(data); // TODO(BridgeAR): Write a test for these two error cases\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n\n if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();\n if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();\n return stream.push(null);\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n'use strict';\n\nmodule.exports = PassThrough;\n\nvar Transform = require('./_stream_transform');\n\nrequire('inherits')(PassThrough, Transform);\n\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n Transform.call(this, options);\n}\n\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n'use strict';\n\nvar eos;\n\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n callback.apply(void 0, arguments);\n };\n}\n\nvar _require$codes = require('../../../errors').codes,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;\n\nfunction noop(err) {\n // Rethrow the error if it exists to avoid swallowing it\n if (err) throw err;\n}\n\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\n\nfunction destroyer(stream, reading, writing, callback) {\n callback = once(callback);\n var closed = false;\n stream.on('close', function () {\n closed = true;\n });\n if (eos === undefined) eos = require('./end-of-stream');\n eos(stream, {\n readable: reading,\n writable: writing\n }, function (err) {\n if (err) return callback(err);\n closed = true;\n callback();\n });\n var destroyed = false;\n return function (err) {\n if (closed) return;\n if (destroyed) return;\n destroyed = true; // request.destroy just do .end - .abort is what we want\n\n if (isRequest(stream)) return stream.abort();\n if (typeof stream.destroy === 'function') return stream.destroy();\n callback(err || new ERR_STREAM_DESTROYED('pipe'));\n };\n}\n\nfunction call(fn) {\n fn();\n}\n\nfunction pipe(from, to) {\n return from.pipe(to);\n}\n\nfunction popCallback(streams) {\n if (!streams.length) return noop;\n if (typeof streams[streams.length - 1] !== 'function') return noop;\n return streams.pop();\n}\n\nfunction pipeline() {\n for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {\n streams[_key] = arguments[_key];\n }\n\n var callback = popCallback(streams);\n if (Array.isArray(streams[0])) streams = streams[0];\n\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams');\n }\n\n var error;\n var destroys = streams.map(function (stream, i) {\n var reading = i < streams.length - 1;\n var writing = i > 0;\n return destroyer(stream, reading, writing, function (err) {\n if (!error) error = err;\n if (err) destroys.forEach(call);\n if (reading) return;\n destroys.forEach(call);\n callback(error);\n });\n });\n return streams.reduce(pipe);\n}\n\nmodule.exports = pipeline;","'use strict'\n\nconst WriteError = require('level-errors').WriteError\nconst catering = require('catering')\nconst getCallback = require('./common').getCallback\nconst getOptions = require('./common').getOptions\n\nfunction Batch (levelup) {\n this.db = levelup\n this.batch = levelup.db.batch()\n this.ops = []\n this.length = 0\n}\n\nBatch.prototype.put = function (key, value, options) {\n try {\n this.batch.put(key, value, options)\n } catch (e) {\n throw new WriteError(e)\n }\n\n this.ops.push({ ...options, type: 'put', key, value })\n this.length++\n\n return this\n}\n\nBatch.prototype.del = function (key, options) {\n try {\n this.batch.del(key, options)\n } catch (err) {\n throw new WriteError(err)\n }\n\n this.ops.push({ ...options, type: 'del', key })\n this.length++\n\n return this\n}\n\nBatch.prototype.clear = function () {\n try {\n this.batch.clear()\n } catch (err) {\n throw new WriteError(err)\n }\n\n this.ops = []\n this.length = 0\n\n return this\n}\n\nBatch.prototype.write = function (options, callback) {\n const levelup = this.db\n const ops = this.ops\n\n callback = getCallback(options, callback)\n callback = catering.fromCallback(callback)\n options = getOptions(options)\n\n try {\n this.batch.write(options, function (err) {\n if (err) { return callback(new WriteError(err)) }\n levelup.emit('batch', ops)\n callback()\n })\n } catch (err) {\n throw new WriteError(err)\n }\n\n return callback.promise\n}\n\nmodule.exports = Batch\n","'use strict'\n\nfunction createError (type, Proto) {\n const Err = function (message, cause) {\n if (typeof message === 'object' && message !== null) {\n // Can be passed just a cause\n cause = cause || message\n message = message.message || message.name\n }\n\n message = message || ''\n cause = cause || undefined\n\n // If input is already of type, return as-is to keep its stack trace.\n // Avoid instanceof, for when node_modules has multiple copies of level-errors.\n if (typeof cause === 'object' && cause.type === type && cause.message === message) {\n return cause\n }\n\n Object.defineProperty(this, 'type', { value: type, enumerable: false, writable: true, configurable: true })\n Object.defineProperty(this, 'name', { value: type, enumerable: false, writable: true, configurable: true })\n Object.defineProperty(this, 'cause', { value: cause, enumerable: false, writable: true, configurable: true })\n Object.defineProperty(this, 'message', { value: message, enumerable: false, writable: true, configurable: true })\n\n Error.call(this)\n\n if (typeof Error.captureStackTrace === 'function') {\n Error.captureStackTrace(this, Err)\n }\n }\n\n Err.prototype = new Proto()\n return Err\n}\n\nconst LevelUPError = createError('LevelUPError', Error)\n\nmodule.exports = {\n LevelUPError: LevelUPError,\n InitializationError: createError('InitializationError', LevelUPError),\n OpenError: createError('OpenError', LevelUPError),\n ReadError: createError('ReadError', LevelUPError),\n WriteError: createError('WriteError', LevelUPError),\n NotFoundError: createError('NotFoundError', LevelUPError),\n EncodingError: createError('EncodingError', LevelUPError)\n}\n\nmodule.exports.NotFoundError.prototype.notFound = true\nmodule.exports.NotFoundError.prototype.status = 404\n","'use strict'\n\nexports.getCallback = function (options, callback) {\n return typeof options === 'function' ? options : callback\n}\n\nexports.getOptions = function (options) {\n return typeof options === 'object' && options !== null ? options : {}\n}\n","'use strict'\n\nconst queueMicrotask = require('queue-microtask')\n\nmodule.exports = function (fn, ...args) {\n if (args.length === 0) {\n queueMicrotask(fn)\n } else {\n queueMicrotask(() => fn(...args))\n }\n}\n","'use strict'\n\nconst AbstractLevelDOWN = require('abstract-leveldown').AbstractLevelDOWN\nconst AbstractChainedBatch = require('abstract-leveldown').AbstractChainedBatch\nconst AbstractIterator = require('abstract-leveldown').AbstractIterator\nconst inherits = require('inherits')\nconst Codec = require('level-codec')\nconst EncodingError = require('level-errors').EncodingError\nconst rangeMethods = ['approximateSize', 'compactRange']\n\nmodule.exports = DB\n\nfunction DB (db, opts) {\n if (!(this instanceof DB)) return new DB(db, opts)\n\n const manifest = db.supports || {}\n const additionalMethods = manifest.additionalMethods || {}\n\n AbstractLevelDOWN.call(this, manifest)\n\n this.supports.encodings = true\n this.supports.additionalMethods = {}\n\n rangeMethods.forEach(function (m) {\n // TODO (future major): remove this fallback\n const fallback = typeof db[m] === 'function'\n\n if (additionalMethods[m] || fallback) {\n this.supports.additionalMethods[m] = true\n\n this[m] = function (start, end, opts, cb) {\n start = this.codec.encodeKey(start, opts)\n end = this.codec.encodeKey(end, opts)\n return this.db[m](start, end, opts, cb)\n }\n }\n }, this)\n\n opts = opts || {}\n if (typeof opts.keyEncoding === 'undefined') opts.keyEncoding = 'utf8'\n if (typeof opts.valueEncoding === 'undefined') opts.valueEncoding = 'utf8'\n\n this.db = db\n this.codec = new Codec(opts)\n}\n\ninherits(DB, AbstractLevelDOWN)\n\nDB.prototype.type = 'encoding-down'\n\nDB.prototype._serializeKey =\nDB.prototype._serializeValue = function (datum) {\n return datum\n}\n\nDB.prototype._open = function (opts, cb) {\n this.db.open(opts, cb)\n}\n\nDB.prototype._close = function (cb) {\n this.db.close(cb)\n}\n\nDB.prototype._put = function (key, value, opts, cb) {\n key = this.codec.encodeKey(key, opts)\n value = this.codec.encodeValue(value, opts)\n this.db.put(key, value, opts, cb)\n}\n\nDB.prototype._get = function (key, opts, cb) {\n key = this.codec.encodeKey(key, opts)\n opts.asBuffer = this.codec.valueAsBuffer(opts)\n\n this.db.get(key, opts, (err, value) => {\n if (err) return cb(err)\n\n try {\n value = this.codec.decodeValue(value, opts)\n } catch (err) {\n return cb(new EncodingError(err))\n }\n\n cb(null, value)\n })\n}\n\nDB.prototype._getMany = function (keys, opts, cb) {\n keys = keys.map((key) => this.codec.encodeKey(key, opts))\n opts.asBuffer = this.codec.valueAsBuffer(opts)\n\n this.db.getMany(keys, opts, (err, values) => {\n if (err) return cb(err)\n\n const decoded = new Array(values.length)\n\n for (let i = 0; i < values.length; i++) {\n if (values[i] === undefined) {\n decoded[i] = undefined\n continue\n }\n\n try {\n decoded[i] = this.codec.decodeValue(values[i], opts)\n } catch (err) {\n return cb(new EncodingError(err))\n }\n }\n\n cb(null, decoded)\n })\n}\n\nDB.prototype._del = function (key, opts, cb) {\n key = this.codec.encodeKey(key, opts)\n this.db.del(key, opts, cb)\n}\n\nDB.prototype._chainedBatch = function () {\n return new Batch(this)\n}\n\nDB.prototype._batch = function (ops, opts, cb) {\n ops = this.codec.encodeBatch(ops, opts)\n this.db.batch(ops, opts, cb)\n}\n\nDB.prototype._iterator = function (opts) {\n opts.keyAsBuffer = this.codec.keyAsBuffer(opts)\n opts.valueAsBuffer = this.codec.valueAsBuffer(opts)\n return new Iterator(this, opts)\n}\n\nDB.prototype._clear = function (opts, callback) {\n opts = this.codec.encodeLtgt(opts)\n this.db.clear(opts, callback)\n}\n\nfunction Iterator (db, opts) {\n AbstractIterator.call(this, db)\n this.codec = db.codec\n this.keys = opts.keys\n this.values = opts.values\n this.opts = this.codec.encodeLtgt(opts)\n this.it = db.db.iterator(this.opts)\n}\n\ninherits(Iterator, AbstractIterator)\n\nIterator.prototype._next = function (cb) {\n this.it.next((err, key, value) => {\n if (err) return cb(err)\n\n try {\n if (this.keys && typeof key !== 'undefined') {\n key = this.codec.decodeKey(key, this.opts)\n } else {\n key = undefined\n }\n\n if (this.values && typeof value !== 'undefined') {\n value = this.codec.decodeValue(value, this.opts)\n } else {\n value = undefined\n }\n } catch (err) {\n return cb(new EncodingError(err))\n }\n\n cb(null, key, value)\n })\n}\n\nIterator.prototype._seek = function (key) {\n key = this.codec.encodeKey(key, this.opts)\n this.it.seek(key)\n}\n\nIterator.prototype._end = function (cb) {\n this.it.end(cb)\n}\n\nfunction Batch (db, codec) {\n AbstractChainedBatch.call(this, db)\n this.codec = db.codec\n this.batch = db.db.batch()\n}\n\ninherits(Batch, AbstractChainedBatch)\n\nBatch.prototype._put = function (key, value, options) {\n key = this.codec.encodeKey(key, options)\n value = this.codec.encodeValue(value, options)\n this.batch.put(key, value)\n}\n\nBatch.prototype._del = function (key, options) {\n key = this.codec.encodeKey(key, options)\n this.batch.del(key)\n}\n\nBatch.prototype._clear = function () {\n this.batch.clear()\n}\n\nBatch.prototype._write = function (opts, cb) {\n this.batch.write(opts, cb)\n}\n","'use strict'\n\nconst encodings = require('./lib/encodings')\nconst rangeOptions = new Set(['lt', 'gt', 'lte', 'gte'])\n\nmodule.exports = Codec\n\nfunction Codec (opts) {\n if (!(this instanceof Codec)) {\n return new Codec(opts)\n }\n this.opts = opts || {}\n this.encodings = encodings\n}\n\nCodec.prototype._encoding = function (encoding) {\n if (typeof encoding === 'string') encoding = encodings[encoding]\n if (!encoding) encoding = encodings.id\n return encoding\n}\n\nCodec.prototype._keyEncoding = function (opts, batchOpts) {\n return this._encoding((batchOpts && batchOpts.keyEncoding) ||\n (opts && opts.keyEncoding) ||\n this.opts.keyEncoding)\n}\n\nCodec.prototype._valueEncoding = function (opts, batchOpts) {\n return this._encoding((batchOpts && (batchOpts.valueEncoding || batchOpts.encoding)) ||\n (opts && (opts.valueEncoding || opts.encoding)) ||\n (this.opts.valueEncoding || this.opts.encoding))\n}\n\nCodec.prototype.encodeKey = function (key, opts, batchOpts) {\n return this._keyEncoding(opts, batchOpts).encode(key)\n}\n\nCodec.prototype.encodeValue = function (value, opts, batchOpts) {\n return this._valueEncoding(opts, batchOpts).encode(value)\n}\n\nCodec.prototype.decodeKey = function (key, opts) {\n return this._keyEncoding(opts).decode(key)\n}\n\nCodec.prototype.decodeValue = function (value, opts) {\n return this._valueEncoding(opts).decode(value)\n}\n\nCodec.prototype.encodeBatch = function (ops, opts) {\n return ops.map((_op) => {\n const op = {\n type: _op.type,\n key: this.encodeKey(_op.key, opts, _op)\n }\n if (this.keyAsBuffer(opts, _op)) op.keyEncoding = 'binary'\n if (_op.prefix) op.prefix = _op.prefix\n if ('value' in _op) {\n op.value = this.encodeValue(_op.value, opts, _op)\n if (this.valueAsBuffer(opts, _op)) op.valueEncoding = 'binary'\n }\n return op\n })\n}\n\nCodec.prototype.encodeLtgt = function (ltgt) {\n const ret = {}\n\n for (const key of Object.keys(ltgt)) {\n if (key === 'start' || key === 'end') {\n throw new Error('Legacy range options (\"start\" and \"end\") have been removed')\n }\n\n ret[key] = rangeOptions.has(key)\n ? this.encodeKey(ltgt[key], ltgt)\n : ltgt[key]\n }\n\n return ret\n}\n\nCodec.prototype.createStreamDecoder = function (opts) {\n if (opts.keys && opts.values) {\n return (key, value) => {\n return {\n key: this.decodeKey(key, opts),\n value: this.decodeValue(value, opts)\n }\n }\n } else if (opts.keys) {\n return (key) => {\n return this.decodeKey(key, opts)\n }\n } else if (opts.values) {\n return (_, value) => {\n return this.decodeValue(value, opts)\n }\n } else {\n return function () {}\n }\n}\n\nCodec.prototype.keyAsBuffer = function (opts) {\n return this._keyEncoding(opts).buffer\n}\n\nCodec.prototype.valueAsBuffer = function (opts) {\n return this._valueEncoding(opts).buffer\n}\n","'use strict'\n\nconst { Buffer } = require('buffer')\n\nexports.utf8 = exports['utf-8'] = {\n encode: function (data) {\n return isBinary(data) ? data : String(data)\n },\n decode: identity,\n buffer: false,\n type: 'utf8'\n}\n\nexports.json = {\n encode: JSON.stringify,\n decode: JSON.parse,\n buffer: false,\n type: 'json'\n}\n\nexports.binary = {\n encode: function (data) {\n return isBinary(data) ? data : Buffer.from(data)\n },\n decode: identity,\n buffer: true,\n type: 'binary'\n}\n\nexports.none = {\n encode: identity,\n decode: identity,\n buffer: false,\n type: 'id'\n}\n\nexports.id = exports.none\n\nconst bufferEncodings = [\n 'hex',\n 'ascii',\n 'base64',\n 'ucs2',\n 'ucs-2',\n 'utf16le',\n 'utf-16le'\n]\n\nfor (const type of bufferEncodings) {\n exports[type] = {\n encode: function (data) {\n return isBinary(data) ? data : Buffer.from(data, type)\n },\n decode: function (buffer) {\n return buffer.toString(type)\n },\n buffer: true,\n type: type\n }\n}\n\nfunction identity (value) {\n return value\n}\n\nfunction isBinary (data) {\n return data === undefined || data === null || Buffer.isBuffer(data)\n}\n","/* global indexedDB */\n\n'use strict'\n\nmodule.exports = Level\n\nconst AbstractLevelDOWN = require('abstract-leveldown').AbstractLevelDOWN\nconst inherits = require('inherits')\nconst parallel = require('run-parallel-limit')\nconst Iterator = require('./iterator')\nconst serialize = require('./util/serialize')\nconst deserialize = require('./util/deserialize')\nconst support = require('./util/support')\nconst clear = require('./util/clear')\nconst createKeyRange = require('./util/key-range')\n\nconst DEFAULT_PREFIX = 'level-js-'\n\nfunction Level (location, opts) {\n if (!(this instanceof Level)) return new Level(location, opts)\n\n AbstractLevelDOWN.call(this, {\n bufferKeys: support.bufferKeys(indexedDB),\n snapshots: true,\n permanence: true,\n clear: true,\n getMany: true\n })\n\n opts = opts || {}\n\n if (typeof location !== 'string') {\n throw new Error('constructor requires a location string argument')\n }\n\n this.location = location\n this.prefix = opts.prefix == null ? DEFAULT_PREFIX : opts.prefix\n this.version = parseInt(opts.version || 1, 10)\n}\n\ninherits(Level, AbstractLevelDOWN)\n\nLevel.prototype.type = 'level-js'\n\nLevel.prototype._open = function (options, callback) {\n const req = indexedDB.open(this.prefix + this.location, this.version)\n\n req.onerror = function () {\n callback(req.error || new Error('unknown error'))\n }\n\n req.onsuccess = () => {\n this.db = req.result\n callback()\n }\n\n req.onupgradeneeded = (ev) => {\n const db = ev.target.result\n\n if (!db.objectStoreNames.contains(this.location)) {\n db.createObjectStore(this.location)\n }\n }\n}\n\nLevel.prototype.store = function (mode) {\n const transaction = this.db.transaction([this.location], mode)\n return transaction.objectStore(this.location)\n}\n\nLevel.prototype.await = function (request, callback) {\n const transaction = request.transaction\n\n // Take advantage of the fact that a non-canceled request error aborts\n // the transaction. I.e. no need to listen for \"request.onerror\".\n transaction.onabort = function () {\n callback(transaction.error || new Error('aborted by user'))\n }\n\n transaction.oncomplete = function () {\n callback(null, request.result)\n }\n}\n\nLevel.prototype._get = function (key, options, callback) {\n const store = this.store('readonly')\n let req\n\n try {\n req = store.get(key)\n } catch (err) {\n return this._nextTick(callback, err)\n }\n\n this.await(req, function (err, value) {\n if (err) return callback(err)\n\n if (value === undefined) {\n // 'NotFound' error, consistent with LevelDOWN API\n return callback(new Error('NotFound'))\n }\n\n callback(null, deserialize(value, options.asBuffer))\n })\n}\n\nLevel.prototype._getMany = function (keys, options, callback) {\n const asBuffer = options.asBuffer\n const store = this.store('readonly')\n const tasks = keys.map((key) => (next) => {\n let request\n\n try {\n request = store.get(key)\n } catch (err) {\n return next(err)\n }\n\n request.onsuccess = () => {\n const value = request.result\n next(null, value === undefined ? value : deserialize(value, asBuffer))\n }\n\n request.onerror = (ev) => {\n ev.stopPropagation()\n next(request.error)\n }\n })\n\n parallel(tasks, 16, callback)\n}\n\nLevel.prototype._del = function (key, options, callback) {\n const store = this.store('readwrite')\n let req\n\n try {\n req = store.delete(key)\n } catch (err) {\n return this._nextTick(callback, err)\n }\n\n this.await(req, callback)\n}\n\nLevel.prototype._put = function (key, value, options, callback) {\n const store = this.store('readwrite')\n let req\n\n try {\n // Will throw a DataError or DataCloneError if the environment\n // does not support serializing the key or value respectively.\n req = store.put(value, key)\n } catch (err) {\n return this._nextTick(callback, err)\n }\n\n this.await(req, callback)\n}\n\nLevel.prototype._serializeKey = function (key) {\n return serialize(key, this.supports.bufferKeys)\n}\n\nLevel.prototype._serializeValue = function (value) {\n return serialize(value, true)\n}\n\nLevel.prototype._iterator = function (options) {\n return new Iterator(this, this.location, options)\n}\n\nLevel.prototype._batch = function (operations, options, callback) {\n if (operations.length === 0) return this._nextTick(callback)\n\n const store = this.store('readwrite')\n const transaction = store.transaction\n let index = 0\n let error\n\n transaction.onabort = function () {\n callback(error || transaction.error || new Error('aborted by user'))\n }\n\n transaction.oncomplete = function () {\n callback()\n }\n\n // Wait for a request to complete before making the next, saving CPU.\n function loop () {\n const op = operations[index++]\n const key = op.key\n\n let req\n\n try {\n req = op.type === 'del' ? store.delete(key) : store.put(op.value, key)\n } catch (err) {\n error = err\n transaction.abort()\n return\n }\n\n if (index < operations.length) {\n req.onsuccess = loop\n }\n }\n\n loop()\n}\n\nLevel.prototype._clear = function (options, callback) {\n let keyRange\n let req\n\n try {\n keyRange = createKeyRange(options)\n } catch (e) {\n // The lower key is greater than the upper key.\n // IndexedDB throws an error, but we'll just do nothing.\n return this._nextTick(callback)\n }\n\n if (options.limit >= 0) {\n // IDBObjectStore#delete(range) doesn't have such an option.\n // Fall back to cursor-based implementation.\n return clear(this, this.location, keyRange, options, callback)\n }\n\n try {\n const store = this.store('readwrite')\n req = keyRange ? store.delete(keyRange) : store.clear()\n } catch (err) {\n return this._nextTick(callback, err)\n }\n\n this.await(req, callback)\n}\n\nLevel.prototype._close = function (callback) {\n this.db.close()\n this._nextTick(callback)\n}\n\n// NOTE: remove in a next major release\nLevel.prototype.upgrade = function (callback) {\n if (this.status !== 'open') {\n return this._nextTick(callback, new Error('cannot upgrade() before open()'))\n }\n\n const it = this.iterator()\n const batchOptions = {}\n const self = this\n\n it._deserializeKey = it._deserializeValue = identity\n next()\n\n function next (err) {\n if (err) return finish(err)\n it.next(each)\n }\n\n function each (err, key, value) {\n if (err || key === undefined) {\n return finish(err)\n }\n\n const newKey = self._serializeKey(deserialize(key, true))\n const newValue = self._serializeValue(deserialize(value, true))\n\n // To bypass serialization on the old key, use _batch() instead of batch().\n // NOTE: if we disable snapshotting (#86) this could lead to a loop of\n // inserting and then iterating those same entries, because the new keys\n // possibly sort after the old keys.\n self._batch([\n { type: 'del', key: key },\n { type: 'put', key: newKey, value: newValue }\n ], batchOptions, next)\n }\n\n function finish (err) {\n it.end(function (err2) {\n callback(err || err2)\n })\n }\n\n function identity (data) {\n return data\n }\n}\n\nLevel.destroy = function (location, prefix, callback) {\n if (typeof prefix === 'function') {\n callback = prefix\n prefix = DEFAULT_PREFIX\n }\n const request = indexedDB.deleteDatabase(prefix + location)\n request.onsuccess = function () {\n callback()\n }\n request.onerror = function (err) {\n callback(err)\n }\n}\n","/*! run-parallel-limit. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */\nmodule.exports = runParallelLimit\n\nconst queueMicrotask = require('queue-microtask')\n\nfunction runParallelLimit (tasks, limit, cb) {\n if (typeof limit !== 'number') throw new Error('second argument must be a Number')\n let results, len, pending, keys, isErrored\n let isSync = true\n let next\n\n if (Array.isArray(tasks)) {\n results = []\n pending = len = tasks.length\n } else {\n keys = Object.keys(tasks)\n results = {}\n pending = len = keys.length\n }\n\n function done (err) {\n function end () {\n if (cb) cb(err, results)\n cb = null\n }\n if (isSync) queueMicrotask(end)\n else end()\n }\n\n function each (i, err, result) {\n results[i] = result\n if (err) isErrored = true\n if (--pending === 0 || err) {\n done(err)\n } else if (!isErrored && next < len) {\n let key\n if (keys) {\n key = keys[next]\n next += 1\n tasks[key](function (err, result) { each(key, err, result) })\n } else {\n key = next\n next += 1\n tasks[key](function (err, result) { each(key, err, result) })\n }\n }\n }\n\n next = limit\n if (!pending) {\n // empty\n done(null)\n } else if (keys) {\n // object\n keys.some(function (key, i) {\n tasks[key](function (err, result) { each(key, err, result) })\n if (i === limit - 1) return true // early return\n return false\n })\n } else {\n // array\n tasks.some(function (task, i) {\n task(function (err, result) { each(i, err, result) })\n if (i === limit - 1) return true // early return\n return false\n })\n }\n\n isSync = false\n}\n","'use strict'\n\nconst inherits = require('inherits')\nconst AbstractIterator = require('abstract-leveldown').AbstractIterator\nconst createKeyRange = require('./util/key-range')\nconst deserialize = require('./util/deserialize')\nconst noop = function () {}\n\nmodule.exports = Iterator\n\nfunction Iterator (db, location, options) {\n AbstractIterator.call(this, db)\n\n this._limit = options.limit\n this._count = 0\n this._callback = null\n this._cache = []\n this._completed = false\n this._aborted = false\n this._error = null\n this._transaction = null\n\n this._keys = options.keys\n this._values = options.values\n this._keyAsBuffer = options.keyAsBuffer\n this._valueAsBuffer = options.valueAsBuffer\n\n if (this._limit === 0) {\n this._completed = true\n return\n }\n\n let keyRange\n\n try {\n keyRange = createKeyRange(options)\n } catch (e) {\n // The lower key is greater than the upper key.\n // IndexedDB throws an error, but we'll just return 0 results.\n this._completed = true\n return\n }\n\n this.createIterator(location, keyRange, options.reverse)\n}\n\ninherits(Iterator, AbstractIterator)\n\nIterator.prototype.createIterator = function (location, keyRange, reverse) {\n const transaction = this.db.db.transaction([location], 'readonly')\n const store = transaction.objectStore(location)\n const req = store.openCursor(keyRange, reverse ? 'prev' : 'next')\n\n req.onsuccess = (ev) => {\n const cursor = ev.target.result\n if (cursor) this.onItem(cursor)\n }\n\n this._transaction = transaction\n\n // If an error occurs (on the request), the transaction will abort.\n transaction.onabort = () => {\n this.onAbort(this._transaction.error || new Error('aborted by user'))\n }\n\n transaction.oncomplete = () => {\n this.onComplete()\n }\n}\n\nIterator.prototype.onItem = function (cursor) {\n this._cache.push(cursor.key, cursor.value)\n\n if (this._limit <= 0 || ++this._count < this._limit) {\n cursor.continue()\n }\n\n this.maybeNext()\n}\n\nIterator.prototype.onAbort = function (err) {\n this._aborted = true\n this._error = err\n this.maybeNext()\n}\n\nIterator.prototype.onComplete = function () {\n this._completed = true\n this.maybeNext()\n}\n\nIterator.prototype.maybeNext = function () {\n if (this._callback) {\n this._next(this._callback)\n this._callback = null\n }\n}\n\nIterator.prototype._next = function (callback) {\n if (this._aborted) {\n // The error should be picked up by either next() or end().\n const err = this._error\n this._error = null\n this._nextTick(callback, err)\n } else if (this._cache.length > 0) {\n let key = this._cache.shift()\n let value = this._cache.shift()\n\n if (this._keys && key !== undefined) {\n key = this._deserializeKey(key, this._keyAsBuffer)\n } else {\n key = undefined\n }\n\n if (this._values && value !== undefined) {\n value = this._deserializeValue(value, this._valueAsBuffer)\n } else {\n value = undefined\n }\n\n this._nextTick(callback, null, key, value)\n } else if (this._completed) {\n this._nextTick(callback)\n } else {\n this._callback = callback\n }\n}\n\n// Exposed for the v4 to v5 upgrade utility\nIterator.prototype._deserializeKey = deserialize\nIterator.prototype._deserializeValue = deserialize\n\nIterator.prototype._end = function (callback) {\n if (this._aborted || this._completed) {\n return this._nextTick(callback, this._error)\n }\n\n // Don't advance the cursor anymore, and the transaction will complete\n // on its own in the next tick. This approach is much cleaner than calling\n // transaction.abort() with its unpredictable event order.\n this.onItem = noop\n this.onAbort = callback\n this.onComplete = callback\n}\n","/* global IDBKeyRange */\n\n'use strict'\n\nconst ltgt = require('ltgt')\nconst NONE = Symbol('none')\n\nmodule.exports = function createKeyRange (options) {\n const lower = ltgt.lowerBound(options, NONE)\n const upper = ltgt.upperBound(options, NONE)\n const lowerOpen = ltgt.lowerBoundExclusive(options, NONE)\n const upperOpen = ltgt.upperBoundExclusive(options, NONE)\n\n if (lower !== NONE && upper !== NONE) {\n return IDBKeyRange.bound(lower, upper, lowerOpen, upperOpen)\n } else if (lower !== NONE) {\n return IDBKeyRange.lowerBound(lower, lowerOpen)\n } else if (upper !== NONE) {\n return IDBKeyRange.upperBound(upper, upperOpen)\n } else {\n return null\n }\n}\n","\nexports.compare = function (a, b) {\n\n if(Buffer.isBuffer(a)) {\n var l = Math.min(a.length, b.length)\n for(var i = 0; i < l; i++) {\n var cmp = a[i] - b[i]\n if(cmp) return cmp\n }\n return a.length - b.length\n }\n\n return a < b ? -1 : a > b ? 1 : 0\n}\n\n// to be compatible with the current abstract-leveldown tests\n// nullish or empty strings.\n// I could use !!val but I want to permit numbers and booleans,\n// if possible.\n\nfunction isDef (val) {\n return val !== undefined && val !== ''\n}\n\nfunction has (range, name) {\n return Object.hasOwnProperty.call(range, name)\n}\n\nfunction hasKey(range, name) {\n return Object.hasOwnProperty.call(range, name) && name\n}\n\nvar lowerBoundKey = exports.lowerBoundKey = function (range) {\n return (\n hasKey(range, 'gt')\n || hasKey(range, 'gte')\n || hasKey(range, 'min')\n || (range.reverse ? hasKey(range, 'end') : hasKey(range, 'start'))\n || undefined\n )\n}\n\nvar lowerBound = exports.lowerBound = function (range, def) {\n var k = lowerBoundKey(range)\n return k ? range[k] : def\n}\n\nvar lowerBoundInclusive = exports.lowerBoundInclusive = function (range) {\n return has(range, 'gt') ? false : true\n}\n\nvar upperBoundInclusive = exports.upperBoundInclusive =\n function (range) {\n return (has(range, 'lt') /*&& !range.maxEx*/) ? false : true\n }\n\nvar lowerBoundExclusive = exports.lowerBoundExclusive =\n function (range) {\n return !lowerBoundInclusive(range)\n }\n\nvar upperBoundExclusive = exports.upperBoundExclusive =\n function (range) {\n return !upperBoundInclusive(range)\n }\n\nvar upperBoundKey = exports.upperBoundKey = function (range) {\n return (\n hasKey(range, 'lt')\n || hasKey(range, 'lte')\n || hasKey(range, 'max')\n || (range.reverse ? hasKey(range, 'start') : hasKey(range, 'end'))\n || undefined\n )\n}\n\nvar upperBound = exports.upperBound = function (range, def) {\n var k = upperBoundKey(range)\n return k ? range[k] : def\n}\n\nexports.start = function (range, def) {\n return range.reverse ? upperBound(range, def) : lowerBound(range, def)\n}\nexports.end = function (range, def) {\n return range.reverse ? lowerBound(range, def) : upperBound(range, def)\n}\nexports.startInclusive = function (range) {\n return (\n range.reverse\n ? upperBoundInclusive(range)\n : lowerBoundInclusive(range)\n )\n}\nexports.endInclusive = function (range) {\n return (\n range.reverse\n ? lowerBoundInclusive(range)\n : upperBoundInclusive(range)\n )\n}\n\nfunction id (e) { return e }\n\nexports.toLtgt = function (range, _range, map, lower, upper) {\n _range = _range || {}\n map = map || id\n var defaults = arguments.length > 3\n var lb = exports.lowerBoundKey(range)\n var ub = exports.upperBoundKey(range)\n if(lb) {\n if(lb === 'gt') _range.gt = map(range.gt, false)\n else _range.gte = map(range[lb], false)\n }\n else if(defaults)\n _range.gte = map(lower, false)\n\n if(ub) {\n if(ub === 'lt') _range.lt = map(range.lt, true)\n else _range.lte = map(range[ub], true)\n }\n else if(defaults)\n _range.lte = map(upper, true)\n\n if(range.reverse != null)\n _range.reverse = !!range.reverse\n\n //if range was used mutably\n //(in level-sublevel it's part of an options object\n //that has more properties on it.)\n if(has(_range, 'max')) delete _range.max\n if(has(_range, 'min')) delete _range.min\n if(has(_range, 'start')) delete _range.start\n if(has(_range, 'end')) delete _range.end\n\n return _range\n}\n\nexports.contains = function (range, key, compare) {\n compare = compare || exports.compare\n\n var lb = lowerBound(range)\n if(isDef(lb)) {\n var cmp = compare(key, lb)\n if(cmp < 0 || (cmp === 0 && lowerBoundExclusive(range)))\n return false\n }\n\n var ub = upperBound(range)\n if(isDef(ub)) {\n var cmp = compare(key, ub)\n if(cmp > 0 || (cmp === 0) && upperBoundExclusive(range))\n return false\n }\n\n return true\n}\n\nexports.filter = function (range, compare) {\n return function (key) {\n return exports.contains(range, key, compare)\n }\n}\n\n\n","'use strict'\n\nconst Buffer = require('buffer').Buffer\nconst ta2str = (function () {\n if (global.TextDecoder) {\n const decoder = new TextDecoder('utf-8')\n return decoder.decode.bind(decoder)\n } else {\n return function ta2str (ta) {\n return ta2buf(ta).toString()\n }\n }\n})()\n\nconst ab2str = (function () {\n if (global.TextDecoder) {\n const decoder = new TextDecoder('utf-8')\n return decoder.decode.bind(decoder)\n } else {\n return function ab2str (ab) {\n return Buffer.from(ab).toString()\n }\n }\n})()\n\nfunction ta2buf (ta) {\n const buf = Buffer.from(ta.buffer)\n\n if (ta.byteLength === ta.buffer.byteLength) {\n return buf\n } else {\n return buf.slice(ta.byteOffset, ta.byteOffset + ta.byteLength)\n }\n}\n\nmodule.exports = function (data, asBuffer) {\n if (data instanceof Uint8Array) {\n return asBuffer ? ta2buf(data) : ta2str(data)\n } else if (data instanceof ArrayBuffer) {\n return asBuffer ? Buffer.from(data) : ab2str(data)\n } else {\n return asBuffer ? Buffer.from(String(data)) : String(data)\n }\n}\n","'use strict'\n\nconst Buffer = require('buffer').Buffer\n// Returns either a Uint8Array or Buffer (doesn't matter to\n// IndexedDB, because Buffer is a subclass of Uint8Array)\nconst str2bin = (function () {\n if (global.TextEncoder) {\n const encoder = new TextEncoder('utf-8')\n return encoder.encode.bind(encoder)\n } else {\n return Buffer.from\n }\n})()\n\nmodule.exports = function (data, asBuffer) {\n if (asBuffer) {\n return Buffer.isBuffer(data) ? data : str2bin(String(data))\n } else {\n return String(data)\n }\n}\n","'use strict'\n\nconst Buffer = require('buffer').Buffer\n\nexports.test = function (key) {\n return function test (impl) {\n try {\n impl.cmp(key, 0)\n return true\n } catch (err) {\n return false\n }\n }\n}\n\n// Detect binary key support (IndexedDB Second Edition)\nexports.bufferKeys = exports.test(Buffer.alloc(0))\n","'use strict'\n\nmodule.exports = function clear (db, location, keyRange, options, callback) {\n if (options.limit === 0) return db._nextTick(callback)\n\n const transaction = db.db.transaction([location], 'readwrite')\n const store = transaction.objectStore(location)\n let count = 0\n\n transaction.oncomplete = function () {\n callback()\n }\n\n transaction.onabort = function () {\n callback(transaction.error || new Error('aborted by user'))\n }\n\n // A key cursor is faster (skips reading values) but not supported by IE\n const method = store.openKeyCursor ? 'openKeyCursor' : 'openCursor'\n const direction = options.reverse ? 'prev' : 'next'\n\n store[method](keyRange, direction).onsuccess = function (ev) {\n const cursor = ev.target.result\n\n if (cursor) {\n // Wait for a request to complete before continuing, saving CPU.\n store.delete(cursor.key).onsuccess = function () {\n if (options.limit <= 0 || ++count < options.limit) {\n cursor.continue()\n }\n }\n }\n }\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar drain = require('it-drain');\nvar pushable = require('it-pushable');\nvar key = require('interface-datastore/key');\nvar cid = require('multiformats/cid');\nvar raw = require('multiformats/codecs/raw');\nvar Digest = require('multiformats/hashes/digest');\nvar base32 = require('multiformats/bases/base32');\nvar base58 = require('multiformats/bases/base58');\nvar errcode = require('err-code');\nvar base = require('blockstore-core/base');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar pushable__default = /*#__PURE__*/_interopDefaultLegacy(pushable);\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\n\nfunction cidToKey(cid$1) {\n const c = cid.CID.asCID(cid$1);\n if (!c) {\n throw errcode__default['default'](new Error('Not a valid cid'), 'ERR_INVALID_CID');\n }\n return new key.Key('/' + base32.base32.encode(c.multihash.bytes).slice(1).toUpperCase(), false);\n}\nfunction keyToCid(key) {\n return cid.CID.createV1(raw__namespace.code, Digest__namespace.decode(base32.base32.decode('b' + key.toString().slice(1).toLowerCase())));\n}\nfunction convertPrefix(prefix) {\n const firstChar = prefix.substring(0, 1);\n if (firstChar === '/') {\n return convertPrefix(prefix.substring(1));\n }\n let decoder;\n if (firstChar.toLowerCase() === 'b') {\n decoder = input => base32.base32.decode(input.toLowerCase()).subarray(2);\n } else if (firstChar.toLowerCase() === 'c') {\n decoder = input => base32.base32pad.decode(input.toLowerCase()).subarray(2);\n } else if (firstChar === 'z') {\n decoder = input => base58.base58btc.decode(input).subarray(2);\n } else if (firstChar === 'Q') {\n decoder = input => base58.base58btc.decode('z' + input);\n } else {\n decoder = input => base32.base32.decode('b' + input.toLowerCase()).subarray(2);\n }\n let bytes;\n for (let i = 1; i < prefix.length; i++) {\n try {\n bytes = decoder(prefix.substring(0, i));\n } catch (err) {\n if (err.message !== 'Unexpected end of data') {\n throw err;\n }\n }\n }\n let str = '/C';\n if (bytes) {\n str = `/${ base32.base32.encode(bytes).slice(1, -1).toUpperCase() || 'C' }`;\n }\n return str;\n}\nfunction convertQuery(query) {\n return {\n ...query,\n prefix: query.prefix ? convertPrefix(query.prefix) : undefined,\n filters: query.filters ? query.filters.map(filter => pair => {\n return filter({\n key: keyToCid(pair.key),\n value: pair.value\n });\n }) : undefined,\n orders: query.orders ? query.orders.map(order => (a, b) => {\n return order({\n key: keyToCid(a.key),\n value: a.value\n }, {\n key: keyToCid(b.key),\n value: b.value\n });\n }) : undefined\n };\n}\nfunction convertKeyQuery(query) {\n return {\n ...query,\n prefix: query.prefix ? convertPrefix(query.prefix) : undefined,\n filters: query.filters ? query.filters.map(filter => key => {\n return filter(keyToCid(key));\n }) : undefined,\n orders: query.orders ? query.orders.map(order => (a, b) => {\n return order(keyToCid(a), keyToCid(b));\n }) : undefined\n };\n}\nclass BlockstoreDatastoreAdapter extends base.BaseBlockstore {\n constructor(datastore) {\n super();\n this.child = datastore;\n }\n open() {\n return this.child.open();\n }\n close() {\n return this.child.close();\n }\n async *query(query, options) {\n for await (const {key, value} of this.child.query(convertQuery(query), options)) {\n yield {\n key: keyToCid(key),\n value\n };\n }\n }\n async *queryKeys(query, options) {\n for await (const key of this.child.queryKeys(convertKeyQuery(query), options)) {\n yield keyToCid(key);\n }\n }\n async get(cid, options) {\n return this.child.get(cidToKey(cid), options);\n }\n async *getMany(cids, options) {\n for await (const cid of cids) {\n yield this.get(cid, options);\n }\n }\n async put(cid, value, options) {\n await this.child.put(cidToKey(cid), value, options);\n }\n async *putMany(blocks, options) {\n const output = pushable__default['default']();\n const runner = globalThis.process && globalThis.process.nextTick ? globalThis.process.nextTick : globalThis.setImmediate || globalThis.setTimeout;\n runner(async () => {\n try {\n const store = this.child;\n await drain__default['default'](this.child.putMany(async function* () {\n for await (const block of blocks) {\n const key = cidToKey(block.key);\n const exists = await store.has(key, options);\n if (!exists) {\n yield {\n key,\n value: block.value\n };\n }\n output.push(block);\n }\n }()));\n output.end();\n } catch (err) {\n output.end(err);\n }\n });\n yield* output;\n }\n has(cid, options) {\n return this.child.has(cidToKey(cid), options);\n }\n delete(cid, options) {\n return this.child.delete(cidToKey(cid), options);\n }\n deleteMany(cids, options) {\n const out = pushable__default['default']();\n drain__default['default'](this.child.deleteMany(async function* () {\n for await (const cid of cids) {\n yield cidToKey(cid);\n out.push(cid);\n }\n out.end();\n }(), options)).catch(err => {\n out.end(err);\n });\n return out;\n }\n}\n\nexports.BlockstoreDatastoreAdapter = BlockstoreDatastoreAdapter;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar drain = require('it-drain');\nvar filter = require('it-filter');\nvar take = require('it-take');\nvar all = require('it-all');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar drain__default = /*#__PURE__*/_interopDefaultLegacy(drain);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\nvar take__default = /*#__PURE__*/_interopDefaultLegacy(take);\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\n\nconst sortAll = (iterable, sorter) => {\n return async function* () {\n const values = await all__default['default'](iterable);\n yield* values.sort(sorter);\n }();\n};\nclass BaseBlockstore {\n open() {\n return Promise.reject(new Error('.open is not implemented'));\n }\n close() {\n return Promise.reject(new Error('.close is not implemented'));\n }\n put(key, val, options) {\n return Promise.reject(new Error('.put is not implemented'));\n }\n get(key, options) {\n return Promise.reject(new Error('.get is not implemented'));\n }\n has(key, options) {\n return Promise.reject(new Error('.has is not implemented'));\n }\n delete(key, options) {\n return Promise.reject(new Error('.delete is not implemented'));\n }\n async *putMany(source, options = {}) {\n for await (const {key, value} of source) {\n await this.put(key, value, options);\n yield {\n key,\n value\n };\n }\n }\n async *getMany(source, options = {}) {\n for await (const key of source) {\n yield this.get(key, options);\n }\n }\n async *deleteMany(source, options = {}) {\n for await (const key of source) {\n await this.delete(key, options);\n yield key;\n }\n }\n batch() {\n let puts = [];\n let dels = [];\n return {\n put(key, value) {\n puts.push({\n key,\n value\n });\n },\n delete(key) {\n dels.push(key);\n },\n commit: async options => {\n await drain__default['default'](this.putMany(puts, options));\n puts = [];\n await drain__default['default'](this.deleteMany(dels, options));\n dels = [];\n }\n };\n }\n async *_all(q, options) {\n throw new Error('._all is not implemented');\n }\n async *_allKeys(q, options) {\n throw new Error('._allKeys is not implemented');\n }\n query(q, options) {\n let it = this._all(q, options);\n if (q.prefix != null) {\n it = filter__default['default'](it, e => e.key.toString().startsWith(q.prefix || ''));\n }\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => sortAll(it, f), it);\n }\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= (q.offset || 0));\n }\n if (q.limit != null) {\n it = take__default['default'](it, q.limit);\n }\n return it;\n }\n queryKeys(q, options) {\n let it = this._allKeys(q, options);\n if (q.prefix != null) {\n it = filter__default['default'](it, cid => cid.toString().startsWith(q.prefix || ''));\n }\n if (Array.isArray(q.filters)) {\n it = q.filters.reduce((it, f) => filter__default['default'](it, f), it);\n }\n if (Array.isArray(q.orders)) {\n it = q.orders.reduce((it, f) => sortAll(it, f), it);\n }\n if (q.offset != null) {\n let i = 0;\n it = filter__default['default'](it, () => i++ >= q.offset);\n }\n if (q.limit != null) {\n it = take__default['default'](it, q.limit);\n }\n return it;\n }\n}\n\nexports.BaseBlockstore = BaseBlockstore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar get = require('dlv');\nvar mergeOpts = require('merge-options');\nvar errCode = require('err-code');\nvar libp2pPubsubRouters = require('ipfs-core-config/libp2p-pubsub-routers');\nvar DelegatedPeerRouter = require('libp2p-delegated-peer-routing');\nvar DelegatedContentRouter = require('libp2p-delegated-content-routing');\nvar ipfsHttpClient = require('ipfs-http-client');\nvar multiaddr = require('multiaddr');\nvar version = require('../version.js');\nvar libp2p = require('ipfs-core-config/libp2p');\nvar bootstrap = require('libp2p-bootstrap');\nvar Libp2p = require('libp2p');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar get__default = /*#__PURE__*/_interopDefaultLegacy(get);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar DelegatedPeerRouter__default = /*#__PURE__*/_interopDefaultLegacy(DelegatedPeerRouter);\nvar DelegatedContentRouter__default = /*#__PURE__*/_interopDefaultLegacy(DelegatedContentRouter);\nvar bootstrap__default = /*#__PURE__*/_interopDefaultLegacy(bootstrap);\nvar Libp2p__default = /*#__PURE__*/_interopDefaultLegacy(Libp2p);\n\nconst mergeOptions = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nfunction createLibp2p({options = {}, peerId, multiaddrs = [], repo, keychainConfig = {}, config = {}}) {\n const {datastore, keys} = repo;\n const libp2pOptions = getLibp2pOptions({\n options,\n config,\n datastore,\n keys,\n keychainConfig,\n peerId,\n multiaddrs\n });\n if (typeof options.libp2p === 'function') {\n return options.libp2p({\n libp2pOptions,\n options,\n config,\n datastore,\n peerId\n });\n }\n return Libp2p__default['default'].create(libp2pOptions);\n}\nfunction getLibp2pOptions({options, config, datastore, keys, keychainConfig, peerId, multiaddrs}) {\n const getPubsubRouter = () => {\n const router = get__default['default'](config, 'Pubsub.Router') || 'gossipsub';\n if (!libp2pPubsubRouters.routers[router]) {\n throw errCode__default['default'](new Error(`Router unavailable. Configure libp2p.modules.pubsub to use the ${ router } router.`), 'ERR_NOT_SUPPORTED');\n }\n return libp2pPubsubRouters.routers[router];\n };\n const libp2pDefaults = {\n datastore,\n peerId: peerId,\n modules: {}\n };\n const libp2pOptions = {\n modules: {\n pubsub: getPubsubRouter(),\n contentRouting: [],\n peerRouting: []\n },\n config: {\n peerDiscovery: {\n mdns: { enabled: get__default['default'](options, 'config.Discovery.MDNS.Enabled', get__default['default'](config, 'Discovery.MDNS.Enabled', true)) },\n webRTCStar: { enabled: get__default['default'](options, 'config.Discovery.webRTCStar.Enabled', get__default['default'](config, 'Discovery.webRTCStar.Enabled', true)) },\n bootstrap: { list: get__default['default'](options, 'config.Bootstrap', get__default['default'](config, 'Bootstrap', [])) }\n },\n relay: {\n enabled: get__default['default'](options, 'relay.enabled', get__default['default'](config, 'relay.enabled', true)),\n hop: {\n enabled: get__default['default'](options, 'relay.hop.enabled', get__default['default'](config, 'relay.hop.enabled', false)),\n active: get__default['default'](options, 'relay.hop.active', get__default['default'](config, 'relay.hop.active', false))\n }\n },\n dht: {\n enabled: get__default['default'](config, 'Routing.Type', 'none') !== 'none',\n clientMode: get__default['default'](config, 'Routing.Type', 'dht') !== 'dhtserver',\n kBucketSize: get__default['default'](options, 'dht.kBucketSize', 20)\n },\n pubsub: { enabled: get__default['default'](options, 'config.Pubsub.Enabled', get__default['default'](config, 'Pubsub.Enabled', true)) },\n nat: { enabled: !get__default['default'](config, 'Swarm.DisableNatPortMap', false) }\n },\n addresses: {\n listen: multiaddrs.map(ma => ma.toString()),\n announce: get__default['default'](options, 'addresses.announce', get__default['default'](config, 'Addresses.Announce', [])),\n noAnnounce: get__default['default'](options, 'addresses.noAnnounce', get__default['default'](config, 'Addresses.NoAnnounce', []))\n },\n connectionManager: get__default['default'](options, 'connectionManager', {\n maxConnections: get__default['default'](options, 'config.Swarm.ConnMgr.HighWater', get__default['default'](config, 'Swarm.ConnMgr.HighWater')),\n minConnections: get__default['default'](options, 'config.Swarm.ConnMgr.LowWater', get__default['default'](config, 'Swarm.ConnMgr.LowWater'))\n }),\n keychain: {\n datastore: keys,\n ...keychainConfig\n },\n host: { agentVersion: `js-ipfs/${ version.ipfsCore }` }\n };\n let constructorOptions = get__default['default'](options, 'libp2p', undefined);\n if (typeof constructorOptions === 'function') {\n constructorOptions = undefined;\n }\n const libp2pConfig = mergeOptions(libp2pDefaults, libp2p.libp2pConfig(), libp2pOptions, constructorOptions);\n const bootstrapList = get__default['default'](libp2pConfig, 'config.peerDiscovery.bootstrap.list', []);\n if (bootstrapList.length > 0) {\n libp2pConfig.modules.peerDiscovery.push(bootstrap__default['default']);\n }\n const delegateHosts = get__default['default'](options, 'config.Addresses.Delegates', get__default['default'](config, 'Addresses.Delegates', []));\n if (delegateHosts.length > 0) {\n const delegateString = delegateHosts[Math.floor(Math.random() * delegateHosts.length)];\n const delegateAddr = new multiaddr.Multiaddr(delegateString).toOptions();\n const delegateApiOptions = {\n host: delegateAddr.host,\n protocol: parseInt(delegateAddr.port) === 443 ? 'https' : 'http',\n port: delegateAddr.port\n };\n const delegateHttpClient = ipfsHttpClient.create(delegateApiOptions);\n libp2pOptions.modules.contentRouting = libp2pOptions.modules.contentRouting || [];\n libp2pOptions.modules.contentRouting.push(new DelegatedContentRouter__default['default'](peerId, delegateHttpClient));\n libp2pOptions.modules.peerRouting = libp2pOptions.modules.peerRouting || [];\n libp2pOptions.modules.peerRouting.push(new DelegatedPeerRouter__default['default'](delegateHttpClient));\n }\n return libp2pConfig;\n}\n\nexports.createLibp2p = createLibp2p;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar GossipSub = require('libp2p-gossipsub');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar GossipSub__default = /*#__PURE__*/_interopDefaultLegacy(GossipSub);\n\nconst routers = { gossipsub: GossipSub__default[\"default\"] };\n\nexports.routers = routers;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nconst pubsub_1 = __importStar(require(\"libp2p-interfaces/src/pubsub\"));\nconst message_cache_1 = require(\"./message-cache\");\nconst rpc_1 = require(\"./message/rpc\");\nconst constants = __importStar(require(\"./constants\"));\nconst heartbeat_1 = require(\"./heartbeat\");\nconst get_gossip_peers_1 = require(\"./get-gossip-peers\");\nconst utils_1 = require(\"./utils\");\nconst score_1 = require(\"./score\");\nconst tracer_1 = require(\"./tracer\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst TimeCache = require(\"time-cache\");\nconst PeerId = require(\"peer-id\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst Envelope = require(\"libp2p/src/record/envelope\");\nclass Gossipsub extends pubsub_1.default {\n // TODO: add remaining props\n /**\n * @param {Libp2p} libp2p\n * @param {Object} [options]\n * @param {boolean} [options.emitSelf = false] if publish should emit to self, if subscribed\n * @param {boolean} [options.canRelayMessage = false] - if can relay messages not subscribed\n * @param {boolean} [options.gossipIncoming = true] if incoming messages on a subscribed topic should be automatically gossiped\n * @param {boolean} [options.fallbackToFloodsub = true] if dial should fallback to floodsub\n * @param {boolean} [options.floodPublish = true] if self-published messages should be sent to all peers\n * @param {boolean} [options.doPX = false] whether PX is enabled; this should be enabled in bootstrappers and other well connected/trusted nodes.\n * @param {Object} [options.messageCache] override the default MessageCache\n * @param {string} [options.globalSignaturePolicy = \"StrictSign\"] signing policy to apply across all messages\n * @param {Object} [options.scoreParams] peer score parameters\n * @param {Object} [options.scoreThresholds] peer score thresholds\n * @param {AddrInfo[]} [options.directPeers] peers with which we will maintain direct connections\n * @constructor\n */\n constructor(libp2p, options = {}) {\n const multicodecs = [constants.GossipsubIDv11, constants.GossipsubIDv10];\n const opts = Object.assign(Object.assign({ gossipIncoming: true, fallbackToFloodsub: true, floodPublish: true, doPX: false, directPeers: [], D: constants.GossipsubD, Dlo: constants.GossipsubDlo, Dhi: constants.GossipsubDhi, Dscore: constants.GossipsubDscore, Dout: constants.GossipsubDout, Dlazy: constants.GossipsubDlazy, heartbeatInterval: constants.GossipsubHeartbeatInterval, fanoutTTL: constants.GossipsubFanoutTTL, mcacheLength: constants.GossipsubHistoryLength, mcacheGossip: constants.GossipsubHistoryGossip, seenTTL: constants.GossipsubSeenTTL }, options), { scoreParams: score_1.createPeerScoreParams(options.scoreParams), scoreThresholds: score_1.createPeerScoreThresholds(options.scoreThresholds) });\n // Also wants to get notified of peers connected using floodsub\n if (opts.fallbackToFloodsub) {\n multicodecs.push(constants.FloodsubID);\n }\n super(Object.assign({ debugName: 'libp2p:gossipsub', multicodecs,\n libp2p }, opts));\n this._options = opts;\n /**\n * Direct peers\n * @type {Set<string>}\n */\n this.direct = new Set(opts.directPeers.map(p => p.id.toB58String()));\n // set direct peer addresses in the address book\n opts.directPeers.forEach(p => {\n libp2p.peerStore.addressBook.add(p.id, p.addrs);\n });\n /**\n * Cache of seen messages\n *\n * @type {TimeCache}\n */\n this.seenCache = new TimeCache({ validity: opts.seenTTL / 1000 });\n /**\n * Map of topic meshes\n * topic => peer id set\n *\n * @type {Map<string, Set<string>>}\n */\n this.mesh = new Map();\n /**\n * Map of topics to set of peers. These mesh peers are the ones to which we are publishing without a topic membership\n * topic => peer id set\n *\n * @type {Map<string, Set<string>>}\n */\n this.fanout = new Map();\n /**\n * Map of last publish time for fanout topics\n * topic => last publish time\n *\n * @type {Map<string, number>}\n */\n this.lastpub = new Map();\n /**\n * Map of pending messages to gossip\n * peer id => control messages\n *\n * @type {Map<string, Array<RPC.IControlIHave object>> }\n */\n this.gossip = new Map();\n /**\n * Map of control messages\n * peer id => control message\n *\n * @type {Map<string, RPC.IControlMessage object>}\n */\n this.control = new Map();\n /**\n * Number of IHAVEs received from peer in the last heartbeat\n * @type {Map<string, number>}\n */\n this.peerhave = new Map();\n /**\n * Number of messages we have asked from peer in the last heartbeat\n * @type {Map<string, number>}\n */\n this.iasked = new Map();\n /**\n * Prune backoff map\n */\n this.backoff = new Map();\n /**\n * Connection direction cache, marks peers with outbound connections\n * peer id => direction\n *\n * @type {Map<string, boolean>}\n */\n this.outbound = new Map();\n /**\n * A message cache that contains the messages for last few hearbeat ticks\n *\n */\n this.messageCache = options.messageCache || new message_cache_1.MessageCache(opts.mcacheGossip, opts.mcacheLength, this.getMsgId.bind(this));\n /**\n * A heartbeat timer that maintains the mesh\n */\n this.heartbeat = new heartbeat_1.Heartbeat(this);\n /**\n * Number of heartbeats since the beginning of time\n * This allows us to amortize some resource cleanup -- eg: backoff cleanup\n */\n this.heartbeatTicks = 0;\n /**\n * Tracks IHAVE/IWANT promises broken by peers\n */\n this.gossipTracer = new tracer_1.IWantTracer(this.getMsgId.bind(this));\n /**\n * libp2p\n */\n this._libp2p = libp2p;\n /**\n * Peer score tracking\n */\n this.score = new score_1.PeerScore(this._options.scoreParams, libp2p.connectionManager, this.getMsgId.bind(this));\n }\n /**\n * Decode a Uint8Array into an RPC object\n * Overrided to use an extended protocol-specific protobuf decoder\n * @override\n * @param {Uint8Array} bytes\n * @returns {RPC}\n */\n _decodeRpc(bytes) {\n return rpc_1.RPC.decode(bytes);\n }\n /**\n * Encode an RPC object into a Uint8Array\n * Overrided to use an extended protocol-specific protobuf encoder\n * @override\n * @param {RPC} rpc\n * @returns {Uint8Array}\n */\n _encodeRpc(rpc) {\n return rpc_1.RPC.encode(rpc).finish();\n }\n /**\n * Add a peer to the router\n * @override\n * @param {PeerId} peerId\n * @param {string} protocol\n * @returns {PeerStreams}\n */\n _addPeer(peerId, protocol) {\n const p = super._addPeer(peerId, protocol);\n // Add to peer scoring\n this.score.addPeer(peerId.toB58String());\n // track the connection direction\n let outbound = false;\n for (const c of this._libp2p.connectionManager.getAll(peerId)) {\n if (c.stat.direction === 'outbound') {\n if (Array.from(c.registry.values()).some(rvalue => protocol === rvalue.protocol)) {\n outbound = true;\n break;\n }\n }\n }\n this.outbound.set(p.id.toB58String(), outbound);\n return p;\n }\n /**\n * Removes a peer from the router\n * @override\n * @param {PeerId} peer\n * @returns {PeerStreams | undefined}\n */\n _removePeer(peerId) {\n const peerStreams = super._removePeer(peerId);\n const id = peerId.toB58String();\n // Remove this peer from the mesh\n // eslint-disable-next-line no-unused-vars\n for (const peers of this.mesh.values()) {\n peers.delete(id);\n }\n // Remove this peer from the fanout\n // eslint-disable-next-line no-unused-vars\n for (const peers of this.fanout.values()) {\n peers.delete(id);\n }\n // Remove from gossip mapping\n this.gossip.delete(id);\n // Remove from control mapping\n this.control.delete(id);\n // Remove from backoff mapping\n this.outbound.delete(id);\n // Remove from peer scoring\n this.score.removePeer(id);\n return peerStreams;\n }\n /**\n * Handles an rpc request from a peer\n *\n * @override\n * @param {String} idB58Str\n * @param {PeerStreams} peerStreams\n * @param {RPC} rpc\n * @returns {Promise<boolean>}\n */\n _processRpc(id, peerStreams, rpc) {\n const _super = Object.create(null, {\n _processRpc: { get: () => super._processRpc }\n });\n return __awaiter(this, void 0, void 0, function* () {\n if (yield _super._processRpc.call(this, id, peerStreams, rpc)) {\n if (rpc.control) {\n this._processRpcControlMessage(id, rpc.control);\n }\n return true;\n }\n return false;\n });\n }\n /**\n * Handles an rpc control message from a peer\n * @param {string} id peer id\n * @param {RPC.IControlMessage} controlMsg\n * @returns {void}\n */\n _processRpcControlMessage(id, controlMsg) {\n if (!controlMsg) {\n return;\n }\n const iwant = controlMsg.ihave ? this._handleIHave(id, controlMsg.ihave) : [];\n const ihave = controlMsg.iwant ? this._handleIWant(id, controlMsg.iwant) : [];\n const prune = controlMsg.graft ? this._handleGraft(id, controlMsg.graft) : [];\n controlMsg.prune && this._handlePrune(id, controlMsg.prune);\n if (!iwant.length && !ihave.length && !prune.length) {\n return;\n }\n const outRpc = utils_1.createGossipRpc(ihave, { iwant, prune });\n this._sendRpc(id, outRpc);\n }\n /**\n * Process incoming message,\n * emitting locally and forwarding on to relevant floodsub and gossipsub peers\n * @override\n * @param {InMessage} msg\n * @returns {Promise<void>}\n */\n _processRpcMessage(msg) {\n const _super = Object.create(null, {\n _processRpcMessage: { get: () => super._processRpcMessage }\n });\n return __awaiter(this, void 0, void 0, function* () {\n const msgID = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgID);\n // Ignore if we've already seen the message\n if (this.seenCache.has(msgIdStr)) {\n this.score.duplicateMessage(msg);\n return;\n }\n this.seenCache.put(msgIdStr);\n yield this.score.validateMessage(msg);\n yield _super._processRpcMessage.call(this, msg);\n });\n }\n /**\n * Whether to accept a message from a peer\n * @override\n * @param {string} id\n * @returns {boolean}\n */\n _acceptFrom(id) {\n return this.direct.has(id) || this.score.score(id) >= this._options.scoreThresholds.graylistThreshold;\n }\n /**\n * Validate incoming message\n * @override\n * @param {InMessage} message\n * @returns {Promise<void>}\n */\n validate(message) {\n const _super = Object.create(null, {\n validate: { get: () => super.validate }\n });\n return __awaiter(this, void 0, void 0, function* () {\n try {\n yield _super.validate.call(this, message);\n }\n catch (e) {\n this.score.rejectMessage(message, e.code);\n this.gossipTracer.rejectMessage(message, e.code);\n throw e;\n }\n });\n }\n /**\n * Handles IHAVE messages\n * @param {string} id peer id\n * @param {Array<RPC.IControlIHave>} ihave\n * @returns {RPC.IControlIWant}\n */\n _handleIHave(id, ihave) {\n if (!ihave.length) {\n return [];\n }\n // we ignore IHAVE gossip from any peer whose score is below the gossips threshold\n const score = this.score.score(id);\n if (score < this._options.scoreThresholds.gossipThreshold) {\n this.log('IHAVE: ignoring peer %s with score below threshold [ score = %d ]', id, score);\n return [];\n }\n // IHAVE flood protection\n const peerhave = (this.peerhave.get(id) || 0) + 1;\n this.peerhave.set(id, peerhave);\n if (peerhave > constants.GossipsubMaxIHaveMessages) {\n this.log('IHAVE: peer %s has advertised too many times (%d) within this heartbeat interval; ignoring', id, peerhave);\n return [];\n }\n const iasked = this.iasked.get(id) || 0;\n if (iasked >= constants.GossipsubMaxIHaveLength) {\n this.log('IHAVE: peer %s has already advertised too many messages (%d); ignoring', id, iasked);\n return [];\n }\n // string msgId => msgId\n const iwant = new Map();\n ihave.forEach(({ topicID, messageIDs }) => {\n if (!topicID || !messageIDs || !this.mesh.has(topicID)) {\n return;\n }\n messageIDs.forEach((msgID) => {\n const msgIdStr = utils_1.messageIdToString(msgID);\n if (this.seenCache.has(msgIdStr)) {\n return;\n }\n iwant.set(msgIdStr, msgID);\n });\n });\n if (!iwant.size) {\n return [];\n }\n let iask = iwant.size;\n if (iask + iasked > constants.GossipsubMaxIHaveLength) {\n iask = constants.GossipsubMaxIHaveLength - iasked;\n }\n this.log('IHAVE: Asking for %d out of %d messages from %s', iask, iwant.size, id);\n let iwantList = Array.from(iwant.values());\n // ask in random order\n utils_1.shuffle(iwantList);\n // truncate to the messages we are actually asking for and update the iasked counter\n iwantList = iwantList.slice(0, iask);\n this.iasked.set(id, iasked + iask);\n this.gossipTracer.addPromise(id, iwantList);\n return [{\n messageIDs: iwantList\n }];\n }\n /**\n * Handles IWANT messages\n * Returns messages to send back to peer\n * @param {string} id peer id\n * @param {Array<RPC.IControlIWant>} iwant\n * @returns {Array<RPC.IMessage>}\n */\n _handleIWant(id, iwant) {\n if (!iwant.length) {\n return [];\n }\n // we don't respond to IWANT requests from any per whose score is below the gossip threshold\n const score = this.score.score(id);\n if (score < this._options.scoreThresholds.gossipThreshold) {\n this.log('IWANT: ignoring peer %s with score below threshold [score = %d]', id, score);\n return [];\n }\n // @type {Map<string, Message>}\n const ihave = new Map();\n iwant.forEach(({ messageIDs }) => {\n messageIDs && messageIDs.forEach((msgID) => {\n const [msg, count] = this.messageCache.getForPeer(msgID, id);\n if (!msg) {\n return;\n }\n if (count > constants.GossipsubGossipRetransmission) {\n this.log('IWANT: Peer %s has asked for message %s too many times: ignoring request', id, msgID);\n return;\n }\n ihave.set(utils_1.messageIdToString(msgID), msg);\n });\n });\n if (!ihave.size) {\n return [];\n }\n this.log('IWANT: Sending %d messages to %s', ihave.size, id);\n return Array.from(ihave.values()).map(pubsub_1.utils.normalizeOutRpcMessage);\n }\n /**\n * Handles Graft messages\n * @param {string} id peer id\n * @param {Array<RPC.IControlGraft>} graft\n * @return {Array<RPC.IControlPrune>}\n */\n _handleGraft(id, graft) {\n const prune = [];\n const score = this.score.score(id);\n const now = this._now();\n let doPX = this._options.doPX;\n graft.forEach(({ topicID }) => {\n var _a;\n if (!topicID) {\n return;\n }\n const peersInMesh = this.mesh.get(topicID);\n if (!peersInMesh) {\n // don't do PX when there is an unknown topic to avoid leaking our peers\n doPX = false;\n // spam hardening: ignore GRAFTs for unknown topics\n return;\n }\n // check if peer is already in the mesh; if so do nothing\n if (peersInMesh.has(id)) {\n return;\n }\n // we don't GRAFT to/from direct peers; complain loudly if this happens\n if (this.direct.has(id)) {\n this.log('GRAFT: ignoring request from direct peer %s', id);\n // this is possibly a bug from a non-reciprical configuration; send a PRUNE\n prune.push(topicID);\n // but don't px\n doPX = false;\n return;\n }\n // make sure we are not backing off that peer\n const expire = (_a = this.backoff.get(topicID)) === null || _a === void 0 ? void 0 : _a.get(id);\n if (typeof expire === 'number' && now < expire) {\n this.log('GRAFT: ignoring backed off peer %s', id);\n // add behavioral penalty\n this.score.addPenalty(id, 1);\n // no PX\n doPX = false;\n // check the flood cutoff -- is the GRAFT coming too fast?\n const floodCutoff = expire + constants.GossipsubGraftFloodThreshold - constants.GossipsubPruneBackoff;\n if (now < floodCutoff) {\n // extra penalty\n this.score.addPenalty(id, 1);\n }\n // refresh the backoff\n this._addBackoff(id, topicID);\n prune.push(topicID);\n return;\n }\n // check the score\n if (score < 0) {\n // we don't GRAFT peers with negative score\n this.log('GRAFT: ignoring peer %s with negative score: score=%d, topic=%s', id, score, topicID);\n // we do send them PRUNE however, because it's a matter of protocol correctness\n prune.push(topicID);\n // but we won't PX to them\n doPX = false;\n // add/refresh backoff so that we don't reGRAFT too early even if the score decays\n this._addBackoff(id, topicID);\n return;\n }\n // check the number of mesh peers; if it is at (or over) Dhi, we only accept grafts\n // from peers with outbound connections; this is a defensive check to restrict potential\n // mesh takeover attacks combined with love bombing\n if (peersInMesh.size >= this._options.Dhi && !this.outbound.get(id)) {\n prune.push(topicID);\n this._addBackoff(id, topicID);\n return;\n }\n this.log('GRAFT: Add mesh link from %s in %s', id, topicID);\n this.score.graft(id, topicID);\n peersInMesh.add(id);\n });\n if (!prune.length) {\n return [];\n }\n return prune.map(topic => this._makePrune(id, topic, doPX));\n }\n /**\n * Handles Prune messages\n * @param {string} id peer id\n * @param {Array<RPC.IControlPrune>} prune\n * @returns {void}\n */\n _handlePrune(id, prune) {\n const score = this.score.score(id);\n prune.forEach(({ topicID, backoff, peers }) => {\n if (!topicID) {\n return;\n }\n const peersInMesh = this.mesh.get(topicID);\n if (!peersInMesh) {\n return;\n }\n this.log('PRUNE: Remove mesh link to %s in %s', id, topicID);\n this.score.prune(id, topicID);\n peersInMesh.delete(id);\n // is there a backoff specified by the peer? if so obey it\n if (typeof backoff === 'number' && backoff > 0) {\n this._doAddBackoff(id, topicID, backoff * 1000);\n }\n else {\n this._addBackoff(id, topicID);\n }\n // PX\n if (peers && peers.length) {\n // we ignore PX from peers with insufficient scores\n if (score < this._options.scoreThresholds.acceptPXThreshold) {\n this.log('PRUNE: ignoring PX from peer %s with insufficient score [score = %d, topic = %s]', id, score, topicID);\n return;\n }\n this._pxConnect(peers);\n }\n });\n }\n /**\n * Add standard backoff log for a peer in a topic\n * @param {string} id\n * @param {string} topic\n * @returns {void}\n */\n _addBackoff(id, topic) {\n this._doAddBackoff(id, topic, constants.GossipsubPruneBackoff);\n }\n /**\n * Add backoff expiry interval for a peer in a topic\n * @param {string} id\n * @param {string} topic\n * @param {number} interval backoff duration in milliseconds\n * @returns {void}\n */\n _doAddBackoff(id, topic, interval) {\n let backoff = this.backoff.get(topic);\n if (!backoff) {\n backoff = new Map();\n this.backoff.set(topic, backoff);\n }\n const expire = this._now() + interval;\n const existingExpire = backoff.get(id) || 0;\n if (existingExpire < expire) {\n backoff.set(id, expire);\n }\n }\n /**\n * Apply penalties from broken IHAVE/IWANT promises\n * @returns {void}\n */\n _applyIwantPenalties() {\n this.gossipTracer.getBrokenPromises().forEach((count, p) => {\n this.log('peer %s didn\\'t follow up in %d IWANT requests; adding penalty', p, count);\n this.score.addPenalty(p, count);\n });\n }\n /**\n * Clear expired backoff expiries\n * @returns {void}\n */\n _clearBackoff() {\n // we only clear once every GossipsubPruneBackoffTicks ticks to avoid iterating over the maps too much\n if (this.heartbeatTicks % constants.GossipsubPruneBackoffTicks !== 0) {\n return;\n }\n const now = this._now();\n this.backoff.forEach((backoff, topic) => {\n backoff.forEach((expire, id) => {\n if (expire < now) {\n backoff.delete(id);\n }\n });\n if (backoff.size === 0) {\n this.backoff.delete(topic);\n }\n });\n }\n /**\n * Maybe reconnect to direct peers\n * @returns {void}\n */\n _directConnect() {\n // we only do this every few ticks to allow pending connections to complete and account for\n // restarts/downtime\n if (this.heartbeatTicks % constants.GossipsubDirectConnectTicks !== 0) {\n return;\n }\n const toconnect = [];\n this.direct.forEach(id => {\n const peer = this.peers.get(id);\n if (!peer || !peer.isWritable) {\n toconnect.push(id);\n }\n });\n if (toconnect.length) {\n toconnect.forEach(id => {\n this._connect(id);\n });\n }\n }\n /**\n * Maybe attempt connection given signed peer records\n * @param {RPC.IPeerInfo[]} peers\n * @returns {Promise<void>}\n */\n _pxConnect(peers) {\n return __awaiter(this, void 0, void 0, function* () {\n if (peers.length > constants.GossipsubPrunePeers) {\n utils_1.shuffle(peers);\n peers = peers.slice(0, constants.GossipsubPrunePeers);\n }\n const toconnect = [];\n yield Promise.all(peers.map((pi) => __awaiter(this, void 0, void 0, function* () {\n if (!pi.peerID) {\n return;\n }\n const p = PeerId.createFromBytes(pi.peerID);\n const id = p.toB58String();\n if (this.peers.has(id)) {\n return;\n }\n if (!pi.signedPeerRecord) {\n toconnect.push(id);\n return;\n }\n // The peer sent us a signed record\n // This is not a record from the peer who sent the record, but another peer who is connected with it\n // Ensure that it is valid\n try {\n const envelope = yield Envelope.openAndCertify(pi.signedPeerRecord, 'libp2p-peer-record');\n const eid = envelope.peerId.toB58String();\n if (id !== eid) {\n this.log('bogus peer record obtained through px: peer ID %s doesn\\'t match expected peer %s', eid, id);\n return;\n }\n if (!this._libp2p.peerStore.addressBook.consumePeerRecord(envelope)) {\n this.log('bogus peer record obtained through px: could not add peer record to address book');\n return;\n }\n toconnect.push(id);\n }\n catch (e) {\n this.log('bogus peer record obtained through px: invalid signature or not a peer record');\n }\n })));\n if (!toconnect.length) {\n return;\n }\n toconnect.forEach(id => this._connect(id));\n });\n }\n /**\n * Mounts the gossipsub protocol onto the libp2p node and sends our\n * our subscriptions to every peer connected\n * @override\n * @returns {void}\n */\n start() {\n super.start();\n this.heartbeat.start();\n this.score.start();\n // connect to direct peers\n this._directPeerInitial = setTimeout(() => {\n this.direct.forEach(id => {\n this._connect(id);\n });\n }, constants.GossipsubDirectConnectInitialDelay);\n }\n /**\n * Unmounts the gossipsub protocol and shuts down every connection\n * @override\n * @returns {void}\n */\n stop() {\n super.stop();\n this.heartbeat.stop();\n this.score.stop();\n this.mesh = new Map();\n this.fanout = new Map();\n this.lastpub = new Map();\n this.gossip = new Map();\n this.control = new Map();\n this.peerhave = new Map();\n this.iasked = new Map();\n this.backoff = new Map();\n this.outbound = new Map();\n this.gossipTracer.clear();\n clearTimeout(this._directPeerInitial);\n }\n /**\n * Connect to a peer using the gossipsub protocol\n * @param {string} id\n * @returns {void}\n */\n _connect(id) {\n this.log('Initiating connection with %s', id);\n this._libp2p.dialProtocol(PeerId.createFromB58String(id), this.multicodecs);\n }\n /**\n * Subscribes to a topic\n * @override\n * @param {string} topic\n * @returns {void}\n */\n subscribe(topic) {\n super.subscribe(topic);\n this.join(topic);\n }\n /**\n * Unsubscribe to a topic\n * @override\n * @param {string} topic\n * @returns {void}\n */\n unsubscribe(topic) {\n super.unsubscribe(topic);\n this.leave(topic);\n }\n /**\n * Join topic\n * @param {string} topic\n * @returns {void}\n */\n join(topic) {\n if (!this.started) {\n throw new Error('Gossipsub has not started');\n }\n this.log('JOIN %s', topic);\n const fanoutPeers = this.fanout.get(topic);\n if (fanoutPeers) {\n // these peers have a score above the publish threshold, which may be negative\n // so drop the ones with a negative score\n fanoutPeers.forEach(id => {\n if (this.score.score(id) < 0) {\n fanoutPeers.delete(id);\n }\n });\n if (fanoutPeers.size < this._options.D) {\n // we need more peers; eager, as this would get fixed in the next heartbeat\n get_gossip_peers_1.getGossipPeers(this, topic, this._options.D - fanoutPeers.size, (id) => {\n // filter our current peers, direct peers, and peers with negative scores\n return !fanoutPeers.has(id) && !this.direct.has(id) && this.score.score(id) >= 0;\n }).forEach(id => fanoutPeers.add(id));\n }\n this.mesh.set(topic, fanoutPeers);\n this.fanout.delete(topic);\n this.lastpub.delete(topic);\n }\n else {\n const peers = get_gossip_peers_1.getGossipPeers(this, topic, this._options.D, (id) => {\n // filter direct peers and peers with negative score\n return !this.direct.has(id) && this.score.score(id) >= 0;\n });\n this.mesh.set(topic, peers);\n }\n this.mesh.get(topic).forEach((id) => {\n this.log('JOIN: Add mesh link to %s in %s', id, topic);\n this._sendGraft(id, topic);\n });\n }\n /**\n * Leave topic\n * @param {string} topic\n * @returns {void}\n */\n leave(topic) {\n if (!this.started) {\n throw new Error('Gossipsub has not started');\n }\n this.log('LEAVE %s', topic);\n // Send PRUNE to mesh peers\n const meshPeers = this.mesh.get(topic);\n if (meshPeers) {\n meshPeers.forEach((id) => {\n this.log('LEAVE: Remove mesh link to %s in %s', id, topic);\n this._sendPrune(id, topic);\n });\n this.mesh.delete(topic);\n }\n }\n /**\n * Publish messages\n *\n * @override\n * @param {InMessage} msg\n * @returns {void}\n */\n _publish(msg) {\n return __awaiter(this, void 0, void 0, function* () {\n if (msg.receivedFrom !== this.peerId.toB58String()) {\n this.score.deliverMessage(msg);\n this.gossipTracer.deliverMessage(msg);\n }\n const msgID = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgID);\n // put in seen cache\n this.seenCache.put(msgIdStr);\n this.messageCache.put(msg);\n const tosend = new Set();\n msg.topicIDs.forEach((topic) => {\n const peersInTopic = this.topics.get(topic);\n if (!peersInTopic) {\n return;\n }\n if (this._options.floodPublish && msg.from === this.peerId.toB58String()) {\n // flood-publish behavior\n // send to direct peers and _all_ peers meeting the publishThreshold\n peersInTopic.forEach(id => {\n if (this.direct.has(id) || this.score.score(id) >= this._options.scoreThresholds.publishThreshold) {\n tosend.add(id);\n }\n });\n }\n else {\n // non-flood-publish behavior\n // send to direct peers, subscribed floodsub peers\n // and some mesh peers above publishThreshold\n // direct peers\n this.direct.forEach(id => {\n tosend.add(id);\n });\n // floodsub peers\n peersInTopic.forEach((id) => {\n const score = this.score.score(id);\n const peerStreams = this.peers.get(id);\n if (!peerStreams) {\n return;\n }\n if (peerStreams.protocol === constants.FloodsubID && score >= this._options.scoreThresholds.publishThreshold) {\n tosend.add(id);\n }\n });\n // Gossipsub peers handling\n let meshPeers = this.mesh.get(topic);\n if (!meshPeers || !meshPeers.size) {\n // We are not in the mesh for topic, use fanout peers\n meshPeers = this.fanout.get(topic);\n if (!meshPeers) {\n // If we are not in the fanout, then pick peers in topic above the publishThreshold\n const peers = get_gossip_peers_1.getGossipPeers(this, topic, this._options.D, id => {\n return this.score.score(id) >= this._options.scoreThresholds.publishThreshold;\n });\n if (peers.size > 0) {\n meshPeers = peers;\n this.fanout.set(topic, peers);\n }\n else {\n meshPeers = new Set();\n }\n }\n // Store the latest publishing time\n this.lastpub.set(topic, this._now());\n }\n meshPeers.forEach((peer) => {\n tosend.add(peer);\n });\n }\n });\n // Publish messages to peers\n const rpc = utils_1.createGossipRpc([\n pubsub_1.utils.normalizeOutRpcMessage(msg)\n ]);\n tosend.forEach((id) => {\n if (id === msg.from) {\n return;\n }\n this._sendRpc(id, rpc);\n });\n });\n }\n /**\n * Sends a GRAFT message to a peer\n * @param {string} id peer id\n * @param {string} topic\n * @returns {void}\n */\n _sendGraft(id, topic) {\n const graft = [{\n topicID: topic\n }];\n const out = utils_1.createGossipRpc([], { graft });\n this._sendRpc(id, out);\n }\n /**\n * Sends a PRUNE message to a peer\n * @param {string} id peer id\n * @param {string} topic\n * @returns {void}\n */\n _sendPrune(id, topic) {\n const prune = [\n this._makePrune(id, topic, this._options.doPX)\n ];\n const out = utils_1.createGossipRpc([], { prune });\n this._sendRpc(id, out);\n }\n /**\n * @override\n */\n _sendRpc(id, outRpc) {\n const peerStreams = this.peers.get(id);\n if (!peerStreams || !peerStreams.isWritable) {\n return;\n }\n // piggyback control message retries\n const ctrl = this.control.get(id);\n if (ctrl) {\n this._piggybackControl(id, outRpc, ctrl);\n this.control.delete(id);\n }\n // piggyback gossip\n const ihave = this.gossip.get(id);\n if (ihave) {\n this._piggybackGossip(id, outRpc, ihave);\n this.gossip.delete(id);\n }\n peerStreams.write(rpc_1.RPC.encode(outRpc).finish());\n }\n _piggybackControl(id, outRpc, ctrl) {\n const tograft = (ctrl.graft || [])\n .filter(({ topicID }) => (topicID && this.mesh.get(topicID) || new Set()).has(id));\n const toprune = (ctrl.prune || [])\n .filter(({ topicID }) => !(topicID && this.mesh.get(topicID) || new Set()).has(id));\n if (!tograft.length && !toprune.length) {\n return;\n }\n if (outRpc.control) {\n outRpc.control.graft = outRpc.control.graft && outRpc.control.graft.concat(tograft);\n outRpc.control.prune = outRpc.control.prune && outRpc.control.prune.concat(toprune);\n }\n else {\n outRpc.control = { ihave: [], iwant: [], graft: tograft, prune: toprune };\n }\n }\n _piggybackGossip(id, outRpc, ihave) {\n if (!outRpc.control) {\n outRpc.control = { ihave: [], iwant: [], graft: [], prune: [] };\n }\n outRpc.control.ihave = ihave;\n }\n /**\n * Send graft and prune messages\n * @param {Map<string, Array<string>>} tograft peer id => topic[]\n * @param {Map<string, Array<string>>} toprune peer id => topic[]\n */\n _sendGraftPrune(tograft, toprune, noPX) {\n const doPX = this._options.doPX;\n for (const [id, topics] of tograft) {\n const graft = topics.map((topicID) => ({ topicID }));\n let prune = [];\n // If a peer also has prunes, process them now\n const pruning = toprune.get(id);\n if (pruning) {\n prune = pruning.map((topicID) => this._makePrune(id, topicID, doPX && !noPX.get(id)));\n toprune.delete(id);\n }\n const outRpc = utils_1.createGossipRpc([], { graft, prune });\n this._sendRpc(id, outRpc);\n }\n for (const [id, topics] of toprune) {\n const prune = topics.map((topicID) => this._makePrune(id, topicID, doPX && !noPX.get(id)));\n const outRpc = utils_1.createGossipRpc([], { prune });\n this._sendRpc(id, outRpc);\n }\n }\n /**\n * Emits gossip to peers in a particular topic\n * @param {string} topic\n * @param {Set<string>} exclude peers to exclude\n * @returns {void}\n */\n _emitGossip(topic, exclude) {\n const messageIDs = this.messageCache.getGossipIDs(topic);\n if (!messageIDs.length) {\n return;\n }\n // shuffle to emit in random order\n utils_1.shuffle(messageIDs);\n // if we are emitting more than GossipsubMaxIHaveLength ids, truncate the list\n if (messageIDs.length > constants.GossipsubMaxIHaveLength) {\n // we do the truncation (with shuffling) per peer below\n this.log('too many messages for gossip; will truncate IHAVE list (%d messages)', messageIDs.length);\n }\n // Send gossip to GossipFactor peers above threshold with a minimum of D_lazy\n // First we collect the peers above gossipThreshold that are not in the exclude set\n // and then randomly select from that set\n // We also exclude direct peers, as there is no reason to emit gossip to them\n const peersToGossip = [];\n const topicPeers = this.topics.get(topic);\n if (!topicPeers) {\n // no topic peers, no gossip\n return;\n }\n topicPeers.forEach(id => {\n const peerStreams = this.peers.get(id);\n if (!peerStreams) {\n return;\n }\n if (!exclude.has(id) &&\n !this.direct.has(id) &&\n utils_1.hasGossipProtocol(peerStreams.protocol) &&\n this.score.score(id) >= this._options.scoreThresholds.gossipThreshold) {\n peersToGossip.push(id);\n }\n });\n let target = this._options.Dlazy;\n const factor = constants.GossipsubGossipFactor * peersToGossip.length;\n if (factor > target) {\n target = factor;\n }\n if (target > peersToGossip.length) {\n target = peersToGossip.length;\n }\n else {\n utils_1.shuffle(peersToGossip);\n }\n // Emit the IHAVE gossip to the selected peers up to the target\n peersToGossip.slice(0, target).forEach(id => {\n let peerMessageIDs = messageIDs;\n if (messageIDs.length > constants.GossipsubMaxIHaveLength) {\n // shuffle and slice message IDs per peer so that we emit a different set for each peer\n // we have enough reduncancy in the system that this will significantly increase the message\n // coverage when we do truncate\n peerMessageIDs = utils_1.shuffle(peerMessageIDs.slice()).slice(0, constants.GossipsubMaxIHaveLength);\n }\n this._pushGossip(id, {\n topicID: topic,\n messageIDs: peerMessageIDs\n });\n });\n }\n /**\n * Flush gossip and control messages\n */\n _flush() {\n // send gossip first, which will also piggyback control\n for (const [peer, ihave] of this.gossip.entries()) {\n this.gossip.delete(peer);\n const out = utils_1.createGossipRpc([], { ihave });\n this._sendRpc(peer, out);\n }\n // send the remaining control messages\n for (const [peer, control] of this.control.entries()) {\n this.control.delete(peer);\n const out = utils_1.createGossipRpc([], { graft: control.graft, prune: control.prune });\n this._sendRpc(peer, out);\n }\n }\n /**\n * Adds new IHAVE messages to pending gossip\n * @param {PeerStreams} peerStreams\n * @param {Array<RPC.IControlIHave>} controlIHaveMsgs\n * @returns {void}\n */\n _pushGossip(id, controlIHaveMsgs) {\n this.log('Add gossip to %s', id);\n const gossip = this.gossip.get(id) || [];\n this.gossip.set(id, gossip.concat(controlIHaveMsgs));\n }\n /**\n * Returns the current time in milliseconds\n * @returns {number}\n */\n _now() {\n return Date.now();\n }\n /**\n * Make a PRUNE control message for a peer in a topic\n * @param {string} id\n * @param {string} topic\n * @param {boolean} doPX\n * @returns {RPC.IControlPrune}\n */\n _makePrune(id, topic, doPX) {\n if (this.peers.get(id).protocol === constants.GossipsubIDv10) {\n // Gossipsub v1.0 -- no backoff, the peer won't be able to parse it anyway\n return {\n topicID: topic,\n peers: []\n };\n }\n // backoff is measured in seconds\n // GossipsubPruneBackoff is measured in milliseconds\n const backoff = constants.GossipsubPruneBackoff / 1000;\n const px = [];\n if (doPX) {\n // select peers for Peer eXchange\n const peers = get_gossip_peers_1.getGossipPeers(this, topic, constants.GossipsubPrunePeers, (xid) => {\n return xid !== id && this.score.score(xid) >= 0;\n });\n peers.forEach(p => {\n // see if we have a signed record to send back; if we don't, just send\n // the peer ID and let the pruned peer find them in the DHT -- we can't trust\n // unsigned address records through PX anyways\n // Finding signed records in the DHT is not supported at the time of writing in js-libp2p\n const peerId = PeerId.createFromB58String(p);\n px.push({\n peerID: peerId.toBytes(),\n signedPeerRecord: this._libp2p.peerStore.addressBook.getRawEnvelope(peerId)\n });\n });\n }\n return {\n topicID: topic,\n peers: px,\n backoff: backoff\n };\n }\n}\nGossipsub.multicodec = constants.GossipsubIDv11;\nmodule.exports = Gossipsub;\n","'use strict'\n\nconst debug = require('debug')\nconst { EventEmitter } = require('events')\nconst errcode = require('err-code')\n\nconst { pipe } = require('it-pipe')\nconst { default: Queue } = require('p-queue')\n\nconst MulticodecTopology = require('../topology/multicodec-topology')\nconst { codes } = require('./errors')\n\nconst { RPC } = require('./message/rpc')\nconst PeerStreams = require('./peer-streams')\nconst { SignaturePolicy } = require('./signature-policy')\nconst utils = require('./utils')\n\nconst {\n signMessage,\n verifySignature\n} = require('./message/sign')\n\n/**\n * @typedef {any} Libp2p\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('bl')} BufferList\n * @typedef {import('../stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('../connection/connection')} Connection\n * @typedef {import('./signature-policy').SignaturePolicyType} SignaturePolicyType\n * @typedef {import('./message/rpc').IRPC} IRPC\n * @typedef {import('./message/rpc').RPC.SubOpts} RPCSubOpts\n * @typedef {import('./message/rpc').RPC.Message} RPCMessage\n */\n\n/**\n * @typedef {Object} InMessage\n * @property {string} [from]\n * @property {string} receivedFrom\n * @property {string[]} topicIDs\n * @property {Uint8Array} [seqno]\n * @property {Uint8Array} data\n * @property {Uint8Array} [signature]\n * @property {Uint8Array} [key]\n *\n * @typedef {Object} PubsubProperties\n * @property {string} debugName - log namespace\n * @property {Array<string>|string} multicodecs - protocol identificers to connect\n * @property {Libp2p} libp2p\n *\n * @typedef {Object} PubsubOptions\n * @property {SignaturePolicyType} [globalSignaturePolicy = SignaturePolicy.StrictSign] - defines how signatures should be handled\n * @property {boolean} [canRelayMessage = false] - if can relay messages not subscribed\n * @property {boolean} [emitSelf = false] - if publish should emit to self, if subscribed\n * @property {number} [messageProcessingConcurrency = 10] - handle this many incoming pubsub messages concurrently\n */\n\n/**\n * PubsubBaseProtocol handles the peers and connections logic for pubsub routers\n * and specifies the API that pubsub routers should have.\n */\nclass PubsubBaseProtocol extends EventEmitter {\n /**\n * @param {PubsubProperties & PubsubOptions} props\n * @abstract\n */\n constructor ({\n debugName,\n multicodecs,\n libp2p,\n globalSignaturePolicy = SignaturePolicy.StrictSign,\n canRelayMessage = false,\n emitSelf = false,\n messageProcessingConcurrency = 10\n }) {\n if (typeof debugName !== 'string') {\n throw new Error('a debugname `string` is required')\n }\n\n if (!multicodecs) {\n throw new Error('multicodecs are required')\n }\n\n if (!libp2p) {\n throw new Error('libp2p is required')\n }\n\n super()\n\n this.log = Object.assign(debug(debugName), {\n err: debug(`${debugName}:error`)\n })\n\n /**\n * @type {Array<string>}\n */\n this.multicodecs = utils.ensureArray(multicodecs)\n this._libp2p = libp2p\n this.registrar = libp2p.registrar\n /**\n * @type {PeerId}\n */\n this.peerId = libp2p.peerId\n\n this.started = false\n\n /**\n * Map of topics to which peers are subscribed to\n *\n * @type {Map<string, Set<string>>}\n */\n this.topics = new Map()\n\n /**\n * List of our subscriptions\n *\n * @type {Set<string>}\n */\n this.subscriptions = new Set()\n\n /**\n * Map of peer streams\n *\n * @type {Map<string, import('./peer-streams')>}\n */\n this.peers = new Map()\n\n // validate signature policy\n if (!SignaturePolicy[globalSignaturePolicy]) {\n throw errcode(new Error('Invalid global signature policy'), codes.ERR_INVALID_SIGNATURE_POLICY)\n }\n\n /**\n * The signature policy to follow by default\n *\n * @type {string}\n */\n this.globalSignaturePolicy = globalSignaturePolicy\n\n /**\n * If router can relay received messages, even if not subscribed\n *\n * @type {boolean}\n */\n this.canRelayMessage = canRelayMessage\n\n /**\n * if publish should emit to self, if subscribed\n *\n * @type {boolean}\n */\n this.emitSelf = emitSelf\n\n /**\n * Topic validator function\n *\n * @typedef {function(string, InMessage): Promise<void>} validator\n */\n /**\n * Topic validator map\n *\n * Keyed by topic\n * Topic validators are functions with the following input:\n *\n * @type {Map<string, validator>}\n */\n this.topicValidators = new Map()\n\n /**\n * @type {Queue}\n */\n this.queue = new Queue({ concurrency: messageProcessingConcurrency })\n\n this._registrarId = undefined\n this._onIncomingStream = this._onIncomingStream.bind(this)\n this._onPeerConnected = this._onPeerConnected.bind(this)\n this._onPeerDisconnected = this._onPeerDisconnected.bind(this)\n }\n\n // LIFECYCLE METHODS\n\n /**\n * Register the pubsub protocol onto the libp2p node.\n *\n * @returns {void}\n */\n start () {\n if (this.started) {\n return\n }\n this.log('starting')\n\n // Incoming streams\n // Called after a peer dials us\n this.registrar.handle(this.multicodecs, this._onIncomingStream)\n\n // register protocol with topology\n // Topology callbacks called on connection manager changes\n const topology = new MulticodecTopology({\n multicodecs: this.multicodecs,\n handlers: {\n onConnect: this._onPeerConnected,\n onDisconnect: this._onPeerDisconnected\n }\n })\n this._registrarId = this.registrar.register(topology)\n\n this.log('started')\n this.started = true\n }\n\n /**\n * Unregister the pubsub protocol and the streams with other peers will be closed.\n *\n * @returns {void}\n */\n stop () {\n if (!this.started) {\n return\n }\n\n // unregister protocol and handlers\n this.registrar.unregister(this._registrarId)\n\n this.log('stopping')\n this.peers.forEach((peerStreams) => peerStreams.close())\n\n this.peers = new Map()\n this.subscriptions = new Set()\n this.started = false\n this.log('stopped')\n }\n\n /**\n * On an inbound stream opened.\n *\n * @protected\n * @param {Object} props\n * @param {string} props.protocol\n * @param {MuxedStream} props.stream\n * @param {Connection} props.connection - connection\n */\n _onIncomingStream ({ protocol, stream, connection }) {\n const peerId = connection.remotePeer\n const idB58Str = peerId.toB58String()\n const peer = this._addPeer(peerId, protocol)\n const inboundStream = peer.attachInboundStream(stream)\n\n this._processMessages(idB58Str, inboundStream, peer)\n }\n\n /**\n * Registrar notifies an established connection with pubsub protocol.\n *\n * @protected\n * @param {PeerId} peerId - remote peer-id\n * @param {Connection} conn - connection to the peer\n */\n async _onPeerConnected (peerId, conn) {\n const idB58Str = peerId.toB58String()\n this.log('connected', idB58Str)\n\n try {\n const { stream, protocol } = await conn.newStream(this.multicodecs)\n const peer = this._addPeer(peerId, protocol)\n await peer.attachOutboundStream(stream)\n } catch (err) {\n this.log.err(err)\n }\n\n // Immediately send my own subscriptions to the newly established conn\n this._sendSubscriptions(idB58Str, Array.from(this.subscriptions), true)\n }\n\n /**\n * Registrar notifies a closing connection with pubsub protocol.\n *\n * @protected\n * @param {PeerId} peerId - peerId\n * @param {Error} [err] - error for connection end\n */\n _onPeerDisconnected (peerId, err) {\n const idB58Str = peerId.toB58String()\n\n this.log('connection ended', idB58Str, err ? err.message : '')\n this._removePeer(peerId)\n }\n\n /**\n * Notifies the router that a peer has been connected\n *\n * @protected\n * @param {PeerId} peerId\n * @param {string} protocol\n * @returns {PeerStreams}\n */\n _addPeer (peerId, protocol) {\n const id = peerId.toB58String()\n const existing = this.peers.get(id)\n\n // If peer streams already exists, do nothing\n if (existing) {\n return existing\n }\n\n // else create a new peer streams\n this.log('new peer', id)\n\n const peerStreams = new PeerStreams({\n id: peerId,\n protocol\n })\n\n this.peers.set(id, peerStreams)\n peerStreams.once('close', () => this._removePeer(peerId))\n\n return peerStreams\n }\n\n /**\n * Notifies the router that a peer has been disconnected.\n *\n * @protected\n * @param {PeerId} peerId\n * @returns {PeerStreams | undefined}\n */\n _removePeer (peerId) {\n if (!peerId) return\n const id = peerId.toB58String()\n const peerStreams = this.peers.get(id)\n if (!peerStreams) return\n\n // close peer streams\n peerStreams.removeAllListeners()\n peerStreams.close()\n\n // delete peer streams\n this.log('delete peer', id)\n this.peers.delete(id)\n\n // remove peer from topics map\n for (const peers of this.topics.values()) {\n peers.delete(id)\n }\n\n return peerStreams\n }\n\n // MESSAGE METHODS\n\n /**\n * Responsible for processing each RPC message received by other peers.\n *\n * @param {string} idB58Str - peer id string in base58\n * @param {AsyncIterable<Uint8Array|BufferList>} stream - inbound stream\n * @param {PeerStreams} peerStreams - PubSub peer\n * @returns {Promise<void>}\n */\n async _processMessages (idB58Str, stream, peerStreams) {\n try {\n await pipe(\n stream,\n async (source) => {\n for await (const data of source) {\n const rpcBytes = data instanceof Uint8Array ? data : data.slice()\n const rpcMsg = this._decodeRpc(rpcBytes)\n\n // Since _processRpc may be overridden entirely in unsafe ways,\n // the simplest/safest option here is to wrap in a function and capture all errors\n // to prevent a top-level unhandled exception\n // This processing of rpc messages should happen without awaiting full validation/execution of prior messages\n ;(async () => {\n try {\n await this._processRpc(idB58Str, peerStreams, rpcMsg)\n } catch (err) {\n this.log.err(err)\n }\n })()\n }\n }\n )\n } catch (err) {\n this._onPeerDisconnected(peerStreams.id, err)\n }\n }\n\n /**\n * Handles an rpc request from a peer\n *\n * @param {string} idB58Str\n * @param {PeerStreams} peerStreams\n * @param {RPC} rpc\n * @returns {Promise<boolean>}\n */\n async _processRpc (idB58Str, peerStreams, rpc) {\n this.log('rpc from', idB58Str)\n const subs = rpc.subscriptions\n const msgs = rpc.msgs\n\n if (subs.length) {\n // update peer subscriptions\n subs.forEach((subOpt) => {\n this._processRpcSubOpt(idB58Str, subOpt)\n })\n this.emit('pubsub:subscription-change', peerStreams.id, subs)\n }\n\n if (!this._acceptFrom(idB58Str)) {\n this.log('received message from unacceptable peer %s', idB58Str)\n return false\n }\n\n if (msgs.length) {\n this.queue.addAll(msgs.map(message => async () => {\n if (!(this.canRelayMessage || (message.topicIDs && message.topicIDs.some((topic) => this.subscriptions.has(topic))))) {\n this.log('received message we didn\\'t subscribe to. Dropping.')\n return\n }\n\n try {\n const msg = utils.normalizeInRpcMessage(message, idB58Str)\n\n await this._processRpcMessage(msg)\n } catch (err) {\n this.log.err(err)\n }\n }))\n }\n return true\n }\n\n /**\n * Handles a subscription change from a peer\n *\n * @param {string} id\n * @param {RPC.ISubOpts} subOpt\n */\n _processRpcSubOpt (id, subOpt) {\n const t = subOpt.topicID\n\n if (!t) {\n return\n }\n\n let topicSet = this.topics.get(t)\n if (!topicSet) {\n topicSet = new Set()\n this.topics.set(t, topicSet)\n }\n\n if (subOpt.subscribe) {\n // subscribe peer to new topic\n topicSet.add(id)\n } else {\n // unsubscribe from existing topic\n topicSet.delete(id)\n }\n }\n\n /**\n * Handles an message from a peer\n *\n * @param {InMessage} msg\n * @returns {Promise<void>}\n */\n async _processRpcMessage (msg) {\n if (this.peerId.toB58String() === msg.from && !this.emitSelf) {\n return\n }\n\n // Ensure the message is valid before processing it\n try {\n await this.validate(msg)\n } catch (err) {\n this.log('Message is invalid, dropping it. %O', err)\n return\n }\n\n // Emit to self\n this._emitMessage(msg)\n\n return this._publish(utils.normalizeOutRpcMessage(msg))\n }\n\n /**\n * Emit a message from a peer\n *\n * @param {InMessage} message\n */\n _emitMessage (message) {\n message.topicIDs.forEach((topic) => {\n if (this.subscriptions.has(topic)) {\n this.emit(topic, message)\n }\n })\n }\n\n /**\n * The default msgID implementation\n * Child class can override this.\n *\n * @param {InMessage} msg - the message object\n * @returns {Promise<Uint8Array> | Uint8Array} message id as bytes\n */\n getMsgId (msg) {\n const signaturePolicy = this.globalSignaturePolicy\n switch (signaturePolicy) {\n case SignaturePolicy.StrictSign:\n // @ts-ignore seqno is optional in protobuf definition but it will exist\n return utils.msgId(msg.from, msg.seqno)\n case SignaturePolicy.StrictNoSign:\n return utils.noSignMsgId(msg.data)\n default:\n throw errcode(new Error('Cannot get message id: unhandled signature policy: ' + signaturePolicy), codes.ERR_UNHANDLED_SIGNATURE_POLICY)\n }\n }\n\n /**\n * Whether to accept a message from a peer\n * Override to create a graylist\n *\n * @param {string} id\n * @returns {boolean}\n */\n _acceptFrom (id) {\n return true\n }\n\n /**\n * Decode Uint8Array into an RPC object.\n * This can be override to use a custom router protobuf.\n *\n * @param {Uint8Array} bytes\n * @returns {RPC}\n */\n _decodeRpc (bytes) {\n return RPC.decode(bytes)\n }\n\n /**\n * Encode RPC object into a Uint8Array.\n * This can be override to use a custom router protobuf.\n *\n * @param {IRPC} rpc\n * @returns {Uint8Array}\n */\n _encodeRpc (rpc) {\n return RPC.encode(rpc).finish()\n }\n\n /**\n * Send an rpc object to a peer\n *\n * @param {string} id - peer id\n * @param {IRPC} rpc\n * @returns {void}\n */\n _sendRpc (id, rpc) {\n const peerStreams = this.peers.get(id)\n if (!peerStreams || !peerStreams.isWritable) {\n const msg = `Cannot send RPC to ${id} as there is no open stream to it available`\n\n this.log.err(msg)\n return\n }\n peerStreams.write(this._encodeRpc(rpc))\n }\n\n /**\n * Send subscroptions to a peer\n *\n * @param {string} id - peer id\n * @param {string[]} topics\n * @param {boolean} subscribe - set to false for unsubscriptions\n * @returns {void}\n */\n _sendSubscriptions (id, topics, subscribe) {\n return this._sendRpc(id, {\n subscriptions: topics.map(t => ({ topicID: t, subscribe: subscribe }))\n })\n }\n\n /**\n * Validates the given message. The signature will be checked for authenticity.\n * Throws an error on invalid messages\n *\n * @param {InMessage} message\n * @returns {Promise<void>}\n */\n async validate (message) { // eslint-disable-line require-await\n const signaturePolicy = this.globalSignaturePolicy\n switch (signaturePolicy) {\n case SignaturePolicy.StrictNoSign:\n if (message.from) {\n throw errcode(new Error('StrictNoSigning: from should not be present'), codes.ERR_UNEXPECTED_FROM)\n }\n if (message.signature) {\n throw errcode(new Error('StrictNoSigning: signature should not be present'), codes.ERR_UNEXPECTED_SIGNATURE)\n }\n if (message.key) {\n throw errcode(new Error('StrictNoSigning: key should not be present'), codes.ERR_UNEXPECTED_KEY)\n }\n if (message.seqno) {\n throw errcode(new Error('StrictNoSigning: seqno should not be present'), codes.ERR_UNEXPECTED_SEQNO)\n }\n break\n case SignaturePolicy.StrictSign:\n if (!message.signature) {\n throw errcode(new Error('StrictSigning: Signing required and no signature was present'), codes.ERR_MISSING_SIGNATURE)\n }\n if (!message.seqno) {\n throw errcode(new Error('StrictSigning: Signing required and no seqno was present'), codes.ERR_MISSING_SEQNO)\n }\n if (!(await verifySignature(message))) {\n throw errcode(new Error('StrictSigning: Invalid message signature'), codes.ERR_INVALID_SIGNATURE)\n }\n break\n default:\n throw errcode(new Error('Cannot validate message: unhandled signature policy: ' + signaturePolicy), codes.ERR_UNHANDLED_SIGNATURE_POLICY)\n }\n\n for (const topic of message.topicIDs) {\n const validatorFn = this.topicValidators.get(topic)\n if (validatorFn) {\n await validatorFn(topic, message)\n }\n }\n }\n\n /**\n * Normalizes the message and signs it, if signing is enabled.\n * Should be used by the routers to create the message to send.\n *\n * @protected\n * @param {InMessage} message\n * @returns {Promise<InMessage>}\n */\n _buildMessage (message) {\n const signaturePolicy = this.globalSignaturePolicy\n switch (signaturePolicy) {\n case SignaturePolicy.StrictSign:\n message.from = this.peerId.toB58String()\n message.seqno = utils.randomSeqno()\n return signMessage(this.peerId, message)\n case SignaturePolicy.StrictNoSign:\n return Promise.resolve(message)\n default:\n throw errcode(new Error('Cannot build message: unhandled signature policy: ' + signaturePolicy), codes.ERR_UNHANDLED_SIGNATURE_POLICY)\n }\n }\n\n // API METHODS\n\n /**\n * Get a list of the peer-ids that are subscribed to one topic.\n *\n * @param {string} topic\n * @returns {Array<string>}\n */\n getSubscribers (topic) {\n if (!this.started) {\n throw errcode(new Error('not started yet'), 'ERR_NOT_STARTED_YET')\n }\n\n if (!topic || typeof topic !== 'string') {\n throw errcode(new Error('a string topic must be provided'), 'ERR_NOT_VALID_TOPIC')\n }\n\n const peersInTopic = this.topics.get(topic)\n if (!peersInTopic) {\n return []\n }\n return Array.from(peersInTopic)\n }\n\n /**\n * Publishes messages to all subscribed peers\n *\n * @param {string} topic\n * @param {Uint8Array} message\n * @returns {Promise<void>}\n */\n async publish (topic, message) {\n if (!this.started) {\n throw new Error('Pubsub has not started')\n }\n\n this.log('publish', topic, message)\n\n const from = this.peerId.toB58String()\n const msgObject = {\n receivedFrom: from,\n data: message,\n topicIDs: [topic]\n }\n\n // ensure that the message follows the signature policy\n const outMsg = await this._buildMessage(msgObject)\n // @ts-ignore different type as from is converted\n const msg = utils.normalizeInRpcMessage(outMsg)\n\n // Emit to self if I'm interested and emitSelf enabled\n this.emitSelf && this._emitMessage(msg)\n\n // send to all the other peers\n await this._publish(msg)\n }\n\n /**\n * Overriding the implementation of publish should handle the appropriate algorithms for the publish/subscriber implementation.\n * For example, a Floodsub implementation might simply publish each message to each topic for every peer\n *\n * @abstract\n * @param {InMessage|RPCMessage} message\n * @returns {Promise<void>}\n *\n */\n _publish (message) {\n throw errcode(new Error('publish must be implemented by the subclass'), 'ERR_NOT_IMPLEMENTED')\n }\n\n /**\n * Subscribes to a given topic.\n *\n * @abstract\n * @param {string} topic\n * @returns {void}\n */\n subscribe (topic) {\n if (!this.started) {\n throw new Error('Pubsub has not started')\n }\n\n if (!this.subscriptions.has(topic)) {\n this.subscriptions.add(topic)\n this.peers.forEach((_, id) => this._sendSubscriptions(id, [topic], true))\n }\n }\n\n /**\n * Unsubscribe from the given topic.\n *\n * @param {string} topic\n * @returns {void}\n */\n unsubscribe (topic) {\n if (!this.started) {\n throw new Error('Pubsub is not started')\n }\n\n if (this.subscriptions.has(topic) && this.listenerCount(topic) === 0) {\n this.subscriptions.delete(topic)\n this.peers.forEach((_, id) => this._sendSubscriptions(id, [topic], false))\n }\n }\n\n /**\n * Get the list of topics which the peer is subscribed to.\n *\n * @returns {Array<string>}\n */\n getTopics () {\n if (!this.started) {\n throw new Error('Pubsub is not started')\n }\n\n return Array.from(this.subscriptions)\n }\n}\n\nPubsubBaseProtocol.utils = utils\nPubsubBaseProtocol.SignaturePolicy = SignaturePolicy\n\nmodule.exports = PubsubBaseProtocol\n","'use strict'\n\nconst Topology = require('./index')\nconst multicodecTopologySymbol = Symbol.for('@libp2p/js-interfaces/topology/multicodec-topology')\n\nclass MulticodecTopology extends Topology {\n /**\n * @param {TopologyOptions & MulticodecOptions} props\n */\n constructor ({\n min,\n max,\n multicodecs,\n handlers\n }) {\n super({ min, max, handlers })\n\n if (!multicodecs) {\n throw new Error('one or more multicodec should be provided')\n }\n\n if (!handlers) {\n throw new Error('the handlers should be provided')\n }\n\n if (typeof handlers.onConnect !== 'function') {\n throw new Error('the \\'onConnect\\' handler must be provided')\n }\n\n if (typeof handlers.onDisconnect !== 'function') {\n throw new Error('the \\'onDisconnect\\' handler must be provided')\n }\n\n this.multicodecs = Array.isArray(multicodecs) ? multicodecs : [multicodecs]\n this._registrar = undefined\n\n this._onProtocolChange = this._onProtocolChange.bind(this)\n this._onPeerConnect = this._onPeerConnect.bind(this)\n }\n\n get [Symbol.toStringTag] () {\n return 'Topology'\n }\n\n get [multicodecTopologySymbol] () {\n return true\n }\n\n /**\n * Checks if the given value is a `MulticodecTopology` instance.\n *\n * @param {any} other\n * @returns {other is MulticodecTopology}\n */\n static isMulticodecTopology (other) {\n return Boolean(other && other[multicodecTopologySymbol])\n }\n\n /**\n * @param {any} registrar\n */\n set registrar (registrar) { // eslint-disable-line\n this._registrar = registrar\n this._registrar.peerStore.on('change:protocols', this._onProtocolChange)\n this._registrar.connectionManager.on('peer:connect', this._onPeerConnect)\n\n // Update topology peers\n this._updatePeers(this._registrar.peerStore.peers.values())\n }\n\n /**\n * Update topology.\n *\n * @param {Array<{id: PeerId, multiaddrs: Array<Multiaddr>, protocols: Array<string>}>} peerDataIterable\n * @returns {void}\n */\n _updatePeers (peerDataIterable) {\n for (const { id, protocols } of peerDataIterable) {\n if (this.multicodecs.filter(multicodec => protocols.includes(multicodec)).length) {\n // Add the peer regardless of whether or not there is currently a connection\n this.peers.add(id.toB58String())\n // If there is a connection, call _onConnect\n const connection = this._registrar.getConnection(id)\n connection && this._onConnect(id, connection)\n } else {\n // Remove any peers we might be tracking that are no longer of value to us\n this.peers.delete(id.toB58String())\n }\n }\n }\n\n /**\n * Check if a new peer support the multicodecs for this topology.\n *\n * @param {Object} props\n * @param {PeerId} props.peerId\n * @param {Array<string>} props.protocols\n */\n _onProtocolChange ({ peerId, protocols }) {\n const hadPeer = this.peers.has(peerId.toB58String())\n const hasProtocol = protocols.filter(protocol => this.multicodecs.includes(protocol))\n\n // Not supporting the protocol anymore?\n if (hadPeer && hasProtocol.length === 0) {\n this._onDisconnect(peerId)\n }\n\n // New to protocol support\n for (const protocol of protocols) {\n if (this.multicodecs.includes(protocol)) {\n const peerData = this._registrar.peerStore.get(peerId)\n this._updatePeers([peerData])\n return\n }\n }\n }\n\n /**\n * Verify if a new connected peer has a topology multicodec and call _onConnect.\n *\n * @param {Connection} connection\n * @returns {void}\n */\n _onPeerConnect (connection) {\n // @ts-ignore - remotePeer does not existist on Connection\n const peerId = connection.remotePeer\n const protocols = this._registrar.peerStore.protoBook.get(peerId)\n\n if (!protocols) {\n return\n }\n\n if (this.multicodecs.find(multicodec => protocols.includes(multicodec))) {\n this.peers.add(peerId.toB58String())\n this._onConnect(peerId, connection)\n }\n }\n}\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr')} Multiaddr\n * @typedef {import('../connection/connection')} Connection\n * @typedef {import('.').Options} TopologyOptions\n * @typedef {Object} MulticodecOptions\n * @property {string[]} multicodecs - protocol multicodecs\n * @property {Required<Handlers>} handlers\n * @typedef {import('.').Handlers} Handlers\n */\nmodule.exports = MulticodecTopology\n","'use strict'\n\nconst noop = () => {}\nconst topologySymbol = Symbol.for('@libp2p/js-interfaces/topology')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * @typedef {Object} Options\n * @property {number} [min=0] - minimum needed connections.\n * @property {number} [max=Infinity] - maximum needed connections.\n * @property {Handlers} [handlers]\n *\n * @typedef {Object} Handlers\n * @property {(peerId: PeerId, conn: Connection) => void} [onConnect] - protocol \"onConnect\" handler\n * @property {(peerId: PeerId, error?:Error) => void} [onDisconnect] - protocol \"onDisconnect\" handler\n *\n * @typedef {import('../connection/connection')} Connection\n */\n\nclass Topology {\n /**\n * @param {Options} options\n */\n constructor ({\n min = 0,\n max = Infinity,\n handlers = {}\n }) {\n this.min = min\n this.max = max\n\n // Handlers\n this._onConnect = handlers.onConnect || noop\n this._onDisconnect = handlers.onDisconnect || noop\n\n /**\n * Set of peers that support the protocol.\n *\n * @type {Set<string>}\n */\n this.peers = new Set()\n }\n\n get [Symbol.toStringTag] () {\n return 'Topology'\n }\n\n get [topologySymbol] () {\n return true\n }\n\n /**\n * Checks if the given value is a Topology instance.\n *\n * @param {any} other\n * @returns {other is Topology}\n */\n static isTopology (other) {\n return Boolean(other && other[topologySymbol])\n }\n\n /**\n * @param {any} registrar\n */\n set registrar (registrar) { // eslint-disable-line\n this._registrar = registrar\n }\n\n /**\n * Notify about peer disconnected event.\n *\n * @param {PeerId} peerId\n * @returns {void}\n */\n disconnect (peerId) {\n this._onDisconnect(peerId)\n }\n}\n\nmodule.exports = Topology\n","'use strict'\n\nexports.codes = {\n /**\n * Signature policy is invalid\n */\n ERR_INVALID_SIGNATURE_POLICY: 'ERR_INVALID_SIGNATURE_POLICY',\n /**\n * Signature policy is unhandled\n */\n ERR_UNHANDLED_SIGNATURE_POLICY: 'ERR_UNHANDLED_SIGNATURE_POLICY',\n\n // Strict signing codes\n\n /**\n * Message expected to have a `signature`, but doesn't\n */\n ERR_MISSING_SIGNATURE: 'ERR_MISSING_SIGNATURE',\n /**\n * Message expected to have a `seqno`, but doesn't\n */\n ERR_MISSING_SEQNO: 'ERR_MISSING_SEQNO',\n /**\n * Message `signature` is invalid\n */\n ERR_INVALID_SIGNATURE: 'ERR_INVALID_SIGNATURE',\n\n // Strict no-signing codes\n\n /**\n * Message expected to not have a `from`, but does\n */\n ERR_UNEXPECTED_FROM: 'ERR_UNEXPECTED_FROM',\n /**\n * Message expected to not have a `signature`, but does\n */\n ERR_UNEXPECTED_SIGNATURE: 'ERR_UNEXPECTED_SIGNATURE',\n /**\n * Message expected to not have a `key`, but does\n */\n ERR_UNEXPECTED_KEY: 'ERR_UNEXPECTED_KEY',\n /**\n * Message expected to not have a `seqno`, but does\n */\n ERR_UNEXPECTED_SEQNO: 'ERR_UNEXPECTED_SEQNO'\n}\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-pubsub-rpc\"] || ($protobuf.roots[\"libp2p-pubsub-rpc\"] = {});\n\n$root.RPC = (function() {\n\n /**\n * Properties of a RPC.\n * @exports IRPC\n * @interface IRPC\n * @property {Array.<RPC.ISubOpts>|null} [subscriptions] RPC subscriptions\n * @property {Array.<RPC.IMessage>|null} [msgs] RPC msgs\n */\n\n /**\n * Constructs a new RPC.\n * @exports RPC\n * @classdesc Represents a RPC.\n * @implements IRPC\n * @constructor\n * @param {IRPC=} [p] Properties to set\n */\n function RPC(p) {\n this.subscriptions = [];\n this.msgs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * RPC subscriptions.\n * @member {Array.<RPC.ISubOpts>} subscriptions\n * @memberof RPC\n * @instance\n */\n RPC.prototype.subscriptions = $util.emptyArray;\n\n /**\n * RPC msgs.\n * @member {Array.<RPC.IMessage>} msgs\n * @memberof RPC\n * @instance\n */\n RPC.prototype.msgs = $util.emptyArray;\n\n /**\n * Encodes the specified RPC message. Does not implicitly {@link RPC.verify|verify} messages.\n * @function encode\n * @memberof RPC\n * @static\n * @param {IRPC} m RPC message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n RPC.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.subscriptions != null && m.subscriptions.length) {\n for (var i = 0; i < m.subscriptions.length; ++i)\n $root.RPC.SubOpts.encode(m.subscriptions[i], w.uint32(10).fork()).ldelim();\n }\n if (m.msgs != null && m.msgs.length) {\n for (var i = 0; i < m.msgs.length; ++i)\n $root.RPC.Message.encode(m.msgs[i], w.uint32(18).fork()).ldelim();\n }\n return w;\n };\n\n /**\n * Decodes a RPC message from the specified reader or buffer.\n * @function decode\n * @memberof RPC\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC} RPC\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n RPC.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.subscriptions && m.subscriptions.length))\n m.subscriptions = [];\n m.subscriptions.push($root.RPC.SubOpts.decode(r, r.uint32()));\n break;\n case 2:\n if (!(m.msgs && m.msgs.length))\n m.msgs = [];\n m.msgs.push($root.RPC.Message.decode(r, r.uint32()));\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a RPC message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC} RPC\n */\n RPC.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC)\n return d;\n var m = new $root.RPC();\n if (d.subscriptions) {\n if (!Array.isArray(d.subscriptions))\n throw TypeError(\".RPC.subscriptions: array expected\");\n m.subscriptions = [];\n for (var i = 0; i < d.subscriptions.length; ++i) {\n if (typeof d.subscriptions[i] !== \"object\")\n throw TypeError(\".RPC.subscriptions: object expected\");\n m.subscriptions[i] = $root.RPC.SubOpts.fromObject(d.subscriptions[i]);\n }\n }\n if (d.msgs) {\n if (!Array.isArray(d.msgs))\n throw TypeError(\".RPC.msgs: array expected\");\n m.msgs = [];\n for (var i = 0; i < d.msgs.length; ++i) {\n if (typeof d.msgs[i] !== \"object\")\n throw TypeError(\".RPC.msgs: object expected\");\n m.msgs[i] = $root.RPC.Message.fromObject(d.msgs[i]);\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a RPC message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC\n * @static\n * @param {RPC} m RPC\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n RPC.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.subscriptions = [];\n d.msgs = [];\n }\n if (m.subscriptions && m.subscriptions.length) {\n d.subscriptions = [];\n for (var j = 0; j < m.subscriptions.length; ++j) {\n d.subscriptions[j] = $root.RPC.SubOpts.toObject(m.subscriptions[j], o);\n }\n }\n if (m.msgs && m.msgs.length) {\n d.msgs = [];\n for (var j = 0; j < m.msgs.length; ++j) {\n d.msgs[j] = $root.RPC.Message.toObject(m.msgs[j], o);\n }\n }\n return d;\n };\n\n /**\n * Converts this RPC to JSON.\n * @function toJSON\n * @memberof RPC\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n RPC.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n RPC.SubOpts = (function() {\n\n /**\n * Properties of a SubOpts.\n * @memberof RPC\n * @interface ISubOpts\n * @property {boolean|null} [subscribe] SubOpts subscribe\n * @property {string|null} [topicID] SubOpts topicID\n */\n\n /**\n * Constructs a new SubOpts.\n * @memberof RPC\n * @classdesc Represents a SubOpts.\n * @implements ISubOpts\n * @constructor\n * @param {RPC.ISubOpts=} [p] Properties to set\n */\n function SubOpts(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * SubOpts subscribe.\n * @member {boolean|null|undefined} subscribe\n * @memberof RPC.SubOpts\n * @instance\n */\n SubOpts.prototype.subscribe = null;\n\n /**\n * SubOpts topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.SubOpts\n * @instance\n */\n SubOpts.prototype.topicID = null;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * SubOpts _subscribe.\n * @member {\"subscribe\"|undefined} _subscribe\n * @memberof RPC.SubOpts\n * @instance\n */\n Object.defineProperty(SubOpts.prototype, \"_subscribe\", {\n get: $util.oneOfGetter($oneOfFields = [\"subscribe\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * SubOpts _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.SubOpts\n * @instance\n */\n Object.defineProperty(SubOpts.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified SubOpts message. Does not implicitly {@link RPC.SubOpts.verify|verify} messages.\n * @function encode\n * @memberof RPC.SubOpts\n * @static\n * @param {RPC.ISubOpts} m SubOpts message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n SubOpts.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.subscribe != null && Object.hasOwnProperty.call(m, \"subscribe\"))\n w.uint32(8).bool(m.subscribe);\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(18).string(m.topicID);\n return w;\n };\n\n /**\n * Decodes a SubOpts message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.SubOpts\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.SubOpts} SubOpts\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n SubOpts.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.SubOpts();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.subscribe = r.bool();\n break;\n case 2:\n m.topicID = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a SubOpts message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.SubOpts\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.SubOpts} SubOpts\n */\n SubOpts.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.SubOpts)\n return d;\n var m = new $root.RPC.SubOpts();\n if (d.subscribe != null) {\n m.subscribe = Boolean(d.subscribe);\n }\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n return m;\n };\n\n /**\n * Creates a plain object from a SubOpts message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.SubOpts\n * @static\n * @param {RPC.SubOpts} m SubOpts\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n SubOpts.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.subscribe != null && m.hasOwnProperty(\"subscribe\")) {\n d.subscribe = m.subscribe;\n if (o.oneofs)\n d._subscribe = \"subscribe\";\n }\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n return d;\n };\n\n /**\n * Converts this SubOpts to JSON.\n * @function toJSON\n * @memberof RPC.SubOpts\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n SubOpts.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return SubOpts;\n })();\n\n RPC.Message = (function() {\n\n /**\n * Properties of a Message.\n * @memberof RPC\n * @interface IMessage\n * @property {Uint8Array|null} [from] Message from\n * @property {Uint8Array|null} [data] Message data\n * @property {Uint8Array|null} [seqno] Message seqno\n * @property {Array.<string>|null} [topicIDs] Message topicIDs\n * @property {Uint8Array|null} [signature] Message signature\n * @property {Uint8Array|null} [key] Message key\n */\n\n /**\n * Constructs a new Message.\n * @memberof RPC\n * @classdesc Represents a Message.\n * @implements IMessage\n * @constructor\n * @param {RPC.IMessage=} [p] Properties to set\n */\n function Message(p) {\n this.topicIDs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Message from.\n * @member {Uint8Array|null|undefined} from\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.from = null;\n\n /**\n * Message data.\n * @member {Uint8Array|null|undefined} data\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.data = null;\n\n /**\n * Message seqno.\n * @member {Uint8Array|null|undefined} seqno\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.seqno = null;\n\n /**\n * Message topicIDs.\n * @member {Array.<string>} topicIDs\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.topicIDs = $util.emptyArray;\n\n /**\n * Message signature.\n * @member {Uint8Array|null|undefined} signature\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.signature = null;\n\n /**\n * Message key.\n * @member {Uint8Array|null|undefined} key\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.key = null;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * Message _from.\n * @member {\"from\"|undefined} _from\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_from\", {\n get: $util.oneOfGetter($oneOfFields = [\"from\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _data.\n * @member {\"data\"|undefined} _data\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_data\", {\n get: $util.oneOfGetter($oneOfFields = [\"data\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _seqno.\n * @member {\"seqno\"|undefined} _seqno\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_seqno\", {\n get: $util.oneOfGetter($oneOfFields = [\"seqno\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _signature.\n * @member {\"signature\"|undefined} _signature\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_signature\", {\n get: $util.oneOfGetter($oneOfFields = [\"signature\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _key.\n * @member {\"key\"|undefined} _key\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_key\", {\n get: $util.oneOfGetter($oneOfFields = [\"key\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified Message message. Does not implicitly {@link RPC.Message.verify|verify} messages.\n * @function encode\n * @memberof RPC.Message\n * @static\n * @param {RPC.IMessage} m Message message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Message.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.from != null && Object.hasOwnProperty.call(m, \"from\"))\n w.uint32(10).bytes(m.from);\n if (m.data != null && Object.hasOwnProperty.call(m, \"data\"))\n w.uint32(18).bytes(m.data);\n if (m.seqno != null && Object.hasOwnProperty.call(m, \"seqno\"))\n w.uint32(26).bytes(m.seqno);\n if (m.topicIDs != null && m.topicIDs.length) {\n for (var i = 0; i < m.topicIDs.length; ++i)\n w.uint32(34).string(m.topicIDs[i]);\n }\n if (m.signature != null && Object.hasOwnProperty.call(m, \"signature\"))\n w.uint32(42).bytes(m.signature);\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(50).bytes(m.key);\n return w;\n };\n\n /**\n * Decodes a Message message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.Message\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.Message} Message\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Message.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.Message();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.from = r.bytes();\n break;\n case 2:\n m.data = r.bytes();\n break;\n case 3:\n m.seqno = r.bytes();\n break;\n case 4:\n if (!(m.topicIDs && m.topicIDs.length))\n m.topicIDs = [];\n m.topicIDs.push(r.string());\n break;\n case 5:\n m.signature = r.bytes();\n break;\n case 6:\n m.key = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Message message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.Message\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.Message} Message\n */\n Message.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.Message)\n return d;\n var m = new $root.RPC.Message();\n if (d.from != null) {\n if (typeof d.from === \"string\")\n $util.base64.decode(d.from, m.from = $util.newBuffer($util.base64.length(d.from)), 0);\n else if (d.from.length)\n m.from = d.from;\n }\n if (d.data != null) {\n if (typeof d.data === \"string\")\n $util.base64.decode(d.data, m.data = $util.newBuffer($util.base64.length(d.data)), 0);\n else if (d.data.length)\n m.data = d.data;\n }\n if (d.seqno != null) {\n if (typeof d.seqno === \"string\")\n $util.base64.decode(d.seqno, m.seqno = $util.newBuffer($util.base64.length(d.seqno)), 0);\n else if (d.seqno.length)\n m.seqno = d.seqno;\n }\n if (d.topicIDs) {\n if (!Array.isArray(d.topicIDs))\n throw TypeError(\".RPC.Message.topicIDs: array expected\");\n m.topicIDs = [];\n for (var i = 0; i < d.topicIDs.length; ++i) {\n m.topicIDs[i] = String(d.topicIDs[i]);\n }\n }\n if (d.signature != null) {\n if (typeof d.signature === \"string\")\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Message message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.Message\n * @static\n * @param {RPC.Message} m Message\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Message.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.topicIDs = [];\n }\n if (m.from != null && m.hasOwnProperty(\"from\")) {\n d.from = o.bytes === String ? $util.base64.encode(m.from, 0, m.from.length) : o.bytes === Array ? Array.prototype.slice.call(m.from) : m.from;\n if (o.oneofs)\n d._from = \"from\";\n }\n if (m.data != null && m.hasOwnProperty(\"data\")) {\n d.data = o.bytes === String ? $util.base64.encode(m.data, 0, m.data.length) : o.bytes === Array ? Array.prototype.slice.call(m.data) : m.data;\n if (o.oneofs)\n d._data = \"data\";\n }\n if (m.seqno != null && m.hasOwnProperty(\"seqno\")) {\n d.seqno = o.bytes === String ? $util.base64.encode(m.seqno, 0, m.seqno.length) : o.bytes === Array ? Array.prototype.slice.call(m.seqno) : m.seqno;\n if (o.oneofs)\n d._seqno = \"seqno\";\n }\n if (m.topicIDs && m.topicIDs.length) {\n d.topicIDs = [];\n for (var j = 0; j < m.topicIDs.length; ++j) {\n d.topicIDs[j] = m.topicIDs[j];\n }\n }\n if (m.signature != null && m.hasOwnProperty(\"signature\")) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n if (o.oneofs)\n d._signature = \"signature\";\n }\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n if (o.oneofs)\n d._key = \"key\";\n }\n return d;\n };\n\n /**\n * Converts this Message to JSON.\n * @function toJSON\n * @memberof RPC.Message\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Message.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Message;\n })();\n\n return RPC;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p-pubsub:peer-streams'), {\n error: debug('libp2p-pubsub:peer-streams:err')\n})\nconst { EventEmitter } = require('events')\n\nconst lp = require('it-length-prefixed')\nconst pushable = require('it-pushable')\nconst { pipe } = require('it-pipe')\nconst { source: abortable } = require('abortable-iterator')\nconst AbortController = require('abort-controller').default\n\n/**\n * @typedef {import('../stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('it-pushable').Pushable<Uint8Array>} PushableStream\n */\n\n/**\n * Thin wrapper around a peer's inbound / outbound pubsub streams\n */\nclass PeerStreams extends EventEmitter {\n /**\n * @param {object} properties - properties of the PeerStreams.\n * @param {PeerId} properties.id\n * @param {string} properties.protocol\n */\n constructor ({ id, protocol }) {\n super()\n\n /**\n * @type {import('peer-id')}\n */\n this.id = id\n /**\n * Established protocol\n *\n * @type {string}\n */\n this.protocol = protocol\n /**\n * The raw outbound stream, as retrieved from conn.newStream\n *\n * @private\n * @type {null|MuxedStream}\n */\n this._rawOutboundStream = null\n /**\n * The raw inbound stream, as retrieved from the callback from libp2p.handle\n *\n * @private\n * @type {null|MuxedStream}\n */\n this._rawInboundStream = null\n /**\n * An AbortController for controlled shutdown of the inbound stream\n *\n * @private\n * @type {AbortController}\n */\n this._inboundAbortController = new AbortController()\n /**\n * Write stream -- its preferable to use the write method\n *\n * @type {null|PushableStream}\n */\n this.outboundStream = null\n /**\n * Read stream\n *\n * @type {null| AsyncIterable<Uint8Array>}\n */\n this.inboundStream = null\n }\n\n /**\n * Do we have a connection to read from?\n *\n * @type {boolean}\n */\n get isReadable () {\n return Boolean(this.inboundStream)\n }\n\n /**\n * Do we have a connection to write on?\n *\n * @type {boolean}\n */\n get isWritable () {\n return Boolean(this.outboundStream)\n }\n\n /**\n * Send a message to this peer.\n * Throws if there is no `stream` to write to available.\n *\n * @param {Uint8Array} data\n * @returns {void}\n */\n write (data) {\n if (!this.outboundStream) {\n const id = this.id.toB58String()\n throw new Error('No writable connection to ' + id)\n }\n\n this.outboundStream.push(data)\n }\n\n /**\n * Attach a raw inbound stream and setup a read stream\n *\n * @param {MuxedStream} stream\n * @returns {AsyncIterable<Uint8Array>}\n */\n attachInboundStream (stream) {\n // Create and attach a new inbound stream\n // The inbound stream is:\n // - abortable, set to only return on abort, rather than throw\n // - transformed with length-prefix transform\n this._rawInboundStream = stream\n this.inboundStream = abortable(\n pipe(\n this._rawInboundStream,\n lp.decode()\n ),\n this._inboundAbortController.signal,\n { returnOnAbort: true }\n )\n\n this.emit('stream:inbound')\n return this.inboundStream\n }\n\n /**\n * Attach a raw outbound stream and setup a write stream\n *\n * @param {MuxedStream} stream\n * @returns {Promise<void>}\n */\n async attachOutboundStream (stream) {\n // If an outbound stream already exists, gently close it\n const _prevStream = this.outboundStream\n if (this.outboundStream) {\n // End the stream without emitting a close event\n await this.outboundStream.end()\n }\n\n this._rawOutboundStream = stream\n this.outboundStream = pushable({\n onEnd: (shouldEmit) => {\n // close writable side of the stream\n this._rawOutboundStream && this._rawOutboundStream.reset && this._rawOutboundStream.reset()\n this._rawOutboundStream = null\n this.outboundStream = null\n if (shouldEmit) {\n this.emit('close')\n }\n }\n })\n\n pipe(\n this.outboundStream,\n lp.encode(),\n this._rawOutboundStream\n ).catch(/** @param {Error} err */ err => {\n log.error(err)\n })\n\n // Only emit if the connection is new\n if (!_prevStream) {\n this.emit('stream:outbound')\n }\n }\n\n /**\n * Closes the open connection to peer\n *\n * @returns {void}\n */\n close () {\n // End the outbound stream\n if (this.outboundStream) {\n this.outboundStream.end()\n }\n // End the inbound stream\n if (this.inboundStream) {\n this._inboundAbortController.abort()\n }\n\n this._rawOutboundStream = null\n this.outboundStream = null\n this._rawInboundStream = null\n this.inboundStream = null\n this.emit('close')\n }\n}\n\nmodule.exports = PeerStreams\n","'use strict'\n\n/**\n * @typedef {import('./types').EncoderOptions} EncoderOptions\n * @typedef {import('./types').DecoderOptions} DecoderOptions\n */\n\nexports.encode = require('./encode')\nexports.decode = require('./decode')\n\nexports.varintEncode = require('./varint-encode')\nexports.varintDecode = require('./varint-decode')\n\nexports.int32BEEncode = require('./int32BE-encode')\nexports.int32BEDecode = require('./int32BE-decode')\n","'use strict'\n\nconst { Buffer } = require('buffer')\n// @ts-ignore\nconst BufferList = require('bl/BufferList')\nconst varintEncode = require('./varint-encode')\n\nconst MIN_POOL_SIZE = 8 // Varint.encode(Number.MAX_SAFE_INTEGER).length\nconst DEFAULT_POOL_SIZE = 10 * 1024\n\n/**\n * @param {import('./types').EncoderOptions} [options]\n */\nfunction encode (options) {\n options = options || {}\n\n const poolSize = Math.max(options.poolSize || DEFAULT_POOL_SIZE, options.minPoolSize || MIN_POOL_SIZE)\n const encodeLength = options.lengthEncoder || varintEncode\n\n /**\n * @param {AsyncIterable<BufferList>} source\n */\n const encoder = async function * (source) {\n let pool = Buffer.alloc(poolSize)\n let poolOffset = 0\n\n for await (const chunk of source) {\n encodeLength(chunk.length, pool, poolOffset)\n const encodedLength = pool.slice(poolOffset, poolOffset + encodeLength.bytes)\n poolOffset += encodeLength.bytes\n\n if (pool.length - poolOffset < MIN_POOL_SIZE) {\n pool = Buffer.alloc(poolSize)\n poolOffset = 0\n }\n\n yield new BufferList().append(encodedLength).append(chunk)\n // yield Buffer.concat([encodedLength, chunk])\n }\n }\n\n return encoder\n}\n\n/**\n * @param {BufferList | Buffer} chunk\n * @param {import('./types').EncoderOptions} [options]\n */\nencode.single = (chunk, options) => {\n options = options || {}\n const encodeLength = options.lengthEncoder || varintEncode\n return new BufferList([encodeLength(chunk.length), chunk.slice()])\n}\n\nmodule.exports = encode\nmodule.exports.MIN_POOL_SIZE = MIN_POOL_SIZE\nmodule.exports.DEFAULT_POOL_SIZE = DEFAULT_POOL_SIZE\n","'use strict'\n\n// @ts-ignore no types\nconst Varint = require('varint')\nconst { Buffer } = require('buffer')\n\n/**\n * Encode the passed length `value` to the `target` buffer at the given `offset`\n *\n * @type {import('./types').LengthEncoderFunction}\n */\n// @ts-ignore cannot declare expected bytes property\nconst varintEncode = (value, target, offset) => {\n const ret = Varint.encode(value, target, offset)\n varintEncode.bytes = Varint.encode.bytes\n // If no target, create Buffer from returned array\n return target || Buffer.from(ret)\n}\n\nmodule.exports = varintEncode\n","'use strict'\n\nconst { Buffer } = require('buffer')\n// @ts-ignore\nconst BufferList = require('bl/BufferList')\nconst varintDecode = require('./varint-decode')\n\n// Maximum length of the length section of the message\nconst MAX_LENGTH_LENGTH = 8 // Varint.encode(Number.MAX_SAFE_INTEGER).length\n// Maximum length of the data section of the message\nconst MAX_DATA_LENGTH = 1024 * 1024 * 4\n\nconst Empty = Buffer.alloc(0)\nconst ReadModes = { LENGTH: 'readLength', DATA: 'readData' }\n\nconst ReadHandlers = {\n /**\n * @param {BufferList} chunk\n * @param {BufferList} buffer\n * @param {import('./types').ReadState | undefined} state\n * @param {import('./types').DecoderOptions} options\n * @returns {import('./types').ReadResult}\n */\n [ReadModes.LENGTH]: (chunk, buffer, state, options) => {\n // console.log(ReadModes.LENGTH, chunk.length)\n buffer = buffer.append(chunk)\n\n let dataLength\n try {\n dataLength = options.lengthDecoder(buffer)\n } catch (err) {\n if (buffer.length > options.maxLengthLength) {\n throw Object.assign(err, { message: 'message length too long', code: 'ERR_MSG_LENGTH_TOO_LONG' })\n }\n if (err instanceof RangeError) {\n return { mode: ReadModes.LENGTH, buffer, chunk: undefined, state: undefined, data: undefined }\n }\n throw err\n }\n\n if (dataLength > options.maxDataLength) {\n throw Object.assign(new Error('message data too long'), { code: 'ERR_MSG_DATA_TOO_LONG' })\n }\n\n chunk = buffer.shallowSlice(options.lengthDecoder.bytes)\n buffer = new BufferList()\n\n if (options.onLength) options.onLength(dataLength)\n\n if (dataLength <= 0) {\n if (options.onData) options.onData(Empty)\n return { mode: ReadModes.LENGTH, chunk, buffer, data: Empty }\n }\n\n return { mode: ReadModes.DATA, chunk, buffer, state: { dataLength }, data: undefined }\n },\n\n /**\n * @param {BufferList} chunk\n * @param {BufferList} buffer\n * @param {import('./types').ReadState | undefined} state\n * @param {import('./types').DecoderOptions} options\n * @returns {import('./types').ReadResult}\n */\n [ReadModes.DATA]: (chunk, buffer, state, options) => {\n // console.log(ReadModes.DATA, chunk.length)\n buffer = buffer.append(chunk)\n\n if (!state) {\n throw new Error('state is required')\n }\n\n if (buffer.length < state.dataLength) {\n return { mode: ReadModes.DATA, buffer, state, chunk: undefined, data: undefined }\n }\n\n const { dataLength } = state\n const data = buffer.shallowSlice(0, dataLength)\n\n const nextChunk = buffer.length > dataLength ? buffer.shallowSlice(dataLength) : undefined\n buffer = new BufferList()\n\n if (options.onData) options.onData(data)\n return { mode: ReadModes.LENGTH, chunk: nextChunk, buffer, state: undefined, data }\n }\n}\n\n/**\n * @param {any} [options]\n */\nfunction decode (options) {\n options = options || {}\n\n /**\n * @type {import('./types').DecoderOptions}\n */\n const opts = {\n lengthDecoder: options.lengthDecoder || varintDecode,\n maxLengthLength: options.maxLengthLength || MAX_LENGTH_LENGTH,\n maxDataLength: options.maxDataLength || MAX_DATA_LENGTH,\n onLength: options.onLength,\n onData: options.onData\n }\n\n /**\n * @param {AsyncIterable<BufferList>} source\n */\n const decoder = async function * (source) {\n let buffer = new BufferList()\n let mode = ReadModes.LENGTH // current parsing mode\n let state // accumulated state for the current mode\n\n for await (const chunk of source) {\n /** @type {BufferList | undefined} */\n let nextChunk = chunk\n\n // Each chunk may contain multiple messages - keep calling handler for the\n // current parsing mode until all handlers have consumed the chunk.\n while (nextChunk) {\n const result = ReadHandlers[mode](nextChunk, buffer, state, opts)\n\n mode = result.mode\n nextChunk = result.chunk\n buffer = result.buffer\n state = result.state\n\n if (result.data) {\n yield result.data\n }\n }\n }\n\n if (buffer.length) {\n throw Object.assign(new Error('unexpected end of input'), { code: 'ERR_UNEXPECTED_EOF' })\n }\n }\n\n return decoder\n}\n\n/**\n * @param {*} reader\n * @param {import('./types').DecoderOptions} [options]\n * @returns\n */\ndecode.fromReader = (reader, options) => {\n let byteLength = 1 // Read single byte chunks until the length is known\n\n const varByteSource = {\n [Symbol.asyncIterator] () { return this },\n next: async () => {\n try {\n return await reader.next(byteLength)\n } catch (err) {\n if (err.code === 'ERR_UNDER_READ') {\n return { done: true, value: null }\n }\n throw err\n } finally {\n // Reset the byteLength so we continue to check for varints\n byteLength = 1\n }\n }\n }\n\n /**\n * Once the length has been parsed, read chunk for that length\n *\n * @param {number} l\n */\n const onLength = l => { byteLength = l }\n return decode({\n ...(options || {}),\n onLength\n })(varByteSource)\n}\n\nmodule.exports = decode\nmodule.exports.MAX_LENGTH_LENGTH = MAX_LENGTH_LENGTH\nmodule.exports.MAX_DATA_LENGTH = MAX_DATA_LENGTH\n","'use strict'\n\n// @ts-ignore no types\nconst Varint = require('varint')\nconst { Buffer } = require('buffer')\n\n/**\n * @param {any} bl\n */\nconst toBufferProxy = bl => new Proxy({}, {\n get: (_, prop) => {\n // @ts-ignore magic\n return prop[0] === 'l' ? bl[prop] : bl.get(parseInt(prop))\n }\n})\n\n/**\n * @type {import('./types').LengthDecoderFunction}\n */\n// @ts-ignore cannot declare expected bytes property\nconst varintDecode = data => {\n const len = Varint.decode(Buffer.isBuffer(data) ? data : toBufferProxy(data))\n varintDecode.bytes = Varint.decode.bytes\n return len\n}\n\nmodule.exports = varintDecode\n","'use strict'\n\nconst { Buffer } = require('buffer')\n\n/**\n * @param {number} value\n * @param {Buffer} target\n * @param {number} offset\n */\nconst int32BEEncode = (value, target, offset) => {\n target = target || Buffer.allocUnsafe(4)\n target.writeInt32BE(value, offset)\n return target\n}\n\nint32BEEncode.bytes = 4 // Always because fixed length\n\nmodule.exports = int32BEEncode\n","'use strict'\n\n/**\n * @param {import('buffer').Buffer} data\n */\nconst int32BEDecode = data => {\n if (data.length < 4) throw RangeError('Could not decode int32BE')\n return data.readInt32BE(0)\n}\n\nint32BEDecode.bytes = 4 // Always because fixed length\n\nmodule.exports = int32BEDecode\n","const getIterator = require('get-iterator')\nconst AbortError = require('./AbortError')\n\n// Wrap an iterator to make it abortable, allow cleanup when aborted via onAbort\nconst toAbortableSource = (source, signal, options) => (\n toMultiAbortableSource(source, Array.isArray(signal) ? signal : [{ signal, options }])\n)\n\nconst toMultiAbortableSource = (source, signals) => {\n source = getIterator(source)\n signals = signals.map(({ signal, options }) => ({ signal, options: options || {} }))\n\n async function * abortable () {\n let nextAbortHandler\n const abortHandler = () => {\n if (nextAbortHandler) nextAbortHandler()\n }\n\n for (const { signal } of signals) {\n signal.addEventListener('abort', abortHandler)\n }\n\n while (true) {\n let result\n try {\n for (const { signal, options } of signals) {\n if (signal.aborted) {\n const { abortMessage, abortCode } = options\n throw new AbortError(abortMessage, abortCode)\n }\n }\n\n const abort = new Promise((resolve, reject) => {\n nextAbortHandler = () => {\n const { options } = signals.find(({ signal }) => signal.aborted)\n const { abortMessage, abortCode } = options\n reject(new AbortError(abortMessage, abortCode))\n }\n })\n\n // Race the iterator and the abort signals\n result = await Promise.race([abort, source.next()])\n nextAbortHandler = null\n } catch (err) {\n for (const { signal } of signals) {\n signal.removeEventListener('abort', abortHandler)\n }\n\n // Might not have been aborted by a known signal\n const aborter = signals.find(({ signal }) => signal.aborted)\n const isKnownAborter = err.type === 'aborted' && aborter\n\n if (isKnownAborter && aborter.options.onAbort) {\n // Do any custom abort handling for the iterator\n await aborter.options.onAbort(source)\n }\n\n // End the iterator if it is a generator\n if (typeof source.return === 'function') {\n await source.return()\n }\n\n if (isKnownAborter && aborter.options.returnOnAbort) {\n return\n }\n\n throw err\n }\n\n if (result.done) break\n yield result.value\n }\n\n for (const { signal } of signals) {\n signal.removeEventListener('abort', abortHandler)\n }\n }\n\n return abortable()\n}\n\nconst toAbortableSink = (sink, signal, options) => (\n toMultiAbortableSink(sink, Array.isArray(signal) ? signal : [{ signal, options }])\n)\n\nconst toMultiAbortableSink = (sink, signals) => source => (\n sink(toMultiAbortableSource(source, signals))\n)\n\nconst toAbortableDuplex = (duplex, signal, options) => (\n toMultiAbortableDuplex(duplex, Array.isArray(signal) ? signal : [{ signal, options }])\n)\n\nconst toMultiAbortableDuplex = (duplex, signals) => ({\n sink: toMultiAbortableSink(duplex.sink, signals),\n source: toMultiAbortableSource(duplex.source, signals)\n})\n\nmodule.exports = toAbortableSource\nmodule.exports.AbortError = AbortError\nmodule.exports.source = toAbortableSource\nmodule.exports.sink = toAbortableSink\nmodule.exports.transform = toAbortableSink\nmodule.exports.duplex = toAbortableDuplex\n","// If the passed object is an (async) iterable, then get the iterator\n// If it's probably an iterator already (i.e. has next function) return it\n// else throw\nmodule.exports = function getIterator (obj) {\n if (obj) {\n if (typeof obj[Symbol.iterator] === 'function') {\n return obj[Symbol.iterator]()\n }\n if (typeof obj[Symbol.asyncIterator] === 'function') {\n return obj[Symbol.asyncIterator]()\n }\n if (typeof obj.next === 'function') {\n return obj // probably an iterator\n }\n }\n throw new Error('argument is not an iterator or iterable')\n}\n","module.exports = class AbortError extends Error {\n constructor (message, code) {\n super(message || 'The operation was aborted')\n this.type = 'aborted'\n this.code = code || 'ABORT_ERR'\n }\n}\n","'use strict'\n\n/**\n * Enum for Signature Policy\n * Details how message signatures are produced/consumed\n */\nconst SignaturePolicy = {\n /**\n * On the producing side:\n * * Build messages with the signature, key (from may be enough for certain inlineable public key types), from and seqno fields.\n *\n * On the consuming side:\n * * Enforce the fields to be present, reject otherwise.\n * * Propagate only if the fields are valid and signature can be verified, reject otherwise.\n */\n StrictSign: /** @type {'StrictSign'} */ ('StrictSign'),\n /**\n * On the producing side:\n * * Build messages without the signature, key, from and seqno fields.\n * * The corresponding protobuf key-value pairs are absent from the marshalled message, not just empty.\n *\n * On the consuming side:\n * * Enforce the fields to be absent, reject otherwise.\n * * Propagate only if the fields are absent, reject otherwise.\n * * A message_id function will not be able to use the above fields, and should instead rely on the data field. A commonplace strategy is to calculate a hash.\n */\n StrictNoSign: /** @type {'StrictNoSign'} */ ('StrictNoSign')\n}\nexports.SignaturePolicy = SignaturePolicy\n\n/**\n * @typedef {SignaturePolicy[keyof SignaturePolicy]} SignaturePolicyType\n */\n","'use strict'\n\n// @ts-ignore libp2p crypto has no types\nconst randomBytes = require('libp2p-crypto/src/random-bytes')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst PeerId = require('peer-id')\nconst { sha256 } = require('multiformats/hashes/sha2')\n\n/**\n * @typedef {import('./message/rpc').RPC.IMessage} IMessage\n * @typedef {import('./message/rpc').RPC.Message} Message\n * @typedef {import('.').InMessage} NormalizedIMessage\n */\n\n/**\n * Generatea random sequence number.\n *\n * @returns {Uint8Array}\n * @private\n */\nconst randomSeqno = () => {\n return randomBytes(8)\n}\n\n/**\n * Generate a message id, based on the `from` and `seqno`.\n *\n * @param {Uint8Array|string} from\n * @param {Uint8Array} seqno\n * @returns {Uint8Array}\n * @private\n */\nconst msgId = (from, seqno) => {\n let fromBytes\n\n if (from instanceof Uint8Array) {\n fromBytes = PeerId.createFromBytes(from).id\n } else {\n fromBytes = PeerId.parse(from).id\n }\n\n const msgId = new Uint8Array(fromBytes.length + seqno.length)\n msgId.set(fromBytes, 0)\n msgId.set(seqno, fromBytes.length)\n return msgId\n}\n\n/**\n * Generate a message id, based on message `data`.\n *\n * @param {Uint8Array} data\n * @private\n */\nconst noSignMsgId = (data) => sha256.encode(data)\n\n/**\n * Check if any member of the first set is also a member\n * of the second set.\n *\n * @param {Set<number>|Array<number>} a\n * @param {Set<number>|Array<number>} b\n * @returns {boolean}\n * @private\n */\nconst anyMatch = (a, b) => {\n let bHas\n if (Array.isArray(b)) {\n /**\n * @param {number} val\n */\n bHas = (val) => b.indexOf(val) > -1\n } else {\n /**\n * @param {number} val\n */\n bHas = (val) => b.has(val)\n }\n\n for (const val of a) {\n if (bHas(val)) {\n return true\n }\n }\n\n return false\n}\n\n/**\n * Make everything an array.\n *\n * @template T\n * @param {T|T[]} maybeArray\n * @returns {T[]}\n * @private\n */\nconst ensureArray = (maybeArray) => {\n if (!Array.isArray(maybeArray)) {\n return [maybeArray]\n }\n\n return maybeArray\n}\n\n/**\n * Ensures `message.from` is base58 encoded\n *\n * @template {{from?:any}} T\n * @param {T & IMessage} message\n * @param {string} [peerId]\n * @returns {NormalizedIMessage}\n */\nconst normalizeInRpcMessage = (message, peerId) => {\n /** @type {NormalizedIMessage} */\n // @ts-ignore receivedFrom not yet defined\n const m = Object.assign({}, message)\n if (message.from instanceof Uint8Array) {\n m.from = uint8ArrayToString(message.from, 'base58btc')\n }\n if (peerId) {\n m.receivedFrom = peerId\n }\n return m\n}\n\n/**\n * @template {{from?:any, data?:any}} T\n *\n * @param {T & NormalizedIMessage} message\n * @returns {Message}\n */\nconst normalizeOutRpcMessage = (message) => {\n /** @type {Message} */\n // @ts-ignore from not yet defined\n const m = Object.assign({}, message)\n if (typeof message.from === 'string') {\n m.from = uint8ArrayFromString(message.from, 'base58btc')\n }\n if (typeof message.data === 'string') {\n m.data = uint8ArrayFromString(message.data)\n }\n return m\n}\n\nmodule.exports = {\n randomSeqno,\n msgId,\n noSignMsgId,\n anyMatch,\n ensureArray,\n normalizeInRpcMessage,\n normalizeOutRpcMessage\n}\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { RPC } = require('./rpc')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst SignPrefix = uint8ArrayFromString('libp2p-pubsub:')\nconst { normalizeOutRpcMessage } = require('../utils')\n\n/**\n * @typedef {import('..').InMessage}\n */\n\n/**\n * Signs the provided message with the given `peerId`\n *\n * @param {PeerId} peerId\n * @param {InMessage} message\n * @returns {Promise<InMessage>}\n */\nasync function signMessage (peerId, message) {\n // Get the message in bytes, and prepend with the pubsub prefix\n const bytes = uint8ArrayConcat([\n SignPrefix,\n RPC.Message.encode(normalizeOutRpcMessage(message)).finish()\n ])\n\n const signature = await peerId.privKey.sign(bytes)\n\n return {\n ...message,\n signature: signature,\n key: peerId.pubKey.bytes\n }\n}\n\n/**\n * Verifies the signature of the given message\n *\n * @param {InMessage} message\n * @returns {Promise<boolean>}\n */\nasync function verifySignature (message) {\n if (!message.signature) {\n throw new Error('Message must contain a signature to be verified')\n }\n\n if (!message.from) {\n throw new Error('Message must contain a from property to be verified')\n }\n\n // Get message sans the signature\n const bytes = uint8ArrayConcat([\n SignPrefix,\n RPC.Message.encode({\n ...message,\n from: PeerId.createFromB58String(message.from).toBytes(),\n signature: undefined,\n key: undefined\n }).finish()\n ])\n\n // Get the public key\n const pubKey = await messagePublicKey(message)\n\n // verify the base message\n return pubKey.verify(bytes, message.signature)\n}\n\n/**\n * Returns the PublicKey associated with the given message.\n * If no, valid PublicKey can be retrieved an error will be returned.\n *\n * @param {InMessage} message\n * @returns {Promise<PublicKey>}\n */\nasync function messagePublicKey (message) {\n // should be available in the from property of the message (peer id)\n if (!message.from) {\n throw new Error('Could not get the public key from the originator id')\n }\n\n const from = PeerId.createFromB58String(message.from)\n\n if (message.key) {\n const keyPeerId = await PeerId.createFromPubKey(message.key)\n\n // the key belongs to the sender, return the key\n if (keyPeerId.equals(from)) return keyPeerId.pubKey\n // We couldn't validate pubkey is from the originator, error\n throw new Error('Public Key does not match the originator')\n } else if (from.pubKey) {\n return from.pubKey\n } else {\n throw new Error('Could not get the public key from the originator id')\n }\n}\n\n/**\n * @typedef {import('..').InMessage} InMessage\n * @typedef {import('libp2p-crypto').PublicKey} PublicKey\n */\n\nmodule.exports = {\n messagePublicKey,\n signMessage,\n SignPrefix,\n verifySignature\n}\n","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MessageCache = void 0;\nconst utils_1 = require(\"./utils\");\nclass MessageCache {\n /**\n * @param {Number} gossip\n * @param {Number} history\n * @param {msgIdFn} msgIdFn a function that returns message id from a message\n *\n * @constructor\n */\n constructor(gossip, history, msgIdFn) {\n /**\n * @type {Map<string, RPC.Message>}\n */\n this.msgs = new Map();\n this.peertx = new Map();\n /**\n * @type {Array<Array<CacheEntry>>}\n */\n this.history = [];\n for (let i = 0; i < history; i++) {\n this.history[i] = [];\n }\n /**\n * @type {Number}\n */\n this.gossip = gossip;\n /**\n * @type {Function}\n */\n this.msgIdFn = msgIdFn;\n }\n /**\n * Adds a message to the current window and the cache\n *\n * @param {RPC.Message} msg\n * @returns {Promise<void>}\n */\n put(msg) {\n return __awaiter(this, void 0, void 0, function* () {\n const msgID = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgID);\n this.msgs.set(msgIdStr, msg);\n this.history[0].push({ msgID, topics: msg.topicIDs });\n });\n }\n /**\n * Get message id of message.\n * @param {RPC.Message} msg\n * @returns {Promise<Uint8Array> | Uint8Array}\n */\n getMsgId(msg) {\n return this.msgIdFn(msg);\n }\n /**\n * Retrieves a message from the cache by its ID, if it is still present\n *\n * @param {Uint8Array} msgID\n * @returns {Message}\n */\n get(msgID) {\n return this.msgs.get(utils_1.messageIdToString(msgID));\n }\n /**\n * Retrieves a message from the cache by its ID, if it is present\n * for a specific peer.\n * Returns the message and the number of times the peer has requested the message\n *\n * @param {string} msgID\n * @param {string} p\n * @returns {[InMessage | undefined, number]}\n */\n getForPeer(msgID, p) {\n const msgIdStr = utils_1.messageIdToString(msgID);\n const msg = this.msgs.get(msgIdStr);\n if (!msg) {\n return [undefined, 0];\n }\n let peertx = this.peertx.get(msgIdStr);\n if (!peertx) {\n peertx = new Map();\n this.peertx.set(msgIdStr, peertx);\n }\n const count = (peertx.get(p) || 0) + 1;\n peertx.set(p, count);\n return [msg, count];\n }\n /**\n * Retrieves a list of message IDs for a given topic\n *\n * @param {String} topic\n *\n * @returns {Array<Uint8Array>}\n */\n getGossipIDs(topic) {\n const msgIDs = [];\n for (let i = 0; i < this.gossip; i++) {\n this.history[i].forEach((entry) => {\n for (const t of entry.topics) {\n if (t === topic) {\n msgIDs.push(entry.msgID);\n break;\n }\n }\n });\n }\n return msgIDs;\n }\n /**\n * Shifts the current window, discarding messages older than this.history.length of the cache\n *\n * @returns {void}\n */\n shift() {\n const last = this.history[this.history.length - 1];\n last.forEach((entry) => {\n const msgIdStr = utils_1.messageIdToString(entry.msgID);\n this.msgs.delete(msgIdStr);\n this.peertx.delete(msgIdStr);\n });\n this.history.pop();\n this.history.unshift([]);\n }\n}\nexports.MessageCache = MessageCache;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__exportStar(require(\"./create-gossip-rpc\"), exports);\n__exportStar(require(\"./shuffle\"), exports);\n__exportStar(require(\"./has-gossip-protocol\"), exports);\n__exportStar(require(\"./messageIdToString\"), exports);\n","'use strict';\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.createGossipRpc = void 0;\n/**\n * Create a gossipsub RPC object\n * @param {Array<RPC.IMessage>} msgs\n * @param {Partial<RPC.IControlMessage>} control\n * @returns {IRPC}\n */\nfunction createGossipRpc(msgs = [], control = {}) {\n return {\n subscriptions: [],\n msgs: msgs,\n control: Object.assign({ ihave: [], iwant: [], graft: [], prune: [] }, control)\n };\n}\nexports.createGossipRpc = createGossipRpc;\n","'use strict';\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.shuffle = void 0;\n/**\n * Pseudo-randomly shuffles an array\n *\n * Mutates the input array\n *\n * @param {Array} arr\n * @returns {Array}\n */\nfunction shuffle(arr) {\n if (arr.length <= 1) {\n return arr;\n }\n const randInt = () => {\n return Math.floor(Math.random() * Math.floor(arr.length));\n };\n for (let i = 0; i < arr.length; i++) {\n const j = randInt();\n const tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n }\n return arr;\n}\nexports.shuffle = shuffle;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.hasGossipProtocol = void 0;\nconst constants_1 = require(\"../constants\");\nfunction hasGossipProtocol(protocol) {\n return (protocol === constants_1.GossipsubIDv10 || protocol === constants_1.GossipsubIDv11);\n}\nexports.hasGossipProtocol = hasGossipProtocol;\n","'use strict';\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ERR_TOPIC_VALIDATOR_IGNORE = exports.ERR_TOPIC_VALIDATOR_REJECT = exports.TimeCacheDuration = exports.GossipsubSeenTTL = exports.GossipsubIWantFollowupTime = exports.GossipsubMaxIHaveMessages = exports.GossipsubMaxIHaveLength = exports.GossipsubGraftFloodThreshold = exports.GossipsubOpportunisticGraftPeers = exports.GossipsubOpportunisticGraftTicks = exports.GossipsubDirectConnectInitialDelay = exports.GossipsubDirectConnectTicks = exports.GossipsubConnectionTimeout = exports.GossipsubMaxPendingConnections = exports.GossipsubConnectors = exports.GossipsubPruneBackoffTicks = exports.GossipsubPruneBackoff = exports.GossipsubPrunePeers = exports.GossipsubFanoutTTL = exports.GossipsubHeartbeatInterval = exports.GossipsubHeartbeatInitialDelay = exports.GossipsubGossipRetransmission = exports.GossipsubGossipFactor = exports.GossipsubDlazy = exports.GossipsubHistoryGossip = exports.GossipsubHistoryLength = exports.GossipsubDout = exports.GossipsubDscore = exports.GossipsubDhi = exports.GossipsubDlo = exports.GossipsubD = exports.GossipsubIDv11 = exports.GossipsubIDv10 = exports.FloodsubID = exports.minute = exports.second = void 0;\nexports.second = 1000;\nexports.minute = 60 * exports.second;\n// Protocol identifiers\nexports.FloodsubID = '/floodsub/1.0.0';\n/**\n * The protocol ID for version 1.0.0 of the Gossipsub protocol\n * It is advertised along with GossipsubIDv11 for backwards compatability\n */\nexports.GossipsubIDv10 = '/meshsub/1.0.0';\n/**\n * The protocol ID for version 1.1.0 of the Gossipsub protocol\n * See the spec for details about how v1.1.0 compares to v1.0.0:\n * https://github.com/libp2p/specs/blob/master/pubsub/gossipsub/gossipsub-v1.1.md\n */\nexports.GossipsubIDv11 = '/meshsub/1.1.0';\n// Overlay parameters\n/**\n * GossipsubD sets the optimal degree for a Gossipsub topic mesh. For example, if GossipsubD == 6,\n * each peer will want to have about six peers in their mesh for each topic they're subscribed to.\n * GossipsubD should be set somewhere between GossipsubDlo and GossipsubDhi.\n */\nexports.GossipsubD = 6;\n/**\n * GossipsubDlo sets the lower bound on the number of peers we keep in a Gossipsub topic mesh.\n * If we have fewer than GossipsubDlo peers, we will attempt to graft some more into the mesh at\n * the next heartbeat.\n */\nexports.GossipsubDlo = 4;\n/**\n * GossipsubDhi sets the upper bound on the number of peers we keep in a Gossipsub topic mesh.\n * If we have more than GossipsubDhi peers, we will select some to prune from the mesh at the next heartbeat.\n */\nexports.GossipsubDhi = 12;\n/**\n * GossipsubDscore affects how peers are selected when pruning a mesh due to over subscription.\n * At least GossipsubDscore of the retained peers will be high-scoring, while the remainder are\n * chosen randomly.\n */\nexports.GossipsubDscore = 4;\n/**\n * GossipsubDout sets the quota for the number of outbound connections to maintain in a topic mesh.\n * When the mesh is pruned due to over subscription, we make sure that we have outbound connections\n * to at least GossipsubDout of the survivor peers. This prevents sybil attackers from overwhelming\n * our mesh with incoming connections.\n *\n * GossipsubDout must be set below GossipsubDlo, and must not exceed GossipsubD / 2.\n */\nexports.GossipsubDout = 2;\n// Gossip parameters\n/**\n * GossipsubHistoryLength controls the size of the message cache used for gossip.\n * The message cache will remember messages for GossipsubHistoryLength heartbeats.\n */\nexports.GossipsubHistoryLength = 5;\n/**\n * GossipsubHistoryGossip controls how many cached message ids we will advertise in\n * IHAVE gossip messages. When asked for our seen message IDs, we will return\n * only those from the most recent GossipsubHistoryGossip heartbeats. The slack between\n * GossipsubHistoryGossip and GossipsubHistoryLength allows us to avoid advertising messages\n * that will be expired by the time they're requested.\n *\n * GossipsubHistoryGossip must be less than or equal to GossipsubHistoryLength to\n * avoid a runtime panic.\n */\nexports.GossipsubHistoryGossip = 3;\n/**\n * GossipsubDlazy affects how many peers we will emit gossip to at each heartbeat.\n * We will send gossip to at least GossipsubDlazy peers outside our mesh. The actual\n * number may be more, depending on GossipsubGossipFactor and how many peers we're\n * connected to.\n */\nexports.GossipsubDlazy = 6;\n/**\n * GossipsubGossipFactor affects how many peers we will emit gossip to at each heartbeat.\n * We will send gossip to GossipsubGossipFactor * (total number of non-mesh peers), or\n * GossipsubDlazy, whichever is greater.\n */\nexports.GossipsubGossipFactor = 0.25;\n/**\n * GossipsubGossipRetransmission controls how many times we will allow a peer to request\n * the same message id through IWANT gossip before we start ignoring them. This is designed\n * to prevent peers from spamming us with requests and wasting our resources.\n */\nexports.GossipsubGossipRetransmission = 3;\n// Heartbeat interval\n/**\n * GossipsubHeartbeatInitialDelay is the short delay before the heartbeat timer begins\n * after the router is initialized.\n */\nexports.GossipsubHeartbeatInitialDelay = 100;\n/**\n * GossipsubHeartbeatInterval controls the time between heartbeats.\n */\nexports.GossipsubHeartbeatInterval = exports.second;\n/**\n * GossipsubFanoutTTL controls how long we keep track of the fanout state. If it's been\n * GossipsubFanoutTTL since we've published to a topic that we're not subscribed to,\n * we'll delete the fanout map for that topic.\n */\nexports.GossipsubFanoutTTL = exports.minute;\n/**\n * GossipsubPrunePeers controls the number of peers to include in prune Peer eXchange.\n * When we prune a peer that's eligible for PX (has a good score, etc), we will try to\n * send them signed peer records for up to GossipsubPrunePeers other peers that we\n * know of.\n */\nexports.GossipsubPrunePeers = 16;\n/**\n * GossipsubPruneBackoff controls the backoff time for pruned peers. This is how long\n * a peer must wait before attempting to graft into our mesh again after being pruned.\n * When pruning a peer, we send them our value of GossipsubPruneBackoff so they know\n * the minimum time to wait. Peers running older versions may not send a backoff time,\n * so if we receive a prune message without one, we will wait at least GossipsubPruneBackoff\n * before attempting to re-graft.\n */\nexports.GossipsubPruneBackoff = exports.minute;\n/**\n * GossipsubPruneBackoffTicks is the number of heartbeat ticks for attempting to prune expired\n * backoff timers.\n */\nexports.GossipsubPruneBackoffTicks = 15;\n/**\n * GossipsubConnectors controls the number of active connection attempts for peers obtained through PX.\n */\nexports.GossipsubConnectors = 8;\n/**\n * GossipsubMaxPendingConnections sets the maximum number of pending connections for peers attempted through px.\n */\nexports.GossipsubMaxPendingConnections = 128;\n/**\n * GossipsubConnectionTimeout controls the timeout for connection attempts.\n */\nexports.GossipsubConnectionTimeout = 30 * exports.second;\n/**\n * GossipsubDirectConnectTicks is the number of heartbeat ticks for attempting to reconnect direct peers\n * that are not currently connected.\n */\nexports.GossipsubDirectConnectTicks = 300;\n/**\n * GossipsubDirectConnectInitialDelay is the initial delay before opening connections to direct peers\n */\nexports.GossipsubDirectConnectInitialDelay = exports.second;\n/**\n * GossipsubOpportunisticGraftTicks is the number of heartbeat ticks for attempting to improve the mesh\n * with opportunistic grafting. Every GossipsubOpportunisticGraftTicks we will attempt to select some\n * high-scoring mesh peers to replace lower-scoring ones, if the median score of our mesh peers falls\n * below a threshold\n */\nexports.GossipsubOpportunisticGraftTicks = 60;\n/**\n * GossipsubOpportunisticGraftPeers is the number of peers to opportunistically graft.\n */\nexports.GossipsubOpportunisticGraftPeers = 2;\n/**\n * If a GRAFT comes before GossipsubGraftFloodThreshold has elapsed since the last PRUNE,\n * then there is an extra score penalty applied to the peer through P7.\n */\nexports.GossipsubGraftFloodThreshold = 10 * exports.second;\n/**\n * GossipsubMaxIHaveLength is the maximum number of messages to include in an IHAVE message.\n * Also controls the maximum number of IHAVE ids we will accept and request with IWANT from a\n * peer within a heartbeat, to protect from IHAVE floods. You should adjust this value from the\n * default if your system is pushing more than 5000 messages in GossipsubHistoryGossip heartbeats;\n * with the defaults this is 1666 messages/s.\n */\nexports.GossipsubMaxIHaveLength = 5000;\n/**\n * GossipsubMaxIHaveMessages is the maximum number of IHAVE messages to accept from a peer within a heartbeat.\n */\nexports.GossipsubMaxIHaveMessages = 10;\n/**\n * Time to wait for a message requested through IWANT following an IHAVE advertisement.\n * If the message is not received within this window, a broken promise is declared and\n * the router may apply bahavioural penalties.\n */\nexports.GossipsubIWantFollowupTime = 3 * exports.second;\n/**\n * Time in milliseconds to keep message ids in the seen cache\n */\nexports.GossipsubSeenTTL = 30 * exports.second;\nexports.TimeCacheDuration = 120 * 1000;\nexports.ERR_TOPIC_VALIDATOR_REJECT = 'ERR_TOPIC_VALIDATOR_REJECT';\nexports.ERR_TOPIC_VALIDATOR_IGNORE = 'ERR_TOPIC_VALIDATOR_IGNORE';\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.messageIdToString = void 0;\nconst to_string_1 = require(\"uint8arrays/to-string\");\nfunction messageIdToString(msgId) {\n return to_string_1.toString(msgId, 'base64');\n}\nexports.messageIdToString = messageIdToString;\n","/*eslint-disable*/\n(function(global, factory) { /* global define, require, module */\n\n /* AMD */ if (typeof define === 'function' && define.amd)\n define([\"protobufjs/minimal\"], factory);\n\n /* CommonJS */ else if (typeof require === 'function' && typeof module === 'object' && module && module.exports)\n module.exports = factory(require(\"protobufjs/minimal\"));\n\n})(this, function($protobuf) {\n \"use strict\";\n\n // Common aliases\n var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n \n // Exported root namespace\n var $root = $protobuf.roots[\"default\"] || ($protobuf.roots[\"default\"] = {});\n \n $root.RPC = (function() {\n \n /**\n * Properties of a RPC.\n * @exports IRPC\n * @interface IRPC\n * @property {Array.<RPC.ISubOpts>|null} [subscriptions] RPC subscriptions\n * @property {Array.<RPC.IMessage>|null} [msgs] RPC msgs\n * @property {RPC.IControlMessage|null} [control] RPC control\n */\n \n /**\n * Constructs a new RPC.\n * @exports RPC\n * @classdesc Represents a RPC.\n * @implements IRPC\n * @constructor\n * @param {IRPC=} [p] Properties to set\n */\n function RPC(p) {\n this.subscriptions = [];\n this.msgs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * RPC subscriptions.\n * @member {Array.<RPC.ISubOpts>} subscriptions\n * @memberof RPC\n * @instance\n */\n RPC.prototype.subscriptions = $util.emptyArray;\n \n /**\n * RPC msgs.\n * @member {Array.<RPC.IMessage>} msgs\n * @memberof RPC\n * @instance\n */\n RPC.prototype.msgs = $util.emptyArray;\n \n /**\n * RPC control.\n * @member {RPC.IControlMessage|null|undefined} control\n * @memberof RPC\n * @instance\n */\n RPC.prototype.control = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * RPC _control.\n * @member {\"control\"|undefined} _control\n * @memberof RPC\n * @instance\n */\n Object.defineProperty(RPC.prototype, \"_control\", {\n get: $util.oneOfGetter($oneOfFields = [\"control\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified RPC message. Does not implicitly {@link RPC.verify|verify} messages.\n * @function encode\n * @memberof RPC\n * @static\n * @param {IRPC} m RPC message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n RPC.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.subscriptions != null && m.subscriptions.length) {\n for (var i = 0; i < m.subscriptions.length; ++i)\n $root.RPC.SubOpts.encode(m.subscriptions[i], w.uint32(10).fork()).ldelim();\n }\n if (m.msgs != null && m.msgs.length) {\n for (var i = 0; i < m.msgs.length; ++i)\n $root.RPC.Message.encode(m.msgs[i], w.uint32(18).fork()).ldelim();\n }\n if (m.control != null && Object.hasOwnProperty.call(m, \"control\"))\n $root.RPC.ControlMessage.encode(m.control, w.uint32(26).fork()).ldelim();\n return w;\n };\n \n /**\n * Decodes a RPC message from the specified reader or buffer.\n * @function decode\n * @memberof RPC\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC} RPC\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n RPC.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.subscriptions && m.subscriptions.length))\n m.subscriptions = [];\n m.subscriptions.push($root.RPC.SubOpts.decode(r, r.uint32()));\n break;\n case 2:\n if (!(m.msgs && m.msgs.length))\n m.msgs = [];\n m.msgs.push($root.RPC.Message.decode(r, r.uint32()));\n break;\n case 3:\n m.control = $root.RPC.ControlMessage.decode(r, r.uint32());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a RPC message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC} RPC\n */\n RPC.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC)\n return d;\n var m = new $root.RPC();\n if (d.subscriptions) {\n if (!Array.isArray(d.subscriptions))\n throw TypeError(\".RPC.subscriptions: array expected\");\n m.subscriptions = [];\n for (var i = 0; i < d.subscriptions.length; ++i) {\n if (typeof d.subscriptions[i] !== \"object\")\n throw TypeError(\".RPC.subscriptions: object expected\");\n m.subscriptions[i] = $root.RPC.SubOpts.fromObject(d.subscriptions[i]);\n }\n }\n if (d.msgs) {\n if (!Array.isArray(d.msgs))\n throw TypeError(\".RPC.msgs: array expected\");\n m.msgs = [];\n for (var i = 0; i < d.msgs.length; ++i) {\n if (typeof d.msgs[i] !== \"object\")\n throw TypeError(\".RPC.msgs: object expected\");\n m.msgs[i] = $root.RPC.Message.fromObject(d.msgs[i]);\n }\n }\n if (d.control != null) {\n if (typeof d.control !== \"object\")\n throw TypeError(\".RPC.control: object expected\");\n m.control = $root.RPC.ControlMessage.fromObject(d.control);\n }\n return m;\n };\n \n /**\n * Creates a plain object from a RPC message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC\n * @static\n * @param {RPC} m RPC\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n RPC.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.subscriptions = [];\n d.msgs = [];\n }\n if (m.subscriptions && m.subscriptions.length) {\n d.subscriptions = [];\n for (var j = 0; j < m.subscriptions.length; ++j) {\n d.subscriptions[j] = $root.RPC.SubOpts.toObject(m.subscriptions[j], o);\n }\n }\n if (m.msgs && m.msgs.length) {\n d.msgs = [];\n for (var j = 0; j < m.msgs.length; ++j) {\n d.msgs[j] = $root.RPC.Message.toObject(m.msgs[j], o);\n }\n }\n if (m.control != null && m.hasOwnProperty(\"control\")) {\n d.control = $root.RPC.ControlMessage.toObject(m.control, o);\n if (o.oneofs)\n d._control = \"control\";\n }\n return d;\n };\n \n /**\n * Converts this RPC to JSON.\n * @function toJSON\n * @memberof RPC\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n RPC.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n RPC.SubOpts = (function() {\n \n /**\n * Properties of a SubOpts.\n * @memberof RPC\n * @interface ISubOpts\n * @property {boolean|null} [subscribe] SubOpts subscribe\n * @property {string|null} [topicID] SubOpts topicID\n */\n \n /**\n * Constructs a new SubOpts.\n * @memberof RPC\n * @classdesc Represents a SubOpts.\n * @implements ISubOpts\n * @constructor\n * @param {RPC.ISubOpts=} [p] Properties to set\n */\n function SubOpts(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * SubOpts subscribe.\n * @member {boolean|null|undefined} subscribe\n * @memberof RPC.SubOpts\n * @instance\n */\n SubOpts.prototype.subscribe = null;\n \n /**\n * SubOpts topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.SubOpts\n * @instance\n */\n SubOpts.prototype.topicID = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * SubOpts _subscribe.\n * @member {\"subscribe\"|undefined} _subscribe\n * @memberof RPC.SubOpts\n * @instance\n */\n Object.defineProperty(SubOpts.prototype, \"_subscribe\", {\n get: $util.oneOfGetter($oneOfFields = [\"subscribe\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * SubOpts _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.SubOpts\n * @instance\n */\n Object.defineProperty(SubOpts.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified SubOpts message. Does not implicitly {@link RPC.SubOpts.verify|verify} messages.\n * @function encode\n * @memberof RPC.SubOpts\n * @static\n * @param {RPC.ISubOpts} m SubOpts message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n SubOpts.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.subscribe != null && Object.hasOwnProperty.call(m, \"subscribe\"))\n w.uint32(8).bool(m.subscribe);\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(18).string(m.topicID);\n return w;\n };\n \n /**\n * Decodes a SubOpts message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.SubOpts\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.SubOpts} SubOpts\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n SubOpts.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.SubOpts();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.subscribe = r.bool();\n break;\n case 2:\n m.topicID = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a SubOpts message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.SubOpts\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.SubOpts} SubOpts\n */\n SubOpts.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.SubOpts)\n return d;\n var m = new $root.RPC.SubOpts();\n if (d.subscribe != null) {\n m.subscribe = Boolean(d.subscribe);\n }\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n return m;\n };\n \n /**\n * Creates a plain object from a SubOpts message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.SubOpts\n * @static\n * @param {RPC.SubOpts} m SubOpts\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n SubOpts.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.subscribe != null && m.hasOwnProperty(\"subscribe\")) {\n d.subscribe = m.subscribe;\n if (o.oneofs)\n d._subscribe = \"subscribe\";\n }\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n return d;\n };\n \n /**\n * Converts this SubOpts to JSON.\n * @function toJSON\n * @memberof RPC.SubOpts\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n SubOpts.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return SubOpts;\n })();\n \n RPC.Message = (function() {\n \n /**\n * Properties of a Message.\n * @memberof RPC\n * @interface IMessage\n * @property {Uint8Array|null} [from] Message from\n * @property {Uint8Array|null} [data] Message data\n * @property {Uint8Array|null} [seqno] Message seqno\n * @property {Array.<string>|null} [topicIDs] Message topicIDs\n * @property {Uint8Array|null} [signature] Message signature\n * @property {Uint8Array|null} [key] Message key\n */\n \n /**\n * Constructs a new Message.\n * @memberof RPC\n * @classdesc Represents a Message.\n * @implements IMessage\n * @constructor\n * @param {RPC.IMessage=} [p] Properties to set\n */\n function Message(p) {\n this.topicIDs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * Message from.\n * @member {Uint8Array|null|undefined} from\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.from = null;\n \n /**\n * Message data.\n * @member {Uint8Array|null|undefined} data\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.data = null;\n \n /**\n * Message seqno.\n * @member {Uint8Array|null|undefined} seqno\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.seqno = null;\n \n /**\n * Message topicIDs.\n * @member {Array.<string>} topicIDs\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.topicIDs = $util.emptyArray;\n \n /**\n * Message signature.\n * @member {Uint8Array|null|undefined} signature\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.signature = null;\n \n /**\n * Message key.\n * @member {Uint8Array|null|undefined} key\n * @memberof RPC.Message\n * @instance\n */\n Message.prototype.key = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * Message _from.\n * @member {\"from\"|undefined} _from\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_from\", {\n get: $util.oneOfGetter($oneOfFields = [\"from\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Message _data.\n * @member {\"data\"|undefined} _data\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_data\", {\n get: $util.oneOfGetter($oneOfFields = [\"data\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Message _seqno.\n * @member {\"seqno\"|undefined} _seqno\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_seqno\", {\n get: $util.oneOfGetter($oneOfFields = [\"seqno\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Message _signature.\n * @member {\"signature\"|undefined} _signature\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_signature\", {\n get: $util.oneOfGetter($oneOfFields = [\"signature\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Message _key.\n * @member {\"key\"|undefined} _key\n * @memberof RPC.Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_key\", {\n get: $util.oneOfGetter($oneOfFields = [\"key\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified Message message. Does not implicitly {@link RPC.Message.verify|verify} messages.\n * @function encode\n * @memberof RPC.Message\n * @static\n * @param {RPC.IMessage} m Message message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Message.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.from != null && Object.hasOwnProperty.call(m, \"from\"))\n w.uint32(10).bytes(m.from);\n if (m.data != null && Object.hasOwnProperty.call(m, \"data\"))\n w.uint32(18).bytes(m.data);\n if (m.seqno != null && Object.hasOwnProperty.call(m, \"seqno\"))\n w.uint32(26).bytes(m.seqno);\n if (m.topicIDs != null && m.topicIDs.length) {\n for (var i = 0; i < m.topicIDs.length; ++i)\n w.uint32(34).string(m.topicIDs[i]);\n }\n if (m.signature != null && Object.hasOwnProperty.call(m, \"signature\"))\n w.uint32(42).bytes(m.signature);\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(50).bytes(m.key);\n return w;\n };\n \n /**\n * Decodes a Message message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.Message\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.Message} Message\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Message.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.Message();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.from = r.bytes();\n break;\n case 2:\n m.data = r.bytes();\n break;\n case 3:\n m.seqno = r.bytes();\n break;\n case 4:\n if (!(m.topicIDs && m.topicIDs.length))\n m.topicIDs = [];\n m.topicIDs.push(r.string());\n break;\n case 5:\n m.signature = r.bytes();\n break;\n case 6:\n m.key = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a Message message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.Message\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.Message} Message\n */\n Message.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.Message)\n return d;\n var m = new $root.RPC.Message();\n if (d.from != null) {\n if (typeof d.from === \"string\")\n $util.base64.decode(d.from, m.from = $util.newBuffer($util.base64.length(d.from)), 0);\n else if (d.from.length)\n m.from = d.from;\n }\n if (d.data != null) {\n if (typeof d.data === \"string\")\n $util.base64.decode(d.data, m.data = $util.newBuffer($util.base64.length(d.data)), 0);\n else if (d.data.length)\n m.data = d.data;\n }\n if (d.seqno != null) {\n if (typeof d.seqno === \"string\")\n $util.base64.decode(d.seqno, m.seqno = $util.newBuffer($util.base64.length(d.seqno)), 0);\n else if (d.seqno.length)\n m.seqno = d.seqno;\n }\n if (d.topicIDs) {\n if (!Array.isArray(d.topicIDs))\n throw TypeError(\".RPC.Message.topicIDs: array expected\");\n m.topicIDs = [];\n for (var i = 0; i < d.topicIDs.length; ++i) {\n m.topicIDs[i] = String(d.topicIDs[i]);\n }\n }\n if (d.signature != null) {\n if (typeof d.signature === \"string\")\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n return m;\n };\n \n /**\n * Creates a plain object from a Message message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.Message\n * @static\n * @param {RPC.Message} m Message\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Message.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.topicIDs = [];\n }\n if (m.from != null && m.hasOwnProperty(\"from\")) {\n d.from = o.bytes === String ? $util.base64.encode(m.from, 0, m.from.length) : o.bytes === Array ? Array.prototype.slice.call(m.from) : m.from;\n if (o.oneofs)\n d._from = \"from\";\n }\n if (m.data != null && m.hasOwnProperty(\"data\")) {\n d.data = o.bytes === String ? $util.base64.encode(m.data, 0, m.data.length) : o.bytes === Array ? Array.prototype.slice.call(m.data) : m.data;\n if (o.oneofs)\n d._data = \"data\";\n }\n if (m.seqno != null && m.hasOwnProperty(\"seqno\")) {\n d.seqno = o.bytes === String ? $util.base64.encode(m.seqno, 0, m.seqno.length) : o.bytes === Array ? Array.prototype.slice.call(m.seqno) : m.seqno;\n if (o.oneofs)\n d._seqno = \"seqno\";\n }\n if (m.topicIDs && m.topicIDs.length) {\n d.topicIDs = [];\n for (var j = 0; j < m.topicIDs.length; ++j) {\n d.topicIDs[j] = m.topicIDs[j];\n }\n }\n if (m.signature != null && m.hasOwnProperty(\"signature\")) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n if (o.oneofs)\n d._signature = \"signature\";\n }\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n if (o.oneofs)\n d._key = \"key\";\n }\n return d;\n };\n \n /**\n * Converts this Message to JSON.\n * @function toJSON\n * @memberof RPC.Message\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Message.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return Message;\n })();\n \n RPC.ControlMessage = (function() {\n \n /**\n * Properties of a ControlMessage.\n * @memberof RPC\n * @interface IControlMessage\n * @property {Array.<RPC.IControlIHave>|null} [ihave] ControlMessage ihave\n * @property {Array.<RPC.IControlIWant>|null} [iwant] ControlMessage iwant\n * @property {Array.<RPC.IControlGraft>|null} [graft] ControlMessage graft\n * @property {Array.<RPC.IControlPrune>|null} [prune] ControlMessage prune\n */\n \n /**\n * Constructs a new ControlMessage.\n * @memberof RPC\n * @classdesc Represents a ControlMessage.\n * @implements IControlMessage\n * @constructor\n * @param {RPC.IControlMessage=} [p] Properties to set\n */\n function ControlMessage(p) {\n this.ihave = [];\n this.iwant = [];\n this.graft = [];\n this.prune = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlMessage ihave.\n * @member {Array.<RPC.IControlIHave>} ihave\n * @memberof RPC.ControlMessage\n * @instance\n */\n ControlMessage.prototype.ihave = $util.emptyArray;\n \n /**\n * ControlMessage iwant.\n * @member {Array.<RPC.IControlIWant>} iwant\n * @memberof RPC.ControlMessage\n * @instance\n */\n ControlMessage.prototype.iwant = $util.emptyArray;\n \n /**\n * ControlMessage graft.\n * @member {Array.<RPC.IControlGraft>} graft\n * @memberof RPC.ControlMessage\n * @instance\n */\n ControlMessage.prototype.graft = $util.emptyArray;\n \n /**\n * ControlMessage prune.\n * @member {Array.<RPC.IControlPrune>} prune\n * @memberof RPC.ControlMessage\n * @instance\n */\n ControlMessage.prototype.prune = $util.emptyArray;\n \n /**\n * Encodes the specified ControlMessage message. Does not implicitly {@link RPC.ControlMessage.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlMessage\n * @static\n * @param {RPC.IControlMessage} m ControlMessage message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlMessage.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.ihave != null && m.ihave.length) {\n for (var i = 0; i < m.ihave.length; ++i)\n $root.RPC.ControlIHave.encode(m.ihave[i], w.uint32(10).fork()).ldelim();\n }\n if (m.iwant != null && m.iwant.length) {\n for (var i = 0; i < m.iwant.length; ++i)\n $root.RPC.ControlIWant.encode(m.iwant[i], w.uint32(18).fork()).ldelim();\n }\n if (m.graft != null && m.graft.length) {\n for (var i = 0; i < m.graft.length; ++i)\n $root.RPC.ControlGraft.encode(m.graft[i], w.uint32(26).fork()).ldelim();\n }\n if (m.prune != null && m.prune.length) {\n for (var i = 0; i < m.prune.length; ++i)\n $root.RPC.ControlPrune.encode(m.prune[i], w.uint32(34).fork()).ldelim();\n }\n return w;\n };\n \n /**\n * Decodes a ControlMessage message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlMessage\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlMessage} ControlMessage\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlMessage.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlMessage();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.ihave && m.ihave.length))\n m.ihave = [];\n m.ihave.push($root.RPC.ControlIHave.decode(r, r.uint32()));\n break;\n case 2:\n if (!(m.iwant && m.iwant.length))\n m.iwant = [];\n m.iwant.push($root.RPC.ControlIWant.decode(r, r.uint32()));\n break;\n case 3:\n if (!(m.graft && m.graft.length))\n m.graft = [];\n m.graft.push($root.RPC.ControlGraft.decode(r, r.uint32()));\n break;\n case 4:\n if (!(m.prune && m.prune.length))\n m.prune = [];\n m.prune.push($root.RPC.ControlPrune.decode(r, r.uint32()));\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlMessage message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlMessage\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.ControlMessage} ControlMessage\n */\n ControlMessage.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlMessage)\n return d;\n var m = new $root.RPC.ControlMessage();\n if (d.ihave) {\n if (!Array.isArray(d.ihave))\n throw TypeError(\".RPC.ControlMessage.ihave: array expected\");\n m.ihave = [];\n for (var i = 0; i < d.ihave.length; ++i) {\n if (typeof d.ihave[i] !== \"object\")\n throw TypeError(\".RPC.ControlMessage.ihave: object expected\");\n m.ihave[i] = $root.RPC.ControlIHave.fromObject(d.ihave[i]);\n }\n }\n if (d.iwant) {\n if (!Array.isArray(d.iwant))\n throw TypeError(\".RPC.ControlMessage.iwant: array expected\");\n m.iwant = [];\n for (var i = 0; i < d.iwant.length; ++i) {\n if (typeof d.iwant[i] !== \"object\")\n throw TypeError(\".RPC.ControlMessage.iwant: object expected\");\n m.iwant[i] = $root.RPC.ControlIWant.fromObject(d.iwant[i]);\n }\n }\n if (d.graft) {\n if (!Array.isArray(d.graft))\n throw TypeError(\".RPC.ControlMessage.graft: array expected\");\n m.graft = [];\n for (var i = 0; i < d.graft.length; ++i) {\n if (typeof d.graft[i] !== \"object\")\n throw TypeError(\".RPC.ControlMessage.graft: object expected\");\n m.graft[i] = $root.RPC.ControlGraft.fromObject(d.graft[i]);\n }\n }\n if (d.prune) {\n if (!Array.isArray(d.prune))\n throw TypeError(\".RPC.ControlMessage.prune: array expected\");\n m.prune = [];\n for (var i = 0; i < d.prune.length; ++i) {\n if (typeof d.prune[i] !== \"object\")\n throw TypeError(\".RPC.ControlMessage.prune: object expected\");\n m.prune[i] = $root.RPC.ControlPrune.fromObject(d.prune[i]);\n }\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlMessage message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlMessage\n * @static\n * @param {RPC.ControlMessage} m ControlMessage\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n ControlMessage.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.ihave = [];\n d.iwant = [];\n d.graft = [];\n d.prune = [];\n }\n if (m.ihave && m.ihave.length) {\n d.ihave = [];\n for (var j = 0; j < m.ihave.length; ++j) {\n d.ihave[j] = $root.RPC.ControlIHave.toObject(m.ihave[j], o);\n }\n }\n if (m.iwant && m.iwant.length) {\n d.iwant = [];\n for (var j = 0; j < m.iwant.length; ++j) {\n d.iwant[j] = $root.RPC.ControlIWant.toObject(m.iwant[j], o);\n }\n }\n if (m.graft && m.graft.length) {\n d.graft = [];\n for (var j = 0; j < m.graft.length; ++j) {\n d.graft[j] = $root.RPC.ControlGraft.toObject(m.graft[j], o);\n }\n }\n if (m.prune && m.prune.length) {\n d.prune = [];\n for (var j = 0; j < m.prune.length; ++j) {\n d.prune[j] = $root.RPC.ControlPrune.toObject(m.prune[j], o);\n }\n }\n return d;\n };\n \n /**\n * Converts this ControlMessage to JSON.\n * @function toJSON\n * @memberof RPC.ControlMessage\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n ControlMessage.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlMessage;\n })();\n \n RPC.ControlIHave = (function() {\n \n /**\n * Properties of a ControlIHave.\n * @memberof RPC\n * @interface IControlIHave\n * @property {string|null} [topicID] ControlIHave topicID\n * @property {Array.<Uint8Array>|null} [messageIDs] ControlIHave messageIDs\n */\n \n /**\n * Constructs a new ControlIHave.\n * @memberof RPC\n * @classdesc Represents a ControlIHave.\n * @implements IControlIHave\n * @constructor\n * @param {RPC.IControlIHave=} [p] Properties to set\n */\n function ControlIHave(p) {\n this.messageIDs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlIHave topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.ControlIHave\n * @instance\n */\n ControlIHave.prototype.topicID = null;\n \n /**\n * ControlIHave messageIDs.\n * @member {Array.<Uint8Array>} messageIDs\n * @memberof RPC.ControlIHave\n * @instance\n */\n ControlIHave.prototype.messageIDs = $util.emptyArray;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * ControlIHave _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.ControlIHave\n * @instance\n */\n Object.defineProperty(ControlIHave.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified ControlIHave message. Does not implicitly {@link RPC.ControlIHave.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlIHave\n * @static\n * @param {RPC.IControlIHave} m ControlIHave message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlIHave.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(10).string(m.topicID);\n if (m.messageIDs != null && m.messageIDs.length) {\n for (var i = 0; i < m.messageIDs.length; ++i)\n w.uint32(18).bytes(m.messageIDs[i]);\n }\n return w;\n };\n \n /**\n * Decodes a ControlIHave message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlIHave\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlIHave} ControlIHave\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlIHave.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlIHave();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.topicID = r.string();\n break;\n case 2:\n if (!(m.messageIDs && m.messageIDs.length))\n m.messageIDs = [];\n m.messageIDs.push(r.bytes());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlIHave message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlIHave\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.ControlIHave} ControlIHave\n */\n ControlIHave.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlIHave)\n return d;\n var m = new $root.RPC.ControlIHave();\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n if (d.messageIDs) {\n if (!Array.isArray(d.messageIDs))\n throw TypeError(\".RPC.ControlIHave.messageIDs: array expected\");\n m.messageIDs = [];\n for (var i = 0; i < d.messageIDs.length; ++i) {\n if (typeof d.messageIDs[i] === \"string\")\n $util.base64.decode(d.messageIDs[i], m.messageIDs[i] = $util.newBuffer($util.base64.length(d.messageIDs[i])), 0);\n else if (d.messageIDs[i].length)\n m.messageIDs[i] = d.messageIDs[i];\n }\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlIHave message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlIHave\n * @static\n * @param {RPC.ControlIHave} m ControlIHave\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n ControlIHave.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.messageIDs = [];\n }\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n if (m.messageIDs && m.messageIDs.length) {\n d.messageIDs = [];\n for (var j = 0; j < m.messageIDs.length; ++j) {\n d.messageIDs[j] = o.bytes === String ? $util.base64.encode(m.messageIDs[j], 0, m.messageIDs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.messageIDs[j]) : m.messageIDs[j];\n }\n }\n return d;\n };\n \n /**\n * Converts this ControlIHave to JSON.\n * @function toJSON\n * @memberof RPC.ControlIHave\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n ControlIHave.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlIHave;\n })();\n \n RPC.ControlIWant = (function() {\n \n /**\n * Properties of a ControlIWant.\n * @memberof RPC\n * @interface IControlIWant\n * @property {Array.<Uint8Array>|null} [messageIDs] ControlIWant messageIDs\n */\n \n /**\n * Constructs a new ControlIWant.\n * @memberof RPC\n * @classdesc Represents a ControlIWant.\n * @implements IControlIWant\n * @constructor\n * @param {RPC.IControlIWant=} [p] Properties to set\n */\n function ControlIWant(p) {\n this.messageIDs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlIWant messageIDs.\n * @member {Array.<Uint8Array>} messageIDs\n * @memberof RPC.ControlIWant\n * @instance\n */\n ControlIWant.prototype.messageIDs = $util.emptyArray;\n \n /**\n * Encodes the specified ControlIWant message. Does not implicitly {@link RPC.ControlIWant.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlIWant\n * @static\n * @param {RPC.IControlIWant} m ControlIWant message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlIWant.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.messageIDs != null && m.messageIDs.length) {\n for (var i = 0; i < m.messageIDs.length; ++i)\n w.uint32(10).bytes(m.messageIDs[i]);\n }\n return w;\n };\n \n /**\n * Decodes a ControlIWant message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlIWant\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlIWant} ControlIWant\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlIWant.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlIWant();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.messageIDs && m.messageIDs.length))\n m.messageIDs = [];\n m.messageIDs.push(r.bytes());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlIWant message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlIWant\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.ControlIWant} ControlIWant\n */\n ControlIWant.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlIWant)\n return d;\n var m = new $root.RPC.ControlIWant();\n if (d.messageIDs) {\n if (!Array.isArray(d.messageIDs))\n throw TypeError(\".RPC.ControlIWant.messageIDs: array expected\");\n m.messageIDs = [];\n for (var i = 0; i < d.messageIDs.length; ++i) {\n if (typeof d.messageIDs[i] === \"string\")\n $util.base64.decode(d.messageIDs[i], m.messageIDs[i] = $util.newBuffer($util.base64.length(d.messageIDs[i])), 0);\n else if (d.messageIDs[i].length)\n m.messageIDs[i] = d.messageIDs[i];\n }\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlIWant message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlIWant\n * @static\n * @param {RPC.ControlIWant} m ControlIWant\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n ControlIWant.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.messageIDs = [];\n }\n if (m.messageIDs && m.messageIDs.length) {\n d.messageIDs = [];\n for (var j = 0; j < m.messageIDs.length; ++j) {\n d.messageIDs[j] = o.bytes === String ? $util.base64.encode(m.messageIDs[j], 0, m.messageIDs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.messageIDs[j]) : m.messageIDs[j];\n }\n }\n return d;\n };\n \n /**\n * Converts this ControlIWant to JSON.\n * @function toJSON\n * @memberof RPC.ControlIWant\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n ControlIWant.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlIWant;\n })();\n \n RPC.ControlGraft = (function() {\n \n /**\n * Properties of a ControlGraft.\n * @memberof RPC\n * @interface IControlGraft\n * @property {string|null} [topicID] ControlGraft topicID\n */\n \n /**\n * Constructs a new ControlGraft.\n * @memberof RPC\n * @classdesc Represents a ControlGraft.\n * @implements IControlGraft\n * @constructor\n * @param {RPC.IControlGraft=} [p] Properties to set\n */\n function ControlGraft(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlGraft topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.ControlGraft\n * @instance\n */\n ControlGraft.prototype.topicID = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * ControlGraft _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.ControlGraft\n * @instance\n */\n Object.defineProperty(ControlGraft.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified ControlGraft message. Does not implicitly {@link RPC.ControlGraft.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlGraft\n * @static\n * @param {RPC.IControlGraft} m ControlGraft message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlGraft.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(10).string(m.topicID);\n return w;\n };\n \n /**\n * Decodes a ControlGraft message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlGraft\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlGraft} ControlGraft\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlGraft.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlGraft();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.topicID = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlGraft message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlGraft\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.ControlGraft} ControlGraft\n */\n ControlGraft.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlGraft)\n return d;\n var m = new $root.RPC.ControlGraft();\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlGraft message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlGraft\n * @static\n * @param {RPC.ControlGraft} m ControlGraft\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n ControlGraft.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n return d;\n };\n \n /**\n * Converts this ControlGraft to JSON.\n * @function toJSON\n * @memberof RPC.ControlGraft\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n ControlGraft.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlGraft;\n })();\n \n RPC.ControlPrune = (function() {\n \n /**\n * Properties of a ControlPrune.\n * @memberof RPC\n * @interface IControlPrune\n * @property {string|null} [topicID] ControlPrune topicID\n * @property {Array.<RPC.IPeerInfo>|null} [peers] ControlPrune peers\n * @property {number|null} [backoff] ControlPrune backoff\n */\n \n /**\n * Constructs a new ControlPrune.\n * @memberof RPC\n * @classdesc Represents a ControlPrune.\n * @implements IControlPrune\n * @constructor\n * @param {RPC.IControlPrune=} [p] Properties to set\n */\n function ControlPrune(p) {\n this.peers = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * ControlPrune topicID.\n * @member {string|null|undefined} topicID\n * @memberof RPC.ControlPrune\n * @instance\n */\n ControlPrune.prototype.topicID = null;\n \n /**\n * ControlPrune peers.\n * @member {Array.<RPC.IPeerInfo>} peers\n * @memberof RPC.ControlPrune\n * @instance\n */\n ControlPrune.prototype.peers = $util.emptyArray;\n \n /**\n * ControlPrune backoff.\n * @member {number|null|undefined} backoff\n * @memberof RPC.ControlPrune\n * @instance\n */\n ControlPrune.prototype.backoff = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * ControlPrune _topicID.\n * @member {\"topicID\"|undefined} _topicID\n * @memberof RPC.ControlPrune\n * @instance\n */\n Object.defineProperty(ControlPrune.prototype, \"_topicID\", {\n get: $util.oneOfGetter($oneOfFields = [\"topicID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * ControlPrune _backoff.\n * @member {\"backoff\"|undefined} _backoff\n * @memberof RPC.ControlPrune\n * @instance\n */\n Object.defineProperty(ControlPrune.prototype, \"_backoff\", {\n get: $util.oneOfGetter($oneOfFields = [\"backoff\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified ControlPrune message. Does not implicitly {@link RPC.ControlPrune.verify|verify} messages.\n * @function encode\n * @memberof RPC.ControlPrune\n * @static\n * @param {RPC.IControlPrune} m ControlPrune message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n ControlPrune.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.topicID != null && Object.hasOwnProperty.call(m, \"topicID\"))\n w.uint32(10).string(m.topicID);\n if (m.peers != null && m.peers.length) {\n for (var i = 0; i < m.peers.length; ++i)\n $root.RPC.PeerInfo.encode(m.peers[i], w.uint32(18).fork()).ldelim();\n }\n if (m.backoff != null && Object.hasOwnProperty.call(m, \"backoff\"))\n w.uint32(24).uint64(m.backoff);\n return w;\n };\n \n /**\n * Decodes a ControlPrune message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.ControlPrune\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.ControlPrune} ControlPrune\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n ControlPrune.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.ControlPrune();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.topicID = r.string();\n break;\n case 2:\n if (!(m.peers && m.peers.length))\n m.peers = [];\n m.peers.push($root.RPC.PeerInfo.decode(r, r.uint32()));\n break;\n case 3:\n m.backoff = r.uint64();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a ControlPrune message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.ControlPrune\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.ControlPrune} ControlPrune\n */\n ControlPrune.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.ControlPrune)\n return d;\n var m = new $root.RPC.ControlPrune();\n if (d.topicID != null) {\n m.topicID = String(d.topicID);\n }\n if (d.peers) {\n if (!Array.isArray(d.peers))\n throw TypeError(\".RPC.ControlPrune.peers: array expected\");\n m.peers = [];\n for (var i = 0; i < d.peers.length; ++i) {\n if (typeof d.peers[i] !== \"object\")\n throw TypeError(\".RPC.ControlPrune.peers: object expected\");\n m.peers[i] = $root.RPC.PeerInfo.fromObject(d.peers[i]);\n }\n }\n if (d.backoff != null) {\n if ($util.Long)\n (m.backoff = $util.Long.fromValue(d.backoff)).unsigned = true;\n else if (typeof d.backoff === \"string\")\n m.backoff = parseInt(d.backoff, 10);\n else if (typeof d.backoff === \"number\")\n m.backoff = d.backoff;\n else if (typeof d.backoff === \"object\")\n m.backoff = new $util.LongBits(d.backoff.low >>> 0, d.backoff.high >>> 0).toNumber(true);\n }\n return m;\n };\n \n /**\n * Creates a plain object from a ControlPrune message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.ControlPrune\n * @static\n * @param {RPC.ControlPrune} m ControlPrune\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n ControlPrune.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.peers = [];\n }\n if (m.topicID != null && m.hasOwnProperty(\"topicID\")) {\n d.topicID = m.topicID;\n if (o.oneofs)\n d._topicID = \"topicID\";\n }\n if (m.peers && m.peers.length) {\n d.peers = [];\n for (var j = 0; j < m.peers.length; ++j) {\n d.peers[j] = $root.RPC.PeerInfo.toObject(m.peers[j], o);\n }\n }\n if (m.backoff != null && m.hasOwnProperty(\"backoff\")) {\n if (typeof m.backoff === \"number\")\n d.backoff = o.longs === String ? String(m.backoff) : m.backoff;\n else\n d.backoff = o.longs === String ? $util.Long.prototype.toString.call(m.backoff) : o.longs === Number ? new $util.LongBits(m.backoff.low >>> 0, m.backoff.high >>> 0).toNumber(true) : m.backoff;\n if (o.oneofs)\n d._backoff = \"backoff\";\n }\n return d;\n };\n \n /**\n * Converts this ControlPrune to JSON.\n * @function toJSON\n * @memberof RPC.ControlPrune\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n ControlPrune.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return ControlPrune;\n })();\n \n RPC.PeerInfo = (function() {\n \n /**\n * Properties of a PeerInfo.\n * @memberof RPC\n * @interface IPeerInfo\n * @property {Uint8Array|null} [peerID] PeerInfo peerID\n * @property {Uint8Array|null} [signedPeerRecord] PeerInfo signedPeerRecord\n */\n \n /**\n * Constructs a new PeerInfo.\n * @memberof RPC\n * @classdesc Represents a PeerInfo.\n * @implements IPeerInfo\n * @constructor\n * @param {RPC.IPeerInfo=} [p] Properties to set\n */\n function PeerInfo(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n \n /**\n * PeerInfo peerID.\n * @member {Uint8Array|null|undefined} peerID\n * @memberof RPC.PeerInfo\n * @instance\n */\n PeerInfo.prototype.peerID = null;\n \n /**\n * PeerInfo signedPeerRecord.\n * @member {Uint8Array|null|undefined} signedPeerRecord\n * @memberof RPC.PeerInfo\n * @instance\n */\n PeerInfo.prototype.signedPeerRecord = null;\n \n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n \n /**\n * PeerInfo _peerID.\n * @member {\"peerID\"|undefined} _peerID\n * @memberof RPC.PeerInfo\n * @instance\n */\n Object.defineProperty(PeerInfo.prototype, \"_peerID\", {\n get: $util.oneOfGetter($oneOfFields = [\"peerID\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * PeerInfo _signedPeerRecord.\n * @member {\"signedPeerRecord\"|undefined} _signedPeerRecord\n * @memberof RPC.PeerInfo\n * @instance\n */\n Object.defineProperty(PeerInfo.prototype, \"_signedPeerRecord\", {\n get: $util.oneOfGetter($oneOfFields = [\"signedPeerRecord\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n \n /**\n * Encodes the specified PeerInfo message. Does not implicitly {@link RPC.PeerInfo.verify|verify} messages.\n * @function encode\n * @memberof RPC.PeerInfo\n * @static\n * @param {RPC.IPeerInfo} m PeerInfo message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PeerInfo.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.peerID != null && Object.hasOwnProperty.call(m, \"peerID\"))\n w.uint32(10).bytes(m.peerID);\n if (m.signedPeerRecord != null && Object.hasOwnProperty.call(m, \"signedPeerRecord\"))\n w.uint32(18).bytes(m.signedPeerRecord);\n return w;\n };\n \n /**\n * Decodes a PeerInfo message from the specified reader or buffer.\n * @function decode\n * @memberof RPC.PeerInfo\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {RPC.PeerInfo} PeerInfo\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PeerInfo.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.RPC.PeerInfo();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.peerID = r.bytes();\n break;\n case 2:\n m.signedPeerRecord = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n \n /**\n * Creates a PeerInfo message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof RPC.PeerInfo\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {RPC.PeerInfo} PeerInfo\n */\n PeerInfo.fromObject = function fromObject(d) {\n if (d instanceof $root.RPC.PeerInfo)\n return d;\n var m = new $root.RPC.PeerInfo();\n if (d.peerID != null) {\n if (typeof d.peerID === \"string\")\n $util.base64.decode(d.peerID, m.peerID = $util.newBuffer($util.base64.length(d.peerID)), 0);\n else if (d.peerID.length)\n m.peerID = d.peerID;\n }\n if (d.signedPeerRecord != null) {\n if (typeof d.signedPeerRecord === \"string\")\n $util.base64.decode(d.signedPeerRecord, m.signedPeerRecord = $util.newBuffer($util.base64.length(d.signedPeerRecord)), 0);\n else if (d.signedPeerRecord.length)\n m.signedPeerRecord = d.signedPeerRecord;\n }\n return m;\n };\n \n /**\n * Creates a plain object from a PeerInfo message. Also converts values to other types if specified.\n * @function toObject\n * @memberof RPC.PeerInfo\n * @static\n * @param {RPC.PeerInfo} m PeerInfo\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n PeerInfo.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.peerID != null && m.hasOwnProperty(\"peerID\")) {\n d.peerID = o.bytes === String ? $util.base64.encode(m.peerID, 0, m.peerID.length) : o.bytes === Array ? Array.prototype.slice.call(m.peerID) : m.peerID;\n if (o.oneofs)\n d._peerID = \"peerID\";\n }\n if (m.signedPeerRecord != null && m.hasOwnProperty(\"signedPeerRecord\")) {\n d.signedPeerRecord = o.bytes === String ? $util.base64.encode(m.signedPeerRecord, 0, m.signedPeerRecord.length) : o.bytes === Array ? Array.prototype.slice.call(m.signedPeerRecord) : m.signedPeerRecord;\n if (o.oneofs)\n d._signedPeerRecord = \"signedPeerRecord\";\n }\n return d;\n };\n \n /**\n * Converts this PeerInfo to JSON.\n * @function toJSON\n * @memberof RPC.PeerInfo\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n PeerInfo.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return PeerInfo;\n })();\n \n return RPC;\n })();\n\n return $root;\n});\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Heartbeat = void 0;\nconst constants = __importStar(require(\"./constants\"));\nconst get_gossip_peers_1 = require(\"./get-gossip-peers\");\nconst utils_1 = require(\"./utils\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\nclass Heartbeat {\n /**\n * @param {Object} gossipsub\n * @constructor\n */\n constructor(gossipsub) {\n this.gossipsub = gossipsub;\n }\n start() {\n if (this._heartbeatTimer) {\n return;\n }\n const heartbeat = this._heartbeat.bind(this);\n const timeout = setTimeout(() => {\n heartbeat();\n this._heartbeatTimer.runPeriodically(heartbeat, this.gossipsub._options.heartbeatInterval);\n }, constants.GossipsubHeartbeatInitialDelay);\n this._heartbeatTimer = {\n _intervalId: undefined,\n runPeriodically: (fn, period) => {\n this._heartbeatTimer._intervalId = setInterval(fn, period);\n },\n cancel: () => {\n clearTimeout(timeout);\n clearInterval(this._heartbeatTimer._intervalId);\n }\n };\n }\n /**\n * Unmounts the gossipsub protocol and shuts down every connection\n * @override\n * @returns {void}\n */\n stop() {\n if (!this._heartbeatTimer) {\n return;\n }\n this._heartbeatTimer.cancel();\n this._heartbeatTimer = null;\n }\n /**\n * Maintains the mesh and fanout maps in gossipsub.\n *\n * @returns {void}\n */\n _heartbeat() {\n const { D, Dlo, Dhi, Dscore, Dout, fanoutTTL } = this.gossipsub._options;\n this.gossipsub.heartbeatTicks++;\n // cache scores throught the heartbeat\n const scores = new Map();\n const getScore = (id) => {\n let s = scores.get(id);\n if (s === undefined) {\n s = this.gossipsub.score.score(id);\n scores.set(id, s);\n }\n return s;\n };\n // peer id => topic[]\n const tograft = new Map();\n // peer id => topic[]\n const toprune = new Map();\n // peer id => don't px\n const noPX = new Map();\n // clean up expired backoffs\n this.gossipsub._clearBackoff();\n // clean up peerhave/iasked counters\n this.gossipsub.peerhave.clear();\n this.gossipsub.iasked.clear();\n // apply IWANT request penalties\n this.gossipsub._applyIwantPenalties();\n // ensure direct peers are connected\n this.gossipsub._directConnect();\n // maintain the mesh for topics we have joined\n this.gossipsub.mesh.forEach((peers, topic) => {\n // prune/graft helper functions (defined per topic)\n const prunePeer = (id) => {\n this.gossipsub.log('HEARTBEAT: Remove mesh link to %s in %s', id, topic);\n // update peer score\n this.gossipsub.score.prune(id, topic);\n // add prune backoff record\n this.gossipsub._addBackoff(id, topic);\n // remove peer from mesh\n peers.delete(id);\n // add to toprune\n const topics = toprune.get(id);\n if (!topics) {\n toprune.set(id, [topic]);\n }\n else {\n topics.push(topic);\n }\n };\n const graftPeer = (id) => {\n this.gossipsub.log('HEARTBEAT: Add mesh link to %s in %s', id, topic);\n // update peer score\n this.gossipsub.score.graft(id, topic);\n // add peer to mesh\n peers.add(id);\n // add to tograft\n const topics = tograft.get(id);\n if (!topics) {\n tograft.set(id, [topic]);\n }\n else {\n topics.push(topic);\n }\n };\n // drop all peers with negative score, without PX\n peers.forEach(id => {\n const score = getScore(id);\n if (score < 0) {\n this.gossipsub.log('HEARTBEAT: Prune peer %s with negative score: score=%d, topic=%s', id, score, topic);\n prunePeer(id);\n noPX.set(id, true);\n }\n });\n // do we have enough peers?\n if (peers.size < Dlo) {\n const backoff = this.gossipsub.backoff.get(topic);\n const ineed = D - peers.size;\n const peersSet = get_gossip_peers_1.getGossipPeers(this.gossipsub, topic, ineed, id => {\n // filter out mesh peers, direct peers, peers we are backing off, peers with negative score\n return !peers.has(id) && !this.gossipsub.direct.has(id) && (!backoff || !backoff.has(id)) && getScore(id) >= 0;\n });\n peersSet.forEach(graftPeer);\n }\n // do we have to many peers?\n if (peers.size > Dhi) {\n let peersArray = Array.from(peers);\n // sort by score\n peersArray.sort((a, b) => getScore(b) - getScore(a));\n // We keep the first D_score peers by score and the remaining up to D randomly\n // under the constraint that we keep D_out peers in the mesh (if we have that many)\n peersArray = peersArray.slice(0, Dscore).concat(utils_1.shuffle(peersArray.slice(Dscore)));\n // count the outbound peers we are keeping\n let outbound = 0;\n peersArray.slice(0, D).forEach(p => {\n if (this.gossipsub.outbound.get(p)) {\n outbound++;\n }\n });\n // if it's less than D_out, bubble up some outbound peers from the random selection\n if (outbound < Dout) {\n const rotate = (i) => {\n // rotate the peersArray to the right and put the ith peer in the front\n const p = peersArray[i];\n for (let j = i; j > 0; j--) {\n peersArray[j] = peersArray[j - 1];\n }\n peersArray[0] = p;\n };\n // first bubble up all outbound peers already in the selection to the front\n if (outbound > 0) {\n let ihave = outbound;\n for (let i = 1; i < D && ihave > 0; i++) {\n if (this.gossipsub.outbound.get(peersArray[i])) {\n rotate(i);\n ihave--;\n }\n }\n }\n // now bubble up enough outbound peers outside the selection to the front\n let ineed = D - outbound;\n for (let i = D; i < peersArray.length && ineed > 0; i++) {\n if (this.gossipsub.outbound.get(peersArray[i])) {\n rotate(i);\n ineed--;\n }\n }\n }\n // prune the excess peers\n peersArray.slice(D).forEach(prunePeer);\n }\n // do we have enough outbound peers?\n if (peers.size >= Dlo) {\n // count the outbound peers we have\n let outbound = 0;\n peers.forEach(p => {\n if (this.gossipsub.outbound.get(p)) {\n outbound++;\n }\n });\n // if it's less than D_out, select some peers with outbound connections and graft them\n if (outbound < Dout) {\n const ineed = Dout - outbound;\n const backoff = this.gossipsub.backoff.get(topic);\n get_gossip_peers_1.getGossipPeers(this.gossipsub, topic, ineed, (id) => {\n // filter our current mesh peers, direct peers, peers we are backing off, peers with negative score\n return !peers.has(id) && !this.gossipsub.direct.has(id) && (!backoff || !backoff.has(id)) && getScore(id) >= 0;\n }).forEach(graftPeer);\n }\n }\n // should we try to improve the mesh with opportunistic grafting?\n if (this.gossipsub.heartbeatTicks % constants.GossipsubOpportunisticGraftTicks === 0 && peers.size > 1) {\n // Opportunistic grafting works as follows: we check the median score of peers in the\n // mesh; if this score is below the opportunisticGraftThreshold, we select a few peers at\n // random with score over the median.\n // The intention is to (slowly) improve an underperforming mesh by introducing good\n // scoring peers that may have been gossiping at us. This allows us to get out of sticky\n // situations where we are stuck with poor peers and also recover from churn of good peers.\n // now compute the median peer score in the mesh\n const peersList = Array.from(peers)\n .sort((a, b) => getScore(a) - getScore(b));\n const medianIndex = Math.floor(peers.size / 2);\n const medianScore = getScore(peersList[medianIndex]);\n // if the median score is below the threshold, select a better peer (if any) and GRAFT\n if (medianScore < this.gossipsub._options.scoreThresholds.opportunisticGraftThreshold) {\n const backoff = this.gossipsub.backoff.get(topic);\n const peersToGraft = get_gossip_peers_1.getGossipPeers(this.gossipsub, topic, constants.GossipsubOpportunisticGraftPeers, (id) => {\n // filter out current mesh peers, direct peers, peers we are backing off, peers below or at threshold\n return peers.has(id) && !this.gossipsub.direct.has(id) && (!backoff || !backoff.has(id)) && getScore(id) > medianScore;\n });\n peersToGraft.forEach(id => {\n this.gossipsub.log('HEARTBEAT: Opportunistically graft peer %s on topic %s', id, topic);\n graftPeer(id);\n });\n }\n }\n // 2nd arg are mesh peers excluded from gossip. We have already pushed\n // messages to them, so its redundant to gossip IHAVEs.\n this.gossipsub._emitGossip(topic, peers);\n });\n // expire fanout for topics we haven't published to in a while\n const now = this.gossipsub._now();\n this.gossipsub.lastpub.forEach((lastpb, topic) => {\n if ((lastpb + fanoutTTL) < now) {\n this.gossipsub.fanout.delete(topic);\n this.gossipsub.lastpub.delete(topic);\n }\n });\n // maintain our fanout for topics we are publishing but we have not joined\n this.gossipsub.fanout.forEach((fanoutPeers, topic) => {\n // checks whether our peers are still in the topic and have a score above the publish threshold\n const topicPeers = this.gossipsub.topics.get(topic);\n fanoutPeers.forEach(id => {\n if (!topicPeers.has(id) ||\n getScore(id) < this.gossipsub._options.scoreThresholds.publishThreshold) {\n fanoutPeers.delete(id);\n }\n });\n // do we need more peers?\n if (fanoutPeers.size < D) {\n const ineed = D - fanoutPeers.size;\n const peersSet = get_gossip_peers_1.getGossipPeers(this.gossipsub, topic, ineed, (id) => {\n // filter out existing fanout peers, direct peers, and peers with score above the publish threshold\n return !fanoutPeers.has(id) &&\n !this.gossipsub.direct.has(id) &&\n getScore(id) >= this.gossipsub._options.scoreThresholds.publishThreshold;\n });\n peersSet.forEach(id => {\n fanoutPeers.add(id);\n });\n }\n // 2nd arg are fanout peers excluded from gossip.\n // We have already pushed messages to them, so its redundant to gossip IHAVEs\n this.gossipsub._emitGossip(topic, fanoutPeers);\n });\n // send coalesced GRAFT/PRUNE messages (will piggyback gossip)\n this.gossipsub._sendGraftPrune(tograft, toprune, noPX);\n // flush pending gossip that wasn't piggybacked above\n this.gossipsub._flush();\n // advance the message history window\n this.gossipsub.messageCache.shift();\n this.gossipsub.emit('gossipsub:heartbeat');\n }\n}\nexports.Heartbeat = Heartbeat;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getGossipPeers = void 0;\nconst utils_1 = require(\"./utils\");\n/**\n * Given a topic, returns up to count peers subscribed to that topic\n * that pass an optional filter function\n *\n * @param {Gossipsub} router\n * @param {String} topic\n * @param {Number} count\n * @param {Function} [filter] a function to filter acceptable peers\n * @returns {Set<string>}\n *\n */\nfunction getGossipPeers(router, topic, count, filter = () => true) {\n const peersInTopic = router.topics.get(topic);\n if (!peersInTopic) {\n return new Set();\n }\n // Adds all peers using our protocol\n // that also pass the filter function\n let peers = [];\n peersInTopic.forEach((id) => {\n const peerStreams = router.peers.get(id);\n if (!peerStreams) {\n return;\n }\n if (utils_1.hasGossipProtocol(peerStreams.protocol) &&\n filter(id)) {\n peers.push(id);\n }\n });\n // Pseudo-randomly shuffles peers\n peers = utils_1.shuffle(peers);\n if (count > 0 && peers.length > count) {\n peers = peers.slice(0, count);\n }\n return new Set(peers);\n}\nexports.getGossipPeers = getGossipPeers;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__exportStar(require(\"./peer-score-params\"), exports);\n__exportStar(require(\"./peer-score-thresholds\"), exports);\n__exportStar(require(\"./peer-score\"), exports);\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateTopicScoreParams = exports.validatePeerScoreParams = exports.createTopicScoreParams = exports.createPeerScoreParams = exports.defaultTopicScoreParams = exports.defaultPeerScoreParams = void 0;\nconst constants_1 = require(\"./constants\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst errcode = require(\"err-code\");\nexports.defaultPeerScoreParams = {\n topics: {},\n topicScoreCap: 10,\n appSpecificScore: () => 0,\n appSpecificWeight: 10,\n IPColocationFactorWeight: -5,\n IPColocationFactorThreshold: 10,\n IPColocationFactorWhitelist: new Set(),\n behaviourPenaltyWeight: -10,\n behaviourPenaltyDecay: 0.2,\n decayInterval: 1000,\n decayToZero: 0.1,\n retainScore: 3600 * 1000\n};\nexports.defaultTopicScoreParams = {\n topicWeight: 0.5,\n timeInMeshWeight: 1,\n timeInMeshQuantum: 1,\n timeInMeshCap: 3600,\n firstMessageDeliveriesWeight: 1,\n firstMessageDeliveriesDecay: 0.5,\n firstMessageDeliveriesCap: 2000,\n meshMessageDeliveriesWeight: -1,\n meshMessageDeliveriesDecay: 0.5,\n meshMessageDeliveriesCap: 100,\n meshMessageDeliveriesThreshold: 20,\n meshMessageDeliveriesWindow: 10,\n meshMessageDeliveriesActivation: 5000,\n meshFailurePenaltyWeight: -1,\n meshFailurePenaltyDecay: 0.5,\n invalidMessageDeliveriesWeight: -1,\n invalidMessageDeliveriesDecay: 0.3\n};\nfunction createPeerScoreParams(p = {}) {\n return Object.assign(Object.assign(Object.assign({}, exports.defaultPeerScoreParams), p), { topics: p.topics\n ? Object.entries(p.topics)\n .reduce((topics, [topic, topicScoreParams]) => {\n topics[topic] = createTopicScoreParams(topicScoreParams);\n return topics;\n }, {})\n : {} });\n}\nexports.createPeerScoreParams = createPeerScoreParams;\nfunction createTopicScoreParams(p = {}) {\n return Object.assign(Object.assign({}, exports.defaultTopicScoreParams), p);\n}\nexports.createTopicScoreParams = createTopicScoreParams;\n// peer score parameter validation\nfunction validatePeerScoreParams(p) {\n for (const [topic, params] of Object.entries(p.topics)) {\n try {\n validateTopicScoreParams(params);\n }\n catch (e) {\n throw errcode(new Error(`invalid score parameters for topic ${topic}: ${e.message}`), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n }\n // check that the topic score is 0 or something positive\n if (p.topicScoreCap < 0) {\n throw errcode(new Error('invalid topic score cap; must be positive (or 0 for no cap)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check that we have an app specific score; the weight can be anything (but expected positive)\n if (p.appSpecificScore === null || p.appSpecificScore === undefined) {\n throw errcode(new Error('missing application specific score function'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check the IP colocation factor\n if (p.IPColocationFactorWeight > 0) {\n throw errcode(new Error('invalid IPColocationFactorWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.IPColocationFactorWeight !== 0 && p.IPColocationFactorThreshold < 1) {\n throw errcode(new Error('invalid IPColocationFactorThreshold; must be at least 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check the behaviour penalty\n if (p.behaviourPenaltyWeight > 0) {\n throw errcode(new Error('invalid BehaviourPenaltyWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.behaviourPenaltyWeight !== 0 && (p.behaviourPenaltyDecay <= 0 || p.behaviourPenaltyDecay >= 1)) {\n throw errcode(new Error('invalid BehaviourPenaltyDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check the decay parameters\n if (p.decayInterval < 1000) {\n throw errcode(new Error('invalid DecayInterval; must be at least 1s'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.decayToZero <= 0 || p.decayToZero >= 1) {\n throw errcode(new Error('invalid DecayToZero; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // no need to check the score retention; a value of 0 means that we don't retain scores\n}\nexports.validatePeerScoreParams = validatePeerScoreParams;\nfunction validateTopicScoreParams(p) {\n // make sure we have a sane topic weight\n if (p.topicWeight < 0) {\n throw errcode(new Error('invalid topic weight; must be >= 0'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P1\n if (p.timeInMeshQuantum === 0) {\n throw errcode(new Error('invalid TimeInMeshQuantum; must be non zero'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.timeInMeshWeight < 0) {\n throw errcode(new Error('invalid TimeInMeshWeight; must be positive (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.timeInMeshWeight !== 0 && p.timeInMeshQuantum <= 0) {\n throw errcode(new Error('invalid TimeInMeshQuantum; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.timeInMeshWeight !== 0 && p.timeInMeshCap <= 0) {\n throw errcode(new Error('invalid TimeInMeshCap; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P2\n if (p.firstMessageDeliveriesWeight < 0) {\n throw errcode(new Error('invallid FirstMessageDeliveriesWeight; must be positive (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.firstMessageDeliveriesWeight !== 0 && (p.firstMessageDeliveriesDecay <= 0 || p.firstMessageDeliveriesDecay >= 1)) {\n throw errcode(new Error('invalid FirstMessageDeliveriesDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.firstMessageDeliveriesWeight !== 0 && p.firstMessageDeliveriesCap <= 0) {\n throw errcode(new Error('invalid FirstMessageDeliveriesCap; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P3\n if (p.meshMessageDeliveriesWeight > 0) {\n throw errcode(new Error('invalid MeshMessageDeliveriesWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWeight !== 0 && (p.meshMessageDeliveriesDecay <= 0 || p.meshMessageDeliveriesDecay >= 1)) {\n throw errcode(new Error('invalid MeshMessageDeliveriesDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWeight !== 0 && p.meshMessageDeliveriesCap <= 0) {\n throw errcode(new Error('invalid MeshMessageDeliveriesCap; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWeight !== 0 && p.meshMessageDeliveriesThreshold <= 0) {\n throw errcode(new Error('invalid MeshMessageDeliveriesThreshold; must be positive'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWindow < 0) {\n throw errcode(new Error('invalid MeshMessageDeliveriesWindow; must be non-negative'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshMessageDeliveriesWeight !== 0 && p.meshMessageDeliveriesActivation < 1000) {\n throw errcode(new Error('invalid MeshMessageDeliveriesActivation; must be at least 1s'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P3b\n if (p.meshFailurePenaltyWeight > 0) {\n throw errcode(new Error('invalid MeshFailurePenaltyWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.meshFailurePenaltyWeight !== 0 && (p.meshFailurePenaltyDecay <= 0 || p.meshFailurePenaltyDecay >= 1)) {\n throw errcode(new Error('invalid MeshFailurePenaltyDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n // check P4\n if (p.invalidMessageDeliveriesWeight > 0) {\n throw errcode(new Error('invalid InvalidMessageDeliveriesWeight; must be negative (or 0 to disable)'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n if (p.invalidMessageDeliveriesDecay <= 0 || p.invalidMessageDeliveriesDecay >= 1) {\n throw errcode(new Error('invalid InvalidMessageDeliveriesDecay; must be between 0 and 1'), constants_1.ERR_INVALID_PEER_SCORE_PARAMS);\n }\n}\nexports.validateTopicScoreParams = validateTopicScoreParams;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ERR_INVALID_PEER_SCORE_THRESHOLDS = exports.ERR_INVALID_PEER_SCORE_PARAMS = void 0;\nexports.ERR_INVALID_PEER_SCORE_PARAMS = 'ERR_INVALID_PEER_SCORE_PARAMS';\nexports.ERR_INVALID_PEER_SCORE_THRESHOLDS = 'ERR_INVALID_PEER_SCORE_THRESHOLDS';\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validatePeerScoreThresholds = exports.createPeerScoreThresholds = exports.defaultPeerScoreThresholds = void 0;\nconst constants_1 = require(\"./constants\");\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nconst errcode = require(\"err-code\");\nexports.defaultPeerScoreThresholds = {\n gossipThreshold: -10,\n publishThreshold: -50,\n graylistThreshold: -80,\n acceptPXThreshold: 10,\n opportunisticGraftThreshold: 20\n};\nfunction createPeerScoreThresholds(p = {}) {\n return Object.assign(Object.assign({}, exports.defaultPeerScoreThresholds), p);\n}\nexports.createPeerScoreThresholds = createPeerScoreThresholds;\nfunction validatePeerScoreThresholds(p) {\n if (p.gossipThreshold > 0) {\n throw errcode(new Error('invalid gossip threshold; it must be <= 0'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n if (p.publishThreshold > 0 || p.publishThreshold > p.gossipThreshold) {\n throw errcode(new Error('invalid publish threshold; it must be <= 0 and <= gossip threshold'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n if (p.graylistThreshold > 0 || p.graylistThreshold > p.publishThreshold) {\n throw errcode(new Error('invalid graylist threshold; it must be <= 0 and <= publish threshold'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n if (p.acceptPXThreshold < 0) {\n throw errcode(new Error('invalid accept PX threshold; it must be >= 0'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n if (p.opportunisticGraftThreshold < 0) {\n throw errcode(new Error('invalid opportunistic grafting threshold; it must be >= 0'), constants_1.ERR_INVALID_PEER_SCORE_THRESHOLDS);\n }\n}\nexports.validatePeerScoreThresholds = validatePeerScoreThresholds;\n","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.PeerScore = void 0;\nconst peer_score_params_1 = require(\"./peer-score-params\");\nconst peer_stats_1 = require(\"./peer-stats\");\nconst compute_score_1 = require(\"./compute-score\");\nconst message_deliveries_1 = require(\"./message-deliveries\");\nconst constants_1 = require(\"../constants\");\nconst peer_id_1 = __importDefault(require(\"peer-id\"));\nconst debug = require(\"debug\");\nconst pubsubErrors = require(\"libp2p-interfaces/src/pubsub/errors\");\nconst { ERR_INVALID_SIGNATURE, ERR_MISSING_SIGNATURE } = pubsubErrors.codes;\nconst log = debug('libp2p:gossipsub:score');\nclass PeerScore {\n constructor(params, connectionManager, msgId) {\n peer_score_params_1.validatePeerScoreParams(params);\n this.params = params;\n this._connectionManager = connectionManager;\n this.peerStats = new Map();\n this.peerIPs = new Map();\n this.deliveryRecords = new message_deliveries_1.MessageDeliveries();\n this.msgId = msgId;\n }\n /**\n * Start PeerScore instance\n * @returns {void}\n */\n start() {\n if (this._backgroundInterval) {\n log('Peer score already running');\n return;\n }\n this._backgroundInterval = setInterval(() => this.background(), this.params.decayInterval);\n log('started');\n }\n /**\n * Stop PeerScore instance\n * @returns {void}\n */\n stop() {\n if (!this._backgroundInterval) {\n log('Peer score already stopped');\n return;\n }\n clearInterval(this._backgroundInterval);\n delete this._backgroundInterval;\n this.peerIPs.clear();\n this.peerStats.clear();\n this.deliveryRecords.clear();\n log('stopped');\n }\n /**\n * Periodic maintenance\n * @returns {void}\n */\n background() {\n this._refreshScores();\n this._updateIPs();\n this.deliveryRecords.gc();\n }\n /**\n * Decays scores, and purges score records for disconnected peers once their expiry has elapsed.\n * @returns {void}\n */\n _refreshScores() {\n const now = Date.now();\n const decayToZero = this.params.decayToZero;\n this.peerStats.forEach((pstats, id) => {\n if (!pstats.connected) {\n // has the retention perious expired?\n if (now > pstats.expire) {\n // yes, throw it away (but clean up the IP tracking first)\n this._removeIPs(id, pstats.ips);\n this.peerStats.delete(id);\n }\n // we don't decay retained scores, as the peer is not active.\n // this way the peer cannot reset a negative score by simply disconnecting and reconnecting,\n // unless the retention period has ellapsed.\n // similarly, a well behaved peer does not lose its score by getting disconnected.\n return;\n }\n Object.entries(pstats.topics).forEach(([topic, tstats]) => {\n const tparams = this.params.topics[topic];\n if (!tparams) {\n // we are not scoring this topic\n // should be unreachable, we only add scored topics to pstats\n return;\n }\n // decay counters\n tstats.firstMessageDeliveries *= tparams.firstMessageDeliveriesDecay;\n if (tstats.firstMessageDeliveries < decayToZero) {\n tstats.firstMessageDeliveries = 0;\n }\n tstats.meshMessageDeliveries *= tparams.meshMessageDeliveriesDecay;\n if (tstats.meshMessageDeliveries < decayToZero) {\n tstats.meshMessageDeliveries = 0;\n }\n tstats.meshFailurePenalty *= tparams.meshFailurePenaltyDecay;\n if (tstats.meshFailurePenalty < decayToZero) {\n tstats.meshFailurePenalty = 0;\n }\n tstats.invalidMessageDeliveries *= tparams.invalidMessageDeliveriesDecay;\n if (tstats.invalidMessageDeliveries < decayToZero) {\n tstats.invalidMessageDeliveries = 0;\n }\n // update mesh time and activate mesh message delivery parameter if need be\n if (tstats.inMesh) {\n tstats.meshTime = now - tstats.graftTime;\n if (tstats.meshTime > tparams.meshMessageDeliveriesActivation) {\n tstats.meshMessageDeliveriesActive = true;\n }\n }\n });\n // decay P7 counter\n pstats.behaviourPenalty *= this.params.behaviourPenaltyDecay;\n if (pstats.behaviourPenalty < decayToZero) {\n pstats.behaviourPenalty = 0;\n }\n });\n }\n /**\n * Return the score for a peer\n * @param {string} id\n * @returns {Number}\n */\n score(id) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return 0;\n }\n return compute_score_1.computeScore(id, pstats, this.params, this.peerIPs);\n }\n /**\n * Apply a behavioural penalty to a peer\n * @param {string} id\n * @param {Number} penalty\n * @returns {void}\n */\n addPenalty(id, penalty) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n pstats.behaviourPenalty += penalty;\n }\n /**\n * @param {string} id\n * @returns {void}\n */\n addPeer(id) {\n // create peer stats (not including topic stats for each topic to be scored)\n // topic stats will be added as needed\n const pstats = peer_stats_1.createPeerStats({\n connected: true\n });\n this.peerStats.set(id, pstats);\n // get + update peer IPs\n const ips = this._getIPs(id);\n this._setIPs(id, ips, pstats.ips);\n pstats.ips = ips;\n }\n /**\n * @param {string} id\n * @returns {void}\n */\n removePeer(id) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n // decide whether to retain the score; this currently only retains non-positive scores\n // to dissuade attacks on the score function.\n if (this.score(id) > 0) {\n this._removeIPs(id, pstats.ips);\n this.peerStats.delete(id);\n return;\n }\n // furthermore, when we decide to retain the score, the firstMessageDelivery counters are\n // reset to 0 and mesh delivery penalties applied.\n Object.entries(pstats.topics).forEach(([topic, tstats]) => {\n tstats.firstMessageDeliveries = 0;\n const threshold = this.params.topics[topic].meshMessageDeliveriesThreshold;\n if (tstats.inMesh && tstats.meshMessageDeliveriesActive && tstats.meshMessageDeliveries < threshold) {\n const deficit = threshold - tstats.meshMessageDeliveries;\n tstats.meshFailurePenalty += deficit * deficit;\n }\n tstats.inMesh = false;\n });\n pstats.connected = false;\n pstats.expire = Date.now() + this.params.retainScore;\n }\n /**\n * @param {string} id\n * @param {String} topic\n * @returns {void}\n */\n graft(id, topic) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n tstats.inMesh = true;\n tstats.graftTime = Date.now();\n tstats.meshTime = 0;\n tstats.meshMessageDeliveriesActive = false;\n }\n /**\n * @param {string} id\n * @param {string} topic\n * @returns {void}\n */\n prune(id, topic) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n // sticky mesh delivery rate failure penalty\n const threshold = this.params.topics[topic].meshMessageDeliveriesThreshold;\n if (tstats.meshMessageDeliveriesActive && tstats.meshMessageDeliveries < threshold) {\n const deficit = threshold - tstats.meshMessageDeliveries;\n tstats.meshFailurePenalty += deficit * deficit;\n }\n tstats.inMesh = false;\n }\n /**\n * @param {InMessage} message\n * @returns {Promise<void>}\n */\n validateMessage(message) {\n return __awaiter(this, void 0, void 0, function* () {\n this.deliveryRecords.ensureRecord(yield this.msgId(message));\n });\n }\n /**\n * @param {InMessage} message\n * @returns {Promise<void>}\n */\n deliverMessage(message) {\n return __awaiter(this, void 0, void 0, function* () {\n const id = message.receivedFrom;\n this._markFirstMessageDelivery(id, message);\n const drec = this.deliveryRecords.ensureRecord(yield this.msgId(message));\n const now = Date.now();\n // defensive check that this is the first delivery trace -- delivery status should be unknown\n if (drec.status !== message_deliveries_1.DeliveryRecordStatus.unknown) {\n log('unexpected delivery: message from %s was first seen %s ago and has delivery status %d', id, now - drec.firstSeen, message_deliveries_1.DeliveryRecordStatus[drec.status]);\n return;\n }\n // mark the message as valid and reward mesh peers that have already forwarded it to us\n drec.status = message_deliveries_1.DeliveryRecordStatus.valid;\n drec.validated = now;\n drec.peers.forEach(p => {\n // this check is to make sure a peer can't send us a message twice and get a double count\n // if it is a first delivery.\n if (p !== id) {\n this._markDuplicateMessageDelivery(p, message);\n }\n });\n });\n }\n /**\n * @param {InMessage} message\n * @param {string} reason\n * @returns {Promise<void>}\n */\n rejectMessage(message, reason) {\n return __awaiter(this, void 0, void 0, function* () {\n const id = message.receivedFrom;\n switch (reason) {\n case ERR_MISSING_SIGNATURE:\n case ERR_INVALID_SIGNATURE:\n this._markInvalidMessageDelivery(id, message);\n return;\n }\n const drec = this.deliveryRecords.ensureRecord(yield this.msgId(message));\n // defensive check that this is the first rejection -- delivery status should be unknown\n if (drec.status !== message_deliveries_1.DeliveryRecordStatus.unknown) {\n log('unexpected rejection: message from %s was first seen %s ago and has delivery status %d', id, Date.now() - drec.firstSeen, message_deliveries_1.DeliveryRecordStatus[drec.status]);\n return;\n }\n switch (reason) {\n case constants_1.ERR_TOPIC_VALIDATOR_IGNORE:\n // we were explicitly instructed by the validator to ignore the message but not penalize the peer\n drec.status = message_deliveries_1.DeliveryRecordStatus.ignored;\n return;\n }\n // mark the message as invalid and penalize peers that have already forwarded it.\n drec.status = message_deliveries_1.DeliveryRecordStatus.invalid;\n this._markInvalidMessageDelivery(id, message);\n drec.peers.forEach(p => {\n this._markInvalidMessageDelivery(p, message);\n });\n });\n }\n /**\n * @param {InMessage} message\n * @returns {Promise<void>}\n */\n duplicateMessage(message) {\n return __awaiter(this, void 0, void 0, function* () {\n const id = message.receivedFrom;\n const drec = this.deliveryRecords.ensureRecord(yield this.msgId(message));\n if (drec.peers.has(id)) {\n // we have already seen this duplicate\n return;\n }\n switch (drec.status) {\n case message_deliveries_1.DeliveryRecordStatus.unknown:\n // the message is being validated; track the peer delivery and wait for\n // the Deliver/Reject/Ignore notification.\n drec.peers.add(id);\n break;\n case message_deliveries_1.DeliveryRecordStatus.valid:\n // mark the peer delivery time to only count a duplicate delivery once.\n drec.peers.add(id);\n this._markDuplicateMessageDelivery(id, message, drec.validated);\n break;\n case message_deliveries_1.DeliveryRecordStatus.invalid:\n // we no longer track delivery time\n this._markInvalidMessageDelivery(id, message);\n break;\n }\n });\n }\n /**\n * Increments the \"invalid message deliveries\" counter for all scored topics the message is published in.\n * @param {string} id\n * @param {InMessage} message\n * @returns {void}\n */\n _markInvalidMessageDelivery(id, message) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n message.topicIDs.forEach(topic => {\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n tstats.invalidMessageDeliveries += 1;\n });\n }\n /**\n * Increments the \"first message deliveries\" counter for all scored topics the message is published in,\n * as well as the \"mesh message deliveries\" counter, if the peer is in the mesh for the topic.\n * @param {string} id\n * @param {InMessage} message\n * @returns {void}\n */\n _markFirstMessageDelivery(id, message) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n message.topicIDs.forEach(topic => {\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n let cap = this.params.topics[topic].firstMessageDeliveriesCap;\n tstats.firstMessageDeliveries += 1;\n if (tstats.firstMessageDeliveries > cap) {\n tstats.firstMessageDeliveries = cap;\n }\n if (!tstats.inMesh) {\n return;\n }\n cap = this.params.topics[topic].meshMessageDeliveriesCap;\n tstats.meshMessageDeliveries += 1;\n if (tstats.meshMessageDeliveries > cap) {\n tstats.meshMessageDeliveries = cap;\n }\n });\n }\n /**\n * Increments the \"mesh message deliveries\" counter for messages we've seen before,\n * as long the message was received within the P3 window.\n * @param {string} id\n * @param {InMessage} message\n * @param {number} validatedTime\n * @returns {void}\n */\n _markDuplicateMessageDelivery(id, message, validatedTime = 0) {\n const pstats = this.peerStats.get(id);\n if (!pstats) {\n return;\n }\n const now = validatedTime ? Date.now() : 0;\n message.topicIDs.forEach(topic => {\n const tstats = peer_stats_1.ensureTopicStats(topic, pstats, this.params);\n if (!tstats) {\n return;\n }\n if (!tstats.inMesh) {\n return;\n }\n const tparams = this.params.topics[topic];\n // check against the mesh delivery window -- if the validated time is passed as 0, then\n // the message was received before we finished validation and thus falls within the mesh\n // delivery window.\n if (validatedTime && now > validatedTime + tparams.meshMessageDeliveriesWindow) {\n return;\n }\n const cap = tparams.meshMessageDeliveriesCap;\n tstats.meshMessageDeliveries += 1;\n if (tstats.meshMessageDeliveries > cap) {\n tstats.meshMessageDeliveries = cap;\n }\n });\n }\n /**\n * Gets the current IPs for a peer.\n * @param {string} id\n * @returns {Array<string>}\n */\n _getIPs(id) {\n return this._connectionManager.getAll(peer_id_1.default.createFromB58String(id))\n .map(c => c.remoteAddr.toOptions().host);\n }\n /**\n * Adds tracking for the new IPs in the list, and removes tracking from the obsolete IPs.\n * @param {string} id\n * @param {Array<string>} newIPs\n * @param {Array<string>} oldIPs\n * @returns {void}\n */\n _setIPs(id, newIPs, oldIPs) {\n // add the new IPs to the tracking\n // eslint-disable-next-line no-labels\n addNewIPs: for (const ip of newIPs) {\n // check if it is in the old ips list\n for (const xip of oldIPs) {\n if (ip === xip) {\n // eslint-disable-next-line no-labels\n continue addNewIPs;\n }\n }\n // no, it's a new one -- add it to the tracker\n let peers = this.peerIPs.get(ip);\n if (!peers) {\n peers = new Set();\n this.peerIPs.set(ip, peers);\n }\n peers.add(id);\n }\n // remove the obsolete old IPs from the tracking\n // eslint-disable-next-line no-labels\n removeOldIPs: for (const ip of oldIPs) {\n // check if it is in the new ips list\n for (const xip of newIPs) {\n if (ip === xip) {\n // eslint-disable-next-line no-labels\n continue removeOldIPs;\n }\n }\n // no, its obselete -- remove it from the tracker\n const peers = this.peerIPs.get(ip);\n if (!peers) {\n continue;\n }\n peers.delete(id);\n if (!peers.size) {\n this.peerIPs.delete(ip);\n }\n }\n }\n /**\n * Removes an IP list from the tracking list for a peer.\n * @param {string} id\n * @param {Array<string>} ips\n * @returns {void}\n */\n _removeIPs(id, ips) {\n ips.forEach(ip => {\n const peers = this.peerIPs.get(ip);\n if (!peers) {\n return;\n }\n peers.delete(id);\n if (!peers.size) {\n this.peerIPs.delete(ip);\n }\n });\n }\n /**\n * Update all peer IPs to currently open connections\n * @returns {void}\n */\n _updateIPs() {\n this.peerStats.forEach((pstats, id) => {\n const newIPs = this._getIPs(id);\n this._setIPs(id, newIPs, pstats.ips);\n pstats.ips = newIPs;\n });\n }\n}\nexports.PeerScore = PeerScore;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ensureTopicStats = exports.createTopicStats = exports.createPeerStats = void 0;\nfunction createPeerStats(ps = {}) {\n return Object.assign(Object.assign({ connected: false, expire: 0, ips: [], behaviourPenalty: 0 }, ps), { topics: ps.topics\n ? Object.entries(ps.topics)\n .reduce((topics, [topic, topicStats]) => {\n topics[topic] = createTopicStats(topicStats);\n return topics;\n }, {})\n : {} });\n}\nexports.createPeerStats = createPeerStats;\nfunction createTopicStats(ts = {}) {\n return Object.assign({ inMesh: false, graftTime: 0, meshTime: 0, firstMessageDeliveries: 0, meshMessageDeliveries: 0, meshMessageDeliveriesActive: false, meshFailurePenalty: 0, invalidMessageDeliveries: 0 }, ts);\n}\nexports.createTopicStats = createTopicStats;\nfunction ensureTopicStats(topic, ps, params) {\n let ts = ps.topics[topic];\n if (ts) {\n return ts;\n }\n if (!params.topics[topic]) {\n return undefined;\n }\n ps.topics[topic] = ts = createTopicStats();\n return ts;\n}\nexports.ensureTopicStats = ensureTopicStats;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.computeScore = void 0;\nfunction computeScore(peer, pstats, params, peerIPs) {\n let score = 0;\n // topic stores\n Object.entries(pstats.topics).forEach(([topic, tstats]) => {\n // the topic parameters\n const topicParams = params.topics[topic];\n if (!topicParams) {\n // we are not scoring this topic\n return;\n }\n let topicScore = 0;\n // P1: time in Mesh\n if (tstats.inMesh) {\n let p1 = tstats.meshTime / topicParams.timeInMeshQuantum;\n if (p1 > topicParams.timeInMeshCap) {\n p1 = topicParams.timeInMeshCap;\n }\n topicScore += p1 * topicParams.timeInMeshWeight;\n }\n // P2: first message deliveries\n const p2 = tstats.firstMessageDeliveries;\n topicScore += p2 * topicParams.firstMessageDeliveriesWeight;\n // P3: mesh message deliveries\n if (tstats.meshMessageDeliveriesActive) {\n if (tstats.meshMessageDeliveries < topicParams.meshMessageDeliveriesThreshold) {\n const deficit = topicParams.meshMessageDeliveriesThreshold - tstats.meshMessageDeliveries;\n const p3 = deficit * deficit;\n topicScore += p3 * topicParams.meshMessageDeliveriesWeight;\n }\n }\n // P3b:\n // NOTE: the weight of P3b is negative (validated in validateTopicScoreParams) so this detracts\n const p3b = tstats.meshFailurePenalty;\n topicScore += p3b * topicParams.meshFailurePenaltyWeight;\n // P4: invalid messages\n // NOTE: the weight of P4 is negative (validated in validateTopicScoreParams) so this detracts\n const p4 = tstats.invalidMessageDeliveries * tstats.invalidMessageDeliveries;\n topicScore += p4 * topicParams.invalidMessageDeliveriesWeight;\n // update score, mixing with topic weight\n score += topicScore * topicParams.topicWeight;\n });\n // apply the topic score cap, if any\n if (params.topicScoreCap > 0 && score > params.topicScoreCap) {\n score = params.topicScoreCap;\n }\n // P5: application-specific score\n const p5 = params.appSpecificScore(peer);\n score += p5 * params.appSpecificWeight;\n // P6: IP colocation factor\n pstats.ips.forEach(ip => {\n if (params.IPColocationFactorWhitelist.has(ip)) {\n return;\n }\n // P6 has a cliff (IPColocationFactorThreshold)\n // It's only applied if at least that many peers are connected to us from that source IP addr.\n // It is quadratic, and the weight is negative (validated in validatePeerScoreParams)\n const peersInIP = peerIPs.get(ip);\n const numPeersInIP = peersInIP ? peersInIP.size : 0;\n if (numPeersInIP > params.IPColocationFactorThreshold) {\n const surplus = numPeersInIP - params.IPColocationFactorThreshold;\n const p6 = surplus * surplus;\n score += p6 * params.IPColocationFactorWeight;\n }\n });\n // P7: behavioural pattern penalty\n const p7 = pstats.behaviourPenalty * pstats.behaviourPenalty;\n score += p7 * params.behaviourPenaltyWeight;\n return score;\n}\nexports.computeScore = computeScore;\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MessageDeliveries = exports.DeliveryRecordStatus = void 0;\nconst constants_1 = require(\"../constants\");\nconst denque_1 = __importDefault(require(\"denque\"));\nconst utils_1 = require(\"../utils\");\nvar DeliveryRecordStatus;\n(function (DeliveryRecordStatus) {\n /**\n * we don't know (yet) if the message is valid\n */\n DeliveryRecordStatus[DeliveryRecordStatus[\"unknown\"] = 0] = \"unknown\";\n /**\n * we know the message is valid\n */\n DeliveryRecordStatus[DeliveryRecordStatus[\"valid\"] = 1] = \"valid\";\n /**\n * we know the message is invalid\n */\n DeliveryRecordStatus[DeliveryRecordStatus[\"invalid\"] = 2] = \"invalid\";\n /**\n * we were instructed by the validator to ignore the message\n */\n DeliveryRecordStatus[DeliveryRecordStatus[\"ignored\"] = 3] = \"ignored\";\n})(DeliveryRecordStatus = exports.DeliveryRecordStatus || (exports.DeliveryRecordStatus = {}));\n/**\n * Map of message ID to DeliveryRecord\n *\n * Maintains an internal queue for efficient gc of old messages\n */\nclass MessageDeliveries {\n constructor() {\n this.records = new Map();\n this.queue = new denque_1.default();\n }\n ensureRecord(msgId) {\n const msgIdStr = utils_1.messageIdToString(msgId);\n let drec = this.records.get(msgIdStr);\n if (drec) {\n return drec;\n }\n // record doesn't exist yet\n // create record\n drec = {\n status: DeliveryRecordStatus.unknown,\n firstSeen: Date.now(),\n validated: 0,\n peers: new Set()\n };\n this.records.set(msgIdStr, drec);\n // and add msgId to the queue\n const entry = {\n msgId: msgIdStr,\n expire: Date.now() + constants_1.TimeCacheDuration\n };\n this.queue.push(entry);\n return drec;\n }\n gc() {\n const now = Date.now();\n // queue is sorted by expiry time\n // remove expired messages, remove from queue until first un-expired message found\n let head = this.queue.peekFront();\n while (head && head.expire < now) {\n this.records.delete(head.msgId);\n this.queue.shift();\n head = this.queue.peekFront();\n }\n }\n clear() {\n this.records.clear();\n this.queue.clear();\n }\n}\nexports.MessageDeliveries = MessageDeliveries;\n","'use strict';\n\n/**\n * Custom implementation of a double ended queue.\n */\nfunction Denque(array, options) {\n var options = options || {};\n\n this._head = 0;\n this._tail = 0;\n this._capacity = options.capacity;\n this._capacityMask = 0x3;\n this._list = new Array(4);\n if (Array.isArray(array)) {\n this._fromArray(array);\n }\n}\n\n/**\n * -------------\n * PUBLIC API\n * -------------\n */\n\n/**\n * Returns the item at the specified index from the list.\n * 0 is the first element, 1 is the second, and so on...\n * Elements at negative values are that many from the end: -1 is one before the end\n * (the last element), -2 is two before the end (one before last), etc.\n * @param index\n * @returns {*}\n */\nDenque.prototype.peekAt = function peekAt(index) {\n var i = index;\n // expect a number or return undefined\n if ((i !== (i | 0))) {\n return void 0;\n }\n var len = this.size();\n if (i >= len || i < -len) return undefined;\n if (i < 0) i += len;\n i = (this._head + i) & this._capacityMask;\n return this._list[i];\n};\n\n/**\n * Alias for peekAt()\n * @param i\n * @returns {*}\n */\nDenque.prototype.get = function get(i) {\n return this.peekAt(i);\n};\n\n/**\n * Returns the first item in the list without removing it.\n * @returns {*}\n */\nDenque.prototype.peek = function peek() {\n if (this._head === this._tail) return undefined;\n return this._list[this._head];\n};\n\n/**\n * Alias for peek()\n * @returns {*}\n */\nDenque.prototype.peekFront = function peekFront() {\n return this.peek();\n};\n\n/**\n * Returns the item that is at the back of the queue without removing it.\n * Uses peekAt(-1)\n */\nDenque.prototype.peekBack = function peekBack() {\n return this.peekAt(-1);\n};\n\n/**\n * Returns the current length of the queue\n * @return {Number}\n */\nObject.defineProperty(Denque.prototype, 'length', {\n get: function length() {\n return this.size();\n }\n});\n\n/**\n * Return the number of items on the list, or 0 if empty.\n * @returns {number}\n */\nDenque.prototype.size = function size() {\n if (this._head === this._tail) return 0;\n if (this._head < this._tail) return this._tail - this._head;\n else return this._capacityMask + 1 - (this._head - this._tail);\n};\n\n/**\n * Add an item at the beginning of the list.\n * @param item\n */\nDenque.prototype.unshift = function unshift(item) {\n if (item === undefined) return this.size();\n var len = this._list.length;\n this._head = (this._head - 1 + len) & this._capacityMask;\n this._list[this._head] = item;\n if (this._tail === this._head) this._growArray();\n if (this._capacity && this.size() > this._capacity) this.pop();\n if (this._head < this._tail) return this._tail - this._head;\n else return this._capacityMask + 1 - (this._head - this._tail);\n};\n\n/**\n * Remove and return the first item on the list,\n * Returns undefined if the list is empty.\n * @returns {*}\n */\nDenque.prototype.shift = function shift() {\n var head = this._head;\n if (head === this._tail) return undefined;\n var item = this._list[head];\n this._list[head] = undefined;\n this._head = (head + 1) & this._capacityMask;\n if (head < 2 && this._tail > 10000 && this._tail <= this._list.length >>> 2) this._shrinkArray();\n return item;\n};\n\n/**\n * Add an item to the bottom of the list.\n * @param item\n */\nDenque.prototype.push = function push(item) {\n if (item === undefined) return this.size();\n var tail = this._tail;\n this._list[tail] = item;\n this._tail = (tail + 1) & this._capacityMask;\n if (this._tail === this._head) {\n this._growArray();\n }\n if (this._capacity && this.size() > this._capacity) {\n this.shift();\n }\n if (this._head < this._tail) return this._tail - this._head;\n else return this._capacityMask + 1 - (this._head - this._tail);\n};\n\n/**\n * Remove and return the last item on the list.\n * Returns undefined if the list is empty.\n * @returns {*}\n */\nDenque.prototype.pop = function pop() {\n var tail = this._tail;\n if (tail === this._head) return undefined;\n var len = this._list.length;\n this._tail = (tail - 1 + len) & this._capacityMask;\n var item = this._list[this._tail];\n this._list[this._tail] = undefined;\n if (this._head < 2 && tail > 10000 && tail <= len >>> 2) this._shrinkArray();\n return item;\n};\n\n/**\n * Remove and return the item at the specified index from the list.\n * Returns undefined if the list is empty.\n * @param index\n * @returns {*}\n */\nDenque.prototype.removeOne = function removeOne(index) {\n var i = index;\n // expect a number or return undefined\n if ((i !== (i | 0))) {\n return void 0;\n }\n if (this._head === this._tail) return void 0;\n var size = this.size();\n var len = this._list.length;\n if (i >= size || i < -size) return void 0;\n if (i < 0) i += size;\n i = (this._head + i) & this._capacityMask;\n var item = this._list[i];\n var k;\n if (index < size / 2) {\n for (k = index; k > 0; k--) {\n this._list[i] = this._list[i = (i - 1 + len) & this._capacityMask];\n }\n this._list[i] = void 0;\n this._head = (this._head + 1 + len) & this._capacityMask;\n } else {\n for (k = size - 1 - index; k > 0; k--) {\n this._list[i] = this._list[i = ( i + 1 + len) & this._capacityMask];\n }\n this._list[i] = void 0;\n this._tail = (this._tail - 1 + len) & this._capacityMask;\n }\n return item;\n};\n\n/**\n * Remove number of items from the specified index from the list.\n * Returns array of removed items.\n * Returns undefined if the list is empty.\n * @param index\n * @param count\n * @returns {array}\n */\nDenque.prototype.remove = function remove(index, count) {\n var i = index;\n var removed;\n var del_count = count;\n // expect a number or return undefined\n if ((i !== (i | 0))) {\n return void 0;\n }\n if (this._head === this._tail) return void 0;\n var size = this.size();\n var len = this._list.length;\n if (i >= size || i < -size || count < 1) return void 0;\n if (i < 0) i += size;\n if (count === 1 || !count) {\n removed = new Array(1);\n removed[0] = this.removeOne(i);\n return removed;\n }\n if (i === 0 && i + count >= size) {\n removed = this.toArray();\n this.clear();\n return removed;\n }\n if (i + count > size) count = size - i;\n var k;\n removed = new Array(count);\n for (k = 0; k < count; k++) {\n removed[k] = this._list[(this._head + i + k) & this._capacityMask];\n }\n i = (this._head + i) & this._capacityMask;\n if (index + count === size) {\n this._tail = (this._tail - count + len) & this._capacityMask;\n for (k = count; k > 0; k--) {\n this._list[i = (i + 1 + len) & this._capacityMask] = void 0;\n }\n return removed;\n }\n if (index === 0) {\n this._head = (this._head + count + len) & this._capacityMask;\n for (k = count - 1; k > 0; k--) {\n this._list[i = (i + 1 + len) & this._capacityMask] = void 0;\n }\n return removed;\n }\n if (i < size / 2) {\n this._head = (this._head + index + count + len) & this._capacityMask;\n for (k = index; k > 0; k--) {\n this.unshift(this._list[i = (i - 1 + len) & this._capacityMask]);\n }\n i = (this._head - 1 + len) & this._capacityMask;\n while (del_count > 0) {\n this._list[i = (i - 1 + len) & this._capacityMask] = void 0;\n del_count--;\n }\n if (index < 0) this._tail = i;\n } else {\n this._tail = i;\n i = (i + count + len) & this._capacityMask;\n for (k = size - (count + index); k > 0; k--) {\n this.push(this._list[i++]);\n }\n i = this._tail;\n while (del_count > 0) {\n this._list[i = (i + 1 + len) & this._capacityMask] = void 0;\n del_count--;\n }\n }\n if (this._head < 2 && this._tail > 10000 && this._tail <= len >>> 2) this._shrinkArray();\n return removed;\n};\n\n/**\n * Native splice implementation.\n * Remove number of items from the specified index from the list and/or add new elements.\n * Returns array of removed items or empty array if count == 0.\n * Returns undefined if the list is empty.\n *\n * @param index\n * @param count\n * @param {...*} [elements]\n * @returns {array}\n */\nDenque.prototype.splice = function splice(index, count) {\n var i = index;\n // expect a number or return undefined\n if ((i !== (i | 0))) {\n return void 0;\n }\n var size = this.size();\n if (i < 0) i += size;\n if (i > size) return void 0;\n if (arguments.length > 2) {\n var k;\n var temp;\n var removed;\n var arg_len = arguments.length;\n var len = this._list.length;\n var arguments_index = 2;\n if (!size || i < size / 2) {\n temp = new Array(i);\n for (k = 0; k < i; k++) {\n temp[k] = this._list[(this._head + k) & this._capacityMask];\n }\n if (count === 0) {\n removed = [];\n if (i > 0) {\n this._head = (this._head + i + len) & this._capacityMask;\n }\n } else {\n removed = this.remove(i, count);\n this._head = (this._head + i + len) & this._capacityMask;\n }\n while (arg_len > arguments_index) {\n this.unshift(arguments[--arg_len]);\n }\n for (k = i; k > 0; k--) {\n this.unshift(temp[k - 1]);\n }\n } else {\n temp = new Array(size - (i + count));\n var leng = temp.length;\n for (k = 0; k < leng; k++) {\n temp[k] = this._list[(this._head + i + count + k) & this._capacityMask];\n }\n if (count === 0) {\n removed = [];\n if (i != size) {\n this._tail = (this._head + i + len) & this._capacityMask;\n }\n } else {\n removed = this.remove(i, count);\n this._tail = (this._tail - leng + len) & this._capacityMask;\n }\n while (arguments_index < arg_len) {\n this.push(arguments[arguments_index++]);\n }\n for (k = 0; k < leng; k++) {\n this.push(temp[k]);\n }\n }\n return removed;\n } else {\n return this.remove(i, count);\n }\n};\n\n/**\n * Soft clear - does not reset capacity.\n */\nDenque.prototype.clear = function clear() {\n this._head = 0;\n this._tail = 0;\n};\n\n/**\n * Returns true or false whether the list is empty.\n * @returns {boolean}\n */\nDenque.prototype.isEmpty = function isEmpty() {\n return this._head === this._tail;\n};\n\n/**\n * Returns an array of all queue items.\n * @returns {Array}\n */\nDenque.prototype.toArray = function toArray() {\n return this._copyArray(false);\n};\n\n/**\n * -------------\n * INTERNALS\n * -------------\n */\n\n/**\n * Fills the queue with items from an array\n * For use in the constructor\n * @param array\n * @private\n */\nDenque.prototype._fromArray = function _fromArray(array) {\n for (var i = 0; i < array.length; i++) this.push(array[i]);\n};\n\n/**\n *\n * @param fullCopy\n * @returns {Array}\n * @private\n */\nDenque.prototype._copyArray = function _copyArray(fullCopy) {\n var newArray = [];\n var list = this._list;\n var len = list.length;\n var i;\n if (fullCopy || this._head > this._tail) {\n for (i = this._head; i < len; i++) newArray.push(list[i]);\n for (i = 0; i < this._tail; i++) newArray.push(list[i]);\n } else {\n for (i = this._head; i < this._tail; i++) newArray.push(list[i]);\n }\n return newArray;\n};\n\n/**\n * Grows the internal list array.\n * @private\n */\nDenque.prototype._growArray = function _growArray() {\n if (this._head) {\n // copy existing data, head to end, then beginning to tail.\n this._list = this._copyArray(true);\n this._head = 0;\n }\n\n // head is at 0 and array is now full, safe to extend\n this._tail = this._list.length;\n\n this._list.length <<= 1;\n this._capacityMask = (this._capacityMask << 1) | 1;\n};\n\n/**\n * Shrinks the internal list array.\n * @private\n */\nDenque.prototype._shrinkArray = function _shrinkArray() {\n this._list.length >>>= 1;\n this._capacityMask >>>= 1;\n};\n\n\nmodule.exports = Denque;\n","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.IWantTracer = void 0;\nconst constants_1 = require(\"./constants\");\nconst utils_1 = require(\"./utils\");\nconst pubsubErrors = require(\"libp2p-interfaces/src/pubsub/errors\");\nconst { ERR_INVALID_SIGNATURE, ERR_MISSING_SIGNATURE } = pubsubErrors.codes;\n/**\n * IWantTracer is an internal tracer that tracks IWANT requests in order to penalize\n * peers who don't follow up on IWANT requests after an IHAVE advertisement.\n * The tracking of promises is probabilistic to avoid using too much memory.\n *\n * Note: Do not confuse these 'promises' with JS Promise objects.\n * These 'promises' are merely expectations of a peer's behavior.\n */\nclass IWantTracer {\n constructor(getMsgId) {\n this.getMsgId = getMsgId;\n this.promises = new Map();\n }\n /**\n * Track a promise to deliver a message from a list of msgIDs we are requesting\n * @param {string} p peer id\n * @param {string[]} msgIds\n * @returns {void}\n */\n addPromise(p, msgIds) {\n // pick msgId randomly from the list\n const ix = Math.floor(Math.random() * msgIds.length);\n const msgId = msgIds[ix];\n const msgIdStr = utils_1.messageIdToString(msgId);\n let peers = this.promises.get(msgIdStr);\n if (!peers) {\n peers = new Map();\n this.promises.set(msgIdStr, peers);\n }\n if (!peers.has(p)) {\n peers.set(p, Date.now() + constants_1.GossipsubIWantFollowupTime);\n }\n }\n /**\n * Returns the number of broken promises for each peer who didn't follow up on an IWANT request.\n * @returns {Map<string, number>}\n */\n getBrokenPromises() {\n const now = Date.now();\n const result = new Map();\n this.promises.forEach((peers, msgId) => {\n peers.forEach((expire, p) => {\n // the promise has been broken\n if (expire < now) {\n // add 1 to result\n result.set(p, (result.get(p) || 0) + 1);\n // delete from tracked promises\n peers.delete(p);\n }\n });\n // clean up empty promises for a msgId\n if (!peers.size) {\n this.promises.delete(msgId);\n }\n });\n return result;\n }\n /**\n * Someone delivered a message, stop tracking promises for it\n * @param {InMessage} msg\n * @returns {Promise<void>}\n */\n deliverMessage(msg) {\n return __awaiter(this, void 0, void 0, function* () {\n const msgId = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgId);\n this.promises.delete(msgIdStr);\n });\n }\n /**\n * A message got rejected, so we can stop tracking promises and let the score penalty apply from invalid message delivery,\n * unless its an obviously invalid message.\n * @param {InMessage} msg\n * @param {string} reason\n * @returns {Promise<void>}\n */\n rejectMessage(msg, reason) {\n return __awaiter(this, void 0, void 0, function* () {\n switch (reason) {\n case ERR_INVALID_SIGNATURE:\n case ERR_MISSING_SIGNATURE:\n return;\n }\n const msgId = yield this.getMsgId(msg);\n const msgIdStr = utils_1.messageIdToString(msgId);\n this.promises.delete(msgIdStr);\n });\n }\n clear() {\n this.promises.clear();\n }\n}\nexports.IWantTracer = IWantTracer;\n","'use strict'\n\nconst throttle = require('lodash.throttle')\nexports = module.exports = TimeCache\n\nfunction TimeCache (options) {\n if (!(this instanceof TimeCache)) {\n return new TimeCache(options)\n }\n\n options = options || {}\n\n const validity = options.validity || 30 // seconds\n\n const entries = new Map()\n\n const sweep = throttle(() => {\n entries.forEach((entry, key) => {\n const v = entry.validity || validity\n const delta = getTimeElapsed(entry.timestamp)\n if (delta > v) {\n entries.delete(key)\n }\n })\n }, 200)\n\n this.put = (key, value, validity) => {\n if (!this.has(key)) {\n entries.set(key, {\n value: value,\n timestamp: new Date(),\n validity: validity\n })\n }\n\n sweep()\n }\n\n this.get = (key) => {\n if (entries.has(key)) {\n return entries.get(key).value\n } else {\n throw new Error('key does not exist')\n }\n }\n\n this.has = (key) => {\n return entries.has(key)\n }\n}\n\nfunction getTimeElapsed (prevTime) {\n const currentTime = new Date()\n const a = currentTime.getTime() - prevTime.getTime()\n\n return Math.floor(a / 1000)\n}\n","/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n result = wait - timeSinceLastCall;\n\n return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\n/**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n * Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\nfunction throttle(func, wait, options) {\n var leading = true,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (isObject(options)) {\n leading = 'leading' in options ? !!options.leading : leading;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n return debounce(func, wait, {\n 'leading': leading,\n 'maxWait': wait,\n 'trailing': trailing\n });\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && objectToString.call(value) == symbolTag);\n}\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = value.replace(reTrim, '');\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = throttle;\n","'use strict'\n\nconst errCode = require('err-code')\nconst { concat: uint8arraysConcat } = require('uint8arrays/concat')\nconst { fromString: uint8arraysFromString } = require('uint8arrays/from-string')\n// @ts-ignore libp2p-crypto does not support types\nconst cryptoKeys = require('libp2p-crypto/src/keys')\nconst PeerId = require('peer-id')\nconst varint = require('varint')\nconst { equals: uint8arraysEquals } = require('uint8arrays/equals')\n\nconst { codes } = require('../../errors')\nconst { Envelope: Protobuf } = require('./envelope')\n\n/**\n * @typedef {import('libp2p-interfaces/src/record/types').Record} Record\n */\n\nclass Envelope {\n /**\n * The Envelope is responsible for keeping an arbitrary signed record\n * by a libp2p peer.\n *\n * @class\n * @param {object} params\n * @param {PeerId} params.peerId\n * @param {Uint8Array} params.payloadType\n * @param {Uint8Array} params.payload - marshaled record\n * @param {Uint8Array} params.signature - signature of the domain string :: type hint :: payload.\n */\n constructor ({ peerId, payloadType, payload, signature }) {\n this.peerId = peerId\n this.payloadType = payloadType\n this.payload = payload\n this.signature = signature\n\n // Cache\n this._marshal = undefined\n }\n\n /**\n * Marshal the envelope content.\n *\n * @returns {Uint8Array}\n */\n marshal () {\n if (this._marshal) {\n return this._marshal\n }\n\n const publicKey = cryptoKeys.marshalPublicKey(this.peerId.pubKey)\n\n this._marshal = Protobuf.encode({\n publicKey: publicKey,\n payloadType: this.payloadType,\n payload: this.payload,\n signature: this.signature\n }).finish()\n\n return this._marshal\n }\n\n /**\n * Verifies if the other Envelope is identical to this one.\n *\n * @param {Envelope} other\n * @returns {boolean}\n */\n equals (other) {\n return uint8arraysEquals(this.peerId.pubKey.bytes, other.peerId.pubKey.bytes) &&\n uint8arraysEquals(this.payloadType, other.payloadType) &&\n uint8arraysEquals(this.payload, other.payload) &&\n uint8arraysEquals(this.signature, other.signature)\n }\n\n /**\n * Validate envelope data signature for the given domain.\n *\n * @param {string} domain\n * @returns {Promise<boolean>}\n */\n validate (domain) {\n const signData = formatSignaturePayload(domain, this.payloadType, this.payload)\n\n return this.peerId.pubKey.verify(signData, this.signature)\n }\n}\n\n/**\n * Helper function that prepares a Uint8Array to sign or verify a signature.\n *\n * @param {string} domain\n * @param {Uint8Array} payloadType\n * @param {Uint8Array} payload\n * @returns {Uint8Array}\n */\nconst formatSignaturePayload = (domain, payloadType, payload) => {\n // When signing, a peer will prepare a Uint8Array by concatenating the following:\n // - The length of the domain separation string string in bytes\n // - The domain separation string, encoded as UTF-8\n // - The length of the payload_type field in bytes\n // - The value of the payload_type field\n // - The length of the payload field in bytes\n // - The value of the payload field\n\n const domainUint8Array = uint8arraysFromString(domain)\n const domainLength = varint.encode(domainUint8Array.byteLength)\n const payloadTypeLength = varint.encode(payloadType.length)\n const payloadLength = varint.encode(payload.length)\n\n return uint8arraysConcat([\n new Uint8Array(domainLength),\n domainUint8Array,\n new Uint8Array(payloadTypeLength),\n payloadType,\n new Uint8Array(payloadLength),\n payload\n ])\n}\n\n/**\n * Unmarshal a serialized Envelope protobuf message.\n *\n * @param {Uint8Array} data\n * @returns {Promise<Envelope>}\n */\nEnvelope.createFromProtobuf = async (data) => {\n const envelopeData = Protobuf.decode(data)\n const peerId = await PeerId.createFromPubKey(envelopeData.publicKey)\n\n return new Envelope({\n peerId,\n payloadType: envelopeData.payloadType,\n payload: envelopeData.payload,\n signature: envelopeData.signature\n })\n}\n\n/**\n * Seal marshals the given Record, places the marshaled bytes inside an Envelope\n * and signs it with the given peerId's private key.\n *\n * @async\n * @param {Record} record\n * @param {PeerId} peerId\n * @returns {Promise<Envelope>}\n */\nEnvelope.seal = async (record, peerId) => {\n const domain = record.domain\n const payloadType = record.codec\n const payload = record.marshal()\n\n const signData = formatSignaturePayload(domain, payloadType, payload)\n const signature = await peerId.privKey.sign(signData)\n\n return new Envelope({\n peerId,\n payloadType,\n payload,\n signature\n })\n}\n\n/**\n * Open and certify a given marshalled envelope.\n * Data is unmarshalled and the signature validated for the given domain.\n *\n * @param {Uint8Array} data\n * @param {string} domain\n * @returns {Promise<Envelope>}\n */\nEnvelope.openAndCertify = async (data, domain) => {\n const envelope = await Envelope.createFromProtobuf(data)\n const valid = await envelope.validate(domain)\n\n if (!valid) {\n throw errCode(new Error('envelope signature is not valid for the given domain'), codes.ERR_SIGNATURE_NOT_VALID)\n }\n\n return envelope\n}\n\nmodule.exports = Envelope\n","'use strict'\n\nexports.messages = {\n NOT_STARTED_YET: 'The libp2p node is not started yet',\n DHT_DISABLED: 'DHT is not available',\n CONN_ENCRYPTION_REQUIRED: 'At least one connection encryption module is required'\n}\n\nexports.codes = {\n DHT_DISABLED: 'ERR_DHT_DISABLED',\n PUBSUB_NOT_STARTED: 'ERR_PUBSUB_NOT_STARTED',\n DHT_NOT_STARTED: 'ERR_DHT_NOT_STARTED',\n CONN_ENCRYPTION_REQUIRED: 'ERR_CONN_ENCRYPTION_REQUIRED',\n ERR_INVALID_PROTOCOLS_FOR_STREAM: 'ERR_INVALID_PROTOCOLS_FOR_STREAM',\n ERR_CONNECTION_ENDED: 'ERR_CONNECTION_ENDED',\n ERR_CONNECTION_FAILED: 'ERR_CONNECTION_FAILED',\n ERR_NODE_NOT_STARTED: 'ERR_NODE_NOT_STARTED',\n ERR_ALREADY_ABORTED: 'ERR_ALREADY_ABORTED',\n ERR_TOO_MANY_ADDRESSES: 'ERR_TOO_MANY_ADDRESSES',\n ERR_NO_VALID_ADDRESSES: 'ERR_NO_VALID_ADDRESSES',\n ERR_RELAYED_DIAL: 'ERR_RELAYED_DIAL',\n ERR_DIALED_SELF: 'ERR_DIALED_SELF',\n ERR_DISCOVERED_SELF: 'ERR_DISCOVERED_SELF',\n ERR_DUPLICATE_TRANSPORT: 'ERR_DUPLICATE_TRANSPORT',\n ERR_ENCRYPTION_FAILED: 'ERR_ENCRYPTION_FAILED',\n ERR_HOP_REQUEST_FAILED: 'ERR_HOP_REQUEST_FAILED',\n ERR_INVALID_KEY: 'ERR_INVALID_KEY',\n ERR_INVALID_MESSAGE: 'ERR_INVALID_MESSAGE',\n ERR_INVALID_PARAMETERS: 'ERR_INVALID_PARAMETERS',\n ERR_INVALID_PEER: 'ERR_INVALID_PEER',\n ERR_MUXER_UNAVAILABLE: 'ERR_MUXER_UNAVAILABLE',\n ERR_TIMEOUT: 'ERR_TIMEOUT',\n ERR_TRANSPORT_UNAVAILABLE: 'ERR_TRANSPORT_UNAVAILABLE',\n ERR_TRANSPORT_DIAL_FAILED: 'ERR_TRANSPORT_DIAL_FAILED',\n ERR_UNSUPPORTED_PROTOCOL: 'ERR_UNSUPPORTED_PROTOCOL',\n ERR_INVALID_MULTIADDR: 'ERR_INVALID_MULTIADDR',\n ERR_SIGNATURE_NOT_VALID: 'ERR_SIGNATURE_NOT_VALID'\n}\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-envelope\"] || ($protobuf.roots[\"libp2p-envelope\"] = {});\n\n$root.Envelope = (function() {\n\n /**\n * Properties of an Envelope.\n * @exports IEnvelope\n * @interface IEnvelope\n * @property {Uint8Array|null} [publicKey] Envelope publicKey\n * @property {Uint8Array|null} [payloadType] Envelope payloadType\n * @property {Uint8Array|null} [payload] Envelope payload\n * @property {Uint8Array|null} [signature] Envelope signature\n */\n\n /**\n * Constructs a new Envelope.\n * @exports Envelope\n * @classdesc Represents an Envelope.\n * @implements IEnvelope\n * @constructor\n * @param {IEnvelope=} [p] Properties to set\n */\n function Envelope(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Envelope publicKey.\n * @member {Uint8Array} publicKey\n * @memberof Envelope\n * @instance\n */\n Envelope.prototype.publicKey = $util.newBuffer([]);\n\n /**\n * Envelope payloadType.\n * @member {Uint8Array} payloadType\n * @memberof Envelope\n * @instance\n */\n Envelope.prototype.payloadType = $util.newBuffer([]);\n\n /**\n * Envelope payload.\n * @member {Uint8Array} payload\n * @memberof Envelope\n * @instance\n */\n Envelope.prototype.payload = $util.newBuffer([]);\n\n /**\n * Envelope signature.\n * @member {Uint8Array} signature\n * @memberof Envelope\n * @instance\n */\n Envelope.prototype.signature = $util.newBuffer([]);\n\n /**\n * Encodes the specified Envelope message. Does not implicitly {@link Envelope.verify|verify} messages.\n * @function encode\n * @memberof Envelope\n * @static\n * @param {IEnvelope} m Envelope message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Envelope.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.publicKey != null && Object.hasOwnProperty.call(m, \"publicKey\"))\n w.uint32(10).bytes(m.publicKey);\n if (m.payloadType != null && Object.hasOwnProperty.call(m, \"payloadType\"))\n w.uint32(18).bytes(m.payloadType);\n if (m.payload != null && Object.hasOwnProperty.call(m, \"payload\"))\n w.uint32(26).bytes(m.payload);\n if (m.signature != null && Object.hasOwnProperty.call(m, \"signature\"))\n w.uint32(42).bytes(m.signature);\n return w;\n };\n\n /**\n * Decodes an Envelope message from the specified reader or buffer.\n * @function decode\n * @memberof Envelope\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Envelope} Envelope\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Envelope.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Envelope();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.publicKey = r.bytes();\n break;\n case 2:\n m.payloadType = r.bytes();\n break;\n case 3:\n m.payload = r.bytes();\n break;\n case 5:\n m.signature = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an Envelope message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Envelope\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Envelope} Envelope\n */\n Envelope.fromObject = function fromObject(d) {\n if (d instanceof $root.Envelope)\n return d;\n var m = new $root.Envelope();\n if (d.publicKey != null) {\n if (typeof d.publicKey === \"string\")\n $util.base64.decode(d.publicKey, m.publicKey = $util.newBuffer($util.base64.length(d.publicKey)), 0);\n else if (d.publicKey.length)\n m.publicKey = d.publicKey;\n }\n if (d.payloadType != null) {\n if (typeof d.payloadType === \"string\")\n $util.base64.decode(d.payloadType, m.payloadType = $util.newBuffer($util.base64.length(d.payloadType)), 0);\n else if (d.payloadType.length)\n m.payloadType = d.payloadType;\n }\n if (d.payload != null) {\n if (typeof d.payload === \"string\")\n $util.base64.decode(d.payload, m.payload = $util.newBuffer($util.base64.length(d.payload)), 0);\n else if (d.payload.length)\n m.payload = d.payload;\n }\n if (d.signature != null) {\n if (typeof d.signature === \"string\")\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n return m;\n };\n\n /**\n * Creates a plain object from an Envelope message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Envelope\n * @static\n * @param {Envelope} m Envelope\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Envelope.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.publicKey = \"\";\n else {\n d.publicKey = [];\n if (o.bytes !== Array)\n d.publicKey = $util.newBuffer(d.publicKey);\n }\n if (o.bytes === String)\n d.payloadType = \"\";\n else {\n d.payloadType = [];\n if (o.bytes !== Array)\n d.payloadType = $util.newBuffer(d.payloadType);\n }\n if (o.bytes === String)\n d.payload = \"\";\n else {\n d.payload = [];\n if (o.bytes !== Array)\n d.payload = $util.newBuffer(d.payload);\n }\n if (o.bytes === String)\n d.signature = \"\";\n else {\n d.signature = [];\n if (o.bytes !== Array)\n d.signature = $util.newBuffer(d.signature);\n }\n }\n if (m.publicKey != null && m.hasOwnProperty(\"publicKey\")) {\n d.publicKey = o.bytes === String ? $util.base64.encode(m.publicKey, 0, m.publicKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.publicKey) : m.publicKey;\n }\n if (m.payloadType != null && m.hasOwnProperty(\"payloadType\")) {\n d.payloadType = o.bytes === String ? $util.base64.encode(m.payloadType, 0, m.payloadType.length) : o.bytes === Array ? Array.prototype.slice.call(m.payloadType) : m.payloadType;\n }\n if (m.payload != null && m.hasOwnProperty(\"payload\")) {\n d.payload = o.bytes === String ? $util.base64.encode(m.payload, 0, m.payload.length) : o.bytes === Array ? Array.prototype.slice.call(m.payload) : m.payload;\n }\n if (m.signature != null && m.hasOwnProperty(\"signature\")) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n }\n return d;\n };\n\n /**\n * Converts this Envelope to JSON.\n * @function toJSON\n * @memberof Envelope\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Envelope.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Envelope;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { base58btc } = require('multiformats/bases/base58')\nconst { default: PQueue } = require('p-queue')\nconst defer = require('p-defer')\nconst debug = require('debug')\n\nconst log = debug('libp2p-delegated-peer-routing')\nlog.error = debug('libp2p-delegated-peer-routing:error')\n\nconst DEFAULT_TIMEOUT = 30e3 // 30 second default\nconst CONCURRENT_HTTP_REQUESTS = 4\n\nclass DelegatedPeerRouting {\n /**\n * Create a new DelegatedPeerRouting instance.\n *\n * @param {object} client - an instance of the ipfs-http-client module\n */\n constructor (client) {\n if (client == null) {\n throw new Error('missing ipfs http client')\n }\n\n this._client = client\n\n // limit concurrency to avoid request flood in web browser\n // https://github.com/libp2p/js-libp2p-delegated-content-routing/issues/12\n this._httpQueue = new PQueue({\n concurrency: CONCURRENT_HTTP_REQUESTS\n })\n\n const {\n protocol,\n host,\n port\n } = client.getEndpointConfig()\n\n log(`enabled DelegatedPeerRouting via ${protocol}://${host}:${port}`)\n }\n\n /**\n * Attempts to find the given peer\n *\n * @param {PeerID} id\n * @param {object} options\n * @param {number} options.timeout - How long the query can take. Defaults to 30 seconds\n * @returns {Promise<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async findPeer (id, options = {}) {\n let idStr = id\n if (PeerId.isPeerId(idStr)) {\n idStr = id.toB58String()\n }\n\n log('findPeer starts: ' + id)\n\n options.timeout = options.timeout || DEFAULT_TIMEOUT\n\n try {\n return await this._httpQueue.add(async () => {\n const { addrs } = await this._client.dht.findPeer(idStr, {\n timeout: options.timeout\n })\n\n return {\n id,\n multiaddrs: addrs\n }\n })\n } catch (err) {\n if (err.message.includes('not found')) {\n return undefined\n }\n\n throw err\n } finally {\n log('findPeer finished: ' + id)\n }\n }\n\n /**\n * Attempt to find the closest peers on the network to the given key\n *\n * @param {Uint8Array} key - A CID like key\n * @param {object} [options]\n * @param {number} [options.timeout=30e3] - How long the query can take.\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * getClosestPeers (key, options = {}) {\n const keyStr = base58btc.encode(key).substring(1)\n\n log('getClosestPeers starts:', keyStr)\n options.timeout = options.timeout || DEFAULT_TIMEOUT\n\n const onStart = defer()\n const onFinish = defer()\n\n this._httpQueue.add(() => {\n onStart.resolve()\n return onFinish.promise\n })\n\n try {\n await onStart.promise\n\n const peers = new Map()\n\n for await (const result of this._client.dht.query(keyStr, {\n timeout: options.timeout\n })) {\n switch (result.type) {\n case 1: // Found Closer\n // Track the addresses, so we can yield them when done\n result.responses.forEach(response => {\n peers.set(response.id, {\n id: PeerId.parse(response.id),\n multiaddrs: response.addrs\n })\n })\n break\n case 2: // Final Peer\n yield peers.get(result.id.string) || {\n id: PeerId.createFromCID(result.id),\n multiaddrs: []\n }\n break\n default:\n log('getClosestPeers unhandled response', result)\n }\n }\n } catch (err) {\n log.error('getClosestPeers errored:', err)\n throw err\n } finally {\n onFinish.resolve()\n log('getClosestPeers finished:', keyStr)\n }\n }\n}\n\nmodule.exports = DelegatedPeerRouting\n","'use strict'\n\nconst debug = require('debug')\nconst PeerId = require('peer-id')\nconst drain = require('it-drain')\n\nconst { default: PQueue } = require('p-queue')\nconst defer = require('p-defer')\n\nconst log = debug('libp2p-delegated-content-routing')\nlog.error = debug('libp2p-delegated-content-routing:error')\n\nconst DEFAULT_TIMEOUT = 30e3 // 30 second default\nconst CONCURRENT_HTTP_REQUESTS = 4\n\n/**\n * @typedef {import('peer-id').PeerID} PeerID\n * @typedef {import('cids').CID} CID\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * An implementation of content routing, using a delegated peer.\n */\nclass DelegatedContentRouting {\n /**\n * Create a new DelegatedContentRouting instance.\n *\n * @param {PeerID} peerId - the id of the node that is using this routing.\n * @param {object} client - an instance of the ipfs-http-client module\n */\n constructor (peerId, client) {\n if (peerId == null) {\n throw new Error('missing self peerId')\n }\n\n if (client == null) {\n throw new Error('missing ipfs http client')\n }\n\n this._client = client\n this.peerId = peerId\n\n // limit concurrency to avoid request flood in web browser\n // https://github.com/libp2p/js-libp2p-delegated-content-routing/issues/12\n const concurrency = { concurrency: CONCURRENT_HTTP_REQUESTS }\n this._httpQueue = new PQueue(concurrency)\n // sometimes refs requests take long time, they need separate queue\n // to not suffocate regular business\n this._httpQueueRefs = new PQueue(Object.assign({}, concurrency, {\n concurrency: 2\n }))\n\n const {\n protocol,\n host,\n port\n } = client.getEndpointConfig()\n\n log(`enabled DelegatedContentRouting via ${protocol}://${host}:${port}`)\n }\n\n /**\n * Search the dht for providers of the given CID.\n *\n * - call `findProviders` on the delegated node.\n *\n * @param {CID} key - The CID to find providers for\n * @param {object} options - Options\n * @param {number} options.timeout - How long the query can take. Defaults to 30 seconds\n * @param {number} options.numProviders - How many providers to find, defaults to 20\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} - An async iterable of PeerId/Multiaddrs\n */\n async * findProviders (key, options = {}) {\n log(`findProviders starts: ${key}`)\n options.timeout = options.timeout || DEFAULT_TIMEOUT\n\n let providers = 0\n const onStart = defer()\n const onFinish = defer()\n\n this._httpQueue.add(() => {\n onStart.resolve()\n return onFinish.promise\n })\n\n try {\n await onStart.promise\n\n for await (const { id, addrs } of this._client.dht.findProvs(key, {\n numProviders: options.numProviders,\n timeout: options.timeout\n })) {\n yield {\n id: PeerId.parse(id),\n multiaddrs: addrs\n }\n providers++\n }\n } catch (err) {\n log.error('findProviders errored:', err)\n throw err\n } finally {\n onFinish.resolve()\n log(`findProviders finished: ${key} found ${providers} providers`)\n }\n }\n\n /**\n * Announce to the network that the delegated node can provide the given key.\n *\n * Currently this uses the following hack\n * - delegate is one of bootstrap nodes, so we are always connected to it\n * - call block stat on the delegated node, so it fetches the content\n * - call dht provide with the passed cid\n *\n * N.B. this must be called for every block in the dag you want provided otherwise\n * the delegate will only be able to supply the root block of the dag when asked\n * for the data by an interested peer.\n *\n * @param {CID} key - The delegate will publish a provider record for this CID\n * @returns {Promise<void>}\n */\n async provide (key) {\n log(`provide starts: ${key}`)\n await this._httpQueueRefs.add(async () => {\n await this._client.block.stat(key)\n await drain(this._client.dht.provide(key))\n })\n log(`provide finished: ${key}`)\n }\n}\n\nmodule.exports = DelegatedContentRouting\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multibases = require('ipfs-core-utils/multibases');\nvar multicodecs = require('ipfs-core-utils/multicodecs');\nvar multihashes = require('ipfs-core-utils/multihashes');\nvar dagPB = require('@ipld/dag-pb');\nvar dagCBOR = require('@ipld/dag-cbor');\nvar identity = require('multiformats/hashes/identity');\nvar basics = require('multiformats/basics');\nvar index = require('./bitswap/index.js');\nvar index$1 = require('./block/index.js');\nvar index$2 = require('./bootstrap/index.js');\nvar index$3 = require('./config/index.js');\nvar index$4 = require('./dag/index.js');\nvar index$5 = require('./dht/index.js');\nvar index$6 = require('./diag/index.js');\nvar index$7 = require('./files/index.js');\nvar index$8 = require('./key/index.js');\nvar index$9 = require('./log/index.js');\nvar index$a = require('./name/index.js');\nvar index$b = require('./object/index.js');\nvar index$c = require('./pin/index.js');\nvar index$d = require('./pubsub/index.js');\nvar index$e = require('./refs/index.js');\nvar index$f = require('./repo/index.js');\nvar index$g = require('./stats/index.js');\nvar index$h = require('./swarm/index.js');\nvar add = require('./add.js');\nvar addAll = require('./add-all.js');\nvar cat = require('./cat.js');\nvar commands = require('./commands.js');\nvar dns = require('./dns.js');\nvar getEndpointConfig = require('./get-endpoint-config.js');\nvar get = require('./get.js');\nvar id = require('./id.js');\nvar isOnline = require('./is-online.js');\nvar ls = require('./ls.js');\nvar mount = require('./mount.js');\nvar ping = require('./ping.js');\nvar resolve = require('./resolve.js');\nvar start = require('./start.js');\nvar stop = require('./stop.js');\nvar version = require('./version.js');\nvar globSourceImport = require('ipfs-utils/src/files/glob-source.js');\nvar cid = require('multiformats/cid');\nvar multiaddr = require('multiaddr');\nvar urlSource_js = require('ipfs-utils/src/files/url-source.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar dagPB__namespace = /*#__PURE__*/_interopNamespace(dagPB);\nvar dagCBOR__namespace = /*#__PURE__*/_interopNamespace(dagCBOR);\nvar globSourceImport__default = /*#__PURE__*/_interopDefaultLegacy(globSourceImport);\nvar urlSource_js__default = /*#__PURE__*/_interopDefaultLegacy(urlSource_js);\n\nfunction create(options = {}) {\n const id$1 = {\n name: identity.identity.name,\n code: identity.identity.code,\n encode: id => id,\n decode: id => id\n };\n const multibaseCodecs = Object.values(basics.bases);\n (options.ipld && options.ipld.bases ? options.ipld.bases : []).forEach(base => multibaseCodecs.push(base));\n const multibases$1 = new multibases.Multibases({\n bases: multibaseCodecs,\n loadBase: options.ipld && options.ipld.loadBase\n });\n const blockCodecs = Object.values(basics.codecs);\n [\n dagPB__namespace,\n dagCBOR__namespace,\n id$1\n ].concat(options.ipld && options.ipld.codecs || []).forEach(codec => blockCodecs.push(codec));\n const multicodecs$1 = new multicodecs.Multicodecs({\n codecs: blockCodecs,\n loadCodec: options.ipld && options.ipld.loadCodec\n });\n const multihashHashers = Object.values(basics.hashes);\n (options.ipld && options.ipld.hashers ? options.ipld.hashers : []).forEach(hasher => multihashHashers.push(hasher));\n const multihashes$1 = new multihashes.Multihashes({\n hashers: multihashHashers,\n loadHasher: options.ipld && options.ipld.loadHasher\n });\n const client = {\n add: add.createAdd(options),\n addAll: addAll.createAddAll(options),\n bitswap: index.createBitswap(options),\n block: index$1.createBlock(options),\n bootstrap: index$2.createBootstrap(options),\n cat: cat.createCat(options),\n commands: commands.createCommands(options),\n config: index$3.createConfig(options),\n dag: index$4.createDag(multicodecs$1, options),\n dht: index$5.createDht(options),\n diag: index$6.createDiag(options),\n dns: dns.createDns(options),\n files: index$7.createFiles(options),\n get: get.createGet(options),\n getEndpointConfig: getEndpointConfig.createGetEndpointConfig(options),\n id: id.createId(options),\n isOnline: isOnline.createIsOnline(options),\n key: index$8.createKey(options),\n log: index$9.createLog(options),\n ls: ls.createLs(options),\n mount: mount.createMount(options),\n name: index$a.createName(options),\n object: index$b.createObject(multicodecs$1, options),\n pin: index$c.createPin(options),\n ping: ping.createPing(options),\n pubsub: index$d.createPubsub(options),\n refs: index$e.createRefs(options),\n repo: index$f.createRepo(options),\n resolve: resolve.createResolve(options),\n start: start.createStart(options),\n stats: index$g.createStats(options),\n stop: stop.createStop(options),\n swarm: index$h.createSwarm(options),\n version: version.createVersion(options),\n bases: multibases$1,\n codecs: multicodecs$1,\n hashers: multihashes$1\n };\n return client;\n}\nconst globSource = globSourceImport__default['default'];\n\nObject.defineProperty(exports, 'CID', {\n enumerable: true,\n get: function () {\n return cid.CID;\n }\n});\nObject.defineProperty(exports, 'multiaddr', {\n enumerable: true,\n get: function () {\n return multiaddr.Multiaddr;\n }\n});\nObject.defineProperty(exports, 'urlSource', {\n enumerable: true,\n get: function () {\n return urlSource_js__default['default'];\n }\n});\nexports.create = create;\nexports.globSource = globSource;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst LOAD_BASE = name => Promise.reject(new Error(`No base found for \"${ name }\"`));\nclass Multibases {\n constructor(options) {\n this._basesByName = {};\n this._basesByPrefix = {};\n this._loadBase = options.loadBase || LOAD_BASE;\n for (const base of options.bases) {\n this.addBase(base);\n }\n }\n addBase(base) {\n if (this._basesByName[base.name] || this._basesByPrefix[base.prefix]) {\n throw new Error(`Codec already exists for codec \"${ base.name }\"`);\n }\n this._basesByName[base.name] = base;\n this._basesByPrefix[base.prefix] = base;\n }\n removeBase(base) {\n delete this._basesByName[base.name];\n delete this._basesByPrefix[base.prefix];\n }\n async getBase(nameOrPrefix) {\n if (this._basesByName[nameOrPrefix]) {\n return this._basesByName[nameOrPrefix];\n }\n if (this._basesByPrefix[nameOrPrefix]) {\n return this._basesByPrefix[nameOrPrefix];\n }\n const base = await this._loadBase(nameOrPrefix);\n if (this._basesByName[base.name] == null && this._basesByPrefix[base.prefix] == null) {\n this.addBase(base);\n }\n return base;\n }\n listBases() {\n return Object.values(this._basesByName);\n }\n}\n\nexports.Multibases = Multibases;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst LOAD_CODEC = codeOrName => Promise.reject(new Error(`No codec found for \"${ codeOrName }\"`));\nclass Multicodecs {\n constructor(options) {\n this._codecsByName = {};\n this._codecsByCode = {};\n this._loadCodec = options.loadCodec || LOAD_CODEC;\n for (const codec of options.codecs) {\n this.addCodec(codec);\n }\n }\n addCodec(codec) {\n if (this._codecsByName[codec.name] || this._codecsByCode[codec.code]) {\n throw new Error(`Resolver already exists for codec \"${ codec.name }\"`);\n }\n this._codecsByName[codec.name] = codec;\n this._codecsByCode[codec.code] = codec;\n }\n removeCodec(codec) {\n delete this._codecsByName[codec.name];\n delete this._codecsByCode[codec.code];\n }\n async getCodec(code) {\n const table = typeof code === 'string' ? this._codecsByName : this._codecsByCode;\n if (table[code]) {\n return table[code];\n }\n const codec = await this._loadCodec(code);\n if (table[code] == null) {\n this.addCodec(codec);\n }\n return codec;\n }\n listCodecs() {\n return Object.values(this._codecsByName);\n }\n}\n\nexports.Multicodecs = Multicodecs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst LOAD_HASHER = codeOrName => Promise.reject(new Error(`No hasher found for \"${ codeOrName }\"`));\nclass Multihashes {\n constructor(options) {\n this._hashersByName = {};\n this._hashersByCode = {};\n this._loadHasher = options.loadHasher || LOAD_HASHER;\n for (const hasher of options.hashers) {\n this.addHasher(hasher);\n }\n }\n addHasher(hasher) {\n if (this._hashersByName[hasher.name] || this._hashersByCode[hasher.code]) {\n throw new Error(`Resolver already exists for codec \"${ hasher.name }\"`);\n }\n this._hashersByName[hasher.name] = hasher;\n this._hashersByCode[hasher.code] = hasher;\n }\n removeHasher(hasher) {\n delete this._hashersByName[hasher.name];\n delete this._hashersByCode[hasher.code];\n }\n async getHasher(code) {\n const table = typeof code === 'string' ? this._hashersByName : this._hashersByCode;\n if (table[code]) {\n return table[code];\n }\n const hasher = await this._loadHasher(code);\n if (table[code] == null) {\n this.addHasher(hasher);\n }\n return hasher;\n }\n listHashers() {\n return Object.values(this._hashersByName);\n }\n}\n\nexports.Multihashes = Multihashes;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar wantlist = require('./wantlist.js');\nvar wantlistForPeer = require('./wantlist-for-peer.js');\nvar stat = require('./stat.js');\nvar unwant = require('./unwant.js');\n\nfunction createBitswap(config) {\n return {\n wantlist: wantlist.createWantlist(config),\n wantlistForPeer: wantlistForPeer.createWantlistForPeer(config),\n unwant: unwant.createUnwant(config),\n stat: stat.createStat(config)\n };\n}\n\nexports.createBitswap = createBitswap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createWantlist = configure.configure(api => {\n async function wantlist(options = {}) {\n const res = await (await api.post('bitswap/wantlist', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n })).json();\n return (res.Keys || []).map(k => cid.CID.parse(k['/']));\n }\n return wantlist;\n});\n\nexports.createWantlist = createWantlist;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar core = require('./core.js');\n\nconst configure = fn => {\n return options => {\n return fn(new core.Client(options), options);\n };\n};\n\nexports.configure = configure;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar env_js = require('ipfs-utils/src/env.js');\nvar parseDuration = require('parse-duration');\nvar debug = require('debug');\nvar HTTP = require('ipfs-utils/src/http.js');\nvar mergeOpts = require('merge-options');\nvar toUrlString = require('ipfs-core-utils/to-url-string');\nvar getAgent = require('ipfs-core-utils/agent');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar parseDuration__default = /*#__PURE__*/_interopDefaultLegacy(parseDuration);\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\nvar HTTP__default = /*#__PURE__*/_interopDefaultLegacy(HTTP);\nvar mergeOpts__default = /*#__PURE__*/_interopDefaultLegacy(mergeOpts);\nvar getAgent__default = /*#__PURE__*/_interopDefaultLegacy(getAgent);\n\nconst log = debug__default['default']('ipfs-http-client:lib:error-handler');\nconst merge = mergeOpts__default['default'].bind({ ignoreUndefined: true });\nconst DEFAULT_PROTOCOL = env_js.isBrowser || env_js.isWebWorker ? location.protocol : 'http';\nconst DEFAULT_HOST = env_js.isBrowser || env_js.isWebWorker ? location.hostname : 'localhost';\nconst DEFAULT_PORT = env_js.isBrowser || env_js.isWebWorker ? location.port : '5001';\nconst normalizeOptions = (options = {}) => {\n let url;\n let opts = {};\n let agent;\n if (typeof options === 'string' || multiaddr.Multiaddr.isMultiaddr(options)) {\n url = new URL(toUrlString.toUrlString(options));\n } else if (options instanceof URL) {\n url = options;\n } else if (typeof options.url === 'string' || multiaddr.Multiaddr.isMultiaddr(options.url)) {\n url = new URL(toUrlString.toUrlString(options.url));\n opts = options;\n } else if (options.url instanceof URL) {\n url = options.url;\n opts = options;\n } else {\n opts = options || {};\n const protocol = (opts.protocol || DEFAULT_PROTOCOL).replace(':', '');\n const host = (opts.host || DEFAULT_HOST).split(':')[0];\n const port = opts.port || DEFAULT_PORT;\n url = new URL(`${ protocol }://${ host }:${ port }`);\n }\n if (opts.apiPath) {\n url.pathname = opts.apiPath;\n } else if (url.pathname === '/' || url.pathname === undefined) {\n url.pathname = 'api/v0';\n }\n if (env_js.isNode) {\n const Agent = getAgent__default['default'](url);\n agent = opts.agent || new Agent({\n keepAlive: true,\n maxSockets: 6\n });\n }\n return {\n ...opts,\n host: url.host,\n protocol: url.protocol.replace(':', ''),\n port: Number(url.port),\n apiPath: url.pathname,\n url,\n agent\n };\n};\nconst errorHandler = async response => {\n let msg;\n try {\n if ((response.headers.get('Content-Type') || '').startsWith('application/json')) {\n const data = await response.json();\n log(data);\n msg = data.Message || data.message;\n } else {\n msg = await response.text();\n }\n } catch (err) {\n log('Failed to parse error response', err);\n msg = err.message;\n }\n let error = new HTTP__default['default'].HTTPError(response);\n if (msg) {\n if (msg.includes('deadline has elapsed')) {\n error = new HTTP__default['default'].TimeoutError();\n }\n if (msg && msg.includes('context deadline exceeded')) {\n error = new HTTP__default['default'].TimeoutError();\n }\n }\n if (msg && msg.includes('request timed out')) {\n error = new HTTP__default['default'].TimeoutError();\n }\n if (msg) {\n error.message = msg;\n }\n throw error;\n};\nconst KEBAB_REGEX = /[A-Z\\u00C0-\\u00D6\\u00D8-\\u00DE]/g;\nconst kebabCase = str => {\n return str.replace(KEBAB_REGEX, function (match) {\n return '-' + match.toLowerCase();\n });\n};\nconst parseTimeout = value => {\n return typeof value === 'string' ? parseDuration__default['default'](value) : value;\n};\nclass Client extends HTTP__default['default'] {\n constructor(options = {}) {\n const opts = normalizeOptions(options);\n super({\n timeout: parseTimeout(opts.timeout || 0) || undefined,\n headers: opts.headers,\n base: `${ opts.url }`,\n handleError: errorHandler,\n transformSearchParams: search => {\n const out = new URLSearchParams();\n for (const [key, value] of search) {\n if (value !== 'undefined' && value !== 'null' && key !== 'signal') {\n out.append(kebabCase(key), value);\n }\n if (key === 'timeout' && !isNaN(value)) {\n out.append(kebabCase(key), value);\n }\n }\n return out;\n },\n agent: opts.agent\n });\n delete this.get;\n delete this.put;\n delete this.delete;\n delete this.options;\n const fetch = this.fetch;\n this.fetch = (resource, options = {}) => {\n if (typeof resource === 'string' && !resource.startsWith('/')) {\n resource = `${ opts.url }/${ resource }`;\n }\n return fetch.call(this, resource, merge(options, { method: 'POST' }));\n };\n }\n}\nconst HTTPError = HTTP__default['default'].HTTPError;\n\nexports.Client = Client;\nexports.HTTPError = HTTPError;\nexports.errorHandler = errorHandler;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar multiAddrToUri = require('multiaddr-to-uri');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar multiAddrToUri__default = /*#__PURE__*/_interopDefaultLegacy(multiAddrToUri);\n\nfunction toUrlString(url) {\n try {\n url = multiAddrToUri__default['default'](new multiaddr.Multiaddr(url));\n } catch (err) {\n }\n url = url.toString();\n return url;\n}\n\nexports.toUrlString = toUrlString;\n","'use strict';\n\nvar agent_browser = () => {\n};\n\nmodule.exports = agent_browser;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar modeToString = require('./mode-to-string.js');\nvar parseMtime = require('./parse-mtime.js');\n\nfunction toUrlSearchParams({arg, searchParams, hashAlg, mtime, mode, ...options} = {}) {\n if (searchParams) {\n options = {\n ...options,\n ...searchParams\n };\n }\n if (hashAlg) {\n options.hash = hashAlg;\n }\n if (mtime != null) {\n mtime = parseMtime.parseMtime(mtime);\n options.mtime = mtime.secs;\n options.mtimeNsecs = mtime.nsecs;\n }\n if (mode != null) {\n options.mode = modeToString.modeToString(mode);\n }\n if (options.timeout && !isNaN(options.timeout)) {\n options.timeout = `${ options.timeout }ms`;\n }\n if (arg === undefined || arg === null) {\n arg = [];\n } else if (!Array.isArray(arg)) {\n arg = [arg];\n }\n const urlSearchParams = new URLSearchParams(options);\n arg.forEach(arg => urlSearchParams.append('arg', arg));\n return urlSearchParams;\n}\n\nexports.toUrlSearchParams = toUrlSearchParams;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction modeToString(mode) {\n if (mode == null) {\n return undefined;\n }\n if (typeof mode === 'string') {\n return mode;\n }\n return mode.toString(8).padStart(4, '0');\n}\n\nexports.modeToString = modeToString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction parseMtime(input) {\n if (input == null) {\n return undefined;\n }\n let mtime;\n if (input.secs != null) {\n mtime = {\n secs: input.secs,\n nsecs: input.nsecs\n };\n }\n if (input.Seconds != null) {\n mtime = {\n secs: input.Seconds,\n nsecs: input.FractionalNanoseconds\n };\n }\n if (Array.isArray(input)) {\n mtime = {\n secs: input[0],\n nsecs: input[1]\n };\n }\n if (input instanceof Date) {\n const ms = input.getTime();\n const secs = Math.floor(ms / 1000);\n mtime = {\n secs: secs,\n nsecs: (ms - secs * 1000) * 1000\n };\n }\n if (!Object.prototype.hasOwnProperty.call(mtime, 'secs')) {\n return undefined;\n }\n if (mtime != null && mtime.nsecs != null && (mtime.nsecs < 0 || mtime.nsecs > 999999999)) {\n throw errCode__default['default'](new Error('mtime-nsecs must be within the range [0,999999999]'), 'ERR_INVALID_MTIME_NSECS');\n }\n return mtime;\n}\n\nexports.parseMtime = parseMtime;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createWantlistForPeer = configure.configure(api => {\n async function wantlistForPeer(peerId, options = {}) {\n const res = await (await api.post('bitswap/wantlist', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n peer: peerId.toString()\n }),\n headers: options.headers\n })).json();\n return (res.Keys || []).map(k => cid.CID.parse(k['/']));\n }\n return wantlistForPeer;\n});\n\nexports.createWantlistForPeer = createWantlistForPeer;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(options = {}) {\n const res = await api.post('bitswap/stat', {\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n signal: options.signal,\n headers: options.headers\n });\n return toCoreInterface(await res.json());\n }\n return stat;\n});\nfunction toCoreInterface(res) {\n return {\n provideBufLen: res.ProvideBufLen,\n wantlist: (res.Wantlist || []).map(k => cid.CID.parse(k['/'])),\n peers: res.Peers || [],\n blocksReceived: BigInt(res.BlocksReceived),\n dataReceived: BigInt(res.DataReceived),\n blocksSent: BigInt(res.BlocksSent),\n dataSent: BigInt(res.DataSent),\n dupBlksReceived: BigInt(res.DupBlksReceived),\n dupDataReceived: BigInt(res.DupDataReceived)\n };\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createUnwant = configure.configure(api => {\n async function unwant(cid, options = {}) {\n const res = await api.post('bitswap/unwant', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.toString(),\n ...options\n }),\n headers: options.headers\n });\n return res.json();\n }\n return unwant;\n});\n\nexports.createUnwant = createUnwant;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar get = require('./get.js');\nvar put = require('./put.js');\nvar rm = require('./rm.js');\nvar stat = require('./stat.js');\n\nfunction createBlock(config) {\n return {\n get: get.createGet(config),\n put: put.createPut(config),\n rm: rm.createRm(config),\n stat: stat.createStat(config)\n };\n}\n\nexports.createBlock = createBlock;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGet = configure.configure(api => {\n async function get(cid, options = {}) {\n const res = await api.post('block/get', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.toString(),\n ...options\n }),\n headers: options.headers\n });\n return new Uint8Array(await res.arrayBuffer());\n }\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createPut = configure.configure(api => {\n async function put(data, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n let res;\n try {\n const response = await api.post('block/put', {\n signal: signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n ...await multipartRequest.multipartRequest(data, controller, options.headers)\n });\n res = await response.json();\n } catch (err) {\n if (options.format === 'dag-pb') {\n return put(data, {\n ...options,\n format: 'protobuf'\n });\n } else if (options.format === 'dag-cbor') {\n return put(data, {\n ...options,\n format: 'cbor'\n });\n }\n throw err;\n }\n return cid.CID.parse(res.Key);\n }\n return put;\n});\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseInput_browser = require('./files/normalise-input.browser.js');\nvar modeToString = require('./mode-to-string.js');\n\nasync function multipartRequest(source, abortController, headers = {}) {\n const parts = [];\n const formData = new FormData();\n let index = 0;\n let total = 0;\n for await (const {content, path, mode, mtime} of normaliseInput_browser.normaliseInput(source)) {\n let fileSuffix = '';\n const type = content ? 'file' : 'dir';\n if (index > 0) {\n fileSuffix = `-${ index }`;\n }\n let fieldName = type + fileSuffix;\n const qs = [];\n if (mode !== null && mode !== undefined) {\n qs.push(`mode=${ modeToString.modeToString(mode) }`);\n }\n if (mtime != null) {\n const {secs, nsecs} = mtime;\n qs.push(`mtime=${ secs }`);\n if (nsecs != null) {\n qs.push(`mtime-nsecs=${ nsecs }`);\n }\n }\n if (qs.length) {\n fieldName = `${ fieldName }?${ qs.join('&') }`;\n }\n if (content) {\n formData.set(fieldName, content, path != null ? encodeURIComponent(path) : undefined);\n const end = total + content.size;\n parts.push({\n name: path,\n start: total,\n end\n });\n total = end;\n } else if (path != null) {\n formData.set(fieldName, new File([''], encodeURIComponent(path), { type: 'application/x-directory' }));\n } else {\n throw new Error('path or content or both must be set');\n }\n index++;\n }\n return {\n total,\n parts,\n headers,\n body: formData\n };\n}\n\nexports.multipartRequest = multipartRequest;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar normaliseContent_browser = require('./normalise-content.browser.js');\nvar normalise = require('./normalise.js');\n\nfunction normaliseInput(input) {\n return normalise.normalise(input, normaliseContent_browser.normaliseContent);\n}\n\nexports.normaliseInput = normaliseInput;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\nvar itPeekable = require('it-peekable');\nvar browserStreamToIt = require('browser-readablestream-to-it');\nvar all = require('it-all');\nvar utils = require('./utils.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar itPeekable__default = /*#__PURE__*/_interopDefaultLegacy(itPeekable);\nvar browserStreamToIt__default = /*#__PURE__*/_interopDefaultLegacy(browserStreamToIt);\nvar all__default = /*#__PURE__*/_interopDefaultLegacy(all);\n\nasync function normaliseContent(input) {\n if (utils.isBytes(input)) {\n return new Blob([input]);\n }\n if (typeof input === 'string' || input instanceof String) {\n return new Blob([input.toString()]);\n }\n if (utils.isBlob(input)) {\n return input;\n }\n if (utils.isReadableStream(input)) {\n input = browserStreamToIt__default['default'](input);\n }\n if (Symbol.iterator in input || Symbol.asyncIterator in input) {\n const peekable = itPeekable__default['default'](input);\n const {value, done} = await peekable.peek();\n if (done) {\n return itToBlob(peekable);\n }\n peekable.push(value);\n if (Number.isInteger(value)) {\n return new Blob([Uint8Array.from(await all__default['default'](peekable))]);\n }\n if (utils.isBytes(value) || typeof value === 'string' || value instanceof String) {\n return itToBlob(peekable);\n }\n }\n throw errCode__default['default'](new Error(`Unexpected input: ${ input }`), 'ERR_UNEXPECTED_INPUT');\n}\nasync function itToBlob(stream) {\n const parts = [];\n for await (const chunk of stream) {\n parts.push(chunk);\n }\n return new Blob(parts);\n}\n\nexports.normaliseContent = normaliseContent;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction modeToString(mode) {\n if (mode == null) {\n return undefined;\n }\n if (typeof mode === 'string') {\n return mode;\n }\n return mode.toString(8).padStart(4, '0');\n}\n\nexports.modeToString = modeToString;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar anySignal = require('any-signal');\n\nfunction filter(signals) {\n return signals.filter(Boolean);\n}\nfunction abortSignal(...signals) {\n return anySignal.anySignal(filter(signals));\n}\n\nexports.abortSignal = abortSignal;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRm = configure.configure(api => {\n async function* rm(cid, options = {}) {\n if (!Array.isArray(cid)) {\n cid = [cid];\n }\n const res = await api.post('block/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.map(cid => cid.toString()),\n 'stream-channels': true,\n ...options\n }),\n headers: options.headers\n });\n for await (const removed of res.ndjson()) {\n yield toCoreInterface(removed);\n }\n }\n return rm;\n});\nfunction toCoreInterface(removed) {\n const out = { cid: cid.CID.parse(removed.Hash) };\n if (removed.Error) {\n out.error = new Error(removed.Error);\n }\n return out;\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(cid$1, options = {}) {\n const res = await api.post('block/stat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid$1.toString(),\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return {\n cid: cid.CID.parse(data.Key),\n size: data.Size\n };\n }\n return stat;\n});\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar add = require('./add.js');\nvar clear = require('./clear.js');\nvar list = require('./list.js');\nvar reset = require('./reset.js');\nvar rm = require('./rm.js');\n\nfunction createBootstrap(config) {\n return {\n add: add.createAdd(config),\n clear: clear.createClear(config),\n list: list.createList(config),\n reset: reset.createReset(config),\n rm: rm.createRm(config)\n };\n}\n\nexports.createBootstrap = createBootstrap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createAdd = configure.configure(api => {\n async function add(addr, options = {}) {\n const res = await api.post('bootstrap/add', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: addr,\n ...options\n }),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return add;\n});\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createClear = configure.configure(api => {\n async function clear(options = {}) {\n const res = await api.post('bootstrap/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n all: true\n }),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return clear;\n});\n\nexports.createClear = createClear;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createList = configure.configure(api => {\n async function list(options = {}) {\n const res = await api.post('bootstrap/list', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return list;\n});\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createReset = configure.configure(api => {\n async function reset(options = {}) {\n const res = await api.post('bootstrap/add', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n default: true\n }),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return reset;\n});\n\nexports.createReset = createReset;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multiaddr = require('multiaddr');\n\nconst createRm = configure.configure(api => {\n async function rm(addr, options = {}) {\n const res = await api.post('bootstrap/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: addr,\n ...options\n }),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return { Peers: Peers.map(ma => new multiaddr.Multiaddr(ma)) };\n }\n return rm;\n});\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('./profiles/index.js');\nvar get = require('./get.js');\nvar getAll = require('./get-all.js');\nvar replace = require('./replace.js');\nvar set = require('./set.js');\n\nfunction createConfig(config) {\n return {\n getAll: getAll.createGetAll(config),\n get: get.createGet(config),\n set: set.createSet(config),\n replace: replace.createReplace(config),\n profiles: index.createProfiles(config)\n };\n}\n\nexports.createConfig = createConfig;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar apply = require('./apply.js');\nvar list = require('./list.js');\n\nfunction createProfiles(config) {\n return {\n apply: apply.createApply(config),\n list: list.createList(config)\n };\n}\n\nexports.createProfiles = createProfiles;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createApply = configure.configure(api => {\n async function apply(profile, options = {}) {\n const res = await api.post('config/profile/apply', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: profile,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return {\n original: data.OldCfg,\n updated: data.NewCfg\n };\n }\n return apply;\n});\n\nexports.createApply = createApply;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../../lib/object-to-camel.js');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createList = configure.configure(api => {\n async function list(options = {}) {\n const res = await api.post('config/profile/list', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return data.map(profile => objectToCamel.objectToCamel(profile));\n }\n return list;\n});\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction objectToCamel(obj) {\n if (obj == null) {\n return obj;\n }\n const caps = /^[A-Z]+$/;\n const output = {};\n return Object.keys(obj).reduce((camelObj, k) => {\n if (caps.test(k)) {\n camelObj[k.toLowerCase()] = obj[k];\n } else if (caps.test(k[0])) {\n camelObj[k[0].toLowerCase() + k.slice(1)] = obj[k];\n } else {\n camelObj[k] = obj[k];\n }\n return camelObj;\n }, output);\n}\n\nexports.objectToCamel = objectToCamel;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGet = configure.configure(api => {\n const get = async (key, options = {}) => {\n if (!key) {\n throw new Error('key argument is required');\n }\n const res = await api.post('config', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: key,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return data.Value;\n };\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGetAll = configure.configure(api => {\n const getAll = async (options = {}) => {\n const res = await api.post('config/show', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({ ...options }),\n headers: options.headers\n });\n const data = await res.json();\n return data;\n };\n return getAll;\n});\n\nexports.createGetAll = createGetAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar fromString = require('uint8arrays/from-string');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createReplace = configure.configure(api => {\n const replace = async (config, options = {}) => {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('config/replace', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n ...await multipartRequest.multipartRequest(fromString.fromString(JSON.stringify(config)), controller, options.headers)\n });\n await res.text();\n };\n return replace;\n});\n\nexports.createReplace = createReplace;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createSet = configure.configure(api => {\n const set = async (key, value, options = {}) => {\n if (typeof key !== 'string') {\n throw new Error('Invalid key type');\n }\n const params = {\n ...options,\n ...encodeParam(key, value)\n };\n const res = await api.post('config', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(params),\n headers: options.headers\n });\n await res.text();\n };\n return set;\n});\nconst encodeParam = (key, value) => {\n switch (typeof value) {\n case 'boolean':\n return {\n arg: [\n key,\n value.toString()\n ],\n bool: true\n };\n case 'string':\n return {\n arg: [\n key,\n value\n ]\n };\n default:\n return {\n arg: [\n key,\n JSON.stringify(value)\n ],\n json: true\n };\n }\n};\n\nexports.createSet = createSet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _export = require('./export.js');\nvar get = require('./get.js');\nvar _import = require('./import.js');\nvar put = require('./put.js');\nvar resolve = require('./resolve.js');\n\nfunction createDag(codecs, config) {\n return {\n export: _export.createExport(config),\n get: get.createGet(codecs, config),\n import: _import.createImport(config),\n put: put.createPut(codecs, config),\n resolve: resolve.createResolve(config)\n };\n}\n\nexports.createDag = createDag;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createExport = configure.configure(api => {\n async function* dagExport(root, options = {}) {\n const res = await api.post('dag/export', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({ arg: root.toString() }),\n headers: options.headers\n });\n yield* res.iterator();\n }\n return dagExport;\n});\n\nexports.createExport = createExport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar resolve = require('../lib/resolve.js');\nvar first = require('it-first');\nvar last = require('it-last');\nvar errCode = require('err-code');\nvar get = require('../block/get.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar first__default = /*#__PURE__*/_interopDefaultLegacy(first);\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst createGet = (codecs, options) => {\n const fn = configure.configure((api, opts) => {\n const getBlock = get.createGet(opts);\n const get$1 = async (cid, options = {}) => {\n if (options.path) {\n const entry = options.localResolve ? await first__default['default'](resolve.resolve(cid, options.path, codecs, getBlock, options)) : await last__default['default'](resolve.resolve(cid, options.path, codecs, getBlock, options));\n const result = entry;\n if (!result) {\n throw errCode__default['default'](new Error('Not found'), 'ERR_NOT_FOUND');\n }\n return result;\n }\n const codec = await codecs.getCodec(cid.code);\n const block = await getBlock(cid, options);\n const node = codec.decode(block);\n return {\n value: node,\n remainderPath: ''\n };\n };\n return get$1;\n });\n return fn(options);\n};\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nasync function* resolve(cid$1, path, codecs, getBlock, options) {\n const load = async cid => {\n const codec = await codecs.getCodec(cid.code);\n const block = await getBlock(cid, options);\n return codec.decode(block);\n };\n const parts = path.split('/').filter(Boolean);\n let value = await load(cid$1);\n let lastCid = cid$1;\n if (!parts.length) {\n yield {\n value,\n remainderPath: ''\n };\n }\n while (parts.length) {\n const key = parts.shift();\n if (!key) {\n throw errCode__default['default'](new Error(`Could not resolve path \"${ path }\"`), 'ERR_INVALID_PATH');\n }\n if (Object.prototype.hasOwnProperty.call(value, key)) {\n value = value[key];\n yield {\n value,\n remainderPath: parts.join('/')\n };\n } else {\n throw errCode__default['default'](new Error(`no link named \"${ key }\" under ${ lastCid }`), 'ERR_NO_LINK');\n }\n const cid$1 = cid.CID.asCID(value);\n if (cid$1) {\n lastCid = cid$1;\n value = await load(value);\n }\n }\n}\n\nexports.resolve = resolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar nativeAbortController = require('native-abort-controller');\nvar cid = require('multiformats/cid');\n\nconst createImport = configure.configure(api => {\n async function* dagImport(source, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const {headers, body} = await multipartRequest.multipartRequest(source, controller, options.headers);\n const res = await api.post('dag/import', {\n signal,\n headers,\n body,\n searchParams: toUrlSearchParams.toUrlSearchParams({ 'pin-roots': options.pinRoots })\n });\n for await (const {Root} of res.ndjson()) {\n if (Root !== undefined) {\n const {\n Cid: {'/': Cid},\n PinErrorMsg\n } = Root;\n yield {\n root: {\n cid: cid.CID.parse(Cid),\n pinErrorMsg: PinErrorMsg\n }\n };\n }\n }\n }\n return dagImport;\n});\n\nexports.createImport = createImport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createPut = (codecs, options) => {\n const fn = configure.configure(api => {\n const put = async (dagNode, options = {}) => {\n const settings = {\n format: 'dag-cbor',\n hashAlg: 'sha2-256',\n inputEnc: 'raw',\n ...options\n };\n const codec = await codecs.getCodec(settings.format);\n const serialized = codec.encode(dagNode);\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, settings.signal);\n const res = await api.post('dag/put', {\n timeout: settings.timeout,\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(settings),\n ...await multipartRequest.multipartRequest(serialized, controller, settings.headers)\n });\n const data = await res.json();\n return cid.CID.parse(data.Cid['/']);\n };\n return put;\n });\n return fn(options);\n};\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createResolve = configure.configure(api => {\n const resolve = async (ipfsPath, options = {}) => {\n const res = await api.post('dag/resolve', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ ipfsPath }${ options.path ? `/${ options.path }`.replace(/\\/[/]+/g, '/') : '' }`,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return {\n cid: cid.CID.parse(data.Cid['/']),\n remainderPath: data.RemPath\n };\n };\n return resolve;\n});\n\nexports.createResolve = createResolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar findPeer = require('./find-peer.js');\nvar findProvs = require('./find-provs.js');\nvar get = require('./get.js');\nvar provide = require('./provide.js');\nvar put = require('./put.js');\nvar query = require('./query.js');\n\nfunction createDht(config) {\n return {\n findPeer: findPeer.createFindPeer(config),\n findProvs: findProvs.createFindProvs(config),\n get: get.createGet(config),\n provide: provide.createProvide(config),\n put: put.createPut(config),\n query: query.createQuery(config)\n };\n}\n\nexports.createDht = createDht;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar responseTypes = require('./response-types.js');\n\nconst createFindPeer = configure.configure(api => {\n async function findPeer(peerId, options = {}) {\n const res = await api.post('dht/findpeer', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: peerId,\n ...options\n }),\n headers: options.headers\n });\n for await (const data of res.ndjson()) {\n if (data.Type === responseTypes.FinalPeer && data.Responses) {\n const {ID, Addrs} = data.Responses[0];\n return {\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n };\n }\n }\n throw new Error('not found');\n }\n return findPeer;\n});\n\nexports.createFindPeer = createFindPeer;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst SendingQuery = 0;\nconst PeerResponse = 1;\nconst FinalPeer = 2;\nconst QueryError = 3;\nconst Provider = 4;\nconst Value = 5;\nconst AddingPeer = 6;\nconst DialingPeer = 7;\n\nexports.AddingPeer = AddingPeer;\nexports.DialingPeer = DialingPeer;\nexports.FinalPeer = FinalPeer;\nexports.PeerResponse = PeerResponse;\nexports.Provider = Provider;\nexports.QueryError = QueryError;\nexports.SendingQuery = SendingQuery;\nexports.Value = Value;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar responseTypes = require('./response-types.js');\n\nconst createFindProvs = configure.configure(api => {\n async function* findProvs(cid, options = {}) {\n const res = await api.post('dht/findprovs', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.toString(),\n ...options\n }),\n headers: options.headers\n });\n for await (const message of res.ndjson()) {\n if (message.Type === responseTypes.Provider && message.Responses) {\n for (const {ID, Addrs} of message.Responses) {\n yield {\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n };\n }\n }\n }\n }\n return findProvs;\n});\n\nexports.createFindProvs = createFindProvs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar responseTypes = require('./response-types.js');\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\n\nconst createGet = configure.configure(api => {\n async function get(key, options = {}) {\n const res = await api.post('dht/get', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: key instanceof Uint8Array ? toString.toString(key) : key,\n ...options\n }),\n headers: options.headers\n });\n for await (const message of res.ndjson()) {\n if (message.Type === responseTypes.Value) {\n return fromString.fromString(message.Extra, 'base64pad');\n }\n }\n throw new Error('not found');\n }\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createProvide = configure.configure(api => {\n async function* provide(cids, options = { recursive: false }) {\n const cidArr = Array.isArray(cids) ? cids : [cids];\n const res = await api.post('dht/provide', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cidArr.map(cid => cid.toString()),\n ...options\n }),\n headers: options.headers\n });\n for await (let message of res.ndjson()) {\n message = objectToCamel.objectToCamel(message);\n if (message.responses) {\n message.responses = message.responses.map(({ID, Addrs}) => ({\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n }));\n } else {\n message.responses = [];\n }\n yield message;\n }\n }\n return provide;\n});\n\nexports.createProvide = createProvide;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\nvar toString = require('uint8arrays/to-string');\n\nconst createPut = configure.configure(api => {\n async function* put(key, value, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('dht/put', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: toString.toString(key),\n ...options\n }),\n ...await multipartRequest.multipartRequest(value, controller, options.headers)\n });\n for await (let message of res.ndjson()) {\n message = objectToCamel.objectToCamel(message);\n if (message.responses) {\n message.responses = message.responses.map(({ID, Addrs}) => ({\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n }));\n }\n yield message;\n }\n }\n return put;\n});\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createQuery = configure.configure(api => {\n async function* query(peerId, options = {}) {\n const res = await api.post('dht/query', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: peerId.toString(),\n ...options\n }),\n headers: options.headers\n });\n for await (let message of res.ndjson()) {\n message = objectToCamel.objectToCamel(message);\n message.responses = (message.responses || []).map(({ID, Addrs}) => ({\n id: ID,\n addrs: (Addrs || []).map(a => new multiaddr.Multiaddr(a))\n }));\n yield message;\n }\n }\n return query;\n});\n\nexports.createQuery = createQuery;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cmds = require('./cmds.js');\nvar net = require('./net.js');\nvar sys = require('./sys.js');\n\nfunction createDiag(config) {\n return {\n cmds: cmds.createCmds(config),\n net: net.createNet(config),\n sys: sys.createSys(config)\n };\n}\n\nexports.createDiag = createDiag;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createCmds = configure.configure(api => {\n async function cmds(options = {}) {\n const res = await api.post('diag/cmds', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return res.json();\n }\n return cmds;\n});\n\nexports.createCmds = createCmds;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createNet = configure.configure(api => {\n async function net(options = {}) {\n const res = await api.post('diag/net', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return res.json();\n }\n return net;\n});\n\nexports.createNet = createNet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createSys = configure.configure(api => {\n async function sys(options = {}) {\n const res = await api.post('diag/sys', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return res.json();\n }\n return sys;\n});\n\nexports.createSys = createSys;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar chmod = require('./chmod.js');\nvar cp = require('./cp.js');\nvar flush = require('./flush.js');\nvar ls = require('./ls.js');\nvar mkdir = require('./mkdir.js');\nvar mv = require('./mv.js');\nvar read = require('./read.js');\nvar rm = require('./rm.js');\nvar stat = require('./stat.js');\nvar touch = require('./touch.js');\nvar write = require('./write.js');\n\nfunction createFiles(config) {\n return {\n chmod: chmod.createChmod(config),\n cp: cp.createCp(config),\n flush: flush.createFlush(config),\n ls: ls.createLs(config),\n mkdir: mkdir.createMkdir(config),\n mv: mv.createMv(config),\n read: read.createRead(config),\n rm: rm.createRm(config),\n stat: stat.createStat(config),\n touch: touch.createTouch(config),\n write: write.createWrite(config)\n };\n}\n\nexports.createFiles = createFiles;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createChmod = configure.configure(api => {\n async function chmod(path, mode, options = {}) {\n const res = await api.post('files/chmod', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n mode,\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return chmod;\n});\n\nexports.createChmod = createChmod;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createCp = configure.configure(api => {\n async function cp(sources, destination, options = {}) {\n const sourceArr = Array.isArray(sources) ? sources : [sources];\n const res = await api.post('files/cp', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: sourceArr.concat(destination).map(src => cid.CID.asCID(src) ? `/ipfs/${ src }` : src),\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return cp;\n});\n\nexports.createCp = createCp;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createFlush = configure.configure(api => {\n async function flush(path, options = {}) {\n if (!path || typeof path !== 'string') {\n throw new Error('ipfs.files.flush requires a path');\n }\n const res = await api.post('files/flush', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return cid.CID.parse(data.Cid);\n }\n return flush;\n});\n\nexports.createFlush = createFlush;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar objectToCamelWithMetadata = require('../lib/object-to-camel-with-metadata.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLs = configure.configure(api => {\n async function* ls(path, options = {}) {\n if (!path) {\n throw new Error('ipfs.files.ls requires a path');\n }\n const res = await api.post('files/ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: cid.CID.asCID(path) ? `/ipfs/${ path }` : path,\n long: true,\n ...options,\n stream: true\n }),\n headers: options.headers\n });\n for await (const result of res.ndjson()) {\n if ('Entries' in result) {\n for (const entry of result.Entries || []) {\n yield toCoreInterface(objectToCamelWithMetadata.objectToCamelWithMetadata(entry));\n }\n } else {\n yield toCoreInterface(objectToCamelWithMetadata.objectToCamelWithMetadata(result));\n }\n }\n }\n return ls;\n});\nfunction toCoreInterface(entry) {\n if (entry.hash) {\n entry.cid = cid.CID.parse(entry.hash);\n }\n delete entry.hash;\n entry.type = entry.type === 1 ? 'directory' : 'file';\n return entry;\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./object-to-camel.js');\n\nfunction objectToCamelWithMetadata(entry) {\n const file = objectToCamel.objectToCamel(entry);\n if (Object.prototype.hasOwnProperty.call(file, 'mode')) {\n file.mode = parseInt(file.mode, 8);\n }\n if (Object.prototype.hasOwnProperty.call(file, 'mtime')) {\n file.mtime = {\n secs: file.mtime,\n nsecs: file.mtimeNsecs || 0\n };\n delete file.mtimeNsecs;\n }\n return file;\n}\n\nexports.objectToCamelWithMetadata = objectToCamelWithMetadata;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createMkdir = configure.configure(api => {\n async function mkdir(path, options = {}) {\n const res = await api.post('files/mkdir', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return mkdir;\n});\n\nexports.createMkdir = createMkdir;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createMv = configure.configure(api => {\n async function mv(sources, destination, options = {}) {\n if (!Array.isArray(sources)) {\n sources = [sources];\n }\n const res = await api.post('files/mv', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: sources.concat(destination),\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return mv;\n});\n\nexports.createMv = createMv;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar toIterable = require('stream-to-it/source.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar toIterable__default = /*#__PURE__*/_interopDefaultLegacy(toIterable);\n\nconst createRead = configure.configure(api => {\n async function* read(path, options = {}) {\n const res = await api.post('files/read', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n count: options.length,\n ...options\n }),\n headers: options.headers\n });\n yield* toIterable__default['default'](res.body);\n }\n return read;\n});\n\nexports.createRead = createRead;\n","module.exports = readable => {\n // Node.js stream\n if (readable[Symbol.asyncIterator]) return readable\n\n // Browser ReadableStream\n if (readable.getReader) {\n return (async function * () {\n const reader = readable.getReader()\n\n try {\n while (true) {\n const { done, value } = await reader.read()\n if (done) return\n yield value\n }\n } finally {\n reader.releaseLock()\n }\n })()\n }\n\n throw new Error('unknown stream')\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRm = configure.configure(api => {\n async function rm(path, options = {}) {\n const res = await api.post('files/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return rm;\n});\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar objectToCamelWithMetadata = require('../lib/object-to-camel-with-metadata.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(path, options = {}) {\n const res = await api.post('files/stat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n data.WithLocality = data.WithLocality || false;\n return toCoreInterface(objectToCamelWithMetadata.objectToCamelWithMetadata(data));\n }\n return stat;\n});\nfunction toCoreInterface(entry) {\n entry.cid = cid.CID.parse(entry.hash);\n delete entry.hash;\n return entry;\n}\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createTouch = configure.configure(api => {\n async function touch(path, options = {}) {\n const res = await api.post('files/touch', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n await res.text();\n }\n return touch;\n});\n\nexports.createTouch = createTouch;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar modeToString = require('../lib/mode-to-string.js');\nvar parseMtime = require('../lib/parse-mtime.js');\nvar configure = require('../lib/configure.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createWrite = configure.configure(api => {\n async function write(path, input, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('files/write', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n streamChannels: true,\n count: options.length,\n ...options\n }),\n ...await multipartRequest.multipartRequest({\n content: input,\n path: 'arg',\n mode: modeToString.modeToString(options.mode),\n mtime: parseMtime.parseMtime(options.mtime)\n }, controller, options.headers)\n });\n await res.text();\n }\n return write;\n});\n\nexports.createWrite = createWrite;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar _export = require('./export.js');\nvar gen = require('./gen.js');\nvar _import = require('./import.js');\nvar info = require('./info.js');\nvar list = require('./list.js');\nvar rename = require('./rename.js');\nvar rm = require('./rm.js');\n\nfunction createKey(config) {\n return {\n export: _export.createExport(config),\n gen: gen.createGen(config),\n import: _import.createImport(config),\n info: info.createInfo(config),\n list: list.createList(config),\n rename: rename.createRename(config),\n rm: rm.createRm(config)\n };\n}\n\nexports.createKey = createKey;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst createExport = configure.configure(api => {\n const exportKey = async (name, password, options = {}) => {\n throw errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED');\n };\n return exportKey;\n});\n\nexports.createExport = createExport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGen = configure.configure(api => {\n async function gen(name, options = {\n type: 'rsa',\n size: 2048\n }) {\n const res = await api.post('key/gen', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: name,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return objectToCamel.objectToCamel(data);\n }\n return gen;\n});\n\nexports.createGen = createGen;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createImport = configure.configure(api => {\n async function importKey(name, pem, password, options = {}) {\n const res = await api.post('key/import', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: name,\n pem,\n password,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return objectToCamel.objectToCamel(data);\n }\n return importKey;\n});\n\nexports.createImport = createImport;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst createInfo = configure.configure(api => {\n const info = async (name, options = {}) => {\n throw errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED');\n };\n return info;\n});\n\nexports.createInfo = createInfo;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createList = configure.configure(api => {\n async function list(options = {}) {\n const res = await api.post('key/list', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return (data.Keys || []).map(k => objectToCamel.objectToCamel(k));\n }\n return list;\n});\n\nexports.createList = createList;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRename = configure.configure(api => {\n async function rename(oldName, newName, options = {}) {\n const res = await api.post('key/rename', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n oldName,\n newName\n ],\n ...options\n }),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return rename;\n});\n\nexports.createRename = createRename;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRm = configure.configure(api => {\n async function rm(name, options = {}) {\n const res = await api.post('key/rm', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: name,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return objectToCamel.objectToCamel(data.Keys[0]);\n }\n return rm;\n});\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar level = require('./level.js');\nvar ls = require('./ls.js');\nvar tail = require('./tail.js');\n\nfunction createLog(config) {\n return {\n level: level.createLevel(config),\n ls: ls.createLs(config),\n tail: tail.createTail(config)\n };\n}\n\nexports.createLog = createLog;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLevel = configure.configure(api => {\n async function level(subsystem, level, options = {}) {\n const res = await api.post('log/level', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n subsystem,\n level\n ],\n ...options\n }),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return level;\n});\n\nexports.createLevel = createLevel;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLs = configure.configure(api => {\n async function ls(options = {}) {\n const res = await api.post('log/ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return data.Strings;\n }\n return ls;\n});\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createTail = configure.configure(api => {\n async function* tail(options = {}) {\n const res = await api.post('log/tail', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n yield* res.ndjson();\n }\n return tail;\n});\n\nexports.createTail = createTail;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar publish = require('./publish.js');\nvar resolve = require('./resolve.js');\nvar index = require('./pubsub/index.js');\n\nfunction createName(config) {\n return {\n publish: publish.createPublish(config),\n resolve: resolve.createResolve(config),\n pubsub: index.createPubsub(config)\n };\n}\n\nexports.createName = createName;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createPublish = configure.configure(api => {\n async function publish(path, options = {}) {\n const res = await api.post('name/publish', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ path }`,\n ...options\n }),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return publish;\n});\n\nexports.createPublish = createPublish;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createResolve = configure.configure(api => {\n async function* resolve(path, options = {}) {\n const res = await api.post('name/resolve', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n stream: true,\n ...options\n }),\n headers: options.headers\n });\n for await (const result of res.ndjson()) {\n yield result.Path;\n }\n }\n return resolve;\n});\n\nexports.createResolve = createResolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cancel = require('./cancel.js');\nvar state = require('./state.js');\nvar subs = require('./subs.js');\n\nfunction createPubsub(config) {\n return {\n cancel: cancel.createCancel(config),\n state: state.createState(config),\n subs: subs.createSubs(config)\n };\n}\n\nexports.createPubsub = createPubsub;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../../lib/object-to-camel.js');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createCancel = configure.configure(api => {\n async function cancel(name, options = {}) {\n const res = await api.post('name/pubsub/cancel', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: name,\n ...options\n }),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return cancel;\n});\n\nexports.createCancel = createCancel;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../../lib/object-to-camel.js');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createState = configure.configure(api => {\n async function state(options = {}) {\n const res = await api.post('name/pubsub/state', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return state;\n});\n\nexports.createState = createState;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createSubs = configure.configure(api => {\n async function subs(options = {}) {\n const res = await api.post('name/pubsub/subs', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return data.Strings || [];\n }\n return subs;\n});\n\nexports.createSubs = createSubs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar data = require('./data.js');\nvar get = require('./get.js');\nvar links = require('./links.js');\nvar _new = require('./new.js');\nvar put = require('./put.js');\nvar stat = require('./stat.js');\nvar index = require('./patch/index.js');\n\nfunction createObject(codecs, config) {\n return {\n data: data.createData(config),\n get: get.createGet(config),\n links: links.createLinks(config),\n new: _new.createNew(config),\n put: put.createPut(codecs, config),\n stat: stat.createStat(config),\n patch: index.createPatch(config)\n };\n}\n\nexports.createObject = createObject;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createData = configure.configure(api => {\n async function data(cid$1, options = {}) {\n const res = await api.post('object/data', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 instanceof Uint8Array ? cid.CID.decode(cid$1) : cid$1 }`,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.arrayBuffer();\n return new Uint8Array(data, 0, data.byteLength);\n }\n return data;\n});\n\nexports.createData = createData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar fromString = require('uint8arrays/from-string');\n\nconst createGet = configure.configure(api => {\n async function get(cid$1, options = {}) {\n const res = await api.post('object/get', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 instanceof Uint8Array ? cid.CID.decode(cid$1) : cid$1 }`,\n dataEncoding: 'base64',\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return {\n Data: fromString.fromString(data.Data, 'base64pad'),\n Links: (data.Links || []).map(link => ({\n Name: link.Name,\n Hash: cid.CID.parse(link.Hash),\n Tsize: link.Size\n }))\n };\n }\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLinks = configure.configure(api => {\n async function links(cid$1, options = {}) {\n const res = await api.post('object/links', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 instanceof Uint8Array ? cid.CID.decode(cid$1) : cid$1 }`,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return (data.Links || []).map(l => ({\n Name: l.Name,\n Tsize: l.Size,\n Hash: cid.CID.parse(l.Hash)\n }));\n }\n return links;\n});\n\nexports.createLinks = createLinks;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createNew = configure.configure(api => {\n async function newObject(options = {}) {\n const res = await api.post('object/new', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: options.template,\n ...options\n }),\n headers: options.headers\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return newObject;\n});\n\nexports.createNew = createNew;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar put = require('../dag/put.js');\n\nconst createPut = (codecs, options) => {\n const fn = configure.configure(api => {\n const dagPut = put.createPut(codecs, options);\n async function put$1(obj, options = {}) {\n return dagPut(obj, {\n ...options,\n format: 'dag-pb',\n hashAlg: 'sha2-256',\n version: 0\n });\n }\n return put$1;\n });\n return fn(options);\n};\n\nexports.createPut = createPut;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(cid$1, options = {}) {\n const res = await api.post('object/stat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 }`,\n ...options\n }),\n headers: options.headers\n });\n const output = await res.json();\n return {\n ...output,\n Hash: cid.CID.parse(output.Hash)\n };\n }\n return stat;\n});\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addLink = require('./add-link.js');\nvar appendData = require('./append-data.js');\nvar rmLink = require('./rm-link.js');\nvar setData = require('./set-data.js');\n\nfunction createPatch(config) {\n return {\n addLink: addLink.createAddLink(config),\n appendData: appendData.createAppendData(config),\n rmLink: rmLink.createRmLink(config),\n setData: setData.createSetData(config)\n };\n}\n\nexports.createPatch = createPatch;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createAddLink = configure.configure(api => {\n async function addLink(cid$1, dLink, options = {}) {\n const res = await api.post('object/patch/add-link', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n `${ cid$1 }`,\n dLink.Name || dLink.name || '',\n (dLink.Hash || dLink.cid || '').toString() || null\n ],\n ...options\n }),\n headers: options.headers\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return addLink;\n});\n\nexports.createAddLink = createAddLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\nvar abortSignal = require('../../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createAppendData = configure.configure(api => {\n async function appendData(cid$1, data, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('object/patch/append-data', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ cid$1 }`,\n ...options\n }),\n ...await multipartRequest.multipartRequest(data, controller, options.headers)\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return appendData;\n});\n\nexports.createAppendData = createAppendData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst createRmLink = configure.configure(api => {\n async function rmLink(cid$1, dLink, options = {}) {\n const res = await api.post('object/patch/rm-link', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n `${ cid$1 }`,\n dLink.Name || dLink.name || null\n ],\n ...options\n }),\n headers: options.headers\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return rmLink;\n});\n\nexports.createRmLink = createRmLink;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar configure = require('../../lib/configure.js');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\nvar abortSignal = require('../../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createSetData = configure.configure(api => {\n async function setData(cid$1, data, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('object/patch/set-data', {\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [`${ cid$1 }`],\n ...options\n }),\n ...await multipartRequest.multipartRequest(data, controller, options.headers)\n });\n const {Hash} = await res.json();\n return cid.CID.parse(Hash);\n }\n return setData;\n});\n\nexports.createSetData = createSetData;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addAll = require('./add-all.js');\nvar add = require('./add.js');\nvar ls = require('./ls.js');\nvar rmAll = require('./rm-all.js');\nvar rm = require('./rm.js');\nvar index = require('./remote/index.js');\n\nfunction createPin(config) {\n return {\n addAll: addAll.createAddAll(config),\n add: add.createAdd(config),\n ls: ls.createLs(config),\n rmAll: rmAll.createRmAll(config),\n rm: rm.createRm(config),\n remote: index.createRemote(config)\n };\n}\n\nexports.createPin = createPin;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createAddAll = configure.configure(api => {\n async function* addAll(source, options = {}) {\n for await (const {path, recursive, metadata} of normaliseInput.normaliseInput(source)) {\n const res = await api.post('pin/add', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n arg: path,\n recursive,\n metadata: metadata ? JSON.stringify(metadata) : undefined,\n stream: true\n }),\n headers: options.headers\n });\n for await (const pin of res.ndjson()) {\n if (pin.Pins) {\n for (const cid$1 of pin.Pins) {\n yield cid.CID.parse(cid$1);\n }\n continue;\n }\n yield cid.CID.parse(pin);\n }\n }\n }\n return addAll;\n});\n\nexports.createAddAll = createAddAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addAll = require('./add-all.js');\nvar last = require('it-last');\nvar configure = require('../lib/configure.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createAdd(config) {\n const all = addAll.createAddAll(config);\n return configure.configure(() => {\n async function add(path, options = {}) {\n return last__default['default'](all([{\n path,\n ...options\n }], options));\n }\n return add;\n })(config);\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nfunction toPin(type, cid$1, metadata) {\n const pin = {\n type,\n cid: cid.CID.parse(cid$1)\n };\n if (metadata) {\n pin.metadata = metadata;\n }\n return pin;\n}\nconst createLs = configure.configure(api => {\n async function* ls(options = {}) {\n let paths = [];\n if (options.paths) {\n paths = Array.isArray(options.paths) ? options.paths : [options.paths];\n }\n const res = await api.post('pin/ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n arg: paths.map(path => `${ path }`),\n stream: true\n }),\n headers: options.headers\n });\n for await (const pin of res.ndjson()) {\n if (pin.Keys) {\n for (const cid of Object.keys(pin.Keys)) {\n yield toPin(pin.Keys[cid].Type, cid, pin.Keys[cid].Metadata);\n }\n return;\n }\n yield toPin(pin.Type, pin.Cid, pin.Metadata);\n }\n }\n return ls;\n});\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar normaliseInput = require('ipfs-core-utils/pins/normalise-input');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createRmAll = configure.configure(api => {\n async function* rmAll(source, options = {}) {\n for await (const {path, recursive} of normaliseInput.normaliseInput(source)) {\n const searchParams = new URLSearchParams(options.searchParams);\n searchParams.append('arg', `${ path }`);\n if (recursive != null)\n searchParams.set('recursive', String(recursive));\n const res = await api.post('pin/rm', {\n signal: options.signal,\n headers: options.headers,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n ...options,\n arg: `${ path }`,\n recursive\n })\n });\n for await (const pin of res.ndjson()) {\n if (pin.Pins) {\n yield* pin.Pins.map(cid$1 => cid.CID.parse(cid$1));\n continue;\n }\n yield cid.CID.parse(pin);\n }\n }\n }\n return rmAll;\n});\n\nexports.createRmAll = createRmAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar rmAll = require('./rm-all.js');\nvar last = require('it-last');\nvar configure = require('../lib/configure.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nconst createRm = config => {\n const all = rmAll.createRmAll(config);\n return configure.configure(() => {\n async function rm(path, options = {}) {\n return last__default['default'](all([{\n path,\n ...options\n }], options));\n }\n return rm;\n })(config);\n};\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar core = require('../../lib/core.js');\nvar add = require('./add.js');\nvar ls = require('./ls.js');\nvar rm = require('./rm.js');\nvar rmAll = require('./rm-all.js');\nvar index = require('./service/index.js');\n\nfunction createRemote(config) {\n const client = new core.Client(config);\n return {\n add: add.createAdd(client),\n ls: ls.createLs(client),\n rm: rm.createRm(client),\n rmAll: rmAll.createRmAll(client),\n service: index.createService(config)\n };\n}\n\nexports.createRemote = createRemote;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\n\nfunction createAdd(client) {\n async function add(cid, {timeout, signal, headers, ...query}) {\n const response = await client.post('pin/remote/add', {\n timeout,\n signal,\n headers,\n searchParams: utils.encodeAddParams({\n cid,\n ...query\n })\n });\n return utils.decodePin(await response.json());\n }\n return add;\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar toUrlSearchParams = require('../../lib/to-url-search-params.js');\n\nconst decodePin = ({\n Name: name,\n Status: status,\n Cid: cid$1\n}) => {\n return {\n cid: cid.CID.parse(cid$1),\n name,\n status\n };\n};\nconst encodeService = service => {\n if (typeof service === 'string' && service !== '') {\n return service;\n } else {\n throw new TypeError('service name must be passed');\n }\n};\nconst encodeCID = cid$1 => {\n if (cid.CID.asCID(cid$1)) {\n return cid$1.toString();\n } else {\n throw new TypeError(`CID instance expected instead of ${ typeof cid$1 }`);\n }\n};\nconst encodeQuery = ({service, cid, name, status, all}) => {\n const query = toUrlSearchParams.toUrlSearchParams({\n service: encodeService(service),\n name,\n force: all ? true : undefined\n });\n if (cid) {\n for (const value of cid) {\n query.append('cid', encodeCID(value));\n }\n }\n if (status) {\n for (const value of status) {\n query.append('status', value);\n }\n }\n return query;\n};\nconst encodeAddParams = ({cid, service, background, name, origins}) => {\n const params = toUrlSearchParams.toUrlSearchParams({\n arg: encodeCID(cid),\n service: encodeService(service),\n name,\n background: background ? true : undefined\n });\n if (origins) {\n for (const origin of origins) {\n params.append('origin', origin.toString());\n }\n }\n return params;\n};\n\nexports.decodePin = decodePin;\nexports.encodeAddParams = encodeAddParams;\nexports.encodeCID = encodeCID;\nexports.encodeQuery = encodeQuery;\nexports.encodeService = encodeService;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\n\nfunction createLs(client) {\n async function* ls({timeout, signal, headers, ...query}) {\n const response = await client.post('pin/remote/ls', {\n timeout,\n signal,\n headers,\n searchParams: utils.encodeQuery(query)\n });\n for await (const pin of response.ndjson()) {\n yield utils.decodePin(pin);\n }\n }\n return ls;\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\n\nfunction createRm(client) {\n async function rm({timeout, signal, headers, ...query}) {\n await client.post('pin/remote/rm', {\n timeout,\n signal,\n headers,\n searchParams: utils.encodeQuery({\n ...query,\n all: false\n })\n });\n }\n return rm;\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar utils = require('./utils.js');\n\nfunction createRmAll(client) {\n async function rmAll({timeout, signal, headers, ...query}) {\n await client.post('pin/remote/rm', {\n timeout,\n signal,\n headers,\n searchParams: utils.encodeQuery({\n ...query,\n all: true\n })\n });\n }\n return rmAll;\n}\n\nexports.createRmAll = createRmAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar core = require('../../../lib/core.js');\nvar add = require('./add.js');\nvar ls = require('./ls.js');\nvar rm = require('./rm.js');\n\nfunction createService(config) {\n const client = new core.Client(config);\n return {\n add: add.createAdd(client),\n ls: ls.createLs(client),\n rm: rm.createRm(client)\n };\n}\n\nexports.createService = createService;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar toUrlSearchParams = require('../../../lib/to-url-search-params.js');\nvar utils = require('./utils.js');\n\nfunction createAdd(client) {\n async function add(name, options) {\n const {endpoint, key, headers, timeout, signal} = options;\n await client.post('pin/remote/service/add', {\n timeout,\n signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: [\n name,\n utils.encodeEndpoint(endpoint),\n key\n ]\n }),\n headers\n });\n }\n return add;\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction encodeEndpoint(url) {\n const href = String(url);\n if (href === 'undefined') {\n throw Error('endpoint is required');\n }\n return href[href.length - 1] === '/' ? href.slice(0, -1) : href;\n}\nfunction decodeRemoteService(json) {\n return {\n service: json.Service,\n endpoint: new URL(json.ApiEndpoint),\n ...json.Stat && { stat: decodeStat(json.Stat) }\n };\n}\nfunction decodeStat(json) {\n switch (json.Status) {\n case 'valid': {\n const {Pinning, Pinned, Queued, Failed} = json.PinCount;\n return {\n status: 'valid',\n pinCount: {\n queued: Queued,\n pinning: Pinning,\n pinned: Pinned,\n failed: Failed\n }\n };\n }\n case 'invalid': {\n return { status: 'invalid' };\n }\n default: {\n return { status: json.Status };\n }\n }\n}\n\nexports.decodeRemoteService = decodeRemoteService;\nexports.decodeStat = decodeStat;\nexports.encodeEndpoint = encodeEndpoint;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar toUrlSearchParams = require('../../../lib/to-url-search-params.js');\nvar utils = require('./utils.js');\n\nfunction createLs(client) {\n async function ls(options = {}) {\n const {stat, headers, timeout, signal} = options;\n const response = await client.post('pin/remote/service/ls', {\n timeout,\n signal,\n headers,\n searchParams: stat === true ? toUrlSearchParams.toUrlSearchParams({ stat }) : undefined\n });\n const {RemoteServices} = await response.json();\n return RemoteServices.map(utils.decodeRemoteService);\n }\n return ls;\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar toUrlSearchParams = require('../../../lib/to-url-search-params.js');\n\nfunction createRm(client) {\n async function rm(name, options = {}) {\n await client.post('pin/remote/service/rm', {\n signal: options.signal,\n headers: options.headers,\n searchParams: toUrlSearchParams.toUrlSearchParams({ arg: name })\n });\n }\n return rm;\n}\n\nexports.createRm = createRm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ls = require('./ls.js');\nvar peers = require('./peers.js');\nvar publish = require('./publish.js');\nvar subscribe = require('./subscribe.js');\nvar unsubscribe = require('./unsubscribe.js');\nvar subscriptionTracker = require('./subscription-tracker.js');\n\nfunction createPubsub(config) {\n const subscriptionTracker$1 = new subscriptionTracker.SubscriptionTracker();\n return {\n ls: ls.createLs(config),\n peers: peers.createPeers(config),\n publish: publish.createPublish(config),\n subscribe: subscribe.createSubscribe(config, subscriptionTracker$1),\n unsubscribe: unsubscribe.createUnsubscribe(config, subscriptionTracker$1)\n };\n}\n\nexports.createPubsub = createPubsub;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLs = configure.configure(api => {\n async function ls(options = {}) {\n const {Strings} = await (await api.post('pubsub/ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n })).json();\n return Strings || [];\n }\n return ls;\n});\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createPeers = configure.configure(api => {\n async function peers(topic, options = {}) {\n const res = await api.post('pubsub/peers', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: topic,\n ...options\n }),\n headers: options.headers\n });\n const {Strings} = await res.json();\n return Strings || [];\n }\n return peers;\n});\n\nexports.createPeers = createPeers;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar abortSignal = require('../lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createPublish = configure.configure(api => {\n async function publish(topic, data, options = {}) {\n const searchParams = toUrlSearchParams.toUrlSearchParams({\n arg: topic,\n ...options\n });\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const res = await api.post('pubsub/pub', {\n signal,\n searchParams,\n ...await multipartRequest.multipartRequest(data, controller, options.headers)\n });\n await res.text();\n }\n return publish;\n});\n\nexports.createPublish = createPublish;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar fromString = require('uint8arrays/from-string');\nvar toString = require('uint8arrays/to-string');\nvar debug = require('debug');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst log = debug__default['default']('ipfs-http-client:pubsub:subscribe');\nconst createSubscribe = (options, subsTracker) => {\n return configure.configure(api => {\n async function subscribe(topic, handler, options = {}) {\n options.signal = subsTracker.subscribe(topic, handler, options.signal);\n let done;\n let fail;\n const result = new Promise((resolve, reject) => {\n done = resolve;\n fail = reject;\n });\n const ffWorkaround = setTimeout(() => done(), 1000);\n api.post('pubsub/sub', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: topic,\n ...options\n }),\n headers: options.headers\n }).catch(err => {\n subsTracker.unsubscribe(topic, handler);\n fail(err);\n }).then(response => {\n clearTimeout(ffWorkaround);\n if (!response) {\n return;\n }\n readMessages(response, {\n onMessage: handler,\n onEnd: () => subsTracker.unsubscribe(topic, handler),\n onError: options.onError\n });\n done();\n });\n return result;\n }\n return subscribe;\n })(options);\n};\nasync function readMessages(response, {onMessage, onEnd, onError}) {\n onError = onError || log;\n try {\n for await (const msg of response.ndjson()) {\n try {\n if (!msg.from) {\n continue;\n }\n onMessage({\n from: toString.toString(fromString.fromString(msg.from, 'base64pad'), 'base58btc'),\n data: fromString.fromString(msg.data, 'base64pad'),\n seqno: fromString.fromString(msg.seqno, 'base64pad'),\n topicIDs: msg.topicIDs\n });\n } catch (err) {\n err.message = `Failed to parse pubsub message: ${ err.message }`;\n onError(err, false, msg);\n }\n }\n } catch (err) {\n if (!isAbortError(err)) {\n onError(err, true);\n }\n } finally {\n onEnd();\n }\n}\nconst isAbortError = error => {\n switch (error.type) {\n case 'aborted':\n return true;\n case 'abort':\n return true;\n default:\n return error.name === 'AbortError';\n }\n};\n\nexports.createSubscribe = createSubscribe;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst createUnsubscribe = (options, subsTracker) => {\n async function unsubscribe(topic, handler) {\n subsTracker.unsubscribe(topic, handler);\n }\n return unsubscribe;\n};\n\nexports.createUnsubscribe = createUnsubscribe;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar nativeAbortController = require('native-abort-controller');\n\nclass SubscriptionTracker {\n constructor() {\n this._subs = new Map();\n }\n subscribe(topic, handler, signal) {\n const topicSubs = this._subs.get(topic) || [];\n if (topicSubs.find(s => s.handler === handler)) {\n throw new Error(`Already subscribed to ${ topic } with this handler`);\n }\n const controller = new nativeAbortController.AbortController();\n this._subs.set(topic, [{\n handler,\n controller\n }].concat(topicSubs));\n if (signal) {\n signal.addEventListener('abort', () => this.unsubscribe(topic, handler));\n }\n return controller.signal;\n }\n unsubscribe(topic, handler) {\n const subs = this._subs.get(topic) || [];\n let unsubs;\n if (handler) {\n this._subs.set(topic, subs.filter(s => s.handler !== handler));\n unsubs = subs.filter(s => s.handler === handler);\n } else {\n this._subs.set(topic, []);\n unsubs = subs;\n }\n if (!(this._subs.get(topic) || []).length) {\n this._subs.delete(topic);\n }\n unsubs.forEach(s => s.controller.abort());\n }\n}\n\nexports.SubscriptionTracker = SubscriptionTracker;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\nvar local = require('./local.js');\n\nconst createRefs = configure.configure((api, opts) => {\n const refs = async function* (args, options = {}) {\n const argsArr = Array.isArray(args) ? args : [args];\n const res = await api.post('refs', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: argsArr.map(arg => `${ arg instanceof Uint8Array ? cid.CID.decode(arg) : arg }`),\n ...options\n }),\n headers: options.headers,\n transform: objectToCamel.objectToCamel\n });\n yield* res.ndjson();\n };\n return Object.assign(refs, { local: local.createLocal(opts) });\n});\n\nexports.createRefs = createRefs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('../lib/object-to-camel.js');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLocal = configure.configure(api => {\n async function* refsLocal(options = {}) {\n const res = await api.post('refs/local', {\n signal: options.signal,\n transform: objectToCamel.objectToCamel,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n yield* res.ndjson();\n }\n return refsLocal;\n});\n\nexports.createLocal = createLocal;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar gc = require('./gc.js');\nvar stat = require('./stat.js');\nvar version = require('./version.js');\n\nfunction createRepo(config) {\n return {\n gc: gc.createGc(config),\n stat: stat.createStat(config),\n version: version.createVersion(config)\n };\n}\n\nexports.createRepo = createRepo;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createGc = configure.configure(api => {\n async function* gc(options = {}) {\n const res = await api.post('repo/gc', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers,\n transform: res => {\n return {\n err: res.Error ? new Error(res.Error) : null,\n cid: (res.Key || {})['/'] ? cid.CID.parse(res.Key['/']) : null\n };\n }\n });\n yield* res.ndjson();\n }\n return gc;\n});\n\nexports.createGc = createGc;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createStat = configure.configure(api => {\n async function stat(options = {}) {\n const res = await api.post('repo/stat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const data = await res.json();\n return {\n numObjects: BigInt(data.NumObjects),\n repoSize: BigInt(data.RepoSize),\n repoPath: data.RepoPath,\n version: data.Version,\n storageMax: BigInt(data.StorageMax)\n };\n }\n return stat;\n});\n\nexports.createStat = createStat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createVersion = configure.configure(api => {\n async function version(options = {}) {\n const res = await (await api.post('repo/version', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n })).json();\n return res.Version;\n }\n return version;\n});\n\nexports.createVersion = createVersion;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar stat = require('../bitswap/stat.js');\nvar stat$1 = require('../repo/stat.js');\nvar bw = require('./bw.js');\n\nfunction createStats(config) {\n return {\n bitswap: stat.createStat(config),\n repo: stat$1.createStat(config),\n bw: bw.createBw(config)\n };\n}\n\nexports.createStats = createStats;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createBw = configure.configure(api => {\n async function* bw(options = {}) {\n const res = await api.post('stats/bw', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers,\n transform: stats => ({\n totalIn: BigInt(stats.TotalIn),\n totalOut: BigInt(stats.TotalOut),\n rateIn: parseFloat(stats.RateIn),\n rateOut: parseFloat(stats.RateOut)\n })\n });\n yield* res.ndjson();\n }\n return bw;\n});\n\nexports.createBw = createBw;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addrs = require('./addrs.js');\nvar connect = require('./connect.js');\nvar disconnect = require('./disconnect.js');\nvar localAddrs = require('./local-addrs.js');\nvar peers = require('./peers.js');\n\nfunction createSwarm(config) {\n return {\n addrs: addrs.createAddrs(config),\n connect: connect.createConnect(config),\n disconnect: disconnect.createDisconnect(config),\n localAddrs: localAddrs.createLocalAddrs(config),\n peers: peers.createPeers(config)\n };\n}\n\nexports.createSwarm = createSwarm;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createAddrs = configure.configure(api => {\n async function addrs(options = {}) {\n const res = await api.post('swarm/addrs', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const {Addrs} = await res.json();\n return Object.keys(Addrs).map(id => ({\n id,\n addrs: (Addrs[id] || []).map(a => new multiaddr.Multiaddr(a))\n }));\n }\n return addrs;\n});\n\nexports.createAddrs = createAddrs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createConnect = configure.configure(api => {\n async function connect(addr, options = {}) {\n const res = await api.post('swarm/connect', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: addr,\n ...options\n }),\n headers: options.headers\n });\n const {Strings} = await res.json();\n return Strings || [];\n }\n return connect;\n});\n\nexports.createConnect = createConnect;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createDisconnect = configure.configure(api => {\n async function disconnect(addr, options = {}) {\n const res = await api.post('swarm/disconnect', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: addr,\n ...options\n }),\n headers: options.headers\n });\n const {Strings} = await res.json();\n return Strings || [];\n }\n return disconnect;\n});\n\nexports.createDisconnect = createDisconnect;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createLocalAddrs = configure.configure(api => {\n async function localAddrs(options = {}) {\n const res = await api.post('swarm/addrs/local', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const {Strings} = await res.json();\n return (Strings || []).map(a => new multiaddr.Multiaddr(a));\n }\n return localAddrs;\n});\n\nexports.createLocalAddrs = createLocalAddrs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar multiaddr = require('multiaddr');\nvar configure = require('../lib/configure.js');\nvar toUrlSearchParams = require('../lib/to-url-search-params.js');\n\nconst createPeers = configure.configure(api => {\n async function peers(options = {}) {\n const res = await api.post('swarm/peers', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n const {Peers} = await res.json();\n return (Peers || []).map(peer => {\n return {\n addr: new multiaddr.Multiaddr(peer.Addr),\n peer: peer.Peer,\n muxer: peer.Muxer,\n latency: peer.Latency,\n streams: peer.Streams,\n direction: peer.Direction == null ? undefined : peer.Direction === 0 ? 'inbound' : 'outbound'\n };\n });\n }\n return peers;\n});\n\nexports.createPeers = createPeers;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addAll = require('./add-all.js');\nvar last = require('it-last');\nvar configure = require('./lib/configure.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar last__default = /*#__PURE__*/_interopDefaultLegacy(last);\n\nfunction createAdd(options) {\n const all = addAll.createAddAll(options);\n return configure.configure(() => {\n async function add(input, options = {}) {\n return await last__default['default'](all(input, options));\n }\n return add;\n })(options);\n}\n\nexports.createAdd = createAdd;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar configure = require('./lib/configure.js');\nvar multipartRequest = require('ipfs-core-utils/multipart-request');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\nvar abortSignal = require('./lib/abort-signal.js');\nvar nativeAbortController = require('native-abort-controller');\n\nconst createAddAll = configure.configure(api => {\n async function* addAll(source, options = {}) {\n const controller = new nativeAbortController.AbortController();\n const signal = abortSignal.abortSignal(controller.signal, options.signal);\n const {headers, body, total, parts} = await multipartRequest.multipartRequest(source, controller, options.headers);\n const [progressFn, onUploadProgress] = typeof options.progress === 'function' ? createProgressHandler(total, parts, options.progress) : [\n undefined,\n undefined\n ];\n const res = await api.post('add', {\n searchParams: toUrlSearchParams.toUrlSearchParams({\n 'stream-channels': true,\n ...options,\n progress: Boolean(progressFn)\n }),\n onUploadProgress,\n signal,\n headers,\n body\n });\n for await (let file of res.ndjson()) {\n file = objectToCamel.objectToCamel(file);\n if (file.hash !== undefined) {\n yield toCoreInterface(file);\n } else if (progressFn) {\n progressFn(file.bytes || 0, file.name);\n }\n }\n }\n return addAll;\n});\nconst createProgressHandler = (total, parts, progress) => parts ? [\n undefined,\n createOnUploadProgress(total, parts, progress)\n] : [\n progress,\n undefined\n];\nconst createOnUploadProgress = (size, parts, progress) => {\n let index = 0;\n const count = parts.length;\n return ({loaded, total}) => {\n const position = Math.floor(loaded / total * size);\n while (index < count) {\n const {start, end, name} = parts[index];\n if (position < end) {\n progress(position - start, name);\n break;\n } else {\n progress(end - start, name);\n index += 1;\n }\n }\n };\n};\nfunction toCoreInterface({name, hash, size, mode, mtime, mtimeNsecs}) {\n const output = {\n path: name,\n cid: cid.CID.parse(hash),\n size: parseInt(size)\n };\n if (mode != null) {\n output.mode = parseInt(mode, 8);\n }\n if (mtime != null) {\n output.mtime = {\n secs: mtime,\n nsecs: mtimeNsecs || 0\n };\n }\n return output;\n}\n\nexports.createAddAll = createAddAll;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createCat = configure.configure(api => {\n async function* cat(path, options = {}) {\n const res = await api.post('cat', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path.toString(),\n ...options\n }),\n headers: options.headers\n });\n yield* res.iterator();\n }\n return cat;\n});\n\nexports.createCat = createCat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createCommands = configure.configure(api => {\n const commands = async (options = {}) => {\n const res = await api.post('commands', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return res.json();\n };\n return commands;\n});\n\nexports.createCommands = createCommands;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createDns = configure.configure(api => {\n const dns = async (domain, options = {}) => {\n const res = await api.post('dns', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: domain,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n return data.Path;\n };\n return dns;\n});\n\nexports.createDns = createDns;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\n\nconst createGetEndpointConfig = configure.configure(api => {\n return () => {\n const url = new URL(api.opts.base || '');\n return {\n host: url.hostname,\n port: url.port,\n protocol: url.protocol,\n pathname: url.pathname,\n 'api-path': url.pathname\n };\n };\n});\n\nexports.createGetEndpointConfig = createGetEndpointConfig;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createGet = configure.configure(api => {\n async function* get(path, options = {}) {\n const opts = {\n arg: `${ path instanceof Uint8Array ? cid.CID.decode(path) : path }`,\n ...options\n };\n if (opts.compressionLevel) {\n opts['compression-level'] = opts.compressionLevel;\n delete opts.compressionLevel;\n }\n const res = await api.post('get', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(opts),\n headers: options.headers\n });\n yield* res.iterator();\n }\n return get;\n});\n\nexports.createGet = createGet;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar multiaddr = require('multiaddr');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createId = configure.configure(api => {\n async function id(options = {}) {\n const res = await api.post('id', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: options.peerId ? options.peerId.toString() : undefined,\n ...options\n }),\n headers: options.headers\n });\n const data = await res.json();\n const output = { ...objectToCamel.objectToCamel(data) };\n if (output.addresses) {\n output.addresses = output.addresses.map(ma => new multiaddr.Multiaddr(ma));\n }\n return output;\n }\n return id;\n});\n\nexports.createId = createId;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar id = require('./id.js');\n\nconst createIsOnline = options => {\n const id$1 = id.createId(options);\n async function isOnline(options = {}) {\n const res = await id$1(options);\n return Boolean(res && res.addresses && res.addresses.length);\n }\n return isOnline;\n};\n\nexports.createIsOnline = createIsOnline;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\nvar stat = require('./files/stat.js');\n\nconst createLs = configure.configure((api, opts) => {\n async function* ls(path, options = {}) {\n const pathStr = `${ path instanceof Uint8Array ? cid.CID.decode(path) : path }`;\n async function mapLink(link) {\n let hash = link.Hash;\n if (hash.includes('/')) {\n const ipfsPath = hash.startsWith('/ipfs/') ? hash : `/ipfs/${ hash }`;\n const stats = await stat.createStat(opts)(ipfsPath);\n hash = stats.cid;\n } else {\n hash = cid.CID.parse(hash);\n }\n const entry = {\n name: link.Name,\n path: pathStr + (link.Name ? `/${ link.Name }` : ''),\n size: link.Size,\n cid: hash,\n type: typeOf(link)\n };\n if (link.Mode) {\n entry.mode = parseInt(link.Mode, 8);\n }\n if (link.Mtime !== undefined && link.Mtime !== null) {\n entry.mtime = { secs: link.Mtime };\n if (link.MtimeNsecs !== undefined && link.MtimeNsecs !== null) {\n entry.mtime.nsecs = link.MtimeNsecs;\n }\n }\n return entry;\n }\n const res = await api.post('ls', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: pathStr,\n ...options\n }),\n headers: options.headers\n });\n for await (let result of res.ndjson()) {\n result = result.Objects;\n if (!result) {\n throw new Error('expected .Objects in results');\n }\n result = result[0];\n if (!result) {\n throw new Error('expected one array in results.Objects');\n }\n const links = result.Links;\n if (!Array.isArray(links)) {\n throw new Error('expected one array in results.Objects[0].Links');\n }\n if (!links.length) {\n yield mapLink(result);\n return;\n }\n yield* links.map(mapLink);\n }\n }\n return ls;\n});\nfunction typeOf(link) {\n switch (link.Type) {\n case 1:\n case 5:\n return 'dir';\n case 2:\n return 'file';\n default:\n return 'file';\n }\n}\n\nexports.createLs = createLs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createMount = configure.configure(api => {\n async function mount(options = {}) {\n const res = await api.post('dns', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return objectToCamel.objectToCamel(await res.json());\n }\n return mount;\n});\n\nexports.createMount = createMount;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createPing = configure.configure(api => {\n async function* ping(peerId, options = {}) {\n const res = await api.post('ping', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: `${ peerId }`,\n ...options\n }),\n headers: options.headers,\n transform: objectToCamel.objectToCamel\n });\n yield* res.ndjson();\n }\n return ping;\n});\n\nexports.createPing = createPing;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createResolve = configure.configure(api => {\n async function resolve(path, options = {}) {\n const res = await api.post('resolve', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams({\n arg: path,\n ...options\n }),\n headers: options.headers\n });\n const {Path} = await res.json();\n return Path;\n }\n return resolve;\n});\n\nexports.createResolve = createResolve;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nconst createStart = configure.configure(api => {\n const start = async (options = {}) => {\n throw errCode__default['default'](new Error('Not implemented'), 'ERR_NOT_IMPLEMENTED');\n };\n return start;\n});\n\nexports.createStart = createStart;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createStop = configure.configure(api => {\n async function stop(options = {}) {\n const res = await api.post('shutdown', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n await res.text();\n }\n return stop;\n});\n\nexports.createStop = createStop;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar objectToCamel = require('./lib/object-to-camel.js');\nvar configure = require('./lib/configure.js');\nvar toUrlSearchParams = require('./lib/to-url-search-params.js');\n\nconst createVersion = configure.configure(api => {\n async function version(options = {}) {\n const res = await api.post('version', {\n signal: options.signal,\n searchParams: toUrlSearchParams.toUrlSearchParams(options),\n headers: options.headers\n });\n return {\n ...objectToCamel.objectToCamel(await res.json()),\n 'ipfs-http-client': '1.0.0'\n };\n }\n return version;\n});\n\nexports.createVersion = createVersion;\n","'use strict'\n\nconst HTTP = require('../http')\n\n/**\n *\n * @param {string} url\n * @param {import(\"../types\").HTTPOptions} [options]\n * @returns {{ path: string; content?: AsyncIterable<Uint8Array> }}\n */\nconst urlSource = (url, options) => {\n return {\n path: decodeURIComponent(new URL(url).pathname.split('/').pop() || ''),\n content: readURLContent(url, options)\n }\n}\n\n/**\n *\n * @param {string} url\n * @param {import(\"../types\").HTTPOptions} [options]\n * @returns {AsyncIterable<Uint8Array>}\n */\nasync function * readURLContent (url, options) {\n const http = new HTTP()\n const response = await http.get(url, options)\n\n yield * response.iterator()\n}\n\nmodule.exports = urlSource\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar WS = require('libp2p-websockets');\nvar WebRTCStar = require('libp2p-webrtc-star');\nvar Multiplex = require('libp2p-mplex');\nvar libp2pNoise = require('@chainsafe/libp2p-noise');\nvar KadDHT = require('libp2p-kad-dht');\nvar GossipSub = require('libp2p-gossipsub');\nvar ipns = require('./utils/ipns.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar WS__default = /*#__PURE__*/_interopDefaultLegacy(WS);\nvar WebRTCStar__default = /*#__PURE__*/_interopDefaultLegacy(WebRTCStar);\nvar Multiplex__default = /*#__PURE__*/_interopDefaultLegacy(Multiplex);\nvar KadDHT__default = /*#__PURE__*/_interopDefaultLegacy(KadDHT);\nvar GossipSub__default = /*#__PURE__*/_interopDefaultLegacy(GossipSub);\n\nfunction libp2pConfig() {\n const options = {\n dialer: {\n maxParallelDials: 150,\n maxDialsPerPeer: 4,\n dialTimeout: 10000\n },\n modules: {\n transport: [\n WS__default[\"default\"],\n WebRTCStar__default[\"default\"]\n ],\n streamMuxer: [Multiplex__default[\"default\"]],\n connEncryption: [libp2pNoise.NOISE],\n peerDiscovery: [],\n dht: KadDHT__default[\"default\"],\n pubsub: GossipSub__default[\"default\"]\n },\n config: {\n peerDiscovery: {\n autoDial: true,\n bootstrap: { enabled: true },\n webRTCStar: { enabled: true }\n },\n dht: {\n kBucketSize: 20,\n enabled: false,\n clientMode: true,\n randomWalk: { enabled: false },\n validators: { ipns: ipns.validator },\n selectors: { ipns: ipns.selector }\n },\n pubsub: {\n enabled: true,\n emitSelf: true\n },\n nat: { enabled: false }\n },\n metrics: { enabled: true },\n peerStore: {\n persistence: true,\n threshold: 1\n }\n };\n return options;\n}\n\nexports.libp2pConfig = libp2pConfig;\n","'use strict'\n\nconst connect = require('it-ws/client')\nconst withIs = require('class-is')\nconst toUri = require('multiaddr-to-uri')\nconst { AbortError } = require('abortable-iterator')\nconst pDefer = require('p-defer')\n\nconst debug = require('debug')\nconst log = debug('libp2p:websockets')\nlog.error = debug('libp2p:websockets:error')\nconst env = require('ipfs-utils/src/env')\n\nconst createListener = require('./listener')\nconst toConnection = require('./socket-to-conn')\nconst filters = require('./filters')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @class WebSockets\n */\nclass WebSockets {\n /**\n * @class\n * @param {object} options\n * @param {Upgrader} options.upgrader\n * @param {(multiaddrs: Array<Multiaddr>) => Array<Multiaddr>} options.filter - override transport addresses filter\n */\n constructor ({ upgrader, filter }) {\n if (!upgrader) {\n throw new Error('An upgrader must be provided. See https://github.com/libp2p/interface-transport#upgrader.')\n }\n this._upgrader = upgrader\n this._filter = filter\n }\n\n /**\n * @async\n * @param {Multiaddr} ma\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - Used to abort dial requests\n * @returns {Connection} An upgraded Connection\n */\n async dial (ma, options = {}) {\n log('dialing %s', ma)\n\n const socket = await this._connect(ma, options)\n const maConn = toConnection(socket, { remoteAddr: ma, signal: options.signal })\n log('new outbound connection %s', maConn.remoteAddr)\n\n const conn = await this._upgrader.upgradeOutbound(maConn)\n log('outbound connection %s upgraded', maConn.remoteAddr)\n return conn\n }\n\n /**\n * @private\n * @param {Multiaddr} ma\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - Used to abort dial requests\n * @returns {Promise<WebSocket>} Resolves a extended duplex iterable on top of a WebSocket\n */\n async _connect (ma, options = {}) {\n if (options.signal && options.signal.aborted) {\n throw new AbortError()\n }\n const cOpts = ma.toOptions()\n log('dialing %s:%s', cOpts.host, cOpts.port)\n\n const errorPromise = pDefer()\n const errfn = (err) => {\n const msg = `connection error: ${err.message}`\n log.error(msg)\n\n errorPromise.reject(err)\n }\n\n const rawSocket = connect(toUri(ma), Object.assign({ binary: true }, options))\n\n if (rawSocket.socket.on) {\n rawSocket.socket.on('error', errfn)\n } else {\n rawSocket.socket.onerror = errfn\n }\n\n if (!options.signal) {\n await Promise.race([rawSocket.connected(), errorPromise.promise])\n\n log('connected %s', ma)\n return rawSocket\n }\n\n // Allow abort via signal during connect\n let onAbort\n const abort = new Promise((resolve, reject) => {\n onAbort = () => {\n reject(new AbortError())\n // FIXME: https://github.com/libp2p/js-libp2p-websockets/issues/121\n setTimeout(() => {\n rawSocket.close()\n })\n }\n\n // Already aborted?\n if (options.signal.aborted) return onAbort()\n options.signal.addEventListener('abort', onAbort)\n })\n\n try {\n await Promise.race([abort, errorPromise.promise, rawSocket.connected()])\n } finally {\n options.signal.removeEventListener('abort', onAbort)\n }\n\n log('connected %s', ma)\n return rawSocket\n }\n\n /**\n * Creates a Websockets listener. The provided `handler` function will be called\n * anytime a new incoming Connection has been successfully upgraded via\n * `upgrader.upgradeInbound`.\n *\n * @param {object} [options]\n * @param {http.Server} [options.server] - A pre-created Node.js HTTP/S server.\n * @param {function (Connection)} handler\n * @returns {Listener} A Websockets listener\n */\n createListener (options = {}, handler) {\n if (typeof options === 'function') {\n handler = options\n options = {}\n }\n\n return createListener({ handler, upgrader: this._upgrader }, options)\n }\n\n /**\n * Takes a list of `Multiaddr`s and returns only valid Websockets addresses.\n * By default, in a browser environment only DNS+WSS multiaddr is accepted,\n * while in a Node.js environment DNS+{WS, WSS} multiaddrs are accepted.\n *\n * @param {Multiaddr[]} multiaddrs\n * @returns {Multiaddr[]} Valid Websockets multiaddrs\n */\n filter (multiaddrs) {\n multiaddrs = Array.isArray(multiaddrs) ? multiaddrs : [multiaddrs]\n\n if (this._filter) {\n return this._filter(multiaddrs)\n }\n\n // Browser\n if (env.isBrowser || env.isWebWorker) {\n return filters.dnsWss(multiaddrs)\n }\n\n return filters.all(multiaddrs)\n }\n}\n\nmodule.exports = withIs(WebSockets, {\n className: 'WebSockets',\n symbolName: '@libp2p/js-libp2p-websockets/websockets'\n})\n","'use strict'\n\n// load websocket library if we are not in the browser\nvar WebSocket = require('./web-socket')\nvar duplex = require('./duplex')\nvar wsurl = require('./ws-url')\n\nmodule.exports = function (addr, opts = {}) {\n const location = typeof window === 'undefined' ? {} : window.location\n\n const url = wsurl(addr, location)\n const socket = new WebSocket(url, opts.websocket)\n\n const stream = duplex(socket, opts)\n stream.remoteAddress = url\n stream.close = () => new Promise((resolve, reject) => {\n socket.addEventListener('close', resolve)\n socket.close()\n })\n stream.destroy = () => {\n if (socket.terminate) {\n socket.terminate()\n } else {\n socket.close()\n }\n }\n stream.socket = socket\n\n return stream\n}\n\nmodule.exports.connect = module.exports\n","/* eslint-env browser */\nmodule.exports = typeof WebSocket === 'undefined' ? require('ws') : WebSocket\n","const source = require('./source')\nconst sink = require('./sink')\n\nmodule.exports = (socket, options) => {\n options = options || {}\n\n if (options.binaryType) {\n socket.binaryType = options.binaryType\n } else if (options.binary) {\n socket.binaryType = 'arraybuffer'\n }\n\n const duplex = {\n sink: sink(socket, options),\n source: source(socket, options),\n connected: () => duplex.source.connected()\n }\n\n return duplex\n}\n","const { Buffer } = require('buffer')\nconst { EventIterator } = require('event-iterator')\n\n// copied from github.com/feross/buffer\n// Some ArrayBuffers are not passing the instanceof check, so we need to do a bit more work :(\nfunction isArrayBuffer (obj) {\n return obj instanceof ArrayBuffer ||\n (obj != null && obj.constructor != null && obj.constructor.name === 'ArrayBuffer' &&\n typeof obj.byteLength === 'number')\n}\n\nmodule.exports = socket => {\n const removeListener = socket.removeEventListener || socket.removeListener\n\n const source = (async function * () {\n const messages = new EventIterator(\n ({ push, stop, fail }) => {\n socket.addEventListener('message', push)\n socket.addEventListener('error', fail)\n socket.addEventListener('close', stop)\n\n return () => {\n removeListener.call(socket, 'message', push)\n removeListener.call(socket, 'error', fail)\n removeListener.call(socket, 'close', stop)\n }\n },\n { highWaterMark: Infinity }\n )\n\n for await (const { data } of messages) {\n yield isArrayBuffer(data) ? Buffer.from(data) : data\n }\n })()\n\n let connected = socket.readyState === 1\n let connError\n\n socket.addEventListener('open', () => {\n connected = true\n connError = null\n })\n\n socket.addEventListener('close', () => {\n connected = false\n connError = null\n })\n\n socket.addEventListener('error', err => {\n if (!connected) connError = err\n })\n\n source.connected = () => new Promise((resolve, reject) => {\n if (connected) return resolve()\n if (connError) return reject(connError)\n\n const cleanUp = cont => {\n removeListener.call(socket, 'open', onOpen)\n removeListener.call(socket, 'error', onError)\n cont()\n }\n\n const onOpen = () => cleanUp(resolve)\n const onError = err => cleanUp(() => reject(err))\n\n socket.addEventListener('open', onOpen)\n socket.addEventListener('error', onError)\n })\n\n return source\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst event_iterator_1 = require(\"./event-iterator\");\nexports.EventIterator = event_iterator_1.EventIterator;\nfunction subscribe(event, options, evOptions) {\n return new event_iterator_1.EventIterator(({ push }) => {\n this.addEventListener(event, push, options);\n return () => this.removeEventListener(event, push, options);\n }, evOptions);\n}\nexports.subscribe = subscribe;\nexports.default = event_iterator_1.EventIterator;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nclass EventQueue {\n constructor() {\n this.pullQueue = [];\n this.pushQueue = [];\n this.eventHandlers = {};\n this.isPaused = false;\n this.isStopped = false;\n }\n push(value) {\n if (this.isStopped)\n return;\n const resolution = { value, done: false };\n if (this.pullQueue.length) {\n const placeholder = this.pullQueue.shift();\n if (placeholder)\n placeholder.resolve(resolution);\n }\n else {\n this.pushQueue.push(Promise.resolve(resolution));\n if (this.highWaterMark !== undefined &&\n this.pushQueue.length >= this.highWaterMark &&\n !this.isPaused) {\n this.isPaused = true;\n if (this.eventHandlers.highWater) {\n this.eventHandlers.highWater();\n }\n else if (console) {\n console.warn(`EventIterator queue reached ${this.pushQueue.length} items`);\n }\n }\n }\n }\n stop() {\n if (this.isStopped)\n return;\n this.isStopped = true;\n this.remove();\n for (const placeholder of this.pullQueue) {\n placeholder.resolve({ value: undefined, done: true });\n }\n this.pullQueue.length = 0;\n }\n fail(error) {\n if (this.isStopped)\n return;\n this.isStopped = true;\n this.remove();\n if (this.pullQueue.length) {\n for (const placeholder of this.pullQueue) {\n placeholder.reject(error);\n }\n this.pullQueue.length = 0;\n }\n else {\n const rejection = Promise.reject(error);\n /* Attach error handler to avoid leaking an unhandled promise rejection. */\n rejection.catch(() => { });\n this.pushQueue.push(rejection);\n }\n }\n remove() {\n Promise.resolve().then(() => {\n if (this.removeCallback)\n this.removeCallback();\n });\n }\n [Symbol.asyncIterator]() {\n return {\n next: (value) => {\n const result = this.pushQueue.shift();\n if (result) {\n if (this.lowWaterMark !== undefined &&\n this.pushQueue.length <= this.lowWaterMark &&\n this.isPaused) {\n this.isPaused = false;\n if (this.eventHandlers.lowWater) {\n this.eventHandlers.lowWater();\n }\n }\n return result;\n }\n else if (this.isStopped) {\n return Promise.resolve({ value: undefined, done: true });\n }\n else {\n return new Promise((resolve, reject) => {\n this.pullQueue.push({ resolve, reject });\n });\n }\n },\n return: () => {\n this.isStopped = true;\n this.pushQueue.length = 0;\n this.remove();\n return Promise.resolve({ value: undefined, done: true });\n },\n };\n }\n}\nclass EventIterator {\n constructor(listen, { highWaterMark = 100, lowWaterMark = 1 } = {}) {\n const queue = new EventQueue();\n queue.highWaterMark = highWaterMark;\n queue.lowWaterMark = lowWaterMark;\n queue.removeCallback =\n listen({\n push: value => queue.push(value),\n stop: () => queue.stop(),\n fail: error => queue.fail(error),\n on: (event, fn) => {\n queue.eventHandlers[event] = fn;\n },\n }) || (() => { });\n this[Symbol.asyncIterator] = () => queue[Symbol.asyncIterator]();\n Object.freeze(this);\n }\n}\nexports.EventIterator = EventIterator;\nexports.default = EventIterator;\n","const ready = require('./ready')\n\nmodule.exports = (socket, options) => {\n options = options || {}\n options.closeOnEnd = options.closeOnEnd !== false\n\n return async source => {\n for await (const data of source) {\n try {\n await ready(socket)\n } catch (err) {\n if (err.message === 'socket closed') break\n throw err\n }\n\n socket.send(data)\n }\n\n if (options.closeOnEnd && socket.readyState <= 1) {\n return new Promise((resolve, reject) => {\n socket.addEventListener('close', event => {\n if (event.wasClean || event.code === 1006) {\n resolve()\n } else {\n const err = Object.assign(new Error('ws error'), { event })\n reject(err)\n }\n })\n\n setTimeout(() => socket.close())\n })\n }\n }\n}\n","module.exports = async socket => {\n // if the socket is closing or closed, return end\n if (socket.readyState >= 2) {\n throw new Error('socket closed')\n }\n\n // if open, return\n if (socket.readyState === 1) {\n return\n }\n\n return new Promise((resolve, reject) => {\n const remove = socket && (socket.removeEventListener || socket.removeListener)\n\n function cleanup () {\n if (typeof remove === 'function') {\n remove.call(socket, 'open', handleOpen)\n remove.call(socket, 'error', handleErr)\n }\n }\n\n function handleOpen () {\n cleanup(); resolve()\n }\n\n function handleErr (evt) {\n cleanup(); reject(evt)\n }\n\n socket.addEventListener('open', handleOpen)\n socket.addEventListener('error', handleErr)\n })\n}\n","const { relative } = require('iso-url')\nconst map = { http: 'ws', https: 'wss' }\nconst def = 'ws'\n\nmodule.exports = (url, location) => relative(url, location, map, def)\n","'use strict'\n\nmodule.exports = function () {\n throw new Error('WebSocket Servers can not be created in the browser!')\n}\n","'use strict'\n\nconst abortable = require('abortable-iterator')\nconst { CLOSE_TIMEOUT } = require('./constants')\nconst toMultiaddr = require('libp2p-utils/src/ip-port-to-multiaddr')\n\nconst pTimeout = require('p-timeout')\n\nconst debug = require('debug')\nconst log = debug('libp2p:websockets:socket')\nlog.error = debug('libp2p:websockets:socket:error')\n\n// Convert a stream into a MultiaddrConnection\n// https://github.com/libp2p/interface-transport#multiaddrconnection\nmodule.exports = (stream, options = {}) => {\n const maConn = {\n async sink (source) {\n if (options.signal) {\n source = abortable(source, options.signal)\n }\n\n try {\n await stream.sink((async function * () {\n for await (const chunk of source) {\n // Convert BufferList to Buffer\n yield chunk instanceof Uint8Array ? chunk : chunk.slice()\n }\n })())\n } catch (err) {\n if (err.type !== 'aborted') {\n log.error(err)\n }\n }\n },\n\n source: options.signal ? abortable(stream.source, options.signal) : stream.source,\n\n conn: stream,\n\n localAddr: options.localAddr || (stream.localAddress && stream.localPort\n ? toMultiaddr(stream.localAddress, stream.localPort)\n : undefined),\n\n // If the remote address was passed, use it - it may have the peer ID encapsulated\n remoteAddr: options.remoteAddr || toMultiaddr(stream.remoteAddress, stream.remotePort),\n\n timeline: { open: Date.now() },\n\n async close () {\n const start = Date.now()\n\n try {\n await pTimeout(stream.close(), CLOSE_TIMEOUT)\n } catch (err) {\n const { host, port } = maConn.remoteAddr.toOptions()\n log('timeout closing stream to %s:%s after %dms, destroying it manually',\n host, port, Date.now() - start)\n\n stream.destroy()\n } finally {\n maConn.timeline.close = Date.now()\n }\n }\n }\n\n stream.socket.once && stream.socket.once('close', () => {\n // In instances where `close` was not explicitly called,\n // such as an iterable stream ending, ensure we have set the close\n // timeline\n if (!maConn.timeline.close) {\n maConn.timeline.close = Date.now()\n }\n })\n\n return maConn\n}\n","'use strict'\n\n// p2p multi-address code\nexports.CODE_P2P = 421\nexports.CODE_CIRCUIT = 290\n\nexports.CODE_TCP = 6\nexports.CODE_WS = 477\nexports.CODE_WSS = 478\n\n// Time to wait for a connection to close gracefully before destroying it manually\nexports.CLOSE_TIMEOUT = 2000\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:ip-port-to-multiaddr'), {\n error: debug('libp2p:ip-port-to-multiaddr:err')\n})\nconst { Multiaddr } = require('multiaddr')\nconst errCode = require('err-code')\nconst { Address4, Address6 } = require('ip-address')\n\nconst errors = {\n ERR_INVALID_IP_PARAMETER: 'ERR_INVALID_IP_PARAMETER',\n ERR_INVALID_PORT_PARAMETER: 'ERR_INVALID_PORT_PARAMETER',\n ERR_INVALID_IP: 'ERR_INVALID_IP'\n}\n\n/**\n * Transform an IP, Port pair into a multiaddr\n *\n * @param {string} ip\n * @param {number|string} port\n */\nfunction ipPortToMultiaddr (ip, port) {\n if (typeof ip !== 'string') {\n throw errCode(new Error(`invalid ip provided: ${ip}`), errors.ERR_INVALID_IP_PARAMETER)\n }\n\n if (typeof port === 'string') {\n port = parseInt(port)\n }\n\n if (isNaN(port)) {\n throw errCode(new Error(`invalid port provided: ${port}`), errors.ERR_INVALID_PORT_PARAMETER)\n }\n\n try {\n // Test valid IPv4\n new Address4(ip) // eslint-disable-line no-new\n return new Multiaddr(`/ip4/${ip}/tcp/${port}`)\n } catch {}\n\n try {\n // Test valid IPv6\n const ip6 = new Address6(ip)\n return ip6.is4()\n ? new Multiaddr(`/ip4/${ip6.to4().correctForm()}/tcp/${port}`)\n : new Multiaddr(`/ip6/${ip}/tcp/${port}`)\n } catch (err) {\n const errMsg = `invalid ip:port for creating a multiaddr: ${ip}:${port}`\n log.error(errMsg)\n throw errCode(new Error(errMsg), errors.ERR_INVALID_IP)\n }\n}\n\nmodule.exports = ipPortToMultiaddr\n\nmodule.exports.Errors = errors\n",null,null,null,null,null,"(function(){\n\n // Copyright (c) 2005 Tom Wu\n // All Rights Reserved.\n // See \"LICENSE\" for details.\n\n // Basic JavaScript BN library - subset useful for RSA encryption.\n\n // Bits per digit\n var dbits;\n\n // JavaScript engine analysis\n var canary = 0xdeadbeefcafe;\n var j_lm = ((canary&0xffffff)==0xefcafe);\n\n // (public) Constructor\n function BigInteger(a,b,c) {\n if(a != null)\n if(\"number\" == typeof a) this.fromNumber(a,b,c);\n else if(b == null && \"string\" != typeof a) this.fromString(a,256);\n else this.fromString(a,b);\n }\n\n // return new, unset BigInteger\n function nbi() { return new BigInteger(null); }\n\n // am: Compute w_j += (x*this_i), propagate carries,\n // c is initial carry, returns final carry.\n // c < 3*dvalue, x < 2*dvalue, this_i < dvalue\n // We need to select the fastest one that works in this environment.\n\n // am1: use a single mult and divide to get the high bits,\n // max digit bits should be 26 because\n // max internal value = 2*dvalue^2-2*dvalue (< 2^53)\n function am1(i,x,w,j,c,n) {\n while(--n >= 0) {\n var v = x*this[i++]+w[j]+c;\n c = Math.floor(v/0x4000000);\n w[j++] = v&0x3ffffff;\n }\n return c;\n }\n // am2 avoids a big mult-and-extract completely.\n // Max digit bits should be <= 30 because we do bitwise ops\n // on values up to 2*hdvalue^2-hdvalue-1 (< 2^31)\n function am2(i,x,w,j,c,n) {\n var xl = x&0x7fff, xh = x>>15;\n while(--n >= 0) {\n var l = this[i]&0x7fff;\n var h = this[i++]>>15;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x7fff)<<15)+w[j]+(c&0x3fffffff);\n c = (l>>>30)+(m>>>15)+xh*h+(c>>>30);\n w[j++] = l&0x3fffffff;\n }\n return c;\n }\n // Alternately, set max digit bits to 28 since some\n // browsers slow down when dealing with 32-bit numbers.\n function am3(i,x,w,j,c,n) {\n var xl = x&0x3fff, xh = x>>14;\n while(--n >= 0) {\n var l = this[i]&0x3fff;\n var h = this[i++]>>14;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x3fff)<<14)+w[j]+c;\n c = (l>>28)+(m>>14)+xh*h;\n w[j++] = l&0xfffffff;\n }\n return c;\n }\n var inBrowser = typeof navigator !== \"undefined\";\n if(inBrowser && j_lm && (navigator.appName == \"Microsoft Internet Explorer\")) {\n BigInteger.prototype.am = am2;\n dbits = 30;\n }\n else if(inBrowser && j_lm && (navigator.appName != \"Netscape\")) {\n BigInteger.prototype.am = am1;\n dbits = 26;\n }\n else { // Mozilla/Netscape seems to prefer am3\n BigInteger.prototype.am = am3;\n dbits = 28;\n }\n\n BigInteger.prototype.DB = dbits;\n BigInteger.prototype.DM = ((1<<dbits)-1);\n BigInteger.prototype.DV = (1<<dbits);\n\n var BI_FP = 52;\n BigInteger.prototype.FV = Math.pow(2,BI_FP);\n BigInteger.prototype.F1 = BI_FP-dbits;\n BigInteger.prototype.F2 = 2*dbits-BI_FP;\n\n // Digit conversions\n var BI_RM = \"0123456789abcdefghijklmnopqrstuvwxyz\";\n var BI_RC = new Array();\n var rr,vv;\n rr = \"0\".charCodeAt(0);\n for(vv = 0; vv <= 9; ++vv) BI_RC[rr++] = vv;\n rr = \"a\".charCodeAt(0);\n for(vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv;\n rr = \"A\".charCodeAt(0);\n for(vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv;\n\n function int2char(n) { return BI_RM.charAt(n); }\n function intAt(s,i) {\n var c = BI_RC[s.charCodeAt(i)];\n return (c==null)?-1:c;\n }\n\n // (protected) copy this to r\n function bnpCopyTo(r) {\n for(var i = this.t-1; i >= 0; --i) r[i] = this[i];\n r.t = this.t;\n r.s = this.s;\n }\n\n // (protected) set from integer value x, -DV <= x < DV\n function bnpFromInt(x) {\n this.t = 1;\n this.s = (x<0)?-1:0;\n if(x > 0) this[0] = x;\n else if(x < -1) this[0] = x+this.DV;\n else this.t = 0;\n }\n\n // return bigint initialized to value\n function nbv(i) { var r = nbi(); r.fromInt(i); return r; }\n\n // (protected) set from string and radix\n function bnpFromString(s,b) {\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 256) k = 8; // byte array\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else { this.fromRadix(s,b); return; }\n this.t = 0;\n this.s = 0;\n var i = s.length, mi = false, sh = 0;\n while(--i >= 0) {\n var x = (k==8)?s[i]&0xff:intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\") mi = true;\n continue;\n }\n mi = false;\n if(sh == 0)\n this[this.t++] = x;\n else if(sh+k > this.DB) {\n this[this.t-1] |= (x&((1<<(this.DB-sh))-1))<<sh;\n this[this.t++] = (x>>(this.DB-sh));\n }\n else\n this[this.t-1] |= x<<sh;\n sh += k;\n if(sh >= this.DB) sh -= this.DB;\n }\n if(k == 8 && (s[0]&0x80) != 0) {\n this.s = -1;\n if(sh > 0) this[this.t-1] |= ((1<<(this.DB-sh))-1)<<sh;\n }\n this.clamp();\n if(mi) BigInteger.ZERO.subTo(this,this);\n }\n\n // (protected) clamp off excess high words\n function bnpClamp() {\n var c = this.s&this.DM;\n while(this.t > 0 && this[this.t-1] == c) --this.t;\n }\n\n // (public) return string representation in given radix\n function bnToString(b) {\n if(this.s < 0) return \"-\"+this.negate().toString(b);\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else return this.toRadix(b);\n var km = (1<<k)-1, d, m = false, r = \"\", i = this.t;\n var p = this.DB-(i*this.DB)%k;\n if(i-- > 0) {\n if(p < this.DB && (d = this[i]>>p) > 0) { m = true; r = int2char(d); }\n while(i >= 0) {\n if(p < k) {\n d = (this[i]&((1<<p)-1))<<(k-p);\n d |= this[--i]>>(p+=this.DB-k);\n }\n else {\n d = (this[i]>>(p-=k))&km;\n if(p <= 0) { p += this.DB; --i; }\n }\n if(d > 0) m = true;\n if(m) r += int2char(d);\n }\n }\n return m?r:\"0\";\n }\n\n // (public) -this\n function bnNegate() { var r = nbi(); BigInteger.ZERO.subTo(this,r); return r; }\n\n // (public) |this|\n function bnAbs() { return (this.s<0)?this.negate():this; }\n\n // (public) return + if this > a, - if this < a, 0 if equal\n function bnCompareTo(a) {\n var r = this.s-a.s;\n if(r != 0) return r;\n var i = this.t;\n r = i-a.t;\n if(r != 0) return (this.s<0)?-r:r;\n while(--i >= 0) if((r=this[i]-a[i]) != 0) return r;\n return 0;\n }\n\n // returns bit length of the integer x\n function nbits(x) {\n var r = 1, t;\n if((t=x>>>16) != 0) { x = t; r += 16; }\n if((t=x>>8) != 0) { x = t; r += 8; }\n if((t=x>>4) != 0) { x = t; r += 4; }\n if((t=x>>2) != 0) { x = t; r += 2; }\n if((t=x>>1) != 0) { x = t; r += 1; }\n return r;\n }\n\n // (public) return the number of bits in \"this\"\n function bnBitLength() {\n if(this.t <= 0) return 0;\n return this.DB*(this.t-1)+nbits(this[this.t-1]^(this.s&this.DM));\n }\n\n // (protected) r = this << n*DB\n function bnpDLShiftTo(n,r) {\n var i;\n for(i = this.t-1; i >= 0; --i) r[i+n] = this[i];\n for(i = n-1; i >= 0; --i) r[i] = 0;\n r.t = this.t+n;\n r.s = this.s;\n }\n\n // (protected) r = this >> n*DB\n function bnpDRShiftTo(n,r) {\n for(var i = n; i < this.t; ++i) r[i-n] = this[i];\n r.t = Math.max(this.t-n,0);\n r.s = this.s;\n }\n\n // (protected) r = this << n\n function bnpLShiftTo(n,r) {\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<<cbs)-1;\n var ds = Math.floor(n/this.DB), c = (this.s<<bs)&this.DM, i;\n for(i = this.t-1; i >= 0; --i) {\n r[i+ds+1] = (this[i]>>cbs)|c;\n c = (this[i]&bm)<<bs;\n }\n for(i = ds-1; i >= 0; --i) r[i] = 0;\n r[ds] = c;\n r.t = this.t+ds+1;\n r.s = this.s;\n r.clamp();\n }\n\n // (protected) r = this >> n\n function bnpRShiftTo(n,r) {\n r.s = this.s;\n var ds = Math.floor(n/this.DB);\n if(ds >= this.t) { r.t = 0; return; }\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<<bs)-1;\n r[0] = this[ds]>>bs;\n for(var i = ds+1; i < this.t; ++i) {\n r[i-ds-1] |= (this[i]&bm)<<cbs;\n r[i-ds] = this[i]>>bs;\n }\n if(bs > 0) r[this.t-ds-1] |= (this.s&bm)<<cbs;\n r.t = this.t-ds;\n r.clamp();\n }\n\n // (protected) r = this - a\n function bnpSubTo(a,r) {\n var i = 0, c = 0, m = Math.min(a.t,this.t);\n while(i < m) {\n c += this[i]-a[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n if(a.t < this.t) {\n c -= a.s;\n while(i < this.t) {\n c += this[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n }\n else {\n c += this.s;\n while(i < a.t) {\n c -= a[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n c -= a.s;\n }\n r.s = (c<0)?-1:0;\n if(c < -1) r[i++] = this.DV+c;\n else if(c > 0) r[i++] = c;\n r.t = i;\n r.clamp();\n }\n\n // (protected) r = this * a, r != this,a (HAC 14.12)\n // \"this\" should be the larger one if appropriate.\n function bnpMultiplyTo(a,r) {\n var x = this.abs(), y = a.abs();\n var i = x.t;\n r.t = i+y.t;\n while(--i >= 0) r[i] = 0;\n for(i = 0; i < y.t; ++i) r[i+x.t] = x.am(0,y[i],r,i,0,x.t);\n r.s = 0;\n r.clamp();\n if(this.s != a.s) BigInteger.ZERO.subTo(r,r);\n }\n\n // (protected) r = this^2, r != this (HAC 14.16)\n function bnpSquareTo(r) {\n var x = this.abs();\n var i = r.t = 2*x.t;\n while(--i >= 0) r[i] = 0;\n for(i = 0; i < x.t-1; ++i) {\n var c = x.am(i,x[i],r,2*i,0,1);\n if((r[i+x.t]+=x.am(i+1,2*x[i],r,2*i+1,c,x.t-i-1)) >= x.DV) {\n r[i+x.t] -= x.DV;\n r[i+x.t+1] = 1;\n }\n }\n if(r.t > 0) r[r.t-1] += x.am(i,x[i],r,2*i,0,1);\n r.s = 0;\n r.clamp();\n }\n\n // (protected) divide this by m, quotient and remainder to q, r (HAC 14.20)\n // r != q, this != m. q or r may be null.\n function bnpDivRemTo(m,q,r) {\n var pm = m.abs();\n if(pm.t <= 0) return;\n var pt = this.abs();\n if(pt.t < pm.t) {\n if(q != null) q.fromInt(0);\n if(r != null) this.copyTo(r);\n return;\n }\n if(r == null) r = nbi();\n var y = nbi(), ts = this.s, ms = m.s;\n var nsh = this.DB-nbits(pm[pm.t-1]); // normalize modulus\n if(nsh > 0) { pm.lShiftTo(nsh,y); pt.lShiftTo(nsh,r); }\n else { pm.copyTo(y); pt.copyTo(r); }\n var ys = y.t;\n var y0 = y[ys-1];\n if(y0 == 0) return;\n var yt = y0*(1<<this.F1)+((ys>1)?y[ys-2]>>this.F2:0);\n var d1 = this.FV/yt, d2 = (1<<this.F1)/yt, e = 1<<this.F2;\n var i = r.t, j = i-ys, t = (q==null)?nbi():q;\n y.dlShiftTo(j,t);\n if(r.compareTo(t) >= 0) {\n r[r.t++] = 1;\n r.subTo(t,r);\n }\n BigInteger.ONE.dlShiftTo(ys,t);\n t.subTo(y,y); // \"negative\" y so we can replace sub with am later\n while(y.t < ys) y[y.t++] = 0;\n while(--j >= 0) {\n // Estimate quotient digit\n var qd = (r[--i]==y0)?this.DM:Math.floor(r[i]*d1+(r[i-1]+e)*d2);\n if((r[i]+=y.am(0,qd,r,j,0,ys)) < qd) { // Try it out\n y.dlShiftTo(j,t);\n r.subTo(t,r);\n while(r[i] < --qd) r.subTo(t,r);\n }\n }\n if(q != null) {\n r.drShiftTo(ys,q);\n if(ts != ms) BigInteger.ZERO.subTo(q,q);\n }\n r.t = ys;\n r.clamp();\n if(nsh > 0) r.rShiftTo(nsh,r); // Denormalize remainder\n if(ts < 0) BigInteger.ZERO.subTo(r,r);\n }\n\n // (public) this mod a\n function bnMod(a) {\n var r = nbi();\n this.abs().divRemTo(a,null,r);\n if(this.s < 0 && r.compareTo(BigInteger.ZERO) > 0) a.subTo(r,r);\n return r;\n }\n\n // Modular reduction using \"classic\" algorithm\n function Classic(m) { this.m = m; }\n function cConvert(x) {\n if(x.s < 0 || x.compareTo(this.m) >= 0) return x.mod(this.m);\n else return x;\n }\n function cRevert(x) { return x; }\n function cReduce(x) { x.divRemTo(this.m,null,x); }\n function cMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n function cSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n Classic.prototype.convert = cConvert;\n Classic.prototype.revert = cRevert;\n Classic.prototype.reduce = cReduce;\n Classic.prototype.mulTo = cMulTo;\n Classic.prototype.sqrTo = cSqrTo;\n\n // (protected) return \"-1/this % 2^DB\"; useful for Mont. reduction\n // justification:\n // xy == 1 (mod m)\n // xy = 1+km\n // xy(2-xy) = (1+km)(1-km)\n // x[y(2-xy)] = 1-k^2m^2\n // x[y(2-xy)] == 1 (mod m^2)\n // if y is 1/x mod m, then y(2-xy) is 1/x mod m^2\n // should reduce x and y(2-xy) by m^2 at each step to keep size bounded.\n // JS multiply \"overflows\" differently from C/C++, so care is needed here.\n function bnpInvDigit() {\n if(this.t < 1) return 0;\n var x = this[0];\n if((x&1) == 0) return 0;\n var y = x&3; // y == 1/x mod 2^2\n y = (y*(2-(x&0xf)*y))&0xf; // y == 1/x mod 2^4\n y = (y*(2-(x&0xff)*y))&0xff; // y == 1/x mod 2^8\n y = (y*(2-(((x&0xffff)*y)&0xffff)))&0xffff; // y == 1/x mod 2^16\n // last step - calculate inverse mod DV directly;\n // assumes 16 < DB <= 32 and assumes ability to handle 48-bit ints\n y = (y*(2-x*y%this.DV))%this.DV; // y == 1/x mod 2^dbits\n // we really want the negative inverse, and -DV < y < DV\n return (y>0)?this.DV-y:-y;\n }\n\n // Montgomery reduction\n function Montgomery(m) {\n this.m = m;\n this.mp = m.invDigit();\n this.mpl = this.mp&0x7fff;\n this.mph = this.mp>>15;\n this.um = (1<<(m.DB-15))-1;\n this.mt2 = 2*m.t;\n }\n\n // xR mod m\n function montConvert(x) {\n var r = nbi();\n x.abs().dlShiftTo(this.m.t,r);\n r.divRemTo(this.m,null,r);\n if(x.s < 0 && r.compareTo(BigInteger.ZERO) > 0) this.m.subTo(r,r);\n return r;\n }\n\n // x/R mod m\n function montRevert(x) {\n var r = nbi();\n x.copyTo(r);\n this.reduce(r);\n return r;\n }\n\n // x = x/R mod m (HAC 14.32)\n function montReduce(x) {\n while(x.t <= this.mt2) // pad x so am has enough room later\n x[x.t++] = 0;\n for(var i = 0; i < this.m.t; ++i) {\n // faster way of calculating u0 = x[i]*mp mod DV\n var j = x[i]&0x7fff;\n var u0 = (j*this.mpl+(((j*this.mph+(x[i]>>15)*this.mpl)&this.um)<<15))&x.DM;\n // use am to combine the multiply-shift-add into one call\n j = i+this.m.t;\n x[j] += this.m.am(0,u0,x,i,0,this.m.t);\n // propagate carry\n while(x[j] >= x.DV) { x[j] -= x.DV; x[++j]++; }\n }\n x.clamp();\n x.drShiftTo(this.m.t,x);\n if(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n }\n\n // r = \"x^2/R mod m\"; x != r\n function montSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n // r = \"xy/R mod m\"; x,y != r\n function montMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\n Montgomery.prototype.convert = montConvert;\n Montgomery.prototype.revert = montRevert;\n Montgomery.prototype.reduce = montReduce;\n Montgomery.prototype.mulTo = montMulTo;\n Montgomery.prototype.sqrTo = montSqrTo;\n\n // (protected) true iff this is even\n function bnpIsEven() { return ((this.t>0)?(this[0]&1):this.s) == 0; }\n\n // (protected) this^e, e < 2^32, doing sqr and mul with \"r\" (HAC 14.79)\n function bnpExp(e,z) {\n if(e > 0xffffffff || e < 1) return BigInteger.ONE;\n var r = nbi(), r2 = nbi(), g = z.convert(this), i = nbits(e)-1;\n g.copyTo(r);\n while(--i >= 0) {\n z.sqrTo(r,r2);\n if((e&(1<<i)) > 0) z.mulTo(r2,g,r);\n else { var t = r; r = r2; r2 = t; }\n }\n return z.revert(r);\n }\n\n // (public) this^e % m, 0 <= e < 2^32\n function bnModPowInt(e,m) {\n var z;\n if(e < 256 || m.isEven()) z = new Classic(m); else z = new Montgomery(m);\n return this.exp(e,z);\n }\n\n // protected\n BigInteger.prototype.copyTo = bnpCopyTo;\n BigInteger.prototype.fromInt = bnpFromInt;\n BigInteger.prototype.fromString = bnpFromString;\n BigInteger.prototype.clamp = bnpClamp;\n BigInteger.prototype.dlShiftTo = bnpDLShiftTo;\n BigInteger.prototype.drShiftTo = bnpDRShiftTo;\n BigInteger.prototype.lShiftTo = bnpLShiftTo;\n BigInteger.prototype.rShiftTo = bnpRShiftTo;\n BigInteger.prototype.subTo = bnpSubTo;\n BigInteger.prototype.multiplyTo = bnpMultiplyTo;\n BigInteger.prototype.squareTo = bnpSquareTo;\n BigInteger.prototype.divRemTo = bnpDivRemTo;\n BigInteger.prototype.invDigit = bnpInvDigit;\n BigInteger.prototype.isEven = bnpIsEven;\n BigInteger.prototype.exp = bnpExp;\n\n // public\n BigInteger.prototype.toString = bnToString;\n BigInteger.prototype.negate = bnNegate;\n BigInteger.prototype.abs = bnAbs;\n BigInteger.prototype.compareTo = bnCompareTo;\n BigInteger.prototype.bitLength = bnBitLength;\n BigInteger.prototype.mod = bnMod;\n BigInteger.prototype.modPowInt = bnModPowInt;\n\n // \"constants\"\n BigInteger.ZERO = nbv(0);\n BigInteger.ONE = nbv(1);\n\n // Copyright (c) 2005-2009 Tom Wu\n // All Rights Reserved.\n // See \"LICENSE\" for details.\n\n // Extended JavaScript BN functions, required for RSA private ops.\n\n // Version 1.1: new BigInteger(\"0\", 10) returns \"proper\" zero\n // Version 1.2: square() API, isProbablePrime fix\n\n // (public)\n function bnClone() { var r = nbi(); this.copyTo(r); return r; }\n\n // (public) return value as integer\n function bnIntValue() {\n if(this.s < 0) {\n if(this.t == 1) return this[0]-this.DV;\n else if(this.t == 0) return -1;\n }\n else if(this.t == 1) return this[0];\n else if(this.t == 0) return 0;\n // assumes 16 < DB < 32\n return ((this[1]&((1<<(32-this.DB))-1))<<this.DB)|this[0];\n }\n\n // (public) return value as byte\n function bnByteValue() { return (this.t==0)?this.s:(this[0]<<24)>>24; }\n\n // (public) return value as short (assumes DB>=16)\n function bnShortValue() { return (this.t==0)?this.s:(this[0]<<16)>>16; }\n\n // (protected) return x s.t. r^x < DV\n function bnpChunkSize(r) { return Math.floor(Math.LN2*this.DB/Math.log(r)); }\n\n // (public) 0 if this == 0, 1 if this > 0\n function bnSigNum() {\n if(this.s < 0) return -1;\n else if(this.t <= 0 || (this.t == 1 && this[0] <= 0)) return 0;\n else return 1;\n }\n\n // (protected) convert to radix string\n function bnpToRadix(b) {\n if(b == null) b = 10;\n if(this.signum() == 0 || b < 2 || b > 36) return \"0\";\n var cs = this.chunkSize(b);\n var a = Math.pow(b,cs);\n var d = nbv(a), y = nbi(), z = nbi(), r = \"\";\n this.divRemTo(d,y,z);\n while(y.signum() > 0) {\n r = (a+z.intValue()).toString(b).substr(1) + r;\n y.divRemTo(d,y,z);\n }\n return z.intValue().toString(b) + r;\n }\n\n // (protected) convert from radix string\n function bnpFromRadix(s,b) {\n this.fromInt(0);\n if(b == null) b = 10;\n var cs = this.chunkSize(b);\n var d = Math.pow(b,cs), mi = false, j = 0, w = 0;\n for(var i = 0; i < s.length; ++i) {\n var x = intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\" && this.signum() == 0) mi = true;\n continue;\n }\n w = b*w+x;\n if(++j >= cs) {\n this.dMultiply(d);\n this.dAddOffset(w,0);\n j = 0;\n w = 0;\n }\n }\n if(j > 0) {\n this.dMultiply(Math.pow(b,j));\n this.dAddOffset(w,0);\n }\n if(mi) BigInteger.ZERO.subTo(this,this);\n }\n\n // (protected) alternate constructor\n function bnpFromNumber(a,b,c) {\n if(\"number\" == typeof b) {\n // new BigInteger(int,int,RNG)\n if(a < 2) this.fromInt(1);\n else {\n this.fromNumber(a,c);\n if(!this.testBit(a-1)) // force MSB set\n this.bitwiseTo(BigInteger.ONE.shiftLeft(a-1),op_or,this);\n if(this.isEven()) this.dAddOffset(1,0); // force odd\n while(!this.isProbablePrime(b)) {\n this.dAddOffset(2,0);\n if(this.bitLength() > a) this.subTo(BigInteger.ONE.shiftLeft(a-1),this);\n }\n }\n }\n else {\n // new BigInteger(int,RNG)\n var x = new Array(), t = a&7;\n x.length = (a>>3)+1;\n b.nextBytes(x);\n if(t > 0) x[0] &= ((1<<t)-1); else x[0] = 0;\n this.fromString(x,256);\n }\n }\n\n // (public) convert to bigendian byte array\n function bnToByteArray() {\n var i = this.t, r = new Array();\n r[0] = this.s;\n var p = this.DB-(i*this.DB)%8, d, k = 0;\n if(i-- > 0) {\n if(p < this.DB && (d = this[i]>>p) != (this.s&this.DM)>>p)\n r[k++] = d|(this.s<<(this.DB-p));\n while(i >= 0) {\n if(p < 8) {\n d = (this[i]&((1<<p)-1))<<(8-p);\n d |= this[--i]>>(p+=this.DB-8);\n }\n else {\n d = (this[i]>>(p-=8))&0xff;\n if(p <= 0) { p += this.DB; --i; }\n }\n if((d&0x80) != 0) d |= -256;\n if(k == 0 && (this.s&0x80) != (d&0x80)) ++k;\n if(k > 0 || d != this.s) r[k++] = d;\n }\n }\n return r;\n }\n\n function bnEquals(a) { return(this.compareTo(a)==0); }\n function bnMin(a) { return(this.compareTo(a)<0)?this:a; }\n function bnMax(a) { return(this.compareTo(a)>0)?this:a; }\n\n // (protected) r = this op a (bitwise)\n function bnpBitwiseTo(a,op,r) {\n var i, f, m = Math.min(a.t,this.t);\n for(i = 0; i < m; ++i) r[i] = op(this[i],a[i]);\n if(a.t < this.t) {\n f = a.s&this.DM;\n for(i = m; i < this.t; ++i) r[i] = op(this[i],f);\n r.t = this.t;\n }\n else {\n f = this.s&this.DM;\n for(i = m; i < a.t; ++i) r[i] = op(f,a[i]);\n r.t = a.t;\n }\n r.s = op(this.s,a.s);\n r.clamp();\n }\n\n // (public) this & a\n function op_and(x,y) { return x&y; }\n function bnAnd(a) { var r = nbi(); this.bitwiseTo(a,op_and,r); return r; }\n\n // (public) this | a\n function op_or(x,y) { return x|y; }\n function bnOr(a) { var r = nbi(); this.bitwiseTo(a,op_or,r); return r; }\n\n // (public) this ^ a\n function op_xor(x,y) { return x^y; }\n function bnXor(a) { var r = nbi(); this.bitwiseTo(a,op_xor,r); return r; }\n\n // (public) this & ~a\n function op_andnot(x,y) { return x&~y; }\n function bnAndNot(a) { var r = nbi(); this.bitwiseTo(a,op_andnot,r); return r; }\n\n // (public) ~this\n function bnNot() {\n var r = nbi();\n for(var i = 0; i < this.t; ++i) r[i] = this.DM&~this[i];\n r.t = this.t;\n r.s = ~this.s;\n return r;\n }\n\n // (public) this << n\n function bnShiftLeft(n) {\n var r = nbi();\n if(n < 0) this.rShiftTo(-n,r); else this.lShiftTo(n,r);\n return r;\n }\n\n // (public) this >> n\n function bnShiftRight(n) {\n var r = nbi();\n if(n < 0) this.lShiftTo(-n,r); else this.rShiftTo(n,r);\n return r;\n }\n\n // return index of lowest 1-bit in x, x < 2^31\n function lbit(x) {\n if(x == 0) return -1;\n var r = 0;\n if((x&0xffff) == 0) { x >>= 16; r += 16; }\n if((x&0xff) == 0) { x >>= 8; r += 8; }\n if((x&0xf) == 0) { x >>= 4; r += 4; }\n if((x&3) == 0) { x >>= 2; r += 2; }\n if((x&1) == 0) ++r;\n return r;\n }\n\n // (public) returns index of lowest 1-bit (or -1 if none)\n function bnGetLowestSetBit() {\n for(var i = 0; i < this.t; ++i)\n if(this[i] != 0) return i*this.DB+lbit(this[i]);\n if(this.s < 0) return this.t*this.DB;\n return -1;\n }\n\n // return number of 1 bits in x\n function cbit(x) {\n var r = 0;\n while(x != 0) { x &= x-1; ++r; }\n return r;\n }\n\n // (public) return number of set bits\n function bnBitCount() {\n var r = 0, x = this.s&this.DM;\n for(var i = 0; i < this.t; ++i) r += cbit(this[i]^x);\n return r;\n }\n\n // (public) true iff nth bit is set\n function bnTestBit(n) {\n var j = Math.floor(n/this.DB);\n if(j >= this.t) return(this.s!=0);\n return((this[j]&(1<<(n%this.DB)))!=0);\n }\n\n // (protected) this op (1<<n)\n function bnpChangeBit(n,op) {\n var r = BigInteger.ONE.shiftLeft(n);\n this.bitwiseTo(r,op,r);\n return r;\n }\n\n // (public) this | (1<<n)\n function bnSetBit(n) { return this.changeBit(n,op_or); }\n\n // (public) this & ~(1<<n)\n function bnClearBit(n) { return this.changeBit(n,op_andnot); }\n\n // (public) this ^ (1<<n)\n function bnFlipBit(n) { return this.changeBit(n,op_xor); }\n\n // (protected) r = this + a\n function bnpAddTo(a,r) {\n var i = 0, c = 0, m = Math.min(a.t,this.t);\n while(i < m) {\n c += this[i]+a[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n if(a.t < this.t) {\n c += a.s;\n while(i < this.t) {\n c += this[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n }\n else {\n c += this.s;\n while(i < a.t) {\n c += a[i];\n r[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += a.s;\n }\n r.s = (c<0)?-1:0;\n if(c > 0) r[i++] = c;\n else if(c < -1) r[i++] = this.DV+c;\n r.t = i;\n r.clamp();\n }\n\n // (public) this + a\n function bnAdd(a) { var r = nbi(); this.addTo(a,r); return r; }\n\n // (public) this - a\n function bnSubtract(a) { var r = nbi(); this.subTo(a,r); return r; }\n\n // (public) this * a\n function bnMultiply(a) { var r = nbi(); this.multiplyTo(a,r); return r; }\n\n // (public) this^2\n function bnSquare() { var r = nbi(); this.squareTo(r); return r; }\n\n // (public) this / a\n function bnDivide(a) { var r = nbi(); this.divRemTo(a,r,null); return r; }\n\n // (public) this % a\n function bnRemainder(a) { var r = nbi(); this.divRemTo(a,null,r); return r; }\n\n // (public) [this/a,this%a]\n function bnDivideAndRemainder(a) {\n var q = nbi(), r = nbi();\n this.divRemTo(a,q,r);\n return new Array(q,r);\n }\n\n // (protected) this *= n, this >= 0, 1 < n < DV\n function bnpDMultiply(n) {\n this[this.t] = this.am(0,n-1,this,0,0,this.t);\n ++this.t;\n this.clamp();\n }\n\n // (protected) this += n << w words, this >= 0\n function bnpDAddOffset(n,w) {\n if(n == 0) return;\n while(this.t <= w) this[this.t++] = 0;\n this[w] += n;\n while(this[w] >= this.DV) {\n this[w] -= this.DV;\n if(++w >= this.t) this[this.t++] = 0;\n ++this[w];\n }\n }\n\n // A \"null\" reducer\n function NullExp() {}\n function nNop(x) { return x; }\n function nMulTo(x,y,r) { x.multiplyTo(y,r); }\n function nSqrTo(x,r) { x.squareTo(r); }\n\n NullExp.prototype.convert = nNop;\n NullExp.prototype.revert = nNop;\n NullExp.prototype.mulTo = nMulTo;\n NullExp.prototype.sqrTo = nSqrTo;\n\n // (public) this^e\n function bnPow(e) { return this.exp(e,new NullExp()); }\n\n // (protected) r = lower n words of \"this * a\", a.t <= n\n // \"this\" should be the larger one if appropriate.\n function bnpMultiplyLowerTo(a,n,r) {\n var i = Math.min(this.t+a.t,n);\n r.s = 0; // assumes a,this >= 0\n r.t = i;\n while(i > 0) r[--i] = 0;\n var j;\n for(j = r.t-this.t; i < j; ++i) r[i+this.t] = this.am(0,a[i],r,i,0,this.t);\n for(j = Math.min(a.t,n); i < j; ++i) this.am(0,a[i],r,i,0,n-i);\n r.clamp();\n }\n\n // (protected) r = \"this * a\" without lower n words, n > 0\n // \"this\" should be the larger one if appropriate.\n function bnpMultiplyUpperTo(a,n,r) {\n --n;\n var i = r.t = this.t+a.t-n;\n r.s = 0; // assumes a,this >= 0\n while(--i >= 0) r[i] = 0;\n for(i = Math.max(n-this.t,0); i < a.t; ++i)\n r[this.t+i-n] = this.am(n-i,a[i],r,0,0,this.t+i-n);\n r.clamp();\n r.drShiftTo(1,r);\n }\n\n // Barrett modular reduction\n function Barrett(m) {\n // setup Barrett\n this.r2 = nbi();\n this.q3 = nbi();\n BigInteger.ONE.dlShiftTo(2*m.t,this.r2);\n this.mu = this.r2.divide(m);\n this.m = m;\n }\n\n function barrettConvert(x) {\n if(x.s < 0 || x.t > 2*this.m.t) return x.mod(this.m);\n else if(x.compareTo(this.m) < 0) return x;\n else { var r = nbi(); x.copyTo(r); this.reduce(r); return r; }\n }\n\n function barrettRevert(x) { return x; }\n\n // x = x mod m (HAC 14.42)\n function barrettReduce(x) {\n x.drShiftTo(this.m.t-1,this.r2);\n if(x.t > this.m.t+1) { x.t = this.m.t+1; x.clamp(); }\n this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3);\n this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);\n while(x.compareTo(this.r2) < 0) x.dAddOffset(1,this.m.t+1);\n x.subTo(this.r2,x);\n while(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n }\n\n // r = x^2 mod m; x != r\n function barrettSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n // r = x*y mod m; x,y != r\n function barrettMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\n Barrett.prototype.convert = barrettConvert;\n Barrett.prototype.revert = barrettRevert;\n Barrett.prototype.reduce = barrettReduce;\n Barrett.prototype.mulTo = barrettMulTo;\n Barrett.prototype.sqrTo = barrettSqrTo;\n\n // (public) this^e % m (HAC 14.85)\n function bnModPow(e,m) {\n var i = e.bitLength(), k, r = nbv(1), z;\n if(i <= 0) return r;\n else if(i < 18) k = 1;\n else if(i < 48) k = 3;\n else if(i < 144) k = 4;\n else if(i < 768) k = 5;\n else k = 6;\n if(i < 8)\n z = new Classic(m);\n else if(m.isEven())\n z = new Barrett(m);\n else\n z = new Montgomery(m);\n\n // precomputation\n var g = new Array(), n = 3, k1 = k-1, km = (1<<k)-1;\n g[1] = z.convert(this);\n if(k > 1) {\n var g2 = nbi();\n z.sqrTo(g[1],g2);\n while(n <= km) {\n g[n] = nbi();\n z.mulTo(g2,g[n-2],g[n]);\n n += 2;\n }\n }\n\n var j = e.t-1, w, is1 = true, r2 = nbi(), t;\n i = nbits(e[j])-1;\n while(j >= 0) {\n if(i >= k1) w = (e[j]>>(i-k1))&km;\n else {\n w = (e[j]&((1<<(i+1))-1))<<(k1-i);\n if(j > 0) w |= e[j-1]>>(this.DB+i-k1);\n }\n\n n = k;\n while((w&1) == 0) { w >>= 1; --n; }\n if((i -= n) < 0) { i += this.DB; --j; }\n if(is1) { // ret == 1, don't bother squaring or multiplying it\n g[w].copyTo(r);\n is1 = false;\n }\n else {\n while(n > 1) { z.sqrTo(r,r2); z.sqrTo(r2,r); n -= 2; }\n if(n > 0) z.sqrTo(r,r2); else { t = r; r = r2; r2 = t; }\n z.mulTo(r2,g[w],r);\n }\n\n while(j >= 0 && (e[j]&(1<<i)) == 0) {\n z.sqrTo(r,r2); t = r; r = r2; r2 = t;\n if(--i < 0) { i = this.DB-1; --j; }\n }\n }\n return z.revert(r);\n }\n\n // (public) gcd(this,a) (HAC 14.54)\n function bnGCD(a) {\n var x = (this.s<0)?this.negate():this.clone();\n var y = (a.s<0)?a.negate():a.clone();\n if(x.compareTo(y) < 0) { var t = x; x = y; y = t; }\n var i = x.getLowestSetBit(), g = y.getLowestSetBit();\n if(g < 0) return x;\n if(i < g) g = i;\n if(g > 0) {\n x.rShiftTo(g,x);\n y.rShiftTo(g,y);\n }\n while(x.signum() > 0) {\n if((i = x.getLowestSetBit()) > 0) x.rShiftTo(i,x);\n if((i = y.getLowestSetBit()) > 0) y.rShiftTo(i,y);\n if(x.compareTo(y) >= 0) {\n x.subTo(y,x);\n x.rShiftTo(1,x);\n }\n else {\n y.subTo(x,y);\n y.rShiftTo(1,y);\n }\n }\n if(g > 0) y.lShiftTo(g,y);\n return y;\n }\n\n // (protected) this % n, n < 2^26\n function bnpModInt(n) {\n if(n <= 0) return 0;\n var d = this.DV%n, r = (this.s<0)?n-1:0;\n if(this.t > 0)\n if(d == 0) r = this[0]%n;\n else for(var i = this.t-1; i >= 0; --i) r = (d*r+this[i])%n;\n return r;\n }\n\n // (public) 1/this % m (HAC 14.61)\n function bnModInverse(m) {\n var ac = m.isEven();\n if((this.isEven() && ac) || m.signum() == 0) return BigInteger.ZERO;\n var u = m.clone(), v = this.clone();\n var a = nbv(1), b = nbv(0), c = nbv(0), d = nbv(1);\n while(u.signum() != 0) {\n while(u.isEven()) {\n u.rShiftTo(1,u);\n if(ac) {\n if(!a.isEven() || !b.isEven()) { a.addTo(this,a); b.subTo(m,b); }\n a.rShiftTo(1,a);\n }\n else if(!b.isEven()) b.subTo(m,b);\n b.rShiftTo(1,b);\n }\n while(v.isEven()) {\n v.rShiftTo(1,v);\n if(ac) {\n if(!c.isEven() || !d.isEven()) { c.addTo(this,c); d.subTo(m,d); }\n c.rShiftTo(1,c);\n }\n else if(!d.isEven()) d.subTo(m,d);\n d.rShiftTo(1,d);\n }\n if(u.compareTo(v) >= 0) {\n u.subTo(v,u);\n if(ac) a.subTo(c,a);\n b.subTo(d,b);\n }\n else {\n v.subTo(u,v);\n if(ac) c.subTo(a,c);\n d.subTo(b,d);\n }\n }\n if(v.compareTo(BigInteger.ONE) != 0) return BigInteger.ZERO;\n if(d.compareTo(m) >= 0) return d.subtract(m);\n if(d.signum() < 0) d.addTo(m,d); else return d;\n if(d.signum() < 0) return d.add(m); else return d;\n }\n\n var lowprimes = [2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997];\n var lplim = (1<<26)/lowprimes[lowprimes.length-1];\n\n // (public) test primality with certainty >= 1-.5^t\n function bnIsProbablePrime(t) {\n var i, x = this.abs();\n if(x.t == 1 && x[0] <= lowprimes[lowprimes.length-1]) {\n for(i = 0; i < lowprimes.length; ++i)\n if(x[0] == lowprimes[i]) return true;\n return false;\n }\n if(x.isEven()) return false;\n i = 1;\n while(i < lowprimes.length) {\n var m = lowprimes[i], j = i+1;\n while(j < lowprimes.length && m < lplim) m *= lowprimes[j++];\n m = x.modInt(m);\n while(i < j) if(m%lowprimes[i++] == 0) return false;\n }\n return x.millerRabin(t);\n }\n\n // (protected) true if probably prime (HAC 4.24, Miller-Rabin)\n function bnpMillerRabin(t) {\n var n1 = this.subtract(BigInteger.ONE);\n var k = n1.getLowestSetBit();\n if(k <= 0) return false;\n var r = n1.shiftRight(k);\n t = (t+1)>>1;\n if(t > lowprimes.length) t = lowprimes.length;\n var a = nbi();\n for(var i = 0; i < t; ++i) {\n //Pick bases at random, instead of starting at 2\n a.fromInt(lowprimes[Math.floor(Math.random()*lowprimes.length)]);\n var y = a.modPow(r,this);\n if(y.compareTo(BigInteger.ONE) != 0 && y.compareTo(n1) != 0) {\n var j = 1;\n while(j++ < k && y.compareTo(n1) != 0) {\n y = y.modPowInt(2,this);\n if(y.compareTo(BigInteger.ONE) == 0) return false;\n }\n if(y.compareTo(n1) != 0) return false;\n }\n }\n return true;\n }\n\n // protected\n BigInteger.prototype.chunkSize = bnpChunkSize;\n BigInteger.prototype.toRadix = bnpToRadix;\n BigInteger.prototype.fromRadix = bnpFromRadix;\n BigInteger.prototype.fromNumber = bnpFromNumber;\n BigInteger.prototype.bitwiseTo = bnpBitwiseTo;\n BigInteger.prototype.changeBit = bnpChangeBit;\n BigInteger.prototype.addTo = bnpAddTo;\n BigInteger.prototype.dMultiply = bnpDMultiply;\n BigInteger.prototype.dAddOffset = bnpDAddOffset;\n BigInteger.prototype.multiplyLowerTo = bnpMultiplyLowerTo;\n BigInteger.prototype.multiplyUpperTo = bnpMultiplyUpperTo;\n BigInteger.prototype.modInt = bnpModInt;\n BigInteger.prototype.millerRabin = bnpMillerRabin;\n\n // public\n BigInteger.prototype.clone = bnClone;\n BigInteger.prototype.intValue = bnIntValue;\n BigInteger.prototype.byteValue = bnByteValue;\n BigInteger.prototype.shortValue = bnShortValue;\n BigInteger.prototype.signum = bnSigNum;\n BigInteger.prototype.toByteArray = bnToByteArray;\n BigInteger.prototype.equals = bnEquals;\n BigInteger.prototype.min = bnMin;\n BigInteger.prototype.max = bnMax;\n BigInteger.prototype.and = bnAnd;\n BigInteger.prototype.or = bnOr;\n BigInteger.prototype.xor = bnXor;\n BigInteger.prototype.andNot = bnAndNot;\n BigInteger.prototype.not = bnNot;\n BigInteger.prototype.shiftLeft = bnShiftLeft;\n BigInteger.prototype.shiftRight = bnShiftRight;\n BigInteger.prototype.getLowestSetBit = bnGetLowestSetBit;\n BigInteger.prototype.bitCount = bnBitCount;\n BigInteger.prototype.testBit = bnTestBit;\n BigInteger.prototype.setBit = bnSetBit;\n BigInteger.prototype.clearBit = bnClearBit;\n BigInteger.prototype.flipBit = bnFlipBit;\n BigInteger.prototype.add = bnAdd;\n BigInteger.prototype.subtract = bnSubtract;\n BigInteger.prototype.multiply = bnMultiply;\n BigInteger.prototype.divide = bnDivide;\n BigInteger.prototype.remainder = bnRemainder;\n BigInteger.prototype.divideAndRemainder = bnDivideAndRemainder;\n BigInteger.prototype.modPow = bnModPow;\n BigInteger.prototype.modInverse = bnModInverse;\n BigInteger.prototype.pow = bnPow;\n BigInteger.prototype.gcd = bnGCD;\n BigInteger.prototype.isProbablePrime = bnIsProbablePrime;\n\n // JSBN-specific extension\n BigInteger.prototype.square = bnSquare;\n\n // Expose the Barrett function\n BigInteger.prototype.Barrett = Barrett\n\n // BigInteger interfaces not implemented in jsbn:\n\n // BigInteger(int signum, byte[] magnitude)\n // double doubleValue()\n // float floatValue()\n // int hashCode()\n // long longValue()\n // static BigInteger valueOf(long val)\n\n // Random number generator - requires a PRNG backend, e.g. prng4.js\n\n // For best results, put code like\n // <body onClick='rng_seed_time();' onKeyPress='rng_seed_time();'>\n // in your main HTML document.\n\n var rng_state;\n var rng_pool;\n var rng_pptr;\n\n // Mix in a 32-bit integer into the pool\n function rng_seed_int(x) {\n rng_pool[rng_pptr++] ^= x & 255;\n rng_pool[rng_pptr++] ^= (x >> 8) & 255;\n rng_pool[rng_pptr++] ^= (x >> 16) & 255;\n rng_pool[rng_pptr++] ^= (x >> 24) & 255;\n if(rng_pptr >= rng_psize) rng_pptr -= rng_psize;\n }\n\n // Mix in the current time (w/milliseconds) into the pool\n function rng_seed_time() {\n rng_seed_int(new Date().getTime());\n }\n\n // Initialize the pool with junk if needed.\n if(rng_pool == null) {\n rng_pool = new Array();\n rng_pptr = 0;\n var t;\n if(typeof window !== \"undefined\" && window.crypto) {\n if (window.crypto.getRandomValues) {\n // Use webcrypto if available\n var ua = new Uint8Array(32);\n window.crypto.getRandomValues(ua);\n for(t = 0; t < 32; ++t)\n rng_pool[rng_pptr++] = ua[t];\n }\n else if(navigator.appName == \"Netscape\" && navigator.appVersion < \"5\") {\n // Extract entropy (256 bits) from NS4 RNG if available\n var z = window.crypto.random(32);\n for(t = 0; t < z.length; ++t)\n rng_pool[rng_pptr++] = z.charCodeAt(t) & 255;\n }\n }\n while(rng_pptr < rng_psize) { // extract some randomness from Math.random()\n t = Math.floor(65536 * Math.random());\n rng_pool[rng_pptr++] = t >>> 8;\n rng_pool[rng_pptr++] = t & 255;\n }\n rng_pptr = 0;\n rng_seed_time();\n //rng_seed_int(window.screenX);\n //rng_seed_int(window.screenY);\n }\n\n function rng_get_byte() {\n if(rng_state == null) {\n rng_seed_time();\n rng_state = prng_newstate();\n rng_state.init(rng_pool);\n for(rng_pptr = 0; rng_pptr < rng_pool.length; ++rng_pptr)\n rng_pool[rng_pptr] = 0;\n rng_pptr = 0;\n //rng_pool = null;\n }\n // TODO: allow reseeding after first request\n return rng_state.next();\n }\n\n function rng_get_bytes(ba) {\n var i;\n for(i = 0; i < ba.length; ++i) ba[i] = rng_get_byte();\n }\n\n function SecureRandom() {}\n\n SecureRandom.prototype.nextBytes = rng_get_bytes;\n\n // prng4.js - uses Arcfour as a PRNG\n\n function Arcfour() {\n this.i = 0;\n this.j = 0;\n this.S = new Array();\n }\n\n // Initialize arcfour context from key, an array of ints, each from [0..255]\n function ARC4init(key) {\n var i, j, t;\n for(i = 0; i < 256; ++i)\n this.S[i] = i;\n j = 0;\n for(i = 0; i < 256; ++i) {\n j = (j + this.S[i] + key[i % key.length]) & 255;\n t = this.S[i];\n this.S[i] = this.S[j];\n this.S[j] = t;\n }\n this.i = 0;\n this.j = 0;\n }\n\n function ARC4next() {\n var t;\n this.i = (this.i + 1) & 255;\n this.j = (this.j + this.S[this.i]) & 255;\n t = this.S[this.i];\n this.S[this.i] = this.S[this.j];\n this.S[this.j] = t;\n return this.S[(t + this.S[this.i]) & 255];\n }\n\n Arcfour.prototype.init = ARC4init;\n Arcfour.prototype.next = ARC4next;\n\n // Plug in your RNG constructor here\n function prng_newstate() {\n return new Arcfour();\n }\n\n // Pool size must be a multiple of 4 and greater than 32.\n // An array of bytes the size of the pool will be passed to init()\n var rng_psize = 256;\n\n if (typeof exports !== 'undefined') {\n exports = module.exports = {\n default: BigInteger,\n BigInteger: BigInteger,\n SecureRandom: SecureRandom,\n };\n } else {\n this.jsbn = {\n BigInteger: BigInteger,\n SecureRandom: SecureRandom\n };\n }\n\n}).call(this);\n","/* global window, exports, define */\n\n!function() {\n 'use strict'\n\n var re = {\n not_string: /[^s]/,\n not_bool: /[^t]/,\n not_type: /[^T]/,\n not_primitive: /[^v]/,\n number: /[diefg]/,\n numeric_arg: /[bcdiefguxX]/,\n json: /[j]/,\n not_json: /[^j]/,\n text: /^[^\\x25]+/,\n modulo: /^\\x25{2}/,\n placeholder: /^\\x25(?:([1-9]\\d*)\\$|\\(([^)]+)\\))?(\\+)?(0|'[^$])?(-)?(\\d+)?(?:\\.(\\d+))?([b-gijostTuvxX])/,\n key: /^([a-z_][a-z_\\d]*)/i,\n key_access: /^\\.([a-z_][a-z_\\d]*)/i,\n index_access: /^\\[(\\d+)\\]/,\n sign: /^[+-]/\n }\n\n function sprintf(key) {\n // `arguments` is not an array, but should be fine for this call\n return sprintf_format(sprintf_parse(key), arguments)\n }\n\n function vsprintf(fmt, argv) {\n return sprintf.apply(null, [fmt].concat(argv || []))\n }\n\n function sprintf_format(parse_tree, argv) {\n var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign\n for (i = 0; i < tree_length; i++) {\n if (typeof parse_tree[i] === 'string') {\n output += parse_tree[i]\n }\n else if (typeof parse_tree[i] === 'object') {\n ph = parse_tree[i] // convenience purposes only\n if (ph.keys) { // keyword argument\n arg = argv[cursor]\n for (k = 0; k < ph.keys.length; k++) {\n if (arg == undefined) {\n throw new Error(sprintf('[sprintf] Cannot access property \"%s\" of undefined value \"%s\"', ph.keys[k], ph.keys[k-1]))\n }\n arg = arg[ph.keys[k]]\n }\n }\n else if (ph.param_no) { // positional argument (explicit)\n arg = argv[ph.param_no]\n }\n else { // positional argument (implicit)\n arg = argv[cursor++]\n }\n\n if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) {\n arg = arg()\n }\n\n if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) {\n throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg))\n }\n\n if (re.number.test(ph.type)) {\n is_positive = arg >= 0\n }\n\n switch (ph.type) {\n case 'b':\n arg = parseInt(arg, 10).toString(2)\n break\n case 'c':\n arg = String.fromCharCode(parseInt(arg, 10))\n break\n case 'd':\n case 'i':\n arg = parseInt(arg, 10)\n break\n case 'j':\n arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0)\n break\n case 'e':\n arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential()\n break\n case 'f':\n arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg)\n break\n case 'g':\n arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg)\n break\n case 'o':\n arg = (parseInt(arg, 10) >>> 0).toString(8)\n break\n case 's':\n arg = String(arg)\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 't':\n arg = String(!!arg)\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 'T':\n arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase()\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 'u':\n arg = parseInt(arg, 10) >>> 0\n break\n case 'v':\n arg = arg.valueOf()\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 'x':\n arg = (parseInt(arg, 10) >>> 0).toString(16)\n break\n case 'X':\n arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase()\n break\n }\n if (re.json.test(ph.type)) {\n output += arg\n }\n else {\n if (re.number.test(ph.type) && (!is_positive || ph.sign)) {\n sign = is_positive ? '+' : '-'\n arg = arg.toString().replace(re.sign, '')\n }\n else {\n sign = ''\n }\n pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' '\n pad_length = ph.width - (sign + arg).length\n pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : ''\n output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg)\n }\n }\n }\n return output\n }\n\n var sprintf_cache = Object.create(null)\n\n function sprintf_parse(fmt) {\n if (sprintf_cache[fmt]) {\n return sprintf_cache[fmt]\n }\n\n var _fmt = fmt, match, parse_tree = [], arg_names = 0\n while (_fmt) {\n if ((match = re.text.exec(_fmt)) !== null) {\n parse_tree.push(match[0])\n }\n else if ((match = re.modulo.exec(_fmt)) !== null) {\n parse_tree.push('%')\n }\n else if ((match = re.placeholder.exec(_fmt)) !== null) {\n if (match[2]) {\n arg_names |= 1\n var field_list = [], replacement_field = match[2], field_match = []\n if ((field_match = re.key.exec(replacement_field)) !== null) {\n field_list.push(field_match[1])\n while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') {\n if ((field_match = re.key_access.exec(replacement_field)) !== null) {\n field_list.push(field_match[1])\n }\n else if ((field_match = re.index_access.exec(replacement_field)) !== null) {\n field_list.push(field_match[1])\n }\n else {\n throw new SyntaxError('[sprintf] failed to parse named argument key')\n }\n }\n }\n else {\n throw new SyntaxError('[sprintf] failed to parse named argument key')\n }\n match[2] = field_list\n }\n else {\n arg_names |= 2\n }\n if (arg_names === 3) {\n throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported')\n }\n\n parse_tree.push(\n {\n placeholder: match[0],\n param_no: match[1],\n keys: match[2],\n sign: match[3],\n pad_char: match[4],\n align: match[5],\n width: match[6],\n precision: match[7],\n type: match[8]\n }\n )\n }\n else {\n throw new SyntaxError('[sprintf] unexpected placeholder')\n }\n _fmt = _fmt.substring(match[0].length)\n }\n return sprintf_cache[fmt] = parse_tree\n }\n\n /**\n * export to either browser or node.js\n */\n /* eslint-disable quote-props */\n if (typeof exports !== 'undefined') {\n exports['sprintf'] = sprintf\n exports['vsprintf'] = vsprintf\n }\n if (typeof window !== 'undefined') {\n window['sprintf'] = sprintf\n window['vsprintf'] = vsprintf\n\n if (typeof define === 'function' && define['amd']) {\n define(function() {\n return {\n 'sprintf': sprintf,\n 'vsprintf': vsprintf\n }\n })\n }\n }\n /* eslint-enable quote-props */\n}(); // eslint-disable-line\n",null,null,null,null,"'use strict';\n\nclass TimeoutError extends Error {\n\tconstructor(message) {\n\t\tsuper(message);\n\t\tthis.name = 'TimeoutError';\n\t}\n}\n\nconst pTimeout = (promise, milliseconds, fallback, options) => {\n\tlet timer;\n\tconst cancelablePromise = new Promise((resolve, reject) => {\n\t\tif (typeof milliseconds !== 'number' || milliseconds < 0) {\n\t\t\tthrow new TypeError('Expected `milliseconds` to be a positive number');\n\t\t}\n\n\t\tif (milliseconds === Infinity) {\n\t\t\tresolve(promise);\n\t\t\treturn;\n\t\t}\n\n\t\toptions = {\n\t\t\tcustomTimers: {setTimeout, clearTimeout},\n\t\t\t...options\n\t\t};\n\n\t\ttimer = options.customTimers.setTimeout.call(undefined, () => {\n\t\t\tif (typeof fallback === 'function') {\n\t\t\t\ttry {\n\t\t\t\t\tresolve(fallback());\n\t\t\t\t} catch (error) {\n\t\t\t\t\treject(error);\n\t\t\t\t}\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst message = typeof fallback === 'string' ? fallback : `Promise timed out after ${milliseconds} milliseconds`;\n\t\t\tconst timeoutError = fallback instanceof Error ? fallback : new TimeoutError(message);\n\n\t\t\tif (typeof promise.cancel === 'function') {\n\t\t\t\tpromise.cancel();\n\t\t\t}\n\n\t\t\treject(timeoutError);\n\t\t}, milliseconds);\n\n\t\t(async () => {\n\t\t\ttry {\n\t\t\t\tresolve(await promise);\n\t\t\t} catch (error) {\n\t\t\t\treject(error);\n\t\t\t} finally {\n\t\t\t\toptions.customTimers.clearTimeout.call(undefined, timer);\n\t\t\t}\n\t\t})();\n\t});\n\n\tcancelablePromise.clear = () => {\n\t\tclearTimeout(timer);\n\t\ttimer = undefined;\n\t};\n\n\treturn cancelablePromise;\n};\n\nmodule.exports = pTimeout;\n// TODO: Remove this for the next major release\nmodule.exports.default = pTimeout;\n\nmodule.exports.TimeoutError = TimeoutError;\n","'use strict'\n\nconst mafmt = require('mafmt')\nconst {\n CODE_CIRCUIT,\n CODE_P2P,\n CODE_TCP,\n CODE_WS,\n CODE_WSS\n} = require('./constants')\n\nmodule.exports = {\n all: (multiaddrs) => multiaddrs.filter((ma) => {\n if (ma.protoCodes().includes(CODE_CIRCUIT)) {\n return false\n }\n\n const testMa = ma.decapsulateCode(CODE_P2P)\n\n return mafmt.WebSockets.matches(testMa) ||\n mafmt.WebSocketsSecure.matches(testMa)\n }),\n dnsWss: (multiaddrs) => multiaddrs.filter((ma) => {\n if (ma.protoCodes().includes(CODE_CIRCUIT)) {\n return false\n }\n\n const testMa = ma.decapsulateCode(CODE_P2P)\n\n return mafmt.WebSocketsSecure.matches(testMa) &&\n mafmt.DNS.matches(testMa.decapsulateCode(CODE_TCP).decapsulateCode(CODE_WSS))\n }),\n dnsWsOrWss: (multiaddrs) => multiaddrs.filter((ma) => {\n if (ma.protoCodes().includes(CODE_CIRCUIT)) {\n return false\n }\n\n const testMa = ma.decapsulateCode(CODE_P2P)\n\n // WS\n if (mafmt.WebSockets.matches(testMa)) {\n return mafmt.DNS.matches(testMa.decapsulateCode(CODE_TCP).decapsulateCode(CODE_WS))\n }\n\n // WSS\n return mafmt.WebSocketsSecure.matches(testMa) &&\n mafmt.DNS.matches(testMa.decapsulateCode(CODE_TCP).decapsulateCode(CODE_WSS))\n })\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = debug('libp2p:webrtc-star')\nlog.error = debug('libp2p:webrtc-star:error')\n\nconst { EventEmitter } = require('events')\nconst errcode = require('err-code')\nconst withIs = require('class-is')\n\nconst { AbortError } = require('abortable-iterator')\nconst SimplePeer = require('libp2p-webrtc-peer')\nconst { supportsWebRTCDataChannels: webrtcSupport } = require('ipfs-utils/src/supports')\n\nconst { Multiaddr } = require('multiaddr')\nconst mafmt = require('mafmt')\nconst PeerId = require('peer-id')\n\nconst { CODE_CIRCUIT } = require('./constants')\nconst createListener = require('./listener')\nconst toConnection = require('./socket-to-conn')\nconst { cleanMultiaddr, cleanUrlSIO } = require('./utils')\n\nfunction noop () { }\n\n/**\n * @class WebRTCStar\n */\nclass WebRTCStar {\n /**\n * @class\n * @param {object} options\n * @param {Upgrader} options.upgrader\n */\n constructor (options = {}) {\n if (!options.upgrader) {\n throw new Error('An upgrader must be provided. See https://github.com/libp2p/interface-transport#upgrader.')\n }\n\n this._upgrader = options.upgrader\n\n this.sioOptions = {\n transports: ['websocket'],\n 'force new connection': true\n }\n\n if (options.wrtc) {\n this.wrtc = options.wrtc\n }\n\n // Keep Signalling references\n this.sigReferences = new Map()\n\n // Discovery\n this.discovery = new EventEmitter()\n this.discovery.tag = 'webRTCStar'\n this.discovery._isStarted = false\n this.discovery.start = () => {\n this.discovery._isStarted = true\n }\n this.discovery.stop = () => {\n this.discovery._isStarted = false\n }\n this._peerDiscovered = this._peerDiscovered.bind(this)\n }\n\n /**\n * @async\n * @param {Multiaddr} ma\n * @param {object} options\n * @param {AbortSignal} options.signal - Used to abort dial requests\n * @returns {Connection} An upgraded Connection\n */\n async dial (ma, options = {}) {\n const rawConn = await this._connect(ma, options)\n const maConn = toConnection(rawConn, { remoteAddr: ma, signal: options.signal })\n log('new outbound connection %s', maConn.remoteAddr)\n const conn = await this._upgrader.upgradeOutbound(maConn)\n log('outbound connection %s upgraded', maConn.remoteAddr)\n return conn\n }\n\n /**\n * @private\n * @param {Multiaddr} ma\n * @param {object} options\n * @param {AbortSignal} options.signal - Used to abort dial requests\n * @returns {Promise<SimplePeer>} Resolves a SimplePeer Webrtc channel\n */\n _connect (ma, options = {}) {\n if (options.signal && options.signal.aborted) {\n throw new AbortError()\n }\n\n const spOptions = {\n initiator: true,\n trickle: false,\n ...options.spOptions || {}\n }\n\n // Use custom WebRTC implementation\n if (this.wrtc) { spOptions.wrtc = this.wrtc }\n\n const cOpts = ma.toOptions()\n const intentId = (~~(Math.random() * 1e9)).toString(36) + Date.now()\n\n return new Promise((resolve, reject) => {\n const sio = this.sigReferences.get(cleanUrlSIO(ma))\n\n if (!sio || !sio.listener) {\n return reject(errcode(new Error('unknown signal server to use'), 'ERR_UNKNOWN_SIGNAL_SERVER'))\n }\n\n const sioClient = sio.listener.io\n\n const start = Date.now()\n let connected\n\n log('dialing %s:%s', cOpts.host, cOpts.port)\n const channel = new SimplePeer(spOptions)\n\n const onError = (err) => {\n if (!connected) {\n const msg = `connection error ${cOpts.host}:${cOpts.port}: ${err.message}`\n log.error(msg)\n done(err)\n }\n }\n\n const onTimeout = () => {\n log('connnection timeout %s:%s', cOpts.host, cOpts.port)\n const err = errcode(new Error(`connection timeout after ${Date.now() - start}ms`), 'ERR_CONNECT_TIMEOUT')\n // Note: this will result in onError() being called\n channel.emit('error', err)\n }\n\n const onConnect = () => {\n connected = true\n\n log('connection opened %s:%s', cOpts.host, cOpts.port)\n done(null)\n }\n\n const onAbort = () => {\n log.error('connection aborted %s:%s', cOpts.host, cOpts.port)\n channel.destroy()\n done(new AbortError())\n }\n\n const done = (err) => {\n channel.removeListener('timeout', onTimeout)\n channel.removeListener('connect', onConnect)\n options.signal && options.signal.removeEventListener('abort', onAbort)\n\n err ? reject(err) : resolve(channel)\n }\n\n channel.on('error', onError)\n channel.once('timeout', onTimeout)\n channel.once('connect', onConnect)\n channel.on('close', () => {\n channel.removeListener('error', onError)\n })\n options.signal && options.signal.addEventListener('abort', onAbort)\n\n channel.on('signal', (signal) => {\n sioClient.emit('ss-handshake', {\n intentId: intentId,\n srcMultiaddr: sio.signallingAddr.toString(),\n dstMultiaddr: ma.toString(),\n signal: signal\n })\n })\n\n // NOTE: aegir segfaults if we do .once on the socket.io event emitter and we\n // are clueless as to why.\n sioClient.on('ws-handshake', (offer) => {\n if (offer.intentId === intentId && offer.err) {\n channel.destroy()\n reject(errcode(offer.err instanceof Error ? offer.err : new Error(offer.err), 'ERR_SIGNALLING_FAILED'))\n }\n\n if (offer.intentId !== intentId || !offer.answer || channel.destroyed) {\n return\n }\n\n channel.signal(offer.signal)\n })\n })\n }\n\n /**\n * Creates a WebrtcStar listener. The provided `handler` function will be called\n * anytime a new incoming Connection has been successfully upgraded via\n * `upgrader.upgradeInbound`.\n *\n * @param {object} [options] - simple-peer options for listener\n * @param {function (Connection)} handler\n * @returns {Listener} A WebrtcStar listener\n */\n createListener (options = {}, handler) {\n if (!webrtcSupport && !this.wrtc) {\n throw errcode(new Error('no WebRTC support'), 'ERR_NO_WEBRTC_SUPPORT')\n }\n\n if (typeof options === 'function') {\n handler = options\n options = {}\n }\n\n handler = handler || noop\n\n return createListener({ handler, upgrader: this._upgrader }, this, options)\n }\n\n /**\n * Takes a list of `Multiaddr`s and returns only valid TCP addresses\n *\n * @param {Multiaddr[]} multiaddrs\n * @returns {Multiaddr[]} Valid TCP multiaddrs\n */\n filter (multiaddrs) {\n multiaddrs = Array.isArray(multiaddrs) ? multiaddrs : [multiaddrs]\n\n return multiaddrs.filter((ma) => {\n if (ma.protoCodes().includes(CODE_CIRCUIT)) {\n return false\n }\n\n return mafmt.WebRTCStar.matches(ma)\n })\n }\n\n _peerDiscovered (maStr) {\n if (!this.discovery._isStarted) return\n\n log('Peer Discovered:', maStr)\n maStr = cleanMultiaddr(maStr)\n\n const ma = new Multiaddr(maStr)\n const peerId = PeerId.createFromB58String(ma.getPeerId())\n\n this.discovery.emit('peer', {\n id: peerId,\n multiaddrs: [ma]\n })\n }\n}\n\nmodule.exports = withIs(WebRTCStar, { className: 'WebRTCStar', symbolName: '@libp2p/js-libp2p-webrtc-star/webrtcstar' })\n","/*! simple-peer. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */\nvar debug = require('debug')('simple-peer')\nvar getBrowserRTC = require('get-browser-rtc')\nvar randombytes = require('randombytes')\nvar stream = require('readable-stream')\nvar queueMicrotask = require('queue-microtask') // TODO: remove when Node 10 is not supported\nvar errCode = require('err-code')\n\nvar MAX_BUFFERED_AMOUNT = 64 * 1024\nvar ICECOMPLETE_TIMEOUT = 5 * 1000\nvar CHANNEL_CLOSING_TIMEOUT = 5 * 1000\n\n// HACK: Filter trickle lines when trickle is disabled #354\nfunction filterTrickle (sdp) {\n return sdp.replace(/a=ice-options:trickle\\s\\n/g, '')\n}\n\nfunction warn (message) {\n console.warn(message)\n}\n\n/**\n * WebRTC peer connection. Same API as node core `net.Socket`, plus a few extra methods.\n * Duplex stream.\n * @param {Object} opts\n */\nclass Peer extends stream.Duplex {\n constructor (opts) {\n opts = Object.assign({\n allowHalfOpen: false\n }, opts)\n\n super(opts)\n\n this._id = randombytes(4).toString('hex').slice(0, 7)\n this._debug('new peer %o', opts)\n\n this.channelName = opts.initiator\n ? opts.channelName || randombytes(20).toString('hex')\n : null\n\n this.initiator = opts.initiator || false\n this.channelConfig = opts.channelConfig || Peer.channelConfig\n this.negotiated = this.channelConfig.negotiated\n this.config = Object.assign({}, Peer.config, opts.config)\n this.offerOptions = opts.offerOptions || {}\n this.answerOptions = opts.answerOptions || {}\n this.sdpTransform = opts.sdpTransform || (sdp => sdp)\n this.streams = opts.streams || (opts.stream ? [opts.stream] : []) // support old \"stream\" option\n this.trickle = opts.trickle !== undefined ? opts.trickle : true\n this.allowHalfTrickle = opts.allowHalfTrickle !== undefined ? opts.allowHalfTrickle : false\n this.iceCompleteTimeout = opts.iceCompleteTimeout || ICECOMPLETE_TIMEOUT\n\n this._connected = false\n\n this.remoteAddress = undefined\n this.remoteFamily = undefined\n this.remotePort = undefined\n this.localAddress = undefined\n this.localFamily = undefined\n this.localPort = undefined\n\n this._wrtc = (opts.wrtc && typeof opts.wrtc === 'object')\n ? opts.wrtc\n : getBrowserRTC()\n\n if (!this._wrtc) {\n if (typeof window === 'undefined') {\n throw errCode(new Error('No WebRTC support: Specify `opts.wrtc` option in this environment'), 'ERR_WEBRTC_SUPPORT')\n } else {\n throw errCode(new Error('No WebRTC support: Not a supported browser'), 'ERR_WEBRTC_SUPPORT')\n }\n }\n\n this._pcReady = false\n this._channelReady = false\n this._iceComplete = false // ice candidate trickle done (got null candidate)\n this._iceCompleteTimer = null // send an offer/answer anyway after some timeout\n this._channel = null\n this._pendingCandidates = []\n\n this._isNegotiating = this.negotiated ? false : !this.initiator // is this peer waiting for negotiation to complete?\n this._batchedNegotiation = false // batch synchronous negotiations\n this._queuedNegotiation = false // is there a queued negotiation request?\n this._sendersAwaitingStable = []\n this._senderMap = new Map()\n this._firstStable = true\n this._closingInterval = null\n\n this._remoteTracks = []\n this._remoteStreams = []\n\n this._chunk = null\n this._cb = null\n this._interval = null\n\n try {\n this._pc = new (this._wrtc.RTCPeerConnection)(this.config)\n } catch (err) {\n queueMicrotask(() => this.destroy(errCode(err, 'ERR_PC_CONSTRUCTOR')))\n return\n }\n\n // We prefer feature detection whenever possible, but sometimes that's not\n // possible for certain implementations.\n this._isReactNativeWebrtc = typeof this._pc._peerConnectionId === 'number'\n\n this._pc.oniceconnectionstatechange = () => {\n this._onIceStateChange()\n }\n this._pc.onicegatheringstatechange = () => {\n this._onIceStateChange()\n }\n this._pc.onconnectionstatechange = () => {\n this._onConnectionStateChange()\n }\n this._pc.onsignalingstatechange = () => {\n this._onSignalingStateChange()\n }\n this._pc.onicecandidate = event => {\n this._onIceCandidate(event)\n }\n\n // Other spec events, unused by this implementation:\n // - onconnectionstatechange\n // - onicecandidateerror\n // - onfingerprintfailure\n // - onnegotiationneeded\n\n if (this.initiator || this.negotiated) {\n this._setupData({\n channel: this._pc.createDataChannel(this.channelName, this.channelConfig)\n })\n } else {\n this._pc.ondatachannel = event => {\n this._setupData(event)\n }\n }\n\n if (this.streams) {\n this.streams.forEach(stream => {\n this.addStream(stream)\n })\n }\n this._pc.ontrack = event => {\n this._onTrack(event)\n }\n\n if (this.initiator) {\n this._needsNegotiation()\n }\n\n this._onFinishBound = () => {\n this._onFinish()\n }\n this.once('finish', this._onFinishBound)\n }\n\n get bufferSize () {\n return (this._channel && this._channel.bufferedAmount) || 0\n }\n\n // HACK: it's possible channel.readyState is \"closing\" before peer.destroy() fires\n // https://bugs.chromium.org/p/chromium/issues/detail?id=882743\n get connected () {\n return (this._connected && this._channel.readyState === 'open')\n }\n\n address () {\n return { port: this.localPort, family: this.localFamily, address: this.localAddress }\n }\n\n signal (data) {\n if (this.destroyed) throw errCode(new Error('cannot signal after peer is destroyed'), 'ERR_SIGNALING')\n if (typeof data === 'string') {\n try {\n data = JSON.parse(data)\n } catch (err) {\n data = {}\n }\n }\n this._debug('signal()')\n\n if (data.renegotiate && this.initiator) {\n this._debug('got request to renegotiate')\n this._needsNegotiation()\n }\n if (data.transceiverRequest && this.initiator) {\n this._debug('got request for transceiver')\n this.addTransceiver(data.transceiverRequest.kind, data.transceiverRequest.init)\n }\n if (data.candidate) {\n if (this._pc.remoteDescription && this._pc.remoteDescription.type) {\n this._addIceCandidate(data.candidate)\n } else {\n this._pendingCandidates.push(data.candidate)\n }\n }\n if (data.sdp) {\n this._pc.setRemoteDescription(new (this._wrtc.RTCSessionDescription)(data))\n .then(() => {\n if (this.destroyed) return\n\n this._pendingCandidates.forEach(candidate => {\n this._addIceCandidate(candidate)\n })\n this._pendingCandidates = []\n\n if (this._pc.remoteDescription.type === 'offer') this._createAnswer()\n })\n .catch(err => {\n this.destroy(errCode(err, 'ERR_SET_REMOTE_DESCRIPTION'))\n })\n }\n if (!data.sdp && !data.candidate && !data.renegotiate && !data.transceiverRequest) {\n this.destroy(errCode(new Error('signal() called with invalid signal data'), 'ERR_SIGNALING'))\n }\n }\n\n _addIceCandidate (candidate) {\n var iceCandidateObj = new this._wrtc.RTCIceCandidate(candidate)\n this._pc.addIceCandidate(iceCandidateObj)\n .catch(err => {\n if (!iceCandidateObj.address || iceCandidateObj.address.endsWith('.local')) {\n warn('Ignoring unsupported ICE candidate.')\n } else {\n this.destroy(errCode(err, 'ERR_ADD_ICE_CANDIDATE'))\n }\n })\n }\n\n /**\n * Send text/binary data to the remote peer.\n * @param {ArrayBufferView|ArrayBuffer|Buffer|string|Blob} chunk\n */\n send (chunk) {\n this._channel.send(chunk)\n }\n\n /**\n * Add a Transceiver to the connection.\n * @param {String} kind\n * @param {Object} init\n */\n addTransceiver (kind, init) {\n this._debug('addTransceiver()')\n\n if (this.initiator) {\n try {\n this._pc.addTransceiver(kind, init)\n this._needsNegotiation()\n } catch (err) {\n this.destroy(errCode(err, 'ERR_ADD_TRANSCEIVER'))\n }\n } else {\n this.emit('signal', { // request initiator to renegotiate\n transceiverRequest: { kind, init }\n })\n }\n }\n\n /**\n * Add a MediaStream to the connection.\n * @param {MediaStream} stream\n */\n addStream (stream) {\n this._debug('addStream()')\n\n stream.getTracks().forEach(track => {\n this.addTrack(track, stream)\n })\n }\n\n /**\n * Add a MediaStreamTrack to the connection.\n * @param {MediaStreamTrack} track\n * @param {MediaStream} stream\n */\n addTrack (track, stream) {\n this._debug('addTrack()')\n\n var submap = this._senderMap.get(track) || new Map() // nested Maps map [track, stream] to sender\n var sender = submap.get(stream)\n if (!sender) {\n sender = this._pc.addTrack(track, stream)\n submap.set(stream, sender)\n this._senderMap.set(track, submap)\n this._needsNegotiation()\n } else if (sender.removed) {\n throw errCode(new Error('Track has been removed. You should enable/disable tracks that you want to re-add.'), 'ERR_SENDER_REMOVED')\n } else {\n throw errCode(new Error('Track has already been added to that stream.'), 'ERR_SENDER_ALREADY_ADDED')\n }\n }\n\n /**\n * Replace a MediaStreamTrack by another in the connection.\n * @param {MediaStreamTrack} oldTrack\n * @param {MediaStreamTrack} newTrack\n * @param {MediaStream} stream\n */\n replaceTrack (oldTrack, newTrack, stream) {\n this._debug('replaceTrack()')\n\n var submap = this._senderMap.get(oldTrack)\n var sender = submap ? submap.get(stream) : null\n if (!sender) {\n throw errCode(new Error('Cannot replace track that was never added.'), 'ERR_TRACK_NOT_ADDED')\n }\n if (newTrack) this._senderMap.set(newTrack, submap)\n\n if (sender.replaceTrack != null) {\n sender.replaceTrack(newTrack)\n } else {\n this.destroy(errCode(new Error('replaceTrack is not supported in this browser'), 'ERR_UNSUPPORTED_REPLACETRACK'))\n }\n }\n\n /**\n * Remove a MediaStreamTrack from the connection.\n * @param {MediaStreamTrack} track\n * @param {MediaStream} stream\n */\n removeTrack (track, stream) {\n this._debug('removeSender()')\n\n var submap = this._senderMap.get(track)\n var sender = submap ? submap.get(stream) : null\n if (!sender) {\n throw errCode(new Error('Cannot remove track that was never added.'), 'ERR_TRACK_NOT_ADDED')\n }\n try {\n sender.removed = true\n this._pc.removeTrack(sender)\n } catch (err) {\n if (err.name === 'NS_ERROR_UNEXPECTED') {\n this._sendersAwaitingStable.push(sender) // HACK: Firefox must wait until (signalingState === stable) https://bugzilla.mozilla.org/show_bug.cgi?id=1133874\n } else {\n this.destroy(errCode(err, 'ERR_REMOVE_TRACK'))\n }\n }\n this._needsNegotiation()\n }\n\n /**\n * Remove a MediaStream from the connection.\n * @param {MediaStream} stream\n */\n removeStream (stream) {\n this._debug('removeSenders()')\n\n stream.getTracks().forEach(track => {\n this.removeTrack(track, stream)\n })\n }\n\n _needsNegotiation () {\n this._debug('_needsNegotiation')\n if (this._batchedNegotiation) return // batch synchronous renegotiations\n this._batchedNegotiation = true\n queueMicrotask(() => {\n this._batchedNegotiation = false\n this._debug('starting batched negotiation')\n this.negotiate()\n })\n }\n\n negotiate () {\n if (this.initiator) {\n if (this._isNegotiating) {\n this._queuedNegotiation = true\n this._debug('already negotiating, queueing')\n } else {\n this._debug('start negotiation')\n setTimeout(() => { // HACK: Chrome crashes if we immediately call createOffer\n this._createOffer()\n }, 0)\n }\n } else {\n if (this._isNegotiating) {\n this._queuedNegotiation = true\n this._debug('already negotiating, queueing')\n } else {\n this._debug('requesting negotiation from initiator')\n this.emit('signal', { // request initiator to renegotiate\n renegotiate: true\n })\n }\n }\n this._isNegotiating = true\n }\n\n _destroy (err, cb) {\n this._debug('destroy (error: %s)', err && (err.message || err))\n\n this.readable = this.writable = false\n\n if (!this._readableState.ended) this.push(null)\n if (!this._writableState.finished) this.end()\n\n this._connected = false\n this._pcReady = false\n this._channelReady = false\n this._remoteTracks = null\n this._remoteStreams = null\n this._senderMap = null\n\n clearInterval(this._closingInterval)\n this._closingInterval = null\n\n clearInterval(this._interval)\n this._interval = null\n this._chunk = null\n this._cb = null\n\n if (this._onFinishBound) this.removeListener('finish', this._onFinishBound)\n this._onFinishBound = null\n\n if (this._channel) {\n try {\n this._channel.close()\n } catch (err) {}\n\n this._channel.onmessage = null\n this._channel.onopen = null\n this._channel.onclose = null\n this._channel.onerror = null\n }\n if (this._pc) {\n try {\n this._pc.close()\n } catch (err) {}\n\n this._pc.oniceconnectionstatechange = null\n this._pc.onicegatheringstatechange = null\n this._pc.onsignalingstatechange = null\n this._pc.onicecandidate = null\n this._pc.ontrack = null\n this._pc.ondatachannel = null\n }\n this._pc = null\n this._channel = null\n\n cb(err)\n }\n\n _setupData (event) {\n if (!event.channel) {\n // In some situations `pc.createDataChannel()` returns `undefined` (in wrtc),\n // which is invalid behavior. Handle it gracefully.\n // See: https://github.com/feross/simple-peer/issues/163\n return this.destroy(errCode(new Error('Data channel event is missing `channel` property'), 'ERR_DATA_CHANNEL'))\n }\n\n this._channel = event.channel\n this._channel.binaryType = 'arraybuffer'\n\n if (typeof this._channel.bufferedAmountLowThreshold === 'number') {\n this._channel.bufferedAmountLowThreshold = MAX_BUFFERED_AMOUNT\n }\n\n this.channelName = this._channel.label\n\n this._channel.onmessage = event => {\n this._onChannelMessage(event)\n }\n this._channel.onbufferedamountlow = () => {\n this._onChannelBufferedAmountLow()\n }\n this._channel.onopen = () => {\n this._onChannelOpen()\n }\n this._channel.onclose = () => {\n this._onChannelClose()\n }\n this._channel.onerror = err => {\n this.destroy(errCode(err, 'ERR_DATA_CHANNEL'))\n }\n\n // HACK: Chrome will sometimes get stuck in readyState \"closing\", let's check for this condition\n // https://bugs.chromium.org/p/chromium/issues/detail?id=882743\n var isClosing = false\n this._closingInterval = setInterval(() => { // No \"onclosing\" event\n if (this._channel && this._channel.readyState === 'closing') {\n if (isClosing) this._onChannelClose() // closing timed out: equivalent to onclose firing\n isClosing = true\n } else {\n isClosing = false\n }\n }, CHANNEL_CLOSING_TIMEOUT)\n }\n\n _read () {}\n\n _write (chunk, encoding, cb) {\n if (this.destroyed) return cb(errCode(new Error('cannot write after peer is destroyed'), 'ERR_DATA_CHANNEL'))\n\n if (this._connected) {\n try {\n this.send(chunk)\n } catch (err) {\n return this.destroy(errCode(err, 'ERR_DATA_CHANNEL'))\n }\n if (this._channel.bufferedAmount > MAX_BUFFERED_AMOUNT) {\n this._debug('start backpressure: bufferedAmount %d', this._channel.bufferedAmount)\n this._cb = cb\n } else {\n cb(null)\n }\n } else {\n this._debug('write before connect')\n this._chunk = chunk\n this._cb = cb\n }\n }\n\n // When stream finishes writing, close socket. Half open connections are not\n // supported.\n _onFinish () {\n if (this.destroyed) return\n\n // Wait a bit before destroying so the socket flushes.\n // TODO: is there a more reliable way to accomplish this?\n const destroySoon = () => {\n setTimeout(() => this.destroy(), 1000)\n }\n\n if (this._connected) {\n destroySoon()\n } else {\n this.once('connect', destroySoon)\n }\n }\n\n _startIceCompleteTimeout () {\n if (this.destroyed) return\n if (this._iceCompleteTimer) return\n this._debug('started iceComplete timeout')\n this._iceCompleteTimer = setTimeout(() => {\n if (!this._iceComplete) {\n this._iceComplete = true\n this._debug('iceComplete timeout completed')\n this.emit('iceTimeout')\n this.emit('_iceComplete')\n }\n }, this.iceCompleteTimeout)\n }\n\n _createOffer () {\n if (this.destroyed) return\n\n this._pc.createOffer(this.offerOptions)\n .then(offer => {\n if (this.destroyed) return\n if (!this.trickle && !this.allowHalfTrickle) offer.sdp = filterTrickle(offer.sdp)\n offer.sdp = this.sdpTransform(offer.sdp)\n\n const sendOffer = () => {\n if (this.destroyed) return\n var signal = this._pc.localDescription || offer\n this._debug('signal')\n this.emit('signal', {\n type: signal.type,\n sdp: signal.sdp\n })\n }\n\n const onSuccess = () => {\n this._debug('createOffer success')\n if (this.destroyed) return\n if (this.trickle || this._iceComplete) sendOffer()\n else this.once('_iceComplete', sendOffer) // wait for candidates\n }\n\n const onError = err => {\n this.destroy(errCode(err, 'ERR_SET_LOCAL_DESCRIPTION'))\n }\n\n this._pc.setLocalDescription(offer)\n .then(onSuccess)\n .catch(onError)\n })\n .catch(err => {\n this.destroy(errCode(err, 'ERR_CREATE_OFFER'))\n })\n }\n\n _requestMissingTransceivers () {\n if (this._pc.getTransceivers) {\n this._pc.getTransceivers().forEach(transceiver => {\n if (!transceiver.mid && transceiver.sender.track && !transceiver.requested) {\n transceiver.requested = true // HACK: Safari returns negotiated transceivers with a null mid\n this.addTransceiver(transceiver.sender.track.kind)\n }\n })\n }\n }\n\n _createAnswer () {\n if (this.destroyed) return\n\n this._pc.createAnswer(this.answerOptions)\n .then(answer => {\n if (this.destroyed) return\n if (!this.trickle && !this.allowHalfTrickle) answer.sdp = filterTrickle(answer.sdp)\n answer.sdp = this.sdpTransform(answer.sdp)\n\n const sendAnswer = () => {\n if (this.destroyed) return\n var signal = this._pc.localDescription || answer\n this._debug('signal')\n this.emit('signal', {\n type: signal.type,\n sdp: signal.sdp\n })\n if (!this.initiator) this._requestMissingTransceivers()\n }\n\n const onSuccess = () => {\n if (this.destroyed) return\n if (this.trickle || this._iceComplete) sendAnswer()\n else this.once('_iceComplete', sendAnswer)\n }\n\n const onError = err => {\n this.destroy(errCode(err, 'ERR_SET_LOCAL_DESCRIPTION'))\n }\n\n this._pc.setLocalDescription(answer)\n .then(onSuccess)\n .catch(onError)\n })\n .catch(err => {\n this.destroy(errCode(err, 'ERR_CREATE_ANSWER'))\n })\n }\n\n _onConnectionStateChange () {\n if (this.destroyed) return\n if (this._pc.connectionState === 'failed') {\n this.destroy(errCode(new Error('Connection failed.'), 'ERR_CONNECTION_FAILURE'))\n }\n }\n\n _onIceStateChange () {\n if (this.destroyed) return\n var iceConnectionState = this._pc.iceConnectionState\n var iceGatheringState = this._pc.iceGatheringState\n\n this._debug(\n 'iceStateChange (connection: %s) (gathering: %s)',\n iceConnectionState,\n iceGatheringState\n )\n this.emit('iceStateChange', iceConnectionState, iceGatheringState)\n\n if (iceConnectionState === 'connected' || iceConnectionState === 'completed') {\n this._pcReady = true\n this._maybeReady()\n }\n if (iceConnectionState === 'failed') {\n this.destroy(errCode(new Error('Ice connection failed.'), 'ERR_ICE_CONNECTION_FAILURE'))\n }\n if (iceConnectionState === 'closed') {\n this.destroy(errCode(new Error('Ice connection closed.'), 'ERR_ICE_CONNECTION_CLOSED'))\n }\n }\n\n getStats (cb) {\n // statreports can come with a value array instead of properties\n const flattenValues = report => {\n if (Object.prototype.toString.call(report.values) === '[object Array]') {\n report.values.forEach(value => {\n Object.assign(report, value)\n })\n }\n return report\n }\n\n // Promise-based getStats() (standard)\n if (this._pc.getStats.length === 0 || this._isReactNativeWebrtc) {\n this._pc.getStats()\n .then(res => {\n var reports = []\n res.forEach(report => {\n reports.push(flattenValues(report))\n })\n cb(null, reports)\n }, err => cb(err))\n\n // Single-parameter callback-based getStats() (non-standard)\n } else if (this._pc.getStats.length > 0) {\n this._pc.getStats(res => {\n // If we destroy connection in `connect` callback this code might happen to run when actual connection is already closed\n if (this.destroyed) return\n\n var reports = []\n res.result().forEach(result => {\n var report = {}\n result.names().forEach(name => {\n report[name] = result.stat(name)\n })\n report.id = result.id\n report.type = result.type\n report.timestamp = result.timestamp\n reports.push(flattenValues(report))\n })\n cb(null, reports)\n }, err => cb(err))\n\n // Unknown browser, skip getStats() since it's anyone's guess which style of\n // getStats() they implement.\n } else {\n cb(null, [])\n }\n }\n\n _maybeReady () {\n this._debug('maybeReady pc %s channel %s', this._pcReady, this._channelReady)\n if (this._connected || this._connecting || !this._pcReady || !this._channelReady) return\n\n this._connecting = true\n\n // HACK: We can't rely on order here, for details see https://github.com/js-platform/node-webrtc/issues/339\n const findCandidatePair = () => {\n if (this.destroyed) return\n\n this.getStats((err, items) => {\n if (this.destroyed) return\n\n // Treat getStats error as non-fatal. It's not essential.\n if (err) items = []\n\n var remoteCandidates = {}\n var localCandidates = {}\n var candidatePairs = {}\n var foundSelectedCandidatePair = false\n\n items.forEach(item => {\n // TODO: Once all browsers support the hyphenated stats report types, remove\n // the non-hypenated ones\n if (item.type === 'remotecandidate' || item.type === 'remote-candidate') {\n remoteCandidates[item.id] = item\n }\n if (item.type === 'localcandidate' || item.type === 'local-candidate') {\n localCandidates[item.id] = item\n }\n if (item.type === 'candidatepair' || item.type === 'candidate-pair') {\n candidatePairs[item.id] = item\n }\n })\n\n const setSelectedCandidatePair = selectedCandidatePair => {\n foundSelectedCandidatePair = true\n\n var local = localCandidates[selectedCandidatePair.localCandidateId]\n\n if (local && (local.ip || local.address)) {\n // Spec\n this.localAddress = local.ip || local.address\n this.localPort = Number(local.port)\n } else if (local && local.ipAddress) {\n // Firefox\n this.localAddress = local.ipAddress\n this.localPort = Number(local.portNumber)\n } else if (typeof selectedCandidatePair.googLocalAddress === 'string') {\n // TODO: remove this once Chrome 58 is released\n local = selectedCandidatePair.googLocalAddress.split(':')\n this.localAddress = local[0]\n this.localPort = Number(local[1])\n }\n if (this.localAddress) {\n this.localFamily = this.localAddress.includes(':') ? 'IPv6' : 'IPv4'\n }\n\n var remote = remoteCandidates[selectedCandidatePair.remoteCandidateId]\n\n if (remote && (remote.ip || remote.address)) {\n // Spec\n this.remoteAddress = remote.ip || remote.address\n this.remotePort = Number(remote.port)\n } else if (remote && remote.ipAddress) {\n // Firefox\n this.remoteAddress = remote.ipAddress\n this.remotePort = Number(remote.portNumber)\n } else if (typeof selectedCandidatePair.googRemoteAddress === 'string') {\n // TODO: remove this once Chrome 58 is released\n remote = selectedCandidatePair.googRemoteAddress.split(':')\n this.remoteAddress = remote[0]\n this.remotePort = Number(remote[1])\n }\n if (this.remoteAddress) {\n this.remoteFamily = this.remoteAddress.includes(':') ? 'IPv6' : 'IPv4'\n }\n\n this._debug(\n 'connect local: %s:%s remote: %s:%s',\n this.localAddress, this.localPort, this.remoteAddress, this.remotePort\n )\n }\n\n items.forEach(item => {\n // Spec-compliant\n if (item.type === 'transport' && item.selectedCandidatePairId) {\n setSelectedCandidatePair(candidatePairs[item.selectedCandidatePairId])\n }\n\n // Old implementations\n if (\n (item.type === 'googCandidatePair' && item.googActiveConnection === 'true') ||\n ((item.type === 'candidatepair' || item.type === 'candidate-pair') && item.selected)\n ) {\n setSelectedCandidatePair(item)\n }\n })\n\n // Ignore candidate pair selection in browsers like Safari 11 that do not have any local or remote candidates\n // But wait until at least 1 candidate pair is available\n if (!foundSelectedCandidatePair && (!Object.keys(candidatePairs).length || Object.keys(localCandidates).length)) {\n setTimeout(findCandidatePair, 100)\n return\n } else {\n this._connecting = false\n this._connected = true\n }\n\n if (this._chunk) {\n try {\n this.send(this._chunk)\n } catch (err) {\n return this.destroy(errCode(err, 'ERR_DATA_CHANNEL'))\n }\n this._chunk = null\n this._debug('sent chunk from \"write before connect\"')\n\n var cb = this._cb\n this._cb = null\n cb(null)\n }\n\n // If `bufferedAmountLowThreshold` and 'onbufferedamountlow' are unsupported,\n // fallback to using setInterval to implement backpressure.\n if (typeof this._channel.bufferedAmountLowThreshold !== 'number') {\n this._interval = setInterval(() => this._onInterval(), 150)\n if (this._interval.unref) this._interval.unref()\n }\n\n this._debug('connect')\n this.emit('connect')\n })\n }\n findCandidatePair()\n }\n\n _onInterval () {\n if (!this._cb || !this._channel || this._channel.bufferedAmount > MAX_BUFFERED_AMOUNT) {\n return\n }\n this._onChannelBufferedAmountLow()\n }\n\n _onSignalingStateChange () {\n if (this.destroyed) return\n\n if (this._pc.signalingState === 'stable' && !this._firstStable) {\n this._isNegotiating = false\n\n // HACK: Firefox doesn't yet support removing tracks when signalingState !== 'stable'\n this._debug('flushing sender queue', this._sendersAwaitingStable)\n this._sendersAwaitingStable.forEach(sender => {\n this._pc.removeTrack(sender)\n this._queuedNegotiation = true\n })\n this._sendersAwaitingStable = []\n\n if (this._queuedNegotiation) {\n this._debug('flushing negotiation queue')\n this._queuedNegotiation = false\n this._needsNegotiation() // negotiate again\n }\n\n this._debug('negotiate')\n this.emit('negotiate')\n }\n this._firstStable = false\n\n this._debug('signalingStateChange %s', this._pc.signalingState)\n this.emit('signalingStateChange', this._pc.signalingState)\n }\n\n _onIceCandidate (event) {\n if (this.destroyed) return\n if (event.candidate && this.trickle) {\n this.emit('signal', {\n candidate: {\n candidate: event.candidate.candidate,\n sdpMLineIndex: event.candidate.sdpMLineIndex,\n sdpMid: event.candidate.sdpMid\n }\n })\n } else if (!event.candidate && !this._iceComplete) {\n this._iceComplete = true\n this.emit('_iceComplete')\n }\n // as soon as we've received one valid candidate start timeout\n if (event.candidate) {\n this._startIceCompleteTimeout()\n }\n }\n\n _onChannelMessage (event) {\n if (this.destroyed) return\n var data = event.data\n if (data instanceof ArrayBuffer) data = new Uint8Array(data)\n this.push(data)\n }\n\n _onChannelBufferedAmountLow () {\n if (this.destroyed || !this._cb) return\n this._debug('ending backpressure: bufferedAmount %d', this._channel.bufferedAmount)\n var cb = this._cb\n this._cb = null\n cb(null)\n }\n\n _onChannelOpen () {\n if (this._connected || this.destroyed) return\n this._debug('on channel open')\n this._channelReady = true\n this._maybeReady()\n }\n\n _onChannelClose () {\n if (this.destroyed) return\n this._debug('on channel close')\n this.destroy()\n }\n\n _onTrack (event) {\n if (this.destroyed) return\n\n event.streams.forEach(eventStream => {\n this._debug('on track')\n this.emit('track', event.track, eventStream)\n\n this._remoteTracks.push({\n track: event.track,\n stream: eventStream\n })\n\n if (this._remoteStreams.some(remoteStream => {\n return remoteStream.id === eventStream.id\n })) return // Only fire one 'stream' event, even though there may be multiple tracks per stream\n\n this._remoteStreams.push(eventStream)\n queueMicrotask(() => {\n this.emit('stream', eventStream) // ensure all tracks have been added\n })\n })\n }\n\n _debug () {\n var args = [].slice.call(arguments)\n args[0] = '[' + this._id + '] ' + args[0]\n debug.apply(null, args)\n }\n}\n\nPeer.WEBRTC_SUPPORT = !!getBrowserRTC()\n\n/**\n * Expose peer and data channel config for overriding all Peer\n * instances. Otherwise, just set opts.config or opts.channelConfig\n * when constructing a Peer.\n */\nPeer.config = {\n iceServers: [\n {\n urls: [\n 'stun:stun.l.google.com:19302',\n 'stun:global.stun.twilio.com:3478'\n ]\n }\n ],\n sdpSemantics: 'unified-plan'\n}\n\nPeer.channelConfig = {}\n\nmodule.exports = Peer\n","// originally pulled out of simple-peer\n\nmodule.exports = function getBrowserRTC () {\n if (typeof globalThis === 'undefined') return null\n var wrtc = {\n RTCPeerConnection: globalThis.RTCPeerConnection || globalThis.mozRTCPeerConnection ||\n globalThis.webkitRTCPeerConnection,\n RTCSessionDescription: globalThis.RTCSessionDescription ||\n globalThis.mozRTCSessionDescription || globalThis.webkitRTCSessionDescription,\n RTCIceCandidate: globalThis.RTCIceCandidate || globalThis.mozRTCIceCandidate ||\n globalThis.webkitRTCIceCandidate\n }\n if (!wrtc.RTCPeerConnection) return null\n return wrtc\n}\n","'use strict'\n\n// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nvar MAX_BYTES = 65536\n\n// Node supports requesting up to this number of bytes\n// https://github.com/nodejs/node/blob/master/lib/internal/crypto/random.js#L48\nvar MAX_UINT32 = 4294967295\n\nfunction oldBrowser () {\n throw new Error('Secure random number generation is not supported by this browser.\\nUse Chrome, Firefox or Internet Explorer 11')\n}\n\nvar Buffer = require('safe-buffer').Buffer\nvar crypto = global.crypto || global.msCrypto\n\nif (crypto && crypto.getRandomValues) {\n module.exports = randomBytes\n} else {\n module.exports = oldBrowser\n}\n\nfunction randomBytes (size, cb) {\n // phantomjs needs to throw\n if (size > MAX_UINT32) throw new RangeError('requested too many random bytes')\n\n var bytes = Buffer.allocUnsafe(size)\n\n if (size > 0) { // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) { // this is the max bytes crypto.getRandomValues\n // can do at once see https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues\n for (var generated = 0; generated < size; generated += MAX_BYTES) {\n // buffer.slice automatically checks if the end is past the end of\n // the buffer so we don't have to here\n crypto.getRandomValues(bytes.slice(generated, generated + MAX_BYTES))\n }\n } else {\n crypto.getRandomValues(bytes)\n }\n }\n\n if (typeof cb === 'function') {\n return process.nextTick(function () {\n cb(null, bytes)\n })\n }\n\n return bytes\n}\n","/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","'use strict';\n\nfunction assign(obj, props) {\n for (const key in props) {\n Object.defineProperty(obj, key, {\n value: props[key],\n enumerable: true,\n configurable: true,\n });\n }\n\n return obj;\n}\n\nfunction createError(err, code, props) {\n if (!err || typeof err === 'string') {\n throw new TypeError('Please pass an Error to err-code');\n }\n\n if (!props) {\n props = {};\n }\n\n if (typeof code === 'object') {\n props = code;\n code = undefined;\n }\n\n if (code != null) {\n props.code = code;\n }\n\n try {\n return assign(err, props);\n } catch (_) {\n props.message = err.message;\n props.stack = err.stack;\n\n const ErrClass = function () {};\n\n ErrClass.prototype = Object.create(Object.getPrototypeOf(err));\n\n return assign(new ErrClass(), props);\n }\n}\n\nmodule.exports = createError;\n","'use strict'\n\nmodule.exports = {\n // in React Native: global === window === self\n supportsFileReader: typeof self !== 'undefined' && 'FileReader' in self,\n supportsWebRTC: 'RTCPeerConnection' in globalThis &&\n (typeof navigator !== 'undefined' && typeof navigator.mediaDevices !== 'undefined' && 'getUserMedia' in navigator.mediaDevices),\n supportsWebRTCDataChannels: 'RTCPeerConnection' in globalThis\n}\n","'use strict'\n\n// p2p multi-address code\nexports.CODE_P2P = 421\nexports.CODE_CIRCUIT = 290\n\n// Time to wait for a connection to close gracefully before destroying it manually\nexports.CLOSE_TIMEOUT = 2000\n","'use strict'\n\nconst EventEmitter = require('events')\nconst debug = require('debug')\nconst log = debug('libp2p:webrtc-star:listener')\nlog.error = debug('libp2p:webrtc-star:listener:error')\n\nconst errCode = require('err-code')\nconst io = require('socket.io-client')\nconst SimplePeer = require('libp2p-webrtc-peer')\nconst pDefer = require('p-defer')\n\nconst toConnection = require('./socket-to-conn')\nconst { cleanUrlSIO } = require('./utils')\nconst { CODE_P2P } = require('./constants')\n\nconst sioOptions = {\n transports: ['websocket'],\n 'force new connection': true,\n path: '/socket.io-next/' // This should be removed when socket.io@2 support is removed\n}\n\nmodule.exports = ({ handler, upgrader }, WebRTCStar, options = {}) => {\n const listener = new EventEmitter()\n let listeningAddr\n let signallingUrl\n\n listener.__connections = []\n listener.__spChannels = new Map()\n listener.__pendingIntents = new Map()\n listener.listen = (ma) => {\n // Should only be used if not already listening\n if (listeningAddr) {\n throw errCode(new Error('listener already in use'), 'ERR_ALREADY_LISTENING')\n }\n\n const defer = pDefer()\n\n // Should be kept unmodified\n listeningAddr = ma\n\n let signallingAddr\n if (!ma.protoCodes().includes(CODE_P2P) && upgrader.localPeer) {\n signallingAddr = ma.encapsulate(`/p2p/${upgrader.localPeer.toB58String()}`)\n } else {\n signallingAddr = ma\n }\n\n listener.on('error', () => defer.reject())\n\n signallingUrl = cleanUrlSIO(ma)\n\n log('Dialing to Signalling Server on: ' + signallingUrl)\n listener.io = io.connect(signallingUrl, sioOptions)\n\n const incomingDial = (offer) => {\n if (offer.answer || offer.err || !offer.intentId) {\n return\n }\n\n const intentId = offer.intentId\n let pendings = listener.__pendingIntents.get(intentId)\n if (!pendings) {\n pendings = []\n listener.__pendingIntents.set(intentId, pendings)\n }\n\n let channel = listener.__spChannels.get(intentId)\n if (channel) {\n channel.signal(offer.signal)\n return\n } else if (offer.signal.type !== 'offer') {\n pendings.push(offer)\n return\n }\n\n const spOptions = {\n trickle: false,\n ...options\n }\n\n // Use custom WebRTC implementation\n if (WebRTCStar.wrtc) { spOptions.wrtc = WebRTCStar.wrtc }\n\n channel = new SimplePeer(spOptions)\n\n const onError = (err) => {\n log.error('incoming connection errored', err)\n }\n\n channel.on('error', onError)\n channel.once('close', (...args) => {\n channel.removeListener('error', onError)\n })\n\n channel.on('signal', (signal) => {\n offer.signal = signal\n offer.answer = true\n listener.io.emit('ss-handshake', offer)\n })\n\n channel.signal(offer.signal)\n for (const pendingOffer of pendings) {\n channel.signal(pendingOffer.signal)\n }\n listener.__pendingIntents.set(intentId, [])\n\n channel.once('connect', async () => {\n const maConn = toConnection(channel)\n log('new inbound connection %s', maConn.remoteAddr)\n\n let conn\n try {\n conn = await upgrader.upgradeInbound(maConn)\n } catch (err) {\n log.error('inbound connection failed to upgrade', err)\n return maConn.close()\n }\n\n if (!conn.remoteAddr) {\n try {\n conn.remoteAddr = ma.decapsulateCode(CODE_P2P).encapsulate(`/p2p/${conn.remotePeer.toB58String()}`)\n } catch (err) {\n log.error('could not determine remote address', err)\n }\n }\n\n log('inbound connection %s upgraded', maConn.remoteAddr)\n\n trackConn(listener, maConn, intentId)\n\n listener.emit('connection', conn)\n handler(conn)\n })\n listener.__spChannels.set(intentId, channel)\n }\n\n listener.io.once('connect_error', (err) => defer.reject(err))\n listener.io.once('error', (err) => {\n listener.emit('error', err)\n listener.emit('close')\n })\n\n listener.io.on('ws-handshake', incomingDial)\n listener.io.on('ws-peer', WebRTCStar._peerDiscovered)\n\n listener.io.on('connect', () => {\n listener.io.emit('ss-join', signallingAddr.toString())\n })\n\n listener.io.once('connect', () => {\n listener.emit('listening')\n defer.resolve()\n })\n\n // Store listen and signal reference addresses\n WebRTCStar.sigReferences.set(signallingUrl, {\n listener,\n signallingAddr\n })\n\n return defer.promise\n }\n\n listener.close = async () => {\n // Close listener\n const ref = WebRTCStar.sigReferences.get(signallingUrl)\n if (ref && ref.listener.io) {\n ref.listener.io.emit('ss-leave')\n ref.listener.io.close()\n }\n\n await Promise.all(listener.__connections.map(maConn => maConn.close()))\n listener.emit('close')\n listener.removeAllListeners()\n\n // Reset state\n listeningAddr = undefined\n WebRTCStar.sigReferences.delete(signallingUrl)\n }\n\n listener.getAddrs = () => {\n return [listeningAddr]\n }\n\n return listener\n}\n\nfunction trackConn (listener, maConn, intentId) {\n listener.__connections.push(maConn)\n\n const untrackConn = () => {\n listener.__connections = listener.__connections.filter(c => c !== maConn)\n listener.__spChannels.delete(intentId)\n listener.__pendingIntents.delete(intentId)\n }\n\n maConn.conn.once('close', untrackConn)\n}\n","import { url } from \"./url.js\";\nimport { Manager } from \"./manager.js\";\nimport { Socket } from \"./socket.js\";\n/**\n * Managers cache.\n */\nconst cache = {};\nfunction lookup(uri, opts) {\n if (typeof uri === \"object\") {\n opts = uri;\n uri = undefined;\n }\n opts = opts || {};\n const parsed = url(uri, opts.path || \"/socket.io\");\n const source = parsed.source;\n const id = parsed.id;\n const path = parsed.path;\n const sameNamespace = cache[id] && path in cache[id][\"nsps\"];\n const newConnection = opts.forceNew ||\n opts[\"force new connection\"] ||\n false === opts.multiplex ||\n sameNamespace;\n let io;\n if (newConnection) {\n io = new Manager(source, opts);\n }\n else {\n if (!cache[id]) {\n cache[id] = new Manager(source, opts);\n }\n io = cache[id];\n }\n if (parsed.query && !opts.query) {\n opts.query = parsed.queryKey;\n }\n return io.socket(parsed.path, opts);\n}\n// so that \"lookup\" can be used both as a function (e.g. `io(...)`) and as a\n// namespace (e.g. `io.connect(...)`), for backward compatibility\nObject.assign(lookup, {\n Manager,\n Socket,\n io: lookup,\n connect: lookup,\n});\n/**\n * Protocol version.\n *\n * @public\n */\nexport { protocol } from \"socket.io-parser\";\n/**\n * Expose constructors for standalone build.\n *\n * @public\n */\nexport { Manager, Socket, lookup as io, lookup as connect, lookup as default, };\n","import parseuri from \"parseuri\";\n/**\n * URL parser.\n *\n * @param uri - url\n * @param path - the request path of the connection\n * @param loc - An object meant to mimic window.location.\n * Defaults to window.location.\n * @public\n */\nexport function url(uri, path = \"\", loc) {\n let obj = uri;\n // default to window.location\n loc = loc || (typeof location !== \"undefined\" && location);\n if (null == uri)\n uri = loc.protocol + \"//\" + loc.host;\n // relative path support\n if (typeof uri === \"string\") {\n if (\"/\" === uri.charAt(0)) {\n if (\"/\" === uri.charAt(1)) {\n uri = loc.protocol + uri;\n }\n else {\n uri = loc.host + uri;\n }\n }\n if (!/^(https?|wss?):\\/\\//.test(uri)) {\n if (\"undefined\" !== typeof loc) {\n uri = loc.protocol + \"//\" + uri;\n }\n else {\n uri = \"https://\" + uri;\n }\n }\n // parse\n obj = parseuri(uri);\n }\n // make sure we treat `localhost:80` and `localhost` equally\n if (!obj.port) {\n if (/^(http|ws)$/.test(obj.protocol)) {\n obj.port = \"80\";\n }\n else if (/^(http|ws)s$/.test(obj.protocol)) {\n obj.port = \"443\";\n }\n }\n obj.path = obj.path || \"/\";\n const ipv6 = obj.host.indexOf(\":\") !== -1;\n const host = ipv6 ? \"[\" + obj.host + \"]\" : obj.host;\n // define unique id\n obj.id = obj.protocol + \"://\" + host + \":\" + obj.port + path;\n // define href\n obj.href =\n obj.protocol +\n \"://\" +\n host +\n (loc && loc.port === obj.port ? \"\" : \":\" + obj.port);\n return obj;\n}\n","/**\n * Parses an URI\n *\n * @author Steven Levithan <stevenlevithan.com> (MIT license)\n * @api private\n */\n\nvar re = /^(?:(?![^:@]+:[^:@\\/]*@)(http|https|ws|wss):\\/\\/)?((?:(([^:@]*)(?::([^:@]*))?)?@)?((?:[a-f0-9]{0,4}:){2,7}[a-f0-9]{0,4}|[^:\\/?#]*)(?::(\\d*))?)(((\\/(?:[^?#](?![^?#\\/]*\\.[^?#\\/.]+(?:[?#]|$)))*\\/?)?([^?#\\/]*))(?:\\?([^#]*))?(?:#(.*))?)/;\n\nvar parts = [\n 'source', 'protocol', 'authority', 'userInfo', 'user', 'password', 'host', 'port', 'relative', 'path', 'directory', 'file', 'query', 'anchor'\n];\n\nmodule.exports = function parseuri(str) {\n var src = str,\n b = str.indexOf('['),\n e = str.indexOf(']');\n\n if (b != -1 && e != -1) {\n str = str.substring(0, b) + str.substring(b, e).replace(/:/g, ';') + str.substring(e, str.length);\n }\n\n var m = re.exec(str || ''),\n uri = {},\n i = 14;\n\n while (i--) {\n uri[parts[i]] = m[i] || '';\n }\n\n if (b != -1 && e != -1) {\n uri.source = src;\n uri.host = uri.host.substring(1, uri.host.length - 1).replace(/;/g, ':');\n uri.authority = uri.authority.replace('[', '').replace(']', '').replace(/;/g, ':');\n uri.ipv6uri = true;\n }\n\n uri.pathNames = pathNames(uri, uri['path']);\n uri.queryKey = queryKey(uri, uri['query']);\n\n return uri;\n};\n\nfunction pathNames(obj, path) {\n var regx = /\\/{2,9}/g,\n names = path.replace(regx, \"/\").split(\"/\");\n\n if (path.substr(0, 1) == '/' || path.length === 0) {\n names.splice(0, 1);\n }\n if (path.substr(path.length - 1, 1) == '/') {\n names.splice(names.length - 1, 1);\n }\n\n return names;\n}\n\nfunction queryKey(uri, query) {\n var data = {};\n\n query.replace(/(?:^|&)([^&=]*)=?([^&]*)/g, function ($0, $1, $2) {\n if ($1) {\n data[$1] = $2;\n }\n });\n\n return data;\n}\n","import { Socket as Engine, installTimerFunctions, } from \"engine.io-client\";\nimport { Socket } from \"./socket.js\";\nimport * as parser from \"socket.io-parser\";\nimport { on } from \"./on.js\";\nimport Backoff from \"backo2\";\nimport { Emitter, } from \"@socket.io/component-emitter\";\nexport class Manager extends Emitter {\n constructor(uri, opts) {\n var _a;\n super();\n this.nsps = {};\n this.subs = [];\n if (uri && \"object\" === typeof uri) {\n opts = uri;\n uri = undefined;\n }\n opts = opts || {};\n opts.path = opts.path || \"/socket.io\";\n this.opts = opts;\n installTimerFunctions(this, opts);\n this.reconnection(opts.reconnection !== false);\n this.reconnectionAttempts(opts.reconnectionAttempts || Infinity);\n this.reconnectionDelay(opts.reconnectionDelay || 1000);\n this.reconnectionDelayMax(opts.reconnectionDelayMax || 5000);\n this.randomizationFactor((_a = opts.randomizationFactor) !== null && _a !== void 0 ? _a : 0.5);\n this.backoff = new Backoff({\n min: this.reconnectionDelay(),\n max: this.reconnectionDelayMax(),\n jitter: this.randomizationFactor(),\n });\n this.timeout(null == opts.timeout ? 20000 : opts.timeout);\n this._readyState = \"closed\";\n this.uri = uri;\n const _parser = opts.parser || parser;\n this.encoder = new _parser.Encoder();\n this.decoder = new _parser.Decoder();\n this._autoConnect = opts.autoConnect !== false;\n if (this._autoConnect)\n this.open();\n }\n reconnection(v) {\n if (!arguments.length)\n return this._reconnection;\n this._reconnection = !!v;\n return this;\n }\n reconnectionAttempts(v) {\n if (v === undefined)\n return this._reconnectionAttempts;\n this._reconnectionAttempts = v;\n return this;\n }\n reconnectionDelay(v) {\n var _a;\n if (v === undefined)\n return this._reconnectionDelay;\n this._reconnectionDelay = v;\n (_a = this.backoff) === null || _a === void 0 ? void 0 : _a.setMin(v);\n return this;\n }\n randomizationFactor(v) {\n var _a;\n if (v === undefined)\n return this._randomizationFactor;\n this._randomizationFactor = v;\n (_a = this.backoff) === null || _a === void 0 ? void 0 : _a.setJitter(v);\n return this;\n }\n reconnectionDelayMax(v) {\n var _a;\n if (v === undefined)\n return this._reconnectionDelayMax;\n this._reconnectionDelayMax = v;\n (_a = this.backoff) === null || _a === void 0 ? void 0 : _a.setMax(v);\n return this;\n }\n timeout(v) {\n if (!arguments.length)\n return this._timeout;\n this._timeout = v;\n return this;\n }\n /**\n * Starts trying to reconnect if reconnection is enabled and we have not\n * started reconnecting yet\n *\n * @private\n */\n maybeReconnectOnOpen() {\n // Only try to reconnect if it's the first time we're connecting\n if (!this._reconnecting &&\n this._reconnection &&\n this.backoff.attempts === 0) {\n // keeps reconnection from firing twice for the same reconnection loop\n this.reconnect();\n }\n }\n /**\n * Sets the current transport `socket`.\n *\n * @param {Function} fn - optional, callback\n * @return self\n * @public\n */\n open(fn) {\n if (~this._readyState.indexOf(\"open\"))\n return this;\n this.engine = new Engine(this.uri, this.opts);\n const socket = this.engine;\n const self = this;\n this._readyState = \"opening\";\n this.skipReconnect = false;\n // emit `open`\n const openSubDestroy = on(socket, \"open\", function () {\n self.onopen();\n fn && fn();\n });\n // emit `error`\n const errorSub = on(socket, \"error\", (err) => {\n self.cleanup();\n self._readyState = \"closed\";\n this.emitReserved(\"error\", err);\n if (fn) {\n fn(err);\n }\n else {\n // Only do this if there is no fn to handle the error\n self.maybeReconnectOnOpen();\n }\n });\n if (false !== this._timeout) {\n const timeout = this._timeout;\n if (timeout === 0) {\n openSubDestroy(); // prevents a race condition with the 'open' event\n }\n // set timer\n const timer = this.setTimeoutFn(() => {\n openSubDestroy();\n socket.close();\n // @ts-ignore\n socket.emit(\"error\", new Error(\"timeout\"));\n }, timeout);\n if (this.opts.autoUnref) {\n timer.unref();\n }\n this.subs.push(function subDestroy() {\n clearTimeout(timer);\n });\n }\n this.subs.push(openSubDestroy);\n this.subs.push(errorSub);\n return this;\n }\n /**\n * Alias for open()\n *\n * @return self\n * @public\n */\n connect(fn) {\n return this.open(fn);\n }\n /**\n * Called upon transport open.\n *\n * @private\n */\n onopen() {\n // clear old subs\n this.cleanup();\n // mark as open\n this._readyState = \"open\";\n this.emitReserved(\"open\");\n // add new subs\n const socket = this.engine;\n this.subs.push(on(socket, \"ping\", this.onping.bind(this)), on(socket, \"data\", this.ondata.bind(this)), on(socket, \"error\", this.onerror.bind(this)), on(socket, \"close\", this.onclose.bind(this)), on(this.decoder, \"decoded\", this.ondecoded.bind(this)));\n }\n /**\n * Called upon a ping.\n *\n * @private\n */\n onping() {\n this.emitReserved(\"ping\");\n }\n /**\n * Called with data.\n *\n * @private\n */\n ondata(data) {\n this.decoder.add(data);\n }\n /**\n * Called when parser fully decodes a packet.\n *\n * @private\n */\n ondecoded(packet) {\n this.emitReserved(\"packet\", packet);\n }\n /**\n * Called upon socket error.\n *\n * @private\n */\n onerror(err) {\n this.emitReserved(\"error\", err);\n }\n /**\n * Creates a new socket for the given `nsp`.\n *\n * @return {Socket}\n * @public\n */\n socket(nsp, opts) {\n let socket = this.nsps[nsp];\n if (!socket) {\n socket = new Socket(this, nsp, opts);\n this.nsps[nsp] = socket;\n }\n return socket;\n }\n /**\n * Called upon a socket close.\n *\n * @param socket\n * @private\n */\n _destroy(socket) {\n const nsps = Object.keys(this.nsps);\n for (const nsp of nsps) {\n const socket = this.nsps[nsp];\n if (socket.active) {\n return;\n }\n }\n this._close();\n }\n /**\n * Writes a packet.\n *\n * @param packet\n * @private\n */\n _packet(packet) {\n const encodedPackets = this.encoder.encode(packet);\n for (let i = 0; i < encodedPackets.length; i++) {\n this.engine.write(encodedPackets[i], packet.options);\n }\n }\n /**\n * Clean up transport subscriptions and packet buffer.\n *\n * @private\n */\n cleanup() {\n this.subs.forEach((subDestroy) => subDestroy());\n this.subs.length = 0;\n this.decoder.destroy();\n }\n /**\n * Close the current socket.\n *\n * @private\n */\n _close() {\n this.skipReconnect = true;\n this._reconnecting = false;\n this.onclose(\"forced close\");\n if (this.engine)\n this.engine.close();\n }\n /**\n * Alias for close()\n *\n * @private\n */\n disconnect() {\n return this._close();\n }\n /**\n * Called upon engine close.\n *\n * @private\n */\n onclose(reason) {\n this.cleanup();\n this.backoff.reset();\n this._readyState = \"closed\";\n this.emitReserved(\"close\", reason);\n if (this._reconnection && !this.skipReconnect) {\n this.reconnect();\n }\n }\n /**\n * Attempt a reconnection.\n *\n * @private\n */\n reconnect() {\n if (this._reconnecting || this.skipReconnect)\n return this;\n const self = this;\n if (this.backoff.attempts >= this._reconnectionAttempts) {\n this.backoff.reset();\n this.emitReserved(\"reconnect_failed\");\n this._reconnecting = false;\n }\n else {\n const delay = this.backoff.duration();\n this._reconnecting = true;\n const timer = this.setTimeoutFn(() => {\n if (self.skipReconnect)\n return;\n this.emitReserved(\"reconnect_attempt\", self.backoff.attempts);\n // check again for the case socket closed in above events\n if (self.skipReconnect)\n return;\n self.open((err) => {\n if (err) {\n self._reconnecting = false;\n self.reconnect();\n this.emitReserved(\"reconnect_error\", err);\n }\n else {\n self.onreconnect();\n }\n });\n }, delay);\n if (this.opts.autoUnref) {\n timer.unref();\n }\n this.subs.push(function subDestroy() {\n clearTimeout(timer);\n });\n }\n }\n /**\n * Called upon successful reconnect.\n *\n * @private\n */\n onreconnect() {\n const attempt = this.backoff.attempts;\n this._reconnecting = false;\n this.backoff.reset();\n this.emitReserved(\"reconnect\", attempt);\n }\n}\n","import { Socket } from \"./socket.js\";\nexport { Socket };\nexport const protocol = Socket.protocol;\nexport { Transport } from \"./transport.js\";\nexport { transports } from \"./transports/index.js\";\nexport { installTimerFunctions } from \"./util.js\";\n","import { transports } from \"./transports/index.js\";\nimport { installTimerFunctions } from \"./util.js\";\nimport parseqs from \"parseqs\";\nimport parseuri from \"parseuri\";\nimport { Emitter } from \"@socket.io/component-emitter\";\nimport { protocol } from \"engine.io-parser\";\nexport class Socket extends Emitter {\n /**\n * Socket constructor.\n *\n * @param {String|Object} uri or options\n * @param {Object} opts - options\n * @api public\n */\n constructor(uri, opts = {}) {\n super();\n if (uri && \"object\" === typeof uri) {\n opts = uri;\n uri = null;\n }\n if (uri) {\n uri = parseuri(uri);\n opts.hostname = uri.host;\n opts.secure = uri.protocol === \"https\" || uri.protocol === \"wss\";\n opts.port = uri.port;\n if (uri.query)\n opts.query = uri.query;\n }\n else if (opts.host) {\n opts.hostname = parseuri(opts.host).host;\n }\n installTimerFunctions(this, opts);\n this.secure =\n null != opts.secure\n ? opts.secure\n : typeof location !== \"undefined\" && \"https:\" === location.protocol;\n if (opts.hostname && !opts.port) {\n // if no port is specified manually, use the protocol default\n opts.port = this.secure ? \"443\" : \"80\";\n }\n this.hostname =\n opts.hostname ||\n (typeof location !== \"undefined\" ? location.hostname : \"localhost\");\n this.port =\n opts.port ||\n (typeof location !== \"undefined\" && location.port\n ? location.port\n : this.secure\n ? \"443\"\n : \"80\");\n this.transports = opts.transports || [\"polling\", \"websocket\"];\n this.readyState = \"\";\n this.writeBuffer = [];\n this.prevBufferLen = 0;\n this.opts = Object.assign({\n path: \"/engine.io\",\n agent: false,\n withCredentials: false,\n upgrade: true,\n timestampParam: \"t\",\n rememberUpgrade: false,\n rejectUnauthorized: true,\n perMessageDeflate: {\n threshold: 1024\n },\n transportOptions: {},\n closeOnBeforeunload: true\n }, opts);\n this.opts.path = this.opts.path.replace(/\\/$/, \"\") + \"/\";\n if (typeof this.opts.query === \"string\") {\n this.opts.query = parseqs.decode(this.opts.query);\n }\n // set on handshake\n this.id = null;\n this.upgrades = null;\n this.pingInterval = null;\n this.pingTimeout = null;\n // set on heartbeat\n this.pingTimeoutTimer = null;\n if (typeof addEventListener === \"function\") {\n if (this.opts.closeOnBeforeunload) {\n // Firefox closes the connection when the \"beforeunload\" event is emitted but not Chrome. This event listener\n // ensures every browser behaves the same (no \"disconnect\" event at the Socket.IO level when the page is\n // closed/reloaded)\n addEventListener(\"beforeunload\", () => {\n if (this.transport) {\n // silently close the transport\n this.transport.removeAllListeners();\n this.transport.close();\n }\n }, false);\n }\n if (this.hostname !== \"localhost\") {\n this.offlineEventListener = () => {\n this.onClose(\"transport close\");\n };\n addEventListener(\"offline\", this.offlineEventListener, false);\n }\n }\n this.open();\n }\n /**\n * Creates transport of the given type.\n *\n * @param {String} transport name\n * @return {Transport}\n * @api private\n */\n createTransport(name) {\n const query = clone(this.opts.query);\n // append engine.io protocol identifier\n query.EIO = protocol;\n // transport name\n query.transport = name;\n // session id if we already have one\n if (this.id)\n query.sid = this.id;\n const opts = Object.assign({}, this.opts.transportOptions[name], this.opts, {\n query,\n socket: this,\n hostname: this.hostname,\n secure: this.secure,\n port: this.port\n });\n return new transports[name](opts);\n }\n /**\n * Initializes transport to use and starts probe.\n *\n * @api private\n */\n open() {\n let transport;\n if (this.opts.rememberUpgrade &&\n Socket.priorWebsocketSuccess &&\n this.transports.indexOf(\"websocket\") !== -1) {\n transport = \"websocket\";\n }\n else if (0 === this.transports.length) {\n // Emit error on next tick so it can be listened to\n this.setTimeoutFn(() => {\n this.emitReserved(\"error\", \"No transports available\");\n }, 0);\n return;\n }\n else {\n transport = this.transports[0];\n }\n this.readyState = \"opening\";\n // Retry with the next transport if the transport is disabled (jsonp: false)\n try {\n transport = this.createTransport(transport);\n }\n catch (e) {\n this.transports.shift();\n this.open();\n return;\n }\n transport.open();\n this.setTransport(transport);\n }\n /**\n * Sets the current transport. Disables the existing one (if any).\n *\n * @api private\n */\n setTransport(transport) {\n if (this.transport) {\n this.transport.removeAllListeners();\n }\n // set up transport\n this.transport = transport;\n // set up transport listeners\n transport\n .on(\"drain\", this.onDrain.bind(this))\n .on(\"packet\", this.onPacket.bind(this))\n .on(\"error\", this.onError.bind(this))\n .on(\"close\", () => {\n this.onClose(\"transport close\");\n });\n }\n /**\n * Probes a transport.\n *\n * @param {String} transport name\n * @api private\n */\n probe(name) {\n let transport = this.createTransport(name);\n let failed = false;\n Socket.priorWebsocketSuccess = false;\n const onTransportOpen = () => {\n if (failed)\n return;\n transport.send([{ type: \"ping\", data: \"probe\" }]);\n transport.once(\"packet\", msg => {\n if (failed)\n return;\n if (\"pong\" === msg.type && \"probe\" === msg.data) {\n this.upgrading = true;\n this.emitReserved(\"upgrading\", transport);\n if (!transport)\n return;\n Socket.priorWebsocketSuccess = \"websocket\" === transport.name;\n this.transport.pause(() => {\n if (failed)\n return;\n if (\"closed\" === this.readyState)\n return;\n cleanup();\n this.setTransport(transport);\n transport.send([{ type: \"upgrade\" }]);\n this.emitReserved(\"upgrade\", transport);\n transport = null;\n this.upgrading = false;\n this.flush();\n });\n }\n else {\n const err = new Error(\"probe error\");\n // @ts-ignore\n err.transport = transport.name;\n this.emitReserved(\"upgradeError\", err);\n }\n });\n };\n function freezeTransport() {\n if (failed)\n return;\n // Any callback called by transport should be ignored since now\n failed = true;\n cleanup();\n transport.close();\n transport = null;\n }\n // Handle any error that happens while probing\n const onerror = err => {\n const error = new Error(\"probe error: \" + err);\n // @ts-ignore\n error.transport = transport.name;\n freezeTransport();\n this.emitReserved(\"upgradeError\", error);\n };\n function onTransportClose() {\n onerror(\"transport closed\");\n }\n // When the socket is closed while we're probing\n function onclose() {\n onerror(\"socket closed\");\n }\n // When the socket is upgraded while we're probing\n function onupgrade(to) {\n if (transport && to.name !== transport.name) {\n freezeTransport();\n }\n }\n // Remove all listeners on the transport and on self\n const cleanup = () => {\n transport.removeListener(\"open\", onTransportOpen);\n transport.removeListener(\"error\", onerror);\n transport.removeListener(\"close\", onTransportClose);\n this.off(\"close\", onclose);\n this.off(\"upgrading\", onupgrade);\n };\n transport.once(\"open\", onTransportOpen);\n transport.once(\"error\", onerror);\n transport.once(\"close\", onTransportClose);\n this.once(\"close\", onclose);\n this.once(\"upgrading\", onupgrade);\n transport.open();\n }\n /**\n * Called when connection is deemed open.\n *\n * @api private\n */\n onOpen() {\n this.readyState = \"open\";\n Socket.priorWebsocketSuccess = \"websocket\" === this.transport.name;\n this.emitReserved(\"open\");\n this.flush();\n // we check for `readyState` in case an `open`\n // listener already closed the socket\n if (\"open\" === this.readyState &&\n this.opts.upgrade &&\n this.transport.pause) {\n let i = 0;\n const l = this.upgrades.length;\n for (; i < l; i++) {\n this.probe(this.upgrades[i]);\n }\n }\n }\n /**\n * Handles a packet.\n *\n * @api private\n */\n onPacket(packet) {\n if (\"opening\" === this.readyState ||\n \"open\" === this.readyState ||\n \"closing\" === this.readyState) {\n this.emitReserved(\"packet\", packet);\n // Socket is live - any packet counts\n this.emitReserved(\"heartbeat\");\n switch (packet.type) {\n case \"open\":\n this.onHandshake(JSON.parse(packet.data));\n break;\n case \"ping\":\n this.resetPingTimeout();\n this.sendPacket(\"pong\");\n this.emitReserved(\"ping\");\n this.emitReserved(\"pong\");\n break;\n case \"error\":\n const err = new Error(\"server error\");\n // @ts-ignore\n err.code = packet.data;\n this.onError(err);\n break;\n case \"message\":\n this.emitReserved(\"data\", packet.data);\n this.emitReserved(\"message\", packet.data);\n break;\n }\n }\n else {\n }\n }\n /**\n * Called upon handshake completion.\n *\n * @param {Object} data - handshake obj\n * @api private\n */\n onHandshake(data) {\n this.emitReserved(\"handshake\", data);\n this.id = data.sid;\n this.transport.query.sid = data.sid;\n this.upgrades = this.filterUpgrades(data.upgrades);\n this.pingInterval = data.pingInterval;\n this.pingTimeout = data.pingTimeout;\n this.onOpen();\n // In case open handler closes socket\n if (\"closed\" === this.readyState)\n return;\n this.resetPingTimeout();\n }\n /**\n * Sets and resets ping timeout timer based on server pings.\n *\n * @api private\n */\n resetPingTimeout() {\n this.clearTimeoutFn(this.pingTimeoutTimer);\n this.pingTimeoutTimer = this.setTimeoutFn(() => {\n this.onClose(\"ping timeout\");\n }, this.pingInterval + this.pingTimeout);\n if (this.opts.autoUnref) {\n this.pingTimeoutTimer.unref();\n }\n }\n /**\n * Called on `drain` event\n *\n * @api private\n */\n onDrain() {\n this.writeBuffer.splice(0, this.prevBufferLen);\n // setting prevBufferLen = 0 is very important\n // for example, when upgrading, upgrade packet is sent over,\n // and a nonzero prevBufferLen could cause problems on `drain`\n this.prevBufferLen = 0;\n if (0 === this.writeBuffer.length) {\n this.emitReserved(\"drain\");\n }\n else {\n this.flush();\n }\n }\n /**\n * Flush write buffers.\n *\n * @api private\n */\n flush() {\n if (\"closed\" !== this.readyState &&\n this.transport.writable &&\n !this.upgrading &&\n this.writeBuffer.length) {\n this.transport.send(this.writeBuffer);\n // keep track of current length of writeBuffer\n // splice writeBuffer and callbackBuffer on `drain`\n this.prevBufferLen = this.writeBuffer.length;\n this.emitReserved(\"flush\");\n }\n }\n /**\n * Sends a message.\n *\n * @param {String} message.\n * @param {Function} callback function.\n * @param {Object} options.\n * @return {Socket} for chaining.\n * @api public\n */\n write(msg, options, fn) {\n this.sendPacket(\"message\", msg, options, fn);\n return this;\n }\n send(msg, options, fn) {\n this.sendPacket(\"message\", msg, options, fn);\n return this;\n }\n /**\n * Sends a packet.\n *\n * @param {String} packet type.\n * @param {String} data.\n * @param {Object} options.\n * @param {Function} callback function.\n * @api private\n */\n sendPacket(type, data, options, fn) {\n if (\"function\" === typeof data) {\n fn = data;\n data = undefined;\n }\n if (\"function\" === typeof options) {\n fn = options;\n options = null;\n }\n if (\"closing\" === this.readyState || \"closed\" === this.readyState) {\n return;\n }\n options = options || {};\n options.compress = false !== options.compress;\n const packet = {\n type: type,\n data: data,\n options: options\n };\n this.emitReserved(\"packetCreate\", packet);\n this.writeBuffer.push(packet);\n if (fn)\n this.once(\"flush\", fn);\n this.flush();\n }\n /**\n * Closes the connection.\n *\n * @api public\n */\n close() {\n const close = () => {\n this.onClose(\"forced close\");\n this.transport.close();\n };\n const cleanupAndClose = () => {\n this.off(\"upgrade\", cleanupAndClose);\n this.off(\"upgradeError\", cleanupAndClose);\n close();\n };\n const waitForUpgrade = () => {\n // wait for upgrade to finish since we can't send packets while pausing a transport\n this.once(\"upgrade\", cleanupAndClose);\n this.once(\"upgradeError\", cleanupAndClose);\n };\n if (\"opening\" === this.readyState || \"open\" === this.readyState) {\n this.readyState = \"closing\";\n if (this.writeBuffer.length) {\n this.once(\"drain\", () => {\n if (this.upgrading) {\n waitForUpgrade();\n }\n else {\n close();\n }\n });\n }\n else if (this.upgrading) {\n waitForUpgrade();\n }\n else {\n close();\n }\n }\n return this;\n }\n /**\n * Called upon transport error\n *\n * @api private\n */\n onError(err) {\n Socket.priorWebsocketSuccess = false;\n this.emitReserved(\"error\", err);\n this.onClose(\"transport error\", err);\n }\n /**\n * Called upon transport close.\n *\n * @api private\n */\n onClose(reason, desc) {\n if (\"opening\" === this.readyState ||\n \"open\" === this.readyState ||\n \"closing\" === this.readyState) {\n // clear timers\n this.clearTimeoutFn(this.pingTimeoutTimer);\n // stop event from firing again for transport\n this.transport.removeAllListeners(\"close\");\n // ensure transport won't stay open\n this.transport.close();\n // ignore further transport communication\n this.transport.removeAllListeners();\n if (typeof removeEventListener === \"function\") {\n removeEventListener(\"offline\", this.offlineEventListener, false);\n }\n // set ready state\n this.readyState = \"closed\";\n // clear session id\n this.id = null;\n // emit close event\n this.emitReserved(\"close\", reason, desc);\n // clean buffers after, so users can still\n // grab the buffers on `close` event\n this.writeBuffer = [];\n this.prevBufferLen = 0;\n }\n }\n /**\n * Filters upgrades, returning only those matching client transports.\n *\n * @param {Array} server upgrades\n * @api private\n *\n */\n filterUpgrades(upgrades) {\n const filteredUpgrades = [];\n let i = 0;\n const j = upgrades.length;\n for (; i < j; i++) {\n if (~this.transports.indexOf(upgrades[i]))\n filteredUpgrades.push(upgrades[i]);\n }\n return filteredUpgrades;\n }\n}\nSocket.protocol = protocol;\nfunction clone(obj) {\n const o = {};\n for (let i in obj) {\n if (obj.hasOwnProperty(i)) {\n o[i] = obj[i];\n }\n }\n return o;\n}\n","import { XHR } from \"./polling-xhr.js\";\nimport { WS } from \"./websocket.js\";\nexport const transports = {\n websocket: WS,\n polling: XHR\n};\n","/* global attachEvent */\nimport XMLHttpRequest from \"./xmlhttprequest.js\";\nimport globalThis from \"../globalThis.js\";\nimport { installTimerFunctions, pick } from \"../util.js\";\nimport { Emitter } from \"@socket.io/component-emitter\";\nimport { Polling } from \"./polling.js\";\n/**\n * Empty function\n */\nfunction empty() { }\nconst hasXHR2 = (function () {\n const xhr = new XMLHttpRequest({\n xdomain: false\n });\n return null != xhr.responseType;\n})();\nexport class XHR extends Polling {\n /**\n * XHR Polling constructor.\n *\n * @param {Object} opts\n * @api public\n */\n constructor(opts) {\n super(opts);\n if (typeof location !== \"undefined\") {\n const isSSL = \"https:\" === location.protocol;\n let port = location.port;\n // some user agents have empty `location.port`\n if (!port) {\n port = isSSL ? \"443\" : \"80\";\n }\n this.xd =\n (typeof location !== \"undefined\" &&\n opts.hostname !== location.hostname) ||\n port !== opts.port;\n this.xs = opts.secure !== isSSL;\n }\n /**\n * XHR supports binary\n */\n const forceBase64 = opts && opts.forceBase64;\n this.supportsBinary = hasXHR2 && !forceBase64;\n }\n /**\n * Creates a request.\n *\n * @param {String} method\n * @api private\n */\n request(opts = {}) {\n Object.assign(opts, { xd: this.xd, xs: this.xs }, this.opts);\n return new Request(this.uri(), opts);\n }\n /**\n * Sends data.\n *\n * @param {String} data to send.\n * @param {Function} called upon flush.\n * @api private\n */\n doWrite(data, fn) {\n const req = this.request({\n method: \"POST\",\n data: data\n });\n req.on(\"success\", fn);\n req.on(\"error\", err => {\n this.onError(\"xhr post error\", err);\n });\n }\n /**\n * Starts a poll cycle.\n *\n * @api private\n */\n doPoll() {\n const req = this.request();\n req.on(\"data\", this.onData.bind(this));\n req.on(\"error\", err => {\n this.onError(\"xhr poll error\", err);\n });\n this.pollXhr = req;\n }\n}\nexport class Request extends Emitter {\n /**\n * Request constructor\n *\n * @param {Object} options\n * @api public\n */\n constructor(uri, opts) {\n super();\n installTimerFunctions(this, opts);\n this.opts = opts;\n this.method = opts.method || \"GET\";\n this.uri = uri;\n this.async = false !== opts.async;\n this.data = undefined !== opts.data ? opts.data : null;\n this.create();\n }\n /**\n * Creates the XHR object and sends the request.\n *\n * @api private\n */\n create() {\n const opts = pick(this.opts, \"agent\", \"pfx\", \"key\", \"passphrase\", \"cert\", \"ca\", \"ciphers\", \"rejectUnauthorized\", \"autoUnref\");\n opts.xdomain = !!this.opts.xd;\n opts.xscheme = !!this.opts.xs;\n const xhr = (this.xhr = new XMLHttpRequest(opts));\n try {\n xhr.open(this.method, this.uri, this.async);\n try {\n if (this.opts.extraHeaders) {\n xhr.setDisableHeaderCheck && xhr.setDisableHeaderCheck(true);\n for (let i in this.opts.extraHeaders) {\n if (this.opts.extraHeaders.hasOwnProperty(i)) {\n xhr.setRequestHeader(i, this.opts.extraHeaders[i]);\n }\n }\n }\n }\n catch (e) { }\n if (\"POST\" === this.method) {\n try {\n xhr.setRequestHeader(\"Content-type\", \"text/plain;charset=UTF-8\");\n }\n catch (e) { }\n }\n try {\n xhr.setRequestHeader(\"Accept\", \"*/*\");\n }\n catch (e) { }\n // ie6 check\n if (\"withCredentials\" in xhr) {\n xhr.withCredentials = this.opts.withCredentials;\n }\n if (this.opts.requestTimeout) {\n xhr.timeout = this.opts.requestTimeout;\n }\n xhr.onreadystatechange = () => {\n if (4 !== xhr.readyState)\n return;\n if (200 === xhr.status || 1223 === xhr.status) {\n this.onLoad();\n }\n else {\n // make sure the `error` event handler that's user-set\n // does not throw in the same tick and gets caught here\n this.setTimeoutFn(() => {\n this.onError(typeof xhr.status === \"number\" ? xhr.status : 0);\n }, 0);\n }\n };\n xhr.send(this.data);\n }\n catch (e) {\n // Need to defer since .create() is called directly from the constructor\n // and thus the 'error' event can only be only bound *after* this exception\n // occurs. Therefore, also, we cannot throw here at all.\n this.setTimeoutFn(() => {\n this.onError(e);\n }, 0);\n return;\n }\n if (typeof document !== \"undefined\") {\n this.index = Request.requestsCount++;\n Request.requests[this.index] = this;\n }\n }\n /**\n * Called upon successful response.\n *\n * @api private\n */\n onSuccess() {\n this.emit(\"success\");\n this.cleanup();\n }\n /**\n * Called if we have data.\n *\n * @api private\n */\n onData(data) {\n this.emit(\"data\", data);\n this.onSuccess();\n }\n /**\n * Called upon error.\n *\n * @api private\n */\n onError(err) {\n this.emit(\"error\", err);\n this.cleanup(true);\n }\n /**\n * Cleans up house.\n *\n * @api private\n */\n cleanup(fromError) {\n if (\"undefined\" === typeof this.xhr || null === this.xhr) {\n return;\n }\n this.xhr.onreadystatechange = empty;\n if (fromError) {\n try {\n this.xhr.abort();\n }\n catch (e) { }\n }\n if (typeof document !== \"undefined\") {\n delete Request.requests[this.index];\n }\n this.xhr = null;\n }\n /**\n * Called upon load.\n *\n * @api private\n */\n onLoad() {\n const data = this.xhr.responseText;\n if (data !== null) {\n this.onData(data);\n }\n }\n /**\n * Aborts the request.\n *\n * @api public\n */\n abort() {\n this.cleanup();\n }\n}\nRequest.requestsCount = 0;\nRequest.requests = {};\n/**\n * Aborts pending requests when unloading the window. This is needed to prevent\n * memory leaks (e.g. when using IE) and to ensure that no spurious error is\n * emitted.\n */\nif (typeof document !== \"undefined\") {\n // @ts-ignore\n if (typeof attachEvent === \"function\") {\n // @ts-ignore\n attachEvent(\"onunload\", unloadHandler);\n }\n else if (typeof addEventListener === \"function\") {\n const terminationEvent = \"onpagehide\" in globalThis ? \"pagehide\" : \"unload\";\n addEventListener(terminationEvent, unloadHandler, false);\n }\n}\nfunction unloadHandler() {\n for (let i in Request.requests) {\n if (Request.requests.hasOwnProperty(i)) {\n Request.requests[i].abort();\n }\n }\n}\n","// browser shim for xmlhttprequest module\nimport hasCORS from \"has-cors\";\nimport globalThis from \"../globalThis.js\";\nexport default function (opts) {\n const xdomain = opts.xdomain;\n // XMLHttpRequest can be disabled on IE\n try {\n if (\"undefined\" !== typeof XMLHttpRequest && (!xdomain || hasCORS)) {\n return new XMLHttpRequest();\n }\n }\n catch (e) { }\n if (!xdomain) {\n try {\n return new globalThis[[\"Active\"].concat(\"Object\").join(\"X\")](\"Microsoft.XMLHTTP\");\n }\n catch (e) { }\n }\n}\n","\n/**\n * Module exports.\n *\n * Logic borrowed from Modernizr:\n *\n * - https://github.com/Modernizr/Modernizr/blob/master/feature-detects/cors.js\n */\n\ntry {\n module.exports = typeof XMLHttpRequest !== 'undefined' &&\n 'withCredentials' in new XMLHttpRequest();\n} catch (err) {\n // if XMLHttp support is disabled in IE then it will throw\n // when trying to create\n module.exports = false;\n}\n","export default (() => {\n if (typeof self !== \"undefined\") {\n return self;\n }\n else if (typeof window !== \"undefined\") {\n return window;\n }\n else {\n return Function(\"return this\")();\n }\n})();\n","import globalThis from \"./globalThis.js\";\nexport function pick(obj, ...attr) {\n return attr.reduce((acc, k) => {\n if (obj.hasOwnProperty(k)) {\n acc[k] = obj[k];\n }\n return acc;\n }, {});\n}\n// Keep a reference to the real timeout functions so they can be used when overridden\nconst NATIVE_SET_TIMEOUT = setTimeout;\nconst NATIVE_CLEAR_TIMEOUT = clearTimeout;\nexport function installTimerFunctions(obj, opts) {\n if (opts.useNativeTimers) {\n obj.setTimeoutFn = NATIVE_SET_TIMEOUT.bind(globalThis);\n obj.clearTimeoutFn = NATIVE_CLEAR_TIMEOUT.bind(globalThis);\n }\n else {\n obj.setTimeoutFn = setTimeout.bind(globalThis);\n obj.clearTimeoutFn = clearTimeout.bind(globalThis);\n }\n}\n","\n/**\n * Expose `Emitter`.\n */\n\nexports.Emitter = Emitter;\n\n/**\n * Initialize a new `Emitter`.\n *\n * @api public\n */\n\nfunction Emitter(obj) {\n if (obj) return mixin(obj);\n}\n\n/**\n * Mixin the emitter properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\nfunction mixin(obj) {\n for (var key in Emitter.prototype) {\n obj[key] = Emitter.prototype[key];\n }\n return obj;\n}\n\n/**\n * Listen on the given `event` with `fn`.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.on =\nEmitter.prototype.addEventListener = function(event, fn){\n this._callbacks = this._callbacks || {};\n (this._callbacks['$' + event] = this._callbacks['$' + event] || [])\n .push(fn);\n return this;\n};\n\n/**\n * Adds an `event` listener that will be invoked a single\n * time then automatically removed.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.once = function(event, fn){\n function on() {\n this.off(event, on);\n fn.apply(this, arguments);\n }\n\n on.fn = fn;\n this.on(event, on);\n return this;\n};\n\n/**\n * Remove the given callback for `event` or all\n * registered callbacks.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.off =\nEmitter.prototype.removeListener =\nEmitter.prototype.removeAllListeners =\nEmitter.prototype.removeEventListener = function(event, fn){\n this._callbacks = this._callbacks || {};\n\n // all\n if (0 == arguments.length) {\n this._callbacks = {};\n return this;\n }\n\n // specific event\n var callbacks = this._callbacks['$' + event];\n if (!callbacks) return this;\n\n // remove all handlers\n if (1 == arguments.length) {\n delete this._callbacks['$' + event];\n return this;\n }\n\n // remove specific handler\n var cb;\n for (var i = 0; i < callbacks.length; i++) {\n cb = callbacks[i];\n if (cb === fn || cb.fn === fn) {\n callbacks.splice(i, 1);\n break;\n }\n }\n\n // Remove event specific arrays for event types that no\n // one is subscribed for to avoid memory leak.\n if (callbacks.length === 0) {\n delete this._callbacks['$' + event];\n }\n\n return this;\n};\n\n/**\n * Emit `event` with the given args.\n *\n * @param {String} event\n * @param {Mixed} ...\n * @return {Emitter}\n */\n\nEmitter.prototype.emit = function(event){\n this._callbacks = this._callbacks || {};\n\n var args = new Array(arguments.length - 1)\n , callbacks = this._callbacks['$' + event];\n\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n\n if (callbacks) {\n callbacks = callbacks.slice(0);\n for (var i = 0, len = callbacks.length; i < len; ++i) {\n callbacks[i].apply(this, args);\n }\n }\n\n return this;\n};\n\n// alias used for reserved events (protected method)\nEmitter.prototype.emitReserved = Emitter.prototype.emit;\n\n/**\n * Return array of callbacks for `event`.\n *\n * @param {String} event\n * @return {Array}\n * @api public\n */\n\nEmitter.prototype.listeners = function(event){\n this._callbacks = this._callbacks || {};\n return this._callbacks['$' + event] || [];\n};\n\n/**\n * Check if this emitter has `event` handlers.\n *\n * @param {String} event\n * @return {Boolean}\n * @api public\n */\n\nEmitter.prototype.hasListeners = function(event){\n return !! this.listeners(event).length;\n};\n","import { Transport } from \"../transport.js\";\nimport yeast from \"yeast\";\nimport parseqs from \"parseqs\";\nimport { encodePayload, decodePayload } from \"engine.io-parser\";\nexport class Polling extends Transport {\n constructor() {\n super(...arguments);\n this.polling = false;\n }\n /**\n * Transport name.\n */\n get name() {\n return \"polling\";\n }\n /**\n * Opens the socket (triggers polling). We write a PING message to determine\n * when the transport is open.\n *\n * @api private\n */\n doOpen() {\n this.poll();\n }\n /**\n * Pauses polling.\n *\n * @param {Function} callback upon buffers are flushed and transport is paused\n * @api private\n */\n pause(onPause) {\n this.readyState = \"pausing\";\n const pause = () => {\n this.readyState = \"paused\";\n onPause();\n };\n if (this.polling || !this.writable) {\n let total = 0;\n if (this.polling) {\n total++;\n this.once(\"pollComplete\", function () {\n --total || pause();\n });\n }\n if (!this.writable) {\n total++;\n this.once(\"drain\", function () {\n --total || pause();\n });\n }\n }\n else {\n pause();\n }\n }\n /**\n * Starts polling cycle.\n *\n * @api public\n */\n poll() {\n this.polling = true;\n this.doPoll();\n this.emit(\"poll\");\n }\n /**\n * Overloads onData to detect payloads.\n *\n * @api private\n */\n onData(data) {\n const callback = packet => {\n // if its the first message we consider the transport open\n if (\"opening\" === this.readyState && packet.type === \"open\") {\n this.onOpen();\n }\n // if its a close packet, we close the ongoing requests\n if (\"close\" === packet.type) {\n this.onClose();\n return false;\n }\n // otherwise bypass onData and handle the message\n this.onPacket(packet);\n };\n // decode payload\n decodePayload(data, this.socket.binaryType).forEach(callback);\n // if an event did not trigger closing\n if (\"closed\" !== this.readyState) {\n // if we got data we're not polling\n this.polling = false;\n this.emit(\"pollComplete\");\n if (\"open\" === this.readyState) {\n this.poll();\n }\n else {\n }\n }\n }\n /**\n * For polling, send a close packet.\n *\n * @api private\n */\n doClose() {\n const close = () => {\n this.write([{ type: \"close\" }]);\n };\n if (\"open\" === this.readyState) {\n close();\n }\n else {\n // in case we're trying to close while\n // handshaking is in progress (GH-164)\n this.once(\"open\", close);\n }\n }\n /**\n * Writes a packets payload.\n *\n * @param {Array} data packets\n * @param {Function} drain callback\n * @api private\n */\n write(packets) {\n this.writable = false;\n encodePayload(packets, data => {\n this.doWrite(data, () => {\n this.writable = true;\n this.emit(\"drain\");\n });\n });\n }\n /**\n * Generates uri for connection.\n *\n * @api private\n */\n uri() {\n let query = this.query || {};\n const schema = this.opts.secure ? \"https\" : \"http\";\n let port = \"\";\n // cache busting is forced\n if (false !== this.opts.timestampRequests) {\n query[this.opts.timestampParam] = yeast();\n }\n if (!this.supportsBinary && !query.sid) {\n query.b64 = 1;\n }\n // avoid port if default for schema\n if (this.opts.port &&\n ((\"https\" === schema && Number(this.opts.port) !== 443) ||\n (\"http\" === schema && Number(this.opts.port) !== 80))) {\n port = \":\" + this.opts.port;\n }\n const encodedQuery = parseqs.encode(query);\n const ipv6 = this.opts.hostname.indexOf(\":\") !== -1;\n return (schema +\n \"://\" +\n (ipv6 ? \"[\" + this.opts.hostname + \"]\" : this.opts.hostname) +\n port +\n this.opts.path +\n (encodedQuery.length ? \"?\" + encodedQuery : \"\"));\n }\n}\n","import { decodePacket } from \"engine.io-parser\";\nimport { Emitter } from \"@socket.io/component-emitter\";\nimport { installTimerFunctions } from \"./util.js\";\nexport class Transport extends Emitter {\n /**\n * Transport abstract constructor.\n *\n * @param {Object} options.\n * @api private\n */\n constructor(opts) {\n super();\n this.writable = false;\n installTimerFunctions(this, opts);\n this.opts = opts;\n this.query = opts.query;\n this.readyState = \"\";\n this.socket = opts.socket;\n }\n /**\n * Emits an error.\n *\n * @param {String} str\n * @return {Transport} for chaining\n * @api protected\n */\n onError(msg, desc) {\n const err = new Error(msg);\n // @ts-ignore\n err.type = \"TransportError\";\n // @ts-ignore\n err.description = desc;\n super.emit(\"error\", err);\n return this;\n }\n /**\n * Opens the transport.\n *\n * @api public\n */\n open() {\n if (\"closed\" === this.readyState || \"\" === this.readyState) {\n this.readyState = \"opening\";\n this.doOpen();\n }\n return this;\n }\n /**\n * Closes the transport.\n *\n * @api public\n */\n close() {\n if (\"opening\" === this.readyState || \"open\" === this.readyState) {\n this.doClose();\n this.onClose();\n }\n return this;\n }\n /**\n * Sends multiple packets.\n *\n * @param {Array} packets\n * @api public\n */\n send(packets) {\n if (\"open\" === this.readyState) {\n this.write(packets);\n }\n else {\n // this might happen if the transport was silently closed in the beforeunload event handler\n }\n }\n /**\n * Called upon open\n *\n * @api protected\n */\n onOpen() {\n this.readyState = \"open\";\n this.writable = true;\n super.emit(\"open\");\n }\n /**\n * Called with data.\n *\n * @param {String} data\n * @api protected\n */\n onData(data) {\n const packet = decodePacket(data, this.socket.binaryType);\n this.onPacket(packet);\n }\n /**\n * Called with a decoded packet.\n *\n * @api protected\n */\n onPacket(packet) {\n super.emit(\"packet\", packet);\n }\n /**\n * Called upon close.\n *\n * @api protected\n */\n onClose() {\n this.readyState = \"closed\";\n super.emit(\"close\");\n }\n}\n","import encodePacket from \"./encodePacket.js\";\nimport decodePacket from \"./decodePacket.js\";\nconst SEPARATOR = String.fromCharCode(30); // see https://en.wikipedia.org/wiki/Delimiter#ASCII_delimited_text\nconst encodePayload = (packets, callback) => {\n // some packets may be added to the array while encoding, so the initial length must be saved\n const length = packets.length;\n const encodedPackets = new Array(length);\n let count = 0;\n packets.forEach((packet, i) => {\n // force base64 encoding for binary packets\n encodePacket(packet, false, encodedPacket => {\n encodedPackets[i] = encodedPacket;\n if (++count === length) {\n callback(encodedPackets.join(SEPARATOR));\n }\n });\n });\n};\nconst decodePayload = (encodedPayload, binaryType) => {\n const encodedPackets = encodedPayload.split(SEPARATOR);\n const packets = [];\n for (let i = 0; i < encodedPackets.length; i++) {\n const decodedPacket = decodePacket(encodedPackets[i], binaryType);\n packets.push(decodedPacket);\n if (decodedPacket.type === \"error\") {\n break;\n }\n }\n return packets;\n};\nexport const protocol = 4;\nexport { encodePacket, encodePayload, decodePacket, decodePayload };\n","import { PACKET_TYPES } from \"./commons.js\";\nconst withNativeBlob = typeof Blob === \"function\" ||\n (typeof Blob !== \"undefined\" &&\n Object.prototype.toString.call(Blob) === \"[object BlobConstructor]\");\nconst withNativeArrayBuffer = typeof ArrayBuffer === \"function\";\n// ArrayBuffer.isView method is not defined in IE10\nconst isView = obj => {\n return typeof ArrayBuffer.isView === \"function\"\n ? ArrayBuffer.isView(obj)\n : obj && obj.buffer instanceof ArrayBuffer;\n};\nconst encodePacket = ({ type, data }, supportsBinary, callback) => {\n if (withNativeBlob && data instanceof Blob) {\n if (supportsBinary) {\n return callback(data);\n }\n else {\n return encodeBlobAsBase64(data, callback);\n }\n }\n else if (withNativeArrayBuffer &&\n (data instanceof ArrayBuffer || isView(data))) {\n if (supportsBinary) {\n return callback(data);\n }\n else {\n return encodeBlobAsBase64(new Blob([data]), callback);\n }\n }\n // plain string\n return callback(PACKET_TYPES[type] + (data || \"\"));\n};\nconst encodeBlobAsBase64 = (data, callback) => {\n const fileReader = new FileReader();\n fileReader.onload = function () {\n const content = fileReader.result.split(\",\")[1];\n callback(\"b\" + content);\n };\n return fileReader.readAsDataURL(data);\n};\nexport default encodePacket;\n","const PACKET_TYPES = Object.create(null); // no Map = no polyfill\nPACKET_TYPES[\"open\"] = \"0\";\nPACKET_TYPES[\"close\"] = \"1\";\nPACKET_TYPES[\"ping\"] = \"2\";\nPACKET_TYPES[\"pong\"] = \"3\";\nPACKET_TYPES[\"message\"] = \"4\";\nPACKET_TYPES[\"upgrade\"] = \"5\";\nPACKET_TYPES[\"noop\"] = \"6\";\nconst PACKET_TYPES_REVERSE = Object.create(null);\nObject.keys(PACKET_TYPES).forEach(key => {\n PACKET_TYPES_REVERSE[PACKET_TYPES[key]] = key;\n});\nconst ERROR_PACKET = { type: \"error\", data: \"parser error\" };\nexport { PACKET_TYPES, PACKET_TYPES_REVERSE, ERROR_PACKET };\n","import { ERROR_PACKET, PACKET_TYPES_REVERSE } from \"./commons.js\";\nimport { decode } from \"base64-arraybuffer\";\nconst withNativeArrayBuffer = typeof ArrayBuffer === \"function\";\nconst decodePacket = (encodedPacket, binaryType) => {\n if (typeof encodedPacket !== \"string\") {\n return {\n type: \"message\",\n data: mapBinary(encodedPacket, binaryType)\n };\n }\n const type = encodedPacket.charAt(0);\n if (type === \"b\") {\n return {\n type: \"message\",\n data: decodeBase64Packet(encodedPacket.substring(1), binaryType)\n };\n }\n const packetType = PACKET_TYPES_REVERSE[type];\n if (!packetType) {\n return ERROR_PACKET;\n }\n return encodedPacket.length > 1\n ? {\n type: PACKET_TYPES_REVERSE[type],\n data: encodedPacket.substring(1)\n }\n : {\n type: PACKET_TYPES_REVERSE[type]\n };\n};\nconst decodeBase64Packet = (data, binaryType) => {\n if (withNativeArrayBuffer) {\n const decoded = decode(data);\n return mapBinary(decoded, binaryType);\n }\n else {\n return { base64: true, data }; // fallback for old browsers\n }\n};\nconst mapBinary = (data, binaryType) => {\n switch (binaryType) {\n case \"blob\":\n return data instanceof ArrayBuffer ? new Blob([data]) : data;\n case \"arraybuffer\":\n default:\n return data; // assuming the data is already an ArrayBuffer\n }\n};\nexport default decodePacket;\n",null,"'use strict';\n\nvar alphabet = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz-_'.split('')\n , length = 64\n , map = {}\n , seed = 0\n , i = 0\n , prev;\n\n/**\n * Return a string representing the specified number.\n *\n * @param {Number} num The number to convert.\n * @returns {String} The string representation of the number.\n * @api public\n */\nfunction encode(num) {\n var encoded = '';\n\n do {\n encoded = alphabet[num % length] + encoded;\n num = Math.floor(num / length);\n } while (num > 0);\n\n return encoded;\n}\n\n/**\n * Return the integer value specified by the given string.\n *\n * @param {String} str The string to convert.\n * @returns {Number} The integer value represented by the string.\n * @api public\n */\nfunction decode(str) {\n var decoded = 0;\n\n for (i = 0; i < str.length; i++) {\n decoded = decoded * length + map[str.charAt(i)];\n }\n\n return decoded;\n}\n\n/**\n * Yeast: A tiny growing id generator.\n *\n * @returns {String} A unique id.\n * @api public\n */\nfunction yeast() {\n var now = encode(+new Date());\n\n if (now !== prev) return seed = 0, prev = now;\n return now +'.'+ encode(seed++);\n}\n\n//\n// Map each character to its index.\n//\nfor (; i < length; i++) map[alphabet[i]] = i;\n\n//\n// Expose the `yeast`, `encode` and `decode` functions.\n//\nyeast.encode = encode;\nyeast.decode = decode;\nmodule.exports = yeast;\n","/**\n * Compiles a querystring\n * Returns string representation of the object\n *\n * @param {Object}\n * @api private\n */\n\nexports.encode = function (obj) {\n var str = '';\n\n for (var i in obj) {\n if (obj.hasOwnProperty(i)) {\n if (str.length) str += '&';\n str += encodeURIComponent(i) + '=' + encodeURIComponent(obj[i]);\n }\n }\n\n return str;\n};\n\n/**\n * Parses a simple querystring into an object\n *\n * @param {String} qs\n * @api private\n */\n\nexports.decode = function(qs){\n var qry = {};\n var pairs = qs.split('&');\n for (var i = 0, l = pairs.length; i < l; i++) {\n var pair = pairs[i].split('=');\n qry[decodeURIComponent(pair[0])] = decodeURIComponent(pair[1]);\n }\n return qry;\n};\n","import { Transport } from \"../transport.js\";\nimport parseqs from \"parseqs\";\nimport yeast from \"yeast\";\nimport { pick } from \"../util.js\";\nimport { defaultBinaryType, nextTick, usingBrowserWebSocket, WebSocket } from \"./websocket-constructor.js\";\nimport { encodePacket } from \"engine.io-parser\";\n// detect ReactNative environment\nconst isReactNative = typeof navigator !== \"undefined\" &&\n typeof navigator.product === \"string\" &&\n navigator.product.toLowerCase() === \"reactnative\";\nexport class WS extends Transport {\n /**\n * WebSocket transport constructor.\n *\n * @api {Object} connection options\n * @api public\n */\n constructor(opts) {\n super(opts);\n this.supportsBinary = !opts.forceBase64;\n }\n /**\n * Transport name.\n *\n * @api public\n */\n get name() {\n return \"websocket\";\n }\n /**\n * Opens socket.\n *\n * @api private\n */\n doOpen() {\n if (!this.check()) {\n // let probe timeout\n return;\n }\n const uri = this.uri();\n const protocols = this.opts.protocols;\n // React Native only supports the 'headers' option, and will print a warning if anything else is passed\n const opts = isReactNative\n ? {}\n : pick(this.opts, \"agent\", \"perMessageDeflate\", \"pfx\", \"key\", \"passphrase\", \"cert\", \"ca\", \"ciphers\", \"rejectUnauthorized\", \"localAddress\", \"protocolVersion\", \"origin\", \"maxPayload\", \"family\", \"checkServerIdentity\");\n if (this.opts.extraHeaders) {\n opts.headers = this.opts.extraHeaders;\n }\n try {\n this.ws =\n usingBrowserWebSocket && !isReactNative\n ? protocols\n ? new WebSocket(uri, protocols)\n : new WebSocket(uri)\n : new WebSocket(uri, protocols, opts);\n }\n catch (err) {\n return this.emit(\"error\", err);\n }\n this.ws.binaryType = this.socket.binaryType || defaultBinaryType;\n this.addEventListeners();\n }\n /**\n * Adds event listeners to the socket\n *\n * @api private\n */\n addEventListeners() {\n this.ws.onopen = () => {\n if (this.opts.autoUnref) {\n this.ws._socket.unref();\n }\n this.onOpen();\n };\n this.ws.onclose = this.onClose.bind(this);\n this.ws.onmessage = ev => this.onData(ev.data);\n this.ws.onerror = e => this.onError(\"websocket error\", e);\n }\n /**\n * Writes data to socket.\n *\n * @param {Array} array of packets.\n * @api private\n */\n write(packets) {\n this.writable = false;\n // encodePacket efficient as it uses WS framing\n // no need for encodePayload\n for (let i = 0; i < packets.length; i++) {\n const packet = packets[i];\n const lastPacket = i === packets.length - 1;\n encodePacket(packet, this.supportsBinary, data => {\n // always create a new object (GH-437)\n const opts = {};\n if (!usingBrowserWebSocket) {\n if (packet.options) {\n opts.compress = packet.options.compress;\n }\n if (this.opts.perMessageDeflate) {\n const len = \"string\" === typeof data ? Buffer.byteLength(data) : data.length;\n if (len < this.opts.perMessageDeflate.threshold) {\n opts.compress = false;\n }\n }\n }\n // Sometimes the websocket has already been closed but the browser didn't\n // have a chance of informing us about it yet, in that case send will\n // throw an error\n try {\n if (usingBrowserWebSocket) {\n // TypeError is thrown when passing the second argument on Safari\n this.ws.send(data);\n }\n else {\n this.ws.send(data, opts);\n }\n }\n catch (e) {\n }\n if (lastPacket) {\n // fake drain\n // defer to next tick to allow Socket to clear writeBuffer\n nextTick(() => {\n this.writable = true;\n this.emit(\"drain\");\n }, this.setTimeoutFn);\n }\n });\n }\n }\n /**\n * Closes socket.\n *\n * @api private\n */\n doClose() {\n if (typeof this.ws !== \"undefined\") {\n this.ws.close();\n this.ws = null;\n }\n }\n /**\n * Generates uri for connection.\n *\n * @api private\n */\n uri() {\n let query = this.query || {};\n const schema = this.opts.secure ? \"wss\" : \"ws\";\n let port = \"\";\n // avoid port if default for schema\n if (this.opts.port &&\n ((\"wss\" === schema && Number(this.opts.port) !== 443) ||\n (\"ws\" === schema && Number(this.opts.port) !== 80))) {\n port = \":\" + this.opts.port;\n }\n // append timestamp to URI\n if (this.opts.timestampRequests) {\n query[this.opts.timestampParam] = yeast();\n }\n // communicate binary support capabilities\n if (!this.supportsBinary) {\n query.b64 = 1;\n }\n const encodedQuery = parseqs.encode(query);\n const ipv6 = this.opts.hostname.indexOf(\":\") !== -1;\n return (schema +\n \"://\" +\n (ipv6 ? \"[\" + this.opts.hostname + \"]\" : this.opts.hostname) +\n port +\n this.opts.path +\n (encodedQuery.length ? \"?\" + encodedQuery : \"\"));\n }\n /**\n * Feature detection for WebSocket.\n *\n * @return {Boolean} whether this transport is available.\n * @api public\n */\n check() {\n return (!!WebSocket &&\n !(\"__initialize\" in WebSocket && this.name === WS.prototype.name));\n }\n}\n","import globalThis from \"../globalThis.js\";\nexport const nextTick = (() => {\n const isPromiseAvailable = typeof Promise === \"function\" && typeof Promise.resolve === \"function\";\n if (isPromiseAvailable) {\n return cb => Promise.resolve().then(cb);\n }\n else {\n return (cb, setTimeoutFn) => setTimeoutFn(cb, 0);\n }\n})();\nexport const WebSocket = globalThis.WebSocket || globalThis.MozWebSocket;\nexport const usingBrowserWebSocket = true;\nexport const defaultBinaryType = \"arraybuffer\";\n","import { PacketType } from \"socket.io-parser\";\nimport { on } from \"./on.js\";\nimport { Emitter, } from \"@socket.io/component-emitter\";\n/**\n * Internal events.\n * These events can't be emitted by the user.\n */\nconst RESERVED_EVENTS = Object.freeze({\n connect: 1,\n connect_error: 1,\n disconnect: 1,\n disconnecting: 1,\n // EventEmitter reserved events: https://nodejs.org/api/events.html#events_event_newlistener\n newListener: 1,\n removeListener: 1,\n});\nexport class Socket extends Emitter {\n /**\n * `Socket` constructor.\n *\n * @public\n */\n constructor(io, nsp, opts) {\n super();\n this.connected = false;\n this.disconnected = true;\n this.receiveBuffer = [];\n this.sendBuffer = [];\n this.ids = 0;\n this.acks = {};\n this.flags = {};\n this.io = io;\n this.nsp = nsp;\n if (opts && opts.auth) {\n this.auth = opts.auth;\n }\n if (this.io._autoConnect)\n this.open();\n }\n /**\n * Subscribe to open, close and packet events\n *\n * @private\n */\n subEvents() {\n if (this.subs)\n return;\n const io = this.io;\n this.subs = [\n on(io, \"open\", this.onopen.bind(this)),\n on(io, \"packet\", this.onpacket.bind(this)),\n on(io, \"error\", this.onerror.bind(this)),\n on(io, \"close\", this.onclose.bind(this)),\n ];\n }\n /**\n * Whether the Socket will try to reconnect when its Manager connects or reconnects\n */\n get active() {\n return !!this.subs;\n }\n /**\n * \"Opens\" the socket.\n *\n * @public\n */\n connect() {\n if (this.connected)\n return this;\n this.subEvents();\n if (!this.io[\"_reconnecting\"])\n this.io.open(); // ensure open\n if (\"open\" === this.io._readyState)\n this.onopen();\n return this;\n }\n /**\n * Alias for connect()\n */\n open() {\n return this.connect();\n }\n /**\n * Sends a `message` event.\n *\n * @return self\n * @public\n */\n send(...args) {\n args.unshift(\"message\");\n this.emit.apply(this, args);\n return this;\n }\n /**\n * Override `emit`.\n * If the event is in `events`, it's emitted normally.\n *\n * @return self\n * @public\n */\n emit(ev, ...args) {\n if (RESERVED_EVENTS.hasOwnProperty(ev)) {\n throw new Error('\"' + ev + '\" is a reserved event name');\n }\n args.unshift(ev);\n const packet = {\n type: PacketType.EVENT,\n data: args,\n };\n packet.options = {};\n packet.options.compress = this.flags.compress !== false;\n // event ack callback\n if (\"function\" === typeof args[args.length - 1]) {\n const id = this.ids++;\n const ack = args.pop();\n this._registerAckCallback(id, ack);\n packet.id = id;\n }\n const isTransportWritable = this.io.engine &&\n this.io.engine.transport &&\n this.io.engine.transport.writable;\n const discardPacket = this.flags.volatile && (!isTransportWritable || !this.connected);\n if (discardPacket) {\n }\n else if (this.connected) {\n this.packet(packet);\n }\n else {\n this.sendBuffer.push(packet);\n }\n this.flags = {};\n return this;\n }\n /**\n * @private\n */\n _registerAckCallback(id, ack) {\n const timeout = this.flags.timeout;\n if (timeout === undefined) {\n this.acks[id] = ack;\n return;\n }\n // @ts-ignore\n const timer = this.io.setTimeoutFn(() => {\n delete this.acks[id];\n for (let i = 0; i < this.sendBuffer.length; i++) {\n if (this.sendBuffer[i].id === id) {\n this.sendBuffer.splice(i, 1);\n }\n }\n ack.call(this, new Error(\"operation has timed out\"));\n }, timeout);\n this.acks[id] = (...args) => {\n // @ts-ignore\n this.io.clearTimeoutFn(timer);\n ack.apply(this, [null, ...args]);\n };\n }\n /**\n * Sends a packet.\n *\n * @param packet\n * @private\n */\n packet(packet) {\n packet.nsp = this.nsp;\n this.io._packet(packet);\n }\n /**\n * Called upon engine `open`.\n *\n * @private\n */\n onopen() {\n if (typeof this.auth == \"function\") {\n this.auth((data) => {\n this.packet({ type: PacketType.CONNECT, data });\n });\n }\n else {\n this.packet({ type: PacketType.CONNECT, data: this.auth });\n }\n }\n /**\n * Called upon engine or manager `error`.\n *\n * @param err\n * @private\n */\n onerror(err) {\n if (!this.connected) {\n this.emitReserved(\"connect_error\", err);\n }\n }\n /**\n * Called upon engine `close`.\n *\n * @param reason\n * @private\n */\n onclose(reason) {\n this.connected = false;\n this.disconnected = true;\n delete this.id;\n this.emitReserved(\"disconnect\", reason);\n }\n /**\n * Called with socket packet.\n *\n * @param packet\n * @private\n */\n onpacket(packet) {\n const sameNamespace = packet.nsp === this.nsp;\n if (!sameNamespace)\n return;\n switch (packet.type) {\n case PacketType.CONNECT:\n if (packet.data && packet.data.sid) {\n const id = packet.data.sid;\n this.onconnect(id);\n }\n else {\n this.emitReserved(\"connect_error\", new Error(\"It seems you are trying to reach a Socket.IO server in v2.x with a v3.x client, but they are not compatible (more information here: https://socket.io/docs/v3/migrating-from-2-x-to-3-0/)\"));\n }\n break;\n case PacketType.EVENT:\n this.onevent(packet);\n break;\n case PacketType.BINARY_EVENT:\n this.onevent(packet);\n break;\n case PacketType.ACK:\n this.onack(packet);\n break;\n case PacketType.BINARY_ACK:\n this.onack(packet);\n break;\n case PacketType.DISCONNECT:\n this.ondisconnect();\n break;\n case PacketType.CONNECT_ERROR:\n this.destroy();\n const err = new Error(packet.data.message);\n // @ts-ignore\n err.data = packet.data.data;\n this.emitReserved(\"connect_error\", err);\n break;\n }\n }\n /**\n * Called upon a server event.\n *\n * @param packet\n * @private\n */\n onevent(packet) {\n const args = packet.data || [];\n if (null != packet.id) {\n args.push(this.ack(packet.id));\n }\n if (this.connected) {\n this.emitEvent(args);\n }\n else {\n this.receiveBuffer.push(Object.freeze(args));\n }\n }\n emitEvent(args) {\n if (this._anyListeners && this._anyListeners.length) {\n const listeners = this._anyListeners.slice();\n for (const listener of listeners) {\n listener.apply(this, args);\n }\n }\n super.emit.apply(this, args);\n }\n /**\n * Produces an ack callback to emit with an event.\n *\n * @private\n */\n ack(id) {\n const self = this;\n let sent = false;\n return function (...args) {\n // prevent double callbacks\n if (sent)\n return;\n sent = true;\n self.packet({\n type: PacketType.ACK,\n id: id,\n data: args,\n });\n };\n }\n /**\n * Called upon a server acknowlegement.\n *\n * @param packet\n * @private\n */\n onack(packet) {\n const ack = this.acks[packet.id];\n if (\"function\" === typeof ack) {\n ack.apply(this, packet.data);\n delete this.acks[packet.id];\n }\n else {\n }\n }\n /**\n * Called upon server connect.\n *\n * @private\n */\n onconnect(id) {\n this.id = id;\n this.connected = true;\n this.disconnected = false;\n this.emitBuffered();\n this.emitReserved(\"connect\");\n }\n /**\n * Emit buffered events (received and emitted).\n *\n * @private\n */\n emitBuffered() {\n this.receiveBuffer.forEach((args) => this.emitEvent(args));\n this.receiveBuffer = [];\n this.sendBuffer.forEach((packet) => this.packet(packet));\n this.sendBuffer = [];\n }\n /**\n * Called upon server disconnect.\n *\n * @private\n */\n ondisconnect() {\n this.destroy();\n this.onclose(\"io server disconnect\");\n }\n /**\n * Called upon forced client/server side disconnections,\n * this method ensures the manager stops tracking us and\n * that reconnections don't get triggered for this.\n *\n * @private\n */\n destroy() {\n if (this.subs) {\n // clean subscriptions to avoid reconnections\n this.subs.forEach((subDestroy) => subDestroy());\n this.subs = undefined;\n }\n this.io[\"_destroy\"](this);\n }\n /**\n * Disconnects the socket manually.\n *\n * @return self\n * @public\n */\n disconnect() {\n if (this.connected) {\n this.packet({ type: PacketType.DISCONNECT });\n }\n // remove socket from pool\n this.destroy();\n if (this.connected) {\n // fire events\n this.onclose(\"io client disconnect\");\n }\n return this;\n }\n /**\n * Alias for disconnect()\n *\n * @return self\n * @public\n */\n close() {\n return this.disconnect();\n }\n /**\n * Sets the compress flag.\n *\n * @param compress - if `true`, compresses the sending data\n * @return self\n * @public\n */\n compress(compress) {\n this.flags.compress = compress;\n return this;\n }\n /**\n * Sets a modifier for a subsequent event emission that the event message will be dropped when this socket is not\n * ready to send messages.\n *\n * @returns self\n * @public\n */\n get volatile() {\n this.flags.volatile = true;\n return this;\n }\n /**\n * Sets a modifier for a subsequent event emission that the callback will be called with an error when the\n * given number of milliseconds have elapsed without an acknowledgement from the server:\n *\n * ```\n * socket.timeout(5000).emit(\"my-event\", (err) => {\n * if (err) {\n * // the server did not acknowledge the event in the given delay\n * }\n * });\n * ```\n *\n * @returns self\n * @public\n */\n timeout(timeout) {\n this.flags.timeout = timeout;\n return this;\n }\n /**\n * Adds a listener that will be fired when any event is emitted. The event name is passed as the first argument to the\n * callback.\n *\n * @param listener\n * @public\n */\n onAny(listener) {\n this._anyListeners = this._anyListeners || [];\n this._anyListeners.push(listener);\n return this;\n }\n /**\n * Adds a listener that will be fired when any event is emitted. The event name is passed as the first argument to the\n * callback. The listener is added to the beginning of the listeners array.\n *\n * @param listener\n * @public\n */\n prependAny(listener) {\n this._anyListeners = this._anyListeners || [];\n this._anyListeners.unshift(listener);\n return this;\n }\n /**\n * Removes the listener that will be fired when any event is emitted.\n *\n * @param listener\n * @public\n */\n offAny(listener) {\n if (!this._anyListeners) {\n return this;\n }\n if (listener) {\n const listeners = this._anyListeners;\n for (let i = 0; i < listeners.length; i++) {\n if (listener === listeners[i]) {\n listeners.splice(i, 1);\n return this;\n }\n }\n }\n else {\n this._anyListeners = [];\n }\n return this;\n }\n /**\n * Returns an array of listeners that are listening for any event that is specified. This array can be manipulated,\n * e.g. to remove listeners.\n *\n * @public\n */\n listenersAny() {\n return this._anyListeners || [];\n }\n}\n","import { Emitter } from \"@socket.io/component-emitter\";\nimport { deconstructPacket, reconstructPacket } from \"./binary.js\";\nimport { isBinary, hasBinary } from \"./is-binary.js\";\n/**\n * Protocol version.\n *\n * @public\n */\nexport const protocol = 5;\nexport var PacketType;\n(function (PacketType) {\n PacketType[PacketType[\"CONNECT\"] = 0] = \"CONNECT\";\n PacketType[PacketType[\"DISCONNECT\"] = 1] = \"DISCONNECT\";\n PacketType[PacketType[\"EVENT\"] = 2] = \"EVENT\";\n PacketType[PacketType[\"ACK\"] = 3] = \"ACK\";\n PacketType[PacketType[\"CONNECT_ERROR\"] = 4] = \"CONNECT_ERROR\";\n PacketType[PacketType[\"BINARY_EVENT\"] = 5] = \"BINARY_EVENT\";\n PacketType[PacketType[\"BINARY_ACK\"] = 6] = \"BINARY_ACK\";\n})(PacketType || (PacketType = {}));\n/**\n * A socket.io Encoder instance\n */\nexport class Encoder {\n /**\n * Encode a packet as a single string if non-binary, or as a\n * buffer sequence, depending on packet type.\n *\n * @param {Object} obj - packet object\n */\n encode(obj) {\n if (obj.type === PacketType.EVENT || obj.type === PacketType.ACK) {\n if (hasBinary(obj)) {\n obj.type =\n obj.type === PacketType.EVENT\n ? PacketType.BINARY_EVENT\n : PacketType.BINARY_ACK;\n return this.encodeAsBinary(obj);\n }\n }\n return [this.encodeAsString(obj)];\n }\n /**\n * Encode packet as string.\n */\n encodeAsString(obj) {\n // first is type\n let str = \"\" + obj.type;\n // attachments if we have them\n if (obj.type === PacketType.BINARY_EVENT ||\n obj.type === PacketType.BINARY_ACK) {\n str += obj.attachments + \"-\";\n }\n // if we have a namespace other than `/`\n // we append it followed by a comma `,`\n if (obj.nsp && \"/\" !== obj.nsp) {\n str += obj.nsp + \",\";\n }\n // immediately followed by the id\n if (null != obj.id) {\n str += obj.id;\n }\n // json data\n if (null != obj.data) {\n str += JSON.stringify(obj.data);\n }\n return str;\n }\n /**\n * Encode packet as 'buffer sequence' by removing blobs, and\n * deconstructing packet into object with placeholders and\n * a list of buffers.\n */\n encodeAsBinary(obj) {\n const deconstruction = deconstructPacket(obj);\n const pack = this.encodeAsString(deconstruction.packet);\n const buffers = deconstruction.buffers;\n buffers.unshift(pack); // add packet info to beginning of data list\n return buffers; // write all the buffers\n }\n}\n/**\n * A socket.io Decoder instance\n *\n * @return {Object} decoder\n */\nexport class Decoder extends Emitter {\n constructor() {\n super();\n }\n /**\n * Decodes an encoded packet string into packet JSON.\n *\n * @param {String} obj - encoded packet\n */\n add(obj) {\n let packet;\n if (typeof obj === \"string\") {\n packet = this.decodeString(obj);\n if (packet.type === PacketType.BINARY_EVENT ||\n packet.type === PacketType.BINARY_ACK) {\n // binary packet's json\n this.reconstructor = new BinaryReconstructor(packet);\n // no attachments, labeled binary but no binary data to follow\n if (packet.attachments === 0) {\n super.emitReserved(\"decoded\", packet);\n }\n }\n else {\n // non-binary full packet\n super.emitReserved(\"decoded\", packet);\n }\n }\n else if (isBinary(obj) || obj.base64) {\n // raw binary data\n if (!this.reconstructor) {\n throw new Error(\"got binary data when not reconstructing a packet\");\n }\n else {\n packet = this.reconstructor.takeBinaryData(obj);\n if (packet) {\n // received final buffer\n this.reconstructor = null;\n super.emitReserved(\"decoded\", packet);\n }\n }\n }\n else {\n throw new Error(\"Unknown type: \" + obj);\n }\n }\n /**\n * Decode a packet String (JSON data)\n *\n * @param {String} str\n * @return {Object} packet\n */\n decodeString(str) {\n let i = 0;\n // look up type\n const p = {\n type: Number(str.charAt(0)),\n };\n if (PacketType[p.type] === undefined) {\n throw new Error(\"unknown packet type \" + p.type);\n }\n // look up attachments if type binary\n if (p.type === PacketType.BINARY_EVENT ||\n p.type === PacketType.BINARY_ACK) {\n const start = i + 1;\n while (str.charAt(++i) !== \"-\" && i != str.length) { }\n const buf = str.substring(start, i);\n if (buf != Number(buf) || str.charAt(i) !== \"-\") {\n throw new Error(\"Illegal attachments\");\n }\n p.attachments = Number(buf);\n }\n // look up namespace (if any)\n if (\"/\" === str.charAt(i + 1)) {\n const start = i + 1;\n while (++i) {\n const c = str.charAt(i);\n if (\",\" === c)\n break;\n if (i === str.length)\n break;\n }\n p.nsp = str.substring(start, i);\n }\n else {\n p.nsp = \"/\";\n }\n // look up id\n const next = str.charAt(i + 1);\n if (\"\" !== next && Number(next) == next) {\n const start = i + 1;\n while (++i) {\n const c = str.charAt(i);\n if (null == c || Number(c) != c) {\n --i;\n break;\n }\n if (i === str.length)\n break;\n }\n p.id = Number(str.substring(start, i + 1));\n }\n // look up json data\n if (str.charAt(++i)) {\n const payload = tryParse(str.substr(i));\n if (Decoder.isPayloadValid(p.type, payload)) {\n p.data = payload;\n }\n else {\n throw new Error(\"invalid payload\");\n }\n }\n return p;\n }\n static isPayloadValid(type, payload) {\n switch (type) {\n case PacketType.CONNECT:\n return typeof payload === \"object\";\n case PacketType.DISCONNECT:\n return payload === undefined;\n case PacketType.CONNECT_ERROR:\n return typeof payload === \"string\" || typeof payload === \"object\";\n case PacketType.EVENT:\n case PacketType.BINARY_EVENT:\n return Array.isArray(payload) && payload.length > 0;\n case PacketType.ACK:\n case PacketType.BINARY_ACK:\n return Array.isArray(payload);\n }\n }\n /**\n * Deallocates a parser's resources\n */\n destroy() {\n if (this.reconstructor) {\n this.reconstructor.finishedReconstruction();\n }\n }\n}\nfunction tryParse(str) {\n try {\n return JSON.parse(str);\n }\n catch (e) {\n return false;\n }\n}\n/**\n * A manager of a binary event's 'buffer sequence'. Should\n * be constructed whenever a packet of type BINARY_EVENT is\n * decoded.\n *\n * @param {Object} packet\n * @return {BinaryReconstructor} initialized reconstructor\n */\nclass BinaryReconstructor {\n constructor(packet) {\n this.packet = packet;\n this.buffers = [];\n this.reconPack = packet;\n }\n /**\n * Method to be called when binary data received from connection\n * after a BINARY_EVENT packet.\n *\n * @param {Buffer | ArrayBuffer} binData - the raw binary data received\n * @return {null | Object} returns null if more binary data is expected or\n * a reconstructed packet object if all buffers have been received.\n */\n takeBinaryData(binData) {\n this.buffers.push(binData);\n if (this.buffers.length === this.reconPack.attachments) {\n // done with buffer list\n const packet = reconstructPacket(this.reconPack, this.buffers);\n this.finishedReconstruction();\n return packet;\n }\n return null;\n }\n /**\n * Cleans up binary packet reconstruction variables.\n */\n finishedReconstruction() {\n this.reconPack = null;\n this.buffers = [];\n }\n}\n","import { isBinary } from \"./is-binary.js\";\n/**\n * Replaces every Buffer | ArrayBuffer | Blob | File in packet with a numbered placeholder.\n *\n * @param {Object} packet - socket.io event packet\n * @return {Object} with deconstructed packet and list of buffers\n * @public\n */\nexport function deconstructPacket(packet) {\n const buffers = [];\n const packetData = packet.data;\n const pack = packet;\n pack.data = _deconstructPacket(packetData, buffers);\n pack.attachments = buffers.length; // number of binary 'attachments'\n return { packet: pack, buffers: buffers };\n}\nfunction _deconstructPacket(data, buffers) {\n if (!data)\n return data;\n if (isBinary(data)) {\n const placeholder = { _placeholder: true, num: buffers.length };\n buffers.push(data);\n return placeholder;\n }\n else if (Array.isArray(data)) {\n const newData = new Array(data.length);\n for (let i = 0; i < data.length; i++) {\n newData[i] = _deconstructPacket(data[i], buffers);\n }\n return newData;\n }\n else if (typeof data === \"object\" && !(data instanceof Date)) {\n const newData = {};\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n newData[key] = _deconstructPacket(data[key], buffers);\n }\n }\n return newData;\n }\n return data;\n}\n/**\n * Reconstructs a binary packet from its placeholder packet and buffers\n *\n * @param {Object} packet - event packet with placeholders\n * @param {Array} buffers - binary buffers to put in placeholder positions\n * @return {Object} reconstructed packet\n * @public\n */\nexport function reconstructPacket(packet, buffers) {\n packet.data = _reconstructPacket(packet.data, buffers);\n packet.attachments = undefined; // no longer useful\n return packet;\n}\nfunction _reconstructPacket(data, buffers) {\n if (!data)\n return data;\n if (data && data._placeholder) {\n return buffers[data.num]; // appropriate buffer (should be natural order anyway)\n }\n else if (Array.isArray(data)) {\n for (let i = 0; i < data.length; i++) {\n data[i] = _reconstructPacket(data[i], buffers);\n }\n }\n else if (typeof data === \"object\") {\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n data[key] = _reconstructPacket(data[key], buffers);\n }\n }\n }\n return data;\n}\n","const withNativeArrayBuffer = typeof ArrayBuffer === \"function\";\nconst isView = (obj) => {\n return typeof ArrayBuffer.isView === \"function\"\n ? ArrayBuffer.isView(obj)\n : obj.buffer instanceof ArrayBuffer;\n};\nconst toString = Object.prototype.toString;\nconst withNativeBlob = typeof Blob === \"function\" ||\n (typeof Blob !== \"undefined\" &&\n toString.call(Blob) === \"[object BlobConstructor]\");\nconst withNativeFile = typeof File === \"function\" ||\n (typeof File !== \"undefined\" &&\n toString.call(File) === \"[object FileConstructor]\");\n/**\n * Returns true if obj is a Buffer, an ArrayBuffer, a Blob or a File.\n *\n * @private\n */\nexport function isBinary(obj) {\n return ((withNativeArrayBuffer && (obj instanceof ArrayBuffer || isView(obj))) ||\n (withNativeBlob && obj instanceof Blob) ||\n (withNativeFile && obj instanceof File));\n}\nexport function hasBinary(obj, toJSON) {\n if (!obj || typeof obj !== \"object\") {\n return false;\n }\n if (Array.isArray(obj)) {\n for (let i = 0, l = obj.length; i < l; i++) {\n if (hasBinary(obj[i])) {\n return true;\n }\n }\n return false;\n }\n if (isBinary(obj)) {\n return true;\n }\n if (obj.toJSON &&\n typeof obj.toJSON === \"function\" &&\n arguments.length === 1) {\n return hasBinary(obj.toJSON(), true);\n }\n for (const key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key) && hasBinary(obj[key])) {\n return true;\n }\n }\n return false;\n}\n","export function on(obj, ev, fn) {\n obj.on(ev, fn);\n return function subDestroy() {\n obj.off(ev, fn);\n };\n}\n","\n/**\n * Expose `Backoff`.\n */\n\nmodule.exports = Backoff;\n\n/**\n * Initialize backoff timer with `opts`.\n *\n * - `min` initial timeout in milliseconds [100]\n * - `max` max timeout [10000]\n * - `jitter` [0]\n * - `factor` [2]\n *\n * @param {Object} opts\n * @api public\n */\n\nfunction Backoff(opts) {\n opts = opts || {};\n this.ms = opts.min || 100;\n this.max = opts.max || 10000;\n this.factor = opts.factor || 2;\n this.jitter = opts.jitter > 0 && opts.jitter <= 1 ? opts.jitter : 0;\n this.attempts = 0;\n}\n\n/**\n * Return the backoff duration.\n *\n * @return {Number}\n * @api public\n */\n\nBackoff.prototype.duration = function(){\n var ms = this.ms * Math.pow(this.factor, this.attempts++);\n if (this.jitter) {\n var rand = Math.random();\n var deviation = Math.floor(rand * this.jitter * ms);\n ms = (Math.floor(rand * 10) & 1) == 0 ? ms - deviation : ms + deviation;\n }\n return Math.min(ms, this.max) | 0;\n};\n\n/**\n * Reset the number of attempts.\n *\n * @api public\n */\n\nBackoff.prototype.reset = function(){\n this.attempts = 0;\n};\n\n/**\n * Set the minimum duration\n *\n * @api public\n */\n\nBackoff.prototype.setMin = function(min){\n this.ms = min;\n};\n\n/**\n * Set the maximum duration\n *\n * @api public\n */\n\nBackoff.prototype.setMax = function(max){\n this.max = max;\n};\n\n/**\n * Set the jitter\n *\n * @api public\n */\n\nBackoff.prototype.setJitter = function(jitter){\n this.jitter = jitter;\n};\n\n","'use strict'\n\nconst abortable = require('abortable-iterator')\nconst toIterable = require('stream-to-it')\nconst { CLOSE_TIMEOUT } = require('./constants')\nconst toMultiaddr = require('libp2p-utils/src/ip-port-to-multiaddr')\n\nconst debug = require('debug')\nconst log = debug('libp2p:webrtc-star:socket')\nlog.error = debug('libp2p:webrtc-star:socket:error')\n\nconst toWebrtcMultiaddr = (address, port) => {\n if (!address || !port) return undefined\n\n try {\n return toMultiaddr(address, port)\n } catch (err) {\n log.error(err)\n // Account for mdns hostnames, just make it a local ip for now\n return toMultiaddr('0.0.0.0', port)\n }\n}\n\n// Convert a socket into a MultiaddrConnection\n// https://github.com/libp2p/js-libp2p-interfaces/tree/master/src/transport#multiaddrconnection\nmodule.exports = (socket, options = {}) => {\n const { sink, source } = toIterable.duplex(socket)\n\n // If the remote address was passed, use it - it may have the peer ID encapsulated\n const remoteAddr = options.remoteAddr || toWebrtcMultiaddr(socket.remoteAddress, socket.remotePort)\n const localAddr = toWebrtcMultiaddr(socket.localAddress, socket.localPort)\n\n const maConn = {\n async sink (source) {\n if (options.signal) {\n source = abortable(source, options.signal)\n }\n\n try {\n await sink((async function * () {\n for await (const chunk of source) {\n // Convert BufferList to Buffer\n yield chunk instanceof Uint8Array ? chunk : chunk.slice()\n }\n })())\n } catch (err) {\n // If aborted we can safely ignore\n if (err.type !== 'aborted') {\n // If the source errored the socket will already have been destroyed by\n // toIterable.duplex(). If the socket errored it will already be\n // destroyed. There's nothing to do here except log the error & return.\n log.error(err)\n }\n }\n },\n\n source: options.signal ? abortable(source, options.signal) : source,\n\n conn: socket,\n\n localAddr,\n remoteAddr,\n\n timeline: { open: Date.now() },\n\n close () {\n if (socket.destroyed) return\n\n return new Promise((resolve, reject) => {\n const start = Date.now()\n\n // Attempt to end the socket. If it takes longer to close than the\n // timeout, destroy it manually.\n const timeout = setTimeout(() => {\n if (maConn.remoteAddr) {\n const { host, port } = maConn.remoteAddr.toOptions()\n log('timeout closing socket to %s:%s after %dms, destroying it manually',\n host, port, Date.now() - start)\n }\n\n if (!socket.destroyed) {\n socket.destroy()\n }\n }, CLOSE_TIMEOUT)\n\n socket.once('close', () => {\n resolve()\n })\n\n socket.end(err => {\n clearTimeout(timeout)\n\n maConn.timeline.close = Date.now()\n if (err) return reject(err)\n })\n })\n }\n }\n\n socket.once('close', () => {\n // In instances where `close` was not explicitly called,\n // such as an iterable stream ending, ensure we have set the close\n // timeline\n if (!maConn.timeline.close) {\n maConn.timeline.close = Date.now()\n }\n })\n\n return maConn\n}\n","module.exports = require('./source')\nmodule.exports.source = require('./source')\nmodule.exports.sink = require('./sink')\nmodule.exports.transform = require('./transform')\nmodule.exports.duplex = require('./duplex')\n","const getIterator = require('get-iterator')\n\nmodule.exports = writable => async source => {\n source = getIterator(source)\n\n const maybeEndSource = (source) => {\n if (typeof source.return === 'function') source.return()\n }\n\n let error = null\n let errCb = null\n const errorHandler = (err) => {\n error = err\n if (errCb) errCb(err)\n // When the writable errors, try to end the source to exit iteration early\n maybeEndSource(source)\n }\n\n let closeCb = null\n let closed = false\n const closeHandler = () => {\n closed = true\n if (closeCb) closeCb()\n }\n\n let finishCb = null\n let finished = false\n const finishHandler = () => {\n finished = true\n if (finishCb) finishCb()\n }\n\n let drainCb = null\n const drainHandler = () => {\n if (drainCb) drainCb()\n }\n\n const waitForDrainOrClose = () => {\n return new Promise((resolve, reject) => {\n closeCb = drainCb = resolve\n errCb = reject\n writable.once('drain', drainHandler)\n })\n }\n\n const waitForDone = () => {\n // Immediately try to end the source\n maybeEndSource(source)\n return new Promise((resolve, reject) => {\n if (closed || finished || error) return resolve()\n finishCb = closeCb = resolve\n errCb = reject\n })\n }\n\n const cleanup = () => {\n writable.removeListener('error', errorHandler)\n writable.removeListener('close', closeHandler)\n writable.removeListener('finish', finishHandler)\n writable.removeListener('drain', drainHandler)\n }\n\n writable.once('error', errorHandler)\n writable.once('close', closeHandler)\n writable.once('finish', finishHandler)\n\n try {\n for await (const value of source) {\n if (!writable.writable || writable.destroyed || error) break\n\n if (writable.write(value) === false) {\n await waitForDrainOrClose()\n }\n }\n } catch (err) {\n // error is set by stream error handler so only destroy stream if source threw\n if (!error) {\n writable.destroy()\n }\n\n // could we be obscuring an error here?\n error = err\n }\n\n try {\n // We're done writing, end everything (n.b. stream may be destroyed at this point but then this is a no-op)\n if (writable.writable) {\n writable.end()\n }\n\n // Wait until we close or finish. This supports halfClosed streams\n await waitForDone()\n\n // Notify the user an error occurred\n if (error) throw error\n } finally {\n // Clean up listeners\n cleanup()\n }\n}\n","const toDuplex = require('./duplex')\n\nmodule.exports = transform => async function * (source) {\n const duplex = toDuplex(transform)\n // In a transform the sink and source are connected, an error in the sink\n // will be thrown in the source also. Catch the sink error to avoid unhandled\n // rejections and yield from the source.\n let sinkError\n duplex.sink(source).catch(err => { sinkError = err })\n\n yield * duplex.source\n if (sinkError) throw sinkError\n}\n","const toSink = require('./sink')\nconst toSource = require('./source')\n\nmodule.exports = duplex => ({ sink: toSink(duplex), source: toSource(duplex) })\n","'use strict'\n\nconst { Multiaddr } = require('multiaddr')\n\nfunction cleanUrlSIO (ma) {\n const maStrSplit = ma.toString().split('/')\n const tcpProto = ma.protos()[1].name\n const wsProto = ma.protos()[2].name\n const tcpPort = ma.stringTuples()[1][1]\n\n if (tcpProto !== 'tcp' || (wsProto !== 'ws' && wsProto !== 'wss')) {\n throw new Error('invalid multiaddr: ' + ma.toString())\n }\n\n if (!Multiaddr.isName(ma)) {\n return 'http://' + maStrSplit[2] + ':' + maStrSplit[4]\n }\n\n if (wsProto === 'ws') {\n return 'http://' + maStrSplit[2] + (tcpPort === '80' ? '' : ':' + tcpPort)\n }\n\n if (wsProto === 'wss') {\n return 'https://' + maStrSplit[2] + (tcpPort === '443' ? '' : ':' + tcpPort)\n }\n}\n\nfunction cleanMultiaddr (maStr) {\n const legacy = '/libp2p-webrtc-star'\n\n if (maStr.indexOf(legacy) !== -1) {\n maStr = maStr.substring(legacy.length, maStr.length)\n let ma = new Multiaddr(maStr)\n const tuppleIPFS = ma.stringTuples().filter((tupple) => {\n return tupple[0] === 421 // ipfs code\n })[0]\n\n ma = ma.decapsulate('p2p')\n ma = ma.encapsulate('/p2p-webrtc-star')\n ma = ma.encapsulate(`/p2p/${tuppleIPFS[1]}`)\n maStr = ma.toString()\n }\n\n return maStr\n}\n\nmodule.exports = {\n cleanUrlSIO,\n cleanMultiaddr\n}\n","'use strict'\n\nmodule.exports = require('./mplex')\n","'use strict'\n\nconst pipe = require('it-pipe')\nconst pushable = require('it-pushable')\nconst log = require('debug')('libp2p:mplex')\nconst abortable = require('abortable-iterator')\nconst Coder = require('./coder')\nconst restrictSize = require('./restrict-size')\nconst { MessageTypes, MessageTypeNames } = require('./message-types')\nconst createStream = require('./stream')\n\nclass Mplex {\n /**\n * @class\n * @param {object} options\n * @param {function(*)} options.onStream - Called whenever an inbound stream is created\n * @param {function(*)} options.onStreamEnd - Called whenever a stream ends\n * @param {AbortSignal} options.signal - An AbortController signal\n */\n constructor (options) {\n options = options || {}\n options = typeof options === 'function' ? { onStream: options } : options\n\n this._streamId = 0\n this._streams = {\n /**\n * @type {Map<number, *>} Stream to ids map\n */\n initiators: new Map(),\n /**\n * @type {Map<number, *>} Stream to ids map\n */\n receivers: new Map()\n }\n this._options = options\n\n /**\n * An iterable sink\n */\n this.sink = this._createSink()\n\n /**\n * An iterable source\n */\n this.source = this._createSource()\n\n /**\n * @property {Function} onStream\n */\n this.onStream = options.onStream\n\n /**\n * @property {Function} onStreamEnd\n */\n this.onStreamEnd = options.onStreamEnd\n }\n\n /**\n * Returns a Map of streams and their ids\n *\n * @returns {Map<number,*>}\n */\n get streams () {\n // Inbound and Outbound streams may have the same ids, so we need to make those unique\n const streams = []\n this._streams.initiators.forEach(stream => {\n streams.push(stream)\n })\n this._streams.receivers.forEach(stream => {\n streams.push(stream)\n })\n return streams\n }\n\n /**\n * Initiate a new stream with the given name. If no name is\n * provided, the id of th stream will be used.\n *\n * @param {string} [name] - If name is not a string it will be cast to one\n * @returns {Stream}\n */\n newStream (name) {\n const id = this._streamId++\n name = name == null ? id.toString() : String(name)\n const registry = this._streams.initiators\n return this._newStream({ id, name, type: 'initiator', registry })\n }\n\n /**\n * Called whenever an inbound stream is created\n *\n * @private\n * @param {*} options\n * @param {number} options.id\n * @param {string} options.name\n * @returns {*} A muxed stream\n */\n _newReceiverStream ({ id, name }) {\n const registry = this._streams.receivers\n return this._newStream({ id, name, type: 'receiver', registry })\n }\n\n /**\n * Creates a new stream\n *\n * @private\n * @param {object} options\n * @param {number} options.id\n * @param {string} options.name\n * @param {string} options.type\n * @param {Map<number, *>} options.registry - A map of streams to their ids\n * @returns {*} A muxed stream\n */\n _newStream ({ id, name, type, registry }) {\n if (registry.has(id)) {\n throw new Error(`${type} stream ${id} already exists!`)\n }\n log('new %s stream %s %s', type, id, name)\n const send = msg => {\n if (log.enabled) {\n log('%s stream %s %s send', type, id, name, { ...msg, type: MessageTypeNames[msg.type], data: msg.data && msg.data.slice() })\n }\n return this.source.push(msg)\n }\n const onEnd = () => {\n log('%s stream %s %s ended', type, id, name)\n registry.delete(id)\n this.onStreamEnd && this.onStreamEnd(stream)\n }\n const stream = createStream({ id, name, send, type, onEnd, maxMsgSize: this._options.maxMsgSize })\n registry.set(id, stream)\n return stream\n }\n\n /**\n * Creates a sink with an abortable source. Incoming messages will\n * also have their size restricted. All messages will be varint decoded.\n *\n * @private\n * @returns {*} Returns an iterable sink\n */\n _createSink () {\n return async source => {\n if (this._options.signal) {\n source = abortable(source, this._options.signal)\n }\n\n try {\n await pipe(\n source,\n Coder.decode,\n restrictSize(this._options.maxMsgSize),\n async source => {\n for await (const msgs of source) {\n for (const msg of msgs) {\n this._handleIncoming(msg)\n }\n }\n }\n )\n } catch (err) {\n log('error in sink', err)\n return this.source.end(err) // End the source with an error\n }\n\n this.source.end()\n }\n }\n\n /**\n * Creates a source that restricts outgoing message sizes\n * and varint encodes them.\n *\n * @private\n * @returns {*} An iterable source\n */\n _createSource () {\n const onEnd = err => {\n const { initiators, receivers } = this._streams\n // Abort all the things!\n for (const s of initiators.values()) s.abort(err)\n for (const s of receivers.values()) s.abort(err)\n }\n const source = pushable({ onEnd, writev: true })\n return Object.assign(Coder.encode(source), {\n push: source.push,\n end: source.end,\n return: source.return\n })\n }\n\n /**\n * @private\n * @param {object} options\n * @param {number} options.id\n * @param {string} options.type\n * @param {Uint8Array|BufferList} options.data\n * @returns {void}\n */\n _handleIncoming ({ id, type, data }) {\n if (log.enabled) {\n log('incoming message', { id, type: MessageTypeNames[type], data: data.slice() })\n }\n\n // Create a new stream?\n if (type === MessageTypes.NEW_STREAM && this.onStream) {\n const stream = this._newReceiverStream({ id, name: data.toString() })\n return this.onStream(stream)\n }\n\n const list = type & 1 ? this._streams.initiators : this._streams.receivers\n const stream = list.get(id)\n\n if (!stream) return log('missing stream %s', id)\n\n switch (type) {\n case MessageTypes.MESSAGE_INITIATOR:\n case MessageTypes.MESSAGE_RECEIVER:\n stream.source.push(data)\n break\n case MessageTypes.CLOSE_INITIATOR:\n case MessageTypes.CLOSE_RECEIVER:\n stream.close()\n break\n case MessageTypes.RESET_INITIATOR:\n case MessageTypes.RESET_RECEIVER:\n stream.reset()\n break\n default:\n log('unknown message type %s', type)\n }\n }\n}\n\nMplex.multicodec = '/mplex/6.7.0'\n\nmodule.exports = Mplex\n","'use strict'\n\nexports.encode = require('./encode')\nexports.decode = require('./decode')\n","'use strict'\n\nconst varint = require('varint')\nconst BufferList = require('bl/BufferList')\n\nconst POOL_SIZE = 10 * 1024\n\nclass Encoder {\n constructor () {\n this._pool = new Uint8Array(POOL_SIZE)\n this._poolOffset = 0\n }\n\n /**\n * Encodes the given message and returns it and its header\n *\n * @param {*} msg - The message object to encode\n * @returns {Uint8Array|Uint8Array[]}\n */\n write (msg) {\n const pool = this._pool\n let offset = this._poolOffset\n\n varint.encode(msg.id << 3 | msg.type, pool, offset)\n offset += varint.encode.bytes\n varint.encode(msg.data ? msg.data.length : 0, pool, offset)\n offset += varint.encode.bytes\n\n const header = pool.subarray(this._poolOffset, offset)\n\n if (POOL_SIZE - offset < 100) {\n this._pool = new Uint8Array(POOL_SIZE)\n this._poolOffset = 0\n } else {\n this._poolOffset = offset\n }\n\n if (!msg.data) return header\n\n return [header, msg.data]\n }\n}\n\nconst encoder = new Encoder()\n\n// Encode one or more messages and yield a BufferList of encoded messages\nmodule.exports = source => (async function * encode () {\n for await (const msg of source) {\n if (Array.isArray(msg)) {\n yield new BufferList(msg.map(m => encoder.write(m)))\n } else {\n yield new BufferList(encoder.write(msg))\n }\n }\n})()\n","'use strict'\n\nconst varint = require('varint')\nconst BufferList = require('bl/BufferList')\n\n// Decode a chunk and yield an _array_ of decoded messages\nmodule.exports = source => (async function * decode () {\n const decoder = new Decoder()\n for await (const chunk of source) {\n const msgs = decoder.write(chunk)\n if (msgs.length) yield msgs\n }\n})()\n\nclass Decoder {\n constructor () {\n this._buffer = new BufferList()\n // optimization to allow varint to take a BufferList (well a proxy to)\n this._bufferProxy = new Proxy({}, {\n get: (_, prop) => prop[0] === 'l' ? this._buffer[prop] : this._buffer.get(parseInt(prop))\n })\n this._headerInfo = null\n }\n\n /**\n * @param {Uint8Array|BufferList} chunk\n * @returns {object[]} An array of message objects\n */\n write (chunk) {\n if (!chunk || !chunk.length) return []\n\n this._buffer.append(chunk)\n const msgs = []\n\n while (true) {\n if (!this._headerInfo) {\n try {\n this._headerInfo = this._decodeHeader(this._bufferProxy)\n } catch (_) {\n break // We haven't received enough data yet\n }\n }\n\n const { id, type, length, offset } = this._headerInfo\n const bufferedDataLength = this._buffer.length - offset\n\n if (bufferedDataLength < length) break // not enough data yet\n\n msgs.push({ id, type, data: this._buffer.shallowSlice(offset, offset + length) })\n\n this._buffer.consume(offset + length)\n this._headerInfo = null\n }\n\n return msgs\n }\n\n /**\n * Attempts to decode the message header from the buffer\n *\n * @private\n * @param {Uint8Array} data\n * @returns {*} message header (id, type, offset, length)\n */\n _decodeHeader (data) {\n const h = varint.decode(data)\n let offset = varint.decode.bytes\n const length = varint.decode(data, offset)\n offset += varint.decode.bytes\n return { id: h >> 3, type: h & 7, offset, length }\n }\n}\n","'use strict'\n\nconst MAX_MSG_SIZE = 1 << 20 // 1MB\n\n/**\n * Creates an iterable transform that restricts message sizes to\n * the given maximum size.\n *\n * @param {number} [max] - The maximum message size. Defaults to 1MB\n * @returns {*} An iterable transform.\n */\nmodule.exports = max => {\n max = max || MAX_MSG_SIZE\n\n const checkSize = msg => {\n if (msg.data && msg.data.length > max) {\n throw Object.assign(new Error('message size too large!'), { code: 'ERR_MSG_TOO_BIG' })\n }\n }\n\n return source => {\n return (async function * restrictSize () {\n for await (const msg of source) {\n if (Array.isArray(msg)) {\n msg.forEach(checkSize)\n } else {\n checkSize(msg)\n }\n yield msg\n }\n })()\n }\n}\n\nmodule.exports.MAX_MSG_SIZE = MAX_MSG_SIZE\n","'use strict'\n\nconst MessageTypes = Object.freeze({\n NEW_STREAM: 0,\n MESSAGE_RECEIVER: 1,\n MESSAGE_INITIATOR: 2,\n CLOSE_RECEIVER: 3,\n CLOSE_INITIATOR: 4,\n RESET_RECEIVER: 5,\n RESET_INITIATOR: 6\n})\n\nexports.MessageTypes = MessageTypes\n\nexports.InitiatorMessageTypes = Object.freeze({\n NEW_STREAM: MessageTypes.NEW_STREAM,\n MESSAGE: MessageTypes.MESSAGE_INITIATOR,\n CLOSE: MessageTypes.CLOSE_INITIATOR,\n RESET: MessageTypes.RESET_INITIATOR\n})\n\nexports.ReceiverMessageTypes = Object.freeze({\n MESSAGE: MessageTypes.MESSAGE_RECEIVER,\n CLOSE: MessageTypes.CLOSE_RECEIVER,\n RESET: MessageTypes.RESET_RECEIVER\n})\n\nexports.MessageTypeNames = Object.freeze(\n Object.entries(MessageTypes).reduce((obj, e) => {\n obj[e[1]] = e[0]\n return obj\n }, {})\n)\n","'use strict'\n\nconst abortable = require('abortable-iterator')\nconst AbortController = require('abort-controller')\nconst log = require('debug')('libp2p:mplex:stream')\nconst pushable = require('it-pushable')\nconst BufferList = require('bl/BufferList')\nconst errCode = require('err-code')\nconst { MAX_MSG_SIZE } = require('./restrict-size')\nconst { InitiatorMessageTypes, ReceiverMessageTypes } = require('./message-types')\n\nconst ERR_MPLEX_STREAM_RESET = 'ERR_MPLEX_STREAM_RESET'\nconst ERR_MPLEX_STREAM_ABORT = 'ERR_MPLEX_STREAM_ABORT'\n\n/**\n * @param {object} options\n * @param {number} options.id\n * @param {string} options.name\n * @param {function(*)} options.send - Called to send data through the stream\n * @param {function(Error)} [options.onEnd] - Called whenever the stream ends\n * @param {string} [options.type] - One of ['initiator','receiver']. Defaults to 'initiator'\n * @param {number} [options.maxMsgSize] - Max size of an mplex message in bytes. Writes > size are automatically split. Defaults to 1MB\n * @returns {*} A muxed stream\n */\nmodule.exports = ({ id, name, send, onEnd = () => {}, type = 'initiator', maxMsgSize = MAX_MSG_SIZE }) => {\n const abortController = new AbortController()\n const resetController = new AbortController()\n const Types = type === 'initiator' ? InitiatorMessageTypes : ReceiverMessageTypes\n const externalId = type === 'initiator' ? (`i${id}`) : `r${id}`\n\n name = String(name == null ? id : name)\n\n let sourceEnded = false\n let sinkEnded = false\n let endErr\n\n const onSourceEnd = err => {\n if (sourceEnded) return\n sourceEnded = true\n log('%s stream %s source end', type, name, err)\n if (err && !endErr) endErr = err\n if (sinkEnded) {\n stream.timeline.close = Date.now()\n onEnd(endErr)\n }\n }\n\n const onSinkEnd = err => {\n if (sinkEnded) return\n sinkEnded = true\n log('%s stream %s sink end', type, name, err)\n if (err && !endErr) endErr = err\n if (sourceEnded) {\n stream.timeline.close = Date.now()\n onEnd(endErr)\n }\n }\n\n const stream = {\n // Close for reading\n close: () => stream.source.end(),\n // Close for reading and writing (local error)\n abort: err => {\n log('%s stream %s abort', type, name, err)\n // End the source with the passed error\n stream.source.end(err)\n abortController.abort()\n onSinkEnd(err)\n },\n // Close immediately for reading and writing (remote error)\n reset: () => {\n const err = errCode(new Error('stream reset'), ERR_MPLEX_STREAM_RESET)\n resetController.abort()\n stream.source.end(err)\n onSinkEnd(err)\n },\n sink: async source => {\n source = abortable(source, [\n { signal: abortController.signal, options: { abortMessage: 'stream aborted', abortCode: ERR_MPLEX_STREAM_ABORT } },\n { signal: resetController.signal, options: { abortMessage: 'stream reset', abortCode: ERR_MPLEX_STREAM_RESET } }\n ])\n\n if (type === 'initiator') { // If initiator, open a new stream\n send({ id, type: Types.NEW_STREAM, data: name })\n }\n\n try {\n for await (let data of source) {\n while (data.length) {\n if (data.length <= maxMsgSize) {\n send({ id, type: Types.MESSAGE, data })\n break\n }\n data = BufferList.isBufferList(data) ? data : new BufferList(data)\n send({ id, type: Types.MESSAGE, data: data.shallowSlice(0, maxMsgSize) })\n data.consume(maxMsgSize)\n }\n }\n } catch (err) {\n // Send no more data if this stream was remotely reset\n if (err.code === ERR_MPLEX_STREAM_RESET) {\n log('%s stream %s reset', type, name)\n } else {\n log('%s stream %s error', type, name, err)\n send({ id, type: Types.RESET })\n }\n\n stream.source.end(err)\n return onSinkEnd(err)\n }\n\n send({ id, type: Types.CLOSE })\n onSinkEnd()\n },\n source: pushable(onSourceEnd),\n timeline: {\n open: Date.now(),\n close: null\n },\n id: externalId\n }\n\n return stream\n}\n","import { Noise } from './noise'\nexport * from './noise'\n\n/**\n * Default configuration, it will generate new noise static key and enable noise pipes (IK handshake).\n */\nexport const NOISE = new Noise()\n","import * as x25519 from '@stablelib/x25519'\nimport { Buffer } from 'buffer'\nimport Wrap from 'it-pb-rpc'\nimport DuplexPair from 'it-pair/duplex'\nimport ensureBuffer from 'it-buffer'\nimport pipe from 'it-pipe'\nimport { encode, decode } from 'it-length-prefixed'\n\nimport { XXHandshake } from './handshake-xx'\nimport { IKHandshake } from './handshake-ik'\nimport { XXFallbackHandshake } from './handshake-xx-fallback'\nimport { generateKeypair, getPayload } from './utils'\nimport { uint16BEDecode, uint16BEEncode } from './encoder'\nimport { decryptStream, encryptStream } from './crypto'\nimport { bytes } from './@types/basic'\nimport { INoiseConnection, KeyPair, SecureOutbound } from './@types/libp2p'\nimport { Duplex } from 'it-pair'\nimport { IHandshake } from './@types/handshake-interface'\nimport { KeyCache } from './keycache'\nimport { logger } from './logger'\nimport PeerId from 'peer-id'\nimport { NOISE_MSG_MAX_LENGTH_BYTES } from './constants'\n\nexport type WrappedConnection = ReturnType<typeof Wrap>\n\ninterface HandshakeParams {\n connection: WrappedConnection\n isInitiator: boolean\n localPeer: PeerId\n remotePeer?: PeerId\n}\n\nexport class Noise implements INoiseConnection {\n public protocol = '/noise'\n\n private readonly prologue = Buffer.alloc(0)\n private readonly staticKeys: KeyPair\n private readonly earlyData?: bytes\n private readonly useNoisePipes: boolean\n\n /**\n *\n * @param {bytes} staticNoiseKey - x25519 private key, reuse for faster handshakes\n * @param {bytes} earlyData\n */\n constructor (staticNoiseKey?: bytes, earlyData?: bytes) {\n this.earlyData = earlyData ?? Buffer.alloc(0)\n // disabled until properly specked\n this.useNoisePipes = false\n\n if (staticNoiseKey) {\n // accepts x25519 private key of length 32\n const keyPair = x25519.generateKeyPairFromSeed(staticNoiseKey)\n this.staticKeys = {\n privateKey: Buffer.from(\n keyPair.secretKey.buffer,\n keyPair.secretKey.byteOffset,\n keyPair.secretKey.length\n ),\n publicKey: Buffer.from(\n keyPair.publicKey.buffer,\n keyPair.publicKey.byteOffset,\n keyPair.publicKey.length\n )\n }\n } else {\n this.staticKeys = generateKeypair()\n }\n }\n\n /**\n * Encrypt outgoing data to the remote party (handshake as initiator)\n *\n * @param {PeerId} localPeer - PeerId of the receiving peer\n * @param {any} connection - streaming iterable duplex that will be encrypted\n * @param {PeerId} remotePeer - PeerId of the remote peer. Used to validate the integrity of the remote peer.\n * @returns {Promise<SecureOutbound>}\n */\n public async secureOutbound (localPeer: PeerId, connection: any, remotePeer: PeerId): Promise<SecureOutbound> {\n const wrappedConnection = Wrap(\n connection,\n {\n lengthEncoder: uint16BEEncode,\n lengthDecoder: uint16BEDecode,\n maxDataLength: NOISE_MSG_MAX_LENGTH_BYTES\n }\n )\n const handshake = await this.performHandshake({\n connection: wrappedConnection,\n isInitiator: true,\n localPeer,\n remotePeer\n })\n const conn = await this.createSecureConnection(wrappedConnection, handshake)\n\n return {\n conn,\n remoteEarlyData: handshake.remoteEarlyData,\n remotePeer: handshake.remotePeer\n }\n }\n\n /**\n * Decrypt incoming data (handshake as responder).\n *\n * @param {PeerId} localPeer - PeerId of the receiving peer.\n * @param {any} connection - streaming iterable duplex that will be encryption.\n * @param {PeerId} remotePeer - optional PeerId of the initiating peer, if known. This may only exist during transport upgrades.\n * @returns {Promise<SecureOutbound>}\n */\n public async secureInbound (localPeer: PeerId, connection: any, remotePeer?: PeerId): Promise<SecureOutbound> {\n const wrappedConnection = Wrap(\n connection,\n {\n lengthEncoder: uint16BEEncode,\n lengthDecoder: uint16BEDecode,\n maxDataLength: NOISE_MSG_MAX_LENGTH_BYTES\n }\n )\n const handshake = await this.performHandshake({\n connection: wrappedConnection,\n isInitiator: false,\n localPeer,\n remotePeer\n })\n const conn = await this.createSecureConnection(wrappedConnection, handshake)\n\n return {\n conn,\n remoteEarlyData: handshake.remoteEarlyData,\n remotePeer: handshake.remotePeer\n }\n }\n\n /**\n * If Noise pipes supported, tries IK handshake first with XX as fallback if it fails.\n * If noise pipes disabled or remote peer static key is unknown, use XX.\n *\n * @param {HandshakeParams} params\n */\n private async performHandshake (params: HandshakeParams): Promise<IHandshake> {\n const payload = await getPayload(params.localPeer, this.staticKeys.publicKey, this.earlyData)\n let tryIK = this.useNoisePipes\n if (params.isInitiator && KeyCache.load(params.remotePeer) === null) {\n // if we are initiator and remote static key is unknown, don't try IK\n tryIK = false\n }\n // Try IK if acting as responder or initiator that has remote's static key.\n if (tryIK) {\n // Try IK first\n const { remotePeer, connection, isInitiator } = params\n const ikHandshake = new IKHandshake(\n isInitiator,\n payload,\n this.prologue,\n this.staticKeys,\n connection,\n // safe to cast as we did checks\n KeyCache.load(params.remotePeer) ?? Buffer.alloc(32),\n remotePeer as PeerId\n )\n\n try {\n return await this.performIKHandshake(ikHandshake)\n } catch (e) {\n // IK failed, go to XX fallback\n let ephemeralKeys\n if (params.isInitiator) {\n ephemeralKeys = ikHandshake.getLocalEphemeralKeys()\n }\n return await this.performXXFallbackHandshake(params, payload, e.initialMsg, ephemeralKeys)\n }\n } else {\n // run XX handshake\n return await this.performXXHandshake(params, payload)\n }\n }\n\n private async performXXFallbackHandshake (\n params: HandshakeParams,\n payload: bytes,\n initialMsg: bytes,\n ephemeralKeys?: KeyPair\n ): Promise<XXFallbackHandshake> {\n const { isInitiator, remotePeer, connection } = params\n const handshake =\n new XXFallbackHandshake(isInitiator, payload, this.prologue, this.staticKeys, connection, initialMsg, remotePeer, ephemeralKeys)\n\n try {\n await handshake.propose()\n await handshake.exchange()\n await handshake.finish()\n } catch (e) {\n logger(e)\n const err = e as Error\n throw new Error(`Error occurred during XX Fallback handshake: ${err.message}`)\n }\n\n return handshake\n }\n\n private async performXXHandshake (\n params: HandshakeParams,\n payload: bytes\n ): Promise<XXHandshake> {\n const { isInitiator, remotePeer, connection } = params\n const handshake = new XXHandshake(isInitiator, payload, this.prologue, this.staticKeys, connection, remotePeer)\n\n try {\n await handshake.propose()\n await handshake.exchange()\n await handshake.finish()\n\n if (this.useNoisePipes && handshake.remotePeer) {\n KeyCache.store(handshake.remotePeer, handshake.getRemoteStaticKey())\n }\n } catch (e) {\n const err = e as Error\n throw new Error(`Error occurred during XX handshake: ${err.message}`)\n }\n\n return handshake\n }\n\n private async performIKHandshake (\n handshake: IKHandshake\n ): Promise<IKHandshake> {\n await handshake.stage0()\n await handshake.stage1()\n\n return handshake\n }\n\n private async createSecureConnection (\n connection: WrappedConnection,\n handshake: IHandshake\n ): Promise<Duplex> {\n // Create encryption box/unbox wrapper\n const [secure, user] = DuplexPair()\n const network = connection.unwrap()\n\n await pipe(\n secure, // write to wrapper\n ensureBuffer, // ensure any type of data is converted to buffer\n encryptStream(handshake), // data is encrypted\n encode({ lengthEncoder: uint16BEEncode }), // prefix with message length\n network, // send to the remote peer\n decode({ lengthDecoder: uint16BEDecode }), // read message length prefix\n ensureBuffer, // ensure any type of data is converted to buffer\n decryptStream(handshake), // decrypt the incoming data\n secure // pipe to the wrapper\n )\n\n return user\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package x25519 implements X25519 key agreement.\n */\n\nimport { randomBytes, RandomSource } from \"@stablelib/random\";\nimport { wipe } from \"@stablelib/wipe\";\n\nexport const PUBLIC_KEY_LENGTH = 32;\nexport const SECRET_KEY_LENGTH = 32;\nexport const SHARED_KEY_LENGTH = 32;\n\n// TODO(dchest): some functions are copies of ../sign/ed25519.\n// Find a way to combine them without opening up to public.\n\n// Ported from TweetNaCl.js, which is ported from TweetNaCl\n// by Dmitry Chestnykh and Devi Mandiri.\n// Public domain.\n// https://tweetnacl.js.org\n\n// TweetNaCl contributors:\n// Daniel J. Bernstein, Bernard van Gastel, Wesley Janssen,\n// Tanja Lange, Peter Schwabe, Sjaak Smetsers.\n// Public domain.\n// https://tweetnacl.cr.yp.to/\n\ntype GF = Float64Array;\n\n// Returns new zero-filled 16-element GF (Float64Array).\n// If passed an array of numbers, prefills the returned\n// array with them.\n//\n// We use Float64Array, because we need 48-bit numbers\n// for this implementation.\nfunction gf(init?: number[]): GF {\n const r = new Float64Array(16);\n if (init) {\n for (let i = 0; i < init.length; i++) {\n r[i] = init[i];\n }\n }\n return r;\n}\n\n// Base point.\nconst _9 = new Uint8Array(32); _9[0] = 9;\n\nconst _121665 = gf([0xdb41, 1]);\n\nfunction car25519(o: GF) {\n let c = 1;\n for (let i = 0; i < 16; i++) {\n let v = o[i] + c + 65535;\n c = Math.floor(v / 65536);\n o[i] = v - c * 65536;\n }\n o[0] += c - 1 + 37 * (c - 1);\n}\n\nfunction sel25519(p: GF, q: GF, b: number) {\n const c = ~(b - 1);\n for (let i = 0; i < 16; i++) {\n const t = c & (p[i] ^ q[i]);\n p[i] ^= t;\n q[i] ^= t;\n }\n}\n\nfunction pack25519(o: Uint8Array, n: GF) {\n const m = gf();\n const t = gf();\n for (let i = 0; i < 16; i++) {\n t[i] = n[i];\n }\n car25519(t);\n car25519(t);\n car25519(t);\n for (let j = 0; j < 2; j++) {\n m[0] = t[0] - 0xffed;\n for (let i = 1; i < 15; i++) {\n m[i] = t[i] - 0xffff - ((m[i - 1] >> 16) & 1);\n m[i - 1] &= 0xffff;\n }\n m[15] = t[15] - 0x7fff - ((m[14] >> 16) & 1);\n const b = (m[15] >> 16) & 1;\n m[14] &= 0xffff;\n sel25519(t, m, 1 - b);\n }\n for (let i = 0; i < 16; i++) {\n o[2 * i] = t[i] & 0xff;\n o[2 * i + 1] = t[i] >> 8;\n }\n}\n\nfunction unpack25519(o: GF, n: Uint8Array) {\n for (let i = 0; i < 16; i++) {\n o[i] = n[2 * i] + (n[2 * i + 1] << 8);\n }\n o[15] &= 0x7fff;\n}\n\nfunction add(o: GF, a: GF, b: GF) {\n for (let i = 0; i < 16; i++) {\n o[i] = a[i] + b[i];\n }\n}\n\nfunction sub(o: GF, a: GF, b: GF) {\n for (let i = 0; i < 16; i++) {\n o[i] = a[i] - b[i];\n }\n}\n\nfunction mul(o: GF, a: GF, b: GF) {\n let v: number, c: number,\n t0 = 0, t1 = 0, t2 = 0, t3 = 0, t4 = 0, t5 = 0, t6 = 0, t7 = 0,\n t8 = 0, t9 = 0, t10 = 0, t11 = 0, t12 = 0, t13 = 0, t14 = 0, t15 = 0,\n t16 = 0, t17 = 0, t18 = 0, t19 = 0, t20 = 0, t21 = 0, t22 = 0, t23 = 0,\n t24 = 0, t25 = 0, t26 = 0, t27 = 0, t28 = 0, t29 = 0, t30 = 0,\n b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11],\n b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n\n v = a[0];\n t0 += v * b0;\n t1 += v * b1;\n t2 += v * b2;\n t3 += v * b3;\n t4 += v * b4;\n t5 += v * b5;\n t6 += v * b6;\n t7 += v * b7;\n t8 += v * b8;\n t9 += v * b9;\n t10 += v * b10;\n t11 += v * b11;\n t12 += v * b12;\n t13 += v * b13;\n t14 += v * b14;\n t15 += v * b15;\n v = a[1];\n t1 += v * b0;\n t2 += v * b1;\n t3 += v * b2;\n t4 += v * b3;\n t5 += v * b4;\n t6 += v * b5;\n t7 += v * b6;\n t8 += v * b7;\n t9 += v * b8;\n t10 += v * b9;\n t11 += v * b10;\n t12 += v * b11;\n t13 += v * b12;\n t14 += v * b13;\n t15 += v * b14;\n t16 += v * b15;\n v = a[2];\n t2 += v * b0;\n t3 += v * b1;\n t4 += v * b2;\n t5 += v * b3;\n t6 += v * b4;\n t7 += v * b5;\n t8 += v * b6;\n t9 += v * b7;\n t10 += v * b8;\n t11 += v * b9;\n t12 += v * b10;\n t13 += v * b11;\n t14 += v * b12;\n t15 += v * b13;\n t16 += v * b14;\n t17 += v * b15;\n v = a[3];\n t3 += v * b0;\n t4 += v * b1;\n t5 += v * b2;\n t6 += v * b3;\n t7 += v * b4;\n t8 += v * b5;\n t9 += v * b6;\n t10 += v * b7;\n t11 += v * b8;\n t12 += v * b9;\n t13 += v * b10;\n t14 += v * b11;\n t15 += v * b12;\n t16 += v * b13;\n t17 += v * b14;\n t18 += v * b15;\n v = a[4];\n t4 += v * b0;\n t5 += v * b1;\n t6 += v * b2;\n t7 += v * b3;\n t8 += v * b4;\n t9 += v * b5;\n t10 += v * b6;\n t11 += v * b7;\n t12 += v * b8;\n t13 += v * b9;\n t14 += v * b10;\n t15 += v * b11;\n t16 += v * b12;\n t17 += v * b13;\n t18 += v * b14;\n t19 += v * b15;\n v = a[5];\n t5 += v * b0;\n t6 += v * b1;\n t7 += v * b2;\n t8 += v * b3;\n t9 += v * b4;\n t10 += v * b5;\n t11 += v * b6;\n t12 += v * b7;\n t13 += v * b8;\n t14 += v * b9;\n t15 += v * b10;\n t16 += v * b11;\n t17 += v * b12;\n t18 += v * b13;\n t19 += v * b14;\n t20 += v * b15;\n v = a[6];\n t6 += v * b0;\n t7 += v * b1;\n t8 += v * b2;\n t9 += v * b3;\n t10 += v * b4;\n t11 += v * b5;\n t12 += v * b6;\n t13 += v * b7;\n t14 += v * b8;\n t15 += v * b9;\n t16 += v * b10;\n t17 += v * b11;\n t18 += v * b12;\n t19 += v * b13;\n t20 += v * b14;\n t21 += v * b15;\n v = a[7];\n t7 += v * b0;\n t8 += v * b1;\n t9 += v * b2;\n t10 += v * b3;\n t11 += v * b4;\n t12 += v * b5;\n t13 += v * b6;\n t14 += v * b7;\n t15 += v * b8;\n t16 += v * b9;\n t17 += v * b10;\n t18 += v * b11;\n t19 += v * b12;\n t20 += v * b13;\n t21 += v * b14;\n t22 += v * b15;\n v = a[8];\n t8 += v * b0;\n t9 += v * b1;\n t10 += v * b2;\n t11 += v * b3;\n t12 += v * b4;\n t13 += v * b5;\n t14 += v * b6;\n t15 += v * b7;\n t16 += v * b8;\n t17 += v * b9;\n t18 += v * b10;\n t19 += v * b11;\n t20 += v * b12;\n t21 += v * b13;\n t22 += v * b14;\n t23 += v * b15;\n v = a[9];\n t9 += v * b0;\n t10 += v * b1;\n t11 += v * b2;\n t12 += v * b3;\n t13 += v * b4;\n t14 += v * b5;\n t15 += v * b6;\n t16 += v * b7;\n t17 += v * b8;\n t18 += v * b9;\n t19 += v * b10;\n t20 += v * b11;\n t21 += v * b12;\n t22 += v * b13;\n t23 += v * b14;\n t24 += v * b15;\n v = a[10];\n t10 += v * b0;\n t11 += v * b1;\n t12 += v * b2;\n t13 += v * b3;\n t14 += v * b4;\n t15 += v * b5;\n t16 += v * b6;\n t17 += v * b7;\n t18 += v * b8;\n t19 += v * b9;\n t20 += v * b10;\n t21 += v * b11;\n t22 += v * b12;\n t23 += v * b13;\n t24 += v * b14;\n t25 += v * b15;\n v = a[11];\n t11 += v * b0;\n t12 += v * b1;\n t13 += v * b2;\n t14 += v * b3;\n t15 += v * b4;\n t16 += v * b5;\n t17 += v * b6;\n t18 += v * b7;\n t19 += v * b8;\n t20 += v * b9;\n t21 += v * b10;\n t22 += v * b11;\n t23 += v * b12;\n t24 += v * b13;\n t25 += v * b14;\n t26 += v * b15;\n v = a[12];\n t12 += v * b0;\n t13 += v * b1;\n t14 += v * b2;\n t15 += v * b3;\n t16 += v * b4;\n t17 += v * b5;\n t18 += v * b6;\n t19 += v * b7;\n t20 += v * b8;\n t21 += v * b9;\n t22 += v * b10;\n t23 += v * b11;\n t24 += v * b12;\n t25 += v * b13;\n t26 += v * b14;\n t27 += v * b15;\n v = a[13];\n t13 += v * b0;\n t14 += v * b1;\n t15 += v * b2;\n t16 += v * b3;\n t17 += v * b4;\n t18 += v * b5;\n t19 += v * b6;\n t20 += v * b7;\n t21 += v * b8;\n t22 += v * b9;\n t23 += v * b10;\n t24 += v * b11;\n t25 += v * b12;\n t26 += v * b13;\n t27 += v * b14;\n t28 += v * b15;\n v = a[14];\n t14 += v * b0;\n t15 += v * b1;\n t16 += v * b2;\n t17 += v * b3;\n t18 += v * b4;\n t19 += v * b5;\n t20 += v * b6;\n t21 += v * b7;\n t22 += v * b8;\n t23 += v * b9;\n t24 += v * b10;\n t25 += v * b11;\n t26 += v * b12;\n t27 += v * b13;\n t28 += v * b14;\n t29 += v * b15;\n v = a[15];\n t15 += v * b0;\n t16 += v * b1;\n t17 += v * b2;\n t18 += v * b3;\n t19 += v * b4;\n t20 += v * b5;\n t21 += v * b6;\n t22 += v * b7;\n t23 += v * b8;\n t24 += v * b9;\n t25 += v * b10;\n t26 += v * b11;\n t27 += v * b12;\n t28 += v * b13;\n t29 += v * b14;\n t30 += v * b15;\n\n t0 += 38 * t16;\n t1 += 38 * t17;\n t2 += 38 * t18;\n t3 += 38 * t19;\n t4 += 38 * t20;\n t5 += 38 * t21;\n t6 += 38 * t22;\n t7 += 38 * t23;\n t8 += 38 * t24;\n t9 += 38 * t25;\n t10 += 38 * t26;\n t11 += 38 * t27;\n t12 += 38 * t28;\n t13 += 38 * t29;\n t14 += 38 * t30;\n // t15 left as is\n\n // first car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c - 1 + 37 * (c - 1);\n\n // second car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c - 1 + 37 * (c - 1);\n\n o[0] = t0;\n o[1] = t1;\n o[2] = t2;\n o[3] = t3;\n o[4] = t4;\n o[5] = t5;\n o[6] = t6;\n o[7] = t7;\n o[8] = t8;\n o[9] = t9;\n o[10] = t10;\n o[11] = t11;\n o[12] = t12;\n o[13] = t13;\n o[14] = t14;\n o[15] = t15;\n}\n\nfunction square(o: GF, a: GF) {\n mul(o, a, a);\n}\n\nfunction inv25519(o: GF, inp: GF) {\n const c = gf();\n for (let i = 0; i < 16; i++) {\n c[i] = inp[i];\n }\n for (let i = 253; i >= 0; i--) {\n square(c, c);\n if (i !== 2 && i !== 4) {\n mul(c, c, inp);\n }\n }\n for (let i = 0; i < 16; i++) {\n o[i] = c[i];\n }\n}\n\nexport function scalarMult(n: Uint8Array, p: Uint8Array): Uint8Array {\n const z = new Uint8Array(32);\n const x = new Float64Array(80);\n const a = gf(), b = gf(), c = gf(),\n d = gf(), e = gf(), f = gf();\n\n for (let i = 0; i < 31; i++) {\n z[i] = n[i];\n }\n z[31] = (n[31] & 127) | 64;\n z[0] &= 248;\n\n unpack25519(x, p);\n\n for (let i = 0; i < 16; i++) {\n b[i] = x[i];\n }\n\n a[0] = d[0] = 1;\n\n for (let i = 254; i >= 0; --i) {\n const r = (z[i >>> 3] >>> (i & 7)) & 1;\n sel25519(a, b, r);\n sel25519(c, d, r);\n add(e, a, c);\n sub(a, a, c);\n add(c, b, d);\n sub(b, b, d);\n square(d, e);\n square(f, a);\n mul(a, c, a);\n mul(c, b, e);\n add(e, a, c);\n sub(a, a, c);\n square(b, a);\n sub(c, d, f);\n mul(a, c, _121665);\n add(a, a, d);\n mul(c, c, a);\n mul(a, d, f);\n mul(d, b, x);\n square(b, e);\n sel25519(a, b, r);\n sel25519(c, d, r);\n }\n for (let i = 0; i < 16; i++) {\n x[i + 16] = a[i];\n x[i + 32] = c[i];\n x[i + 48] = b[i];\n x[i + 64] = d[i];\n }\n const x32 = x.subarray(32);\n const x16 = x.subarray(16);\n inv25519(x32, x32);\n mul(x16, x16, x32);\n const q = new Uint8Array(32);\n pack25519(q, x16);\n return q;\n}\n\nexport function scalarMultBase(n: Uint8Array): Uint8Array {\n return scalarMult(n, _9);\n}\n\nexport interface KeyPair {\n publicKey: Uint8Array;\n secretKey: Uint8Array;\n}\n\nexport function generateKeyPairFromSeed(seed: Uint8Array): KeyPair {\n if (seed.length !== SECRET_KEY_LENGTH) {\n throw new Error(`x25519: seed must be ${SECRET_KEY_LENGTH} bytes`);\n }\n const secretKey = new Uint8Array(seed);\n const publicKey = scalarMultBase(secretKey);\n return {\n publicKey,\n secretKey\n };\n}\n\nexport function generateKeyPair(prng?: RandomSource): KeyPair {\n const seed = randomBytes(32, prng);\n const result = generateKeyPairFromSeed(seed);\n wipe(seed);\n return result;\n}\n\n/**\n * Returns a shared key between our secret key and a peer's public key.\n *\n * Throws an error if the given keys are of wrong length.\n *\n * If rejectZero is true throws if the calculated shared key is all-zero.\n * From RFC 7748:\n *\n * > Protocol designers using Diffie-Hellman over the curves defined in\n * > this document must not assume \"contributory behavior\". Specially,\n * > contributory behavior means that both parties' private keys\n * > contribute to the resulting shared key. Since curve25519 and\n * > curve448 have cofactors of 8 and 4 (respectively), an input point of\n * > small order will eliminate any contribution from the other party's\n * > private key. This situation can be detected by checking for the all-\n * > zero output, which implementations MAY do, as specified in Section 6.\n * > However, a large number of existing implementations do not do this.\n *\n * IMPORTANT: the returned key is a raw result of scalar multiplication.\n * To use it as a key material, hash it with a cryptographic hash function.\n */\nexport function sharedKey(mySecretKey: Uint8Array, theirPublicKey: Uint8Array, rejectZero = false): Uint8Array {\n if (mySecretKey.length !== PUBLIC_KEY_LENGTH) {\n throw new Error(\"X25519: incorrect secret key length\");\n }\n if (theirPublicKey.length !== PUBLIC_KEY_LENGTH) {\n throw new Error(\"X25519: incorrect public key length\");\n }\n\n const result = scalarMult(mySecretKey, theirPublicKey);\n\n if (rejectZero) {\n let zeros = 0;\n for (let i = 0; i < result.length; i++) {\n zeros |= result[i];\n }\n if (zeros === 0) {\n throw new Error(\"X25519: invalid shared key\");\n }\n }\n\n return result;\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package random provides functions to access system's\n * cryptographically secure random byte generator.\n */\n\nimport { RandomSource } from \"./source\";\nimport { SystemRandomSource } from \"./source/system\";\nimport { readUint32LE } from \"@stablelib/binary\";\nimport { wipe } from \"@stablelib/wipe\";\n\nexport { RandomSource } from \"./source\";\n\nexport const defaultRandomSource = new SystemRandomSource();\n\nexport function randomBytes(length: number, prng: RandomSource = defaultRandomSource): Uint8Array {\n return prng.randomBytes(length);\n}\n\n/**\n * Returns a uniformly random unsigned 32-bit integer.\n */\nexport function randomUint32(prng: RandomSource = defaultRandomSource): number {\n // Generate 4-byte random buffer.\n const buf = randomBytes(4, prng);\n\n // Convert bytes from buffer into a 32-bit integer.\n // It's not important which byte order to use, since\n // the result is random.\n const result = readUint32LE(buf);\n\n // Clean the buffer.\n wipe(buf);\n\n return result;\n}\n\n/** 62 alphanumeric characters for default charset of randomString() */\nconst ALPHANUMERIC = \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz\";\n\n/**\n * Returns a uniform random string of the given length\n * with characters from the given charset.\n *\n * Charset must not have more than 256 characters.\n *\n * Default charset generates case-sensitive alphanumeric\n * strings (0-9, A-Z, a-z).\n */\nexport function randomString(\n length: number,\n charset = ALPHANUMERIC,\n prng: RandomSource = defaultRandomSource\n): string {\n if (charset.length < 2) {\n throw new Error(\"randomString charset is too short\");\n }\n if (charset.length > 256) {\n throw new Error(\"randomString charset is too long\");\n }\n let out = '';\n const charsLen = charset.length;\n const maxByte = 256 - (256 % charsLen);\n while (length > 0) {\n const buf = randomBytes(Math.ceil(length * 256 / maxByte), prng);\n for (let i = 0; i < buf.length && length > 0; i++) {\n const randomByte = buf[i];\n if (randomByte < maxByte) {\n out += charset.charAt(randomByte % charsLen);\n length--;\n }\n }\n wipe(buf);\n }\n return out;\n}\n\n/**\n * Returns uniform random string containing at least the given\n * number of bits of entropy.\n *\n * For example, randomStringForEntropy(128) will return a 22-character\n * alphanumeric string, while randomStringForEntropy(128, \"0123456789\")\n * will return a 39-character numeric string, both will contain at\n * least 128 bits of entropy.\n *\n * Default charset generates case-sensitive alphanumeric\n * strings (0-9, A-Z, a-z).\n */\nexport function randomStringForEntropy(\n bits: number,\n charset = ALPHANUMERIC,\n prng: RandomSource = defaultRandomSource\n): string {\n const length = Math.ceil(bits / (Math.log(charset.length) / Math.LN2));\n return randomString(length, charset, prng);\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\nimport { RandomSource } from \"./\";\nimport { BrowserRandomSource } from \"./browser\";\nimport { NodeRandomSource } from \"./node\";\n\nexport class SystemRandomSource implements RandomSource {\n isAvailable = false;\n name = \"\";\n private _source: RandomSource;\n\n constructor() {\n // Try browser.\n this._source = new BrowserRandomSource();\n if (this._source.isAvailable) {\n this.isAvailable = true;\n this.name = \"Browser\";\n return;\n }\n\n // If no browser source, try Node.\n this._source = new NodeRandomSource();\n if (this._source.isAvailable) {\n this.isAvailable = true;\n this.name = \"Node\";\n return;\n }\n\n // No sources, we're out of options.\n }\n\n randomBytes(length: number): Uint8Array {\n if (!this.isAvailable) {\n throw new Error(\"System random byte generator is not available.\");\n }\n return this._source.randomBytes(length);\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\nimport { RandomSource } from \"./\";\n\nconst QUOTA = 65536;\n\nexport class BrowserRandomSource implements RandomSource {\n isAvailable = false;\n isInstantiated = false;\n\n private _crypto?: { getRandomValues: typeof window.crypto.getRandomValues };\n\n constructor() {\n const browserCrypto = typeof self !== 'undefined'\n ? (self.crypto || (self as { msCrypto?: any }).msCrypto) // IE11 has msCrypto\n : null;\n\n if (browserCrypto && browserCrypto.getRandomValues) {\n this._crypto = browserCrypto;\n this.isAvailable = true;\n this.isInstantiated = true;\n }\n }\n\n randomBytes(length: number): Uint8Array {\n if (!this.isAvailable || !this._crypto) {\n throw new Error(\"Browser random byte generator is not available.\");\n }\n const out = new Uint8Array(length);\n for (let i = 0; i < out.length; i += QUOTA) {\n this._crypto.getRandomValues(out.subarray(i, i + Math.min(out.length - i, QUOTA)));\n }\n return out;\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\nimport { RandomSource } from \"./\";\nimport { wipe } from \"@stablelib/wipe\";\n\ndeclare function require(name: string): any;\n\nexport class NodeRandomSource implements RandomSource {\n isAvailable = false;\n isInstantiated = false;\n\n private _crypto: { randomBytes(n: number): Uint8Array } | undefined;\n\n constructor() {\n if (typeof require !== \"undefined\") {\n const nodeCrypto = require(\"crypto\");\n if (nodeCrypto && nodeCrypto.randomBytes) {\n this._crypto = nodeCrypto;\n this.isAvailable = true;\n this.isInstantiated = true;\n }\n }\n }\n\n randomBytes(length: number): Uint8Array {\n if (!this.isAvailable || !this._crypto) {\n throw new Error(\"Node.js random byte generator is not available.\");\n }\n\n // Get random bytes (result is Buffer).\n let buffer = this._crypto.randomBytes(length);\n\n // Make sure we got the length that we requested.\n if (buffer.length !== length) {\n throw new Error(\"NodeRandomSource: got fewer bytes than requested\");\n }\n\n // Allocate output array.\n const out = new Uint8Array(length);\n\n // Copy bytes from buffer to output.\n for (let i = 0; i < out.length; i++) {\n out[i] = buffer[i];\n }\n\n // Cleanup.\n wipe(buffer);\n\n return out;\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package wipe implements functions for zeroing arrays.\n */\n\nexport type NumericArray = number[] | Uint8Array | Int8Array | Uint16Array\n | Int16Array | Uint32Array | Int32Array | Float32Array | Float64Array;\n\n/**\n * Sets all values in the given array to zero and returns it.\n *\n * The fact that it sets bytes to zero can be relied on.\n *\n * There is no guarantee that this function makes data disappear from memory,\n * as runtime implementation can, for example, have copying garbage collector\n * that will make copies of sensitive data before we wipe it. Or that an\n * operating system will write our data to swap or sleep image. Another thing\n * is that an optimizing compiler can remove calls to this function or make it\n * no-op. There's nothing we can do with it, so we just do our best and hope\n * that everything will be okay and good will triumph over evil.\n */\nexport function wipe(array: NumericArray): NumericArray {\n // Right now it's similar to array.fill(0). If it turns\n // out that runtimes optimize this call away, maybe\n // we can try something else.\n for (let i = 0; i < array.length; i++) {\n array[i] = 0;\n }\n return array;\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package binary provides functions for encoding and decoding numbers in byte arrays.\n */\n\nimport { isSafeInteger } from \"@stablelib/int\";\n\n// TODO(dchest): add asserts for correct value ranges and array offsets.\n\n/**\n * Reads 2 bytes from array starting at offset as big-endian\n * signed 16-bit integer and returns it.\n */\nexport function readInt16BE(array: Uint8Array, offset = 0): number {\n return (((array[offset + 0] << 8) | array[offset + 1]) << 16) >> 16;\n}\n\n/**\n * Reads 2 bytes from array starting at offset as big-endian\n * unsigned 16-bit integer and returns it.\n */\nexport function readUint16BE(array: Uint8Array, offset = 0): number {\n return ((array[offset + 0] << 8) | array[offset + 1]) >>> 0;\n}\n\n/**\n * Reads 2 bytes from array starting at offset as little-endian\n * signed 16-bit integer and returns it.\n */\nexport function readInt16LE(array: Uint8Array, offset = 0): number {\n return (((array[offset + 1] << 8) | array[offset]) << 16) >> 16;\n}\n\n/**\n * Reads 2 bytes from array starting at offset as little-endian\n * unsigned 16-bit integer and returns it.\n */\nexport function readUint16LE(array: Uint8Array, offset = 0): number {\n return ((array[offset + 1] << 8) | array[offset]) >>> 0;\n}\n\n/**\n * Writes 2-byte big-endian representation of 16-bit unsigned\n * value to byte array starting at offset.\n *\n * If byte array is not given, creates a new 2-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint16BE(value: number, out = new Uint8Array(2), offset = 0): Uint8Array {\n out[offset + 0] = value >>> 8;\n out[offset + 1] = value >>> 0;\n return out;\n}\n\nexport const writeInt16BE = writeUint16BE;\n\n/**\n * Writes 2-byte little-endian representation of 16-bit unsigned\n * value to array starting at offset.\n *\n * If byte array is not given, creates a new 2-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint16LE(value: number, out = new Uint8Array(2), offset = 0): Uint8Array {\n out[offset + 0] = value >>> 0;\n out[offset + 1] = value >>> 8;\n return out;\n}\n\nexport const writeInt16LE = writeUint16LE;\n\n/**\n * Reads 4 bytes from array starting at offset as big-endian\n * signed 32-bit integer and returns it.\n */\nexport function readInt32BE(array: Uint8Array, offset = 0): number {\n return (array[offset] << 24) |\n (array[offset + 1] << 16) |\n (array[offset + 2] << 8) |\n array[offset + 3];\n}\n\n/**\n * Reads 4 bytes from array starting at offset as big-endian\n * unsigned 32-bit integer and returns it.\n */\nexport function readUint32BE(array: Uint8Array, offset = 0): number {\n return ((array[offset] << 24) |\n (array[offset + 1] << 16) |\n (array[offset + 2] << 8) |\n array[offset + 3]) >>> 0;\n}\n\n/**\n * Reads 4 bytes from array starting at offset as little-endian\n * signed 32-bit integer and returns it.\n */\nexport function readInt32LE(array: Uint8Array, offset = 0): number {\n return (array[offset + 3] << 24) |\n (array[offset + 2] << 16) |\n (array[offset + 1] << 8) |\n array[offset];\n}\n\n/**\n * Reads 4 bytes from array starting at offset as little-endian\n * unsigned 32-bit integer and returns it.\n */\nexport function readUint32LE(array: Uint8Array, offset = 0): number {\n return ((array[offset + 3] << 24) |\n (array[offset + 2] << 16) |\n (array[offset + 1] << 8) |\n array[offset]) >>> 0;\n}\n\n/**\n * Writes 4-byte big-endian representation of 32-bit unsigned\n * value to byte array starting at offset.\n *\n * If byte array is not given, creates a new 4-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint32BE(value: number, out = new Uint8Array(4), offset = 0): Uint8Array {\n out[offset + 0] = value >>> 24;\n out[offset + 1] = value >>> 16;\n out[offset + 2] = value >>> 8;\n out[offset + 3] = value >>> 0;\n return out;\n}\n\nexport const writeInt32BE = writeUint32BE;\n\n/**\n * Writes 4-byte little-endian representation of 32-bit unsigned\n * value to array starting at offset.\n *\n * If byte array is not given, creates a new 4-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint32LE(value: number, out = new Uint8Array(4), offset = 0): Uint8Array {\n out[offset + 0] = value >>> 0;\n out[offset + 1] = value >>> 8;\n out[offset + 2] = value >>> 16;\n out[offset + 3] = value >>> 24;\n return out;\n}\n\n\nexport const writeInt32LE = writeUint32LE;\n\n/**\n * Reads 8 bytes from array starting at offset as big-endian\n * signed 64-bit integer and returns it.\n *\n * IMPORTANT: due to JavaScript limitation, supports exact\n * numbers in range -9007199254740991 to 9007199254740991.\n * If the number stored in the byte array is outside this range,\n * the result is not exact.\n */\nexport function readInt64BE(array: Uint8Array, offset = 0): number {\n const hi = readInt32BE(array, offset);\n const lo = readInt32BE(array, offset + 4);\n return hi * 0x100000000 + lo - ((lo>>31) * 0x100000000);\n}\n\n/**\n * Reads 8 bytes from array starting at offset as big-endian\n * unsigned 64-bit integer and returns it.\n *\n * IMPORTANT: due to JavaScript limitation, supports values up to 2^53-1.\n */\nexport function readUint64BE(array: Uint8Array, offset = 0): number {\n const hi = readUint32BE(array, offset);\n const lo = readUint32BE(array, offset + 4);\n return hi * 0x100000000 + lo;\n}\n\n/**\n * Reads 8 bytes from array starting at offset as little-endian\n * signed 64-bit integer and returns it.\n *\n * IMPORTANT: due to JavaScript limitation, supports exact\n * numbers in range -9007199254740991 to 9007199254740991.\n * If the number stored in the byte array is outside this range,\n * the result is not exact.\n */\nexport function readInt64LE(array: Uint8Array, offset = 0): number {\n const lo = readInt32LE(array, offset);\n const hi = readInt32LE(array, offset + 4);\n return hi * 0x100000000 + lo - ((lo>>31) * 0x100000000);\n}\n\n\n/**\n * Reads 8 bytes from array starting at offset as little-endian\n * unsigned 64-bit integer and returns it.\n *\n * IMPORTANT: due to JavaScript limitation, supports values up to 2^53-1.\n */\nexport function readUint64LE(array: Uint8Array, offset = 0): number {\n const lo = readUint32LE(array, offset);\n const hi = readUint32LE(array, offset + 4);\n return hi * 0x100000000 + lo;\n}\n\n/**\n * Writes 8-byte big-endian representation of 64-bit unsigned\n * value to byte array starting at offset.\n *\n * Due to JavaScript limitation, supports values up to 2^53-1.\n *\n * If byte array is not given, creates a new 8-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint64BE(value: number, out = new Uint8Array(8), offset = 0): Uint8Array {\n writeUint32BE(value / 0x100000000 >>> 0, out, offset);\n writeUint32BE(value >>> 0, out, offset + 4);\n return out;\n}\n\nexport const writeInt64BE = writeUint64BE;\n\n/**\n * Writes 8-byte little-endian representation of 64-bit unsigned\n * value to byte array starting at offset.\n *\n * Due to JavaScript limitation, supports values up to 2^53-1.\n *\n * If byte array is not given, creates a new 8-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeUint64LE(value: number, out = new Uint8Array(8), offset = 0): Uint8Array {\n writeUint32LE(value >>> 0, out, offset);\n writeUint32LE(value / 0x100000000 >>> 0, out, offset + 4);\n return out;\n}\n\nexport const writeInt64LE = writeUint64LE;\n\n/**\n * Reads bytes from array starting at offset as big-endian\n * unsigned bitLen-bit integer and returns it.\n *\n * Supports bit lengths divisible by 8, up to 48.\n */\nexport function readUintBE(bitLength: number, array: Uint8Array, offset = 0): number {\n // TODO(dchest): implement support for bitLengths non-divisible by 8\n if (bitLength % 8 !== 0) {\n throw new Error(\"readUintBE supports only bitLengths divisible by 8\");\n }\n if (bitLength / 8 > array.length - offset) {\n throw new Error(\"readUintBE: array is too short for the given bitLength\");\n }\n let result = 0;\n let mul = 1;\n for (let i = bitLength / 8 + offset - 1; i >= offset; i--) {\n result += array[i] * mul;\n mul *= 256;\n }\n return result;\n}\n\n/**\n * Reads bytes from array starting at offset as little-endian\n * unsigned bitLen-bit integer and returns it.\n *\n * Supports bit lengths divisible by 8, up to 48.\n */\nexport function readUintLE(bitLength: number, array: Uint8Array, offset = 0): number {\n // TODO(dchest): implement support for bitLengths non-divisible by 8\n if (bitLength % 8 !== 0) {\n throw new Error(\"readUintLE supports only bitLengths divisible by 8\");\n }\n if (bitLength / 8 > array.length - offset) {\n throw new Error(\"readUintLE: array is too short for the given bitLength\");\n }\n let result = 0;\n let mul = 1;\n for (let i = offset; i < offset + bitLength / 8; i++) {\n result += array[i] * mul;\n mul *= 256;\n }\n return result;\n}\n\n/**\n * Writes a big-endian representation of bitLen-bit unsigned\n * value to array starting at offset.\n *\n * Supports bit lengths divisible by 8, up to 48.\n *\n * If byte array is not given, creates a new one.\n *\n * Returns the output byte array.\n */\nexport function writeUintBE(bitLength: number, value: number,\n out = new Uint8Array(bitLength / 8), offset = 0): Uint8Array {\n // TODO(dchest): implement support for bitLengths non-divisible by 8\n if (bitLength % 8 !== 0) {\n throw new Error(\"writeUintBE supports only bitLengths divisible by 8\");\n }\n if (!isSafeInteger(value)) {\n throw new Error(\"writeUintBE value must be an integer\");\n }\n let div = 1;\n for (let i = bitLength / 8 + offset - 1; i >= offset; i--) {\n out[i] = (value / div) & 0xff;\n div *= 256;\n }\n return out;\n}\n\n/**\n * Writes a little-endian representation of bitLen-bit unsigned\n * value to array starting at offset.\n *\n * Supports bit lengths divisible by 8, up to 48.\n *\n * If byte array is not given, creates a new one.\n *\n * Returns the output byte array.\n */\nexport function writeUintLE(bitLength: number, value: number,\n out = new Uint8Array(bitLength / 8), offset = 0): Uint8Array {\n // TODO(dchest): implement support for bitLengths non-divisible by 8\n if (bitLength % 8 !== 0) {\n throw new Error(\"writeUintLE supports only bitLengths divisible by 8\");\n }\n if (!isSafeInteger(value)) {\n throw new Error(\"writeUintLE value must be an integer\");\n }\n let div = 1;\n for (let i = offset; i < offset + bitLength / 8; i++) {\n out[i] = (value / div) & 0xff;\n div *= 256;\n }\n return out;\n}\n\n/**\n * Reads 4 bytes from array starting at offset as big-endian\n * 32-bit floating-point number and returns it.\n */\nexport function readFloat32BE(array: Uint8Array, offset = 0): number {\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat32(offset);\n}\n\n/**\n * Reads 4 bytes from array starting at offset as little-endian\n * 32-bit floating-point number and returns it.\n */\nexport function readFloat32LE(array: Uint8Array, offset = 0): number {\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat32(offset, true);\n}\n\n/**\n * Reads 8 bytes from array starting at offset as big-endian\n * 64-bit floating-point number (\"double\") and returns it.\n */\nexport function readFloat64BE(array: Uint8Array, offset = 0): number {\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat64(offset);\n}\n\n/**\n * Reads 8 bytes from array starting at offset as little-endian\n * 64-bit floating-point number (\"double\") and returns it.\n */\nexport function readFloat64LE(array: Uint8Array, offset = 0): number {\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat64(offset, true);\n}\n\n/**\n * Writes 4-byte big-endian floating-point representation of value\n * to byte array starting at offset.\n *\n * If byte array is not given, creates a new 4-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeFloat32BE(value: number, out = new Uint8Array(4), offset = 0): Uint8Array {\n const view = new DataView(out.buffer, out.byteOffset, out.byteLength);\n view.setFloat32(offset, value);\n return out;\n}\n\n/**\n * Writes 4-byte little-endian floating-point representation of value\n * to byte array starting at offset.\n *\n * If byte array is not given, creates a new 4-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeFloat32LE(value: number, out = new Uint8Array(4), offset = 0): Uint8Array {\n const view = new DataView(out.buffer, out.byteOffset, out.byteLength);\n view.setFloat32(offset, value, true);\n return out;\n}\n\n/**\n * Writes 8-byte big-endian floating-point representation of value\n * to byte array starting at offset.\n *\n * If byte array is not given, creates a new 8-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeFloat64BE(value: number, out = new Uint8Array(8), offset = 0): Uint8Array {\n const view = new DataView(out.buffer, out.byteOffset, out.byteLength);\n view.setFloat64(offset, value);\n return out;\n}\n\n/**\n * Writes 8-byte little-endian floating-point representation of value\n * to byte array starting at offset.\n *\n * If byte array is not given, creates a new 8-byte one.\n *\n * Returns the output byte array.\n */\nexport function writeFloat64LE(value: number, out = new Uint8Array(8), offset = 0): Uint8Array {\n const view = new DataView(out.buffer, out.byteOffset, out.byteLength);\n view.setFloat64(offset, value, true);\n return out;\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package int provides helper functions for integerss.\n */\n\n// Shim using 16-bit pieces.\nfunction imulShim(a: number, b: number): number {\n const ah = (a >>> 16) & 0xffff, al = a & 0xffff;\n const bh = (b >>> 16) & 0xffff, bl = b & 0xffff;\n return ((al * bl) + (((ah * bl + al * bh) << 16) >>> 0) | 0);\n}\n\n/** 32-bit integer multiplication. */\n// Use system Math.imul if available, otherwise use our shim.\nexport const mul = (Math as { imul?(a: number, b: number): number }).imul || imulShim;\n\n/** 32-bit integer addition. */\nexport function add(a: number, b: number): number {\n return (a + b) | 0;\n}\n\n/** 32-bit integer subtraction. */\nexport function sub(a: number, b: number): number {\n return (a - b) | 0;\n}\n\n/** 32-bit integer left rotation */\nexport function rotl(x: number, n: number): number {\n return x << n | x >>> (32 - n);\n}\n\n/** 32-bit integer left rotation */\nexport function rotr(x: number, n: number): number {\n return x << (32 - n) | x >>> n;\n}\n\nfunction isIntegerShim(n: number): boolean {\n return typeof n === \"number\" && isFinite(n) && Math.floor(n) === n;\n}\n\n/**\n * Returns true if the argument is an integer number.\n *\n * In ES2015, Number.isInteger.\n */\nexport const isInteger = (Number as { isInteger?(n: number): boolean }).isInteger || isIntegerShim;\n\n/**\n * Math.pow(2, 53) - 1\n *\n * In ES2015 Number.MAX_SAFE_INTEGER.\n */\nexport const MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Returns true if the argument is a safe integer number\n * (-MIN_SAFE_INTEGER < number <= MAX_SAFE_INTEGER)\n *\n * In ES2015, Number.isSafeInteger.\n */\nexport const isSafeInteger = (n: number): boolean =>\n isInteger(n) && (n >= -MAX_SAFE_INTEGER && n <= MAX_SAFE_INTEGER);\n","'use strict'\n\nconst isBuffer = require('is-buffer')\nconst Shake = require('it-handshake')\nconst lp = require('it-length-prefixed')\n\nmodule.exports = (duplex, opts = {}) => {\n const shake = Shake(duplex)\n const lpReader = lp.decode.fromReader(\n shake.reader,\n opts\n )\n\n let isDone = false\n\n const W = {\n read: async (bytes) => {\n // just read\n\n const { value, done } = await shake.reader.next(bytes)\n\n if (done && value.length < bytes) {\n throw new Error('Couldn\\'t read enough bytes')\n }\n\n isDone = done\n\n if (!value) { throw new Error('Value is null') }\n return value\n },\n readLP: async () => {\n // read, decode\n const { value, done } = await lpReader.next()\n\n isDone = done\n\n if (!value) { throw new Error('Value is null') }\n return value\n },\n readPB: async (proto) => {\n // readLP, decode\n const value = await W.readLP()\n\n if (!value) { throw new Error('Value is null') }\n\n // Is this a buffer?\n const buf = isBuffer(value) ? value : value.slice()\n\n return proto.decode(buf)\n },\n write: (data) => {\n // just write\n shake.writer.push(data)\n },\n writeLP: (data) => {\n // encode, write\n W.write(lp.encode.single(data, opts))\n },\n writePB: (data, proto) => {\n // encode, writeLP\n W.writeLP(proto.encode(data))\n },\n\n pb: (proto) => {\n return {\n read: () => W.readPB(proto),\n write: (d) => W.writePB(d, proto)\n }\n },\n\n unwrap: () => {\n // returns vanilla duplex again, terminates all reads/writes from this object\n shake.rest()\n return shake.stream\n }\n }\n\n return W\n}\n","'use strict'\n\nconst Reader = require('it-reader')\nconst Writer = require('it-pushable')\nconst defer = require('p-defer')\n\n// Convert a duplex stream into a reader and writer and rest stream\nmodule.exports = stream => {\n const writer = Writer() // Write bytes on demand to the sink\n const reader = Reader(stream.source) // Read bytes on demand from the source\n\n // Waits for a source to be passed to the rest stream's sink\n const sourcePromise = defer()\n let sinkErr\n\n const sinkPromise = stream.sink((async function * () {\n yield * writer\n const source = await sourcePromise.promise\n yield * source\n })())\n\n sinkPromise.catch(err => {\n sinkErr = err\n })\n\n const rest = {\n sink: source => {\n if (sinkErr) {\n return Promise.reject(sinkErr)\n }\n\n sourcePromise.resolve(source)\n return sinkPromise\n },\n source: reader\n }\n\n return {\n reader,\n writer,\n stream: rest,\n rest: () => writer.end(),\n write: writer.push,\n read: async () => {\n return (await reader.next()).value\n }\n }\n}\n","\nvar Pair = require('./')\nmodule.exports = function () {\n var a = Pair()\n var b = Pair()\n return [\n {\n source: a.source,\n sink: b.sink\n },\n {\n source: b.source,\n sink: a.sink\n }\n ]\n}\n","'use strict'\n\nconst getIterator = require('get-iterator')\n\n// a pair of streams where one drains from the other\nmodule.exports = function pair () {\n let _source, onSource\n\n const sink = async source => {\n if (_source) throw new Error('already piped')\n _source = getIterator(source)\n if (onSource) onSource(_source)\n }\n\n const source = {\n [Symbol.asyncIterator] () {\n return this\n },\n next () {\n if (_source) return _source.next()\n return new Promise(resolve => {\n onSource = source => {\n onSource = null\n resolve(source.next())\n }\n })\n }\n }\n\n return { sink, source }\n}\n","'use strict'\n\nconst { Buffer } = require('buffer')\nconst BufferList = require('bl/BufferList')\n\nmodule.exports = async function * (source) {\n for await (const b of source) {\n if (Buffer.isBuffer(b)) {\n yield b\n } else if (BufferList.isBufferList(b)) {\n yield b.slice()\n } else {\n yield Buffer.from(b)\n }\n }\n}\n\nmodule.exports.toBuffer = module.exports\n\nmodule.exports.toList = async function * (source) {\n for await (const b of source) {\n if (Buffer.isBuffer(b)) {\n yield new BufferList().append(b)\n } else if (BufferList.isBufferList(b)) {\n yield b\n } else {\n yield new BufferList().append(Buffer.from(b))\n }\n }\n}\n","import { Buffer } from 'buffer'\n\nimport { XX } from './handshakes/xx'\nimport { KeyPair } from './@types/libp2p'\nimport { bytes, bytes32 } from './@types/basic'\nimport { NoiseSession } from './@types/handshake'\nimport { IHandshake } from './@types/handshake-interface'\nimport {\n decodePayload,\n getPeerIdFromPayload,\n verifySignedPayload\n} from './utils'\nimport {\n logger,\n logLocalStaticKeys,\n logLocalEphemeralKeys,\n logRemoteEphemeralKey,\n logRemoteStaticKey,\n logCipherState\n} from './logger'\nimport { decode0, decode1, decode2, encode0, encode1, encode2 } from './encoder'\nimport { WrappedConnection } from './noise'\nimport PeerId from 'peer-id'\n\nexport class XXHandshake implements IHandshake {\n public isInitiator: boolean\n public session: NoiseSession\n public remotePeer!: PeerId\n public remoteEarlyData: Buffer\n\n protected payload: bytes\n protected connection: WrappedConnection\n protected xx: XX\n protected staticKeypair: KeyPair\n\n private readonly prologue: bytes32\n\n constructor (\n isInitiator: boolean,\n payload: bytes,\n prologue: bytes32,\n staticKeypair: KeyPair,\n connection: WrappedConnection,\n remotePeer?: PeerId,\n handshake?: XX\n ) {\n this.isInitiator = isInitiator\n this.payload = payload\n this.prologue = prologue\n this.staticKeypair = staticKeypair\n this.connection = connection\n if (remotePeer) {\n this.remotePeer = remotePeer\n }\n this.xx = handshake ?? new XX()\n this.session = this.xx.initSession(this.isInitiator, this.prologue, this.staticKeypair)\n this.remoteEarlyData = Buffer.alloc(0)\n }\n\n // stage 0\n public async propose (): Promise<void> {\n logLocalStaticKeys(this.session.hs.s)\n if (this.isInitiator) {\n logger('Stage 0 - Initiator starting to send first message.')\n const messageBuffer = this.xx.sendMessage(this.session, Buffer.alloc(0))\n this.connection.writeLP(encode0(messageBuffer))\n logger('Stage 0 - Initiator finished sending first message.')\n logLocalEphemeralKeys(this.session.hs.e)\n } else {\n logger('Stage 0 - Responder waiting to receive first message...')\n const receivedMessageBuffer = decode0((await this.connection.readLP()).slice())\n const { valid } = this.xx.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('xx handshake stage 0 validation fail')\n }\n logger('Stage 0 - Responder received first message.')\n logRemoteEphemeralKey(this.session.hs.re)\n }\n }\n\n // stage 1\n public async exchange (): Promise<void> {\n if (this.isInitiator) {\n logger('Stage 1 - Initiator waiting to receive first message from responder...')\n const receivedMessageBuffer = decode1((await this.connection.readLP()).slice())\n const { plaintext, valid } = this.xx.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('xx handshake stage 1 validation fail')\n }\n logger('Stage 1 - Initiator received the message.')\n logRemoteEphemeralKey(this.session.hs.re)\n logRemoteStaticKey(this.session.hs.rs)\n\n logger(\"Initiator going to check remote's signature...\")\n try {\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n this.remotePeer = await verifySignedPayload(receivedMessageBuffer.ns, decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n } catch (e) {\n const err = e as Error\n throw new Error(`Error occurred while verifying signed payload: ${err.message}`)\n }\n logger('All good with the signature!')\n } else {\n logger('Stage 1 - Responder sending out first message with signed payload and static key.')\n const messageBuffer = this.xx.sendMessage(this.session, this.payload)\n this.connection.writeLP(encode1(messageBuffer))\n logger('Stage 1 - Responder sent the second handshake message with signed payload.')\n logLocalEphemeralKeys(this.session.hs.e)\n }\n }\n\n // stage 2\n public async finish (): Promise<void> {\n if (this.isInitiator) {\n logger('Stage 2 - Initiator sending third handshake message.')\n const messageBuffer = this.xx.sendMessage(this.session, this.payload)\n this.connection.writeLP(encode2(messageBuffer))\n logger('Stage 2 - Initiator sent message with signed payload.')\n } else {\n logger('Stage 2 - Responder waiting for third handshake message...')\n const receivedMessageBuffer = decode2((await this.connection.readLP()).slice())\n const { plaintext, valid } = this.xx.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('xx handshake stage 2 validation fail')\n }\n logger('Stage 2 - Responder received the message, finished handshake.')\n\n try {\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n await verifySignedPayload(this.session.hs.rs, decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n } catch (e) {\n const err = e as Error\n throw new Error(`Error occurred while verifying signed payload: ${err.message}`)\n }\n }\n logCipherState(this.session)\n }\n\n public encrypt (plaintext: bytes, session: NoiseSession): bytes {\n const cs = this.getCS(session)\n\n return this.xx.encryptWithAd(cs, Buffer.alloc(0), plaintext)\n }\n\n public decrypt (ciphertext: bytes, session: NoiseSession): {plaintext: bytes, valid: boolean} {\n const cs = this.getCS(session, false)\n return this.xx.decryptWithAd(cs, Buffer.alloc(0), ciphertext)\n }\n\n public getRemoteStaticKey (): bytes {\n return this.session.hs.rs\n }\n\n private getCS (session: NoiseSession, encryption = true) {\n if (!session.cs1 || !session.cs2) {\n throw new Error('Handshake not completed properly, cipher state does not exist.')\n }\n\n if (this.isInitiator) {\n return encryption ? session.cs1 : session.cs2\n } else {\n return encryption ? session.cs2 : session.cs1\n }\n }\n\n protected setRemoteEarlyData (data: Uint8Array|null|undefined): void {\n if (data) {\n this.remoteEarlyData = Buffer.from(data.buffer, data.byteOffset, data.length)\n }\n }\n}\n","import { Buffer } from 'buffer'\nimport { bytes32, bytes } from '../@types/basic'\nimport { KeyPair } from '../@types/libp2p'\nimport { generateKeypair, isValidPublicKey } from '../utils'\nimport { CipherState, HandshakeState, MessageBuffer, NoiseSession } from '../@types/handshake'\nimport { AbstractHandshake } from './abstract-handshake'\n\nexport class XX extends AbstractHandshake {\n private initializeInitiator (prologue: bytes32, s: KeyPair, rs: bytes32, psk: bytes32): HandshakeState {\n const name = 'Noise_XX_25519_ChaChaPoly_SHA256'\n const ss = this.initializeSymmetric(name)\n this.mixHash(ss, prologue)\n const re = Buffer.alloc(32)\n\n return { ss, s, rs, psk, re }\n }\n\n private initializeResponder (prologue: bytes32, s: KeyPair, rs: bytes32, psk: bytes32): HandshakeState {\n const name = 'Noise_XX_25519_ChaChaPoly_SHA256'\n const ss = this.initializeSymmetric(name)\n this.mixHash(ss, prologue)\n const re = Buffer.alloc(32)\n\n return { ss, s, rs, psk, re }\n }\n\n private writeMessageA (hs: HandshakeState, payload: bytes, e?: KeyPair): MessageBuffer {\n const ns = Buffer.alloc(0)\n\n if (e !== undefined) {\n hs.e = e\n } else {\n hs.e = generateKeypair()\n }\n\n const ne = hs.e.publicKey\n\n this.mixHash(hs.ss, ne)\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n\n return { ne, ns, ciphertext }\n }\n\n private writeMessageB (hs: HandshakeState, payload: bytes): MessageBuffer {\n hs.e = generateKeypair()\n const ne = hs.e.publicKey\n this.mixHash(hs.ss, ne)\n\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.re))\n const spk = Buffer.from(hs.s.publicKey)\n const ns = this.encryptAndHash(hs.ss, spk)\n\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.re))\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n\n return { ne, ns, ciphertext }\n }\n\n private writeMessageC (hs: HandshakeState, payload: bytes) {\n const spk = Buffer.from(hs.s.publicKey)\n const ns = this.encryptAndHash(hs.ss, spk)\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.re))\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n const ne = this.createEmptyKey()\n const messageBuffer: MessageBuffer = { ne, ns, ciphertext }\n const { cs1, cs2 } = this.split(hs.ss)\n\n return { h: hs.ss.h, messageBuffer, cs1, cs2 }\n }\n\n private readMessageA (hs: HandshakeState, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n if (isValidPublicKey(message.ne)) {\n hs.re = message.ne\n }\n\n this.mixHash(hs.ss, hs.re)\n return this.decryptAndHash(hs.ss, message.ciphertext)\n }\n\n private readMessageB (hs: HandshakeState, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n if (isValidPublicKey(message.ne)) {\n hs.re = message.ne\n }\n\n this.mixHash(hs.ss, hs.re)\n if (!hs.e) {\n throw new Error('Handshake state `e` param is missing.')\n }\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.re))\n const { plaintext: ns, valid: valid1 } = this.decryptAndHash(hs.ss, message.ns)\n if (valid1 && ns.length === 32 && isValidPublicKey(ns)) {\n hs.rs = ns\n }\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.rs))\n const { plaintext, valid: valid2 } = this.decryptAndHash(hs.ss, message.ciphertext)\n return { plaintext, valid: (valid1 && valid2) }\n }\n\n private readMessageC (hs: HandshakeState, message: MessageBuffer): {h: bytes, plaintext: bytes, valid: boolean, cs1: CipherState, cs2: CipherState} {\n const { plaintext: ns, valid: valid1 } = this.decryptAndHash(hs.ss, message.ns)\n if (valid1 && ns.length === 32 && isValidPublicKey(ns)) {\n hs.rs = ns\n }\n if (!hs.e) {\n throw new Error('Handshake state `e` param is missing.')\n }\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.rs))\n\n const { plaintext, valid: valid2 } = this.decryptAndHash(hs.ss, message.ciphertext)\n const { cs1, cs2 } = this.split(hs.ss)\n\n return { h: hs.ss.h, plaintext, valid: (valid1 && valid2), cs1, cs2 }\n }\n\n public initSession (initiator: boolean, prologue: bytes32, s: KeyPair): NoiseSession {\n const psk = this.createEmptyKey()\n const rs = Buffer.alloc(32) // no static key yet\n let hs\n\n if (initiator) {\n hs = this.initializeInitiator(prologue, s, rs, psk)\n } else {\n hs = this.initializeResponder(prologue, s, rs, psk)\n }\n\n return {\n hs,\n i: initiator,\n mc: 0\n }\n }\n\n public sendMessage (session: NoiseSession, message: bytes, ephemeral?: KeyPair): MessageBuffer {\n let messageBuffer: MessageBuffer\n if (session.mc === 0) {\n messageBuffer = this.writeMessageA(session.hs, message, ephemeral)\n } else if (session.mc === 1) {\n messageBuffer = this.writeMessageB(session.hs, message)\n } else if (session.mc === 2) {\n const { h, messageBuffer: resultingBuffer, cs1, cs2 } = this.writeMessageC(session.hs, message)\n messageBuffer = resultingBuffer\n session.h = h\n session.cs1 = cs1\n session.cs2 = cs2\n } else if (session.mc > 2) {\n if (session.i) {\n if (!session.cs1) {\n throw new Error('CS1 (cipher state) is not defined')\n }\n\n messageBuffer = this.writeMessageRegular(session.cs1, message)\n } else {\n if (!session.cs2) {\n throw new Error('CS2 (cipher state) is not defined')\n }\n\n messageBuffer = this.writeMessageRegular(session.cs2, message)\n }\n } else {\n throw new Error('Session invalid.')\n }\n\n session.mc++\n return messageBuffer\n }\n\n public recvMessage (session: NoiseSession, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n let plaintext: bytes = Buffer.alloc(0)\n let valid = false\n if (session.mc === 0) {\n ({ plaintext, valid } = this.readMessageA(session.hs, message))\n } else if (session.mc === 1) {\n ({ plaintext, valid } = this.readMessageB(session.hs, message))\n } else if (session.mc === 2) {\n const { h, plaintext: resultingPlaintext, valid: resultingValid, cs1, cs2 } = this.readMessageC(session.hs, message)\n plaintext = resultingPlaintext\n valid = resultingValid\n session.h = h\n session.cs1 = cs1\n session.cs2 = cs2\n }\n session.mc++\n return { plaintext, valid }\n }\n}\n","import { HKDF } from '@stablelib/hkdf'\nimport { SHA256 } from '@stablelib/sha256'\nimport * as x25519 from '@stablelib/x25519'\nimport { Buffer } from 'buffer'\nimport PeerId from 'peer-id'\nimport { keys } from 'libp2p-crypto'\nimport { KeyPair } from './@types/libp2p'\nimport { bytes, bytes32 } from './@types/basic'\nimport { Hkdf, INoisePayload } from './@types/handshake'\nimport { pb } from './proto/payload'\nimport { equals as uint8ArrayEquals } from 'uint8arrays/equals'\n\nconst NoiseHandshakePayloadProto = pb.NoiseHandshakePayload\n\nexport function generateKeypair (): KeyPair {\n const keypair = x25519.generateKeyPair()\n\n return {\n publicKey: Buffer.from(keypair.publicKey.buffer, keypair.publicKey.byteOffset, keypair.publicKey.length),\n privateKey: Buffer.from(keypair.secretKey.buffer, keypair.secretKey.byteOffset, keypair.secretKey.length)\n }\n}\n\nexport async function getPayload (\n localPeer: PeerId,\n staticPublicKey: bytes,\n earlyData?: bytes\n): Promise<bytes> {\n const signedPayload = await signPayload(localPeer, getHandshakePayload(staticPublicKey))\n const earlyDataPayload = earlyData ?? Buffer.alloc(0)\n\n return createHandshakePayload(\n localPeer.marshalPubKey(),\n signedPayload,\n earlyDataPayload\n )\n}\n\nexport function createHandshakePayload (\n libp2pPublicKey: Uint8Array,\n signedPayload: Uint8Array,\n earlyData?: Uint8Array\n): bytes {\n const payloadInit = NoiseHandshakePayloadProto.create({\n identityKey: Buffer.from(libp2pPublicKey),\n identitySig: signedPayload,\n data: earlyData ?? null\n })\n\n return Buffer.from(NoiseHandshakePayloadProto.encode(payloadInit).finish())\n}\n\nexport async function signPayload (peerId: PeerId, payload: bytes): Promise<bytes> {\n return Buffer.from(await peerId.privKey.sign(payload))\n}\n\nexport async function getPeerIdFromPayload (payload: pb.INoiseHandshakePayload): Promise<PeerId> {\n return await PeerId.createFromPubKey(Buffer.from(payload.identityKey as Uint8Array))\n}\n\nexport function decodePayload (payload: bytes|Uint8Array): pb.INoiseHandshakePayload {\n return NoiseHandshakePayloadProto.toObject(\n NoiseHandshakePayloadProto.decode(Buffer.from(payload))\n ) as INoisePayload\n}\n\nexport function getHandshakePayload (publicKey: bytes): bytes {\n return Buffer.concat([Buffer.from('noise-libp2p-static-key:'), publicKey])\n}\n\nasync function isValidPeerId (peerId: Uint8Array, publicKeyProtobuf: bytes): Promise<boolean> {\n const generatedPeerId = await PeerId.createFromPubKey(publicKeyProtobuf)\n return uint8ArrayEquals(generatedPeerId.id, peerId)\n}\n\n/**\n * Verifies signed payload, throws on any irregularities.\n *\n * @param {bytes} noiseStaticKey - owner's noise static key\n * @param {bytes} payload - decoded payload\n * @param {PeerId} remotePeer - owner's libp2p peer ID\n * @returns {Promise<PeerId>} - peer ID of payload owner\n */\nexport async function verifySignedPayload (\n noiseStaticKey: bytes,\n payload: pb.INoiseHandshakePayload,\n remotePeer: PeerId\n): Promise<PeerId> {\n const identityKey = Buffer.from(payload.identityKey as Uint8Array)\n if (!(await isValidPeerId(remotePeer.id, identityKey))) {\n throw new Error(\"Peer ID doesn't match libp2p public key.\")\n }\n const generatedPayload = getHandshakePayload(noiseStaticKey)\n // Unmarshaling from PublicKey protobuf\n const publicKey = keys.unmarshalPublicKey(identityKey)\n // TODO remove this after libp2p-crypto ships proper types\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n if (!payload.identitySig || !publicKey.verify(generatedPayload, Buffer.from(payload.identitySig))) {\n throw new Error(\"Static key doesn't match to peer that signed payload!\")\n }\n return await PeerId.createFromPubKey(identityKey)\n}\n\nexport function getHkdf (ck: bytes32, ikm: bytes): Hkdf {\n const hkdf = new HKDF(SHA256, ikm, ck)\n const okmU8Array = hkdf.expand(96)\n const okm = Buffer.from(okmU8Array.buffer, okmU8Array.byteOffset, okmU8Array.length)\n\n const k1 = okm.slice(0, 32)\n const k2 = okm.slice(32, 64)\n const k3 = okm.slice(64, 96)\n\n return [k1, k2, k3]\n}\n\nexport function isValidPublicKey (pk: bytes): boolean {\n if (!Buffer.isBuffer(pk)) {\n return false\n }\n\n if (pk.length !== 32) {\n return false\n }\n\n return true\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package hkdf implements HKDF key derivation function.\n */\n\nimport { Hash } from \"@stablelib/hash\";\nimport { HMAC, hmac } from \"@stablelib/hmac\";\nimport { wipe } from \"@stablelib/wipe\";\n\n/**\n * HMAC-based Extract-and-Expand Key Derivation Function.\n *\n * Implements HKDF from RFC5869.\n *\n * Expands the given master key with salt and info into\n * a limited stream of key material.\n */\nexport class HKDF {\n private _hmac: HMAC;\n private _buffer: Uint8Array;\n private _bufpos: number;\n private _counter = new Uint8Array(1); // starts with zero\n private _hash: new () => Hash;\n private _info?: Uint8Array;\n\n /**\n * Create a new HKDF instance for the given hash function\n * with the master key, optional salt, and info.\n *\n * - Master key is a high-entropy secret key (not a password).\n * - Salt is a non-secret random value.\n * - Info is application- and/or context-specific information.\n */\n constructor(hash: new () => Hash,\n key: Uint8Array,\n salt = new Uint8Array(0),\n info?: Uint8Array) {\n\n this._hash = hash;\n this._info = info;\n\n // HKDF-Extract uses salt as HMAC key, and key as data.\n const okm = hmac(this._hash, salt, key);\n\n // Initialize HMAC for expanding with extracted key.\n this._hmac = new HMAC(hash, okm);\n\n // Allocate buffer.\n this._buffer = new Uint8Array(this._hmac.digestLength);\n this._bufpos = this._buffer.length;\n }\n\n // Fill buffer with new block of HKDF-Extract output.\n private _fillBuffer(): void {\n // Increment counter.\n this._counter[0]++;\n\n const ctr = this._counter[0];\n\n // Check if counter overflowed.\n if (ctr === 0) {\n throw new Error(\"hkdf: cannot expand more\");\n }\n\n // Prepare HMAC instance for new data with old key.\n this._hmac.reset();\n\n // Hash in previous output if it was generated\n // (i.e. counter is greater than 1).\n if (ctr > 1) {\n this._hmac.update(this._buffer);\n }\n\n // Hash in info if it exists.\n if (this._info) {\n this._hmac.update(this._info);\n }\n\n // Hash in the counter.\n this._hmac.update(this._counter);\n\n // Output result to buffer and clean HMAC instance.\n this._hmac.finish(this._buffer);\n\n // Reset buffer position.\n this._bufpos = 0;\n }\n\n /**\n * Expand returns next key material of the given length.\n *\n * It throws if expansion limit is reached (which is\n * 254 digests of the underlying HMAC function).\n */\n expand(length: number): Uint8Array {\n const out = new Uint8Array(length);\n for (let i = 0; i < out.length; i++) {\n if (this._bufpos === this._buffer.length) {\n this._fillBuffer();\n }\n out[i] = this._buffer[this._bufpos++];\n }\n return out;\n }\n\n clean(): void {\n this._hmac.clean();\n wipe(this._buffer);\n wipe(this._counter);\n this._bufpos = 0;\n }\n}\n\n// TODO(dchest): maybe implement deriveKey?\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package hmac implements HMAC algorithm.\n */\n\nimport { Hash, SerializableHash, isSerializableHash } from \"@stablelib/hash\";\nimport { equal as constantTimeEqual } from \"@stablelib/constant-time\";\nimport { wipe } from \"@stablelib/wipe\";\n\n/**\n * HMAC implements hash-based message authentication algorithm.\n */\nexport class HMAC implements SerializableHash {\n readonly blockSize: number;\n readonly digestLength: number;\n\n private _inner: Hash; // inner hash\n private _outer: Hash; // outer hash\n\n private _finished = false; // true if HMAC was finalized\n\n // Copies of hash states after keying.\n // Need for quick reset without hashing the key again.\n private _innerKeyedState: any | undefined;\n private _outerKeyedState: any | undefined;\n\n /**\n * Constructs a new HMAC with the given Hash and secret key.\n */\n constructor(hash: new () => Hash | SerializableHash, key: Uint8Array) {\n // Initialize inner and outer hashes.\n this._inner = new hash();\n this._outer = new hash();\n\n // Set block and digest sizes for this HMAC\n // instance to values from the hash.\n this.blockSize = this._outer.blockSize;\n this.digestLength = this._outer.digestLength;\n\n // Pad temporary stores a key (or its hash) padded with zeroes.\n const pad = new Uint8Array(this.blockSize);\n\n if (key.length > this.blockSize) {\n // If key is bigger than hash block size, it must be\n // hashed and this hash is used as a key instead.\n this._inner.update(key).finish(pad).clean();\n } else {\n // Otherwise, copy the key into pad.\n pad.set(key);\n }\n\n // Now two different keys are derived from padded key\n // by xoring a different byte value to each.\n\n // To make inner hash key, xor byte 0x36 into pad.\n for (let i = 0; i < pad.length; i++) {\n pad[i] ^= 0x36;\n }\n // Update inner hash with the result.\n this._inner.update(pad);\n\n // To make outer hash key, xor byte 0x5c into pad.\n // But since we already xored 0x36 there, we must\n // first undo this by xoring it again.\n for (let i = 0; i < pad.length; i++) {\n pad[i] ^= 0x36 ^ 0x5c;\n }\n // Update outer hash with the result.\n this._outer.update(pad);\n\n // Save states of both hashes, so that we can quickly restore\n // them later in reset() without the need to remember the actual\n // key and perform this initialization again.\n if (isSerializableHash(this._inner) && isSerializableHash(this._outer)) {\n this._innerKeyedState = this._inner.saveState();\n this._outerKeyedState = this._outer.saveState();\n }\n\n // Clean pad.\n wipe(pad);\n }\n\n /**\n * Returns HMAC state to the state initialized with key\n * to make it possible to run HMAC over the other data with the same\n * key without creating a new instance.\n */\n reset(): this {\n if (!isSerializableHash(this._inner) || !isSerializableHash(this._outer)) {\n throw new Error(\"hmac: can't reset() because hash doesn't implement restoreState()\");\n }\n // Restore keyed states of inner and outer hashes.\n this._inner.restoreState(this._innerKeyedState);\n this._outer.restoreState(this._outerKeyedState);\n this._finished = false;\n return this;\n }\n\n /**\n * Cleans HMAC state.\n */\n clean() {\n if (isSerializableHash(this._inner)) {\n this._inner.cleanSavedState(this._innerKeyedState);\n }\n if (isSerializableHash(this._outer)) {\n this._outer.cleanSavedState(this._outerKeyedState);\n }\n this._inner.clean();\n this._outer.clean();\n }\n\n /**\n * Updates state with provided data.\n */\n update(data: Uint8Array): this {\n this._inner.update(data);\n return this;\n }\n\n /**\n * Finalizes HMAC and puts the result in out.\n */\n finish(out: Uint8Array): this {\n if (this._finished) {\n // If HMAC was finalized, outer hash is also finalized,\n // so it produces the same digest it produced when it\n // was finalized.\n this._outer.finish(out);\n return this;\n }\n\n // Finalize inner hash and store the result temporarily.\n this._inner.finish(out);\n\n // Update outer hash with digest of inner hash and and finalize it.\n this._outer.update(out.subarray(0, this.digestLength)).finish(out);\n this._finished = true;\n\n return this;\n }\n\n /**\n * Returns the computed message authentication code.\n */\n digest(): Uint8Array {\n const out = new Uint8Array(this.digestLength);\n this.finish(out);\n return out;\n }\n\n /**\n * Saves HMAC state.\n * This function is needed for PBKDF2 optimization.\n */\n saveState(): any {\n if (!isSerializableHash(this._inner)) {\n throw new Error(\"hmac: can't saveState() because hash doesn't implement it\");\n }\n return this._inner.saveState();\n }\n\n restoreState(savedState: any): this {\n if (!isSerializableHash(this._inner) || !isSerializableHash(this._outer)) {\n throw new Error(\"hmac: can't restoreState() because hash doesn't implement it\");\n }\n this._inner.restoreState(savedState);\n this._outer.restoreState(this._outerKeyedState);\n this._finished = false;\n return this;\n }\n\n cleanSavedState(savedState: any) {\n if (!isSerializableHash(this._inner)) {\n throw new Error(\"hmac: can't cleanSavedState() because hash doesn't implement it\");\n }\n this._inner.cleanSavedState(savedState);\n }\n}\n\n/**\n * Returns HMAC using the given hash constructor for the key over data.\n */\nexport function hmac(hash: new () => Hash, key: Uint8Array, data: Uint8Array): Uint8Array {\n const h = new HMAC(hash, key);\n h.update(data);\n const digest = h.digest();\n h.clean();\n return digest;\n}\n\n/**\n * Returns true if two HMAC digests are equal.\n * Uses constant-time comparison to avoid leaking timing information.\n *\n * Example:\n *\n * const receivedDigest = ...\n * const realDigest = hmac(SHA256, key, data);\n * if (!equal(receivedDigest, realDigest)) {\n * throw new Error(\"Authentication error\");\n * }\n */\nexport const equal = constantTimeEqual;\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package hash provides interface for hash functions.\n */\n\n/**\n * Hash interface describes properties of\n * cryptographic hash functions.\n */\nexport interface Hash {\n readonly digestLength: number;\n readonly blockSize: number;\n update(data: Uint8Array): this;\n reset(): this;\n finish(out: Uint8Array): this;\n digest(): Uint8Array;\n clean(): void;\n}\n\nexport interface SerializableHash extends Hash {\n saveState(): any;\n restoreState(savedState: any): this;\n cleanSavedState(savedState: any): void;\n}\n\nexport function isSerializableHash(h: Hash): h is SerializableHash {\n return (\n typeof (h as SerializableHash).saveState !== \"undefined\" &&\n typeof (h as SerializableHash).restoreState !== \"undefined\" &&\n typeof (h as SerializableHash).cleanSavedState !== \"undefined\"\n );\n}\n\n// TODO(dchest): figure out the standardized interface for XOF such as\n// SHAKE and BLAKE2X.\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package constant-time provides functions for performing algorithmically constant-time operations.\n */\n\n/**\n * NOTE! Due to the inability to guarantee real constant time evaluation of\n * anything in JavaScript VM, this is module is the best effort.\n */\n\n/**\n * Returns resultIfOne if subject is 1, or resultIfZero if subject is 0.\n *\n * Supports only 32-bit integers, so resultIfOne or resultIfZero are not\n * integers, they'll be converted to them with bitwise operations.\n */\nexport function select(subject: number, resultIfOne: number, resultIfZero: number): number {\n return (~(subject - 1) & resultIfOne) | ((subject - 1) & resultIfZero);\n}\n\n/**\n * Returns 1 if a <= b, or 0 if not.\n * Arguments must be positive 32-bit integers less than or equal to 2^31 - 1.\n */\nexport function lessOrEqual(a: number, b: number): number {\n return (((a | 0) - (b | 0) - 1) >>> 31) & 1;\n}\n\n/**\n * Returns 1 if a and b are of equal length and their contents\n * are equal, or 0 otherwise.\n *\n * Note that unlike in equal(), zero-length inputs are considered\n * the same, so this function will return 1.\n */\nexport function compare(a: Uint8Array, b: Uint8Array): number {\n if (a.length !== b.length) {\n return 0;\n }\n let result = 0;\n for (let i = 0; i < a.length; i++) {\n result |= a[i] ^ b[i];\n }\n return (1 & ((result - 1) >>> 8));\n}\n\n/**\n * Returns true if a and b are of equal non-zero length,\n * and their contents are equal, or false otherwise.\n *\n * Note that unlike in compare() zero-length inputs are considered\n * _not_ equal, so this function will return false.\n */\nexport function equal(a: Uint8Array, b: Uint8Array): boolean {\n if (a.length === 0 || b.length === 0) {\n return false;\n }\n return compare(a, b) !== 0;\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package sha256 implements SHA-2-256 cryptographic hash function.\n */\n\nimport { SerializableHash } from \"@stablelib/hash\";\nimport { readUint32BE, writeUint32BE } from \"@stablelib/binary\";\nimport { wipe } from \"@stablelib/wipe\";\n\nexport const DIGEST_LENGTH = 32;\nexport const BLOCK_SIZE = 64;\n\n/**\n * SHA2-256 cryptographic hash algorithm.\n */\nexport class SHA256 implements SerializableHash {\n /** Length of hash output */\n readonly digestLength: number = DIGEST_LENGTH;\n\n /** Block size */\n readonly blockSize: number = BLOCK_SIZE;\n\n // Note: Int32Array is used instead of Uint32Array for performance reasons.\n protected _state = new Int32Array(8); // hash state\n private _temp = new Int32Array(64); // temporary state\n private _buffer = new Uint8Array(128); // buffer for data to hash\n private _bufferLength = 0; // number of bytes in buffer\n private _bytesHashed = 0; // number of total bytes hashed\n private _finished = false; // indicates whether the hash was finalized\n\n constructor() {\n this.reset();\n }\n\n protected _initState() {\n this._state[0] = 0x6a09e667;\n this._state[1] = 0xbb67ae85;\n this._state[2] = 0x3c6ef372;\n this._state[3] = 0xa54ff53a;\n this._state[4] = 0x510e527f;\n this._state[5] = 0x9b05688c;\n this._state[6] = 0x1f83d9ab;\n this._state[7] = 0x5be0cd19;\n }\n\n /**\n * Resets hash state making it possible\n * to re-use this instance to hash other data.\n */\n reset(): this {\n this._initState();\n this._bufferLength = 0;\n this._bytesHashed = 0;\n this._finished = false;\n return this;\n }\n\n /**\n * Cleans internal buffers and resets hash state.\n */\n clean() {\n wipe(this._buffer);\n wipe(this._temp);\n this.reset();\n }\n\n /**\n * Updates hash state with the given data.\n *\n * Throws error when trying to update already finalized hash:\n * instance must be reset to update it again.\n */\n update(data: Uint8Array, dataLength: number = data.length): this {\n if (this._finished) {\n throw new Error(\"SHA256: can't update because hash was finished.\");\n }\n let dataPos = 0;\n this._bytesHashed += dataLength;\n if (this._bufferLength > 0) {\n while (this._bufferLength < this.blockSize && dataLength > 0) {\n this._buffer[this._bufferLength++] = data[dataPos++];\n dataLength--;\n }\n if (this._bufferLength === this.blockSize) {\n hashBlocks(this._temp, this._state, this._buffer, 0, this.blockSize);\n this._bufferLength = 0;\n }\n }\n if (dataLength >= this.blockSize) {\n dataPos = hashBlocks(this._temp, this._state, data, dataPos, dataLength);\n dataLength %= this.blockSize;\n }\n while (dataLength > 0) {\n this._buffer[this._bufferLength++] = data[dataPos++];\n dataLength--;\n }\n return this;\n }\n\n /**\n * Finalizes hash state and puts hash into out.\n * If hash was already finalized, puts the same value.\n */\n finish(out: Uint8Array): this {\n if (!this._finished) {\n const bytesHashed = this._bytesHashed;\n const left = this._bufferLength;\n const bitLenHi = (bytesHashed / 0x20000000) | 0;\n const bitLenLo = bytesHashed << 3;\n const padLength = (bytesHashed % 64 < 56) ? 64 : 128;\n\n this._buffer[left] = 0x80;\n for (let i = left + 1; i < padLength - 8; i++) {\n this._buffer[i] = 0;\n }\n writeUint32BE(bitLenHi, this._buffer, padLength - 8);\n writeUint32BE(bitLenLo, this._buffer, padLength - 4);\n\n hashBlocks(this._temp, this._state, this._buffer, 0, padLength);\n\n this._finished = true;\n }\n\n for (let i = 0; i < this.digestLength / 4; i++) {\n writeUint32BE(this._state[i], out, i * 4);\n }\n\n return this;\n }\n\n /**\n * Returns the final hash digest.\n */\n digest(): Uint8Array {\n const out = new Uint8Array(this.digestLength);\n this.finish(out);\n return out;\n }\n\n /**\n * Function useful for HMAC/PBKDF2 optimization.\n * Returns hash state to be used with restoreState().\n * Only chain value is saved, not buffers or other\n * state variables.\n */\n saveState(): SavedState {\n if (this._finished) {\n throw new Error(\"SHA256: cannot save finished state\");\n }\n return {\n state: new Int32Array(this._state),\n buffer: this._bufferLength > 0 ? new Uint8Array(this._buffer) : undefined,\n bufferLength: this._bufferLength,\n bytesHashed: this._bytesHashed\n };\n }\n\n /**\n * Function useful for HMAC/PBKDF2 optimization.\n * Restores state saved by saveState() and sets bytesHashed\n * to the given value.\n */\n restoreState(savedState: SavedState): this {\n this._state.set(savedState.state);\n this._bufferLength = savedState.bufferLength;\n if (savedState.buffer) {\n this._buffer.set(savedState.buffer);\n }\n this._bytesHashed = savedState.bytesHashed;\n this._finished = false;\n return this;\n }\n\n /**\n * Cleans state returned by saveState().\n */\n cleanSavedState(savedState: SavedState) {\n wipe(savedState.state);\n if (savedState.buffer) {\n wipe(savedState.buffer);\n }\n savedState.bufferLength = 0;\n savedState.bytesHashed = 0;\n }\n}\n\nexport type SavedState = {\n state: Int32Array;\n buffer: Uint8Array | undefined;\n bufferLength: number;\n bytesHashed: number;\n};\n\n// Constants\nconst K = new Int32Array([\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b,\n 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01,\n 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7,\n 0xc19bf174, 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, 0x983e5152,\n 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147,\n 0x06ca6351, 0x14292967, 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc,\n 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819,\n 0xd6990624, 0xf40e3585, 0x106aa070, 0x19a4c116, 0x1e376c08,\n 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f,\n 0x682e6ff3, 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n]);\n\nfunction hashBlocks(w: Int32Array, v: Int32Array, p: Uint8Array, pos: number, len: number): number {\n while (len >= 64) {\n let a = v[0];\n let b = v[1];\n let c = v[2];\n let d = v[3];\n let e = v[4];\n let f = v[5];\n let g = v[6];\n let h = v[7];\n\n for (let i = 0; i < 16; i++) {\n let j = pos + i * 4;\n w[i] = readUint32BE(p, j);\n }\n\n for (let i = 16; i < 64; i++) {\n let u = w[i - 2];\n let t1 = (u >>> 17 | u << (32 - 17)) ^ (u >>> 19 | u << (32 - 19)) ^ (u >>> 10);\n\n u = w[i - 15];\n let t2 = (u >>> 7 | u << (32 - 7)) ^ (u >>> 18 | u << (32 - 18)) ^ (u >>> 3);\n\n w[i] = (t1 + w[i - 7] | 0) + (t2 + w[i - 16] | 0);\n }\n\n for (let i = 0; i < 64; i++) {\n let t1 = (((((e >>> 6 | e << (32 - 6)) ^ (e >>> 11 | e << (32 - 11)) ^\n (e >>> 25 | e << (32 - 25))) + ((e & f) ^ (~e & g))) | 0) +\n ((h + ((K[i] + w[i]) | 0)) | 0)) | 0;\n\n let t2 = (((a >>> 2 | a << (32 - 2)) ^ (a >>> 13 | a << (32 - 13)) ^\n (a >>> 22 | a << (32 - 22))) + ((a & b) ^ (a & c) ^ (b & c))) | 0;\n\n h = g;\n g = f;\n f = e;\n e = (d + t1) | 0;\n d = c;\n c = b;\n b = a;\n a = (t1 + t2) | 0;\n }\n\n v[0] += a;\n v[1] += b;\n v[2] += c;\n v[3] += d;\n v[4] += e;\n v[5] += f;\n v[6] += g;\n v[7] += h;\n\n pos += 64;\n len -= 64;\n }\n return pos;\n}\n\nexport function hash(data: Uint8Array): Uint8Array {\n const h = new SHA256();\n h.update(data);\n const digest = h.digest();\n h.clean();\n return digest;\n}\n","/*eslint-disable block-scoped-var, id-length, no-control-regex, no-magic-numbers, no-prototype-builtins, no-redeclare, no-shadow, no-var, sort-vars*/\n(function(global, factory) { /* global define, require, module */\n\n /* AMD */ if (typeof define === 'function' && define.amd)\n define([\"protobufjs/minimal\"], factory);\n\n /* CommonJS */ else if (typeof require === 'function' && typeof module === 'object' && module && module.exports)\n module.exports = factory(require(\"protobufjs/minimal\"));\n\n})(this, function($protobuf) {\n \"use strict\";\n\n // Common aliases\n var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n \n // Exported root namespace\n var $root = $protobuf.roots[\"libp2p-noise\"] || ($protobuf.roots[\"libp2p-noise\"] = {});\n \n $root.pb = (function() {\n \n /**\n * Namespace pb.\n * @exports pb\n * @namespace\n */\n var pb = {};\n \n pb.NoiseHandshakePayload = (function() {\n \n /**\n * Properties of a NoiseHandshakePayload.\n * @memberof pb\n * @interface INoiseHandshakePayload\n * @property {Uint8Array|null} [identityKey] NoiseHandshakePayload identityKey\n * @property {Uint8Array|null} [identitySig] NoiseHandshakePayload identitySig\n * @property {Uint8Array|null} [data] NoiseHandshakePayload data\n */\n \n /**\n * Constructs a new NoiseHandshakePayload.\n * @memberof pb\n * @classdesc Represents a NoiseHandshakePayload.\n * @implements INoiseHandshakePayload\n * @constructor\n * @param {pb.INoiseHandshakePayload=} [properties] Properties to set\n */\n function NoiseHandshakePayload(properties) {\n if (properties)\n for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)\n if (properties[keys[i]] != null)\n this[keys[i]] = properties[keys[i]];\n }\n \n /**\n * NoiseHandshakePayload identityKey.\n * @member {Uint8Array} identityKey\n * @memberof pb.NoiseHandshakePayload\n * @instance\n */\n NoiseHandshakePayload.prototype.identityKey = $util.newBuffer([]);\n \n /**\n * NoiseHandshakePayload identitySig.\n * @member {Uint8Array} identitySig\n * @memberof pb.NoiseHandshakePayload\n * @instance\n */\n NoiseHandshakePayload.prototype.identitySig = $util.newBuffer([]);\n \n /**\n * NoiseHandshakePayload data.\n * @member {Uint8Array} data\n * @memberof pb.NoiseHandshakePayload\n * @instance\n */\n NoiseHandshakePayload.prototype.data = $util.newBuffer([]);\n \n /**\n * Creates a new NoiseHandshakePayload instance using the specified properties.\n * @function create\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {pb.INoiseHandshakePayload=} [properties] Properties to set\n * @returns {pb.NoiseHandshakePayload} NoiseHandshakePayload instance\n */\n NoiseHandshakePayload.create = function create(properties) {\n return new NoiseHandshakePayload(properties);\n };\n \n /**\n * Encodes the specified NoiseHandshakePayload message. Does not implicitly {@link pb.NoiseHandshakePayload.verify|verify} messages.\n * @function encode\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {pb.INoiseHandshakePayload} message NoiseHandshakePayload message or plain object to encode\n * @param {$protobuf.Writer} [writer] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n NoiseHandshakePayload.encode = function encode(message, writer) {\n if (!writer)\n writer = $Writer.create();\n if (message.identityKey != null && Object.hasOwnProperty.call(message, \"identityKey\"))\n writer.uint32(/* id 1, wireType 2 =*/10).bytes(message.identityKey);\n if (message.identitySig != null && Object.hasOwnProperty.call(message, \"identitySig\"))\n writer.uint32(/* id 2, wireType 2 =*/18).bytes(message.identitySig);\n if (message.data != null && Object.hasOwnProperty.call(message, \"data\"))\n writer.uint32(/* id 3, wireType 2 =*/26).bytes(message.data);\n return writer;\n };\n \n /**\n * Encodes the specified NoiseHandshakePayload message, length delimited. Does not implicitly {@link pb.NoiseHandshakePayload.verify|verify} messages.\n * @function encodeDelimited\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {pb.INoiseHandshakePayload} message NoiseHandshakePayload message or plain object to encode\n * @param {$protobuf.Writer} [writer] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n NoiseHandshakePayload.encodeDelimited = function encodeDelimited(message, writer) {\n return this.encode(message, writer).ldelim();\n };\n \n /**\n * Decodes a NoiseHandshakePayload message from the specified reader or buffer.\n * @function decode\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from\n * @param {number} [length] Message length if known beforehand\n * @returns {pb.NoiseHandshakePayload} NoiseHandshakePayload\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n NoiseHandshakePayload.decode = function decode(reader, length) {\n if (!(reader instanceof $Reader))\n reader = $Reader.create(reader);\n var end = length === undefined ? reader.len : reader.pos + length, message = new $root.pb.NoiseHandshakePayload();\n while (reader.pos < end) {\n var tag = reader.uint32();\n switch (tag >>> 3) {\n case 1:\n message.identityKey = reader.bytes();\n break;\n case 2:\n message.identitySig = reader.bytes();\n break;\n case 3:\n message.data = reader.bytes();\n break;\n default:\n reader.skipType(tag & 7);\n break;\n }\n }\n return message;\n };\n \n /**\n * Decodes a NoiseHandshakePayload message from the specified reader or buffer, length delimited.\n * @function decodeDelimited\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from\n * @returns {pb.NoiseHandshakePayload} NoiseHandshakePayload\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n NoiseHandshakePayload.decodeDelimited = function decodeDelimited(reader) {\n if (!(reader instanceof $Reader))\n reader = new $Reader(reader);\n return this.decode(reader, reader.uint32());\n };\n \n /**\n * Verifies a NoiseHandshakePayload message.\n * @function verify\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {Object.<string,*>} message Plain object to verify\n * @returns {string|null} `null` if valid, otherwise the reason why it is not\n */\n NoiseHandshakePayload.verify = function verify(message) {\n if (typeof message !== \"object\" || message === null)\n return \"object expected\";\n if (message.identityKey != null && message.hasOwnProperty(\"identityKey\"))\n if (!(message.identityKey && typeof message.identityKey.length === \"number\" || $util.isString(message.identityKey)))\n return \"identityKey: buffer expected\";\n if (message.identitySig != null && message.hasOwnProperty(\"identitySig\"))\n if (!(message.identitySig && typeof message.identitySig.length === \"number\" || $util.isString(message.identitySig)))\n return \"identitySig: buffer expected\";\n if (message.data != null && message.hasOwnProperty(\"data\"))\n if (!(message.data && typeof message.data.length === \"number\" || $util.isString(message.data)))\n return \"data: buffer expected\";\n return null;\n };\n \n /**\n * Creates a NoiseHandshakePayload message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {Object.<string,*>} object Plain object\n * @returns {pb.NoiseHandshakePayload} NoiseHandshakePayload\n */\n NoiseHandshakePayload.fromObject = function fromObject(object) {\n if (object instanceof $root.pb.NoiseHandshakePayload)\n return object;\n var message = new $root.pb.NoiseHandshakePayload();\n if (object.identityKey != null)\n if (typeof object.identityKey === \"string\")\n $util.base64.decode(object.identityKey, message.identityKey = $util.newBuffer($util.base64.length(object.identityKey)), 0);\n else if (object.identityKey.length)\n message.identityKey = object.identityKey;\n if (object.identitySig != null)\n if (typeof object.identitySig === \"string\")\n $util.base64.decode(object.identitySig, message.identitySig = $util.newBuffer($util.base64.length(object.identitySig)), 0);\n else if (object.identitySig.length)\n message.identitySig = object.identitySig;\n if (object.data != null)\n if (typeof object.data === \"string\")\n $util.base64.decode(object.data, message.data = $util.newBuffer($util.base64.length(object.data)), 0);\n else if (object.data.length)\n message.data = object.data;\n return message;\n };\n \n /**\n * Creates a plain object from a NoiseHandshakePayload message. Also converts values to other types if specified.\n * @function toObject\n * @memberof pb.NoiseHandshakePayload\n * @static\n * @param {pb.NoiseHandshakePayload} message NoiseHandshakePayload\n * @param {$protobuf.IConversionOptions} [options] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n NoiseHandshakePayload.toObject = function toObject(message, options) {\n if (!options)\n options = {};\n var object = {};\n if (options.defaults) {\n if (options.bytes === String)\n object.identityKey = \"\";\n else {\n object.identityKey = [];\n if (options.bytes !== Array)\n object.identityKey = $util.newBuffer(object.identityKey);\n }\n if (options.bytes === String)\n object.identitySig = \"\";\n else {\n object.identitySig = [];\n if (options.bytes !== Array)\n object.identitySig = $util.newBuffer(object.identitySig);\n }\n if (options.bytes === String)\n object.data = \"\";\n else {\n object.data = [];\n if (options.bytes !== Array)\n object.data = $util.newBuffer(object.data);\n }\n }\n if (message.identityKey != null && message.hasOwnProperty(\"identityKey\"))\n object.identityKey = options.bytes === String ? $util.base64.encode(message.identityKey, 0, message.identityKey.length) : options.bytes === Array ? Array.prototype.slice.call(message.identityKey) : message.identityKey;\n if (message.identitySig != null && message.hasOwnProperty(\"identitySig\"))\n object.identitySig = options.bytes === String ? $util.base64.encode(message.identitySig, 0, message.identitySig.length) : options.bytes === Array ? Array.prototype.slice.call(message.identitySig) : message.identitySig;\n if (message.data != null && message.hasOwnProperty(\"data\"))\n object.data = options.bytes === String ? $util.base64.encode(message.data, 0, message.data.length) : options.bytes === Array ? Array.prototype.slice.call(message.data) : message.data;\n return object;\n };\n \n /**\n * Converts this NoiseHandshakePayload to JSON.\n * @function toJSON\n * @memberof pb.NoiseHandshakePayload\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n NoiseHandshakePayload.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n \n return NoiseHandshakePayload;\n })();\n \n return pb;\n })();\n\n return $root;\n});\n","import { Buffer } from 'buffer'\nimport * as x25519 from '@stablelib/x25519'\nimport * as SHA256 from '@stablelib/sha256'\nimport { ChaCha20Poly1305 } from '@stablelib/chacha20poly1305'\n\nimport { bytes, bytes32, uint32 } from '../@types/basic'\nimport { CipherState, MessageBuffer, SymmetricState } from '../@types/handshake'\nimport { getHkdf } from '../utils'\nimport { logger } from '../logger'\n\nexport const MIN_NONCE = 0\n\nexport abstract class AbstractHandshake {\n public encryptWithAd (cs: CipherState, ad: bytes, plaintext: bytes): bytes {\n const e = this.encrypt(cs.k, cs.n, ad, plaintext)\n this.setNonce(cs, this.incrementNonce(cs.n))\n\n return e\n }\n\n public decryptWithAd (cs: CipherState, ad: bytes, ciphertext: bytes): {plaintext: bytes, valid: boolean} {\n const { plaintext, valid } = this.decrypt(cs.k, cs.n, ad, ciphertext)\n this.setNonce(cs, this.incrementNonce(cs.n))\n\n return { plaintext, valid }\n }\n\n // Cipher state related\n protected hasKey (cs: CipherState): boolean {\n return !this.isEmptyKey(cs.k)\n }\n\n protected setNonce (cs: CipherState, nonce: uint32): void {\n cs.n = nonce\n }\n\n protected createEmptyKey (): bytes32 {\n return Buffer.alloc(32)\n }\n\n protected isEmptyKey (k: bytes32): boolean {\n const emptyKey = this.createEmptyKey()\n return emptyKey.equals(k)\n }\n\n protected incrementNonce (n: uint32): uint32 {\n return n + 1\n }\n\n protected nonceToBytes (n: uint32): bytes {\n const nonce = Buffer.alloc(12)\n nonce.writeUInt32LE(n, 4)\n\n return nonce\n }\n\n protected encrypt (k: bytes32, n: uint32, ad: bytes, plaintext: bytes): bytes {\n const nonce = this.nonceToBytes(n)\n const ctx = new ChaCha20Poly1305(k)\n const encryptedMessage = ctx.seal(nonce, plaintext, ad)\n return Buffer.from(encryptedMessage.buffer, encryptedMessage.byteOffset, encryptedMessage.length)\n }\n\n protected encryptAndHash (ss: SymmetricState, plaintext: bytes): bytes {\n let ciphertext\n if (this.hasKey(ss.cs)) {\n ciphertext = this.encryptWithAd(ss.cs, ss.h, plaintext)\n } else {\n ciphertext = plaintext\n }\n\n this.mixHash(ss, ciphertext)\n return ciphertext\n }\n\n protected decrypt (k: bytes32, n: uint32, ad: bytes, ciphertext: bytes): {plaintext: bytes, valid: boolean} {\n const nonce = this.nonceToBytes(n)\n const ctx = new ChaCha20Poly1305(k)\n const encryptedMessage = ctx.open(\n nonce,\n ciphertext,\n ad\n )\n if (encryptedMessage) {\n return {\n plaintext: Buffer.from(\n encryptedMessage.buffer,\n encryptedMessage.byteOffset,\n encryptedMessage.length\n ),\n valid: true\n }\n } else {\n return {\n plaintext: Buffer.from(''),\n valid: false\n }\n }\n }\n\n protected decryptAndHash (ss: SymmetricState, ciphertext: bytes): {plaintext: bytes, valid: boolean} {\n let plaintext: bytes; let valid = true\n if (this.hasKey(ss.cs)) {\n ({ plaintext, valid } = this.decryptWithAd(ss.cs, ss.h, ciphertext))\n } else {\n plaintext = ciphertext\n }\n\n this.mixHash(ss, ciphertext)\n return { plaintext, valid }\n }\n\n protected dh (privateKey: bytes32, publicKey: bytes32): bytes32 {\n try {\n const derivedU8 = x25519.sharedKey(privateKey, publicKey)\n const derived = Buffer.from(derivedU8.buffer, derivedU8.byteOffset, derivedU8.length)\n const result = Buffer.alloc(32)\n derived.copy(result)\n return result\n } catch (e) {\n logger(e.message)\n return Buffer.alloc(32)\n }\n }\n\n protected mixHash (ss: SymmetricState, data: bytes): void {\n ss.h = this.getHash(ss.h, data)\n }\n\n protected getHash (a: bytes, b: bytes): bytes32 {\n const hash = SHA256.hash(Buffer.from([...a, ...b]))\n return Buffer.from(hash.buffer, hash.byteOffset, hash.length)\n }\n\n protected mixKey (ss: SymmetricState, ikm: bytes32): void {\n const [ck, tempK] = getHkdf(ss.ck, ikm)\n ss.cs = this.initializeKey(tempK)\n ss.ck = ck\n }\n\n protected initializeKey (k: bytes32): CipherState {\n const n = MIN_NONCE\n return { k, n }\n }\n\n // Symmetric state related\n\n protected initializeSymmetric (protocolName: string): SymmetricState {\n const protocolNameBytes: bytes = Buffer.from(protocolName, 'utf-8')\n const h = this.hashProtocolName(protocolNameBytes)\n\n const ck = h\n const key = this.createEmptyKey()\n const cs: CipherState = this.initializeKey(key)\n\n return { cs, ck, h }\n }\n\n protected hashProtocolName (protocolName: bytes): bytes32 {\n if (protocolName.length <= 32) {\n const h = Buffer.alloc(32)\n protocolName.copy(h)\n return h\n } else {\n return this.getHash(protocolName, Buffer.alloc(0))\n }\n }\n\n protected split (ss: SymmetricState): {cs1: CipherState, cs2: CipherState} {\n const [tempk1, tempk2] = getHkdf(ss.ck, Buffer.alloc(0))\n const cs1 = this.initializeKey(tempk1)\n const cs2 = this.initializeKey(tempk2)\n\n return { cs1, cs2 }\n }\n\n protected writeMessageRegular (cs: CipherState, payload: bytes): MessageBuffer {\n const ciphertext = this.encryptWithAd(cs, Buffer.alloc(0), payload)\n const ne = this.createEmptyKey()\n const ns = Buffer.alloc(0)\n\n return { ne, ns, ciphertext }\n }\n\n protected readMessageRegular (cs: CipherState, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n return this.decryptWithAd(cs, Buffer.alloc(0), message.ciphertext)\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package chacha20poly1305 implements ChaCha20-Poly1305 AEAD.\n */\n\nimport { AEAD } from \"@stablelib/aead\";\nimport { streamXOR, stream } from \"@stablelib/chacha\";\nimport { Poly1305 } from \"@stablelib/poly1305\";\nimport { wipe } from \"@stablelib/wipe\";\nimport { writeUint64LE } from \"@stablelib/binary\";\nimport { equal } from \"@stablelib/constant-time\";\n\nexport const KEY_LENGTH = 32;\nexport const NONCE_LENGTH = 12;\nexport const TAG_LENGTH = 16;\n\nconst ZEROS = new Uint8Array(16);\n\n/**\n * ChaCha20-Poly1305 Authenticated Encryption with Associated Data.\n *\n * Defined in RFC7539.\n */\nexport class ChaCha20Poly1305 implements AEAD {\n readonly nonceLength = NONCE_LENGTH;\n readonly tagLength = TAG_LENGTH;\n\n private _key: Uint8Array;\n\n /**\n * Creates a new instance with the given 32-byte key.\n */\n constructor(key: Uint8Array) {\n if (key.length !== KEY_LENGTH) {\n throw new Error(\"ChaCha20Poly1305 needs 32-byte key\");\n }\n // Copy key.\n this._key = new Uint8Array(key);\n }\n\n /**\n * Encrypts and authenticates plaintext, authenticates associated data,\n * and returns sealed ciphertext, which includes authentication tag.\n *\n * RFC7539 specifies 12 bytes for nonce. It may be this 12-byte nonce\n * (\"IV\"), or full 16-byte counter (called \"32-bit fixed-common part\")\n * and nonce.\n *\n * If dst is given (it must be the size of plaintext + the size of tag\n * length) the result will be put into it. Dst and plaintext must not\n * overlap.\n */\n seal(nonce: Uint8Array, plaintext: Uint8Array, associatedData?: Uint8Array,\n dst?: Uint8Array): Uint8Array {\n if (nonce.length > 16) {\n throw new Error(\"ChaCha20Poly1305: incorrect nonce length\");\n }\n\n // Allocate space for counter, and set nonce as last bytes of it.\n const counter = new Uint8Array(16);\n counter.set(nonce, counter.length - nonce.length);\n\n // Generate authentication key by taking first 32-bytes of stream.\n // We pass full counter, which has 12-byte nonce and 4-byte block counter,\n // and it will get incremented after generating the block, which is\n // exactly what we need: we only use the first 32 bytes of 64-byte\n // ChaCha block and discard the next 32 bytes.\n const authKey = new Uint8Array(32);\n stream(this._key, counter, authKey, 4);\n\n // Allocate space for sealed ciphertext.\n const resultLength = plaintext.length + this.tagLength;\n let result;\n if (dst) {\n if (dst.length !== resultLength) {\n throw new Error(\"ChaCha20Poly1305: incorrect destination length\");\n }\n result = dst;\n } else {\n result = new Uint8Array(resultLength);\n }\n\n // Encrypt plaintext.\n streamXOR(this._key, counter, plaintext, result, 4);\n\n // Authenticate.\n // XXX: can \"simplify\" here: pass full result (which is already padded\n // due to zeroes prepared for tag), and ciphertext length instead of\n // subarray of result.\n this._authenticate(result.subarray(result.length - this.tagLength, result.length),\n authKey, result.subarray(0, result.length - this.tagLength), associatedData);\n\n // Cleanup.\n wipe(counter);\n\n return result;\n }\n\n /**\n * Authenticates sealed ciphertext (which includes authentication tag) and\n * associated data, decrypts ciphertext and returns decrypted plaintext.\n *\n * RFC7539 specifies 12 bytes for nonce. It may be this 12-byte nonce\n * (\"IV\"), or full 16-byte counter (called \"32-bit fixed-common part\")\n * and nonce.\n *\n * If authentication fails, it returns null.\n *\n * If dst is given (it must be of ciphertext length minus tag length),\n * the result will be put into it. Dst and plaintext must not overlap.\n */\n open(nonce: Uint8Array, sealed: Uint8Array, associatedData?: Uint8Array,\n dst?: Uint8Array): Uint8Array | null {\n if (nonce.length > 16) {\n throw new Error(\"ChaCha20Poly1305: incorrect nonce length\");\n }\n\n // Sealed ciphertext should at least contain tag.\n if (sealed.length < this.tagLength) {\n // TODO(dchest): should we throw here instead?\n return null;\n }\n\n // Allocate space for counter, and set nonce as last bytes of it.\n const counter = new Uint8Array(16);\n counter.set(nonce, counter.length - nonce.length);\n\n // Generate authentication key by taking first 32-bytes of stream.\n const authKey = new Uint8Array(32);\n stream(this._key, counter, authKey, 4);\n\n // Authenticate.\n // XXX: can simplify and avoid allocation: since authenticate()\n // already allocates tag (from Poly1305.digest(), it can return)\n // it instead of copying to calculatedTag. But then in seal()\n // we'll need to copy it.\n const calculatedTag = new Uint8Array(this.tagLength);\n this._authenticate(calculatedTag, authKey,\n sealed.subarray(0, sealed.length - this.tagLength), associatedData);\n\n // Constant-time compare tags and return null if they differ.\n if (!equal(calculatedTag,\n sealed.subarray(sealed.length - this.tagLength, sealed.length))) {\n return null;\n }\n\n // Allocate space for decrypted plaintext.\n const resultLength = sealed.length - this.tagLength;\n let result;\n if (dst) {\n if (dst.length !== resultLength) {\n throw new Error(\"ChaCha20Poly1305: incorrect destination length\");\n }\n result = dst;\n } else {\n result = new Uint8Array(resultLength);\n }\n\n // Decrypt.\n streamXOR(this._key, counter,\n sealed.subarray(0, sealed.length - this.tagLength), result, 4);\n\n // Cleanup.\n wipe(counter);\n\n return result;\n }\n\n clean(): this {\n wipe(this._key);\n return this;\n }\n\n private _authenticate(tagOut: Uint8Array, authKey: Uint8Array,\n ciphertext: Uint8Array, associatedData?: Uint8Array) {\n\n // Initialize Poly1305 with authKey.\n const h = new Poly1305(authKey);\n\n // Authenticate padded associated data.\n if (associatedData) {\n h.update(associatedData);\n if (associatedData.length % 16 > 0) {\n h.update(ZEROS.subarray(associatedData.length % 16));\n }\n }\n\n // Authenticate padded ciphertext.\n h.update(ciphertext);\n if (ciphertext.length % 16 > 0) {\n h.update(ZEROS.subarray(ciphertext.length % 16));\n }\n\n // Authenticate length of associated data.\n // XXX: can avoid allocation here?\n const length = new Uint8Array(8);\n if (associatedData) {\n writeUint64LE(associatedData.length, length);\n }\n h.update(length);\n\n // Authenticate length of ciphertext.\n writeUint64LE(ciphertext.length, length);\n h.update(length);\n\n // Get tag and copy it into tagOut.\n const tag = h.digest();\n for (let i = 0; i < tag.length; i++) {\n tagOut[i] = tag[i];\n }\n\n // Cleanup.\n h.clean();\n wipe(tag);\n wipe(length);\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package chacha implements ChaCha stream cipher.\n */\n\nimport { writeUint32LE } from \"@stablelib/binary\";\nimport { wipe } from \"@stablelib/wipe\";\n\n// Number of ChaCha rounds (ChaCha20).\nconst ROUNDS = 20;\n\n// Applies the ChaCha core function to 16-byte input,\n// 32-byte key key, and puts the result into 64-byte array out.\nfunction core(out: Uint8Array, input: Uint8Array, key: Uint8Array): void {\n let j0 = 0x61707865; // \"expa\" -- ChaCha's \"sigma\" constant\n let j1 = 0x3320646E; // \"nd 3\" for 32-byte keys\n let j2 = 0x79622D32; // \"2-by\"\n let j3 = 0x6B206574; // \"te k\"\n let j4 = (key[3] << 24) | (key[2] << 16) | (key[1] << 8) | key[0];\n let j5 = (key[7] << 24) | (key[6] << 16) | (key[5] << 8) | key[4];\n let j6 = (key[11] << 24) | (key[10] << 16) | (key[9] << 8) | key[8];\n let j7 = (key[15] << 24) | (key[14] << 16) | (key[13] << 8) | key[12];\n let j8 = (key[19] << 24) | (key[18] << 16) | (key[17] << 8) | key[16];\n let j9 = (key[23] << 24) | (key[22] << 16) | (key[21] << 8) | key[20];\n let j10 = (key[27] << 24) | (key[26] << 16) | (key[25] << 8) | key[24];\n let j11 = (key[31] << 24) | (key[30] << 16) | (key[29] << 8) | key[28];\n let j12 = (input[3] << 24) | (input[2] << 16) | (input[1] << 8) | input[0];\n let j13 = (input[7] << 24) | (input[6] << 16) | (input[5] << 8) | input[4];\n let j14 = (input[11] << 24) | (input[10] << 16) | (input[9] << 8) | input[8];\n let j15 = (input[15] << 24) | (input[14] << 16) | (input[13] << 8) | input[12];\n\n let x0 = j0;\n let x1 = j1;\n let x2 = j2;\n let x3 = j3;\n let x4 = j4;\n let x5 = j5;\n let x6 = j6;\n let x7 = j7;\n let x8 = j8;\n let x9 = j9;\n let x10 = j10;\n let x11 = j11;\n let x12 = j12;\n let x13 = j13;\n let x14 = j14;\n let x15 = j15;\n\n for (let i = 0; i < ROUNDS; i += 2) {\n x0 = x0 + x4 | 0; x12 ^= x0; x12 = x12 >>> (32 - 16) | x12 << 16;\n x8 = x8 + x12 | 0; x4 ^= x8; x4 = x4 >>> (32 - 12) | x4 << 12;\n x1 = x1 + x5 | 0; x13 ^= x1; x13 = x13 >>> (32 - 16) | x13 << 16;\n x9 = x9 + x13 | 0; x5 ^= x9; x5 = x5 >>> (32 - 12) | x5 << 12;\n\n x2 = x2 + x6 | 0; x14 ^= x2; x14 = x14 >>> (32 - 16) | x14 << 16;\n x10 = x10 + x14 | 0; x6 ^= x10; x6 = x6 >>> (32 - 12) | x6 << 12;\n x3 = x3 + x7 | 0; x15 ^= x3; x15 = x15 >>> (32 - 16) | x15 << 16;\n x11 = x11 + x15 | 0; x7 ^= x11; x7 = x7 >>> (32 - 12) | x7 << 12;\n\n x2 = x2 + x6 | 0; x14 ^= x2; x14 = x14 >>> (32 - 8) | x14 << 8;\n x10 = x10 + x14 | 0; x6 ^= x10; x6 = x6 >>> (32 - 7) | x6 << 7;\n x3 = x3 + x7 | 0; x15 ^= x3; x15 = x15 >>> (32 - 8) | x15 << 8;\n x11 = x11 + x15 | 0; x7 ^= x11; x7 = x7 >>> (32 - 7) | x7 << 7;\n\n x1 = x1 + x5 | 0; x13 ^= x1; x13 = x13 >>> (32 - 8) | x13 << 8;\n x9 = x9 + x13 | 0; x5 ^= x9; x5 = x5 >>> (32 - 7) | x5 << 7;\n x0 = x0 + x4 | 0; x12 ^= x0; x12 = x12 >>> (32 - 8) | x12 << 8;\n x8 = x8 + x12 | 0; x4 ^= x8; x4 = x4 >>> (32 - 7) | x4 << 7;\n\n x0 = x0 + x5 | 0; x15 ^= x0; x15 = x15 >>> (32 - 16) | x15 << 16;\n x10 = x10 + x15 | 0; x5 ^= x10; x5 = x5 >>> (32 - 12) | x5 << 12;\n x1 = x1 + x6 | 0; x12 ^= x1; x12 = x12 >>> (32 - 16) | x12 << 16;\n x11 = x11 + x12 | 0; x6 ^= x11; x6 = x6 >>> (32 - 12) | x6 << 12;\n\n x2 = x2 + x7 | 0; x13 ^= x2; x13 = x13 >>> (32 - 16) | x13 << 16;\n x8 = x8 + x13 | 0; x7 ^= x8; x7 = x7 >>> (32 - 12) | x7 << 12;\n x3 = x3 + x4 | 0; x14 ^= x3; x14 = x14 >>> (32 - 16) | x14 << 16;\n x9 = x9 + x14 | 0; x4 ^= x9; x4 = x4 >>> (32 - 12) | x4 << 12;\n\n x2 = x2 + x7 | 0; x13 ^= x2; x13 = x13 >>> (32 - 8) | x13 << 8;\n x8 = x8 + x13 | 0; x7 ^= x8; x7 = x7 >>> (32 - 7) | x7 << 7;\n x3 = x3 + x4 | 0; x14 ^= x3; x14 = x14 >>> (32 - 8) | x14 << 8;\n x9 = x9 + x14 | 0; x4 ^= x9; x4 = x4 >>> (32 - 7) | x4 << 7;\n\n x1 = x1 + x6 | 0; x12 ^= x1; x12 = x12 >>> (32 - 8) | x12 << 8;\n x11 = x11 + x12 | 0; x6 ^= x11; x6 = x6 >>> (32 - 7) | x6 << 7;\n x0 = x0 + x5 | 0; x15 ^= x0; x15 = x15 >>> (32 - 8) | x15 << 8;\n x10 = x10 + x15 | 0; x5 ^= x10; x5 = x5 >>> (32 - 7) | x5 << 7;\n }\n writeUint32LE(x0 + j0 | 0, out, 0);\n writeUint32LE(x1 + j1 | 0, out, 4);\n writeUint32LE(x2 + j2 | 0, out, 8);\n writeUint32LE(x3 + j3 | 0, out, 12);\n writeUint32LE(x4 + j4 | 0, out, 16);\n writeUint32LE(x5 + j5 | 0, out, 20);\n writeUint32LE(x6 + j6 | 0, out, 24);\n writeUint32LE(x7 + j7 | 0, out, 28);\n writeUint32LE(x8 + j8 | 0, out, 32);\n writeUint32LE(x9 + j9 | 0, out, 36);\n writeUint32LE(x10 + j10 | 0, out, 40);\n writeUint32LE(x11 + j11 | 0, out, 44);\n writeUint32LE(x12 + j12 | 0, out, 48);\n writeUint32LE(x13 + j13 | 0, out, 52);\n writeUint32LE(x14 + j14 | 0, out, 56);\n writeUint32LE(x15 + j15 | 0, out, 60);\n}\n\n/**\n * Encrypt src with ChaCha20 stream generated for the given 32-byte key and\n * 8-byte (as in original implementation) or 12-byte (as in RFC7539) nonce and\n * write the result into dst and return it.\n *\n * dst and src may be the same, but otherwise must not overlap.\n *\n * If nonce is 12 bytes, users should not encrypt more than 256 GiB with the\n * same key and nonce, otherwise the stream will repeat. The function will\n * throw error if counter overflows to prevent this.\n *\n * If nonce is 8 bytes, the output is practically unlimited (2^70 bytes, which\n * is more than a million petabytes). However, it is not recommended to\n * generate 8-byte nonces randomly, as the chance of collision is high.\n *\n * Never use the same key and nonce to encrypt more than one message.\n *\n * If nonceInplaceCounterLength is not 0, the nonce is assumed to be a 16-byte\n * array with stream counter in first nonceInplaceCounterLength bytes and nonce\n * in the last remaining bytes. The counter will be incremented inplace for\n * each ChaCha block. This is useful if you need to encrypt one stream of data\n * in chunks.\n */\nexport function streamXOR(key: Uint8Array, nonce: Uint8Array,\n src: Uint8Array, dst: Uint8Array, nonceInplaceCounterLength = 0): Uint8Array {\n // We only support 256-bit keys.\n if (key.length !== 32) {\n throw new Error(\"ChaCha: key size must be 32 bytes\");\n }\n\n if (dst.length < src.length) {\n throw new Error(\"ChaCha: destination is shorter than source\");\n }\n\n let nc: Uint8Array;\n let counterLength: number;\n\n if (nonceInplaceCounterLength === 0) {\n if (nonce.length !== 8 && nonce.length !== 12) {\n throw new Error(\"ChaCha nonce must be 8 or 12 bytes\");\n }\n nc = new Uint8Array(16);\n // First counterLength bytes of nc are counter, starting with zero.\n counterLength = nc.length - nonce.length;\n // Last bytes of nc after counterLength are nonce, set them.\n nc.set(nonce, counterLength);\n } else {\n if (nonce.length !== 16) {\n throw new Error(\"ChaCha nonce with counter must be 16 bytes\");\n }\n // This will update passed nonce with counter inplace.\n nc = nonce;\n counterLength = nonceInplaceCounterLength;\n }\n\n // Allocate temporary space for ChaCha block.\n const block = new Uint8Array(64);\n\n for (let i = 0; i < src.length; i += 64) {\n // Generate a block.\n core(block, nc, key);\n\n // XOR block bytes with src into dst.\n for (let j = i; j < i + 64 && j < src.length; j++) {\n dst[j] = src[j] ^ block[j - i];\n }\n\n // Increment counter.\n incrementCounter(nc, 0, counterLength);\n }\n\n // Cleanup temporary space.\n wipe(block);\n\n if (nonceInplaceCounterLength === 0) {\n // Cleanup counter.\n wipe(nc);\n }\n\n return dst;\n}\n\n/**\n * Generate ChaCha20 stream for the given 32-byte key and 8-byte or 12-byte\n * nonce and write it into dst and return it.\n *\n * Never use the same key and nonce to generate more than one stream.\n *\n * If nonceInplaceCounterLength is not 0, it behaves the same with respect to\n * the nonce as described in the streamXOR documentation.\n *\n * stream is like streamXOR with all-zero src.\n */\nexport function stream(key: Uint8Array, nonce: Uint8Array,\n dst: Uint8Array, nonceInplaceCounterLength = 0): Uint8Array {\n wipe(dst);\n return streamXOR(key, nonce, dst, dst, nonceInplaceCounterLength);\n}\n\nfunction incrementCounter(counter: Uint8Array, pos: number, len: number) {\n let carry = 1;\n while (len--) {\n carry = carry + (counter[pos] & 0xff) | 0;\n counter[pos] = carry & 0xff;\n carry >>>= 8;\n pos++;\n }\n if (carry > 0) {\n throw new Error(\"ChaCha: counter overflow\");\n }\n}\n","// Copyright (C) 2016 Dmitry Chestnykh\n// MIT License. See LICENSE file for details.\n\n/**\n * Package poly1305 implements Poly1305 one-time message authentication algorithm.\n */\n\nimport { equal as constantTimeEqual } from \"@stablelib/constant-time\";\nimport { wipe } from \"@stablelib/wipe\";\n\nexport const DIGEST_LENGTH = 16;\n\n// Port of Andrew Moon's Poly1305-donna-16. Public domain.\n// https://github.com/floodyberry/poly1305-donna\n\n/**\n * Poly1305 computes 16-byte authenticator of message using\n * a one-time 32-byte key.\n *\n * Important: key should be used for only one message,\n * it should never repeat.\n */\nexport class Poly1305 {\n readonly digestLength = DIGEST_LENGTH;\n\n private _buffer = new Uint8Array(16);\n private _r = new Uint16Array(10);\n private _h = new Uint16Array(10);\n private _pad = new Uint16Array(8);\n private _leftover = 0;\n private _fin = 0;\n private _finished = false;\n\n constructor(key: Uint8Array) {\n let t0 = key[0] | key[1] << 8; this._r[0] = (t0) & 0x1fff;\n let t1 = key[2] | key[3] << 8; this._r[1] = ((t0 >>> 13) | (t1 << 3)) & 0x1fff;\n let t2 = key[4] | key[5] << 8; this._r[2] = ((t1 >>> 10) | (t2 << 6)) & 0x1f03;\n let t3 = key[6] | key[7] << 8; this._r[3] = ((t2 >>> 7) | (t3 << 9)) & 0x1fff;\n let t4 = key[8] | key[9] << 8; this._r[4] = ((t3 >>> 4) | (t4 << 12)) & 0x00ff;\n this._r[5] = ((t4 >>> 1)) & 0x1ffe;\n let t5 = key[10] | key[11] << 8; this._r[6] = ((t4 >>> 14) | (t5 << 2)) & 0x1fff;\n let t6 = key[12] | key[13] << 8; this._r[7] = ((t5 >>> 11) | (t6 << 5)) & 0x1f81;\n let t7 = key[14] | key[15] << 8; this._r[8] = ((t6 >>> 8) | (t7 << 8)) & 0x1fff;\n this._r[9] = ((t7 >>> 5)) & 0x007f;\n\n this._pad[0] = key[16] | key[17] << 8;\n this._pad[1] = key[18] | key[19] << 8;\n this._pad[2] = key[20] | key[21] << 8;\n this._pad[3] = key[22] | key[23] << 8;\n this._pad[4] = key[24] | key[25] << 8;\n this._pad[5] = key[26] | key[27] << 8;\n this._pad[6] = key[28] | key[29] << 8;\n this._pad[7] = key[30] | key[31] << 8;\n }\n\n private _blocks(m: Uint8Array, mpos: number, bytes: number) {\n let hibit = this._fin ? 0 : 1 << 11;\n\n let h0 = this._h[0],\n h1 = this._h[1],\n h2 = this._h[2],\n h3 = this._h[3],\n h4 = this._h[4],\n h5 = this._h[5],\n h6 = this._h[6],\n h7 = this._h[7],\n h8 = this._h[8],\n h9 = this._h[9];\n\n let r0 = this._r[0],\n r1 = this._r[1],\n r2 = this._r[2],\n r3 = this._r[3],\n r4 = this._r[4],\n r5 = this._r[5],\n r6 = this._r[6],\n r7 = this._r[7],\n r8 = this._r[8],\n r9 = this._r[9];\n\n while (bytes >= 16) {\n let t0 = m[mpos + 0] | m[mpos + 1] << 8; h0 += (t0) & 0x1fff;\n let t1 = m[mpos + 2] | m[mpos + 3] << 8; h1 += ((t0 >>> 13) | (t1 << 3)) & 0x1fff;\n let t2 = m[mpos + 4] | m[mpos + 5] << 8; h2 += ((t1 >>> 10) | (t2 << 6)) & 0x1fff;\n let t3 = m[mpos + 6] | m[mpos + 7] << 8; h3 += ((t2 >>> 7) | (t3 << 9)) & 0x1fff;\n let t4 = m[mpos + 8] | m[mpos + 9] << 8; h4 += ((t3 >>> 4) | (t4 << 12)) & 0x1fff;\n h5 += ((t4 >>> 1)) & 0x1fff;\n let t5 = m[mpos + 10] | m[mpos + 11] << 8; h6 += ((t4 >>> 14) | (t5 << 2)) & 0x1fff;\n let t6 = m[mpos + 12] | m[mpos + 13] << 8; h7 += ((t5 >>> 11) | (t6 << 5)) & 0x1fff;\n let t7 = m[mpos + 14] | m[mpos + 15] << 8; h8 += ((t6 >>> 8) | (t7 << 8)) & 0x1fff;\n h9 += ((t7 >>> 5)) | hibit;\n\n let c = 0;\n\n let d0 = c;\n d0 += h0 * r0;\n d0 += h1 * (5 * r9);\n d0 += h2 * (5 * r8);\n d0 += h3 * (5 * r7);\n d0 += h4 * (5 * r6);\n c = (d0 >>> 13); d0 &= 0x1fff;\n d0 += h5 * (5 * r5);\n d0 += h6 * (5 * r4);\n d0 += h7 * (5 * r3);\n d0 += h8 * (5 * r2);\n d0 += h9 * (5 * r1);\n c += (d0 >>> 13); d0 &= 0x1fff;\n\n let d1 = c;\n d1 += h0 * r1;\n d1 += h1 * r0;\n d1 += h2 * (5 * r9);\n d1 += h3 * (5 * r8);\n d1 += h4 * (5 * r7);\n c = (d1 >>> 13); d1 &= 0x1fff;\n d1 += h5 * (5 * r6);\n d1 += h6 * (5 * r5);\n d1 += h7 * (5 * r4);\n d1 += h8 * (5 * r3);\n d1 += h9 * (5 * r2);\n c += (d1 >>> 13); d1 &= 0x1fff;\n\n let d2 = c;\n d2 += h0 * r2;\n d2 += h1 * r1;\n d2 += h2 * r0;\n d2 += h3 * (5 * r9);\n d2 += h4 * (5 * r8);\n c = (d2 >>> 13); d2 &= 0x1fff;\n d2 += h5 * (5 * r7);\n d2 += h6 * (5 * r6);\n d2 += h7 * (5 * r5);\n d2 += h8 * (5 * r4);\n d2 += h9 * (5 * r3);\n c += (d2 >>> 13); d2 &= 0x1fff;\n\n let d3 = c;\n d3 += h0 * r3;\n d3 += h1 * r2;\n d3 += h2 * r1;\n d3 += h3 * r0;\n d3 += h4 * (5 * r9);\n c = (d3 >>> 13); d3 &= 0x1fff;\n d3 += h5 * (5 * r8);\n d3 += h6 * (5 * r7);\n d3 += h7 * (5 * r6);\n d3 += h8 * (5 * r5);\n d3 += h9 * (5 * r4);\n c += (d3 >>> 13); d3 &= 0x1fff;\n\n let d4 = c;\n d4 += h0 * r4;\n d4 += h1 * r3;\n d4 += h2 * r2;\n d4 += h3 * r1;\n d4 += h4 * r0;\n c = (d4 >>> 13); d4 &= 0x1fff;\n d4 += h5 * (5 * r9);\n d4 += h6 * (5 * r8);\n d4 += h7 * (5 * r7);\n d4 += h8 * (5 * r6);\n d4 += h9 * (5 * r5);\n c += (d4 >>> 13); d4 &= 0x1fff;\n\n let d5 = c;\n d5 += h0 * r5;\n d5 += h1 * r4;\n d5 += h2 * r3;\n d5 += h3 * r2;\n d5 += h4 * r1;\n c = (d5 >>> 13); d5 &= 0x1fff;\n d5 += h5 * r0;\n d5 += h6 * (5 * r9);\n d5 += h7 * (5 * r8);\n d5 += h8 * (5 * r7);\n d5 += h9 * (5 * r6);\n c += (d5 >>> 13); d5 &= 0x1fff;\n\n let d6 = c;\n d6 += h0 * r6;\n d6 += h1 * r5;\n d6 += h2 * r4;\n d6 += h3 * r3;\n d6 += h4 * r2;\n c = (d6 >>> 13); d6 &= 0x1fff;\n d6 += h5 * r1;\n d6 += h6 * r0;\n d6 += h7 * (5 * r9);\n d6 += h8 * (5 * r8);\n d6 += h9 * (5 * r7);\n c += (d6 >>> 13); d6 &= 0x1fff;\n\n let d7 = c;\n d7 += h0 * r7;\n d7 += h1 * r6;\n d7 += h2 * r5;\n d7 += h3 * r4;\n d7 += h4 * r3;\n c = (d7 >>> 13); d7 &= 0x1fff;\n d7 += h5 * r2;\n d7 += h6 * r1;\n d7 += h7 * r0;\n d7 += h8 * (5 * r9);\n d7 += h9 * (5 * r8);\n c += (d7 >>> 13); d7 &= 0x1fff;\n\n let d8 = c;\n d8 += h0 * r8;\n d8 += h1 * r7;\n d8 += h2 * r6;\n d8 += h3 * r5;\n d8 += h4 * r4;\n c = (d8 >>> 13); d8 &= 0x1fff;\n d8 += h5 * r3;\n d8 += h6 * r2;\n d8 += h7 * r1;\n d8 += h8 * r0;\n d8 += h9 * (5 * r9);\n c += (d8 >>> 13); d8 &= 0x1fff;\n\n let d9 = c;\n d9 += h0 * r9;\n d9 += h1 * r8;\n d9 += h2 * r7;\n d9 += h3 * r6;\n d9 += h4 * r5;\n c = (d9 >>> 13); d9 &= 0x1fff;\n d9 += h5 * r4;\n d9 += h6 * r3;\n d9 += h7 * r2;\n d9 += h8 * r1;\n d9 += h9 * r0;\n c += (d9 >>> 13); d9 &= 0x1fff;\n\n c = (((c << 2) + c)) | 0;\n c = (c + d0) | 0;\n d0 = c & 0x1fff;\n c = (c >>> 13);\n d1 += c;\n\n h0 = d0;\n h1 = d1;\n h2 = d2;\n h3 = d3;\n h4 = d4;\n h5 = d5;\n h6 = d6;\n h7 = d7;\n h8 = d8;\n h9 = d9;\n\n mpos += 16;\n bytes -= 16;\n }\n this._h[0] = h0;\n this._h[1] = h1;\n this._h[2] = h2;\n this._h[3] = h3;\n this._h[4] = h4;\n this._h[5] = h5;\n this._h[6] = h6;\n this._h[7] = h7;\n this._h[8] = h8;\n this._h[9] = h9;\n }\n\n finish(mac: Uint8Array, macpos = 0): this {\n const g = new Uint16Array(10);\n let c: number;\n let mask: number;\n let f: number;\n let i: number;\n\n if (this._leftover) {\n i = this._leftover;\n this._buffer[i++] = 1;\n for (; i < 16; i++) {\n this._buffer[i] = 0;\n }\n this._fin = 1;\n this._blocks(this._buffer, 0, 16);\n }\n\n c = this._h[1] >>> 13;\n this._h[1] &= 0x1fff;\n for (i = 2; i < 10; i++) {\n this._h[i] += c;\n c = this._h[i] >>> 13;\n this._h[i] &= 0x1fff;\n }\n this._h[0] += (c * 5);\n c = this._h[0] >>> 13;\n this._h[0] &= 0x1fff;\n this._h[1] += c;\n c = this._h[1] >>> 13;\n this._h[1] &= 0x1fff;\n this._h[2] += c;\n\n g[0] = this._h[0] + 5;\n c = g[0] >>> 13;\n g[0] &= 0x1fff;\n for (i = 1; i < 10; i++) {\n g[i] = this._h[i] + c;\n c = g[i] >>> 13;\n g[i] &= 0x1fff;\n }\n g[9] -= (1 << 13);\n\n mask = (c ^ 1) - 1;\n for (i = 0; i < 10; i++) {\n g[i] &= mask;\n }\n mask = ~mask;\n for (i = 0; i < 10; i++) {\n this._h[i] = (this._h[i] & mask) | g[i];\n }\n\n this._h[0] = ((this._h[0]) | (this._h[1] << 13)) & 0xffff;\n this._h[1] = ((this._h[1] >>> 3) | (this._h[2] << 10)) & 0xffff;\n this._h[2] = ((this._h[2] >>> 6) | (this._h[3] << 7)) & 0xffff;\n this._h[3] = ((this._h[3] >>> 9) | (this._h[4] << 4)) & 0xffff;\n this._h[4] = ((this._h[4] >>> 12) | (this._h[5] << 1) | (this._h[6] << 14)) & 0xffff;\n this._h[5] = ((this._h[6] >>> 2) | (this._h[7] << 11)) & 0xffff;\n this._h[6] = ((this._h[7] >>> 5) | (this._h[8] << 8)) & 0xffff;\n this._h[7] = ((this._h[8] >>> 8) | (this._h[9] << 5)) & 0xffff;\n\n f = this._h[0] + this._pad[0];\n this._h[0] = f & 0xffff;\n for (i = 1; i < 8; i++) {\n f = (((this._h[i] + this._pad[i]) | 0) + (f >>> 16)) | 0;\n this._h[i] = f & 0xffff;\n }\n\n mac[macpos + 0] = this._h[0] >>> 0;\n mac[macpos + 1] = this._h[0] >>> 8;\n mac[macpos + 2] = this._h[1] >>> 0;\n mac[macpos + 3] = this._h[1] >>> 8;\n mac[macpos + 4] = this._h[2] >>> 0;\n mac[macpos + 5] = this._h[2] >>> 8;\n mac[macpos + 6] = this._h[3] >>> 0;\n mac[macpos + 7] = this._h[3] >>> 8;\n mac[macpos + 8] = this._h[4] >>> 0;\n mac[macpos + 9] = this._h[4] >>> 8;\n mac[macpos + 10] = this._h[5] >>> 0;\n mac[macpos + 11] = this._h[5] >>> 8;\n mac[macpos + 12] = this._h[6] >>> 0;\n mac[macpos + 13] = this._h[6] >>> 8;\n mac[macpos + 14] = this._h[7] >>> 0;\n mac[macpos + 15] = this._h[7] >>> 8;\n\n this._finished = true;\n return this;\n }\n\n update(m: Uint8Array): this {\n let mpos = 0;\n let bytes = m.length;\n let want: number;\n\n if (this._leftover) {\n want = (16 - this._leftover);\n if (want > bytes) {\n want = bytes;\n }\n for (let i = 0; i < want; i++) {\n this._buffer[this._leftover + i] = m[mpos + i];\n }\n bytes -= want;\n mpos += want;\n this._leftover += want;\n if (this._leftover < 16) {\n return this;\n }\n this._blocks(this._buffer, 0, 16);\n this._leftover = 0;\n }\n\n if (bytes >= 16) {\n want = bytes - (bytes % 16);\n this._blocks(m, mpos, want);\n mpos += want;\n bytes -= want;\n }\n\n if (bytes) {\n for (let i = 0; i < bytes; i++) {\n this._buffer[this._leftover + i] = m[mpos + i];\n }\n this._leftover += bytes;\n }\n\n return this;\n }\n\n digest(): Uint8Array {\n // TODO(dchest): it behaves differently than other hashes/HMAC,\n // because it throws when finished — others just return saved result.\n if (this._finished) {\n throw new Error(\"Poly1305 was finished\");\n }\n let mac = new Uint8Array(16);\n this.finish(mac);\n return mac;\n }\n\n clean(): this {\n wipe(this._buffer);\n wipe(this._r);\n wipe(this._h);\n wipe(this._pad);\n this._leftover = 0;\n this._fin = 0;\n this._finished = true; // mark as finished even if not\n return this;\n }\n}\n\n/**\n * Returns 16-byte authenticator of data using a one-time 32-byte key.\n *\n * Important: key should be used for only one message, it should never repeat.\n */\nexport function oneTimeAuth(key: Uint8Array, data: Uint8Array): Uint8Array {\n const h = new Poly1305(key);\n h.update(data);\n const digest = h.digest();\n h.clean();\n return digest;\n}\n\n/**\n * Returns true if two authenticators are 16-byte long and equal.\n * Uses contant-time comparison to avoid leaking timing information.\n */\nexport function equal(a: Uint8Array, b: Uint8Array): boolean {\n if (a.length !== DIGEST_LENGTH || b.length !== DIGEST_LENGTH) {\n return false;\n }\n return constantTimeEqual(a, b);\n}\n","import debug from 'debug'\nimport { DUMP_SESSION_KEYS } from './constants'\nimport { KeyPair } from './@types/libp2p'\nimport { NoiseSession } from './@types/handshake'\n\nexport const logger = debug('libp2p:noise')\n\nlet keyLogger\nif (DUMP_SESSION_KEYS) {\n keyLogger = logger\n} else {\n keyLogger = () => { /* do nothing */ }\n}\n\nexport function logLocalStaticKeys (s: KeyPair): void {\n keyLogger(`LOCAL_STATIC_PUBLIC_KEY ${s.publicKey.toString('hex')}`)\n keyLogger(`LOCAL_STATIC_PRIVATE_KEY ${s.privateKey.toString('hex')}`)\n}\n\nexport function logLocalEphemeralKeys (e: KeyPair|undefined): void {\n if (e) {\n keyLogger(`LOCAL_PUBLIC_EPHEMERAL_KEY ${e.publicKey.toString('hex')}`)\n keyLogger(`LOCAL_PRIVATE_EPHEMERAL_KEY ${e.privateKey.toString('hex')}`)\n } else {\n keyLogger('Missing local ephemeral keys.')\n }\n}\n\nexport function logRemoteStaticKey (rs: Buffer): void {\n keyLogger(`REMOTE_STATIC_PUBLIC_KEY ${rs.toString('hex')}`)\n}\n\nexport function logRemoteEphemeralKey (re: Buffer): void {\n keyLogger(`REMOTE_EPHEMERAL_PUBLIC_KEY ${re.toString('hex')}`)\n}\n\nexport function logCipherState (session: NoiseSession): void {\n if (session.cs1 && session.cs2) {\n keyLogger(`CIPHER_STATE_1 ${session.cs1.n} ${session.cs1.k.toString('hex')}`)\n keyLogger(`CIPHER_STATE_2 ${session.cs2.n} ${session.cs2.k.toString('hex')}`)\n } else {\n keyLogger('Missing cipher state.')\n }\n}\n","export const NOISE_MSG_MAX_LENGTH_BYTES = 65535\nexport const NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG = NOISE_MSG_MAX_LENGTH_BYTES - 16\n\nexport const DUMP_SESSION_KEYS = process.env.DUMP_SESSION_KEYS\n","import { Buffer } from 'buffer'\nimport { bytes } from './@types/basic'\nimport { MessageBuffer } from './@types/handshake'\nimport BufferList from 'bl'\n\nexport const uint16BEEncode = (value: number, target: Buffer, offset: number): Buffer => {\n target = target || Buffer.allocUnsafe(2)\n target.writeUInt16BE(value, offset)\n return target\n}\nuint16BEEncode.bytes = 2\n\nexport const uint16BEDecode = (data: Buffer | BufferList): number => {\n if (data.length < 2) throw RangeError('Could not decode int16BE')\n return data.readUInt16BE(0)\n}\nuint16BEDecode.bytes = 2\n\n// Note: IK and XX encoder usage is opposite (XX uses in stages encode0 where IK uses encode1)\n\nexport function encode0 (message: MessageBuffer): bytes {\n return Buffer.concat([message.ne, message.ciphertext])\n}\n\nexport function encode1 (message: MessageBuffer): bytes {\n return Buffer.concat([message.ne, message.ns, message.ciphertext])\n}\n\nexport function encode2 (message: MessageBuffer): bytes {\n return Buffer.concat([message.ns, message.ciphertext])\n}\n\nexport function decode0 (input: bytes): MessageBuffer {\n if (input.length < 32) {\n throw new Error('Cannot decode stage 0 MessageBuffer: length less than 32 bytes.')\n }\n\n return {\n ne: input.slice(0, 32),\n ciphertext: input.slice(32, input.length),\n ns: Buffer.alloc(0)\n }\n}\n\nexport function decode1 (input: bytes): MessageBuffer {\n if (input.length < 80) {\n throw new Error('Cannot decode stage 1 MessageBuffer: length less than 80 bytes.')\n }\n\n return {\n ne: input.slice(0, 32),\n ns: input.slice(32, 80),\n ciphertext: input.slice(80, input.length)\n }\n}\n\nexport function decode2 (input: bytes): MessageBuffer {\n if (input.length < 48) {\n throw new Error('Cannot decode stage 2 MessageBuffer: length less than 48 bytes.')\n }\n\n return {\n ne: Buffer.alloc(0),\n ns: input.slice(0, 48),\n ciphertext: input.slice(48, input.length)\n }\n}\n","import { WrappedConnection } from './noise'\nimport { IK } from './handshakes/ik'\nimport { NoiseSession } from './@types/handshake'\nimport { bytes, bytes32 } from './@types/basic'\nimport { KeyPair } from './@types/libp2p'\nimport { IHandshake } from './@types/handshake-interface'\nimport { Buffer } from 'buffer'\nimport { decode0, decode1, encode0, encode1 } from './encoder'\nimport { decodePayload, getPeerIdFromPayload, verifySignedPayload } from './utils'\nimport { FailedIKError } from './errors'\nimport {\n logger,\n logLocalStaticKeys,\n logRemoteStaticKey,\n logLocalEphemeralKeys,\n logRemoteEphemeralKey,\n logCipherState\n} from './logger'\nimport PeerId from 'peer-id'\n\nexport class IKHandshake implements IHandshake {\n public isInitiator: boolean\n public session: NoiseSession\n public remotePeer!: PeerId\n public remoteEarlyData: Buffer\n\n private readonly payload: bytes\n private readonly prologue: bytes32\n private readonly staticKeypair: KeyPair\n private readonly connection: WrappedConnection\n private readonly ik: IK\n\n constructor (\n isInitiator: boolean,\n payload: bytes,\n prologue: bytes32,\n staticKeypair: KeyPair,\n connection: WrappedConnection,\n remoteStaticKey: bytes,\n remotePeer?: PeerId,\n handshake?: IK\n ) {\n this.isInitiator = isInitiator\n this.payload = Buffer.from(payload)\n this.prologue = prologue\n this.staticKeypair = staticKeypair\n this.connection = connection\n if (remotePeer) {\n this.remotePeer = remotePeer\n }\n this.ik = handshake ?? new IK()\n this.session = this.ik.initSession(this.isInitiator, this.prologue, this.staticKeypair, remoteStaticKey)\n this.remoteEarlyData = Buffer.alloc(0)\n }\n\n public async stage0 (): Promise<void> {\n logLocalStaticKeys(this.session.hs.s)\n logRemoteStaticKey(this.session.hs.rs)\n if (this.isInitiator) {\n logger('IK Stage 0 - Initiator sending message...')\n const messageBuffer = this.ik.sendMessage(this.session, this.payload)\n this.connection.writeLP(encode1(messageBuffer))\n logger('IK Stage 0 - Initiator sent message.')\n logLocalEphemeralKeys(this.session.hs.e)\n } else {\n logger('IK Stage 0 - Responder receiving message...')\n const receivedMsg = await this.connection.readLP()\n try {\n const receivedMessageBuffer = decode1(receivedMsg.slice())\n const { plaintext, valid } = this.ik.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('ik handshake stage 0 decryption validation fail')\n }\n logger('IK Stage 0 - Responder got message, going to verify payload.')\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n await verifySignedPayload(this.session.hs.rs, decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n logger('IK Stage 0 - Responder successfully verified payload!')\n logRemoteEphemeralKey(this.session.hs.re)\n } catch (e) {\n const err = e as Error\n logger('Responder breaking up with IK handshake in stage 0.')\n\n throw new FailedIKError(receivedMsg, `Error occurred while verifying initiator's signed payload: ${err.message}`)\n }\n }\n }\n\n public async stage1 (): Promise<void> {\n if (this.isInitiator) {\n logger('IK Stage 1 - Initiator receiving message...')\n const receivedMsg = (await this.connection.readLP()).slice()\n const receivedMessageBuffer = decode0(Buffer.from(receivedMsg))\n const { plaintext, valid } = this.ik.recvMessage(this.session, receivedMessageBuffer)\n logger('IK Stage 1 - Initiator got message, going to verify payload.')\n try {\n if (!valid) {\n throw new Error('ik stage 1 decryption validation fail')\n }\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n await verifySignedPayload(receivedMessageBuffer.ns.slice(0, 32), decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n logger('IK Stage 1 - Initiator successfully verified payload!')\n logRemoteEphemeralKey(this.session.hs.re)\n } catch (e) {\n const err = e as Error\n logger('Initiator breaking up with IK handshake in stage 1.')\n throw new FailedIKError(receivedMsg, `Error occurred while verifying responder's signed payload: ${err.message}`)\n }\n } else {\n logger('IK Stage 1 - Responder sending message...')\n const messageBuffer = this.ik.sendMessage(this.session, this.payload)\n this.connection.writeLP(encode0(messageBuffer))\n logger('IK Stage 1 - Responder sent message...')\n logLocalEphemeralKeys(this.session.hs.e)\n }\n logCipherState(this.session)\n }\n\n public decrypt (ciphertext: bytes, session: NoiseSession): {plaintext: bytes, valid: boolean} {\n const cs = this.getCS(session, false)\n return this.ik.decryptWithAd(cs, Buffer.alloc(0), ciphertext)\n }\n\n public encrypt (plaintext: Buffer, session: NoiseSession): Buffer {\n const cs = this.getCS(session)\n return this.ik.encryptWithAd(cs, Buffer.alloc(0), plaintext)\n }\n\n public getLocalEphemeralKeys (): KeyPair {\n if (!this.session.hs.e) {\n throw new Error('Ephemeral keys do not exist.')\n }\n\n return this.session.hs.e\n }\n\n private getCS (session: NoiseSession, encryption = true) {\n if (!session.cs1 || !session.cs2) {\n throw new Error('Handshake not completed properly, cipher state does not exist.')\n }\n\n if (this.isInitiator) {\n return encryption ? session.cs1 : session.cs2\n } else {\n return encryption ? session.cs2 : session.cs1\n }\n }\n\n private setRemoteEarlyData (data: Uint8Array|null|undefined): void {\n if (data) {\n this.remoteEarlyData = Buffer.from(data.buffer, data.byteOffset, data.length)\n }\n }\n}\n","import { Buffer } from 'buffer'\nimport { CipherState, HandshakeState, MessageBuffer, NoiseSession } from '../@types/handshake'\nimport { bytes, bytes32 } from '../@types/basic'\nimport { generateKeypair, isValidPublicKey } from '../utils'\nimport { AbstractHandshake } from './abstract-handshake'\nimport { KeyPair } from '../@types/libp2p'\n\nexport class IK extends AbstractHandshake {\n public initSession (initiator: boolean, prologue: bytes32, s: KeyPair, rs: bytes32): NoiseSession {\n const psk = this.createEmptyKey()\n\n let hs\n if (initiator) {\n hs = this.initializeInitiator(prologue, s, rs, psk)\n } else {\n hs = this.initializeResponder(prologue, s, rs, psk)\n }\n\n return {\n hs,\n i: initiator,\n mc: 0\n }\n }\n\n public sendMessage (session: NoiseSession, message: bytes): MessageBuffer {\n let messageBuffer: MessageBuffer\n if (session.mc === 0) {\n messageBuffer = this.writeMessageA(session.hs, message)\n } else if (session.mc === 1) {\n const { messageBuffer: mb, h, cs1, cs2 } = this.writeMessageB(session.hs, message)\n messageBuffer = mb\n session.h = h\n session.cs1 = cs1\n session.cs2 = cs2\n } else if (session.mc > 1) {\n if (session.i) {\n if (!session.cs1) {\n throw new Error('CS1 (cipher state) is not defined')\n }\n\n messageBuffer = this.writeMessageRegular(session.cs1, message)\n } else {\n if (!session.cs2) {\n throw new Error('CS2 (cipher state) is not defined')\n }\n\n messageBuffer = this.writeMessageRegular(session.cs2, message)\n }\n } else {\n throw new Error('Session invalid.')\n }\n\n session.mc++\n return messageBuffer\n }\n\n public recvMessage (session: NoiseSession, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n let plaintext = Buffer.alloc(0); let valid = false\n if (session.mc === 0) {\n ({ plaintext, valid } = this.readMessageA(session.hs, message))\n }\n if (session.mc === 1) {\n const { plaintext: pt, valid: v, h, cs1, cs2 } = this.readMessageB(session.hs, message)\n plaintext = pt\n valid = v\n session.h = h\n session.cs1 = cs1\n session.cs2 = cs2\n }\n session.mc++\n return { plaintext, valid }\n }\n\n private writeMessageA (hs: HandshakeState, payload: bytes): MessageBuffer {\n hs.e = generateKeypair()\n const ne = hs.e.publicKey\n this.mixHash(hs.ss, ne)\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.rs))\n const spk = Buffer.from(hs.s.publicKey)\n const ns = this.encryptAndHash(hs.ss, spk)\n\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.rs))\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n\n return { ne, ns, ciphertext }\n }\n\n private writeMessageB (hs: HandshakeState, payload: bytes) {\n hs.e = generateKeypair()\n const ne = hs.e.publicKey\n this.mixHash(hs.ss, ne)\n\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.re))\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.rs))\n const ciphertext = this.encryptAndHash(hs.ss, payload)\n const ns = this.createEmptyKey()\n const messageBuffer: MessageBuffer = { ne, ns, ciphertext }\n const { cs1, cs2 } = this.split(hs.ss)\n\n return { messageBuffer, cs1, cs2, h: hs.ss.h }\n }\n\n private readMessageA (hs: HandshakeState, message: MessageBuffer): {plaintext: bytes, valid: boolean} {\n if (isValidPublicKey(message.ne)) {\n hs.re = message.ne\n }\n\n this.mixHash(hs.ss, hs.re)\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.re))\n const { plaintext: ns, valid: valid1 } = this.decryptAndHash(hs.ss, message.ns)\n if (valid1 && ns.length === 32 && isValidPublicKey(ns)) {\n hs.rs = ns\n }\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.rs))\n const { plaintext, valid: valid2 } = this.decryptAndHash(hs.ss, message.ciphertext)\n return { plaintext, valid: (valid1 && valid2) }\n }\n\n private readMessageB (hs: HandshakeState, message: MessageBuffer): {h: bytes, plaintext: bytes, valid: boolean, cs1: CipherState, cs2: CipherState} {\n if (isValidPublicKey(message.ne)) {\n hs.re = message.ne\n }\n\n this.mixHash(hs.ss, hs.re)\n if (!hs.e) {\n throw new Error('Handshake state should contain ephemeral key by now.')\n }\n this.mixKey(hs.ss, this.dh(hs.e.privateKey, hs.re))\n this.mixKey(hs.ss, this.dh(hs.s.privateKey, hs.re))\n const { plaintext, valid } = this.decryptAndHash(hs.ss, message.ciphertext)\n const { cs1, cs2 } = this.split(hs.ss)\n\n return { h: hs.ss.h, valid, plaintext, cs1, cs2 }\n }\n\n private initializeInitiator (prologue: bytes32, s: KeyPair, rs: bytes32, psk: bytes32): HandshakeState {\n const name = 'Noise_IK_25519_ChaChaPoly_SHA256'\n const ss = this.initializeSymmetric(name)\n this.mixHash(ss, prologue)\n this.mixHash(ss, rs)\n const re = Buffer.alloc(32)\n\n return { ss, s, rs, re, psk }\n }\n\n private initializeResponder (prologue: bytes32, s: KeyPair, rs: bytes32, psk: bytes32): HandshakeState {\n const name = 'Noise_IK_25519_ChaChaPoly_SHA256'\n const ss = this.initializeSymmetric(name)\n this.mixHash(ss, prologue)\n this.mixHash(ss, s.publicKey)\n const re = Buffer.alloc(32)\n\n return { ss, s, rs, re, psk }\n }\n}\n","import BufferList from 'bl'\n\nexport class FailedIKError extends Error {\n public initialMsg: string|BufferList|Buffer\n\n constructor (initialMsg: string|BufferList|Buffer, message?: string) {\n super(message)\n\n this.initialMsg = initialMsg\n this.name = 'FailedIKhandshake'\n }\n}\n","import { Buffer } from 'buffer'\nimport { XXHandshake } from './handshake-xx'\nimport { XX } from './handshakes/xx'\nimport { KeyPair } from './@types/libp2p'\nimport { bytes, bytes32 } from './@types/basic'\nimport { decodePayload, getPeerIdFromPayload, verifySignedPayload } from './utils'\nimport { logger, logLocalEphemeralKeys, logRemoteEphemeralKey, logRemoteStaticKey } from './logger'\nimport { WrappedConnection } from './noise'\nimport { decode0, decode1 } from './encoder'\nimport PeerId from 'peer-id'\n\nexport class XXFallbackHandshake extends XXHandshake {\n private readonly ephemeralKeys?: KeyPair\n private readonly initialMsg: bytes\n\n constructor (\n isInitiator: boolean,\n payload: bytes,\n prologue: bytes32,\n staticKeypair: KeyPair,\n connection: WrappedConnection,\n initialMsg: bytes,\n remotePeer?: PeerId,\n ephemeralKeys?: KeyPair,\n handshake?: XX\n ) {\n super(isInitiator, payload, prologue, staticKeypair, connection, remotePeer, handshake)\n if (ephemeralKeys) {\n this.ephemeralKeys = ephemeralKeys\n }\n this.initialMsg = initialMsg\n }\n\n // stage 0\n // eslint-disable-next-line require-await\n public async propose (): Promise<void> {\n if (this.isInitiator) {\n this.xx.sendMessage(this.session, Buffer.alloc(0), this.ephemeralKeys)\n logger('XX Fallback Stage 0 - Initialized state as the first message was sent by initiator.')\n logLocalEphemeralKeys(this.session.hs.e)\n } else {\n logger('XX Fallback Stage 0 - Responder decoding initial msg from IK.')\n const receivedMessageBuffer = decode0(this.initialMsg)\n const { valid } = this.xx.recvMessage(this.session, {\n ne: receivedMessageBuffer.ne,\n ns: Buffer.alloc(0),\n ciphertext: Buffer.alloc(0)\n })\n if (!valid) {\n throw new Error('xx fallback stage 0 decryption validation fail')\n }\n logger('XX Fallback Stage 0 - Responder used received message from IK.')\n logRemoteEphemeralKey(this.session.hs.re)\n }\n }\n\n // stage 1\n public async exchange (): Promise<void> {\n if (this.isInitiator) {\n const receivedMessageBuffer = decode1(this.initialMsg)\n const { plaintext, valid } = this.xx.recvMessage(this.session, receivedMessageBuffer)\n if (!valid) {\n throw new Error('xx fallback stage 1 decryption validation fail')\n }\n logger('XX Fallback Stage 1 - Initiator used received message from IK.')\n logRemoteEphemeralKey(this.session.hs.re)\n logRemoteStaticKey(this.session.hs.rs)\n\n logger(\"Initiator going to check remote's signature...\")\n try {\n const decodedPayload = await decodePayload(plaintext)\n this.remotePeer = this.remotePeer || await getPeerIdFromPayload(decodedPayload)\n await verifySignedPayload(this.session.hs.rs, decodedPayload, this.remotePeer)\n this.setRemoteEarlyData(decodedPayload.data)\n } catch (e) {\n const err = e as Error\n throw new Error(`Error occurred while verifying signed payload from responder: ${err.message}`)\n }\n logger('All good with the signature!')\n } else {\n logger('XX Fallback Stage 1 - Responder start')\n await super.exchange()\n logger('XX Fallback Stage 1 - Responder end')\n }\n }\n}\n","import { Buffer } from 'buffer'\nimport { IHandshake } from './@types/handshake-interface'\nimport { NOISE_MSG_MAX_LENGTH_BYTES, NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG } from './constants'\n\ninterface IReturnEncryptionWrapper {\n (source: Iterable<Uint8Array>): AsyncIterableIterator<Uint8Array>\n}\n\n// Returns generator that encrypts payload from the user\nexport function encryptStream (handshake: IHandshake): IReturnEncryptionWrapper {\n return async function * (source) {\n for await (const chunk of source) {\n const chunkBuffer = Buffer.from(chunk.buffer, chunk.byteOffset, chunk.length)\n\n for (let i = 0; i < chunkBuffer.length; i += NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG) {\n let end = i + NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG\n if (end > chunkBuffer.length) {\n end = chunkBuffer.length\n }\n\n const data = handshake.encrypt(chunkBuffer.slice(i, end), handshake.session)\n yield data\n }\n }\n }\n}\n\n// Decrypt received payload to the user\nexport function decryptStream (handshake: IHandshake): IReturnEncryptionWrapper {\n return async function * (source) {\n for await (const chunk of source) {\n const chunkBuffer = Buffer.from(chunk.buffer, chunk.byteOffset, chunk.length)\n\n for (let i = 0; i < chunkBuffer.length; i += NOISE_MSG_MAX_LENGTH_BYTES) {\n let end = i + NOISE_MSG_MAX_LENGTH_BYTES\n if (end > chunkBuffer.length) {\n end = chunkBuffer.length\n }\n\n const chunk = chunkBuffer.slice(i, end)\n const { plaintext: decrypted, valid } = await handshake.decrypt(chunk, handshake.session)\n if (!valid) {\n throw new Error('Failed to validate decrypted chunk')\n }\n yield decrypted\n }\n }\n }\n}\n","import { bytes32 } from './@types/basic'\nimport PeerId from 'peer-id'\n\n/**\n * Storage for static keys of previously connected peers.\n */\nclass Keycache {\n private readonly storage = new Map<Uint8Array, bytes32>()\n\n public store (peerId: PeerId, key: bytes32): void {\n this.storage.set(peerId.id, key)\n }\n\n public load (peerId?: PeerId): bytes32 | null {\n if (!peerId) {\n return null\n }\n return this.storage.get(peerId.id) ?? null\n }\n\n public resetStorage (): void {\n this.storage.clear()\n }\n}\n\nconst KeyCache = new Keycache()\nexport {\n KeyCache\n}\n","'use strict'\n\nconst { EventEmitter } = require('events')\nconst errcode = require('err-code')\n\nconst libp2pRecord = require('libp2p-record')\nconst { MemoryDatastore } = require('datastore-core/memory')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst RoutingTable = require('./routing-table')\nconst utils = require('./utils')\nconst c = require('./constants')\nconst Network = require('./network')\nconst contentFetching = require('./content-fetching')\nconst contentRouting = require('./content-routing')\nconst peerRouting = require('./peer-routing')\nconst Message = require('./message')\nconst Providers = require('./providers')\nconst QueryManager = require('./query-manager')\n\nconst Record = libp2pRecord.Record\n\n/**\n * @typedef {*} Libp2p\n * @typedef {*} PeerStore\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('interface-datastore').Datastore} Datastore\n * @typedef {*} Dialer\n * @typedef {*} Registrar\n * @typedef {import('multiformats/cid').CID} CID\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {object} PeerData\n * @property {PeerId} id\n * @property {Multiaddr[]} multiaddrs\n */\n\n/**\n * A DHT implementation modeled after Kademlia with S/Kademlia modifications.\n * Original implementation in go: https://github.com/libp2p/go-libp2p-kad-dht.\n */\nclass KadDHT extends EventEmitter {\n /**\n * Create a new KadDHT.\n *\n * @param {Object} props\n * @param {Libp2p} props.libp2p - the libp2p instance\n * @param {Dialer} props.dialer - libp2p dialer instance\n * @param {PeerId} props.peerId - peer's peerId\n * @param {PeerStore} props.peerStore - libp2p peerStore\n * @param {Registrar} props.registrar - libp2p registrar instance\n * @param {string} [props.protocolPrefix = '/ipfs'] - libp2p registrar handle protocol\n * @param {boolean} [props.forceProtocolLegacy = false] - WARNING: this is not recommended and should only be used for legacy purposes\n * @param {number} props.kBucketSize - k-bucket size (default 20)\n * @param {boolean} props.clientMode - If true, the DHT will not respond to queries. This should be true if your node will not be dialable. (default: false)\n * @param {number} props.concurrency - alpha concurrency of queries (default 3)\n * @param {Datastore} props.datastore - datastore (default MemoryDatastore)\n * @param {object} props.validators - validators object with namespace as keys and function(key, record, callback)\n * @param {object} props.selectors - selectors object with namespace as keys and function(key, records)\n * @param {function(import('libp2p-record').Record, PeerId): void} [props.onPut] - Called when an entry is added to or changed in the datastore\n * @param {function(import('libp2p-record').Record): void} [props.onRemove] - Called when an entry is removed from the datastore\n */\n constructor ({\n libp2p,\n dialer,\n peerId,\n peerStore,\n registrar,\n protocolPrefix = '/ipfs',\n forceProtocolLegacy = false,\n datastore = new MemoryDatastore(),\n kBucketSize = c.K,\n clientMode = false,\n concurrency = c.ALPHA,\n validators = {},\n selectors = {},\n onPut = () => {},\n onRemove = () => {}\n }) {\n super()\n\n if (!dialer) {\n throw new Error('libp2p-kad-dht requires an instance of Dialer')\n }\n\n /**\n * Local reference to the libp2p instance. May be undefined.\n *\n * @type {Libp2p}\n */\n this.libp2p = libp2p\n\n /**\n * Local reference to the libp2p dialer instance\n *\n * @type {Dialer}\n */\n this.dialer = dialer\n\n /**\n * Local peer-id\n *\n * @type {PeerId}\n */\n this.peerId = peerId\n\n /**\n * Local PeerStore\n *\n * @type {PeerStore}\n */\n this.peerStore = peerStore\n\n /**\n * Local peer info\n *\n * @type {Registrar}\n */\n this.registrar = registrar\n\n /**\n * Registrar protocol\n *\n * @type {string}\n */\n this.protocol = protocolPrefix + (forceProtocolLegacy ? '' : c.PROTOCOL_DHT)\n\n /**\n * k-bucket size\n *\n * @type {number}\n */\n this.kBucketSize = kBucketSize\n\n this._clientMode = clientMode\n\n /**\n * ALPHA concurrency at which each query path with run, defaults to 3\n *\n * @type {number}\n */\n this.concurrency = concurrency\n\n /**\n * Number of disjoint query paths to use\n * This is set to `kBucketSize`/2 per the S/Kademlia paper\n *\n * @type {number}\n */\n this.disjointPaths = Math.ceil(this.kBucketSize / 2)\n\n /**\n * The routing table.\n *\n * @type {RoutingTable}\n */\n this.routingTable = new RoutingTable(this, { kBucketSize: this.kBucketSize })\n\n /**\n * Reference to the datastore, uses an in-memory store if none given.\n *\n * @type {Datastore}\n */\n this.datastore = datastore\n\n /**\n * Provider management\n *\n * @type {Providers}\n */\n this.providers = new Providers(this.datastore, this.peerId)\n\n this.validators = {\n pk: libp2pRecord.validator.validators.pk,\n ...validators\n }\n\n this.selectors = {\n pk: libp2pRecord.selection.selectors.pk,\n ...selectors\n }\n\n this.network = new Network(this)\n\n this._log = utils.logger(this.peerId)\n\n /**\n * Keeps track of running queries\n *\n * @type {QueryManager}\n */\n this._queryManager = new QueryManager()\n\n this._running = false\n\n // DHT components\n this.contentFetching = contentFetching(this)\n this.contentRouting = contentRouting(this)\n this.peerRouting = peerRouting(this)\n\n // datastore events\n this.onPut = onPut\n this.onRemove = onRemove\n }\n\n /**\n * Is this DHT running.\n */\n get isStarted () {\n return this._running\n }\n\n /**\n * Start listening to incoming connections.\n */\n start () {\n this._running = true\n\n return Promise.all([\n this.providers.start(),\n this._queryManager.start(),\n this.network.start(),\n this.routingTable.start()\n ])\n }\n\n /**\n * Stop accepting incoming connections and sending outgoing\n * messages.\n */\n stop () {\n this._running = false\n\n return Promise.all([\n this.providers.stop(),\n this._queryManager.stop(),\n this.network.stop(),\n this.routingTable.stop()\n ])\n }\n\n /**\n * Store the given key/value pair in the DHT.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n * @param {Object} [options] - put options\n * @param {number} [options.minPeers] - minimum number of peers required to successfully put (default: closestPeers.length)\n * @returns {Promise<void>}\n */\n async put (key, value, options = {}) { // eslint-disable-line require-await\n return this.contentFetching.put(key, value, options)\n }\n\n /**\n * Get the value to the given key.\n * Times out after 1 minute by default.\n *\n * @param {Uint8Array} key\n * @param {Object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n * @returns {Promise<Uint8Array>}\n */\n async get (key, options = {}) { // eslint-disable-line require-await\n return this.contentFetching.get(key, options)\n }\n\n /**\n * Get the `n` values to the given key without sorting.\n *\n * @param {Uint8Array} key\n * @param {number} nvals\n * @param {Object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n */\n async getMany (key, nvals, options = {}) { // eslint-disable-line require-await\n return this.contentFetching.getMany(key, nvals, options)\n }\n\n /**\n * Remove the given key from the local datastore.\n *\n * @param {Uint8Array} key\n */\n async removeLocal (key) {\n this._log(`removeLocal: ${uint8ArrayToString(key, 'base32')}`)\n const dsKey = utils.bufferToKey(key)\n\n try {\n await this.datastore.delete(dsKey)\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n return undefined\n }\n throw err\n }\n }\n\n /**\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n */\n async _putLocal (key, value) {\n this._log(`_putLocal: ${uint8ArrayToString(key, 'base32')}`)\n const dsKey = utils.bufferToKey(key)\n\n await this.datastore.put(dsKey, value)\n }\n\n // ----------- Content Routing\n\n /**\n * Announce to the network that we can provide given key's value.\n *\n * @param {CID} key\n * @returns {Promise<void>}\n */\n async provide (key) { // eslint-disable-line require-await\n return this.contentRouting.provide(key)\n }\n\n /**\n * Search the dht for up to `K` providers of the given CID.\n *\n * @param {CID} key\n * @param {Object} [options] - findProviders options\n * @param {number} [options.timeout=60000] - how long the query should maximally run, in milliseconds (default: 60000)\n * @param {number} [options.maxNumProviders=5] - maximum number of providers to find\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * findProviders (key, options = { timeout: 6000, maxNumProviders: 5 }) {\n for await (const peerData of this.contentRouting.findProviders(key, options)) {\n yield peerData\n }\n }\n\n // ----------- Peer Routing -----------\n\n /**\n * Search for a peer with the given ID.\n *\n * @param {PeerId} id\n * @param {Object} [options] - findPeer options\n * @param {number} [options.timeout=60000] - how long the query should maximally run, in milliseconds (default: 60000)\n * @returns {Promise<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async findPeer (id, options = { timeout: 60000 }) { // eslint-disable-line require-await\n return this.peerRouting.findPeer(id, options)\n }\n\n /**\n * Kademlia 'node lookup' operation.\n *\n * @param {Uint8Array} key\n * @param {Object} [options]\n * @param {boolean} [options.shallow = false] - shallow query\n */\n async * getClosestPeers (key, options = { shallow: false }) {\n yield * this.peerRouting.getClosestPeers(key, options)\n }\n\n /**\n * Get the public key for the given peer id.\n *\n * @param {PeerId} peer\n */\n getPublicKey (peer) {\n return this.peerRouting.getPublicKey(peer)\n }\n\n // ----------- Discovery -----------\n\n /**\n * @param {PeerId} peerId\n * @param {Multiaddr[]} multiaddrs\n */\n _peerDiscovered (peerId, multiaddrs) {\n this.emit('peer', {\n id: peerId,\n multiaddrs\n })\n }\n\n // ----------- Internals -----------\n\n /**\n * Returns the routing tables closest peers, for the key of\n * the message.\n *\n * @param {Message} msg\n */\n async _nearestPeersToQuery (msg) {\n const key = await utils.convertBuffer(msg.key)\n const ids = this.routingTable.closestPeers(key, this.kBucketSize)\n\n return ids.map((p) => {\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peer = this.peerStore.get(p)\n\n return {\n id: p,\n multiaddrs: peer ? peer.addresses.map((address) => address.multiaddr) : []\n }\n })\n }\n\n /**\n * Get the nearest peers to the given query, but iff closer\n * than self.\n *\n * @param {Message} msg\n * @param {PeerId} peerId\n */\n async _betterPeersToQuery (msg, peerId) {\n this._log('betterPeersToQuery')\n const closer = await this._nearestPeersToQuery(msg)\n\n return closer.filter((closer) => {\n if (this._isSelf(closer.id)) {\n // Should bail, not sure\n this._log.error('trying to return self as closer')\n return false\n }\n\n return !closer.id.isEqual(peerId)\n })\n }\n\n /**\n * Try to fetch a given record by from the local datastore.\n * Returns the record iff it is still valid, meaning\n * - it was either authored by this node, or\n * - it was received less than `MAX_RECORD_AGE` ago.\n *\n * @param {Uint8Array} key\n */\n\n async _checkLocalDatastore (key) {\n this._log(`checkLocalDatastore: ${uint8ArrayToString(key)} %b`, key)\n const dsKey = utils.bufferToKey(key)\n\n // Fetch value from ds\n let rawRecord\n try {\n rawRecord = await this.datastore.get(dsKey)\n } catch (err) {\n if (err.code === 'ERR_NOT_FOUND') {\n return undefined\n }\n throw err\n }\n\n // Create record from the returned bytes\n const record = Record.deserialize(rawRecord)\n\n if (!record) {\n throw errcode(new Error('Invalid record'), 'ERR_INVALID_RECORD')\n }\n\n // Check validity: compare time received with max record age\n if (record.timeReceived == null ||\n utils.now() - record.timeReceived.getTime() > c.MAX_RECORD_AGE) {\n // If record is bad delete it and return\n await this.datastore.delete(dsKey)\n this.onRemove(record)\n return undefined\n }\n\n // Record is valid\n return record\n }\n\n /**\n * Add the peer to the routing table and update it in the peerStore.\n *\n * @param {PeerId} peerId\n */\n async _add (peerId) {\n await this.routingTable.add(peerId)\n }\n\n /**\n * Verify a record without searching the DHT.\n *\n * @param {import('libp2p-record').Record} record\n */\n async _verifyRecordLocally (record) {\n this._log('verifyRecordLocally')\n\n await libp2pRecord.validator.verifyRecord(this.validators, record)\n }\n\n /**\n * Is the given peer id our PeerId?\n *\n * @param {PeerId} other\n */\n _isSelf (other) {\n return other && uint8ArrayEquals(this.peerId.id, other.id)\n }\n\n /**\n * Store the given key/value pair at the peer `target`.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} rec - encoded record\n * @param {PeerId} target\n */\n async _putValueToPeer (key, rec, target) {\n const msg = new Message(Message.TYPES.PUT_VALUE, key, 0)\n msg.record = Record.deserialize(rec)\n\n const resp = await this.network.sendRequest(target, msg)\n\n if (resp.record && !uint8ArrayEquals(resp.record.value, Record.deserialize(rec).value)) {\n throw errcode(new Error('value not put correctly'), 'ERR_PUT_VALUE_INVALID')\n }\n }\n\n /**\n * Query a particular peer for the value for the given key.\n * It will either return the value or a list of closer peers.\n *\n * Note: The peerStore is updated with new addresses found for the given peer.\n *\n * @param {PeerId} peer\n * @param {Uint8Array} key\n */\n async _getValueOrPeers (peer, key) {\n const msg = await this._getValueSingle(peer, key)\n\n const peers = msg.closerPeers\n const record = msg.record\n\n if (record) {\n // We have a record\n try {\n await this._verifyRecordOnline(record)\n } catch (err) {\n const errMsg = 'invalid record received, discarded'\n this._log(errMsg)\n throw errcode(new Error(errMsg), 'ERR_INVALID_RECORD')\n }\n\n return { record, peers }\n }\n\n if (peers.length > 0) {\n return { peers }\n }\n\n throw errcode(new Error('Not found'), 'ERR_NOT_FOUND')\n }\n\n /**\n * Get a value via rpc call for the given parameters.\n *\n * @param {PeerId} peer\n * @param {Uint8Array} key\n */\n async _getValueSingle (peer, key) { // eslint-disable-line require-await\n const msg = new Message(Message.TYPES.GET_VALUE, key, 0)\n return this.network.sendRequest(peer, msg)\n }\n\n /**\n * Verify a record, fetching missing public keys from the network.\n * Calls back with an error if the record is invalid.\n *\n * @param {import('libp2p-record').Record} record\n * @returns {Promise<void>}\n */\n async _verifyRecordOnline (record) {\n await libp2pRecord.validator.verifyRecord(this.validators, record)\n }\n}\n\nmodule.exports = KadDHT\nmodule.exports.multicodec = '/ipfs' + c.PROTOCOL_DHT\n","'use strict'\n\n// @ts-ignore\nconst KBuck = require('k-bucket')\nconst { xor: uint8ArrayXor } = require('uint8arrays/xor')\nconst GENERATED_PREFIXES = require('./generated-prefix-list.json')\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst crypto = require('libp2p-crypto')\nconst PeerId = require('peer-id')\nconst utils = require('../utils')\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:dht:routing-table'), {\n error: debug('libp2p:dht:routing-table:error')\n})\n// @ts-ignore\nconst length = require('it-length')\n\n/**\n * @typedef {object} KBucketPeer\n * @property {Uint8Array} id\n * @property {PeerId} peer\n *\n * @typedef {object} KBucket\n * @property {Uint8Array} id\n * @property {KBucketPeer[]} contacts\n * @property {boolean} dontSplit\n * @property {KBucket} left\n * @property {KBucket} right\n *\n * @typedef {object} KBucketTree\n * @property {KBucket} root\n * @property {Uint8Array} localNodeId\n * @property {(event: string, callback: Function) => void} on\n * @property {(key: Uint8Array, count: number) => KBucketPeer[]} closest\n * @property {(key: Uint8Array) => KBucketPeer} closestPeer\n * @property {(key: Uint8Array) => void} remove\n * @property {(peer: KBucketPeer) => void} add\n * @property {() => number} count\n * @property {() => Iterable<KBucket>} toIterable\n */\n\n/**\n * Cannot generate random KadIds longer than this + 1\n */\nconst MAX_COMMON_PREFIX_LENGTH = 15\n\n/**\n * A wrapper around `k-bucket`, to provide easy store and\n * retrieval for peers.\n */\nclass RoutingTable {\n /**\n * @param {import('../')} dht\n * @param {object} [options]\n * @param {number} [options.kBucketSize=20]\n * @param {number} [options.refreshInterval=30000]\n */\n constructor (dht, { kBucketSize, refreshInterval } = {}) {\n this.peerId = dht.peerId\n this.dht = dht\n this._kBucketSize = kBucketSize || 20\n this._refreshInterval = refreshInterval || 30000\n\n /** @type {KBucketTree} */\n this.kb = new KBuck({\n numberOfNodesPerKBucket: this._kBucketSize,\n numberOfNodesToPing: 1\n })\n\n /** @type {Date[]} */\n this.commonPrefixLengthRefreshedAt = []\n\n this._refreshTable = this._refreshTable.bind(this)\n this._onPing = this._onPing.bind(this)\n }\n\n async start () {\n this.kb.localNodeId = await utils.convertPeerId(this.peerId)\n this.kb.on('ping', this._onPing)\n\n await this._refreshTable(true)\n }\n\n async stop () {\n if (this._refreshTimeoutId) {\n clearTimeout(this._refreshTimeoutId)\n }\n }\n\n /**\n * To speed lookups, we seed the table with random PeerIds. This means\n * when we are asked to locate a peer on the network, we can find a KadId\n * that is close to the requested peer ID and query that, then network\n * peers will tell us who they know who is close to the fake ID\n *\n * @param {boolean} [force=false]\n */\n async _refreshTable (force) {\n log('refreshing routing table')\n\n const prefixLength = this._maxCommonPrefix()\n const refreshCpls = this._getTrackedCommonPrefixLengthsForRefresh(prefixLength)\n\n log(`max common prefix length ${prefixLength}`)\n log(`tracked CPLs [ ${refreshCpls.map(date => `${date.getFullYear()}-${(date.getMonth() + 1).toString().padStart(2, '0')}-${date.getDate().toString().padStart(2, '0')} ${date.getHours().toString().padStart(2, '0')}:${date.getMinutes().toString().padStart(2, '0')}:${date.getSeconds().toString().padStart(2, '0')}`).join(', ')} ]`)\n\n /**\n * If we see a gap at a common prefix length in the Routing table, we ONLY refresh up until\n * the maximum cpl we have in the Routing Table OR (2 * (Cpl+ 1) with the gap), whichever\n * is smaller.\n *\n * This is to prevent refreshes for Cpls that have no peers in the network but happen to be\n * before a very high max Cpl for which we do have peers in the network.\n *\n * The number of 2 * (Cpl + 1) can be proved and a proof would have been written here if\n * the programmer had paid more attention in the Math classes at university.\n *\n * So, please be patient and a doc explaining it will be published soon.\n *\n * https://github.com/libp2p/go-libp2p-kad-dht/commit/2851c88acb0a3f86bcfe3cfd0f4604a03db801d8#diff-ad45f4ba97ffbc4083c2eb87a4420c1157057b233f048030d67c6b551855ccf6R219\n */\n await Promise.all(\n refreshCpls.map(async (lastRefresh, index) => {\n try {\n await this._refreshCommonPrefixLength(index, lastRefresh, force === true)\n\n if (this._numPeersForCpl(prefixLength) === 0) {\n const lastCpl = Math.min(2 * (index + 1), refreshCpls.length - 1)\n\n for (let n = index + 1; n < lastCpl + 1; n++) {\n try {\n await this._refreshCommonPrefixLength(n, lastRefresh, force === true)\n } catch (err) {\n log.error(err)\n }\n }\n }\n } catch (err) {\n log.error(err)\n }\n })\n )\n\n this._refreshTimeoutId = setTimeout(this._refreshTable, this._refreshInterval)\n // @ts-ignore\n this._refreshTimeoutId.unref()\n }\n\n /**\n * @param {number} cpl\n * @param {Date} lastRefresh\n * @param {boolean} force\n */\n async _refreshCommonPrefixLength (cpl, lastRefresh, force) {\n if (!force && lastRefresh.getTime() > (Date.now() - this._refreshInterval)) {\n log(`not running refresh for cpl ${cpl} as time since last refresh not above interval`)\n return\n }\n\n // gen a key for the query to refresh the cpl\n const peerId = await this._generateRandomPeerId(cpl)\n\n log(`starting refreshing cpl ${cpl} with key ${peerId.toB58String()} (routing table size was ${this.kb.count()})`)\n\n const peers = await length(this.dht.getClosestPeers(peerId.toBytes(), {}))\n\n log(`found ${peers} peers that were close to imaginary peer ${peerId.toB58String()}`)\n\n log(`finished refreshing cpl ${cpl} with key ${peerId.toB58String()} (routing table size was ${this.kb.count()})`)\n }\n\n /**\n * @param {number} maxCommonPrefix\n */\n _getTrackedCommonPrefixLengthsForRefresh (maxCommonPrefix) {\n if (maxCommonPrefix > MAX_COMMON_PREFIX_LENGTH) {\n maxCommonPrefix = MAX_COMMON_PREFIX_LENGTH\n }\n\n const dates = []\n\n for (let i = 0; i <= maxCommonPrefix; i++) {\n // defaults to the zero value if we haven't refreshed it yet.\n dates[i] = this.commonPrefixLengthRefreshedAt[i] || new Date()\n }\n\n return dates\n }\n\n /**\n *\n * @param {number} targetCommonPrefixLength\n */\n async _generateRandomPeerId (targetCommonPrefixLength) {\n const randomBytes = crypto.randomBytes(2)\n const randomUint16 = (randomBytes[1] << 8) + randomBytes[0]\n\n const key = await this._makePeerId(this.kb.localNodeId, randomUint16, targetCommonPrefixLength)\n\n return PeerId.createFromBytes(key)\n }\n\n /**\n * @param {Uint8Array} localKadId\n * @param {number} randomPrefix\n * @param {number} targetCommonPrefixLength\n */\n async _makePeerId (localKadId, randomPrefix, targetCommonPrefixLength) {\n if (targetCommonPrefixLength > MAX_COMMON_PREFIX_LENGTH) {\n throw new Error(`Cannot generate peer ID for common prefix length greater than ${MAX_COMMON_PREFIX_LENGTH}`)\n }\n\n const view = new DataView(localKadId.buffer, localKadId.byteOffset, localKadId.byteLength)\n const localPrefix = view.getUint16(0, false)\n\n // For host with ID `L`, an ID `K` belongs to a bucket with ID `B` ONLY IF CommonPrefixLen(L,K) is EXACTLY B.\n // Hence, to achieve a targetPrefix `T`, we must toggle the (T+1)th bit in L & then copy (T+1) bits from L\n // to our randomly generated prefix.\n const toggledLocalPrefix = localPrefix ^ (0x8000 >> targetCommonPrefixLength)\n\n // Combine the toggled local prefix and the random bits at the correct offset\n // such that ONLY the first `targetCommonPrefixLength` bits match the local ID.\n const mask = 65535 << (16 - (targetCommonPrefixLength + 1))\n const targetPrefix = (toggledLocalPrefix & mask) | (randomPrefix & ~mask)\n\n // Convert to a known peer ID.\n const keyPrefix = GENERATED_PREFIXES[targetPrefix]\n\n const keyBuffer = new ArrayBuffer(34)\n const keyView = new DataView(keyBuffer, 0, keyBuffer.byteLength)\n keyView.setUint8(0, sha256.code)\n keyView.setUint8(1, 32)\n keyView.setUint32(2, keyPrefix, false)\n\n return new Uint8Array(keyView.buffer, keyView.byteOffset, keyView.byteLength)\n }\n\n /**\n * returns the maximum common prefix length between any peer in the table\n * and the current peer\n */\n _maxCommonPrefix () {\n if (!this.kb.localNodeId) {\n return 0\n }\n\n // xor our KadId with every KadId in the k-bucket tree,\n // return the longest id prefix that is the same\n let prefixLength = 0\n\n for (const length of this._prefixLengths()) {\n if (length > prefixLength) {\n prefixLength = length\n }\n }\n\n return prefixLength\n }\n\n /**\n * Returns the number of peers in the table with a given prefix length\n *\n * @param {number} prefixLength\n */\n _numPeersForCpl (prefixLength) {\n let count = 0\n\n for (const length of this._prefixLengths()) {\n if (length === prefixLength) {\n count++\n }\n }\n\n return count\n }\n\n /**\n * Yields the common prefix length of every peer in the table\n */\n * _prefixLengths () {\n for (const { id } of this.kb.toIterable()) {\n const distance = uint8ArrayXor(this.kb.localNodeId, id)\n let leadingZeros = 0\n\n for (const byte of distance) {\n if (byte === 0) {\n leadingZeros++\n } else {\n break\n }\n }\n\n yield leadingZeros\n }\n }\n\n /**\n * Called on the `ping` event from `k-bucket`.\n * Currently this just removes the oldest contact from\n * the list, without actually pinging the individual peers.\n * This is the same as go does, but should probably\n * be upgraded to actually ping the individual peers.\n *\n * @param {KBucketPeer[]} oldContacts\n * @param {KBucketPeer} newContact\n */\n _onPing (oldContacts, newContact) {\n // just use the first one (k-bucket sorts from oldest to newest)\n const oldest = oldContacts[0]\n\n if (oldest) {\n // remove the oldest one\n this.kb.remove(oldest.id)\n }\n\n // add the new one\n this.kb.add(newContact)\n }\n\n // -- Public Interface\n\n /**\n * Amount of currently stored peers.\n */\n get size () {\n return this.kb.count()\n }\n\n /**\n * Find a specific peer by id.\n *\n * @param {PeerId} peer\n */\n async find (peer) {\n const key = await utils.convertPeerId(peer)\n const closest = this.closestPeer(key)\n\n if (closest && peer.equals(closest)) {\n return closest\n }\n }\n\n /**\n * Retrieve the closest peers to the given key.\n *\n * @param {Uint8Array} key\n */\n closestPeer (key) {\n const res = this.closestPeers(key, 1)\n\n if (res.length > 0) {\n return res[0]\n }\n }\n\n /**\n * Retrieve the `count`-closest peers to the given key.\n *\n * @param {Uint8Array} key\n * @param {number} count\n */\n closestPeers (key, count) {\n const closest = this.kb.closest(key, count)\n\n return closest.map(p => p.peer)\n }\n\n /**\n * Add or update the routing table with the given peer.\n *\n * @param {PeerId} peer\n */\n async add (peer) {\n const id = await utils.convertPeerId(peer)\n\n this.kb.add({ id: id, peer: peer })\n }\n\n /**\n * Remove a given peer from the table.\n *\n * @param {PeerId} peer\n */\n async remove (peer) {\n const id = await utils.convertPeerId(peer)\n\n this.kb.remove(id)\n }\n}\n\nmodule.exports = RoutingTable\n","/*\nindex.js - Kademlia DHT K-bucket implementation as a binary tree.\n\nThe MIT License (MIT)\n\nCopyright (c) 2013-2021 Tristan Slominski\n\nPermission is hereby granted, free of charge, to any person\nobtaining a copy of this software and associated documentation\nfiles (the \"Software\"), to deal in the Software without\nrestriction, including without limitation the rights to use,\ncopy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the\nSoftware is furnished to do so, subject to the following\nconditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES\nOF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\nNONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\nHOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,\nWHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\nFROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR\nOTHER DEALINGS IN THE SOFTWARE.\n*/\n'use strict'\n\nconst randomBytes = require('randombytes')\nconst { EventEmitter } = require('events')\n\n/**\n * @param {Uint8Array} array1\n * @param {Uint8Array} array2\n * @return {Boolean}\n */\nfunction arrayEquals (array1, array2) {\n if (array1 === array2) {\n return true\n }\n if (array1.length !== array2.length) {\n return false\n }\n for (let i = 0, length = array1.length; i < length; ++i) {\n if (array1[i] !== array2[i]) {\n return false\n }\n }\n return true\n}\n\nfunction createNode () {\n return { contacts: [], dontSplit: false, left: null, right: null }\n}\n\nfunction ensureInt8 (name, val) {\n if (!(val instanceof Uint8Array)) {\n throw new TypeError(name + ' is not a Uint8Array')\n }\n}\n\n/**\n * Implementation of a Kademlia DHT k-bucket used for storing\n * contact (peer node) information.\n *\n * @extends EventEmitter\n */\nclass KBucket extends EventEmitter {\n /**\n * `options`:\n * `distance`: _Function_\n * `function (firstId, secondId) { return distance }` An optional\n * `distance` function that gets two `id` Uint8Arrays\n * and return distance (as number) between them.\n * `arbiter`: _Function_ _(Default: vectorClock arbiter)_\n * `function (incumbent, candidate) { return contact; }` An optional\n * `arbiter` function that givent two `contact` objects with the same `id`\n * returns the desired object to be used for updating the k-bucket. For\n * more details, see [arbiter function](#arbiter-function).\n * `localNodeId`: _Uint8Array_ An optional Uint8Array representing the local node id.\n * If not provided, a local node id will be created via `randomBytes(20)`.\n * `metadata`: _Object_ _(Default: {})_ Optional satellite data to include\n * with the k-bucket. `metadata` property is guaranteed not be altered by,\n * it is provided as an explicit container for users of k-bucket to store\n * implementation-specific data.\n * `numberOfNodesPerKBucket`: _Integer_ _(Default: 20)_ The number of nodes\n * that a k-bucket can contain before being full or split.\n * `numberOfNodesToPing`: _Integer_ _(Default: 3)_ The number of nodes to\n * ping when a bucket that should not be split becomes full. KBucket will\n * emit a `ping` event that contains `numberOfNodesToPing` nodes that have\n * not been contacted the longest.\n *\n * @param {Object=} options optional\n */\n constructor (options = {}) {\n super()\n\n this.localNodeId = options.localNodeId || randomBytes(20)\n this.numberOfNodesPerKBucket = options.numberOfNodesPerKBucket || 20\n this.numberOfNodesToPing = options.numberOfNodesToPing || 3\n this.distance = options.distance || KBucket.distance\n // use an arbiter from options or vectorClock arbiter by default\n this.arbiter = options.arbiter || KBucket.arbiter\n this.metadata = Object.assign({}, options.metadata)\n\n ensureInt8('option.localNodeId as parameter 1', this.localNodeId)\n\n this.root = createNode()\n }\n\n /**\n * Default arbiter function for contacts with the same id. Uses\n * contact.vectorClock to select which contact to update the k-bucket with.\n * Contact with larger vectorClock field will be selected. If vectorClock is\n * the same, candidat will be selected.\n *\n * @param {Object} incumbent Contact currently stored in the k-bucket.\n * @param {Object} candidate Contact being added to the k-bucket.\n * @return {Object} Contact to updated the k-bucket with.\n */\n static arbiter (incumbent, candidate) {\n return incumbent.vectorClock > candidate.vectorClock ? incumbent : candidate\n }\n\n /**\n * Default distance function. Finds the XOR\n * distance between firstId and secondId.\n *\n * @param {Uint8Array} firstId Uint8Array containing first id.\n * @param {Uint8Array} secondId Uint8Array containing second id.\n * @return {Number} Integer The XOR distance between firstId\n * and secondId.\n */\n static distance (firstId, secondId) {\n let distance = 0\n let i = 0\n const min = Math.min(firstId.length, secondId.length)\n const max = Math.max(firstId.length, secondId.length)\n for (; i < min; ++i) {\n distance = distance * 256 + (firstId[i] ^ secondId[i])\n }\n for (; i < max; ++i) distance = distance * 256 + 255\n return distance\n }\n\n /**\n * Adds a contact to the k-bucket.\n *\n * @param {Object} contact the contact object to add\n */\n add (contact) {\n ensureInt8('contact.id', (contact || {}).id)\n\n let bitIndex = 0\n let node = this.root\n\n while (node.contacts === null) {\n // this is not a leaf node but an inner node with 'low' and 'high'\n // branches; we will check the appropriate bit of the identifier and\n // delegate to the appropriate node for further processing\n node = this._determineNode(node, contact.id, bitIndex++)\n }\n\n // check if the contact already exists\n const index = this._indexOf(node, contact.id)\n if (index >= 0) {\n this._update(node, index, contact)\n return this\n }\n\n if (node.contacts.length < this.numberOfNodesPerKBucket) {\n node.contacts.push(contact)\n this.emit('added', contact)\n return this\n }\n\n // the bucket is full\n if (node.dontSplit) {\n // we are not allowed to split the bucket\n // we need to ping the first this.numberOfNodesToPing\n // in order to determine if they are alive\n // only if one of the pinged nodes does not respond, can the new contact\n // be added (this prevents DoS flodding with new invalid contacts)\n this.emit('ping', node.contacts.slice(0, this.numberOfNodesToPing), contact)\n return this\n }\n\n this._split(node, bitIndex)\n return this.add(contact)\n }\n\n /**\n * Get the n closest contacts to the provided node id. \"Closest\" here means:\n * closest according to the XOR metric of the contact node id.\n *\n * @param {Uint8Array} id Contact node id\n * @param {Number=} n Integer (Default: Infinity) The maximum number of\n * closest contacts to return\n * @return {Array} Array Maximum of n closest contacts to the node id\n */\n closest (id, n = Infinity) {\n ensureInt8('id', id)\n\n if ((!Number.isInteger(n) && n !== Infinity) || n <= 0) {\n throw new TypeError('n is not positive number')\n }\n\n let contacts = []\n\n for (let nodes = [this.root], bitIndex = 0; nodes.length > 0 && contacts.length < n;) {\n const node = nodes.pop()\n if (node.contacts === null) {\n const detNode = this._determineNode(node, id, bitIndex++)\n nodes.push(node.left === detNode ? node.right : node.left)\n nodes.push(detNode)\n } else {\n contacts = contacts.concat(node.contacts)\n }\n }\n\n return contacts\n .map(a => [this.distance(a.id, id), a])\n .sort((a, b) => a[0] - b[0])\n .slice(0, n)\n .map(a => a[1])\n }\n\n /**\n * Counts the total number of contacts in the tree.\n *\n * @return {Number} The number of contacts held in the tree\n */\n count () {\n // return this.toArray().length\n let count = 0\n for (const nodes = [this.root]; nodes.length > 0;) {\n const node = nodes.pop()\n if (node.contacts === null) nodes.push(node.right, node.left)\n else count += node.contacts.length\n }\n return count\n }\n\n /**\n * Determines whether the id at the bitIndex is 0 or 1.\n * Return left leaf if `id` at `bitIndex` is 0, right leaf otherwise\n *\n * @param {Object} node internal object that has 2 leafs: left and right\n * @param {Uint8Array} id Id to compare localNodeId with.\n * @param {Number} bitIndex Integer (Default: 0) The bit index to which bit\n * to check in the id Uint8Array.\n * @return {Object} left leaf if id at bitIndex is 0, right leaf otherwise.\n */\n _determineNode (node, id, bitIndex) {\n // **NOTE** remember that id is a Uint8Array and has granularity of\n // bytes (8 bits), whereas the bitIndex is the _bit_ index (not byte)\n\n // id's that are too short are put in low bucket (1 byte = 8 bits)\n // (bitIndex >> 3) finds how many bytes the bitIndex describes\n // bitIndex % 8 checks if we have extra bits beyond byte multiples\n // if number of bytes is <= no. of bytes described by bitIndex and there\n // are extra bits to consider, this means id has less bits than what\n // bitIndex describes, id therefore is too short, and will be put in low\n // bucket\n const bytesDescribedByBitIndex = bitIndex >> 3\n const bitIndexWithinByte = bitIndex % 8\n if ((id.length <= bytesDescribedByBitIndex) && (bitIndexWithinByte !== 0)) {\n return node.left\n }\n\n const byteUnderConsideration = id[bytesDescribedByBitIndex]\n\n // byteUnderConsideration is an integer from 0 to 255 represented by 8 bits\n // where 255 is 11111111 and 0 is 00000000\n // in order to find out whether the bit at bitIndexWithinByte is set\n // we construct (1 << (7 - bitIndexWithinByte)) which will consist\n // of all bits being 0, with only one bit set to 1\n // for example, if bitIndexWithinByte is 3, we will construct 00010000 by\n // (1 << (7 - 3)) -> (1 << 4) -> 16\n if (byteUnderConsideration & (1 << (7 - bitIndexWithinByte))) {\n return node.right\n }\n\n return node.left\n }\n\n /**\n * Get a contact by its exact ID.\n * If this is a leaf, loop through the bucket contents and return the correct\n * contact if we have it or null if not. If this is an inner node, determine\n * which branch of the tree to traverse and repeat.\n *\n * @param {Uint8Array} id The ID of the contact to fetch.\n * @return {Object|Null} The contact if available, otherwise null\n */\n get (id) {\n ensureInt8('id', id)\n\n let bitIndex = 0\n\n let node = this.root\n while (node.contacts === null) {\n node = this._determineNode(node, id, bitIndex++)\n }\n\n // index of uses contact id for matching\n const index = this._indexOf(node, id)\n return index >= 0 ? node.contacts[index] : null\n }\n\n /**\n * Returns the index of the contact with provided\n * id if it exists, returns -1 otherwise.\n *\n * @param {Object} node internal object that has 2 leafs: left and right\n * @param {Uint8Array} id Contact node id.\n * @return {Number} Integer Index of contact with provided id if it\n * exists, -1 otherwise.\n */\n _indexOf (node, id) {\n for (let i = 0; i < node.contacts.length; ++i) {\n if (arrayEquals(node.contacts[i].id, id)) return i\n }\n\n return -1\n }\n\n /**\n * Removes contact with the provided id.\n *\n * @param {Uint8Array} id The ID of the contact to remove.\n * @return {Object} The k-bucket itself.\n */\n remove (id) {\n ensureInt8('the id as parameter 1', id)\n\n let bitIndex = 0\n let node = this.root\n\n while (node.contacts === null) {\n node = this._determineNode(node, id, bitIndex++)\n }\n\n const index = this._indexOf(node, id)\n if (index >= 0) {\n const contact = node.contacts.splice(index, 1)[0]\n this.emit('removed', contact)\n }\n\n return this\n }\n\n /**\n * Splits the node, redistributes contacts to the new nodes, and marks the\n * node that was split as an inner node of the binary tree of nodes by\n * setting this.root.contacts = null\n *\n * @param {Object} node node for splitting\n * @param {Number} bitIndex the bitIndex to which byte to check in the\n * Uint8Array for navigating the binary tree\n */\n _split (node, bitIndex) {\n node.left = createNode()\n node.right = createNode()\n\n // redistribute existing contacts amongst the two newly created nodes\n for (const contact of node.contacts) {\n this._determineNode(node, contact.id, bitIndex).contacts.push(contact)\n }\n\n node.contacts = null // mark as inner tree node\n\n // don't split the \"far away\" node\n // we check where the local node would end up and mark the other one as\n // \"dontSplit\" (i.e. \"far away\")\n const detNode = this._determineNode(node, this.localNodeId, bitIndex)\n const otherNode = node.left === detNode ? node.right : node.left\n otherNode.dontSplit = true\n }\n\n /**\n * Returns all the contacts contained in the tree as an array.\n * If this is a leaf, return a copy of the bucket. If this is not a leaf,\n * return the union of the low and high branches (themselves also as arrays).\n *\n * @return {Array} All of the contacts in the tree, as an array\n */\n toArray () {\n let result = []\n for (const nodes = [this.root]; nodes.length > 0;) {\n const node = nodes.pop()\n if (node.contacts === null) nodes.push(node.right, node.left)\n else result = result.concat(node.contacts)\n }\n return result\n }\n\n /**\n * Similar to `toArray()` but instead of buffering everything up into an\n * array before returning it, yields contacts as they are encountered while\n * walking the tree.\n *\n * @return {Iterable} All of the contacts in the tree, as an iterable\n */\n * toIterable () {\n for (const nodes = [this.root]; nodes.length > 0;) {\n const node = nodes.pop()\n if (node.contacts === null) {\n nodes.push(node.right, node.left)\n } else {\n yield * node.contacts\n }\n }\n }\n\n /**\n * Updates the contact selected by the arbiter.\n * If the selection is our old contact and the candidate is some new contact\n * then the new contact is abandoned (not added).\n * If the selection is our old contact and the candidate is our old contact\n * then we are refreshing the contact and it is marked as most recently\n * contacted (by being moved to the right/end of the bucket array).\n * If the selection is our new contact, the old contact is removed and the new\n * contact is marked as most recently contacted.\n *\n * @param {Object} node internal object that has 2 leafs: left and right\n * @param {Number} index the index in the bucket where contact exists\n * (index has already been computed in a previous\n * calculation)\n * @param {Object} contact The contact object to update.\n */\n _update (node, index, contact) {\n // sanity check\n if (!arrayEquals(node.contacts[index].id, contact.id)) {\n throw new Error('wrong index for _update')\n }\n\n const incumbent = node.contacts[index]\n const selection = this.arbiter(incumbent, contact)\n // if the selection is our old contact and the candidate is some new\n // contact, then there is nothing to do\n if (selection === incumbent && incumbent !== contact) return\n\n node.contacts.splice(index, 1) // remove old contact\n node.contacts.push(selection) // add more recent contact version\n this.emit('updated', incumbent, selection)\n }\n}\n\nmodule.exports = KBucket\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction xor(a, b) {\n if (a.length !== b.length) {\n throw new Error('Inputs should have the same length');\n }\n const result = new Uint8Array(a.length);\n for (let i = 0; i < a.length; i++) {\n result[i] = a[i] ^ b[i];\n }\n return result;\n}\n\nexports.xor = xor;\n","[\n\t77591, 22417, 43971, 28421, 740, 29829, 71467, 228973, 196661, 78537, 27689, 36431, 44415, 14362, 19456, 106025,\n\t96308, 2882, 49509, 21149, 87173, 131409, 75844, 23676, 121838, 30291, 17492, 2953, 7564, 110620, 129477, 127283,\n\t53113, 72417, 165166, 109690, 21200, 102125, 24049, 71504, 90342, 25307, 72039, 26812, 26715, 32264, 133800, 71161,\n\t88956, 171987, 51779, 24425, 16671, 30251, 186294, 247761, 14202, 2121, 8465, 35024, 4876, 85917, 169730, 3638,\n\t256836, 96184, 943, 18678, 6583, 52907, 35807, 112254, 214097, 18796, 11595, 9243, 23554, 887, 268203, 382004,\n\t24590, 111335, 11625, 16619, 29039, 102425, 69006, 97976, 92362, 32552, 63717, 41433, 128974, 137630, 59943, 10019,\n\t13986, 35430, 33665, 108037, 43799, 43280, 38195, 29078, 58629, 18265, 14425, 46832, 235538, 40830, 77881, 110717,\n\t58937, 3463, 325358, 51300, 47623, 117252, 19007, 10170, 20540, 91237, 294813, 4951, 79841, 56232, 36270, 128547,\n\t69209, 66275, 100156, 32063, 73531, 34439, 80937, 28892, 44466, 88595, 216307, 32583, 49620, 16605, 82127, 45807,\n\t21630, 78726, 20235, 40163, 111007, 96926, 5567, 72083, 21665, 58844, 39419, 179767, 48328, 42662, 51550, 5251,\n\t37811, 49608, 81056, 50854, 55513, 20922, 18891, 197409, 164656, 32593, 71449, 220474, 58919, 85682, 67854, 13758,\n\t35066, 3565, 61905, 214793, 119572, 141419, 21504, 10302, 27354, 67003, 46131, 32668, 15165, 64871, 34450, 17821,\n\t2757, 11452, 34189, 5160, 12257, 85523, 560, 53385, 65887, 119549, 135620, 312353, 115979, 122356, 10867, 193231,\n\t124537, 54783, 90675, 120791, 4715, 142253, 50943, 17271, 43358, 25331, 4917, 120566, 34580, 12878, 33786, 160528,\n\t32523, 4869, 301307, 104817, 81491, 23276, 8832, 97911, 31265, 52065, 7998, 49622, 9715, 43998, 34091, 84587,\n\t20664, 69041, 29419, 53205, 10838, 58288, 116145, 6185, 5154, 141795, 35924, 21307, 144738, 43730, 12085, 8279,\n\t10002, 119, 133779, 199668, 72938, 31768, 39176, 67875, 38453, 9700, 44144, 4121, 116048, 41733, 12868, 82669,\n\t92308, 128, 34262, 11332, 7712, 90764, 36141, 13553, 71312, 77470, 117314, 96549, 49135, 23602, 54468, 28605,\n\t6327, 62308, 17171, 67531, 21319, 14105, 894, 107722, 46157, 8503, 51069, 100472, 45138, 15246, 14577, 35609,\n\t191464, 1757, 13364, 161349, 32067, 91705, 81144, 52339, 5408, 91066, 21983, 14157, 100545, 4372, 26630, 129112,\n\t1423, 29676, 213626, 4397, 88436, 99190, 6877, 49958, 26122, 114348, 60661, 29818, 293118, 50042, 179738, 16400,\n\t163423, 89627, 31040, 43973, 36638, 45952, 5153, 1894, 109322, 1898, 134021, 12402, 112077, 68309, 190269, 69866,\n\t31938, 107383, 11522, 105232, 11248, 14868, 39852, 71707, 186525, 16530, 38162, 106212, 11700, 5130, 16608, 26998,\n\t59586, 108399, 230033, 43683, 48135, 82179, 2073, 5015, 196684, 189293, 16378, 23452, 8301, 35640, 11632, 214551,\n\t29240, 57644, 33137, 91949, 55157, 52384, 117313, 5090, 17717, 89668, 49363, 82238, 241035, 66216, 29066, 184088,\n\t97206, 62820, 26595, 4241, 135635, 173672, 8202, 459, 71355, 146294, 29587, 3008, 135385, 141203, 14803, 6634,\n\t45094, 69362, 50925, 546, 51884, 62011, 83296, 234584, 44515, 56050, 89476, 87751, 19373, 12691, 149923, 19794,\n\t13833, 35846, 87557, 58339, 2884, 19145, 25647, 12224, 11024, 77338, 64608, 122297, 53025, 7205, 36189, 36294,\n\t170779, 21750, 7739, 173883, 75192, 35664, 224240, 113121, 30181, 26267, 27036, 117827, 92015, 106516, 55628, 203549,\n\t67949, 60462, 60844, 35911, 20457, 1820, 920, 19773, 8738, 73173, 181993, 38521, 98254, 76257, 46008, 92796,\n\t5384, 26868, 151566, 22124, 2411, 15919, 186872, 180021, 28099, 152961, 78811, 80237, 62352, 102653, 74259, 184890,\n\t16792, 123702, 224945, 29940, 19512, 75283, 14059, 112691, 92811, 233329, 20411, 138569, 53341, 109802, 50600, 134528,\n\t66747, 5529, 166531, 31578, 64732, 67189, 1596, 126357, 967, 167999, 206598, 109752, 119431, 207825, 78791, 91938,\n\t10301, 27311, 24233, 252343, 28831, 32812, 66002, 112267, 90895, 8786, 8095, 16824, 22866, 21813, 60507, 174833,\n\t19549, 130985, 117051, 52110, 6938, 81923, 123864, 38061, 919, 18680, 53534, 46739, 112893, 161529, 85429, 26761,\n\t11900, 81121, 91968, 15390, 217947, 56524, 1713, 6654, 37089, 85630, 138866, 61850, 16491, 75577, 16884, 98296,\n\t73523, 6140, 44645, 6062, 36366, 29844, 57946, 37932, 42472, 5266, 20834, 19309, 33753, 127182, 134259, 35810,\n\t41805, 45878, 312001, 14881, 47757, 49251, 120050, 44252, 3708, 25856, 107864, 120347, 1228, 36550, 41682, 34496,\n\t47025, 8393, 173365, 246526, 12894, 161607, 35670, 90785, 126572, 2095, 124731, 157033, 58694, 554, 12786, 9642,\n\t4817, 16136, 47864, 174698, 66992, 4639, 69284, 10625, 40710, 27763, 51738, 30404, 264105, 137904, 109882, 52487,\n\t42824, 57514, 2740, 10479, 146799, 107390, 16586, 88038, 174951, 9410, 16185, 44158, 5568, 40658, 46108, 12763,\n\t97385, 26175, 108859, 664, 230732, 67470, 46663, 14395, 50750, 141320, 93140, 15361, 47997, 55784, 6791, 307840,\n\t118569, 107326, 18056, 58281, 260415, 54691, 8790, 73332, 45633, 7511, 45674, 143373, 14031, 11799, 94491, 35646,\n\t96544, 14560, 26049, 32983, 25791, 83814, 42094, 231370, 63955, 139212, 2359, 169908, 3108, 183486, 105867, 28197,\n\t32941, 124968, 26402, 88267, 149768, 23053, 3078, 19091, 52924, 25383, 19209, 111548, 97361, 3959, 24880, 235061,\n\t9099, 24921, 161254, 151405, 20508, 7159, 34381, 20133, 11434, 74036, 19974, 34769, 36585, 1076, 22454, 17354,\n\t38727, 235160, 111547, 96454, 117448, 156940, 91330, 37299, 7310, 26915, 117060, 51369, 22620, 61861, 322264, 106850,\n\t111694, 15091, 2624, 40345, 300446, 177064, 1707, 27389, 54792, 327783, 132669, 183543, 59003, 17744, 20603, 151134,\n\t106923, 53084, 71803, 279424, 319816, 11579, 21946, 16728, 38274, 72711, 5085, 83391, 88646, 40159, 25027, 34680,\n\t10752, 12988, 54126, 30365, 18338, 100445, 230674, 44874, 84974, 143877, 123253, 139372, 28082, 91477, 144002, 13096,\n\t219729, 46016, 50029, 42377, 14601, 6660, 58244, 58978, 23918, 88206, 113611, 64452, 17541, 41032, 10942, 12021,\n\t49189, 10978, 40175, 37156, 10947, 71709, 106894, 112538, 57007, 137486, 150608, 152719, 40615, 7746, 279716, 13101,\n\t19524, 28708, 40578, 72320, 1096, 182051, 94527, 51275, 22833, 45164, 81917, 77519, 48508, 5421, 140302, 37845,\n\t149830, 5587, 27579, 5357, 428725, 248187, 6326, 206760, 39814, 32585, 89923, 44341, 288753, 284443, 96368, 31201,\n\t94189, 119504, 20359, 52073, 103216, 179, 27934, 32801, 96035, 34111, 34309, 101326, 18198, 20704, 210266, 37643,\n\t27880, 141873, 106000, 19414, 56614, 167714, 66483, 107885, 86602, 4379, 20796, 75467, 4987, 5017, 118857, 26003,\n\t34308, 114428, 29198, 6686, 29697, 73632, 3739, 69795, 16798, 41504, 7207, 30722, 21436, 36735, 28067, 28545,\n\t3239, 11221, 36031, 41889, 100010, 19247, 317673, 29495, 174554, 6424, 129725, 53845, 94986, 7955, 59676, 2604,\n\t191497, 19735, 102214, 62954, 23844, 11872, 179525, 261436, 34492, 428, 78404, 142035, 16747, 17246, 27578, 37021,\n\t33672, 57944, 26056, 135760, 2369, 61674, 122066, 31327, 19374, 157065, 40553, 130982, 69619, 71290, 38855, 72100,\n\t92903, 95940, 51422, 165999, 65713, 57873, 50726, 7288, 20272, 2081, 42326, 22624, 81120, 57914, 79352, 19447,\n\t1684, 72302, 11774, 302559, 161481, 96396, 13692, 414988, 3721, 79066, 56627, 46883, 21150, 11747, 12184, 5856,\n\t113458, 176117, 84416, 52079, 27933, 3354, 59765, 141359, 2212, 216309, 2555, 23458, 196722, 142463, 45701, 44548,\n\t28798, 19418, 215, 29916, 9396, 10574, 114226, 84475, 13520, 18694, 34056, 4524, 90302, 62930, 13539, 19407,\n\t77209, 7728, 38088, 9535, 2263, 23875, 183945, 17750, 26274, 67172, 10585, 28042, 22199, 7478, 51331, 66030,\n\t26774, 192929, 31434, 25850, 50197, 52926, 178158, 4679, 181256, 70184, 229600, 9959, 105594, 72158, 73974, 2726,\n\t35085, 78087, 23284, 35568, 51713, 155676, 5401, 27254, 11966, 17569, 223253, 71993, 103357, 111477, 55722, 30504,\n\t26034, 46774, 35392, 36285, 214814, 41143, 163465, 1051, 16094, 81044, 6636, 76489, 179102, 20712, 39178, 35683,\n\t125177, 54219, 30617, 52994, 25324, 50123, 2543, 87529, 58995, 10688, 125199, 12388, 60158, 125481, 131646, 7642,\n\t133350, 65874, 3438, 97277, 101450, 10075, 56344, 116821, 50778, 60547, 98016, 106135, 13859, 14255, 16300, 77373,\n\t173521, 8285, 45932, 37426, 4054, 114295, 55947, 7703, 39114, 52, 51119, 128135, 19714, 60715, 9554, 50492,\n\t88180, 2823, 118271, 52993, 122625, 97919, 23859, 37895, 25040, 33614, 32102, 20431, 3577, 9275, 15686, 43031,\n\t157741, 110358, 1884, 40291, 125391, 13736, 5008, 64881, 87336, 77381, 70711, 43032, 49155, 118587, 70494, 4318,\n\t10168, 30126, 12580, 10524, 280104, 104001, 145413, 2862, 84140, 6603, 106005, 13566, 12780, 11251, 42830, 571,\n\t179910, 82443, 13146, 469, 42714, 32591, 265217, 424024, 92553, 54721, 134100, 6007, 15242, 114681, 59030, 16718,\n\t85465, 200214, 85982, 55174, 165013, 23493, 56964, 82529, 109150, 32706, 27568, 82442, 5350, 14976, 13165, 44890,\n\t60021, 21343, 33978, 17264, 4655, 22328, 27819, 75730, 16567, 55483, 14510, 17926, 45827, 150609, 3704, 7385,\n\t272531, 161543, 76904, 122163, 52405, 2039, 19165, 41623, 14423, 228354, 3369, 176360, 85491, 7122, 35789, 303724,\n\t4465, 13628, 2233, 55311, 118771, 20713, 10006, 221519, 45115, 71021, 35650, 29775, 7337, 10864, 20665, 21142,\n\t1746, 15080, 1624, 32449, 10905, 105743, 229797, 7701, 3940, 22997, 178467, 57208, 389057, 39683, 59403, 63344,\n\t63125, 54847, 69691, 18336, 56448, 3362, 37202, 18282, 29648, 138224, 35867, 10495, 5911, 28814, 26653, 31514,\n\t176702, 26550, 45621, 11734, 4525, 40543, 73944, 121080, 27858, 155561, 14887, 44670, 30742, 8796, 107455, 113472,\n\t56369, 75581, 183777, 240095, 133699, 153299, 8768, 160464, 26058, 49078, 103971, 21875, 71486, 44888, 17156, 9678,\n\t89541, 123019, 102337, 3972, 83930, 21245, 87852, 109660, 287918, 183019, 686, 10100, 39177, 283941, 11274, 24736,\n\t26793, 26214, 25995, 77011, 141580, 4070, 23742, 46285, 46632, 30700, 26669, 19056, 35951, 115575, 174034, 56097,\n\t35463, 87425, 24575, 44245, 38701, 82317, 85922, 281616, 100333, 147697, 61503, 7730, 84330, 8530, 59917, 61597,\n\t17173, 9092, 32658, 90288, 193136, 39023, 20381, 56654, 31132, 7779, 1919, 1375, 117128, 30819, 11169, 40938,\n\t23935, 115201, 101155, 151034, 4835, 11231, 74550, 89388, 59951, 91704, 107312, 167882, 115062, 12732, 72738, 88703,\n\t464019, 158267, 57995, 60496, 737, 14371, 123867, 4174, 243339, 159946, 7568, 16025, 134556, 110916, 38103, 191,\n\t80226, 88794, 29688, 27230, 10454, 76308, 57647, 77409, 113483, 66864, 14745, 19808, 12023, 46583, 84805, 16015,\n\t17102, 2231, 20611, 3547, 95740, 250131, 34559, 108894, 8498, 15853, 159169, 148920, 20942, 2813, 93160, 45188,\n\t210613, 45531, 52587, 149062, 39782, 28194, 57849, 60965, 84954, 89766, 84453, 100927, 16501, 27658, 165311, 103841,\n\t54192, 207341, 19558, 20084, 319622, 5672, 205467, 98462, 61849, 36279, 13609, 147177, 24726, 165015, 209489, 59591,\n\t31157, 6551, 117580, 75060, 141146, 277310, 21072, 22023, 106474, 63041, 137443, 122965, 68371, 5383, 42146, 98961,\n\t113467, 30863, 23794, 4843, 99630, 30392, 82679, 13699, 241612, 33601, 93146, 24319, 18643, 32155, 95669, 40440,\n\t15333, 34089, 67799, 142144, 58245, 38633, 114531, 117400, 77861, 188726, 5507, 2568, 8853, 10987, 107222, 2663,\n\t2421, 11530, 13345, 30075, 41785, 118661, 104786, 17459, 12490, 16281, 71936, 193555, 17431, 5944, 71758, 26485,\n\t77317, 20803, 367167, 158, 7362, 93430, 11735, 172445, 46002, 11532, 54482, 930, 62911, 2235, 23004, 179236,\n\t4764, 101859, 208113, 22477, 55163, 95579, 14098, 67320, 162556, 90709, 156949, 3826, 57492, 4025, 34092, 87442,\n\t104565, 6718, 186015, 28214, 14209, 10039, 107186, 233912, 58877, 81637, 55265, 39828, 6194, 145813, 50831, 105849,\n\t4974, 88319, 122296, 10272, 197216, 95714, 51540, 72418, 23324, 91555, 8743, 140452, 250249, 51666, 34124, 7229,\n\t38592, 129641, 78169, 174242, 22464, 149964, 51450, 14034, 10026, 95376, 26190, 120062, 14401, 8700, 265, 31386,\n\t143573, 7203, 229889, 61567, 4227, 140981, 2466, 72052, 10787, 10062, 30958, 6099, 38471, 30103, 23202, 208101,\n\t70847, 467, 58934, 32271, 32984, 36637, 24107, 30771, 17109, 73353, 13650, 2098, 157040, 67366, 66904, 106018,\n\t265380, 107238, 18535, 44025, 32681, 144983, 62505, 91295, 56120, 3082, 77508, 10322, 63023, 36700, 81885, 224127,\n\t16721, 45023, 239261, 111272, 13852, 7866, 149243, 204199, 32309, 22084, 42029, 38316, 126644, 104973, 14406, 43454,\n\t67322, 61310, 15789, 40285, 24026, 181047, 6301, 70927, 23319, 115823, 27248, 66693, 115875, 278566, 63007, 146844,\n\t56841, 59007, 87368, 180001, 22370, 42114, 80605, 12022, 10374, 308, 25079, 14689, 12618, 63368, 7936, 264973,\n\t212291, 136713, 95999, 105801, 18965, 32075, 48700, 52230, 35119, 96912, 32992, 8586, 16606, 101333, 101812, 14969,\n\t39930, 759, 193090, 27387, 42914, 12937, 5058, 62646, 64528, 38624, 25743, 37502, 3716, 4435, 30352, 178687,\n\t26461, 132611, 42002, 138442, 35833, 59582, 16345, 8048, 60319, 49349, 309, 47800, 49739, 90482, 26405, 34470,\n\t63786, 32479, 85028, 39866, 47846, 11649, 23934, 29466, 2816, 42864, 31828, 7410, 74885, 49632, 47629, 111801,\n\t90749, 19536, 18767, 105764, 59606, 21223, 10746, 76298, 22220, 39408, 7190, 79654, 64856, 11602, 82156, 272765,\n\t17079, 70089, 245473, 51813, 184407, 384678, 1576, 122249, 5064, 27481, 6188, 25790, 74361, 27541, 318284, 45430,\n\t31488, 620, 93579, 45723, 192118, 22670, 51913, 4162, 70244, 35966, 26397, 16199, 50899, 209613, 121702, 287507,\n\t2993, 36101, 132229, 67345, 33062, 76295, 118628, 78705, 52316, 34375, 107083, 107454, 44863, 127561, 33964, 3073,\n\t154010, 190914, 55967, 39074, 6272, 31047, 5550, 41123, 26154, 98638, 47110, 19998, 148091, 50229, 31329, 59900,\n\t195442, 19106, 61347, 73497, 70015, 682, 45850, 25776, 38022, 148951, 6288, 37411, 232526, 109277, 27286, 32342,\n\t9262, 5220, 16651, 23175, 46740, 129438, 78614, 121925, 66914, 88710, 127952, 5563, 21500, 34521, 10739, 14863,\n\t191006, 62956, 17359, 16749, 67027, 56284, 69134, 43301, 35039, 58883, 54466, 60823, 404451, 75743, 59856, 86979,\n\t7923, 34273, 83785, 32142, 7693, 268986, 197428, 282681, 17049, 22346, 22990, 92245, 107180, 3357, 37104, 96724,\n\t49153, 7683, 31197, 43267, 82231, 164276, 23696, 20848, 188364, 22309, 24821, 158707, 1018, 22514, 70922, 27792,\n\t45589, 59709, 10765, 736, 35218, 63479, 51987, 24275, 63588, 55361, 92929, 81964, 4658, 20122, 12330, 44058,\n\t13065, 311456, 72224, 8337, 211229, 38979, 22590, 138478, 52757, 32595, 133600, 8838, 31549, 94412, 43391, 90056,\n\t1585, 94802, 127271, 6223, 31889, 137038, 132910, 2165, 57616, 230152, 6080, 10748, 36737, 74579, 134062, 50525,\n\t180532, 119270, 34556, 76155, 82394, 52595, 29258, 31435, 87820, 67996, 26943, 183878, 38007, 2410, 13526, 180297,\n\t69856, 3503, 187396, 167700, 7838, 16701, 9199, 56267, 3661, 37407, 65994, 23767, 5708, 62508, 221700, 67088,\n\t86978, 46776, 84434, 32088, 5612, 9149, 88244, 21685, 95151, 46750, 189612, 2979, 506311, 2594, 3628, 40074,\n\t105039, 78243, 28523, 6651, 38058, 71999, 30992, 12764, 68261, 108991, 6165, 26450, 61961, 13400, 22426, 7490,\n\t60890, 109623, 2070, 12958, 50355, 67979, 257096, 7213, 42578, 52121, 35716, 65461, 7516, 124758, 39268, 302,\n\t64712, 14977, 1467, 219452, 2840, 34229, 11121, 21602, 19270, 63574, 8024, 1532, 17331, 79839, 78885, 52029,\n\t180767, 57957, 6069, 91265, 61380, 55767, 8927, 32881, 287603, 22149, 35029, 68876, 6428, 199567, 46926, 13412,\n\t104132, 21434, 366616, 45060, 110046, 81924, 128910, 45886, 52821, 130416, 29416, 77342, 21762, 67329, 121432, 79924,\n\t11724, 38625, 81006, 102033, 28338, 13326, 3250, 82056, 82526, 38212, 21112, 12382, 111495, 3263, 7414, 86274,\n\t93490, 40844, 30224, 45212, 24019, 48411, 71367, 24941, 76729, 57776, 3769, 38114, 202019, 197745, 31953, 237533,\n\t33270, 201580, 255648, 100798, 44741, 32241, 98468, 106931, 10085, 15090, 170358, 33154, 66787, 18819, 69760, 25061,\n\t234005, 82660, 6295, 131975, 16874, 9076, 4094, 25005, 17740, 40908, 19533, 220019, 44330, 99792, 50040, 19619,\n\t13950, 55228, 24423, 31253, 95308, 103177, 184795, 28590, 82285, 5059, 3210, 75525, 49894, 70007, 56178, 10580,\n\t36051, 139681, 21617, 98736, 3555, 106306, 164189, 37352, 63915, 47824, 24883, 145530, 61904, 28444, 11483, 19837,\n\t145446, 30420, 112972, 85939, 11835, 191233, 2262, 20705, 58630, 1753, 148334, 1197, 144714, 6887, 11223, 107667,\n\t60879, 77914, 4151, 57417, 81594, 96681, 169430, 1784, 20444, 95138, 254041, 27038, 596, 7117, 72808, 13759,\n\t3353, 126776, 21074, 55322, 27081, 36942, 39547, 139830, 179275, 4453, 713, 8722, 71399, 19204, 25785, 22794,\n\t23923, 104114, 11291, 25458, 102309, 88396, 75288, 230440, 206396, 104551, 58447, 130857, 37247, 94734, 31548, 176529,\n\t226077, 65159, 20104, 10096, 66881, 94191, 237909, 27109, 37404, 1520, 27421, 25220, 113003, 23423, 24884, 50585,\n\t6286, 231877, 150800, 11789, 3226, 90004, 60642, 5053, 202400, 61442, 132531, 175329, 57138, 30116, 103847, 9973,\n\t75367, 16452, 32360, 59119, 21246, 10191, 164804, 23305, 61051, 37348, 154530, 13214, 5468, 50403, 66754, 130976,\n\t50559, 80515, 14436, 155492, 84017, 5472, 43107, 41240, 2890, 90431, 70188, 382, 76234, 48040, 50211, 281038,\n\t237007, 32115, 142178, 1536, 22761, 96429, 1811, 31243, 1679, 49143, 55209, 17402, 235054, 61494, 7462, 77030,\n\t34925, 87609, 78002, 9499, 9027, 73289, 201078, 101379, 63544, 27666, 5469, 10642, 30029, 49816, 132979, 95620,\n\t58086, 351930, 116300, 2110, 2043, 30845, 6154, 11279, 16727, 4122, 2277, 27281, 4971, 3650, 39060, 61970,\n\t65951, 39674, 75686, 38151, 11370, 130809, 177895, 32665, 63725, 122267, 7857, 39618, 118483, 44792, 157755, 178624,\n\t136994, 24260, 41308, 22471, 12404, 21707, 12486, 30473, 52781, 50246, 20247, 39065, 909, 56825, 103158, 128603,\n\t31542, 1089, 41935, 32744, 12428, 37963, 84420, 33134, 72921, 208449, 42622, 168151, 127335, 147107, 46699, 38216,\n\t12591, 94342, 85814, 31423, 24944, 2605, 87542, 67473, 192551, 4496, 56321, 91819, 17630, 6300, 256183, 114569,\n\t202090, 33209, 35289, 34897, 24967, 40520, 43470, 5344, 10199, 34810, 14283, 10381, 10017, 62923, 49924, 23233,\n\t64539, 13051, 35686, 19698, 11570, 135555, 120868, 44924, 87065, 52318, 52335, 47586, 140906, 245885, 109834, 78668,\n\t9065, 46990, 25258, 72022, 61243, 40838, 4545, 146387, 10537, 11557, 17470, 36930, 68104, 46711, 24264, 79401,\n\t81043, 18225, 120488, 24746, 84338, 81652, 28266, 13776, 21878, 46973, 1047, 230465, 73357, 95777, 24973, 210160,\n\t62210, 58404, 110633, 169651, 6937, 41870, 9909, 26822, 191062, 76553, 27519, 96256, 239070, 2478, 205678, 67955,\n\t58532, 20601, 50120, 19148, 78501, 195724, 110740, 8249, 109665, 27446, 30568, 57631, 31425, 49752, 32820, 65504,\n\t50079, 3663, 102256, 219898, 23849, 211315, 14645, 4359, 91767, 9528, 12449, 49366, 7941, 49763, 107848, 8930,\n\t27086, 50686, 9744, 10447, 81935, 39513, 46514, 1670, 29229, 6172, 22312, 137280, 97759, 9806, 14445, 22976,\n\t56458, 73391, 34983, 93760, 174219, 52573, 33149, 59747, 2429, 136277, 75123, 165263, 91040, 7446, 57632, 48633,\n\t97140, 246081, 84766, 151684, 79918, 93268, 120346, 54059, 54875, 77858, 32996, 103590, 45276, 11968, 19600, 25849,\n\t17159, 132907, 42828, 16817, 4913, 99462, 103303, 27395, 5737, 74184, 20749, 21160, 14377, 77062, 131403, 158735,\n\t10999, 27799, 77785, 9320, 34366, 51593, 61070, 33746, 47048, 29268, 36675, 30262, 53297, 9832, 82000, 20188,\n\t122292, 39917, 7331, 18160, 68301, 185935, 134830, 15031, 4935, 10004, 165845, 185534, 46923, 30109, 44134, 122631,\n\t18874, 22903, 112790, 26561, 18549, 348902, 82871, 140345, 255565, 135390, 63556, 103747, 145055, 179600, 145662, 296111,\n\t61661, 211987, 23952, 52342, 126343, 48450, 32919, 44277, 82185, 9591, 62139, 205363, 376969, 394874, 108461, 18040,\n\t120885, 14798, 39863, 16571, 16794, 58271, 81025, 55206, 14640, 118656, 6361, 44092, 85970, 6262, 153863, 108244,\n\t180200, 72264, 79947, 38044, 10050, 5735, 61221, 80712, 5471, 115689, 11391, 11661, 184257, 20010, 60116, 30320,\n\t19327, 134598, 45455, 27542, 18004, 125092, 452272, 1549, 91523, 46567, 180063, 156026, 2608, 11174, 58848, 37788,\n\t65907, 80194, 30490, 5786, 40775, 119519, 106241, 11323, 156297, 8425, 61495, 2617, 29675, 2425, 59886, 112582,\n\t49142, 59618, 4863, 50597, 86710, 50650, 168632, 27693, 85641, 83643, 18993, 25768, 84284, 28090, 93592, 36627,\n\t312804, 43381, 9887, 9402, 100931, 97165, 3311, 173330, 66805, 28935, 4963, 184460, 3201, 78102, 19126, 21607,\n\t37496, 24938, 22615, 16153, 32862, 134792, 153318, 61120, 6067, 2812, 12826, 12792, 23825, 37559, 64662, 202250,\n\t102694, 155488, 85881, 149193, 46233, 65383, 15521, 106982, 11358, 176786, 25752, 39717, 34208, 24510, 32464, 77742,\n\t39371, 72028, 138229, 60688, 71386, 102834, 132477, 2208, 11548, 63670, 271279, 28351, 30338, 38620, 32491, 99845,\n\t143885, 152266, 13252, 2825, 178663, 108097, 1775, 78201, 14897, 113573, 163346, 62292, 171129, 22183, 96598, 38733,\n\t64971, 166776, 117445, 9968, 146393, 44677, 74867, 20908, 97328, 12761, 25656, 26785, 9148, 112344, 26115, 99176,\n\t110121, 22437, 49547, 6180, 79320, 5835, 31392, 43328, 33377, 75870, 119860, 69497, 80273, 7325, 155219, 43167,\n\t111173, 28347, 20222, 3763, 71752, 55041, 47252, 14618, 28088, 15012, 97805, 194698, 54636, 2036, 41349, 6173,\n\t96604, 61530, 51859, 43782, 13361, 24334, 22668, 24792, 7070, 23441, 16789, 3209, 36211, 208475, 26242, 32880,\n\t122181, 182407, 21444, 31060, 88459, 29929, 77907, 12716, 10934, 97005, 20599, 31690, 8403, 58445, 30303, 22700,\n\t10336, 86731, 103115, 337709, 72556, 46788, 112566, 47684, 67089, 53548, 36874, 56487, 41387, 125985, 26893, 40071,\n\t106683, 73712, 18787, 40105, 72992, 67246, 137276, 50802, 36790, 70328, 138827, 22466, 39263, 183295, 29858, 50975,\n\t9322, 57397, 10654, 24364, 30383, 55799, 41600, 23584, 127295, 296610, 129078, 143558, 244131, 86397, 36049, 1085,\n\t80677, 3820, 108139, 5476, 34767, 24683, 7758, 13060, 7239, 131671, 250593, 59556, 103392, 29810, 4188, 252323,\n\t39404, 116877, 7651, 43600, 40338, 13554, 157253, 39196, 25978, 144387, 61211, 234, 50104, 6129, 10449, 93777,\n\t9240, 356378, 274148, 4439, 72970, 3724, 147770, 78680, 62570, 115877, 40027, 40547, 36817, 224392, 64609, 34795,\n\t165027, 67440, 2477, 37206, 23431, 50754, 164797, 46018, 94995, 170982, 27051, 7957, 22767, 3674, 27900, 56419,\n\t18930, 60701, 41302, 2692, 84749, 339721, 61996, 111094, 80221, 50129, 1045, 8153, 62945, 19202, 8250, 37208,\n\t37418, 32560, 79477, 41106, 88569, 33963, 36693, 5892, 30570, 1581, 66471, 49647, 11922, 160717, 29442, 5643,\n\t114865, 82962, 95982, 132098, 22633, 22838, 94726, 54556, 28566, 205039, 162340, 33216, 16849, 35847, 221339, 94851,\n\t26533, 71469, 1805, 3804, 12935, 45483, 71020, 36310, 65381, 192960, 34240, 35165, 59773, 1248, 46954, 155332,\n\t96864, 4246, 388800, 16129, 57133, 74592, 44807, 442014, 38203, 42574, 80818, 91592, 26377, 36424, 65760, 977,\n\t77387, 22628, 147610, 28018, 30561, 98454, 6969, 119628, 63648, 18170, 36854, 26601, 64018, 22027, 37279, 51395,\n\t152934, 21153, 9430, 58760, 194742, 5330, 55115, 34158, 28917, 174111, 13171, 122326, 1526, 43896, 66094, 25325,\n\t4234, 148354, 11450, 275, 18999, 112191, 44365, 22723, 68409, 8733, 57746, 96565, 75007, 14196, 108844, 29475,\n\t88599, 177563, 100792, 106156, 86323, 93726, 14248, 135341, 194131, 40126, 47099, 14779, 8272, 39597, 95983, 171398,\n\t65882, 28052, 10393, 47213, 40689, 22120, 72212, 106829, 34964, 109146, 753, 648, 21660, 30047, 17527, 181025,\n\t5619, 145357, 4085, 216883, 9359, 186951, 24779, 53931, 24545, 36197, 223296, 62628, 168101, 4243, 107313, 30321,\n\t26642, 13049, 51059, 31027, 107912, 807, 73550, 26551, 84369, 122422, 165872, 49754, 74213, 234264, 33151, 52014,\n\t33100, 87183, 22365, 52500, 40013, 23302, 5652, 72723, 21404, 26107, 48434, 587, 94049, 168493, 96418, 32871,\n\t70860, 31709, 25128, 443, 71597, 166253, 15670, 70994, 26341, 133675, 28280, 75491, 54756, 47955, 56028, 26182,\n\t11952, 113272, 472197, 64640, 110753, 17919, 337, 50642, 22576, 142, 87371, 53391, 93210, 126694, 15285, 19642,\n\t85667, 14148, 1506, 42092, 52962, 33243, 11970, 20734, 135843, 57044, 58880, 13002, 219134, 22876, 64754, 232519,\n\t4257, 43120, 321573, 24799, 64526, 124728, 52579, 81472, 70831, 276848, 17403, 74359, 23021, 182101, 74597, 23744,\n\t148267, 12055, 7976, 5349, 11772, 67540, 167347, 65318, 18720, 127832, 108238, 22828, 90233, 9987, 259080, 118185,\n\t73209, 79270, 13775, 90100, 137742, 90799, 70569, 15699, 19961, 9087, 67475, 57872, 39731, 8810, 134897, 131868,\n\t146849, 19898, 3334, 2281, 167061, 91073, 60356, 467742, 74712, 188, 53179, 137679, 92769, 29241, 9537, 132595,\n\t80119, 1041, 88962, 5976, 40171, 44911, 102859, 139059, 104558, 98987, 47761, 19272, 71472, 113864, 175377, 73338,\n\t10857, 23402, 23758, 1591, 139864, 5644, 4076, 118760, 16427, 134198, 18853, 20291, 100849, 37423, 22038, 36677,\n\t19071, 195521, 57445, 11069, 31869, 55718, 66882, 148490, 44, 41296, 75242, 49704, 166810, 9906, 20943, 122258,\n\t49112, 105667, 15969, 10344, 6408, 187694, 21399, 72742, 58970, 14867, 14376, 81889, 41856, 23225, 15042, 56993,\n\t16074, 131389, 74276, 72407, 53875, 383108, 53597, 37363, 68993, 44854, 122548, 430927, 198279, 38430, 80409, 12245,\n\t2981, 628, 2818, 17760, 37437, 238229, 7968, 46892, 2200, 3730, 34190, 65983, 37959, 112291, 87850, 70827,\n\t6522, 20750, 73913, 111621, 41652, 19587, 2780, 58668, 25916, 85259, 18200, 168962, 95781, 42445, 102050, 7776,\n\t57662, 103313, 47742, 96358, 41964, 66174, 100396, 29069, 204735, 19679, 27978, 7479, 40264, 22534, 61183, 36081,\n\t107436, 58223, 14680, 23002, 101311, 24716, 124108, 12908, 5646, 31750, 40380, 14215, 232799, 102772, 14122, 96775,\n\t61398, 50917, 12096, 149880, 67833, 598749, 124194, 155871, 49216, 790, 14677, 65319, 56917, 7440, 145744, 95701,\n\t12206, 49405, 129269, 76199, 45732, 9767, 11058, 9047, 210885, 11051, 7392, 26307, 2130, 8132, 147526, 20802,\n\t232698, 115660, 50060, 59789, 57344, 107623, 80343, 112676, 23291, 9866, 160971, 34032, 118291, 15719, 59730, 164911,\n\t28975, 2659, 58046, 78480, 21854, 66209, 53863, 109085, 116045, 29021, 46481, 107552, 22130, 18764, 70254, 31272,\n\t11300, 52460, 43933, 84738, 20721, 53869, 190840, 79673, 105300, 7561, 321817, 66924, 13940, 33281, 101046, 183181,\n\t32176, 71878, 5678, 62924, 79535, 56646, 40303, 19559, 27703, 93042, 73368, 42187, 3670, 37376, 46440, 7023,\n\t36816, 109628, 20680, 5940, 276440, 275233, 170848, 112093, 136996, 14984, 20226, 111441, 77693, 112960, 48577, 39370,\n\t55707, 50314, 123404, 26570, 54281, 61372, 123391, 4857, 35928, 246740, 132507, 106646, 44241, 7196, 92258, 9825,\n\t37688, 51197, 303141, 5590, 15476, 132986, 10955, 85782, 34486, 26696, 7991, 28813, 18858, 39546, 11703, 11365,\n\t38185, 5716, 93555, 11925, 40121, 60002, 6985, 10976, 171384, 3887, 43394, 13337, 56346, 6381, 252336, 39573,\n\t75042, 53711, 1028, 31781, 44295, 95925, 131713, 7214, 68125, 43571, 70954, 213234, 1628, 8760, 13391, 65485,\n\t17320, 56038, 1710, 25248, 60803, 57399, 19839, 3870, 326, 281556, 50945, 72400, 21460, 316244, 75619, 56246,\n\t98775, 481, 13513, 55765, 50427, 7388, 123519, 32929, 57908, 27124, 61316, 101097, 57467, 30228, 48792, 10788,\n\t20402, 37318, 50526, 155730, 34456, 158065, 145305, 17832, 43733, 64052, 4506, 35072, 205355, 177028, 184004, 187081,\n\t68616, 35938, 83703, 10367, 36892, 93186, 260137, 51934, 89970, 4985, 23445, 26755, 21558, 7948, 78741, 23376,\n\t124405, 85594, 68596, 57536, 49351, 12619, 56593, 132668, 99924, 109728, 71844, 71935, 196018, 65464, 17617, 14987,\n\t89701, 143773, 33997, 8687, 22701, 33258, 2914, 4436, 72108, 85610, 9671, 49067, 2327, 82988, 1361, 1672,\n\t44033, 35777, 30269, 24057, 10605, 82236, 616, 15793, 13919, 47249, 112086, 116698, 9484, 80207, 90574, 33304,\n\t68624, 93127, 56101, 42210, 160929, 4827, 38995, 38095, 4701, 125119, 5027, 33680, 9236, 231236, 14135, 87837,\n\t23318, 70261, 78893, 30151, 81482, 14332, 1084, 74256, 27532, 46644, 79185, 3148, 62615, 6981, 55672, 31668,\n\t36825, 1849, 14536, 37446, 14738, 23779, 43058, 162749, 72199, 1168, 21346, 5592, 85932, 85302, 9668, 18351,\n\t57135, 150360, 2080, 228015, 77953, 34670, 119302, 151751, 31009, 106725, 84265, 45214, 59289, 74178, 113071, 263206,\n\t111009, 4021, 44449, 188119, 192629, 123592, 392506, 292847, 114487, 12831, 205858, 9852, 20780, 79648, 75767, 357014,\n\t97721, 18166, 21005, 67950, 33226, 204009, 16536, 2987, 11335, 66717, 144910, 47950, 17262, 55060, 15063, 2934,\n\t51038, 26775, 178497, 66008, 3427, 49433, 128592, 20036, 157553, 63861, 3089, 23015, 51210, 28696, 35933, 49942,\n\t71135, 231518, 99620, 17248, 21835, 176536, 20676, 16944, 38700, 165831, 233253, 295625, 36723, 13023, 52745, 10907,\n\t19423, 67972, 125868, 95473, 82875, 1183, 108455, 52685, 33417, 64095, 21433, 52438, 33191, 127809, 44505, 211823,\n\t7810, 2752, 95548, 162031, 7185, 91196, 47563, 61721, 33359, 17897, 23682, 42806, 178101, 22874, 49707, 199897,\n\t75419, 82456, 8618, 11171, 79712, 116847, 18783, 44190, 46564, 5346, 59046, 95032, 7893, 14916, 3214, 26800,\n\t24172, 121453, 34362, 10250, 17408, 18888, 4840, 68696, 22831, 13162, 36005, 32512, 14800, 62357, 41723, 45046,\n\t27247, 37486, 5372, 2564, 34261, 298500, 66509, 133920, 89138, 31305, 117697, 19097, 108304, 81386, 84106, 23802,\n\t46411, 63304, 946, 51417, 41777, 41041, 19501, 115864, 60743, 294354, 37955, 94165, 18116, 1156, 17937, 20645,\n\t57114, 90804, 58042, 48643, 92288, 9861, 2557, 88546, 61333, 101008, 12853, 5148, 87856, 4152, 144503, 73841,\n\t18718, 9789, 147565, 10846, 42085, 12789, 30223, 8993, 56352, 67203, 2448, 28215, 6052, 23540, 126319, 75933,\n\t36689, 80235, 23231, 23561, 21383, 38800, 77548, 102798, 21234, 31468, 158608, 46188, 63960, 191679, 8051, 67014,\n\t11185, 170078, 42186, 28827, 34777, 41930, 212079, 12421, 34750, 24111, 110344, 73918, 45171, 70826, 141949, 40063,\n\t23979, 24254, 37309, 26724, 27179, 24718, 83648, 54938, 14591, 17425, 29525, 102675, 48975, 48654, 12316, 8929,\n\t60640, 41709, 50168, 63264, 89812, 50716, 48632, 38755, 138583, 160123, 55579, 71829, 24230, 233277, 46322, 39650,\n\t166388, 34718, 24108, 98252, 7031, 106695, 62498, 18258, 35062, 217827, 78731, 34824, 33354, 19520, 60852, 2432,\n\t60224, 8587, 2836, 62955, 702, 20227, 42285, 40560, 95592, 62486, 11094, 53035, 143291, 18842, 46177, 77994,\n\t1770, 9657, 107422, 172915, 32655, 128716, 25886, 25164, 156740, 119928, 165875, 85817, 11007, 89110, 33956, 12652,\n\t65156, 180266, 8494, 36889, 19958, 20955, 96, 1264, 118288, 135769, 44754, 86671, 5632, 19026, 168220, 289120,\n\t33569, 93821, 66144, 70635, 7687, 5642, 2714, 55445, 56636, 71545, 184182, 93133, 7332, 37389, 12643, 52315,\n\t22729, 11014, 158742, 17050, 152889, 50178, 34601, 41945, 52136, 9948, 26914, 63548, 95721, 115951, 40759, 8960,\n\t158258, 38938, 49232, 48325, 42234, 81523, 253019, 66128, 40978, 20048, 238048, 38760, 62928, 122560, 118532, 43687,\n\t137472, 163689, 26680, 9878, 17448, 51035, 16211, 60834, 36749, 29178, 14241, 59868, 150086, 2305, 26477, 42422,\n\t34342, 165341, 83279, 33894, 14257, 29928, 12743, 13957, 125571, 89134, 66712, 10952, 16507, 147839, 30146, 7249,\n\t16565, 45399, 39874, 114565, 215780, 31990, 230881, 171477, 102, 196546, 44538, 10880, 84948, 281705, 86651, 10617,\n\t31395, 2342, 453658, 43569, 60561, 132901, 21845, 17727, 58556, 258242, 22262, 58728, 4008, 77997, 11806, 37431,\n\t30599, 81375, 109137, 185787, 114085, 217292, 97453, 169085, 30593, 60212, 11544, 102056, 65580, 2384, 91655, 4855,\n\t95725, 7295, 157994, 16228, 20669, 53276, 141590, 105246, 17334, 25440, 76067, 17967, 39321, 38911, 11362, 28559,\n\t63807, 21627, 26468, 85816, 40120, 1025, 15234, 58319, 69516, 66512, 124548, 75845, 78873, 22137, 46681, 51242,\n\t85683, 32909, 76747, 35555, 43396, 101465, 1765, 73094, 1077, 2962, 39028, 66777, 57831, 42048, 15828, 13962,\n\t36041, 63657, 52412, 5242, 58846, 2141, 5506, 219012, 134451, 3936, 182230, 17558, 17153, 152237, 22621, 49377,\n\t170216, 35257, 68233, 65374, 6510, 11126, 212151, 7184, 2480, 22517, 3437, 33073, 30156, 16557, 3768, 55067,\n\t86829, 91000, 12350, 148650, 66017, 79424, 70885, 49066, 28250, 21369, 51213, 34533, 11510, 3258, 18176, 18465,\n\t84413, 6315, 36411, 163765, 4346, 356, 107618, 598, 13727, 285026, 162695, 8749, 14583, 7132, 63521, 184253,\n\t32378, 25991, 5604, 30961, 53675, 4874, 84693, 5086, 34811, 26978, 56564, 7904, 33519, 51221, 113942, 69253,\n\t6664, 125563, 22055, 220680, 102008, 742, 51930, 19494, 176108, 44424, 35123, 13025, 75685, 11759, 74335, 22250,\n\t181453, 131147, 16984, 132115, 154311, 11991, 76452, 52609, 85351, 196, 30969, 9198, 74919, 2529, 56838, 71779,\n\t29187, 116304, 3504, 62330, 41190, 86153, 28393, 254926, 104228, 105189, 13264, 84359, 3574, 12415, 8534, 57147,\n\t10175, 188174, 59504, 60932, 66318, 16407, 107921, 17638, 99103, 49278, 28403, 39786, 145865, 8462, 3558, 43406,\n\t142271, 29139, 21989, 36552, 93955, 72365, 7176, 13556, 106185, 37957, 321774, 17782, 129017, 51154, 27938, 24952,\n\t1935, 39366, 2791, 33489, 41582, 56078, 24558, 9311, 5449, 218786, 27808, 190429, 68013, 36020, 86003, 29735,\n\t3404, 87348, 119357, 115714, 2324, 86796, 81973, 40992, 43376, 93621, 28784, 16808, 36367, 2517, 2909, 191926,\n\t24978, 55303, 53308, 205724, 60068, 3098, 21375, 64784, 23949, 26579, 63121, 12319, 80145, 39967, 97861, 6757,\n\t70143, 67642, 37082, 34698, 69140, 122883, 46151, 62187, 80934, 429, 19437, 135071, 137885, 222647, 13331, 154065,\n\t327, 61778, 74257, 40116, 37493, 14855, 85079, 237641, 42342, 102164, 199965, 71204, 4662, 29368, 5042, 113914,\n\t122214, 8955, 13149, 102503, 43173, 5659, 163787, 69003, 307084, 63392, 171080, 21390, 81918, 86666, 36622, 24126,\n\t28887, 5736, 28054, 207170, 163428, 79891, 346467, 95363, 38980, 111806, 80828, 9200, 19288, 294896, 114468, 87405,\n\t111715, 141705, 7015, 72754, 68463, 48738, 243147, 33397, 101210, 37051, 98801, 82847, 20397, 4940, 185559, 18716,\n\t54718, 83491, 11725, 40803, 1128, 12128, 23060, 5174, 7745, 67007, 46701, 1571, 27807, 180186, 256996, 18975,\n\t16837, 7877, 212758, 250379, 15440, 87954, 57755, 24719, 124057, 83461, 258, 50864, 8874, 29038, 71289, 31627,\n\t15429, 9005, 4061, 113851, 107716, 82819, 13651, 79656, 117851, 17539, 111446, 12938, 39724, 190787, 4352, 15402,\n\t21070, 62708, 8539, 23777, 73853, 13552, 38810, 86117, 16285, 56400, 1718, 75342, 142863, 29033, 378, 110113,\n\t180321, 32586, 23606, 26393, 160984, 207987, 23783, 8406, 16904, 24596, 47274, 11693, 46539, 60524, 78595, 48423,\n\t31718, 20170, 9009, 146268, 15183, 191060, 172765, 1349, 138436, 37365, 10970, 40509, 225817, 20021, 70394, 152138,\n\t21541, 66559, 66544, 89352, 2725, 17258, 91345, 7313, 3815, 115868, 8660, 40362, 4071, 103524, 39388, 118275,\n\t21950, 6549, 38226, 32754, 209574, 29201, 43495, 18028, 20296, 40597, 18370, 47520, 202450, 24134, 2219, 8195,\n\t69545, 38041, 136934, 46374, 19041, 159811, 84865, 58620, 846, 98749, 13569, 30714, 97246, 32186, 4479, 27355,\n\t92973, 35214, 151491, 75963, 37631, 1561, 27200, 238083, 23182, 60756, 12291, 25766, 39355, 102333, 87362, 65741,\n\t59906, 19538, 201575, 48772, 102938, 24438, 292580, 39964, 66366, 9004, 61379, 50548, 37622, 38732, 28379, 68180,\n\t76622, 17488, 69849, 5963, 7219, 48143, 43413, 55358, 540, 58691, 29506, 19245, 52193, 48621, 5518, 13048,\n\t118625, 44755, 191081, 42061, 89197, 2259, 60665, 66994, 71210, 51232, 3585, 142096, 55024, 7892, 8345, 58653,\n\t463307, 65658, 64319, 137941, 136323, 53499, 12746, 43492, 6978, 95163, 29925, 60175, 5128, 7352, 41463, 184756,\n\t121146, 20473, 18426, 4598, 5309, 54580, 14277, 121151, 10691, 56711, 43880, 63409, 76682, 11830, 172218, 264898,\n\t32632, 66536, 81062, 31649, 25788, 92774, 60222, 11100, 63159, 9432, 224657, 25240, 53613, 152, 138620, 163829,\n\t2397, 85345, 12501, 37507, 64932, 38575, 43522, 65789, 80198, 78796, 35226, 3851, 108891, 73311, 3060, 28391,\n\t93671, 39663, 46142, 30982, 66041, 37281, 68157, 26553, 71872, 81142, 211527, 39747, 118119, 22695, 2859, 11066,\n\t20232, 168911, 7933, 197005, 17066, 111071, 44434, 133994, 120798, 12766, 227798, 45756, 132852, 29917, 36076, 55352,\n\t65281, 129800, 41958, 18944, 84678, 18580, 168093, 132621, 39997, 54092, 27740, 32354, 3770, 114118, 103242, 43918,\n\t15899, 18574, 145944, 3190, 123469, 219903, 24169, 100571, 62403, 16776, 92779, 14535, 17168, 16475, 14304, 37231,\n\t1712, 28218, 242754, 61688, 28980, 1318, 51359, 222657, 99200, 67989, 31772, 23932, 35351, 201251, 49041, 27306,\n\t19128, 40135, 3986, 77333, 19649, 120683, 151927, 21081, 7076, 78375, 77501, 101599, 8011, 89585, 96715, 58179,\n\t5378, 102138, 106793, 26051, 217276, 4197, 16297, 27014, 46721, 13322, 22806, 5278, 29629, 70632, 9647, 71519,\n\t58818, 40603, 128530, 8903, 36770, 56900, 31483, 26935, 43845, 34265, 34920, 87658, 6114, 84767, 64250, 47318,\n\t50720, 19264, 162514, 33357, 13117, 6705, 46696, 75032, 71054, 87004, 42035, 69138, 11903, 99854, 102328, 19611,\n\t34525, 69312, 6431, 49842, 101600, 133178, 108751, 41829, 89939, 225664, 48916, 99556, 9195, 130387, 5960, 36857,\n\t116724, 53518, 94002, 39077, 53996, 6945, 22261, 64291, 8314, 152785, 57588, 16522, 9091, 5048, 87671, 35441,\n\t39509, 1945, 12423, 158923, 178413, 37549, 14095, 1475, 73188, 62878, 4819, 24012, 68534, 42606, 4010, 120809,\n\t57497, 59564, 101758, 103718, 32701, 80116, 12345, 95834, 46918, 21468, 53213, 15665, 31200, 3867, 5140, 96013,\n\t250744, 21016, 10069, 13968, 35449, 180829, 27683, 39704, 59956, 22893, 3115, 26293, 32785, 75934, 62445, 141162,\n\t62720, 2018, 83638, 19949, 114012, 95006, 3330, 99829, 130935, 309272, 9565, 55874, 121727, 37017, 23586, 319858,\n\t40970, 27602, 8625, 112329, 61060, 100088, 118525, 25922, 16232, 1907, 60671, 51583, 44553, 80993, 5262, 94679,\n\t8676, 940, 20736, 11823, 3020, 16476, 12340, 152600, 97416, 3703, 25744, 66826, 16245, 16876, 46446, 84798,\n\t74227, 176020, 45192, 61955, 75496, 23946, 23626, 40372, 26036, 6149, 11822, 30582, 16541, 41914, 82385, 232823,\n\t40921, 80773, 14930, 3631, 7517, 39619, 4348, 36180, 126106, 138939, 62611, 1477, 113512, 47321, 25052, 14546,\n\t118881, 29060, 23589, 128322, 36795, 18401, 137921, 104699, 267929, 36194, 172791, 18113, 4766, 188215, 30083, 332586,\n\t94089, 5805, 77909, 22194, 68234, 154976, 43220, 40660, 70001, 184893, 138095, 11128, 103010, 22663, 5108, 212615,\n\t8485, 5565, 49222, 54614, 26530, 42639, 16319, 55062, 152662, 105595, 21114, 22216, 10294, 68158, 10436, 86950,\n\t7206, 62115, 3977, 3657, 59874, 456, 118617, 18156, 106663, 112229, 80992, 17442, 8217, 55551, 5133, 34344,\n\t251927, 51153, 39364, 201321, 7816, 66803, 23057, 156724, 145664, 14276, 95705, 979, 2796, 6875, 13429, 212525,\n\t50602, 26276, 28284, 3424, 19465, 52397, 46963, 31420, 51399, 206476, 92317, 48851, 637, 100820, 83349, 10317,\n\t60227, 21972, 6908, 282439, 32857, 224767, 95629, 83882, 42106, 87338, 69757, 29840, 68709, 37665, 45244, 114577,\n\t49188, 175943, 54009, 186746, 106158, 70168, 3358, 234002, 50555, 9221, 129338, 9562, 20118, 32923, 78479, 118280,\n\t65752, 4977, 10474, 102174, 60947, 129006, 10570, 83451, 8598, 8078, 159367, 123785, 80438, 16742, 5905, 5281,\n\t181513, 42402, 6977, 163136, 93179, 42191, 14968, 50421, 112401, 105440, 33456, 57347, 121611, 4221, 94954, 36517,\n\t24046, 27796, 6255, 33394, 72990, 135408, 116627, 1233, 57874, 25654, 95419, 68156, 401399, 313338, 55208, 45573,\n\t93124, 119251, 47200, 38196, 11909, 130667, 45391, 73904, 64964, 167846, 4137, 115606, 52036, 62214, 7969, 160925,\n\t7187, 1132, 134835, 40309, 73195, 64494, 80472, 444841, 61111, 26500, 45323, 40743, 53625, 52797, 22659, 15631,\n\t29739, 36706, 28841, 39147, 102836, 26794, 10536, 14845, 87305, 45874, 12241, 127587, 83833, 57183, 79722, 30844,\n\t41304, 84655, 20825, 92500, 3722, 25655, 27811, 10157, 81634, 31362, 34088, 92487, 70123, 22190, 185100, 72658,\n\t139035, 192523, 88241, 2078, 230490, 44528, 85638, 100198, 22088, 29982, 291233, 241062, 13865, 4445, 137791, 37835,\n\t107218, 31726, 19718, 38234, 72528, 23046, 19177, 66695, 5109, 17251, 28077, 5617, 21554, 47839, 72425, 133825,\n\t1486, 73065, 181275, 141508, 21768, 62971, 63082, 2512, 34200, 9904, 120309, 6392, 91243, 68416, 268253, 41199,\n\t116757, 138551, 185526, 41246, 28986, 4093, 19057, 17295, 4148, 245766, 122360, 35356, 112075, 20301, 75441, 10998,\n\t7977, 19769, 62922, 937, 63547, 100196, 26427, 157820, 20983, 236696, 22935, 8140, 90315, 156004, 47204, 140973,\n\t7726, 45097, 52725, 22636, 23436, 257282, 105247, 522, 88389, 216031, 202204, 46812, 211666, 19693, 68828, 81691,\n\t45925, 11256, 30292, 372, 5236, 167826, 88328, 232776, 151611, 5360, 82104, 18841, 80393, 25465, 18285, 20320,\n\t72377, 31730, 33160, 45803, 38715, 27705, 37379, 24163, 18360, 103586, 4015, 32305, 269494, 91252, 20080, 36567,\n\t54650, 7797, 57073, 12650, 31164, 42209, 6375, 261663, 105528, 81661, 106002, 2800, 5375, 17247, 43151, 4442,\n\t15727, 194619, 100855, 144898, 62320, 78465, 39929, 16454, 1967, 28311, 61363, 17219, 9395, 8745, 121445, 76939,\n\t80385, 162380, 22009, 54191, 44248, 16299, 122830, 48151, 74429, 78291, 64755, 14238, 44966, 2511, 17712, 67954,\n\t93583, 829, 105899, 49935, 84750, 11591, 33185, 85447, 42717, 27409, 208542, 28965, 62052, 52525, 5597, 25694,\n\t65594, 16343, 63224, 276188, 12475, 9331, 127507, 38522, 57287, 24128, 133161, 79723, 105548, 133695, 48917, 27558,\n\t43278, 46520, 13778, 141954, 110785, 83366, 17715, 46317, 105763, 66298, 147013, 41086, 94180, 16478, 220447, 44611,\n\t730, 19722, 78975, 117889, 125643, 26254, 16574, 18480, 65006, 15806, 38549, 246418, 46052, 36056, 8440, 34984,\n\t30170, 3163, 59800, 4458, 115442, 4283, 41970, 33507, 104078, 1653, 22, 121158, 276486, 3655, 6338, 24048,\n\t133421, 23641, 2161, 24422, 36006, 8086, 10675, 181474, 12307, 29514, 59143, 14729, 52509, 87128, 122470, 19446,\n\t80852, 33314, 24573, 119864, 14237, 9652, 57779, 6612, 51851, 15284, 98871, 90581, 124466, 156831, 21190, 22015,\n\t71380, 161906, 87247, 69201, 18392, 17908, 108470, 72962, 40719, 14338, 17911, 95260, 43339, 20610, 78916, 20710,\n\t72451, 11315, 31448, 17263, 58853, 178878, 48111, 116002, 45497, 80506, 82605, 85880, 36300, 121755, 25215, 36118,\n\t301929, 88728, 405223, 276136, 553, 34704, 212438, 49970, 78329, 922, 20711, 25036, 257130, 38295, 145369, 18128,\n\t15385, 30829, 55656, 48345, 8012, 3561, 28004, 122041, 192900, 58338, 112508, 41085, 29976, 87040, 47117, 23905,\n\t4336, 92061, 138880, 97407, 42083, 172121, 6256, 25192, 172671, 5, 93568, 1420, 12677, 31605, 56743, 40620,\n\t6015, 78415, 231077, 31298, 80026, 13902, 19048, 24924, 170586, 32955, 176119, 87859, 36731, 6773, 27711, 24658,\n\t26475, 115216, 133207, 93250, 95820, 88522, 8317, 5714, 124047, 55219, 86860, 19677, 23961, 22928, 162209, 8904,\n\t225992, 359835, 56084, 96201, 29392, 96558, 86071, 93643, 55114, 13347, 8183, 95129, 82012, 2017, 123336, 34219,\n\t115554, 157159, 47747, 101684, 41008, 18735, 193781, 104151, 226906, 7552, 179874, 124113, 31159, 21162, 44010, 14771,\n\t51268, 166128, 31382, 73124, 77438, 92830, 205709, 12113, 1292, 38937, 13114, 1334, 2118, 15597, 69581, 14449,\n\t21934, 76618, 48728, 67038, 14967, 51495, 24243, 87736, 147249, 26720, 11119, 46063, 43749, 5843, 44147, 152629,\n\t133428, 65703, 14269, 45604, 57982, 28672, 55616, 45957, 8438, 95433, 37698, 220862, 132034, 39456, 61870, 4161,\n\t26501, 73560, 56418, 9845, 4654, 20916, 10456, 88920, 119358, 9015, 65931, 96507, 48029, 38534, 21676, 109081,\n\t43078, 34943, 25089, 6131, 28766, 23665, 5477, 10255, 16695, 67, 45778, 42443, 42770, 29534, 23733, 100513,\n\t62617, 42630, 48746, 14191, 43753, 50295, 26007, 8792, 57243, 43119, 54725, 164253, 58250, 112304, 131796, 25165,\n\t4651, 3188, 24831, 47748, 3705, 19540, 13211, 102095, 5593, 18699, 23666, 32005, 117571, 33541, 60584, 74573,\n\t86311, 99443, 25172, 27222, 168938, 7143, 11853, 53560, 18834, 19960, 86522, 28217, 53266, 117700, 72989, 34323,\n\t18721, 66450, 34346, 74056, 47217, 202002, 46269, 9429, 68582, 75458, 37823, 82843, 96652, 32549, 145144, 27958,\n\t19820, 158086, 31955, 201406, 135379, 31207, 192545, 12950, 51704, 9094, 248263, 76147, 64028, 110009, 79407, 89345,\n\t99284, 223492, 47966, 26848, 15359, 201137, 2861, 110507, 71231, 72297, 31851, 118777, 71039, 151051, 240855, 16333,\n\t50766, 14727, 7939, 4149, 80908, 418780, 88378, 59276, 1327, 7284, 38576, 79814, 65820, 42199, 84860, 49574,\n\t62596, 12396, 70598, 40117, 8648, 7994, 16836, 7630, 14047, 359699, 106878, 525, 29037, 28064, 13380, 11675,\n\t50669, 74216, 103539, 180314, 27449, 56299, 172344, 19274, 7301, 246099, 32043, 19422, 36506, 129317, 6806, 30140,\n\t4614, 46639, 66926, 932, 86600, 6322, 27847, 233103, 10541, 39025, 34887, 3517, 12972, 26220, 2031, 66561,\n\t115015, 48658, 47596, 12714, 33845, 3893, 16165, 35237, 89983, 14769, 11962, 147224, 47018, 29977, 27979, 5552,\n\t82338, 86023, 131368, 1218, 24853, 237840, 132193, 15455, 40873, 3668, 65351, 53388, 15229, 59889, 272245, 47934,\n\t11858, 34347, 18038, 90853, 86981, 300602, 19343, 114181, 29362, 84921, 6095, 106059, 79472, 38015, 1206, 48741,\n\t6208, 80000, 21916, 17423, 6002, 108083, 24479, 34931, 56661, 9511, 26995, 100694, 163853, 35997, 81254, 58321,\n\t18919, 171890, 86877, 91341, 74503, 70477, 53412, 7027, 59281, 39892, 131302, 5864, 15947, 61301, 67466, 162369,\n\t47956, 27874, 35624, 282324, 21270, 111847, 102548, 41482, 30955, 116737, 28264, 8592, 55458, 22301, 75090, 29821,\n\t30697, 51709, 3041, 19208, 8038, 24634, 30467, 87509, 126428, 19389, 18814, 152686, 20701, 83474, 45832, 80891,\n\t105808, 11378, 153223, 120770, 98186, 150633, 49838, 9141, 12755, 30962, 5260, 74490, 21256, 31678, 65062, 33326,\n\t289838, 187831, 20595, 89768, 2805, 58535, 10844, 70085, 12090, 2451, 138068, 98544, 24461, 4511, 6754, 41684,\n\t28203, 3383, 65355, 82833, 30161, 83924, 234361, 128424, 28921, 222594, 33975, 125491, 34069, 11508, 67464, 144226,\n\t41850, 98703, 34371, 7901, 21254, 38398, 65651, 23549, 53883, 213340, 123269, 12028, 71764, 177701, 28758, 2623,\n\t68395, 11549, 15232, 68603, 9660, 63116, 36079, 57093, 31198, 20475, 48467, 89984, 35619, 186847, 107469, 31389,\n\t43631, 73867, 41949, 68841, 114250, 1605, 30564, 63403, 17588, 27680, 99533, 12641, 70325, 50428, 73426, 78379,\n\t11855, 91651, 72081, 91720, 60198, 15743, 12065, 83398, 140046, 6761, 46598, 45900, 5068, 886, 62448, 148968,\n\t37347, 19405, 9680, 15819, 43496, 63370, 75667, 163700, 37639, 3633, 22774, 34341, 183131, 134335, 37200, 23915,\n\t7054, 14194, 12970, 26438, 13350, 285521, 25594, 8219, 104410, 91039, 168804, 138480, 149734, 15907, 33818, 61132,\n\t60082, 4622, 110187, 56736, 13551, 73571, 3945, 73463, 65498, 17758, 263266, 17593, 2710, 27585, 54469, 38200,\n\t45367, 63754, 28881, 3473, 12791, 98287, 31895, 65787, 4463, 94536, 24951, 36332, 59901, 28803, 52130, 86403,\n\t7668, 181822, 74831, 18977, 9850, 177206, 145485, 109798, 7292, 31421, 26280, 77211, 58511, 12507, 127004, 11113,\n\t147, 8729, 56208, 43066, 79926, 129937, 31345, 83947, 39915, 46146, 98763, 42566, 1337, 13192, 18323, 105163,\n\t80570, 117753, 16555, 72883, 11077, 159438, 40764, 70933, 83329, 26066, 12276, 72059, 21655, 173836, 126713, 69454,\n\t153482, 91585, 70644, 102558, 110483, 6764, 127864, 190133, 3961, 101798, 20945, 71138, 82402, 90884, 69669, 44753,\n\t923, 16939, 59700, 164258, 25969, 27082, 31399, 43846, 6306, 246093, 51342, 6153, 151581, 202801, 182731, 56475,\n\t162188, 89426, 141356, 14355, 121815, 27536, 28023, 65257, 77523, 106668, 127314, 24947, 12790, 38796, 169698, 23555,\n\t10725, 44573, 183083, 42088, 62716, 43265, 105958, 32050, 44067, 50118, 1668, 3874, 6243, 318411, 16599, 1691,\n\t94999, 52378, 28671, 216728, 123258, 2059, 34969, 69225, 5913, 136280, 171443, 141515, 91662, 22175, 135282, 80020,\n\t92270, 1663, 4808, 4482, 3495, 34691, 5226, 109830, 108512, 17342, 107488, 11606, 123190, 100247, 29666, 146527,\n\t113014, 15794, 30894, 13224, 39585, 243192, 22351, 9903, 7836, 47699, 11078, 25468, 122291, 48821, 26780, 122679,\n\t75521, 81450, 630, 4895, 92900, 55074, 74293, 17441, 3563, 111657, 103102, 51613, 12318, 52370, 36191, 68245,\n\t34269, 40445, 41354, 122901, 168604, 182500, 62012, 42557, 11259, 24428, 115113, 86345, 12362, 3909, 78430, 86852,\n\t134602, 20459, 47853, 93879, 22577, 7659, 3688, 38555, 13349, 17381, 56715, 91639, 12493, 10895, 92438, 3142,\n\t37057, 28928, 2004, 36427, 32268, 34222, 209974, 10432, 67436, 41989, 173518, 107930, 27079, 62729, 30908, 55558,\n\t5828, 45031, 14902, 53546, 8204, 144263, 60255, 14520, 88212, 86582, 109589, 69356, 8064, 47449, 8505, 66558,\n\t16886, 4844, 52817, 111260, 215129, 12941, 91118, 650, 20770, 6273, 73089, 40618, 62790, 2873, 35002, 14023,\n\t97208, 19386, 102646, 36993, 143736, 135457, 35385, 113601, 17893, 32627, 84439, 100619, 56016, 6581, 57264, 172160,\n\t45452, 111710, 203627, 70131, 24100, 322787, 1996, 35665, 70078, 22358, 90922, 83658, 4097, 63200, 58499, 14542,\n\t99153, 52159, 6615, 12414, 63415, 31986, 16823, 1579, 65405, 137809, 8841, 16898, 48082, 259, 33014, 42375,\n\t12260, 179850, 73667, 91389, 98882, 29532, 17311, 326251, 41092, 5928, 20742, 44964, 48019, 43505, 9317, 49265,\n\t6643, 192712, 48424, 163487, 19861, 20113, 70848, 31928, 105333, 23685, 78563, 14638, 54755, 7158, 24142, 44018,\n\t20774, 125255, 20331, 24280, 10163, 1285, 2336, 39851, 4299, 117269, 46714, 63816, 87779, 159624, 11731, 9971,\n\t990, 137317, 108831, 50994, 74554, 162680, 23640, 131597, 146962, 170620, 34829, 91205, 21184, 1913, 63616, 18427,\n\t93136, 156592, 17519, 67565, 115882, 138220, 78622, 88535, 18115, 2711, 33554, 109492, 54298, 971, 24914, 25863,\n\t36363, 45715, 27099, 194995, 14299, 178181, 111488, 72395, 322385, 157719, 130787, 11897, 81843, 83999, 11369, 49280,\n\t118604, 40922, 61332, 110343, 53407, 75639, 40582, 300440, 54722, 25637, 13694, 48248, 48278, 194521, 56203, 52779,\n\t48783, 72627, 10953, 376, 16733, 280238, 26351, 230789, 15132, 25168, 137270, 3588, 63704, 73376, 94031, 74284,\n\t19443, 159557, 9697, 39901, 13351, 119050, 15406, 146455, 3460, 29556, 75195, 37673, 102524, 92329, 47289, 98413,\n\t15311, 100684, 56345, 7116, 95480, 11590, 7200, 167, 23610, 58426, 17730, 136656, 27944, 53151, 2701, 8824,\n\t103124, 3017, 90744, 113588, 53216, 79736, 65940, 26931, 498, 29568, 80540, 143543, 21292, 1740, 59268, 16561,\n\t180816, 42323, 50174, 40890, 52866, 10703, 57169, 4700, 17191, 4424, 93511, 49698, 166650, 26972, 48631, 165169,\n\t82879, 69326, 202970, 4007, 2376, 231325, 139592, 22119, 62851, 37504, 68816, 58345, 67398, 186643, 43331, 277416,\n\t53749, 15746, 23102, 17432, 4793, 151138, 48822, 54265, 48203, 198688, 14305, 54287, 2291, 18018, 113378, 123260,\n\t7180, 97549, 87027, 120085, 2920, 76080, 8190, 102005, 5641, 64580, 14955, 59802, 54028, 58884, 19367, 81779,\n\t412567, 85957, 97053, 103637, 78871, 29364, 27637, 141728, 4767, 30686, 112738, 130146, 42745, 12730, 105040, 14844,\n\t232, 210944, 36581, 152317, 135543, 29744, 3129, 55647, 58149, 46319, 27265, 17499, 28005, 59948, 7170, 34138,\n\t5702, 293047, 110892, 408, 91760, 218674, 18469, 46095, 81403, 14389, 4610, 35672, 73060, 11006, 74848, 104820,\n\t118143, 190357, 20043, 105358, 141735, 5115, 27093, 45924, 123073, 52599, 29433, 9616, 238350, 78610, 24851, 58858,\n\t26769, 31969, 24613, 18294, 4982, 32735, 39639, 143563, 112073, 202205, 12567, 4873, 88601, 44897, 81503, 101648,\n\t81362, 34662, 85277, 17574, 48173, 21435, 221188, 40215, 39576, 80786, 26544, 64668, 81841, 10731, 37733, 247986,\n\t149188, 127703, 495, 18382, 54388, 72446, 43071, 30974, 198723, 89608, 41360, 190, 33045, 8386, 31658, 19992,\n\t237838, 119015, 137622, 50890, 100913, 6460, 116233, 267230, 26621, 104129, 65114, 14190, 41542, 14888, 85962, 23342,\n\t23041, 26453, 43725, 71809, 45186, 4770, 46452, 53894, 56616, 221286, 18973, 9038, 109299, 55365, 19366, 26863,\n\t18808, 60909, 69353, 41738, 83463, 12100, 68561, 72860, 3980, 13796, 49340, 12332, 31311, 27418, 4255, 53430,\n\t18976, 45523, 510, 14224, 30477, 26581, 4530, 3651, 101663, 139840, 22709, 150861, 31996, 63923, 120623, 262522,\n\t3076, 10528, 2929, 14672, 130238, 18087, 9816, 121894, 100308, 25085, 55111, 14565, 18952, 53293, 2042, 369988,\n\t23674, 61789, 133529, 28783, 108293, 35477, 47119, 36448, 71049, 40015, 33055, 78598, 198442, 1833, 159937, 40654,\n\t77444, 189245, 113153, 8621, 18599, 38553, 35223, 166072, 2375, 11659, 21786, 89523, 6032, 12116, 63046, 159398,\n\t18454, 3678, 32521, 47626, 11411, 103527, 38896, 42946, 15696, 26370, 10185, 8413, 37080, 165583, 4331, 63555,\n\t14907, 72220, 50056, 6623, 62236, 36565, 49783, 10049, 17503, 100581, 55951, 146244, 24724, 9626, 17969, 25524,\n\t109300, 173965, 99994, 101056, 46459, 43647, 53737, 277968, 8347, 123521, 74858, 33829, 44762, 77574, 877, 81377,\n\t222525, 123532, 30602, 43881, 53145, 2973, 16284, 81940, 61281, 127044, 63620, 9875, 14756, 114829, 19032, 9202,\n\t52759, 119141, 23928, 120551, 19607, 3599, 33401, 76821, 73233, 117430, 39968, 36539, 7071, 5446, 121735, 194059,\n\t15206, 45283, 6706, 15603, 65615, 1207, 165723, 92275, 34773, 104447, 8396, 32353, 205240, 164323, 13600, 60555,\n\t79205, 25532, 22907, 33410, 57480, 107111, 69630, 32137, 47832, 70913, 33161, 20321, 2371, 117348, 10714, 86246,\n\t1625, 11763, 17900, 268, 78457, 99175, 97940, 101092, 86660, 32221, 14041, 128504, 125080, 53744, 124263, 31017,\n\t13897, 403, 31859, 21964, 5633, 111630, 5547, 77329, 17961, 18241, 84995, 25984, 12983, 67491, 62168, 47262,\n\t5241, 297, 51191, 7351, 8967, 147212, 82060, 16821, 782, 11033, 82431, 62957, 5026, 43459, 77963, 203477,\n\t53528, 6247, 191852, 87774, 74164, 215654, 13467, 1522, 219964, 28589, 244104, 16242, 117821, 67725, 72570, 156792,\n\t17186, 15979, 26990, 44128, 193014, 35276, 57125, 16212, 166451, 68017, 6905, 77608, 16364, 53777, 75921, 76426,\n\t37975, 26203, 269296, 64099, 84122, 12077, 38533, 830, 4407, 20139, 963, 43028, 38902, 42911, 37503, 83343,\n\t85045, 16979, 1165, 60835, 137387, 58380, 86990, 110066, 134540, 56331, 193845, 81238, 17922, 163093, 38744, 110641,\n\t12502, 56404, 34862, 26865, 125964, 12965, 111648, 25547, 7771, 27196, 136980, 9555, 29551, 107158, 57885, 18831,\n\t37705, 35505, 101742, 13970, 102109, 62548, 124657, 23328, 11124, 89592, 146376, 248050, 6241, 22033, 18337, 80685,\n\t29898, 11908, 216623, 67721, 106162, 146610, 21377, 15085, 91552, 42041, 62560, 122532, 125336, 102365, 121537, 142559,\n\t29693, 223919, 11515, 110495, 18776, 22494, 5895, 185059, 103592, 229351, 51220, 100102, 37027, 257855, 29359, 54123,\n\t36066, 106493, 12244, 79258, 32002, 432, 56205, 94836, 90182, 6726, 14762, 29391, 48938, 26864, 38083, 60364,\n\t3310, 60192, 14766, 205567, 57504, 110760, 22649, 24666, 46333, 21517, 3430, 13135, 28873, 27052, 158809, 11597,\n\t20529, 6695, 23138, 22960, 37137, 45574, 6545, 305877, 43423, 26153, 24769, 59844, 14501, 10430, 134352, 56169,\n\t13213, 103432, 49523, 35181, 13435, 12408, 129475, 64620, 230854, 77390, 51990, 15653, 83248, 33466, 44571, 117828,\n\t51481, 2187, 10559, 68019, 18021, 54895, 48247, 18354, 33737, 4554, 108595, 37288, 39767, 116707, 9175, 3726,\n\t108877, 21616, 83684, 49862, 1938, 8543, 276466, 20134, 108498, 48770, 102254, 31914, 131520, 185291, 100559, 51890,\n\t209, 19526, 76471, 50544, 71814, 99351, 8172, 198526, 28816, 20419, 9109, 98389, 136777, 76479, 75596, 30635,\n\t165417, 48216, 120220, 25955, 211071, 39314, 24308, 32164, 2559, 146280, 43403, 9233, 17947, 90585, 1786, 86920,\n\t125662, 2457, 64741, 32152, 32918, 122882, 78538, 44001, 31723, 56426, 23375, 103172, 88177, 145697, 52506, 49319,\n\t68016, 31664, 41488, 18486, 110400, 7030, 28241, 986, 109199, 19900, 42147, 56864, 65287, 49183, 7858, 24000,\n\t30453, 840, 16673, 25907, 68916, 89927, 6309, 158335, 36407, 199737, 130464, 13137, 59603, 201778, 195292, 21015,\n\t42466, 179062, 172561, 89492, 11075, 180407, 31868, 72493, 20998, 60217, 9865, 19530, 39274, 130266, 54539, 21623,\n\t12535, 13505, 40641, 73375, 4087, 85633, 2153, 3117, 70680, 55788, 92096, 47509, 98493, 37490, 271936, 151475,\n\t3032, 16171, 96642, 34106, 78425, 125761, 19591, 3366, 19316, 54508, 24183, 50786, 194248, 91528, 33253, 34622,\n\t108355, 41741, 705, 3814, 3883, 108929, 13203, 67831, 10142, 59754, 68208, 29128, 84820, 56880, 38794, 24972,\n\t48571, 40821, 40476, 18137, 164254, 24064, 236309, 79181, 11282, 395, 39169, 2013, 51587, 28551, 9645, 701,\n\t109513, 115899, 113566, 12762, 62045, 58322, 103726, 41343, 40866, 244102, 143816, 2490, 70346, 40973, 52618, 15412,\n\t30720, 104315, 38917, 42027, 93676, 17513, 107418, 20706, 123890, 13399, 97727, 24044, 87962, 65606, 44250, 98044,\n\t65276, 74790, 101473, 19350, 91570, 1326, 87790, 172042, 7577, 100813, 86896, 85891, 41512, 108130, 27794, 14875,\n\t71431, 12835, 156250, 58135, 3759, 22476, 42176, 115873, 34686, 56523, 73643, 108505, 51491, 20838, 12721, 32863,\n\t45700, 29496, 13700, 34294, 55360, 29206, 155942, 123812, 7706, 163234, 203, 132720, 49358, 144431, 8130, 175788,\n\t35818, 3270, 76832, 25710, 54095, 97274, 28779, 94621, 74396, 19092, 128242, 58067, 20885, 14670, 93255, 15107,\n\t63291, 23654, 126900, 129421, 59294, 262659, 9798, 3251, 67344, 28600, 44629, 50672, 29072, 26999, 31526, 23183,\n\t49175, 165843, 175455, 17282, 175411, 32022, 45989, 30298, 90690, 78118, 83156, 23749, 35636, 31317, 7069, 80381,\n\t94561, 133756, 14960, 97404, 6138, 41065, 78041, 32843, 16601, 34123, 9559, 146529, 123377, 96395, 54441, 42012,\n\t84257, 123541, 10745, 22139, 106459, 11720, 150883, 172651, 154996, 110538, 4728, 53447, 25704, 2009, 71152, 119354,\n\t21166, 66604, 1429, 216162, 8637, 122250, 63520, 27180, 29172, 36124, 276428, 107787, 77184, 4680, 14952, 104903,\n\t24418, 14793, 51561, 52931, 8371, 26342, 48526, 7118, 92066, 67280, 40653, 8847, 34597, 105438, 14198, 50163,\n\t61188, 146286, 50315, 41205, 170829, 161496, 585, 197359, 95056, 1687, 365794, 91349, 48507, 5804, 49263, 5146,\n\t104902, 96365, 117343, 132222, 46084, 96919, 16875, 8073, 262381, 79982, 52663, 13928, 16056, 153908, 15145, 109256,\n\t132308, 18763, 24904, 167644, 13618, 40750, 18686, 147124, 114709, 150038, 52849, 2938, 12568, 48617, 8778, 5459,\n\t44202, 44591, 74914, 17183, 248689, 13878, 7822, 80060, 23116, 194037, 18487, 2067, 7798, 43077, 33678, 244028,\n\t31320, 74273, 2794, 19466, 8218, 36280, 183997, 48124, 19416, 29656, 19280, 98734, 7715, 18311, 30701, 133602,\n\t150307, 126956, 7378, 2933, 79903, 13178, 12593, 86571, 26604, 92446, 13574, 44205, 65699, 427599, 21118, 8245,\n\t14407, 27877, 47936, 33542, 7916, 26460, 117762, 21596, 37818, 2249, 127359, 209394, 60044, 47677, 308089, 36791,\n\t154971, 31417, 6998, 150042, 174360, 12255, 43009, 29335, 48739, 3912, 101398, 53340, 2580, 146939, 151295, 45360,\n\t125275, 15273, 45383, 27456, 48761, 23314, 8750, 60801, 85823, 104759, 27894, 123685, 66968, 39480, 26917, 55290,\n\t83305, 2696, 98390, 57569, 145853, 340733, 4919, 20024, 52268, 30884, 7413, 203685, 70989, 112855, 4129, 50536,\n\t349518, 68205, 332641, 159581, 135361, 236026, 37563, 176404, 64899, 6578, 122033, 63871, 1850, 85234, 82089, 66124,\n\t74145, 121098, 107351, 12687, 36881, 117334, 13136, 14698, 85933, 93866, 18047, 32620, 310, 15094, 46000, 88451,\n\t23632, 36645, 27940, 87618, 80520, 58892, 20976, 27702, 140090, 96075, 67841, 103292, 238964, 87778, 107338, 17019,\n\t83427, 67522, 7302, 8261, 47570, 116787, 8730, 80484, 61772, 174422, 56005, 131193, 52875, 14588, 28471, 59817,\n\t9586, 15720, 158155, 51307, 109734, 15196, 11025, 59331, 3884, 52626, 102602, 84797, 25158, 27314, 4437, 20488,\n\t76214, 189248, 35023, 114952, 157376, 2827, 62439, 102878, 129749, 36405, 10329, 109339, 108633, 36662, 1254, 13267,\n\t5470, 87105, 58004, 15397, 10434, 159667, 21864, 52022, 179464, 3013, 32147, 31496, 116832, 18494, 105502, 129227,\n\t107267, 50033, 13481, 9954, 24267, 22141, 16257, 116154, 36185, 950, 115685, 11305, 176708, 2048, 178671, 112573,\n\t287867, 162328, 497663, 95170, 50979, 193861, 50987, 30368, 136257, 31830, 46549, 15119, 169876, 23788, 17462, 249887,\n\t57377, 1949, 35448, 14791, 43769, 210091, 3783, 34612, 282103, 88380, 245190, 5457, 20491, 98908, 11402, 86899,\n\t117916, 16028, 162584, 60644, 320177, 156096, 31065, 55876, 22000, 77655, 9992, 23397, 13757, 317623, 63978, 215255,\n\t2443, 17648, 93231, 27388, 104529, 93807, 55505, 140477, 12046, 112040, 70887, 40152, 94365, 112353, 25063, 114679,\n\t266061, 71248, 119555, 15589, 2244, 617, 14129, 211431, 70110, 100652, 7777, 4383, 85911, 89221, 21010, 120615,\n\t58357, 86405, 37554, 41647, 18, 15143, 69662, 60491, 14714, 186134, 148344, 42347, 5410, 168175, 44535, 42449,\n\t343894, 129417, 99682, 20659, 27272, 140483, 63455, 222159, 17536, 13722, 42637, 62324, 11976, 114691, 148109, 2283,\n\t32057, 182393, 4295, 147364, 33705, 2075, 44303, 30274, 28331, 63740, 69740, 29148, 10346, 44862, 33716, 73937,\n\t153333, 12930, 38784, 247159, 2515, 41053, 20256, 83368, 256189, 54639, 115240, 5096, 24661, 175419, 153552, 26516,\n\t141, 138176, 63885, 34115, 47222, 55709, 2765, 28479, 38875, 236608, 12229, 22921, 77291, 54426, 45388, 2860,\n\t57787, 114579, 295139, 105782, 17826, 71066, 19119, 54364, 69385, 16568, 12323, 28057, 33346, 34919, 124763, 155533,\n\t101386, 31644, 8627, 49001, 303600, 29868, 63213, 9103, 77280, 71333, 9696, 138789, 37059, 24823, 5057, 21352,\n\t32368, 114208, 56803, 19424, 10445, 58514, 8661, 209508, 26187, 171838, 10460, 63454, 14016, 122504, 41328, 21329,\n\t46618, 32493, 38225, 7855, 31763, 7945, 29876, 8734, 6438, 24205, 97490, 139977, 130740, 47323, 33195, 85390,\n\t57194, 13813, 60600, 21313, 96251, 7699, 27584, 170521, 139271, 1363, 4402, 336738, 129223, 84983, 69150, 13147,\n\t3590, 163929, 207225, 155260, 55916, 20288, 4503, 8398, 98490, 11773, 27512, 37113, 84976, 86558, 28365, 11756,\n\t116005, 182148, 13733, 115313, 47644, 67208, 85069, 9347, 14995, 226141, 14704, 101835, 41159, 35314, 13113, 63526,\n\t214039, 29978, 50446, 83339, 17440, 129441, 72522, 118641, 97816, 24907, 73844, 15717, 118884, 167255, 96509, 162793,\n\t30847, 36849, 51297, 78974, 77793, 10427, 1873, 2972, 9999, 35074, 28190, 64297, 146836, 46298, 60038, 163007,\n\t108919, 61219, 2403, 75022, 127339, 4233, 110389, 69022, 9833, 128097, 88016, 79390, 222936, 22570, 94657, 28462,\n\t56956, 38803, 81536, 30474, 152794, 19566, 16481, 147408, 74574, 81895, 20731, 1918, 1366, 76367, 187321, 54494,\n\t24366, 21690, 61696, 33283, 107477, 77499, 31112, 414383, 74362, 18463, 218441, 120929, 59848, 258629, 201924, 69269,\n\t454, 19989, 13054, 59894, 3623, 58908, 20681, 35723, 78523, 102680, 38988, 184112, 108087, 50944, 132704, 52966,\n\t21699, 18860, 96349, 201411, 82697, 85395, 95658, 5093, 6427, 177894, 44191, 32755, 26961, 155739, 6249, 31310,\n\t81030, 26574, 84311, 120155, 86730, 113535, 7424, 48888, 13516, 45747, 98098, 20077, 183995, 81945, 43210, 26704,\n\t40420, 75831, 45648, 11180, 6855, 57927, 65528, 124096, 34851, 2598, 156633, 107572, 127352, 38169, 123845, 60142,\n\t62722, 105584, 232364, 23211, 68120, 1601, 22169, 89299, 747, 258039, 80572, 7258, 152249, 11862, 101204, 8834,\n\t121434, 33761, 19175, 133142, 46343, 40178, 48723, 3589, 41977, 30210, 38868, 62257, 10087, 82658, 87827, 90646,\n\t16415, 47552, 351723, 28298, 72225, 91146, 272760, 1701, 11295, 1652, 109651, 300747, 51863, 198800, 29446, 11794,\n\t32345, 37538, 22356, 33102, 37590, 113544, 37970, 11478, 179743, 25454, 103417, 59905, 221970, 105196, 145604, 7817,\n\t164809, 102360, 16974, 75840, 255333, 56902, 6659, 1954, 645, 59400, 67769, 7689, 18675, 5215, 13793, 20536,\n\t27852, 3387, 29523, 259718, 16860, 94625, 43143, 29245, 15848, 233581, 22685, 63631, 78557, 22836, 133302, 84513,\n\t1348, 51826, 47129, 98836, 58284, 1830, 1749, 94642, 10933, 6145, 12506, 10975, 13879, 103781, 144434, 10268,\n\t28409, 32346, 52968, 121567, 107374, 77268, 23686, 35097, 10501, 155275, 15303, 47136, 21102, 168741, 55332, 90385,\n\t15996, 84817, 681, 137803, 25054, 142275, 6163, 38175, 8056, 124296, 240642, 65621, 4934, 178205, 16101, 62803,\n\t60964, 18230, 100622, 76465, 44689, 14545, 9543, 47514, 16852, 93380, 28048, 12047, 107106, 37575, 101485, 77047,\n\t57326, 34819, 96137, 76916, 6469, 46264, 115983, 75768, 87668, 69942, 13027, 165, 8373, 114231, 26434, 52844,\n\t42799, 182044, 23580, 146254, 38081, 43236, 33883, 146220, 382894, 14606, 46035, 36481, 166621, 35417, 95382, 2957,\n\t59384, 60428, 36358, 66343, 75378, 22267, 22950, 83528, 17577, 56474, 25285, 4619, 179691, 75355, 95836, 53295,\n\t34588, 171410, 4487, 14679, 84208, 44015, 18562, 109133, 54101, 11531, 86052, 174479, 303157, 28095, 9953, 35642,\n\t14564, 39802, 16145, 77606, 117406, 53038, 121117, 53624, 22062, 1212, 7632, 127157, 237292, 189087, 10478, 127345,\n\t102515, 181997, 86752, 87623, 10966, 121602, 68783, 68681, 83042, 114380, 138349, 191305, 67176, 50085, 39016, 1427,\n\t42384, 1412, 67118, 122616, 72389, 25260, 2237, 13576, 137346, 19938, 20304, 2191, 68759, 5373, 61364, 238507,\n\t75814, 23931, 69565, 38993, 131741, 38364, 12528, 87762, 5679, 129853, 5310, 186831, 32653, 90338, 260176, 389531,\n\t108118, 26843, 43985, 50175, 30563, 25106, 56965, 18130, 140428, 4542, 165503, 117991, 24219, 229605, 1819, 129663,\n\t1240, 3797, 76093, 18398, 71339, 51919, 93043, 27175, 47060, 216257, 6483, 35051, 1217, 16512, 80798, 129064,\n\t13225, 69339, 8548, 237079, 72298, 2575, 34280, 51379, 117910, 55671, 53345, 247552, 29486, 39328, 140821, 34681,\n\t57045, 60177, 5004, 90269, 78522, 2479, 322607, 48474, 61296, 13057, 31558, 4678, 59271, 6699, 27044, 31988,\n\t35944, 12503, 83480, 4389, 136508, 3781, 114121, 70279, 4488, 155829, 42214, 2898, 68191, 75695, 305850, 45041,\n\t74344, 106509, 30087, 17429, 93292, 12477, 290, 23080, 114802, 35714, 18751, 26554, 105424, 17775, 2144, 2412,\n\t100610, 65192, 113975, 52975, 180272, 135050, 129815, 76238, 106483, 21440, 63186, 4260, 46189, 9711, 28249, 4169,\n\t23429, 23390, 8324, 141585, 63809, 67668, 38457, 38063, 39226, 59972, 1189, 203916, 62368, 14403, 16949, 61767,\n\t85801, 1739, 40147, 35049, 76757, 33124, 62102, 15780, 103593, 103009, 53484, 22952, 67973, 114645, 6566, 5245,\n\t50462, 7601, 8288, 3513, 194571, 80276, 1908, 54592, 5124, 58571, 2513, 6800, 273997, 193904, 1119, 17991,\n\t117245, 2508, 129156, 82366, 26278, 71465, 63341, 56943, 39662, 106116, 94966, 156875, 9736, 2204, 122308, 94418,\n\t27134, 1280, 24539, 49022, 45314, 3764, 50904, 46424, 30699, 28087, 293839, 9400, 33646, 40165, 822, 147499,\n\t50263, 116179, 29085, 11863, 31314, 5578, 17797, 5104, 12454, 1604, 15342, 219206, 10232, 67800, 94261, 25872,\n\t13565, 90339, 78971, 75377, 26649, 41184, 47695, 11514, 35369, 20767, 14227, 41953, 309396, 148270, 147938, 33074,\n\t14453, 27499, 109019, 39018, 25738, 240196, 158931, 52820, 8612, 95853, 21524, 137010, 84901, 70869, 70021, 116794,\n\t48404, 38771, 6732, 1070, 70990, 187297, 49140, 5238, 576, 3564, 253975, 16027, 16483, 2811, 37775, 19034,\n\t25259, 4053, 2000, 70083, 95774, 19713, 33431, 92703, 91314, 42381, 288770, 48194, 95985, 3991, 77418, 13406,\n\t241328, 245086, 56533, 35275, 62725, 9246, 51924, 70181, 95331, 16163, 31410, 79016, 39312, 120878, 119371, 275987,\n\t80124, 27712, 9186, 220, 23598, 146167, 85209, 68238, 282190, 57048, 31273, 30555, 80913, 17594, 75779, 59160,\n\t135002, 101219, 189377, 29225, 96735, 60126, 62522, 104000, 27620, 86814, 17240, 147533, 11001, 5425, 43682, 410,\n\t49460, 87270, 69480, 46315, 59448, 1816, 76201, 9431, 11788, 87960, 29063, 65539, 47347, 11678, 33846, 7008,\n\t196704, 9895, 6753, 8633, 120892, 59970, 572824, 115934, 6646, 202559, 892, 48351, 37611, 251282, 57823, 67263,\n\t57750, 26527, 34485, 90747, 7685, 88370, 6144, 64182, 1709, 41969, 21458, 62327, 181657, 49247, 225330, 122600,\n\t114574, 107124, 85361, 111833, 63243, 71420, 15655, 191178, 72430, 18063, 51425, 54002, 12364, 53225, 86557, 18193,\n\t97580, 41232, 138398, 67821, 128724, 8944, 233212, 101353, 52099, 42127, 14006, 120107, 32789, 32132, 3498, 18123,\n\t33758, 56058, 5779, 128760, 59888, 98869, 18445, 84702, 51911, 13234, 218379, 20093, 39031, 8074, 70195, 20708,\n\t23462, 24355, 131384, 60189, 26390, 10403, 41060, 7140, 10781, 49410, 42261, 87202, 82566, 41663, 43105, 60276,\n\t2768, 5733, 74176, 28329, 2297, 145430, 131632, 83615, 122915, 105441, 655, 224102, 5284, 136426, 67763, 16294,\n\t188511, 32538, 61049, 27893, 3394, 13951, 159099, 28542, 17930, 145360, 9492, 190122, 32285, 78855, 26440, 13570,\n\t58648, 73908, 4239, 124561, 2444, 74172, 53131, 11468, 10794, 73566, 11623, 35343, 64710, 30481, 4163, 10328,\n\t38309, 29901, 10538, 154377, 76132, 92405, 24839, 11679, 3465, 13449, 11637, 7824, 2337, 57754, 1260, 14458,\n\t41118, 19878, 38661, 13416, 159180, 37074, 163164, 54137, 28627, 52134, 184900, 8520, 40385, 29546, 30502, 22386,\n\t66527, 107458, 6850, 24022, 47983, 30603, 35083, 8934, 304066, 39500, 9, 28261, 33026, 77251, 9374, 44833,\n\t116312, 34990, 29236, 63563, 125639, 135405, 165398, 159055, 55690, 88141, 69643, 236964, 31983, 25572, 20436, 36746,\n\t60896, 31850, 16179, 11828, 5888, 3043, 66368, 9750, 31167, 7915, 53111, 36430, 1333, 64344, 93659, 20061,\n\t60596, 180191, 51630, 6792, 30244, 43509, 101058, 22409, 420, 44210, 109783, 43223, 27030, 72477, 72831, 32679,\n\t29235, 7675, 47556, 12258, 39907, 149412, 84926, 118247, 24692, 71717, 105038, 86009, 45941, 41189, 89453, 29856,\n\t52543, 30627, 226798, 67303, 59230, 67415, 34408, 1367, 99685, 16867, 128419, 52147, 4111, 125381, 117881, 16173,\n\t44093, 102224, 31575, 23234, 24870, 83790, 127407, 239098, 3200, 994, 1255, 100903, 242275, 117266, 55116, 38205,\n\t16140, 29662, 11307, 40414, 208793, 123355, 56470, 4862, 75600, 30119, 58218, 70828, 24075, 26974, 7802, 192353,\n\t4851, 5475, 78720, 66596, 3409, 28573, 64396, 30381, 30690, 59859, 88256, 5406, 99945, 103064, 34463, 37727,\n\t24238, 86643, 60088, 4057, 23741, 5967, 162904, 38240, 28356, 93858, 25510, 122879, 6897, 3278, 7057, 11971,\n\t4400, 35461, 211413, 21395, 59615, 39471, 87233, 55795, 128426, 3051, 22470, 41950, 14705, 3974, 180108, 80476,\n\t78442, 204996, 91987, 15634, 67610, 139015, 142373, 35611, 51134, 10387, 4353, 153456, 57749, 181039, 14183, 68447,\n\t151532, 21107, 36452, 20551, 3186, 46247, 46383, 129666, 88736, 140662, 146243, 2066, 8360, 7978, 64818, 106963,\n\t17896, 47801, 10723, 114821, 223295, 74192, 3293, 3393, 16987, 74064, 11277, 91622, 4270, 29828, 27951, 387869,\n\t103235, 1374, 61988, 120083, 477, 145892, 128378, 11779, 211263, 61354, 18221, 17869, 46530, 83061, 108538, 157981,\n\t90608, 67199, 95080, 49064, 195814, 12302, 66307, 10348, 231346, 160732, 112859, 63633, 146558, 21271, 31037, 198802,\n\t47622, 12862, 95710, 3910, 77850, 73961, 85585, 34752, 61000, 4082, 24595, 103679, 71107, 8208, 79568, 150019,\n\t16615, 24961, 139857, 32664, 197366, 4559, 54735, 32696, 4126, 162019, 75698, 13916, 70108, 159638, 19834, 9349,\n\t24675, 175560, 49643, 18206, 52459, 27992, 10809, 88865, 401975, 133172, 29000, 34558, 30915, 3658, 25834, 42430,\n\t36562, 125265, 18182, 10155, 40149, 97082, 208980, 19575, 60853, 90529, 66545, 9600, 789, 46420, 2317, 88593,\n\t55595, 98980, 115302, 5742, 169155, 1073, 177901, 3472, 11189, 63711, 78643, 65472, 50459, 127979, 93, 42202,\n\t67053, 21720, 157650, 11145, 141378, 42033, 22824, 85705, 79114, 35584, 15974, 1510, 54172, 28562, 12451, 104226,\n\t19190, 97151, 73024, 20948, 5151, 81741, 21499, 29006, 84183, 198074, 54003, 45120, 170125, 26240, 35177, 28389,\n\t64863, 79974, 60778, 176915, 232183, 45342, 2038, 80253, 41564, 40703, 32689, 5430, 100689, 5366, 23007, 134279,\n\t14266, 26712, 73993, 24934, 64242, 52113, 102887, 61801, 46415, 201049, 54251, 62133, 122757, 164883, 30815, 139966,\n\t2319, 30842, 766, 13362, 10287, 134518, 86111, 81665, 82440, 28333, 43019, 18963, 8804, 161944, 23439, 102144,\n\t101145, 80029, 39052, 248708, 30350, 117340, 11878, 128467, 974, 138625, 63961, 5237, 74778, 61834, 67040, 43814,\n\t13690, 65947, 33809, 232476, 115258, 181745, 28824, 94013, 9510, 10246, 93722, 81976, 7217, 114383, 3493, 16014,\n\t69045, 72692, 12145, 80981, 9507, 6692, 1620, 60820, 330444, 35474, 33962, 4797, 7053, 295463, 46445, 27026,\n\t12491, 77988, 49524, 35675, 90947, 29114, 166705, 101385, 133782, 32704, 6186, 84595, 176031, 185623, 45966, 151302,\n\t63069, 1699, 107491, 947, 15458, 74452, 196212, 6046, 10498, 12163, 10239, 35191, 243951, 9277, 9090, 29539,\n\t54460, 22820, 26514, 112549, 60372, 51753, 48756, 21812, 70861, 260326, 41, 44222, 10441, 16961, 48148, 138771,\n\t216194, 5914, 52153, 53400, 212036, 56519, 26245, 10117, 45888, 15294, 138019, 90913, 26368, 43842, 42111, 23348,\n\t6082, 194845, 161089, 156206, 51546, 11647, 30759, 302912, 262094, 8635, 78876, 26535, 35283, 54183, 31183, 85484,\n\t147873, 12989, 5197, 6356, 72894, 65347, 20150, 27370, 73787, 1493, 45918, 12366, 190217, 20724, 13858, 10981,\n\t67449, 81213, 7553, 14115, 72242, 271517, 11842, 48310, 88743, 143726, 22177, 3290, 243231, 58452, 62937, 12592,\n\t1654, 40066, 33477, 13751, 9921, 128442, 15868, 7106, 75236, 83773, 10775, 36938, 10482, 170465, 17368, 17469,\n\t161508, 32752, 98340, 800, 19824, 264456, 3901, 87319, 2867, 26782, 9630, 113102, 185815, 24197, 44584, 86366,\n\t40224, 3636, 140916, 31731, 267731, 9567, 53678, 72984, 29389, 27963, 17106, 50282, 284911, 60170, 8322, 12608,\n\t23374, 89652, 5268, 39044, 229766, 8869, 151350, 31436, 177342, 12269, 183212, 120418, 116270, 2843, 78888, 69192,\n\t7865, 184099, 1086, 129897, 18383, 70508, 20242, 18508, 229924, 124569, 35749, 50589, 55626, 9884, 83115, 40971,\n\t30671, 18135, 14452, 38861, 17844, 201826, 5549, 26413, 17189, 13561, 38539, 10679, 143331, 3314, 36785, 171194,\n\t49685, 187713, 67506, 4618, 104039, 17060, 195080, 50648, 33159, 19238, 67559, 134840, 28599, 157523, 17130, 38064,\n\t117398, 94355, 31918, 13575, 34538, 40326, 13997, 3494, 348283, 62481, 26862, 3603, 104426, 244363, 153709, 112487,\n\t304612, 199674, 41239, 35545, 54869, 293005, 28223, 26277, 26899, 4533, 18518, 15492, 38587, 80488, 70485, 160395,\n\t263, 60162, 11382, 222152, 4696, 250751, 51921, 182609, 10707, 48463, 46243, 1227, 49111, 111564, 46502, 33342,\n\t56846, 68541, 63559, 858, 139927, 16654, 229375, 76759, 26478, 33205, 95828, 23399, 92945, 2637, 35630, 28470,\n\t143992, 50214, 14174, 21456, 166191, 65665, 1711, 21594, 78019, 97599, 111701, 36, 147151, 110246, 189022, 43021,\n\t30397, 40757, 131935, 42065, 73335, 48039, 26596, 28984, 15102, 2361, 7421, 202167, 69744, 43766, 52826, 3642,\n\t83304, 33873, 75140, 63169, 192389, 36551, 92748, 13039, 123959, 233220, 21738, 84447, 77230, 20228, 187852, 19095,\n\t25799, 92136, 108774, 29237, 53947, 2299, 118106, 2687, 8830, 42331, 202924, 33667, 2023, 73763, 30704, 19363,\n\t19779, 16737, 35629, 48081, 24068, 101013, 162338, 291912, 13749, 24745, 328289, 167679, 70086, 48299, 23306, 16732,\n\t17801, 43322, 54589, 3586, 63653, 43624, 53474, 925, 109177, 251316, 43805, 13082, 19511, 86565, 142182, 92461,\n\t17117, 101033, 103319, 64589, 4022, 4351, 235897, 5352, 82705, 107142, 46391, 156084, 5860, 61365, 10558, 13045,\n\t7717, 18357, 33922, 12590, 33065, 6928, 46993, 783, 46937, 67846, 8952, 26295, 6107, 119656, 18799, 17458,\n\t50747, 4229, 179559, 112727, 118080, 20683, 41464, 125468, 51560, 49749, 44231, 7359, 35339, 62988, 136487, 67015,\n\t5208, 29150, 24956, 105186, 48858, 6143, 18097, 6972, 16404, 73489, 58742, 97196, 36357, 164616, 5834, 32267,\n\t13746, 147733, 15113, 132091, 34127, 106298, 39729, 106426, 22294, 9780, 15602, 36213, 71502, 42808, 66802, 599,\n\t60755, 5851, 39120, 67363, 108623, 126368, 72770, 91263, 32486, 30596, 151717, 7951, 52002, 43103, 11768, 68942,\n\t40901, 39344, 24037, 127500, 116890, 48403, 16926, 86750, 17745, 48648, 159545, 34460, 58419, 5634, 114317, 67865,\n\t31462, 23352, 24010, 98185, 125708, 69686, 68337, 13610, 26271, 70691, 2980, 4768, 27225, 102402, 75453, 28106,\n\t8104, 6931, 1176, 6274, 6475, 112635, 22498, 6176, 238686, 26832, 28893, 90319, 14441, 15682, 15087, 39517,\n\t45270, 109134, 104440, 45965, 47645, 81772, 7876, 52683, 87720, 12898, 4505, 185665, 2769, 113401, 15664, 57592,\n\t105229, 137381, 97059, 119268, 6876, 43309, 33886, 128363, 35476, 144249, 67013, 143587, 83367, 25703, 91436, 59347,\n\t53236, 2289, 16519, 19844, 46309, 58558, 99834, 23313, 218816, 231303, 36388, 51333, 183535, 109792, 139277, 54306,\n\t90139, 18235, 8275, 32710, 37677, 82464, 86025, 92204, 88842, 117723, 37570, 128723, 234242, 76350, 73795, 34896,\n\t148247, 58424, 11105, 11744, 45746, 63372, 17118, 49772, 199520, 81902, 38004, 22911, 33752, 3125, 1995, 53792,\n\t4689, 26909, 108150, 146062, 69674, 41811, 161444, 84855, 8999, 28561, 16731, 93937, 3189, 21967, 24890, 22943,\n\t1356, 145300, 51569, 28802, 517, 118679, 31703, 40607, 48098, 108854, 25003, 10233, 73969, 177495, 5248, 24516,\n\t215347, 146192, 48712, 60626, 69188, 40735, 5866, 586, 101541, 6509, 47590, 52129, 5969, 222045, 110933, 25733,\n\t24223, 65339, 62812, 2414, 155418, 35819, 16022, 78423, 43138, 20995, 128255, 240673, 46745, 236093, 72176, 57085,\n\t97841, 61248, 107, 36068, 193177, 105427, 55726, 215229, 20446, 47228, 100420, 87091, 14429, 121708, 23605, 21157,\n\t187721, 21880, 2997, 203976, 99166, 95068, 25877, 7724, 98925, 83401, 4829, 13182, 18229, 13718, 239662, 38653,\n\t116505, 153497, 30589, 89029, 38962, 181302, 43853, 78872, 180301, 4786, 248240, 7401, 106136, 112590, 77745, 19731,\n\t60880, 77789, 125748, 135487, 5975, 48627, 34084, 12419, 215770, 47557, 254582, 10364, 106495, 21856, 67539, 88981,\n\t38805, 21428, 48732, 42316, 12149, 16078, 52808, 25327, 51322, 33850, 51147, 12253, 122354, 46077, 56483, 254553,\n\t115417, 81834, 150991, 94662, 86668, 7381, 12841, 100650, 18218, 15741, 22372, 68294, 50705, 15535, 84660, 61887,\n\t22553, 72299, 31361, 24824, 17743, 46820, 64288, 31582, 77006, 111674, 116384, 30760, 80920, 86149, 77192, 51979,\n\t79691, 60342, 122805, 103800, 240873, 160744, 233114, 78962, 54920, 8608, 3484, 316104, 72548, 24337, 5088, 230040,\n\t21926, 10172, 36838, 26, 86221, 83458, 102176, 12062, 17571, 41929, 41170, 28428, 68239, 41750, 103930, 2634,\n\t18313, 53019, 34825, 97837, 63115, 24606, 73157, 152474, 14715, 91439, 37033, 109806, 140259, 30668, 174760, 380,\n\t135597, 95673, 136073, 65073, 134249, 13829, 17279, 122305, 4420, 46444, 10237, 64848, 203623, 70728, 10349, 182885,\n\t65075, 24519, 25783, 40318, 34139, 22222, 63394, 55266, 102764, 41422, 20126, 65100, 90408, 53640, 35128, 48932,\n\t11192, 38935, 96839, 34782, 39492, 19396, 41332, 6250, 5511, 19492, 51304, 25936, 104466, 54099, 73771, 86115,\n\t5080, 7669, 30891, 111700, 13931, 25276, 72289, 135447, 14820, 258641, 25265, 31005, 281179, 75286, 393, 95359,\n\t14623, 13584, 6680, 101227, 80173, 44933, 76666, 54542, 13244, 39348, 458, 25379, 109451, 134348, 81143, 6959,\n\t65554, 12027, 51311, 8716, 57589, 140731, 28467, 23316, 17272, 30458, 25980, 55229, 77197, 83798, 28302, 114784,\n\t7428, 34548, 26241, 14712, 39336, 103304, 18928, 54080, 12870, 334, 87722, 15208, 16895, 142098, 114262, 39820,\n\t83913, 57817, 28682, 7721, 14900, 108672, 11250, 62246, 42849, 415188, 1724, 26555, 24549, 25505, 26443, 107450,\n\t145899, 61035, 43528, 6901, 60726, 65906, 267741, 21338, 147590, 42079, 18924, 73017, 135236, 15393, 5206, 4026,\n\t84185, 1531, 5988, 113890, 82647, 303391, 7386, 69844, 71611, 189865, 76523, 31877, 13315, 19314, 198575, 32821,\n\t1928, 67641, 25913, 104475, 103489, 3297, 70391, 18406, 15446, 113347, 19295, 93790, 27856, 1792, 167471, 116449,\n\t8541, 4408, 41757, 63233, 25765, 86680, 64501, 27034, 24816, 34975, 6079, 4486, 49693, 36229, 16917, 21581,\n\t62426, 27862, 11612, 54284, 35702, 194034, 355, 24277, 48262, 87411, 70504, 310164, 118018, 12516, 47559, 43502,\n\t57433, 107139, 9290, 66533, 80863, 14634, 34312, 91725, 28606, 21342, 67241, 72355, 43244, 375789, 37402, 174015,\n\t105070, 8342, 44167, 67494, 1890, 16365, 11723, 271002, 1865, 47918, 8350, 45564, 27742, 25110, 125803, 8553,\n\t49504, 81925, 62211, 4534, 15491, 19011, 80373, 206920, 667, 102405, 128623, 245524, 5553, 113309, 192739, 65766,\n\t19567, 22832, 261958, 29679, 21293, 71134, 20962, 105123, 24721, 860, 21752, 33448, 18372, 157167, 94822, 35770,\n\t173224, 232737, 75729, 28937, 46828, 28062, 25453, 5207, 140366, 36665, 30652, 6169, 67920, 150458, 92040, 23186,\n\t184604, 92330, 20891, 176492, 49427, 27828, 38305, 42495, 143982, 49560, 25503, 90043, 29747, 65328, 47830, 12932,\n\t11068, 77721, 9003, 25213, 94205, 140426, 46090, 89945, 138173, 192691, 33329, 112232, 129905, 35709, 27514, 1841,\n\t19957, 31411, 127476, 53572, 17497, 173549, 55063, 175135, 19841, 69314, 5192, 237921, 117660, 150697, 4060, 273045,\n\t50414, 98940, 65348, 153665, 164423, 58804, 156695, 48994, 213928, 86036, 28608, 8355, 39574, 34540, 16927, 135680,\n\t18374, 151587, 10830, 53805, 16878, 16623, 4282, 48030, 8537, 14986, 46102, 13062, 72897, 72, 33050, 108227,\n\t39451, 45935, 651, 113320, 40535, 95176, 57450, 48843, 5003, 19019, 10407, 211163, 3848, 1068, 4988, 32091,\n\t30095, 41692, 15099, 43602, 107434, 50744, 7627, 171349, 16313, 150832, 352665, 207750, 33937, 38256, 51091, 156000,\n\t87889, 90663, 84175, 24908, 114900, 50365, 31494, 83829, 5398, 169342, 47521, 54818, 18935, 8356, 43094, 41212,\n\t174536, 10082, 92550, 6678, 60614, 23355, 69721, 14796, 34149, 128830, 58187, 3179, 208, 40325, 28399, 225029,\n\t401412, 51150, 31580, 207268, 6657, 10993, 69818, 64282, 289845, 23308, 12961, 38447, 6681, 52944, 31855, 2572,\n\t47646, 120728, 179148, 37240, 45196, 218274, 4816, 3695, 21961, 50084, 35209, 18073, 51452, 27004, 6100, 33941,\n\t1377, 84831, 171214, 85, 141510, 9078, 99227, 32610, 6417, 11718, 49868, 65579, 87902, 73018, 49062, 46280,\n\t61742, 21512, 40862, 107733, 15941, 29168, 157765, 144919, 14487, 5767, 158014, 140070, 7241, 573, 71584, 16921,\n\t223566, 40331, 179473, 35081, 47926, 140885, 41508, 52104, 59180, 42310, 32811, 29048, 123517, 102413, 80208, 10104,\n\t14746, 12649, 153641, 126022, 37965, 113017, 4171, 83, 142592, 2809, 6362, 50416, 71323, 116894, 260776, 16204,\n\t1524, 5760, 30351, 12658, 20703, 54403, 36083, 45408, 74772, 4946, 14485, 50759, 111222, 10890, 2195, 167147,\n\t92962, 130534, 16283, 177256, 35016, 15472, 210156, 151187, 73922, 117691, 43250, 52051, 37392, 24811, 24358, 30830,\n\t5775, 818, 21969, 1476, 127322, 151783, 58392, 31021, 106913, 65215, 89407, 90802, 28531, 11690, 20234, 95249,\n\t44602, 37256, 18707, 11928, 5161, 4410, 26571, 51903, 49768, 22008, 25252, 65780, 209499, 68769, 203726, 13249,\n\t137363, 48845, 86823, 6658, 5674, 31881, 1083, 1823, 108676, 34518, 166752, 13791, 14287, 91576, 91429, 8665,\n\t11529, 26401, 16191, 91972, 30964, 5254, 28486, 54697, 79613, 66520, 18447, 22870, 45203, 194466, 22822, 51703,\n\t12278, 76716, 44595, 73455, 33546, 12235, 144843, 36154, 51247, 11116, 33040, 3180, 225753, 60864, 1972, 28469,\n\t12891, 28879, 10338, 144157, 56294, 353058, 38302, 41447, 87532, 110616, 27065, 168438, 6557, 1213, 50804, 144643,\n\t24817, 2390, 136531, 38174, 247513, 16190, 4059, 122791, 131994, 137430, 39506, 57650, 16305, 5188, 54309, 106128,\n\t20628, 88071, 67394, 395446, 250285, 66176, 91254, 1399, 114196, 43915, 60230, 44853, 27206, 106353, 43013, 18733,\n\t345105, 226453, 51202, 16607, 57106, 117175, 35492, 10476, 89598, 127439, 15187, 39624, 13688, 61570, 10615, 31111,\n\t59370, 6238, 175252, 32143, 224492, 41388, 95408, 34384, 148238, 78307, 38959, 9340, 160091, 61443, 15737, 11216,\n\t41244, 170, 38299, 102443, 113097, 26382, 14027, 33707, 3957, 76300, 66160, 19431, 18900, 6952, 1717, 108656,\n\t82206, 188021, 257335, 27295, 43999, 41210, 31777, 46956, 57457, 12657, 11489, 15697, 48060, 204748, 53583, 82422,\n\t284790, 30503, 137341, 8120, 19615, 220311, 15991, 10217, 63424, 9808, 67431, 70976, 98221, 4491, 15177, 28535,\n\t144789, 751, 13230, 2394, 1504, 33977, 132104, 30316, 22230, 931, 97193, 185240, 24826, 22687, 174322, 15307,\n\t22988, 1390, 188745, 180325, 29580, 59068, 74903, 18994, 29195, 79, 15436, 7622, 38462, 11566, 138710, 44828,\n\t45774, 37768, 99236, 68137, 84083, 19282, 22698, 17134, 74807, 126662, 173497, 46248, 16938, 119735, 3212, 28292,\n\t213652, 49013, 9975, 32180, 45660, 86250, 4801, 68788, 95490, 77482, 113751, 11994, 44624, 94452, 46839, 128497,\n\t100316, 5798, 58588, 73184, 202987, 65417, 37790, 88524, 1606, 43156, 97964, 105717, 34947, 11203, 100060, 37742,\n\t130074, 93653, 107799, 94311, 196106, 41347, 8035, 10780, 16390, 27883, 118236, 167395, 1979, 25006, 19375, 31628,\n\t18916, 144723, 78502, 114047, 103107, 86492, 107686, 5844, 20934, 206963, 23556, 22591, 16562, 146333, 20167, 10471,\n\t117434, 33085, 2863, 9740, 36669, 41849, 37271, 22790, 18209, 28979, 8231, 12952, 54408, 21731, 25130, 45208,\n\t55748, 138120, 75826, 414, 29593, 9925, 292865, 25999, 683, 123149, 7036, 92159, 86055, 61827, 103680, 23176,\n\t54918, 58466, 57578, 13305, 5709, 86479, 16697, 31064, 17660, 200919, 10770, 49793, 33423, 32370, 52047, 16488,\n\t62555, 6459, 8426, 83493, 7763, 59725, 82812, 18628, 67760, 79405, 68557, 9612, 7673, 28102, 56517, 69620,\n\t171797, 32458, 29541, 15870, 81109, 32080, 207644, 71495, 21202, 11039, 91036, 61230, 2810, 130800, 32260, 4613,\n\t60590, 37112, 75214, 33979, 126402, 155062, 30642, 63875, 12810, 194463, 82799, 47664, 16725, 36685, 43367, 61099,\n\t449, 172150, 102867, 21691, 301838, 36745, 7130, 18671, 57316, 34852, 38034, 54182, 35578, 65900, 99486, 19771,\n\t3456, 2658, 16914, 99866, 28390, 28109, 8262, 21147, 34353, 20006, 4228, 137085, 1675, 203023, 283196, 198286,\n\t214375, 163329, 290603, 152574, 40471, 83506, 30068, 14730, 23177, 131539, 34759, 27668, 32178, 71896, 104799, 116305,\n\t85430, 119262, 42860, 25160, 8911, 23428, 49437, 105322, 6519, 16203, 6349, 74711, 1230, 38045, 8540, 75165,\n\t44736, 25909, 51026, 317034, 4984, 32281, 91312, 27060, 44431, 17817, 45363, 155937, 239085, 35697, 59784, 91993,\n\t29531, 126740, 213757, 76560, 167776, 285273, 24262, 8237, 65030, 41160, 74437, 48804, 118916, 13159, 37842, 1031,\n\t75349, 1478, 11655, 108777, 23435, 277425, 101734, 67469, 70231, 124711, 43532, 28514, 65526, 54956, 1000, 21882,\n\t17728, 25302, 40952, 52214, 149632, 1999, 2111, 3259, 63362, 89961, 220561, 39777, 26335, 9063, 10572, 12416,\n\t34551, 34623, 38604, 24723, 5947, 15588, 69927, 66252, 119177, 69173, 46629, 28714, 70715, 212408, 20521, 406913,\n\t74380, 11716, 50659, 50862, 37009, 88460, 130101, 7210, 53853, 538, 65120, 151950, 55806, 163748, 52837, 13153,\n\t21100, 16674, 64536, 6091, 138201, 44837, 58547, 3723, 163, 2177, 32288, 85454, 34033, 8497, 14282, 25742,\n\t10535, 10741, 79559, 117493, 243787, 49337, 100718, 79495, 40139, 42956, 7551, 55433, 15421, 31509, 23034, 45081,\n\t547, 61176, 53434, 328001, 8470, 36263, 30145, 4519, 74173, 53935, 11845, 73774, 60211, 78025, 3, 4102,\n\t73782, 109293, 315332, 48412, 26683, 13714, 6865, 20128, 18490, 104141, 325, 39470, 171970, 115860, 15707, 7268,\n\t73301, 74336, 31370, 2368, 111827, 107757, 136231, 142844, 97138, 96638, 84053, 38691, 23801, 1588, 10573, 122098,\n\t77039, 240, 186135, 146101, 11996, 18143, 112963, 46171, 155836, 348769, 47795, 121213, 116266, 132515, 3344, 144804,\n\t31286, 99187, 255838, 129694, 35894, 48779, 55235, 148582, 71967, 65282, 15174, 13920, 47080, 6147, 108242, 157593,\n\t125025, 7136, 1286, 28957, 127956, 28402, 98813, 20805, 7532, 109417, 40610, 5041, 32958, 15142, 18408, 108596,\n\t33543, 50517, 27748, 80114, 233434, 91447, 487, 37094, 100048, 30541, 43477, 10639, 89862, 155868, 37667, 8726,\n\t60684, 237903, 73408, 99589, 12190, 38739, 97348, 3914, 13594, 2680, 149016, 13907, 30171, 28343, 23530, 115225,\n\t61104, 35821, 147679, 14337, 4297, 244282, 24085, 326976, 56428, 7851, 21303, 131620, 71446, 83253, 68692, 111870,\n\t5224, 15813, 38197, 49026, 45057, 13660, 3306, 76345, 40671, 27905, 91072, 996, 68527, 62085, 91351, 122634,\n\t55109, 168209, 2024, 27560, 112707, 17352, 8306, 167115, 169921, 166958, 5031, 46020, 11844, 67284, 19130, 76185,\n\t6920, 32849, 5450, 14610, 22451, 21002, 17392, 31872, 66682, 84796, 13709, 40210, 59898, 12029, 8719, 53564,\n\t21462, 91884, 21647, 88379, 194428, 12754, 37797, 132826, 160016, 22567, 54383, 53186, 77611, 31107, 8339, 4694,\n\t19185, 90355, 23597, 17222, 140675, 28442, 23668, 55977, 9128, 61555, 28774, 155229, 17658, 9390, 24379, 69357,\n\t15752, 127381, 239631, 62460, 93181, 55913, 45133, 140155, 18676, 25249, 33164, 29581, 82837, 67223, 22362, 29975,\n\t7317, 52813, 1943, 29613, 20012, 207130, 49617, 49651, 5636, 15334, 36313, 29226, 28084, 95247, 72072, 19000,\n\t224932, 15811, 114, 32127, 38097, 37508, 88507, 37225, 27359, 91626, 12193, 69279, 20608, 11055, 88156, 92808,\n\t2152, 57259, 55275, 72789, 24475, 104414, 1708, 9882, 3818, 48661, 66897, 1631, 34806, 227930, 85815, 87753,\n\t18321, 250664, 72733, 25107, 206797, 50891, 8082, 196411, 92596, 96764, 152823, 65514, 22819, 387277, 62176, 51225,\n\t40329, 15563, 189, 3659, 73670, 64357, 51793, 275136, 33482, 86653, 74615, 67058, 11318, 125720, 15388, 22388,\n\t8267, 1730, 102663, 170910, 40784, 7144, 85373, 13040, 7088, 94309, 583, 44224, 140424, 77439, 18496, 164026,\n\t36578, 4722, 9151, 5824, 63365, 26510, 35199, 40500, 79277, 32495, 44614, 35233, 9566, 203293, 152144, 7097,\n\t2330, 183480, 98629, 13423, 330887, 44130, 68600, 30939, 97829, 31012, 345465, 56747, 94879, 4939, 160027, 149761,\n\t99423, 46099, 32251, 15332, 8761, 96094, 128555, 5763, 235318, 222223, 55729, 30241, 55420, 201746, 3987, 81382,\n\t8259, 49325, 23287, 7719, 24633, 251100, 92311, 18591, 110533, 64759, 170260, 393860, 7175, 21144, 132887, 3593,\n\t75346, 101277, 91109, 16387, 259187, 11627, 57459, 173829, 44694, 55780, 49797, 89192, 120443, 62622, 3904, 14814,\n\t23887, 1027, 112258, 64955, 99800, 11132, 66353, 36202, 48624, 18158, 88481, 96882, 43059, 11040, 2455, 7077,\n\t21651, 181159, 99126, 100434, 61388, 68186, 19161, 110468, 120052, 8819, 55324, 41494, 7014, 37689, 3618, 87729,\n\t92615, 207943, 9823, 128657, 12587, 15857, 6379, 67628, 51216, 71775, 157617, 63244, 1503, 3864, 218754, 110864,\n\t5769, 21492, 7243, 1192, 87921, 85529, 31512, 18537, 42698, 35350, 73510, 84474, 34301, 8991, 21013, 35034,\n\t566, 38832, 19838, 35586, 37216, 39413, 55006, 12178, 59742, 856, 84563, 6900, 25632, 17437, 49786, 30723,\n\t13847, 70845, 4044, 7843, 23944, 235976, 55530, 48942, 6518, 20939, 73769, 192653, 52936, 95207, 23895, 132542,\n\t142982, 22632, 87452, 48042, 54018, 178468, 10728, 26230, 23559, 363, 81269, 142012, 5718, 346258, 31456, 84333,\n\t246476, 51018, 66692, 101804, 120570, 39962, 30373, 70593, 2864, 60541, 19425, 54209, 104092, 7201, 31545, 48018,\n\t25865, 15442, 46257, 40443, 8328, 6451, 111782, 47527, 97754, 33046, 470, 245116, 31095, 39, 91934, 87208,\n\t73470, 36708, 36521, 12801, 70624, 36272, 8892, 79768, 12427, 55454, 103756, 5908, 52390, 62962, 22720, 141138,\n\t94634, 41689, 128402, 126390, 6628, 106394, 35527, 134394, 82727, 254651, 194502, 148064, 89549, 3202, 28359, 957,\n\t21954, 27906, 49840, 142747, 8307, 24206, 48978, 1186, 71728, 133038, 71474, 91306, 6333, 110959, 74600, 70387,\n\t18983, 62609, 56057, 22970, 1147, 135850, 1321, 28834, 3578, 59715, 102227, 32827, 81415, 99952, 55636, 257598,\n\t390, 22702, 35701, 85872, 402916, 39216, 189795, 14929, 19467, 10112, 144422, 61514, 5279, 63421, 134686, 41436,\n\t8424, 51925, 10598, 132295, 124416, 4604, 194739, 210929, 57866, 31829, 51626, 50007, 9976, 91878, 61906, 56168,\n\t81906, 60918, 61859, 40017, 23059, 16887, 40927, 62064, 12785, 32893, 32913, 21782, 93965, 20169, 44387, 79084,\n\t38463, 11457, 93950, 27127, 157050, 2697, 337088, 5116, 54128, 48255, 33279, 8821, 27352, 25515, 124022, 65710,\n\t28906, 38557, 33390, 1722, 104435, 72215, 38551, 12094, 30978, 25113, 6671, 37355, 175109, 42862, 98024, 65406,\n\t221276, 59624, 118012, 64637, 78760, 86697, 21426, 1639, 40350, 12584, 67193, 84144, 31396, 7863, 143011, 69629,\n\t63112, 9454, 28666, 65798, 46372, 134721, 6314, 51402, 30837, 151922, 2847, 38676, 38008, 92823, 136245, 17540,\n\t5504, 109295, 205242, 37606, 5211, 214892, 1586, 20670, 208711, 137743, 19328, 40652, 16995, 20023, 14657, 154919,\n\t34422, 12996, 13918, 38221, 47690, 16398, 2959, 37680, 89122, 6721, 198469, 91876, 172043, 83898, 101992, 26084,\n\t94570, 3635, 76958, 22853, 76497, 38266, 176590, 168403, 44464, 142840, 79180, 184594, 1984, 41806, 83147, 11985,\n\t6546, 366068, 59732, 24533, 271505, 8736, 39084, 222992, 93429, 28962, 58985, 86665, 8432, 30028, 14548, 32439,\n\t54424, 165029, 55175, 27458, 69046, 121277, 46168, 33732, 20661, 24581, 135574, 123110, 37556, 79260, 72611, 16957,\n\t12939, 46162, 58238, 44907, 72936, 253758, 41324, 32518, 96480, 11949, 124438, 65280, 43256, 34107, 53533, 43531,\n\t37037, 28366, 45970, 32741, 173438, 6121, 194202, 62969, 26355, 30314, 58370, 28455, 1848, 50519, 82830, 90393,\n\t21761, 295490, 10936, 256940, 133568, 44050, 20269, 4089, 27457, 21610, 219460, 36743, 14821, 101388, 52005, 13124,\n\t30979, 140816, 167362, 26054, 18458, 60789, 34917, 40447, 26606, 33422, 9066, 3452, 83614, 5761, 20263, 137238,\n\t25038, 91310, 101, 52322, 74548, 42572, 38084, 214054, 186568, 31802, 17665, 30620, 141936, 37730, 14420, 4265,\n\t187218, 49640, 188208, 51441, 55388, 96452, 66659, 40869, 42039, 60967, 221027, 19234, 178581, 29105, 96050, 9165,\n\t196118, 157335, 3738, 40354, 117436, 2965, 34136, 59659, 15570, 50843, 230035, 31444, 71260, 43886, 18316, 5387,\n\t38500, 168508, 17406, 32174, 8828, 103373, 143806, 90367, 3560, 18719, 122310, 16508, 26719, 2541, 105429, 6645,\n\t37998, 73190, 10591, 235916, 49737, 87112, 233941, 53188, 32193, 79154, 4544, 52905, 126477, 7580, 63501, 57314,\n\t3216, 31337, 6541, 103083, 60846, 49, 9756, 15481, 1355, 43840, 14319, 13743, 27486, 10222, 73114, 230718,\n\t418644, 16706, 6674, 279748, 23058, 45273, 295831, 86306, 2743, 5535, 88773, 21829, 35253, 120938, 31153, 3169,\n\t16839, 42847, 8751, 80974, 33942, 36867, 35514, 16485, 26474, 77775, 56877, 5391, 48346, 3882, 108713, 31403,\n\t27804, 55248, 26235, 43821, 136104, 40118, 175507, 28034, 203908, 18732, 1788, 34030, 106427, 36958, 54359, 7251,\n\t44936, 15356, 69139, 455, 157915, 22173, 140291, 50348, 43275, 82066, 49621, 54952, 15216, 36226, 96695, 66855,\n\t6936, 1987, 8227, 196087, 4631, 68827, 99004, 47541, 110265, 17953, 147605, 110242, 58520, 31312, 38724, 329975,\n\t642, 3155, 34497, 75937, 6207, 73843, 6120, 17249, 51429, 117746, 3218, 910, 68961, 319671, 14938, 29555,\n\t34700, 1649, 66673, 72268, 9655, 76800, 153087, 6941, 210168, 27130, 35398, 1780, 73242, 3135, 56689, 19556,\n\t165307, 8765, 35967, 121458, 13333, 70453, 17350, 117253, 22265, 13340, 44265, 39869, 441, 3742, 135025, 23581,\n\t33309, 16543, 17731, 13291, 157637, 283005, 21408, 101360, 63887, 52312, 83873, 5338, 233779, 23759, 186949, 34531,\n\t177320, 38069, 156465, 91004, 19353, 59852, 68160, 14891, 1338, 1072, 29823, 1950, 28901, 81407, 313445, 73038,\n\t84807, 162348, 240257, 37162, 138934, 16111, 58013, 41253, 102951, 16457, 96056, 19541, 56402, 67217, 41638, 94381,\n\t89674, 29481, 37456, 80815, 151579, 13937, 13683, 132537, 19699, 134545, 67020, 29816, 222341, 141235, 427578, 48868,\n\t129557, 233342, 23077, 87871, 16213, 18728, 16184, 9469, 37913, 19680, 2798, 171356, 178328, 13216, 50049, 72690,\n\t71904, 124644, 55455, 7504, 29052, 41036, 266546, 19899, 30391, 188755, 8659, 59469, 16, 104298, 112943, 53865,\n\t76203, 138226, 68857, 139953, 14125, 107625, 119795, 173133, 4398, 50273, 48808, 54390, 16466, 122086, 31835, 67035,\n\t50971, 48859, 7508, 46427, 66477, 73021, 84615, 39985, 83076, 46779, 201569, 53336, 36443, 60865, 168164, 143810,\n\t51393, 25548, 169307, 32896, 24485, 38424, 21837, 29087, 275813, 51674, 6714, 64883, 46169, 187369, 55186, 76192,\n\t12852, 12018, 62134, 31067, 118303, 16542, 12125, 10579, 4928, 26291, 43854, 7091, 10946, 253716, 109062, 39283,\n\t17261, 113012, 258512, 47764, 125126, 32646, 55892, 80279, 201623, 149872, 3192, 385, 1208, 48750, 5376, 58738,\n\t22335, 5427, 82416, 47811, 32435, 143086, 38930, 94128, 59975, 156037, 37977, 38224, 62485, 7698, 50405, 71027,\n\t16462, 21559, 136153, 34131, 107506, 162069, 63703, 3101, 215029, 40407, 4178, 3774, 9187, 80019, 17880, 97926,\n\t67579, 2600, 18405, 8351, 47924, 86638, 70820, 92206, 86453, 29610, 42241, 119200, 3198, 15466, 67813, 57863,\n\t35454, 4779, 99518, 4649, 104641, 144269, 33730, 38073, 65864, 6838, 109456, 193298, 154007, 5623, 45741, 30846,\n\t182578, 25573, 157224, 1543, 58575, 138703, 146140, 44971, 49356, 18275, 59064, 20300, 13122, 11848, 24453, 11973,\n\t9797, 86843, 2919, 25530, 49210, 1130, 161220, 76788, 75373, 85604, 34926, 36014, 17777, 17255, 51533, 11676,\n\t92226, 51845, 119859, 21525, 5936, 18507, 28050, 1140, 31418, 14857, 34207, 47859, 10750, 36382, 32079, 106909,\n\t59426, 87757, 38393, 110042, 15965, 97104, 33757, 35344, 97993, 53979, 33651, 45407, 41884, 82515, 173089, 7177,\n\t58371, 35365, 47543, 51927, 35587, 10670, 23544, 29306, 84233, 39976, 76076, 62097, 9007, 8668, 28119, 78281,\n\t120790, 19835, 143020, 54968, 18670, 64959, 20649, 34469, 42570, 33001, 136570, 87796, 120044, 1106, 58700, 63951,\n\t127623, 12805, 83057, 40212, 31773, 49850, 7361, 54336, 347524, 101314, 23751, 19569, 48791, 29174, 49369, 20467,\n\t7465, 75842, 38281, 623, 112457, 60210, 28849, 51003, 94720, 6426, 90047, 85560, 43761, 3579, 85105, 34607,\n\t90410, 118528, 7224, 42907, 111163, 18168, 6960, 161135, 191298, 5247, 100584, 127552, 171568, 20121, 91173, 12636,\n\t54615, 20199, 63730, 98105, 2396, 40387, 14438, 125012, 4765, 33235, 12865, 45299, 37728, 82098, 77872, 114037,\n\t59253, 19675, 24838, 398016, 102561, 11446, 17069, 57508, 178277, 65836, 99941, 26114, 2585, 271882, 136866, 50126,\n\t11027, 155648, 118367, 14585, 8910, 123015, 335383, 40434, 41016, 53021, 14439, 87098, 176860, 201543, 121888, 2358,\n\t9286, 5739, 22666, 54270, 37884, 169381, 33984, 93859, 16124, 89364, 72207, 51639, 76366, 99029, 65812, 2198,\n\t12147, 174891, 194289, 6986, 30252, 88822, 21284, 11445, 288337, 160821, 33034, 100869, 43852, 25761, 52882, 1144,\n\t103809, 1924, 84458, 86079, 43411, 13542, 139276, 18141, 34978, 41298, 7276, 26481, 173800, 33210, 17951, 142652,\n\t33616, 33677, 2210, 19941, 98568, 2486, 192414, 80136, 12058, 235883, 50963, 249638, 29572, 27221, 47034, 6124,\n\t72107, 63346, 97620, 158513, 299699, 40388, 23235, 37176, 224244, 198386, 121323, 67992, 23827, 63170, 17838, 106622,\n\t158590, 26807, 5345, 23489, 91891, 55474, 74834, 37981, 13058, 5977, 72552, 34706, 26828, 145172, 19904, 21367,\n\t34043, 960, 77092, 91381, 4733, 47446, 7680, 41697, 5170, 16960, 14741, 46101, 13656, 473, 51842, 37433,\n\t11103, 11551, 121951, 13191, 97536, 165932, 50397, 51628, 129028, 9069, 44885, 6590, 59195, 47045, 32940, 225472,\n\t90345, 21833, 13303, 29407, 96615, 141951, 5198, 6028, 18395, 7181, 3861, 14966, 156358, 167182, 36529, 55253,\n\t25942, 173153, 30959, 27261, 50691, 150176, 162201, 38467, 48462, 80602, 42163, 118482, 168, 108756, 26011, 17166,\n\t54149, 456538, 22512, 91374, 13816, 90358, 131615, 18132, 226707, 1824, 28139, 26860, 42253, 93877, 77351, 65575,\n\t8980, 80574, 22020, 27948, 40422, 91324, 76376, 13528, 39281, 91685, 82215, 122541, 144066, 1983, 193851, 17283,\n\t26320, 2739, 194978, 4790, 26845, 42627, 61300, 65815, 174612, 55133, 4200, 191130, 79771, 158321, 52280, 166796,\n\t221620, 62461, 11278, 4067, 88152, 83409, 31717, 121367, 13522, 47325, 37945, 10406, 174348, 249321, 154101, 64912,\n\t29938, 51775, 17220, 15776, 166138, 78890, 84425, 54121, 42861, 16368, 24572, 291647, 10197, 32073, 22651, 11677,\n\t97509, 26952, 35787, 18424, 41910, 71614, 94977, 72318, 41594, 70024, 275419, 37702, 60199, 7335, 39107, 61315,\n\t18271, 18394, 33768, 87884, 104277, 123724, 7277, 56288, 71981, 189803, 49320, 3352, 6798, 14240, 8954, 69220,\n\t94433, 57372, 28620, 68863, 193727, 85575, 42309, 41667, 67689, 42081, 22543, 44824, 12719, 28540, 114236, 101553,\n\t27638, 27296, 4300, 5353, 4663, 19379, 94098, 3758, 95888, 95144, 80344, 87320, 28447, 259518, 12718, 71391,\n\t152731, 37063, 24132, 31911, 104896, 15672, 103782, 1521, 4945, 72541, 23717, 122632, 15619, 87175, 206120, 29428,\n\t189780, 61416, 28350, 44457, 972, 1175, 47233, 198738, 95789, 41907, 21953, 97034, 59341, 22864, 53713, 16873,\n\t32971, 20693, 20954, 31336, 21477, 16169, 38370, 16412, 9019, 3841, 24599, 21938, 17085, 6484, 81198, 76413,\n\t5849, 72514, 12320, 65247, 276175, 37234, 59796, 52642, 16312, 57349, 198507, 94148, 46134, 18958, 125552, 1747,\n\t18725, 151873, 14901, 5490, 68287, 29470, 3689, 64794, 40814, 26018, 25692, 54450, 2703, 88278, 124886, 173087,\n\t174000, 24159, 179477, 24276, 46004, 201876, 209202, 445, 52876, 31948, 30206, 157610, 39180, 18439, 44124, 50469,\n\t5774, 96278, 222758, 200216, 50290, 45486, 20435, 46986, 46276, 140133, 142326, 15569, 13363, 47522, 92583, 2182,\n\t7135, 16853, 22998, 30272, 4952, 63263, 35623, 39096, 53789, 44864, 20053, 110392, 124213, 4630, 16087, 28221,\n\t127787, 25839, 77481, 44693, 13464, 113146, 6983, 27069, 55717, 50102, 4760, 7107, 26186, 66507, 59145, 36032,\n\t104182, 71328, 29425, 64317, 50781, 47465, 94298, 69706, 74899, 22754, 120756, 25108, 93077, 56834, 73286, 39928,\n\t16218, 41699, 176763, 7555, 70819, 50083, 26895, 23315, 26014, 16773, 123079, 41712, 5719, 31516, 90427, 158540,\n\t85051, 183128, 40864, 27505, 55392, 9058, 45224, 96857, 30901, 136622, 96557, 56304, 120061, 11501, 151448, 5773,\n\t89743, 7769, 86069, 2935, 18471, 41628, 10114, 33660, 110170, 49479, 26745, 92846, 33221, 26731, 18795, 87076,\n\t8550, 2100, 29972, 120289, 3077, 72490, 33784, 2630, 208722, 50861, 63483, 79029, 6419, 39467, 14302, 45286,\n\t64207, 9686, 67513, 44170, 1050, 77246, 59266, 17055, 53801, 7150, 11111, 42432, 4278, 94579, 362117, 36175,\n\t42902, 41933, 39002, 98489, 22913, 74161, 84773, 57036, 17556, 162288, 74485, 178760, 93867, 73635, 128860, 50362,\n\t261, 67455, 80001, 46080, 35662, 4368, 25247, 19230, 74393, 22588, 1822, 27682, 235324, 13798, 85998, 13194,\n\t235067, 23514, 71669, 147632, 23191, 134748, 214683, 105101, 1518, 25489, 247114, 7380, 54842, 26922, 3971, 26361,\n\t20844, 68642, 170517, 77339, 123255, 8963, 77818, 150998, 48466, 36806, 2732, 23261, 11741, 236162, 18243, 126216,\n\t28690, 50546, 16385, 92760, 197383, 246558, 201295, 88255, 67588, 71687, 176076, 172653, 169058, 33906, 63747, 24835,\n\t157621, 43338, 30050, 46152, 132741, 2770, 51371, 94835, 6614, 15112, 11749, 56936, 1250, 19027, 399017, 58036,\n\t100215, 23388, 55815, 308768, 124152, 94803, 9521, 64186, 8971, 28, 30427, 62163, 7616, 103838, 35079, 29203,\n\t131235, 7743, 17389, 10882, 37420, 61460, 228512, 85363, 41581, 131077, 62822, 119647, 10130, 54445, 26925, 19968,\n\t29016, 24446, 74028, 24176, 61448, 67185, 9254, 8563, 119129, 9771, 99184, 37716, 39514, 10532, 221512, 258753,\n\t218630, 55980, 23394, 32141, 61924, 66749, 32411, 3741, 36475, 26678, 77010, 44946, 91203, 128749, 116953, 20476,\n\t49625, 53116, 13735, 102335, 29376, 51946, 83407, 67892, 59212, 34685, 21083, 1546, 112982, 32972, 74397, 1078,\n\t190545, 16082, 86140, 58591, 89611, 101531, 10061, 105104, 76319, 20035, 17551, 52611, 169061, 190842, 100780, 23907,\n\t90413, 115619, 9675, 34710, 193435, 49443, 129734, 11183, 258877, 16318, 136182, 126808, 44635, 27304, 192375, 2599,\n\t125648, 47051, 12091, 23814, 721, 58800, 40137, 66726, 97930, 60877, 74487, 7942, 54326, 9841, 41428, 13762,\n\t8211, 85383, 6950, 99177, 79806, 201786, 296464, 124087, 13144, 29741, 41721, 47634, 55088, 254286, 106408, 17041,\n\t99064, 12942, 64086, 45233, 14005, 2612, 55827, 255, 7984, 13980, 38574, 12776, 46654, 73499, 249951, 2101,\n\t26676, 25996, 132326, 116415, 119062, 50449, 31033, 23038, 11589, 179252, 20007, 14860, 129270, 21143, 17796, 144715,\n\t60106, 70758, 69842, 34674, 282133, 44014, 16774, 57268, 38528, 24053, 46373, 201667, 28327, 471023, 51889, 102667,\n\t21193, 114909, 84132, 69317, 96723, 67969, 16134, 68145, 15058, 28765, 32035, 2524, 101089, 98664, 25045, 76571,\n\t14957, 86040, 118506, 262428, 154764, 81573, 39681, 283900, 73287, 127825, 544, 80448, 52347, 38512, 175971, 15180,\n\t45467, 33086, 46552, 48894, 81107, 43213, 36672, 54025, 76703, 8053, 7608, 13299, 56619, 20752, 238099, 54164,\n\t105133, 1444, 32942, 953, 37564, 8000, 66316, 119463, 106817, 404, 13667, 149108, 128597, 31267, 10269, 49836,\n\t106150, 1484, 52330, 76965, 160486, 171648, 38456, 31263, 22424, 37738, 66245, 67467, 143369, 60471, 75610, 20895,\n\t115528, 86070, 60854, 40796, 49347, 18989, 15030, 11371, 37578, 15779, 79867, 10187, 86462, 46402, 155626, 93200,\n\t40229, 7090, 57547, 108053, 99598, 11088, 47505, 41218, 206017, 2173, 20988, 30219, 22919, 80563, 57566, 42369,\n\t93141, 41675, 2407, 182519, 120495, 27154, 16702, 29456, 14349, 7958, 16688, 117177, 140375, 42467, 261919, 74916,\n\t153569, 10836, 34742, 49526, 7621, 105997, 12212, 2270, 392377, 7755, 17959, 25086, 232152, 138791, 33847, 13860,\n\t35316, 5811, 1344, 71259, 50452, 207539, 92635, 50359, 5821, 33674, 30255, 2086, 2587, 96264, 17543, 42,\n\t6029, 9580, 43007, 139248, 82831, 12917, 29607, 25786, 51467, 42137, 85161, 100698, 31561, 88989, 121990, 278500,\n\t3602, 109344, 37982, 15279, 116442, 28936, 30880, 87894, 58079, 128661, 126731, 67392, 28051, 146885, 4861, 16216,\n\t97344, 42827, 147561, 153948, 22684, 21335, 47685, 1853, 43349, 15185, 59642, 10229, 25520, 187921, 108972, 5579,\n\t98037, 24945, 6697, 19193, 63734, 137934, 75056, 89740, 19767, 224268, 56138, 63643, 151661, 39313, 70618, 84031,\n\t89723, 84074, 13703, 85626, 35460, 8867, 64845, 3439, 57906, 99776, 63968, 49270, 81130, 34356, 16210, 23547,\n\t36446, 34090, 140028, 72439, 2221, 22163, 57058, 363492, 113754, 18913, 95451, 48663, 54464, 54037, 176097, 68425,\n\t3023, 34906, 29482, 117389, 341780, 80431, 58330, 16753, 92616, 60907, 94846, 147486, 4498, 48646, 7773, 46801,\n\t7778, 18946, 464978, 47558, 33223, 177444, 7328, 15626, 63337, 94700, 11743, 9351, 255024, 39098, 16447, 42647,\n\t96230, 39769, 58840, 10068, 63439, 35800, 65843, 58823, 413844, 9156, 51258, 7434, 61791, 85018, 6872, 3692,\n\t28096, 7121, 33024, 6009, 75532, 31997, 192535, 9661, 3304, 9547, 14753, 31987, 25314, 55689, 15896, 20430,\n\t39472, 31340, 99744, 25398, 115569, 54883, 28719, 205423, 23071, 57855, 64638, 149867, 25671, 82403, 37616, 20668,\n\t39989, 77996, 74948, 140555, 175248, 64810, 36515, 46595, 4958, 248773, 24045, 28728, 136673, 168704, 20804, 114833,\n\t100325, 27135, 21205, 96151, 153134, 45992, 7093, 13992, 76047, 1980, 19432, 145001, 75159, 87462, 17710, 1013,\n\t45556, 34297, 144882, 20648, 26061, 11319, 129567, 108555, 18872, 464580, 33386, 22717, 65948, 167189, 5603, 135042,\n\t79542, 8801, 202632, 18114, 91882, 5973, 5239, 67315, 4431, 60916, 47819, 71693, 32597, 32606, 18183, 45072,\n\t80329, 76385, 24749, 51305, 40314, 156514, 14693, 130345, 13168, 66214, 18029, 12858, 34801, 27628, 14544, 10823,\n\t40522, 40185, 33739, 148694, 23548, 9923, 61012, 28859, 17933, 19442, 34364, 99849, 164107, 141167, 30629, 21054,\n\t6744, 36491, 8096, 42474, 41706, 155060, 30650, 10600, 163442, 1143, 96655, 61390, 52359, 7559, 51568, 64256,\n\t203854, 4467, 22453, 14504, 436398, 7878, 6980, 8293, 63610, 293747, 16167, 35763, 19627, 147603, 15419, 18032,\n\t110744, 51346, 33681, 54571, 40472, 48615, 39073, 21604, 13754, 173027, 92560, 11083, 47299, 63062, 11813, 52007,\n\t29883, 9734, 139722, 15953, 1550, 20651, 13616, 49306, 16113, 90089, 92326, 7584, 30712, 72424, 164858, 6831,\n\t152871, 55746, 197721, 34167, 196442, 6022, 112107, 55215, 7538, 123381, 4920, 43539, 77165, 8939, 50392, 34192,\n\t20225, 79762, 22505, 58667, 40770, 29788, 97180, 82835, 4568, 8579, 13273, 363569, 35898, 49983, 436, 36598,\n\t3237, 131691, 62418, 35591, 8101, 4073, 379438, 65218, 76072, 33887, 2968, 27573, 212619, 288680, 68278, 72851,\n\t150504, 217896, 6913, 121339, 22017, 35340, 51072, 43616, 75043, 31437, 10833, 81487, 4364, 22968, 41454, 106687,\n\t85446, 19863, 109625, 149241, 524, 141850, 214404, 54376, 657, 237023, 9401, 108137, 53800, 32474, 49712, 53334,\n\t126876, 27337, 45552, 177696, 8269, 15036, 12097, 42240, 2328, 125374, 119295, 99715, 2500, 19624, 39441, 27220,\n\t102691, 60957, 94543, 39101, 18566, 67362, 13975, 78230, 25017, 34017, 239007, 90027, 39351, 41681, 35354, 43822,\n\t1043, 916, 58587, 141983, 94818, 38799, 75459, 41114, 67432, 16195, 36606, 59568, 22272, 126769, 31424, 68659,\n\t12287, 134302, 257977, 5756, 207285, 95637, 47248, 117689, 19583, 77451, 22373, 12200, 54993, 117118, 34244, 29386,\n\t34562, 53819, 71267, 64172, 77665, 49368, 7716, 59301, 25749, 45426, 194789, 17297, 2650, 1766, 32501, 45198,\n\t20403, 20984, 6600, 14171, 94604, 19037, 5402, 29896, 9938, 59935, 109708, 88081, 145182, 44844, 39167, 352626,\n\t164173, 35374, 45982, 6122, 154, 73419, 220487, 53834, 53601, 17992, 8609, 229321, 5610, 68098, 66815, 71012,\n\t95069, 140968, 27396, 8957, 134489, 24656, 86659, 56598, 134852, 17316, 123838, 255436, 6613, 41610, 138033, 81452,\n\t32023, 32396, 123687, 63398, 8693, 29712, 30407, 19296, 121188, 3551, 36099, 20032, 111948, 56624, 16547, 27453,\n\t35916, 15378, 52039, 56849, 13489, 22214, 73177, 53097, 277349, 2157, 14029, 187886, 10260, 141743, 246460, 91880,\n\t50869, 3788, 49486, 133566, 54950, 33120, 129337, 53768, 18333, 9525, 26902, 312251, 10297, 9020, 70759, 16647,\n\t112432, 59260, 84609, 9818, 82766, 73569, 468, 46001, 75780, 55028, 52106, 11498, 43645, 108069, 17150, 17753,\n\t29417, 16705, 31799, 9606, 289, 122254, 115975, 8620, 6133, 255357, 56908, 14456, 133464, 43554, 79224, 11247,\n\t29630, 160, 12756, 25464, 65960, 350428, 62521, 321796, 100359, 67358, 35169, 46172, 113128, 48988, 88868, 31094,\n\t33266, 6847, 60887, 98188, 49659, 69117, 92977, 220228, 13947, 80181, 35103, 62170, 97351, 13475, 2440, 199768,\n\t19498, 36597, 46971, 25234, 67806, 62881, 84717, 73648, 181966, 10488, 94149, 21550, 26655, 63436, 48375, 14405,\n\t165650, 9621, 24439, 28043, 42735, 4490, 29963, 56674, 45373, 1934, 262446, 50855, 67098, 26898, 5261, 52696,\n\t40644, 33900, 9440, 180286, 87162, 22940, 19704, 26936, 69769, 10254, 101759, 27406, 12243, 48000, 73926, 113215,\n\t54935, 5726, 192787, 4312, 106216, 9366, 11550, 52949, 23457, 212271, 277152, 133895, 108374, 6191, 96477, 29980,\n\t218916, 58024, 54696, 40853, 91124, 65894, 91170, 65908, 252552, 6793, 29212, 15389, 44516, 122515, 52617, 35058,\n\t9017, 103536, 39510, 49136, 19242, 130652, 662077, 74699, 47024, 31422, 8517, 73351, 24399, 13867, 128360, 4810,\n\t4434, 61779, 111983, 61036, 17798, 110240, 59722, 102960, 39688, 10001, 23803, 23039, 176498, 56659, 44814, 134295,\n\t17188, 77577, 74466, 226175, 102472, 154333, 63900, 111747, 18062, 41171, 79669, 32773, 408933, 42562, 28931, 30907,\n\t107388, 43487, 2946, 240310, 23938, 24354, 319, 184983, 7927, 6488, 1422, 10790, 68809, 68209, 64775, 4361,\n\t202, 17123, 59634, 51200, 44391, 18188, 17843, 2619, 74278, 3230, 9540, 47187, 21702, 36274, 56894, 43907,\n\t16310, 34790, 16866, 6150, 5561, 13587, 107545, 108873, 126867, 86986, 28640, 33427, 19017, 5762, 80637, 17430,\n\t46903, 2047, 131055, 25958, 13558, 5444, 47152, 13900, 44563, 122857, 45348, 70863, 39593, 54332, 38068, 33637,\n\t318, 40310, 143467, 18502, 24520, 11377, 62013, 28942, 27246, 28269, 83545, 17999, 59015, 90707, 30065, 15161,\n\t34720, 1263, 37008, 2012, 6060, 98575, 92933, 5721, 299, 199555, 24578, 29223, 2985, 743, 115825, 109523,\n\t136657, 47454, 26378, 53586, 3733, 174945, 93340, 244456, 5693, 37386, 28782, 89767, 27545, 23573, 18798, 136425,\n\t34320, 84778, 20041, 48453, 38215, 7477, 71958, 40621, 8773, 5874, 187927, 105965, 51100, 43533, 18083, 8443,\n\t10180, 43597, 2003, 183999, 69689, 12216, 129696, 146188, 62389, 34044, 68410, 12765, 43273, 26949, 266807, 3345,\n\t34477, 79197, 5688, 47539, 213110, 21634, 22257, 50092, 32222, 42346, 39530, 63668, 98, 134978, 74022, 5152,\n\t59088, 174145, 37220, 9934, 9545, 118937, 5724, 87240, 19875, 15784, 40143, 23263, 87513, 181654, 285152, 37881,\n\t263241, 4966, 43934, 10433, 186657, 6470, 74416, 225854, 25908, 142677, 246262, 32280, 6192, 75890, 45546, 143264,\n\t135305, 29742, 47013, 77787, 11732, 126658, 8763, 37950, 21806, 57557, 113464, 89465, 108995, 164574, 23894, 22996,\n\t23169, 15369, 23117, 17642, 130607, 40503, 36239, 280990, 44666, 9981, 40427, 147487, 26869, 168452, 32886, 32991,\n\t46798, 240839, 15111, 70502, 65697, 88548, 44145, 28701, 48767, 31139, 206777, 35659, 181164, 166262, 14554, 171445,\n\t31786, 66523, 76607, 17956, 6507, 31279, 90476, 116611, 167918, 6560, 1243, 115324, 80128, 41867, 55897, 187323,\n\t37069, 32596, 189444, 145931, 13390, 105530, 65709, 26805, 6999, 55714, 41300, 22915, 68951, 22138, 21120, 22264,\n\t10058, 19945, 33635, 56123, 99085, 10032, 5818, 6016, 46649, 57476, 35264, 94413, 112522, 262288, 93686, 83038,\n\t14341, 23204, 28807, 66084, 77987, 6101, 126673, 7133, 38126, 5923, 122091, 170240, 97772, 46874, 215746, 43948,\n\t41622, 3272, 55596, 8332, 146411, 251315, 13533, 8561, 81521, 115449, 48616, 175175, 2063, 186556, 3036, 134537,\n\t75772, 29728, 82360, 22973, 186559, 86348, 89100, 38388, 82297, 45610, 2613, 87082, 9986, 177812, 57884, 23591,\n\t47485, 42543, 33582, 44713, 74439, 257444, 252451, 31825, 35631, 38540, 33066, 5147, 13973, 4343, 51830, 70378,\n\t22827, 26448, 95560, 36896, 241741, 48067, 203953, 298860, 61620, 20450, 3220, 67272, 6586, 107662, 100160, 108684,\n\t6929, 57226, 4762, 7457, 1320, 40404, 77204, 99309, 62750, 208653, 59977, 44000, 74315, 34332, 5819, 172217,\n\t64904, 114077, 18147, 84012, 1791, 98456, 90930, 21446, 116669, 103938, 7422, 85140, 59713, 5768, 326211, 16239,\n\t75411, 13229, 29398, 10758, 236107, 1539, 112472, 95979, 152154, 151294, 306, 21196, 38146, 10700, 6891, 84282,\n\t109646, 56492, 40539, 6589, 119491, 51354, 30685, 140209, 136906, 29622, 73617, 49553, 70525, 51671, 166869, 139616,\n\t74395, 37439, 49595, 45678, 11959, 33211, 86560, 52434, 9282, 62690, 112155, 130810, 5243, 108261, 99970, 265613,\n\t72551, 80049, 6391, 33365, 90721, 66737, 69872, 87011, 1860, 9032, 112544, 60905, 37371, 89015, 140351, 19076,\n\t850, 373531, 2802, 36725, 218795, 72062, 28990, 16550, 24614, 7815, 6187, 26336, 33373, 32162, 42791, 73555,\n\t32062, 23386, 10244, 56392, 49442, 27076, 136262, 12412, 14883, 1134, 33675, 97153, 199281, 15608, 100152, 74072,\n\t47942, 254301, 36451, 16026, 10687, 65067, 56708, 254030, 30290, 50490, 13864, 57941, 259331, 35588, 23485, 43486,\n\t24869, 21620, 92971, 22072, 88645, 1048, 182050, 13343, 32452, 14825, 19509, 3325, 216938, 45740, 99716, 189082,\n\t53740, 78245, 25609, 24311, 176777, 47340, 308354, 40669, 66085, 14102, 125339, 9225, 128709, 97207, 1271, 200933,\n\t78439, 113451, 88975, 18324, 46521, 11819, 18570, 141756, 72512, 170020, 52754, 63550, 118515, 103073, 93330, 32736,\n\t50499, 14722, 31600, 68452, 398867, 29316, 172786, 18417, 104924, 2606, 5670, 84818, 16288, 67106, 59580, 82929,\n\t607401, 291, 85829, 359, 15897, 35830, 50696, 65630, 52672, 22115, 356968, 29895, 40837, 231192, 34024, 38957,\n\t26722, 406, 23335, 124952, 72068, 68804, 13268, 147101, 164740, 276569, 162596, 66943, 11569, 26654, 66358, 4777,\n\t23229, 102127, 5848, 978, 2921, 59666, 5371, 28212, 90108, 42938, 39320, 2499, 4271, 108792, 33510, 125072,\n\t71653, 65239, 38250, 66357, 38577, 13964, 86251, 35708, 50755, 36010, 29448, 12209, 3844, 38222, 206337, 100876,\n\t67827, 137088, 14167, 252225, 84163, 195270, 1306, 5703, 54198, 779, 46802, 22028, 51124, 86759, 70560, 113164,\n\t35685, 162145, 45471, 34561, 422, 2611, 6464, 47486, 19223, 38246, 9191, 18331, 89942, 243642, 212364, 15893,\n\t17518, 22617, 6409, 30046, 126182, 59716, 36560, 104428, 18846, 26592, 19458, 50793, 147333, 30826, 1388, 27647,\n\t10922, 14495, 33545, 19269, 135828, 39727, 41601, 46931, 233379, 49169, 131130, 182112, 16276, 82381, 118209, 142445,\n\t128310, 19672, 28740, 82907, 33436, 3118, 102206, 28723, 24819, 41937, 38854, 5157, 3881, 111491, 1142, 9776,\n\t421673, 152241, 29309, 14961, 87854, 6054, 15424, 3796, 82656, 54996, 2108, 55367, 239450, 154525, 9643, 118103,\n\t106041, 64601, 68549, 48707, 30266, 25772, 18740, 9462, 229669, 91798, 112152, 191327, 14493, 72828, 8175, 66636,\n\t236474, 25817, 87351, 129027, 76653, 20422, 22983, 71240, 27846, 44661, 12399, 46158, 77704, 53101, 35032, 11072,\n\t17300, 109294, 33638, 24408, 1895, 11241, 760, 17584, 82479, 125877, 63150, 141075, 34259, 23274, 81698, 15732,\n\t43577, 48340, 91584, 14688, 16379, 24481, 150280, 96420, 262050, 48635, 43727, 61819, 56268, 72003, 88178, 17281,\n\t79912, 13218, 122519, 125295, 166396, 11811, 2171, 118930, 67746, 17636, 178278, 174656, 95661, 173039, 83845, 79689,\n\t17473, 98555, 127696, 203415, 54730, 22925, 232239, 9309, 12136, 175026, 20740, 180188, 10747, 39816, 314017, 266131,\n\t10040, 175732, 112550, 220651, 31974, 37393, 888, 23008, 86799, 4303, 64905, 148467, 75337, 251, 3284, 370102,\n\t50264, 9835, 5438, 23655, 4481, 29851, 329, 12855, 7162, 64931, 78141, 12804, 42372, 296771, 83547, 18624,\n\t34874, 86271, 3360, 48665, 77735, 88767, 11463, 63527, 28889, 22258, 29140, 194315, 113924, 25499, 6406, 31334,\n\t1845, 4802, 49184, 43455, 35469, 127594, 92970, 61038, 115005, 38840, 87761, 106838, 8811, 20572, 55637, 11162,\n\t96721, 132425, 108925, 2948, 125457, 36356, 3502, 75270, 27622, 127192, 2561, 123095, 49394, 61155, 16897, 110064,\n\t9699, 89448, 53356, 19628, 220310, 21622, 83036, 9885, 112214, 6087, 26713, 17901, 161912, 91492, 3440, 68594,\n\t9266, 92238, 8087, 6866, 150194, 72175, 80701, 13459, 31836, 43243, 239700, 95846, 44749, 50647, 21945, 230538,\n\t120612, 132371, 244604, 5193, 105637, 34661, 41341, 68775, 85393, 1874, 8771, 33718, 49672, 77403, 595452, 99507,\n\t6490, 58895, 128742, 7704, 39239, 73217, 43816, 62824, 37804, 199976, 22361, 80005, 87514, 94832, 14089, 4574,\n\t139975, 59142, 75523, 100268, 43906, 53442, 15152, 2547, 186002, 17011, 19513, 204282, 3343, 60568, 128318, 119250,\n\t4298, 51871, 41336, 71759, 21921, 45074, 98169, 145889, 99427, 11350, 1237, 5520, 28799, 7803, 53702, 21026,\n\t136352, 38293, 128690, 12158, 90132, 44600, 10184, 26957, 39459, 126025, 78904, 82999, 59373, 39301, 150198, 120529,\n\t153042, 20177, 50089, 14764, 271571, 30530, 123161, 38975, 101562, 22941, 5648, 124654, 109243, 69817, 71675, 49162,\n\t106884, 21241, 107795, 30258, 16572, 188262, 141456, 7688, 60718, 8271, 11044, 32440, 104608, 103419, 236109, 93156,\n\t43293, 128929, 42107, 67180, 25201, 115254, 185488, 130954, 72813, 167547, 20537, 39969, 38432, 22582, 184022, 1139,\n\t27199, 5655, 17767, 97412, 122606, 209377, 27070, 35871, 326617, 188954, 42680, 73512, 80911, 22629, 3011, 95021,\n\t315242, 157737, 383, 41821, 41808, 19335, 27950, 15674, 25677, 110950, 35375, 76835, 59108, 57370, 35262, 16569,\n\t160415, 37706, 78086, 32041, 49691, 137143, 9782, 172080, 50148, 77917, 6323, 10110, 69172, 17711, 21795, 59511,\n\t76184, 135114, 31046, 132319, 59105, 157578, 20549, 80778, 57649, 158421, 65143, 4575, 72235, 21899, 10797, 92745,\n\t34035, 106079, 80159, 4508, 78304, 25350, 75457, 46458, 32937, 25623, 47, 8531, 104751, 84953, 8138, 36508,\n\t187199, 66310, 115274, 13253, 32461, 38536, 1916, 42007, 187160, 35055, 26325, 84394, 35963, 94216, 45590, 97782\n]\n","'use strict'\n\nconst debug = require('debug')\nconst { sha256 } = require('multiformats/hashes/sha2')\nconst { base58btc } = require('multiformats/bases/base58')\nconst { Key } = require('interface-datastore/key')\nconst { xor: uint8ArrayXor } = require('uint8arrays/xor')\nconst { compare: uint8ArrayCompare } = require('uint8arrays/compare')\nconst pMap = require('p-map')\nconst { Record } = require('libp2p-record')\nconst PeerId = require('peer-id')\nconst errcode = require('err-code')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { concat: uint8ArrayConcat } = require('uint8arrays/concat')\nconst pTimeout = require('p-timeout')\n\n/**\n * Creates a DHT ID by hashing a given Uint8Array.\n *\n * @param {Uint8Array} buf\n * @returns {Promise<Uint8Array>}\n */\nexports.convertBuffer = async (buf) => {\n return (await sha256.digest(buf)).digest\n}\n\n/**\n * Creates a DHT ID by hashing a Peer ID\n *\n * @param {PeerId} peer\n * @returns {Promise<Uint8Array>}\n */\nexports.convertPeerId = async (peer) => {\n return (await sha256.digest(peer.id)).digest\n}\n\n/**\n * Convert a Uint8Array to their SHA2-256 hash.\n *\n * @param {Uint8Array} buf\n * @returns {Key}\n */\nexports.bufferToKey = (buf) => {\n return new Key('/' + exports.encodeBase32(buf), false)\n}\n\n/**\n * Generate the key for a public key.\n *\n * @param {PeerId} peer\n * @returns {Uint8Array}\n */\nexports.keyForPublicKey = (peer) => {\n return uint8ArrayConcat([\n uint8ArrayFromString('/pk/'),\n peer.id\n ])\n}\n\n/**\n * @param {Uint8Array} key\n */\nexports.isPublicKeyKey = (key) => {\n return uint8ArrayToString(key.slice(0, 4)) === '/pk/'\n}\n\n/**\n * @param {Uint8Array} key\n */\nexports.fromPublicKeyKey = (key) => {\n return new PeerId(key.slice(4))\n}\n\n/**\n * Get the current time as timestamp.\n *\n * @returns {number}\n */\nexports.now = () => {\n return Date.now()\n}\n\n/**\n * Encode a given Uint8Array into a base32 string.\n *\n * @param {Uint8Array} buf\n * @returns {string}\n */\nexports.encodeBase32 = (buf) => {\n return uint8ArrayToString(buf, 'base32')\n}\n\n/**\n * Decode a given base32 string into a Uint8Array.\n *\n * @param {string} raw\n * @returns {Uint8Array}\n */\nexports.decodeBase32 = (raw) => {\n return uint8ArrayFromString(raw, 'base32')\n}\n\n/**\n * Sort peers by distance to the given `target`.\n *\n * @param {Array<PeerId>} peers\n * @param {Uint8Array} target\n */\nexports.sortClosestPeers = async (peers, target) => {\n const distances = await pMap(peers, async (peer) => {\n const id = await exports.convertPeerId(peer)\n\n return {\n peer: peer,\n distance: uint8ArrayXor(id, target)\n }\n })\n\n return distances.sort(exports.xorCompare).map((d) => d.peer)\n}\n\n/**\n * Compare function to sort an array of elements which have a distance property which is the xor distance to a given element.\n *\n * @param {{ distance: Uint8Array }} a\n * @param {{ distance: Uint8Array }} b\n */\nexports.xorCompare = (a, b) => {\n return uint8ArrayCompare(a.distance, b.distance)\n}\n\n/**\n * Computes how many results to collect on each disjoint path, rounding up.\n * This ensures that we look for at least one result per path.\n *\n * @param {number} resultsWanted\n * @param {number} numPaths - total number of paths\n */\nexports.pathSize = (resultsWanted, numPaths) => {\n return Math.ceil(resultsWanted / numPaths)\n}\n\n/**\n * Create a new put record, encodes and signs it if enabled.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n * @returns {Uint8Array}\n */\nexports.createPutRecord = (key, value) => {\n const timeReceived = new Date()\n const rec = new Record(key, value, timeReceived)\n\n return rec.serialize()\n}\n\n/**\n * Creates a logger for the given subsystem\n *\n * @param {PeerId} [id]\n * @param {string} [subsystem]\n */\nexports.logger = (id, subsystem) => {\n const name = ['libp2p', 'dht']\n if (subsystem) {\n name.push(subsystem)\n }\n if (id) {\n name.push(`${id.toB58String().slice(0, 8)}`)\n }\n\n // Add a formatter for converting to a base58 string\n debug.formatters.b = (v) => {\n return base58btc.baseEncode(v)\n }\n\n const logger = Object.assign(debug(name.join(':')), {\n error: debug(name.concat(['error']).join(':'))\n })\n\n return logger\n}\n\nexports.TimeoutError = class TimeoutError extends Error {\n get code () {\n return 'ETIMEDOUT'\n }\n}\n\n/**\n * Creates an async function that calls the given `asyncFn` and Errors\n * if it does not resolve within `time` ms\n *\n * @template T\n * @param {(...args: any[]) => Promise<T>} asyncFn\n * @param {number} [time]\n */\nexports.withTimeout = (asyncFn, time) => {\n /**\n * @param {...any} args\n * @returns {Promise<T>}\n */\n async function timeoutFn (...args) {\n if (!time) {\n return asyncFn(...args)\n }\n\n let res\n\n try {\n res = await pTimeout(asyncFn(...args), time)\n } catch (err) {\n if (err instanceof pTimeout.TimeoutError) {\n throw errcode(err, 'ETIMEDOUT')\n }\n\n throw err\n }\n\n return res\n }\n\n return timeoutFn\n}\n\n/**\n * Iterates the given `asyncIterator` and runs each item through the given `asyncFn` in parallel.\n * Returns a promise that resolves when all items of the `asyncIterator` have been passed\n * through `asyncFn`.\n *\n * @template T\n * @template O\n *\n * @param {AsyncIterable<T>} asyncIterator\n * @param {(arg0: T) => Promise<O>} asyncFn\n */\nexports.mapParallel = async function (asyncIterator, asyncFn) {\n const tasks = []\n for await (const item of asyncIterator) {\n tasks.push(asyncFn(item))\n }\n return Promise.all(tasks)\n}\n","'use strict';\nconst AggregateError = require('aggregate-error');\n\nmodule.exports = async (\n\titerable,\n\tmapper,\n\t{\n\t\tconcurrency = Infinity,\n\t\tstopOnError = true\n\t} = {}\n) => {\n\treturn new Promise((resolve, reject) => {\n\t\tif (typeof mapper !== 'function') {\n\t\t\tthrow new TypeError('Mapper function is required');\n\t\t}\n\n\t\tif (!((Number.isSafeInteger(concurrency) || concurrency === Infinity) && concurrency >= 1)) {\n\t\t\tthrow new TypeError(`Expected \\`concurrency\\` to be an integer from 1 and up or \\`Infinity\\`, got \\`${concurrency}\\` (${typeof concurrency})`);\n\t\t}\n\n\t\tconst result = [];\n\t\tconst errors = [];\n\t\tconst iterator = iterable[Symbol.iterator]();\n\t\tlet isRejected = false;\n\t\tlet isIterableDone = false;\n\t\tlet resolvingCount = 0;\n\t\tlet currentIndex = 0;\n\n\t\tconst next = () => {\n\t\t\tif (isRejected) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst nextItem = iterator.next();\n\t\t\tconst index = currentIndex;\n\t\t\tcurrentIndex++;\n\n\t\t\tif (nextItem.done) {\n\t\t\t\tisIterableDone = true;\n\n\t\t\t\tif (resolvingCount === 0) {\n\t\t\t\t\tif (!stopOnError && errors.length !== 0) {\n\t\t\t\t\t\treject(new AggregateError(errors));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresolve(result);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tresolvingCount++;\n\n\t\t\t(async () => {\n\t\t\t\ttry {\n\t\t\t\t\tconst element = await nextItem.value;\n\t\t\t\t\tresult[index] = await mapper(element, index);\n\t\t\t\t\tresolvingCount--;\n\t\t\t\t\tnext();\n\t\t\t\t} catch (error) {\n\t\t\t\t\tif (stopOnError) {\n\t\t\t\t\t\tisRejected = true;\n\t\t\t\t\t\treject(error);\n\t\t\t\t\t} else {\n\t\t\t\t\t\terrors.push(error);\n\t\t\t\t\t\tresolvingCount--;\n\t\t\t\t\t\tnext();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t})();\n\t\t};\n\n\t\tfor (let i = 0; i < concurrency; i++) {\n\t\t\tnext();\n\n\t\t\tif (isIterableDone) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t});\n};\n","'use strict';\nconst indentString = require('indent-string');\nconst cleanStack = require('clean-stack');\n\nconst cleanInternalStack = stack => stack.replace(/\\s+at .*aggregate-error\\/index.js:\\d+:\\d+\\)?/g, '');\n\nclass AggregateError extends Error {\n\tconstructor(errors) {\n\t\tif (!Array.isArray(errors)) {\n\t\t\tthrow new TypeError(`Expected input to be an Array, got ${typeof errors}`);\n\t\t}\n\n\t\terrors = [...errors].map(error => {\n\t\t\tif (error instanceof Error) {\n\t\t\t\treturn error;\n\t\t\t}\n\n\t\t\tif (error !== null && typeof error === 'object') {\n\t\t\t\t// Handle plain error objects with message property and/or possibly other metadata\n\t\t\t\treturn Object.assign(new Error(error.message), error);\n\t\t\t}\n\n\t\t\treturn new Error(error);\n\t\t});\n\n\t\tlet message = errors\n\t\t\t.map(error => {\n\t\t\t\t// The `stack` property is not standardized, so we can't assume it exists\n\t\t\t\treturn typeof error.stack === 'string' ? cleanInternalStack(cleanStack(error.stack)) : String(error);\n\t\t\t})\n\t\t\t.join('\\n');\n\t\tmessage = '\\n' + indentString(message, 4);\n\t\tsuper(message);\n\n\t\tthis.name = 'AggregateError';\n\n\t\tObject.defineProperty(this, '_errors', {value: errors});\n\t}\n\n\t* [Symbol.iterator]() {\n\t\tfor (const error of this._errors) {\n\t\t\tyield error;\n\t\t}\n\t}\n}\n\nmodule.exports = AggregateError;\n","'use strict';\n\nmodule.exports = (string, count = 1, options) => {\n\toptions = {\n\t\tindent: ' ',\n\t\tincludeEmptyLines: false,\n\t\t...options\n\t};\n\n\tif (typeof string !== 'string') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`input\\` to be a \\`string\\`, got \\`${typeof string}\\``\n\t\t);\n\t}\n\n\tif (typeof count !== 'number') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`count\\` to be a \\`number\\`, got \\`${typeof count}\\``\n\t\t);\n\t}\n\n\tif (typeof options.indent !== 'string') {\n\t\tthrow new TypeError(\n\t\t\t`Expected \\`options.indent\\` to be a \\`string\\`, got \\`${typeof options.indent}\\``\n\t\t);\n\t}\n\n\tif (count === 0) {\n\t\treturn string;\n\t}\n\n\tconst regex = options.includeEmptyLines ? /^/gm : /^(?!\\s*$)/gm;\n\n\treturn string.replace(regex, options.indent.repeat(count));\n};\n","'use strict';\nconst os = require('os');\n\nconst extractPathRegex = /\\s+at.*(?:\\(|\\s)(.*)\\)?/;\nconst pathRegex = /^(?:(?:(?:node|(?:internal\\/[\\w/]*|.*node_modules\\/(?:babel-polyfill|pirates)\\/.*)?\\w+)\\.js:\\d+:\\d+)|native)/;\nconst homeDir = typeof os.homedir === 'undefined' ? '' : os.homedir();\n\nmodule.exports = (stack, options) => {\n\toptions = Object.assign({pretty: false}, options);\n\n\treturn stack.replace(/\\\\/g, '/')\n\t\t.split('\\n')\n\t\t.filter(line => {\n\t\t\tconst pathMatches = line.match(extractPathRegex);\n\t\t\tif (pathMatches === null || !pathMatches[1]) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\tconst match = pathMatches[1];\n\n\t\t\t// Electron\n\t\t\tif (\n\t\t\t\tmatch.includes('.app/Contents/Resources/electron.asar') ||\n\t\t\t\tmatch.includes('.app/Contents/Resources/default_app.asar')\n\t\t\t) {\n\t\t\t\treturn false;\n\t\t\t}\n\n\t\t\treturn !pathRegex.test(match);\n\t\t})\n\t\t.filter(line => line.trim() !== '')\n\t\t.map(line => {\n\t\t\tif (options.pretty) {\n\t\t\t\treturn line.replace(extractPathRegex, (m, p1) => m.replace(p1, p1.replace(homeDir, '~')));\n\t\t\t}\n\n\t\t\treturn line;\n\t\t})\n\t\t.join('\\n');\n};\n","'use strict'\n\n// MaxRecordAge specifies the maximum time that any node will hold onto a record\n// from the time its received. This does not apply to any other forms of validity that\n// the record may contain.\n// For example, a record may contain an ipns entry with an EOL saying its valid\n// until the year 2020 (a great time in the future). For that record to stick around\n// it must be rebroadcasted more frequently than once every 'MaxRecordAge'\n\nconst second = exports.second = 1000\nconst minute = exports.minute = 60 * second\nconst hour = exports.hour = 60 * minute\n\nexports.MAX_RECORD_AGE = 36 * hour\n\nexports.PROTOCOL_DHT = '/kad/1.0.0'\n\nexports.PROVIDERS_KEY_PREFIX = '/providers/'\n\nexports.PROVIDERS_LRU_CACHE_SIZE = 256\n\nexports.PROVIDERS_VALIDITY = 24 * hour\n\nexports.PROVIDERS_CLEANUP_INTERVAL = hour\n\nexports.READ_MESSAGE_TIMEOUT = 10 * second\n\n// The number of records that will be retrieved on a call to getMany()\nexports.GET_MANY_RECORD_COUNT = 16\n\n// K is the maximum number of requests to perform before returning failure\nexports.K = 20\n\n// Alpha is the concurrency for asynchronous requests\nexports.ALPHA = 3\n","'use strict'\n\nconst errcode = require('err-code')\n\nconst { pipe } = require('it-pipe')\nconst lp = require('it-length-prefixed')\nconst pTimeout = require('p-timeout')\nconst { consume } = require('streaming-iterables')\nconst first = require('it-first')\n\nconst MulticodecTopology = require('libp2p-interfaces/src/topology/multicodec-topology')\n\nconst rpc = require('./rpc')\nconst c = require('./constants')\nconst Message = require('./message')\nconst utils = require('./utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\n/**\n * Handle network operations for the dht\n */\nclass Network {\n /**\n * Create a new network\n *\n * @param {import('./index')} dht\n */\n constructor (dht) {\n this.dht = dht\n this.readMessageTimeout = c.READ_MESSAGE_TIMEOUT\n this._log = utils.logger(this.dht.peerId, 'net')\n this._rpc = rpc(this.dht)\n this._onPeerConnected = this._onPeerConnected.bind(this)\n this._running = false\n }\n\n /**\n * Start the network\n */\n start () {\n if (this._running) {\n return\n }\n\n if (!this.dht.isStarted) {\n throw errcode(new Error('Can not start network'), 'ERR_CANNOT_START_NETWORK')\n }\n\n this._running = true\n\n // Only respond to queries when not in client mode\n if (this.dht._clientMode === false) {\n // Incoming streams\n this.dht.registrar.handle(this.dht.protocol, this._rpc)\n }\n\n // register protocol with topology\n const topology = new MulticodecTopology({\n multicodecs: [this.dht.protocol],\n handlers: {\n onConnect: this._onPeerConnected,\n onDisconnect: () => {}\n }\n })\n this._registrarId = this.dht.registrar.register(topology)\n }\n\n /**\n * Stop all network activity\n */\n stop () {\n if (!this.dht.isStarted && !this.isStarted) {\n return\n }\n this._running = false\n\n // unregister protocol and handlers\n if (this._registrarId) {\n this.dht.registrar.unregister(this._registrarId)\n }\n }\n\n /**\n * Is the network online?\n *\n * @type {boolean}\n */\n get isStarted () {\n return this._running\n }\n\n /**\n * Are all network components there?\n *\n * @type {boolean}\n */\n get isConnected () {\n // TODO add a way to check if switch has started or not\n return this.dht.isStarted && this.isStarted\n }\n\n /**\n * Registrar notifies a connection successfully with dht protocol.\n *\n * @param {PeerId} peerId - remote peer id\n */\n async _onPeerConnected (peerId) {\n await this.dht._add(peerId)\n this._log('added to the routing table: %s', peerId.toB58String())\n }\n\n /**\n * Send a request and record RTT for latency measurements.\n *\n * @async\n * @param {PeerId} to - The peer that should receive a message\n * @param {Message} msg - The message to send.\n */\n async sendRequest (to, msg) {\n // TODO: record latency\n if (!this.isConnected) {\n throw errcode(new Error('Network is offline'), 'ERR_NETWORK_OFFLINE')\n }\n\n const id = to.toB58String()\n this._log('sending to: %s', id)\n\n let conn = this.dht.registrar.connectionManager.get(to)\n if (!conn) {\n conn = await this.dht.dialer.connectToPeer(to)\n }\n\n const { stream } = await conn.newStream(this.dht.protocol)\n\n return this._writeReadMessage(stream, msg.serialize())\n }\n\n /**\n * Sends a message without expecting an answer.\n *\n * @param {PeerId} to\n * @param {Message} msg\n */\n async sendMessage (to, msg) {\n if (!this.isConnected) {\n throw errcode(new Error('Network is offline'), 'ERR_NETWORK_OFFLINE')\n }\n\n const id = to.toB58String()\n this._log('sending to: %s', id)\n\n let conn = this.dht.registrar.connectionManager.get(to)\n if (!conn) {\n conn = await this.dht.dialer.connectToPeer(to)\n }\n const { stream } = await conn.newStream(this.dht.protocol)\n\n return this._writeMessage(stream, msg.serialize())\n }\n\n /**\n * Write a message and read its response.\n * If no response is received after the specified timeout\n * this will error out.\n *\n * @param {MuxedStream} stream - the stream to use\n * @param {Uint8Array} msg - the message to send\n */\n async _writeReadMessage (stream, msg) { // eslint-disable-line require-await\n return pTimeout(\n writeReadMessage(stream, msg),\n this.readMessageTimeout\n )\n }\n\n /**\n * Write a message to the given stream.\n *\n * @param {MuxedStream} stream - the stream to use\n * @param {Uint8Array} msg - the message to send\n */\n _writeMessage (stream, msg) {\n return pipe(\n [msg],\n lp.encode(),\n stream,\n consume\n )\n }\n}\n\n/**\n * @param {MuxedStream} stream\n * @param {Uint8Array} msg\n */\nasync function writeReadMessage (stream, msg) {\n const res = await pipe(\n [msg],\n lp.encode(),\n stream,\n lp.decode(),\n /**\n * @param {AsyncIterable<Uint8Array>} source\n */\n async source => {\n const buf = await first(source)\n\n if (buf) {\n return buf.slice()\n }\n }\n )\n\n if (res.length === 0) {\n throw errcode(new Error('No message received'), 'ERR_NO_MESSAGE_RECEIVED')\n }\n\n return Message.deserialize(res)\n}\n\nmodule.exports = Network\n","async function* _batch(size, iterable) {\n let dataBatch = [];\n for await (const data of iterable) {\n dataBatch.push(data);\n if (dataBatch.length === size) {\n yield dataBatch;\n dataBatch = [];\n }\n }\n if (dataBatch.length > 0) {\n yield dataBatch;\n }\n}\nfunction* _syncBatch(size, iterable) {\n let dataBatch = [];\n for (const data of iterable) {\n dataBatch.push(data);\n if (dataBatch.length === size) {\n yield dataBatch;\n dataBatch = [];\n }\n }\n if (dataBatch.length > 0) {\n yield dataBatch;\n }\n}\nfunction batch(size, iterable) {\n if (iterable === undefined) {\n return curriedIterable => batch(size, curriedIterable);\n }\n if (iterable[Symbol.asyncIterator]) {\n return _batch(size, iterable);\n }\n return _syncBatch(size, iterable);\n}\n\nfunction getIterator(iterable) {\n if (typeof iterable.next === 'function') {\n return iterable;\n }\n if (typeof iterable[Symbol.iterator] === 'function') {\n return iterable[Symbol.iterator]();\n }\n if (typeof iterable[Symbol.asyncIterator] === 'function') {\n return iterable[Symbol.asyncIterator]();\n }\n throw new TypeError('\"values\" does not to conform to any of the iterator or iterable protocols');\n}\n\nfunction defer() {\n let reject;\n let resolve;\n const promise = new Promise((resolveFunc, rejectFunc) => {\n resolve = resolveFunc;\n reject = rejectFunc;\n });\n return {\n promise,\n reject,\n resolve,\n };\n}\n\n/// <reference lib=\"esnext.asynciterable\" />\nfunction _buffer(size, iterable) {\n const iterator = getIterator(iterable);\n const resultQueue = [];\n const readQueue = [];\n let reading = false;\n let ended = false;\n function fulfillReadQueue() {\n while (readQueue.length > 0 && resultQueue.length > 0) {\n const readDeferred = readQueue.shift();\n const { error, value } = resultQueue.shift();\n if (error) {\n readDeferred.reject(error);\n }\n else {\n readDeferred.resolve({ done: false, value });\n }\n }\n while (readQueue.length > 0 && ended) {\n const { resolve } = readQueue.shift();\n resolve({ done: true, value: undefined });\n }\n }\n async function fillQueue() {\n if (ended) {\n return;\n }\n if (reading) {\n return;\n }\n if (resultQueue.length >= size) {\n return;\n }\n reading = true;\n try {\n const { done, value } = await iterator.next();\n if (done) {\n ended = true;\n }\n else {\n resultQueue.push({ value });\n }\n }\n catch (error) {\n ended = true;\n resultQueue.push({ error });\n }\n fulfillReadQueue();\n reading = false;\n fillQueue();\n }\n async function next() {\n if (resultQueue.length > 0) {\n const { error, value } = resultQueue.shift();\n if (error) {\n throw error;\n }\n fillQueue();\n return { done: false, value };\n }\n if (ended) {\n return { done: true, value: undefined }; // stupid ts\n }\n const deferred = defer();\n readQueue.push(deferred);\n fillQueue();\n return deferred.promise;\n }\n const asyncIterableIterator = {\n next,\n [Symbol.asyncIterator]: () => asyncIterableIterator,\n };\n return asyncIterableIterator;\n}\nfunction* syncBuffer(size, iterable) {\n const valueQueue = [];\n let e;\n try {\n for (const value of iterable) {\n valueQueue.push(value);\n if (valueQueue.length <= size) {\n continue;\n }\n yield valueQueue.shift();\n }\n }\n catch (error) {\n e = error;\n }\n for (const value of valueQueue) {\n yield value;\n }\n if (e) {\n throw e;\n }\n}\nfunction buffer(size, iterable) {\n if (iterable === undefined) {\n return curriedIterable => buffer(size, curriedIterable);\n }\n if (size === 0) {\n return iterable;\n }\n if (iterable[Symbol.asyncIterator]) {\n return _buffer(size, iterable);\n }\n return syncBuffer(size, iterable);\n}\n\nasync function _collect(iterable) {\n const values = [];\n for await (const value of iterable) {\n values.push(value);\n }\n return values;\n}\nfunction collect(iterable) {\n if (iterable[Symbol.asyncIterator]) {\n return _collect(iterable);\n }\n return Array.from(iterable);\n}\n\nasync function* _concat(iterables) {\n for await (const iterable of iterables) {\n yield* iterable;\n }\n}\nfunction* _syncConcat(iterables) {\n for (const iterable of iterables) {\n yield* iterable;\n }\n}\nfunction concat(...iterables) {\n const hasAnyAsync = iterables.find(itr => itr[Symbol.asyncIterator] !== undefined);\n if (hasAnyAsync) {\n return _concat(iterables);\n }\n else {\n return _syncConcat(iterables);\n }\n}\n\nasync function _consume(iterable) {\n for await (const val of iterable) {\n // do nothing\n }\n}\nfunction consume(iterable) {\n if (iterable[Symbol.asyncIterator]) {\n return _consume(iterable);\n }\n for (const val of iterable) {\n // do nothing\n }\n}\n\nasync function* _filter(filterFunc, iterable) {\n for await (const data of iterable) {\n if (await filterFunc(data)) {\n yield data;\n }\n }\n}\nfunction filter(filterFunc, iterable) {\n if (iterable === undefined) {\n return (curriedIterable) => _filter(filterFunc, curriedIterable);\n }\n return _filter(filterFunc, iterable);\n}\n\nasync function* flatten(iterable) {\n for await (const maybeItr of iterable) {\n if (maybeItr && typeof maybeItr !== 'string' && (maybeItr[Symbol.iterator] || maybeItr[Symbol.asyncIterator])) {\n yield* flatten(maybeItr);\n }\n else {\n yield maybeItr;\n }\n }\n}\n\nasync function* _map(func, iterable) {\n for await (const val of iterable) {\n yield await func(val);\n }\n}\nfunction map(func, iterable) {\n if (iterable === undefined) {\n return curriedIterable => _map(func, curriedIterable);\n }\n return _map(func, iterable);\n}\n\nfunction flatMap(func, iterable) {\n if (iterable === undefined) {\n return curriedIterable => flatMap(func, curriedIterable);\n }\n return filter(i => i !== undefined && i !== null, flatten(map(func, iterable)));\n}\n\nfunction _flatTransform(concurrency, func, iterable) {\n const iterator = getIterator(iterable);\n const resultQueue = [];\n const readQueue = [];\n let ended = false;\n let reading = false;\n let inflightCount = 0;\n let lastError = null;\n function fulfillReadQueue() {\n while (readQueue.length > 0 && resultQueue.length > 0) {\n const { resolve } = readQueue.shift();\n const value = resultQueue.shift();\n resolve({ done: false, value });\n }\n while (readQueue.length > 0 && inflightCount === 0 && ended) {\n const { resolve, reject } = readQueue.shift();\n if (lastError) {\n reject(lastError);\n lastError = null;\n }\n else {\n resolve({ done: true, value: undefined });\n }\n }\n }\n async function fillQueue() {\n if (ended) {\n fulfillReadQueue();\n return;\n }\n if (reading) {\n return;\n }\n if (inflightCount + resultQueue.length >= concurrency) {\n return;\n }\n reading = true;\n inflightCount++;\n try {\n const { done, value } = await iterator.next();\n if (done) {\n ended = true;\n inflightCount--;\n fulfillReadQueue();\n }\n else {\n mapAndQueue(value);\n }\n }\n catch (error) {\n ended = true;\n inflightCount--;\n lastError = error;\n fulfillReadQueue();\n }\n reading = false;\n fillQueue();\n }\n async function mapAndQueue(itrValue) {\n try {\n const value = await func(itrValue);\n if (value && value[Symbol.asyncIterator]) {\n for await (const asyncVal of value) {\n resultQueue.push(asyncVal);\n }\n }\n else {\n resultQueue.push(value);\n }\n }\n catch (error) {\n ended = true;\n lastError = error;\n }\n inflightCount--;\n fulfillReadQueue();\n fillQueue();\n }\n async function next() {\n if (resultQueue.length === 0) {\n const deferred = defer();\n readQueue.push(deferred);\n fillQueue();\n return deferred.promise;\n }\n const value = resultQueue.shift();\n fillQueue();\n return { done: false, value };\n }\n const asyncIterableIterator = {\n next,\n [Symbol.asyncIterator]: () => asyncIterableIterator,\n };\n return asyncIterableIterator;\n}\nfunction flatTransform(concurrency, func, iterable) {\n if (func === undefined) {\n return (curriedFunc, curriedIterable) => curriedIterable\n ? flatTransform(concurrency, curriedFunc, curriedIterable)\n : flatTransform(concurrency, curriedFunc);\n }\n if (iterable === undefined) {\n return (curriedIterable) => flatTransform(concurrency, func, curriedIterable);\n }\n return filter(i => i !== undefined && i !== null, flatten(_flatTransform(concurrency, func, iterable)));\n}\n\nasync function onceReadable(stream) {\n return new Promise(resolve => {\n stream.once('readable', () => {\n resolve();\n });\n });\n}\nasync function* _fromStream(stream) {\n while (true) {\n const data = stream.read();\n if (data !== null) {\n yield data;\n continue;\n }\n if (stream._readableState.ended) {\n break;\n }\n await onceReadable(stream);\n }\n}\nfunction fromStream(stream) {\n if (typeof stream[Symbol.asyncIterator] === 'function') {\n return stream;\n }\n return _fromStream(stream);\n}\n\nasync function* merge(...iterables) {\n const sources = new Set(iterables.map(getIterator));\n while (sources.size > 0) {\n for (const iterator of sources) {\n const nextVal = await iterator.next();\n if (nextVal.done) {\n sources.delete(iterator);\n }\n else {\n yield nextVal.value;\n }\n }\n }\n}\n\nfunction pipeline(firstFn, ...fns) {\n let previousFn = firstFn();\n for (const func of fns) {\n previousFn = func(previousFn);\n }\n return previousFn;\n}\n\nasync function* _parallelMap(concurrency, func, iterable) {\n let transformError = null;\n const wrapFunc = value => ({\n value: func(value),\n });\n const stopOnError = async function* (source) {\n for await (const value of source) {\n if (transformError) {\n return;\n }\n yield value;\n }\n };\n const output = pipeline(() => iterable, buffer(1), stopOnError, map(wrapFunc), buffer(concurrency - 1));\n const itr = getIterator(output);\n while (true) {\n const { value, done } = await itr.next();\n if (done) {\n break;\n }\n try {\n const val = await value.value;\n if (!transformError) {\n yield val;\n }\n }\n catch (error) {\n transformError = error;\n }\n }\n if (transformError) {\n throw transformError;\n }\n}\nfunction parallelMap(concurrency, func, iterable) {\n if (func === undefined) {\n return (curriedFunc, curriedIterable) => parallelMap(concurrency, curriedFunc, curriedIterable);\n }\n if (iterable === undefined) {\n return curriedIterable => parallelMap(concurrency, func, curriedIterable);\n }\n if (concurrency === 1) {\n return map(func, iterable);\n }\n return _parallelMap(concurrency, func, iterable);\n}\n\nfunction parallelFlatMap(concurrency, func, iterable) {\n if (func === undefined) {\n return (curriedFunc, curriedIterable) => curriedIterable\n ? parallelFlatMap(concurrency, curriedFunc, curriedIterable)\n : parallelFlatMap(concurrency, curriedFunc);\n }\n if (iterable === undefined) {\n return (curriedIterable) => parallelFlatMap(concurrency, func, curriedIterable);\n }\n return filter(i => i !== undefined && i !== null, flatten(parallelMap(concurrency, func, iterable)));\n}\n\n/// <reference lib=\"esnext.asynciterable\" />\nasync function* parallelMerge(...iterables) {\n const inputs = iterables.map(getIterator);\n const concurrentWork = new Set();\n const values = new Map();\n let lastError = null;\n let errCb = null;\n let valueCb = null;\n const notifyError = err => {\n lastError = err;\n if (errCb) {\n errCb(err);\n }\n };\n const notifyDone = value => {\n if (valueCb) {\n valueCb(value);\n }\n };\n const waitForQueue = () => new Promise((resolve, reject) => {\n if (lastError) {\n reject(lastError);\n }\n if (values.size > 0) {\n return resolve();\n }\n valueCb = resolve;\n errCb = reject;\n });\n const queueNext = input => {\n const nextVal = Promise.resolve(input.next()).then(async ({ done, value }) => {\n if (!done) {\n values.set(input, value);\n }\n concurrentWork.delete(nextVal);\n });\n concurrentWork.add(nextVal);\n nextVal.then(notifyDone, notifyError);\n };\n for (const input of inputs) {\n queueNext(input);\n }\n while (true) {\n // We technically don't have to check `values.size` as the for loop should have emptied it\n // However I haven't yet found specs verifying that behavior, only tests\n // the guard in waitForQueue() checking for values is in place for the same reason\n if (concurrentWork.size === 0 && values.size === 0) {\n return;\n }\n await waitForQueue();\n for (const [input, value] of values) {\n values.delete(input);\n yield value;\n queueNext(input);\n }\n }\n}\n\nasync function _reduce(func, start, iterable) {\n let value = start;\n for await (const nextItem of iterable) {\n value = await func(value, nextItem);\n }\n return value;\n}\nfunction reduce(func, start, iterable) {\n if (start === undefined) {\n return (curriedStart, curriedIterable) => curriedIterable ? _reduce(func, curriedStart, curriedIterable) : reduce(func, curriedStart);\n }\n if (iterable === undefined) {\n return (curriedIterable) => reduce(func, start, curriedIterable);\n }\n return _reduce(func, start, iterable);\n}\n\nasync function* _take(count, iterable) {\n let taken = 0;\n for await (const val of iterable) {\n yield await val;\n taken++;\n if (taken >= count) {\n break;\n }\n }\n}\nfunction* _syncTake(count, iterable) {\n let taken = 0;\n for (const val of iterable) {\n yield val;\n taken++;\n if (taken >= count) {\n break;\n }\n }\n}\nfunction take(count, iterable) {\n if (iterable === undefined) {\n return curriedIterable => take(count, curriedIterable);\n }\n if (iterable[Symbol.asyncIterator]) {\n return _take(count, iterable);\n }\n return _syncTake(count, iterable);\n}\n\nasync function* _asyncTap(func, iterable) {\n for await (const val of iterable) {\n await func(val);\n yield val;\n }\n}\nfunction tap(func, iterable) {\n if (iterable === undefined) {\n return (curriedIterable) => _asyncTap(func, curriedIterable);\n }\n return _asyncTap(func, iterable);\n}\n\nfunction addTime(a, b) {\n let seconds = a[0] + b[0];\n let nanoseconds = a[1] + b[1];\n if (nanoseconds >= 1000000000) {\n const remainder = nanoseconds % 1000000000;\n seconds += (nanoseconds - remainder) / 1000000000;\n nanoseconds = remainder;\n }\n return [seconds, nanoseconds];\n}\nasync function* _asyncTime(config, iterable) {\n const itr = iterable[Symbol.asyncIterator]();\n let total = [0, 0];\n while (true) {\n const start = process.hrtime();\n const { value, done } = await itr.next();\n const delta = process.hrtime(start);\n total = addTime(total, delta);\n if (config.progress) {\n config.progress(delta, total);\n }\n if (done) {\n if (config.total) {\n config.total(total);\n }\n return value;\n }\n yield value;\n }\n}\nfunction* _syncTime(config, iterable) {\n const itr = iterable[Symbol.iterator]();\n let total = [0, 0];\n while (true) {\n const start = process.hrtime();\n const { value, done } = itr.next();\n const delta = process.hrtime(start);\n total = addTime(total, delta);\n if (config.progress) {\n config.progress(delta, total);\n }\n if (done) {\n if (config.total) {\n config.total(total);\n }\n return value;\n }\n yield value;\n }\n}\nfunction time(config = {}, iterable) {\n if (iterable === undefined) {\n return curriedIterable => time(config, curriedIterable);\n }\n if (iterable[Symbol.asyncIterator] !== undefined) {\n return _asyncTime(config, iterable);\n }\n else {\n return _syncTime(config, iterable);\n }\n}\n\nfunction _transform(concurrency, func, iterable) {\n const iterator = getIterator(iterable);\n const resultQueue = [];\n const readQueue = [];\n let ended = false;\n let reading = false;\n let inflightCount = 0;\n let lastError = null;\n function fulfillReadQueue() {\n while (readQueue.length > 0 && resultQueue.length > 0) {\n const { resolve } = readQueue.shift();\n const value = resultQueue.shift();\n resolve({ done: false, value });\n }\n while (readQueue.length > 0 && inflightCount === 0 && ended) {\n const { resolve, reject } = readQueue.shift();\n if (lastError) {\n reject(lastError);\n lastError = null;\n }\n else {\n resolve({ done: true, value: undefined });\n }\n }\n }\n async function fillQueue() {\n if (ended) {\n fulfillReadQueue();\n return;\n }\n if (reading) {\n return;\n }\n if (inflightCount + resultQueue.length >= concurrency) {\n return;\n }\n reading = true;\n inflightCount++;\n try {\n const { done, value } = await iterator.next();\n if (done) {\n ended = true;\n inflightCount--;\n fulfillReadQueue();\n }\n else {\n mapAndQueue(value);\n }\n }\n catch (error) {\n ended = true;\n inflightCount--;\n lastError = error;\n fulfillReadQueue();\n }\n reading = false;\n fillQueue();\n }\n async function mapAndQueue(itrValue) {\n try {\n const value = await func(itrValue);\n resultQueue.push(value);\n }\n catch (error) {\n ended = true;\n lastError = error;\n }\n inflightCount--;\n fulfillReadQueue();\n fillQueue();\n }\n async function next() {\n if (resultQueue.length === 0) {\n const deferred = defer();\n readQueue.push(deferred);\n fillQueue();\n return deferred.promise;\n }\n const value = resultQueue.shift();\n fillQueue();\n return { done: false, value };\n }\n const asyncIterableIterator = {\n next,\n [Symbol.asyncIterator]: () => asyncIterableIterator,\n };\n return asyncIterableIterator;\n}\nfunction transform(concurrency, func, iterable) {\n if (func === undefined) {\n return (curriedFunc, curriedIterable) => curriedIterable\n ? transform(concurrency, curriedFunc, curriedIterable)\n : transform(concurrency, curriedFunc);\n }\n if (iterable === undefined) {\n return (curriedIterable) => transform(concurrency, func, curriedIterable);\n }\n return _transform(concurrency, func, iterable);\n}\n\nasync function _writeToStream(stream, iterable) {\n let lastError = null;\n let errCb = null;\n let drainCb = null;\n const notifyError = err => {\n lastError = err;\n if (errCb) {\n errCb(err);\n }\n };\n const notifyDrain = () => {\n if (drainCb) {\n drainCb();\n }\n };\n const cleanup = () => {\n stream.removeListener('error', notifyError);\n stream.removeListener('drain', notifyDrain);\n };\n stream.once('error', notifyError);\n const waitForDrain = () => new Promise((resolve, reject) => {\n if (lastError) {\n return reject(lastError);\n }\n stream.once('drain', notifyDrain);\n drainCb = resolve;\n errCb = reject;\n });\n for await (const value of iterable) {\n if (stream.write(value) === false) {\n await waitForDrain();\n }\n if (lastError) {\n break;\n }\n }\n cleanup();\n if (lastError) {\n throw lastError;\n }\n}\nfunction writeToStream(stream, iterable) {\n if (iterable === undefined) {\n return (curriedIterable) => _writeToStream(stream, curriedIterable);\n }\n return _writeToStream(stream, iterable);\n}\n\nexport { batch, buffer, collect, concat, consume, filter, flatMap, flatTransform, flatten, fromStream, getIterator, map, merge, parallelFlatMap, parallelMap, parallelMerge, pipeline, reduce, take, tap, time, transform, writeToStream };\n","'use strict'\n\nconst { pipe } = require('it-pipe')\nconst lp = require('it-length-prefixed')\n\nconst Message = require('../message')\nconst handlers = require('./handlers')\nconst utils = require('../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\n/**\n * @param {import('../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc')\n const getMessageHandler = handlers(dht)\n\n /**\n * Process incoming DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function handleMessage (peerId, msg) {\n // get handler & execute it\n const handler = getMessageHandler(msg.type)\n\n try {\n await dht._add(peerId)\n } catch (err) {\n log.error('Failed to update the kbucket store', err)\n }\n\n if (!handler) {\n log.error(`no handler found for message type: ${msg.type}`)\n return\n }\n\n return handler(peerId, msg)\n }\n\n /**\n * Handle incoming streams on the dht protocol\n *\n * @param {object} props\n * @param {MuxedStream} props.stream\n * @param {import('libp2p-interfaces/src/connection').Connection} props.connection\n */\n async function onIncomingStream ({ stream, connection }) {\n const peerId = connection.remotePeer\n\n try {\n await dht._add(peerId)\n } catch (err) {\n log.error(err)\n }\n\n const idB58Str = peerId.toB58String()\n log('from: %s', idB58Str)\n\n await pipe(\n stream.source,\n lp.decode(),\n /**\n * @param {AsyncIterable<Uint8Array>} source\n */\n source => (async function * () {\n for await (const msg of source) {\n // handle the message\n const desMessage = Message.deserialize(msg.slice())\n const res = await handleMessage(peerId, desMessage)\n\n // Not all handlers will return a response\n if (res) {\n yield res.serialize()\n }\n }\n })(),\n lp.encode(),\n stream.sink\n )\n }\n\n return onIncomingStream\n}\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\nconst { Record } = require('libp2p-record')\nconst Proto = require('./dht')\n\nconst MESSAGE_TYPE = Proto.Message.MessageType\nconst CONNECTION_TYPE = Proto.Message.ConnectionType\n\n/**\n * @typedef {0|1|2|3|4} ConnectionType\n *\n * @typedef {object} PBPeer\n * @property {Uint8Array} id\n * @property {Uint8Array[]} addrs\n * @property {ConnectionType} connection\n *\n * @typedef {import('../index').PeerData} PeerData\n */\n\n/**\n * Represents a single DHT control message.\n */\nclass Message {\n /**\n * @param {import('./dht').Message.MessageType} type\n * @param {Uint8Array} key\n * @param {number} level\n */\n constructor (type, key, level) {\n if (key && !(key instanceof Uint8Array)) {\n throw new Error('Key must be a Uint8Array')\n }\n\n this.type = type\n this.key = key\n this._clusterLevelRaw = level\n\n /** @type {PeerData[]} */\n this.closerPeers = []\n /** @type {PeerData[]} */\n this.providerPeers = []\n /** @type {import('libp2p-record').Record | undefined} */\n this.record = undefined\n }\n\n /**\n * @type {number}\n */\n get clusterLevel () {\n const level = this._clusterLevelRaw - 1\n if (level < 0) {\n return 0\n }\n\n return level\n }\n\n set clusterLevel (level) {\n this._clusterLevelRaw = level\n }\n\n /**\n * Encode into protobuf\n */\n serialize () {\n const obj = {\n key: this.key,\n type: this.type,\n clusterLevelRaw: this._clusterLevelRaw,\n closerPeers: this.closerPeers.map(toPbPeer),\n providerPeers: this.providerPeers.map(toPbPeer),\n\n /** @type {Uint8Array | undefined} */\n record: undefined\n }\n\n if (this.record) {\n if (this.record instanceof Uint8Array) {\n obj.record = this.record\n } else {\n obj.record = this.record.serialize()\n }\n }\n\n return Proto.Message.encode(obj).finish()\n }\n\n /**\n * Decode from protobuf\n *\n * @param {Uint8Array} raw\n */\n static deserialize (raw) {\n const dec = Proto.Message.decode(raw)\n\n const msg = new Message(dec.type || 0, dec.key || Uint8Array.from([]), dec.clusterLevelRaw || 0)\n\n msg.closerPeers = dec.closerPeers.map(fromPbPeer)\n msg.providerPeers = dec.providerPeers.map(fromPbPeer)\n\n if (dec.record && dec.record.length) {\n msg.record = Record.deserialize(dec.record)\n }\n\n return msg\n }\n}\n\nMessage.TYPES = MESSAGE_TYPE\nMessage.CONNECTION_TYPES = CONNECTION_TYPE\n\n/**\n * @param {PeerData} peer\n */\nfunction toPbPeer (peer) {\n /** @type {PBPeer} */\n const output = {\n id: peer.id.id,\n addrs: (peer.multiaddrs || []).map((m) => m.bytes),\n connection: CONNECTION_TYPE.CONNECTED\n }\n\n return output\n}\n\n/**\n * @param {import('./dht').Message.IPeer} peer\n */\nfunction fromPbPeer (peer) {\n return {\n // @ts-ignore id is optional on protobuf, but it will exist?\n id: new PeerId(peer.id),\n multiaddrs: (peer.addrs || []).map((a) => new Multiaddr(a))\n }\n}\n\nmodule.exports = Message\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-dht-message\"] || ($protobuf.roots[\"libp2p-dht-message\"] = {});\n\n$root.Record = (function() {\n\n /**\n * Properties of a Record.\n * @exports IRecord\n * @interface IRecord\n * @property {Uint8Array|null} [key] Record key\n * @property {Uint8Array|null} [value] Record value\n * @property {Uint8Array|null} [author] Record author\n * @property {Uint8Array|null} [signature] Record signature\n * @property {string|null} [timeReceived] Record timeReceived\n */\n\n /**\n * Constructs a new Record.\n * @exports Record\n * @classdesc Represents a Record.\n * @implements IRecord\n * @constructor\n * @param {IRecord=} [p] Properties to set\n */\n function Record(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Record key.\n * @member {Uint8Array|null|undefined} key\n * @memberof Record\n * @instance\n */\n Record.prototype.key = null;\n\n /**\n * Record value.\n * @member {Uint8Array|null|undefined} value\n * @memberof Record\n * @instance\n */\n Record.prototype.value = null;\n\n /**\n * Record author.\n * @member {Uint8Array|null|undefined} author\n * @memberof Record\n * @instance\n */\n Record.prototype.author = null;\n\n /**\n * Record signature.\n * @member {Uint8Array|null|undefined} signature\n * @memberof Record\n * @instance\n */\n Record.prototype.signature = null;\n\n /**\n * Record timeReceived.\n * @member {string|null|undefined} timeReceived\n * @memberof Record\n * @instance\n */\n Record.prototype.timeReceived = null;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * Record _key.\n * @member {\"key\"|undefined} _key\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_key\", {\n get: $util.oneOfGetter($oneOfFields = [\"key\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Record _value.\n * @member {\"value\"|undefined} _value\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_value\", {\n get: $util.oneOfGetter($oneOfFields = [\"value\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Record _author.\n * @member {\"author\"|undefined} _author\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_author\", {\n get: $util.oneOfGetter($oneOfFields = [\"author\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Record _signature.\n * @member {\"signature\"|undefined} _signature\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_signature\", {\n get: $util.oneOfGetter($oneOfFields = [\"signature\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Record _timeReceived.\n * @member {\"timeReceived\"|undefined} _timeReceived\n * @memberof Record\n * @instance\n */\n Object.defineProperty(Record.prototype, \"_timeReceived\", {\n get: $util.oneOfGetter($oneOfFields = [\"timeReceived\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified Record message. Does not implicitly {@link Record.verify|verify} messages.\n * @function encode\n * @memberof Record\n * @static\n * @param {IRecord} m Record message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Record.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(10).bytes(m.key);\n if (m.value != null && Object.hasOwnProperty.call(m, \"value\"))\n w.uint32(18).bytes(m.value);\n if (m.author != null && Object.hasOwnProperty.call(m, \"author\"))\n w.uint32(26).bytes(m.author);\n if (m.signature != null && Object.hasOwnProperty.call(m, \"signature\"))\n w.uint32(34).bytes(m.signature);\n if (m.timeReceived != null && Object.hasOwnProperty.call(m, \"timeReceived\"))\n w.uint32(42).string(m.timeReceived);\n return w;\n };\n\n /**\n * Decodes a Record message from the specified reader or buffer.\n * @function decode\n * @memberof Record\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Record} Record\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Record.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Record();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.key = r.bytes();\n break;\n case 2:\n m.value = r.bytes();\n break;\n case 3:\n m.author = r.bytes();\n break;\n case 4:\n m.signature = r.bytes();\n break;\n case 5:\n m.timeReceived = r.string();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Record message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Record\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Record} Record\n */\n Record.fromObject = function fromObject(d) {\n if (d instanceof $root.Record)\n return d;\n var m = new $root.Record();\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n if (d.value != null) {\n if (typeof d.value === \"string\")\n $util.base64.decode(d.value, m.value = $util.newBuffer($util.base64.length(d.value)), 0);\n else if (d.value.length)\n m.value = d.value;\n }\n if (d.author != null) {\n if (typeof d.author === \"string\")\n $util.base64.decode(d.author, m.author = $util.newBuffer($util.base64.length(d.author)), 0);\n else if (d.author.length)\n m.author = d.author;\n }\n if (d.signature != null) {\n if (typeof d.signature === \"string\")\n $util.base64.decode(d.signature, m.signature = $util.newBuffer($util.base64.length(d.signature)), 0);\n else if (d.signature.length)\n m.signature = d.signature;\n }\n if (d.timeReceived != null) {\n m.timeReceived = String(d.timeReceived);\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Record message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Record\n * @static\n * @param {Record} m Record\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Record.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n if (o.oneofs)\n d._key = \"key\";\n }\n if (m.value != null && m.hasOwnProperty(\"value\")) {\n d.value = o.bytes === String ? $util.base64.encode(m.value, 0, m.value.length) : o.bytes === Array ? Array.prototype.slice.call(m.value) : m.value;\n if (o.oneofs)\n d._value = \"value\";\n }\n if (m.author != null && m.hasOwnProperty(\"author\")) {\n d.author = o.bytes === String ? $util.base64.encode(m.author, 0, m.author.length) : o.bytes === Array ? Array.prototype.slice.call(m.author) : m.author;\n if (o.oneofs)\n d._author = \"author\";\n }\n if (m.signature != null && m.hasOwnProperty(\"signature\")) {\n d.signature = o.bytes === String ? $util.base64.encode(m.signature, 0, m.signature.length) : o.bytes === Array ? Array.prototype.slice.call(m.signature) : m.signature;\n if (o.oneofs)\n d._signature = \"signature\";\n }\n if (m.timeReceived != null && m.hasOwnProperty(\"timeReceived\")) {\n d.timeReceived = m.timeReceived;\n if (o.oneofs)\n d._timeReceived = \"timeReceived\";\n }\n return d;\n };\n\n /**\n * Converts this Record to JSON.\n * @function toJSON\n * @memberof Record\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Record.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Record;\n})();\n\n$root.Message = (function() {\n\n /**\n * Properties of a Message.\n * @exports IMessage\n * @interface IMessage\n * @property {Message.MessageType|null} [type] Message type\n * @property {number|null} [clusterLevelRaw] Message clusterLevelRaw\n * @property {Uint8Array|null} [key] Message key\n * @property {Uint8Array|null} [record] Message record\n * @property {Array.<Message.IPeer>|null} [closerPeers] Message closerPeers\n * @property {Array.<Message.IPeer>|null} [providerPeers] Message providerPeers\n */\n\n /**\n * Constructs a new Message.\n * @exports Message\n * @classdesc Represents a Message.\n * @implements IMessage\n * @constructor\n * @param {IMessage=} [p] Properties to set\n */\n function Message(p) {\n this.closerPeers = [];\n this.providerPeers = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Message type.\n * @member {Message.MessageType|null|undefined} type\n * @memberof Message\n * @instance\n */\n Message.prototype.type = null;\n\n /**\n * Message clusterLevelRaw.\n * @member {number|null|undefined} clusterLevelRaw\n * @memberof Message\n * @instance\n */\n Message.prototype.clusterLevelRaw = null;\n\n /**\n * Message key.\n * @member {Uint8Array|null|undefined} key\n * @memberof Message\n * @instance\n */\n Message.prototype.key = null;\n\n /**\n * Message record.\n * @member {Uint8Array|null|undefined} record\n * @memberof Message\n * @instance\n */\n Message.prototype.record = null;\n\n /**\n * Message closerPeers.\n * @member {Array.<Message.IPeer>} closerPeers\n * @memberof Message\n * @instance\n */\n Message.prototype.closerPeers = $util.emptyArray;\n\n /**\n * Message providerPeers.\n * @member {Array.<Message.IPeer>} providerPeers\n * @memberof Message\n * @instance\n */\n Message.prototype.providerPeers = $util.emptyArray;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * Message _type.\n * @member {\"type\"|undefined} _type\n * @memberof Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_type\", {\n get: $util.oneOfGetter($oneOfFields = [\"type\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _clusterLevelRaw.\n * @member {\"clusterLevelRaw\"|undefined} _clusterLevelRaw\n * @memberof Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_clusterLevelRaw\", {\n get: $util.oneOfGetter($oneOfFields = [\"clusterLevelRaw\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _key.\n * @member {\"key\"|undefined} _key\n * @memberof Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_key\", {\n get: $util.oneOfGetter($oneOfFields = [\"key\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Message _record.\n * @member {\"record\"|undefined} _record\n * @memberof Message\n * @instance\n */\n Object.defineProperty(Message.prototype, \"_record\", {\n get: $util.oneOfGetter($oneOfFields = [\"record\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified Message message. Does not implicitly {@link Message.verify|verify} messages.\n * @function encode\n * @memberof Message\n * @static\n * @param {IMessage} m Message message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Message.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.type != null && Object.hasOwnProperty.call(m, \"type\"))\n w.uint32(8).int32(m.type);\n if (m.key != null && Object.hasOwnProperty.call(m, \"key\"))\n w.uint32(18).bytes(m.key);\n if (m.record != null && Object.hasOwnProperty.call(m, \"record\"))\n w.uint32(26).bytes(m.record);\n if (m.closerPeers != null && m.closerPeers.length) {\n for (var i = 0; i < m.closerPeers.length; ++i)\n $root.Message.Peer.encode(m.closerPeers[i], w.uint32(66).fork()).ldelim();\n }\n if (m.providerPeers != null && m.providerPeers.length) {\n for (var i = 0; i < m.providerPeers.length; ++i)\n $root.Message.Peer.encode(m.providerPeers[i], w.uint32(74).fork()).ldelim();\n }\n if (m.clusterLevelRaw != null && Object.hasOwnProperty.call(m, \"clusterLevelRaw\"))\n w.uint32(80).int32(m.clusterLevelRaw);\n return w;\n };\n\n /**\n * Decodes a Message message from the specified reader or buffer.\n * @function decode\n * @memberof Message\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Message} Message\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Message.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.type = r.int32();\n break;\n case 10:\n m.clusterLevelRaw = r.int32();\n break;\n case 2:\n m.key = r.bytes();\n break;\n case 3:\n m.record = r.bytes();\n break;\n case 8:\n if (!(m.closerPeers && m.closerPeers.length))\n m.closerPeers = [];\n m.closerPeers.push($root.Message.Peer.decode(r, r.uint32()));\n break;\n case 9:\n if (!(m.providerPeers && m.providerPeers.length))\n m.providerPeers = [];\n m.providerPeers.push($root.Message.Peer.decode(r, r.uint32()));\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Message message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Message\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Message} Message\n */\n Message.fromObject = function fromObject(d) {\n if (d instanceof $root.Message)\n return d;\n var m = new $root.Message();\n switch (d.type) {\n case \"PUT_VALUE\":\n case 0:\n m.type = 0;\n break;\n case \"GET_VALUE\":\n case 1:\n m.type = 1;\n break;\n case \"ADD_PROVIDER\":\n case 2:\n m.type = 2;\n break;\n case \"GET_PROVIDERS\":\n case 3:\n m.type = 3;\n break;\n case \"FIND_NODE\":\n case 4:\n m.type = 4;\n break;\n case \"PING\":\n case 5:\n m.type = 5;\n break;\n }\n if (d.clusterLevelRaw != null) {\n m.clusterLevelRaw = d.clusterLevelRaw | 0;\n }\n if (d.key != null) {\n if (typeof d.key === \"string\")\n $util.base64.decode(d.key, m.key = $util.newBuffer($util.base64.length(d.key)), 0);\n else if (d.key.length)\n m.key = d.key;\n }\n if (d.record != null) {\n if (typeof d.record === \"string\")\n $util.base64.decode(d.record, m.record = $util.newBuffer($util.base64.length(d.record)), 0);\n else if (d.record.length)\n m.record = d.record;\n }\n if (d.closerPeers) {\n if (!Array.isArray(d.closerPeers))\n throw TypeError(\".Message.closerPeers: array expected\");\n m.closerPeers = [];\n for (var i = 0; i < d.closerPeers.length; ++i) {\n if (typeof d.closerPeers[i] !== \"object\")\n throw TypeError(\".Message.closerPeers: object expected\");\n m.closerPeers[i] = $root.Message.Peer.fromObject(d.closerPeers[i]);\n }\n }\n if (d.providerPeers) {\n if (!Array.isArray(d.providerPeers))\n throw TypeError(\".Message.providerPeers: array expected\");\n m.providerPeers = [];\n for (var i = 0; i < d.providerPeers.length; ++i) {\n if (typeof d.providerPeers[i] !== \"object\")\n throw TypeError(\".Message.providerPeers: object expected\");\n m.providerPeers[i] = $root.Message.Peer.fromObject(d.providerPeers[i]);\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Message message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Message\n * @static\n * @param {Message} m Message\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Message.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.closerPeers = [];\n d.providerPeers = [];\n }\n if (m.type != null && m.hasOwnProperty(\"type\")) {\n d.type = o.enums === String ? $root.Message.MessageType[m.type] : m.type;\n if (o.oneofs)\n d._type = \"type\";\n }\n if (m.key != null && m.hasOwnProperty(\"key\")) {\n d.key = o.bytes === String ? $util.base64.encode(m.key, 0, m.key.length) : o.bytes === Array ? Array.prototype.slice.call(m.key) : m.key;\n if (o.oneofs)\n d._key = \"key\";\n }\n if (m.record != null && m.hasOwnProperty(\"record\")) {\n d.record = o.bytes === String ? $util.base64.encode(m.record, 0, m.record.length) : o.bytes === Array ? Array.prototype.slice.call(m.record) : m.record;\n if (o.oneofs)\n d._record = \"record\";\n }\n if (m.closerPeers && m.closerPeers.length) {\n d.closerPeers = [];\n for (var j = 0; j < m.closerPeers.length; ++j) {\n d.closerPeers[j] = $root.Message.Peer.toObject(m.closerPeers[j], o);\n }\n }\n if (m.providerPeers && m.providerPeers.length) {\n d.providerPeers = [];\n for (var j = 0; j < m.providerPeers.length; ++j) {\n d.providerPeers[j] = $root.Message.Peer.toObject(m.providerPeers[j], o);\n }\n }\n if (m.clusterLevelRaw != null && m.hasOwnProperty(\"clusterLevelRaw\")) {\n d.clusterLevelRaw = m.clusterLevelRaw;\n if (o.oneofs)\n d._clusterLevelRaw = \"clusterLevelRaw\";\n }\n return d;\n };\n\n /**\n * Converts this Message to JSON.\n * @function toJSON\n * @memberof Message\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Message.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n /**\n * MessageType enum.\n * @name Message.MessageType\n * @enum {number}\n * @property {number} PUT_VALUE=0 PUT_VALUE value\n * @property {number} GET_VALUE=1 GET_VALUE value\n * @property {number} ADD_PROVIDER=2 ADD_PROVIDER value\n * @property {number} GET_PROVIDERS=3 GET_PROVIDERS value\n * @property {number} FIND_NODE=4 FIND_NODE value\n * @property {number} PING=5 PING value\n */\n Message.MessageType = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = \"PUT_VALUE\"] = 0;\n values[valuesById[1] = \"GET_VALUE\"] = 1;\n values[valuesById[2] = \"ADD_PROVIDER\"] = 2;\n values[valuesById[3] = \"GET_PROVIDERS\"] = 3;\n values[valuesById[4] = \"FIND_NODE\"] = 4;\n values[valuesById[5] = \"PING\"] = 5;\n return values;\n })();\n\n /**\n * ConnectionType enum.\n * @name Message.ConnectionType\n * @enum {number}\n * @property {number} NOT_CONNECTED=0 NOT_CONNECTED value\n * @property {number} CONNECTED=1 CONNECTED value\n * @property {number} CAN_CONNECT=2 CAN_CONNECT value\n * @property {number} CANNOT_CONNECT=3 CANNOT_CONNECT value\n */\n Message.ConnectionType = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = \"NOT_CONNECTED\"] = 0;\n values[valuesById[1] = \"CONNECTED\"] = 1;\n values[valuesById[2] = \"CAN_CONNECT\"] = 2;\n values[valuesById[3] = \"CANNOT_CONNECT\"] = 3;\n return values;\n })();\n\n Message.Peer = (function() {\n\n /**\n * Properties of a Peer.\n * @memberof Message\n * @interface IPeer\n * @property {Uint8Array|null} [id] Peer id\n * @property {Array.<Uint8Array>|null} [addrs] Peer addrs\n * @property {Message.ConnectionType|null} [connection] Peer connection\n */\n\n /**\n * Constructs a new Peer.\n * @memberof Message\n * @classdesc Represents a Peer.\n * @implements IPeer\n * @constructor\n * @param {Message.IPeer=} [p] Properties to set\n */\n function Peer(p) {\n this.addrs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Peer id.\n * @member {Uint8Array|null|undefined} id\n * @memberof Message.Peer\n * @instance\n */\n Peer.prototype.id = null;\n\n /**\n * Peer addrs.\n * @member {Array.<Uint8Array>} addrs\n * @memberof Message.Peer\n * @instance\n */\n Peer.prototype.addrs = $util.emptyArray;\n\n /**\n * Peer connection.\n * @member {Message.ConnectionType|null|undefined} connection\n * @memberof Message.Peer\n * @instance\n */\n Peer.prototype.connection = null;\n\n // OneOf field names bound to virtual getters and setters\n var $oneOfFields;\n\n /**\n * Peer _id.\n * @member {\"id\"|undefined} _id\n * @memberof Message.Peer\n * @instance\n */\n Object.defineProperty(Peer.prototype, \"_id\", {\n get: $util.oneOfGetter($oneOfFields = [\"id\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Peer _connection.\n * @member {\"connection\"|undefined} _connection\n * @memberof Message.Peer\n * @instance\n */\n Object.defineProperty(Peer.prototype, \"_connection\", {\n get: $util.oneOfGetter($oneOfFields = [\"connection\"]),\n set: $util.oneOfSetter($oneOfFields)\n });\n\n /**\n * Encodes the specified Peer message. Does not implicitly {@link Message.Peer.verify|verify} messages.\n * @function encode\n * @memberof Message.Peer\n * @static\n * @param {Message.IPeer} m Peer message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Peer.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.id != null && Object.hasOwnProperty.call(m, \"id\"))\n w.uint32(10).bytes(m.id);\n if (m.addrs != null && m.addrs.length) {\n for (var i = 0; i < m.addrs.length; ++i)\n w.uint32(18).bytes(m.addrs[i]);\n }\n if (m.connection != null && Object.hasOwnProperty.call(m, \"connection\"))\n w.uint32(24).int32(m.connection);\n return w;\n };\n\n /**\n * Decodes a Peer message from the specified reader or buffer.\n * @function decode\n * @memberof Message.Peer\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Message.Peer} Peer\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Peer.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.Peer();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.id = r.bytes();\n break;\n case 2:\n if (!(m.addrs && m.addrs.length))\n m.addrs = [];\n m.addrs.push(r.bytes());\n break;\n case 3:\n m.connection = r.int32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Peer message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Message.Peer\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Message.Peer} Peer\n */\n Peer.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.Peer)\n return d;\n var m = new $root.Message.Peer();\n if (d.id != null) {\n if (typeof d.id === \"string\")\n $util.base64.decode(d.id, m.id = $util.newBuffer($util.base64.length(d.id)), 0);\n else if (d.id.length)\n m.id = d.id;\n }\n if (d.addrs) {\n if (!Array.isArray(d.addrs))\n throw TypeError(\".Message.Peer.addrs: array expected\");\n m.addrs = [];\n for (var i = 0; i < d.addrs.length; ++i) {\n if (typeof d.addrs[i] === \"string\")\n $util.base64.decode(d.addrs[i], m.addrs[i] = $util.newBuffer($util.base64.length(d.addrs[i])), 0);\n else if (d.addrs[i].length)\n m.addrs[i] = d.addrs[i];\n }\n }\n switch (d.connection) {\n case \"NOT_CONNECTED\":\n case 0:\n m.connection = 0;\n break;\n case \"CONNECTED\":\n case 1:\n m.connection = 1;\n break;\n case \"CAN_CONNECT\":\n case 2:\n m.connection = 2;\n break;\n case \"CANNOT_CONNECT\":\n case 3:\n m.connection = 3;\n break;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Peer message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Message.Peer\n * @static\n * @param {Message.Peer} m Peer\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Peer.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.addrs = [];\n }\n if (m.id != null && m.hasOwnProperty(\"id\")) {\n d.id = o.bytes === String ? $util.base64.encode(m.id, 0, m.id.length) : o.bytes === Array ? Array.prototype.slice.call(m.id) : m.id;\n if (o.oneofs)\n d._id = \"id\";\n }\n if (m.addrs && m.addrs.length) {\n d.addrs = [];\n for (var j = 0; j < m.addrs.length; ++j) {\n d.addrs[j] = o.bytes === String ? $util.base64.encode(m.addrs[j], 0, m.addrs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.addrs[j]) : m.addrs[j];\n }\n }\n if (m.connection != null && m.hasOwnProperty(\"connection\")) {\n d.connection = o.enums === String ? $root.Message.ConnectionType[m.connection] : m.connection;\n if (o.oneofs)\n d._connection = \"connection\";\n }\n return d;\n };\n\n /**\n * Converts this Peer to JSON.\n * @function toJSON\n * @memberof Message.Peer\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Peer.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Peer;\n })();\n\n return Message;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst T = require('../../message').TYPES\n\n/**\n *\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const handlers = {\n [T.GET_VALUE]: require('./get-value')(dht),\n [T.PUT_VALUE]: require('./put-value')(dht),\n [T.FIND_NODE]: require('./find-node')(dht),\n [T.ADD_PROVIDER]: require('./add-provider')(dht),\n [T.GET_PROVIDERS]: require('./get-providers')(dht),\n [T.PING]: require('./ping')(dht)\n }\n\n /**\n * Get the message handler matching the passed in type.\n *\n * @param {number} type\n */\n function getMessageHandler (type) {\n // @ts-ignore ts does not aknowledge number as an index type\n return handlers[type]\n }\n\n return getMessageHandler\n}\n","'use strict'\n\nconst { Record } = require('libp2p-record')\n\nconst errcode = require('err-code')\n\nconst Message = require('../../message')\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:get-value')\n\n /**\n * Process `GetValue` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n * @returns {Promise<Message>}\n */\n async function getValue (peerId, msg) {\n const key = msg.key\n\n log('key: %b', key)\n\n if (!key || key.length === 0) {\n throw errcode(new Error('Invalid key'), 'ERR_INVALID_KEY')\n }\n\n const response = new Message(Message.TYPES.GET_VALUE, key, msg.clusterLevel)\n\n if (utils.isPublicKeyKey(key)) {\n log('is public key')\n const idFromKey = utils.fromPublicKeyKey(key)\n let id\n\n if (dht._isSelf(idFromKey)) {\n id = dht.peerId\n } else {\n const peerData = dht.peerStore.get(idFromKey)\n id = peerData && peerData.id\n }\n\n if (id && id.pubKey) {\n log('returning found public key')\n response.record = new Record(key, id.pubKey.bytes)\n return response\n }\n }\n\n const [record, closer] = await Promise.all([\n dht._checkLocalDatastore(key),\n dht._betterPeersToQuery(msg, peerId)\n ])\n\n if (record) {\n log('got record')\n response.record = record\n }\n\n if (closer.length > 0) {\n log('got closer %s', closer.length)\n response.closerPeers = closer\n }\n\n return response\n }\n\n return getValue\n}\n","'use strict'\n\nconst utils = require('../../utils')\nconst errcode = require('err-code')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../../message')} Message\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:put-value')\n\n /**\n * Process `PutValue` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function putValue (peerId, msg) {\n const key = msg.key\n log('key: %b', key)\n\n const record = msg.record\n\n if (!record) {\n const errMsg = `Empty record from: ${peerId.toB58String()}`\n\n log.error(errMsg)\n throw errcode(new Error(errMsg), 'ERR_EMPTY_RECORD')\n }\n\n await dht._verifyRecordLocally(record)\n\n record.timeReceived = new Date()\n const recordKey = utils.bufferToKey(record.key)\n await dht.datastore.put(recordKey, record.serialize())\n\n dht.onPut(record, peerId)\n\n return msg\n }\n\n return putValue\n}\n","'use strict'\n\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\nconst Message = require('../../message')\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:find-node')\n\n /**\n * Process `FindNode` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function findNode (peerId, msg) {\n log('start')\n\n let closer\n if (uint8ArrayEquals(msg.key, dht.peerId.id)) {\n closer = [{\n id: dht.peerId,\n multiaddrs: dht.libp2p.multiaddrs\n }]\n } else {\n closer = await dht._betterPeersToQuery(msg, peerId)\n }\n\n const response = new Message(msg.type, new Uint8Array(0), msg.clusterLevel)\n\n if (closer.length > 0) {\n response.closerPeers = closer\n } else {\n log('handle FindNode %s: could not find anything', peerId.toB58String())\n }\n\n return response\n }\n\n return findNode\n}\n","'use strict'\n\nconst { CID } = require('multiformats/cid')\nconst errcode = require('err-code')\n\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../../message')} Message\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:add-provider')\n /**\n * Process `AddProvider` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function addProvider (peerId, msg) { // eslint-disable-line require-await\n log('start')\n\n if (!msg.key || msg.key.length === 0) {\n throw errcode(new Error('Missing key'), 'ERR_MISSING_KEY')\n }\n\n /** @type {CID} */\n let cid\n try {\n cid = CID.decode(msg.key)\n } catch (err) {\n const errMsg = `Invalid CID: ${err.message}`\n throw errcode(new Error(errMsg), 'ERR_INVALID_CID')\n }\n\n msg.providerPeers.forEach((pi) => {\n // Ignore providers not from the originator\n if (!pi.id.isEqual(peerId)) {\n log('invalid provider peer %s from %s', pi.id.toB58String(), peerId.toB58String())\n return\n }\n\n if (pi.multiaddrs.length < 1) {\n log('no valid addresses for provider %s. Ignore', peerId.toB58String())\n return\n }\n\n log('received provider %s for %s (addrs %s)', peerId.toB58String(), cid.toString(), pi.multiaddrs.map((m) => m.toString()))\n\n if (!dht._isSelf(pi.id)) {\n // Add known address to peer store\n dht.peerStore.addressBook.add(pi.id, pi.multiaddrs)\n return dht.providers.addProvider(cid, pi.id)\n }\n })\n\n // Previous versions of the JS DHT sent erroneous providers in the\n // `providerPeers` field. In order to accommodate older clients that have\n // this bug, we fall back to assuming the originator is the provider if\n // we can't find any valid providers in the payload.\n // https://github.com/libp2p/js-libp2p-kad-dht/pull/127\n // https://github.com/libp2p/js-libp2p-kad-dht/issues/128\n return dht.providers.addProvider(cid, peerId)\n }\n\n return addProvider\n}\n","'use strict'\n\nconst { CID } = require('multiformats/cid')\nconst errcode = require('err-code')\n\nconst Message = require('../../message')\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:get-providers')\n\n /**\n * Process `GetProviders` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n async function getProviders (peerId, msg) {\n let cid\n try {\n cid = CID.decode(msg.key)\n } catch (err) {\n throw errcode(new Error(`Invalid CID: ${err.message}`), 'ERR_INVALID_CID')\n }\n\n log('%s', cid.toString())\n const dsKey = utils.bufferToKey(cid.bytes)\n\n const [has, peers, closer] = await Promise.all([\n dht.datastore.has(dsKey),\n dht.providers.getProviders(cid),\n dht._betterPeersToQuery(msg, peerId)\n ])\n\n const providerPeers = peers.map((peerId) => ({\n id: peerId,\n multiaddrs: []\n }))\n const closerPeers = closer.map((c) => ({\n id: c.id,\n multiaddrs: []\n }))\n\n if (has) {\n providerPeers.push({\n id: dht.peerId,\n multiaddrs: []\n })\n }\n\n const response = new Message(msg.type, msg.key, msg.clusterLevel)\n\n if (providerPeers.length > 0) {\n response.providerPeers = providerPeers\n }\n\n if (closerPeers.length > 0) {\n response.closerPeers = closerPeers\n }\n\n log('got %s providers %s closerPeers', providerPeers.length, closerPeers.length)\n return response\n }\n\n return getProviders\n}\n","'use strict'\n\nconst utils = require('../../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../../message')} Message\n */\n\n/**\n * @param {import('../../index')} dht\n */\nmodule.exports = (dht) => {\n const log = utils.logger(dht.peerId, 'rpc:ping')\n\n /**\n * Process `Ping` DHT messages.\n *\n * @param {PeerId} peerId\n * @param {Message} msg\n */\n function ping (peerId, msg) {\n log('from %s', peerId.toB58String())\n return msg\n }\n\n return ping\n}\n","'use strict'\n\nconst errcode = require('err-code')\nconst pTimeout = require('p-timeout')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst libp2pRecord = require('libp2p-record')\nconst c = require('../constants')\nconst Query = require('../query')\nconst utils = require('../utils')\nconst Record = libp2pRecord.Record\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../query').DHTQueryResult} DHTQueryResult\n */\n\n/**\n * @param {import('../')} dht\n */\nmodule.exports = (dht) => {\n /**\n * @param {Uint8Array} key\n * @param {Uint8Array} rec\n */\n const putLocal = async (key, rec) => { // eslint-disable-line require-await\n return dht.datastore.put(utils.bufferToKey(key), rec)\n }\n\n /**\n * Attempt to retrieve the value for the given key from\n * the local datastore.\n *\n * @param {Uint8Array} key\n */\n const getLocal = async (key) => {\n dht._log(`getLocal ${uint8ArrayToString(key, 'base32')}`)\n\n const raw = await dht.datastore.get(utils.bufferToKey(key))\n dht._log(`found ${uint8ArrayToString(key, 'base32')} in local datastore`)\n\n const rec = Record.deserialize(raw)\n\n await dht._verifyRecordLocally(rec)\n\n return rec\n }\n\n /**\n * Send the best record found to any peers that have an out of date record.\n *\n * @param {Uint8Array} key\n * @param {import('../query').DHTQueryValue[]} vals - values retrieved from the DHT\n * @param {Uint8Array} best - the best record that was found\n */\n const sendCorrectionRecord = async (key, vals, best) => {\n const fixupRec = await utils.createPutRecord(key, best)\n\n return Promise.all(vals.map(async (v) => {\n // no need to do anything\n if (uint8ArrayEquals(v.val, best)) {\n return\n }\n\n // correct ourself\n if (dht._isSelf(v.from)) {\n try {\n await dht._putLocal(key, fixupRec)\n } catch (err) {\n dht._log.error('Failed error correcting self', err)\n }\n return\n }\n\n // send correction\n try {\n await dht._putValueToPeer(key, fixupRec, v.from)\n } catch (err) {\n dht._log.error('Failed error correcting entry', err)\n }\n }))\n }\n\n return {\n /**\n * Store the given key/value pair locally, in the datastore.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} rec - encoded record\n */\n async _putLocal (key, rec) { // eslint-disable-line require-await\n return putLocal(key, rec)\n },\n\n /**\n * Store the given key/value pair in the DHT.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n * @param {object} [options] - put options\n * @param {number} [options.minPeers] - minimum number of peers required to successfully put (default: closestPeers.length)\n */\n async put (key, value, options = {}) {\n dht._log('PutValue %b', key)\n\n // create record in the dht format\n const record = await utils.createPutRecord(key, value)\n\n // store the record locally\n await putLocal(key, record)\n\n // put record to the closest peers\n let counterAll = 0\n let counterSuccess = 0\n\n await utils.mapParallel(dht.getClosestPeers(key, { shallow: true }), async (peer) => {\n try {\n counterAll += 1\n await dht._putValueToPeer(key, record, peer)\n counterSuccess += 1\n } catch (err) {\n dht._log.error('Failed to put to peer (%b): %s', peer.id, err)\n }\n })\n\n // verify if we were able to put to enough peers\n const minPeers = options.minPeers || counterAll // Ensure we have a default `minPeers`\n\n if (minPeers > counterSuccess) {\n const error = errcode(new Error(`Failed to put value to enough peers: ${counterSuccess}/${minPeers}`), 'ERR_NOT_ENOUGH_PUT_PEERS')\n dht._log.error(error)\n throw error\n }\n },\n\n /**\n * Get the value to the given key.\n * Times out after 1 minute by default.\n *\n * @param {Uint8Array} key\n * @param {object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n */\n async get (key, options = {}) {\n options.timeout = options.timeout || c.minute\n\n dht._log('_get %b', key)\n\n const vals = await dht.getMany(key, c.GET_MANY_RECORD_COUNT, options)\n const recs = vals.map((v) => v.val)\n let i = 0\n\n try {\n i = libp2pRecord.selection.bestRecord(dht.selectors, key, recs)\n } catch (err) {\n // Assume the first record if no selector available\n if (err.code !== 'ERR_NO_SELECTOR_FUNCTION_FOR_RECORD_KEY') {\n throw err\n }\n }\n\n const best = recs[i]\n dht._log('GetValue %b %s', key, best)\n\n if (!best) {\n throw errcode(new Error('best value was not found'), 'ERR_NOT_FOUND')\n }\n\n await sendCorrectionRecord(key, vals, best)\n\n return best\n },\n\n /**\n * Get the `n` values to the given key without sorting.\n *\n * @param {Uint8Array} key\n * @param {number} nvals\n * @param {object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n */\n async getMany (key, nvals, options = {}) {\n options.timeout = options.timeout || c.minute\n\n dht._log('getMany %b (%s)', key, nvals)\n\n const vals = []\n let localRec\n\n try {\n localRec = await getLocal(key)\n } catch (err) {\n if (nvals === 0) {\n throw err\n }\n }\n\n if (localRec) {\n vals.push({\n val: localRec.value,\n from: dht.peerId\n })\n }\n\n if (vals.length >= nvals) {\n return vals\n }\n\n const id = await utils.convertBuffer(key)\n const rtp = dht.routingTable.closestPeers(id, dht.kBucketSize)\n\n dht._log('peers in rt: %d', rtp.length)\n\n if (rtp.length === 0) {\n const errMsg = 'Failed to lookup key! No peers from routing table!'\n\n dht._log.error(errMsg)\n if (vals.length === 0) {\n throw errcode(new Error(errMsg), 'ERR_NO_PEERS_IN_ROUTING_TABLE')\n }\n return vals\n }\n\n const valsLength = vals.length\n\n /**\n * @param {number} pathIndex\n * @param {number} numPaths\n */\n function createQuery (pathIndex, numPaths) {\n // This function body runs once per disjoint path\n const pathSize = utils.pathSize(nvals - valsLength, numPaths)\n let queryResults = 0\n\n /**\n * Here we return the query function to use on this particular disjoint path\n *\n * @param {PeerId} peer\n */\n async function disjointPathQuery (peer) {\n let rec, peers, lookupErr\n try {\n const results = await dht._getValueOrPeers(peer, key)\n rec = results.record\n peers = results.peers\n } catch (err) {\n // If we have an invalid record we just want to continue and fetch a new one.\n if (err.code !== 'ERR_INVALID_RECORD') {\n throw err\n }\n lookupErr = err\n }\n\n /** @type {import('../query').QueryResult} */\n const res = {\n closerPeers: peers\n }\n\n if (rec && rec.value) {\n vals.push({\n val: rec.value,\n from: peer\n })\n\n queryResults++\n } else if (lookupErr) {\n vals.push({\n err: lookupErr,\n from: peer\n })\n\n queryResults++\n }\n\n // enough is enough\n if (queryResults >= pathSize) {\n res.pathComplete = true\n }\n\n return res\n }\n\n return disjointPathQuery\n }\n\n // we have peers, lets send the actual query to them\n const query = new Query(dht, key, createQuery)\n\n try {\n await pTimeout(query.run(rtp), options.timeout)\n } catch (err) {\n if (vals.length === 0) {\n throw err\n }\n } finally {\n query.stop()\n }\n\n return vals\n }\n }\n}\n","'use strict'\n\nconst { base58btc } = require('multiformats/bases/base58')\n\nconst utils = require('../utils')\nconst Run = require('./run')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {{from: PeerId, val: Uint8Array}} DHTQueryValue\n * @typedef {{from: PeerId, err: Error}} DHTQueryError\n * @typedef {DHTQueryValue | DHTQueryError} DHTQueryResult\n * @typedef {import('../').PeerData} PeerData\n *\n * @typedef {{ pathComplete?: boolean, queryComplete?: boolean, closerPeers?: PeerData[], peer?: PeerData, success?: boolean }} QueryResult\n */\n\n/**\n * User-supplied function to set up an individual disjoint path. Per-path\n * query state should be held in this function's closure.\n *\n * Accepts the numeric index from zero to numPaths - 1 and returns a function\n * to call on each peer in the query.\n *\n * @typedef {(pathIndex: number, numPaths: number) => QueryFunc } MakeQueryFunc\n */\n\n/**\n * Query function\n *\n * @typedef {(peer: PeerId) => Promise<QueryResult> } QueryFunc\n */\n\n/**\n * Divide peers up into disjoint paths (subqueries). Any peer can only be used once over all paths.\n * Within each path, query peers from closest to farthest away.\n */\nclass Query {\n /**\n * Create a new query. The makePath function is called once per disjoint path, so that per-path\n * variables can be created in that scope. makePath then returns the actual query function (queryFunc) to\n * use when on that path.\n *\n * @param {import('../index')} dht - DHT instance\n * @param {Uint8Array} key\n * @param {MakeQueryFunc} makePath - Called to set up each disjoint path. Must return the query function.\n */\n constructor (dht, key, makePath) {\n this.dht = dht\n this.key = key\n this.makePath = makePath\n this._log = utils.logger(this.dht.peerId, 'query:' + base58btc.baseEncode(key))\n\n this.running = false\n\n this._onStart = this._onStart.bind(this)\n this._onComplete = this._onComplete.bind(this)\n }\n\n /**\n * Run this query, start with the given list of peers first.\n *\n * @param {PeerId[]} peers\n */\n async run (peers) { // eslint-disable-line require-await\n if (!this.dht._queryManager.running) {\n this._log.error('Attempt to run query after shutdown')\n return { finalSet: new Set(), paths: [] }\n }\n\n if (peers.length === 0) {\n this._log.error('Running query with no peers')\n return { finalSet: new Set(), paths: [] }\n }\n\n this._run = new Run(this)\n\n this._log(`query running with K=${this.dht.kBucketSize}, A=${this.dht.concurrency}, D=${Math.min(this.dht.disjointPaths, peers.length)}`)\n this._run.once('start', this._onStart)\n this._run.once('complete', this._onComplete)\n\n return this._run.execute(peers)\n }\n\n /**\n * Called when the run starts.\n */\n _onStart () {\n this.running = true\n this._startTime = Date.now()\n this._log('query:start')\n\n // Register this query so we can stop it if the DHT stops\n this.dht._queryManager.queryStarted(this)\n }\n\n /**\n * Called when the run completes (even if there's an error).\n */\n _onComplete () {\n // Ensure worker queues for all paths are stopped at the end of the query\n this.stop()\n }\n\n /**\n * Stop the query.\n */\n stop () {\n this._log(`query:done in ${Date.now() - (this._startTime || 0)}ms`)\n\n if (this._run) {\n this._log(`${this._run.errors.length} of ${this._run.peersSeen.size} peers errored (${this._run.errors.length / this._run.peersSeen.size * 100}% fail rate)`)\n }\n\n if (!this.running) {\n return\n }\n\n this.running = false\n\n if (this._run) {\n this._run.removeListener('start', this._onStart)\n this._run.removeListener('complete', this._onComplete)\n this._run.stop()\n }\n\n this.dht._queryManager.queryCompleted(this)\n }\n}\n\nmodule.exports = Query\n","'use strict'\n\nconst PeerDistanceList = require('../peer-list/peer-distance-list')\nconst EventEmitter = require('events')\n\nconst Path = require('./path')\nconst WorkerQueue = require('./worker-queue')\nconst utils = require('../utils')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * Manages a single run of the query.\n */\nclass Run extends EventEmitter {\n /**\n * Creates a Run.\n *\n * @param {import('./index')} query\n */\n constructor (query) {\n super()\n\n this.query = query\n\n this.running = false\n\n /** @type {WorkerQueue[]} */\n this.workers = []\n\n // The peers that have been queried (including error responses)\n this.peersSeen = new Set()\n\n // The errors received when querying peers\n /** @type {Error[]} */\n this.errors = []\n\n // The closest K peers that have been queried successfully\n // (this member is initialized when the worker queues start)\n /** @type {PeerDistanceList | null} */\n this.peersQueried = null\n }\n\n /**\n * Stop all the workers\n */\n stop () {\n if (!this.running) {\n return\n }\n\n this.running = false\n for (const worker of this.workers) {\n worker.stop()\n }\n }\n\n /**\n * Execute the run with the given initial set of peers.\n *\n * @param {PeerId[]} peers\n */\n async execute (peers) {\n /** @type {import('./path')[]} */\n const paths = [] // array of states per disjoint path\n\n // Create disjoint paths\n const numPaths = Math.min(this.query.dht.disjointPaths, peers.length)\n for (let i = 0; i < numPaths; i++) {\n paths.push(new Path(this, this.query.makePath(i, numPaths)))\n }\n\n // Assign peers to paths round-robin style\n peers.forEach((peer, i) => {\n paths[i % numPaths].addInitialPeer(peer)\n })\n\n // Execute the query along each disjoint path\n await this.executePaths(paths)\n\n const res = {\n // The closest K peers we were able to query successfully\n finalSet: new Set(this.peersQueried && this.peersQueried.peers),\n\n /** @type {import('./index').QueryResult[]} */\n paths: []\n }\n\n // Collect the results from each completed path\n for (const path of paths) {\n if (path.res && (path.res.pathComplete || path.res.queryComplete)) {\n path.res.success = true\n res.paths.push(path.res)\n }\n }\n\n return res\n }\n\n /**\n * Execute all paths through the DHT.\n *\n * @param {Array<Path>} paths\n * @returns {Promise<void>}\n */\n async executePaths (paths) {\n this.running = true\n\n this.emit('start')\n try {\n await Promise.all(paths.map(path => path.execute()))\n } finally {\n // Ensure all workers are stopped\n this.stop()\n // Completed the Run\n this.emit('complete')\n }\n\n // If all queries errored out, something is seriously wrong, so callback\n // with an error\n if (this.errors.length === this.peersSeen.size) {\n throw this.errors[0]\n }\n }\n\n /**\n * Initialize the list of queried peers, then start a worker queue for the\n * given path.\n *\n * @param {Path} path\n * @returns {Promise<void>}\n */\n async workerQueue (path) {\n await this.init()\n await this.startWorker(path)\n }\n\n /**\n * Create and start a worker queue for a particular path.\n *\n * @param {Path} path\n * @returns {Promise<void>}\n */\n async startWorker (path) {\n const worker = new WorkerQueue(this.query.dht, this, path, this.query._log)\n this.workers.push(worker)\n await worker.execute()\n }\n\n /**\n * Initialize the list of closest peers we've queried - this is shared by all\n * paths in the run.\n *\n * @returns {Promise<void>}\n */\n async init () {\n if (this.peersQueried) {\n return\n }\n\n // We only want to initialize the PeerDistanceList once for the run\n if (this.peersQueriedPromise) {\n await this.peersQueriedPromise\n return\n }\n\n // This promise is temporarily stored so that others may await its completion\n this.peersQueriedPromise = (async () => {\n const dhtKey = await utils.convertBuffer(this.query.key)\n this.peersQueried = new PeerDistanceList(dhtKey, this.query.dht.kBucketSize)\n })()\n\n // After PeerDistanceList is initialized, clean up\n await this.peersQueriedPromise\n delete this.peersQueriedPromise\n }\n\n /**\n * If we've queried K peers, and the remaining peers in the given `worker`'s queue\n * are all further from the key than the peers we've already queried, then we should\n * stop querying on that `worker`.\n *\n * @param {WorkerQueue} worker\n * @returns {Promise<boolean>}\n */\n async continueQuerying (worker) {\n // If we haven't queried K peers yet, keep going\n if (this.peersQueried && this.peersQueried.length < this.peersQueried.capacity) {\n return true\n }\n\n // Get all the peers that are currently being queried.\n // Note that this function gets called right after a peer has been popped\n // off the head of the closest peers queue so it will include that peer.\n const running = Array.from(worker.queuedPeerIds)\n\n // Check if any of the peers that are currently being queried are closer\n // to the key than the peers we've already queried\n const someCloser = this.peersQueried && await this.peersQueried.anyCloser(running)\n\n // Some are closer, the worker should keep going\n if (someCloser) {\n return true\n }\n\n // None are closer, the worker can stop\n return false\n }\n}\n\nmodule.exports = Run\n","'use strict'\n\nconst utils = require('../utils')\nconst pMap = require('p-map')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\nconst { compare: uint8ArrayCompare } = require('uint8arrays/compare')\nconst { xor: uint8ArrayXor } = require('uint8arrays/xor')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../').PeerData} PeerData\n */\n\n/**\n * Maintains a list of peerIds sorted by distance from a DHT key.\n */\nclass PeerDistanceList {\n /**\n * Creates a new PeerDistanceList.\n *\n * @param {Uint8Array} originDhtKey - the DHT key from which distance is calculated\n * @param {number} capacity - the maximum size of the list\n */\n constructor (originDhtKey, capacity) {\n this.originDhtKey = originDhtKey\n this.capacity = capacity\n\n /** @type {{ peerId: PeerId, distance: Uint8Array }[]} */\n this.peerDistances = []\n }\n\n /**\n * The length of the list\n */\n get length () {\n return this.peerDistances.length\n }\n\n /**\n * The peerIds in the list, in order of distance from the origin key\n */\n get peers () {\n return this.peerDistances.map(pd => pd.peerId)\n }\n\n /**\n * Add a peerId to the list.\n *\n * @param {PeerId} peerId\n */\n async add (peerId) {\n if (this.peerDistances.find(pd => uint8ArrayEquals(pd.peerId.id, peerId.id))) {\n return\n }\n\n const dhtKey = await utils.convertPeerId(peerId)\n const el = {\n peerId,\n distance: uint8ArrayXor(this.originDhtKey, dhtKey)\n }\n\n this.peerDistances.push(el)\n this.peerDistances.sort((a, b) => uint8ArrayCompare(a.distance, b.distance))\n this.peerDistances = this.peerDistances.slice(0, this.capacity)\n }\n\n /**\n * Indicates whether any of the peerIds passed as a parameter are closer\n * to the origin key than the furthest peerId in the PeerDistanceList.\n *\n * @param {PeerId[]} peerIds\n */\n async anyCloser (peerIds) {\n if (!peerIds.length) {\n return false\n }\n\n if (!this.length) {\n return true\n }\n\n const dhtKeys = await pMap(peerIds, (peerId) => utils.convertPeerId(peerId))\n const furthestDistance = this.peerDistances[this.peerDistances.length - 1].distance\n\n for (const dhtKey of dhtKeys) {\n const keyDistance = uint8ArrayXor(this.originDhtKey, dhtKey)\n\n if (uint8ArrayCompare(keyDistance, furthestDistance) < 0) {\n return true\n }\n }\n\n return false\n }\n}\n\nmodule.exports = PeerDistanceList\n","'use strict'\n\nconst PeerQueue = require('../peer-list/peer-queue')\nconst utils = require('../utils')\n\n// TODO: Temporary until parallel dial in Switch have a proper\n// timeout. Requires async/await refactor of transports and\n// dial abort logic. This gives us 30s to complete the `queryFunc`.\n// This should help reduce the high end call times of queries\nconst QUERY_FUNC_TIMEOUT = 30e3\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * Manages a single Path through the DHT.\n */\nclass Path {\n /**\n * Creates a Path.\n *\n * @param {import('./run')} run\n * @param {import('./index').QueryFunc} queryFunc\n */\n constructor (run, queryFunc) {\n this.run = run\n this.queryFunc = utils.withTimeout(queryFunc, QUERY_FUNC_TIMEOUT)\n if (!this.queryFunc) throw new Error('Path requires a `queryFn` to be specified')\n if (typeof this.queryFunc !== 'function') throw new Error('Path expected `queryFn` to be a function. Got ' + typeof this.queryFunc)\n\n /** @type {PeerId[]} */\n this.initialPeers = []\n\n /** @type {PeerQueue | null} */\n this.peersToQuery = null\n\n /** @type {import('./index').QueryResult | null} */\n this.res = null\n }\n\n /**\n * Add a peer to the set of peers that are used to intialize the path.\n *\n * @param {PeerId} peer\n */\n addInitialPeer (peer) {\n this.initialPeers.push(peer)\n }\n\n /**\n * Execute the path\n */\n async execute () {\n // Create a queue of peers ordered by distance from the key\n const queue = await PeerQueue.fromKey(this.run.query.key)\n // Add initial peers to the queue\n this.peersToQuery = queue\n await Promise.all(this.initialPeers.map(peer => this.addPeerToQuery(peer)))\n await this.run.workerQueue(this)\n }\n\n /**\n * Add a peer to the peers to be queried.\n *\n * @param {PeerId} peer\n */\n async addPeerToQuery (peer) {\n // Don't add self\n if (this.run.query.dht._isSelf(peer)) {\n return\n }\n\n // The paths must be disjoint, meaning that no two paths in the Query may\n // traverse the same peer\n if (this.run.peersSeen.has(peer.toB58String())) {\n return\n }\n\n if (this.peersToQuery) {\n await this.peersToQuery.enqueue(peer)\n }\n }\n}\n\nmodule.exports = Path\n","'use strict'\n\n// @ts-ignore\nconst Heap = require('heap')\nconst { xor: uint8ArrayXor } = require('uint8arrays/xor')\nconst debug = require('debug')\n\nconst utils = require('../utils')\n\nconst log = debug('libp2p:dht:peer-queue')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\n/**\n * PeerQueue is a heap that sorts its entries (PeerIds) by their\n * xor distance to the inital provided key.\n */\nclass PeerQueue {\n /**\n * Create from a given peer id.\n *\n * @param {PeerId} id\n * @returns {Promise<PeerQueue>}\n */\n static async fromPeerId (id) {\n const key = await utils.convertPeerId(id)\n\n return new PeerQueue(key)\n }\n\n /**\n * Create from a given Uint8Array.\n *\n * @param {Uint8Array} keyBuffer\n * @returns {Promise<PeerQueue>}\n */\n static async fromKey (keyBuffer) {\n const key = await utils.convertBuffer(keyBuffer)\n\n return new PeerQueue(key)\n }\n\n /**\n * Create a new PeerQueue.\n *\n * @param {Uint8Array} from - The sha2-256 encoded peer id\n */\n constructor (from) {\n log('create: %b', from)\n this.from = from\n this.heap = new Heap(utils.xorCompare)\n }\n\n /**\n * Add a new PeerId to the queue.\n *\n * @param {PeerId} id\n */\n async enqueue (id) {\n log('enqueue %s', id.toB58String())\n const key = await utils.convertPeerId(id)\n\n const el = {\n id: id,\n distance: uint8ArrayXor(this.from, key)\n }\n\n this.heap.push(el)\n }\n\n /**\n * Returns the closest peer to the `from` peer.\n *\n * @returns {PeerId}\n */\n dequeue () {\n const el = this.heap.pop()\n log('dequeue %s', el.id.toB58String())\n return el.id\n }\n\n get length () {\n return this.heap.size()\n }\n}\n\nmodule.exports = PeerQueue\n","module.exports = require('./lib/heap');\n","// Generated by CoffeeScript 1.8.0\n(function() {\n var Heap, defaultCmp, floor, heapify, heappop, heappush, heappushpop, heapreplace, insort, min, nlargest, nsmallest, updateItem, _siftdown, _siftup;\n\n floor = Math.floor, min = Math.min;\n\n\n /*\n Default comparison function to be used\n */\n\n defaultCmp = function(x, y) {\n if (x < y) {\n return -1;\n }\n if (x > y) {\n return 1;\n }\n return 0;\n };\n\n\n /*\n Insert item x in list a, and keep it sorted assuming a is sorted.\n \n If x is already in a, insert it to the right of the rightmost x.\n \n Optional args lo (default 0) and hi (default a.length) bound the slice\n of a to be searched.\n */\n\n insort = function(a, x, lo, hi, cmp) {\n var mid;\n if (lo == null) {\n lo = 0;\n }\n if (cmp == null) {\n cmp = defaultCmp;\n }\n if (lo < 0) {\n throw new Error('lo must be non-negative');\n }\n if (hi == null) {\n hi = a.length;\n }\n while (lo < hi) {\n mid = floor((lo + hi) / 2);\n if (cmp(x, a[mid]) < 0) {\n hi = mid;\n } else {\n lo = mid + 1;\n }\n }\n return ([].splice.apply(a, [lo, lo - lo].concat(x)), x);\n };\n\n\n /*\n Push item onto heap, maintaining the heap invariant.\n */\n\n heappush = function(array, item, cmp) {\n if (cmp == null) {\n cmp = defaultCmp;\n }\n array.push(item);\n return _siftdown(array, 0, array.length - 1, cmp);\n };\n\n\n /*\n Pop the smallest item off the heap, maintaining the heap invariant.\n */\n\n heappop = function(array, cmp) {\n var lastelt, returnitem;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n lastelt = array.pop();\n if (array.length) {\n returnitem = array[0];\n array[0] = lastelt;\n _siftup(array, 0, cmp);\n } else {\n returnitem = lastelt;\n }\n return returnitem;\n };\n\n\n /*\n Pop and return the current smallest value, and add the new item.\n \n This is more efficient than heappop() followed by heappush(), and can be\n more appropriate when using a fixed size heap. Note that the value\n returned may be larger than item! That constrains reasonable use of\n this routine unless written as part of a conditional replacement:\n if item > array[0]\n item = heapreplace(array, item)\n */\n\n heapreplace = function(array, item, cmp) {\n var returnitem;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n returnitem = array[0];\n array[0] = item;\n _siftup(array, 0, cmp);\n return returnitem;\n };\n\n\n /*\n Fast version of a heappush followed by a heappop.\n */\n\n heappushpop = function(array, item, cmp) {\n var _ref;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n if (array.length && cmp(array[0], item) < 0) {\n _ref = [array[0], item], item = _ref[0], array[0] = _ref[1];\n _siftup(array, 0, cmp);\n }\n return item;\n };\n\n\n /*\n Transform list into a heap, in-place, in O(array.length) time.\n */\n\n heapify = function(array, cmp) {\n var i, _i, _j, _len, _ref, _ref1, _results, _results1;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n _ref1 = (function() {\n _results1 = [];\n for (var _j = 0, _ref = floor(array.length / 2); 0 <= _ref ? _j < _ref : _j > _ref; 0 <= _ref ? _j++ : _j--){ _results1.push(_j); }\n return _results1;\n }).apply(this).reverse();\n _results = [];\n for (_i = 0, _len = _ref1.length; _i < _len; _i++) {\n i = _ref1[_i];\n _results.push(_siftup(array, i, cmp));\n }\n return _results;\n };\n\n\n /*\n Update the position of the given item in the heap.\n This function should be called every time the item is being modified.\n */\n\n updateItem = function(array, item, cmp) {\n var pos;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n pos = array.indexOf(item);\n if (pos === -1) {\n return;\n }\n _siftdown(array, 0, pos, cmp);\n return _siftup(array, pos, cmp);\n };\n\n\n /*\n Find the n largest elements in a dataset.\n */\n\n nlargest = function(array, n, cmp) {\n var elem, result, _i, _len, _ref;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n result = array.slice(0, n);\n if (!result.length) {\n return result;\n }\n heapify(result, cmp);\n _ref = array.slice(n);\n for (_i = 0, _len = _ref.length; _i < _len; _i++) {\n elem = _ref[_i];\n heappushpop(result, elem, cmp);\n }\n return result.sort(cmp).reverse();\n };\n\n\n /*\n Find the n smallest elements in a dataset.\n */\n\n nsmallest = function(array, n, cmp) {\n var elem, i, los, result, _i, _j, _len, _ref, _ref1, _results;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n if (n * 10 <= array.length) {\n result = array.slice(0, n).sort(cmp);\n if (!result.length) {\n return result;\n }\n los = result[result.length - 1];\n _ref = array.slice(n);\n for (_i = 0, _len = _ref.length; _i < _len; _i++) {\n elem = _ref[_i];\n if (cmp(elem, los) < 0) {\n insort(result, elem, 0, null, cmp);\n result.pop();\n los = result[result.length - 1];\n }\n }\n return result;\n }\n heapify(array, cmp);\n _results = [];\n for (i = _j = 0, _ref1 = min(n, array.length); 0 <= _ref1 ? _j < _ref1 : _j > _ref1; i = 0 <= _ref1 ? ++_j : --_j) {\n _results.push(heappop(array, cmp));\n }\n return _results;\n };\n\n _siftdown = function(array, startpos, pos, cmp) {\n var newitem, parent, parentpos;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n newitem = array[pos];\n while (pos > startpos) {\n parentpos = (pos - 1) >> 1;\n parent = array[parentpos];\n if (cmp(newitem, parent) < 0) {\n array[pos] = parent;\n pos = parentpos;\n continue;\n }\n break;\n }\n return array[pos] = newitem;\n };\n\n _siftup = function(array, pos, cmp) {\n var childpos, endpos, newitem, rightpos, startpos;\n if (cmp == null) {\n cmp = defaultCmp;\n }\n endpos = array.length;\n startpos = pos;\n newitem = array[pos];\n childpos = 2 * pos + 1;\n while (childpos < endpos) {\n rightpos = childpos + 1;\n if (rightpos < endpos && !(cmp(array[childpos], array[rightpos]) < 0)) {\n childpos = rightpos;\n }\n array[pos] = array[childpos];\n pos = childpos;\n childpos = 2 * pos + 1;\n }\n array[pos] = newitem;\n return _siftdown(array, startpos, pos, cmp);\n };\n\n Heap = (function() {\n Heap.push = heappush;\n\n Heap.pop = heappop;\n\n Heap.replace = heapreplace;\n\n Heap.pushpop = heappushpop;\n\n Heap.heapify = heapify;\n\n Heap.updateItem = updateItem;\n\n Heap.nlargest = nlargest;\n\n Heap.nsmallest = nsmallest;\n\n function Heap(cmp) {\n this.cmp = cmp != null ? cmp : defaultCmp;\n this.nodes = [];\n }\n\n Heap.prototype.push = function(x) {\n return heappush(this.nodes, x, this.cmp);\n };\n\n Heap.prototype.pop = function() {\n return heappop(this.nodes, this.cmp);\n };\n\n Heap.prototype.peek = function() {\n return this.nodes[0];\n };\n\n Heap.prototype.contains = function(x) {\n return this.nodes.indexOf(x) !== -1;\n };\n\n Heap.prototype.replace = function(x) {\n return heapreplace(this.nodes, x, this.cmp);\n };\n\n Heap.prototype.pushpop = function(x) {\n return heappushpop(this.nodes, x, this.cmp);\n };\n\n Heap.prototype.heapify = function() {\n return heapify(this.nodes, this.cmp);\n };\n\n Heap.prototype.updateItem = function(x) {\n return updateItem(this.nodes, x, this.cmp);\n };\n\n Heap.prototype.clear = function() {\n return this.nodes = [];\n };\n\n Heap.prototype.empty = function() {\n return this.nodes.length === 0;\n };\n\n Heap.prototype.size = function() {\n return this.nodes.length;\n };\n\n Heap.prototype.clone = function() {\n var heap;\n heap = new Heap();\n heap.nodes = this.nodes.slice(0);\n return heap;\n };\n\n Heap.prototype.toArray = function() {\n return this.nodes.slice(0);\n };\n\n Heap.prototype.insert = Heap.prototype.push;\n\n Heap.prototype.top = Heap.prototype.peek;\n\n Heap.prototype.front = Heap.prototype.peek;\n\n Heap.prototype.has = Heap.prototype.contains;\n\n Heap.prototype.copy = Heap.prototype.clone;\n\n return Heap;\n\n })();\n\n (function(root, factory) {\n if (typeof define === 'function' && define.amd) {\n return define([], factory);\n } else if (typeof exports === 'object') {\n return module.exports = factory();\n } else {\n return root.Heap = factory();\n }\n })(this, function() {\n return Heap;\n });\n\n}).call(this);\n","'use strict'\n\nconst { default: Queue } = require('p-queue')\n\n/**\n * @typedef {import('peer-id')} PeerId\n */\n\nclass WorkerQueue {\n /**\n * Creates a new WorkerQueue.\n *\n * @param {import('../index')} dht\n * @param {import('./run')} run\n * @param {import('./path')} path\n * @param {Function & {error: Function}} log\n */\n constructor (dht, run, path, log) {\n this.dht = dht\n this.run = run\n this.path = path\n this.log = log\n\n this.concurrency = this.dht.concurrency\n this.queue = this.setupQueue()\n // a container for resolve/reject functions that will be populated\n // when execute() is called\n\n /** @type {{ resolve: (result?: any) => void, reject: (err: Error) => void} | null} */\n this.execution = null\n\n /** @type {Set<PeerId>} */\n this.queuedPeerIds = new Set()\n }\n\n /**\n * Create the underlying async queue.\n *\n * @returns {Queue}\n */\n setupQueue () {\n const q = new Queue({\n concurrency: this.concurrency\n })\n\n // When all peers in the queue have been processed, stop the worker\n q.on('idle', () => {\n if (this.path.peersToQuery && !this.path.peersToQuery.length) {\n this.log('queue:drain')\n this.stop()\n }\n })\n\n // When a space opens up in the queue, add some more peers\n q.on('next', () => {\n if (!this.running) {\n return\n }\n\n if (q.pending < this.concurrency) {\n this.fill()\n }\n })\n\n return q\n }\n\n /**\n * Stop the worker, optionally providing an error to pass to the worker's\n * callback.\n *\n * @param {Error} [err]\n */\n stop (err) {\n if (!this.running) {\n return\n }\n\n this.running = false\n this.queue.clear()\n this.log('worker:stop, %d workers still running', this.run.workers.filter(w => w.running).length)\n\n if (this.execution) {\n if (err) {\n this.execution.reject(err)\n } else {\n this.execution.resolve()\n }\n }\n }\n\n /**\n * Use the queue from async to keep `concurrency` amount items running\n * per path.\n *\n * @returns {Promise<void>}\n */\n async execute () {\n this.running = true\n // store the promise resolution functions to be resolved at end of queue\n this.execution = null\n const execPromise = new Promise((resolve, reject) => {\n this.execution = {\n resolve, reject\n }\n })\n // start queue\n this.fill()\n // await completion\n await execPromise\n }\n\n /**\n * Add peers to the worker queue until there are enough to satisfy the\n * worker queue concurrency.\n * Note that we don't want to take any more than those required to satisfy\n * concurrency from the peers-to-query queue, because we always want to\n * query the closest peers to the key first, and new peers are continuously\n * being added to the peers-to-query queue.\n */\n fill () {\n if (!this.path.peersToQuery) {\n return\n }\n\n // Note:\n // - queue.pending: number of items that are currently running\n // - queue.size: the number of items that are waiting to be run\n while (this.queue.pending + this.queue.size < this.concurrency && this.path.peersToQuery.length > 0) {\n const peer = this.path.peersToQuery.dequeue()\n\n // store the peer id so we can potentially abort early\n this.queuedPeerIds.add(peer)\n\n this.queue.add(\n () => {\n return this.processNext(peer)\n .catch(err => {\n this.log.error('queue', err)\n this.stop(err)\n })\n .finally(() => {\n this.queuedPeerIds.delete(peer)\n })\n }\n )\n }\n }\n\n /**\n * Process the next peer in the queue\n *\n * @param {PeerId} peer\n */\n async processNext (peer) {\n if (!this.running) {\n return\n }\n\n // The paths must be disjoint, meaning that no two paths in the Query may\n // traverse the same peer\n if (this.run.peersSeen.has(peer.toB58String())) {\n return\n }\n\n // Check if we've queried enough peers already\n let continueQuerying, continueQueryingError\n try {\n continueQuerying = await this.run.continueQuerying(this)\n } catch (err) {\n continueQueryingError = err\n }\n\n // Abort and ignore any error if we're no longer running\n if (!this.running) {\n return\n }\n\n if (continueQueryingError) {\n throw continueQueryingError\n }\n\n // No peer we're querying is closer, stop the queue\n // This will cause queries that may potentially result in\n // closer nodes to be ended, but it reduces overall query time\n if (!continueQuerying) {\n this.stop()\n return\n }\n\n // Check if another path has queried this peer in the mean time\n if (this.run.peersSeen.has(peer.toB58String())) {\n return\n }\n this.run.peersSeen.add(peer.toB58String())\n\n // Execute the query on the next peer\n this.log('queue:work')\n let state, execError\n try {\n state = await this.execQuery(peer)\n } catch (err) {\n execError = err\n }\n\n // Abort and ignore any error if we're no longer running\n if (!this.running) {\n return\n }\n\n this.log('queue:work:done', execError, state)\n\n if (execError) {\n throw execError\n }\n\n // If query is complete, stop all workers.\n // Note: run.stop() calls stop() on all the workers, which kills the\n // queue and resolves execution\n if (state && state.queryComplete) {\n this.log('query:complete')\n this.run.stop()\n return\n }\n\n // If path is complete, just stop this worker.\n // Note: this.stop() kills the queue and resolves execution\n if (state && state.pathComplete) {\n this.stop()\n }\n }\n\n /**\n * Execute a query on the next peer.\n *\n * @param {PeerId} peer\n */\n async execQuery (peer) {\n let res, queryError\n try {\n res = await this.path.queryFunc(peer)\n } catch (err) {\n queryError = err\n }\n\n // Abort and ignore any error if we're no longer running\n if (!this.running) {\n return\n }\n\n if (queryError) {\n this.run.errors.push(queryError)\n return\n }\n\n // Add the peer to the closest peers we have successfully queried\n this.run.peersQueried && await this.run.peersQueried.add(peer)\n\n if (!res) {\n return\n }\n\n // If the query indicates that this path or the whole query is complete\n // set the path result and bail out\n if (res.pathComplete || res.queryComplete) {\n this.path.res = res\n\n return {\n pathComplete: res.pathComplete,\n queryComplete: res.queryComplete\n }\n }\n\n // If there are closer peers to query, add them to the queue\n if (res.closerPeers && res.closerPeers.length > 0) {\n /**\n * @param {import('../').PeerData} closer\n */\n const queryCloser = async (closer) => {\n // don't add ourselves\n if (this.dht._isSelf(closer.id)) {\n return\n }\n\n this.dht._peerDiscovered(closer.id, closer.multiaddrs)\n await this.path.addPeerToQuery(closer.id)\n }\n\n await Promise.all(res.closerPeers.map(queryCloser))\n }\n }\n}\n\nmodule.exports = WorkerQueue\n","'use strict'\n\nconst errcode = require('err-code')\nconst pTimeout = require('p-timeout')\n\nconst c = require('../constants')\nconst LimitedPeerList = require('../peer-list/limited-peer-list')\nconst Message = require('../message')\nconst Query = require('../query')\nconst utils = require('../utils')\n\n/**\n * @typedef {import('multiformats/cid').CID} CID\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @param {import('../')} dht\n */\nmodule.exports = (dht) => {\n /**\n * Check for providers from a single node.\n *\n * @param {PeerId} peer\n * @param {CID} key\n *\n * @private\n */\n const findProvidersSingle = async (peer, key) => { // eslint-disable-line require-await\n const msg = new Message(Message.TYPES.GET_PROVIDERS, key.bytes, 0)\n return dht.network.sendRequest(peer, msg)\n }\n\n return {\n /**\n * Announce to the network that we can provide the value for a given key\n *\n * @param {CID} key\n */\n async provide (key) {\n dht._log(`provide: ${key}`)\n\n /** @type {Error[]} */\n const errors = []\n\n // Add peer as provider\n await dht.providers.addProvider(key, dht.peerId)\n\n const multiaddrs = dht.libp2p ? dht.libp2p.multiaddrs : []\n const msg = new Message(Message.TYPES.ADD_PROVIDER, key.bytes, 0)\n msg.providerPeers = [{\n id: dht.peerId,\n multiaddrs\n }]\n\n /**\n * @param {PeerId} peer\n */\n async function mapPeer (peer) {\n dht._log(`putProvider ${key} to ${peer.toB58String()}`)\n try {\n await dht.network.sendMessage(peer, msg)\n } catch (err) {\n errors.push(err)\n }\n }\n\n // Notify closest peers\n await utils.mapParallel(dht.getClosestPeers(key.bytes), mapPeer)\n\n if (errors.length) {\n // TODO:\n // This should be infrequent. This means a peer we previously connected\n // to failed to exchange the provide message. If getClosestPeers was an\n // iterator, we could continue to pull until we announce to kBucketSize peers.\n throw errcode(new Error(`Failed to provide to ${errors.length} of ${dht.kBucketSize} peers`), 'ERR_SOME_PROVIDES_FAILED', { errors })\n }\n },\n\n /**\n * Search the dht for up to `K` providers of the given CID.\n *\n * @param {CID} key\n * @param {Object} [options] - findProviders options\n * @param {number} [options.timeout=60000] - how long the query should maximally run, in milliseconds\n * @param {number} [options.maxNumProviders=5] - maximum number of providers to find\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * findProviders (key, options = { timeout: 60000, maxNumProviders: 5 }) {\n const providerTimeout = options.timeout || c.minute\n const n = options.maxNumProviders || c.K\n\n dht._log(`findProviders ${key}`)\n\n const out = new LimitedPeerList(n)\n const provs = await dht.providers.getProviders(key)\n\n provs\n .forEach(id => {\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peerData = dht.peerStore.get(id)\n\n if (peerData) {\n out.push({\n id: peerData.id,\n multiaddrs: peerData.addresses\n .map((address) => address.multiaddr)\n })\n } else {\n out.push({\n id,\n multiaddrs: []\n })\n }\n })\n\n // All done\n if (out.length >= n) {\n // yield values\n for (const pData of out.toArray()) {\n yield pData\n }\n return\n }\n\n // need more, query the network\n /** @type {LimitedPeerList[]} */\n const paths = []\n\n /**\n *\n * @param {number} pathIndex\n * @param {number} numPaths\n */\n function makePath (pathIndex, numPaths) {\n // This function body runs once per disjoint path\n const pathSize = utils.pathSize(n - out.length, numPaths)\n const pathProviders = new LimitedPeerList(pathSize)\n paths.push(pathProviders)\n\n /**\n * The query function to use on this particular disjoint path\n *\n * @param {PeerId} peer\n */\n async function queryDisjointPath (peer) {\n const msg = await findProvidersSingle(peer, key)\n const provs = msg.providerPeers\n dht._log(`Found ${provs.length} provider entries for ${key}`)\n\n provs.forEach((prov) => {\n pathProviders.push({\n ...prov\n })\n })\n\n // hooray we have all that we want\n if (pathProviders.length >= pathSize) {\n return { pathComplete: true }\n }\n\n // it looks like we want some more\n return { closerPeers: msg.closerPeers }\n }\n\n return queryDisjointPath\n }\n\n const query = new Query(dht, key.bytes, makePath)\n const peers = dht.routingTable.closestPeers(key.bytes, dht.kBucketSize)\n\n try {\n await pTimeout(\n query.run(peers),\n providerTimeout\n )\n } catch (err) {\n if (err.name !== pTimeout.TimeoutError.name) {\n throw err\n }\n } finally {\n query.stop()\n }\n\n // combine peers from each path\n paths.forEach((path) => {\n path.toArray().forEach((peer) => {\n out.push(peer)\n })\n })\n\n for (const pData of out.toArray()) {\n yield pData\n }\n }\n }\n}\n","'use strict'\n\nconst PeerList = require('.')\n\n/**\n * @typedef {import('../').PeerData} PeerData\n */\n\n/**\n * Like PeerList but with a length restriction.\n */\nclass LimitedPeerList extends PeerList {\n /**\n * Create a new limited peer list.\n *\n * @param {number} limit\n */\n constructor (limit) {\n super()\n this.limit = limit\n }\n\n /**\n * Add a PeerData if it fits in the list\n *\n * @param {PeerData} peerData\n */\n push (peerData) {\n if (this.length < this.limit) {\n return super.push(peerData)\n }\n\n return false\n }\n}\n\nmodule.exports = LimitedPeerList\n","'use strict'\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../').PeerData} PeerData\n */\n\n/**\n * A list of unique peers.\n */\nclass PeerList {\n constructor () {\n /** @type {PeerData[]} */\n this.list = []\n }\n\n /**\n * Add a new peer. Returns `true` if it was a new one\n *\n * @param {PeerData} peerData\n */\n push (peerData) {\n if (!this.has(peerData.id)) {\n this.list.push(peerData)\n\n return true\n }\n\n return false\n }\n\n /**\n * Check if this PeerData is already in here.\n *\n * @param {PeerId} peerId\n */\n has (peerId) {\n const match = this.list.find((i) => i.id.equals(peerId))\n return Boolean(match)\n }\n\n /**\n * Get the list as an array.\n */\n toArray () {\n return this.list.slice()\n }\n\n /**\n * Remove the last element\n */\n pop () {\n return this.list.pop()\n }\n\n /**\n * The length of the list\n */\n get length () {\n return this.list.length\n }\n}\n\nmodule.exports = PeerList\n","'use strict'\n\nconst errcode = require('err-code')\nconst pTimeout = require('p-timeout')\n\nconst PeerId = require('peer-id')\nconst crypto = require('libp2p-crypto')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst c = require('../constants')\nconst Message = require('../message')\nconst Query = require('../query')\n\nconst utils = require('../utils')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @param {import('../index')} dht\n */\nmodule.exports = (dht) => {\n /**\n * Look if we are connected to a peer with the given id.\n * Returns its id and addresses, if found, otherwise `undefined`.\n *\n * @param {PeerId} peer\n */\n const findPeerLocal = async (peer) => {\n dht._log(`findPeerLocal ${peer.toB58String()}`)\n const p = await dht.routingTable.find(peer)\n\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peerData = p && dht.peerStore.get(p)\n\n if (peerData) {\n return {\n id: peerData.id,\n multiaddrs: peerData.addresses.map((address) => address.multiaddr)\n }\n }\n }\n\n /**\n * Get a value via rpc call for the given parameters.\n *\n * @param {PeerId} peer\n * @param {Uint8Array} key\n * @returns {Promise<Message>}\n * @private\n */\n const getValueSingle = async (peer, key) => { // eslint-disable-line require-await\n const msg = new Message(Message.TYPES.GET_VALUE, key, 0)\n return dht.network.sendRequest(peer, msg)\n }\n\n /**\n * Find close peers for a given peer\n *\n * @param {Uint8Array} key\n * @param {PeerId} peer\n * @returns {Promise<Array<{ id: PeerId, multiaddrs: Multiaddr[] }>>}\n * @private\n */\n\n const closerPeersSingle = async (key, peer) => {\n dht._log(`closerPeersSingle ${uint8ArrayToString(key, 'base32')} from ${peer.toB58String()}`)\n const msg = await dht.peerRouting._findPeerSingle(peer, new PeerId(key))\n\n return msg.closerPeers\n .filter((peerData) => !dht._isSelf(peerData.id))\n .map((peerData) => {\n dht.peerStore.addressBook.add(peerData.id, peerData.multiaddrs)\n\n return peerData\n })\n }\n\n /**\n * Get the public key directly from a node.\n *\n * @param {PeerId} peer\n */\n const getPublicKeyFromNode = async (peer) => {\n const pkKey = utils.keyForPublicKey(peer)\n const msg = await getValueSingle(peer, pkKey)\n\n if (!msg.record || !msg.record.value) {\n throw errcode(new Error(`Node not responding with its public key: ${peer.toB58String()}`), 'ERR_INVALID_RECORD')\n }\n\n const recPeer = await PeerId.createFromPubKey(msg.record.value)\n\n // compare hashes of the pub key\n if (!recPeer.equals(peer)) {\n throw errcode(new Error('public key does not match id'), 'ERR_PUBLIC_KEY_DOES_NOT_MATCH_ID')\n }\n\n return recPeer.pubKey\n }\n\n return {\n /**\n * Ask peer `peer` if they know where the peer with id `target` is.\n *\n * @param {PeerId} peer\n * @param {PeerId} target\n * @returns {Promise<Message>}\n * @private\n */\n async _findPeerSingle (peer, target) { // eslint-disable-line require-await\n dht._log('findPeerSingle %s', peer.toB58String())\n const msg = new Message(Message.TYPES.FIND_NODE, target.id, 0)\n\n return dht.network.sendRequest(peer, msg)\n },\n\n /**\n * Search for a peer with the given ID.\n *\n * @param {PeerId} id\n * @param {Object} [options] - findPeer options\n * @param {number} [options.timeout=60000] - how long the query should maximally run, in milliseconds\n * @returns {Promise<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async findPeer (id, options = { timeout: 60000 }) {\n options.timeout = options.timeout || c.minute\n dht._log('findPeer %s', id.toB58String())\n\n // Try to find locally\n const pi = await findPeerLocal(id)\n\n // already got it\n if (pi != null) {\n dht._log('found local')\n return pi\n }\n\n const key = await utils.convertPeerId(id)\n const peers = dht.routingTable.closestPeers(key, dht.kBucketSize)\n\n if (peers.length === 0) {\n throw errcode(new Error('Peer lookup failed'), 'ERR_LOOKUP_FAILED')\n }\n\n // sanity check\n const match = peers.find((p) => p.isEqual(id))\n if (match) {\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peer = dht.peerStore.get(id)\n\n if (peer) {\n dht._log('found in peerStore')\n return {\n id: peer.id,\n multiaddrs: peer.addresses.map((address) => address.multiaddr)\n }\n }\n }\n\n // query the network\n const query = new Query(dht, id.id, () => {\n /**\n * There is no distinction between the disjoint paths, so there are no per-path\n * variables in dht scope. Just return the actual query function.\n *\n * @param {PeerId} peer\n */\n const queryFn = async (peer) => {\n const msg = await this._findPeerSingle(peer, id)\n const match = msg.closerPeers.find((p) => p.id.isEqual(id))\n\n // found it\n if (match) {\n return {\n peer: match,\n queryComplete: true\n }\n }\n\n return {\n closerPeers: msg.closerPeers\n }\n }\n\n return queryFn\n })\n\n let result\n try {\n result = await pTimeout(query.run(peers), options.timeout)\n } finally {\n query.stop()\n }\n\n let success = false\n result.paths.forEach((result) => {\n if (result.success && result.peer) {\n success = true\n dht.peerStore.addressBook.add(result.peer.id, result.peer.multiaddrs)\n }\n })\n dht._log('findPeer %s: %s', id.toB58String(), success)\n\n if (!success) {\n throw errcode(new Error('No peer found'), 'ERR_NOT_FOUND')\n }\n\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peerData = dht.peerStore.get(id)\n\n if (!peerData) {\n throw errcode(new Error('No peer found in peer store'), 'ERR_NOT_FOUND')\n }\n\n return {\n id: peerData.id,\n multiaddrs: peerData.addresses.map((address) => address.multiaddr)\n }\n },\n\n /**\n * Kademlia 'node lookup' operation.\n *\n * @param {Uint8Array} key\n * @param {Object} [options]\n * @param {boolean} [options.shallow=false] - shallow query\n * @returns {AsyncIterable<PeerId>}\n */\n async * getClosestPeers (key, options = { shallow: false }) {\n dht._log('getClosestPeers to %b', key)\n\n const id = await utils.convertBuffer(key)\n const tablePeers = dht.routingTable.closestPeers(id, dht.kBucketSize)\n\n const q = new Query(dht, key, () => {\n // There is no distinction between the disjoint paths,\n // so there are no per-path variables in dht scope.\n // Just return the actual query function.\n return async (peer) => {\n const closer = await closerPeersSingle(key, peer)\n\n return {\n closerPeers: closer,\n pathComplete: options.shallow ? true : undefined\n }\n }\n })\n\n const res = await q.run(tablePeers)\n if (!res || !res.finalSet) {\n return []\n }\n\n const sorted = await utils.sortClosestPeers(Array.from(res.finalSet), id)\n\n for (const pId of sorted.slice(0, dht.kBucketSize)) {\n yield pId\n }\n },\n\n /**\n * Get the public key for the given peer id.\n *\n * @param {PeerId} peer\n */\n async getPublicKey (peer) {\n dht._log('getPublicKey %s', peer.toB58String())\n\n // local check\n /** @type {{ id: PeerId, addresses: { multiaddr: Multiaddr }[] }} */\n const peerData = dht.peerStore.get(peer)\n\n if (peerData && peerData.id.pubKey) {\n dht._log('getPublicKey: found local copy')\n return peerData.id.pubKey\n }\n\n // try the node directly\n let pk\n\n try {\n pk = await getPublicKeyFromNode(peer)\n } catch (err) {\n // try dht directly\n const pkKey = utils.keyForPublicKey(peer)\n const value = await dht.get(pkKey)\n pk = crypto.keys.unmarshalPublicKey(value)\n }\n\n const peerId = new PeerId(peer.id, undefined, pk)\n const addrs = ((peerData && peerData.addresses) || []).map((address) => address.multiaddr)\n dht.peerStore.addressBook.add(peerId, addrs)\n dht.peerStore.keyBook.set(peerId, pk)\n\n return pk\n }\n }\n}\n","'use strict'\n\nconst cache = require('hashlru')\n// @ts-ignore\nconst varint = require('varint')\nconst PeerId = require('peer-id')\nconst { Key } = require('interface-datastore/key')\nconst { default: Queue } = require('p-queue')\nconst c = require('./constants')\nconst utils = require('./utils')\n\n/**\n * @typedef {import('multiformats/cid').CID} CID\n * @typedef {import('interface-datastore').Datastore} Datastore\n */\n\n/**\n * This class manages known providers.\n * A provider is a peer that we know to have the content for a given CID.\n *\n * Every `cleanupInterval` providers are checked if they\n * are still valid, i.e. younger than the `provideValidity`.\n * If they are not, they are deleted.\n *\n * To ensure the list survives restarts of the daemon,\n * providers are stored in the datastore, but to ensure\n * access is fast there is an LRU cache in front of that.\n */\nclass Providers {\n /**\n * @param {Datastore} datastore\n * @param {PeerId} [self]\n * @param {number} [cacheSize=256]\n */\n constructor (datastore, self, cacheSize) {\n this.datastore = datastore\n\n this._log = utils.logger(self, 'providers')\n\n /**\n * How often invalid records are cleaned. (in seconds)\n *\n * @type {number}\n */\n this.cleanupInterval = c.PROVIDERS_CLEANUP_INTERVAL\n\n /**\n * How long is a provider valid for. (in seconds)\n *\n * @type {number}\n */\n this.provideValidity = c.PROVIDERS_VALIDITY\n\n /**\n * LRU cache size\n *\n * @type {number}\n */\n this.lruCacheSize = cacheSize || c.PROVIDERS_LRU_CACHE_SIZE\n\n // @ts-ignore hashlru types are wrong\n this.providers = cache(this.lruCacheSize)\n\n this.syncQueue = new Queue({ concurrency: 1 })\n }\n\n /**\n * Start the provider cleanup service\n */\n start () {\n if (this._started) {\n return\n }\n\n this._started = true\n\n this._cleaner = setInterval(\n () => this._cleanup(),\n this.cleanupInterval\n )\n }\n\n /**\n * Release any resources.\n */\n stop () {\n this._started = false\n\n if (this._cleaner) {\n clearInterval(this._cleaner)\n this._cleaner = null\n }\n }\n\n /**\n * Check all providers if they are still valid, and if not delete them.\n *\n * @returns {Promise<void>}\n * @private\n */\n _cleanup () {\n return this.syncQueue.add(async () => {\n this._log('start cleanup')\n const start = Date.now()\n\n let count = 0\n let deleteCount = 0\n const deleted = new Map()\n const batch = this.datastore.batch()\n\n // Get all provider entries from the datastore\n const query = this.datastore.query({ prefix: c.PROVIDERS_KEY_PREFIX })\n for await (const entry of query) {\n try {\n // Add a delete to the batch for each expired entry\n const { cid, peerId } = parseProviderKey(entry.key)\n const time = readTime(entry.value)\n const now = Date.now()\n const delta = now - time\n const expired = delta > this.provideValidity\n this._log('comparing: %d - %d = %d > %d %s',\n now, time, delta, this.provideValidity, expired ? '(expired)' : '')\n if (expired) {\n deleteCount++\n batch.delete(entry.key)\n const peers = deleted.get(cid) || new Set()\n peers.add(peerId)\n deleted.set(cid, peers)\n }\n count++\n } catch (err) {\n this._log.error(err.message)\n }\n }\n this._log('deleting %d / %d entries', deleteCount, count)\n\n // Commit the deletes to the datastore\n if (deleted.size) {\n await batch.commit()\n }\n\n // Clear expired entries from the cache\n for (const [cid, peers] of deleted) {\n const key = makeProviderKey(cid)\n const provs = this.providers.get(key)\n if (provs) {\n for (const peerId of peers) {\n provs.delete(peerId)\n }\n if (provs.size === 0) {\n this.providers.remove(key)\n } else {\n this.providers.set(key, provs)\n }\n }\n }\n\n this._log('Cleanup successful (%dms)', Date.now() - start)\n })\n }\n\n /**\n * Get the currently known provider peer ids for a given CID.\n *\n * @param {CID} cid\n * @returns {Promise<Map<string, Date>>}\n *\n * @private\n */\n async _getProvidersMap (cid) {\n const cacheKey = makeProviderKey(cid)\n let provs = this.providers.get(cacheKey)\n if (!provs) {\n provs = await loadProviders(this.datastore, cid)\n this.providers.set(cacheKey, provs)\n }\n return provs\n }\n\n /**\n * Add a new provider for the given CID.\n *\n * @param {CID} cid\n * @param {PeerId} provider\n * @returns {Promise<void>}\n */\n async addProvider (cid, provider) { // eslint-disable-line require-await\n return this.syncQueue.add(async () => {\n this._log('addProvider %s', cid.toString())\n const provs = await this._getProvidersMap(cid)\n\n this._log('loaded %s provs', provs.size)\n const now = new Date()\n provs.set(utils.encodeBase32(provider.id), now)\n\n const dsKey = makeProviderKey(cid)\n this.providers.set(dsKey, provs)\n return writeProviderEntry(this.datastore, cid, provider, now)\n })\n }\n\n /**\n * Get a list of providers for the given CID.\n *\n * @param {CID} cid\n * @returns {Promise<Array<PeerId>>}\n */\n async getProviders (cid) { // eslint-disable-line require-await\n return this.syncQueue.add(async () => {\n this._log('getProviders %s', cid.toString())\n const provs = await this._getProvidersMap(cid)\n return [...provs.keys()].map((base32PeerId) => {\n return new PeerId(utils.decodeBase32(base32PeerId))\n })\n })\n }\n}\n\n/**\n * Encode the given key its matching datastore key.\n *\n * @param {CID|string} cid - cid or base32 encoded string\n * @returns {string}\n *\n * @private\n */\nfunction makeProviderKey (cid) {\n cid = typeof cid === 'string' ? cid : utils.encodeBase32(cid.bytes)\n return c.PROVIDERS_KEY_PREFIX + cid\n}\n\n/**\n * Write a provider into the given store.\n *\n * @param {Datastore} store\n * @param {CID} cid\n * @param {PeerId} peer\n * @param {Date} time\n */\nasync function writeProviderEntry (store, cid, peer, time) { // eslint-disable-line require-await\n const dsKey = [\n makeProviderKey(cid),\n '/',\n utils.encodeBase32(peer.id)\n ].join('')\n\n const key = new Key(dsKey)\n const buffer = Uint8Array.from(varint.encode(time.getTime()))\n return store.put(key, buffer)\n}\n\n/**\n * Parse the CID and provider peer id from the key\n *\n * @param {import('interface-datastore/key').Key} key\n */\nfunction parseProviderKey (key) {\n const parts = key.toString().split('/')\n if (parts.length !== 4) {\n throw new Error('incorrectly formatted provider entry key in datastore: ' + key)\n }\n\n return {\n cid: parts[2],\n peerId: parts[3]\n }\n}\n\n/**\n * Load providers for the given CID from the store.\n *\n * @param {Datastore} store\n * @param {CID} cid\n * @returns {Promise<Map<PeerId, Date>>}\n *\n * @private\n */\nasync function loadProviders (store, cid) {\n const providers = new Map()\n const query = store.query({ prefix: makeProviderKey(cid) })\n for await (const entry of query) {\n const { peerId } = parseProviderKey(entry.key)\n providers.set(peerId, readTime(entry.value))\n }\n return providers\n}\n\n/**\n * @param {Uint8Array} buf\n */\nfunction readTime (buf) {\n return varint.decode(buf)\n}\n\nmodule.exports = Providers\n","'use strict'\n\n/**\n * @typedef {import('./query')} Query\n */\n\n/**\n * Keeps track of all running queries.\n */\nclass QueryManager {\n /**\n * Creates a new QueryManager.\n */\n constructor () {\n this.queries = new Set()\n this.running = false\n }\n\n /**\n * Called when a query is started.\n *\n * @param {Query} query\n */\n queryStarted (query) {\n this.queries.add(query)\n }\n\n /**\n * Called when a query completes.\n *\n * @param {Query} query\n */\n queryCompleted (query) {\n this.queries.delete(query)\n }\n\n /**\n * Starts the query manager.\n */\n start () {\n this.running = true\n }\n\n /**\n * Stops all queries.\n */\n stop () {\n this.running = false\n for (const query of this.queries) {\n query.stop()\n }\n this.queries.clear()\n }\n}\n\nmodule.exports = QueryManager\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipns = require('ipns');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar ipns__namespace = /*#__PURE__*/_interopNamespace(ipns);\n\nconst validator = { func: (key, record) => ipns__namespace.validator.validate(record, key) };\nfunction selector(_k, records) {\n return ipns__namespace.validator.select(records[0], records[1]);\n}\n\nexports.selector = selector;\nexports.validator = validator;\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\nconst mafmt = require('mafmt')\nconst { EventEmitter } = require('events')\nconst debug = require('debug')\n\nconst log = Object.assign(debug('libp2p:bootstrap'), {\n error: debug('libp2p:bootstrap:error')\n})\n\n/**\n * Emits 'peer' events on a regular interval for each peer in the provided list.\n */\nclass Bootstrap extends EventEmitter {\n /**\n * Constructs a new Bootstrap.\n *\n * @param {Object} options\n * @param {Array<string>} options.list - the list of peer addresses in multi-address format\n * @param {number} [options.interval = 10000] - the interval between emitting addresses in milliseconds\n *\n */\n constructor (options = { list: [] }) {\n if (!options.list || !options.list.length) {\n throw new Error('Bootstrap requires a list of peer addresses')\n }\n super()\n\n this._list = options.list\n this._interval = options.interval || 10000\n this._timer = null\n }\n\n /**\n * Start emitting events.\n */\n start () {\n if (this._timer) {\n return\n }\n\n this._timer = setInterval(() => this._discoverBootstrapPeers(), this._interval)\n log('Starting bootstrap node discovery')\n this._discoverBootstrapPeers()\n }\n\n /**\n * Emit each address in the list as a PeerInfo.\n */\n _discoverBootstrapPeers () {\n if (!this._timer) {\n return\n }\n\n this._list.forEach((candidate) => {\n if (!mafmt.P2P.matches(candidate)) {\n return log.error('Invalid multiaddr')\n }\n\n const ma = new Multiaddr(candidate)\n const peerIdStr = ma.getPeerId()\n\n if (!peerIdStr) {\n log.error('Invalid bootstrap multiaddr without peer id')\n return\n }\n\n const peerId = PeerId.createFromB58String(peerIdStr)\n\n try {\n this.emit('peer', {\n id: peerId,\n multiaddrs: [ma]\n })\n } catch (err) {\n log.error('Invalid bootstrap peer id', err)\n }\n })\n }\n\n /**\n * Stop emitting events.\n */\n stop () {\n if (this._timer) clearInterval(this._timer)\n this._timer = null\n }\n}\n\nexports = module.exports = Bootstrap\nexports.tag = 'bootstrap'\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p'), {\n error: debug('libp2p:err')\n})\nconst { EventEmitter } = require('events')\n\nconst errCode = require('err-code')\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\n\nconst PeerRouting = require('./peer-routing')\nconst ContentRouting = require('./content-routing')\nconst getPeer = require('./get-peer')\nconst { validate: validateConfig } = require('./config')\nconst { codes, messages } = require('./errors')\n\nconst AddressManager = require('./address-manager')\nconst ConnectionManager = require('./connection-manager')\nconst Circuit = require('./circuit/transport')\nconst Relay = require('./circuit')\nconst Dialer = require('./dialer')\nconst Keychain = require('./keychain')\nconst Metrics = require('./metrics')\nconst TransportManager = require('./transport-manager')\nconst Upgrader = require('./upgrader')\nconst PeerStore = require('./peer-store')\nconst PubsubAdapter = require('./pubsub-adapter')\nconst PersistentPeerStore = require('./peer-store/persistent')\nconst Registrar = require('./registrar')\nconst ping = require('./ping')\nconst IdentifyService = require('./identify')\nconst NatManager = require('./nat-manager')\nconst { updateSelfPeerRecord } = require('./record/utils')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('libp2p-interfaces/src/transport/types').TransportFactory<any, any>} TransportFactory\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxerFactory} MuxerFactory\n * @typedef {import('libp2p-interfaces/src/content-routing/types').ContentRouting} ContentRoutingModule\n * @typedef {import('libp2p-interfaces/src/peer-discovery/types').PeerDiscoveryFactory} PeerDiscoveryFactory\n * @typedef {import('libp2p-interfaces/src/peer-routing/types').PeerRouting} PeerRoutingModule\n * @typedef {import('libp2p-interfaces/src/crypto/types').Crypto} Crypto\n * @typedef {import('libp2p-interfaces/src/pubsub')} Pubsub\n * @typedef {import('libp2p-interfaces/src/pubsub').PubsubOptions} PubsubOptions\n * @typedef {import('interface-datastore').Datastore} Datastore\n * @typedef {import('./pnet')} Protector\n */\n\n/**\n * @typedef {Object} HandlerProps\n * @property {Connection} connection\n * @property {MuxedStream} stream\n * @property {string} protocol\n *\n * @typedef {Object} RandomWalkOptions\n * @property {boolean} [enabled = false]\n * @property {number} [queriesPerPeriod = 1]\n * @property {number} [interval = 300e3]\n * @property {number} [timeout = 10e3]\n *\n * @typedef {Object} DhtOptions\n * @property {boolean} [enabled = false]\n * @property {number} [kBucketSize = 20]\n * @property {RandomWalkOptions} [randomWalk]\n * @property {boolean} [clientMode]\n * @property {import('libp2p-interfaces/src/types').DhtSelectors} [selectors]\n * @property {import('libp2p-interfaces/src/types').DhtValidators} [validators]\n *\n * @typedef {Object} KeychainOptions\n * @property {Datastore} [datastore]\n *\n * @typedef {Object} PeerStoreOptions\n * @property {boolean} persistence\n *\n * @typedef {Object} PubsubLocalOptions\n * @property {boolean} enabled\n *\n * @typedef {Object} MetricsOptions\n * @property {boolean} enabled\n *\n * @typedef {Object} RelayOptions\n * @property {boolean} [enabled = true]\n * @property {import('./circuit').RelayAdvertiseOptions} [advertise]\n * @property {import('./circuit').HopOptions} [hop]\n * @property {import('./circuit').AutoRelayOptions} [autoRelay]\n *\n * @typedef {Object} Libp2pConfig\n * @property {DhtOptions} [dht] dht module options\n * @property {import('./nat-manager').NatManagerOptions} [nat]\n * @property {Record<string, Object|boolean>} [peerDiscovery]\n * @property {PubsubLocalOptions & PubsubOptions} [pubsub] pubsub module options\n * @property {RelayOptions} [relay]\n * @property {Record<string, Object>} [transport] transport options indexed by transport key\n *\n * @typedef {Object} Libp2pModules\n * @property {TransportFactory[]} transport\n * @property {MuxerFactory[]} streamMuxer\n * @property {Crypto[]} connEncryption\n * @property {PeerDiscoveryFactory[]} [peerDiscovery]\n * @property {PeerRoutingModule[]} [peerRouting]\n * @property {ContentRoutingModule[]} [contentRouting]\n * @property {Object} [dht]\n * @property {{new(...args: any[]): Pubsub}} [pubsub]\n * @property {Protector} [connProtector]\n *\n * @typedef {Object} Libp2pOptions\n * @property {Libp2pModules} modules libp2p modules to use\n * @property {import('./address-manager').AddressManagerOptions} [addresses]\n * @property {import('./connection-manager').ConnectionManagerOptions} [connectionManager]\n * @property {Datastore} [datastore]\n * @property {import('./dialer').DialerOptions} [dialer]\n * @property {import('./identify/index').HostProperties} [host] libp2p host\n * @property {KeychainOptions & import('./keychain/index').KeychainOptions} [keychain]\n * @property {MetricsOptions & import('./metrics').MetricsOptions} [metrics]\n * @property {import('./peer-routing').PeerRoutingOptions} [peerRouting]\n * @property {PeerStoreOptions & import('./peer-store/persistent').PersistentPeerStoreOptions} [peerStore]\n * @property {import('./transport-manager').TransportManagerOptions} [transportManager]\n * @property {Libp2pConfig} [config]\n *\n * @typedef {Object} constructorOptions\n * @property {PeerId} peerId\n *\n * @typedef {Object} CreateOptions\n * @property {PeerId} [peerId]\n *\n * @extends {EventEmitter}\n * @fires Libp2p#error Emitted when an error occurs\n * @fires Libp2p#peer:discovery Emitted when a peer is discovered\n */\nclass Libp2p extends EventEmitter {\n /**\n * Like `new Libp2p(options)` except it will create a `PeerId`\n * instance if one is not provided in options.\n *\n * @param {Libp2pOptions & CreateOptions} options - Libp2p configuration options\n * @returns {Promise<Libp2p>}\n */\n static async create (options) {\n if (options.peerId) {\n // @ts-ignore 'Libp2pOptions & CreateOptions' is not assignable to 'Libp2pOptions & constructorOptions'\n return new Libp2p(options)\n }\n\n const peerId = await PeerId.create()\n\n options.peerId = peerId\n // @ts-ignore 'Libp2pOptions & CreateOptions' is not assignable to 'Libp2pOptions & constructorOptions'\n return new Libp2p(options)\n }\n\n /**\n * Libp2p node.\n *\n * @class\n * @param {Libp2pOptions & constructorOptions} _options\n */\n constructor (_options) {\n super()\n // validateConfig will ensure the config is correct,\n // and add default values where appropriate\n this._options = validateConfig(_options)\n\n /** @type {PeerId} */\n this.peerId = this._options.peerId\n this.datastore = this._options.datastore\n\n this.peerStore = (this.datastore && this._options.peerStore.persistence)\n ? new PersistentPeerStore({\n peerId: this.peerId,\n datastore: this.datastore,\n ...this._options.peerStore\n })\n : new PeerStore({ peerId: this.peerId })\n\n // Addresses {listen, announce, noAnnounce}\n this.addresses = this._options.addresses\n this.addressManager = new AddressManager(this.peerId, this._options.addresses)\n\n // when addresses change, update our peer record\n this.addressManager.on('change:addresses', () => {\n updateSelfPeerRecord(this).catch(err => {\n log.error('Error updating self peer record', err)\n })\n })\n\n this._modules = this._options.modules\n this._config = this._options.config\n this._transport = [] // Transport instances/references\n this._discovery = new Map() // Discovery service instances/references\n\n // Create the Connection Manager\n this.connectionManager = new ConnectionManager(this, {\n autoDial: this._config.peerDiscovery.autoDial,\n ...this._options.connectionManager\n })\n\n // Create Metrics\n if (this._options.metrics.enabled) {\n this.metrics = new Metrics({\n ...this._options.metrics,\n connectionManager: this.connectionManager\n })\n }\n\n // Create keychain\n if (this._options.keychain && this._options.keychain.datastore) {\n log('creating keychain')\n\n const keychainOpts = Keychain.generateOptions()\n\n this.keychain = new Keychain(this._options.keychain.datastore, {\n ...keychainOpts,\n ...this._options.keychain\n })\n\n log('keychain constructed')\n }\n\n // Setup the Upgrader\n this.upgrader = new Upgrader({\n localPeer: this.peerId,\n metrics: this.metrics,\n onConnection: (connection) => this.connectionManager.onConnect(connection),\n onConnectionEnd: (connection) => this.connectionManager.onDisconnect(connection)\n })\n\n // Setup the transport manager\n this.transportManager = new TransportManager({\n libp2p: this,\n upgrader: this.upgrader,\n faultTolerance: this._options.transportManager.faultTolerance\n })\n\n // Create the Nat Manager\n this.natManager = new NatManager({\n peerId: this.peerId,\n addressManager: this.addressManager,\n transportManager: this.transportManager,\n // @ts-ignore Nat typedef is not understood as Object\n ...this._options.config.nat\n })\n\n // Create the Registrar\n this.registrar = new Registrar({\n peerStore: this.peerStore,\n connectionManager: this.connectionManager\n })\n\n this.handle = this.handle.bind(this)\n this.registrar.handle = this.handle\n\n // Attach crypto channels\n if (!this._modules.connEncryption || !this._modules.connEncryption.length) {\n throw errCode(new Error(messages.CONN_ENCRYPTION_REQUIRED), codes.CONN_ENCRYPTION_REQUIRED)\n }\n const cryptos = this._modules.connEncryption\n cryptos.forEach((crypto) => {\n this.upgrader.cryptos.set(crypto.protocol, crypto)\n })\n\n this.dialer = new Dialer({\n transportManager: this.transportManager,\n peerStore: this.peerStore,\n ...this._options.dialer\n })\n\n this._modules.transport.forEach((Transport) => {\n const key = Transport.prototype[Symbol.toStringTag]\n const transportOptions = this._config.transport[key]\n this.transportManager.add(key, Transport, transportOptions)\n })\n\n if (this._config.relay.enabled) {\n // @ts-ignore Circuit prototype\n this.transportManager.add(Circuit.prototype[Symbol.toStringTag], Circuit)\n this.relay = new Relay(this)\n }\n\n // Attach stream multiplexers\n if (this._modules.streamMuxer) {\n const muxers = this._modules.streamMuxer\n muxers.forEach((muxer) => {\n this.upgrader.muxers.set(muxer.multicodec, muxer)\n })\n\n // Add the identify service since we can multiplex\n this.identifyService = new IdentifyService({ libp2p: this })\n this.handle(Object.values(IdentifyService.getProtocolStr(this)), this.identifyService.handleMessage)\n }\n\n // Attach private network protector\n if (this._modules.connProtector) {\n this.upgrader.protector = this._modules.connProtector\n } else if (globalThis.process !== undefined && globalThis.process.env && globalThis.process.env.LIBP2P_FORCE_PNET) { // eslint-disable-line no-undef\n throw new Error('Private network is enforced, but no protector was provided')\n }\n\n // dht provided components (peerRouting, contentRouting, dht)\n if (this._modules.dht) {\n const DHT = this._modules.dht\n // @ts-ignore Object is not constructable\n this._dht = new DHT({\n libp2p: this,\n dialer: this.dialer,\n peerId: this.peerId,\n peerStore: this.peerStore,\n registrar: this.registrar,\n datastore: this.datastore,\n ...this._config.dht\n })\n }\n\n // Create pubsub if provided\n if (this._modules.pubsub) {\n const Pubsub = this._modules.pubsub\n // using pubsub adapter with *DEPRECATED* handlers functionality\n /** @type {Pubsub} */\n this.pubsub = PubsubAdapter(Pubsub, this, this._config.pubsub)\n }\n\n // Attach remaining APIs\n // peer and content routing will automatically get modules from _modules and _dht\n this.peerRouting = new PeerRouting(this)\n this.contentRouting = new ContentRouting(this)\n\n // Mount default protocols\n ping.mount(this)\n\n this._onDiscoveryPeer = this._onDiscoveryPeer.bind(this)\n }\n\n /**\n * Overrides EventEmitter.emit to conditionally emit errors\n * if there is a handler. If not, errors will be logged.\n *\n * @param {string} eventName\n * @param {...any} args\n * @returns {boolean}\n */\n emit (eventName, ...args) {\n // TODO: do we still need this?\n // @ts-ignore _events does not exist in libp2p\n if (eventName === 'error' && !this._events.error) {\n log.error(args)\n return false\n } else {\n return super.emit(eventName, ...args)\n }\n }\n\n /**\n * Starts the libp2p node and all its subsystems\n *\n * @returns {Promise<void>}\n */\n async start () {\n log('libp2p is starting')\n\n try {\n await this._onStarting()\n await this._onDidStart()\n log('libp2p has started')\n } catch (err) {\n this.emit('error', err)\n log.error('An error occurred starting libp2p', err)\n await this.stop()\n throw err\n }\n }\n\n /**\n * Stop the libp2p node by closing its listeners and open connections\n *\n * @async\n * @returns {Promise<void>}\n */\n async stop () {\n log('libp2p is stopping')\n\n try {\n this._isStarted = false\n\n this.relay && this.relay.stop()\n this.peerRouting.stop()\n\n for (const service of this._discovery.values()) {\n service.removeListener('peer', this._onDiscoveryPeer)\n }\n\n await Promise.all(Array.from(this._discovery.values(), s => s.stop()))\n\n this._discovery = new Map()\n\n await this.peerStore.stop()\n await this.connectionManager.stop()\n\n await Promise.all([\n this.pubsub && this.pubsub.stop(),\n this._dht && this._dht.stop(),\n this.metrics && this.metrics.stop()\n ])\n\n await this.natManager.stop()\n await this.transportManager.close()\n\n ping.unmount(this)\n this.dialer.destroy()\n } catch (err) {\n if (err) {\n log.error(err)\n this.emit('error', err)\n }\n }\n log('libp2p has stopped')\n }\n\n /**\n * Load keychain keys from the datastore.\n * Imports the private key as 'self', if needed.\n *\n * @async\n * @returns {Promise<void>}\n */\n async loadKeychain () {\n if (!this.keychain) {\n return\n }\n\n try {\n await this.keychain.findKeyByName('self')\n } catch (err) {\n await this.keychain.importPeer('self', this.peerId)\n }\n }\n\n isStarted () {\n return this._isStarted\n }\n\n /**\n * Gets a Map of the current connections. The keys are the stringified\n * `PeerId` of the peer. The value is an array of Connections to that peer.\n *\n * @returns {Map<string, Connection[]>}\n */\n get connections () {\n return this.connectionManager.connections\n }\n\n /**\n * Dials to the provided peer. If successful, the known metadata of the\n * peer will be added to the nodes `peerStore`\n *\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @param {object} [options]\n * @param {AbortSignal} [options.signal]\n * @returns {Promise<Connection>}\n */\n dial (peer, options) {\n return this._dial(peer, options)\n }\n\n /**\n * Dials to the provided peer and tries to handshake with the given protocols in order.\n * If successful, the known metadata of the peer will be added to the nodes `peerStore`,\n * and the `MuxedStream` will be returned together with the successful negotiated protocol.\n *\n * @async\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @param {string[]|string} protocols\n * @param {object} [options]\n * @param {AbortSignal} [options.signal]\n */\n async dialProtocol (peer, protocols, options) {\n if (!protocols || !protocols.length) {\n throw errCode(new Error('no protocols were provided to open a stream'), codes.ERR_INVALID_PROTOCOLS_FOR_STREAM)\n }\n\n const connection = await this._dial(peer, options)\n return connection.newStream(protocols)\n }\n\n /**\n * @async\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @param {object} [options]\n * @returns {Promise<Connection>}\n */\n async _dial (peer, options) {\n const { id, multiaddrs } = getPeer(peer)\n\n if (id.equals(this.peerId)) {\n throw errCode(new Error('Cannot dial self'), codes.ERR_DIALED_SELF)\n }\n\n let connection = this.connectionManager.get(id)\n\n if (!connection) {\n connection = await this.dialer.connectToPeer(peer, options)\n } else if (multiaddrs) {\n this.peerStore.addressBook.add(id, multiaddrs)\n }\n\n return connection\n }\n\n /**\n * Get a deduplicated list of peer advertising multiaddrs by concatenating\n * the listen addresses used by transports with any configured\n * announce addresses as well as observed addresses reported by peers.\n *\n * If Announce addrs are specified, configured listen addresses will be\n * ignored though observed addresses will still be included.\n *\n * @returns {Multiaddr[]}\n */\n get multiaddrs () {\n let addrs = this.addressManager.getAnnounceAddrs().map(ma => ma.toString())\n\n if (!addrs.length) {\n // no configured announce addrs, add configured listen addresses\n addrs = this.transportManager.getAddrs().map(ma => ma.toString())\n }\n\n addrs = addrs.concat(this.addressManager.getObservedAddrs().map(ma => ma.toString()))\n\n const announceFilter = this._options.addresses.announceFilter\n\n // dedupe multiaddrs\n const addrSet = new Set(addrs)\n\n // Create advertising list\n return announceFilter(Array.from(addrSet).map(str => new Multiaddr(str)))\n }\n\n /**\n * Disconnects all connections to the given `peer`\n *\n * @param {PeerId|Multiaddr|string} peer - the peer to close connections to\n * @returns {Promise<void>}\n */\n async hangUp (peer) {\n const { id } = getPeer(peer)\n\n const connections = this.connectionManager.connections.get(id.toB58String())\n\n if (!connections) {\n return\n }\n\n await Promise.all(\n connections.map(connection => {\n return connection.close()\n })\n )\n }\n\n /**\n * Pings the given peer in order to obtain the operation latency.\n *\n * @param {PeerId|Multiaddr|string} peer - The peer to ping\n * @returns {Promise<number>}\n */\n ping (peer) {\n const { id, multiaddrs } = getPeer(peer)\n\n // If received multiaddr, ping it\n if (multiaddrs) {\n return ping(this, multiaddrs[0])\n }\n\n return ping(this, id)\n }\n\n /**\n * Registers the `handler` for each protocol\n *\n * @param {string[]|string} protocols\n * @param {(props: HandlerProps) => void} handler\n */\n handle (protocols, handler) {\n protocols = Array.isArray(protocols) ? protocols : [protocols]\n protocols.forEach(protocol => {\n this.upgrader.protocols.set(protocol, handler)\n })\n\n // Add new protocols to self protocols in the Protobook\n this.peerStore.protoBook.add(this.peerId, protocols)\n }\n\n /**\n * Removes the handler for each protocol. The protocol\n * will no longer be supported on streams.\n *\n * @param {string[]|string} protocols\n */\n unhandle (protocols) {\n protocols = Array.isArray(protocols) ? protocols : [protocols]\n protocols.forEach(protocol => {\n this.upgrader.protocols.delete(protocol)\n })\n\n // Remove protocols from self protocols in the Protobook\n this.peerStore.protoBook.remove(this.peerId, protocols)\n }\n\n async _onStarting () {\n // Listen on the provided transports for the provided addresses\n const addrs = this.addressManager.getListenAddrs()\n await this.transportManager.listen(addrs)\n\n // Manage your NATs\n this.natManager.start()\n\n // Start PeerStore\n await this.peerStore.start()\n\n if (this._config.pubsub.enabled) {\n this.pubsub && this.pubsub.start()\n }\n\n // DHT subsystem\n if (this._config.dht.enabled) {\n this._dht && this._dht.start()\n\n // TODO: this should be modified once random-walk is used as\n // the other discovery modules\n this._dht.on('peer', this._onDiscoveryPeer)\n }\n\n // Start metrics if present\n this.metrics && this.metrics.start()\n }\n\n /**\n * Called when libp2p has started and before it returns\n *\n * @private\n */\n async _onDidStart () {\n this._isStarted = true\n\n this.peerStore.on('peer', peerId => {\n this.emit('peer:discovery', peerId)\n this._maybeConnect(peerId)\n })\n\n // Once we start, emit any peers we may have already discovered\n // TODO: this should be removed, as we already discovered these peers in the past\n for (const peer of this.peerStore.peers.values()) {\n this.emit('peer:discovery', peer.id)\n }\n\n this.connectionManager.start()\n\n // Peer discovery\n await this._setupPeerDiscovery()\n\n // Relay\n this.relay && this.relay.start()\n\n this.peerRouting.start()\n }\n\n /**\n * Called whenever peer discovery services emit `peer` events.\n * Known peers may be emitted.\n *\n * @private\n * @param {{ id: PeerId, multiaddrs: Multiaddr[], protocols: string[] }} peer\n */\n _onDiscoveryPeer (peer) {\n if (peer.id.toB58String() === this.peerId.toB58String()) {\n log.error(new Error(codes.ERR_DISCOVERED_SELF))\n return\n }\n\n peer.multiaddrs && this.peerStore.addressBook.add(peer.id, peer.multiaddrs)\n peer.protocols && this.peerStore.protoBook.set(peer.id, peer.protocols)\n }\n\n /**\n * Will dial to the given `peerId` if the current number of\n * connected peers is less than the configured `ConnectionManager`\n * minConnections.\n *\n * @private\n * @param {PeerId} peerId\n */\n async _maybeConnect (peerId) {\n // If auto dialing is on and we have no connection to the peer, check if we should dial\n if (this._config.peerDiscovery.autoDial === true && !this.connectionManager.get(peerId)) {\n const minConnections = this._options.connectionManager.minConnections || 0\n if (minConnections > this.connectionManager.size) {\n log('connecting to discovered peer %s', peerId.toB58String())\n try {\n await this.dialer.connectToPeer(peerId)\n } catch (err) {\n log.error(`could not connect to discovered peer ${peerId.toB58String()} with ${err}`)\n }\n }\n }\n }\n\n /**\n * Initializes and starts peer discovery services\n *\n * @async\n * @private\n */\n async _setupPeerDiscovery () {\n /**\n * @param {PeerDiscoveryFactory} DiscoveryService\n */\n const setupService = (DiscoveryService) => {\n let config = {\n enabled: true // on by default\n }\n\n if (DiscoveryService.tag &&\n this._config.peerDiscovery &&\n this._config.peerDiscovery[DiscoveryService.tag]) {\n // @ts-ignore PeerDiscovery not understood as an Object for spread\n config = { ...config, ...this._config.peerDiscovery[DiscoveryService.tag] }\n }\n\n if (config.enabled &&\n !this._discovery.has(DiscoveryService.tag)) { // not already added\n let discoveryService\n\n if (typeof DiscoveryService === 'function') {\n // @ts-ignore DiscoveryService has no constructor type inferred\n discoveryService = new DiscoveryService(Object.assign({}, config, {\n peerId: this.peerId,\n libp2p: this\n }))\n } else {\n discoveryService = DiscoveryService\n }\n\n discoveryService.on('peer', this._onDiscoveryPeer)\n this._discovery.set(DiscoveryService.tag, discoveryService)\n }\n }\n\n // Discovery modules\n for (const DiscoveryService of this._modules.peerDiscovery || []) {\n setupService(DiscoveryService)\n }\n\n // Transport modules with discovery\n for (const Transport of this.transportManager.getTransports()) {\n // @ts-ignore Transport interface does not include discovery\n if (Transport.discovery) {\n // @ts-ignore Transport interface does not include discovery\n setupService(Transport.discovery)\n }\n }\n\n await Promise.all(Array.from(this._discovery.values(), d => d.start()))\n }\n}\n\nmodule.exports = Libp2p\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-routing'), {\n error: debug('libp2p:peer-routing:err')\n})\nconst errCode = require('err-code')\nconst {\n storeAddresses,\n uniquePeers,\n requirePeers\n} = require('./content-routing/utils')\n\nconst merge = require('it-merge')\nconst { pipe } = require('it-pipe')\nconst first = require('it-first')\nconst drain = require('it-drain')\nconst filter = require('it-filter')\nconst {\n setDelayedInterval,\n clearDelayedInterval\n// @ts-ignore module with no types\n} = require('set-delayed-interval')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('libp2p-interfaces/src/peer-routing/types').PeerRouting} PeerRoutingModule\n */\n\n/**\n * @typedef {Object} RefreshManagerOptions\n * @property {boolean} [enabled = true] - Whether to enable the Refresh manager\n * @property {number} [bootDelay = 6e5] - Boot delay to start the Refresh Manager (in ms)\n * @property {number} [interval = 10e3] - Interval between each Refresh Manager run (in ms)\n *\n * @typedef {Object} PeerRoutingOptions\n * @property {RefreshManagerOptions} [refreshManager]\n */\n\nclass PeerRouting {\n /**\n * @class\n * @param {import('./')} libp2p\n */\n constructor (libp2p) {\n this._peerId = libp2p.peerId\n this._peerStore = libp2p.peerStore\n /** @type {PeerRoutingModule[]} */\n this._routers = libp2p._modules.peerRouting || []\n\n // If we have the dht, add it to the available peer routers\n if (libp2p._dht && libp2p._config.dht.enabled) {\n this._routers.push(libp2p._dht)\n }\n\n this._refreshManagerOptions = libp2p._options.peerRouting.refreshManager\n\n this._findClosestPeersTask = this._findClosestPeersTask.bind(this)\n }\n\n /**\n * Start peer routing service.\n */\n start () {\n if (!this._routers.length || this._timeoutId || !this._refreshManagerOptions.enabled) {\n return\n }\n\n this._timeoutId = setDelayedInterval(\n this._findClosestPeersTask, this._refreshManagerOptions.interval, this._refreshManagerOptions.bootDelay\n )\n }\n\n /**\n * Recurrent task to find closest peers and add their addresses to the Address Book.\n */\n async _findClosestPeersTask () {\n try {\n // nb getClosestPeers adds the addresses to the address book\n await drain(this.getClosestPeers(this._peerId.id))\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Stop peer routing service.\n */\n stop () {\n clearDelayedInterval(this._timeoutId)\n }\n\n /**\n * Iterates over all peer routers in parallel to find the given peer.\n *\n * @param {PeerId} id - The id of the peer to find\n * @param {object} [options]\n * @param {number} [options.timeout] - How long the query should run\n * @returns {Promise<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async findPeer (id, options) { // eslint-disable-line require-await\n if (!this._routers.length) {\n throw errCode(new Error('No peer routers available'), 'NO_ROUTERS_AVAILABLE')\n }\n\n if (id.toB58String() === this._peerId.toB58String()) {\n throw errCode(new Error('Should not try to find self'), 'ERR_FIND_SELF')\n }\n\n const output = await pipe(\n merge(\n ...this._routers.map(router => [router.findPeer(id, options)])\n ),\n (source) => filter(source, Boolean),\n // @ts-ignore findPeer resolves a Promise\n (source) => storeAddresses(source, this._peerStore),\n (source) => first(source)\n )\n\n if (output) {\n return output\n }\n\n throw errCode(new Error('not found'), 'NOT_FOUND')\n }\n\n /**\n * Attempt to find the closest peers on the network to the given key.\n *\n * @param {Uint8Array} key - A CID like key\n * @param {Object} [options]\n * @param {number} [options.timeout=30e3] - How long the query can take.\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * getClosestPeers (key, options = { timeout: 30e3 }) {\n if (!this._routers.length) {\n throw errCode(new Error('No peer routers available'), 'NO_ROUTERS_AVAILABLE')\n }\n\n yield * pipe(\n merge(\n ...this._routers.map(router => router.getClosestPeers(key, options))\n ),\n (source) => storeAddresses(source, this._peerStore),\n (source) => uniquePeers(source),\n (source) => requirePeers(source)\n )\n }\n}\n\nmodule.exports = PeerRouting\n","'use strict'\n\nconst errCode = require('err-code')\nconst filter = require('it-filter')\nconst map = require('it-map')\nconst take = require('it-take')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * Store the multiaddrs from every peer in the passed peer store\n *\n * @param {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} source\n * @param {import('../peer-store')} peerStore\n */\nfunction storeAddresses (source, peerStore) {\n return map(source, (peer) => {\n // ensure we have the addresses for a given peer\n peerStore.addressBook.add(peer.id, peer.multiaddrs)\n\n return peer\n })\n}\n\n/**\n * Filter peers by unique peer id\n *\n * @param {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} source\n */\nfunction uniquePeers (source) {\n /** @type Set<string> */\n const seen = new Set()\n\n return filter(source, (peer) => {\n // dedupe by peer id\n if (seen.has(peer.id.toString())) {\n return false\n }\n\n seen.add(peer.id.toString())\n\n return true\n })\n}\n\n/**\n * Require at least `min` peers to be yielded from `source`\n *\n * @param {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} source\n * @param {number} min\n */\nasync function * requirePeers (source, min = 1) {\n let seen = 0\n\n for await (const peer of source) {\n seen++\n\n yield peer\n }\n\n if (seen < min) {\n throw errCode(new Error('not found'), 'NOT_FOUND')\n }\n}\n\n/**\n * If `max` is passed, only take that number of peers from the source\n * otherwise take all the peers\n *\n * @param {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>} source\n * @param {number} [max]\n */\nfunction maybeLimitSource (source, max) {\n if (max) {\n return take(source, max)\n }\n\n return source\n}\n\nmodule.exports = {\n storeAddresses,\n uniquePeers,\n requirePeers,\n maybeLimitSource\n}\n","'use strict'\n\nconst intervals = new Map()\n\nconst _generateId = () => `${Date.now()}:${Math.floor(Math.random() * 1000000)}`\n\n/**\n * Run a given task each {interval} ms\n *\n * @param {() => Promise} task\n * @param {number} interval\n * @param {string} id\n */\nasync function _runPeriodically (task, interval, id) {\n while (intervals.get(id)) {\n try {\n await task()\n } catch (err) {\n // Throw global context error if handler throws\n setTimeout(() => { throw err }, 1)\n break\n }\n\n if (!intervals.get(id)) {\n break\n }\n\n await new Promise(resolve => {\n const _timeout = setTimeout(resolve, interval)\n\n intervals.set(id, _timeout)\n })\n }\n}\n\n/**\n * Asynchronous setInterval that is properly delayed using promises and can be delayed on boot.\n *\n * @param {() => Promise} task\n * @param {number} interval\n * @param {number} [delay = interval]\n * @returns {string}\n */\nfunction setDelayedInterval (task, interval, delay) {\n delay = delay || interval\n\n const id = _generateId()\n const _timeout = setTimeout(() => {\n _runPeriodically(task, interval, id)\n }, delay)\n\n intervals.set(id, _timeout)\n\n return id\n}\n\n/**\n * Clear delayed interval.\n *\n * @param {string} id\n */\nfunction clearDelayedInterval (id) {\n const _timeout = intervals.get(id)\n\n if (_timeout) {\n clearTimeout(_timeout)\n intervals.delete(id)\n }\n}\n\nmodule.exports = {\n setDelayedInterval,\n clearDelayedInterval\n}\n","'use strict'\n\nconst errCode = require('err-code')\nconst { messages, codes } = require('../errors')\nconst {\n storeAddresses,\n uniquePeers,\n requirePeers,\n maybeLimitSource\n} = require('./utils')\n\nconst merge = require('it-merge')\nconst { pipe } = require('it-pipe')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('multiformats/cid').CID} CID\n * @typedef {import('libp2p-interfaces/src/content-routing/types').ContentRouting} ContentRoutingModule\n */\n\n/**\n * @typedef {Object} GetData\n * @property {PeerId} from\n * @property {Uint8Array} val\n */\n\nclass ContentRouting {\n /**\n * @class\n * @param {import('..')} libp2p\n */\n constructor (libp2p) {\n this.libp2p = libp2p\n /** @type {ContentRoutingModule[]} */\n this.routers = libp2p._modules.contentRouting || []\n this.dht = libp2p._dht\n\n // If we have the dht, add it to the available content routers\n if (this.dht && libp2p._config.dht.enabled) {\n this.routers.push(this.dht)\n }\n }\n\n /**\n * Iterates over all content routers in parallel to find providers of the given key.\n *\n * @param {CID} key - The CID key of the content to find\n * @param {object} [options]\n * @param {number} [options.timeout] - How long the query should run\n * @param {number} [options.maxNumProviders] - maximum number of providers to find\n * @returns {AsyncIterable<{ id: PeerId, multiaddrs: Multiaddr[] }>}\n */\n async * findProviders (key, options = {}) {\n if (!this.routers.length) {\n throw errCode(new Error('No content this.routers available'), 'NO_ROUTERS_AVAILABLE')\n }\n\n yield * pipe(\n merge(\n ...this.routers.map(router => router.findProviders(key, options))\n ),\n (source) => storeAddresses(source, this.libp2p.peerStore),\n (source) => uniquePeers(source),\n (source) => maybeLimitSource(source, options.maxNumProviders),\n (source) => requirePeers(source)\n )\n }\n\n /**\n * Iterates over all content routers in parallel to notify it is\n * a provider of the given key.\n *\n * @param {CID} key - The CID key of the content to find\n * @returns {Promise<void>}\n */\n async provide (key) {\n if (!this.routers.length) {\n throw errCode(new Error('No content routers available'), 'NO_ROUTERS_AVAILABLE')\n }\n\n await Promise.all(this.routers.map((router) => router.provide(key)))\n }\n\n /**\n * Store the given key/value pair in the DHT.\n *\n * @param {Uint8Array} key\n * @param {Uint8Array} value\n * @param {Object} [options] - put options\n * @param {number} [options.minPeers] - minimum number of peers required to successfully put\n * @returns {Promise<void>}\n */\n put (key, value, options) {\n if (!this.libp2p.isStarted() || !this.dht.isStarted) {\n throw errCode(new Error(messages.NOT_STARTED_YET), codes.DHT_NOT_STARTED)\n }\n\n return this.dht.put(key, value, options)\n }\n\n /**\n * Get the value to the given key.\n * Times out after 1 minute by default.\n *\n * @param {Uint8Array} key\n * @param {Object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n * @returns {Promise<GetData>}\n */\n get (key, options) {\n if (!this.libp2p.isStarted() || !this.dht.isStarted) {\n throw errCode(new Error(messages.NOT_STARTED_YET), codes.DHT_NOT_STARTED)\n }\n\n return this.dht.get(key, options)\n }\n\n /**\n * Get the `n` values to the given key without sorting.\n *\n * @param {Uint8Array} key\n * @param {number} nVals\n * @param {Object} [options] - get options\n * @param {number} [options.timeout] - optional timeout (default: 60000)\n * @returns {Promise<GetData[]>}\n */\n async getMany (key, nVals, options) { // eslint-disable-line require-await\n if (!this.libp2p.isStarted() || !this.dht.isStarted) {\n throw errCode(new Error(messages.NOT_STARTED_YET), codes.DHT_NOT_STARTED)\n }\n\n return this.dht.getMany(key, nVals, options)\n }\n}\n\nmodule.exports = ContentRouting\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\nconst errCode = require('err-code')\n\nconst { codes } = require('./errors')\n\n/**\n * Converts the given `peer` to a `Peer` object.\n * If a multiaddr is received, the addressBook is updated.\n *\n * @param {PeerId|Multiaddr|string} peer\n * @returns {{ id: PeerId, multiaddrs: Multiaddr[]|undefined }}\n */\nfunction getPeer (peer) {\n if (typeof peer === 'string') {\n peer = new Multiaddr(peer)\n }\n\n let addr\n if (Multiaddr.isMultiaddr(peer)) {\n addr = peer\n const idStr = peer.getPeerId()\n\n if (!idStr) {\n throw errCode(\n new Error(`${peer} does not have a valid peer type`),\n codes.ERR_INVALID_MULTIADDR\n )\n }\n\n try {\n peer = PeerId.createFromB58String(idStr)\n } catch (err) {\n throw errCode(\n new Error(`${peer} is not a valid peer type`),\n codes.ERR_INVALID_MULTIADDR\n )\n }\n }\n\n return {\n id: peer,\n multiaddrs: addr ? [addr] : undefined\n }\n}\n\nmodule.exports = getPeer\n","'use strict'\n\nconst mergeOptions = require('merge-options')\n// @ts-ignore no types in multiaddr path\nconst { dnsaddrResolver } = require('multiaddr/src/resolvers')\n\nconst Constants = require('./constants')\nconst { AGENT_VERSION } = require('./identify/consts')\nconst RelayConstants = require('./circuit/constants')\n\nconst { publicAddressesFirst } = require('libp2p-utils/src/address-sort')\nconst { FaultTolerance } = require('./transport-manager')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('.').Libp2pOptions} Libp2pOptions\n * @typedef {import('.').constructorOptions} constructorOptions\n */\n\nconst DefaultConfig = {\n addresses: {\n listen: [],\n announce: [],\n noAnnounce: [],\n announceFilter: (/** @type {Multiaddr[]} */ multiaddrs) => multiaddrs\n },\n connectionManager: {\n minConnections: 25\n },\n transportManager: {\n faultTolerance: FaultTolerance.FATAL_ALL\n },\n dialer: {\n maxParallelDials: Constants.MAX_PARALLEL_DIALS,\n maxDialsPerPeer: Constants.MAX_PER_PEER_DIALS,\n dialTimeout: Constants.DIAL_TIMEOUT,\n resolvers: {\n dnsaddr: dnsaddrResolver\n },\n addressSorter: publicAddressesFirst\n },\n host: {\n agentVersion: AGENT_VERSION\n },\n metrics: {\n enabled: false\n },\n peerStore: {\n persistence: false,\n threshold: 5\n },\n peerRouting: {\n refreshManager: {\n enabled: true,\n interval: 6e5,\n bootDelay: 10e3\n }\n },\n config: {\n protocolPrefix: 'ipfs',\n dht: {\n enabled: false,\n kBucketSize: 20,\n randomWalk: {\n enabled: false, // disabled waiting for https://github.com/libp2p/js-libp2p-kad-dht/issues/86\n queriesPerPeriod: 1,\n interval: 300e3,\n timeout: 10e3\n }\n },\n nat: {\n enabled: true,\n ttl: 7200,\n keepAlive: true,\n gateway: null,\n externalIp: null,\n pmp: {\n enabled: false\n }\n },\n peerDiscovery: {\n autoDial: true\n },\n pubsub: {\n enabled: true\n },\n relay: {\n enabled: true,\n advertise: {\n bootDelay: RelayConstants.ADVERTISE_BOOT_DELAY,\n enabled: false,\n ttl: RelayConstants.ADVERTISE_TTL\n },\n hop: {\n enabled: false,\n active: false\n },\n autoRelay: {\n enabled: false,\n maxListeners: 2\n }\n },\n transport: {}\n }\n}\n\n/**\n * @param {Libp2pOptions} opts\n * @returns {DefaultConfig & Libp2pOptions & constructorOptions}\n */\nmodule.exports.validate = (opts) => {\n /** @type {DefaultConfig & Libp2pOptions & constructorOptions} */\n const resultingOptions = mergeOptions(DefaultConfig, opts)\n\n if (resultingOptions.modules.transport.length < 1) throw new Error(\"'options.modules.transport' must contain at least 1 transport\")\n\n return resultingOptions\n}\n","'use strict'\n\nconst protocols = require('../protocols-table')\n\nconst { code: dnsaddrCode } = protocols('dnsaddr')\n\n/**\n * @typedef {import('..').Multiaddr} Multiaddr\n */\n\n/**\n * Resolver for dnsaddr addresses.\n *\n * @param {Multiaddr} addr\n * @returns {Promise<string[]>}\n */\nasync function dnsaddrResolver (addr) {\n const Resolver = require('./dns')\n const resolver = new Resolver()\n\n const peerId = addr.getPeerId()\n const [, hostname] = addr.stringTuples().find(([proto]) => proto === dnsaddrCode) || []\n\n const records = await resolver.resolveTxt(`_dnsaddr.${hostname}`)\n let addresses = records.flat().map((a) => a.split('=')[1])\n\n if (peerId) {\n addresses = addresses.filter((entry) => entry.includes(peerId))\n }\n\n return addresses\n}\n\nmodule.exports = {\n dnsaddrResolver\n}\n","'use strict'\n\n/** @type {import('dns').promises.Resolver} */\n// @ts-ignore - has no types\nconst dns = require('dns-over-http-resolver')\n\nmodule.exports = dns\n","'use strict'\nconst debug = require('debug')\nconst log = debug('dns-over-http-resolver')\nlog.error = debug('dns-over-http-resolver:error')\n\nconst Receptacle = require('receptacle')\n\nconst utils = require('./utils')\n\n/**\n * DNS over HTTP resolver.\n * Uses a list of servers to resolve DNS records with HTTP requests.\n */\nclass Resolver {\n /**\n * @class\n * @param {object} [properties]\n * @param {number} [properties.maxCache = 100] - maximum number of cached dns records.\n */\n constructor ({ maxCache = 100 } = {}) {\n this._cache = new Receptacle({ max: maxCache })\n this._servers = [\n 'https://cloudflare-dns.com/dns-query',\n 'https://dns.google/resolve'\n ]\n }\n\n /**\n * Get an array of the IP addresses currently configured for DNS resolution.\n * These addresses are formatted according to RFC 5952. It can include a custom port.\n *\n * @returns {Array<string>}\n */\n getServers () {\n return this._servers\n }\n\n /**\n * Get a shuffled array of the IP addresses currently configured for DNS resolution.\n * These addresses are formatted according to RFC 5952. It can include a custom port.\n *\n * @returns {Array<string>}\n */\n _getShuffledServers () {\n const newServers = [].concat(this._servers)\n\n for (let i = newServers.length - 1; i > 0; i--) {\n const j = Math.floor(Math.random() * i)\n const temp = newServers[i]\n newServers[i] = newServers[j]\n newServers[j] = temp\n }\n\n return newServers\n }\n\n /**\n * Sets the IP address and port of servers to be used when performing DNS resolution.\n *\n * @param {Array<string>} servers - array of RFC 5952 formatted addresses.\n */\n setServers (servers) {\n this._servers = servers\n }\n\n /**\n * Uses the DNS protocol to resolve the given host name into the appropriate DNS record.\n *\n * @param {string} hostname - host name to resolve.\n * @param {string} [rrType = 'A'] - resource record type.\n * @returns {Promise<*>}\n */\n resolve (hostname, rrType = 'A') {\n switch (rrType) {\n case 'A':\n return this.resolve4(hostname)\n case 'AAAA':\n return this.resolve6(hostname)\n case 'TXT':\n return this.resolveTxt(hostname)\n default:\n throw new Error(`${rrType} is not supported`)\n }\n }\n\n /**\n * Uses the DNS protocol to resolve the given host name into IPv4 addresses.\n *\n * @param {string} hostname - host name to resolve.\n * @returns {Promise<Array<string>>}\n */\n async resolve4 (hostname) {\n const recordType = 'A'\n const cached = this._cache.get(utils.getCacheKey(hostname, recordType))\n if (cached) {\n return cached\n }\n\n for (const server of this._getShuffledServers()) {\n try {\n const response = await utils.fetch(utils.buildResource({\n serverResolver: server,\n hostname,\n recordType\n }))\n\n const d = await response.json()\n const data = d.Answer.map(a => a.data)\n const ttl = Math.min(d.Answer.map(a => a.TTL))\n\n this._cache.set(utils.getCacheKey(hostname, recordType), data, { ttl })\n\n return data\n } catch (err) {\n log.error(`${server} could not resolve ${hostname} record ${recordType}`)\n }\n }\n\n throw new Error(`Could not resolve ${hostname} record ${recordType}`)\n }\n\n /**\n * Uses the DNS protocol to resolve the given host name into IPv6 addresses.\n *\n * @param {string} hostname - host name to resolve.\n * @returns {Promise<Array<string>>}\n */\n async resolve6 (hostname) {\n const recordType = 'AAAA'\n const cached = this._cache.get(utils.getCacheKey(hostname, recordType))\n if (cached) {\n return cached\n }\n\n for (const server of this._getShuffledServers()) {\n try {\n const response = await utils.fetch(utils.buildResource({\n serverResolver: server,\n hostname,\n recordType\n }))\n\n const d = await response.json()\n const data = d.Answer.map(a => a.data)\n const ttl = Math.min(d.Answer.map(a => a.TTL))\n\n this._cache.set(utils.getCacheKey(hostname, recordType), data, { ttl })\n\n return data\n } catch (err) {\n log.error(`${server} could not resolve ${hostname} record ${recordType}`)\n }\n }\n\n throw new Error(`Could not resolve ${hostname} record ${recordType}`)\n }\n\n /**\n * Uses the DNS protocol to resolve the given host name into a Text record.\n *\n * @param {string} hostname - host name to resolve.\n * @returns {Promise<Array<Array<string>>>}\n */\n async resolveTxt (hostname) {\n const recordType = 'TXT'\n const cached = this._cache.get(utils.getCacheKey(hostname, recordType))\n if (cached) {\n return cached\n }\n\n for (const server of this._getShuffledServers()) {\n try {\n const response = await utils.fetch(utils.buildResource({\n serverResolver: server,\n hostname,\n recordType\n }))\n\n const d = await response.json()\n const data = d.Answer.map(a => [a.data.replace(/['\"]+/g, '')])\n const ttl = Math.min(d.Answer.map(a => a.TTL))\n\n this._cache.set(utils.getCacheKey(hostname, recordType), data, { ttl })\n\n return data\n } catch (err) {\n log.error(`${server} could not resolve ${hostname} record ${recordType}`)\n }\n }\n\n throw new Error(`Could not resolve ${hostname} record ${recordType}`)\n }\n}\n\nResolver.Resolver = Resolver\nmodule.exports = Resolver\n","'use strict'\n\nmodule.exports = Receptacle\nvar toMS = require('ms')\nvar cache = Receptacle.prototype\nvar counter = new Date() % 1e9\n\nfunction getUID () { return (Math.random() * 1e9 >>> 0) + (counter++) }\n\n/**\n * Creates a cache with a maximum key size.\n *\n * @constructor\n * @param {Object} options\n * @param {Number} [options.max=Infinity] the maximum number of keys allowed in the cache (lru).\n * @param {Array} [options.items=[]] the default items in the cache.\n */\nfunction Receptacle (options) {\n options = options || {}\n this.id = options.id || getUID()\n this.max = options.max || Infinity\n this.items = options.items || []\n this._lookup = {}\n this.size = this.items.length\n this.lastModified = new Date(options.lastModified || new Date())\n\n // Setup initial timers and indexes for the cache.\n for (var item, ttl, i = this.items.length; i--;) {\n item = this.items[i]\n ttl = new Date(item.expires) - new Date()\n this._lookup[item.key] = item\n if (ttl > 0) this.expire(item.key, ttl)\n else if (ttl <= 0) this.delete(item.key)\n }\n}\n\n/**\n * Tests if a key is currently in the cache.\n * Does not check if slot is empty.\n *\n * @param {String} key - the key to retrieve from the cache.\n * @return {Boolean}\n */\ncache.has = function (key) {\n return key in this._lookup\n}\n\n/**\n * Retrieves a key from the cache and marks it as recently used.\n *\n * @param {String} key - the key to retrieve from the cache.\n * @return {*}\n */\ncache.get = function (key) {\n if (!this.has(key)) return null\n var record = this._lookup[key]\n // Update expiry for \"refresh\" keys\n if (record.refresh) this.expire(key, record.refresh)\n // Move to front of the line.\n this.items.splice(this.items.indexOf(record), 1)\n this.items.push(record)\n return record.value\n}\n\n/**\n * Retrieves user meta data for a cached item.\n *\n * @param {String} key - the key to retrieve meta data from the cache.\n * @return {*}\n */\ncache.meta = function (key) {\n if (!this.has(key)) return null\n var record = this._lookup[key]\n if (!('meta' in record)) return null\n return record.meta\n}\n\n/**\n * Puts a key into the cache with an optional expiry time.\n *\n * @param {String} key - the key for the value in the cache.\n * @param {*} value - the value to place at the key.\n * @param {Number} [options.ttl] - a time after which the key will be removed.\n * @return {Receptacle}\n */\ncache.set = function (key, value, options) {\n var oldRecord = this._lookup[key]\n var record = this._lookup[key] = { key: key, value: value }\n // Mark cache as modified.\n this.lastModified = new Date()\n\n if (oldRecord) {\n // Replace an old key.\n clearTimeout(oldRecord.timeout)\n this.items.splice(this.items.indexOf(oldRecord), 1, record)\n } else {\n // Remove least used item if needed.\n if (this.size >= this.max) this.delete(this.items[0].key)\n // Add a new key.\n this.items.push(record)\n this.size++\n }\n\n if (options) {\n // Setup key expiry.\n if ('ttl' in options) this.expire(key, options.ttl)\n // Store user options in the record.\n if ('meta' in options) record.meta = options.meta\n // Mark a auto refresh key.\n if (options.refresh) record.refresh = options.ttl\n }\n\n return this\n}\n\n/**\n * Deletes an item from the cache.\n *\n * @param {String} key - the key to remove.\n * @return {Receptacle}\n */\ncache.delete = function (key) {\n var record = this._lookup[key]\n if (!record) return false\n this.lastModified = new Date()\n this.items.splice(this.items.indexOf(record), 1)\n clearTimeout(record.timeout)\n delete this._lookup[key]\n this.size--\n return this\n}\n\n/**\n * Utility to register a key that will be removed after some time.\n *\n * @param {String} key - the key to remove.\n * @param {Number} [ms] - the timeout before removal.\n * @return {Receptacle}\n */\ncache.expire = function (key, ttl) {\n var ms = ttl || 0\n var record = this._lookup[key]\n if (!record) return this\n if (typeof ms === 'string') ms = toMS(ttl)\n if (typeof ms !== 'number') throw new TypeError('Expiration time must be a string or number.')\n clearTimeout(record.timeout)\n record.timeout = setTimeout(this.delete.bind(this, record.key), ms)\n record.expires = Number(new Date()) + ms\n return this\n}\n\n/**\n * Deletes all items from the cache.\n * @return {Receptacle}\n */\ncache.clear = function () {\n for (var i = this.items.length; i--;) this.delete(this.items[i].key)\n return this\n}\n\n/**\n * Fixes serialization issues in polyfilled environments.\n * Ensures non-cyclical serialized object.\n */\ncache.toJSON = function () {\n var items = new Array(this.items.length)\n var item\n for (var i = items.length; i--;) {\n item = this.items[i]\n items[i] = {\n key: item.key,\n meta: item.meta,\n value: item.value,\n expires: item.expires,\n refresh: item.refresh\n }\n }\n\n return {\n id: this.id,\n max: isFinite(this.max) ? this.max : undefined,\n lastModified: this.lastModified,\n items: items\n }\n}\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function (val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","'use strict'\n\nconst { default: nativeFetch, Headers } = require('native-fetch')\n\n/**\n * Build fetch resource for request.\n *\n * @param {object} properties\n * @param {string} properties.serverResolver\n * @param {string} properties.hostname\n * @param {string} properties.recordType\n * @returns {string}\n */\nfunction buildResource ({ serverResolver, hostname, recordType }) {\n return `${serverResolver}?name=${hostname}&type=${recordType}`\n}\n\n/**\n * Use fetch to find the record.\n *\n * @param {object} resource\n * @returns {Promise}\n */\nfunction fetch (resource) {\n return nativeFetch(resource, {\n headers: new Headers({\n accept: 'application/dns-json'\n })\n })\n}\n\n/**\n * Creates cache key composed by recordType and hostname.\n *\n * @param {string} hostname\n * @param {string} recordType\n * @returns {string}\n */\nfunction getCacheKey (hostname, recordType) {\n return `${recordType}_${hostname}`\n}\n\nmodule.exports = {\n buildResource,\n fetch,\n getCacheKey\n}\n","'use strict'\n\nmodule.exports = {\n DIAL_TIMEOUT: 30e3, // How long in ms a dial attempt is allowed to take\n MAX_PARALLEL_DIALS: 100, // Maximum allowed concurrent dials\n MAX_PER_PEER_DIALS: 4, // Allowed parallel dials per DialRequest\n MAX_ADDRS_TO_DIAL: 25, // Maximum number of allowed addresses to attempt to dial\n METRICS: {\n computeThrottleMaxQueueSize: 1000,\n computeThrottleTimeout: 2000,\n movingAverageIntervals: [\n 60 * 1000, // 1 minute\n 5 * 60 * 1000, // 5 minutes\n 15 * 60 * 1000 // 15 minutes\n ],\n maxOldPeersRetention: 50\n }\n}\n","'use strict'\n\n// @ts-ignore file not listed within the file list of projects\nconst libp2pVersion = require('../../package.json').version\n\nmodule.exports.PROTOCOL_VERSION = 'ipfs/0.1.0' // deprecated\nmodule.exports.AGENT_VERSION = `js-libp2p/${libp2pVersion}`\nmodule.exports.MULTICODEC_IDENTIFY = '/ipfs/id/1.0.0' // deprecated\nmodule.exports.MULTICODEC_IDENTIFY_PUSH = '/ipfs/id/push/1.0.0' // deprecated\n\nmodule.exports.IDENTIFY_PROTOCOL_VERSION = '0.1.0'\nmodule.exports.MULTICODEC_IDENTIFY_PROTOCOL_NAME = 'id'\nmodule.exports.MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME = 'id/push'\nmodule.exports.MULTICODEC_IDENTIFY_PROTOCOL_VERSION = '1.0.0'\nmodule.exports.MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION = '1.0.0'\n","{\n \"name\": \"libp2p\",\n \"version\": \"0.33.0\",\n \"description\": \"JavaScript implementation of libp2p, a modular peer to peer network stack\",\n \"leadMaintainer\": \"Jacob Heun <jacobheun@gmail.com>\",\n \"main\": \"src/index.js\",\n \"types\": \"dist/src/index.d.ts\",\n \"typesVersions\": {\n \"*\": {\n \"src/*\": [\n \"dist/src/*\",\n \"dist/src/*/index\"\n ]\n }\n },\n \"files\": [\n \"dist\",\n \"src\"\n ],\n \"scripts\": {\n \"lint\": \"aegir lint\",\n \"build\": \"aegir build\",\n \"build:proto\": \"npm run build:proto:circuit && npm run build:proto:identify && npm run build:proto:plaintext && npm run build:proto:address-book && npm run build:proto:proto-book && npm run build:proto:peer-record && npm run build:proto:envelope\",\n \"build:proto:circuit\": \"pbjs -t static-module -w commonjs -r libp2p-circuit --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/circuit/protocol/index.js ./src/circuit/protocol/index.proto\",\n \"build:proto:identify\": \"pbjs -t static-module -w commonjs -r libp2p-identify --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/identify/message.js ./src/identify/message.proto\",\n \"build:proto:plaintext\": \"pbjs -t static-module -w commonjs -r libp2p-plaintext --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/insecure/proto.js ./src/insecure/proto.proto\",\n \"build:proto:address-book\": \"pbjs -t static-module -w commonjs -r libp2p-address-book --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/peer-store/persistent/pb/address-book.js ./src/peer-store/persistent/pb/address-book.proto\",\n \"build:proto:proto-book\": \"pbjs -t static-module -w commonjs -r libp2p-proto-book --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/peer-store/persistent/pb/proto-book.js ./src/peer-store/persistent/pb/proto-book.proto\",\n \"build:proto:peer-record\": \"pbjs -t static-module -w commonjs -r libp2p-peer-record --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/record/peer-record/peer-record.js ./src/record/peer-record/peer-record.proto\",\n \"build:proto:envelope\": \"pbjs -t static-module -w commonjs -r libp2p-envelope --force-number --no-verify --no-delimited --no-create --no-beautify --no-defaults --lint eslint-disable -o src/record/envelope/envelope.js ./src/record/envelope/envelope.proto\",\n \"build:proto-types\": \"npm run build:proto-types:circuit && npm run build:proto-types:identify && npm run build:proto-types:plaintext && npm run build:proto-types:address-book && npm run build:proto-types:proto-book && npm run build:proto-types:peer-record && npm run build:proto-types:envelope\",\n \"build:proto-types:circuit\": \"pbts -o src/circuit/protocol/index.d.ts src/circuit/protocol/index.js\",\n \"build:proto-types:identify\": \"pbts -o src/identify/message.d.ts src/identify/message.js\",\n \"build:proto-types:plaintext\": \"pbts -o src/insecure/proto.d.ts src/insecure/proto.js\",\n \"build:proto-types:address-book\": \"pbts -o src/peer-store/persistent/pb/address-book.d.ts src/peer-store/persistent/pb/address-book.js\",\n \"build:proto-types:proto-book\": \"pbts -o src/peer-store/persistent/pb/proto-book.d.ts src/peer-store/persistent/pb/proto-book.js\",\n \"build:proto-types:peer-record\": \"pbts -o src/record/peer-record/peer-record.d.ts src/record/peer-record/peer-record.js\",\n \"build:proto-types:envelope\": \"pbts -o src/record/envelope/envelope.d.ts src/record/envelope/envelope.js\",\n \"test\": \"aegir test\",\n \"test:ts\": \"aegir build --no-bundle && npm run test --prefix test/ts-use\",\n \"test:node\": \"aegir test -t node -f \\\"./test/**/*.{node,spec}.js\\\"\",\n \"test:browser\": \"aegir test -t browser\",\n \"test:examples\": \"cd examples && npm run test:all\",\n \"prepare\": \"aegir build --no-bundle\",\n \"release\": \"aegir release -t node -t browser\",\n \"release-minor\": \"aegir release --type minor -t node -t browser\",\n \"release-major\": \"aegir release --type major -t node -t browser\",\n \"coverage\": \"nyc --reporter=text --reporter=lcov npm run test:node\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/libp2p/js-libp2p.git\"\n },\n \"keywords\": [\n \"libp2p\",\n \"network\",\n \"p2p\",\n \"peer\",\n \"peer-to-peer\",\n \"IPFS\"\n ],\n \"bugs\": {\n \"url\": \"https://github.com/libp2p/js-libp2p/issues\"\n },\n \"homepage\": \"https://libp2p.io\",\n \"license\": \"MIT\",\n \"engines\": {\n \"node\": \">=14.0.0\"\n },\n \"browser\": {\n \"@motrix/nat-api\": false\n },\n \"eslintConfig\": {\n \"extends\": \"ipfs\",\n \"ignorePatterns\": [\n \"!.aegir.js\",\n \"test/ts-use\"\n ]\n },\n \"dependencies\": {\n \"abortable-iterator\": \"^3.0.0\",\n \"@motrix/nat-api\": \"^0.3.1\",\n \"@vascosantos/moving-average\": \"^1.1.0\",\n \"abort-controller\": \"^3.0.0\",\n \"aggregate-error\": \"^3.1.0\",\n \"any-signal\": \"^2.1.1\",\n \"bignumber.js\": \"^9.0.1\",\n \"class-is\": \"^1.1.0\",\n \"debug\": \"^4.3.1\",\n \"err-code\": \"^3.0.0\",\n \"es6-promisify\": \"^7.0.0\",\n \"events\": \"^3.3.0\",\n \"hashlru\": \"^2.3.0\",\n \"interface-datastore\": \"^6.0.2\",\n \"it-all\": \"^1.0.4\",\n \"it-buffer\": \"^0.1.2\",\n \"it-drain\": \"^1.0.3\",\n \"it-filter\": \"^1.0.1\",\n \"it-first\": \"^1.0.4\",\n \"it-handshake\": \"^2.0.0\",\n \"it-length-prefixed\": \"^5.0.2\",\n \"it-map\": \"^1.0.4\",\n \"it-merge\": \"^1.0.0\",\n \"it-pipe\": \"^1.1.0\",\n \"it-take\": \"^1.0.0\",\n \"libp2p-crypto\": \"^0.19.4\",\n \"libp2p-interfaces\": \"^1.0.0\",\n \"libp2p-utils\": \"^0.4.0\",\n \"mafmt\": \"^10.0.0\",\n \"merge-options\": \"^3.0.4\",\n \"multiaddr\": \"^10.0.0\",\n \"multiformats\": \"^9.0.0\",\n \"multistream-select\": \"^2.0.0\",\n \"mutable-proxy\": \"^1.0.0\",\n \"node-forge\": \"^0.10.0\",\n \"p-any\": \"^3.0.0\",\n \"p-fifo\": \"^1.0.0\",\n \"p-retry\": \"^4.4.0\",\n \"p-settle\": \"^4.1.1\",\n \"peer-id\": \"^0.15.0\",\n \"private-ip\": \"^2.1.0\",\n \"protobufjs\": \"^6.10.2\",\n \"retimer\": \"^3.0.0\",\n \"sanitize-filename\": \"^1.6.3\",\n \"set-delayed-interval\": \"^1.0.0\",\n \"streaming-iterables\": \"^6.0.0\",\n \"timeout-abort-controller\": \"^1.1.1\",\n \"uint8arrays\": \"^3.0.0\",\n \"varint\": \"^6.0.0\",\n \"wherearewe\": \"^1.0.0\",\n \"xsalsa20\": \"^1.1.0\"\n },\n \"devDependencies\": {\n \"@chainsafe/libp2p-noise\": \"^4.0.0\",\n \"@nodeutils/defaults-deep\": \"^1.1.0\",\n \"@types/es6-promisify\": \"^6.0.0\",\n \"@types/node\": \"^16.0.1\",\n \"@types/node-forge\": \"^0.10.1\",\n \"@types/varint\": \"^6.0.0\",\n \"aegir\": \"^33.1.1\",\n \"buffer\": \"^6.0.3\",\n \"datastore-core\": \"^6.0.7\",\n \"delay\": \"^5.0.0\",\n \"interop-libp2p\": \"^0.4.0\",\n \"into-stream\": \"^7.0.0\",\n \"ipfs-http-client\": \"^52.0.2\",\n \"it-concat\": \"^2.0.0\",\n \"it-pair\": \"^1.0.0\",\n \"it-pushable\": \"^1.4.0\",\n \"libp2p\": \".\",\n \"libp2p-bootstrap\": \"^0.13.0\",\n \"libp2p-delegated-content-routing\": \"^0.11.0\",\n \"libp2p-delegated-peer-routing\": \"^0.10.0\",\n \"libp2p-floodsub\": \"^0.27.0\",\n \"libp2p-gossipsub\": \"^0.11.0\",\n \"libp2p-interfaces-compliance-tests\": \"^1.0.0\",\n \"libp2p-kad-dht\": \"^0.24.2\",\n \"libp2p-mdns\": \"^0.17.0\",\n \"libp2p-mplex\": \"^0.10.1\",\n \"libp2p-tcp\": \"^0.17.0\",\n \"libp2p-webrtc-star\": \"^0.23.0\",\n \"libp2p-websockets\": \"^0.16.0\",\n \"nock\": \"^13.0.3\",\n \"p-defer\": \"^3.0.0\",\n \"p-times\": \"^3.0.0\",\n \"p-wait-for\": \"^3.2.0\",\n \"rimraf\": \"^3.0.2\",\n \"sinon\": \"^11.1.1\",\n \"util\": \"^0.12.3\"\n },\n \"contributors\": [\n \"Vasco Santos <vasco.santos@moxy.studio>\",\n \"David Dias <daviddias.p@gmail.com>\",\n \"Jacob Heun <jacobheun@gmail.com>\",\n \"Alex Potsides <alex@achingbrain.net>\",\n \"Alan Shaw <alan@tableflip.io>\",\n \"Cayman <caymannava@gmail.com>\",\n \"Pedro Teixeira <i@pgte.me>\",\n \"Friedel Ziegelmayer <dignifiedquire@gmail.com>\",\n \"Maciej Krüger <mkg20001@gmail.com>\",\n \"Hugo Dias <mail@hugodias.me>\",\n \"Chris Dostert <chrisdostert@users.noreply.github.com>\",\n \"dirkmc <dirkmdev@gmail.com>\",\n \"Volker Mische <volker.mische@gmail.com>\",\n \"zeim839 <50573884+zeim839@users.noreply.github.com>\",\n \"Richard Littauer <richard.littauer@gmail.com>\",\n \"a1300 <matthias-knopp@gmx.net>\",\n \"Ryan Bell <ryan@piing.net>\",\n \"ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com>\",\n \"Franck Royer <franck@royer.one>\",\n \"Thomas Eizinger <thomas@eizinger.io>\",\n \"Giovanni T. Parra <fiatjaf@gmail.com>\",\n \"acolytec3 <17355484+acolytec3@users.noreply.github.com>\",\n \"Elven <mon.samuel@qq.com>\",\n \"Andrew Nesbitt <andrewnez@gmail.com>\",\n \"Samlior <samlior@foxmail.com>\",\n \"Didrik Nordström <didrik.nordstrom@gmail.com>\",\n \"RasmusErik Voel Jensen <github@solsort.com>\",\n \"Robert Kiel <robert.kiel@hoprnet.org>\",\n \"Smite Chow <xiaopengyou@live.com>\",\n \"Soeren <nikorpoulsen@gmail.com>\",\n \"Sönke Hahn <soenkehahn@gmail.com>\",\n \"TJKoury <TJKoury@gmail.com>\",\n \"Tiago Alves <alvesjtiago@gmail.com>\",\n \"XiaoZhang <zxinmyth@gmail.com>\",\n \"Yusef Napora <yusef@napora.org>\",\n \"Zane Starr <zcstarr@gmail.com>\",\n \"ebinks <elizabethjbinks@gmail.com>\",\n \"Aditya Bose <13054902+adbose@users.noreply.github.com>\",\n \"isan_rivkin <isanrivkin@gmail.com>\",\n \"mayerwin <mayerwin@users.noreply.github.com>\",\n \"mcclure <andi.m.mcclure@gmail.com>\",\n \"phillmac <phillmac@users.noreply.github.com>\",\n \"robertkiel <robert.kiel@validitylabs.org>\",\n \"shresthagrawal <34920931+shresthagrawal@users.noreply.github.com>\",\n \"swedneck <40505480+swedneck@users.noreply.github.com>\",\n \"greenSnot <greenSnot@users.noreply.github.com>\",\n \"Aleksei <vozhdb@gmail.com>\",\n \"Bernd Strehl <bernd.strehl@gmail.com>\",\n \"Chris Bratlien <chrisbratlien@gmail.com>\",\n \"Cindy Wu <ciindy.wu@gmail.com>\",\n \"Daijiro Wachi <daijiro.wachi@gmail.com>\",\n \"Diogo Silva <fsdiogo@gmail.com>\",\n \"Dmitriy Ryajov <dryajov@gmail.com>\",\n \"Ethan Lam <elmemphis2000@gmail.com>\",\n \"Fei Liu <liu.feiwood@gmail.com>\",\n \"Felipe Martins <felipebrasil93@gmail.com>\",\n \"Florian-Merle <florian.david.merle@gmail.com>\",\n \"Francis Gulotta <wizard@roborooter.com>\",\n \"Guy Sviry <32539816+guysv@users.noreply.github.com>\",\n \"Henrique Dias <hacdias@gmail.com>\",\n \"Irakli Gozalishvili <rfobic@gmail.com>\",\n \"Joel Gustafson <joelg@mit.edu>\",\n \"John Rees <johnrees@users.noreply.github.com>\",\n \"João Santos <joaosantos15@users.noreply.github.com>\",\n \"Julien Bouquillon <contact@revolunet.com>\",\n \"Kevin Kwok <antimatter15@gmail.com>\",\n \"Kevin Lacker <lacker@gmail.com>\",\n \"Lars Gierth <lgierth@users.noreply.github.com>\",\n \"Leask Wong <i@leaskh.com>\",\n \"Marcin Tojek <mtojek@users.noreply.github.com>\",\n \"Michael Burns <5170+mburns@users.noreply.github.com>\",\n \"Miguel Mota <miguelmota2@gmail.com>\",\n \"Nuno Nogueira <nunofmn@gmail.com>\",\n \"Philipp Muens <raute1337@gmx.de>\"\n ]\n}\n","'use strict'\n\nconst minute = 60 * 1000\n\nmodule.exports = {\n ADVERTISE_BOOT_DELAY: 15 * minute, // Delay before HOP relay service is advertised on the network\n ADVERTISE_TTL: 30 * minute, // Delay Between HOP relay service advertisements on the network\n CIRCUIT_PROTO_CODE: 290, // Multicodec code\n HOP_METADATA_KEY: 'hop_relay', // PeerStore metadaBook key for HOP relay service\n HOP_METADATA_VALUE: 'true', // PeerStore metadaBook value for HOP relay service\n RELAY_RENDEZVOUS_NS: '/libp2p/relay' // Relay HOP relay service namespace for discovery\n}\n","'use strict'\n\nconst isPrivate = require('./multiaddr/is-private')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @typedef {Object} Address\n * @property {Multiaddr} multiaddr peer multiaddr.\n * @property {boolean} isCertified obtained from a signed peer record.\n */\n\n/**\n * Compare function for array.sort().\n * This sort aims to move the private adresses to the end of the array.\n * In case of equality, a certified address will come first.\n *\n * @param {Address} a\n * @param {Address} b\n * @returns {number}\n */\nfunction addressesPublicFirstCompareFunction (a, b) {\n const isAPrivate = isPrivate(a.multiaddr)\n const isBPrivate = isPrivate(b.multiaddr)\n\n if (isAPrivate && !isBPrivate) {\n return 1\n } else if (!isAPrivate && isBPrivate) {\n return -1\n }\n // Check certified?\n if (a.isCertified && !b.isCertified) {\n return -1\n } else if (!a.isCertified && b.isCertified) {\n return 1\n }\n\n return 0\n}\n\n/**\n * Sort given addresses by putting public addresses first.\n * In case of equality, a certified address will come first.\n *\n * @param {Array<Address>} addresses\n * @returns {Array<Address>}\n */\nfunction publicAddressesFirst (addresses) {\n return [...addresses].sort(addressesPublicFirstCompareFunction)\n}\n\nmodule.exports.publicAddressesFirst = publicAddressesFirst\n","'use strict'\n\n// @ts-ignore private-ip does not publish types\nconst isIpPrivate = require('private-ip')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * Check if a given multiaddr has a private address.\n *\n * @param {Multiaddr} ma\n * @returns {boolean}\n */\nfunction isPrivate (ma) {\n const { address } = ma.nodeAddress()\n\n return isIpPrivate(address)\n}\n\nmodule.exports = isPrivate\n","'use strict'\n\nmodule.exports = require('./lib').default\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst netmask_1 = require(\"netmask\");\nconst ip_regex_1 = __importDefault(require(\"ip-regex\"));\nconst is_ip_1 = __importDefault(require(\"is-ip\"));\nconst ipaddr_js_1 = require(\"ipaddr.js\");\nconst PRIVATE_IP_RANGES = [\n '0.0.0.0/8',\n '10.0.0.0/8',\n '100.64.0.0/10',\n '127.0.0.0/8',\n '169.254.0.0/16',\n '172.16.0.0/12',\n '192.0.0.0/24',\n '192.0.0.0/29',\n '192.0.0.8/32',\n '192.0.0.9/32',\n '192.0.0.10/32',\n '192.0.0.170/32',\n '192.0.0.171/32',\n '192.0.2.0/24',\n '192.31.196.0/24',\n '192.52.193.0/24',\n '192.88.99.0/24',\n '192.168.0.0/16',\n '192.175.48.0/24',\n '198.18.0.0/15',\n '198.51.100.0/24',\n '203.0.113.0/24',\n '240.0.0.0/4',\n '255.255.255.255/32'\n];\nconst NETMASK_RANGES = PRIVATE_IP_RANGES.map(ip_range => new netmask_1.Netmask(ip_range));\nfunction ipv4_check(ip_addr) {\n for (let r of NETMASK_RANGES) {\n if (r.contains(ip_addr))\n return true;\n }\n return false;\n}\nfunction ipv6_check(ip_addr) {\n return /^::$/.test(ip_addr) ||\n /^::1$/.test(ip_addr) ||\n /^::f{4}:([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/.test(ip_addr) ||\n /^::f{4}:0.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/.test(ip_addr) ||\n /^64:ff9b::([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/.test(ip_addr) ||\n /^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(ip_addr) ||\n /^f[c-d]([0-9a-fA-F]{2,2}):/i.test(ip_addr) ||\n /^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(ip_addr) ||\n /^ff([0-9a-fA-F]{2,2}):/i.test(ip_addr);\n}\nexports.default = (ip) => {\n if (ipaddr_js_1.isValid(ip)) {\n const parsed = ipaddr_js_1.parse(ip);\n if (parsed.kind() === 'ipv4')\n return ipv4_check(parsed.toNormalizedString());\n else if (parsed.kind() === 'ipv6')\n return ipv6_check(ip);\n }\n else if (is_ip_1.default(ip) && ip_regex_1.default.v6().test(ip))\n return ipv6_check(ip);\n return undefined;\n};\n","// Generated by CoffeeScript 1.12.7\n(function() {\n var Netmask, atob, chr, chr0, chrA, chra, ip2long, long2ip;\n\n long2ip = function(long) {\n var a, b, c, d;\n a = (long & (0xff << 24)) >>> 24;\n b = (long & (0xff << 16)) >>> 16;\n c = (long & (0xff << 8)) >>> 8;\n d = long & 0xff;\n return [a, b, c, d].join('.');\n };\n\n ip2long = function(ip) {\n var b, c, i, j, n, ref;\n b = [];\n for (i = j = 0; j <= 3; i = ++j) {\n if (ip.length === 0) {\n break;\n }\n if (i > 0) {\n if (ip[0] !== '.') {\n throw new Error('Invalid IP');\n }\n ip = ip.substring(1);\n }\n ref = atob(ip), n = ref[0], c = ref[1];\n ip = ip.substring(c);\n b.push(n);\n }\n if (ip.length !== 0) {\n throw new Error('Invalid IP');\n }\n switch (b.length) {\n case 1:\n if (b[0] > 0xFFFFFFFF) {\n throw new Error('Invalid IP');\n }\n return b[0] >>> 0;\n case 2:\n if (b[0] > 0xFF || b[1] > 0xFFFFFF) {\n throw new Error('Invalid IP');\n }\n return (b[0] << 24 | b[1]) >>> 0;\n case 3:\n if (b[0] > 0xFF || b[1] > 0xFF || b[2] > 0xFFFF) {\n throw new Error('Invalid IP');\n }\n return (b[0] << 24 | b[1] << 16 | b[2]) >>> 0;\n case 4:\n if (b[0] > 0xFF || b[1] > 0xFF || b[2] > 0xFF || b[3] > 0xFF) {\n throw new Error('Invalid IP');\n }\n return (b[0] << 24 | b[1] << 16 | b[2] << 8 | b[3]) >>> 0;\n default:\n throw new Error('Invalid IP');\n }\n };\n\n chr = function(b) {\n return b.charCodeAt(0);\n };\n\n chr0 = chr('0');\n\n chra = chr('a');\n\n chrA = chr('A');\n\n atob = function(s) {\n var base, dmax, i, n, start;\n n = 0;\n base = 10;\n dmax = '9';\n i = 0;\n if (s.length > 1 && s[i] === '0') {\n if (s[i + 1] === 'x' || s[i + 1] === 'X') {\n i += 2;\n base = 16;\n } else if ('0' <= s[i + 1] && s[i + 1] <= '9') {\n i++;\n base = 8;\n dmax = '7';\n }\n }\n start = i;\n while (i < s.length) {\n if ('0' <= s[i] && s[i] <= dmax) {\n n = (n * base + (chr(s[i]) - chr0)) >>> 0;\n } else if (base === 16) {\n if ('a' <= s[i] && s[i] <= 'f') {\n n = (n * base + (10 + chr(s[i]) - chra)) >>> 0;\n } else if ('A' <= s[i] && s[i] <= 'F') {\n n = (n * base + (10 + chr(s[i]) - chrA)) >>> 0;\n } else {\n break;\n }\n } else {\n break;\n }\n if (n > 0xFFFFFFFF) {\n throw new Error('too large');\n }\n i++;\n }\n if (i === start) {\n throw new Error('empty octet');\n }\n return [n, i];\n };\n\n Netmask = (function() {\n function Netmask(net, mask) {\n var error, i, j, ref;\n if (typeof net !== 'string') {\n throw new Error(\"Missing `net' parameter\");\n }\n if (!mask) {\n ref = net.split('/', 2), net = ref[0], mask = ref[1];\n }\n if (!mask) {\n mask = 32;\n }\n if (typeof mask === 'string' && mask.indexOf('.') > -1) {\n try {\n this.maskLong = ip2long(mask);\n } catch (error1) {\n error = error1;\n throw new Error(\"Invalid mask: \" + mask);\n }\n for (i = j = 32; j >= 0; i = --j) {\n if (this.maskLong === (0xffffffff << (32 - i)) >>> 0) {\n this.bitmask = i;\n break;\n }\n }\n } else if (mask || mask === 0) {\n this.bitmask = parseInt(mask, 10);\n this.maskLong = 0;\n if (this.bitmask > 0) {\n this.maskLong = (0xffffffff << (32 - this.bitmask)) >>> 0;\n }\n } else {\n throw new Error(\"Invalid mask: empty\");\n }\n try {\n this.netLong = (ip2long(net) & this.maskLong) >>> 0;\n } catch (error1) {\n error = error1;\n throw new Error(\"Invalid net address: \" + net);\n }\n if (!(this.bitmask <= 32)) {\n throw new Error(\"Invalid mask for ip4: \" + mask);\n }\n this.size = Math.pow(2, 32 - this.bitmask);\n this.base = long2ip(this.netLong);\n this.mask = long2ip(this.maskLong);\n this.hostmask = long2ip(~this.maskLong);\n this.first = this.bitmask <= 30 ? long2ip(this.netLong + 1) : this.base;\n this.last = this.bitmask <= 30 ? long2ip(this.netLong + this.size - 2) : long2ip(this.netLong + this.size - 1);\n this.broadcast = this.bitmask <= 30 ? long2ip(this.netLong + this.size - 1) : void 0;\n }\n\n Netmask.prototype.contains = function(ip) {\n if (typeof ip === 'string' && (ip.indexOf('/') > 0 || ip.split('.').length !== 4)) {\n ip = new Netmask(ip);\n }\n if (ip instanceof Netmask) {\n return this.contains(ip.base) && this.contains(ip.broadcast || ip.last);\n } else {\n return (ip2long(ip) & this.maskLong) >>> 0 === (this.netLong & this.maskLong) >>> 0;\n }\n };\n\n Netmask.prototype.next = function(count) {\n if (count == null) {\n count = 1;\n }\n return new Netmask(long2ip(this.netLong + (this.size * count)), this.mask);\n };\n\n Netmask.prototype.forEach = function(fn) {\n var index, lastLong, long;\n long = ip2long(this.first);\n lastLong = ip2long(this.last);\n index = 0;\n while (long <= lastLong) {\n fn(long2ip(long), long, index);\n index++;\n long++;\n }\n };\n\n Netmask.prototype.toString = function() {\n return this.base + \"/\" + this.bitmask;\n };\n\n return Netmask;\n\n })();\n\n exports.ip2long = ip2long;\n\n exports.long2ip = long2ip;\n\n exports.Netmask = Netmask;\n\n}).call(this);\n","(function (root) {\n 'use strict';\n // A list of regular expressions that match arbitrary IPv4 addresses,\n // for which a number of weird notations exist.\n // Note that an address like 0010.0xa5.1.1 is considered legal.\n const ipv4Part = '(0?\\\\d+|0x[a-f0-9]+)';\n const ipv4Regexes = {\n fourOctet: new RegExp(`^${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}$`, 'i'),\n threeOctet: new RegExp(`^${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}$`, 'i'),\n twoOctet: new RegExp(`^${ipv4Part}\\\\.${ipv4Part}$`, 'i'),\n longValue: new RegExp(`^${ipv4Part}$`, 'i')\n };\n\n // Regular Expression for checking Octal numbers\n const octalRegex = new RegExp(`^0[0-7]+$`, 'i');\n const hexRegex = new RegExp(`^0x[a-f0-9]+$`, 'i');\n\n const zoneIndex = '%[0-9a-z]{1,}';\n\n // IPv6-matching regular expressions.\n // For IPv6, the task is simpler: it is enough to match the colon-delimited\n // hexadecimal IPv6 and a transitional variant with dotted-decimal IPv4 at\n // the end.\n const ipv6Part = '(?:[0-9a-f]+::?)+';\n const ipv6Regexes = {\n zoneIndex: new RegExp(zoneIndex, 'i'),\n 'native': new RegExp(`^(::)?(${ipv6Part})?([0-9a-f]+)?(::)?(${zoneIndex})?$`, 'i'),\n deprecatedTransitional: new RegExp(`^(?:::)(${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}(${zoneIndex})?)$`, 'i'),\n transitional: new RegExp(`^((?:${ipv6Part})|(?:::)(?:${ipv6Part})?)${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}\\\\.${ipv4Part}(${zoneIndex})?$`, 'i')\n };\n\n // Expand :: in an IPv6 address or address part consisting of `parts` groups.\n function expandIPv6 (string, parts) {\n // More than one '::' means invalid adddress\n if (string.indexOf('::') !== string.lastIndexOf('::')) {\n return null;\n }\n\n let colonCount = 0;\n let lastColon = -1;\n let zoneId = (string.match(ipv6Regexes.zoneIndex) || [])[0];\n let replacement, replacementCount;\n\n // Remove zone index and save it for later\n if (zoneId) {\n zoneId = zoneId.substring(1);\n string = string.replace(/%.+$/, '');\n }\n\n // How many parts do we already have?\n while ((lastColon = string.indexOf(':', lastColon + 1)) >= 0) {\n colonCount++;\n }\n\n // 0::0 is two parts more than ::\n if (string.substr(0, 2) === '::') {\n colonCount--;\n }\n\n if (string.substr(-2, 2) === '::') {\n colonCount--;\n }\n\n // The following loop would hang if colonCount > parts\n if (colonCount > parts) {\n return null;\n }\n\n // replacement = ':' + '0:' * (parts - colonCount)\n replacementCount = parts - colonCount;\n replacement = ':';\n while (replacementCount--) {\n replacement += '0:';\n }\n\n // Insert the missing zeroes\n string = string.replace('::', replacement);\n\n // Trim any garbage which may be hanging around if :: was at the edge in\n // the source strin\n if (string[0] === ':') {\n string = string.slice(1);\n }\n\n if (string[string.length - 1] === ':') {\n string = string.slice(0, -1);\n }\n\n parts = (function () {\n const ref = string.split(':');\n const results = [];\n\n for (let i = 0; i < ref.length; i++) {\n results.push(parseInt(ref[i], 16));\n }\n\n return results;\n })();\n\n return {\n parts: parts,\n zoneId: zoneId\n };\n }\n\n // A generic CIDR (Classless Inter-Domain Routing) RFC1518 range matcher.\n function matchCIDR (first, second, partSize, cidrBits) {\n if (first.length !== second.length) {\n throw new Error('ipaddr: cannot match CIDR for objects with different lengths');\n }\n\n let part = 0;\n let shift;\n\n while (cidrBits > 0) {\n shift = partSize - cidrBits;\n if (shift < 0) {\n shift = 0;\n }\n\n if (first[part] >> shift !== second[part] >> shift) {\n return false;\n }\n\n cidrBits -= partSize;\n part += 1;\n }\n\n return true;\n }\n\n function parseIntAuto (string) {\n // Hexadedimal base 16 (0x#)\n if (hexRegex.test(string)) {\n return parseInt(string, 16);\n }\n // While octal representation is discouraged by ECMAScript 3\n // and forbidden by ECMAScript 5, we silently allow it to\n // work only if the rest of the string has numbers less than 8.\n if (string[0] === '0' && !isNaN(parseInt(string[1], 10))) {\n if (octalRegex.test(string)) {\n return parseInt(string, 8);\n }\n throw new Error(`ipaddr: cannot parse ${string} as octal`);\n }\n // Always include the base 10 radix!\n return parseInt(string, 10);\n }\n\n function padPart (part, length) {\n while (part.length < length) {\n part = `0${part}`;\n }\n\n return part;\n }\n\n const ipaddr = {};\n\n // An IPv4 address (RFC791).\n ipaddr.IPv4 = (function () {\n // Constructs a new IPv4 address from an array of four octets\n // in network order (MSB first)\n // Verifies the input.\n function IPv4 (octets) {\n if (octets.length !== 4) {\n throw new Error('ipaddr: ipv4 octet count should be 4');\n }\n\n let i, octet;\n\n for (i = 0; i < octets.length; i++) {\n octet = octets[i];\n if (!((0 <= octet && octet <= 255))) {\n throw new Error('ipaddr: ipv4 octet should fit in 8 bits');\n }\n }\n\n this.octets = octets;\n }\n\n // Special IPv4 address ranges.\n // See also https://en.wikipedia.org/wiki/Reserved_IP_addresses\n IPv4.prototype.SpecialRanges = {\n unspecified: [[new IPv4([0, 0, 0, 0]), 8]],\n broadcast: [[new IPv4([255, 255, 255, 255]), 32]],\n // RFC3171\n multicast: [[new IPv4([224, 0, 0, 0]), 4]],\n // RFC3927\n linkLocal: [[new IPv4([169, 254, 0, 0]), 16]],\n // RFC5735\n loopback: [[new IPv4([127, 0, 0, 0]), 8]],\n // RFC6598\n carrierGradeNat: [[new IPv4([100, 64, 0, 0]), 10]],\n // RFC1918\n 'private': [\n [new IPv4([10, 0, 0, 0]), 8],\n [new IPv4([172, 16, 0, 0]), 12],\n [new IPv4([192, 168, 0, 0]), 16]\n ],\n // Reserved and testing-only ranges; RFCs 5735, 5737, 2544, 1700\n reserved: [\n [new IPv4([192, 0, 0, 0]), 24],\n [new IPv4([192, 0, 2, 0]), 24],\n [new IPv4([192, 88, 99, 0]), 24],\n [new IPv4([198, 51, 100, 0]), 24],\n [new IPv4([203, 0, 113, 0]), 24],\n [new IPv4([240, 0, 0, 0]), 4]\n ]\n };\n\n // The 'kind' method exists on both IPv4 and IPv6 classes.\n IPv4.prototype.kind = function () {\n return 'ipv4';\n };\n\n // Checks if this address matches other one within given CIDR range.\n IPv4.prototype.match = function (other, cidrRange) {\n let ref;\n if (cidrRange === undefined) {\n ref = other;\n other = ref[0];\n cidrRange = ref[1];\n }\n\n if (other.kind() !== 'ipv4') {\n throw new Error('ipaddr: cannot match ipv4 address with non-ipv4 one');\n }\n\n return matchCIDR(this.octets, other.octets, 8, cidrRange);\n };\n\n // returns a number of leading ones in IPv4 address, making sure that\n // the rest is a solid sequence of 0's (valid netmask)\n // returns either the CIDR length or null if mask is not valid\n IPv4.prototype.prefixLengthFromSubnetMask = function () {\n let cidr = 0;\n // non-zero encountered stop scanning for zeroes\n let stop = false;\n // number of zeroes in octet\n const zerotable = {\n 0: 8,\n 128: 7,\n 192: 6,\n 224: 5,\n 240: 4,\n 248: 3,\n 252: 2,\n 254: 1,\n 255: 0\n };\n let i, octet, zeros;\n\n for (i = 3; i >= 0; i -= 1) {\n octet = this.octets[i];\n if (octet in zerotable) {\n zeros = zerotable[octet];\n if (stop && zeros !== 0) {\n return null;\n }\n\n if (zeros !== 8) {\n stop = true;\n }\n\n cidr += zeros;\n } else {\n return null;\n }\n }\n\n return 32 - cidr;\n };\n\n // Checks if the address corresponds to one of the special ranges.\n IPv4.prototype.range = function () {\n return ipaddr.subnetMatch(this, this.SpecialRanges);\n };\n\n // Returns an array of byte-sized values in network order (MSB first)\n IPv4.prototype.toByteArray = function () {\n return this.octets.slice(0);\n };\n\n // Converts this IPv4 address to an IPv4-mapped IPv6 address.\n IPv4.prototype.toIPv4MappedAddress = function () {\n return ipaddr.IPv6.parse(`::ffff:${this.toString()}`);\n };\n\n // Symmetrical method strictly for aligning with the IPv6 methods.\n IPv4.prototype.toNormalizedString = function () {\n return this.toString();\n };\n\n // Returns the address in convenient, decimal-dotted format.\n IPv4.prototype.toString = function () {\n return this.octets.join('.');\n };\n\n return IPv4;\n })();\n\n // A utility function to return broadcast address given the IPv4 interface and prefix length in CIDR notation\n ipaddr.IPv4.broadcastAddressFromCIDR = function (string) {\n\n try {\n const cidr = this.parseCIDR(string);\n const ipInterfaceOctets = cidr[0].toByteArray();\n const subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();\n const octets = [];\n let i = 0;\n while (i < 4) {\n // Broadcast address is bitwise OR between ip interface and inverted mask\n octets.push(parseInt(ipInterfaceOctets[i], 10) | parseInt(subnetMaskOctets[i], 10) ^ 255);\n i++;\n }\n\n return new this(octets);\n } catch (e) {\n throw new Error('ipaddr: the address does not have IPv4 CIDR format');\n }\n };\n\n // Checks if a given string is formatted like IPv4 address.\n ipaddr.IPv4.isIPv4 = function (string) {\n return this.parser(string) !== null;\n };\n\n // Checks if a given string is a valid IPv4 address.\n ipaddr.IPv4.isValid = function (string) {\n try {\n new this(this.parser(string));\n return true;\n } catch (e) {\n return false;\n }\n };\n\n // Checks if a given string is a full four-part IPv4 Address.\n ipaddr.IPv4.isValidFourPartDecimal = function (string) {\n if (ipaddr.IPv4.isValid(string) && string.match(/^(0|[1-9]\\d*)(\\.(0|[1-9]\\d*)){3}$/)) {\n return true;\n } else {\n return false;\n }\n };\n\n // A utility function to return network address given the IPv4 interface and prefix length in CIDR notation\n ipaddr.IPv4.networkAddressFromCIDR = function (string) {\n let cidr, i, ipInterfaceOctets, octets, subnetMaskOctets;\n\n try {\n cidr = this.parseCIDR(string);\n ipInterfaceOctets = cidr[0].toByteArray();\n subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();\n octets = [];\n i = 0;\n while (i < 4) {\n // Network address is bitwise AND between ip interface and mask\n octets.push(parseInt(ipInterfaceOctets[i], 10) & parseInt(subnetMaskOctets[i], 10));\n i++;\n }\n\n return new this(octets);\n } catch (e) {\n throw new Error('ipaddr: the address does not have IPv4 CIDR format');\n }\n };\n\n // Tries to parse and validate a string with IPv4 address.\n // Throws an error if it fails.\n ipaddr.IPv4.parse = function (string) {\n const parts = this.parser(string);\n\n if (parts === null) {\n throw new Error('ipaddr: string is not formatted like an IPv4 Address');\n }\n\n return new this(parts);\n };\n\n // Parses the string as an IPv4 Address with CIDR Notation.\n ipaddr.IPv4.parseCIDR = function (string) {\n let match;\n\n if ((match = string.match(/^(.+)\\/(\\d+)$/))) {\n const maskLength = parseInt(match[2]);\n if (maskLength >= 0 && maskLength <= 32) {\n const parsed = [this.parse(match[1]), maskLength];\n Object.defineProperty(parsed, 'toString', {\n value: function () {\n return this.join('/');\n }\n });\n return parsed;\n }\n }\n\n throw new Error('ipaddr: string is not formatted like an IPv4 CIDR range');\n };\n\n // Classful variants (like a.b, where a is an octet, and b is a 24-bit\n // value representing last three octets; this corresponds to a class C\n // address) are omitted due to classless nature of modern Internet.\n ipaddr.IPv4.parser = function (string) {\n let match, part, value;\n\n // parseInt recognizes all that octal & hexadecimal weirdness for us\n if ((match = string.match(ipv4Regexes.fourOctet))) {\n return (function () {\n const ref = match.slice(1, 6);\n const results = [];\n\n for (let i = 0; i < ref.length; i++) {\n part = ref[i];\n results.push(parseIntAuto(part));\n }\n\n return results;\n })();\n } else if ((match = string.match(ipv4Regexes.longValue))) {\n value = parseIntAuto(match[1]);\n if (value > 0xffffffff || value < 0) {\n throw new Error('ipaddr: address outside defined range');\n }\n\n return ((function () {\n const results = [];\n let shift;\n\n for (shift = 0; shift <= 24; shift += 8) {\n results.push((value >> shift) & 0xff);\n }\n\n return results;\n })()).reverse();\n } else if ((match = string.match(ipv4Regexes.twoOctet))) {\n return (function () {\n const ref = match.slice(1, 4);\n const results = [];\n\n value = parseIntAuto(ref[1]);\n if (value > 0xffffff || value < 0) {\n throw new Error('ipaddr: address outside defined range');\n }\n\n results.push(parseIntAuto(ref[0]));\n results.push((value >> 16) & 0xff);\n results.push((value >> 8) & 0xff);\n results.push( value & 0xff);\n\n return results;\n })();\n } else if ((match = string.match(ipv4Regexes.threeOctet))) {\n return (function () {\n const ref = match.slice(1, 5);\n const results = [];\n\n value = parseIntAuto(ref[2]);\n if (value > 0xffff || value < 0) {\n throw new Error('ipaddr: address outside defined range');\n }\n\n results.push(parseIntAuto(ref[0]));\n results.push(parseIntAuto(ref[1]));\n results.push((value >> 8) & 0xff);\n results.push( value & 0xff);\n\n return results;\n })();\n } else {\n return null;\n }\n };\n\n // A utility function to return subnet mask in IPv4 format given the prefix length\n ipaddr.IPv4.subnetMaskFromPrefixLength = function (prefix) {\n prefix = parseInt(prefix);\n if (prefix < 0 || prefix > 32) {\n throw new Error('ipaddr: invalid IPv4 prefix length');\n }\n\n const octets = [0, 0, 0, 0];\n let j = 0;\n const filledOctetCount = Math.floor(prefix / 8);\n\n while (j < filledOctetCount) {\n octets[j] = 255;\n j++;\n }\n\n if (filledOctetCount < 4) {\n octets[filledOctetCount] = Math.pow(2, prefix % 8) - 1 << 8 - (prefix % 8);\n }\n\n return new this(octets);\n };\n\n // An IPv6 address (RFC2460)\n ipaddr.IPv6 = (function () {\n // Constructs an IPv6 address from an array of eight 16 - bit parts\n // or sixteen 8 - bit parts in network order(MSB first).\n // Throws an error if the input is invalid.\n function IPv6 (parts, zoneId) {\n let i, part;\n\n if (parts.length === 16) {\n this.parts = [];\n for (i = 0; i <= 14; i += 2) {\n this.parts.push((parts[i] << 8) | parts[i + 1]);\n }\n } else if (parts.length === 8) {\n this.parts = parts;\n } else {\n throw new Error('ipaddr: ipv6 part count should be 8 or 16');\n }\n\n for (i = 0; i < this.parts.length; i++) {\n part = this.parts[i];\n if (!((0 <= part && part <= 0xffff))) {\n throw new Error('ipaddr: ipv6 part should fit in 16 bits');\n }\n }\n\n if (zoneId) {\n this.zoneId = zoneId;\n }\n }\n\n // Special IPv6 ranges\n IPv6.prototype.SpecialRanges = {\n // RFC4291, here and after\n unspecified: [new IPv6([0, 0, 0, 0, 0, 0, 0, 0]), 128],\n linkLocal: [new IPv6([0xfe80, 0, 0, 0, 0, 0, 0, 0]), 10],\n multicast: [new IPv6([0xff00, 0, 0, 0, 0, 0, 0, 0]), 8],\n loopback: [new IPv6([0, 0, 0, 0, 0, 0, 0, 1]), 128],\n uniqueLocal: [new IPv6([0xfc00, 0, 0, 0, 0, 0, 0, 0]), 7],\n ipv4Mapped: [new IPv6([0, 0, 0, 0, 0, 0xffff, 0, 0]), 96],\n // RFC6145\n rfc6145: [new IPv6([0, 0, 0, 0, 0xffff, 0, 0, 0]), 96],\n // RFC6052\n rfc6052: [new IPv6([0x64, 0xff9b, 0, 0, 0, 0, 0, 0]), 96],\n // RFC3056\n '6to4': [new IPv6([0x2002, 0, 0, 0, 0, 0, 0, 0]), 16],\n // RFC6052, RFC6146\n teredo: [new IPv6([0x2001, 0, 0, 0, 0, 0, 0, 0]), 32],\n // RFC4291\n reserved: [[new IPv6([0x2001, 0xdb8, 0, 0, 0, 0, 0, 0]), 32]]\n };\n\n // Checks if this address is an IPv4-mapped IPv6 address.\n IPv6.prototype.isIPv4MappedAddress = function () {\n return this.range() === 'ipv4Mapped';\n };\n\n // The 'kind' method exists on both IPv4 and IPv6 classes.\n IPv6.prototype.kind = function () {\n return 'ipv6';\n };\n\n // Checks if this address matches other one within given CIDR range.\n IPv6.prototype.match = function (other, cidrRange) {\n let ref;\n\n if (cidrRange === undefined) {\n ref = other;\n other = ref[0];\n cidrRange = ref[1];\n }\n\n if (other.kind() !== 'ipv6') {\n throw new Error('ipaddr: cannot match ipv6 address with non-ipv6 one');\n }\n\n return matchCIDR(this.parts, other.parts, 16, cidrRange);\n };\n\n // returns a number of leading ones in IPv6 address, making sure that\n // the rest is a solid sequence of 0's (valid netmask)\n // returns either the CIDR length or null if mask is not valid\n IPv6.prototype.prefixLengthFromSubnetMask = function () {\n let cidr = 0;\n // non-zero encountered stop scanning for zeroes\n let stop = false;\n // number of zeroes in octet\n const zerotable = {\n 0: 16,\n 32768: 15,\n 49152: 14,\n 57344: 13,\n 61440: 12,\n 63488: 11,\n 64512: 10,\n 65024: 9,\n 65280: 8,\n 65408: 7,\n 65472: 6,\n 65504: 5,\n 65520: 4,\n 65528: 3,\n 65532: 2,\n 65534: 1,\n 65535: 0\n };\n let part, zeros;\n\n for (let i = 7; i >= 0; i -= 1) {\n part = this.parts[i];\n if (part in zerotable) {\n zeros = zerotable[part];\n if (stop && zeros !== 0) {\n return null;\n }\n\n if (zeros !== 16) {\n stop = true;\n }\n\n cidr += zeros;\n } else {\n return null;\n }\n }\n\n return 128 - cidr;\n };\n\n\n // Checks if the address corresponds to one of the special ranges.\n IPv6.prototype.range = function () {\n return ipaddr.subnetMatch(this, this.SpecialRanges);\n };\n\n // Returns an array of byte-sized values in network order (MSB first)\n IPv6.prototype.toByteArray = function () {\n let part;\n const bytes = [];\n const ref = this.parts;\n for (let i = 0; i < ref.length; i++) {\n part = ref[i];\n bytes.push(part >> 8);\n bytes.push(part & 0xff);\n }\n\n return bytes;\n };\n\n // Returns the address in expanded format with all zeroes included, like\n // 2001:0db8:0008:0066:0000:0000:0000:0001\n IPv6.prototype.toFixedLengthString = function () {\n const addr = ((function () {\n const results = [];\n for (let i = 0; i < this.parts.length; i++) {\n results.push(padPart(this.parts[i].toString(16), 4));\n }\n\n return results;\n }).call(this)).join(':');\n\n let suffix = '';\n\n if (this.zoneId) {\n suffix = `%${this.zoneId}`;\n }\n\n return addr + suffix;\n };\n\n // Converts this address to IPv4 address if it is an IPv4-mapped IPv6 address.\n // Throws an error otherwise.\n IPv6.prototype.toIPv4Address = function () {\n if (!this.isIPv4MappedAddress()) {\n throw new Error('ipaddr: trying to convert a generic ipv6 address to ipv4');\n }\n\n const ref = this.parts.slice(-2);\n const high = ref[0];\n const low = ref[1];\n\n return new ipaddr.IPv4([high >> 8, high & 0xff, low >> 8, low & 0xff]);\n };\n\n // Returns the address in expanded format with all zeroes included, like\n // 2001:db8:8:66:0:0:0:1\n //\n // Deprecated: use toFixedLengthString() instead.\n IPv6.prototype.toNormalizedString = function () {\n const addr = ((function () {\n const results = [];\n\n for (let i = 0; i < this.parts.length; i++) {\n results.push(this.parts[i].toString(16));\n }\n\n return results;\n }).call(this)).join(':');\n\n let suffix = '';\n\n if (this.zoneId) {\n suffix = `%${this.zoneId}`;\n }\n\n return addr + suffix;\n };\n\n // Returns the address in compact, human-readable format like\n // 2001:db8:8:66::1\n // in line with RFC 5952 (see https://tools.ietf.org/html/rfc5952#section-4)\n IPv6.prototype.toRFC5952String = function () {\n const regex = /((^|:)(0(:|$)){2,})/g;\n const string = this.toNormalizedString();\n let bestMatchIndex = 0;\n let bestMatchLength = -1;\n let match;\n\n while ((match = regex.exec(string))) {\n if (match[0].length > bestMatchLength) {\n bestMatchIndex = match.index;\n bestMatchLength = match[0].length;\n }\n }\n\n if (bestMatchLength < 0) {\n return string;\n }\n\n return `${string.substring(0, bestMatchIndex)}::${string.substring(bestMatchIndex + bestMatchLength)}`;\n };\n\n // Returns the address in compact, human-readable format like\n // 2001:db8:8:66::1\n //\n // Deprecated: use toRFC5952String() instead.\n IPv6.prototype.toString = function () {\n // Replace the first sequence of 1 or more '0' parts with '::'\n return this.toNormalizedString().replace(/((^|:)(0(:|$))+)/, '::');\n };\n\n return IPv6;\n\n })();\n\n // A utility function to return broadcast address given the IPv6 interface and prefix length in CIDR notation\n ipaddr.IPv6.broadcastAddressFromCIDR = function (string) {\n try {\n const cidr = this.parseCIDR(string);\n const ipInterfaceOctets = cidr[0].toByteArray();\n const subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();\n const octets = [];\n let i = 0;\n while (i < 16) {\n // Broadcast address is bitwise OR between ip interface and inverted mask\n octets.push(parseInt(ipInterfaceOctets[i], 10) | parseInt(subnetMaskOctets[i], 10) ^ 255);\n i++;\n }\n\n return new this(octets);\n } catch (e) {\n throw new Error(`ipaddr: the address does not have IPv6 CIDR format (${e})`);\n }\n };\n\n // Checks if a given string is formatted like IPv6 address.\n ipaddr.IPv6.isIPv6 = function (string) {\n return this.parser(string) !== null;\n };\n\n // Checks to see if string is a valid IPv6 Address\n ipaddr.IPv6.isValid = function (string) {\n\n // Since IPv6.isValid is always called first, this shortcut\n // provides a substantial performance gain.\n if (typeof string === 'string' && string.indexOf(':') === -1) {\n return false;\n }\n\n try {\n const addr = this.parser(string);\n new this(addr.parts, addr.zoneId);\n return true;\n } catch (e) {\n return false;\n }\n };\n\n // A utility function to return network address given the IPv6 interface and prefix length in CIDR notation\n ipaddr.IPv6.networkAddressFromCIDR = function (string) {\n let cidr, i, ipInterfaceOctets, octets, subnetMaskOctets;\n\n try {\n cidr = this.parseCIDR(string);\n ipInterfaceOctets = cidr[0].toByteArray();\n subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();\n octets = [];\n i = 0;\n while (i < 16) {\n // Network address is bitwise AND between ip interface and mask\n octets.push(parseInt(ipInterfaceOctets[i], 10) & parseInt(subnetMaskOctets[i], 10));\n i++;\n }\n\n return new this(octets);\n } catch (e) {\n throw new Error(`ipaddr: the address does not have IPv6 CIDR format (${e})`);\n }\n };\n\n // Tries to parse and validate a string with IPv6 address.\n // Throws an error if it fails.\n ipaddr.IPv6.parse = function (string) {\n const addr = this.parser(string);\n\n if (addr.parts === null) {\n throw new Error('ipaddr: string is not formatted like an IPv6 Address');\n }\n\n return new this(addr.parts, addr.zoneId);\n };\n\n ipaddr.IPv6.parseCIDR = function (string) {\n let maskLength, match, parsed;\n\n if ((match = string.match(/^(.+)\\/(\\d+)$/))) {\n maskLength = parseInt(match[2]);\n if (maskLength >= 0 && maskLength <= 128) {\n parsed = [this.parse(match[1]), maskLength];\n Object.defineProperty(parsed, 'toString', {\n value: function () {\n return this.join('/');\n }\n });\n return parsed;\n }\n }\n\n throw new Error('ipaddr: string is not formatted like an IPv6 CIDR range');\n };\n\n // Parse an IPv6 address.\n ipaddr.IPv6.parser = function (string) {\n let addr, i, match, octet, octets, zoneId;\n\n if ((match = string.match(ipv6Regexes.deprecatedTransitional))) {\n return this.parser(`::ffff:${match[1]}`);\n }\n if (ipv6Regexes.native.test(string)) {\n return expandIPv6(string, 8);\n }\n if ((match = string.match(ipv6Regexes.transitional))) {\n zoneId = match[6] || '';\n addr = expandIPv6(match[1].slice(0, -1) + zoneId, 6);\n if (addr.parts) {\n octets = [\n parseInt(match[2]),\n parseInt(match[3]),\n parseInt(match[4]),\n parseInt(match[5])\n ];\n for (i = 0; i < octets.length; i++) {\n octet = octets[i];\n if (!((0 <= octet && octet <= 255))) {\n return null;\n }\n }\n\n addr.parts.push(octets[0] << 8 | octets[1]);\n addr.parts.push(octets[2] << 8 | octets[3]);\n return {\n parts: addr.parts,\n zoneId: addr.zoneId\n };\n }\n }\n\n return null;\n };\n\n // A utility function to return subnet mask in IPv6 format given the prefix length\n ipaddr.IPv6.subnetMaskFromPrefixLength = function (prefix) {\n prefix = parseInt(prefix);\n if (prefix < 0 || prefix > 128) {\n throw new Error('ipaddr: invalid IPv6 prefix length');\n }\n\n const octets = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];\n let j = 0;\n const filledOctetCount = Math.floor(prefix / 8);\n\n while (j < filledOctetCount) {\n octets[j] = 255;\n j++;\n }\n\n if (filledOctetCount < 16) {\n octets[filledOctetCount] = Math.pow(2, prefix % 8) - 1 << 8 - (prefix % 8);\n }\n\n return new this(octets);\n };\n\n // Try to parse an array in network order (MSB first) for IPv4 and IPv6\n ipaddr.fromByteArray = function (bytes) {\n const length = bytes.length;\n\n if (length === 4) {\n return new ipaddr.IPv4(bytes);\n } else if (length === 16) {\n return new ipaddr.IPv6(bytes);\n } else {\n throw new Error('ipaddr: the binary input is neither an IPv6 nor IPv4 address');\n }\n };\n\n // Checks if the address is valid IP address\n ipaddr.isValid = function (string) {\n return ipaddr.IPv6.isValid(string) || ipaddr.IPv4.isValid(string);\n };\n\n\n // Attempts to parse an IP Address, first through IPv6 then IPv4.\n // Throws an error if it could not be parsed.\n ipaddr.parse = function (string) {\n if (ipaddr.IPv6.isValid(string)) {\n return ipaddr.IPv6.parse(string);\n } else if (ipaddr.IPv4.isValid(string)) {\n return ipaddr.IPv4.parse(string);\n } else {\n throw new Error('ipaddr: the address has neither IPv6 nor IPv4 format');\n }\n };\n\n // Attempt to parse CIDR notation, first through IPv6 then IPv4.\n // Throws an error if it could not be parsed.\n ipaddr.parseCIDR = function (string) {\n try {\n return ipaddr.IPv6.parseCIDR(string);\n } catch (e) {\n try {\n return ipaddr.IPv4.parseCIDR(string);\n } catch (e2) {\n throw new Error('ipaddr: the address has neither IPv6 nor IPv4 CIDR format');\n }\n }\n };\n\n // Parse an address and return plain IPv4 address if it is an IPv4-mapped address\n ipaddr.process = function (string) {\n const addr = this.parse(string);\n\n if (addr.kind() === 'ipv6' && addr.isIPv4MappedAddress()) {\n return addr.toIPv4Address();\n } else {\n return addr;\n }\n };\n\n // An utility function to ease named range matching. See examples below.\n // rangeList can contain both IPv4 and IPv6 subnet entries and will not throw errors\n // on matching IPv4 addresses to IPv6 ranges or vice versa.\n ipaddr.subnetMatch = function (address, rangeList, defaultName) {\n let i, rangeName, rangeSubnets, subnet;\n\n if (defaultName === undefined || defaultName === null) {\n defaultName = 'unicast';\n }\n\n for (rangeName in rangeList) {\n if (Object.prototype.hasOwnProperty.call(rangeList, rangeName)) {\n rangeSubnets = rangeList[rangeName];\n // ECMA5 Array.isArray isn't available everywhere\n if (rangeSubnets[0] && !(rangeSubnets[0] instanceof Array)) {\n rangeSubnets = [rangeSubnets];\n }\n\n for (i = 0; i < rangeSubnets.length; i++) {\n subnet = rangeSubnets[i];\n if (address.kind() === subnet[0].kind() && address.match.apply(address, subnet)) {\n return rangeName;\n }\n }\n }\n }\n\n return defaultName;\n };\n\n // Export for both the CommonJS and browser-like environment\n if (typeof module !== 'undefined' && module.exports) {\n module.exports = ipaddr;\n\n } else {\n root.ipaddr = ipaddr;\n }\n\n}(this));\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:transports'), {\n error: debug('libp2p:transports:err')\n})\n\nconst pSettle = require('p-settle')\nconst { codes } = require('./errors')\nconst errCode = require('err-code')\n\nconst { updateSelfPeerRecord } = require('./record/utils')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/transport/types').TransportFactory<any, any>} TransportFactory\n * @typedef {import('libp2p-interfaces/src/transport/types').Transport<any, any>} Transport\n *\n * @typedef {Object} TransportManagerProperties\n * @property {import('./')} libp2p\n * @property {import('./upgrader')} upgrader\n *\n * @typedef {Object} TransportManagerOptions\n * @property {number} [faultTolerance = FAULT_TOLERANCE.FATAL_ALL] - Address listen error tolerance.\n */\n\nclass TransportManager {\n /**\n * @class\n * @param {TransportManagerProperties & TransportManagerOptions} options\n */\n constructor ({ libp2p, upgrader, faultTolerance = FAULT_TOLERANCE.FATAL_ALL }) {\n this.libp2p = libp2p\n this.upgrader = upgrader\n /** @type {Map<string, Transport>} */\n this._transports = new Map()\n this._listeners = new Map()\n this._listenerOptions = new Map()\n this.faultTolerance = faultTolerance\n }\n\n /**\n * Adds a `Transport` to the manager\n *\n * @param {string} key\n * @param {TransportFactory} Transport\n * @param {*} transportOptions - Additional options to pass to the transport\n * @returns {void}\n */\n add (key, Transport, transportOptions = {}) {\n log('adding %s', key)\n if (!key) {\n throw errCode(new Error(`Transport must have a valid key, was given '${key}'`), codes.ERR_INVALID_KEY)\n }\n if (this._transports.has(key)) {\n throw errCode(new Error('There is already a transport with this key'), codes.ERR_DUPLICATE_TRANSPORT)\n }\n\n const transport = new Transport({\n ...transportOptions,\n libp2p: this.libp2p,\n upgrader: this.upgrader\n })\n\n this._transports.set(key, transport)\n this._listenerOptions.set(key, transportOptions.listenerOptions || {})\n if (!this._listeners.has(key)) {\n this._listeners.set(key, [])\n }\n }\n\n /**\n * Stops all listeners\n *\n * @async\n */\n async close () {\n const tasks = []\n for (const [key, listeners] of this._listeners) {\n log('closing listeners for %s', key)\n while (listeners.length) {\n const listener = listeners.pop()\n listener.removeAllListeners('listening')\n listener.removeAllListeners('close')\n tasks.push(listener.close())\n }\n }\n\n await Promise.all(tasks)\n log('all listeners closed')\n for (const key of this._listeners.keys()) {\n this._listeners.set(key, [])\n }\n }\n\n /**\n * Dials the given Multiaddr over it's supported transport\n *\n * @param {Multiaddr} ma\n * @param {*} options\n * @returns {Promise<Connection>}\n */\n async dial (ma, options) {\n const transport = this.transportForMultiaddr(ma)\n if (!transport) {\n throw errCode(new Error(`No transport available for address ${String(ma)}`), codes.ERR_TRANSPORT_UNAVAILABLE)\n }\n\n try {\n return await transport.dial(ma, options)\n } catch (err) {\n if (!err.code) err.code = codes.ERR_TRANSPORT_DIAL_FAILED\n throw err\n }\n }\n\n /**\n * Returns all Multiaddr's the listeners are using\n *\n * @returns {Multiaddr[]}\n */\n getAddrs () {\n /** @type {Multiaddr[]} */\n let addrs = []\n for (const listeners of this._listeners.values()) {\n for (const listener of listeners) {\n addrs = [...addrs, ...listener.getAddrs()]\n }\n }\n return addrs\n }\n\n /**\n * Returns all the transports instances.\n *\n * @returns {IterableIterator<Transport>}\n */\n getTransports () {\n return this._transports.values()\n }\n\n /**\n * Finds a transport that matches the given Multiaddr\n *\n * @param {Multiaddr} ma\n * @returns {Transport|null}\n */\n transportForMultiaddr (ma) {\n for (const transport of this._transports.values()) {\n const addrs = transport.filter([ma])\n if (addrs.length) return transport\n }\n return null\n }\n\n /**\n * Starts listeners for each listen Multiaddr.\n *\n * @async\n * @param {Multiaddr[]} addrs - addresses to attempt to listen on\n */\n async listen (addrs) {\n if (!addrs || addrs.length === 0) {\n log('no addresses were provided for listening, this node is dial only')\n return\n }\n\n const couldNotListen = []\n for (const [key, transport] of this._transports.entries()) {\n const supportedAddrs = transport.filter(addrs)\n const tasks = []\n\n // For each supported multiaddr, create a listener\n for (const addr of supportedAddrs) {\n log('creating listener for %s on %s', key, addr)\n const listener = transport.createListener(this._listenerOptions.get(key))\n this._listeners.get(key).push(listener)\n\n // Track listen/close events\n listener.on('listening', () => updateSelfPeerRecord(this.libp2p))\n listener.on('close', () => updateSelfPeerRecord(this.libp2p))\n\n // We need to attempt to listen on everything\n tasks.push(listener.listen(addr))\n }\n\n // Keep track of transports we had no addresses for\n if (tasks.length === 0) {\n couldNotListen.push(key)\n continue\n }\n\n const results = await pSettle(tasks)\n // If we are listening on at least 1 address, succeed.\n // TODO: we should look at adding a retry (`p-retry`) here to better support\n // listening on remote addresses as they may be offline. We could then potentially\n // just wait for any (`p-any`) listener to succeed on each transport before returning\n const isListening = results.find(r => r.isFulfilled === true)\n if (!isListening && this.faultTolerance !== FAULT_TOLERANCE.NO_FATAL) {\n throw errCode(new Error(`Transport (${key}) could not listen on any available address`), codes.ERR_NO_VALID_ADDRESSES)\n }\n }\n\n // If no transports were able to listen, throw an error. This likely\n // means we were given addresses we do not have transports for\n if (couldNotListen.length === this._transports.size) {\n const message = `no valid addresses were provided for transports [${couldNotListen}]`\n if (this.faultTolerance === FAULT_TOLERANCE.FATAL_ALL) {\n throw errCode(new Error(message), codes.ERR_NO_VALID_ADDRESSES)\n }\n log(`libp2p in dial mode only: ${message}`)\n }\n }\n\n /**\n * Removes the given transport from the manager.\n * If a transport has any running listeners, they will be closed.\n *\n * @async\n * @param {string} key\n */\n async remove (key) {\n log('removing %s', key)\n if (this._listeners.has(key)) {\n // Close any running listeners\n for (const listener of this._listeners.get(key)) {\n listener.removeAllListeners('listening')\n listener.removeAllListeners('close')\n await listener.close()\n }\n }\n\n this._transports.delete(key)\n this._listeners.delete(key)\n }\n\n /**\n * Removes all transports from the manager.\n * If any listeners are running, they will be closed.\n *\n * @async\n */\n async removeAll () {\n const tasks = []\n for (const key of this._transports.keys()) {\n tasks.push(this.remove(key))\n }\n\n await Promise.all(tasks)\n }\n}\n\n/**\n * Enum Transport Manager Fault Tolerance values.\n * FATAL_ALL should be used for failing in any listen circumstance.\n * NO_FATAL should be used for not failing when not listening.\n *\n * @readonly\n * @enum {number}\n */\nconst FAULT_TOLERANCE = {\n FATAL_ALL: 0,\n NO_FATAL: 1\n}\n\nTransportManager.FaultTolerance = FAULT_TOLERANCE\n\nmodule.exports = TransportManager\n","'use strict';\nconst pReflect = require('p-reflect');\nconst pLimit = require('p-limit');\n\nmodule.exports = async (array, options = {}) => {\n\tconst {concurrency = Infinity} = options;\n\tconst limit = pLimit(concurrency);\n\n\treturn Promise.all(array.map(element => {\n\t\tif (element && typeof element.then === 'function') { // eslint-disable-line promise/prefer-await-to-then\n\t\t\treturn pReflect(element);\n\t\t}\n\n\t\tif (typeof element === 'function') {\n\t\t\treturn pReflect(limit(() => element()));\n\t\t}\n\n\t\treturn pReflect(Promise.resolve(element));\n\t}));\n};\n","'use strict';\n\nconst pReflect = async promise => {\n\ttry {\n\t\tconst value = await promise;\n\t\treturn {\n\t\t\tisFulfilled: true,\n\t\t\tisRejected: false,\n\t\t\tvalue\n\t\t};\n\t} catch (error) {\n\t\treturn {\n\t\t\tisFulfilled: false,\n\t\t\tisRejected: true,\n\t\t\treason: error\n\t\t};\n\t}\n};\n\nmodule.exports = pReflect;\n// TODO: Remove this for the next major release\nmodule.exports.default = pReflect;\n","'use strict';\nconst pTry = require('p-try');\n\nconst pLimit = concurrency => {\n\tif (!((Number.isInteger(concurrency) || concurrency === Infinity) && concurrency > 0)) {\n\t\treturn Promise.reject(new TypeError('Expected `concurrency` to be a number from 1 and up'));\n\t}\n\n\tconst queue = [];\n\tlet activeCount = 0;\n\n\tconst next = () => {\n\t\tactiveCount--;\n\n\t\tif (queue.length > 0) {\n\t\t\tqueue.shift()();\n\t\t}\n\t};\n\n\tconst run = (fn, resolve, ...args) => {\n\t\tactiveCount++;\n\n\t\tconst result = pTry(fn, ...args);\n\n\t\tresolve(result);\n\n\t\tresult.then(next, next);\n\t};\n\n\tconst enqueue = (fn, resolve, ...args) => {\n\t\tif (activeCount < concurrency) {\n\t\t\trun(fn, resolve, ...args);\n\t\t} else {\n\t\t\tqueue.push(run.bind(null, fn, resolve, ...args));\n\t\t}\n\t};\n\n\tconst generator = (fn, ...args) => new Promise(resolve => enqueue(fn, resolve, ...args));\n\tObject.defineProperties(generator, {\n\t\tactiveCount: {\n\t\t\tget: () => activeCount\n\t\t},\n\t\tpendingCount: {\n\t\t\tget: () => queue.length\n\t\t},\n\t\tclearQueue: {\n\t\t\tvalue: () => {\n\t\t\t\tqueue.length = 0;\n\t\t\t}\n\t\t}\n\t});\n\n\treturn generator;\n};\n\nmodule.exports = pLimit;\nmodule.exports.default = pLimit;\n","'use strict';\n\nconst pTry = (fn, ...arguments_) => new Promise(resolve => {\n\tresolve(fn(...arguments_));\n});\n\nmodule.exports = pTry;\n// TODO: remove this in the next major version\nmodule.exports.default = pTry;\n","'use strict'\n\nconst Envelope = require('./envelope')\nconst PeerRecord = require('./peer-record')\n\n/**\n * @typedef {import('../')} Libp2p\n */\n\n/**\n * Create (or update if existing) self peer record and store it in the AddressBook.\n *\n * @param {Libp2p} libp2p\n * @returns {Promise<void>}\n */\nasync function updateSelfPeerRecord (libp2p) {\n const peerRecord = new PeerRecord({\n peerId: libp2p.peerId,\n multiaddrs: libp2p.multiaddrs\n })\n const envelope = await Envelope.seal(peerRecord, libp2p.peerId)\n libp2p.peerStore.addressBook.consumePeerRecord(envelope)\n}\n\nmodule.exports.updateSelfPeerRecord = updateSelfPeerRecord\n","'use strict'\n\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\nconst arrayEquals = require('libp2p-utils/src/array-equals')\n\nconst { PeerRecord: Protobuf } = require('./peer-record')\nconst {\n ENVELOPE_DOMAIN_PEER_RECORD,\n ENVELOPE_PAYLOAD_TYPE_PEER_RECORD\n} = require('./consts')\n\n/**\n * @typedef {import('../../peer-store/address-book.js').Address} Address\n * @typedef {import('libp2p-interfaces/src/record/types').Record} Record\n */\n\n/**\n * @implements {Record}\n */\nclass PeerRecord {\n /**\n * The PeerRecord is used for distributing peer routing records across the network.\n * It contains the peer's reachable listen addresses.\n *\n * @class\n * @param {Object} params\n * @param {PeerId} params.peerId\n * @param {Multiaddr[]} params.multiaddrs - addresses of the associated peer.\n * @param {number} [params.seqNumber] - monotonically-increasing sequence counter that's used to order PeerRecords in time.\n */\n constructor ({ peerId, multiaddrs = [], seqNumber = Date.now() }) {\n this.domain = ENVELOPE_DOMAIN_PEER_RECORD\n this.codec = ENVELOPE_PAYLOAD_TYPE_PEER_RECORD\n\n this.peerId = peerId\n this.multiaddrs = multiaddrs\n this.seqNumber = seqNumber\n\n // Cache\n this._marshal = undefined\n }\n\n /**\n * Marshal a record to be used in an envelope.\n *\n * @returns {Uint8Array}\n */\n marshal () {\n if (this._marshal) {\n return this._marshal\n }\n\n this._marshal = Protobuf.encode({\n peerId: this.peerId.toBytes(),\n seq: this.seqNumber,\n addresses: this.multiaddrs.map((m) => ({\n multiaddr: m.bytes\n }))\n }).finish()\n\n return this._marshal\n }\n\n /**\n * Returns true if `this` record equals the `other`.\n *\n * @param {unknown} other\n * @returns {boolean}\n */\n equals (other) {\n if (!(other instanceof PeerRecord)) {\n return false\n }\n\n // Validate PeerId\n if (!this.peerId.equals(other.peerId)) {\n return false\n }\n\n // Validate seqNumber\n if (this.seqNumber !== other.seqNumber) {\n return false\n }\n\n // Validate multiaddrs\n if (!arrayEquals(this.multiaddrs, other.multiaddrs)) {\n return false\n }\n\n return true\n }\n}\n\n/**\n * Unmarshal Peer Record Protobuf.\n *\n * @param {Uint8Array} buf - marshaled peer record.\n * @returns {PeerRecord}\n */\nPeerRecord.createFromProtobuf = (buf) => {\n const peerRecord = Protobuf.decode(buf)\n\n const peerId = PeerId.createFromBytes(peerRecord.peerId)\n const multiaddrs = (peerRecord.addresses || []).map((a) => new Multiaddr(a.multiaddr))\n const seqNumber = Number(peerRecord.seq)\n\n return new PeerRecord({ peerId, multiaddrs, seqNumber })\n}\n\nPeerRecord.DOMAIN = ENVELOPE_DOMAIN_PEER_RECORD\n\nmodule.exports = PeerRecord\n","'use strict'\n\n/**\n * Verify if two arrays of non primitive types with the \"equals\" function are equal.\n * Compatible with multiaddr, peer-id and others.\n *\n * @param {Array<*>} a\n * @param {Array<*>} b\n * @returns {boolean}\n */\nfunction arrayEquals (a, b) {\n return a.length === b.length && b.sort() && a.sort().every((item, index) => b[index].equals(item))\n}\n\nmodule.exports = arrayEquals\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-peer-record\"] || ($protobuf.roots[\"libp2p-peer-record\"] = {});\n\n$root.PeerRecord = (function() {\n\n /**\n * Properties of a PeerRecord.\n * @exports IPeerRecord\n * @interface IPeerRecord\n * @property {Uint8Array|null} [peerId] PeerRecord peerId\n * @property {number|null} [seq] PeerRecord seq\n * @property {Array.<PeerRecord.IAddressInfo>|null} [addresses] PeerRecord addresses\n */\n\n /**\n * Constructs a new PeerRecord.\n * @exports PeerRecord\n * @classdesc Represents a PeerRecord.\n * @implements IPeerRecord\n * @constructor\n * @param {IPeerRecord=} [p] Properties to set\n */\n function PeerRecord(p) {\n this.addresses = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * PeerRecord peerId.\n * @member {Uint8Array} peerId\n * @memberof PeerRecord\n * @instance\n */\n PeerRecord.prototype.peerId = $util.newBuffer([]);\n\n /**\n * PeerRecord seq.\n * @member {number} seq\n * @memberof PeerRecord\n * @instance\n */\n PeerRecord.prototype.seq = $util.Long ? $util.Long.fromBits(0,0,true) : 0;\n\n /**\n * PeerRecord addresses.\n * @member {Array.<PeerRecord.IAddressInfo>} addresses\n * @memberof PeerRecord\n * @instance\n */\n PeerRecord.prototype.addresses = $util.emptyArray;\n\n /**\n * Encodes the specified PeerRecord message. Does not implicitly {@link PeerRecord.verify|verify} messages.\n * @function encode\n * @memberof PeerRecord\n * @static\n * @param {IPeerRecord} m PeerRecord message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n PeerRecord.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.peerId != null && Object.hasOwnProperty.call(m, \"peerId\"))\n w.uint32(10).bytes(m.peerId);\n if (m.seq != null && Object.hasOwnProperty.call(m, \"seq\"))\n w.uint32(16).uint64(m.seq);\n if (m.addresses != null && m.addresses.length) {\n for (var i = 0; i < m.addresses.length; ++i)\n $root.PeerRecord.AddressInfo.encode(m.addresses[i], w.uint32(26).fork()).ldelim();\n }\n return w;\n };\n\n /**\n * Decodes a PeerRecord message from the specified reader or buffer.\n * @function decode\n * @memberof PeerRecord\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PeerRecord} PeerRecord\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n PeerRecord.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PeerRecord();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.peerId = r.bytes();\n break;\n case 2:\n m.seq = r.uint64();\n break;\n case 3:\n if (!(m.addresses && m.addresses.length))\n m.addresses = [];\n m.addresses.push($root.PeerRecord.AddressInfo.decode(r, r.uint32()));\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a PeerRecord message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PeerRecord\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {PeerRecord} PeerRecord\n */\n PeerRecord.fromObject = function fromObject(d) {\n if (d instanceof $root.PeerRecord)\n return d;\n var m = new $root.PeerRecord();\n if (d.peerId != null) {\n if (typeof d.peerId === \"string\")\n $util.base64.decode(d.peerId, m.peerId = $util.newBuffer($util.base64.length(d.peerId)), 0);\n else if (d.peerId.length)\n m.peerId = d.peerId;\n }\n if (d.seq != null) {\n if ($util.Long)\n (m.seq = $util.Long.fromValue(d.seq)).unsigned = true;\n else if (typeof d.seq === \"string\")\n m.seq = parseInt(d.seq, 10);\n else if (typeof d.seq === \"number\")\n m.seq = d.seq;\n else if (typeof d.seq === \"object\")\n m.seq = new $util.LongBits(d.seq.low >>> 0, d.seq.high >>> 0).toNumber(true);\n }\n if (d.addresses) {\n if (!Array.isArray(d.addresses))\n throw TypeError(\".PeerRecord.addresses: array expected\");\n m.addresses = [];\n for (var i = 0; i < d.addresses.length; ++i) {\n if (typeof d.addresses[i] !== \"object\")\n throw TypeError(\".PeerRecord.addresses: object expected\");\n m.addresses[i] = $root.PeerRecord.AddressInfo.fromObject(d.addresses[i]);\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a PeerRecord message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PeerRecord\n * @static\n * @param {PeerRecord} m PeerRecord\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n PeerRecord.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.addresses = [];\n }\n if (o.defaults) {\n if (o.bytes === String)\n d.peerId = \"\";\n else {\n d.peerId = [];\n if (o.bytes !== Array)\n d.peerId = $util.newBuffer(d.peerId);\n }\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.seq = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.seq = o.longs === String ? \"0\" : 0;\n }\n if (m.peerId != null && m.hasOwnProperty(\"peerId\")) {\n d.peerId = o.bytes === String ? $util.base64.encode(m.peerId, 0, m.peerId.length) : o.bytes === Array ? Array.prototype.slice.call(m.peerId) : m.peerId;\n }\n if (m.seq != null && m.hasOwnProperty(\"seq\")) {\n if (typeof m.seq === \"number\")\n d.seq = o.longs === String ? String(m.seq) : m.seq;\n else\n d.seq = o.longs === String ? $util.Long.prototype.toString.call(m.seq) : o.longs === Number ? new $util.LongBits(m.seq.low >>> 0, m.seq.high >>> 0).toNumber(true) : m.seq;\n }\n if (m.addresses && m.addresses.length) {\n d.addresses = [];\n for (var j = 0; j < m.addresses.length; ++j) {\n d.addresses[j] = $root.PeerRecord.AddressInfo.toObject(m.addresses[j], o);\n }\n }\n return d;\n };\n\n /**\n * Converts this PeerRecord to JSON.\n * @function toJSON\n * @memberof PeerRecord\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n PeerRecord.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n PeerRecord.AddressInfo = (function() {\n\n /**\n * Properties of an AddressInfo.\n * @memberof PeerRecord\n * @interface IAddressInfo\n * @property {Uint8Array|null} [multiaddr] AddressInfo multiaddr\n */\n\n /**\n * Constructs a new AddressInfo.\n * @memberof PeerRecord\n * @classdesc Represents an AddressInfo.\n * @implements IAddressInfo\n * @constructor\n * @param {PeerRecord.IAddressInfo=} [p] Properties to set\n */\n function AddressInfo(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * AddressInfo multiaddr.\n * @member {Uint8Array} multiaddr\n * @memberof PeerRecord.AddressInfo\n * @instance\n */\n AddressInfo.prototype.multiaddr = $util.newBuffer([]);\n\n /**\n * Encodes the specified AddressInfo message. Does not implicitly {@link PeerRecord.AddressInfo.verify|verify} messages.\n * @function encode\n * @memberof PeerRecord.AddressInfo\n * @static\n * @param {PeerRecord.IAddressInfo} m AddressInfo message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n AddressInfo.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.multiaddr != null && Object.hasOwnProperty.call(m, \"multiaddr\"))\n w.uint32(10).bytes(m.multiaddr);\n return w;\n };\n\n /**\n * Decodes an AddressInfo message from the specified reader or buffer.\n * @function decode\n * @memberof PeerRecord.AddressInfo\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {PeerRecord.AddressInfo} AddressInfo\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n AddressInfo.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.PeerRecord.AddressInfo();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.multiaddr = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an AddressInfo message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof PeerRecord.AddressInfo\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {PeerRecord.AddressInfo} AddressInfo\n */\n AddressInfo.fromObject = function fromObject(d) {\n if (d instanceof $root.PeerRecord.AddressInfo)\n return d;\n var m = new $root.PeerRecord.AddressInfo();\n if (d.multiaddr != null) {\n if (typeof d.multiaddr === \"string\")\n $util.base64.decode(d.multiaddr, m.multiaddr = $util.newBuffer($util.base64.length(d.multiaddr)), 0);\n else if (d.multiaddr.length)\n m.multiaddr = d.multiaddr;\n }\n return m;\n };\n\n /**\n * Creates a plain object from an AddressInfo message. Also converts values to other types if specified.\n * @function toObject\n * @memberof PeerRecord.AddressInfo\n * @static\n * @param {PeerRecord.AddressInfo} m AddressInfo\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n AddressInfo.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.multiaddr = \"\";\n else {\n d.multiaddr = [];\n if (o.bytes !== Array)\n d.multiaddr = $util.newBuffer(d.multiaddr);\n }\n }\n if (m.multiaddr != null && m.hasOwnProperty(\"multiaddr\")) {\n d.multiaddr = o.bytes === String ? $util.base64.encode(m.multiaddr, 0, m.multiaddr.length) : o.bytes === Array ? Array.prototype.slice.call(m.multiaddr) : m.multiaddr;\n }\n return d;\n };\n\n /**\n * Converts this AddressInfo to JSON.\n * @function toJSON\n * @memberof PeerRecord.AddressInfo\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n AddressInfo.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return AddressInfo;\n })();\n\n return PeerRecord;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\n// The domain string used for peer records contained in a Envelope.\nconst domain = 'libp2p-peer-record'\n\n// The type hint used to identify peer records in a Envelope.\n// Defined in https://github.com/multiformats/multicodec/blob/master/table.csv\n// with name \"libp2p-peer-record\"\nconst payloadType = Uint8Array.from([3, 1])\n\nmodule.exports = {\n ENVELOPE_DOMAIN_PEER_RECORD: domain,\n ENVELOPE_PAYLOAD_TYPE_PEER_RECORD: payloadType\n}\n","'use strict'\n\nconst { EventEmitter } = require('events')\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\n\n/**\n * @typedef {Object} AddressManagerOptions\n * @property {string[]} [listen = []] - list of multiaddrs string representation to listen.\n * @property {string[]} [announce = []] - list of multiaddrs string representation to announce.\n */\n\n/**\n * @fires AddressManager#change:addresses Emitted when a addresses change.\n */\nclass AddressManager extends EventEmitter {\n /**\n * Responsible for managing the peer addresses.\n * Peers can specify their listen and announce addresses.\n * The listen addresses will be used by the libp2p transports to listen for new connections,\n * while the announce addresses will be used for the peer addresses' to other peers in the network.\n *\n * @class\n * @param {PeerId} peerId - The Peer ID of the node\n * @param {object} [options]\n * @param {Array<string>} [options.listen = []] - list of multiaddrs string representation to listen.\n * @param {Array<string>} [options.announce = []] - list of multiaddrs string representation to announce.\n */\n constructor (peerId, { listen = [], announce = [] } = {}) {\n super()\n\n this.peerId = peerId\n this.listen = new Set(listen.map(ma => ma.toString()))\n this.announce = new Set(announce.map(ma => ma.toString()))\n this.observed = new Set()\n }\n\n /**\n * Get peer listen multiaddrs.\n *\n * @returns {Multiaddr[]}\n */\n getListenAddrs () {\n return Array.from(this.listen).map((a) => new Multiaddr(a))\n }\n\n /**\n * Get peer announcing multiaddrs.\n *\n * @returns {Multiaddr[]}\n */\n getAnnounceAddrs () {\n return Array.from(this.announce).map((a) => new Multiaddr(a))\n }\n\n /**\n * Get observed multiaddrs.\n *\n * @returns {Array<Multiaddr>}\n */\n getObservedAddrs () {\n return Array.from(this.observed).map((a) => new Multiaddr(a))\n }\n\n /**\n * Add peer observed addresses\n *\n * @param {string | Multiaddr} addr\n */\n addObservedAddr (addr) {\n let ma = new Multiaddr(addr)\n const remotePeer = ma.getPeerId()\n\n // strip our peer id if it has been passed\n if (remotePeer) {\n const remotePeerId = PeerId.createFromB58String(remotePeer)\n\n // use same encoding for comparison\n if (remotePeerId.equals(this.peerId)) {\n ma = ma.decapsulate(new Multiaddr(`/p2p/${this.peerId}`))\n }\n }\n\n const addrString = ma.toString()\n\n // do not trigger the change:addresses event if we already know about this address\n if (this.observed.has(addrString)) {\n return\n }\n\n this.observed.add(addrString)\n this.emit('change:addresses')\n }\n}\n\nmodule.exports = AddressManager\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:connection-manager'), {\n error: debug('libp2p:connection-manager:err')\n})\n\nconst errcode = require('err-code')\nconst mergeOptions = require('merge-options')\nconst LatencyMonitor = require('./latency-monitor')\n// @ts-ignore retimer does not have types\nconst retimer = require('retimer')\n\nconst { EventEmitter } = require('events')\n\nconst PeerId = require('peer-id')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\nconst defaultOptions = {\n maxConnections: Infinity,\n minConnections: 0,\n maxData: Infinity,\n maxSentData: Infinity,\n maxReceivedData: Infinity,\n maxEventLoopDelay: Infinity,\n pollInterval: 2000,\n autoDialInterval: 10000,\n movingAverageInterval: 60000,\n defaultPeerValue: 1\n}\n\n/**\n * @typedef {import('../')} Libp2p\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n */\n\n/**\n * @typedef {Object} ConnectionManagerOptions\n * @property {number} [maxConnections = Infinity] - The maximum number of connections allowed.\n * @property {number} [minConnections = 0] - The minimum number of connections to avoid pruning.\n * @property {number} [maxData = Infinity] - The max data (in and out), per average interval to allow.\n * @property {number} [maxSentData = Infinity] - The max outgoing data, per average interval to allow.\n * @property {number} [maxReceivedData = Infinity] - The max incoming data, per average interval to allow.\n * @property {number} [maxEventLoopDelay = Infinity] - The upper limit the event loop can take to run.\n * @property {number} [pollInterval = 2000] - How often, in milliseconds, metrics and latency should be checked.\n * @property {number} [movingAverageInterval = 60000] - How often, in milliseconds, to compute averages.\n * @property {number} [defaultPeerValue = 1] - The value of the peer.\n * @property {boolean} [autoDial = true] - Should preemptively guarantee connections are above the low watermark.\n * @property {number} [autoDialInterval = 10000] - How often, in milliseconds, it should preemptively guarantee connections are above the low watermark.\n */\n\n/**\n *\n * @fires ConnectionManager#peer:connect Emitted when a new peer is connected.\n * @fires ConnectionManager#peer:disconnect Emitted when a peer is disconnected.\n */\nclass ConnectionManager extends EventEmitter {\n /**\n * Responsible for managing known connections.\n *\n * @class\n * @param {Libp2p} libp2p\n * @param {ConnectionManagerOptions} options\n */\n constructor (libp2p, options = {}) {\n super()\n\n this._libp2p = libp2p\n this._peerId = libp2p.peerId.toB58String()\n\n this._options = mergeOptions.call({ ignoreUndefined: true }, defaultOptions, options)\n if (this._options.maxConnections < this._options.minConnections) {\n throw errcode(new Error('Connection Manager maxConnections must be greater than minConnections'), ERR_INVALID_PARAMETERS)\n }\n\n log('options: %j', this._options)\n\n /**\n * Map of peer identifiers to their peer value for pruning connections.\n *\n * @type {Map<string, number>}\n */\n this._peerValues = new Map()\n\n /**\n * Map of connections per peer\n *\n * @type {Map<string, Connection[]>}\n */\n this.connections = new Map()\n\n this._started = false\n this._timer = null\n this._autoDialTimeout = null\n this._checkMetrics = this._checkMetrics.bind(this)\n this._autoDial = this._autoDial.bind(this)\n\n this._latencyMonitor = new LatencyMonitor({\n latencyCheckIntervalMs: this._options.pollInterval,\n dataEmitIntervalMs: this._options.pollInterval\n })\n }\n\n /**\n * Get current number of open connections.\n */\n get size () {\n return Array.from(this.connections.values())\n .reduce((accumulator, value) => accumulator + value.length, 0)\n }\n\n /**\n * Starts the Connection Manager. If Metrics are not enabled on libp2p\n * only event loop and connection limits will be monitored.\n */\n start () {\n if (this._libp2p.metrics) {\n this._timer = this._timer || retimer(this._checkMetrics, this._options.pollInterval)\n }\n\n // latency monitor\n this._latencyMonitor.start()\n this._onLatencyMeasure = this._onLatencyMeasure.bind(this)\n this._latencyMonitor.on('data', this._onLatencyMeasure)\n\n this._started = true\n log('started')\n\n this._options.autoDial && this._autoDial()\n }\n\n /**\n * Stops the Connection Manager\n *\n * @async\n */\n async stop () {\n this._autoDialTimeout && this._autoDialTimeout.clear()\n this._timer && this._timer.clear()\n\n this._latencyMonitor.removeListener('data', this._onLatencyMeasure)\n this._latencyMonitor.stop()\n\n this._started = false\n await this._close()\n log('stopped')\n }\n\n /**\n * Cleans up the connections\n *\n * @async\n */\n async _close () {\n // Close all connections we're tracking\n const tasks = []\n for (const connectionList of this.connections.values()) {\n for (const connection of connectionList) {\n tasks.push(connection.close())\n }\n }\n\n await Promise.all(tasks)\n this.connections.clear()\n }\n\n /**\n * Sets the value of the given peer. Peers with lower values\n * will be disconnected first.\n *\n * @param {PeerId} peerId\n * @param {number} value - A number between 0 and 1\n * @returns {void}\n */\n setPeerValue (peerId, value) {\n if (value < 0 || value > 1) {\n throw new Error('value should be a number between 0 and 1')\n }\n this._peerValues.set(peerId.toB58String(), value)\n }\n\n /**\n * Checks the libp2p metrics to determine if any values have exceeded\n * the configured maximums.\n *\n * @private\n */\n _checkMetrics () {\n if (this._libp2p.metrics) {\n const movingAverages = this._libp2p.metrics.global.movingAverages\n // @ts-ignore moving averages object types\n const received = movingAverages.dataReceived[this._options.movingAverageInterval].movingAverage()\n this._checkMaxLimit('maxReceivedData', received)\n // @ts-ignore moving averages object types\n const sent = movingAverages.dataSent[this._options.movingAverageInterval].movingAverage()\n this._checkMaxLimit('maxSentData', sent)\n const total = received + sent\n this._checkMaxLimit('maxData', total)\n log('metrics update', total)\n this._timer = retimer(this._checkMetrics, this._options.pollInterval)\n }\n }\n\n /**\n * Tracks the incoming connection and check the connection limit\n *\n * @param {Connection} connection\n * @returns {void}\n */\n onConnect (connection) {\n const peerId = connection.remotePeer\n const peerIdStr = peerId.toB58String()\n const storedConn = this.connections.get(peerIdStr)\n\n this.emit('peer:connect', connection)\n if (storedConn) {\n storedConn.push(connection)\n } else {\n this.connections.set(peerIdStr, [connection])\n }\n\n this._libp2p.peerStore.keyBook.set(peerId, peerId.pubKey)\n\n if (!this._peerValues.has(peerIdStr)) {\n this._peerValues.set(peerIdStr, this._options.defaultPeerValue)\n }\n\n this._checkMaxLimit('maxConnections', this.size)\n }\n\n /**\n * Removes the connection from tracking\n *\n * @param {Connection} connection\n * @returns {void}\n */\n onDisconnect (connection) {\n const peerId = connection.remotePeer.toB58String()\n let storedConn = this.connections.get(peerId)\n\n if (storedConn && storedConn.length > 1) {\n storedConn = storedConn.filter((conn) => conn.id !== connection.id)\n this.connections.set(peerId, storedConn)\n } else if (storedConn) {\n this.connections.delete(peerId)\n this._peerValues.delete(connection.remotePeer.toB58String())\n this.emit('peer:disconnect', connection)\n }\n }\n\n /**\n * Get a connection with a peer.\n *\n * @param {PeerId} peerId\n * @returns {Connection|null}\n */\n get (peerId) {\n const connections = this.getAll(peerId)\n if (connections.length) {\n return connections[0]\n }\n return null\n }\n\n /**\n * Get all open connections with a peer.\n *\n * @param {PeerId} peerId\n * @returns {Connection[]}\n */\n getAll (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const connections = this.connections.get(id)\n\n // Return all open connections\n if (connections) {\n return connections.filter(connection => connection.stat.status === 'open')\n }\n return []\n }\n\n /**\n * If the event loop is slow, maybe close a connection\n *\n * @private\n * @param {*} summary - The LatencyMonitor summary\n */\n _onLatencyMeasure (summary) {\n this._checkMaxLimit('maxEventLoopDelay', summary.avgMs)\n }\n\n /**\n * If the `value` of `name` has exceeded its limit, maybe close a connection\n *\n * @private\n * @param {string} name - The name of the field to check limits for\n * @param {number} value - The current value of the field\n */\n _checkMaxLimit (name, value) {\n const limit = this._options[name]\n log('checking limit of %s. current value: %d of %d', name, value, limit)\n if (value > limit) {\n log('%s: limit exceeded: %s, %d', this._peerId, name, value)\n this._maybeDisconnectOne()\n }\n }\n\n /**\n * Proactively tries to connect to known peers stored in the PeerStore.\n * It will keep the number of connections below the upper limit and sort\n * the peers to connect based on wether we know their keys and protocols.\n *\n * @async\n * @private\n */\n async _autoDial () {\n const minConnections = this._options.minConnections\n\n // Already has enough connections\n if (this.size >= minConnections) {\n this._autoDialTimeout = retimer(this._autoDial, this._options.autoDialInterval)\n return\n }\n\n // Sort peers on wether we know protocols of public keys for them\n const peers = Array.from(this._libp2p.peerStore.peers.values())\n .sort((a, b) => {\n if (b.protocols && b.protocols.length && (!a.protocols || !a.protocols.length)) {\n return 1\n } else if (b.id.pubKey && !a.id.pubKey) {\n return 1\n }\n return -1\n })\n\n for (let i = 0; i < peers.length && this.size < minConnections; i++) {\n if (!this.get(peers[i].id)) {\n log('connecting to a peerStore stored peer %s', peers[i].id.toB58String())\n try {\n await this._libp2p.dialer.connectToPeer(peers[i].id)\n\n // Connection Manager was stopped\n if (!this._started) {\n return\n }\n } catch (err) {\n log.error('could not connect to peerStore stored peer', err)\n }\n }\n }\n\n this._autoDialTimeout = retimer(this._autoDial, this._options.autoDialInterval)\n }\n\n /**\n * If we have more connections than our maximum, close a connection\n * to the lowest valued peer.\n *\n * @private\n */\n _maybeDisconnectOne () {\n if (this._options.minConnections < this.connections.size) {\n const peerValues = Array.from(new Map([...this._peerValues.entries()].sort((a, b) => a[1] - b[1])))\n log('%s: sorted peer values: %j', this._peerId, peerValues)\n const disconnectPeer = peerValues[0]\n if (disconnectPeer) {\n const peerId = disconnectPeer[0]\n log('%s: lowest value peer is %s', this._peerId, peerId)\n log('%s: closing a connection to %j', this._peerId, peerId)\n for (const connections of this.connections.values()) {\n if (connections[0].remotePeer.toB58String() === peerId) {\n connections[0].close()\n break\n }\n }\n }\n }\n }\n}\n\nmodule.exports = ConnectionManager\n","// @ts-nocheck\n'use strict'\n\n/**\n * This code is based on `latency-monitor` (https://github.com/mlucool/latency-monitor) by `mlucool` (https://github.com/mlucool), available under Apache License 2.0 (https://github.com/mlucool/latency-monitor/blob/master/LICENSE)\n */\n\nconst { EventEmitter } = require('events')\nconst VisibilityChangeEmitter = require('./visibility-change-emitter')\nconst debug = require('debug')('latency-monitor:LatencyMonitor')\n\n/**\n * @typedef {Object} SummaryObject\n * @property {number} events How many events were called\n * @property {number} minMS What was the min time for a cb to be called\n * @property {number} maxMS What was the max time for a cb to be called\n * @property {number} avgMs What was the average time for a cb to be called\n * @property {number} lengthMs How long this interval was in ms\n *\n * @typedef {Object} LatencyMonitorOptions\n * @property {number} [latencyCheckIntervalMs=500] - How often to add a latency check event (ms)\n * @property {number} [dataEmitIntervalMs=5000] - How often to summarize latency check events. null or 0 disables event firing\n * @property {Function} [asyncTestFn] - What cb-style async function to use\n * @property {number} [latencyRandomPercentage=5] - What percent (+/-) of latencyCheckIntervalMs should we randomly use? This helps avoid alignment to other events.\n */\n\n/**\n * A class to monitor latency of any async function which works in a browser or node. This works by periodically calling\n * the asyncTestFn and timing how long it takes the callback to be called. It can also periodically emit stats about this.\n * This can be disabled and stats can be pulled via setting dataEmitIntervalMs = 0.\n *\n * @extends {EventEmitter}\n *\n * The default implementation is an event loop latency monitor. This works by firing periodic events into the event loop\n * and timing how long it takes to get back.\n *\n * @example\n * const monitor = new LatencyMonitor();\n * monitor.on('data', (summary) => console.log('Event Loop Latency: %O', summary));\n *\n * @example\n * const monitor = new LatencyMonitor({latencyCheckIntervalMs: 1000, dataEmitIntervalMs: 60000, asyncTestFn:ping});\n * monitor.on('data', (summary) => console.log('Ping Pong Latency: %O', summary));\n */\nclass LatencyMonitor extends EventEmitter {\n /**\n * @class\n * @param {LatencyMonitorOptions} [options]\n */\n constructor ({ latencyCheckIntervalMs, dataEmitIntervalMs, asyncTestFn, latencyRandomPercentage } = {}) {\n super()\n const that = this\n\n // 0 isn't valid here, so its ok to use ||\n that.latencyCheckIntervalMs = latencyCheckIntervalMs || 500 // 0.5s\n that.latencyRandomPercentage = latencyRandomPercentage || 10\n that._latecyCheckMultiply = 2 * (that.latencyRandomPercentage / 100.0) * that.latencyCheckIntervalMs\n that._latecyCheckSubtract = that._latecyCheckMultiply / 2\n\n that.dataEmitIntervalMs = (dataEmitIntervalMs === null || dataEmitIntervalMs === 0)\n ? undefined\n : dataEmitIntervalMs || 5 * 1000 // 5s\n debug('latencyCheckIntervalMs: %s dataEmitIntervalMs: %s',\n that.latencyCheckIntervalMs, that.dataEmitIntervalMs)\n if (that.dataEmitIntervalMs) {\n debug('Expecting ~%s events per summary', that.latencyCheckIntervalMs / that.dataEmitIntervalMs)\n } else {\n debug('Not emitting summaries')\n }\n\n that.asyncTestFn = asyncTestFn // If there is no asyncFn, we measure latency\n }\n\n start () {\n // If process: use high resolution timer\n if (globalThis.process && globalThis.process.hrtime) { // eslint-disable-line no-undef\n debug('Using process.hrtime for timing')\n this.now = globalThis.process.hrtime // eslint-disable-line no-undef\n this.getDeltaMS = (startTime) => {\n const hrtime = this.now(startTime)\n return (hrtime[0] * 1000) + (hrtime[1] / 1000000)\n }\n // Let's try for a timer that only monotonically increases\n } else if (typeof window !== 'undefined' && window.performance && window.performance.now) {\n debug('Using performance.now for timing')\n this.now = window.performance.now.bind(window.performance)\n this.getDeltaMS = (startTime) => Math.round(this.now() - startTime)\n } else {\n debug('Using Date.now for timing')\n this.now = Date.now\n this.getDeltaMS = (startTime) => this.now() - startTime\n }\n\n this._latencyData = this._initLatencyData()\n\n // We check for isBrowser because of browsers set max rates of timeouts when a page is hidden,\n // so we fall back to another library\n // See: http://stackoverflow.com/questions/6032429/chrome-timeouts-interval-suspended-in-background-tabs\n if (isBrowser()) {\n this._visibilityChangeEmitter = new VisibilityChangeEmitter()\n\n this._visibilityChangeEmitter.on('visibilityChange', (pageInFocus) => {\n if (pageInFocus) {\n this._startTimers()\n } else {\n this._emitSummary()\n this._stopTimers()\n }\n })\n }\n\n if (!this._visibilityChangeEmitter || this._visibilityChangeEmitter.isVisible()) {\n this._startTimers()\n }\n }\n\n stop () {\n this._stopTimers()\n }\n\n /**\n * Start internal timers\n *\n * @private\n */\n _startTimers () {\n // Timer already started, ignore this\n if (this._checkLatencyID) {\n return\n }\n this._checkLatency()\n if (this.dataEmitIntervalMs) {\n this._emitIntervalID = setInterval(() => this._emitSummary(), this.dataEmitIntervalMs)\n if (typeof this._emitIntervalID.unref === 'function') {\n this._emitIntervalID.unref() // Doesn't block exit\n }\n }\n }\n\n /**\n * Stop internal timers\n *\n * @private\n */\n _stopTimers () {\n if (this._checkLatencyID) {\n clearTimeout(this._checkLatencyID)\n this._checkLatencyID = undefined\n }\n if (this._emitIntervalID) {\n clearInterval(this._emitIntervalID)\n this._emitIntervalID = undefined\n }\n }\n\n /**\n * Emit summary only if there were events. It might not have any events if it was forced via a page hidden/show\n *\n * @private\n */\n _emitSummary () {\n const summary = this.getSummary()\n if (summary.events > 0) {\n this.emit('data', summary)\n }\n }\n\n /**\n * Calling this function will end the collection period. If a timing event was already fired and somewhere in the queue,\n * it will not count for this time period\n *\n * @returns {SummaryObject}\n */\n getSummary () {\n // We might want to adjust for the number of expected events\n // Example: first 1 event it comes back, then such a long blocker that the next emit check comes\n // Then this fires - looks like no latency!!\n const latency = {\n events: this._latencyData.events,\n minMs: this._latencyData.minMs,\n maxMs: this._latencyData.maxMs,\n avgMs: this._latencyData.events\n ? this._latencyData.totalMs / this._latencyData.events\n : Number.POSITIVE_INFINITY,\n lengthMs: this.getDeltaMS(this._latencyData.startTime)\n }\n this._latencyData = this._initLatencyData() // Clear\n\n debug('Summary: %O', latency)\n return latency\n }\n\n /**\n * Randomly calls an async fn every roughly latencyCheckIntervalMs (plus some randomness). If no async fn is found,\n * it will simply report on event loop latency.\n *\n * @private\n */\n _checkLatency () {\n const that = this\n // Randomness is needed to avoid alignment by accident to regular things in the event loop\n const randomness = (Math.random() * that._latecyCheckMultiply) - that._latecyCheckSubtract\n\n // We use this to ensure that in case some overlap somehow, we don't take the wrong startTime/offset\n const localData = {\n deltaOffset: Math.ceil(that.latencyCheckIntervalMs + randomness),\n startTime: that.now()\n }\n\n const cb = () => {\n // We are already stopped, ignore this datapoint\n if (!this._checkLatencyID) {\n return\n }\n const deltaMS = that.getDeltaMS(localData.startTime) - localData.deltaOffset\n that._checkLatency() // Start again ASAP\n\n // Add the data point. If this gets complex, refactor it\n that._latencyData.events++\n that._latencyData.minMs = Math.min(that._latencyData.minMs, deltaMS)\n that._latencyData.maxMs = Math.max(that._latencyData.maxMs, deltaMS)\n that._latencyData.totalMs += deltaMS\n debug('MS: %s Data: %O', deltaMS, that._latencyData)\n }\n debug('localData: %O', localData)\n\n this._checkLatencyID = setTimeout(() => {\n // This gets rid of including event loop\n if (that.asyncTestFn) {\n // Clear timing related things\n localData.deltaOffset = 0\n localData.startTime = that.now()\n that.asyncTestFn(cb)\n } else {\n // setTimeout is not more accurate than 1ms, so this will ensure positive numbers. Add 1 to emitted data to remove.\n // This is not the best, but for now it'll be just fine. This isn't meant to be sub ms accurate.\n localData.deltaOffset -= 1\n // If there is no function to test, we mean check latency which is a special case that is really cb => cb()\n // We avoid that for the few extra function all overheads. Also, we want to keep the timers different\n cb()\n }\n }, localData.deltaOffset)\n\n if (typeof this._checkLatencyID.unref === 'function') {\n this._checkLatencyID.unref() // Doesn't block exit\n }\n }\n\n _initLatencyData () {\n return {\n startTime: this.now(),\n minMs: Number.POSITIVE_INFINITY,\n maxMs: Number.NEGATIVE_INFINITY,\n events: 0,\n totalMs: 0\n }\n }\n}\n\nfunction isBrowser () {\n return typeof window !== 'undefined'\n}\n\nmodule.exports = LatencyMonitor\n","// @ts-nocheck\n/* global document */\n\n/**\n * This code is based on `latency-monitor` (https://github.com/mlucool/latency-monitor) by `mlucool` (https://github.com/mlucool), available under Apache License 2.0 (https://github.com/mlucool/latency-monitor/blob/master/LICENSE)\n */\n'use strict'\n\nconst { EventEmitter } = require('events')\n\nconst debug = require('debug')('latency-monitor:VisibilityChangeEmitter')\n\n/**\n * Listen to page visibility change events (i.e. when the page is focused / blurred) by an event emitter.\n *\n * Warning: This does not work on all browsers, but should work on all modern browsers\n *\n * @example\n *\n * const myVisibilityEmitter = new VisibilityChangeEmitter();\n *\n * myVisibilityEmitter.on('visibilityChange', (pageInFocus) => {\n * if ( pageInFocus ){\n * // Page is in focus\n * console.log('In focus');\n * }\n * else {\n * // Page is blurred\n * console.log('Out of focus');\n * }\n * });\n * // To access the visibility state directly, call:\n * console.log('Am I focused now? ' + myVisibilityEmitter.isVisible());\n */\nclass VisibilityChangeEmitter extends EventEmitter {\n /**\n * Creates a VisibilityChangeEmitter\n *\n * @class\n */\n constructor () {\n super()\n if (typeof document === 'undefined') {\n debug('This is not a browser, no \"document\" found. Stopping.')\n return\n }\n this._initializeVisibilityVarNames()\n this._addVisibilityChangeListener()\n }\n\n /**\n * document.hidden and document.visibilityChange are the two variables we need to check for;\n * Since these variables are named differently in different browsers, this function sets\n * the appropriate name based on the browser being used. Once executed, tha actual names of\n * document.hidden and document.visibilityChange are found in this._hidden and this._visibilityChange\n * respectively\n *\n * @private\n */\n _initializeVisibilityVarNames () {\n let hidden\n let visibilityChange\n if (typeof document.hidden !== 'undefined') { // Opera 12.10 and Firefox 18 and later support\n hidden = 'hidden'\n visibilityChange = 'visibilitychange'\n } else if (typeof document.mozHidden !== 'undefined') {\n hidden = 'mozHidden'\n visibilityChange = 'mozvisibilitychange'\n } else if (typeof document.msHidden !== 'undefined') {\n hidden = 'msHidden'\n visibilityChange = 'msvisibilitychange'\n } else if (typeof document.webkitHidden !== 'undefined') {\n hidden = 'webkitHidden'\n visibilityChange = 'webkitvisibilitychange'\n }\n this._hidden = hidden\n this._visibilityChange = visibilityChange\n }\n\n /**\n * Adds an event listener on the document that listens to changes in document.visibilityChange\n * (or whatever name by which the visibilityChange variable is known in the browser)\n *\n * @private\n */\n _addVisibilityChangeListener () {\n if (typeof document.addEventListener === 'undefined' ||\n typeof document[this._hidden] === 'undefined') {\n debug('Checking page visibility requires a browser that supports the Page Visibility API.')\n } else {\n // Handle page visibility change\n document.addEventListener(this._visibilityChange, this._handleVisibilityChange.bind(this), false)\n }\n }\n\n /**\n * The function returns ```true``` if the page is visible or ```false``` if the page is not visible and\n * ```undefined``` if the page visibility API is not supported by the browser.\n *\n * @returns {boolean | void} whether the page is now visible or not (undefined is unknown)\n */\n isVisible () {\n if (this._hidden === undefined || document[this._hidden] === undefined) {\n return undefined\n }\n\n return !document[this._hidden]\n }\n\n /**\n * The function that is called when document.visibilityChange has changed\n * It emits an event called visibilityChange and sends the value of document.hidden as a\n * parameter\n *\n * @private\n */\n _handleVisibilityChange () {\n const visible = !document[this._hidden]\n debug(visible ? 'Page Visible' : 'Page Hidden')\n // Emit the event\n this.emit('visibilityChange', visible)\n }\n}\n\nmodule.exports = VisibilityChangeEmitter\n","'use strict'\n\nconst getTime = require('./time')\n\nclass Retimer {\n constructor (callback, timeout, args) {\n const that = this\n\n this._started = getTime()\n this._rescheduled = 0\n this._scheduled = timeout\n this._args = args\n this._triggered = false\n\n this._timerWrapper = () => {\n if (that._rescheduled > 0) {\n that._scheduled = that._rescheduled - (getTime() - that._started)\n that._schedule(that._scheduled)\n } else {\n that._triggered = true\n callback.apply(null, that._args)\n }\n }\n\n this._timer = setTimeout(this._timerWrapper, timeout)\n }\n\n reschedule (timeout) {\n if (!timeout) {\n timeout = this._scheduled\n }\n const now = getTime()\n if ((now + timeout) - (this._started + this._scheduled) < 0) {\n clearTimeout(this._timer)\n this._schedule(timeout)\n } else if (!this._triggered) {\n this._started = now\n this._rescheduled = timeout\n } else {\n this._schedule(timeout)\n }\n }\n\n _schedule (timeout) {\n this._triggered = false\n this._started = getTime()\n this._rescheduled = 0\n this._scheduled = timeout\n this._timer = setTimeout(this._timerWrapper, timeout)\n }\n\n clear () {\n clearTimeout(this._timer)\n }\n}\n\nfunction retimer () {\n if (typeof arguments[0] !== 'function') {\n throw new Error('callback needed')\n }\n\n if (typeof arguments[1] !== 'number') {\n throw new Error('timeout needed')\n }\n\n let args\n\n if (arguments.length > 0) {\n args = new Array(arguments.length - 2)\n\n /* eslint-disable no-var */\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 2]\n }\n }\n\n return new Retimer(arguments[0], arguments[1], args)\n}\n\nmodule.exports = retimer\n","'use strict'\n\nmodule.exports = function getTime () {\n return Date.now()\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:circuit'), {\n error: debug('libp2p:circuit:err')\n})\n\nconst errCode = require('err-code')\nconst mafmt = require('mafmt')\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\nconst { CircuitRelay: CircuitPB } = require('./protocol')\nconst { codes } = require('../errors')\n\nconst toConnection = require('libp2p-utils/src/stream-to-ma-conn')\n\nconst { relay: multicodec } = require('./multicodec')\nconst createListener = require('./listener')\nconst { handleCanHop, handleHop, hop } = require('./circuit/hop')\nconst { handleStop } = require('./circuit/stop')\nconst StreamHandler = require('./circuit/stream-handler')\n\nconst transportSymbol = Symbol.for('@libp2p/js-libp2p-circuit/circuit')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\nclass Circuit {\n /**\n * Creates an instance of the Circuit Transport.\n *\n * @class\n * @param {object} options\n * @param {import('../')} options.libp2p\n * @param {import('../upgrader')} options.upgrader\n */\n constructor ({ libp2p, upgrader }) {\n this._dialer = libp2p.dialer\n this._registrar = libp2p.registrar\n this._connectionManager = libp2p.connectionManager\n this._upgrader = upgrader\n this._options = libp2p._config.relay\n this._libp2p = libp2p\n this.peerId = libp2p.peerId\n\n this._registrar.handle(multicodec, this._onProtocol.bind(this))\n }\n\n /**\n * @param {Object} props\n * @param {Connection} props.connection\n * @param {MuxedStream} props.stream\n */\n async _onProtocol ({ connection, stream }) {\n /** @type {import('./circuit/stream-handler')} */\n const streamHandler = new StreamHandler({ stream })\n const request = await streamHandler.read()\n\n if (!request) {\n return\n }\n\n const circuit = this\n let virtualConnection\n\n switch (request.type) {\n case CircuitPB.Type.CAN_HOP: {\n log('received CAN_HOP request from %s', connection.remotePeer.toB58String())\n await handleCanHop({ circuit, connection, streamHandler })\n break\n }\n case CircuitPB.Type.HOP: {\n log('received HOP request from %s', connection.remotePeer.toB58String())\n virtualConnection = await handleHop({\n connection,\n request,\n streamHandler,\n circuit\n })\n break\n }\n case CircuitPB.Type.STOP: {\n log('received STOP request from %s', connection.remotePeer.toB58String())\n virtualConnection = await handleStop({\n connection,\n request,\n streamHandler\n })\n break\n }\n default: {\n log('Request of type %s not supported', request.type)\n }\n }\n\n if (virtualConnection) {\n // @ts-ignore dst peer will not be undefined\n const remoteAddr = new Multiaddr(request.dstPeer.addrs[0])\n // @ts-ignore src peer will not be undefined\n const localAddr = new Multiaddr(request.srcPeer.addrs[0])\n const maConn = toConnection({\n stream: virtualConnection,\n remoteAddr,\n localAddr\n })\n const type = request.type === CircuitPB.Type.HOP ? 'relay' : 'inbound'\n log('new %s connection %s', type, maConn.remoteAddr)\n\n const conn = await this._upgrader.upgradeInbound(maConn)\n log('%s connection %s upgraded', type, maConn.remoteAddr)\n this.handler && this.handler(conn)\n }\n }\n\n /**\n * Dial a peer over a relay\n *\n * @param {Multiaddr} ma - the multiaddr of the peer to dial\n * @param {Object} options - dial options\n * @param {AbortSignal} [options.signal] - An optional abort signal\n * @returns {Promise<Connection>} - the connection\n */\n async dial (ma, options) {\n // Check the multiaddr to see if it contains a relay and a destination peer\n const addrs = ma.toString().split('/p2p-circuit')\n const relayAddr = new Multiaddr(addrs[0])\n const destinationAddr = new Multiaddr(addrs[addrs.length - 1])\n const relayId = relayAddr.getPeerId()\n const destinationId = destinationAddr.getPeerId()\n\n if (!relayId || !destinationId) {\n const errMsg = 'Circuit relay dial failed as addresses did not have peer id'\n log.error(errMsg)\n throw errCode(new Error(errMsg), codes.ERR_RELAYED_DIAL)\n }\n\n const relayPeer = PeerId.createFromB58String(relayId)\n const destinationPeer = PeerId.createFromB58String(destinationId)\n\n let disconnectOnFailure = false\n let relayConnection = this._connectionManager.get(relayPeer)\n if (!relayConnection) {\n relayConnection = await this._dialer.connectToPeer(relayAddr, options)\n disconnectOnFailure = true\n }\n\n try {\n const virtualConnection = await hop({\n connection: relayConnection,\n request: {\n type: CircuitPB.Type.HOP,\n srcPeer: {\n id: this.peerId.toBytes(),\n addrs: this._libp2p.multiaddrs.map(addr => addr.bytes)\n },\n dstPeer: {\n id: destinationPeer.toBytes(),\n addrs: [new Multiaddr(destinationAddr).bytes]\n }\n }\n })\n\n const localAddr = relayAddr.encapsulate(`/p2p-circuit/p2p/${this.peerId.toB58String()}`)\n const maConn = toConnection({\n stream: virtualConnection,\n remoteAddr: ma,\n localAddr\n })\n log('new outbound connection %s', maConn.remoteAddr)\n\n return this._upgrader.upgradeOutbound(maConn)\n } catch (err) {\n log.error('Circuit relay dial failed', err)\n disconnectOnFailure && await relayConnection.close()\n throw err\n }\n }\n\n /**\n * Create a listener\n *\n * @param {any} options\n * @param {Function} handler\n * @returns {import('libp2p-interfaces/src/transport/types').Listener}\n */\n createListener (options, handler) {\n if (typeof options === 'function') {\n handler = options\n options = {}\n }\n\n // Called on successful HOP and STOP requests\n this.handler = handler\n\n return createListener(this._libp2p)\n }\n\n /**\n * Filter check for all Multiaddrs that this transport can dial on\n *\n * @param {Multiaddr[]} multiaddrs\n * @returns {Multiaddr[]}\n */\n filter (multiaddrs) {\n multiaddrs = Array.isArray(multiaddrs) ? multiaddrs : [multiaddrs]\n\n return multiaddrs.filter((ma) => {\n return mafmt.Circuit.matches(ma)\n })\n }\n\n get [Symbol.toStringTag] () {\n return 'Circuit'\n }\n\n /**\n * Checks if the given value is a Transport instance.\n *\n * @param {any} other\n * @returns {other is Transport}\n */\n static isTransport (other) {\n return Boolean(other && other[transportSymbol])\n }\n}\n\nmodule.exports = Circuit\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-circuit\"] || ($protobuf.roots[\"libp2p-circuit\"] = {});\n\n$root.CircuitRelay = (function() {\n\n /**\n * Properties of a CircuitRelay.\n * @exports ICircuitRelay\n * @interface ICircuitRelay\n * @property {CircuitRelay.Type|null} [type] CircuitRelay type\n * @property {CircuitRelay.IPeer|null} [srcPeer] CircuitRelay srcPeer\n * @property {CircuitRelay.IPeer|null} [dstPeer] CircuitRelay dstPeer\n * @property {CircuitRelay.Status|null} [code] CircuitRelay code\n */\n\n /**\n * Constructs a new CircuitRelay.\n * @exports CircuitRelay\n * @classdesc Represents a CircuitRelay.\n * @implements ICircuitRelay\n * @constructor\n * @param {ICircuitRelay=} [p] Properties to set\n */\n function CircuitRelay(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * CircuitRelay type.\n * @member {CircuitRelay.Type} type\n * @memberof CircuitRelay\n * @instance\n */\n CircuitRelay.prototype.type = 1;\n\n /**\n * CircuitRelay srcPeer.\n * @member {CircuitRelay.IPeer|null|undefined} srcPeer\n * @memberof CircuitRelay\n * @instance\n */\n CircuitRelay.prototype.srcPeer = null;\n\n /**\n * CircuitRelay dstPeer.\n * @member {CircuitRelay.IPeer|null|undefined} dstPeer\n * @memberof CircuitRelay\n * @instance\n */\n CircuitRelay.prototype.dstPeer = null;\n\n /**\n * CircuitRelay code.\n * @member {CircuitRelay.Status} code\n * @memberof CircuitRelay\n * @instance\n */\n CircuitRelay.prototype.code = 100;\n\n /**\n * Encodes the specified CircuitRelay message. Does not implicitly {@link CircuitRelay.verify|verify} messages.\n * @function encode\n * @memberof CircuitRelay\n * @static\n * @param {ICircuitRelay} m CircuitRelay message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n CircuitRelay.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.type != null && Object.hasOwnProperty.call(m, \"type\"))\n w.uint32(8).int32(m.type);\n if (m.srcPeer != null && Object.hasOwnProperty.call(m, \"srcPeer\"))\n $root.CircuitRelay.Peer.encode(m.srcPeer, w.uint32(18).fork()).ldelim();\n if (m.dstPeer != null && Object.hasOwnProperty.call(m, \"dstPeer\"))\n $root.CircuitRelay.Peer.encode(m.dstPeer, w.uint32(26).fork()).ldelim();\n if (m.code != null && Object.hasOwnProperty.call(m, \"code\"))\n w.uint32(32).int32(m.code);\n return w;\n };\n\n /**\n * Decodes a CircuitRelay message from the specified reader or buffer.\n * @function decode\n * @memberof CircuitRelay\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {CircuitRelay} CircuitRelay\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n CircuitRelay.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.CircuitRelay();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.type = r.int32();\n break;\n case 2:\n m.srcPeer = $root.CircuitRelay.Peer.decode(r, r.uint32());\n break;\n case 3:\n m.dstPeer = $root.CircuitRelay.Peer.decode(r, r.uint32());\n break;\n case 4:\n m.code = r.int32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a CircuitRelay message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof CircuitRelay\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {CircuitRelay} CircuitRelay\n */\n CircuitRelay.fromObject = function fromObject(d) {\n if (d instanceof $root.CircuitRelay)\n return d;\n var m = new $root.CircuitRelay();\n switch (d.type) {\n case \"HOP\":\n case 1:\n m.type = 1;\n break;\n case \"STOP\":\n case 2:\n m.type = 2;\n break;\n case \"STATUS\":\n case 3:\n m.type = 3;\n break;\n case \"CAN_HOP\":\n case 4:\n m.type = 4;\n break;\n }\n if (d.srcPeer != null) {\n if (typeof d.srcPeer !== \"object\")\n throw TypeError(\".CircuitRelay.srcPeer: object expected\");\n m.srcPeer = $root.CircuitRelay.Peer.fromObject(d.srcPeer);\n }\n if (d.dstPeer != null) {\n if (typeof d.dstPeer !== \"object\")\n throw TypeError(\".CircuitRelay.dstPeer: object expected\");\n m.dstPeer = $root.CircuitRelay.Peer.fromObject(d.dstPeer);\n }\n switch (d.code) {\n case \"SUCCESS\":\n case 100:\n m.code = 100;\n break;\n case \"HOP_SRC_ADDR_TOO_LONG\":\n case 220:\n m.code = 220;\n break;\n case \"HOP_DST_ADDR_TOO_LONG\":\n case 221:\n m.code = 221;\n break;\n case \"HOP_SRC_MULTIADDR_INVALID\":\n case 250:\n m.code = 250;\n break;\n case \"HOP_DST_MULTIADDR_INVALID\":\n case 251:\n m.code = 251;\n break;\n case \"HOP_NO_CONN_TO_DST\":\n case 260:\n m.code = 260;\n break;\n case \"HOP_CANT_DIAL_DST\":\n case 261:\n m.code = 261;\n break;\n case \"HOP_CANT_OPEN_DST_STREAM\":\n case 262:\n m.code = 262;\n break;\n case \"HOP_CANT_SPEAK_RELAY\":\n case 270:\n m.code = 270;\n break;\n case \"HOP_CANT_RELAY_TO_SELF\":\n case 280:\n m.code = 280;\n break;\n case \"STOP_SRC_ADDR_TOO_LONG\":\n case 320:\n m.code = 320;\n break;\n case \"STOP_DST_ADDR_TOO_LONG\":\n case 321:\n m.code = 321;\n break;\n case \"STOP_SRC_MULTIADDR_INVALID\":\n case 350:\n m.code = 350;\n break;\n case \"STOP_DST_MULTIADDR_INVALID\":\n case 351:\n m.code = 351;\n break;\n case \"STOP_RELAY_REFUSED\":\n case 390:\n m.code = 390;\n break;\n case \"MALFORMED_MESSAGE\":\n case 400:\n m.code = 400;\n break;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a CircuitRelay message. Also converts values to other types if specified.\n * @function toObject\n * @memberof CircuitRelay\n * @static\n * @param {CircuitRelay} m CircuitRelay\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n CircuitRelay.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n d.type = o.enums === String ? \"HOP\" : 1;\n d.srcPeer = null;\n d.dstPeer = null;\n d.code = o.enums === String ? \"SUCCESS\" : 100;\n }\n if (m.type != null && m.hasOwnProperty(\"type\")) {\n d.type = o.enums === String ? $root.CircuitRelay.Type[m.type] : m.type;\n }\n if (m.srcPeer != null && m.hasOwnProperty(\"srcPeer\")) {\n d.srcPeer = $root.CircuitRelay.Peer.toObject(m.srcPeer, o);\n }\n if (m.dstPeer != null && m.hasOwnProperty(\"dstPeer\")) {\n d.dstPeer = $root.CircuitRelay.Peer.toObject(m.dstPeer, o);\n }\n if (m.code != null && m.hasOwnProperty(\"code\")) {\n d.code = o.enums === String ? $root.CircuitRelay.Status[m.code] : m.code;\n }\n return d;\n };\n\n /**\n * Converts this CircuitRelay to JSON.\n * @function toJSON\n * @memberof CircuitRelay\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n CircuitRelay.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n /**\n * Status enum.\n * @name CircuitRelay.Status\n * @enum {number}\n * @property {number} SUCCESS=100 SUCCESS value\n * @property {number} HOP_SRC_ADDR_TOO_LONG=220 HOP_SRC_ADDR_TOO_LONG value\n * @property {number} HOP_DST_ADDR_TOO_LONG=221 HOP_DST_ADDR_TOO_LONG value\n * @property {number} HOP_SRC_MULTIADDR_INVALID=250 HOP_SRC_MULTIADDR_INVALID value\n * @property {number} HOP_DST_MULTIADDR_INVALID=251 HOP_DST_MULTIADDR_INVALID value\n * @property {number} HOP_NO_CONN_TO_DST=260 HOP_NO_CONN_TO_DST value\n * @property {number} HOP_CANT_DIAL_DST=261 HOP_CANT_DIAL_DST value\n * @property {number} HOP_CANT_OPEN_DST_STREAM=262 HOP_CANT_OPEN_DST_STREAM value\n * @property {number} HOP_CANT_SPEAK_RELAY=270 HOP_CANT_SPEAK_RELAY value\n * @property {number} HOP_CANT_RELAY_TO_SELF=280 HOP_CANT_RELAY_TO_SELF value\n * @property {number} STOP_SRC_ADDR_TOO_LONG=320 STOP_SRC_ADDR_TOO_LONG value\n * @property {number} STOP_DST_ADDR_TOO_LONG=321 STOP_DST_ADDR_TOO_LONG value\n * @property {number} STOP_SRC_MULTIADDR_INVALID=350 STOP_SRC_MULTIADDR_INVALID value\n * @property {number} STOP_DST_MULTIADDR_INVALID=351 STOP_DST_MULTIADDR_INVALID value\n * @property {number} STOP_RELAY_REFUSED=390 STOP_RELAY_REFUSED value\n * @property {number} MALFORMED_MESSAGE=400 MALFORMED_MESSAGE value\n */\n CircuitRelay.Status = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[100] = \"SUCCESS\"] = 100;\n values[valuesById[220] = \"HOP_SRC_ADDR_TOO_LONG\"] = 220;\n values[valuesById[221] = \"HOP_DST_ADDR_TOO_LONG\"] = 221;\n values[valuesById[250] = \"HOP_SRC_MULTIADDR_INVALID\"] = 250;\n values[valuesById[251] = \"HOP_DST_MULTIADDR_INVALID\"] = 251;\n values[valuesById[260] = \"HOP_NO_CONN_TO_DST\"] = 260;\n values[valuesById[261] = \"HOP_CANT_DIAL_DST\"] = 261;\n values[valuesById[262] = \"HOP_CANT_OPEN_DST_STREAM\"] = 262;\n values[valuesById[270] = \"HOP_CANT_SPEAK_RELAY\"] = 270;\n values[valuesById[280] = \"HOP_CANT_RELAY_TO_SELF\"] = 280;\n values[valuesById[320] = \"STOP_SRC_ADDR_TOO_LONG\"] = 320;\n values[valuesById[321] = \"STOP_DST_ADDR_TOO_LONG\"] = 321;\n values[valuesById[350] = \"STOP_SRC_MULTIADDR_INVALID\"] = 350;\n values[valuesById[351] = \"STOP_DST_MULTIADDR_INVALID\"] = 351;\n values[valuesById[390] = \"STOP_RELAY_REFUSED\"] = 390;\n values[valuesById[400] = \"MALFORMED_MESSAGE\"] = 400;\n return values;\n })();\n\n /**\n * Type enum.\n * @name CircuitRelay.Type\n * @enum {number}\n * @property {number} HOP=1 HOP value\n * @property {number} STOP=2 STOP value\n * @property {number} STATUS=3 STATUS value\n * @property {number} CAN_HOP=4 CAN_HOP value\n */\n CircuitRelay.Type = (function() {\n var valuesById = {}, values = Object.create(valuesById);\n values[valuesById[1] = \"HOP\"] = 1;\n values[valuesById[2] = \"STOP\"] = 2;\n values[valuesById[3] = \"STATUS\"] = 3;\n values[valuesById[4] = \"CAN_HOP\"] = 4;\n return values;\n })();\n\n CircuitRelay.Peer = (function() {\n\n /**\n * Properties of a Peer.\n * @memberof CircuitRelay\n * @interface IPeer\n * @property {Uint8Array} id Peer id\n * @property {Array.<Uint8Array>|null} [addrs] Peer addrs\n */\n\n /**\n * Constructs a new Peer.\n * @memberof CircuitRelay\n * @classdesc Represents a Peer.\n * @implements IPeer\n * @constructor\n * @param {CircuitRelay.IPeer=} [p] Properties to set\n */\n function Peer(p) {\n this.addrs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Peer id.\n * @member {Uint8Array} id\n * @memberof CircuitRelay.Peer\n * @instance\n */\n Peer.prototype.id = $util.newBuffer([]);\n\n /**\n * Peer addrs.\n * @member {Array.<Uint8Array>} addrs\n * @memberof CircuitRelay.Peer\n * @instance\n */\n Peer.prototype.addrs = $util.emptyArray;\n\n /**\n * Encodes the specified Peer message. Does not implicitly {@link CircuitRelay.Peer.verify|verify} messages.\n * @function encode\n * @memberof CircuitRelay.Peer\n * @static\n * @param {CircuitRelay.IPeer} m Peer message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Peer.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n w.uint32(10).bytes(m.id);\n if (m.addrs != null && m.addrs.length) {\n for (var i = 0; i < m.addrs.length; ++i)\n w.uint32(18).bytes(m.addrs[i]);\n }\n return w;\n };\n\n /**\n * Decodes a Peer message from the specified reader or buffer.\n * @function decode\n * @memberof CircuitRelay.Peer\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {CircuitRelay.Peer} Peer\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Peer.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.CircuitRelay.Peer();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.id = r.bytes();\n break;\n case 2:\n if (!(m.addrs && m.addrs.length))\n m.addrs = [];\n m.addrs.push(r.bytes());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n if (!m.hasOwnProperty(\"id\"))\n throw $util.ProtocolError(\"missing required 'id'\", { instance: m });\n return m;\n };\n\n /**\n * Creates a Peer message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof CircuitRelay.Peer\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {CircuitRelay.Peer} Peer\n */\n Peer.fromObject = function fromObject(d) {\n if (d instanceof $root.CircuitRelay.Peer)\n return d;\n var m = new $root.CircuitRelay.Peer();\n if (d.id != null) {\n if (typeof d.id === \"string\")\n $util.base64.decode(d.id, m.id = $util.newBuffer($util.base64.length(d.id)), 0);\n else if (d.id.length)\n m.id = d.id;\n }\n if (d.addrs) {\n if (!Array.isArray(d.addrs))\n throw TypeError(\".CircuitRelay.Peer.addrs: array expected\");\n m.addrs = [];\n for (var i = 0; i < d.addrs.length; ++i) {\n if (typeof d.addrs[i] === \"string\")\n $util.base64.decode(d.addrs[i], m.addrs[i] = $util.newBuffer($util.base64.length(d.addrs[i])), 0);\n else if (d.addrs[i].length)\n m.addrs[i] = d.addrs[i];\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Peer message. Also converts values to other types if specified.\n * @function toObject\n * @memberof CircuitRelay.Peer\n * @static\n * @param {CircuitRelay.Peer} m Peer\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Peer.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.addrs = [];\n }\n if (o.defaults) {\n if (o.bytes === String)\n d.id = \"\";\n else {\n d.id = [];\n if (o.bytes !== Array)\n d.id = $util.newBuffer(d.id);\n }\n }\n if (m.id != null && m.hasOwnProperty(\"id\")) {\n d.id = o.bytes === String ? $util.base64.encode(m.id, 0, m.id.length) : o.bytes === Array ? Array.prototype.slice.call(m.id) : m.id;\n }\n if (m.addrs && m.addrs.length) {\n d.addrs = [];\n for (var j = 0; j < m.addrs.length; ++j) {\n d.addrs[j] = o.bytes === String ? $util.base64.encode(m.addrs[j], 0, m.addrs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.addrs[j]) : m.addrs[j];\n }\n }\n return d;\n };\n\n /**\n * Converts this Peer to JSON.\n * @function toJSON\n * @memberof CircuitRelay.Peer\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Peer.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Peer;\n })();\n\n return CircuitRelay;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst { source: abortable } = require('abortable-iterator')\nconst debug = require('debug')\nconst log = debug('libp2p:stream:converter')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n *\n * @typedef {Object} Timeline\n * @property {number} open - connection opening timestamp.\n * @property {number} [upgraded] - connection upgraded timestamp.\n * @property {number} [close]\n */\n\n/**\n * Convert a duplex iterable into a MultiaddrConnection.\n * https://github.com/libp2p/interface-transport#multiaddrconnection\n *\n * @param {object} streamProperties\n * @param {MuxedStream} streamProperties.stream\n * @param {Multiaddr} streamProperties.remoteAddr\n * @param {Multiaddr} streamProperties.localAddr\n * @param {object} [options]\n * @param {AbortSignal} [options.signal]\n * @returns {import('libp2p-interfaces/src/transport/types').MultiaddrConnection}\n */\nfunction streamToMaConnection ({ stream, remoteAddr, localAddr }, options = {}) {\n const { sink, source } = stream\n const maConn = {\n /**\n * @param {Uint8Array} source\n */\n async sink (source) {\n if (options.signal) {\n // @ts-ignore ts infers source template will be a number\n source = abortable(source, options.signal)\n }\n\n try {\n await sink(source)\n } catch (err) {\n // If aborted we can safely ignore\n if (err.type !== 'aborted') {\n // If the source errored the socket will already have been destroyed by\n // toIterable.duplex(). If the socket errored it will already be\n // destroyed. There's nothing to do here except log the error & return.\n log(err)\n }\n }\n close()\n },\n source: options.signal ? abortable(source, options.signal) : source,\n conn: stream,\n localAddr,\n remoteAddr,\n /** @type {Timeline} */\n timeline: { open: Date.now(), close: undefined },\n close () {\n sink(new Uint8Array(0))\n return close()\n }\n }\n\n function close () {\n if (!maConn.timeline.close) {\n maConn.timeline.close = Date.now()\n }\n return Promise.resolve()\n }\n\n return maConn\n}\n\nmodule.exports = streamToMaConnection\n","'use strict'\n\nmodule.exports = {\n relay: '/libp2p/circuit/relay/0.1.0'\n}\n","'use strict'\n\nconst { EventEmitter } = require('events')\nconst { Multiaddr } = require('multiaddr')\n\n/**\n * @typedef {import('libp2p-interfaces/src/transport/types').Listener} Listener\n */\n\n/**\n * @param {import('../')} libp2p\n * @returns {Listener} a transport listener\n */\nmodule.exports = (libp2p) => {\n const listeningAddrs = new Map()\n\n /**\n * Add swarm handler and listen for incoming connections\n *\n * @param {Multiaddr} addr\n * @returns {Promise<void>}\n */\n async function listen (addr) {\n const addrString = String(addr).split('/p2p-circuit').find(a => a !== '')\n\n const relayConn = await libp2p.dial(new Multiaddr(addrString))\n const relayedAddr = relayConn.remoteAddr.encapsulate('/p2p-circuit')\n\n listeningAddrs.set(relayConn.remotePeer.toB58String(), relayedAddr)\n listener.emit('listening')\n }\n\n /**\n * Get fixed up multiaddrs\n *\n * NOTE: This method will grab the peers multiaddrs and expand them such that:\n *\n * a) If it's an existing /p2p-circuit address for a specific relay i.e.\n * `/ip4/0.0.0.0/tcp/0/ipfs/QmRelay/p2p-circuit` this method will expand the\n * address to `/ip4/0.0.0.0/tcp/0/ipfs/QmRelay/p2p-circuit/ipfs/QmPeer` where\n * `QmPeer` is this peers id\n * b) If it's not a /p2p-circuit address, it will encapsulate the address as a /p2p-circuit\n * addr, such when dialing over a relay with this address, it will create the circuit using\n * the encapsulated transport address. This is useful when for example, a peer should only\n * be dialed over TCP rather than any other transport\n *\n * @returns {Multiaddr[]}\n */\n function getAddrs () {\n const addrs = []\n for (const addr of listeningAddrs.values()) {\n addrs.push(addr)\n }\n return addrs\n }\n\n /** @type Listener */\n const listener = Object.assign(new EventEmitter(), {\n close: () => Promise.resolve(),\n listen,\n getAddrs\n })\n\n // Remove listeningAddrs when a peer disconnects\n libp2p.connectionManager.on('peer:disconnect', (connection) => {\n const deleted = listeningAddrs.delete(connection.remotePeer.toB58String())\n\n if (deleted) {\n // Announce listen addresses change\n listener.emit('close')\n }\n })\n\n return listener\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:circuit:hop'), {\n error: debug('libp2p:circuit:hop:err')\n})\nconst errCode = require('err-code')\n\nconst PeerId = require('peer-id')\nconst { validateAddrs } = require('./utils')\nconst StreamHandler = require('./stream-handler')\nconst { CircuitRelay: CircuitPB } = require('../protocol')\nconst { pipe } = require('it-pipe')\nconst { codes: Errors } = require('../../errors')\n\nconst { stop } = require('./stop')\n\nconst multicodec = require('./../multicodec')\n\n/**\n * @typedef {import('../protocol').ICircuitRelay} ICircuitRelay\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('../transport')} Transport\n */\n\n/**\n * @typedef {Object} HopRequest\n * @property {Connection} connection\n * @property {ICircuitRelay} request\n * @property {StreamHandler} streamHandler\n * @property {Transport} circuit\n */\n\n/**\n * @param {HopRequest} options\n * @returns {Promise<void>}\n */\nasync function handleHop ({\n connection,\n request,\n streamHandler,\n circuit\n}) {\n // Ensure hop is enabled\n if (!circuit._options.hop.enabled) {\n log('HOP request received but we are not acting as a relay')\n return streamHandler.end({\n type: CircuitPB.Type.STATUS,\n code: CircuitPB.Status.HOP_CANT_SPEAK_RELAY\n })\n }\n\n // Validate the HOP request has the required input\n try {\n validateAddrs(request, streamHandler)\n } catch (err) {\n return log.error('invalid hop request via peer %s', connection.remotePeer.toB58String(), err)\n }\n\n if (!request.dstPeer) {\n log('HOP request received but we do not receive a dstPeer')\n return\n }\n\n // Get the connection to the destination (stop) peer\n const destinationPeer = new PeerId(request.dstPeer.id)\n\n const destinationConnection = circuit._connectionManager.get(destinationPeer)\n if (!destinationConnection && !circuit._options.hop.active) {\n log('HOP request received but we are not connected to the destination peer')\n return streamHandler.end({\n type: CircuitPB.Type.STATUS,\n code: CircuitPB.Status.HOP_NO_CONN_TO_DST\n })\n }\n\n // TODO: Handle being an active relay\n if (!destinationConnection) {\n return\n }\n\n // Handle the incoming HOP request by performing a STOP request\n const stopRequest = {\n type: CircuitPB.Type.STOP,\n dstPeer: request.dstPeer,\n srcPeer: request.srcPeer\n }\n\n let destinationStream\n try {\n destinationStream = await stop({\n connection: destinationConnection,\n request: stopRequest\n })\n } catch (err) {\n return log.error(err)\n }\n\n log('hop request from %s is valid', connection.remotePeer.toB58String())\n streamHandler.write({\n type: CircuitPB.Type.STATUS,\n code: CircuitPB.Status.SUCCESS\n })\n const sourceStream = streamHandler.rest()\n\n // Short circuit the two streams to create the relayed connection\n return pipe(\n sourceStream,\n destinationStream,\n sourceStream\n )\n}\n\n/**\n * Performs a HOP request to a relay peer, to request a connection to another\n * peer. A new, virtual, connection will be created between the two via the relay.\n *\n * @param {object} options\n * @param {Connection} options.connection - Connection to the relay\n * @param {ICircuitRelay} options.request\n * @returns {Promise<MuxedStream>}\n */\nasync function hop ({\n connection,\n request\n}) {\n // Create a new stream to the relay\n const { stream } = await connection.newStream([multicodec.relay])\n // Send the HOP request\n const streamHandler = new StreamHandler({ stream })\n streamHandler.write(request)\n\n const response = await streamHandler.read()\n\n if (!response) {\n throw errCode(new Error('HOP request had no response'), Errors.ERR_HOP_REQUEST_FAILED)\n }\n\n if (response.code === CircuitPB.Status.SUCCESS) {\n log('hop request was successful')\n return streamHandler.rest()\n }\n\n log('hop request failed with code %d, closing stream', response.code)\n streamHandler.close()\n throw errCode(new Error(`HOP request failed with code ${response.code}`), Errors.ERR_HOP_REQUEST_FAILED)\n}\n\n/**\n * Performs a CAN_HOP request to a relay peer, in order to understand its capabilities.\n *\n * @param {object} options\n * @param {Connection} options.connection - Connection to the relay\n * @returns {Promise<boolean>}\n */\nasync function canHop ({\n connection\n}) {\n // Create a new stream to the relay\n const { stream } = await connection.newStream([multicodec.relay])\n // Send the HOP request\n const streamHandler = new StreamHandler({ stream })\n streamHandler.write({\n type: CircuitPB.Type.CAN_HOP\n })\n\n const response = await streamHandler.read()\n await streamHandler.close()\n\n if (!response || response.code !== CircuitPB.Status.SUCCESS) {\n return false\n }\n\n return true\n}\n\n/**\n * Creates an unencoded CAN_HOP response based on the Circuits configuration\n *\n * @param {Object} options\n * @param {Connection} options.connection\n * @param {StreamHandler} options.streamHandler\n * @param {Transport} options.circuit\n * @private\n */\nfunction handleCanHop ({\n connection,\n streamHandler,\n circuit\n}) {\n const canHop = circuit._options.hop.enabled\n log('can hop (%s) request from %s', canHop, connection.remotePeer.toB58String())\n streamHandler.end({\n type: CircuitPB.Type.STATUS,\n code: canHop ? CircuitPB.Status.SUCCESS : CircuitPB.Status.HOP_CANT_SPEAK_RELAY\n })\n}\n\nmodule.exports = {\n handleHop,\n hop,\n canHop,\n handleCanHop\n}\n","'use strict'\n\nconst { Multiaddr } = require('multiaddr')\nconst { CircuitRelay } = require('../protocol')\n\n/**\n * @typedef {import('./stream-handler')} StreamHandler\n * @typedef {import('../protocol').ICircuitRelay} ICircuitRelay\n */\n\n/**\n * Write a response\n *\n * @param {StreamHandler} streamHandler\n * @param {import('../protocol').CircuitRelay.Status} status\n */\nfunction writeResponse (streamHandler, status) {\n streamHandler.write({\n type: CircuitRelay.Type.STATUS,\n code: status\n })\n}\n\n/**\n * Validate incomming HOP/STOP message\n *\n * @param {ICircuitRelay} msg - A CircuitRelay unencoded protobuf message\n * @param {StreamHandler} streamHandler\n */\nfunction validateAddrs (msg, streamHandler) {\n try {\n if (msg.dstPeer && msg.dstPeer.addrs) {\n msg.dstPeer.addrs.forEach((addr) => {\n return new Multiaddr(addr)\n })\n }\n } catch (err) {\n writeResponse(streamHandler, msg.type === CircuitRelay.Type.HOP\n ? CircuitRelay.Status.HOP_DST_MULTIADDR_INVALID\n : CircuitRelay.Status.STOP_DST_MULTIADDR_INVALID)\n throw err\n }\n\n try {\n if (msg.srcPeer && msg.srcPeer.addrs) {\n msg.srcPeer.addrs.forEach((addr) => {\n return new Multiaddr(addr)\n })\n }\n } catch (err) {\n writeResponse(streamHandler, msg.type === CircuitRelay.Type.HOP\n ? CircuitRelay.Status.HOP_SRC_MULTIADDR_INVALID\n : CircuitRelay.Status.STOP_SRC_MULTIADDR_INVALID)\n throw err\n }\n}\n\nmodule.exports = {\n validateAddrs\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:circuit:stream-handler'), {\n error: debug('libp2p:circuit:stream-handler:err')\n})\n\nconst lp = require('it-length-prefixed')\n// @ts-ignore it-handshake does not export types\nconst handshake = require('it-handshake')\nconst { CircuitRelay } = require('../protocol')\n\n/**\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('../protocol').ICircuitRelay} ICircuitRelay\n */\n\nclass StreamHandler {\n /**\n * Create a stream handler for connection\n *\n * @class\n * @param {object} options\n * @param {MuxedStream} options.stream - A duplex iterable\n * @param {number} [options.maxLength = 4096] - max bytes length of message\n */\n constructor ({ stream, maxLength = 4096 }) {\n this.stream = stream\n\n this.shake = handshake(this.stream)\n // @ts-ignore options are not optional\n this.decoder = lp.decode.fromReader(this.shake.reader, { maxDataLength: maxLength })\n }\n\n /**\n * Read and decode message\n *\n * @async\n */\n async read () {\n const msg = await this.decoder.next()\n if (msg.value) {\n const value = CircuitRelay.decode(msg.value.slice())\n log('read message type', value.type)\n return value\n }\n\n log('read received no value, closing stream')\n // End the stream, we didn't get data\n this.close()\n }\n\n /**\n * Encode and write array of buffers\n *\n * @param {ICircuitRelay} msg - An unencoded CircuitRelay protobuf message\n * @returns {void}\n */\n write (msg) {\n log('write message type %s', msg.type)\n // @ts-ignore lp.encode expects type type 'Buffer | BufferList', not 'Uint8Array'\n this.shake.write(lp.encode.single(CircuitRelay.encode(msg).finish()))\n }\n\n /**\n * Return the handshake rest stream and invalidate handler\n *\n * @returns {*} A duplex iterable\n */\n rest () {\n this.shake.rest()\n return this.shake.stream\n }\n\n /**\n * @param {ICircuitRelay} msg - An unencoded CircuitRelay protobuf message\n */\n end (msg) {\n this.write(msg)\n this.close()\n }\n\n /**\n * Close the stream\n *\n * @returns {void}\n */\n close () {\n log('closing the stream')\n this.rest().sink([])\n }\n}\n\nmodule.exports = StreamHandler\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:circuit:stop'), {\n error: debug('libp2p:circuit:stop:err')\n})\n\nconst { CircuitRelay: CircuitPB } = require('../protocol')\nconst multicodec = require('../multicodec')\nconst StreamHandler = require('./stream-handler')\nconst { validateAddrs } = require('./utils')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('../protocol').ICircuitRelay} ICircuitRelay\n */\n\n/**\n * Handles incoming STOP requests\n *\n * @private\n * @param {Object} options\n * @param {Connection} options.connection\n * @param {ICircuitRelay} options.request - The CircuitRelay protobuf request (unencoded)\n * @param {StreamHandler} options.streamHandler\n * @returns {Promise<MuxedStream>|void} Resolves a duplex iterable\n */\nmodule.exports.handleStop = function handleStop ({\n connection,\n request,\n streamHandler\n}) {\n // Validate the STOP request has the required input\n try {\n validateAddrs(request, streamHandler)\n } catch (err) {\n return log.error('invalid stop request via peer %s', connection.remotePeer.toB58String(), err)\n }\n\n // The request is valid\n log('stop request is valid')\n streamHandler.write({\n type: CircuitPB.Type.STATUS,\n code: CircuitPB.Status.SUCCESS\n })\n return streamHandler.rest()\n}\n\n/**\n * Creates a STOP request\n *\n * @private\n * @param {Object} options\n * @param {Connection} options.connection\n * @param {ICircuitRelay} options.request - The CircuitRelay protobuf request (unencoded)\n * @returns {Promise<MuxedStream|void>} Resolves a duplex iterable\n */\nmodule.exports.stop = async function stop ({\n connection,\n request\n}) {\n const { stream } = await connection.newStream([multicodec.relay])\n log('starting stop request to %s', connection.remotePeer.toB58String())\n const streamHandler = new StreamHandler({ stream })\n\n streamHandler.write(request)\n const response = await streamHandler.read()\n\n if (!response) {\n return streamHandler.close()\n }\n\n if (response.code === CircuitPB.Status.SUCCESS) {\n log('stop request to %s was successful', connection.remotePeer.toB58String())\n return streamHandler.rest()\n }\n\n log('stop request failed with code %d', response.code)\n streamHandler.close()\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:relay'), {\n error: debug('libp2p:relay:err')\n})\n\nconst {\n setDelayedInterval,\n clearDelayedInterval\n// @ts-ignore set-delayed-interval does not export types\n} = require('set-delayed-interval')\n\nconst AutoRelay = require('./auto-relay')\nconst { namespaceToCid } = require('./utils')\nconst {\n RELAY_RENDEZVOUS_NS\n} = require('./constants')\n\n/**\n * @typedef {import('../')} Libp2p\n *\n * @typedef {Object} RelayAdvertiseOptions\n * @property {number} [bootDelay = ADVERTISE_BOOT_DELAY]\n * @property {boolean} [enabled = true]\n * @property {number} [ttl = ADVERTISE_TTL]\n *\n * @typedef {Object} HopOptions\n * @property {boolean} [enabled = false]\n * @property {boolean} [active = false]\n *\n * @typedef {Object} AutoRelayOptions\n * @property {number} [maxListeners = 2] - maximum number of relays to listen.\n * @property {boolean} [enabled = false]\n */\n\nclass Relay {\n /**\n * Creates an instance of Relay.\n *\n * @class\n * @param {Libp2p} libp2p\n */\n constructor (libp2p) {\n this._libp2p = libp2p\n this._options = {\n ...libp2p._config.relay\n }\n\n // Create autoRelay if enabled\n this._autoRelay = this._options.autoRelay.enabled && new AutoRelay({ libp2p, ...this._options.autoRelay })\n\n this._advertiseService = this._advertiseService.bind(this)\n }\n\n /**\n * Start Relay service.\n *\n * @returns {void}\n */\n start () {\n // Advertise service if HOP enabled\n const canHop = this._options.hop.enabled\n\n if (canHop && this._options.advertise.enabled) {\n this._timeout = setDelayedInterval(\n this._advertiseService, this._options.advertise.ttl, this._options.advertise.bootDelay\n )\n }\n }\n\n /**\n * Stop Relay service.\n *\n * @returns {void}\n */\n stop () {\n clearDelayedInterval(this._timeout)\n }\n\n /**\n * Advertise hop relay service in the network.\n *\n * @returns {Promise<void>}\n */\n async _advertiseService () {\n try {\n const cid = await namespaceToCid(RELAY_RENDEZVOUS_NS)\n await this._libp2p.contentRouting.provide(cid)\n } catch (err) {\n if (err.code === 'NO_ROUTERS_AVAILABLE') {\n log.error('a content router, such as a DHT, must be provided in order to advertise the relay service', err)\n // Stop the advertise\n this.stop()\n } else {\n log.error(err)\n }\n }\n }\n}\n\nmodule.exports = Relay\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:auto-relay'), {\n error: debug('libp2p:auto-relay:err')\n})\n\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\n\nconst { relay: multicodec } = require('./multicodec')\nconst { canHop } = require('./circuit/hop')\nconst { namespaceToCid } = require('./utils')\nconst {\n CIRCUIT_PROTO_CODE,\n HOP_METADATA_KEY,\n HOP_METADATA_VALUE,\n RELAY_RENDEZVOUS_NS\n} = require('./constants')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('../peer-store/address-book').Address} Address\n */\n\n/**\n * @typedef {Object} AutoRelayProperties\n * @property {import('../')} libp2p\n *\n * @typedef {Object} AutoRelayOptions\n * @property {number} [maxListeners = 1] - maximum number of relays to listen.\n * @property {(error: Error, msg?: string) => {}} [onError]\n */\n\nclass AutoRelay {\n /**\n * Creates an instance of AutoRelay.\n *\n * @class\n * @param {AutoRelayProperties & AutoRelayOptions} props\n */\n constructor ({ libp2p, maxListeners = 1, onError }) {\n this._libp2p = libp2p\n this._peerId = libp2p.peerId\n this._peerStore = libp2p.peerStore\n this._connectionManager = libp2p.connectionManager\n this._transportManager = libp2p.transportManager\n this._addressSorter = libp2p.dialer.addressSorter\n\n this.maxListeners = maxListeners\n\n /**\n * @type {Set<string>}\n */\n this._listenRelays = new Set()\n\n this._onProtocolChange = this._onProtocolChange.bind(this)\n this._onPeerDisconnected = this._onPeerDisconnected.bind(this)\n\n this._peerStore.on('change:protocols', this._onProtocolChange)\n this._connectionManager.on('peer:disconnect', this._onPeerDisconnected)\n\n /**\n * @param {Error} error\n * @param {string} [msg]\n */\n this._onError = (error, msg) => {\n log.error(msg || error)\n onError && onError(error, msg)\n }\n }\n\n /**\n * Check if a peer supports the relay protocol.\n * If the protocol is not supported, check if it was supported before and remove it as a listen relay.\n * If the protocol is supported, check if the peer supports **HOP** and add it as a listener if\n * inside the threshold.\n *\n * @param {Object} props\n * @param {PeerId} props.peerId\n * @param {string[]} props.protocols\n * @returns {Promise<void>}\n */\n async _onProtocolChange ({ peerId, protocols }) {\n const id = peerId.toB58String()\n\n // Check if it has the protocol\n const hasProtocol = protocols.find(protocol => protocol === multicodec)\n\n // If no protocol, check if we were keeping the peer before as a listenRelay\n if (!hasProtocol && this._listenRelays.has(id)) {\n this._removeListenRelay(id)\n return\n } else if (!hasProtocol || this._listenRelays.has(id)) {\n return\n }\n\n // If protocol, check if can hop, store info in the metadataBook and listen on it\n try {\n const connection = this._connectionManager.get(peerId)\n if (!connection) {\n return\n }\n\n // Do not hop on a relayed connection\n if (connection.remoteAddr.protoCodes().includes(CIRCUIT_PROTO_CODE)) {\n log(`relayed connection to ${id} will not be used to hop on`)\n return\n }\n\n const supportsHop = await canHop({ connection })\n\n if (supportsHop) {\n this._peerStore.metadataBook.set(peerId, HOP_METADATA_KEY, uint8ArrayFromString(HOP_METADATA_VALUE))\n await this._addListenRelay(connection, id)\n }\n } catch (err) {\n this._onError(err)\n }\n }\n\n /**\n * Peer disconnects.\n *\n * @param {Connection} connection - connection to the peer\n * @returns {void}\n */\n _onPeerDisconnected (connection) {\n const peerId = connection.remotePeer\n const id = peerId.toB58String()\n\n // Not listening on this relay\n if (!this._listenRelays.has(id)) {\n return\n }\n\n this._removeListenRelay(id)\n }\n\n /**\n * Attempt to listen on the given relay connection.\n *\n * @private\n * @param {Connection} connection - connection to the peer\n * @param {string} id - peer identifier string\n * @returns {Promise<void>}\n */\n async _addListenRelay (connection, id) {\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n\n // Get peer known addresses and sort them per public addresses first\n const remoteAddrs = this._peerStore.addressBook.getMultiaddrsForPeer(\n connection.remotePeer, this._addressSorter\n )\n\n if (!remoteAddrs || !remoteAddrs.length) {\n return\n }\n\n const listenAddr = `${remoteAddrs[0].toString()}/p2p-circuit`\n this._listenRelays.add(id)\n\n // Attempt to listen on relay\n try {\n await this._transportManager.listen([new Multiaddr(listenAddr)])\n // Announce multiaddrs will update on listen success by TransportManager event being triggered\n } catch (err) {\n this._onError(err)\n this._listenRelays.delete(id)\n }\n }\n\n /**\n * Remove listen relay.\n *\n * @private\n * @param {string} id - peer identifier string.\n * @returns {void}\n */\n _removeListenRelay (id) {\n if (this._listenRelays.delete(id)) {\n // TODO: this should be responsibility of the connMgr\n this._listenOnAvailableHopRelays([id])\n }\n }\n\n /**\n * Try to listen on available hop relay connections.\n * The following order will happen while we do not have enough relays.\n * 1. Check the metadata store for known relays, try to listen on the ones we are already connected.\n * 2. Dial and try to listen on the peers we know that support hop but are not connected.\n * 3. Search the network.\n *\n * @param {string[]} [peersToIgnore]\n * @returns {Promise<void>}\n */\n async _listenOnAvailableHopRelays (peersToIgnore = []) {\n // TODO: The peer redial issue on disconnect should be handled by connection gating\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n\n const knownHopsToDial = []\n\n // Check if we have known hop peers to use and attempt to listen on the already connected\n for (const [id, metadataMap] of this._peerStore.metadataBook.data.entries()) {\n // Continue to next if listening on this or peer to ignore\n if (this._listenRelays.has(id) || peersToIgnore.includes(id)) {\n continue\n }\n\n const supportsHop = metadataMap.get(HOP_METADATA_KEY)\n\n // Continue to next if it does not support Hop\n if (!supportsHop || uint8ArrayToString(supportsHop) !== HOP_METADATA_VALUE) {\n continue\n }\n\n const peerId = PeerId.createFromB58String(id)\n const connection = this._connectionManager.get(peerId)\n\n // If not connected, store for possible later use.\n if (!connection) {\n knownHopsToDial.push(peerId)\n continue\n }\n\n await this._addListenRelay(connection, id)\n\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n }\n\n // Try to listen on known peers that are not connected\n for (const peerId of knownHopsToDial) {\n await this._tryToListenOnRelay(peerId)\n\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n }\n\n // Try to find relays to hop on the network\n try {\n const cid = await namespaceToCid(RELAY_RENDEZVOUS_NS)\n for await (const provider of this._libp2p.contentRouting.findProviders(cid)) {\n if (!provider.multiaddrs.length) {\n continue\n }\n\n const peerId = provider.id\n this._peerStore.addressBook.add(peerId, provider.multiaddrs)\n\n await this._tryToListenOnRelay(peerId)\n\n // Check if already listening on enough relays\n if (this._listenRelays.size >= this.maxListeners) {\n return\n }\n }\n } catch (err) {\n this._onError(err)\n }\n }\n\n /**\n * @param {PeerId} peerId\n */\n async _tryToListenOnRelay (peerId) {\n try {\n const connection = await this._libp2p.dial(peerId)\n await this._addListenRelay(connection, peerId.toB58String())\n } catch (err) {\n this._onError(err, `could not connect and listen on known hop relay ${peerId.toB58String()}`)\n }\n }\n}\n\nmodule.exports = AutoRelay\n","'use strict'\n\nconst { CID } = require('multiformats/cid')\nconst { sha256 } = require('multiformats/hashes/sha2')\n\n/**\n * Convert a namespace string into a cid.\n *\n * @param {string} namespace\n * @returns {Promise<CID>}\n */\nmodule.exports.namespaceToCid = async (namespace) => {\n const bytes = new TextEncoder().encode(namespace)\n const hash = await sha256.digest(bytes)\n\n return CID.createV0(hash)\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:dialer'), {\n error: debug('libp2p:dialer:err')\n})\nconst errCode = require('err-code')\nconst { Multiaddr } = require('multiaddr')\n// @ts-ignore timeout-abourt-controles does not export types\nconst TimeoutController = require('timeout-abort-controller')\nconst { AbortError } = require('abortable-iterator')\nconst { anySignal } = require('any-signal')\n\nconst DialRequest = require('./dial-request')\nconst { publicAddressesFirst } = require('libp2p-utils/src/address-sort')\nconst getPeer = require('../get-peer')\n\nconst { codes } = require('../errors')\nconst {\n DIAL_TIMEOUT,\n MAX_PARALLEL_DIALS,\n MAX_PER_PEER_DIALS,\n MAX_ADDRS_TO_DIAL\n} = require('../constants')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('../peer-store')} PeerStore\n * @typedef {import('../peer-store/address-book').Address} Address\n * @typedef {import('../transport-manager')} TransportManager\n */\n\n/**\n * @typedef {Object} DialerProperties\n * @property {PeerStore} peerStore\n * @property {TransportManager} transportManager\n *\n * @typedef {(addr:Multiaddr) => Promise<string[]>} Resolver\n *\n * @typedef {Object} DialerOptions\n * @property {(addresses: Address[]) => Address[]} [options.addressSorter = publicAddressesFirst] - Sort the known addresses of a peer before trying to dial.\n * @property {number} [maxParallelDials = MAX_PARALLEL_DIALS] - Number of max concurrent dials.\n * @property {number} [maxAddrsToDial = MAX_ADDRS_TO_DIAL] - Number of max addresses to dial for a given peer.\n * @property {number} [maxDialsPerPeer = MAX_PER_PEER_DIALS] - Number of max concurrent dials per peer.\n * @property {number} [dialTimeout = DIAL_TIMEOUT] - How long a dial attempt is allowed to take.\n * @property {Record<string, Resolver>} [resolvers = {}] - multiaddr resolvers to use when dialing\n *\n * @typedef DialTarget\n * @property {string} id\n * @property {Multiaddr[]} addrs\n *\n * @typedef PendingDial\n * @property {DialRequest} dialRequest\n * @property {TimeoutController} controller\n * @property {Promise<Connection>} promise\n * @property {function():void} destroy\n */\n\nclass Dialer {\n /**\n * @class\n * @param {DialerProperties & DialerOptions} options\n */\n constructor ({\n transportManager,\n peerStore,\n addressSorter = publicAddressesFirst,\n maxParallelDials = MAX_PARALLEL_DIALS,\n maxAddrsToDial = MAX_ADDRS_TO_DIAL,\n dialTimeout = DIAL_TIMEOUT,\n maxDialsPerPeer = MAX_PER_PEER_DIALS,\n resolvers = {}\n }) {\n this.transportManager = transportManager\n this.peerStore = peerStore\n this.addressSorter = addressSorter\n this.maxParallelDials = maxParallelDials\n this.maxAddrsToDial = maxAddrsToDial\n this.timeout = dialTimeout\n this.maxDialsPerPeer = maxDialsPerPeer\n this.tokens = [...new Array(maxParallelDials)].map((_, index) => index)\n this._pendingDials = new Map()\n this._pendingDialTargets = new Map()\n\n for (const [key, value] of Object.entries(resolvers)) {\n Multiaddr.resolvers.set(key, value)\n }\n }\n\n /**\n * Clears any pending dials\n */\n destroy () {\n for (const dial of this._pendingDials.values()) {\n try {\n dial.controller.abort()\n } catch (err) {\n log.error(err)\n }\n }\n this._pendingDials.clear()\n\n for (const pendingTarget of this._pendingDialTargets.values()) {\n pendingTarget.reject(new AbortError('Dialer was destroyed'))\n }\n this._pendingDialTargets.clear()\n }\n\n /**\n * Connects to a given `peer` by dialing all of its known addresses.\n * The dial to the first address that is successfully able to upgrade a connection\n * will be used.\n *\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - An AbortController signal\n * @returns {Promise<Connection>}\n */\n async connectToPeer (peer, options = {}) {\n const dialTarget = await this._createCancellableDialTarget(peer)\n\n if (!dialTarget.addrs.length) {\n throw errCode(new Error('The dial request has no valid addresses'), codes.ERR_NO_VALID_ADDRESSES)\n }\n const pendingDial = this._pendingDials.get(dialTarget.id) || this._createPendingDial(dialTarget, options)\n\n try {\n const connection = await pendingDial.promise\n log('dial succeeded to %s', dialTarget.id)\n return connection\n } catch (err) {\n // Error is a timeout\n if (pendingDial.controller.signal.aborted) {\n err.code = codes.ERR_TIMEOUT\n }\n log.error(err)\n throw err\n } finally {\n pendingDial.destroy()\n }\n }\n\n /**\n * Connects to a given `peer` by dialing all of its known addresses.\n * The dial to the first address that is successfully able to upgrade a connection\n * will be used.\n *\n * @param {PeerId|Multiaddr|string} peer - The peer to dial\n * @returns {Promise<DialTarget>}\n */\n async _createCancellableDialTarget (peer) {\n // Make dial target promise cancellable\n const id = `${(parseInt(String(Math.random() * 1e9), 10)).toString() + Date.now()}`\n const cancellablePromise = new Promise((resolve, reject) => {\n this._pendingDialTargets.set(id, { resolve, reject })\n })\n\n const dialTarget = await Promise.race([\n this._createDialTarget(peer),\n cancellablePromise\n ])\n\n this._pendingDialTargets.delete(id)\n\n return dialTarget\n }\n\n /**\n * Creates a DialTarget. The DialTarget is used to create and track\n * the DialRequest to a given peer.\n * If a multiaddr is received it should be the first address attempted.\n * Multiaddrs not supported by the available transports will be filtered out.\n *\n * @private\n * @param {PeerId|Multiaddr|string} peer - A PeerId or Multiaddr\n * @returns {Promise<DialTarget>}\n */\n async _createDialTarget (peer) {\n const { id, multiaddrs } = getPeer(peer)\n\n if (multiaddrs) {\n this.peerStore.addressBook.add(id, multiaddrs)\n }\n\n let knownAddrs = this.peerStore.addressBook.getMultiaddrsForPeer(id, this.addressSorter) || []\n\n // If received a multiaddr to dial, it should be the first to use\n // But, if we know other multiaddrs for the peer, we should try them too.\n if (Multiaddr.isMultiaddr(peer)) {\n knownAddrs = knownAddrs.filter((addr) => !peer.equals(addr))\n knownAddrs.unshift(peer)\n }\n\n /** @type {Multiaddr[]} */\n const addrs = []\n for (const a of knownAddrs) {\n const resolvedAddrs = await this._resolve(a)\n resolvedAddrs.forEach(ra => addrs.push(ra))\n }\n\n // Multiaddrs not supported by the available transports will be filtered out.\n const supportedAddrs = addrs.filter(a => this.transportManager.transportForMultiaddr(a))\n\n if (supportedAddrs.length > this.maxAddrsToDial) {\n this.peerStore.delete(id)\n throw errCode(new Error('dial with more addresses than allowed'), codes.ERR_TOO_MANY_ADDRESSES)\n }\n\n return {\n id: id.toB58String(),\n addrs: supportedAddrs\n }\n }\n\n /**\n * Creates a PendingDial that wraps the underlying DialRequest\n *\n * @private\n * @param {DialTarget} dialTarget\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - An AbortController signal\n * @returns {PendingDial}\n */\n _createPendingDial (dialTarget, options = {}) {\n /**\n * @param {Multiaddr} addr\n * @param {{ signal: { aborted: any; }; }} options\n */\n const dialAction = (addr, options) => {\n if (options.signal.aborted) throw errCode(new Error('already aborted'), codes.ERR_ALREADY_ABORTED)\n return this.transportManager.dial(addr, options)\n }\n\n const dialRequest = new DialRequest({\n addrs: dialTarget.addrs,\n dialAction,\n dialer: this\n })\n\n // Combine the timeout signal and options.signal, if provided\n const timeoutController = new TimeoutController(this.timeout)\n const signals = [timeoutController.signal]\n options.signal && signals.push(options.signal)\n const signal = anySignal(signals)\n\n const pendingDial = {\n dialRequest,\n controller: timeoutController,\n promise: dialRequest.run({ ...options, signal }),\n destroy: () => {\n timeoutController.clear()\n this._pendingDials.delete(dialTarget.id)\n }\n }\n this._pendingDials.set(dialTarget.id, pendingDial)\n return pendingDial\n }\n\n /**\n * @param {number} num\n */\n getTokens (num) {\n const total = Math.min(num, this.maxDialsPerPeer, this.tokens.length)\n const tokens = this.tokens.splice(0, total)\n log('%d tokens request, returning %d, %d remaining', num, total, this.tokens.length)\n return tokens\n }\n\n /**\n * @param {number} token\n */\n releaseToken (token) {\n // Guard against duplicate releases\n if (this.tokens.indexOf(token) > -1) return\n log('token %d released', token)\n this.tokens.push(token)\n }\n\n /**\n * Resolve multiaddr recursively.\n *\n * @param {Multiaddr} ma\n * @returns {Promise<Multiaddr[]>}\n */\n async _resolve (ma) {\n // TODO: recursive logic should live in multiaddr once dns4/dns6 support is in place\n // Now only supporting resolve for dnsaddr\n const resolvableProto = ma.protoNames().includes('dnsaddr')\n\n // Multiaddr is not resolvable? End recursion!\n if (!resolvableProto) {\n return [ma]\n }\n\n const resolvedMultiaddrs = await this._resolveRecord(ma)\n const recursiveMultiaddrs = await Promise.all(resolvedMultiaddrs.map((nm) => {\n return this._resolve(nm)\n }))\n\n const addrs = recursiveMultiaddrs.flat()\n return addrs.reduce((array, newM) => {\n if (!array.find(m => m.equals(newM))) {\n array.push(newM)\n }\n return array\n }, /** @type {Multiaddr[]} */([]))\n }\n\n /**\n * Resolve a given multiaddr. If this fails, an empty array will be returned\n *\n * @param {Multiaddr} ma\n * @returns {Promise<Multiaddr[]>}\n */\n async _resolveRecord (ma) {\n try {\n ma = new Multiaddr(ma.toString()) // Use current multiaddr module\n const multiaddrs = await ma.resolve()\n return multiaddrs\n } catch (_) {\n log.error(`multiaddr ${ma} could not be resolved`)\n return []\n }\n }\n}\n\nmodule.exports = Dialer\n","'use strict'\n\nconst errCode = require('err-code')\nconst AbortController = require('abort-controller').default\nconst { anySignal } = require('any-signal')\n// @ts-ignore p-fifo does not export types\nconst FIFO = require('p-fifo')\nconst pAny = require('p-any')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('./')} Dialer\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @typedef {Object} DialOptions\n * @property {AbortSignal} signal\n *\n * @typedef {Object} DialRequestOptions\n * @property {Multiaddr[]} addrs\n * @property {(m: Multiaddr, options: DialOptions) => Promise<Connection>} dialAction\n * @property {Dialer} dialer\n */\n\nclass DialRequest {\n /**\n * Manages running the `dialAction` on multiple provided `addrs` in parallel\n * up to a maximum determined by the number of tokens returned\n * from `dialer.getTokens`. Once a DialRequest is created, it can be\n * started using `DialRequest.run(options)`. Once a single dial has succeeded,\n * all other dials in the request will be cancelled.\n *\n * @class\n * @param {DialRequestOptions} options\n */\n constructor ({\n addrs,\n dialAction,\n dialer\n }) {\n this.addrs = addrs\n this.dialer = dialer\n this.dialAction = dialAction\n }\n\n /**\n * @async\n * @param {object} [options]\n * @param {AbortSignal} [options.signal] - An AbortController signal\n * @returns {Promise<Connection>}\n */\n async run (options = {}) {\n const tokens = this.dialer.getTokens(this.addrs.length)\n // If no tokens are available, throw\n if (tokens.length < 1) {\n throw errCode(new Error('No dial tokens available'), 'ERR_NO_DIAL_TOKENS')\n }\n\n const tokenHolder = new FIFO()\n tokens.forEach(token => tokenHolder.push(token))\n const dialAbortControllers = this.addrs.map(() => new AbortController())\n let completedDials = 0\n\n try {\n return await pAny(this.addrs.map(async (addr, i) => {\n const token = await tokenHolder.shift() // get token\n let conn\n try {\n const signal = dialAbortControllers[i].signal\n conn = await this.dialAction(addr, { ...options, signal: options.signal ? anySignal([signal, options.signal]) : signal })\n // Remove the successful AbortController so it is not aborted\n dialAbortControllers.splice(i, 1)\n } finally {\n completedDials++\n // If we have more or equal dials remaining than tokens, recycle the token, otherwise release it\n if (this.addrs.length - completedDials >= tokens.length) {\n tokenHolder.push(token)\n } else {\n this.dialer.releaseToken(tokens.splice(tokens.indexOf(token), 1)[0])\n }\n }\n\n return conn\n }))\n } finally {\n dialAbortControllers.map(c => c.abort()) // success/failure happened, abort everything else\n tokens.forEach(token => this.dialer.releaseToken(token)) // release tokens back to the dialer\n }\n }\n}\n\nmodule.exports = DialRequest\n","const Fifo = require('fast-fifo')\nconst defer = require('p-defer')\n\nmodule.exports = class PFifo {\n constructor () {\n this._buffer = new Fifo()\n this._waitingConsumers = new Fifo()\n }\n\n push (chunk) {\n const { promise, resolve } = defer()\n this._buffer.push({ chunk, resolve })\n this._consume()\n return promise\n }\n\n _consume () {\n while (!this._waitingConsumers.isEmpty() && !this._buffer.isEmpty()) {\n const nextConsumer = this._waitingConsumers.shift()\n const nextChunk = this._buffer.shift()\n nextConsumer.resolve(nextChunk.chunk)\n nextChunk.resolve()\n }\n }\n\n shift () {\n const { promise, resolve } = defer()\n this._waitingConsumers.push({ resolve })\n this._consume()\n return promise\n }\n\n isEmpty () {\n return this._buffer.isEmpty()\n }\n}\n","'use strict';\nconst pSome = require('p-some');\nconst PCancelable = require('p-cancelable');\n\nmodule.exports = (iterable, options) => {\n\tconst anyCancelable = pSome(iterable, {...options, count: 1});\n\n\treturn PCancelable.fn(async onCancel => {\n\t\tonCancel(() => {\n\t\t\tanyCancelable.cancel();\n\t\t});\n\n\t\tconst [value] = await anyCancelable;\n\t\treturn value;\n\t})();\n};\n\nmodule.exports.AggregateError = pSome.AggregateError;\n","'use strict';\nconst AggregateError = require('aggregate-error');\nconst PCancelable = require('p-cancelable');\n\nclass FilterError extends Error { }\n\nconst pSome = (iterable, options) => new PCancelable((resolve, reject, onCancel) => {\n\tconst {\n\t\tcount,\n\t\tfilter = () => true\n\t} = options;\n\n\tif (!Number.isFinite(count)) {\n\t\treject(new TypeError(`Expected a finite number, got ${typeof options.count}`));\n\t\treturn;\n\t}\n\n\tconst values = [];\n\tconst errors = [];\n\tlet elementCount = 0;\n\tlet isSettled = false;\n\n\tconst completed = new Set();\n\tconst maybeSettle = () => {\n\t\tif (values.length === count) {\n\t\t\tresolve(values);\n\t\t\tisSettled = true;\n\t\t}\n\n\t\tif (elementCount - errors.length < count) {\n\t\t\treject(new AggregateError(errors));\n\t\t\tisSettled = true;\n\t\t}\n\n\t\treturn isSettled;\n\t};\n\n\tconst cancelPending = () => {\n\t\tfor (const promise of iterable) {\n\t\t\tif (!completed.has(promise) && typeof promise.cancel === 'function') {\n\t\t\t\tpromise.cancel();\n\t\t\t}\n\t\t}\n\t};\n\n\tonCancel(cancelPending);\n\n\tfor (const element of iterable) {\n\t\telementCount++;\n\n\t\t(async () => {\n\t\t\ttry {\n\t\t\t\tconst value = await element;\n\n\t\t\t\tif (isSettled) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (!filter(value)) {\n\t\t\t\t\tthrow new FilterError('Value does not satisfy filter');\n\t\t\t\t}\n\n\t\t\t\tvalues.push(value);\n\t\t\t} catch (error) {\n\t\t\t\terrors.push(error);\n\t\t\t} finally {\n\t\t\t\tcompleted.add(element);\n\n\t\t\t\tif (!isSettled && maybeSettle()) {\n\t\t\t\t\tcancelPending();\n\t\t\t\t}\n\t\t\t}\n\t\t})();\n\t}\n\n\tif (count > elementCount) {\n\t\treject(new RangeError(`Expected input to contain at least ${options.count} items, but contains ${elementCount} items`));\n\t\tcancelPending();\n\t}\n});\n\nmodule.exports = pSome;\nmodule.exports.AggregateError = AggregateError;\nmodule.exports.FilterError = FilterError;\n","'use strict';\n\nclass CancelError extends Error {\n\tconstructor(reason) {\n\t\tsuper(reason || 'Promise was canceled');\n\t\tthis.name = 'CancelError';\n\t}\n\n\tget isCanceled() {\n\t\treturn true;\n\t}\n}\n\nclass PCancelable {\n\tstatic fn(userFn) {\n\t\treturn (...arguments_) => {\n\t\t\treturn new PCancelable((resolve, reject, onCancel) => {\n\t\t\t\targuments_.push(onCancel);\n\t\t\t\t// eslint-disable-next-line promise/prefer-await-to-then\n\t\t\t\tuserFn(...arguments_).then(resolve, reject);\n\t\t\t});\n\t\t};\n\t}\n\n\tconstructor(executor) {\n\t\tthis._cancelHandlers = [];\n\t\tthis._isPending = true;\n\t\tthis._isCanceled = false;\n\t\tthis._rejectOnCancel = true;\n\n\t\tthis._promise = new Promise((resolve, reject) => {\n\t\t\tthis._reject = reject;\n\n\t\t\tconst onResolve = value => {\n\t\t\t\tif (!this._isCanceled || !onCancel.shouldReject) {\n\t\t\t\t\tthis._isPending = false;\n\t\t\t\t\tresolve(value);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tconst onReject = error => {\n\t\t\t\tthis._isPending = false;\n\t\t\t\treject(error);\n\t\t\t};\n\n\t\t\tconst onCancel = handler => {\n\t\t\t\tif (!this._isPending) {\n\t\t\t\t\tthrow new Error('The `onCancel` handler was attached after the promise settled.');\n\t\t\t\t}\n\n\t\t\t\tthis._cancelHandlers.push(handler);\n\t\t\t};\n\n\t\t\tObject.defineProperties(onCancel, {\n\t\t\t\tshouldReject: {\n\t\t\t\t\tget: () => this._rejectOnCancel,\n\t\t\t\t\tset: boolean => {\n\t\t\t\t\t\tthis._rejectOnCancel = boolean;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\n\t\t\treturn executor(onResolve, onReject, onCancel);\n\t\t});\n\t}\n\n\tthen(onFulfilled, onRejected) {\n\t\t// eslint-disable-next-line promise/prefer-await-to-then\n\t\treturn this._promise.then(onFulfilled, onRejected);\n\t}\n\n\tcatch(onRejected) {\n\t\treturn this._promise.catch(onRejected);\n\t}\n\n\tfinally(onFinally) {\n\t\treturn this._promise.finally(onFinally);\n\t}\n\n\tcancel(reason) {\n\t\tif (!this._isPending || this._isCanceled) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis._isCanceled = true;\n\n\t\tif (this._cancelHandlers.length > 0) {\n\t\t\ttry {\n\t\t\t\tfor (const handler of this._cancelHandlers) {\n\t\t\t\t\thandler();\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tthis._reject(error);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tif (this._rejectOnCancel) {\n\t\t\tthis._reject(new CancelError(reason));\n\t\t}\n\t}\n\n\tget isCanceled() {\n\t\treturn this._isCanceled;\n\t}\n}\n\nObject.setPrototypeOf(PCancelable.prototype, Promise.prototype);\n\nmodule.exports = PCancelable;\nmodule.exports.CancelError = CancelError;\n","/* eslint max-nested-callbacks: [\"error\", 5] */\n'use strict'\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:keychain'), {\n error: debug('libp2p:keychain:err')\n})\nconst sanitize = require('sanitize-filename')\nconst mergeOptions = require('merge-options')\nconst crypto = require('libp2p-crypto')\nconst { Key } = require('interface-datastore/key')\nconst CMS = require('./cms')\nconst errcode = require('err-code')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\n// @ts-ignore node-forge sha512 types not exported\nrequire('node-forge/lib/sha512')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('interface-datastore').Datastore} Datastore\n */\n\n/**\n * @typedef {Object} DekOptions\n * @property {string} hash\n * @property {string} salt\n * @property {number} iterationCount\n * @property {number} keyLength\n *\n * @typedef {Object} KeychainOptions\n * @property {string} [pass]\n * @property {DekOptions} [dek]\n */\n\n/**\n * Information about a key.\n *\n * @typedef {Object} KeyInfo\n * @property {string} id - The universally unique key id.\n * @property {string} name - The local key name.\n */\n\nconst keyPrefix = '/pkcs8/'\nconst infoPrefix = '/info/'\nconst privates = new WeakMap()\n\n// NIST SP 800-132\nconst NIST = {\n minKeyLength: 112 / 8,\n minSaltLength: 128 / 8,\n minIterationCount: 1000\n}\n\nconst defaultOptions = {\n // See https://cryptosense.com/parametesr-choice-for-pbkdf2/\n dek: {\n keyLength: 512 / 8,\n iterationCount: 10000,\n salt: 'you should override this value with a crypto secure random number',\n hash: 'sha2-512'\n }\n}\n\n/**\n * @param {string} name\n */\nfunction validateKeyName (name) {\n if (!name) return false\n if (typeof name !== 'string') return false\n return name === sanitize(name.trim())\n}\n\n/**\n * Throws an error after a delay\n *\n * This assumes than an error indicates that the keychain is under attack. Delay returning an\n * error to make brute force attacks harder.\n *\n * @param {string|Error} err - The error\n * @returns {Promise<never>}\n * @private\n */\nasync function throwDelayed (err) {\n const min = 200\n const max = 1000\n const delay = Math.random() * (max - min) + min\n\n await new Promise(resolve => setTimeout(resolve, delay))\n throw err\n}\n\n/**\n * Converts a key name into a datastore name.\n *\n * @param {string} name\n * @returns {Key}\n * @private\n */\nfunction DsName (name) {\n return new Key(keyPrefix + name)\n}\n\n/**\n * Converts a key name into a datastore info name.\n *\n * @param {string} name\n * @returns {Key}\n * @private\n */\nfunction DsInfoName (name) {\n return new Key(infoPrefix + name)\n}\n\n/**\n * Manages the lifecycle of a key. Keys are encrypted at rest using PKCS #8.\n *\n * A key in the store has two entries\n * - '/info/*key-name*', contains the KeyInfo for the key\n * - '/pkcs8/*key-name*', contains the PKCS #8 for the key\n *\n */\nclass Keychain {\n /**\n * Creates a new instance of a key chain.\n *\n * @param {Datastore} store - where the key are.\n * @param {KeychainOptions} options\n * @class\n */\n constructor (store, options) {\n if (!store) {\n throw new Error('store is required')\n }\n this.store = store\n\n this.opts = mergeOptions(defaultOptions, options)\n\n // Enforce NIST SP 800-132\n if (this.opts.pass && this.opts.pass.length < 20) {\n throw new Error('pass must be least 20 characters')\n }\n if (this.opts.dek.keyLength < NIST.minKeyLength) {\n throw new Error(`dek.keyLength must be least ${NIST.minKeyLength} bytes`)\n }\n if (this.opts.dek.salt.length < NIST.minSaltLength) {\n throw new Error(`dek.saltLength must be least ${NIST.minSaltLength} bytes`)\n }\n if (this.opts.dek.iterationCount < NIST.minIterationCount) {\n throw new Error(`dek.iterationCount must be least ${NIST.minIterationCount}`)\n }\n\n const dek = this.opts.pass\n ? crypto.pbkdf2(\n this.opts.pass,\n this.opts.dek.salt,\n this.opts.dek.iterationCount,\n this.opts.dek.keyLength,\n this.opts.dek.hash)\n : ''\n\n privates.set(this, { dek })\n }\n\n /**\n * Gets an object that can encrypt/decrypt protected data\n * using the Cryptographic Message Syntax (CMS).\n *\n * CMS describes an encapsulation syntax for data protection. It\n * is used to digitally sign, digest, authenticate, or encrypt\n * arbitrary message content.\n *\n * @returns {CMS}\n */\n get cms () {\n return new CMS(this, privates.get(this).dek)\n }\n\n /**\n * Generates the options for a keychain. A random salt is produced.\n *\n * @returns {Object}\n */\n static generateOptions () {\n const options = Object.assign({}, defaultOptions)\n const saltLength = Math.ceil(NIST.minSaltLength / 3) * 3 // no base64 padding\n options.dek.salt = uint8ArrayToString(crypto.randomBytes(saltLength), 'base64')\n return options\n }\n\n /**\n * Gets an object that can encrypt/decrypt protected data.\n * The default options for a keychain.\n *\n * @returns {Object}\n */\n static get options () {\n return defaultOptions\n }\n\n /**\n * Create a new key.\n *\n * @param {string} name - The local key name; cannot already exist.\n * @param {string} type - One of the key types; 'rsa'.\n * @param {number} [size = 2048] - The key size in bits. Used for rsa keys only.\n * @returns {Promise<KeyInfo>}\n */\n async createKey (name, type, size = 2048) {\n const self = this\n\n if (!validateKeyName(name) || name === 'self') {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n\n if (typeof type !== 'string') {\n return throwDelayed(errcode(new Error(`Invalid key type '${type}'`), 'ERR_INVALID_KEY_TYPE'))\n }\n\n const dsname = DsName(name)\n const exists = await self.store.has(dsname)\n if (exists) return throwDelayed(errcode(new Error(`Key '${name}' already exists`), 'ERR_KEY_ALREADY_EXISTS'))\n\n switch (type.toLowerCase()) {\n case 'rsa':\n if (!Number.isSafeInteger(size) || size < 2048) {\n return throwDelayed(errcode(new Error(`Invalid RSA key size ${size}`), 'ERR_INVALID_KEY_SIZE'))\n }\n break\n default:\n break\n }\n\n let keyInfo\n try {\n // @ts-ignore Differences between several crypto return types need to be fixed in libp2p-crypto\n const keypair = await crypto.keys.generateKeyPair(type, size)\n const kid = await keypair.id()\n /** @type {string} */\n const dek = privates.get(this).dek\n const pem = await keypair.export(dek)\n keyInfo = {\n name: name,\n id: kid\n }\n const batch = self.store.batch()\n batch.put(dsname, uint8ArrayFromString(pem))\n batch.put(DsInfoName(name), uint8ArrayFromString(JSON.stringify(keyInfo)))\n\n await batch.commit()\n } catch (err) {\n return throwDelayed(err)\n }\n\n return keyInfo\n }\n\n /**\n * List all the keys.\n *\n * @returns {Promise<KeyInfo[]>}\n */\n async listKeys () {\n const self = this\n const query = {\n prefix: infoPrefix\n }\n\n const info = []\n for await (const value of self.store.query(query)) {\n info.push(JSON.parse(uint8ArrayToString(value.value)))\n }\n\n return info\n }\n\n /**\n * Find a key by it's id.\n *\n * @param {string} id - The universally unique key identifier.\n * @returns {Promise<KeyInfo|undefined>}\n */\n async findKeyById (id) {\n try {\n const keys = await this.listKeys()\n return keys.find((k) => k.id === id)\n } catch (err) {\n return throwDelayed(err)\n }\n }\n\n /**\n * Find a key by it's name.\n *\n * @param {string} name - The local key name.\n * @returns {Promise<KeyInfo>}\n */\n async findKeyByName (name) {\n if (!validateKeyName(name)) {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n\n const dsname = DsInfoName(name)\n try {\n const res = await this.store.get(dsname)\n return JSON.parse(uint8ArrayToString(res))\n } catch (err) {\n return throwDelayed(errcode(new Error(`Key '${name}' does not exist. ${err.message}`), 'ERR_KEY_NOT_FOUND'))\n }\n }\n\n /**\n * Remove an existing key.\n *\n * @param {string} name - The local key name; must already exist.\n * @returns {Promise<KeyInfo>}\n */\n async removeKey (name) {\n const self = this\n if (!validateKeyName(name) || name === 'self') {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n const dsname = DsName(name)\n const keyInfo = await self.findKeyByName(name)\n const batch = self.store.batch()\n batch.delete(dsname)\n batch.delete(DsInfoName(name))\n await batch.commit()\n return keyInfo\n }\n\n /**\n * Rename a key\n *\n * @param {string} oldName - The old local key name; must already exist.\n * @param {string} newName - The new local key name; must not already exist.\n * @returns {Promise<KeyInfo>}\n */\n async renameKey (oldName, newName) {\n const self = this\n if (!validateKeyName(oldName) || oldName === 'self') {\n return throwDelayed(errcode(new Error(`Invalid old key name '${oldName}'`), 'ERR_OLD_KEY_NAME_INVALID'))\n }\n if (!validateKeyName(newName) || newName === 'self') {\n return throwDelayed(errcode(new Error(`Invalid new key name '${newName}'`), 'ERR_NEW_KEY_NAME_INVALID'))\n }\n const oldDsname = DsName(oldName)\n const newDsname = DsName(newName)\n const oldInfoName = DsInfoName(oldName)\n const newInfoName = DsInfoName(newName)\n\n const exists = await self.store.has(newDsname)\n if (exists) return throwDelayed(errcode(new Error(`Key '${newName}' already exists`), 'ERR_KEY_ALREADY_EXISTS'))\n\n try {\n const pem = await self.store.get(oldDsname)\n const res = await self.store.get(oldInfoName)\n\n const keyInfo = JSON.parse(uint8ArrayToString(res))\n keyInfo.name = newName\n const batch = self.store.batch()\n batch.put(newDsname, pem)\n batch.put(newInfoName, uint8ArrayFromString(JSON.stringify(keyInfo)))\n batch.delete(oldDsname)\n batch.delete(oldInfoName)\n await batch.commit()\n return keyInfo\n } catch (err) {\n return throwDelayed(err)\n }\n }\n\n /**\n * Export an existing key as a PEM encrypted PKCS #8 string\n *\n * @param {string} name - The local key name; must already exist.\n * @param {string} password - The password\n * @returns {Promise<string>}\n */\n async exportKey (name, password) {\n if (!validateKeyName(name)) {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n if (!password) {\n return throwDelayed(errcode(new Error('Password is required'), 'ERR_PASSWORD_REQUIRED'))\n }\n\n const dsname = DsName(name)\n try {\n const res = await this.store.get(dsname)\n const pem = uint8ArrayToString(res)\n /** @type {string} */\n const dek = privates.get(this).dek\n const privateKey = await crypto.keys.import(pem, dek)\n return privateKey.export(password)\n } catch (err) {\n return throwDelayed(err)\n }\n }\n\n /**\n * Import a new key from a PEM encoded PKCS #8 string\n *\n * @param {string} name - The local key name; must not already exist.\n * @param {string} pem - The PEM encoded PKCS #8 string\n * @param {string} password - The password.\n * @returns {Promise<KeyInfo>}\n */\n async importKey (name, pem, password) {\n const self = this\n if (!validateKeyName(name) || name === 'self') {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n if (!pem) {\n return throwDelayed(errcode(new Error('PEM encoded key is required'), 'ERR_PEM_REQUIRED'))\n }\n const dsname = DsName(name)\n const exists = await self.store.has(dsname)\n if (exists) return throwDelayed(errcode(new Error(`Key '${name}' already exists`), 'ERR_KEY_ALREADY_EXISTS'))\n\n let privateKey\n try {\n privateKey = await crypto.keys.import(pem, password)\n } catch (err) {\n return throwDelayed(errcode(new Error('Cannot read the key, most likely the password is wrong'), 'ERR_CANNOT_READ_KEY'))\n }\n\n let kid\n try {\n kid = await privateKey.id()\n /** @type {string} */\n const dek = privates.get(this).dek\n pem = await privateKey.export(dek)\n } catch (err) {\n return throwDelayed(err)\n }\n\n const keyInfo = {\n name: name,\n id: kid\n }\n const batch = self.store.batch()\n batch.put(dsname, uint8ArrayFromString(pem))\n batch.put(DsInfoName(name), uint8ArrayFromString(JSON.stringify(keyInfo)))\n await batch.commit()\n\n return keyInfo\n }\n\n /**\n * Import a peer key\n *\n * @param {string} name - The local key name; must not already exist.\n * @param {PeerId} peer - The PEM encoded PKCS #8 string\n * @returns {Promise<KeyInfo>}\n */\n async importPeer (name, peer) {\n const self = this\n if (!validateKeyName(name)) {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n if (!peer || !peer.privKey) {\n return throwDelayed(errcode(new Error('Peer.privKey is required'), 'ERR_MISSING_PRIVATE_KEY'))\n }\n\n const privateKey = peer.privKey\n const dsname = DsName(name)\n const exists = await self.store.has(dsname)\n if (exists) return throwDelayed(errcode(new Error(`Key '${name}' already exists`), 'ERR_KEY_ALREADY_EXISTS'))\n\n try {\n const kid = await privateKey.id()\n /** @type {string} */\n const dek = privates.get(this).dek\n const pem = await privateKey.export(dek)\n const keyInfo = {\n name: name,\n id: kid\n }\n const batch = self.store.batch()\n batch.put(dsname, uint8ArrayFromString(pem))\n batch.put(DsInfoName(name), uint8ArrayFromString(JSON.stringify(keyInfo)))\n await batch.commit()\n return keyInfo\n } catch (err) {\n return throwDelayed(err)\n }\n }\n\n /**\n * Gets the private key as PEM encoded PKCS #8 string.\n *\n * @param {string} name\n * @returns {Promise<string>}\n */\n async _getPrivateKey (name) {\n if (!validateKeyName(name)) {\n return throwDelayed(errcode(new Error(`Invalid key name '${name}'`), 'ERR_INVALID_KEY_NAME'))\n }\n\n try {\n const dsname = DsName(name)\n const res = await this.store.get(dsname)\n return uint8ArrayToString(res)\n } catch (err) {\n return throwDelayed(errcode(new Error(`Key '${name}' does not exist. ${err.message}`), 'ERR_KEY_NOT_FOUND'))\n }\n }\n\n /**\n * Rotate keychain password and re-encrypt all assosciated keys\n *\n * @param {string} oldPass - The old local keychain password\n * @param {string} newPass - The new local keychain password\n */\n async rotateKeychainPass (oldPass, newPass) {\n if (typeof oldPass !== 'string') {\n return throwDelayed(errcode(new Error(`Invalid old pass type '${typeof oldPass}'`), 'ERR_INVALID_OLD_PASS_TYPE'))\n }\n if (typeof newPass !== 'string') {\n return throwDelayed(errcode(new Error(`Invalid new pass type '${typeof newPass}'`), 'ERR_INVALID_NEW_PASS_TYPE'))\n }\n if (newPass.length < 20) {\n return throwDelayed(errcode(new Error(`Invalid pass length ${newPass.length}`), 'ERR_INVALID_PASS_LENGTH'))\n }\n log('recreating keychain')\n const oldDek = privates.get(this).dek\n this.opts.pass = newPass\n const newDek = newPass\n ? crypto.pbkdf2(\n newPass,\n this.opts.dek.salt,\n this.opts.dek.iterationCount,\n this.opts.dek.keyLength,\n this.opts.dek.hash)\n : ''\n privates.set(this, { dek: newDek })\n const keys = await this.listKeys()\n for (const key of keys) {\n const res = await this.store.get(DsName(key.name))\n const pem = uint8ArrayToString(res)\n const privateKey = await crypto.keys.import(pem, oldDek)\n const password = newDek.toString()\n const keyAsPEM = await privateKey.export(password)\n\n // Update stored key\n const batch = this.store.batch()\n const keyInfo = {\n name: key.name,\n id: key.id\n }\n batch.put(DsName(key.name), uint8ArrayFromString(keyAsPEM))\n batch.put(DsInfoName(key.name), uint8ArrayFromString(JSON.stringify(keyInfo)))\n await batch.commit()\n }\n log('keychain reconstructed')\n }\n}\n\nmodule.exports = Keychain\n","/*jshint node:true*/\n'use strict';\n\n/**\n * Replaces characters in strings that are illegal/unsafe for filenames.\n * Unsafe characters are either removed or replaced by a substitute set\n * in the optional `options` object.\n *\n * Illegal Characters on Various Operating Systems\n * / ? < > \\ : * | \"\n * https://kb.acronis.com/content/39790\n *\n * Unicode Control codes\n * C0 0x00-0x1f & C1 (0x80-0x9f)\n * http://en.wikipedia.org/wiki/C0_and_C1_control_codes\n *\n * Reserved filenames on Unix-based systems (\".\", \"..\")\n * Reserved filenames in Windows (\"CON\", \"PRN\", \"AUX\", \"NUL\", \"COM1\",\n * \"COM2\", \"COM3\", \"COM4\", \"COM5\", \"COM6\", \"COM7\", \"COM8\", \"COM9\",\n * \"LPT1\", \"LPT2\", \"LPT3\", \"LPT4\", \"LPT5\", \"LPT6\", \"LPT7\", \"LPT8\", and\n * \"LPT9\") case-insesitively and with or without filename extensions.\n *\n * Capped at 255 characters in length.\n * http://unix.stackexchange.com/questions/32795/what-is-the-maximum-allowed-filename-and-folder-size-with-ecryptfs\n *\n * @param {String} input Original filename\n * @param {Object} options {replacement: String | Function }\n * @return {String} Sanitized filename\n */\n\nvar truncate = require(\"truncate-utf8-bytes\");\n\nvar illegalRe = /[\\/\\?<>\\\\:\\*\\|\"]/g;\nvar controlRe = /[\\x00-\\x1f\\x80-\\x9f]/g;\nvar reservedRe = /^\\.+$/;\nvar windowsReservedRe = /^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\\..*)?$/i;\nvar windowsTrailingRe = /[\\. ]+$/;\n\nfunction sanitize(input, replacement) {\n if (typeof input !== 'string') {\n throw new Error('Input must be string');\n }\n var sanitized = input\n .replace(illegalRe, replacement)\n .replace(controlRe, replacement)\n .replace(reservedRe, replacement)\n .replace(windowsReservedRe, replacement)\n .replace(windowsTrailingRe, replacement);\n return truncate(sanitized, 255);\n}\n\nmodule.exports = function (input, options) {\n var replacement = (options && options.replacement) || '';\n var output = sanitize(input, replacement);\n if (replacement === '') {\n return output;\n }\n return sanitize(output, '');\n};\n","'use strict';\n\nvar truncate = require(\"./lib/truncate\");\nvar getLength = require(\"utf8-byte-length/browser\");\nmodule.exports = truncate.bind(null, getLength);\n","'use strict';\n\nfunction isHighSurrogate(codePoint) {\n return codePoint >= 0xd800 && codePoint <= 0xdbff;\n}\n\nfunction isLowSurrogate(codePoint) {\n return codePoint >= 0xdc00 && codePoint <= 0xdfff;\n}\n\n// Truncate string by size in bytes\nmodule.exports = function truncate(getLength, string, byteLength) {\n if (typeof string !== \"string\") {\n throw new Error(\"Input must be string\");\n }\n\n var charLength = string.length;\n var curByteLength = 0;\n var codePoint;\n var segment;\n\n for (var i = 0; i < charLength; i += 1) {\n codePoint = string.charCodeAt(i);\n segment = string[i];\n\n if (isHighSurrogate(codePoint) && isLowSurrogate(string.charCodeAt(i + 1))) {\n i += 1;\n segment += string[i];\n }\n\n curByteLength += getLength(segment);\n\n if (curByteLength === byteLength) {\n return string.slice(0, i + 1);\n }\n else if (curByteLength > byteLength) {\n return string.slice(0, i - segment.length + 1);\n }\n }\n\n return string;\n};\n\n","'use strict';\n\nfunction isHighSurrogate(codePoint) {\n return codePoint >= 0xd800 && codePoint <= 0xdbff;\n}\n\nfunction isLowSurrogate(codePoint) {\n return codePoint >= 0xdc00 && codePoint <= 0xdfff;\n}\n\n// Truncate string by size in bytes\nmodule.exports = function getByteLength(string) {\n if (typeof string !== \"string\") {\n throw new Error(\"Input must be string\");\n }\n\n var charLength = string.length;\n var byteLength = 0;\n var codePoint = null;\n var prevCodePoint = null;\n for (var i = 0; i < charLength; i++) {\n codePoint = string.charCodeAt(i);\n // handle 4-byte non-BMP chars\n // low surrogate\n if (isLowSurrogate(codePoint)) {\n // when parsing previous hi-surrogate, 3 is added to byteLength\n if (prevCodePoint != null && isHighSurrogate(prevCodePoint)) {\n byteLength += 1;\n }\n else {\n byteLength += 3;\n }\n }\n else if (codePoint <= 0x7f ) {\n byteLength += 1;\n }\n else if (codePoint >= 0x80 && codePoint <= 0x7ff) {\n byteLength += 2;\n }\n else if (codePoint >= 0x800 && codePoint <= 0xffff) {\n byteLength += 3;\n }\n prevCodePoint = codePoint;\n }\n\n return byteLength;\n};\n","'use strict'\n\n// @ts-ignore node-forge types not exported\nrequire('node-forge/lib/pkcs7')\n// @ts-ignore node-forge types not exported\nrequire('node-forge/lib/pbe')\n// @ts-ignore node-forge types not exported\nconst forge = require('node-forge/lib/forge')\nconst { certificateForKey, findAsync } = require('./util')\nconst errcode = require('err-code')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst { toString: uint8ArrayToString } = require('uint8arrays/to-string')\n\nconst privates = new WeakMap()\n\n/**\n * Cryptographic Message Syntax (aka PKCS #7)\n *\n * CMS describes an encapsulation syntax for data protection. It\n * is used to digitally sign, digest, authenticate, or encrypt\n * arbitrary message content.\n *\n * See RFC 5652 for all the details.\n */\nclass CMS {\n /**\n * Creates a new instance with a keychain\n *\n * @param {import('./index')} keychain - the available keys\n * @param {string} dek\n */\n constructor (keychain, dek) {\n if (!keychain) {\n throw errcode(new Error('keychain is required'), 'ERR_KEYCHAIN_REQUIRED')\n }\n\n this.keychain = keychain\n privates.set(this, { dek })\n }\n\n /**\n * Creates some protected data.\n *\n * The output Uint8Array contains the PKCS #7 message in DER.\n *\n * @param {string} name - The local key name.\n * @param {Uint8Array} plain - The data to encrypt.\n * @returns {Promise<Uint8Array>}\n */\n async encrypt (name, plain) {\n if (!(plain instanceof Uint8Array)) {\n throw errcode(new Error('Plain data must be a Uint8Array'), 'ERR_INVALID_PARAMS')\n }\n\n const key = await this.keychain.findKeyByName(name)\n const pem = await this.keychain._getPrivateKey(name)\n /** @type {string} */\n const dek = privates.get(this).dek\n const privateKey = forge.pki.decryptRsaPrivateKey(pem, dek)\n const certificate = await certificateForKey(key, privateKey)\n\n // create a p7 enveloped message\n const p7 = forge.pkcs7.createEnvelopedData()\n p7.addRecipient(certificate)\n p7.content = forge.util.createBuffer(plain)\n p7.encrypt()\n\n // convert message to DER\n const der = forge.asn1.toDer(p7.toAsn1()).getBytes()\n return uint8ArrayFromString(der, 'ascii')\n }\n\n /**\n * Reads some protected data.\n *\n * The keychain must contain one of the keys used to encrypt the data. If none of the keys\n * exists, an Error is returned with the property 'missingKeys'. It is array of key ids.\n *\n * @param {Uint8Array} cmsData - The CMS encrypted data to decrypt.\n * @returns {Promise<Uint8Array>}\n */\n async decrypt (cmsData) {\n if (!(cmsData instanceof Uint8Array)) {\n throw errcode(new Error('CMS data is required'), 'ERR_INVALID_PARAMS')\n }\n\n let cms\n try {\n const buf = forge.util.createBuffer(uint8ArrayToString(cmsData, 'ascii'))\n const obj = forge.asn1.fromDer(buf)\n // @ts-ignore not defined\n cms = forge.pkcs7.messageFromAsn1(obj)\n } catch (err) {\n throw errcode(new Error('Invalid CMS: ' + err.message), 'ERR_INVALID_CMS')\n }\n\n // Find a recipient whose key we hold. We only deal with recipient certs\n // issued by ipfs (O=ipfs).\n const recipients = cms.recipients\n // @ts-ignore cms types not defined\n .filter(r => r.issuer.find(a => a.shortName === 'O' && a.value === 'ipfs'))\n // @ts-ignore cms types not defined\n .filter(r => r.issuer.find(a => a.shortName === 'CN'))\n // @ts-ignore cms types not defined\n .map(r => {\n return {\n recipient: r,\n // @ts-ignore cms types not defined\n keyId: r.issuer.find(a => a.shortName === 'CN').value\n }\n })\n\n const r = await findAsync(recipients, async (recipient) => {\n try {\n const key = await this.keychain.findKeyById(recipient.keyId)\n if (key) return true\n } catch (err) {\n return false\n }\n return false\n })\n\n if (!r) {\n // @ts-ignore cms types not defined\n const missingKeys = recipients.map(r => r.keyId)\n throw errcode(new Error('Decryption needs one of the key(s): ' + missingKeys.join(', ')), 'ERR_MISSING_KEYS', {\n missingKeys\n })\n }\n\n const key = await this.keychain.findKeyById(r.keyId)\n\n if (!key) {\n throw errcode(new Error('No key available to decrypto'), 'ERR_NO_KEY')\n }\n\n const pem = await this.keychain._getPrivateKey(key.name)\n const dek = privates.get(this).dek\n const privateKey = forge.pki.decryptRsaPrivateKey(pem, dek)\n cms.decrypt(r.recipient, privateKey)\n return uint8ArrayFromString(cms.content.getBytes(), 'ascii')\n }\n}\n\nmodule.exports = CMS\n","/**\n * Javascript implementation of PKCS#7 v1.5.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n *\n * Currently this implementation only supports ContentType of EnvelopedData,\n * EncryptedData, or SignedData at the root level. The top level elements may\n * contain only a ContentInfo of ContentType Data, i.e. plain data. Further\n * nesting is not (yet) supported.\n *\n * The Forge validators for PKCS #7's ASN.1 structures are available from\n * a separate file pkcs7asn1.js, since those are referenced from other\n * PKCS standards like PKCS #12.\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./oids');\nrequire('./pem');\nrequire('./pkcs7asn1');\nrequire('./random');\nrequire('./util');\nrequire('./x509');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7 = module.exports = forge.pkcs7 = forge.pkcs7 || {};\n\n/**\n * Converts a PKCS#7 message from PEM format.\n *\n * @param pem the PEM-formatted PKCS#7 message.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'PKCS7') {\n var error = new Error('Could not convert PKCS#7 message from PEM; PEM ' +\n 'header type is not \"PKCS#7\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert PKCS#7 message from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body);\n\n return p7.messageFromAsn1(obj);\n};\n\n/**\n * Converts a PKCS#7 message to PEM format.\n *\n * @param msg The PKCS#7 message object\n * @param maxline The maximum characters per line, defaults to 64.\n *\n * @return The PEM-formatted PKCS#7 message.\n */\np7.messageToPem = function(msg, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var pemObj = {\n type: 'PKCS7',\n body: asn1.toDer(msg.toAsn1()).getBytes()\n };\n return forge.pem.encode(pemObj, {maxline: maxline});\n};\n\n/**\n * Converts a PKCS#7 message from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a ContentInfo.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromAsn1 = function(obj) {\n // validate root level ContentInfo and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.contentInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 message. ' +\n 'ASN.1 object is not an PKCS#7 ContentInfo.');\n error.errors = errors;\n throw error;\n }\n\n var contentType = asn1.derToOid(capture.contentType);\n var msg;\n\n switch(contentType) {\n case forge.pki.oids.envelopedData:\n msg = p7.createEnvelopedData();\n break;\n\n case forge.pki.oids.encryptedData:\n msg = p7.createEncryptedData();\n break;\n\n case forge.pki.oids.signedData:\n msg = p7.createSignedData();\n break;\n\n default:\n throw new Error('Cannot read PKCS#7 message. ContentType with OID ' +\n contentType + ' is not (yet) supported.');\n }\n\n msg.fromAsn1(capture.content.value[0]);\n return msg;\n};\n\np7.createSignedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.signedData,\n version: 1,\n certificates: [],\n crls: [],\n // TODO: add json-formatted signer stuff here?\n signers: [],\n // populated during sign()\n digestAlgorithmIdentifiers: [],\n contentInfo: null,\n signerInfos: [],\n\n fromAsn1: function(obj) {\n // validate SignedData content block and capture data.\n _fromAsn1(msg, obj, p7.asn1.signedDataValidator);\n msg.certificates = [];\n msg.crls = [];\n msg.digestAlgorithmIdentifiers = [];\n msg.contentInfo = null;\n msg.signerInfos = [];\n\n if(msg.rawCapture.certificates) {\n var certs = msg.rawCapture.certificates.value;\n for(var i = 0; i < certs.length; ++i) {\n msg.certificates.push(forge.pki.certificateFromAsn1(certs[i]));\n }\n }\n\n // TODO: parse crls\n },\n\n toAsn1: function() {\n // degenerate case with no content\n if(!msg.contentInfo) {\n msg.sign();\n }\n\n var certs = [];\n for(var i = 0; i < msg.certificates.length; ++i) {\n certs.push(forge.pki.certificateToAsn1(msg.certificates[i]));\n }\n\n var crls = [];\n // TODO: implement CRLs\n\n // [0] SignedData\n var signedData = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(msg.version).getBytes()),\n // DigestAlgorithmIdentifiers\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n msg.digestAlgorithmIdentifiers),\n // ContentInfo\n msg.contentInfo\n ])\n ]);\n if(certs.length > 0) {\n // [0] IMPLICIT ExtendedCertificatesAndCertificates OPTIONAL\n signedData.value[0].value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, certs));\n }\n if(crls.length > 0) {\n // [1] IMPLICIT CertificateRevocationLists OPTIONAL\n signedData.value[0].value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, crls));\n }\n // SignerInfos\n signedData.value[0].value.push(\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n msg.signerInfos));\n\n // ContentInfo\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(msg.type).getBytes()),\n // [0] SignedData\n signedData\n ]);\n },\n\n /**\n * Add (another) entity to list of signers.\n *\n * Note: If authenticatedAttributes are provided, then, per RFC 2315,\n * they must include at least two attributes: content type and\n * message digest. The message digest attribute value will be\n * auto-calculated during signing and will be ignored if provided.\n *\n * Here's an example of providing these two attributes:\n *\n * forge.pkcs7.createSignedData();\n * p7.addSigner({\n * issuer: cert.issuer.attributes,\n * serialNumber: cert.serialNumber,\n * key: privateKey,\n * digestAlgorithm: forge.pki.oids.sha1,\n * authenticatedAttributes: [{\n * type: forge.pki.oids.contentType,\n * value: forge.pki.oids.data\n * }, {\n * type: forge.pki.oids.messageDigest\n * }]\n * });\n *\n * TODO: Support [subjectKeyIdentifier] as signer's ID.\n *\n * @param signer the signer information:\n * key the signer's private key.\n * [certificate] a certificate containing the public key\n * associated with the signer's private key; use this option as\n * an alternative to specifying signer.issuer and\n * signer.serialNumber.\n * [issuer] the issuer attributes (eg: cert.issuer.attributes).\n * [serialNumber] the signer's certificate's serial number in\n * hexadecimal (eg: cert.serialNumber).\n * [digestAlgorithm] the message digest OID, as a string, to use\n * (eg: forge.pki.oids.sha1).\n * [authenticatedAttributes] an optional array of attributes\n * to also sign along with the content.\n */\n addSigner: function(signer) {\n var issuer = signer.issuer;\n var serialNumber = signer.serialNumber;\n if(signer.certificate) {\n var cert = signer.certificate;\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n issuer = cert.issuer.attributes;\n serialNumber = cert.serialNumber;\n }\n var key = signer.key;\n if(!key) {\n throw new Error(\n 'Could not add PKCS#7 signer; no private key specified.');\n }\n if(typeof key === 'string') {\n key = forge.pki.privateKeyFromPem(key);\n }\n\n // ensure OID known for digest algorithm\n var digestAlgorithm = signer.digestAlgorithm || forge.pki.oids.sha1;\n switch(digestAlgorithm) {\n case forge.pki.oids.sha1:\n case forge.pki.oids.sha256:\n case forge.pki.oids.sha384:\n case forge.pki.oids.sha512:\n case forge.pki.oids.md5:\n break;\n default:\n throw new Error(\n 'Could not add PKCS#7 signer; unknown message digest algorithm: ' +\n digestAlgorithm);\n }\n\n // if authenticatedAttributes is present, then the attributes\n // must contain at least PKCS #9 content-type and message-digest\n var authenticatedAttributes = signer.authenticatedAttributes || [];\n if(authenticatedAttributes.length > 0) {\n var contentType = false;\n var messageDigest = false;\n for(var i = 0; i < authenticatedAttributes.length; ++i) {\n var attr = authenticatedAttributes[i];\n if(!contentType && attr.type === forge.pki.oids.contentType) {\n contentType = true;\n if(messageDigest) {\n break;\n }\n continue;\n }\n if(!messageDigest && attr.type === forge.pki.oids.messageDigest) {\n messageDigest = true;\n if(contentType) {\n break;\n }\n continue;\n }\n }\n\n if(!contentType || !messageDigest) {\n throw new Error('Invalid signer.authenticatedAttributes. If ' +\n 'signer.authenticatedAttributes is specified, then it must ' +\n 'contain at least two attributes, PKCS #9 content-type and ' +\n 'PKCS #9 message-digest.');\n }\n }\n\n msg.signers.push({\n key: key,\n version: 1,\n issuer: issuer,\n serialNumber: serialNumber,\n digestAlgorithm: digestAlgorithm,\n signatureAlgorithm: forge.pki.oids.rsaEncryption,\n signature: null,\n authenticatedAttributes: authenticatedAttributes,\n unauthenticatedAttributes: []\n });\n },\n\n /**\n * Signs the content.\n * @param options Options to apply when signing:\n * [detached] boolean. If signing should be done in detached mode. Defaults to false.\n */\n sign: function(options) {\n options = options || {};\n // auto-generate content info\n if(typeof msg.content !== 'object' || msg.contentInfo === null) {\n // use Data ContentInfo\n msg.contentInfo = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(forge.pki.oids.data).getBytes())\n ]);\n\n // add actual content, if present\n if('content' in msg) {\n var content;\n if(msg.content instanceof forge.util.ByteBuffer) {\n content = msg.content.bytes();\n } else if(typeof msg.content === 'string') {\n content = forge.util.encodeUtf8(msg.content);\n }\n\n if (options.detached) {\n msg.detachedContent = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, content);\n } else {\n msg.contentInfo.value.push(\n // [0] EXPLICIT content\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n content)\n ]));\n }\n }\n }\n\n // no signers, return early (degenerate case for certificate container)\n if(msg.signers.length === 0) {\n return;\n }\n\n // generate digest algorithm identifiers\n var mds = addDigestAlgorithmIds();\n\n // generate signerInfos\n addSignerInfos(mds);\n },\n\n verify: function() {\n throw new Error('PKCS#7 signature verification not yet implemented.');\n },\n\n /**\n * Add a certificate.\n *\n * @param cert the certificate to add.\n */\n addCertificate: function(cert) {\n // convert from PEM\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n msg.certificates.push(cert);\n },\n\n /**\n * Add a certificate revokation list.\n *\n * @param crl the certificate revokation list to add.\n */\n addCertificateRevokationList: function(crl) {\n throw new Error('PKCS#7 CRL support not yet implemented.');\n }\n };\n return msg;\n\n function addDigestAlgorithmIds() {\n var mds = {};\n\n for(var i = 0; i < msg.signers.length; ++i) {\n var signer = msg.signers[i];\n var oid = signer.digestAlgorithm;\n if(!(oid in mds)) {\n // content digest\n mds[oid] = forge.md[forge.pki.oids[oid]].create();\n }\n if(signer.authenticatedAttributes.length === 0) {\n // no custom attributes to digest; use content message digest\n signer.md = mds[oid];\n } else {\n // custom attributes to be digested; use own message digest\n // TODO: optimize to just copy message digest state if that\n // feature is ever supported with message digests\n signer.md = forge.md[forge.pki.oids[oid]].create();\n }\n }\n\n // add unique digest algorithm identifiers\n msg.digestAlgorithmIdentifiers = [];\n for(var oid in mds) {\n msg.digestAlgorithmIdentifiers.push(\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oid).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n }\n\n return mds;\n }\n\n function addSignerInfos(mds) {\n var content;\n\n if (msg.detachedContent) {\n // Signature has been made in detached mode.\n content = msg.detachedContent;\n } else {\n // Note: ContentInfo is a SEQUENCE with 2 values, second value is\n // the content field and is optional for a ContentInfo but required here\n // since signers are present\n // get ContentInfo content\n content = msg.contentInfo.value[1];\n // skip [0] EXPLICIT content wrapper\n content = content.value[0];\n }\n\n if(!content) {\n throw new Error(\n 'Could not sign PKCS#7 message; there is no content to sign.');\n }\n\n // get ContentInfo content type\n var contentType = asn1.derToOid(msg.contentInfo.value[0].value);\n\n // serialize content\n var bytes = asn1.toDer(content);\n\n // skip identifier and length per RFC 2315 9.3\n // skip identifier (1 byte)\n bytes.getByte();\n // read and discard length bytes\n asn1.getBerValueLength(bytes);\n bytes = bytes.getBytes();\n\n // digest content DER value bytes\n for(var oid in mds) {\n mds[oid].start().update(bytes);\n }\n\n // sign content\n var signingTime = new Date();\n for(var i = 0; i < msg.signers.length; ++i) {\n var signer = msg.signers[i];\n\n if(signer.authenticatedAttributes.length === 0) {\n // if ContentInfo content type is not \"Data\", then\n // authenticatedAttributes must be present per RFC 2315\n if(contentType !== forge.pki.oids.data) {\n throw new Error(\n 'Invalid signer; authenticatedAttributes must be present ' +\n 'when the ContentInfo content type is not PKCS#7 Data.');\n }\n } else {\n // process authenticated attributes\n // [0] IMPLICIT\n signer.authenticatedAttributesAsn1 = asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n\n // per RFC 2315, attributes are to be digested using a SET container\n // not the above [0] IMPLICIT container\n var attrsAsn1 = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SET, true, []);\n\n for(var ai = 0; ai < signer.authenticatedAttributes.length; ++ai) {\n var attr = signer.authenticatedAttributes[ai];\n if(attr.type === forge.pki.oids.messageDigest) {\n // use content message digest as value\n attr.value = mds[signer.digestAlgorithm].digest();\n } else if(attr.type === forge.pki.oids.signingTime) {\n // auto-populate signing time if not already set\n if(!attr.value) {\n attr.value = signingTime;\n }\n }\n\n // convert to ASN.1 and push onto Attributes SET (for signing) and\n // onto authenticatedAttributesAsn1 to complete SignedData ASN.1\n // TODO: optimize away duplication\n attrsAsn1.value.push(_attributeToAsn1(attr));\n signer.authenticatedAttributesAsn1.value.push(_attributeToAsn1(attr));\n }\n\n // DER-serialize and digest SET OF attributes only\n bytes = asn1.toDer(attrsAsn1).getBytes();\n signer.md.start().update(bytes);\n }\n\n // sign digest\n signer.signature = signer.key.sign(signer.md, 'RSASSA-PKCS1-V1_5');\n }\n\n // add signer info\n msg.signerInfos = _signersToAsn1(msg.signers);\n }\n};\n\n/**\n * Creates an empty PKCS#7 message of type EncryptedData.\n *\n * @return the message.\n */\np7.createEncryptedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.encryptedData,\n version: 0,\n encryptedContent: {\n algorithm: forge.pki.oids['aes256-CBC']\n },\n\n /**\n * Reads an EncryptedData content block (in ASN.1 format)\n *\n * @param obj The ASN.1 representation of the EncryptedData content block\n */\n fromAsn1: function(obj) {\n // Validate EncryptedData content block and capture data.\n _fromAsn1(msg, obj, p7.asn1.encryptedDataValidator);\n },\n\n /**\n * Decrypt encrypted content\n *\n * @param key The (symmetric) key as a byte buffer\n */\n decrypt: function(key) {\n if(key !== undefined) {\n msg.encryptedContent.key = key;\n }\n _decryptContent(msg);\n }\n };\n return msg;\n};\n\n/**\n * Creates an empty PKCS#7 message of type EnvelopedData.\n *\n * @return the message.\n */\np7.createEnvelopedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.envelopedData,\n version: 0,\n recipients: [],\n encryptedContent: {\n algorithm: forge.pki.oids['aes256-CBC']\n },\n\n /**\n * Reads an EnvelopedData content block (in ASN.1 format)\n *\n * @param obj the ASN.1 representation of the EnvelopedData content block.\n */\n fromAsn1: function(obj) {\n // validate EnvelopedData content block and capture data\n var capture = _fromAsn1(msg, obj, p7.asn1.envelopedDataValidator);\n msg.recipients = _recipientsFromAsn1(capture.recipientInfos.value);\n },\n\n toAsn1: function() {\n // ContentInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(msg.type).getBytes()),\n // [0] EnvelopedData\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(msg.version).getBytes()),\n // RecipientInfos\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n _recipientsToAsn1(msg.recipients)),\n // EncryptedContentInfo\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true,\n _encryptedContentToAsn1(msg.encryptedContent))\n ])\n ])\n ]);\n },\n\n /**\n * Find recipient by X.509 certificate's issuer.\n *\n * @param cert the certificate with the issuer to look for.\n *\n * @return the recipient object.\n */\n findRecipient: function(cert) {\n var sAttr = cert.issuer.attributes;\n\n for(var i = 0; i < msg.recipients.length; ++i) {\n var r = msg.recipients[i];\n var rAttr = r.issuer;\n\n if(r.serialNumber !== cert.serialNumber) {\n continue;\n }\n\n if(rAttr.length !== sAttr.length) {\n continue;\n }\n\n var match = true;\n for(var j = 0; j < sAttr.length; ++j) {\n if(rAttr[j].type !== sAttr[j].type ||\n rAttr[j].value !== sAttr[j].value) {\n match = false;\n break;\n }\n }\n\n if(match) {\n return r;\n }\n }\n\n return null;\n },\n\n /**\n * Decrypt enveloped content\n *\n * @param recipient The recipient object related to the private key\n * @param privKey The (RSA) private key object\n */\n decrypt: function(recipient, privKey) {\n if(msg.encryptedContent.key === undefined && recipient !== undefined &&\n privKey !== undefined) {\n switch(recipient.encryptedContent.algorithm) {\n case forge.pki.oids.rsaEncryption:\n case forge.pki.oids.desCBC:\n var key = privKey.decrypt(recipient.encryptedContent.content);\n msg.encryptedContent.key = forge.util.createBuffer(key);\n break;\n\n default:\n throw new Error('Unsupported asymmetric cipher, ' +\n 'OID ' + recipient.encryptedContent.algorithm);\n }\n }\n\n _decryptContent(msg);\n },\n\n /**\n * Add (another) entity to list of recipients.\n *\n * @param cert The certificate of the entity to add.\n */\n addRecipient: function(cert) {\n msg.recipients.push({\n version: 0,\n issuer: cert.issuer.attributes,\n serialNumber: cert.serialNumber,\n encryptedContent: {\n // We simply assume rsaEncryption here, since forge.pki only\n // supports RSA so far. If the PKI module supports other\n // ciphers one day, we need to modify this one as well.\n algorithm: forge.pki.oids.rsaEncryption,\n key: cert.publicKey\n }\n });\n },\n\n /**\n * Encrypt enveloped content.\n *\n * This function supports two optional arguments, cipher and key, which\n * can be used to influence symmetric encryption. Unless cipher is\n * provided, the cipher specified in encryptedContent.algorithm is used\n * (defaults to AES-256-CBC). If no key is provided, encryptedContent.key\n * is (re-)used. If that one's not set, a random key will be generated\n * automatically.\n *\n * @param [key] The key to be used for symmetric encryption.\n * @param [cipher] The OID of the symmetric cipher to use.\n */\n encrypt: function(key, cipher) {\n // Part 1: Symmetric encryption\n if(msg.encryptedContent.content === undefined) {\n cipher = cipher || msg.encryptedContent.algorithm;\n key = key || msg.encryptedContent.key;\n\n var keyLen, ivLen, ciphFn;\n switch(cipher) {\n case forge.pki.oids['aes128-CBC']:\n keyLen = 16;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['aes192-CBC']:\n keyLen = 24;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['aes256-CBC']:\n keyLen = 32;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['des-EDE3-CBC']:\n keyLen = 24;\n ivLen = 8;\n ciphFn = forge.des.createEncryptionCipher;\n break;\n\n default:\n throw new Error('Unsupported symmetric cipher, OID ' + cipher);\n }\n\n if(key === undefined) {\n key = forge.util.createBuffer(forge.random.getBytes(keyLen));\n } else if(key.length() != keyLen) {\n throw new Error('Symmetric key has wrong length; ' +\n 'got ' + key.length() + ' bytes, expected ' + keyLen + '.');\n }\n\n // Keep a copy of the key & IV in the object, so the caller can\n // use it for whatever reason.\n msg.encryptedContent.algorithm = cipher;\n msg.encryptedContent.key = key;\n msg.encryptedContent.parameter = forge.util.createBuffer(\n forge.random.getBytes(ivLen));\n\n var ciph = ciphFn(key);\n ciph.start(msg.encryptedContent.parameter.copy());\n ciph.update(msg.content);\n\n // The finish function does PKCS#7 padding by default, therefore\n // no action required by us.\n if(!ciph.finish()) {\n throw new Error('Symmetric encryption failed.');\n }\n\n msg.encryptedContent.content = ciph.output;\n }\n\n // Part 2: asymmetric encryption for each recipient\n for(var i = 0; i < msg.recipients.length; ++i) {\n var recipient = msg.recipients[i];\n\n // Nothing to do, encryption already done.\n if(recipient.encryptedContent.content !== undefined) {\n continue;\n }\n\n switch(recipient.encryptedContent.algorithm) {\n case forge.pki.oids.rsaEncryption:\n recipient.encryptedContent.content =\n recipient.encryptedContent.key.encrypt(\n msg.encryptedContent.key.data);\n break;\n\n default:\n throw new Error('Unsupported asymmetric cipher, OID ' +\n recipient.encryptedContent.algorithm);\n }\n }\n }\n };\n return msg;\n};\n\n/**\n * Converts a single recipient from an ASN.1 object.\n *\n * @param obj the ASN.1 RecipientInfo.\n *\n * @return the recipient object.\n */\nfunction _recipientFromAsn1(obj) {\n // validate EnvelopedData content block and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.recipientInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 RecipientInfo. ' +\n 'ASN.1 object is not an PKCS#7 RecipientInfo.');\n error.errors = errors;\n throw error;\n }\n\n return {\n version: capture.version.charCodeAt(0),\n issuer: forge.pki.RDNAttributesAsArray(capture.issuer),\n serialNumber: forge.util.createBuffer(capture.serial).toHex(),\n encryptedContent: {\n algorithm: asn1.derToOid(capture.encAlgorithm),\n parameter: capture.encParameter.value,\n content: capture.encKey\n }\n };\n}\n\n/**\n * Converts a single recipient object to an ASN.1 object.\n *\n * @param obj the recipient object.\n *\n * @return the ASN.1 RecipientInfo.\n */\nfunction _recipientToAsn1(obj) {\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(obj.version).getBytes()),\n // IssuerAndSerialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Name\n forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),\n // Serial\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(obj.serialNumber))\n ]),\n // KeyEncryptionAlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.encryptedContent.algorithm).getBytes()),\n // Parameter, force NULL, only RSA supported for now.\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // EncryptedKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n obj.encryptedContent.content)\n ]);\n}\n\n/**\n * Map a set of RecipientInfo ASN.1 objects to recipient objects.\n *\n * @param infos an array of ASN.1 representations RecipientInfo (i.e. SET OF).\n *\n * @return an array of recipient objects.\n */\nfunction _recipientsFromAsn1(infos) {\n var ret = [];\n for(var i = 0; i < infos.length; ++i) {\n ret.push(_recipientFromAsn1(infos[i]));\n }\n return ret;\n}\n\n/**\n * Map an array of recipient objects to ASN.1 RecipientInfo objects.\n *\n * @param recipients an array of recipientInfo objects.\n *\n * @return an array of ASN.1 RecipientInfos.\n */\nfunction _recipientsToAsn1(recipients) {\n var ret = [];\n for(var i = 0; i < recipients.length; ++i) {\n ret.push(_recipientToAsn1(recipients[i]));\n }\n return ret;\n}\n\n/**\n * Converts a single signer from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a SignerInfo.\n *\n * @return the signer object.\n */\nfunction _signerFromAsn1(obj) {\n // validate EnvelopedData content block and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.signerInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 SignerInfo. ' +\n 'ASN.1 object is not an PKCS#7 SignerInfo.');\n error.errors = errors;\n throw error;\n }\n\n var rval = {\n version: capture.version.charCodeAt(0),\n issuer: forge.pki.RDNAttributesAsArray(capture.issuer),\n serialNumber: forge.util.createBuffer(capture.serial).toHex(),\n digestAlgorithm: asn1.derToOid(capture.digestAlgorithm),\n signatureAlgorithm: asn1.derToOid(capture.signatureAlgorithm),\n signature: capture.signature,\n authenticatedAttributes: [],\n unauthenticatedAttributes: []\n };\n\n // TODO: convert attributes\n var authenticatedAttributes = capture.authenticatedAttributes || [];\n var unauthenticatedAttributes = capture.unauthenticatedAttributes || [];\n\n return rval;\n}\n\n/**\n * Converts a single signerInfo object to an ASN.1 object.\n *\n * @param obj the signerInfo object.\n *\n * @return the ASN.1 representation of a SignerInfo.\n */\nfunction _signerToAsn1(obj) {\n // SignerInfo\n var rval = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(obj.version).getBytes()),\n // issuerAndSerialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // name\n forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),\n // serial\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(obj.serialNumber))\n ]),\n // digestAlgorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.digestAlgorithm).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ]);\n\n // authenticatedAttributes (OPTIONAL)\n if(obj.authenticatedAttributesAsn1) {\n // add ASN.1 previously generated during signing\n rval.value.push(obj.authenticatedAttributesAsn1);\n }\n\n // digestEncryptionAlgorithm\n rval.value.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.signatureAlgorithm).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n\n // encryptedDigest\n rval.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, obj.signature));\n\n // unauthenticatedAttributes (OPTIONAL)\n if(obj.unauthenticatedAttributes.length > 0) {\n // [1] IMPLICIT\n var attrsAsn1 = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, []);\n for(var i = 0; i < obj.unauthenticatedAttributes.length; ++i) {\n var attr = obj.unauthenticatedAttributes[i];\n attrsAsn1.values.push(_attributeToAsn1(attr));\n }\n rval.value.push(attrsAsn1);\n }\n\n return rval;\n}\n\n/**\n * Map a set of SignerInfo ASN.1 objects to an array of signer objects.\n *\n * @param signerInfoAsn1s an array of ASN.1 SignerInfos (i.e. SET OF).\n *\n * @return an array of signers objects.\n */\nfunction _signersFromAsn1(signerInfoAsn1s) {\n var ret = [];\n for(var i = 0; i < signerInfoAsn1s.length; ++i) {\n ret.push(_signerFromAsn1(signerInfoAsn1s[i]));\n }\n return ret;\n}\n\n/**\n * Map an array of signer objects to ASN.1 objects.\n *\n * @param signers an array of signer objects.\n *\n * @return an array of ASN.1 SignerInfos.\n */\nfunction _signersToAsn1(signers) {\n var ret = [];\n for(var i = 0; i < signers.length; ++i) {\n ret.push(_signerToAsn1(signers[i]));\n }\n return ret;\n}\n\n/**\n * Convert an attribute object to an ASN.1 Attribute.\n *\n * @param attr the attribute object.\n *\n * @return the ASN.1 Attribute.\n */\nfunction _attributeToAsn1(attr) {\n var value;\n\n // TODO: generalize to support more attributes\n if(attr.type === forge.pki.oids.contentType) {\n value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.value).getBytes());\n } else if(attr.type === forge.pki.oids.messageDigest) {\n value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n attr.value.bytes());\n } else if(attr.type === forge.pki.oids.signingTime) {\n /* Note per RFC 2985: Dates between 1 January 1950 and 31 December 2049\n (inclusive) MUST be encoded as UTCTime. Any dates with year values\n before 1950 or after 2049 MUST be encoded as GeneralizedTime. [Further,]\n UTCTime values MUST be expressed in Greenwich Mean Time (Zulu) and MUST\n include seconds (i.e., times are YYMMDDHHMMSSZ), even where the\n number of seconds is zero. Midnight (GMT) must be represented as\n \"YYMMDD000000Z\". */\n // TODO: make these module-level constants\n var jan_1_1950 = new Date('1950-01-01T00:00:00Z');\n var jan_1_2050 = new Date('2050-01-01T00:00:00Z');\n var date = attr.value;\n if(typeof date === 'string') {\n // try to parse date\n var timestamp = Date.parse(date);\n if(!isNaN(timestamp)) {\n date = new Date(timestamp);\n } else if(date.length === 13) {\n // YYMMDDHHMMSSZ (13 chars for UTCTime)\n date = asn1.utcTimeToDate(date);\n } else {\n // assume generalized time\n date = asn1.generalizedTimeToDate(date);\n }\n }\n\n if(date >= jan_1_1950 && date < jan_1_2050) {\n value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.UTCTIME, false,\n asn1.dateToUtcTime(date));\n } else {\n value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.GENERALIZEDTIME, false,\n asn1.dateToGeneralizedTime(date));\n }\n }\n\n // TODO: expose as common API call\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n // AttributeValue\n value\n ])\n ]);\n}\n\n/**\n * Map messages encrypted content to ASN.1 objects.\n *\n * @param ec The encryptedContent object of the message.\n *\n * @return ASN.1 representation of the encryptedContent object (SEQUENCE).\n */\nfunction _encryptedContentToAsn1(ec) {\n return [\n // ContentType, always Data for the moment\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(forge.pki.oids.data).getBytes()),\n // ContentEncryptionAlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(ec.algorithm).getBytes()),\n // Parameters (IV)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n ec.parameter.getBytes())\n ]),\n // [0] EncryptedContent\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n ec.content.getBytes())\n ])\n ];\n}\n\n/**\n * Reads the \"common part\" of an PKCS#7 content block (in ASN.1 format)\n *\n * This function reads the \"common part\" of the PKCS#7 content blocks\n * EncryptedData and EnvelopedData, i.e. version number and symmetrically\n * encrypted content block.\n *\n * The result of the ASN.1 validate and capture process is returned\n * to allow the caller to extract further data, e.g. the list of recipients\n * in case of a EnvelopedData object.\n *\n * @param msg the PKCS#7 object to read the data to.\n * @param obj the ASN.1 representation of the content block.\n * @param validator the ASN.1 structure validator object to use.\n *\n * @return the value map captured by validator object.\n */\nfunction _fromAsn1(msg, obj, validator) {\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, validator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 message. ' +\n 'ASN.1 object is not a supported PKCS#7 message.');\n error.errors = error;\n throw error;\n }\n\n // Check contentType, so far we only support (raw) Data.\n var contentType = asn1.derToOid(capture.contentType);\n if(contentType !== forge.pki.oids.data) {\n throw new Error('Unsupported PKCS#7 message. ' +\n 'Only wrapped ContentType Data supported.');\n }\n\n if(capture.encryptedContent) {\n var content = '';\n if(forge.util.isArray(capture.encryptedContent)) {\n for(var i = 0; i < capture.encryptedContent.length; ++i) {\n if(capture.encryptedContent[i].type !== asn1.Type.OCTETSTRING) {\n throw new Error('Malformed PKCS#7 message, expecting encrypted ' +\n 'content constructed of only OCTET STRING objects.');\n }\n content += capture.encryptedContent[i].value;\n }\n } else {\n content = capture.encryptedContent;\n }\n msg.encryptedContent = {\n algorithm: asn1.derToOid(capture.encAlgorithm),\n parameter: forge.util.createBuffer(capture.encParameter.value),\n content: forge.util.createBuffer(content)\n };\n }\n\n if(capture.content) {\n var content = '';\n if(forge.util.isArray(capture.content)) {\n for(var i = 0; i < capture.content.length; ++i) {\n if(capture.content[i].type !== asn1.Type.OCTETSTRING) {\n throw new Error('Malformed PKCS#7 message, expecting ' +\n 'content constructed of only OCTET STRING objects.');\n }\n content += capture.content[i].value;\n }\n } else {\n content = capture.content;\n }\n msg.content = forge.util.createBuffer(content);\n }\n\n msg.version = capture.version.charCodeAt(0);\n msg.rawCapture = capture;\n\n return capture;\n}\n\n/**\n * Decrypt the symmetrically encrypted content block of the PKCS#7 message.\n *\n * Decryption is skipped in case the PKCS#7 message object already has a\n * (decrypted) content attribute. The algorithm, key and cipher parameters\n * (probably the iv) are taken from the encryptedContent attribute of the\n * message object.\n *\n * @param The PKCS#7 message object.\n */\nfunction _decryptContent(msg) {\n if(msg.encryptedContent.key === undefined) {\n throw new Error('Symmetric key not available.');\n }\n\n if(msg.content === undefined) {\n var ciph;\n\n switch(msg.encryptedContent.algorithm) {\n case forge.pki.oids['aes128-CBC']:\n case forge.pki.oids['aes192-CBC']:\n case forge.pki.oids['aes256-CBC']:\n ciph = forge.aes.createDecryptionCipher(msg.encryptedContent.key);\n break;\n\n case forge.pki.oids['desCBC']:\n case forge.pki.oids['des-EDE3-CBC']:\n ciph = forge.des.createDecryptionCipher(msg.encryptedContent.key);\n break;\n\n default:\n throw new Error('Unsupported symmetric cipher, OID ' +\n msg.encryptedContent.algorithm);\n }\n ciph.start(msg.encryptedContent.parameter);\n ciph.update(msg.encryptedContent.content);\n\n if(!ciph.finish()) {\n throw new Error('Symmetric decryption failed.');\n }\n\n msg.content = ciph.output;\n }\n}\n","/**\n * Javascript implementation of ASN.1 validators for PKCS#7 v1.5.\n *\n * @author Dave Longley\n * @author Stefan Siegl\n *\n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * The ASN.1 representation of PKCS#7 is as follows\n * (see RFC #2315 for details, http://www.ietf.org/rfc/rfc2315.txt):\n *\n * A PKCS#7 message consists of a ContentInfo on root level, which may\n * contain any number of further ContentInfo nested into it.\n *\n * ContentInfo ::= SEQUENCE {\n * contentType ContentType,\n * content [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL\n * }\n *\n * ContentType ::= OBJECT IDENTIFIER\n *\n * EnvelopedData ::= SEQUENCE {\n * version Version,\n * recipientInfos RecipientInfos,\n * encryptedContentInfo EncryptedContentInfo\n * }\n *\n * EncryptedData ::= SEQUENCE {\n * version Version,\n * encryptedContentInfo EncryptedContentInfo\n * }\n *\n * id-signedData OBJECT IDENTIFIER ::= { iso(1) member-body(2)\n * us(840) rsadsi(113549) pkcs(1) pkcs7(7) 2 }\n *\n * SignedData ::= SEQUENCE {\n * version INTEGER,\n * digestAlgorithms DigestAlgorithmIdentifiers,\n * contentInfo ContentInfo,\n * certificates [0] IMPLICIT Certificates OPTIONAL,\n * crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,\n * signerInfos SignerInfos\n * }\n *\n * SignerInfos ::= SET OF SignerInfo\n *\n * SignerInfo ::= SEQUENCE {\n * version Version,\n * issuerAndSerialNumber IssuerAndSerialNumber,\n * digestAlgorithm DigestAlgorithmIdentifier,\n * authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,\n * digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,\n * encryptedDigest EncryptedDigest,\n * unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL\n * }\n *\n * EncryptedDigest ::= OCTET STRING\n *\n * Attributes ::= SET OF Attribute\n *\n * Attribute ::= SEQUENCE {\n * attrType OBJECT IDENTIFIER,\n * attrValues SET OF AttributeValue\n * }\n *\n * AttributeValue ::= ANY\n *\n * Version ::= INTEGER\n *\n * RecipientInfos ::= SET OF RecipientInfo\n *\n * EncryptedContentInfo ::= SEQUENCE {\n * contentType ContentType,\n * contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,\n * encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL\n * }\n *\n * ContentEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of AES and DES3, there is only one,\n * the IV.\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * EncryptedContent ::= OCTET STRING\n *\n * RecipientInfo ::= SEQUENCE {\n * version Version,\n * issuerAndSerialNumber IssuerAndSerialNumber,\n * keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,\n * encryptedKey EncryptedKey\n * }\n *\n * IssuerAndSerialNumber ::= SEQUENCE {\n * issuer Name,\n * serialNumber CertificateSerialNumber\n * }\n *\n * CertificateSerialNumber ::= INTEGER\n *\n * KeyEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * EncryptedKey ::= OCTET STRING\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./util');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7v = module.exports = forge.pkcs7asn1 = forge.pkcs7asn1 || {};\nforge.pkcs7 = forge.pkcs7 || {};\nforge.pkcs7.asn1 = p7v;\n\nvar contentInfoValidator = {\n name: 'ContentInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'ContentInfo.ContentType',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'contentType'\n }, {\n name: 'ContentInfo.content',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n captureAsn1: 'content'\n }]\n};\np7v.contentInfoValidator = contentInfoValidator;\n\nvar encryptedContentInfoValidator = {\n name: 'EncryptedContentInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedContentInfo.contentType',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'contentType'\n }, {\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encAlgorithm'\n }, {\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n captureAsn1: 'encParameter'\n }]\n }, {\n name: 'EncryptedContentInfo.encryptedContent',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n /* The PKCS#7 structure output by OpenSSL somewhat differs from what\n * other implementations do generate.\n *\n * OpenSSL generates a structure like this:\n * SEQUENCE {\n * ...\n * [0]\n * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n * ...\n * }\n *\n * Whereas other implementations (and this PKCS#7 module) generate:\n * SEQUENCE {\n * ...\n * [0] {\n * OCTET STRING\n * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n * ...\n * }\n * }\n *\n * In order to support both, we just capture the context specific\n * field here. The OCTET STRING bit is removed below.\n */\n capture: 'encryptedContent',\n captureAsn1: 'encryptedContentAsn1'\n }]\n};\n\np7v.envelopedDataValidator = {\n name: 'EnvelopedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EnvelopedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'EnvelopedData.RecipientInfos',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n captureAsn1: 'recipientInfos'\n }].concat(encryptedContentInfoValidator)\n};\n\np7v.encryptedDataValidator = {\n name: 'EncryptedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }].concat(encryptedContentInfoValidator)\n};\n\nvar signerValidator = {\n name: 'SignerInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false\n }, {\n name: 'SignerInfo.issuerAndSerialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.issuerAndSerialNumber.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'issuer'\n }, {\n name: 'SignerInfo.issuerAndSerialNumber.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'serial'\n }]\n }, {\n name: 'SignerInfo.digestAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.digestAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'digestAlgorithm'\n }, {\n name: 'SignerInfo.digestAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n constructed: false,\n captureAsn1: 'digestParameter',\n optional: true\n }]\n }, {\n name: 'SignerInfo.authenticatedAttributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n capture: 'authenticatedAttributes'\n }, {\n name: 'SignerInfo.digestEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n capture: 'signatureAlgorithm'\n }, {\n name: 'SignerInfo.encryptedDigest',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'signature'\n }, {\n name: 'SignerInfo.unauthenticatedAttributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n optional: true,\n capture: 'unauthenticatedAttributes'\n }]\n};\n\np7v.signedDataValidator = {\n name: 'SignedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'SignedData.DigestAlgorithms',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n captureAsn1: 'digestAlgorithms'\n },\n contentInfoValidator,\n {\n name: 'SignedData.Certificates',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n optional: true,\n captureAsn1: 'certificates'\n }, {\n name: 'SignedData.CertificateRevocationLists',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n optional: true,\n captureAsn1: 'crls'\n }, {\n name: 'SignedData.SignerInfos',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n capture: 'signerInfos',\n optional: true,\n value: [signerValidator]\n }]\n};\n\np7v.recipientInfoValidator = {\n name: 'RecipientInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'RecipientInfo.issuerAndSerial',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.issuerAndSerial.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'issuer'\n }, {\n name: 'RecipientInfo.issuerAndSerial.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'serial'\n }]\n }, {\n name: 'RecipientInfo.keyEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.keyEncryptionAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encAlgorithm'\n }, {\n name: 'RecipientInfo.keyEncryptionAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n constructed: false,\n captureAsn1: 'encParameter'\n }]\n }, {\n name: 'RecipientInfo.encryptedKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encKey'\n }]\n};\n","/**\n * Javascript implementation of X.509 and related components (such as\n * Certification Signing Requests) of a Public Key Infrastructure.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n *\n * The ASN.1 representation of an X.509v3 certificate is as follows\n * (see RFC 2459):\n *\n * Certificate ::= SEQUENCE {\n * tbsCertificate TBSCertificate,\n * signatureAlgorithm AlgorithmIdentifier,\n * signatureValue BIT STRING\n * }\n *\n * TBSCertificate ::= SEQUENCE {\n * version [0] EXPLICIT Version DEFAULT v1,\n * serialNumber CertificateSerialNumber,\n * signature AlgorithmIdentifier,\n * issuer Name,\n * validity Validity,\n * subject Name,\n * subjectPublicKeyInfo SubjectPublicKeyInfo,\n * issuerUniqueID [1] IMPLICIT UniqueIdentifier OPTIONAL,\n * -- If present, version shall be v2 or v3\n * subjectUniqueID [2] IMPLICIT UniqueIdentifier OPTIONAL,\n * -- If present, version shall be v2 or v3\n * extensions [3] EXPLICIT Extensions OPTIONAL\n * -- If present, version shall be v3\n * }\n *\n * Version ::= INTEGER { v1(0), v2(1), v3(2) }\n *\n * CertificateSerialNumber ::= INTEGER\n *\n * Name ::= CHOICE {\n * // only one possible choice for now\n * RDNSequence\n * }\n *\n * RDNSequence ::= SEQUENCE OF RelativeDistinguishedName\n *\n * RelativeDistinguishedName ::= SET OF AttributeTypeAndValue\n *\n * AttributeTypeAndValue ::= SEQUENCE {\n * type AttributeType,\n * value AttributeValue\n * }\n * AttributeType ::= OBJECT IDENTIFIER\n * AttributeValue ::= ANY DEFINED BY AttributeType\n *\n * Validity ::= SEQUENCE {\n * notBefore Time,\n * notAfter Time\n * }\n *\n * Time ::= CHOICE {\n * utcTime UTCTime,\n * generalTime GeneralizedTime\n * }\n *\n * UniqueIdentifier ::= BIT STRING\n *\n * SubjectPublicKeyInfo ::= SEQUENCE {\n * algorithm AlgorithmIdentifier,\n * subjectPublicKey BIT STRING\n * }\n *\n * Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension\n *\n * Extension ::= SEQUENCE {\n * extnID OBJECT IDENTIFIER,\n * critical BOOLEAN DEFAULT FALSE,\n * extnValue OCTET STRING\n * }\n *\n * The only key algorithm currently supported for PKI is RSA.\n *\n * RSASSA-PSS signatures are described in RFC 3447 and RFC 4055.\n *\n * PKCS#10 v1.7 describes certificate signing requests:\n *\n * CertificationRequestInfo:\n *\n * CertificationRequestInfo ::= SEQUENCE {\n * version INTEGER { v1(0) } (v1,...),\n * subject Name,\n * subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},\n * attributes [0] Attributes{{ CRIAttributes }}\n * }\n *\n * Attributes { ATTRIBUTE:IOSet } ::= SET OF Attribute{{ IOSet }}\n *\n * CRIAttributes ATTRIBUTE ::= {\n * ... -- add any locally defined attributes here -- }\n *\n * Attribute { ATTRIBUTE:IOSet } ::= SEQUENCE {\n * type ATTRIBUTE.&id({IOSet}),\n * values SET SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{@type})\n * }\n *\n * CertificationRequest ::= SEQUENCE {\n * certificationRequestInfo CertificationRequestInfo,\n * signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},\n * signature BIT STRING\n * }\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./md');\nrequire('./mgf');\nrequire('./oids');\nrequire('./pem');\nrequire('./pss');\nrequire('./rsa');\nrequire('./util');\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n/* Public Key Infrastructure (PKI) implementation. */\nvar pki = module.exports = forge.pki = forge.pki || {};\nvar oids = pki.oids;\n\n// short name OID mappings\nvar _shortNames = {};\n_shortNames['CN'] = oids['commonName'];\n_shortNames['commonName'] = 'CN';\n_shortNames['C'] = oids['countryName'];\n_shortNames['countryName'] = 'C';\n_shortNames['L'] = oids['localityName'];\n_shortNames['localityName'] = 'L';\n_shortNames['ST'] = oids['stateOrProvinceName'];\n_shortNames['stateOrProvinceName'] = 'ST';\n_shortNames['O'] = oids['organizationName'];\n_shortNames['organizationName'] = 'O';\n_shortNames['OU'] = oids['organizationalUnitName'];\n_shortNames['organizationalUnitName'] = 'OU';\n_shortNames['E'] = oids['emailAddress'];\n_shortNames['emailAddress'] = 'E';\n\n// validator for an SubjectPublicKeyInfo structure\n// Note: Currently only works with an RSA public key\nvar publicKeyValidator = forge.pki.rsa.publicKeyValidator;\n\n// validator for an X.509v3 certificate\nvar x509CertificateValidator = {\n name: 'Certificate',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'Certificate.TBSCertificate',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'tbsCertificate',\n value: [{\n name: 'Certificate.TBSCertificate.version',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n value: [{\n name: 'Certificate.TBSCertificate.version.integer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'certVersion'\n }]\n }, {\n name: 'Certificate.TBSCertificate.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'certSerialNumber'\n }, {\n name: 'Certificate.TBSCertificate.signature',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'Certificate.TBSCertificate.signature.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'certinfoSignatureOid'\n }, {\n name: 'Certificate.TBSCertificate.signature.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: 'certinfoSignatureParams'\n }]\n }, {\n name: 'Certificate.TBSCertificate.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certIssuer'\n }, {\n name: 'Certificate.TBSCertificate.validity',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n // Note: UTC and generalized times may both appear so the capture\n // names are based on their detected order, the names used below\n // are only for the common case, which validity time really means\n // \"notBefore\" and which means \"notAfter\" will be determined by order\n value: [{\n // notBefore (Time) (UTC time case)\n name: 'Certificate.TBSCertificate.validity.notBefore (utc)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.UTCTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity1UTCTime'\n }, {\n // notBefore (Time) (generalized time case)\n name: 'Certificate.TBSCertificate.validity.notBefore (generalized)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.GENERALIZEDTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity2GeneralizedTime'\n }, {\n // notAfter (Time) (only UTC time is supported)\n name: 'Certificate.TBSCertificate.validity.notAfter (utc)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.UTCTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity3UTCTime'\n }, {\n // notAfter (Time) (only UTC time is supported)\n name: 'Certificate.TBSCertificate.validity.notAfter (generalized)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.GENERALIZEDTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity4GeneralizedTime'\n }]\n }, {\n // Name (subject) (RDNSequence)\n name: 'Certificate.TBSCertificate.subject',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certSubject'\n },\n // SubjectPublicKeyInfo\n publicKeyValidator,\n {\n // issuerUniqueID (optional)\n name: 'Certificate.TBSCertificate.issuerUniqueID',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n optional: true,\n value: [{\n name: 'Certificate.TBSCertificate.issuerUniqueID.id',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n // TODO: support arbitrary bit length ids\n captureBitStringValue: 'certIssuerUniqueId'\n }]\n }, {\n // subjectUniqueID (optional)\n name: 'Certificate.TBSCertificate.subjectUniqueID',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 2,\n constructed: true,\n optional: true,\n value: [{\n name: 'Certificate.TBSCertificate.subjectUniqueID.id',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n // TODO: support arbitrary bit length ids\n captureBitStringValue: 'certSubjectUniqueId'\n }]\n }, {\n // Extensions (optional)\n name: 'Certificate.TBSCertificate.extensions',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 3,\n constructed: true,\n captureAsn1: 'certExtensions',\n optional: true\n }]\n }, {\n // AlgorithmIdentifier (signature algorithm)\n name: 'Certificate.signatureAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // algorithm\n name: 'Certificate.signatureAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'certSignatureOid'\n }, {\n name: 'Certificate.TBSCertificate.signature.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: 'certSignatureParams'\n }]\n }, {\n // SignatureValue\n name: 'Certificate.signatureValue',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n captureBitStringValue: 'certSignature'\n }]\n};\n\nvar rsassaPssParameterValidator = {\n name: 'rsapss',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'rsapss.hashAlgorithm',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n value: [{\n name: 'rsapss.hashAlgorithm.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.SEQUENCE,\n constructed: true,\n optional: true,\n value: [{\n name: 'rsapss.hashAlgorithm.AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'hashOid'\n /* parameter block omitted, for SHA1 NULL anyhow. */\n }]\n }]\n }, {\n name: 'rsapss.maskGenAlgorithm',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n value: [{\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.SEQUENCE,\n constructed: true,\n optional: true,\n value: [{\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'maskGenOid'\n }, {\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier.params',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier.params.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'maskGenHashOid'\n /* parameter block omitted, for SHA1 NULL anyhow. */\n }]\n }]\n }]\n }, {\n name: 'rsapss.saltLength',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 2,\n optional: true,\n value: [{\n name: 'rsapss.saltLength.saltLength',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.INTEGER,\n constructed: false,\n capture: 'saltLength'\n }]\n }, {\n name: 'rsapss.trailerField',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 3,\n optional: true,\n value: [{\n name: 'rsapss.trailer.trailer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.INTEGER,\n constructed: false,\n capture: 'trailer'\n }]\n }]\n};\n\n// validator for a CertificationRequestInfo structure\nvar certificationRequestInfoValidator = {\n name: 'CertificationRequestInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certificationRequestInfo',\n value: [{\n name: 'CertificationRequestInfo.integer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'certificationRequestInfoVersion'\n }, {\n // Name (subject) (RDNSequence)\n name: 'CertificationRequestInfo.subject',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certificationRequestInfoSubject'\n },\n // SubjectPublicKeyInfo\n publicKeyValidator,\n {\n name: 'CertificationRequestInfo.attributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n capture: 'certificationRequestInfoAttributes',\n value: [{\n name: 'CertificationRequestInfo.attributes',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'CertificationRequestInfo.attributes.type',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false\n }, {\n name: 'CertificationRequestInfo.attributes.value',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true\n }]\n }]\n }]\n};\n\n// validator for a CertificationRequest structure\nvar certificationRequestValidator = {\n name: 'CertificationRequest',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'csr',\n value: [\n certificationRequestInfoValidator, {\n // AlgorithmIdentifier (signature algorithm)\n name: 'CertificationRequest.signatureAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // algorithm\n name: 'CertificationRequest.signatureAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'csrSignatureOid'\n }, {\n name: 'CertificationRequest.signatureAlgorithm.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: 'csrSignatureParams'\n }]\n }, {\n // signature\n name: 'CertificationRequest.signature',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n captureBitStringValue: 'csrSignature'\n }\n ]\n};\n\n/**\n * Converts an RDNSequence of ASN.1 DER-encoded RelativeDistinguishedName\n * sets into an array with objects that have type and value properties.\n *\n * @param rdn the RDNSequence to convert.\n * @param md a message digest to append type and value to if provided.\n */\npki.RDNAttributesAsArray = function(rdn, md) {\n var rval = [];\n\n // each value in 'rdn' in is a SET of RelativeDistinguishedName\n var set, attr, obj;\n for(var si = 0; si < rdn.value.length; ++si) {\n // get the RelativeDistinguishedName set\n set = rdn.value[si];\n\n // each value in the SET is an AttributeTypeAndValue sequence\n // containing first a type (an OID) and second a value (defined by\n // the OID)\n for(var i = 0; i < set.value.length; ++i) {\n obj = {};\n attr = set.value[i];\n obj.type = asn1.derToOid(attr.value[0].value);\n obj.value = attr.value[1].value;\n obj.valueTagClass = attr.value[1].type;\n // if the OID is known, get its name and short name\n if(obj.type in oids) {\n obj.name = oids[obj.type];\n if(obj.name in _shortNames) {\n obj.shortName = _shortNames[obj.name];\n }\n }\n if(md) {\n md.update(obj.type);\n md.update(obj.value);\n }\n rval.push(obj);\n }\n }\n\n return rval;\n};\n\n/**\n * Converts ASN.1 CRIAttributes into an array with objects that have type and\n * value properties.\n *\n * @param attributes the CRIAttributes to convert.\n */\npki.CRIAttributesAsArray = function(attributes) {\n var rval = [];\n\n // each value in 'attributes' in is a SEQUENCE with an OID and a SET\n for(var si = 0; si < attributes.length; ++si) {\n // get the attribute sequence\n var seq = attributes[si];\n\n // each value in the SEQUENCE containing first a type (an OID) and\n // second a set of values (defined by the OID)\n var type = asn1.derToOid(seq.value[0].value);\n var values = seq.value[1].value;\n for(var vi = 0; vi < values.length; ++vi) {\n var obj = {};\n obj.type = type;\n obj.value = values[vi].value;\n obj.valueTagClass = values[vi].type;\n // if the OID is known, get its name and short name\n if(obj.type in oids) {\n obj.name = oids[obj.type];\n if(obj.name in _shortNames) {\n obj.shortName = _shortNames[obj.name];\n }\n }\n // parse extensions\n if(obj.type === oids.extensionRequest) {\n obj.extensions = [];\n for(var ei = 0; ei < obj.value.length; ++ei) {\n obj.extensions.push(pki.certificateExtensionFromAsn1(obj.value[ei]));\n }\n }\n rval.push(obj);\n }\n }\n\n return rval;\n};\n\n/**\n * Gets an issuer or subject attribute from its name, type, or short name.\n *\n * @param obj the issuer or subject object.\n * @param options a short name string or an object with:\n * shortName the short name for the attribute.\n * name the name for the attribute.\n * type the type for the attribute.\n *\n * @return the attribute.\n */\nfunction _getAttribute(obj, options) {\n if(typeof options === 'string') {\n options = {shortName: options};\n }\n\n var rval = null;\n var attr;\n for(var i = 0; rval === null && i < obj.attributes.length; ++i) {\n attr = obj.attributes[i];\n if(options.type && options.type === attr.type) {\n rval = attr;\n } else if(options.name && options.name === attr.name) {\n rval = attr;\n } else if(options.shortName && options.shortName === attr.shortName) {\n rval = attr;\n }\n }\n return rval;\n}\n\n/**\n * Converts signature parameters from ASN.1 structure.\n *\n * Currently only RSASSA-PSS supported. The PKCS#1 v1.5 signature scheme had\n * no parameters.\n *\n * RSASSA-PSS-params ::= SEQUENCE {\n * hashAlgorithm [0] HashAlgorithm DEFAULT\n * sha1Identifier,\n * maskGenAlgorithm [1] MaskGenAlgorithm DEFAULT\n * mgf1SHA1Identifier,\n * saltLength [2] INTEGER DEFAULT 20,\n * trailerField [3] INTEGER DEFAULT 1\n * }\n *\n * HashAlgorithm ::= AlgorithmIdentifier\n *\n * MaskGenAlgorithm ::= AlgorithmIdentifier\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * @param oid The OID specifying the signature algorithm\n * @param obj The ASN.1 structure holding the parameters\n * @param fillDefaults Whether to use return default values where omitted\n * @return signature parameter object\n */\nvar _readSignatureParameters = function(oid, obj, fillDefaults) {\n var params = {};\n\n if(oid !== oids['RSASSA-PSS']) {\n return params;\n }\n\n if(fillDefaults) {\n params = {\n hash: {\n algorithmOid: oids['sha1']\n },\n mgf: {\n algorithmOid: oids['mgf1'],\n hash: {\n algorithmOid: oids['sha1']\n }\n },\n saltLength: 20\n };\n }\n\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, rsassaPssParameterValidator, capture, errors)) {\n var error = new Error('Cannot read RSASSA-PSS parameter block.');\n error.errors = errors;\n throw error;\n }\n\n if(capture.hashOid !== undefined) {\n params.hash = params.hash || {};\n params.hash.algorithmOid = asn1.derToOid(capture.hashOid);\n }\n\n if(capture.maskGenOid !== undefined) {\n params.mgf = params.mgf || {};\n params.mgf.algorithmOid = asn1.derToOid(capture.maskGenOid);\n params.mgf.hash = params.mgf.hash || {};\n params.mgf.hash.algorithmOid = asn1.derToOid(capture.maskGenHashOid);\n }\n\n if(capture.saltLength !== undefined) {\n params.saltLength = capture.saltLength.charCodeAt(0);\n }\n\n return params;\n};\n\n/**\n * Converts an X.509 certificate from PEM format.\n *\n * Note: If the certificate is to be verified then compute hash should\n * be set to true. This will scan the TBSCertificate part of the ASN.1\n * object while it is converted so it doesn't need to be converted back\n * to ASN.1-DER-encoding later.\n *\n * @param pem the PEM-formatted certificate.\n * @param computeHash true to compute the hash for verification.\n * @param strict true to be strict when checking ASN.1 value lengths, false to\n * allow truncated values (default: true).\n *\n * @return the certificate.\n */\npki.certificateFromPem = function(pem, computeHash, strict) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'CERTIFICATE' &&\n msg.type !== 'X509 CERTIFICATE' &&\n msg.type !== 'TRUSTED CERTIFICATE') {\n var error = new Error(\n 'Could not convert certificate from PEM; PEM header type ' +\n 'is not \"CERTIFICATE\", \"X509 CERTIFICATE\", or \"TRUSTED CERTIFICATE\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error(\n 'Could not convert certificate from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body, strict);\n\n return pki.certificateFromAsn1(obj, computeHash);\n};\n\n/**\n * Converts an X.509 certificate to PEM format.\n *\n * @param cert the certificate.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted certificate.\n */\npki.certificateToPem = function(cert, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'CERTIFICATE',\n body: asn1.toDer(pki.certificateToAsn1(cert)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts an RSA public key from PEM format.\n *\n * @param pem the PEM-formatted public key.\n *\n * @return the public key.\n */\npki.publicKeyFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'PUBLIC KEY' && msg.type !== 'RSA PUBLIC KEY') {\n var error = new Error('Could not convert public key from PEM; PEM header ' +\n 'type is not \"PUBLIC KEY\" or \"RSA PUBLIC KEY\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert public key from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body);\n\n return pki.publicKeyFromAsn1(obj);\n};\n\n/**\n * Converts an RSA public key to PEM format (using a SubjectPublicKeyInfo).\n *\n * @param key the public key.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted public key.\n */\npki.publicKeyToPem = function(key, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'PUBLIC KEY',\n body: asn1.toDer(pki.publicKeyToAsn1(key)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts an RSA public key to PEM format (using an RSAPublicKey).\n *\n * @param key the public key.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted public key.\n */\npki.publicKeyToRSAPublicKeyPem = function(key, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'RSA PUBLIC KEY',\n body: asn1.toDer(pki.publicKeyToRSAPublicKey(key)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Gets a fingerprint for the given public key.\n *\n * @param options the options to use.\n * [md] the message digest object to use (defaults to forge.md.sha1).\n * [type] the type of fingerprint, such as 'RSAPublicKey',\n * 'SubjectPublicKeyInfo' (defaults to 'RSAPublicKey').\n * [encoding] an alternative output encoding, such as 'hex'\n * (defaults to none, outputs a byte buffer).\n * [delimiter] the delimiter to use between bytes for 'hex' encoded\n * output, eg: ':' (defaults to none).\n *\n * @return the fingerprint as a byte buffer or other encoding based on options.\n */\npki.getPublicKeyFingerprint = function(key, options) {\n options = options || {};\n var md = options.md || forge.md.sha1.create();\n var type = options.type || 'RSAPublicKey';\n\n var bytes;\n switch(type) {\n case 'RSAPublicKey':\n bytes = asn1.toDer(pki.publicKeyToRSAPublicKey(key)).getBytes();\n break;\n case 'SubjectPublicKeyInfo':\n bytes = asn1.toDer(pki.publicKeyToAsn1(key)).getBytes();\n break;\n default:\n throw new Error('Unknown fingerprint type \"' + options.type + '\".');\n }\n\n // hash public key bytes\n md.start();\n md.update(bytes);\n var digest = md.digest();\n if(options.encoding === 'hex') {\n var hex = digest.toHex();\n if(options.delimiter) {\n return hex.match(/.{2}/g).join(options.delimiter);\n }\n return hex;\n } else if(options.encoding === 'binary') {\n return digest.getBytes();\n } else if(options.encoding) {\n throw new Error('Unknown encoding \"' + options.encoding + '\".');\n }\n return digest;\n};\n\n/**\n * Converts a PKCS#10 certification request (CSR) from PEM format.\n *\n * Note: If the certification request is to be verified then compute hash\n * should be set to true. This will scan the CertificationRequestInfo part of\n * the ASN.1 object while it is converted so it doesn't need to be converted\n * back to ASN.1-DER-encoding later.\n *\n * @param pem the PEM-formatted certificate.\n * @param computeHash true to compute the hash for verification.\n * @param strict true to be strict when checking ASN.1 value lengths, false to\n * allow truncated values (default: true).\n *\n * @return the certification request (CSR).\n */\npki.certificationRequestFromPem = function(pem, computeHash, strict) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'CERTIFICATE REQUEST') {\n var error = new Error('Could not convert certification request from PEM; ' +\n 'PEM header type is not \"CERTIFICATE REQUEST\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert certification request from PEM; ' +\n 'PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body, strict);\n\n return pki.certificationRequestFromAsn1(obj, computeHash);\n};\n\n/**\n * Converts a PKCS#10 certification request (CSR) to PEM format.\n *\n * @param csr the certification request.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted certification request.\n */\npki.certificationRequestToPem = function(csr, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'CERTIFICATE REQUEST',\n body: asn1.toDer(pki.certificationRequestToAsn1(csr)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Creates an empty X.509v3 RSA certificate.\n *\n * @return the certificate.\n */\npki.createCertificate = function() {\n var cert = {};\n cert.version = 0x02;\n cert.serialNumber = '00';\n cert.signatureOid = null;\n cert.signature = null;\n cert.siginfo = {};\n cert.siginfo.algorithmOid = null;\n cert.validity = {};\n cert.validity.notBefore = new Date();\n cert.validity.notAfter = new Date();\n\n cert.issuer = {};\n cert.issuer.getField = function(sn) {\n return _getAttribute(cert.issuer, sn);\n };\n cert.issuer.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.issuer.attributes.push(attr);\n };\n cert.issuer.attributes = [];\n cert.issuer.hash = null;\n\n cert.subject = {};\n cert.subject.getField = function(sn) {\n return _getAttribute(cert.subject, sn);\n };\n cert.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.subject.attributes.push(attr);\n };\n cert.subject.attributes = [];\n cert.subject.hash = null;\n\n cert.extensions = [];\n cert.publicKey = null;\n cert.md = null;\n\n /**\n * Sets the subject of this certificate.\n *\n * @param attrs the array of subject attributes to use.\n * @param uniqueId an optional a unique ID to use.\n */\n cert.setSubject = function(attrs, uniqueId) {\n // set new attributes, clear hash\n _fillMissingFields(attrs);\n cert.subject.attributes = attrs;\n delete cert.subject.uniqueId;\n if(uniqueId) {\n // TODO: support arbitrary bit length ids\n cert.subject.uniqueId = uniqueId;\n }\n cert.subject.hash = null;\n };\n\n /**\n * Sets the issuer of this certificate.\n *\n * @param attrs the array of issuer attributes to use.\n * @param uniqueId an optional a unique ID to use.\n */\n cert.setIssuer = function(attrs, uniqueId) {\n // set new attributes, clear hash\n _fillMissingFields(attrs);\n cert.issuer.attributes = attrs;\n delete cert.issuer.uniqueId;\n if(uniqueId) {\n // TODO: support arbitrary bit length ids\n cert.issuer.uniqueId = uniqueId;\n }\n cert.issuer.hash = null;\n };\n\n /**\n * Sets the extensions of this certificate.\n *\n * @param exts the array of extensions to use.\n */\n cert.setExtensions = function(exts) {\n for(var i = 0; i < exts.length; ++i) {\n _fillMissingExtensionFields(exts[i], {cert: cert});\n }\n // set new extensions\n cert.extensions = exts;\n };\n\n /**\n * Gets an extension by its name or id.\n *\n * @param options the name to use or an object with:\n * name the name to use.\n * id the id to use.\n *\n * @return the extension or null if not found.\n */\n cert.getExtension = function(options) {\n if(typeof options === 'string') {\n options = {name: options};\n }\n\n var rval = null;\n var ext;\n for(var i = 0; rval === null && i < cert.extensions.length; ++i) {\n ext = cert.extensions[i];\n if(options.id && ext.id === options.id) {\n rval = ext;\n } else if(options.name && ext.name === options.name) {\n rval = ext;\n }\n }\n return rval;\n };\n\n /**\n * Signs this certificate using the given private key.\n *\n * @param key the private key to sign with.\n * @param md the message digest object to use (defaults to forge.md.sha1).\n */\n cert.sign = function(key, md) {\n // TODO: get signature OID from private key\n cert.md = md || forge.md.sha1.create();\n var algorithmOid = oids[cert.md.algorithm + 'WithRSAEncryption'];\n if(!algorithmOid) {\n var error = new Error('Could not compute certificate digest. ' +\n 'Unknown message digest algorithm OID.');\n error.algorithm = cert.md.algorithm;\n throw error;\n }\n cert.signatureOid = cert.siginfo.algorithmOid = algorithmOid;\n\n // get TBSCertificate, convert to DER\n cert.tbsCertificate = pki.getTBSCertificate(cert);\n var bytes = asn1.toDer(cert.tbsCertificate);\n\n // digest and sign\n cert.md.update(bytes.getBytes());\n cert.signature = key.sign(cert.md);\n };\n\n /**\n * Attempts verify the signature on the passed certificate using this\n * certificate's public key.\n *\n * @param child the certificate to verify.\n *\n * @return true if verified, false if not.\n */\n cert.verify = function(child) {\n var rval = false;\n\n if(!cert.issued(child)) {\n var issuer = child.issuer;\n var subject = cert.subject;\n var error = new Error(\n 'The parent certificate did not issue the given child ' +\n 'certificate; the child certificate\\'s issuer does not match the ' +\n 'parent\\'s subject.');\n error.expectedIssuer = issuer.attributes;\n error.actualIssuer = subject.attributes;\n throw error;\n }\n\n var md = child.md;\n if(md === null) {\n // check signature OID for supported signature types\n if(child.signatureOid in oids) {\n var oid = oids[child.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n md = forge.md.sha256.create();\n break;\n }\n }\n if(md === null) {\n var error = new Error('Could not compute certificate digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = child.signatureOid;\n throw error;\n }\n\n // produce DER formatted TBSCertificate and digest it\n var tbsCertificate = child.tbsCertificate || pki.getTBSCertificate(child);\n var bytes = asn1.toDer(tbsCertificate);\n md.update(bytes.getBytes());\n }\n\n if(md !== null) {\n var scheme;\n\n switch(child.signatureOid) {\n case oids.sha1WithRSAEncryption:\n scheme = undefined; /* use PKCS#1 v1.5 padding scheme */\n break;\n case oids['RSASSA-PSS']:\n var hash, mgf;\n\n /* initialize mgf */\n hash = oids[child.signatureParameters.mgf.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported MGF hash function.');\n error.oid = child.signatureParameters.mgf.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n mgf = oids[child.signatureParameters.mgf.algorithmOid];\n if(mgf === undefined || forge.mgf[mgf] === undefined) {\n var error = new Error('Unsupported MGF function.');\n error.oid = child.signatureParameters.mgf.algorithmOid;\n error.name = mgf;\n throw error;\n }\n\n mgf = forge.mgf[mgf].create(forge.md[hash].create());\n\n /* initialize hash function */\n hash = oids[child.signatureParameters.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n throw {\n message: 'Unsupported RSASSA-PSS hash function.',\n oid: child.signatureParameters.hash.algorithmOid,\n name: hash\n };\n }\n\n scheme = forge.pss.create(forge.md[hash].create(), mgf,\n child.signatureParameters.saltLength);\n break;\n }\n\n // verify signature on cert using public key\n rval = cert.publicKey.verify(\n md.digest().getBytes(), child.signature, scheme);\n }\n\n return rval;\n };\n\n /**\n * Returns true if this certificate's issuer matches the passed\n * certificate's subject. Note that no signature check is performed.\n *\n * @param parent the certificate to check.\n *\n * @return true if this certificate's issuer matches the passed certificate's\n * subject.\n */\n cert.isIssuer = function(parent) {\n var rval = false;\n\n var i = cert.issuer;\n var s = parent.subject;\n\n // compare hashes if present\n if(i.hash && s.hash) {\n rval = (i.hash === s.hash);\n } else if(i.attributes.length === s.attributes.length) {\n // all attributes are the same so issuer matches subject\n rval = true;\n var iattr, sattr;\n for(var n = 0; rval && n < i.attributes.length; ++n) {\n iattr = i.attributes[n];\n sattr = s.attributes[n];\n if(iattr.type !== sattr.type || iattr.value !== sattr.value) {\n // attribute mismatch\n rval = false;\n }\n }\n }\n\n return rval;\n };\n\n /**\n * Returns true if this certificate's subject matches the issuer of the\n * given certificate). Note that not signature check is performed.\n *\n * @param child the certificate to check.\n *\n * @return true if this certificate's subject matches the passed\n * certificate's issuer.\n */\n cert.issued = function(child) {\n return child.isIssuer(cert);\n };\n\n /**\n * Generates the subjectKeyIdentifier for this certificate as byte buffer.\n *\n * @return the subjectKeyIdentifier for this certificate as byte buffer.\n */\n cert.generateSubjectKeyIdentifier = function() {\n /* See: 4.2.1.2 section of the the RFC3280, keyIdentifier is either:\n\n (1) The keyIdentifier is composed of the 160-bit SHA-1 hash of the\n value of the BIT STRING subjectPublicKey (excluding the tag,\n length, and number of unused bits).\n\n (2) The keyIdentifier is composed of a four bit type field with\n the value 0100 followed by the least significant 60 bits of the\n SHA-1 hash of the value of the BIT STRING subjectPublicKey\n (excluding the tag, length, and number of unused bit string bits).\n */\n\n // skipping the tag, length, and number of unused bits is the same\n // as just using the RSAPublicKey (for RSA keys, which are the\n // only ones supported)\n return pki.getPublicKeyFingerprint(cert.publicKey, {type: 'RSAPublicKey'});\n };\n\n /**\n * Verifies the subjectKeyIdentifier extension value for this certificate\n * against its public key. If no extension is found, false will be\n * returned.\n *\n * @return true if verified, false if not.\n */\n cert.verifySubjectKeyIdentifier = function() {\n var oid = oids['subjectKeyIdentifier'];\n for(var i = 0; i < cert.extensions.length; ++i) {\n var ext = cert.extensions[i];\n if(ext.id === oid) {\n var ski = cert.generateSubjectKeyIdentifier().getBytes();\n return (forge.util.hexToBytes(ext.subjectKeyIdentifier) === ski);\n }\n }\n return false;\n };\n\n return cert;\n};\n\n/**\n * Converts an X.509v3 RSA certificate from an ASN.1 object.\n *\n * Note: If the certificate is to be verified then compute hash should\n * be set to true. There is currently no implementation for converting\n * a certificate back to ASN.1 so the TBSCertificate part of the ASN.1\n * object needs to be scanned before the cert object is created.\n *\n * @param obj the asn1 representation of an X.509v3 RSA certificate.\n * @param computeHash true to compute the hash for verification.\n *\n * @return the certificate.\n */\npki.certificateFromAsn1 = function(obj, computeHash) {\n // validate certificate and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, x509CertificateValidator, capture, errors)) {\n var error = new Error('Cannot read X.509 certificate. ' +\n 'ASN.1 object is not an X509v3 Certificate.');\n error.errors = errors;\n throw error;\n }\n\n // get oid\n var oid = asn1.derToOid(capture.publicKeyOid);\n if(oid !== pki.oids.rsaEncryption) {\n throw new Error('Cannot read public key. OID is not RSA.');\n }\n\n // create certificate\n var cert = pki.createCertificate();\n cert.version = capture.certVersion ?\n capture.certVersion.charCodeAt(0) : 0;\n var serial = forge.util.createBuffer(capture.certSerialNumber);\n cert.serialNumber = serial.toHex();\n cert.signatureOid = forge.asn1.derToOid(capture.certSignatureOid);\n cert.signatureParameters = _readSignatureParameters(\n cert.signatureOid, capture.certSignatureParams, true);\n cert.siginfo.algorithmOid = forge.asn1.derToOid(capture.certinfoSignatureOid);\n cert.siginfo.parameters = _readSignatureParameters(cert.siginfo.algorithmOid,\n capture.certinfoSignatureParams, false);\n cert.signature = capture.certSignature;\n\n var validity = [];\n if(capture.certValidity1UTCTime !== undefined) {\n validity.push(asn1.utcTimeToDate(capture.certValidity1UTCTime));\n }\n if(capture.certValidity2GeneralizedTime !== undefined) {\n validity.push(asn1.generalizedTimeToDate(\n capture.certValidity2GeneralizedTime));\n }\n if(capture.certValidity3UTCTime !== undefined) {\n validity.push(asn1.utcTimeToDate(capture.certValidity3UTCTime));\n }\n if(capture.certValidity4GeneralizedTime !== undefined) {\n validity.push(asn1.generalizedTimeToDate(\n capture.certValidity4GeneralizedTime));\n }\n if(validity.length > 2) {\n throw new Error('Cannot read notBefore/notAfter validity times; more ' +\n 'than two times were provided in the certificate.');\n }\n if(validity.length < 2) {\n throw new Error('Cannot read notBefore/notAfter validity times; they ' +\n 'were not provided as either UTCTime or GeneralizedTime.');\n }\n cert.validity.notBefore = validity[0];\n cert.validity.notAfter = validity[1];\n\n // keep TBSCertificate to preserve signature when exporting\n cert.tbsCertificate = capture.tbsCertificate;\n\n if(computeHash) {\n // check signature OID for supported signature types\n cert.md = null;\n if(cert.signatureOid in oids) {\n var oid = oids[cert.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n cert.md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n cert.md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n cert.md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n cert.md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n cert.md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n cert.md = forge.md.sha256.create();\n break;\n }\n }\n if(cert.md === null) {\n var error = new Error('Could not compute certificate digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = cert.signatureOid;\n throw error;\n }\n\n // produce DER formatted TBSCertificate and digest it\n var bytes = asn1.toDer(cert.tbsCertificate);\n cert.md.update(bytes.getBytes());\n }\n\n // handle issuer, build issuer message digest\n var imd = forge.md.sha1.create();\n cert.issuer.getField = function(sn) {\n return _getAttribute(cert.issuer, sn);\n };\n cert.issuer.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.issuer.attributes.push(attr);\n };\n cert.issuer.attributes = pki.RDNAttributesAsArray(capture.certIssuer, imd);\n if(capture.certIssuerUniqueId) {\n cert.issuer.uniqueId = capture.certIssuerUniqueId;\n }\n cert.issuer.hash = imd.digest().toHex();\n\n // handle subject, build subject message digest\n var smd = forge.md.sha1.create();\n cert.subject.getField = function(sn) {\n return _getAttribute(cert.subject, sn);\n };\n cert.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.subject.attributes.push(attr);\n };\n cert.subject.attributes = pki.RDNAttributesAsArray(capture.certSubject, smd);\n if(capture.certSubjectUniqueId) {\n cert.subject.uniqueId = capture.certSubjectUniqueId;\n }\n cert.subject.hash = smd.digest().toHex();\n\n // handle extensions\n if(capture.certExtensions) {\n cert.extensions = pki.certificateExtensionsFromAsn1(capture.certExtensions);\n } else {\n cert.extensions = [];\n }\n\n // convert RSA public key from ASN.1\n cert.publicKey = pki.publicKeyFromAsn1(capture.subjectPublicKeyInfo);\n\n return cert;\n};\n\n/**\n * Converts an ASN.1 extensions object (with extension sequences as its\n * values) into an array of extension objects with types and values.\n *\n * Supported extensions:\n *\n * id-ce-keyUsage OBJECT IDENTIFIER ::= { id-ce 15 }\n * KeyUsage ::= BIT STRING {\n * digitalSignature (0),\n * nonRepudiation (1),\n * keyEncipherment (2),\n * dataEncipherment (3),\n * keyAgreement (4),\n * keyCertSign (5),\n * cRLSign (6),\n * encipherOnly (7),\n * decipherOnly (8)\n * }\n *\n * id-ce-basicConstraints OBJECT IDENTIFIER ::= { id-ce 19 }\n * BasicConstraints ::= SEQUENCE {\n * cA BOOLEAN DEFAULT FALSE,\n * pathLenConstraint INTEGER (0..MAX) OPTIONAL\n * }\n *\n * subjectAltName EXTENSION ::= {\n * SYNTAX GeneralNames\n * IDENTIFIED BY id-ce-subjectAltName\n * }\n *\n * GeneralNames ::= SEQUENCE SIZE (1..MAX) OF GeneralName\n *\n * GeneralName ::= CHOICE {\n * otherName [0] INSTANCE OF OTHER-NAME,\n * rfc822Name [1] IA5String,\n * dNSName [2] IA5String,\n * x400Address [3] ORAddress,\n * directoryName [4] Name,\n * ediPartyName [5] EDIPartyName,\n * uniformResourceIdentifier [6] IA5String,\n * IPAddress [7] OCTET STRING,\n * registeredID [8] OBJECT IDENTIFIER\n * }\n *\n * OTHER-NAME ::= TYPE-IDENTIFIER\n *\n * EDIPartyName ::= SEQUENCE {\n * nameAssigner [0] DirectoryString {ub-name} OPTIONAL,\n * partyName [1] DirectoryString {ub-name}\n * }\n *\n * @param exts the extensions ASN.1 with extension sequences to parse.\n *\n * @return the array.\n */\npki.certificateExtensionsFromAsn1 = function(exts) {\n var rval = [];\n for(var i = 0; i < exts.value.length; ++i) {\n // get extension sequence\n var extseq = exts.value[i];\n for(var ei = 0; ei < extseq.value.length; ++ei) {\n rval.push(pki.certificateExtensionFromAsn1(extseq.value[ei]));\n }\n }\n\n return rval;\n};\n\n/**\n * Parses a single certificate extension from ASN.1.\n *\n * @param ext the extension in ASN.1 format.\n *\n * @return the parsed extension as an object.\n */\npki.certificateExtensionFromAsn1 = function(ext) {\n // an extension has:\n // [0] extnID OBJECT IDENTIFIER\n // [1] critical BOOLEAN DEFAULT FALSE\n // [2] extnValue OCTET STRING\n var e = {};\n e.id = asn1.derToOid(ext.value[0].value);\n e.critical = false;\n if(ext.value[1].type === asn1.Type.BOOLEAN) {\n e.critical = (ext.value[1].value.charCodeAt(0) !== 0x00);\n e.value = ext.value[2].value;\n } else {\n e.value = ext.value[1].value;\n }\n // if the oid is known, get its name\n if(e.id in oids) {\n e.name = oids[e.id];\n\n // handle key usage\n if(e.name === 'keyUsage') {\n // get value as BIT STRING\n var ev = asn1.fromDer(e.value);\n var b2 = 0x00;\n var b3 = 0x00;\n if(ev.value.length > 1) {\n // skip first byte, just indicates unused bits which\n // will be padded with 0s anyway\n // get bytes with flag bits\n b2 = ev.value.charCodeAt(1);\n b3 = ev.value.length > 2 ? ev.value.charCodeAt(2) : 0;\n }\n // set flags\n e.digitalSignature = (b2 & 0x80) === 0x80;\n e.nonRepudiation = (b2 & 0x40) === 0x40;\n e.keyEncipherment = (b2 & 0x20) === 0x20;\n e.dataEncipherment = (b2 & 0x10) === 0x10;\n e.keyAgreement = (b2 & 0x08) === 0x08;\n e.keyCertSign = (b2 & 0x04) === 0x04;\n e.cRLSign = (b2 & 0x02) === 0x02;\n e.encipherOnly = (b2 & 0x01) === 0x01;\n e.decipherOnly = (b3 & 0x80) === 0x80;\n } else if(e.name === 'basicConstraints') {\n // handle basic constraints\n // get value as SEQUENCE\n var ev = asn1.fromDer(e.value);\n // get cA BOOLEAN flag (defaults to false)\n if(ev.value.length > 0 && ev.value[0].type === asn1.Type.BOOLEAN) {\n e.cA = (ev.value[0].value.charCodeAt(0) !== 0x00);\n } else {\n e.cA = false;\n }\n // get path length constraint\n var value = null;\n if(ev.value.length > 0 && ev.value[0].type === asn1.Type.INTEGER) {\n value = ev.value[0].value;\n } else if(ev.value.length > 1) {\n value = ev.value[1].value;\n }\n if(value !== null) {\n e.pathLenConstraint = asn1.derToInteger(value);\n }\n } else if(e.name === 'extKeyUsage') {\n // handle extKeyUsage\n // value is a SEQUENCE of OIDs\n var ev = asn1.fromDer(e.value);\n for(var vi = 0; vi < ev.value.length; ++vi) {\n var oid = asn1.derToOid(ev.value[vi].value);\n if(oid in oids) {\n e[oids[oid]] = true;\n } else {\n e[oid] = true;\n }\n }\n } else if(e.name === 'nsCertType') {\n // handle nsCertType\n // get value as BIT STRING\n var ev = asn1.fromDer(e.value);\n var b2 = 0x00;\n if(ev.value.length > 1) {\n // skip first byte, just indicates unused bits which\n // will be padded with 0s anyway\n // get bytes with flag bits\n b2 = ev.value.charCodeAt(1);\n }\n // set flags\n e.client = (b2 & 0x80) === 0x80;\n e.server = (b2 & 0x40) === 0x40;\n e.email = (b2 & 0x20) === 0x20;\n e.objsign = (b2 & 0x10) === 0x10;\n e.reserved = (b2 & 0x08) === 0x08;\n e.sslCA = (b2 & 0x04) === 0x04;\n e.emailCA = (b2 & 0x02) === 0x02;\n e.objCA = (b2 & 0x01) === 0x01;\n } else if(\n e.name === 'subjectAltName' ||\n e.name === 'issuerAltName') {\n // handle subjectAltName/issuerAltName\n e.altNames = [];\n\n // ev is a SYNTAX SEQUENCE\n var gn;\n var ev = asn1.fromDer(e.value);\n for(var n = 0; n < ev.value.length; ++n) {\n // get GeneralName\n gn = ev.value[n];\n\n var altName = {\n type: gn.type,\n value: gn.value\n };\n e.altNames.push(altName);\n\n // Note: Support for types 1,2,6,7,8\n switch(gn.type) {\n // rfc822Name\n case 1:\n // dNSName\n case 2:\n // uniformResourceIdentifier (URI)\n case 6:\n break;\n // IPAddress\n case 7:\n // convert to IPv4/IPv6 string representation\n altName.ip = forge.util.bytesToIP(gn.value);\n break;\n // registeredID\n case 8:\n altName.oid = asn1.derToOid(gn.value);\n break;\n default:\n // unsupported\n }\n }\n } else if(e.name === 'subjectKeyIdentifier') {\n // value is an OCTETSTRING w/the hash of the key-type specific\n // public key structure (eg: RSAPublicKey)\n var ev = asn1.fromDer(e.value);\n e.subjectKeyIdentifier = forge.util.bytesToHex(ev.value);\n }\n }\n return e;\n};\n\n/**\n * Converts a PKCS#10 certification request (CSR) from an ASN.1 object.\n *\n * Note: If the certification request is to be verified then compute hash\n * should be set to true. There is currently no implementation for converting\n * a certificate back to ASN.1 so the CertificationRequestInfo part of the\n * ASN.1 object needs to be scanned before the csr object is created.\n *\n * @param obj the asn1 representation of a PKCS#10 certification request (CSR).\n * @param computeHash true to compute the hash for verification.\n *\n * @return the certification request (CSR).\n */\npki.certificationRequestFromAsn1 = function(obj, computeHash) {\n // validate certification request and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, certificationRequestValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#10 certificate request. ' +\n 'ASN.1 object is not a PKCS#10 CertificationRequest.');\n error.errors = errors;\n throw error;\n }\n\n // get oid\n var oid = asn1.derToOid(capture.publicKeyOid);\n if(oid !== pki.oids.rsaEncryption) {\n throw new Error('Cannot read public key. OID is not RSA.');\n }\n\n // create certification request\n var csr = pki.createCertificationRequest();\n csr.version = capture.csrVersion ? capture.csrVersion.charCodeAt(0) : 0;\n csr.signatureOid = forge.asn1.derToOid(capture.csrSignatureOid);\n csr.signatureParameters = _readSignatureParameters(\n csr.signatureOid, capture.csrSignatureParams, true);\n csr.siginfo.algorithmOid = forge.asn1.derToOid(capture.csrSignatureOid);\n csr.siginfo.parameters = _readSignatureParameters(\n csr.siginfo.algorithmOid, capture.csrSignatureParams, false);\n csr.signature = capture.csrSignature;\n\n // keep CertificationRequestInfo to preserve signature when exporting\n csr.certificationRequestInfo = capture.certificationRequestInfo;\n\n if(computeHash) {\n // check signature OID for supported signature types\n csr.md = null;\n if(csr.signatureOid in oids) {\n var oid = oids[csr.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n csr.md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n csr.md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n csr.md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n csr.md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n csr.md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n csr.md = forge.md.sha256.create();\n break;\n }\n }\n if(csr.md === null) {\n var error = new Error('Could not compute certification request digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = csr.signatureOid;\n throw error;\n }\n\n // produce DER formatted CertificationRequestInfo and digest it\n var bytes = asn1.toDer(csr.certificationRequestInfo);\n csr.md.update(bytes.getBytes());\n }\n\n // handle subject, build subject message digest\n var smd = forge.md.sha1.create();\n csr.subject.getField = function(sn) {\n return _getAttribute(csr.subject, sn);\n };\n csr.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n csr.subject.attributes.push(attr);\n };\n csr.subject.attributes = pki.RDNAttributesAsArray(\n capture.certificationRequestInfoSubject, smd);\n csr.subject.hash = smd.digest().toHex();\n\n // convert RSA public key from ASN.1\n csr.publicKey = pki.publicKeyFromAsn1(capture.subjectPublicKeyInfo);\n\n // convert attributes from ASN.1\n csr.getAttribute = function(sn) {\n return _getAttribute(csr, sn);\n };\n csr.addAttribute = function(attr) {\n _fillMissingFields([attr]);\n csr.attributes.push(attr);\n };\n csr.attributes = pki.CRIAttributesAsArray(\n capture.certificationRequestInfoAttributes || []);\n\n return csr;\n};\n\n/**\n * Creates an empty certification request (a CSR or certificate signing\n * request). Once created, its public key and attributes can be set and then\n * it can be signed.\n *\n * @return the empty certification request.\n */\npki.createCertificationRequest = function() {\n var csr = {};\n csr.version = 0x00;\n csr.signatureOid = null;\n csr.signature = null;\n csr.siginfo = {};\n csr.siginfo.algorithmOid = null;\n\n csr.subject = {};\n csr.subject.getField = function(sn) {\n return _getAttribute(csr.subject, sn);\n };\n csr.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n csr.subject.attributes.push(attr);\n };\n csr.subject.attributes = [];\n csr.subject.hash = null;\n\n csr.publicKey = null;\n csr.attributes = [];\n csr.getAttribute = function(sn) {\n return _getAttribute(csr, sn);\n };\n csr.addAttribute = function(attr) {\n _fillMissingFields([attr]);\n csr.attributes.push(attr);\n };\n csr.md = null;\n\n /**\n * Sets the subject of this certification request.\n *\n * @param attrs the array of subject attributes to use.\n */\n csr.setSubject = function(attrs) {\n // set new attributes\n _fillMissingFields(attrs);\n csr.subject.attributes = attrs;\n csr.subject.hash = null;\n };\n\n /**\n * Sets the attributes of this certification request.\n *\n * @param attrs the array of attributes to use.\n */\n csr.setAttributes = function(attrs) {\n // set new attributes\n _fillMissingFields(attrs);\n csr.attributes = attrs;\n };\n\n /**\n * Signs this certification request using the given private key.\n *\n * @param key the private key to sign with.\n * @param md the message digest object to use (defaults to forge.md.sha1).\n */\n csr.sign = function(key, md) {\n // TODO: get signature OID from private key\n csr.md = md || forge.md.sha1.create();\n var algorithmOid = oids[csr.md.algorithm + 'WithRSAEncryption'];\n if(!algorithmOid) {\n var error = new Error('Could not compute certification request digest. ' +\n 'Unknown message digest algorithm OID.');\n error.algorithm = csr.md.algorithm;\n throw error;\n }\n csr.signatureOid = csr.siginfo.algorithmOid = algorithmOid;\n\n // get CertificationRequestInfo, convert to DER\n csr.certificationRequestInfo = pki.getCertificationRequestInfo(csr);\n var bytes = asn1.toDer(csr.certificationRequestInfo);\n\n // digest and sign\n csr.md.update(bytes.getBytes());\n csr.signature = key.sign(csr.md);\n };\n\n /**\n * Attempts verify the signature on the passed certification request using\n * its public key.\n *\n * A CSR that has been exported to a file in PEM format can be verified using\n * OpenSSL using this command:\n *\n * openssl req -in <the-csr-pem-file> -verify -noout -text\n *\n * @return true if verified, false if not.\n */\n csr.verify = function() {\n var rval = false;\n\n var md = csr.md;\n if(md === null) {\n // check signature OID for supported signature types\n if(csr.signatureOid in oids) {\n // TODO: create DRY `OID to md` function\n var oid = oids[csr.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n md = forge.md.sha256.create();\n break;\n }\n }\n if(md === null) {\n var error = new Error(\n 'Could not compute certification request digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = csr.signatureOid;\n throw error;\n }\n\n // produce DER formatted CertificationRequestInfo and digest it\n var cri = csr.certificationRequestInfo ||\n pki.getCertificationRequestInfo(csr);\n var bytes = asn1.toDer(cri);\n md.update(bytes.getBytes());\n }\n\n if(md !== null) {\n var scheme;\n\n switch(csr.signatureOid) {\n case oids.sha1WithRSAEncryption:\n /* use PKCS#1 v1.5 padding scheme */\n break;\n case oids['RSASSA-PSS']:\n var hash, mgf;\n\n /* initialize mgf */\n hash = oids[csr.signatureParameters.mgf.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported MGF hash function.');\n error.oid = csr.signatureParameters.mgf.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n mgf = oids[csr.signatureParameters.mgf.algorithmOid];\n if(mgf === undefined || forge.mgf[mgf] === undefined) {\n var error = new Error('Unsupported MGF function.');\n error.oid = csr.signatureParameters.mgf.algorithmOid;\n error.name = mgf;\n throw error;\n }\n\n mgf = forge.mgf[mgf].create(forge.md[hash].create());\n\n /* initialize hash function */\n hash = oids[csr.signatureParameters.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported RSASSA-PSS hash function.');\n error.oid = csr.signatureParameters.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n scheme = forge.pss.create(forge.md[hash].create(), mgf,\n csr.signatureParameters.saltLength);\n break;\n }\n\n // verify signature on csr using its public key\n rval = csr.publicKey.verify(\n md.digest().getBytes(), csr.signature, scheme);\n }\n\n return rval;\n };\n\n return csr;\n};\n\n/**\n * Converts an X.509 subject or issuer to an ASN.1 RDNSequence.\n *\n * @param obj the subject or issuer (distinguished name).\n *\n * @return the ASN.1 RDNSequence.\n */\nfunction _dnToAsn1(obj) {\n // create an empty RDNSequence\n var rval = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n // iterate over attributes\n var attr, set;\n var attrs = obj.attributes;\n for(var i = 0; i < attrs.length; ++i) {\n attr = attrs[i];\n var value = attr.value;\n\n // reuse tag class for attribute value if available\n var valueTagClass = asn1.Type.PRINTABLESTRING;\n if('valueTagClass' in attr) {\n valueTagClass = attr.valueTagClass;\n\n if(valueTagClass === asn1.Type.UTF8) {\n value = forge.util.encodeUtf8(value);\n }\n // FIXME: handle more encodings\n }\n\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n set = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n // AttributeValue\n asn1.create(asn1.Class.UNIVERSAL, valueTagClass, false, value)\n ])\n ]);\n rval.value.push(set);\n }\n\n return rval;\n}\n\n/**\n * Gets all printable attributes (typically of an issuer or subject) in a\n * simplified JSON format for display.\n *\n * @param attrs the attributes.\n *\n * @return the JSON for display.\n */\nfunction _getAttributesAsJson(attrs) {\n var rval = {};\n for(var i = 0; i < attrs.length; ++i) {\n var attr = attrs[i];\n if(attr.shortName && (\n attr.valueTagClass === asn1.Type.UTF8 ||\n attr.valueTagClass === asn1.Type.PRINTABLESTRING ||\n attr.valueTagClass === asn1.Type.IA5STRING)) {\n var value = attr.value;\n if(attr.valueTagClass === asn1.Type.UTF8) {\n value = forge.util.encodeUtf8(attr.value);\n }\n if(!(attr.shortName in rval)) {\n rval[attr.shortName] = value;\n } else if(forge.util.isArray(rval[attr.shortName])) {\n rval[attr.shortName].push(value);\n } else {\n rval[attr.shortName] = [rval[attr.shortName], value];\n }\n }\n }\n return rval;\n}\n\n/**\n * Fills in missing fields in attributes.\n *\n * @param attrs the attributes to fill missing fields in.\n */\nfunction _fillMissingFields(attrs) {\n var attr;\n for(var i = 0; i < attrs.length; ++i) {\n attr = attrs[i];\n\n // populate missing name\n if(typeof attr.name === 'undefined') {\n if(attr.type && attr.type in pki.oids) {\n attr.name = pki.oids[attr.type];\n } else if(attr.shortName && attr.shortName in _shortNames) {\n attr.name = pki.oids[_shortNames[attr.shortName]];\n }\n }\n\n // populate missing type (OID)\n if(typeof attr.type === 'undefined') {\n if(attr.name && attr.name in pki.oids) {\n attr.type = pki.oids[attr.name];\n } else {\n var error = new Error('Attribute type not specified.');\n error.attribute = attr;\n throw error;\n }\n }\n\n // populate missing shortname\n if(typeof attr.shortName === 'undefined') {\n if(attr.name && attr.name in _shortNames) {\n attr.shortName = _shortNames[attr.name];\n }\n }\n\n // convert extensions to value\n if(attr.type === oids.extensionRequest) {\n attr.valueConstructed = true;\n attr.valueTagClass = asn1.Type.SEQUENCE;\n if(!attr.value && attr.extensions) {\n attr.value = [];\n for(var ei = 0; ei < attr.extensions.length; ++ei) {\n attr.value.push(pki.certificateExtensionToAsn1(\n _fillMissingExtensionFields(attr.extensions[ei])));\n }\n }\n }\n\n if(typeof attr.value === 'undefined') {\n var error = new Error('Attribute value not specified.');\n error.attribute = attr;\n throw error;\n }\n }\n}\n\n/**\n * Fills in missing fields in certificate extensions.\n *\n * @param e the extension.\n * @param [options] the options to use.\n * [cert] the certificate the extensions are for.\n *\n * @return the extension.\n */\nfunction _fillMissingExtensionFields(e, options) {\n options = options || {};\n\n // populate missing name\n if(typeof e.name === 'undefined') {\n if(e.id && e.id in pki.oids) {\n e.name = pki.oids[e.id];\n }\n }\n\n // populate missing id\n if(typeof e.id === 'undefined') {\n if(e.name && e.name in pki.oids) {\n e.id = pki.oids[e.name];\n } else {\n var error = new Error('Extension ID not specified.');\n error.extension = e;\n throw error;\n }\n }\n\n if(typeof e.value !== 'undefined') {\n return e;\n }\n\n // handle missing value:\n\n // value is a BIT STRING\n if(e.name === 'keyUsage') {\n // build flags\n var unused = 0;\n var b2 = 0x00;\n var b3 = 0x00;\n if(e.digitalSignature) {\n b2 |= 0x80;\n unused = 7;\n }\n if(e.nonRepudiation) {\n b2 |= 0x40;\n unused = 6;\n }\n if(e.keyEncipherment) {\n b2 |= 0x20;\n unused = 5;\n }\n if(e.dataEncipherment) {\n b2 |= 0x10;\n unused = 4;\n }\n if(e.keyAgreement) {\n b2 |= 0x08;\n unused = 3;\n }\n if(e.keyCertSign) {\n b2 |= 0x04;\n unused = 2;\n }\n if(e.cRLSign) {\n b2 |= 0x02;\n unused = 1;\n }\n if(e.encipherOnly) {\n b2 |= 0x01;\n unused = 0;\n }\n if(e.decipherOnly) {\n b3 |= 0x80;\n unused = 7;\n }\n\n // create bit string\n var value = String.fromCharCode(unused);\n if(b3 !== 0) {\n value += String.fromCharCode(b2) + String.fromCharCode(b3);\n } else if(b2 !== 0) {\n value += String.fromCharCode(b2);\n }\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false, value);\n } else if(e.name === 'basicConstraints') {\n // basicConstraints is a SEQUENCE\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n // cA BOOLEAN flag defaults to false\n if(e.cA) {\n e.value.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BOOLEAN, false,\n String.fromCharCode(0xFF)));\n }\n if('pathLenConstraint' in e) {\n e.value.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(e.pathLenConstraint).getBytes()));\n }\n } else if(e.name === 'extKeyUsage') {\n // extKeyUsage is a SEQUENCE of OIDs\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var seq = e.value.value;\n for(var key in e) {\n if(e[key] !== true) {\n continue;\n }\n // key is name in OID map\n if(key in oids) {\n seq.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID,\n false, asn1.oidToDer(oids[key]).getBytes()));\n } else if(key.indexOf('.') !== -1) {\n // assume key is an OID\n seq.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID,\n false, asn1.oidToDer(key).getBytes()));\n }\n }\n } else if(e.name === 'nsCertType') {\n // nsCertType is a BIT STRING\n // build flags\n var unused = 0;\n var b2 = 0x00;\n\n if(e.client) {\n b2 |= 0x80;\n unused = 7;\n }\n if(e.server) {\n b2 |= 0x40;\n unused = 6;\n }\n if(e.email) {\n b2 |= 0x20;\n unused = 5;\n }\n if(e.objsign) {\n b2 |= 0x10;\n unused = 4;\n }\n if(e.reserved) {\n b2 |= 0x08;\n unused = 3;\n }\n if(e.sslCA) {\n b2 |= 0x04;\n unused = 2;\n }\n if(e.emailCA) {\n b2 |= 0x02;\n unused = 1;\n }\n if(e.objCA) {\n b2 |= 0x01;\n unused = 0;\n }\n\n // create bit string\n var value = String.fromCharCode(unused);\n if(b2 !== 0) {\n value += String.fromCharCode(b2);\n }\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false, value);\n } else if(e.name === 'subjectAltName' || e.name === 'issuerAltName') {\n // SYNTAX SEQUENCE\n e.value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n var altName;\n for(var n = 0; n < e.altNames.length; ++n) {\n altName = e.altNames[n];\n var value = altName.value;\n // handle IP\n if(altName.type === 7 && altName.ip) {\n value = forge.util.bytesFromIP(altName.ip);\n if(value === null) {\n var error = new Error(\n 'Extension \"ip\" value is not a valid IPv4 or IPv6 address.');\n error.extension = e;\n throw error;\n }\n } else if(altName.type === 8) {\n // handle OID\n if(altName.oid) {\n value = asn1.oidToDer(asn1.oidToDer(altName.oid));\n } else {\n // deprecated ... convert value to OID\n value = asn1.oidToDer(value);\n }\n }\n e.value.value.push(asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, altName.type, false,\n value));\n }\n } else if(e.name === 'nsComment' && options.cert) {\n // sanity check value is ASCII (req'd) and not too big\n if(!(/^[\\x00-\\x7F]*$/.test(e.comment)) ||\n (e.comment.length < 1) || (e.comment.length > 128)) {\n throw new Error('Invalid \"nsComment\" content.');\n }\n // IA5STRING opaque comment\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.IA5STRING, false, e.comment);\n } else if(e.name === 'subjectKeyIdentifier' && options.cert) {\n var ski = options.cert.generateSubjectKeyIdentifier();\n e.subjectKeyIdentifier = ski.toHex();\n // OCTETSTRING w/digest\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, ski.getBytes());\n } else if(e.name === 'authorityKeyIdentifier' && options.cert) {\n // SYNTAX SEQUENCE\n e.value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var seq = e.value.value;\n\n if(e.keyIdentifier) {\n var keyIdentifier = (e.keyIdentifier === true ?\n options.cert.generateSubjectKeyIdentifier().getBytes() :\n e.keyIdentifier);\n seq.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, false, keyIdentifier));\n }\n\n if(e.authorityCertIssuer) {\n var authorityCertIssuer = [\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 4, true, [\n _dnToAsn1(e.authorityCertIssuer === true ?\n options.cert.issuer : e.authorityCertIssuer)\n ])\n ];\n seq.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, authorityCertIssuer));\n }\n\n if(e.serialNumber) {\n var serialNumber = forge.util.hexToBytes(e.serialNumber === true ?\n options.cert.serialNumber : e.serialNumber);\n seq.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 2, false, serialNumber));\n }\n } else if(e.name === 'cRLDistributionPoints') {\n e.value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var seq = e.value.value;\n\n // Create sub SEQUENCE of DistributionPointName\n var subSeq = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n // Create fullName CHOICE\n var fullNameGeneralNames = asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n var altName;\n for(var n = 0; n < e.altNames.length; ++n) {\n altName = e.altNames[n];\n var value = altName.value;\n // handle IP\n if(altName.type === 7 && altName.ip) {\n value = forge.util.bytesFromIP(altName.ip);\n if(value === null) {\n var error = new Error(\n 'Extension \"ip\" value is not a valid IPv4 or IPv6 address.');\n error.extension = e;\n throw error;\n }\n } else if(altName.type === 8) {\n // handle OID\n if(altName.oid) {\n value = asn1.oidToDer(asn1.oidToDer(altName.oid));\n } else {\n // deprecated ... convert value to OID\n value = asn1.oidToDer(value);\n }\n }\n fullNameGeneralNames.value.push(asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, altName.type, false,\n value));\n }\n\n // Add to the parent SEQUENCE\n subSeq.value.push(asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, [fullNameGeneralNames]));\n seq.push(subSeq);\n }\n\n // ensure value has been defined by now\n if(typeof e.value === 'undefined') {\n var error = new Error('Extension value not specified.');\n error.extension = e;\n throw error;\n }\n\n return e;\n}\n\n/**\n * Convert signature parameters object to ASN.1\n *\n * @param {String} oid Signature algorithm OID\n * @param params The signature parametrs object\n * @return ASN.1 object representing signature parameters\n */\nfunction _signatureParametersToAsn1(oid, params) {\n switch(oid) {\n case oids['RSASSA-PSS']:\n var parts = [];\n\n if(params.hash.algorithmOid !== undefined) {\n parts.push(asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(params.hash.algorithmOid).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ]));\n }\n\n if(params.mgf.algorithmOid !== undefined) {\n parts.push(asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(params.mgf.algorithmOid).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(params.mgf.hash.algorithmOid).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ])\n ]));\n }\n\n if(params.saltLength !== undefined) {\n parts.push(asn1.create(asn1.Class.CONTEXT_SPECIFIC, 2, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(params.saltLength).getBytes())\n ]));\n }\n\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, parts);\n\n default:\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '');\n }\n}\n\n/**\n * Converts a certification request's attributes to an ASN.1 set of\n * CRIAttributes.\n *\n * @param csr certification request.\n *\n * @return the ASN.1 set of CRIAttributes.\n */\nfunction _CRIAttributesToAsn1(csr) {\n // create an empty context-specific container\n var rval = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n\n // no attributes, return empty container\n if(csr.attributes.length === 0) {\n return rval;\n }\n\n // each attribute has a sequence with a type and a set of values\n var attrs = csr.attributes;\n for(var i = 0; i < attrs.length; ++i) {\n var attr = attrs[i];\n var value = attr.value;\n\n // reuse tag class for attribute value if available\n var valueTagClass = asn1.Type.UTF8;\n if('valueTagClass' in attr) {\n valueTagClass = attr.valueTagClass;\n }\n if(valueTagClass === asn1.Type.UTF8) {\n value = forge.util.encodeUtf8(value);\n }\n var valueConstructed = false;\n if('valueConstructed' in attr) {\n valueConstructed = attr.valueConstructed;\n }\n // FIXME: handle more encodings\n\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n var seq = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n // AttributeValue\n asn1.create(\n asn1.Class.UNIVERSAL, valueTagClass, valueConstructed, value)\n ])\n ]);\n rval.value.push(seq);\n }\n\n return rval;\n}\n\nvar jan_1_1950 = new Date('1950-01-01T00:00:00Z');\nvar jan_1_2050 = new Date('2050-01-01T00:00:00Z');\n\n/**\n * Converts a Date object to ASN.1\n * Handles the different format before and after 1st January 2050\n *\n * @param date date object.\n *\n * @return the ASN.1 object representing the date.\n */\nfunction _dateToAsn1(date) {\n if(date >= jan_1_1950 && date < jan_1_2050) {\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.UTCTIME, false,\n asn1.dateToUtcTime(date));\n } else {\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.GENERALIZEDTIME, false,\n asn1.dateToGeneralizedTime(date));\n }\n}\n\n/**\n * Gets the ASN.1 TBSCertificate part of an X.509v3 certificate.\n *\n * @param cert the certificate.\n *\n * @return the asn1 TBSCertificate.\n */\npki.getTBSCertificate = function(cert) {\n // TBSCertificate\n var notBefore = _dateToAsn1(cert.validity.notBefore);\n var notAfter = _dateToAsn1(cert.validity.notAfter);\n var tbs = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n // integer\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(cert.version).getBytes())\n ]),\n // serialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(cert.serialNumber)),\n // signature\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(cert.siginfo.algorithmOid).getBytes()),\n // parameters\n _signatureParametersToAsn1(\n cert.siginfo.algorithmOid, cert.siginfo.parameters)\n ]),\n // issuer\n _dnToAsn1(cert.issuer),\n // validity\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n notBefore,\n notAfter\n ]),\n // subject\n _dnToAsn1(cert.subject),\n // SubjectPublicKeyInfo\n pki.publicKeyToAsn1(cert.publicKey)\n ]);\n\n if(cert.issuer.uniqueId) {\n // issuerUniqueID (optional)\n tbs.value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n // TODO: support arbitrary bit length ids\n String.fromCharCode(0x00) +\n cert.issuer.uniqueId\n )\n ])\n );\n }\n if(cert.subject.uniqueId) {\n // subjectUniqueID (optional)\n tbs.value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 2, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n // TODO: support arbitrary bit length ids\n String.fromCharCode(0x00) +\n cert.subject.uniqueId\n )\n ])\n );\n }\n\n if(cert.extensions.length > 0) {\n // extensions (optional)\n tbs.value.push(pki.certificateExtensionsToAsn1(cert.extensions));\n }\n\n return tbs;\n};\n\n/**\n * Gets the ASN.1 CertificationRequestInfo part of a\n * PKCS#10 CertificationRequest.\n *\n * @param csr the certification request.\n *\n * @return the asn1 CertificationRequestInfo.\n */\npki.getCertificationRequestInfo = function(csr) {\n // CertificationRequestInfo\n var cri = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(csr.version).getBytes()),\n // subject\n _dnToAsn1(csr.subject),\n // SubjectPublicKeyInfo\n pki.publicKeyToAsn1(csr.publicKey),\n // attributes\n _CRIAttributesToAsn1(csr)\n ]);\n\n return cri;\n};\n\n/**\n * Converts a DistinguishedName (subject or issuer) to an ASN.1 object.\n *\n * @param dn the DistinguishedName.\n *\n * @return the asn1 representation of a DistinguishedName.\n */\npki.distinguishedNameToAsn1 = function(dn) {\n return _dnToAsn1(dn);\n};\n\n/**\n * Converts an X.509v3 RSA certificate to an ASN.1 object.\n *\n * @param cert the certificate.\n *\n * @return the asn1 representation of an X.509v3 RSA certificate.\n */\npki.certificateToAsn1 = function(cert) {\n // prefer cached TBSCertificate over generating one\n var tbsCertificate = cert.tbsCertificate || pki.getTBSCertificate(cert);\n\n // Certificate\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // TBSCertificate\n tbsCertificate,\n // AlgorithmIdentifier (signature algorithm)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(cert.signatureOid).getBytes()),\n // parameters\n _signatureParametersToAsn1(cert.signatureOid, cert.signatureParameters)\n ]),\n // SignatureValue\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n String.fromCharCode(0x00) + cert.signature)\n ]);\n};\n\n/**\n * Converts X.509v3 certificate extensions to ASN.1.\n *\n * @param exts the extensions to convert.\n *\n * @return the extensions in ASN.1 format.\n */\npki.certificateExtensionsToAsn1 = function(exts) {\n // create top-level extension container\n var rval = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 3, true, []);\n\n // create extension sequence (stores a sequence for each extension)\n var seq = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n rval.value.push(seq);\n\n for(var i = 0; i < exts.length; ++i) {\n seq.value.push(pki.certificateExtensionToAsn1(exts[i]));\n }\n\n return rval;\n};\n\n/**\n * Converts a single certificate extension to ASN.1.\n *\n * @param ext the extension to convert.\n *\n * @return the extension in ASN.1 format.\n */\npki.certificateExtensionToAsn1 = function(ext) {\n // create a sequence for each extension\n var extseq = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n // extnID (OID)\n extseq.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(ext.id).getBytes()));\n\n // critical defaults to false\n if(ext.critical) {\n // critical BOOLEAN DEFAULT FALSE\n extseq.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BOOLEAN, false,\n String.fromCharCode(0xFF)));\n }\n\n var value = ext.value;\n if(typeof ext.value !== 'string') {\n // value is asn.1\n value = asn1.toDer(value).getBytes();\n }\n\n // extnValue (OCTET STRING)\n extseq.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, value));\n\n return extseq;\n};\n\n/**\n * Converts a PKCS#10 certification request to an ASN.1 object.\n *\n * @param csr the certification request.\n *\n * @return the asn1 representation of a certification request.\n */\npki.certificationRequestToAsn1 = function(csr) {\n // prefer cached CertificationRequestInfo over generating one\n var cri = csr.certificationRequestInfo ||\n pki.getCertificationRequestInfo(csr);\n\n // Certificate\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // CertificationRequestInfo\n cri,\n // AlgorithmIdentifier (signature algorithm)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(csr.signatureOid).getBytes()),\n // parameters\n _signatureParametersToAsn1(csr.signatureOid, csr.signatureParameters)\n ]),\n // signature\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n String.fromCharCode(0x00) + csr.signature)\n ]);\n};\n\n/**\n * Creates a CA store.\n *\n * @param certs an optional array of certificate objects or PEM-formatted\n * certificate strings to add to the CA store.\n *\n * @return the CA store.\n */\npki.createCaStore = function(certs) {\n // create CA store\n var caStore = {\n // stored certificates\n certs: {}\n };\n\n /**\n * Gets the certificate that issued the passed certificate or its\n * 'parent'.\n *\n * @param cert the certificate to get the parent for.\n *\n * @return the parent certificate or null if none was found.\n */\n caStore.getIssuer = function(cert) {\n var rval = getBySubject(cert.issuer);\n\n // see if there are multiple matches\n /*if(forge.util.isArray(rval)) {\n // TODO: resolve multiple matches by checking\n // authorityKey/subjectKey/issuerUniqueID/other identifiers, etc.\n // FIXME: or alternatively do authority key mapping\n // if possible (X.509v1 certs can't work?)\n throw new Error('Resolving multiple issuer matches not implemented yet.');\n }*/\n\n return rval;\n };\n\n /**\n * Adds a trusted certificate to the store.\n *\n * @param cert the certificate to add as a trusted certificate (either a\n * pki.certificate object or a PEM-formatted certificate).\n */\n caStore.addCertificate = function(cert) {\n // convert from pem if necessary\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n\n ensureSubjectHasHash(cert.subject);\n\n if(!caStore.hasCertificate(cert)) { // avoid duplicate certificates in store\n if(cert.subject.hash in caStore.certs) {\n // subject hash already exists, append to array\n var tmp = caStore.certs[cert.subject.hash];\n if(!forge.util.isArray(tmp)) {\n tmp = [tmp];\n }\n tmp.push(cert);\n caStore.certs[cert.subject.hash] = tmp;\n } else {\n caStore.certs[cert.subject.hash] = cert;\n }\n }\n };\n\n /**\n * Checks to see if the given certificate is in the store.\n *\n * @param cert the certificate to check (either a pki.certificate or a\n * PEM-formatted certificate).\n *\n * @return true if the certificate is in the store, false if not.\n */\n caStore.hasCertificate = function(cert) {\n // convert from pem if necessary\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n\n var match = getBySubject(cert.subject);\n if(!match) {\n return false;\n }\n if(!forge.util.isArray(match)) {\n match = [match];\n }\n // compare DER-encoding of certificates\n var der1 = asn1.toDer(pki.certificateToAsn1(cert)).getBytes();\n for(var i = 0; i < match.length; ++i) {\n var der2 = asn1.toDer(pki.certificateToAsn1(match[i])).getBytes();\n if(der1 === der2) {\n return true;\n }\n }\n return false;\n };\n\n /**\n * Lists all of the certificates kept in the store.\n *\n * @return an array of all of the pki.certificate objects in the store.\n */\n caStore.listAllCertificates = function() {\n var certList = [];\n\n for(var hash in caStore.certs) {\n if(caStore.certs.hasOwnProperty(hash)) {\n var value = caStore.certs[hash];\n if(!forge.util.isArray(value)) {\n certList.push(value);\n } else {\n for(var i = 0; i < value.length; ++i) {\n certList.push(value[i]);\n }\n }\n }\n }\n\n return certList;\n };\n\n /**\n * Removes a certificate from the store.\n *\n * @param cert the certificate to remove (either a pki.certificate or a\n * PEM-formatted certificate).\n *\n * @return the certificate that was removed or null if the certificate\n * wasn't in store.\n */\n caStore.removeCertificate = function(cert) {\n var result;\n\n // convert from pem if necessary\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n ensureSubjectHasHash(cert.subject);\n if(!caStore.hasCertificate(cert)) {\n return null;\n }\n\n var match = getBySubject(cert.subject);\n\n if(!forge.util.isArray(match)) {\n result = caStore.certs[cert.subject.hash];\n delete caStore.certs[cert.subject.hash];\n return result;\n }\n\n // compare DER-encoding of certificates\n var der1 = asn1.toDer(pki.certificateToAsn1(cert)).getBytes();\n for(var i = 0; i < match.length; ++i) {\n var der2 = asn1.toDer(pki.certificateToAsn1(match[i])).getBytes();\n if(der1 === der2) {\n result = match[i];\n match.splice(i, 1);\n }\n }\n if(match.length === 0) {\n delete caStore.certs[cert.subject.hash];\n }\n\n return result;\n };\n\n function getBySubject(subject) {\n ensureSubjectHasHash(subject);\n return caStore.certs[subject.hash] || null;\n }\n\n function ensureSubjectHasHash(subject) {\n // produce subject hash if it doesn't exist\n if(!subject.hash) {\n var md = forge.md.sha1.create();\n subject.attributes = pki.RDNAttributesAsArray(_dnToAsn1(subject), md);\n subject.hash = md.digest().toHex();\n }\n }\n\n // auto-add passed in certs\n if(certs) {\n // parse PEM-formatted certificates as necessary\n for(var i = 0; i < certs.length; ++i) {\n var cert = certs[i];\n caStore.addCertificate(cert);\n }\n }\n\n return caStore;\n};\n\n/**\n * Certificate verification errors, based on TLS.\n */\npki.certificateError = {\n bad_certificate: 'forge.pki.BadCertificate',\n unsupported_certificate: 'forge.pki.UnsupportedCertificate',\n certificate_revoked: 'forge.pki.CertificateRevoked',\n certificate_expired: 'forge.pki.CertificateExpired',\n certificate_unknown: 'forge.pki.CertificateUnknown',\n unknown_ca: 'forge.pki.UnknownCertificateAuthority'\n};\n\n/**\n * Verifies a certificate chain against the given Certificate Authority store\n * with an optional custom verify callback.\n *\n * @param caStore a certificate store to verify against.\n * @param chain the certificate chain to verify, with the root or highest\n * authority at the end (an array of certificates).\n * @param options a callback to be called for every certificate in the chain or\n * an object with:\n * verify a callback to be called for every certificate in the\n * chain\n * validityCheckDate the date against which the certificate\n * validity period should be checked. Pass null to not check\n * the validity period. By default, the current date is used.\n *\n * The verify callback has the following signature:\n *\n * verified - Set to true if certificate was verified, otherwise the\n * pki.certificateError for why the certificate failed.\n * depth - The current index in the chain, where 0 is the end point's cert.\n * certs - The certificate chain, *NOTE* an empty chain indicates an anonymous\n * end point.\n *\n * The function returns true on success and on failure either the appropriate\n * pki.certificateError or an object with 'error' set to the appropriate\n * pki.certificateError and 'message' set to a custom error message.\n *\n * @return true if successful, error thrown if not.\n */\npki.verifyCertificateChain = function(caStore, chain, options) {\n /* From: RFC3280 - Internet X.509 Public Key Infrastructure Certificate\n Section 6: Certification Path Validation\n See inline parentheticals related to this particular implementation.\n\n The primary goal of path validation is to verify the binding between\n a subject distinguished name or a subject alternative name and subject\n public key, as represented in the end entity certificate, based on the\n public key of the trust anchor. This requires obtaining a sequence of\n certificates that support that binding. That sequence should be provided\n in the passed 'chain'. The trust anchor should be in the given CA\n store. The 'end entity' certificate is the certificate provided by the\n end point (typically a server) and is the first in the chain.\n\n To meet this goal, the path validation process verifies, among other\n things, that a prospective certification path (a sequence of n\n certificates or a 'chain') satisfies the following conditions:\n\n (a) for all x in {1, ..., n-1}, the subject of certificate x is\n the issuer of certificate x+1;\n\n (b) certificate 1 is issued by the trust anchor;\n\n (c) certificate n is the certificate to be validated; and\n\n (d) for all x in {1, ..., n}, the certificate was valid at the\n time in question.\n\n Note that here 'n' is index 0 in the chain and 1 is the last certificate\n in the chain and it must be signed by a certificate in the connection's\n CA store.\n\n The path validation process also determines the set of certificate\n policies that are valid for this path, based on the certificate policies\n extension, policy mapping extension, policy constraints extension, and\n inhibit any-policy extension.\n\n Note: Policy mapping extension not supported (Not Required).\n\n Note: If the certificate has an unsupported critical extension, then it\n must be rejected.\n\n Note: A certificate is self-issued if the DNs that appear in the subject\n and issuer fields are identical and are not empty.\n\n The path validation algorithm assumes the following seven inputs are\n provided to the path processing logic. What this specific implementation\n will use is provided parenthetically:\n\n (a) a prospective certification path of length n (the 'chain')\n (b) the current date/time: ('now').\n (c) user-initial-policy-set: A set of certificate policy identifiers\n naming the policies that are acceptable to the certificate user.\n The user-initial-policy-set contains the special value any-policy\n if the user is not concerned about certificate policy\n (Not implemented. Any policy is accepted).\n (d) trust anchor information, describing a CA that serves as a trust\n anchor for the certification path. The trust anchor information\n includes:\n\n (1) the trusted issuer name,\n (2) the trusted public key algorithm,\n (3) the trusted public key, and\n (4) optionally, the trusted public key parameters associated\n with the public key.\n\n (Trust anchors are provided via certificates in the CA store).\n\n The trust anchor information may be provided to the path processing\n procedure in the form of a self-signed certificate. The trusted anchor\n information is trusted because it was delivered to the path processing\n procedure by some trustworthy out-of-band procedure. If the trusted\n public key algorithm requires parameters, then the parameters are\n provided along with the trusted public key (No parameters used in this\n implementation).\n\n (e) initial-policy-mapping-inhibit, which indicates if policy mapping is\n allowed in the certification path.\n (Not implemented, no policy checking)\n\n (f) initial-explicit-policy, which indicates if the path must be valid\n for at least one of the certificate policies in the user-initial-\n policy-set.\n (Not implemented, no policy checking)\n\n (g) initial-any-policy-inhibit, which indicates whether the\n anyPolicy OID should be processed if it is included in a\n certificate.\n (Not implemented, so any policy is valid provided that it is\n not marked as critical) */\n\n /* Basic Path Processing:\n\n For each certificate in the 'chain', the following is checked:\n\n 1. The certificate validity period includes the current time.\n 2. The certificate was signed by its parent (where the parent is either\n the next in the chain or from the CA store). Allow processing to\n continue to the next step if no parent is found but the certificate is\n in the CA store.\n 3. TODO: The certificate has not been revoked.\n 4. The certificate issuer name matches the parent's subject name.\n 5. TODO: If the certificate is self-issued and not the final certificate\n in the chain, skip this step, otherwise verify that the subject name\n is within one of the permitted subtrees of X.500 distinguished names\n and that each of the alternative names in the subjectAltName extension\n (critical or non-critical) is within one of the permitted subtrees for\n that name type.\n 6. TODO: If the certificate is self-issued and not the final certificate\n in the chain, skip this step, otherwise verify that the subject name\n is not within one of the excluded subtrees for X.500 distinguished\n names and none of the subjectAltName extension names are excluded for\n that name type.\n 7. The other steps in the algorithm for basic path processing involve\n handling the policy extension which is not presently supported in this\n implementation. Instead, if a critical policy extension is found, the\n certificate is rejected as not supported.\n 8. If the certificate is not the first or if its the only certificate in\n the chain (having no parent from the CA store or is self-signed) and it\n has a critical key usage extension, verify that the keyCertSign bit is\n set. If the key usage extension exists, verify that the basic\n constraints extension exists. If the basic constraints extension exists,\n verify that the cA flag is set. If pathLenConstraint is set, ensure that\n the number of certificates that precede in the chain (come earlier\n in the chain as implemented below), excluding the very first in the\n chain (typically the end-entity one), isn't greater than the\n pathLenConstraint. This constraint limits the number of intermediate\n CAs that may appear below a CA before only end-entity certificates\n may be issued. */\n\n // if a verify callback is passed as the third parameter, package it within\n // the options object. This is to support a legacy function signature that\n // expected the verify callback as the third parameter.\n if(typeof options === 'function') {\n options = {verify: options};\n }\n options = options || {};\n\n // copy cert chain references to another array to protect against changes\n // in verify callback\n chain = chain.slice(0);\n var certs = chain.slice(0);\n\n var validityCheckDate = options.validityCheckDate;\n // if no validityCheckDate is specified, default to the current date. Make\n // sure to maintain the value null because it indicates that the validity\n // period should not be checked.\n if(typeof validityCheckDate === 'undefined') {\n validityCheckDate = new Date();\n }\n\n // verify each cert in the chain using its parent, where the parent\n // is either the next in the chain or from the CA store\n var first = true;\n var error = null;\n var depth = 0;\n do {\n var cert = chain.shift();\n var parent = null;\n var selfSigned = false;\n\n if(validityCheckDate) {\n // 1. check valid time\n if(validityCheckDate < cert.validity.notBefore ||\n validityCheckDate > cert.validity.notAfter) {\n error = {\n message: 'Certificate is not valid yet or has expired.',\n error: pki.certificateError.certificate_expired,\n notBefore: cert.validity.notBefore,\n notAfter: cert.validity.notAfter,\n // TODO: we might want to reconsider renaming 'now' to\n // 'validityCheckDate' should this API be changed in the future.\n now: validityCheckDate\n };\n }\n }\n\n // 2. verify with parent from chain or CA store\n if(error === null) {\n parent = chain[0] || caStore.getIssuer(cert);\n if(parent === null) {\n // check for self-signed cert\n if(cert.isIssuer(cert)) {\n selfSigned = true;\n parent = cert;\n }\n }\n\n if(parent) {\n // FIXME: current CA store implementation might have multiple\n // certificates where the issuer can't be determined from the\n // certificate (happens rarely with, eg: old certificates) so normalize\n // by always putting parents into an array\n // TODO: there's may be an extreme degenerate case currently uncovered\n // where an old intermediate certificate seems to have a matching parent\n // but none of the parents actually verify ... but the intermediate\n // is in the CA and it should pass this check; needs investigation\n var parents = parent;\n if(!forge.util.isArray(parents)) {\n parents = [parents];\n }\n\n // try to verify with each possible parent (typically only one)\n var verified = false;\n while(!verified && parents.length > 0) {\n parent = parents.shift();\n try {\n verified = parent.verify(cert);\n } catch(ex) {\n // failure to verify, don't care why, try next one\n }\n }\n\n if(!verified) {\n error = {\n message: 'Certificate signature is invalid.',\n error: pki.certificateError.bad_certificate\n };\n }\n }\n\n if(error === null && (!parent || selfSigned) &&\n !caStore.hasCertificate(cert)) {\n // no parent issuer and certificate itself is not trusted\n error = {\n message: 'Certificate is not trusted.',\n error: pki.certificateError.unknown_ca\n };\n }\n }\n\n // TODO: 3. check revoked\n\n // 4. check for matching issuer/subject\n if(error === null && parent && !cert.isIssuer(parent)) {\n // parent is not issuer\n error = {\n message: 'Certificate issuer is invalid.',\n error: pki.certificateError.bad_certificate\n };\n }\n\n // 5. TODO: check names with permitted names tree\n\n // 6. TODO: check names against excluded names tree\n\n // 7. check for unsupported critical extensions\n if(error === null) {\n // supported extensions\n var se = {\n keyUsage: true,\n basicConstraints: true\n };\n for(var i = 0; error === null && i < cert.extensions.length; ++i) {\n var ext = cert.extensions[i];\n if(ext.critical && !(ext.name in se)) {\n error = {\n message:\n 'Certificate has an unsupported critical extension.',\n error: pki.certificateError.unsupported_certificate\n };\n }\n }\n }\n\n // 8. check for CA if cert is not first or is the only certificate\n // remaining in chain with no parent or is self-signed\n if(error === null &&\n (!first || (chain.length === 0 && (!parent || selfSigned)))) {\n // first check keyUsage extension and then basic constraints\n var bcExt = cert.getExtension('basicConstraints');\n var keyUsageExt = cert.getExtension('keyUsage');\n if(keyUsageExt !== null) {\n // keyCertSign must be true and there must be a basic\n // constraints extension\n if(!keyUsageExt.keyCertSign || bcExt === null) {\n // bad certificate\n error = {\n message:\n 'Certificate keyUsage or basicConstraints conflict ' +\n 'or indicate that the certificate is not a CA. ' +\n 'If the certificate is the only one in the chain or ' +\n 'isn\\'t the first then the certificate must be a ' +\n 'valid CA.',\n error: pki.certificateError.bad_certificate\n };\n }\n }\n // basic constraints cA flag must be set\n if(error === null && bcExt !== null && !bcExt.cA) {\n // bad certificate\n error = {\n message:\n 'Certificate basicConstraints indicates the certificate ' +\n 'is not a CA.',\n error: pki.certificateError.bad_certificate\n };\n }\n // if error is not null and keyUsage is available, then we know it\n // has keyCertSign and there is a basic constraints extension too,\n // which means we can check pathLenConstraint (if it exists)\n if(error === null && keyUsageExt !== null &&\n 'pathLenConstraint' in bcExt) {\n // pathLen is the maximum # of intermediate CA certs that can be\n // found between the current certificate and the end-entity (depth 0)\n // certificate; this number does not include the end-entity (depth 0,\n // last in the chain) even if it happens to be a CA certificate itself\n var pathLen = depth - 1;\n if(pathLen > bcExt.pathLenConstraint) {\n // pathLenConstraint violated, bad certificate\n error = {\n message:\n 'Certificate basicConstraints pathLenConstraint violated.',\n error: pki.certificateError.bad_certificate\n };\n }\n }\n }\n\n // call application callback\n var vfd = (error === null) ? true : error.error;\n var ret = options.verify ? options.verify(vfd, depth, certs) : vfd;\n if(ret === true) {\n // clear any set error\n error = null;\n } else {\n // if passed basic tests, set default message and alert\n if(vfd === true) {\n error = {\n message: 'The application rejected the certificate.',\n error: pki.certificateError.bad_certificate\n };\n }\n\n // check for custom error info\n if(ret || ret === 0) {\n // set custom message and error\n if(typeof ret === 'object' && !forge.util.isArray(ret)) {\n if(ret.message) {\n error.message = ret.message;\n }\n if(ret.error) {\n error.error = ret.error;\n }\n } else if(typeof ret === 'string') {\n // set custom error\n error.error = ret;\n }\n }\n\n // throw error\n throw error;\n }\n\n // no longer first cert in chain\n first = false;\n ++depth;\n } while(chain.length > 0);\n\n return true;\n};\n","/**\n * Node.js module for Forge mask generation functions.\n *\n * @author Stefan Siegl\n *\n * Copyright 2012 Stefan Siegl <stesie@brokenpipe.de>\n */\nvar forge = require('./forge');\nrequire('./mgf1');\n\nmodule.exports = forge.mgf = forge.mgf || {};\nforge.mgf.mgf1 = forge.mgf1;\n","/**\n * Javascript implementation of mask generation function MGF1.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nforge.mgf = forge.mgf || {};\nvar mgf1 = module.exports = forge.mgf.mgf1 = forge.mgf1 = forge.mgf1 || {};\n\n/**\n * Creates a MGF1 mask generation function object.\n *\n * @param md the message digest API to use (eg: forge.md.sha1.create()).\n *\n * @return a mask generation function object.\n */\nmgf1.create = function(md) {\n var mgf = {\n /**\n * Generate mask of specified length.\n *\n * @param {String} seed The seed for mask generation.\n * @param maskLen Number of bytes to generate.\n * @return {String} The generated mask.\n */\n generate: function(seed, maskLen) {\n /* 2. Let T be the empty octet string. */\n var t = new forge.util.ByteBuffer();\n\n /* 3. For counter from 0 to ceil(maskLen / hLen), do the following: */\n var len = Math.ceil(maskLen / md.digestLength);\n for(var i = 0; i < len; i++) {\n /* a. Convert counter to an octet string C of length 4 octets */\n var c = new forge.util.ByteBuffer();\n c.putInt32(i);\n\n /* b. Concatenate the hash of the seed mgfSeed and C to the octet\n * string T: */\n md.start();\n md.update(seed + c.getBytes());\n t.putBuffer(md.digest());\n }\n\n /* Output the leading maskLen octets of T as the octet string mask. */\n t.truncate(t.length() - maskLen);\n return t.getBytes();\n }\n };\n\n return mgf;\n};\n","/**\n * Javascript implementation of PKCS#1 PSS signature padding.\n *\n * @author Stefan Siegl\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n */\nvar forge = require('./forge');\nrequire('./random');\nrequire('./util');\n\n// shortcut for PSS API\nvar pss = module.exports = forge.pss = forge.pss || {};\n\n/**\n * Creates a PSS signature scheme object.\n *\n * There are several ways to provide a salt for encoding:\n *\n * 1. Specify the saltLength only and the built-in PRNG will generate it.\n * 2. Specify the saltLength and a custom PRNG with 'getBytesSync' defined that\n * will be used.\n * 3. Specify the salt itself as a forge.util.ByteBuffer.\n *\n * @param options the options to use:\n * md the message digest object to use, a forge md instance.\n * mgf the mask generation function to use, a forge mgf instance.\n * [saltLength] the length of the salt in octets.\n * [prng] the pseudo-random number generator to use to produce a salt.\n * [salt] the salt to use when encoding.\n *\n * @return a signature scheme object.\n */\npss.create = function(options) {\n // backwards compatibility w/legacy args: hash, mgf, sLen\n if(arguments.length === 3) {\n options = {\n md: arguments[0],\n mgf: arguments[1],\n saltLength: arguments[2]\n };\n }\n\n var hash = options.md;\n var mgf = options.mgf;\n var hLen = hash.digestLength;\n\n var salt_ = options.salt || null;\n if(typeof salt_ === 'string') {\n // assume binary-encoded string\n salt_ = forge.util.createBuffer(salt_);\n }\n\n var sLen;\n if('saltLength' in options) {\n sLen = options.saltLength;\n } else if(salt_ !== null) {\n sLen = salt_.length();\n } else {\n throw new Error('Salt length not specified or specific salt not given.');\n }\n\n if(salt_ !== null && salt_.length() !== sLen) {\n throw new Error('Given salt length does not match length of given salt.');\n }\n\n var prng = options.prng || forge.random;\n\n var pssobj = {};\n\n /**\n * Encodes a PSS signature.\n *\n * This function implements EMSA-PSS-ENCODE as per RFC 3447, section 9.1.1.\n *\n * @param md the message digest object with the hash to sign.\n * @param modsBits the length of the RSA modulus in bits.\n *\n * @return the encoded message as a binary-encoded string of length\n * ceil((modBits - 1) / 8).\n */\n pssobj.encode = function(md, modBits) {\n var i;\n var emBits = modBits - 1;\n var emLen = Math.ceil(emBits / 8);\n\n /* 2. Let mHash = Hash(M), an octet string of length hLen. */\n var mHash = md.digest().getBytes();\n\n /* 3. If emLen < hLen + sLen + 2, output \"encoding error\" and stop. */\n if(emLen < hLen + sLen + 2) {\n throw new Error('Message is too long to encrypt.');\n }\n\n /* 4. Generate a random octet string salt of length sLen; if sLen = 0,\n * then salt is the empty string. */\n var salt;\n if(salt_ === null) {\n salt = prng.getBytesSync(sLen);\n } else {\n salt = salt_.bytes();\n }\n\n /* 5. Let M' = (0x)00 00 00 00 00 00 00 00 || mHash || salt; */\n var m_ = new forge.util.ByteBuffer();\n m_.fillWithByte(0, 8);\n m_.putBytes(mHash);\n m_.putBytes(salt);\n\n /* 6. Let H = Hash(M'), an octet string of length hLen. */\n hash.start();\n hash.update(m_.getBytes());\n var h = hash.digest().getBytes();\n\n /* 7. Generate an octet string PS consisting of emLen - sLen - hLen - 2\n * zero octets. The length of PS may be 0. */\n var ps = new forge.util.ByteBuffer();\n ps.fillWithByte(0, emLen - sLen - hLen - 2);\n\n /* 8. Let DB = PS || 0x01 || salt; DB is an octet string of length\n * emLen - hLen - 1. */\n ps.putByte(0x01);\n ps.putBytes(salt);\n var db = ps.getBytes();\n\n /* 9. Let dbMask = MGF(H, emLen - hLen - 1). */\n var maskLen = emLen - hLen - 1;\n var dbMask = mgf.generate(h, maskLen);\n\n /* 10. Let maskedDB = DB \\xor dbMask. */\n var maskedDB = '';\n for(i = 0; i < maskLen; i++) {\n maskedDB += String.fromCharCode(db.charCodeAt(i) ^ dbMask.charCodeAt(i));\n }\n\n /* 11. Set the leftmost 8emLen - emBits bits of the leftmost octet in\n * maskedDB to zero. */\n var mask = (0xFF00 >> (8 * emLen - emBits)) & 0xFF;\n maskedDB = String.fromCharCode(maskedDB.charCodeAt(0) & ~mask) +\n maskedDB.substr(1);\n\n /* 12. Let EM = maskedDB || H || 0xbc.\n * 13. Output EM. */\n return maskedDB + h + String.fromCharCode(0xbc);\n };\n\n /**\n * Verifies a PSS signature.\n *\n * This function implements EMSA-PSS-VERIFY as per RFC 3447, section 9.1.2.\n *\n * @param mHash the message digest hash, as a binary-encoded string, to\n * compare against the signature.\n * @param em the encoded message, as a binary-encoded string\n * (RSA decryption result).\n * @param modsBits the length of the RSA modulus in bits.\n *\n * @return true if the signature was verified, false if not.\n */\n pssobj.verify = function(mHash, em, modBits) {\n var i;\n var emBits = modBits - 1;\n var emLen = Math.ceil(emBits / 8);\n\n /* c. Convert the message representative m to an encoded message EM\n * of length emLen = ceil((modBits - 1) / 8) octets, where modBits\n * is the length in bits of the RSA modulus n */\n em = em.substr(-emLen);\n\n /* 3. If emLen < hLen + sLen + 2, output \"inconsistent\" and stop. */\n if(emLen < hLen + sLen + 2) {\n throw new Error('Inconsistent parameters to PSS signature verification.');\n }\n\n /* 4. If the rightmost octet of EM does not have hexadecimal value\n * 0xbc, output \"inconsistent\" and stop. */\n if(em.charCodeAt(emLen - 1) !== 0xbc) {\n throw new Error('Encoded message does not end in 0xBC.');\n }\n\n /* 5. Let maskedDB be the leftmost emLen - hLen - 1 octets of EM, and\n * let H be the next hLen octets. */\n var maskLen = emLen - hLen - 1;\n var maskedDB = em.substr(0, maskLen);\n var h = em.substr(maskLen, hLen);\n\n /* 6. If the leftmost 8emLen - emBits bits of the leftmost octet in\n * maskedDB are not all equal to zero, output \"inconsistent\" and stop. */\n var mask = (0xFF00 >> (8 * emLen - emBits)) & 0xFF;\n if((maskedDB.charCodeAt(0) & mask) !== 0) {\n throw new Error('Bits beyond keysize not zero as expected.');\n }\n\n /* 7. Let dbMask = MGF(H, emLen - hLen - 1). */\n var dbMask = mgf.generate(h, maskLen);\n\n /* 8. Let DB = maskedDB \\xor dbMask. */\n var db = '';\n for(i = 0; i < maskLen; i++) {\n db += String.fromCharCode(maskedDB.charCodeAt(i) ^ dbMask.charCodeAt(i));\n }\n\n /* 9. Set the leftmost 8emLen - emBits bits of the leftmost octet\n * in DB to zero. */\n db = String.fromCharCode(db.charCodeAt(0) & ~mask) + db.substr(1);\n\n /* 10. If the emLen - hLen - sLen - 2 leftmost octets of DB are not zero\n * or if the octet at position emLen - hLen - sLen - 1 (the leftmost\n * position is \"position 1\") does not have hexadecimal value 0x01,\n * output \"inconsistent\" and stop. */\n var checkLen = emLen - hLen - sLen - 2;\n for(i = 0; i < checkLen; i++) {\n if(db.charCodeAt(i) !== 0x00) {\n throw new Error('Leftmost octets not zero as expected');\n }\n }\n\n if(db.charCodeAt(checkLen) !== 0x01) {\n throw new Error('Inconsistent PSS signature, 0x01 marker not found');\n }\n\n /* 11. Let salt be the last sLen octets of DB. */\n var salt = db.substr(-sLen);\n\n /* 12. Let M' = (0x)00 00 00 00 00 00 00 00 || mHash || salt */\n var m_ = new forge.util.ByteBuffer();\n m_.fillWithByte(0, 8);\n m_.putBytes(mHash);\n m_.putBytes(salt);\n\n /* 13. Let H' = Hash(M'), an octet string of length hLen. */\n hash.start();\n hash.update(m_.getBytes());\n var h_ = hash.digest().getBytes();\n\n /* 14. If H = H', output \"consistent.\" Otherwise, output \"inconsistent.\" */\n return h === h_;\n };\n\n return pssobj;\n};\n","// @ts-nocheck\n'use strict'\n\nrequire('node-forge/lib/x509')\nconst forge = require('node-forge/lib/forge')\nconst pki = forge.pki\n\n/**\n * Gets a self-signed X.509 certificate for the key.\n *\n * The output Uint8Array contains the PKCS #7 message in DER.\n *\n * TODO: move to libp2p-crypto package\n *\n * @param {KeyInfo} key - The id and name of the key\n * @param {RsaPrivateKey} privateKey - The naked key\n * @returns {Uint8Array}\n */\nconst certificateForKey = (key, privateKey) => {\n const publicKey = pki.setRsaPublicKey(privateKey.n, privateKey.e)\n const cert = pki.createCertificate()\n cert.publicKey = publicKey\n cert.serialNumber = '01'\n cert.validity.notBefore = new Date()\n cert.validity.notAfter = new Date()\n cert.validity.notAfter.setFullYear(cert.validity.notBefore.getFullYear() + 10)\n const attrs = [{\n name: 'organizationName',\n value: 'ipfs'\n }, {\n shortName: 'OU',\n value: 'keystore'\n }, {\n name: 'commonName',\n value: key.id\n }]\n cert.setSubject(attrs)\n cert.setIssuer(attrs)\n cert.setExtensions([{\n name: 'basicConstraints',\n cA: true\n }, {\n name: 'keyUsage',\n keyCertSign: true,\n digitalSignature: true,\n nonRepudiation: true,\n keyEncipherment: true,\n dataEncipherment: true\n }, {\n name: 'extKeyUsage',\n serverAuth: true,\n clientAuth: true,\n codeSigning: true,\n emailProtection: true,\n timeStamping: true\n }, {\n name: 'nsCertType',\n client: true,\n server: true,\n email: true,\n objsign: true,\n sslCA: true,\n emailCA: true,\n objCA: true\n }])\n // self-sign certificate\n cert.sign(privateKey)\n\n return cert\n}\n\n/**\n * Finds the first item in a collection that is matched in the\n * `asyncCompare` function.\n *\n * `asyncCompare` is an async function that must\n * resolve to either `true` or `false`.\n *\n * @param {Array} array\n * @param {function(*)} asyncCompare - An async function that returns a boolean\n */\nasync function findAsync (array, asyncCompare) {\n const promises = array.map(asyncCompare)\n const results = await Promise.all(promises)\n const index = results.findIndex(result => result)\n return array[index]\n}\n\nmodule.exports = {\n certificateForKey,\n findAsync\n}\n","// @ts-nocheck\n'use strict'\n\nconst mergeOptions = require('merge-options')\nconst { pipe } = require('it-pipe')\nconst { tap } = require('streaming-iterables')\nconst oldPeerLRU = require('./old-peers')\nconst { METRICS: defaultOptions } = require('../constants')\nconst Stats = require('./stats')\n\nconst initialCounters = [\n 'dataReceived',\n 'dataSent'\n]\n\nconst directionToEvent = {\n in: 'dataReceived',\n out: 'dataSent'\n}\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('libp2p-interfaces/src/transport/types').MultiaddrConnection} MultiaddrConnection\n */\n\n/**\n * @typedef MetricsProperties\n * @property {import('../connection-manager')} connectionManager\n *\n * @typedef MetricsOptions\n * @property {number} [computeThrottleMaxQueueSize = defaultOptions.computeThrottleMaxQueueSize]\n * @property {number} [computeThrottleTimeout = defaultOptions.computeThrottleTimeout]\n * @property {number[]} [movingAverageIntervals = defaultOptions.movingAverageIntervals]\n * @property {number} [maxOldPeersRetention = defaultOptions.maxOldPeersRetention]\n */\n\nclass Metrics {\n /**\n * @class\n * @param {MetricsProperties & MetricsOptions} options\n */\n constructor (options) {\n this._options = mergeOptions(defaultOptions, options)\n this._globalStats = new Stats(initialCounters, this._options)\n this._peerStats = new Map()\n this._protocolStats = new Map()\n this._oldPeers = oldPeerLRU(this._options.maxOldPeersRetention)\n this._running = false\n this._onMessage = this._onMessage.bind(this)\n this._connectionManager = options.connectionManager\n this._connectionManager.on('peer:disconnect', (connection) => {\n this.onPeerDisconnected(connection.remotePeer)\n })\n }\n\n /**\n * Must be called for stats to saved. Any data pushed for tracking\n * will be ignored.\n */\n start () {\n this._running = true\n }\n\n /**\n * Stops all averages timers and prevents new data from being tracked.\n * Once `stop` is called, `start` must be called to resume stats tracking.\n */\n stop () {\n this._running = false\n this._globalStats.stop()\n for (const stats of this._peerStats.values()) {\n stats.stop()\n }\n for (const stats of this._protocolStats.values()) {\n stats.stop()\n }\n }\n\n /**\n * Gets the global `Stats` object\n *\n * @returns {Stats}\n */\n get global () {\n return this._globalStats\n }\n\n /**\n * Returns a list of `PeerId` strings currently being tracked\n *\n * @returns {string[]}\n */\n get peers () {\n return Array.from(this._peerStats.keys())\n }\n\n /**\n * Returns the `Stats` object for the given `PeerId` whether it\n * is a live peer, or in the disconnected peer LRU cache.\n *\n * @param {PeerId} peerId\n * @returns {Stats}\n */\n forPeer (peerId) {\n const idString = peerId.toB58String()\n return this._peerStats.get(idString) || this._oldPeers.get(idString)\n }\n\n /**\n * Returns a list of all protocol strings currently being tracked.\n *\n * @returns {string[]}\n */\n get protocols () {\n return Array.from(this._protocolStats.keys())\n }\n\n /**\n * Returns the `Stats` object for the given `protocol`.\n *\n * @param {string} protocol\n * @returns {Stats}\n */\n forProtocol (protocol) {\n return this._protocolStats.get(protocol)\n }\n\n /**\n * Should be called when all connections to a given peer\n * have closed. The `Stats` collection for the peer will\n * be stopped and moved to an LRU for temporary retention.\n *\n * @param {PeerId} peerId\n */\n onPeerDisconnected (peerId) {\n const idString = peerId.toB58String()\n const peerStats = this._peerStats.get(idString)\n if (peerStats) {\n peerStats.stop()\n this._peerStats.delete(idString)\n this._oldPeers.set(idString, peerStats)\n }\n }\n\n /**\n * Takes the metadata for a message and tracks it in the\n * appropriate categories. If the protocol is present, protocol\n * stats will also be tracked.\n *\n * @private\n * @param {object} params\n * @param {PeerId} params.remotePeer - Remote peer\n * @param {string} [params.protocol] - Protocol string the stream is running\n * @param {string} params.direction - One of ['in','out']\n * @param {number} params.dataLength - Size of the message\n * @returns {void}\n */\n _onMessage ({ remotePeer, protocol, direction, dataLength }) {\n if (!this._running) return\n\n const key = directionToEvent[direction]\n\n let peerStats = this.forPeer(remotePeer)\n if (!peerStats) {\n peerStats = new Stats(initialCounters, this._options)\n this._peerStats.set(remotePeer.toB58String(), peerStats)\n }\n\n // Peer and global stats\n peerStats.push(key, dataLength)\n this._globalStats.push(key, dataLength)\n\n // Protocol specific stats\n if (protocol) {\n let protocolStats = this.forProtocol(protocol)\n if (!protocolStats) {\n protocolStats = new Stats(initialCounters, this._options)\n this._protocolStats.set(protocol, protocolStats)\n }\n protocolStats.push(key, dataLength)\n }\n }\n\n /**\n * Replaces the `PeerId` string with the given `peerId`.\n * If stats are already being tracked for the given `peerId`, the\n * placeholder stats will be merged with the existing stats.\n *\n * @param {PeerId} placeholder - A peerId string\n * @param {PeerId} peerId\n * @returns {void}\n */\n updatePlaceholder (placeholder, peerId) {\n if (!this._running) return\n const placeholderStats = this.forPeer(placeholder)\n const peerIdString = peerId.toB58String()\n const existingStats = this.forPeer(peerId)\n let mergedStats = placeholderStats\n\n // If we already have stats, merge the two\n if (existingStats) {\n // If existing, merge\n mergedStats = Metrics.mergeStats(existingStats, mergedStats)\n // Attempt to delete from the old peers list just in case it was tracked there\n this._oldPeers.delete(peerIdString)\n }\n\n this._peerStats.delete(placeholder.toB58String())\n this._peerStats.set(peerIdString, mergedStats)\n mergedStats.start()\n }\n\n /**\n * Tracks data running through a given Duplex Iterable `stream`. If\n * the `peerId` is not provided, a placeholder string will be created and\n * returned. This allows lazy tracking of a peer when the peer is not yet known.\n * When the `PeerId` is known, `Metrics.updatePlaceholder` should be called\n * with the placeholder string returned from here, and the known `PeerId`.\n *\n * @param {Object} options\n * @param {MultiaddrConnection} options.stream - A duplex iterable stream\n * @param {PeerId} [options.remotePeer] - The id of the remote peer that's connected\n * @param {string} [options.protocol] - The protocol the stream is running\n * @returns {MultiaddrConnection} The peerId string or placeholder string\n */\n trackStream ({ stream, remotePeer, protocol }) {\n const metrics = this\n const _source = stream.source\n stream.source = tap(chunk => metrics._onMessage({\n remotePeer,\n protocol,\n direction: 'in',\n dataLength: chunk.length\n }))(_source)\n\n const _sink = stream.sink\n stream.sink = source => {\n return pipe(\n source,\n tap(chunk => metrics._onMessage({\n remotePeer,\n protocol,\n direction: 'out',\n dataLength: chunk.length\n })),\n _sink\n )\n }\n\n return stream\n }\n\n /**\n * Merges `other` into `target`. `target` will be modified\n * and returned.\n *\n * @param {Stats} target\n * @param {Stats} other\n * @returns {Stats}\n */\n static mergeStats (target, other) {\n target.stop()\n other.stop()\n\n // Merge queues\n target._queue = [...target._queue, ...other._queue]\n\n // TODO: how to merge moving averages?\n return target\n }\n}\n\nmodule.exports = Metrics\n","'use strict'\n\nconst LRU = require('hashlru')\n\n/**\n * Creates and returns a Least Recently Used Cache\n *\n * @param {number} maxSize\n * @returns {any}\n */\nmodule.exports = (maxSize) => {\n // @ts-ignore LRU expression is not callable\n const patched = LRU(maxSize)\n patched.delete = patched.remove\n return patched\n}\n","// @ts-nocheck\n'use strict'\n\nconst { EventEmitter } = require('events')\nconst { BigNumber: Big } = require('bignumber.js')\nconst MovingAverage = require('@vascosantos/moving-average')\nconst retimer = require('retimer')\n\n/**\n * @typedef {import('@vascosantos/moving-average').IMovingAverage} IMovingAverage\n */\n\nclass Stats extends EventEmitter {\n /**\n * A queue based manager for stat processing\n *\n * @class\n * @param {string[]} initialCounters\n * @param {any} options\n */\n constructor (initialCounters, options) {\n super()\n\n this._options = options\n this._queue = []\n\n /** @type {{ dataReceived: Big, dataSent: Big }} */\n this._stats = {\n dataReceived: Big(0),\n dataSent: Big(0)\n }\n\n this._frequencyLastTime = Date.now()\n this._frequencyAccumulators = {}\n\n /** @type {{ dataReceived: IMovingAverage[], dataSent: IMovingAverage[] }} */\n this._movingAverages = {}\n\n this._update = this._update.bind(this)\n\n const intervals = this._options.movingAverageIntervals\n\n for (let i = 0; i < initialCounters.length; i++) {\n const key = initialCounters[i]\n this._stats[key] = Big(0)\n this._movingAverages[key] = {}\n for (let k = 0; k < intervals.length; k++) {\n const interval = intervals[k]\n const ma = this._movingAverages[key][interval] = MovingAverage(interval)\n ma.push(this._frequencyLastTime, 0)\n }\n }\n }\n\n /**\n * Initializes the internal timer if there are items in the queue. This\n * should only need to be called if `Stats.stop` was previously called, as\n * `Stats.push` will also start the processing.\n *\n * @returns {void}\n */\n start () {\n if (this._queue.length) {\n this._resetComputeTimeout()\n }\n }\n\n /**\n * Stops processing and computing of stats by clearing the internal\n * timer.\n *\n * @returns {void}\n */\n stop () {\n if (this._timeout) {\n this._timeout.clear()\n this._timeout = null\n }\n }\n\n /**\n * Returns a clone of the current stats.\n */\n get snapshot () {\n return Object.assign({}, this._stats)\n }\n\n /**\n * Returns a clone of the internal movingAverages\n */\n get movingAverages () {\n return Object.assign({}, this._movingAverages)\n }\n\n /**\n * Returns a plain JSON object of the stats\n *\n * @returns {*}\n */\n toJSON () {\n const snapshot = this.snapshot\n const movingAverages = this.movingAverages\n const data = {\n dataReceived: snapshot.dataReceived.toString(),\n dataSent: snapshot.dataSent.toString(),\n movingAverages: {}\n }\n\n const counters = Object.keys(movingAverages)\n for (const key of counters) {\n data.movingAverages[key] = {}\n for (const interval of Object.keys(movingAverages[key])) {\n data.movingAverages[key][interval] = movingAverages[key][interval].movingAverage()\n }\n }\n\n return data\n }\n\n /**\n * Pushes the given operation data to the queue, along with the\n * current Timestamp, then resets the update timer.\n *\n * @param {string} counter\n * @param {number} inc\n * @returns {void}\n */\n push (counter, inc) {\n this._queue.push([counter, inc, Date.now()])\n this._resetComputeTimeout()\n }\n\n /**\n * Resets the timeout for triggering updates.\n *\n * @private\n * @returns {void}\n */\n _resetComputeTimeout () {\n this._timeout = retimer(this._update, this._nextTimeout())\n }\n\n /**\n * Calculates and returns the timeout for the next update based on\n * the urgency of the update.\n *\n * @private\n * @returns {number}\n */\n _nextTimeout () {\n // calculate the need for an update, depending on the queue length\n const urgency = this._queue.length / this._options.computeThrottleMaxQueueSize\n const timeout = Math.max(this._options.computeThrottleTimeout * (1 - urgency), 0)\n return timeout\n }\n\n /**\n * If there are items in the queue, they will will be processed and\n * the frequency for all items will be updated based on the Timestamp\n * of the last item in the queue. The `update` event will also be emitted\n * with the latest stats.\n *\n * If there are no items in the queue, no action is taken.\n *\n * @private\n * @returns {void}\n */\n _update () {\n this._timeout = null\n if (this._queue.length) {\n let last\n for (last of this._queue) {\n this._applyOp(last)\n }\n this._queue = []\n\n this._updateFrequency(last[2]) // contains timestamp of last op\n\n this.emit('update', this._stats)\n }\n }\n\n /**\n * For each key in the stats, the frequency and moving averages\n * will be updated via Stats._updateFrequencyFor based on the time\n * difference between calls to this method.\n *\n * @private\n * @param {Timestamp} latestTime\n * @returns {void}\n */\n _updateFrequency (latestTime) {\n const timeDiff = latestTime - this._frequencyLastTime\n\n Object.keys(this._stats).forEach((key) => {\n this._updateFrequencyFor(key, timeDiff, latestTime)\n })\n\n this._frequencyLastTime = latestTime\n }\n\n /**\n * Updates the `movingAverages` for the given `key` and also\n * resets the `frequencyAccumulator` for the `key`.\n *\n * @private\n * @param {string} key\n * @param {number} timeDiffMS - Time in milliseconds\n * @param {Timestamp} latestTime - Time in ticks\n * @returns {void}\n */\n _updateFrequencyFor (key, timeDiffMS, latestTime) {\n const count = this._frequencyAccumulators[key] || 0\n this._frequencyAccumulators[key] = 0\n // if `timeDiff` is zero, `hz` becomes Infinity, so we fallback to 1ms\n const safeTimeDiff = timeDiffMS || 1\n const hz = (count / safeTimeDiff) * 1000\n\n let movingAverages = this._movingAverages[key]\n if (!movingAverages) {\n movingAverages = this._movingAverages[key] = {}\n }\n\n const intervals = this._options.movingAverageIntervals\n\n for (let i = 0; i < intervals.length; i++) {\n const movingAverageInterval = intervals[i]\n let movingAverage = movingAverages[movingAverageInterval]\n if (!movingAverage) {\n movingAverage = movingAverages[movingAverageInterval] = MovingAverage(movingAverageInterval)\n }\n movingAverage.push(latestTime, hz)\n }\n }\n\n /**\n * For the given operation, `op`, the stats and `frequencyAccumulator`\n * will be updated or initialized if they don't already exist.\n *\n * @private\n * @param {{string, number}[]} op\n * @throws {InvalidNumber}\n * @returns {void}\n */\n _applyOp (op) {\n const key = op[0]\n const inc = op[1]\n\n if (typeof inc !== 'number') {\n throw new Error(`invalid increment number: ${inc}`)\n }\n\n let n\n\n if (!Object.prototype.hasOwnProperty.call(this._stats, key)) {\n n = this._stats[key] = Big(0)\n } else {\n n = this._stats[key]\n }\n this._stats[key] = n.plus(inc)\n\n if (!this._frequencyAccumulators[key]) {\n this._frequencyAccumulators[key] = 0\n }\n this._frequencyAccumulators[key] += inc\n }\n}\n\nmodule.exports = Stats\n",";(function (globalObject) {\r\n 'use strict';\r\n\r\n/*\r\n * bignumber.js v9.0.1\r\n * A JavaScript library for arbitrary-precision arithmetic.\r\n * https://github.com/MikeMcl/bignumber.js\r\n * Copyright (c) 2020 Michael Mclaughlin <M8ch88l@gmail.com>\r\n * MIT Licensed.\r\n *\r\n * BigNumber.prototype methods | BigNumber methods\r\n * |\r\n * absoluteValue abs | clone\r\n * comparedTo | config set\r\n * decimalPlaces dp | DECIMAL_PLACES\r\n * dividedBy div | ROUNDING_MODE\r\n * dividedToIntegerBy idiv | EXPONENTIAL_AT\r\n * exponentiatedBy pow | RANGE\r\n * integerValue | CRYPTO\r\n * isEqualTo eq | MODULO_MODE\r\n * isFinite | POW_PRECISION\r\n * isGreaterThan gt | FORMAT\r\n * isGreaterThanOrEqualTo gte | ALPHABET\r\n * isInteger | isBigNumber\r\n * isLessThan lt | maximum max\r\n * isLessThanOrEqualTo lte | minimum min\r\n * isNaN | random\r\n * isNegative | sum\r\n * isPositive |\r\n * isZero |\r\n * minus |\r\n * modulo mod |\r\n * multipliedBy times |\r\n * negated |\r\n * plus |\r\n * precision sd |\r\n * shiftedBy |\r\n * squareRoot sqrt |\r\n * toExponential |\r\n * toFixed |\r\n * toFormat |\r\n * toFraction |\r\n * toJSON |\r\n * toNumber |\r\n * toPrecision |\r\n * toString |\r\n * valueOf |\r\n *\r\n */\r\n\r\n\r\n var BigNumber,\r\n isNumeric = /^-?(?:\\d+(?:\\.\\d*)?|\\.\\d+)(?:e[+-]?\\d+)?$/i,\r\n mathceil = Math.ceil,\r\n mathfloor = Math.floor,\r\n\r\n bignumberError = '[BigNumber Error] ',\r\n tooManyDigits = bignumberError + 'Number primitive has more than 15 significant digits: ',\r\n\r\n BASE = 1e14,\r\n LOG_BASE = 14,\r\n MAX_SAFE_INTEGER = 0x1fffffffffffff, // 2^53 - 1\r\n // MAX_INT32 = 0x7fffffff, // 2^31 - 1\r\n POWS_TEN = [1, 10, 100, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9, 1e10, 1e11, 1e12, 1e13],\r\n SQRT_BASE = 1e7,\r\n\r\n // EDITABLE\r\n // The limit on the value of DECIMAL_PLACES, TO_EXP_NEG, TO_EXP_POS, MIN_EXP, MAX_EXP, and\r\n // the arguments to toExponential, toFixed, toFormat, and toPrecision.\r\n MAX = 1E9; // 0 to MAX_INT32\r\n\r\n\r\n /*\r\n * Create and return a BigNumber constructor.\r\n */\r\n function clone(configObject) {\r\n var div, convertBase, parseNumeric,\r\n P = BigNumber.prototype = { constructor: BigNumber, toString: null, valueOf: null },\r\n ONE = new BigNumber(1),\r\n\r\n\r\n //----------------------------- EDITABLE CONFIG DEFAULTS -------------------------------\r\n\r\n\r\n // The default values below must be integers within the inclusive ranges stated.\r\n // The values can also be changed at run-time using BigNumber.set.\r\n\r\n // The maximum number of decimal places for operations involving division.\r\n DECIMAL_PLACES = 20, // 0 to MAX\r\n\r\n // The rounding mode used when rounding to the above decimal places, and when using\r\n // toExponential, toFixed, toFormat and toPrecision, and round (default value).\r\n // UP 0 Away from zero.\r\n // DOWN 1 Towards zero.\r\n // CEIL 2 Towards +Infinity.\r\n // FLOOR 3 Towards -Infinity.\r\n // HALF_UP 4 Towards nearest neighbour. If equidistant, up.\r\n // HALF_DOWN 5 Towards nearest neighbour. If equidistant, down.\r\n // HALF_EVEN 6 Towards nearest neighbour. If equidistant, towards even neighbour.\r\n // HALF_CEIL 7 Towards nearest neighbour. If equidistant, towards +Infinity.\r\n // HALF_FLOOR 8 Towards nearest neighbour. If equidistant, towards -Infinity.\r\n ROUNDING_MODE = 4, // 0 to 8\r\n\r\n // EXPONENTIAL_AT : [TO_EXP_NEG , TO_EXP_POS]\r\n\r\n // The exponent value at and beneath which toString returns exponential notation.\r\n // Number type: -7\r\n TO_EXP_NEG = -7, // 0 to -MAX\r\n\r\n // The exponent value at and above which toString returns exponential notation.\r\n // Number type: 21\r\n TO_EXP_POS = 21, // 0 to MAX\r\n\r\n // RANGE : [MIN_EXP, MAX_EXP]\r\n\r\n // The minimum exponent value, beneath which underflow to zero occurs.\r\n // Number type: -324 (5e-324)\r\n MIN_EXP = -1e7, // -1 to -MAX\r\n\r\n // The maximum exponent value, above which overflow to Infinity occurs.\r\n // Number type: 308 (1.7976931348623157e+308)\r\n // For MAX_EXP > 1e7, e.g. new BigNumber('1e100000000').plus(1) may be slow.\r\n MAX_EXP = 1e7, // 1 to MAX\r\n\r\n // Whether to use cryptographically-secure random number generation, if available.\r\n CRYPTO = false, // true or false\r\n\r\n // The modulo mode used when calculating the modulus: a mod n.\r\n // The quotient (q = a / n) is calculated according to the corresponding rounding mode.\r\n // The remainder (r) is calculated as: r = a - n * q.\r\n //\r\n // UP 0 The remainder is positive if the dividend is negative, else is negative.\r\n // DOWN 1 The remainder has the same sign as the dividend.\r\n // This modulo mode is commonly known as 'truncated division' and is\r\n // equivalent to (a % n) in JavaScript.\r\n // FLOOR 3 The remainder has the same sign as the divisor (Python %).\r\n // HALF_EVEN 6 This modulo mode implements the IEEE 754 remainder function.\r\n // EUCLID 9 Euclidian division. q = sign(n) * floor(a / abs(n)).\r\n // The remainder is always positive.\r\n //\r\n // The truncated division, floored division, Euclidian division and IEEE 754 remainder\r\n // modes are commonly used for the modulus operation.\r\n // Although the other rounding modes can also be used, they may not give useful results.\r\n MODULO_MODE = 1, // 0 to 9\r\n\r\n // The maximum number of significant digits of the result of the exponentiatedBy operation.\r\n // If POW_PRECISION is 0, there will be unlimited significant digits.\r\n POW_PRECISION = 0, // 0 to MAX\r\n\r\n // The format specification used by the BigNumber.prototype.toFormat method.\r\n FORMAT = {\r\n prefix: '',\r\n groupSize: 3,\r\n secondaryGroupSize: 0,\r\n groupSeparator: ',',\r\n decimalSeparator: '.',\r\n fractionGroupSize: 0,\r\n fractionGroupSeparator: '\\xA0', // non-breaking space\r\n suffix: ''\r\n },\r\n\r\n // The alphabet used for base conversion. It must be at least 2 characters long, with no '+',\r\n // '-', '.', whitespace, or repeated character.\r\n // '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ$_'\r\n ALPHABET = '0123456789abcdefghijklmnopqrstuvwxyz';\r\n\r\n\r\n //------------------------------------------------------------------------------------------\r\n\r\n\r\n // CONSTRUCTOR\r\n\r\n\r\n /*\r\n * The BigNumber constructor and exported function.\r\n * Create and return a new instance of a BigNumber object.\r\n *\r\n * v {number|string|BigNumber} A numeric value.\r\n * [b] {number} The base of v. Integer, 2 to ALPHABET.length inclusive.\r\n */\r\n function BigNumber(v, b) {\r\n var alphabet, c, caseChanged, e, i, isNum, len, str,\r\n x = this;\r\n\r\n // Enable constructor call without `new`.\r\n if (!(x instanceof BigNumber)) return new BigNumber(v, b);\r\n\r\n if (b == null) {\r\n\r\n if (v && v._isBigNumber === true) {\r\n x.s = v.s;\r\n\r\n if (!v.c || v.e > MAX_EXP) {\r\n x.c = x.e = null;\r\n } else if (v.e < MIN_EXP) {\r\n x.c = [x.e = 0];\r\n } else {\r\n x.e = v.e;\r\n x.c = v.c.slice();\r\n }\r\n\r\n return;\r\n }\r\n\r\n if ((isNum = typeof v == 'number') && v * 0 == 0) {\r\n\r\n // Use `1 / n` to handle minus zero also.\r\n x.s = 1 / v < 0 ? (v = -v, -1) : 1;\r\n\r\n // Fast path for integers, where n < 2147483648 (2**31).\r\n if (v === ~~v) {\r\n for (e = 0, i = v; i >= 10; i /= 10, e++);\r\n\r\n if (e > MAX_EXP) {\r\n x.c = x.e = null;\r\n } else {\r\n x.e = e;\r\n x.c = [v];\r\n }\r\n\r\n return;\r\n }\r\n\r\n str = String(v);\r\n } else {\r\n\r\n if (!isNumeric.test(str = String(v))) return parseNumeric(x, str, isNum);\r\n\r\n x.s = str.charCodeAt(0) == 45 ? (str = str.slice(1), -1) : 1;\r\n }\r\n\r\n // Decimal point?\r\n if ((e = str.indexOf('.')) > -1) str = str.replace('.', '');\r\n\r\n // Exponential form?\r\n if ((i = str.search(/e/i)) > 0) {\r\n\r\n // Determine exponent.\r\n if (e < 0) e = i;\r\n e += +str.slice(i + 1);\r\n str = str.substring(0, i);\r\n } else if (e < 0) {\r\n\r\n // Integer.\r\n e = str.length;\r\n }\r\n\r\n } else {\r\n\r\n // '[BigNumber Error] Base {not a primitive number|not an integer|out of range}: {b}'\r\n intCheck(b, 2, ALPHABET.length, 'Base');\r\n\r\n // Allow exponential notation to be used with base 10 argument, while\r\n // also rounding to DECIMAL_PLACES as with other bases.\r\n if (b == 10) {\r\n x = new BigNumber(v);\r\n return round(x, DECIMAL_PLACES + x.e + 1, ROUNDING_MODE);\r\n }\r\n\r\n str = String(v);\r\n\r\n if (isNum = typeof v == 'number') {\r\n\r\n // Avoid potential interpretation of Infinity and NaN as base 44+ values.\r\n if (v * 0 != 0) return parseNumeric(x, str, isNum, b);\r\n\r\n x.s = 1 / v < 0 ? (str = str.slice(1), -1) : 1;\r\n\r\n // '[BigNumber Error] Number primitive has more than 15 significant digits: {n}'\r\n if (BigNumber.DEBUG && str.replace(/^0\\.0*|\\./, '').length > 15) {\r\n throw Error\r\n (tooManyDigits + v);\r\n }\r\n } else {\r\n x.s = str.charCodeAt(0) === 45 ? (str = str.slice(1), -1) : 1;\r\n }\r\n\r\n alphabet = ALPHABET.slice(0, b);\r\n e = i = 0;\r\n\r\n // Check that str is a valid base b number.\r\n // Don't use RegExp, so alphabet can contain special characters.\r\n for (len = str.length; i < len; i++) {\r\n if (alphabet.indexOf(c = str.charAt(i)) < 0) {\r\n if (c == '.') {\r\n\r\n // If '.' is not the first character and it has not be found before.\r\n if (i > e) {\r\n e = len;\r\n continue;\r\n }\r\n } else if (!caseChanged) {\r\n\r\n // Allow e.g. hexadecimal 'FF' as well as 'ff'.\r\n if (str == str.toUpperCase() && (str = str.toLowerCase()) ||\r\n str == str.toLowerCase() && (str = str.toUpperCase())) {\r\n caseChanged = true;\r\n i = -1;\r\n e = 0;\r\n continue;\r\n }\r\n }\r\n\r\n return parseNumeric(x, String(v), isNum, b);\r\n }\r\n }\r\n\r\n // Prevent later check for length on converted number.\r\n isNum = false;\r\n str = convertBase(str, b, 10, x.s);\r\n\r\n // Decimal point?\r\n if ((e = str.indexOf('.')) > -1) str = str.replace('.', '');\r\n else e = str.length;\r\n }\r\n\r\n // Determine leading zeros.\r\n for (i = 0; str.charCodeAt(i) === 48; i++);\r\n\r\n // Determine trailing zeros.\r\n for (len = str.length; str.charCodeAt(--len) === 48;);\r\n\r\n if (str = str.slice(i, ++len)) {\r\n len -= i;\r\n\r\n // '[BigNumber Error] Number primitive has more than 15 significant digits: {n}'\r\n if (isNum && BigNumber.DEBUG &&\r\n len > 15 && (v > MAX_SAFE_INTEGER || v !== mathfloor(v))) {\r\n throw Error\r\n (tooManyDigits + (x.s * v));\r\n }\r\n\r\n // Overflow?\r\n if ((e = e - i - 1) > MAX_EXP) {\r\n\r\n // Infinity.\r\n x.c = x.e = null;\r\n\r\n // Underflow?\r\n } else if (e < MIN_EXP) {\r\n\r\n // Zero.\r\n x.c = [x.e = 0];\r\n } else {\r\n x.e = e;\r\n x.c = [];\r\n\r\n // Transform base\r\n\r\n // e is the base 10 exponent.\r\n // i is where to slice str to get the first element of the coefficient array.\r\n i = (e + 1) % LOG_BASE;\r\n if (e < 0) i += LOG_BASE; // i < 1\r\n\r\n if (i < len) {\r\n if (i) x.c.push(+str.slice(0, i));\r\n\r\n for (len -= LOG_BASE; i < len;) {\r\n x.c.push(+str.slice(i, i += LOG_BASE));\r\n }\r\n\r\n i = LOG_BASE - (str = str.slice(i)).length;\r\n } else {\r\n i -= len;\r\n }\r\n\r\n for (; i--; str += '0');\r\n x.c.push(+str);\r\n }\r\n } else {\r\n\r\n // Zero.\r\n x.c = [x.e = 0];\r\n }\r\n }\r\n\r\n\r\n // CONSTRUCTOR PROPERTIES\r\n\r\n\r\n BigNumber.clone = clone;\r\n\r\n BigNumber.ROUND_UP = 0;\r\n BigNumber.ROUND_DOWN = 1;\r\n BigNumber.ROUND_CEIL = 2;\r\n BigNumber.ROUND_FLOOR = 3;\r\n BigNumber.ROUND_HALF_UP = 4;\r\n BigNumber.ROUND_HALF_DOWN = 5;\r\n BigNumber.ROUND_HALF_EVEN = 6;\r\n BigNumber.ROUND_HALF_CEIL = 7;\r\n BigNumber.ROUND_HALF_FLOOR = 8;\r\n BigNumber.EUCLID = 9;\r\n\r\n\r\n /*\r\n * Configure infrequently-changing library-wide settings.\r\n *\r\n * Accept an object with the following optional properties (if the value of a property is\r\n * a number, it must be an integer within the inclusive range stated):\r\n *\r\n * DECIMAL_PLACES {number} 0 to MAX\r\n * ROUNDING_MODE {number} 0 to 8\r\n * EXPONENTIAL_AT {number|number[]} -MAX to MAX or [-MAX to 0, 0 to MAX]\r\n * RANGE {number|number[]} -MAX to MAX (not zero) or [-MAX to -1, 1 to MAX]\r\n * CRYPTO {boolean} true or false\r\n * MODULO_MODE {number} 0 to 9\r\n * POW_PRECISION {number} 0 to MAX\r\n * ALPHABET {string} A string of two or more unique characters which does\r\n * not contain '.'.\r\n * FORMAT {object} An object with some of the following properties:\r\n * prefix {string}\r\n * groupSize {number}\r\n * secondaryGroupSize {number}\r\n * groupSeparator {string}\r\n * decimalSeparator {string}\r\n * fractionGroupSize {number}\r\n * fractionGroupSeparator {string}\r\n * suffix {string}\r\n *\r\n * (The values assigned to the above FORMAT object properties are not checked for validity.)\r\n *\r\n * E.g.\r\n * BigNumber.config({ DECIMAL_PLACES : 20, ROUNDING_MODE : 4 })\r\n *\r\n * Ignore properties/parameters set to null or undefined, except for ALPHABET.\r\n *\r\n * Return an object with the properties current values.\r\n */\r\n BigNumber.config = BigNumber.set = function (obj) {\r\n var p, v;\r\n\r\n if (obj != null) {\r\n\r\n if (typeof obj == 'object') {\r\n\r\n // DECIMAL_PLACES {number} Integer, 0 to MAX inclusive.\r\n // '[BigNumber Error] DECIMAL_PLACES {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'DECIMAL_PLACES')) {\r\n v = obj[p];\r\n intCheck(v, 0, MAX, p);\r\n DECIMAL_PLACES = v;\r\n }\r\n\r\n // ROUNDING_MODE {number} Integer, 0 to 8 inclusive.\r\n // '[BigNumber Error] ROUNDING_MODE {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'ROUNDING_MODE')) {\r\n v = obj[p];\r\n intCheck(v, 0, 8, p);\r\n ROUNDING_MODE = v;\r\n }\r\n\r\n // EXPONENTIAL_AT {number|number[]}\r\n // Integer, -MAX to MAX inclusive or\r\n // [integer -MAX to 0 inclusive, 0 to MAX inclusive].\r\n // '[BigNumber Error] EXPONENTIAL_AT {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'EXPONENTIAL_AT')) {\r\n v = obj[p];\r\n if (v && v.pop) {\r\n intCheck(v[0], -MAX, 0, p);\r\n intCheck(v[1], 0, MAX, p);\r\n TO_EXP_NEG = v[0];\r\n TO_EXP_POS = v[1];\r\n } else {\r\n intCheck(v, -MAX, MAX, p);\r\n TO_EXP_NEG = -(TO_EXP_POS = v < 0 ? -v : v);\r\n }\r\n }\r\n\r\n // RANGE {number|number[]} Non-zero integer, -MAX to MAX inclusive or\r\n // [integer -MAX to -1 inclusive, integer 1 to MAX inclusive].\r\n // '[BigNumber Error] RANGE {not a primitive number|not an integer|out of range|cannot be zero}: {v}'\r\n if (obj.hasOwnProperty(p = 'RANGE')) {\r\n v = obj[p];\r\n if (v && v.pop) {\r\n intCheck(v[0], -MAX, -1, p);\r\n intCheck(v[1], 1, MAX, p);\r\n MIN_EXP = v[0];\r\n MAX_EXP = v[1];\r\n } else {\r\n intCheck(v, -MAX, MAX, p);\r\n if (v) {\r\n MIN_EXP = -(MAX_EXP = v < 0 ? -v : v);\r\n } else {\r\n throw Error\r\n (bignumberError + p + ' cannot be zero: ' + v);\r\n }\r\n }\r\n }\r\n\r\n // CRYPTO {boolean} true or false.\r\n // '[BigNumber Error] CRYPTO not true or false: {v}'\r\n // '[BigNumber Error] crypto unavailable'\r\n if (obj.hasOwnProperty(p = 'CRYPTO')) {\r\n v = obj[p];\r\n if (v === !!v) {\r\n if (v) {\r\n if (typeof crypto != 'undefined' && crypto &&\r\n (crypto.getRandomValues || crypto.randomBytes)) {\r\n CRYPTO = v;\r\n } else {\r\n CRYPTO = !v;\r\n throw Error\r\n (bignumberError + 'crypto unavailable');\r\n }\r\n } else {\r\n CRYPTO = v;\r\n }\r\n } else {\r\n throw Error\r\n (bignumberError + p + ' not true or false: ' + v);\r\n }\r\n }\r\n\r\n // MODULO_MODE {number} Integer, 0 to 9 inclusive.\r\n // '[BigNumber Error] MODULO_MODE {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'MODULO_MODE')) {\r\n v = obj[p];\r\n intCheck(v, 0, 9, p);\r\n MODULO_MODE = v;\r\n }\r\n\r\n // POW_PRECISION {number} Integer, 0 to MAX inclusive.\r\n // '[BigNumber Error] POW_PRECISION {not a primitive number|not an integer|out of range}: {v}'\r\n if (obj.hasOwnProperty(p = 'POW_PRECISION')) {\r\n v = obj[p];\r\n intCheck(v, 0, MAX, p);\r\n POW_PRECISION = v;\r\n }\r\n\r\n // FORMAT {object}\r\n // '[BigNumber Error] FORMAT not an object: {v}'\r\n if (obj.hasOwnProperty(p = 'FORMAT')) {\r\n v = obj[p];\r\n if (typeof v == 'object') FORMAT = v;\r\n else throw Error\r\n (bignumberError + p + ' not an object: ' + v);\r\n }\r\n\r\n // ALPHABET {string}\r\n // '[BigNumber Error] ALPHABET invalid: {v}'\r\n if (obj.hasOwnProperty(p = 'ALPHABET')) {\r\n v = obj[p];\r\n\r\n // Disallow if less than two characters,\r\n // or if it contains '+', '-', '.', whitespace, or a repeated character.\r\n if (typeof v == 'string' && !/^.?$|[+\\-.\\s]|(.).*\\1/.test(v)) {\r\n ALPHABET = v;\r\n } else {\r\n throw Error\r\n (bignumberError + p + ' invalid: ' + v);\r\n }\r\n }\r\n\r\n } else {\r\n\r\n // '[BigNumber Error] Object expected: {v}'\r\n throw Error\r\n (bignumberError + 'Object expected: ' + obj);\r\n }\r\n }\r\n\r\n return {\r\n DECIMAL_PLACES: DECIMAL_PLACES,\r\n ROUNDING_MODE: ROUNDING_MODE,\r\n EXPONENTIAL_AT: [TO_EXP_NEG, TO_EXP_POS],\r\n RANGE: [MIN_EXP, MAX_EXP],\r\n CRYPTO: CRYPTO,\r\n MODULO_MODE: MODULO_MODE,\r\n POW_PRECISION: POW_PRECISION,\r\n FORMAT: FORMAT,\r\n ALPHABET: ALPHABET\r\n };\r\n };\r\n\r\n\r\n /*\r\n * Return true if v is a BigNumber instance, otherwise return false.\r\n *\r\n * If BigNumber.DEBUG is true, throw if a BigNumber instance is not well-formed.\r\n *\r\n * v {any}\r\n *\r\n * '[BigNumber Error] Invalid BigNumber: {v}'\r\n */\r\n BigNumber.isBigNumber = function (v) {\r\n if (!v || v._isBigNumber !== true) return false;\r\n if (!BigNumber.DEBUG) return true;\r\n\r\n var i, n,\r\n c = v.c,\r\n e = v.e,\r\n s = v.s;\r\n\r\n out: if ({}.toString.call(c) == '[object Array]') {\r\n\r\n if ((s === 1 || s === -1) && e >= -MAX && e <= MAX && e === mathfloor(e)) {\r\n\r\n // If the first element is zero, the BigNumber value must be zero.\r\n if (c[0] === 0) {\r\n if (e === 0 && c.length === 1) return true;\r\n break out;\r\n }\r\n\r\n // Calculate number of digits that c[0] should have, based on the exponent.\r\n i = (e + 1) % LOG_BASE;\r\n if (i < 1) i += LOG_BASE;\r\n\r\n // Calculate number of digits of c[0].\r\n //if (Math.ceil(Math.log(c[0] + 1) / Math.LN10) == i) {\r\n if (String(c[0]).length == i) {\r\n\r\n for (i = 0; i < c.length; i++) {\r\n n = c[i];\r\n if (n < 0 || n >= BASE || n !== mathfloor(n)) break out;\r\n }\r\n\r\n // Last element cannot be zero, unless it is the only element.\r\n if (n !== 0) return true;\r\n }\r\n }\r\n\r\n // Infinity/NaN\r\n } else if (c === null && e === null && (s === null || s === 1 || s === -1)) {\r\n return true;\r\n }\r\n\r\n throw Error\r\n (bignumberError + 'Invalid BigNumber: ' + v);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the maximum of the arguments.\r\n *\r\n * arguments {number|string|BigNumber}\r\n */\r\n BigNumber.maximum = BigNumber.max = function () {\r\n return maxOrMin(arguments, P.lt);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the minimum of the arguments.\r\n *\r\n * arguments {number|string|BigNumber}\r\n */\r\n BigNumber.minimum = BigNumber.min = function () {\r\n return maxOrMin(arguments, P.gt);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber with a random value equal to or greater than 0 and less than 1,\r\n * and with dp, or DECIMAL_PLACES if dp is omitted, decimal places (or less if trailing\r\n * zeros are produced).\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp}'\r\n * '[BigNumber Error] crypto unavailable'\r\n */\r\n BigNumber.random = (function () {\r\n var pow2_53 = 0x20000000000000;\r\n\r\n // Return a 53 bit integer n, where 0 <= n < 9007199254740992.\r\n // Check if Math.random() produces more than 32 bits of randomness.\r\n // If it does, assume at least 53 bits are produced, otherwise assume at least 30 bits.\r\n // 0x40000000 is 2^30, 0x800000 is 2^23, 0x1fffff is 2^21 - 1.\r\n var random53bitInt = (Math.random() * pow2_53) & 0x1fffff\r\n ? function () { return mathfloor(Math.random() * pow2_53); }\r\n : function () { return ((Math.random() * 0x40000000 | 0) * 0x800000) +\r\n (Math.random() * 0x800000 | 0); };\r\n\r\n return function (dp) {\r\n var a, b, e, k, v,\r\n i = 0,\r\n c = [],\r\n rand = new BigNumber(ONE);\r\n\r\n if (dp == null) dp = DECIMAL_PLACES;\r\n else intCheck(dp, 0, MAX);\r\n\r\n k = mathceil(dp / LOG_BASE);\r\n\r\n if (CRYPTO) {\r\n\r\n // Browsers supporting crypto.getRandomValues.\r\n if (crypto.getRandomValues) {\r\n\r\n a = crypto.getRandomValues(new Uint32Array(k *= 2));\r\n\r\n for (; i < k;) {\r\n\r\n // 53 bits:\r\n // ((Math.pow(2, 32) - 1) * Math.pow(2, 21)).toString(2)\r\n // 11111 11111111 11111111 11111111 11100000 00000000 00000000\r\n // ((Math.pow(2, 32) - 1) >>> 11).toString(2)\r\n // 11111 11111111 11111111\r\n // 0x20000 is 2^21.\r\n v = a[i] * 0x20000 + (a[i + 1] >>> 11);\r\n\r\n // Rejection sampling:\r\n // 0 <= v < 9007199254740992\r\n // Probability that v >= 9e15, is\r\n // 7199254740992 / 9007199254740992 ~= 0.0008, i.e. 1 in 1251\r\n if (v >= 9e15) {\r\n b = crypto.getRandomValues(new Uint32Array(2));\r\n a[i] = b[0];\r\n a[i + 1] = b[1];\r\n } else {\r\n\r\n // 0 <= v <= 8999999999999999\r\n // 0 <= (v % 1e14) <= 99999999999999\r\n c.push(v % 1e14);\r\n i += 2;\r\n }\r\n }\r\n i = k / 2;\r\n\r\n // Node.js supporting crypto.randomBytes.\r\n } else if (crypto.randomBytes) {\r\n\r\n // buffer\r\n a = crypto.randomBytes(k *= 7);\r\n\r\n for (; i < k;) {\r\n\r\n // 0x1000000000000 is 2^48, 0x10000000000 is 2^40\r\n // 0x100000000 is 2^32, 0x1000000 is 2^24\r\n // 11111 11111111 11111111 11111111 11111111 11111111 11111111\r\n // 0 <= v < 9007199254740992\r\n v = ((a[i] & 31) * 0x1000000000000) + (a[i + 1] * 0x10000000000) +\r\n (a[i + 2] * 0x100000000) + (a[i + 3] * 0x1000000) +\r\n (a[i + 4] << 16) + (a[i + 5] << 8) + a[i + 6];\r\n\r\n if (v >= 9e15) {\r\n crypto.randomBytes(7).copy(a, i);\r\n } else {\r\n\r\n // 0 <= (v % 1e14) <= 99999999999999\r\n c.push(v % 1e14);\r\n i += 7;\r\n }\r\n }\r\n i = k / 7;\r\n } else {\r\n CRYPTO = false;\r\n throw Error\r\n (bignumberError + 'crypto unavailable');\r\n }\r\n }\r\n\r\n // Use Math.random.\r\n if (!CRYPTO) {\r\n\r\n for (; i < k;) {\r\n v = random53bitInt();\r\n if (v < 9e15) c[i++] = v % 1e14;\r\n }\r\n }\r\n\r\n k = c[--i];\r\n dp %= LOG_BASE;\r\n\r\n // Convert trailing digits to zeros according to dp.\r\n if (k && dp) {\r\n v = POWS_TEN[LOG_BASE - dp];\r\n c[i] = mathfloor(k / v) * v;\r\n }\r\n\r\n // Remove trailing elements which are zero.\r\n for (; c[i] === 0; c.pop(), i--);\r\n\r\n // Zero?\r\n if (i < 0) {\r\n c = [e = 0];\r\n } else {\r\n\r\n // Remove leading elements which are zero and adjust exponent accordingly.\r\n for (e = -1 ; c[0] === 0; c.splice(0, 1), e -= LOG_BASE);\r\n\r\n // Count the digits of the first element of c to determine leading zeros, and...\r\n for (i = 1, v = c[0]; v >= 10; v /= 10, i++);\r\n\r\n // adjust the exponent accordingly.\r\n if (i < LOG_BASE) e -= LOG_BASE - i;\r\n }\r\n\r\n rand.e = e;\r\n rand.c = c;\r\n return rand;\r\n };\r\n })();\r\n\r\n\r\n /*\r\n * Return a BigNumber whose value is the sum of the arguments.\r\n *\r\n * arguments {number|string|BigNumber}\r\n */\r\n BigNumber.sum = function () {\r\n var i = 1,\r\n args = arguments,\r\n sum = new BigNumber(args[0]);\r\n for (; i < args.length;) sum = sum.plus(args[i++]);\r\n return sum;\r\n };\r\n\r\n\r\n // PRIVATE FUNCTIONS\r\n\r\n\r\n // Called by BigNumber and BigNumber.prototype.toString.\r\n convertBase = (function () {\r\n var decimal = '0123456789';\r\n\r\n /*\r\n * Convert string of baseIn to an array of numbers of baseOut.\r\n * Eg. toBaseOut('255', 10, 16) returns [15, 15].\r\n * Eg. toBaseOut('ff', 16, 10) returns [2, 5, 5].\r\n */\r\n function toBaseOut(str, baseIn, baseOut, alphabet) {\r\n var j,\r\n arr = [0],\r\n arrL,\r\n i = 0,\r\n len = str.length;\r\n\r\n for (; i < len;) {\r\n for (arrL = arr.length; arrL--; arr[arrL] *= baseIn);\r\n\r\n arr[0] += alphabet.indexOf(str.charAt(i++));\r\n\r\n for (j = 0; j < arr.length; j++) {\r\n\r\n if (arr[j] > baseOut - 1) {\r\n if (arr[j + 1] == null) arr[j + 1] = 0;\r\n arr[j + 1] += arr[j] / baseOut | 0;\r\n arr[j] %= baseOut;\r\n }\r\n }\r\n }\r\n\r\n return arr.reverse();\r\n }\r\n\r\n // Convert a numeric string of baseIn to a numeric string of baseOut.\r\n // If the caller is toString, we are converting from base 10 to baseOut.\r\n // If the caller is BigNumber, we are converting from baseIn to base 10.\r\n return function (str, baseIn, baseOut, sign, callerIsToString) {\r\n var alphabet, d, e, k, r, x, xc, y,\r\n i = str.indexOf('.'),\r\n dp = DECIMAL_PLACES,\r\n rm = ROUNDING_MODE;\r\n\r\n // Non-integer.\r\n if (i >= 0) {\r\n k = POW_PRECISION;\r\n\r\n // Unlimited precision.\r\n POW_PRECISION = 0;\r\n str = str.replace('.', '');\r\n y = new BigNumber(baseIn);\r\n x = y.pow(str.length - i);\r\n POW_PRECISION = k;\r\n\r\n // Convert str as if an integer, then restore the fraction part by dividing the\r\n // result by its base raised to a power.\r\n\r\n y.c = toBaseOut(toFixedPoint(coeffToString(x.c), x.e, '0'),\r\n 10, baseOut, decimal);\r\n y.e = y.c.length;\r\n }\r\n\r\n // Convert the number as integer.\r\n\r\n xc = toBaseOut(str, baseIn, baseOut, callerIsToString\r\n ? (alphabet = ALPHABET, decimal)\r\n : (alphabet = decimal, ALPHABET));\r\n\r\n // xc now represents str as an integer and converted to baseOut. e is the exponent.\r\n e = k = xc.length;\r\n\r\n // Remove trailing zeros.\r\n for (; xc[--k] == 0; xc.pop());\r\n\r\n // Zero?\r\n if (!xc[0]) return alphabet.charAt(0);\r\n\r\n // Does str represent an integer? If so, no need for the division.\r\n if (i < 0) {\r\n --e;\r\n } else {\r\n x.c = xc;\r\n x.e = e;\r\n\r\n // The sign is needed for correct rounding.\r\n x.s = sign;\r\n x = div(x, y, dp, rm, baseOut);\r\n xc = x.c;\r\n r = x.r;\r\n e = x.e;\r\n }\r\n\r\n // xc now represents str converted to baseOut.\r\n\r\n // THe index of the rounding digit.\r\n d = e + dp + 1;\r\n\r\n // The rounding digit: the digit to the right of the digit that may be rounded up.\r\n i = xc[d];\r\n\r\n // Look at the rounding digits and mode to determine whether to round up.\r\n\r\n k = baseOut / 2;\r\n r = r || d < 0 || xc[d + 1] != null;\r\n\r\n r = rm < 4 ? (i != null || r) && (rm == 0 || rm == (x.s < 0 ? 3 : 2))\r\n : i > k || i == k &&(rm == 4 || r || rm == 6 && xc[d - 1] & 1 ||\r\n rm == (x.s < 0 ? 8 : 7));\r\n\r\n // If the index of the rounding digit is not greater than zero, or xc represents\r\n // zero, then the result of the base conversion is zero or, if rounding up, a value\r\n // such as 0.00001.\r\n if (d < 1 || !xc[0]) {\r\n\r\n // 1^-dp or 0\r\n str = r ? toFixedPoint(alphabet.charAt(1), -dp, alphabet.charAt(0)) : alphabet.charAt(0);\r\n } else {\r\n\r\n // Truncate xc to the required number of decimal places.\r\n xc.length = d;\r\n\r\n // Round up?\r\n if (r) {\r\n\r\n // Rounding up may mean the previous digit has to be rounded up and so on.\r\n for (--baseOut; ++xc[--d] > baseOut;) {\r\n xc[d] = 0;\r\n\r\n if (!d) {\r\n ++e;\r\n xc = [1].concat(xc);\r\n }\r\n }\r\n }\r\n\r\n // Determine trailing zeros.\r\n for (k = xc.length; !xc[--k];);\r\n\r\n // E.g. [4, 11, 15] becomes 4bf.\r\n for (i = 0, str = ''; i <= k; str += alphabet.charAt(xc[i++]));\r\n\r\n // Add leading zeros, decimal point and trailing zeros as required.\r\n str = toFixedPoint(str, e, alphabet.charAt(0));\r\n }\r\n\r\n // The caller will add the sign.\r\n return str;\r\n };\r\n })();\r\n\r\n\r\n // Perform division in the specified base. Called by div and convertBase.\r\n div = (function () {\r\n\r\n // Assume non-zero x and k.\r\n function multiply(x, k, base) {\r\n var m, temp, xlo, xhi,\r\n carry = 0,\r\n i = x.length,\r\n klo = k % SQRT_BASE,\r\n khi = k / SQRT_BASE | 0;\r\n\r\n for (x = x.slice(); i--;) {\r\n xlo = x[i] % SQRT_BASE;\r\n xhi = x[i] / SQRT_BASE | 0;\r\n m = khi * xlo + xhi * klo;\r\n temp = klo * xlo + ((m % SQRT_BASE) * SQRT_BASE) + carry;\r\n carry = (temp / base | 0) + (m / SQRT_BASE | 0) + khi * xhi;\r\n x[i] = temp % base;\r\n }\r\n\r\n if (carry) x = [carry].concat(x);\r\n\r\n return x;\r\n }\r\n\r\n function compare(a, b, aL, bL) {\r\n var i, cmp;\r\n\r\n if (aL != bL) {\r\n cmp = aL > bL ? 1 : -1;\r\n } else {\r\n\r\n for (i = cmp = 0; i < aL; i++) {\r\n\r\n if (a[i] != b[i]) {\r\n cmp = a[i] > b[i] ? 1 : -1;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return cmp;\r\n }\r\n\r\n function subtract(a, b, aL, base) {\r\n var i = 0;\r\n\r\n // Subtract b from a.\r\n for (; aL--;) {\r\n a[aL] -= i;\r\n i = a[aL] < b[aL] ? 1 : 0;\r\n a[aL] = i * base + a[aL] - b[aL];\r\n }\r\n\r\n // Remove leading zeros.\r\n for (; !a[0] && a.length > 1; a.splice(0, 1));\r\n }\r\n\r\n // x: dividend, y: divisor.\r\n return function (x, y, dp, rm, base) {\r\n var cmp, e, i, more, n, prod, prodL, q, qc, rem, remL, rem0, xi, xL, yc0,\r\n yL, yz,\r\n s = x.s == y.s ? 1 : -1,\r\n xc = x.c,\r\n yc = y.c;\r\n\r\n // Either NaN, Infinity or 0?\r\n if (!xc || !xc[0] || !yc || !yc[0]) {\r\n\r\n return new BigNumber(\r\n\r\n // Return NaN if either NaN, or both Infinity or 0.\r\n !x.s || !y.s || (xc ? yc && xc[0] == yc[0] : !yc) ? NaN :\r\n\r\n // Return ±0 if x is ±0 or y is ±Infinity, or return ±Infinity as y is ±0.\r\n xc && xc[0] == 0 || !yc ? s * 0 : s / 0\r\n );\r\n }\r\n\r\n q = new BigNumber(s);\r\n qc = q.c = [];\r\n e = x.e - y.e;\r\n s = dp + e + 1;\r\n\r\n if (!base) {\r\n base = BASE;\r\n e = bitFloor(x.e / LOG_BASE) - bitFloor(y.e / LOG_BASE);\r\n s = s / LOG_BASE | 0;\r\n }\r\n\r\n // Result exponent may be one less then the current value of e.\r\n // The coefficients of the BigNumbers from convertBase may have trailing zeros.\r\n for (i = 0; yc[i] == (xc[i] || 0); i++);\r\n\r\n if (yc[i] > (xc[i] || 0)) e--;\r\n\r\n if (s < 0) {\r\n qc.push(1);\r\n more = true;\r\n } else {\r\n xL = xc.length;\r\n yL = yc.length;\r\n i = 0;\r\n s += 2;\r\n\r\n // Normalise xc and yc so highest order digit of yc is >= base / 2.\r\n\r\n n = mathfloor(base / (yc[0] + 1));\r\n\r\n // Not necessary, but to handle odd bases where yc[0] == (base / 2) - 1.\r\n // if (n > 1 || n++ == 1 && yc[0] < base / 2) {\r\n if (n > 1) {\r\n yc = multiply(yc, n, base);\r\n xc = multiply(xc, n, base);\r\n yL = yc.length;\r\n xL = xc.length;\r\n }\r\n\r\n xi = yL;\r\n rem = xc.slice(0, yL);\r\n remL = rem.length;\r\n\r\n // Add zeros to make remainder as long as divisor.\r\n for (; remL < yL; rem[remL++] = 0);\r\n yz = yc.slice();\r\n yz = [0].concat(yz);\r\n yc0 = yc[0];\r\n if (yc[1] >= base / 2) yc0++;\r\n // Not necessary, but to prevent trial digit n > base, when using base 3.\r\n // else if (base == 3 && yc0 == 1) yc0 = 1 + 1e-15;\r\n\r\n do {\r\n n = 0;\r\n\r\n // Compare divisor and remainder.\r\n cmp = compare(yc, rem, yL, remL);\r\n\r\n // If divisor < remainder.\r\n if (cmp < 0) {\r\n\r\n // Calculate trial digit, n.\r\n\r\n rem0 = rem[0];\r\n if (yL != remL) rem0 = rem0 * base + (rem[1] || 0);\r\n\r\n // n is how many times the divisor goes into the current remainder.\r\n n = mathfloor(rem0 / yc0);\r\n\r\n // Algorithm:\r\n // product = divisor multiplied by trial digit (n).\r\n // Compare product and remainder.\r\n // If product is greater than remainder:\r\n // Subtract divisor from product, decrement trial digit.\r\n // Subtract product from remainder.\r\n // If product was less than remainder at the last compare:\r\n // Compare new remainder and divisor.\r\n // If remainder is greater than divisor:\r\n // Subtract divisor from remainder, increment trial digit.\r\n\r\n if (n > 1) {\r\n\r\n // n may be > base only when base is 3.\r\n if (n >= base) n = base - 1;\r\n\r\n // product = divisor * trial digit.\r\n prod = multiply(yc, n, base);\r\n prodL = prod.length;\r\n remL = rem.length;\r\n\r\n // Compare product and remainder.\r\n // If product > remainder then trial digit n too high.\r\n // n is 1 too high about 5% of the time, and is not known to have\r\n // ever been more than 1 too high.\r\n while (compare(prod, rem, prodL, remL) == 1) {\r\n n--;\r\n\r\n // Subtract divisor from product.\r\n subtract(prod, yL < prodL ? yz : yc, prodL, base);\r\n prodL = prod.length;\r\n cmp = 1;\r\n }\r\n } else {\r\n\r\n // n is 0 or 1, cmp is -1.\r\n // If n is 0, there is no need to compare yc and rem again below,\r\n // so change cmp to 1 to avoid it.\r\n // If n is 1, leave cmp as -1, so yc and rem are compared again.\r\n if (n == 0) {\r\n\r\n // divisor < remainder, so n must be at least 1.\r\n cmp = n = 1;\r\n }\r\n\r\n // product = divisor\r\n prod = yc.slice();\r\n prodL = prod.length;\r\n }\r\n\r\n if (prodL < remL) prod = [0].concat(prod);\r\n\r\n // Subtract product from remainder.\r\n subtract(rem, prod, remL, base);\r\n remL = rem.length;\r\n\r\n // If product was < remainder.\r\n if (cmp == -1) {\r\n\r\n // Compare divisor and new remainder.\r\n // If divisor < new remainder, subtract divisor from remainder.\r\n // Trial digit n too low.\r\n // n is 1 too low about 5% of the time, and very rarely 2 too low.\r\n while (compare(yc, rem, yL, remL) < 1) {\r\n n++;\r\n\r\n // Subtract divisor from remainder.\r\n subtract(rem, yL < remL ? yz : yc, remL, base);\r\n remL = rem.length;\r\n }\r\n }\r\n } else if (cmp === 0) {\r\n n++;\r\n rem = [0];\r\n } // else cmp === 1 and n will be 0\r\n\r\n // Add the next digit, n, to the result array.\r\n qc[i++] = n;\r\n\r\n // Update the remainder.\r\n if (rem[0]) {\r\n rem[remL++] = xc[xi] || 0;\r\n } else {\r\n rem = [xc[xi]];\r\n remL = 1;\r\n }\r\n } while ((xi++ < xL || rem[0] != null) && s--);\r\n\r\n more = rem[0] != null;\r\n\r\n // Leading zero?\r\n if (!qc[0]) qc.splice(0, 1);\r\n }\r\n\r\n if (base == BASE) {\r\n\r\n // To calculate q.e, first get the number of digits of qc[0].\r\n for (i = 1, s = qc[0]; s >= 10; s /= 10, i++);\r\n\r\n round(q, dp + (q.e = i + e * LOG_BASE - 1) + 1, rm, more);\r\n\r\n // Caller is convertBase.\r\n } else {\r\n q.e = e;\r\n q.r = +more;\r\n }\r\n\r\n return q;\r\n };\r\n })();\r\n\r\n\r\n /*\r\n * Return a string representing the value of BigNumber n in fixed-point or exponential\r\n * notation rounded to the specified decimal places or significant digits.\r\n *\r\n * n: a BigNumber.\r\n * i: the index of the last digit required (i.e. the digit that may be rounded up).\r\n * rm: the rounding mode.\r\n * id: 1 (toExponential) or 2 (toPrecision).\r\n */\r\n function format(n, i, rm, id) {\r\n var c0, e, ne, len, str;\r\n\r\n if (rm == null) rm = ROUNDING_MODE;\r\n else intCheck(rm, 0, 8);\r\n\r\n if (!n.c) return n.toString();\r\n\r\n c0 = n.c[0];\r\n ne = n.e;\r\n\r\n if (i == null) {\r\n str = coeffToString(n.c);\r\n str = id == 1 || id == 2 && (ne <= TO_EXP_NEG || ne >= TO_EXP_POS)\r\n ? toExponential(str, ne)\r\n : toFixedPoint(str, ne, '0');\r\n } else {\r\n n = round(new BigNumber(n), i, rm);\r\n\r\n // n.e may have changed if the value was rounded up.\r\n e = n.e;\r\n\r\n str = coeffToString(n.c);\r\n len = str.length;\r\n\r\n // toPrecision returns exponential notation if the number of significant digits\r\n // specified is less than the number of digits necessary to represent the integer\r\n // part of the value in fixed-point notation.\r\n\r\n // Exponential notation.\r\n if (id == 1 || id == 2 && (i <= e || e <= TO_EXP_NEG)) {\r\n\r\n // Append zeros?\r\n for (; len < i; str += '0', len++);\r\n str = toExponential(str, e);\r\n\r\n // Fixed-point notation.\r\n } else {\r\n i -= ne;\r\n str = toFixedPoint(str, e, '0');\r\n\r\n // Append zeros?\r\n if (e + 1 > len) {\r\n if (--i > 0) for (str += '.'; i--; str += '0');\r\n } else {\r\n i += e - len;\r\n if (i > 0) {\r\n if (e + 1 == len) str += '.';\r\n for (; i--; str += '0');\r\n }\r\n }\r\n }\r\n }\r\n\r\n return n.s < 0 && c0 ? '-' + str : str;\r\n }\r\n\r\n\r\n // Handle BigNumber.max and BigNumber.min.\r\n function maxOrMin(args, method) {\r\n var n,\r\n i = 1,\r\n m = new BigNumber(args[0]);\r\n\r\n for (; i < args.length; i++) {\r\n n = new BigNumber(args[i]);\r\n\r\n // If any number is NaN, return NaN.\r\n if (!n.s) {\r\n m = n;\r\n break;\r\n } else if (method.call(m, n)) {\r\n m = n;\r\n }\r\n }\r\n\r\n return m;\r\n }\r\n\r\n\r\n /*\r\n * Strip trailing zeros, calculate base 10 exponent and check against MIN_EXP and MAX_EXP.\r\n * Called by minus, plus and times.\r\n */\r\n function normalise(n, c, e) {\r\n var i = 1,\r\n j = c.length;\r\n\r\n // Remove trailing zeros.\r\n for (; !c[--j]; c.pop());\r\n\r\n // Calculate the base 10 exponent. First get the number of digits of c[0].\r\n for (j = c[0]; j >= 10; j /= 10, i++);\r\n\r\n // Overflow?\r\n if ((e = i + e * LOG_BASE - 1) > MAX_EXP) {\r\n\r\n // Infinity.\r\n n.c = n.e = null;\r\n\r\n // Underflow?\r\n } else if (e < MIN_EXP) {\r\n\r\n // Zero.\r\n n.c = [n.e = 0];\r\n } else {\r\n n.e = e;\r\n n.c = c;\r\n }\r\n\r\n return n;\r\n }\r\n\r\n\r\n // Handle values that fail the validity test in BigNumber.\r\n parseNumeric = (function () {\r\n var basePrefix = /^(-?)0([xbo])(?=\\w[\\w.]*$)/i,\r\n dotAfter = /^([^.]+)\\.$/,\r\n dotBefore = /^\\.([^.]+)$/,\r\n isInfinityOrNaN = /^-?(Infinity|NaN)$/,\r\n whitespaceOrPlus = /^\\s*\\+(?=[\\w.])|^\\s+|\\s+$/g;\r\n\r\n return function (x, str, isNum, b) {\r\n var base,\r\n s = isNum ? str : str.replace(whitespaceOrPlus, '');\r\n\r\n // No exception on ±Infinity or NaN.\r\n if (isInfinityOrNaN.test(s)) {\r\n x.s = isNaN(s) ? null : s < 0 ? -1 : 1;\r\n } else {\r\n if (!isNum) {\r\n\r\n // basePrefix = /^(-?)0([xbo])(?=\\w[\\w.]*$)/i\r\n s = s.replace(basePrefix, function (m, p1, p2) {\r\n base = (p2 = p2.toLowerCase()) == 'x' ? 16 : p2 == 'b' ? 2 : 8;\r\n return !b || b == base ? p1 : m;\r\n });\r\n\r\n if (b) {\r\n base = b;\r\n\r\n // E.g. '1.' to '1', '.1' to '0.1'\r\n s = s.replace(dotAfter, '$1').replace(dotBefore, '0.$1');\r\n }\r\n\r\n if (str != s) return new BigNumber(s, base);\r\n }\r\n\r\n // '[BigNumber Error] Not a number: {n}'\r\n // '[BigNumber Error] Not a base {b} number: {n}'\r\n if (BigNumber.DEBUG) {\r\n throw Error\r\n (bignumberError + 'Not a' + (b ? ' base ' + b : '') + ' number: ' + str);\r\n }\r\n\r\n // NaN\r\n x.s = null;\r\n }\r\n\r\n x.c = x.e = null;\r\n }\r\n })();\r\n\r\n\r\n /*\r\n * Round x to sd significant digits using rounding mode rm. Check for over/under-flow.\r\n * If r is truthy, it is known that there are more digits after the rounding digit.\r\n */\r\n function round(x, sd, rm, r) {\r\n var d, i, j, k, n, ni, rd,\r\n xc = x.c,\r\n pows10 = POWS_TEN;\r\n\r\n // if x is not Infinity or NaN...\r\n if (xc) {\r\n\r\n // rd is the rounding digit, i.e. the digit after the digit that may be rounded up.\r\n // n is a base 1e14 number, the value of the element of array x.c containing rd.\r\n // ni is the index of n within x.c.\r\n // d is the number of digits of n.\r\n // i is the index of rd within n including leading zeros.\r\n // j is the actual index of rd within n (if < 0, rd is a leading zero).\r\n out: {\r\n\r\n // Get the number of digits of the first element of xc.\r\n for (d = 1, k = xc[0]; k >= 10; k /= 10, d++);\r\n i = sd - d;\r\n\r\n // If the rounding digit is in the first element of xc...\r\n if (i < 0) {\r\n i += LOG_BASE;\r\n j = sd;\r\n n = xc[ni = 0];\r\n\r\n // Get the rounding digit at index j of n.\r\n rd = n / pows10[d - j - 1] % 10 | 0;\r\n } else {\r\n ni = mathceil((i + 1) / LOG_BASE);\r\n\r\n if (ni >= xc.length) {\r\n\r\n if (r) {\r\n\r\n // Needed by sqrt.\r\n for (; xc.length <= ni; xc.push(0));\r\n n = rd = 0;\r\n d = 1;\r\n i %= LOG_BASE;\r\n j = i - LOG_BASE + 1;\r\n } else {\r\n break out;\r\n }\r\n } else {\r\n n = k = xc[ni];\r\n\r\n // Get the number of digits of n.\r\n for (d = 1; k >= 10; k /= 10, d++);\r\n\r\n // Get the index of rd within n.\r\n i %= LOG_BASE;\r\n\r\n // Get the index of rd within n, adjusted for leading zeros.\r\n // The number of leading zeros of n is given by LOG_BASE - d.\r\n j = i - LOG_BASE + d;\r\n\r\n // Get the rounding digit at index j of n.\r\n rd = j < 0 ? 0 : n / pows10[d - j - 1] % 10 | 0;\r\n }\r\n }\r\n\r\n r = r || sd < 0 ||\r\n\r\n // Are there any non-zero digits after the rounding digit?\r\n // The expression n % pows10[d - j - 1] returns all digits of n to the right\r\n // of the digit at j, e.g. if n is 908714 and j is 2, the expression gives 714.\r\n xc[ni + 1] != null || (j < 0 ? n : n % pows10[d - j - 1]);\r\n\r\n r = rm < 4\r\n ? (rd || r) && (rm == 0 || rm == (x.s < 0 ? 3 : 2))\r\n : rd > 5 || rd == 5 && (rm == 4 || r || rm == 6 &&\r\n\r\n // Check whether the digit to the left of the rounding digit is odd.\r\n ((i > 0 ? j > 0 ? n / pows10[d - j] : 0 : xc[ni - 1]) % 10) & 1 ||\r\n rm == (x.s < 0 ? 8 : 7));\r\n\r\n if (sd < 1 || !xc[0]) {\r\n xc.length = 0;\r\n\r\n if (r) {\r\n\r\n // Convert sd to decimal places.\r\n sd -= x.e + 1;\r\n\r\n // 1, 0.1, 0.01, 0.001, 0.0001 etc.\r\n xc[0] = pows10[(LOG_BASE - sd % LOG_BASE) % LOG_BASE];\r\n x.e = -sd || 0;\r\n } else {\r\n\r\n // Zero.\r\n xc[0] = x.e = 0;\r\n }\r\n\r\n return x;\r\n }\r\n\r\n // Remove excess digits.\r\n if (i == 0) {\r\n xc.length = ni;\r\n k = 1;\r\n ni--;\r\n } else {\r\n xc.length = ni + 1;\r\n k = pows10[LOG_BASE - i];\r\n\r\n // E.g. 56700 becomes 56000 if 7 is the rounding digit.\r\n // j > 0 means i > number of leading zeros of n.\r\n xc[ni] = j > 0 ? mathfloor(n / pows10[d - j] % pows10[j]) * k : 0;\r\n }\r\n\r\n // Round up?\r\n if (r) {\r\n\r\n for (; ;) {\r\n\r\n // If the digit to be rounded up is in the first element of xc...\r\n if (ni == 0) {\r\n\r\n // i will be the length of xc[0] before k is added.\r\n for (i = 1, j = xc[0]; j >= 10; j /= 10, i++);\r\n j = xc[0] += k;\r\n for (k = 1; j >= 10; j /= 10, k++);\r\n\r\n // if i != k the length has increased.\r\n if (i != k) {\r\n x.e++;\r\n if (xc[0] == BASE) xc[0] = 1;\r\n }\r\n\r\n break;\r\n } else {\r\n xc[ni] += k;\r\n if (xc[ni] != BASE) break;\r\n xc[ni--] = 0;\r\n k = 1;\r\n }\r\n }\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (i = xc.length; xc[--i] === 0; xc.pop());\r\n }\r\n\r\n // Overflow? Infinity.\r\n if (x.e > MAX_EXP) {\r\n x.c = x.e = null;\r\n\r\n // Underflow? Zero.\r\n } else if (x.e < MIN_EXP) {\r\n x.c = [x.e = 0];\r\n }\r\n }\r\n\r\n return x;\r\n }\r\n\r\n\r\n function valueOf(n) {\r\n var str,\r\n e = n.e;\r\n\r\n if (e === null) return n.toString();\r\n\r\n str = coeffToString(n.c);\r\n\r\n str = e <= TO_EXP_NEG || e >= TO_EXP_POS\r\n ? toExponential(str, e)\r\n : toFixedPoint(str, e, '0');\r\n\r\n return n.s < 0 ? '-' + str : str;\r\n }\r\n\r\n\r\n // PROTOTYPE/INSTANCE METHODS\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the absolute value of this BigNumber.\r\n */\r\n P.absoluteValue = P.abs = function () {\r\n var x = new BigNumber(this);\r\n if (x.s < 0) x.s = 1;\r\n return x;\r\n };\r\n\r\n\r\n /*\r\n * Return\r\n * 1 if the value of this BigNumber is greater than the value of BigNumber(y, b),\r\n * -1 if the value of this BigNumber is less than the value of BigNumber(y, b),\r\n * 0 if they have the same value,\r\n * or null if the value of either is NaN.\r\n */\r\n P.comparedTo = function (y, b) {\r\n return compare(this, new BigNumber(y, b));\r\n };\r\n\r\n\r\n /*\r\n * If dp is undefined or null or true or false, return the number of decimal places of the\r\n * value of this BigNumber, or null if the value of this BigNumber is ±Infinity or NaN.\r\n *\r\n * Otherwise, if dp is a number, return a new BigNumber whose value is the value of this\r\n * BigNumber rounded to a maximum of dp decimal places using rounding mode rm, or\r\n * ROUNDING_MODE if rm is omitted.\r\n *\r\n * [dp] {number} Decimal places: integer, 0 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp|rm}'\r\n */\r\n P.decimalPlaces = P.dp = function (dp, rm) {\r\n var c, n, v,\r\n x = this;\r\n\r\n if (dp != null) {\r\n intCheck(dp, 0, MAX);\r\n if (rm == null) rm = ROUNDING_MODE;\r\n else intCheck(rm, 0, 8);\r\n\r\n return round(new BigNumber(x), dp + x.e + 1, rm);\r\n }\r\n\r\n if (!(c = x.c)) return null;\r\n n = ((v = c.length - 1) - bitFloor(this.e / LOG_BASE)) * LOG_BASE;\r\n\r\n // Subtract the number of trailing zeros of the last number.\r\n if (v = c[v]) for (; v % 10 == 0; v /= 10, n--);\r\n if (n < 0) n = 0;\r\n\r\n return n;\r\n };\r\n\r\n\r\n /*\r\n * n / 0 = I\r\n * n / N = N\r\n * n / I = 0\r\n * 0 / n = 0\r\n * 0 / 0 = N\r\n * 0 / N = N\r\n * 0 / I = 0\r\n * N / n = N\r\n * N / 0 = N\r\n * N / N = N\r\n * N / I = N\r\n * I / n = I\r\n * I / 0 = I\r\n * I / N = N\r\n * I / I = N\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber divided by the value of\r\n * BigNumber(y, b), rounded according to DECIMAL_PLACES and ROUNDING_MODE.\r\n */\r\n P.dividedBy = P.div = function (y, b) {\r\n return div(this, new BigNumber(y, b), DECIMAL_PLACES, ROUNDING_MODE);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the integer part of dividing the value of this\r\n * BigNumber by the value of BigNumber(y, b).\r\n */\r\n P.dividedToIntegerBy = P.idiv = function (y, b) {\r\n return div(this, new BigNumber(y, b), 0, 1);\r\n };\r\n\r\n\r\n /*\r\n * Return a BigNumber whose value is the value of this BigNumber exponentiated by n.\r\n *\r\n * If m is present, return the result modulo m.\r\n * If n is negative round according to DECIMAL_PLACES and ROUNDING_MODE.\r\n * If POW_PRECISION is non-zero and m is not present, round to POW_PRECISION using ROUNDING_MODE.\r\n *\r\n * The modular power operation works efficiently when x, n, and m are integers, otherwise it\r\n * is equivalent to calculating x.exponentiatedBy(n).modulo(m) with a POW_PRECISION of 0.\r\n *\r\n * n {number|string|BigNumber} The exponent. An integer.\r\n * [m] {number|string|BigNumber} The modulus.\r\n *\r\n * '[BigNumber Error] Exponent not an integer: {n}'\r\n */\r\n P.exponentiatedBy = P.pow = function (n, m) {\r\n var half, isModExp, i, k, more, nIsBig, nIsNeg, nIsOdd, y,\r\n x = this;\r\n\r\n n = new BigNumber(n);\r\n\r\n // Allow NaN and ±Infinity, but not other non-integers.\r\n if (n.c && !n.isInteger()) {\r\n throw Error\r\n (bignumberError + 'Exponent not an integer: ' + valueOf(n));\r\n }\r\n\r\n if (m != null) m = new BigNumber(m);\r\n\r\n // Exponent of MAX_SAFE_INTEGER is 15.\r\n nIsBig = n.e > 14;\r\n\r\n // If x is NaN, ±Infinity, ±0 or ±1, or n is ±Infinity, NaN or ±0.\r\n if (!x.c || !x.c[0] || x.c[0] == 1 && !x.e && x.c.length == 1 || !n.c || !n.c[0]) {\r\n\r\n // The sign of the result of pow when x is negative depends on the evenness of n.\r\n // If +n overflows to ±Infinity, the evenness of n would be not be known.\r\n y = new BigNumber(Math.pow(+valueOf(x), nIsBig ? 2 - isOdd(n) : +valueOf(n)));\r\n return m ? y.mod(m) : y;\r\n }\r\n\r\n nIsNeg = n.s < 0;\r\n\r\n if (m) {\r\n\r\n // x % m returns NaN if abs(m) is zero, or m is NaN.\r\n if (m.c ? !m.c[0] : !m.s) return new BigNumber(NaN);\r\n\r\n isModExp = !nIsNeg && x.isInteger() && m.isInteger();\r\n\r\n if (isModExp) x = x.mod(m);\r\n\r\n // Overflow to ±Infinity: >=2**1e10 or >=1.0000024**1e15.\r\n // Underflow to ±0: <=0.79**1e10 or <=0.9999975**1e15.\r\n } else if (n.e > 9 && (x.e > 0 || x.e < -1 || (x.e == 0\r\n // [1, 240000000]\r\n ? x.c[0] > 1 || nIsBig && x.c[1] >= 24e7\r\n // [80000000000000] [99999750000000]\r\n : x.c[0] < 8e13 || nIsBig && x.c[0] <= 9999975e7))) {\r\n\r\n // If x is negative and n is odd, k = -0, else k = 0.\r\n k = x.s < 0 && isOdd(n) ? -0 : 0;\r\n\r\n // If x >= 1, k = ±Infinity.\r\n if (x.e > -1) k = 1 / k;\r\n\r\n // If n is negative return ±0, else return ±Infinity.\r\n return new BigNumber(nIsNeg ? 1 / k : k);\r\n\r\n } else if (POW_PRECISION) {\r\n\r\n // Truncating each coefficient array to a length of k after each multiplication\r\n // equates to truncating significant digits to POW_PRECISION + [28, 41],\r\n // i.e. there will be a minimum of 28 guard digits retained.\r\n k = mathceil(POW_PRECISION / LOG_BASE + 2);\r\n }\r\n\r\n if (nIsBig) {\r\n half = new BigNumber(0.5);\r\n if (nIsNeg) n.s = 1;\r\n nIsOdd = isOdd(n);\r\n } else {\r\n i = Math.abs(+valueOf(n));\r\n nIsOdd = i % 2;\r\n }\r\n\r\n y = new BigNumber(ONE);\r\n\r\n // Performs 54 loop iterations for n of 9007199254740991.\r\n for (; ;) {\r\n\r\n if (nIsOdd) {\r\n y = y.times(x);\r\n if (!y.c) break;\r\n\r\n if (k) {\r\n if (y.c.length > k) y.c.length = k;\r\n } else if (isModExp) {\r\n y = y.mod(m); //y = y.minus(div(y, m, 0, MODULO_MODE).times(m));\r\n }\r\n }\r\n\r\n if (i) {\r\n i = mathfloor(i / 2);\r\n if (i === 0) break;\r\n nIsOdd = i % 2;\r\n } else {\r\n n = n.times(half);\r\n round(n, n.e + 1, 1);\r\n\r\n if (n.e > 14) {\r\n nIsOdd = isOdd(n);\r\n } else {\r\n i = +valueOf(n);\r\n if (i === 0) break;\r\n nIsOdd = i % 2;\r\n }\r\n }\r\n\r\n x = x.times(x);\r\n\r\n if (k) {\r\n if (x.c && x.c.length > k) x.c.length = k;\r\n } else if (isModExp) {\r\n x = x.mod(m); //x = x.minus(div(x, m, 0, MODULO_MODE).times(m));\r\n }\r\n }\r\n\r\n if (isModExp) return y;\r\n if (nIsNeg) y = ONE.div(y);\r\n\r\n return m ? y.mod(m) : k ? round(y, POW_PRECISION, ROUNDING_MODE, more) : y;\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the value of this BigNumber rounded to an integer\r\n * using rounding mode rm, or ROUNDING_MODE if rm is omitted.\r\n *\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {rm}'\r\n */\r\n P.integerValue = function (rm) {\r\n var n = new BigNumber(this);\r\n if (rm == null) rm = ROUNDING_MODE;\r\n else intCheck(rm, 0, 8);\r\n return round(n, n.e + 1, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is equal to the value of BigNumber(y, b),\r\n * otherwise return false.\r\n */\r\n P.isEqualTo = P.eq = function (y, b) {\r\n return compare(this, new BigNumber(y, b)) === 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is a finite number, otherwise return false.\r\n */\r\n P.isFinite = function () {\r\n return !!this.c;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is greater than the value of BigNumber(y, b),\r\n * otherwise return false.\r\n */\r\n P.isGreaterThan = P.gt = function (y, b) {\r\n return compare(this, new BigNumber(y, b)) > 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is greater than or equal to the value of\r\n * BigNumber(y, b), otherwise return false.\r\n */\r\n P.isGreaterThanOrEqualTo = P.gte = function (y, b) {\r\n return (b = compare(this, new BigNumber(y, b))) === 1 || b === 0;\r\n\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is an integer, otherwise return false.\r\n */\r\n P.isInteger = function () {\r\n return !!this.c && bitFloor(this.e / LOG_BASE) > this.c.length - 2;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is less than the value of BigNumber(y, b),\r\n * otherwise return false.\r\n */\r\n P.isLessThan = P.lt = function (y, b) {\r\n return compare(this, new BigNumber(y, b)) < 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is less than or equal to the value of\r\n * BigNumber(y, b), otherwise return false.\r\n */\r\n P.isLessThanOrEqualTo = P.lte = function (y, b) {\r\n return (b = compare(this, new BigNumber(y, b))) === -1 || b === 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is NaN, otherwise return false.\r\n */\r\n P.isNaN = function () {\r\n return !this.s;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is negative, otherwise return false.\r\n */\r\n P.isNegative = function () {\r\n return this.s < 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is positive, otherwise return false.\r\n */\r\n P.isPositive = function () {\r\n return this.s > 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this BigNumber is 0 or -0, otherwise return false.\r\n */\r\n P.isZero = function () {\r\n return !!this.c && this.c[0] == 0;\r\n };\r\n\r\n\r\n /*\r\n * n - 0 = n\r\n * n - N = N\r\n * n - I = -I\r\n * 0 - n = -n\r\n * 0 - 0 = 0\r\n * 0 - N = N\r\n * 0 - I = -I\r\n * N - n = N\r\n * N - 0 = N\r\n * N - N = N\r\n * N - I = N\r\n * I - n = I\r\n * I - 0 = I\r\n * I - N = N\r\n * I - I = N\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber minus the value of\r\n * BigNumber(y, b).\r\n */\r\n P.minus = function (y, b) {\r\n var i, j, t, xLTy,\r\n x = this,\r\n a = x.s;\r\n\r\n y = new BigNumber(y, b);\r\n b = y.s;\r\n\r\n // Either NaN?\r\n if (!a || !b) return new BigNumber(NaN);\r\n\r\n // Signs differ?\r\n if (a != b) {\r\n y.s = -b;\r\n return x.plus(y);\r\n }\r\n\r\n var xe = x.e / LOG_BASE,\r\n ye = y.e / LOG_BASE,\r\n xc = x.c,\r\n yc = y.c;\r\n\r\n if (!xe || !ye) {\r\n\r\n // Either Infinity?\r\n if (!xc || !yc) return xc ? (y.s = -b, y) : new BigNumber(yc ? x : NaN);\r\n\r\n // Either zero?\r\n if (!xc[0] || !yc[0]) {\r\n\r\n // Return y if y is non-zero, x if x is non-zero, or zero if both are zero.\r\n return yc[0] ? (y.s = -b, y) : new BigNumber(xc[0] ? x :\r\n\r\n // IEEE 754 (2008) 6.3: n - n = -0 when rounding to -Infinity\r\n ROUNDING_MODE == 3 ? -0 : 0);\r\n }\r\n }\r\n\r\n xe = bitFloor(xe);\r\n ye = bitFloor(ye);\r\n xc = xc.slice();\r\n\r\n // Determine which is the bigger number.\r\n if (a = xe - ye) {\r\n\r\n if (xLTy = a < 0) {\r\n a = -a;\r\n t = xc;\r\n } else {\r\n ye = xe;\r\n t = yc;\r\n }\r\n\r\n t.reverse();\r\n\r\n // Prepend zeros to equalise exponents.\r\n for (b = a; b--; t.push(0));\r\n t.reverse();\r\n } else {\r\n\r\n // Exponents equal. Check digit by digit.\r\n j = (xLTy = (a = xc.length) < (b = yc.length)) ? a : b;\r\n\r\n for (a = b = 0; b < j; b++) {\r\n\r\n if (xc[b] != yc[b]) {\r\n xLTy = xc[b] < yc[b];\r\n break;\r\n }\r\n }\r\n }\r\n\r\n // x < y? Point xc to the array of the bigger number.\r\n if (xLTy) t = xc, xc = yc, yc = t, y.s = -y.s;\r\n\r\n b = (j = yc.length) - (i = xc.length);\r\n\r\n // Append zeros to xc if shorter.\r\n // No need to add zeros to yc if shorter as subtract only needs to start at yc.length.\r\n if (b > 0) for (; b--; xc[i++] = 0);\r\n b = BASE - 1;\r\n\r\n // Subtract yc from xc.\r\n for (; j > a;) {\r\n\r\n if (xc[--j] < yc[j]) {\r\n for (i = j; i && !xc[--i]; xc[i] = b);\r\n --xc[i];\r\n xc[j] += BASE;\r\n }\r\n\r\n xc[j] -= yc[j];\r\n }\r\n\r\n // Remove leading zeros and adjust exponent accordingly.\r\n for (; xc[0] == 0; xc.splice(0, 1), --ye);\r\n\r\n // Zero?\r\n if (!xc[0]) {\r\n\r\n // Following IEEE 754 (2008) 6.3,\r\n // n - n = +0 but n - n = -0 when rounding towards -Infinity.\r\n y.s = ROUNDING_MODE == 3 ? -1 : 1;\r\n y.c = [y.e = 0];\r\n return y;\r\n }\r\n\r\n // No need to check for Infinity as +x - +y != Infinity && -x - -y != Infinity\r\n // for finite x and y.\r\n return normalise(y, xc, ye);\r\n };\r\n\r\n\r\n /*\r\n * n % 0 = N\r\n * n % N = N\r\n * n % I = n\r\n * 0 % n = 0\r\n * -0 % n = -0\r\n * 0 % 0 = N\r\n * 0 % N = N\r\n * 0 % I = 0\r\n * N % n = N\r\n * N % 0 = N\r\n * N % N = N\r\n * N % I = N\r\n * I % n = N\r\n * I % 0 = N\r\n * I % N = N\r\n * I % I = N\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber modulo the value of\r\n * BigNumber(y, b). The result depends on the value of MODULO_MODE.\r\n */\r\n P.modulo = P.mod = function (y, b) {\r\n var q, s,\r\n x = this;\r\n\r\n y = new BigNumber(y, b);\r\n\r\n // Return NaN if x is Infinity or NaN, or y is NaN or zero.\r\n if (!x.c || !y.s || y.c && !y.c[0]) {\r\n return new BigNumber(NaN);\r\n\r\n // Return x if y is Infinity or x is zero.\r\n } else if (!y.c || x.c && !x.c[0]) {\r\n return new BigNumber(x);\r\n }\r\n\r\n if (MODULO_MODE == 9) {\r\n\r\n // Euclidian division: q = sign(y) * floor(x / abs(y))\r\n // r = x - qy where 0 <= r < abs(y)\r\n s = y.s;\r\n y.s = 1;\r\n q = div(x, y, 0, 3);\r\n y.s = s;\r\n q.s *= s;\r\n } else {\r\n q = div(x, y, 0, MODULO_MODE);\r\n }\r\n\r\n y = x.minus(q.times(y));\r\n\r\n // To match JavaScript %, ensure sign of zero is sign of dividend.\r\n if (!y.c[0] && MODULO_MODE == 1) y.s = x.s;\r\n\r\n return y;\r\n };\r\n\r\n\r\n /*\r\n * n * 0 = 0\r\n * n * N = N\r\n * n * I = I\r\n * 0 * n = 0\r\n * 0 * 0 = 0\r\n * 0 * N = N\r\n * 0 * I = N\r\n * N * n = N\r\n * N * 0 = N\r\n * N * N = N\r\n * N * I = N\r\n * I * n = I\r\n * I * 0 = N\r\n * I * N = N\r\n * I * I = I\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber multiplied by the value\r\n * of BigNumber(y, b).\r\n */\r\n P.multipliedBy = P.times = function (y, b) {\r\n var c, e, i, j, k, m, xcL, xlo, xhi, ycL, ylo, yhi, zc,\r\n base, sqrtBase,\r\n x = this,\r\n xc = x.c,\r\n yc = (y = new BigNumber(y, b)).c;\r\n\r\n // Either NaN, ±Infinity or ±0?\r\n if (!xc || !yc || !xc[0] || !yc[0]) {\r\n\r\n // Return NaN if either is NaN, or one is 0 and the other is Infinity.\r\n if (!x.s || !y.s || xc && !xc[0] && !yc || yc && !yc[0] && !xc) {\r\n y.c = y.e = y.s = null;\r\n } else {\r\n y.s *= x.s;\r\n\r\n // Return ±Infinity if either is ±Infinity.\r\n if (!xc || !yc) {\r\n y.c = y.e = null;\r\n\r\n // Return ±0 if either is ±0.\r\n } else {\r\n y.c = [0];\r\n y.e = 0;\r\n }\r\n }\r\n\r\n return y;\r\n }\r\n\r\n e = bitFloor(x.e / LOG_BASE) + bitFloor(y.e / LOG_BASE);\r\n y.s *= x.s;\r\n xcL = xc.length;\r\n ycL = yc.length;\r\n\r\n // Ensure xc points to longer array and xcL to its length.\r\n if (xcL < ycL) zc = xc, xc = yc, yc = zc, i = xcL, xcL = ycL, ycL = i;\r\n\r\n // Initialise the result array with zeros.\r\n for (i = xcL + ycL, zc = []; i--; zc.push(0));\r\n\r\n base = BASE;\r\n sqrtBase = SQRT_BASE;\r\n\r\n for (i = ycL; --i >= 0;) {\r\n c = 0;\r\n ylo = yc[i] % sqrtBase;\r\n yhi = yc[i] / sqrtBase | 0;\r\n\r\n for (k = xcL, j = i + k; j > i;) {\r\n xlo = xc[--k] % sqrtBase;\r\n xhi = xc[k] / sqrtBase | 0;\r\n m = yhi * xlo + xhi * ylo;\r\n xlo = ylo * xlo + ((m % sqrtBase) * sqrtBase) + zc[j] + c;\r\n c = (xlo / base | 0) + (m / sqrtBase | 0) + yhi * xhi;\r\n zc[j--] = xlo % base;\r\n }\r\n\r\n zc[j] = c;\r\n }\r\n\r\n if (c) {\r\n ++e;\r\n } else {\r\n zc.splice(0, 1);\r\n }\r\n\r\n return normalise(y, zc, e);\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the value of this BigNumber negated,\r\n * i.e. multiplied by -1.\r\n */\r\n P.negated = function () {\r\n var x = new BigNumber(this);\r\n x.s = -x.s || null;\r\n return x;\r\n };\r\n\r\n\r\n /*\r\n * n + 0 = n\r\n * n + N = N\r\n * n + I = I\r\n * 0 + n = n\r\n * 0 + 0 = 0\r\n * 0 + N = N\r\n * 0 + I = I\r\n * N + n = N\r\n * N + 0 = N\r\n * N + N = N\r\n * N + I = N\r\n * I + n = I\r\n * I + 0 = I\r\n * I + N = N\r\n * I + I = I\r\n *\r\n * Return a new BigNumber whose value is the value of this BigNumber plus the value of\r\n * BigNumber(y, b).\r\n */\r\n P.plus = function (y, b) {\r\n var t,\r\n x = this,\r\n a = x.s;\r\n\r\n y = new BigNumber(y, b);\r\n b = y.s;\r\n\r\n // Either NaN?\r\n if (!a || !b) return new BigNumber(NaN);\r\n\r\n // Signs differ?\r\n if (a != b) {\r\n y.s = -b;\r\n return x.minus(y);\r\n }\r\n\r\n var xe = x.e / LOG_BASE,\r\n ye = y.e / LOG_BASE,\r\n xc = x.c,\r\n yc = y.c;\r\n\r\n if (!xe || !ye) {\r\n\r\n // Return ±Infinity if either ±Infinity.\r\n if (!xc || !yc) return new BigNumber(a / 0);\r\n\r\n // Either zero?\r\n // Return y if y is non-zero, x if x is non-zero, or zero if both are zero.\r\n if (!xc[0] || !yc[0]) return yc[0] ? y : new BigNumber(xc[0] ? x : a * 0);\r\n }\r\n\r\n xe = bitFloor(xe);\r\n ye = bitFloor(ye);\r\n xc = xc.slice();\r\n\r\n // Prepend zeros to equalise exponents. Faster to use reverse then do unshifts.\r\n if (a = xe - ye) {\r\n if (a > 0) {\r\n ye = xe;\r\n t = yc;\r\n } else {\r\n a = -a;\r\n t = xc;\r\n }\r\n\r\n t.reverse();\r\n for (; a--; t.push(0));\r\n t.reverse();\r\n }\r\n\r\n a = xc.length;\r\n b = yc.length;\r\n\r\n // Point xc to the longer array, and b to the shorter length.\r\n if (a - b < 0) t = yc, yc = xc, xc = t, b = a;\r\n\r\n // Only start adding at yc.length - 1 as the further digits of xc can be ignored.\r\n for (a = 0; b;) {\r\n a = (xc[--b] = xc[b] + yc[b] + a) / BASE | 0;\r\n xc[b] = BASE === xc[b] ? 0 : xc[b] % BASE;\r\n }\r\n\r\n if (a) {\r\n xc = [a].concat(xc);\r\n ++ye;\r\n }\r\n\r\n // No need to check for zero, as +x + +y != 0 && -x + -y != 0\r\n // ye = MAX_EXP + 1 possible\r\n return normalise(y, xc, ye);\r\n };\r\n\r\n\r\n /*\r\n * If sd is undefined or null or true or false, return the number of significant digits of\r\n * the value of this BigNumber, or null if the value of this BigNumber is ±Infinity or NaN.\r\n * If sd is true include integer-part trailing zeros in the count.\r\n *\r\n * Otherwise, if sd is a number, return a new BigNumber whose value is the value of this\r\n * BigNumber rounded to a maximum of sd significant digits using rounding mode rm, or\r\n * ROUNDING_MODE if rm is omitted.\r\n *\r\n * sd {number|boolean} number: significant digits: integer, 1 to MAX inclusive.\r\n * boolean: whether to count integer-part trailing zeros: true or false.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {sd|rm}'\r\n */\r\n P.precision = P.sd = function (sd, rm) {\r\n var c, n, v,\r\n x = this;\r\n\r\n if (sd != null && sd !== !!sd) {\r\n intCheck(sd, 1, MAX);\r\n if (rm == null) rm = ROUNDING_MODE;\r\n else intCheck(rm, 0, 8);\r\n\r\n return round(new BigNumber(x), sd, rm);\r\n }\r\n\r\n if (!(c = x.c)) return null;\r\n v = c.length - 1;\r\n n = v * LOG_BASE + 1;\r\n\r\n if (v = c[v]) {\r\n\r\n // Subtract the number of trailing zeros of the last element.\r\n for (; v % 10 == 0; v /= 10, n--);\r\n\r\n // Add the number of digits of the first element.\r\n for (v = c[0]; v >= 10; v /= 10, n++);\r\n }\r\n\r\n if (sd && x.e + 1 > n) n = x.e + 1;\r\n\r\n return n;\r\n };\r\n\r\n\r\n /*\r\n * Return a new BigNumber whose value is the value of this BigNumber shifted by k places\r\n * (powers of 10). Shift to the right if n > 0, and to the left if n < 0.\r\n *\r\n * k {number} Integer, -MAX_SAFE_INTEGER to MAX_SAFE_INTEGER inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {k}'\r\n */\r\n P.shiftedBy = function (k) {\r\n intCheck(k, -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER);\r\n return this.times('1e' + k);\r\n };\r\n\r\n\r\n /*\r\n * sqrt(-n) = N\r\n * sqrt(N) = N\r\n * sqrt(-I) = N\r\n * sqrt(I) = I\r\n * sqrt(0) = 0\r\n * sqrt(-0) = -0\r\n *\r\n * Return a new BigNumber whose value is the square root of the value of this BigNumber,\r\n * rounded according to DECIMAL_PLACES and ROUNDING_MODE.\r\n */\r\n P.squareRoot = P.sqrt = function () {\r\n var m, n, r, rep, t,\r\n x = this,\r\n c = x.c,\r\n s = x.s,\r\n e = x.e,\r\n dp = DECIMAL_PLACES + 4,\r\n half = new BigNumber('0.5');\r\n\r\n // Negative/NaN/Infinity/zero?\r\n if (s !== 1 || !c || !c[0]) {\r\n return new BigNumber(!s || s < 0 && (!c || c[0]) ? NaN : c ? x : 1 / 0);\r\n }\r\n\r\n // Initial estimate.\r\n s = Math.sqrt(+valueOf(x));\r\n\r\n // Math.sqrt underflow/overflow?\r\n // Pass x to Math.sqrt as integer, then adjust the exponent of the result.\r\n if (s == 0 || s == 1 / 0) {\r\n n = coeffToString(c);\r\n if ((n.length + e) % 2 == 0) n += '0';\r\n s = Math.sqrt(+n);\r\n e = bitFloor((e + 1) / 2) - (e < 0 || e % 2);\r\n\r\n if (s == 1 / 0) {\r\n n = '5e' + e;\r\n } else {\r\n n = s.toExponential();\r\n n = n.slice(0, n.indexOf('e') + 1) + e;\r\n }\r\n\r\n r = new BigNumber(n);\r\n } else {\r\n r = new BigNumber(s + '');\r\n }\r\n\r\n // Check for zero.\r\n // r could be zero if MIN_EXP is changed after the this value was created.\r\n // This would cause a division by zero (x/t) and hence Infinity below, which would cause\r\n // coeffToString to throw.\r\n if (r.c[0]) {\r\n e = r.e;\r\n s = e + dp;\r\n if (s < 3) s = 0;\r\n\r\n // Newton-Raphson iteration.\r\n for (; ;) {\r\n t = r;\r\n r = half.times(t.plus(div(x, t, dp, 1)));\r\n\r\n if (coeffToString(t.c).slice(0, s) === (n = coeffToString(r.c)).slice(0, s)) {\r\n\r\n // The exponent of r may here be one less than the final result exponent,\r\n // e.g 0.0009999 (e-4) --> 0.001 (e-3), so adjust s so the rounding digits\r\n // are indexed correctly.\r\n if (r.e < e) --s;\r\n n = n.slice(s - 3, s + 1);\r\n\r\n // The 4th rounding digit may be in error by -1 so if the 4 rounding digits\r\n // are 9999 or 4999 (i.e. approaching a rounding boundary) continue the\r\n // iteration.\r\n if (n == '9999' || !rep && n == '4999') {\r\n\r\n // On the first iteration only, check to see if rounding up gives the\r\n // exact result as the nines may infinitely repeat.\r\n if (!rep) {\r\n round(t, t.e + DECIMAL_PLACES + 2, 0);\r\n\r\n if (t.times(t).eq(x)) {\r\n r = t;\r\n break;\r\n }\r\n }\r\n\r\n dp += 4;\r\n s += 4;\r\n rep = 1;\r\n } else {\r\n\r\n // If rounding digits are null, 0{0,4} or 50{0,3}, check for exact\r\n // result. If not, then there are further digits and m will be truthy.\r\n if (!+n || !+n.slice(1) && n.charAt(0) == '5') {\r\n\r\n // Truncate to the first rounding digit.\r\n round(r, r.e + DECIMAL_PLACES + 2, 1);\r\n m = !r.times(r).eq(x);\r\n }\r\n\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n\r\n return round(r, r.e + DECIMAL_PLACES + 1, ROUNDING_MODE, m);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber in exponential notation and\r\n * rounded using ROUNDING_MODE to dp fixed decimal places.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp|rm}'\r\n */\r\n P.toExponential = function (dp, rm) {\r\n if (dp != null) {\r\n intCheck(dp, 0, MAX);\r\n dp++;\r\n }\r\n return format(this, dp, rm, 1);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber in fixed-point notation rounding\r\n * to dp fixed decimal places using rounding mode rm, or ROUNDING_MODE if rm is omitted.\r\n *\r\n * Note: as with JavaScript's number type, (-0).toFixed(0) is '0',\r\n * but e.g. (-0.00001).toFixed(0) is '-0'.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp|rm}'\r\n */\r\n P.toFixed = function (dp, rm) {\r\n if (dp != null) {\r\n intCheck(dp, 0, MAX);\r\n dp = dp + this.e + 1;\r\n }\r\n return format(this, dp, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber in fixed-point notation rounded\r\n * using rm or ROUNDING_MODE to dp decimal places, and formatted according to the properties\r\n * of the format or FORMAT object (see BigNumber.set).\r\n *\r\n * The formatting object may contain some or all of the properties shown below.\r\n *\r\n * FORMAT = {\r\n * prefix: '',\r\n * groupSize: 3,\r\n * secondaryGroupSize: 0,\r\n * groupSeparator: ',',\r\n * decimalSeparator: '.',\r\n * fractionGroupSize: 0,\r\n * fractionGroupSeparator: '\\xA0', // non-breaking space\r\n * suffix: ''\r\n * };\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n * [format] {object} Formatting options. See FORMAT pbject above.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {dp|rm}'\r\n * '[BigNumber Error] Argument not an object: {format}'\r\n */\r\n P.toFormat = function (dp, rm, format) {\r\n var str,\r\n x = this;\r\n\r\n if (format == null) {\r\n if (dp != null && rm && typeof rm == 'object') {\r\n format = rm;\r\n rm = null;\r\n } else if (dp && typeof dp == 'object') {\r\n format = dp;\r\n dp = rm = null;\r\n } else {\r\n format = FORMAT;\r\n }\r\n } else if (typeof format != 'object') {\r\n throw Error\r\n (bignumberError + 'Argument not an object: ' + format);\r\n }\r\n\r\n str = x.toFixed(dp, rm);\r\n\r\n if (x.c) {\r\n var i,\r\n arr = str.split('.'),\r\n g1 = +format.groupSize,\r\n g2 = +format.secondaryGroupSize,\r\n groupSeparator = format.groupSeparator || '',\r\n intPart = arr[0],\r\n fractionPart = arr[1],\r\n isNeg = x.s < 0,\r\n intDigits = isNeg ? intPart.slice(1) : intPart,\r\n len = intDigits.length;\r\n\r\n if (g2) i = g1, g1 = g2, g2 = i, len -= i;\r\n\r\n if (g1 > 0 && len > 0) {\r\n i = len % g1 || g1;\r\n intPart = intDigits.substr(0, i);\r\n for (; i < len; i += g1) intPart += groupSeparator + intDigits.substr(i, g1);\r\n if (g2 > 0) intPart += groupSeparator + intDigits.slice(i);\r\n if (isNeg) intPart = '-' + intPart;\r\n }\r\n\r\n str = fractionPart\r\n ? intPart + (format.decimalSeparator || '') + ((g2 = +format.fractionGroupSize)\r\n ? fractionPart.replace(new RegExp('\\\\d{' + g2 + '}\\\\B', 'g'),\r\n '$&' + (format.fractionGroupSeparator || ''))\r\n : fractionPart)\r\n : intPart;\r\n }\r\n\r\n return (format.prefix || '') + str + (format.suffix || '');\r\n };\r\n\r\n\r\n /*\r\n * Return an array of two BigNumbers representing the value of this BigNumber as a simple\r\n * fraction with an integer numerator and an integer denominator.\r\n * The denominator will be a positive non-zero value less than or equal to the specified\r\n * maximum denominator. If a maximum denominator is not specified, the denominator will be\r\n * the lowest value necessary to represent the number exactly.\r\n *\r\n * [md] {number|string|BigNumber} Integer >= 1, or Infinity. The maximum denominator.\r\n *\r\n * '[BigNumber Error] Argument {not an integer|out of range} : {md}'\r\n */\r\n P.toFraction = function (md) {\r\n var d, d0, d1, d2, e, exp, n, n0, n1, q, r, s,\r\n x = this,\r\n xc = x.c;\r\n\r\n if (md != null) {\r\n n = new BigNumber(md);\r\n\r\n // Throw if md is less than one or is not an integer, unless it is Infinity.\r\n if (!n.isInteger() && (n.c || n.s !== 1) || n.lt(ONE)) {\r\n throw Error\r\n (bignumberError + 'Argument ' +\r\n (n.isInteger() ? 'out of range: ' : 'not an integer: ') + valueOf(n));\r\n }\r\n }\r\n\r\n if (!xc) return new BigNumber(x);\r\n\r\n d = new BigNumber(ONE);\r\n n1 = d0 = new BigNumber(ONE);\r\n d1 = n0 = new BigNumber(ONE);\r\n s = coeffToString(xc);\r\n\r\n // Determine initial denominator.\r\n // d is a power of 10 and the minimum max denominator that specifies the value exactly.\r\n e = d.e = s.length - x.e - 1;\r\n d.c[0] = POWS_TEN[(exp = e % LOG_BASE) < 0 ? LOG_BASE + exp : exp];\r\n md = !md || n.comparedTo(d) > 0 ? (e > 0 ? d : n1) : n;\r\n\r\n exp = MAX_EXP;\r\n MAX_EXP = 1 / 0;\r\n n = new BigNumber(s);\r\n\r\n // n0 = d1 = 0\r\n n0.c[0] = 0;\r\n\r\n for (; ;) {\r\n q = div(n, d, 0, 1);\r\n d2 = d0.plus(q.times(d1));\r\n if (d2.comparedTo(md) == 1) break;\r\n d0 = d1;\r\n d1 = d2;\r\n n1 = n0.plus(q.times(d2 = n1));\r\n n0 = d2;\r\n d = n.minus(q.times(d2 = d));\r\n n = d2;\r\n }\r\n\r\n d2 = div(md.minus(d0), d1, 0, 1);\r\n n0 = n0.plus(d2.times(n1));\r\n d0 = d0.plus(d2.times(d1));\r\n n0.s = n1.s = x.s;\r\n e = e * 2;\r\n\r\n // Determine which fraction is closer to x, n0/d0 or n1/d1\r\n r = div(n1, d1, e, ROUNDING_MODE).minus(x).abs().comparedTo(\r\n div(n0, d0, e, ROUNDING_MODE).minus(x).abs()) < 1 ? [n1, d1] : [n0, d0];\r\n\r\n MAX_EXP = exp;\r\n\r\n return r;\r\n };\r\n\r\n\r\n /*\r\n * Return the value of this BigNumber converted to a number primitive.\r\n */\r\n P.toNumber = function () {\r\n return +valueOf(this);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber rounded to sd significant digits\r\n * using rounding mode rm or ROUNDING_MODE. If sd is less than the number of digits\r\n * necessary to represent the integer part of the value in fixed-point notation, then use\r\n * exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * '[BigNumber Error] Argument {not a primitive number|not an integer|out of range}: {sd|rm}'\r\n */\r\n P.toPrecision = function (sd, rm) {\r\n if (sd != null) intCheck(sd, 1, MAX);\r\n return format(this, sd, rm, 2);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this BigNumber in base b, or base 10 if b is\r\n * omitted. If a base is specified, including base 10, round according to DECIMAL_PLACES and\r\n * ROUNDING_MODE. If a base is not specified, and this BigNumber has a positive exponent\r\n * that is equal to or greater than TO_EXP_POS, or a negative exponent equal to or less than\r\n * TO_EXP_NEG, return exponential notation.\r\n *\r\n * [b] {number} Integer, 2 to ALPHABET.length inclusive.\r\n *\r\n * '[BigNumber Error] Base {not a primitive number|not an integer|out of range}: {b}'\r\n */\r\n P.toString = function (b) {\r\n var str,\r\n n = this,\r\n s = n.s,\r\n e = n.e;\r\n\r\n // Infinity or NaN?\r\n if (e === null) {\r\n if (s) {\r\n str = 'Infinity';\r\n if (s < 0) str = '-' + str;\r\n } else {\r\n str = 'NaN';\r\n }\r\n } else {\r\n if (b == null) {\r\n str = e <= TO_EXP_NEG || e >= TO_EXP_POS\r\n ? toExponential(coeffToString(n.c), e)\r\n : toFixedPoint(coeffToString(n.c), e, '0');\r\n } else if (b === 10) {\r\n n = round(new BigNumber(n), DECIMAL_PLACES + e + 1, ROUNDING_MODE);\r\n str = toFixedPoint(coeffToString(n.c), n.e, '0');\r\n } else {\r\n intCheck(b, 2, ALPHABET.length, 'Base');\r\n str = convertBase(toFixedPoint(coeffToString(n.c), e, '0'), 10, b, s, true);\r\n }\r\n\r\n if (s < 0 && n.c[0]) str = '-' + str;\r\n }\r\n\r\n return str;\r\n };\r\n\r\n\r\n /*\r\n * Return as toString, but do not accept a base argument, and include the minus sign for\r\n * negative zero.\r\n */\r\n P.valueOf = P.toJSON = function () {\r\n return valueOf(this);\r\n };\r\n\r\n\r\n P._isBigNumber = true;\r\n\r\n if (configObject != null) BigNumber.set(configObject);\r\n\r\n return BigNumber;\r\n }\r\n\r\n\r\n // PRIVATE HELPER FUNCTIONS\r\n\r\n // These functions don't need access to variables,\r\n // e.g. DECIMAL_PLACES, in the scope of the `clone` function above.\r\n\r\n\r\n function bitFloor(n) {\r\n var i = n | 0;\r\n return n > 0 || n === i ? i : i - 1;\r\n }\r\n\r\n\r\n // Return a coefficient array as a string of base 10 digits.\r\n function coeffToString(a) {\r\n var s, z,\r\n i = 1,\r\n j = a.length,\r\n r = a[0] + '';\r\n\r\n for (; i < j;) {\r\n s = a[i++] + '';\r\n z = LOG_BASE - s.length;\r\n for (; z--; s = '0' + s);\r\n r += s;\r\n }\r\n\r\n // Determine trailing zeros.\r\n for (j = r.length; r.charCodeAt(--j) === 48;);\r\n\r\n return r.slice(0, j + 1 || 1);\r\n }\r\n\r\n\r\n // Compare the value of BigNumbers x and y.\r\n function compare(x, y) {\r\n var a, b,\r\n xc = x.c,\r\n yc = y.c,\r\n i = x.s,\r\n j = y.s,\r\n k = x.e,\r\n l = y.e;\r\n\r\n // Either NaN?\r\n if (!i || !j) return null;\r\n\r\n a = xc && !xc[0];\r\n b = yc && !yc[0];\r\n\r\n // Either zero?\r\n if (a || b) return a ? b ? 0 : -j : i;\r\n\r\n // Signs differ?\r\n if (i != j) return i;\r\n\r\n a = i < 0;\r\n b = k == l;\r\n\r\n // Either Infinity?\r\n if (!xc || !yc) return b ? 0 : !xc ^ a ? 1 : -1;\r\n\r\n // Compare exponents.\r\n if (!b) return k > l ^ a ? 1 : -1;\r\n\r\n j = (k = xc.length) < (l = yc.length) ? k : l;\r\n\r\n // Compare digit by digit.\r\n for (i = 0; i < j; i++) if (xc[i] != yc[i]) return xc[i] > yc[i] ^ a ? 1 : -1;\r\n\r\n // Compare lengths.\r\n return k == l ? 0 : k > l ^ a ? 1 : -1;\r\n }\r\n\r\n\r\n /*\r\n * Check that n is a primitive number, an integer, and in range, otherwise throw.\r\n */\r\n function intCheck(n, min, max, name) {\r\n if (n < min || n > max || n !== mathfloor(n)) {\r\n throw Error\r\n (bignumberError + (name || 'Argument') + (typeof n == 'number'\r\n ? n < min || n > max ? ' out of range: ' : ' not an integer: '\r\n : ' not a primitive number: ') + String(n));\r\n }\r\n }\r\n\r\n\r\n // Assumes finite n.\r\n function isOdd(n) {\r\n var k = n.c.length - 1;\r\n return bitFloor(n.e / LOG_BASE) == k && n.c[k] % 2 != 0;\r\n }\r\n\r\n\r\n function toExponential(str, e) {\r\n return (str.length > 1 ? str.charAt(0) + '.' + str.slice(1) : str) +\r\n (e < 0 ? 'e' : 'e+') + e;\r\n }\r\n\r\n\r\n function toFixedPoint(str, e, z) {\r\n var len, zs;\r\n\r\n // Negative exponent?\r\n if (e < 0) {\r\n\r\n // Prepend zeros.\r\n for (zs = z + '.'; ++e; zs += z);\r\n str = zs + str;\r\n\r\n // Positive exponent\r\n } else {\r\n len = str.length;\r\n\r\n // Append zeros.\r\n if (++e > len) {\r\n for (zs = z, e -= len; --e; zs += z);\r\n str += zs;\r\n } else if (e < len) {\r\n str = str.slice(0, e) + '.' + str.slice(e);\r\n }\r\n }\r\n\r\n return str;\r\n }\r\n\r\n\r\n // EXPORT\r\n\r\n\r\n BigNumber = clone();\r\n BigNumber['default'] = BigNumber.BigNumber = BigNumber;\r\n\r\n // AMD.\r\n if (typeof define == 'function' && define.amd) {\r\n define(function () { return BigNumber; });\r\n\r\n // Node.js and other environments that support module.exports.\r\n } else if (typeof module != 'undefined' && module.exports) {\r\n module.exports = BigNumber;\r\n\r\n // Browser.\r\n } else {\r\n if (!globalObject) {\r\n globalObject = typeof self != 'undefined' && self ? self : window;\r\n }\r\n\r\n globalObject.BigNumber = BigNumber;\r\n }\r\n})(this);\r\n","'use strict'\n\nconst exp = Math.exp\n\nexports =\nmodule.exports =\nfunction MovingAverage (timespan) {\n if (typeof timespan !== 'number') { throw new Error('must provide a timespan to the moving average constructor') }\n\n if (timespan <= 0) { throw new Error('must provide a timespan > 0 to the moving average constructor') }\n\n let ma // moving average\n let v = 0 // variance\n let d = 0 // deviation\n let f = 0 // forecast\n\n let previousTime\n\n let ret = {}\n\n function alpha (t, pt) {\n return 1 - (exp(-(t - pt) / timespan))\n }\n\n ret.push =\n function push (time, value) {\n if (previousTime) {\n // calculate moving average\n const a = alpha(time, previousTime)\n const diff = value - ma\n const incr = a * diff\n ma = a * value + (1 - a) * ma\n // calculate variance & deviation\n v = (1 - a) * (v + diff * incr)\n d = Math.sqrt(v)\n // calculate forecast\n f = ma + a * diff\n } else {\n ma = value\n }\n previousTime = time\n }\n\n // Exponential Moving Average\n\n ret.movingAverage =\n function movingAverage () {\n return ma\n }\n\n // Variance\n ret.variance =\n function variance () {\n return v\n }\n\n ret.deviation =\n function deviation () {\n return d\n }\n\n ret.forecast =\n function forecast () {\n return f\n }\n\n return ret\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:upgrader'), {\n error: debug('libp2p:upgrader:err')\n})\nconst errCode = require('err-code')\n// @ts-ignore multistream-select does not export types\nconst Multistream = require('multistream-select')\nconst { Connection } = require('libp2p-interfaces/src/connection')\nconst PeerId = require('peer-id')\nconst { pipe } = require('it-pipe')\n// @ts-ignore mutable-proxy does not export types\nconst mutableProxy = require('mutable-proxy')\n\nconst { codes } = require('./errors')\n\n/**\n * @typedef {import('libp2p-interfaces/src/transport/types').MultiaddrConnection} MultiaddrConnection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxerFactory} MuxerFactory\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').Muxer} Muxer\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('libp2p-interfaces/src/crypto/types').Crypto} Crypto\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * @typedef CryptoResult\n * @property {MultiaddrConnection} conn A duplex iterable\n * @property {PeerId} remotePeer\n * @property {string} protocol\n */\n\nclass Upgrader {\n /**\n * @param {object} options\n * @param {PeerId} options.localPeer\n * @param {import('./metrics')} [options.metrics]\n * @param {Map<string, Crypto>} [options.cryptos]\n * @param {Map<string, MuxerFactory>} [options.muxers]\n * @param {(connection: Connection) => void} options.onConnection - Called when a connection is upgraded\n * @param {(connection: Connection) => void} options.onConnectionEnd\n */\n constructor ({\n localPeer,\n metrics,\n cryptos = new Map(),\n muxers = new Map(),\n onConnectionEnd = () => {},\n onConnection = () => {}\n }) {\n this.localPeer = localPeer\n this.metrics = metrics\n this.cryptos = cryptos\n this.muxers = muxers\n /** @type {import(\"./pnet\") | null} */\n this.protector = null\n this.protocols = new Map()\n this.onConnection = onConnection\n this.onConnectionEnd = onConnectionEnd\n }\n\n /**\n * Upgrades an inbound connection\n *\n * @async\n * @param {MultiaddrConnection} maConn\n * @returns {Promise<Connection>}\n */\n async upgradeInbound (maConn) {\n let encryptedConn\n let remotePeer\n let upgradedConn\n let Muxer\n let cryptoProtocol\n let setPeer\n let proxyPeer\n\n if (this.metrics) {\n ({ setTarget: setPeer, proxy: proxyPeer } = mutableProxy())\n const idString = (Math.random() * 1e9).toString(36) + Date.now()\n setPeer({ toB58String: () => idString })\n maConn = this.metrics.trackStream({ stream: maConn, remotePeer: proxyPeer })\n }\n\n log('Starting the inbound connection upgrade')\n\n // Protect\n let protectedConn = maConn\n if (this.protector) {\n protectedConn = await this.protector.protect(maConn)\n }\n\n try {\n // Encrypt the connection\n ({\n conn: encryptedConn,\n remotePeer,\n protocol: cryptoProtocol\n } = await this._encryptInbound(this.localPeer, protectedConn, this.cryptos))\n\n // Multiplex the connection\n if (this.muxers.size) {\n ({ stream: upgradedConn, Muxer } = await this._multiplexInbound(encryptedConn, this.muxers))\n } else {\n upgradedConn = encryptedConn\n }\n } catch (err) {\n log.error('Failed to upgrade inbound connection', err)\n await maConn.close(err)\n throw err\n }\n\n if (this.metrics) {\n this.metrics.updatePlaceholder(proxyPeer, remotePeer)\n setPeer(remotePeer)\n }\n\n log('Successfully upgraded inbound connection')\n\n return this._createConnection({\n cryptoProtocol,\n direction: 'inbound',\n maConn,\n upgradedConn,\n Muxer,\n remotePeer\n })\n }\n\n /**\n * Upgrades an outbound connection\n *\n * @async\n * @param {MultiaddrConnection} maConn\n * @returns {Promise<Connection>}\n */\n async upgradeOutbound (maConn) {\n const idStr = maConn.remoteAddr.getPeerId()\n if (!idStr) {\n throw errCode(new Error('outbound connection must have a peer id'), codes.ERR_INVALID_MULTIADDR)\n }\n\n const remotePeerId = PeerId.createFromB58String(idStr)\n\n let encryptedConn\n let remotePeer\n let upgradedConn\n let cryptoProtocol\n let Muxer\n let setPeer\n let proxyPeer\n\n if (this.metrics) {\n ({ setTarget: setPeer, proxy: proxyPeer } = mutableProxy())\n const idString = (Math.random() * 1e9).toString(36) + Date.now()\n setPeer({ toB58String: () => idString })\n maConn = this.metrics.trackStream({ stream: maConn, remotePeer: proxyPeer })\n }\n\n log('Starting the outbound connection upgrade')\n\n // Protect\n let protectedConn = maConn\n if (this.protector) {\n protectedConn = await this.protector.protect(maConn)\n }\n\n try {\n // Encrypt the connection\n ({\n conn: encryptedConn,\n remotePeer,\n protocol: cryptoProtocol\n } = await this._encryptOutbound(this.localPeer, protectedConn, remotePeerId, this.cryptos))\n\n // Multiplex the connection\n if (this.muxers.size) {\n ({ stream: upgradedConn, Muxer } = await this._multiplexOutbound(encryptedConn, this.muxers))\n } else {\n upgradedConn = encryptedConn\n }\n } catch (err) {\n log.error('Failed to upgrade outbound connection', err)\n await maConn.close(err)\n throw err\n }\n\n if (this.metrics) {\n this.metrics.updatePlaceholder(proxyPeer, remotePeer)\n setPeer(remotePeer)\n }\n\n log('Successfully upgraded outbound connection')\n\n return this._createConnection({\n cryptoProtocol,\n direction: 'outbound',\n maConn,\n upgradedConn,\n Muxer,\n remotePeer\n })\n }\n\n /**\n * A convenience method for generating a new `Connection`\n *\n * @private\n * @param {object} options\n * @param {string} options.cryptoProtocol - The crypto protocol that was negotiated\n * @param {'inbound' | 'outbound'} options.direction - One of ['inbound', 'outbound']\n * @param {MultiaddrConnection} options.maConn - The transport layer connection\n * @param {MuxedStream | MultiaddrConnection} options.upgradedConn - A duplex connection returned from multiplexer and/or crypto selection\n * @param {MuxerFactory} [options.Muxer] - The muxer to be used for muxing\n * @param {PeerId} options.remotePeer - The peer the connection is with\n * @returns {Connection}\n */\n _createConnection ({\n cryptoProtocol,\n direction,\n maConn,\n upgradedConn,\n Muxer,\n remotePeer\n }) {\n /** @type {import(\"libp2p-interfaces/src/stream-muxer/types\").Muxer} */\n let muxer\n /** @type {import(\"libp2p-interfaces/src/connection/connection\").CreatedMuxedStream | undefined} */\n let newStream\n /** @type {Connection} */\n let connection // eslint-disable-line prefer-const\n\n if (Muxer) {\n // Create the muxer\n muxer = new Muxer({\n // Run anytime a remote stream is created\n onStream: async muxedStream => {\n if (!connection) return\n const mss = new Multistream.Listener(muxedStream)\n try {\n const { stream, protocol } = await mss.handle(Array.from(this.protocols.keys()))\n log('%s: incoming stream opened on %s', direction, protocol)\n if (this.metrics) this.metrics.trackStream({ stream, remotePeer, protocol })\n connection.addStream(muxedStream, { protocol })\n this._onStream({ connection, stream: { ...muxedStream, ...stream }, protocol })\n } catch (err) {\n log.error(err)\n }\n },\n // Run anytime a stream closes\n onStreamEnd: muxedStream => {\n connection.removeStream(muxedStream.id)\n }\n })\n\n newStream = async (protocols) => {\n log('%s: starting new stream on %s', direction, protocols)\n const muxedStream = muxer.newStream()\n const mss = new Multistream.Dialer(muxedStream)\n try {\n const { stream, protocol } = await mss.select(protocols)\n if (this.metrics) this.metrics.trackStream({ stream, remotePeer, protocol })\n return { stream: { ...muxedStream, ...stream }, protocol }\n } catch (err) {\n log.error('could not create new stream', err)\n throw errCode(err, codes.ERR_UNSUPPORTED_PROTOCOL)\n }\n }\n\n // Pipe all data through the muxer\n pipe(upgradedConn, muxer, upgradedConn).catch(log.error)\n }\n\n const _timeline = maConn.timeline\n maConn.timeline = new Proxy(_timeline, {\n set: (...args) => {\n if (connection && args[1] === 'close' && args[2] && !_timeline.close) {\n // Wait for close to finish before notifying of the closure\n (async () => {\n try {\n if (connection.stat.status === 'open') {\n await connection.close()\n }\n } catch (err) {\n log.error(err)\n } finally {\n this.onConnectionEnd(connection)\n }\n })()\n }\n\n return Reflect.set(...args)\n }\n })\n maConn.timeline.upgraded = Date.now()\n\n const errConnectionNotMultiplexed = () => {\n throw errCode(new Error('connection is not multiplexed'), 'ERR_CONNECTION_NOT_MULTIPLEXED')\n }\n\n // Create the connection\n connection = new Connection({\n localAddr: maConn.localAddr,\n remoteAddr: maConn.remoteAddr,\n localPeer: this.localPeer,\n remotePeer: remotePeer,\n stat: {\n direction,\n // @ts-ignore\n timeline: maConn.timeline,\n multiplexer: Muxer && Muxer.multicodec,\n encryption: cryptoProtocol\n },\n newStream: newStream || errConnectionNotMultiplexed,\n getStreams: () => muxer ? muxer.streams : errConnectionNotMultiplexed(),\n close: async () => {\n await maConn.close()\n // Ensure remaining streams are aborted\n if (muxer) {\n muxer.streams.map(stream => stream.abort())\n }\n }\n })\n\n this.onConnection(connection)\n\n return connection\n }\n\n /**\n * Routes incoming streams to the correct handler\n *\n * @private\n * @param {object} options\n * @param {Connection} options.connection - The connection the stream belongs to\n * @param {MuxedStream} options.stream\n * @param {string} options.protocol\n */\n _onStream ({ connection, stream, protocol }) {\n const handler = this.protocols.get(protocol)\n handler({ connection, stream, protocol })\n }\n\n /**\n * Attempts to encrypt the incoming `connection` with the provided `cryptos`.\n *\n * @private\n * @async\n * @param {PeerId} localPeer - The initiators PeerId\n * @param {*} connection\n * @param {Map<string, Crypto>} cryptos\n * @returns {Promise<CryptoResult>} An encrypted connection, remote peer `PeerId` and the protocol of the `Crypto` used\n */\n async _encryptInbound (localPeer, connection, cryptos) {\n const mss = new Multistream.Listener(connection)\n const protocols = Array.from(cryptos.keys())\n log('handling inbound crypto protocol selection', protocols)\n\n try {\n const { stream, protocol } = await mss.handle(protocols)\n const crypto = cryptos.get(protocol)\n log('encrypting inbound connection...')\n\n if (!crypto) {\n throw new Error(`no crypto module found for ${protocol}`)\n }\n\n return {\n ...await crypto.secureInbound(localPeer, stream),\n protocol\n }\n } catch (err) {\n throw errCode(err, codes.ERR_ENCRYPTION_FAILED)\n }\n }\n\n /**\n * Attempts to encrypt the given `connection` with the provided `cryptos`.\n * The first `Crypto` module to succeed will be used\n *\n * @private\n * @async\n * @param {PeerId} localPeer - The initiators PeerId\n * @param {MultiaddrConnection} connection\n * @param {PeerId} remotePeerId\n * @param {Map<string, Crypto>} cryptos\n * @returns {Promise<CryptoResult>} An encrypted connection, remote peer `PeerId` and the protocol of the `Crypto` used\n */\n async _encryptOutbound (localPeer, connection, remotePeerId, cryptos) {\n const mss = new Multistream.Dialer(connection)\n const protocols = Array.from(cryptos.keys())\n log('selecting outbound crypto protocol', protocols)\n\n try {\n const { stream, protocol } = await mss.select(protocols)\n const crypto = cryptos.get(protocol)\n log('encrypting outbound connection to %j', remotePeerId)\n\n if (!crypto) {\n throw new Error(`no crypto module found for ${protocol}`)\n }\n\n return {\n ...await crypto.secureOutbound(localPeer, stream, remotePeerId),\n protocol\n }\n } catch (err) {\n throw errCode(err, codes.ERR_ENCRYPTION_FAILED)\n }\n }\n\n /**\n * Selects one of the given muxers via multistream-select. That\n * muxer will be used for all future streams on the connection.\n *\n * @private\n * @async\n * @param {MultiaddrConnection} connection - A basic duplex connection to multiplex\n * @param {Map<string, MuxerFactory>} muxers - The muxers to attempt multiplexing with\n * @returns {Promise<{ stream: MuxedStream, Muxer?: MuxerFactory}>} A muxed connection\n */\n async _multiplexOutbound (connection, muxers) {\n const dialer = new Multistream.Dialer(connection)\n const protocols = Array.from(muxers.keys())\n log('outbound selecting muxer %s', protocols)\n try {\n const { stream, protocol } = await dialer.select(protocols)\n log('%s selected as muxer protocol', protocol)\n const Muxer = muxers.get(protocol)\n return { stream, Muxer }\n } catch (err) {\n throw errCode(err, codes.ERR_MUXER_UNAVAILABLE)\n }\n }\n\n /**\n * Registers support for one of the given muxers via multistream-select. The\n * selected muxer will be used for all future streams on the connection.\n *\n * @private\n * @async\n * @param {MultiaddrConnection} connection - A basic duplex connection to multiplex\n * @param {Map<string, MuxerFactory>} muxers - The muxers to attempt multiplexing with\n * @returns {Promise<{ stream: MuxedStream, Muxer?: MuxerFactory}>} A muxed connection\n */\n async _multiplexInbound (connection, muxers) {\n const listener = new Multistream.Listener(connection)\n const protocols = Array.from(muxers.keys())\n log('inbound handling muxers %s', protocols)\n try {\n const { stream, protocol } = await listener.handle(protocols)\n const Muxer = muxers.get(protocol)\n return { stream, Muxer }\n } catch (err) {\n throw errCode(err, codes.ERR_MUXER_UNAVAILABLE)\n }\n }\n}\n\nmodule.exports = Upgrader\n","'use strict'\n\nconst select = require('./select')\nconst handle = require('./handle')\nconst ls = require('./ls')\nconst { PROTOCOL_ID } = require('./constants')\n\nexports.PROTOCOL_ID = PROTOCOL_ID\n\nclass MultistreamSelect {\n constructor (stream) {\n this._stream = stream\n this._shaken = false\n }\n\n // Perform the multistream-select handshake\n async _handshake () {\n if (this._shaken) return\n const { stream } = await select(this._stream, PROTOCOL_ID)\n this._stream = stream\n this._shaken = true\n }\n}\n\nclass Dialer extends MultistreamSelect {\n select (protocols) {\n return select(this._stream, protocols, this._shaken ? null : PROTOCOL_ID)\n }\n\n async ls () {\n await this._handshake()\n const { stream, protocols } = await ls(this._stream)\n this._stream = stream\n return protocols\n }\n}\n\nexports.Dialer = Dialer\n\nclass Listener extends MultistreamSelect {\n handle (protocols) {\n return handle(this._stream, protocols)\n }\n}\n\nexports.Listener = Listener\n","'use strict'\n\nconst log = require('debug')('mss:select')\nconst errCode = require('err-code')\nconst multistream = require('./multistream')\nconst handshake = require('it-handshake')\n\nmodule.exports = async (stream, protocols, protocolId) => {\n protocols = Array.isArray(protocols) ? [...protocols] : [protocols]\n const { reader, writer, rest, stream: shakeStream } = handshake(stream)\n\n const protocol = protocols.shift()\n if (protocolId) {\n log('select: write [\"%s\", \"%s\"]', protocolId, protocol)\n multistream.writeAll(writer, [protocolId, protocol])\n } else {\n log('select: write \"%s\"', protocol)\n multistream.write(writer, protocol)\n }\n\n let response = (await multistream.read(reader)).toString()\n log('select: read \"%s\"', response)\n\n // Read the protocol response if we got the protocolId in return\n if (response === protocolId) {\n response = (await multistream.read(reader)).toString()\n log('select: read \"%s\"', response)\n }\n\n // We're done\n if (response === protocol) {\n rest()\n return { stream: shakeStream, protocol }\n }\n\n // We haven't gotten a valid ack, try the other protocols\n for (const protocol of protocols) {\n log('select: write \"%s\"', protocol)\n multistream.write(writer, protocol)\n const response = (await multistream.read(reader)).toString()\n log('select: read \"%s\" for \"%s\"', response, protocol)\n\n if (response === protocol) {\n rest() // End our writer so others can start writing to stream\n return { stream: shakeStream, protocol }\n }\n }\n\n rest()\n throw errCode(new Error('protocol selection failed'), 'ERR_UNSUPPORTED_PROTOCOL')\n}\n","'use strict'\n\nconst BufferList = require('bl/BufferList')\nconst lp = require('it-length-prefixed')\nconst pipe = require('it-pipe')\nconst errCode = require('err-code')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\nconst first = require('it-first')\n\nconst NewLine = uint8ArrayFromString('\\n')\n\nexports.encode = buffer => lp.encode.single(new BufferList([buffer, NewLine]))\n\n// `write` encodes and writes a single buffer\nexports.write = (writer, buffer) => writer.push(exports.encode(buffer))\n\n// `writeAll` behaves like `write`, except it encodes an array of items as a single write\nexports.writeAll = (writer, buffers) => {\n writer.push(buffers.reduce((bl, buffer) => bl.append(exports.encode(buffer)), new BufferList()))\n}\n\nexports.read = async reader => {\n let byteLength = 1 // Read single byte chunks until the length is known\n const varByteSource = { // No return impl - we want the reader to remain readable\n [Symbol.asyncIterator] () { return this },\n next: () => reader.next(byteLength)\n }\n\n // Once the length has been parsed, read chunk for that length\n const onLength = l => { byteLength = l }\n const buf = await pipe(varByteSource, lp.decode({ onLength }), first)\n\n if (buf.get(buf.length - 1) !== NewLine[0]) {\n throw errCode(new Error('missing newline'), 'ERR_INVALID_MULTISTREAM_SELECT_MESSAGE')\n }\n\n return buf.shallowSlice(0, -1) // Remove newline\n}\n","'use strict'\n\nconst log = require('debug')('mss:handle')\nconst BufferList = require('bl/BufferList')\nconst multistream = require('./multistream')\nconst handshake = require('it-handshake')\nconst { PROTOCOL_ID } = require('./constants')\n\nmodule.exports = async (stream, protocols) => {\n protocols = Array.isArray(protocols) ? protocols : [protocols]\n const { writer, reader, rest, stream: shakeStream } = handshake(stream)\n\n while (true) {\n const protocol = (await multistream.read(reader)).toString()\n log('read \"%s\"', protocol)\n\n if (protocol === PROTOCOL_ID) {\n log('respond with \"%s\" for \"%s\"', PROTOCOL_ID, protocol)\n multistream.write(writer, PROTOCOL_ID)\n continue\n }\n\n if (protocols.includes(protocol)) {\n multistream.write(writer, protocol)\n log('respond with \"%s\" for \"%s\"', protocol, protocol)\n rest()\n return { stream: shakeStream, protocol }\n }\n\n if (protocol === 'ls') {\n // <varint-msg-len><varint-proto-name-len><proto-name>\\n<varint-proto-name-len><proto-name>\\n\\n\n multistream.write(writer, new BufferList(\n protocols.map(p => multistream.encode(p))\n ))\n log('respond with \"%s\" for %s', protocols, protocol)\n continue\n }\n\n multistream.write(writer, 'na')\n log('respond with \"na\" for \"%s\"', protocol)\n }\n}\n","'use strict'\n\nexports.PROTOCOL_ID = '/multistream/1.0.0'\n","'use strict'\n\nconst Reader = require('it-reader')\nconst log = require('debug')('it-multistream-select:ls')\nconst multistream = require('./multistream')\nconst handshake = require('it-handshake')\nconst lp = require('it-length-prefixed')\nconst pipe = require('it-pipe')\n\nmodule.exports = async stream => {\n const { reader, writer, rest, stream: shakeStream } = handshake(stream)\n\n log('write \"ls\"')\n multistream.write(writer, 'ls')\n rest()\n\n // Next message from remote will be (e.g. for 2 protocols):\n // <varint-msg-len><varint-proto-name-len><proto-name>\\n<varint-proto-name-len><proto-name>\\n\n const res = await multistream.read(reader)\n\n // After reading response we have:\n // <varint-proto-name-len><proto-name>\\n<varint-proto-name-len><proto-name>\\n\n const protocolsReader = Reader([res])\n const protocols = []\n\n // Decode each of the protocols from the reader\n await pipe(\n protocolsReader,\n lp.decode(),\n async source => {\n for await (const protocol of source) {\n // Remove the newline\n protocols.push(protocol.shallowSlice(0, -1).toString())\n }\n }\n )\n\n return { stream: shakeStream, protocols }\n}\n","'use strict'\n\nexports.Connection = require('./connection')\n","'use strict'\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\nconst errCode = require('err-code')\nconst { OPEN, CLOSING, CLOSED } = require('./status')\n\nconst connectionSymbol = Symbol.for('@libp2p/interface-connection/connection')\n\n/**\n * @typedef {import('../stream-muxer/types').MuxedStream} MuxedStream\n * @typedef {import('./status').Status} Status\n */\n\n/**\n * @typedef {Object} Timeline\n * @property {number} open - connection opening timestamp.\n * @property {number} [upgraded] - connection upgraded timestamp.\n * @property {number} [close]\n *\n * @typedef {Object} ConectionStat\n * @property {'inbound' | 'outbound'} direction - connection establishment direction\n * @property {Timeline} timeline - connection relevant events timestamp.\n * @property {string} [multiplexer] - connection multiplexing identifier.\n * @property {string} [encryption] - connection encryption method identifier.\n *\n * @typedef {(protocols: string|string[]) => Promise<{stream: MuxedStream, protocol: string}>} CreatedMuxedStream\n *\n * @typedef {Object} ConnectionOptions\n * @property {Multiaddr} [localAddr] - local multiaddr of the connection if known.\n * @property {Multiaddr} remoteAddr - remote multiaddr of the connection.\n * @property {PeerId} localPeer - local peer-id.\n * @property {PeerId} remotePeer - remote peer-id.\n * @property {CreatedMuxedStream} newStream - new stream muxer function.\n * @property {() => Promise<void>} close - close raw connection function.\n * @property {() => MuxedStream[]} getStreams - get streams from muxer function.\n * @property {ConectionStat} stat - metadata of the connection.\n *\n * @typedef {Object} StreamData\n * @property {string} protocol - the protocol used by the stream\n * @property {Object} [metadata] - metadata of the stream\n */\n\n/**\n * An implementation of the js-libp2p connection.\n * Any libp2p transport should use an upgrader to return this connection.\n */\nclass Connection {\n /**\n * An implementation of the js-libp2p connection.\n * Any libp2p transport should use an upgrader to return this connection.\n *\n * @class\n * @param {ConnectionOptions} options\n */\n constructor ({ localAddr, remoteAddr, localPeer, remotePeer, newStream, close, getStreams, stat }) {\n validateArgs(localAddr, localPeer, remotePeer, newStream, close, getStreams, stat)\n\n /**\n * Connection identifier.\n */\n this.id = (parseInt(String(Math.random() * 1e9))).toString(36) + Date.now()\n\n /**\n * Observed multiaddr of the local peer\n */\n this.localAddr = localAddr\n\n /**\n * Observed multiaddr of the remote peer\n */\n this.remoteAddr = remoteAddr\n\n /**\n * Local peer id.\n */\n this.localPeer = localPeer\n\n /**\n * Remote peer id.\n */\n this.remotePeer = remotePeer\n\n /**\n * Connection metadata.\n *\n * @type {ConectionStat & {status: Status}}\n */\n this._stat = {\n ...stat,\n status: OPEN\n }\n\n /**\n * Reference to the new stream function of the multiplexer\n */\n this._newStream = newStream\n\n /**\n * Reference to the close function of the raw connection\n */\n this._close = close\n\n /**\n * Reference to the getStreams function of the muxer\n */\n this._getStreams = getStreams\n\n /**\n * Connection streams registry\n */\n this.registry = new Map()\n\n /**\n * User provided tags\n *\n * @type {string[]}\n */\n this.tags = []\n }\n\n get [Symbol.toStringTag] () {\n return 'Connection'\n }\n\n get [connectionSymbol] () {\n return true\n }\n\n /**\n * Checks if the given value is a `Connection` instance.\n *\n * @param {any} other\n * @returns {other is Connection}\n */\n static isConnection (other) {\n return Boolean(other && other[connectionSymbol])\n }\n\n /**\n * Get connection metadata\n *\n * @this {Connection}\n */\n get stat () {\n return this._stat\n }\n\n /**\n * Get all the streams of the muxer.\n *\n * @this {Connection}\n */\n get streams () {\n return this._getStreams()\n }\n\n /**\n * Create a new stream from this connection\n *\n * @param {string|string[]} protocols - intended protocol for the stream\n * @returns {Promise<{stream: MuxedStream, protocol: string}>} with muxed+multistream-selected stream and selected protocol\n */\n async newStream (protocols) {\n if (this.stat.status === CLOSING) {\n throw errCode(new Error('the connection is being closed'), 'ERR_CONNECTION_BEING_CLOSED')\n }\n\n if (this.stat.status === CLOSED) {\n throw errCode(new Error('the connection is closed'), 'ERR_CONNECTION_CLOSED')\n }\n\n if (!Array.isArray(protocols)) protocols = [protocols]\n\n const { stream, protocol } = await this._newStream(protocols)\n\n this.addStream(stream, { protocol })\n\n return {\n stream,\n protocol\n }\n }\n\n /**\n * Add a stream when it is opened to the registry.\n *\n * @param {MuxedStream} muxedStream - a muxed stream\n * @param {StreamData} data - the stream data to be registered\n * @returns {void}\n */\n addStream (muxedStream, { protocol, metadata = {} }) {\n // Add metadata for the stream\n this.registry.set(muxedStream.id, {\n protocol,\n ...metadata\n })\n }\n\n /**\n * Remove stream registry after it is closed.\n *\n * @param {string} id - identifier of the stream\n */\n removeStream (id) {\n this.registry.delete(id)\n }\n\n /**\n * Close the connection.\n *\n * @returns {Promise<void>}\n */\n async close () {\n if (this.stat.status === CLOSED) {\n return\n }\n\n if (this._closing) {\n return this._closing\n }\n\n this.stat.status = CLOSING\n\n // Close raw connection\n this._closing = await this._close()\n\n this._stat.timeline.close = Date.now()\n this.stat.status = CLOSED\n }\n}\n\nmodule.exports = Connection\n\n/**\n * @param {Multiaddr|undefined} localAddr\n * @param {PeerId} localPeer\n * @param {PeerId} remotePeer\n * @param {(protocols: string | string[]) => Promise<{ stream: import(\"../stream-muxer/types\").MuxedStream; protocol: string; }>} newStream\n * @param {() => Promise<void>} close\n * @param {() => import(\"../stream-muxer/types\").MuxedStream[]} getStreams\n * @param {{ direction: any; timeline: any; multiplexer?: string | undefined; encryption?: string | undefined; }} stat\n */\nfunction validateArgs (localAddr, localPeer, remotePeer, newStream, close, getStreams, stat) {\n if (localAddr && !Multiaddr.isMultiaddr(localAddr)) {\n throw errCode(new Error('localAddr must be an instance of multiaddr'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!PeerId.isPeerId(localPeer)) {\n throw errCode(new Error('localPeer must be an instance of peer-id'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!PeerId.isPeerId(remotePeer)) {\n throw errCode(new Error('remotePeer must be an instance of peer-id'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (typeof newStream !== 'function') {\n throw errCode(new Error('new stream must be a function'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (typeof close !== 'function') {\n throw errCode(new Error('close must be a function'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (typeof getStreams !== 'function') {\n throw errCode(new Error('getStreams must be a function'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!stat) {\n throw errCode(new Error('connection metadata object must be provided'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (stat.direction !== 'inbound' && stat.direction !== 'outbound') {\n throw errCode(new Error('direction must be \"inbound\" or \"outbound\"'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!stat.timeline) {\n throw errCode(new Error('connection timeline object must be provided in the stat object'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!stat.timeline.open) {\n throw errCode(new Error('connection open timestamp must be provided'), 'ERR_INVALID_PARAMETERS')\n }\n\n if (!stat.timeline.upgraded) {\n throw errCode(new Error('connection upgraded timestamp must be provided'), 'ERR_INVALID_PARAMETERS')\n }\n}\n","'use strict'\n\nconst STATUS = {\n OPEN: /** @type {'open'} */('open'),\n CLOSING: /** @type {'closing'} */('closing'),\n CLOSED: /** @type {'closed'} */('closed')\n}\nmodule.exports = STATUS\n\n/**\n * @typedef {STATUS[keyof STATUS]} Status\n */\n","'use strict';\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nmodule.exports = function mutableProxyFactory(defaultTarget) {\n var mutableHandler = void 0;\n var mutableTarget = void 0;\n\n function setTarget(target) {\n if (!(target instanceof Object)) {\n throw new Error('Target \"' + target + '\" is not an object');\n }\n mutableTarget = target;\n }\n\n function setHandler(handler) {\n Object.keys(handler).forEach(function (key) {\n var value = handler[key];\n\n if (typeof value !== 'function') {\n throw new Error('Trap \"' + key + ': ' + value + '\" is not a function');\n }\n\n if (!Reflect[key]) {\n throw new Error('Trap \"' + key + ': ' + value + '\" is not a valid trap');\n }\n });\n mutableHandler = handler;\n }\n setTarget(function () {});\n\n if (defaultTarget) {\n setTarget(defaultTarget);\n }\n setHandler(Reflect);\n\n // Dynamically forward all the traps to the associated methods on the mutable handler\n var handler = new Proxy({}, {\n get: function get(target, property) {\n return function () {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return mutableHandler[property].apply(null, [mutableTarget].concat(_toConsumableArray(args.slice(1))));\n };\n }\n });\n\n return {\n setTarget: setTarget,\n setHandler: setHandler,\n getTarget: function getTarget() {\n return mutableTarget;\n },\n getHandler: function getHandler() {\n return mutableHandler;\n },\n\n proxy: new Proxy(mutableTarget, handler)\n };\n};","'use strict'\n\nconst errcode = require('err-code')\n\nconst { EventEmitter } = require('events')\nconst PeerId = require('peer-id')\n\nconst AddressBook = require('./address-book')\nconst KeyBook = require('./key-book')\nconst MetadataBook = require('./metadata-book')\nconst ProtoBook = require('./proto-book')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @typedef {import('./address-book').Address} Address\n */\n\n/**\n * @extends {EventEmitter}\n *\n * @fires PeerStore#peer Emitted when a new peer is added.\n * @fires PeerStore#change:protocols Emitted when a known peer supports a different set of protocols.\n * @fires PeerStore#change:multiaddrs Emitted when a known peer has a different set of multiaddrs.\n * @fires PeerStore#change:pubkey Emitted emitted when a peer's public key is known.\n * @fires PeerStore#change:metadata Emitted when the known metadata of a peer change.\n */\nclass PeerStore extends EventEmitter {\n /**\n * Peer object\n *\n * @typedef {Object} Peer\n * @property {PeerId} id peer's peer-id instance.\n * @property {Address[]} addresses peer's addresses containing its multiaddrs and metadata.\n * @property {string[]} protocols peer's supported protocols.\n * @property {Map<string, Uint8Array>|undefined} metadata peer's metadata map.\n */\n\n /**\n * Responsible for managing known peers, as well as their addresses, protocols and metadata.\n *\n * @param {object} options\n * @param {PeerId} options.peerId\n * @class\n */\n constructor ({ peerId }) {\n super()\n\n this._peerId = peerId\n\n /**\n * AddressBook containing a map of peerIdStr to Address.\n */\n this.addressBook = new AddressBook(this)\n\n /**\n * KeyBook containing a map of peerIdStr to their PeerId with public keys.\n */\n this.keyBook = new KeyBook(this)\n\n /**\n * MetadataBook containing a map of peerIdStr to their metadata Map.\n */\n this.metadataBook = new MetadataBook(this)\n\n /**\n * ProtoBook containing a map of peerIdStr to supported protocols.\n */\n this.protoBook = new ProtoBook(this)\n }\n\n /**\n * Start the PeerStore.\n */\n start () {}\n\n /**\n * Stop the PeerStore.\n */\n stop () {}\n\n /**\n * Get all the stored information of every peer known.\n *\n * @returns {Map<string, Peer>}\n */\n get peers () {\n const storedPeers = new Set([\n ...this.addressBook.data.keys(),\n ...this.keyBook.data.keys(),\n ...this.protoBook.data.keys(),\n ...this.metadataBook.data.keys()\n ])\n\n // Remove self peer if present\n this._peerId && storedPeers.delete(this._peerId.toB58String())\n\n const peersData = new Map()\n storedPeers.forEach((idStr) => {\n peersData.set(idStr, this.get(PeerId.createFromB58String(idStr)))\n })\n\n return peersData\n }\n\n /**\n * Delete the information of the given peer in every book.\n *\n * @param {PeerId} peerId\n * @returns {boolean} true if found and removed\n */\n delete (peerId) {\n const addressesDeleted = this.addressBook.delete(peerId)\n const keyDeleted = this.keyBook.delete(peerId)\n const protocolsDeleted = this.protoBook.delete(peerId)\n const metadataDeleted = this.metadataBook.delete(peerId)\n\n return addressesDeleted || keyDeleted || protocolsDeleted || metadataDeleted\n }\n\n /**\n * Get the stored information of a given peer.\n *\n * @param {PeerId} peerId\n * @returns {Peer|undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const id = this.keyBook.data.get(peerId.toB58String())\n const addresses = this.addressBook.get(peerId)\n const metadata = this.metadataBook.get(peerId)\n const protocols = this.protoBook.get(peerId)\n\n if (!id && !addresses && !metadata && !protocols) {\n return undefined\n }\n\n return {\n id: id || peerId,\n addresses: addresses || [],\n protocols: protocols || [],\n metadata: metadata\n }\n }\n}\n\nmodule.exports = PeerStore\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-store:address-book'), {\n error: debug('libp2p:peer-store:address-book:err')\n})\nconst errcode = require('err-code')\n\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\n\nconst Book = require('./book')\nconst PeerRecord = require('../record/peer-record')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\nconst Envelope = require('../record/envelope')\n\n/**\n * @typedef {import('./')} PeerStore\n */\n\n/**\n * @typedef {Object} Address\n * @property {Multiaddr} multiaddr peer multiaddr.\n * @property {boolean} isCertified obtained from a signed peer record.\n *\n * @typedef {Object} CertifiedRecord\n * @property {Uint8Array} raw raw envelope.\n * @property {number} seqNumber seq counter.\n *\n * @typedef {Object} Entry\n * @property {Address[]} addresses peer Addresses.\n * @property {CertifiedRecord} record certified peer record.\n */\n\n/**\n * @extends {Book}\n */\nclass AddressBook extends Book {\n /**\n * The AddressBook is responsible for keeping the known multiaddrs of a peer.\n *\n * @class\n * @param {PeerStore} peerStore\n */\n constructor (peerStore) {\n /**\n * PeerStore Event emitter, used by the AddressBook to emit:\n * \"peer\" - emitted when a peer is discovered by the node.\n * \"change:multiaddrs\" - emitted when the known multiaddrs of a peer change.\n */\n super({\n peerStore,\n eventName: 'change:multiaddrs',\n eventProperty: 'multiaddrs',\n eventTransformer: (data) => {\n if (!data.addresses) {\n return []\n }\n return data.addresses.map((/** @type {Address} */ address) => address.multiaddr)\n }\n })\n\n /**\n * Map known peers to their known Address Entries.\n *\n * @type {Map<string, Entry>}\n */\n this.data = new Map()\n }\n\n /**\n * ConsumePeerRecord adds addresses from a signed peer record contained in a record envelope.\n * This will return a boolean that indicates if the record was successfully processed and added\n * into the AddressBook.\n *\n * @param {Envelope} envelope\n * @returns {boolean}\n */\n consumePeerRecord (envelope) {\n let peerRecord\n try {\n peerRecord = PeerRecord.createFromProtobuf(envelope.payload)\n } catch (err) {\n log.error('invalid peer record received')\n return false\n }\n\n // Verify peerId\n if (!peerRecord.peerId.equals(envelope.peerId)) {\n log('signing key does not match PeerId in the PeerRecord')\n return false\n }\n\n // ensure the record has multiaddrs\n if (!peerRecord.multiaddrs || !peerRecord.multiaddrs.length) {\n return false\n }\n\n const peerId = peerRecord.peerId\n const id = peerId.toB58String()\n const entry = this.data.get(id) || { record: undefined }\n const storedRecord = entry.record\n\n // ensure seq is greater than, or equal to, the last received\n if (storedRecord && storedRecord.seqNumber >= peerRecord.seqNumber) {\n return false\n }\n\n const addresses = this._toAddresses(peerRecord.multiaddrs, true)\n\n // Replace unsigned addresses by the new ones from the record\n // TODO: Once we have ttls for the addresses, we should merge these in.\n this._setData(peerId, {\n addresses,\n record: {\n raw: envelope.marshal(),\n seqNumber: peerRecord.seqNumber\n }\n })\n log(`stored provided peer record for ${id}`)\n\n return true\n }\n\n /**\n * Get the raw Envelope for a peer. Returns\n * undefined if no Envelope is found.\n *\n * @param {PeerId} peerId\n * @returns {Uint8Array|undefined}\n */\n getRawEnvelope (peerId) {\n const entry = this.data.get(peerId.toB58String())\n\n if (!entry || !entry.record || !entry.record.raw) {\n return undefined\n }\n\n return entry.record.raw\n }\n\n /**\n * Get an Envelope containing a PeerRecord for the given peer.\n * Returns undefined if no record exists.\n *\n * @param {PeerId} peerId\n * @returns {Promise<Envelope|void>|undefined}\n */\n getPeerRecord (peerId) {\n const raw = this.getRawEnvelope(peerId)\n\n if (!raw) {\n return undefined\n }\n\n return Envelope.createFromProtobuf(raw)\n }\n\n /**\n * Set known multiaddrs of a provided peer.\n * This will replace previously stored multiaddrs, if available.\n * Replacing stored multiaddrs might result in losing obtained certified addresses.\n * If you are not sure, it's recommended to use `add` instead.\n *\n * @override\n * @param {PeerId} peerId\n * @param {Multiaddr[]} multiaddrs\n * @returns {AddressBook}\n */\n set (peerId, multiaddrs) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const addresses = this._toAddresses(multiaddrs)\n\n // Not replace multiaddrs\n if (!addresses.length) {\n return this\n }\n\n const id = peerId.toB58String()\n const entry = this.data.get(id)\n\n // Already knows the peer\n if (entry && entry.addresses && entry.addresses.length === addresses.length) {\n const intersection = entry.addresses.filter((addr) => addresses.some((newAddr) => addr.multiaddr.equals(newAddr.multiaddr)))\n\n // Are new addresses equal to the old ones?\n // If yes, no changes needed!\n if (intersection.length === entry.addresses.length) {\n log(`the addresses provided to store are equal to the already stored for ${id}`)\n return this\n }\n }\n\n this._setData(peerId, {\n addresses,\n record: entry && entry.record\n })\n log(`stored provided multiaddrs for ${id}`)\n\n // Notify the existance of a new peer\n if (!entry) {\n this._ps.emit('peer', peerId)\n }\n\n return this\n }\n\n /**\n * Add known addresses of a provided peer.\n * If the peer is not known, it is set with the given addresses.\n *\n * @param {PeerId} peerId\n * @param {Multiaddr[]} multiaddrs\n * @returns {AddressBook}\n */\n add (peerId, multiaddrs) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const addresses = this._toAddresses(multiaddrs)\n const id = peerId.toB58String()\n\n // No addresses to be added\n if (!addresses.length) {\n return this\n }\n\n const entry = this.data.get(id)\n\n if (entry && entry.addresses) {\n // Add recorded uniquely to the new array (Union)\n entry.addresses.forEach((addr) => {\n if (!addresses.find(r => r.multiaddr.equals(addr.multiaddr))) {\n addresses.push(addr)\n }\n })\n\n // If the recorded length is equal to the new after the unique union\n // The content is the same, no need to update.\n if (entry.addresses.length === addresses.length) {\n log(`the addresses provided to store are already stored for ${id}`)\n return this\n }\n }\n\n this._setData(peerId, {\n addresses,\n record: entry && entry.record\n })\n\n log(`added provided multiaddrs for ${id}`)\n\n // Notify the existance of a new peer\n if (!(entry && entry.addresses)) {\n this._ps.emit('peer', peerId)\n }\n\n return this\n }\n\n /**\n * Get the known data of a provided peer.\n *\n * @override\n * @param {PeerId} peerId\n * @returns {Address[]|undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const entry = this.data.get(peerId.toB58String())\n\n return entry && entry.addresses ? [...entry.addresses] : undefined\n }\n\n /**\n * Transforms received multiaddrs into Address.\n *\n * @private\n * @param {Multiaddr[]} multiaddrs\n * @param {boolean} [isCertified]\n * @returns {Address[]}\n */\n _toAddresses (multiaddrs, isCertified = false) {\n if (!multiaddrs) {\n log.error('multiaddrs must be provided to store data')\n throw errcode(new Error('multiaddrs must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n // create Address for each address\n /** @type {Address[]} */\n const addresses = []\n multiaddrs.forEach((addr) => {\n if (!Multiaddr.isMultiaddr(addr)) {\n log.error(`multiaddr ${addr} must be an instance of multiaddr`)\n throw errcode(new Error(`multiaddr ${addr} must be an instance of multiaddr`), ERR_INVALID_PARAMETERS)\n }\n\n // Guarantee no replicates\n if (!addresses.find((a) => a.multiaddr.equals(addr))) {\n addresses.push({\n multiaddr: addr,\n isCertified\n })\n }\n })\n\n return addresses\n }\n\n /**\n * Get the known multiaddrs for a given peer. All returned multiaddrs\n * will include the encapsulated `PeerId` of the peer.\n * Returns `undefined` if there are no known multiaddrs for the given peer.\n *\n * @param {PeerId} peerId\n * @param {(addresses: Address[]) => Address[]} [addressSorter]\n * @returns {Multiaddr[]|undefined}\n */\n getMultiaddrsForPeer (peerId, addressSorter = (ms) => ms) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const entry = this.data.get(peerId.toB58String())\n if (!entry || !entry.addresses) {\n return undefined\n }\n\n return addressSorter(\n entry.addresses || []\n ).map((address) => {\n const multiaddr = address.multiaddr\n\n const idString = multiaddr.getPeerId()\n if (idString && idString === peerId.toB58String()) return multiaddr\n\n return multiaddr.encapsulate(`/p2p/${peerId.toB58String()}`)\n })\n }\n}\n\nmodule.exports = AddressBook\n","'use strict'\n\nconst errcode = require('err-code')\nconst PeerId = require('peer-id')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @param {any} data\n */\nconst passthrough = data => data\n\n/**\n * @typedef {import('./')} PeerStore\n */\n\nclass Book {\n /**\n * The Book is the skeleton for the PeerStore books.\n *\n * @class\n * @param {Object} properties\n * @param {PeerStore} properties.peerStore - PeerStore instance.\n * @param {string} properties.eventName - Name of the event to emit by the PeerStore.\n * @param {string} properties.eventProperty - Name of the property to emit by the PeerStore.\n * @param {(data: any) => any[]} [properties.eventTransformer] - Transformer function of the provided data for being emitted.\n */\n constructor ({ peerStore, eventName, eventProperty, eventTransformer = passthrough }) {\n this._ps = peerStore\n this.eventName = eventName\n this.eventProperty = eventProperty\n this.eventTransformer = eventTransformer\n\n /**\n * Map known peers to their data.\n *\n * @type {Map<string, any[]|any>}\n */\n this.data = new Map()\n }\n\n /**\n * Set known data of a provided peer.\n *\n * @param {PeerId} peerId\n * @param {any[]|any} data\n */\n set (peerId, data) {\n throw errcode(new Error('set must be implemented by the subclass'), 'ERR_NOT_IMPLEMENTED')\n }\n\n /**\n * Set data into the datastructure, persistence and emit it using the provided transformers.\n *\n * @protected\n * @param {PeerId} peerId - peerId of the data to store\n * @param {any} data - data to store.\n * @param {Object} [options] - storing options.\n * @param {boolean} [options.emit = true] - emit the provided data.\n * @returns {void}\n */\n _setData (peerId, data, { emit = true } = {}) {\n const b58key = peerId.toB58String()\n\n // Store data in memory\n this.data.set(b58key, data)\n\n // Emit event\n emit && this._emit(peerId, data)\n }\n\n /**\n * Emit data.\n *\n * @protected\n * @param {PeerId} peerId\n * @param {any} [data]\n */\n _emit (peerId, data) {\n this._ps.emit(this.eventName, {\n peerId,\n [this.eventProperty]: this.eventTransformer(data)\n })\n }\n\n /**\n * Get the known data of a provided peer.\n * Returns `undefined` if there is no available data for the given peer.\n *\n * @param {PeerId} peerId\n * @returns {any[]|any|undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const rec = this.data.get(peerId.toB58String())\n\n // @ts-ignore\n return rec ? [...rec] : undefined\n }\n\n /**\n * Deletes the provided peer from the book.\n *\n * @param {PeerId} peerId\n * @returns {boolean}\n */\n delete (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!this.data.delete(peerId.toB58String())) {\n return false\n }\n\n this._emit(peerId, [])\n\n return true\n }\n}\n\nmodule.exports = Book\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-store:key-book'), {\n error: debug('libp2p:peer-store:key-book:err')\n})\nconst errcode = require('err-code')\n\nconst PeerId = require('peer-id')\n\nconst Book = require('./book')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @typedef {import('./')} PeerStore\n * @typedef {import('libp2p-crypto').PublicKey} PublicKey\n */\n\n/**\n * @extends {Book}\n */\nclass KeyBook extends Book {\n /**\n * The KeyBook is responsible for keeping the known public keys of a peer.\n *\n * @class\n * @param {PeerStore} peerStore\n */\n constructor (peerStore) {\n super({\n peerStore,\n eventName: 'change:pubkey',\n eventProperty: 'pubkey',\n eventTransformer: (data) => data.pubKey\n })\n\n /**\n * Map known peers to their known Public Key.\n *\n * @type {Map<string, PeerId>}\n */\n this.data = new Map()\n }\n\n /**\n * Set the Peer public key.\n *\n * @override\n * @param {PeerId} peerId\n * @param {PublicKey} publicKey\n * @returns {KeyBook}\n */\n set (peerId, publicKey) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const recPeerId = this.data.get(id)\n\n // If no record available, and this is valid\n if (!recPeerId && publicKey) {\n // This might be unecessary, but we want to store the PeerId\n // to avoid an async operation when reconstructing the PeerId\n peerId.pubKey = publicKey\n\n this._setData(peerId, peerId)\n log(`stored provided public key for ${id}`)\n }\n\n return this\n }\n\n /**\n * Get Public key of the given PeerId, if stored.\n *\n * @override\n * @param {PeerId} peerId\n * @returns {PublicKey | undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const rec = this.data.get(peerId.toB58String())\n\n return rec ? rec.pubKey : undefined\n }\n}\n\nmodule.exports = KeyBook\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-store:proto-book'), {\n error: debug('libp2p:peer-store:proto-book:err')\n})\nconst errcode = require('err-code')\nconst { equals: uint8ArrayEquals } = require('uint8arrays/equals')\n\nconst PeerId = require('peer-id')\n\nconst Book = require('./book')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @typedef {import('./')} PeerStore\n */\n\n/**\n * @extends {Book}\n *\n * @fires MetadataBook#change:metadata\n */\nclass MetadataBook extends Book {\n /**\n * The MetadataBook is responsible for keeping the known supported\n * protocols of a peer.\n *\n * @class\n * @param {PeerStore} peerStore\n */\n constructor (peerStore) {\n /**\n * PeerStore Event emitter, used by the MetadataBook to emit:\n * \"change:metadata\" - emitted when the known metadata of a peer change.\n */\n super({\n peerStore,\n eventName: 'change:metadata',\n eventProperty: 'metadata'\n })\n\n /**\n * Map known peers to their known protocols.\n *\n * @type {Map<string, Map<string, Uint8Array>>}\n */\n this.data = new Map()\n }\n\n /**\n * Set metadata key and value of a provided peer.\n *\n * @override\n * @param {PeerId} peerId\n * @param {string} key - metadata key\n * @param {Uint8Array} value - metadata value\n * @returns {MetadataBook}\n */\n // @ts-ignore override with more then the parameters expected in Book\n set (peerId, key, value) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (typeof key !== 'string' || !(value instanceof Uint8Array)) {\n log.error('valid key and value must be provided to store data')\n throw errcode(new Error('valid key and value must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n this._setValue(peerId, key, value)\n\n return this\n }\n\n /**\n * Set data into the datastructure\n *\n * @override\n * @param {PeerId} peerId\n * @param {string} key\n * @param {Uint8Array} value\n */\n _setValue (peerId, key, value, { emit = true } = {}) {\n const id = peerId.toB58String()\n const rec = this.data.get(id) || new Map()\n const recMap = rec.get(key)\n\n // Already exists and is equal\n if (recMap && uint8ArrayEquals(value, recMap)) {\n log(`the metadata provided to store is equal to the already stored for ${id} on ${key}`)\n return\n }\n\n rec.set(key, value)\n this.data.set(id, rec)\n\n emit && this._emit(peerId, key)\n }\n\n /**\n * Get the known data of a provided peer.\n *\n * @param {PeerId} peerId\n * @returns {Map<string, Uint8Array>|undefined}\n */\n get (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n return this.data.get(peerId.toB58String())\n }\n\n /**\n * Get specific metadata value, if it exists\n *\n * @param {PeerId} peerId\n * @param {string} key\n * @returns {Uint8Array | undefined}\n */\n getValue (peerId, key) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const rec = this.data.get(peerId.toB58String())\n return rec && rec.get(key)\n }\n\n /**\n * Deletes the provided peer from the book.\n *\n * @param {PeerId} peerId\n * @returns {boolean}\n */\n delete (peerId) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!this.data.delete(peerId.toB58String())) {\n return false\n }\n\n this._emit(peerId)\n\n return true\n }\n\n /**\n * Deletes the provided peer metadata key from the book.\n *\n * @param {PeerId} peerId\n * @param {string} key\n * @returns {boolean}\n */\n deleteValue (peerId, key) {\n if (!PeerId.isPeerId(peerId)) {\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n const rec = this.data.get(peerId.toB58String())\n\n if (!rec || !rec.delete(key)) {\n return false\n }\n\n this._emit(peerId, key)\n\n return true\n }\n}\n\nmodule.exports = MetadataBook\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:peer-store:proto-book'), {\n error: debug('libp2p:peer-store:proto-book:err')\n})\nconst errcode = require('err-code')\nconst PeerId = require('peer-id')\n\nconst Book = require('./book')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('../errors')\n\n/**\n * @typedef {import('./')} PeerStore\n */\n\n/**\n * @extends {Book}\n *\n * @fires ProtoBook#change:protocols\n */\nclass ProtoBook extends Book {\n /**\n * The ProtoBook is responsible for keeping the known supported\n * protocols of a peer.\n *\n * @class\n * @param {PeerStore} peerStore\n */\n constructor (peerStore) {\n /**\n * PeerStore Event emitter, used by the ProtoBook to emit:\n * \"change:protocols\" - emitted when the known protocols of a peer change.\n */\n super({\n peerStore,\n eventName: 'change:protocols',\n eventProperty: 'protocols',\n eventTransformer: (data) => Array.from(data)\n })\n\n /**\n * Map known peers to their known protocols.\n *\n * @type {Map<string, Set<string>>}\n */\n this.data = new Map()\n }\n\n /**\n * Set known protocols of a provided peer.\n * If the peer was not known before, it will be added.\n *\n * @override\n * @param {PeerId} peerId\n * @param {string[]} protocols\n * @returns {ProtoBook}\n */\n set (peerId, protocols) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!protocols) {\n log.error('protocols must be provided to store data')\n throw errcode(new Error('protocols must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const recSet = this.data.get(id)\n const newSet = new Set(protocols)\n\n /**\n * @param {Set<string>} a\n * @param {Set<string>} b\n */\n const isSetEqual = (a, b) => a.size === b.size && [...a].every(value => b.has(value))\n\n // Already knows the peer and the recorded protocols are the same?\n // If yes, no changes needed!\n if (recSet && isSetEqual(recSet, newSet)) {\n log(`the protocols provided to store are equal to the already stored for ${id}`)\n return this\n }\n\n this._setData(peerId, newSet)\n log(`stored provided protocols for ${id}`)\n\n return this\n }\n\n /**\n * Adds known protocols of a provided peer.\n * If the peer was not known before, it will be added.\n *\n * @param {PeerId} peerId\n * @param {string[]} protocols\n * @returns {ProtoBook}\n */\n add (peerId, protocols) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!protocols) {\n log.error('protocols must be provided to store data')\n throw errcode(new Error('protocols must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const recSet = this.data.get(id) || new Set()\n const newSet = new Set([...recSet, ...protocols]) // Set Union\n\n // Any new protocol added?\n if (recSet.size === newSet.size) {\n log(`the protocols provided to store are already stored for ${id}`)\n return this\n }\n\n this._setData(peerId, newSet)\n log(`added provided protocols for ${id}`)\n\n return this\n }\n\n /**\n * Removes known protocols of a provided peer.\n * If the protocols did not exist before, nothing will be done.\n *\n * @param {PeerId} peerId\n * @param {string[]} protocols\n * @returns {ProtoBook}\n */\n remove (peerId, protocols) {\n if (!PeerId.isPeerId(peerId)) {\n log.error('peerId must be an instance of peer-id to store data')\n throw errcode(new Error('peerId must be an instance of peer-id'), ERR_INVALID_PARAMETERS)\n }\n\n if (!protocols) {\n log.error('protocols must be provided to store data')\n throw errcode(new Error('protocols must be provided'), ERR_INVALID_PARAMETERS)\n }\n\n const id = peerId.toB58String()\n const recSet = this.data.get(id)\n\n if (recSet) {\n const newSet = new Set([\n ...recSet\n ].filter((p) => !protocols.includes(p)))\n\n // Any protocol removed?\n if (recSet.size === newSet.size) {\n return this\n }\n\n this._setData(peerId, newSet)\n log(`removed provided protocols for ${id}`)\n }\n\n return this\n }\n}\n\nmodule.exports = ProtoBook\n","'use strict'\n\n// Pubsub adapter to keep API with handlers while not removed.\n/**\n * @typedef {import('libp2p-interfaces/src/pubsub').InMessage} InMessage\n * @typedef {import('libp2p-interfaces/src/pubsub')} PubsubRouter\n */\n\n/**\n * @param {{new(...args: any[]): PubsubRouter}} PubsubRouter\n * @param {import('.')} libp2p\n * @param {{ enabled: boolean; } & import(\".\").PubsubLocalOptions & import(\"libp2p-interfaces/src/pubsub\").PubsubOptions} options\n */\nfunction pubsubAdapter (PubsubRouter, libp2p, options) {\n /** @type {PubsubRouter & { _subscribeAdapter: PubsubRouter['subscribe'], _unsubscribeAdapter: PubsubRouter['unsubscribe'] }} */\n // @ts-ignore we set the extra _subscribeAdapter and _unsubscribeAdapter properties afterwards\n const pubsub = new PubsubRouter(libp2p, options)\n pubsub._subscribeAdapter = pubsub.subscribe\n pubsub._unsubscribeAdapter = pubsub.unsubscribe\n\n /**\n * Subscribes to a given topic.\n *\n * @override\n * @param {string} topic\n * @param {(msg: InMessage) => void} [handler]\n * @returns {void}\n */\n function subscribe (topic, handler) {\n // Bind provided handler\n handler && pubsub.on(topic, handler)\n pubsub._subscribeAdapter(topic)\n }\n\n /**\n * Unsubscribe from the given topic.\n *\n * @override\n * @param {string} topic\n * @param {(msg: InMessage) => void} [handler]\n * @returns {void}\n */\n function unsubscribe (topic, handler) {\n if (!handler) {\n pubsub.removeAllListeners(topic)\n } else {\n pubsub.removeListener(topic, handler)\n }\n\n if (pubsub.listenerCount(topic) === 0) {\n pubsub._unsubscribeAdapter(topic)\n }\n }\n\n pubsub.subscribe = subscribe\n pubsub.unsubscribe = unsubscribe\n\n return pubsub\n}\n\nmodule.exports = pubsubAdapter\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:persistent-peer-store'), {\n error: debug('libp2p:persistent-peer-store:err')\n})\nconst { Key } = require('interface-datastore/key')\nconst { Multiaddr } = require('multiaddr')\nconst PeerId = require('peer-id')\nconst { base32 } = require('multiformats/bases/base32')\n\nconst PeerStore = require('..')\n\nconst {\n NAMESPACE_ADDRESS,\n NAMESPACE_COMMON,\n NAMESPACE_KEYS,\n NAMESPACE_METADATA,\n NAMESPACE_PROTOCOL\n} = require('./consts')\n\nconst { Addresses } = require('./pb/address-book')\nconst { Protocols } = require('./pb/proto-book')\n\n/**\n * @typedef {import('interface-datastore').Batch} Batch\n * @typedef {import('../address-book.js').Address} Address\n */\n\n/**\n * @typedef {Object} PersistentPeerStoreProperties\n * @property {PeerId} peerId\n * @property {import('interface-datastore').Datastore} datastore\n *\n * @typedef {Object} PersistentPeerStoreOptions\n * @property {number} [threshold = 5] - Number of dirty peers allowed before commit data.\n */\n\n/**\n * Responsible for managing the persistence of data in the PeerStore.\n */\nclass PersistentPeerStore extends PeerStore {\n /**\n * @class\n * @param {PersistentPeerStoreProperties & PersistentPeerStoreOptions} properties\n */\n constructor ({ peerId, datastore, threshold = 5 }) {\n super({ peerId })\n\n /**\n * Backend datastore used to persist data.\n */\n this._datastore = datastore\n\n /**\n * Peers modified after the latest data persisted.\n */\n this._dirtyPeers = new Set()\n\n /**\n * Peers metadata changed mapping peer identifers to metadata changed.\n *\n * @type {Map<string, Set<string>>}\n */\n this._dirtyMetadata = new Map()\n\n this.threshold = threshold\n this._addDirtyPeer = this._addDirtyPeer.bind(this)\n }\n\n /**\n * Start Persistent PeerStore.\n *\n * @returns {Promise<void>}\n */\n async start () {\n log('PeerStore is starting')\n\n // Handlers for dirty peers\n this.on('change:protocols', this._addDirtyPeer)\n this.on('change:multiaddrs', this._addDirtyPeer)\n this.on('change:pubkey', this._addDirtyPeerKey)\n this.on('change:metadata', this._addDirtyPeerMetadata)\n\n // Load data\n for await (const entry of this._datastore.query({ prefix: NAMESPACE_COMMON })) {\n await this._processDatastoreEntry(entry)\n }\n\n log('PeerStore started')\n }\n\n /**\n * Stop Persistent PeerStore.\n *\n * @returns {Promise<void>}\n */\n async stop () {\n log('PeerStore is stopping')\n this.removeAllListeners()\n await this._commitData()\n log('PeerStore stopped')\n }\n\n /**\n * Add modified peer to the dirty set\n *\n * @private\n * @param {Object} params\n * @param {PeerId} params.peerId\n */\n _addDirtyPeer ({ peerId }) {\n const peerIdstr = peerId.toB58String()\n\n log('add dirty peer', peerIdstr)\n this._dirtyPeers.add(peerIdstr)\n\n if (this._dirtyPeers.size >= this.threshold) {\n // Commit current data\n this._commitData().catch(err => {\n log.error('error committing data', err)\n })\n }\n }\n\n /**\n * Add modified peer key to the dirty set\n *\n * @private\n * @param {Object} params\n * @param {PeerId} params.peerId\n */\n _addDirtyPeerKey ({ peerId }) {\n // Not add if inline key available\n if (peerId.hasInlinePublicKey()) {\n return\n }\n\n const peerIdstr = peerId.toB58String()\n\n log('add dirty peer key', peerIdstr)\n this._dirtyPeers.add(peerIdstr)\n\n if (this._dirtyPeers.size >= this.threshold) {\n // Commit current data\n this._commitData().catch(err => {\n log.error('error committing data', err)\n })\n }\n }\n\n /**\n * Add modified metadata peer to the set.\n *\n * @private\n * @param {Object} params\n * @param {PeerId} params.peerId\n * @param {string} params.metadata\n */\n _addDirtyPeerMetadata ({ peerId, metadata }) {\n const peerIdstr = peerId.toB58String()\n\n log('add dirty metadata peer', peerIdstr)\n this._dirtyPeers.add(peerIdstr)\n\n // Add dirty metadata key\n const mData = this._dirtyMetadata.get(peerIdstr) || new Set()\n mData.add(metadata)\n this._dirtyMetadata.set(peerIdstr, mData)\n\n if (this._dirtyPeers.size >= this.threshold) {\n // Commit current data\n this._commitData().catch(err => {\n log.error('error committing data', err)\n })\n }\n }\n\n /**\n * Add all the peers current data to a datastore batch and commit it.\n *\n * @private\n * @returns {Promise<void>}\n */\n async _commitData () {\n const commitPeers = Array.from(this._dirtyPeers)\n\n if (!commitPeers.length) {\n return\n }\n\n // Clear Dirty Peers set\n this._dirtyPeers.clear()\n\n log('create batch commit')\n const batch = this._datastore.batch()\n for (const peerIdStr of commitPeers) {\n // PeerId\n const peerId = this.keyBook.data.get(peerIdStr) || PeerId.createFromB58String(peerIdStr)\n\n // Address Book\n this._batchAddressBook(peerId, batch)\n\n // Key Book\n !peerId.hasInlinePublicKey() && this._batchKeyBook(peerId, batch)\n\n // Metadata Book\n this._batchMetadataBook(peerId, batch)\n\n // Proto Book\n this._batchProtoBook(peerId, batch)\n }\n\n await batch.commit()\n log('batch committed')\n }\n\n /**\n * Add address book data of the peer to the batch.\n *\n * @private\n * @param {PeerId} peerId\n * @param {Batch} batch\n */\n _batchAddressBook (peerId, batch) {\n const b32key = peerId.toString()\n const key = new Key(`${NAMESPACE_ADDRESS}${b32key}`)\n\n const entry = this.addressBook.data.get(peerId.toB58String())\n\n try {\n // Deleted from the book\n if (!entry) {\n batch.delete(key)\n return\n }\n\n const encodedData = Addresses.encode({\n addrs: entry.addresses.map((address) => ({\n multiaddr: address.multiaddr.bytes,\n isCertified: address.isCertified\n })),\n certifiedRecord: entry.record\n ? {\n seq: entry.record.seqNumber,\n raw: entry.record.raw\n }\n : undefined\n }).finish()\n\n batch.put(key, encodedData)\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Add Key book data of the peer to the batch.\n *\n * @private\n * @param {PeerId} peerId\n * @param {Batch} batch\n */\n _batchKeyBook (peerId, batch) {\n const b32key = peerId.toString()\n const key = new Key(`${NAMESPACE_KEYS}${b32key}`)\n\n try {\n // Deleted from the book\n if (!peerId.pubKey) {\n batch.delete(key)\n return\n }\n\n const encodedData = peerId.marshalPubKey()\n\n batch.put(key, encodedData)\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Add metadata book data of the peer to the batch.\n *\n * @private\n * @param {PeerId} peerId\n * @param {Batch} batch\n */\n _batchMetadataBook (peerId, batch) {\n const b32key = peerId.toString()\n const dirtyMetada = this._dirtyMetadata.get(peerId.toB58String()) || []\n\n try {\n dirtyMetada.forEach((/** @type {string} */ dirtyKey) => {\n const key = new Key(`${NAMESPACE_METADATA}${b32key}/${dirtyKey}`)\n const dirtyValue = this.metadataBook.getValue(peerId, dirtyKey)\n\n if (dirtyValue) {\n batch.put(key, dirtyValue)\n } else {\n batch.delete(key)\n }\n })\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Add proto book data of the peer to the batch.\n *\n * @private\n * @param {PeerId} peerId\n * @param {Batch} batch\n */\n _batchProtoBook (peerId, batch) {\n const b32key = peerId.toString()\n const key = new Key(`${NAMESPACE_PROTOCOL}${b32key}`)\n\n const protocols = this.protoBook.get(peerId)\n\n try {\n // Deleted from the book\n if (!protocols) {\n batch.delete(key)\n return\n }\n\n const encodedData = Protocols.encode({ protocols }).finish()\n\n batch.put(key, encodedData)\n } catch (err) {\n log.error(err)\n }\n }\n\n /**\n * Process datastore entry and add its data to the correct book.\n *\n * @private\n * @param {Object} params\n * @param {Key} params.key - datastore key\n * @param {Uint8Array} params.value - datastore value stored\n * @returns {Promise<void>}\n */\n async _processDatastoreEntry ({ key, value }) {\n try {\n const keyParts = key.toString().split('/')\n const peerId = PeerId.createFromBytes(base32.decode(keyParts[3]))\n\n let decoded\n switch (keyParts[2]) {\n case 'addrs':\n decoded = Addresses.decode(value)\n\n // @ts-ignore protected function\n this.addressBook._setData(\n peerId,\n {\n addresses: decoded.addrs.map((address) => ({\n multiaddr: new Multiaddr(address.multiaddr),\n isCertified: Boolean(address.isCertified)\n })),\n record: decoded.certifiedRecord\n ? {\n raw: decoded.certifiedRecord.raw,\n seqNumber: decoded.certifiedRecord.seq\n }\n : undefined\n },\n { emit: false })\n break\n case 'keys':\n decoded = await PeerId.createFromPubKey(value)\n\n // @ts-ignore protected function\n this.keyBook._setData(\n decoded,\n decoded,\n { emit: false })\n break\n case 'metadata':\n this.metadataBook._setValue(\n peerId,\n keyParts[4],\n value,\n { emit: false })\n break\n case 'protos':\n decoded = Protocols.decode(value)\n\n // @ts-ignore protected function\n this.protoBook._setData(\n peerId,\n new Set(decoded.protocols),\n { emit: false })\n break\n default:\n log('invalid data persisted for: ', key.toString())\n }\n } catch (err) {\n log.error(err)\n }\n }\n}\n\nmodule.exports = PersistentPeerStore\n","'use strict'\n\nmodule.exports.NAMESPACE_COMMON = '/peers/'\n\n// /peers/protos/<b32 peer id no padding>\nmodule.exports.NAMESPACE_ADDRESS = '/peers/addrs/'\n\n// /peers/keys/<b32 peer id no padding>\nmodule.exports.NAMESPACE_KEYS = '/peers/keys/'\n\n// /peers/metadata/<b32 peer id no padding>/<key>\nmodule.exports.NAMESPACE_METADATA = '/peers/metadata/'\n\n// /peers/addrs/<b32 peer id no padding>\nmodule.exports.NAMESPACE_PROTOCOL = '/peers/protos/'\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-address-book\"] || ($protobuf.roots[\"libp2p-address-book\"] = {});\n\n$root.Addresses = (function() {\n\n /**\n * Properties of an Addresses.\n * @exports IAddresses\n * @interface IAddresses\n * @property {Array.<Addresses.IAddress>|null} [addrs] Addresses addrs\n * @property {Addresses.ICertifiedRecord|null} [certifiedRecord] Addresses certifiedRecord\n */\n\n /**\n * Constructs a new Addresses.\n * @exports Addresses\n * @classdesc Represents an Addresses.\n * @implements IAddresses\n * @constructor\n * @param {IAddresses=} [p] Properties to set\n */\n function Addresses(p) {\n this.addrs = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Addresses addrs.\n * @member {Array.<Addresses.IAddress>} addrs\n * @memberof Addresses\n * @instance\n */\n Addresses.prototype.addrs = $util.emptyArray;\n\n /**\n * Addresses certifiedRecord.\n * @member {Addresses.ICertifiedRecord|null|undefined} certifiedRecord\n * @memberof Addresses\n * @instance\n */\n Addresses.prototype.certifiedRecord = null;\n\n /**\n * Encodes the specified Addresses message. Does not implicitly {@link Addresses.verify|verify} messages.\n * @function encode\n * @memberof Addresses\n * @static\n * @param {IAddresses} m Addresses message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Addresses.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.addrs != null && m.addrs.length) {\n for (var i = 0; i < m.addrs.length; ++i)\n $root.Addresses.Address.encode(m.addrs[i], w.uint32(10).fork()).ldelim();\n }\n if (m.certifiedRecord != null && Object.hasOwnProperty.call(m, \"certifiedRecord\"))\n $root.Addresses.CertifiedRecord.encode(m.certifiedRecord, w.uint32(18).fork()).ldelim();\n return w;\n };\n\n /**\n * Decodes an Addresses message from the specified reader or buffer.\n * @function decode\n * @memberof Addresses\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Addresses} Addresses\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Addresses.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Addresses();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.addrs && m.addrs.length))\n m.addrs = [];\n m.addrs.push($root.Addresses.Address.decode(r, r.uint32()));\n break;\n case 2:\n m.certifiedRecord = $root.Addresses.CertifiedRecord.decode(r, r.uint32());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an Addresses message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Addresses\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Addresses} Addresses\n */\n Addresses.fromObject = function fromObject(d) {\n if (d instanceof $root.Addresses)\n return d;\n var m = new $root.Addresses();\n if (d.addrs) {\n if (!Array.isArray(d.addrs))\n throw TypeError(\".Addresses.addrs: array expected\");\n m.addrs = [];\n for (var i = 0; i < d.addrs.length; ++i) {\n if (typeof d.addrs[i] !== \"object\")\n throw TypeError(\".Addresses.addrs: object expected\");\n m.addrs[i] = $root.Addresses.Address.fromObject(d.addrs[i]);\n }\n }\n if (d.certifiedRecord != null) {\n if (typeof d.certifiedRecord !== \"object\")\n throw TypeError(\".Addresses.certifiedRecord: object expected\");\n m.certifiedRecord = $root.Addresses.CertifiedRecord.fromObject(d.certifiedRecord);\n }\n return m;\n };\n\n /**\n * Creates a plain object from an Addresses message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Addresses\n * @static\n * @param {Addresses} m Addresses\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Addresses.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.addrs = [];\n }\n if (o.defaults) {\n d.certifiedRecord = null;\n }\n if (m.addrs && m.addrs.length) {\n d.addrs = [];\n for (var j = 0; j < m.addrs.length; ++j) {\n d.addrs[j] = $root.Addresses.Address.toObject(m.addrs[j], o);\n }\n }\n if (m.certifiedRecord != null && m.hasOwnProperty(\"certifiedRecord\")) {\n d.certifiedRecord = $root.Addresses.CertifiedRecord.toObject(m.certifiedRecord, o);\n }\n return d;\n };\n\n /**\n * Converts this Addresses to JSON.\n * @function toJSON\n * @memberof Addresses\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Addresses.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n Addresses.Address = (function() {\n\n /**\n * Properties of an Address.\n * @memberof Addresses\n * @interface IAddress\n * @property {Uint8Array|null} [multiaddr] Address multiaddr\n * @property {boolean|null} [isCertified] Address isCertified\n */\n\n /**\n * Constructs a new Address.\n * @memberof Addresses\n * @classdesc Represents an Address.\n * @implements IAddress\n * @constructor\n * @param {Addresses.IAddress=} [p] Properties to set\n */\n function Address(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Address multiaddr.\n * @member {Uint8Array} multiaddr\n * @memberof Addresses.Address\n * @instance\n */\n Address.prototype.multiaddr = $util.newBuffer([]);\n\n /**\n * Address isCertified.\n * @member {boolean} isCertified\n * @memberof Addresses.Address\n * @instance\n */\n Address.prototype.isCertified = false;\n\n /**\n * Encodes the specified Address message. Does not implicitly {@link Addresses.Address.verify|verify} messages.\n * @function encode\n * @memberof Addresses.Address\n * @static\n * @param {Addresses.IAddress} m Address message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Address.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.multiaddr != null && Object.hasOwnProperty.call(m, \"multiaddr\"))\n w.uint32(10).bytes(m.multiaddr);\n if (m.isCertified != null && Object.hasOwnProperty.call(m, \"isCertified\"))\n w.uint32(16).bool(m.isCertified);\n return w;\n };\n\n /**\n * Decodes an Address message from the specified reader or buffer.\n * @function decode\n * @memberof Addresses.Address\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Addresses.Address} Address\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Address.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Addresses.Address();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.multiaddr = r.bytes();\n break;\n case 2:\n m.isCertified = r.bool();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an Address message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Addresses.Address\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Addresses.Address} Address\n */\n Address.fromObject = function fromObject(d) {\n if (d instanceof $root.Addresses.Address)\n return d;\n var m = new $root.Addresses.Address();\n if (d.multiaddr != null) {\n if (typeof d.multiaddr === \"string\")\n $util.base64.decode(d.multiaddr, m.multiaddr = $util.newBuffer($util.base64.length(d.multiaddr)), 0);\n else if (d.multiaddr.length)\n m.multiaddr = d.multiaddr;\n }\n if (d.isCertified != null) {\n m.isCertified = Boolean(d.isCertified);\n }\n return m;\n };\n\n /**\n * Creates a plain object from an Address message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Addresses.Address\n * @static\n * @param {Addresses.Address} m Address\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Address.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.multiaddr = \"\";\n else {\n d.multiaddr = [];\n if (o.bytes !== Array)\n d.multiaddr = $util.newBuffer(d.multiaddr);\n }\n d.isCertified = false;\n }\n if (m.multiaddr != null && m.hasOwnProperty(\"multiaddr\")) {\n d.multiaddr = o.bytes === String ? $util.base64.encode(m.multiaddr, 0, m.multiaddr.length) : o.bytes === Array ? Array.prototype.slice.call(m.multiaddr) : m.multiaddr;\n }\n if (m.isCertified != null && m.hasOwnProperty(\"isCertified\")) {\n d.isCertified = m.isCertified;\n }\n return d;\n };\n\n /**\n * Converts this Address to JSON.\n * @function toJSON\n * @memberof Addresses.Address\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Address.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Address;\n })();\n\n Addresses.CertifiedRecord = (function() {\n\n /**\n * Properties of a CertifiedRecord.\n * @memberof Addresses\n * @interface ICertifiedRecord\n * @property {number|null} [seq] CertifiedRecord seq\n * @property {Uint8Array|null} [raw] CertifiedRecord raw\n */\n\n /**\n * Constructs a new CertifiedRecord.\n * @memberof Addresses\n * @classdesc Represents a CertifiedRecord.\n * @implements ICertifiedRecord\n * @constructor\n * @param {Addresses.ICertifiedRecord=} [p] Properties to set\n */\n function CertifiedRecord(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * CertifiedRecord seq.\n * @member {number} seq\n * @memberof Addresses.CertifiedRecord\n * @instance\n */\n CertifiedRecord.prototype.seq = $util.Long ? $util.Long.fromBits(0,0,true) : 0;\n\n /**\n * CertifiedRecord raw.\n * @member {Uint8Array} raw\n * @memberof Addresses.CertifiedRecord\n * @instance\n */\n CertifiedRecord.prototype.raw = $util.newBuffer([]);\n\n /**\n * Encodes the specified CertifiedRecord message. Does not implicitly {@link Addresses.CertifiedRecord.verify|verify} messages.\n * @function encode\n * @memberof Addresses.CertifiedRecord\n * @static\n * @param {Addresses.ICertifiedRecord} m CertifiedRecord message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n CertifiedRecord.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.seq != null && Object.hasOwnProperty.call(m, \"seq\"))\n w.uint32(8).uint64(m.seq);\n if (m.raw != null && Object.hasOwnProperty.call(m, \"raw\"))\n w.uint32(18).bytes(m.raw);\n return w;\n };\n\n /**\n * Decodes a CertifiedRecord message from the specified reader or buffer.\n * @function decode\n * @memberof Addresses.CertifiedRecord\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Addresses.CertifiedRecord} CertifiedRecord\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n CertifiedRecord.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Addresses.CertifiedRecord();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.seq = r.uint64();\n break;\n case 2:\n m.raw = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a CertifiedRecord message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Addresses.CertifiedRecord\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Addresses.CertifiedRecord} CertifiedRecord\n */\n CertifiedRecord.fromObject = function fromObject(d) {\n if (d instanceof $root.Addresses.CertifiedRecord)\n return d;\n var m = new $root.Addresses.CertifiedRecord();\n if (d.seq != null) {\n if ($util.Long)\n (m.seq = $util.Long.fromValue(d.seq)).unsigned = true;\n else if (typeof d.seq === \"string\")\n m.seq = parseInt(d.seq, 10);\n else if (typeof d.seq === \"number\")\n m.seq = d.seq;\n else if (typeof d.seq === \"object\")\n m.seq = new $util.LongBits(d.seq.low >>> 0, d.seq.high >>> 0).toNumber(true);\n }\n if (d.raw != null) {\n if (typeof d.raw === \"string\")\n $util.base64.decode(d.raw, m.raw = $util.newBuffer($util.base64.length(d.raw)), 0);\n else if (d.raw.length)\n m.raw = d.raw;\n }\n return m;\n };\n\n /**\n * Creates a plain object from a CertifiedRecord message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Addresses.CertifiedRecord\n * @static\n * @param {Addresses.CertifiedRecord} m CertifiedRecord\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n CertifiedRecord.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if ($util.Long) {\n var n = new $util.Long(0, 0, true);\n d.seq = o.longs === String ? n.toString() : o.longs === Number ? n.toNumber() : n;\n } else\n d.seq = o.longs === String ? \"0\" : 0;\n if (o.bytes === String)\n d.raw = \"\";\n else {\n d.raw = [];\n if (o.bytes !== Array)\n d.raw = $util.newBuffer(d.raw);\n }\n }\n if (m.seq != null && m.hasOwnProperty(\"seq\")) {\n if (typeof m.seq === \"number\")\n d.seq = o.longs === String ? String(m.seq) : m.seq;\n else\n d.seq = o.longs === String ? $util.Long.prototype.toString.call(m.seq) : o.longs === Number ? new $util.LongBits(m.seq.low >>> 0, m.seq.high >>> 0).toNumber(true) : m.seq;\n }\n if (m.raw != null && m.hasOwnProperty(\"raw\")) {\n d.raw = o.bytes === String ? $util.base64.encode(m.raw, 0, m.raw.length) : o.bytes === Array ? Array.prototype.slice.call(m.raw) : m.raw;\n }\n return d;\n };\n\n /**\n * Converts this CertifiedRecord to JSON.\n * @function toJSON\n * @memberof Addresses.CertifiedRecord\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n CertifiedRecord.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return CertifiedRecord;\n })();\n\n return Addresses;\n})();\n\nmodule.exports = $root;\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-proto-book\"] || ($protobuf.roots[\"libp2p-proto-book\"] = {});\n\n$root.Protocols = (function() {\n\n /**\n * Properties of a Protocols.\n * @exports IProtocols\n * @interface IProtocols\n * @property {Array.<string>|null} [protocols] Protocols protocols\n */\n\n /**\n * Constructs a new Protocols.\n * @exports Protocols\n * @classdesc Represents a Protocols.\n * @implements IProtocols\n * @constructor\n * @param {IProtocols=} [p] Properties to set\n */\n function Protocols(p) {\n this.protocols = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Protocols protocols.\n * @member {Array.<string>} protocols\n * @memberof Protocols\n * @instance\n */\n Protocols.prototype.protocols = $util.emptyArray;\n\n /**\n * Encodes the specified Protocols message. Does not implicitly {@link Protocols.verify|verify} messages.\n * @function encode\n * @memberof Protocols\n * @static\n * @param {IProtocols} m Protocols message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Protocols.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.protocols != null && m.protocols.length) {\n for (var i = 0; i < m.protocols.length; ++i)\n w.uint32(10).string(m.protocols[i]);\n }\n return w;\n };\n\n /**\n * Decodes a Protocols message from the specified reader or buffer.\n * @function decode\n * @memberof Protocols\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Protocols} Protocols\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Protocols.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Protocols();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.protocols && m.protocols.length))\n m.protocols = [];\n m.protocols.push(r.string());\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates a Protocols message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Protocols\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Protocols} Protocols\n */\n Protocols.fromObject = function fromObject(d) {\n if (d instanceof $root.Protocols)\n return d;\n var m = new $root.Protocols();\n if (d.protocols) {\n if (!Array.isArray(d.protocols))\n throw TypeError(\".Protocols.protocols: array expected\");\n m.protocols = [];\n for (var i = 0; i < d.protocols.length; ++i) {\n m.protocols[i] = String(d.protocols[i]);\n }\n }\n return m;\n };\n\n /**\n * Creates a plain object from a Protocols message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Protocols\n * @static\n * @param {Protocols} m Protocols\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Protocols.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.protocols = [];\n }\n if (m.protocols && m.protocols.length) {\n d.protocols = [];\n for (var j = 0; j < m.protocols.length; ++j) {\n d.protocols[j] = m.protocols[j];\n }\n }\n return d;\n };\n\n /**\n * Converts this Protocols to JSON.\n * @function toJSON\n * @memberof Protocols\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Protocols.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Protocols;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:registrar'), {\n error: debug('libp2p:registrar:err')\n})\nconst errcode = require('err-code')\n\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('./errors')\nconst Topology = require('libp2p-interfaces/src/topology')\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('./peer-store')} PeerStore\n * @typedef {import('./connection-manager')} ConnectionManager\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('./').HandlerProps} HandlerProps\n */\n\n/**\n *\n */\n\n/**\n * Responsible for notifying registered protocols of events in the network.\n */\nclass Registrar {\n /**\n * @param {Object} props\n * @param {PeerStore} props.peerStore\n * @param {ConnectionManager} props.connectionManager\n * @class\n */\n constructor ({ peerStore, connectionManager }) {\n // Used on topology to listen for protocol changes\n this.peerStore = peerStore\n\n this.connectionManager = connectionManager\n\n /**\n * Map of topologies\n *\n * @type {Map<string, Topology>}\n */\n this.topologies = new Map()\n\n /** @type {(protocols: string[]|string, handler: (props: HandlerProps) => void) => void} */\n // @ts-ignore handle is not optional\n this._handle = undefined\n\n this._onDisconnect = this._onDisconnect.bind(this)\n this.connectionManager.on('peer:disconnect', this._onDisconnect)\n }\n\n /**\n * @returns {(protocols: string[]|string, handler: (props: HandlerProps) => void) => void}\n */\n get handle () {\n return this._handle\n }\n\n /**\n * @param {(protocols: string[]|string, handler: (props: HandlerProps) => void) => void} handle\n */\n set handle (handle) {\n this._handle = handle\n }\n\n /**\n * Get a connection with a peer.\n *\n * @param {PeerId} peerId\n * @returns {Connection | null}\n */\n getConnection (peerId) {\n return this.connectionManager.get(peerId)\n }\n\n /**\n * Register handlers for a set of multicodecs given\n *\n * @param {Topology} topology - protocol topology\n * @returns {string} registrar identifier\n */\n register (topology) {\n if (!Topology.isTopology(topology)) {\n log.error('topology must be an instance of interfaces/topology')\n throw errcode(new Error('topology must be an instance of interfaces/topology'), ERR_INVALID_PARAMETERS)\n }\n\n // Create topology\n const id = (Math.random() * 1e9).toString(36) + Date.now()\n\n this.topologies.set(id, topology)\n\n // Set registrar\n topology.registrar = this\n\n return id\n }\n\n /**\n * Unregister topology.\n *\n * @param {string} id - registrar identifier\n * @returns {boolean} unregistered successfully\n */\n unregister (id) {\n return this.topologies.delete(id)\n }\n\n /**\n * Remove a disconnected peer from the record\n *\n * @param {Connection} connection\n * @returns {void}\n */\n _onDisconnect (connection) {\n for (const [, topology] of this.topologies) {\n topology.disconnect(connection.remotePeer)\n }\n }\n}\n\nmodule.exports = Registrar\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:ping'), {\n error: debug('libp2p:ping:err')\n})\nconst errCode = require('err-code')\n\nconst crypto = require('libp2p-crypto')\nconst { pipe } = require('it-pipe')\n// @ts-ignore it-buffer has no types exported\nconst { toBuffer } = require('it-buffer')\nconst { collect, take } = require('streaming-iterables')\nconst { equals } = require('uint8arrays/equals')\n\nconst { PROTOCOL_NAME, PING_LENGTH, PROTOCOL_VERSION } = require('./constants')\n\n/**\n * @typedef {import('../')} Libp2p\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\n/**\n * Ping a given peer and wait for its response, getting the operation latency.\n *\n * @param {Libp2p} node\n * @param {PeerId|Multiaddr} peer\n * @returns {Promise<number>}\n */\nasync function ping (node, peer) {\n const protocol = `/${node._config.protocolPrefix}/${PROTOCOL_NAME}/${PROTOCOL_VERSION}`\n // @ts-ignore multiaddr might not have toB58String\n log('dialing %s to %s', protocol, peer.toB58String ? peer.toB58String() : peer)\n\n const connection = await node.dial(peer)\n const { stream } = await connection.newStream(protocol)\n\n const start = Date.now()\n const data = crypto.randomBytes(PING_LENGTH)\n\n const [result] = await pipe(\n [data],\n stream,\n (/** @type {MuxedStream} */ stream) => take(1, stream),\n toBuffer,\n collect\n )\n const end = Date.now()\n\n if (!equals(data, result)) {\n throw errCode(new Error('Received wrong ping ack'), 'ERR_WRONG_PING_ACK')\n }\n\n return end - start\n}\n\n/**\n * Subscribe ping protocol handler.\n *\n * @param {Libp2p} node\n */\nfunction mount (node) {\n node.handle(`/${node._config.protocolPrefix}/${PROTOCOL_NAME}/${PROTOCOL_VERSION}`, ({ stream }) => pipe(stream, stream))\n}\n\n/**\n * Unsubscribe ping protocol handler.\n *\n * @param {Libp2p} node\n */\nfunction unmount (node) {\n node.unhandle(`/${node._config.protocolPrefix}/${PROTOCOL_NAME}/${PROTOCOL_VERSION}`)\n}\n\nexports = module.exports = ping\nexports.mount = mount\nexports.unmount = unmount\n","'use strict'\n\nmodule.exports = {\n PROTOCOL: '/ipfs/ping/1.0.0', // deprecated\n PING_LENGTH: 32,\n PROTOCOL_VERSION: '1.0.0',\n PROTOCOL_NAME: 'ping'\n}\n","'use strict'\n\nconst debug = require('debug')\nconst log = Object.assign(debug('libp2p:identify'), {\n error: debug('libp2p:identify:err')\n})\nconst errCode = require('err-code')\nconst lp = require('it-length-prefixed')\nconst { pipe } = require('it-pipe')\nconst { collect, take, consume } = require('streaming-iterables')\nconst { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')\n\nconst PeerId = require('peer-id')\nconst { Multiaddr } = require('multiaddr')\n// @ts-ignore it-buffer does not have types\nconst { toBuffer } = require('it-buffer')\n\nconst Message = require('./message')\n\nconst Envelope = require('../record/envelope')\nconst PeerRecord = require('../record/peer-record')\n\nconst {\n MULTICODEC_IDENTIFY,\n MULTICODEC_IDENTIFY_PUSH,\n IDENTIFY_PROTOCOL_VERSION,\n MULTICODEC_IDENTIFY_PROTOCOL_NAME,\n MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME,\n MULTICODEC_IDENTIFY_PROTOCOL_VERSION,\n MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION\n} = require('./consts')\n\nconst { codes } = require('../errors')\n\n/**\n * @typedef {import('libp2p-interfaces/src/connection').Connection} Connection\n * @typedef {import('libp2p-interfaces/src/stream-muxer/types').MuxedStream} MuxedStream\n */\n\n/**\n * @typedef {Object} HostProperties\n * @property {string} agentVersion\n */\n\nclass IdentifyService {\n /**\n * @param {import('../')} libp2p\n */\n static getProtocolStr (libp2p) {\n return {\n identifyProtocolStr: `/${libp2p._config.protocolPrefix}/${MULTICODEC_IDENTIFY_PROTOCOL_NAME}/${MULTICODEC_IDENTIFY_PROTOCOL_VERSION}`,\n identifyPushProtocolStr: `/${libp2p._config.protocolPrefix}/${MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME}/${MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION}`\n }\n }\n\n /**\n * @class\n * @param {Object} options\n * @param {import('../')} options.libp2p\n */\n constructor ({ libp2p }) {\n this._libp2p = libp2p\n this.peerStore = libp2p.peerStore\n this.addressManager = libp2p.addressManager\n this.connectionManager = libp2p.connectionManager\n this.peerId = libp2p.peerId\n\n this.handleMessage = this.handleMessage.bind(this)\n\n const protocolStr = IdentifyService.getProtocolStr(libp2p)\n this.identifyProtocolStr = protocolStr.identifyProtocolStr\n this.identifyPushProtocolStr = protocolStr.identifyPushProtocolStr\n\n // Store self host metadata\n this._host = {\n protocolVersion: `${libp2p._config.protocolPrefix}/${IDENTIFY_PROTOCOL_VERSION}`,\n ...libp2p._options.host\n }\n\n this.peerStore.metadataBook.set(this.peerId, 'AgentVersion', uint8ArrayFromString(this._host.agentVersion))\n this.peerStore.metadataBook.set(this.peerId, 'ProtocolVersion', uint8ArrayFromString(this._host.protocolVersion))\n // When a new connection happens, trigger identify\n this.connectionManager.on('peer:connect', (connection) => {\n this.identify(connection).catch(log.error)\n })\n\n // When self multiaddrs change, trigger identify-push\n this.peerStore.on('change:multiaddrs', ({ peerId }) => {\n if (peerId.toString() === this.peerId.toString()) {\n this.pushToPeerStore()\n }\n })\n\n // When self protocols change, trigger identify-push\n this.peerStore.on('change:protocols', ({ peerId }) => {\n if (peerId.toString() === this.peerId.toString()) {\n this.pushToPeerStore()\n }\n })\n }\n\n /**\n * Send an Identify Push update to the list of connections\n *\n * @param {Connection[]} connections\n * @returns {Promise<void[]>}\n */\n async push (connections) {\n const signedPeerRecord = await this.peerStore.addressBook.getRawEnvelope(this.peerId)\n const listenAddrs = this._libp2p.multiaddrs.map((ma) => ma.bytes)\n const protocols = this.peerStore.protoBook.get(this.peerId) || []\n\n const pushes = connections.map(async connection => {\n try {\n const { stream } = await connection.newStream(this.identifyPushProtocolStr)\n\n await pipe(\n [Message.Identify.encode({\n listenAddrs,\n signedPeerRecord,\n protocols\n }).finish()],\n lp.encode(),\n stream,\n consume\n )\n } catch (err) {\n // Just log errors\n log.error('could not push identify update to peer', err)\n }\n })\n\n return Promise.all(pushes)\n }\n\n /**\n * Calls `push` for all peers in the `peerStore` that are connected\n *\n * @returns {void}\n */\n pushToPeerStore () {\n // Do not try to push if libp2p node is not running\n if (!this._libp2p.isStarted()) {\n return\n }\n\n const connections = []\n let connection\n for (const peer of this.peerStore.peers.values()) {\n if (peer.protocols.includes(this.identifyPushProtocolStr) && (connection = this.connectionManager.get(peer.id))) {\n connections.push(connection)\n }\n }\n\n this.push(connections)\n }\n\n /**\n * Requests the `Identify` message from peer associated with the given `connection`.\n * If the identified peer does not match the `PeerId` associated with the connection,\n * an error will be thrown.\n *\n * @async\n * @param {Connection} connection\n * @returns {Promise<void>}\n */\n async identify (connection) {\n const { stream } = await connection.newStream(this.identifyProtocolStr)\n const [data] = await pipe(\n [],\n stream,\n lp.decode(),\n take(1),\n toBuffer,\n collect\n )\n\n if (!data) {\n throw errCode(new Error('No data could be retrieved'), codes.ERR_CONNECTION_ENDED)\n }\n\n let message\n try {\n message = Message.Identify.decode(data)\n } catch (err) {\n throw errCode(err, codes.ERR_INVALID_MESSAGE)\n }\n\n const {\n publicKey,\n listenAddrs,\n protocols,\n observedAddr,\n signedPeerRecord\n } = message\n\n const id = await PeerId.createFromPubKey(publicKey)\n\n if (connection.remotePeer.toB58String() !== id.toB58String()) {\n throw errCode(new Error('identified peer does not match the expected peer'), codes.ERR_INVALID_PEER)\n }\n\n // Get the observedAddr if there is one\n const cleanObservedAddr = IdentifyService.getCleanMultiaddr(observedAddr)\n\n try {\n const envelope = await Envelope.openAndCertify(signedPeerRecord, PeerRecord.DOMAIN)\n if (this.peerStore.addressBook.consumePeerRecord(envelope)) {\n this.peerStore.protoBook.set(id, protocols)\n this.peerStore.metadataBook.set(id, 'AgentVersion', uint8ArrayFromString(message.agentVersion))\n this.peerStore.metadataBook.set(id, 'ProtocolVersion', uint8ArrayFromString(message.protocolVersion))\n return\n }\n } catch (err) {\n log('received invalid envelope, discard it and fallback to listenAddrs is available', err)\n }\n\n // LEGACY: Update peers data in PeerStore\n try {\n this.peerStore.addressBook.set(id, listenAddrs.map((addr) => new Multiaddr(addr)))\n } catch (err) {\n log.error('received invalid addrs', err)\n }\n\n this.peerStore.protoBook.set(id, protocols)\n this.peerStore.metadataBook.set(id, 'AgentVersion', uint8ArrayFromString(message.agentVersion))\n this.peerStore.metadataBook.set(id, 'ProtocolVersion', uint8ArrayFromString(message.protocolVersion))\n\n // TODO: Add and score our observed addr\n log('received observed address of %s', cleanObservedAddr)\n // this.addressManager.addObservedAddr(observedAddr)\n }\n\n /**\n * A handler to register with Libp2p to process identify messages.\n *\n * @param {Object} options\n * @param {Connection} options.connection\n * @param {MuxedStream} options.stream\n * @param {string} options.protocol\n * @returns {Promise<void>|undefined}\n */\n handleMessage ({ connection, stream, protocol }) {\n switch (protocol) {\n case this.identifyProtocolStr:\n return this._handleIdentify({ connection, stream })\n case this.identifyPushProtocolStr:\n return this._handlePush({ connection, stream })\n default:\n log.error('cannot handle unknown protocol %s', protocol)\n }\n }\n\n /**\n * Sends the `Identify` response with the Signed Peer Record\n * to the requesting peer over the given `connection`\n *\n * @private\n * @param {Object} options\n * @param {MuxedStream} options.stream\n * @param {Connection} options.connection\n * @returns {Promise<void>}\n */\n async _handleIdentify ({ connection, stream }) {\n let publicKey = new Uint8Array(0)\n if (this.peerId.pubKey) {\n publicKey = this.peerId.pubKey.bytes\n }\n\n const signedPeerRecord = await this.peerStore.addressBook.getRawEnvelope(this.peerId)\n const protocols = this.peerStore.protoBook.get(this.peerId) || []\n\n const message = Message.Identify.encode({\n protocolVersion: this._host.protocolVersion,\n agentVersion: this._host.agentVersion,\n publicKey,\n listenAddrs: this._libp2p.multiaddrs.map((ma) => ma.bytes),\n signedPeerRecord,\n observedAddr: connection.remoteAddr.bytes,\n protocols\n }).finish()\n\n try {\n await pipe(\n [message],\n lp.encode(),\n stream,\n consume\n )\n } catch (err) {\n log.error('could not respond to identify request', err)\n }\n }\n\n /**\n * Reads the Identify Push message from the given `connection`\n *\n * @private\n * @param {object} options\n * @param {MuxedStream} options.stream\n * @param {Connection} options.connection\n * @returns {Promise<void>}\n */\n async _handlePush ({ connection, stream }) {\n let message\n try {\n const [data] = await pipe(\n [],\n stream,\n lp.decode(),\n take(1),\n toBuffer,\n collect\n )\n message = Message.Identify.decode(data)\n } catch (err) {\n return log.error('received invalid message', err)\n }\n\n const id = connection.remotePeer\n\n try {\n const envelope = await Envelope.openAndCertify(message.signedPeerRecord, PeerRecord.DOMAIN)\n if (this.peerStore.addressBook.consumePeerRecord(envelope)) {\n this.peerStore.protoBook.set(id, message.protocols)\n return\n }\n } catch (err) {\n log('received invalid envelope, discard it and fallback to listenAddrs is available', err)\n }\n\n // LEGACY: Update peers data in PeerStore\n try {\n this.peerStore.addressBook.set(id,\n message.listenAddrs.map((addr) => new Multiaddr(addr)))\n } catch (err) {\n log.error('received invalid addrs', err)\n }\n\n // Update the protocols\n this.peerStore.protoBook.set(id, message.protocols)\n }\n\n /**\n * Takes the `addr` and converts it to a Multiaddr if possible\n *\n * @param {Uint8Array | string} addr\n * @returns {Multiaddr|null}\n */\n static getCleanMultiaddr (addr) {\n if (addr && addr.length > 0) {\n try {\n return new Multiaddr(addr)\n } catch (_) {\n return null\n }\n }\n return null\n }\n}\n\n/**\n * The protocols the IdentifyService supports\n *\n * @property multicodecs\n */\nconst multicodecs = {\n IDENTIFY: MULTICODEC_IDENTIFY,\n IDENTIFY_PUSH: MULTICODEC_IDENTIFY_PUSH\n}\n\nIdentifyService.multicodecs = multicodecs\nIdentifyService.Messsage = Message\n\nmodule.exports = IdentifyService\n","/*eslint-disable*/\n\"use strict\";\n\nvar $protobuf = require(\"protobufjs/minimal\");\n\n// Common aliases\nvar $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;\n\n// Exported root namespace\nvar $root = $protobuf.roots[\"libp2p-identify\"] || ($protobuf.roots[\"libp2p-identify\"] = {});\n\n$root.Identify = (function() {\n\n /**\n * Properties of an Identify.\n * @exports IIdentify\n * @interface IIdentify\n * @property {string|null} [protocolVersion] Identify protocolVersion\n * @property {string|null} [agentVersion] Identify agentVersion\n * @property {Uint8Array|null} [publicKey] Identify publicKey\n * @property {Array.<Uint8Array>|null} [listenAddrs] Identify listenAddrs\n * @property {Uint8Array|null} [observedAddr] Identify observedAddr\n * @property {Array.<string>|null} [protocols] Identify protocols\n * @property {Uint8Array|null} [signedPeerRecord] Identify signedPeerRecord\n */\n\n /**\n * Constructs a new Identify.\n * @exports Identify\n * @classdesc Represents an Identify.\n * @implements IIdentify\n * @constructor\n * @param {IIdentify=} [p] Properties to set\n */\n function Identify(p) {\n this.listenAddrs = [];\n this.protocols = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n\n /**\n * Identify protocolVersion.\n * @member {string} protocolVersion\n * @memberof Identify\n * @instance\n */\n Identify.prototype.protocolVersion = \"\";\n\n /**\n * Identify agentVersion.\n * @member {string} agentVersion\n * @memberof Identify\n * @instance\n */\n Identify.prototype.agentVersion = \"\";\n\n /**\n * Identify publicKey.\n * @member {Uint8Array} publicKey\n * @memberof Identify\n * @instance\n */\n Identify.prototype.publicKey = $util.newBuffer([]);\n\n /**\n * Identify listenAddrs.\n * @member {Array.<Uint8Array>} listenAddrs\n * @memberof Identify\n * @instance\n */\n Identify.prototype.listenAddrs = $util.emptyArray;\n\n /**\n * Identify observedAddr.\n * @member {Uint8Array} observedAddr\n * @memberof Identify\n * @instance\n */\n Identify.prototype.observedAddr = $util.newBuffer([]);\n\n /**\n * Identify protocols.\n * @member {Array.<string>} protocols\n * @memberof Identify\n * @instance\n */\n Identify.prototype.protocols = $util.emptyArray;\n\n /**\n * Identify signedPeerRecord.\n * @member {Uint8Array} signedPeerRecord\n * @memberof Identify\n * @instance\n */\n Identify.prototype.signedPeerRecord = $util.newBuffer([]);\n\n /**\n * Encodes the specified Identify message. Does not implicitly {@link Identify.verify|verify} messages.\n * @function encode\n * @memberof Identify\n * @static\n * @param {IIdentify} m Identify message or plain object to encode\n * @param {$protobuf.Writer} [w] Writer to encode to\n * @returns {$protobuf.Writer} Writer\n */\n Identify.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.publicKey != null && Object.hasOwnProperty.call(m, \"publicKey\"))\n w.uint32(10).bytes(m.publicKey);\n if (m.listenAddrs != null && m.listenAddrs.length) {\n for (var i = 0; i < m.listenAddrs.length; ++i)\n w.uint32(18).bytes(m.listenAddrs[i]);\n }\n if (m.protocols != null && m.protocols.length) {\n for (var i = 0; i < m.protocols.length; ++i)\n w.uint32(26).string(m.protocols[i]);\n }\n if (m.observedAddr != null && Object.hasOwnProperty.call(m, \"observedAddr\"))\n w.uint32(34).bytes(m.observedAddr);\n if (m.protocolVersion != null && Object.hasOwnProperty.call(m, \"protocolVersion\"))\n w.uint32(42).string(m.protocolVersion);\n if (m.agentVersion != null && Object.hasOwnProperty.call(m, \"agentVersion\"))\n w.uint32(50).string(m.agentVersion);\n if (m.signedPeerRecord != null && Object.hasOwnProperty.call(m, \"signedPeerRecord\"))\n w.uint32(66).bytes(m.signedPeerRecord);\n return w;\n };\n\n /**\n * Decodes an Identify message from the specified reader or buffer.\n * @function decode\n * @memberof Identify\n * @static\n * @param {$protobuf.Reader|Uint8Array} r Reader or buffer to decode from\n * @param {number} [l] Message length if known beforehand\n * @returns {Identify} Identify\n * @throws {Error} If the payload is not a reader or valid buffer\n * @throws {$protobuf.util.ProtocolError} If required fields are missing\n */\n Identify.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Identify();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 5:\n m.protocolVersion = r.string();\n break;\n case 6:\n m.agentVersion = r.string();\n break;\n case 1:\n m.publicKey = r.bytes();\n break;\n case 2:\n if (!(m.listenAddrs && m.listenAddrs.length))\n m.listenAddrs = [];\n m.listenAddrs.push(r.bytes());\n break;\n case 4:\n m.observedAddr = r.bytes();\n break;\n case 3:\n if (!(m.protocols && m.protocols.length))\n m.protocols = [];\n m.protocols.push(r.string());\n break;\n case 8:\n m.signedPeerRecord = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n\n /**\n * Creates an Identify message from a plain object. Also converts values to their respective internal types.\n * @function fromObject\n * @memberof Identify\n * @static\n * @param {Object.<string,*>} d Plain object\n * @returns {Identify} Identify\n */\n Identify.fromObject = function fromObject(d) {\n if (d instanceof $root.Identify)\n return d;\n var m = new $root.Identify();\n if (d.protocolVersion != null) {\n m.protocolVersion = String(d.protocolVersion);\n }\n if (d.agentVersion != null) {\n m.agentVersion = String(d.agentVersion);\n }\n if (d.publicKey != null) {\n if (typeof d.publicKey === \"string\")\n $util.base64.decode(d.publicKey, m.publicKey = $util.newBuffer($util.base64.length(d.publicKey)), 0);\n else if (d.publicKey.length)\n m.publicKey = d.publicKey;\n }\n if (d.listenAddrs) {\n if (!Array.isArray(d.listenAddrs))\n throw TypeError(\".Identify.listenAddrs: array expected\");\n m.listenAddrs = [];\n for (var i = 0; i < d.listenAddrs.length; ++i) {\n if (typeof d.listenAddrs[i] === \"string\")\n $util.base64.decode(d.listenAddrs[i], m.listenAddrs[i] = $util.newBuffer($util.base64.length(d.listenAddrs[i])), 0);\n else if (d.listenAddrs[i].length)\n m.listenAddrs[i] = d.listenAddrs[i];\n }\n }\n if (d.observedAddr != null) {\n if (typeof d.observedAddr === \"string\")\n $util.base64.decode(d.observedAddr, m.observedAddr = $util.newBuffer($util.base64.length(d.observedAddr)), 0);\n else if (d.observedAddr.length)\n m.observedAddr = d.observedAddr;\n }\n if (d.protocols) {\n if (!Array.isArray(d.protocols))\n throw TypeError(\".Identify.protocols: array expected\");\n m.protocols = [];\n for (var i = 0; i < d.protocols.length; ++i) {\n m.protocols[i] = String(d.protocols[i]);\n }\n }\n if (d.signedPeerRecord != null) {\n if (typeof d.signedPeerRecord === \"string\")\n $util.base64.decode(d.signedPeerRecord, m.signedPeerRecord = $util.newBuffer($util.base64.length(d.signedPeerRecord)), 0);\n else if (d.signedPeerRecord.length)\n m.signedPeerRecord = d.signedPeerRecord;\n }\n return m;\n };\n\n /**\n * Creates a plain object from an Identify message. Also converts values to other types if specified.\n * @function toObject\n * @memberof Identify\n * @static\n * @param {Identify} m Identify\n * @param {$protobuf.IConversionOptions} [o] Conversion options\n * @returns {Object.<string,*>} Plain object\n */\n Identify.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.listenAddrs = [];\n d.protocols = [];\n }\n if (o.defaults) {\n if (o.bytes === String)\n d.publicKey = \"\";\n else {\n d.publicKey = [];\n if (o.bytes !== Array)\n d.publicKey = $util.newBuffer(d.publicKey);\n }\n if (o.bytes === String)\n d.observedAddr = \"\";\n else {\n d.observedAddr = [];\n if (o.bytes !== Array)\n d.observedAddr = $util.newBuffer(d.observedAddr);\n }\n d.protocolVersion = \"\";\n d.agentVersion = \"\";\n if (o.bytes === String)\n d.signedPeerRecord = \"\";\n else {\n d.signedPeerRecord = [];\n if (o.bytes !== Array)\n d.signedPeerRecord = $util.newBuffer(d.signedPeerRecord);\n }\n }\n if (m.publicKey != null && m.hasOwnProperty(\"publicKey\")) {\n d.publicKey = o.bytes === String ? $util.base64.encode(m.publicKey, 0, m.publicKey.length) : o.bytes === Array ? Array.prototype.slice.call(m.publicKey) : m.publicKey;\n }\n if (m.listenAddrs && m.listenAddrs.length) {\n d.listenAddrs = [];\n for (var j = 0; j < m.listenAddrs.length; ++j) {\n d.listenAddrs[j] = o.bytes === String ? $util.base64.encode(m.listenAddrs[j], 0, m.listenAddrs[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.listenAddrs[j]) : m.listenAddrs[j];\n }\n }\n if (m.protocols && m.protocols.length) {\n d.protocols = [];\n for (var j = 0; j < m.protocols.length; ++j) {\n d.protocols[j] = m.protocols[j];\n }\n }\n if (m.observedAddr != null && m.hasOwnProperty(\"observedAddr\")) {\n d.observedAddr = o.bytes === String ? $util.base64.encode(m.observedAddr, 0, m.observedAddr.length) : o.bytes === Array ? Array.prototype.slice.call(m.observedAddr) : m.observedAddr;\n }\n if (m.protocolVersion != null && m.hasOwnProperty(\"protocolVersion\")) {\n d.protocolVersion = m.protocolVersion;\n }\n if (m.agentVersion != null && m.hasOwnProperty(\"agentVersion\")) {\n d.agentVersion = m.agentVersion;\n }\n if (m.signedPeerRecord != null && m.hasOwnProperty(\"signedPeerRecord\")) {\n d.signedPeerRecord = o.bytes === String ? $util.base64.encode(m.signedPeerRecord, 0, m.signedPeerRecord.length) : o.bytes === Array ? Array.prototype.slice.call(m.signedPeerRecord) : m.signedPeerRecord;\n }\n return d;\n };\n\n /**\n * Converts this Identify to JSON.\n * @function toJSON\n * @memberof Identify\n * @instance\n * @returns {Object.<string,*>} JSON object\n */\n Identify.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf.util.toJSONOptions);\n };\n\n return Identify;\n})();\n\nmodule.exports = $root;\n","'use strict'\n\n// @ts-ignore nat-api does not export types\nconst NatAPI = require('@motrix/nat-api')\nconst debug = require('debug')\nconst { promisify } = require('es6-promisify')\nconst { Multiaddr } = require('multiaddr')\nconst log = Object.assign(debug('libp2p:nat'), {\n error: debug('libp2p:nat:err')\n})\nconst { isBrowser } = require('wherearewe')\nconst retry = require('p-retry')\n// @ts-ignore private-api does not export types\nconst isPrivateIp = require('private-ip')\nconst pkg = require('../package.json')\nconst errcode = require('err-code')\nconst {\n codes: { ERR_INVALID_PARAMETERS }\n} = require('./errors')\nconst isLoopback = require('libp2p-utils/src/multiaddr/is-loopback')\n\nconst DEFAULT_TTL = 7200\n\n/**\n * @typedef {import('peer-id')} PeerId\n * @typedef {import('./transport-manager')} TransportManager\n * @typedef {import('./address-manager')} AddressManager\n */\n\n/**\n * @typedef {Object} NatManagerProperties\n * @property {PeerId} peerId - The peer ID of the current node\n * @property {TransportManager} transportManager - A transport manager\n * @property {AddressManager} addressManager - An address manager\n *\n * @typedef {Object} NatManagerOptions\n * @property {boolean} enabled - Whether to enable the NAT manager\n * @property {string} [externalIp] - Pass a value to use instead of auto-detection\n * @property {string} [description] - A string value to use for the port mapping description on the gateway\n * @property {number} [ttl = DEFAULT_TTL] - How long UPnP port mappings should last for in seconds (minimum 1200)\n * @property {boolean} [keepAlive] - Whether to automatically refresh UPnP port mappings when their TTL is reached\n * @property {string} [gateway] - Pass a value to use instead of auto-detection\n * @property {object} [pmp] - PMP options\n * @property {boolean} [pmp.enabled] - Whether to enable PMP as well as UPnP\n */\n\nfunction highPort (min = 1024, max = 65535) {\n return Math.floor(Math.random() * (max - min + 1) + min)\n}\n\nclass NatManager {\n /**\n * @class\n * @param {NatManagerProperties & NatManagerOptions} options\n */\n constructor ({ peerId, addressManager, transportManager, ...options }) {\n this._peerId = peerId\n this._addressManager = addressManager\n this._transportManager = transportManager\n\n this._enabled = options.enabled\n this._externalIp = options.externalIp\n this._options = {\n description: options.description || `${pkg.name}@${pkg.version} ${this._peerId}`,\n ttl: options.ttl || DEFAULT_TTL,\n autoUpdate: options.keepAlive || true,\n gateway: options.gateway,\n enablePMP: Boolean(options.pmp && options.pmp.enabled)\n }\n\n if (this._options.ttl < DEFAULT_TTL) {\n throw errcode(new Error(`NatManager ttl should be at least ${DEFAULT_TTL} seconds`), ERR_INVALID_PARAMETERS)\n }\n }\n\n /**\n * Starts the NAT manager\n */\n start () {\n if (isBrowser || !this._enabled) {\n return\n }\n\n // done async to not slow down startup\n this._start().catch((err) => {\n // hole punching errors are non-fatal\n log.error(err)\n })\n }\n\n async _start () {\n const addrs = this._transportManager.getAddrs()\n\n for (const addr of addrs) {\n // try to open uPnP ports for each thin waist address\n const { family, host, port, transport } = addr.toOptions()\n\n if (!addr.isThinWaistAddress() || transport !== 'tcp') {\n // only bare tcp addresses\n // eslint-disable-next-line no-continue\n continue\n }\n\n if (isLoopback(addr)) {\n // eslint-disable-next-line no-continue\n continue\n }\n\n if (family !== 4) {\n // ignore ipv6\n // eslint-disable-next-line no-continue\n continue\n }\n\n const client = this._getClient()\n const publicIp = this._externalIp || await client.externalIp()\n\n if (isPrivateIp(publicIp)) {\n throw new Error(`${publicIp} is private - please set config.nat.externalIp to an externally routable IP or ensure you are not behind a double NAT`)\n }\n\n const publicPort = highPort()\n\n log(`opening uPnP connection from ${publicIp}:${publicPort} to ${host}:${port}`)\n\n await client.map({\n publicPort,\n privatePort: port,\n protocol: transport.toUpperCase()\n })\n\n this._addressManager.addObservedAddr(Multiaddr.fromNodeAddress({\n family: 4,\n address: publicIp,\n port: publicPort\n }, transport))\n }\n }\n\n _getClient () {\n if (this._client) {\n return this._client\n }\n\n const client = new NatAPI(this._options)\n\n /** @type {(...any: any) => any} */\n const map = promisify(client.map.bind(client))\n /** @type {(...any: any) => any} */\n const destroy = promisify(client.destroy.bind(client))\n /** @type {(...any: any) => any} */\n const externalIp = promisify(client.externalIp.bind(client))\n\n // these are all network operations so add a retry\n this._client = {\n /**\n * @param {...any} args\n * @returns {Promise<void>}\n */\n map: (...args) => retry(() => map(...args), { onFailedAttempt: log.error, unref: true }),\n\n /**\n * @param {...any} args\n * @returns {Promise<void>}\n */\n destroy: (...args) => retry(() => destroy(...args), { onFailedAttempt: log.error, unref: true }),\n\n /**\n * @param {...any} args\n * @returns {Promise<string>}\n */\n externalIp: (...args) => retry(() => externalIp(...args), { onFailedAttempt: log.error, unref: true })\n }\n\n return this._client\n }\n\n /**\n * Stops the NAT manager\n *\n * @async\n */\n async stop () {\n if (isBrowser || !this._client) {\n return\n }\n\n try {\n await this._client.destroy()\n this._client = null\n } catch (err) {\n log.error(err)\n }\n }\n}\n\nmodule.exports = NatManager\n","var customArgumentsToken=\"__ES6-PROMISIFY--CUSTOM-ARGUMENTS__\";export function promisify(a){if(\"function\"!=typeof a)throw new TypeError(\"Argument to promisify must be a function\");var b=a[customArgumentsToken],c=promisify.Promise||Promise;if(\"function\"!=typeof c)throw new Error(\"No Promise implementation found; do you need a polyfill?\");return function(){for(var d=arguments.length,e=Array(d),f=0;f<d;f++)e[f]=arguments[f];return new c((c,d)=>{e.push(function(a){if(a)return d(a);for(var e=arguments.length,f=Array(1<e?e-1:0),g=1;g<e;g++)f[g-1]=arguments[g];if(1===f.length||!b)return c(f[0]);var h={};f.forEach((a,c)=>{var d=b[c];d&&(h[d]=a)}),c(h)}),a.apply(this,e)})}}promisify.argumentNames=\"__ES6-PROMISIFY--CUSTOM-ARGUMENTS__\",promisify.Promise=void 0;\n","'use strict'\n\n/** @type {() => boolean} */\n// @ts-ignore\nconst isElectron = require('is-electron')\n\nconst IS_ENV_WITH_DOM = typeof window === 'object' && typeof document === 'object' && document.nodeType === 9\n\nconst IS_ELECTRON = isElectron()\nconst IS_BROWSER = IS_ENV_WITH_DOM && !IS_ELECTRON\nconst IS_ELECTRON_MAIN = IS_ELECTRON && !IS_ENV_WITH_DOM\nconst IS_ELECTRON_RENDERER = IS_ELECTRON && IS_ENV_WITH_DOM\nconst IS_NODE = typeof require === 'function' && typeof process !== 'undefined' && typeof process.release !== 'undefined' && process.release.name === 'node' && !IS_ELECTRON\n// @ts-ignore\n// eslint-disable-next-line no-undef\nconst IS_WEBWORKER = typeof importScripts === 'function' && typeof self !== 'undefined' && typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope\nconst IS_TEST = typeof process !== 'undefined' && typeof process.env !== 'undefined' && process.env.NODE_ENV === 'test'\n\nmodule.exports = {\n isTest: IS_TEST,\n isElectron: IS_ELECTRON,\n isElectronMain: IS_ELECTRON_MAIN,\n isElectronRenderer: IS_ELECTRON_RENDERER,\n isNode: IS_NODE,\n /**\n * Detects browser main thread **NOT** web worker or service worker\n */\n isBrowser: IS_BROWSER,\n isWebWorker: IS_WEBWORKER,\n isEnvWithDom: IS_ENV_WITH_DOM\n}\n","'use strict';\nconst retry = require('retry');\n\nconst networkErrorMsgs = [\n\t'Failed to fetch', // Chrome\n\t'NetworkError when attempting to fetch resource.', // Firefox\n\t'The Internet connection appears to be offline.', // Safari\n\t'Network request failed' // `cross-fetch`\n];\n\nclass AbortError extends Error {\n\tconstructor(message) {\n\t\tsuper();\n\n\t\tif (message instanceof Error) {\n\t\t\tthis.originalError = message;\n\t\t\t({message} = message);\n\t\t} else {\n\t\t\tthis.originalError = new Error(message);\n\t\t\tthis.originalError.stack = this.stack;\n\t\t}\n\n\t\tthis.name = 'AbortError';\n\t\tthis.message = message;\n\t}\n}\n\nconst decorateErrorWithCounts = (error, attemptNumber, options) => {\n\t// Minus 1 from attemptNumber because the first attempt does not count as a retry\n\tconst retriesLeft = options.retries - (attemptNumber - 1);\n\n\terror.attemptNumber = attemptNumber;\n\terror.retriesLeft = retriesLeft;\n\treturn error;\n};\n\nconst isNetworkError = errorMessage => networkErrorMsgs.includes(errorMessage);\n\nconst pRetry = (input, options) => new Promise((resolve, reject) => {\n\toptions = {\n\t\tonFailedAttempt: () => {},\n\t\tretries: 10,\n\t\t...options\n\t};\n\n\tconst operation = retry.operation(options);\n\n\toperation.attempt(async attemptNumber => {\n\t\ttry {\n\t\t\tresolve(await input(attemptNumber));\n\t\t} catch (error) {\n\t\t\tif (!(error instanceof Error)) {\n\t\t\t\treject(new TypeError(`Non-error was thrown: \"${error}\". You should only throw errors.`));\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (error instanceof AbortError) {\n\t\t\t\toperation.stop();\n\t\t\t\treject(error.originalError);\n\t\t\t} else if (error instanceof TypeError && !isNetworkError(error.message)) {\n\t\t\t\toperation.stop();\n\t\t\t\treject(error);\n\t\t\t} else {\n\t\t\t\tdecorateErrorWithCounts(error, attemptNumber, options);\n\n\t\t\t\ttry {\n\t\t\t\t\tawait options.onFailedAttempt(error);\n\t\t\t\t} catch (error) {\n\t\t\t\t\treject(error);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (!operation.retry(error)) {\n\t\t\t\t\treject(operation.mainError());\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n});\n\nmodule.exports = pRetry;\n// TODO: remove this in the next major version\nmodule.exports.default = pRetry;\n\nmodule.exports.AbortError = AbortError;\n","module.exports = require('./lib/retry');","var RetryOperation = require('./retry_operation');\n\nexports.operation = function(options) {\n var timeouts = exports.timeouts(options);\n return new RetryOperation(timeouts, {\n forever: options && (options.forever || options.retries === Infinity),\n unref: options && options.unref,\n maxRetryTime: options && options.maxRetryTime\n });\n};\n\nexports.timeouts = function(options) {\n if (options instanceof Array) {\n return [].concat(options);\n }\n\n var opts = {\n retries: 10,\n factor: 2,\n minTimeout: 1 * 1000,\n maxTimeout: Infinity,\n randomize: false\n };\n for (var key in options) {\n opts[key] = options[key];\n }\n\n if (opts.minTimeout > opts.maxTimeout) {\n throw new Error('minTimeout is greater than maxTimeout');\n }\n\n var timeouts = [];\n for (var i = 0; i < opts.retries; i++) {\n timeouts.push(this.createTimeout(i, opts));\n }\n\n if (options && options.forever && !timeouts.length) {\n timeouts.push(this.createTimeout(i, opts));\n }\n\n // sort the array numerically ascending\n timeouts.sort(function(a,b) {\n return a - b;\n });\n\n return timeouts;\n};\n\nexports.createTimeout = function(attempt, opts) {\n var random = (opts.randomize)\n ? (Math.random() + 1)\n : 1;\n\n var timeout = Math.round(random * Math.max(opts.minTimeout, 1) * Math.pow(opts.factor, attempt));\n timeout = Math.min(timeout, opts.maxTimeout);\n\n return timeout;\n};\n\nexports.wrap = function(obj, options, methods) {\n if (options instanceof Array) {\n methods = options;\n options = null;\n }\n\n if (!methods) {\n methods = [];\n for (var key in obj) {\n if (typeof obj[key] === 'function') {\n methods.push(key);\n }\n }\n }\n\n for (var i = 0; i < methods.length; i++) {\n var method = methods[i];\n var original = obj[method];\n\n obj[method] = function retryWrapper(original) {\n var op = exports.operation(options);\n var args = Array.prototype.slice.call(arguments, 1);\n var callback = args.pop();\n\n args.push(function(err) {\n if (op.retry(err)) {\n return;\n }\n if (err) {\n arguments[0] = op.mainError();\n }\n callback.apply(this, arguments);\n });\n\n op.attempt(function() {\n original.apply(obj, args);\n });\n }.bind(obj, original);\n obj[method].options = options;\n }\n};\n","function RetryOperation(timeouts, options) {\n // Compatibility for the old (timeouts, retryForever) signature\n if (typeof options === 'boolean') {\n options = { forever: options };\n }\n\n this._originalTimeouts = JSON.parse(JSON.stringify(timeouts));\n this._timeouts = timeouts;\n this._options = options || {};\n this._maxRetryTime = options && options.maxRetryTime || Infinity;\n this._fn = null;\n this._errors = [];\n this._attempts = 1;\n this._operationTimeout = null;\n this._operationTimeoutCb = null;\n this._timeout = null;\n this._operationStart = null;\n this._timer = null;\n\n if (this._options.forever) {\n this._cachedTimeouts = this._timeouts.slice(0);\n }\n}\nmodule.exports = RetryOperation;\n\nRetryOperation.prototype.reset = function() {\n this._attempts = 1;\n this._timeouts = this._originalTimeouts.slice(0);\n}\n\nRetryOperation.prototype.stop = function() {\n if (this._timeout) {\n clearTimeout(this._timeout);\n }\n if (this._timer) {\n clearTimeout(this._timer);\n }\n\n this._timeouts = [];\n this._cachedTimeouts = null;\n};\n\nRetryOperation.prototype.retry = function(err) {\n if (this._timeout) {\n clearTimeout(this._timeout);\n }\n\n if (!err) {\n return false;\n }\n var currentTime = new Date().getTime();\n if (err && currentTime - this._operationStart >= this._maxRetryTime) {\n this._errors.push(err);\n this._errors.unshift(new Error('RetryOperation timeout occurred'));\n return false;\n }\n\n this._errors.push(err);\n\n var timeout = this._timeouts.shift();\n if (timeout === undefined) {\n if (this._cachedTimeouts) {\n // retry forever, only keep last error\n this._errors.splice(0, this._errors.length - 1);\n timeout = this._cachedTimeouts.slice(-1);\n } else {\n return false;\n }\n }\n\n var self = this;\n this._timer = setTimeout(function() {\n self._attempts++;\n\n if (self._operationTimeoutCb) {\n self._timeout = setTimeout(function() {\n self._operationTimeoutCb(self._attempts);\n }, self._operationTimeout);\n\n if (self._options.unref) {\n self._timeout.unref();\n }\n }\n\n self._fn(self._attempts);\n }, timeout);\n\n if (this._options.unref) {\n this._timer.unref();\n }\n\n return true;\n};\n\nRetryOperation.prototype.attempt = function(fn, timeoutOps) {\n this._fn = fn;\n\n if (timeoutOps) {\n if (timeoutOps.timeout) {\n this._operationTimeout = timeoutOps.timeout;\n }\n if (timeoutOps.cb) {\n this._operationTimeoutCb = timeoutOps.cb;\n }\n }\n\n var self = this;\n if (this._operationTimeoutCb) {\n this._timeout = setTimeout(function() {\n self._operationTimeoutCb();\n }, self._operationTimeout);\n }\n\n this._operationStart = new Date().getTime();\n\n this._fn(this._attempts);\n};\n\nRetryOperation.prototype.try = function(fn) {\n console.log('Using RetryOperation.try() is deprecated');\n this.attempt(fn);\n};\n\nRetryOperation.prototype.start = function(fn) {\n console.log('Using RetryOperation.start() is deprecated');\n this.attempt(fn);\n};\n\nRetryOperation.prototype.start = RetryOperation.prototype.try;\n\nRetryOperation.prototype.errors = function() {\n return this._errors;\n};\n\nRetryOperation.prototype.attempts = function() {\n return this._attempts;\n};\n\nRetryOperation.prototype.mainError = function() {\n if (this._errors.length === 0) {\n return null;\n }\n\n var counts = {};\n var mainError = null;\n var mainErrorCount = 0;\n\n for (var i = 0; i < this._errors.length; i++) {\n var error = this._errors[i];\n var message = error.message;\n var count = (counts[message] || 0) + 1;\n\n counts[message] = count;\n\n if (count >= mainErrorCount) {\n mainError = error;\n mainErrorCount = count;\n }\n }\n\n return mainError;\n};\n","'use strict'\n\n// @ts-ignore is-loopback-addr does not publish types\nconst isLoopbackAddr = require('is-loopback-addr')\n\n/**\n * @typedef {import('multiaddr').Multiaddr} Multiaddr\n */\n\n/**\n * Check if a given multiaddr is a loopback address.\n *\n * @param {Multiaddr} ma\n * @returns {boolean}\n */\nfunction isLoopback (ma) {\n const { address } = ma.nodeAddress()\n\n return isLoopbackAddr(address)\n}\n\nmodule.exports = isLoopback\n","'use strict'\n\n/**\n * Check if a given ip address is a loopback address\n *\n * @param {string} ip - ip address to check\n * @returns {boolean}\n */\nfunction isLoopbackAddr (ip) {\n return /^127\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/i.test(ip) ||\n /^::1$/.test(ip)\n}\n\nmodule.exports = isLoopbackAddr\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar ipfsBitswap = require('ipfs-bitswap');\nvar libp2p = require('./libp2p.js');\nvar multiaddr = require('multiaddr');\nvar errCode = require('err-code');\nvar blockStorage = require('../block-storage.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nclass Network {\n constructor(peerId, libp2p, bitswap, repo, blockstore) {\n this.peerId = peerId;\n this.libp2p = libp2p;\n this.bitswap = bitswap;\n this.repo = repo;\n this.blockstore = blockstore;\n }\n static async start({peerId, repo, print, options}) {\n if (repo.closed) {\n await repo.open();\n }\n const config = await repo.config.getAll();\n const libp2p$1 = await libp2p.createLibp2p({\n options,\n repo,\n peerId,\n multiaddrs: readAddrs(peerId, config),\n config,\n keychainConfig: undefined\n });\n if (libp2p$1.keychain) {\n await libp2p$1.loadKeychain();\n }\n await libp2p$1.start();\n for (const ma of libp2p$1.multiaddrs) {\n print(`Swarm listening on ${ ma }/p2p/${ peerId.toB58String() }`);\n }\n const bitswap = ipfsBitswap.createBitswap(libp2p$1, repo.blocks, { statsEnabled: true });\n await bitswap.start();\n const blockstore = new blockStorage.BlockStorage(repo.blocks, bitswap);\n repo.blocks = blockstore;\n repo.pins.blockstore = blockstore;\n return new Network(peerId, libp2p$1, bitswap, repo, blockstore);\n }\n static async stop(network) {\n network.repo.blocks = network.blockstore.unwrap();\n network.repo.pins.blockstore = network.blockstore.unwrap();\n await Promise.all([\n network.bitswap.stop(),\n network.libp2p.stop()\n ]);\n }\n}\nconst readAddrs = (peerId, config) => {\n const peerIdStr = peerId.toB58String();\n const addrs = [];\n const swarm = config.Addresses && config.Addresses.Swarm || [];\n for (const addr of swarm) {\n let ma = new multiaddr.Multiaddr(addr);\n if (ma.protoCodes().includes(WEBSOCKET_STAR_PROTO_CODE)) {\n throw errCode__default['default'](new Error('websocket-star swarm addresses are not supported. See https://github.com/ipfs/js-ipfs/issues/2779'), 'ERR_WEBSOCKET_STAR_SWARM_ADDR_NOT_SUPPORTED');\n }\n const maId = ma.getPeerId();\n if (maId && maId !== peerIdStr) {\n ma = ma.encapsulate(`/p2p/${ peerIdStr }`);\n }\n addrs.push(ma);\n }\n return addrs;\n};\nconst WEBSOCKET_STAR_PROTO_CODE = 479;\n\nexports.Network = Network;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar bitswap = require('./bitswap.js');\n\nconst createBitswap = (libp2p, blockstore, options = {}) => {\n return new bitswap.Bitswap(libp2p, blockstore, options);\n};\n\nexports.createBitswap = createBitswap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index$3 = require('./want-manager/index.js');\nvar network = require('./network.js');\nvar index$2 = require('./decision-engine/index.js');\nvar notifications = require('./notifications.js');\nvar index = require('./utils/index.js');\nvar index$1 = require('./stats/index.js');\nvar nativeAbortController = require('native-abort-controller');\nvar anySignal = require('any-signal');\nvar base = require('blockstore-core/base');\nvar cid = require('multiformats/cid');\n\nconst defaultOptions = {\n statsEnabled: false,\n statsComputeThrottleTimeout: 1000,\n statsComputeThrottleMaxQueueSize: 1000\n};\nconst statsKeys = [\n 'blocksReceived',\n 'dataReceived',\n 'dupBlksReceived',\n 'dupDataReceived',\n 'blocksSent',\n 'dataSent',\n 'providesBufferLength',\n 'wantListLength',\n 'peerCount'\n];\nclass Bitswap extends base.BaseBlockstore {\n constructor(libp2p, blockstore, options = {}) {\n super();\n this._libp2p = libp2p;\n this._log = index.logger(this.peerId);\n this._options = Object.assign({}, defaultOptions, options);\n this._stats = new index$1.Stats(statsKeys, {\n enabled: this._options.statsEnabled,\n computeThrottleTimeout: this._options.statsComputeThrottleTimeout,\n computeThrottleMaxQueueSize: this._options.statsComputeThrottleMaxQueueSize\n });\n this.network = new network.Network(libp2p, this, this._stats, { hashLoader: options.hashLoader });\n this.blockstore = blockstore;\n this.engine = new index$2.DecisionEngine(this.peerId, blockstore, this.network, this._stats);\n this.wm = new index$3.WantManager(this.peerId, this.network, this._stats);\n this.notifications = new notifications.Notifications(this.peerId);\n this.started = false;\n }\n isStarted() {\n return this.started;\n }\n get peerId() {\n return this._libp2p.peerId;\n }\n async _receiveMessage(peerId, incoming) {\n try {\n await this.engine.messageReceived(peerId, incoming);\n } catch (err) {\n this._log('failed to receive message', incoming);\n }\n if (incoming.blocks.size === 0) {\n return;\n }\n const received = [];\n for (const [cidStr, data] of incoming.blocks.entries()) {\n const cid$1 = cid.CID.parse(cidStr);\n received.push({\n wasWanted: this.wm.wantlist.contains(cid$1),\n cid: cid$1,\n data\n });\n }\n this.wm.cancelWants(received.filter(({wasWanted}) => wasWanted).map(({cid}) => cid));\n await Promise.all(received.map(({cid, wasWanted, data}) => this._handleReceivedBlock(peerId, cid, data, wasWanted)));\n }\n async _handleReceivedBlock(peerId, cid, data, wasWanted) {\n this._log('received block');\n const has = await this.blockstore.has(cid);\n this._updateReceiveCounters(peerId.toB58String(), cid, data, has);\n if (!wasWanted) {\n return;\n }\n await this.put(cid, data);\n }\n _updateReceiveCounters(peerIdStr, cid, data, exists) {\n this._stats.push(peerIdStr, 'blocksReceived', 1);\n this._stats.push(peerIdStr, 'dataReceived', data.length);\n if (exists) {\n this._stats.push(peerIdStr, 'dupBlksReceived', 1);\n this._stats.push(peerIdStr, 'dupDataReceived', data.length);\n }\n }\n _receiveError(err) {\n this._log.error('ReceiveError: %s', err.message);\n }\n _onPeerConnected(peerId) {\n this.wm.connected(peerId);\n }\n _onPeerDisconnected(peerId) {\n this.wm.disconnected(peerId);\n this.engine.peerDisconnected(peerId);\n this._stats.disconnected(peerId);\n }\n enableStats() {\n this._stats.enable();\n }\n disableStats() {\n this._stats.disable();\n }\n wantlistForPeer(peerId, _options) {\n return this.engine.wantlistForPeer(peerId);\n }\n ledgerForPeer(peerId) {\n return this.engine.ledgerForPeer(peerId);\n }\n async get(cid, options = {}) {\n const fetchFromNetwork = (cid, options) => {\n this.wm.wantBlocks([cid], options);\n return this.notifications.wantBlock(cid, options);\n };\n let promptedNetwork = false;\n const loadOrFetchFromNetwork = async (cid, options) => {\n try {\n const block = await this.blockstore.get(cid, options);\n return block;\n } catch (err) {\n if (err.code !== 'ERR_NOT_FOUND') {\n throw err;\n }\n if (!promptedNetwork) {\n promptedNetwork = true;\n this.network.findAndConnect(cid).catch(err => this._log.error(err));\n }\n return fetchFromNetwork(cid, options);\n }\n };\n const controller = new nativeAbortController.AbortController();\n const signal = options.signal ? anySignal.anySignal([\n options.signal,\n controller.signal\n ]) : controller.signal;\n const block = await Promise.race([\n this.notifications.wantBlock(cid, { signal }),\n loadOrFetchFromNetwork(cid, { signal })\n ]);\n controller.abort();\n return block;\n }\n async *getMany(cids, options = {}) {\n for await (const cid of cids) {\n yield this.get(cid, options);\n }\n }\n unwant(cids) {\n const cidsArray = Array.isArray(cids) ? cids : [cids];\n this.wm.unwantBlocks(cidsArray);\n cidsArray.forEach(cid => this.notifications.unwantBlock(cid));\n }\n cancelWants(cids) {\n this.wm.cancelWants(Array.isArray(cids) ? cids : [cids]);\n }\n async put(cid, block, _options) {\n await this.blockstore.put(cid, block);\n this._sendHaveBlockNotifications(cid, block);\n }\n async *putMany(source, options) {\n for await (const {key, value} of this.blockstore.putMany(source, options)) {\n this._sendHaveBlockNotifications(key, value);\n yield {\n key,\n value\n };\n }\n }\n _sendHaveBlockNotifications(cid, data) {\n this.notifications.hasBlock(cid, data);\n this.engine.receivedBlocks([{\n cid,\n data\n }]);\n this.network.provide(cid).catch(err => {\n this._log.error('Failed to provide: %s', err.message);\n });\n }\n getWantlist() {\n return this.wm.wantlist.entries();\n }\n peers() {\n return this.engine.peers();\n }\n stat() {\n return this._stats;\n }\n start() {\n this.wm.start();\n this.network.start();\n this.engine.start();\n this.started = true;\n }\n stop() {\n this._stats.stop();\n this.wm.stop();\n this.network.stop();\n this.engine.stop();\n this.started = false;\n }\n unwrap() {\n return this.blockstore;\n }\n}\n\nexports.Bitswap = Bitswap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index$2 = require('../message/index.js');\nvar index = require('../wantlist/index.js');\nvar constants = require('../constants.js');\nvar msgQueue = require('./msg-queue.js');\nvar index$1 = require('../utils/index.js');\nvar base58 = require('multiformats/bases/base58');\n\nclass WantManager {\n constructor(peerId, network, stats) {\n this.peers = new Map();\n this.wantlist = new index.Wantlist(stats);\n this.network = network;\n this._stats = stats;\n this._peerId = peerId;\n this._log = index$1.logger(peerId, 'want');\n }\n _addEntries(cids, cancel, force) {\n const entries = cids.map((cid, i) => {\n return new index$2.BitswapMessage.Entry(cid, constants.kMaxPriority - i, index$2.BitswapMessage.WantType.Block, cancel);\n });\n entries.forEach(e => {\n if (e.cancel) {\n if (force) {\n this.wantlist.removeForce(e.cid.toString(base58.base58btc));\n } else {\n this.wantlist.remove(e.cid);\n }\n } else {\n this._log('adding to wl');\n this.wantlist.add(e.cid, e.priority);\n }\n });\n for (const p of this.peers.values()) {\n p.addEntries(entries);\n }\n }\n _startPeerHandler(peerId) {\n let mq = this.peers.get(peerId.toB58String());\n if (mq) {\n mq.refcnt++;\n return;\n }\n mq = new msgQueue.MsgQueue(this._peerId, peerId, this.network);\n const fullwantlist = new index$2.BitswapMessage(true);\n for (const entry of this.wantlist.entries()) {\n fullwantlist.addEntry(entry[1].cid, entry[1].priority);\n }\n mq.addMessage(fullwantlist);\n this.peers.set(peerId.toB58String(), mq);\n return mq;\n }\n _stopPeerHandler(peerId) {\n const mq = this.peers.get(peerId.toB58String());\n if (!mq) {\n return;\n }\n mq.refcnt--;\n if (mq.refcnt > 0) {\n return;\n }\n this.peers.delete(peerId.toB58String());\n }\n wantBlocks(cids, options = {}) {\n this._addEntries(cids, false);\n if (options && options.signal) {\n options.signal.addEventListener('abort', () => {\n this.cancelWants(cids);\n });\n }\n }\n unwantBlocks(cids) {\n this._log('unwant blocks: %s', cids.length);\n this._addEntries(cids, true, true);\n }\n cancelWants(cids) {\n this._log('cancel wants: %s', cids.length);\n this._addEntries(cids, true);\n }\n connectedPeers() {\n return Array.from(this.peers.keys());\n }\n connected(peerId) {\n this._startPeerHandler(peerId);\n }\n disconnected(peerId) {\n this._stopPeerHandler(peerId);\n }\n start() {\n }\n stop() {\n this.peers.forEach(mq => this.disconnected(mq.peerId));\n }\n}\n\nexports.WantManager = WantManager;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar sha2 = require('multiformats/hashes/sha2');\nvar base58 = require('multiformats/bases/base58');\nvar vd = require('varint-decoder');\nvar varintEncoder = require('../utils/varint-encoder.js');\nvar index = require('../utils/index.js');\nvar message = require('./message.js');\nvar entry = require('./entry.js');\nvar errcode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar vd__default = /*#__PURE__*/_interopDefaultLegacy(vd);\nvar errcode__default = /*#__PURE__*/_interopDefaultLegacy(errcode);\n\nclass BitswapMessage {\n constructor(full) {\n this.full = full;\n this.wantlist = new Map();\n this.blocks = new Map();\n this.blockPresences = new Map();\n this.pendingBytes = 0;\n }\n get empty() {\n return this.blocks.size === 0 && this.wantlist.size === 0 && this.blockPresences.size === 0;\n }\n addEntry(cid, priority, wantType, cancel, sendDontHave) {\n if (wantType == null) {\n wantType = BitswapMessage.WantType.Block;\n }\n const cidStr = cid.toString(base58.base58btc);\n const entry$1 = this.wantlist.get(cidStr);\n if (entry$1) {\n if (entry$1.wantType === wantType) {\n entry$1.priority = priority;\n }\n if (cancel) {\n entry$1.cancel = Boolean(cancel);\n }\n if (sendDontHave) {\n entry$1.sendDontHave = Boolean(sendDontHave);\n }\n if (wantType === BitswapMessage.WantType.Block && entry$1.wantType === BitswapMessage.WantType.Have) {\n entry$1.wantType = wantType;\n }\n } else {\n this.wantlist.set(cidStr, new entry.BitswapMessageEntry(cid, priority, wantType, cancel, sendDontHave));\n }\n }\n addBlock(cid, block) {\n const cidStr = cid.toString(base58.base58btc);\n this.blocks.set(cidStr, block);\n }\n addHave(cid) {\n const cidStr = cid.toString(base58.base58btc);\n if (!this.blockPresences.has(cidStr)) {\n this.blockPresences.set(cidStr, BitswapMessage.BlockPresenceType.Have);\n }\n }\n addDontHave(cid) {\n const cidStr = cid.toString(base58.base58btc);\n if (!this.blockPresences.has(cidStr)) {\n this.blockPresences.set(cidStr, BitswapMessage.BlockPresenceType.DontHave);\n }\n }\n cancel(cid) {\n const cidStr = cid.toString(base58.base58btc);\n this.wantlist.delete(cidStr);\n this.addEntry(cid, 0, BitswapMessage.WantType.Block, true, false);\n }\n setPendingBytes(size) {\n this.pendingBytes = size;\n }\n serializeToBitswap100() {\n const msg = {\n wantlist: {\n entries: Array.from(this.wantlist.values()).map(entry => {\n return {\n block: entry.cid.bytes,\n priority: Number(entry.priority),\n cancel: Boolean(entry.cancel)\n };\n }),\n full: this.full ? true : undefined\n },\n blocks: Array.from(this.blocks.values())\n };\n return message.Message.encode(msg).finish();\n }\n serializeToBitswap110() {\n const msg = {\n wantlist: {\n entries: Array.from(this.wantlist.values()).map(entry => {\n return {\n block: entry.cid.bytes,\n priority: Number(entry.priority),\n wantType: entry.wantType,\n cancel: Boolean(entry.cancel),\n sendDontHave: Boolean(entry.sendDontHave)\n };\n }),\n full: this.full ? true : undefined\n },\n blockPresences: [],\n payload: [],\n pendingBytes: this.pendingBytes\n };\n for (const [cidStr, data] of this.blocks.entries()) {\n const cid$1 = cid.CID.parse(cidStr);\n const version = cid$1.version;\n const codec = cid$1.code;\n const multihash = cid$1.multihash.code;\n const digestLength = cid$1.multihash.digest.length;\n const prefix = varintEncoder([\n version,\n codec,\n multihash,\n digestLength\n ]);\n msg.payload.push(new message.Message.Block({\n prefix,\n data\n }));\n }\n for (const [cidStr, bpType] of this.blockPresences) {\n msg.blockPresences.push(new message.Message.BlockPresence({\n cid: cid.CID.parse(cidStr).bytes,\n type: bpType\n }));\n }\n if (this.pendingBytes > 0) {\n msg.pendingBytes = this.pendingBytes;\n }\n return message.Message.encode(msg).finish();\n }\n equals(other) {\n if (this.full !== other.full || this.pendingBytes !== other.pendingBytes || !index.isMapEqual(this.wantlist, other.wantlist) || !index.isMapEqual(this.blocks, other.blocks) || !index.isMapEqual(this.blockPresences, other.blockPresences)) {\n return false;\n }\n return true;\n }\n get [Symbol.toStringTag]() {\n const list = Array.from(this.wantlist.keys());\n const blocks = Array.from(this.blocks.keys());\n return `BitswapMessage <full: ${ this.full }, list: ${ list }, blocks: ${ blocks }>`;\n }\n}\nBitswapMessage.deserialize = async (raw, hashLoader) => {\n const decoded = message.Message.decode(raw);\n const isFull = decoded.wantlist && decoded.wantlist.full || false;\n const msg = new BitswapMessage(isFull);\n if (decoded.wantlist && decoded.wantlist.entries) {\n decoded.wantlist.entries.forEach(entry => {\n if (!entry.block) {\n return;\n }\n const cid$1 = cid.CID.decode(entry.block);\n msg.addEntry(cid$1, entry.priority || 0, entry.wantType, Boolean(entry.cancel), Boolean(entry.sendDontHave));\n });\n }\n if (decoded.blockPresences) {\n decoded.blockPresences.forEach(blockPresence => {\n if (!blockPresence.cid) {\n return;\n }\n const cid$1 = cid.CID.decode(blockPresence.cid);\n if (blockPresence.type === BitswapMessage.BlockPresenceType.Have) {\n msg.addHave(cid$1);\n } else {\n msg.addDontHave(cid$1);\n }\n });\n }\n if (decoded.blocks.length > 0) {\n await Promise.all(decoded.blocks.map(async b => {\n const hash = await sha2.sha256.digest(b);\n const cid$1 = cid.CID.createV0(hash);\n msg.addBlock(cid$1, b);\n }));\n return msg;\n }\n if (decoded.payload.length > 0) {\n await Promise.all(decoded.payload.map(async p => {\n if (!p.prefix || !p.data) {\n return;\n }\n const values = vd__default[\"default\"](p.prefix);\n const cidVersion = values[0];\n const multicodec = values[1];\n const hashAlg = values[2];\n const hasher = hashAlg === sha2.sha256.code ? sha2.sha256 : hashLoader && await hashLoader.getHasher(hashAlg);\n if (!hasher) {\n throw errcode__default[\"default\"](new Error('Unknown hash algorithm'), 'ERR_UNKNOWN_HASH_ALG');\n }\n const hash = await hasher.digest(p.data);\n const cid$1 = cid.CID.create(cidVersion, multicodec, hash);\n msg.addBlock(cid$1, p.data);\n }));\n msg.setPendingBytes(decoded.pendingBytes);\n return msg;\n }\n return msg;\n};\nBitswapMessage.blockPresenceSize = cid => {\n return cid.bytes.length + 1;\n};\nBitswapMessage.Entry = entry.BitswapMessageEntry;\nBitswapMessage.WantType = {\n Block: message.Message.Wantlist.WantType.Block,\n Have: message.Message.Wantlist.WantType.Have\n};\nBitswapMessage.BlockPresenceType = {\n Have: message.Message.BlockPresenceType.Have,\n DontHave: message.Message.BlockPresenceType.DontHave\n};\n\nexports.BitswapMessage = BitswapMessage;\n","'use strict'\n\nconst varint = require('varint')\n\nmodule.exports = (buf) => {\n if (!(buf instanceof Uint8Array)) {\n throw new Error('arg needs to be a Uint8Array')\n }\n\n const result = []\n\n while (buf.length > 0) {\n const num = varint.decode(buf)\n result.push(num)\n buf = buf.slice(varint.decode.bytes)\n }\n\n return result\n}\n","module.exports = {\n encode: require('./encode.js')\n , decode: require('./decode.js')\n , encodingLength: require('./length.js')\n}\n","module.exports = encode\n\nvar MSB = 0x80\n , REST = 0x7F\n , MSBALL = ~REST\n , INT = Math.pow(2, 31)\n\nfunction encode(num, out, offset) {\n out = out || []\n offset = offset || 0\n var oldOffset = offset\n\n while(num >= INT) {\n out[offset++] = (num & 0xFF) | MSB\n num /= 128\n }\n while(num & MSBALL) {\n out[offset++] = (num & 0xFF) | MSB\n num >>>= 7\n }\n out[offset] = num | 0\n \n encode.bytes = offset - oldOffset + 1\n \n return out\n}\n","module.exports = read\n\nvar MSB = 0x80\n , REST = 0x7F\n\nfunction read(buf, offset) {\n var res = 0\n , offset = offset || 0\n , shift = 0\n , counter = offset\n , b\n , l = buf.length\n\n do {\n if (counter >= l) {\n read.bytes = 0\n throw new RangeError('Could not decode varint')\n }\n b = buf[counter++]\n res += shift < 28\n ? (b & REST) << shift\n : (b & REST) * Math.pow(2, shift)\n shift += 7\n } while (b >= MSB)\n\n read.bytes = counter - offset\n\n return res\n}\n","\nvar N1 = Math.pow(2, 7)\nvar N2 = Math.pow(2, 14)\nvar N3 = Math.pow(2, 21)\nvar N4 = Math.pow(2, 28)\nvar N5 = Math.pow(2, 35)\nvar N6 = Math.pow(2, 42)\nvar N7 = Math.pow(2, 49)\nvar N8 = Math.pow(2, 56)\nvar N9 = Math.pow(2, 63)\n\nmodule.exports = function (value) {\n return (\n value < N1 ? 1\n : value < N2 ? 2\n : value < N3 ? 3\n : value < N4 ? 4\n : value < N5 ? 5\n : value < N6 ? 6\n : value < N7 ? 7\n : value < N8 ? 8\n : value < N9 ? 9\n : 10\n )\n}\n","'use strict';\n\nvar varint = require('varint');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n}\n\nvar varint__namespace = /*#__PURE__*/_interopNamespace(varint);\n\nfunction varintEncoder(buf) {\n let out = new Uint8Array(buf.reduce((acc, curr) => {\n return acc + varint__namespace.default.encodingLength(curr);\n }, 0));\n let offset = 0;\n for (const num of buf) {\n out = varint__namespace.encode(num, out, offset);\n offset += varint__namespace.default.encodingLength(num);\n }\n return out;\n}\n\nmodule.exports = varintEncoder;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debug = require('debug');\nvar equals = require('uint8arrays/equals');\nvar entry = require('../message/entry.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debug__default = /*#__PURE__*/_interopDefaultLegacy(debug);\n\nconst logger = (id, subsystem) => {\n const name = ['bitswap'];\n if (subsystem) {\n name.push(subsystem);\n }\n if (id) {\n name.push(`${ id.toB58String().slice(0, 8) }`);\n }\n return Object.assign(debug__default[\"default\"](name.join(':')), { error: debug__default[\"default\"](name.concat(['error']).join(':')) });\n};\nconst includesWith = (pred, x, list) => {\n let idx = 0;\n const len = list.length;\n while (idx < len) {\n if (pred(x, list[idx])) {\n return true;\n }\n idx += 1;\n }\n return false;\n};\nconst uniqWith = (pred, list) => {\n let idx = 0;\n const len = list.length;\n const result = [];\n let item;\n while (idx < len) {\n item = list[idx];\n if (!includesWith(pred, item, result)) {\n result[result.length] = item;\n }\n idx += 1;\n }\n return result;\n};\nconst groupBy = (pred, list) => {\n return list.reduce((acc, v) => {\n const k = pred(v);\n if (acc[k]) {\n acc[k].push(v);\n } else {\n acc[k] = [v];\n }\n return acc;\n }, {});\n};\nconst pullAllWith = (pred, list, values) => {\n return list.filter(i => {\n return !includesWith(pred, i, values);\n });\n};\nconst sortBy = (fn, list) => {\n return Array.prototype.slice.call(list, 0).sort((a, b) => {\n const aa = fn(a);\n const bb = fn(b);\n return aa < bb ? -1 : aa > bb ? 1 : 0;\n });\n};\nconst isMapEqual = (a, b) => {\n if (a.size !== b.size) {\n return false;\n }\n for (const [key, valueA] of a) {\n const valueB = b.get(key);\n if (valueB === undefined) {\n return false;\n }\n if (valueA instanceof Uint8Array && valueB instanceof Uint8Array && !equals.equals(valueA, valueB)) {\n return false;\n }\n if (valueA instanceof entry.BitswapMessageEntry && valueB instanceof entry.BitswapMessageEntry && !valueA.equals(valueB)) {\n return false;\n }\n }\n return true;\n};\n\nexports.groupBy = groupBy;\nexports.includesWith = includesWith;\nexports.isMapEqual = isMapEqual;\nexports.logger = logger;\nexports.pullAllWith = pullAllWith;\nexports.sortBy = sortBy;\nexports.uniqWith = uniqWith;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('../wantlist/index.js');\nvar base58 = require('multiformats/bases/base58');\n\nconst WantlistEntry = index.Wantlist.Entry;\nclass BitswapMessageEntry {\n constructor(cid, priority, wantType, cancel, sendDontHave) {\n this.entry = new WantlistEntry(cid, priority, wantType);\n this.cancel = Boolean(cancel);\n this.sendDontHave = Boolean(sendDontHave);\n }\n get cid() {\n return this.entry.cid;\n }\n set cid(cid) {\n this.entry.cid = cid;\n }\n get priority() {\n return this.entry.priority;\n }\n set priority(val) {\n this.entry.priority = val;\n }\n get wantType() {\n return this.entry.wantType;\n }\n set wantType(val) {\n this.entry.wantType = val;\n }\n get [Symbol.toStringTag]() {\n const cidStr = this.cid.toString(base58.base58btc);\n return `BitswapMessageEntry ${ cidStr } <cancel: ${ this.cancel }, priority: ${ this.priority }>`;\n }\n equals(other) {\n return this.cancel === other.cancel && this.sendDontHave === other.sendDontHave && this.wantType === other.wantType && this.entry.equals(other.entry);\n }\n}\n\nexports.BitswapMessageEntry = BitswapMessageEntry;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar entry = require('./entry.js');\nvar base58 = require('multiformats/bases/base58');\nvar message = require('../message/message.js');\n\nconst WantType = {\n Block: message.Message.Wantlist.WantType.Block,\n Have: message.Message.Wantlist.WantType.Have\n};\nconst sortBy = (fn, list) => {\n return Array.prototype.slice.call(list, 0).sort((a, b) => {\n const aa = fn(a);\n const bb = fn(b);\n return aa < bb ? -1 : aa > bb ? 1 : 0;\n });\n};\nclass Wantlist {\n constructor(stats) {\n this.set = new Map();\n this._stats = stats;\n }\n get length() {\n return this.set.size;\n }\n add(cid, priority, wantType) {\n const cidStr = cid.toString(base58.base58btc);\n const entry$1 = this.set.get(cidStr);\n if (entry$1) {\n entry$1.inc();\n entry$1.priority = priority;\n if (entry$1.wantType === WantType.Have && wantType === WantType.Block) {\n entry$1.wantType = wantType;\n }\n } else {\n this.set.set(cidStr, new entry.WantListEntry(cid, priority, wantType));\n if (this._stats) {\n this._stats.push(null, 'wantListSize', 1);\n }\n }\n }\n remove(cid) {\n const cidStr = cid.toString(base58.base58btc);\n const entry = this.set.get(cidStr);\n if (!entry) {\n return;\n }\n entry.dec();\n if (entry.hasRefs()) {\n return;\n }\n this.set.delete(cidStr);\n if (this._stats) {\n this._stats.push(null, 'wantListSize', -1);\n }\n }\n removeForce(cidStr) {\n if (this.set.has(cidStr)) {\n this.set.delete(cidStr);\n }\n }\n forEach(fn) {\n return this.set.forEach(fn);\n }\n entries() {\n return this.set.entries();\n }\n sortedEntries() {\n return new Map(sortBy(o => o[1].key, Array.from(this.set.entries())));\n }\n contains(cid) {\n const cidStr = cid.toString(base58.base58btc);\n return this.set.has(cidStr);\n }\n get(cid) {\n const cidStr = cid.toString(base58.base58btc);\n return this.set.get(cidStr);\n }\n}\nWantlist.Entry = entry.WantListEntry;\n\nexports.Wantlist = Wantlist;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base58 = require('multiformats/bases/base58');\n\nclass WantListEntry {\n constructor(cid, priority, wantType) {\n this._refCounter = 1;\n this.cid = cid;\n this.priority = priority || 1;\n this.wantType = wantType;\n }\n inc() {\n this._refCounter += 1;\n }\n dec() {\n this._refCounter = Math.max(0, this._refCounter - 1);\n }\n hasRefs() {\n return this._refCounter > 0;\n }\n get [Symbol.toStringTag]() {\n const cidStr = this.cid.toString(base58.base58btc);\n return `WantlistEntry <key: ${ cidStr }, priority: ${ this.priority }, refs: ${ this._refCounter }>`;\n }\n equals(other) {\n return this._refCounter === other._refCounter && this.cid.equals(other.cid) && this.priority === other.priority && this.wantType === other.wantType;\n }\n}\n\nexports.WantListEntry = WantListEntry;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar $protobuf = require('protobufjs/minimal.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar $protobuf__default = /*#__PURE__*/_interopDefaultLegacy($protobuf);\n\nconst $Reader = $protobuf__default[\"default\"].Reader, $Writer = $protobuf__default[\"default\"].Writer, $util = $protobuf__default[\"default\"].util;\nconst $root = $protobuf__default[\"default\"].roots['ipfs-bitswap'] || ($protobuf__default[\"default\"].roots['ipfs-bitswap'] = {});\nconst Message = $root.Message = (() => {\n function Message(p) {\n this.blocks = [];\n this.payload = [];\n this.blockPresences = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Message.prototype.wantlist = null;\n Message.prototype.blocks = $util.emptyArray;\n Message.prototype.payload = $util.emptyArray;\n Message.prototype.blockPresences = $util.emptyArray;\n Message.prototype.pendingBytes = 0;\n Message.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.wantlist != null && Object.hasOwnProperty.call(m, 'wantlist'))\n $root.Message.Wantlist.encode(m.wantlist, w.uint32(10).fork()).ldelim();\n if (m.blocks != null && m.blocks.length) {\n for (var i = 0; i < m.blocks.length; ++i)\n w.uint32(18).bytes(m.blocks[i]);\n }\n if (m.payload != null && m.payload.length) {\n for (var i = 0; i < m.payload.length; ++i)\n $root.Message.Block.encode(m.payload[i], w.uint32(26).fork()).ldelim();\n }\n if (m.blockPresences != null && m.blockPresences.length) {\n for (var i = 0; i < m.blockPresences.length; ++i)\n $root.Message.BlockPresence.encode(m.blockPresences[i], w.uint32(34).fork()).ldelim();\n }\n if (m.pendingBytes != null && Object.hasOwnProperty.call(m, 'pendingBytes'))\n w.uint32(40).int32(m.pendingBytes);\n return w;\n };\n Message.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.wantlist = $root.Message.Wantlist.decode(r, r.uint32());\n break;\n case 2:\n if (!(m.blocks && m.blocks.length))\n m.blocks = [];\n m.blocks.push(r.bytes());\n break;\n case 3:\n if (!(m.payload && m.payload.length))\n m.payload = [];\n m.payload.push($root.Message.Block.decode(r, r.uint32()));\n break;\n case 4:\n if (!(m.blockPresences && m.blockPresences.length))\n m.blockPresences = [];\n m.blockPresences.push($root.Message.BlockPresence.decode(r, r.uint32()));\n break;\n case 5:\n m.pendingBytes = r.int32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Message.fromObject = function fromObject(d) {\n if (d instanceof $root.Message)\n return d;\n var m = new $root.Message();\n if (d.wantlist != null) {\n if (typeof d.wantlist !== 'object')\n throw TypeError('.Message.wantlist: object expected');\n m.wantlist = $root.Message.Wantlist.fromObject(d.wantlist);\n }\n if (d.blocks) {\n if (!Array.isArray(d.blocks))\n throw TypeError('.Message.blocks: array expected');\n m.blocks = [];\n for (var i = 0; i < d.blocks.length; ++i) {\n if (typeof d.blocks[i] === 'string')\n $util.base64.decode(d.blocks[i], m.blocks[i] = $util.newBuffer($util.base64.length(d.blocks[i])), 0);\n else if (d.blocks[i].length)\n m.blocks[i] = d.blocks[i];\n }\n }\n if (d.payload) {\n if (!Array.isArray(d.payload))\n throw TypeError('.Message.payload: array expected');\n m.payload = [];\n for (var i = 0; i < d.payload.length; ++i) {\n if (typeof d.payload[i] !== 'object')\n throw TypeError('.Message.payload: object expected');\n m.payload[i] = $root.Message.Block.fromObject(d.payload[i]);\n }\n }\n if (d.blockPresences) {\n if (!Array.isArray(d.blockPresences))\n throw TypeError('.Message.blockPresences: array expected');\n m.blockPresences = [];\n for (var i = 0; i < d.blockPresences.length; ++i) {\n if (typeof d.blockPresences[i] !== 'object')\n throw TypeError('.Message.blockPresences: object expected');\n m.blockPresences[i] = $root.Message.BlockPresence.fromObject(d.blockPresences[i]);\n }\n }\n if (d.pendingBytes != null) {\n m.pendingBytes = d.pendingBytes | 0;\n }\n return m;\n };\n Message.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.blocks = [];\n d.payload = [];\n d.blockPresences = [];\n }\n if (o.defaults) {\n d.wantlist = null;\n d.pendingBytes = 0;\n }\n if (m.wantlist != null && m.hasOwnProperty('wantlist')) {\n d.wantlist = $root.Message.Wantlist.toObject(m.wantlist, o);\n }\n if (m.blocks && m.blocks.length) {\n d.blocks = [];\n for (var j = 0; j < m.blocks.length; ++j) {\n d.blocks[j] = o.bytes === String ? $util.base64.encode(m.blocks[j], 0, m.blocks[j].length) : o.bytes === Array ? Array.prototype.slice.call(m.blocks[j]) : m.blocks[j];\n }\n }\n if (m.payload && m.payload.length) {\n d.payload = [];\n for (var j = 0; j < m.payload.length; ++j) {\n d.payload[j] = $root.Message.Block.toObject(m.payload[j], o);\n }\n }\n if (m.blockPresences && m.blockPresences.length) {\n d.blockPresences = [];\n for (var j = 0; j < m.blockPresences.length; ++j) {\n d.blockPresences[j] = $root.Message.BlockPresence.toObject(m.blockPresences[j], o);\n }\n }\n if (m.pendingBytes != null && m.hasOwnProperty('pendingBytes')) {\n d.pendingBytes = m.pendingBytes;\n }\n return d;\n };\n Message.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n Message.Wantlist = function () {\n function Wantlist(p) {\n this.entries = [];\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Wantlist.prototype.entries = $util.emptyArray;\n Wantlist.prototype.full = false;\n Wantlist.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.entries != null && m.entries.length) {\n for (var i = 0; i < m.entries.length; ++i)\n $root.Message.Wantlist.Entry.encode(m.entries[i], w.uint32(10).fork()).ldelim();\n }\n if (m.full != null && Object.hasOwnProperty.call(m, 'full'))\n w.uint32(16).bool(m.full);\n return w;\n };\n Wantlist.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.Wantlist();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n if (!(m.entries && m.entries.length))\n m.entries = [];\n m.entries.push($root.Message.Wantlist.Entry.decode(r, r.uint32()));\n break;\n case 2:\n m.full = r.bool();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Wantlist.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.Wantlist)\n return d;\n var m = new $root.Message.Wantlist();\n if (d.entries) {\n if (!Array.isArray(d.entries))\n throw TypeError('.Message.Wantlist.entries: array expected');\n m.entries = [];\n for (var i = 0; i < d.entries.length; ++i) {\n if (typeof d.entries[i] !== 'object')\n throw TypeError('.Message.Wantlist.entries: object expected');\n m.entries[i] = $root.Message.Wantlist.Entry.fromObject(d.entries[i]);\n }\n }\n if (d.full != null) {\n m.full = Boolean(d.full);\n }\n return m;\n };\n Wantlist.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.arrays || o.defaults) {\n d.entries = [];\n }\n if (o.defaults) {\n d.full = false;\n }\n if (m.entries && m.entries.length) {\n d.entries = [];\n for (var j = 0; j < m.entries.length; ++j) {\n d.entries[j] = $root.Message.Wantlist.Entry.toObject(m.entries[j], o);\n }\n }\n if (m.full != null && m.hasOwnProperty('full')) {\n d.full = m.full;\n }\n return d;\n };\n Wantlist.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n Wantlist.WantType = function () {\n const valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = 'Block'] = 0;\n values[valuesById[1] = 'Have'] = 1;\n return values;\n }();\n Wantlist.Entry = function () {\n function Entry(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Entry.prototype.block = $util.newBuffer([]);\n Entry.prototype.priority = 0;\n Entry.prototype.cancel = false;\n Entry.prototype.wantType = 0;\n Entry.prototype.sendDontHave = false;\n Entry.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.block != null && Object.hasOwnProperty.call(m, 'block'))\n w.uint32(10).bytes(m.block);\n if (m.priority != null && Object.hasOwnProperty.call(m, 'priority'))\n w.uint32(16).int32(m.priority);\n if (m.cancel != null && Object.hasOwnProperty.call(m, 'cancel'))\n w.uint32(24).bool(m.cancel);\n if (m.wantType != null && Object.hasOwnProperty.call(m, 'wantType'))\n w.uint32(32).int32(m.wantType);\n if (m.sendDontHave != null && Object.hasOwnProperty.call(m, 'sendDontHave'))\n w.uint32(40).bool(m.sendDontHave);\n return w;\n };\n Entry.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.Wantlist.Entry();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.block = r.bytes();\n break;\n case 2:\n m.priority = r.int32();\n break;\n case 3:\n m.cancel = r.bool();\n break;\n case 4:\n m.wantType = r.int32();\n break;\n case 5:\n m.sendDontHave = r.bool();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Entry.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.Wantlist.Entry)\n return d;\n var m = new $root.Message.Wantlist.Entry();\n if (d.block != null) {\n if (typeof d.block === 'string')\n $util.base64.decode(d.block, m.block = $util.newBuffer($util.base64.length(d.block)), 0);\n else if (d.block.length)\n m.block = d.block;\n }\n if (d.priority != null) {\n m.priority = d.priority | 0;\n }\n if (d.cancel != null) {\n m.cancel = Boolean(d.cancel);\n }\n switch (d.wantType) {\n case 'Block':\n case 0:\n m.wantType = 0;\n break;\n case 'Have':\n case 1:\n m.wantType = 1;\n break;\n }\n if (d.sendDontHave != null) {\n m.sendDontHave = Boolean(d.sendDontHave);\n }\n return m;\n };\n Entry.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.block = '';\n else {\n d.block = [];\n if (o.bytes !== Array)\n d.block = $util.newBuffer(d.block);\n }\n d.priority = 0;\n d.cancel = false;\n d.wantType = o.enums === String ? 'Block' : 0;\n d.sendDontHave = false;\n }\n if (m.block != null && m.hasOwnProperty('block')) {\n d.block = o.bytes === String ? $util.base64.encode(m.block, 0, m.block.length) : o.bytes === Array ? Array.prototype.slice.call(m.block) : m.block;\n }\n if (m.priority != null && m.hasOwnProperty('priority')) {\n d.priority = m.priority;\n }\n if (m.cancel != null && m.hasOwnProperty('cancel')) {\n d.cancel = m.cancel;\n }\n if (m.wantType != null && m.hasOwnProperty('wantType')) {\n d.wantType = o.enums === String ? $root.Message.Wantlist.WantType[m.wantType] : m.wantType;\n }\n if (m.sendDontHave != null && m.hasOwnProperty('sendDontHave')) {\n d.sendDontHave = m.sendDontHave;\n }\n return d;\n };\n Entry.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n return Entry;\n }();\n return Wantlist;\n }();\n Message.Block = function () {\n function Block(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n Block.prototype.prefix = $util.newBuffer([]);\n Block.prototype.data = $util.newBuffer([]);\n Block.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.prefix != null && Object.hasOwnProperty.call(m, 'prefix'))\n w.uint32(10).bytes(m.prefix);\n if (m.data != null && Object.hasOwnProperty.call(m, 'data'))\n w.uint32(18).bytes(m.data);\n return w;\n };\n Block.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.Block();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.prefix = r.bytes();\n break;\n case 2:\n m.data = r.bytes();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n Block.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.Block)\n return d;\n var m = new $root.Message.Block();\n if (d.prefix != null) {\n if (typeof d.prefix === 'string')\n $util.base64.decode(d.prefix, m.prefix = $util.newBuffer($util.base64.length(d.prefix)), 0);\n else if (d.prefix.length)\n m.prefix = d.prefix;\n }\n if (d.data != null) {\n if (typeof d.data === 'string')\n $util.base64.decode(d.data, m.data = $util.newBuffer($util.base64.length(d.data)), 0);\n else if (d.data.length)\n m.data = d.data;\n }\n return m;\n };\n Block.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.prefix = '';\n else {\n d.prefix = [];\n if (o.bytes !== Array)\n d.prefix = $util.newBuffer(d.prefix);\n }\n if (o.bytes === String)\n d.data = '';\n else {\n d.data = [];\n if (o.bytes !== Array)\n d.data = $util.newBuffer(d.data);\n }\n }\n if (m.prefix != null && m.hasOwnProperty('prefix')) {\n d.prefix = o.bytes === String ? $util.base64.encode(m.prefix, 0, m.prefix.length) : o.bytes === Array ? Array.prototype.slice.call(m.prefix) : m.prefix;\n }\n if (m.data != null && m.hasOwnProperty('data')) {\n d.data = o.bytes === String ? $util.base64.encode(m.data, 0, m.data.length) : o.bytes === Array ? Array.prototype.slice.call(m.data) : m.data;\n }\n return d;\n };\n Block.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n return Block;\n }();\n Message.BlockPresenceType = function () {\n const valuesById = {}, values = Object.create(valuesById);\n values[valuesById[0] = 'Have'] = 0;\n values[valuesById[1] = 'DontHave'] = 1;\n return values;\n }();\n Message.BlockPresence = function () {\n function BlockPresence(p) {\n if (p)\n for (var ks = Object.keys(p), i = 0; i < ks.length; ++i)\n if (p[ks[i]] != null)\n this[ks[i]] = p[ks[i]];\n }\n BlockPresence.prototype.cid = $util.newBuffer([]);\n BlockPresence.prototype.type = 0;\n BlockPresence.encode = function encode(m, w) {\n if (!w)\n w = $Writer.create();\n if (m.cid != null && Object.hasOwnProperty.call(m, 'cid'))\n w.uint32(10).bytes(m.cid);\n if (m.type != null && Object.hasOwnProperty.call(m, 'type'))\n w.uint32(16).int32(m.type);\n return w;\n };\n BlockPresence.decode = function decode(r, l) {\n if (!(r instanceof $Reader))\n r = $Reader.create(r);\n var c = l === undefined ? r.len : r.pos + l, m = new $root.Message.BlockPresence();\n while (r.pos < c) {\n var t = r.uint32();\n switch (t >>> 3) {\n case 1:\n m.cid = r.bytes();\n break;\n case 2:\n m.type = r.int32();\n break;\n default:\n r.skipType(t & 7);\n break;\n }\n }\n return m;\n };\n BlockPresence.fromObject = function fromObject(d) {\n if (d instanceof $root.Message.BlockPresence)\n return d;\n var m = new $root.Message.BlockPresence();\n if (d.cid != null) {\n if (typeof d.cid === 'string')\n $util.base64.decode(d.cid, m.cid = $util.newBuffer($util.base64.length(d.cid)), 0);\n else if (d.cid.length)\n m.cid = d.cid;\n }\n switch (d.type) {\n case 'Have':\n case 0:\n m.type = 0;\n break;\n case 'DontHave':\n case 1:\n m.type = 1;\n break;\n }\n return m;\n };\n BlockPresence.toObject = function toObject(m, o) {\n if (!o)\n o = {};\n var d = {};\n if (o.defaults) {\n if (o.bytes === String)\n d.cid = '';\n else {\n d.cid = [];\n if (o.bytes !== Array)\n d.cid = $util.newBuffer(d.cid);\n }\n d.type = o.enums === String ? 'Have' : 0;\n }\n if (m.cid != null && m.hasOwnProperty('cid')) {\n d.cid = o.bytes === String ? $util.base64.encode(m.cid, 0, m.cid.length) : o.bytes === Array ? Array.prototype.slice.call(m.cid) : m.cid;\n }\n if (m.type != null && m.hasOwnProperty('type')) {\n d.type = o.enums === String ? $root.Message.BlockPresenceType[m.type] : m.type;\n }\n return d;\n };\n BlockPresence.prototype.toJSON = function toJSON() {\n return this.constructor.toObject(this, $protobuf__default[\"default\"].util.toJSONOptions);\n };\n return BlockPresence;\n }();\n return Message;\n})();\n\nexports.Message = Message;\nexports[\"default\"] = $root;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst SECOND = 1000;\nconst maxProvidersPerRequest = 3;\nconst providerRequestTimeout = 10 * SECOND;\nconst hasBlockTimeout = 15 * SECOND;\nconst provideTimeout = 15 * SECOND;\nconst kMaxPriority = Math.pow(2, 31) - 1;\nconst maxListeners = 1000;\nconst wantlistSendDebounceMs = 1;\n\nexports.hasBlockTimeout = hasBlockTimeout;\nexports.kMaxPriority = kMaxPriority;\nexports.maxListeners = maxListeners;\nexports.maxProvidersPerRequest = maxProvidersPerRequest;\nexports.provideTimeout = provideTimeout;\nexports.providerRequestTimeout = providerRequestTimeout;\nexports.wantlistSendDebounceMs = wantlistSendDebounceMs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar debounce = require('just-debounce-it');\nvar index$1 = require('../message/index.js');\nvar index = require('../utils/index.js');\nvar constants = require('../constants.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar debounce__default = /*#__PURE__*/_interopDefaultLegacy(debounce);\n\nclass MsgQueue {\n constructor(selfPeerId, otherPeerId, network) {\n this.peerId = otherPeerId;\n this.network = network;\n this.refcnt = 1;\n this._entries = [];\n this._log = index.logger(selfPeerId, 'msgqueue');\n this.sendEntries = debounce__default[\"default\"](this._sendEntries.bind(this), constants.wantlistSendDebounceMs);\n }\n addMessage(msg) {\n if (msg.empty) {\n return;\n }\n this.send(msg);\n }\n addEntries(entries) {\n this._entries = this._entries.concat(entries);\n this.sendEntries();\n }\n _sendEntries() {\n if (!this._entries.length) {\n return;\n }\n const msg = new index$1.BitswapMessage(false);\n this._entries.forEach(entry => {\n if (entry.cancel) {\n msg.cancel(entry.cid);\n } else {\n msg.addEntry(entry.cid, entry.priority);\n }\n });\n this._entries = [];\n this.addMessage(msg);\n }\n async send(msg) {\n try {\n await this.network.connectTo(this.peerId);\n } catch (err) {\n this._log.error('cant connect to peer %s: %s', this.peerId.toB58String(), err.message);\n return;\n }\n this._log('sending message to peer %s', this.peerId.toB58String());\n this.network.sendMessage(this.peerId, msg).catch(err => {\n this._log.error('send error: %s', err.message);\n });\n }\n}\n\nexports.MsgQueue = MsgQueue;\n","module.exports = debounce;\n\nfunction debounce(fn, wait, callFirst) {\n var timeout = null;\n var debouncedFn = null;\n\n var clear = function() {\n if (timeout) {\n clearTimeout(timeout);\n\n debouncedFn = null;\n timeout = null;\n }\n };\n\n var flush = function() {\n var call = debouncedFn;\n clear();\n\n if (call) {\n call();\n }\n };\n\n var debounceWrapper = function() {\n if (!wait) {\n return fn.apply(this, arguments);\n }\n\n var context = this;\n var args = arguments;\n var callNow = callFirst && !timeout;\n clear();\n\n debouncedFn = function() {\n fn.apply(context, args);\n };\n\n timeout = setTimeout(function() {\n timeout = null;\n\n if (!callNow) {\n var call = debouncedFn;\n debouncedFn = null;\n\n return call();\n }\n }, wait);\n\n if (callNow) {\n return debouncedFn();\n }\n };\n\n debounceWrapper.cancel = clear;\n debounceWrapper.flush = flush;\n\n return debounceWrapper;\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar lp = require('it-length-prefixed');\nvar itPipe = require('it-pipe');\nvar MulticodecTopology = require('libp2p-interfaces/src/topology/multicodec-topology.js');\nvar index$1 = require('./message/index.js');\nvar constants = require('./constants.js');\nvar index = require('./utils/index.js');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar lp__default = /*#__PURE__*/_interopDefaultLegacy(lp);\nvar MulticodecTopology__default = /*#__PURE__*/_interopDefaultLegacy(MulticodecTopology);\n\nconst BITSWAP100 = '/ipfs/bitswap/1.0.0';\nconst BITSWAP110 = '/ipfs/bitswap/1.1.0';\nconst BITSWAP120 = '/ipfs/bitswap/1.2.0';\nclass Network {\n constructor(libp2p, bitswap, stats, options = {}) {\n this._log = index.logger(libp2p.peerId, 'network');\n this._libp2p = libp2p;\n this._bitswap = bitswap;\n this._protocols = [BITSWAP100];\n if (!options.b100Only) {\n this._protocols.unshift(BITSWAP110);\n this._protocols.unshift(BITSWAP120);\n }\n this._stats = stats;\n this._running = false;\n this._onPeerConnect = this._onPeerConnect.bind(this);\n this._onPeerDisconnect = this._onPeerDisconnect.bind(this);\n this._onConnection = this._onConnection.bind(this);\n this._hashLoader = options.hashLoader;\n }\n start() {\n this._running = true;\n this._libp2p.handle(this._protocols, this._onConnection);\n const topology = new MulticodecTopology__default[\"default\"]({\n multicodecs: this._protocols,\n handlers: {\n onConnect: this._onPeerConnect,\n onDisconnect: this._onPeerDisconnect\n }\n });\n this._registrarId = this._libp2p.registrar.register(topology);\n for (const peer of this._libp2p.peerStore.peers.values()) {\n const conn = this._libp2p.connectionManager.get(peer.id);\n conn && this._onPeerConnect(conn.remotePeer);\n }\n }\n stop() {\n this._running = false;\n this._libp2p.unhandle(this._protocols);\n if (this._registrarId != null) {\n this._libp2p.registrar.unregister(this._registrarId);\n }\n }\n async _onConnection({protocol, stream, connection}) {\n if (!this._running) {\n return;\n }\n this._log('incoming new bitswap %s connection from %s', protocol, connection.remotePeer.toB58String());\n try {\n await itPipe.pipe(stream, lp__default[\"default\"].decode(), async source => {\n for await (const data of source) {\n try {\n const message = await index$1.BitswapMessage.deserialize(data.slice(), this._hashLoader);\n await this._bitswap._receiveMessage(connection.remotePeer, message);\n } catch (err) {\n this._bitswap._receiveError(err);\n break;\n }\n }\n });\n } catch (err) {\n this._log(err);\n }\n }\n _onPeerConnect(peerId) {\n this._bitswap._onPeerConnected(peerId);\n }\n _onPeerDisconnect(peerId) {\n this._bitswap._onPeerDisconnected(peerId);\n }\n findProviders(cid, maxProviders, options = {}) {\n return this._libp2p.contentRouting.findProviders(cid, {\n timeout: constants.providerRequestTimeout,\n maxNumProviders: maxProviders\n });\n }\n async findAndConnect(cid, options) {\n const connectAttempts = [];\n for await (const provider of this.findProviders(cid, constants.maxProvidersPerRequest, options)) {\n this._log(`connecting to provider ${ provider.id }`);\n connectAttempts.push(this.connectTo(provider.id, options).catch(err => {\n this._log.error(err);\n }));\n }\n await Promise.all(connectAttempts);\n }\n async provide(cid, options) {\n await this._libp2p.contentRouting.provide(cid, options);\n }\n async sendMessage(peer, msg) {\n if (!this._running)\n throw new Error('network isn\\'t running');\n const stringId = peer.toB58String();\n this._log('sendMessage to %s', stringId, msg);\n const connection = await this._libp2p.dial(peer);\n const {stream, protocol} = await connection.newStream([\n BITSWAP120,\n BITSWAP110,\n BITSWAP100\n ]);\n let serialized;\n switch (protocol) {\n case BITSWAP100:\n serialized = msg.serializeToBitswap100();\n break;\n case BITSWAP110:\n case BITSWAP120:\n serialized = msg.serializeToBitswap110();\n break;\n default:\n throw new Error('Unknown protocol: ' + protocol);\n }\n writeMessage(stream, serialized, this._log);\n this._updateSentStats(peer, msg.blocks);\n }\n async connectTo(peer, options) {\n if (!this._running) {\n throw new Error('network isn\\'t running');\n }\n return this._libp2p.dial(peer, options);\n }\n _updateSentStats(peer, blocks) {\n const peerId = peer.toB58String();\n if (this._stats) {\n for (const block of blocks.values()) {\n this._stats.push(peerId, 'dataSent', block.length);\n }\n this._stats.push(peerId, 'blocksSent', blocks.size);\n }\n }\n}\nasync function writeMessage(stream, msg, log) {\n try {\n await itPipe.pipe([msg], lp__default[\"default\"].encode(), stream);\n } catch (err) {\n log(err);\n }\n}\n\nexports.Network = Network;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar cid = require('multiformats/cid');\nvar base58 = require('multiformats/bases/base58');\nvar index = require('../message/index.js');\nvar index$2 = require('../wantlist/index.js');\nvar ledger = require('./ledger.js');\nvar reqQueue = require('./req-queue.js');\nvar taskMerger = require('./task-merger.js');\nvar index$1 = require('../utils/index.js');\n\nconst WantType = index.BitswapMessage.WantType;\nconst TARGET_MESSAGE_SIZE = 16 * 1024;\nconst MAX_SIZE_REPLACE_HAS_WITH_BLOCK = 1024;\nclass DecisionEngine {\n constructor(peerId, blockstore, network, stats, opts = {}) {\n this._log = index$1.logger(peerId, 'engine');\n this.blockstore = blockstore;\n this.network = network;\n this._stats = stats;\n this._opts = this._processOpts(opts);\n this.ledgerMap = new Map();\n this._running = false;\n this._requestQueue = new reqQueue.RequestQueue(taskMerger.TaskMerger);\n }\n _processOpts(opts) {\n return {\n maxSizeReplaceHasWithBlock: MAX_SIZE_REPLACE_HAS_WITH_BLOCK,\n targetMessageSize: TARGET_MESSAGE_SIZE,\n ...opts\n };\n }\n _scheduleProcessTasks() {\n setTimeout(() => {\n this._processTasks();\n });\n }\n async _processTasks() {\n if (!this._running) {\n return;\n }\n const {peerId, tasks, pendingSize} = this._requestQueue.popTasks(this._opts.targetMessageSize);\n if (tasks.length === 0) {\n return;\n }\n const msg = new index.BitswapMessage(false);\n msg.setPendingBytes(pendingSize);\n const blockCids = [];\n const blockTasks = new Map();\n for (const task of tasks) {\n const cid$1 = cid.CID.parse(task.topic);\n if (task.data.haveBlock) {\n if (task.data.isWantBlock) {\n blockCids.push(cid$1);\n blockTasks.set(task.topic, task.data);\n } else {\n msg.addHave(cid$1);\n }\n } else {\n msg.addDontHave(cid$1);\n }\n }\n const blocks = await this._getBlocks(blockCids);\n for (const [topic, taskData] of blockTasks) {\n const cid$1 = cid.CID.parse(topic);\n const blk = blocks.get(topic);\n if (blk) {\n msg.addBlock(cid$1, blk);\n } else {\n if (taskData.sendDontHave) {\n msg.addDontHave(cid$1);\n }\n }\n }\n if (msg.empty) {\n peerId && this._requestQueue.tasksDone(peerId, tasks);\n this._scheduleProcessTasks();\n return;\n }\n try {\n peerId && await this.network.sendMessage(peerId, msg);\n for (const [cidStr, block] of blocks.entries()) {\n peerId && this.messageSent(peerId, cid.CID.parse(cidStr), block);\n }\n } catch (err) {\n this._log.error(err);\n }\n peerId && this._requestQueue.tasksDone(peerId, tasks);\n this._scheduleProcessTasks();\n }\n wantlistForPeer(peerId) {\n const peerIdStr = peerId.toB58String();\n const ledger = this.ledgerMap.get(peerIdStr);\n return ledger ? ledger.wantlist.sortedEntries() : new Map();\n }\n ledgerForPeer(peerId) {\n const peerIdStr = peerId.toB58String();\n const ledger = this.ledgerMap.get(peerIdStr);\n if (!ledger) {\n return null;\n }\n return {\n peer: ledger.partner,\n value: ledger.debtRatio(),\n sent: ledger.accounting.bytesSent,\n recv: ledger.accounting.bytesRecv,\n exchanged: ledger.exchangeCount\n };\n }\n peers() {\n return Array.from(this.ledgerMap.values()).map(l => l.partner);\n }\n receivedBlocks(blocks) {\n if (!blocks.length) {\n return;\n }\n for (const ledger of this.ledgerMap.values()) {\n for (const block of blocks) {\n const want = ledger.wantlistContains(block.cid);\n if (!want) {\n continue;\n }\n const blockSize = block.data.length;\n const isWantBlock = this._sendAsBlock(want.wantType, blockSize);\n let entrySize = blockSize;\n if (!isWantBlock) {\n entrySize = index.BitswapMessage.blockPresenceSize(want.cid);\n }\n this._requestQueue.pushTasks(ledger.partner, [{\n topic: want.cid.toString(base58.base58btc),\n priority: want.priority,\n size: entrySize,\n data: {\n blockSize,\n isWantBlock,\n haveBlock: true,\n sendDontHave: false\n }\n }]);\n }\n }\n this._scheduleProcessTasks();\n }\n async messageReceived(peerId, msg) {\n const ledger = this._findOrCreate(peerId);\n if (msg.empty) {\n return;\n }\n if (msg.full) {\n ledger.wantlist = new index$2.Wantlist();\n }\n this._updateBlockAccounting(msg.blocks, ledger);\n if (msg.wantlist.size === 0) {\n this._scheduleProcessTasks();\n return;\n }\n const cancels = [];\n const wants = [];\n msg.wantlist.forEach(entry => {\n if (entry.cancel) {\n ledger.cancelWant(entry.cid);\n cancels.push(entry.cid);\n } else {\n ledger.wants(entry.cid, entry.priority, entry.wantType);\n wants.push(entry);\n }\n });\n this._cancelWants(peerId, cancels);\n await this._addWants(peerId, wants);\n this._scheduleProcessTasks();\n }\n _cancelWants(peerId, cids) {\n for (const c of cids) {\n this._requestQueue.remove(c.toString(base58.base58btc), peerId);\n }\n }\n async _addWants(peerId, wants) {\n const blockSizes = await this._getBlockSizes(wants.map(w => w.cid));\n const tasks = [];\n for (const want of wants) {\n const id = want.cid.toString(base58.base58btc);\n const blockSize = blockSizes.get(id);\n if (blockSize == null) {\n if (want.sendDontHave) {\n tasks.push({\n topic: id,\n priority: want.priority,\n size: index.BitswapMessage.blockPresenceSize(want.cid),\n data: {\n isWantBlock: want.wantType === WantType.Block,\n blockSize: 0,\n haveBlock: false,\n sendDontHave: want.sendDontHave\n }\n });\n }\n } else {\n const isWantBlock = this._sendAsBlock(want.wantType, blockSize);\n let entrySize = blockSize;\n if (!isWantBlock) {\n entrySize = index.BitswapMessage.blockPresenceSize(want.cid);\n }\n tasks.push({\n topic: id,\n priority: want.priority,\n size: entrySize,\n data: {\n isWantBlock,\n blockSize,\n haveBlock: true,\n sendDontHave: want.sendDontHave\n }\n });\n }\n this._requestQueue.pushTasks(peerId, tasks);\n }\n }\n _sendAsBlock(wantType, blockSize) {\n return wantType === WantType.Block || blockSize <= this._opts.maxSizeReplaceHasWithBlock;\n }\n async _getBlockSizes(cids) {\n const blocks = await this._getBlocks(cids);\n return new Map([...blocks].map(([k, v]) => [\n k,\n v.length\n ]));\n }\n async _getBlocks(cids) {\n const res = new Map();\n await Promise.all(cids.map(async cid => {\n try {\n const block = await this.blockstore.get(cid);\n res.set(cid.toString(base58.base58btc), block);\n } catch (e) {\n if (e.code !== 'ERR_NOT_FOUND') {\n this._log.error('failed to query blockstore for %s: %s', cid, e);\n }\n }\n }));\n return res;\n }\n _updateBlockAccounting(blocksMap, ledger) {\n for (const block of blocksMap.values()) {\n this._log('got block (%s bytes)', block.length);\n ledger.receivedBytes(block.length);\n }\n }\n messageSent(peerId, cid, block) {\n const ledger = this._findOrCreate(peerId);\n ledger.sentBytes(block.length);\n ledger.wantlist.remove(cid);\n }\n numBytesSentTo(peerId) {\n return this._findOrCreate(peerId).accounting.bytesSent;\n }\n numBytesReceivedFrom(peerId) {\n return this._findOrCreate(peerId).accounting.bytesRecv;\n }\n peerDisconnected(_peerId) {\n }\n _findOrCreate(peerId) {\n const peerIdStr = peerId.toB58String();\n const ledger$1 = this.ledgerMap.get(peerIdStr);\n if (ledger$1) {\n return ledger$1;\n }\n const l = new ledger.Ledger(peerId);\n this.ledgerMap.set(peerIdStr, l);\n if (this._stats) {\n this._stats.push(peerIdStr, 'peerCount', 1);\n }\n return l;\n }\n start() {\n this._running = true;\n }\n stop() {\n this._running = false;\n }\n}\n\nexports.DecisionEngine = DecisionEngine;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar index = require('../wantlist/index.js');\n\nclass Ledger {\n constructor(peerId) {\n this.partner = peerId;\n this.wantlist = new index.Wantlist();\n this.exchangeCount = 0;\n this.sentToPeer = new Map();\n this.accounting = {\n bytesSent: 0,\n bytesRecv: 0\n };\n }\n sentBytes(n) {\n this.exchangeCount++;\n this.lastExchange = new Date().getTime();\n this.accounting.bytesSent += n;\n }\n receivedBytes(n) {\n this.exchangeCount++;\n this.lastExchange = new Date().getTime();\n this.accounting.bytesRecv += n;\n }\n wants(cid, priority, wantType) {\n this.wantlist.add(cid, priority, wantType);\n }\n cancelWant(cid) {\n this.wantlist.remove(cid);\n }\n wantlistContains(cid) {\n return this.wantlist.get(cid);\n }\n debtRatio() {\n return this.accounting.bytesSent / (this.accounting.bytesRecv + 1);\n }\n}\n\nexports.Ledger = Ledger;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar sortedMap = require('../utils/sorted-map.js');\n\nconst DefaultTaskMerger = {\n hasNewInfo() {\n return false;\n },\n merge() {\n }\n};\nclass RequestQueue {\n constructor(taskMerger = DefaultTaskMerger) {\n this._taskMerger = taskMerger;\n this._byPeer = new sortedMap.SortedMap([], PeerTasks.compare);\n }\n pushTasks(peerId, tasks) {\n let peerTasks = this._byPeer.get(peerId.toB58String());\n if (!peerTasks) {\n peerTasks = new PeerTasks(peerId, this._taskMerger);\n }\n peerTasks.pushTasks(tasks);\n this._byPeer.set(peerId.toB58String(), peerTasks);\n }\n popTasks(targetMinBytes) {\n const peerTasks = this._head();\n if (peerTasks === undefined) {\n return {\n tasks: [],\n pendingSize: 0\n };\n }\n const {tasks, pendingSize} = peerTasks.popTasks(targetMinBytes);\n if (tasks.length === 0) {\n return {\n tasks,\n pendingSize\n };\n }\n const peerId = peerTasks.peerId;\n if (peerTasks.isIdle()) {\n this._byPeer.delete(peerId.toB58String());\n } else {\n this._byPeer.update(0);\n }\n return {\n peerId,\n tasks,\n pendingSize\n };\n }\n _head() {\n if (this._byPeer.size === 0) {\n return undefined;\n }\n for (const [, v] of this._byPeer) {\n return v;\n }\n return undefined;\n }\n remove(topic, peerId) {\n const peerTasks = this._byPeer.get(peerId.toB58String());\n peerTasks && peerTasks.remove(topic);\n }\n tasksDone(peerId, tasks) {\n const peerTasks = this._byPeer.get(peerId.toB58String());\n if (!peerTasks) {\n return;\n }\n const i = this._byPeer.indexOf(peerId.toB58String());\n for (const task of tasks) {\n peerTasks.taskDone(task);\n }\n this._byPeer.update(i);\n }\n}\nclass PeerTasks {\n constructor(peerId, taskMerger) {\n this.peerId = peerId;\n this._taskMerger = taskMerger;\n this._activeTotalSize = 0;\n this._pending = new PendingTasks();\n this._active = new Set();\n }\n pushTasks(tasks) {\n for (const t of tasks) {\n this._pushTask(t);\n }\n }\n _pushTask(task) {\n if (!this._taskHasMoreInfoThanActiveTasks(task)) {\n return;\n }\n const existingTask = this._pending.get(task.topic);\n if (existingTask) {\n if (task.priority > existingTask.priority) {\n this._pending.updatePriority(task.topic, task.priority);\n }\n this._taskMerger.merge(task, existingTask);\n return;\n }\n this._pending.add(task);\n }\n _taskHasMoreInfoThanActiveTasks(task) {\n const tasksWithTopic = [];\n for (const activeTask of this._active) {\n if (activeTask.topic === task.topic) {\n tasksWithTopic.push(activeTask);\n }\n }\n if (tasksWithTopic.length === 0) {\n return true;\n }\n return this._taskMerger.hasNewInfo(task, tasksWithTopic);\n }\n popTasks(targetMinBytes) {\n let size = 0;\n const tasks = [];\n const pendingTasks = this._pending.tasks();\n for (let i = 0; i < pendingTasks.length && size < targetMinBytes; i++) {\n const task = pendingTasks[i];\n tasks.push(task);\n size += task.size;\n this._pending.delete(task.topic);\n this._activeTotalSize += task.size;\n this._active.add(task);\n }\n return {\n tasks,\n pendingSize: this._pending.totalSize\n };\n }\n taskDone(task) {\n if (this._active.has(task)) {\n this._activeTotalSize -= task.size;\n this._active.delete(task);\n }\n }\n remove(topic) {\n this._pending.delete(topic);\n }\n isIdle() {\n return this._pending.length === 0 && this._active.size === 0;\n }\n static compare(a, b) {\n if (a[1]._pending.length === 0) {\n return 1;\n }\n if (b[1]._pending.length === 0) {\n return -1;\n }\n if (a[1]._activeTotalSize === b[1]._activeTotalSize) {\n return b[1]._pending.length - a[1]._pending.length;\n }\n return a[1]._activeTotalSize - b[1]._activeTotalSize;\n }\n}\nclass PendingTasks {\n constructor() {\n this._tasks = new sortedMap.SortedMap([], this._compare);\n }\n get length() {\n return this._tasks.size;\n }\n get totalSize() {\n return [...this._tasks.values()].reduce((a, t) => a + t.task.size, 0);\n }\n get(topic) {\n return (this._tasks.get(topic) || {}).task;\n }\n add(task) {\n this._tasks.set(task.topic, {\n created: Date.now(),\n task\n });\n }\n delete(topic) {\n this._tasks.delete(topic);\n }\n tasks() {\n return [...this._tasks.values()].map(i => i.task);\n }\n updatePriority(topic, priority) {\n const obj = this._tasks.get(topic);\n if (!obj) {\n return;\n }\n const i = this._tasks.indexOf(topic);\n obj.task.priority = priority;\n this._tasks.update(i);\n }\n _compare(a, b) {\n if (a[1].task.priority === b[1].task.priority) {\n return a[1].created - b[1].created;\n }\n return b[1].task.priority - a[1].task.priority;\n }\n}\n\nexports.RequestQueue = RequestQueue;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass SortedMap extends Map {\n constructor(entries, cmp) {\n super();\n this._cmp = cmp || this._defaultSort;\n this._keys = [];\n for (const [k, v] of entries || []) {\n this.set(k, v);\n }\n }\n update(i) {\n if (i < 0 || i >= this._keys.length) {\n return;\n }\n const k = this._keys[i];\n this._keys.splice(i, 1);\n const newIdx = this._find(k);\n this._keys.splice(newIdx, 0, k);\n }\n set(k, v) {\n if (this.has(k)) {\n const i = this.indexOf(k);\n this._keys.splice(i, 1);\n }\n super.set(k, v);\n const i = this._find(k);\n this._keys.splice(i, 0, k);\n return this;\n }\n clear() {\n super.clear();\n this._keys = [];\n }\n delete(k) {\n if (!this.has(k)) {\n return false;\n }\n const i = this.indexOf(k);\n this._keys.splice(i, 1);\n return super.delete(k);\n }\n indexOf(k) {\n if (!this.has(k)) {\n return -1;\n }\n const i = this._find(k);\n if (this._keys[i] === k) {\n return i;\n }\n for (let j = 1; j < this._keys.length; j++) {\n if (this._keys[i + j] === k)\n return i + j;\n if (this._keys[i - j] === k)\n return i - j;\n }\n return -1;\n }\n _find(k) {\n let lower = 0;\n let upper = this._keys.length;\n while (lower < upper) {\n const pivot = lower + upper >>> 1;\n const cmp = this._kCmp(this._keys[pivot], k);\n if (cmp < 0) {\n lower = pivot + 1;\n } else if (cmp > 0) {\n upper = pivot;\n } else {\n return pivot;\n }\n }\n return lower;\n }\n *keys() {\n for (const k of this._keys) {\n yield k;\n }\n return undefined;\n }\n *values() {\n for (const k of this._keys) {\n yield this.get(k);\n }\n return undefined;\n }\n *entries() {\n for (const k of this._keys) {\n yield [\n k,\n this.get(k)\n ];\n }\n return undefined;\n }\n *[Symbol.iterator]() {\n yield* this.entries();\n }\n forEach(cb, thisArg) {\n if (!cb) {\n return;\n }\n for (const k of this._keys) {\n cb.apply(thisArg, [[\n k,\n this.get(k)\n ]]);\n }\n }\n _defaultSort(a, b) {\n if (a[0] < b[0])\n return -1;\n if (b[0] < a[0])\n return 1;\n return 0;\n }\n _kCmp(a, b) {\n return this._cmp([\n a,\n this.get(a)\n ], [\n b,\n this.get(b)\n ]);\n }\n}\n\nexports.SortedMap = SortedMap;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst TaskMerger = {\n hasNewInfo(task, tasksWithTopic) {\n let haveBlock = false;\n let isWantBlock = false;\n for (const existing of tasksWithTopic) {\n if (existing.data.haveBlock) {\n haveBlock = true;\n }\n if (existing.data.isWantBlock) {\n isWantBlock = true;\n }\n }\n if (!isWantBlock && task.data.isWantBlock) {\n return true;\n }\n if (!haveBlock && task.data.haveBlock) {\n return true;\n }\n return false;\n },\n merge(newTask, existingTask) {\n const taskData = newTask.data;\n const existingData = existingTask.data;\n if (!existingData.haveBlock && taskData.haveBlock) {\n existingData.haveBlock = taskData.haveBlock;\n existingData.blockSize = taskData.blockSize;\n }\n if (!existingData.isWantBlock && taskData.isWantBlock) {\n existingData.isWantBlock = true;\n if (!existingData.haveBlock || taskData.haveBlock) {\n existingData.haveBlock = taskData.haveBlock;\n existingTask.size = newTask.size;\n }\n }\n if (existingData.isWantBlock && existingData.haveBlock) {\n existingTask.size = existingData.blockSize;\n }\n }\n};\n\nexports.TaskMerger = TaskMerger;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar events = require('events');\nvar toString = require('uint8arrays/to-string');\nvar constants = require('./constants.js');\nvar index = require('./utils/index.js');\n\nconst unwantEvent = cid => `unwant:${ toString.toString(cid.multihash.bytes, 'base64') }`;\nconst blockEvent = cid => `block:${ toString.toString(cid.multihash.bytes, 'base64') }`;\nclass Notifications extends events.EventEmitter {\n constructor(peerId) {\n super();\n this.setMaxListeners(constants.maxListeners);\n this._log = index.logger(peerId, 'notif');\n }\n hasBlock(cid, block) {\n const event = blockEvent(cid);\n this._log(event);\n this.emit(event, block);\n }\n wantBlock(cid, options = {}) {\n if (!cid) {\n throw new Error('Not a valid cid');\n }\n const blockEvt = blockEvent(cid);\n const unwantEvt = unwantEvent(cid);\n this._log(`wantBlock:${ cid }`);\n return new Promise((resolve, reject) => {\n const onUnwant = () => {\n this.removeListener(blockEvt, onBlock);\n reject(new Error(`Block for ${ cid } unwanted`));\n };\n const onBlock = data => {\n this.removeListener(unwantEvt, onUnwant);\n resolve(data);\n };\n this.once(unwantEvt, onUnwant);\n this.once(blockEvt, onBlock);\n if (options && options.signal) {\n options.signal.addEventListener('abort', () => {\n this.removeListener(blockEvt, onBlock);\n this.removeListener(unwantEvt, onUnwant);\n reject(new Error(`Want for ${ cid } aborted`));\n });\n }\n });\n }\n unwantBlock(cid) {\n const event = unwantEvent(cid);\n this._log(event);\n this.emit(event);\n }\n}\n\nexports.Notifications = Notifications;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar events = require('events');\nvar stat = require('./stat.js');\n\nconst defaultOptions = {\n enabled: false,\n computeThrottleTimeout: 1000,\n computeThrottleMaxQueueSize: 1000,\n movingAverageIntervals: [\n 60 * 1000,\n 5 * 60 * 1000,\n 15 * 60 * 1000\n ]\n};\nclass Stats extends events.EventEmitter {\n constructor(initialCounters = [], _options = defaultOptions) {\n super();\n const options = Object.assign({}, defaultOptions, _options);\n if (typeof options.computeThrottleTimeout !== 'number') {\n throw new Error('need computeThrottleTimeout');\n }\n if (typeof options.computeThrottleMaxQueueSize !== 'number') {\n throw new Error('need computeThrottleMaxQueueSize');\n }\n this._initialCounters = initialCounters;\n this._options = options;\n this._enabled = this._options.enabled;\n this._global = new stat.Stat(initialCounters, options);\n this._global.on('update', stats => this.emit('update', stats));\n this._peers = new Map();\n }\n enable() {\n this._enabled = true;\n this._options.enabled = true;\n this._global.enable();\n }\n disable() {\n this._enabled = false;\n this._options.enabled = false;\n this._global.disable();\n }\n stop() {\n this._enabled = false;\n this._global.stop();\n for (const peerStat of this._peers) {\n peerStat[1].stop();\n }\n }\n get snapshot() {\n return this._global.snapshot;\n }\n get movingAverages() {\n return this._global.movingAverages;\n }\n forPeer(peerId) {\n const peerIdStr = typeof peerId !== 'string' && peerId.toB58String ? peerId.toB58String() : `${ peerId }`;\n return this._peers.get(peerIdStr);\n }\n push(peer, counter, inc) {\n if (this._enabled) {\n this._global.push(counter, inc);\n if (peer) {\n let peerStats = this._peers.get(peer);\n if (!peerStats) {\n peerStats = new stat.Stat(this._initialCounters, this._options);\n this._peers.set(peer, peerStats);\n }\n peerStats.push(counter, inc);\n }\n }\n }\n disconnected(peer) {\n const peerId = peer.toB58String();\n const peerStats = this._peers.get(peerId);\n if (peerStats) {\n peerStats.stop();\n this._peers.delete(peerId);\n }\n }\n}\n\nexports.Stats = Stats;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar events = require('events');\nvar MovingAverage = require('@vascosantos/moving-average');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar MovingAverage__default = /*#__PURE__*/_interopDefaultLegacy(MovingAverage);\n\nclass Stat extends events.EventEmitter {\n constructor(initialCounters, options) {\n super();\n this._options = options;\n this._queue = [];\n this._stats = {};\n this._frequencyLastTime = Date.now();\n this._frequencyAccumulators = {};\n this._movingAverages = {};\n this._update = this._update.bind(this);\n initialCounters.forEach(key => {\n this._stats[key] = BigInt(0);\n this._movingAverages[key] = {};\n this._options.movingAverageIntervals.forEach(interval => {\n const ma = this._movingAverages[key][interval] = MovingAverage__default[\"default\"](interval);\n ma.push(this._frequencyLastTime, 0);\n });\n });\n this._enabled = this._options.enabled;\n }\n enable() {\n this._enabled = true;\n }\n disable() {\n this._disabled = true;\n }\n stop() {\n if (this._timeout) {\n clearTimeout(this._timeout);\n }\n }\n get snapshot() {\n return Object.assign({}, this._stats);\n }\n get movingAverages() {\n return Object.assign({}, this._movingAverages);\n }\n push(counter, inc) {\n if (this._enabled) {\n this._queue.push([\n counter,\n inc,\n Date.now()\n ]);\n this._resetComputeTimeout();\n }\n }\n _resetComputeTimeout() {\n if (this._timeout) {\n clearTimeout(this._timeout);\n }\n this._timeout = setTimeout(this._update, this._nextTimeout());\n }\n _nextTimeout() {\n const urgency = this._queue.length / this._options.computeThrottleMaxQueueSize;\n return Math.max(this._options.computeThrottleTimeout * (1 - urgency), 0);\n }\n _update() {\n this._timeout = null;\n if (this._queue.length) {\n let last;\n while (this._queue.length) {\n const op = last = this._queue.shift();\n op && this._applyOp(op);\n }\n last && this._updateFrequency(last[2]);\n this.emit('update', this._stats);\n }\n }\n _updateFrequency(latestTime) {\n const timeDiff = latestTime - this._frequencyLastTime;\n if (timeDiff) {\n Object.keys(this._stats).forEach(key => {\n this._updateFrequencyFor(key, timeDiff, latestTime);\n });\n }\n this._frequencyLastTime = latestTime;\n }\n _updateFrequencyFor(key, timeDiffMS, latestTime) {\n const count = this._frequencyAccumulators[key] || 0;\n this._frequencyAccumulators[key] = 0;\n const hz = count / timeDiffMS * 1000;\n let movingAverages = this._movingAverages[key];\n if (!movingAverages) {\n movingAverages = this._movingAverages[key] = {};\n }\n this._options.movingAverageIntervals.forEach(movingAverageInterval => {\n let movingAverage = movingAverages[movingAverageInterval];\n if (!movingAverage) {\n movingAverage = movingAverages[movingAverageInterval] = MovingAverage__default[\"default\"](movingAverageInterval);\n }\n movingAverage.push(latestTime, hz);\n });\n }\n _applyOp(op) {\n const key = op[0];\n const inc = op[1];\n if (typeof inc !== 'number') {\n throw new Error(`invalid increment number: ${ inc }`);\n }\n if (!Object.prototype.hasOwnProperty.call(this._stats, key)) {\n this._stats[key] = BigInt(0);\n }\n this._stats[key] = BigInt(this._stats[key]) + BigInt(inc);\n if (!this._frequencyAccumulators[key]) {\n this._frequencyAccumulators[key] = 0;\n }\n this._frequencyAccumulators[key] += inc;\n }\n}\n\nexports.Stat = Stat;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar blockstoreCore = require('blockstore-core');\nvar merge = require('it-merge');\nvar pushable = require('it-pushable');\nvar filter = require('it-filter');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar merge__default = /*#__PURE__*/_interopDefaultLegacy(merge);\nvar pushable__default = /*#__PURE__*/_interopDefaultLegacy(pushable);\nvar filter__default = /*#__PURE__*/_interopDefaultLegacy(filter);\n\nclass BlockStorage extends blockstoreCore.BaseBlockstore {\n constructor(blockstore, bitswap) {\n super();\n this.child = blockstore;\n this.bitswap = bitswap;\n }\n open() {\n return this.child.open();\n }\n close() {\n return this.child.close();\n }\n unwrap() {\n return this.child;\n }\n async put(cid, block, options = {}) {\n if (await this.has(cid)) {\n return;\n }\n if (this.bitswap.isStarted()) {\n await this.bitswap.put(cid, block, options);\n } else {\n await this.child.put(cid, block, options);\n }\n }\n async *putMany(blocks, options = {}) {\n const missingBlocks = filter__default['default'](blocks, async ({key}) => {\n return !await this.has(key);\n });\n if (this.bitswap.isStarted()) {\n yield* this.bitswap.putMany(missingBlocks, options);\n } else {\n yield* this.child.putMany(missingBlocks, options);\n }\n }\n async get(cid, options = {}) {\n if (!await this.has(cid) && this.bitswap.isStarted()) {\n return this.bitswap.get(cid, options);\n } else {\n return this.child.get(cid, options);\n }\n }\n async *getMany(cids, options = {}) {\n const getFromBitswap = pushable__default['default']();\n const getFromChild = pushable__default['default']();\n Promise.resolve().then(async () => {\n for await (const cid of cids) {\n if (!await this.has(cid) && this.bitswap.isStarted()) {\n getFromBitswap.push(cid);\n } else {\n getFromChild.push(cid);\n }\n }\n getFromBitswap.end();\n getFromChild.end();\n });\n yield* merge__default['default'](this.bitswap.getMany(getFromBitswap, options), this.child.getMany(getFromChild, options));\n }\n async delete(cid, options) {\n await this.child.delete(cid, options);\n }\n async *deleteMany(cids, options) {\n yield* this.child.deleteMany(cids, options);\n }\n async has(cid, options = {}) {\n return this.child.has(cid, options);\n }\n async *query(q, options = {}) {\n yield* this.child.query(q, options);\n }\n async *queryKeys(q, options = {}) {\n yield* this.child.queryKeys(q, options);\n }\n}\n\nexports.BlockStorage = BlockStorage;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errors = require('./errors.js');\nvar base = require('./base.js');\nvar memory = require('./memory.js');\n\nconst Errors = { ...errors };\n\nexports.BaseBlockstore = base.BaseBlockstore;\nexports.MemoryBlockstore = memory.MemoryBlockstore;\nexports.Errors = Errors;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar errCode = require('err-code');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\n\nfunction notFoundError(err) {\n err = err || new Error('Not Found');\n return errCode__default['default'](err, 'ERR_NOT_FOUND');\n}\nfunction abortedError(err) {\n err = err || new Error('Aborted');\n return errCode__default['default'](err, 'ERR_ABORTED');\n}\n\nexports.abortedError = abortedError;\nexports.notFoundError = notFoundError;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar base = require('./base.js');\nvar base32 = require('multiformats/bases/base32');\nvar raw = require('multiformats/codecs/raw');\nvar cid = require('multiformats/cid');\nvar Digest = require('multiformats/hashes/digest');\nvar errors = require('./errors.js');\n\nfunction _interopNamespace(e) {\n if (e && e.__esModule) return e;\n var n = Object.create(null);\n if (e) {\n Object.keys(e).forEach(function (k) {\n if (k !== 'default') {\n var d = Object.getOwnPropertyDescriptor(e, k);\n Object.defineProperty(n, k, d.get ? d : {\n enumerable: true,\n get: function () {\n return e[k];\n }\n });\n }\n });\n }\n n['default'] = e;\n return Object.freeze(n);\n}\n\nvar raw__namespace = /*#__PURE__*/_interopNamespace(raw);\nvar Digest__namespace = /*#__PURE__*/_interopNamespace(Digest);\n\nclass MemoryBlockstore extends base.BaseBlockstore {\n constructor() {\n super();\n this.data = {};\n }\n open() {\n return Promise.resolve();\n }\n close() {\n return Promise.resolve();\n }\n async put(key, val) {\n this.data[base32.base32.encode(key.multihash.bytes)] = val;\n }\n async get(key) {\n const exists = await this.has(key);\n if (!exists)\n throw errors.notFoundError();\n return this.data[base32.base32.encode(key.multihash.bytes)];\n }\n async has(key) {\n return this.data[base32.base32.encode(key.multihash.bytes)] !== undefined;\n }\n async delete(key) {\n delete this.data[base32.base32.encode(key.multihash.bytes)];\n }\n async *_all() {\n yield* Object.entries(this.data).map(([key, value]) => ({\n key: cid.CID.createV1(raw__namespace.code, Digest__namespace.decode(base32.base32.decode(key))),\n value\n }));\n }\n async *_allKeys() {\n yield* Object.entries(this.data).map(([key]) => cid.CID.createV1(raw__namespace.code, Digest__namespace.decode(base32.base32.decode(key))));\n }\n}\n\nexports.MemoryBlockstore = MemoryBlockstore;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar addrs = require('./addrs.js');\nvar connect = require('./connect.js');\nvar disconnect = require('./disconnect.js');\nvar localAddrs = require('./local-addrs.js');\nvar peers = require('./peers.js');\n\nclass SwarmAPI {\n constructor({network}) {\n this.addrs = addrs.createAddrs({ network });\n this.connect = connect.createConnect({ network });\n this.disconnect = disconnect.createDisconnect({ network });\n this.localAddrs = localAddrs.createLocalAddrs({ network });\n this.peers = peers.createPeers({ network });\n }\n}\n\nexports.SwarmAPI = SwarmAPI;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createAddrs({network}) {\n async function addrs(options = {}) {\n const peers = [];\n const {libp2p} = await network.use(options);\n for (const [peerId, peer] of libp2p.peerStore.peers.entries()) {\n peers.push({\n id: peerId,\n addrs: peer.addresses.map(mi => mi.multiaddr)\n });\n }\n return peers;\n }\n return withTimeoutOption.withTimeoutOption(addrs);\n}\n\nexports.createAddrs = createAddrs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createConnect({network}) {\n async function connect(addr, options = {}) {\n const {libp2p} = await network.use(options);\n await libp2p.dial(addr, options);\n }\n return withTimeoutOption.withTimeoutOption(connect);\n}\n\nexports.createConnect = createConnect;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createDisconnect({network}) {\n async function disconnect(addr, options = {}) {\n const {libp2p} = await network.use(options);\n await libp2p.hangUp(addr);\n }\n return withTimeoutOption.withTimeoutOption(disconnect);\n}\n\nexports.createDisconnect = createDisconnect;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createLocalAddrs({network}) {\n async function localAddrs(options = {}) {\n const {libp2p} = await network.use(options);\n return libp2p.multiaddrs;\n }\n return withTimeoutOption.withTimeoutOption(localAddrs);\n}\n\nexports.createLocalAddrs = createLocalAddrs;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction createPeers({network}) {\n async function peers(options = {}) {\n const {libp2p} = await network.use(options);\n const peers = [];\n for (const [peerId, connections] of libp2p.connections) {\n for (const connection of connections) {\n const peer = {\n addr: connection.remoteAddr,\n peer: peerId\n };\n if (options.verbose || options.direction) {\n peer.direction = connection.stat.direction;\n }\n if (options.verbose) {\n peer.muxer = connection.stat.multiplexer;\n peer.latency = 'n/a';\n peer.streams = [];\n }\n peers.push(peer);\n }\n }\n return peers;\n }\n return withTimeoutOption.withTimeoutOption(peers);\n}\n\nexports.createPeers = createPeers;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\n\nconst basePacket = {\n success: true,\n time: 0,\n text: ''\n};\nfunction createPing({network}) {\n async function* ping(peerId, options = {}) {\n const {libp2p} = await network.use();\n options.count = options.count || 10;\n const peer = PeerId__default['default'].createFromB58String(peerId);\n const storedPeer = libp2p.peerStore.get(peer);\n let id = storedPeer && storedPeer.id;\n if (!id) {\n yield {\n ...basePacket,\n text: `Looking up peer ${ peerId }`\n };\n const remotePeer = await libp2p.peerRouting.findPeer(peer);\n id = remotePeer && remotePeer.id;\n }\n if (!id) {\n throw new Error('Peer was not found');\n }\n yield {\n ...basePacket,\n text: `PING ${ id.toB58String() }`\n };\n let packetCount = 0;\n let totalTime = 0;\n for (let i = 0; i < options.count; i++) {\n try {\n const time = await libp2p.ping(id);\n totalTime += time;\n packetCount++;\n yield {\n ...basePacket,\n time\n };\n } catch (err) {\n yield {\n ...basePacket,\n success: false,\n text: err.toString()\n };\n }\n }\n if (packetCount) {\n const average = totalTime / packetCount;\n yield {\n ...basePacket,\n text: `Average latency: ${ average }ms`\n };\n }\n }\n return withTimeoutOption.withTimeoutOption(ping);\n}\n\nexports.createPing = createPing;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar PeerId = require('peer-id');\nvar errCode = require('err-code');\nvar errors = require('../errors.js');\nvar get = require('dlv');\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar PeerId__default = /*#__PURE__*/_interopDefaultLegacy(PeerId);\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar get__default = /*#__PURE__*/_interopDefaultLegacy(get);\n\nfunction createDht({network, repo}) {\n const {get, put, findProvs, findPeer, provide, query} = {\n async get(key, options = {}) {\n const {libp2p} = await use(network, options);\n return libp2p._dht.get(key, options);\n },\n async *put(key, value, options) {\n const {libp2p} = await use(network, options);\n yield* libp2p._dht.put(key, value);\n },\n async *findProvs(cid, options = { numProviders: 20 }) {\n const {libp2p} = await use(network, options);\n for await (const peer of libp2p._dht.findProviders(cid, {\n maxNumProviders: options.numProviders,\n signal: options.signal\n })) {\n yield {\n id: peer.id.toB58String(),\n addrs: peer.addrs\n };\n }\n },\n async findPeer(peerId, options) {\n const {libp2p} = await use(network, options);\n const peer = await libp2p._dht.findPeer(PeerId__default['default'].parse(peerId));\n return {\n id: peer.id.toB58String(),\n addrs: peer.multiaddrs\n };\n },\n async *provide(cids, options = { recursive: false }) {\n const {libp2p} = await use(network, options);\n const cidArr = Array.isArray(cids) ? cids : [cids];\n const hasCids = await Promise.all(cidArr.map(cid => repo.blocks.has(cid)));\n const hasAll = hasCids.every(has => has);\n if (!hasAll) {\n throw errCode__default['default'](new Error('block(s) not found locally, cannot provide'), 'ERR_BLOCK_NOT_FOUND');\n }\n if (options.recursive) {\n throw errCode__default['default'](new Error('not implemented yet'), 'ERR_NOT_IMPLEMENTED_YET');\n }\n for (const cid of cidArr) {\n yield libp2p._dht.provide(cid);\n }\n },\n async *query(peerId, options) {\n const {libp2p} = await use(network, options);\n for await (const closerPeerId of libp2p._dht.getClosestPeers(PeerId__default['default'].parse(peerId).toBytes())) {\n yield {\n id: closerPeerId.toB58String(),\n addrs: []\n };\n }\n }\n };\n return {\n get: withTimeoutOption.withTimeoutOption(get),\n put: withTimeoutOption.withTimeoutOption(put),\n findProvs: withTimeoutOption.withTimeoutOption(findProvs),\n findPeer: withTimeoutOption.withTimeoutOption(findPeer),\n provide: withTimeoutOption.withTimeoutOption(provide),\n query: withTimeoutOption.withTimeoutOption(query)\n };\n}\nconst use = async (network, options) => {\n const net = await network.use(options);\n if (get__default['default'](net.libp2p, '_config.dht.enabled', false)) {\n return net;\n } else {\n throw new errors.NotEnabledError('dht not enabled');\n }\n};\n\nexports.createDht = createDht;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar withTimeoutOption = require('ipfs-core-utils/with-timeout-option');\nvar errCode = require('err-code');\nvar errors = require('../errors.js');\nvar get = require('dlv');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar errCode__default = /*#__PURE__*/_interopDefaultLegacy(errCode);\nvar get__default = /*#__PURE__*/_interopDefaultLegacy(get);\n\nfunction createPubsub({network, config}) {\n const isEnabled = get__default['default'](config || {}, 'Pubsub.Enabled', true);\n return {\n subscribe: isEnabled ? withTimeoutOption.withTimeoutOption(subscribe) : notEnabled,\n unsubscribe: isEnabled ? withTimeoutOption.withTimeoutOption(unsubscribe) : notEnabled,\n publish: isEnabled ? withTimeoutOption.withTimeoutOption(publish) : notEnabled,\n ls: isEnabled ? withTimeoutOption.withTimeoutOption(ls) : notEnabled,\n peers: isEnabled ? withTimeoutOption.withTimeoutOption(peers) : notEnabled\n };\n async function subscribe(topic, handler, options = {}) {\n const {libp2p} = await network.use(options);\n return libp2p.pubsub.subscribe(topic, handler, options);\n }\n async function unsubscribe(topic, handler, options = {}) {\n const {libp2p} = await network.use(options);\n libp2p.pubsub.unsubscribe(topic, handler, options);\n }\n async function publish(topic, data, options = {}) {\n const {libp2p} = await network.use(options);\n if (!data) {\n throw errCode__default['default'](new Error('argument \"data\" is required'), 'ERR_ARG_REQUIRED');\n }\n await libp2p.pubsub.publish(topic, data);\n }\n async function ls(options = {}) {\n const {libp2p} = await network.use(options);\n return libp2p.pubsub.getTopics();\n }\n async function peers(topic, options = {}) {\n const {libp2p} = await network.use(options);\n return libp2p.pubsub.getSubscribers(topic);\n }\n}\nconst notEnabled = async () => {\n throw new errors.NotEnabledError('pubsub not enabled');\n};\n\nexports.createPubsub = createPubsub;\n","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Hls\"] = factory();\n\telse\n\t\troot[\"Hls\"] = factory();\n})(this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/dist/\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/hls.ts\");\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","// see https://tools.ietf.org/html/rfc1808\n\n(function (root) {\n var URL_REGEX = /^((?:[a-zA-Z0-9+\\-.]+:)?)(\\/\\/[^\\/?#]*)?((?:[^\\/?#]*\\/)*[^;?#]*)?(;[^?#]*)?(\\?[^#]*)?(#.*)?$/;\n var FIRST_SEGMENT_REGEX = /^([^\\/?#]*)(.*)$/;\n var SLASH_DOT_REGEX = /(?:\\/|^)\\.(?=\\/)/g;\n var SLASH_DOT_DOT_REGEX = /(?:\\/|^)\\.\\.\\/(?!\\.\\.\\/)[^\\/]*(?=\\/)/g;\n\n var URLToolkit = {\n // If opts.alwaysNormalize is true then the path will always be normalized even when it starts with / or //\n // E.g\n // With opts.alwaysNormalize = false (default, spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/f/../g\n // With opts.alwaysNormalize = true (not spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/g\n buildAbsoluteURL: function (baseURL, relativeURL, opts) {\n opts = opts || {};\n // remove any remaining space and CRLF\n baseURL = baseURL.trim();\n relativeURL = relativeURL.trim();\n if (!relativeURL) {\n // 2a) If the embedded URL is entirely empty, it inherits the\n // entire base URL (i.e., is set equal to the base URL)\n // and we are done.\n if (!opts.alwaysNormalize) {\n return baseURL;\n }\n var basePartsForNormalise = URLToolkit.parseURL(baseURL);\n if (!basePartsForNormalise) {\n throw new Error('Error trying to parse base URL.');\n }\n basePartsForNormalise.path = URLToolkit.normalizePath(\n basePartsForNormalise.path\n );\n return URLToolkit.buildURLFromParts(basePartsForNormalise);\n }\n var relativeParts = URLToolkit.parseURL(relativeURL);\n if (!relativeParts) {\n throw new Error('Error trying to parse relative URL.');\n }\n if (relativeParts.scheme) {\n // 2b) If the embedded URL starts with a scheme name, it is\n // interpreted as an absolute URL and we are done.\n if (!opts.alwaysNormalize) {\n return relativeURL;\n }\n relativeParts.path = URLToolkit.normalizePath(relativeParts.path);\n return URLToolkit.buildURLFromParts(relativeParts);\n }\n var baseParts = URLToolkit.parseURL(baseURL);\n if (!baseParts) {\n throw new Error('Error trying to parse base URL.');\n }\n if (!baseParts.netLoc && baseParts.path && baseParts.path[0] !== '/') {\n // If netLoc missing and path doesn't start with '/', assume everthing before the first '/' is the netLoc\n // This causes 'example.com/a' to be handled as '//example.com/a' instead of '/example.com/a'\n var pathParts = FIRST_SEGMENT_REGEX.exec(baseParts.path);\n baseParts.netLoc = pathParts[1];\n baseParts.path = pathParts[2];\n }\n if (baseParts.netLoc && !baseParts.path) {\n baseParts.path = '/';\n }\n var builtParts = {\n // 2c) Otherwise, the embedded URL inherits the scheme of\n // the base URL.\n scheme: baseParts.scheme,\n netLoc: relativeParts.netLoc,\n path: null,\n params: relativeParts.params,\n query: relativeParts.query,\n fragment: relativeParts.fragment,\n };\n if (!relativeParts.netLoc) {\n // 3) If the embedded URL's <net_loc> is non-empty, we skip to\n // Step 7. Otherwise, the embedded URL inherits the <net_loc>\n // (if any) of the base URL.\n builtParts.netLoc = baseParts.netLoc;\n // 4) If the embedded URL path is preceded by a slash \"/\", the\n // path is not relative and we skip to Step 7.\n if (relativeParts.path[0] !== '/') {\n if (!relativeParts.path) {\n // 5) If the embedded URL path is empty (and not preceded by a\n // slash), then the embedded URL inherits the base URL path\n builtParts.path = baseParts.path;\n // 5a) if the embedded URL's <params> is non-empty, we skip to\n // step 7; otherwise, it inherits the <params> of the base\n // URL (if any) and\n if (!relativeParts.params) {\n builtParts.params = baseParts.params;\n // 5b) if the embedded URL's <query> is non-empty, we skip to\n // step 7; otherwise, it inherits the <query> of the base\n // URL (if any) and we skip to step 7.\n if (!relativeParts.query) {\n builtParts.query = baseParts.query;\n }\n }\n } else {\n // 6) The last segment of the base URL's path (anything\n // following the rightmost slash \"/\", or the entire path if no\n // slash is present) is removed and the embedded URL's path is\n // appended in its place.\n var baseURLPath = baseParts.path;\n var newPath =\n baseURLPath.substring(0, baseURLPath.lastIndexOf('/') + 1) +\n relativeParts.path;\n builtParts.path = URLToolkit.normalizePath(newPath);\n }\n }\n }\n if (builtParts.path === null) {\n builtParts.path = opts.alwaysNormalize\n ? URLToolkit.normalizePath(relativeParts.path)\n : relativeParts.path;\n }\n return URLToolkit.buildURLFromParts(builtParts);\n },\n parseURL: function (url) {\n var parts = URL_REGEX.exec(url);\n if (!parts) {\n return null;\n }\n return {\n scheme: parts[1] || '',\n netLoc: parts[2] || '',\n path: parts[3] || '',\n params: parts[4] || '',\n query: parts[5] || '',\n fragment: parts[6] || '',\n };\n },\n normalizePath: function (path) {\n // The following operations are\n // then applied, in order, to the new path:\n // 6a) All occurrences of \"./\", where \".\" is a complete path\n // segment, are removed.\n // 6b) If the path ends with \".\" as a complete path segment,\n // that \".\" is removed.\n path = path.split('').reverse().join('').replace(SLASH_DOT_REGEX, '');\n // 6c) All occurrences of \"<segment>/../\", where <segment> is a\n // complete path segment not equal to \"..\", are removed.\n // Removal of these path segments is performed iteratively,\n // removing the leftmost matching pattern on each iteration,\n // until no matching pattern remains.\n // 6d) If the path ends with \"<segment>/..\", where <segment> is a\n // complete path segment not equal to \"..\", that\n // \"<segment>/..\" is removed.\n while (\n path.length !== (path = path.replace(SLASH_DOT_DOT_REGEX, '')).length\n ) {}\n return path.split('').reverse().join('');\n },\n buildURLFromParts: function (parts) {\n return (\n parts.scheme +\n parts.netLoc +\n parts.path +\n parts.params +\n parts.query +\n parts.fragment\n );\n },\n };\n\n if (typeof exports === 'object' && typeof module === 'object')\n module.exports = URLToolkit;\n else if (typeof define === 'function' && define.amd)\n define([], function () {\n return URLToolkit;\n });\n else if (typeof exports === 'object') exports['URLToolkit'] = URLToolkit;\n else root['URLToolkit'] = URLToolkit;\n})(this);\n","function webpackBootstrapFunc (modules) {\n/******/ // The module cache\n/******/ var installedModules = {};\n\n/******/ // The require function\n/******/ function __webpack_require__(moduleId) {\n\n/******/ // Check if module is in cache\n/******/ if(installedModules[moduleId])\n/******/ return installedModules[moduleId].exports;\n\n/******/ // Create a new module (and put it into the cache)\n/******/ var module = installedModules[moduleId] = {\n/******/ i: moduleId,\n/******/ l: false,\n/******/ exports: {}\n/******/ };\n\n/******/ // Execute the module function\n/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n/******/ // Flag the module as loaded\n/******/ module.l = true;\n\n/******/ // Return the exports of the module\n/******/ return module.exports;\n/******/ }\n\n/******/ // expose the modules object (__webpack_modules__)\n/******/ __webpack_require__.m = modules;\n\n/******/ // expose the module cache\n/******/ __webpack_require__.c = installedModules;\n\n/******/ // identity function for calling harmony imports with the correct context\n/******/ __webpack_require__.i = function(value) { return value; };\n\n/******/ // define getter function for harmony exports\n/******/ __webpack_require__.d = function(exports, name, getter) {\n/******/ if(!__webpack_require__.o(exports, name)) {\n/******/ Object.defineProperty(exports, name, {\n/******/ configurable: false,\n/******/ enumerable: true,\n/******/ get: getter\n/******/ });\n/******/ }\n/******/ };\n\n/******/ // define __esModule on exports\n/******/ __webpack_require__.r = function(exports) {\n/******/ Object.defineProperty(exports, '__esModule', { value: true });\n/******/ };\n\n/******/ // getDefaultExport function for compatibility with non-harmony modules\n/******/ __webpack_require__.n = function(module) {\n/******/ var getter = module && module.__esModule ?\n/******/ function getDefault() { return module['default']; } :\n/******/ function getModuleExports() { return module; };\n/******/ __webpack_require__.d(getter, 'a', getter);\n/******/ return getter;\n/******/ };\n\n/******/ // Object.prototype.hasOwnProperty.call\n/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n/******/ // __webpack_public_path__\n/******/ __webpack_require__.p = \"/\";\n\n/******/ // on error function for async loading\n/******/ __webpack_require__.oe = function(err) { console.error(err); throw err; };\n\n var f = __webpack_require__(__webpack_require__.s = ENTRY_MODULE)\n return f.default || f // try to call default if defined to also support babel esmodule exports\n}\n\nvar moduleNameReqExp = '[\\\\.|\\\\-|\\\\+|\\\\w|\\/|@]+'\nvar dependencyRegExp = '\\\\(\\\\s*(\\/\\\\*.*?\\\\*\\/)?\\\\s*.*?(' + moduleNameReqExp + ').*?\\\\)' // additional chars when output.pathinfo is true\n\n// http://stackoverflow.com/a/2593661/130442\nfunction quoteRegExp (str) {\n return (str + '').replace(/[.?*+^$[\\]\\\\(){}|-]/g, '\\\\$&')\n}\n\nfunction isNumeric(n) {\n return !isNaN(1 * n); // 1 * n converts integers, integers as string (\"123\"), 1e3 and \"1e3\" to integers and strings to NaN\n}\n\nfunction getModuleDependencies (sources, module, queueName) {\n var retval = {}\n retval[queueName] = []\n\n var fnString = module.toString()\n var wrapperSignature = fnString.match(/^function\\s?\\w*\\(\\w+,\\s*\\w+,\\s*(\\w+)\\)/)\n if (!wrapperSignature) return retval\n var webpackRequireName = wrapperSignature[1]\n\n // main bundle deps\n var re = new RegExp('(\\\\\\\\n|\\\\W)' + quoteRegExp(webpackRequireName) + dependencyRegExp, 'g')\n var match\n while ((match = re.exec(fnString))) {\n if (match[3] === 'dll-reference') continue\n retval[queueName].push(match[3])\n }\n\n // dll deps\n re = new RegExp('\\\\(' + quoteRegExp(webpackRequireName) + '\\\\(\"(dll-reference\\\\s(' + moduleNameReqExp + '))\"\\\\)\\\\)' + dependencyRegExp, 'g')\n while ((match = re.exec(fnString))) {\n if (!sources[match[2]]) {\n retval[queueName].push(match[1])\n sources[match[2]] = __webpack_require__(match[1]).m\n }\n retval[match[2]] = retval[match[2]] || []\n retval[match[2]].push(match[4])\n }\n\n // convert 1e3 back to 1000 - this can be important after uglify-js converted 1000 to 1e3\n var keys = Object.keys(retval);\n for (var i = 0; i < keys.length; i++) {\n for (var j = 0; j < retval[keys[i]].length; j++) {\n if (isNumeric(retval[keys[i]][j])) {\n retval[keys[i]][j] = 1 * retval[keys[i]][j];\n }\n }\n }\n\n return retval\n}\n\nfunction hasValuesInQueues (queues) {\n var keys = Object.keys(queues)\n return keys.reduce(function (hasValues, key) {\n return hasValues || queues[key].length > 0\n }, false)\n}\n\nfunction getRequiredModules (sources, moduleId) {\n var modulesQueue = {\n main: [moduleId]\n }\n var requiredModules = {\n main: []\n }\n var seenModules = {\n main: {}\n }\n\n while (hasValuesInQueues(modulesQueue)) {\n var queues = Object.keys(modulesQueue)\n for (var i = 0; i < queues.length; i++) {\n var queueName = queues[i]\n var queue = modulesQueue[queueName]\n var moduleToCheck = queue.pop()\n seenModules[queueName] = seenModules[queueName] || {}\n if (seenModules[queueName][moduleToCheck] || !sources[queueName][moduleToCheck]) continue\n seenModules[queueName][moduleToCheck] = true\n requiredModules[queueName] = requiredModules[queueName] || []\n requiredModules[queueName].push(moduleToCheck)\n var newModules = getModuleDependencies(sources, sources[queueName][moduleToCheck], queueName)\n var newModulesKeys = Object.keys(newModules)\n for (var j = 0; j < newModulesKeys.length; j++) {\n modulesQueue[newModulesKeys[j]] = modulesQueue[newModulesKeys[j]] || []\n modulesQueue[newModulesKeys[j]] = modulesQueue[newModulesKeys[j]].concat(newModules[newModulesKeys[j]])\n }\n }\n }\n\n return requiredModules\n}\n\nmodule.exports = function (moduleId, options) {\n options = options || {}\n var sources = {\n main: __webpack_modules__\n }\n\n var requiredModules = options.all ? { main: Object.keys(sources.main) } : getRequiredModules(sources, moduleId)\n\n var src = ''\n\n Object.keys(requiredModules).filter(function (m) { return m !== 'main' }).forEach(function (module) {\n var entryModule = 0\n while (requiredModules[module][entryModule]) {\n entryModule++\n }\n requiredModules[module].push(entryModule)\n sources[module][entryModule] = '(function(module, exports, __webpack_require__) { module.exports = __webpack_require__; })'\n src = src + 'var ' + module + ' = (' + webpackBootstrapFunc.toString().replace('ENTRY_MODULE', JSON.stringify(entryModule)) + ')({' + requiredModules[module].map(function (id) { return '' + JSON.stringify(id) + ': ' + sources[module][id].toString() }).join(',') + '});\\n'\n })\n\n src = src + 'new ((' + webpackBootstrapFunc.toString().replace('ENTRY_MODULE', JSON.stringify(moduleId)) + ')({' + requiredModules.main.map(function (id) { return '' + JSON.stringify(id) + ': ' + sources.main[id].toString() }).join(',') + '}))(self);'\n\n var blob = new window.Blob([src], { type: 'text/javascript' })\n if (options.bare) { return blob }\n\n var URL = window.URL || window.webkitURL || window.mozURL || window.msURL\n\n var workerUrl = URL.createObjectURL(blob)\n var worker = new window.Worker(workerUrl)\n worker.objectURL = workerUrl\n\n return worker\n}\n","export default class AESCrypto {\n constructor (subtle, iv) {\n this.subtle = subtle;\n this.aesIV = iv;\n }\n\n decrypt (data, key) {\n return this.subtle.decrypt({ name: 'AES-CBC', iv: this.aesIV }, key, data);\n }\n}\n","class FastAESKey {\n constructor (subtle, key) {\n this.subtle = subtle;\n this.key = key;\n }\n\n expandKey () {\n return this.subtle.importKey('raw', this.key, { name: 'AES-CBC' }, false, ['encrypt', 'decrypt']);\n }\n}\n\nexport default FastAESKey;\n","// PKCS7\nexport function removePadding (buffer) {\n const outputBytes = buffer.byteLength;\n const paddingBytes = outputBytes && (new DataView(buffer)).getUint8(outputBytes - 1);\n if (paddingBytes) {\n return buffer.slice(0, outputBytes - paddingBytes);\n } else {\n return buffer;\n }\n}\n\nclass AESDecryptor {\n constructor () {\n // Static after running initTable\n this.rcon = [0x0, 0x1, 0x2, 0x4, 0x8, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36];\n this.subMix = [new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256)];\n this.invSubMix = [new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256)];\n this.sBox = new Uint32Array(256);\n this.invSBox = new Uint32Array(256);\n\n // Changes during runtime\n this.key = new Uint32Array(0);\n\n this.initTable();\n }\n\n // Using view.getUint32() also swaps the byte order.\n uint8ArrayToUint32Array_ (arrayBuffer) {\n let view = new DataView(arrayBuffer);\n let newArray = new Uint32Array(4);\n for (let i = 0; i < 4; i++) {\n newArray[i] = view.getUint32(i * 4);\n }\n\n return newArray;\n }\n\n initTable () {\n let sBox = this.sBox;\n let invSBox = this.invSBox;\n let subMix = this.subMix;\n let subMix0 = subMix[0];\n let subMix1 = subMix[1];\n let subMix2 = subMix[2];\n let subMix3 = subMix[3];\n let invSubMix = this.invSubMix;\n let invSubMix0 = invSubMix[0];\n let invSubMix1 = invSubMix[1];\n let invSubMix2 = invSubMix[2];\n let invSubMix3 = invSubMix[3];\n\n let d = new Uint32Array(256);\n let x = 0;\n let xi = 0;\n let i = 0;\n for (i = 0; i < 256; i++) {\n if (i < 128) {\n d[i] = i << 1;\n } else {\n d[i] = (i << 1) ^ 0x11b;\n }\n }\n\n for (i = 0; i < 256; i++) {\n let sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4);\n sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63;\n sBox[x] = sx;\n invSBox[sx] = x;\n\n // Compute multiplication\n let x2 = d[x];\n let x4 = d[x2];\n let x8 = d[x4];\n\n // Compute sub/invSub bytes, mix columns tables\n let t = (d[sx] * 0x101) ^ (sx * 0x1010100);\n subMix0[x] = (t << 24) | (t >>> 8);\n subMix1[x] = (t << 16) | (t >>> 16);\n subMix2[x] = (t << 8) | (t >>> 24);\n subMix3[x] = t;\n\n // Compute inv sub bytes, inv mix columns tables\n t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100);\n invSubMix0[sx] = (t << 24) | (t >>> 8);\n invSubMix1[sx] = (t << 16) | (t >>> 16);\n invSubMix2[sx] = (t << 8) | (t >>> 24);\n invSubMix3[sx] = t;\n\n // Compute next counter\n if (!x) {\n x = xi = 1;\n } else {\n x = x2 ^ d[d[d[x8 ^ x2]]];\n xi ^= d[d[xi]];\n }\n }\n }\n\n expandKey (keyBuffer) {\n // convert keyBuffer to Uint32Array\n let key = this.uint8ArrayToUint32Array_(keyBuffer);\n let sameKey = true;\n let offset = 0;\n\n while (offset < key.length && sameKey) {\n sameKey = (key[offset] === this.key[offset]);\n offset++;\n }\n\n if (sameKey) {\n return;\n }\n\n this.key = key;\n let keySize = this.keySize = key.length;\n\n if (keySize !== 4 && keySize !== 6 && keySize !== 8) {\n throw new Error('Invalid aes key size=' + keySize);\n }\n\n let ksRows = this.ksRows = (keySize + 6 + 1) * 4;\n let ksRow;\n let invKsRow;\n\n let keySchedule = this.keySchedule = new Uint32Array(ksRows);\n let invKeySchedule = this.invKeySchedule = new Uint32Array(ksRows);\n let sbox = this.sBox;\n let rcon = this.rcon;\n\n let invSubMix = this.invSubMix;\n let invSubMix0 = invSubMix[0];\n let invSubMix1 = invSubMix[1];\n let invSubMix2 = invSubMix[2];\n let invSubMix3 = invSubMix[3];\n\n let prev;\n let t;\n\n for (ksRow = 0; ksRow < ksRows; ksRow++) {\n if (ksRow < keySize) {\n prev = keySchedule[ksRow] = key[ksRow];\n continue;\n }\n t = prev;\n\n if (ksRow % keySize === 0) {\n // Rot word\n t = (t << 8) | (t >>> 24);\n\n // Sub word\n t = (sbox[t >>> 24] << 24) | (sbox[(t >>> 16) & 0xff] << 16) | (sbox[(t >>> 8) & 0xff] << 8) | sbox[t & 0xff];\n\n // Mix Rcon\n t ^= rcon[(ksRow / keySize) | 0] << 24;\n } else if (keySize > 6 && ksRow % keySize === 4) {\n // Sub word\n t = (sbox[t >>> 24] << 24) | (sbox[(t >>> 16) & 0xff] << 16) | (sbox[(t >>> 8) & 0xff] << 8) | sbox[t & 0xff];\n }\n\n keySchedule[ksRow] = prev = (keySchedule[ksRow - keySize] ^ t) >>> 0;\n }\n\n for (invKsRow = 0; invKsRow < ksRows; invKsRow++) {\n ksRow = ksRows - invKsRow;\n if (invKsRow & 3) {\n t = keySchedule[ksRow];\n } else {\n t = keySchedule[ksRow - 4];\n }\n\n if (invKsRow < 4 || ksRow <= 4) {\n invKeySchedule[invKsRow] = t;\n } else {\n invKeySchedule[invKsRow] = invSubMix0[sbox[t >>> 24]] ^ invSubMix1[sbox[(t >>> 16) & 0xff]] ^ invSubMix2[sbox[(t >>> 8) & 0xff]] ^ invSubMix3[sbox[t & 0xff]];\n }\n\n invKeySchedule[invKsRow] = invKeySchedule[invKsRow] >>> 0;\n }\n }\n\n // Adding this as a method greatly improves performance.\n networkToHostOrderSwap (word) {\n return (word << 24) | ((word & 0xff00) << 8) | ((word & 0xff0000) >> 8) | (word >>> 24);\n }\n\n decrypt (inputArrayBuffer, offset, aesIV, removePKCS7Padding) {\n let nRounds = this.keySize + 6;\n let invKeySchedule = this.invKeySchedule;\n let invSBOX = this.invSBox;\n\n let invSubMix = this.invSubMix;\n let invSubMix0 = invSubMix[0];\n let invSubMix1 = invSubMix[1];\n let invSubMix2 = invSubMix[2];\n let invSubMix3 = invSubMix[3];\n\n let initVector = this.uint8ArrayToUint32Array_(aesIV);\n let initVector0 = initVector[0];\n let initVector1 = initVector[1];\n let initVector2 = initVector[2];\n let initVector3 = initVector[3];\n\n let inputInt32 = new Int32Array(inputArrayBuffer);\n let outputInt32 = new Int32Array(inputInt32.length);\n\n let t0, t1, t2, t3;\n let s0, s1, s2, s3;\n let inputWords0, inputWords1, inputWords2, inputWords3;\n\n let ksRow, i;\n let swapWord = this.networkToHostOrderSwap;\n\n while (offset < inputInt32.length) {\n inputWords0 = swapWord(inputInt32[offset]);\n inputWords1 = swapWord(inputInt32[offset + 1]);\n inputWords2 = swapWord(inputInt32[offset + 2]);\n inputWords3 = swapWord(inputInt32[offset + 3]);\n\n s0 = inputWords0 ^ invKeySchedule[0];\n s1 = inputWords3 ^ invKeySchedule[1];\n s2 = inputWords2 ^ invKeySchedule[2];\n s3 = inputWords1 ^ invKeySchedule[3];\n\n ksRow = 4;\n\n // Iterate through the rounds of decryption\n for (i = 1; i < nRounds; i++) {\n t0 = invSubMix0[s0 >>> 24] ^ invSubMix1[(s1 >> 16) & 0xff] ^ invSubMix2[(s2 >> 8) & 0xff] ^ invSubMix3[s3 & 0xff] ^ invKeySchedule[ksRow];\n t1 = invSubMix0[s1 >>> 24] ^ invSubMix1[(s2 >> 16) & 0xff] ^ invSubMix2[(s3 >> 8) & 0xff] ^ invSubMix3[s0 & 0xff] ^ invKeySchedule[ksRow + 1];\n t2 = invSubMix0[s2 >>> 24] ^ invSubMix1[(s3 >> 16) & 0xff] ^ invSubMix2[(s0 >> 8) & 0xff] ^ invSubMix3[s1 & 0xff] ^ invKeySchedule[ksRow + 2];\n t3 = invSubMix0[s3 >>> 24] ^ invSubMix1[(s0 >> 16) & 0xff] ^ invSubMix2[(s1 >> 8) & 0xff] ^ invSubMix3[s2 & 0xff] ^ invKeySchedule[ksRow + 3];\n // Update state\n s0 = t0;\n s1 = t1;\n s2 = t2;\n s3 = t3;\n\n ksRow = ksRow + 4;\n }\n\n // Shift rows, sub bytes, add round key\n t0 = ((invSBOX[s0 >>> 24] << 24) ^ (invSBOX[(s1 >> 16) & 0xff] << 16) ^ (invSBOX[(s2 >> 8) & 0xff] << 8) ^ invSBOX[s3 & 0xff]) ^ invKeySchedule[ksRow];\n t1 = ((invSBOX[s1 >>> 24] << 24) ^ (invSBOX[(s2 >> 16) & 0xff] << 16) ^ (invSBOX[(s3 >> 8) & 0xff] << 8) ^ invSBOX[s0 & 0xff]) ^ invKeySchedule[ksRow + 1];\n t2 = ((invSBOX[s2 >>> 24] << 24) ^ (invSBOX[(s3 >> 16) & 0xff] << 16) ^ (invSBOX[(s0 >> 8) & 0xff] << 8) ^ invSBOX[s1 & 0xff]) ^ invKeySchedule[ksRow + 2];\n t3 = ((invSBOX[s3 >>> 24] << 24) ^ (invSBOX[(s0 >> 16) & 0xff] << 16) ^ (invSBOX[(s1 >> 8) & 0xff] << 8) ^ invSBOX[s2 & 0xff]) ^ invKeySchedule[ksRow + 3];\n ksRow = ksRow + 3;\n\n // Write\n outputInt32[offset] = swapWord(t0 ^ initVector0);\n outputInt32[offset + 1] = swapWord(t3 ^ initVector1);\n outputInt32[offset + 2] = swapWord(t2 ^ initVector2);\n outputInt32[offset + 3] = swapWord(t1 ^ initVector3);\n\n // reset initVector to last 4 unsigned int\n initVector0 = inputWords0;\n initVector1 = inputWords1;\n initVector2 = inputWords2;\n initVector3 = inputWords3;\n\n offset = offset + 4;\n }\n\n return removePKCS7Padding ? removePadding(outputInt32.buffer) : outputInt32.buffer;\n }\n\n destroy () {\n this.key = undefined;\n this.keySize = undefined;\n this.ksRows = undefined;\n\n this.sBox = undefined;\n this.invSBox = undefined;\n this.subMix = undefined;\n this.invSubMix = undefined;\n this.keySchedule = undefined;\n this.invKeySchedule = undefined;\n\n this.rcon = undefined;\n }\n}\n\nexport default AESDecryptor;\n","import AESCrypto from './aes-crypto';\nimport FastAESKey from './fast-aes-key';\nimport AESDecryptor from './aes-decryptor';\n\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\n\nimport Event from '../events';\n\nimport { getSelfScope } from '../utils/get-self-scope';\n\n// see https://stackoverflow.com/a/11237259/589493\nconst global = getSelfScope(); // safeguard for code that might run both on worker and main thread\n\nclass Decrypter {\n constructor (observer, config, { removePKCS7Padding = true } = {}) {\n this.logEnabled = true;\n this.observer = observer;\n this.config = config;\n this.removePKCS7Padding = removePKCS7Padding;\n // built in decryptor expects PKCS7 padding\n if (removePKCS7Padding) {\n try {\n const browserCrypto = global.crypto;\n if (browserCrypto) {\n this.subtle = browserCrypto.subtle || browserCrypto.webkitSubtle;\n }\n } catch (e) {}\n }\n this.disableWebCrypto = !this.subtle;\n }\n\n isSync () {\n return (this.disableWebCrypto && this.config.enableSoftwareAES);\n }\n\n decrypt (data, key, iv, callback) {\n if (this.disableWebCrypto && this.config.enableSoftwareAES) {\n if (this.logEnabled) {\n logger.log('JS AES decrypt');\n this.logEnabled = false;\n }\n let decryptor = this.decryptor;\n if (!decryptor) {\n this.decryptor = decryptor = new AESDecryptor();\n }\n\n decryptor.expandKey(key);\n callback(decryptor.decrypt(data, 0, iv, this.removePKCS7Padding));\n } else {\n if (this.logEnabled) {\n logger.log('WebCrypto AES decrypt');\n this.logEnabled = false;\n }\n const subtle = this.subtle;\n if (this.key !== key) {\n this.key = key;\n this.fastAesKey = new FastAESKey(subtle, key);\n }\n\n this.fastAesKey.expandKey()\n .then((aesKey) => {\n // decrypt using web crypto\n let crypto = new AESCrypto(subtle, iv);\n crypto.decrypt(data, aesKey)\n .catch((err) => {\n this.onWebCryptoError(err, data, key, iv, callback);\n })\n .then((result) => {\n callback(result);\n });\n })\n .catch((err) => {\n this.onWebCryptoError(err, data, key, iv, callback);\n });\n }\n }\n\n onWebCryptoError (err, data, key, iv, callback) {\n if (this.config.enableSoftwareAES) {\n logger.log('WebCrypto Error, disable WebCrypto API');\n this.disableWebCrypto = true;\n this.logEnabled = true;\n this.decrypt(data, key, iv, callback);\n } else {\n logger.error(`decrypting error : ${err.message}`);\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_DECRYPT_ERROR, fatal: true, reason: err.message });\n }\n }\n\n destroy () {\n let decryptor = this.decryptor;\n if (decryptor) {\n decryptor.destroy();\n this.decryptor = undefined;\n }\n }\n}\n\nexport default Decrypter;\n","/**\n * ADTS parser helper\n * @link https://wiki.multimedia.cx/index.php?title=ADTS\n */\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\n\nimport Event from '../events';\n\nimport { getSelfScope } from '../utils/get-self-scope';\n\nexport function getAudioConfig (observer, data, offset, audioCodec) {\n let adtsObjectType, // :int\n adtsSampleingIndex, // :int\n adtsExtensionSampleingIndex, // :int\n adtsChanelConfig, // :int\n config,\n userAgent = navigator.userAgent.toLowerCase(),\n manifestCodec = audioCodec,\n adtsSampleingRates = [\n 96000, 88200,\n 64000, 48000,\n 44100, 32000,\n 24000, 22050,\n 16000, 12000,\n 11025, 8000,\n 7350];\n // byte 2\n adtsObjectType = ((data[offset + 2] & 0xC0) >>> 6) + 1;\n adtsSampleingIndex = ((data[offset + 2] & 0x3C) >>> 2);\n if (adtsSampleingIndex > adtsSampleingRates.length - 1) {\n observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: true, reason: `invalid ADTS sampling index:${adtsSampleingIndex}` });\n return;\n }\n adtsChanelConfig = ((data[offset + 2] & 0x01) << 2);\n // byte 3\n adtsChanelConfig |= ((data[offset + 3] & 0xC0) >>> 6);\n logger.log(`manifest codec:${audioCodec},ADTS data:type:${adtsObjectType},sampleingIndex:${adtsSampleingIndex}[${adtsSampleingRates[adtsSampleingIndex]}Hz],channelConfig:${adtsChanelConfig}`);\n // firefox: freq less than 24kHz = AAC SBR (HE-AAC)\n if (/firefox/i.test(userAgent)) {\n if (adtsSampleingIndex >= 6) {\n adtsObjectType = 5;\n config = new Array(4);\n // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n // there is a factor 2 between frame sample rate and output sample rate\n // multiply frequency by 2 (see table below, equivalent to substract 3)\n adtsExtensionSampleingIndex = adtsSampleingIndex - 3;\n } else {\n adtsObjectType = 2;\n config = new Array(2);\n adtsExtensionSampleingIndex = adtsSampleingIndex;\n }\n // Android : always use AAC\n } else if (userAgent.indexOf('android') !== -1) {\n adtsObjectType = 2;\n config = new Array(2);\n adtsExtensionSampleingIndex = adtsSampleingIndex;\n } else {\n /* for other browsers (Chrome/Vivaldi/Opera ...)\n always force audio type to be HE-AAC SBR, as some browsers do not support audio codec switch properly (like Chrome ...)\n */\n adtsObjectType = 5;\n config = new Array(4);\n // if (manifest codec is HE-AAC or HE-AACv2) OR (manifest codec not specified AND frequency less than 24kHz)\n if ((audioCodec && ((audioCodec.indexOf('mp4a.40.29') !== -1) ||\n (audioCodec.indexOf('mp4a.40.5') !== -1))) ||\n (!audioCodec && adtsSampleingIndex >= 6)) {\n // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n // there is a factor 2 between frame sample rate and output sample rate\n // multiply frequency by 2 (see table below, equivalent to substract 3)\n adtsExtensionSampleingIndex = adtsSampleingIndex - 3;\n } else {\n // if (manifest codec is AAC) AND (frequency less than 24kHz AND nb channel is 1) OR (manifest codec not specified and mono audio)\n // Chrome fails to play back with low frequency AAC LC mono when initialized with HE-AAC. This is not a problem with stereo.\n if (audioCodec && audioCodec.indexOf('mp4a.40.2') !== -1 && ((adtsSampleingIndex >= 6 && adtsChanelConfig === 1) ||\n /vivaldi/i.test(userAgent)) ||\n (!audioCodec && adtsChanelConfig === 1)) {\n adtsObjectType = 2;\n config = new Array(2);\n }\n adtsExtensionSampleingIndex = adtsSampleingIndex;\n }\n }\n /* refer to http://wiki.multimedia.cx/index.php?title=MPEG-4_Audio#Audio_Specific_Config\n ISO 14496-3 (AAC).pdf - Table 1.13 — Syntax of AudioSpecificConfig()\n Audio Profile / Audio Object Type\n 0: Null\n 1: AAC Main\n 2: AAC LC (Low Complexity)\n 3: AAC SSR (Scalable Sample Rate)\n 4: AAC LTP (Long Term Prediction)\n 5: SBR (Spectral Band Replication)\n 6: AAC Scalable\n sampling freq\n 0: 96000 Hz\n 1: 88200 Hz\n 2: 64000 Hz\n 3: 48000 Hz\n 4: 44100 Hz\n 5: 32000 Hz\n 6: 24000 Hz\n 7: 22050 Hz\n 8: 16000 Hz\n 9: 12000 Hz\n 10: 11025 Hz\n 11: 8000 Hz\n 12: 7350 Hz\n 13: Reserved\n 14: Reserved\n 15: frequency is written explictly\n Channel Configurations\n These are the channel configurations:\n 0: Defined in AOT Specifc Config\n 1: 1 channel: front-center\n 2: 2 channels: front-left, front-right\n */\n // audioObjectType = profile => profile, the MPEG-4 Audio Object Type minus 1\n config[0] = adtsObjectType << 3;\n // samplingFrequencyIndex\n config[0] |= (adtsSampleingIndex & 0x0E) >> 1;\n config[1] |= (adtsSampleingIndex & 0x01) << 7;\n // channelConfiguration\n config[1] |= adtsChanelConfig << 3;\n if (adtsObjectType === 5) {\n // adtsExtensionSampleingIndex\n config[1] |= (adtsExtensionSampleingIndex & 0x0E) >> 1;\n config[2] = (adtsExtensionSampleingIndex & 0x01) << 7;\n // adtsObjectType (force to 2, chrome is checking that object type is less than 5 ???\n // https://chromium.googlesource.com/chromium/src.git/+/master/media/formats/mp4/aac.cc\n config[2] |= 2 << 2;\n config[3] = 0;\n }\n return { config: config, samplerate: adtsSampleingRates[adtsSampleingIndex], channelCount: adtsChanelConfig, codec: ('mp4a.40.' + adtsObjectType), manifestCodec: manifestCodec };\n}\n\nexport function isHeaderPattern (data, offset) {\n return data[offset] === 0xff && (data[offset + 1] & 0xf6) === 0xf0;\n}\n\nexport function getHeaderLength (data, offset) {\n return (data[offset + 1] & 0x01 ? 7 : 9);\n}\n\nexport function getFullFrameLength (data, offset) {\n return ((data[offset + 3] & 0x03) << 11) |\n (data[offset + 4] << 3) |\n ((data[offset + 5] & 0xE0) >>> 5);\n}\n\nexport function isHeader (data, offset) {\n // Look for ADTS header | 1111 1111 | 1111 X00X | where X can be either 0 or 1\n // Layer bits (position 14 and 15) in header should be always 0 for ADTS\n // More info https://wiki.multimedia.cx/index.php?title=ADTS\n if (offset + 1 < data.length && isHeaderPattern(data, offset)) {\n return true;\n }\n\n return false;\n}\n\nexport function probe (data, offset) {\n // same as isHeader but we also check that ADTS frame follows last ADTS frame\n // or end of data is reached\n if (isHeader(data, offset)) {\n // ADTS header Length\n let headerLength = getHeaderLength(data, offset);\n if (offset + headerLength >= data.length) {\n return false;\n }\n // ADTS frame Length\n let frameLength = getFullFrameLength(data, offset);\n if (frameLength <= headerLength) {\n return false;\n }\n\n let newOffset = offset + frameLength;\n if (newOffset === data.length || (newOffset + 1 < data.length && isHeaderPattern(data, newOffset))) {\n return true;\n }\n }\n return false;\n}\n\nexport function initTrackConfig (track, observer, data, offset, audioCodec) {\n if (!track.samplerate) {\n let config = getAudioConfig(observer, data, offset, audioCodec);\n track.config = config.config;\n track.samplerate = config.samplerate;\n track.channelCount = config.channelCount;\n track.codec = config.codec;\n track.manifestCodec = config.manifestCodec;\n logger.log(`parsed codec:${track.codec},rate:${config.samplerate},nb channel:${config.channelCount}`);\n }\n}\n\nexport function getFrameDuration (samplerate) {\n return 1024 * 90000 / samplerate;\n}\n\nexport function parseFrameHeader (data, offset, pts, frameIndex, frameDuration) {\n let headerLength, frameLength, stamp;\n let length = data.length;\n\n // The protection skip bit tells us if we have 2 bytes of CRC data at the end of the ADTS header\n headerLength = getHeaderLength(data, offset);\n // retrieve frame size\n frameLength = getFullFrameLength(data, offset);\n frameLength -= headerLength;\n\n if ((frameLength > 0) && ((offset + headerLength + frameLength) <= length)) {\n stamp = pts + frameIndex * frameDuration;\n // logger.log(`AAC frame, offset/length/total/pts:${offset+headerLength}/${frameLength}/${data.byteLength}/${(stamp/90).toFixed(0)}`);\n return { headerLength, frameLength, stamp };\n }\n\n return undefined;\n}\n\nexport function appendFrame (track, data, offset, pts, frameIndex) {\n let frameDuration = getFrameDuration(track.samplerate);\n let header = parseFrameHeader(data, offset, pts, frameIndex, frameDuration);\n if (header) {\n let stamp = header.stamp;\n let headerLength = header.headerLength;\n let frameLength = header.frameLength;\n\n // logger.log(`AAC frame, offset/length/total/pts:${offset+headerLength}/${frameLength}/${data.byteLength}/${(stamp/90).toFixed(0)}`);\n let aacSample = {\n unit: data.subarray(offset + headerLength, offset + headerLength + frameLength),\n pts: stamp,\n dts: stamp\n };\n\n track.samples.push(aacSample);\n return { sample: aacSample, length: frameLength + headerLength };\n }\n\n return undefined;\n}\n","/**\n * AAC demuxer\n */\nimport * as ADTS from './adts';\nimport { logger } from '../utils/logger';\nimport ID3 from '../demux/id3';\n\nclass AACDemuxer {\n constructor (observer, remuxer, config) {\n this.observer = observer;\n this.config = config;\n this.remuxer = remuxer;\n }\n\n resetInitSegment (initSegment, audioCodec, videoCodec, duration) {\n this._audioTrack = { container: 'audio/adts', type: 'audio', id: 0, sequenceNumber: 0, isAAC: true, samples: [], len: 0, manifestCodec: audioCodec, duration: duration, inputTimeScale: 90000 };\n }\n\n resetTimeStamp () {\n }\n\n static probe (data) {\n if (!data) {\n return false;\n }\n\n // Check for the ADTS sync word\n // Look for ADTS header | 1111 1111 | 1111 X00X | where X can be either 0 or 1\n // Layer bits (position 14 and 15) in header should be always 0 for ADTS\n // More info https://wiki.multimedia.cx/index.php?title=ADTS\n const id3Data = ID3.getID3Data(data, 0) || [];\n let offset = id3Data.length;\n\n for (let length = data.length; offset < length; offset++) {\n if (ADTS.probe(data, offset)) {\n logger.log('ADTS sync word found !');\n return true;\n }\n }\n return false;\n }\n\n // feed incoming data to the front of the parsing pipeline\n append (data, timeOffset, contiguous, accurateTimeOffset) {\n let track = this._audioTrack;\n let id3Data = ID3.getID3Data(data, 0) || [];\n let timestamp = ID3.getTimeStamp(id3Data);\n let pts = Number.isFinite(timestamp) ? timestamp * 90 : timeOffset * 90000;\n let frameIndex = 0;\n let stamp = pts;\n let length = data.length;\n let offset = id3Data.length;\n\n let id3Samples = [{ pts: stamp, dts: stamp, data: id3Data }];\n\n while (offset < length - 1) {\n if (ADTS.isHeader(data, offset) && (offset + 5) < length) {\n ADTS.initTrackConfig(track, this.observer, data, offset, track.manifestCodec);\n let frame = ADTS.appendFrame(track, data, offset, pts, frameIndex);\n if (frame) {\n offset += frame.length;\n stamp = frame.sample.pts;\n frameIndex++;\n } else {\n logger.log('Unable to parse AAC frame');\n break;\n }\n } else if (ID3.isHeader(data, offset)) {\n id3Data = ID3.getID3Data(data, offset);\n id3Samples.push({ pts: stamp, dts: stamp, data: id3Data });\n offset += id3Data.length;\n } else {\n // nothing found, keep looking\n offset++;\n }\n }\n\n this.remuxer.remux(track,\n { samples: [] },\n { samples: id3Samples, inputTimeScale: 90000 },\n { samples: [] },\n timeOffset,\n contiguous,\n accurateTimeOffset);\n }\n\n destroy () {\n }\n}\n\nexport default AACDemuxer;\n","/**\n * MPEG parser helper\n */\n\nconst MpegAudio = {\n\n BitratesMap: [\n 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448,\n 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384,\n 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320,\n 32, 48, 56, 64, 80, 96, 112, 128, 144, 160, 176, 192, 224, 256,\n 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160],\n\n SamplingRateMap: [44100, 48000, 32000, 22050, 24000, 16000, 11025, 12000, 8000],\n\n SamplesCoefficients: [\n // MPEG 2.5\n [\n 0, // Reserved\n 72, // Layer3\n 144, // Layer2\n 12 // Layer1\n ],\n // Reserved\n [\n 0, // Reserved\n 0, // Layer3\n 0, // Layer2\n 0 // Layer1\n ],\n // MPEG 2\n [\n 0, // Reserved\n 72, // Layer3\n 144, // Layer2\n 12 // Layer1\n ],\n // MPEG 1\n [\n 0, // Reserved\n 144, // Layer3\n 144, // Layer2\n 12 // Layer1\n ]\n ],\n\n BytesInSlot: [\n 0, // Reserved\n 1, // Layer3\n 1, // Layer2\n 4 // Layer1\n ],\n\n appendFrame: function (track, data, offset, pts, frameIndex) {\n // Using http://www.datavoyage.com/mpgscript/mpeghdr.htm as a reference\n if (offset + 24 > data.length) {\n return undefined;\n }\n\n let header = this.parseHeader(data, offset);\n if (header && offset + header.frameLength <= data.length) {\n let frameDuration = header.samplesPerFrame * 90000 / header.sampleRate;\n let stamp = pts + frameIndex * frameDuration;\n let sample = { unit: data.subarray(offset, offset + header.frameLength), pts: stamp, dts: stamp };\n\n track.config = [];\n track.channelCount = header.channelCount;\n track.samplerate = header.sampleRate;\n track.samples.push(sample);\n\n return { sample, length: header.frameLength };\n }\n\n return undefined;\n },\n\n parseHeader: function (data, offset) {\n let headerB = (data[offset + 1] >> 3) & 3;\n let headerC = (data[offset + 1] >> 1) & 3;\n let headerE = (data[offset + 2] >> 4) & 15;\n let headerF = (data[offset + 2] >> 2) & 3;\n let headerG = (data[offset + 2] >> 1) & 1;\n if (headerB !== 1 && headerE !== 0 && headerE !== 15 && headerF !== 3) {\n let columnInBitrates = headerB === 3 ? (3 - headerC) : (headerC === 3 ? 3 : 4);\n let bitRate = MpegAudio.BitratesMap[columnInBitrates * 14 + headerE - 1] * 1000;\n let columnInSampleRates = headerB === 3 ? 0 : headerB === 2 ? 1 : 2;\n let sampleRate = MpegAudio.SamplingRateMap[columnInSampleRates * 3 + headerF];\n let channelCount = data[offset + 3] >> 6 === 3 ? 1 : 2; // If bits of channel mode are `11` then it is a single channel (Mono)\n let sampleCoefficient = MpegAudio.SamplesCoefficients[headerB][headerC];\n let bytesInSlot = MpegAudio.BytesInSlot[headerC];\n let samplesPerFrame = sampleCoefficient * 8 * bytesInSlot;\n let frameLength = parseInt(sampleCoefficient * bitRate / sampleRate + headerG, 10) * bytesInSlot;\n\n return { sampleRate, channelCount, frameLength, samplesPerFrame };\n }\n\n return undefined;\n },\n\n isHeaderPattern: function (data, offset) {\n return data[offset] === 0xff && (data[offset + 1] & 0xe0) === 0xe0 && (data[offset + 1] & 0x06) !== 0x00;\n },\n\n isHeader: function (data, offset) {\n // Look for MPEG header | 1111 1111 | 111X XYZX | where X can be either 0 or 1 and Y or Z should be 1\n // Layer bits (position 14 and 15) in header should be always different from 0 (Layer I or Layer II or Layer III)\n // More info http://www.mp3-tech.org/programmer/frame_header.html\n if (offset + 1 < data.length && this.isHeaderPattern(data, offset)) {\n return true;\n }\n\n return false;\n },\n\n probe: function (data, offset) {\n // same as isHeader but we also check that MPEG frame follows last MPEG frame\n // or end of data is reached\n if (offset + 1 < data.length && this.isHeaderPattern(data, offset)) {\n // MPEG header Length\n let headerLength = 4;\n // MPEG frame Length\n let header = this.parseHeader(data, offset);\n let frameLength = headerLength;\n if (header && header.frameLength) {\n frameLength = header.frameLength;\n }\n\n let newOffset = offset + frameLength;\n if (newOffset === data.length || (newOffset + 1 < data.length && this.isHeaderPattern(data, newOffset))) {\n return true;\n }\n }\n return false;\n }\n};\n\nexport default MpegAudio;\n","/**\n * Parser for exponential Golomb codes, a variable-bitwidth number encoding scheme used by h264.\n*/\n\nimport { logger } from '../utils/logger';\n\nclass ExpGolomb {\n constructor (data) {\n this.data = data;\n // the number of bytes left to examine in this.data\n this.bytesAvailable = data.byteLength;\n // the current word being examined\n this.word = 0; // :uint\n // the number of bits left to examine in the current word\n this.bitsAvailable = 0; // :uint\n }\n\n // ():void\n loadWord () {\n let\n data = this.data,\n bytesAvailable = this.bytesAvailable,\n position = data.byteLength - bytesAvailable,\n workingBytes = new Uint8Array(4),\n availableBytes = Math.min(4, bytesAvailable);\n if (availableBytes === 0) {\n throw new Error('no bytes available');\n }\n\n workingBytes.set(data.subarray(position, position + availableBytes));\n this.word = new DataView(workingBytes.buffer).getUint32(0);\n // track the amount of this.data that has been processed\n this.bitsAvailable = availableBytes * 8;\n this.bytesAvailable -= availableBytes;\n }\n\n // (count:int):void\n skipBits (count) {\n let skipBytes; // :int\n if (this.bitsAvailable > count) {\n this.word <<= count;\n this.bitsAvailable -= count;\n } else {\n count -= this.bitsAvailable;\n skipBytes = count >> 3;\n count -= (skipBytes >> 3);\n this.bytesAvailable -= skipBytes;\n this.loadWord();\n this.word <<= count;\n this.bitsAvailable -= count;\n }\n }\n\n // (size:int):uint\n readBits (size) {\n let\n bits = Math.min(this.bitsAvailable, size), // :uint\n valu = this.word >>> (32 - bits); // :uint\n if (size > 32) {\n logger.error('Cannot read more than 32 bits at a time');\n }\n\n this.bitsAvailable -= bits;\n if (this.bitsAvailable > 0) {\n this.word <<= bits;\n } else if (this.bytesAvailable > 0) {\n this.loadWord();\n }\n\n bits = size - bits;\n if (bits > 0 && this.bitsAvailable) {\n return valu << bits | this.readBits(bits);\n } else {\n return valu;\n }\n }\n\n // ():uint\n skipLZ () {\n let leadingZeroCount; // :uint\n for (leadingZeroCount = 0; leadingZeroCount < this.bitsAvailable; ++leadingZeroCount) {\n if ((this.word & (0x80000000 >>> leadingZeroCount)) !== 0) {\n // the first bit of working word is 1\n this.word <<= leadingZeroCount;\n this.bitsAvailable -= leadingZeroCount;\n return leadingZeroCount;\n }\n }\n // we exhausted word and still have not found a 1\n this.loadWord();\n return leadingZeroCount + this.skipLZ();\n }\n\n // ():void\n skipUEG () {\n this.skipBits(1 + this.skipLZ());\n }\n\n // ():void\n skipEG () {\n this.skipBits(1 + this.skipLZ());\n }\n\n // ():uint\n readUEG () {\n let clz = this.skipLZ(); // :uint\n return this.readBits(clz + 1) - 1;\n }\n\n // ():int\n readEG () {\n let valu = this.readUEG(); // :int\n if (0x01 & valu) {\n // the number is odd if the low order bit is set\n return (1 + valu) >>> 1; // add 1 to make it even, and divide by 2\n } else {\n return -1 * (valu >>> 1); // divide by two then make it negative\n }\n }\n\n // Some convenience functions\n // :Boolean\n readBoolean () {\n return this.readBits(1) === 1;\n }\n\n // ():int\n readUByte () {\n return this.readBits(8);\n }\n\n // ():int\n readUShort () {\n return this.readBits(16);\n }\n // ():int\n readUInt () {\n return this.readBits(32);\n }\n\n /**\n * Advance the ExpGolomb decoder past a scaling list. The scaling\n * list is optionally transmitted as part of a sequence parameter\n * set and is not relevant to transmuxing.\n * @param count {number} the number of entries in this scaling list\n * @see Recommendation ITU-T H.264, Section 7.3.2.1.1.1\n */\n skipScalingList (count) {\n let\n lastScale = 8,\n nextScale = 8,\n j,\n deltaScale;\n for (j = 0; j < count; j++) {\n if (nextScale !== 0) {\n deltaScale = this.readEG();\n nextScale = (lastScale + deltaScale + 256) % 256;\n }\n lastScale = (nextScale === 0) ? lastScale : nextScale;\n }\n }\n\n /**\n * Read a sequence parameter set and return some interesting video\n * properties. A sequence parameter set is the H264 metadata that\n * describes the properties of upcoming video frames.\n * @param data {Uint8Array} the bytes of a sequence parameter set\n * @return {object} an object with configuration parsed from the\n * sequence parameter set, including the dimensions of the\n * associated video frames.\n */\n readSPS () {\n let\n frameCropLeftOffset = 0,\n frameCropRightOffset = 0,\n frameCropTopOffset = 0,\n frameCropBottomOffset = 0,\n profileIdc, profileCompat, levelIdc,\n numRefFramesInPicOrderCntCycle, picWidthInMbsMinus1,\n picHeightInMapUnitsMinus1,\n frameMbsOnlyFlag,\n scalingListCount,\n i,\n readUByte = this.readUByte.bind(this),\n readBits = this.readBits.bind(this),\n readUEG = this.readUEG.bind(this),\n readBoolean = this.readBoolean.bind(this),\n skipBits = this.skipBits.bind(this),\n skipEG = this.skipEG.bind(this),\n skipUEG = this.skipUEG.bind(this),\n skipScalingList = this.skipScalingList.bind(this);\n\n readUByte();\n profileIdc = readUByte(); // profile_idc\n profileCompat = readBits(5); // constraint_set[0-4]_flag, u(5)\n skipBits(3); // reserved_zero_3bits u(3),\n levelIdc = readUByte(); // level_idc u(8)\n skipUEG(); // seq_parameter_set_id\n // some profiles have more optional data we don't need\n if (profileIdc === 100 ||\n profileIdc === 110 ||\n profileIdc === 122 ||\n profileIdc === 244 ||\n profileIdc === 44 ||\n profileIdc === 83 ||\n profileIdc === 86 ||\n profileIdc === 118 ||\n profileIdc === 128) {\n let chromaFormatIdc = readUEG();\n if (chromaFormatIdc === 3) {\n skipBits(1);\n } // separate_colour_plane_flag\n\n skipUEG(); // bit_depth_luma_minus8\n skipUEG(); // bit_depth_chroma_minus8\n skipBits(1); // qpprime_y_zero_transform_bypass_flag\n if (readBoolean()) { // seq_scaling_matrix_present_flag\n scalingListCount = (chromaFormatIdc !== 3) ? 8 : 12;\n for (i = 0; i < scalingListCount; i++) {\n if (readBoolean()) { // seq_scaling_list_present_flag[ i ]\n if (i < 6) {\n skipScalingList(16);\n } else {\n skipScalingList(64);\n }\n }\n }\n }\n }\n skipUEG(); // log2_max_frame_num_minus4\n let picOrderCntType = readUEG();\n if (picOrderCntType === 0) {\n readUEG(); // log2_max_pic_order_cnt_lsb_minus4\n } else if (picOrderCntType === 1) {\n skipBits(1); // delta_pic_order_always_zero_flag\n skipEG(); // offset_for_non_ref_pic\n skipEG(); // offset_for_top_to_bottom_field\n numRefFramesInPicOrderCntCycle = readUEG();\n for (i = 0; i < numRefFramesInPicOrderCntCycle; i++) {\n skipEG();\n } // offset_for_ref_frame[ i ]\n }\n skipUEG(); // max_num_ref_frames\n skipBits(1); // gaps_in_frame_num_value_allowed_flag\n picWidthInMbsMinus1 = readUEG();\n picHeightInMapUnitsMinus1 = readUEG();\n frameMbsOnlyFlag = readBits(1);\n if (frameMbsOnlyFlag === 0) {\n skipBits(1);\n } // mb_adaptive_frame_field_flag\n\n skipBits(1); // direct_8x8_inference_flag\n if (readBoolean()) { // frame_cropping_flag\n frameCropLeftOffset = readUEG();\n frameCropRightOffset = readUEG();\n frameCropTopOffset = readUEG();\n frameCropBottomOffset = readUEG();\n }\n let pixelRatio = [1, 1];\n if (readBoolean()) {\n // vui_parameters_present_flag\n if (readBoolean()) {\n // aspect_ratio_info_present_flag\n const aspectRatioIdc = readUByte();\n switch (aspectRatioIdc) {\n case 1: pixelRatio = [1, 1]; break;\n case 2: pixelRatio = [12, 11]; break;\n case 3: pixelRatio = [10, 11]; break;\n case 4: pixelRatio = [16, 11]; break;\n case 5: pixelRatio = [40, 33]; break;\n case 6: pixelRatio = [24, 11]; break;\n case 7: pixelRatio = [20, 11]; break;\n case 8: pixelRatio = [32, 11]; break;\n case 9: pixelRatio = [80, 33]; break;\n case 10: pixelRatio = [18, 11]; break;\n case 11: pixelRatio = [15, 11]; break;\n case 12: pixelRatio = [64, 33]; break;\n case 13: pixelRatio = [160, 99]; break;\n case 14: pixelRatio = [4, 3]; break;\n case 15: pixelRatio = [3, 2]; break;\n case 16: pixelRatio = [2, 1]; break;\n case 255: {\n pixelRatio = [readUByte() << 8 | readUByte(), readUByte() << 8 | readUByte()];\n break;\n }\n }\n }\n }\n return {\n width: Math.ceil((((picWidthInMbsMinus1 + 1) * 16) - frameCropLeftOffset * 2 - frameCropRightOffset * 2)),\n height: ((2 - frameMbsOnlyFlag) * (picHeightInMapUnitsMinus1 + 1) * 16) - ((frameMbsOnlyFlag ? 2 : 4) * (frameCropTopOffset + frameCropBottomOffset)),\n pixelRatio: pixelRatio\n };\n }\n\n readSliceType () {\n // skip NALu type\n this.readUByte();\n // discard first_mb_in_slice\n this.readUEG();\n // return slice_type\n return this.readUEG();\n }\n}\n\nexport default ExpGolomb;\n","/**\n * SAMPLE-AES decrypter\n*/\n\nimport Decrypter from '../crypt/decrypter';\n\nclass SampleAesDecrypter {\n constructor (observer, config, decryptdata, discardEPB) {\n this.decryptdata = decryptdata;\n this.discardEPB = discardEPB;\n this.decrypter = new Decrypter(observer, config, { removePKCS7Padding: false });\n }\n\n decryptBuffer (encryptedData, callback) {\n this.decrypter.decrypt(encryptedData, this.decryptdata.key.buffer, this.decryptdata.iv.buffer, callback);\n }\n\n // AAC - encrypt all full 16 bytes blocks starting from offset 16\n decryptAacSample (samples, sampleIndex, callback, sync) {\n let curUnit = samples[sampleIndex].unit;\n let encryptedData = curUnit.subarray(16, curUnit.length - curUnit.length % 16);\n let encryptedBuffer = encryptedData.buffer.slice(\n encryptedData.byteOffset,\n encryptedData.byteOffset + encryptedData.length);\n\n let localthis = this;\n this.decryptBuffer(encryptedBuffer, function (decryptedData) {\n decryptedData = new Uint8Array(decryptedData);\n curUnit.set(decryptedData, 16);\n\n if (!sync) {\n localthis.decryptAacSamples(samples, sampleIndex + 1, callback);\n }\n });\n }\n\n decryptAacSamples (samples, sampleIndex, callback) {\n for (;; sampleIndex++) {\n if (sampleIndex >= samples.length) {\n callback();\n return;\n }\n\n if (samples[sampleIndex].unit.length < 32) {\n continue;\n }\n\n let sync = this.decrypter.isSync();\n\n this.decryptAacSample(samples, sampleIndex, callback, sync);\n\n if (!sync) {\n return;\n }\n }\n }\n\n // AVC - encrypt one 16 bytes block out of ten, starting from offset 32\n getAvcEncryptedData (decodedData) {\n let encryptedDataLen = Math.floor((decodedData.length - 48) / 160) * 16 + 16;\n let encryptedData = new Int8Array(encryptedDataLen);\n let outputPos = 0;\n for (let inputPos = 32; inputPos <= decodedData.length - 16; inputPos += 160, outputPos += 16) {\n encryptedData.set(decodedData.subarray(inputPos, inputPos + 16), outputPos);\n }\n\n return encryptedData;\n }\n\n getAvcDecryptedUnit (decodedData, decryptedData) {\n decryptedData = new Uint8Array(decryptedData);\n let inputPos = 0;\n for (let outputPos = 32; outputPos <= decodedData.length - 16; outputPos += 160, inputPos += 16) {\n decodedData.set(decryptedData.subarray(inputPos, inputPos + 16), outputPos);\n }\n\n return decodedData;\n }\n\n decryptAvcSample (samples, sampleIndex, unitIndex, callback, curUnit, sync) {\n let decodedData = this.discardEPB(curUnit.data);\n let encryptedData = this.getAvcEncryptedData(decodedData);\n let localthis = this;\n\n this.decryptBuffer(encryptedData.buffer, function (decryptedData) {\n curUnit.data = localthis.getAvcDecryptedUnit(decodedData, decryptedData);\n\n if (!sync) {\n localthis.decryptAvcSamples(samples, sampleIndex, unitIndex + 1, callback);\n }\n });\n }\n\n decryptAvcSamples (samples, sampleIndex, unitIndex, callback) {\n for (;; sampleIndex++, unitIndex = 0) {\n if (sampleIndex >= samples.length) {\n callback();\n return;\n }\n\n let curUnits = samples[sampleIndex].units;\n for (;; unitIndex++) {\n if (unitIndex >= curUnits.length) {\n break;\n }\n\n let curUnit = curUnits[unitIndex];\n if (curUnit.data.length <= 48 || (curUnit.type !== 1 && curUnit.type !== 5)) {\n continue;\n }\n\n let sync = this.decrypter.isSync();\n\n this.decryptAvcSample(samples, sampleIndex, unitIndex, callback, curUnit, sync);\n\n if (!sync) {\n return;\n }\n }\n }\n }\n}\n\nexport default SampleAesDecrypter;\n","/**\n * highly optimized TS demuxer:\n * parse PAT, PMT\n * extract PES packet from audio and video PIDs\n * extract AVC/H264 NAL units and AAC/ADTS samples from PES packet\n * trigger the remuxer upon parsing completion\n * it also tries to workaround as best as it can audio codec switch (HE-AAC to AAC and vice versa), without having to restart the MediaSource.\n * it also controls the remuxing process :\n * upon discontinuity or level switch detection, it will also notifies the remuxer so that it can reset its state.\n*/\n\nimport * as ADTS from './adts';\nimport MpegAudio from './mpegaudio';\nimport Event from '../events';\nimport ExpGolomb from './exp-golomb';\nimport SampleAesDecrypter from './sample-aes';\n// import Hex from '../utils/hex';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { utf8ArrayToStr } from './id3';\n\n// We are using fixed track IDs for driving the MP4 remuxer\n// instead of following the TS PIDs.\n// There is no reason not to do this and some browsers/SourceBuffer-demuxers\n// may not like if there are TrackID \"switches\"\n// See https://github.com/video-dev/hls.js/issues/1331\n// Here we are mapping our internal track types to constant MP4 track IDs\n// With MSE currently one can only have one track of each, and we are muxing\n// whatever video/audio rendition in them.\nconst RemuxerTrackIdConfig = {\n video: 1,\n audio: 2,\n id3: 3,\n text: 4\n};\n\nclass TSDemuxer {\n constructor (observer, remuxer, config, typeSupported) {\n this.observer = observer;\n this.config = config;\n this.typeSupported = typeSupported;\n this.remuxer = remuxer;\n this.sampleAes = null;\n this.pmtUnknownTypes = {};\n }\n\n setDecryptData (decryptdata) {\n if ((decryptdata != null) && (decryptdata.key != null) && (decryptdata.method === 'SAMPLE-AES')) {\n this.sampleAes = new SampleAesDecrypter(this.observer, this.config, decryptdata, this.discardEPB);\n } else {\n this.sampleAes = null;\n }\n }\n\n static probe (data) {\n const syncOffset = TSDemuxer._syncOffset(data);\n if (syncOffset < 0) {\n return false;\n } else {\n if (syncOffset) {\n logger.warn(`MPEG2-TS detected but first sync word found @ offset ${syncOffset}, junk ahead ?`);\n }\n\n return true;\n }\n }\n\n static _syncOffset (data) {\n // scan 1000 first bytes\n const scanwindow = Math.min(1000, data.length - 3 * 188);\n let i = 0;\n while (i < scanwindow) {\n // a TS fragment should contain at least 3 TS packets, a PAT, a PMT, and one PID, each starting with 0x47\n if (data[i] === 0x47 && data[i + 188] === 0x47 && data[i + 2 * 188] === 0x47) {\n return i;\n } else {\n i++;\n }\n }\n return -1;\n }\n\n /**\n * Creates a track model internal to demuxer used to drive remuxing input\n *\n * @param {string} type 'audio' | 'video' | 'id3' | 'text'\n * @param {number} duration\n * @return {object} TSDemuxer's internal track model\n */\n static createTrack (type, duration) {\n return {\n container: type === 'video' || type === 'audio' ? 'video/mp2t' : undefined,\n type,\n id: RemuxerTrackIdConfig[type],\n pid: -1,\n inputTimeScale: 90000,\n sequenceNumber: 0,\n samples: [],\n dropped: type === 'video' ? 0 : undefined,\n isAAC: type === 'audio' ? true : undefined,\n duration: type === 'audio' ? duration : undefined\n };\n }\n\n /**\n * Initializes a new init segment on the demuxer/remuxer interface. Needed for discontinuities/track-switches (or at stream start)\n * Resets all internal track instances of the demuxer.\n *\n * @override Implements generic demuxing/remuxing interface (see DemuxerInline)\n * @param {object} initSegment\n * @param {string} audioCodec\n * @param {string} videoCodec\n * @param {number} duration (in TS timescale = 90kHz)\n */\n resetInitSegment (initSegment, audioCodec, videoCodec, duration) {\n this.pmtParsed = false;\n this._pmtId = -1;\n this.pmtUnknownTypes = {};\n\n this._avcTrack = TSDemuxer.createTrack('video', duration);\n this._audioTrack = TSDemuxer.createTrack('audio', duration);\n this._id3Track = TSDemuxer.createTrack('id3', duration);\n this._txtTrack = TSDemuxer.createTrack('text', duration);\n\n // flush any partial content\n this.aacOverFlow = null;\n this.aacLastPTS = null;\n this.avcSample = null;\n this.audioCodec = audioCodec;\n this.videoCodec = videoCodec;\n this._duration = duration;\n }\n\n /**\n *\n * @override\n */\n resetTimeStamp () {}\n\n // feed incoming data to the front of the parsing pipeline\n append (data, timeOffset, contiguous, accurateTimeOffset) {\n let start, len = data.length, stt, pid, atf, offset, pes,\n unknownPIDs = false;\n this.pmtUnknownTypes = {};\n this.contiguous = contiguous;\n let pmtParsed = this.pmtParsed,\n avcTrack = this._avcTrack,\n audioTrack = this._audioTrack,\n id3Track = this._id3Track,\n avcId = avcTrack.pid,\n audioId = audioTrack.pid,\n id3Id = id3Track.pid,\n pmtId = this._pmtId,\n avcData = avcTrack.pesData,\n audioData = audioTrack.pesData,\n id3Data = id3Track.pesData,\n parsePAT = this._parsePAT,\n parsePMT = this._parsePMT.bind(this),\n parsePES = this._parsePES,\n parseAVCPES = this._parseAVCPES.bind(this),\n parseAACPES = this._parseAACPES.bind(this),\n parseMPEGPES = this._parseMPEGPES.bind(this),\n parseID3PES = this._parseID3PES.bind(this);\n\n const syncOffset = TSDemuxer._syncOffset(data);\n\n // don't parse last TS packet if incomplete\n len -= (len + syncOffset) % 188;\n\n // loop through TS packets\n for (start = syncOffset; start < len; start += 188) {\n if (data[start] === 0x47) {\n stt = !!(data[start + 1] & 0x40);\n // pid is a 13-bit field starting at the last bit of TS[1]\n pid = ((data[start + 1] & 0x1f) << 8) + data[start + 2];\n atf = (data[start + 3] & 0x30) >> 4;\n // if an adaption field is present, its length is specified by the fifth byte of the TS packet header.\n if (atf > 1) {\n offset = start + 5 + data[start + 4];\n // continue if there is only adaptation field\n if (offset === (start + 188)) {\n continue;\n }\n } else {\n offset = start + 4;\n }\n switch (pid) {\n case avcId:\n if (stt) {\n if (avcData && (pes = parsePES(avcData))) {\n parseAVCPES(pes, false);\n }\n\n avcData = { data: [], size: 0 };\n }\n if (avcData) {\n avcData.data.push(data.subarray(offset, start + 188));\n avcData.size += start + 188 - offset;\n }\n break;\n case audioId:\n if (stt) {\n if (audioData && (pes = parsePES(audioData))) {\n if (audioTrack.isAAC) {\n parseAACPES(pes);\n } else {\n parseMPEGPES(pes);\n }\n }\n audioData = { data: [], size: 0 };\n }\n if (audioData) {\n audioData.data.push(data.subarray(offset, start + 188));\n audioData.size += start + 188 - offset;\n }\n break;\n case id3Id:\n if (stt) {\n if (id3Data && (pes = parsePES(id3Data))) {\n parseID3PES(pes);\n }\n\n id3Data = { data: [], size: 0 };\n }\n if (id3Data) {\n id3Data.data.push(data.subarray(offset, start + 188));\n id3Data.size += start + 188 - offset;\n }\n break;\n case 0:\n if (stt) {\n offset += data[offset] + 1;\n }\n\n pmtId = this._pmtId = parsePAT(data, offset);\n break;\n case pmtId:\n if (stt) {\n offset += data[offset] + 1;\n }\n\n let parsedPIDs = parsePMT(data, offset, this.typeSupported.mpeg === true || this.typeSupported.mp3 === true, this.sampleAes != null);\n\n // only update track id if track PID found while parsing PMT\n // this is to avoid resetting the PID to -1 in case\n // track PID transiently disappears from the stream\n // this could happen in case of transient missing audio samples for example\n // NOTE this is only the PID of the track as found in TS,\n // but we are not using this for MP4 track IDs.\n avcId = parsedPIDs.avc;\n if (avcId > 0) {\n avcTrack.pid = avcId;\n }\n\n audioId = parsedPIDs.audio;\n if (audioId > 0) {\n audioTrack.pid = audioId;\n audioTrack.isAAC = parsedPIDs.isAAC;\n }\n id3Id = parsedPIDs.id3;\n if (id3Id > 0) {\n id3Track.pid = id3Id;\n }\n\n if (unknownPIDs && !pmtParsed) {\n logger.log('reparse from beginning');\n unknownPIDs = false;\n // we set it to -188, the += 188 in the for loop will reset start to 0\n start = syncOffset - 188;\n }\n pmtParsed = this.pmtParsed = true;\n break;\n case 17:\n case 0x1fff:\n break;\n default:\n unknownPIDs = true;\n break;\n }\n } else {\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: false, reason: 'TS packet did not start with 0x47' });\n }\n }\n // try to parse last PES packets\n if (avcData && (pes = parsePES(avcData))) {\n parseAVCPES(pes, true);\n avcTrack.pesData = null;\n } else {\n // either avcData null or PES truncated, keep it for next frag parsing\n avcTrack.pesData = avcData;\n }\n\n if (audioData && (pes = parsePES(audioData))) {\n if (audioTrack.isAAC) {\n parseAACPES(pes);\n } else {\n parseMPEGPES(pes);\n }\n\n audioTrack.pesData = null;\n } else {\n if (audioData && audioData.size) {\n logger.log('last AAC PES packet truncated,might overlap between fragments');\n }\n\n // either audioData null or PES truncated, keep it for next frag parsing\n audioTrack.pesData = audioData;\n }\n\n if (id3Data && (pes = parsePES(id3Data))) {\n parseID3PES(pes);\n id3Track.pesData = null;\n } else {\n // either id3Data null or PES truncated, keep it for next frag parsing\n id3Track.pesData = id3Data;\n }\n\n if (this.sampleAes == null) {\n this.remuxer.remux(audioTrack, avcTrack, id3Track, this._txtTrack, timeOffset, contiguous, accurateTimeOffset);\n } else {\n this.decryptAndRemux(audioTrack, avcTrack, id3Track, this._txtTrack, timeOffset, contiguous, accurateTimeOffset);\n }\n }\n\n decryptAndRemux (audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset) {\n if (audioTrack.samples && audioTrack.isAAC) {\n let localthis = this;\n this.sampleAes.decryptAacSamples(audioTrack.samples, 0, function () {\n localthis.decryptAndRemuxAvc(audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset);\n });\n } else {\n this.decryptAndRemuxAvc(audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset);\n }\n }\n\n decryptAndRemuxAvc (audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset) {\n if (videoTrack.samples) {\n let localthis = this;\n this.sampleAes.decryptAvcSamples(videoTrack.samples, 0, 0, function () {\n localthis.remuxer.remux(audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset);\n });\n } else {\n this.remuxer.remux(audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset);\n }\n }\n\n destroy () {\n this._initPTS = this._initDTS = undefined;\n this._duration = 0;\n }\n\n _parsePAT (data, offset) {\n // skip the PSI header and parse the first PMT entry\n return (data[offset + 10] & 0x1F) << 8 | data[offset + 11];\n // logger.log('PMT PID:' + this._pmtId);\n }\n\n _trackUnknownPmt (type, logLevel, message) {\n // Only log unknown and unsupported stream types once per append or stream (by resetting this.pmtUnknownTypes)\n // For more information on elementary stream types see:\n // https://en.wikipedia.org/wiki/Program-specific_information#Elementary_stream_types\n const result = this.pmtUnknownTypes[type] || 0;\n if (result === 0) {\n this.pmtUnknownTypes[type] = 0;\n logLevel.call(logger, message);\n }\n this.pmtUnknownTypes[type]++;\n return result;\n }\n\n _parsePMT (data, offset, mpegSupported, isSampleAes) {\n let sectionLength, tableEnd, programInfoLength, pid, result = { audio: -1, avc: -1, id3: -1, isAAC: true };\n sectionLength = (data[offset + 1] & 0x0f) << 8 | data[offset + 2];\n tableEnd = offset + 3 + sectionLength - 4;\n // to determine where the table is, we have to figure out how\n // long the program info descriptors are\n programInfoLength = (data[offset + 10] & 0x0f) << 8 | data[offset + 11];\n // advance the offset to the first entry in the mapping table\n offset += 12 + programInfoLength;\n while (offset < tableEnd) {\n pid = (data[offset + 1] & 0x1F) << 8 | data[offset + 2];\n switch (data[offset]) {\n case 0xcf: // SAMPLE-AES AAC\n if (!isSampleAes) {\n this._trackUnknownPmt(data[offset], logger.warn, 'ADTS AAC with AES-128-CBC frame encryption found in unencrypted stream');\n break;\n }\n /* falls through */\n\n // ISO/IEC 13818-7 ADTS AAC (MPEG-2 lower bit-rate audio)\n case 0x0f:\n // logger.log('AAC PID:' + pid);\n if (result.audio === -1) {\n result.audio = pid;\n }\n\n break;\n\n // Packetized metadata (ID3)\n case 0x15:\n // logger.log('ID3 PID:' + pid);\n if (result.id3 === -1) {\n result.id3 = pid;\n }\n\n break;\n\n case 0xdb: // SAMPLE-AES AVC\n if (!isSampleAes) {\n this._trackUnknownPmt(data[offset], logger.warn, 'H.264 with AES-128-CBC slice encryption found in unencrypted stream');\n break;\n }\n /* falls through */\n\n // ITU-T Rec. H.264 and ISO/IEC 14496-10 (lower bit-rate video)\n case 0x1b:\n // logger.log('AVC PID:' + pid);\n if (result.avc === -1) {\n result.avc = pid;\n }\n\n break;\n\n // ISO/IEC 11172-3 (MPEG-1 audio)\n // or ISO/IEC 13818-3 (MPEG-2 halved sample rate audio)\n case 0x03:\n case 0x04:\n // logger.log('MPEG PID:' + pid);\n if (!mpegSupported) {\n this._trackUnknownPmt(data[offset], logger.warn, 'MPEG audio found, not supported in this browser');\n } else if (result.audio === -1) {\n result.audio = pid;\n result.isAAC = false;\n }\n break;\n\n case 0x24:\n this._trackUnknownPmt(data[offset], logger.warn, 'Unsupported HEVC stream type found');\n break;\n\n default:\n this._trackUnknownPmt(data[offset], logger.log, 'Unknown stream type:' + data[offset]);\n break;\n }\n // move to the next table entry\n // skip past the elementary stream descriptors, if present\n offset += ((data[offset + 3] & 0x0F) << 8 | data[offset + 4]) + 5;\n }\n return result;\n }\n\n _parsePES (stream) {\n let i = 0, frag, pesFlags, pesPrefix, pesLen, pesHdrLen, pesData, pesPts, pesDts, payloadStartOffset, data = stream.data;\n // safety check\n if (!stream || stream.size === 0) {\n return null;\n }\n\n // we might need up to 19 bytes to read PES header\n // if first chunk of data is less than 19 bytes, let's merge it with following ones until we get 19 bytes\n // usually only one merge is needed (and this is rare ...)\n while (data[0].length < 19 && data.length > 1) {\n let newData = new Uint8Array(data[0].length + data[1].length);\n newData.set(data[0]);\n newData.set(data[1], data[0].length);\n data[0] = newData;\n data.splice(1, 1);\n }\n // retrieve PTS/DTS from first fragment\n frag = data[0];\n pesPrefix = (frag[0] << 16) + (frag[1] << 8) + frag[2];\n if (pesPrefix === 1) {\n pesLen = (frag[4] << 8) + frag[5];\n // if PES parsed length is not zero and greater than total received length, stop parsing. PES might be truncated\n // minus 6 : PES header size\n if (pesLen && pesLen > stream.size - 6) {\n return null;\n }\n\n pesFlags = frag[7];\n if (pesFlags & 0xC0) {\n /* PES header described here : http://dvd.sourceforge.net/dvdinfo/pes-hdr.html\n as PTS / DTS is 33 bit we cannot use bitwise operator in JS,\n as Bitwise operators treat their operands as a sequence of 32 bits */\n pesPts = (frag[9] & 0x0E) * 536870912 +// 1 << 29\n (frag[10] & 0xFF) * 4194304 +// 1 << 22\n (frag[11] & 0xFE) * 16384 +// 1 << 14\n (frag[12] & 0xFF) * 128 +// 1 << 7\n (frag[13] & 0xFE) / 2;\n\n if (pesFlags & 0x40) {\n pesDts = (frag[14] & 0x0E) * 536870912 +// 1 << 29\n (frag[15] & 0xFF) * 4194304 +// 1 << 22\n (frag[16] & 0xFE) * 16384 +// 1 << 14\n (frag[17] & 0xFF) * 128 +// 1 << 7\n (frag[18] & 0xFE) / 2;\n\n if (pesPts - pesDts > 60 * 90000) {\n logger.warn(`${Math.round((pesPts - pesDts) / 90000)}s delta between PTS and DTS, align them`);\n pesPts = pesDts;\n }\n } else {\n pesDts = pesPts;\n }\n }\n pesHdrLen = frag[8];\n // 9 bytes : 6 bytes for PES header + 3 bytes for PES extension\n payloadStartOffset = pesHdrLen + 9;\n\n if (stream.size <= payloadStartOffset) {\n return null;\n }\n stream.size -= payloadStartOffset;\n // reassemble PES packet\n pesData = new Uint8Array(stream.size);\n for (let j = 0, dataLen = data.length; j < dataLen; j++) {\n frag = data[j];\n let len = frag.byteLength;\n if (payloadStartOffset) {\n if (payloadStartOffset > len) {\n // trim full frag if PES header bigger than frag\n payloadStartOffset -= len;\n continue;\n } else {\n // trim partial frag if PES header smaller than frag\n frag = frag.subarray(payloadStartOffset);\n len -= payloadStartOffset;\n payloadStartOffset = 0;\n }\n }\n pesData.set(frag, i);\n i += len;\n }\n if (pesLen) {\n // payload size : remove PES header + PES extension\n pesLen -= pesHdrLen + 3;\n }\n return { data: pesData, pts: pesPts, dts: pesDts, len: pesLen };\n } else {\n return null;\n }\n }\n\n pushAccesUnit (avcSample, avcTrack) {\n if (avcSample.units.length && avcSample.frame) {\n const samples = avcTrack.samples;\n const nbSamples = samples.length;\n // if sample does not have PTS/DTS, patch with last sample PTS/DTS\n if (isNaN(avcSample.pts)) {\n if (nbSamples) {\n const lastSample = samples[nbSamples - 1];\n avcSample.pts = lastSample.pts;\n avcSample.dts = lastSample.dts;\n } else {\n // dropping samples, no timestamp found\n avcTrack.dropped++;\n return;\n }\n }\n // only push AVC sample if starting with a keyframe is not mandatory OR\n // if keyframe already found in this fragment OR\n // keyframe found in last fragment (track.sps) AND\n // samples already appended (we already found a keyframe in this fragment) OR fragment is contiguous\n if (!this.config.forceKeyFrameOnDiscontinuity ||\n avcSample.key === true ||\n (avcTrack.sps && (nbSamples || this.contiguous))) {\n avcSample.id = nbSamples;\n samples.push(avcSample);\n } else {\n // dropped samples, track it\n avcTrack.dropped++;\n }\n }\n if (avcSample.debug.length) {\n logger.log(avcSample.pts + '/' + avcSample.dts + ':' + avcSample.debug);\n }\n }\n\n _parseAVCPES (pes, last) {\n // logger.log('parse new PES');\n let track = this._avcTrack,\n units = this._parseAVCNALu(pes.data),\n debug = false,\n expGolombDecoder,\n avcSample = this.avcSample,\n push,\n spsfound = false,\n i,\n pushAccesUnit = this.pushAccesUnit.bind(this),\n createAVCSample = function (key, pts, dts, debug) {\n return { key: key, pts: pts, dts: dts, units: [], debug: debug };\n };\n // free pes.data to save up some memory\n pes.data = null;\n\n // if new NAL units found and last sample still there, let's push ...\n // this helps parsing streams with missing AUD (only do this if AUD never found)\n if (avcSample && units.length && !track.audFound) {\n pushAccesUnit(avcSample, track);\n avcSample = this.avcSample = createAVCSample(false, pes.pts, pes.dts, '');\n }\n\n units.forEach(unit => {\n switch (unit.type) {\n // NDR\n case 1:\n push = true;\n if (!avcSample) {\n avcSample = this.avcSample = createAVCSample(true, pes.pts, pes.dts, '');\n }\n\n if (debug) {\n avcSample.debug += 'NDR ';\n }\n\n avcSample.frame = true;\n let data = unit.data;\n // only check slice type to detect KF in case SPS found in same packet (any keyframe is preceded by SPS ...)\n if (spsfound && data.length > 4) {\n // retrieve slice type by parsing beginning of NAL unit (follow H264 spec, slice_header definition) to detect keyframe embedded in NDR\n let sliceType = new ExpGolomb(data).readSliceType();\n // 2 : I slice, 4 : SI slice, 7 : I slice, 9: SI slice\n // SI slice : A slice that is coded using intra prediction only and using quantisation of the prediction samples.\n // An SI slice can be coded such that its decoded samples can be constructed identically to an SP slice.\n // I slice: A slice that is not an SI slice that is decoded using intra prediction only.\n // if (sliceType === 2 || sliceType === 7) {\n if (sliceType === 2 || sliceType === 4 || sliceType === 7 || sliceType === 9) {\n avcSample.key = true;\n }\n }\n break;\n // IDR\n case 5:\n push = true;\n // handle PES not starting with AUD\n if (!avcSample) {\n avcSample = this.avcSample = createAVCSample(true, pes.pts, pes.dts, '');\n }\n\n if (debug) {\n avcSample.debug += 'IDR ';\n }\n\n avcSample.key = true;\n avcSample.frame = true;\n break;\n // SEI\n case 6:\n push = true;\n if (debug && avcSample) {\n avcSample.debug += 'SEI ';\n }\n\n expGolombDecoder = new ExpGolomb(this.discardEPB(unit.data));\n\n // skip frameType\n expGolombDecoder.readUByte();\n\n var payloadType = 0;\n var payloadSize = 0;\n var endOfCaptions = false;\n var b = 0;\n\n while (!endOfCaptions && expGolombDecoder.bytesAvailable > 1) {\n payloadType = 0;\n do {\n b = expGolombDecoder.readUByte();\n payloadType += b;\n } while (b === 0xFF);\n\n // Parse payload size.\n payloadSize = 0;\n do {\n b = expGolombDecoder.readUByte();\n payloadSize += b;\n } while (b === 0xFF);\n\n // TODO: there can be more than one payload in an SEI packet...\n // TODO: need to read type and size in a while loop to get them all\n if (payloadType === 4 && expGolombDecoder.bytesAvailable !== 0) {\n endOfCaptions = true;\n\n let countryCode = expGolombDecoder.readUByte();\n\n if (countryCode === 181) {\n let providerCode = expGolombDecoder.readUShort();\n\n if (providerCode === 49) {\n let userStructure = expGolombDecoder.readUInt();\n\n if (userStructure === 0x47413934) {\n let userDataType = expGolombDecoder.readUByte();\n\n // Raw CEA-608 bytes wrapped in CEA-708 packet\n if (userDataType === 3) {\n let firstByte = expGolombDecoder.readUByte();\n let secondByte = expGolombDecoder.readUByte();\n\n let totalCCs = 31 & firstByte;\n let byteArray = [firstByte, secondByte];\n\n for (i = 0; i < totalCCs; i++) {\n // 3 bytes per CC\n byteArray.push(expGolombDecoder.readUByte());\n byteArray.push(expGolombDecoder.readUByte());\n byteArray.push(expGolombDecoder.readUByte());\n }\n\n this._insertSampleInOrder(this._txtTrack.samples, { type: 3, pts: pes.pts, bytes: byteArray });\n }\n }\n }\n }\n } else if (payloadType === 5 && expGolombDecoder.bytesAvailable !== 0) {\n endOfCaptions = true;\n\n if (payloadSize > 16) {\n const uuidStrArray = [];\n for (i = 0; i < 16; i++) {\n uuidStrArray.push(expGolombDecoder.readUByte().toString(16));\n\n if (i === 3 || i === 5 || i === 7 || i === 9) {\n uuidStrArray.push('-');\n }\n }\n const length = payloadSize - 16;\n const userDataPayloadBytes = new Uint8Array(length);\n for (i = 0; i < length; i++) {\n userDataPayloadBytes[i] = expGolombDecoder.readUByte();\n }\n\n this._insertSampleInOrder(this._txtTrack.samples, {\n pts: pes.pts,\n payloadType: payloadType,\n uuid: uuidStrArray.join(''),\n userDataBytes: userDataPayloadBytes,\n userData: utf8ArrayToStr(userDataPayloadBytes.buffer)\n });\n }\n } else if (payloadSize < expGolombDecoder.bytesAvailable) {\n for (i = 0; i < payloadSize; i++) {\n expGolombDecoder.readUByte();\n }\n }\n }\n break;\n // SPS\n case 7:\n push = true;\n spsfound = true;\n if (debug && avcSample) {\n avcSample.debug += 'SPS ';\n }\n\n if (!track.sps) {\n expGolombDecoder = new ExpGolomb(unit.data);\n let config = expGolombDecoder.readSPS();\n track.width = config.width;\n track.height = config.height;\n track.pixelRatio = config.pixelRatio;\n track.sps = [unit.data];\n track.duration = this._duration;\n let codecarray = unit.data.subarray(1, 4);\n let codecstring = 'avc1.';\n for (i = 0; i < 3; i++) {\n let h = codecarray[i].toString(16);\n if (h.length < 2) {\n h = '0' + h;\n }\n\n codecstring += h;\n }\n track.codec = codecstring;\n }\n break;\n // PPS\n case 8:\n push = true;\n if (debug && avcSample) {\n avcSample.debug += 'PPS ';\n }\n\n if (!track.pps) {\n track.pps = [unit.data];\n }\n\n break;\n // AUD\n case 9:\n push = false;\n track.audFound = true;\n if (avcSample) {\n pushAccesUnit(avcSample, track);\n }\n\n avcSample = this.avcSample = createAVCSample(false, pes.pts, pes.dts, debug ? 'AUD ' : '');\n break;\n // Filler Data\n case 12:\n push = false;\n break;\n default:\n push = false;\n if (avcSample) {\n avcSample.debug += 'unknown NAL ' + unit.type + ' ';\n }\n\n break;\n }\n if (avcSample && push) {\n let units = avcSample.units;\n units.push(unit);\n }\n });\n // if last PES packet, push samples\n if (last && avcSample) {\n pushAccesUnit(avcSample, track);\n this.avcSample = null;\n }\n }\n\n _insertSampleInOrder (arr, data) {\n let len = arr.length;\n if (len > 0) {\n if (data.pts >= arr[len - 1].pts) {\n arr.push(data);\n } else {\n for (let pos = len - 1; pos >= 0; pos--) {\n if (data.pts < arr[pos].pts) {\n arr.splice(pos, 0, data);\n break;\n }\n }\n }\n } else {\n arr.push(data);\n }\n }\n\n _getLastNalUnit () {\n let avcSample = this.avcSample, lastUnit;\n // try to fallback to previous sample if current one is empty\n if (!avcSample || avcSample.units.length === 0) {\n let track = this._avcTrack, samples = track.samples;\n avcSample = samples[samples.length - 1];\n }\n if (avcSample) {\n let units = avcSample.units;\n lastUnit = units[units.length - 1];\n }\n return lastUnit;\n }\n\n _parseAVCNALu (array) {\n let i = 0, len = array.byteLength, value, overflow, track = this._avcTrack, state = track.naluState || 0, lastState = state;\n let units = [], unit, unitType, lastUnitStart = -1, lastUnitType;\n // logger.log('PES:' + Hex.hexDump(array));\n\n if (state === -1) {\n // special use case where we found 3 or 4-byte start codes exactly at the end of previous PES packet\n lastUnitStart = 0;\n // NALu type is value read from offset 0\n lastUnitType = array[0] & 0x1f;\n state = 0;\n i = 1;\n }\n\n while (i < len) {\n value = array[i++];\n // optimization. state 0 and 1 are the predominant case. let's handle them outside of the switch/case\n if (!state) {\n state = value ? 0 : 1;\n continue;\n }\n if (state === 1) {\n state = value ? 0 : 2;\n continue;\n }\n // here we have state either equal to 2 or 3\n if (!value) {\n state = 3;\n } else if (value === 1) {\n if (lastUnitStart >= 0) {\n unit = { data: array.subarray(lastUnitStart, i - state - 1), type: lastUnitType };\n // logger.log('pushing NALU, type/size:' + unit.type + '/' + unit.data.byteLength);\n units.push(unit);\n } else {\n // lastUnitStart is undefined => this is the first start code found in this PES packet\n // first check if start code delimiter is overlapping between 2 PES packets,\n // ie it started in last packet (lastState not zero)\n // and ended at the beginning of this PES packet (i <= 4 - lastState)\n let lastUnit = this._getLastNalUnit();\n if (lastUnit) {\n if (lastState && (i <= 4 - lastState)) {\n // start delimiter overlapping between PES packets\n // strip start delimiter bytes from the end of last NAL unit\n // check if lastUnit had a state different from zero\n if (lastUnit.state) {\n // strip last bytes\n lastUnit.data = lastUnit.data.subarray(0, lastUnit.data.byteLength - lastState);\n }\n }\n // If NAL units are not starting right at the beginning of the PES packet, push preceding data into previous NAL unit.\n overflow = i - state - 1;\n if (overflow > 0) {\n // logger.log('first NALU found with overflow:' + overflow);\n let tmp = new Uint8Array(lastUnit.data.byteLength + overflow);\n tmp.set(lastUnit.data, 0);\n tmp.set(array.subarray(0, overflow), lastUnit.data.byteLength);\n lastUnit.data = tmp;\n }\n }\n }\n // check if we can read unit type\n if (i < len) {\n unitType = array[i] & 0x1f;\n // logger.log('find NALU @ offset:' + i + ',type:' + unitType);\n lastUnitStart = i;\n lastUnitType = unitType;\n state = 0;\n } else {\n // not enough byte to read unit type. let's read it on next PES parsing\n state = -1;\n }\n } else {\n state = 0;\n }\n }\n if (lastUnitStart >= 0 && state >= 0) {\n unit = { data: array.subarray(lastUnitStart, len), type: lastUnitType, state: state };\n units.push(unit);\n // logger.log('pushing NALU, type/size/state:' + unit.type + '/' + unit.data.byteLength + '/' + state);\n }\n // no NALu found\n if (units.length === 0) {\n // append pes.data to previous NAL unit\n let lastUnit = this._getLastNalUnit();\n if (lastUnit) {\n let tmp = new Uint8Array(lastUnit.data.byteLength + array.byteLength);\n tmp.set(lastUnit.data, 0);\n tmp.set(array, lastUnit.data.byteLength);\n lastUnit.data = tmp;\n }\n }\n track.naluState = state;\n return units;\n }\n\n /**\n * remove Emulation Prevention bytes from a RBSP\n */\n discardEPB (data) {\n let length = data.byteLength,\n EPBPositions = [],\n i = 1,\n newLength, newData;\n\n // Find all `Emulation Prevention Bytes`\n while (i < length - 2) {\n if (data[i] === 0 &&\n data[i + 1] === 0 &&\n data[i + 2] === 0x03) {\n EPBPositions.push(i + 2);\n i += 2;\n } else {\n i++;\n }\n }\n\n // If no Emulation Prevention Bytes were found just return the original\n // array\n if (EPBPositions.length === 0) {\n return data;\n }\n\n // Create a new array to hold the NAL unit data\n newLength = length - EPBPositions.length;\n newData = new Uint8Array(newLength);\n let sourceIndex = 0;\n\n for (i = 0; i < newLength; sourceIndex++, i++) {\n if (sourceIndex === EPBPositions[0]) {\n // Skip this byte\n sourceIndex++;\n // Remove this position index\n EPBPositions.shift();\n }\n newData[i] = data[sourceIndex];\n }\n return newData;\n }\n\n _parseAACPES (pes) {\n let track = this._audioTrack,\n data = pes.data,\n pts = pes.pts,\n startOffset = 0,\n aacOverFlow = this.aacOverFlow,\n aacLastPTS = this.aacLastPTS,\n frameDuration, frameIndex, offset, stamp, len;\n if (aacOverFlow) {\n let tmp = new Uint8Array(aacOverFlow.byteLength + data.byteLength);\n tmp.set(aacOverFlow, 0);\n tmp.set(data, aacOverFlow.byteLength);\n // logger.log(`AAC: append overflowing ${aacOverFlow.byteLength} bytes to beginning of new PES`);\n data = tmp;\n }\n // look for ADTS header (0xFFFx)\n for (offset = startOffset, len = data.length; offset < len - 1; offset++) {\n if (ADTS.isHeader(data, offset)) {\n break;\n }\n }\n // if ADTS header does not start straight from the beginning of the PES payload, raise an error\n if (offset) {\n let reason, fatal;\n if (offset < len - 1) {\n reason = `AAC PES did not start with ADTS header,offset:${offset}`;\n fatal = false;\n } else {\n reason = 'no ADTS header found in AAC PES';\n fatal = true;\n }\n logger.warn(`parsing error:${reason}`);\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: fatal, reason: reason });\n if (fatal) {\n return;\n }\n }\n\n ADTS.initTrackConfig(track, this.observer, data, offset, this.audioCodec);\n frameIndex = 0;\n frameDuration = ADTS.getFrameDuration(track.samplerate);\n\n // if last AAC frame is overflowing, we should ensure timestamps are contiguous:\n // first sample PTS should be equal to last sample PTS + frameDuration\n if (aacOverFlow && aacLastPTS) {\n let newPTS = aacLastPTS + frameDuration;\n if (Math.abs(newPTS - pts) > 1) {\n logger.log(`AAC: align PTS for overlapping frames by ${Math.round((newPTS - pts) / 90)}`);\n pts = newPTS;\n }\n }\n\n // scan for aac samples\n while (offset < len) {\n if (ADTS.isHeader(data, offset)) {\n if ((offset + 5) < len) {\n const frame = ADTS.appendFrame(track, data, offset, pts, frameIndex);\n if (frame) {\n offset += frame.length;\n stamp = frame.sample.pts;\n frameIndex++;\n continue;\n }\n }\n // We are at an ADTS header, but do not have enough data for a frame\n // Remaining data will be added to aacOverFlow\n break;\n } else {\n // nothing found, keep looking\n offset++;\n }\n }\n\n if (offset < len) {\n aacOverFlow = data.subarray(offset, len);\n // logger.log(`AAC: overflow detected:${len-offset}`);\n } else {\n aacOverFlow = null;\n }\n\n this.aacOverFlow = aacOverFlow;\n this.aacLastPTS = stamp;\n }\n\n _parseMPEGPES (pes) {\n let data = pes.data;\n let length = data.length;\n let frameIndex = 0;\n let offset = 0;\n let pts = pes.pts;\n\n while (offset < length) {\n if (MpegAudio.isHeader(data, offset)) {\n let frame = MpegAudio.appendFrame(this._audioTrack, data, offset, pts, frameIndex);\n if (frame) {\n offset += frame.length;\n frameIndex++;\n } else {\n // logger.log('Unable to parse Mpeg audio frame');\n break;\n }\n } else {\n // nothing found, keep looking\n offset++;\n }\n }\n }\n\n _parseID3PES (pes) {\n this._id3Track.samples.push(pes);\n }\n}\n\nexport default TSDemuxer;\n","/**\n * MP3 demuxer\n */\nimport ID3 from '../demux/id3';\nimport { logger } from '../utils/logger';\nimport MpegAudio from './mpegaudio';\n\nclass MP3Demuxer {\n constructor (observer, remuxer, config) {\n this.observer = observer;\n this.config = config;\n this.remuxer = remuxer;\n }\n\n resetInitSegment (initSegment, audioCodec, videoCodec, duration) {\n this._audioTrack = { container: 'audio/mpeg', type: 'audio', id: -1, sequenceNumber: 0, isAAC: false, samples: [], len: 0, manifestCodec: audioCodec, duration: duration, inputTimeScale: 90000 };\n }\n\n resetTimeStamp () {\n }\n\n static probe (data) {\n // check if data contains ID3 timestamp and MPEG sync word\n let offset, length;\n let id3Data = ID3.getID3Data(data, 0);\n if (id3Data && ID3.getTimeStamp(id3Data) !== undefined) {\n // Look for MPEG header | 1111 1111 | 111X XYZX | where X can be either 0 or 1 and Y or Z should be 1\n // Layer bits (position 14 and 15) in header should be always different from 0 (Layer I or Layer II or Layer III)\n // More info http://www.mp3-tech.org/programmer/frame_header.html\n for (offset = id3Data.length, length = Math.min(data.length - 1, offset + 100); offset < length; offset++) {\n if (MpegAudio.probe(data, offset)) {\n logger.log('MPEG Audio sync word found !');\n return true;\n }\n }\n }\n return false;\n }\n\n // feed incoming data to the front of the parsing pipeline\n append (data, timeOffset, contiguous, accurateTimeOffset) {\n let id3Data = ID3.getID3Data(data, 0) || [];\n let timestamp = ID3.getTimeStamp(id3Data);\n let pts = timestamp !== undefined ? 90 * timestamp : timeOffset * 90000;\n let offset = id3Data.length;\n let length = data.length;\n let frameIndex = 0, stamp = 0;\n let track = this._audioTrack;\n\n let id3Samples = [{ pts: pts, dts: pts, data: id3Data }];\n\n while (offset < length) {\n if (MpegAudio.isHeader(data, offset)) {\n let frame = MpegAudio.appendFrame(track, data, offset, pts, frameIndex);\n if (frame) {\n offset += frame.length;\n stamp = frame.sample.pts;\n frameIndex++;\n } else {\n // logger.log('Unable to parse Mpeg audio frame');\n break;\n }\n } else if (ID3.isHeader(data, offset)) {\n id3Data = ID3.getID3Data(data, offset);\n id3Samples.push({ pts: stamp, dts: stamp, data: id3Data });\n offset += id3Data.length;\n } else {\n // nothing found, keep looking\n offset++;\n }\n }\n\n this.remuxer.remux(track,\n { samples: [] },\n { samples: id3Samples, inputTimeScale: 90000 },\n { samples: [] },\n timeOffset,\n contiguous,\n accurateTimeOffset);\n }\n\n destroy () {\n }\n}\n\nexport default MP3Demuxer;\n","/**\n * AAC helper\n */\n\nclass AAC {\n static getSilentFrame (codec, channelCount) {\n switch (codec) {\n case 'mp4a.40.2':\n if (channelCount === 1) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x23, 0x80]);\n } else if (channelCount === 2) {\n return new Uint8Array([0x21, 0x00, 0x49, 0x90, 0x02, 0x19, 0x00, 0x23, 0x80]);\n } else if (channelCount === 3) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x8e]);\n } else if (channelCount === 4) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x80, 0x2c, 0x80, 0x08, 0x02, 0x38]);\n } else if (channelCount === 5) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x82, 0x30, 0x04, 0x99, 0x00, 0x21, 0x90, 0x02, 0x38]);\n } else if (channelCount === 6) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x82, 0x30, 0x04, 0x99, 0x00, 0x21, 0x90, 0x02, 0x00, 0xb2, 0x00, 0x20, 0x08, 0xe0]);\n }\n\n break;\n // handle HE-AAC below (mp4a.40.5 / mp4a.40.29)\n default:\n if (channelCount === 1) {\n // ffmpeg -y -f lavfi -i \"aevalsrc=0:d=0.05\" -c:a libfdk_aac -profile:a aac_he -b:a 4k output.aac && hexdump -v -e '16/1 \"0x%x,\" \"\\n\"' -v output.aac\n return new Uint8Array([0x1, 0x40, 0x22, 0x80, 0xa3, 0x4e, 0xe6, 0x80, 0xba, 0x8, 0x0, 0x0, 0x0, 0x1c, 0x6, 0xf1, 0xc1, 0xa, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5e]);\n } else if (channelCount === 2) {\n // ffmpeg -y -f lavfi -i \"aevalsrc=0|0:d=0.05\" -c:a libfdk_aac -profile:a aac_he_v2 -b:a 4k output.aac && hexdump -v -e '16/1 \"0x%x,\" \"\\n\"' -v output.aac\n return new Uint8Array([0x1, 0x40, 0x22, 0x80, 0xa3, 0x5e, 0xe6, 0x80, 0xba, 0x8, 0x0, 0x0, 0x0, 0x0, 0x95, 0x0, 0x6, 0xf1, 0xa1, 0xa, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5e]);\n } else if (channelCount === 3) {\n // ffmpeg -y -f lavfi -i \"aevalsrc=0|0|0:d=0.05\" -c:a libfdk_aac -profile:a aac_he_v2 -b:a 4k output.aac && hexdump -v -e '16/1 \"0x%x,\" \"\\n\"' -v output.aac\n return new Uint8Array([0x1, 0x40, 0x22, 0x80, 0xa3, 0x5e, 0xe6, 0x80, 0xba, 0x8, 0x0, 0x0, 0x0, 0x0, 0x95, 0x0, 0x6, 0xf1, 0xa1, 0xa, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5e]);\n }\n break;\n }\n return null;\n }\n}\n\nexport default AAC;\n","/**\n * Generate MP4 Box\n*/\n\nconst UINT32_MAX = Math.pow(2, 32) - 1;\n\nclass MP4 {\n static init () {\n MP4.types = {\n avc1: [], // codingname\n avcC: [],\n btrt: [],\n dinf: [],\n dref: [],\n esds: [],\n ftyp: [],\n hdlr: [],\n mdat: [],\n mdhd: [],\n mdia: [],\n mfhd: [],\n minf: [],\n moof: [],\n moov: [],\n mp4a: [],\n '.mp3': [],\n mvex: [],\n mvhd: [],\n pasp: [],\n sdtp: [],\n stbl: [],\n stco: [],\n stsc: [],\n stsd: [],\n stsz: [],\n stts: [],\n tfdt: [],\n tfhd: [],\n traf: [],\n trak: [],\n trun: [],\n trex: [],\n tkhd: [],\n vmhd: [],\n smhd: []\n };\n\n let i;\n for (i in MP4.types) {\n if (MP4.types.hasOwnProperty(i)) {\n MP4.types[i] = [\n i.charCodeAt(0),\n i.charCodeAt(1),\n i.charCodeAt(2),\n i.charCodeAt(3)\n ];\n }\n }\n\n let videoHdlr = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x76, 0x69, 0x64, 0x65, // handler_type: 'vide'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x56, 0x69, 0x64, 0x65,\n 0x6f, 0x48, 0x61, 0x6e,\n 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'VideoHandler'\n ]);\n\n let audioHdlr = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x73, 0x6f, 0x75, 0x6e, // handler_type: 'soun'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x53, 0x6f, 0x75, 0x6e,\n 0x64, 0x48, 0x61, 0x6e,\n 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'SoundHandler'\n ]);\n\n MP4.HDLR_TYPES = {\n 'video': videoHdlr,\n 'audio': audioHdlr\n };\n\n let dref = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01, // entry_count\n 0x00, 0x00, 0x00, 0x0c, // entry_size\n 0x75, 0x72, 0x6c, 0x20, // 'url' type\n 0x00, // version 0\n 0x00, 0x00, 0x01 // entry_flags\n ]);\n\n let stco = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00 // entry_count\n ]);\n\n MP4.STTS = MP4.STSC = MP4.STCO = stco;\n\n MP4.STSZ = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // sample_size\n 0x00, 0x00, 0x00, 0x00 // sample_count\n ]);\n MP4.VMHD = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x01, // flags\n 0x00, 0x00, // graphicsmode\n 0x00, 0x00,\n 0x00, 0x00,\n 0x00, 0x00 // opcolor\n ]);\n MP4.SMHD = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, // balance\n 0x00, 0x00 // reserved\n ]);\n\n MP4.STSD = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01]);// entry_count\n\n let majorBrand = new Uint8Array([105, 115, 111, 109]); // isom\n let avc1Brand = new Uint8Array([97, 118, 99, 49]); // avc1\n let minorVersion = new Uint8Array([0, 0, 0, 1]);\n\n MP4.FTYP = MP4.box(MP4.types.ftyp, majorBrand, minorVersion, majorBrand, avc1Brand);\n MP4.DINF = MP4.box(MP4.types.dinf, MP4.box(MP4.types.dref, dref));\n }\n\n static box (type) {\n let\n payload = Array.prototype.slice.call(arguments, 1),\n size = 8,\n i = payload.length,\n len = i,\n result;\n // calculate the total size we need to allocate\n while (i--) {\n size += payload[i].byteLength;\n }\n\n result = new Uint8Array(size);\n result[0] = (size >> 24) & 0xff;\n result[1] = (size >> 16) & 0xff;\n result[2] = (size >> 8) & 0xff;\n result[3] = size & 0xff;\n result.set(type, 4);\n // copy the payload into the result\n for (i = 0, size = 8; i < len; i++) {\n // copy payload[i] array @ offset size\n result.set(payload[i], size);\n size += payload[i].byteLength;\n }\n return result;\n }\n\n static hdlr (type) {\n return MP4.box(MP4.types.hdlr, MP4.HDLR_TYPES[type]);\n }\n\n static mdat (data) {\n return MP4.box(MP4.types.mdat, data);\n }\n\n static mdhd (timescale, duration) {\n duration *= timescale;\n const upperWordDuration = Math.floor(duration / (UINT32_MAX + 1));\n const lowerWordDuration = Math.floor(duration % (UINT32_MAX + 1));\n return MP4.box(MP4.types.mdhd, new Uint8Array([\n 0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, // modification_time\n (timescale >> 24) & 0xFF,\n (timescale >> 16) & 0xFF,\n (timescale >> 8) & 0xFF,\n timescale & 0xFF, // timescale\n (upperWordDuration >> 24),\n (upperWordDuration >> 16) & 0xFF,\n (upperWordDuration >> 8) & 0xFF,\n upperWordDuration & 0xFF,\n (lowerWordDuration >> 24),\n (lowerWordDuration >> 16) & 0xFF,\n (lowerWordDuration >> 8) & 0xFF,\n lowerWordDuration & 0xFF,\n 0x55, 0xc4, // 'und' language (undetermined)\n 0x00, 0x00\n ]));\n }\n\n static mdia (track) {\n return MP4.box(MP4.types.mdia, MP4.mdhd(track.timescale, track.duration), MP4.hdlr(track.type), MP4.minf(track));\n }\n\n static mfhd (sequenceNumber) {\n return MP4.box(MP4.types.mfhd, new Uint8Array([\n 0x00,\n 0x00, 0x00, 0x00, // flags\n (sequenceNumber >> 24),\n (sequenceNumber >> 16) & 0xFF,\n (sequenceNumber >> 8) & 0xFF,\n sequenceNumber & 0xFF // sequence_number\n ]));\n }\n\n static minf (track) {\n if (track.type === 'audio') {\n return MP4.box(MP4.types.minf, MP4.box(MP4.types.smhd, MP4.SMHD), MP4.DINF, MP4.stbl(track));\n } else {\n return MP4.box(MP4.types.minf, MP4.box(MP4.types.vmhd, MP4.VMHD), MP4.DINF, MP4.stbl(track));\n }\n }\n\n static moof (sn, baseMediaDecodeTime, track) {\n return MP4.box(MP4.types.moof, MP4.mfhd(sn), MP4.traf(track, baseMediaDecodeTime));\n }\n /**\n * @param tracks... (optional) {array} the tracks associated with this movie\n */\n static moov (tracks) {\n let\n i = tracks.length,\n boxes = [];\n\n while (i--) {\n boxes[i] = MP4.trak(tracks[i]);\n }\n\n return MP4.box.apply(null, [MP4.types.moov, MP4.mvhd(tracks[0].timescale, tracks[0].duration)].concat(boxes).concat(MP4.mvex(tracks)));\n }\n\n static mvex (tracks) {\n let\n i = tracks.length,\n boxes = [];\n\n while (i--) {\n boxes[i] = MP4.trex(tracks[i]);\n }\n\n return MP4.box.apply(null, [MP4.types.mvex].concat(boxes));\n }\n\n static mvhd (timescale, duration) {\n duration *= timescale;\n const upperWordDuration = Math.floor(duration / (UINT32_MAX + 1));\n const lowerWordDuration = Math.floor(duration % (UINT32_MAX + 1));\n let\n bytes = new Uint8Array([\n 0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, // modification_time\n (timescale >> 24) & 0xFF,\n (timescale >> 16) & 0xFF,\n (timescale >> 8) & 0xFF,\n timescale & 0xFF, // timescale\n (upperWordDuration >> 24),\n (upperWordDuration >> 16) & 0xFF,\n (upperWordDuration >> 8) & 0xFF,\n upperWordDuration & 0xFF,\n (lowerWordDuration >> 24),\n (lowerWordDuration >> 16) & 0xFF,\n (lowerWordDuration >> 8) & 0xFF,\n lowerWordDuration & 0xFF,\n 0x00, 0x01, 0x00, 0x00, // 1.0 rate\n 0x01, 0x00, // 1.0 volume\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0xff, 0xff, 0xff, 0xff // next_track_ID\n ]);\n return MP4.box(MP4.types.mvhd, bytes);\n }\n\n static sdtp (track) {\n let\n samples = track.samples || [],\n bytes = new Uint8Array(4 + samples.length),\n flags,\n i;\n // leave the full box header (4 bytes) all zero\n // write the sample table\n for (i = 0; i < samples.length; i++) {\n flags = samples[i].flags;\n bytes[i + 4] = (flags.dependsOn << 4) |\n (flags.isDependedOn << 2) |\n (flags.hasRedundancy);\n }\n\n return MP4.box(MP4.types.sdtp, bytes);\n }\n\n static stbl (track) {\n return MP4.box(MP4.types.stbl, MP4.stsd(track), MP4.box(MP4.types.stts, MP4.STTS), MP4.box(MP4.types.stsc, MP4.STSC), MP4.box(MP4.types.stsz, MP4.STSZ), MP4.box(MP4.types.stco, MP4.STCO));\n }\n\n static avc1 (track) {\n let sps = [], pps = [], i, data, len;\n // assemble the SPSs\n\n for (i = 0; i < track.sps.length; i++) {\n data = track.sps[i];\n len = data.byteLength;\n sps.push((len >>> 8) & 0xFF);\n sps.push((len & 0xFF));\n\n // SPS\n sps = sps.concat(Array.prototype.slice.call(data));\n }\n\n // assemble the PPSs\n for (i = 0; i < track.pps.length; i++) {\n data = track.pps[i];\n len = data.byteLength;\n pps.push((len >>> 8) & 0xFF);\n pps.push((len & 0xFF));\n\n pps = pps.concat(Array.prototype.slice.call(data));\n }\n\n let avcc = MP4.box(MP4.types.avcC, new Uint8Array([\n 0x01, // version\n sps[3], // profile\n sps[4], // profile compat\n sps[5], // level\n 0xfc | 3, // lengthSizeMinusOne, hard-coded to 4 bytes\n 0xE0 | track.sps.length // 3bit reserved (111) + numOfSequenceParameterSets\n ].concat(sps).concat([\n track.pps.length // numOfPictureParameterSets\n ]).concat(pps))), // \"PPS\"\n width = track.width,\n height = track.height,\n hSpacing = track.pixelRatio[0],\n vSpacing = track.pixelRatio[1];\n\n return MP4.box(MP4.types.avc1, new Uint8Array([\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, // pre_defined\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n (width >> 8) & 0xFF,\n width & 0xff, // width\n (height >> 8) & 0xFF,\n height & 0xff, // height\n 0x00, 0x48, 0x00, 0x00, // horizresolution\n 0x00, 0x48, 0x00, 0x00, // vertresolution\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // frame_count\n 0x12,\n 0x64, 0x61, 0x69, 0x6C, // dailymotion/hls.js\n 0x79, 0x6D, 0x6F, 0x74,\n 0x69, 0x6F, 0x6E, 0x2F,\n 0x68, 0x6C, 0x73, 0x2E,\n 0x6A, 0x73, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, // compressorname\n 0x00, 0x18, // depth = 24\n 0x11, 0x11]), // pre_defined = -1\n avcc,\n MP4.box(MP4.types.btrt, new Uint8Array([\n 0x00, 0x1c, 0x9c, 0x80, // bufferSizeDB\n 0x00, 0x2d, 0xc6, 0xc0, // maxBitrate\n 0x00, 0x2d, 0xc6, 0xc0])), // avgBitrate\n MP4.box(MP4.types.pasp, new Uint8Array([\n (hSpacing >> 24), // hSpacing\n (hSpacing >> 16) & 0xFF,\n (hSpacing >> 8) & 0xFF,\n hSpacing & 0xFF,\n (vSpacing >> 24), // vSpacing\n (vSpacing >> 16) & 0xFF,\n (vSpacing >> 8) & 0xFF,\n vSpacing & 0xFF]))\n );\n }\n\n static esds (track) {\n let configlen = track.config.length;\n return new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n\n 0x03, // descriptor_type\n 0x17 + configlen, // length\n 0x00, 0x01, // es_id\n 0x00, // stream_priority\n\n 0x04, // descriptor_type\n 0x0f + configlen, // length\n 0x40, // codec : mpeg4_audio\n 0x15, // stream_type\n 0x00, 0x00, 0x00, // buffer_size\n 0x00, 0x00, 0x00, 0x00, // maxBitrate\n 0x00, 0x00, 0x00, 0x00, // avgBitrate\n\n 0x05 // descriptor_type\n ].concat([configlen]).concat(track.config).concat([0x06, 0x01, 0x02])); // GASpecificConfig)); // length + audio config descriptor\n }\n\n static mp4a (track) {\n let samplerate = track.samplerate;\n return MP4.box(MP4.types.mp4a, new Uint8Array([\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, track.channelCount, // channelcount\n 0x00, 0x10, // sampleSize:16bits\n 0x00, 0x00, 0x00, 0x00, // reserved2\n (samplerate >> 8) & 0xFF,\n samplerate & 0xff, //\n 0x00, 0x00]),\n MP4.box(MP4.types.esds, MP4.esds(track)));\n }\n\n static mp3 (track) {\n let samplerate = track.samplerate;\n return MP4.box(MP4.types['.mp3'], new Uint8Array([\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, track.channelCount, // channelcount\n 0x00, 0x10, // sampleSize:16bits\n 0x00, 0x00, 0x00, 0x00, // reserved2\n (samplerate >> 8) & 0xFF,\n samplerate & 0xff, //\n 0x00, 0x00]));\n }\n\n static stsd (track) {\n if (track.type === 'audio') {\n if (!track.isAAC && track.codec === 'mp3') {\n return MP4.box(MP4.types.stsd, MP4.STSD, MP4.mp3(track));\n }\n\n return MP4.box(MP4.types.stsd, MP4.STSD, MP4.mp4a(track));\n } else {\n return MP4.box(MP4.types.stsd, MP4.STSD, MP4.avc1(track));\n }\n }\n\n static tkhd (track) {\n let id = track.id,\n duration = track.duration * track.timescale,\n width = track.width,\n height = track.height,\n upperWordDuration = Math.floor(duration / (UINT32_MAX + 1)),\n lowerWordDuration = Math.floor(duration % (UINT32_MAX + 1));\n return MP4.box(MP4.types.tkhd, new Uint8Array([\n 0x01, // version 1\n 0x00, 0x00, 0x07, // flags\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, // modification_time\n (id >> 24) & 0xFF,\n (id >> 16) & 0xFF,\n (id >> 8) & 0xFF,\n id & 0xFF, // track_ID\n 0x00, 0x00, 0x00, 0x00, // reserved\n (upperWordDuration >> 24),\n (upperWordDuration >> 16) & 0xFF,\n (upperWordDuration >> 8) & 0xFF,\n upperWordDuration & 0xFF,\n (lowerWordDuration >> 24),\n (lowerWordDuration >> 16) & 0xFF,\n (lowerWordDuration >> 8) & 0xFF,\n lowerWordDuration & 0xFF,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, // layer\n 0x00, 0x00, // alternate_group\n 0x00, 0x00, // non-audio track volume\n 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n (width >> 8) & 0xFF,\n width & 0xFF,\n 0x00, 0x00, // width\n (height >> 8) & 0xFF,\n height & 0xFF,\n 0x00, 0x00 // height\n ]));\n }\n\n static traf (track, baseMediaDecodeTime) {\n let sampleDependencyTable = MP4.sdtp(track),\n id = track.id,\n upperWordBaseMediaDecodeTime = Math.floor(baseMediaDecodeTime / (UINT32_MAX + 1)),\n lowerWordBaseMediaDecodeTime = Math.floor(baseMediaDecodeTime % (UINT32_MAX + 1));\n return MP4.box(MP4.types.traf,\n MP4.box(MP4.types.tfhd, new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n (id >> 24),\n (id >> 16) & 0XFF,\n (id >> 8) & 0XFF,\n (id & 0xFF) // track_ID\n ])),\n MP4.box(MP4.types.tfdt, new Uint8Array([\n 0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n (upperWordBaseMediaDecodeTime >> 24),\n (upperWordBaseMediaDecodeTime >> 16) & 0XFF,\n (upperWordBaseMediaDecodeTime >> 8) & 0XFF,\n (upperWordBaseMediaDecodeTime & 0xFF),\n (lowerWordBaseMediaDecodeTime >> 24),\n (lowerWordBaseMediaDecodeTime >> 16) & 0XFF,\n (lowerWordBaseMediaDecodeTime >> 8) & 0XFF,\n (lowerWordBaseMediaDecodeTime & 0xFF)\n ])),\n MP4.trun(track,\n sampleDependencyTable.length +\n 16 + // tfhd\n 20 + // tfdt\n 8 + // traf header\n 16 + // mfhd\n 8 + // moof header\n 8), // mdat header\n sampleDependencyTable);\n }\n\n /**\n * Generate a track box.\n * @param track {object} a track definition\n * @return {Uint8Array} the track box\n */\n static trak (track) {\n track.duration = track.duration || 0xffffffff;\n return MP4.box(MP4.types.trak, MP4.tkhd(track), MP4.mdia(track));\n }\n\n static trex (track) {\n let id = track.id;\n return MP4.box(MP4.types.trex, new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n (id >> 24),\n (id >> 16) & 0XFF,\n (id >> 8) & 0XFF,\n (id & 0xFF), // track_ID\n 0x00, 0x00, 0x00, 0x01, // default_sample_description_index\n 0x00, 0x00, 0x00, 0x00, // default_sample_duration\n 0x00, 0x00, 0x00, 0x00, // default_sample_size\n 0x00, 0x01, 0x00, 0x01 // default_sample_flags\n ]));\n }\n\n static trun (track, offset) {\n let samples = track.samples || [],\n len = samples.length,\n arraylen = 12 + (16 * len),\n array = new Uint8Array(arraylen),\n i, sample, duration, size, flags, cts;\n offset += 8 + arraylen;\n array.set([\n 0x00, // version 0\n 0x00, 0x0f, 0x01, // flags\n (len >>> 24) & 0xFF,\n (len >>> 16) & 0xFF,\n (len >>> 8) & 0xFF,\n len & 0xFF, // sample_count\n (offset >>> 24) & 0xFF,\n (offset >>> 16) & 0xFF,\n (offset >>> 8) & 0xFF,\n offset & 0xFF // data_offset\n ], 0);\n for (i = 0; i < len; i++) {\n sample = samples[i];\n duration = sample.duration;\n size = sample.size;\n flags = sample.flags;\n cts = sample.cts;\n array.set([\n (duration >>> 24) & 0xFF,\n (duration >>> 16) & 0xFF,\n (duration >>> 8) & 0xFF,\n duration & 0xFF, // sample_duration\n (size >>> 24) & 0xFF,\n (size >>> 16) & 0xFF,\n (size >>> 8) & 0xFF,\n size & 0xFF, // sample_size\n (flags.isLeading << 2) | flags.dependsOn,\n (flags.isDependedOn << 6) |\n (flags.hasRedundancy << 4) |\n (flags.paddingValue << 1) |\n flags.isNonSync,\n flags.degradPrio & 0xF0 << 8,\n flags.degradPrio & 0x0F, // sample_flags\n (cts >>> 24) & 0xFF,\n (cts >>> 16) & 0xFF,\n (cts >>> 8) & 0xFF,\n cts & 0xFF // sample_composition_time_offset\n ], 12 + 16 * i);\n }\n return MP4.box(MP4.types.trun, array);\n }\n\n static initSegment (tracks) {\n if (!MP4.types) {\n MP4.init();\n }\n\n let movie = MP4.moov(tracks), result;\n result = new Uint8Array(MP4.FTYP.byteLength + movie.byteLength);\n result.set(MP4.FTYP);\n result.set(movie, MP4.FTYP.byteLength);\n return result;\n }\n}\n\nexport default MP4;\n","const MPEG_TS_CLOCK_FREQ_HZ = 90000;\n\nexport function toTimescaleFromScale (value, destScale: number, srcScale: number = 1, round: boolean = false): number {\n return toTimescaleFromBase(value, destScale, 1 / srcScale);\n}\n\nexport function toTimescaleFromBase (value, destScale: number, srcBase: number = 1, round: boolean = false): number {\n const result = value * destScale * srcBase; // equivalent to `(value * scale) / (1 / base)`\n return round ? Math.round(result) : result;\n}\n\nexport function toMsFromMpegTsClock (value: number, round: boolean = false): number {\n return toTimescaleFromBase(value, 1000, 1 / MPEG_TS_CLOCK_FREQ_HZ, round);\n}\n\nexport function toMpegTsClockFromTimescale (value: number, srcScale: number = 1): number {\n return toTimescaleFromBase(value, MPEG_TS_CLOCK_FREQ_HZ, 1 / srcScale);\n}\n","/**\n * fMP4 remuxer\n*/\n\nimport AAC from './aac-helper';\nimport MP4 from './mp4-generator';\n\nimport Event from '../events';\nimport { ErrorTypes, ErrorDetails } from '../errors';\n\nimport { toMsFromMpegTsClock, toMpegTsClockFromTimescale } from '../utils/timescale-conversion';\n\nimport { logger } from '../utils/logger';\n\nconst MAX_SILENT_FRAME_DURATION_90KHZ = toMpegTsClockFromTimescale(10);\nconst PTS_DTS_SHIFT_TOLERANCE_90KHZ = toMpegTsClockFromTimescale(0.2);\n\nlet chromeVersion = null;\n\nclass MP4Remuxer {\n constructor (observer, config, typeSupported, vendor) {\n this.observer = observer;\n this.config = config;\n this.typeSupported = typeSupported;\n this.ISGenerated = false;\n if (chromeVersion === null) {\n const result = navigator.userAgent.match(/Chrome\\/(\\d+)/i);\n chromeVersion = result ? parseInt(result[1]) : 0;\n }\n }\n\n destroy () {\n }\n\n resetTimeStamp (defaultTimeStamp) {\n this._initPTS = this._initDTS = defaultTimeStamp;\n }\n\n resetInitSegment () {\n this.ISGenerated = false;\n }\n\n getVideoStartPts (videoSamples) {\n let rolloverDetected = false;\n const startPTS = videoSamples.reduce((minPTS, sample) => {\n const delta = sample.pts - minPTS;\n if (delta < -4294967296) { // 2^32, see PTSNormalize for reasoning, but we're hitting a rollover here, and we don't want that to impact the timeOffset calculation\n rolloverDetected = true;\n return PTSNormalize(minPTS, sample.pts);\n } else if (delta > 0) {\n return minPTS;\n } else {\n return sample.pts;\n }\n }, videoSamples[0].pts);\n if (rolloverDetected) {\n logger.debug('PTS rollover detected');\n }\n return startPTS;\n }\n\n remux (audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset) {\n // generate Init Segment if needed\n if (!this.ISGenerated) {\n this.generateIS(audioTrack, videoTrack, timeOffset);\n }\n\n if (this.ISGenerated) {\n const nbAudioSamples = audioTrack.samples.length;\n const nbVideoSamples = videoTrack.samples.length;\n let audioTimeOffset = timeOffset;\n let videoTimeOffset = timeOffset;\n if (nbAudioSamples && nbVideoSamples) {\n // timeOffset is expected to be the offset of the first timestamp of this fragment (first DTS)\n // if first audio DTS is not aligned with first video DTS then we need to take that into account\n // when providing timeOffset to remuxAudio / remuxVideo. if we don't do that, there might be a permanent / small\n // drift between audio and video streams\n const startPTS = this.getVideoStartPts(videoTrack.samples);\n const tsDelta = PTSNormalize(audioTrack.samples[0].pts, startPTS) - startPTS;\n const audiovideoTimestampDelta = tsDelta / videoTrack.inputTimeScale;\n audioTimeOffset += Math.max(0, audiovideoTimestampDelta);\n videoTimeOffset += Math.max(0, -audiovideoTimestampDelta);\n }\n // Purposefully remuxing audio before video, so that remuxVideo can use nextAudioPts, which is\n // calculated in remuxAudio.\n // logger.log('nb AAC samples:' + audioTrack.samples.length);\n if (nbAudioSamples) {\n // if initSegment was generated without video samples, regenerate it again\n if (!audioTrack.timescale) {\n logger.warn('regenerate InitSegment as audio detected');\n this.generateIS(audioTrack, videoTrack, timeOffset);\n }\n let audioData = this.remuxAudio(audioTrack, audioTimeOffset, contiguous, accurateTimeOffset);\n // logger.log('nb AVC samples:' + videoTrack.samples.length);\n if (nbVideoSamples) {\n let audioTrackLength;\n if (audioData) {\n audioTrackLength = audioData.endPTS - audioData.startPTS;\n }\n\n // if initSegment was generated without video samples, regenerate it again\n if (!videoTrack.timescale) {\n logger.warn('regenerate InitSegment as video detected');\n this.generateIS(audioTrack, videoTrack, timeOffset);\n }\n this.remuxVideo(videoTrack, videoTimeOffset, contiguous, audioTrackLength);\n }\n } else {\n // logger.log('nb AVC samples:' + videoTrack.samples.length);\n if (nbVideoSamples) {\n let videoData = this.remuxVideo(videoTrack, videoTimeOffset, contiguous, 0, accurateTimeOffset);\n if (videoData && audioTrack.codec) {\n this.remuxEmptyAudio(audioTrack, audioTimeOffset, contiguous, videoData);\n }\n }\n }\n }\n // logger.log('nb ID3 samples:' + audioTrack.samples.length);\n if (id3Track.samples.length) {\n this.remuxID3(id3Track, timeOffset);\n }\n\n // logger.log('nb ID3 samples:' + audioTrack.samples.length);\n if (textTrack.samples.length) {\n this.remuxText(textTrack, timeOffset);\n }\n\n // notify end of parsing\n this.observer.trigger(Event.FRAG_PARSED);\n }\n\n generateIS (audioTrack, videoTrack, timeOffset) {\n let observer = this.observer,\n audioSamples = audioTrack.samples,\n videoSamples = videoTrack.samples,\n typeSupported = this.typeSupported,\n container = 'audio/mp4',\n tracks = {},\n data = { tracks },\n computePTSDTS = (this._initPTS === undefined),\n initPTS, initDTS;\n\n if (computePTSDTS) {\n initPTS = initDTS = Infinity;\n }\n\n if (audioTrack.config && audioSamples.length) {\n // let's use audio sampling rate as MP4 time scale.\n // rationale is that there is a integer nb of audio frames per audio sample (1024 for AAC)\n // using audio sampling rate here helps having an integer MP4 frame duration\n // this avoids potential rounding issue and AV sync issue\n audioTrack.timescale = audioTrack.samplerate;\n logger.log(`audio sampling rate : ${audioTrack.samplerate}`);\n if (!audioTrack.isAAC) {\n if (typeSupported.mpeg) { // Chrome and Safari\n container = 'audio/mpeg';\n audioTrack.codec = '';\n } else if (typeSupported.mp3) { // Firefox\n audioTrack.codec = 'mp3';\n }\n }\n tracks.audio = {\n container: container,\n codec: audioTrack.codec,\n initSegment: !audioTrack.isAAC && typeSupported.mpeg ? new Uint8Array() : MP4.initSegment([audioTrack]),\n metadata: {\n channelCount: audioTrack.channelCount\n }\n };\n if (computePTSDTS) {\n // remember first PTS of this demuxing context. for audio, PTS = DTS\n initPTS = initDTS = audioSamples[0].pts - Math.round(audioTrack.inputTimeScale * timeOffset);\n }\n }\n\n if (videoTrack.sps && videoTrack.pps && videoSamples.length) {\n // let's use input time scale as MP4 video timescale\n // we use input time scale straight away to avoid rounding issues on frame duration / cts computation\n const inputTimeScale = videoTrack.inputTimeScale;\n videoTrack.timescale = inputTimeScale;\n tracks.video = {\n container: 'video/mp4',\n codec: videoTrack.codec,\n initSegment: MP4.initSegment([videoTrack]),\n metadata: {\n width: videoTrack.width,\n height: videoTrack.height\n }\n };\n if (computePTSDTS) {\n const startPTS = this.getVideoStartPts(videoSamples);\n const startOffset = Math.round(inputTimeScale * timeOffset);\n initDTS = Math.min(initDTS, PTSNormalize(videoSamples[0].dts, startPTS) - startOffset);\n initPTS = Math.min(initPTS, startPTS - startOffset);\n this.observer.trigger(Event.INIT_PTS_FOUND, { initPTS });\n }\n } else if (computePTSDTS && tracks.audio) {\n // initPTS found for audio-only stream with main and alt audio\n this.observer.trigger(Event.INIT_PTS_FOUND, { initPTS });\n }\n\n if (Object.keys(tracks).length) {\n observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT, data);\n this.ISGenerated = true;\n if (computePTSDTS) {\n this._initPTS = initPTS;\n this._initDTS = initDTS;\n }\n } else {\n observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: false, reason: 'no audio/video samples found' });\n }\n }\n\n remuxVideo (track, timeOffset, contiguous, audioTrackLength) {\n const timeScale = track.timescale;\n const inputSamples = track.samples;\n const outputSamples = [];\n const nbSamples = inputSamples.length;\n const initPTS = this._initPTS;\n\n let offset = 8;\n let mp4SampleDuration;\n let mdat;\n let moof;\n let firstDTS;\n let lastDTS;\n let minPTS = Number.POSITIVE_INFINITY;\n let maxPTS = Number.NEGATIVE_INFINITY;\n let ptsDtsShift = 0;\n let sortSamples = false;\n\n // if parsed fragment is contiguous with last one, let's use last DTS value as reference\n let nextAvcDts = this.nextAvcDts;\n\n if (nbSamples === 0) {\n return;\n }\n\n if (!contiguous) {\n const pts = timeOffset * timeScale;\n const cts = inputSamples[0].pts - PTSNormalize(inputSamples[0].dts, inputSamples[0].pts);\n // if not contiguous, let's use target timeOffset\n nextAvcDts = pts - cts;\n }\n\n // PTS is coded on 33bits, and can loop from -2^32 to 2^32\n // PTSNormalize will make PTS/DTS value monotonic, we use last known DTS value as reference value\n for (let i = 0; i < nbSamples; i++) {\n const sample = inputSamples[i];\n sample.pts = PTSNormalize(sample.pts - initPTS, nextAvcDts);\n sample.dts = PTSNormalize(sample.dts - initPTS, nextAvcDts);\n if (sample.dts > sample.pts) {\n ptsDtsShift = Math.max(Math.min(ptsDtsShift, sample.pts - sample.dts), -1 * PTS_DTS_SHIFT_TOLERANCE_90KHZ);\n }\n if (sample.dts < inputSamples[i > 0 ? i - 1 : i].dts) {\n sortSamples = true;\n }\n }\n\n // sort video samples by DTS then PTS then demux id order\n if (sortSamples) {\n inputSamples.sort(function (a, b) {\n const deltadts = a.dts - b.dts;\n const deltapts = a.pts - b.pts;\n return deltadts || (deltapts || (a.id - b.id));\n });\n }\n\n // Get first/last DTS\n firstDTS = inputSamples[0].dts;\n lastDTS = inputSamples[nbSamples - 1].dts;\n\n // on Safari let's signal the same sample duration for all samples\n // sample duration (as expected by trun MP4 boxes), should be the delta between sample DTS\n // set this constant duration as being the avg delta between consecutive DTS.\n const averageSampleDuration = Math.round((lastDTS - firstDTS) / (nbSamples - 1));\n\n // handle broken streams with PTS < DTS, tolerance up 0.2 seconds\n if (ptsDtsShift < 0) {\n if (ptsDtsShift < averageSampleDuration * -2) {\n // Fix for \"CNN special report, with CC\" in test-streams (including Safari browser)\n // With large PTS < DTS errors such as this, we want to correct CTS while maintaining increasing DTS values\n logger.warn(`PTS < DTS detected in video samples, offsetting DTS from PTS by ${toMsFromMpegTsClock(-averageSampleDuration, true)} ms`);\n let lastDts = ptsDtsShift;\n for (let i = 0; i < nbSamples; i++) {\n inputSamples[i].dts = lastDts = Math.max(lastDts, inputSamples[i].pts - averageSampleDuration);\n inputSamples[i].pts = Math.max(lastDts, inputSamples[i].pts);\n }\n } else {\n // Fix for \"Custom IV with bad PTS DTS\" in test-streams\n // With smaller PTS < DTS errors we can simply move all DTS back. This increases CTS without causing buffer gaps or decode errors in Safari\n logger.warn(`PTS < DTS detected in video samples, shifting DTS by ${toMsFromMpegTsClock(ptsDtsShift, true)} ms to overcome this issue`);\n for (let i = 0; i < nbSamples; i++) {\n inputSamples[i].dts = inputSamples[i].dts + ptsDtsShift;\n }\n }\n firstDTS = inputSamples[0].dts;\n lastDTS = inputSamples[nbSamples - 1].dts;\n }\n\n // if fragment are contiguous, detect hole/overlapping between fragments\n if (contiguous) {\n // check timestamp continuity across consecutive fragments (this is to remove inter-fragment gap/hole)\n const delta = firstDTS - nextAvcDts;\n const foundHole = delta > averageSampleDuration;\n const foundOverlap = delta < -1;\n if (foundHole || foundOverlap) {\n if (foundHole) {\n logger.warn(`AVC: ${toMsFromMpegTsClock(delta, true)} ms (${delta}dts) hole between fragments detected, filling it`);\n } else {\n logger.warn(`AVC: ${toMsFromMpegTsClock(-delta, true)} ms (${delta}dts) overlapping between fragments detected`);\n }\n firstDTS = nextAvcDts;\n const firstPTS = inputSamples[0].pts - delta;\n inputSamples[0].dts = firstDTS;\n inputSamples[0].pts = firstPTS;\n logger.log(`Video: First PTS/DTS adjusted: ${toMsFromMpegTsClock(firstPTS, true)}/${toMsFromMpegTsClock(firstDTS, true)}, delta: ${toMsFromMpegTsClock(delta, true)} ms`);\n }\n }\n\n if (chromeVersion && chromeVersion < 75) {\n firstDTS = Math.max(0, firstDTS);\n }\n let nbNalu = 0;\n let naluLen = 0;\n for (let i = 0; i < nbSamples; i++) {\n // compute total/avc sample length and nb of NAL units\n const sample = inputSamples[i];\n const units = sample.units;\n const nbUnits = units.length;\n let sampleLen = 0;\n for (let j = 0; j < nbUnits; j++) {\n sampleLen += units[j].data.length;\n }\n\n naluLen += sampleLen;\n nbNalu += nbUnits;\n sample.length = sampleLen;\n\n // normalize PTS/DTS\n // ensure sample monotonic DTS\n sample.dts = Math.max(sample.dts, firstDTS);\n // ensure that computed value is greater or equal than sample DTS\n sample.pts = Math.max(sample.pts, sample.dts, 0);\n minPTS = Math.min(sample.pts, minPTS);\n maxPTS = Math.max(sample.pts, maxPTS);\n }\n lastDTS = inputSamples[nbSamples - 1].dts;\n\n /* concatenate the video data and construct the mdat in place\n (need 8 more bytes to fill length and mpdat type) */\n let mdatSize = naluLen + (4 * nbNalu) + 8;\n try {\n mdat = new Uint8Array(mdatSize);\n } catch (err) {\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MUX_ERROR, details: ErrorDetails.REMUX_ALLOC_ERROR, fatal: false, bytes: mdatSize, reason: `fail allocating video mdat ${mdatSize}` });\n return;\n }\n let view = new DataView(mdat.buffer);\n view.setUint32(0, mdatSize);\n mdat.set(MP4.types.mdat, 4);\n\n for (let i = 0; i < nbSamples; i++) {\n const avcSample = inputSamples[i];\n const avcSampleUnits = avcSample.units;\n let mp4SampleLength = 0;\n let compositionTimeOffset;\n // convert NALU bitstream to MP4 format (prepend NALU with size field)\n for (let j = 0, nbUnits = avcSampleUnits.length; j < nbUnits; j++) {\n const unit = avcSampleUnits[j];\n const unitData = unit.data;\n const unitDataLen = unit.data.byteLength;\n view.setUint32(offset, unitDataLen);\n offset += 4;\n mdat.set(unitData, offset);\n offset += unitDataLen;\n mp4SampleLength += 4 + unitDataLen;\n }\n\n // expected sample duration is the Decoding Timestamp diff of consecutive samples\n if (i < nbSamples - 1) {\n mp4SampleDuration = inputSamples[i + 1].dts - avcSample.dts;\n } else {\n const config = this.config;\n const lastFrameDuration = avcSample.dts - inputSamples[i > 0 ? i - 1 : i].dts;\n if (config.stretchShortVideoTrack) {\n // In some cases, a segment's audio track duration may exceed the video track duration.\n // Since we've already remuxed audio, and we know how long the audio track is, we look to\n // see if the delta to the next segment is longer than maxBufferHole.\n // If so, playback would potentially get stuck, so we artificially inflate\n // the duration of the last frame to minimize any potential gap between segments.\n const maxBufferHole = config.maxBufferHole;\n const gapTolerance = Math.floor(maxBufferHole * timeScale);\n const deltaToFrameEnd = (audioTrackLength ? minPTS + audioTrackLength * timeScale : this.nextAudioPts) - avcSample.pts;\n if (deltaToFrameEnd > gapTolerance) {\n // We subtract lastFrameDuration from deltaToFrameEnd to try to prevent any video\n // frame overlap. maxBufferHole should be >> lastFrameDuration anyway.\n mp4SampleDuration = deltaToFrameEnd - lastFrameDuration;\n if (mp4SampleDuration < 0) {\n mp4SampleDuration = lastFrameDuration;\n }\n\n logger.log(`It is approximately ${toMsFromMpegTsClock(deltaToFrameEnd, false)} ms to the next segment; using duration ${toMsFromMpegTsClock(mp4SampleDuration, false)} ms for the last video frame.`);\n } else {\n mp4SampleDuration = lastFrameDuration;\n }\n } else {\n mp4SampleDuration = lastFrameDuration;\n }\n }\n compositionTimeOffset = Math.round(avcSample.pts - avcSample.dts);\n\n // console.log('PTS/DTS/initDTS/normPTS/normDTS/relative PTS : ${avcSample.pts}/${avcSample.dts}/${initDTS}/${ptsnorm}/${dtsnorm}/${(avcSample.pts/4294967296).toFixed(3)}');\n outputSamples.push({\n size: mp4SampleLength,\n // constant duration\n duration: mp4SampleDuration,\n cts: compositionTimeOffset,\n flags: {\n isLeading: 0,\n isDependedOn: 0,\n hasRedundancy: 0,\n degradPrio: 0,\n dependsOn: avcSample.key ? 2 : 1,\n isNonSync: avcSample.key ? 0 : 1\n }\n });\n }\n // next AVC sample DTS should be equal to last sample DTS + last sample duration (in PES timescale)\n this.nextAvcDts = lastDTS + mp4SampleDuration;\n const dropped = track.dropped;\n track.nbNalu = 0;\n track.dropped = 0;\n if (outputSamples.length && navigator.userAgent.toLowerCase().indexOf('chrome') > -1) {\n const flags = outputSamples[0].flags;\n // chrome workaround, mark first sample as being a Random Access Point to avoid sourcebuffer append issue\n // https://code.google.com/p/chromium/issues/detail?id=229412\n flags.dependsOn = 2;\n flags.isNonSync = 0;\n }\n track.samples = outputSamples;\n moof = MP4.moof(track.sequenceNumber++, firstDTS, track);\n track.samples = [];\n\n const data = {\n data1: moof,\n data2: mdat,\n startPTS: minPTS / timeScale,\n endPTS: (maxPTS + mp4SampleDuration) / timeScale,\n startDTS: firstDTS / timeScale,\n endDTS: this.nextAvcDts / timeScale,\n type: 'video',\n hasAudio: false,\n hasVideo: true,\n nb: outputSamples.length,\n dropped: dropped\n };\n this.observer.trigger(Event.FRAG_PARSING_DATA, data);\n return data;\n }\n\n remuxAudio (track, timeOffset, contiguous, accurateTimeOffset) {\n const inputTimeScale = track.inputTimeScale;\n const mp4timeScale = track.timescale;\n const scaleFactor = inputTimeScale / mp4timeScale;\n const mp4SampleDuration = track.isAAC ? 1024 : 1152;\n const inputSampleDuration = mp4SampleDuration * scaleFactor;\n const initPTS = this._initPTS;\n const rawMPEG = !track.isAAC && this.typeSupported.mpeg;\n\n let mp4Sample;\n let fillFrame;\n let mdat;\n let moof;\n let firstPTS;\n let lastPTS;\n let offset = (rawMPEG ? 0 : 8);\n let inputSamples = track.samples;\n let outputSamples = [];\n let nextAudioPts = this.nextAudioPts;\n\n // for audio samples, also consider consecutive fragments as being contiguous (even if a level switch occurs),\n // for sake of clarity:\n // consecutive fragments are frags with\n // - less than 100ms gaps between new time offset (if accurate) and next expected PTS OR\n // - less than 20 audio frames distance\n // contiguous fragments are consecutive fragments from same quality level (same level, new SN = old SN + 1)\n // this helps ensuring audio continuity\n // and this also avoids audio glitches/cut when switching quality, or reporting wrong duration on first audio frame\n contiguous |= (inputSamples.length && nextAudioPts &&\n ((accurateTimeOffset && Math.abs(timeOffset - nextAudioPts / inputTimeScale) < 0.1) ||\n Math.abs((inputSamples[0].pts - nextAudioPts - initPTS)) < 20 * inputSampleDuration)\n );\n\n // compute normalized PTS\n inputSamples.forEach(function (sample) {\n sample.pts = sample.dts = PTSNormalize(sample.pts - initPTS, timeOffset * inputTimeScale);\n });\n\n // filter out sample with negative PTS that are not playable anyway\n // if we don't remove these negative samples, they will shift all audio samples forward.\n // leading to audio overlap between current / next fragment\n inputSamples = inputSamples.filter((sample) => sample.pts >= 0);\n\n // in case all samples have negative PTS, and have been filtered out, return now\n if (inputSamples.length === 0) {\n return;\n }\n\n if (!contiguous) {\n if (!accurateTimeOffset) {\n // if frag are mot contiguous and if we cant trust time offset, let's use first sample PTS as next audio PTS\n nextAudioPts = inputSamples[0].pts;\n } else {\n // if timeOffset is accurate, let's use it as predicted next audio PTS\n nextAudioPts = Math.max(0, timeOffset * inputTimeScale);\n }\n }\n\n // If the audio track is missing samples, the frames seem to get \"left-shifted\" within the\n // resulting mp4 segment, causing sync issues and leaving gaps at the end of the audio segment.\n // In an effort to prevent this from happening, we inject frames here where there are gaps.\n // When possible, we inject a silent frame; when that's not possible, we duplicate the last\n // frame.\n\n if (track.isAAC) {\n const maxAudioFramesDrift = this.config.maxAudioFramesDrift;\n for (let i = 0, nextPts = nextAudioPts; i < inputSamples.length;) {\n // First, let's see how far off this frame is from where we expect it to be\n const sample = inputSamples[i];\n let pts = sample.pts;\n let delta = pts - nextPts;\n\n // If we're overlapping by more than a duration, drop this sample\n if (delta <= -maxAudioFramesDrift * inputSampleDuration) {\n if (contiguous || i > 0) {\n logger.warn(`Dropping 1 audio frame @ ${toMsFromMpegTsClock(nextPts, true) / 1000}s due to ${toMsFromMpegTsClock(delta, true)} ms overlap.`);\n inputSamples.splice(i, 1);\n // Don't touch nextPtsNorm or i\n } else {\n // When changing qualities we can't trust that audio has been appended up to nextAudioPts\n // Warn about the overlap but do not drop samples as that can introduce buffer gaps\n logger.warn(`Audio frame @ ${toMsFromMpegTsClock(pts, true) / 1000}s overlaps nextAudioPts by ${toMsFromMpegTsClock(delta, true)} ms.`);\n nextPts = pts + inputSampleDuration;\n i++;\n }\n } // eslint-disable-line brace-style\n\n // Insert missing frames if:\n // 1: We're more than maxAudioFramesDrift frame away\n // 2: Not more than MAX_SILENT_FRAME_DURATION away\n // 3: currentTime (aka nextPtsNorm) is not 0\n else if (delta >= maxAudioFramesDrift * inputSampleDuration && delta < MAX_SILENT_FRAME_DURATION_90KHZ && nextPts) {\n let missing = Math.round(delta / inputSampleDuration);\n logger.warn(`Injecting ${missing} audio frames @ ${toMsFromMpegTsClock(nextPts, true) / 1000}s due to ${toMsFromMpegTsClock(delta, true)} ms gap.`);\n for (let j = 0; j < missing; j++) {\n let newStamp = Math.max(nextPts, 0);\n fillFrame = AAC.getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n if (!fillFrame) {\n logger.log('Unable to get silent frame for given audio codec; duplicating last frame instead.');\n fillFrame = sample.unit.subarray();\n }\n inputSamples.splice(i, 0, { unit: fillFrame, pts: newStamp, dts: newStamp });\n nextPts += inputSampleDuration;\n i++;\n }\n\n // Adjust sample to next expected pts\n sample.pts = sample.dts = nextPts;\n nextPts += inputSampleDuration;\n i++;\n } else {\n // Otherwise, just adjust pts\n if (Math.abs(delta) > (0.1 * inputSampleDuration)) {\n // logger.log(`Invalid frame delta ${Math.round(delta + inputSampleDuration)} at PTS ${Math.round(pts / 90)} (should be ${Math.round(inputSampleDuration)}).`);\n }\n sample.pts = sample.dts = nextPts;\n nextPts += inputSampleDuration;\n i++;\n }\n }\n }\n\n // compute mdat size, as we eventually filtered/added some samples\n let nbSamples = inputSamples.length;\n let mdatSize = 0;\n while (nbSamples--) {\n mdatSize += inputSamples[nbSamples].unit.byteLength;\n }\n\n for (let j = 0, nbSamples = inputSamples.length; j < nbSamples; j++) {\n let audioSample = inputSamples[j];\n let unit = audioSample.unit;\n let pts = audioSample.pts;\n\n // logger.log(`Audio/PTS:${toMsFromMpegTsClock(pts, true)}`);\n // if not first sample\n\n if (lastPTS !== undefined && mp4Sample) {\n mp4Sample.duration = Math.round((pts - lastPTS) / scaleFactor);\n } else {\n let delta = pts - nextAudioPts;\n let numMissingFrames = 0;\n\n // if fragment are contiguous, detect hole/overlapping between fragments\n // contiguous fragments are consecutive fragments from same quality level (same level, new SN = old SN + 1)\n if (contiguous && track.isAAC) {\n // log delta\n if (delta) {\n if (delta > 0 && delta < MAX_SILENT_FRAME_DURATION_90KHZ) {\n // Q: why do we have to round here, shouldn't this always result in an integer if timestamps are correct,\n // and if not, shouldn't we actually Math.ceil() instead?\n numMissingFrames = Math.round((pts - nextAudioPts) / inputSampleDuration);\n\n logger.log(`${toMsFromMpegTsClock(delta, true)} ms hole between AAC samples detected,filling it`);\n if (numMissingFrames > 0) {\n fillFrame = AAC.getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n if (!fillFrame) {\n fillFrame = unit.subarray();\n }\n\n mdatSize += numMissingFrames * fillFrame.length;\n }\n // if we have frame overlap, overlapping for more than half a frame duraion\n } else if (delta < -12) {\n // drop overlapping audio frames... browser will deal with it\n logger.log(`drop overlapping AAC sample, expected/parsed/delta: ${toMsFromMpegTsClock(nextAudioPts, true)} ms / ${toMsFromMpegTsClock(pts, true)} ms / ${toMsFromMpegTsClock(-delta, true)} ms`);\n mdatSize -= unit.byteLength;\n continue;\n }\n // set PTS/DTS to expected PTS/DTS\n pts = nextAudioPts;\n }\n }\n // remember first PTS of our audioSamples\n firstPTS = pts;\n if (mdatSize > 0) {\n mdatSize += offset;\n try {\n mdat = new Uint8Array(mdatSize);\n } catch (err) {\n this.observer.trigger(Event.ERROR, { type: ErrorTypes.MUX_ERROR, details: ErrorDetails.REMUX_ALLOC_ERROR, fatal: false, bytes: mdatSize, reason: `fail allocating audio mdat ${mdatSize}` });\n return;\n }\n if (!rawMPEG) {\n const view = new DataView(mdat.buffer);\n view.setUint32(0, mdatSize);\n mdat.set(MP4.types.mdat, 4);\n }\n } else {\n // no audio samples\n return;\n }\n for (let i = 0; i < numMissingFrames; i++) {\n fillFrame = AAC.getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n if (!fillFrame) {\n logger.log('Unable to get silent frame for given audio codec; duplicating this frame instead.');\n fillFrame = unit.subarray();\n }\n mdat.set(fillFrame, offset);\n offset += fillFrame.byteLength;\n mp4Sample = {\n size: fillFrame.byteLength,\n cts: 0,\n duration: 1024,\n flags: {\n isLeading: 0,\n isDependedOn: 0,\n hasRedundancy: 0,\n degradPrio: 0,\n dependsOn: 1\n }\n };\n outputSamples.push(mp4Sample);\n }\n }\n mdat.set(unit, offset);\n let unitLen = unit.byteLength;\n offset += unitLen;\n // console.log('PTS/DTS/initDTS/normPTS/normDTS/relative PTS : ${audioSample.pts}/${audioSample.dts}/${initDTS}/${ptsnorm}/${dtsnorm}/${(audioSample.pts/4294967296).toFixed(3)}');\n mp4Sample = {\n size: unitLen,\n cts: 0,\n duration: 0,\n flags: {\n isLeading: 0,\n isDependedOn: 0,\n hasRedundancy: 0,\n degradPrio: 0,\n dependsOn: 1\n }\n };\n outputSamples.push(mp4Sample);\n lastPTS = pts;\n }\n let lastSampleDuration = 0;\n nbSamples = outputSamples.length;\n // set last sample duration as being identical to previous sample\n if (nbSamples >= 2) {\n lastSampleDuration = outputSamples[nbSamples - 2].duration;\n mp4Sample.duration = lastSampleDuration;\n }\n if (nbSamples) {\n // next audio sample PTS should be equal to last sample PTS + duration\n this.nextAudioPts = nextAudioPts = lastPTS + scaleFactor * lastSampleDuration;\n // logger.log('Audio/PTS/PTSend:' + audioSample.pts.toFixed(0) + '/' + this.nextAacDts.toFixed(0));\n track.samples = outputSamples;\n if (rawMPEG) {\n moof = new Uint8Array();\n } else {\n moof = MP4.moof(track.sequenceNumber++, firstPTS / scaleFactor, track);\n }\n\n track.samples = [];\n const start = firstPTS / inputTimeScale;\n const end = nextAudioPts / inputTimeScale;\n const audioData = {\n data1: moof,\n data2: mdat,\n startPTS: start,\n endPTS: end,\n startDTS: start,\n endDTS: end,\n type: 'audio',\n hasAudio: true,\n hasVideo: false,\n nb: nbSamples\n };\n this.observer.trigger(Event.FRAG_PARSING_DATA, audioData);\n return audioData;\n }\n return null;\n }\n\n remuxEmptyAudio (track, timeOffset, contiguous, videoData) {\n let inputTimeScale = track.inputTimeScale;\n let mp4timeScale = track.samplerate ? track.samplerate : inputTimeScale;\n let scaleFactor = inputTimeScale / mp4timeScale;\n let nextAudioPts = this.nextAudioPts;\n\n // sync with video's timestamp\n let startDTS = (nextAudioPts !== undefined ? nextAudioPts : videoData.startDTS * inputTimeScale) + this._initDTS;\n let endDTS = videoData.endDTS * inputTimeScale + this._initDTS;\n // one sample's duration value\n let sampleDuration = 1024;\n let frameDuration = scaleFactor * sampleDuration;\n\n // samples count of this segment's duration\n let nbSamples = Math.ceil((endDTS - startDTS) / frameDuration);\n\n // silent frame\n let silentFrame = AAC.getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n\n logger.warn('remux empty Audio');\n // Can't remux if we can't generate a silent frame...\n if (!silentFrame) {\n logger.trace('Unable to remuxEmptyAudio since we were unable to get a silent frame for given audio codec!');\n return;\n }\n\n let samples = [];\n for (let i = 0; i < nbSamples; i++) {\n let stamp = startDTS + i * frameDuration;\n samples.push({ unit: silentFrame, pts: stamp, dts: stamp });\n }\n track.samples = samples;\n\n this.remuxAudio(track, timeOffset, contiguous);\n }\n\n remuxID3 (track, timeOffset) {\n const length = track.samples.length;\n if (!length) {\n return;\n }\n const inputTimeScale = track.inputTimeScale;\n const initPTS = this._initPTS;\n const initDTS = this._initDTS;\n // consume samples\n for (let index = 0; index < length; index++) {\n const sample = track.samples[index];\n // setting id3 pts, dts to relative time\n // using this._initPTS and this._initDTS to calculate relative time\n sample.pts = PTSNormalize(sample.pts - initPTS, timeOffset * inputTimeScale) / inputTimeScale;\n sample.dts = PTSNormalize(sample.dts - initDTS, timeOffset * inputTimeScale) / inputTimeScale;\n }\n this.observer.trigger(Event.FRAG_PARSING_METADATA, {\n samples: track.samples\n });\n\n track.samples = [];\n }\n\n remuxText (track, timeOffset) {\n const length = track.samples.length;\n const inputTimeScale = track.inputTimeScale;\n const initPTS = this._initPTS;\n // consume samples\n if (length) {\n for (let index = 0; index < length; index++) {\n const sample = track.samples[index];\n // setting text pts, dts to relative time\n // using this._initPTS and this._initDTS to calculate relative time\n sample.pts = PTSNormalize(sample.pts - initPTS, timeOffset * inputTimeScale) / inputTimeScale;\n }\n track.samples.sort(function (a, b) {\n return (a.pts - b.pts);\n });\n this.observer.trigger(Event.FRAG_PARSING_USERDATA, {\n samples: track.samples\n });\n }\n\n track.samples = [];\n }\n}\n\nfunction PTSNormalize (value, reference) {\n let offset;\n if (reference === undefined) {\n return value;\n }\n\n if (reference < value) {\n // - 2^33\n offset = -8589934592;\n } else {\n // + 2^33\n offset = 8589934592;\n }\n /* PTS is 33bit (from 0 to 2^33 -1)\n if diff between value and reference is bigger than half of the amplitude (2^32) then it means that\n PTS looping occured. fill the gap */\n while (Math.abs(value - reference) > 4294967296) {\n value += offset;\n }\n\n return value;\n}\n\nexport default MP4Remuxer;\n","/**\n *\n * inline demuxer: probe fragments and instantiate\n * appropriate demuxer depending on content type (TSDemuxer, AACDemuxer, ...)\n *\n */\n\nimport Event from '../events';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport Decrypter from '../crypt/decrypter';\nimport AACDemuxer from '../demux/aacdemuxer';\nimport MP4Demuxer from '../demux/mp4demuxer';\nimport TSDemuxer from '../demux/tsdemuxer';\nimport MP3Demuxer from '../demux/mp3demuxer';\nimport MP4Remuxer from '../remux/mp4-remuxer';\nimport PassThroughRemuxer from '../remux/passthrough-remuxer';\n\nimport { getSelfScope } from '../utils/get-self-scope';\nimport { logger } from '../utils/logger';\n\n// see https://stackoverflow.com/a/11237259/589493\nconst global = getSelfScope(); // safeguard for code that might run both on worker and main thread\n\nlet now;\n// performance.now() not available on WebWorker, at least on Safari Desktop\ntry {\n now = global.performance.now.bind(global.performance);\n} catch (err) {\n logger.debug('Unable to use Performance API on this environment');\n now = global.Date.now;\n}\n\nclass DemuxerInline {\n constructor (observer, typeSupported, config, vendor) {\n this.observer = observer;\n this.typeSupported = typeSupported;\n this.config = config;\n this.vendor = vendor;\n }\n\n destroy () {\n let demuxer = this.demuxer;\n if (demuxer) {\n demuxer.destroy();\n }\n }\n\n push (data, decryptdata, initSegment, audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS) {\n if ((data.byteLength > 0) && (decryptdata != null) && (decryptdata.key != null) && (decryptdata.method === 'AES-128')) {\n let decrypter = this.decrypter;\n if (decrypter == null) {\n decrypter = this.decrypter = new Decrypter(this.observer, this.config);\n }\n\n const startTime = now();\n decrypter.decrypt(data, decryptdata.key.buffer, decryptdata.iv.buffer, (decryptedData) => {\n const endTime = now();\n this.observer.trigger(Event.FRAG_DECRYPTED, { stats: { tstart: startTime, tdecrypt: endTime } });\n this.pushDecrypted(new Uint8Array(decryptedData), decryptdata, new Uint8Array(initSegment), audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS);\n });\n } else {\n this.pushDecrypted(new Uint8Array(data), decryptdata, new Uint8Array(initSegment), audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS);\n }\n }\n\n pushDecrypted (data, decryptdata, initSegment, audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS) {\n let demuxer = this.demuxer;\n let remuxer = this.remuxer;\n if (!demuxer ||\n // in case of continuity change, or track switch\n // we might switch from content type (AAC container to TS container, or TS to fmp4 for example)\n (discontinuity || trackSwitch)) {\n const observer = this.observer;\n const typeSupported = this.typeSupported;\n const config = this.config;\n // probing order is TS/MP4/AAC/MP3\n const muxConfig = [\n { demux: TSDemuxer, remux: MP4Remuxer },\n { demux: MP4Demuxer, remux: PassThroughRemuxer },\n { demux: AACDemuxer, remux: MP4Remuxer },\n { demux: MP3Demuxer, remux: MP4Remuxer }\n ];\n\n // probe for content type\n let mux;\n for (let i = 0, len = muxConfig.length; i < len; i++) {\n mux = muxConfig[i];\n if (mux.demux.probe(data)) {\n break;\n }\n }\n if (!mux) {\n observer.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.FRAG_PARSING_ERROR, fatal: true, reason: 'no demux matching with content found' });\n return;\n }\n // so let's check that current remuxer and demuxer are still valid\n if (!remuxer || !(remuxer instanceof mux.remux)) {\n remuxer = new mux.remux(observer, config, typeSupported, this.vendor);\n }\n if (!demuxer || !(demuxer instanceof mux.demux)) {\n demuxer = new mux.demux(observer, remuxer, config, typeSupported);\n this.probe = mux.demux.probe;\n }\n this.demuxer = demuxer;\n this.remuxer = remuxer;\n }\n\n if (discontinuity || trackSwitch) {\n demuxer.resetInitSegment(initSegment, audioCodec, videoCodec, duration);\n remuxer.resetInitSegment();\n }\n if (discontinuity) {\n demuxer.resetTimeStamp(defaultInitPTS);\n remuxer.resetTimeStamp(defaultInitPTS);\n }\n if (typeof demuxer.setDecryptData === 'function') {\n demuxer.setDecryptData(decryptdata);\n }\n\n demuxer.append(data, timeOffset, contiguous, accurateTimeOffset);\n }\n}\n\nexport default DemuxerInline;\n","/**\n * passthrough remuxer\n*/\nimport Event from '../events';\n\nclass PassThroughRemuxer {\n constructor (observer) {\n this.observer = observer;\n }\n\n destroy () {\n }\n\n resetTimeStamp () {\n }\n\n resetInitSegment () {\n }\n\n remux (audioTrack, videoTrack, id3Track, textTrack, timeOffset, contiguous, accurateTimeOffset, rawData) {\n let observer = this.observer;\n let streamType = '';\n if (audioTrack) {\n streamType += 'audio';\n }\n\n if (videoTrack) {\n streamType += 'video';\n }\n\n observer.trigger(Event.FRAG_PARSING_DATA, {\n data1: rawData,\n startPTS: timeOffset,\n startDTS: timeOffset,\n type: streamType,\n hasAudio: !!audioTrack,\n hasVideo: !!videoTrack,\n nb: 1,\n dropped: 0\n });\n // notify end of parsing\n observer.trigger(Event.FRAG_PARSED);\n }\n}\n\nexport default PassThroughRemuxer;\n","/* demuxer web worker.\n * - listen to worker message, and trigger DemuxerInline upon reception of Fragments.\n * - provides MP4 Boxes back to main thread using [transferable objects](https://developers.google.com/web/updates/2011/12/Transferable-Objects-Lightning-Fast) in order to minimize message passing overhead.\n */\n\nimport DemuxerInline from '../demux/demuxer-inline';\nimport Event from '../events';\nimport { enableLogs } from '../utils/logger';\n\nimport { EventEmitter } from 'eventemitter3';\n\nlet DemuxerWorker = function (self) {\n // observer setup\n let observer = new EventEmitter();\n observer.trigger = function trigger (event, ...data) {\n observer.emit(event, event, ...data);\n };\n\n observer.off = function off (event, ...data) {\n observer.removeListener(event, ...data);\n };\n\n let forwardMessage = function (ev, data) {\n self.postMessage({ event: ev, data: data });\n };\n\n self.addEventListener('message', function (ev) {\n let data = ev.data;\n // console.log('demuxer cmd:' + data.cmd);\n switch (data.cmd) {\n case 'init':\n const config = JSON.parse(data.config);\n self.demuxer = new DemuxerInline(observer, data.typeSupported, config, data.vendor);\n\n enableLogs(config.debug);\n\n // signal end of worker init\n forwardMessage('init', null);\n break;\n case 'demux':\n self.demuxer.push(data.data, data.decryptdata, data.initSegment, data.audioCodec, data.videoCodec, data.timeOffset, data.discontinuity, data.trackSwitch, data.contiguous, data.duration, data.accurateTimeOffset, data.defaultInitPTS);\n break;\n default:\n break;\n }\n });\n\n // forward events to main thread\n observer.on(Event.FRAG_DECRYPTED, forwardMessage);\n observer.on(Event.FRAG_PARSING_INIT_SEGMENT, forwardMessage);\n observer.on(Event.FRAG_PARSED, forwardMessage);\n observer.on(Event.ERROR, forwardMessage);\n observer.on(Event.FRAG_PARSING_METADATA, forwardMessage);\n observer.on(Event.FRAG_PARSING_USERDATA, forwardMessage);\n observer.on(Event.INIT_PTS_FOUND, forwardMessage);\n\n // special case for FRAG_PARSING_DATA: pass data1/data2 as transferable object (no copy)\n observer.on(Event.FRAG_PARSING_DATA, function (ev, data) {\n let transferable = [];\n let message = { event: ev, data: data };\n if (data.data1) {\n message.data1 = data.data1.buffer;\n transferable.push(data.data1.buffer);\n delete data.data1;\n }\n if (data.data2) {\n message.data2 = data.data2.buffer;\n transferable.push(data.data2.buffer);\n delete data.data2;\n }\n self.postMessage(message, transferable);\n });\n};\n\nexport default DemuxerWorker;\n","import { getSelfScope } from '../utils/get-self-scope';\n\n/**\n * ID3 parser\n */\nclass ID3 {\n /**\n * Returns true if an ID3 header can be found at offset in data\n * @param {Uint8Array} data - The data to search in\n * @param {number} offset - The offset at which to start searching\n * @return {boolean} - True if an ID3 header is found\n */\n static isHeader (data, offset) {\n /*\n * http://id3.org/id3v2.3.0\n * [0] = 'I'\n * [1] = 'D'\n * [2] = '3'\n * [3,4] = {Version}\n * [5] = {Flags}\n * [6-9] = {ID3 Size}\n *\n * An ID3v2 tag can be detected with the following pattern:\n * $49 44 33 yy yy xx zz zz zz zz\n * Where yy is less than $FF, xx is the 'flags' byte and zz is less than $80\n */\n if (offset + 10 <= data.length) {\n // look for 'ID3' identifier\n if (data[offset] === 0x49 && data[offset + 1] === 0x44 && data[offset + 2] === 0x33) {\n // check version is within range\n if (data[offset + 3] < 0xFF && data[offset + 4] < 0xFF) {\n // check size is within range\n if (data[offset + 6] < 0x80 && data[offset + 7] < 0x80 && data[offset + 8] < 0x80 && data[offset + 9] < 0x80) {\n return true;\n }\n }\n }\n }\n\n return false;\n }\n\n /**\n * Returns true if an ID3 footer can be found at offset in data\n * @param {Uint8Array} data - The data to search in\n * @param {number} offset - The offset at which to start searching\n * @return {boolean} - True if an ID3 footer is found\n */\n static isFooter (data, offset) {\n /*\n * The footer is a copy of the header, but with a different identifier\n */\n if (offset + 10 <= data.length) {\n // look for '3DI' identifier\n if (data[offset] === 0x33 && data[offset + 1] === 0x44 && data[offset + 2] === 0x49) {\n // check version is within range\n if (data[offset + 3] < 0xFF && data[offset + 4] < 0xFF) {\n // check size is within range\n if (data[offset + 6] < 0x80 && data[offset + 7] < 0x80 && data[offset + 8] < 0x80 && data[offset + 9] < 0x80) {\n return true;\n }\n }\n }\n }\n\n return false;\n }\n\n /**\n * Returns any adjacent ID3 tags found in data starting at offset, as one block of data\n * @param {Uint8Array} data - The data to search in\n * @param {number} offset - The offset at which to start searching\n * @return {Uint8Array} - The block of data containing any ID3 tags found\n */\n static getID3Data (data, offset) {\n const front = offset;\n let length = 0;\n\n while (ID3.isHeader(data, offset)) {\n // ID3 header is 10 bytes\n length += 10;\n\n const size = ID3._readSize(data, offset + 6);\n length += size;\n\n if (ID3.isFooter(data, offset + 10)) {\n // ID3 footer is 10 bytes\n length += 10;\n }\n\n offset += length;\n }\n\n if (length > 0) {\n return data.subarray(front, front + length);\n }\n\n return undefined;\n }\n\n static _readSize (data, offset) {\n let size = 0;\n size = ((data[offset] & 0x7f) << 21);\n size |= ((data[offset + 1] & 0x7f) << 14);\n size |= ((data[offset + 2] & 0x7f) << 7);\n size |= (data[offset + 3] & 0x7f);\n return size;\n }\n\n /**\n * Searches for the Elementary Stream timestamp found in the ID3 data chunk\n * @param {Uint8Array} data - Block of data containing one or more ID3 tags\n * @return {number} - The timestamp\n */\n static getTimeStamp (data) {\n const frames = ID3.getID3Frames(data);\n for (let i = 0; i < frames.length; i++) {\n const frame = frames[i];\n if (ID3.isTimeStampFrame(frame)) {\n return ID3._readTimeStamp(frame);\n }\n }\n\n return undefined;\n }\n\n /**\n * Returns true if the ID3 frame is an Elementary Stream timestamp frame\n * @param {ID3 frame} frame\n */\n static isTimeStampFrame (frame) {\n return (frame && frame.key === 'PRIV' && frame.info === 'com.apple.streaming.transportStreamTimestamp');\n }\n\n static _getFrameData (data) {\n /*\n Frame ID $xx xx xx xx (four characters)\n Size $xx xx xx xx\n Flags $xx xx\n */\n const type = String.fromCharCode(data[0], data[1], data[2], data[3]);\n const size = ID3._readSize(data, 4);\n\n // skip frame id, size, and flags\n let offset = 10;\n\n return { type, size, data: data.subarray(offset, offset + size) };\n }\n\n /**\n * Returns an array of ID3 frames found in all the ID3 tags in the id3Data\n * @param {Uint8Array} id3Data - The ID3 data containing one or more ID3 tags\n * @return {ID3 frame[]} - Array of ID3 frame objects\n */\n static getID3Frames (id3Data) {\n let offset = 0;\n const frames = [];\n\n while (ID3.isHeader(id3Data, offset)) {\n const size = ID3._readSize(id3Data, offset + 6);\n // skip past ID3 header\n offset += 10;\n const end = offset + size;\n // loop through frames in the ID3 tag\n while (offset + 8 < end) {\n const frameData = ID3._getFrameData(id3Data.subarray(offset));\n const frame = ID3._decodeFrame(frameData);\n if (frame) {\n frames.push(frame);\n }\n\n // skip frame header and frame data\n offset += frameData.size + 10;\n }\n\n if (ID3.isFooter(id3Data, offset)) {\n offset += 10;\n }\n }\n\n return frames;\n }\n\n static _decodeFrame (frame) {\n if (frame.type === 'PRIV') {\n return ID3._decodePrivFrame(frame);\n } else if (frame.type[0] === 'W') {\n return ID3._decodeURLFrame(frame);\n }\n\n return ID3._decodeTextFrame(frame);\n }\n\n static _readTimeStamp (timeStampFrame) {\n if (timeStampFrame.data.byteLength === 8) {\n const data = new Uint8Array(timeStampFrame.data);\n // timestamp is 33 bit expressed as a big-endian eight-octet number,\n // with the upper 31 bits set to zero.\n const pts33Bit = data[3] & 0x1;\n let timestamp = (data[4] << 23) +\n (data[5] << 15) +\n (data[6] << 7) +\n data[7];\n timestamp /= 45;\n\n if (pts33Bit) {\n timestamp += 47721858.84;\n } // 2^32 / 90\n\n return Math.round(timestamp);\n }\n\n return undefined;\n }\n\n static _decodePrivFrame (frame) {\n /*\n Format: <text string>\\0<binary data>\n */\n if (frame.size < 2) {\n return undefined;\n }\n\n const owner = ID3._utf8ArrayToStr(frame.data, true);\n const privateData = new Uint8Array(frame.data.subarray(owner.length + 1));\n\n return { key: frame.type, info: owner, data: privateData.buffer };\n }\n\n static _decodeTextFrame (frame) {\n if (frame.size < 2) {\n return undefined;\n }\n\n if (frame.type === 'TXXX') {\n /*\n Format:\n [0] = {Text Encoding}\n [1-?] = {Description}\\0{Value}\n */\n let index = 1;\n const description = ID3._utf8ArrayToStr(frame.data.subarray(index), true);\n\n index += description.length + 1;\n const value = ID3._utf8ArrayToStr(frame.data.subarray(index));\n\n return { key: frame.type, info: description, data: value };\n } else {\n /*\n Format:\n [0] = {Text Encoding}\n [1-?] = {Value}\n */\n const text = ID3._utf8ArrayToStr(frame.data.subarray(1));\n return { key: frame.type, data: text };\n }\n }\n\n static _decodeURLFrame (frame) {\n if (frame.type === 'WXXX') {\n /*\n Format:\n [0] = {Text Encoding}\n [1-?] = {Description}\\0{URL}\n */\n if (frame.size < 2) {\n return undefined;\n }\n\n let index = 1;\n const description = ID3._utf8ArrayToStr(frame.data.subarray(index), true);\n\n index += description.length + 1;\n const value = ID3._utf8ArrayToStr(frame.data.subarray(index));\n\n return { key: frame.type, info: description, data: value };\n } else {\n /*\n Format:\n [0-?] = {URL}\n */\n const url = ID3._utf8ArrayToStr(frame.data);\n return { key: frame.type, data: url };\n }\n }\n\n // http://stackoverflow.com/questions/8936984/uint8array-to-string-in-javascript/22373197\n // http://www.onicos.com/staff/iz/amuse/javascript/expert/utf.txt\n /* utf.js - UTF-8 <=> UTF-16 convertion\n *\n * Copyright (C) 1999 Masanao Izumo <iz@onicos.co.jp>\n * Version: 1.0\n * LastModified: Dec 25 1999\n * This library is free. You can redistribute it and/or modify it.\n */\n static _utf8ArrayToStr (array, exitOnNull = false) {\n const decoder = getTextDecoder();\n if (decoder) {\n const decoded = decoder.decode(array);\n\n if (exitOnNull) {\n // grab up to the first null\n const idx = decoded.indexOf('\\0');\n return idx !== -1 ? decoded.substring(0, idx) : decoded;\n }\n\n // remove any null characters\n return decoded.replace(/\\0/g, '');\n }\n\n const len = array.length;\n let c;\n let char2;\n let char3;\n let out = '';\n let i = 0;\n while (i < len) {\n c = array[i++];\n if (c === 0x00 && exitOnNull) {\n return out;\n } else if (c === 0x00 || c === 0x03) {\n // If the character is 3 (END_OF_TEXT) or 0 (NULL) then skip it\n continue;\n }\n switch (c >> 4) {\n case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7:\n // 0xxxxxxx\n out += String.fromCharCode(c);\n break;\n case 12: case 13:\n // 110x xxxx 10xx xxxx\n char2 = array[i++];\n out += String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F));\n break;\n case 14:\n // 1110 xxxx 10xx xxxx 10xx xxxx\n char2 = array[i++];\n char3 = array[i++];\n out += String.fromCharCode(((c & 0x0F) << 12) |\n ((char2 & 0x3F) << 6) |\n ((char3 & 0x3F) << 0));\n break;\n default:\n }\n }\n return out;\n }\n}\n\nlet decoder;\n\nfunction getTextDecoder () {\n const global = getSelfScope(); // safeguard for code that might run both on worker and main thread\n if (!decoder && typeof global.TextDecoder !== 'undefined') {\n decoder = new global.TextDecoder('utf-8');\n }\n\n return decoder;\n}\n\nconst utf8ArrayToStr = ID3._utf8ArrayToStr;\n\nexport default ID3;\n\nexport { utf8ArrayToStr };\n","/**\n * MP4 demuxer\n */\nimport { logger } from '../utils/logger';\nimport Event from '../events';\n\nconst UINT32_MAX = Math.pow(2, 32) - 1;\n\nclass MP4Demuxer {\n constructor (observer, remuxer) {\n this.observer = observer;\n this.remuxer = remuxer;\n }\n\n resetTimeStamp (initPTS) {\n this.initPTS = initPTS;\n }\n\n resetInitSegment (initSegment, audioCodec, videoCodec, duration) {\n // jshint unused:false\n if (initSegment && initSegment.byteLength) {\n const initData = this.initData = MP4Demuxer.parseInitSegment(initSegment);\n\n // default audio codec if nothing specified\n // TODO : extract that from initsegment\n if (audioCodec == null) {\n audioCodec = 'mp4a.40.5';\n }\n\n if (videoCodec == null) {\n videoCodec = 'avc1.42e01e';\n }\n\n const tracks = {};\n if (initData.audio && initData.video) {\n tracks.audiovideo = { container: 'video/mp4', codec: audioCodec + ',' + videoCodec, initSegment: duration ? initSegment : null };\n } else {\n if (initData.audio) {\n tracks.audio = { container: 'audio/mp4', codec: audioCodec, initSegment: duration ? initSegment : null };\n }\n\n if (initData.video) {\n tracks.video = { container: 'video/mp4', codec: videoCodec, initSegment: duration ? initSegment : null };\n }\n }\n this.observer.trigger(Event.FRAG_PARSING_INIT_SEGMENT, { tracks });\n } else {\n if (audioCodec) {\n this.audioCodec = audioCodec;\n }\n\n if (videoCodec) {\n this.videoCodec = videoCodec;\n }\n }\n }\n\n static probe (data) {\n // ensure we find a moof box in the first 16 kB\n return MP4Demuxer.findBox({ data: data, start: 0, end: Math.min(data.length, 16384) }, ['moof']).length > 0;\n }\n\n static bin2str (buffer) {\n return String.fromCharCode.apply(null, buffer);\n }\n\n static readUint16 (buffer, offset) {\n if (buffer.data) {\n offset += buffer.start;\n buffer = buffer.data;\n }\n\n const val = buffer[offset] << 8 |\n buffer[offset + 1];\n\n return val < 0 ? 65536 + val : val;\n }\n\n static readUint32 (buffer, offset) {\n if (buffer.data) {\n offset += buffer.start;\n buffer = buffer.data;\n }\n\n const val = buffer[offset] << 24 |\n buffer[offset + 1] << 16 |\n buffer[offset + 2] << 8 |\n buffer[offset + 3];\n return val < 0 ? 4294967296 + val : val;\n }\n\n static writeUint32 (buffer, offset, value) {\n if (buffer.data) {\n offset += buffer.start;\n buffer = buffer.data;\n }\n buffer[offset] = value >> 24;\n buffer[offset + 1] = (value >> 16) & 0xff;\n buffer[offset + 2] = (value >> 8) & 0xff;\n buffer[offset + 3] = value & 0xff;\n }\n\n // Find the data for a box specified by its path\n static findBox (data, path) {\n let results = [],\n i, size, type, end, subresults, start, endbox;\n\n if (data.data) {\n start = data.start;\n end = data.end;\n data = data.data;\n } else {\n start = 0;\n end = data.byteLength;\n }\n\n if (!path.length) {\n // short-circuit the search for empty paths\n return null;\n }\n\n for (i = start; i < end;) {\n size = MP4Demuxer.readUint32(data, i);\n type = MP4Demuxer.bin2str(data.subarray(i + 4, i + 8));\n endbox = size > 1 ? i + size : end;\n\n if (type === path[0]) {\n if (path.length === 1) {\n // this is the end of the path and we've found the box we were\n // looking for\n results.push({ data: data, start: i + 8, end: endbox });\n } else {\n // recursively search for the next box along the path\n subresults = MP4Demuxer.findBox({ data: data, start: i + 8, end: endbox }, path.slice(1));\n if (subresults.length) {\n results = results.concat(subresults);\n }\n }\n }\n i = endbox;\n }\n\n // we've finished searching all of data\n return results;\n }\n\n static parseSegmentIndex (initSegment) {\n const moov = MP4Demuxer.findBox(initSegment, ['moov'])[0];\n const moovEndOffset = moov ? moov.end : null; // we need this in case we need to chop of garbage of the end of current data\n\n let index = 0;\n let sidx = MP4Demuxer.findBox(initSegment, ['sidx']);\n let references;\n\n if (!sidx || !sidx[0]) {\n return null;\n }\n\n references = [];\n sidx = sidx[0];\n\n const version = sidx.data[0];\n\n // set initial offset, we skip the reference ID (not needed)\n index = version === 0 ? 8 : 16;\n\n const timescale = MP4Demuxer.readUint32(sidx, index);\n index += 4;\n\n // TODO: parse earliestPresentationTime and firstOffset\n // usually zero in our case\n let earliestPresentationTime = 0;\n let firstOffset = 0;\n\n if (version === 0) {\n index += 8;\n } else {\n index += 16;\n }\n\n // skip reserved\n index += 2;\n\n let startByte = sidx.end + firstOffset;\n\n const referencesCount = MP4Demuxer.readUint16(sidx, index);\n index += 2;\n\n for (let i = 0; i < referencesCount; i++) {\n let referenceIndex = index;\n\n const referenceInfo = MP4Demuxer.readUint32(sidx, referenceIndex);\n referenceIndex += 4;\n\n const referenceSize = referenceInfo & 0x7FFFFFFF;\n const referenceType = (referenceInfo & 0x80000000) >>> 31;\n\n if (referenceType === 1) {\n console.warn('SIDX has hierarchical references (not supported)');\n return;\n }\n\n const subsegmentDuration = MP4Demuxer.readUint32(sidx, referenceIndex);\n referenceIndex += 4;\n\n references.push({\n referenceSize,\n subsegmentDuration, // unscaled\n info: {\n duration: subsegmentDuration / timescale,\n start: startByte,\n end: startByte + referenceSize - 1\n }\n });\n\n startByte += referenceSize;\n\n // Skipping 1 bit for |startsWithSap|, 3 bits for |sapType|, and 28 bits\n // for |sapDelta|.\n referenceIndex += 4;\n\n // skip to next ref\n index = referenceIndex;\n }\n\n return {\n earliestPresentationTime,\n timescale,\n version,\n referencesCount,\n references,\n moovEndOffset\n };\n }\n\n /**\n * Parses an MP4 initialization segment and extracts stream type and\n * timescale values for any declared tracks. Timescale values indicate the\n * number of clock ticks per second to assume for time-based values\n * elsewhere in the MP4.\n *\n * To determine the start time of an MP4, you need two pieces of\n * information: the timescale unit and the earliest base media decode\n * time. Multiple timescales can be specified within an MP4 but the\n * base media decode time is always expressed in the timescale from\n * the media header box for the track:\n * ```\n * moov > trak > mdia > mdhd.timescale\n * moov > trak > mdia > hdlr\n * ```\n * @param init {Uint8Array} the bytes of the init segment\n * @return {object} a hash of track type to timescale values or null if\n * the init segment is malformed.\n */\n static parseInitSegment (initSegment) {\n let result = [];\n let traks = MP4Demuxer.findBox(initSegment, ['moov', 'trak']);\n\n traks.forEach(trak => {\n const tkhd = MP4Demuxer.findBox(trak, ['tkhd'])[0];\n if (tkhd) {\n let version = tkhd.data[tkhd.start];\n let index = version === 0 ? 12 : 20;\n let trackId = MP4Demuxer.readUint32(tkhd, index);\n\n const mdhd = MP4Demuxer.findBox(trak, ['mdia', 'mdhd'])[0];\n if (mdhd) {\n version = mdhd.data[mdhd.start];\n index = version === 0 ? 12 : 20;\n const timescale = MP4Demuxer.readUint32(mdhd, index);\n\n const hdlr = MP4Demuxer.findBox(trak, ['mdia', 'hdlr'])[0];\n if (hdlr) {\n const hdlrType = MP4Demuxer.bin2str(hdlr.data.subarray(hdlr.start + 8, hdlr.start + 12));\n let type = { 'soun': 'audio', 'vide': 'video' }[hdlrType];\n if (type) {\n // extract codec info. TODO : parse codec details to be able to build MIME type\n let codecBox = MP4Demuxer.findBox(trak, ['mdia', 'minf', 'stbl', 'stsd']);\n if (codecBox.length) {\n codecBox = codecBox[0];\n let codecType = MP4Demuxer.bin2str(codecBox.data.subarray(codecBox.start + 12, codecBox.start + 16));\n logger.log(`MP4Demuxer:${type}:${codecType} found`);\n }\n result[trackId] = { timescale: timescale, type: type };\n result[type] = { timescale: timescale, id: trackId };\n }\n }\n }\n }\n });\n return result;\n }\n\n /**\n * Determine the base media decode start time, in seconds, for an MP4\n * fragment. If multiple fragments are specified, the earliest time is\n * returned.\n *\n * The base media decode time can be parsed from track fragment\n * metadata:\n * ```\n * moof > traf > tfdt.baseMediaDecodeTime\n * ```\n * It requires the timescale value from the mdhd to interpret.\n *\n * @param timescale {object} a hash of track ids to timescale values.\n * @return {number} the earliest base media decode start time for the\n * fragment, in seconds\n */\n static getStartDTS (initData, fragment) {\n let trafs, baseTimes, result;\n\n // we need info from two childrend of each track fragment box\n trafs = MP4Demuxer.findBox(fragment, ['moof', 'traf']);\n\n // determine the start times for each track\n baseTimes = [].concat.apply([], trafs.map(function (traf) {\n return MP4Demuxer.findBox(traf, ['tfhd']).map(function (tfhd) {\n let id, scale, baseTime;\n\n // get the track id from the tfhd\n id = MP4Demuxer.readUint32(tfhd, 4);\n // assume a 90kHz clock if no timescale was specified\n scale = initData[id].timescale || 90e3;\n\n // get the base media decode time from the tfdt\n baseTime = MP4Demuxer.findBox(traf, ['tfdt']).map(function (tfdt) {\n let version, result;\n\n version = tfdt.data[tfdt.start];\n result = MP4Demuxer.readUint32(tfdt, 4);\n if (version === 1) {\n result *= Math.pow(2, 32);\n\n result += MP4Demuxer.readUint32(tfdt, 8);\n }\n return result;\n })[0];\n // convert base time to seconds\n return baseTime / scale;\n });\n }));\n\n // return the minimum\n result = Math.min.apply(null, baseTimes);\n return isFinite(result) ? result : 0;\n }\n\n static offsetStartDTS (initData, fragment, timeOffset) {\n MP4Demuxer.findBox(fragment, ['moof', 'traf']).map(function (traf) {\n return MP4Demuxer.findBox(traf, ['tfhd']).map(function (tfhd) {\n // get the track id from the tfhd\n let id = MP4Demuxer.readUint32(tfhd, 4);\n // assume a 90kHz clock if no timescale was specified\n let timescale = initData[id].timescale || 90e3;\n\n // get the base media decode time from the tfdt\n MP4Demuxer.findBox(traf, ['tfdt']).map(function (tfdt) {\n let version = tfdt.data[tfdt.start];\n let baseMediaDecodeTime = MP4Demuxer.readUint32(tfdt, 4);\n if (version === 0) {\n MP4Demuxer.writeUint32(tfdt, 4, baseMediaDecodeTime - timeOffset * timescale);\n } else {\n baseMediaDecodeTime *= Math.pow(2, 32);\n baseMediaDecodeTime += MP4Demuxer.readUint32(tfdt, 8);\n baseMediaDecodeTime -= timeOffset * timescale;\n baseMediaDecodeTime = Math.max(baseMediaDecodeTime, 0);\n const upper = Math.floor(baseMediaDecodeTime / (UINT32_MAX + 1));\n const lower = Math.floor(baseMediaDecodeTime % (UINT32_MAX + 1));\n MP4Demuxer.writeUint32(tfdt, 4, upper);\n MP4Demuxer.writeUint32(tfdt, 8, lower);\n }\n });\n });\n });\n }\n\n // feed incoming data to the front of the parsing pipeline\n append (data, timeOffset, contiguous, accurateTimeOffset) {\n let initData = this.initData;\n if (!initData) {\n this.resetInitSegment(data, this.audioCodec, this.videoCodec, false);\n initData = this.initData;\n }\n let startDTS, initPTS = this.initPTS;\n if (initPTS === undefined) {\n let startDTS = MP4Demuxer.getStartDTS(initData, data);\n this.initPTS = initPTS = startDTS - timeOffset;\n this.observer.trigger(Event.INIT_PTS_FOUND, { initPTS: initPTS });\n }\n MP4Demuxer.offsetStartDTS(initData, data, initPTS);\n startDTS = MP4Demuxer.getStartDTS(initData, data);\n this.remuxer.remux(initData.audio, initData.video, null, null, startDTS, contiguous, accurateTimeOffset, data);\n }\n\n destroy () {}\n}\n\nexport default MP4Demuxer;\n","export enum ErrorTypes {\n // Identifier for a network error (loading error / timeout ...)\n NETWORK_ERROR = 'networkError',\n // Identifier for a media Error (video/parsing/mediasource error)\n MEDIA_ERROR = 'mediaError',\n // EME (encrypted media extensions) errors\n KEY_SYSTEM_ERROR = 'keySystemError',\n // Identifier for a mux Error (demuxing/remuxing)\n MUX_ERROR = 'muxError',\n // Identifier for all other errors\n OTHER_ERROR = 'otherError'\n}\n\n/**\n * @enum {ErrorDetails}\n * @typedef {string} ErrorDetail\n */\nexport enum ErrorDetails {\n KEY_SYSTEM_NO_KEYS = 'keySystemNoKeys',\n KEY_SYSTEM_NO_ACCESS = 'keySystemNoAccess',\n KEY_SYSTEM_NO_SESSION = 'keySystemNoSession',\n KEY_SYSTEM_LICENSE_REQUEST_FAILED = 'keySystemLicenseRequestFailed',\n KEY_SYSTEM_NO_INIT_DATA = 'keySystemNoInitData',\n // Identifier for a manifest load error - data: { url : faulty URL, response : { code: error code, text: error text }}\n MANIFEST_LOAD_ERROR = 'manifestLoadError',\n // Identifier for a manifest load timeout - data: { url : faulty URL, response : { code: error code, text: error text }}\n MANIFEST_LOAD_TIMEOUT = 'manifestLoadTimeOut',\n // Identifier for a manifest parsing error - data: { url : faulty URL, reason : error reason}\n MANIFEST_PARSING_ERROR = 'manifestParsingError',\n // Identifier for a manifest with only incompatible codecs error - data: { url : faulty URL, reason : error reason}\n MANIFEST_INCOMPATIBLE_CODECS_ERROR = 'manifestIncompatibleCodecsError',\n // Identifier for a level which contains no fragments - data: { url: faulty URL, reason: \"no fragments found in level\", level: index of the bad level }\n LEVEL_EMPTY_ERROR = 'levelEmptyError',\n // Identifier for a level load error - data: { url : faulty URL, response : { code: error code, text: error text }}\n LEVEL_LOAD_ERROR = 'levelLoadError',\n // Identifier for a level load timeout - data: { url : faulty URL, response : { code: error code, text: error text }}\n LEVEL_LOAD_TIMEOUT = 'levelLoadTimeOut',\n // Identifier for a level switch error - data: { level : faulty level Id, event : error description}\n LEVEL_SWITCH_ERROR = 'levelSwitchError',\n // Identifier for an audio track load error - data: { url : faulty URL, response : { code: error code, text: error text }}\n AUDIO_TRACK_LOAD_ERROR = 'audioTrackLoadError',\n // Identifier for an audio track load timeout - data: { url : faulty URL, response : { code: error code, text: error text }}\n AUDIO_TRACK_LOAD_TIMEOUT = 'audioTrackLoadTimeOut',\n // Identifier for fragment load error - data: { frag : fragment object, response : { code: error code, text: error text }}\n FRAG_LOAD_ERROR = 'fragLoadError',\n // Identifier for fragment load timeout error - data: { frag : fragment object}\n FRAG_LOAD_TIMEOUT = 'fragLoadTimeOut',\n // Identifier for a fragment decryption error event - data: {id : demuxer Id,frag: fragment object, reason : parsing error description }\n FRAG_DECRYPT_ERROR = 'fragDecryptError',\n // Identifier for a fragment parsing error event - data: { id : demuxer Id, reason : parsing error description }\n // will be renamed DEMUX_PARSING_ERROR and switched to MUX_ERROR in the next major release\n FRAG_PARSING_ERROR = 'fragParsingError',\n // Identifier for a remux alloc error event - data: { id : demuxer Id, frag : fragment object, bytes : nb of bytes on which allocation failed , reason : error text }\n REMUX_ALLOC_ERROR = 'remuxAllocError',\n // Identifier for decrypt key load error - data: { frag : fragment object, response : { code: error code, text: error text }}\n KEY_LOAD_ERROR = 'keyLoadError',\n // Identifier for decrypt key load timeout error - data: { frag : fragment object}\n KEY_LOAD_TIMEOUT = 'keyLoadTimeOut',\n // Triggered when an exception occurs while adding a sourceBuffer to MediaSource - data : { err : exception , mimeType : mimeType }\n BUFFER_ADD_CODEC_ERROR = 'bufferAddCodecError',\n // Identifier for a buffer append error - data: append error description\n BUFFER_APPEND_ERROR = 'bufferAppendError',\n // Identifier for a buffer appending error event - data: appending error description\n BUFFER_APPENDING_ERROR = 'bufferAppendingError',\n // Identifier for a buffer stalled error event\n BUFFER_STALLED_ERROR = 'bufferStalledError',\n // Identifier for a buffer full event\n BUFFER_FULL_ERROR = 'bufferFullError',\n // Identifier for a buffer seek over hole event\n BUFFER_SEEK_OVER_HOLE = 'bufferSeekOverHole',\n // Identifier for a buffer nudge on stall (playback is stuck although currentTime is in a buffered area)\n BUFFER_NUDGE_ON_STALL = 'bufferNudgeOnStall',\n // Identifier for an internal exception happening inside hls.js while handling an event\n INTERNAL_EXCEPTION = 'internalException'\n}\n","/**\n * @readonly\n * @enum {string}\n */\nconst HlsEvents = {\n // fired before MediaSource is attaching to media element - data: { media }\n MEDIA_ATTACHING: 'hlsMediaAttaching',\n // fired when MediaSource has been succesfully attached to media element - data: { }\n MEDIA_ATTACHED: 'hlsMediaAttached',\n // fired before detaching MediaSource from media element - data: { }\n MEDIA_DETACHING: 'hlsMediaDetaching',\n // fired when MediaSource has been detached from media element - data: { }\n MEDIA_DETACHED: 'hlsMediaDetached',\n // fired when we buffer is going to be reset - data: { }\n BUFFER_RESET: 'hlsBufferReset',\n // fired when we know about the codecs that we need buffers for to push into - data: {tracks : { container, codec, levelCodec, initSegment, metadata }}\n BUFFER_CODECS: 'hlsBufferCodecs',\n // fired when sourcebuffers have been created - data: { tracks : tracks }\n BUFFER_CREATED: 'hlsBufferCreated',\n // fired when we append a segment to the buffer - data: { segment: segment object }\n BUFFER_APPENDING: 'hlsBufferAppending',\n // fired when we are done with appending a media segment to the buffer - data : { parent : segment parent that triggered BUFFER_APPENDING, pending : nb of segments waiting for appending for this segment parent}\n BUFFER_APPENDED: 'hlsBufferAppended',\n // fired when the stream is finished and we want to notify the media buffer that there will be no more data - data: { }\n BUFFER_EOS: 'hlsBufferEos',\n // fired when the media buffer should be flushed - data { startOffset, endOffset }\n BUFFER_FLUSHING: 'hlsBufferFlushing',\n // fired when the media buffer has been flushed - data: { }\n BUFFER_FLUSHED: 'hlsBufferFlushed',\n // fired to signal that a manifest loading starts - data: { url : manifestURL}\n MANIFEST_LOADING: 'hlsManifestLoading',\n // fired after manifest has been loaded - data: { levels : [available quality levels], audioTracks : [ available audio tracks], url : manifestURL, stats : { trequest, tfirst, tload, mtime}}\n MANIFEST_LOADED: 'hlsManifestLoaded',\n // fired after manifest has been parsed - data: { levels : [available quality levels], firstLevel : index of first quality level appearing in Manifest}\n MANIFEST_PARSED: 'hlsManifestParsed',\n // fired when a level switch is requested - data: { level : id of new level }\n LEVEL_SWITCHING: 'hlsLevelSwitching',\n // fired when a level switch is effective - data: { level : id of new level }\n LEVEL_SWITCHED: 'hlsLevelSwitched',\n // fired when a level playlist loading starts - data: { url : level URL, level : id of level being loaded}\n LEVEL_LOADING: 'hlsLevelLoading',\n // fired when a level playlist loading finishes - data: { details : levelDetails object, level : id of loaded level, stats : { trequest, tfirst, tload, mtime} }\n LEVEL_LOADED: 'hlsLevelLoaded',\n // fired when a level's details have been updated based on previous details, after it has been loaded - data: { details : levelDetails object, level : id of updated level }\n LEVEL_UPDATED: 'hlsLevelUpdated',\n // fired when a level's PTS information has been updated after parsing a fragment - data: { details : levelDetails object, level : id of updated level, drift: PTS drift observed when parsing last fragment }\n LEVEL_PTS_UPDATED: 'hlsLevelPtsUpdated',\n // fired to notify that levels have changed after removing a level - data: { levels : [available quality levels] }\n LEVELS_UPDATED: 'hlsLevelsUpdated',\n // fired to notify that audio track lists has been updated - data: { audioTracks : audioTracks }\n AUDIO_TRACKS_UPDATED: 'hlsAudioTracksUpdated',\n // fired when an audio track switching is requested - data: { id : audio track id }\n AUDIO_TRACK_SWITCHING: 'hlsAudioTrackSwitching',\n // fired when an audio track switch actually occurs - data: { id : audio track id }\n AUDIO_TRACK_SWITCHED: 'hlsAudioTrackSwitched',\n // fired when an audio track loading starts - data: { url : audio track URL, id : audio track id }\n AUDIO_TRACK_LOADING: 'hlsAudioTrackLoading',\n // fired when an audio track loading finishes - data: { details : levelDetails object, id : audio track id, stats : { trequest, tfirst, tload, mtime } }\n AUDIO_TRACK_LOADED: 'hlsAudioTrackLoaded',\n // fired to notify that subtitle track lists has been updated - data: { subtitleTracks : subtitleTracks }\n SUBTITLE_TRACKS_UPDATED: 'hlsSubtitleTracksUpdated',\n // fired when an subtitle track switch occurs - data: { id : subtitle track id }\n SUBTITLE_TRACK_SWITCH: 'hlsSubtitleTrackSwitch',\n // fired when a subtitle track loading starts - data: { url : subtitle track URL, id : subtitle track id }\n SUBTITLE_TRACK_LOADING: 'hlsSubtitleTrackLoading',\n // fired when a subtitle track loading finishes - data: { details : levelDetails object, id : subtitle track id, stats : { trequest, tfirst, tload, mtime } }\n SUBTITLE_TRACK_LOADED: 'hlsSubtitleTrackLoaded',\n // fired when a subtitle fragment has been processed - data: { success : boolean, frag : the processed frag }\n SUBTITLE_FRAG_PROCESSED: 'hlsSubtitleFragProcessed',\n // fired when a set of VTTCues to be managed externally has been parsed - data: { type: string, track: string, cues: [ VTTCue ] }\n CUES_PARSED: 'hlsCuesParsed',\n // fired when a text track to be managed externally is found - data: { tracks: [ { label: string, kind: string, default: boolean } ] }\n NON_NATIVE_TEXT_TRACKS_FOUND: 'hlsNonNativeTextTracksFound',\n // fired when the first timestamp is found - data: { id : demuxer id, initPTS: initPTS, frag : fragment object }\n INIT_PTS_FOUND: 'hlsInitPtsFound',\n // fired when a fragment loading starts - data: { frag : fragment object }\n FRAG_LOADING: 'hlsFragLoading',\n // fired when a fragment loading is progressing - data: { frag : fragment object, { trequest, tfirst, loaded } }\n FRAG_LOAD_PROGRESS: 'hlsFragLoadProgress',\n // Identifier for fragment load aborting for emergency switch down - data: { frag : fragment object }\n FRAG_LOAD_EMERGENCY_ABORTED: 'hlsFragLoadEmergencyAborted',\n // fired when a fragment loading is completed - data: { frag : fragment object, payload : fragment payload, stats : { trequest, tfirst, tload, length } }\n FRAG_LOADED: 'hlsFragLoaded',\n // fired when a fragment has finished decrypting - data: { id : demuxer id, frag: fragment object, payload : fragment payload, stats : { tstart, tdecrypt } }\n FRAG_DECRYPTED: 'hlsFragDecrypted',\n // fired when Init Segment has been extracted from fragment - data: { id : demuxer id, frag: fragment object, moov : moov MP4 box, codecs : codecs found while parsing fragment }\n FRAG_PARSING_INIT_SEGMENT: 'hlsFragParsingInitSegment',\n // fired when parsing sei text is completed - data: { id : demuxer id, frag: fragment object, samples : [ sei samples pes ] }\n FRAG_PARSING_USERDATA: 'hlsFragParsingUserdata',\n // fired when parsing id3 is completed - data: { id : demuxer id, frag: fragment object, samples : [ id3 samples pes ] }\n FRAG_PARSING_METADATA: 'hlsFragParsingMetadata',\n // fired when data have been extracted from fragment - data: { id : demuxer id, frag: fragment object, data1 : moof MP4 box or TS fragments, data2 : mdat MP4 box or null}\n FRAG_PARSING_DATA: 'hlsFragParsingData',\n // fired when fragment parsing is completed - data: { id : demuxer id, frag: fragment object }\n FRAG_PARSED: 'hlsFragParsed',\n // fired when fragment remuxed MP4 boxes have all been appended into SourceBuffer - data: { id : demuxer id, frag : fragment object, stats : { trequest, tfirst, tload, tparsed, tbuffered, length, bwEstimate } }\n FRAG_BUFFERED: 'hlsFragBuffered',\n // fired when fragment matching with current media position is changing - data : { id : demuxer id, frag : fragment object }\n FRAG_CHANGED: 'hlsFragChanged',\n // Identifier for a FPS drop event - data: { curentDropped, currentDecoded, totalDroppedFrames }\n FPS_DROP: 'hlsFpsDrop',\n // triggered when FPS drop triggers auto level capping - data: { level, droppedlevel }\n FPS_DROP_LEVEL_CAPPING: 'hlsFpsDropLevelCapping',\n // Identifier for an error event - data: { type : error type, details : error details, fatal : if true, hls.js cannot/will not try to recover, if false, hls.js will try to recover,other error specific data }\n ERROR: 'hlsError',\n // fired when hls.js instance starts destroying. Different from MEDIA_DETACHED as one could want to detach and reattach a media to the instance of hls.js to handle mid-rolls for example - data: { }\n DESTROYING: 'hlsDestroying',\n // fired when a decrypt key loading starts - data: { frag : fragment object }\n KEY_LOADING: 'hlsKeyLoading',\n // fired when a decrypt key loading is completed - data: { frag : fragment object, payload : key payload, stats : { trequest, tfirst, tload, length } }\n KEY_LOADED: 'hlsKeyLoaded',\n // fired upon stream controller state transitions - data: { previousState, nextState }\n STREAM_STATE_TRANSITION: 'hlsStreamStateTransition',\n // fired when the live back buffer is reached defined by the liveBackBufferLength config option - data : { bufferEnd: number }\n LIVE_BACK_BUFFER_REACHED: 'hlsLiveBackBufferReached'\n};\n\nexport default HlsEvents;\n","import Level from '../loader/level';\n\nexport interface LoaderContext {\n // target URL\n url: string\n // loader response type (arraybuffer or default response type for playlist)\n responseType: string\n // start byte range offset\n rangeStart?: number\n // end byte range offset\n rangeEnd?: number\n // true if onProgress should report partial chunk of loaded content\n progressData?: boolean\n}\n\nexport interface LoaderConfiguration {\n // Max number of load retries\n maxRetry: number\n // Timeout after which `onTimeOut` callback will be triggered\n // (if loading is still not finished after that delay)\n timeout: number\n // Delay between an I/O error and following connection retry (ms).\n // This to avoid spamming the server\n retryDelay: number\n // max connection retry delay (ms)\n maxRetryDelay: number\n}\n\nexport interface LoaderResponse {\n url: string,\n // TODO(jstackhouse): SharedArrayBuffer, es2017 extension to TS\n data: string | ArrayBuffer\n}\n\nexport interface LoaderStats {\n // performance.now() just after load() has been called\n trequest: number\n // performance.now() of first received byte\n tfirst: number\n // performance.now() on load complete\n tload: number\n // performance.now() on parse completion\n tparsed: number\n // number of loaded bytes\n loaded: number\n // total number of bytes\n total: number\n}\n\ntype LoaderOnSuccess < T extends LoaderContext > = (\n response: LoaderResponse,\n stats: LoaderStats,\n context: T,\n networkDetails: any\n) => void;\n\ntype LoaderOnProgress < T extends LoaderContext > = (\n stats: LoaderStats,\n context: T,\n data: string | ArrayBuffer,\n networkDetails: any,\n) => void;\n\ntype LoaderOnError < T extends LoaderContext > = (\n error: {\n // error status code\n code: number,\n // error description\n text: string,\n },\n context: T,\n networkDetails: any,\n) => void;\n\ntype LoaderOnTimeout < T extends LoaderContext > = (\n stats: LoaderStats,\n context: T,\n) => void;\n\nexport interface LoaderCallbacks<T extends LoaderContext>{\n onSuccess: LoaderOnSuccess<T>,\n onError: LoaderOnError<T>,\n onTimeout: LoaderOnTimeout<T>,\n onProgress?: LoaderOnProgress<T>,\n}\n\nexport interface Loader<T extends LoaderContext> {\n destroy(): void\n abort(): void\n load(\n context: LoaderContext,\n config: LoaderConfiguration,\n callbacks: LoaderCallbacks<T>,\n ): void\n\n context: T\n}\n\n/**\n * `type` property values for this loaders' context object\n * @enum\n *\n */\nexport enum PlaylistContextType {\n MANIFEST = 'manifest',\n LEVEL = 'level',\n AUDIO_TRACK = 'audioTrack',\n SUBTITLE_TRACK= 'subtitleTrack'\n}\n\n/**\n * @enum {string}\n */\nexport enum PlaylistLevelType {\n MAIN = 'main',\n AUDIO = 'audio',\n SUBTITLE = 'subtitle'\n}\n\nexport interface PlaylistLoaderContext extends LoaderContext {\n loader?: Loader<PlaylistLoaderContext>\n\n type: PlaylistContextType\n // the level index to load\n level: number | null\n // TODO: what is id?\n id: number | null\n // defines if the loader is handling a sidx request for the playlist\n isSidxRequest?: boolean\n // internal reprsentation of a parsed m3u8 level playlist\n levelDetails?: Level\n}\n","/*\n*\n* All objects in the event handling chain should inherit from this class\n*\n*/\n\nimport { logger } from './utils/logger';\nimport { ErrorTypes, ErrorDetails } from './errors';\nimport Event from './events';\nimport Hls from './hls';\n\nconst FORBIDDEN_EVENT_NAMES = {\n 'hlsEventGeneric': true,\n 'hlsHandlerDestroying': true,\n 'hlsHandlerDestroyed': true\n};\n\nclass EventHandler {\n hls: Hls;\n handledEvents: any[];\n useGenericHandler: boolean;\n\n constructor (hls: Hls, ...events: any[]) {\n this.hls = hls;\n this.onEvent = this.onEvent.bind(this);\n this.handledEvents = events;\n this.useGenericHandler = true;\n\n this.registerListeners();\n }\n\n destroy () {\n this.onHandlerDestroying();\n this.unregisterListeners();\n this.onHandlerDestroyed();\n }\n\n protected onHandlerDestroying () {}\n protected onHandlerDestroyed () {}\n\n isEventHandler () {\n return typeof this.handledEvents === 'object' && this.handledEvents.length && typeof this.onEvent === 'function';\n }\n\n registerListeners () {\n if (this.isEventHandler()) {\n this.handledEvents.forEach(function (event) {\n if (FORBIDDEN_EVENT_NAMES[event]) {\n throw new Error('Forbidden event-name: ' + event);\n }\n\n this.hls.on(event, this.onEvent);\n }, this);\n }\n }\n\n unregisterListeners () {\n if (this.isEventHandler()) {\n this.handledEvents.forEach(function (event) {\n this.hls.off(event, this.onEvent);\n }, this);\n }\n }\n\n /**\n * arguments: event (string), data (any)\n */\n onEvent (event: string, data: any) {\n this.onEventGeneric(event, data);\n }\n\n onEventGeneric (event: string, data: any) {\n let eventToFunction = function (event: string, data: any) {\n let funcName = 'on' + event.replace('hls', '');\n if (typeof this[funcName] !== 'function') {\n throw new Error(`Event ${event} has no generic handler in this ${this.constructor.name} class (tried ${funcName})`);\n }\n\n return this[funcName].bind(this, data);\n };\n try {\n eventToFunction.call(this, event, data).call();\n } catch (err) {\n logger.error(`An internal error happened while handling event ${event}. Error message: \"${err.message}\". Here is a stacktrace:`, err);\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.OTHER_ERROR, details: ErrorDetails.INTERNAL_EXCEPTION, fatal: false, event: event, err: err });\n }\n }\n}\n\nexport default EventHandler;\n","import { buildAbsoluteURL } from 'url-toolkit';\n\nexport default class LevelKey {\n private _uri: string | null = null;\n\n public baseuri: string;\n public reluri: string;\n public method: string | null = null;\n public key: Uint8Array | null = null;\n public iv: Uint8Array | null = null;\n\n constructor (baseURI: string, relativeURI: string) {\n this.baseuri = baseURI;\n this.reluri = relativeURI;\n }\n\n get uri () {\n if (!this._uri && this.reluri) {\n this._uri = buildAbsoluteURL(this.baseuri, this.reluri, { alwaysNormalize: true });\n }\n\n return this._uri;\n }\n}\n","\nimport { buildAbsoluteURL } from 'url-toolkit';\nimport { logger } from '../utils/logger';\nimport LevelKey from './level-key';\nimport { PlaylistLevelType } from '../types/loader';\n\nexport enum ElementaryStreamTypes {\n AUDIO = 'audio',\n VIDEO = 'video',\n}\n\nexport default class Fragment {\n private _url: string | null = null;\n private _byteRange: number[] | null = null;\n private _decryptdata: LevelKey | null = null;\n\n // Holds the types of data this fragment supports\n private _elementaryStreams: Record<ElementaryStreamTypes, boolean> = {\n [ElementaryStreamTypes.AUDIO]: false,\n [ElementaryStreamTypes.VIDEO]: false\n };\n\n // deltaPTS tracks the change in presentation timestamp between fragments\n public deltaPTS: number = 0;\n\n public rawProgramDateTime: string | null = null;\n public programDateTime: number | null = null;\n public title: string | null = null;\n public tagList: Array<string[]> = [];\n\n // TODO: Move at least baseurl to constructor.\n // Currently we do a two-pass construction as use the Fragment class almost like a object for holding parsing state.\n // It may make more sense to just use a POJO to keep state during the parsing phase.\n // Have Fragment be the representation once we have a known state?\n // Something to think on.\n\n // Discontinuity Counter\n public cc!: number;\n\n public type!: PlaylistLevelType;\n // relurl is the portion of the URL that comes from inside the playlist.\n public relurl!: string;\n // baseurl is the URL to the playlist\n public baseurl!: string;\n // EXTINF has to be present for a m3u8 to be considered valid\n public duration!: number;\n // When this segment starts in the timeline\n public start!: number;\n // sn notates the sequence number for a segment, and if set to a string can be 'initSegment'\n public sn: number | 'initSegment' = 0;\n\n public urlId: number = 0;\n // level matches this fragment to a index playlist\n public level: number = 0;\n // levelkey is the EXT-X-KEY that applies to this segment for decryption\n // core difference from the private field _decryptdata is the lack of the initialized IV\n // _decryptdata will set the IV for this segment based on the segment number in the fragment\n public levelkey?: LevelKey;\n\n // TODO(typescript-xhrloader)\n public loader: any;\n\n // setByteRange converts a EXT-X-BYTERANGE attribute into a two element array\n setByteRange (value: string, previousFrag?: Fragment) {\n const params = value.split('@', 2);\n const byteRange: number[] = [];\n if (params.length === 1) {\n byteRange[0] = previousFrag ? previousFrag.byteRangeEndOffset : 0;\n } else {\n byteRange[0] = parseInt(params[1]);\n }\n byteRange[1] = parseInt(params[0]) + byteRange[0];\n this._byteRange = byteRange;\n }\n\n get url () {\n if (!this._url && this.relurl) {\n this._url = buildAbsoluteURL(this.baseurl, this.relurl, { alwaysNormalize: true });\n }\n\n return this._url;\n }\n\n set url (value) {\n this._url = value;\n }\n\n get byteRange (): number[] {\n if (!this._byteRange) {\n return [];\n }\n\n return this._byteRange;\n }\n\n /**\n * @type {number}\n */\n get byteRangeStartOffset () {\n return this.byteRange[0];\n }\n\n get byteRangeEndOffset () {\n return this.byteRange[1];\n }\n\n get decryptdata (): LevelKey | null {\n if (!this.levelkey && !this._decryptdata) {\n return null;\n }\n\n if (!this._decryptdata && this.levelkey) {\n let sn = this.sn;\n if (typeof sn !== 'number') {\n // We are fetching decryption data for a initialization segment\n // If the segment was encrypted with AES-128\n // It must have an IV defined. We cannot substitute the Segment Number in.\n if (this.levelkey && this.levelkey.method === 'AES-128' && !this.levelkey.iv) {\n logger.warn(`missing IV for initialization segment with method=\"${this.levelkey.method}\" - compliance issue`);\n }\n\n /*\n Be converted to a Number.\n 'initSegment' will become NaN.\n NaN, which when converted through ToInt32() -> +0.\n ---\n Explicitly set sn to resulting value from implicit conversions 'initSegment' values for IV generation.\n */\n sn = 0;\n }\n this._decryptdata = this.setDecryptDataFromLevelKey(this.levelkey, sn);\n }\n\n return this._decryptdata;\n }\n\n get endProgramDateTime () {\n if (this.programDateTime === null) {\n return null;\n }\n\n if (!Number.isFinite(this.programDateTime)) {\n return null;\n }\n\n let duration = !Number.isFinite(this.duration) ? 0 : this.duration;\n\n return this.programDateTime + (duration * 1000);\n }\n\n get encrypted () {\n return !!((this.decryptdata && this.decryptdata.uri !== null) && (this.decryptdata.key === null));\n }\n\n /**\n * @param {ElementaryStreamTypes} type\n */\n addElementaryStream (type: ElementaryStreamTypes) {\n this._elementaryStreams[type] = true;\n }\n\n /**\n * @param {ElementaryStreamTypes} type\n */\n hasElementaryStream (type: ElementaryStreamTypes) {\n return this._elementaryStreams[type] === true;\n }\n\n /**\n * Utility method for parseLevelPlaylist to create an initialization vector for a given segment\n * @param {number} segmentNumber - segment number to generate IV with\n * @returns {Uint8Array}\n */\n createInitializationVector (segmentNumber: number): Uint8Array {\n let uint8View = new Uint8Array(16);\n\n for (let i = 12; i < 16; i++) {\n uint8View[i] = (segmentNumber >> 8 * (15 - i)) & 0xff;\n }\n\n return uint8View;\n }\n\n /**\n * Utility method for parseLevelPlaylist to get a fragment's decryption data from the currently parsed encryption key data\n * @param levelkey - a playlist's encryption info\n * @param segmentNumber - the fragment's segment number\n * @returns {LevelKey} - an object to be applied as a fragment's decryptdata\n */\n setDecryptDataFromLevelKey (levelkey: LevelKey, segmentNumber: number): LevelKey {\n let decryptdata = levelkey;\n\n if (levelkey?.method && levelkey.uri && !levelkey.iv) {\n decryptdata = new LevelKey(levelkey.baseuri, levelkey.reluri);\n decryptdata.method = levelkey.method;\n decryptdata.iv = this.createInitializationVector(segmentNumber);\n }\n\n return decryptdata;\n }\n}\n","export default class Level {\n constructor (baseUrl) {\n // Please keep properties in alphabetical order\n this.endCC = 0;\n this.endSN = 0;\n this.fragments = [];\n this.initSegment = null;\n this.live = true;\n this.needSidxRanges = false;\n this.startCC = 0;\n this.startSN = 0;\n this.startTimeOffset = null;\n this.targetduration = 0;\n this.totalduration = 0;\n this.type = null;\n this.url = baseUrl;\n this.version = null;\n }\n\n get hasProgramDateTime () {\n return !!(this.fragments[0] && Number.isFinite(this.fragments[0].programDateTime));\n }\n}\n","const DECIMAL_RESOLUTION_REGEX = /^(\\d+)x(\\d+)$/; // eslint-disable-line no-useless-escape\nconst ATTR_LIST_REGEX = /\\s*(.+?)\\s*=((?:\\\".*?\\\")|.*?)(?:,|$)/g; // eslint-disable-line no-useless-escape\n\n// adapted from https://github.com/kanongil/node-m3u8parse/blob/master/attrlist.js\nclass AttrList {\n constructor (attrs) {\n if (typeof attrs === 'string') {\n attrs = AttrList.parseAttrList(attrs);\n }\n\n for (let attr in attrs) {\n if (attrs.hasOwnProperty(attr)) {\n this[attr] = attrs[attr];\n }\n }\n }\n\n decimalInteger (attrName) {\n const intValue = parseInt(this[attrName], 10);\n if (intValue > Number.MAX_SAFE_INTEGER) {\n return Infinity;\n }\n\n return intValue;\n }\n\n hexadecimalInteger (attrName) {\n if (this[attrName]) {\n let stringValue = (this[attrName] || '0x').slice(2);\n stringValue = ((stringValue.length & 1) ? '0' : '') + stringValue;\n\n const value = new Uint8Array(stringValue.length / 2);\n for (let i = 0; i < stringValue.length / 2; i++) {\n value[i] = parseInt(stringValue.slice(i * 2, i * 2 + 2), 16);\n }\n\n return value;\n } else {\n return null;\n }\n }\n\n hexadecimalIntegerAsNumber (attrName) {\n const intValue = parseInt(this[attrName], 16);\n if (intValue > Number.MAX_SAFE_INTEGER) {\n return Infinity;\n }\n\n return intValue;\n }\n\n decimalFloatingPoint (attrName) {\n return parseFloat(this[attrName]);\n }\n\n enumeratedString (attrName) {\n return this[attrName];\n }\n\n decimalResolution (attrName) {\n const res = DECIMAL_RESOLUTION_REGEX.exec(this[attrName]);\n if (res === null) {\n return undefined;\n }\n\n return {\n width: parseInt(res[1], 10),\n height: parseInt(res[2], 10)\n };\n }\n\n static parseAttrList (input) {\n let match, attrs = {};\n ATTR_LIST_REGEX.lastIndex = 0;\n while ((match = ATTR_LIST_REGEX.exec(input)) !== null) {\n let value = match[2], quote = '\"';\n\n if (value.indexOf(quote) === 0 &&\n value.lastIndexOf(quote) === (value.length - 1)) {\n value = value.slice(1, -1);\n }\n\n attrs[match[1]] = value;\n }\n return attrs;\n }\n}\n\nexport default AttrList;\n","// from http://mp4ra.org/codecs.html\nconst sampleEntryCodesISO = {\n audio: {\n 'a3ds': true,\n 'ac-3': true,\n 'ac-4': true,\n 'alac': true,\n 'alaw': true,\n 'dra1': true,\n 'dts+': true,\n 'dts-': true,\n 'dtsc': true,\n 'dtse': true,\n 'dtsh': true,\n 'ec-3': true,\n 'enca': true,\n 'g719': true,\n 'g726': true,\n 'm4ae': true,\n 'mha1': true,\n 'mha2': true,\n 'mhm1': true,\n 'mhm2': true,\n 'mlpa': true,\n 'mp4a': true,\n 'raw ': true,\n 'Opus': true,\n 'samr': true,\n 'sawb': true,\n 'sawp': true,\n 'sevc': true,\n 'sqcp': true,\n 'ssmv': true,\n 'twos': true,\n 'ulaw': true\n },\n video: {\n 'avc1': true,\n 'avc2': true,\n 'avc3': true,\n 'avc4': true,\n 'avcp': true,\n 'drac': true,\n 'dvav': true,\n 'dvhe': true,\n 'encv': true,\n 'hev1': true,\n 'hvc1': true,\n 'mjp2': true,\n 'mp4v': true,\n 'mvc1': true,\n 'mvc2': true,\n 'mvc3': true,\n 'mvc4': true,\n 'resv': true,\n 'rv60': true,\n 's263': true,\n 'svc1': true,\n 'svc2': true,\n 'vc-1': true,\n 'vp08': true,\n 'vp09': true\n }\n};\n\nexport type CodecType = 'audio' | 'video';\n\nfunction isCodecType (codec: string, type: CodecType): boolean {\n const typeCodes = sampleEntryCodesISO[type];\n return !!typeCodes && typeCodes[codec.slice(0, 4)] === true;\n}\n\nfunction isCodecSupportedInMp4 (codec: string, type: CodecType): boolean {\n return MediaSource.isTypeSupported(`${type || 'video'}/mp4;codecs=\"${codec}\"`);\n}\n\nexport { isCodecType, isCodecSupportedInMp4 };\n","import * as URLToolkit from 'url-toolkit';\n\nimport Fragment from './fragment';\nimport Level from './level';\nimport LevelKey from './level-key';\n\nimport AttrList from '../utils/attr-list';\nimport { logger } from '../utils/logger';\nimport { isCodecType, CodecType } from '../utils/codecs';\nimport { MediaPlaylist, AudioGroup, MediaPlaylistType } from '../types/media-playlist';\nimport { PlaylistLevelType } from '../types/loader';\n\n/**\n * M3U8 parser\n * @module\n */\n\n// https://regex101.com is your friend\nconst MASTER_PLAYLIST_REGEX = /(?:#EXT-X-STREAM-INF:([^\\n\\r]*)[\\r\\n]+([^\\r\\n]+)|#EXT-X-SESSION-DATA:([^\\n\\r]*)[\\r\\n]+)/g;\nconst MASTER_PLAYLIST_MEDIA_REGEX = /#EXT-X-MEDIA:(.*)/g;\n\nconst LEVEL_PLAYLIST_REGEX_FAST = new RegExp([\n /#EXTINF:\\s*(\\d*(?:\\.\\d+)?)(?:,(.*)\\s+)?/.source, // duration (#EXTINF:<duration>,<title>), group 1 => duration, group 2 => title\n /|(?!#)([\\S+ ?]+)/.source, // segment URI, group 3 => the URI (note newline is not eaten)\n /|#EXT-X-BYTERANGE:*(.+)/.source, // next segment's byterange, group 4 => range spec (x@y)\n /|#EXT-X-PROGRAM-DATE-TIME:(.+)/.source, // next segment's program date/time group 5 => the datetime spec\n /|#.*/.source // All other non-segment oriented tags will match with all groups empty\n].join(''), 'g');\n\nconst LEVEL_PLAYLIST_REGEX_SLOW = /(?:(?:#(EXTM3U))|(?:#EXT-X-(PLAYLIST-TYPE):(.+))|(?:#EXT-X-(MEDIA-SEQUENCE): *(\\d+))|(?:#EXT-X-(TARGETDURATION): *(\\d+))|(?:#EXT-X-(KEY):(.+))|(?:#EXT-X-(START):(.+))|(?:#EXT-X-(ENDLIST))|(?:#EXT-X-(DISCONTINUITY-SEQ)UENCE:(\\d+))|(?:#EXT-X-(DIS)CONTINUITY))|(?:#EXT-X-(VERSION):(\\d+))|(?:#EXT-X-(MAP):(.+))|(?:(#)([^:]*):(.*))|(?:(#)(.*))(?:.*)\\r?\\n?/;\n\nconst MP4_REGEX_SUFFIX = /\\.(mp4|m4s|m4v|m4a)$/i;\n\nexport default class M3U8Parser {\n static findGroup (groups: Array<AudioGroup>, mediaGroupId: string): AudioGroup | undefined {\n for (let i = 0; i < groups.length; i++) {\n const group = groups[i];\n if (group.id === mediaGroupId) {\n return group;\n }\n }\n }\n\n static convertAVC1ToAVCOTI (codec) {\n let avcdata = codec.split('.');\n let result;\n if (avcdata.length > 2) {\n result = avcdata.shift() + '.';\n result += parseInt(avcdata.shift()).toString(16);\n result += ('000' + parseInt(avcdata.shift()).toString(16)).substr(-4);\n } else {\n result = codec;\n }\n return result;\n }\n\n static resolve (url, baseUrl) {\n return URLToolkit.buildAbsoluteURL(baseUrl, url, { alwaysNormalize: true });\n }\n\n static parseMasterPlaylist (string: string, baseurl: string) {\n // TODO(typescript-level)\n let levels: Array<any> = [];\n let sessionData: Record<string, AttrList> = {};\n let hasSessionData = false;\n MASTER_PLAYLIST_REGEX.lastIndex = 0;\n\n // TODO(typescript-level)\n function setCodecs (codecs: Array<string>, level: any) {\n ['video', 'audio'].forEach((type: CodecType) => {\n const filtered = codecs.filter((codec) => isCodecType(codec, type));\n if (filtered.length) {\n const preferred = filtered.filter((codec) => {\n return codec.lastIndexOf('avc1', 0) === 0 || codec.lastIndexOf('mp4a', 0) === 0;\n });\n level[`${type}Codec`] = preferred.length > 0 ? preferred[0] : filtered[0];\n\n // remove from list\n codecs = codecs.filter((codec) => filtered.indexOf(codec) === -1);\n }\n });\n\n level.unknownCodecs = codecs;\n }\n\n let result: RegExpExecArray | null;\n while ((result = MASTER_PLAYLIST_REGEX.exec(string)) != null) {\n if (result[1]) {\n // '#EXT-X-STREAM-INF' is found, parse level tag in group 1\n\n // TODO(typescript-level)\n const level: any = {};\n\n const attrs = level.attrs = new AttrList(result[1]);\n level.url = M3U8Parser.resolve(result[2], baseurl);\n\n const resolution = attrs.decimalResolution('RESOLUTION');\n if (resolution) {\n level.width = resolution.width;\n level.height = resolution.height;\n }\n level.bitrate = attrs.decimalInteger('AVERAGE-BANDWIDTH') || attrs.decimalInteger('BANDWIDTH');\n level.name = attrs.NAME;\n\n setCodecs([].concat((attrs.CODECS || '').split(/[ ,]+/)), level);\n\n if (level.videoCodec && level.videoCodec.indexOf('avc1') !== -1) {\n level.videoCodec = M3U8Parser.convertAVC1ToAVCOTI(level.videoCodec);\n }\n\n levels.push(level);\n } else if (result[3]) {\n // '#EXT-X-SESSION-DATA' is found, parse session data in group 3\n let sessionAttrs = new AttrList(result[3]);\n if (sessionAttrs['DATA-ID']) {\n hasSessionData = true;\n sessionData[sessionAttrs['DATA-ID']] = sessionAttrs;\n }\n }\n }\n return {\n levels,\n sessionData: hasSessionData ? sessionData : null\n };\n }\n\n static parseMasterPlaylistMedia (string: string, baseurl: string, type: MediaPlaylistType, audioGroups: Array<AudioGroup> = []): Array<MediaPlaylist> {\n let result: RegExpExecArray | null;\n let medias: Array<MediaPlaylist> = [];\n let id = 0;\n MASTER_PLAYLIST_MEDIA_REGEX.lastIndex = 0;\n while ((result = MASTER_PLAYLIST_MEDIA_REGEX.exec(string)) !== null) {\n const attrs = new AttrList(result[1]);\n if (attrs.TYPE === type) {\n const media: MediaPlaylist = {\n attrs,\n id: id++,\n groupId: attrs['GROUP-ID'],\n instreamId: attrs['INSTREAM-ID'],\n name: attrs.NAME || attrs.LANGUAGE,\n type,\n default: (attrs.DEFAULT === 'YES'),\n autoselect: (attrs.AUTOSELECT === 'YES'),\n forced: (attrs.FORCED === 'YES'),\n lang: attrs.LANGUAGE\n };\n\n if (attrs.URI) {\n media.url = M3U8Parser.resolve(attrs.URI, baseurl);\n }\n\n if (audioGroups.length) {\n // If there are audio groups signalled in the manifest, let's look for a matching codec string for this track\n const groupCodec = M3U8Parser.findGroup(audioGroups, media.groupId as string);\n\n // If we don't find the track signalled, lets use the first audio groups codec we have\n // Acting as a best guess\n media.audioCodec = groupCodec ? groupCodec.codec : audioGroups[0].codec;\n }\n\n medias.push(media);\n }\n }\n return medias;\n }\n\n static parseLevelPlaylist (string: string, baseurl: string, id: number, type: PlaylistLevelType, levelUrlId: number) {\n let currentSN = 0;\n let totalduration = 0;\n let level = new Level(baseurl);\n let discontinuityCounter = 0;\n let prevFrag: Fragment | null = null;\n let frag: Fragment | null = new Fragment();\n let result: RegExpExecArray | RegExpMatchArray | null;\n let i: number;\n let levelkey: LevelKey | undefined;\n\n let firstPdtIndex = null;\n\n LEVEL_PLAYLIST_REGEX_FAST.lastIndex = 0;\n\n while ((result = LEVEL_PLAYLIST_REGEX_FAST.exec(string)) !== null) {\n const duration = result[1];\n if (duration) { // INF\n frag.duration = parseFloat(duration);\n // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n const title = (' ' + result[2]).slice(1);\n frag.title = title || null;\n frag.tagList.push(title ? [ 'INF', duration, title ] : [ 'INF', duration ]);\n } else if (result[3]) { // url\n if (Number.isFinite(frag.duration)) {\n const sn = currentSN++;\n frag.type = type;\n frag.start = totalduration;\n if (levelkey) {\n frag.levelkey = levelkey;\n }\n frag.sn = sn;\n frag.level = id;\n frag.cc = discontinuityCounter;\n frag.urlId = levelUrlId;\n frag.baseurl = baseurl;\n // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n frag.relurl = (' ' + result[3]).slice(1);\n assignProgramDateTime(frag, prevFrag);\n\n level.fragments.push(frag);\n prevFrag = frag;\n totalduration += frag.duration;\n\n frag = new Fragment();\n }\n } else if (result[4]) { // X-BYTERANGE\n const data = (' ' + result[4]).slice(1);\n if (prevFrag) {\n frag.setByteRange(data, prevFrag);\n } else {\n frag.setByteRange(data);\n }\n } else if (result[5]) { // PROGRAM-DATE-TIME\n // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n frag.rawProgramDateTime = (' ' + result[5]).slice(1);\n frag.tagList.push(['PROGRAM-DATE-TIME', frag.rawProgramDateTime]);\n if (firstPdtIndex === null) {\n firstPdtIndex = level.fragments.length;\n }\n } else {\n result = result[0].match(LEVEL_PLAYLIST_REGEX_SLOW);\n if (!result) {\n logger.warn('No matches on slow regex match for level playlist!');\n continue;\n }\n for (i = 1; i < result.length; i++) {\n if (typeof result[i] !== 'undefined') {\n break;\n }\n }\n\n // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n const value1 = (' ' + result[i + 1]).slice(1);\n const value2 = (' ' + result[i + 2]).slice(1);\n\n switch (result[i]) {\n case '#':\n frag.tagList.push(value2 ? [ value1, value2 ] : [ value1 ]);\n break;\n case 'PLAYLIST-TYPE':\n level.type = value1.toUpperCase();\n break;\n case 'MEDIA-SEQUENCE':\n currentSN = level.startSN = parseInt(value1);\n break;\n case 'TARGETDURATION':\n level.targetduration = parseFloat(value1);\n break;\n case 'VERSION':\n level.version = parseInt(value1);\n break;\n case 'EXTM3U':\n break;\n case 'ENDLIST':\n level.live = false;\n break;\n case 'DIS':\n discontinuityCounter++;\n frag.tagList.push(['DIS']);\n break;\n case 'DISCONTINUITY-SEQ':\n discontinuityCounter = parseInt(value1);\n break;\n case 'KEY': {\n // https://tools.ietf.org/html/rfc8216#section-4.3.2.4\n const decryptparams = value1;\n const keyAttrs = new AttrList(decryptparams);\n const decryptmethod = keyAttrs.enumeratedString('METHOD');\n const decrypturi = keyAttrs.URI;\n const decryptiv = keyAttrs.hexadecimalInteger('IV');\n // From RFC: This attribute is OPTIONAL; its absence indicates an implicit value of \"identity\".\n const decryptkeyformat = keyAttrs.KEYFORMAT || 'identity';\n\n if (decryptkeyformat === 'com.apple.streamingkeydelivery') {\n logger.warn('Keyformat com.apple.streamingkeydelivery is not supported');\n continue;\n }\n\n if (decryptmethod) {\n levelkey = new LevelKey(baseurl, decrypturi);\n if ((decrypturi) && (['AES-128', 'SAMPLE-AES', 'SAMPLE-AES-CENC'].indexOf(decryptmethod) >= 0)) {\n levelkey.method = decryptmethod;\n levelkey.key = null;\n // Initialization Vector (IV)\n levelkey.iv = decryptiv;\n }\n }\n break;\n }\n case 'START': {\n const startAttrs = new AttrList(value1);\n const startTimeOffset = startAttrs.decimalFloatingPoint('TIME-OFFSET');\n // TIME-OFFSET can be 0\n if (Number.isFinite(startTimeOffset)) {\n level.startTimeOffset = startTimeOffset;\n }\n break;\n }\n case 'MAP': {\n const mapAttrs = new AttrList(value1);\n frag.relurl = mapAttrs.URI;\n if (mapAttrs.BYTERANGE) {\n frag.setByteRange(mapAttrs.BYTERANGE);\n }\n frag.baseurl = baseurl;\n frag.level = id;\n frag.type = type;\n frag.sn = 'initSegment';\n level.initSegment = frag;\n frag = new Fragment();\n frag.rawProgramDateTime = level.initSegment.rawProgramDateTime;\n break;\n }\n default:\n logger.warn(`line parsed but not handled: ${result}`);\n break;\n }\n }\n }\n frag = prevFrag;\n // logger.log('found ' + level.fragments.length + ' fragments');\n if (frag && !frag.relurl) {\n level.fragments.pop();\n totalduration -= frag.duration;\n }\n level.totalduration = totalduration;\n level.averagetargetduration = totalduration / level.fragments.length;\n level.endSN = currentSN - 1;\n level.startCC = level.fragments[0] ? level.fragments[0].cc : 0;\n level.endCC = discontinuityCounter;\n\n if (!level.initSegment && level.fragments.length) {\n // this is a bit lurky but HLS really has no other way to tell us\n // if the fragments are TS or MP4, except if we download them :/\n // but this is to be able to handle SIDX.\n if (level.fragments.every((frag) => MP4_REGEX_SUFFIX.test(frag.relurl))) {\n logger.warn('MP4 fragments found but no init segment (probably no MAP, incomplete M3U8), trying to fetch SIDX');\n\n frag = new Fragment();\n frag.relurl = level.fragments[0].relurl;\n frag.baseurl = baseurl;\n frag.level = id;\n frag.type = type;\n frag.sn = 'initSegment';\n\n level.initSegment = frag;\n level.needSidxRanges = true;\n }\n }\n\n /**\n * Backfill any missing PDT values\n \"If the first EXT-X-PROGRAM-DATE-TIME tag in a Playlist appears after\n one or more Media Segment URIs, the client SHOULD extrapolate\n backward from that tag (using EXTINF durations and/or media\n timestamps) to associate dates with those segments.\"\n * We have already extrapolated forward, but all fragments up to the first instance of PDT do not have their PDTs\n * computed.\n */\n if (firstPdtIndex) {\n backfillProgramDateTimes(level.fragments, firstPdtIndex);\n }\n\n return level;\n }\n}\n\nfunction backfillProgramDateTimes (fragments, startIndex) {\n let fragPrev = fragments[startIndex];\n for (let i = startIndex - 1; i >= 0; i--) {\n const frag = fragments[i];\n frag.programDateTime = fragPrev.programDateTime - (frag.duration * 1000);\n fragPrev = frag;\n }\n}\n\nfunction assignProgramDateTime (frag, prevFrag) {\n if (frag.rawProgramDateTime) {\n frag.programDateTime = Date.parse(frag.rawProgramDateTime);\n } else if (prevFrag?.programDateTime) {\n frag.programDateTime = prevFrag.endProgramDateTime;\n }\n\n if (!Number.isFinite(frag.programDateTime)) {\n frag.programDateTime = null;\n frag.rawProgramDateTime = null;\n }\n}\n","/**\n * PlaylistLoader - delegate for media manifest/playlist loading tasks. Takes care of parsing media to internal data-models.\n *\n * Once loaded, dispatches events with parsed data-models of manifest/levels/audio/subtitle tracks.\n *\n * Uses loader(s) set in config to do actual internal loading of resource tasks.\n *\n * @module\n *\n */\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport { Loader, PlaylistContextType, PlaylistLoaderContext, PlaylistLevelType, LoaderCallbacks, LoaderResponse, LoaderStats, LoaderConfiguration } from '../types/loader';\nimport MP4Demuxer from '../demux/mp4demuxer';\nimport M3U8Parser from './m3u8-parser';\nimport { AudioGroup } from '../types/media-playlist';\n\nconst { performance } = window;\n\n/**\n * @constructor\n */\nclass PlaylistLoader extends EventHandler {\n private loaders: Partial<Record<PlaylistContextType, Loader<PlaylistLoaderContext>>> = {};\n\n /**\n * @constructs\n * @param {Hls} hls\n */\n constructor (hls) {\n super(hls,\n Event.MANIFEST_LOADING,\n Event.LEVEL_LOADING,\n Event.AUDIO_TRACK_LOADING,\n Event.SUBTITLE_TRACK_LOADING);\n }\n\n /**\n * @param {PlaylistContextType} type\n * @returns {boolean}\n */\n static canHaveQualityLevels (type: PlaylistContextType): boolean {\n return (type !== PlaylistContextType.AUDIO_TRACK &&\n type !== PlaylistContextType.SUBTITLE_TRACK);\n }\n\n /**\n * Map context.type to LevelType\n * @param {PlaylistLoaderContext} context\n * @returns {LevelType}\n */\n static mapContextToLevelType (context: PlaylistLoaderContext): PlaylistLevelType {\n const { type } = context;\n\n switch (type) {\n case PlaylistContextType.AUDIO_TRACK:\n return PlaylistLevelType.AUDIO;\n case PlaylistContextType.SUBTITLE_TRACK:\n return PlaylistLevelType.SUBTITLE;\n default:\n return PlaylistLevelType.MAIN;\n }\n }\n\n static getResponseUrl (response: LoaderResponse, context: PlaylistLoaderContext): string {\n let url = response.url;\n // responseURL not supported on some browsers (it is used to detect URL redirection)\n // data-uri mode also not supported (but no need to detect redirection)\n if (url === undefined || url.indexOf('data:') === 0) {\n // fallback to initial URL\n url = context.url;\n }\n return url;\n }\n\n /**\n * Returns defaults or configured loader-type overloads (pLoader and loader config params)\n * Default loader is XHRLoader (see utils)\n * @param {PlaylistLoaderContext} context\n * @returns {Loader} or other compatible configured overload\n */\n createInternalLoader (context: PlaylistLoaderContext): Loader<PlaylistLoaderContext> {\n const config = this.hls.config;\n const PLoader = config.pLoader;\n const Loader = config.loader;\n // TODO(typescript-config): Verify once config is typed that InternalLoader always returns a Loader\n const InternalLoader = PLoader || Loader;\n\n const loader = new InternalLoader(config);\n\n // TODO - Do we really need to assign the instance or if the dep has been lost\n context.loader = loader;\n this.loaders[context.type] = loader;\n\n return loader;\n }\n\n getInternalLoader (context: PlaylistLoaderContext): Loader<PlaylistLoaderContext> | undefined {\n return this.loaders[context.type];\n }\n\n resetInternalLoader (contextType: PlaylistContextType) {\n if (this.loaders[contextType]) {\n delete this.loaders[contextType];\n }\n }\n\n /**\n * Call `destroy` on all internal loader instances mapped (one per context type)\n */\n destroyInternalLoaders () {\n for (let contextType in this.loaders) {\n let loader = this.loaders[contextType];\n if (loader) {\n loader.destroy();\n }\n\n this.resetInternalLoader(contextType as PlaylistContextType);\n }\n }\n\n destroy () {\n this.destroyInternalLoaders();\n\n super.destroy();\n }\n\n onManifestLoading (data: { url: string; }) {\n this.load({\n url: data.url,\n type: PlaylistContextType.MANIFEST,\n level: 0,\n id: null,\n responseType: 'text'\n });\n }\n\n onLevelLoading (data: { url: string; level: number | null; id: number | null; }) {\n this.load({\n url: data.url,\n type: PlaylistContextType.LEVEL,\n level: data.level,\n id: data.id,\n responseType: 'text'\n });\n }\n\n onAudioTrackLoading (data: { url: string; id: number | null; }) {\n this.load({\n url: data.url,\n type: PlaylistContextType.AUDIO_TRACK,\n level: null,\n id: data.id,\n responseType: 'text'\n });\n }\n\n onSubtitleTrackLoading (data: { url: string; id: number | null; }) {\n this.load({\n url: data.url,\n type: PlaylistContextType.SUBTITLE_TRACK,\n level: null,\n id: data.id,\n responseType: 'text'\n });\n }\n\n load (context: PlaylistLoaderContext): boolean {\n const config = this.hls.config;\n\n logger.debug(`Loading playlist of type ${context.type}, level: ${context.level}, id: ${context.id}`);\n\n // Check if a loader for this context already exists\n let loader = this.getInternalLoader(context);\n if (loader) {\n const loaderContext = loader.context;\n if (loaderContext && loaderContext.url === context.url) { // same URL can't overlap\n logger.trace('playlist request ongoing');\n return false;\n } else {\n logger.warn(`aborting previous loader for type: ${context.type}`);\n loader.abort();\n }\n }\n\n let maxRetry: number;\n let timeout: number;\n let retryDelay: number;\n let maxRetryDelay: number;\n\n // apply different configs for retries depending on\n // context (manifest, level, audio/subs playlist)\n switch (context.type) {\n case PlaylistContextType.MANIFEST:\n maxRetry = config.manifestLoadingMaxRetry;\n timeout = config.manifestLoadingTimeOut;\n retryDelay = config.manifestLoadingRetryDelay;\n maxRetryDelay = config.manifestLoadingMaxRetryTimeout;\n break;\n case PlaylistContextType.LEVEL:\n // Disable internal loader retry logic, since we are managing retries in Level Controller\n maxRetry = 0;\n maxRetryDelay = 0;\n retryDelay = 0;\n timeout = config.levelLoadingTimeOut;\n // TODO Introduce retry settings for audio-track and subtitle-track, it should not use level retry config\n break;\n default:\n maxRetry = config.levelLoadingMaxRetry;\n timeout = config.levelLoadingTimeOut;\n retryDelay = config.levelLoadingRetryDelay;\n maxRetryDelay = config.levelLoadingMaxRetryTimeout;\n break;\n }\n\n loader = this.createInternalLoader(context);\n\n const loaderConfig: LoaderConfiguration = {\n timeout,\n maxRetry,\n retryDelay,\n maxRetryDelay\n };\n\n const loaderCallbacks: LoaderCallbacks<PlaylistLoaderContext> = {\n onSuccess: this.loadsuccess.bind(this),\n onError: this.loaderror.bind(this),\n onTimeout: this.loadtimeout.bind(this)\n };\n\n logger.debug(`Calling internal loader delegate for URL: ${context.url}`);\n loader.load(context, loaderConfig, loaderCallbacks);\n\n return true;\n }\n\n loadsuccess (response: LoaderResponse, stats: LoaderStats, context: PlaylistLoaderContext, networkDetails: unknown = null) {\n if (context.isSidxRequest) {\n this._handleSidxRequest(response, context);\n this._handlePlaylistLoaded(response, stats, context, networkDetails);\n return;\n }\n\n this.resetInternalLoader(context.type);\n if (typeof response.data !== 'string') {\n throw new Error('expected responseType of \"text\" for PlaylistLoader');\n }\n\n const string = response.data;\n\n stats.tload = performance.now();\n // stats.mtime = new Date(target.getResponseHeader('Last-Modified'));\n\n // Validate if it is an M3U8 at all\n if (string.indexOf('#EXTM3U') !== 0) {\n this._handleManifestParsingError(response, context, 'no EXTM3U delimiter', networkDetails);\n return;\n }\n\n // Check if chunk-list or master. handle empty chunk list case (first EXTINF not signaled, but TARGETDURATION present)\n if (string.indexOf('#EXTINF:') > 0 || string.indexOf('#EXT-X-TARGETDURATION:') > 0) {\n this._handleTrackOrLevelPlaylist(response, stats, context, networkDetails);\n } else {\n this._handleMasterPlaylist(response, stats, context, networkDetails);\n }\n }\n\n loaderror (response: LoaderResponse, context: PlaylistLoaderContext, networkDetails = null) {\n this._handleNetworkError(context, networkDetails, false, response);\n }\n\n loadtimeout (stats: LoaderStats, context: PlaylistLoaderContext, networkDetails = null) {\n this._handleNetworkError(context, networkDetails, true);\n }\n\n // TODO(typescript-config): networkDetails can currently be a XHR or Fetch impl,\n // but with custom loaders it could be generic investigate this further when config is typed\n _handleMasterPlaylist (response: LoaderResponse, stats: LoaderStats, context: PlaylistLoaderContext, networkDetails: unknown) {\n const hls = this.hls;\n const string = response.data as string;\n\n const url = PlaylistLoader.getResponseUrl(response, context);\n const { levels, sessionData } = M3U8Parser.parseMasterPlaylist(string, url);\n if (!levels.length) {\n this._handleManifestParsingError(response, context, 'no level found in manifest', networkDetails);\n return;\n }\n\n // multi level playlist, parse level info\n const audioGroups: Array<AudioGroup> = levels.map(level => ({\n id: level.attrs.AUDIO,\n codec: level.audioCodec\n }));\n\n const audioTracks = M3U8Parser.parseMasterPlaylistMedia(string, url, 'AUDIO', audioGroups);\n const subtitles = M3U8Parser.parseMasterPlaylistMedia(string, url, 'SUBTITLES');\n const captions = M3U8Parser.parseMasterPlaylistMedia(string, url, 'CLOSED-CAPTIONS');\n\n if (audioTracks.length) {\n // check if we have found an audio track embedded in main playlist (audio track without URI attribute)\n let embeddedAudioFound = false;\n audioTracks.forEach(audioTrack => {\n if (!audioTrack.url) {\n embeddedAudioFound = true;\n }\n });\n\n // if no embedded audio track defined, but audio codec signaled in quality level,\n // we need to signal this main audio track this could happen with playlists with\n // alt audio rendition in which quality levels (main)\n // contains both audio+video. but with mixed audio track not signaled\n if (embeddedAudioFound === false && levels[0].audioCodec && !levels[0].attrs.AUDIO) {\n logger.log('audio codec signaled in quality level, but no embedded audio track signaled, create one');\n audioTracks.unshift({\n type: 'main',\n name: 'main',\n default: false,\n autoselect: false,\n forced: false,\n id: -1,\n attrs: {},\n url: ''\n });\n }\n }\n\n hls.trigger(Event.MANIFEST_LOADED, {\n levels,\n audioTracks,\n subtitles,\n captions,\n url,\n stats,\n networkDetails,\n sessionData\n });\n }\n\n _handleTrackOrLevelPlaylist (response: LoaderResponse, stats: LoaderStats, context: PlaylistLoaderContext, networkDetails: unknown) {\n const hls = this.hls;\n\n const { id, level, type } = context;\n\n const url = PlaylistLoader.getResponseUrl(response, context);\n\n // if the values are null, they will result in the else conditional\n const levelUrlId = Number.isFinite(id as number) ? id as number : 0;\n const levelId = Number.isFinite(level as number) ? level as number : levelUrlId;\n\n const levelType = PlaylistLoader.mapContextToLevelType(context);\n const levelDetails = M3U8Parser.parseLevelPlaylist(response.data as string, url, levelId, levelType, levelUrlId);\n\n // set stats on level structure\n // TODO(jstackhouse): why? mixing concerns, is it just treated as value bag?\n (levelDetails as any).tload = stats.tload;\n\n if (!levelDetails.fragments.length) {\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.NETWORK_ERROR,\n details: ErrorDetails.LEVEL_EMPTY_ERROR,\n fatal: false,\n url: url,\n reason: 'no fragments found in level',\n level: typeof context.level === 'number' ? context.level : undefined\n });\n return;\n }\n\n // We have done our first request (Manifest-type) and receive\n // not a master playlist but a chunk-list (track/level)\n // We fire the manifest-loaded event anyway with the parsed level-details\n // by creating a single-level structure for it.\n if (type === PlaylistContextType.MANIFEST) {\n const singleLevel = {\n url,\n details: levelDetails\n };\n\n hls.trigger(Event.MANIFEST_LOADED, {\n levels: [singleLevel],\n audioTracks: [],\n url,\n stats,\n networkDetails,\n sessionData: null\n });\n }\n\n // save parsing time\n stats.tparsed = performance.now();\n\n // in case we need SIDX ranges\n // return early after calling load for\n // the SIDX box.\n if (levelDetails.needSidxRanges) {\n const sidxUrl = levelDetails.initSegment.url;\n this.load({\n url: sidxUrl,\n isSidxRequest: true,\n type,\n level,\n levelDetails,\n id,\n rangeStart: 0,\n rangeEnd: 2048,\n responseType: 'arraybuffer'\n });\n return;\n }\n\n // extend the context with the new levelDetails property\n context.levelDetails = levelDetails;\n\n this._handlePlaylistLoaded(response, stats, context, networkDetails);\n }\n\n _handleSidxRequest (response: LoaderResponse, context: PlaylistLoaderContext) {\n if (typeof response.data === 'string') {\n throw new Error('sidx request must be made with responseType of array buffer');\n }\n\n const sidxInfo = MP4Demuxer.parseSegmentIndex(new Uint8Array(response.data));\n // if provided fragment does not contain sidx, early return\n if (!sidxInfo) {\n return;\n }\n const sidxReferences = sidxInfo.references;\n const levelDetails = context.levelDetails;\n sidxReferences.forEach((segmentRef, index) => {\n const segRefInfo = segmentRef.info;\n if (!levelDetails) {\n return;\n }\n const frag = levelDetails.fragments[index];\n if (frag.byteRange.length === 0) {\n frag.setByteRange(String(1 + segRefInfo.end - segRefInfo.start) + '@' + String(segRefInfo.start));\n }\n });\n\n if (levelDetails) {\n levelDetails.initSegment.setByteRange(String(sidxInfo.moovEndOffset) + '@0');\n }\n }\n\n _handleManifestParsingError (response: LoaderResponse, context: PlaylistLoaderContext, reason: string, networkDetails: unknown) {\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.NETWORK_ERROR,\n details: ErrorDetails.MANIFEST_PARSING_ERROR,\n fatal: true,\n url: response.url,\n reason,\n networkDetails\n });\n }\n\n _handleNetworkError (context: PlaylistLoaderContext, networkDetails: unknown, timeout: boolean = false, response: LoaderResponse | null = null) {\n logger.info(`A network error occured while loading a ${context.type}-type playlist`);\n\n let details;\n let fatal;\n\n const loader = this.getInternalLoader(context);\n\n switch (context.type) {\n case PlaylistContextType.MANIFEST:\n details = (timeout ? ErrorDetails.MANIFEST_LOAD_TIMEOUT : ErrorDetails.MANIFEST_LOAD_ERROR);\n fatal = true;\n break;\n case PlaylistContextType.LEVEL:\n details = (timeout ? ErrorDetails.LEVEL_LOAD_TIMEOUT : ErrorDetails.LEVEL_LOAD_ERROR);\n fatal = false;\n break;\n case PlaylistContextType.AUDIO_TRACK:\n details = (timeout ? ErrorDetails.AUDIO_TRACK_LOAD_TIMEOUT : ErrorDetails.AUDIO_TRACK_LOAD_ERROR);\n fatal = false;\n break;\n default:\n // details = ...?\n fatal = false;\n }\n\n if (loader) {\n loader.abort();\n this.resetInternalLoader(context.type);\n }\n\n // TODO(typescript-events): when error events are handled, type this\n let errorData: any = {\n type: ErrorTypes.NETWORK_ERROR,\n details,\n fatal,\n url: context.url,\n loader,\n context,\n networkDetails\n };\n\n if (response) {\n errorData.response = response;\n }\n\n this.hls.trigger(Event.ERROR, errorData);\n }\n\n _handlePlaylistLoaded (response: LoaderResponse, stats: LoaderStats, context: PlaylistLoaderContext, networkDetails: unknown) {\n const { type, level, id, levelDetails } = context;\n\n if (!levelDetails || !levelDetails.targetduration) {\n this._handleManifestParsingError(response, context, 'invalid target duration', networkDetails);\n return;\n }\n\n const canHaveLevels = PlaylistLoader.canHaveQualityLevels(context.type);\n if (canHaveLevels) {\n this.hls.trigger(Event.LEVEL_LOADED, {\n details: levelDetails,\n level: level || 0,\n id: id || 0,\n stats,\n networkDetails\n });\n } else {\n switch (type) {\n case PlaylistContextType.AUDIO_TRACK:\n this.hls.trigger(Event.AUDIO_TRACK_LOADED, {\n details: levelDetails,\n id,\n stats,\n networkDetails\n });\n break;\n case PlaylistContextType.SUBTITLE_TRACK:\n this.hls.trigger(Event.SUBTITLE_TRACK_LOADED, {\n details: levelDetails,\n id,\n stats,\n networkDetails\n });\n break;\n }\n }\n }\n}\n\nexport default PlaylistLoader;\n","/*\n * Fragment Loader\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\n\nclass FragmentLoader extends EventHandler {\n constructor (hls) {\n super(hls, Event.FRAG_LOADING);\n this.loaders = {};\n }\n\n destroy () {\n let loaders = this.loaders;\n for (let loaderName in loaders) {\n let loader = loaders[loaderName];\n if (loader) {\n loader.destroy();\n }\n }\n this.loaders = {};\n\n super.destroy();\n }\n\n onFragLoading (data) {\n const frag = data.frag,\n type = frag.type,\n loaders = this.loaders,\n config = this.hls.config,\n FragmentILoader = config.fLoader,\n DefaultILoader = config.loader;\n\n // reset fragment state\n frag.loaded = 0;\n\n let loader = loaders[type];\n if (loader) {\n logger.warn(`abort previous fragment loader for type: ${type}`);\n loader.abort();\n }\n\n loader = loaders[type] = frag.loader =\n config.fLoader ? new FragmentILoader(config) : new DefaultILoader(config);\n\n let loaderContext, loaderConfig, loaderCallbacks;\n\n loaderContext = { url: frag.url, frag: frag, responseType: 'arraybuffer', progressData: false };\n\n let start = frag.byteRangeStartOffset,\n end = frag.byteRangeEndOffset;\n\n if (Number.isFinite(start) && Number.isFinite(end)) {\n loaderContext.rangeStart = start;\n loaderContext.rangeEnd = end;\n }\n\n loaderConfig = {\n timeout: config.fragLoadingTimeOut,\n maxRetry: 0,\n retryDelay: 0,\n maxRetryDelay: config.fragLoadingMaxRetryTimeout\n };\n\n loaderCallbacks = {\n onSuccess: this.loadsuccess.bind(this),\n onError: this.loaderror.bind(this),\n onTimeout: this.loadtimeout.bind(this),\n onProgress: this.loadprogress.bind(this)\n };\n\n loader.load(loaderContext, loaderConfig, loaderCallbacks);\n }\n\n loadsuccess (response, stats, context, networkDetails = null) {\n let payload = response.data, frag = context.frag;\n // detach fragment loader on load success\n frag.loader = undefined;\n this.loaders[frag.type] = undefined;\n this.hls.trigger(Event.FRAG_LOADED, { payload: payload, frag: frag, stats: stats, networkDetails: networkDetails });\n }\n\n loaderror (response, context, networkDetails = null) {\n const frag = context.frag;\n let loader = frag.loader;\n if (loader) {\n loader.abort();\n }\n\n this.loaders[frag.type] = undefined;\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.NETWORK_ERROR, details: ErrorDetails.FRAG_LOAD_ERROR, fatal: false, frag: context.frag, response: response, networkDetails: networkDetails });\n }\n\n loadtimeout (stats, context, networkDetails = null) {\n const frag = context.frag;\n let loader = frag.loader;\n if (loader) {\n loader.abort();\n }\n\n this.loaders[frag.type] = undefined;\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.NETWORK_ERROR, details: ErrorDetails.FRAG_LOAD_TIMEOUT, fatal: false, frag: context.frag, networkDetails: networkDetails });\n }\n\n // data will be used for progressive parsing\n loadprogress (stats, context, data, networkDetails = null) { // jshint ignore:line\n let frag = context.frag;\n frag.loaded = stats.loaded;\n this.hls.trigger(Event.FRAG_LOAD_PROGRESS, { frag: frag, stats: stats, networkDetails: networkDetails });\n }\n}\n\nexport default FragmentLoader;\n","/*\n * Decrypt key Loader\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport Hls from '../hls';\nimport Fragment from './fragment';\nimport { LoaderStats, LoaderResponse, LoaderContext, LoaderConfiguration, LoaderCallbacks } from '../types/loader';\n\ninterface OnKeyLoadingPayload {\n frag: Fragment\n}\n\ninterface KeyLoaderContext extends LoaderContext {\n frag: Fragment\n}\n\nclass KeyLoader extends EventHandler {\n public loaders = {};\n public decryptkey: Uint8Array | null = null;\n public decrypturl: string | null = null;\n\n constructor (hls: Hls) {\n super(hls, Event.KEY_LOADING);\n }\n\n destroy (): void {\n for (const loaderName in this.loaders) {\n let loader = this.loaders[loaderName];\n if (loader) {\n loader.destroy();\n }\n }\n this.loaders = {};\n\n super.destroy();\n }\n\n onKeyLoading (data: OnKeyLoadingPayload) {\n const { frag } = data;\n const type = frag.type;\n const loader = this.loaders[type];\n if (!frag.decryptdata) {\n logger.warn('Missing decryption data on fragment in onKeyLoading');\n return;\n }\n\n // Load the key if the uri is different from previous one, or if the decrypt key has not yet been retrieved\n const uri = frag.decryptdata.uri;\n if (uri !== this.decrypturl || this.decryptkey === null) {\n let config = this.hls.config;\n if (loader) {\n logger.warn(`abort previous key loader for type:${type}`);\n loader.abort();\n }\n if (!uri) {\n logger.warn('key uri is falsy');\n return;\n }\n\n frag.loader = this.loaders[type] = new config.loader(config);\n this.decrypturl = uri;\n this.decryptkey = null;\n\n const loaderContext: KeyLoaderContext = {\n url: uri,\n frag: frag,\n responseType: 'arraybuffer'\n };\n\n // maxRetry is 0 so that instead of retrying the same key on the same variant multiple times,\n // key-loader will trigger an error and rely on stream-controller to handle retry logic.\n // this will also align retry logic with fragment-loader\n const loaderConfig: LoaderConfiguration = {\n timeout: config.fragLoadingTimeOut,\n maxRetry: 0,\n retryDelay: config.fragLoadingRetryDelay,\n maxRetryDelay: config.fragLoadingMaxRetryTimeout\n };\n\n const loaderCallbacks: LoaderCallbacks<KeyLoaderContext> = {\n onSuccess: this.loadsuccess.bind(this),\n onError: this.loaderror.bind(this),\n onTimeout: this.loadtimeout.bind(this)\n };\n\n frag.loader.load(loaderContext, loaderConfig, loaderCallbacks);\n } else if (this.decryptkey) {\n // Return the key if it's already been loaded\n frag.decryptdata.key = this.decryptkey;\n this.hls.trigger(Event.KEY_LOADED, { frag: frag });\n }\n }\n\n loadsuccess (response: LoaderResponse, stats: LoaderStats, context: KeyLoaderContext) {\n let frag = context.frag;\n if (!frag.decryptdata) {\n logger.error('after key load, decryptdata unset');\n return;\n }\n this.decryptkey = frag.decryptdata.key = new Uint8Array(response.data as ArrayBuffer);\n\n // detach fragment loader on load success\n frag.loader = undefined;\n delete this.loaders[frag.type];\n this.hls.trigger(Event.KEY_LOADED, { frag: frag });\n }\n\n loaderror (response: LoaderResponse, context: KeyLoaderContext) {\n let frag = context.frag;\n let loader = frag.loader;\n if (loader) {\n loader.abort();\n }\n\n delete this.loaders[frag.type];\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.NETWORK_ERROR, details: ErrorDetails.KEY_LOAD_ERROR, fatal: false, frag, response });\n }\n\n loadtimeout (stats: LoaderStats, context: KeyLoaderContext) {\n let frag = context.frag;\n let loader = frag.loader;\n if (loader) {\n loader.abort();\n }\n\n delete this.loaders[frag.type];\n this.hls.trigger(Event.ERROR, { type: ErrorTypes.NETWORK_ERROR, details: ErrorDetails.KEY_LOAD_TIMEOUT, fatal: false, frag });\n }\n}\n\nexport default KeyLoader;\n","import EventHandler from '../event-handler';\nimport Event from '../events';\n\nexport const FragmentState = {\n NOT_LOADED: 'NOT_LOADED',\n APPENDING: 'APPENDING',\n PARTIAL: 'PARTIAL',\n OK: 'OK'\n};\n\nexport class FragmentTracker extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.BUFFER_APPENDED,\n Event.FRAG_BUFFERED,\n Event.FRAG_LOADED\n );\n\n this.bufferPadding = 0.2;\n\n this.fragments = Object.create(null);\n this.timeRanges = Object.create(null);\n\n this.config = hls.config;\n }\n\n destroy () {\n this.fragments = Object.create(null);\n this.timeRanges = Object.create(null);\n this.config = null;\n EventHandler.prototype.destroy.call(this);\n super.destroy();\n }\n\n /**\n * Return a Fragment that match the position and levelType.\n * If not found any Fragment, return null\n * @param {number} position\n * @param {LevelType} levelType\n * @returns {Fragment|null}\n */\n getBufferedFrag (position, levelType) {\n const fragments = this.fragments;\n const bufferedFrags = Object.keys(fragments).filter(key => {\n const fragmentEntity = fragments[key];\n if (fragmentEntity.body.type !== levelType) {\n return false;\n }\n\n if (!fragmentEntity.buffered) {\n return false;\n }\n\n const frag = fragmentEntity.body;\n return frag.startPTS <= position && position <= frag.endPTS;\n });\n if (bufferedFrags.length === 0) {\n return null;\n } else {\n // https://github.com/video-dev/hls.js/pull/1545#discussion_r166229566\n const bufferedFragKey = bufferedFrags.pop();\n return fragments[bufferedFragKey].body;\n }\n }\n\n /**\n * Partial fragments effected by coded frame eviction will be removed\n * The browser will unload parts of the buffer to free up memory for new buffer data\n * Fragments will need to be reloaded when the buffer is freed up, removing partial fragments will allow them to reload(since there might be parts that are still playable)\n * @param {String} elementaryStream The elementaryStream of media this is (eg. video/audio)\n * @param {TimeRanges} timeRange TimeRange object from a sourceBuffer\n */\n detectEvictedFragments (elementaryStream, timeRange) {\n // Check if any flagged fragments have been unloaded\n Object.keys(this.fragments).forEach(key => {\n const fragmentEntity = this.fragments[key];\n if (!fragmentEntity || !fragmentEntity.buffered) {\n return;\n }\n const esData = fragmentEntity.range[elementaryStream];\n if (!esData) {\n return;\n }\n const fragmentTimes = esData.time;\n for (let i = 0; i < fragmentTimes.length; i++) {\n const time = fragmentTimes[i];\n if (!this.isTimeBuffered(time.startPTS, time.endPTS, timeRange)) {\n // Unregister partial fragment as it needs to load again to be reused\n this.removeFragment(fragmentEntity.body);\n break;\n }\n }\n });\n }\n\n /**\n * Checks if the fragment passed in is loaded in the buffer properly\n * Partially loaded fragments will be registered as a partial fragment\n * @param {Object} fragment Check the fragment against all sourceBuffers loaded\n */\n detectPartialFragments (fragment) {\n let fragKey = this.getFragmentKey(fragment);\n let fragmentEntity = this.fragments[fragKey];\n if (fragmentEntity) {\n fragmentEntity.buffered = true;\n\n Object.keys(this.timeRanges).forEach(elementaryStream => {\n if (fragment.hasElementaryStream(elementaryStream)) {\n let timeRange = this.timeRanges[elementaryStream];\n // Check for malformed fragments\n // Gaps need to be calculated for each elementaryStream\n fragmentEntity.range[elementaryStream] = this.getBufferedTimes(fragment.startPTS, fragment.endPTS, timeRange);\n }\n });\n }\n }\n\n getBufferedTimes (startPTS, endPTS, timeRange) {\n let fragmentTimes = [];\n let startTime, endTime;\n let fragmentPartial = false;\n for (let i = 0; i < timeRange.length; i++) {\n startTime = timeRange.start(i) - this.bufferPadding;\n endTime = timeRange.end(i) + this.bufferPadding;\n if (startPTS >= startTime && endPTS <= endTime) {\n // Fragment is entirely contained in buffer\n // No need to check the other timeRange times since it's completely playable\n fragmentTimes.push({\n startPTS: Math.max(startPTS, timeRange.start(i)),\n endPTS: Math.min(endPTS, timeRange.end(i))\n });\n break;\n } else if (startPTS < endTime && endPTS > startTime) {\n // Check for intersection with buffer\n // Get playable sections of the fragment\n fragmentTimes.push({\n startPTS: Math.max(startPTS, timeRange.start(i)),\n endPTS: Math.min(endPTS, timeRange.end(i))\n });\n fragmentPartial = true;\n } else if (endPTS <= startTime) {\n // No need to check the rest of the timeRange as it is in order\n break;\n }\n }\n\n return {\n time: fragmentTimes,\n partial: fragmentPartial\n };\n }\n\n getFragmentKey (fragment) {\n return `${fragment.type}_${fragment.level}_${fragment.urlId}_${fragment.sn}`;\n }\n\n /**\n * Gets the partial fragment for a certain time\n * @param {Number} time\n * @returns {Object} fragment Returns a partial fragment at a time or null if there is no partial fragment\n */\n getPartialFragment (time) {\n let timePadding, startTime, endTime;\n let bestFragment = null;\n let bestOverlap = 0;\n Object.keys(this.fragments).forEach(key => {\n const fragmentEntity = this.fragments[key];\n if (this.isPartial(fragmentEntity)) {\n startTime = fragmentEntity.body.startPTS - this.bufferPadding;\n endTime = fragmentEntity.body.endPTS + this.bufferPadding;\n if (time >= startTime && time <= endTime) {\n // Use the fragment that has the most padding from start and end time\n timePadding = Math.min(time - startTime, endTime - time);\n if (bestOverlap <= timePadding) {\n bestFragment = fragmentEntity.body;\n bestOverlap = timePadding;\n }\n }\n }\n });\n return bestFragment;\n }\n\n /**\n * @param {Object} fragment The fragment to check\n * @returns {String} Returns the fragment state when a fragment never loaded or if it partially loaded\n */\n getState (fragment) {\n let fragKey = this.getFragmentKey(fragment);\n let fragmentEntity = this.fragments[fragKey];\n let state = FragmentState.NOT_LOADED;\n\n if (fragmentEntity !== undefined) {\n if (!fragmentEntity.buffered) {\n state = FragmentState.APPENDING;\n } else if (this.isPartial(fragmentEntity) === true) {\n state = FragmentState.PARTIAL;\n } else {\n state = FragmentState.OK;\n }\n }\n\n return state;\n }\n\n isPartial (fragmentEntity) {\n return fragmentEntity.buffered === true &&\n ((fragmentEntity.range.video !== undefined && fragmentEntity.range.video.partial === true) ||\n (fragmentEntity.range.audio !== undefined && fragmentEntity.range.audio.partial === true));\n }\n\n isTimeBuffered (startPTS, endPTS, timeRange) {\n let startTime, endTime;\n for (let i = 0; i < timeRange.length; i++) {\n startTime = timeRange.start(i) - this.bufferPadding;\n endTime = timeRange.end(i) + this.bufferPadding;\n if (startPTS >= startTime && endPTS <= endTime) {\n return true;\n }\n\n if (endPTS <= startTime) {\n // No need to check the rest of the timeRange as it is in order\n return false;\n }\n }\n\n return false;\n }\n\n /**\n * Fires when a fragment loading is completed\n */\n onFragLoaded (e) {\n const fragment = e.frag;\n // don't track initsegment (for which sn is not a number)\n // don't track frags used for bitrateTest, they're irrelevant.\n if (!Number.isFinite(fragment.sn) || fragment.bitrateTest) {\n return;\n }\n\n this.fragments[this.getFragmentKey(fragment)] = {\n body: fragment,\n range: Object.create(null),\n buffered: false\n };\n }\n\n /**\n * Fires when the buffer is updated\n */\n onBufferAppended (e) {\n // Store the latest timeRanges loaded in the buffer\n this.timeRanges = e.timeRanges;\n Object.keys(this.timeRanges).forEach(elementaryStream => {\n let timeRange = this.timeRanges[elementaryStream];\n this.detectEvictedFragments(elementaryStream, timeRange);\n });\n }\n\n /**\n * Fires after a fragment has been loaded into the source buffer\n */\n onFragBuffered (e) {\n this.detectPartialFragments(e.frag);\n }\n\n /**\n * Return true if fragment tracker has the fragment.\n * @param {Object} fragment\n * @returns {boolean}\n */\n hasFragment (fragment) {\n const fragKey = this.getFragmentKey(fragment);\n return this.fragments[fragKey] !== undefined;\n }\n\n /**\n * Remove a fragment from fragment tracker until it is loaded again\n * @param {Object} fragment The fragment to remove\n */\n removeFragment (fragment) {\n let fragKey = this.getFragmentKey(fragment);\n delete this.fragments[fragKey];\n }\n\n /**\n * Remove all fragments from fragment tracker.\n */\n removeAllFragments () {\n this.fragments = Object.create(null);\n }\n}\n","type BinarySearchComparison < T > = (candidate: T) => -1 | 0 | 1;\n\nconst BinarySearch = {\n\n /**\n * Searches for an item in an array which matches a certain condition.\n * This requires the condition to only match one item in the array,\n * and for the array to be ordered.\n *\n * @param {Array<T>} list The array to search.\n * @param {BinarySearchComparison<T>} comparisonFn\n * Called and provided a candidate item as the first argument.\n * Should return:\n * > -1 if the item should be located at a lower index than the provided item.\n * > 1 if the item should be located at a higher index than the provided item.\n * > 0 if the item is the item you're looking for.\n *\n * @return {T | null} The object if it is found or null otherwise.\n */\n search: function<T> (list: T[], comparisonFn: BinarySearchComparison<T>): T | null {\n let minIndex: number = 0;\n let maxIndex: number = list.length - 1;\n let currentIndex: number | null = null;\n let currentElement: T | null = null;\n\n while (minIndex <= maxIndex) {\n currentIndex = (minIndex + maxIndex) / 2 | 0;\n currentElement = list[currentIndex];\n\n let comparisonResult = comparisonFn(currentElement);\n if (comparisonResult > 0) {\n minIndex = currentIndex + 1;\n } else if (comparisonResult < 0) {\n maxIndex = currentIndex - 1;\n } else {\n return currentElement;\n }\n }\n\n return null;\n }\n};\n\nexport default BinarySearch;\n","/**\n * @module BufferHelper\n *\n * Providing methods dealing with buffer length retrieval for example.\n *\n * In general, a helper around HTML5 MediaElement TimeRanges gathered from `buffered` property.\n *\n * Also @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/buffered\n*/\n\ntype BufferTimeRange = {\n start: number\n end: number\n};\n\ntype Bufferable = {\n buffered: TimeRanges\n};\n\nexport class BufferHelper {\n /**\n * Return true if `media`'s buffered include `position`\n * @param {Bufferable} media\n * @param {number} position\n * @returns {boolean}\n */\n static isBuffered (media: Bufferable, position: number): boolean {\n try {\n if (media) {\n let buffered = media.buffered;\n for (let i = 0; i < buffered.length; i++) {\n if (position >= buffered.start(i) && position <= buffered.end(i)) {\n return true;\n }\n }\n }\n } catch (error) {\n // this is to catch\n // InvalidStateError: Failed to read the 'buffered' property from 'SourceBuffer':\n // This SourceBuffer has been removed from the parent media source\n }\n return false;\n }\n\n static bufferInfo (\n media: Bufferable,\n pos: number,\n maxHoleDuration: number\n ): {\n len: number,\n start: number,\n end: number,\n nextStart?: number,\n } {\n try {\n if (media) {\n let vbuffered = media.buffered;\n let buffered: BufferTimeRange[] = [];\n let i: number;\n for (i = 0; i < vbuffered.length; i++) {\n buffered.push({ start: vbuffered.start(i), end: vbuffered.end(i) });\n }\n\n return this.bufferedInfo(buffered, pos, maxHoleDuration);\n }\n } catch (error) {\n // this is to catch\n // InvalidStateError: Failed to read the 'buffered' property from 'SourceBuffer':\n // This SourceBuffer has been removed from the parent media source\n }\n return { len: 0, start: pos, end: pos, nextStart: undefined };\n }\n\n static bufferedInfo (\n buffered: BufferTimeRange[],\n pos: number,\n maxHoleDuration: number\n ): {\n len: number,\n start: number,\n end: number,\n nextStart?: number,\n } {\n // sort on buffer.start/smaller end (IE does not always return sorted buffered range)\n buffered.sort(function (a, b) {\n let diff = a.start - b.start;\n if (diff) {\n return diff;\n } else {\n return b.end - a.end;\n }\n });\n\n let buffered2: BufferTimeRange[] = [];\n if (maxHoleDuration) {\n // there might be some small holes between buffer time range\n // consider that holes smaller than maxHoleDuration are irrelevant and build another\n // buffer time range representations that discards those holes\n for (let i = 0; i < buffered.length; i++) {\n let buf2len = buffered2.length;\n if (buf2len) {\n let buf2end = buffered2[buf2len - 1].end;\n // if small hole (value between 0 or maxHoleDuration ) or overlapping (negative)\n if ((buffered[i].start - buf2end) < maxHoleDuration) {\n // merge overlapping time ranges\n // update lastRange.end only if smaller than item.end\n // e.g. [ 1, 15] with [ 2,8] => [ 1,15] (no need to modify lastRange.end)\n // whereas [ 1, 8] with [ 2,15] => [ 1,15] ( lastRange should switch from [1,8] to [1,15])\n if (buffered[i].end > buf2end) {\n buffered2[buf2len - 1].end = buffered[i].end;\n }\n } else {\n // big hole\n buffered2.push(buffered[i]);\n }\n } else {\n // first value\n buffered2.push(buffered[i]);\n }\n }\n } else {\n buffered2 = buffered;\n }\n\n let bufferLen = 0;\n\n // bufferStartNext can possibly be undefined based on the conditional logic below\n let bufferStartNext: number | undefined;\n\n // bufferStart and bufferEnd are buffer boundaries around current video position\n let bufferStart: number = pos;\n let bufferEnd: number = pos;\n for (let i = 0; i < buffered2.length; i++) {\n let start = buffered2[i].start,\n end = buffered2[i].end;\n // logger.log('buf start/end:' + buffered.start(i) + '/' + buffered.end(i));\n if ((pos + maxHoleDuration) >= start && pos < end) {\n // play position is inside this buffer TimeRange, retrieve end of buffer position and buffer length\n bufferStart = start;\n bufferEnd = end;\n bufferLen = bufferEnd - pos;\n } else if ((pos + maxHoleDuration) < start) {\n bufferStartNext = start;\n break;\n }\n }\n return { len: bufferLen, start: bufferStart, end: bufferEnd, nextStart: bufferStartNext };\n }\n}\n","/**\n * MediaSource helper\n */\n\nexport function getMediaSource (): typeof MediaSource | undefined {\n return (window as any).MediaSource || (window as any).WebKitMediaSource;\n}\n","import { EventEmitter } from 'eventemitter3';\n\n/**\n * Simple adapter sub-class of Nodejs-like EventEmitter.\n */\nexport class Observer extends EventEmitter {\n /**\n * We simply want to pass along the event-name itself\n * in every call to a handler, which is the purpose of our `trigger` method\n * extending the standard API.\n */\n trigger (event: string, ...data: Array<any>): void {\n this.emit(event, event, ...data);\n }\n}\n","import { EventEmitter } from 'eventemitter3';\nimport * as work from 'webworkify-webpack';\n\nimport Event from '../events';\nimport DemuxerInline from '../demux/demuxer-inline';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { getMediaSource } from '../utils/mediasource-helper';\nimport { getSelfScope } from '../utils/get-self-scope';\n\nimport { Observer } from '../observer';\n\n// see https://stackoverflow.com/a/11237259/589493\nconst global = getSelfScope(); // safeguard for code that might run both on worker and main thread\nconst MediaSource = getMediaSource() || { isTypeSupported: () => false };\n\nclass Demuxer {\n constructor (hls, id) {\n this.hls = hls;\n this.id = id;\n\n const observer = this.observer = new Observer();\n const config = hls.config;\n\n const forwardMessage = (ev, data) => {\n data = data || {};\n data.frag = this.frag;\n data.id = this.id;\n hls.trigger(ev, data);\n };\n\n // forward events to main thread\n observer.on(Event.FRAG_DECRYPTED, forwardMessage);\n observer.on(Event.FRAG_PARSING_INIT_SEGMENT, forwardMessage);\n observer.on(Event.FRAG_PARSING_DATA, forwardMessage);\n observer.on(Event.FRAG_PARSED, forwardMessage);\n observer.on(Event.ERROR, forwardMessage);\n observer.on(Event.FRAG_PARSING_METADATA, forwardMessage);\n observer.on(Event.FRAG_PARSING_USERDATA, forwardMessage);\n observer.on(Event.INIT_PTS_FOUND, forwardMessage);\n\n const typeSupported = {\n mp4: MediaSource.isTypeSupported('video/mp4'),\n mpeg: MediaSource.isTypeSupported('audio/mpeg'),\n mp3: MediaSource.isTypeSupported('audio/mp4; codecs=\"mp3\"')\n };\n // navigator.vendor is not always available in Web Worker\n // refer to https://developer.mozilla.org/en-US/docs/Web/API/WorkerGlobalScope/navigator\n const vendor = navigator.vendor;\n if (config.enableWorker && (typeof (Worker) !== 'undefined')) {\n logger.log('demuxing in webworker');\n let w;\n try {\n w = this.w = work(require.resolve('../demux/demuxer-worker.js'));\n this.onwmsg = this.onWorkerMessage.bind(this);\n w.addEventListener('message', this.onwmsg);\n w.onerror = function (event) {\n hls.trigger(Event.ERROR, { type: ErrorTypes.OTHER_ERROR, details: ErrorDetails.INTERNAL_EXCEPTION, fatal: true, event: 'demuxerWorker', err: { message: event.message + ' (' + event.filename + ':' + event.lineno + ')' } });\n };\n w.postMessage({ cmd: 'init', typeSupported: typeSupported, vendor: vendor, id: id, config: JSON.stringify(config) });\n } catch (err) {\n logger.warn('Error in worker:', err);\n logger.error('Error while initializing DemuxerWorker, fallback on DemuxerInline');\n if (w) {\n // revoke the Object URL that was used to create demuxer worker, so as not to leak it\n global.URL.revokeObjectURL(w.objectURL);\n }\n this.demuxer = new DemuxerInline(observer, typeSupported, config, vendor);\n this.w = undefined;\n }\n } else {\n this.demuxer = new DemuxerInline(observer, typeSupported, config, vendor);\n }\n }\n\n destroy () {\n let w = this.w;\n if (w) {\n w.removeEventListener('message', this.onwmsg);\n w.terminate();\n this.w = null;\n } else {\n let demuxer = this.demuxer;\n if (demuxer) {\n demuxer.destroy();\n this.demuxer = null;\n }\n }\n const observer = this.observer;\n if (observer) {\n observer.removeAllListeners();\n this.observer = null;\n }\n }\n\n push (data, initSegment, audioCodec, videoCodec, frag, duration, accurateTimeOffset, defaultInitPTS) {\n const w = this.w;\n const timeOffset = Number.isFinite(frag.startPTS) ? frag.startPTS : frag.start;\n const decryptdata = frag.decryptdata;\n const lastFrag = this.frag;\n const discontinuity = !(lastFrag && (frag.cc === lastFrag.cc));\n const trackSwitch = !(lastFrag && (frag.level === lastFrag.level));\n const nextSN = lastFrag && (frag.sn === (lastFrag.sn + 1));\n const contiguous = !trackSwitch && nextSN;\n if (discontinuity) {\n logger.log(`${this.id}:discontinuity detected`);\n }\n\n if (trackSwitch) {\n logger.log(`${this.id}:switch detected`);\n }\n\n this.frag = frag;\n if (w) {\n // post fragment payload as transferable objects for ArrayBuffer (no copy)\n w.postMessage({ cmd: 'demux', data, decryptdata, initSegment, audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS }, data instanceof ArrayBuffer ? [data] : []);\n } else {\n let demuxer = this.demuxer;\n if (demuxer) {\n demuxer.push(data, decryptdata, initSegment, audioCodec, videoCodec, timeOffset, discontinuity, trackSwitch, contiguous, duration, accurateTimeOffset, defaultInitPTS);\n }\n }\n }\n\n onWorkerMessage (ev) {\n let data = ev.data,\n hls = this.hls;\n switch (data.event) {\n case 'init':\n // revoke the Object URL that was used to create demuxer worker, so as not to leak it\n global.URL.revokeObjectURL(this.w.objectURL);\n break;\n // special case for FRAG_PARSING_DATA: data1 and data2 are transferable objects\n case Event.FRAG_PARSING_DATA:\n data.data.data1 = new Uint8Array(data.data1);\n if (data.data2) {\n data.data.data2 = new Uint8Array(data.data2);\n }\n\n /* falls through */\n default:\n data.data = data.data || {};\n data.data.frag = this.frag;\n data.data.id = this.id;\n hls.trigger(data.event, data.data);\n break;\n }\n }\n}\n\nexport default Demuxer;\n","/**\n * @module LevelHelper\n *\n * Providing methods dealing with playlist sliding and drift\n *\n * TODO: Create an actual `Level` class/model that deals with all this logic in an object-oriented-manner.\n *\n * */\n\nimport { logger } from '../utils/logger';\n\nexport function addGroupId (level, type, id) {\n switch (type) {\n case 'audio':\n if (!level.audioGroupIds) {\n level.audioGroupIds = [];\n }\n level.audioGroupIds.push(id);\n break;\n case 'text':\n if (!level.textGroupIds) {\n level.textGroupIds = [];\n }\n level.textGroupIds.push(id);\n break;\n }\n}\n\nexport function updatePTS (fragments, fromIdx, toIdx) {\n let fragFrom = fragments[fromIdx], fragTo = fragments[toIdx], fragToPTS = fragTo.startPTS;\n // if we know startPTS[toIdx]\n if (Number.isFinite(fragToPTS)) {\n // update fragment duration.\n // it helps to fix drifts between playlist reported duration and fragment real duration\n if (toIdx > fromIdx) {\n fragFrom.duration = fragToPTS - fragFrom.start;\n if (fragFrom.duration < 0) {\n logger.warn(`negative duration computed for frag ${fragFrom.sn},level ${fragFrom.level}, there should be some duration drift between playlist and fragment!`);\n }\n } else {\n fragTo.duration = fragFrom.start - fragToPTS;\n if (fragTo.duration < 0) {\n logger.warn(`negative duration computed for frag ${fragTo.sn},level ${fragTo.level}, there should be some duration drift between playlist and fragment!`);\n }\n }\n } else {\n // we dont know startPTS[toIdx]\n if (toIdx > fromIdx) {\n const contiguous = fragFrom.cc === fragTo.cc;\n fragTo.start = fragFrom.start + ((contiguous && fragFrom.minEndPTS) ? fragFrom.minEndPTS - fragFrom.start : fragFrom.duration);\n } else {\n fragTo.start = Math.max(fragFrom.start - fragTo.duration, 0);\n }\n }\n}\n\nexport function updateFragPTSDTS (details, frag, startPTS, endPTS, startDTS, endDTS) {\n // update frag PTS/DTS\n let maxStartPTS = startPTS;\n let minEndPTS = endPTS;\n if (Number.isFinite(frag.startPTS)) {\n // delta PTS between audio and video\n let deltaPTS = Math.abs(frag.startPTS - startPTS);\n if (!Number.isFinite(frag.deltaPTS)) {\n frag.deltaPTS = deltaPTS;\n } else {\n frag.deltaPTS = Math.max(deltaPTS, frag.deltaPTS);\n }\n\n maxStartPTS = Math.max(startPTS, frag.startPTS);\n startPTS = Math.min(startPTS, frag.startPTS);\n minEndPTS = Math.min(endPTS, frag.endPTS);\n endPTS = Math.max(endPTS, frag.endPTS);\n startDTS = Math.min(startDTS, frag.startDTS);\n endDTS = Math.max(endDTS, frag.endDTS);\n }\n\n const drift = startPTS - frag.start;\n frag.start = frag.startPTS = startPTS;\n frag.maxStartPTS = maxStartPTS;\n frag.endPTS = endPTS;\n frag.minEndPTS = minEndPTS;\n frag.startDTS = startDTS;\n frag.endDTS = endDTS;\n frag.duration = endPTS - startPTS;\n\n const sn = frag.sn;\n // exit if sn out of range\n if (!details || sn < details.startSN || sn > details.endSN) {\n return 0;\n }\n\n let fragIdx, fragments, i;\n fragIdx = sn - details.startSN;\n fragments = details.fragments;\n // update frag reference in fragments array\n // rationale is that fragments array might not contain this frag object.\n // this will happen if playlist has been refreshed between frag loading and call to updateFragPTSDTS()\n // if we don't update frag, we won't be able to propagate PTS info on the playlist\n // resulting in invalid sliding computation\n fragments[fragIdx] = frag;\n // adjust fragment PTS/duration from seqnum-1 to frag 0\n for (i = fragIdx; i > 0; i--) {\n updatePTS(fragments, i, i - 1);\n }\n\n // adjust fragment PTS/duration from seqnum to last frag\n for (i = fragIdx; i < fragments.length - 1; i++) {\n updatePTS(fragments, i, i + 1);\n }\n\n details.PTSKnown = true;\n return drift;\n}\n\nexport function mergeDetails (oldDetails, newDetails) {\n // potentially retrieve cached initsegment\n if (newDetails.initSegment && oldDetails.initSegment) {\n newDetails.initSegment = oldDetails.initSegment;\n }\n\n // check if old/new playlists have fragments in common\n // loop through overlapping SN and update startPTS , cc, and duration if any found\n let ccOffset = 0;\n let PTSFrag;\n mapFragmentIntersection(oldDetails, newDetails, (oldFrag, newFrag) => {\n ccOffset = oldFrag.cc - newFrag.cc;\n if (Number.isFinite(oldFrag.startPTS)) {\n newFrag.start = newFrag.startPTS = oldFrag.startPTS;\n newFrag.endPTS = oldFrag.endPTS;\n newFrag.duration = oldFrag.duration;\n newFrag.backtracked = oldFrag.backtracked;\n newFrag.dropped = oldFrag.dropped;\n PTSFrag = newFrag;\n }\n // PTS is known when there are overlapping segments\n newDetails.PTSKnown = true;\n });\n\n if (!newDetails.PTSKnown) {\n return;\n }\n\n if (ccOffset) {\n logger.log('discontinuity sliding from playlist, take drift into account');\n const newFragments = newDetails.fragments;\n for (let i = 0; i < newFragments.length; i++) {\n newFragments[i].cc += ccOffset;\n }\n }\n\n // if at least one fragment contains PTS info, recompute PTS information for all fragments\n if (PTSFrag) {\n updateFragPTSDTS(newDetails, PTSFrag, PTSFrag.startPTS, PTSFrag.endPTS, PTSFrag.startDTS, PTSFrag.endDTS);\n } else {\n // ensure that delta is within oldFragments range\n // also adjust sliding in case delta is 0 (we could have old=[50-60] and new=old=[50-61])\n // in that case we also need to adjust start offset of all fragments\n adjustSliding(oldDetails, newDetails);\n }\n // if we are here, it means we have fragments overlapping between\n // old and new level. reliable PTS info is thus relying on old level\n newDetails.PTSKnown = oldDetails.PTSKnown;\n}\n\nexport function mergeSubtitlePlaylists (oldPlaylist, newPlaylist, referenceStart = 0) {\n let lastIndex = -1;\n mapFragmentIntersection(oldPlaylist, newPlaylist, (oldFrag, newFrag, index) => {\n newFrag.start = oldFrag.start;\n lastIndex = index;\n });\n\n const frags = newPlaylist.fragments;\n if (lastIndex < 0) {\n frags.forEach(frag => {\n frag.start += referenceStart;\n });\n return;\n }\n\n for (let i = lastIndex + 1; i < frags.length; i++) {\n frags[i].start = (frags[i - 1].start + frags[i - 1].duration);\n }\n}\n\nexport function mapFragmentIntersection (oldPlaylist, newPlaylist, intersectionFn) {\n if (!oldPlaylist || !newPlaylist) {\n return;\n }\n\n const start = Math.max(oldPlaylist.startSN, newPlaylist.startSN) - newPlaylist.startSN;\n const end = Math.min(oldPlaylist.endSN, newPlaylist.endSN) - newPlaylist.startSN;\n const delta = newPlaylist.startSN - oldPlaylist.startSN;\n\n for (let i = start; i <= end; i++) {\n const oldFrag = oldPlaylist.fragments[delta + i];\n const newFrag = newPlaylist.fragments[i];\n if (!oldFrag || !newFrag) {\n break;\n }\n intersectionFn(oldFrag, newFrag, i);\n }\n}\n\nexport function adjustSliding (oldPlaylist, newPlaylist) {\n const delta = newPlaylist.startSN - oldPlaylist.startSN;\n const oldFragments = oldPlaylist.fragments;\n const newFragments = newPlaylist.fragments;\n\n if (delta < 0 || delta > oldFragments.length) {\n return;\n }\n for (let i = 0; i < newFragments.length; i++) {\n newFragments[i].start += oldFragments[delta].start;\n }\n}\n\nexport function computeReloadInterval (currentPlaylist, newPlaylist, lastRequestTime) {\n let reloadInterval = 1000 * (newPlaylist.averagetargetduration ? newPlaylist.averagetargetduration : newPlaylist.targetduration);\n const minReloadInterval = reloadInterval / 2;\n if (currentPlaylist && newPlaylist.endSN === currentPlaylist.endSN) {\n // follow HLS Spec, If the client reloads a Playlist file and finds that it has not\n // changed then it MUST wait for a period of one-half the target\n // duration before retrying.\n reloadInterval = minReloadInterval;\n }\n\n if (lastRequestTime) {\n reloadInterval = Math.max(minReloadInterval, reloadInterval - (window.performance.now() - lastRequestTime));\n }\n // in any case, don't reload more than half of target duration\n return Math.round(reloadInterval);\n}\n","/**\n * TimeRanges to string helper\n */\n\nconst TimeRanges = {\n toString: function (r: TimeRanges) {\n let log = '';\n let len = r.length;\n for (let i = 0; i < len; i++) {\n log += '[' + r.start(i).toFixed(3) + ',' + r.end(i).toFixed(3) + ']';\n }\n\n return log;\n }\n};\n\nexport default TimeRanges;\n","import BinarySearch from './binary-search';\nimport { logger } from '../utils/logger';\n\nexport function findFirstFragWithCC (fragments, cc) {\n let firstFrag = null;\n\n for (let i = 0; i < fragments.length; i += 1) {\n const currentFrag = fragments[i];\n if (currentFrag && currentFrag.cc === cc) {\n firstFrag = currentFrag;\n break;\n }\n }\n\n return firstFrag;\n}\n\nexport function findFragWithCC (fragments, CC) {\n return BinarySearch.search(fragments, (candidate) => {\n if (candidate.cc < CC) {\n return 1;\n } else if (candidate.cc > CC) {\n return -1;\n } else {\n return 0;\n }\n });\n}\n\nexport function shouldAlignOnDiscontinuities (lastFrag, lastLevel, details) {\n let shouldAlign = false;\n if (lastLevel && lastLevel.details && details) {\n if (details.endCC > details.startCC || (lastFrag && lastFrag.cc < details.startCC)) {\n shouldAlign = true;\n }\n }\n return shouldAlign;\n}\n\n// Find the first frag in the previous level which matches the CC of the first frag of the new level\nexport function findDiscontinuousReferenceFrag (prevDetails, curDetails) {\n const prevFrags = prevDetails.fragments;\n const curFrags = curDetails.fragments;\n\n if (!curFrags.length || !prevFrags.length) {\n logger.log('No fragments to align');\n return;\n }\n\n const prevStartFrag = findFirstFragWithCC(prevFrags, curFrags[0].cc);\n\n if (!prevStartFrag || (prevStartFrag && !prevStartFrag.startPTS)) {\n logger.log('No frag in previous level to align on');\n return;\n }\n\n return prevStartFrag;\n}\n\nexport function adjustPts (sliding, details) {\n details.fragments.forEach((frag) => {\n if (frag) {\n let start = frag.start + sliding;\n frag.start = frag.startPTS = start;\n frag.endPTS = start + frag.duration;\n }\n });\n details.PTSKnown = true;\n}\n\n/**\n * Using the parameters of the last level, this function computes PTS' of the new fragments so that they form a\n * contiguous stream with the last fragments.\n * The PTS of a fragment lets Hls.js know where it fits into a stream - by knowing every PTS, we know which fragment to\n * download at any given time. PTS is normally computed when the fragment is demuxed, so taking this step saves us time\n * and an extra download.\n * @param lastFrag\n * @param lastLevel\n * @param details\n */\nexport function alignStream (lastFrag, lastLevel, details) {\n alignDiscontinuities(lastFrag, details, lastLevel);\n if (!details.PTSKnown && lastLevel) {\n // If the PTS wasn't figured out via discontinuity sequence that means there was no CC increase within the level.\n // Aligning via Program Date Time should therefore be reliable, since PDT should be the same within the same\n // discontinuity sequence.\n alignPDT(details, lastLevel.details);\n }\n}\n\n/**\n * Computes the PTS if a new level's fragments using the PTS of a fragment in the last level which shares the same\n * discontinuity sequence.\n * @param lastLevel - The details of the last loaded level\n * @param details - The details of the new level\n */\nexport function alignDiscontinuities (lastFrag, details, lastLevel) {\n if (shouldAlignOnDiscontinuities(lastFrag, lastLevel, details)) {\n const referenceFrag = findDiscontinuousReferenceFrag(lastLevel.details, details);\n if (referenceFrag) {\n logger.log('Adjusting PTS using last level due to CC increase within current level');\n adjustPts(referenceFrag.start, details);\n }\n }\n}\n\n/**\n * Computes the PTS of a new level's fragments using the difference in Program Date Time from the last level.\n * @param details - The details of the new level\n * @param lastDetails - The details of the last loaded level\n */\nexport function alignPDT (details, lastDetails) {\n if (lastDetails && lastDetails.fragments.length) {\n if (!details.hasProgramDateTime || !lastDetails.hasProgramDateTime) {\n return;\n }\n // if last level sliding is 1000 and its first frag PROGRAM-DATE-TIME is 2017-08-20 1:10:00 AM\n // and if new details first frag PROGRAM DATE-TIME is 2017-08-20 1:10:08 AM\n // then we can deduce that playlist B sliding is 1000+8 = 1008s\n let lastPDT = lastDetails.fragments[0].programDateTime;\n let newPDT = details.fragments[0].programDateTime;\n // date diff is in ms. frag.start is in seconds\n let sliding = (newPDT - lastPDT) / 1000 + lastDetails.fragments[0].start;\n if (Number.isFinite(sliding)) {\n logger.log(`adjusting PTS using programDateTime delta, sliding:${sliding.toFixed(3)}`);\n adjustPts(sliding, details);\n }\n }\n}\n","import BinarySearch from '../utils/binary-search';\nimport Fragment from '../loader/fragment';\n\n/**\n * Returns first fragment whose endPdt value exceeds the given PDT.\n * @param {Array<Fragment>} fragments - The array of candidate fragments\n * @param {number|null} [PDTValue = null] - The PDT value which must be exceeded\n * @param {number} [maxFragLookUpTolerance = 0] - The amount of time that a fragment's start/end can be within in order to be considered contiguous\n * @returns {*|null} fragment - The best matching fragment\n */\nexport function findFragmentByPDT (fragments: Array<Fragment>, PDTValue: number | null, maxFragLookUpTolerance: number): Fragment | null {\n if (PDTValue === null || !Array.isArray(fragments) || !fragments.length || !Number.isFinite(PDTValue)) {\n return null;\n }\n\n // if less than start\n const startPDT = fragments[0].programDateTime;\n if (PDTValue < (startPDT || 0)) {\n return null;\n }\n\n const endPDT = fragments[fragments.length - 1].endProgramDateTime;\n if (PDTValue >= (endPDT || 0)) {\n return null;\n }\n\n maxFragLookUpTolerance = maxFragLookUpTolerance || 0;\n for (let seg = 0; seg < fragments.length; ++seg) {\n let frag = fragments[seg];\n if (pdtWithinToleranceTest(PDTValue, maxFragLookUpTolerance, frag)) {\n return frag;\n }\n }\n\n return null;\n}\n\n/**\n * Finds a fragment based on the SN of the previous fragment; or based on the needs of the current buffer.\n * This method compensates for small buffer gaps by applying a tolerance to the start of any candidate fragment, thus\n * breaking any traps which would cause the same fragment to be continuously selected within a small range.\n * @param {*} fragPrevious - The last frag successfully appended\n * @param {Array<Fragment>} fragments - The array of candidate fragments\n * @param {number} [bufferEnd = 0] - The end of the contiguous buffered range the playhead is currently within\n * @param {number} maxFragLookUpTolerance - The amount of time that a fragment's start/end can be within in order to be considered contiguous\n * @returns {*} foundFrag - The best matching fragment\n */\nexport function findFragmentByPTS (fragPrevious: Fragment, fragments: Array<Fragment>, bufferEnd: number = 0, maxFragLookUpTolerance: number = 0): Fragment | null {\n let fragNext: Fragment | null = null;\n if (fragPrevious) {\n fragNext = fragments[fragPrevious.sn as number - (fragments[0].sn as number) + 1];\n } else if (bufferEnd === 0 && fragments[0].start === 0) {\n fragNext = fragments[0];\n }\n // Prefer the next fragment if it's within tolerance\n if (fragNext && fragmentWithinToleranceTest(bufferEnd, maxFragLookUpTolerance, fragNext) === 0) {\n return fragNext;\n }\n // We might be seeking past the tolerance so find the best match\n const foundFragment = BinarySearch.search(fragments, fragmentWithinToleranceTest.bind(null, bufferEnd, maxFragLookUpTolerance));\n if (foundFragment) {\n return foundFragment;\n }\n // If no match was found return the next fragment after fragPrevious, or null\n return fragNext;\n}\n\n/**\n * The test function used by the findFragmentBySn's BinarySearch to look for the best match to the current buffer conditions.\n * @param {*} candidate - The fragment to test\n * @param {number} [bufferEnd = 0] - The end of the current buffered range the playhead is currently within\n * @param {number} [maxFragLookUpTolerance = 0] - The amount of time that a fragment's start can be within in order to be considered contiguous\n * @returns {number} - 0 if it matches, 1 if too low, -1 if too high\n */\nexport function fragmentWithinToleranceTest (bufferEnd = 0, maxFragLookUpTolerance = 0, candidate: Fragment) {\n // offset should be within fragment boundary - config.maxFragLookUpTolerance\n // this is to cope with situations like\n // bufferEnd = 9.991\n // frag[Ø] : [0,10]\n // frag[1] : [10,20]\n // bufferEnd is within frag[0] range ... although what we are expecting is to return frag[1] here\n // frag start frag start+duration\n // |-----------------------------|\n // <---> <--->\n // ...--------><-----------------------------><---------....\n // previous frag matching fragment next frag\n // return -1 return 0 return 1\n // logger.log(`level/sn/start/end/bufEnd:${level}/${candidate.sn}/${candidate.start}/${(candidate.start+candidate.duration)}/${bufferEnd}`);\n // Set the lookup tolerance to be small enough to detect the current segment - ensures we don't skip over very small segments\n let candidateLookupTolerance = Math.min(maxFragLookUpTolerance, candidate.duration + (candidate.deltaPTS ? candidate.deltaPTS : 0));\n if (candidate.start + candidate.duration - candidateLookupTolerance <= bufferEnd) {\n return 1;\n } else if (candidate.start - candidateLookupTolerance > bufferEnd && candidate.start) {\n // if maxFragLookUpTolerance will have negative value then don't return -1 for first element\n return -1;\n }\n\n return 0;\n}\n\n/**\n * The test function used by the findFragmentByPdt's BinarySearch to look for the best match to the current buffer conditions.\n * This function tests the candidate's program date time values, as represented in Unix time\n * @param {*} candidate - The fragment to test\n * @param {number} [pdtBufferEnd = 0] - The Unix time representing the end of the current buffered range\n * @param {number} [maxFragLookUpTolerance = 0] - The amount of time that a fragment's start can be within in order to be considered contiguous\n * @returns {boolean} True if contiguous, false otherwise\n */\nexport function pdtWithinToleranceTest (pdtBufferEnd: number, maxFragLookUpTolerance: number, candidate: Fragment): boolean {\n let candidateLookupTolerance = Math.min(maxFragLookUpTolerance, candidate.duration + (candidate.deltaPTS ? candidate.deltaPTS : 0)) * 1000;\n\n // endProgramDateTime can be null, default to zero\n const endProgramDateTime = candidate.endProgramDateTime || 0;\n return endProgramDateTime - candidateLookupTolerance > pdtBufferEnd;\n}\n","import { BufferHelper } from '../utils/buffer-helper';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport Event from '../events';\nimport { logger } from '../utils/logger';\n\nexport const STALL_MINIMUM_DURATION_MS = 250;\nexport const MAX_START_GAP_JUMP = 2.0;\nexport const SKIP_BUFFER_HOLE_STEP_SECONDS = 0.1;\nexport const SKIP_BUFFER_RANGE_START = 0.05;\n\nexport default class GapController {\n constructor (config, media, fragmentTracker, hls) {\n this.config = config;\n this.media = media;\n this.fragmentTracker = fragmentTracker;\n this.hls = hls;\n this.nudgeRetry = 0;\n this.stallReported = false;\n this.stalled = null;\n this.moved = false;\n this.seeking = false;\n }\n\n /**\n * Checks if the playhead is stuck within a gap, and if so, attempts to free it.\n * A gap is an unbuffered range between two buffered ranges (or the start and the first buffered range).\n *\n * @param {number} lastCurrentTime Previously read playhead position\n */\n poll (lastCurrentTime) {\n const { config, media, stalled } = this;\n const { currentTime, seeking } = media;\n const seeked = this.seeking && !seeking;\n const beginSeek = !this.seeking && seeking;\n\n this.seeking = seeking;\n\n // The playhead is moving, no-op\n if (currentTime !== lastCurrentTime) {\n this.moved = true;\n if (stalled !== null) {\n // The playhead is now moving, but was previously stalled\n if (this.stallReported) {\n const stalledDuration = self.performance.now() - stalled;\n logger.warn(`playback not stuck anymore @${currentTime}, after ${Math.round(stalledDuration)}ms`);\n this.stallReported = false;\n }\n this.stalled = null;\n this.nudgeRetry = 0;\n }\n return;\n }\n\n // Clear stalled state when beginning or finishing seeking so that we don't report stalls coming out of a seek\n if (beginSeek || seeked) {\n this.stalled = null;\n }\n\n // The playhead should not be moving\n if (media.paused || media.ended || media.playbackRate === 0 || !media.buffered.length) {\n return;\n }\n\n const bufferInfo = BufferHelper.bufferInfo(media, currentTime, 0);\n const isBuffered = bufferInfo.len > 0;\n const nextStart = bufferInfo.nextStart || 0;\n\n // There is no playable buffer (waiting for buffer append)\n if (!isBuffered && !nextStart) {\n return;\n }\n\n if (seeking) {\n // Waiting for seeking in a buffered range to complete\n const hasEnoughBuffer = bufferInfo.len > MAX_START_GAP_JUMP;\n // Next buffered range is too far ahead to jump to while still seeking\n const noBufferGap = !nextStart ||\n (nextStart - currentTime > MAX_START_GAP_JUMP && !this.fragmentTracker.getPartialFragment(currentTime));\n if (hasEnoughBuffer || noBufferGap) {\n return;\n }\n // Reset moved state when seeking to a point in or before a gap\n this.moved = false;\n }\n\n // Skip start gaps if we haven't played, but the last poll detected the start of a stall\n // The addition poll gives the browser a chance to jump the gap for us\n if (!this.moved && this.stalled) {\n // Jump start gaps within jump threshold\n const startJump = Math.max(nextStart, bufferInfo.start || 0) - currentTime;\n if (startJump > 0 && startJump <= MAX_START_GAP_JUMP) {\n this._trySkipBufferHole(null);\n return;\n }\n }\n\n // Start tracking stall time\n const tnow = self.performance.now();\n if (stalled === null) {\n this.stalled = tnow;\n return;\n }\n\n const stalledDuration = tnow - stalled;\n if (!seeking && stalledDuration >= STALL_MINIMUM_DURATION_MS) {\n // Report stalling after trying to fix\n this._reportStall(bufferInfo.len);\n }\n\n const bufferedWithHoles = BufferHelper.bufferInfo(media, currentTime, config.maxBufferHole);\n this._tryFixBufferStall(bufferedWithHoles, stalledDuration);\n }\n\n /**\n * Detects and attempts to fix known buffer stalling issues.\n * @param bufferInfo - The properties of the current buffer.\n * @param stalledDurationMs - The amount of time Hls.js has been stalling for.\n * @private\n */\n _tryFixBufferStall (bufferInfo, stalledDurationMs) {\n const { config, fragmentTracker, media } = this;\n const currentTime = media.currentTime;\n\n const partial = fragmentTracker.getPartialFragment(currentTime);\n if (partial) {\n // Try to skip over the buffer hole caused by a partial fragment\n // This method isn't limited by the size of the gap between buffered ranges\n const targetTime = this._trySkipBufferHole(partial);\n // we return here in this case, meaning\n // the branch below only executes when we don't handle a partial fragment\n if (targetTime) {\n return;\n }\n }\n\n // if we haven't had to skip over a buffer hole of a partial fragment\n // we may just have to \"nudge\" the playlist as the browser decoding/rendering engine\n // needs to cross some sort of threshold covering all source-buffers content\n // to start playing properly.\n if (bufferInfo.len > config.maxBufferHole &&\n stalledDurationMs > config.highBufferWatchdogPeriod * 1000) {\n logger.warn('Trying to nudge playhead over buffer-hole');\n // Try to nudge currentTime over a buffer hole if we've been stalling for the configured amount of seconds\n // We only try to jump the hole if it's under the configured size\n // Reset stalled so to rearm watchdog timer\n this.stalled = null;\n this._tryNudgeBuffer();\n }\n }\n\n /**\n * Triggers a BUFFER_STALLED_ERROR event, but only once per stall period.\n * @param bufferLen - The playhead distance from the end of the current buffer segment.\n * @private\n */\n _reportStall (bufferLen) {\n const { hls, media, stallReported } = this;\n if (!stallReported) {\n // Report stalled error once\n this.stallReported = true;\n logger.warn(`Playback stalling at @${media.currentTime} due to low buffer (buffer=${bufferLen})`);\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.BUFFER_STALLED_ERROR,\n fatal: false,\n buffer: bufferLen\n });\n }\n }\n\n /**\n * Attempts to fix buffer stalls by jumping over known gaps caused by partial fragments\n * @param partial - The partial fragment found at the current time (where playback is stalling).\n * @private\n */\n _trySkipBufferHole (partial) {\n const { config, hls, media } = this;\n const currentTime = media.currentTime;\n let lastEndTime = 0;\n // Check if currentTime is between unbuffered regions of partial fragments\n for (let i = 0; i < media.buffered.length; i++) {\n const startTime = media.buffered.start(i);\n if (currentTime + config.maxBufferHole >= lastEndTime && currentTime < startTime) {\n const targetTime = Math.max(startTime + SKIP_BUFFER_RANGE_START, media.currentTime + SKIP_BUFFER_HOLE_STEP_SECONDS);\n logger.warn(`skipping hole, adjusting currentTime from ${currentTime} to ${targetTime}`);\n this.moved = true;\n this.stalled = null;\n media.currentTime = targetTime;\n if (partial) {\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.BUFFER_SEEK_OVER_HOLE,\n fatal: false,\n reason: `fragment loaded with buffer holes, seeking from ${currentTime} to ${targetTime}`,\n frag: partial\n });\n }\n return targetTime;\n }\n lastEndTime = media.buffered.end(i);\n }\n return 0;\n }\n\n /**\n * Attempts to fix buffer stalls by advancing the mediaElement's current time by a small amount.\n * @private\n */\n _tryNudgeBuffer () {\n const { config, hls, media } = this;\n const currentTime = media.currentTime;\n const nudgeRetry = (this.nudgeRetry || 0) + 1;\n this.nudgeRetry = nudgeRetry;\n\n if (nudgeRetry < config.nudgeMaxRetry) {\n const targetTime = currentTime + nudgeRetry * config.nudgeOffset;\n // playback stalled in buffered area ... let's nudge currentTime to try to overcome this\n logger.warn(`Nudging 'currentTime' from ${currentTime} to ${targetTime}`);\n media.currentTime = targetTime;\n\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.BUFFER_NUDGE_ON_STALL,\n fatal: false\n });\n } else {\n logger.error(`Playhead still not moving while enough data buffered @${currentTime} after ${config.nudgeMaxRetry} nudges`);\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.BUFFER_STALLED_ERROR,\n fatal: true\n });\n }\n }\n}\n","import EventHandler from './event-handler';\nimport Hls from './hls';\n\n/**\n * Sub-class specialization of EventHandler base class.\n *\n * TaskLoop allows to schedule a task function being called (optionnaly repeatedly) on the main loop,\n * scheduled asynchroneously, avoiding recursive calls in the same tick.\n *\n * The task itself is implemented in `doTick`. It can be requested and called for single execution\n * using the `tick` method.\n *\n * It will be assured that the task execution method (`tick`) only gets called once per main loop \"tick\",\n * no matter how often it gets requested for execution. Execution in further ticks will be scheduled accordingly.\n *\n * If further execution requests have already been scheduled on the next tick, it can be checked with `hasNextTick`,\n * and cancelled with `clearNextTick`.\n *\n * The task can be scheduled as an interval repeatedly with a period as parameter (see `setInterval`, `clearInterval`).\n *\n * Sub-classes need to implement the `doTick` method which will effectively have the task execution routine.\n *\n * Further explanations:\n *\n * The baseclass has a `tick` method that will schedule the doTick call. It may be called synchroneously\n * only for a stack-depth of one. On re-entrant calls, sub-sequent calls are scheduled for next main loop ticks.\n *\n * When the task execution (`tick` method) is called in re-entrant way this is detected and\n * we are limiting the task execution per call stack to exactly one, but scheduling/post-poning further\n * task processing on the next main loop iteration (also known as \"next tick\" in the Node/JS runtime lingo).\n */\n\nexport default class TaskLoop extends EventHandler {\n private readonly _boundTick: () => void;\n private _tickTimer: number | null = null;\n private _tickInterval: number | null = null;\n private _tickCallCount = 0;\n\n constructor (hls: Hls, ...events: string[]) {\n super(hls, ...events);\n this._boundTick = this.tick.bind(this);\n }\n\n /**\n * @override\n */\n protected onHandlerDestroying () {\n // clear all timers before unregistering from event bus\n this.clearNextTick();\n this.clearInterval();\n }\n\n /**\n * @returns {boolean}\n */\n public hasInterval (): boolean {\n return !!this._tickInterval;\n }\n\n /**\n * @returns {boolean}\n */\n public hasNextTick (): boolean {\n return !!this._tickTimer;\n }\n\n /**\n * @param {number} millis Interval time (ms)\n * @returns {boolean} True when interval has been scheduled, false when already scheduled (no effect)\n */\n public setInterval (millis: number): boolean {\n if (!this._tickInterval) {\n this._tickInterval = self.setInterval(this._boundTick, millis);\n return true;\n }\n return false;\n }\n\n /**\n * @returns {boolean} True when interval was cleared, false when none was set (no effect)\n */\n public clearInterval (): boolean {\n if (this._tickInterval) {\n self.clearInterval(this._tickInterval);\n this._tickInterval = null;\n return true;\n }\n return false;\n }\n\n /**\n * @returns {boolean} True when timeout was cleared, false when none was set (no effect)\n */\n public clearNextTick (): boolean {\n if (this._tickTimer) {\n self.clearTimeout(this._tickTimer);\n this._tickTimer = null;\n return true;\n }\n return false;\n }\n\n /**\n * Will call the subclass doTick implementation in this main loop tick\n * or in the next one (via setTimeout(,0)) in case it has already been called\n * in this tick (in case this is a re-entrant call).\n */\n public tick (): void {\n this._tickCallCount++;\n if (this._tickCallCount === 1) {\n this.doTick();\n // re-entrant call to tick from previous doTick call stack\n // -> schedule a call on the next main loop iteration to process this task processing request\n if (this._tickCallCount > 1) {\n // make sure only one timer exists at any time at max\n this.clearNextTick();\n this._tickTimer = self.setTimeout(this._boundTick, 0);\n }\n this._tickCallCount = 0;\n }\n }\n\n /**\n * For subclass to implement task logic\n * @abstract\n */\n protected doTick (): void {}\n}\n","import TaskLoop from '../task-loop';\nimport { FragmentState } from './fragment-tracker';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport { logger } from '../utils/logger';\n\nexport const State = {\n STOPPED: 'STOPPED',\n STARTING: 'STARTING',\n IDLE: 'IDLE',\n PAUSED: 'PAUSED',\n KEY_LOADING: 'KEY_LOADING',\n FRAG_LOADING: 'FRAG_LOADING',\n FRAG_LOADING_WAITING_RETRY: 'FRAG_LOADING_WAITING_RETRY',\n WAITING_TRACK: 'WAITING_TRACK',\n PARSING: 'PARSING',\n PARSED: 'PARSED',\n BUFFER_FLUSHING: 'BUFFER_FLUSHING',\n ENDED: 'ENDED',\n ERROR: 'ERROR',\n WAITING_INIT_PTS: 'WAITING_INIT_PTS',\n WAITING_LEVEL: 'WAITING_LEVEL'\n};\n\nexport default class BaseStreamController extends TaskLoop {\n doTick () {}\n\n startLoad () {}\n\n stopLoad () {\n let frag = this.fragCurrent;\n if (frag) {\n if (frag.loader) {\n frag.loader.abort();\n }\n this.fragmentTracker.removeFragment(frag);\n }\n if (this.demuxer) {\n this.demuxer.destroy();\n this.demuxer = null;\n }\n this.fragCurrent = null;\n this.fragPrevious = null;\n this.clearInterval();\n this.clearNextTick();\n this.state = State.STOPPED;\n }\n\n _streamEnded (bufferInfo, levelDetails) {\n const { fragCurrent, fragmentTracker } = this;\n // we just got done loading the final fragment and there is no other buffered range after ...\n // rationale is that in case there are any buffered ranges after, it means that there are unbuffered portion in between\n // so we should not switch to ENDED in that case, to be able to buffer them\n // dont switch to ENDED if we need to backtrack last fragment\n if (!levelDetails.live && fragCurrent && !fragCurrent.backtracked && fragCurrent.sn === levelDetails.endSN && !bufferInfo.nextStart) {\n const fragState = fragmentTracker.getState(fragCurrent);\n return fragState === FragmentState.PARTIAL || fragState === FragmentState.OK;\n }\n return false;\n }\n\n onMediaSeeking () {\n const { config, media, mediaBuffer, state } = this;\n const currentTime = media ? media.currentTime : null;\n const bufferInfo = BufferHelper.bufferInfo(mediaBuffer || media, currentTime, this.config.maxBufferHole);\n\n logger.log(`media seeking to ${Number.isFinite(currentTime) ? currentTime.toFixed(3) : currentTime}`);\n\n if (state === State.FRAG_LOADING) {\n let fragCurrent = this.fragCurrent;\n // check if we are seeking to a unbuffered area AND if frag loading is in progress\n if (bufferInfo.len === 0 && fragCurrent) {\n const tolerance = config.maxFragLookUpTolerance;\n const fragStartOffset = fragCurrent.start - tolerance;\n const fragEndOffset = fragCurrent.start + fragCurrent.duration + tolerance;\n // check if we seek position will be out of currently loaded frag range : if out cancel frag load, if in, don't do anything\n if (currentTime < fragStartOffset || currentTime > fragEndOffset) {\n if (fragCurrent.loader) {\n logger.log('seeking outside of buffer while fragment load in progress, cancel fragment load');\n fragCurrent.loader.abort();\n }\n this.fragCurrent = null;\n this.fragPrevious = null;\n // switch to IDLE state to load new fragment\n this.state = State.IDLE;\n } else {\n logger.log('seeking outside of buffer but within currently loaded fragment range');\n }\n }\n } else if (state === State.ENDED) {\n // if seeking to unbuffered area, clean up fragPrevious\n if (bufferInfo.len === 0) {\n this.fragPrevious = null;\n this.fragCurrent = null;\n }\n\n // switch to IDLE state to check for potential new fragment\n this.state = State.IDLE;\n }\n if (media) {\n this.lastCurrentTime = currentTime;\n }\n\n // in case seeking occurs although no media buffered, adjust startPosition and nextLoadPosition to seek target\n if (!this.loadedmetadata) {\n this.nextLoadPosition = this.startPosition = currentTime;\n }\n\n // tick to speed up processing\n this.tick();\n }\n\n onMediaEnded () {\n // reset startPosition and lastCurrentTime to restart playback @ stream beginning\n this.startPosition = this.lastCurrentTime = 0;\n }\n\n onHandlerDestroying () {\n this.stopLoad();\n super.onHandlerDestroying();\n }\n\n onHandlerDestroyed () {\n this.state = State.STOPPED;\n this.fragmentTracker = null;\n }\n\n computeLivePosition (sliding, levelDetails) {\n let targetLatency = this.config.liveSyncDuration !== undefined ? this.config.liveSyncDuration : this.config.liveSyncDurationCount * levelDetails.targetduration;\n return sliding + Math.max(0, levelDetails.totalduration - targetLatency);\n }\n}\n","/*\n * Stream Controller\n*/\n\nimport BinarySearch from '../utils/binary-search';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport Demuxer from '../demux/demuxer';\nimport Event from '../events';\nimport { FragmentState } from './fragment-tracker';\nimport { ElementaryStreamTypes } from '../loader/fragment';\nimport { PlaylistLevelType } from '../types/loader';\nimport * as LevelHelper from './level-helper';\nimport TimeRanges from '../utils/time-ranges';\nimport { ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport { alignStream } from '../utils/discontinuities';\nimport { findFragmentByPDT, findFragmentByPTS } from './fragment-finders';\nimport GapController, { MAX_START_GAP_JUMP } from './gap-controller';\nimport BaseStreamController, { State } from './base-stream-controller';\n\nconst TICK_INTERVAL = 100; // how often to tick in ms\n\nclass StreamController extends BaseStreamController {\n constructor (hls, fragmentTracker) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.MANIFEST_LOADING,\n Event.MANIFEST_PARSED,\n Event.LEVEL_LOADED,\n Event.LEVELS_UPDATED,\n Event.KEY_LOADED,\n Event.FRAG_LOADED,\n Event.FRAG_LOAD_EMERGENCY_ABORTED,\n Event.FRAG_PARSING_INIT_SEGMENT,\n Event.FRAG_PARSING_DATA,\n Event.FRAG_PARSED,\n Event.ERROR,\n Event.AUDIO_TRACK_SWITCHING,\n Event.AUDIO_TRACK_SWITCHED,\n Event.BUFFER_CREATED,\n Event.BUFFER_APPENDED,\n Event.BUFFER_FLUSHED);\n\n this.fragmentTracker = fragmentTracker;\n this.config = hls.config;\n this.audioCodecSwap = false;\n this._state = State.STOPPED;\n this.stallReported = false;\n this.gapController = null;\n this.altAudio = false;\n this.audioOnly = false;\n this.bitrateTest = false;\n }\n\n startLoad (startPosition) {\n if (this.levels) {\n let lastCurrentTime = this.lastCurrentTime, hls = this.hls;\n this.stopLoad();\n this.setInterval(TICK_INTERVAL);\n this.level = -1;\n this.fragLoadError = 0;\n if (!this.startFragRequested) {\n // determine load level\n let startLevel = hls.startLevel;\n if (startLevel === -1) {\n if (hls.config.testBandwidth) {\n // -1 : guess start Level by doing a bitrate test by loading first fragment of lowest quality level\n startLevel = 0;\n this.bitrateTest = true;\n } else {\n startLevel = hls.nextAutoLevel;\n }\n }\n // set new level to playlist loader : this will trigger start level load\n // hls.nextLoadLevel remains until it is set to a new value or until a new frag is successfully loaded\n this.level = hls.nextLoadLevel = startLevel;\n this.loadedmetadata = false;\n }\n // if startPosition undefined but lastCurrentTime set, set startPosition to last currentTime\n if (lastCurrentTime > 0 && startPosition === -1) {\n logger.log(`override startPosition with lastCurrentTime @${lastCurrentTime.toFixed(3)}`);\n startPosition = lastCurrentTime;\n }\n this.state = State.IDLE;\n this.nextLoadPosition = this.startPosition = this.lastCurrentTime = startPosition;\n this.tick();\n } else {\n this.forceStartLoad = true;\n this.state = State.STOPPED;\n }\n }\n\n stopLoad () {\n this.forceStartLoad = false;\n super.stopLoad();\n }\n\n doTick () {\n switch (this.state) {\n case State.BUFFER_FLUSHING:\n // in buffer flushing state, reset fragLoadError counter\n this.fragLoadError = 0;\n break;\n case State.IDLE:\n this._doTickIdle();\n break;\n case State.WAITING_LEVEL:\n var level = this.levels[this.level];\n // check if playlist is already loaded\n if (level && level.details) {\n this.state = State.IDLE;\n }\n\n break;\n case State.FRAG_LOADING_WAITING_RETRY:\n var now = window.performance.now();\n var retryDate = this.retryDate;\n // if current time is gt than retryDate, or if media seeking let's switch to IDLE state to retry loading\n if (!retryDate || (now >= retryDate) || (this.media && this.media.seeking)) {\n logger.log('mediaController: retryDate reached, switch back to IDLE state');\n this.state = State.IDLE;\n }\n break;\n case State.ERROR:\n case State.STOPPED:\n case State.FRAG_LOADING:\n case State.PARSING:\n case State.PARSED:\n case State.ENDED:\n break;\n default:\n break;\n }\n // check buffer\n this._checkBuffer();\n // check/update current fragment\n this._checkFragmentChanged();\n }\n\n // Ironically the \"idle\" state is the on we do the most logic in it seems ....\n // NOTE: Maybe we could rather schedule a check for buffer length after half of the currently\n // played segment, or on pause/play/seek instead of naively checking every 100ms?\n _doTickIdle () {\n const hls = this.hls,\n config = hls.config,\n media = this.media;\n\n // if start level not parsed yet OR\n // if video not attached AND start fragment already requested OR start frag prefetch disable\n // exit loop, as we either need more info (level not parsed) or we need media to be attached to load new fragment\n if (this.levelLastLoaded === undefined || (\n !media && (this.startFragRequested || !config.startFragPrefetch))) {\n return;\n }\n\n // If the \"main\" level is audio-only but we are loading an alternate track in the same group, do not load anything\n if (this.altAudio && this.audioOnly) {\n // Clear audio demuxer state so when switching back to main audio we're not still appending where we left off\n this.demuxer.frag = null;\n return;\n }\n\n // if we have not yet loaded any fragment, start loading from start position\n let pos;\n if (this.loadedmetadata) {\n pos = media.currentTime;\n } else {\n pos = this.nextLoadPosition;\n }\n\n // determine next load level\n let level = hls.nextLoadLevel,\n levelInfo = this.levels[level];\n\n if (!levelInfo) {\n return;\n }\n\n let levelBitrate = levelInfo.bitrate,\n maxBufLen;\n\n // compute max Buffer Length that we could get from this load level, based on level bitrate.\n if (levelBitrate) {\n maxBufLen = Math.max(8 * config.maxBufferSize / levelBitrate, config.maxBufferLength);\n } else {\n maxBufLen = config.maxBufferLength;\n }\n\n maxBufLen = Math.min(maxBufLen, config.maxMaxBufferLength);\n\n // determine next candidate fragment to be loaded, based on current position and end of buffer position\n // ensure up to `config.maxMaxBufferLength` of buffer upfront\n\n const maxBufferHole = pos < config.maxBufferHole ? Math.max(MAX_START_GAP_JUMP, config.maxBufferHole) : config.maxBufferHole;\n const bufferInfo = BufferHelper.bufferInfo(this.mediaBuffer ? this.mediaBuffer : media, pos, maxBufferHole);\n const bufferLen = bufferInfo.len;\n // Stay idle if we are still with buffer margins\n if (bufferLen >= maxBufLen) {\n return;\n }\n\n // if buffer length is less than maxBufLen try to load a new fragment ...\n logger.trace(`buffer length of ${bufferLen.toFixed(3)} is below max of ${maxBufLen.toFixed(3)}. checking for more payload ...`);\n\n // set next load level : this will trigger a playlist load if needed\n this.level = hls.nextLoadLevel = level;\n\n const levelDetails = levelInfo.details;\n // if level info not retrieved yet, switch state and wait for level retrieval\n // if live playlist, ensure that new playlist has been refreshed to avoid loading/try to load\n // a useless and outdated fragment (that might even introduce load error if it is already out of the live playlist)\n if (!levelDetails || (levelDetails.live && this.levelLastLoaded !== level)) {\n this.state = State.WAITING_LEVEL;\n return;\n }\n\n if (this._streamEnded(bufferInfo, levelDetails)) {\n const data = {};\n if (this.altAudio) {\n data.type = 'video';\n }\n\n this.hls.trigger(Event.BUFFER_EOS, data);\n this.state = State.ENDED;\n return;\n }\n // if we have the levelDetails for the selected variant, lets continue enrichen our stream (load keys/fragments or trigger EOS, etc..)\n this._fetchPayloadOrEos(pos, bufferInfo, levelDetails);\n }\n\n _fetchPayloadOrEos (pos, bufferInfo, levelDetails) {\n const fragPrevious = this.fragPrevious,\n level = this.level,\n fragments = levelDetails.fragments,\n fragLen = fragments.length;\n\n // empty playlist\n if (fragLen === 0) {\n return;\n }\n\n // find fragment index, contiguous with end of buffer position\n let start = fragments[0].start,\n end = fragments[fragLen - 1].start + fragments[fragLen - 1].duration,\n bufferEnd = bufferInfo.end,\n frag;\n\n if (levelDetails.initSegment && !levelDetails.initSegment.data) {\n frag = levelDetails.initSegment;\n } else {\n // in case of live playlist we need to ensure that requested position is not located before playlist start\n if (levelDetails.live) {\n let initialLiveManifestSize = this.config.initialLiveManifestSize;\n if (fragLen < initialLiveManifestSize) {\n logger.warn(`Can not start playback of a level, reason: not enough fragments ${fragLen} < ${initialLiveManifestSize}`);\n return;\n }\n\n frag = this._ensureFragmentAtLivePoint(levelDetails, bufferEnd, start, end, fragPrevious, fragments);\n // if it explicitely returns null don't load any fragment and exit function now\n if (frag === null) {\n return;\n }\n } else {\n // VoD playlist: if bufferEnd before start of playlist, load first fragment\n if (bufferEnd < start) {\n frag = fragments[0];\n }\n }\n }\n if (!frag) {\n frag = this._findFragment(start, fragPrevious, fragLen, fragments, bufferEnd, end, levelDetails);\n }\n\n if (frag) {\n if (frag.encrypted) {\n this._loadKey(frag, levelDetails);\n } else {\n this._loadFragment(frag, levelDetails, pos, bufferEnd);\n }\n }\n }\n\n _ensureFragmentAtLivePoint (levelDetails, bufferEnd, start, end, fragPrevious, fragments) {\n const config = this.hls.config, media = this.media;\n\n let frag;\n\n // check if requested position is within seekable boundaries :\n // logger.log(`start/pos/bufEnd/seeking:${start.toFixed(3)}/${pos.toFixed(3)}/${bufferEnd.toFixed(3)}/${this.media.seeking}`);\n let maxLatency = Infinity;\n\n if (config.liveMaxLatencyDuration !== undefined) {\n maxLatency = config.liveMaxLatencyDuration;\n } else if (Number.isFinite(config.liveMaxLatencyDurationCount)) {\n maxLatency = config.liveMaxLatencyDurationCount * levelDetails.targetduration;\n }\n\n if (bufferEnd < Math.max(start - config.maxFragLookUpTolerance, end - maxLatency)) {\n let liveSyncPosition = this.liveSyncPosition = this.computeLivePosition(start, levelDetails);\n bufferEnd = liveSyncPosition;\n if (media && !media.paused && media.readyState && media.duration > liveSyncPosition && liveSyncPosition > media.currentTime) {\n logger.log(`buffer end: ${bufferEnd.toFixed(3)} is located too far from the end of live sliding playlist, reset currentTime to : ${liveSyncPosition.toFixed(3)}`);\n media.currentTime = liveSyncPosition;\n }\n\n this.nextLoadPosition = liveSyncPosition;\n }\n\n // if end of buffer greater than live edge, don't load any fragment\n // this could happen if live playlist intermittently slides in the past.\n // level 1 loaded [182580161,182580167]\n // level 1 loaded [182580162,182580169]\n // Loading 182580168 of [182580162 ,182580169],level 1 ..\n // Loading 182580169 of [182580162 ,182580169],level 1 ..\n // level 1 loaded [182580162,182580168] <============= here we should have bufferEnd > end. in that case break to avoid reloading 182580168\n // level 1 loaded [182580164,182580171]\n //\n // don't return null in case media not loaded yet (readystate === 0)\n if (levelDetails.PTSKnown && bufferEnd > end && media && media.readyState) {\n return null;\n }\n\n if (this.startFragRequested && !levelDetails.PTSKnown) {\n /* we are switching level on live playlist, but we don't have any PTS info for that quality level ...\n try to load frag matching with next SN.\n even if SN are not synchronized between playlists, loading this frag will help us\n compute playlist sliding and find the right one after in case it was not the right consecutive one */\n if (fragPrevious) {\n if (levelDetails.hasProgramDateTime) {\n // Relies on PDT in order to switch bitrates (Support EXT-X-DISCONTINUITY without EXT-X-DISCONTINUITY-SEQUENCE)\n logger.log(`live playlist, switching playlist, load frag with same PDT: ${fragPrevious.programDateTime}`);\n frag = findFragmentByPDT(fragments, fragPrevious.endProgramDateTime, config.maxFragLookUpTolerance);\n } else {\n // Uses buffer and sequence number to calculate switch segment (required if using EXT-X-DISCONTINUITY-SEQUENCE)\n const targetSN = fragPrevious.sn + 1;\n if (targetSN >= levelDetails.startSN && targetSN <= levelDetails.endSN) {\n const fragNext = fragments[targetSN - levelDetails.startSN];\n if (fragPrevious.cc === fragNext.cc) {\n frag = fragNext;\n logger.log(`live playlist, switching playlist, load frag with next SN: ${frag.sn}`);\n }\n }\n // next frag SN not available (or not with same continuity counter)\n // look for a frag sharing the same CC\n if (!frag) {\n frag = BinarySearch.search(fragments, function (frag) {\n return fragPrevious.cc - frag.cc;\n });\n if (frag) {\n logger.log(`live playlist, switching playlist, load frag with same CC: ${frag.sn}`);\n }\n }\n }\n }\n }\n\n return frag;\n }\n\n _findFragment (start, fragPreviousLoad, fragmentIndexRange, fragments, bufferEnd, end, levelDetails) {\n const config = this.hls.config;\n let fragNextLoad;\n\n if (bufferEnd < end) {\n const lookupTolerance = (bufferEnd > end - config.maxFragLookUpTolerance) ? 0 : config.maxFragLookUpTolerance;\n // Remove the tolerance if it would put the bufferEnd past the actual end of stream\n // Uses buffer and sequence number to calculate switch segment (required if using EXT-X-DISCONTINUITY-SEQUENCE)\n fragNextLoad = findFragmentByPTS(fragPreviousLoad, fragments, bufferEnd, lookupTolerance);\n } else {\n // reach end of playlist\n fragNextLoad = fragments[fragmentIndexRange - 1];\n }\n\n if (fragNextLoad) {\n const curSNIdx = fragNextLoad.sn - levelDetails.startSN;\n const sameLevel = fragPreviousLoad && fragNextLoad.level === fragPreviousLoad.level;\n const prevSnFrag = fragments[curSNIdx - 1];\n const nextSnFrag = fragments[curSNIdx + 1];\n\n // logger.log('find SN matching with pos:' + bufferEnd + ':' + frag.sn);\n if (fragPreviousLoad && fragNextLoad.sn === fragPreviousLoad.sn) {\n if (sameLevel && !fragNextLoad.backtracked) {\n if (fragNextLoad.sn < levelDetails.endSN) {\n let deltaPTS = fragPreviousLoad.deltaPTS;\n // if there is a significant delta between audio and video, larger than max allowed hole,\n // and if previous remuxed fragment did not start with a keyframe. (fragPrevious.dropped)\n // let's try to load previous fragment again to get last keyframe\n // then we will reload again current fragment (that way we should be able to fill the buffer hole ...)\n if (deltaPTS && deltaPTS > config.maxBufferHole && fragPreviousLoad.dropped && curSNIdx) {\n fragNextLoad = prevSnFrag;\n logger.warn('Previous fragment was dropped with large PTS gap between audio and video. Maybe fragment is not starting with a keyframe? Loading previous one to try to overcome this');\n } else {\n fragNextLoad = nextSnFrag;\n if (this.fragmentTracker.getState(fragNextLoad) !== FragmentState.OK) {\n logger.log(`Re-loading fragment with SN: ${fragNextLoad.sn}`);\n }\n }\n } else {\n fragNextLoad = null;\n }\n } else if (fragNextLoad.backtracked) {\n // Only backtrack a max of 1 consecutive fragment to prevent sliding back too far when little or no frags start with keyframes\n if (nextSnFrag && nextSnFrag.backtracked) {\n logger.warn(`Already backtracked from fragment ${nextSnFrag.sn}, will not backtrack to fragment ${fragNextLoad.sn}. Loading fragment ${nextSnFrag.sn}`);\n fragNextLoad = nextSnFrag;\n } else {\n // If a fragment has dropped frames and it's in a same level/sequence, load the previous fragment to try and find the keyframe\n // Reset the dropped count now since it won't be reset until we parse the fragment again, which prevents infinite backtracking on the same segment\n logger.warn('Loaded fragment with dropped frames, backtracking 1 segment to find a keyframe');\n fragNextLoad.dropped = 0;\n if (prevSnFrag) {\n fragNextLoad = prevSnFrag;\n fragNextLoad.backtracked = true;\n } else if (curSNIdx) {\n // can't backtrack on very first fragment\n fragNextLoad = null;\n }\n }\n }\n }\n }\n\n return fragNextLoad;\n }\n\n _loadKey (frag, levelDetails) {\n logger.log(`Loading key for ${frag.sn} of [${levelDetails.startSN}-${levelDetails.endSN}], level ${this.level}`);\n this.state = State.KEY_LOADING;\n this.hls.trigger(Event.KEY_LOADING, { frag });\n }\n\n _loadFragment (frag, levelDetails, pos, bufferEnd) {\n // Check if fragment is not loaded\n let fragState = this.fragmentTracker.getState(frag);\n\n this.fragCurrent = frag;\n if (frag.sn !== 'initSegment') {\n this.startFragRequested = true;\n }\n // Don't update nextLoadPosition for fragments which are not buffered\n if (Number.isFinite(frag.sn) && !frag.bitrateTest) {\n this.nextLoadPosition = frag.start + frag.duration;\n }\n\n // Allow backtracked fragments to load\n if (frag.backtracked || fragState === FragmentState.NOT_LOADED || fragState === FragmentState.PARTIAL) {\n frag.autoLevel = this.hls.autoLevelEnabled;\n frag.bitrateTest = this.bitrateTest;\n\n logger.log(`Loading ${frag.sn} of [${levelDetails.startSN}-${levelDetails.endSN}], level ${this.level}, ${\n this.loadedmetadata ? 'currentTime' : 'nextLoadPosition'\n }: ${parseFloat(pos.toFixed(3))}, bufferEnd: ${parseFloat(bufferEnd.toFixed(3))}`);\n\n this.hls.trigger(Event.FRAG_LOADING, { frag });\n // lazy demuxer init, as this could take some time ... do it during frag loading\n if (!this.demuxer) {\n this.demuxer = new Demuxer(this.hls, 'main');\n }\n\n this.state = State.FRAG_LOADING;\n } else if (fragState === FragmentState.APPENDING) {\n // Lower the buffer size and try again\n if (this._reduceMaxBufferLength(frag.duration)) {\n this.fragmentTracker.removeFragment(frag);\n }\n }\n }\n\n set state (nextState) {\n if (this.state !== nextState) {\n const previousState = this.state;\n this._state = nextState;\n logger.log(`main stream-controller: ${previousState}->${nextState}`);\n this.hls.trigger(Event.STREAM_STATE_TRANSITION, { previousState, nextState });\n }\n }\n\n get state () {\n return this._state;\n }\n\n getBufferedFrag (position) {\n return this.fragmentTracker.getBufferedFrag(position, PlaylistLevelType.MAIN);\n }\n\n get currentLevel () {\n let media = this.media;\n if (media) {\n const frag = this.getBufferedFrag(media.currentTime);\n if (frag) {\n return frag.level;\n }\n }\n return -1;\n }\n\n get nextBufferedFrag () {\n let media = this.media;\n if (media) {\n // first get end range of current fragment\n return this.followingBufferedFrag(this.getBufferedFrag(media.currentTime));\n } else {\n return null;\n }\n }\n\n followingBufferedFrag (frag) {\n if (frag) {\n // try to get range of next fragment (500ms after this range)\n return this.getBufferedFrag(frag.endPTS + 0.5);\n }\n return null;\n }\n\n get nextLevel () {\n const frag = this.nextBufferedFrag;\n if (frag) {\n return frag.level;\n } else {\n return -1;\n }\n }\n\n _checkFragmentChanged () {\n let fragPlayingCurrent, currentTime, video = this.media;\n if (video && video.readyState && video.seeking === false) {\n currentTime = video.currentTime;\n /* if video element is in seeked state, currentTime can only increase.\n (assuming that playback rate is positive ...)\n As sometimes currentTime jumps back to zero after a\n media decode error, check this, to avoid seeking back to\n wrong position after a media decode error\n */\n if (currentTime > this.lastCurrentTime) {\n this.lastCurrentTime = currentTime;\n }\n\n if (BufferHelper.isBuffered(video, currentTime)) {\n fragPlayingCurrent = this.getBufferedFrag(currentTime);\n } else if (BufferHelper.isBuffered(video, currentTime + 0.1)) {\n /* ensure that FRAG_CHANGED event is triggered at startup,\n when first video frame is displayed and playback is paused.\n add a tolerance of 100ms, in case current position is not buffered,\n check if current pos+100ms is buffered and use that buffer range\n for FRAG_CHANGED event reporting */\n fragPlayingCurrent = this.getBufferedFrag(currentTime + 0.1);\n }\n if (fragPlayingCurrent) {\n let fragPlaying = fragPlayingCurrent;\n if (fragPlaying !== this.fragPlaying) {\n this.hls.trigger(Event.FRAG_CHANGED, { frag: fragPlaying });\n const fragPlayingLevel = fragPlaying.level;\n if (!this.fragPlaying || this.fragPlaying.level !== fragPlayingLevel) {\n this.hls.trigger(Event.LEVEL_SWITCHED, { level: fragPlayingLevel });\n }\n\n this.fragPlaying = fragPlaying;\n }\n }\n }\n }\n\n /*\n on immediate level switch :\n - pause playback if playing\n - cancel any pending load request\n - and trigger a buffer flush\n */\n immediateLevelSwitch () {\n logger.log('immediateLevelSwitch');\n if (!this.immediateSwitch) {\n this.immediateSwitch = true;\n let media = this.media, previouslyPaused;\n if (media) {\n previouslyPaused = media.paused;\n if (!previouslyPaused) {\n media.pause();\n }\n } else {\n // don't restart playback after instant level switch in case media not attached\n previouslyPaused = true;\n }\n this.previouslyPaused = previouslyPaused;\n }\n let fragCurrent = this.fragCurrent;\n if (fragCurrent && fragCurrent.loader) {\n fragCurrent.loader.abort();\n }\n\n this.fragCurrent = null;\n // flush everything\n this.flushMainBuffer(0, Number.POSITIVE_INFINITY);\n }\n\n /**\n * on immediate level switch end, after new fragment has been buffered:\n * - nudge video decoder by slightly adjusting video currentTime (if currentTime buffered)\n * - resume the playback if needed\n */\n immediateLevelSwitchEnd () {\n const media = this.media;\n if (media && media.buffered.length) {\n this.immediateSwitch = false;\n if (media.currentTime > 0 && BufferHelper.isBuffered(media, media.currentTime)) {\n // only nudge if currentTime is buffered\n media.currentTime -= 0.0001;\n }\n if (!this.previouslyPaused) {\n media.play();\n }\n }\n }\n\n /**\n * try to switch ASAP without breaking video playback:\n * in order to ensure smooth but quick level switching,\n * we need to find the next flushable buffer range\n * we should take into account new segment fetch time\n */\n nextLevelSwitch () {\n const media = this.media;\n // ensure that media is defined and that metadata are available (to retrieve currentTime)\n if (media && media.readyState) {\n let fetchdelay;\n const fragPlayingCurrent = this.getBufferedFrag(media.currentTime);\n if (fragPlayingCurrent && fragPlayingCurrent.startPTS > 1) {\n // flush buffer preceding current fragment (flush until current fragment start offset)\n // minus 1s to avoid video freezing, that could happen if we flush keyframe of current video ...\n this.flushMainBuffer(0, fragPlayingCurrent.startPTS - 1);\n }\n if (!media.paused) {\n // add a safety delay of 1s\n let nextLevelId = this.hls.nextLoadLevel, nextLevel = this.levels[nextLevelId], fragLastKbps = this.fragLastKbps;\n if (fragLastKbps && this.fragCurrent) {\n fetchdelay = this.fragCurrent.duration * nextLevel.bitrate / (1000 * fragLastKbps) + 1;\n } else {\n fetchdelay = 0;\n }\n } else {\n fetchdelay = 0;\n }\n // logger.log('fetchdelay:'+fetchdelay);\n // find buffer range that will be reached once new fragment will be fetched\n const bufferedFrag = this.getBufferedFrag(media.currentTime + fetchdelay);\n if (bufferedFrag) {\n // we can flush buffer range following this one without stalling playback\n const nextBufferedFrag = this.followingBufferedFrag(bufferedFrag);\n if (nextBufferedFrag) {\n // if we are here, we can also cancel any loading/demuxing in progress, as they are useless\n let fragCurrent = this.fragCurrent;\n if (fragCurrent && fragCurrent.loader) {\n fragCurrent.loader.abort();\n }\n\n this.fragCurrent = null;\n // start flush position is the start PTS of next buffered frag.\n // we use frag.naxStartPTS which is max(audio startPTS, video startPTS).\n // in case there is a small PTS Delta between audio and video, using maxStartPTS avoids flushing last samples from current fragment\n const startPts = Math.max(bufferedFrag.endPTS, nextBufferedFrag.maxStartPTS + Math.min(this.config.maxFragLookUpTolerance, nextBufferedFrag.duration));\n this.flushMainBuffer(startPts, Number.POSITIVE_INFINITY);\n }\n }\n }\n }\n\n flushMainBuffer (startOffset, endOffset) {\n this.state = State.BUFFER_FLUSHING;\n let flushScope = { startOffset: startOffset, endOffset: endOffset };\n // if alternate audio tracks are used, only flush video, otherwise flush everything\n if (this.altAudio) {\n flushScope.type = 'video';\n }\n\n this.hls.trigger(Event.BUFFER_FLUSHING, flushScope);\n }\n\n onMediaAttached (data) {\n let media = this.media = this.mediaBuffer = data.media;\n this.onvseeking = this.onMediaSeeking.bind(this);\n this.onvseeked = this.onMediaSeeked.bind(this);\n this.onvended = this.onMediaEnded.bind(this);\n media.addEventListener('seeking', this.onvseeking);\n media.addEventListener('seeked', this.onvseeked);\n media.addEventListener('ended', this.onvended);\n let config = this.config;\n if (this.levels && config.autoStartLoad) {\n this.hls.startLoad(config.startPosition);\n }\n\n this.gapController = new GapController(config, media, this.fragmentTracker, this.hls);\n }\n\n onMediaDetaching () {\n let media = this.media;\n if (media && media.ended) {\n logger.log('MSE detaching and video ended, reset startPosition');\n this.startPosition = this.lastCurrentTime = 0;\n }\n\n // reset fragment backtracked flag\n let levels = this.levels;\n if (levels) {\n levels.forEach(level => {\n if (level.details) {\n level.details.fragments.forEach(fragment => {\n fragment.backtracked = undefined;\n });\n }\n });\n }\n\n // remove video listeners\n if (media) {\n media.removeEventListener('seeking', this.onvseeking);\n media.removeEventListener('seeked', this.onvseeked);\n media.removeEventListener('ended', this.onvended);\n this.onvseeking = this.onvseeked = this.onvended = null;\n }\n\n this.fragmentTracker.removeAllFragments();\n this.media = this.mediaBuffer = null;\n this.loadedmetadata = false;\n this.stopLoad();\n }\n\n onMediaSeeked () {\n const media = this.media;\n const currentTime = media ? media.currentTime : undefined;\n if (Number.isFinite(currentTime)) {\n logger.log(`media seeked to ${currentTime.toFixed(3)}`);\n }\n\n // tick to speed up FRAGMENT_PLAYING triggering\n this.tick();\n }\n\n onManifestLoading () {\n // reset buffer on manifest loading\n logger.log('trigger BUFFER_RESET');\n this.hls.trigger(Event.BUFFER_RESET);\n this.fragmentTracker.removeAllFragments();\n this.stalled = false;\n this.startPosition = this.lastCurrentTime = 0;\n }\n\n onManifestParsed (data) {\n let aac = false, heaac = false, codec;\n data.levels.forEach(level => {\n // detect if we have different kind of audio codecs used amongst playlists\n codec = level.audioCodec;\n if (codec) {\n if (codec.indexOf('mp4a.40.2') !== -1) {\n aac = true;\n }\n\n if (codec.indexOf('mp4a.40.5') !== -1) {\n heaac = true;\n }\n }\n });\n this.audioCodecSwitch = (aac && heaac);\n if (this.audioCodecSwitch) {\n logger.log('both AAC/HE-AAC audio found in levels; declaring level codec as HE-AAC');\n }\n\n this.altAudio = data.altAudio;\n this.levels = data.levels;\n this.startFragRequested = false;\n let config = this.config;\n if (config.autoStartLoad || this.forceStartLoad) {\n this.hls.startLoad(config.startPosition);\n }\n }\n\n onLevelLoaded (data) {\n const newDetails = data.details;\n const newLevelId = data.level;\n const lastLevel = this.levels[this.levelLastLoaded];\n const curLevel = this.levels[newLevelId];\n const duration = newDetails.totalduration;\n let sliding = 0;\n\n logger.log(`level ${newLevelId} loaded [${newDetails.startSN},${newDetails.endSN}],duration:${duration}`);\n\n if (newDetails.live || (curLevel.details && curLevel.details.live)) {\n let curDetails = curLevel.details;\n if (curDetails && newDetails.fragments.length > 0) {\n // we already have details for that level, merge them\n LevelHelper.mergeDetails(curDetails, newDetails);\n sliding = newDetails.fragments[0].start;\n this.liveSyncPosition = this.computeLivePosition(sliding, curDetails);\n if (newDetails.PTSKnown && Number.isFinite(sliding)) {\n logger.log(`live playlist sliding:${sliding.toFixed(3)}`);\n } else {\n logger.log('live playlist - outdated PTS, unknown sliding');\n alignStream(this.fragPrevious, lastLevel, newDetails);\n }\n } else {\n logger.log('live playlist - first load, unknown sliding');\n newDetails.PTSKnown = false;\n alignStream(this.fragPrevious, lastLevel, newDetails);\n }\n } else {\n newDetails.PTSKnown = false;\n }\n // override level info\n curLevel.details = newDetails;\n this.levelLastLoaded = newLevelId;\n this.hls.trigger(Event.LEVEL_UPDATED, { details: newDetails, level: newLevelId });\n\n if (this.startFragRequested === false) {\n // compute start position if set to -1. use it straight away if value is defined\n if (this.startPosition === -1 || this.lastCurrentTime === -1) {\n // first, check if start time offset has been set in playlist, if yes, use this value\n let startTimeOffset = newDetails.startTimeOffset;\n if (Number.isFinite(startTimeOffset)) {\n if (startTimeOffset < 0) {\n logger.log(`negative start time offset ${startTimeOffset}, count from end of last fragment`);\n startTimeOffset = sliding + duration + startTimeOffset;\n }\n logger.log(`start time offset found in playlist, adjust startPosition to ${startTimeOffset}`);\n this.startPosition = startTimeOffset;\n } else {\n // if live playlist, set start position to be fragment N-this.config.liveSyncDurationCount (usually 3)\n if (newDetails.live) {\n this.startPosition = this.computeLivePosition(sliding, newDetails);\n logger.log(`configure startPosition to ${this.startPosition}`);\n } else {\n this.startPosition = 0;\n }\n }\n this.lastCurrentTime = this.startPosition;\n }\n this.nextLoadPosition = this.startPosition;\n }\n // only switch batck to IDLE state if we were waiting for level to start downloading a new fragment\n if (this.state === State.WAITING_LEVEL) {\n this.state = State.IDLE;\n }\n\n // trigger handler right now\n this.tick();\n }\n\n onKeyLoaded () {\n if (this.state === State.KEY_LOADING) {\n this.state = State.IDLE;\n this.tick();\n }\n }\n\n onFragLoaded (data) {\n const { fragCurrent, hls, levels, media } = this;\n const fragLoaded = data.frag;\n if (this.state === State.FRAG_LOADING &&\n fragCurrent &&\n fragLoaded.type === 'main' &&\n fragLoaded.level === fragCurrent.level &&\n fragLoaded.sn === fragCurrent.sn) {\n const stats = data.stats;\n const currentLevel = levels[fragCurrent.level];\n const details = currentLevel.details;\n // reset frag bitrate test in any case after frag loaded event\n // if this frag was loaded to perform a bitrate test AND if hls.nextLoadLevel is greater than 0\n // then this means that we should be able to load a fragment at a higher quality level\n this.bitrateTest = false;\n this.stats = stats;\n\n logger.log(`Loaded ${fragCurrent.sn} of [${details.startSN} ,${details.endSN}],level ${fragCurrent.level}`);\n if (fragLoaded.bitrateTest && hls.nextLoadLevel) {\n // switch back to IDLE state ... we just loaded a fragment to determine adequate start bitrate and initialize autoswitch algo\n this.state = State.IDLE;\n this.startFragRequested = false;\n stats.tparsed = stats.tbuffered = window.performance.now();\n hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: fragCurrent, id: 'main' });\n this.tick();\n } else if (fragLoaded.sn === 'initSegment') {\n this.state = State.IDLE;\n stats.tparsed = stats.tbuffered = window.performance.now();\n details.initSegment.data = data.payload;\n hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: fragCurrent, id: 'main' });\n this.tick();\n } else {\n logger.log(`Parsing ${fragCurrent.sn} of [${details.startSN} ,${details.endSN}],level ${fragCurrent.level}, cc ${fragCurrent.cc}`);\n this.state = State.PARSING;\n this.pendingBuffering = true;\n this.appended = false;\n\n // Bitrate test frags are not usually buffered so the fragment tracker ignores them. If Hls.js decides to buffer\n // it (and therefore ends up at this line), then the fragment tracker needs to be manually informed.\n if (fragLoaded.bitrateTest) {\n fragLoaded.bitrateTest = false;\n this.fragmentTracker.onFragLoaded({\n frag: fragLoaded\n });\n }\n\n // time Offset is accurate if level PTS is known, or if playlist is not sliding (not live) and if media is not seeking (this is to overcome potential timestamp drifts between playlists and fragments)\n const accurateTimeOffset = !(media && media.seeking) && (details.PTSKnown || !details.live);\n const initSegmentData = details.initSegment ? details.initSegment.data : [];\n const audioCodec = this._getAudioCodec(currentLevel);\n\n // transmux the MPEG-TS data to ISO-BMFF segments\n const demuxer = this.demuxer = this.demuxer || new Demuxer(this.hls, 'main');\n demuxer.push(\n data.payload,\n initSegmentData,\n audioCodec,\n currentLevel.videoCodec,\n fragCurrent,\n details.totalduration,\n accurateTimeOffset\n );\n }\n }\n this.fragLoadError = 0;\n }\n\n onFragParsingInitSegment (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n\n if (fragCurrent &&\n data.id === 'main' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n let tracks = data.tracks, trackName, track;\n\n this.audioOnly = tracks.audio && !tracks.video;\n\n // if audio track is expected to come from audio stream controller, discard any coming from main\n if (this.altAudio && !this.audioOnly) {\n delete tracks.audio;\n }\n\n // include levelCodec in audio and video tracks\n track = tracks.audio;\n if (track) {\n let audioCodec = this.levels[this.level].audioCodec,\n ua = navigator.userAgent.toLowerCase();\n if (audioCodec && this.audioCodecSwap) {\n logger.log('swapping playlist audio codec');\n if (audioCodec.indexOf('mp4a.40.5') !== -1) {\n audioCodec = 'mp4a.40.2';\n } else {\n audioCodec = 'mp4a.40.5';\n }\n }\n // in case AAC and HE-AAC audio codecs are signalled in manifest\n // force HE-AAC , as it seems that most browsers prefers that way,\n // except for mono streams OR on FF\n // these conditions might need to be reviewed ...\n if (this.audioCodecSwitch) {\n // don't force HE-AAC if mono stream\n if (track.metadata.channelCount !== 1 &&\n // don't force HE-AAC if firefox\n ua.indexOf('firefox') === -1) {\n audioCodec = 'mp4a.40.5';\n }\n }\n // HE-AAC is broken on Android, always signal audio codec as AAC even if variant manifest states otherwise\n if (ua.indexOf('android') !== -1 && track.container !== 'audio/mpeg') { // Exclude mpeg audio\n audioCodec = 'mp4a.40.2';\n logger.log(`Android: force audio codec to ${audioCodec}`);\n }\n track.levelCodec = audioCodec;\n track.id = data.id;\n }\n track = tracks.video;\n if (track) {\n track.levelCodec = this.levels[this.level].videoCodec;\n track.id = data.id;\n }\n this.hls.trigger(Event.BUFFER_CODECS, tracks);\n // loop through tracks that are going to be provided to bufferController\n for (trackName in tracks) {\n track = tracks[trackName];\n logger.log(`main track:${trackName},container:${track.container},codecs[level/parsed]=[${track.levelCodec}/${track.codec}]`);\n let initSegment = track.initSegment;\n if (initSegment) {\n this.appended = true;\n // arm pending Buffering flag before appending a segment\n this.pendingBuffering = true;\n this.hls.trigger(Event.BUFFER_APPENDING, { type: trackName, data: initSegment, parent: 'main', content: 'initSegment' });\n }\n }\n // trigger handler right now\n this.tick();\n }\n }\n\n onFragParsingData (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'main' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n !(data.type === 'audio' && this.altAudio) && // filter out main audio if audio track is loaded through audio stream controller\n this.state === State.PARSING) {\n let level = this.levels[this.level],\n frag = fragCurrent;\n if (!Number.isFinite(data.endPTS)) {\n data.endPTS = data.startPTS + fragCurrent.duration;\n data.endDTS = data.startDTS + fragCurrent.duration;\n }\n\n if (data.hasAudio === true) {\n frag.addElementaryStream(ElementaryStreamTypes.AUDIO);\n }\n\n if (data.hasVideo === true) {\n frag.addElementaryStream(ElementaryStreamTypes.VIDEO);\n }\n\n logger.log(`Parsed ${data.type},PTS:[${data.startPTS.toFixed(3)},${data.endPTS.toFixed(3)}],DTS:[${data.startDTS.toFixed(3)}/${data.endDTS.toFixed(3)}],nb:${data.nb},dropped:${data.dropped || 0}`);\n\n // Detect gaps in a fragment and try to fix it by finding a keyframe in the previous fragment (see _findFragments)\n if (data.type === 'video') {\n frag.dropped = data.dropped;\n if (frag.dropped) {\n if (!frag.backtracked) {\n const levelDetails = level.details;\n if (levelDetails && frag.sn === levelDetails.startSN) {\n logger.warn('missing video frame(s) on first frag, appending with gap', frag.sn);\n } else {\n logger.warn('missing video frame(s), backtracking fragment', frag.sn);\n // Return back to the IDLE state without appending to buffer\n // Causes findFragments to backtrack a segment and find the keyframe\n // Audio fragments arriving before video sets the nextLoadPosition, causing _findFragments to skip the backtracked fragment\n this.fragmentTracker.removeFragment(frag);\n frag.backtracked = true;\n this.nextLoadPosition = data.startPTS;\n this.state = State.IDLE;\n this.fragPrevious = frag;\n if (this.demuxer) {\n this.demuxer.destroy();\n this.demuxer = null;\n }\n this.tick();\n return;\n }\n } else {\n logger.warn('Already backtracked on this fragment, appending with the gap', frag.sn);\n }\n } else {\n // Only reset the backtracked flag if we've loaded the frag without any dropped frames\n frag.backtracked = false;\n }\n }\n\n let drift = LevelHelper.updateFragPTSDTS(level.details, frag, data.startPTS, data.endPTS, data.startDTS, data.endDTS),\n hls = this.hls;\n hls.trigger(Event.LEVEL_PTS_UPDATED, { details: level.details, level: this.level, drift: drift, type: data.type, start: data.startPTS, end: data.endPTS });\n // has remuxer dropped video frames located before first keyframe ?\n [data.data1, data.data2].forEach(buffer => {\n // only append in PARSING state (rationale is that an appending error could happen synchronously on first segment appending)\n // in that case it is useless to append following segments\n if (buffer && buffer.length && this.state === State.PARSING) {\n this.appended = true;\n // arm pending Buffering flag before appending a segment\n this.pendingBuffering = true;\n hls.trigger(Event.BUFFER_APPENDING, { type: data.type, data: buffer, parent: 'main', content: 'data' });\n }\n });\n // trigger handler right now\n this.tick();\n }\n }\n\n onFragParsed (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'main' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n this.stats.tparsed = window.performance.now();\n this.state = State.PARSED;\n this._checkAppendedParsed();\n }\n }\n\n onAudioTrackSwitching (data) {\n // if any URL found on new audio track, it is an alternate audio track\n const fromAltAudio = this.altAudio;\n const altAudio = !!data.url;\n const trackId = data.id;\n // if we switch on main audio, ensure that main fragment scheduling is synced with media.buffered\n // don't do anything if we switch to alt audio: audio stream controller is handling it.\n // we will just have to change buffer scheduling on audioTrackSwitched\n if (!altAudio) {\n if (this.mediaBuffer !== this.media) {\n logger.log('switching on main audio, use media.buffered to schedule main fragment loading');\n this.mediaBuffer = this.media;\n let fragCurrent = this.fragCurrent;\n // we need to refill audio buffer from main: cancel any frag loading to speed up audio switch\n if (fragCurrent.loader) {\n logger.log('switching to main audio track, cancel main fragment load');\n fragCurrent.loader.abort();\n }\n this.fragCurrent = null;\n this.fragPrevious = null;\n // destroy demuxer to force init segment generation (following audio switch)\n if (this.demuxer) {\n this.demuxer.destroy();\n this.demuxer = null;\n }\n // switch to IDLE state to load new fragment\n this.state = State.IDLE;\n }\n let hls = this.hls;\n // If switching from alt to main audio, flush all audio and trigger track switched\n if (fromAltAudio) {\n hls.trigger(Event.BUFFER_FLUSHING, {\n startOffset: 0,\n endOffset: Number.POSITIVE_INFINITY,\n type: 'audio'\n });\n }\n hls.trigger(Event.AUDIO_TRACK_SWITCHED, {\n id: trackId\n });\n }\n }\n\n onAudioTrackSwitched (data) {\n let trackId = data.id,\n altAudio = !!this.hls.audioTracks[trackId].url;\n if (altAudio) {\n let videoBuffer = this.videoBuffer;\n // if we switched on alternate audio, ensure that main fragment scheduling is synced with video sourcebuffer buffered\n if (videoBuffer && this.mediaBuffer !== videoBuffer) {\n logger.log('switching on alternate audio, use video.buffered to schedule main fragment loading');\n this.mediaBuffer = videoBuffer;\n }\n }\n this.altAudio = altAudio;\n this.tick();\n }\n\n onBufferCreated (data) {\n let tracks = data.tracks, mediaTrack, name, alternate = false;\n for (let type in tracks) {\n let track = tracks[type];\n if (track.id === 'main') {\n name = type;\n mediaTrack = track;\n // keep video source buffer reference\n if (type === 'video') {\n this.videoBuffer = tracks[type].buffer;\n }\n } else {\n alternate = true;\n }\n }\n if (alternate && mediaTrack) {\n logger.log(`alternate track found, use ${name}.buffered to schedule main fragment loading`);\n this.mediaBuffer = mediaTrack.buffer;\n } else {\n this.mediaBuffer = this.media;\n }\n }\n\n onBufferAppended (data) {\n if (data.parent === 'main') {\n const state = this.state;\n if (state === State.PARSING || state === State.PARSED) {\n // check if all buffers have been appended\n this.pendingBuffering = (data.pending > 0);\n this._checkAppendedParsed();\n }\n }\n }\n\n _checkAppendedParsed () {\n // trigger handler right now\n if (this.state === State.PARSED && (!this.appended || !this.pendingBuffering)) {\n const frag = this.fragCurrent;\n if (frag) {\n const media = this.mediaBuffer ? this.mediaBuffer : this.media;\n logger.log(`main buffered : ${TimeRanges.toString(media.buffered)}`);\n this.fragPrevious = frag;\n const stats = this.stats;\n stats.tbuffered = window.performance.now();\n // we should get rid of this.fragLastKbps\n this.fragLastKbps = Math.round(8 * stats.total / (stats.tbuffered - stats.tfirst));\n this.hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: frag, id: 'main' });\n this.state = State.IDLE;\n }\n // Do not tick when _seekToStartPos needs to be called as seeking to the start can fail on live streams at this point\n if (this.loadedmetadata || this.startPosition <= 0) {\n this.tick();\n }\n }\n }\n\n onError (data) {\n let frag = data.frag || this.fragCurrent;\n // don't handle frag error not related to main fragment\n if (frag && frag.type !== 'main') {\n return;\n }\n\n // 0.5 : tolerance needed as some browsers stalls playback before reaching buffered end\n let mediaBuffered = !!this.media && BufferHelper.isBuffered(this.media, this.media.currentTime) && BufferHelper.isBuffered(this.media, this.media.currentTime + 0.5);\n\n switch (data.details) {\n case ErrorDetails.FRAG_LOAD_ERROR:\n case ErrorDetails.FRAG_LOAD_TIMEOUT:\n case ErrorDetails.KEY_LOAD_ERROR:\n case ErrorDetails.KEY_LOAD_TIMEOUT:\n if (!data.fatal) {\n // keep retrying until the limit will be reached\n if ((this.fragLoadError + 1) <= this.config.fragLoadingMaxRetry) {\n // exponential backoff capped to config.fragLoadingMaxRetryTimeout\n let delay = Math.min(Math.pow(2, this.fragLoadError) * this.config.fragLoadingRetryDelay, this.config.fragLoadingMaxRetryTimeout);\n logger.warn(`mediaController: frag loading failed, retry in ${delay} ms`);\n this.retryDate = window.performance.now() + delay;\n // retry loading state\n // if loadedmetadata is not set, it means that we are emergency switch down on first frag\n // in that case, reset startFragRequested flag\n if (!this.loadedmetadata) {\n this.startFragRequested = false;\n this.nextLoadPosition = this.startPosition;\n }\n this.fragLoadError++;\n this.state = State.FRAG_LOADING_WAITING_RETRY;\n } else {\n logger.error(`mediaController: ${data.details} reaches max retry, redispatch as fatal ...`);\n // switch error to fatal\n data.fatal = true;\n this.state = State.ERROR;\n }\n }\n break;\n case ErrorDetails.LEVEL_LOAD_ERROR:\n case ErrorDetails.LEVEL_LOAD_TIMEOUT:\n if (this.state !== State.ERROR) {\n if (data.fatal) {\n // if fatal error, stop processing\n this.state = State.ERROR;\n logger.warn(`streamController: ${data.details},switch to ${this.state} state ...`);\n } else {\n // in case of non fatal error while loading level, if level controller is not retrying to load level , switch back to IDLE\n if (!data.levelRetry && this.state === State.WAITING_LEVEL) {\n this.state = State.IDLE;\n }\n }\n }\n break;\n case ErrorDetails.BUFFER_FULL_ERROR:\n // if in appending state\n if (data.parent === 'main' && (this.state === State.PARSING || this.state === State.PARSED)) {\n // reduce max buf len if current position is buffered\n if (mediaBuffered) {\n this._reduceMaxBufferLength(this.config.maxBufferLength);\n this.state = State.IDLE;\n } else {\n // current position is not buffered, but browser is still complaining about buffer full error\n // this happens on IE/Edge, refer to https://github.com/video-dev/hls.js/pull/708\n // in that case flush the whole buffer to recover\n logger.warn('buffer full error also media.currentTime is not buffered, flush everything');\n this.fragCurrent = null;\n // flush everything\n this.flushMainBuffer(0, Number.POSITIVE_INFINITY);\n }\n }\n break;\n default:\n break;\n }\n }\n\n _reduceMaxBufferLength (minLength) {\n let config = this.config;\n if (config.maxMaxBufferLength >= minLength) {\n // reduce max buffer length as it might be too high. we do this to avoid loop flushing ...\n config.maxMaxBufferLength /= 2;\n logger.warn(`main:reduce max buffer length to ${config.maxMaxBufferLength}s`);\n return true;\n }\n return false;\n }\n\n /**\n * Checks the health of the buffer and attempts to resolve playback stalls.\n * @private\n */\n _checkBuffer () {\n const { media } = this;\n if (!media || media.readyState === 0) {\n // Exit early if we don't have media or if the media hasn't bufferd anything yet (readyState 0)\n return;\n }\n\n const mediaBuffer = this.mediaBuffer ? this.mediaBuffer : media;\n const buffered = mediaBuffer.buffered;\n\n if (!this.loadedmetadata && buffered.length) {\n this.loadedmetadata = true;\n this._seekToStartPos();\n } else if (this.immediateSwitch) {\n this.immediateLevelSwitchEnd();\n } else {\n this.gapController.poll(this.lastCurrentTime, buffered);\n }\n }\n\n onFragLoadEmergencyAborted () {\n this.state = State.IDLE;\n // if loadedmetadata is not set, it means that we are emergency switch down on first frag\n // in that case, reset startFragRequested flag\n if (!this.loadedmetadata) {\n this.startFragRequested = false;\n this.nextLoadPosition = this.startPosition;\n }\n this.tick();\n }\n\n onBufferFlushed () {\n /* after successful buffer flushing, filter flushed fragments from bufferedFrags\n use mediaBuffered instead of media (so that we will check against video.buffered ranges in case of alt audio track)\n */\n const media = this.mediaBuffer ? this.mediaBuffer : this.media;\n if (media) {\n // filter fragments potentially evicted from buffer. this is to avoid memleak on live streams\n const elementaryStreamType = this.audioOnly ? ElementaryStreamTypes.AUDIO : ElementaryStreamTypes.VIDEO;\n this.fragmentTracker.detectEvictedFragments(elementaryStreamType, media.buffered);\n }\n // move to IDLE once flush complete. this should trigger new fragment loading\n this.state = State.IDLE;\n // reset reference to frag\n this.fragPrevious = null;\n }\n\n onLevelsUpdated (data) {\n this.levels = data.levels;\n }\n\n swapAudioCodec () {\n this.audioCodecSwap = !this.audioCodecSwap;\n }\n /**\n * Seeks to the set startPosition if not equal to the mediaElement's current time.\n * @private\n */\n _seekToStartPos () {\n const { media } = this;\n const currentTime = media.currentTime;\n let startPosition = this.startPosition;\n // only adjust currentTime if different from startPosition or if startPosition not buffered\n // at that stage, there should be only one buffered range, as we reach that code after first fragment has been buffered\n if (currentTime !== startPosition && startPosition >= 0) {\n if (media.seeking) {\n logger.log(`could not seek to ${startPosition}, already seeking at ${currentTime}`);\n return;\n }\n const bufferStart = media.buffered.length ? media.buffered.start(0) : 0;\n const delta = bufferStart - startPosition;\n if (delta > 0 && delta < this.config.maxBufferHole) {\n logger.log(`adjusting start position by ${delta} to match buffer start`);\n startPosition += delta;\n this.startPosition = startPosition;\n }\n logger.log(`seek to target start position ${startPosition} from current time ${currentTime}. ready state ${media.readyState}`);\n media.currentTime = startPosition;\n }\n }\n\n _getAudioCodec (currentLevel) {\n let audioCodec = this.config.defaultAudioCodec || currentLevel.audioCodec;\n if (this.audioCodecSwap) {\n logger.log('swapping playlist audio codec');\n if (audioCodec) {\n if (audioCodec.indexOf('mp4a.40.5') !== -1) {\n audioCodec = 'mp4a.40.2';\n } else {\n audioCodec = 'mp4a.40.5';\n }\n }\n }\n\n return audioCodec;\n }\n\n get liveSyncPosition () {\n return this._liveSyncPosition;\n }\n\n set liveSyncPosition (value) {\n this._liveSyncPosition = value;\n }\n}\nexport default StreamController;\n","/*\n * Level Controller\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { isCodecSupportedInMp4 } from '../utils/codecs';\nimport { addGroupId, computeReloadInterval } from './level-helper';\n\nlet chromeOrFirefox;\n\nexport default class LevelController extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.MANIFEST_LOADED,\n Event.LEVEL_LOADED,\n Event.AUDIO_TRACK_SWITCHED,\n Event.FRAG_LOADED,\n Event.ERROR);\n\n this.canload = false;\n this.currentLevelIndex = null;\n this.manualLevelIndex = -1;\n this.timer = null;\n\n chromeOrFirefox = /chrome|firefox/.test(navigator.userAgent.toLowerCase());\n }\n\n onHandlerDestroying () {\n this.clearTimer();\n this.manualLevelIndex = -1;\n }\n\n clearTimer () {\n if (this.timer !== null) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n }\n\n startLoad () {\n let levels = this._levels;\n\n this.canload = true;\n this.levelRetryCount = 0;\n\n // clean up live level details to force reload them, and reset load errors\n if (levels) {\n levels.forEach(level => {\n level.loadError = 0;\n const levelDetails = level.details;\n if (levelDetails && levelDetails.live) {\n level.details = undefined;\n }\n });\n }\n // speed up live playlist refresh if timer exists\n if (this.timer !== null) {\n this.loadLevel();\n }\n }\n\n stopLoad () {\n this.canload = false;\n }\n\n onManifestLoaded (data) {\n let levels = [];\n let audioTracks = [];\n let bitrateStart;\n let levelSet = {};\n let levelFromSet = null;\n let videoCodecFound = false;\n let audioCodecFound = false;\n\n // regroup redundant levels together\n data.levels.forEach(level => {\n const attributes = level.attrs;\n level.loadError = 0;\n level.fragmentError = false;\n\n videoCodecFound = videoCodecFound || !!level.videoCodec;\n audioCodecFound = audioCodecFound || !!level.audioCodec;\n\n // erase audio codec info if browser does not support mp4a.40.34.\n // demuxer will autodetect codec and fallback to mpeg/audio\n if (chromeOrFirefox && level.audioCodec && level.audioCodec.indexOf('mp4a.40.34') !== -1) {\n level.audioCodec = undefined;\n }\n\n levelFromSet = levelSet[level.bitrate]; // FIXME: we would also have to match the resolution here\n\n if (!levelFromSet) {\n level.url = [level.url];\n level.urlId = 0;\n levelSet[level.bitrate] = level;\n levels.push(level);\n } else {\n levelFromSet.url.push(level.url);\n }\n\n if (attributes) {\n if (attributes.AUDIO) {\n addGroupId(levelFromSet || level, 'audio', attributes.AUDIO);\n }\n if (attributes.SUBTITLES) {\n addGroupId(levelFromSet || level, 'text', attributes.SUBTITLES);\n }\n }\n });\n\n // remove audio-only level if we also have levels with audio+video codecs signalled\n if (videoCodecFound && audioCodecFound) {\n levels = levels.filter(({ videoCodec }) => !!videoCodec);\n }\n\n // only keep levels with supported audio/video codecs\n levels = levels.filter(({ audioCodec, videoCodec }) => {\n return (!audioCodec || isCodecSupportedInMp4(audioCodec, 'audio')) && (!videoCodec || isCodecSupportedInMp4(videoCodec, 'video'));\n });\n\n if (data.audioTracks) {\n audioTracks = data.audioTracks.filter(track => !track.audioCodec || isCodecSupportedInMp4(track.audioCodec, 'audio'));\n // Reassign id's after filtering since they're used as array indices\n audioTracks.forEach((track, index) => {\n track.id = index;\n });\n }\n\n if (levels.length > 0) {\n // start bitrate is the first bitrate of the manifest\n bitrateStart = levels[0].bitrate;\n // sort level on bitrate\n levels.sort((a, b) => a.bitrate - b.bitrate);\n this._levels = levels;\n // find index of first level in sorted levels\n for (let i = 0; i < levels.length; i++) {\n if (levels[i].bitrate === bitrateStart) {\n this._firstLevel = i;\n logger.log(`manifest loaded,${levels.length} level(s) found, first bitrate:${bitrateStart}`);\n break;\n }\n }\n\n // Audio is only alternate if manifest include a URI along with the audio group tag,\n // and this is not an audio-only stream where levels contain audio-only\n const audioOnly = audioCodecFound && !videoCodecFound;\n this.hls.trigger(Event.MANIFEST_PARSED, {\n levels,\n audioTracks,\n firstLevel: this._firstLevel,\n stats: data.stats,\n audio: audioCodecFound,\n video: videoCodecFound,\n altAudio: !audioOnly && audioTracks.some(t => !!t.url)\n });\n } else {\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.MANIFEST_INCOMPATIBLE_CODECS_ERROR,\n fatal: true,\n url: this.hls.url,\n reason: 'no level with compatible codecs found in manifest'\n });\n }\n }\n\n get levels () {\n return this._levels;\n }\n\n get level () {\n return this.currentLevelIndex;\n }\n\n set level (newLevel) {\n let levels = this._levels;\n if (levels) {\n newLevel = Math.min(newLevel, levels.length - 1);\n if (this.currentLevelIndex !== newLevel || !levels[newLevel].details) {\n this.setLevelInternal(newLevel);\n }\n }\n }\n\n setLevelInternal (newLevel) {\n const levels = this._levels;\n const hls = this.hls;\n // check if level idx is valid\n if (newLevel >= 0 && newLevel < levels.length) {\n // stopping live reloading timer if any\n this.clearTimer();\n if (this.currentLevelIndex !== newLevel) {\n logger.log(`switching to level ${newLevel}`);\n this.currentLevelIndex = newLevel;\n const levelProperties = levels[newLevel];\n levelProperties.level = newLevel;\n hls.trigger(Event.LEVEL_SWITCHING, levelProperties);\n }\n const level = levels[newLevel];\n const levelDetails = level.details;\n\n // check if we need to load playlist for this level\n if (!levelDetails || levelDetails.live) {\n // level not retrieved yet, or live playlist we need to (re)load it\n let urlId = level.urlId;\n hls.trigger(Event.LEVEL_LOADING, { url: level.url[urlId], level: newLevel, id: urlId });\n }\n } else {\n // invalid level id given, trigger error\n hls.trigger(Event.ERROR, {\n type: ErrorTypes.OTHER_ERROR,\n details: ErrorDetails.LEVEL_SWITCH_ERROR,\n level: newLevel,\n fatal: false,\n reason: 'invalid level idx'\n });\n }\n }\n\n get manualLevel () {\n return this.manualLevelIndex;\n }\n\n set manualLevel (newLevel) {\n this.manualLevelIndex = newLevel;\n if (this._startLevel === undefined) {\n this._startLevel = newLevel;\n }\n\n if (newLevel !== -1) {\n this.level = newLevel;\n }\n }\n\n get firstLevel () {\n return this._firstLevel;\n }\n\n set firstLevel (newLevel) {\n this._firstLevel = newLevel;\n }\n\n get startLevel () {\n // hls.startLevel takes precedence over config.startLevel\n // if none of these values are defined, fallback on this._firstLevel (first quality level appearing in variant manifest)\n if (this._startLevel === undefined) {\n let configStartLevel = this.hls.config.startLevel;\n if (configStartLevel !== undefined) {\n return configStartLevel;\n } else {\n return this._firstLevel;\n }\n } else {\n return this._startLevel;\n }\n }\n\n set startLevel (newLevel) {\n this._startLevel = newLevel;\n }\n\n onError (data) {\n if (data.fatal) {\n if (data.type === ErrorTypes.NETWORK_ERROR) {\n this.clearTimer();\n }\n\n return;\n }\n\n let levelError = false, fragmentError = false;\n let levelIndex;\n\n // try to recover not fatal errors\n switch (data.details) {\n case ErrorDetails.FRAG_LOAD_ERROR:\n case ErrorDetails.FRAG_LOAD_TIMEOUT:\n case ErrorDetails.KEY_LOAD_ERROR:\n case ErrorDetails.KEY_LOAD_TIMEOUT:\n levelIndex = data.frag.level;\n fragmentError = true;\n break;\n case ErrorDetails.LEVEL_LOAD_ERROR:\n case ErrorDetails.LEVEL_LOAD_TIMEOUT:\n levelIndex = data.context.level;\n levelError = true;\n break;\n case ErrorDetails.REMUX_ALLOC_ERROR:\n levelIndex = data.level;\n levelError = true;\n break;\n }\n\n if (levelIndex !== undefined) {\n this.recoverLevel(data, levelIndex, levelError, fragmentError);\n }\n }\n\n /**\n * Switch to a redundant stream if any available.\n * If redundant stream is not available, emergency switch down if ABR mode is enabled.\n *\n * @param {Object} errorEvent\n * @param {Number} levelIndex current level index\n * @param {Boolean} levelError\n * @param {Boolean} fragmentError\n */\n // FIXME Find a better abstraction where fragment/level retry management is well decoupled\n recoverLevel (errorEvent, levelIndex, levelError, fragmentError) {\n let { config } = this.hls;\n let { details: errorDetails } = errorEvent;\n let level = this._levels[levelIndex];\n let redundantLevels, delay, nextLevel;\n\n level.loadError++;\n level.fragmentError = fragmentError;\n\n if (levelError) {\n if ((this.levelRetryCount + 1) <= config.levelLoadingMaxRetry) {\n // exponential backoff capped to max retry timeout\n delay = Math.min(Math.pow(2, this.levelRetryCount) * config.levelLoadingRetryDelay, config.levelLoadingMaxRetryTimeout);\n // Schedule level reload\n this.timer = setTimeout(() => this.loadLevel(), delay);\n // boolean used to inform stream controller not to switch back to IDLE on non fatal error\n errorEvent.levelRetry = true;\n this.levelRetryCount++;\n logger.warn(`level controller, ${errorDetails}, retry in ${delay} ms, current retry count is ${this.levelRetryCount}`);\n } else {\n logger.error(`level controller, cannot recover from ${errorDetails} error`);\n this.currentLevelIndex = null;\n // stopping live reloading timer if any\n this.clearTimer();\n // switch error to fatal\n errorEvent.fatal = true;\n return;\n }\n }\n\n // Try any redundant streams if available for both errors: level and fragment\n // If level.loadError reaches redundantLevels it means that we tried them all, no hope => let's switch down\n if (levelError || fragmentError) {\n redundantLevels = level.url.length;\n\n if (redundantLevels > 1 && level.loadError < redundantLevels) {\n level.urlId = (level.urlId + 1) % redundantLevels;\n level.details = undefined;\n\n logger.warn(`level controller, ${errorDetails} for level ${levelIndex}: switching to redundant URL-id ${level.urlId}`);\n\n // console.log('Current audio track group ID:', this.hls.audioTracks[this.hls.audioTrack].groupId);\n // console.log('New video quality level audio group id:', level.attrs.AUDIO);\n } else {\n // Search for available level\n if (this.manualLevelIndex === -1) {\n // When lowest level has been reached, let's start hunt from the top\n nextLevel = (levelIndex === 0) ? this._levels.length - 1 : levelIndex - 1;\n logger.warn(`level controller, ${errorDetails}: switch to ${nextLevel}`);\n this.hls.nextAutoLevel = this.currentLevelIndex = nextLevel;\n } else if (fragmentError) {\n // Allow fragment retry as long as configuration allows.\n // reset this._level so that another call to set level() will trigger again a frag load\n logger.warn(`level controller, ${errorDetails}: reload a fragment`);\n this.currentLevelIndex = null;\n }\n }\n }\n }\n\n // reset errors on the successful load of a fragment\n onFragLoaded ({ frag }) {\n if (frag !== undefined && frag.type === 'main') {\n const level = this._levels[frag.level];\n if (level !== undefined) {\n level.fragmentError = false;\n level.loadError = 0;\n this.levelRetryCount = 0;\n }\n }\n }\n\n onLevelLoaded (data) {\n const { level, details } = data;\n // only process level loaded events matching with expected level\n if (level !== this.currentLevelIndex) {\n return;\n }\n\n const curLevel = this._levels[level];\n // reset level load error counter on successful level loaded only if there is no issues with fragments\n if (!curLevel.fragmentError) {\n curLevel.loadError = 0;\n this.levelRetryCount = 0;\n }\n // if current playlist is a live playlist, arm a timer to reload it\n if (details.live) {\n const reloadInterval = computeReloadInterval(curLevel.details, details, data.stats.trequest);\n logger.log(`live playlist, reload in ${Math.round(reloadInterval)} ms`);\n this.timer = setTimeout(() => this.loadLevel(), reloadInterval);\n } else {\n this.clearTimer();\n }\n }\n\n onAudioTrackSwitched (data) {\n const audioGroupId = this.hls.audioTracks[data.id].groupId;\n\n const currentLevel = this.hls.levels[this.currentLevelIndex];\n if (!currentLevel) {\n return;\n }\n\n if (currentLevel.audioGroupIds) {\n let urlId = -1;\n\n for (let i = 0; i < currentLevel.audioGroupIds.length; i++) {\n if (currentLevel.audioGroupIds[i] === audioGroupId) {\n urlId = i;\n break;\n }\n }\n\n if (urlId !== currentLevel.urlId) {\n currentLevel.urlId = urlId;\n this.startLoad();\n }\n }\n }\n\n loadLevel () {\n logger.debug('call to loadLevel');\n\n if (this.currentLevelIndex !== null && this.canload) {\n const levelObject = this._levels[this.currentLevelIndex];\n\n if (typeof levelObject === 'object' &&\n levelObject.url.length > 0) {\n const level = this.currentLevelIndex;\n const id = levelObject.urlId;\n const url = levelObject.url[id];\n\n logger.log(`Attempt loading level index ${level} with URL-id ${id}`);\n\n // console.log('Current audio track group ID:', this.hls.audioTracks[this.hls.audioTrack].groupId);\n // console.log('New video quality level audio group id:', levelObject.attrs.AUDIO, level);\n\n this.hls.trigger(Event.LEVEL_LOADING, { url, level, id });\n }\n }\n }\n\n get nextLoadLevel () {\n if (this.manualLevelIndex !== -1) {\n return this.manualLevelIndex;\n } else {\n return this.hls.nextAutoLevel;\n }\n }\n\n set nextLoadLevel (nextLevel) {\n this.level = nextLevel;\n if (this.manualLevelIndex === -1) {\n this.hls.nextAutoLevel = nextLevel;\n }\n }\n\n removeLevel (levelIndex, urlId) {\n const levels = this.levels.filter((level, index) => {\n if (index !== levelIndex) {\n return true;\n }\n\n if (level.url.length > 1 && urlId !== undefined) {\n level.url = level.url.filter((url, id) => id !== urlId);\n level.urlId = 0;\n return true;\n }\n return false;\n }).map((level, index) => {\n const { details } = level;\n if (details && details.fragments) {\n details.fragments.forEach((fragment) => {\n fragment.level = index;\n });\n }\n return level;\n });\n\n this._levels = levels;\n\n this.hls.trigger(Event.LEVELS_UPDATED, { levels });\n }\n}\n","\nexport function sendAddTrackEvent (track: TextTrack, videoEl: HTMLMediaElement) {\n let event: Event;\n try {\n event = new Event('addtrack');\n } catch (err) {\n // for IE11\n event = document.createEvent('Event');\n event.initEvent('addtrack', false, false);\n }\n (event as any).track = track;\n videoEl.dispatchEvent(event);\n}\n\nexport function clearCurrentCues (track: TextTrack) {\n if (track?.cues) {\n while (track.cues.length > 0) {\n track.removeCue(track.cues[0]);\n }\n }\n}\n\n/**\n * Given a list of Cues, finds the closest cue matching the given time.\n * Modified verison of binary search O(log(n)).\n *\n * @export\n * @param {(TextTrackCueList | TextTrackCue[])} cues - List of cues.\n * @param {number} time - Target time, to find closest cue to.\n * @returns {TextTrackCue}\n */\nexport function getClosestCue (cues: TextTrackCueList | TextTrackCue[], time: number): TextTrackCue {\n // If the offset is less than the first element, the first element is the closest.\n if (time < cues[0].endTime) {\n return cues[0];\n }\n // If the offset is greater than the last cue, the last is the closest.\n if (time > cues[cues.length - 1].endTime) {\n return cues[cues.length - 1];\n }\n\n let left = 0;\n let right = cues.length - 1;\n\n while (left <= right) {\n const mid = Math.floor((right + left) / 2);\n\n if (time < cues[mid].endTime) {\n right = mid - 1;\n } else if (time > cues[mid].endTime) {\n left = mid + 1;\n } else {\n // If it's not lower or higher, it must be equal.\n return cues[mid];\n }\n }\n // At this point, left and right have swapped.\n // No direct match was found, left or right element must be the closest. Check which one has the smallest diff.\n return (cues[left].endTime - time) < (time - cues[right].endTime) ? cues[left] : cues[right];\n}\n","/*\n * id3 metadata track controller\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport ID3 from '../demux/id3';\nimport { sendAddTrackEvent, clearCurrentCues, getClosestCue } from '../utils/texttrack-utils';\n\nconst MIN_CUE_DURATION = 0.25;\n\nclass ID3TrackController extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.FRAG_PARSING_METADATA,\n Event.LIVE_BACK_BUFFER_REACHED\n );\n this.id3Track = undefined;\n this.media = undefined;\n }\n\n destroy () {\n EventHandler.prototype.destroy.call(this);\n }\n\n // Add ID3 metatadata text track.\n onMediaAttached (data) {\n this.media = data.media;\n if (!this.media) {\n\n }\n }\n\n onMediaDetaching () {\n clearCurrentCues(this.id3Track);\n this.id3Track = undefined;\n this.media = undefined;\n }\n\n getID3Track (textTracks) {\n for (let i = 0; i < textTracks.length; i++) {\n let textTrack = textTracks[i];\n if (textTrack.kind === 'metadata' && textTrack.label === 'id3') {\n // send 'addtrack' when reusing the textTrack for metadata,\n // same as what we do for captions\n sendAddTrackEvent(textTrack, this.media);\n\n return textTrack;\n }\n }\n return this.media.addTextTrack('metadata', 'id3');\n }\n\n onFragParsingMetadata (data) {\n const fragment = data.frag;\n const samples = data.samples;\n\n // create track dynamically\n if (!this.id3Track) {\n this.id3Track = this.getID3Track(this.media.textTracks);\n this.id3Track.mode = 'hidden';\n }\n\n // Attempt to recreate Safari functionality by creating\n // WebKitDataCue objects when available and store the decoded\n // ID3 data in the value property of the cue\n let Cue = window.WebKitDataCue || window.VTTCue || window.TextTrackCue;\n\n for (let i = 0; i < samples.length; i++) {\n const frames = ID3.getID3Frames(samples[i].data);\n if (frames) {\n // Ensure the pts is positive - sometimes it's reported as a small negative number\n let startTime = Math.max(samples[i].pts, 0);\n let endTime = i < samples.length - 1 ? samples[i + 1].pts : fragment.endPTS;\n if (!endTime) {\n endTime = fragment.start + fragment.duration;\n }\n\n const timeDiff = endTime - startTime;\n if (timeDiff <= 0) {\n endTime = startTime + MIN_CUE_DURATION;\n }\n\n for (let j = 0; j < frames.length; j++) {\n const frame = frames[j];\n // Safari doesn't put the timestamp frame in the TextTrack\n if (!ID3.isTimeStampFrame(frame)) {\n const cue = new Cue(startTime, endTime, '');\n cue.value = frame;\n this.id3Track.addCue(cue);\n }\n }\n }\n }\n }\n\n onLiveBackBufferReached ({ bufferEnd }) {\n const { id3Track } = this;\n if (!id3Track || !id3Track.cues || !id3Track.cues.length) {\n return;\n }\n const foundCue = getClosestCue(id3Track.cues, bufferEnd);\n if (!foundCue) {\n return;\n }\n while (id3Track.cues[0] !== foundCue) {\n id3Track.removeCue(id3Track.cues[0]);\n }\n }\n}\n\nexport default ID3TrackController;\n","/*\n * compute an Exponential Weighted moving average\n * - https://en.wikipedia.org/wiki/Moving_average#Exponential_moving_average\n * - heavily inspired from shaka-player\n */\n\nclass EWMA {\n private alpha_: number;\n private estimate_: number;\n private totalWeight_: number;\n\n // About half of the estimated value will be from the last |halfLife| samples by weight.\n constructor (halfLife: number) {\n // Larger values of alpha expire historical data more slowly.\n this.alpha_ = halfLife ? Math.exp(Math.log(0.5) / halfLife) : 0;\n this.estimate_ = 0;\n this.totalWeight_ = 0;\n }\n\n sample (weight: number, value: number) {\n let adjAlpha = Math.pow(this.alpha_, weight);\n this.estimate_ = value * (1 - adjAlpha) + adjAlpha * this.estimate_;\n this.totalWeight_ += weight;\n }\n\n getTotalWeight (): number {\n return this.totalWeight_;\n }\n\n getEstimate (): number {\n if (this.alpha_) {\n let zeroFactor = 1 - Math.pow(this.alpha_, this.totalWeight_);\n return this.estimate_ / zeroFactor;\n } else {\n return this.estimate_;\n }\n }\n}\n\nexport default EWMA;\n","/*\n * EWMA Bandwidth Estimator\n * - heavily inspired from shaka-player\n * Tracks bandwidth samples and estimates available bandwidth.\n * Based on the minimum of two exponentially-weighted moving averages with\n * different half-lives.\n */\n\nimport EWMA from '../utils/ewma';\n\nclass EwmaBandWidthEstimator {\n hls: any;\n\n private defaultEstimate_: number;\n private minWeight_: number;\n private minDelayMs_: number;\n private slow_: EWMA;\n private fast_: EWMA;\n\n // TODO(typescript-hls)\n constructor (hls: any, slow: number, fast: number, defaultEstimate: number) {\n this.hls = hls;\n this.defaultEstimate_ = defaultEstimate;\n this.minWeight_ = 0.001;\n this.minDelayMs_ = 50;\n this.slow_ = new EWMA(slow);\n this.fast_ = new EWMA(fast);\n }\n\n sample (durationMs: number, numBytes: number) {\n durationMs = Math.max(durationMs, this.minDelayMs_);\n let numBits = 8 * numBytes,\n // weight is duration in seconds\n durationS = durationMs / 1000,\n // value is bandwidth in bits/s\n bandwidthInBps = numBits / durationS;\n this.fast_.sample(durationS, bandwidthInBps);\n this.slow_.sample(durationS, bandwidthInBps);\n }\n\n canEstimate (): boolean {\n let fast = this.fast_;\n return (fast && fast.getTotalWeight() >= this.minWeight_);\n }\n\n getEstimate (): number {\n if (this.canEstimate()) {\n // console.log('slow estimate:'+ Math.round(this.slow_.getEstimate()));\n // console.log('fast estimate:'+ Math.round(this.fast_.getEstimate()));\n // Take the minimum of these two estimates. This should have the effect of\n // adapting down quickly, but up more slowly.\n return Math.min(this.fast_.getEstimate(), this.slow_.getEstimate());\n } else {\n return this.defaultEstimate_;\n }\n }\n\n destroy () {\n }\n}\nexport default EwmaBandWidthEstimator;\n","/*\n * simple ABR Controller\n * - compute next level based on last fragment bw heuristics\n * - implement an abandon rules triggered if we have less than 2 frag buffered and if computed bw shows that we risk buffer stalling\n */\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport { ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport EwmaBandWidthEstimator from '../utils/ewma-bandwidth-estimator';\n\nconst { performance } = window;\n\nclass AbrController extends EventHandler {\n constructor (hls) {\n super(hls, Event.FRAG_LOADING,\n Event.FRAG_LOADED,\n Event.FRAG_BUFFERED,\n Event.ERROR);\n this.lastLoadedFragLevel = 0;\n this._nextAutoLevel = -1;\n this.hls = hls;\n this.timer = null;\n this._bwEstimator = null;\n this.onCheck = this._abandonRulesCheck.bind(this);\n }\n\n destroy () {\n this.clearTimer();\n EventHandler.prototype.destroy.call(this);\n }\n\n onFragLoading (data) {\n const frag = data.frag;\n if (frag.type === 'main') {\n if (!this.timer) {\n this.fragCurrent = frag;\n this.timer = setInterval(this.onCheck, 100);\n }\n\n // lazy init of BwEstimator, rationale is that we use different params for Live/VoD\n // so we need to wait for stream manifest / playlist type to instantiate it.\n if (!this._bwEstimator) {\n const hls = this.hls;\n const config = hls.config;\n const level = frag.level;\n const isLive = hls.levels[level].details.live;\n\n let ewmaFast;\n let ewmaSlow;\n if (isLive) {\n ewmaFast = config.abrEwmaFastLive;\n ewmaSlow = config.abrEwmaSlowLive;\n } else {\n ewmaFast = config.abrEwmaFastVoD;\n ewmaSlow = config.abrEwmaSlowVoD;\n }\n this._bwEstimator = new EwmaBandWidthEstimator(hls, ewmaSlow, ewmaFast, config.abrEwmaDefaultEstimate);\n }\n }\n }\n\n _abandonRulesCheck () {\n /*\n monitor fragment retrieval time...\n we compute expected time of arrival of the complete fragment.\n we compare it to expected time of buffer starvation\n */\n const hls = this.hls;\n const video = hls.media;\n const frag = this.fragCurrent;\n\n if (!frag) {\n return;\n }\n\n const loader = frag.loader;\n\n // if loader has been destroyed or loading has been aborted, stop timer and return\n if (!loader || (loader.stats && loader.stats.aborted)) {\n logger.warn('frag loader destroy or aborted, disarm abandonRules');\n this.clearTimer();\n // reset forced auto level value so that next level will be selected\n this._nextAutoLevel = -1;\n return;\n }\n let stats = loader.stats;\n /* only monitor frag retrieval time if\n (video not paused OR first fragment being loaded(ready state === HAVE_NOTHING = 0)) AND autoswitching enabled AND not lowest level (=> means that we have several levels) */\n if (video && stats && ((!video.paused && (video.playbackRate !== 0)) || !video.readyState) && frag.autoLevel && frag.level) {\n const requestDelay = performance.now() - stats.trequest;\n const playbackRate = Math.abs(video.playbackRate);\n\n // monitor fragment load progress after half of expected fragment duration,to stabilize bitrate\n if (requestDelay > (500 * frag.duration / playbackRate)) {\n const levels = hls.levels;\n const loadRate = Math.max(1, stats.bw ? stats.bw / 8 : stats.loaded * 1000 / requestDelay); // byte/s; at least 1 byte/s to avoid division by zero\n\n // compute expected fragment length using frag duration and level bitrate. also ensure that expected len is gte than already loaded size\n const level = levels[frag.level];\n if (!level) {\n return;\n }\n const levelBitrate = level.realBitrate ? Math.max(level.realBitrate, level.bitrate) : level.bitrate;\n const expectedLen = stats.total ? stats.total : Math.max(stats.loaded, Math.round(frag.duration * levelBitrate / 8));\n const pos = video.currentTime;\n const fragLoadedDelay = (expectedLen - stats.loaded) / loadRate;\n const bufferStarvationDelay = (BufferHelper.bufferInfo(video, pos, hls.config.maxBufferHole).end - pos) / playbackRate;\n\n // consider emergency switch down only if we have less than 2 frag buffered AND\n // time to finish loading current fragment is bigger than buffer starvation delay\n // ie if we risk buffer starvation if bw does not increase quickly\n if ((bufferStarvationDelay < (2 * frag.duration / playbackRate)) && (fragLoadedDelay > bufferStarvationDelay)) {\n const minAutoLevel = hls.minAutoLevel;\n let fragLevelNextLoadedDelay;\n let nextLoadLevel;\n // lets iterate through lower level and try to find the biggest one that could avoid rebuffering\n // we start from current level - 1 and we step down , until we find a matching level\n for (nextLoadLevel = frag.level - 1; nextLoadLevel > minAutoLevel; nextLoadLevel--) {\n // compute time to load next fragment at lower level\n // 0.8 : consider only 80% of current bw to be conservative\n // 8 = bits per byte (bps/Bps)\n const levelNextBitrate = levels[nextLoadLevel].realBitrate\n ? Math.max(levels[nextLoadLevel].realBitrate, levels[nextLoadLevel].bitrate)\n : levels[nextLoadLevel].bitrate;\n\n const fragLevelNextLoadedDelay = frag.duration * levelNextBitrate / (8 * 0.8 * loadRate);\n\n if (fragLevelNextLoadedDelay < bufferStarvationDelay) {\n // we found a lower level that be rebuffering free with current estimated bw !\n break;\n }\n }\n // only emergency switch down if it takes less time to load new fragment at lowest level instead\n // of finishing loading current one ...\n if (fragLevelNextLoadedDelay < fragLoadedDelay) {\n logger.warn(`loading too slow, abort fragment loading and switch to level ${nextLoadLevel}:fragLoadedDelay[${nextLoadLevel}]<fragLoadedDelay[${frag.level - 1}];bufferStarvationDelay:${fragLevelNextLoadedDelay.toFixed(1)}<${fragLoadedDelay.toFixed(1)}:${bufferStarvationDelay.toFixed(1)}`);\n // force next load level in auto mode\n hls.nextLoadLevel = nextLoadLevel;\n // update bw estimate for this fragment before cancelling load (this will help reducing the bw)\n this._bwEstimator.sample(requestDelay, stats.loaded);\n // abort fragment loading\n loader.abort();\n // stop abandon rules timer\n this.clearTimer();\n hls.trigger(Event.FRAG_LOAD_EMERGENCY_ABORTED, { frag: frag, stats: stats });\n }\n }\n }\n }\n }\n\n onFragLoaded (data) {\n const frag = data.frag;\n if (frag.type === 'main' && Number.isFinite(frag.sn)) {\n // stop monitoring bw once frag loaded\n this.clearTimer();\n // store level id after successful fragment load\n this.lastLoadedFragLevel = frag.level;\n // reset forced auto level value so that next level will be selected\n this._nextAutoLevel = -1;\n\n // compute level average bitrate\n if (this.hls.config.abrMaxWithRealBitrate) {\n const level = this.hls.levels[frag.level];\n let loadedBytes = (level.loaded ? level.loaded.bytes : 0) + data.stats.loaded;\n let loadedDuration = (level.loaded ? level.loaded.duration : 0) + data.frag.duration;\n level.loaded = { bytes: loadedBytes, duration: loadedDuration };\n level.realBitrate = Math.round(8 * loadedBytes / loadedDuration);\n }\n // if fragment has been loaded to perform a bitrate test,\n if (data.frag.bitrateTest) {\n let stats = data.stats;\n stats.tparsed = stats.tbuffered = stats.tload;\n this.onFragBuffered(data);\n }\n }\n }\n\n onFragBuffered (data) {\n const stats = data.stats;\n const frag = data.frag;\n // only update stats on first frag buffering\n // if same frag is loaded multiple times, it might be in browser cache, and loaded quickly\n // and leading to wrong bw estimation\n // on bitrate test, also only update stats once (if tload = tbuffered == on FRAG_LOADED)\n if (stats.aborted !== true && frag.type === 'main' && Number.isFinite(frag.sn) && ((!frag.bitrateTest || stats.tload === stats.tbuffered))) {\n // use tparsed-trequest instead of tbuffered-trequest to compute fragLoadingProcessing; rationale is that buffer appending only happens once media is attached\n // in case we use config.startFragPrefetch while media is not attached yet, fragment might be parsed while media not attached yet, but it will only be buffered on media attached\n // as a consequence it could happen really late in the process. meaning that appending duration might appears huge ... leading to underestimated throughput estimation\n let fragLoadingProcessingMs = stats.tparsed - stats.trequest;\n logger.log(`latency/loading/parsing/append/kbps:${Math.round(stats.tfirst - stats.trequest)}/${Math.round(stats.tload - stats.tfirst)}/${Math.round(stats.tparsed - stats.tload)}/${Math.round(stats.tbuffered - stats.tparsed)}/${Math.round(8 * stats.loaded / (stats.tbuffered - stats.trequest))}`);\n this._bwEstimator.sample(fragLoadingProcessingMs, stats.loaded);\n stats.bwEstimate = this._bwEstimator.getEstimate();\n // if fragment has been loaded to perform a bitrate test, (hls.startLevel = -1), store bitrate test delay duration\n if (frag.bitrateTest) {\n this.bitrateTestDelay = fragLoadingProcessingMs / 1000;\n } else {\n this.bitrateTestDelay = 0;\n }\n }\n }\n\n onError (data) {\n // stop timer in case of frag loading error\n switch (data.details) {\n case ErrorDetails.FRAG_LOAD_ERROR:\n case ErrorDetails.FRAG_LOAD_TIMEOUT:\n this.clearTimer();\n break;\n default:\n break;\n }\n }\n\n clearTimer () {\n clearInterval(this.timer);\n this.timer = null;\n }\n\n // return next auto level\n get nextAutoLevel () {\n const forcedAutoLevel = this._nextAutoLevel;\n const bwEstimator = this._bwEstimator;\n // in case next auto level has been forced, and bw not available or not reliable, return forced value\n if (forcedAutoLevel !== -1 && (!bwEstimator || !bwEstimator.canEstimate())) {\n return forcedAutoLevel;\n }\n\n // compute next level using ABR logic\n let nextABRAutoLevel = this._nextABRAutoLevel;\n // if forced auto level has been defined, use it to cap ABR computed quality level\n if (forcedAutoLevel !== -1) {\n nextABRAutoLevel = Math.min(forcedAutoLevel, nextABRAutoLevel);\n }\n\n return nextABRAutoLevel;\n }\n get _nextABRAutoLevel () {\n let hls = this.hls;\n const { maxAutoLevel, levels, config, minAutoLevel } = hls;\n const video = hls.media;\n const currentLevel = this.lastLoadedFragLevel;\n const currentFragDuration = this.fragCurrent ? this.fragCurrent.duration : 0;\n const pos = (video ? video.currentTime : 0);\n\n // playbackRate is the absolute value of the playback rate; if video.playbackRate is 0, we use 1 to load as\n // if we're playing back at the normal rate.\n const playbackRate = ((video && (video.playbackRate !== 0)) ? Math.abs(video.playbackRate) : 1.0);\n const avgbw = this._bwEstimator ? this._bwEstimator.getEstimate() : config.abrEwmaDefaultEstimate;\n // bufferStarvationDelay is the wall-clock time left until the playback buffer is exhausted.\n const bufferStarvationDelay = (BufferHelper.bufferInfo(video, pos, config.maxBufferHole).end - pos) / playbackRate;\n\n // First, look to see if we can find a level matching with our avg bandwidth AND that could also guarantee no rebuffering at all\n let bestLevel = this._findBestLevel(currentLevel, currentFragDuration, avgbw, minAutoLevel, maxAutoLevel, bufferStarvationDelay, config.abrBandWidthFactor, config.abrBandWidthUpFactor, levels);\n if (bestLevel >= 0) {\n return bestLevel;\n } else {\n logger.trace('rebuffering expected to happen, lets try to find a quality level minimizing the rebuffering');\n // not possible to get rid of rebuffering ... let's try to find level that will guarantee less than maxStarvationDelay of rebuffering\n // if no matching level found, logic will return 0\n let maxStarvationDelay = currentFragDuration ? Math.min(currentFragDuration, config.maxStarvationDelay) : config.maxStarvationDelay;\n let bwFactor = config.abrBandWidthFactor;\n let bwUpFactor = config.abrBandWidthUpFactor;\n\n if (bufferStarvationDelay === 0) {\n // in case buffer is empty, let's check if previous fragment was loaded to perform a bitrate test\n let bitrateTestDelay = this.bitrateTestDelay;\n if (bitrateTestDelay) {\n // if it is the case, then we need to adjust our max starvation delay using maxLoadingDelay config value\n // max video loading delay used in automatic start level selection :\n // in that mode ABR controller will ensure that video loading time (ie the time to fetch the first fragment at lowest quality level +\n // the time to fetch the fragment at the appropriate quality level is less than ```maxLoadingDelay``` )\n // cap maxLoadingDelay and ensure it is not bigger 'than bitrate test' frag duration\n const maxLoadingDelay = currentFragDuration ? Math.min(currentFragDuration, config.maxLoadingDelay) : config.maxLoadingDelay;\n maxStarvationDelay = maxLoadingDelay - bitrateTestDelay;\n logger.trace(`bitrate test took ${Math.round(1000 * bitrateTestDelay)}ms, set first fragment max fetchDuration to ${Math.round(1000 * maxStarvationDelay)} ms`);\n // don't use conservative factor on bitrate test\n bwFactor = bwUpFactor = 1;\n }\n }\n bestLevel = this._findBestLevel(currentLevel, currentFragDuration, avgbw, minAutoLevel, maxAutoLevel, bufferStarvationDelay + maxStarvationDelay, bwFactor, bwUpFactor, levels);\n return Math.max(bestLevel, 0);\n }\n }\n\n _findBestLevel (currentLevel, currentFragDuration, currentBw, minAutoLevel, maxAutoLevel, maxFetchDuration, bwFactor, bwUpFactor, levels) {\n for (let i = maxAutoLevel; i >= minAutoLevel; i--) {\n let levelInfo = levels[i];\n\n if (!levelInfo) {\n continue;\n }\n\n const levelDetails = levelInfo.details;\n const avgDuration = levelDetails ? levelDetails.totalduration / levelDetails.fragments.length : currentFragDuration;\n const live = levelDetails ? levelDetails.live : false;\n\n let adjustedbw;\n // follow algorithm captured from stagefright :\n // https://android.googlesource.com/platform/frameworks/av/+/master/media/libstagefright/httplive/LiveSession.cpp\n // Pick the highest bandwidth stream below or equal to estimated bandwidth.\n // consider only 80% of the available bandwidth, but if we are switching up,\n // be even more conservative (70%) to avoid overestimating and immediately\n // switching back.\n if (i <= currentLevel) {\n adjustedbw = bwFactor * currentBw;\n } else {\n adjustedbw = bwUpFactor * currentBw;\n }\n\n const bitrate = levels[i].realBitrate ? Math.max(levels[i].realBitrate, levels[i].bitrate) : levels[i].bitrate;\n const fetchDuration = bitrate * avgDuration / adjustedbw;\n\n logger.trace(`level/adjustedbw/bitrate/avgDuration/maxFetchDuration/fetchDuration: ${i}/${Math.round(adjustedbw)}/${bitrate}/${avgDuration}/${maxFetchDuration}/${fetchDuration}`);\n // if adjusted bw is greater than level bitrate AND\n if (adjustedbw > bitrate &&\n // fragment fetchDuration unknown OR live stream OR fragment fetchDuration less than max allowed fetch duration, then this level matches\n // we don't account for max Fetch Duration for live streams, this is to avoid switching down when near the edge of live sliding window ...\n // special case to support startLevel = -1 (bitrateTest) on live streams : in that case we should not exit loop so that _findBestLevel will return -1\n (!fetchDuration || (live && !this.bitrateTestDelay) || fetchDuration < maxFetchDuration)) {\n // as we are looping from highest to lowest, this will return the best achievable quality level\n return i;\n }\n }\n // not enough time budget even with quality level 0 ... rebuffering might happen\n return -1;\n }\n\n set nextAutoLevel (nextLevel) {\n this._nextAutoLevel = nextLevel;\n }\n}\n\nexport default AbrController;\n","/*\n * Buffer Controller\n */\n\nimport Events from '../events';\nimport EventHandler from '../event-handler';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { getMediaSource } from '../utils/mediasource-helper';\n\nimport { TrackSet } from '../types/track';\nimport { Segment } from '../types/segment';\nimport { BufferControllerConfig } from '../config';\n\n// Add extension properties to SourceBuffers from the DOM API.\ntype ExtendedSourceBuffer = SourceBuffer & {\n ended?: boolean\n};\n\ntype SourceBufferName = 'video' | 'audio';\ntype SourceBuffers = Partial<Record<SourceBufferName, ExtendedSourceBuffer>>;\n\ninterface SourceBufferFlushRange {\n start: number;\n end: number;\n type: SourceBufferName\n}\n\nconst MediaSource = getMediaSource();\n\nclass BufferController extends EventHandler {\n // the value that we have set mediasource.duration to\n // (the actual duration may be tweaked slighly by the browser)\n private _msDuration: number | null = null;\n // the value that we want to set mediaSource.duration to\n private _levelDuration: number | null = null;\n // the target duration of the current media playlist\n private _levelTargetDuration: number = 10;\n // current stream state: true - for live broadcast, false - for VoD content\n private _live: boolean | null = null;\n // cache the self generated object url to detect hijack of video tag\n private _objectUrl: string | null = null;\n\n // signals that the sourceBuffers need to be flushed\n private _needsFlush: boolean = false;\n\n // signals that mediaSource should have endOfStream called\n private _needsEos: boolean = false;\n\n private config: BufferControllerConfig;\n\n // this is optional because this property is removed from the class sometimes\n public audioTimestampOffset?: number;\n\n // The number of BUFFER_CODEC events received before any sourceBuffers are created\n public bufferCodecEventsExpected: number = 0;\n\n // The total number of BUFFER_CODEC events received\n private _bufferCodecEventsTotal: number = 0;\n\n // A reference to the attached media element\n public media: HTMLMediaElement | null = null;\n\n // A reference to the active media source\n public mediaSource: MediaSource | null = null;\n\n // List of pending segments to be appended to source buffer\n public segments: Segment[] = [];\n\n public parent?: string;\n\n // A guard to see if we are currently appending to the source buffer\n public appending: boolean = false;\n\n // counters\n public appended: number = 0;\n public appendError: number = 0;\n public flushBufferCounter: number = 0;\n\n public tracks: TrackSet = {};\n public pendingTracks: TrackSet = {};\n public sourceBuffer: SourceBuffers = {};\n public flushRange: SourceBufferFlushRange[] = [];\n\n constructor (hls: any) {\n super(hls,\n Events.MEDIA_ATTACHING,\n Events.MEDIA_DETACHING,\n Events.MANIFEST_PARSED,\n Events.BUFFER_RESET,\n Events.BUFFER_APPENDING,\n Events.BUFFER_CODECS,\n Events.BUFFER_EOS,\n Events.BUFFER_FLUSHING,\n Events.LEVEL_PTS_UPDATED,\n Events.LEVEL_UPDATED);\n\n this.config = hls.config;\n }\n\n destroy () {\n EventHandler.prototype.destroy.call(this);\n }\n\n onLevelPtsUpdated (data: { type: SourceBufferName, start: number }) {\n let type = data.type;\n let audioTrack = this.tracks.audio;\n\n // Adjusting `SourceBuffer.timestampOffset` (desired point in the timeline where the next frames should be appended)\n // in Chrome browser when we detect MPEG audio container and time delta between level PTS and `SourceBuffer.timestampOffset`\n // is greater than 100ms (this is enough to handle seek for VOD or level change for LIVE videos). At the time of change we issue\n // `SourceBuffer.abort()` and adjusting `SourceBuffer.timestampOffset` if `SourceBuffer.updating` is false or awaiting `updateend`\n // event if SB is in updating state.\n // More info here: https://github.com/video-dev/hls.js/issues/332#issuecomment-257986486\n\n if (type === 'audio' && audioTrack && audioTrack.container === 'audio/mpeg') { // Chrome audio mp3 track\n let audioBuffer = this.sourceBuffer.audio;\n if (!audioBuffer) {\n throw Error('Level PTS Updated and source buffer for audio uninitalized');\n }\n\n let delta = Math.abs(audioBuffer.timestampOffset - data.start);\n\n // adjust timestamp offset if time delta is greater than 100ms\n if (delta > 0.1) {\n let updating = audioBuffer.updating;\n\n try {\n audioBuffer.abort();\n } catch (err) {\n logger.warn('can not abort audio buffer: ' + err);\n }\n\n if (!updating) {\n logger.warn('change mpeg audio timestamp offset from ' + audioBuffer.timestampOffset + ' to ' + data.start);\n audioBuffer.timestampOffset = data.start;\n } else {\n this.audioTimestampOffset = data.start;\n }\n }\n }\n }\n\n onManifestParsed (data: { altAudio: boolean, audio: boolean, video: boolean }) {\n // in case of alt audio (where all tracks have urls) 2 BUFFER_CODECS events will be triggered, one per stream controller\n // sourcebuffers will be created all at once when the expected nb of tracks will be reached\n // in case alt audio is not used, only one BUFFER_CODEC event will be fired from main stream controller\n // it will contain the expected nb of source buffers, no need to compute it\n let codecEvents: number = 2;\n if (data.audio && !data.video || !data.altAudio) {\n codecEvents = 1;\n }\n this.bufferCodecEventsExpected = this._bufferCodecEventsTotal = codecEvents;\n\n logger.log(`${this.bufferCodecEventsExpected} bufferCodec event(s) expected`);\n }\n\n onMediaAttaching (data: { media: HTMLMediaElement }) {\n let media = this.media = data.media;\n if (media && MediaSource) {\n // setup the media source\n let ms = this.mediaSource = new MediaSource();\n // Media Source listeners\n ms.addEventListener('sourceopen', this._onMediaSourceOpen);\n ms.addEventListener('sourceended', this._onMediaSourceEnded);\n ms.addEventListener('sourceclose', this._onMediaSourceClose);\n // link video and media Source\n media.src = window.URL.createObjectURL(ms);\n // cache the locally generated object url\n this._objectUrl = media.src;\n }\n }\n\n onMediaDetaching () {\n logger.log('media source detaching');\n let ms = this.mediaSource;\n if (ms) {\n if (ms.readyState === 'open') {\n try {\n // endOfStream could trigger exception if any sourcebuffer is in updating state\n // we don't really care about checking sourcebuffer state here,\n // as we are anyway detaching the MediaSource\n // let's just avoid this exception to propagate\n ms.endOfStream();\n } catch (err) {\n logger.warn(`onMediaDetaching:${err.message} while calling endOfStream`);\n }\n }\n ms.removeEventListener('sourceopen', this._onMediaSourceOpen);\n ms.removeEventListener('sourceended', this._onMediaSourceEnded);\n ms.removeEventListener('sourceclose', this._onMediaSourceClose);\n\n // Detach properly the MediaSource from the HTMLMediaElement as\n // suggested in https://github.com/w3c/media-source/issues/53.\n if (this.media) {\n if (this._objectUrl) {\n window.URL.revokeObjectURL(this._objectUrl);\n }\n\n // clean up video tag src only if it's our own url. some external libraries might\n // hijack the video tag and change its 'src' without destroying the Hls instance first\n if (this.media.src === this._objectUrl) {\n this.media.removeAttribute('src');\n this.media.load();\n } else {\n logger.warn('media.src was changed by a third party - skip cleanup');\n }\n }\n\n this.mediaSource = null;\n this.media = null;\n this._objectUrl = null;\n this.bufferCodecEventsExpected = this._bufferCodecEventsTotal;\n this.pendingTracks = {};\n this.tracks = {};\n this.sourceBuffer = {};\n this.flushRange = [];\n this.segments = [];\n this.appended = 0;\n }\n\n this.hls.trigger(Events.MEDIA_DETACHED);\n }\n\n checkPendingTracks () {\n let { bufferCodecEventsExpected, pendingTracks } = this;\n\n // Check if we've received all of the expected bufferCodec events. When none remain, create all the sourceBuffers at once.\n // This is important because the MSE spec allows implementations to throw QuotaExceededErrors if creating new sourceBuffers after\n // data has been appended to existing ones.\n // 2 tracks is the max (one for audio, one for video). If we've reach this max go ahead and create the buffers.\n const pendingTracksCount = Object.keys(pendingTracks).length;\n if ((pendingTracksCount && !bufferCodecEventsExpected) || pendingTracksCount === 2) {\n // ok, let's create them now !\n this.createSourceBuffers(pendingTracks);\n this.pendingTracks = {};\n // append any pending segments now !\n this.doAppending();\n }\n }\n\n private _onMediaSourceOpen = () => {\n logger.log('media source opened');\n this.hls.trigger(Events.MEDIA_ATTACHED, { media: this.media });\n let mediaSource = this.mediaSource;\n if (mediaSource) {\n // once received, don't listen anymore to sourceopen event\n mediaSource.removeEventListener('sourceopen', this._onMediaSourceOpen);\n }\n this.checkPendingTracks();\n }\n\n private _onMediaSourceClose = () => {\n logger.log('media source closed');\n }\n\n private _onMediaSourceEnded = () => {\n logger.log('media source ended');\n }\n\n private _onSBUpdateEnd = () => {\n // update timestampOffset\n if (this.audioTimestampOffset && this.sourceBuffer.audio) {\n let audioBuffer = this.sourceBuffer.audio;\n\n logger.warn(`change mpeg audio timestamp offset from ${audioBuffer.timestampOffset} to ${this.audioTimestampOffset}`);\n audioBuffer.timestampOffset = this.audioTimestampOffset;\n delete this.audioTimestampOffset;\n }\n\n if (this._needsFlush) {\n this.doFlush();\n }\n\n if (this._needsEos) {\n this.checkEos();\n }\n\n this.appending = false;\n let parent = this.parent;\n // count nb of pending segments waiting for appending on this sourcebuffer\n let pending = this.segments.reduce((counter, segment) => (segment.parent === parent) ? counter + 1 : counter, 0);\n\n // this.sourceBuffer is better to use than media.buffered as it is closer to the PTS data from the fragments\n const timeRanges: Partial<Record<SourceBufferName, TimeRanges>> = {};\n const sbSet = this.sourceBuffer;\n for (let streamType in sbSet) {\n const sb = sbSet[streamType as SourceBufferName];\n if (!sb) {\n throw Error(`handling source buffer update end error: source buffer for ${streamType} uninitilized and unable to update buffered TimeRanges.`);\n }\n timeRanges[streamType as SourceBufferName] = sb.buffered;\n }\n\n this.hls.trigger(Events.BUFFER_APPENDED, { parent, pending, timeRanges });\n // don't append in flushing mode\n if (!this._needsFlush) {\n this.doAppending();\n }\n\n this.updateMediaElementDuration();\n\n // appending goes first\n if (pending === 0) {\n this.flushLiveBackBuffer();\n }\n }\n\n private _onSBUpdateError = (event: Event) => {\n logger.error('sourceBuffer error:', event);\n // according to http://www.w3.org/TR/media-source/#sourcebuffer-append-error\n // this error might not always be fatal (it is fatal if decode error is set, in that case\n // it will be followed by a mediaElement error ...)\n this.hls.trigger(Events.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.BUFFER_APPENDING_ERROR, fatal: false });\n // we don't need to do more than that, as accordin to the spec, updateend will be fired just after\n }\n\n onBufferReset () {\n const sourceBuffer = this.sourceBuffer;\n for (let type in sourceBuffer) {\n const sb = sourceBuffer[type];\n try {\n if (sb) {\n if (this.mediaSource) {\n this.mediaSource.removeSourceBuffer(sb);\n }\n sb.removeEventListener('updateend', this._onSBUpdateEnd);\n sb.removeEventListener('error', this._onSBUpdateError);\n }\n } catch (err) {\n }\n }\n this.sourceBuffer = {};\n this.flushRange = [];\n this.segments = [];\n this.appended = 0;\n }\n\n onBufferCodecs (tracks: TrackSet) {\n // if source buffer(s) not created yet, appended buffer tracks in this.pendingTracks\n // if sourcebuffers already created, do nothing ...\n if (Object.keys(this.sourceBuffer).length) {\n return;\n }\n\n Object.keys(tracks).forEach(trackName => {\n this.pendingTracks[trackName] = tracks[trackName];\n });\n\n this.bufferCodecEventsExpected = Math.max(this.bufferCodecEventsExpected - 1, 0);\n if (this.mediaSource && this.mediaSource.readyState === 'open') {\n this.checkPendingTracks();\n }\n }\n\n createSourceBuffers (tracks: TrackSet) {\n const { sourceBuffer, mediaSource } = this;\n if (!mediaSource) {\n throw Error('createSourceBuffers called when mediaSource was null');\n }\n\n for (let trackName in tracks) {\n if (!sourceBuffer[trackName]) {\n let track = tracks[trackName as keyof TrackSet];\n if (!track) {\n throw Error(`source buffer exists for track ${trackName}, however track does not`);\n }\n // use levelCodec as first priority\n let codec = track.levelCodec || track.codec;\n let mimeType = `${track.container};codecs=${codec}`;\n logger.log(`creating sourceBuffer(${mimeType})`);\n try {\n let sb = sourceBuffer[trackName] = mediaSource.addSourceBuffer(mimeType);\n sb.addEventListener('updateend', this._onSBUpdateEnd);\n sb.addEventListener('error', this._onSBUpdateError);\n this.tracks[trackName] = {\n buffer: sb,\n codec: codec,\n id: track.id,\n container: track.container,\n levelCodec: track.levelCodec\n };\n } catch (err) {\n logger.error(`error while trying to add sourceBuffer:${err.message}`);\n this.hls.trigger(Events.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: ErrorDetails.BUFFER_ADD_CODEC_ERROR, fatal: false, err: err, mimeType: mimeType });\n }\n }\n }\n this.hls.trigger(Events.BUFFER_CREATED, { tracks: this.tracks });\n }\n\n onBufferAppending (data: Segment) {\n if (!this._needsFlush) {\n if (!this.segments) {\n this.segments = [ data ];\n } else {\n this.segments.push(data);\n }\n\n this.doAppending();\n }\n }\n\n // on BUFFER_EOS mark matching sourcebuffer(s) as ended and trigger checkEos()\n // an undefined data.type will mark all buffers as EOS.\n onBufferEos (data: { type?: SourceBufferName }) {\n for (const type in this.sourceBuffer) {\n if (!data.type || data.type === type) {\n const sb = this.sourceBuffer[type as SourceBufferName];\n if (sb && !sb.ended) {\n sb.ended = true;\n logger.log(`${type} sourceBuffer now EOS`);\n }\n }\n }\n\n this.checkEos();\n }\n\n // if all source buffers are marked as ended, signal endOfStream() to MediaSource.\n checkEos () {\n const { sourceBuffer, mediaSource } = this;\n if (!mediaSource || mediaSource.readyState !== 'open') {\n this._needsEos = false;\n return;\n }\n\n for (let type in sourceBuffer) {\n const sb = sourceBuffer[type as SourceBufferName];\n if (!sb) continue;\n\n if (!sb.ended) {\n return;\n }\n\n if (sb.updating) {\n this._needsEos = true;\n return;\n }\n }\n\n logger.log('all media data are available, signal endOfStream() to MediaSource and stop loading fragment');\n // Notify the media element that it now has all of the media data\n try {\n mediaSource.endOfStream();\n } catch (e) {\n logger.warn('exception while calling mediaSource.endOfStream()');\n }\n this._needsEos = false;\n }\n\n onBufferFlushing (data: { startOffset: number, endOffset: number, type?: SourceBufferName }) {\n if (data.type) {\n this.flushRange.push({ start: data.startOffset, end: data.endOffset, type: data.type });\n } else {\n this.flushRange.push({ start: data.startOffset, end: data.endOffset, type: 'video' });\n this.flushRange.push({ start: data.startOffset, end: data.endOffset, type: 'audio' });\n }\n\n // attempt flush immediately\n this.flushBufferCounter = 0;\n this.doFlush();\n }\n\n flushLiveBackBuffer () {\n // clear back buffer for live only\n if (!this._live) {\n return;\n }\n\n const liveBackBufferLength = this.config.liveBackBufferLength;\n if (!isFinite(liveBackBufferLength) || liveBackBufferLength < 0) {\n return;\n }\n\n if (!this.media) {\n logger.error('flushLiveBackBuffer called without attaching media');\n return;\n }\n\n const currentTime = this.media.currentTime;\n const sourceBuffer = this.sourceBuffer;\n const bufferTypes = Object.keys(sourceBuffer);\n const targetBackBufferPosition = currentTime - Math.max(liveBackBufferLength, this._levelTargetDuration);\n\n for (let index = bufferTypes.length - 1; index >= 0; index--) {\n const bufferType = bufferTypes[index];\n const sb = sourceBuffer[bufferType as SourceBufferName];\n if (sb) {\n const buffered = sb.buffered;\n // when target buffer start exceeds actual buffer start\n if (buffered.length > 0 && targetBackBufferPosition > buffered.start(0)) {\n // remove buffer up until current time minus minimum back buffer length (removing buffer too close to current\n // time will lead to playback freezing)\n // credits for level target duration - https://github.com/videojs/http-streaming/blob/3132933b6aa99ddefab29c10447624efd6fd6e52/src/segment-loader.js#L91\n if (this.removeBufferRange(bufferType, sb, 0, targetBackBufferPosition)) {\n this.hls.trigger(Events.LIVE_BACK_BUFFER_REACHED, { bufferEnd: targetBackBufferPosition });\n }\n }\n }\n }\n }\n\n onLevelUpdated ({ details }: { details: { totalduration: number, targetduration?: number, averagetargetduration?: number, live: boolean, fragments: any[] } }) {\n if (details.fragments.length > 0) {\n this._levelDuration = details.totalduration + details.fragments[0].start;\n this._levelTargetDuration = details.averagetargetduration || details.targetduration || 10;\n this._live = details.live;\n this.updateMediaElementDuration();\n }\n }\n\n /**\n * Update Media Source duration to current level duration or override to Infinity if configuration parameter\n * 'liveDurationInfinity` is set to `true`\n * More details: https://github.com/video-dev/hls.js/issues/355\n */\n updateMediaElementDuration () {\n let { config } = this;\n let duration: number;\n\n if (this._levelDuration === null ||\n !this.media ||\n !this.mediaSource ||\n !this.sourceBuffer ||\n this.media.readyState === 0 ||\n this.mediaSource.readyState !== 'open') {\n return;\n }\n\n for (let type in this.sourceBuffer) {\n const sb = this.sourceBuffer[type];\n if (sb && sb.updating === true) {\n // can't set duration whilst a buffer is updating\n return;\n }\n }\n\n duration = this.media.duration;\n // initialise to the value that the media source is reporting\n if (this._msDuration === null) {\n this._msDuration = this.mediaSource.duration;\n }\n\n if (this._live === true && config.liveDurationInfinity === true) {\n // Override duration to Infinity\n logger.log('Media Source duration is set to Infinity');\n this._msDuration = this.mediaSource.duration = Infinity;\n } else if ((this._levelDuration > this._msDuration && this._levelDuration > duration) || !Number.isFinite(duration)) {\n // levelDuration was the last value we set.\n // not using mediaSource.duration as the browser may tweak this value\n // only update Media Source duration if its value increase, this is to avoid\n // flushing already buffered portion when switching between quality level\n logger.log(`Updating Media Source duration to ${this._levelDuration.toFixed(3)}`);\n this._msDuration = this.mediaSource.duration = this._levelDuration;\n }\n }\n\n doFlush () {\n // loop through all buffer ranges to flush\n while (this.flushRange.length) {\n let range = this.flushRange[0];\n // flushBuffer will abort any buffer append in progress and flush Audio/Video Buffer\n if (this.flushBuffer(range.start, range.end, range.type)) {\n // range flushed, remove from flush array\n this.flushRange.shift();\n this.flushBufferCounter = 0;\n } else {\n this._needsFlush = true;\n // avoid looping, wait for SB update end to retrigger a flush\n return;\n }\n }\n if (this.flushRange.length === 0) {\n // everything flushed\n this._needsFlush = false;\n\n // let's recompute this.appended, which is used to avoid flush looping\n let appended = 0;\n let sourceBuffer = this.sourceBuffer;\n try {\n for (let type in sourceBuffer) {\n const sb = sourceBuffer[type];\n if (sb) {\n appended += sb.buffered.length;\n }\n }\n } catch (error) {\n // error could be thrown while accessing buffered, in case sourcebuffer has already been removed from MediaSource\n // this is harmess at this stage, catch this to avoid reporting an internal exception\n logger.error('error while accessing sourceBuffer.buffered');\n }\n this.appended = appended;\n this.hls.trigger(Events.BUFFER_FLUSHED);\n }\n }\n\n doAppending () {\n let { config, hls, segments, sourceBuffer } = this;\n if (!Object.keys(sourceBuffer).length) {\n // early exit if no source buffers have been initialized yet\n return;\n }\n\n if (!this.media || this.media.error) {\n this.segments = [];\n logger.error('trying to append although a media error occured, flush segment and abort');\n return;\n }\n\n if (this.appending) {\n // logger.log(`sb appending in progress`);\n return;\n }\n\n const segment = segments.shift();\n if (!segment) { // handle undefined shift\n return;\n }\n\n try {\n const sb = sourceBuffer[segment.type];\n if (!sb) {\n // in case we don't have any source buffer matching with this segment type,\n // it means that Mediasource fails to create sourcebuffer\n // discard this segment, and trigger update end\n this._onSBUpdateEnd();\n return;\n }\n\n if (sb.updating) {\n // if we are still updating the source buffer from the last segment, place this back at the front of the queue\n segments.unshift(segment);\n return;\n }\n\n // reset sourceBuffer ended flag before appending segment\n sb.ended = false;\n // logger.log(`appending ${segment.content} ${type} SB, size:${segment.data.length}, ${segment.parent}`);\n this.parent = segment.parent;\n sb.appendBuffer(segment.data);\n this.appendError = 0;\n this.appended++;\n this.appending = true;\n } catch (err) {\n // in case any error occured while appending, put back segment in segments table\n logger.error(`error while trying to append buffer:${err.message}`);\n segments.unshift(segment);\n let event = { type: ErrorTypes.MEDIA_ERROR, parent: segment.parent, details: '', fatal: false };\n if (err.code === 22) {\n // QuotaExceededError: http://www.w3.org/TR/html5/infrastructure.html#quotaexceedederror\n // let's stop appending any segments, and report BUFFER_FULL_ERROR error\n this.segments = [];\n event.details = ErrorDetails.BUFFER_FULL_ERROR;\n } else {\n this.appendError++;\n event.details = ErrorDetails.BUFFER_APPEND_ERROR;\n /* with UHD content, we could get loop of quota exceeded error until\n browser is able to evict some data from sourcebuffer. retrying help recovering this\n */\n if (this.appendError > config.appendErrorMaxRetry) {\n logger.log(`fail ${config.appendErrorMaxRetry} times to append segment in sourceBuffer`);\n this.segments = [];\n event.fatal = true;\n }\n }\n hls.trigger(Events.ERROR, event);\n }\n }\n\n /*\n flush specified buffered range,\n return true once range has been flushed.\n as sourceBuffer.remove() is asynchronous, flushBuffer will be retriggered on sourceBuffer update end\n */\n flushBuffer (startOffset: number, endOffset: number, sbType: SourceBufferName): boolean {\n const sourceBuffer = this.sourceBuffer;\n // exit if no sourceBuffers are initialized\n if (!Object.keys(sourceBuffer).length) {\n return true;\n }\n\n let currentTime: string = 'null';\n if (this.media) {\n currentTime = this.media.currentTime.toFixed(3);\n }\n logger.log(`flushBuffer,pos/start/end: ${currentTime}/${startOffset}/${endOffset}`);\n\n // safeguard to avoid infinite looping : don't try to flush more than the nb of appended segments\n if (this.flushBufferCounter >= this.appended) {\n logger.warn('abort flushing too many retries');\n return true;\n }\n\n const sb = sourceBuffer[sbType];\n // we are going to flush buffer, mark source buffer as 'not ended'\n if (sb) {\n sb.ended = false;\n if (!sb.updating) {\n if (this.removeBufferRange(sbType, sb, startOffset, endOffset)) {\n this.flushBufferCounter++;\n return false;\n }\n } else {\n logger.warn('cannot flush, sb updating in progress');\n return false;\n }\n }\n\n logger.log('buffer flushed');\n // everything flushed !\n return true;\n }\n\n /**\n * Removes first buffered range from provided source buffer that lies within given start and end offsets.\n *\n * @param {string} type Type of the source buffer, logging purposes only.\n * @param {SourceBuffer} sb Target SourceBuffer instance.\n * @param {number} startOffset\n * @param {number} endOffset\n *\n * @returns {boolean} True when source buffer remove requested.\n */\n removeBufferRange (type: string, sb: ExtendedSourceBuffer, startOffset: number, endOffset: number): boolean {\n try {\n for (let i = 0; i < sb.buffered.length; i++) {\n let bufStart = sb.buffered.start(i);\n let bufEnd = sb.buffered.end(i);\n let removeStart = Math.max(bufStart, startOffset);\n let removeEnd = Math.min(bufEnd, endOffset);\n\n /* sometimes sourcebuffer.remove() does not flush\n the exact expected time range.\n to avoid rounding issues/infinite loop,\n only flush buffer range of length greater than 500ms.\n */\n if (Math.min(removeEnd, bufEnd) - removeStart > 0.5) {\n let currentTime: string = 'null';\n if (this.media) {\n currentTime = this.media.currentTime.toString();\n }\n\n logger.log(`sb remove ${type} [${removeStart},${removeEnd}], of [${bufStart},${bufEnd}], pos:${currentTime}`);\n sb.remove(removeStart, removeEnd);\n return true;\n }\n }\n } catch (error) {\n logger.warn('removeBufferRange failed', error);\n }\n\n return false;\n }\n}\n\nexport default BufferController;\n","/*\n * cap stream level to media size dimension controller\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\n\nclass CapLevelController extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.FPS_DROP_LEVEL_CAPPING,\n Event.MEDIA_ATTACHING,\n Event.MANIFEST_PARSED,\n Event.LEVELS_UPDATED,\n Event.BUFFER_CODECS,\n Event.MEDIA_DETACHING);\n\n this.autoLevelCapping = Number.POSITIVE_INFINITY;\n this.firstLevel = null;\n this.levels = [];\n this.media = null;\n this.restrictedLevels = [];\n this.timer = null;\n this.clientRect = null;\n }\n\n destroy () {\n if (this.hls.config.capLevelToPlayerSize) {\n this.media = null;\n this.clientRect = null;\n this.stopCapping();\n }\n }\n\n onFpsDropLevelCapping (data) {\n // Don't add a restricted level more than once\n if (CapLevelController.isLevelAllowed(data.droppedLevel, this.restrictedLevels)) {\n this.restrictedLevels.push(data.droppedLevel);\n }\n }\n\n onMediaAttaching (data) {\n this.media = data.media instanceof window.HTMLVideoElement ? data.media : null;\n }\n\n onManifestParsed (data) {\n const hls = this.hls;\n this.restrictedLevels = [];\n this.levels = data.levels;\n this.firstLevel = data.firstLevel;\n if (hls.config.capLevelToPlayerSize && data.video) {\n // Start capping immediately if the manifest has signaled video codecs\n this.startCapping();\n }\n }\n\n // Only activate capping when playing a video stream; otherwise, multi-bitrate audio-only streams will be restricted\n // to the first level\n onBufferCodecs (data) {\n const hls = this.hls;\n if (hls.config.capLevelToPlayerSize && data.video) {\n // If the manifest did not signal a video codec capping has been deferred until we're certain video is present\n this.startCapping();\n }\n }\n\n onLevelsUpdated (data) {\n this.levels = data.levels;\n }\n\n onMediaDetaching () {\n this.stopCapping();\n }\n\n detectPlayerSize () {\n if (this.media) {\n let levelsLength = this.levels ? this.levels.length : 0;\n if (levelsLength) {\n const hls = this.hls;\n hls.autoLevelCapping = this.getMaxLevel(levelsLength - 1);\n if (hls.autoLevelCapping > this.autoLevelCapping) {\n // if auto level capping has a higher value for the previous one, flush the buffer using nextLevelSwitch\n // usually happen when the user go to the fullscreen mode.\n hls.streamController.nextLevelSwitch();\n }\n this.autoLevelCapping = hls.autoLevelCapping;\n }\n }\n }\n\n /*\n * returns level should be the one with the dimensions equal or greater than the media (player) dimensions (so the video will be downscaled)\n */\n getMaxLevel (capLevelIndex) {\n if (!this.levels) {\n return -1;\n }\n\n const validLevels = this.levels.filter((level, index) =>\n CapLevelController.isLevelAllowed(index, this.restrictedLevels) && index <= capLevelIndex\n );\n\n this.clientRect = null;\n return CapLevelController.getMaxLevelByMediaSize(validLevels, this.mediaWidth, this.mediaHeight);\n }\n\n startCapping () {\n if (this.timer) {\n // Don't reset capping if started twice; this can happen if the manifest signals a video codec\n return;\n }\n this.autoLevelCapping = Number.POSITIVE_INFINITY;\n this.hls.firstLevel = this.getMaxLevel(this.firstLevel);\n clearInterval(this.timer);\n this.timer = setInterval(this.detectPlayerSize.bind(this), 1000);\n this.detectPlayerSize();\n }\n\n stopCapping () {\n this.restrictedLevels = [];\n this.firstLevel = null;\n this.autoLevelCapping = Number.POSITIVE_INFINITY;\n if (this.timer) {\n this.timer = clearInterval(this.timer);\n this.timer = null;\n }\n }\n\n getDimensions () {\n if (this.clientRect) {\n return this.clientRect;\n }\n const media = this.media;\n const boundsRect = {\n width: 0,\n height: 0\n };\n\n if (media) {\n const clientRect = media.getBoundingClientRect();\n boundsRect.width = clientRect.width;\n boundsRect.height = clientRect.height;\n if (!boundsRect.width && !boundsRect.height) {\n // When the media element has no width or height (equivalent to not being in the DOM),\n // then use its width and height attributes (media.width, media.height)\n boundsRect.width = clientRect.right - clientRect.left || media.width || 0;\n boundsRect.height = clientRect.bottom - clientRect.top || media.height || 0;\n }\n }\n this.clientRect = boundsRect;\n return boundsRect;\n }\n\n get mediaWidth () {\n return this.getDimensions().width * CapLevelController.contentScaleFactor;\n }\n\n get mediaHeight () {\n return this.getDimensions().height * CapLevelController.contentScaleFactor;\n }\n\n static get contentScaleFactor () {\n let pixelRatio = 1;\n try {\n pixelRatio = window.devicePixelRatio;\n } catch (e) {}\n return pixelRatio;\n }\n\n static isLevelAllowed (level, restrictedLevels = []) {\n return restrictedLevels.indexOf(level) === -1;\n }\n\n static getMaxLevelByMediaSize (levels, width, height) {\n if (!levels || (levels && !levels.length)) {\n return -1;\n }\n\n // Levels can have the same dimensions but differing bandwidths - since levels are ordered, we can look to the next\n // to determine whether we've chosen the greatest bandwidth for the media's dimensions\n const atGreatestBandiwdth = (curLevel, nextLevel) => {\n if (!nextLevel) {\n return true;\n }\n\n return curLevel.width !== nextLevel.width || curLevel.height !== nextLevel.height;\n };\n\n // If we run through the loop without breaking, the media's dimensions are greater than every level, so default to\n // the max level\n let maxLevelIndex = levels.length - 1;\n\n for (let i = 0; i < levels.length; i += 1) {\n const level = levels[i];\n if ((level.width >= width || level.height >= height) && atGreatestBandiwdth(level, levels[i + 1])) {\n maxLevelIndex = i;\n break;\n }\n }\n\n return maxLevelIndex;\n }\n}\n\nexport default CapLevelController;\n","/*\n * FPS Controller\n*/\n\nimport Event from '../events';\nimport EventHandler from '../event-handler';\nimport { logger } from '../utils/logger';\n\nconst { performance } = window;\n\nclass FPSController extends EventHandler {\n constructor (hls) {\n super(hls, Event.MEDIA_ATTACHING);\n }\n\n destroy () {\n if (this.timer) {\n clearInterval(this.timer);\n }\n\n this.isVideoPlaybackQualityAvailable = false;\n }\n\n onMediaAttaching (data) {\n const config = this.hls.config;\n if (config.capLevelOnFPSDrop) {\n const video = this.video = data.media instanceof window.HTMLVideoElement ? data.media : null;\n if (typeof video.getVideoPlaybackQuality === 'function') {\n this.isVideoPlaybackQualityAvailable = true;\n }\n\n clearInterval(this.timer);\n this.timer = setInterval(this.checkFPSInterval.bind(this), config.fpsDroppedMonitoringPeriod);\n }\n }\n\n checkFPS (video, decodedFrames, droppedFrames) {\n let currentTime = performance.now();\n if (decodedFrames) {\n if (this.lastTime) {\n let currentPeriod = currentTime - this.lastTime,\n currentDropped = droppedFrames - this.lastDroppedFrames,\n currentDecoded = decodedFrames - this.lastDecodedFrames,\n droppedFPS = 1000 * currentDropped / currentPeriod,\n hls = this.hls;\n hls.trigger(Event.FPS_DROP, { currentDropped: currentDropped, currentDecoded: currentDecoded, totalDroppedFrames: droppedFrames });\n if (droppedFPS > 0) {\n // logger.log('checkFPS : droppedFPS/decodedFPS:' + droppedFPS/(1000 * currentDecoded / currentPeriod));\n if (currentDropped > hls.config.fpsDroppedMonitoringThreshold * currentDecoded) {\n let currentLevel = hls.currentLevel;\n logger.warn('drop FPS ratio greater than max allowed value for currentLevel: ' + currentLevel);\n if (currentLevel > 0 && (hls.autoLevelCapping === -1 || hls.autoLevelCapping >= currentLevel)) {\n currentLevel = currentLevel - 1;\n hls.trigger(Event.FPS_DROP_LEVEL_CAPPING, { level: currentLevel, droppedLevel: hls.currentLevel });\n hls.autoLevelCapping = currentLevel;\n hls.streamController.nextLevelSwitch();\n }\n }\n }\n }\n this.lastTime = currentTime;\n this.lastDroppedFrames = droppedFrames;\n this.lastDecodedFrames = decodedFrames;\n }\n }\n\n checkFPSInterval () {\n const video = this.video;\n if (video) {\n if (this.isVideoPlaybackQualityAvailable) {\n let videoPlaybackQuality = video.getVideoPlaybackQuality();\n this.checkFPS(video, videoPlaybackQuality.totalVideoFrames, videoPlaybackQuality.droppedVideoFrames);\n } else {\n this.checkFPS(video, video.webkitDecodedFrameCount, video.webkitDroppedFrameCount);\n }\n }\n }\n}\n\nexport default FPSController;\n","/**\n * XHR based logger\n*/\n\nimport { logger } from '../utils/logger';\n\nclass XhrLoader {\n constructor (config) {\n if (config && config.xhrSetup) {\n this.xhrSetup = config.xhrSetup;\n }\n }\n\n destroy () {\n this.abort();\n this.loader = null;\n }\n\n abort () {\n let loader = this.loader;\n if (loader && loader.readyState !== 4) {\n this.stats.aborted = true;\n loader.abort();\n }\n\n window.clearTimeout(this.requestTimeout);\n this.requestTimeout = null;\n window.clearTimeout(this.retryTimeout);\n this.retryTimeout = null;\n }\n\n load (context, config, callbacks) {\n this.context = context;\n this.config = config;\n this.callbacks = callbacks;\n this.stats = { trequest: window.performance.now(), retry: 0 };\n this.retryDelay = config.retryDelay;\n this.loadInternal();\n }\n\n loadInternal () {\n let xhr, context = this.context;\n xhr = this.loader = new window.XMLHttpRequest();\n\n let stats = this.stats;\n stats.tfirst = 0;\n stats.loaded = 0;\n const xhrSetup = this.xhrSetup;\n\n try {\n if (xhrSetup) {\n try {\n xhrSetup(xhr, context.url);\n } catch (e) {\n // fix xhrSetup: (xhr, url) => {xhr.setRequestHeader(\"Content-Language\", \"test\");}\n // not working, as xhr.setRequestHeader expects xhr.readyState === OPEN\n xhr.open('GET', context.url, true);\n xhrSetup(xhr, context.url);\n }\n }\n if (!xhr.readyState) {\n xhr.open('GET', context.url, true);\n }\n } catch (e) {\n // IE11 throws an exception on xhr.open if attempting to access an HTTP resource over HTTPS\n this.callbacks.onError({ code: xhr.status, text: e.message }, context, xhr);\n return;\n }\n\n if (context.rangeEnd) {\n xhr.setRequestHeader('Range', 'bytes=' + context.rangeStart + '-' + (context.rangeEnd - 1));\n }\n\n xhr.onreadystatechange = this.readystatechange.bind(this);\n xhr.onprogress = this.loadprogress.bind(this);\n xhr.responseType = context.responseType;\n\n // setup timeout before we perform request\n this.requestTimeout = window.setTimeout(this.loadtimeout.bind(this), this.config.timeout);\n xhr.send();\n }\n\n readystatechange (event) {\n let xhr = event.currentTarget,\n readyState = xhr.readyState,\n stats = this.stats,\n context = this.context,\n config = this.config;\n\n // don't proceed if xhr has been aborted\n if (stats.aborted) {\n return;\n }\n\n // >= HEADERS_RECEIVED\n if (readyState >= 2) {\n // clear xhr timeout and rearm it if readyState less than 4\n window.clearTimeout(this.requestTimeout);\n if (stats.tfirst === 0) {\n stats.tfirst = Math.max(window.performance.now(), stats.trequest);\n }\n\n if (readyState === 4) {\n let status = xhr.status;\n // http status between 200 to 299 are all successful\n if (status >= 200 && status < 300) {\n stats.tload = Math.max(stats.tfirst, window.performance.now());\n let data, len;\n if (context.responseType === 'arraybuffer') {\n data = xhr.response;\n len = data.byteLength;\n } else {\n data = xhr.responseText;\n len = data.length;\n }\n stats.loaded = stats.total = len;\n let response = { url: xhr.responseURL, data: data };\n this.callbacks.onSuccess(response, stats, context, xhr);\n } else {\n // if max nb of retries reached or if http status between 400 and 499 (such error cannot be recovered, retrying is useless), return error\n if (stats.retry >= config.maxRetry || (status >= 400 && status < 499)) {\n logger.error(`${status} while loading ${context.url}`);\n this.callbacks.onError({ code: status, text: xhr.statusText }, context, xhr);\n } else {\n // retry\n logger.warn(`${status} while loading ${context.url}, retrying in ${this.retryDelay}...`);\n // aborts and resets internal state\n this.destroy();\n // schedule retry\n this.retryTimeout = window.setTimeout(this.loadInternal.bind(this), this.retryDelay);\n // set exponential backoff\n this.retryDelay = Math.min(2 * this.retryDelay, config.maxRetryDelay);\n stats.retry++;\n }\n }\n } else {\n // readyState >= 2 AND readyState !==4 (readyState = HEADERS_RECEIVED || LOADING) rearm timeout as xhr not finished yet\n this.requestTimeout = window.setTimeout(this.loadtimeout.bind(this), config.timeout);\n }\n }\n }\n\n loadtimeout () {\n logger.warn(`timeout while loading ${this.context.url}`);\n this.callbacks.onTimeout(this.stats, this.context, null);\n }\n\n loadprogress (event) {\n let xhr = event.currentTarget,\n stats = this.stats;\n\n stats.loaded = event.loaded;\n if (event.lengthComputable) {\n stats.total = event.total;\n }\n\n let onProgress = this.callbacks.onProgress;\n if (onProgress) {\n // third arg is to provide on progress data\n onProgress(stats, this.context, null, xhr);\n }\n }\n}\n\nexport default XhrLoader;\n","import Event from '../events';\nimport TaskLoop from '../task-loop';\nimport { logger } from '../utils/logger';\nimport { ErrorTypes, ErrorDetails } from '../errors';\n\n/**\n * @class AudioTrackController\n * @implements {EventHandler}\n *\n * Handles main manifest and audio-track metadata loaded,\n * owns and exposes the selectable audio-tracks data-models.\n *\n * Exposes internal interface to select available audio-tracks.\n *\n * Handles errors on loading audio-track playlists. Manages fallback mechanism\n * with redundants tracks (group-IDs).\n *\n * Handles level-loading and group-ID switches for video (fallback on video levels),\n * and eventually adapts the audio-track group-ID to match.\n *\n * @fires AUDIO_TRACK_LOADING\n * @fires AUDIO_TRACK_SWITCHING\n * @fires AUDIO_TRACKS_UPDATED\n * @fires ERROR\n *\n */\nclass AudioTrackController extends TaskLoop {\n constructor (hls) {\n super(hls,\n Event.MANIFEST_LOADING,\n Event.MANIFEST_PARSED,\n Event.AUDIO_TRACK_LOADED,\n Event.AUDIO_TRACK_SWITCHED,\n Event.LEVEL_LOADED,\n Event.ERROR\n );\n\n /**\n * @private\n * Currently selected index in `tracks`\n * @member {number} trackId\n */\n this._trackId = -1;\n\n /**\n * @private\n * If should select tracks according to default track attribute\n * @member {boolean} _selectDefaultTrack\n */\n this._selectDefaultTrack = true;\n\n /**\n * @public\n * All tracks available\n * @member {AudioTrack[]}\n */\n this.tracks = [];\n\n /**\n * @public\n * List of blacklisted audio track IDs (that have caused failure)\n * @member {number[]}\n */\n this.trackIdBlacklist = Object.create(null);\n\n /**\n * @public\n * The currently running group ID for audio\n * (we grab this on manifest-parsed and new level-loaded)\n * @member {string}\n */\n this.audioGroupId = null;\n }\n\n /**\n * Reset audio tracks on new manifest loading.\n */\n onManifestLoading () {\n this.tracks = [];\n this._trackId = -1;\n this._selectDefaultTrack = true;\n }\n\n /**\n * Store tracks data from manifest parsed data.\n *\n * Trigger AUDIO_TRACKS_UPDATED event.\n *\n * @param {*} data\n */\n onManifestParsed (data) {\n const tracks = this.tracks = data.audioTracks || [];\n this.hls.trigger(Event.AUDIO_TRACKS_UPDATED, { audioTracks: tracks });\n\n this._selectAudioGroup(this.hls.nextLoadLevel);\n }\n\n /**\n * Store track details of loaded track in our data-model.\n *\n * Set-up metadata update interval task for live-mode streams.\n *\n * @param {*} data\n */\n onAudioTrackLoaded (data) {\n if (data.id >= this.tracks.length) {\n logger.warn('Invalid audio track id:', data.id);\n return;\n }\n\n logger.log(`audioTrack ${data.id} loaded`);\n\n this.tracks[data.id].details = data.details;\n\n // check if current playlist is a live playlist\n // and if we have already our reload interval setup\n if (data.details.live && !this.hasInterval()) {\n // if live playlist we will have to reload it periodically\n // set reload period to playlist target duration\n const updatePeriodMs = data.details.targetduration * 1000;\n this.setInterval(updatePeriodMs);\n }\n\n if (!data.details.live && this.hasInterval()) {\n // playlist is not live and timer is scheduled: cancel it\n this.clearInterval();\n }\n }\n\n /**\n * Update the internal group ID to any audio-track we may have set manually\n * or because of a failure-handling fallback.\n *\n * Quality-levels should update to that group ID in this case.\n *\n * @param {*} data\n */\n onAudioTrackSwitched (data) {\n const audioGroupId = this.tracks[data.id].groupId;\n if (audioGroupId && (this.audioGroupId !== audioGroupId)) {\n this.audioGroupId = audioGroupId;\n }\n }\n\n /**\n * When a level gets loaded, if it has redundant audioGroupIds (in the same ordinality as it's redundant URLs)\n * we are setting our audio-group ID internally to the one set, if it is different from the group ID currently set.\n *\n * If group-ID got update, we re-select the appropriate audio-track with this group-ID matching the currently\n * selected one (based on NAME property).\n *\n * @param {*} data\n */\n onLevelLoaded (data) {\n this._selectAudioGroup(data.level);\n }\n\n /**\n * Handle network errors loading audio track manifests\n * and also pausing on any netwok errors.\n *\n * @param {ErrorEventData} data\n */\n onError (data) {\n // Only handle network errors\n if (data.type !== ErrorTypes.NETWORK_ERROR) {\n return;\n }\n\n // If fatal network error, cancel update task\n if (data.fatal) {\n this.clearInterval();\n }\n\n // If not an audio-track loading error don't handle further\n if (data.details !== ErrorDetails.AUDIO_TRACK_LOAD_ERROR) {\n return;\n }\n\n logger.warn('Network failure on audio-track id:', data.context.id);\n this._handleLoadError();\n }\n\n /**\n * @type {AudioTrack[]} Audio-track list we own\n */\n get audioTracks () {\n return this.tracks;\n }\n\n /**\n * @type {number} Index into audio-tracks list of currently selected track.\n */\n get audioTrack () {\n return this._trackId;\n }\n\n /**\n * Select current track by index\n */\n set audioTrack (newId) {\n this._setAudioTrack(newId);\n // If audio track is selected from API then don't choose from the manifest default track\n this._selectDefaultTrack = false;\n }\n\n /**\n * @private\n * @param {number} newId\n */\n _setAudioTrack (newId) {\n // noop on same audio track id as already set\n if (this._trackId === newId && this.tracks[this._trackId].details) {\n logger.debug('Same id as current audio-track passed, and track details available -> no-op');\n return;\n }\n\n // check if level idx is valid\n if (newId < 0 || newId >= this.tracks.length) {\n logger.warn('Invalid id passed to audio-track controller');\n return;\n }\n\n const audioTrack = this.tracks[newId];\n\n logger.log(`Now switching to audio-track index ${newId}`);\n\n // stopping live reloading timer if any\n this.clearInterval();\n this._trackId = newId;\n\n const { url, type, id } = audioTrack;\n this.hls.trigger(Event.AUDIO_TRACK_SWITCHING, { id, type, url });\n this._loadTrackDetailsIfNeeded(audioTrack);\n }\n\n /**\n * @override\n */\n doTick () {\n this._updateTrack(this._trackId);\n }\n\n /**\n * @param levelId\n * @private\n */\n _selectAudioGroup (levelId) {\n const levelInfo = this.hls.levels[levelId];\n\n if (!levelInfo || !levelInfo.audioGroupIds) {\n return;\n }\n\n const audioGroupId = levelInfo.audioGroupIds[levelInfo.urlId];\n if (this.audioGroupId !== audioGroupId) {\n this.audioGroupId = audioGroupId;\n this._selectInitialAudioTrack();\n }\n }\n\n /**\n * Select initial track\n * @private\n */\n _selectInitialAudioTrack () {\n let tracks = this.tracks;\n if (!tracks.length) {\n return;\n }\n\n const currentAudioTrack = this.tracks[this._trackId];\n\n let name = null;\n if (currentAudioTrack) {\n name = currentAudioTrack.name;\n }\n\n // Pre-select default tracks if there are any\n if (this._selectDefaultTrack) {\n const defaultTracks = tracks.filter((track) => track.default);\n if (defaultTracks.length) {\n tracks = defaultTracks;\n } else {\n logger.warn('No default audio tracks defined');\n }\n }\n\n let trackFound = false;\n\n const traverseTracks = () => {\n // Select track with right group ID\n tracks.forEach((track) => {\n if (trackFound) {\n return;\n }\n // We need to match the (pre-)selected group ID\n // and the NAME of the current track.\n if ((!this.audioGroupId || track.groupId === this.audioGroupId) &&\n (!name || name === track.name)) {\n // If there was a previous track try to stay with the same `NAME`.\n // It should be unique across tracks of same group, and consistent through redundant track groups.\n this._setAudioTrack(track.id);\n trackFound = true;\n }\n });\n };\n\n traverseTracks();\n\n if (!trackFound) {\n name = null;\n traverseTracks();\n }\n\n if (!trackFound) {\n logger.error(`No track found for running audio group-ID: ${this.audioGroupId}`);\n\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.MEDIA_ERROR,\n details: ErrorDetails.AUDIO_TRACK_LOAD_ERROR,\n fatal: true\n });\n }\n }\n\n /**\n * @private\n * @param {AudioTrack} audioTrack\n * @returns {boolean}\n */\n _needsTrackLoading (audioTrack) {\n const { details, url } = audioTrack;\n\n if (!details || details.live) {\n // check if we face an audio track embedded in main playlist (audio track without URI attribute)\n return !!url;\n }\n\n return false;\n }\n\n /**\n * @private\n * @param {AudioTrack} audioTrack\n */\n _loadTrackDetailsIfNeeded (audioTrack) {\n if (this._needsTrackLoading(audioTrack)) {\n const { url, id } = audioTrack;\n // track not retrieved yet, or live playlist we need to (re)load it\n logger.log(`loading audio-track playlist for id: ${id}`);\n this.hls.trigger(Event.AUDIO_TRACK_LOADING, { url, id });\n }\n }\n\n /**\n * @private\n * @param {number} newId\n */\n _updateTrack (newId) {\n // check if level idx is valid\n if (newId < 0 || newId >= this.tracks.length) {\n return;\n }\n\n // stopping live reloading timer if any\n this.clearInterval();\n this._trackId = newId;\n logger.log(`trying to update audio-track ${newId}`);\n const audioTrack = this.tracks[newId];\n this._loadTrackDetailsIfNeeded(audioTrack);\n }\n\n /**\n * @private\n */\n _handleLoadError () {\n // First, let's black list current track id\n this.trackIdBlacklist[this._trackId] = true;\n\n // Let's try to fall back on a functional audio-track with the same group ID\n const previousId = this._trackId;\n const { name, language, groupId } = this.tracks[previousId];\n\n logger.warn(`Loading failed on audio track id: ${previousId}, group-id: ${groupId}, name/language: \"${name}\" / \"${language}\"`);\n\n // Find a non-blacklisted track ID with the same NAME\n // At least a track that is not blacklisted, thus on another group-ID.\n let newId = previousId;\n for (let i = 0; i < this.tracks.length; i++) {\n if (this.trackIdBlacklist[i]) {\n continue;\n }\n const newTrack = this.tracks[i];\n if (newTrack.name === name) {\n newId = i;\n break;\n }\n }\n\n if (newId === previousId) {\n logger.warn(`No fallback audio-track found for name/language: \"${name}\" / \"${language}\"`);\n return;\n }\n\n logger.log('Attempting audio-track fallback id:', newId, 'group-id:', this.tracks[newId].groupId);\n\n this._setAudioTrack(newId);\n }\n}\n\nexport default AudioTrackController;\n","/*\n * Audio Stream Controller\n*/\n\nimport BinarySearch from '../utils/binary-search';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport Demuxer from '../demux/demuxer';\nimport Event from '../events';\nimport * as LevelHelper from './level-helper';\nimport TimeRanges from '../utils/time-ranges';\nimport { ErrorTypes, ErrorDetails } from '../errors';\nimport { logger } from '../utils/logger';\nimport { findFragWithCC } from '../utils/discontinuities';\nimport { FragmentState } from './fragment-tracker';\nimport { ElementaryStreamTypes } from '../loader/fragment';\nimport BaseStreamController, { State } from './base-stream-controller';\nimport { MAX_START_GAP_JUMP } from './gap-controller';\nimport { fragmentWithinToleranceTest } from './fragment-finders';\n\nconst { performance } = window;\n\nconst TICK_INTERVAL = 100; // how often to tick in ms\n\nclass AudioStreamController extends BaseStreamController {\n constructor (hls, fragmentTracker) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.AUDIO_TRACKS_UPDATED,\n Event.AUDIO_TRACK_SWITCHING,\n Event.AUDIO_TRACK_LOADED,\n Event.KEY_LOADED,\n Event.FRAG_LOADED,\n Event.FRAG_PARSING_INIT_SEGMENT,\n Event.FRAG_PARSING_DATA,\n Event.FRAG_PARSED,\n Event.ERROR,\n Event.BUFFER_RESET,\n Event.BUFFER_CREATED,\n Event.BUFFER_APPENDED,\n Event.BUFFER_FLUSHED,\n Event.INIT_PTS_FOUND);\n this.fragmentTracker = fragmentTracker;\n this.config = hls.config;\n this.audioCodecSwap = false;\n this._state = State.STOPPED;\n this.initPTS = [];\n this.waitingFragment = null;\n this.videoTrackCC = null;\n this.waitingVideoCC = null;\n }\n\n // Signal that video PTS was found\n onInitPtsFound (data) {\n let demuxerId = data.id, cc = data.frag.cc, initPTS = data.initPTS;\n if (demuxerId === 'main') {\n // Always update the new INIT PTS\n // Can change due level switch\n this.initPTS[cc] = initPTS;\n this.videoTrackCC = cc;\n logger.log(`InitPTS for cc: ${cc} found from main: ${initPTS}`);\n\n // If we are waiting we need to demux/remux the waiting frag\n // With the new initPTS\n if (this.state === State.WAITING_INIT_PTS) {\n this.tick();\n }\n }\n }\n\n startLoad (startPosition) {\n if (this.tracks) {\n let lastCurrentTime = this.lastCurrentTime;\n this.stopLoad();\n this.setInterval(TICK_INTERVAL);\n this.fragLoadError = 0;\n if (lastCurrentTime > 0 && startPosition === -1) {\n logger.log(`audio:override startPosition with lastCurrentTime @${lastCurrentTime.toFixed(3)}`);\n this.state = State.IDLE;\n } else {\n this.lastCurrentTime = this.startPosition ? this.startPosition : startPosition;\n this.state = State.STARTING;\n }\n this.nextLoadPosition = this.startPosition = this.lastCurrentTime;\n this.tick();\n } else {\n this.startPosition = startPosition;\n this.state = State.STOPPED;\n }\n }\n\n set state (nextState) {\n if (this.state !== nextState) {\n const previousState = this.state;\n this._state = nextState;\n logger.log(`audio stream:${previousState}->${nextState}`);\n }\n }\n\n get state () {\n return this._state;\n }\n\n doTick () {\n let pos, track, trackDetails, hls = this.hls, config = hls.config;\n // logger.log('audioStream:' + this.state);\n switch (this.state) {\n case State.ERROR:\n // don't do anything in error state to avoid breaking further ...\n case State.PAUSED:\n // don't do anything in paused state either ...\n case State.BUFFER_FLUSHING:\n break;\n case State.STARTING:\n this.state = State.WAITING_TRACK;\n this.loadedmetadata = false;\n break;\n case State.IDLE:\n const tracks = this.tracks;\n // audio tracks not received => exit loop\n if (!tracks) {\n break;\n }\n\n // if video not attached AND\n // start fragment already requested OR start frag prefetch disable\n // exit loop\n // => if media not attached but start frag prefetch is enabled and start frag not requested yet, we will not exit loop\n if (!this.media &&\n (this.startFragRequested || !config.startFragPrefetch)) {\n break;\n }\n\n // determine next candidate fragment to be loaded, based on current position and\n // end of buffer position\n // if we have not yet loaded any fragment, start loading from start position\n if (this.loadedmetadata) {\n pos = this.media.currentTime;\n } else {\n pos = this.nextLoadPosition;\n if (pos === undefined) {\n break;\n }\n }\n let media = this.mediaBuffer ? this.mediaBuffer : this.media;\n const videoBuffer = this.videoBuffer ? this.videoBuffer : this.media;\n const maxBufferHole = pos < config.maxBufferHole ? Math.max(MAX_START_GAP_JUMP, config.maxBufferHole) : config.maxBufferHole;\n const bufferInfo = BufferHelper.bufferInfo(media, pos, maxBufferHole);\n const mainBufferInfo = BufferHelper.bufferInfo(videoBuffer, pos, maxBufferHole);\n const bufferLen = bufferInfo.len;\n let bufferEnd = bufferInfo.end;\n const fragPrevious = this.fragPrevious;\n // ensure we buffer at least config.maxBufferLength (default 30s) or config.maxMaxBufferLength (default: 600s)\n // whichever is smaller.\n // once we reach that threshold, don't buffer more than video (mainBufferInfo.len)\n const maxConfigBuffer = Math.min(config.maxBufferLength, config.maxMaxBufferLength);\n const maxBufLen = Math.max(maxConfigBuffer, mainBufferInfo.len);\n const audioSwitch = this.audioSwitch;\n const trackId = this.trackId;\n\n // if buffer length is less than maxBufLen try to load a new fragment\n if ((bufferLen < maxBufLen || audioSwitch) && trackId < tracks.length) {\n trackDetails = tracks[trackId].details;\n // if track info not retrieved yet, switch state and wait for track retrieval\n if (typeof trackDetails === 'undefined') {\n this.state = State.WAITING_TRACK;\n break;\n }\n\n if (!audioSwitch && this._streamEnded(bufferInfo, trackDetails)) {\n this.hls.trigger(Event.BUFFER_EOS, { type: 'audio' });\n this.state = State.ENDED;\n return;\n }\n\n // find fragment index, contiguous with end of buffer position\n let fragments = trackDetails.fragments,\n fragLen = fragments.length,\n start = fragments[0].start,\n end = fragments[fragLen - 1].start + fragments[fragLen - 1].duration,\n frag;\n\n // When switching audio track, reload audio as close as possible to currentTime\n if (audioSwitch) {\n if (trackDetails.live && !trackDetails.PTSKnown) {\n logger.log('switching audiotrack, live stream, unknown PTS,load first fragment');\n bufferEnd = 0;\n } else {\n bufferEnd = pos;\n // if currentTime (pos) is less than alt audio playlist start time, it means that alt audio is ahead of currentTime\n if (trackDetails.PTSKnown && pos < start) {\n // if everything is buffered from pos to start or if audio buffer upfront, let's seek to start\n if (bufferInfo.end > start || bufferInfo.nextStart) {\n logger.log('alt audio track ahead of main track, seek to start of alt audio track');\n this.media.currentTime = start + 0.05;\n } else {\n return;\n }\n }\n }\n }\n if (trackDetails.initSegment && !trackDetails.initSegment.data) {\n frag = trackDetails.initSegment;\n } // eslint-disable-line brace-style\n // if bufferEnd before start of playlist, load first fragment\n else if (bufferEnd <= start) {\n frag = fragments[0];\n if (this.videoTrackCC !== null && frag.cc !== this.videoTrackCC) {\n // Ensure we find a fragment which matches the continuity of the video track\n frag = findFragWithCC(fragments, this.videoTrackCC);\n }\n if (trackDetails.live && frag.loadIdx && frag.loadIdx === this.fragLoadIdx) {\n // we just loaded this first fragment, and we are still lagging behind the start of the live playlist\n // let's force seek to start\n const nextBuffered = bufferInfo.nextStart ? bufferInfo.nextStart : start;\n logger.log(`no alt audio available @currentTime:${this.media.currentTime}, seeking @${nextBuffered + 0.05}`);\n this.media.currentTime = nextBuffered + 0.05;\n return;\n }\n } else {\n let foundFrag;\n let maxFragLookUpTolerance = config.maxFragLookUpTolerance;\n const fragNext = fragPrevious ? fragments[fragPrevious.sn - fragments[0].sn + 1] : undefined;\n\n if (bufferEnd < end) {\n if (bufferEnd > end - maxFragLookUpTolerance) {\n maxFragLookUpTolerance = 0;\n }\n\n // Prefer the next fragment if it's within tolerance\n if (fragNext && !fragmentWithinToleranceTest(bufferEnd, maxFragLookUpTolerance, fragNext)) {\n foundFrag = fragNext;\n } else {\n foundFrag = BinarySearch.search(fragments, (frag) => fragmentWithinToleranceTest(bufferEnd, maxFragLookUpTolerance, frag));\n }\n } else {\n // reach end of playlist\n foundFrag = fragments[fragLen - 1];\n }\n if (foundFrag) {\n frag = foundFrag;\n start = foundFrag.start;\n // logger.log('find SN matching with pos:' + bufferEnd + ':' + frag.sn);\n if (fragPrevious && frag.level === fragPrevious.level && frag.sn === fragPrevious.sn) {\n if (frag.sn < trackDetails.endSN) {\n frag = fragments[frag.sn + 1 - trackDetails.startSN];\n if (this.fragmentTracker.getState(frag) !== FragmentState.OK) {\n logger.log(`SN just loaded, load next one: ${frag.sn}`);\n }\n } else {\n frag = null;\n }\n }\n }\n }\n if (frag) {\n // logger.log(' loading frag ' + i +',pos/bufEnd:' + pos.toFixed(3) + '/' + bufferEnd.toFixed(3));\n if (frag.encrypted) {\n logger.log(`Loading key for ${frag.sn} of [${trackDetails.startSN} ,${trackDetails.endSN}],track ${trackId}`);\n this.state = State.KEY_LOADING;\n hls.trigger(Event.KEY_LOADING, { frag: frag });\n } else {\n // only load if fragment is not loaded or if in audio switch\n // we force a frag loading in audio switch as fragment tracker might not have evicted previous frags in case of quick audio switch\n this.fragCurrent = frag;\n if (audioSwitch || this.fragmentTracker.getState(frag) === FragmentState.NOT_LOADED) {\n logger.log(`Loading ${frag.sn}, cc: ${frag.cc} of [${trackDetails.startSN} ,${trackDetails.endSN}],track ${trackId}, ${\n this.loadedmetadata ? 'currentTime' : 'nextLoadPosition'\n }: ${pos}, bufferEnd: ${bufferEnd.toFixed(3)}`);\n\n if (frag.sn !== 'initSegment') {\n this.startFragRequested = true;\n }\n if (Number.isFinite(frag.sn)) {\n this.nextLoadPosition = frag.start + frag.duration;\n }\n\n hls.trigger(Event.FRAG_LOADING, { frag });\n this.state = State.FRAG_LOADING;\n }\n }\n }\n }\n break;\n case State.WAITING_TRACK:\n track = this.tracks[this.trackId];\n // check if playlist is already loaded\n if (track && track.details) {\n this.state = State.IDLE;\n }\n\n break;\n case State.FRAG_LOADING_WAITING_RETRY:\n var now = performance.now();\n var retryDate = this.retryDate;\n media = this.media;\n var isSeeking = media && media.seeking;\n // if current time is gt than retryDate, or if media seeking let's switch to IDLE state to retry loading\n if (!retryDate || (now >= retryDate) || isSeeking) {\n logger.log('audioStreamController: retryDate reached, switch back to IDLE state');\n this.state = State.IDLE;\n }\n break;\n case State.WAITING_INIT_PTS:\n // Ensure we don't get stuck in the WAITING_INIT_PTS state if the waiting frag CC doesn't match any initPTS\n const waitingFrag = this.waitingFragment;\n if (waitingFrag) {\n const waitingFragCC = waitingFrag.frag.cc;\n if (this.initPTS[waitingFragCC] !== undefined) {\n this.waitingFragment = null;\n this.state = State.FRAG_LOADING;\n this.onFragLoaded(waitingFrag);\n } else if (this.videoTrackCC !== this.waitingVideoCC) {\n // Drop waiting fragment if videoTrackCC has changed since waitingFragment was set and initPTS was not found\n logger.log(`Waiting fragment cc (${waitingFragCC}) cancelled because video is at cc ${this.videoTrackCC}`);\n this.clearWaitingFragment();\n } else {\n // Drop waiting fragment if an earlier fragment is needed\n const bufferInfo = BufferHelper.bufferInfo(this.mediaBuffer, this.media.currentTime, config.maxBufferHole);\n const waitingFragmentAtPosition = fragmentWithinToleranceTest(bufferInfo.end, config.maxFragLookUpTolerance, waitingFrag.frag);\n if (waitingFragmentAtPosition < 0) {\n logger.log(`Waiting fragment cc (${waitingFragCC}) @ ${waitingFrag.frag.start} cancelled because another fragment at ${bufferInfo.end} is needed`);\n this.clearWaitingFragment();\n }\n }\n } else {\n this.state = State.IDLE;\n }\n\n break;\n case State.STOPPED:\n case State.FRAG_LOADING:\n case State.PARSING:\n case State.PARSED:\n case State.ENDED:\n break;\n default:\n break;\n }\n }\n\n clearWaitingFragment () {\n const waitingFrag = this.waitingFragment;\n if (waitingFrag) {\n this.fragmentTracker.removeFragment(waitingFrag.frag);\n this.waitingFragment = null;\n this.waitingVideoCC = null;\n this.state = State.IDLE;\n }\n }\n\n onMediaAttached (data) {\n let media = this.media = this.mediaBuffer = data.media;\n this.onvseeking = this.onMediaSeeking.bind(this);\n this.onvended = this.onMediaEnded.bind(this);\n media.addEventListener('seeking', this.onvseeking);\n media.addEventListener('ended', this.onvended);\n let config = this.config;\n if (this.tracks && config.autoStartLoad) {\n this.startLoad(config.startPosition);\n }\n }\n\n onMediaDetaching () {\n let media = this.media;\n if (media && media.ended) {\n logger.log('MSE detaching and video ended, reset startPosition');\n this.startPosition = this.lastCurrentTime = 0;\n }\n\n // remove video listeners\n if (media) {\n media.removeEventListener('seeking', this.onvseeking);\n media.removeEventListener('ended', this.onvended);\n this.onvseeking = this.onvseeked = this.onvended = null;\n }\n this.media = this.mediaBuffer = this.videoBuffer = null;\n this.loadedmetadata = false;\n this.fragmentTracker.removeAllFragments();\n this.stopLoad();\n }\n\n onAudioTracksUpdated (data) {\n logger.log('audio tracks updated');\n this.tracks = data.audioTracks;\n }\n\n onAudioTrackSwitching (data) {\n // if any URL found on new audio track, it is an alternate audio track\n let altAudio = !!data.url;\n this.trackId = data.id;\n\n this.fragCurrent = null;\n this.clearWaitingFragment();\n this.state = State.PAUSED;\n // destroy useless demuxer when switching audio to main\n if (!altAudio) {\n if (this.demuxer) {\n this.demuxer.destroy();\n this.demuxer = null;\n }\n } else {\n // switching to audio track, start timer if not already started\n this.setInterval(TICK_INTERVAL);\n }\n\n // should we switch tracks ?\n if (altAudio) {\n this.audioSwitch = true;\n // main audio track are handled by stream-controller, just do something if switching to alt audio track\n this.state = State.IDLE;\n }\n this.tick();\n }\n\n onAudioTrackLoaded (data) {\n let newDetails = data.details,\n trackId = data.id,\n track = this.tracks[trackId],\n curDetails = track.details,\n duration = newDetails.totalduration,\n sliding = 0;\n\n logger.log(`track ${trackId} loaded [${newDetails.startSN},${newDetails.endSN}],duration:${duration}`);\n\n if (newDetails.live || (curDetails && curDetails.live)) {\n if (curDetails && newDetails.fragments.length > 0) {\n // we already have details for that level, merge them\n LevelHelper.mergeDetails(curDetails, newDetails);\n sliding = newDetails.fragments[0].start;\n // TODO\n // this.liveSyncPosition = this.computeLivePosition(sliding, curDetails);\n if (newDetails.PTSKnown) {\n logger.log(`live audio playlist sliding:${sliding.toFixed(3)}`);\n } else {\n logger.log('live audio playlist - outdated PTS, unknown sliding');\n }\n } else {\n newDetails.PTSKnown = false;\n logger.log('live audio playlist - first load, unknown sliding');\n }\n } else {\n newDetails.PTSKnown = false;\n }\n track.details = newDetails;\n\n // compute start position\n if (!this.startFragRequested) {\n // compute start position if set to -1. use it straight away if value is defined\n if (this.startPosition === -1) {\n // first, check if start time offset has been set in playlist, if yes, use this value\n let startTimeOffset = newDetails.startTimeOffset;\n if (Number.isFinite(startTimeOffset)) {\n logger.log(`start time offset found in playlist, adjust startPosition to ${startTimeOffset}`);\n this.startPosition = startTimeOffset;\n } else {\n if (newDetails.live) {\n this.startPosition = this.computeLivePosition(sliding, newDetails);\n logger.log(`compute startPosition for audio-track to ${this.startPosition}`);\n } else {\n this.startPosition = 0;\n }\n }\n }\n this.nextLoadPosition = this.startPosition;\n }\n // only switch batck to IDLE state if we were waiting for track to start downloading a new fragment\n if (this.state === State.WAITING_TRACK) {\n this.state = State.IDLE;\n }\n\n // trigger handler right now\n this.tick();\n }\n\n onKeyLoaded () {\n if (this.state === State.KEY_LOADING) {\n this.state = State.IDLE;\n this.tick();\n }\n }\n\n onFragLoaded (data) {\n let fragCurrent = this.fragCurrent,\n fragLoaded = data.frag;\n if (this.state === State.FRAG_LOADING &&\n fragCurrent &&\n fragLoaded.type === 'audio' &&\n fragLoaded.level === fragCurrent.level &&\n fragLoaded.sn === fragCurrent.sn) {\n let track = this.tracks[this.trackId],\n details = track.details,\n duration = details.totalduration,\n trackId = fragCurrent.level,\n sn = fragCurrent.sn,\n cc = fragCurrent.cc,\n audioCodec = this.config.defaultAudioCodec || track.audioCodec || 'mp4a.40.2',\n stats = this.stats = data.stats;\n if (sn === 'initSegment') {\n this.state = State.IDLE;\n\n stats.tparsed = stats.tbuffered = performance.now();\n details.initSegment.data = data.payload;\n this.hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: fragCurrent, id: 'audio' });\n this.tick();\n } else {\n this.state = State.PARSING;\n // transmux the MPEG-TS data to ISO-BMFF segments\n this.appended = false;\n if (!this.demuxer) {\n this.demuxer = new Demuxer(this.hls, 'audio');\n }\n\n // Check if we have video initPTS\n // If not we need to wait for it\n let initPTS = this.initPTS[cc];\n let initSegmentData = details.initSegment ? details.initSegment.data : [];\n if (initPTS !== undefined) {\n this.pendingBuffering = true;\n logger.log(`Demuxing ${sn} of [${details.startSN} ,${details.endSN}],track ${trackId}`);\n // time Offset is accurate if level PTS is known, or if playlist is not sliding (not live)\n let accurateTimeOffset = false; // details.PTSKnown || !details.live;\n this.demuxer.push(data.payload, initSegmentData, audioCodec, null, fragCurrent, duration, accurateTimeOffset, initPTS);\n } else {\n logger.log(`Unknown video PTS for cc ${cc}, waiting for video PTS before demuxing audio frag ${sn} of [${details.startSN} ,${details.endSN}],track ${trackId}`);\n this.waitingFragment = data;\n this.waitingVideoCC = this.videoTrackCC;\n this.state = State.WAITING_INIT_PTS;\n }\n }\n }\n this.fragLoadError = 0;\n }\n\n onFragParsingInitSegment (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'audio' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n let tracks = data.tracks, track;\n\n // delete any video track found on audio demuxer\n if (tracks.video) {\n delete tracks.video;\n }\n\n // include levelCodec in audio and video tracks\n track = tracks.audio;\n if (track) {\n track.levelCodec = track.codec;\n track.id = data.id;\n this.hls.trigger(Event.BUFFER_CODECS, tracks);\n logger.log(`audio track:audio,container:${track.container},codecs[level/parsed]=[${track.levelCodec}/${track.codec}]`);\n let initSegment = track.initSegment;\n if (initSegment) {\n let appendObj = { type: 'audio', data: initSegment, parent: 'audio', content: 'initSegment' };\n if (this.audioSwitch) {\n this.pendingData = [appendObj];\n } else {\n this.appended = true;\n // arm pending Buffering flag before appending a segment\n this.pendingBuffering = true;\n this.hls.trigger(Event.BUFFER_APPENDING, appendObj);\n }\n }\n // trigger handler right now\n this.tick();\n }\n }\n }\n\n onFragParsingData (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'audio' &&\n data.type === 'audio' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n let trackId = this.trackId,\n track = this.tracks[trackId],\n hls = this.hls;\n\n if (!Number.isFinite(data.endPTS)) {\n data.endPTS = data.startPTS + fragCurrent.duration;\n data.endDTS = data.startDTS + fragCurrent.duration;\n }\n\n fragCurrent.addElementaryStream(ElementaryStreamTypes.AUDIO);\n\n logger.log(`parsed ${data.type},PTS:[${data.startPTS.toFixed(3)},${data.endPTS.toFixed(3)}],DTS:[${data.startDTS.toFixed(3)}/${data.endDTS.toFixed(3)}],nb:${data.nb}`);\n LevelHelper.updateFragPTSDTS(track.details, fragCurrent, data.startPTS, data.endPTS);\n\n const media = this.media;\n let appendOnBufferFlush = false;\n // Only flush audio from old audio tracks when PTS is known on new audio track\n if (this.audioSwitch) {\n if (media && media.readyState) {\n let currentTime = media.currentTime;\n logger.log('switching audio track : currentTime:' + currentTime);\n if (currentTime >= data.startPTS) {\n logger.log('switching audio track : flushing all audio');\n this.state = State.BUFFER_FLUSHING;\n hls.trigger(Event.BUFFER_FLUSHING, { startOffset: 0, endOffset: Number.POSITIVE_INFINITY, type: 'audio' });\n appendOnBufferFlush = true;\n // Lets announce that the initial audio track switch flush occur\n this.audioSwitch = false;\n hls.trigger(Event.AUDIO_TRACK_SWITCHED, { id: trackId });\n }\n } else {\n // Lets announce that the initial audio track switch flush occur\n this.audioSwitch = false;\n hls.trigger(Event.AUDIO_TRACK_SWITCHED, { id: trackId });\n }\n }\n\n let pendingData = this.pendingData;\n\n if (!pendingData) {\n logger.warn('Apparently attempt to enqueue media payload without codec initialization data upfront');\n hls.trigger(Event.ERROR, { type: ErrorTypes.MEDIA_ERROR, details: null, fatal: true });\n return;\n }\n\n if (!this.audioSwitch) {\n [data.data1, data.data2].forEach(buffer => {\n if (buffer && buffer.length) {\n pendingData.push({ type: data.type, data: buffer, parent: 'audio', content: 'data' });\n }\n });\n if (!appendOnBufferFlush && pendingData.length) {\n pendingData.forEach(appendObj => {\n // only append in PARSING state (rationale is that an appending error could happen synchronously on first segment appending)\n // in that case it is useless to append following segments\n if (this.state === State.PARSING) {\n // arm pending Buffering flag before appending a segment\n this.pendingBuffering = true;\n this.hls.trigger(Event.BUFFER_APPENDING, appendObj);\n }\n });\n this.pendingData = [];\n this.appended = true;\n }\n }\n // trigger handler right now\n this.tick();\n }\n }\n\n onFragParsed (data) {\n const fragCurrent = this.fragCurrent;\n const fragNew = data.frag;\n if (fragCurrent &&\n data.id === 'audio' &&\n fragNew.sn === fragCurrent.sn &&\n fragNew.level === fragCurrent.level &&\n this.state === State.PARSING) {\n this.stats.tparsed = performance.now();\n this.state = State.PARSED;\n this._checkAppendedParsed();\n }\n }\n\n onBufferReset () {\n // reset reference to sourcebuffers\n this.mediaBuffer = this.videoBuffer = null;\n this.loadedmetadata = false;\n }\n\n onBufferCreated (data) {\n let audioTrack = data.tracks.audio;\n if (audioTrack) {\n this.mediaBuffer = audioTrack.buffer;\n this.loadedmetadata = true;\n }\n if (data.tracks.video) {\n this.videoBuffer = data.tracks.video.buffer;\n }\n }\n\n onBufferAppended (data) {\n if (data.parent === 'audio') {\n const state = this.state;\n if (state === State.PARSING || state === State.PARSED) {\n // check if all buffers have been appended\n this.pendingBuffering = (data.pending > 0);\n this._checkAppendedParsed();\n }\n }\n }\n\n _checkAppendedParsed () {\n // trigger handler right now\n if (this.state === State.PARSED && (!this.appended || !this.pendingBuffering)) {\n let frag = this.fragCurrent, stats = this.stats, hls = this.hls;\n if (frag) {\n this.fragPrevious = frag;\n stats.tbuffered = performance.now();\n hls.trigger(Event.FRAG_BUFFERED, { stats: stats, frag: frag, id: 'audio' });\n let media = this.mediaBuffer ? this.mediaBuffer : this.media;\n if (media) {\n logger.log(`audio buffered : ${TimeRanges.toString(media.buffered)}`);\n }\n if (this.audioSwitch && this.appended) {\n this.audioSwitch = false;\n hls.trigger(Event.AUDIO_TRACK_SWITCHED, { id: this.trackId });\n }\n this.state = State.IDLE;\n }\n this.tick();\n }\n }\n\n onError (data) {\n let frag = data.frag;\n // don't handle frag error not related to audio fragment\n if (frag && frag.type !== 'audio') {\n return;\n }\n\n switch (data.details) {\n case ErrorDetails.FRAG_LOAD_ERROR:\n case ErrorDetails.FRAG_LOAD_TIMEOUT:\n const frag = data.frag;\n // don't handle frag error not related to audio fragment\n if (frag && frag.type !== 'audio') {\n break;\n }\n\n if (!data.fatal) {\n let loadError = this.fragLoadError;\n if (loadError) {\n loadError++;\n } else {\n loadError = 1;\n }\n\n const config = this.config;\n if (loadError <= config.fragLoadingMaxRetry) {\n this.fragLoadError = loadError;\n // exponential backoff capped to config.fragLoadingMaxRetryTimeout\n const delay = Math.min(Math.pow(2, loadError - 1) * config.fragLoadingRetryDelay, config.fragLoadingMaxRetryTimeout);\n logger.warn(`AudioStreamController: frag loading failed, retry in ${delay} ms`);\n this.retryDate = performance.now() + delay;\n // retry loading state\n this.state = State.FRAG_LOADING_WAITING_RETRY;\n } else {\n logger.error(`AudioStreamController: ${data.details} reaches max retry, redispatch as fatal ...`);\n // switch error to fatal\n data.fatal = true;\n this.state = State.ERROR;\n }\n }\n break;\n case ErrorDetails.AUDIO_TRACK_LOAD_ERROR:\n case ErrorDetails.AUDIO_TRACK_LOAD_TIMEOUT:\n case ErrorDetails.KEY_LOAD_ERROR:\n case ErrorDetails.KEY_LOAD_TIMEOUT:\n // when in ERROR state, don't switch back to IDLE state in case a non-fatal error is received\n if (this.state !== State.ERROR) {\n // if fatal error, stop processing, otherwise move to IDLE to retry loading\n this.state = data.fatal ? State.ERROR : State.IDLE;\n logger.warn(`AudioStreamController: ${data.details} while loading frag, now switching to ${this.state} state ...`);\n }\n break;\n case ErrorDetails.BUFFER_FULL_ERROR:\n // if in appending state\n if (data.parent === 'audio' && (this.state === State.PARSING || this.state === State.PARSED)) {\n const media = this.mediaBuffer,\n currentTime = this.media.currentTime,\n mediaBuffered = media && BufferHelper.isBuffered(media, currentTime) && BufferHelper.isBuffered(media, currentTime + 0.5);\n // reduce max buf len if current position is buffered\n if (mediaBuffered) {\n const config = this.config;\n if (config.maxMaxBufferLength >= config.maxBufferLength) {\n // reduce max buffer length as it might be too high. we do this to avoid loop flushing ...\n config.maxMaxBufferLength /= 2;\n logger.warn(`AudioStreamController: reduce max buffer length to ${config.maxMaxBufferLength}s`);\n }\n this.state = State.IDLE;\n } else {\n // current position is not buffered, but browser is still complaining about buffer full error\n // this happens on IE/Edge, refer to https://github.com/video-dev/hls.js/pull/708\n // in that case flush the whole audio buffer to recover\n logger.warn('AudioStreamController: buffer full error also media.currentTime is not buffered, flush audio buffer');\n this.fragCurrent = null;\n // flush everything\n this.state = State.BUFFER_FLUSHING;\n this.hls.trigger(Event.BUFFER_FLUSHING, { startOffset: 0, endOffset: Number.POSITIVE_INFINITY, type: 'audio' });\n }\n }\n break;\n default:\n break;\n }\n }\n\n onBufferFlushed () {\n let pendingData = this.pendingData;\n if (pendingData && pendingData.length) {\n logger.log('AudioStreamController: appending pending audio data after buffer flushed');\n pendingData.forEach(appendObj => {\n this.hls.trigger(Event.BUFFER_APPENDING, appendObj);\n });\n this.appended = true;\n this.pendingData = [];\n this.state = State.PARSED;\n } else {\n // move to IDLE once flush complete. this should trigger new fragment loading\n this.state = State.IDLE;\n // reset reference to frag\n this.fragPrevious = null;\n this.tick();\n }\n }\n}\nexport default AudioStreamController;\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport default (function () {\n if (typeof window !== 'undefined' && window.VTTCue) {\n return window.VTTCue;\n }\n\n let autoKeyword = 'auto';\n let directionSetting = {\n '': true,\n lr: true,\n rl: true\n };\n let alignSetting = {\n start: true,\n middle: true,\n end: true,\n left: true,\n right: true\n };\n\n function findDirectionSetting (value) {\n if (typeof value !== 'string') {\n return false;\n }\n\n let dir = directionSetting[value.toLowerCase()];\n return dir ? value.toLowerCase() : false;\n }\n\n function findAlignSetting (value) {\n if (typeof value !== 'string') {\n return false;\n }\n\n let align = alignSetting[value.toLowerCase()];\n return align ? value.toLowerCase() : false;\n }\n\n function extend (obj) {\n let i = 1;\n for (; i < arguments.length; i++) {\n let cobj = arguments[i];\n for (let p in cobj) {\n obj[p] = cobj[p];\n }\n }\n\n return obj;\n }\n\n function VTTCue (startTime, endTime, text) {\n let cue = this;\n let baseObj = {};\n\n baseObj.enumerable = true;\n\n /**\n * Shim implementation specific properties. These properties are not in\n * the spec.\n */\n\n // Lets us know when the VTTCue's data has changed in such a way that we need\n // to recompute its display state. This lets us compute its display state\n // lazily.\n cue.hasBeenReset = false;\n\n /**\n * VTTCue and TextTrackCue properties\n * http://dev.w3.org/html5/webvtt/#vttcue-interface\n */\n\n let _id = '';\n let _pauseOnExit = false;\n let _startTime = startTime;\n let _endTime = endTime;\n let _text = text;\n let _region = null;\n let _vertical = '';\n let _snapToLines = true;\n let _line = 'auto';\n let _lineAlign = 'start';\n let _position = 50;\n let _positionAlign = 'middle';\n let _size = 50;\n let _align = 'middle';\n\n Object.defineProperty(cue, 'id', extend({}, baseObj, {\n get: function () {\n return _id;\n },\n set: function (value) {\n _id = '' + value;\n }\n }));\n\n Object.defineProperty(cue, 'pauseOnExit', extend({}, baseObj, {\n get: function () {\n return _pauseOnExit;\n },\n set: function (value) {\n _pauseOnExit = !!value;\n }\n }));\n\n Object.defineProperty(cue, 'startTime', extend({}, baseObj, {\n get: function () {\n return _startTime;\n },\n set: function (value) {\n if (typeof value !== 'number') {\n throw new TypeError('Start time must be set to a number.');\n }\n\n _startTime = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'endTime', extend({}, baseObj, {\n get: function () {\n return _endTime;\n },\n set: function (value) {\n if (typeof value !== 'number') {\n throw new TypeError('End time must be set to a number.');\n }\n\n _endTime = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'text', extend({}, baseObj, {\n get: function () {\n return _text;\n },\n set: function (value) {\n _text = '' + value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'region', extend({}, baseObj, {\n get: function () {\n return _region;\n },\n set: function (value) {\n _region = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'vertical', extend({}, baseObj, {\n get: function () {\n return _vertical;\n },\n set: function (value) {\n let setting = findDirectionSetting(value);\n // Have to check for false because the setting an be an empty string.\n if (setting === false) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _vertical = setting;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'snapToLines', extend({}, baseObj, {\n get: function () {\n return _snapToLines;\n },\n set: function (value) {\n _snapToLines = !!value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'line', extend({}, baseObj, {\n get: function () {\n return _line;\n },\n set: function (value) {\n if (typeof value !== 'number' && value !== autoKeyword) {\n throw new SyntaxError('An invalid number or illegal string was specified.');\n }\n\n _line = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'lineAlign', extend({}, baseObj, {\n get: function () {\n return _lineAlign;\n },\n set: function (value) {\n let setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _lineAlign = setting;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'position', extend({}, baseObj, {\n get: function () {\n return _position;\n },\n set: function (value) {\n if (value < 0 || value > 100) {\n throw new Error('Position must be between 0 and 100.');\n }\n\n _position = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'positionAlign', extend({}, baseObj, {\n get: function () {\n return _positionAlign;\n },\n set: function (value) {\n let setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _positionAlign = setting;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'size', extend({}, baseObj, {\n get: function () {\n return _size;\n },\n set: function (value) {\n if (value < 0 || value > 100) {\n throw new Error('Size must be between 0 and 100.');\n }\n\n _size = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue, 'align', extend({}, baseObj, {\n get: function () {\n return _align;\n },\n set: function (value) {\n let setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _align = setting;\n this.hasBeenReset = true;\n }\n }));\n\n /**\n * Other <track> spec defined properties\n */\n\n // http://www.whatwg.org/specs/web-apps/current-work/multipage/the-video-element.html#text-track-cue-display-state\n cue.displayState = void 0;\n }\n\n /**\n * VTTCue methods\n */\n\n VTTCue.prototype.getCueAsHTML = function () {\n // Assume WebVTT.convertCueToDOMTree is on the global.\n let WebVTT = window.WebVTT;\n return WebVTT.convertCueToDOMTree(window, this.text);\n };\n\n return VTTCue;\n})();\n","/*\n * Source: https://github.com/mozilla/vtt.js/blob/master/dist/vtt.js#L1716\n */\n\nimport VTTCue from './vttcue';\n\nconst StringDecoder = function StringDecoder () {\n return {\n decode: function (data) {\n if (!data) {\n return '';\n }\n\n if (typeof data !== 'string') {\n throw new Error('Error - expected string data.');\n }\n\n return decodeURIComponent(encodeURIComponent(data));\n }\n };\n};\n\nfunction VTTParser () {\n this.window = window;\n this.state = 'INITIAL';\n this.buffer = '';\n this.decoder = new StringDecoder();\n this.regionList = [];\n}\n\n// Try to parse input as a time stamp.\nfunction parseTimeStamp (input) {\n function computeSeconds (h, m, s, f) {\n return (h | 0) * 3600 + (m | 0) * 60 + (s | 0) + (f | 0) / 1000;\n }\n\n let m = input.match(/^(\\d+):(\\d{2})(:\\d{2})?\\.(\\d{3})/);\n if (!m) {\n return null;\n }\n\n if (m[3]) {\n // Timestamp takes the form of [hours]:[minutes]:[seconds].[milliseconds]\n return computeSeconds(m[1], m[2], m[3].replace(':', ''), m[4]);\n } else if (m[1] > 59) {\n // Timestamp takes the form of [hours]:[minutes].[milliseconds]\n // First position is hours as it's over 59.\n return computeSeconds(m[1], m[2], 0, m[4]);\n } else {\n // Timestamp takes the form of [minutes]:[seconds].[milliseconds]\n return computeSeconds(0, m[1], m[2], m[4]);\n }\n}\n\n// A settings object holds key/value pairs and will ignore anything but the first\n// assignment to a specific key.\nfunction Settings () {\n this.values = Object.create(null);\n}\n\nSettings.prototype = {\n // Only accept the first assignment to any key.\n set: function (k, v) {\n if (!this.get(k) && v !== '') {\n this.values[k] = v;\n }\n },\n // Return the value for a key, or a default value.\n // If 'defaultKey' is passed then 'dflt' is assumed to be an object with\n // a number of possible default values as properties where 'defaultKey' is\n // the key of the property that will be chosen; otherwise it's assumed to be\n // a single value.\n get: function (k, dflt, defaultKey) {\n if (defaultKey) {\n return this.has(k) ? this.values[k] : dflt[defaultKey];\n }\n\n return this.has(k) ? this.values[k] : dflt;\n },\n // Check whether we have a value for a key.\n has: function (k) {\n return k in this.values;\n },\n // Accept a setting if its one of the given alternatives.\n alt: function (k, v, a) {\n for (let n = 0; n < a.length; ++n) {\n if (v === a[n]) {\n this.set(k, v);\n break;\n }\n }\n },\n // Accept a setting if its a valid (signed) integer.\n integer: function (k, v) {\n if (/^-?\\d+$/.test(v)) { // integer\n this.set(k, parseInt(v, 10));\n }\n },\n // Accept a setting if its a valid percentage.\n percent: function (k, v) {\n let m;\n if ((m = v.match(/^([\\d]{1,3})(\\.[\\d]*)?%$/))) {\n v = parseFloat(v);\n if (v >= 0 && v <= 100) {\n this.set(k, v);\n return true;\n }\n }\n return false;\n }\n};\n\n// Helper function to parse input into groups separated by 'groupDelim', and\n// interprete each group as a key/value pair separated by 'keyValueDelim'.\nfunction parseOptions (input, callback, keyValueDelim, groupDelim) {\n let groups = groupDelim ? input.split(groupDelim) : [input];\n for (let i in groups) {\n if (typeof groups[i] !== 'string') {\n continue;\n }\n\n let kv = groups[i].split(keyValueDelim);\n if (kv.length !== 2) {\n continue;\n }\n\n let k = kv[0];\n let v = kv[1];\n callback(k, v);\n }\n}\n\nlet defaults = new VTTCue(0, 0, 0);\n// 'middle' was changed to 'center' in the spec: https://github.com/w3c/webvtt/pull/244\n// Safari doesn't yet support this change, but FF and Chrome do.\nlet center = defaults.align === 'middle' ? 'middle' : 'center';\n\nfunction parseCue (input, cue, regionList) {\n // Remember the original input if we need to throw an error.\n let oInput = input;\n // 4.1 WebVTT timestamp\n function consumeTimeStamp () {\n let ts = parseTimeStamp(input);\n if (ts === null) {\n throw new Error('Malformed timestamp: ' + oInput);\n }\n\n // Remove time stamp from input.\n input = input.replace(/^[^\\sa-zA-Z-]+/, '');\n return ts;\n }\n\n // 4.4.2 WebVTT cue settings\n function consumeCueSettings (input, cue) {\n let settings = new Settings();\n\n parseOptions(input, function (k, v) {\n switch (k) {\n case 'region':\n // Find the last region we parsed with the same region id.\n for (let i = regionList.length - 1; i >= 0; i--) {\n if (regionList[i].id === v) {\n settings.set(k, regionList[i].region);\n break;\n }\n }\n break;\n case 'vertical':\n settings.alt(k, v, ['rl', 'lr']);\n break;\n case 'line':\n var vals = v.split(','),\n vals0 = vals[0];\n settings.integer(k, vals0);\n if (settings.percent(k, vals0)) {\n settings.set('snapToLines', false);\n }\n\n settings.alt(k, vals0, ['auto']);\n if (vals.length === 2) {\n settings.alt('lineAlign', vals[1], ['start', center, 'end']);\n }\n\n break;\n case 'position':\n vals = v.split(',');\n settings.percent(k, vals[0]);\n if (vals.length === 2) {\n settings.alt('positionAlign', vals[1], ['start', center, 'end', 'line-left', 'line-right', 'auto']);\n }\n\n break;\n case 'size':\n settings.percent(k, v);\n break;\n case 'align':\n settings.alt(k, v, ['start', center, 'end', 'left', 'right']);\n break;\n }\n }, /:/, /\\s/);\n\n // Apply default values for any missing fields.\n cue.region = settings.get('region', null);\n cue.vertical = settings.get('vertical', '');\n let line = settings.get('line', 'auto');\n if (line === 'auto' && defaults.line === -1) {\n // set numeric line number for Safari\n line = -1;\n }\n cue.line = line;\n cue.lineAlign = settings.get('lineAlign', 'start');\n cue.snapToLines = settings.get('snapToLines', true);\n cue.size = settings.get('size', 100);\n cue.align = settings.get('align', center);\n let position = settings.get('position', 'auto');\n if (position === 'auto' && defaults.position === 50) {\n // set numeric position for Safari\n position = cue.align === 'start' || cue.align === 'left' ? 0 : cue.align === 'end' || cue.align === 'right' ? 100 : 50;\n }\n cue.position = position;\n }\n\n function skipWhitespace () {\n input = input.replace(/^\\s+/, '');\n }\n\n // 4.1 WebVTT cue timings.\n skipWhitespace();\n cue.startTime = consumeTimeStamp(); // (1) collect cue start time\n skipWhitespace();\n if (input.substr(0, 3) !== '-->') { // (3) next characters must match '-->'\n throw new Error('Malformed time stamp (time stamps must be separated by \\'-->\\'): ' +\n oInput);\n }\n input = input.substr(3);\n skipWhitespace();\n cue.endTime = consumeTimeStamp(); // (5) collect cue end time\n\n // 4.1 WebVTT cue settings list.\n skipWhitespace();\n consumeCueSettings(input, cue);\n}\n\nfunction fixLineBreaks (input) {\n return input.replace(/<br(?: \\/)?>/gi, '\\n');\n}\n\nVTTParser.prototype = {\n parse: function (data) {\n let self = this;\n\n // If there is no data then we won't decode it, but will just try to parse\n // whatever is in buffer already. This may occur in circumstances, for\n // example when flush() is called.\n if (data) {\n // Try to decode the data that we received.\n self.buffer += self.decoder.decode(data, { stream: true });\n }\n\n function collectNextLine () {\n let buffer = self.buffer;\n let pos = 0;\n\n buffer = fixLineBreaks(buffer);\n\n while (pos < buffer.length && buffer[pos] !== '\\r' && buffer[pos] !== '\\n') {\n ++pos;\n }\n\n let line = buffer.substr(0, pos);\n // Advance the buffer early in case we fail below.\n if (buffer[pos] === '\\r') {\n ++pos;\n }\n\n if (buffer[pos] === '\\n') {\n ++pos;\n }\n\n self.buffer = buffer.substr(pos);\n return line;\n }\n\n // 3.2 WebVTT metadata header syntax\n function parseHeader (input) {\n parseOptions(input, function (k, v) {\n switch (k) {\n case 'Region':\n // 3.3 WebVTT region metadata header syntax\n // console.log('parse region', v);\n // parseRegion(v);\n break;\n }\n }, /:/);\n }\n\n // 5.1 WebVTT file parsing.\n try {\n let line;\n if (self.state === 'INITIAL') {\n // We can't start parsing until we have the first line.\n if (!/\\r\\n|\\n/.test(self.buffer)) {\n return this;\n }\n\n line = collectNextLine();\n // strip of UTF-8 BOM if any\n // https://en.wikipedia.org/wiki/Byte_order_mark#UTF-8\n let m = line.match(/^()?WEBVTT([ \\t].*)?$/);\n if (!m || !m[0]) {\n throw new Error('Malformed WebVTT signature.');\n }\n\n self.state = 'HEADER';\n }\n\n let alreadyCollectedLine = false;\n while (self.buffer) {\n // We can't parse a line until we have the full line.\n if (!/\\r\\n|\\n/.test(self.buffer)) {\n return this;\n }\n\n if (!alreadyCollectedLine) {\n line = collectNextLine();\n } else {\n alreadyCollectedLine = false;\n }\n\n switch (self.state) {\n case 'HEADER':\n // 13-18 - Allow a header (metadata) under the WEBVTT line.\n if (/:/.test(line)) {\n parseHeader(line);\n } else if (!line) {\n // An empty line terminates the header and starts the body (cues).\n self.state = 'ID';\n }\n continue;\n case 'NOTE':\n // Ignore NOTE blocks.\n if (!line) {\n self.state = 'ID';\n }\n\n continue;\n case 'ID':\n // Check for the start of NOTE blocks.\n if (/^NOTE($|[ \\t])/.test(line)) {\n self.state = 'NOTE';\n break;\n }\n // 19-29 - Allow any number of line terminators, then initialize new cue values.\n if (!line) {\n continue;\n }\n\n self.cue = new VTTCue(0, 0, '');\n self.state = 'CUE';\n // 30-39 - Check if self line contains an optional identifier or timing data.\n if (line.indexOf('-->') === -1) {\n self.cue.id = line;\n continue;\n }\n // Process line as start of a cue.\n /* falls through */\n case 'CUE':\n // 40 - Collect cue timings and settings.\n try {\n parseCue(line, self.cue, self.regionList);\n } catch (e) {\n // In case of an error ignore rest of the cue.\n self.cue = null;\n self.state = 'BADCUE';\n continue;\n }\n self.state = 'CUETEXT';\n continue;\n case 'CUETEXT':\n var hasSubstring = line.indexOf('-->') !== -1;\n // 34 - If we have an empty line then report the cue.\n // 35 - If we have the special substring '-->' then report the cue,\n // but do not collect the line as we need to process the current\n // one as a new cue.\n if (!line || hasSubstring && (alreadyCollectedLine = true)) {\n // We are done parsing self cue.\n if (self.oncue) {\n self.oncue(self.cue);\n }\n\n self.cue = null;\n self.state = 'ID';\n continue;\n }\n if (self.cue.text) {\n self.cue.text += '\\n';\n }\n\n self.cue.text += line;\n continue;\n case 'BADCUE': // BADCUE\n // 54-62 - Collect and discard the remaining cue.\n if (!line) {\n self.state = 'ID';\n }\n\n continue;\n }\n }\n } catch (e) {\n // If we are currently parsing a cue, report what we have.\n if (self.state === 'CUETEXT' && self.cue && self.oncue) {\n self.oncue(self.cue);\n }\n\n self.cue = null;\n // Enter BADWEBVTT state if header was not parsed correctly otherwise\n // another exception occurred so enter BADCUE state.\n self.state = self.state === 'INITIAL' ? 'BADWEBVTT' : 'BADCUE';\n }\n return this;\n },\n flush: function () {\n let self = this;\n try {\n // Finish decoding the stream.\n self.buffer += self.decoder.decode();\n // Synthesize the end of the current cue or region.\n if (self.cue || self.state === 'HEADER') {\n self.buffer += '\\n\\n';\n self.parse();\n }\n // If we've flushed, parsed, and we're still on the INITIAL state then\n // that means we don't have enough of the stream to parse the first\n // line.\n if (self.state === 'INITIAL') {\n throw new Error('Malformed WebVTT signature.');\n }\n } catch (e) {\n throw e;\n }\n if (self.onflush) {\n self.onflush();\n }\n\n return this;\n }\n};\n\nexport { fixLineBreaks };\n\nexport default VTTParser;\n","import { fixLineBreaks } from './vttparser';\nimport { CaptionScreen, Row } from './cea-608-parser';\n\nexport interface CuesInterface {\n newCue (track: TextTrack | null, startTime: number, endTime: number, captionScreen: CaptionScreen): VTTCue[]\n}\n\ninterface VTTCue extends TextTrackCue {\n new(start: number, end: number, cueText: string): VTTCue\n line: number\n align: string\n position: number\n}\n\nexport function newCue (track: TextTrack | null, startTime: number, endTime: number, captionScreen: CaptionScreen): VTTCue[] {\n const result: VTTCue[] = [];\n let row: Row;\n // the type data states this is VTTCue, but it can potentially be a TextTrackCue on old browsers\n let cue: VTTCue;\n let indenting: boolean;\n let indent: number;\n let text: string;\n let VTTCue: VTTCue = (window as any).VTTCue as VTTCue || TextTrackCue;\n\n for (let r = 0; r < captionScreen.rows.length; r++) {\n row = captionScreen.rows[r];\n indenting = true;\n indent = 0;\n text = '';\n\n if (!row.isEmpty()) {\n for (let c = 0; c < row.chars.length; c++) {\n if (row.chars[c].uchar.match(/\\s/) && indenting) {\n indent++;\n } else {\n text += row.chars[c].uchar;\n indenting = false;\n }\n }\n // To be used for cleaning-up orphaned roll-up captions\n row.cueStartTime = startTime;\n\n // Give a slight bump to the endTime if it's equal to startTime to avoid a SyntaxError in IE\n if (startTime === endTime) {\n endTime += 0.0001;\n }\n\n cue = new VTTCue(startTime, endTime, fixLineBreaks(text.trim()));\n\n if (indent >= 16) {\n indent--;\n } else {\n indent++;\n }\n\n // VTTCue.line get's flakey when using controls, so let's now include line 13&14\n // also, drop line 1 since it's to close to the top\n if (navigator.userAgent.match(/Firefox\\//)) {\n cue.line = r + 1;\n } else {\n cue.line = (r > 7 ? r - 2 : r + 1);\n }\n\n cue.align = 'left';\n // Clamp the position between 0 and 100 - if out of these bounds, Firefox throws an exception and captions break\n cue.position = Math.max(0, Math.min(100, 100 * (indent / 32)));\n result.push(cue);\n if (track) {\n track.addCue(cue);\n }\n }\n }\n return result;\n}\n","import OutputFilter from './output-filter';\nimport { logger } from '../utils/logger';\n\n/**\n *\n * This code was ported from the dash.js project at:\n * https://github.com/Dash-Industry-Forum/dash.js/blob/development/externals/cea608-parser.js\n * https://github.com/Dash-Industry-Forum/dash.js/commit/8269b26a761e0853bb21d78780ed945144ecdd4d#diff-71bc295a2d6b6b7093a1d3290d53a4b2\n *\n * The original copyright appears below:\n *\n * The copyright in this software is being made available under the BSD License,\n * included below. This software may be subject to other third party and contributor\n * rights, including patent rights, and no such rights are granted under this license.\n *\n * Copyright (c) 2015-2016, DASH Industry Forum.\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without modification,\n * are permitted provided that the following conditions are met:\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * * Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the documentation and/or\n * other materials provided with the distribution.\n * 2. Neither the name of Dash Industry Forum nor the names of its\n * contributors may be used to endorse or promote products derived from this software\n * without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS AS IS AND ANY\n * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.\n * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,\n * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT\n * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,\n * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n * POSSIBILITY OF SUCH DAMAGE.\n */\n/**\n * Exceptions from regular ASCII. CodePoints are mapped to UTF-16 codes\n */\n\nconst specialCea608CharsCodes = {\n 0x2a: 0xe1, // lowercase a, acute accent\n 0x5c: 0xe9, // lowercase e, acute accent\n 0x5e: 0xed, // lowercase i, acute accent\n 0x5f: 0xf3, // lowercase o, acute accent\n 0x60: 0xfa, // lowercase u, acute accent\n 0x7b: 0xe7, // lowercase c with cedilla\n 0x7c: 0xf7, // division symbol\n 0x7d: 0xd1, // uppercase N tilde\n 0x7e: 0xf1, // lowercase n tilde\n 0x7f: 0x2588, // Full block\n // THIS BLOCK INCLUDES THE 16 EXTENDED (TWO-BYTE) LINE 21 CHARACTERS\n // THAT COME FROM HI BYTE=0x11 AND LOW BETWEEN 0x30 AND 0x3F\n // THIS MEANS THAT \\x50 MUST BE ADDED TO THE VALUES\n 0x80: 0xae, // Registered symbol (R)\n 0x81: 0xb0, // degree sign\n 0x82: 0xbd, // 1/2 symbol\n 0x83: 0xbf, // Inverted (open) question mark\n 0x84: 0x2122, // Trademark symbol (TM)\n 0x85: 0xa2, // Cents symbol\n 0x86: 0xa3, // Pounds sterling\n 0x87: 0x266a, // Music 8'th note\n 0x88: 0xe0, // lowercase a, grave accent\n 0x89: 0x20, // transparent space (regular)\n 0x8a: 0xe8, // lowercase e, grave accent\n 0x8b: 0xe2, // lowercase a, circumflex accent\n 0x8c: 0xea, // lowercase e, circumflex accent\n 0x8d: 0xee, // lowercase i, circumflex accent\n 0x8e: 0xf4, // lowercase o, circumflex accent\n 0x8f: 0xfb, // lowercase u, circumflex accent\n // THIS BLOCK INCLUDES THE 32 EXTENDED (TWO-BYTE) LINE 21 CHARACTERS\n // THAT COME FROM HI BYTE=0x12 AND LOW BETWEEN 0x20 AND 0x3F\n 0x90: 0xc1, // capital letter A with acute\n 0x91: 0xc9, // capital letter E with acute\n 0x92: 0xd3, // capital letter O with acute\n 0x93: 0xda, // capital letter U with acute\n 0x94: 0xdc, // capital letter U with diaresis\n 0x95: 0xfc, // lowercase letter U with diaeresis\n 0x96: 0x2018, // opening single quote\n 0x97: 0xa1, // inverted exclamation mark\n 0x98: 0x2a, // asterisk\n 0x99: 0x2019, // closing single quote\n 0x9a: 0x2501, // box drawings heavy horizontal\n 0x9b: 0xa9, // copyright sign\n 0x9c: 0x2120, // Service mark\n 0x9d: 0x2022, // (round) bullet\n 0x9e: 0x201c, // Left double quotation mark\n 0x9f: 0x201d, // Right double quotation mark\n 0xa0: 0xc0, // uppercase A, grave accent\n 0xa1: 0xc2, // uppercase A, circumflex\n 0xa2: 0xc7, // uppercase C with cedilla\n 0xa3: 0xc8, // uppercase E, grave accent\n 0xa4: 0xca, // uppercase E, circumflex\n 0xa5: 0xcb, // capital letter E with diaresis\n 0xa6: 0xeb, // lowercase letter e with diaresis\n 0xa7: 0xce, // uppercase I, circumflex\n 0xa8: 0xcf, // uppercase I, with diaresis\n 0xa9: 0xef, // lowercase i, with diaresis\n 0xaa: 0xd4, // uppercase O, circumflex\n 0xab: 0xd9, // uppercase U, grave accent\n 0xac: 0xf9, // lowercase u, grave accent\n 0xad: 0xdb, // uppercase U, circumflex\n 0xae: 0xab, // left-pointing double angle quotation mark\n 0xaf: 0xbb, // right-pointing double angle quotation mark\n // THIS BLOCK INCLUDES THE 32 EXTENDED (TWO-BYTE) LINE 21 CHARACTERS\n // THAT COME FROM HI BYTE=0x13 AND LOW BETWEEN 0x20 AND 0x3F\n 0xb0: 0xc3, // Uppercase A, tilde\n 0xb1: 0xe3, // Lowercase a, tilde\n 0xb2: 0xcd, // Uppercase I, acute accent\n 0xb3: 0xcc, // Uppercase I, grave accent\n 0xb4: 0xec, // Lowercase i, grave accent\n 0xb5: 0xd2, // Uppercase O, grave accent\n 0xb6: 0xf2, // Lowercase o, grave accent\n 0xb7: 0xd5, // Uppercase O, tilde\n 0xb8: 0xf5, // Lowercase o, tilde\n 0xb9: 0x7b, // Open curly brace\n 0xba: 0x7d, // Closing curly brace\n 0xbb: 0x5c, // Backslash\n 0xbc: 0x5e, // Caret\n 0xbd: 0x5f, // Underscore\n 0xbe: 0x7c, // Pipe (vertical line)\n 0xbf: 0x223c, // Tilde operator\n 0xc0: 0xc4, // Uppercase A, umlaut\n 0xc1: 0xe4, // Lowercase A, umlaut\n 0xc2: 0xd6, // Uppercase O, umlaut\n 0xc3: 0xf6, // Lowercase o, umlaut\n 0xc4: 0xdf, // Esszett (sharp S)\n 0xc5: 0xa5, // Yen symbol\n 0xc6: 0xa4, // Generic currency sign\n 0xc7: 0x2503, // Box drawings heavy vertical\n 0xc8: 0xc5, // Uppercase A, ring\n 0xc9: 0xe5, // Lowercase A, ring\n 0xca: 0xd8, // Uppercase O, stroke\n 0xcb: 0xf8, // Lowercase o, strok\n 0xcc: 0x250f, // Box drawings heavy down and right\n 0xcd: 0x2513, // Box drawings heavy down and left\n 0xce: 0x2517, // Box drawings heavy up and right\n 0xcf: 0x251b // Box drawings heavy up and left\n};\n\n/**\n * Utils\n */\nconst getCharForByte = function (byte: number) {\n let charCode = byte;\n if (specialCea608CharsCodes.hasOwnProperty(byte)) {\n charCode = specialCea608CharsCodes[byte];\n }\n\n return String.fromCharCode(charCode);\n};\n\nconst NR_ROWS = 15;\nconst NR_COLS = 100;\n// Tables to look up row from PAC data\nconst rowsLowCh1 = { 0x11: 1, 0x12: 3, 0x15: 5, 0x16: 7, 0x17: 9, 0x10: 11, 0x13: 12, 0x14: 14 };\nconst rowsHighCh1 = { 0x11: 2, 0x12: 4, 0x15: 6, 0x16: 8, 0x17: 10, 0x13: 13, 0x14: 15 };\nconst rowsLowCh2 = { 0x19: 1, 0x1A: 3, 0x1D: 5, 0x1E: 7, 0x1F: 9, 0x18: 11, 0x1B: 12, 0x1C: 14 };\nconst rowsHighCh2 = { 0x19: 2, 0x1A: 4, 0x1D: 6, 0x1E: 8, 0x1F: 10, 0x1B: 13, 0x1C: 15 };\n\nconst backgroundColors = ['white', 'green', 'blue', 'cyan', 'red', 'yellow', 'magenta', 'black', 'transparent'];\n\nenum VerboseLevel {\n ERROR = 0,\n TEXT = 1,\n WARNING = 2,\n INFO = 2,\n DEBUG = 3,\n DATA = 3,\n}\n\nclass CaptionsLogger {\n public time: number | null = null;\n public verboseLevel: VerboseLevel = VerboseLevel.ERROR;\n\n log (severity: VerboseLevel, msg: string): void {\n if (this.verboseLevel >= severity) {\n logger.log(`${this.time} [${severity}] ${msg}`);\n }\n }\n}\n\nconst numArrayToHexArray = function (numArray: number[]): string[] {\n const hexArray: string[] = [];\n for (let j = 0; j < numArray.length; j++) {\n hexArray.push(numArray[j].toString(16));\n }\n\n return hexArray;\n};\n\ntype PenStyles = {\n foreground: string | null,\n underline: boolean,\n italics: boolean,\n background: string,\n flash: boolean,\n};\n\nclass PenState {\n public foreground: string;\n public underline: boolean;\n public italics: boolean;\n public background: string;\n public flash: boolean;\n\n constructor (foreground?: string, underline?: boolean, italics?: boolean, background?: string, flash?: boolean) {\n this.foreground = foreground || 'white';\n this.underline = underline || false;\n this.italics = italics || false;\n this.background = background || 'black';\n this.flash = flash || false;\n }\n\n reset () {\n this.foreground = 'white';\n this.underline = false;\n this.italics = false;\n this.background = 'black';\n this.flash = false;\n }\n\n setStyles (styles: Partial<PenStyles>) {\n const attribs = ['foreground', 'underline', 'italics', 'background', 'flash'];\n for (let i = 0; i < attribs.length; i++) {\n const style = attribs[i];\n if (styles.hasOwnProperty(style)) {\n this[style] = styles[style];\n }\n }\n }\n\n isDefault () {\n return (this.foreground === 'white' && !this.underline && !this.italics &&\n this.background === 'black' && !this.flash);\n }\n\n equals (other: PenState) {\n return ((this.foreground === other.foreground) &&\n (this.underline === other.underline) &&\n (this.italics === other.italics) &&\n (this.background === other.background) &&\n (this.flash === other.flash));\n }\n\n copy (newPenState: PenState) {\n this.foreground = newPenState.foreground;\n this.underline = newPenState.underline;\n this.italics = newPenState.italics;\n this.background = newPenState.background;\n this.flash = newPenState.flash;\n }\n\n toString (): string {\n return ('color=' + this.foreground + ', underline=' + this.underline + ', italics=' + this.italics +\n ', background=' + this.background + ', flash=' + this.flash);\n }\n}\n\n/**\n * Unicode character with styling and background.\n * @constructor\n */\nclass StyledUnicodeChar {\n uchar: string;\n penState: PenState;\n\n constructor (uchar?: string, foreground?: string, underline?: boolean, italics?: boolean, background?: string, flash?: boolean) {\n this.uchar = uchar || ' '; // unicode character\n this.penState = new PenState(foreground, underline, italics, background, flash);\n }\n\n reset () {\n this.uchar = ' ';\n this.penState.reset();\n }\n\n setChar (uchar: string, newPenState: PenState) {\n this.uchar = uchar;\n this.penState.copy(newPenState);\n }\n\n setPenState (newPenState: PenState) {\n this.penState.copy(newPenState);\n }\n\n equals (other: StyledUnicodeChar) {\n return this.uchar === other.uchar && this.penState.equals(other.penState);\n }\n\n copy (newChar: StyledUnicodeChar) {\n this.uchar = newChar.uchar;\n this.penState.copy(newChar.penState);\n }\n\n isEmpty (): boolean {\n return this.uchar === ' ' && this.penState.isDefault();\n }\n}\n\n/**\n * CEA-608 row consisting of NR_COLS instances of StyledUnicodeChar.\n * @constructor\n */\nexport class Row {\n public chars: StyledUnicodeChar[];\n public pos: number;\n public currPenState: PenState;\n public cueStartTime?: number;\n logger: CaptionsLogger;\n\n constructor (logger: CaptionsLogger) {\n this.chars = [];\n for (let i = 0; i < NR_COLS; i++) {\n this.chars.push(new StyledUnicodeChar());\n }\n\n this.logger = logger;\n this.pos = 0;\n this.currPenState = new PenState();\n }\n\n equals (other: Row) {\n let equal = true;\n for (let i = 0; i < NR_COLS; i++) {\n if (!this.chars[i].equals(other.chars[i])) {\n equal = false;\n break;\n }\n }\n return equal;\n }\n\n copy (other: Row) {\n for (let i = 0; i < NR_COLS; i++) {\n this.chars[i].copy(other.chars[i]);\n }\n }\n\n isEmpty (): boolean {\n let empty = true;\n for (let i = 0; i < NR_COLS; i++) {\n if (!this.chars[i].isEmpty()) {\n empty = false;\n break;\n }\n }\n return empty;\n }\n\n /**\n * Set the cursor to a valid column.\n */\n setCursor (absPos: number) {\n if (this.pos !== absPos) {\n this.pos = absPos;\n }\n\n if (this.pos < 0) {\n this.logger.log(VerboseLevel.DEBUG, 'Negative cursor position ' + this.pos);\n this.pos = 0;\n } else if (this.pos > NR_COLS) {\n this.logger.log(VerboseLevel.DEBUG, 'Too large cursor position ' + this.pos);\n this.pos = NR_COLS;\n }\n }\n\n /**\n * Move the cursor relative to current position.\n */\n moveCursor (relPos: number) {\n const newPos = this.pos + relPos;\n if (relPos > 1) {\n for (let i = this.pos + 1; i < newPos + 1; i++) {\n this.chars[i].setPenState(this.currPenState);\n }\n }\n this.setCursor(newPos);\n }\n\n /**\n * Backspace, move one step back and clear character.\n */\n backSpace () {\n this.moveCursor(-1);\n this.chars[this.pos].setChar(' ', this.currPenState);\n }\n\n insertChar (byte: number) {\n if (byte >= 0x90) { // Extended char\n this.backSpace();\n }\n const char = getCharForByte(byte);\n if (this.pos >= NR_COLS) {\n this.logger.log(VerboseLevel.ERROR, 'Cannot insert ' + byte.toString(16) +\n ' (' + char + ') at position ' + this.pos + '. Skipping it!');\n return;\n }\n this.chars[this.pos].setChar(char, this.currPenState);\n this.moveCursor(1);\n }\n\n clearFromPos (startPos: number) {\n let i: number;\n for (i = startPos; i < NR_COLS; i++) {\n this.chars[i].reset();\n }\n }\n\n clear () {\n this.clearFromPos(0);\n this.pos = 0;\n this.currPenState.reset();\n }\n\n clearToEndOfRow () {\n this.clearFromPos(this.pos);\n }\n\n getTextString () {\n const chars: string[] = [];\n let empty = true;\n for (let i = 0; i < NR_COLS; i++) {\n const char = this.chars[i].uchar;\n if (char !== ' ') {\n empty = false;\n }\n\n chars.push(char);\n }\n if (empty) {\n return '';\n } else {\n return chars.join('');\n }\n }\n\n setPenStyles (styles: Partial<PenStyles>) {\n this.currPenState.setStyles(styles);\n const currChar = this.chars[this.pos];\n currChar.setPenState(this.currPenState);\n }\n}\n\n/**\n * Keep a CEA-608 screen of 32x15 styled characters\n * @constructor\n */\nexport class CaptionScreen {\n rows: Row[];\n currRow: number;\n nrRollUpRows: number | null;\n lastOutputScreen: CaptionScreen | null;\n logger: CaptionsLogger;\n\n constructor (logger: CaptionsLogger) {\n this.rows = [];\n for (let i = 0; i < NR_ROWS; i++) {\n this.rows.push(new Row(logger));\n } // Note that we use zero-based numbering (0-14)\n\n this.logger = logger;\n this.currRow = NR_ROWS - 1;\n this.nrRollUpRows = null;\n this.lastOutputScreen = null;\n this.reset();\n }\n\n reset () {\n for (let i = 0; i < NR_ROWS; i++) {\n this.rows[i].clear();\n }\n\n this.currRow = NR_ROWS - 1;\n }\n\n equals (other: CaptionScreen): boolean {\n let equal = true;\n for (let i = 0; i < NR_ROWS; i++) {\n if (!this.rows[i].equals(other.rows[i])) {\n equal = false;\n break;\n }\n }\n return equal;\n }\n\n copy (other: CaptionScreen) {\n for (let i = 0; i < NR_ROWS; i++) {\n this.rows[i].copy(other.rows[i]);\n }\n }\n\n isEmpty (): boolean {\n let empty = true;\n for (let i = 0; i < NR_ROWS; i++) {\n if (!this.rows[i].isEmpty()) {\n empty = false;\n break;\n }\n }\n return empty;\n }\n\n backSpace () {\n const row = this.rows[this.currRow];\n row.backSpace();\n }\n\n clearToEndOfRow () {\n const row = this.rows[this.currRow];\n row.clearToEndOfRow();\n }\n\n /**\n * Insert a character (without styling) in the current row.\n */\n insertChar (char: number) {\n const row = this.rows[this.currRow];\n row.insertChar(char);\n }\n\n setPen (styles: Partial<PenStyles>) {\n const row = this.rows[this.currRow];\n row.setPenStyles(styles);\n }\n\n moveCursor (relPos: number) {\n const row = this.rows[this.currRow];\n row.moveCursor(relPos);\n }\n\n setCursor (absPos: number) {\n this.logger.log(VerboseLevel.INFO, 'setCursor: ' + absPos);\n const row = this.rows[this.currRow];\n row.setCursor(absPos);\n }\n\n setPAC (pacData: PACData) {\n this.logger.log(VerboseLevel.INFO, 'pacData = ' + JSON.stringify(pacData));\n let newRow = pacData.row - 1;\n if (this.nrRollUpRows && newRow < this.nrRollUpRows - 1) {\n newRow = this.nrRollUpRows - 1;\n }\n\n // Make sure this only affects Roll-up Captions by checking this.nrRollUpRows\n if (this.nrRollUpRows && this.currRow !== newRow) {\n // clear all rows first\n for (let i = 0; i < NR_ROWS; i++) {\n this.rows[i].clear();\n }\n\n // Copy this.nrRollUpRows rows from lastOutputScreen and place it in the newRow location\n // topRowIndex - the start of rows to copy (inclusive index)\n const topRowIndex = this.currRow + 1 - (this.nrRollUpRows);\n // We only copy if the last position was already shown.\n // We use the cueStartTime value to check this.\n const lastOutputScreen = this.lastOutputScreen;\n if (lastOutputScreen) {\n const prevLineTime = lastOutputScreen.rows[topRowIndex].cueStartTime;\n const time = this.logger.time;\n if (prevLineTime && time !== null && prevLineTime < time) {\n for (let i = 0; i < this.nrRollUpRows; i++) {\n this.rows[newRow - this.nrRollUpRows + i + 1].copy(lastOutputScreen.rows[topRowIndex + i]);\n }\n }\n }\n }\n\n this.currRow = newRow;\n const row = this.rows[this.currRow];\n if (pacData.indent !== null) {\n const indent = pacData.indent;\n const prevPos = Math.max(indent - 1, 0);\n row.setCursor(pacData.indent);\n pacData.color = row.chars[prevPos].penState.foreground;\n }\n const styles: PenStyles = { foreground: pacData.color, underline: pacData.underline, italics: pacData.italics, background: 'black', flash: false };\n this.setPen(styles);\n }\n\n /**\n * Set background/extra foreground, but first do back_space, and then insert space (backwards compatibility).\n */\n setBkgData (bkgData: Partial<PenStyles>) {\n this.logger.log(VerboseLevel.INFO, 'bkgData = ' + JSON.stringify(bkgData));\n this.backSpace();\n this.setPen(bkgData);\n this.insertChar(0x20); // Space\n }\n\n setRollUpRows (nrRows: number | null) {\n this.nrRollUpRows = nrRows;\n }\n\n rollUp () {\n if (this.nrRollUpRows === null) {\n this.logger.log(VerboseLevel.DEBUG, 'roll_up but nrRollUpRows not set yet');\n return; // Not properly setup\n }\n this.logger.log(VerboseLevel.TEXT, this.getDisplayText());\n const topRowIndex = this.currRow + 1 - this.nrRollUpRows;\n const topRow = this.rows.splice(topRowIndex, 1)[0];\n topRow.clear();\n this.rows.splice(this.currRow, 0, topRow);\n this.logger.log(VerboseLevel.INFO, 'Rolling up');\n // this.logger.log(VerboseLevel.TEXT, this.get_display_text())\n }\n\n /**\n * Get all non-empty rows with as unicode text.\n */\n getDisplayText (asOneRow?: boolean) {\n asOneRow = asOneRow || false;\n const displayText: string[] = [];\n let text = '';\n let rowNr = -1;\n for (let i = 0; i < NR_ROWS; i++) {\n const rowText = this.rows[i].getTextString();\n if (rowText) {\n rowNr = i + 1;\n if (asOneRow) {\n displayText.push('Row ' + rowNr + ': \\'' + rowText + '\\'');\n } else {\n displayText.push(rowText.trim());\n }\n }\n }\n if (displayText.length > 0) {\n if (asOneRow) {\n text = '[' + displayText.join(' | ') + ']';\n } else {\n text = displayText.join('\\n');\n }\n }\n return text;\n }\n\n getTextAndFormat () {\n return this.rows;\n }\n}\n\n// var modes = ['MODE_ROLL-UP', 'MODE_POP-ON', 'MODE_PAINT-ON', 'MODE_TEXT'];\n\ntype CaptionModes = 'MODE_ROLL-UP' | 'MODE_POP-ON' | 'MODE_PAINT-ON' | 'MODE_TEXT' | null;\n\nclass Cea608Channel {\n chNr: number;\n outputFilter: OutputFilter;\n mode: CaptionModes;\n verbose: number;\n displayedMemory: CaptionScreen;\n nonDisplayedMemory: CaptionScreen;\n lastOutputScreen: CaptionScreen;\n currRollUpRow: Row;\n writeScreen: CaptionScreen;\n cueStartTime: number | null;\n logger: CaptionsLogger;\n\n constructor (channelNumber: number, outputFilter: OutputFilter, logger: CaptionsLogger) {\n this.chNr = channelNumber;\n this.outputFilter = outputFilter;\n this.mode = null;\n this.verbose = 0;\n this.displayedMemory = new CaptionScreen(logger);\n this.nonDisplayedMemory = new CaptionScreen(logger);\n this.lastOutputScreen = new CaptionScreen(logger);\n this.currRollUpRow = this.displayedMemory.rows[NR_ROWS - 1];\n this.writeScreen = this.displayedMemory;\n this.mode = null;\n this.cueStartTime = null; // Keeps track of where a cue started.\n this.logger = logger;\n }\n\n reset () {\n this.mode = null;\n this.displayedMemory.reset();\n this.nonDisplayedMemory.reset();\n this.lastOutputScreen.reset();\n this.outputFilter.reset();\n this.currRollUpRow = this.displayedMemory.rows[NR_ROWS - 1];\n this.writeScreen = this.displayedMemory;\n this.mode = null;\n this.cueStartTime = null;\n }\n\n getHandler (): OutputFilter {\n return this.outputFilter;\n }\n\n setHandler (newHandler: OutputFilter) {\n this.outputFilter = newHandler;\n }\n\n setPAC (pacData: PACData) {\n this.writeScreen.setPAC(pacData);\n }\n\n setBkgData (bkgData: Partial<PenStyles>) {\n this.writeScreen.setBkgData(bkgData);\n }\n\n setMode (newMode: CaptionModes) {\n if (newMode === this.mode) {\n return;\n }\n\n this.mode = newMode;\n this.logger.log(VerboseLevel.INFO, 'MODE=' + newMode);\n if (this.mode === 'MODE_POP-ON') {\n this.writeScreen = this.nonDisplayedMemory;\n } else {\n this.writeScreen = this.displayedMemory;\n this.writeScreen.reset();\n }\n if (this.mode !== 'MODE_ROLL-UP') {\n this.displayedMemory.nrRollUpRows = null;\n this.nonDisplayedMemory.nrRollUpRows = null;\n }\n this.mode = newMode;\n }\n\n insertChars (chars: number[]) {\n for (let i = 0; i < chars.length; i++) {\n this.writeScreen.insertChar(chars[i]);\n }\n\n const screen = this.writeScreen === this.displayedMemory ? 'DISP' : 'NON_DISP';\n this.logger.log(VerboseLevel.INFO, screen + ': ' + this.writeScreen.getDisplayText(true));\n if (this.mode === 'MODE_PAINT-ON' || this.mode === 'MODE_ROLL-UP') {\n this.logger.log(VerboseLevel.TEXT, 'DISPLAYED: ' + this.displayedMemory.getDisplayText(true));\n this.outputDataUpdate();\n }\n }\n\n ccRCL () { // Resume Caption Loading (switch mode to Pop On)\n this.logger.log(VerboseLevel.INFO, 'RCL - Resume Caption Loading');\n this.setMode('MODE_POP-ON');\n }\n\n ccBS () { // BackSpace\n this.logger.log(VerboseLevel.INFO, 'BS - BackSpace');\n if (this.mode === 'MODE_TEXT') {\n return;\n }\n\n this.writeScreen.backSpace();\n if (this.writeScreen === this.displayedMemory) {\n this.outputDataUpdate();\n }\n }\n\n ccAOF () { // Reserved (formerly Alarm Off)\n\n }\n\n ccAON () { // Reserved (formerly Alarm On)\n\n }\n\n ccDER () { // Delete to End of Row\n this.logger.log(VerboseLevel.INFO, 'DER- Delete to End of Row');\n this.writeScreen.clearToEndOfRow();\n this.outputDataUpdate();\n }\n\n ccRU (nrRows: number | null) { // Roll-Up Captions-2,3,or 4 Rows\n this.logger.log(VerboseLevel.INFO, 'RU(' + nrRows + ') - Roll Up');\n this.writeScreen = this.displayedMemory;\n this.setMode('MODE_ROLL-UP');\n this.writeScreen.setRollUpRows(nrRows);\n }\n\n ccFON () { // Flash On\n this.logger.log(VerboseLevel.INFO, 'FON - Flash On');\n this.writeScreen.setPen({ flash: true });\n }\n\n ccRDC () { // Resume Direct Captioning (switch mode to PaintOn)\n this.logger.log(VerboseLevel.INFO, 'RDC - Resume Direct Captioning');\n this.setMode('MODE_PAINT-ON');\n }\n\n ccTR () { // Text Restart in text mode (not supported, however)\n this.logger.log(VerboseLevel.INFO, 'TR');\n this.setMode('MODE_TEXT');\n }\n\n ccRTD () { // Resume Text Display in Text mode (not supported, however)\n this.logger.log(VerboseLevel.INFO, 'RTD');\n this.setMode('MODE_TEXT');\n }\n\n ccEDM () { // Erase Displayed Memory\n this.logger.log(VerboseLevel.INFO, 'EDM - Erase Displayed Memory');\n this.displayedMemory.reset();\n this.outputDataUpdate(true);\n }\n\n ccCR () { // Carriage Return\n this.logger.log(VerboseLevel.INFO, 'CR - Carriage Return');\n this.writeScreen.rollUp();\n this.outputDataUpdate(true);\n }\n\n ccENM () { // Erase Non-Displayed Memory\n this.logger.log(VerboseLevel.INFO, 'ENM - Erase Non-displayed Memory');\n this.nonDisplayedMemory.reset();\n }\n\n ccEOC () { // End of Caption (Flip Memories)\n this.logger.log(VerboseLevel.INFO, 'EOC - End Of Caption');\n if (this.mode === 'MODE_POP-ON') {\n const tmp = this.displayedMemory;\n this.displayedMemory = this.nonDisplayedMemory;\n this.nonDisplayedMemory = tmp;\n this.writeScreen = this.nonDisplayedMemory;\n this.logger.log(VerboseLevel.TEXT, 'DISP: ' + this.displayedMemory.getDisplayText());\n }\n this.outputDataUpdate(true);\n }\n\n ccTO (nrCols: number) { // Tab Offset 1,2, or 3 columns\n this.logger.log(VerboseLevel.INFO, 'TO(' + nrCols + ') - Tab Offset');\n this.writeScreen.moveCursor(nrCols);\n }\n\n ccMIDROW (secondByte: number) { // Parse MIDROW command\n const styles: Partial<PenStyles> = { flash: false };\n styles.underline = secondByte % 2 === 1;\n styles.italics = secondByte >= 0x2e;\n if (!styles.italics) {\n const colorIndex = Math.floor(secondByte / 2) - 0x10;\n const colors = ['white', 'green', 'blue', 'cyan', 'red', 'yellow', 'magenta'];\n styles.foreground = colors[colorIndex];\n } else {\n styles.foreground = 'white';\n }\n this.logger.log(VerboseLevel.INFO, 'MIDROW: ' + JSON.stringify(styles));\n this.writeScreen.setPen(styles);\n }\n\n outputDataUpdate (dispatch: boolean = false) {\n const time = this.logger.time;\n if (time === null) {\n return;\n }\n\n if (this.outputFilter) {\n if (this.cueStartTime === null && !this.displayedMemory.isEmpty()) { // Start of a new cue\n this.cueStartTime = time;\n } else {\n if (!this.displayedMemory.equals(this.lastOutputScreen)) {\n this.outputFilter.newCue(this.cueStartTime!, time, this.lastOutputScreen);\n if (dispatch && this.outputFilter.dispatchCue) {\n this.outputFilter.dispatchCue();\n }\n\n this.cueStartTime = this.displayedMemory.isEmpty() ? null : time;\n }\n }\n this.lastOutputScreen.copy(this.displayedMemory);\n }\n }\n\n cueSplitAtTime (t: number) {\n if (this.outputFilter) {\n if (!this.displayedMemory.isEmpty()) {\n if (this.outputFilter.newCue) {\n this.outputFilter.newCue(this.cueStartTime!, t, this.displayedMemory);\n }\n\n this.cueStartTime = t;\n }\n }\n }\n}\n\ninterface PACData {\n row: number;\n indent: number | null;\n color: string | null;\n underline: boolean;\n italics: boolean;\n}\n\ntype SupportedField = 1 | 3;\n\ntype Channels = 0 | 1 | 2; // Will be 1 or 2 when parsing captions\n\ntype CmdHistory = {\n a: number | null,\n b: number | null\n};\n\nclass Cea608Parser {\n channels: Array<Cea608Channel | null>;\n currentChannel: Channels = 0;\n cmdHistory: CmdHistory;\n logger: CaptionsLogger;\n\n constructor (field: SupportedField, out1: OutputFilter, out2: OutputFilter) {\n const logger = new CaptionsLogger();\n this.channels = [\n null,\n new Cea608Channel(field, out1, logger),\n new Cea608Channel(field + 1, out2, logger)\n ];\n this.cmdHistory = createCmdHistory();\n this.logger = logger;\n }\n\n getHandler (channel: number) {\n return (this.channels[channel] as Cea608Channel).getHandler();\n }\n\n setHandler (channel: number, newHandler: OutputFilter) {\n (this.channels[channel] as Cea608Channel).setHandler(newHandler);\n }\n\n /**\n * Add data for time t in forms of list of bytes (unsigned ints). The bytes are treated as pairs.\n */\n addData (time: number | null, byteList: number[]) {\n let cmdFound: boolean;\n let a: number;\n let b: number;\n let charsFound: number[] | boolean | null = false;\n\n this.logger.time = time;\n\n for (let i = 0; i < byteList.length; i += 2) {\n a = byteList[i] & 0x7f;\n b = byteList[i + 1] & 0x7f;\n if (a === 0 && b === 0) {\n continue;\n } else {\n this.logger.log(VerboseLevel.DATA, '[' + numArrayToHexArray([byteList[i], byteList[i + 1]]) + '] -> (' + numArrayToHexArray([a, b]) + ')');\n }\n\n cmdFound = this.parseCmd(a, b);\n\n if (!cmdFound) {\n cmdFound = this.parseMidrow(a, b);\n }\n\n if (!cmdFound) {\n cmdFound = this.parsePAC(a, b);\n }\n\n if (!cmdFound) {\n cmdFound = this.parseBackgroundAttributes(a, b);\n }\n\n if (!cmdFound) {\n charsFound = this.parseChars(a, b);\n if (charsFound) {\n const currChNr = this.currentChannel;\n if (currChNr && currChNr > 0) {\n const channel = this.channels[currChNr] as Cea608Channel;\n channel.insertChars(charsFound);\n } else {\n this.logger.log(VerboseLevel.WARNING, 'No channel found yet. TEXT-MODE?');\n }\n }\n }\n if (!cmdFound && !charsFound) {\n this.logger.log(VerboseLevel.WARNING, 'Couldn\\'t parse cleaned data ' + numArrayToHexArray([a, b]) +\n ' orig: ' + numArrayToHexArray([byteList[i], byteList[i + 1]]));\n }\n }\n }\n\n /**\n * Parse Command.\n * @returns {Boolean} Tells if a command was found\n */\n parseCmd (a: number, b: number) {\n const { cmdHistory } = this;\n const cond1 = (a === 0x14 || a === 0x1C || a === 0x15 || a === 0x1D) && (b >= 0x20 && b <= 0x2F);\n const cond2 = (a === 0x17 || a === 0x1F) && (b >= 0x21 && b <= 0x23);\n if (!(cond1 || cond2)) {\n return false;\n }\n\n if (hasCmdRepeated(a, b, cmdHistory)) {\n setLastCmd(null, null, cmdHistory);\n this.logger.log(VerboseLevel.DEBUG, 'Repeated command (' + numArrayToHexArray([a, b]) + ') is dropped');\n return true;\n }\n\n const chNr = (a === 0x14 || a === 0x15 || a === 0x17) ? 1 : 2;\n const channel = this.channels[chNr] as Cea608Channel;\n\n if (a === 0x14 || a === 0x15 || a === 0x1C || a === 0x1D) {\n if (b === 0x20) {\n channel.ccRCL();\n } else if (b === 0x21) {\n channel.ccBS();\n } else if (b === 0x22) {\n channel.ccAOF();\n } else if (b === 0x23) {\n channel.ccAON();\n } else if (b === 0x24) {\n channel.ccDER();\n } else if (b === 0x25) {\n channel.ccRU(2);\n } else if (b === 0x26) {\n channel.ccRU(3);\n } else if (b === 0x27) {\n channel.ccRU(4);\n } else if (b === 0x28) {\n channel.ccFON();\n } else if (b === 0x29) {\n channel.ccRDC();\n } else if (b === 0x2A) {\n channel.ccTR();\n } else if (b === 0x2B) {\n channel.ccRTD();\n } else if (b === 0x2C) {\n channel.ccEDM();\n } else if (b === 0x2D) {\n channel.ccCR();\n } else if (b === 0x2E) {\n channel.ccENM();\n } else if (b === 0x2F) {\n channel.ccEOC();\n }\n } else { // a == 0x17 || a == 0x1F\n channel.ccTO(b - 0x20);\n }\n setLastCmd(a, b, cmdHistory);\n this.currentChannel = chNr;\n return true;\n }\n\n /**\n * Parse midrow styling command\n * @returns {Boolean}\n */\n parseMidrow (a: number, b: number) {\n let chNr: number = 0;\n\n if (((a === 0x11) || (a === 0x19)) && b >= 0x20 && b <= 0x2f) {\n if (a === 0x11) {\n chNr = 1;\n } else {\n chNr = 2;\n }\n\n if (chNr !== this.currentChannel) {\n this.logger.log(VerboseLevel.ERROR, 'Mismatch channel in midrow parsing');\n return false;\n }\n const channel = this.channels[chNr];\n if (!channel) {\n return false;\n }\n channel.ccMIDROW(b);\n this.logger.log(VerboseLevel.DEBUG, 'MIDROW (' + numArrayToHexArray([a, b]) + ')');\n return true;\n }\n return false;\n }\n\n /**\n * Parse Preable Access Codes (Table 53).\n * @returns {Boolean} Tells if PAC found\n */\n parsePAC (a: number, b: number): boolean {\n let row: number;\n const cmdHistory = this.cmdHistory;\n\n const case1 = ((a >= 0x11 && a <= 0x17) || (a >= 0x19 && a <= 0x1F)) && (b >= 0x40 && b <= 0x7F);\n const case2 = (a === 0x10 || a === 0x18) && (b >= 0x40 && b <= 0x5F);\n if (!(case1 || case2)) {\n return false;\n }\n\n if (hasCmdRepeated(a, b, cmdHistory)) {\n setLastCmd(null, null, cmdHistory);\n return true; // Repeated commands are dropped (once)\n }\n\n const chNr: Channels = (a <= 0x17) ? 1 : 2;\n\n if (b >= 0x40 && b <= 0x5F) {\n row = (chNr === 1) ? rowsLowCh1[a] : rowsLowCh2[a];\n } else { // 0x60 <= b <= 0x7F\n row = (chNr === 1) ? rowsHighCh1[a] : rowsHighCh2[a];\n }\n const channel = this.channels[chNr];\n if (!channel) {\n return false;\n }\n channel.setPAC(this.interpretPAC(row, b));\n setLastCmd(a, b, cmdHistory);\n this.currentChannel = chNr;\n return true;\n }\n\n /**\n * Interpret the second byte of the pac, and return the information.\n * @returns {Object} pacData with style parameters.\n */\n interpretPAC (row: number, byte: number): PACData {\n let pacIndex = byte;\n const pacData: PACData = { color: null, italics: false, indent: null, underline: false, row: row };\n\n if (byte > 0x5F) {\n pacIndex = byte - 0x60;\n } else {\n pacIndex = byte - 0x40;\n }\n\n pacData.underline = (pacIndex & 1) === 1;\n if (pacIndex <= 0xd) {\n pacData.color = ['white', 'green', 'blue', 'cyan', 'red', 'yellow', 'magenta', 'white'][Math.floor(pacIndex / 2)];\n } else if (pacIndex <= 0xf) {\n pacData.italics = true;\n pacData.color = 'white';\n } else {\n pacData.indent = (Math.floor((pacIndex - 0x10) / 2)) * 4;\n }\n return pacData; // Note that row has zero offset. The spec uses 1.\n }\n\n /**\n * Parse characters.\n * @returns An array with 1 to 2 codes corresponding to chars, if found. null otherwise.\n */\n parseChars (a: number, b: number): number[] | null {\n let channelNr: Channels;\n let charCodes: number[] | null = null;\n let charCode1: number | null = null;\n\n if (a >= 0x19) {\n channelNr = 2;\n charCode1 = a - 8;\n } else {\n channelNr = 1;\n charCode1 = a;\n }\n if (charCode1 >= 0x11 && charCode1 <= 0x13) {\n // Special character\n let oneCode = b;\n if (charCode1 === 0x11) {\n oneCode = b + 0x50;\n } else if (charCode1 === 0x12) {\n oneCode = b + 0x70;\n } else {\n oneCode = b + 0x90;\n }\n\n this.logger.log(VerboseLevel.INFO, 'Special char \\'' + getCharForByte(oneCode) + '\\' in channel ' + channelNr);\n charCodes = [oneCode];\n } else if (a >= 0x20 && a <= 0x7f) {\n charCodes = (b === 0) ? [a] : [a, b];\n }\n if (charCodes) {\n const hexCodes = numArrayToHexArray(charCodes);\n this.logger.log(VerboseLevel.DEBUG, 'Char codes = ' + hexCodes.join(','));\n setLastCmd(a, b, this.cmdHistory);\n }\n return charCodes;\n }\n\n /**\n * Parse extended background attributes as well as new foreground color black.\n * @returns {Boolean} Tells if background attributes are found\n */\n parseBackgroundAttributes (a: number, b: number): boolean {\n const case1 = (a === 0x10 || a === 0x18) && (b >= 0x20 && b <= 0x2f);\n const case2 = (a === 0x17 || a === 0x1f) && (b >= 0x2d && b <= 0x2f);\n if (!(case1 || case2)) {\n return false;\n }\n let index: number;\n const bkgData: Partial<PenStyles> = {};\n if (a === 0x10 || a === 0x18) {\n index = Math.floor((b - 0x20) / 2);\n bkgData.background = backgroundColors[index];\n if (b % 2 === 1) {\n bkgData.background = bkgData.background + '_semi';\n }\n } else if (b === 0x2d) {\n bkgData.background = 'transparent';\n } else {\n bkgData.foreground = 'black';\n if (b === 0x2f) {\n bkgData.underline = true;\n }\n }\n const chNr: Channels = (a <= 0x17) ? 1 : 2;\n const channel: Cea608Channel = this.channels[chNr] as Cea608Channel;\n channel.setBkgData(bkgData);\n setLastCmd(a, b, this.cmdHistory);\n return true;\n }\n\n /**\n * Reset state of parser and its channels.\n */\n reset () {\n for (let i = 0; i < Object.keys(this.channels).length; i++) {\n const channel = this.channels[i];\n if (channel) {\n channel.reset();\n }\n }\n this.cmdHistory = createCmdHistory();\n }\n\n /**\n * Trigger the generation of a cue, and the start of a new one if displayScreens are not empty.\n */\n cueSplitAtTime (t: number) {\n for (let i = 0; i < this.channels.length; i++) {\n const channel = this.channels[i];\n if (channel) {\n channel.cueSplitAtTime(t);\n }\n }\n }\n}\n\nfunction setLastCmd (a: number | null, b: number | null, cmdHistory: CmdHistory) {\n cmdHistory.a = a;\n cmdHistory.b = b;\n}\n\nfunction hasCmdRepeated (a: number, b: number, cmdHistory: CmdHistory) {\n return cmdHistory.a === a && cmdHistory.b === b;\n}\n\nfunction createCmdHistory (): CmdHistory {\n return {\n a: null,\n b: null\n };\n}\n\nexport default Cea608Parser;\n","import { CaptionScreen } from './cea-608-parser';\nimport type TimelineController from '../controller/timeline-controller';\n\nexport default class OutputFilter {\n private timelineController: TimelineController;\n private cueRanges: Array<[number, number]> = [];\n private trackName: string;\n private startTime: number | null = null;\n private endTime: number | null = null;\n private screen: CaptionScreen | null = null;\n\n constructor (timelineController: TimelineController, trackName: string) {\n this.timelineController = timelineController;\n this.trackName = trackName;\n }\n\n dispatchCue () {\n if (this.startTime === null) {\n return;\n }\n\n this.timelineController.addCues(this.trackName, this.startTime, this.endTime as number, this.screen as CaptionScreen, this.cueRanges);\n this.startTime = null;\n }\n\n newCue (startTime: number, endTime: number, screen: CaptionScreen) {\n if (this.startTime === null || this.startTime > startTime) {\n this.startTime = startTime;\n }\n\n this.endTime = endTime;\n this.screen = screen;\n this.timelineController.createCaptionsTrack(this.trackName);\n }\n\n reset () {\n this.cueRanges = [];\n }\n}\n","import VTTParser from './vttparser';\nimport { utf8ArrayToStr } from '../demux/id3';\n\n// String.prototype.startsWith is not supported in IE11\nconst startsWith = function (inputString, searchString, position) {\n return inputString.substr(position || 0, searchString.length) === searchString;\n};\n\nconst cueString2millis = function (timeString) {\n let ts = parseInt(timeString.substr(-3));\n let secs = parseInt(timeString.substr(-6, 2));\n let mins = parseInt(timeString.substr(-9, 2));\n let hours = timeString.length > 9 ? parseInt(timeString.substr(0, timeString.indexOf(':'))) : 0;\n\n if (!Number.isFinite(ts) || !Number.isFinite(secs) || !Number.isFinite(mins) || !Number.isFinite(hours)) {\n throw Error(`Malformed X-TIMESTAMP-MAP: Local:${timeString}`);\n }\n\n ts += 1000 * secs;\n ts += 60 * 1000 * mins;\n ts += 60 * 60 * 1000 * hours;\n\n return ts;\n};\n\n// From https://github.com/darkskyapp/string-hash\nconst hash = function (text) {\n let hash = 5381;\n let i = text.length;\n while (i) {\n hash = (hash * 33) ^ text.charCodeAt(--i);\n }\n\n return (hash >>> 0).toString();\n};\n\nconst calculateOffset = function (vttCCs, cc, presentationTime) {\n let currCC = vttCCs[cc];\n let prevCC = vttCCs[currCC.prevCC];\n\n // This is the first discontinuity or cues have been processed since the last discontinuity\n // Offset = current discontinuity time\n if (!prevCC || (!prevCC.new && currCC.new)) {\n vttCCs.ccOffset = vttCCs.presentationOffset = currCC.start;\n currCC.new = false;\n return;\n }\n\n // There have been discontinuities since cues were last parsed.\n // Offset = time elapsed\n while (prevCC && prevCC.new) {\n vttCCs.ccOffset += currCC.start - prevCC.start;\n currCC.new = false;\n currCC = prevCC;\n prevCC = vttCCs[currCC.prevCC];\n }\n\n vttCCs.presentationOffset = presentationTime;\n};\n\nconst WebVTTParser = {\n parse: function (vttByteArray, syncPTS, vttCCs, cc, callBack, errorCallBack) {\n // Convert byteArray into string, replacing any somewhat exotic linefeeds with \"\\n\", then split on that character.\n let re = /\\r\\n|\\n\\r|\\n|\\r/g;\n // Uint8Array.prototype.reduce is not implemented in IE11\n let vttLines = utf8ArrayToStr(new Uint8Array(vttByteArray)).trim().replace(re, '\\n').split('\\n');\n\n let cueTime = '00:00.000';\n let mpegTs = 0;\n let localTime = 0;\n let presentationTime = 0;\n let cues = [];\n let parsingError;\n let inHeader = true;\n let timestampMap = false;\n // let VTTCue = VTTCue || window.TextTrackCue;\n\n // Create parser object using VTTCue with TextTrackCue fallback on certain browsers.\n let parser = new VTTParser();\n\n parser.oncue = function (cue) {\n // Adjust cue timing; clamp cues to start no earlier than - and drop cues that don't end after - 0 on timeline.\n let currCC = vttCCs[cc];\n let cueOffset = vttCCs.ccOffset;\n\n // Update offsets for new discontinuities\n if (currCC && currCC.new) {\n if (localTime !== undefined) {\n // When local time is provided, offset = discontinuity start time - local time\n cueOffset = vttCCs.ccOffset = currCC.start;\n } else {\n calculateOffset(vttCCs, cc, presentationTime);\n }\n }\n\n if (presentationTime) {\n // If we have MPEGTS, offset = presentation time + discontinuity offset\n cueOffset = presentationTime - vttCCs.presentationOffset;\n }\n\n if (timestampMap) {\n cue.startTime += cueOffset - localTime;\n cue.endTime += cueOffset - localTime;\n }\n\n // Create a unique hash id for a cue based on start/end times and text.\n // This helps timeline-controller to avoid showing repeated captions.\n cue.id = hash(cue.startTime.toString()) + hash(cue.endTime.toString()) + hash(cue.text);\n\n // Fix encoding of special characters. TODO: Test with all sorts of weird characters.\n cue.text = decodeURIComponent(encodeURIComponent(cue.text));\n if (cue.endTime > 0) {\n cues.push(cue);\n }\n };\n\n parser.onparsingerror = function (e) {\n parsingError = e;\n };\n\n parser.onflush = function () {\n if (parsingError && errorCallBack) {\n errorCallBack(parsingError);\n return;\n }\n callBack(cues);\n };\n\n // Go through contents line by line.\n vttLines.forEach(line => {\n if (inHeader) {\n // Look for X-TIMESTAMP-MAP in header.\n if (startsWith(line, 'X-TIMESTAMP-MAP=')) {\n // Once found, no more are allowed anyway, so stop searching.\n inHeader = false;\n timestampMap = true;\n // Extract LOCAL and MPEGTS.\n line.substr(16).split(',').forEach(timestamp => {\n if (startsWith(timestamp, 'LOCAL:')) {\n cueTime = timestamp.substr(6);\n } else if (startsWith(timestamp, 'MPEGTS:')) {\n mpegTs = parseInt(timestamp.substr(7));\n }\n });\n try {\n // Calculate subtitle offset in milliseconds.\n if (syncPTS + ((vttCCs[cc].start * 90000) || 0) < 0) {\n syncPTS += 8589934592;\n }\n // Adjust MPEGTS by sync PTS.\n mpegTs -= syncPTS;\n // Convert cue time to seconds\n localTime = cueString2millis(cueTime) / 1000;\n // Convert MPEGTS to seconds from 90kHz.\n presentationTime = mpegTs / 90000;\n } catch (e) {\n timestampMap = false;\n parsingError = e;\n }\n // Return without parsing X-TIMESTAMP-MAP line.\n return;\n } else if (line === '') {\n inHeader = false;\n }\n }\n // Parse line by default.\n parser.parse(line + '\\n');\n });\n\n parser.flush();\n }\n};\n\nexport default WebVTTParser;\n","import Event from '../events';\nimport EventHandler from '../event-handler';\nimport Cea608Parser, { CaptionScreen } from '../utils/cea-608-parser';\nimport OutputFilter from '../utils/output-filter';\nimport WebVTTParser from '../utils/webvtt-parser';\nimport { logger } from '../utils/logger';\nimport { sendAddTrackEvent, clearCurrentCues } from '../utils/texttrack-utils';\nimport Fragment from '../loader/fragment';\nimport { HlsConfig } from '../config';\nimport { CuesInterface } from '../utils/cues';\nimport { MediaPlaylist } from '../types/media-playlist';\n\ntype TrackProperties = {\n label: string,\n languageCode: string,\n media?: MediaPlaylist\n};\n\ntype NonNativeCaptionsTrack = {\n _id?: string,\n label: string,\n kind: string,\n default: boolean,\n closedCaptions?: MediaPlaylist,\n subtitleTrack?: MediaPlaylist\n};\n\ntype VTTCCs = {\n ccOffset: number,\n presentationOffset: number,\n [key: number]: {\n start: number,\n prevCC: number,\n new: boolean\n }\n};\n\nclass TimelineController extends EventHandler {\n private media: HTMLMediaElement | null = null;\n private config: HlsConfig;\n private enabled: boolean = true;\n private Cues: CuesInterface;\n private textTracks: Array<TextTrack> = [];\n private tracks: Array<MediaPlaylist> = [];\n private initPTS: Array<number> = [];\n private unparsedVttFrags: Array<{ frag: Fragment, payload: ArrayBuffer }> = [];\n private captionsTracks: Record<string, TextTrack> = {};\n private nonNativeCaptionsTracks: Record<string, NonNativeCaptionsTrack> = {};\n private captionsProperties: {\n textTrack1: TrackProperties\n textTrack2: TrackProperties\n textTrack3: TrackProperties\n textTrack4: TrackProperties\n };\n private readonly cea608Parser1!: Cea608Parser;\n private readonly cea608Parser2!: Cea608Parser;\n private lastSn: number = -1;\n private prevCC: number = -1;\n private vttCCs: VTTCCs = newVTTCCs();\n\n constructor (hls) {\n super(hls,\n Event.MEDIA_ATTACHING,\n Event.MEDIA_DETACHING,\n Event.FRAG_PARSING_USERDATA,\n Event.FRAG_DECRYPTED,\n Event.MANIFEST_LOADING,\n Event.MANIFEST_LOADED,\n Event.FRAG_LOADED,\n Event.INIT_PTS_FOUND);\n\n this.hls = hls;\n this.config = hls.config;\n this.Cues = hls.config.cueHandler;\n\n this.captionsProperties = {\n textTrack1: {\n label: this.config.captionsTextTrack1Label,\n languageCode: this.config.captionsTextTrack1LanguageCode\n },\n textTrack2: {\n label: this.config.captionsTextTrack2Label,\n languageCode: this.config.captionsTextTrack2LanguageCode\n },\n textTrack3: {\n label: this.config.captionsTextTrack3Label,\n languageCode: this.config.captionsTextTrack3LanguageCode\n },\n textTrack4: {\n label: this.config.captionsTextTrack4Label,\n languageCode: this.config.captionsTextTrack4LanguageCode\n }\n };\n\n if (this.config.enableCEA708Captions) {\n const channel1 = new OutputFilter(this, 'textTrack1');\n const channel2 = new OutputFilter(this, 'textTrack2');\n const channel3 = new OutputFilter(this, 'textTrack3');\n const channel4 = new OutputFilter(this, 'textTrack4');\n this.cea608Parser1 = new Cea608Parser(1, channel1, channel2);\n this.cea608Parser2 = new Cea608Parser(3, channel3, channel4);\n }\n }\n\n addCues (trackName: string, startTime: number, endTime: number, screen: CaptionScreen, cueRanges: Array<[number, number]>) {\n // skip cues which overlap more than 50% with previously parsed time ranges\n let merged = false;\n for (let i = cueRanges.length; i--;) {\n let cueRange = cueRanges[i];\n let overlap = intersection(cueRange[0], cueRange[1], startTime, endTime);\n if (overlap >= 0) {\n cueRange[0] = Math.min(cueRange[0], startTime);\n cueRange[1] = Math.max(cueRange[1], endTime);\n merged = true;\n if ((overlap / (endTime - startTime)) > 0.5) {\n return;\n }\n }\n }\n if (!merged) {\n cueRanges.push([startTime, endTime]);\n }\n\n if (this.config.renderTextTracksNatively) {\n this.Cues.newCue(this.captionsTracks[trackName], startTime, endTime, screen);\n } else {\n const cues = this.Cues.newCue(null, startTime, endTime, screen);\n this.hls.trigger(Event.CUES_PARSED, { type: 'captions', cues, track: trackName });\n }\n }\n\n // Triggered when an initial PTS is found; used for synchronisation of WebVTT.\n onInitPtsFound (data: { id: string, frag: Fragment, initPTS: number}) {\n const { frag, id, initPTS } = data;\n const { unparsedVttFrags } = this;\n if (id === 'main') {\n this.initPTS[frag.cc] = initPTS;\n }\n\n // Due to asynchronous processing, initial PTS may arrive later than the first VTT fragments are loaded.\n // Parse any unparsed fragments upon receiving the initial PTS.\n if (unparsedVttFrags.length) {\n this.unparsedVttFrags = [];\n unparsedVttFrags.forEach(frag => {\n this.onFragLoaded(frag);\n });\n }\n }\n\n getExistingTrack (trackName: string): TextTrack | null {\n const { media } = this;\n if (media) {\n for (let i = 0; i < media.textTracks.length; i++) {\n let textTrack = media.textTracks[i];\n if (textTrack[trackName]) {\n return textTrack;\n }\n }\n }\n return null;\n }\n\n createCaptionsTrack (trackName: string) {\n if (this.config.renderTextTracksNatively) {\n this.createNativeTrack(trackName);\n } else {\n this.createNonNativeTrack(trackName);\n }\n }\n\n createNativeTrack (trackName: string) {\n if (this.captionsTracks[trackName]) {\n return;\n }\n const { captionsProperties, captionsTracks, media } = this;\n const { label, languageCode } = captionsProperties[trackName];\n // Enable reuse of existing text track.\n const existingTrack = this.getExistingTrack(trackName);\n if (!existingTrack) {\n const textTrack = this.createTextTrack('captions', label, languageCode);\n if (textTrack) {\n // Set a special property on the track so we know it's managed by Hls.js\n textTrack[trackName] = true;\n captionsTracks[trackName] = textTrack;\n }\n } else {\n captionsTracks[trackName] = existingTrack;\n clearCurrentCues(captionsTracks[trackName]);\n sendAddTrackEvent(captionsTracks[trackName], media as HTMLMediaElement);\n }\n }\n\n createNonNativeTrack (trackName: string) {\n if (this.nonNativeCaptionsTracks[trackName]) {\n return;\n }\n // Create a list of a single track for the provider to consume\n const trackProperties: TrackProperties = this.captionsProperties[trackName];\n if (!trackProperties) {\n return;\n }\n const label = trackProperties.label as string;\n const track = {\n _id: trackName,\n label,\n kind: 'captions',\n default: trackProperties.media ? !!trackProperties.media.default : false,\n closedCaptions: trackProperties.media\n };\n this.nonNativeCaptionsTracks[trackName] = track;\n this.hls.trigger(Event.NON_NATIVE_TEXT_TRACKS_FOUND, { tracks: [track] });\n }\n createTextTrack (kind: TextTrackKind, label: string, lang?: string): TextTrack | undefined {\n const media = this.media;\n if (!media) {\n return;\n }\n return media.addTextTrack(kind, label, lang);\n }\n\n destroy () {\n super.destroy();\n }\n\n onMediaAttaching (data: { media: HTMLMediaElement }) {\n this.media = data.media;\n this._cleanTracks();\n }\n\n onMediaDetaching () {\n const { captionsTracks } = this;\n Object.keys(captionsTracks).forEach(trackName => {\n clearCurrentCues(captionsTracks[trackName]);\n delete captionsTracks[trackName];\n });\n this.nonNativeCaptionsTracks = {};\n }\n\n onManifestLoading () {\n this.lastSn = -1; // Detect discontiguity in fragment parsing\n this.prevCC = -1;\n this.vttCCs = newVTTCCs(); // Detect discontinuity in subtitle manifests\n this._cleanTracks();\n this.tracks = [];\n this.captionsTracks = {};\n this.nonNativeCaptionsTracks = {};\n }\n\n _cleanTracks () {\n // clear outdated subtitles\n const { media } = this;\n if (!media) {\n return;\n }\n const textTracks = media.textTracks;\n if (textTracks) {\n for (let i = 0; i < textTracks.length; i++) {\n clearCurrentCues(textTracks[i]);\n }\n }\n }\n\n onManifestLoaded (data: { subtitles: Array<MediaPlaylist>, captions: Array<MediaPlaylist> }) {\n this.textTracks = [];\n this.unparsedVttFrags = this.unparsedVttFrags || [];\n this.initPTS = [];\n if (this.cea608Parser1 && this.cea608Parser2) {\n this.cea608Parser1.reset();\n this.cea608Parser2.reset();\n }\n\n if (this.config.enableWebVTT) {\n const tracks = data.subtitles || [];\n const sameTracks = this.tracks && tracks && this.tracks.length === tracks.length;\n this.tracks = data.subtitles || [];\n\n if (this.config.renderTextTracksNatively) {\n const inUseTracks = this.media ? this.media.textTracks : [];\n\n this.tracks.forEach((track, index) => {\n let textTrack;\n if (index < inUseTracks.length) {\n let inUseTrack: TextTrack | null = null;\n\n for (let i = 0; i < inUseTracks.length; i++) {\n if (canReuseVttTextTrack(inUseTracks[i], track)) {\n inUseTrack = inUseTracks[i];\n break;\n }\n }\n\n // Reuse tracks with the same label, but do not reuse 608/708 tracks\n if (inUseTrack) {\n textTrack = inUseTrack;\n }\n }\n if (!textTrack) {\n textTrack = this.createTextTrack('subtitles', track.name, track.lang);\n }\n\n if (track.default) {\n textTrack.mode = this.hls.subtitleDisplay ? 'showing' : 'hidden';\n } else {\n textTrack.mode = 'disabled';\n }\n\n this.textTracks.push(textTrack);\n });\n } else if (!sameTracks && this.tracks && this.tracks.length) {\n // Create a list of tracks for the provider to consume\n const tracksList = this.tracks.map((track) => {\n return {\n label: track.name,\n kind: track.type.toLowerCase(),\n default: track.default,\n subtitleTrack: track\n };\n });\n this.hls.trigger(Event.NON_NATIVE_TEXT_TRACKS_FOUND, { tracks: tracksList });\n }\n }\n\n if (this.config.enableCEA708Captions && data.captions) {\n data.captions.forEach(captionsTrack => {\n const instreamIdMatch = /(?:CC|SERVICE)([1-4])/.exec(captionsTrack.instreamId as string);\n if (!instreamIdMatch) {\n return;\n }\n const trackName = `textTrack${instreamIdMatch[1]}`;\n const trackProperties: TrackProperties = this.captionsProperties[trackName];\n if (!trackProperties) {\n return;\n }\n trackProperties.label = captionsTrack.name;\n if (captionsTrack.lang) { // optional attribute\n trackProperties.languageCode = captionsTrack.lang;\n }\n trackProperties.media = captionsTrack;\n });\n }\n }\n\n onFragLoaded (data: { frag: Fragment, payload: ArrayBuffer }) {\n const { frag, payload } = data;\n const { cea608Parser1, cea608Parser2, initPTS, lastSn, unparsedVttFrags } = this;\n if (frag.type === 'main') {\n const sn = frag.sn;\n // if this frag isn't contiguous, clear the parser so cues with bad start/end times aren't added to the textTrack\n if (frag.sn !== lastSn + 1) {\n if (cea608Parser1 && cea608Parser2) {\n cea608Parser1.reset();\n cea608Parser2.reset();\n }\n }\n this.lastSn = sn as number;\n } // eslint-disable-line brace-style\n // If fragment is subtitle type, parse as WebVTT.\n else if (frag.type === 'subtitle') {\n if (payload.byteLength) {\n // We need an initial synchronisation PTS. Store fragments as long as none has arrived.\n if (!Number.isFinite(initPTS[frag.cc])) {\n unparsedVttFrags.push(data);\n if (initPTS.length) {\n // finish unsuccessfully, otherwise the subtitle-stream-controller could be blocked from loading new frags.\n this.hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: false, frag });\n }\n return;\n }\n\n let decryptData = frag.decryptdata;\n // If the subtitles are not encrypted, parse VTTs now. Otherwise, we need to wait.\n if ((decryptData == null) || (decryptData.key == null) || (decryptData.method !== 'AES-128')) {\n this._parseVTTs(frag, payload);\n }\n } else {\n // In case there is no payload, finish unsuccessfully.\n this.hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: false, frag });\n }\n }\n }\n\n _parseVTTs (frag: Fragment, payload: ArrayBuffer) {\n const { hls, prevCC, textTracks, vttCCs } = this;\n if (!vttCCs[frag.cc]) {\n vttCCs[frag.cc] = { start: frag.start, prevCC, new: true };\n this.prevCC = frag.cc;\n }\n // Parse the WebVTT file contents.\n WebVTTParser.parse(payload, this.initPTS[frag.cc], vttCCs, frag.cc, (cues) => {\n if (this.config.renderTextTracksNatively) {\n const currentTrack = textTracks[frag.level];\n // WebVTTParser.parse is an async method and if the currently selected text track mode is set to \"disabled\"\n // before parsing is done then don't try to access currentTrack.cues.getCueById as cues will be null\n // and trying to access getCueById method of cues will throw an exception\n // Because we check if the mode is diabled, we can force check `cues` below. They can't be null.\n if (currentTrack.mode === 'disabled') {\n hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: false, frag: frag });\n return;\n }\n\n // Add cues and trigger event with success true.\n cues.forEach(cue => {\n // Sometimes there are cue overlaps on segmented vtts so the same\n // cue can appear more than once in different vtt files.\n // This avoid showing duplicated cues with same timecode and text.\n if (!currentTrack.cues!.getCueById(cue.id)) {\n try {\n currentTrack.addCue(cue);\n if (!currentTrack.cues!.getCueById(cue.id)) {\n throw new Error(`addCue is failed for: ${cue}`);\n }\n } catch (err) {\n logger.debug(`Failed occurred on adding cues: ${err}`);\n const textTrackCue = new (window as any).TextTrackCue(cue.startTime, cue.endTime, cue.text);\n textTrackCue.id = cue.id;\n currentTrack.addCue(textTrackCue);\n }\n }\n });\n } else {\n let trackId = this.tracks[frag.level].default ? 'default' : 'subtitles' + frag.level;\n hls.trigger(Event.CUES_PARSED, { type: 'subtitles', cues: cues, track: trackId });\n }\n hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: true, frag: frag });\n },\n function (e) {\n // Something went wrong while parsing. Trigger event with success false.\n logger.log(`Failed to parse VTT cue: ${e}`);\n hls.trigger(Event.SUBTITLE_FRAG_PROCESSED, { success: false, frag: frag });\n });\n }\n\n onFragDecrypted (data: { frag: Fragment, payload: any}) {\n const { frag, payload } = data;\n if (frag.type === 'subtitle') {\n if (!Number.isFinite(this.initPTS[frag.cc])) {\n this.unparsedVttFrags.push(data);\n return;\n }\n\n this._parseVTTs(frag, payload);\n }\n }\n\n onFragParsingUserdata (data: { samples: Array<any> }) {\n const { cea608Parser1, cea608Parser2 } = this;\n if (!this.enabled || !(cea608Parser1 && cea608Parser2)) {\n return;\n }\n\n // If the event contains captions (found in the bytes property), push all bytes into the parser immediately\n // It will create the proper timestamps based on the PTS value\n for (let i = 0; i < data.samples.length; i++) {\n const ccBytes = data.samples[i].bytes;\n if (ccBytes) {\n const ccdatas = this.extractCea608Data(ccBytes);\n cea608Parser1.addData(data.samples[i].pts, ccdatas[0]);\n cea608Parser2.addData(data.samples[i].pts, ccdatas[1]);\n }\n }\n }\n\n extractCea608Data (byteArray: Uint8Array): number[][] {\n const count = byteArray[0] & 31;\n let position = 2;\n const actualCCBytes: number[][] = [[], []];\n\n for (let j = 0; j < count; j++) {\n const tmpByte = byteArray[position++];\n const ccbyte1 = 0x7F & byteArray[position++];\n const ccbyte2 = 0x7F & byteArray[position++];\n const ccValid = (4 & tmpByte) !== 0;\n const ccType = 3 & tmpByte;\n\n if (ccbyte1 === 0 && ccbyte2 === 0) {\n continue;\n }\n\n if (ccValid) {\n if (ccType === 0 || ccType === 1) {\n actualCCBytes[ccType].push(ccbyte1);\n actualCCBytes[ccType].push(ccbyte2);\n }\n }\n }\n return actualCCBytes;\n }\n}\n\nfunction canReuseVttTextTrack (inUseTrack, manifestTrack): boolean {\n return inUseTrack && inUseTrack.label === manifestTrack.name && !(inUseTrack.textTrack1 || inUseTrack.textTrack2);\n}\n\nfunction intersection (x1: number, x2: number, y1: number, y2: number): number {\n return Math.min(x2, y2) - Math.max(x1, y1);\n}\n\nfunction newVTTCCs (): VTTCCs {\n return {\n ccOffset: 0,\n presentationOffset: 0,\n 0: {\n start: 0,\n prevCC: -1,\n new: false\n }\n };\n}\n\nexport default TimelineController;\n","import Event from '../events';\nimport EventHandler from '../event-handler';\nimport { logger } from '../utils/logger';\nimport { computeReloadInterval } from './level-helper';\nimport { clearCurrentCues } from '../utils/texttrack-utils';\n\nclass SubtitleTrackController extends EventHandler {\n constructor (hls) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.MANIFEST_LOADED,\n Event.SUBTITLE_TRACK_LOADED);\n this.tracks = [];\n this.trackId = -1;\n this.media = null;\n this.stopped = true;\n\n /**\n * @member {boolean} subtitleDisplay Enable/disable subtitle display rendering\n */\n this.subtitleDisplay = true;\n\n /**\n * Keeps reference to a default track id when media has not been attached yet\n * @member {number}\n */\n this.queuedDefaultTrack = null;\n }\n\n destroy () {\n EventHandler.prototype.destroy.call(this);\n }\n\n // Listen for subtitle track change, then extract the current track ID.\n onMediaAttached (data) {\n this.media = data.media;\n if (!this.media) {\n return;\n }\n\n if (Number.isFinite(this.queuedDefaultTrack)) {\n this.subtitleTrack = this.queuedDefaultTrack;\n this.queuedDefaultTrack = null;\n }\n\n this.trackChangeListener = this._onTextTracksChanged.bind(this);\n\n this.useTextTrackPolling = !(this.media.textTracks && 'onchange' in this.media.textTracks);\n if (this.useTextTrackPolling) {\n this.subtitlePollingInterval = setInterval(() => {\n this.trackChangeListener();\n }, 500);\n } else {\n this.media.textTracks.addEventListener('change', this.trackChangeListener);\n }\n }\n\n onMediaDetaching () {\n if (!this.media) {\n return;\n }\n\n if (this.useTextTrackPolling) {\n clearInterval(this.subtitlePollingInterval);\n } else {\n this.media.textTracks.removeEventListener('change', this.trackChangeListener);\n }\n\n if (Number.isFinite(this.subtitleTrack)) {\n this.queuedDefaultTrack = this.subtitleTrack;\n }\n\n const textTracks = filterSubtitleTracks(this.media.textTracks);\n // Clear loaded cues on media detachment from tracks\n textTracks.forEach((track) => {\n clearCurrentCues(track);\n });\n // Disable all subtitle tracks before detachment so when reattached only tracks in that content are enabled.\n this.subtitleTrack = -1;\n this.media = null;\n }\n\n // Fired whenever a new manifest is loaded.\n onManifestLoaded (data) {\n let tracks = data.subtitles || [];\n this.tracks = tracks;\n this.hls.trigger(Event.SUBTITLE_TRACKS_UPDATED, { subtitleTracks: tracks });\n\n // loop through available subtitle tracks and autoselect default if needed\n // TODO: improve selection logic to handle forced, etc\n tracks.forEach(track => {\n if (track.default) {\n // setting this.subtitleTrack will trigger internal logic\n // if media has not been attached yet, it will fail\n // we keep a reference to the default track id\n // and we'll set subtitleTrack when onMediaAttached is triggered\n if (this.media) {\n this.subtitleTrack = track.id;\n } else {\n this.queuedDefaultTrack = track.id;\n }\n }\n });\n }\n\n onSubtitleTrackLoaded (data) {\n const { id, details } = data;\n const { trackId, tracks } = this;\n const currentTrack = tracks[trackId];\n if (id >= tracks.length || id !== trackId || !currentTrack || this.stopped) {\n this._clearReloadTimer();\n return;\n }\n\n logger.log(`subtitle track ${id} loaded`);\n if (details.live) {\n const reloadInterval = computeReloadInterval(currentTrack.details, details, data.stats.trequest);\n logger.log(`Reloading live subtitle playlist in ${reloadInterval}ms`);\n this.timer = setTimeout(() => {\n this._loadCurrentTrack();\n }, reloadInterval);\n } else {\n this._clearReloadTimer();\n }\n }\n\n startLoad () {\n this.stopped = false;\n this._loadCurrentTrack();\n }\n\n stopLoad () {\n this.stopped = true;\n this._clearReloadTimer();\n }\n\n /** get alternate subtitle tracks list from playlist **/\n get subtitleTracks () {\n return this.tracks;\n }\n\n /** get index of the selected subtitle track (index in subtitle track lists) **/\n get subtitleTrack () {\n return this.trackId;\n }\n\n /** select a subtitle track, based on its index in subtitle track lists**/\n set subtitleTrack (subtitleTrackId) {\n if (this.trackId !== subtitleTrackId) {\n this._toggleTrackModes(subtitleTrackId);\n this._setSubtitleTrackInternal(subtitleTrackId);\n }\n }\n\n _clearReloadTimer () {\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n }\n\n _loadCurrentTrack () {\n const { trackId, tracks, hls } = this;\n const currentTrack = tracks[trackId];\n if (trackId < 0 || !currentTrack || (currentTrack.details && !currentTrack.details.live)) {\n return;\n }\n logger.log(`Loading subtitle track ${trackId}`);\n hls.trigger(Event.SUBTITLE_TRACK_LOADING, { url: currentTrack.url, id: trackId });\n }\n\n /**\n * Disables the old subtitleTrack and sets current mode on the next subtitleTrack.\n * This operates on the DOM textTracks.\n * A value of -1 will disable all subtitle tracks.\n * @param newId - The id of the next track to enable\n * @private\n */\n _toggleTrackModes (newId) {\n const { media, subtitleDisplay, trackId } = this;\n if (!media) {\n return;\n }\n\n const textTracks = filterSubtitleTracks(media.textTracks);\n if (newId === -1) {\n [].slice.call(textTracks).forEach(track => {\n track.mode = 'disabled';\n });\n } else {\n const oldTrack = textTracks[trackId];\n if (oldTrack) {\n oldTrack.mode = 'disabled';\n }\n }\n\n const nextTrack = textTracks[newId];\n if (nextTrack) {\n nextTrack.mode = subtitleDisplay ? 'showing' : 'hidden';\n }\n }\n\n /**\n * This method is responsible for validating the subtitle index and periodically reloading if live.\n * Dispatches the SUBTITLE_TRACK_SWITCH event, which instructs the subtitle-stream-controller to load the selected track.\n * @param newId - The id of the subtitle track to activate.\n */\n _setSubtitleTrackInternal (newId) {\n const { hls, tracks } = this;\n if (!Number.isFinite(newId) || newId < -1 || newId >= tracks.length) {\n return;\n }\n\n this.trackId = newId;\n logger.log(`Switching to subtitle track ${newId}`);\n hls.trigger(Event.SUBTITLE_TRACK_SWITCH, { id: newId });\n this._loadCurrentTrack();\n }\n\n _onTextTracksChanged () {\n // Media is undefined when switching streams via loadSource()\n if (!this.media || !this.hls.config.renderTextTracksNatively) {\n return;\n }\n\n let trackId = -1;\n let tracks = filterSubtitleTracks(this.media.textTracks);\n for (let id = 0; id < tracks.length; id++) {\n if (tracks[id].mode === 'hidden') {\n // Do not break in case there is a following track with showing.\n trackId = id;\n } else if (tracks[id].mode === 'showing') {\n trackId = id;\n break;\n }\n }\n\n // Setting current subtitleTrack will invoke code.\n this.subtitleTrack = trackId;\n }\n}\n\nfunction filterSubtitleTracks (textTrackList) {\n let tracks = [];\n for (let i = 0; i < textTrackList.length; i++) {\n const track = textTrackList[i];\n // Edge adds a track without a label; we don't want to use it\n if (track.kind === 'subtitles' && track.label) {\n tracks.push(textTrackList[i]);\n }\n }\n return tracks;\n}\n\nexport default SubtitleTrackController;\n","/**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Navigator/requestMediaKeySystemAccess\n */\nexport enum KeySystems {\n WIDEVINE = 'com.widevine.alpha',\n PLAYREADY = 'com.microsoft.playready',\n}\n\nexport type MediaKeyFunc = (keySystem: KeySystems, supportedConfigurations: MediaKeySystemConfiguration[]) => Promise<MediaKeySystemAccess>;\nconst requestMediaKeySystemAccess = (function (): MediaKeyFunc | null {\n if (typeof window !== 'undefined' && window.navigator && window.navigator.requestMediaKeySystemAccess) {\n return window.navigator.requestMediaKeySystemAccess.bind(window.navigator);\n } else {\n return null;\n }\n})();\n\nexport {\n requestMediaKeySystemAccess\n};\n","/**\n * @class SubtitleStreamController\n */\n\nimport Event from '../events';\nimport { logger } from '../utils/logger';\nimport Decrypter from '../crypt/decrypter';\nimport { BufferHelper } from '../utils/buffer-helper';\nimport { findFragmentByPDT, findFragmentByPTS } from './fragment-finders';\nimport { FragmentState } from './fragment-tracker';\nimport BaseStreamController, { State } from './base-stream-controller';\nimport { mergeSubtitlePlaylists } from './level-helper';\n\nconst { performance } = window;\nconst TICK_INTERVAL = 500; // how often to tick in ms\n\nexport class SubtitleStreamController extends BaseStreamController {\n constructor (hls, fragmentTracker) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHING,\n Event.ERROR,\n Event.KEY_LOADED,\n Event.FRAG_LOADED,\n Event.SUBTITLE_TRACKS_UPDATED,\n Event.SUBTITLE_TRACK_SWITCH,\n Event.SUBTITLE_TRACK_LOADED,\n Event.SUBTITLE_FRAG_PROCESSED,\n Event.LEVEL_UPDATED);\n\n this.fragmentTracker = fragmentTracker;\n this.config = hls.config;\n this.state = State.STOPPED;\n this.tracks = [];\n this.tracksBuffered = [];\n this.currentTrackId = -1;\n this.decrypter = new Decrypter(hls, hls.config);\n // lastAVStart stores the time in seconds for the start time of a level load\n this.lastAVStart = 0;\n this._onMediaSeeking = this.onMediaSeeking.bind(this);\n }\n\n startLoad () {\n this.stopLoad();\n this.state = State.IDLE;\n\n // Check if we already have a track with necessary details to load fragments\n const currentTrack = this.tracks[this.currentTrackId];\n if (currentTrack && currentTrack.details) {\n this.setInterval(TICK_INTERVAL);\n this.tick();\n }\n }\n\n onSubtitleFragProcessed (data) {\n const { frag, success } = data;\n this.fragPrevious = frag;\n this.state = State.IDLE;\n if (!success) {\n return;\n }\n\n const buffered = this.tracksBuffered[this.currentTrackId];\n if (!buffered) {\n return;\n }\n\n // Create/update a buffered array matching the interface used by BufferHelper.bufferedInfo\n // so we can re-use the logic used to detect how much have been buffered\n let timeRange;\n const fragStart = frag.start;\n for (let i = 0; i < buffered.length; i++) {\n if (fragStart >= buffered[i].start && fragStart <= buffered[i].end) {\n timeRange = buffered[i];\n break;\n }\n }\n\n const fragEnd = frag.start + frag.duration;\n if (timeRange) {\n timeRange.end = fragEnd;\n } else {\n timeRange = {\n start: fragStart,\n end: fragEnd\n };\n buffered.push(timeRange);\n }\n }\n\n onMediaAttached ({ media }) {\n this.media = media;\n media.addEventListener('seeking', this._onMediaSeeking);\n this.state = State.IDLE;\n }\n\n onMediaDetaching () {\n if (!this.media) {\n return;\n }\n this.media.removeEventListener('seeking', this._onMediaSeeking);\n this.fragmentTracker.removeAllFragments();\n this.currentTrackId = -1;\n this.tracks.forEach((track) => {\n this.tracksBuffered[track.id] = [];\n });\n this.media = null;\n this.state = State.STOPPED;\n }\n\n // If something goes wrong, proceed to next frag, if we were processing one.\n onError (data) {\n let frag = data.frag;\n // don't handle error not related to subtitle fragment\n if (!frag || frag.type !== 'subtitle') {\n return;\n }\n\n if (this.fragCurrent && this.fragCurrent.loader) {\n this.fragCurrent.loader.abort();\n }\n\n this.state = State.IDLE;\n }\n\n // Got all new subtitle tracks.\n onSubtitleTracksUpdated (data) {\n logger.log('subtitle tracks updated');\n this.tracksBuffered = [];\n this.tracks = data.subtitleTracks;\n this.tracks.forEach((track) => {\n this.tracksBuffered[track.id] = [];\n });\n }\n\n onSubtitleTrackSwitch (data) {\n this.currentTrackId = data.id;\n\n if (!this.tracks || !this.tracks.length || this.currentTrackId === -1) {\n this.clearInterval();\n return;\n }\n\n // Check if track has the necessary details to load fragments\n const currentTrack = this.tracks[this.currentTrackId];\n if (currentTrack && currentTrack.details) {\n this.setInterval(TICK_INTERVAL);\n }\n }\n\n // Got a new set of subtitle fragments.\n onSubtitleTrackLoaded (data) {\n const { id, details } = data;\n const { currentTrackId, tracks } = this;\n const currentTrack = tracks[currentTrackId];\n if (id >= tracks.length || id !== currentTrackId || !currentTrack) {\n return;\n }\n\n if (details.live) {\n mergeSubtitlePlaylists(currentTrack.details, details, this.lastAVStart);\n }\n currentTrack.details = details;\n this.setInterval(TICK_INTERVAL);\n }\n\n onKeyLoaded () {\n if (this.state === State.KEY_LOADING) {\n this.state = State.IDLE;\n }\n }\n\n onFragLoaded (data) {\n const fragCurrent = this.fragCurrent;\n const decryptData = data.frag.decryptdata;\n const fragLoaded = data.frag;\n const hls = this.hls;\n\n if (this.state === State.FRAG_LOADING &&\n fragCurrent &&\n data.frag.type === 'subtitle' &&\n fragCurrent.sn === data.frag.sn) {\n // check to see if the payload needs to be decrypted\n if (data.payload.byteLength > 0 && (decryptData && decryptData.key && decryptData.method === 'AES-128')) {\n let startTime = performance.now();\n\n // decrypt the subtitles\n this.decrypter.decrypt(data.payload, decryptData.key.buffer, decryptData.iv.buffer, function (decryptedData) {\n let endTime = performance.now();\n hls.trigger(Event.FRAG_DECRYPTED, { frag: fragLoaded, payload: decryptedData, stats: { tstart: startTime, tdecrypt: endTime } });\n });\n }\n }\n }\n\n onLevelUpdated ({ details }) {\n const frags = details.fragments;\n this.lastAVStart = frags.length ? frags[0].start : 0;\n }\n\n doTick () {\n if (!this.media) {\n this.state = State.IDLE;\n return;\n }\n\n switch (this.state) {\n case State.IDLE: {\n const { config, currentTrackId, fragmentTracker, media, tracks } = this;\n if (!tracks || !tracks[currentTrackId] || !tracks[currentTrackId].details) {\n break;\n }\n\n const { maxBufferHole, maxFragLookUpTolerance } = config;\n const maxConfigBuffer = Math.min(config.maxBufferLength, config.maxMaxBufferLength);\n const bufferedInfo = BufferHelper.bufferedInfo(this._getBuffered(), media.currentTime, maxBufferHole);\n const { end: bufferEnd, len: bufferLen } = bufferedInfo;\n\n const trackDetails = tracks[currentTrackId].details;\n const fragments = trackDetails.fragments;\n const fragLen = fragments.length;\n const end = fragments[fragLen - 1].start + fragments[fragLen - 1].duration;\n\n if (bufferLen > maxConfigBuffer) {\n return;\n }\n\n let foundFrag;\n const fragPrevious = this.fragPrevious;\n if (bufferEnd < end) {\n if (fragPrevious && trackDetails.hasProgramDateTime) {\n foundFrag = findFragmentByPDT(fragments, fragPrevious.endProgramDateTime, maxFragLookUpTolerance);\n }\n if (!foundFrag) {\n foundFrag = findFragmentByPTS(fragPrevious, fragments, bufferEnd, maxFragLookUpTolerance);\n }\n } else {\n foundFrag = fragments[fragLen - 1];\n }\n\n if (foundFrag && foundFrag.encrypted) {\n logger.log(`Loading key for ${foundFrag.sn}`);\n this.state = State.KEY_LOADING;\n this.hls.trigger(Event.KEY_LOADING, { frag: foundFrag });\n } else if (foundFrag && fragmentTracker.getState(foundFrag) === FragmentState.NOT_LOADED) {\n // only load if fragment is not loaded\n this.fragCurrent = foundFrag;\n this.state = State.FRAG_LOADING;\n this.hls.trigger(Event.FRAG_LOADING, { frag: foundFrag });\n }\n }\n }\n }\n\n stopLoad () {\n this.lastAVStart = 0;\n this.fragPrevious = null;\n super.stopLoad();\n }\n\n _getBuffered () {\n return this.tracksBuffered[this.currentTrackId] || [];\n }\n\n onMediaSeeking () {\n if (this.fragCurrent) {\n const currentTime = this.media ? this.media.currentTime : 0;\n const tolerance = this.config.maxFragLookUpTolerance;\n const fragStartOffset = this.fragCurrent.start - tolerance;\n const fragEndOffset = this.fragCurrent.start + this.fragCurrent.duration + tolerance;\n\n // check if position will be out of currently loaded frag range after seeking : if out, cancel frag load, if in, don't do anything\n if (currentTime < fragStartOffset || currentTime > fragEndOffset) {\n if (this.fragCurrent.loader) {\n this.fragCurrent.loader.abort();\n }\n\n this.fragmentTracker.removeFragment(this.fragCurrent);\n this.fragCurrent = null;\n this.fragPrevious = null;\n\n // switch to IDLE state to load new fragment\n this.state = State.IDLE;\n\n // speed up things\n this.tick();\n }\n }\n }\n}\n","/**\n * @author Stephan Hesse <disparat@gmail.com> | <tchakabam@gmail.com>\n *\n * DRM support for Hls.js\n */\n\nimport EventHandler from '../event-handler';\nimport Event from '../events';\nimport { ErrorTypes, ErrorDetails } from '../errors';\n\nimport { logger } from '../utils/logger';\nimport { DRMSystemOptions, EMEControllerConfig } from '../config';\nimport { KeySystems, MediaKeyFunc } from '../utils/mediakeys-helper';\n\nconst MAX_LICENSE_REQUEST_FAILURES = 3;\n\n/**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/MediaKeySystemConfiguration\n * @param {Array<string>} audioCodecs List of required audio codecs to support\n * @param {Array<string>} videoCodecs List of required video codecs to support\n * @param {object} drmSystemOptions Optional parameters/requirements for the key-system\n * @returns {Array<MediaSystemConfiguration>} An array of supported configurations\n */\n\nconst createWidevineMediaKeySystemConfigurations = function (\n audioCodecs: string[],\n videoCodecs: string[],\n drmSystemOptions: DRMSystemOptions\n): MediaKeySystemConfiguration[] { /* jshint ignore:line */\n const baseConfig: MediaKeySystemConfiguration = {\n // initDataTypes: ['keyids', 'mp4'],\n // label: \"\",\n // persistentState: \"not-allowed\", // or \"required\" ?\n // distinctiveIdentifier: \"not-allowed\", // or \"required\" ?\n // sessionTypes: ['temporary'],\n audioCapabilities: [], // { contentType: 'audio/mp4; codecs=\"mp4a.40.2\"' }\n videoCapabilities: [] // { contentType: 'video/mp4; codecs=\"avc1.42E01E\"' }\n };\n\n audioCodecs.forEach((codec) => {\n baseConfig.audioCapabilities!.push({\n contentType: `audio/mp4; codecs=\"${codec}\"`,\n robustness: drmSystemOptions.audioRobustness || ''\n });\n });\n videoCodecs.forEach((codec) => {\n baseConfig.videoCapabilities!.push({\n contentType: `video/mp4; codecs=\"${codec}\"`,\n robustness: drmSystemOptions.videoRobustness || ''\n });\n });\n\n return [\n baseConfig\n ];\n};\n\n/**\n * The idea here is to handle key-system (and their respective platforms) specific configuration differences\n * in order to work with the local requestMediaKeySystemAccess method.\n *\n * We can also rule-out platform-related key-system support at this point by throwing an error.\n *\n * @param {string} keySystem Identifier for the key-system, see `KeySystems` enum\n * @param {Array<string>} audioCodecs List of required audio codecs to support\n * @param {Array<string>} videoCodecs List of required video codecs to support\n * @throws will throw an error if a unknown key system is passed\n * @returns {Array<MediaSystemConfiguration>} A non-empty Array of MediaKeySystemConfiguration objects\n */\nconst getSupportedMediaKeySystemConfigurations = function (\n keySystem: KeySystems,\n audioCodecs: string[],\n videoCodecs: string[],\n drmSystemOptions: DRMSystemOptions\n): MediaKeySystemConfiguration[] {\n switch (keySystem) {\n case KeySystems.WIDEVINE:\n return createWidevineMediaKeySystemConfigurations(audioCodecs, videoCodecs, drmSystemOptions);\n default:\n throw new Error(`Unknown key-system: ${keySystem}`);\n }\n};\n\ninterface MediaKeysListItem {\n mediaKeys?: MediaKeys,\n mediaKeysSession?: MediaKeySession,\n mediaKeysSessionInitialized: boolean;\n mediaKeySystemAccess: MediaKeySystemAccess;\n mediaKeySystemDomain: KeySystems;\n}\n\n/**\n * Controller to deal with encrypted media extensions (EME)\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Encrypted_Media_Extensions_API\n *\n * @class\n * @constructor\n */\nclass EMEController extends EventHandler {\n private _widevineLicenseUrl?: string;\n private _licenseXhrSetup?: (xhr: XMLHttpRequest, url: string) => void;\n private _emeEnabled: boolean;\n private _requestMediaKeySystemAccess: MediaKeyFunc | null;\n private _drmSystemOptions: DRMSystemOptions;\n\n private _config: EMEControllerConfig;\n private _mediaKeysList: MediaKeysListItem[] = [];\n private _media: HTMLMediaElement | null = null;\n private _hasSetMediaKeys: boolean = false;\n private _requestLicenseFailureCount: number = 0;\n\n private mediaKeysPromise: Promise<MediaKeys> | null = null;\n\n /**\n * @constructs\n * @param {Hls} hls Our Hls.js instance\n */\n constructor (hls) {\n super(hls,\n Event.MEDIA_ATTACHED,\n Event.MEDIA_DETACHED,\n Event.MANIFEST_PARSED\n );\n this._config = hls.config;\n\n this._widevineLicenseUrl = this._config.widevineLicenseUrl;\n this._licenseXhrSetup = this._config.licenseXhrSetup;\n this._emeEnabled = this._config.emeEnabled;\n this._requestMediaKeySystemAccess = this._config.requestMediaKeySystemAccessFunc;\n this._drmSystemOptions = hls.config.drmSystemOptions;\n }\n\n /**\n * @param {string} keySystem Identifier for the key-system, see `KeySystems` enum\n * @returns {string} License server URL for key-system (if any configured, otherwise causes error)\n * @throws if a unsupported keysystem is passed\n */\n getLicenseServerUrl (keySystem: KeySystems): string {\n switch (keySystem) {\n case KeySystems.WIDEVINE:\n if (!this._widevineLicenseUrl) {\n break;\n }\n return this._widevineLicenseUrl;\n }\n\n throw new Error(`no license server URL configured for key-system \"${keySystem}\"`);\n }\n\n /**\n * Requests access object and adds it to our list upon success\n * @private\n * @param {string} keySystem System ID (see `KeySystems`)\n * @param {Array<string>} audioCodecs List of required audio codecs to support\n * @param {Array<string>} videoCodecs List of required video codecs to support\n * @throws When a unsupported KeySystem is passed\n */\n private _attemptKeySystemAccess (keySystem: KeySystems, audioCodecs: string[], videoCodecs: string[]) {\n // This can throw, but is caught in event handler callpath\n const mediaKeySystemConfigs = getSupportedMediaKeySystemConfigurations(keySystem, audioCodecs, videoCodecs, this._drmSystemOptions);\n\n logger.log('Requesting encrypted media key-system access');\n\n // expecting interface like window.navigator.requestMediaKeySystemAccess\n const keySystemAccessPromise = this.requestMediaKeySystemAccess(keySystem, mediaKeySystemConfigs);\n\n this.mediaKeysPromise = keySystemAccessPromise.then((mediaKeySystemAccess) =>\n this._onMediaKeySystemAccessObtained(keySystem, mediaKeySystemAccess));\n\n keySystemAccessPromise.catch((err) => {\n logger.error(`Failed to obtain key-system \"${keySystem}\" access:`, err);\n });\n }\n\n get requestMediaKeySystemAccess () {\n if (!this._requestMediaKeySystemAccess) {\n throw new Error('No requestMediaKeySystemAccess function configured');\n }\n\n return this._requestMediaKeySystemAccess;\n }\n\n /**\n * Handles obtaining access to a key-system\n * @private\n * @param {string} keySystem\n * @param {MediaKeySystemAccess} mediaKeySystemAccess https://developer.mozilla.org/en-US/docs/Web/API/MediaKeySystemAccess\n */\n private _onMediaKeySystemAccessObtained (keySystem: KeySystems, mediaKeySystemAccess: MediaKeySystemAccess): Promise<MediaKeys> {\n logger.log(`Access for key-system \"${keySystem}\" obtained`);\n\n const mediaKeysListItem: MediaKeysListItem = {\n mediaKeysSessionInitialized: false,\n mediaKeySystemAccess: mediaKeySystemAccess,\n mediaKeySystemDomain: keySystem\n };\n\n this._mediaKeysList.push(mediaKeysListItem);\n\n const mediaKeysPromise = Promise.resolve().then(() => mediaKeySystemAccess.createMediaKeys())\n .then((mediaKeys) => {\n mediaKeysListItem.mediaKeys = mediaKeys;\n\n logger.log(`Media-keys created for key-system \"${keySystem}\"`);\n\n this._onMediaKeysCreated();\n\n return mediaKeys;\n });\n\n mediaKeysPromise.catch((err) => {\n logger.error('Failed to create media-keys:', err);\n });\n\n return mediaKeysPromise;\n }\n\n /**\n * Handles key-creation (represents access to CDM). We are going to create key-sessions upon this\n * for all existing keys where no session exists yet.\n *\n * @private\n */\n private _onMediaKeysCreated () {\n // check for all key-list items if a session exists, otherwise, create one\n this._mediaKeysList.forEach((mediaKeysListItem) => {\n if (!mediaKeysListItem.mediaKeysSession) {\n // mediaKeys is definitely initialized here\n mediaKeysListItem.mediaKeysSession = mediaKeysListItem.mediaKeys!.createSession();\n this._onNewMediaKeySession(mediaKeysListItem.mediaKeysSession);\n }\n });\n }\n\n /**\n * @private\n * @param {*} keySession\n */\n private _onNewMediaKeySession (keySession: MediaKeySession) {\n logger.log(`New key-system session ${keySession.sessionId}`);\n\n keySession.addEventListener('message', (event: MediaKeyMessageEvent) => {\n this._onKeySessionMessage(keySession, event.message);\n }, false);\n }\n\n /**\n * @private\n * @param {MediaKeySession} keySession\n * @param {ArrayBuffer} message\n */\n private _onKeySessionMessage (keySession: MediaKeySession, message: ArrayBuffer) {\n logger.log('Got EME message event, creating license request');\n\n this._requestLicense(message, (data: ArrayBuffer) => {\n logger.log(`Received license data (length: ${data ? data.byteLength : data}), updating key-session`);\n keySession.update(data);\n });\n }\n\n /**\n * @private\n * @param e {MediaEncryptedEvent}\n */\n private _onMediaEncrypted = (e: MediaEncryptedEvent) => {\n logger.log(`Media is encrypted using \"${e.initDataType}\" init data type`);\n\n if (!this.mediaKeysPromise) {\n logger.error('Fatal: Media is encrypted but no CDM access or no keys have been requested');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_KEYS,\n fatal: true\n });\n return;\n }\n\n const finallySetKeyAndStartSession = (mediaKeys) => {\n if (!this._media) {\n return;\n }\n this._attemptSetMediaKeys(mediaKeys);\n this._generateRequestWithPreferredKeySession(e.initDataType, e.initData);\n };\n\n // Could use `Promise.finally` but some Promise polyfills are missing it\n this.mediaKeysPromise.then(finallySetKeyAndStartSession).catch(finallySetKeyAndStartSession);\n }\n\n /**\n * @private\n */\n private _attemptSetMediaKeys (mediaKeys?: MediaKeys) {\n if (!this._media) {\n throw new Error('Attempted to set mediaKeys without first attaching a media element');\n }\n\n if (!this._hasSetMediaKeys) {\n // FIXME: see if we can/want/need-to really to deal with several potential key-sessions?\n const keysListItem = this._mediaKeysList[0];\n if (!keysListItem || !keysListItem.mediaKeys) {\n logger.error('Fatal: Media is encrypted but no CDM access or no keys have been obtained yet');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_KEYS,\n fatal: true\n });\n return;\n }\n\n logger.log('Setting keys for encrypted media');\n\n this._media.setMediaKeys(keysListItem.mediaKeys);\n this._hasSetMediaKeys = true;\n }\n }\n\n /**\n * @private\n */\n private _generateRequestWithPreferredKeySession (initDataType: string, initData: ArrayBuffer | null) {\n // FIXME: see if we can/want/need-to really to deal with several potential key-sessions?\n const keysListItem = this._mediaKeysList[0];\n if (!keysListItem) {\n logger.error('Fatal: Media is encrypted but not any key-system access has been obtained yet');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_ACCESS,\n fatal: true\n });\n return;\n }\n\n if (keysListItem.mediaKeysSessionInitialized) {\n logger.warn('Key-Session already initialized but requested again');\n return;\n }\n\n const keySession = keysListItem.mediaKeysSession;\n if (!keySession) {\n logger.error('Fatal: Media is encrypted but no key-session existing');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_SESSION,\n fatal: true\n });\n return;\n }\n\n // initData is null if the media is not CORS-same-origin\n if (!initData) {\n logger.warn('Fatal: initData required for generating a key session is null');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_INIT_DATA,\n fatal: true\n });\n return;\n }\n\n logger.log(`Generating key-session request for \"${initDataType}\" init data type`);\n keysListItem.mediaKeysSessionInitialized = true;\n\n keySession.generateRequest(initDataType, initData)\n .then(() => {\n logger.debug('Key-session generation succeeded');\n })\n .catch((err) => {\n logger.error('Error generating key-session request:', err);\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_SESSION,\n fatal: false\n });\n });\n }\n\n /**\n * @private\n * @param {string} url License server URL\n * @param {ArrayBuffer} keyMessage Message data issued by key-system\n * @param {function} callback Called when XHR has succeeded\n * @returns {XMLHttpRequest} Unsent (but opened state) XHR object\n * @throws if XMLHttpRequest construction failed\n */\n private _createLicenseXhr (url: string, keyMessage: ArrayBuffer, callback: (data: ArrayBuffer) => void): XMLHttpRequest {\n const xhr = new XMLHttpRequest();\n const licenseXhrSetup = this._licenseXhrSetup;\n\n try {\n if (licenseXhrSetup) {\n try {\n licenseXhrSetup(xhr, url);\n } catch (e) {\n // let's try to open before running setup\n xhr.open('POST', url, true);\n licenseXhrSetup(xhr, url);\n }\n }\n // if licenseXhrSetup did not yet call open, let's do it now\n if (!xhr.readyState) {\n xhr.open('POST', url, true);\n }\n } catch (e) {\n // IE11 throws an exception on xhr.open if attempting to access an HTTP resource over HTTPS\n throw new Error(`issue setting up KeySystem license XHR ${e}`);\n }\n\n // Because we set responseType to ArrayBuffer here, callback is typed as handling only array buffers\n xhr.responseType = 'arraybuffer';\n xhr.onreadystatechange =\n this._onLicenseRequestReadyStageChange.bind(this, xhr, url, keyMessage, callback);\n return xhr;\n }\n\n /**\n * @private\n * @param {XMLHttpRequest} xhr\n * @param {string} url License server URL\n * @param {ArrayBuffer} keyMessage Message data issued by key-system\n * @param {function} callback Called when XHR has succeeded\n */\n private _onLicenseRequestReadyStageChange (xhr: XMLHttpRequest, url: string, keyMessage: ArrayBuffer, callback: (data: ArrayBuffer) => void) {\n switch (xhr.readyState) {\n case 4:\n if (xhr.status === 200) {\n this._requestLicenseFailureCount = 0;\n logger.log('License request succeeded');\n\n if (xhr.responseType !== 'arraybuffer') {\n logger.warn('xhr response type was not set to the expected arraybuffer for license request');\n }\n callback(xhr.response);\n } else {\n logger.error(`License Request XHR failed (${url}). Status: ${xhr.status} (${xhr.statusText})`);\n this._requestLicenseFailureCount++;\n if (this._requestLicenseFailureCount > MAX_LICENSE_REQUEST_FAILURES) {\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_LICENSE_REQUEST_FAILED,\n fatal: true\n });\n return;\n }\n\n const attemptsLeft = MAX_LICENSE_REQUEST_FAILURES - this._requestLicenseFailureCount + 1;\n logger.warn(`Retrying license request, ${attemptsLeft} attempts left`);\n this._requestLicense(keyMessage, callback);\n }\n break;\n }\n }\n\n /**\n * @private\n * @param {MediaKeysListItem} keysListItem\n * @param {ArrayBuffer} keyMessage\n * @returns {ArrayBuffer} Challenge data posted to license server\n * @throws if KeySystem is unsupported\n */\n private _generateLicenseRequestChallenge (keysListItem: MediaKeysListItem, keyMessage: ArrayBuffer): ArrayBuffer {\n switch (keysListItem.mediaKeySystemDomain) {\n // case KeySystems.PLAYREADY:\n // from https://github.com/MicrosoftEdge/Demos/blob/master/eme/scripts/demo.js\n /*\n if (this.licenseType !== this.LICENSE_TYPE_WIDEVINE) {\n // For PlayReady CDMs, we need to dig the Challenge out of the XML.\n var keyMessageXml = new DOMParser().parseFromString(String.fromCharCode.apply(null, new Uint16Array(keyMessage)), 'application/xml');\n if (keyMessageXml.getElementsByTagName('Challenge')[0]) {\n challenge = atob(keyMessageXml.getElementsByTagName('Challenge')[0].childNodes[0].nodeValue);\n } else {\n throw 'Cannot find <Challenge> in key message';\n }\n var headerNames = keyMessageXml.getElementsByTagName('name');\n var headerValues = keyMessageXml.getElementsByTagName('value');\n if (headerNames.length !== headerValues.length) {\n throw 'Mismatched header <name>/<value> pair in key message';\n }\n for (var i = 0; i < headerNames.length; i++) {\n xhr.setRequestHeader(headerNames[i].childNodes[0].nodeValue, headerValues[i].childNodes[0].nodeValue);\n }\n }\n break;\n */\n case KeySystems.WIDEVINE:\n // For Widevine CDMs, the challenge is the keyMessage.\n return keyMessage;\n }\n\n throw new Error(`unsupported key-system: ${keysListItem.mediaKeySystemDomain}`);\n }\n\n /**\n * @private\n * @param keyMessage\n * @param callback\n */\n private _requestLicense (keyMessage: ArrayBuffer, callback: (data: ArrayBuffer) => void) {\n logger.log('Requesting content license for key-system');\n\n const keysListItem = this._mediaKeysList[0];\n if (!keysListItem) {\n logger.error('Fatal error: Media is encrypted but no key-system access has been obtained yet');\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_NO_ACCESS,\n fatal: true\n });\n return;\n }\n\n try {\n const url = this.getLicenseServerUrl(keysListItem.mediaKeySystemDomain);\n const xhr = this._createLicenseXhr(url, keyMessage, callback);\n logger.log(`Sending license request to URL: ${url}`);\n const challenge = this._generateLicenseRequestChallenge(keysListItem, keyMessage);\n xhr.send(challenge);\n } catch (e) {\n logger.error(`Failure requesting DRM license: ${e}`);\n this.hls.trigger(Event.ERROR, {\n type: ErrorTypes.KEY_SYSTEM_ERROR,\n details: ErrorDetails.KEY_SYSTEM_LICENSE_REQUEST_FAILED,\n fatal: true\n });\n }\n }\n\n onMediaAttached (data: { media: HTMLMediaElement; }) {\n if (!this._emeEnabled) {\n return;\n }\n\n const media = data.media;\n\n // keep reference of media\n this._media = media;\n\n media.addEventListener('encrypted', this._onMediaEncrypted);\n }\n\n onMediaDetached () {\n const media = this._media;\n const mediaKeysList = this._mediaKeysList;\n if (!media) {\n return;\n }\n media.removeEventListener('encrypted', this._onMediaEncrypted);\n this._media = null;\n this._mediaKeysList = [];\n // Close all sessions and remove media keys from the video element.\n Promise.all(mediaKeysList.map((mediaKeysListItem) => {\n if (mediaKeysListItem.mediaKeysSession) {\n return mediaKeysListItem.mediaKeysSession.close().catch(() => {\n // Ignore errors when closing the sessions. Closing a session that\n // generated no key requests will throw an error.\n });\n }\n })).then(() => {\n return media.setMediaKeys(null);\n }).catch(() => {\n // Ignore any failures while removing media keys from the video element.\n });\n }\n\n // TODO: Use manifest types here when they are defined\n onManifestParsed (data: any) {\n if (!this._emeEnabled) {\n return;\n }\n\n const audioCodecs = data.levels.map((level) => level.audioCodec);\n const videoCodecs = data.levels.map((level) => level.videoCodec);\n\n this._attemptKeySystemAccess(KeySystems.WIDEVINE, audioCodecs, videoCodecs);\n }\n}\n\nexport default EMEController;\n","/**\n * HLS config\n */\n\nimport AbrController from './controller/abr-controller';\nimport BufferController from './controller/buffer-controller';\nimport CapLevelController from './controller/cap-level-controller';\nimport FPSController from './controller/fps-controller';\nimport XhrLoader from './utils/xhr-loader';\n// import FetchLoader from './utils/fetch-loader';\n\nimport AudioTrackController from './controller/audio-track-controller';\nimport AudioStreamController from './controller/audio-stream-controller';\n\nimport * as Cues from './utils/cues';\nimport TimelineController from './controller/timeline-controller';\nimport SubtitleTrackController from './controller/subtitle-track-controller';\nimport { SubtitleStreamController } from './controller/subtitle-stream-controller';\nimport EMEController from './controller/eme-controller';\nimport { requestMediaKeySystemAccess, MediaKeyFunc } from './utils/mediakeys-helper';\n\ntype ABRControllerConfig = {\n abrEwmaFastLive: number,\n abrEwmaSlowLive: number,\n abrEwmaFastVoD: number,\n abrEwmaSlowVoD: number,\n abrEwmaDefaultEstimate: number,\n abrBandWidthFactor: number,\n abrBandWidthUpFactor: number,\n abrMaxWithRealBitrate: boolean,\n maxStarvationDelay: number,\n maxLoadingDelay: number,\n};\n\nexport type BufferControllerConfig = {\n appendErrorMaxRetry: number,\n liveDurationInfinity: boolean,\n liveBackBufferLength: number,\n};\n\ntype CapLevelControllerConfig = {\n capLevelToPlayerSize: boolean\n};\n\nexport type DRMSystemOptions = {\n audioRobustness?: string,\n videoRobustness?: string,\n}\n\nexport type EMEControllerConfig = {\n licenseXhrSetup?: (xhr: XMLHttpRequest, url: string) => void,\n emeEnabled: boolean,\n widevineLicenseUrl?: string,\n drmSystemOptions: DRMSystemOptions,\n requestMediaKeySystemAccessFunc: MediaKeyFunc | null,\n};\n\ntype FragmentLoaderConfig = {\n fLoader: any, // TODO(typescript-loader): Once Loader is typed fill this in\n\n fragLoadingTimeOut: number,\n fragLoadingMaxRetry: number,\n fragLoadingRetryDelay: number,\n fragLoadingMaxRetryTimeout: number,\n};\n\ntype FPSControllerConfig = {\n capLevelOnFPSDrop: boolean,\n fpsDroppedMonitoringPeriod: number,\n fpsDroppedMonitoringThreshold: number,\n};\n\ntype LevelControllerConfig = {\n startLevel?: number\n};\n\ntype MP4RemuxerConfig = {\n stretchShortVideoTrack: boolean,\n maxAudioFramesDrift: number,\n};\n\ntype PlaylistLoaderConfig = {\n pLoader: any, // TODO(typescript-loader): Once Loader is typed fill this in\n\n manifestLoadingTimeOut: number,\n manifestLoadingMaxRetry: number,\n manifestLoadingRetryDelay: number,\n manifestLoadingMaxRetryTimeout: number,\n\n levelLoadingTimeOut: number,\n levelLoadingMaxRetry: number,\n levelLoadingRetryDelay: number,\n levelLoadingMaxRetryTimeout: number\n};\n\ntype StreamControllerConfig = {\n autoStartLoad: boolean,\n startPosition: number,\n defaultAudioCodec?: string,\n initialLiveManifestSize: number,\n maxBufferLength: number,\n maxBufferSize: number,\n maxBufferHole: number,\n\n lowBufferWatchdogPeriod: number,\n highBufferWatchdogPeriod: number,\n nudgeOffset: number,\n nudgeMaxRetry: number,\n maxFragLookUpTolerance: number,\n liveSyncDurationCount: number,\n liveMaxLatencyDurationCount: number,\n liveSyncDuration?: number,\n liveMaxLatencyDuration?: number,\n maxMaxBufferLength: number,\n\n startFragPrefetch: boolean,\n testBandwidth: boolean\n};\n\ntype TimelineControllerConfig = {\n cueHandler: Cues.CuesInterface,\n enableCEA708Captions: boolean,\n enableWebVTT: boolean,\n captionsTextTrack1Label: string,\n captionsTextTrack1LanguageCode: string,\n captionsTextTrack2Label: string,\n captionsTextTrack2LanguageCode: string,\n captionsTextTrack3Label: string,\n captionsTextTrack3LanguageCode: string,\n captionsTextTrack4Label: string,\n captionsTextTrack4LanguageCode: string,\n renderTextTracksNatively: boolean,\n};\n\ntype TSDemuxerConfig = {\n forceKeyFrameOnDiscontinuity: boolean,\n};\n\nexport type HlsConfig =\n {\n debug: boolean,\n enableWorker: boolean,\n enableSoftwareAES: boolean,\n minAutoBitrate: number,\n loader: any, // TODO(typescript-xhrloader): Type once XHR is done\n xhrSetup?: (xhr: XMLHttpRequest, url: string) => void,\n\n // Alt Audio\n audioStreamController?: any, // TODO(typescript-audiostreamcontroller): Type once file is done\n audioTrackController?: any, // TODO(typescript-audiotrackcontroller): Type once file is done\n // Subtitle\n subtitleStreamController?: any, // TODO(typescript-subtitlestreamcontroller): Type once file is done\n subtitleTrackController?: any, // TODO(typescript-subtitletrackcontroller): Type once file is done\n timelineController?: any, // TODO(typescript-timelinecontroller): Type once file is done\n // EME\n emeController?: typeof EMEController,\n\n abrController: any, // TODO(typescript-abrcontroller): Type once file is done\n bufferController: typeof BufferController,\n capLevelController: any, // TODO(typescript-caplevelcontroller): Type once file is done\n fpsController: any, // TODO(typescript-fpscontroller): Type once file is done\n } &\n ABRControllerConfig &\n BufferControllerConfig &\n CapLevelControllerConfig &\n EMEControllerConfig &\n FPSControllerConfig &\n FragmentLoaderConfig &\n LevelControllerConfig &\n MP4RemuxerConfig &\n PlaylistLoaderConfig &\n StreamControllerConfig &\n TimelineControllerConfig &\n TSDemuxerConfig;\n\n// If possible, keep hlsDefaultConfig shallow\n// It is cloned whenever a new Hls instance is created, by keeping the config\n// shallow the properties are cloned, and we don't end up manipulating the default\nexport const hlsDefaultConfig: HlsConfig = {\n autoStartLoad: true, // used by stream-controller\n startPosition: -1, // used by stream-controller\n defaultAudioCodec: void 0, // used by stream-controller\n debug: false, // used by logger\n capLevelOnFPSDrop: false, // used by fps-controller\n capLevelToPlayerSize: false, // used by cap-level-controller\n initialLiveManifestSize: 1, // used by stream-controller\n maxBufferLength: 30, // used by stream-controller\n maxBufferSize: 60 * 1000 * 1000, // used by stream-controller\n maxBufferHole: 0.5, // used by stream-controller\n\n lowBufferWatchdogPeriod: 0.5, // used by stream-controller\n highBufferWatchdogPeriod: 3, // used by stream-controller\n nudgeOffset: 0.1, // used by stream-controller\n nudgeMaxRetry: 3, // used by stream-controller\n maxFragLookUpTolerance: 0.25, // used by stream-controller\n liveSyncDurationCount: 3, // used by stream-controller\n liveMaxLatencyDurationCount: Infinity, // used by stream-controller\n liveSyncDuration: void 0, // used by stream-controller\n liveMaxLatencyDuration: void 0, // used by stream-controller\n liveDurationInfinity: false, // used by buffer-controller\n liveBackBufferLength: Infinity, // used by buffer-controller\n maxMaxBufferLength: 600, // used by stream-controller\n enableWorker: true, // used by demuxer\n enableSoftwareAES: true, // used by decrypter\n manifestLoadingTimeOut: 10000, // used by playlist-loader\n manifestLoadingMaxRetry: 1, // used by playlist-loader\n manifestLoadingRetryDelay: 1000, // used by playlist-loader\n manifestLoadingMaxRetryTimeout: 64000, // used by playlist-loader\n startLevel: void 0, // used by level-controller\n levelLoadingTimeOut: 10000, // used by playlist-loader\n levelLoadingMaxRetry: 4, // used by playlist-loader\n levelLoadingRetryDelay: 1000, // used by playlist-loader\n levelLoadingMaxRetryTimeout: 64000, // used by playlist-loader\n fragLoadingTimeOut: 20000, // used by fragment-loader\n fragLoadingMaxRetry: 6, // used by fragment-loader\n fragLoadingRetryDelay: 1000, // used by fragment-loader\n fragLoadingMaxRetryTimeout: 64000, // used by fragment-loader\n startFragPrefetch: false, // used by stream-controller\n fpsDroppedMonitoringPeriod: 5000, // used by fps-controller\n fpsDroppedMonitoringThreshold: 0.2, // used by fps-controller\n appendErrorMaxRetry: 3, // used by buffer-controller\n loader: XhrLoader,\n // loader: FetchLoader,\n fLoader: void 0, // used by fragment-loader\n pLoader: void 0, // used by playlist-loader\n xhrSetup: void 0, // used by xhr-loader\n licenseXhrSetup: void 0, // used by eme-controller\n // fetchSetup: void 0,\n abrController: AbrController,\n bufferController: BufferController,\n capLevelController: CapLevelController,\n fpsController: FPSController,\n stretchShortVideoTrack: false, // used by mp4-remuxer\n maxAudioFramesDrift: 1, // used by mp4-remuxer\n forceKeyFrameOnDiscontinuity: true, // used by ts-demuxer\n abrEwmaFastLive: 3, // used by abr-controller\n abrEwmaSlowLive: 9, // used by abr-controller\n abrEwmaFastVoD: 3, // used by abr-controller\n abrEwmaSlowVoD: 9, // used by abr-controller\n abrEwmaDefaultEstimate: 5e5, // 500 kbps // used by abr-controller\n abrBandWidthFactor: 0.95, // used by abr-controller\n abrBandWidthUpFactor: 0.7, // used by abr-controller\n abrMaxWithRealBitrate: false, // used by abr-controller\n maxStarvationDelay: 4, // used by abr-controller\n maxLoadingDelay: 4, // used by abr-controller\n minAutoBitrate: 0, // used by hls\n emeEnabled: false, // used by eme-controller\n widevineLicenseUrl: void 0, // used by eme-controller\n drmSystemOptions: {}, // used by eme-controller\n requestMediaKeySystemAccessFunc: requestMediaKeySystemAccess, // used by eme-controller\n testBandwidth: true,\n\n // Dynamic Modules\n ...timelineConfig(),\n subtitleStreamController: (__USE_SUBTITLES__) ? SubtitleStreamController : void 0,\n subtitleTrackController: (__USE_SUBTITLES__) ? SubtitleTrackController : void 0,\n timelineController: (__USE_SUBTITLES__) ? TimelineController : void 0,\n audioStreamController: (__USE_ALT_AUDIO__) ? AudioStreamController : void 0,\n audioTrackController: (__USE_ALT_AUDIO__) ? AudioTrackController : void 0,\n emeController: (__USE_EME_DRM__) ? EMEController : void 0\n};\n\nfunction timelineConfig (): TimelineControllerConfig {\n return {\n cueHandler: Cues, // used by timeline-controller\n enableCEA708Captions: __USE_SUBTITLES__, // used by timeline-controller\n enableWebVTT: __USE_SUBTITLES__, // used by timeline-controller\n captionsTextTrack1Label: 'English', // used by timeline-controller\n captionsTextTrack1LanguageCode: 'en', // used by timeline-controller\n captionsTextTrack2Label: 'Spanish', // used by timeline-controller\n captionsTextTrack2LanguageCode: 'es', // used by timeline-controller\n captionsTextTrack3Label: 'Unknown CC', // used by timeline-controller\n captionsTextTrack3LanguageCode: '', // used by timeline-controller\n captionsTextTrack4Label: 'Unknown CC', // used by timeline-controller\n captionsTextTrack4LanguageCode: '', // used by timeline-controller\n renderTextTracksNatively: true\n };\n}\n","import * as URLToolkit from 'url-toolkit';\n\nimport {\n ErrorTypes,\n ErrorDetails\n} from './errors';\n\nimport PlaylistLoader from './loader/playlist-loader';\nimport FragmentLoader from './loader/fragment-loader';\nimport KeyLoader from './loader/key-loader';\n\nimport { FragmentTracker } from './controller/fragment-tracker';\nimport StreamController from './controller/stream-controller';\nimport LevelController from './controller/level-controller';\nimport ID3TrackController from './controller/id3-track-controller';\n\nimport { isSupported } from './is-supported';\nimport { logger, enableLogs } from './utils/logger';\nimport { hlsDefaultConfig, HlsConfig } from './config';\n\nimport HlsEvents from './events';\n\nimport { Observer } from './observer';\n\n/**\n * @module Hls\n * @class\n * @constructor\n */\nexport default class Hls extends Observer {\n public static defaultConfig?: HlsConfig;\n public config: HlsConfig;\n\n private _autoLevelCapping: number;\n private abrController: any;\n private capLevelController: any;\n private levelController: LevelController;\n private streamController: StreamController;\n private networkControllers: any[];\n private audioTrackController: any;\n private subtitleTrackController: any;\n private emeController: any;\n private coreComponents: any[];\n private media: HTMLMediaElement | null = null;\n private url: string | null = null;\n\n /**\n * @type {string}\n */\n static get version (): string {\n return __VERSION__;\n }\n\n /**\n * @type {boolean}\n */\n static isSupported (): boolean {\n return isSupported();\n }\n\n /**\n * @type {HlsEvents}\n */\n static get Events () {\n return HlsEvents;\n }\n\n /**\n * @type {HlsErrorTypes}\n */\n static get ErrorTypes () {\n return ErrorTypes;\n }\n\n /**\n * @type {HlsErrorDetails}\n */\n static get ErrorDetails () {\n return ErrorDetails;\n }\n\n /**\n * @type {HlsConfig}\n */\n static get DefaultConfig (): HlsConfig {\n if (!Hls.defaultConfig) {\n return hlsDefaultConfig;\n }\n\n return Hls.defaultConfig;\n }\n\n /**\n * @type {HlsConfig}\n */\n static set DefaultConfig (defaultConfig: HlsConfig) {\n Hls.defaultConfig = defaultConfig;\n }\n\n /**\n * Creates an instance of an HLS client that can attach to exactly one `HTMLMediaElement`.\n *\n * @constructs Hls\n * @param {HlsConfig} config\n */\n constructor (userConfig: Partial<HlsConfig> = {}) {\n super();\n\n const defaultConfig = Hls.DefaultConfig;\n\n if ((userConfig.liveSyncDurationCount || userConfig.liveMaxLatencyDurationCount) && (userConfig.liveSyncDuration || userConfig.liveMaxLatencyDuration)) {\n throw new Error('Illegal hls.js config: don\\'t mix up liveSyncDurationCount/liveMaxLatencyDurationCount and liveSyncDuration/liveMaxLatencyDuration');\n }\n\n // Shallow clone\n this.config = {\n ...defaultConfig,\n ...userConfig\n };\n\n const { config } = this;\n\n if (config.liveMaxLatencyDurationCount !== void 0 && config.liveMaxLatencyDurationCount <= config.liveSyncDurationCount) {\n throw new Error('Illegal hls.js config: \"liveMaxLatencyDurationCount\" must be gt \"liveSyncDurationCount\"');\n }\n\n if (config.liveMaxLatencyDuration !== void 0 && (config.liveSyncDuration === void 0 || config.liveMaxLatencyDuration <= config.liveSyncDuration)) {\n throw new Error('Illegal hls.js config: \"liveMaxLatencyDuration\" must be gt \"liveSyncDuration\"');\n }\n\n enableLogs(config.debug);\n\n this._autoLevelCapping = -1;\n\n // core controllers and network loaders\n\n /**\n * @member {AbrController} abrController\n */\n const abrController = this.abrController = new config.abrController(this); // eslint-disable-line new-cap\n const bufferController = new config.bufferController(this); // eslint-disable-line new-cap\n const capLevelController = this.capLevelController = new config.capLevelController(this); // eslint-disable-line new-cap\n const fpsController = new config.fpsController(this); // eslint-disable-line new-cap\n const playListLoader = new PlaylistLoader(this);\n const fragmentLoader = new FragmentLoader(this);\n const keyLoader = new KeyLoader(this);\n const id3TrackController = new ID3TrackController(this);\n\n // network controllers\n\n /**\n * @member {LevelController} levelController\n */\n const levelController = this.levelController = new LevelController(this);\n\n // FIXME: FragmentTracker must be defined before StreamController because the order of event handling is important\n const fragmentTracker = new FragmentTracker(this);\n\n /**\n * @member {StreamController} streamController\n */\n const streamController = this.streamController = new StreamController(this, fragmentTracker);\n\n let networkControllers = [levelController, streamController];\n\n // optional audio stream controller\n /**\n * @var {ICoreComponent | Controller}\n */\n let Controller = config.audioStreamController;\n if (Controller) {\n networkControllers.push(new Controller(this, fragmentTracker));\n }\n\n /**\n * @member {INetworkController[]} networkControllers\n */\n this.networkControllers = networkControllers;\n\n /**\n * @var {ICoreComponent[]}\n */\n const coreComponents = [\n playListLoader,\n fragmentLoader,\n keyLoader,\n abrController,\n bufferController,\n capLevelController,\n fpsController,\n id3TrackController,\n fragmentTracker\n ];\n\n // optional audio track and subtitle controller\n Controller = config.audioTrackController;\n if (Controller) {\n const audioTrackController = new Controller(this);\n\n /**\n * @member {AudioTrackController} audioTrackController\n */\n this.audioTrackController = audioTrackController;\n coreComponents.push(audioTrackController);\n }\n\n Controller = config.subtitleTrackController;\n if (Controller) {\n const subtitleTrackController = new Controller(this);\n\n /**\n * @member {SubtitleTrackController} subtitleTrackController\n */\n this.subtitleTrackController = subtitleTrackController;\n networkControllers.push(subtitleTrackController);\n }\n\n Controller = config.emeController;\n if (Controller) {\n const emeController = new Controller(this);\n\n /**\n * @member {EMEController} emeController\n */\n this.emeController = emeController;\n coreComponents.push(emeController);\n }\n\n // optional subtitle controllers\n Controller = config.subtitleStreamController;\n if (Controller) {\n networkControllers.push(new Controller(this, fragmentTracker));\n }\n Controller = config.timelineController;\n if (Controller) {\n coreComponents.push(new Controller(this));\n }\n\n /**\n * @member {ICoreComponent[]}\n */\n this.coreComponents = coreComponents;\n }\n\n /**\n * Dispose of the instance\n */\n destroy () {\n logger.log('destroy');\n this.trigger(HlsEvents.DESTROYING);\n this.detachMedia();\n this.coreComponents.concat(this.networkControllers).forEach(component => {\n component.destroy();\n });\n this.url = null;\n this.removeAllListeners();\n this._autoLevelCapping = -1;\n }\n\n /**\n * Attach a media element\n * @param {HTMLMediaElement} media\n */\n attachMedia (media: HTMLMediaElement) {\n logger.log('attachMedia');\n this.media = media;\n this.trigger(HlsEvents.MEDIA_ATTACHING, { media: media });\n }\n\n /**\n * Detach from the media\n */\n detachMedia () {\n logger.log('detachMedia');\n this.trigger(HlsEvents.MEDIA_DETACHING);\n this.media = null;\n }\n\n /**\n * Set the source URL. Can be relative or absolute.\n * @param {string} url\n */\n loadSource (url: string) {\n url = URLToolkit.buildAbsoluteURL(window.location.href, url, { alwaysNormalize: true });\n logger.log(`loadSource:${url}`);\n this.url = url;\n // when attaching to a source URL, trigger a playlist load\n this.trigger(HlsEvents.MANIFEST_LOADING, { url: url });\n }\n\n /**\n * Start loading data from the stream source.\n * Depending on default config, client starts loading automatically when a source is set.\n *\n * @param {number} startPosition Set the start position to stream from\n * @default -1 None (from earliest point)\n */\n startLoad (startPosition: number = -1) {\n logger.log(`startLoad(${startPosition})`);\n this.networkControllers.forEach(controller => {\n controller.startLoad(startPosition);\n });\n }\n\n /**\n * Stop loading of any stream data.\n */\n stopLoad () {\n logger.log('stopLoad');\n this.networkControllers.forEach(controller => {\n controller.stopLoad();\n });\n }\n\n /**\n * Swap through possible audio codecs in the stream (for example to switch from stereo to 5.1)\n */\n swapAudioCodec () {\n logger.log('swapAudioCodec');\n this.streamController.swapAudioCodec();\n }\n\n /**\n * When the media-element fails, this allows to detach and then re-attach it\n * as one call (convenience method).\n *\n * Automatic recovery of media-errors by this process is configurable.\n */\n recoverMediaError () {\n logger.log('recoverMediaError');\n let media = this.media;\n this.detachMedia();\n if (media) {\n this.attachMedia(media);\n }\n }\n\n /**\n * Remove a loaded level from the list of levels, or a level url in from a list of redundant level urls.\n * This can be used to remove a rendition or playlist url that errors frequently from the list of levels that a user\n * or hls.js can choose from.\n *\n * @param levelIndex {number} The quality level index to of the level to remove\n * @param urlId {number} The quality level url index in the case that fallback levels are available. Defaults to 0.\n */\n removeLevel (levelIndex, urlId = 0) {\n this.levelController.removeLevel(levelIndex, urlId);\n }\n\n /**\n * @type {QualityLevel[]}\n */\n // todo(typescript-levelController)\n get levels (): any[] {\n return this.levelController.levels;\n }\n\n /**\n * Index of quality level currently played\n * @type {number}\n */\n get currentLevel (): number {\n return this.streamController.currentLevel;\n }\n\n /**\n * Set quality level index immediately .\n * This will flush the current buffer to replace the quality asap.\n * That means playback will interrupt at least shortly to re-buffer and re-sync eventually.\n * @param newLevel {number} -1 for automatic level selection\n */\n set currentLevel (newLevel: number) {\n logger.log(`set currentLevel:${newLevel}`);\n this.loadLevel = newLevel;\n this.streamController.immediateLevelSwitch();\n }\n\n /**\n * Index of next quality level loaded as scheduled by stream controller.\n * @type {number}\n */\n get nextLevel (): number {\n return this.streamController.nextLevel;\n }\n\n /**\n * Set quality level index for next loaded data.\n * This will switch the video quality asap, without interrupting playback.\n * May abort current loading of data, and flush parts of buffer (outside currently played fragment region).\n * @type {number} -1 for automatic level selection\n */\n set nextLevel (newLevel: number) {\n logger.log(`set nextLevel:${newLevel}`);\n this.levelController.manualLevel = newLevel;\n this.streamController.nextLevelSwitch();\n }\n\n /**\n * Return the quality level of the currently or last (of none is loaded currently) segment\n * @type {number}\n */\n get loadLevel (): number {\n return this.levelController.level;\n }\n\n /**\n * Set quality level index for next loaded data in a conservative way.\n * This will switch the quality without flushing, but interrupt current loading.\n * Thus the moment when the quality switch will appear in effect will only be after the already existing buffer.\n * @type {number} newLevel -1 for automatic level selection\n */\n set loadLevel (newLevel: number) {\n logger.log(`set loadLevel:${newLevel}`);\n this.levelController.manualLevel = newLevel;\n }\n\n /**\n * get next quality level loaded\n * @type {number}\n */\n get nextLoadLevel (): number {\n return this.levelController.nextLoadLevel;\n }\n\n /**\n * Set quality level of next loaded segment in a fully \"non-destructive\" way.\n * Same as `loadLevel` but will wait for next switch (until current loading is done).\n * @type {number} level\n */\n set nextLoadLevel (level: number) {\n this.levelController.nextLoadLevel = level;\n }\n\n /**\n * Return \"first level\": like a default level, if not set,\n * falls back to index of first level referenced in manifest\n * @type {number}\n */\n get firstLevel (): number {\n return Math.max(this.levelController.firstLevel, this.minAutoLevel);\n }\n\n /**\n * Sets \"first-level\", see getter.\n * @type {number}\n */\n set firstLevel (newLevel: number) {\n logger.log(`set firstLevel:${newLevel}`);\n this.levelController.firstLevel = newLevel;\n }\n\n /**\n * Return start level (level of first fragment that will be played back)\n * if not overrided by user, first level appearing in manifest will be used as start level\n * if -1 : automatic start level selection, playback will start from level matching download bandwidth\n * (determined from download of first segment)\n * @type {number}\n */\n get startLevel (): number {\n return this.levelController.startLevel;\n }\n\n /**\n * set start level (level of first fragment that will be played back)\n * if not overrided by user, first level appearing in manifest will be used as start level\n * if -1 : automatic start level selection, playback will start from level matching download bandwidth\n * (determined from download of first segment)\n * @type {number} newLevel\n */\n set startLevel (newLevel: number) {\n logger.log(`set startLevel:${newLevel}`);\n // if not in automatic start level detection, ensure startLevel is greater than minAutoLevel\n if (newLevel !== -1) {\n newLevel = Math.max(newLevel, this.minAutoLevel);\n }\n\n this.levelController.startLevel = newLevel;\n }\n\n /**\n * set dynamically set capLevelToPlayerSize against (`CapLevelController`)\n *\n * @type {boolean}\n */\n set capLevelToPlayerSize (shouldStartCapping: boolean) {\n const newCapLevelToPlayerSize = !!shouldStartCapping;\n\n if (newCapLevelToPlayerSize !== this.config.capLevelToPlayerSize) {\n if (newCapLevelToPlayerSize) {\n this.capLevelController.startCapping(); // If capping occurs, nextLevelSwitch will happen based on size.\n } else {\n this.capLevelController.stopCapping();\n this.autoLevelCapping = -1;\n this.streamController.nextLevelSwitch(); // Now we're uncapped, get the next level asap.\n }\n\n this.config.capLevelToPlayerSize = newCapLevelToPlayerSize;\n }\n }\n\n /**\n * Capping/max level value that should be used by automatic level selection algorithm (`ABRController`)\n * @type {number}\n */\n get autoLevelCapping (): number {\n return this._autoLevelCapping;\n }\n\n /**\n * get bandwidth estimate\n * @type {number}\n */\n get bandwidthEstimate (): number {\n const bwEstimator = this.abrController._bwEstimator;\n return bwEstimator ? bwEstimator.getEstimate() : NaN;\n }\n\n /**\n * Capping/max level value that should be used by automatic level selection algorithm (`ABRController`)\n * @type {number}\n */\n set autoLevelCapping (newLevel: number) {\n logger.log(`set autoLevelCapping:${newLevel}`);\n this._autoLevelCapping = newLevel;\n }\n\n /**\n * True when automatic level selection enabled\n * @type {boolean}\n */\n get autoLevelEnabled (): boolean {\n return (this.levelController.manualLevel === -1);\n }\n\n /**\n * Level set manually (if any)\n * @type {number}\n */\n get manualLevel (): number {\n return this.levelController.manualLevel;\n }\n\n /**\n * min level selectable in auto mode according to config.minAutoBitrate\n * @type {number}\n */\n get minAutoLevel (): number {\n const { levels, config: { minAutoBitrate } } = this;\n const len = levels ? levels.length : 0;\n\n for (let i = 0; i < len; i++) {\n const levelNextBitrate = levels[i].realBitrate\n ? Math.max(levels[i].realBitrate, levels[i].bitrate)\n : levels[i].bitrate;\n\n if (levelNextBitrate > minAutoBitrate) {\n return i;\n }\n }\n\n return 0;\n }\n\n /**\n * max level selectable in auto mode according to autoLevelCapping\n * @type {number}\n */\n get maxAutoLevel (): number {\n const { levels, autoLevelCapping } = this;\n\n let maxAutoLevel;\n if (autoLevelCapping === -1 && levels && levels.length) {\n maxAutoLevel = levels.length - 1;\n } else {\n maxAutoLevel = autoLevelCapping;\n }\n\n return maxAutoLevel;\n }\n\n /**\n * next automatically selected quality level\n * @type {number}\n */\n get nextAutoLevel (): number {\n // ensure next auto level is between min and max auto level\n return Math.min(Math.max(this.abrController.nextAutoLevel, this.minAutoLevel), this.maxAutoLevel);\n }\n\n /**\n * this setter is used to force next auto level.\n * this is useful to force a switch down in auto mode:\n * in case of load error on level N, hls.js can set nextAutoLevel to N-1 for example)\n * forced value is valid for one fragment. upon succesful frag loading at forced level,\n * this value will be resetted to -1 by ABR controller.\n * @type {number}\n */\n set nextAutoLevel (nextLevel: number) {\n this.abrController.nextAutoLevel = Math.max(this.minAutoLevel, nextLevel);\n }\n\n /**\n * @type {AudioTrack[]}\n */\n // todo(typescript-audioTrackController)\n get audioTracks (): any[] {\n const audioTrackController = this.audioTrackController;\n return audioTrackController ? audioTrackController.audioTracks : [];\n }\n\n /**\n * index of the selected audio track (index in audio track lists)\n * @type {number}\n */\n get audioTrack (): number {\n const audioTrackController = this.audioTrackController;\n return audioTrackController ? audioTrackController.audioTrack : -1;\n }\n\n /**\n * selects an audio track, based on its index in audio track lists\n * @type {number}\n */\n set audioTrack (audioTrackId: number) {\n const audioTrackController = this.audioTrackController;\n if (audioTrackController) {\n audioTrackController.audioTrack = audioTrackId;\n }\n }\n\n /**\n * @type {Seconds}\n */\n get liveSyncPosition (): number {\n return this.streamController.liveSyncPosition;\n }\n\n /**\n * get alternate subtitle tracks list from playlist\n * @type {SubtitleTrack[]}\n */\n // todo(typescript-subtitleTrackController)\n get subtitleTracks (): any[] {\n const subtitleTrackController = this.subtitleTrackController;\n return subtitleTrackController ? subtitleTrackController.subtitleTracks : [];\n }\n\n /**\n * index of the selected subtitle track (index in subtitle track lists)\n * @type {number}\n */\n get subtitleTrack (): number {\n const subtitleTrackController = this.subtitleTrackController;\n return subtitleTrackController ? subtitleTrackController.subtitleTrack : -1;\n }\n\n /**\n * select an subtitle track, based on its index in subtitle track lists\n * @type {number}\n */\n set subtitleTrack (subtitleTrackId: number) {\n const subtitleTrackController = this.subtitleTrackController;\n if (subtitleTrackController) {\n subtitleTrackController.subtitleTrack = subtitleTrackId;\n }\n }\n\n /**\n * @type {boolean}\n */\n get subtitleDisplay (): boolean {\n const subtitleTrackController = this.subtitleTrackController;\n return subtitleTrackController ? subtitleTrackController.subtitleDisplay : false;\n }\n\n /**\n * Enable/disable subtitle display rendering\n * @type {boolean}\n */\n set subtitleDisplay (value: boolean) {\n const subtitleTrackController = this.subtitleTrackController;\n if (subtitleTrackController) {\n subtitleTrackController.subtitleDisplay = value;\n }\n }\n}\n","import { getMediaSource } from './utils/mediasource-helper';\n\nexport function isSupported (): boolean {\n const mediaSource = getMediaSource();\n if (!mediaSource) {\n return false;\n }\n const sourceBuffer = self.SourceBuffer || (self as any).WebKitSourceBuffer as SourceBuffer;\n const isTypeSupported = mediaSource &&\n typeof mediaSource.isTypeSupported === 'function' &&\n mediaSource.isTypeSupported('video/mp4; codecs=\"avc1.42E01E,mp4a.40.2\"');\n\n // if SourceBuffer is exposed ensure its API is valid\n // safari and old version of Chrome doe not expose SourceBuffer globally so checking SourceBuffer.prototype is impossible\n const sourceBufferValidAPI = !sourceBuffer ||\n (sourceBuffer.prototype &&\n typeof sourceBuffer.prototype.appendBuffer === 'function' &&\n typeof sourceBuffer.prototype.remove === 'function');\n return !!isTypeSupported && !!sourceBufferValidAPI;\n}\n","export const isFiniteNumber = Number.isFinite || function (value) {\n return typeof value === 'number' && isFinite(value);\n};\n\nexport const MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER || 9007199254740991;\n","export function getSelfScope () {\n // see https://stackoverflow.com/a/11237259/589493\n if (typeof window === 'undefined') {\n /* eslint-disable-next-line no-undef */\n return self;\n } else {\n return window;\n }\n}\n","import { getSelfScope } from './get-self-scope';\n\nfunction noop (...args) {}\n\nconst fakeLogger = {\n trace: noop,\n debug: noop,\n log: noop,\n warn: noop,\n info: noop,\n error: noop\n};\n\nlet exportedLogger = fakeLogger;\n\n// let lastCallTime;\n// function formatMsgWithTimeInfo(type, msg) {\n// const now = Date.now();\n// const diff = lastCallTime ? '+' + (now - lastCallTime) : '0';\n// lastCallTime = now;\n// msg = (new Date(now)).toISOString() + ' | [' + type + '] > ' + msg + ' ( ' + diff + ' ms )';\n// return msg;\n// }\n\nfunction formatMsg (type, msg) {\n msg = '[' + type + '] > ' + msg;\n return msg;\n}\n\nconst global = getSelfScope();\n\nfunction consolePrintFn (type) {\n const func = global.console[type];\n if (func) {\n return function (...args) {\n if (args[0]) {\n args[0] = formatMsg(type, args[0]);\n }\n\n func.apply(global.console, args);\n };\n }\n return noop;\n}\n\nfunction exportLoggerFunctions (debugConfig, ...functions) {\n functions.forEach(function (type) {\n exportedLogger[type] = debugConfig[type] ? debugConfig[type].bind(debugConfig) : consolePrintFn(type);\n });\n}\n\nexport const enableLogs = function (debugConfig) {\n // check that console is available\n if ((global.console && debugConfig === true) || typeof debugConfig === 'object') {\n exportLoggerFunctions(debugConfig,\n // Remove out from list here to hard-disable a log-level\n // 'trace',\n 'debug',\n 'log',\n 'info',\n 'warn',\n 'error'\n );\n // Some browsers don't allow to use bind on console object anyway\n // fallback to default if needed\n try {\n exportedLogger.log();\n } catch (e) {\n exportedLogger = fakeLogger;\n }\n } else {\n exportedLogger = fakeLogger;\n }\n};\n\nexport const logger = exportedLogger;\n","'use strict'\r\n\r\nclass HlsjsIPFSLoader {\r\n constructor(config) {\r\n this._abortFlag = [ false ];\r\n this.ipfs = config.ipfs\r\n this.hash = config.ipfsHash\r\n if (config.debug === false) {\r\n this.debug = function() {}\r\n } else if (config.debug === true) {\r\n this.debug = console.log\r\n } else {\r\n this.debug = config.debug\r\n }\r\n if(config.m3u8provider) {\r\n this.m3u8provider = config.m3u8provider;\r\n } else {\r\n this.m3u8provider = null;\r\n }\r\n if(config.tsListProvider) {\r\n this.tsListProvider = config.tsListProvider;\r\n } else {\r\n this.tsListProvider = null;\r\n }\r\n }\r\n\r\n destroy() {\r\n }\r\n\r\n abort() {\r\n this._abortFlag[0] = true;\r\n }\r\n\r\n load(context, config, callbacks) {\r\n this.context = context\r\n this.config = config\r\n this.callbacks = callbacks\r\n this.stats = { trequest: performance.now(), retry: 0 }\r\n this.retryDelay = config.retryDelay\r\n this.loadInternal()\r\n }\r\n /**\r\n * Call this by getting the HLSIPFSLoader instance from hls.js hls.coreComponents[0].loaders.manifest.setM3U8Provider()\r\n * @param {function} provider\r\n */\r\n setM3U8Provider(provider) {\r\n this.m3u8provider = provider;\r\n }\r\n /**\r\n *\r\n * @param {function} provider\r\n */\r\n setTsListProvider(provider) {\r\n this.tsListProvider = provider;\r\n }\r\n\r\n loadInternal() {\r\n const { stats, context, callbacks } = this\r\n\r\n stats.tfirst = Math.max(performance.now(), stats.trequest)\r\n stats.loaded = 0\r\n\r\n //When using absolute path (https://example.com/index.html) vs https://example.com/\r\n const urlParts = window.location.href.split(\"/\")\r\n if(urlParts[urlParts.length - 1] !== \"\") {\r\n urlParts[urlParts.length - 1] = \"\"\r\n }\r\n const filename = context.url.replace(urlParts.join(\"/\"), \"\")\r\n\r\n const options = {}\r\n if (Number.isFinite(context.rangeStart)) {\r\n options.offset = context.rangeStart;\r\n if (Number.isFinite(context.rangeEnd)) {\r\n\t options.length = context.rangeEnd - context.rangeStart;\r\n }\r\n }\r\n\r\n if(filename.split(\".\")[1] === \"m3u8\" && this.m3u8provider !== null) {\r\n const res = this.m3u8provider();\r\n let data;\r\n if(Buffer.isBuffer(res)) {\r\n data = buf2str(res)\r\n } else {\r\n data = res;\r\n }\r\n const response = { url: context.url, data: data }\r\n callbacks.onSuccess(response, stats, context)\r\n return;\r\n }\r\n if(filename.split(\".\")[1] === \"m3u8\" && this.tsListProvider !== null) {\r\n var tslist = this.tsListProvider();\r\n var hash = tslist[filename];\r\n if(hash) {\r\n this.cat(hash).then(res => {\r\n let data;\r\n if(Buffer.isBuffer(res)) {\r\n data = buf2str(res)\r\n } else {\r\n data = res;\r\n }\r\n stats.loaded = stats.total = data.length\r\n stats.tload = Math.max(stats.tfirst, performance.now())\r\n const response = { url: context.url, data: data }\r\n callbacks.onSuccess(response, stats, context)\r\n });\r\n }\r\n return;\r\n }\r\n this._abortFlag[0] = false;\r\n getFile(this.ipfs, this.hash, filename, options, this.debug, this._abortFlag).then(res => {\r\n const data = (context.responseType === 'arraybuffer') ? res : buf2str(res)\r\n stats.loaded = stats.total = data.length\r\n stats.tload = Math.max(stats.tfirst, performance.now())\r\n const response = { url: context.url, data: data }\r\n callbacks.onSuccess(response, stats, context)\r\n }, console.error)\r\n }\r\n}\r\nasync function getFile(ipfs, rootHash, filename, options, debug, abortFlag) {\r\n debug(`Fetching hash for '${rootHash}/${filename}'`)\r\n const path = `${rootHash}/${filename}`\r\n try {\r\n return await cat(path, options, ipfs, debug, abortFlag)\r\n } catch(ex) {\r\n throw new Error(`File not found: ${rootHash}/${filename}`)\r\n }\r\n}\r\n\r\nfunction buf2str(buf) {\r\n return new TextDecoder().decode(buf)\r\n}\r\n\r\nasync function cat (cid, options, ipfs, debug, abortFlag) {\r\n const parts = []\r\n let length = 0, offset = 0\r\n\r\n for await (const buf of ipfs.cat(cid, options)) {\r\n parts.push(buf)\r\n length += buf.length\r\n if (abortFlag[0]) {\r\n debug('Cancel reading from ipfs')\r\n break\r\n }\r\n }\r\n\r\n const value = new Uint8Array(length)\r\n for (const buf of parts) {\r\n value.set(buf, offset)\r\n offset += buf.length\r\n }\r\n\r\n debug(`Received data for file '${cid}' size: ${value.length} in ${parts.length} blocks`)\r\n return value\r\n}\r\n\r\nexports = module.exports = HlsjsIPFSLoader\r\n"],"names":["_ipfsCore","require","_hlsJs","_hlsjsIpfsLoader","getUrlParameter","name","replace","results","RegExp","exec","location","search","decodeURIComponent","showStatus","message","hide","status","document","getElementById","classList","toggle","innerText","setBodyHeight","body","style","height","window","innerHeight","addEventListener","async","hash","source","title","time","video","background","menu","oncontextmenu","e","left","pageX","top","pageY","preventDefault","onclick","stopPropagation","url","encodeURIComponent","navigator","clipboard","writeText","Math","round","currentTime","setUpContextMenu","display","repoPath","random","node","create","repo","DefaultConfig","loader","_hlsjsIpfsLoaderDefault","default","debug","_hlsJsDefault","isSupported","hls","config","ipfs","ipfsHash","loadSource","attachMedia","on","Events","MANIFEST_PARSED","play","Object","defineProperty","exports","value","index","crypto$1","isIpfs","cid","multiaddr$1","PeerId$1","globSourceImport","urlSourceImport","_interopDefaultLegacy","crypto__default","isIpfs__default","PeerId__default","globSourceImport__default","urlSourceImport__default","crypto","isIPFS","CID","multiaddr","Multiaddr","PeerId","globSource","urlSource","mergeOpts","env_js","errCode","ipfsUnixfs","dagPB","dagCBOR","identity","basics","initAssets","errors","fromString","start","stop","dns","isOnline","resolve","ipns","index$2","index$4","local","index$6","index$7","index$1","root","version","id1","index$8","index$3","preload","mfsPreload","index$5","index$9","index$a","index$b","index$c","storage","network","service","index$d","ping","dht","pubsub","multicodecs","multihashes","multibases","_interopNamespace","__esModule","n","keys","forEach","k","d","getOwnPropertyDescriptor","get","enumerable","freeze","mergeOpts__default","debug__default","errCode__default","dagPB__namespace","dagCBOR__namespace","mergeOptions","bind","ignoreUndefined","log","IPFS","print","print1","storage1","codecs","options","options1","peerId","keychain","network$1","Service","Network","preload$1","createPreloader","dns$1","createDns","isOnline$1","createIsOnline","ipns$1","IPNSAPI","multihashHashers","values","hashes","ipld","hashers","hasher","push","this","Multihashes","loadHasher","multibaseCodecs","bases","base","Multibases","loadBase","pin","PinAPI","block","BlockAPI","NameAPI","resolve$1","createResolve","dag","DagAPI","refs","assign","createRefs","createLocal","add","addAll","cat","ls","RootAPI","EXPERIMENTAL","files","createFiles","mfsPreload$1","createMfsPreloader","createStart","createStop","createDht","createPubsub","id","createId","createVersion","bitswap","BitswapAPI","bootstrap","BootstrapAPI","createConfig","createPing","key","KeyAPI","object","ObjectAPI","RepoAPI","stats","StatsAPI","swarm","SwarmAPI","net","try","libp2p","undefined","notImplemented","Promise","reject","Error","commands","diag","cmds","sys","level","tail","mount","AlreadyInitializedError","initOptions","enabled","isTest","addresses","init","id2","code","encode","decode","blockCodecs","concat","codec","multicodecs$1","Multicodecs","loadCodec","silent","console","storage$1","Storage","getAll","startOffline","isNew","emptyRepo","buf","Data","UnixFS","type","marshal","Links","put","mhtype","format","addEmptyDir","initializeKeyspace","privKey","isOptionObject","hasOwnProperty","prototype","propertyIsEnumerable","writable","configurable","globalThis","defaultMergeOptions","concatArrays","getEnumerableOwnPropertyKeys","call","getOwnPropertySymbols","symbols","symbol","clone","Array","isArray","array","result","slice","cloneArray","getPrototypeOf","cloneOptionObject","mergeKeys","merged","merge","resultIndex","indices","length","String","filter","includes","module","_","option","TypeError","toString","isElectron","IS_ENV_WITH_DOM","nodeType","IS_ELECTRON","IS_BROWSER","IS_ELECTRON_MAIN","IS_ELECTRON_RENDERER","IS_NODE","process","release","IS_WEBWORKER","importScripts","self","WorkerGlobalScope","IS_TEST","env","IS_REACT_NATIVE","product","isElectronMain","isElectronRenderer","isNode","isBrowser","isWebWorker","isEnvWithDom","isReactNative","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","setTimeout","clearTimeout","e1","currentQueue","queue","draining","queueIndex","cleanUpNextTick","drainQueue","timeout","len","run","marker","runClearTimeout","Item","noop","nextTick","args","arguments","i","apply","browser","argv","versions","addListener","once","off","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","cwd","chdir","dir","umask","electron","userAgent","indexOf","formatArgs","useColors","namespace","humanize","diff","c","color","splice","lastC","match","save","namespaces","setItem","removeItem","error","load","r","getItem","__nwjs","toLowerCase","documentElement","WebkitAppearance","firebug","exception","table","parseInt","$1","localStorage","localstorage","destroy","warned","warn","colors","formatters","j","v","JSON","stringify","createDebug","prevTime","namespacesCache","enabledCache","enableOverride","curr","Number","Date","ms","prev","coerce","unshift","formatter","val","selectColor","extend","set","delimiter","newDebug","toNamespace","regexp","substring","stack","disable","names","map","skips","join","enable","split","substr","test","charCodeAt","abs","s","m","h","w","y","plural","msAbs","isPlural","str","parseFloat","parse","isFinite","long","fmtShort","obj","props","err","ErrClass","errcode","unixfs","errcode__default","PBData","types","dirTypes","DEFAULT_FILE_MODE","DEFAULT_DIRECTORY_MODE","parseMode","mode","parseMtime","input","mtime","secs","nsecs","Seconds","FractionalNanoseconds","getTime","floor","marshaled","decoded","toObject","defaults","arrays","longs","objects","data","Type","blockSizes","blocksizes","_originalMode","hashType","fanout","_mode","isDirectory","parsedMode","Boolean","addBlockSize","size1","removeBlockSize","fileSize","sum","size","DataType","Raw","Directory","File","Metadata","Symlink","HAMTShard","parsed","pbData","filesize","finish","$protobuf__default","$Reader","Reader","$Writer","Writer","$util","util","$root","roots","Data1","p","ks","newBuffer","Long","fromBits","emptyArray","uint32","int32","bytes","uint64","UnixTime","fork","ldelim","l","pos","t","c2","skipType","ProtocolError","instance","fromObject","base64","fromValue","unsigned","LongBits","low","high","toNumber","o","enums","toJSON","constructor","toJSONOptions","valuesById","UnixTime1","int64","fixed32","Metadata1","MimeType","string","protobuf","configure","_configure","BufferWriter","BufferReader","build","rpc","utf8","Op","fn","next","State","writer","head","states","Buffer","writeByte","VarintOp","writeVarint64","hi","lo","writeFixed32","alloc","pool","subarray","_push","fromNumber","sint32","bits","from","sint64","zzEncode","bool","sfixed32","fixed64","sfixed64","float","writeFloatLE","double","writeDoubleLE","writeBytes","isString","write","reset","BufferWriter_","dst","src","ifNotSet","newError","CustomError","properties","captureStackTrace","asPromise","EventEmitter","inquire","global","emptyObject","isInteger","isObject","isset","isSet","prop","utf8Write","_Buffer_from","_Buffer_allocUnsafe","sizeOrArray","Uint8Array","dcodeIO","key2Re","key32Re","key64Re","longToHash","toHash","zeroHash","longFromHash","fromHash","lcFirst","charAt","oneOfGetter","fieldNames","fieldMap","i1","oneOfSetter","json","encoding","allocUnsafe","ctx","params1","offset1","pending","params","offset","ceil","s64","b64","buffer","end","chunk","b","parts","fromCharCode","invalidEncoding","_listeners","evt","factory","Float32Array","f32","f8b","le","writeFloat_f32_cpy","writeFloat_f32_rev","readFloat_f32_cpy","readFloat_f32_rev","writeFloatBE","readFloatLE","readFloatBE","writeFloat_ieee754","writeUint","sign","isNaN","exponent","LN2","pow","readFloat_ieee754","readUint","uint","mantissa","NaN","Infinity","writeUintLE","writeUintBE","readUintLE","readUintBE","Float64Array","f64","writeDouble_f64_cpy","writeDouble_f64_rev","readDouble_f64_cpy","readDouble_f64_rev","writeDoubleBE","moduleName","mod","eval","c1","zero","zzDecode","toLong","mask","part0","part1","part2","writeStringBuffer","writeBytesBuffer","copy","byteLength","indexOutOfRange","reader","writeLength","RangeError","create_array","buffer1","isBuffer","readLongVarint","readFixed32_end","readFixed64","_slice","readDoubleLE","read","skip","wireType","BufferReader_","utf8Slice","min","rpcImpl","requestDelimited","responseDelimited","rpcCall","method","requestCtor","responseCtor","request","callback","response","err1","endedByRPC","pbDecode","pbEncode","createLink","createNode","prepare","validate","pbn","decodeNode","link","Hash","Name","Tsize","encodeNode","varint","digest","base58","base32","bytes3","version1","code3","multihash1","bytes1","multihash","byteOffset","asCID","_baseCache","Map","defineProperties","hidden","readonly","toV0","DAG_PB_CODE","SHA_256_CODE","createV0","toV1","digest$1","createV1","equals","other","base2","toStringV0","base58btc","encoder","toStringV1","toStringTag","Symbol","for","deprecate","IS_CID_DEPRECATION","cidSymbol","toBaseEncodedString","multibaseName","prefix","value1","encodeCID","version2","code1","digest1","digest2","code2","digest3","bytes2","remainder","decodeFirst","bytes$1","specs","inspectBytes","prefixSize","multihashSize","multihashBytes","digestBytes","digestSize","Digest","multihashCode","initialBytes","source1","base1","parseCIDtoBytes","decoder","cache","codeOffset","encodingLength","hashOffset","encodeTo","range","varint$1","int","target","encode_1","num","out","oldOffset","INT","res","shift","counter","N1","N2","N3","N4","N5","N6","N7","N8","N9","sizeOffset","digestOffset","a","empty","ArrayBuffer","isView","aa","bb","ii","fromHex","hex","hexes","TextEncoder","isBinary","toHex","reduce","byte","padStart","TextDecoder","baseX","alphabet","base58flickr","baseX$1","Encoder","name3","prefix3","baseEncode","Decoder","name1","prefix1","baseDecode","text1","or","ComposedDecoder","decoders","decoder1","input3","right","Codec","name2","prefix2","baseEncode1","baseDecode1","input1","input2","text","rfc4648","bitsPerChar","pad","encode1","codes","written","SyntaxError","decode1","_brrp__multiformats_scope_baseX","ALPHABET","BASE_MAP","x","xc","BASE","LEADER","FACTOR","iFACTOR","decodeUnsafe","psz","zeroes","b256","carry","it3","it4","vch","pbegin","pend","b58","it1","it2","repeat","base32upper","base32pad","base32padupper","base32hex","base32hexupper","base32hexpad","base32hexpadupper","base32z","textDecoder","decodeVarint","decodeBytes","byteLen","postOffset","decodeKey","wire","decodeLink","fieldNum","byts","links","linksBeforeData","textEncoder","maxInt32","encodeLink","isSafeInteger","encodeVarint","nameBytes","sizeLink","sov","len8tab","len64","sizeNode","cid1","pbNodeProperties","pbLinkProperties","linkComparator","abuf","bbuf","hasOnlyProperties","some","asLink","pbl","cid$1","sort","cborg","cborg__namespace","encodeOptions","float64","typeEncoders","Token","tag","number","decodeOptions","allowIndefinite","allowUndefined","allowNaN","allowInfinity","allowBigInt","strict","useMaps","tags","token","is","token1","bl","common","jump","byteUtils","_0uint","_1negint","_2bytes","_3string","_4array","_5map","_6tag","_7float","defaultEncodeOptions","mapSorter","e2","keyToken1","keyToken2","compare","major","tcmp","cborEncoders","compareTokens","quickEncodeToken","encodeUint","negint","encodeNegint","encodeBytes","encodeString","encodeArray","encodeMap","encodeTag","encodeFloat","buf1","Bl","Ref","obj3","parent","obj1","obj2","encodeErrPrefix","simpleTokens","null","true","false","emptyMap","_typ","_options","_refStack","bigint","BigInt","boolean","_obj","DataView","refStack","addBreakTokens","break","createCheck","entries","objectToTokens","typ","isMap","sortMapEntries","typ1","customTypeEncoder","tokens","typeEncoder","tokensToEncoded","encoders","encodeCustom","quickBytes","encodedSize","chunks","asU8A","toBytes","typeofs","objectTypeNames","typeOf","objectType","objectTypeName","getObjectType","terminal","majorEncoded","encodedLength","encodedBytes","chunkSize","cursor","maxCursor","_initReuseChunk","topChunk","chunkPos","useBuffer","utf8ToBytes","units","codePoint","leadSurrogate","firstByte","bytesPerSequence","secondByte","thirdByte","fourthByte","tempCodePoint","decodeCodePointsArray","codePoints","b1","b2","fromArray","arr","decodeErrPrefix","uintMinorPrefixBytes","assertEnoughData","need","invalidMinor","minor","errorer","msg","decodeUint8","decodeUint16","decodeUint32","decodeUint64","decodeNegint8","decodeNegint16","decodeNegint32","decodeNegint64","i2","decodeBytesCompact","decodeBytes8","decodeBytes16","decodeBytes32","decodeBytes64","i3","decodeStringCompact","decodeString8","decodeString16","decodeString32","decodeString64","i4","decodeArrayCompact","decodeArray8","decodeArray16","decodeArray32","decodeArray64","decodeArrayIndefinite","i5","decodeMapCompact","decodeMap8","decodeMap16","decodeMap32","decodeMap64","decodeMapIndefinite","i6","decodeTagCompact","decodeTag8","decodeTag16","decodeTag32","decodeTag64","i7","decodeUndefined","decodeFloat16","decodeFloat32","decodeFloat64","decodeBreak","quick","i8","i9","token$1","uintBoundaries","readUint8","readUint16","readUint32","readUint64","MAX_SAFE_INTEGER","encodeUintValue","nuint","buint","tok1","tok2","_minor","neg1b","pos1b","MIN_SAFE_INTEGER","toToken","tokenBytes","compareBytes","totLength","_data","_pos","createToken","success","encodeFloat16","readFloat16","ui8a1","encodeFloat32","readFloat32","inp","dataView","setFloat64","readFloat64","setUint16","setFloat32","valu32","getUint32","logicalExponent","ui8a","half","exp","mant","getFloat32","getFloat64","defaultDecodeOptions","Tokeniser","data1","done","byt","DONE","BREAK","tokensToObject","tokeniser","tokenToArray","tokenToMap","tagged","tokenizer","Hasher","base8","base10","base16","base36","sha2","identity$1","raw","base16upper","base36upper","base64pad","base64url","base64urlpad","sha","subtle","sha256","sha512","NotInitializedError","super","AlreadyInitializingError","message1","message2","NotStartedError","message3","AlreadyStartingError","message4","AlreadyStartedError","message5","NotEnabledError","message6","createCodec","string1","ascii","BASES","latin1","binary","all","startOnline","utils","state","activate","promise","ready","panic","service1","deactivate","state1","withTimeout","state2","options2","use","key1","withTimeoutOption","toCidAndPath","MFS_ROOT_KEY","Key","path","getCodec","blocks","lastCid","remainderPath","find","MFS_MAX_CHUNK_SIZE","MFS_MAX_LINKS","OFFLINE_ERROR","mapFile","file","output","normalizeCidPath","normalizePath","pathStr","resolvePath","ipfsPath","lastRemainderPath","startsWith","signal","mafmt","URL","uint8ArrayToString","pathGatewayPattern","pathPattern","subdomainGatewayPattern","fqdnWithTld","isCID","isMultiaddr","pattern","protocolMatch","hashMatch","formatted","convertToString","isIpns","ipnsId","hostname","ipfsSubdomain","ipnsSubdomain","subdomain","ipfsUrl","ipnsUrl","url1","path1","peerMultiaddr","P2P","matches","base32cid","isBase32EncodedMultibase","ipnsPath","urlOrPath","cidPath","protocols","inspect","uint8ArrayEquals","resolvers","addr7","fromBytes","bytesToString","toOptions","opts","family","host","transport","port","protos","protoCodes","sizeForAddr","protoNames","proto","tuples","bytesToTuples","stringTuples","tuplesToStringTuples","encapsulate","addr1","decapsulate","addr2","addrString","lastIndexOf","decapsulateCode","tuplesToBytes","getPeerId","tuple1","tuple","pop","peerIdStr","getPath","addr3","resolvableProto","resolvable","resolver","nodeAddress","address","isThinWaistAddress","addr4","static","addr5","ip","addr6","addr","convert","uint8ArrayConcat","stringToStringTuples","part","ParseError","cleanPath","stringTuplesToString","tup","protoFromTuple","stringTuplesToTuples","stringToBytes","validateBytes","trim","isValidBytes","uint8ArrayFromString","Convert","ip2bytes","ipString","isIP","port2bytes","bytes2port","getUint16","bytes2onion","addrBytes","portBytes","ipBuff","bytes2ip","bytes2str","bytes2mh","str2bytes","mh","mh2bytes","portBuf","onion2bytes","onion32bytes","isIp","isV4","v4","isV6","v6","buff","sections","v4Buffer","word","view","ipRegex","exact","includeBoundaries","v6seg","Protocols","V","lengthPrefixedVarSize","row","acc","DNS4","DNS6","DNSADDR","DNS","IP","TCP","and","UDP","UTP","QUIC","WebSockets","WebSocketsSecure","HTTP","HTTPS","WebRTCStar","WebSocketStar","WebRTCDirect","Reliable","Stardust","_P2P","_Circuit","CircuitRecursive","Circuit","makeMatchesFunction","partialMatch","arg","ma","pnames","URLWithLegacySupport","URLSearchParams","defaultBase","relative","protocol","pathname","auth","username","password","query","href","origin","searchParams","hash1","host1","hostname1","pathname1","port1","protocol1","search1","createObjectURL","o1","revokeObjectURL","userPass","protocolMap","defaultProtocol","urlParsed","nanoid","pathSepS","pathSepB","pathSep","clean","_buf","uint8Array","list","fill","less","key2","list1","list2","reverse","withNamespaces","baseNamespace","ns","namespaceType","namespaceValue","s1","endsWith","child","isAncestorOf","other1","isDecendantOf","other2","isTopLevel","customAlphabet","customRandom","_indexJs","getRandomValues","getRandom","step","toUpperCase","urlAlphabet","interopDefault","defineInteropFlag","exportAll","dest","export","destName","TimeoutController","anySignal","parseDuration","TimeoutController__default","parseDuration__default","optionsArgIndex","controller","fnRes","timeoutPromise","_resolve","TimeoutError","now","maybeThrowTimeoutError","aborted","abort","asyncIterator","it","race","clear","return","AbortController","retimer","_ms","_timer","setPrototypeOf","AbortSignal","Retimer","that","_started","_rescheduled","_scheduled","_args","timerWrapper","reschedule","signals","onAbort","removeEventListener","signal1","impl","durationRE","nanosecond","us","microsecond","millisecond","second","sec","minute","hour","hr","day","week","wk","month","year","yr","IPFS_PREFIX","close","domain","recursive","fqdnFixups","resolveDnslink","tlru","PQueue","PQueue__default","HTTP__default","TLRU","httpQueue","concurrency","Path","Message","fqdn1","opts1","fqdn","query1","nocache","has","hashlru__default","maxSize","lru","expire","remove","ttl","key3","max","_cache","update","p_timeout_1","priority_queue_1","timeoutError","_a","_b","_c","_d","_intervalCount","_intervalEnd","_pendingCount","_resolveEmpty","_resolveIdle","carryoverConcurrencyCount","intervalCap","interval","autoStart","queueClass","_carryoverConcurrencyCount","_isIntervalIgnored","_intervalCap","_interval","_queue","_queueClass","_timeout","_throwOnTimeout","throwOnTimeout","_isPaused","_doesIntervalAllowAnother","_doesConcurrentAllowAnother","_concurrency","_next","_tryToStartAnother","_resolvePromises","_onResumeInterval","_onInterval","_initializeIntervalIfNeeded","_timeoutId","_isIntervalPaused","_intervalId","delay","clearInterval","canInitializeInterval","job","dequeue","setInterval","_processQueue","newConcurrency","enqueue","operation","functions","function_","pause","existingResolve","sizeBy","options3","isPaused","milliseconds","EE","context","emitter","event","listener","_events","_eventsCount","clearEvent","__proto__","eventNames","events","handlers","ee","listenerCount","a1","a2","a3","a4","a5","prefixed","pFinally","pTimeout","fallback","timer","cancel","then","onFinally","lower_bound_1","element","priority","item","comparator","first","count","fetch","Request","Headers","HTTPError","throwHttpErrors","credentials","options7","resource6","headers","transformSearchParams","abortController","timedOut","timeoutID","after","ok","handleError","iterator","fromStream","ndjson","transform","post","resource1","resource2","resource3","options4","delete","resource4","options5","resource5","options6","stream","lines","isNodeReadableStream","iter","isWebReadableStream","getReader","releaseLock","isAsyncIterable","streamToAsyncIterator","resource","AbortError","Response","fetchWithStreaming","parseHeaders","line","ResponseWithURL","onUploadProgress","XMLHttpRequest","open","overrideMimeType","setRequestHeader","onabort","upload","onprogress","responseType","handleEvent","responseURL","statusText","getAllResponseHeaders","onerror","onload","ontimeout","send","fetchWithProgress","getGlobal","isStarted","resolvedPath","schema","rest","cidBase","getBase","parseBytes","b32","b36","cryptoKeys","withIs","PeerIdProto","baseDecoder","PeerIdWithIs","id3","privKey2","pubKey2","public","_id","_idB58String","_privKey","_pubKey","val1","privKey1","pubKey","unmarshalPublicKey","pubKey1","marshalPubKey","marshalPublicKey","marshalPrivKey","marshalPrivateKey","excludePriv","toPrint","pid","toB58String","maxRunes","toB64Opt","toHexString","_idCIDString","isEqual","isValid","hasInlinePublicKey","className","symbolName","computeDigest","computePeerId","keyType","generateKeyPair","createFromHexString","createFromBytes","validMulticodec","createFromCID","createFromB58String","createFromPubKey","createFromPrivKey","unmarshalPrivateKey","createFromJSON","rawPrivKey","rawPubKey","pub","privDigest","pubDigest","createFromProtobuf","isPeerId","keysPBM","forge","importer","supportedKeys","rsa","ed25519","secp256k1","ErrMissingSecp256K1","typeToKey","supported","PrivateKey","KeyType","RSA","unmarshalRsaPrivateKey","Ed25519","unmarshalEd25519PrivateKey","Secp256k1","unmarshalSecp256k1PrivateKey","keyStretcher","generateEphemeralKeyPair","generateKeyPairFromSeed","seed","PublicKey","unmarshalRsaPublicKey","unmarshalEd25519PublicKey","unmarshalSecp256k1PublicKey","import","encryptedKey","pki","decryptRsaPrivateKey","der","asn1","toDer","privateKeyToAsn1","getBytes","$protobuf","_checkBufferLength","remaining","available","requested","Class","UNIVERSAL","APPLICATION","CONTEXT_SPECIFIC","PRIVATE","NONE","BOOLEAN","INTEGER","BITSTRING","OCTETSTRING","NULL","OID","ODESC","EXTERNAL","REAL","ENUMERATED","EMBEDDED","UTF8","ROID","SEQUENCE","SET","PRINTABLESTRING","IA5STRING","UTCTIME","GENERALIZEDTIME","BMPSTRING","tagClass","constructed","tmp","composed","bitStringContents","original","excludeBitStringContents","equal","includeBitStringContents","getBerValueLength","getByte","getInt","_fromDer","depth","longFormBytes","_getValueLength","decodeBitStrings","savedRead","savedRemaining","unused","verbose","used","tc","ex","getInt16","asn1Options","fromDer","createBuffer","useBitStringContents","putBytes","putByte","putBuffer","putInt16","lenBytes","oidToDer","oid","last","valueBytes","derToOid","utcTimeToDate","utc","date","MM","DD","hh","mm","ss","setUTCFullYear","setUTCHours","setTime","generalizedTimeToDate","gentime","YYYY","fff","isUTC","setFullYear","setHours","dateToUtcTime","rval","getUTCFullYear","getUTCMonth","getUTCDate","getUTCHours","getUTCMinutes","getUTCSeconds","dateToGeneralizedTime","integerToDer","putSignedInt","integer","derToInteger","getSignedInt","capture","optional","captureAsn1","captureBitStringContents","captureBitStringValue","_nonLatinRegex","prettyPrint","indentation","indent","IA5String","subvalues","sub","oids","bytesToHex","decodeUtf8","usePureJavaScript","baseN","_checkBitsParam","ByteStringBuffer","isArrayBuffer","isArrayBufferView","_constructedStringLength","setImmediate","postMessage","callbacks","MutationObserver","attr","div","createElement","observe","attributes","oldSetImmediate","setAttribute","isNodejs","globalScope","ByteBuffer","_MAX_CONSTRUCTED_STRING_LENGTH","DataBuffer","readOffset","growSize","writeOffset","_optimizeConstructedString","isEmpty","fillWithByte","putString","encodeUtf8","putInt24","putInt32","putInt16Le","putInt24Le","putInt32Le","putInt","getInt24","getInt32","getInt16Le","getInt24Le","getInt32Le","at","setAt","compact","truncate","accommodate","amount","setUint8","Uint16Array","utf16","setInt16","setInt8","setInt32","getInt8","getUint8","fillString","xorBytes","s2","s3","hexToBytes","int32ToBytes","_base64","_base64Idx","_base58","encode64","maxline","chr1","chr2","chr3","decode64","enc1","enc2","enc3","enc4","unescape","escape","deflate","api","inflate","_setStorageObject","_getStorageObject","_setItem","_getItem","_removeItem","_clearItems","_callStorageFunction","func","idx","clearItems","parseUrl","regex","lastIndex","full","scheme","fullHost","_queryVariables","getQueryVariables","rval1","q","kvpairs","parseFragment","fragment","fp","fq","pathString","queryString","makeRequest","reqString","frag","req","getQuery","getQueryLast","_default","vals","makeLink","jQuery","qstr","param","re","argi","formatNumber","decimals","dec_point","thousands_sep","toFixed","formatSize","bytesFromIP","bytesFromIPv4","bytesFromIPv6","blanks","zeros","bytesToIP","bytesToIPv4","bytesToIPv6","zeroGroups","zeroMaxGroup","group","estimateCores","callback1","cores","hardwareConcurrency","Worker","Blob","blobUrl","st","et","sample","samples","numWorkers","avg1","avg","workers","worker","terminate","overlaps","r1","overlap","r2","_reverseAlphabets","digits","_encodeWithByteBuffer","_IN","_I_","BigInteger","jsbn","pbe","encryptedPrivateKeyValidator","PBES2AlgorithmsValidator","pkcs12PbeParamsValidator","md","prfOidToMessageDigest","prfOid","prfAlgorithm","prfAlgorithmToMessageDigest","algorithm","encryptPrivateKeyInfo","saltSize","dkLen","encryptionAlgorithm","encryptedData","salt","getBytesSync","countBytes","ivLen","encOid","cipherFn","aes","createEncryptionCipher","des","dk","pkcs5","pbkdf2","iv","cipher","createPbkdf2Params","saltBytes","generatePkcs12Key","decryptPrivateKeyInfo","encryptionOid","getCipher","encryptionParams","encrypted","encryptedPrivateKeyToPem","epki","pem","encryptedPrivateKeyFromPem","headerType","procType","encryptRsaPrivateKey","rsaKey","legacy","wrapRsaPrivateKey","opensslDeriveBytes","dekInfo","parameters","createDecryptionCipher","rc2","privateKeyFromAsn1","sha1","u","digestLength","blockLength","passBuf","D","Slen","S","Plen","P","I","B","Inew","getCipherForPBES2","getCipherForPKCS12PBE","supportedOids","kdfOid","kdfSalt","kdfIterationCount","encIv","dIvLen","iterations","startDecrypting","md5","digests","registerAlgorithm","Algorithm","startEncrypting","_createCipher","decrypt","initialize","blockSize","encrypt","inBlock","outBlock","_updateBlock","_w","_init","encryptOp","_expandKey","modes","ecb","cbc","cfb","ofb","ctr","gcm","sbox","isbox","rcon","mix","imix","xtime","e4","e8","sx","sx2","me","ime","ei","temp","iNk","Nk","m0","m1","m2","m3","wnew","wi","Nr","createDecipher","createCipher","algorithms","getAlgorithm","BlockCipher","_finish","_input","_op","_decrypt","unpad","overflow","afterFinish","transformIV","ints","inc32","from64To32","_ints","_inBlock","_outBlock","padding","_prev","_iv","_partialBlock","_partialOutput","_partialBytes","inputLength","partialBytes","_R","additionalData","_cipherLength","_tagLength","tagLength","_tag","_hashBlock","_hashSubkey","componentBits","_m","generateHashTable","ivLength","_j0","ghash","_aDataLength","_s","lengths","multiply","z_i","v_i","lsb","tableMultiply","z","x_i","ah","multiplier","perInt","shft","generateSubHashTable","mid","m_i","m_j","_keys","pc2bytes0","pc2bytes1","pc2bytes2","pc2bytes3","pc2bytes4","pc2bytes5","pc2bytes6","pc2bytes7","pc2bytes8","pc2bytes9","pc2bytes10","pc2bytes11","pc2bytes12","pc2bytes13","shifts","lefttmp","righttmp","_createKeys","spfunction1","spfunction2","spfunction3","spfunction4","spfunction5","spfunction6","spfunction7","spfunction8","looping","endloop","loopinc","right1","right2","pbkdf2Sync","hLen","prf","hmac","xor","u_c","u_c1","outer","inner","_key","_md","_ipadding","_opadding","keylen","getMac","foldHeader","header","insertSpace","candidate","insert","ltrim","contentDomain","rMessage","rHeader","rCRLF","li","nl","vi","prng_aes","_prng_aes_output","_prng_aes_buffer","spawnPrng","prng","generate","formatKey","formatSeed","increment","_ctx","_crypto","msCrypto","collectInt","_navBytes","collect","mousemove","clientX","clientY","keypress","charCode","createInstance","_initialized","_padding","_k","_state","messageLength","fullMessageLength","messageLengthSize","messageLength64","int32s","h0","h1","h2","h3","h4","h5","h6","h7","_update","finalBlock","t1","t2","s0","maj","f","g","_crypto1","plugin","reseeds","generated","keyBytes","md1","pools","_reseedSync","_seed","needed","seedFileSync","_2powK","seedBytes","defaultSeedFile","entropy","Uint32Array","QuotaExceededError","generateSync","seedFile","_reseed","randomBytes","registerWorker","piTable","rol","ror","expandKey","effKeyBits","L","T","T1","T8","TM","mixRound","mashRound","_output","K","R","runPlan","plan","ptr","GCD_30_DELTA","privateKeyValidator","rsaPrivateKeyValidator","rsaPublicKeyValidator","publicKeyValidator","emsaPkcs1v15encode","oidBytes","digestInfo","digestAlgorithm","_modPow","modPow","dP","subtract","ONE","dQ","qInv","modInverse","bitLength","compareTo","gcd","xp","xq","_encodePkcs1_v1_5","bt","eb","padByte","padNum","numZeros","padBytes","_decodePkcs1_v1_5","em","ml","_generateKeyPair","workLoad","workerScript","getPrime","pBits","qBits","prime","generateProbablePrime","p1","q1","phi","privateKey","setPrivateKey","publicKey","setPublicKey","_bnToBytes","_getMillerRabinTests","_detectNodeCrypto","_detectSubtleCrypto","_detectSubtleMsCrypto","_intToUint8Array","yhex","ed","expected","xhex","createKeyPairGenerationState","rng","nextBytes","eInt","pqState","fromInt","stepKeyPairGenerationState","THIRTY","deltaIdx","op_or","total","bits1","testBit","bitwiseTo","shiftLeft","dAddOffset","byteValue","isProbablePrime","modulusLength","publicExponent","publicKeyEncoding","privateKeyEncoding","priv","privateKeyFromPem","publicKeyFromPem","generateKey","pair","exportKey","pkcs8","setRsaPublicKey","genOp","oncomplete","exportOp","keypair","generateKeyPairSync","e3","schemeOptions","pkcs1","encode_rsa_oaep","signature","verify","d1","setRsaPrivateKey","d2","d3","decode_rsa_oaep","rsaEncryption","privateKeyModulus","privateKeyPublicExponent","privateKeyPrivateExponent","privateKeyPrime1","privateKeyPrime2","privateKeyExponent1","privateKeyExponent2","privateKeyCoefficient","privateKeyToRSAPrivateKey","publicKeyFromAsn1","publicKeyOid","rsaPublicKey","publicKeyModulus","publicKeyExponent","publicKeyToAsn1","publicKeyToSubjectPublicKeyInfo","publicKeyToRSAPublicKey","dbits","nbi","am3","xl","xh","am","appName","DB","DM","DV","FV","F1","F2","rr","vv","BI_RC","int2char","intAt","nbv","nbits","Classic","Montgomery","mp","invDigit","mpl","mph","um","mt2","op_and","op_xor","op_andnot","lbit","cbit","NullExp","nNop","Barrett","q3","dlShiftTo","mu","divide","revert","divRemTo","mulTo","multiplyTo","sqrTo","squareTo","ZERO","subTo","copyTo","u0","clamp","drShiftTo","fromRadix","mi","sh","lShiftTo","bs","cbs","bm","ds","rShiftTo","pm","pt","ts","nsh","ys","y0","yt","qd","isEven","negate","toRadix","km","modPowInt","multiplyUpperTo","multiplyLowerTo","lowprimes","lplim","signum","cs","intValue","dMultiply","op","changeBit","addTo","modInt","millerRabin","n1","getLowestSetBit","shiftRight","shortValue","toByteArray","andNot","not","bitCount","setBit","clearBit","flipBit","divideAndRemainder","k1","g2","is1","ac","rsa_mgf1","maskLength","label","mgf1Md","mgf1","keyLength","maxLength","lHash","PS","PS_length","seedLength","dbMask","maskedDB","seedMask","maskedSeed","expectedLength","db","lHashPrime","in_ps","is_0","error_mask","primeincFindPrimeWithoutWorkers","generateRandom","workerMessage","found","primeincFindPrimeWithWorkers","primeincFindPrime","mrTests","getMillerRabinTests","millerRabinTests","maxBlockTime","_primeinc","ciphers","webcrypto","nonceLength","saltLength","nonce","aesGcm","deriveParams","rawKey","importKey","cryptoKey","deriveKey","ciphertext","plaintext","win","nativeCrypto","pbm","exporter","RsaPublicKey","sig","hashAndVerify","jwkToPkix","RsaPrivateKey","_publicKey","genSecret","hashAndSign","jwkToPkcs1","jwk","pkixToJwk","pkcs1ToJwk","fromJwk","sha384","sha224","_states","_h","messageLength128","hlen","t1_hi","t1_lo","t2_hi","t2_lo","s0_hi","s0_lo","s1_hi","ch_hi","maj_hi","maj_lo","a_hi","a_lo","b_hi","b_lo","c_hi","c_lo","d_hi","d_lo","e_hi","e_lo","f_hi","f_lo","g_hi","g_lo","h_hi","h_lo","w2","w7","w15","w16","asn1Validator","NativeBuffer","messageToNativeBuffer","constants","PUBLIC_KEY_BYTE_LENGTH","PRIVATE_KEY_BYTE_LENGTH","SEED_BYTE_LENGTH","SIGN_BYTE_LENGTH","HASH_BYTE_LENGTH","pk","sk","gf","scalarbase","pack","crypto_sign_keypair","privateKeyOid","ed25519Oid","EdDSA25519","privateKeyBytes","publicKeyBytes","ed25519PublicKey","publicKeyFromPrivateKey","signedMsg","sm","smlen","modL","crypto_sign","chk","den","den2","den4","den6","set25519","gf1","unpack25519","M","Z","A","pow2523","neq25519","par25519","gf0","unpackneg","scalarmult","crypto_verify_32","crypto_sign_open","D2","X","Y","msgLen","cswap","sel25519","tx","ty","zi","inv25519","pack25519","car25519","xi","yi","vn","t0","t3","t4","t5","t6","t7","t8","t9","t10","t11","t12","t13","t14","t15","t16","t17","t18","t19","t20","t21","t22","t23","t24","t25","t26","t27","t28","t29","t30","b0","b3","b4","b5","b6","b7","b8","b9","b10","b11","b12","b13","b14","b15","jwKey","kty","jwk2pub","jwk2priv","convertKey","handle","fkey","fomsg","msg1","msg2","MAX_BYTES","bigIntegerToUintBase64url","base64urlToBigInteger","dp","dq","qi","alg","kid","base64urlToBuffer","Ed25519PublicKey","key4","ensureKey","publicKeyLength","Ed25519PrivateKey","publicKey1","privateKeyLength","generateKeyFromSeed","keysProtobuf","Secp256k1PublicKey","validatePublicKey","compressPublicKey","Secp256k1PrivateKey","computePublicKey","validatePrivateKey","privateKeyVerify","ecdsaSign","signatureExport","signatureImport","ecdsaVerify","publicKeyVerify","publicKeyConvert","decompressPublicKey","publicKeyCreate","assert","cond","isUint8Array","isCompressed","toTypeString","getAssertedOutput","contextRandomize","seckey","privateKeyNegate","privateKeyTweakAdd","tweak","privateKeyTweakMul","pubkey","compressed","publicKeyNegate","publicKeyCombine","pubkeys","publicKeyTweakAdd","publicKeyTweakMul","signatureNormalize","outputlen","msg32","noncefn","recid","ecdsaRecover","ecdh","hashfn","xbuf","ybuf","ec","EC","ecparams","curve","BN","loadPublicKey","cmp","toRed","red","redSqr","redIMul","redIAdd","redSqrt","isOdd","redNeg","keyPair","loadCompressedPublicKey","x3","redISub","isZero","loadUncompressedPublicKey","savePublicKey","point","bn","umod","toArrayLike","iadd","isub","tweaked","imul","keyFromPrivate","getPublic","pairs","isInfinity","mul","nh","sigR","sigS","lenR","posR","lenS","posS","_noncefn","canonical","pers","recoveryParam","sigObj","sigr","sigs","recoverPubKey","scalar","getX","toArray","getY","elliptic","rand","curves","eddsa","minAssert","minUtils","zero2","getNAF","naf","ws","andln","isubn","iushrn","getJSF","k2","jsf","m8","cmpn","u1","u2","m14","m24","cachedProperty","computer","intFromLE","inherits","ctor","superCtor","super_","TempCtor","endian","isBN","negative","words","wordSize","parseHex4Bits","parseHexByte","lowerBound","parseBase","_initNumber","_initArray","_parseHex","_parseBase","strip","limbLen","limbPow","imuln","_iaddn","_expand","_normSign","groupSizes","groupBases","smallMulTo","ncarry","rword","maxJ","groupSize","groupBase","modn","idivn","ret","toBuffer","ArrayType","reqLength","littleEndian","clz32","_countBits","_zeroBits","zeroBits","toTwos","width","inotn","iaddn","fromTwos","testn","notn","ineg","isNeg","neg","iuor","ior","uor","iuand","iand","uand","iuxor","ixor","uxor","bytesNeeded","bitsLeft","setn","bit","wbit","comb10MulTo","a0","al0","ah0","al1","ah1","al2","ah2","al3","ah3","al4","ah4","al5","ah5","a6","al6","ah6","a7","al7","ah7","a8","al8","ah8","a9","al9","ah9","bl0","bh0","bl1","bh1","bl2","bh2","bl3","bh3","bl4","bh4","bl5","bh5","bl6","bh6","bl7","bh7","bl8","bh8","bl9","bh9","w0","w1","w3","w4","w5","w6","w8","w9","w10","w11","w12","w13","w14","w17","w18","jumboMulTo","FFTM","mulp","hncarry","bigMulTo","makeRBT","N","revBin","rb","permute","rbt","rws","iws","rtws","itws","rtwdf","cos","PI","itwdf","sin","rtwdf_","itwdf_","ie","ro","io","rx","guessLen13b","odd","conjugate","normalize13b","convert13b","stub","ph","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","muln","sqr","isqr","toBitArray","iushln","carryMask","newCarry","ishln","hint","extended","maskedWords","ishrn","shln","ushln","shrn","ushrn","imaskn","maskn","addn","subn","iabs","_ishlnsubmul","_wordDiv","bhi","qj","divmod","positive","divn","divRound","dm","egcd","C","yp","im","jm","_invmp","x1","x2","delta","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","eq","Red","convertTo","_forceRed","fromRed","convertFrom","forceRed","redAdd","redSub","redShl","shl","redMul","_verify2","_verify1","redISqr","sqrt","redInvm","redPow","primes","k256","p224","p192","p25519","MPrime","_tmp","K256","P224","P192","P25519","_prime","Mont","imod","rinv","minv","ireduce","rlen","imulK","_strip","outLen","mod3","one","nOne","lpow","inv","wnd","current","currentLen","mont","enc","Rand","_rand","short","edwards","BaseCurve","conf","two","pointFromJSON","gRed","_wnafT1","_wnafT2","_wnafT3","_wnafT4","_bitLength","adjustCount","redN","_maxwellTrick","BasePoint","precomputed","_fixedNafMul","doubles","_getDoubles","nafW","repr","jpoint","mixedAdd","points","toP","_wnafMul","nafPoints","_getNAFPoints","dblp","_wnafMulAdd","defW","coeffs","jacobianResult","wndWidth","comb","toJ","ja","jb","decodePoint","pointFromX","encodeCompressed","_encode","precompute","power","beta","_getBeta","_hasDoubles","dbl","Base","ShortCurve","tinv","zeroA","threeA","endo","_getEndomorphism","_endoWnafT1","_endoWnafT2","Point","isRed","inf","JPoint","zOne","lambda","betas","_getEndoRoots","lambdas","basis","vec","_getEndoBasis","ntinv","prevR","aprxSqrt","y1","y2","len1","_endoSplit","v1","v2","p2","q2","ax","rhs","_endoWnafMulAdd","npoints","ncoeffs","fromJSON","pre","endoMul","obj2point","nx","ny","ys1","dyinv","mulAdd","jmulAdd","_precompute","zinv","zinv2","ay","pz2","z2","nz","jx","jy","jz","jz4","jyd","jx2","jyd2","jyd4","dny","_zeroDbl","_threeDbl","_dbl","xx","yy","yyyy","yyyy8","c8","gamma","alpha","beta4","beta8","ggamma8","jy2","jxd4","jyd8","trpl","zz","yyu4","kbase","z3","pz3","eqXToP","zs","MontCurve","a24","normalize","diffAdd","da","cb","jumlAdd","EdwardsCurve","twisted","mOneA","dd","oneC","_mulA","_mulC","lhs","pointFromY","_extDbl","nt","_projDbl","_extAdd","_projAdd","curve1","PresetCurve","defineCurve","ripemd","ripemd160","isSurrogatePair","htonl","zero8","toHex32","join32","split32","rotr32","rotl32","sum32","sum32_3","sum32_4","sum32_5","sum64","al","bh","sum64_hi","sum64_lo","sum64_4_hi","ch","cl","dh","dl","sum64_4_lo","sum64_5_hi","eh","el","sum64_5_lo","rotr64_hi","rotr64_lo","shr64_hi","shr64_lo","BlockHash","pendingTotal","outSize","hmacStrength","padLength","_delta8","_delta32","_pad","_digest","shaCommon","ft_1","sha1_K","SHA1","W","ch32","maj32","p32","s0_256","s1_256","g0_256","g1_256","SHA256","SHA224","sha256_K","T2","SHA512","SHA384","sha512_K","ch64_hi","yh","yl","zh","ch64_lo","zl","maj64_hi","maj64_lo","s0_512_hi","s0_512_lo","s1_512_hi","s1_512_lo","g0_512_hi","g0_512_lo","g1_512_hi","g1_512_lo","_prepareBlock","c0_hi","c0_lo","c1_hi","c1_lo","c2_hi","c2_lo","c3_hi","c3_lo","fh","fl","gh","gl","hl","c4_hi","c4_lo","T1_hi","T1_lo","T2_hi","T2_lo","RIPEMD160","Kh","E","Ah","Bh","Ch","Dh","Eh","rh","Hmac","HmacDRBG","KeyPair","Signature","fromPrivate","keyFromPublic","fromPublic","genKeyPair","drbg","persEnc","entropyEnc","ns2","_truncateToN","truncOnly","bkey","getPrivate","ns1","kp","kpX","sinv","isYOdd","isSecondKey","rInv","getKeyRecoveryParam","Q","Qprime","predResist","minEntropy","reseedInterval","nonceEnc","_hmac","kmac","reseed","addEnc","_importPrivate","privEnc","_importPublic","pubEnc","reason","derive","_importDER","Position","place","getLength","initial","octetLen","rmPadding","constructLength","octets","slen","toDER","backHalf","EDDSA","pointClass","secret","keyFromSecret","hashInt","messagePrefix","Rencoded","encodePoint","s_","pubBytes","makeSignature","SG","fromSecret","lastIx","normed","xIsOdd","encodeInt","decodeInt","isPoint","_secret","_pub","_pubBytes","privBytes","getSecret","_S","_Rencoded","_Sencoded","Sencoded","cipherMap","ivSize","keySize","Blowfish","cipherKeySize","cipherType","allowed","resultLength","todo","resultBuffer","createKey","cipherKey","macKey","hashTypes","generateEphmeralKeyPair","validateCurveType","namedCurve","genSharedKey","theirPub","forcePrivate","deriveBits","curveLengths","crv","ext","private","curveTypes","ClassIsWrapper","withoutNew","_this","rm","rmAll","addAll$1","createAddAll","createAdd","rmAll$1","createRmAll","createRm","createLs","remote","last__default","entry","normaliseInput","pinTypes","pinAdd","metadata","pins","isPinnedWithType","PinTypes","direct","pinRecursively","pinDirectly","lock","gcLock","readLock","toPin","indirect","paths","matched","pinned","recursiveKeys","indirectKeys","cid2","metadata1","directKeys","unpin","offlineDatastore","pass","offline","online","getIPNS","routing","OfflineDatastore","IPNS","datastore","repo1","peerId1","keychain1","createRouting","republisher","publish","lifetime","publisher","IpnsPublisher","IpnsRepublisher","IpnsResolver","defaultRecordLifetime","publishWithEOL","ttEol","Errors","ipns__namespace","ERR_NOT_FOUND","notFoundError","_routing","_datastore","record","_updateOrCreateRecord","_putRecordToRouting","errMsg","embedPublicKeyRecord","embedPublicKey","getIdKeys","_publishEntry","routingKey","_publishPublicKey","routingPubKey","key$1","asKey","entryData","key$11","checkRouting","dsVal","getLocalKey","_unmarshalData","unmarshal","value2","lifetime1","peerId2","getPublishedOptions","_getPublished","seqNumber","sequence","err2","err3","abortedError","dbDeleteFailedError","dbOpenFailedError","dbWriteFailedError","NanoDate","NanoDate__default","Digest__namespace","Long__default","ID_MULTIHASH_CODE","IPNS_PREFIX","namespaceLength","_create","seq","validityType","expirationDate","isoValidity","signatureV1","createCborData","sigData","ipnsEntryDataForV2Sig","validity","signatureV2","Value","Validity","ValidityType","Sequence","TTL","dataForSignature","validateCborDataMatchesPbData","ipnsEntryDataForV1Sig","ERR_SIGNATURE_VERIFICATION","IpnsEntry","EOL","validityDate","parseRFC3339","ERR_UNRECOGNIZED_FORMAT","ERR_IPNS_EXPIRED_RECORD","ERR_UNRECOGNIZED_VALIDITY","ERR_INVALID_RECORD_DATA","extractPublicKey","ERR_UNDEFINED_PARAMETER","ERR_INVALID_EMBEDDED_KEY","rawStdEncoding","ERR_SIGNATURE_CREATION","validityTypeBuffer","getValidityType","extractPublicKeyFromId","validator","marshalledData","receivedEntry","bufferId","select","dataA","dataB","entryA","entryB","entryAValidityDate","lifetimeNs","createWithExpiration","expiration","ttlMs","toDate","ttlNs","getNano","extractedPublicKey","ERR_PEER_ID_FROM_PUBLIC_KEY","ERR_PUBLIC_KEY_FROM_ID","pkBuffer","ipnsBuffer","pkKey","ipnsKey","Timestamp","SEC_DAY","YEAR_SLOT","DAY_SLOT","SEC_SLOT","MSEC_SLOT","MAX_MSEC","BIT32","DEC6","DEC9","ZERO9","trunc","fromDate","fromInt64BE","buildFromInt64","fromInt64LE","nano","UTC","fromTimeT","fromTime","addNano","getTimeT","getYear","newDate","format1","dt","H","pad2","getUTCMilliseconds","FMT_DAY","getUTCDay","FMT_MONTH","strftime","FMT_STRING","writeInt64BE","buildWriteInt64","writeInt64LE","F","changed","slot","pos0","pos1","pos2","pos3","posH","posL","checkRange","writeUint32","cipherMode","createCipheriv","decipher","createDecipheriv","cipher2","CIPHER_MODES","forgePbkdf2","forgeUtil","hashName","dek","wasm","WebAssembly","Instance","Module","isLong","__isLong__","INT_CACHE","UINT_CACHE","cachedObj","UZERO","TWO_PWR_64_DBL","MAX_UNSIGNED_VALUE","TWO_PWR_63_DBL","MIN_VALUE","MAX_VALUE","TWO_PWR_32_DBL","lowBits","highBits","radix","radixToPower","pow_dbl","TWO_PWR_16_DBL","TWO_PWR_24","UONE","NEG_ONE","LongPrototype","toInt","isNegative","radixLong","rem1","rem","remDiv","getHighBits","getHighBitsUnsigned","getLowBits","getLowBitsUnsigned","getNumBitsAbs","eqz","isPositive","notEquals","neq","ne","lessThan","comp","lessThanOrEqual","greaterThan","IpnsEntry1","rfc3339Matcher","toRFC3339","_publisher","_peerId","_keychain","_republishHandle","republishHandle","_task","_inflightTask","runPeriodically","period","firstRun","_republishEntries","initialBroadcastInterval","broadcastInterval","_republishEntry","listKeys","privateKey1","_getPreviousValue","notFound","Errors__namespace","nameSegments","_resolveName","ipnsEntry","_validateRecord","tiered","pubsubDatastore","get__default","ipnsStores","pubsubDs","localDatastore","IpnsPubsubDatastore","offlineDatastore$1","_dht","TieredDatastore","pushable","drain","pushable__default","drain__default","BaseDatastore","stores","store","pushables","putMany","catch","source2","deleteMany","batch","batches","commit","queryKeys","take","filter__default","take__default","puts","dels","options8","options9","_all","filters","orders","sortAll","limit","options10","_allKeys","all__default","replaceStartWith","matcher","iterable","sorter","items","FIFO","onEnd","onNext","ended","bufferNext","bufferError","writev","throw","_pushable","FixedFIFO","hwm","btm","def","undef","datastorePubsub","_subscriptions","_handleSubscriptionKey","_pubsubDs","PubsubDatastore","stringifiedTopic","subscriber","getSubscriptions","canceled","bufTopic","unsubscribe","interfaceDatastore","datastoreCore","subscriptionKeyFn","_pubsub","_validator","_handleSubscriptionKeyFn","_onMessage","keyToTopic","subscriptions","getTopics","_getLocal","subscribe","encodeBase32","topicIDs","topicToKey","_storeIfSubscriptionIsBetter","isBetter","_isBetter","_storeRecord","key5","records","key6","dsKey","currentRecord","_selectRecord","key7","shard$1","memory","keytransform","sharding","shard","MemoryDatastore","KeyTransformDatastore","ShardingDatastore","MountDatastore","NamespaceDatastore","shardReadme","PREFIX","SHARDING_FN","ShardBase","param1","Prefix","prefixLen","noslash","Suffix","suffixLen","noslash1","NextToLast","suffixLen1","noslash2","parseShardFun","readme","README_FN","readShardFun","getRaw","itPipe","map__default","pipe","invert","getMany","source3","rawPipe","fns","isIterable","isDuplex","sink","duplexPipelineFn","duplex","shardKey","shardReadmeKey","shard1","_convertKey","_invertKey","store1","shard2","store2","store3","hasShard","putRaw","diskShard","tq","merge__default","mounts","_lookup","mountpoint","batchMounts","lookup","qs","sources","topic","libp2pRecord","_repo","_routingKey","Record","serialize","deserialize","selection","PBRecord","timeReceived","prepareSerialize","fromDeserialized","recvtime","verifyRecord","validators","keyhash","publicKeyHash","bestRecord","selectors","selector","createPublish","PubSubAPI","utils$1","lookupKey","keyName","pubLifetime","isDomain","isDomain__default","appendRemainder","domainNameRegex","domainName","rootDot","lastChar","subs","createCancel","createState","createSubs","experimental","getPubsubRouting","ipnsPubsub","Format","edges","refsStream","resPath","maxDepth","unique","rootCid","uniqueOnly","seen","Set","traverseLevel","nextLevelDepth","isDagPb","getLinks","isDuplicate","objectStream","ref","formatLink","srcCid","dstCid","linkName","elementPath","getFullPath","wantlist","wantlistForPeer","unwant","stat","createWantlist","createWantlistForPeer","createUnwant","createStat","getWantlist","cids","snapshot","provideBufLen","providesBufferLength","blocksReceived","peers","dupBlksReceived","dupDataReceived","dataReceived","blocksSent","dataSent","createList","createClear","createReset","isValidMultiaddr","boostrappers","Bootstrap","localeCompare","Peers","mafmt__default","removed","getDefaultConfig","getDefaultConfig__default","Addresses","Swarm","Announce","NoAnnounce","API","Gateway","RPC","Delegates","Discovery","MDNS","Enabled","Interval","webRTCStar","Pubsub","ConnMgr","LowWater","HighWater","DisableNatPortMap","Routing","createGet","createPut","cidVersion","codecName","getHasher","parallel","parallel__default","writeLock","cleanCid","force","quiet","defer","ops","slotAvailable","sourceFinished","resultAvailable","task","deferred","ReflectOwnKeys","Reflect","ReflectApply","receiver","Function","ownKeys","getOwnPropertyNames","NumberIsNaN","errorListener","eventTargetAgnosticAddListener","handler","flags","addErrorHandlerIfEventEmitter","_maxListeners","defaultMaxListeners","checkListener","_getMaxListeners","_addListener","prepend","existing","warning","newListener","onceWrapper","fired","wrapFn","_onceWrap","wrapped","unwrap","evlistener","unwrapListeners","arrayClone","wrapListener","setMaxListeners","getMaxListeners","doError","er","position","originalListener","spliceOne","rawListeners","createCat","ipfsUnixfsImporter","isShardingEnabled","shardSplitThreshold","strategy","parseChunkerString","chunker","hashAlg","trickle","leafType","reduceSingleLeafToSelf","rawLeaves","totals","progress","prog","transformFile","wrapWithDirectory","transformFile1","maybePreloadFile","onlyHash","preloadFile","maybePinFile","isRootDir","pinFile","added","parallelBatch","treeBuilder","parallelBatch__default","blockstore","options$1","dagBuilder","treeBuilder$1","candidates","fileImportConcurrency","tasks","things","thing","murmur3","mergeOptions__default","defaultOptions","blockWriteConcurrency","minChunkSize","maxChunkSize","avgChunkSize","polynomial","maxChildrenPerNode","layerRepeat","hamtHashFn","murmur3128","hamtHashCode","hamtBucketBits","multiformats","mur__default","murmur332","fromNumberTo32BitBuf","x86","hash32","x64","hash128","library","inputValidation","_validBytes","_x86Multiply","_x86Rotl","_x86Fmix","_x64Add","_x64Multiply","_x64Rotl","_x64LeftShift","_x64Xor","_x64Fmix","k3","k4","c3","c4","murmurHash3","define","amd","_murmurHash3","noConflict","rabin","fixedSize","validateChunks","contentAsAsyncIterable","content","chunkValidator","dir$1","persist","dagPb","dagPb__namespace","rawCodec","flat","balanced","bufferImporter","rawCodec__namespace","dagBuilders","previous","bufferImporter$1","single","buildFileBatch","leaves","leaf","batch__default","reduceToParents","chunked","SubTree","iteration","currentDepth","children","maxChildren","isFull","_addNextNodeToParent","distantRelative","_findParent","nextNode","append","layer","_reduce","reduce1","node1","Root","layerRepeat1","addChild","reduce2","subTree","BufferList","rabinWasm","BufferList__default","sizepow","log2","buffers","sizes","fingerprint","consume","_bufs","_new","_offset","tot","_t","_reverseOffset","blOffset","dstStart","srcStart","srcEnd","bufoff","shallowSlice","startOffset","endOffset","duplicate","_appendBuffer","_isBufferList","blIndex","buffOffset","nativeSearchResult","revOffset","_match","searchOffset","methods","readDoubleBE","readInt32BE","readInt32LE","readUInt32BE","readUInt32LE","readInt16BE","readInt16LE","readUInt16BE","readUInt16LE","readInt8","readUInt8","readIntBE","readIntLE","readUIntBE","readUIntLE","isBufferList","ieee754","customInspectSymbol","SlowBuffer","INSPECT_MAX_BYTES","K_MAX_LENGTH","encodingOrOffset","isEncoding","byteLength1","actual","arrayView","isInstance","fromArrayBuffer","fromArrayLike","fromArrayView","SharedArrayBuffer","valueOf","checked","numberIsNaN","toPrimitive","assertSize","mustMatch","loweredCase","base64ToBytes","slowToString","hexSlice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","bidirectionalIndexOf","arrayIndexOf","indexSize","arrLength","valLength","foundIndex","hexWrite","strLen","blitBuffer","asciiWrite","byteArray","asciiToBytes","base64Write","ucs2Write","utf16leToBytes","fromByteArray","MAX_ARGUMENTS_LENGTH","kMaxLength","TYPED_ARRAY_SUPPORT","foo","typedArraySupport","poolSize","allocUnsafeSlow","_isBuffer","swap16","swap32","swap64","toLocaleString","thisStart","thisEnd","thisCopy","targetCopy","_arr","hexSliceLookupTable","checkOffset","checkInt","checkIEEE754","writeFloat","noAssert","writeDouble","newBuf","readUint16LE","readUint16BE","readUint32LE","readUint32BE","writeUIntLE","writeUIntBE","writeUint8","writeUInt8","writeUint16LE","writeUInt16LE","writeUint16BE","writeUInt16BE","writeUint32LE","writeUInt32LE","writeUint32BE","writeUInt32BE","writeIntLE","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","targetStart","copyWithin","INVALID_BASE64_RE","base64clean","i16","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","maxChunkLength","len2","encodeChunk","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","rt","Rabin","getRabin","windowSize","compiled","asModule","__retain","__release","__allocArray","__getInt32Array","Int32Array_ID","Uint8Array_ID","lengthsPtr","Int32Array","pointer","processed","instantiate","loadWebAssembly","imp","BIGINT","BigUint64Array","THIS","CHUNKSIZE","getStringImpl","U32","U16","preInstantiate","imports","baseModule","getString","mesg","colm","trace","postInstantiate","rawExports","retain","rttiBase","getInfo","getValueAlign","info","getView","alignLog2","signed","Int8Array","Int16Array","BigInt64Array","__getArrayView","align","getTypedArray","getTypedArrayView","bufPtr","__allocString","__getString","__getArray","__getArrayBuffer","__getInt8Array","__getInt8ArrayView","__getUint8Array","__getUint8ArrayView","__getUint8ClampedArray","Uint8ClampedArray","__getUint8ClampedArrayView","__getInt16Array","__getInt16ArrayView","__getUint16Array","__getUint16ArrayView","__getInt32ArrayView","__getUint32Array","__getUint32ArrayView","__getInt64Array","__getInt64ArrayView","__getUint64Array","__getUint64ArrayView","__getFloat32Array","__getFloat32ArrayView","__getFloat64Array","__getFloat64ArrayView","__instanceof","baseId","demangle","isResponse","instantiateStreaming","compile","arrayBuffer","setArgumentsLength","internalName","elem","classElem","wrap","thisValue","getter","setter","instantiateSync","currentLength","emitted","newBl","dirFlat","flatToShard","toPathComponents","addToTree","tree","pathElems","currentPath","pathElem","dirty","parentKey","flushAndYield","flush","unwrapped","eachChildSeries","_children","childCount","directChildrenCount","onlyChild","dirSharded","threshold","newDir","oldDir","convertToShard","dir1","hamtSharding","bucket","shardRoot","childrenSize","labelPrefix","Bucket","subShard","flushedDir","bitField","tableSize","_bucket","createHAMT","hashFn","leafCount","childrenCount","eachLeafSeries","blockstore1","wrapHash","bucketOptions","SparseArray","posAtParent","_popCount","_parent","_posAtParent","_findNewBucketAndPos","_putAt","_findChild","_findPlace","_at","_delAt","compactArray","asyncTransform","asyncMap1","asyncReduce1","asyncTransformBucket","mapNode","reduceNodes","hashValue","existingChild","_putObjectAt","newPlace","unset","_level","exists","untake","nodes","asyncMap","asyncReduce","mappedChildren","popCountReduce","popCount","_v","sortInternal","valueOnly","_bitArrays","_length","_changedLength","_changedData","_internalPositionFor","_unsetInternalPos","_unsetBit","needsSort","_setBit","_setInternalPos","index1","index2","_sortData","iterator1","mapped","reducer","initialValue","finder","index3","noCreate","bytePos","_bytePosFor","bitPos","index4","noCreate1","targetLength","index5","index6","index7","randomIndex","newByte","pendingBitsForResultingByte","pendingBitsForNewByte","resultingByte","usingBits","ConsumableBuffer","InfiniteHash","_value","_hashFn","_depth","_availableBits","_currentBufferIndex","_buffers","pendingBits","_produceMoreBits","availableBits","availableForUntake","totalBits","START_MASKS","STOP_MASKS","byteBitsToInt","maskFor","_currentBytePos","_currentBitPos","_haveBits","taking","normaliseContent","normalise","browserStreamToIt","blobToIt","itPeekable","browserStreamToIt__default","blobToIt__default","itPeekable__default","isBytes","isBlob","isReadableStream","peekable","peek","toAsyncGenerator","preventCancel","browserReadableStreamToIt","blob","isFileObject","toFileObject","_readableState","parseRabinString","parseChunkSize","sizeStr","ipfsUnixfsExporter","pathComponents","cidAndRest","toResolve","walkPath","entryPath","startingDepth","recurse","dagCbor","raw$1","dagCbor$1","dagCbor__namespace","raw__namespace","findCidInShard","directory","hamtShardedDirectory","contentExporters","symlink","linkCid","link1","findLinkCid","nextName","toPrefix","findShardCid","rootBucket","hamtDepth","lastBucket","bucketPath","toBucketPath","entryPrefix","entryName","extractDataFromBlock","validateOffsetAndLength","emitBytes","streamPosition","childStart","childLink","childEnd","blockStart","requestedStart","requestedEnd","blockEnd","listDirectory","subObject","subPath","subObjectCid","mh__namespace","itTar","Pako","Pako__default","toBuffer__default","compressionLevel","ipfsPathOrCid","compress","archive","gzip","extract","LteReader","discardPadding","getPadding","highWaterMark","gnuLongPath","gnuLongLinkPath","paxGlobal","pax","headerBytes","filenameEncoding","gnuLongPathBytes","decodeLongPath","gnuLongLinkPathBytes","paxGlobalBytes","decodePax","paxBytes","linkname","linkpath","bytesRemaining","bodyConsumed","firstChunk","nextLte","ZERO_OFFSET","USTAR_MAGIC","GNU_MAGIC","GNU_VER","MAGIC_OFFSET","decodeOct","parse256","defaultValue","decodeStr","keyIndex","typeflag","uid","gid","flag","toType","uname","gname","devmajor","devminor","cksum","VERSION_OFFSET","lteReader","nextValue","S_IFMT","S_IFBLK","S_IFCHR","S_IFDIR","S_IFIFO","S_IFLNK","DMODE","FMODE","END_OF_TAR","modeToType","encoded","paxHeader","encodePax","newHeader","RTLD_LAZY","RTLD_NOW","RTLD_GLOBAL","RTLD_LOCAL","RTLD_DEEPBIND","E2BIG","EACCES","EADDRINUSE","EADDRNOTAVAIL","EAFNOSUPPORT","EAGAIN","EALREADY","EBADF","EBADMSG","EBUSY","ECANCELED","ECHILD","ECONNABORTED","ECONNREFUSED","ECONNRESET","EDEADLK","EDESTADDRREQ","EDOM","EDQUOT","EEXIST","EFAULT","EFBIG","EHOSTUNREACH","EIDRM","EILSEQ","EINPROGRESS","EINTR","EINVAL","EIO","EISCONN","EISDIR","ELOOP","EMFILE","EMLINK","EMSGSIZE","EMULTIHOP","ENAMETOOLONG","ENETDOWN","ENETRESET","ENETUNREACH","ENFILE","ENOBUFS","ENODATA","ENODEV","ENOENT","ENOEXEC","ENOLCK","ENOLINK","ENOMEM","ENOMSG","ENOPROTOOPT","ENOSPC","ENOSR","ENOSTR","ENOSYS","ENOTCONN","ENOTDIR","ENOTEMPTY","ENOTSOCK","ENOTSUP","ENOTTY","ENXIO","EOPNOTSUPP","EOVERFLOW","EPERM","EPIPE","EPROTO","EPROTONOSUPPORT","EPROTOTYPE","ERANGE","EROFS","ESPIPE","ESRCH","ESTALE","ETIME","ETIMEDOUT","ETXTBSY","EWOULDBLOCK","EXDEV","PRIORITY_LOW","PRIORITY_BELOW_NORMAL","PRIORITY_NORMAL","PRIORITY_ABOVE_NORMAL","PRIORITY_HIGH","PRIORITY_HIGHEST","SIGHUP","SIGINT","SIGQUIT","SIGILL","SIGTRAP","SIGABRT","SIGIOT","SIGBUS","SIGFPE","SIGKILL","SIGUSR1","SIGSEGV","SIGUSR2","SIGPIPE","SIGALRM","SIGTERM","SIGCHLD","SIGSTKFLT","SIGCONT","SIGSTOP","SIGTSTP","SIGTTIN","SIGTTOU","SIGURG","SIGXCPU","SIGXFSZ","SIGVTALRM","SIGPROF","SIGWINCH","SIGIO","SIGPOLL","SIGPWR","SIGSYS","SIGUNUSED","UV_FS_SYMLINK_DIR","UV_FS_SYMLINK_JUNCTION","O_RDONLY","O_WRONLY","O_RDWR","UV_DIRENT_UNKNOWN","UV_DIRENT_FILE","UV_DIRENT_DIR","UV_DIRENT_LINK","UV_DIRENT_FIFO","UV_DIRENT_SOCKET","UV_DIRENT_CHAR","UV_DIRENT_BLOCK","S_IFREG","S_IFSOCK","O_CREAT","O_EXCL","UV_FS_O_FILEMAP","O_NOCTTY","O_TRUNC","O_APPEND","O_DIRECTORY","O_NOATIME","O_NOFOLLOW","O_SYNC","O_DSYNC","O_DIRECT","O_NONBLOCK","S_IRWXU","S_IRUSR","S_IWUSR","S_IXUSR","S_IRWXG","S_IRGRP","S_IWGRP","S_IXGRP","S_IRWXO","S_IROTH","S_IWOTH","S_IXOTH","F_OK","R_OK","W_OK","X_OK","UV_FS_COPYFILE_EXCL","COPYFILE_EXCL","UV_FS_COPYFILE_FICLONE","COPYFILE_FICLONE","UV_FS_COPYFILE_FICLONE_FORCE","COPYFILE_FICLONE_FORCE","OPENSSL_VERSION_NUMBER","SSL_OP_ALL","SSL_OP_ALLOW_NO_DHE_KEX","SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION","SSL_OP_CIPHER_SERVER_PREFERENCE","SSL_OP_CISCO_ANYCONNECT","SSL_OP_COOKIE_EXCHANGE","SSL_OP_CRYPTOPRO_TLSEXT_BUG","SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS","SSL_OP_EPHEMERAL_RSA","SSL_OP_LEGACY_SERVER_CONNECT","SSL_OP_MICROSOFT_BIG_SSLV3_BUFFER","SSL_OP_MICROSOFT_SESS_ID_BUG","SSL_OP_MSIE_SSLV2_RSA_PADDING","SSL_OP_NETSCAPE_CA_DN_BUG","SSL_OP_NETSCAPE_CHALLENGE_BUG","SSL_OP_NETSCAPE_DEMO_CIPHER_CHANGE_BUG","SSL_OP_NETSCAPE_REUSE_CIPHER_CHANGE_BUG","SSL_OP_NO_COMPRESSION","SSL_OP_NO_ENCRYPT_THEN_MAC","SSL_OP_NO_QUERY_MTU","SSL_OP_NO_RENEGOTIATION","SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION","SSL_OP_NO_SSLv2","SSL_OP_NO_SSLv3","SSL_OP_NO_TICKET","SSL_OP_NO_TLSv1","SSL_OP_NO_TLSv1_1","SSL_OP_NO_TLSv1_2","SSL_OP_NO_TLSv1_3","SSL_OP_PKCS1_CHECK_1","SSL_OP_PKCS1_CHECK_2","SSL_OP_PRIORITIZE_CHACHA","SSL_OP_SINGLE_DH_USE","SSL_OP_SINGLE_ECDH_USE","SSL_OP_SSLEAY_080_CLIENT_DH_BUG","SSL_OP_SSLREF2_REUSE_CERT_TYPE_BUG","SSL_OP_TLS_BLOCK_PADDING_BUG","SSL_OP_TLS_D5_BUG","SSL_OP_TLS_ROLLBACK_BUG","ENGINE_METHOD_RSA","ENGINE_METHOD_DSA","ENGINE_METHOD_DH","ENGINE_METHOD_RAND","ENGINE_METHOD_EC","ENGINE_METHOD_CIPHERS","ENGINE_METHOD_DIGESTS","ENGINE_METHOD_PKEY_METHS","ENGINE_METHOD_PKEY_ASN1_METHS","ENGINE_METHOD_ALL","ENGINE_METHOD_NONE","DH_CHECK_P_NOT_SAFE_PRIME","DH_CHECK_P_NOT_PRIME","DH_UNABLE_TO_CHECK_GENERATOR","DH_NOT_SUITABLE_GENERATOR","ALPN_ENABLED","RSA_PKCS1_PADDING","RSA_SSLV23_PADDING","RSA_NO_PADDING","RSA_PKCS1_OAEP_PADDING","RSA_X931_PADDING","RSA_PKCS1_PSS_PADDING","RSA_PSS_SALTLEN_DIGEST","RSA_PSS_SALTLEN_MAX_SIGN","RSA_PSS_SALTLEN_AUTO","defaultCoreCipherList","TLS1_VERSION","TLS1_1_VERSION","TLS1_2_VERSION","TLS1_3_VERSION","POINT_CONVERSION_COMPRESSED","POINT_CONVERSION_UNCOMPRESSED","POINT_CONVERSION_HYBRID","TypeDefault","USTAR_VER","MASK","encodeOct","addLength","toTypeflag","pako","TYPED_OK","_has","shrinkBuf","fnTyped","arraySet","src_offs","dest_offs","flattenChunks","fnUntyped","setTyped","Buf8","Buf16","Buf32","zlib_deflate","strings","ZStream","Deflate","windowBits","memLevel","to","opt","strm","avail_out","deflateInit2","deflateSetHeader","dictionary","dict","string2buf","deflateSetDictionary","_dict_set","deflator","next_in","avail_in","next_out","onData","buf2binstring","deflateEnd","deflateRaw","configuration_table","trees","adler32","crc32","Z_STREAM_ERROR","MAX_MATCH","MIN_LOOKAHEAD","HCRC_STATE","BUSY_STATE","FINISH_STATE","errorCode","rank","flush_pending","pending_buf","pending_out","total_out","flush_block_only","_tr_flush_block","block_start","strstart","put_byte","putShortMSB","longest_match","cur_match","chain_length","max_chain_length","scan","best_len","prev_length","nice_match","w_size","_win","wmask","w_mask","strend","scan_end1","scan_end","good_match","lookahead","match_start","fill_window","more","_w_size","window_size","hash_size","adler","total_in","ins_h","hash_shift","hash_mask","deflate_fast","hash_head","bflush","match_length","_tr_tally","max_lazy_match","MIN_MATCH","last_lit","deflate_slow","max_insert","prev_match","match_available","Config","good_length","max_lazy","nice_length","max_chain","DeflateState","pending_buf_size","gzhead","gzindex","last_flush","w_bits","hash_bits","dyn_ltree","HEAP_SIZE","dyn_dtree","bl_tree","l_desc","d_desc","bl_desc","bl_count","MAX_BITS","heap","heap_len","heap_max","l_buf","lit_bufsize","d_buf","opt_len","static_len","bi_buf","bi_valid","deflateResetKeep","data_type","_tr_init","deflateReset","max_block_size","max_start","deflateInit","old_flush","beg","hcrc","extra","comment","os","bstate","deflate_huff","deflate_rle","_tr_align","_tr_stored_block","avail","tmpDict","dictLength","deflateInfo","LITERALS","L_CODES","D_CODES","extra_lbits","extra_dbits","extra_blbits","bl_order","static_ltree","static_dtree","_dist_code","_length_code","base_length","static_l_desc","static_d_desc","static_bl_desc","base_dist","StaticTreeDesc","static_tree","extra_bits","extra_base","elems","max_length","has_stree","TreeDesc","dyn_tree","stat_desc","max_code","d_code","dist","put_short","send_bits","send_code","bi_reverse","gen_codes","next_code","init_block","END_BLOCK","bi_windup","smaller","_n2","_m2","pqdownheap","compress_block","ltree","dtree","lc","lx","build_tree","desc","stree","xbits","gen_bitlen","scan_tree","curlen","prevlen","nextlen","max_count","min_count","REP_3_6","REPZ_3_10","REPZ_11_138","send_tree","static_init_done","stored_len","copy_block","LENGTH_CODES","tr_static_init","opt_lenb","static_lenb","max_blindex","black_mask","detect_data_type","BL_CODES","build_bl_tree","lcodes","dcodes","blcodes","send_all_trees","STATIC_TREES","bi_flush","crcTable","makeTable","crc","STR_APPLY_OK","STR_APPLY_UIA_OK","__","__1","_utf8len","m_pos","str_len","buf_len","binstring2buf","buf2string","c_len","utf16buf","utf8border","zlib_inflate","GZheader","Inflate","inflateInit2","Z_OK","inflateGetHeader","inflateSetDictionary","inflator","next_out_utf8","utf8str","allowBufError","Z_FINISH","Z_NO_FLUSH","Z_NEED_DICT","Z_BUF_ERROR","Z_STREAM_END","Z_SYNC_FLUSH","inflateEnd","inflateRaw","ungzip","inflate_fast","inflate_table","TYPE","BAD","zswap32","InflateState","havedict","dmax","check","wbits","wsize","whave","wnext","hold","lencode","distcode","lenbits","distbits","ncode","nlen","ndist","have","work","lendyn","distdyn","sane","back","was","inflateResetKeep","inflateReset","inflateReset2","lenfix","distfix","virgin","fixedtables","sym","updatewindow","inflateInit","_in","_out","from_source","here_bits","here_op","here_val","last_bits","last_op","last_val","here","hbuf","order","inf_leave","xflags","extra_len","inflateInfo","s_window","lcode","dcode","lmask","dmask","dolen","dodist","MAXBITS","lbase","lext","dbase","dext","lens_index","table_index","incr","drop","huff","base_index","offs","extra_index","Z_PARTIAL_FLUSH","Z_FULL_FLUSH","Z_BLOCK","Z_TREES","Z_ERRNO","Z_DATA_ERROR","Z_NO_COMPRESSION","Z_BEST_SPEED","Z_BEST_COMPRESSION","Z_DEFAULT_COMPRESSION","Z_FILTERED","Z_HUFFMAN_ONLY","Z_RLE","Z_FIXED","Z_DEFAULT_STRATEGY","Z_BINARY","Z_TEXT","Z_UNKNOWN","Z_DEFLATED","legacyPath","repoVersion","ipfsCore","interfaceIpfsCore","agentVersion","protocolVersion","peerStore","keyBook","addressBook","getMultiaddrsForPeer","multiaddrs","protoBook","upgrader","metadataBook","getValue","idStr","profiles","listProfiles","description","profileName","dryRun","profile","oldCfg","newCfg","Identity","PrivKey","updated","set__default","server","defaultConfig","lowpower","prototypeCheck","propsArg","lastProp","thisProp","_export","_import","createExport","createImport","block1","writer1","json__namespace","NO_LINKS_CODECS","traverseWrite","b58Cid","createUnsafe","getBlock","writer$1","CarWriter","Block","asBlock","maybeValue","iteratorChannel","roots3","encoder1","_encoder","_mutex","setRoots","_ended","writeBlock","roots1","_roots","_root","toRoots","encodeWriter","CarWriterOut","roots2","bytesReader","readHeader","createHeader","_iterator","_iterating","iw","createEncoder","__browser","varint__default","varintBytes","chunkQueue","drainer1","drainerResolver","outWait","outWaitResolver","makeDrainer","drainer","CIDV0_BYTES","readVarint","upTo","seek","exactly","readCid","codeLength","mhLength","readMultihash","readBlockHead","readBlock","readBlockIndex","blockOffset","chunkReader","readChunk","currentChunk","bufa","asyncIterableReader","asyncIterable","createDecoder","headerPromise","first__default","localResolve","importCar","CarBlockIterator","fromIterable","getRoots","abortOptions","cars","car","pinRoots","pinErrorMsg","CarIteratorBase","_version","_iterable","_decoded","asyncIterable2","CarCIDIterator","asyncIterable1","decodeIterator","decoder$1","dagNode","toUri","shuffle","nativeAbortController","hashlru","toUri__default","shuffle__default","stopped","requests","apiUris","fallbackApiUris","uri","reduceValue","Reducers","ip4","ip6","tcp","assumeHttp","explicitPort","tcpUri","udp","dnsaddr","dns4","dns6","p2p","http","https","wss","parts1","newIndex","timeoutId","preloadMfs","nextRootCid","createLock","chmod","cp","mkdir","mv","touch","readOperations","writeOperations","createChmod","createCp","createFlush","createMkdir","createMv","createTouch","unwrappedOperations","createWrite","createRead","mfs","operations","repoOwner","constructorOptions","createMfs","withPreload","mortice__default","mutex","singleProcess","Queue","mutexes","implementation","createReleaseable","createMutex","isWorker","masterQueue","readQueue","localReadQueue","readPromise","onIdle","finally","script","Impl","WORKER_REQUEST_READ_LOCK","WORKER_RELEASE_READ_LOCK","MASTER_GRANT_READ_LOCK","WORKER_REQUEST_WRITE_LOCK","WORKER_RELEASE_WRITE_LOCK","MASTER_GRANT_WRITE_LOCK","cluster","handleWorkerLockRequest","masterEvent","requestType","releaseType","grantType","requestEvent","identifier","releaseEventListener","releaseEvent","makeWorkerLockRequest","isMaster","observer","event1","responseEvent","observable","dispatchEvent","timeoutMillis","toMfsPath","withLocal","statters","cumulativeSize","sizeLocal","withLocality","mfsPath","exportPath","withMfsRoot","loadMfsRoot","entryType","mfsDirectory","toTrail","addLink","updateTree","updateMfsRoot","parseSymbolicMode","originalMode","references","operator","modification","calculateModification","ugo","calculateUGO","calculateSpecial","calculateMode","strMode","updatedBlock","updatedCid","trail","parentCid","parentBlock","parentNode","newRootCid","fsEntry","hamtUtils","convertToShardedDirectory","createShard","addToDirectory","parentLinks","addToShardedDirectory","addFileToShardedDirectory","newLink","updateHamtDirectory","recreateInitialHamtLevel","DirSharded","segment","recreateHamtLevel","nextSegment","addLinksToHamtBucket","positionInBucket","meta","hamtConstants","Dir","blockstore2","props1","parentBucket","positionAtParent","contents","generatePath","fileName","rootNode","currentBucket","parents","destination","copyToFile","destinationTrail","addSourceToParent","copyToDirectory","childName","sourceBlock","missing","destinationIsDirectory","parentFolder","destinationPath","destinationName","emptyDir","subPathComponents","removeLink","removePath","removeFromDirectory","removeFromShardedDirectory","del","updateShard","positions","nodeLink","newName","updateShardParent","oldName","settings","toAsyncIterator","updateOrImport","parentExists","updatedPath","asyncZeroes","limitAsyncStreamBytes","countBytesStreamed","catAsyncIterators","bytesWritten","_asyncZeroes","notify","wrote","FileReader","handleLoad","ev","readAsArrayBuffer","toOutput","gen","rename","createGen","createRename","createInfo","DEFAULT_KEY_TYPE","findKeyByName","renameKey","overwrite","removeKey","createData","createLinks","new","createNew","patch","ObjectPatchAPI","get$1","findLinks","template","linkLength","NumLinks","BlockSize","LinksSize","DataSize","CumulativeSize","appendData","rmLink","setData","createAddLink","createAppendData","createRmLink","createSetData","put$1","newData","linkRef","gc","createGc","setApiAddr","apiAddr","mfsRootCid","numObjects","repoSize","storageMax","_checkInitialized","bw","stat$1","createBw","getBandwidthStats","metrics","peer","forPeer","forProtocol","totalIn","totalOut","rateIn","rateOut","movingAverages","integerValue","movingAverage","poll","repo2","profiles1","errors$1","print2","repoAutoMigrate","inputRepo","onMigrationProgress","repo$1","createRepo","autoMigrate","loadRepo","closed","configureRepo","ERR_REPO_NOT_INITIALIZED","allowNew","initRepo","decodePeerId","initPeerId","peerIdToIdentity","PeerID","applyProfiles","keychainConfig","libp2p$1","createLibp2p","loadKeychain","DEK","mergeConfigs","Keychain","changes","config1","profiles$1","ipfsRepo","datastoreLevel","blockstoreDatastoreAdapter","codeOrName","LevelDatastore","BlockstoreDatastoreAdapter","repoLock","MemoryLock","_get","migrator","spec1","idstore","defaultDatastore","pinManager","pinnedBlockstore","mortice","_get__default","migrator__namespace","bytes__default","noLimit","Repo","loadCodec1","backends2","pinstore","PinManager","pinnedBlockstore$1","createPinnedBlockstore","createIdStore","spec","_config","_openRoot","Datastore","Spec","mounting","shardFunc","buildDatastoreSpec","ERR_REPO_ALREADY_OPEN","_lockfile","_openLock","_isAutoMigrationEnabled","InvalidRepoVersionError","_migrate","_closeLock","lockfile","ERR_REPO_ALREADY_CLOSED","_storageMaxStat","_blockStat","getSize","autoMigrateConfig","NotFoundError","toVersion","backends1","ignoreLock","onProgress","migrate","backends","getLatestMigrationVersion","migrations","verifyAvailableMigrations","fromVersion","checkReversibility","migrationCounter","migration","NonReversibleMigrationError","InvalidValueError","getCurrentRepoVersion","getVersion","migrations1","repoOptions","isDryRun","RequiredParameterError","wrapBackends","currentVersion","progressCallback","percent","lastSuccessfullyMigratedVersion","setVersion","reversedMigrationArray","lastSuccessfullyRevertedVersion","emptyMigration","defaultMigrations","mhd","length__default","mhd__namespace","keyToMultihash","multihashStr","keyToCid","keyFunction","blockCount","newKey","cbor","pinSet","cbor__namespace","pinsToDatastore","PIN_DS_KEY","pinRootBuf","pinRoot","pinCount","loadSet","cidToKey","pinsToDAG","recursivePins","directPins","storeSet","pin1","fnv1a","fnv1a__default","PinSet","walkItems","pbh","rootData","hdrLength","vBytes","hdrSlice","linkHash","EMPTY_KEY","storeItems","storePins","pbHeader","DEFAULT_FANOUT","headerBuf","fanoutLinks","MAX_ITEMS","rootLinks","bins1","bins","setUint32","encodedKey","bin","storeChild","binIdx","ipfs1","keysToBinary","findLevelJs","withEach","keysToStrings","datastores","backend","migrated","_deserializeKey","_deserializeValue","handleNext","handleEnd","transaction","loop","onsuccess","CONFIG_KEY","VERSION_KEY","hasWithFallback","levelJs","wrapStore","originalGet","originalHas","getWithFallback","isRepoInitialized","NotInitializedRepoError","MissingRepoOptionsError","versionCheck","configCheck","formatThousandsRegExp","formatDecimalsRegExp","kb","mb","gb","tb","pb","parseRegExp","mag","thousandsSeparator","unitSeparator","decimalPlaces","fixedDecimals","unit","floatValue","versionKey","LockExistsError","_set","_set__default","configKey","setQueue","configStore","encodedValue","_maybeDoSet","_saveAll","sortKeys","sortKeys__default","specKey","deep","isPlainObject","object1","seenInput","seenOutput","deepSortArray","seenIndex","newValue","apiFile","extractContents","isIdentity","extracted","lockFile","LOCKS","locked","sync","compression","cid6","walkDag","cid3","fetchCompleteDag","entry1","entry2","childCid","cid4","findChild","cid5","block$1","invalidPinTypeErr","ensureNotPinned","markedSet","mfsSource","pinsSource","createMarkedSet","blockKeys","blocksCount","removedBlocksCount","removeBlock","deleteUnmarkedBlocks","Level","sort__default","Level__default","database","_initDb","valueEncoding","_query","iteratorOpts","keyAsBuffer","levelup","leveldown","DeferredLevelDOWN","IteratorStream","Batch","supports","catering","getCallback","getOptions","WriteError","ReadError","OpenError","InitializationError","LevelUP","_db","deferredOpen","openCallback","promises","streams","additionalMethods","maybeError","isOperational","fromCallback","isOpen","_isOpening","isClosed","readStream","createReadStream","keyStream","createKeyStream","valueStream","createValueStream","_nextTick","getOwnPropertyDescriptors","descriptors","formatRegExp","isNull","noDeprecation","throwDeprecation","traceDeprecation","debugs","debugEnvRegex","stylize","stylizeNoColor","isBoolean","showHidden","_extend","isUndefined","customInspect","stylizeWithColor","formatValue","styleType","styles","recurseTimes","isFunction","primitive","simple","isNumber","formatPrimitive","visibleKeys","arrayToHash","isError","formatError","isRegExp","isDate","braces","toUTCString","formatProperty","formatArray","numLinesEst","cur","reduceToSingleString","ar","objectToString","debuglog","bold","italic","underline","inverse","white","grey","black","blue","cyan","green","magenta","yellow","special","isNullOrUndefined","isSymbol","isNativeError","isPrimitive","months","timestamp","getHours","getMinutes","getSeconds","getDate","getMonth","kCustomPromisifiedSymbol","callbackifyOnRejected","newReason","promisify","promiseResolve","promiseReject","custom","callbackify","callbackified","maybeCb","rej","isArgumentsObject","isGeneratorFunction","whichTypedArray","isTypedArray","uncurryThis","BigIntSupported","SymbolSupported","ObjectToString","numberValue","stringValue","booleanValue","bigIntValue","symbolValue","checkBoxedPrimitive","prototypeValueOf","isMapToString","isSetToString","isWeakMapToString","isWeakSetToString","isArrayBufferToString","working","isDataViewToString","isDataView","isPromise","isUint8ClampedArray","isUint16Array","isUint32Array","isInt8Array","isInt16Array","isInt32Array","isFloat32Array","isFloat64Array","isBigInt64Array","isBigUint64Array","WeakMap","isWeakMap","WeakSet","isWeakSet","SharedArrayBufferCopy","isSharedArrayBufferToString","isSharedArrayBuffer","isNumberObject","isStringObject","isBooleanObject","isBigIntObject","isSymbolObject","isAsyncFunction","isMapIterator","isSetIterator","isGeneratorObject","isWebAssemblyCompiledModule","isBoxedPrimitive","isAnyArrayBuffer","hasToStringTag","$toString","callBound","isStandardArguments","isLegacyArguments","callee","supportsStandardArguments","hasSymbols","symObj","syms","descriptor","GetIntrinsic","callBind","$indexOf","allowMissing","intrinsic","$SyntaxError","$Function","$TypeError","getEvalledConstructor","expressionSyntax","$gOPD","throwTypeError","ThrowTypeError","calleeThrows","gOPDthrows","getProto","needsEval","TypedArray","INTRINSICS","AggregateError","Atomics","decodeURI","encodeURI","EvalError","FinalizationRegistry","Proxy","ReferenceError","URIError","WeakRef","doEval1","doEval","LEGACY_ALIASES","hasOwn","$concat","$spliceApply","$replace","$strSlice","rePropName","reEscapeChar","stringToPath","quote","subString","getBaseIntrinsic","alias","intrinsicName","intrinsicBaseName","intrinsicRealName","skipFurtherCaching","isOwn","origSymbol","hasSymbolSham","ERROR_MESSAGE","toStr","funcType","bound","binder","boundLength","boundArgs","Empty","$apply","$call","$reflectApply","$defineProperty","$max","originalFunction","applyBind","GeneratorFunction","fnToStr","isFnRegex","generatorFunc","getGeneratorFunc","availableTypedArrays","typedArrays","$slice","toStrTags","gOPD","typedArray","superProto","tryTypedArrays","foundName","possibleNames","anyTrue","AbstractLevelDOWN","DeferredIterator","DeferredChainedBatch","deferrables","optionalDeferrables","kInnerDb","kOperations","kPromise","method1","implement","_open","onopen","setDb","_close","_isOperational","AbstractIterator","AbstractChainedBatch","rangeOptions","manifest","cleanRangeOptions","isRangeOption","_serializeKey","oldStatus","createIfMissing","errorIfExists","_checkKey","asBuffer","serialized","_getMany","_checkValue","_serializeValue","_put","_del","_chainedBatch","valueErr","_batch","_clear","valueAsBuffer","emptyOptions","_setupIteratorOptions","maybeObject","manifests","bufferKeys","snapshots","permanence","keyIterator","valueIterator","iteratorNextv","iteratorAll","idempotentOpen","passiveOpen","encodings","queueTick","fromPromise","queueMicrotask","_nexting","_seek","_end","kv","_operations","_written","_checkWritten","_write","kOptions","kIterator","Readable","ReadStream","objectMode","_read","destroyed","_destroy","Stream","Writable","Duplex","Transform","PassThrough","finished","pipeline","ReadableState","EElistenerCount","OurUint8Array","_uint8ArrayToBuffer","_isUint8Array","debugUtil","StringDecoder","createReadableStreamAsyncIterator","destroyImpl","_require","getHighWaterMark","_require$codes","ERR_INVALID_ARG_TYPE","ERR_STREAM_PUSH_AFTER_EOF","ERR_METHOD_NOT_IMPLEMENTED","ERR_STREAM_UNSHIFT_AFTER_END_EVENT","errorOrDestroy","kProxyEvents","readableObjectMode","pipes","pipesCount","flowing","endEmitted","reading","needReadable","emittedReadable","readableListening","resumeScheduled","paused","emitClose","autoDestroy","defaultEncoding","awaitDrain","readingMore","readable","readableAddChunk","addToFront","skipChunkCheck","onEofChunk","chunkInvalid","addChunk","maybeReadMore","emitReadable","_undestroy","undestroy","setEncoding","MAX_HWM","computeNewHighWaterMark","howMuchToRead","emitReadable_","flow","maybeReadMore_","pipeOnDrain","updateReadableListening","resume","nReadingNextTick","resume_","fromList","endReadable","endReadableNT","wState","_writableState","xs","nOrig","doRead","pipeOpts","endFn","stdout","stderr","onend","unpipe","onunpipe","unpipeInfo","hasUnpiped","onclose","onfinish","ondrain","ondata","cleanedUp","needDrain","dests","_fromList","enumerableOnly","_defineProperty","_defineProperties","Constructor","_classCallCheck","protoProps","staticProps","hasStrings","_getString","_getBuffer","nb","_objectSpread","emitErrorAndCloseNT","emitErrorNT","emitCloseNT","readableDestroyed","writableDestroyed","errorEmitted","ending","finalCalled","prefinished","rState","ERR_INVALID_OPT_VALUE","duplexKey","highWaterMarkFrom","createErrorType","NodeError1","_Base","subClass","superClass","NodeError","arg1","arg2","arg3","getMessage","oneOf","determiner","this_len","objectKeys","keys1","allowHalfOpen","onEndNT","getBuffer","CorkedRequest","onCorkedFinish","WritableState","internalUtil","realHasInstance","ERR_MULTIPLE_CALLBACK","ERR_STREAM_CANNOT_PIPE","ERR_STREAM_DESTROYED","ERR_STREAM_NULL_VALUES","ERR_STREAM_WRITE_AFTER_END","ERR_UNKNOWN_ENCODING","nop","writableObjectMode","noDecode","decodeStrings","writing","corked","bufferProcessing","onwrite","writecb","writelen","bufferedRequest","lastBufferedRequest","pendingcb","bufferedRequestCount","corkedRequestsFree","_writev","final","_final","writeAfterEnd","validChunk","decodeChunk","writeOrBuffer","isBuf","newChunk","doWrite","onwriteError","finishMaybe","onwriteStateUpdate","needFinish","clearBuffer","afterWrite","onwriteDrain","holder","allBuffers","callFinal","prefinish","endWritable","corkReq","hasInstance","cork","uncork","setDefaultEncoding","nenc","retried","_normalizeEncoding","normalizeEncoding","utf16Text","utf16End","fillLast","utf8FillLast","base64Text","base64End","simpleWrite","simpleEnd","lastNeed","lastTotal","utf8CheckByte","utf8CheckExtraBytes","utf8CheckIncomplete","copyProps","SafeBuffer","_Object$setPrototypeO","kLastResolve","kLastReject","kError","kEnded","kLastPromise","kHandlePromise","kStream","createIterResult","readAndResolve","onReadable","AsyncIteratorPrototype","ReadableStreamAsyncIteratorPrototype","lastPromise","wrapForNext","_this2","_Object$create","ERR_STREAM_PREMATURE_CLOSE","eos","called","_len","onlegacyfinish","writableEnded","readableEnded","onrequest","setHeader","isRequest","ERR_TRANSFORM_ALREADY_TRANSFORMING","ERR_TRANSFORM_WITH_LENGTH_0","afterTransform","_transformState","transforming","writechunk","rs","needTransform","writeencoding","_transform","_flush","ERR_MISSING_ARGS","destroyer","popCallback","destroys","createError","Proto","Err","cause","LevelUPError","EncodingError","rangeMethods","encodeKey","keyEncoding","Iterator","encodeLtgt","datum","encodeValue","decodeValue","encodeBatch","_encoding","_keyEncoding","batchOpts","_valueEncoding","ltgt","createStreamDecoder","none","bufferEncodings","support","createKeyRange","DEFAULT_PREFIX","indexedDB","onupgradeneeded","objectStoreNames","contains","createObjectStore","objectStore","await","keyRange","upgrade","batchOptions","each","deleteDatabase","isErrored","isSync","result1","_limit","_count","_callback","_completed","_aborted","_error","_transaction","_values","_keyAsBuffer","_valueAsBuffer","createIterator","openCursor","onItem","onComplete","continue","maybeNext","lower","upper","upperBound","lowerOpen","lowerBoundExclusive","upperOpen","upperBoundExclusive","IDBKeyRange","isDef","hasKey","lowerBoundKey","lowerBoundInclusive","upperBoundInclusive","upperBoundKey","startInclusive","endInclusive","toLtgt","_range","lb","ub","ta2str","ta","ta2buf","ab2str","ab","str2bin","openKeyCursor","direction","convertPrefix","firstChar","BaseBlockstore","convertQuery","cids1","libp2pPubsubRouters","DelegatedPeerRouter","DelegatedContentRouter","ipfsHttpClient","Libp2p","DelegatedPeerRouter__default","DelegatedContentRouter__default","bootstrap__default","Libp2p__default","libp2pOptions","libp2pDefaults","modules","router","routers","getPubsubRouter","contentRouting","peerRouting","peerDiscovery","mdns","relay","hop","active","clientMode","kBucketSize","nat","listen","announce","noAnnounce","connectionManager","maxConnections","minConnections","libp2pConfig","delegateHosts","delegateString","delegateAddr","delegateApiOptions","delegateHttpClient","getLibp2pOptions","gossipsub","__createBinding","__setModuleDefault","__importStar","__awaiter","thisArg","_arguments","generator","fulfilled","rejected","pubsub_1","message_cache_1","rpc_1","heartbeat_1","get_gossip_peers_1","utils_1","score_1","tracer_1","TimeCache","Envelope","Gossipsub","GossipsubIDv11","GossipsubIDv10","gossipIncoming","fallbackToFloodsub","floodPublish","doPX","directPeers","GossipsubD","Dlo","GossipsubDlo","Dhi","GossipsubDhi","Dscore","GossipsubDscore","Dout","GossipsubDout","Dlazy","GossipsubDlazy","heartbeatInterval","GossipsubHeartbeatInterval","fanoutTTL","GossipsubFanoutTTL","mcacheLength","GossipsubHistoryLength","mcacheGossip","GossipsubHistoryGossip","seenTTL","GossipsubSeenTTL","scoreParams","createPeerScoreParams","scoreThresholds","createPeerScoreThresholds","FloodsubID","debugName","addrs","seenCache","mesh","lastpub","gossip","control","peerhave","iasked","backoff","outbound","messageCache","MessageCache","getMsgId","heartbeat","Heartbeat","heartbeatTicks","gossipTracer","IWantTracer","_libp2p","score","PeerScore","_decodeRpc","_encodeRpc","rpc2","_addPeer","addPeer","registry","rvalue","_removePeer","peerStreams","peers1","removePeer","_processRpc","id9","peerStreams1","rpc1","_super","_processRpcControlMessage","controlMsg","iwant","ihave","_handleIHave","_handleIWant","prune","graft","_handleGraft","_handlePrune","outRpc","createGossipRpc","_sendRpc","_processRpcMessage","msgID","msgIdStr","messageIdToString","duplicateMessage","validateMessage","_acceptFrom","graylistThreshold","rejectMessage","gossipThreshold","GossipsubMaxIHaveMessages","GossipsubMaxIHaveLength","topicID","messageIDs","iask","iwantList","addPromise","id4","getForPeer","GossipsubGossipRetransmission","normalizeOutRpcMessage","id5","_now","peersInMesh","addPenalty","floodCutoff","GossipsubGraftFloodThreshold","GossipsubPruneBackoff","_addBackoff","_makePrune","id6","_doAddBackoff","acceptPXThreshold","_pxConnect","id7","topic2","id8","topic1","_applyIwantPenalties","getBrokenPromises","_clearBackoff","GossipsubPruneBackoffTicks","_directConnect","GossipsubDirectConnectTicks","toconnect","isWritable","_connect","peers2","GossipsubPrunePeers","pi","peerID","signedPeerRecord","envelope","openAndCertify","eid","consumePeerRecord","_directPeerInitial","GossipsubDirectConnectInitialDelay","id10","dialProtocol","topic6","topic3","leave","topic4","started","fanoutPeers","getGossipPeers","_sendGraft","topic5","meshPeers","_sendPrune","_publish","receivedFrom","deliverMessage","tosend","peersInTopic","topics","publishThreshold","id16","id11","topic7","id12","ctrl","_piggybackControl","_piggybackGossip","id13","outRpc1","tograft","toprune","id14","outRpc2","ihave1","_sendGraftPrune","noPX","pruning","id15","topics1","_emitGossip","topic8","exclude","getGossipIDs","peersToGossip","topicPeers","hasGossipProtocol","factor","GossipsubGossipFactor","peerMessageIDs","_pushGossip","peer1","controlIHaveMsgs","id17","topic9","px","xid","getRawEnvelope","multicodec","MulticodecTopology","PeerStreams","SignaturePolicy","signMessage","verifySignature","PubsubBaseProtocol","globalSignaturePolicy","StrictSign","canRelayMessage","emitSelf","messageProcessingConcurrency","ensureArray","registrar","ERR_INVALID_SIGNATURE_POLICY","topicValidators","_registrarId","_onIncomingStream","_onPeerConnected","_onPeerDisconnected","topology","onConnect","onDisconnect","register","unregister","connection","remotePeer","idB58Str","inboundStream","attachInboundStream","_processMessages","conn","newStream","attachOutboundStream","_sendSubscriptions","peerId3","stream1","rpcBytes","rpcMsg","idB58Str1","msgs","subOpt","_processRpcSubOpt","normalizeInRpcMessage","topicSet","_emitMessage","signaturePolicy","msgId","seqno","StrictNoSign","noSignMsgId","ERR_UNHANDLED_SIGNATURE_POLICY","ERR_UNEXPECTED_FROM","ERR_UNEXPECTED_SIGNATURE","ERR_UNEXPECTED_KEY","ERR_UNEXPECTED_SEQNO","ERR_MISSING_SIGNATURE","ERR_MISSING_SEQNO","ERR_INVALID_SIGNATURE","validatorFn","_buildMessage","randomSeqno","getSubscribers","msgObject","outMsg","Topology","multicodecTopologySymbol","_registrar","_onProtocolChange","_onPeerConnect","_updatePeers","peerDataIterable","getConnection","_onConnect","hadPeer","hasProtocol","_onDisconnect","peerData","topologySymbol","disconnect","SubOpts","$oneOfFields","oneofs","_subscribe","_topicID","_from","_seqno","_signature","lp","abortable","_rawOutboundStream","_rawInboundStream","_inboundAbortController","outboundStream","isReadable","returnOnAbort","_prevStream","shouldEmit","varintEncode","varintDecode","int32BEEncode","int32BEDecode","minPoolSize","encodeLength","lengthEncoder","poolOffset","MIN_POOL_SIZE","DEFAULT_POOL_SIZE","Varint","MAX_DATA_LENGTH","ReadModes","ReadHandlers","ReadModes_LENGTH","dataLength","lengthDecoder","maxLengthLength","maxDataLength","onLength","ReadModes_DATA","nextChunk","fromReader","varByteSource","MAX_LENGTH_LENGTH","getIterator","toAbortableSource","toMultiAbortableSource","nextAbortHandler","abortHandler","signal2","abortMessage","abortCode","signal3","aborter","isKnownAborter","toAbortableSink","toMultiAbortableSink","toMultiAbortableDuplex","anyMatch","bHas","maybeArray","SignPrefix","messagePublicKey","keyPeerId","history","msgIdFn","peertx","msgID1","msgIDs","__exportStar","constants_1","ERR_TOPIC_VALIDATOR_IGNORE","ERR_TOPIC_VALIDATOR_REJECT","TimeCacheDuration","GossipsubIWantFollowupTime","GossipsubOpportunisticGraftPeers","GossipsubOpportunisticGraftTicks","GossipsubConnectionTimeout","GossipsubMaxPendingConnections","GossipsubConnectors","GossipsubHeartbeatInitialDelay","to_string_1","$oneOfFields1","ControlMessage","_control","ControlIHave","ControlIWant","ControlGraft","ControlPrune","PeerInfo","_backoff","_peerID","_signedPeerRecord","_heartbeatTimer","_heartbeat","scores","getScore","prunePeer","graftPeer","ineed","peersArray","rotate","peersList","medianIndex","medianScore","opportunisticGraftThreshold","lastpb","validateTopicScoreParams","validatePeerScoreParams","createTopicScoreParams","defaultTopicScoreParams","defaultPeerScoreParams","topicWeight","ERR_INVALID_PEER_SCORE_PARAMS","timeInMeshQuantum","timeInMeshWeight","timeInMeshCap","firstMessageDeliveriesWeight","firstMessageDeliveriesDecay","firstMessageDeliveriesCap","meshMessageDeliveriesWeight","meshMessageDeliveriesDecay","meshMessageDeliveriesCap","meshMessageDeliveriesThreshold","meshMessageDeliveriesWindow","meshMessageDeliveriesActivation","meshFailurePenaltyWeight","meshFailurePenaltyDecay","invalidMessageDeliveriesWeight","invalidMessageDeliveriesDecay","topicScoreCap","appSpecificScore","appSpecificWeight","IPColocationFactorWeight","IPColocationFactorThreshold","IPColocationFactorWhitelist","behaviourPenaltyWeight","behaviourPenaltyDecay","decayInterval","decayToZero","retainScore","topicScoreParams","ERR_INVALID_PEER_SCORE_THRESHOLDS","validatePeerScoreThresholds","defaultPeerScoreThresholds","__importDefault","peer_score_params_1","peer_stats_1","compute_score_1","message_deliveries_1","peer_id_1","pubsubErrors","_connectionManager","peerStats","peerIPs","deliveryRecords","MessageDeliveries","_backgroundInterval","_refreshScores","_updateIPs","pstats","connected","tstats","tparams","firstMessageDeliveries","meshMessageDeliveries","meshFailurePenalty","invalidMessageDeliveries","inMesh","meshTime","graftTime","meshMessageDeliveriesActive","behaviourPenalty","_removeIPs","ips","computeScore","penalty","createPeerStats","_getIPs","_setIPs","deficit","ensureTopicStats","ensureRecord","_markFirstMessageDelivery","drec","DeliveryRecordStatus","unknown","valid","validated","_markDuplicateMessageDelivery","firstSeen","_markInvalidMessageDelivery","invalid","ignored","cap","validatedTime","remoteAddr","newIPs1","oldIPs","addNewIPs","xip","removeOldIPs","ip1","newIPs","createTopicStats","ps","topicStats","topicParams","topicScore","p5","peersInIP","numPeersInIP","surplus","p7","denque_1","DeliveryRecordStatus1","peekFront","Denque","_head","_tail","_capacity","capacity","_capacityMask","_list","_fromArray","peekAt","peekBack","_growArray","_shrinkArray","removeOne","del_count","arg_len","arguments_index","leng","_copyArray","fullCopy","newArray","msgIds","throttle","validity1","sweep","getTimeElapsed","FUNC_ERROR_TEXT","NAN","symbolTag","reTrim","reIsBadHex","reIsBinary","reIsOctal","freeParseInt","freeGlobal","freeSelf","objectProto","nativeMax","nativeMin","debounce","wait","lastArgs","lastThis","maxWait","timerId","lastCallTime","lastInvokeTime","leading","maxing","trailing","invokeFunc","leadingEdge","timerExpired","shouldInvoke","timeSinceLastCall","trailingEdge","remainingWait","debounced","isInvoking","isObjectLike","uint8arraysConcat","uint8arraysFromString","uint8arraysEquals","Protobuf","payloadType","payloadType1","payload","payload1","signature1","_marshal","domain1","signData","formatSignaturePayload","domainUint8Array","domainLength","payloadTypeLength","payloadLength","envelopeData","seal","ERR_SIGNATURE_NOT_VALID","messages","NOT_STARTED_YET","DHT_DISABLED","CONN_ENCRYPTION_REQUIRED","PUBSUB_NOT_STARTED","DHT_NOT_STARTED","ERR_INVALID_PROTOCOLS_FOR_STREAM","ERR_CONNECTION_ENDED","ERR_CONNECTION_FAILED","ERR_NODE_NOT_STARTED","ERR_ALREADY_ABORTED","ERR_TOO_MANY_ADDRESSES","ERR_NO_VALID_ADDRESSES","ERR_RELAYED_DIAL","ERR_DIALED_SELF","ERR_DISCOVERED_SELF","ERR_DUPLICATE_TRANSPORT","ERR_ENCRYPTION_FAILED","ERR_HOP_REQUEST_FAILED","ERR_INVALID_KEY","ERR_INVALID_MESSAGE","ERR_INVALID_PARAMETERS","ERR_INVALID_PEER","ERR_MUXER_UNAVAILABLE","ERR_TIMEOUT","ERR_TRANSPORT_UNAVAILABLE","ERR_TRANSPORT_DIAL_FAILED","ERR_UNSUPPORTED_PROTOCOL","ERR_INVALID_MULTIADDR","client","_client","_httpQueue","getEndpointConfig","findPeer","keyStr","onStart","onFinish","responses","_httpQueueRefs","providers","findProvs","numProviders","provide","index$e","index$f","index$g","index$h","urlSource_js","urlSource_js__default","id$1","multibases$1","multihashes$1","createBitswap","createBlock","createBootstrap","createCommands","createDag","createDiag","createGetEndpointConfig","createLog","createMount","createName","createObject","createPin","createStats","createSwarm","LOAD_BASE","_basesByName","_basesByPrefix","_loadBase","addBase","removeBase","nameOrPrefix","listBases","LOAD_CODEC","_codecsByName","_codecsByCode","_loadCodec","addCodec","removeCodec","codec1","listCodecs","LOAD_HASHER","_hashersByName","_hashersByCode","_loadHasher","addHasher","removeHasher","hasher1","listHashers","toUrlSearchParams","Keys","core","Client","toUrlString","getAgent","getAgent__default","DEFAULT_PROTOCOL","DEFAULT_HOST","DEFAULT_PORT","errorHandler","KEBAB_REGEX","kebabCase","agent","apiPath","Agent","keepAlive","maxSockets","normalizeOptions","multiAddrToUri__default","modeToString","mtimeNsecs","urlSearchParams","ProvideBufLen","Wantlist","BlocksReceived","DataReceived","BlocksSent","DataSent","DupBlksReceived","DupDataReceived","toCoreInterface","multipartRequest","abortSignal","normaliseInput_browser","formData","FormData","fileSuffix","fieldName","normaliseContent_browser","itToBlob","Size","createGetAll","createSet","createReplace","createProfiles","createApply","OldCfg","NewCfg","objectToCamel","caps","camelObj","encodeParam","Cid","PinErrorMsg","inputEnc","RemPath","createFindPeer","createFindProvs","createProvide","createQuery","responseTypes","FinalPeer","Responses","ID","Addrs","AddingPeer","DialingPeer","PeerResponse","Provider","QueryError","SendingQuery","Extra","cidArr","createCmds","createNet","createSys","sourceArr","objectToCamelWithMetadata","Entries","toIterable__default","WithLocality","streamChannels","createLevel","createTail","subsystem","Strings","createPatch","dataEncoding","dagPut","dLink","createRemote","Pins","createService","encodeAddParams","decodePin","encodeService","Status","origins","encodeQuery","endpoint","encodeEndpoint","decodeStat","Pinning","Pinned","Queued","Failed","PinCount","queued","pinning","failed","decodeRemoteService","ApiEndpoint","Stat","RemoteServices","subscriptionTracker","subscriptionTracker$1","SubscriptionTracker","createPeers","createSubscribe","createUnsubscribe","isAbortError","subsTracker","fail","ffWorkaround","onMessage","onError","readMessages","_subs","topicSubs","handler1","unsubs","argsArr","res1","NumObjects","RepoSize","RepoPath","Version","StorageMax","TotalIn","TotalOut","RateIn","RateOut","connect","localAddrs","createAddrs","createConnect","createDisconnect","createLocalAddrs","Addr","Peer","muxer","Muxer","latency","Latency","Streams","Direction","progressFn","createProgressHandler","createOnUploadProgress","loaded","mapLink","Mode","Mtime","MtimeNsecs","Objects","readURLContent","WS","Multiplex","libp2pNoise","KadDHT","GossipSub","WS__default","WebRTCStar__default","Multiplex__default","KadDHT__default","GossipSub__default","dialer","maxParallelDials","maxDialsPerPeer","dialTimeout","streamMuxer","connEncryption","NOISE","autoDial","randomWalk","persistence","pDefer","createListener","toConnection","_upgrader","_filter","socket","maConn","upgradeOutbound","ma1","cOpts","errorPromise","errfn","rawSocket","dnsWss","WebSocket","wsurl","websocket","remoteAddress","binaryType","EventIterator","connError","readyState","cleanUp","cont","onOpen","event_iterator_1","evOptions","EventQueue","pullQueue","pushQueue","eventHandlers","isStopped","resolution","placeholder","highWater","error1","rejection","removeCallback","lowWaterMark","lowWater","closeOnEnd","wasClean","cleanup","handleOpen","handleErr","CLOSE_TIMEOUT","toMultiaddr","localAddr","localAddress","localPort","remotePort","timeline","CODE_P2P","CODE_CIRCUIT","CODE_TCP","CODE_WS","CODE_WSS","Address4","Address6","ERR_INVALID_IP_PARAMETER","ERR_INVALID_PORT_PARAMETER","ERR_INVALID_IP","is4","to4","correctForm","_ipv4","_ipv6","_addressError","parcelHelpers","_common","_constants","_jsbn","_sprintfJs","groups","GROUPS","parsedAddress","parsedSubnet","subnet","subnetMask","isCorrect","BITS","isInSubnet","RE_SUBNET_STRING","AddressError","addressMinusSuffix","address1","address2","RE_ADDRESS","padded","arpaFormAddress","sprintf","toGroup6","bigInteger","_startAddress","startAddress","fromBigInteger","startAddressExclusive","adjust","_endAddress","endAddress","endAddressExclusive","fromInteger","getBitsBase2","binaryZeroPad","reverseForm","reversed","omitSuffix","isMulticast","groupForV6","segments","defaultBits","parseMessage","inBrowser","rng_state","rng_pool","rng_pptr","rng_seed_time","rng_psize","square","ua","appVersion","z1","rng_get_byte","Arcfour","SecureRandom","ba","not_string","not_bool","not_type","not_primitive","numeric_arg","not_json","modulo","key_access","index_access","sprintf_format","sprintf_parse","vsprintf","fmt","parse_tree","pad_character","pad_length","is_positive","tree_length","param_no","precision","toExponential","toPrecision","pad_char","sprintf_cache","_fmt","arg_names","field_list","replacement_field","field_match","_constants1","_helpers","_regularExpressions","condition","spanLeadingZeroes4","paddedHex","octet","unsignByte","optionalGroups","zone","RE_ZONE_STRING","RE_URL_WITH_PORT","RE_URL","address4","mask6","insertIndex","microsoftTranscription","possibleSubnets","subnetSize","subnetPowers","addCommas","getScope","scope","SCOPES","getBits","getType","TYPES","start1","end1","getBitsBase16","start2","end2","getBitsPastSubnet","characters","canonicalForm","zeroCounter","zeroLengths","correct","parse4in6","address3","parsedAddress4","badCharacters","RE_BAD_CHARACTERS","badAddress","RE_BAD_ADDRESS","halves","elidedGroups","elisionBegin","elisionEnd","decimal","to4in6","infix","inspectTeredo","udpPort","server4","client4","flagsBase2","coneNat","reserved","groupIndividual","universalLocal","microsoft","inspect6to4","gateway","to6to4","addr6to4","toUnsignedByteArray","fromUnsignedByteArray","BYTE_MAX","isCanonical","isLinkLocal","isTeredo","is6to4","isLoopback","optionalPort","formFunction","simpleGroup","classes","regularExpressionString","substringSearch","address6","simpleRegularExpression","possibleElisions","regularExpression","substringSearch1","spanAllZeroes","spanAll","spanLeadingZeroes","spanLeadingZeroesSimple","addressString","groupPossibilities","padGroup","ADDRESS_BOUNDARY","possibilities","zeroIndexes","zeroIndex","elision","moreLeft","moreRight","cancelablePromise","customTimers","testMa","dnsWsOrWss","SimplePeer","supportsWebRTCDataChannels","webrtcSupport","cleanMultiaddr","cleanUrlSIO","sioOptions","transports","wrtc","sigReferences","discovery","_isStarted","_peerDiscovered","ma2","rawConn","spOptions","initiator","intentId","sio","sioClient","channel","onTimeout","srcMultiaddr","signallingAddr","dstMultiaddr","offer","answer","maStr","getBrowserRTC","randombytes","MAX_BUFFERED_AMOUNT","filterTrickle","sdp","_debug","channelName","channelConfig","negotiated","offerOptions","answerOptions","sdpTransform","allowHalfTrickle","iceCompleteTimeout","_connected","remoteFamily","localFamily","_wrtc","_pcReady","_channelReady","_iceComplete","_iceCompleteTimer","_channel","_pendingCandidates","_isNegotiating","_batchedNegotiation","_queuedNegotiation","_sendersAwaitingStable","_senderMap","_firstStable","_closingInterval","_remoteTracks","_remoteStreams","_chunk","_cb","_pc","RTCPeerConnection","_isReactNativeWebrtc","_peerConnectionId","oniceconnectionstatechange","_onIceStateChange","onicegatheringstatechange","onconnectionstatechange","_onConnectionStateChange","onsignalingstatechange","_onSignalingStateChange","onicecandidate","_onIceCandidate","_setupData","createDataChannel","ondatachannel","addStream","ontrack","_onTrack","_needsNegotiation","_onFinishBound","_onFinish","bufferSize","bufferedAmount","renegotiate","transceiverRequest","addTransceiver","kind","remoteDescription","_addIceCandidate","setRemoteDescription","RTCSessionDescription","_createAnswer","iceCandidateObj","RTCIceCandidate","addIceCandidate","getTracks","track","addTrack","track2","stream2","submap","sender","replaceTrack","oldTrack","newTrack","stream3","removeTrack","track1","stream4","removeStream","stream5","negotiate","_createOffer","cb3","onmessage","bufferedAmountLowThreshold","_onChannelMessage","onbufferedamountlow","_onChannelBufferedAmountLow","_onChannelOpen","_onChannelClose","isClosing","chunk1","cb1","destroySoon","_startIceCompleteTimeout","createOffer","sendOffer","localDescription","setLocalDescription","_requestMissingTransceivers","getTransceivers","transceiver","createAnswer","sendAnswer","connectionState","iceConnectionState","iceGatheringState","_maybeReady","getStats","cb2","flattenValues","report","reports","_connecting","findCandidatePair","remoteCandidates","localCandidates","candidatePairs","foundSelectedCandidatePair","setSelectedCandidatePair","selectedCandidatePair","localCandidateId","ipAddress","portNumber","googLocalAddress","remoteCandidateId","googRemoteAddress","selectedCandidatePairId","googActiveConnection","selected","unref","signalingState","sdpMLineIndex","sdpMid","event2","event3","eventStream","remoteStream","WEBRTC_SUPPORT","iceServers","urls","sdpSemantics","mozRTCPeerConnection","webkitRTCPeerConnection","mozRTCSessionDescription","webkitRTCSessionDescription","mozRTCIceCandidate","webkitRTCIceCandidate","MAX_UINT32","oldBrowser","supportsFileReader","supportsWebRTC","mediaDevices","listeningAddr","signallingUrl","__connections","__spChannels","__pendingIntents","localPeer","pendings","pendingOffer","upgradeInbound","untrackConn","trackConn","getAddrs","_socketIoParser","_managerJs","Manager","_urlJs","_socketJs","sameNamespace","forceNew","multiplex","queryKey","_parseuri","loc","_parseuriDefault","authority","ipv6uri","pathNames","regx","$0","$2","_engineIoClient","_onJs","_backo2","_componentEmitter","Emitter","nsps","reconnection","reconnectionAttempts","reconnectionDelay","reconnectionDelayMax","randomizationFactor","_backo2Default","jitter","_readyState","_parser","parser","_autoConnect","autoConnect","_reconnection","_reconnectionAttempts","_reconnectionDelay","setMin","v3","_randomizationFactor","setJitter","_reconnectionDelayMax","setMax","v5","maybeReconnectOnOpen","_reconnecting","attempts","reconnect","engine","Socket","skipReconnect","openSubDestroy","errorSub","emitReserved","setTimeoutFn","autoUnref","fn1","onping","ondecoded","packet","nsp","_packet","packet1","encodedPackets","subDestroy","duration","onreconnect","attempt","_transportJs","_utilJs","_parseqs","_engineIoParser","secure","writeBuffer","prevBufferLen","withCredentials","timestampParam","rememberUpgrade","rejectUnauthorized","perMessageDeflate","transportOptions","closeOnBeforeunload","_parseqsDefault","upgrades","pingInterval","pingTimeout","pingTimeoutTimer","offlineEventListener","onClose","createTransport","sid","priorWebsocketSuccess","setTransport","onDrain","onPacket","probe","onTransportOpen","upgrading","freezeTransport","onTransportClose","onupgrade","onHandshake","resetPingTimeout","sendPacket","filterUpgrades","clearTimeoutFn","fn2","cleanupAndClose","waitForUpgrade","filteredUpgrades","_pollingXhrJs","polling","XHR","_xmlhttprequestJs","_globalThisJs","_pollingJs","hasXHR2","_xmlhttprequestJsDefault","xdomain","Polling","isSSL","xd","forceBase64","supportsBinary","doPoll","pollXhr","opts2","pick","xscheme","xhr","extraHeaders","setDisableHeaderCheck","requestTimeout","onreadystatechange","onLoad","requestsCount","onSuccess","fromError","responseText","attachEvent","unloadHandler","terminationEvent","_globalThisJsDefault","_hasCors","_hasCorsDefault","installTimerFunctions","NATIVE_SET_TIMEOUT","NATIVE_CLEAR_TIMEOUT","useNativeTimers","mixin","_callbacks","hasListeners","_yeast","Transport","doOpen","onPause","doClose","packets","timestampRequests","_yeastDefault","encodedQuery","decodePacket","encodePayload","decodePayload","_encodePacketJs","_decodePacketJs","SEPARATOR","encodedPacket","encodedPayload","decodedPacket","_decodePacketJsDefault","_commonsJs","withNativeBlob","withNativeArrayBuffer","encodeBlobAsBase64","fileReader","readAsDataURL","PACKET_TYPES","PACKET_TYPES_REVERSE","ERROR_PACKET","_base64Arraybuffer","decodeBase64Packet","mapBinary","chars","arraybuffer","encoded1","encoded2","encoded3","encoded4","bufferLength","yeast","qry","_websocketConstructorJs","usingBrowserWebSocket","defaultBinaryType","addEventListeners","_socket","lastPacket","MozWebSocket","RESERVED_EVENTS","connect_error","disconnecting","disconnected","receiveBuffer","sendBuffer","ids","acks","subEvents","onpacket","args2","args1","PacketType","EVENT","ack","_registerAckCallback","isTransportWritable","volatile","packet4","CONNECT","onconnect","BINARY_EVENT","onevent","ACK","BINARY_ACK","onack","DISCONNECT","ondisconnect","CONNECT_ERROR","packet2","emitEvent","args3","_anyListeners","sent","packet3","emitBuffered","onAny","prependAny","listener1","offAny","listener2","listenersAny","PacketType1","_binaryJs","_isBinaryJs","hasBinary","encodeAsString","encodeAsBinary","attachments","deconstruction","deconstructPacket","decodeString","reconstructor","BinaryReconstructor","takeBinaryData","str1","tryParse","isPayloadValid","finishedReconstruction","reconPack","binData","reconstructPacket","packetData","_deconstructPacket","_placeholder","_reconstructPacket","withNativeFile","Backoff","deviation","toIterable","toWebrtcMultiaddr","maybeEndSource","errCb","closeCb","closeHandler","finishCb","finishHandler","drainCb","drainHandler","toDuplex","sinkError","toSink","toSource","maStrSplit","tcpProto","wsProto","tcpPort","isName","tuppleIPFS","tupple","Coder","restrictSize","MessageTypes","MessageTypeNames","createStream","Mplex","onStream","_streamId","_streams","initiators","receivers","_createSink","_createSource","onStreamEnd","_newStream","_newReceiverStream","maxMsgSize","_handleIncoming","type1","NEW_STREAM","MESSAGE_INITIATOR","MESSAGE_RECEIVER","CLOSE_INITIATOR","CLOSE_RECEIVER","RESET_INITIATOR","RESET_RECEIVER","POOL_SIZE","_pool","_poolOffset","_buffer","_bufferProxy","_headerInfo","_decodeHeader","MAX_MSG_SIZE","checkSize","InitiatorMessageTypes","MESSAGE","CLOSE","RESET","ReceiverMessageTypes","ERR_MPLEX_STREAM_RESET","resetController","Types","externalId","endErr","sourceEnded","sinkEnded","onSinkEnd","noise_1","Noise","x25519","buffer_1","it_pb_rpc_1","duplex_1","it_buffer_1","it_pipe_1","it_length_prefixed_1","handshake_xx_1","handshake_ik_1","handshake_xx_fallback_1","encoder_1","crypto_1","keycache_1","logger_1","staticNoiseKey","earlyData","prologue","useNoisePipes","staticKeys","secretKey","generateKeypair","wrappedConnection","uint16BEEncode","uint16BEDecode","NOISE_MSG_MAX_LENGTH_BYTES","handshake","performHandshake","isInitiator","createSecureConnection","remoteEarlyData","localPeer1","connection1","remotePeer1","getPayload","tryIK","KeyCache","performXXHandshake","ikHandshake","IKHandshake","performIKHandshake","ephemeralKeys","getLocalEphemeralKeys","performXXFallbackHandshake","initialMsg","XXFallbackHandshake","propose","exchange","logger","params2","XXHandshake","getRemoteStaticKey","stage0","stage1","connection2","handshake1","user","encryptStream","decryptStream","random_1","wipe_1","PUBLIC_KEY_LENGTH","SECRET_KEY_LENGTH","SHARED_KEY_LENGTH","_9","_121665","scalarMult","x32","x16","scalarMultBase","wipe","sharedKey","mySecretKey","theirPublicKey","rejectZero","system_1","binary_1","defaultRandomSource","SystemRandomSource","randomUint32","ALPHANUMERIC","randomString","charset","charsLen","maxByte","randomByte","randomStringForEntropy","browser_1","node_1","SystemRandomSource1","isAvailable","_source","BrowserRandomSource","NodeRandomSource","BrowserRandomSource1","isInstantiated","browserCrypto","NodeRandomSource1","nodeCrypto","int_1","writeUint64BE","writeUint64LE","readInt64BE","readUint64BE","readInt64LE","readUint64LE","readFloat32BE","readFloat32LE","readFloat64BE","readFloat64LE","writeFloat32BE","writeFloat32LE","writeFloat64BE","writeFloat64LE","rotl","rotr","Shake","shake","lpReader","isDone","readLP","readPB","writeLP","writePB","sourcePromise","sinkErr","sinkPromise","Pair","onSource","toList","xx_1","staticKeypair","XX","session","initSession","logLocalStaticKeys","hs","messageBuffer","sendMessage","encode0","logLocalEphemeralKeys","receivedMessageBuffer","decode0","recvMessage","logRemoteEphemeralKey","logRemoteStaticKey","decodedPayload","getPeerIdFromPayload","verifySignedPayload","setRemoteEarlyData","encode2","decode2","logCipherState","getCS","encryptWithAd","session1","decryptWithAd","session2","encryption","cs1","cs2","abstract_handshake_1","AbstractHandshake","initializeInitiator","psk","initializeSymmetric","mixHash","initializeResponder","prologue1","rs1","psk1","writeMessageA","encryptAndHash","writeMessageB","hs1","mixKey","spk","writeMessageC","hs2","payload2","createEmptyKey","readMessageA","hs3","isValidPublicKey","decryptAndHash","readMessageB","hs4","valid1","valid2","readMessageC","hs5","prologue2","mc","ephemeral","resultingBuffer","writeMessageRegular","resultingPlaintext","resultingValid","hkdf_1","sha256_1","libp2p_crypto_1","payload_1","equals_1","NoiseHandshakePayloadProto","NoiseHandshakePayload","createHandshakePayload","libp2pPublicKey","signedPayload","payloadInit","identityKey","identitySig","signPayload","getHandshakePayload","staticPublicKey","earlyDataPayload","noiseStaticKey","publicKeyProtobuf","generatedPeerId","isValidPeerId","generatedPayload","getHkdf","ck","ikm","okmU8Array","HKDF","expand","okm","hmac_1","HKDF1","_counter","_hash","_info","HMAC","_bufpos","_fillBuffer","hash_1","constant_time_1","HMAC1","_finished","_inner","_outer","isSerializableHash","_innerKeyedState","saveState","_outerKeyedState","restoreState","cleanSavedState","savedState","subject","resultIfOne","resultIfZero","lessOrEqual","DIGEST_LENGTH","BLOCK_SIZE","SHA2561","_temp","_bufferLength","_bytesHashed","_initState","dataPos","hashBlocks","bytesHashed","bitLenHi","bitLenLo","encodeDelimited","decodeDelimited","chacha20poly1305_1","MIN_NONCE","ad","setNonce","incrementNonce","ad1","isEmptyKey","cs3","nonceToBytes","n2","ad2","plaintext1","encryptedMessage","ChaCha20Poly1305","plaintext2","n3","ad3","ciphertext1","ss1","ciphertext2","derivedU8","derived","ss2","getHash","ss3","tempK","initializeKey","protocolName","protocolNameBytes","hashProtocolName","protocolName1","ss4","tempk1","tempk2","cs4","readMessageRegular","cs5","chacha_1","poly1305_1","KEY_LENGTH","NONCE_LENGTH","TAG_LENGTH","ZEROS","ChaCha20Poly13051","associatedData","authKey","streamXOR","_authenticate","sealed","calculatedTag","tagOut","Poly1305","j0","j1","j2","j3","j4","j5","j6","j7","j8","j9","j10","j11","j12","j13","j14","j15","x0","x4","x5","x6","x7","x8","x9","x10","x11","x12","x13","x14","x15","nonceInplaceCounterLength","nc","counterLength","incrementCounter","Poly13051","_r","_leftover","_fin","_blocks","mpos","hibit","h8","h9","r0","r3","r4","r5","r6","r7","r8","r9","d0","d4","d5","d6","d7","d8","d9","mac","macpos","want","oneTimeAuth","debug_1","keyLogger","DUMP_SESSION_KEYS","NOISE_MSG_MAX_LENGTH_BYTES_WITHOUT_TAG","ik_1","errors_1","remoteStaticKey","ik","IK","receivedMsg","FailedIKError","rs2","chunkBuffer","decrypted","resetStorage","RoutingTable","contentFetching","Providers","QueryManager","protocolPrefix","forceProtocolLegacy","ALPHA","onPut","onRemove","PROTOCOL_DHT","_clientMode","disjointPaths","routingTable","_log","_queryManager","_running","nvals","bufferToKey","maxNumProviders","findProviders","shallow","getClosestPeers","getPublicKey","convertBuffer","closestPeers","_nearestPeersToQuery","closer","_isSelf","key8","rawRecord","MAX_RECORD_AGE","key9","rec","PUT_VALUE","resp","sendRequest","key10","_getValueSingle","closerPeers","_verifyRecordOnline","peer2","key11","GET_VALUE","record1","KBuck","uint8ArrayXor","GENERATED_PREFIXES","refreshInterval","_kBucketSize","_refreshInterval","numberOfNodesPerKBucket","numberOfNodesToPing","commonPrefixLengthRefreshedAt","_refreshTable","_onPing","localNodeId","convertPeerId","_refreshTimeoutId","prefixLength","_maxCommonPrefix","refreshCpls","_getTrackedCommonPrefixLengthsForRefresh","getFullYear","lastRefresh","_refreshCommonPrefixLength","_numPeersForCpl","lastCpl","cpl","force1","_generateRandomPeerId","maxCommonPrefix","dates","targetCommonPrefixLength","randomUint16","_makePeerId","localKadId","randomPrefix","targetCommonPrefixLength1","localPrefix","keyPrefix","keyBuffer","keyView","_prefixLengths","distance","leadingZeros","oldContacts","newContact","oldest","closest","closestPeer","arrayEquals","array1","array2","ensureInt8","KBucket","arbiter","contacts","dontSplit","incumbent","vectorClock","firstId","secondId","contact","bitIndex","_determineNode","_indexOf","_split","detNode","bytesDescribedByBitIndex","bitIndexWithinByte","node2","bitIndex1","node3","contact1","uint8ArrayCompare","pMap","keyForPublicKey","isPublicKeyKey","fromPublicKeyKey","decodeBase32","sortClosestPeers","xorCompare","pathSize","resultsWanted","numPaths","createPutRecord","asyncFn","mapParallel","mapper","stopOnError","isRejected","isIterableDone","resolvingCount","currentIndex","nextItem","indentString","cleanStack","_errors","includeEmptyLines","extractPathRegex","pathRegex","homeDir","homedir","pretty","pathMatches","PROVIDERS_KEY_PREFIX","PROVIDERS_LRU_CACHE_SIZE","PROVIDERS_VALIDITY","PROVIDERS_CLEANUP_INTERVAL","READ_MESSAGE_TIMEOUT","GET_MANY_RECORD_COUNT","readMessageTimeout","_rpc","isConnected","_add","msg4","connectToPeer","_writeReadMessage","to1","_writeMessage","writeReadMessage","msg3","flatMap","flatTransform","flatten","parallelFlatMap","parallelMap","parallelMerge","tap","writeToStream","curriedIterable","dataBatch","_syncBatch","resolveFunc","rejectFunc","resultQueue","fillQueue","readDeferred","fulfillReadQueue","asyncIterableIterator","valueQueue","syncBuffer","_collect","iterables","itr","_concat","_syncConcat","_consume","filterFunc","maybeItr","_map","_flatTransform","inflightCount","lastError","itrValue","asyncVal","mapAndQueue","curriedFunc","onceReadable","_fromStream","nextVal","firstFn","previousFn","transformError","_parallelMap","inputs","concurrentWork","valueCb","notifyError","notifyDone","queueNext","curriedStart","taken","_take","_syncTake","_asyncTap","addTime","seconds","nanoseconds","hrtime","_asyncTime","_syncTime","_writeToStream","notifyDrain","getMessageHandler","handleMessage","desMessage","MESSAGE_TYPE","MessageType","CONNECTION_TYPE","ConnectionType","_clusterLevelRaw","providerPeers","clusterLevel","level1","clusterLevelRaw","toPbPeer","dec","fromPbPeer","CONNECTED","CONNECTION_TYPES","author","_author","_timeReceived","_type","_record","_connection","FIND_NODE","ADD_PROVIDER","GET_PROVIDERS","PING","idFromKey","_checkLocalDatastore","_betterPeersToQuery","_verifyRecordLocally","recordKey","addProvider","getProviders","Query","putLocal","counterAll","counterSuccess","_putValueToPeer","minPeers","recs","best","fixupRec","_putLocal","sendCorrectionRecord","localRec","getLocal","rtp","valsLength","pathIndex","queryResults","lookupErr","_getValueOrPeers","pathComplete","Run","makePath","running","_onStart","_onComplete","finalSet","_run","execute","_startTime","queryStarted","peersSeen","queryCompleted","PeerDistanceList","WorkerQueue","peersQueried","addInitialPeer","executePaths","queryComplete","startWorker","peersQueriedPromise","dhtKey","queuedPeerIds","anyCloser","originDhtKey","peerDistances","pd","peerIds","dhtKeys","furthestDistance","keyDistance","PeerQueue","queryFunc","initialPeers","peersToQuery","fromKey","addPeerToQuery","workerQueue","Heap","Heap1","defaultCmp","heapify","heappop","heappush","heappushpop","heapreplace","insort","nlargest","nsmallest","updateItem","_siftdown","_siftup","lastelt","returnitem","_ref","_i","_ref1","_results","_results1","_j","los","startpos","newitem","parentpos","childpos","endpos","rightpos","pushpop","front","setupQueue","execution","execPromise","processNext","continueQuerying","continueQueryingError","execError","execQuery","queryError","queryCloser","LimitedPeerList","providerTimeout","pData","pathProviders","findProvidersSingle","provs","prov","PeerList","getPublicKeyFromNode","getValueSingle","recPeer","findPeerLocal","_findPeerSingle","tablePeers","closerPeersSingle","sorted","pId","makeProviderKey","parseProviderKey","readTime","cacheSize","cleanupInterval","provideValidity","lruCacheSize","syncQueue","_cleaner","_cleanup","deleteCount","deleted","expired","cacheKey","loadProviders","provider","_getProvidersMap","writeProviderEntry","base32PeerId","queries","_discoverBootstrapPeers","PeerRouting","ContentRouting","getPeer","validateConfig","AddressManager","ConnectionManager","Relay","Dialer","Metrics","TransportManager","Upgrader","PeerStore","PubsubAdapter","PersistentPeerStore","Registrar","IdentifyService","NatManager","updateSelfPeerRecord","addressManager","_modules","_transport","_discovery","keychainOpts","generateOptions","onConnection","onConnectionEnd","transportManager","faultTolerance","natManager","cryptos","muxers","identifyService","getProtocolStr","connProtector","protector","LIBP2P_FORCE_PNET","DHT","_onDiscoveryPeer","eventName","_onStarting","_onDidStart","unmount","importPeer","connections","dial","_dial","getAnnounceAddrs","getObservedAddrs","announceFilter","addrSet","peer3","peer4","protocols1","unhandle","protocols2","getListenAddrs","_maybeConnect","_setupPeerDiscovery","peer5","setupService","DiscoveryService","discoveryService","DiscoveryService1","getTransports","storeAddresses","uniquePeers","requirePeers","setDelayedInterval","clearDelayedInterval","_peerStore","_routers","_refreshManagerOptions","refreshManager","_findClosestPeersTask","bootDelay","maybeLimitSource","intervals","_runPeriodically","nVals","dnsaddrResolver","Constants","AGENT_VERSION","RelayConstants","publicAddressesFirst","FaultTolerance","FATAL_ALL","MAX_PARALLEL_DIALS","MAX_PER_PEER_DIALS","DIAL_TIMEOUT","addressSorter","queriesPerPeriod","externalIp","pmp","advertise","ADVERTISE_BOOT_DELAY","ADVERTISE_TTL","autoRelay","maxListeners","resultingOptions","dnsaddrCode","resolveTxt","Receptacle","Resolver","maxCache","_servers","getServers","_getShuffledServers","newServers","setServers","servers","rrType","resolve4","resolve6","recordType","cached","getCacheKey","buildResource","serverResolver","Answer","hostname2","hostname3","toMS","lastModified","expires","refresh","oldRecord","nativeFetch","accept","MAX_ADDRS_TO_DIAL","METRICS","computeThrottleMaxQueueSize","computeThrottleTimeout","movingAverageIntervals","maxOldPeersRetention","libp2pVersion","PROTOCOL_VERSION","MULTICODEC_IDENTIFY","MULTICODEC_IDENTIFY_PUSH","IDENTIFY_PROTOCOL_VERSION","MULTICODEC_IDENTIFY_PROTOCOL_NAME","MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME","MULTICODEC_IDENTIFY_PROTOCOL_VERSION","MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION","CIRCUIT_PROTO_CODE","HOP_METADATA_KEY","HOP_METADATA_VALUE","RELAY_RENDEZVOUS_NS","isPrivate","addressesPublicFirstCompareFunction","isAPrivate","isBPrivate","isCertified","isIpPrivate","netmask_1","ip_regex_1","is_ip_1","ipaddr_js_1","NETMASK_RANGES","ip_range","Netmask","ipv6_check","ip_addr","ipv4_check","toNormalizedString","Netmask1","atob","chr","chr0","chrA","chra","ip2long","long2ip","maskLong","bitmask","netLong","hostmask","broadcast","lastLong","ipv4Part","ipv4Regexes","fourOctet","threeOctet","twoOctet","longValue","octalRegex","hexRegex","zoneIndex","ipv6Part","ipv6Regexes","native","deprecatedTransitional","transitional","expandIPv6","replacement","replacementCount","colonCount","lastColon","zoneId","matchCIDR","partSize","cidrBits","parseIntAuto","padPart","ipaddr","IPv4","SpecialRanges","unspecified","multicast","linkLocal","loopback","carrierGradeNat","cidrRange","prefixLengthFromSubnetMask","cidr","zerotable","subnetMatch","toIPv4MappedAddress","IPv6","broadcastAddressFromCIDR","parseCIDR","ipInterfaceOctets","subnetMaskOctets","subnetMaskFromPrefixLength","isIPv4","isValidFourPartDecimal","networkAddressFromCIDR","filledOctetCount","uniqueLocal","ipv4Mapped","rfc6145","rfc6052","teredo","isIPv4MappedAddress","toFixedLengthString","suffix","toIPv4Address","toRFC5952String","bestMatchIndex","bestMatchLength","isIPv6","rangeList","defaultName","rangeName","rangeSubnets","pSettle","FAULT_TOLERANCE","_transports","_listenerOptions","listenerOptions","transportForMultiaddr","couldNotListen","supportedAddrs","isFulfilled","NO_FATAL","pReflect","pLimit","pTry","activeCount","pendingCount","clearQueue","arguments_","PeerRecord","peerRecord","ENVELOPE_DOMAIN_PEER_RECORD","ENVELOPE_PAYLOAD_TYPE_PEER_RECORD","multiaddrs1","seqNumber1","DOMAIN","every","AddressInfo","observed","addObservedAddr","LatencyMonitor","maxData","maxSentData","maxReceivedData","maxEventLoopDelay","pollInterval","autoDialInterval","movingAverageInterval","defaultPeerValue","_peerValues","_autoDialTimeout","_checkMetrics","_autoDial","_latencyMonitor","latencyCheckIntervalMs","dataEmitIntervalMs","accumulator","_onLatencyMeasure","connectionList","setPeerValue","received","_checkMaxLimit","storedConn","summary","avgMs","_maybeDisconnectOne","peerValues","disconnectPeer","VisibilityChangeEmitter","asyncTestFn","latencyRandomPercentage","_latecyCheckMultiply","_latecyCheckSubtract","getDeltaMS","startTime","performance","_latencyData","_initLatencyData","_visibilityChangeEmitter","pageInFocus","_startTimers","_emitSummary","_stopTimers","isVisible","_checkLatencyID","_checkLatency","_emitIntervalID","getSummary","minMs","maxMs","totalMs","POSITIVE_INFINITY","lengthMs","randomness","localData","deltaOffset","deltaMS","NEGATIVE_INFINITY","_initializeVisibilityVarNames","_addVisibilityChangeListener","visibilityChange","mozHidden","msHidden","webkitHidden","_hidden","_visibilityChange","_handleVisibilityChange","visible","_triggered","_timerWrapper","_schedule","timeout1","timeout2","CircuitRelay","CircuitPB","handleCanHop","handleHop","handleStop","StreamHandler","transportSymbol","_dialer","_onProtocol","streamHandler","circuit","virtualConnection","CAN_HOP","HOP","STOP","dstPeer","srcPeer","relayAddr","destinationAddr","relayId","destinationId","relayPeer","destinationPeer","disconnectOnFailure","relayConnection","listeningAddrs","relayConn","relayedAddr","validateAddrs","STATUS","HOP_CANT_SPEAK_RELAY","destinationConnection","HOP_NO_CONN_TO_DST","stopRequest","destinationStream","SUCCESS","sourceStream","canHop","writeResponse","HOP_DST_MULTIADDR_INVALID","STOP_DST_MULTIADDR_INVALID","HOP_SRC_MULTIADDR_INVALID","STOP_SRC_MULTIADDR_INVALID","AutoRelay","namespaceToCid","_autoRelay","_advertiseService","_transportManager","_addressSorter","_listenRelays","_onError","_addListenRelay","_removeListenRelay","remoteAddrs","listenAddr","_listenOnAvailableHopRelays","peersToIgnore","knownHopsToDial","metadataMap","supportsHop","_tryToListenOnRelay","DialRequest","maxAddrsToDial","_pendingDials","_pendingDialTargets","pendingTarget","dialTarget","_createCancellableDialTarget","pendingDial","_createPendingDial","cancellablePromise","_createDialTarget","knownAddrs","ra","dialRequest","dialAction","timeoutController","getTokens","releaseToken","resolvedMultiaddrs","_resolveRecord","nm","newM","pAny","tokenHolder","dialAbortControllers","completedDials","Fifo","_waitingConsumers","nextConsumer","pSome","PCancelable","anyCancelable","onCancel","FilterError","elementCount","isSettled","completed","cancelPending","CancelError","isCanceled","userFn","executor","_cancelHandlers","_isPending","_isCanceled","_rejectOnCancel","_promise","_reject","shouldReject","onFulfilled","onRejected","onRejected1","reason1","sanitize","CMS","infoPrefix","privates","NIST","iterationCount","validateKeyName","throwDelayed","DsName","DsInfoName","cms","dsname","keyInfo","oldDsname","newDsname","oldInfoName","newInfoName","name4","password1","name5","name6","oldPass","newPass","oldDek","newDek","keyAsPEM","illegalRe","controlRe","reservedRe","windowsReservedRe","windowsTrailingRe","sanitized","isHighSurrogate","isLowSurrogate","charLength","curByteLength","prevCodePoint","certificateForKey","findAsync","plain","_getPrivateKey","certificate","pkcs7","createEnvelopedData","addRecipient","toAsn1","cmsData","messageFromAsn1","recipients","issuer","shortName","recipient","keyId","findKeyById","missingKeys","_recipientFromAsn1","recipientInfoValidator","RDNAttributesAsArray","serialNumber","serial","encryptedContent","encAlgorithm","parameter","encParameter","encKey","_recipientsToAsn1","distinguishedNameToAsn1","_signerToAsn1","authenticatedAttributesAsn1","signatureAlgorithm","unauthenticatedAttributes","attrsAsn1","_attributeToAsn1","contentType","messageDigest","signingTime","jan_1_1950","jan_1_2050","_fromAsn1","rawCapture","_decryptContent","ciph","messageFromPem","messageToPem","pemObj","contentInfoValidator","envelopedData","createEncryptedData","signedData","createSignedData","fromAsn1","certificates","crls","signers","digestAlgorithmIdentifiers","contentInfo","signerInfos","signedDataValidator","certs","certificateFromAsn1","certificateToAsn1","addSigner","signer","cert","certificateFromPem","authenticatedAttributes","detached","detachedContent","mds","ai","_signersToAsn1","addSignerInfos","addDigestAlgorithmIds","addCertificate","addCertificateRevokationList","crl","encryptedDataValidator","envelopedDataValidator","infos","_recipientsFromAsn1","recipientInfos","findRecipient","sAttr","rAttr","desCBC","keyLen","ciphFn","p7v","pkcs7asn1","encryptedContentInfoValidator","signerValidator","_shortNames","x509CertificateValidator","rsassaPssParameterValidator","certificationRequestInfoValidator","certificationRequestValidator","_getAttribute","rdn","si","valueTagClass","CRIAttributesAsArray","extensionRequest","extensions","certificateExtensionFromAsn1","_readSignatureParameters","fillDefaults","algorithmOid","mgf","hashOid","maskGenOid","maskGenHashOid","_dnToAsn1","attrs","_fillMissingFields","attribute","valueConstructed","certificateExtensionToAsn1","_fillMissingExtensionFields","extension","digitalSignature","nonRepudiation","keyEncipherment","dataEncipherment","keyAgreement","keyCertSign","cRLSign","encipherOnly","decipherOnly","cA","pathLenConstraint","email","objsign","sslCA","emailCA","objCA","altNames","altName","ski","generateSubjectKeyIdentifier","subjectKeyIdentifier","keyIdentifier","authorityCertIssuer","subSeq","fullNameGeneralNames","_signatureParametersToAsn1","_CRIAttributesToAsn1","csr","computeHash","certificateToPem","publicKeyToPem","publicKeyToRSAPublicKeyPem","getPublicKeyFingerprint","certificationRequestFromPem","certificationRequestFromAsn1","certificationRequestToPem","certificationRequestToAsn1","createCertificate","siginfo","notBefore","notAfter","getField","sn","addField","setSubject","uniqueId","setIssuer","setExtensions","exts","getExtension","signatureOid","tbsCertificate","getTBSCertificate","issued","expectedIssuer","actualIssuer","sha1WithRSAEncryption","signatureParameters","pss","isIssuer","iattr","sattr","verifySubjectKeyIdentifier","certVersion","certSerialNumber","certSignatureOid","certSignatureParams","certinfoSignatureOid","certinfoSignatureParams","certSignature","certValidity1UTCTime","certValidity2GeneralizedTime","certValidity3UTCTime","certValidity4GeneralizedTime","imd","certIssuer","certIssuerUniqueId","smd","certSubject","certSubjectUniqueId","certExtensions","certificateExtensionsFromAsn1","subjectPublicKeyInfo","extseq","critical","gn","createCertificationRequest","csrVersion","csrSignatureOid","csrSignatureParams","csrSignature","certificationRequestInfo","certificationRequestInfoSubject","getAttribute","addAttribute","certificationRequestInfoAttributes","setAttributes","getCertificationRequestInfo","cri","_dateToAsn1","tbs","certificateExtensionsToAsn1","dn","createCaStore","caStore","getBySubject","ensureSubjectHasHash","getIssuer","hasCertificate","der1","listAllCertificates","certList","removeCertificate","cert1","certificateError","bad_certificate","unsupported_certificate","certificate_revoked","certificate_expired","certificate_unknown","unknown_ca","verifyCertificateChain","chain","validityCheckDate","selfSigned","verified","se","keyUsage","basicConstraints","bcExt","keyUsageExt","vfd","maskLen","sLen","salt_","pssobj","modBits","emBits","emLen","mHash","m_","checkLen","serverAuth","clientAuth","codeSigning","emailProtection","timeStamping","asyncCompare","findIndex","oldPeerLRU","Stats","initialCounters","directionToEvent","in","_globalStats","_peerStats","_protocolStats","_oldPeers","onPeerDisconnected","stats1","idString","protocolStats","updatePlaceholder","placeholderStats","peerIdString","existingStats","mergedStats","mergeStats","trackStream","protocol2","_sink","LRU","patched","BigNumber","Big","MovingAverage","_stats","_frequencyLastTime","_frequencyAccumulators","_movingAverages","_resetComputeTimeout","counters","inc","_nextTimeout","urgency","_applyOp","_updateFrequency","latestTime","timeDiff","_updateFrequencyFor","timeDiffMS","latestTime1","hz","plus","globalObject","BigNumber1","isNumeric","mathceil","mathfloor","bignumberError","tooManyDigits","LOG_BASE","configObject","convertBase","parseNumeric","dotAfter","dotBefore","isInfinityOrNaN","whitespaceOrPlus","caseChanged","isNum","_isBigNumber","MAX_EXP","MIN_EXP","intCheck","DECIMAL_PLACES","ROUNDING_MODE","DEBUG","TO_EXP_NEG","TO_EXP_POS","toFixedPoint","c0","sd","ni","rd","pows10","POWS_TEN","coeffToString","MAX","CRYPTO","MODULO_MODE","POW_PRECISION","FORMAT","maximum","maxOrMin","minimum","pow2_53","random53bitInt","toBaseOut","baseIn","baseOut","arrL","callerIsToString","klo","SQRT_BASE","khi","xhi","aL","bL","prod","prodL","qc","remL","rem0","xL","yc0","yL","yz","yc","bitFloor","basePrefix","compare1","idiv","exponentiatedBy","isModExp","nIsBig","nIsNeg","nIsOdd","times","xLTy","xe","ye","minus","xcL","xlo","ycL","ylo","yhi","zc","sqrtBase","timespan","previousTime","variance","forecast","Multistream","Connection","mutableProxy","encryptedConn","upgradedConn","cryptoProtocol","setPeer","proxyPeer","setTarget","proxy","protectedConn","protect","_encryptInbound","_multiplexInbound","_createConnection","maConn1","remotePeerId","_encryptOutbound","_multiplexOutbound","maConn2","muxedStream","mss","Listener","_onStream","_timeline","upgraded","errConnectionNotMultiplexed","multiplexer","getStreams","cryptos1","secureInbound","localPeer2","cryptos2","secureOutbound","connection3","muxers1","connection4","muxers2","PROTOCOL_ID","MultistreamSelect","_stream","_shaken","_handshake","multistream","protocolId","shakeStream","writeAll","NewLine","protocolsReader","OPEN","CLOSING","CLOSED","connectionSymbol","localAddr1","newStream1","close1","getStreams1","stat1","validateArgs","_stat","_getStreams","_closing","_toConsumableArray","arr2","defaultTarget","mutableHandler","mutableTarget","setHandler","property","getTarget","getHandler","AddressBook","KeyBook","MetadataBook","ProtoBook","storedPeers","peersData","addressesDeleted","keyDeleted","protocolsDeleted","metadataDeleted","Book","eventProperty","eventTransformer","storedRecord","_toAddresses","_setData","getPeerRecord","newAddr","_ps","peerId4","multiaddrs2","peerId5","passthrough","b58key","_emit","data2","_setValue","recMap","deleteValue","recSet","newSet","PubsubRouter","_subscribeAdapter","_unsubscribeAdapter","NAMESPACE_ADDRESS","NAMESPACE_COMMON","NAMESPACE_KEYS","NAMESPACE_METADATA","NAMESPACE_PROTOCOL","_dirtyPeers","_dirtyMetadata","_addDirtyPeer","_addDirtyPeerKey","_addDirtyPeerMetadata","_processDatastoreEntry","_commitData","peerIdstr","mData","commitPeers","_batchAddressBook","_batchKeyBook","_batchMetadataBook","_batchProtoBook","b32key","encodedData","certifiedRecord","batch1","peerId6","batch2","dirtyMetada","dirtyKey","dirtyValue","peerId7","batch3","keyParts","Address","CertifiedRecord","topologies","_handle","isTopology","PROTOCOL_NAME","PING_LENGTH","PROTOCOL","identifyProtocolStr","identifyPushProtocolStr","libp2p1","protocolStr","_host","identify","pushToPeerStore","listenAddrs","pushes","Identify","observedAddr","cleanObservedAddr","getCleanMultiaddr","_handleIdentify","_handlePush","err4","IDENTIFY","IDENTIFY_PUSH","Messsage","NatAPI","retry","isPrivateIp","pkg","DEFAULT_TTL","highPort","_addressManager","_enabled","_externalIp","autoUpdate","enablePMP","_start","_getClient","publicIp","publicPort","privatePort","fromNodeAddress","onFailedAttempt","f1","argumentNames","networkErrorMsgs","originalError","pRetry","retries","attemptNumber","errorMessage","retriesLeft","decorateErrorWithCounts","mainError","RetryOperation","timeouts","forever","maxRetryTime","minTimeout","maxTimeout","randomize","createTimeout","original1","_originalTimeouts","_timeouts","_maxRetryTime","_fn","_attempts","_operationTimeout","_operationTimeoutCb","_operationStart","_cachedTimeouts","timeoutOps","counts","mainErrorCount","isLoopbackAddr","ipfsBitswap","blockStorage","readAddrs","statsEnabled","BlockStorage","WEBSOCKET_STAR_PROTO_CODE","maId","Bitswap","notifications","statsComputeThrottleTimeout","statsComputeThrottleMaxQueueSize","statsKeys","hashLoader","DecisionEngine","wm","WantManager","Notifications","incoming","messageReceived","cidStr","wasWanted","cancelWants","_handleReceivedBlock","_updateReceiveCounters","_receiveError","peerDisconnected","enableStats","disableStats","ledgerForPeer","fetchFromNetwork","wantBlocks","wantBlock","promptedNetwork","findAndConnect","loadOrFetchFromNetwork","cidsArray","unwantBlocks","unwantBlock","cids2","_options1","_sendHaveBlockNotifications","data3","hasBlock","receivedBlocks","msgQueue","_addEntries","BitswapMessage","Entry","kMaxPriority","WantType","removeForce","addEntries","_startPeerHandler","mq","refcnt","MsgQueue","fullwantlist","addEntry","addMessage","_stopPeerHandler","cids3","connectedPeers","vd","varintEncoder","vd__default","blockPresences","pendingBytes","wantType","sendDontHave","entry$1","Have","BitswapMessageEntry","addBlock","addHave","BlockPresenceType","addDontHave","DontHave","setPendingBytes","serializeToBitswap100","serializeToBitswap110","cidStr1","bpType","BlockPresence","isMapEqual","blockPresence","blockPresenceSize","varint__namespace","includesWith","pred","groupBy","valueA","valueB","pullAllWith","sortBy","uniqWith","WantlistEntry","WantListEntry","hasRefs","sortedEntries","_refCounter","Message1","hasBlockTimeout","maxProvidersPerRequest","provideTimeout","providerRequestTimeout","wantlistSendDebounceMs","debounce__default","selfPeerId","otherPeerId","_entries","sendEntries","_sendEntries","connectTo","callFirst","debouncedFn","debounceWrapper","callNow","lp__default","MulticodecTopology__default","BITSWAP100","BITSWAP110","BITSWAP120","_bitswap","_protocols","b100Only","_onPeerDisconnect","_onConnection","_hashLoader","_receiveMessage","maxProviders","connectAttempts","stringId","writeMessage","_updateSentStats","ledger","reqQueue","taskMerger","_opts","_processOpts","ledgerMap","_requestQueue","RequestQueue","TaskMerger","maxSizeReplaceHasWithBlock","targetMessageSize","_scheduleProcessTasks","_processTasks","pendingSize","popTasks","blockCids","blockTasks","haveBlock","isWantBlock","_getBlocks","taskData","blk","tasksDone","messageSent","partner","debtRatio","accounting","bytesSent","recv","bytesRecv","exchanged","exchangeCount","wantlistContains","_sendAsBlock","entrySize","pushTasks","_findOrCreate","_updateBlockAccounting","cancels","wants","cancelWant","_cancelWants","_addWants","_getBlockSizes","blocksMap","ledger1","receivedBytes","sentBytes","numBytesSentTo","numBytesReceivedFrom","peerId8","peerId9","ledger$1","Ledger","sentToPeer","lastExchange","sortedMap","DefaultTaskMerger","hasNewInfo","PeerTasks","taskMerger1","_taskMerger","_activeTotalSize","_pending","PendingTasks","_active","tasks2","_pushTask","_taskHasMoreInfoThanActiveTasks","existingTask","updatePriority","task1","tasksWithTopic","activeTask","targetMinBytes1","pendingTasks","totalSize","taskDone","task2","isIdle","_tasks","SortedMap","_compare","task3","created","_byPeer","peerTasks","targetMinBytes","tasks1","_cmp","_defaultSort","newIdx","_find","pivot","_kCmp","newTask","existingData","unwantEvent","blockEvent","blockEvt","unwantEvt","onUnwant","onBlock","_initialCounters","_global","_peers","peerStat","MovingAverage__default","_disabled","blockstoreCore","missingBlocks","getFromBitswap","getFromChild","MemoryBlockstore","hangUp","basePacket","storedPeer","packetCount","totalTime","average","get1","closerPeerId","notEnabled","isEnabled","installedModules","__webpack_require__","moduleId","URL_REGEX","FIRST_SEGMENT_REGEX","SLASH_DOT_REGEX","SLASH_DOT_DOT_REGEX","URLToolkit","buildAbsoluteURL","baseURL","relativeURL","alwaysNormalize","basePartsForNormalise","parseURL","buildURLFromParts","relativeParts","baseParts","netLoc","pathParts","builtParts","baseURLPath","newPath","webpackBootstrapFunc","oe","ENTRY_MODULE","moduleNameReqExp","dependencyRegExp","quoteRegExp","getModuleDependencies","queueName","retval","fnString","wrapperSignature","webpackRequireName","__webpack_require__1","hasValuesInQueues","queues","hasValues","module1","main","requiredModules","modulesQueue","seenModules","moduleToCheck","newModules","newModulesKeys","getRequiredModules","entryModule","bare","workerUrl","webkitURL","mozURL","msURL","objectURL","AESCrypto","aesIV","FastAESKey","AESDecryptor","subMix","invSubMix","sBox","invSBox","initTable","uint8ArrayToUint32Array_","subMix0","subMix1","subMix2","subMix3","invSubMix0","invSubMix1","invSubMix2","invSubMix3","sameKey","ksRow","invKsRow","ksRows","keySchedule","invKeySchedule","networkToHostOrderSwap","inputArrayBuffer","removePKCS7Padding","inputWords0","inputWords1","inputWords2","inputWords3","outputBytes","paddingBytes","nRounds","invSBOX","initVector","initVector0","initVector1","initVector2","initVector3","inputInt32","outputInt32","swapWord","getSelfScope","Decrypter","_ref$removePKCS7Paddi","logEnabled","webkitSubtle","disableWebCrypto","enableSoftwareAES","decryptor","fastAesKey","aesKey","onWebCryptoError","trigger","Event","ERROR","ErrorTypes","MEDIA_ERROR","details","ErrorDetails","FRAG_DECRYPT_ERROR","fatal","isHeaderPattern","getHeaderLength","getFullFrameLength","isHeader","headerLength","frameLength","newOffset","initTrackConfig","audioCodec","samplerate","adtsObjectType","adtsSampleingIndex","adtsExtensionSampleingIndex","adtsChanelConfig","manifestCodec","adtsSampleingRates","channelCount","FRAG_PARSING_ERROR","getAudioConfig","getFrameDuration","appendFrame","pts","frameIndex","frameDuration","stamp","parseFrameHeader","aacSample","dts","AACDemuxer","remuxer","resetInitSegment","initSegment","videoCodec","_audioTrack","container","sequenceNumber","isAAC","inputTimeScale","resetTimeStamp","ID3","getID3Data","ADTS","timeOffset","contiguous","accurateTimeOffset","id3Data","getTimeStamp","id3Samples","frame","remux","MpegAudio","BitratesMap","SamplingRateMap","SamplesCoefficients","BytesInSlot","parseHeader","samplesPerFrame","sampleRate","headerB","headerC","headerE","headerF","headerG","columnInBitrates","bitRate","columnInSampleRates","sampleCoefficient","bytesInSlot","ExpGolomb","bytesAvailable","bitsAvailable","loadWord","workingBytes","availableBytes","skipBits","skipBytes","readBits","valu","skipLZ","leadingZeroCount","skipUEG","skipEG","readUEG","clz","readEG","readBoolean","readUByte","readUShort","readUInt","skipScalingList","lastScale","nextScale","readSPS","profileIdc","numRefFramesInPicOrderCntCycle","picWidthInMbsMinus1","picHeightInMapUnitsMinus1","frameMbsOnlyFlag","scalingListCount","frameCropLeftOffset","frameCropRightOffset","frameCropTopOffset","frameCropBottomOffset","chromaFormatIdc","picOrderCntType","pixelRatio","readSliceType","SampleAesDecrypter","decryptdata","discardEPB","decrypter","decryptBuffer","decryptAacSample","sampleIndex","curUnit","encryptedBuffer","localthis","decryptedData","decryptAacSamples","getAvcEncryptedData","decodedData","encryptedDataLen","outputPos","inputPos","getAvcDecryptedUnit","decryptAvcSample","unitIndex","decryptAvcSamples","curUnits","RemuxerTrackIdConfig","audio","TSDemuxer","typeSupported","sampleAes","pmtUnknownTypes","setDecryptData","syncOffset","_syncOffset","scanwindow","createTrack","dropped","pmtParsed","_pmtId","_avcTrack","_id3Track","_txtTrack","aacOverFlow","aacLastPTS","avcSample","_duration","stt","pes","unknownPIDs","avcTrack","audioTrack","id3Track","avcId","audioId","id3Id","pmtId","avcData","pesData","audioData","parsePAT","_parsePAT","parsePMT","_parsePMT","parsePES","_parsePES","parseAVCPES","_parseAVCPES","parseAACPES","_parseAACPES","parseMPEGPES","_parseMPEGPES","parseID3PES","_parseID3PES","parsedPIDs","mpeg","mp3","avc","decryptAndRemux","videoTrack","textTrack","decryptAndRemuxAvc","_initPTS","_initDTS","_trackUnknownPmt","logLevel","mpegSupported","isSampleAes","tableEnd","pesFlags","pesLen","pesHdrLen","pesPts","pesDts","payloadStartOffset","dataLen","pushAccesUnit","nbSamples","lastSample","forceKeyFrameOnDiscontinuity","sps","expGolombDecoder","_parseAVCNALu","spsfound","createAVCSample","audFound","sliceType","payloadSize","endOfCaptions","totalCCs","_insertSampleInOrder","uuidStrArray","userDataPayloadBytes","uuid","userDataBytes","userData","utf8ArrayToStr","codecarray","codecstring","pps","_getLastNalUnit","lastUnit","lastUnitType","naluState","lastState","lastUnitStart","newLength","EPBPositions","sourceIndex","newPTS","MP3Demuxer","AAC","getSilentFrame","UINT32_MAX","MP4","avc1","avcC","btrt","dinf","dref","esds","ftyp","hdlr","mdat","mdhd","mdia","mfhd","minf","moof","moov","mp4a","mvex","mvhd","pasp","sdtp","stbl","stco","stsc","stsd","stsz","stts","tfdt","tfhd","traf","trak","trun","trex","tkhd","vmhd","smhd","videoHdlr","audioHdlr","HDLR_TYPES","STTS","STSC","STCO","STSZ","VMHD","SMHD","STSD","majorBrand","avc1Brand","minorVersion","FTYP","box","DINF","timescale","upperWordDuration","lowerWordDuration","baseMediaDecodeTime","tracks","boxes","dependsOn","isDependedOn","hasRedundancy","avcc","hSpacing","vSpacing","configlen","sampleDependencyTable","upperWordBaseMediaDecodeTime","lowerWordBaseMediaDecodeTime","cts","arraylen","isLeading","paddingValue","isNonSync","degradPrio","movie","toTimescaleFromBase","destScale","srcBase","toMsFromMpegTsClock","toMpegTsClockFromTimescale","srcScale","MAX_SILENT_FRAME_DURATION_90KHZ","PTS_DTS_SHIFT_TOLERANCE_90KHZ","chromeVersion","PTSNormalize","reference","MP4Remuxer","vendor","ISGenerated","defaultTimeStamp","getVideoStartPts","videoSamples","rolloverDetected","startPTS","minPTS","generateIS","nbAudioSamples","nbVideoSamples","audioTimeOffset","videoTimeOffset","audiovideoTimestampDelta","audioTrackLength","remuxAudio","endPTS","remuxVideo","videoData","remuxEmptyAudio","remuxID3","remuxText","FRAG_PARSED","initPTS","initDTS","audioSamples","computePTSDTS","INIT_PTS_FOUND","FRAG_PARSING_INIT_SEGMENT","mp4SampleDuration","firstDTS","lastDTS","timeScale","inputSamples","outputSamples","maxPTS","ptsDtsShift","sortSamples","nextAvcDts","deltadts","deltapts","averageSampleDuration","lastDts","foundHole","firstPTS","nbNalu","naluLen","nbUnits","sampleLen","mdatSize","MUX_ERROR","REMUX_ALLOC_ERROR","compositionTimeOffset","avcSampleUnits","mp4SampleLength","unitData","unitDataLen","lastFrameDuration","stretchShortVideoTrack","maxBufferHole","gapTolerance","deltaToFrameEnd","nextAudioPts","startDTS","endDTS","hasAudio","hasVideo","FRAG_PARSING_DATA","mp4Sample","fillFrame","lastPTS","mp4timeScale","scaleFactor","inputSampleDuration","rawMPEG","maxAudioFramesDrift","nextPts","newStamp","audioSample","numMissingFrames","unitLen","lastSampleDuration","silentFrame","FRAG_PARSING_METADATA","FRAG_PARSING_USERDATA","PassThroughRemuxer","rawData","streamType","DemuxerInline","demuxer","discontinuity","trackSwitch","defaultInitPTS","endTime","FRAG_DECRYPTED","tstart","tdecrypt","pushDecrypted","mux","muxConfig","demux","MP4Demuxer","__webpack_exports__","_demux_demuxer_inline__WEBPACK_IMPORTED_MODULE_0__","_events__WEBPACK_IMPORTED_MODULE_1__","_utils_logger__WEBPACK_IMPORTED_MODULE_2__","eventemitter3__WEBPACK_IMPORTED_MODULE_3__","DemuxerWorker","_len2","_key2","forwardMessage","cmd","enableLogs","transferable","_utils_get_self_scope__WEBPACK_IMPORTED_MODULE_0__","isFooter","_readSize","frames","getID3Frames","isTimeStampFrame","_readTimeStamp","_getFrameData","frameData","_decodeFrame","_decodePrivFrame","_decodeURLFrame","_decodeTextFrame","timeStampFrame","pts33Bit","owner","_utf8ArrayToStr","privateData","exitOnNull","getTextDecoder","char2","char3","_utils_logger__WEBPACK_IMPORTED_MODULE_0__","initData","parseInitSegment","audiovideo","findBox","bin2str","subresults","endbox","parseSegmentIndex","moovEndOffset","sidx","startByte","referencesCount","referenceIndex","referenceInfo","referenceSize","subsegmentDuration","earliestPresentationTime","trackId","soun","vide","codecBox","codecType","getStartDTS","trafs","baseTimes","scale","offsetStartDTS","ErrorTypes1","ErrorDetails1","HlsEvents","MEDIA_ATTACHING","MEDIA_ATTACHED","MEDIA_DETACHING","MEDIA_DETACHED","BUFFER_RESET","BUFFER_CODECS","BUFFER_CREATED","BUFFER_APPENDING","BUFFER_APPENDED","BUFFER_EOS","BUFFER_FLUSHING","BUFFER_FLUSHED","MANIFEST_LOADING","MANIFEST_LOADED","LEVEL_SWITCHING","LEVEL_SWITCHED","LEVEL_LOADING","LEVEL_LOADED","LEVEL_UPDATED","LEVEL_PTS_UPDATED","LEVELS_UPDATED","AUDIO_TRACKS_UPDATED","AUDIO_TRACK_SWITCHING","AUDIO_TRACK_SWITCHED","AUDIO_TRACK_LOADING","AUDIO_TRACK_LOADED","SUBTITLE_TRACKS_UPDATED","SUBTITLE_TRACK_SWITCH","SUBTITLE_TRACK_LOADING","SUBTITLE_TRACK_LOADED","SUBTITLE_FRAG_PROCESSED","CUES_PARSED","NON_NATIVE_TEXT_TRACKS_FOUND","FRAG_LOADING","FRAG_LOAD_PROGRESS","FRAG_LOAD_EMERGENCY_ABORTED","FRAG_LOADED","FRAG_BUFFERED","FRAG_CHANGED","FPS_DROP","FPS_DROP_LEVEL_CAPPING","DESTROYING","KEY_LOADING","KEY_LOADED","STREAM_STATE_TRANSITION","LIVE_BACK_BUFFER_REACHED","PlaylistContextType","PlaylistLevelType","FORBIDDEN_EVENT_NAMES","hlsEventGeneric","hlsHandlerDestroying","hlsHandlerDestroyed","EventHandler","handledEvents","useGenericHandler","onEvent","registerListeners","onHandlerDestroying","unregisterListeners","onHandlerDestroyed","isEventHandler","onEventGeneric","funcName","OTHER_ERROR","INTERNAL_EXCEPTION","LevelKey","ElementaryStreamTypes","baseURI","relativeURI","_uri","baseuri","reluri","Fragment","_url","_byteRange","_decryptdata","_elementaryStreams","AUDIO","VIDEO","deltaPTS","rawProgramDateTime","programDateTime","tagList","cc","relurl","baseurl","urlId","levelkey","setByteRange","previousFrag","byteRange","byteRangeEndOffset","addElementaryStream","hasElementaryStream","createInitializationVector","segmentNumber","uint8View","setDecryptDataFromLevelKey","baseUrl","endCC","endSN","fragments","live","needSidxRanges","startCC","startSN","startTimeOffset","targetduration","totalduration","DECIMAL_RESOLUTION_REGEX","ATTR_LIST_REGEX","AttrList","parseAttrList","decimalInteger","attrName","hexadecimalInteger","hexadecimalIntegerAsNumber","decimalFloatingPoint","enumeratedString","decimalResolution","sampleEntryCodesISO","a3ds","alac","alaw","dra1","dtsc","dtse","dtsh","enca","g719","g726","m4ae","mha1","mha2","mhm1","mhm2","mlpa","Opus","samr","sawb","sawp","sevc","sqcp","ssmv","twos","ulaw","avc2","avc3","avc4","avcp","drac","dvav","dvhe","encv","hev1","hvc1","mjp2","mp4v","mvc1","mvc2","mvc3","mvc4","resv","rv60","s263","svc1","svc2","vp08","vp09","isCodecSupportedInMp4","MediaSource","isTypeSupported","MASTER_PLAYLIST_REGEX","MASTER_PLAYLIST_MEDIA_REGEX","LEVEL_PLAYLIST_REGEX_FAST","LEVEL_PLAYLIST_REGEX_SLOW","MP4_REGEX_SUFFIX","M3U8Parser","findGroup","mediaGroupId","convertAVC1ToAVCOTI","avcdata","parseMasterPlaylist","levels","sessionData","hasSessionData","setCodecs","filtered","typeCodes","isCodecType","preferred","unknownCodecs","bitrate","NAME","CODECS","sessionAttrs","parseMasterPlaylistMedia","audioGroups","medias","media","groupId","instreamId","LANGUAGE","DEFAULT","autoselect","AUTOSELECT","forced","FORCED","lang","URI","groupCodec","parseLevelPlaylist","levelUrlId","currentSN","discontinuityCounter","prevFrag","firstPdtIndex","assignProgramDateTime","keyAttrs","decryptmethod","decrypturi","decryptiv","KEYFORMAT","mapAttrs","BYTERANGE","averagetargetduration","startIndex","fragPrev","backfillProgramDateTimes","endProgramDateTime","PlaylistLoader","_EventHandler","loaders","canHaveQualityLevels","AUDIO_TRACK","SUBTITLE_TRACK","mapContextToLevelType","SUBTITLE","MAIN","getResponseUrl","createInternalLoader","PLoader","pLoader","Loader","getInternalLoader","resetInternalLoader","contextType","destroyInternalLoaders","onManifestLoading","MANIFEST","onLevelLoading","LEVEL","onAudioTrackLoading","onSubtitleTrackLoading","maxRetry","retryDelay","maxRetryDelay","loaderContext","manifestLoadingMaxRetry","manifestLoadingTimeOut","manifestLoadingRetryDelay","manifestLoadingMaxRetryTimeout","levelLoadingTimeOut","levelLoadingMaxRetry","levelLoadingRetryDelay","levelLoadingMaxRetryTimeout","loaderConfig","loaderCallbacks","loadsuccess","loaderror","loadtimeout","networkDetails","isSidxRequest","_handleSidxRequest","_handlePlaylistLoaded","tload","_handleTrackOrLevelPlaylist","_handleMasterPlaylist","_handleManifestParsingError","_handleNetworkError","_M3U8Parser$parseMast","audioTracks","subtitles","captions","embeddedAudioFound","levelId","levelType","levelDetails","singleLevel","tparsed","sidxUrl","rangeStart","rangeEnd","NETWORK_ERROR","LEVEL_EMPTY_ERROR","sidxInfo","sidxReferences","segmentRef","segRefInfo","MANIFEST_PARSING_ERROR","MANIFEST_LOAD_TIMEOUT","MANIFEST_LOAD_ERROR","LEVEL_LOAD_TIMEOUT","LEVEL_LOAD_ERROR","AUDIO_TRACK_LOAD_TIMEOUT","AUDIO_TRACK_LOAD_ERROR","errorData","FragmentLoader","loaderName","onFragLoading","FragmentILoader","fLoader","DefaultILoader","progressData","byteRangeStartOffset","fragLoadingTimeOut","fragLoadingMaxRetryTimeout","loadprogress","FRAG_LOAD_ERROR","FRAG_LOAD_TIMEOUT","KeyLoader","decryptkey","decrypturl","onKeyLoading","fragLoadingRetryDelay","KEY_LOAD_ERROR","KEY_LOAD_TIMEOUT","FragmentState","FragmentTracker","bufferPadding","timeRanges","_proto","getBufferedFrag","bufferedFrags","fragmentEntity","buffered","bufferedFragKey","detectEvictedFragments","elementaryStream","timeRange","esData","fragmentTimes","isTimeBuffered","removeFragment","detectPartialFragments","_this3","fragKey","getFragmentKey","getBufferedTimes","fragmentPartial","partial","getPartialFragment","timePadding","_this4","bestFragment","bestOverlap","isPartial","getState","onFragLoaded","bitrateTest","onBufferAppended","_this5","onFragBuffered","hasFragment","removeAllFragments","BinarySearch","comparisonFn","minIndex","maxIndex","currentElement","comparisonResult","BufferHelper","isBuffered","bufferInfo","maxHoleDuration","vbuffered","bufferedInfo","nextStart","buffered2","buf2len","buf2end","bufferStartNext","bufferLen","bufferStart","bufferEnd","getMediaSource","WebKitMediaSource","Observer","_EventEmitter","Demuxer","mp4","enableWorker","onwmsg","onWorkerMessage","filename","lineno","lastFrag","nextSN","addGroupId","audioGroupIds","textGroupIds","updatePTS","fromIdx","toIdx","fragFrom","fragTo","fragToPTS","minEndPTS","updateFragPTSDTS","maxStartPTS","drift","fragIdx","PTSKnown","mergeDetails","oldDetails","newDetails","PTSFrag","ccOffset","mapFragmentIntersection","oldFrag","newFrag","backtracked","newFragments","oldPlaylist","newPlaylist","oldFragments","adjustSliding","intersectionFn","computeReloadInterval","currentPlaylist","lastRequestTime","reloadInterval","minReloadInterval","TimeRanges","adjustPts","sliding","alignStream","lastLevel","shouldAlign","shouldAlignOnDiscontinuities","referenceFrag","prevDetails","curDetails","prevFrags","curFrags","prevStartFrag","firstFrag","currentFrag","findFirstFragWithCC","findDiscontinuousReferenceFrag","alignDiscontinuities","lastDetails","hasProgramDateTime","lastPDT","alignPDT","findFragmentByPDT","PDTValue","maxFragLookUpTolerance","seg","pdtWithinToleranceTest","findFragmentByPTS","fragPrevious","fragNext","fragmentWithinToleranceTest","foundFragment","candidateLookupTolerance","pdtBufferEnd","GapController","fragmentTracker","nudgeRetry","stallReported","stalled","moved","seeking","lastCurrentTime","seeked","beginSeek","playbackRate","hasEnoughBuffer","noBufferGap","startJump","_trySkipBufferHole","tnow","stalledDuration","_reportStall","bufferedWithHoles","_tryFixBufferStall","stalledDurationMs","highBufferWatchdogPeriod","_tryNudgeBuffer","BUFFER_STALLED_ERROR","lastEndTime","targetTime","BUFFER_SEEK_OVER_HOLE","nudgeMaxRetry","nudgeOffset","BUFFER_NUDGE_ON_STALL","TaskLoop","_boundTick","_tickTimer","_tickInterval","_tickCallCount","tick","_assertThisInitialized","clearNextTick","hasInterval","hasNextTick","millis","doTick","BaseStreamController","startLoad","stopLoad","fragCurrent","_streamEnded","fragState","onMediaSeeking","mediaBuffer","tolerance","fragStartOffset","fragEndOffset","loadedmetadata","nextLoadPosition","startPosition","onMediaEnded","_TaskLoop","computeLivePosition","targetLatency","liveSyncDuration","liveSyncDurationCount","chromeOrFirefox","StreamController","_BaseStreamController","audioCodecSwap","gapController","altAudio","audioOnly","fragLoadError","startFragRequested","startLevel","testBandwidth","nextAutoLevel","nextLoadLevel","forceStartLoad","_doTickIdle","retryDate","_checkBuffer","_checkFragmentChanged","levelLastLoaded","startFragPrefetch","levelInfo","maxBufLen","levelBitrate","maxBufferSize","maxBufferLength","maxMaxBufferLength","_fetchPayloadOrEos","fragLen","initialLiveManifestSize","_ensureFragmentAtLivePoint","_findFragment","_loadKey","_loadFragment","maxLatency","liveMaxLatencyDuration","liveMaxLatencyDurationCount","liveSyncPosition","targetSN","fragPreviousLoad","fragmentIndexRange","fragNextLoad","curSNIdx","sameLevel","prevSnFrag","nextSnFrag","autoLevel","autoLevelEnabled","_reduceMaxBufferLength","followingBufferedFrag","fragPlayingCurrent","fragPlaying","fragPlayingLevel","immediateLevelSwitch","immediateSwitch","previouslyPaused","flushMainBuffer","immediateLevelSwitchEnd","nextLevelSwitch","fetchdelay","nextLevelId","nextLevel","fragLastKbps","bufferedFrag","nextBufferedFrag","startPts","flushScope","onMediaAttached","onvseeking","onvseeked","onMediaSeeked","onvended","autoStartLoad","onMediaDetaching","onManifestParsed","aac","heaac","audioCodecSwitch","onLevelLoaded","newLevelId","curLevel","LevelHelper","onKeyLoaded","fragLoaded","currentLevel","tbuffered","pendingBuffering","appended","initSegmentData","_getAudioCodec","onFragParsingInitSegment","fragNew","trackName","levelCodec","onFragParsingData","onFragParsed","_checkAppendedParsed","onAudioTrackSwitching","fromAltAudio","onAudioTrackSwitched","videoBuffer","onBufferCreated","mediaTrack","alternate","tfirst","mediaBuffered","fragLoadingMaxRetry","levelRetry","BUFFER_FULL_ERROR","minLength","_seekToStartPos","onFragLoadEmergencyAborted","onBufferFlushed","elementaryStreamType","onLevelsUpdated","swapAudioCodec","defaultAudioCodec","nextState","previousState","_liveSyncPosition","LevelController","canload","currentLevelIndex","manualLevelIndex","clearTimer","_levels","levelRetryCount","loadError","loadLevel","onManifestLoaded","bitrateStart","levelSet","levelFromSet","videoCodecFound","audioCodecFound","fragmentError","SUBTITLES","_ref2","_firstLevel","firstLevel","MANIFEST_INCOMPATIBLE_CODECS_ERROR","setLevelInternal","newLevel","levelProperties","LEVEL_SWITCH_ERROR","levelIndex","levelError","recoverLevel","errorEvent","redundantLevels","errorDetails","_ref3","trequest","audioGroupId","levelObject","removeLevel","_startLevel","configStartLevel","sendAddTrackEvent","videoEl","createEvent","initEvent","clearCurrentCues","cues","removeCue","ID3TrackController","getID3Track","textTracks","addTextTrack","onFragParsingMetadata","Cue","WebKitDataCue","VTTCue","TextTrackCue","cue","addCue","onLiveBackBufferReached","foundCue","getClosestCue","EWMA","halfLife","alpha_","estimate_","totalWeight_","weight","adjAlpha","getTotalWeight","getEstimate","zeroFactor","EwmaBandWidthEstimator","slow","fast","defaultEstimate","defaultEstimate_","minWeight_","minDelayMs_","slow_","fast_","durationMs","numBytes","durationS","bandwidthInBps","canEstimate","AbrController","lastLoadedFragLevel","_nextAutoLevel","_bwEstimator","onCheck","_abandonRulesCheck","abr_controller_assertThisInitialized","ewmaFast","ewmaSlow","abrEwmaFastLive","abrEwmaSlowLive","abrEwmaFastVoD","abrEwmaSlowVoD","abrEwmaDefaultEstimate","requestDelay","loadRate","realBitrate","expectedLen","fragLoadedDelay","bufferStarvationDelay","fragLevelNextLoadedDelay","minAutoLevel","levelNextBitrate","abrMaxWithRealBitrate","loadedBytes","loadedDuration","fragLoadingProcessingMs","bwEstimate","bitrateTestDelay","_findBestLevel","currentFragDuration","currentBw","maxAutoLevel","maxFetchDuration","bwFactor","bwUpFactor","avgDuration","adjustedbw","fetchDuration","forcedAutoLevel","bwEstimator","nextABRAutoLevel","_nextABRAutoLevel","avgbw","bestLevel","abrBandWidthFactor","abrBandWidthUpFactor","maxStarvationDelay","maxLoadingDelay","BufferController","_msDuration","_levelDuration","_levelTargetDuration","_live","_objectUrl","_needsFlush","_needsEos","audioTimestampOffset","bufferCodecEventsExpected","_bufferCodecEventsTotal","mediaSource","appending","appendError","flushBufferCounter","pendingTracks","sourceBuffer","flushRange","_onMediaSourceOpen","checkPendingTracks","_onMediaSourceClose","_onMediaSourceEnded","_onSBUpdateEnd","audioBuffer","timestampOffset","doFlush","checkEos","sbSet","sb","doAppending","updateMediaElementDuration","flushLiveBackBuffer","_onSBUpdateError","BUFFER_APPENDING_ERROR","onLevelPtsUpdated","updating","codecEvents","onMediaAttaching","endOfStream","removeAttribute","pendingTracksCount","createSourceBuffers","onBufferReset","removeSourceBuffer","onBufferCodecs","mimeType","addSourceBuffer","BUFFER_ADD_CODEC_ERROR","onBufferAppending","onBufferEos","onBufferFlushing","liveBackBufferLength","bufferTypes","targetBackBufferPosition","bufferType","removeBufferRange","onLevelUpdated","liveDurationInfinity","flushBuffer","appendBuffer","BUFFER_APPEND_ERROR","appendErrorMaxRetry","sbType","bufStart","bufEnd","removeStart","removeEnd","CapLevelController","autoLevelCapping","restrictedLevels","clientRect","capLevelToPlayerSize","stopCapping","onFpsDropLevelCapping","isLevelAllowed","droppedLevel","HTMLVideoElement","startCapping","detectPlayerSize","levelsLength","getMaxLevel","streamController","capLevelIndex","validLevels","getMaxLevelByMediaSize","mediaWidth","mediaHeight","getDimensions","boundsRect","getBoundingClientRect","bottom","maxLevelIndex","devicePixelRatio","contentScaleFactor","FPSController","isVideoPlaybackQualityAvailable","capLevelOnFPSDrop","getVideoPlaybackQuality","checkFPSInterval","fpsDroppedMonitoringPeriod","checkFPS","decodedFrames","droppedFrames","lastTime","currentPeriod","currentDropped","lastDroppedFrames","currentDecoded","lastDecodedFrames","droppedFPS","totalDroppedFrames","fpsDroppedMonitoringThreshold","videoPlaybackQuality","totalVideoFrames","droppedVideoFrames","webkitDecodedFrameCount","webkitDroppedFrameCount","XhrLoader","xhrSetup","retryTimeout","loadInternal","readystatechange","currentTarget","lengthComputable","AudioTrackController","_trackId","_selectDefaultTrack","trackIdBlacklist","_selectAudioGroup","onAudioTrackLoaded","updatePeriodMs","_handleLoadError","_setAudioTrack","newId","_loadTrackDetailsIfNeeded","_updateTrack","_selectInitialAudioTrack","currentAudioTrack","defaultTracks","trackFound","traverseTracks","_needsTrackLoading","previousId","_this$tracks$previous","language","AudioStreamController","waitingFragment","videoTrackCC","waitingVideoCC","onInitPtsFound","demuxerId","trackDetails","mainBufferInfo","maxConfigBuffer","audioSwitch","CC","findFragWithCC","loadIdx","fragLoadIdx","nextBuffered","foundFrag","isSeeking","waitingFrag","waitingFragCC","clearWaitingFragment","onAudioTracksUpdated","appendObj","pendingData","appendOnBufferFlush","vttcue","directionSetting","lr","rl","alignSetting","middle","findAlignSetting","cobj","baseObj","hasBeenReset","_pauseOnExit","_endTime","_text","_region","_vertical","_snapToLines","_line","_lineAlign","_position","_positionAlign","_size","_align","setting","findDirectionSetting","displayState","getCueAsHTML","WebVTT","convertCueToDOMTree","VTTParser","regionList","Settings","parseOptions","keyValueDelim","groupDelim","dflt","defaultKey","alt","center","parseCue","oInput","consumeTimeStamp","computeSeconds","parseTimeStamp","skipWhitespace","region","vals0","vertical","lineAlign","snapToLines","consumeCueSettings","fixLineBreaks","collectNextLine","alreadyCollectedLine","hasSubstring","oncue","onflush","newCue","captionScreen","indenting","rows","uchar","cueStartTime","VerboseLevel","specialCea608CharsCodes","getCharForByte","NR_ROWS","NR_COLS","rowsLowCh1","rowsHighCh1","rowsLowCh2","rowsHighCh2","backgroundColors","CaptionsLogger","verboseLevel","severity","numArrayToHexArray","numArray","hexArray","PenState","foreground","italics","flash","setStyles","attribs","isDefault","newPenState","StyledUnicodeChar","penState","setChar","setPenState","newChar","Row","currPenState","_proto4","setCursor","absPos","moveCursor","relPos","newPos","backSpace","insertChar","char","clearFromPos","startPos","clearToEndOfRow","getTextString","setPenStyles","CaptionScreen","currRow","nrRollUpRows","lastOutputScreen","_proto5","setPen","INFO","setPAC","pacData","newRow","topRowIndex","prevLineTime","prevPos","setBkgData","bkgData","setRollUpRows","nrRows","rollUp","TEXT","getDisplayText","topRow","asOneRow","displayText","rowNr","rowText","getTextAndFormat","Cea608Channel","channelNumber","outputFilter","chNr","displayedMemory","nonDisplayedMemory","currRollUpRow","writeScreen","newHandler","setMode","newMode","insertChars","screen","outputDataUpdate","ccRCL","ccBS","ccAOF","ccAON","ccDER","ccRU","ccFON","ccRDC","ccTR","ccRTD","ccEDM","ccCR","ccENM","ccEOC","ccTO","nrCols","ccMIDROW","colorIndex","dispatch","dispatchCue","cueSplitAtTime","setLastCmd","cmdHistory","hasCmdRepeated","Cea608Parser","field","out1","out2","channels","currentChannel","addData","byteList","cmdFound","charsFound","DATA","parseCmd","parseMidrow","parsePAC","parseBackgroundAttributes","parseChars","currChNr","WARNING","interpretPAC","pacIndex","channelNr","charCodes","charCode1","oneCode","hexCodes","OutputFilter","timelineController","cueRanges","addCues","createCaptionsTrack","inputString","searchString","WebVTTParser","vttByteArray","syncPTS","vttCCs","callBack","errorCallBack","parsingError","vttLines","cueTime","mpegTs","localTime","presentationTime","inHeader","timestampMap","currCC","cueOffset","prevCC","presentationOffset","calculateOffset","onparsingerror","timeString","mins","hours","cueString2millis","canReuseVttTextTrack","inUseTrack","manifestTrack","textTrack1","textTrack2","TimelineController","Cues","unparsedVttFrags","captionsTracks","nonNativeCaptionsTracks","captionsProperties","cea608Parser1","cea608Parser2","lastSn","cueHandler","captionsTextTrack1Label","languageCode","captionsTextTrack1LanguageCode","captionsTextTrack2Label","captionsTextTrack2LanguageCode","textTrack3","captionsTextTrack3Label","captionsTextTrack3LanguageCode","textTrack4","captionsTextTrack4Label","captionsTextTrack4LanguageCode","enableCEA708Captions","channel1","timeline_controller_assertThisInitialized","channel2","channel3","channel4","cueRange","renderTextTracksNatively","getExistingTrack","createNativeTrack","createNonNativeTrack","_captionsProperties$t","existingTrack","createTextTrack","trackProperties","closedCaptions","_cleanTracks","enableWebVTT","sameTracks","inUseTracks","subtitleDisplay","tracksList","subtitleTrack","captionsTrack","instreamIdMatch","decryptData","_parseVTTs","currentTrack","getCueById","textTrackCue","onFragDecrypted","onFragParsingUserdata","ccBytes","ccdatas","extractCea608Data","actualCCBytes","tmpByte","ccbyte1","ccbyte2","ccType","filterSubtitleTracks","textTrackList","SubtitleTrackController","KeySystems","queuedDefaultTrack","trackChangeListener","_onTextTracksChanged","useTextTrackPolling","subtitlePollingInterval","subtitleTracks","onSubtitleTrackLoaded","_clearReloadTimer","_loadCurrentTrack","_toggleTrackModes","nextTrack","_setSubtitleTrackInternal","subtitleTrackId","SubtitleStreamController","tracksBuffered","currentTrackId","lastAVStart","_onMediaSeeking","subtitle_stream_controller_assertThisInitialized","onSubtitleFragProcessed","fragStart","fragEnd","onSubtitleTracksUpdated","onSubtitleTrackSwitch","referenceStart","frags","mergeSubtitlePlaylists","_getBuffered","requestMediaKeySystemAccess","EMEController","_widevineLicenseUrl","_licenseXhrSetup","_emeEnabled","_requestMediaKeySystemAccess","_drmSystemOptions","_mediaKeysList","_media","_hasSetMediaKeys","_requestLicenseFailureCount","mediaKeysPromise","_onMediaEncrypted","initDataType","KEY_SYSTEM_ERROR","KEY_SYSTEM_NO_KEYS","finallySetKeyAndStartSession","mediaKeys","_attemptSetMediaKeys","_generateRequestWithPreferredKeySession","widevineLicenseUrl","licenseXhrSetup","emeEnabled","requestMediaKeySystemAccessFunc","drmSystemOptions","getLicenseServerUrl","keySystem","WIDEVINE","_attemptKeySystemAccess","audioCodecs","videoCodecs","mediaKeySystemConfigs","baseConfig","audioCapabilities","videoCapabilities","robustness","audioRobustness","videoRobustness","createWidevineMediaKeySystemConfigurations","getSupportedMediaKeySystemConfigurations","keySystemAccessPromise","mediaKeySystemAccess","_onMediaKeySystemAccessObtained","mediaKeysListItem","mediaKeysSessionInitialized","mediaKeySystemDomain","createMediaKeys","_onMediaKeysCreated","mediaKeysSession","createSession","_onNewMediaKeySession","keySession","sessionId","_onKeySessionMessage","_requestLicense","keysListItem","setMediaKeys","_this6","KEY_SYSTEM_NO_ACCESS","KEY_SYSTEM_NO_SESSION","KEY_SYSTEM_NO_INIT_DATA","generateRequest","_createLicenseXhr","keyMessage","_onLicenseRequestReadyStageChange","KEY_SYSTEM_LICENSE_REQUEST_FAILED","attemptsLeft","_generateLicenseRequestChallenge","challenge","onMediaDetached","mediaKeysList","hlsDefaultConfig","lowBufferWatchdogPeriod","abrController","bufferController","capLevelController","fpsController","minAutoBitrate","__USE_SUBTITLES__","subtitleStreamController","subtitleTrackController","audioStreamController","audioTrackController","emeController","Hls","userConfig","_Observer","_autoLevelCapping","levelController","networkControllers","coreComponents","hls_objectSpread","hls_assertThisInitialized","playListLoader","fragmentLoader","keyLoader","id3TrackController","Controller","SourceBuffer","WebKitSourceBuffer","sourceBufferValidAPI","__VERSION__","detachMedia","component","recoverMediaError","manualLevel","shouldStartCapping","newCapLevelToPlayerSize","audioTrackId","isFiniteNumber","_get_self_scope__WEBPACK_IMPORTED_MODULE_0__","fakeLogger","exportedLogger","formatMsg","consolePrintFn","debugConfig","exportLoggerFunctions","buf2str","_abortFlag","m3u8provider","tsListProvider","setM3U8Provider","provider1","urlParts","rootHash","abortFlag"],"version":3,"file":"index.6b10736e.js.map"} \ No newline at end of file diff --git a/index.html b/index.html index 5a13809..2096d59 100644 --- a/index.html +++ b/index.html @@ -1,4 +1,4 @@ -<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>HLS over IPFS video player

HLS over IPFS video player

How to use:

Accepts three query parameters:

  • hash: required. The IPFS hash of a folder containing an HLS playlist and its files.
  • source: optional, defaults to master.m3u8.
  • title: optional, allows overriding the browser tab title.
  • time: optional, start the video at this many seconds

Usage Examples:

How to make compatible videos:

Here is a Bash script you can use to encode a video into a HLS folder with a playlist:

#!/usr/bin/env bash
+HLS over IPFS video player  

HLS over IPFS video player

How to use:

Accepts three query parameters:

  • hash: required. The IPFS hash of a folder containing an HLS playlist and its files.
  • source: optional, defaults to master.m3u8.
  • title: optional, allows overriding the browser tab title.
  • time: optional, start the video at this many seconds

Usage Examples:

How to make compatible videos:

Here is a Bash script you can use to encode a video into a HLS folder with a playlist:

#!/usr/bin/env bash
 outdir=${1%.*}
 mkdir "$outdir"
 pushd "$outdir"